forked from zanzo420/PirateSenseESP
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathProcMem.h
99 lines (77 loc) · 2.02 KB
/
ProcMem.h
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
#ifndef PROCMEM_H
#define PROCMEM_H
#define WIN32_LEAN_AND_MEAN
#include <windows.h>
#include <iostream>
#include <TlHelp32.h>
#include <string>
#include <sstream>
class ProcMem {
protected:
public:
uintptr_t *base; //Stores Module Base Address
uintptr_t Proc_ID; //Varible to store Process ID
HANDLE hProcess;
DWORD dwPID;
DWORD dwProtection;
DWORD dwCaveAddress;
BOOL bPOn, bIOn, bProt;
public:
ProcMem();
~ProcMem();
int chSizeOfArray(char *chArray);
int iSizeOfArray(int *iArray);
bool iFind(int *iAry, int iVal);
#pragma region TEMPLATE MEMORY FUNCTIONS
template <class cData>
cData Read(uintptr_t dwAddress)
{
cData cRead;
ReadProcessMemory(hProcess, (LPVOID)dwAddress, &cRead, sizeof(cData), NULL);
return cRead;
}
template <class cData>
cData Read(uintptr_t dwAddress, char *Offset, BOOL Type)
{
int iSize = iSizeOfArray(Offset) - 1;
dwAddress = Read<uintptr_t>(dwAddress);
for (int i = 0; i < iSize; i++)
dwAddress = Read<uintptr_t>(dwAddress + Offset[i]);
if (!Type)
return dwAddress + Offset[iSize];
else
return Read<cData>(dwAddress + Offset[iSize]);
}
template <class cData>
void Read(uintptr_t dwAddress, cData Value)
{
ReadProcessMemory(hProcess, (LPVOID)dwAddress, &Value, sizeof(cData), NULL);
}
template <class cData>
void Read(uintptr_t dwAddress, char *Offset, cData Value)
{
Read<cData>(Read<cData>(dwAddress, Offset, false), Value);
}
virtual void Process(char* ProcessName);
virtual void Patch(uintptr_t dwAddress, char *chPatch_Bts, char *chDefault_Bts);
virtual uintptr_t AOB_Scan(uintptr_t dwAddress, uintptr_t dwEnd, char *chPattern);
virtual uintptr_t Module(LPSTR ModuleName);
//WRITE MEMORY
template <class cData>
cData Write(uintptr_t(Address), cData B) {
try {
if (Proc_ID > 0) {
WriteProcessMemory(hProcess, (LPVOID)(Address), &B, sizeof(B), NULL);
return B;
}
else {
throw 1; //Throw Error Number / Defined In Catch
}
} // Try End
catch (int error) {
} //Catch End
return 0;
} //Write End
#pragma endregion
};
#endif