openmw-tes3coop/components/openmw-mp/Packets/PacketPreInit.cpp

95 lines
2.8 KiB
C++
Raw Normal View History

2017-03-05 08:46:11 +00:00
#include <components/openmw-mp/NetworkMessages.hpp>
#include <components/openmw-mp/Log.hpp>
2017-03-05 08:46:11 +00:00
#include "PacketPreInit.hpp"
mwmp::PacketPreInit::PacketPreInit(RakNet::RakPeerInterface *peer) : BasePacket(peer)
{
packetID = ID_GAME_PREINIT;
}
2017-03-06 10:40:53 +00:00
void mwmp::PacketPreInit::Packet(RakNet::BitStream *bs, bool send)
2017-03-05 08:46:11 +00:00
{
BasePacket::Packet(bs, send);
2017-03-05 08:46:11 +00:00
const RakNet::BitSize_t packetSize = bs->GetNumberOfBytesUsed();
uint32_t expectedPacketSize = BasePacket::headerSize() + sizeof(uint32_t);
if (!send && expectedPacketSize > packetSize)
{
LOG_MESSAGE(Log::LOG_ERROR, "Wrong packet size %d when expected %d", packetSize, expectedPacketSize);
packetValid = false;
return;
}
uint32_t numberOfChecksums = checksums->size();
RW(numberOfChecksums, send);
2017-05-02 15:31:30 +00:00
if (numberOfChecksums > maxPlugins)
2017-03-05 08:46:11 +00:00
{
LOG_MESSAGE(Log::LOG_ERROR, "Wrong number of checksums %d when maximum is %d", numberOfChecksums, maxPlugins);
packetValid = false;
return;
}
struct NAS
{
uint32_t hashN;
uint32_t strSize;
};
std::vector<NAS> NumberOfHashesAndStrSizes(numberOfChecksums);
2017-05-02 15:31:30 +00:00
PluginContainer::const_iterator checksumIt = checksums->begin();
2017-05-02 15:31:30 +00:00
for (auto &&nas : NumberOfHashesAndStrSizes)
{
if (send)
2017-03-05 08:46:11 +00:00
{
nas.strSize = checksumIt->first.size();
nas.hashN = checksumIt++->second.size();
2017-03-05 08:46:11 +00:00
}
RW(nas, send);
expectedPacketSize += nas.strSize + nas.hashN;
if (nas.strSize > pluginNameMaxLength)
LOG_MESSAGE(Log::LOG_ERROR, "Wrong string length %d when maximum length is %d",
nas.strSize,
pluginNameMaxLength);
else if (nas.hashN > maxHashes)
LOG_MESSAGE(Log::LOG_ERROR, "Wrong number of hashes %d when maximum is %d", nas.hashN, maxHashes);
else
continue;
packetValid = false;
return;
}
if (!send && expectedPacketSize == packetSize) // server accepted plugin list via sending "empty" packet
return;
if (!send && expectedPacketSize > packetSize)
{
LOG_MESSAGE(Log::LOG_ERROR, "Wrong packet size %d when expected %d", packetSize, expectedPacketSize);
packetValid = false;
return;
}
checksums->resize(numberOfChecksums);
auto numberOfHashesIt = NumberOfHashesAndStrSizes.cbegin();
for (auto &&checksum : *checksums)
{
RW(checksum.first, send, false, numberOfHashesIt->strSize);
checksum.second.resize(numberOfHashesIt->hashN);
for (auto &&hash : checksum.second)
RW(hash, send);
++numberOfHashesIt;
2017-03-05 08:46:11 +00:00
}
}
2017-03-06 10:40:53 +00:00
void mwmp::PacketPreInit::setChecksums(mwmp::PacketPreInit::PluginContainer *checksums)
{
this->checksums = checksums;
}