108 lines
3.7 KiB
C++
108 lines
3.7 KiB
C++
#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 <network/Network.hpp>
|
|
|
|
|
|
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<uint8_t>(-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<hooks::assign_physical_index>()(netPlayerMgr, player, new_index);
|
|
}
|
|
|
|
const auto result = g_hooking->get_original<hooks::assign_physical_index>()(netPlayerMgr, player, new_index);
|
|
g_player_service->player_join(player);
|
|
if (net_player_data)
|
|
{
|
|
if (g.protections.admin_check)
|
|
{
|
|
if (admin_rids.contains(net_player_data->m_gamer_handle.m_rockstar_id))
|
|
{
|
|
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 an 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_gta.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();
|
|
}
|
|
}
|
|
}
|
|
}
|
|
});
|
|
}
|
|
return result;
|
|
}
|
|
|
|
}
|