mirror of
https://github.com/Mauler125/r5sdk.git
synced 2025-02-09 19:15:03 +01:00
Set persistent var for all players on connect
And separate serverbrowser from gameconsole
This commit is contained in:
parent
a51d7d712f
commit
3fa766f730
@ -22,6 +22,7 @@ extern HRESULT __stdcall Present(IDXGISwapChain* pSwapChain, UINT nSyncInterval,
|
||||
/////////////////////////////////////////////////////////////////////////////
|
||||
// Globals
|
||||
extern DWORD g_dThreadId;
|
||||
extern BOOL g_bShowMenu;
|
||||
extern BOOL g_bShowConsole;
|
||||
extern BOOL g_bShowBrowser;
|
||||
|
||||
/////////////////////////////////////////////////////////////////////////////
|
||||
|
@ -5,7 +5,6 @@
|
||||
#include "utility.h"
|
||||
|
||||
void InstallOpcodes();
|
||||
void InstallGlobals();
|
||||
inline HANDLE GameProcess = GetCurrentProcess();
|
||||
|
||||
namespace
|
||||
@ -16,7 +15,6 @@ namespace
|
||||
|
||||
/* -------------- ENGINE ------------------------------------------------------------------------------------------------------------------------------------------------ */
|
||||
DWORD64 dst002 /*0x14043FB90*/ = reinterpret_cast<DWORD64>(PatternScan("r5apex.exe", "48 89 4C 24 08 56 41 55 48 81 EC 68 03 ? ? 4C"));
|
||||
DWORD64 dst003 /*0x140302FF0*/ = reinterpret_cast<DWORD64>(PatternScan("r5apex.exe", "40 53 41 56 41 57 48 83 EC 20 48 8B D9 48 89 74"));
|
||||
DWORD64 dst004 /*0x14022A4A0*/ = reinterpret_cast<DWORD64>(PatternScan("r5apex.exe", "48 83 EC 38 0F 29 74 24 20 48 89 5C 24 40 48 8B"));
|
||||
DWORD64 Host_NewGame /*0x140238DA0*/ = reinterpret_cast<DWORD64>(PatternScan("r5apex.exe", "48 8B C4 ? 41 54 41 ? 48 81 EC ? ? ? ? F2"));
|
||||
|
||||
@ -28,9 +26,6 @@ namespace
|
||||
|
||||
/* -------------- ------- ----------------------------------------------------------------------------------------------------------------------------------------------- */
|
||||
|
||||
/* -------------- GLOBALS ----------------------------------------------------------------------------------------------------------------------------------------------- */
|
||||
DWORD64 ofs000 = 0x000000016073B7BC;
|
||||
|
||||
void PrintOAddress() // Test the sigscan results
|
||||
{
|
||||
std::cout << "+--------------------------------------------------------+" << std::endl;
|
||||
@ -38,7 +33,6 @@ namespace
|
||||
std::cout << "| dst001 : " << std::hex << std::uppercase << dst001 << std::setw(20) << " |" << std::endl;
|
||||
std::cout << "+--------------------------------------------------------+" << std::endl;
|
||||
std::cout << "| dst002 : " << std::hex << std::uppercase << dst002 << std::setw(20) << " |" << std::endl;
|
||||
std::cout << "| dst003 : " << std::hex << std::uppercase << dst003 << std::setw(20) << " |" << std::endl;
|
||||
std::cout << "| dst004 : " << std::hex << std::uppercase << dst004 << std::setw(20) << " |" << std::endl;
|
||||
std::cout << "| Host_NewGame : " << std::hex << std::uppercase << Host_NewGame << std::setw(20) << " |" << std::endl;
|
||||
std::cout << "+--------------------------------------------------------+" << std::endl;
|
||||
|
@ -8,7 +8,8 @@
|
||||
void PrintDXAddress();
|
||||
void InstallDXHooks();
|
||||
void RemoveDXHooks();
|
||||
void DrawMenu();
|
||||
void DrawConsole();
|
||||
void DrawBrowser();
|
||||
|
||||
/////////////////////////////////////////////////////////////////////////////
|
||||
// Internals
|
||||
@ -141,12 +142,14 @@ extern CGameConsole* g_GameConsole;
|
||||
|
||||
class CCompanion
|
||||
{
|
||||
private:
|
||||
bool ThemeSet = false;
|
||||
public:
|
||||
CCompanion();
|
||||
|
||||
////////////////////
|
||||
// Enums //
|
||||
//////////////////
|
||||
// Enums //
|
||||
////////////////////
|
||||
|
||||
enum class ESection {
|
||||
ServerBrowser,
|
||||
@ -163,7 +166,7 @@ public:
|
||||
|
||||
////////////////////
|
||||
// Server Browser //
|
||||
///////////////////
|
||||
////////////////////
|
||||
ImVector<ServerListing*> ServerList;
|
||||
ServerListing* SelectedServer;
|
||||
ImGuiTextFilter ServerBrowserFilter;
|
||||
@ -189,6 +192,68 @@ public:
|
||||
CurrentSection = section;
|
||||
}
|
||||
|
||||
////////////////////
|
||||
// Style //
|
||||
////////////////////
|
||||
void SetStyleVar()
|
||||
{
|
||||
ImGuiStyle& style = ImGui::GetStyle();
|
||||
ImVec4* colors = style.Colors;
|
||||
|
||||
colors[ImGuiCol_Text] = ImVec4(0.81f, 0.81f, 0.81f, 1.00f);
|
||||
colors[ImGuiCol_TextDisabled] = ImVec4(0.56f, 0.56f, 0.56f, 1.00f);
|
||||
colors[ImGuiCol_WindowBg] = ImVec4(0.27f, 0.27f, 0.27f, 1.00f);
|
||||
colors[ImGuiCol_ChildBg] = ImVec4(0.00f, 0.00f, 0.00f, 1.00f);
|
||||
colors[ImGuiCol_PopupBg] = ImVec4(0.27f, 0.27f, 0.27f, 1.00f);
|
||||
colors[ImGuiCol_Border] = ImVec4(0.41f, 0.41f, 0.41f, 1.00f);
|
||||
colors[ImGuiCol_BorderShadow] = ImVec4(0.04f, 0.04f, 0.04f, 0.64f);
|
||||
colors[ImGuiCol_FrameBg] = ImVec4(0.13f, 0.13f, 0.13f, 1.00f);
|
||||
colors[ImGuiCol_FrameBgHovered] = ImVec4(0.19f, 0.19f, 0.19f, 1.00f);
|
||||
colors[ImGuiCol_FrameBgActive] = ImVec4(0.24f, 0.24f, 0.24f, 1.00f);
|
||||
colors[ImGuiCol_TitleBg] = ImVec4(0.22f, 0.22f, 0.22f, 1.00f);
|
||||
colors[ImGuiCol_TitleBgActive] = ImVec4(0.27f, 0.27f, 0.27f, 1.00f);
|
||||
colors[ImGuiCol_TitleBgCollapsed] = ImVec4(0.00f, 0.00f, 0.00f, 1.00f);
|
||||
colors[ImGuiCol_MenuBarBg] = ImVec4(0.22f, 0.22f, 0.22f, 1.00f);
|
||||
colors[ImGuiCol_ScrollbarBg] = ImVec4(0.10f, 0.10f, 0.10f, 1.00f);
|
||||
colors[ImGuiCol_ScrollbarGrab] = ImVec4(0.41f, 0.41f, 0.41f, 1.00f);
|
||||
colors[ImGuiCol_ScrollbarGrabHovered] = ImVec4(0.53f, 0.53f, 0.53f, 1.00f);
|
||||
colors[ImGuiCol_ScrollbarGrabActive] = ImVec4(0.63f, 0.63f, 0.63f, 1.00f);
|
||||
colors[ImGuiCol_CheckMark] = ImVec4(0.61f, 0.61f, 0.61f, 1.00f);
|
||||
colors[ImGuiCol_SliderGrab] = ImVec4(0.41f, 0.41f, 0.41f, 1.00f);
|
||||
colors[ImGuiCol_SliderGrabActive] = ImVec4(0.53f, 0.53f, 0.53f, 1.00f);
|
||||
colors[ImGuiCol_Button] = ImVec4(0.35f, 0.35f, 0.35f, 1.00f);
|
||||
colors[ImGuiCol_ButtonHovered] = ImVec4(0.45f, 0.45f, 0.45f, 1.00f);
|
||||
colors[ImGuiCol_ButtonActive] = ImVec4(0.52f, 0.52f, 0.52f, 1.00f);
|
||||
colors[ImGuiCol_Header] = ImVec4(0.35f, 0.35f, 0.35f, 1.00f);
|
||||
colors[ImGuiCol_HeaderHovered] = ImVec4(0.45f, 0.45f, 0.45f, 1.00f);
|
||||
colors[ImGuiCol_HeaderActive] = ImVec4(0.53f, 0.53f, 0.53f, 1.00f);
|
||||
colors[ImGuiCol_Separator] = ImVec4(0.53f, 0.53f, 0.57f, 1.00f);
|
||||
colors[ImGuiCol_SeparatorHovered] = ImVec4(0.53f, 0.53f, 0.53f, 1.00f);
|
||||
colors[ImGuiCol_SeparatorActive] = ImVec4(0.63f, 0.63f, 0.63f, 1.00f);
|
||||
colors[ImGuiCol_ResizeGrip] = ImVec4(0.41f, 0.41f, 0.41f, 1.00f);
|
||||
colors[ImGuiCol_ResizeGripHovered] = ImVec4(0.52f, 0.52f, 0.52f, 1.00f);
|
||||
colors[ImGuiCol_ResizeGripActive] = ImVec4(0.63f, 0.63f, 0.63f, 1.00f);
|
||||
colors[ImGuiCol_Tab] = ImVec4(0.18f, 0.18f, 0.18f, 1.00f);
|
||||
colors[ImGuiCol_TabHovered] = ImVec4(0.39f, 0.39f, 0.39f, 1.00f);
|
||||
colors[ImGuiCol_TabActive] = ImVec4(0.39f, 0.39f, 0.39f, 1.00f);
|
||||
|
||||
style.WindowBorderSize = 0.0f;
|
||||
style.FrameBorderSize = 1.0f;
|
||||
style.ChildBorderSize = 1.0f;
|
||||
style.PopupBorderSize = 1.0f;
|
||||
style.TabBorderSize = 1.0f;
|
||||
|
||||
style.WindowRounding = 2.5f;
|
||||
style.FrameRounding = 0.0f;
|
||||
style.ChildRounding = 0.0f;
|
||||
style.PopupRounding = 0.0f;
|
||||
style.TabRounding = 1.0f;
|
||||
style.ScrollbarRounding = 1.0f;
|
||||
|
||||
style.ItemSpacing = ImVec2(4, 4);
|
||||
style.WindowPadding = ImVec2(5, 5);
|
||||
}
|
||||
|
||||
void RefreshServerList();
|
||||
void SendHostingPostRequest(char* mapName);
|
||||
void CompMenu();
|
||||
|
@ -44,6 +44,11 @@ namespace
|
||||
DWORD64 p_CHLClient_FrameStageNotify = /*0x1405C0740*/ reinterpret_cast<DWORD64>(PatternScan("r5apex.exe", "48 83 EC 28 89 15 ?? ?? ?? ??"));
|
||||
void (*org_CHLClient_FrameStageNotify)(void* rcx, int curStage) = (void (*)(void*, int))p_CHLClient_FrameStageNotify;
|
||||
|
||||
////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////
|
||||
/* ==== CCLIENT ========================================================================================================================================================= */
|
||||
DWORD64 p_Persistence_IsReady = /*0x140315CF0*/ reinterpret_cast<DWORD64>(PatternScan("r5apex.exe", "3B 15 ?? ?? ?? ?? 7D 33"));
|
||||
bool (*org_Persistence_IsReady)(__int64 entidx, int client) = (bool(*)(__int64, int))p_Persistence_IsReady;
|
||||
|
||||
////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////
|
||||
/* ==== UTILITY ========================================================================================================================================================= */
|
||||
DWORD64 p_MSG_EngineError = /*0x140295600*/ reinterpret_cast<DWORD64>(PatternScan("r5apex.exe", "48 89 5C 24 08 48 89 74 24 10 57 48 81 EC 30 08 00 00 48 8B DA 48 8B F9 E8 ?? ?? ?? FF 33 F6 48"));
|
||||
|
@ -21,7 +21,6 @@ void InitializeR5Dev()
|
||||
InstallIPHooks();
|
||||
InstallDXHooks();
|
||||
InstallOpcodes();
|
||||
InstallGlobals();
|
||||
SetupDXSwapChain();
|
||||
printf("+-----------------------------------------------------------------------------+\n");
|
||||
printf("| R5 DEV -- INITIALIZED ------------------------------------------------- |\n");
|
||||
|
@ -108,15 +108,13 @@ __int64 HSQVM_LoadRson(const char* rson_name)
|
||||
printf("\n");
|
||||
return org_SQVM_LoadRson(filepath);
|
||||
}
|
||||
else
|
||||
{
|
||||
printf("\n");
|
||||
printf("##################################################\n");
|
||||
printf("] '%s'\n", rson_name);
|
||||
printf("##################################################\n");
|
||||
printf("\n");
|
||||
return org_SQVM_LoadRson(rson_name);
|
||||
}
|
||||
|
||||
printf("\n");
|
||||
printf("##################################################\n");
|
||||
printf("] '%s'\n", rson_name);
|
||||
printf("##################################################\n");
|
||||
printf("\n");
|
||||
return org_SQVM_LoadRson(rson_name);
|
||||
}
|
||||
|
||||
bool HSQVM_LoadScript(void* sqvm, const char* script_path, const char* script_name, int flag)
|
||||
@ -156,15 +154,37 @@ bool HSQVM_LoadScript(void* sqvm, const char* script_path, const char* script_na
|
||||
|
||||
int HMSG_EngineError(char* fmt, va_list args)
|
||||
{
|
||||
char buf[1024];
|
||||
printf("ENGINE ERROR #####################################\n");
|
||||
printf("\nENGINE ERROR #####################################\n");
|
||||
vprintf(fmt, args);
|
||||
vsnprintf(buf, IM_ARRAYSIZE(buf), fmt, args);
|
||||
buf[IM_ARRAYSIZE(buf) - 1] = 0;
|
||||
Items.push_back(Strdup(buf));
|
||||
return org_MSG_EngineError(fmt, args);
|
||||
}
|
||||
|
||||
// TODO: turn this into a playerstruct constructor if it ever becomes necessary
|
||||
bool HPersistence_IsReady(__int64 entidx, int client)
|
||||
{
|
||||
static bool isPersistenceVarSet[256];
|
||||
|
||||
// TODO: Maybe not hardcode
|
||||
DWORD64 playerStructBase = 0x16073B200;
|
||||
DWORD64 playerStructSize = 0x4A4C0;
|
||||
DWORD64 persistenceVar = 0x5BC;
|
||||
|
||||
DWORD64 targetPlayerStruct = playerStructBase + client * playerStructSize;
|
||||
|
||||
*(char*)(targetPlayerStruct + persistenceVar) = (char)0x5;
|
||||
|
||||
if (!isPersistenceVarSet[client])
|
||||
{
|
||||
printf("\n");
|
||||
printf("##################################################\n");
|
||||
printf("] SETTING PERSISTENCE VAR FOR CLIENT #%d\n", client);
|
||||
printf("##################################################\n");
|
||||
printf("\n");
|
||||
isPersistenceVarSet[client] = true;
|
||||
}
|
||||
return org_Persistence_IsReady;
|
||||
}
|
||||
|
||||
//#################################################################################
|
||||
// MANAGEMENT
|
||||
//#################################################################################
|
||||
@ -189,6 +209,7 @@ void InstallENHooks()
|
||||
///////////////////////////////////////////////////////////////////////////////
|
||||
// Hook Utility functions
|
||||
DetourAttach((LPVOID*)&org_MSG_EngineError, &HMSG_EngineError);
|
||||
DetourAttach((LPVOID*)&org_Persistence_IsReady, &HPersistence_IsReady);
|
||||
|
||||
///////////////////////////////////////////////////////////////////////////////
|
||||
// Commit the transaction
|
||||
@ -224,6 +245,7 @@ void RemoveENHooks()
|
||||
///////////////////////////////////////////////////////////////////////////////
|
||||
// Unhook Utility functions
|
||||
DetourDetach((LPVOID*)&org_MSG_EngineError, &HMSG_EngineError);
|
||||
DetourDetach((LPVOID*)&org_Persistence_IsReady, &HPersistence_IsReady);
|
||||
|
||||
///////////////////////////////////////////////////////////////////////////////
|
||||
// Commit the transaction
|
||||
|
@ -33,7 +33,8 @@ typedef BOOL(WINAPI* IPostMessageA)(HWND hWnd, UINT Msg, WPARAM wParam, LPARAM l
|
||||
typedef BOOL(WINAPI* IPostMessageW)(HWND hWnd, UINT Msg, WPARAM wParam, LPARAM lParam);
|
||||
|
||||
///////////////////////////////////////////////////////////////////////////////////
|
||||
extern BOOL g_bShowMenu = false;
|
||||
extern BOOL g_bShowConsole = false;
|
||||
extern BOOL g_bShowBrowser = false;
|
||||
static BOOL g_bInitMenu = false;
|
||||
static BOOL g_bInitialized = false;
|
||||
static BOOL g_bPresentHooked = false;
|
||||
@ -69,10 +70,17 @@ LRESULT CALLBACK HwndProc(HWND hWnd, UINT uMsg, WPARAM wParam, LPARAM lParam)
|
||||
{
|
||||
if (wParam == VK_OEM_3 || wParam == VK_INSERT) // For everyone without a US keyboard layout.
|
||||
{
|
||||
g_bShowMenu = !g_bShowMenu;
|
||||
g_bShowConsole = !g_bShowConsole;
|
||||
}
|
||||
}
|
||||
if (g_bShowMenu)
|
||||
if (uMsg == WM_SYSKEYDOWN)
|
||||
{
|
||||
if (wParam == VK_F10)
|
||||
{
|
||||
g_bShowBrowser = !g_bShowBrowser;
|
||||
}
|
||||
}
|
||||
if (g_bShowConsole || g_bShowBrowser)
|
||||
{//////////////////////////////////////////////////////////////////////////////
|
||||
ImGui_ImplWin32_WndProcHandler(hWnd, uMsg, wParam, lParam);
|
||||
g_bBlockInput = true;
|
||||
@ -264,10 +272,15 @@ void DrawImGui()
|
||||
|
||||
ImGui::NewFrame();
|
||||
|
||||
if (g_bShowMenu)
|
||||
if (g_bShowConsole)
|
||||
{
|
||||
GameGlobals::InputSystem->EnableInput(false); // Disable input.
|
||||
DrawMenu();
|
||||
DrawConsole();
|
||||
}
|
||||
if(g_bShowBrowser)
|
||||
{
|
||||
GameGlobals::InputSystem->EnableInput(false); // Disable input.
|
||||
DrawBrowser();
|
||||
}
|
||||
else
|
||||
{
|
||||
@ -351,7 +364,8 @@ HRESULT GetDeviceAndCtxFromSwapchain(IDXGISwapChain* pSwapChain, ID3D11Device**
|
||||
|
||||
HRESULT __stdcall GetResizeBuffers(IDXGISwapChain* pSwapChain, UINT nBufferCount, UINT nWidth, UINT nHeight, DXGI_FORMAT dxFormat, UINT nSwapChainFlags)
|
||||
{
|
||||
g_bShowMenu = false;
|
||||
g_bShowConsole = false;
|
||||
g_bShowBrowser = false;
|
||||
g_bInitialized = false;
|
||||
g_bPresentHooked = false;
|
||||
|
||||
|
@ -15,9 +15,6 @@ void InstallOpcodes() /* .TEXT */
|
||||
// JNE --> JMP | Allow games to be loaded without the optional texture streaming file
|
||||
WriteProcessMemory(GameProcess, LPVOID(dst002 + 0x8E5), "\xEB\x19", 2, NULL);
|
||||
//-------------------------------------------------------------------------
|
||||
// MOV --> NOP | Prevent PDATA global being initialized as NULL
|
||||
WriteProcessMemory(GameProcess, LPVOID(dst003 + 0x174), "\x90\x90\x90\x90\x90\x90\x90\x90\x90\x90\x90\x90\x90\x90", 14, NULL);
|
||||
//-------------------------------------------------------------------------
|
||||
// JNE --> JMP | Prevent connect command from crashing by invalid call to UI function
|
||||
WriteProcessMemory(GameProcess, LPVOID(dst004 + 0x1D6), "\xEB\x27", 2, NULL);
|
||||
//-------------------------------------------------------------------------
|
||||
@ -30,10 +27,3 @@ void InstallOpcodes() /* .TEXT */
|
||||
// JA --> JMP | Prevent FairFight anti-cheat from initializing on the server
|
||||
WriteProcessMemory(GameProcess, LPVOID(dst007 + 0x61), "\xE9\xED\x00\x00\x00\x00", 6, NULL);
|
||||
}
|
||||
|
||||
void InstallGlobals() /* .DATA */
|
||||
{
|
||||
//-------------------------------------------------------------------------
|
||||
// 00 --> 05 | Set PDATA global to enable clientcommand codecallback on the server
|
||||
WriteProcessMemory(GameProcess, LPVOID(ofs000), "\x05", 1, NULL);
|
||||
}
|
||||
|
@ -615,6 +615,12 @@ void CCompanion::SettingsSection()
|
||||
|
||||
void CCompanion::Draw(const char* title)
|
||||
{
|
||||
if (!ThemeSet)
|
||||
{
|
||||
SetStyleVar();
|
||||
ThemeSet = true;
|
||||
}
|
||||
|
||||
ImGui::SetNextWindowSize(ImVec2(800, 890), ImGuiCond_FirstUseEver);
|
||||
ImGui::SetWindowPos(ImVec2(-500, 50), ImGuiCond_FirstUseEver);
|
||||
|
||||
@ -687,11 +693,15 @@ void Strtrim(char* s)
|
||||
// ENTRYPOINT
|
||||
//#############################################################################
|
||||
|
||||
void DrawMenu()
|
||||
void DrawConsole()
|
||||
{
|
||||
static CGameConsole console;
|
||||
g_GameConsole = &console;
|
||||
static CCompanion browser;
|
||||
console.Draw("Console");
|
||||
}
|
||||
|
||||
void DrawBrowser()
|
||||
{
|
||||
static CCompanion browser;
|
||||
browser.Draw("Companion");
|
||||
}
|
Loading…
x
Reference in New Issue
Block a user