From 2ed56d7317c109f630b6d86c17a96c2d3199a455 Mon Sep 17 00:00:00 2001 From: Kawe Mazidjatari <48657826+Mauler125@users.noreply.github.com> Date: Fri, 17 Feb 2023 23:59:37 +0100 Subject: [PATCH] More mapped out fields for server and client class --- r5dev/engine/client/client.cpp | 27 +++++++++++++ r5dev/engine/client/client.h | 71 ++++++++++++++++++++++++++++++++-- r5dev/engine/server/server.h | 11 ++++-- 3 files changed, 102 insertions(+), 7 deletions(-) diff --git a/r5dev/engine/client/client.cpp b/r5dev/engine/client/client.cpp index e6688b5f..692f0d46 100644 --- a/r5dev/engine/client/client.cpp +++ b/r5dev/engine/client/client.cpp @@ -10,6 +10,7 @@ /////////////////////////////////////////////////////////////////////////////////// #include "core/stdafx.h" #include "tier1/cvar.h" +#include "engine/host.h" #include "engine/server/server.h" #include "engine/client/client.h" @@ -70,6 +71,22 @@ CNetChan* CClient::GetNetChan(void) const return m_NetChannel; } +//--------------------------------------------------------------------------------- +// Purpose: gets the pointer to the server object +//--------------------------------------------------------------------------------- +CServer* CClient::GetServer(void) const +{ + return m_pServer; +} + +//--------------------------------------------------------------------------------- +// Purpose: gets the command tick +//--------------------------------------------------------------------------------- +int CClient::GetCommandTick(void) const +{ + return m_nCommandTick; +} + //--------------------------------------------------------------------------------- // Purpose: gets the name of this client (managed by server) //--------------------------------------------------------------------------------- @@ -286,6 +303,16 @@ void CClient::Disconnect(const Reputation_t nRepLvl, const char* szReason, ...) } } +bool CClient::SendNetMsg(CNetMessage* pMsg, char bLocal, bool bForceReliable, bool bVoice) +{ + return v_CClient_SendNetMsg(this, pMsg, bLocal, bForceReliable, bVoice); +} + +void* CClient::VSendSnapshot(CClient* pClient, CClientFrame* pFrame, int nTick, int nTickAck) +{ + return v_CClient_SendSnapshot(pClient, pFrame, nTick, nTickAck); +} + //--------------------------------------------------------------------------------- // Purpose: process string commands (kicking anyone attempting to DOS) // Input : *pClient - (ADJ) diff --git a/r5dev/engine/client/client.h b/r5dev/engine/client/client.h index 444c5330..96a95338 100644 --- a/r5dev/engine/client/client.h +++ b/r5dev/engine/client/client.h @@ -20,6 +20,41 @@ enum Reputation_t class CServer; class CClient; +struct Spike_t +{ +public: + Spike_t() : + m_nBits(0) + { + m_szDesc[0] = 0; + } + + // !TODO: !unconfirmed! + char m_szDesc[64]; + int m_nBits; +}; + +class CNetworkStatTrace +{ +public: + CNetworkStatTrace() : + m_nStartBit(0), m_nCurBit(0), m_nMinWarningBytes(0) + { + } + int m_nStartBit; + int m_nCurBit; + int m_nMinWarningBytes; + CUtlVector< Spike_t > m_Records; +}; + +class CClientFrame +{ + // !TODO: !unconfirmed! + int last_entity; + int tick_count; + CClientFrame* m_pNext; +}; + /////////////////////////////////////////////////////////////////////////////// extern CClient* g_pClient; @@ -33,6 +68,8 @@ public: SIGNONSTATE GetSignonState(void) const; PERSISTENCE GetPersistenceState(void) const; CNetChan* GetNetChan(void) const; + CServer* GetServer(void) const; + int GetCommandTick(void) const; const char* GetServerName(void) const; const char* GetClientName(void) const; void SetHandle(edict_t nHandle); @@ -48,12 +85,17 @@ public: bool IsPersistenceReady(void) const; bool IsFakeClient(void) const; bool IsHumanPlayer(void) const; + + bool SendNetMsg(CNetMessage* pMsg, char bLocal, bool bForceReliable, bool bVoice); bool Connect(const char* szName, void* pNetChannel, bool bFakePlayer, void* a5, char* szMessage, int nMessageSize); void Disconnect(const Reputation_t nRepLvl, const char* szReason, ...); static bool VConnect(CClient* pClient, const char* szName, void* pNetChannel, bool bFakePlayer, void* a5, char* szMessage, int nMessageSize); void Clear(void); + +public: // Hook statics: static void VClear(CClient* pClient); static bool VProcessStringCmd(CClient* pClient, NET_StringCmd* pMsg); + static void* VSendSnapshot(CClient* pClient, CClientFrame* pFrame, int nTick, int nTickAck); private: uint32_t m_nUserID; //0x0010 @@ -62,7 +104,9 @@ private: int64_t m_nReputation; //0x0058 char pad_0014[182]; //0x0060 char m_szClientName[64]; //0x0116 - char pad_0015[522]; //0x0156 + char pad_0156[450]; //0x0156 + int m_nCommandTick; //0x0318 + char pad_031C[68]; //0x031C KeyValues* m_ConVars; //0x0360 char pad_0368[8]; //0x0368 CServer* m_pServer; //0x0370 @@ -84,7 +128,10 @@ private: bool m_bFullyAuthenticated; //0x05A3 char pad_05A4[24]; //0x05A4 PERSISTENCE m_nPersistenceState; //0x05BC - char pad_05C0[302676]; //0x05C0 + char pad_05C0[295312]; //0x05C0 + int m_iTracing; //0x48750 + CNetworkStatTrace m_Trace; //0x48754 + char pad_4878C[7304]; //0x4878C int32_t m_LastMovementTick; //0x4A414 #if defined (GAMEDLL_S2) || defined (GAMEDLL_S3) char pad_4A418[120]; //0x4A418 @@ -114,6 +161,12 @@ inline auto v_CClient_ProcessStringCmd = p_CClient_ProcessStringCmd.RCast(); +inline CMemory p_CClient_SendNetMsg; +inline auto v_CClient_SendNetMsg = p_CClient_SendNetMsg.RCast(); + +inline CMemory p_CClient_SendSnapshot; +inline auto v_CClient_SendSnapshot = p_CClient_SendSnapshot.RCast(); + /////////////////////////////////////////////////////////////////////////////// class VClient : public IDetour { @@ -124,7 +177,9 @@ class VClient : public IDetour LogFunAdr("CClient::Clear", p_CClient_Clear.GetPtr()); LogFunAdr("CClient::ProcessStringCmd", p_CClient_ProcessStringCmd.GetPtr()); LogFunAdr("CClient::SetSignonState", p_CClient_SetSignonState.GetPtr()); - LogVarAdr("g_pClient[128]", reinterpret_cast(g_pClient)); + LogFunAdr("CClient::SendNetMsg", p_CClient_SendNetMsg.GetPtr()); + LogFunAdr("CClient::SendSnapshot", p_CClient_SendSnapshot.GetPtr()); + LogVarAdr("g_Client[128]", reinterpret_cast(g_pClient)); } virtual void GetFun(void) const { @@ -137,8 +192,12 @@ class VClient : public IDetour p_CClient_Clear = g_GameDll.FindPatternSIMD("40 53 41 56 41 57 48 83 EC 20 48 8B D9 48 89 74"); #if defined (GAMEDLL_S0) || defined (GAMEDLL_S1) p_CClient_ProcessStringCmd = g_GameDll.FindPatternSIMD("48 83 EC 28 4C 8B 42 20"); + p_CClient_SendNetMsg = g_GameDll.FindPatternSIMD("48 89 5C 24 ?? 48 89 6C 24 ?? 48 89 74 24 ?? 57 41 56 41 57 48 83 EC 30 48 8B 05 ?? ?? ?? ?? 45 0F B6 F1"); + p_CClient_SendSnapshot = g_GameDll.FindPatternSIMD("44 89 44 24 ?? 48 89 4C 24 ?? 55 53 56 57 41 55"); #elif defined (GAMEDLL_S2) || defined (GAMEDLL_S3) p_CClient_ProcessStringCmd = g_GameDll.FindPatternSIMD("48 89 6C 24 ?? 57 48 81 EC ?? ?? ?? ?? 48 8B 7A 20"); + p_CClient_SendNetMsg = g_GameDll.FindPatternSIMD("40 53 55 56 57 41 56 48 83 EC 40 48 8B 05 ?? ?? ?? ??"); + p_CClient_SendSnapshot = g_GameDll.FindPatternSIMD("48 89 5C 24 ?? 55 56 41 55 41 56 41 57 48 8D 6C 24 ??"); #endif // !GAMEDLL_S0 || !GAMEDLL_S1 p_CClient_SetSignonState = g_GameDll.FindPatternSIMD("48 8B C4 48 89 58 10 48 89 70 18 57 48 81 EC ?? ?? ?? ?? 0F 29 70 E8 8B F2"); @@ -146,7 +205,9 @@ class VClient : public IDetour v_CClient_Disconnect = p_CClient_Disconnect.RCast(); /*48 8B C4 4C 89 40 18 4C 89 48 20 53 56 57 48 81 EC ?? ?? ?? ?? 83 B9 ?? ?? ?? ?? ?? 49 8B F8 8B F2*/ v_CClient_Clear = p_CClient_Clear.RCast(); /*40 53 41 56 41 57 48 83 EC 20 48 8B D9 48 89 74*/ v_CClient_ProcessStringCmd = p_CClient_ProcessStringCmd.RCast(); /*48 89 6C 24 ?? 57 48 81 EC ?? ?? ?? ?? 48 8B 7A 20*/ - v_CClient_SetSignonState = p_CClient_SetSignonState.RCast(); + v_CClient_SetSignonState = p_CClient_SetSignonState.RCast(); + v_CClient_SendNetMsg = p_CClient_SendNetMsg.RCast(); + v_CClient_SendSnapshot = p_CClient_SendSnapshot.RCast(); } virtual void GetVar(void) const { @@ -159,12 +220,14 @@ class VClient : public IDetour DetourAttach((LPVOID*)&v_CClient_Clear, &CClient::VClear); DetourAttach((LPVOID*)&v_CClient_Connect, &CClient::VConnect); DetourAttach((LPVOID*)&v_CClient_ProcessStringCmd, &CClient::VProcessStringCmd); + //DetourAttach((LPVOID*)&p_CClient_SendSnapshot, &CClient::VSendSnapshot); } virtual void Detach(void) const { DetourDetach((LPVOID*)&v_CClient_Clear, &CClient::VClear); DetourDetach((LPVOID*)&v_CClient_Connect, &CClient::VConnect); DetourDetach((LPVOID*)&v_CClient_ProcessStringCmd, &CClient::VProcessStringCmd); + //DetourDetach((LPVOID*)&p_CClient_SendSnapshot, &CClient::VSendSnapshot); } }; /////////////////////////////////////////////////////////////////////////////// diff --git a/r5dev/engine/server/server.h b/r5dev/engine/server/server.h index 800155e5..bcfcba80 100644 --- a/r5dev/engine/server/server.h +++ b/r5dev/engine/server/server.h @@ -38,6 +38,7 @@ public: const char* GetMapGroupName(void) const { return m_szMapGroupName; } int GetNumClasses(void) const { return m_nServerClasses; } int GetClassBits(void) const { return m_nServerClassBits; } + float GetCPUUsage(void) const { return m_fCPUPercent; } bool IsActive(void) const { return m_State >= server_state_t::ss_active; } bool IsLoading(void) const { return m_State == server_state_t::ss_loading; } bool IsDedicated(void) const { return m_bIsDedicated; } @@ -71,9 +72,13 @@ private: int m_nServerClasses; // number of unique server classes int m_nServerClassBits; // log2 of serverclasses char m_szHostInfo[128]; // see '[r5apex_ds.exe + 0x237740]' for more details. fmt: '[IPv6]:PORT:TIMEi64u' - char m_nGap0[0x4A290]; // TODO: Reverse the rest in this gap. + char m_nGap0[640]; + float m_fCPUPercent; + float m_fStartTime; + float m_fLastCPUCheckTime; + char m_nGap1[303108]; // TODO: Reverse the rest in this gap. #if defined (GAMEDLL_S2) || defined (GAMEDLL_S3) - char m_nGap1[0x80]; + char m_nGap2[0x80]; #endif }; #if defined (GAMEDLL_S0) || defined (GAMEDLL_S1) @@ -103,7 +108,7 @@ class VServer : public IDetour LogFunAdr("CServer::FrameJob", p_CServer_FrameJob.GetPtr()); LogFunAdr("CServer::ConnectClient", p_CServer_Authenticate.GetPtr()); LogFunAdr("CServer::RejectConnection", p_CServer_RejectConnection.GetPtr()); - LogVarAdr("g_pServer[128]", reinterpret_cast(g_pServer)); + LogVarAdr("g_Server[128]", reinterpret_cast(g_pServer)); #endif // !CLIENT_DLL } virtual void GetFun(void) const