2021-06-16 18:43:45 +03:00
|
|
|
#include "Interfaces.hpp"
|
|
|
|
#include "PatternScan.hpp"
|
2021-07-08 21:58:05 +03:00
|
|
|
#include "Options.hpp"
|
2021-06-16 18:43:45 +03:00
|
|
|
|
|
|
|
IF iff;
|
|
|
|
|
|
|
|
void* IF::GetInterface(const char* dllname, const char* interfacename)
|
|
|
|
{
|
|
|
|
tCreateInterface CreateInterface = (tCreateInterface)GetProcAddress(GetModuleHandleA(dllname), "CreateInterface");
|
|
|
|
int returnCode = 0;
|
2022-11-10 01:46:15 +03:00
|
|
|
void* ointerface = CreateInterface(interfacename, &returnCode);
|
2022-11-12 14:23:45 +03:00
|
|
|
printfdbg("Interface %s: %x\n", interfacename, ointerface);
|
2021-06-16 18:43:45 +03:00
|
|
|
return ointerface;
|
|
|
|
}
|
|
|
|
|
|
|
|
PVOID FindHudElement(const char* name)
|
|
|
|
{
|
2022-11-10 01:46:15 +03:00
|
|
|
static void* pointer1 = (void*)(FindPatternV2("client.dll", "B9 ? ? ? ? E8 ? ? ? ? 8B 5D 08") + 1);
|
2021-06-16 18:43:45 +03:00
|
|
|
static void* pThis = *reinterpret_cast<DWORD**>(pointer1);
|
2022-11-10 01:46:15 +03:00
|
|
|
static void* pointer2 = (void*)(FindPatternV2("client.dll", "55 8B EC 53 8B 5D 08 56 57 8B F9 33 F6 39 77 28"));
|
2021-06-16 18:43:45 +03:00
|
|
|
static auto find_hud_element
|
|
|
|
= reinterpret_cast<DWORD(__thiscall*)(void*, const char*)>(
|
|
|
|
pointer2
|
|
|
|
);
|
2022-11-12 14:23:45 +03:00
|
|
|
|
|
|
|
void* ret = (void*)find_hud_element(pThis, name);
|
|
|
|
printfdbg("HUD Element %s: %x\n", name, ret);
|
|
|
|
return ret;
|
2021-06-16 18:43:45 +03:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
#define VTBL(classptr) (*(DWORD*)classptr)
|
|
|
|
#define PVFN_(classptr, offset) (VTBL(classptr) + offset)
|
|
|
|
#define VFN_(classptr, offset) *(DWORD*)PVFN_(classptr, offset)
|
|
|
|
#define VFN(classptr, offset) VFN_(classptr, (offset * sizeof(void*)))
|
|
|
|
|
|
|
|
|
|
|
|
void IF::Init()
|
|
|
|
{
|
|
|
|
g_pEntityList = (IClientEntityList*)GetInterface("client.dll", "VClientEntityList003");
|
|
|
|
g_pGameUI = (CGameUI*)GetInterface("client.dll", "GameUI011");
|
|
|
|
g_pVGuiPanel = (vgui::IPanel*)GetInterface("vgui2.dll", "VGUI_Panel009");
|
|
|
|
g_pGameEvents = (CGameEventManager*)GetInterface("engine.dll", "GAMEEVENTSMANAGER002");
|
|
|
|
g_pEngineClient = (IVEngineClient*)GetInterface("engine.dll", "VEngineClient014");
|
|
|
|
g_pEnginetrace = (IEngineTrace*)GetInterface("engine.dll", "EngineTraceClient004");
|
|
|
|
g_pEnginevgui = (IEngineVGui*)GetInterface("engine.dll", "VEngineVGui001");
|
|
|
|
g_pVGui = (vgui::IVGui*)GetInterface("vgui2.dll", "VGUI_ivgui008");
|
|
|
|
g_pClient = (IBaseClientDLL*)GetInterface("client.dll", "VClient018");
|
|
|
|
g_pMdlInfo = (IVModelInfoClient*)GetInterface("engine.dll", "VModelInfoClient004");
|
|
|
|
g_pMdlRender = (IVModelRender*)GetInterface("engine.dll", "VEngineModel016");
|
|
|
|
g_pMaterialSystem = (IMaterialSystem*)GetInterface("materialsystem.dll", "VMaterialSystem080");
|
|
|
|
g_pCVar = (ICvar*)GetInterface("vstdlib.dll", "VEngineCvar007");
|
|
|
|
g_pVGuiSystem = (vgui::ISystem*)GetInterface("vgui2.dll", "VGUI_System010");
|
|
|
|
g_pVGuiSchemeManager = (vgui::ISchemeManager*)GetInterface("vgui2.dll", "VGUI_Scheme010");
|
|
|
|
g_pVGuiInput = (vgui::IInput*)GetInterface("vgui2.dll", "VGUI_Input005");
|
|
|
|
g_pFullFileSystem = (IFileSystem*)GetInterface("filesystem_stdio.dll", "VFileSystem017");
|
|
|
|
g_pGameConsole = (IGameConsole*)GetInterface("client.dll", "GameConsole004");
|
|
|
|
g_pEfx = (IVEfx*)GetInterface("engine.dll", "VEngineEffects001");
|
|
|
|
g_pPhysProps = (IPhysicsSurfaceProps*)GetInterface("vphysics.dll", "VPhysicsSurfaceProps001");
|
|
|
|
g_pRenderView = (IVRenderView*)GetInterface("engine.dll", "VEngineRenderView014");
|
|
|
|
g_pDebugOverlay = (IVDebugOverlay*)GetInterface("engine.dll", "VDebugOverlay004");
|
|
|
|
g_pEffects = (IEffects*)GetInterface("client.dll", "IEffects001");
|
|
|
|
g_pStudioRender = (IStudioRender*)GetInterface("studiorender.dll", "VStudioRender026");
|
2022-11-09 09:47:59 +03:00
|
|
|
g_pPrediction = (CPrediction*)GetInterface("client.dll", "VClientPrediction001");
|
2022-11-12 14:23:45 +03:00
|
|
|
g_pGameTypes = (IGameTypes*)GetInterface("client.dll", "VENGINE_GAMETYPES_VERSION002");
|
2022-11-13 14:55:23 +03:00
|
|
|
g_pGameMovement = (IGameMovement*)GetInterface("client.dll", "GameMovement001");
|
2021-06-16 18:43:45 +03:00
|
|
|
|
|
|
|
typedef PVOID(__cdecl* oKeyValuesSystem)();
|
|
|
|
oKeyValuesSystem pkeyValuesSystem = (oKeyValuesSystem)GetProcAddress(GetModuleHandleA("vstdlib.dll"), "KeyValuesSystem");
|
|
|
|
keyValuesSystem = (IKeyValuesSystem*)pkeyValuesSystem();
|
2022-10-29 19:05:04 +03:00
|
|
|
|
|
|
|
printfdbg("KeyValuesSystem = %x\n", keyValuesSystem);
|
|
|
|
|
2021-06-16 18:43:45 +03:00
|
|
|
myConMsg = (CONMSGPROC)GetProcAddress(GetModuleHandleA("tier0.dll"), "?ConMsg@@YAXPBDZZ");
|
2022-11-12 14:23:45 +03:00
|
|
|
myConColorMsg = (CONCOLORMSGPROC)GetProcAddress(GetModuleHandleA("tier0.dll"), "?ConColorMsg@@YAXABVColor@@PBDZZ");
|
2021-06-16 18:43:45 +03:00
|
|
|
|
|
|
|
g_pGlobals = **(CGlobalVarsBase***)(FindPatternV2("client.dll", "A1 ? ? ? ? 5E 8B 40 10") + 1);
|
|
|
|
g_pInput = *(CInput**)(FindPatternV2("client.dll", "B9 ? ? ? ? F3 0F 11 04 24 FF 50 10") + 1);
|
|
|
|
g_pViewRenderBeams = *(IViewRenderBeams**)(FindPatternV2("client.dll", "B9 ?? ?? ?? ?? A1 ?? ?? ?? ?? FF 10 A1 ?? ?? ?? ?? B9") + 0x1);
|
2022-10-29 19:05:04 +03:00
|
|
|
|
|
|
|
printfdbg("g_pGlobals = %x\n", g_pGlobals);
|
|
|
|
printfdbg("g_pInput = %x\n", g_pInput);
|
|
|
|
printfdbg("g_pViewRenderBeams = %x\n", g_pViewRenderBeams);
|
|
|
|
|
2021-06-16 18:43:45 +03:00
|
|
|
FX_Tesla = (FX_TeslaFn)FindPatternV2("client.dll", "55 8B EC 81 EC ? ? ? ? 56 57 8B F9 8B 47 18");
|
2022-10-29 19:05:04 +03:00
|
|
|
|
|
|
|
printfdbg("FX_TeslaFn %x\n", FX_Tesla);
|
|
|
|
|
2021-06-16 18:43:45 +03:00
|
|
|
BloodSprayFn = (FX_BloodSprayFn)FindPatternV2("client.dll", "55 8B EC 8B 4D 08 F3 0F 10 51 ? 8D");
|
2022-10-29 19:05:04 +03:00
|
|
|
|
|
|
|
printfdbg("FX_BloodSprayFn %x\n", BloodSprayFn);
|
|
|
|
|
2021-06-16 18:43:45 +03:00
|
|
|
DispatchEffect = (FXDispatchEffect)FindPatternV2("client.dll", "55 8B EC 83 E4 F8 83 EC 20 56 57 8B F9 C7 44 24");
|
2022-10-29 19:05:04 +03:00
|
|
|
|
|
|
|
printfdbg("DispatchEffect %x\n", DispatchEffect);
|
|
|
|
|
2021-06-16 18:43:45 +03:00
|
|
|
g_pChatElement = (CHudChat*)FindHudElement("CHudChat");
|
2022-10-29 19:05:04 +03:00
|
|
|
|
|
|
|
printfdbg("Chat element %x\n", g_pChatElement);
|
2021-06-16 18:43:45 +03:00
|
|
|
|
|
|
|
LoadFromFile = (void*)FindPatternV2("client.dll", "55 8B EC 83 EC 0C 53 8B 5D 08 56 8B F1 3B");
|
2022-10-29 19:05:04 +03:00
|
|
|
|
|
|
|
printfdbg("LoadFromFile %x\n", LoadFromFile);
|
|
|
|
|
2021-06-16 18:43:45 +03:00
|
|
|
g_pD3DDevice9 = **(IDirect3DDevice9***)(FindPatternV2("shaderapidx9.dll", "A1 ? ? ? ? 50 8B 08 FF 51 0C") + 1);
|
2022-10-29 19:05:04 +03:00
|
|
|
|
|
|
|
printfdbg("g_pD3DDevice9 %x\n", g_pD3DDevice9);
|
|
|
|
|
2021-06-16 18:43:45 +03:00
|
|
|
g_pMemAlloc = *(IMemAlloc**)(GetProcAddress(GetModuleHandle("tier0.dll"), "g_pMemAlloc"));
|
2022-10-29 19:05:04 +03:00
|
|
|
|
|
|
|
printfdbg("g_pMemAlloc %x\n", g_pMemAlloc);
|
2021-06-16 18:43:45 +03:00
|
|
|
|
|
|
|
g_pClientState = **reinterpret_cast<CClientState***>(getvfunc<uintptr_t>(g_pEngineClient, 12) + 0x10);
|
2022-10-29 19:05:04 +03:00
|
|
|
|
|
|
|
printfdbg("g_pClientState %x\n", g_pClientState);
|
2021-06-16 18:43:45 +03:00
|
|
|
|
|
|
|
CHudElement* g_pHudElement = (CHudElement*)FindHudElement("CCSGO_HudDeathNotice");
|
2022-10-29 19:05:04 +03:00
|
|
|
|
|
|
|
printfdbg("Hud element %x\n", g_pHudElement);
|
2021-06-16 18:43:45 +03:00
|
|
|
|
|
|
|
auto SteamClient = ((ISteamClient * (__cdecl*)(void))GetProcAddress(GetModuleHandleA("steam_api.dll"), "SteamClient"))();
|
2022-11-12 14:23:45 +03:00
|
|
|
g_SteamGameCoordinator = (ISteamGameCoordinator*)SteamClient->GetISteamGenericInterface((HSteamUser)1, (HSteamPipe)1, "SteamGameCoordinator001");
|
|
|
|
g_SteamUser = SteamClient->GetISteamUser((HSteamUser)1, (HSteamPipe)1, "SteamUser019");
|
2022-10-29 19:05:04 +03:00
|
|
|
|
|
|
|
printfdbg("SteamClient %X\n", SteamClient);
|
|
|
|
printfdbg("g_SteamGameCoordinator %X\n", g_SteamGameCoordinator);
|
|
|
|
printfdbg("g_SteamUser %X\n", g_SteamUser);
|
|
|
|
|
2021-06-16 18:43:45 +03:00
|
|
|
g_pClientLeafSystem = (IClientLeafSystem*)GetInterface("client.dll", "ClientLeafSystem002");
|
2022-10-29 19:05:04 +03:00
|
|
|
|
|
|
|
printfdbg("g_pClientLeafSystem %x\n", g_pClientLeafSystem);
|
|
|
|
|
2021-06-16 18:43:45 +03:00
|
|
|
g_pNetworkStringTableContainer = (INetworkStringTableContainer*)GetInterface("engine.dll", "VEngineClientStringTable001");
|
2022-10-29 19:05:04 +03:00
|
|
|
|
|
|
|
printfdbg("g_pNetworkStringTableContainer %x\n", g_pNetworkStringTableContainer);
|
2021-06-16 18:43:45 +03:00
|
|
|
|
|
|
|
getPlayerViewmodelArmConfigForPlayerModel = relativeToAbsolute<decltype(getPlayerViewmodelArmConfigForPlayerModel)>(FindPatternV2("client.dll", "E8 ? ? ? ? 89 87 ? ? ? ? 6A") + 1);
|
|
|
|
|
|
|
|
g_pMdlCache = (IMDLCache*)GetInterface("datacache.dll", "MDLCache004");
|
|
|
|
g_pEngineSound = (IEngineSound*)GetInterface("engine.dll", "IEngineSoundClient003");
|
|
|
|
|
|
|
|
g_pClientShadowMgr = *(IClientShadowMgr**)(FindPatternV2("client.dll", "A1 ? ? ? ? FF 90 ? ? ? ? 6A 00 6A 00") + 1);
|
2022-10-29 19:05:04 +03:00
|
|
|
|
|
|
|
printfdbg("g_pClientShadowMgr %x\n", g_pClientShadowMgr);
|
|
|
|
|
2021-06-16 18:43:45 +03:00
|
|
|
g_ViewRender = *(CCSViewRender**)(FindPatternV2("client.dll", "A1 ? ? ? ? B9 ? ? ? ? C7 05 ? ? ? ? ? ? ? ? FF 10") + 1);
|
2022-10-29 19:05:04 +03:00
|
|
|
|
|
|
|
printfdbg("g_ViewRender %x\n", g_ViewRender);
|
|
|
|
|
2022-11-12 14:23:45 +03:00
|
|
|
g_ClientMode = **(ClientModeShared***)((*(DWORD**)g_pClient)[10] + 0x5);
|
2022-10-29 19:05:04 +03:00
|
|
|
|
|
|
|
printfdbg("g_ClientMode %x\n", g_ClientMode);
|
2021-06-16 18:43:45 +03:00
|
|
|
|
|
|
|
g_pInputSystem = (IInputSystem*)GetInterface("inputsystem.dll", "InputSystemVersion001");
|
|
|
|
g_pVGuiSurface = (vgui::ISurface*)GetInterface("vguimatsurface.dll", "VGUI_Surface031");
|
2022-11-12 14:23:45 +03:00
|
|
|
|
2021-06-17 01:37:58 +03:00
|
|
|
fn_get_account_data = relativeToAbsolute<decltype(fn_get_account_data)>(FindPatternV2("client.dll", "E8 ? ? ? ? 85 C0 74 EE") + 1);
|
2022-10-29 19:05:04 +03:00
|
|
|
|
|
|
|
printfdbg("fn_get_account_data %x\n", fn_get_account_data);
|
2021-07-09 18:59:53 +03:00
|
|
|
|
|
|
|
ParticleCollectionSimulateAdr = relativeToAbsolute<decltype(ParticleCollectionSimulateAdr)>(FindPatternV2("client.dll", "E8 ? ? ? ? 8B 0E 83 C1 10") + 1);
|
2022-10-29 19:05:04 +03:00
|
|
|
|
|
|
|
printfdbg("ParticleCollectionSimulateAdr %x\n", ParticleCollectionSimulateAdr);
|
|
|
|
|
2022-11-12 14:23:45 +03:00
|
|
|
HudUniqueAlerts = (CHudElement*)FindHudElement("CCSGO_HudUniqueAlerts");
|
2022-11-09 09:47:59 +03:00
|
|
|
|
2022-11-12 14:23:45 +03:00
|
|
|
GameRulesProxy = *(C_GameRulesProxy**)(FindPatternV2("client.dll", "A1 ? ? ? ? 85 C0 0F 84 ? ? ? ? 80 B8 ? ? ? ? ? 74 7A")+1); //C_GameRulesProxy
|
2022-11-13 14:55:23 +03:00
|
|
|
dwRadarBase = FindPatternV2("client.dll", "A1 ? ? ? ? 8B 0C B0 8B 01 FF 50 ? 46 3B 35 ? ? ? ? 7C EA 8B 0D") + 1;
|
|
|
|
g_pMoveHelper = **reinterpret_cast<IMoveHelper***>(FindPatternV2("client.dll", "8B 0D ? ? ? ? 8B 46 08 68") + 2);
|
2021-06-16 18:43:45 +03:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
auto is_code_ptr(void* ptr) -> bool
|
|
|
|
{
|
|
|
|
constexpr const DWORD protect_flags = PAGE_EXECUTE | PAGE_EXECUTE_READ | PAGE_EXECUTE_READWRITE | PAGE_EXECUTE_WRITECOPY;
|
|
|
|
|
|
|
|
MEMORY_BASIC_INFORMATION out;
|
|
|
|
VirtualQuery(ptr, &out, sizeof out);
|
|
|
|
|
|
|
|
return out.Type
|
|
|
|
&& !(out.Protect & (PAGE_GUARD | PAGE_NOACCESS))
|
|
|
|
&& out.Protect & protect_flags;
|
|
|
|
}
|
|
|
|
|
2021-07-08 21:58:05 +03:00
|
|
|
|
|
|
|
const char* GetVisibleValue(const char* cvar)
|
|
|
|
{
|
|
|
|
PVOID addr = iff.g_pCVar->FindVar(cvar);
|
|
|
|
if (!addr) return 0;
|
|
|
|
char dummy[255];
|
|
|
|
memcpy(dummy, *(PVOID*)PVOID(*(int*)&addr + 0x24), 255);
|
|
|
|
return dummy;
|
|
|
|
}
|
|
|
|
|
|
|
|
float GetVisibleFloat(const char* cvar)
|
|
|
|
{
|
|
|
|
return std::stof(GetVisibleValue(cvar));
|
|
|
|
}
|
2021-06-16 18:43:45 +03:00
|
|
|
|
2021-07-08 21:58:05 +03:00
|
|
|
|
|
|
|
void SetFloatUnrestricted(const char* cvar, float value)
|
|
|
|
{
|
|
|
|
PVOID addr = iff.g_pCVar->FindVar(cvar);
|
|
|
|
if (!addr)
|
|
|
|
{
|
2022-10-29 19:05:04 +03:00
|
|
|
printfdbg("Can't find cvar %s\n", cvar);
|
|
|
|
|
2021-07-08 21:58:05 +03:00
|
|
|
PlaySoundA((char*)"null", opt.hModuleGlobal, SND_ASYNC);
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
float valX = value;
|
|
|
|
int valXX = *(int*)&valX ^ (DWORD)addr;
|
|
|
|
memcpy(PVOID(*(int*)&addr + 0x2C), &valXX, sizeof(valXX));
|
|
|
|
}
|
|
|
|
|
|
|
|
void SetIntUnrestricted(const char* cvar, int value)
|
|
|
|
{
|
|
|
|
PVOID addr = iff.g_pCVar->FindVar(cvar);
|
|
|
|
if (!addr)
|
|
|
|
{
|
2022-10-29 19:05:04 +03:00
|
|
|
printfdbg("Can't find cvar %s\n", cvar);
|
|
|
|
|
2021-07-08 21:58:05 +03:00
|
|
|
PlaySoundA((char*)"null", opt.hModuleGlobal, SND_ASYNC);
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
int valXX = value ^ (DWORD)addr;
|
|
|
|
memcpy(PVOID(*(int*)&addr + 0x30), &valXX, sizeof(valXX));
|
|
|
|
}
|
2021-06-16 18:43:45 +03:00
|
|
|
|
2021-07-08 21:58:05 +03:00
|
|
|
void SetValueUnrestricted(const char* cvar, float value)
|
|
|
|
{
|
2022-10-29 19:05:04 +03:00
|
|
|
printfdbg("Set %s to %f\n", cvar, value);
|
|
|
|
|
2021-07-08 21:58:05 +03:00
|
|
|
SetFloatUnrestricted(cvar, value);
|
|
|
|
SetIntUnrestricted(cvar, (int)value);
|
|
|
|
}
|
2022-11-09 06:36:54 +03:00
|
|
|
|
2022-11-09 09:47:59 +03:00
|
|
|
|
2022-11-10 03:05:22 +03:00
|
|
|
void NETSetConVar(const char* cvarname, const char* cvarvalue)
|
2022-11-09 06:36:54 +03:00
|
|
|
{
|
|
|
|
//__asm pushad
|
|
|
|
|
2022-11-10 03:05:22 +03:00
|
|
|
char name[1024]; char value[1024];
|
|
|
|
strcpy(name, cvarname);
|
|
|
|
strcpy(value, cvarvalue);
|
|
|
|
|
|
|
|
static void* pvSetConVar = (void*)FindPatternV2(XorStr("engine.dll"), XorStr("8D 4C 24 1C E8 ? ? ? ? 56"));
|
|
|
|
|
|
|
|
printfdbg("NETSetConVar %s %s\n", cvarname, value);
|
2022-11-09 06:36:54 +03:00
|
|
|
|
2022-11-10 03:05:22 +03:00
|
|
|
if (pvSetConVar) {
|
|
|
|
Invoke_NET_SetConVar(pvSetConVar, cvarname, value);
|
|
|
|
}
|
2022-11-09 06:36:54 +03:00
|
|
|
|
|
|
|
//__asm popad
|
|
|
|
}
|
2022-11-09 09:47:59 +03:00
|
|
|
|
2022-11-12 14:23:45 +03:00
|
|
|
void TextMsg(std::string text)
|
|
|
|
{
|
|
|
|
if (iff.g_pClient) {
|
|
|
|
char message[0x100] = "\x08\x04\x1A";
|
|
|
|
BYTE textsize = (BYTE)text.length();
|
|
|
|
memcpy(&message[3], &textsize, 1);
|
|
|
|
memcpy(&message[4], text.c_str(), textsize);
|
|
|
|
memcpy(&message[4 + textsize], "\x1A\x00\x1A\x00\x1A\x00\x1A\x00", 8);
|
|
|
|
iff.g_pClient->DispatchUserMessage(CS_UM_TextMsg, 0, textsize + 12, &message);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
void ShowMenu(std::string text)
|
|
|
|
{
|
|
|
|
if (iff.g_pClient) {
|
2022-11-13 00:40:18 +03:00
|
|
|
char message[0x1000] = "\x08\x80\x02\x10\x0A\x1A";
|
2022-11-12 14:23:45 +03:00
|
|
|
text.append("\x0A \x0A->\x00");
|
|
|
|
BYTE textsize = (BYTE)text.length();
|
|
|
|
memcpy(&message[6], &textsize, 1);
|
|
|
|
memcpy(&message[7], text.c_str(), textsize);
|
|
|
|
iff.g_pClient->DispatchUserMessage(CS_UM_ShowMenu, 0, textsize + 7, &message);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|