#include "core/data/admin_rids.hpp" #include "core/globals.hpp" #include "fiber_pool.hpp" #include "gta_util.hpp" #include "hooking.hpp" #include "packet.hpp" #include "services/player_database/player_database_service.hpp" #include "services/players/player_service.hpp" #include "util/notify.hpp" #include namespace big { void* hooks::assign_physical_index(CNetworkPlayerMgr* netPlayerMgr, CNetGamePlayer* player, uint8_t new_index) { const auto* net_player_data = player->get_net_data(); if (new_index == static_cast(-1)) { g.m_spoofed_peer_ids.erase(player->get_net_data()->m_host_token); g_player_service->player_leave(player); if (net_player_data) { if (g.notifications.player_leave.log) LOG(INFO) << "Player left '" << net_player_data->m_name << "' freeing slot #" << (int)player->m_player_id << " with Rockstar ID: " << net_player_data->m_gamer_handle.m_rockstar_id; if (g.notifications.player_leave.notify) { g_notification_service->push("PLAYER_LEFT"_T.data(), std::vformat("PLAYER_LEFT_INFO"_T, std::make_format_args(net_player_data->m_name, player->m_player_id, net_player_data->m_gamer_handle.m_rockstar_id))); } } return g_hooking->get_original()(netPlayerMgr, player, new_index); } const auto result = g_hooking->get_original()(netPlayerMgr, player, new_index); g_player_service->player_join(player); if (net_player_data) { if (g.protections.admin_check) { auto found = std::find(admin_rids.begin(), admin_rids.end(), net_player_data->m_gamer_handle.m_rockstar_id); if (found != admin_rids.end()) { g_notification_service->push_warning("POTENTIAL_ADMIN_FOUND"_T.data(), std::vformat("PLAYER_DETECTED_AS_ADMIN"_T, std::make_format_args(net_player_data->m_name))); LOG(WARNING) << net_player_data->m_name << " (" << net_player_data->m_gamer_handle.m_rockstar_id << ") has been detected as admin"; auto id = player->m_player_id; if (auto plyr = g_player_service->get_by_id(id)) plyr->is_admin = true; } } if (g.notifications.player_join.above_map && *g_pointers->m_is_session_started) // prevent loading screen spam notify::player_joined(player); if (g.notifications.player_join.log) LOG(INFO) << "Player joined '" << net_player_data->m_name << "' allocating slot #" << (int)player->m_player_id << " with Rockstar ID: " << net_player_data->m_gamer_handle.m_rockstar_id; if (g.notifications.player_join.notify) { g_notification_service->push("PLAYER_JOINED"_T.data(), std::vformat("PLAYER_JOINED_INFO"_T, std::make_format_args(net_player_data->m_name, player->m_player_id, net_player_data->m_gamer_handle.m_rockstar_id))); } auto id = player->m_player_id; g_fiber_pool->queue_job([id] { if (auto plyr = g_player_service->get_by_id(id)) { if (plyr->get_net_data()->m_gamer_handle.m_rockstar_id != 0) { if (auto entry = g_player_database_service->get_player_by_rockstar_id( plyr->get_net_data()->m_gamer_handle.m_rockstar_id)) { plyr->is_modder = entry->is_modder; plyr->block_join = entry->block_join; plyr->block_join_reason = plyr->block_join_reason; if (strcmp(plyr->get_name(), entry->name.data())) { g_notification_service->push("PLAYERS"_T.data(), std::vformat("PLAYER_CHANGED_NAME"_T, std::make_format_args(entry->name, plyr->get_name()))); entry->name = plyr->get_name(); g_player_database_service->save(); } } } if (auto snplyr = plyr->get_session_player()) { packet msg{}; msg.write_message(rage::eNetMessage::MsgSessionEstablishedRequest); msg.write(gta_util::get_network()->m_game_session_ptr->m_rline_session.m_session_id, 64); msg.send(snplyr->m_msg_id); } } }); } return result; } }