@ -212,18 +212,15 @@ void Networking::processWorldstatePacket(RakNet::Packet *packet)
}
}
void Networking : : update ( RakNet : : Packet * packet )
bool Networking : : preInit ( RakNet : : Packet * packet , RakNet : : BitStream & bsIn )
{
{
Player * player = Players : : getPlayer ( packet - > guid ) ;
if ( packet - > data [ 0 ] ! = ID_GAME_PREINIT )
RakNet : : BitStream bsIn ( & packet - > data [ 1 ] , packet - > length , false ) ;
bsIn . IgnoreBytes ( ( unsigned int ) RakNet : : RakNetGUID : : size ( ) ) ; // Ignore GUID from received packet
if ( player = = nullptr )
{
if ( packet - > data [ 0 ] = = ID_GAME_PREINIT )
{
{
LOG_MESSAGE_SIMPLE ( Log : : LOG_WARN , " %s sent wrong first packet (ID_GAME_PREINIT was expected) " ,
packet - > systemAddress . ToString ( ) ) ;
peer - > CloseConnection ( packet - > systemAddress , true ) ;
}
DEBUG_PRINTF ( " ID_GAME_PREINIT " ) ;
DEBUG_PRINTF ( " ID_GAME_PREINIT " ) ;
PacketPreInit : : PluginContainer plugins ;
PacketPreInit : : PluginContainer plugins ;
@ -232,11 +229,11 @@ void Networking::update(RakNet::Packet *packet)
packetPreInit . setChecksums ( & plugins ) ;
packetPreInit . setChecksums ( & plugins ) ;
packetPreInit . Read ( ) ;
packetPreInit . Read ( ) ;
if ( ! packetPreInit . isPacketValid ( ) )
if ( ! packetPreInit . isPacketValid ( ) | | plugins . empty ( ) )
{
{
LOG_APPEND ( Log : : LOG_ERROR , " Invalid packetPreInit " ) ;
LOG_APPEND ( Log : : LOG_ERROR , " Invalid packetPreInit " ) ;
peer - > CloseConnection ( packet - > systemAddress , false ) ; // close connection without notification
peer - > CloseConnection ( packet - > systemAddress , false ) ; // close connection without notification
return ;
return false ;
}
}
auto plugin = plugins . begin ( ) ;
auto plugin = plugins . begin ( ) ;
@ -257,7 +254,6 @@ void Networking::update(RakNet::Packet *packet)
// the server
// the server
if ( it = = hashList . end ( ) )
if ( it = = hashList . end ( ) )
break ;
break ;
}
}
else // name is incorrect
else // name is incorrect
break ;
break ;
@ -280,20 +276,20 @@ void Networking::update(RakNet::Packet *packet)
PacketPreInit : : PluginContainer tmp ;
PacketPreInit : : PluginContainer tmp ;
packetPreInit . setChecksums ( & tmp ) ;
packetPreInit . setChecksums ( & tmp ) ;
packetPreInit . Send ( packet - > systemAddress ) ;
packetPreInit . Send ( packet - > systemAddress ) ;
Players : : newPlayer ( packet - > guid ) ; // create player if connection allowed
playerPacketController - > SetStream ( & bsIn , nullptr ) ; // and request handshake
playerPacketController - > GetPacket ( ID_HANDSHAKE ) - > RequestData ( packet - > guid ) ;
return true ;
}
}
return ;
}
playerPacketController - > SetStream ( & bsIn , 0 ) ;
playerPacketController - > GetPacket ( ID_HANDSHAKE ) - > RequestData ( packet - > guid ) ;
return false ;
Players : : newPlayer ( packet - > guid ) ;
player = Players : : getPlayer ( packet - > guid ) ;
return ;
}
}
else if ( playerPacketController - > ContainsPacket ( packet - > data [ 0 ] ) )
void Networking : : update ( RakNet : : Packet * packet , RakNet : : BitStream & bsIn )
{
if ( playerPacketController - > ContainsPacket ( packet - > data [ 0 ] ) )
{
{
playerPacketController - > SetStream ( & bsIn , 0 ) ;
playerPacketController - > SetStream ( & bsIn , nullptr ) ;
processPlayerPacket ( packet ) ;
processPlayerPacket ( packet ) ;
}
}
else if ( actorPacketController - > ContainsPacket ( packet - > data [ 0 ] ) )
else if ( actorPacketController - > ContainsPacket ( packet - > data [ 0 ] ) )
@ -531,10 +527,19 @@ int Networking::mainLoop()
case ID_UNCONNECTED_PING :
case ID_UNCONNECTED_PING :
break ;
break ;
default :
default :
update ( packet ) ;
{
RakNet : : BitStream bsIn ( & packet - > data [ 1 ] , packet - > length , false ) ;
bsIn . IgnoreBytes ( ( unsigned int ) RakNet : : RakNetGUID : : size ( ) ) ; // Ignore GUID from received packet
if ( Players : : isPlayerExists ( packet - > guid ) )
update ( packet , bsIn ) ;
else
preInit ( packet , bsIn ) ;
break ;
break ;
}
}
}
}
}
TimerAPI : : Tick ( ) ;
TimerAPI : : Tick ( ) ;
this_thread : : sleep_for ( chrono : : milliseconds ( 1 ) ) ;
this_thread : : sleep_for ( chrono : : milliseconds ( 1 ) ) ;
}
}