diff --git a/src/Components/Modules/Bans.cpp b/src/Components/Modules/Bans.cpp index 7fdef6cb..d3f5d306 100644 --- a/src/Components/Modules/Bans.cpp +++ b/src/Components/Modules/Bans.cpp @@ -181,9 +181,9 @@ namespace Components Game::client_t* client = &Game::svs_clients[num]; SteamID guid; - guid.bits = client->steamid; + guid.bits = client->steamID; - Bans::InsertBan({ guid, client->addr.ip }); + Bans::InsertBan({ guid, client->netchan.remoteAddress.ip }); Game::SV_KickClientError(client, reason); } diff --git a/src/Components/Modules/Bots.cpp b/src/Components/Modules/Bots.cpp index 4cbbde53..7e0f16ba 100644 --- a/src/Components/Modules/Bots.cpp +++ b/src/Components/Modules/Bots.cpp @@ -437,7 +437,7 @@ namespace Components ucmd.rightmove = g_botai[i].right; ucmd.weapon = g_botai[i].weapon; - client->deltaMessage = client->outgoingSequence - 1; + client->deltaMessage = client->netchan.outgoingSequence - 1; Game::SV_ClientThink(client, &ucmd); } diff --git a/src/Components/Modules/Client.cpp b/src/Components/Modules/Client.cpp index 0f3e991f..4f5f9770 100644 --- a/src/Components/Modules/Client.cpp +++ b/src/Components/Modules/Client.cpp @@ -134,7 +134,7 @@ namespace Components if (client->state >= 3) { - std::string ip = Game::NET_AdrToString(client->addr); + std::string ip = Game::NET_AdrToString(client->netchan.remoteAddress); if (ip.find_first_of(":") != std::string::npos) ip.erase(ip.begin() + ip.find_first_of(":"), ip.end()); // erase port Game::Scr_AddString(ip.data()); diff --git a/src/Components/Modules/Dedicated.cpp b/src/Components/Modules/Dedicated.cpp index dade1ca7..f19cae05 100644 --- a/src/Components/Modules/Dedicated.cpp +++ b/src/Components/Modules/Dedicated.cpp @@ -177,7 +177,7 @@ namespace Components { if (Game::svs_clients[i].state >= 3) { - list.append(Utils::String::VA(" %llX", Game::svs_clients[i].steamid)); + list.append(Utils::String::VA(" %llX", Game::svs_clients[i].steamID)); Utils::InfoString info(Game::svs_clients[i].connectInfoString); list.append(Utils::String::VA(" %llX", strtoull(info.get("realsteamId").data(), nullptr, 16))); @@ -218,7 +218,7 @@ namespace Components { if (!Dedicated::IsEnabled() && Dvar::Var("sv_dontrotate").get()) { - Dvar::Var("sv_dontrotate").setRaw(0); + Dvar::Var("sv_dontrotate").set(0); return; } diff --git a/src/Components/Modules/Download.cpp b/src/Components/Modules/Download.cpp index f4c25566..d2bb9649 100644 --- a/src/Components/Modules/Download.cpp +++ b/src/Components/Modules/Download.cpp @@ -387,7 +387,7 @@ namespace Components if (client->state >= 3) { - if (address.getIP().full == Network::Address(client->addr).getIP().full) + if (address.getIP().full == Network::Address(client->netchan.remoteAddress).getIP().full) { return client; } diff --git a/src/Components/Modules/Dvar.cpp b/src/Components/Modules/Dvar.cpp index dc95eb23..27effcb3 100644 --- a/src/Components/Modules/Dvar.cpp +++ b/src/Components/Modules/Dvar.cpp @@ -20,6 +20,7 @@ namespace Components { return this->dvar; } + template <> char* Dvar::Var::get() { if (this->dvar && this->dvar->type == Game::dvar_type::DVAR_TYPE_STRING && this->dvar->current.string) @@ -29,10 +30,12 @@ namespace Components return const_cast(""); } + template <> const char* Dvar::Var::get() { return this->get(); } + template <> int Dvar::Var::get() { if (this->dvar && this->dvar->type == Game::dvar_type::DVAR_TYPE_INT) @@ -42,10 +45,12 @@ namespace Components return 0; } + template <> unsigned int Dvar::Var::get() { return static_cast(this->get()); } + template <> float Dvar::Var::get() { if (this->dvar && this->dvar->type == Game::dvar_type::DVAR_TYPE_FLOAT) @@ -55,6 +60,7 @@ namespace Components return 0; } + template <> float* Dvar::Var::get() { static float val[4] = { 0 }; @@ -66,6 +72,7 @@ namespace Components return val; } + template <> bool Dvar::Var::get() { if (this->dvar && this->dvar->type == Game::dvar_type::DVAR_TYPE_BOOL) @@ -75,6 +82,7 @@ namespace Components return false; } + template <> std::string Dvar::Var::get() { return this->get(); @@ -84,57 +92,46 @@ namespace Components { this->set(const_cast(string)); } + void Dvar::Var::set(const char* string) { - if (this->dvar && this->dvar->name) + assert(this->dvar->type == Game::DVAR_TYPE_STRING); + if (this->dvar) { - Game::Dvar_SetCommand(this->dvar->name, string); + Game::Dvar_SetString(this->dvar, string); } } + void Dvar::Var::set(const std::string& string) { this->set(string.data()); } + void Dvar::Var::set(int integer) { - if (this->dvar && this->dvar->name) + assert(this->dvar->type == Game::DVAR_TYPE_INT); + if (this->dvar) { - Game::Dvar_SetCommand(this->dvar->name, Utils::String::VA("%i", integer)); - } - } - void Dvar::Var::set(float value) - { - if (this->dvar && this->dvar->name) - { - Game::Dvar_SetCommand(this->dvar->name, Utils::String::VA("%f", value)); + Game::Dvar_SetInt(this->dvar, integer); } } - void Dvar::Var::setRaw(int integer) + void Dvar::Var::set(float value) { + assert(this->dvar->type == Game::DVAR_TYPE_FLOAT); if (this->dvar) { - this->dvar->current.integer = integer; - this->dvar->latched.integer = integer; + Game::Dvar_SetFloat(this->dvar, value); } } - void Dvar::Var::setRaw(float value) + void Dvar::Var::set(bool enabled) { + assert(this->dvar->type == Game::DVAR_TYPE_BOOL); if (this->dvar) { - this->dvar->current.value = value; - this->dvar->latched.value = value; - } - } - - void Dvar::Var::setRaw(bool value) - { - if (this->dvar) - { - this->dvar->current.enabled = value; - this->dvar->latched.enabled = value; + Game::Dvar_SetBool(this->dvar, enabled); } } @@ -142,14 +139,17 @@ namespace Components { return Game::Dvar_RegisterBool(name, value, flag.val, description); } + template<> static Dvar::Var Dvar::Register(const char* name, const char* value, Dvar::Flag flag, const char* description) { return Game::Dvar_RegisterString(name, value, flag.val, description); } + template<> static Dvar::Var Dvar::Register(const char* name, int value, int min, int max, Dvar::Flag flag, const char* description) { return Game::Dvar_RegisterInt(name, value, min, max, flag.val, description); } + template<> static Dvar::Var Dvar::Register(const char* name, float value, float min, float max, Dvar::Flag flag, const char* description) { return Game::Dvar_RegisterFloat(name, value, min, max, flag.val, description); diff --git a/src/Components/Modules/Dvar.hpp b/src/Components/Modules/Dvar.hpp index b76d77f5..47cf8102 100644 --- a/src/Components/Modules/Dvar.hpp +++ b/src/Components/Modules/Dvar.hpp @@ -31,11 +31,7 @@ namespace Components void set(int integer); void set(float value); - - // TODO: Add others - void setRaw(int integer); - void setRaw(float value); - void setRaw(bool value); + void set(bool enabled); private: Game::dvar_t* dvar; diff --git a/src/Components/Modules/IW4MVM.cpp b/src/Components/Modules/IW4MVM.cpp index 94fe685e..9b6b3fb8 100644 --- a/src/Components/Modules/IW4MVM.cpp +++ b/src/Components/Modules/IW4MVM.cpp @@ -22,7 +22,7 @@ namespace Components { if (!Game::CL_IsCgameInitialized()) { - Dvar::Var("com_timescale").setRaw(1.0f); + Dvar::Var("com_timescale").set(1.0f); } }); diff --git a/src/Components/Modules/Maps.cpp b/src/Components/Modules/Maps.cpp index 5ed5ba11..ee36600a 100644 --- a/src/Components/Modules/Maps.cpp +++ b/src/Components/Modules/Maps.cpp @@ -560,7 +560,7 @@ namespace Components } hasDlc.push_back(hasAllMaps); - Dvar::Var(Utils::String::VA("isDlcInstalled_%d", pack.index)).setRaw(hasAllMaps ? 1 : 0); + Dvar::Var(Utils::String::VA("isDlcInstalled_%d", pack.index)).set(hasAllMaps ? 1 : 0); } // Must have all of dlc 3 to 5 or it causes issues @@ -571,7 +571,7 @@ namespace Components sentMessage = true; } - Dvar::Var("isDlcInstalled_All").setRaw(hasAllDlcs ? 1 : 0); + Dvar::Var("isDlcInstalled_All").set(hasAllDlcs ? 1 : 0); } bool Maps::IsCustomMap() diff --git a/src/Game/Functions.cpp b/src/Game/Functions.cpp index 1ac39bc9..bc30cf8e 100644 --- a/src/Game/Functions.cpp +++ b/src/Game/Functions.cpp @@ -289,6 +289,10 @@ namespace Game Dvar_SetFromStringByName_t Dvar_SetFromStringByName = Dvar_SetFromStringByName_t(0x4F52E0); Dvar_SetFromStringByNameFromSource_t Dvar_SetFromStringByNameFromSource = Dvar_SetFromStringByNameFromSource_t(0x4FC770); Dvar_SetStringByName_t Dvar_SetStringByName = Dvar_SetStringByName_t(0x44F060); + Dvar_SetString_t Dvar_SetString = Dvar_SetString_t(0x4A9580); + Dvar_SetBool_t Dvar_SetBool = Dvar_SetBool_t(0x4A9510); + Dvar_SetFloat_t Dvar_SetFloat = Dvar_SetFloat_t(0x40BB20); + Dvar_SetInt_t Dvar_SetInt = Dvar_SetInt_t(0x421DA0); SL_ConvertToString_t SL_ConvertToString = SL_ConvertToString_t(0x4EC1D0); SL_GetString_t SL_GetString = SL_GetString_t(0x4CDC10); @@ -634,7 +638,7 @@ namespace Game { if (client->state < 5) { - Components::Network::SendCommand(client->addr, "error", reason); + Components::Network::SendCommand(client->netchan.remoteAddress, "error", reason); } SV_KickClient(client, reason.data()); diff --git a/src/Game/Functions.hpp b/src/Game/Functions.hpp index 6e97fc7c..7c434042 100644 --- a/src/Game/Functions.hpp +++ b/src/Game/Functions.hpp @@ -253,15 +253,27 @@ namespace Game typedef dvar_t* (__cdecl * Dvar_RegisterColor_t)(const char* name, float r, float g, float b, float a, int flags, const char* description); extern Dvar_RegisterColor_t Dvar_RegisterColor; - typedef dvar_t*(__cdecl * Dvar_SetFromStringByName_t)(const char* cvar, const char* value); + typedef dvar_t* (__cdecl * Dvar_SetFromStringByName_t)(const char* cvar, const char* value); extern Dvar_SetFromStringByName_t Dvar_SetFromStringByName; - typedef dvar_t*(__cdecl * Dvar_SetFromStringByNameFromSource_t)(const char* cvar, const char* value, DvarSetSource source); + typedef dvar_t* (__cdecl * Dvar_SetFromStringByNameFromSource_t)(const char* cvar, const char* value, DvarSetSource source); extern Dvar_SetFromStringByNameFromSource_t Dvar_SetFromStringByNameFromSource; - typedef void(__cdecl * Dvar_SetStringByName_t)(const char* cvar, const char* value); + typedef void (__cdecl * Dvar_SetStringByName_t)(const char* cvar, const char* value); extern Dvar_SetStringByName_t Dvar_SetStringByName; + typedef void (__cdecl * Dvar_SetString_t)(dvar_t* cvar, const char* value); + extern Dvar_SetString_t Dvar_SetString; + + typedef void (__cdecl * Dvar_SetBool_t)(dvar_t* cvar, bool enabled); + extern Dvar_SetBool_t Dvar_SetBool; + + typedef void (__cdecl * Dvar_SetFloat_t)(dvar_t* cvar, float value); + extern Dvar_SetFloat_t Dvar_SetFloat; + + typedef void (__cdecl * Dvar_SetInt_t)(dvar_t* cvar, int integer); + extern Dvar_SetInt_t Dvar_SetInt; + typedef void(__cdecl * Dvar_GetUnpackedColorByName_t)(const char* name, float* color); extern Dvar_GetUnpackedColorByName_t Dvar_GetUnpackedColorByName; diff --git a/src/Game/Structs.hpp b/src/Game/Structs.hpp index a73b370d..84a1b091 100644 --- a/src/Game/Structs.hpp +++ b/src/Game/Structs.hpp @@ -74,7 +74,7 @@ namespace Game ASSET_TYPE_INVALID = -1, }; - typedef enum + typedef enum : unsigned int { DVAR_FLAG_NONE = 0x0, //no flags DVAR_FLAG_SAVED = 0x1, //saves in config_mp.cfg for clients @@ -152,7 +152,7 @@ namespace Game DVAR_SOURCE_DEVGUI = 0x3, }; - typedef enum + typedef enum : char { DVAR_TYPE_BOOL = 0x0, DVAR_TYPE_FLOAT = 0x1, @@ -3212,7 +3212,7 @@ namespace Game const char *name; const char *description; unsigned int flags; - char type; + dvar_type type; bool modified; DvarValue current; DvarValue latched; @@ -5015,6 +5015,35 @@ namespace Game char ipx[10]; }; + struct netProfileInfo_t + { + char __pad0[0x5E0]; + }; + + static_assert(sizeof(netProfileInfo_t) == 0x5E0); + + struct netchan_t + { + int outgoingSequence; + netsrc_t sock; + int dropped; + int incomingSequence; + netadr_t remoteAddress; + int qport; + int fragmentSequence; + int fragmentLength; + char* fragmentBuffer; + int fragmentBufferSize; + int unsentFragments; + int unsentFragmentStart; + int unsentLength; + char* unsentBuffer; + int unsentBufferSize; + netProfileInfo_t prof; + }; + + static_assert(sizeof(netchan_t) == 0x62C); + struct FxEditorElemAtlas { int behavior; @@ -5376,50 +5405,34 @@ namespace Game #pragma pack(push, 1) typedef struct client_s { - // 0 - clientstate_t state; - // 4 - char _pad[4]; - // 8 - int deltaMessage; - // 12 - char __pad[12]; - // 24 - int outgoingSequence; - // 28 - char pad[12]; - // 40 - netadr_t addr; - // 60 - char pad1[1568]; - // 1628 - char connectInfoString[1024]; - // 2652 - char pad2[133192]; - // 135844 - char name[16]; - // 135860 - char pad3[12]; - // 135872 - int snapNum; - // 135876 - int pad4; - // 135880 - short ping; - // 135882 - //char pad5[142390]; - char pad5[133158]; - // 269040 - int isBot; - // 269044 - char pad6[9228]; - // 278272 - unsigned __int64 steamid; - // 278280 - char pad7[403592]; + clientstate_t state; // 0 + char __pad0[4]; // 4 + int deltaMessage; // 8 + char __pad1[12]; // 12 + netchan_t netchan; // 24 + char __pad2[20]; // 1604 + const char* delayDropReason; // 1624 + char connectInfoString[1024]; // 1628 + char __pad3[132096]; // 2652 + int reliableSequence; // 134748 + int reliableAcknowledge; // 134752 + int reliableSent; // 134756 + char __pad4[1084]; // 134760 + char name[16]; // 135844 + char __pad5[12]; // 135860 + int snapNum; // 135872 + int __pad6; // 135876 + short ping; // 135880 + char __pad7[133158]; // 135882 + int isBot; // 269040 + char __pad8[9228]; // 269044 + unsigned __int64 steamID; // 278272 + char __pad9[403592]; // 278280 } client_t; #pragma pack(pop) + static_assert(sizeof(client_t) == 0xA6790); + struct CModelAllocData { void* mainArray;