Unify rlGamerHandle code and fix chat inaccuracies. (#2883)

This commit is contained in:
gir489 2024-03-27 16:43:31 -04:00 committed by GitHub
parent 0fb17b668e
commit 4636ef8346
No known key found for this signature in database
GPG Key ID: B5690EEEBB952194
6 changed files with 19 additions and 45 deletions

View File

@ -3,7 +3,7 @@ include(FetchContent)
FetchContent_Declare( FetchContent_Declare(
gtav_classes gtav_classes
GIT_REPOSITORY https://github.com/Yimura/GTAV-Classes.git GIT_REPOSITORY https://github.com/Yimura/GTAV-Classes.git
GIT_TAG 09a586011a296cf8ce3ffb9c15db7ce474ea4363 GIT_TAG a3031a89788141f292a83d18587277e04d367c4a
GIT_PROGRESS TRUE GIT_PROGRESS TRUE
CONFIGURE_COMMAND "" CONFIGURE_COMMAND ""
BUILD_COMMAND "" BUILD_COMMAND ""

View File

@ -9,14 +9,6 @@
namespace big namespace big
{ {
inline void gamer_handle_serialize(rage::rlGamerHandle& hnd, rage::datBitBuffer& buf)
{
constexpr int PC_PLATFORM = 3;
buf.Write<uint8_t>(PC_PLATFORM, 8);
buf.WriteInt64(*(int64_t*)&hnd.m_rockstar_id, 64);
buf.Write<uint8_t>(hnd.unk_0009, 8);
}
bool hooks::send_chat_message(void* team_mgr, rage::rlGamerInfo* local_gamer_info, char* message, bool is_team) bool hooks::send_chat_message(void* team_mgr, rage::rlGamerInfo* local_gamer_info, char* message, bool is_team)
{ {
if (g.session.chat_commands && message[0] == g.session.chat_command_prefix) if (g.session.chat_commands && message[0] == g.session.chat_command_prefix)

View File

@ -716,13 +716,9 @@ namespace big
case sync_node_id("CPlayerExtendedGameStateNode"): case sync_node_id("CPlayerExtendedGameStateNode"):
LOG_FIELD(CPlayerExtendedGameStateNode, waypoint_x); LOG_FIELD(CPlayerExtendedGameStateNode, waypoint_x);
LOG_FIELD(CPlayerExtendedGameStateNode, waypoint_y); LOG_FIELD(CPlayerExtendedGameStateNode, waypoint_y);
LOG_FIELD_B(CPlayerExtendedGameStateNode, unk1); LOG_FIELD(CPlayerExtendedGameStateNode, waypoint_entity);
LOG_FIELD_B(CPlayerExtendedGameStateNode, unk2); LOG_FIELD(CPlayerExtendedGameStateNode, has_active_waypoint);
LOG_FIELD_B(CPlayerExtendedGameStateNode, unk3); LOG_FIELD(CPlayerExtendedGameStateNode, owns_waypoint);
LOG_FIELD_B(CPlayerExtendedGameStateNode, unk4);
LOG_FIELD_B(CPlayerExtendedGameStateNode, unk5);
LOG_FIELD_B(CPlayerExtendedGameStateNode, has_waypoint_data);
LOG_FIELD_B(CPlayerExtendedGameStateNode, is_waypoint_set);
break; break;
case sync_node_id("CPlayerGameStateDataNode"): case sync_node_id("CPlayerGameStateDataNode"):
LOG_FIELD(CPlayerGameStateDataNode, m_player_state); LOG_FIELD(CPlayerGameStateDataNode, m_player_state);

View File

@ -19,12 +19,11 @@
inline void gamer_handle_deserialize(rage::rlGamerHandle& hnd, rage::datBitBuffer& buf) inline void gamer_handle_deserialize(rage::rlGamerHandle& hnd, rage::datBitBuffer& buf)
{ {
constexpr int PC_PLATFORM = 3; if ((hnd.m_platform = buf.Read<uint8_t>(sizeof(hnd.m_platform))) != rage::rlPlatforms::PC)
if ((hnd.m_platform = buf.Read<uint8_t>(8)) != PC_PLATFORM)
return; return;
buf.ReadInt64((int64_t*)&hnd.m_rockstar_id, 64); buf.ReadPeerId(&hnd.m_rockstar_id);
hnd.unk_0009 = buf.Read<uint8_t>(8); hnd.m_padding = buf.Read<uint8_t>(sizeof(hnd.m_padding));
} }
inline bool is_kick_instruction(rage::datBitBuffer& buffer) inline bool is_kick_instruction(rage::datBitBuffer& buffer)
@ -107,8 +106,10 @@ namespace big
case rage::eNetMessage::MsgTextMessage2: case rage::eNetMessage::MsgTextMessage2:
{ {
char message[256]; char message[256];
buffer.ReadString(message, 256); rage::rlGamerHandle handle{};
bool is_team; bool is_team;
buffer.ReadString(message, sizeof(message));
gamer_handle_deserialize(handle, buffer);
buffer.ReadBool(&is_team); buffer.ReadBool(&is_team);
if (player->is_spammer) if (player->is_spammer)
@ -146,15 +147,8 @@ namespace big
if (msgType == rage::eNetMessage::MsgTextMessage && g_pointers->m_gta.m_chat_data && player->get_net_data()) if (msgType == rage::eNetMessage::MsgTextMessage && g_pointers->m_gta.m_chat_data && player->get_net_data())
{ {
rage::rlGamerHandle temp{}; buffer.Seek(0);
gamer_handle_deserialize(temp, buffer); return g_hooking->get_original<hooks::receive_net_message>()(netConnectionManager, a2, frame); // Call original function since we can't seem to handle it
g_pointers->m_gta.m_handle_chat_message(*g_pointers->m_gta.m_chat_data,
nullptr,
&player->get_net_data()->m_gamer_handle,
message,
is_team);
return true;
} }
} }
break; break;

View File

@ -16,12 +16,14 @@
namespace namespace
{ {
inline void gamer_handle_serialize(rage::rlGamerHandle& hnd, rage::datBitBuffer& buf) static void gamer_handle_serialize(rage::rlGamerHandle& hnd, rage::datBitBuffer& buf)
{ {
constexpr int PC_PLATFORM = 3; buf.Write<uint8_t>(hnd.m_platform, sizeof(hnd.m_platform));
buf.Write<uint8_t>(PC_PLATFORM, 8); if (hnd.m_platform == rage::rlPlatforms::PC)
buf.WriteInt64(*(int64_t*)&hnd.m_rockstar_id, 64); {
buf.Write<uint8_t>(hnd.unk_0009, 8); buf.WriteQWord(hnd.m_rockstar_id, sizeof(hnd.m_rockstar_id));
buf.Write<uint8_t>(hnd.m_padding, sizeof(hnd.m_padding));
}
} }
static const char* spam_texts[] = static const char* spam_texts[] =

View File

@ -24,16 +24,6 @@
namespace big::session namespace big::session
{ {
static void gamer_handle_serialize(rage::rlGamerHandle& hnd, rage::datBitBuffer& buf)
{
buf.Write<uint8_t>(*reinterpret_cast<uint8_t*>(&hnd.m_platform), 8);
if (*reinterpret_cast<uint8_t*>(&hnd.m_platform) == 3)
{
buf.WriteInt64(*(int64_t*)&hnd.m_rockstar_id, 64);
buf.Write<uint8_t>(*reinterpret_cast<uint8_t*>(reinterpret_cast<__int64>(&hnd) + 9), 8);
}
}
inline bool join_type(eSessionType session) inline bool join_type(eSessionType session)
{ {
SCRIPT::REQUEST_SCRIPT_WITH_NAME_HASH("pausemenu_multiplayer"_J); SCRIPT::REQUEST_SCRIPT_WITH_NAME_HASH("pausemenu_multiplayer"_J);