Player Database Enhancement (#2411)
Added 'Send Friend Request' through the player's rockstar ID.
This commit is contained in:
parent
cadb6dab92
commit
ef355736a2
@ -1,3 +1,5 @@
|
|||||||
|
#include "backend/bool_command.hpp"
|
||||||
|
#include "backend/int_command.hpp"
|
||||||
#include "backend/looped/looped.hpp"
|
#include "backend/looped/looped.hpp"
|
||||||
#include "natives.hpp"
|
#include "natives.hpp"
|
||||||
#include "services/players/player_service.hpp"
|
#include "services/players/player_service.hpp"
|
||||||
@ -41,6 +43,12 @@ namespace big
|
|||||||
|
|
||||||
STREAMING::SET_FOCUS_ENTITY(target);
|
STREAMING::SET_FOCUS_ENTITY(target);
|
||||||
|
|
||||||
|
if (g.player.override_cam_distance)
|
||||||
|
CAM::SET_THIRD_PERSON_CAM_ORBIT_DISTANCE_LIMITS_THIS_UPDATE(1.f, (float)g.player.cam_distance);
|
||||||
|
|
||||||
bReset = false;
|
bReset = false;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
bool_command g_override_cam_distance("overridecamdistance", "BACKEND_LOOPED_PLAYER_OVERRIDE_CAM_DISTANCE", "BACKEND_LOOPED_PLAYER_OVERRIDE_CAM_DISTANCE_DESC", g.player.override_cam_distance);
|
||||||
|
int_command g_override_cam_distance_int("overridecamdistanceint", "BACKEND_LOOPED_PLAYER_OVERRIDE_CAM_DISTANCE_INT", "BACKEND_LOOPED_PLAYER_OVERRIDE_CAM_DISTANCE_INT_DESC", g.player.cam_distance, 1, 200);
|
||||||
}
|
}
|
||||||
|
@ -228,8 +228,10 @@ namespace big
|
|||||||
struct player
|
struct player
|
||||||
{
|
{
|
||||||
bool spectating = false;
|
bool spectating = false;
|
||||||
|
bool override_cam_distance = false;
|
||||||
|
int cam_distance = 10;
|
||||||
|
|
||||||
NLOHMANN_DEFINE_TYPE_INTRUSIVE(player, spectating)
|
NLOHMANN_DEFINE_TYPE_INTRUSIVE(player, spectating, override_cam_distance, cam_distance)
|
||||||
} player{};
|
} player{};
|
||||||
|
|
||||||
struct player_db
|
struct player_db
|
||||||
|
@ -120,6 +120,8 @@ namespace big::functions
|
|||||||
using join_session_by_info = bool (*)(Network* network, rage::rlSessionInfo* info, int unk, int flags, rage::rlGamerHandle* handles, int handlecount);
|
using join_session_by_info = bool (*)(Network* network, rage::rlSessionInfo* info, int unk, int flags, rage::rlGamerHandle* handles, int handlecount);
|
||||||
|
|
||||||
using invite_player_by_gamer_handle = bool(*)(uint64_t config, rage::rlGamerHandle* handle, int unk1, int unk2, int unk3, int unk4);
|
using invite_player_by_gamer_handle = bool(*)(uint64_t config, rage::rlGamerHandle* handle, int unk1, int unk2, int unk3, int unk4);
|
||||||
|
using add_friend_by_gamer_handle = void(*)(rage::rlGamerHandle* handle, const char* unk);
|
||||||
|
using show_profile_by_gamer_handle = void(*)(rage::rlGamerHandle* handle);
|
||||||
|
|
||||||
using generate_uuid = bool (*)(uint64_t* uuid);
|
using generate_uuid = bool (*)(uint64_t* uuid);
|
||||||
|
|
||||||
|
@ -163,6 +163,8 @@ namespace big
|
|||||||
functions::join_session_by_info m_join_session_by_info;
|
functions::join_session_by_info m_join_session_by_info;
|
||||||
|
|
||||||
functions::invite_player_by_gamer_handle m_invite_player_by_gamer_handle;
|
functions::invite_player_by_gamer_handle m_invite_player_by_gamer_handle;
|
||||||
|
functions::add_friend_by_gamer_handle m_add_friend_by_gamer_handle;
|
||||||
|
functions::show_profile_by_gamer_handle m_show_profile_by_gamer_handle;
|
||||||
uint64_t m_network_config;
|
uint64_t m_network_config;
|
||||||
|
|
||||||
functions::reset_network_complaints m_reset_network_complaints;
|
functions::reset_network_complaints m_reset_network_complaints;
|
||||||
|
@ -646,6 +646,24 @@ namespace big
|
|||||||
g_pointers->m_gta.m_invite_player_by_gamer_handle = ptr.add(1).rip().as<functions::invite_player_by_gamer_handle>();
|
g_pointers->m_gta.m_invite_player_by_gamer_handle = ptr.add(1).rip().as<functions::invite_player_by_gamer_handle>();
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
|
// Add Friend By Gamer Handle
|
||||||
|
{
|
||||||
|
"AFBGH",
|
||||||
|
"48 89 5C 24 ? 57 48 83 EC ? 48 8B F9 B1 ? 48 8B DA E8 ? ? ? ? 84 C0 74 ? 8B 15",
|
||||||
|
[](memory::handle ptr)
|
||||||
|
{
|
||||||
|
g_pointers->m_gta.m_add_friend_by_gamer_handle = ptr.as<functions::add_friend_by_gamer_handle>();
|
||||||
|
}
|
||||||
|
},
|
||||||
|
// Show Profile By Gamer Handle
|
||||||
|
{
|
||||||
|
"SPBGH",
|
||||||
|
"E8 ? ? ? ? E9 ? ? ? ? 3D ? ? ? ? 75 ? E8",
|
||||||
|
[](memory::handle ptr)
|
||||||
|
{
|
||||||
|
g_pointers->m_gta.m_show_profile_by_gamer_handle = ptr.add(1).rip().as<functions::show_profile_by_gamer_handle>();
|
||||||
|
}
|
||||||
|
},
|
||||||
// Network Config
|
// Network Config
|
||||||
{
|
{
|
||||||
"NC",
|
"NC",
|
||||||
|
@ -170,6 +170,20 @@ namespace big::session
|
|||||||
g_notification_service->push_success("Network", "Target player has been invited to your session!");
|
g_notification_service->push_success("Network", "Target player has been invited to your session!");
|
||||||
}
|
}
|
||||||
|
|
||||||
|
inline void show_profile_by_rockstar_id(uint64_t rid)
|
||||||
|
{
|
||||||
|
rage::rlGamerHandle player_handle(rid);
|
||||||
|
|
||||||
|
g_pointers->m_gta.m_show_profile_by_gamer_handle(&player_handle);
|
||||||
|
}
|
||||||
|
|
||||||
|
inline void add_friend_by_rockstar_id(uint64_t rid)
|
||||||
|
{
|
||||||
|
rage::rlGamerHandle player_handle(rid);
|
||||||
|
|
||||||
|
g_pointers->m_gta.m_add_friend_by_gamer_handle(&player_handle, 0);
|
||||||
|
}
|
||||||
|
|
||||||
inline void add_infraction(player_ptr player, Infraction infraction, const std::string& custom_reason = "")
|
inline void add_infraction(player_ptr player, Infraction infraction, const std::string& custom_reason = "")
|
||||||
{
|
{
|
||||||
if (g.debug.fuzzer.enabled)
|
if (g.debug.fuzzer.enabled)
|
||||||
|
@ -208,10 +208,22 @@ namespace big
|
|||||||
session::join_by_rockstar_id(current_player->rockstar_id);
|
session::join_by_rockstar_id(current_player->rockstar_id);
|
||||||
});
|
});
|
||||||
|
|
||||||
|
ImGui::SameLine();
|
||||||
|
|
||||||
components::button("INVITE_PLAYER"_T, [] {
|
components::button("INVITE_PLAYER"_T, [] {
|
||||||
session::invite_by_rockstar_id(current_player->rockstar_id);
|
session::invite_by_rockstar_id(current_player->rockstar_id);
|
||||||
});
|
});
|
||||||
|
|
||||||
|
components::button("VIEW_PLAYER_INFO_SC_PROFILE"_T, [] {
|
||||||
|
session::show_profile_by_rockstar_id(current_player->rockstar_id);
|
||||||
|
});
|
||||||
|
|
||||||
|
ImGui::SameLine();
|
||||||
|
|
||||||
|
components::button("SEND_FRIEND_REQUEST"_T, [] {
|
||||||
|
session::add_friend_by_rockstar_id(current_player->rockstar_id);
|
||||||
|
});
|
||||||
|
|
||||||
static char message[256];
|
static char message[256];
|
||||||
components::input_text("INPUT_MSG"_T, message, sizeof(message));
|
components::input_text("INPUT_MSG"_T, message, sizeof(message));
|
||||||
if (components::button("SEND_MSG"_T))
|
if (components::button("SEND_MSG"_T))
|
||||||
|
@ -5,6 +5,7 @@
|
|||||||
#include "services/player_database/player_database_service.hpp"
|
#include "services/player_database/player_database_service.hpp"
|
||||||
#include "views/view.hpp"
|
#include "views/view.hpp"
|
||||||
#include "services/gta_data/gta_data_service.hpp"
|
#include "services/gta_data/gta_data_service.hpp"
|
||||||
|
#include "util/session.hpp"
|
||||||
|
|
||||||
#include <network/netConnection.hpp>
|
#include <network/netConnection.hpp>
|
||||||
#include <script/globals/GPBD_FM.hpp>
|
#include <script/globals/GPBD_FM.hpp>
|
||||||
@ -179,11 +180,7 @@ namespace big
|
|||||||
ImGui::SameLine();
|
ImGui::SameLine();
|
||||||
|
|
||||||
if (ImGui::SmallButton("VIEW_PLAYER_INFO_SC_PROFILE"_T.data()))
|
if (ImGui::SmallButton("VIEW_PLAYER_INFO_SC_PROFILE"_T.data()))
|
||||||
g_fiber_pool->queue_job([] {
|
session::show_profile_by_rockstar_id(g_player_service->get_selected()->get_net_data()->m_gamer_handle.m_rockstar_id);
|
||||||
uint64_t gamerHandle[13];
|
|
||||||
NETWORK::NETWORK_HANDLE_FROM_PLAYER(g_player_service->get_selected()->id(), (Any*)&gamerHandle, 13);
|
|
||||||
NETWORK::NETWORK_SHOW_PROFILE_UI((Any*)&gamerHandle);
|
|
||||||
});
|
|
||||||
|
|
||||||
if (CPlayerInfo* player_info = g_player_service->get_selected()->get_player_info(); player_info != nullptr)
|
if (CPlayerInfo* player_info = g_player_service->get_selected()->get_player_info(); player_info != nullptr)
|
||||||
{
|
{
|
||||||
|
@ -7,6 +7,14 @@ namespace big
|
|||||||
{
|
{
|
||||||
ImGui::Checkbox("SPECTATE"_T.data(), &g.player.spectating);
|
ImGui::Checkbox("SPECTATE"_T.data(), &g.player.spectating);
|
||||||
|
|
||||||
|
if (g.player.spectating)
|
||||||
|
{
|
||||||
|
components::command_checkbox<"overridecamdistance">();
|
||||||
|
|
||||||
|
if (g.player.override_cam_distance)
|
||||||
|
components::command_int_slider<"overridecamdistanceint">();
|
||||||
|
}
|
||||||
|
|
||||||
if (g_player_service->get_selected()->is_valid())
|
if (g_player_service->get_selected()->is_valid())
|
||||||
{
|
{
|
||||||
player_ptr current_player = g_player_service->get_selected();
|
player_ptr current_player = g_player_service->get_selected();
|
||||||
|
Reference in New Issue
Block a user