Add asset packet + AO NetEncode
This commit is contained in:
parent
7a1a41932a
commit
5248cc718f
@ -317,6 +317,10 @@ class Server : public QObject {
|
||||
* @brief The minimum time between IC messages, in milliseconds.
|
||||
*/
|
||||
int message_floodguard;
|
||||
/**
|
||||
* @brief URL send to the client during handshake to set the remote repository URL.
|
||||
*/
|
||||
QUrl asset_url;
|
||||
|
||||
public slots:
|
||||
/**
|
||||
|
@ -265,6 +265,10 @@ void AOClient::sendPacket(AOPacket packet)
|
||||
#ifdef NET_DEBUG
|
||||
qDebug() << "Sent packet:" << packet.header << ":" << packet.contents;
|
||||
#endif
|
||||
packet.contents.replaceInStrings("#", "<num>")
|
||||
.replaceInStrings("%", "<percent>")
|
||||
.replaceInStrings("$", "<dollar>")
|
||||
.replaceInStrings("&", "<and>");
|
||||
socket->write(packet.toUtf8());
|
||||
socket->flush();
|
||||
}
|
||||
|
@ -63,6 +63,9 @@ void AOClient::pktSoftwareId(AreaData* area, int argc, QStringList argv, AOPacke
|
||||
|
||||
sendPacket("PN", {QString::number(server->player_count), server->max_players});
|
||||
sendPacket("FL", feature_list);
|
||||
|
||||
QByteArray asset_url = server->asset_url.toEncoded(QUrl::EncodeSpaces);
|
||||
sendPacket("ASS", {asset_url});
|
||||
}
|
||||
|
||||
void AOClient::pktBeginLoad(AreaData* area, int argc, QStringList argv, AOPacket packet)
|
||||
|
@ -295,6 +295,9 @@ void Server::loadServerConfig()
|
||||
message_floodguard = config.value("message_floodguard", "250").toInt(&message_floodguard_conversion_success);
|
||||
if (!message_floodguard_conversion_success)
|
||||
message_floodguard = 30;
|
||||
asset_url = config.value("asset_url","").toString().toUtf8();
|
||||
if (!asset_url.isValid())
|
||||
asset_url = NULL;
|
||||
config.endGroup();
|
||||
|
||||
//Load dice values
|
||||
|
Loading…
Reference in New Issue
Block a user