mirror of
https://github.com/TrinityCore/TrinityCore.git
synced 2026-01-25 11:21:58 +01:00
Battle.net/Packets: Added packet name mapping for logging
This commit is contained in:
@@ -18,6 +18,17 @@
|
||||
#include "Session.h"
|
||||
#include "FriendsPackets.h"
|
||||
|
||||
void Battlenet::Friends::GetFriendsOfFriend::Read()
|
||||
{
|
||||
uint8 unk = _stream.Read<uint8>(2);
|
||||
uint32 unk1 = _stream.Read<uint32>(32);
|
||||
}
|
||||
|
||||
std::string Battlenet::Friends::GetFriendsOfFriend::ToString() const
|
||||
{
|
||||
return "Battlenet::Friends::GetFriendsOfFriend";
|
||||
}
|
||||
|
||||
void Battlenet::Friends::SocialNetworkCheckConnected::Read()
|
||||
{
|
||||
SocialNetworkId = _stream.Read<uint32>(32);
|
||||
@@ -33,52 +44,6 @@ void Battlenet::Friends::SocialNetworkCheckConnected::CallHandler(Session* sessi
|
||||
session->HandleSocialNetworkCheckConnected(*this);
|
||||
}
|
||||
|
||||
void Battlenet::Friends::SocialNetworkConnect::Read()
|
||||
{
|
||||
int32 unk1 = _stream.Read<int32>(32);
|
||||
uint32 size1 = _stream.Read<uint32>(9);
|
||||
auto data1 = _stream.ReadBytes(size1);
|
||||
uint32 size2 = _stream.Read<uint32>(7);
|
||||
auto data2 = _stream.ReadBytes(size2);
|
||||
}
|
||||
|
||||
std::string Battlenet::Friends::SocialNetworkConnect::ToString() const
|
||||
{
|
||||
return "Battlenet::Friends::SocialNetworkConnect";
|
||||
}
|
||||
|
||||
std::string Battlenet::Friends::SocialNetworkConnectResult::ToString() const
|
||||
{
|
||||
return "Battlenet::Friends::SocialNetworkConnectResult";
|
||||
}
|
||||
|
||||
void Battlenet::Friends::SocialNetworkConnectResult::Write()
|
||||
{
|
||||
}
|
||||
|
||||
std::string Battlenet::Friends::SocialNetworkCheckConnectedResult::ToString() const
|
||||
{
|
||||
return "Battlenet::Friends::SocialNetworkCheckConnectedResult";
|
||||
}
|
||||
|
||||
void Battlenet::Friends::SocialNetworkCheckConnectedResult::Write()
|
||||
{
|
||||
_stream.Write(0, 23); // Ignored
|
||||
_stream.Write(4601, 16); // Result, 4601 = The Facebook add friend service is unavailable right now. Please try again later.
|
||||
_stream.Write(SocialNetworkId, 32);
|
||||
}
|
||||
|
||||
void Battlenet::Friends::GetFriendsOfFriend::Read()
|
||||
{
|
||||
uint8 unk = _stream.Read<uint8>(2);
|
||||
uint32 unk1 = _stream.Read<uint32>(32);
|
||||
}
|
||||
|
||||
std::string Battlenet::Friends::GetFriendsOfFriend::ToString() const
|
||||
{
|
||||
return "Battlenet::Friends::GetFriendsOfFriend";
|
||||
}
|
||||
|
||||
void Battlenet::Friends::RealIdFriendInvite::Read()
|
||||
{
|
||||
_stream.Read<uint32>(32);
|
||||
@@ -159,3 +124,15 @@ void Battlenet::Friends::FriendInviteResult::Write()
|
||||
_stream.WriteString("Testing3", 7, 2);
|
||||
}
|
||||
}
|
||||
|
||||
std::string Battlenet::Friends::SocialNetworkCheckConnectedResult::ToString() const
|
||||
{
|
||||
return "Battlenet::Friends::SocialNetworkCheckConnectedResult";
|
||||
}
|
||||
|
||||
void Battlenet::Friends::SocialNetworkCheckConnectedResult::Write()
|
||||
{
|
||||
_stream.Write(0, 23); // Ignored
|
||||
_stream.Write(Result, 16);
|
||||
_stream.Write(SocialNetworkId, 32);
|
||||
}
|
||||
|
||||
@@ -34,9 +34,9 @@ namespace Battlenet
|
||||
CMSG_BLOCK_ADD = 0x08, // Not implemented
|
||||
CMSG_BLOCK_REMOVE = 0x0A, // Not implemented
|
||||
CMSG_GET_FRIENDS_OF_FRIEND = 0x0B, // Not implemented
|
||||
CMSG_GET_SOCIAL_NETWORK_FRIENDS = 0x0D, // Not implemented
|
||||
CMSG_SOCIAL_NETWORK_CONNECT = 0x0F, // Not implemented
|
||||
CMSG_SOCIAL_NETWORK_DISCONNECT = 0x11, // Not implemented
|
||||
CMSG_GET_SOCIAL_NETWORK_FRIENDS = 0x0D, // Won't support
|
||||
CMSG_SOCIAL_NETWORK_CONNECT = 0x0F, // Won't support
|
||||
CMSG_SOCIAL_NETWORK_DISCONNECT = 0x11, // Won't support
|
||||
CMSG_SOCIAL_NETWORK_CHECK_CONNECTED = 0x13,
|
||||
CMSG_REALID_FRIEND_INVITE = 0x16, // Not implemented
|
||||
|
||||
@@ -46,37 +46,26 @@ namespace Battlenet
|
||||
SMSG_BLOCK_INVITE_NOTIFY = 0x07, // Not implemented
|
||||
SMSG_BLOCK_ADD_FAILURE = 0x09, // Not implemented
|
||||
SMSG_FRIENDS_OF_FRIEND = 0x0C, // Not implemented
|
||||
SMSG_SOCIAL_NETWORK_FRIENDS = 0x0E, // Not implemented
|
||||
SMSG_SOCIAL_NETWORK_CONNECT_RESULT = 0x10, // Not implemented
|
||||
SMSG_SOCIAL_NETWORK_DISCONNECT_RESULT = 0x12, // Not implemented
|
||||
SMSG_SOCIAL_NETWORK_FRIENDS = 0x0E, // Won't support
|
||||
SMSG_SOCIAL_NETWORK_CONNECT_RESULT = 0x10, // Won't support
|
||||
SMSG_SOCIAL_NETWORK_DISCONNECT_RESULT = 0x12, // Won't support
|
||||
SMSG_SOCIAL_NETWORK_CHECK_CONNECTED_RESULT = 0x14,
|
||||
SMSG_MAX_FRIENDS_NOTIFY = 0x15, // Not implemented
|
||||
SMSG_FRIENDS_LIST_NOTIFY_3 = 0x18 // Not implemented
|
||||
};
|
||||
|
||||
class SocialNetworkConnect final : public ClientPacket
|
||||
class GetFriendsOfFriend final : public ClientPacket
|
||||
{
|
||||
public:
|
||||
SocialNetworkConnect(PacketHeader const& header, BitStream& stream) : ClientPacket(header, stream)
|
||||
GetFriendsOfFriend(PacketHeader const& header, BitStream& stream) : ClientPacket(header, stream)
|
||||
{
|
||||
ASSERT(header == PacketHeader(CMSG_SOCIAL_NETWORK_CONNECT, FRIENDS) && "Invalid packet header for SocialNetworkConnect");
|
||||
ASSERT(header == PacketHeader(CMSG_GET_FRIENDS_OF_FRIEND, FRIENDS) && "Invalid packet header for GetFriendsOfFriend");
|
||||
}
|
||||
|
||||
void Read() override;
|
||||
std::string ToString() const override;
|
||||
};
|
||||
|
||||
class SocialNetworkConnectResult final : public ServerPacket
|
||||
{
|
||||
public:
|
||||
SocialNetworkConnectResult() : ServerPacket(PacketHeader(SMSG_SOCIAL_NETWORK_CONNECT_RESULT, FRIENDS))
|
||||
{
|
||||
}
|
||||
|
||||
void Write() override;
|
||||
std::string ToString() const override;
|
||||
};
|
||||
|
||||
class SocialNetworkCheckConnected final : public ClientPacket
|
||||
{
|
||||
public:
|
||||
@@ -92,43 +81,6 @@ namespace Battlenet
|
||||
uint32 SocialNetworkId;
|
||||
};
|
||||
|
||||
class SocialNetworkCheckConnectedResult final : public ServerPacket
|
||||
{
|
||||
public:
|
||||
SocialNetworkCheckConnectedResult() : ServerPacket(PacketHeader(SMSG_SOCIAL_NETWORK_CHECK_CONNECTED_RESULT, FRIENDS)),
|
||||
SocialNetworkId(0)
|
||||
{
|
||||
}
|
||||
|
||||
void Write() override;
|
||||
std::string ToString() const override;
|
||||
|
||||
uint32 SocialNetworkId;
|
||||
};
|
||||
|
||||
class GetFriendsOfFriend final : public ClientPacket
|
||||
{
|
||||
public:
|
||||
GetFriendsOfFriend(PacketHeader const& header, BitStream& stream) : ClientPacket(header, stream)
|
||||
{
|
||||
ASSERT(header == PacketHeader(CMSG_GET_FRIENDS_OF_FRIEND, FRIENDS) && "Invalid packet header for GetFriendsOfFriend");
|
||||
}
|
||||
|
||||
void Read() override;
|
||||
std::string ToString() const override;
|
||||
};
|
||||
|
||||
class FriendsOfFriend final : public ServerPacket
|
||||
{
|
||||
public:
|
||||
FriendsOfFriend() : ServerPacket(PacketHeader(SMSG_FRIENDS_OF_FRIEND, FRIENDS))
|
||||
{
|
||||
}
|
||||
|
||||
void Write() override;
|
||||
std::string ToString() const override;
|
||||
};
|
||||
|
||||
class RealIdFriendInvite final : public ClientPacket
|
||||
{
|
||||
public:
|
||||
@@ -154,6 +106,32 @@ namespace Battlenet
|
||||
void Write() override;
|
||||
std::string ToString() const override;
|
||||
};
|
||||
|
||||
class FriendsOfFriend final : public ServerPacket
|
||||
{
|
||||
public:
|
||||
FriendsOfFriend() : ServerPacket(PacketHeader(SMSG_FRIENDS_OF_FRIEND, FRIENDS))
|
||||
{
|
||||
}
|
||||
|
||||
void Write() override;
|
||||
std::string ToString() const override;
|
||||
};
|
||||
|
||||
class SocialNetworkCheckConnectedResult final : public ServerPacket
|
||||
{
|
||||
public:
|
||||
SocialNetworkCheckConnectedResult() : ServerPacket(PacketHeader(SMSG_SOCIAL_NETWORK_CHECK_CONNECTED_RESULT, FRIENDS)),
|
||||
Result(4601), SocialNetworkId(0) // 4601 = The Facebook add friend service is unavailable right now. Please try again later.
|
||||
{
|
||||
}
|
||||
|
||||
void Write() override;
|
||||
std::string ToString() const override;
|
||||
|
||||
uint16 Result;
|
||||
uint32 SocialNetworkId;
|
||||
};
|
||||
}
|
||||
}
|
||||
|
||||
|
||||
@@ -1,86 +0,0 @@
|
||||
/*
|
||||
* Copyright (C) 2008-2014 TrinityCore <http://www.trinitycore.org/>
|
||||
*
|
||||
* This program is free software; you can redistribute it and/or modify it
|
||||
* under the terms of the GNU General Public License as published by the
|
||||
* Free Software Foundation; either version 2 of the License, or (at your
|
||||
* option) any later version.
|
||||
*
|
||||
* This program is distributed in the hope that it will be useful, but WITHOUT
|
||||
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
|
||||
* FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
|
||||
* more details.
|
||||
*
|
||||
* You should have received a copy of the GNU General Public License along
|
||||
* with this program. If not, see <http://www.gnu.org/licenses/>.
|
||||
*/
|
||||
|
||||
#ifndef PacketFactory_h__
|
||||
#define PacketFactory_h__
|
||||
|
||||
#include "Packets.h"
|
||||
#include <map>
|
||||
|
||||
namespace Battlenet
|
||||
{
|
||||
class PacketFactory
|
||||
{
|
||||
typedef ClientPacket*(*PacketCreateFn)(PacketHeader const& header, BitStream& stream);
|
||||
|
||||
public:
|
||||
ClientPacket* Create(PacketHeader const& header, BitStream& stream)
|
||||
{
|
||||
auto creator = _creators.find(header);
|
||||
if (creator == _creators.end())
|
||||
return nullptr;
|
||||
|
||||
ClientPacket* packet = creator->second(header, stream);
|
||||
packet->Read();
|
||||
return packet;
|
||||
}
|
||||
|
||||
static PacketFactory& Instance()
|
||||
{
|
||||
static PacketFactory instance;
|
||||
return instance;
|
||||
}
|
||||
|
||||
private:
|
||||
PacketFactory()
|
||||
{
|
||||
_creators[PacketHeader(Authentication::CMSG_LOGON_REQUEST, AUTHENTICATION)] = &New<Authentication::LogonRequest>;
|
||||
_creators[PacketHeader(Authentication::CMSG_RESUME_REQUEST, AUTHENTICATION)] = &New<Authentication::ResumeRequest>;
|
||||
_creators[PacketHeader(Authentication::CMSG_PROOF_RESPONSE, AUTHENTICATION)] = &New<Authentication::ProofResponse>;
|
||||
|
||||
_creators[PacketHeader(Connection::CMSG_PING, CONNECTION)] = &New<Connection::Ping>;
|
||||
_creators[PacketHeader(Connection::CMSG_ENABLE_ENCRYPTION, CONNECTION)] = &New<Connection::EnableEncryption>;
|
||||
_creators[PacketHeader(Connection::CMSG_LOGOUT_REQUEST, CONNECTION)] = &New<Connection::LogoutRequest>;
|
||||
_creators[PacketHeader(Connection::CMSG_DISCONNECT_REQUEST, CONNECTION)] = &New<Connection::DisconnectRequest>;
|
||||
_creators[PacketHeader(Connection::CMSG_CONNECTION_CLOSING, CONNECTION)] = &New<Connection::ConnectionClosing>;
|
||||
|
||||
_creators[PacketHeader(WoWRealm::CMSG_LIST_SUBSCRIBE_REQUEST, WOWREALM)] = &New<WoWRealm::ListSubscribeRequest>;
|
||||
_creators[PacketHeader(WoWRealm::CMSG_LIST_UNSUBSCRIBE, WOWREALM)] = &New<WoWRealm::ListUnsubscribe>;
|
||||
_creators[PacketHeader(WoWRealm::CMSG_JOIN_REQUEST_V2, WOWREALM)] = &New<WoWRealm::JoinRequestV2>;
|
||||
|
||||
_creators[PacketHeader(Friends::CMSG_SOCIAL_NETWORK_CHECK_CONNECTED, FRIENDS)] = &New<Friends::SocialNetworkCheckConnected>;
|
||||
_creators[PacketHeader(Friends::CMSG_SOCIAL_NETWORK_CONNECT, FRIENDS)] = &New<Friends::SocialNetworkConnect>;
|
||||
_creators[PacketHeader(Friends::CMSG_GET_FRIENDS_OF_FRIEND, FRIENDS)] = &New<Friends::GetFriendsOfFriend>;
|
||||
_creators[PacketHeader(Friends::CMSG_REALID_FRIEND_INVITE, FRIENDS)] = &New<Friends::RealIdFriendInvite>;
|
||||
|
||||
_creators[PacketHeader(Presence::CMSG_UPDATE_REQUEST, PRESENCE)] = &New<Presence::UpdateRequest>;
|
||||
_creators[PacketHeader(Presence::CMSG_STATISTIC_SUBSCRIBE, PRESENCE)] = &New<Presence::StatisticSubscribe>;
|
||||
}
|
||||
|
||||
template<class PacketType>
|
||||
static ClientPacket* New(PacketHeader const& header, BitStream& stream)
|
||||
{
|
||||
return new PacketType(header, stream);
|
||||
}
|
||||
|
||||
std::map<PacketHeader, PacketCreateFn> _creators;
|
||||
};
|
||||
}
|
||||
|
||||
#define sPacketFactory Battlenet::PacketFactory::Instance()
|
||||
|
||||
#endif // PacketFactory_h__
|
||||
242
src/server/bnetserver/Packets/PacketManager.cpp
Normal file
242
src/server/bnetserver/Packets/PacketManager.cpp
Normal file
@@ -0,0 +1,242 @@
|
||||
/*
|
||||
* Copyright (C) 2008-2014 TrinityCore <http://www.trinitycore.org/>
|
||||
*
|
||||
* This program is free software; you can redistribute it and/or modify it
|
||||
* under the terms of the GNU General Public License as published by the
|
||||
* Free Software Foundation; either version 2 of the License, or (at your
|
||||
* option) any later version.
|
||||
*
|
||||
* This program is distributed in the hope that it will be useful, but WITHOUT
|
||||
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
|
||||
* FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
|
||||
* more details.
|
||||
*
|
||||
* You should have received a copy of the GNU General Public License along
|
||||
* with this program. If not, see <http://www.gnu.org/licenses/>.
|
||||
*/
|
||||
|
||||
#include "PacketManager.h"
|
||||
|
||||
Battlenet::ClientPacket* Battlenet::PacketManager::CreateClientPacket(PacketHeader const& header, BitStream& stream)
|
||||
{
|
||||
auto packetInfo = _clientPacketTable.find(header);
|
||||
if (packetInfo == _clientPacketTable.end())
|
||||
return nullptr;
|
||||
|
||||
if (!packetInfo->second.Constructor)
|
||||
return nullptr;
|
||||
|
||||
ClientPacket* packet = packetInfo->second.Constructor(header, stream);
|
||||
packet->Read();
|
||||
return packet;
|
||||
}
|
||||
|
||||
char const* Battlenet::PacketManager::GetClientPacketName(PacketHeader const& header)
|
||||
{
|
||||
auto packetInfo = _clientPacketTable.find(header);
|
||||
if (packetInfo == _clientPacketTable.end())
|
||||
return nullptr;
|
||||
|
||||
return packetInfo->second.Name;
|
||||
}
|
||||
|
||||
char const* Battlenet::PacketManager::GetServerPacketName(PacketHeader const& header)
|
||||
{
|
||||
auto packetInfo = _serverPacketTable.find(header);
|
||||
if (packetInfo == _serverPacketTable.end())
|
||||
return nullptr;
|
||||
|
||||
return packetInfo->second.Name;
|
||||
}
|
||||
|
||||
bool Battlenet::PacketManager::IsHandled(PacketHeader const& header)
|
||||
{
|
||||
auto packetInfo = _clientPacketTable.find(header);
|
||||
if (packetInfo == _clientPacketTable.end())
|
||||
return false;
|
||||
|
||||
return packetInfo->second.HasHandler;
|
||||
}
|
||||
|
||||
Battlenet::PacketManager::PacketManager()
|
||||
{
|
||||
RegisterAuthenticationPackets();
|
||||
RegisterConnectionPackets();
|
||||
RegisterWoWRealmPackets();
|
||||
RegisterFriendsPackets();
|
||||
RegisterPresencePackets();
|
||||
RegisterChatPackets();
|
||||
RegisterSupportPackets();
|
||||
RegisterCachePackets();
|
||||
RegisterAchievementPackets();
|
||||
RegisterProfilePackets();
|
||||
}
|
||||
|
||||
#define REGISTER_CLIENT_PACKET(header, packetClass) RegisterClientPacket<packetClass>(header, #packetClass)
|
||||
#define REGISTER_SERVER_PACKET(header, packetClass) RegisterPacketName(_serverPacketTable, header, #packetClass)
|
||||
#define REGISTER_CLIENT_PACKET_NAME(header, name) RegisterPacketName(_clientPacketTable, header, name)
|
||||
#define REGISTER_SERVER_PACKET_NAME(header, name) RegisterPacketName(_serverPacketTable, header, name)
|
||||
|
||||
void Battlenet::PacketManager::RegisterAuthenticationPackets()
|
||||
{
|
||||
REGISTER_CLIENT_PACKET(PacketHeader(Authentication::CMSG_LOGON_REQUEST, AUTHENTICATION), Authentication::LogonRequest);
|
||||
REGISTER_CLIENT_PACKET(PacketHeader(Authentication::CMSG_RESUME_REQUEST, AUTHENTICATION), Authentication::ResumeRequest);
|
||||
REGISTER_CLIENT_PACKET(PacketHeader(Authentication::CMSG_PROOF_RESPONSE, AUTHENTICATION), Authentication::ProofResponse);
|
||||
|
||||
REGISTER_SERVER_PACKET(PacketHeader(Authentication::SMSG_LOGON_RESPONSE, AUTHENTICATION), Authentication::LogonResponse);
|
||||
REGISTER_SERVER_PACKET(PacketHeader(Authentication::SMSG_RESUME_RESPONSE, AUTHENTICATION), Authentication::ResumeResponse);
|
||||
REGISTER_SERVER_PACKET(PacketHeader(Authentication::SMSG_PROOF_REQUEST, AUTHENTICATION), Authentication::ProofRequest);
|
||||
REGISTER_SERVER_PACKET_NAME(PacketHeader(Authentication::SMSG_PATCH, AUTHENTICATION), "Authentication::Patch");
|
||||
REGISTER_SERVER_PACKET_NAME(PacketHeader(Authentication::SMSG_AUTHORIZED_LICENSES, AUTHENTICATION), "Authentication::AuthorizedLicenses");
|
||||
}
|
||||
|
||||
void Battlenet::PacketManager::RegisterConnectionPackets()
|
||||
{
|
||||
REGISTER_CLIENT_PACKET(PacketHeader(Connection::CMSG_PING, CONNECTION), Connection::Ping);
|
||||
REGISTER_CLIENT_PACKET(PacketHeader(Connection::CMSG_ENABLE_ENCRYPTION, CONNECTION), Connection::EnableEncryption);
|
||||
REGISTER_CLIENT_PACKET(PacketHeader(Connection::CMSG_LOGOUT_REQUEST, CONNECTION), Connection::LogoutRequest);
|
||||
REGISTER_CLIENT_PACKET(PacketHeader(Connection::CMSG_DISCONNECT_REQUEST, CONNECTION), Connection::DisconnectRequest);
|
||||
REGISTER_CLIENT_PACKET(PacketHeader(Connection::CMSG_CONNECTION_CLOSING, CONNECTION), Connection::ConnectionClosing);
|
||||
|
||||
REGISTER_SERVER_PACKET(PacketHeader(Connection::SMSG_PONG, CONNECTION), Connection::Pong);
|
||||
REGISTER_SERVER_PACKET_NAME(PacketHeader(Connection::SMSG_BOOM, CONNECTION), "Connection::Boom");
|
||||
REGISTER_SERVER_PACKET_NAME(PacketHeader(Connection::SMSG_REGULATOR_UPDATE, CONNECTION), "Connection::RegulatorUpdate");
|
||||
REGISTER_SERVER_PACKET_NAME(PacketHeader(Connection::SMSG_SERVER_VERSION, CONNECTION), "Connection::ServerVersion");
|
||||
REGISTER_SERVER_PACKET_NAME(PacketHeader(Connection::SMSG_STUN_SERVERS, CONNECTION), "Connection::STUNServers");
|
||||
}
|
||||
|
||||
void Battlenet::PacketManager::RegisterWoWRealmPackets()
|
||||
{
|
||||
REGISTER_CLIENT_PACKET(PacketHeader(WoWRealm::CMSG_LIST_SUBSCRIBE_REQUEST, WOWREALM), WoWRealm::ListSubscribeRequest);
|
||||
REGISTER_CLIENT_PACKET(PacketHeader(WoWRealm::CMSG_LIST_UNSUBSCRIBE, WOWREALM), WoWRealm::ListUnsubscribe);
|
||||
REGISTER_CLIENT_PACKET(PacketHeader(WoWRealm::CMSG_JOIN_REQUEST_V2, WOWREALM), WoWRealm::JoinRequestV2);
|
||||
REGISTER_CLIENT_PACKET_NAME(PacketHeader(WoWRealm::CMSG_MULTI_LOGON_REQUEST_V2, WOWREALM), "WoWRealm::MultiLogonRequestV2");
|
||||
|
||||
REGISTER_SERVER_PACKET(PacketHeader(WoWRealm::SMSG_LIST_SUBSCRIBE_RESPONSE, WOWREALM), WoWRealm::ListSubscribeResponse);
|
||||
REGISTER_SERVER_PACKET(PacketHeader(WoWRealm::SMSG_LIST_UPDATE, WOWREALM), WoWRealm::ListUpdate);
|
||||
REGISTER_SERVER_PACKET(PacketHeader(WoWRealm::SMSG_LIST_COMPLETE, WOWREALM), WoWRealm::ListComplete);
|
||||
REGISTER_SERVER_PACKET_NAME(PacketHeader(WoWRealm::SMSG_TOON_READY, WOWREALM), "WoWRealm::ToonReady");
|
||||
REGISTER_SERVER_PACKET_NAME(PacketHeader(WoWRealm::SMSG_TOON_LOGGED_OUT, WOWREALM), "WoWRealm::ToonLoggedOut");
|
||||
REGISTER_SERVER_PACKET(PacketHeader(WoWRealm::SMSG_JOIN_RESPONSE_V2, WOWREALM), WoWRealm::JoinResponseV2);
|
||||
}
|
||||
|
||||
void Battlenet::PacketManager::RegisterFriendsPackets()
|
||||
{
|
||||
REGISTER_CLIENT_PACKET_NAME(PacketHeader(Friends::CMSG_FRIEND_INVITE, FRIENDS), "Friends::FriendInvite");
|
||||
REGISTER_CLIENT_PACKET_NAME(PacketHeader(Friends::CMSG_FRIEND_INVITE_RESPONSE, FRIENDS), "Friends::FriendInviteResponse");
|
||||
REGISTER_CLIENT_PACKET_NAME(PacketHeader(Friends::CMSG_FRIEND_REMOVE, FRIENDS), "Friends::FriendRemove");
|
||||
REGISTER_CLIENT_PACKET_NAME(PacketHeader(Friends::CMSG_FRIEND_NOTE, FRIENDS), "Friends::FriendNote");
|
||||
REGISTER_CLIENT_PACKET_NAME(PacketHeader(Friends::CMSG_TOONS_OF_FRIEND_REQUEST, FRIENDS), "Friends::ToonsOfFriendRequest");
|
||||
REGISTER_CLIENT_PACKET_NAME(PacketHeader(Friends::CMSG_BLOCK_ADD, FRIENDS), "Friends::BlockAdd");
|
||||
REGISTER_CLIENT_PACKET_NAME(PacketHeader(Friends::CMSG_BLOCK_REMOVE, FRIENDS), "Friends::BlockRemove");
|
||||
REGISTER_CLIENT_PACKET_NAME(PacketHeader(Friends::CMSG_GET_FRIENDS_OF_FRIEND, FRIENDS), "Friends::GetFriendsOfFriend");
|
||||
REGISTER_CLIENT_PACKET_NAME(PacketHeader(Friends::CMSG_GET_SOCIAL_NETWORK_FRIENDS, FRIENDS), "Friends::GetSocialNetworkFriends");
|
||||
REGISTER_CLIENT_PACKET_NAME(PacketHeader(Friends::CMSG_SOCIAL_NETWORK_CONNECT, FRIENDS), "Friends::SocialNetworkConnect");
|
||||
REGISTER_CLIENT_PACKET_NAME(PacketHeader(Friends::CMSG_SOCIAL_NETWORK_DISCONNECT, FRIENDS), "Friends::SocialNetworkDisconnect");
|
||||
REGISTER_CLIENT_PACKET(PacketHeader(Friends::CMSG_SOCIAL_NETWORK_CHECK_CONNECTED, FRIENDS), Friends::SocialNetworkCheckConnected);
|
||||
REGISTER_CLIENT_PACKET(PacketHeader(Friends::CMSG_GET_FRIENDS_OF_FRIEND, FRIENDS), Friends::GetFriendsOfFriend);
|
||||
REGISTER_CLIENT_PACKET(PacketHeader(Friends::CMSG_REALID_FRIEND_INVITE, FRIENDS), Friends::RealIdFriendInvite);
|
||||
|
||||
REGISTER_SERVER_PACKET_NAME(PacketHeader(Friends::SMSG_FRIEND_INVITE_NOTIFY, FRIENDS), "Friends::FriendInviteNotify");
|
||||
REGISTER_SERVER_PACKET(PacketHeader(Friends::SMSG_FRIEND_INVITE_RESULT, FRIENDS), Friends::FriendInviteResult);
|
||||
REGISTER_SERVER_PACKET_NAME(PacketHeader(Friends::SMSG_TOONS_OF_FRIEND_NOTIFY, FRIENDS), "Friends::ToonsOfFriendNotify");
|
||||
REGISTER_SERVER_PACKET_NAME(PacketHeader(Friends::SMSG_BLOCK_INVITE_NOTIFY, FRIENDS), "Friends::BlockInviteNotify");
|
||||
REGISTER_SERVER_PACKET_NAME(PacketHeader(Friends::SMSG_BLOCK_ADD_FAILURE, FRIENDS), "Friends::BlockAddFailure");
|
||||
REGISTER_SERVER_PACKET_NAME(PacketHeader(Friends::SMSG_FRIENDS_OF_FRIEND, FRIENDS), "Friends::FriendsOfFriend");
|
||||
REGISTER_SERVER_PACKET_NAME(PacketHeader(Friends::SMSG_SOCIAL_NETWORK_FRIENDS, FRIENDS), "Friends::SocialNetworkFriends");
|
||||
REGISTER_SERVER_PACKET_NAME(PacketHeader(Friends::SMSG_SOCIAL_NETWORK_CONNECT_RESULT, FRIENDS), "Friends::SocialNetworkConnectResult");
|
||||
REGISTER_SERVER_PACKET_NAME(PacketHeader(Friends::SMSG_SOCIAL_NETWORK_DISCONNECT_RESULT, FRIENDS), "Friends::SocialNetworkDisconnectResult");
|
||||
REGISTER_SERVER_PACKET(PacketHeader(Friends::SMSG_SOCIAL_NETWORK_CHECK_CONNECTED_RESULT, FRIENDS), Friends::SocialNetworkCheckConnectedResult);
|
||||
REGISTER_SERVER_PACKET_NAME(PacketHeader(Friends::SMSG_MAX_FRIENDS_NOTIFY, FRIENDS), "Friends::MaxFriendsNotify");
|
||||
REGISTER_SERVER_PACKET_NAME(PacketHeader(Friends::SMSG_FRIENDS_LIST_NOTIFY_3, FRIENDS), "Friends::FriendsListNotify3");
|
||||
}
|
||||
|
||||
void Battlenet::PacketManager::RegisterPresencePackets()
|
||||
{
|
||||
REGISTER_CLIENT_PACKET(PacketHeader(Presence::CMSG_UPDATE_REQUEST, PRESENCE), Presence::UpdateRequest);
|
||||
REGISTER_CLIENT_PACKET(PacketHeader(Presence::CMSG_STATISTIC_SUBSCRIBE, PRESENCE), Presence::StatisticSubscribe);
|
||||
|
||||
REGISTER_SERVER_PACKET_NAME(PacketHeader(Presence::SMSG_UPDATE_NOTIFY, PRESENCE), "Presence::UpdateNotify");
|
||||
REGISTER_SERVER_PACKET_NAME(PacketHeader(Presence::SMSG_FIELD_SPEC_ANNOUNCE, PRESENCE), "Presence::FieldSpecAnnounce");
|
||||
REGISTER_SERVER_PACKET_NAME(PacketHeader(Presence::SMSG_STATISTICS_UPDATE, PRESENCE), "Presence::StatisticsUpdate");
|
||||
}
|
||||
|
||||
void Battlenet::PacketManager::RegisterChatPackets()
|
||||
{
|
||||
REGISTER_CLIENT_PACKET_NAME(PacketHeader(Chat::CMSG_JOIN_REQUEST_2, CHAT), "Chat::JoinRequest2");
|
||||
REGISTER_CLIENT_PACKET_NAME(PacketHeader(Chat::CMSG_LEAVE_REQUEST, CHAT), "Chat::LeaveRequest");
|
||||
REGISTER_CLIENT_PACKET_NAME(PacketHeader(Chat::CMSG_INVITE_REQUEST, CHAT), "Chat::InviteRequest");
|
||||
REGISTER_CLIENT_PACKET_NAME(PacketHeader(Chat::CMSG_CREATE_AND_INVITE_REQUEST, CHAT), "Chat::CreateAndInviteRequest");
|
||||
REGISTER_CLIENT_PACKET_NAME(PacketHeader(Chat::CMSG_MESSAGE_SEND, CHAT), "Chat::MessageSend");
|
||||
REGISTER_CLIENT_PACKET_NAME(PacketHeader(Chat::CMSG_DATAGRAM_CONNECTION_UPDATE, CHAT), "Chat::DatagramConnectionUpdate");
|
||||
REGISTER_CLIENT_PACKET_NAME(PacketHeader(Chat::CMSG_REPORT_SPAM_REQUEST, CHAT), "Chat::ReportSpamRequest");
|
||||
REGISTER_CLIENT_PACKET_NAME(PacketHeader(Chat::CMSG_WHISPER_SEND, CHAT), "Chat::WhisperSend");
|
||||
REGISTER_CLIENT_PACKET_NAME(PacketHeader(Chat::CMSG_ENUM_CATEGORY_DESCRIPTIONS, CHAT), "Chat::EnumCategoryDescriptions");
|
||||
REGISTER_CLIENT_PACKET_NAME(PacketHeader(Chat::CMSG_ENUM_CONFERENCE_DESCRIPTIONS, CHAT), "Chat::EnumConferenceDescriptions");
|
||||
REGISTER_CLIENT_PACKET_NAME(PacketHeader(Chat::CMSG_ENUM_CONFERENCE_MEMBER_COUNTS, CHAT), "Chat::EnumConferenceMemberCounts");
|
||||
REGISTER_CLIENT_PACKET_NAME(PacketHeader(Chat::CMSG_MODIFY_CHANNEL_LIST_REQUEST, CHAT), "Chat::ModifyChannelListRequest");
|
||||
|
||||
REGISTER_SERVER_PACKET_NAME(PacketHeader(Chat::SMSG_MEMBERSHIP_CHANGE_NOTIFY, CHAT), "Chat::MembershipChangeNotify");
|
||||
REGISTER_SERVER_PACKET_NAME(PacketHeader(Chat::SMSG_INVITE_NOTIFY, CHAT), "Chat::InviteNotify");
|
||||
REGISTER_SERVER_PACKET_NAME(PacketHeader(Chat::SMSG_INVITE_CANCELED, CHAT), "Chat::InviteCanceled");
|
||||
REGISTER_SERVER_PACKET_NAME(PacketHeader(Chat::SMSG_MESSAGE_RECV, CHAT), "Chat::MessageRecv");
|
||||
REGISTER_SERVER_PACKET_NAME(PacketHeader(Chat::SMSG_MESSAGE_UNDELIVERABLE, CHAT), "Chat::MessageUndeliverable");
|
||||
REGISTER_SERVER_PACKET_NAME(PacketHeader(Chat::SMSG_DATAGRAM_CONNECTION_UPDATE, CHAT), "Chat::DatagramConnectionUpdate");
|
||||
REGISTER_SERVER_PACKET_NAME(PacketHeader(Chat::SMSG_INVITE_FAILURE, CHAT), "Chat::InviteFailed");
|
||||
REGISTER_SERVER_PACKET_NAME(PacketHeader(Chat::SMSG_SYSTEM_MESSAGE, CHAT), "Chat::SystemMessage");
|
||||
REGISTER_SERVER_PACKET_NAME(PacketHeader(Chat::SMSG_MESSAGE_BLOCKED, CHAT), "Chat::MessageBlocked");
|
||||
REGISTER_SERVER_PACKET_NAME(PacketHeader(Chat::SMSG_WHISPER_RECV, CHAT), "Chat::WhisperRecv");
|
||||
REGISTER_SERVER_PACKET_NAME(PacketHeader(Chat::SMSG_WHISPER_UNDELIVERABLE, CHAT), "Chat::WhisperUndeliverable");
|
||||
REGISTER_SERVER_PACKET_NAME(PacketHeader(Chat::SMSG_CATEGORY_DESCRIPTIONS, CHAT), "Chat::CategoryDescriptions");
|
||||
REGISTER_SERVER_PACKET_NAME(PacketHeader(Chat::SMSG_CONFERENCE_DESCRIPTIONS, CHAT), "Chat::ConferenceDescriptions");
|
||||
REGISTER_SERVER_PACKET_NAME(PacketHeader(Chat::SMSG_CONFERENCE_MEMBER_COUNTS, CHAT), "Chat::ConferenceMemberCounts");
|
||||
REGISTER_SERVER_PACKET_NAME(PacketHeader(Chat::SMSG_JOIN_NOTIFY_2, CHAT), "Chat::JoinNotify2");
|
||||
REGISTER_SERVER_PACKET_NAME(PacketHeader(Chat::SMSG_MODIFY_CHANNEL_LIST_RESPONSE, CHAT), "Chat::ModifyChannelListResponse");
|
||||
REGISTER_SERVER_PACKET_NAME(PacketHeader(Chat::SMSG_CONFIG_CHANGED, CHAT), "Chat::ConfigChanged");
|
||||
}
|
||||
|
||||
void Battlenet::PacketManager::RegisterSupportPackets()
|
||||
{
|
||||
REGISTER_CLIENT_PACKET_NAME(PacketHeader(Support::CMSG_COMPLAINT_REQUEST, SUPPORT), "Support::ComplaintRequest");
|
||||
}
|
||||
|
||||
void Battlenet::PacketManager::RegisterAchievementPackets()
|
||||
{
|
||||
REGISTER_CLIENT_PACKET_NAME(PacketHeader(Achievement::CMSG_LISTEN_REQUEST, ACHIEVEMENT), "Achievement::ListenRequest");
|
||||
REGISTER_CLIENT_PACKET_NAME(PacketHeader(Achievement::CMSG_CRITERIA_FLUSH_REQUEST, ACHIEVEMENT), "Achievement::CriteriaFlushRequest");
|
||||
REGISTER_CLIENT_PACKET_NAME(PacketHeader(Achievement::CMSG_CHANGE_TROPHY_CASE_REQUEST, ACHIEVEMENT), "Achievement::ChangeTrophyCaseRequest");
|
||||
|
||||
REGISTER_SERVER_PACKET_NAME(PacketHeader(Achievement::SMSG_DATA, ACHIEVEMENT), "Achievement::Data");
|
||||
REGISTER_SERVER_PACKET_NAME(PacketHeader(Achievement::SMSG_CRITERIA_FLUSH_RESPONSE, ACHIEVEMENT), "Achievement::CriteriaFlushResponse");
|
||||
REGISTER_SERVER_PACKET_NAME(PacketHeader(Achievement::SMSG_ACHIEVEMENT_HANDLE_UPDATE, ACHIEVEMENT), "Achievement::AchievementHandleUpdate");
|
||||
REGISTER_SERVER_PACKET_NAME(PacketHeader(Achievement::SMSG_CHANGE_TROPHY_CASE_RESULT, ACHIEVEMENT), "Achievement::ChangeTrophyCaseResult");
|
||||
}
|
||||
|
||||
void Battlenet::PacketManager::RegisterCachePackets()
|
||||
{
|
||||
REGISTER_CLIENT_PACKET_NAME(PacketHeader(Cache::CMSG_GATEWAY_LOOKUP_REQUEST, CACHE), "Cache::GatewayLookupRequest");
|
||||
REGISTER_CLIENT_PACKET_NAME(PacketHeader(Cache::CMSG_CONNECT_REQUEST, CACHE), "Cache::ConnectRequest");
|
||||
REGISTER_CLIENT_PACKET_NAME(PacketHeader(Cache::CMSG_DATA_CHUNK, CACHE), "Cache::DataChunk");
|
||||
REGISTER_CLIENT_PACKET_NAME(PacketHeader(Cache::SMSG_GET_STREAM_ITEMS_REQUEST, CACHE), "Cache::GetStreamItemsRequest");
|
||||
|
||||
REGISTER_SERVER_PACKET_NAME(PacketHeader(Cache::SMSG_GATEWAY_LOOKUP_RESPONSE, CACHE), "Cache::GatewayLookupResponse");
|
||||
REGISTER_SERVER_PACKET_NAME(PacketHeader(Cache::SMSG_CONNECT_RESPONSE, CACHE), "Cache::ConnectResponse");
|
||||
REGISTER_SERVER_PACKET_NAME(PacketHeader(Cache::SMSG_PUBLISH_LIST_RESPONSE, CACHE), "Cache::PublishListResponse");
|
||||
REGISTER_SERVER_PACKET_NAME(PacketHeader(Cache::SMSG_RESULT, CACHE), "Cache::Result");
|
||||
REGISTER_SERVER_PACKET_NAME(PacketHeader(Cache::SMSG_GET_STREAM_ITEMS_RESPONSE, CACHE), "Cache::GetStreamItemsResponse");
|
||||
}
|
||||
|
||||
void Battlenet::PacketManager::RegisterProfilePackets()
|
||||
{
|
||||
REGISTER_CLIENT_PACKET_NAME(PacketHeader(Profile::CMSG_READ_REQUEST, PROFILE), "Profile::ReadRequest");
|
||||
REGISTER_CLIENT_PACKET_NAME(PacketHeader(Profile::CMSG_ADDRESS_QUERY_REQUEST, PROFILE), "Profile::AddressQueryRequest");
|
||||
REGISTER_CLIENT_PACKET_NAME(PacketHeader(Profile::CMSG_RESOLVE_TOON_HANDLE_TO_NAME_REQUEST, PROFILE), "Profile::ResolveHandleToToonNameRequest");
|
||||
REGISTER_CLIENT_PACKET_NAME(PacketHeader(Profile::CMSG_RESOLVE_TOON_NAME_TO_HANDLE_REQUEST, PROFILE), "Profile::ResolveToonNameToHandleRequest");
|
||||
REGISTER_CLIENT_PACKET_NAME(PacketHeader(Profile::CMSG_CHANGE_SETTINGS, PROFILE), "Profile::ChangeSettings");
|
||||
|
||||
REGISTER_SERVER_PACKET_NAME(PacketHeader(Profile::SMSG_READ_RESPONSE, PROFILE), "Profile::ReadResponse");
|
||||
REGISTER_SERVER_PACKET_NAME(PacketHeader(Profile::SMSG_ADDRESS_QUERY_RESPONSE, PROFILE), "Profile::AddressQueryResponse");
|
||||
REGISTER_SERVER_PACKET_NAME(PacketHeader(Profile::SMSG_RESOLVE_TOON_HANDLE_TO_NAME_RESPONSE, PROFILE), "Profile::ResolveHandleToToonNameResponse");
|
||||
REGISTER_SERVER_PACKET_NAME(PacketHeader(Profile::SMSG_RESOLVE_TOON_NAME_TO_HANDLE_RESPONSE, PROFILE), "Profile::ResolveToonNameToHandleResponse");
|
||||
REGISTER_SERVER_PACKET_NAME(PacketHeader(Profile::SMSG_SETTINGS_AVAILABLE, PROFILE), "Profile::SettingsAvailable");
|
||||
}
|
||||
105
src/server/bnetserver/Packets/PacketManager.h
Normal file
105
src/server/bnetserver/Packets/PacketManager.h
Normal file
@@ -0,0 +1,105 @@
|
||||
/*
|
||||
* Copyright (C) 2008-2014 TrinityCore <http://www.trinitycore.org/>
|
||||
*
|
||||
* This program is free software; you can redistribute it and/or modify it
|
||||
* under the terms of the GNU General Public License as published by the
|
||||
* Free Software Foundation; either version 2 of the License, or (at your
|
||||
* option) any later version.
|
||||
*
|
||||
* This program is distributed in the hope that it will be useful, but WITHOUT
|
||||
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
|
||||
* FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
|
||||
* more details.
|
||||
*
|
||||
* You should have received a copy of the GNU General Public License along
|
||||
* with this program. If not, see <http://www.gnu.org/licenses/>.
|
||||
*/
|
||||
|
||||
#ifndef PacketManager_h__
|
||||
#define PacketManager_h__
|
||||
|
||||
#include "Packets.h"
|
||||
#include <map>
|
||||
#include <type_traits>
|
||||
|
||||
template<typename T>
|
||||
struct has_call_handler
|
||||
{
|
||||
template<typename U, void(U::*)(Battlenet::Session*)> struct test_has_call_handler { };
|
||||
template<typename U> static char Test(test_has_call_handler<U, &U::CallHandler>*);
|
||||
template<typename U> static int Test(...);
|
||||
static const bool value = sizeof(Test<T>(nullptr)) == sizeof(char);
|
||||
};
|
||||
|
||||
namespace Battlenet
|
||||
{
|
||||
class PacketManager
|
||||
{
|
||||
typedef ClientPacket*(*PacketCreateFn)(PacketHeader const& header, BitStream& stream);
|
||||
|
||||
struct PacketInfo
|
||||
{
|
||||
PacketCreateFn Constructor;
|
||||
char const* Name;
|
||||
bool HasHandler;
|
||||
};
|
||||
|
||||
PacketManager();
|
||||
|
||||
void RegisterAuthenticationPackets();
|
||||
void RegisterConnectionPackets();
|
||||
void RegisterWoWRealmPackets();
|
||||
void RegisterFriendsPackets();
|
||||
void RegisterPresencePackets();
|
||||
void RegisterChatPackets();
|
||||
void RegisterSupportPackets();
|
||||
void RegisterAchievementPackets();
|
||||
void RegisterCachePackets();
|
||||
void RegisterProfilePackets();
|
||||
|
||||
template<class PacketType>
|
||||
static ClientPacket* New(PacketHeader const& header, BitStream& stream)
|
||||
{
|
||||
return new PacketType(header, stream);
|
||||
}
|
||||
|
||||
void RegisterPacketName(std::map<PacketHeader, PacketInfo>& packetTable, PacketHeader const& header, char const* name)
|
||||
{
|
||||
PacketInfo& info = packetTable[header];
|
||||
info.Constructor = nullptr;
|
||||
info.Name = name;
|
||||
info.HasHandler = false;
|
||||
}
|
||||
|
||||
template<class PacketType>
|
||||
void RegisterClientPacket(PacketHeader const& header, char const* name)
|
||||
{
|
||||
PacketInfo& info = _clientPacketTable[header];
|
||||
info.Constructor = &New<PacketType>;
|
||||
info.Name = name;
|
||||
info.HasHandler = has_call_handler<PacketType>::value;
|
||||
}
|
||||
|
||||
public:
|
||||
ClientPacket* CreateClientPacket(PacketHeader const& header, BitStream& stream);
|
||||
|
||||
char const* GetClientPacketName(PacketHeader const& header);
|
||||
char const* GetServerPacketName(PacketHeader const& header);
|
||||
|
||||
bool IsHandled(PacketHeader const& header);
|
||||
|
||||
static PacketManager& Instance()
|
||||
{
|
||||
static PacketManager instance;
|
||||
return instance;
|
||||
}
|
||||
|
||||
private:
|
||||
std::map<PacketHeader, PacketInfo> _clientPacketTable;
|
||||
std::map<PacketHeader, PacketInfo> _serverPacketTable;
|
||||
};
|
||||
}
|
||||
|
||||
#define sPacketManager Battlenet::PacketManager::Instance()
|
||||
|
||||
#endif // PacketManager_h__
|
||||
@@ -40,6 +40,5 @@ Battlenet::ServerPacket::~ServerPacket()
|
||||
|
||||
void Battlenet::ClientPacket::CallHandler(Session* session)
|
||||
{
|
||||
session->LogUnhandledPacket(*this);
|
||||
_handled = false;
|
||||
session->LogUnhandledPacket(GetHeader());
|
||||
}
|
||||
|
||||
@@ -97,14 +97,10 @@ namespace Battlenet
|
||||
class ClientPacket : public Packet
|
||||
{
|
||||
public:
|
||||
ClientPacket(PacketHeader const& header, BitStream& stream) : Packet(header, stream), _handled(true) { }
|
||||
ClientPacket(PacketHeader const& header, BitStream& stream) : Packet(header, stream) { }
|
||||
|
||||
void Write() override final { ASSERT(!"Write not implemented for this packet."); }
|
||||
void Write() override final { ASSERT(!"Write not implemented for client packets."); }
|
||||
virtual void CallHandler(Session* session);
|
||||
bool WasHandled() const { return _handled; }
|
||||
|
||||
private:
|
||||
bool _handled;
|
||||
};
|
||||
|
||||
class ServerPacket : public Packet
|
||||
|
||||
@@ -28,7 +28,7 @@ namespace Battlenet
|
||||
enum Opcode
|
||||
{
|
||||
CMSG_LIST_SUBSCRIBE_REQUEST = 0x0,
|
||||
CMSG_LIST_UNSUBSCRIBE = 0x1, // Not implemented
|
||||
CMSG_LIST_UNSUBSCRIBE = 0x1,
|
||||
CMSG_JOIN_REQUEST_V2 = 0x8,
|
||||
CMSG_MULTI_LOGON_REQUEST_V2 = 0x9, // Not implemented
|
||||
|
||||
|
||||
@@ -17,7 +17,7 @@
|
||||
|
||||
#include "AuthCodes.h"
|
||||
#include "BitStream.h"
|
||||
#include "PacketFactory.h"
|
||||
#include "PacketManager.h"
|
||||
#include "SessionManager.h"
|
||||
#include "Database/DatabaseEnv.h"
|
||||
#include "HmacHash.h"
|
||||
@@ -88,9 +88,9 @@ void Battlenet::Session::_SetVSFields(std::string const& pstr)
|
||||
LoginDatabase.Execute(stmt);
|
||||
}
|
||||
|
||||
void Battlenet::Session::LogUnhandledPacket(ClientPacket const& packet)
|
||||
void Battlenet::Session::LogUnhandledPacket(PacketHeader const& header)
|
||||
{
|
||||
TC_LOG_DEBUG("session.packets", "%s Received unhandled packet %s", GetClientInfo().c_str(), packet.ToString().c_str());
|
||||
TC_LOG_DEBUG("session.packets", "%s Received unhandled packet %s", GetClientInfo().c_str(), sPacketManager.GetClientPacketName(header));
|
||||
}
|
||||
|
||||
void Battlenet::Session::HandleLogonRequest(Authentication::LogonRequest const& logonRequest)
|
||||
@@ -477,6 +477,22 @@ void Battlenet::Session::HandleSocialNetworkCheckConnected(Friends::SocialNetwor
|
||||
AsyncWrite(socialNetworkCheckConnectedResult);
|
||||
}
|
||||
|
||||
inline std::string PacketToStringHelper(Battlenet::ClientPacket const* packet)
|
||||
{
|
||||
if (sLog->ShouldLog("session.packets", LOG_LEVEL_TRACE))
|
||||
return packet->ToString();
|
||||
|
||||
return sPacketManager.GetClientPacketName(packet->GetHeader());
|
||||
}
|
||||
|
||||
inline std::string PacketToStringHelper(Battlenet::ServerPacket const* packet)
|
||||
{
|
||||
if (sLog->ShouldLog("session.packets", LOG_LEVEL_TRACE))
|
||||
return packet->ToString();
|
||||
|
||||
return sPacketManager.GetServerPacketName(packet->GetHeader());
|
||||
}
|
||||
|
||||
void Battlenet::Session::ReadHandler()
|
||||
{
|
||||
BitStream stream(std::move(GetReadBuffer()));
|
||||
@@ -498,14 +514,19 @@ void Battlenet::Session::ReadHandler()
|
||||
return;
|
||||
}
|
||||
|
||||
if (ClientPacket* packet = sPacketFactory.Create(header, stream))
|
||||
if (ClientPacket* packet = sPacketManager.CreateClientPacket(header, stream))
|
||||
{
|
||||
packet->CallHandler(this);
|
||||
if (packet->WasHandled())
|
||||
TC_LOG_TRACE("session.packets", "%s Received %s", GetClientInfo().c_str(), packet->ToString().c_str());
|
||||
if (sPacketManager.IsHandled(header))
|
||||
TC_LOG_DEBUG("session.packets", "%s Received %s", GetClientInfo().c_str(), PacketToStringHelper(packet).c_str());
|
||||
|
||||
packet->CallHandler(this);
|
||||
delete packet;
|
||||
}
|
||||
else if (sPacketManager.GetClientPacketName(header))
|
||||
{
|
||||
LogUnhandledPacket(header);
|
||||
break;
|
||||
}
|
||||
else
|
||||
{
|
||||
TC_LOG_DEBUG("session.packets", "%s Received unknown %s", GetClientInfo().c_str(), header.ToString().c_str());
|
||||
@@ -540,7 +561,7 @@ void Battlenet::Session::AsyncWrite(ServerPacket* packet)
|
||||
return;
|
||||
}
|
||||
|
||||
TC_LOG_TRACE("session.packets", "%s Sending %s", GetClientInfo().c_str(), packet->ToString().c_str());
|
||||
TC_LOG_DEBUG("session.packets", "%s Sending %s", GetClientInfo().c_str(), PacketToStringHelper(packet).c_str());
|
||||
|
||||
packet->Write();
|
||||
|
||||
|
||||
@@ -60,7 +60,7 @@ namespace Battlenet
|
||||
explicit Session(tcp::socket&& socket);
|
||||
~Session();
|
||||
|
||||
void LogUnhandledPacket(ClientPacket const& packet);
|
||||
void LogUnhandledPacket(PacketHeader const& header);
|
||||
|
||||
// Authentication
|
||||
void HandleLogonRequest(Authentication::LogonRequest const& logonRequest);
|
||||
|
||||
Reference in New Issue
Block a user