@cheatron/native-mock 1.0.1 → 1.0.3
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/index.d.ts +3 -3
- package/dist/index.d.ts.map +1 -1
- package/dist/index.js +3 -3
- package/dist/index.js.map +1 -1
- package/dist/kernel32.d.ts +16 -7
- package/dist/kernel32.d.ts.map +1 -1
- package/dist/kernel32.js +106 -47
- package/dist/kernel32.js.map +1 -1
- package/dist/msvcrt.d.ts +15 -0
- package/dist/msvcrt.d.ts.map +1 -0
- package/dist/msvcrt.js +43 -0
- package/dist/msvcrt.js.map +1 -0
- package/dist/os/handles.d.ts +1 -1
- package/dist/os/handles.d.ts.map +1 -1
- package/dist/os/kernel.d.ts +3 -0
- package/dist/os/kernel.d.ts.map +1 -1
- package/dist/os/kernel.js +33 -0
- package/dist/os/kernel.js.map +1 -1
- package/dist/os/module.d.ts +11 -0
- package/dist/os/module.d.ts.map +1 -0
- package/dist/os/module.js +20 -0
- package/dist/os/module.js.map +1 -0
- package/dist/os/process.d.ts +4 -0
- package/dist/os/process.d.ts.map +1 -1
- package/dist/os/process.js +11 -0
- package/dist/os/process.js.map +1 -1
- package/dist/os/thread.d.ts +4 -4
- package/dist/os/thread.d.ts.map +1 -1
- package/dist/os/thread.js.map +1 -1
- package/package.json +7 -7
- package/dist/process.d.ts +0 -29
- package/dist/process.d.ts.map +0 -1
- package/dist/process.js +0 -124
- package/dist/process.js.map +0 -1
- package/dist/thread.d.ts +0 -27
- package/dist/thread.d.ts.map +0 -1
- package/dist/thread.js +0 -113
- package/dist/thread.js.map +0 -1
package/dist/index.d.ts
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
|
+
export { log } from './logger';
|
|
2
|
+
export * from './kernel32';
|
|
3
|
+
export * from './msvcrt';
|
|
1
4
|
export * from '@cheatron/win32-ext';
|
|
2
5
|
export type * from '@cheatron/win32-ext';
|
|
3
|
-
export * from './process';
|
|
4
|
-
export * from './thread';
|
|
5
|
-
export * from './kernel32';
|
|
6
6
|
//# sourceMappingURL=index.d.ts.map
|
package/dist/index.d.ts.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":"AAAA,
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,GAAG,EAAE,MAAM,UAAU,CAAC;AAC/B,cAAc,YAAY,CAAC;AAC3B,cAAc,UAAU,CAAC;AACzB,cAAc,qBAAqB,CAAC;AACpC,mBAAmB,qBAAqB,CAAC"}
|
package/dist/index.js
CHANGED
package/dist/index.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.js","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":"AAAA,
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,GAAG,EAAE,MAAM,UAAU,CAAC;AAC/B,cAAc,YAAY,CAAC;AAC3B,cAAc,UAAU,CAAC;AACzB,cAAc,qBAAqB,CAAC"}
|
package/dist/kernel32.d.ts
CHANGED
|
@@ -3,20 +3,29 @@ export declare const Kernel32Impl: {
|
|
|
3
3
|
OpenProcess: (dwDesiredAccess: Def.DWORD, bInheritHandle: Def.BOOL, dwProcessId: Def.DWORD) => Def.HANDLE;
|
|
4
4
|
GetCurrentProcess: () => Def.HANDLE;
|
|
5
5
|
GetCurrentProcessId: () => Def.DWORD;
|
|
6
|
+
GetProcessId: (hProcess: Def.HANDLE) => Def.DWORD;
|
|
6
7
|
CloseHandle: (hObject: Def.HANDLE) => Def.BOOL;
|
|
7
|
-
ReadProcessMemory: (hProcess: Def.HANDLE, lpBaseAddress: Def.LPCVOID, lpBuffer: Buffer, nSize: Def.SIZE_T, _lpNumberOfBytesRead: Def.
|
|
8
|
-
WriteProcessMemory: (hProcess: Def.HANDLE, lpBaseAddress: Def.
|
|
9
|
-
VirtualAlloc: (lpAddress: Def.
|
|
10
|
-
VirtualAllocEx: (hProcess: Def.HANDLE, lpAddress: Def.
|
|
8
|
+
ReadProcessMemory: (hProcess: Def.HANDLE, lpBaseAddress: Def.LPCVOID, lpBuffer: Buffer, nSize: Def.SIZE_T, _lpNumberOfBytesRead: Def.SIZE_T | null) => Def.BOOL;
|
|
9
|
+
WriteProcessMemory: (hProcess: Def.HANDLE, lpBaseAddress: Def.LPVOID, lpBuffer: Buffer, nSize: Def.SIZE_T, _lpNumberOfBytesWritten: Def.SIZE_T | null) => Def.BOOL;
|
|
10
|
+
VirtualAlloc: (lpAddress: Def.LPVOID | null, dwSize: Def.SIZE_T, flAllocationType: Def.DWORD, flProtect: Def.DWORD) => Def.LPVOID;
|
|
11
|
+
VirtualAllocEx: (hProcess: Def.HANDLE, lpAddress: Def.LPVOID | null, dwSize: Def.SIZE_T, flAllocationType: Def.DWORD, flProtect: Def.DWORD) => Def.LPVOID;
|
|
11
12
|
VirtualQuery: (lpAddress: Def.LPCVOID, lpBuffer: Buffer, dwLength: Def.SIZE_T) => Def.SIZE_T;
|
|
12
13
|
VirtualQueryEx: (hProcess: Def.HANDLE, lpAddress: Def.LPCVOID, lpBuffer: Buffer, dwLength: Def.SIZE_T) => Def.SIZE_T;
|
|
13
|
-
OpenThread: (
|
|
14
|
+
OpenThread: (dwDesiredAccess: Def.DWORD, bInheritHandle: Def.BOOL, dwThreadId: Def.DWORD) => Def.HANDLE;
|
|
14
15
|
GetCurrentThread: () => Def.HANDLE;
|
|
15
16
|
GetCurrentThreadId: () => Def.DWORD;
|
|
17
|
+
GetThreadId: (hThread: Def.HANDLE) => Def.DWORD;
|
|
16
18
|
SuspendThread: (hThread: Def.HANDLE) => Def.DWORD;
|
|
17
19
|
ResumeThread: (hThread: Def.HANDLE) => Def.DWORD;
|
|
18
|
-
|
|
19
|
-
|
|
20
|
+
GetExitCodeThread: (hThread: Def.HANDLE, lpExitCode: Buffer) => Def.BOOL;
|
|
21
|
+
GetThreadContext: (hThread: Def.HANDLE, _lpContext: Buffer) => Def.BOOL;
|
|
22
|
+
SetThreadContext: (hThread: Def.HANDLE, _lpContext: Buffer) => Def.BOOL;
|
|
23
|
+
CreateThread: (_lpThreadAttributes: Def.SecurityAttributes | Def.LPVOID | null, _dwStackSize: Def.SIZE_T, _lpStartAddress: Def.LPVOID, _lpParameter: Def.LPVOID | null, _dwCreationFlags: Def.ThreadCreationFlags | Def.DWORD, lpThreadId: Buffer | null) => Def.HANDLE;
|
|
24
|
+
CreateRemoteThread: (hProcess: Def.HANDLE, _lpThreadAttributes: Def.SecurityAttributes | Def.LPVOID | null, _dwStackSize: Def.SIZE_T, _lpStartAddress: Def.LPVOID, _lpParameter: Def.LPVOID | null, _dwCreationFlags: Def.ThreadCreationFlags | Def.DWORD, lpThreadId: Buffer | null) => Def.HANDLE;
|
|
25
|
+
WaitForSingleObject: (hHandle: Def.HANDLE, _dwMilliseconds: Def.DWORD) => Def.DWORD;
|
|
26
|
+
GetModuleHandleW: (lpModuleName: string | null) => Def.HMODULE;
|
|
27
|
+
GetModuleHandleA: (lpModuleName: string | null) => Def.HMODULE;
|
|
28
|
+
GetProcAddress: (hModule: Def.HMODULE, lpProcName: string) => Def.LPVOID;
|
|
20
29
|
GetLastError: () => Def.DWORD;
|
|
21
30
|
};
|
|
22
31
|
//# sourceMappingURL=kernel32.d.ts.map
|
package/dist/kernel32.d.ts.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"kernel32.d.ts","sourceRoot":"","sources":["../src/kernel32.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,GAAG,MAAM,qBAAqB,CAAC;
|
|
1
|
+
{"version":3,"file":"kernel32.d.ts","sourceRoot":"","sources":["../src/kernel32.ts"],"names":[],"mappings":"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"}
|
package/dist/kernel32.js
CHANGED
|
@@ -1,6 +1,7 @@
|
|
|
1
1
|
import * as Def from '@cheatron/win32-ext';
|
|
2
2
|
import { kernel } from './os/kernel';
|
|
3
3
|
import { SimulatedProcess } from './os/process';
|
|
4
|
+
import { SimulatedThread } from './os/thread';
|
|
4
5
|
// Constants
|
|
5
6
|
const PSEUDO_HANDLE_PROCESS = 0xffffffffffffffffn; // -1
|
|
6
7
|
const PSEUDO_HANDLE_THREAD = 0xfffffffffffffffen; // -2
|
|
@@ -11,17 +12,12 @@ export const Kernel32Impl = {
|
|
|
11
12
|
},
|
|
12
13
|
GetCurrentProcess: () => PSEUDO_HANDLE_PROCESS,
|
|
13
14
|
GetCurrentProcessId: () => kernel.currentProcess.id,
|
|
15
|
+
GetProcessId: (hProcess) => kernel.GetProcessId(hProcess),
|
|
14
16
|
CloseHandle: (hObject) => {
|
|
15
|
-
if (hObject === PSEUDO_HANDLE_PROCESS || hObject === PSEUDO_HANDLE_THREAD) {
|
|
16
|
-
return 1;
|
|
17
|
-
}
|
|
18
17
|
return kernel.CloseHandle(hObject) ? 1 : 0;
|
|
19
18
|
},
|
|
20
19
|
// Memory
|
|
21
|
-
ReadProcessMemory: (hProcess, lpBaseAddress,
|
|
22
|
-
lpBuffer, // LPVOID
|
|
23
|
-
nSize, // bigint | number
|
|
24
|
-
_lpNumberOfBytesRead) => {
|
|
20
|
+
ReadProcessMemory: (hProcess, lpBaseAddress, lpBuffer, nSize, _lpNumberOfBytesRead) => {
|
|
25
21
|
let process;
|
|
26
22
|
if (hProcess === PSEUDO_HANDLE_PROCESS) {
|
|
27
23
|
process = kernel.currentProcess;
|
|
@@ -34,10 +30,8 @@ export const Kernel32Impl = {
|
|
|
34
30
|
}
|
|
35
31
|
if (!process)
|
|
36
32
|
return 0;
|
|
37
|
-
const addr = Number(lpBaseAddress);
|
|
38
|
-
const size = Number(nSize);
|
|
39
33
|
try {
|
|
40
|
-
const data = process.memory.read(
|
|
34
|
+
const data = process.memory.read(Number(lpBaseAddress), Number(nSize));
|
|
41
35
|
data.copy(lpBuffer);
|
|
42
36
|
return 1;
|
|
43
37
|
}
|
|
@@ -58,11 +52,9 @@ export const Kernel32Impl = {
|
|
|
58
52
|
}
|
|
59
53
|
if (!process)
|
|
60
54
|
return 0;
|
|
61
|
-
const addr = Number(lpBaseAddress);
|
|
62
|
-
// Ensure we only write nSize bytes essentially
|
|
63
55
|
const dataToWrite = lpBuffer.subarray(0, Number(nSize));
|
|
64
56
|
try {
|
|
65
|
-
if (process.memory.write(
|
|
57
|
+
if (process.memory.write(Number(lpBaseAddress), dataToWrite) > 0) {
|
|
66
58
|
return 1;
|
|
67
59
|
}
|
|
68
60
|
return 0;
|
|
@@ -87,21 +79,15 @@ export const Kernel32Impl = {
|
|
|
87
79
|
}
|
|
88
80
|
if (!process)
|
|
89
81
|
return 0n;
|
|
90
|
-
const addr = Number(lpAddress);
|
|
91
|
-
const size = Number(dwSize);
|
|
92
|
-
// We assume flAllocationType and flProtect match our internal constants or we pass them through
|
|
93
|
-
// Our MemoryManager uses constants from constants.ts which match Win32
|
|
94
82
|
try {
|
|
95
|
-
const
|
|
96
|
-
return BigInt(
|
|
83
|
+
const addr = process.memory.allocate(Number(lpAddress || 0), Number(dwSize), flAllocationType, flProtect);
|
|
84
|
+
return BigInt(addr);
|
|
97
85
|
}
|
|
98
86
|
catch (_e) {
|
|
99
87
|
return 0n;
|
|
100
88
|
}
|
|
101
89
|
},
|
|
102
|
-
VirtualQuery: (lpAddress, lpBuffer,
|
|
103
|
-
dwLength) => {
|
|
104
|
-
// Queries CURRENT process
|
|
90
|
+
VirtualQuery: (lpAddress, lpBuffer, dwLength) => {
|
|
105
91
|
return Kernel32Impl.VirtualQueryEx(PSEUDO_HANDLE_PROCESS, lpAddress, lpBuffer, dwLength);
|
|
106
92
|
},
|
|
107
93
|
VirtualQueryEx: (hProcess, lpAddress, lpBuffer, dwLength) => {
|
|
@@ -117,56 +103,129 @@ export const Kernel32Impl = {
|
|
|
117
103
|
}
|
|
118
104
|
if (!process)
|
|
119
105
|
return 0n;
|
|
120
|
-
const
|
|
121
|
-
|
|
122
|
-
// Serialize info to lpBuffer
|
|
123
|
-
// BaseAddress (0)
|
|
106
|
+
const info = process.memory.query(Number(lpAddress));
|
|
107
|
+
// Serialize info to lpBuffer (PMEMORY_BASIC_INFORMATION)
|
|
124
108
|
lpBuffer.writeBigUInt64LE(BigInt(info.BaseAddress), 0);
|
|
125
|
-
// AllocationBase (8)
|
|
126
109
|
lpBuffer.writeBigUInt64LE(BigInt(info.AllocationBase), 8);
|
|
127
|
-
// AllocationProtect (16)
|
|
128
110
|
lpBuffer.writeUInt32LE(info.AllocationProtect, 16);
|
|
129
|
-
// RegionSize (24)
|
|
130
111
|
lpBuffer.writeBigUInt64LE(BigInt(info.RegionSize), 24);
|
|
131
|
-
// State (32)
|
|
132
112
|
lpBuffer.writeUInt32LE(info.State, 32);
|
|
133
|
-
// Protect (36)
|
|
134
113
|
lpBuffer.writeUInt32LE(info.Protect, 36);
|
|
135
|
-
// Type (40)
|
|
136
114
|
lpBuffer.writeUInt32LE(info.Type, 40);
|
|
137
115
|
return BigInt(dwLength);
|
|
138
116
|
},
|
|
139
117
|
// Thread
|
|
140
|
-
OpenThread: (
|
|
141
|
-
return
|
|
118
|
+
OpenThread: (dwDesiredAccess, bInheritHandle, dwThreadId) => {
|
|
119
|
+
return kernel.OpenThread(dwDesiredAccess, !!bInheritHandle, dwThreadId);
|
|
142
120
|
},
|
|
143
121
|
GetCurrentThread: () => PSEUDO_HANDLE_THREAD,
|
|
144
|
-
GetCurrentThreadId: () =>
|
|
122
|
+
GetCurrentThreadId: () => kernel.GetThreadId(PSEUDO_HANDLE_THREAD),
|
|
123
|
+
GetThreadId: (hThread) => kernel.GetThreadId(hThread),
|
|
145
124
|
SuspendThread: (hThread) => {
|
|
146
|
-
if (hThread === PSEUDO_HANDLE_THREAD)
|
|
147
|
-
|
|
125
|
+
if (hThread === PSEUDO_HANDLE_THREAD) {
|
|
126
|
+
// Find current thread of current process
|
|
127
|
+
const tid = kernel.GetThreadId(hThread);
|
|
128
|
+
const thread = kernel.currentProcess.getThread(tid);
|
|
129
|
+
return thread ? thread.suspend() : 0;
|
|
130
|
+
}
|
|
148
131
|
const handleObj = kernel.getObjectFromHandle(hThread);
|
|
149
132
|
if (handleObj && handleObj.type === 'Thread') {
|
|
150
|
-
|
|
151
|
-
return 0; // SimulatedThread import might be cyclic or tricky, simplified for now
|
|
133
|
+
return handleObj.object.suspend();
|
|
152
134
|
}
|
|
153
|
-
return 0;
|
|
135
|
+
return 0;
|
|
154
136
|
},
|
|
155
137
|
ResumeThread: (hThread) => {
|
|
156
|
-
if (hThread === PSEUDO_HANDLE_THREAD)
|
|
157
|
-
|
|
138
|
+
if (hThread === PSEUDO_HANDLE_THREAD) {
|
|
139
|
+
const tid = kernel.GetThreadId(hThread);
|
|
140
|
+
const thread = kernel.currentProcess.getThread(tid);
|
|
141
|
+
return thread ? thread.resume() : 0;
|
|
142
|
+
}
|
|
158
143
|
const handleObj = kernel.getObjectFromHandle(hThread);
|
|
159
144
|
if (handleObj && handleObj.type === 'Thread') {
|
|
160
|
-
|
|
161
|
-
return 0;
|
|
145
|
+
return handleObj.object.resume();
|
|
162
146
|
}
|
|
163
147
|
return 0;
|
|
164
148
|
},
|
|
165
|
-
|
|
149
|
+
GetExitCodeThread: (hThread, lpExitCode) => {
|
|
150
|
+
const handleObj = kernel.getObjectFromHandle(hThread);
|
|
151
|
+
if (handleObj && handleObj.type === 'Thread') {
|
|
152
|
+
const thread = handleObj.object;
|
|
153
|
+
lpExitCode.writeUInt32LE(thread.state === 4 /* TERMINATED */ ? 0 : 259 /* STILL_ACTIVE */, 0);
|
|
154
|
+
return 1;
|
|
155
|
+
}
|
|
156
|
+
return 0;
|
|
157
|
+
},
|
|
158
|
+
GetThreadContext: (hThread, _lpContext) => {
|
|
159
|
+
const handleObj = kernel.getObjectFromHandle(hThread);
|
|
160
|
+
if (handleObj && handleObj.type === 'Thread') {
|
|
161
|
+
handleObj.object.getContext(0);
|
|
162
|
+
// Context serialization would go here. For now just 1.
|
|
163
|
+
return 1;
|
|
164
|
+
}
|
|
166
165
|
return 0;
|
|
167
166
|
},
|
|
168
|
-
SetThreadContext: (
|
|
169
|
-
|
|
167
|
+
SetThreadContext: (hThread, _lpContext) => {
|
|
168
|
+
const handleObj = kernel.getObjectFromHandle(hThread);
|
|
169
|
+
return handleObj && handleObj.type === 'Thread' ? 1 : 0;
|
|
170
|
+
},
|
|
171
|
+
CreateThread: (_lpThreadAttributes, _dwStackSize, _lpStartAddress, _lpParameter, _dwCreationFlags, lpThreadId) => {
|
|
172
|
+
return Kernel32Impl.CreateRemoteThread(PSEUDO_HANDLE_PROCESS, _lpThreadAttributes, _dwStackSize, _lpStartAddress, _lpParameter, _dwCreationFlags, lpThreadId);
|
|
173
|
+
},
|
|
174
|
+
CreateRemoteThread: (hProcess, _lpThreadAttributes, _dwStackSize, _lpStartAddress, _lpParameter, _dwCreationFlags, lpThreadId) => {
|
|
175
|
+
let process;
|
|
176
|
+
if (hProcess === PSEUDO_HANDLE_PROCESS) {
|
|
177
|
+
process = kernel.currentProcess;
|
|
178
|
+
}
|
|
179
|
+
else {
|
|
180
|
+
const handleObj = kernel.getObjectFromHandle(hProcess);
|
|
181
|
+
if (handleObj && handleObj.type === 'Process') {
|
|
182
|
+
process = handleObj.object;
|
|
183
|
+
}
|
|
184
|
+
}
|
|
185
|
+
if (!process)
|
|
186
|
+
return 0n;
|
|
187
|
+
const thread = process.createThread();
|
|
188
|
+
if (lpThreadId) {
|
|
189
|
+
lpThreadId.writeUInt32LE(thread.id, 0);
|
|
190
|
+
}
|
|
191
|
+
return kernel.currentProcess.handles.createHandle(thread, 'Thread', 0x1fffff /* ALL_ACCESS */);
|
|
192
|
+
},
|
|
193
|
+
// Synchronization
|
|
194
|
+
WaitForSingleObject: (hHandle, _dwMilliseconds) => {
|
|
195
|
+
const handleObj = kernel.getObjectFromHandle(hHandle);
|
|
196
|
+
if (handleObj && handleObj.type === 'Thread') {
|
|
197
|
+
handleObj.object.state = 4; // TERMINATED
|
|
198
|
+
}
|
|
199
|
+
return 0; // WAIT_OBJECT_0
|
|
200
|
+
},
|
|
201
|
+
// Modules
|
|
202
|
+
GetModuleHandleW: (lpModuleName) => {
|
|
203
|
+
const name = lpModuleName || 'kernel32.dll';
|
|
204
|
+
const mod = kernel.currentProcess.getModule(name);
|
|
205
|
+
if (mod)
|
|
206
|
+
return BigInt(mod.baseAddress);
|
|
207
|
+
// Create on the fly if not exists (lazy loading simulation)
|
|
208
|
+
const base = 0x7ff00000 + kernel.currentProcess.modules.size * 0x100000;
|
|
209
|
+
const newMod = kernel.currentProcess.createModule(name, base, 0x100000);
|
|
210
|
+
return BigInt(newMod.baseAddress);
|
|
211
|
+
},
|
|
212
|
+
GetModuleHandleA: (lpModuleName) => {
|
|
213
|
+
return Kernel32Impl.GetModuleHandleW(lpModuleName);
|
|
214
|
+
},
|
|
215
|
+
GetProcAddress: (hModule, lpProcName) => {
|
|
216
|
+
// Find module by base address
|
|
217
|
+
const mod = Array.from(kernel.currentProcess.modules.values()).find((m) => BigInt(m.baseAddress) === BigInt(hModule));
|
|
218
|
+
if (mod) {
|
|
219
|
+
let addr = mod.getProcAddress(lpProcName);
|
|
220
|
+
if (!addr) {
|
|
221
|
+
// Add pseudo-export if it doesn't exist
|
|
222
|
+
const offset = mod.exports.size * 16;
|
|
223
|
+
mod.addExport(lpProcName, offset);
|
|
224
|
+
addr = mod.getProcAddress(lpProcName);
|
|
225
|
+
}
|
|
226
|
+
return BigInt(addr);
|
|
227
|
+
}
|
|
228
|
+
return 0n;
|
|
170
229
|
},
|
|
171
230
|
GetLastError: () => 0,
|
|
172
231
|
};
|
package/dist/kernel32.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"kernel32.js","sourceRoot":"","sources":["../src/kernel32.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,GAAG,MAAM,qBAAqB,CAAC;AAC3C,OAAO,EAAE,MAAM,EAAE,MAAM,aAAa,CAAC;AACrC,OAAO,EAAE,gBAAgB,EAAE,MAAM,cAAc,CAAC;
|
|
1
|
+
{"version":3,"file":"kernel32.js","sourceRoot":"","sources":["../src/kernel32.ts"],"names":[],"mappings":"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"}
|
package/dist/msvcrt.d.ts
ADDED
|
@@ -0,0 +1,15 @@
|
|
|
1
|
+
import { type LPVOID, type SIZE_T } from '@cheatron/win32-ext';
|
|
2
|
+
/**
|
|
3
|
+
* MSVCRT function definitions
|
|
4
|
+
*/
|
|
5
|
+
export interface MSVCRT {
|
|
6
|
+
malloc: (size: SIZE_T) => LPVOID;
|
|
7
|
+
free: (ptr: LPVOID) => void;
|
|
8
|
+
memcpy: (dest: LPVOID, src: LPVOID, count: SIZE_T) => LPVOID;
|
|
9
|
+
memset: (dest: LPVOID, value: number, count: SIZE_T) => LPVOID;
|
|
10
|
+
}
|
|
11
|
+
/**
|
|
12
|
+
* Simulated implementation of MSVCRT
|
|
13
|
+
*/
|
|
14
|
+
export declare const MsvcrtImpl: MSVCRT;
|
|
15
|
+
//# sourceMappingURL=msvcrt.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"msvcrt.d.ts","sourceRoot":"","sources":["../src/msvcrt.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,KAAK,MAAM,EAAE,KAAK,MAAM,EAAE,MAAM,qBAAqB,CAAC;AAG/D;;GAEG;AACH,MAAM,WAAW,MAAM;IACrB,MAAM,EAAE,CAAC,IAAI,EAAE,MAAM,KAAK,MAAM,CAAC;IACjC,IAAI,EAAE,CAAC,GAAG,EAAE,MAAM,KAAK,IAAI,CAAC;IAC5B,MAAM,EAAE,CAAC,IAAI,EAAE,MAAM,EAAE,GAAG,EAAE,MAAM,EAAE,KAAK,EAAE,MAAM,KAAK,MAAM,CAAC;IAC7D,MAAM,EAAE,CAAC,IAAI,EAAE,MAAM,EAAE,KAAK,EAAE,MAAM,EAAE,KAAK,EAAE,MAAM,KAAK,MAAM,CAAC;CAChE;AAED;;GAEG;AACH,eAAO,MAAM,UAAU,EAAE,MA6CxB,CAAC"}
|
package/dist/msvcrt.js
ADDED
|
@@ -0,0 +1,43 @@
|
|
|
1
|
+
import {} from '@cheatron/win32-ext';
|
|
2
|
+
import { kernel } from './os/kernel';
|
|
3
|
+
/**
|
|
4
|
+
* Simulated implementation of MSVCRT
|
|
5
|
+
*/
|
|
6
|
+
export const MsvcrtImpl = {
|
|
7
|
+
malloc: (size) => {
|
|
8
|
+
const addr = kernel.currentProcess.memory.allocate(0, Number(size));
|
|
9
|
+
return BigInt(addr);
|
|
10
|
+
},
|
|
11
|
+
free: (ptr) => {
|
|
12
|
+
kernel.currentProcess.memory.free(Number(ptr));
|
|
13
|
+
},
|
|
14
|
+
memcpy: (dest, src, count) => {
|
|
15
|
+
const size = Number(count);
|
|
16
|
+
let data;
|
|
17
|
+
if (Buffer.isBuffer(src)) {
|
|
18
|
+
data = src.subarray(0, size);
|
|
19
|
+
}
|
|
20
|
+
else {
|
|
21
|
+
data = kernel.currentProcess.memory.read(Number(src), size);
|
|
22
|
+
}
|
|
23
|
+
if (Buffer.isBuffer(dest)) {
|
|
24
|
+
data.copy(dest);
|
|
25
|
+
}
|
|
26
|
+
else {
|
|
27
|
+
kernel.currentProcess.memory.write(Number(dest), data);
|
|
28
|
+
}
|
|
29
|
+
return dest;
|
|
30
|
+
},
|
|
31
|
+
memset: (dest, value, count) => {
|
|
32
|
+
const size = Number(count);
|
|
33
|
+
const data = Buffer.alloc(size, value);
|
|
34
|
+
if (Buffer.isBuffer(dest)) {
|
|
35
|
+
data.copy(dest);
|
|
36
|
+
}
|
|
37
|
+
else {
|
|
38
|
+
kernel.currentProcess.memory.write(Number(dest), data);
|
|
39
|
+
}
|
|
40
|
+
return dest;
|
|
41
|
+
},
|
|
42
|
+
};
|
|
43
|
+
//# sourceMappingURL=msvcrt.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"msvcrt.js","sourceRoot":"","sources":["../src/msvcrt.ts"],"names":[],"mappings":"AAAA,OAAO,EAA4B,MAAM,qBAAqB,CAAC;AAC/D,OAAO,EAAE,MAAM,EAAE,MAAM,aAAa,CAAC;AAYrC;;GAEG;AACH,MAAM,CAAC,MAAM,UAAU,GAAW;IAChC,MAAM,EAAE,CAAC,IAAY,EAAU,EAAE;QAC/B,MAAM,IAAI,GAAG,MAAM,CAAC,cAAc,CAAC,MAAM,CAAC,QAAQ,CAAC,CAAC,EAAE,MAAM,CAAC,IAAI,CAAC,CAAC,CAAC;QACpE,OAAO,MAAM,CAAC,IAAI,CAAsB,CAAC;IAC3C,CAAC;IAED,IAAI,EAAE,CAAC,GAAW,EAAQ,EAAE;QAC1B,MAAM,CAAC,cAAc,CAAC,MAAM,CAAC,IAAI,CAAC,MAAM,CAAC,GAAG,CAAC,CAAC,CAAC;IACjD,CAAC;IAED,MAAM,EAAE,CACN,IAAqB,EACrB,GAAoB,EACpB,KAAa,EACL,EAAE;QACV,MAAM,IAAI,GAAG,MAAM,CAAC,KAAK,CAAC,CAAC;QAC3B,IAAI,IAAY,CAAC;QAEjB,IAAI,MAAM,CAAC,QAAQ,CAAC,GAAG,CAAC,EAAE,CAAC;YACzB,IAAI,GAAG,GAAG,CAAC,QAAQ,CAAC,CAAC,EAAE,IAAI,CAAC,CAAC;QAC/B,CAAC;aAAM,CAAC;YACN,IAAI,GAAG,MAAM,CAAC,cAAc,CAAC,MAAM,CAAC,IAAI,CAAC,MAAM,CAAC,GAAG,CAAC,EAAE,IAAI,CAAC,CAAC;QAC9D,CAAC;QAED,IAAI,MAAM,CAAC,QAAQ,CAAC,IAAI,CAAC,EAAE,CAAC;YAC1B,IAAI,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;QAClB,CAAC;aAAM,CAAC;YACN,MAAM,CAAC,cAAc,CAAC,MAAM,CAAC,KAAK,CAAC,MAAM,CAAC,IAAI,CAAC,EAAE,IAAI,CAAC,CAAC;QACzD,CAAC;QAED,OAAO,IAAc,CAAC;IACxB,CAAC;IAED,MAAM,EAAE,CAAC,IAAqB,EAAE,KAAa,EAAE,KAAa,EAAU,EAAE;QACtE,MAAM,IAAI,GAAG,MAAM,CAAC,KAAK,CAAC,CAAC;QAC3B,MAAM,IAAI,GAAG,MAAM,CAAC,KAAK,CAAC,IAAI,EAAE,KAAK,CAAC,CAAC;QAEvC,IAAI,MAAM,CAAC,QAAQ,CAAC,IAAI,CAAC,EAAE,CAAC;YAC1B,IAAI,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;QAClB,CAAC;aAAM,CAAC;YACN,MAAM,CAAC,cAAc,CAAC,MAAM,CAAC,KAAK,CAAC,MAAM,CAAC,IAAI,CAAC,EAAE,IAAI,CAAC,CAAC;QACzD,CAAC;QAED,OAAO,IAAc,CAAC;IACxB,CAAC;CACF,CAAC"}
|
package/dist/os/handles.d.ts
CHANGED
|
@@ -3,7 +3,7 @@ export interface ISimulatedObject {
|
|
|
3
3
|
id: number;
|
|
4
4
|
}
|
|
5
5
|
export interface HandleObject {
|
|
6
|
-
type: 'Process' | 'Thread' | 'File' | 'Event' | 'Unknown';
|
|
6
|
+
type: 'Process' | 'Thread' | 'Module' | 'File' | 'Event' | 'Unknown';
|
|
7
7
|
object: ISimulatedObject;
|
|
8
8
|
accessMask: number;
|
|
9
9
|
}
|
package/dist/os/handles.d.ts.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"handles.d.ts","sourceRoot":"","sources":["../../src/os/handles.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,GAAG,MAAM,qBAAqB,CAAC;AAE3C,MAAM,WAAW,gBAAgB;IAC/B,EAAE,EAAE,MAAM,CAAC;CACZ;AAED,MAAM,WAAW,YAAY;IAC3B,IAAI,EAAE,SAAS,GAAG,QAAQ,GAAG,MAAM,GAAG,OAAO,GAAG,SAAS,CAAC;
|
|
1
|
+
{"version":3,"file":"handles.d.ts","sourceRoot":"","sources":["../../src/os/handles.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,GAAG,MAAM,qBAAqB,CAAC;AAE3C,MAAM,WAAW,gBAAgB;IAC/B,EAAE,EAAE,MAAM,CAAC;CACZ;AAED,MAAM,WAAW,YAAY;IAC3B,IAAI,EAAE,SAAS,GAAG,QAAQ,GAAG,QAAQ,GAAG,MAAM,GAAG,OAAO,GAAG,SAAS,CAAC;IACrE,MAAM,EAAE,gBAAgB,CAAC;IACzB,UAAU,EAAE,MAAM,CAAC;CACpB;AAED,qBAAa,WAAW;IACtB,OAAO,CAAC,OAAO,CAAmC;IAClD,OAAO,CAAC,eAAe,CAAM;IAE7B,YAAY,CACV,MAAM,EAAE,gBAAgB,EACxB,IAAI,EAAE,YAAY,CAAC,MAAM,CAAC,EAC1B,UAAU,EAAE,MAAM,GACjB,GAAG,CAAC,MAAM;IAeb,SAAS,CAAC,MAAM,EAAE,GAAG,CAAC,MAAM,GAAG,YAAY,GAAG,SAAS;IAIvD,WAAW,CAAC,MAAM,EAAE,GAAG,CAAC,MAAM,GAAG,OAAO;CAGzC"}
|
package/dist/os/kernel.d.ts
CHANGED
|
@@ -11,7 +11,10 @@ export declare class Kernel {
|
|
|
11
11
|
createProcess(name: string): SimulatedProcess;
|
|
12
12
|
getProcess(pid: number): SimulatedProcess | undefined;
|
|
13
13
|
OpenProcess(dwDesiredAccess: number, _bInheritHandle: boolean, dwProcessId: number): Def.HANDLE;
|
|
14
|
+
OpenThread(dwDesiredAccess: number, _bInheritHandle: boolean, dwThreadId: number): Def.HANDLE;
|
|
14
15
|
CloseHandle(hObject: Def.HANDLE): boolean;
|
|
16
|
+
GetProcessId(hProcess: Def.HANDLE): number;
|
|
17
|
+
GetThreadId(hThread: Def.HANDLE): number;
|
|
15
18
|
getObjectFromHandle(handle: Def.HANDLE): HandleObject | undefined;
|
|
16
19
|
}
|
|
17
20
|
export declare const kernel: Kernel;
|
package/dist/os/kernel.d.ts.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"kernel.d.ts","sourceRoot":"","sources":["../../src/os/kernel.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,gBAAgB,EAAE,MAAM,WAAW,CAAC;AAC7C,OAAO,KAAK,EAAE,YAAY,EAAE,MAAM,WAAW,CAAC;AAC9C,OAAO,KAAK,GAAG,MAAM,qBAAqB,CAAC;AAE3C,qBAAa,MAAM;IACjB,OAAc,QAAQ,EAAE,MAAM,CAAC;IAE/B,OAAO,CAAC,SAAS,CAA4C;IAC7D,OAAO,CAAC,OAAO,CAAa;IAGrB,cAAc,EAAE,gBAAgB,CAAC;;
|
|
1
|
+
{"version":3,"file":"kernel.d.ts","sourceRoot":"","sources":["../../src/os/kernel.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,gBAAgB,EAAE,MAAM,WAAW,CAAC;AAC7C,OAAO,KAAK,EAAE,YAAY,EAAE,MAAM,WAAW,CAAC;AAC9C,OAAO,KAAK,GAAG,MAAM,qBAAqB,CAAC;AAE3C,qBAAa,MAAM;IACjB,OAAc,QAAQ,EAAE,MAAM,CAAC;IAE/B,OAAO,CAAC,SAAS,CAA4C;IAC7D,OAAO,CAAC,OAAO,CAAa;IAGrB,cAAc,EAAE,gBAAgB,CAAC;;IAgBxC,OAAO,CAAC,mBAAmB;IAKpB,aAAa,CAAC,IAAI,EAAE,MAAM,GAAG,gBAAgB;IAQ7C,UAAU,CAAC,GAAG,EAAE,MAAM,GAAG,gBAAgB,GAAG,SAAS;IAMrD,WAAW,CAChB,eAAe,EAAE,MAAM,EACvB,eAAe,EAAE,OAAO,EACxB,WAAW,EAAE,MAAM,GAClB,GAAG,CAAC,MAAM;IAeN,UAAU,CACf,eAAe,EAAE,MAAM,EACvB,eAAe,EAAE,OAAO,EACxB,UAAU,EAAE,MAAM,GACjB,GAAG,CAAC,MAAM;IAeN,WAAW,CAAC,OAAO,EAAE,GAAG,CAAC,MAAM,GAAG,OAAO;IAMzC,YAAY,CAAC,QAAQ,EAAE,GAAG,CAAC,MAAM,GAAG,MAAM;IAQ1C,WAAW,CAAC,OAAO,EAAE,GAAG,CAAC,MAAM,GAAG,MAAM;IASxC,mBAAmB,CAAC,MAAM,EAAE,GAAG,CAAC,MAAM,GAAG,YAAY,GAAG,SAAS;CAGzE;AAGD,eAAO,MAAM,MAAM,QAAe,CAAC"}
|
package/dist/os/kernel.js
CHANGED
|
@@ -14,6 +14,8 @@ export class Kernel {
|
|
|
14
14
|
// We simulate it as a process so it can have a Handle Table.
|
|
15
15
|
this.currentProcess = new SimulatedProcess(9999, 'CurrentTestRunner.exe');
|
|
16
16
|
this.processes.set(this.currentProcess.id, this.currentProcess);
|
|
17
|
+
// Create initial thread for current process
|
|
18
|
+
this.currentProcess.createThread();
|
|
17
19
|
}
|
|
18
20
|
createSystemProcess() {
|
|
19
21
|
const sys = new SimulatedProcess(4, 'System');
|
|
@@ -39,9 +41,40 @@ export class Kernel {
|
|
|
39
41
|
const handle = this.currentProcess.handles.createHandle(targetProc, 'Process', dwDesiredAccess);
|
|
40
42
|
return handle;
|
|
41
43
|
}
|
|
44
|
+
OpenThread(dwDesiredAccess, _bInheritHandle, dwThreadId) {
|
|
45
|
+
// Find thread across all processes
|
|
46
|
+
for (const proc of this.processes.values()) {
|
|
47
|
+
const thread = proc.getThread(dwThreadId);
|
|
48
|
+
if (thread) {
|
|
49
|
+
return this.currentProcess.handles.createHandle(thread, 'Thread', dwDesiredAccess);
|
|
50
|
+
}
|
|
51
|
+
}
|
|
52
|
+
return 0n;
|
|
53
|
+
}
|
|
42
54
|
CloseHandle(hObject) {
|
|
55
|
+
const h = BigInt.asIntN(64, BigInt(hObject));
|
|
56
|
+
if (h === -1n || h === -2n)
|
|
57
|
+
return true;
|
|
43
58
|
return this.currentProcess.handles.closeHandle(hObject);
|
|
44
59
|
}
|
|
60
|
+
GetProcessId(hProcess) {
|
|
61
|
+
const h = BigInt.asIntN(64, BigInt(hProcess));
|
|
62
|
+
if (h === -1n)
|
|
63
|
+
return this.currentProcess.id;
|
|
64
|
+
const obj = this.getObjectFromHandle(hProcess);
|
|
65
|
+
if (obj && obj.type === 'Process')
|
|
66
|
+
return obj.object.id;
|
|
67
|
+
return 0;
|
|
68
|
+
}
|
|
69
|
+
GetThreadId(hThread) {
|
|
70
|
+
const h = BigInt.asIntN(64, BigInt(hThread));
|
|
71
|
+
if (h === -2n)
|
|
72
|
+
return this.currentProcess.threads.keys().next().value || 0;
|
|
73
|
+
const obj = this.getObjectFromHandle(hThread);
|
|
74
|
+
if (obj && obj.type === 'Thread')
|
|
75
|
+
return obj.object.id;
|
|
76
|
+
return 0;
|
|
77
|
+
}
|
|
45
78
|
// Helper to dereference a handle from the current process context
|
|
46
79
|
getObjectFromHandle(handle) {
|
|
47
80
|
return this.currentProcess.handles.getObject(handle);
|
package/dist/os/kernel.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"kernel.js","sourceRoot":"","sources":["../../src/os/kernel.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,gBAAgB,EAAE,MAAM,WAAW,CAAC;AAE7C,OAAO,KAAK,GAAG,MAAM,qBAAqB,CAAC;AAE3C,MAAM,OAAO,MAAM;IACV,MAAM,CAAC,QAAQ,CAAS;IAEvB,SAAS,GAAkC,IAAI,GAAG,EAAE,CAAC;IACrD,OAAO,GAAW,CAAC,CAAC,CAAC,6BAA6B;IAE1D,yFAAyF;IAClF,cAAc,CAAmB;IAExC;QACE,MAAM,CAAC,QAAQ,GAAG,IAAI,CAAC;QACvB,iEAAiE;QACjE,IAAI,CAAC,mBAAmB,EAAE,CAAC;QAE3B,2DAA2D;QAC3D,6DAA6D;QAC7D,IAAI,CAAC,cAAc,GAAG,IAAI,gBAAgB,CAAC,IAAI,EAAE,uBAAuB,CAAC,CAAC;QAC1E,IAAI,CAAC,SAAS,CAAC,GAAG,CAAC,IAAI,CAAC,cAAc,CAAC,EAAE,EAAE,IAAI,CAAC,cAAc,CAAC,CAAC;
|
|
1
|
+
{"version":3,"file":"kernel.js","sourceRoot":"","sources":["../../src/os/kernel.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,11 @@
|
|
|
1
|
+
export declare class SimulatedModule {
|
|
2
|
+
id: number;
|
|
3
|
+
name: string;
|
|
4
|
+
baseAddress: number;
|
|
5
|
+
size: number;
|
|
6
|
+
exports: Map<string, number>;
|
|
7
|
+
constructor(id: number, name: string, baseAddress: number, size: number);
|
|
8
|
+
addExport(name: string, offset: number): void;
|
|
9
|
+
getProcAddress(name: string): number | undefined;
|
|
10
|
+
}
|
|
11
|
+
//# sourceMappingURL=module.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"module.d.ts","sourceRoot":"","sources":["../../src/os/module.ts"],"names":[],"mappings":"AAAA,qBAAa,eAAe;IACnB,EAAE,EAAE,MAAM,CAAC;IACX,IAAI,EAAE,MAAM,CAAC;IACb,WAAW,EAAE,MAAM,CAAC;IACpB,IAAI,EAAE,MAAM,CAAC;IACb,OAAO,EAAE,GAAG,CAAC,MAAM,EAAE,MAAM,CAAC,CAAa;gBAEpC,EAAE,EAAE,MAAM,EAAE,IAAI,EAAE,MAAM,EAAE,WAAW,EAAE,MAAM,EAAE,IAAI,EAAE,MAAM;IAOvE,SAAS,CAAC,IAAI,EAAE,MAAM,EAAE,MAAM,EAAE,MAAM;IAItC,cAAc,CAAC,IAAI,EAAE,MAAM,GAAG,MAAM,GAAG,SAAS;CAGjD"}
|
|
@@ -0,0 +1,20 @@
|
|
|
1
|
+
export class SimulatedModule {
|
|
2
|
+
id;
|
|
3
|
+
name;
|
|
4
|
+
baseAddress;
|
|
5
|
+
size;
|
|
6
|
+
exports = new Map();
|
|
7
|
+
constructor(id, name, baseAddress, size) {
|
|
8
|
+
this.id = id;
|
|
9
|
+
this.name = name;
|
|
10
|
+
this.baseAddress = baseAddress;
|
|
11
|
+
this.size = size;
|
|
12
|
+
}
|
|
13
|
+
addExport(name, offset) {
|
|
14
|
+
this.exports.set(name, this.baseAddress + offset);
|
|
15
|
+
}
|
|
16
|
+
getProcAddress(name) {
|
|
17
|
+
return this.exports.get(name);
|
|
18
|
+
}
|
|
19
|
+
}
|
|
20
|
+
//# sourceMappingURL=module.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"module.js","sourceRoot":"","sources":["../../src/os/module.ts"],"names":[],"mappings":"AAAA,MAAM,OAAO,eAAe;IACnB,EAAE,CAAS;IACX,IAAI,CAAS;IACb,WAAW,CAAS;IACpB,IAAI,CAAS;IACb,OAAO,GAAwB,IAAI,GAAG,EAAE,CAAC;IAEhD,YAAY,EAAU,EAAE,IAAY,EAAE,WAAmB,EAAE,IAAY;QACrE,IAAI,CAAC,EAAE,GAAG,EAAE,CAAC;QACb,IAAI,CAAC,IAAI,GAAG,IAAI,CAAC;QACjB,IAAI,CAAC,WAAW,GAAG,WAAW,CAAC;QAC/B,IAAI,CAAC,IAAI,GAAG,IAAI,CAAC;IACnB,CAAC;IAED,SAAS,CAAC,IAAY,EAAE,MAAc;QACpC,IAAI,CAAC,OAAO,CAAC,GAAG,CAAC,IAAI,EAAE,IAAI,CAAC,WAAW,GAAG,MAAM,CAAC,CAAC;IACpD,CAAC;IAED,cAAc,CAAC,IAAY;QACzB,OAAO,IAAI,CAAC,OAAO,CAAC,GAAG,CAAC,IAAI,CAAC,CAAC;IAChC,CAAC;CACF"}
|
package/dist/os/process.d.ts
CHANGED
|
@@ -1,16 +1,20 @@
|
|
|
1
1
|
import { MemoryManager } from './memory';
|
|
2
2
|
import { HandleTable } from './handles';
|
|
3
3
|
import { SimulatedThread } from './thread';
|
|
4
|
+
import { SimulatedModule } from './module';
|
|
4
5
|
export declare class SimulatedProcess {
|
|
5
6
|
id: number;
|
|
6
7
|
name: string;
|
|
7
8
|
memory: MemoryManager;
|
|
8
9
|
handles: HandleTable;
|
|
9
10
|
threads: Map<number, SimulatedThread>;
|
|
11
|
+
modules: Map<string, SimulatedModule>;
|
|
10
12
|
exitCode: number | null;
|
|
11
13
|
private nextThreadId;
|
|
12
14
|
constructor(pid: number, name: string);
|
|
13
15
|
createThread(): SimulatedThread;
|
|
16
|
+
createModule(name: string, baseAddress: number, size: number): SimulatedModule;
|
|
17
|
+
getModule(name: string): SimulatedModule | undefined;
|
|
14
18
|
getThread(tid: number): SimulatedThread | undefined;
|
|
15
19
|
terminate(exitCode?: number): void;
|
|
16
20
|
}
|
package/dist/os/process.d.ts.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"process.d.ts","sourceRoot":"","sources":["../../src/os/process.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,aAAa,EAAE,MAAM,UAAU,CAAC;AACzC,OAAO,EAAE,WAAW,EAAE,MAAM,WAAW,CAAC;AACxC,OAAO,EAAE,eAAe,EAAE,MAAM,UAAU,CAAC;AAE3C,qBAAa,gBAAgB;IACpB,EAAE,EAAE,MAAM,CAAC;IACX,IAAI,EAAE,MAAM,CAAC;IACb,MAAM,EAAE,aAAa,CAAC;IACtB,OAAO,EAAE,WAAW,CAAC;IACrB,OAAO,EAAE,GAAG,CAAC,MAAM,EAAE,eAAe,CAAC,CAAC;IACtC,QAAQ,EAAE,MAAM,GAAG,IAAI,CAAQ;IAEtC,OAAO,CAAC,YAAY,CAAgB;gBAExB,GAAG,EAAE,MAAM,EAAE,IAAI,EAAE,MAAM;IAQrC,YAAY,IAAI,eAAe;IAO/B,SAAS,CAAC,GAAG,EAAE,MAAM,GAAG,eAAe,GAAG,SAAS;IAInD,SAAS,CAAC,QAAQ,GAAE,MAAU;CAO/B"}
|
|
1
|
+
{"version":3,"file":"process.d.ts","sourceRoot":"","sources":["../../src/os/process.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,aAAa,EAAE,MAAM,UAAU,CAAC;AACzC,OAAO,EAAE,WAAW,EAAE,MAAM,WAAW,CAAC;AACxC,OAAO,EAAE,eAAe,EAAE,MAAM,UAAU,CAAC;AAC3C,OAAO,EAAE,eAAe,EAAE,MAAM,UAAU,CAAC;AAE3C,qBAAa,gBAAgB;IACpB,EAAE,EAAE,MAAM,CAAC;IACX,IAAI,EAAE,MAAM,CAAC;IACb,MAAM,EAAE,aAAa,CAAC;IACtB,OAAO,EAAE,WAAW,CAAC;IACrB,OAAO,EAAE,GAAG,CAAC,MAAM,EAAE,eAAe,CAAC,CAAC;IACtC,OAAO,EAAE,GAAG,CAAC,MAAM,EAAE,eAAe,CAAC,CAAa;IAClD,QAAQ,EAAE,MAAM,GAAG,IAAI,CAAQ;IAEtC,OAAO,CAAC,YAAY,CAAgB;gBAExB,GAAG,EAAE,MAAM,EAAE,IAAI,EAAE,MAAM;IAQrC,YAAY,IAAI,eAAe;IAO/B,YAAY,CACV,IAAI,EAAE,MAAM,EACZ,WAAW,EAAE,MAAM,EACnB,IAAI,EAAE,MAAM,GACX,eAAe;IAOlB,SAAS,CAAC,IAAI,EAAE,MAAM,GAAG,eAAe,GAAG,SAAS;IAIpD,SAAS,CAAC,GAAG,EAAE,MAAM,GAAG,eAAe,GAAG,SAAS;IAInD,SAAS,CAAC,QAAQ,GAAE,MAAU;CAO/B"}
|
package/dist/os/process.js
CHANGED
|
@@ -1,12 +1,14 @@
|
|
|
1
1
|
import { MemoryManager } from './memory';
|
|
2
2
|
import { HandleTable } from './handles';
|
|
3
3
|
import { SimulatedThread } from './thread';
|
|
4
|
+
import { SimulatedModule } from './module';
|
|
4
5
|
export class SimulatedProcess {
|
|
5
6
|
id;
|
|
6
7
|
name;
|
|
7
8
|
memory;
|
|
8
9
|
handles;
|
|
9
10
|
threads;
|
|
11
|
+
modules = new Map();
|
|
10
12
|
exitCode = null;
|
|
11
13
|
nextThreadId = 1000;
|
|
12
14
|
constructor(pid, name) {
|
|
@@ -22,6 +24,15 @@ export class SimulatedProcess {
|
|
|
22
24
|
this.threads.set(tid, thread);
|
|
23
25
|
return thread;
|
|
24
26
|
}
|
|
27
|
+
createModule(name, baseAddress, size) {
|
|
28
|
+
const id = this.modules.size + 1;
|
|
29
|
+
const mod = new SimulatedModule(id, name, baseAddress, size);
|
|
30
|
+
this.modules.set(name.toLowerCase(), mod);
|
|
31
|
+
return mod;
|
|
32
|
+
}
|
|
33
|
+
getModule(name) {
|
|
34
|
+
return this.modules.get(name.toLowerCase());
|
|
35
|
+
}
|
|
25
36
|
getThread(tid) {
|
|
26
37
|
return this.threads.get(tid);
|
|
27
38
|
}
|
package/dist/os/process.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"process.js","sourceRoot":"","sources":["../../src/os/process.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,aAAa,EAAE,MAAM,UAAU,CAAC;AACzC,OAAO,EAAE,WAAW,EAAE,MAAM,WAAW,CAAC;AACxC,OAAO,EAAE,eAAe,EAAE,MAAM,UAAU,CAAC;AAE3C,MAAM,OAAO,gBAAgB;IACpB,EAAE,CAAS;IACX,IAAI,CAAS;IACb,MAAM,CAAgB;IACtB,OAAO,CAAc;IACrB,OAAO,CAA+B;IACtC,QAAQ,GAAkB,IAAI,CAAC;IAE9B,YAAY,GAAW,IAAI,CAAC;IAEpC,YAAY,GAAW,EAAE,IAAY;QACnC,IAAI,CAAC,EAAE,GAAG,GAAG,CAAC;QACd,IAAI,CAAC,IAAI,GAAG,IAAI,CAAC;QACjB,IAAI,CAAC,MAAM,GAAG,IAAI,aAAa,EAAE,CAAC;QAClC,IAAI,CAAC,OAAO,GAAG,IAAI,WAAW,EAAE,CAAC;QACjC,IAAI,CAAC,OAAO,GAAG,IAAI,GAAG,EAAE,CAAC;IAC3B,CAAC;IAED,YAAY;QACV,MAAM,GAAG,GAAG,IAAI,CAAC,YAAY,EAAE,CAAC;QAChC,MAAM,MAAM,GAAG,IAAI,eAAe,CAAC,GAAG,EAAE,IAAI,CAAC,EAAE,CAAC,CAAC;QACjD,IAAI,CAAC,OAAO,CAAC,GAAG,CAAC,GAAG,EAAE,MAAM,CAAC,CAAC;QAC9B,OAAO,MAAM,CAAC;IAChB,CAAC;IAED,SAAS,CAAC,GAAW;QACnB,OAAO,IAAI,CAAC,OAAO,CAAC,GAAG,CAAC,GAAG,CAAC,CAAC;IAC/B,CAAC;IAED,SAAS,CAAC,WAAmB,CAAC;QAC5B,IAAI,CAAC,QAAQ,GAAG,QAAQ,CAAC;QACzB,kBAAkB;QAClB,IAAI,CAAC,OAAO,CAAC,KAAK,EAAE,CAAC;QACrB,mBAAmB;QACnB,oCAAoC;IACtC,CAAC;CACF"}
|
|
1
|
+
{"version":3,"file":"process.js","sourceRoot":"","sources":["../../src/os/process.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,aAAa,EAAE,MAAM,UAAU,CAAC;AACzC,OAAO,EAAE,WAAW,EAAE,MAAM,WAAW,CAAC;AACxC,OAAO,EAAE,eAAe,EAAE,MAAM,UAAU,CAAC;AAC3C,OAAO,EAAE,eAAe,EAAE,MAAM,UAAU,CAAC;AAE3C,MAAM,OAAO,gBAAgB;IACpB,EAAE,CAAS;IACX,IAAI,CAAS;IACb,MAAM,CAAgB;IACtB,OAAO,CAAc;IACrB,OAAO,CAA+B;IACtC,OAAO,GAAiC,IAAI,GAAG,EAAE,CAAC;IAClD,QAAQ,GAAkB,IAAI,CAAC;IAE9B,YAAY,GAAW,IAAI,CAAC;IAEpC,YAAY,GAAW,EAAE,IAAY;QACnC,IAAI,CAAC,EAAE,GAAG,GAAG,CAAC;QACd,IAAI,CAAC,IAAI,GAAG,IAAI,CAAC;QACjB,IAAI,CAAC,MAAM,GAAG,IAAI,aAAa,EAAE,CAAC;QAClC,IAAI,CAAC,OAAO,GAAG,IAAI,WAAW,EAAE,CAAC;QACjC,IAAI,CAAC,OAAO,GAAG,IAAI,GAAG,EAAE,CAAC;IAC3B,CAAC;IAED,YAAY;QACV,MAAM,GAAG,GAAG,IAAI,CAAC,YAAY,EAAE,CAAC;QAChC,MAAM,MAAM,GAAG,IAAI,eAAe,CAAC,GAAG,EAAE,IAAI,CAAC,EAAE,CAAC,CAAC;QACjD,IAAI,CAAC,OAAO,CAAC,GAAG,CAAC,GAAG,EAAE,MAAM,CAAC,CAAC;QAC9B,OAAO,MAAM,CAAC;IAChB,CAAC;IAED,YAAY,CACV,IAAY,EACZ,WAAmB,EACnB,IAAY;QAEZ,MAAM,EAAE,GAAG,IAAI,CAAC,OAAO,CAAC,IAAI,GAAG,CAAC,CAAC;QACjC,MAAM,GAAG,GAAG,IAAI,eAAe,CAAC,EAAE,EAAE,IAAI,EAAE,WAAW,EAAE,IAAI,CAAC,CAAC;QAC7D,IAAI,CAAC,OAAO,CAAC,GAAG,CAAC,IAAI,CAAC,WAAW,EAAE,EAAE,GAAG,CAAC,CAAC;QAC1C,OAAO,GAAG,CAAC;IACb,CAAC;IAED,SAAS,CAAC,IAAY;QACpB,OAAO,IAAI,CAAC,OAAO,CAAC,GAAG,CAAC,IAAI,CAAC,WAAW,EAAE,CAAC,CAAC;IAC9C,CAAC;IAED,SAAS,CAAC,GAAW;QACnB,OAAO,IAAI,CAAC,OAAO,CAAC,GAAG,CAAC,GAAG,CAAC,CAAC;IAC/B,CAAC;IAED,SAAS,CAAC,WAAmB,CAAC;QAC5B,IAAI,CAAC,QAAQ,GAAG,QAAQ,CAAC;QACzB,kBAAkB;QAClB,IAAI,CAAC,OAAO,CAAC,KAAK,EAAE,CAAC;QACrB,mBAAmB;QACnB,oCAAoC;IACtC,CAAC;CACF"}
|
package/dist/os/thread.d.ts
CHANGED
|
@@ -5,7 +5,7 @@ export declare enum ThreadState {
|
|
|
5
5
|
WAITING = 3,
|
|
6
6
|
TERMINATED = 4
|
|
7
7
|
}
|
|
8
|
-
export interface
|
|
8
|
+
export interface SimulatedThreadContext {
|
|
9
9
|
Rip: bigint;
|
|
10
10
|
Rax: bigint;
|
|
11
11
|
Rbx: bigint;
|
|
@@ -29,12 +29,12 @@ export declare class SimulatedThread {
|
|
|
29
29
|
id: number;
|
|
30
30
|
state: ThreadState;
|
|
31
31
|
suspendCount: number;
|
|
32
|
-
context:
|
|
32
|
+
context: SimulatedThreadContext;
|
|
33
33
|
ownerProcessId: number;
|
|
34
34
|
constructor(tid: number, ownerPid: number);
|
|
35
35
|
suspend(): number;
|
|
36
36
|
resume(): number;
|
|
37
|
-
getContext(_flags: number):
|
|
38
|
-
setContext(ctx: Partial<
|
|
37
|
+
getContext(_flags: number): SimulatedThreadContext;
|
|
38
|
+
setContext(ctx: Partial<SimulatedThreadContext>): void;
|
|
39
39
|
}
|
|
40
40
|
//# sourceMappingURL=thread.d.ts.map
|
package/dist/os/thread.d.ts.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"thread.d.ts","sourceRoot":"","sources":["../../src/os/thread.ts"],"names":[],"mappings":"AAAA,oBAAY,WAAW;IACrB,WAAW,IAAA;IACX,KAAK,IAAA;IACL,OAAO,IAAA;IACP,OAAO,IAAA;IACP,UAAU,IAAA;CACX;AAED,MAAM,WAAW,
|
|
1
|
+
{"version":3,"file":"thread.d.ts","sourceRoot":"","sources":["../../src/os/thread.ts"],"names":[],"mappings":"AAAA,oBAAY,WAAW;IACrB,WAAW,IAAA;IACX,KAAK,IAAA;IACL,OAAO,IAAA;IACP,OAAO,IAAA;IACP,UAAU,IAAA;CACX;AAED,MAAM,WAAW,sBAAsB;IACrC,GAAG,EAAE,MAAM,CAAC;IACZ,GAAG,EAAE,MAAM,CAAC;IACZ,GAAG,EAAE,MAAM,CAAC;IACZ,GAAG,EAAE,MAAM,CAAC;IACZ,GAAG,EAAE,MAAM,CAAC;IACZ,GAAG,EAAE,MAAM,CAAC;IACZ,GAAG,EAAE,MAAM,CAAC;IACZ,GAAG,EAAE,MAAM,CAAC;IACZ,GAAG,EAAE,MAAM,CAAC;IACZ,EAAE,EAAE,MAAM,CAAC;IACX,EAAE,EAAE,MAAM,CAAC;IACX,GAAG,EAAE,MAAM,CAAC;IACZ,GAAG,EAAE,MAAM,CAAC;IACZ,GAAG,EAAE,MAAM,CAAC;IACZ,GAAG,EAAE,MAAM,CAAC;IACZ,GAAG,EAAE,MAAM,CAAC;IACZ,GAAG,EAAE,MAAM,CAAC;IACZ,MAAM,EAAE,MAAM,CAAC;CAChB;AAED,qBAAa,eAAe;IACnB,EAAE,EAAE,MAAM,CAAC;IACX,KAAK,EAAE,WAAW,CAAC;IACnB,YAAY,EAAE,MAAM,CAAK;IACzB,OAAO,EAAE,sBAAsB,CAAC;IAChC,cAAc,EAAE,MAAM,CAAC;gBAElB,GAAG,EAAE,MAAM,EAAE,QAAQ,EAAE,MAAM;IA4BzC,OAAO,IAAI,MAAM;IAQjB,MAAM,IAAI,MAAM;IAUhB,UAAU,CAAC,MAAM,EAAE,MAAM,GAAG,sBAAsB;IAKlD,UAAU,CAAC,GAAG,EAAE,OAAO,CAAC,sBAAsB,CAAC,GAAG,IAAI;CAGvD"}
|
package/dist/os/thread.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"thread.js","sourceRoot":"","sources":["../../src/os/thread.ts"],"names":[],"mappings":"AAAA,MAAM,CAAN,IAAY,WAMX;AAND,WAAY,WAAW;IACrB,2DAAW,CAAA;IACX,+CAAK,CAAA;IACL,mDAAO,CAAA;IACP,mDAAO,CAAA;IACP,yDAAU,CAAA;AACZ,CAAC,EANW,WAAW,KAAX,WAAW,QAMtB;AAuBD,MAAM,OAAO,eAAe;IACnB,EAAE,CAAS;IACX,KAAK,CAAc;IACnB,YAAY,GAAW,CAAC,CAAC;IACzB,OAAO,
|
|
1
|
+
{"version":3,"file":"thread.js","sourceRoot":"","sources":["../../src/os/thread.ts"],"names":[],"mappings":"AAAA,MAAM,CAAN,IAAY,WAMX;AAND,WAAY,WAAW;IACrB,2DAAW,CAAA;IACX,+CAAK,CAAA;IACL,mDAAO,CAAA;IACP,mDAAO,CAAA;IACP,yDAAU,CAAA;AACZ,CAAC,EANW,WAAW,KAAX,WAAW,QAMtB;AAuBD,MAAM,OAAO,eAAe;IACnB,EAAE,CAAS;IACX,KAAK,CAAc;IACnB,YAAY,GAAW,CAAC,CAAC;IACzB,OAAO,CAAyB;IAChC,cAAc,CAAS;IAE9B,YAAY,GAAW,EAAE,QAAgB;QACvC,IAAI,CAAC,EAAE,GAAG,GAAG,CAAC;QACd,IAAI,CAAC,cAAc,GAAG,QAAQ,CAAC;QAC/B,IAAI,CAAC,KAAK,GAAG,WAAW,CAAC,WAAW,CAAC;QAErC,mDAAmD;QACnD,IAAI,CAAC,OAAO,GAAG;YACb,GAAG,EAAE,eAAe,EAAE,oBAAoB;YAC1C,GAAG,EAAE,EAAE;YACP,GAAG,EAAE,EAAE;YACP,GAAG,EAAE,EAAE;YACP,GAAG,EAAE,EAAE;YACP,GAAG,EAAE,EAAE;YACP,GAAG,EAAE,EAAE;YACP,GAAG,EAAE,EAAE;YACP,GAAG,EAAE,cAAc,EAAE,cAAc;YACnC,EAAE,EAAE,EAAE;YACN,EAAE,EAAE,EAAE;YACN,GAAG,EAAE,EAAE;YACP,GAAG,EAAE,EAAE;YACP,GAAG,EAAE,EAAE;YACP,GAAG,EAAE,EAAE;YACP,GAAG,EAAE,EAAE;YACP,GAAG,EAAE,EAAE;YACP,MAAM,EAAE,KAAK,EAAE,aAAa;SAC7B,CAAC;IACJ,CAAC;IAED,OAAO;QACL,IAAI,CAAC,YAAY,EAAE,CAAC;QACpB,IAAI,IAAI,CAAC,KAAK,KAAK,WAAW,CAAC,OAAO,EAAE,CAAC;YACvC,IAAI,CAAC,KAAK,GAAG,WAAW,CAAC,OAAO,CAAC,CAAC,iBAAiB;QACrD,CAAC;QACD,OAAO,IAAI,CAAC,YAAY,GAAG,CAAC,CAAC,CAAC,wBAAwB;IACxD,CAAC;IAED,MAAM;QACJ,IAAI,IAAI,CAAC,YAAY,GAAG,CAAC,EAAE,CAAC;YAC1B,IAAI,CAAC,YAAY,EAAE,CAAC;YACpB,IAAI,IAAI,CAAC,YAAY,KAAK,CAAC,EAAE,CAAC;gBAC5B,IAAI,CAAC,KAAK,GAAG,WAAW,CAAC,KAAK,CAAC,CAAC,eAAe;YACjD,CAAC;QACH,CAAC;QACD,OAAO,IAAI,CAAC,YAAY,CAAC;IAC3B,CAAC;IAED,UAAU,CAAC,MAAc;QACvB,0EAA0E;QAC1E,OAAO,EAAE,GAAG,IAAI,CAAC,OAAO,EAAE,CAAC;IAC7B,CAAC;IAED,UAAU,CAAC,GAAoC;QAC7C,MAAM,CAAC,MAAM,CAAC,IAAI,CAAC,OAAO,EAAE,GAAG,CAAC,CAAC;IACnC,CAAC;CACF"}
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@cheatron/native-mock",
|
|
3
|
-
"version": "1.0.
|
|
3
|
+
"version": "1.0.3",
|
|
4
4
|
"description": "Pure JavaScript mock implementation of Win32 native modules for testing without native dependencies",
|
|
5
5
|
"main": "./dist/index.js",
|
|
6
6
|
"types": "./dist/index.d.ts",
|
|
@@ -31,7 +31,7 @@
|
|
|
31
31
|
"dependencies": {
|
|
32
32
|
"@cheatron/log": "^1.0.1",
|
|
33
33
|
"@cheatron/native-mock-koffi": "^1.0.0",
|
|
34
|
-
"@cheatron/win32-ext": "^1.0.
|
|
34
|
+
"@cheatron/win32-ext": "^1.0.2"
|
|
35
35
|
},
|
|
36
36
|
"devDependencies": {
|
|
37
37
|
"@eslint/js": "^10.0.1",
|
|
@@ -50,10 +50,10 @@
|
|
|
50
50
|
"scripts": {
|
|
51
51
|
"build": "tsc",
|
|
52
52
|
"prepublishOnly": "bun run build",
|
|
53
|
-
"test": "
|
|
54
|
-
"lint": "eslint
|
|
55
|
-
"lint:fix": "eslint
|
|
56
|
-
"format": "prettier --write
|
|
57
|
-
"format:check": "prettier --check
|
|
53
|
+
"test": "echo \"Error: no test specified\" && exit 1",
|
|
54
|
+
"lint": "eslint src/**/*.ts --cache",
|
|
55
|
+
"lint:fix": "eslint src/**/*.ts --fix",
|
|
56
|
+
"format": "prettier --write src/**/*.ts",
|
|
57
|
+
"format:check": "prettier --check src/**/*.ts"
|
|
58
58
|
}
|
|
59
59
|
}
|
package/dist/process.d.ts
DELETED
|
@@ -1,29 +0,0 @@
|
|
|
1
|
-
import type { MemoryBasicInformation, HANDLE } from '@cheatron/win32-ext';
|
|
2
|
-
/**
|
|
3
|
-
* Represents a remote process
|
|
4
|
-
*/
|
|
5
|
-
export declare class Process {
|
|
6
|
-
protected _handle: HANDLE | null;
|
|
7
|
-
protected _pid: number;
|
|
8
|
-
constructor(handle: HANDLE | null, autoClose?: boolean, pid?: number);
|
|
9
|
-
static open(pid: number, access?: number): Process;
|
|
10
|
-
static current(): CurrentProcess;
|
|
11
|
-
get handle(): HANDLE | null;
|
|
12
|
-
get pid(): number;
|
|
13
|
-
isValid(): boolean;
|
|
14
|
-
close(): void;
|
|
15
|
-
read(address: number | bigint, size: number): Buffer;
|
|
16
|
-
write(address: number | bigint, buffer: Buffer): void;
|
|
17
|
-
query(address: number | bigint): MemoryBasicInformation;
|
|
18
|
-
}
|
|
19
|
-
/**
|
|
20
|
-
* Represents the current process (singleton)
|
|
21
|
-
*/
|
|
22
|
-
export declare class CurrentProcess extends Process {
|
|
23
|
-
constructor();
|
|
24
|
-
close(): void;
|
|
25
|
-
query(address: number | bigint): MemoryBasicInformation;
|
|
26
|
-
}
|
|
27
|
-
export declare const currentProcess: CurrentProcess;
|
|
28
|
-
export declare const currentProcessId: number;
|
|
29
|
-
//# sourceMappingURL=process.d.ts.map
|
package/dist/process.d.ts.map
DELETED
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"process.d.ts","sourceRoot":"","sources":["../src/process.ts"],"names":[],"mappings":"AAOA,OAAO,KAAK,EAAE,sBAAsB,EAAE,MAAM,EAAE,MAAM,qBAAqB,CAAC;AAa1E;;GAEG;AACH,qBAAa,OAAO;IAClB,SAAS,CAAC,OAAO,EAAE,MAAM,GAAG,IAAI,CAAC;IACjC,SAAS,CAAC,IAAI,EAAE,MAAM,CAAC;gBAGrB,MAAM,EAAE,MAAM,GAAG,IAAI,EACrB,SAAS,GAAE,OAAc,EACzB,GAAG,GAAE,MAAU;IASjB,MAAM,CAAC,IAAI,CAAC,GAAG,EAAE,MAAM,EAAE,MAAM,GAAE,MAAiC,GAAG,OAAO;IAU5E,MAAM,CAAC,OAAO,IAAI,cAAc;IAIhC,IAAI,MAAM,kBAET;IACD,IAAI,GAAG,WAEN;IAED,OAAO,IAAI,OAAO;IAIlB,KAAK;IAUL,IAAI,CAAC,OAAO,EAAE,MAAM,GAAG,MAAM,EAAE,IAAI,EAAE,MAAM,GAAG,MAAM;IAyBpD,KAAK,CAAC,OAAO,EAAE,MAAM,GAAG,MAAM,EAAE,MAAM,EAAE,MAAM,GAAG,IAAI;IAsBrD,KAAK,CAAC,OAAO,EAAE,MAAM,GAAG,MAAM,GAAG,sBAAsB;CAkBxD;AAED;;GAEG;AACH,qBAAa,cAAe,SAAQ,OAAO;;IAMhC,KAAK;IAIL,KAAK,CAAC,OAAO,EAAE,MAAM,GAAG,MAAM,GAAG,sBAAsB;CAQjE;AAGD,eAAO,MAAM,cAAc,gBAAuB,CAAC;AACnD,eAAO,MAAM,gBAAgB,QAAqB,CAAC"}
|
package/dist/process.js
DELETED
|
@@ -1,124 +0,0 @@
|
|
|
1
|
-
import { Kernel32Impl as Kernel32 } from './kernel32';
|
|
2
|
-
import { ProcessAccess, MEMORY_BASIC_INFORMATION, MBI_SIZE, ffi, } from '@cheatron/win32-ext';
|
|
3
|
-
import { log } from './logger';
|
|
4
|
-
/**
|
|
5
|
-
* Handle management registry for automatic cleanup
|
|
6
|
-
*/
|
|
7
|
-
const registry = new FinalizationRegistry((handle) => {
|
|
8
|
-
if (handle) {
|
|
9
|
-
log.trace('Process', 'Closing orphaned handle via GC');
|
|
10
|
-
Kernel32.CloseHandle(handle);
|
|
11
|
-
}
|
|
12
|
-
});
|
|
13
|
-
/**
|
|
14
|
-
* Represents a remote process
|
|
15
|
-
*/
|
|
16
|
-
export class Process {
|
|
17
|
-
_handle;
|
|
18
|
-
_pid;
|
|
19
|
-
constructor(handle, autoClose = true, pid = 0) {
|
|
20
|
-
this._handle = handle;
|
|
21
|
-
this._pid = pid;
|
|
22
|
-
if (autoClose && handle) {
|
|
23
|
-
registry.register(this, handle, this);
|
|
24
|
-
}
|
|
25
|
-
}
|
|
26
|
-
static open(pid, access = ProcessAccess.ALL_ACCESS) {
|
|
27
|
-
log.debug('Process', `Opening process ${pid}`, { access });
|
|
28
|
-
const handle = Kernel32.OpenProcess(access, 0, pid);
|
|
29
|
-
if (!handle) {
|
|
30
|
-
log.error('Process', `Failed to open process ${pid}`);
|
|
31
|
-
throw new Error(`Failed to open process ${pid}`);
|
|
32
|
-
}
|
|
33
|
-
return new Process(handle, true, pid);
|
|
34
|
-
}
|
|
35
|
-
static current() {
|
|
36
|
-
return currentProcess;
|
|
37
|
-
}
|
|
38
|
-
get handle() {
|
|
39
|
-
return this._handle;
|
|
40
|
-
}
|
|
41
|
-
get pid() {
|
|
42
|
-
return this._pid;
|
|
43
|
-
}
|
|
44
|
-
isValid() {
|
|
45
|
-
return this._handle !== null && this._handle !== undefined;
|
|
46
|
-
}
|
|
47
|
-
close() {
|
|
48
|
-
if (this.isValid()) {
|
|
49
|
-
log.debug('Process', `Closing process handle ${this._pid}`);
|
|
50
|
-
const h = this._handle;
|
|
51
|
-
this._handle = null;
|
|
52
|
-
registry.unregister(this);
|
|
53
|
-
Kernel32.CloseHandle(h);
|
|
54
|
-
}
|
|
55
|
-
}
|
|
56
|
-
read(address, size) {
|
|
57
|
-
if (!this.isValid())
|
|
58
|
-
throw new Error('Process handle is closed');
|
|
59
|
-
const buffer = Buffer.alloc(size);
|
|
60
|
-
const success = Kernel32.ReadProcessMemory(this._handle, address, buffer, size, null);
|
|
61
|
-
if (!success) {
|
|
62
|
-
const errCode = Kernel32.GetLastError
|
|
63
|
-
? Kernel32.GetLastError()
|
|
64
|
-
: 'unknown';
|
|
65
|
-
log.error('Process', `ReadProcessMemory failed at ${address}`, {
|
|
66
|
-
size,
|
|
67
|
-
errCode,
|
|
68
|
-
});
|
|
69
|
-
throw new Error('ReadProcessMemory failed');
|
|
70
|
-
}
|
|
71
|
-
return buffer;
|
|
72
|
-
}
|
|
73
|
-
write(address, buffer) {
|
|
74
|
-
if (!this.isValid())
|
|
75
|
-
throw new Error('Process handle is closed');
|
|
76
|
-
const success = Kernel32.WriteProcessMemory(this._handle, address, buffer, buffer.length, null);
|
|
77
|
-
if (!success) {
|
|
78
|
-
const errCode = Kernel32.GetLastError
|
|
79
|
-
? Kernel32.GetLastError()
|
|
80
|
-
: 'unknown';
|
|
81
|
-
log.error('Process', `WriteProcessMemory failed at ${address}`, {
|
|
82
|
-
size: buffer.length,
|
|
83
|
-
errCode,
|
|
84
|
-
});
|
|
85
|
-
throw new Error('WriteProcessMemory failed');
|
|
86
|
-
}
|
|
87
|
-
}
|
|
88
|
-
query(address) {
|
|
89
|
-
if (!this.isValid())
|
|
90
|
-
throw new Error('Process handle is closed');
|
|
91
|
-
const buffer = Buffer.alloc(MBI_SIZE);
|
|
92
|
-
const result = Kernel32.VirtualQueryEx(this._handle, address, buffer, MBI_SIZE);
|
|
93
|
-
if (!result) {
|
|
94
|
-
log.error('Process', `VirtualQueryEx failed at ${address}`);
|
|
95
|
-
throw new Error('VirtualQueryEx failed');
|
|
96
|
-
}
|
|
97
|
-
const info = ffi.decode(buffer, MEMORY_BASIC_INFORMATION);
|
|
98
|
-
return info;
|
|
99
|
-
}
|
|
100
|
-
}
|
|
101
|
-
/**
|
|
102
|
-
* Represents the current process (singleton)
|
|
103
|
-
*/
|
|
104
|
-
export class CurrentProcess extends Process {
|
|
105
|
-
constructor() {
|
|
106
|
-
// Current process uses a pseudo-handle that doesn't need closing
|
|
107
|
-
super(Kernel32.GetCurrentProcess(), false, Kernel32.GetCurrentProcessId());
|
|
108
|
-
}
|
|
109
|
-
close() {
|
|
110
|
-
this._handle = null;
|
|
111
|
-
}
|
|
112
|
-
query(address) {
|
|
113
|
-
const buffer = Buffer.alloc(MBI_SIZE);
|
|
114
|
-
const result = Kernel32.VirtualQuery(address, buffer, MBI_SIZE);
|
|
115
|
-
if (!result)
|
|
116
|
-
throw new Error('VirtualQuery failed');
|
|
117
|
-
const info = ffi.decode(buffer, MEMORY_BASIC_INFORMATION);
|
|
118
|
-
return info;
|
|
119
|
-
}
|
|
120
|
-
}
|
|
121
|
-
// Export a pre-initialized instance of the current process
|
|
122
|
-
export const currentProcess = new CurrentProcess();
|
|
123
|
-
export const currentProcessId = currentProcess.pid;
|
|
124
|
-
//# sourceMappingURL=process.js.map
|
package/dist/process.js.map
DELETED
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"process.js","sourceRoot":"","sources":["../src/process.ts"],"names":[],"mappings":"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"}
|
package/dist/thread.d.ts
DELETED
|
@@ -1,27 +0,0 @@
|
|
|
1
|
-
import type { ThreadContext, HANDLE } from '@cheatron/win32-ext';
|
|
2
|
-
/**
|
|
3
|
-
* Represents a thread handle
|
|
4
|
-
*/
|
|
5
|
-
export declare class Thread {
|
|
6
|
-
protected _handle: HANDLE | null;
|
|
7
|
-
constructor(handle: HANDLE | null, autoClose?: boolean);
|
|
8
|
-
static open(threadId: number, access?: number): Thread;
|
|
9
|
-
static current(): CurrentThread;
|
|
10
|
-
static currentId(): number;
|
|
11
|
-
isValid(): boolean;
|
|
12
|
-
close(): void;
|
|
13
|
-
suspend(): number;
|
|
14
|
-
resume(): number;
|
|
15
|
-
getContext(flags?: number): ThreadContext;
|
|
16
|
-
setContext(ctx: ThreadContext): void;
|
|
17
|
-
get handle(): HANDLE | null;
|
|
18
|
-
}
|
|
19
|
-
/**
|
|
20
|
-
* Represents the current thread (singleton)
|
|
21
|
-
*/
|
|
22
|
-
export declare class CurrentThread extends Thread {
|
|
23
|
-
constructor();
|
|
24
|
-
close(): void;
|
|
25
|
-
}
|
|
26
|
-
export declare const currentThread: CurrentThread;
|
|
27
|
-
//# sourceMappingURL=thread.d.ts.map
|
package/dist/thread.d.ts.map
DELETED
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"thread.d.ts","sourceRoot":"","sources":["../src/thread.ts"],"names":[],"mappings":"AAQA,OAAO,KAAK,EAAE,aAAa,EAAE,MAAM,EAAE,MAAM,qBAAqB,CAAC;AAajE;;GAEG;AACH,qBAAa,MAAM;IACjB,SAAS,CAAC,OAAO,EAAE,MAAM,GAAG,IAAI,CAAC;gBAErB,MAAM,EAAE,MAAM,GAAG,IAAI,EAAE,SAAS,GAAE,OAAc;IAO5D,MAAM,CAAC,IAAI,CACT,QAAQ,EAAE,MAAM,EAChB,MAAM,GAAE,MAAgC,GACvC,MAAM;IAUT,MAAM,CAAC,OAAO,IAAI,aAAa;IAI/B,MAAM,CAAC,SAAS,IAAI,MAAM;IAI1B,OAAO,IAAI,OAAO;IAIlB,KAAK;IAUL,OAAO,IAAI,MAAM;IAUjB,MAAM,IAAI,MAAM;IAUhB,UAAU,CAAC,KAAK,GAAE,MAA0B,GAAG,aAAa;IAgB5D,UAAU,CAAC,GAAG,EAAE,aAAa,GAAG,IAAI;IAapC,IAAI,MAAM,kBAET;CACF;AAED;;GAEG;AACH,qBAAa,aAAc,SAAQ,MAAM;;IAM9B,KAAK;CAGf;AAGD,eAAO,MAAM,aAAa,eAAsB,CAAC"}
|
package/dist/thread.js
DELETED
|
@@ -1,113 +0,0 @@
|
|
|
1
|
-
import { Kernel32Impl as Kernel32 } from './kernel32';
|
|
2
|
-
import { ThreadAccess, ContextFlags, CONTEXT, CONTEXT_SIZE, ffi, } from '@cheatron/win32-ext';
|
|
3
|
-
import { log } from './logger';
|
|
4
|
-
/**
|
|
5
|
-
* Handle management registry for automatic cleanup
|
|
6
|
-
*/
|
|
7
|
-
const registry = new FinalizationRegistry((handle) => {
|
|
8
|
-
if (handle) {
|
|
9
|
-
log.trace('Thread', 'Closing orphaned handle via GC');
|
|
10
|
-
Kernel32.CloseHandle(handle);
|
|
11
|
-
}
|
|
12
|
-
});
|
|
13
|
-
/**
|
|
14
|
-
* Represents a thread handle
|
|
15
|
-
*/
|
|
16
|
-
export class Thread {
|
|
17
|
-
_handle;
|
|
18
|
-
constructor(handle, autoClose = true) {
|
|
19
|
-
this._handle = handle;
|
|
20
|
-
if (autoClose && handle) {
|
|
21
|
-
registry.register(this, handle, this);
|
|
22
|
-
}
|
|
23
|
-
}
|
|
24
|
-
static open(threadId, access = ThreadAccess.ALL_ACCESS) {
|
|
25
|
-
log.debug('Thread', `Opening thread ${threadId}`, { access });
|
|
26
|
-
const handle = Kernel32.OpenThread(access, 0, threadId);
|
|
27
|
-
if (!handle) {
|
|
28
|
-
log.error('Thread', `Failed to open thread ${threadId}`);
|
|
29
|
-
throw new Error(`Failed to open thread ${threadId}`);
|
|
30
|
-
}
|
|
31
|
-
return new Thread(handle);
|
|
32
|
-
}
|
|
33
|
-
static current() {
|
|
34
|
-
return currentThread;
|
|
35
|
-
}
|
|
36
|
-
static currentId() {
|
|
37
|
-
return Kernel32.GetCurrentThreadId();
|
|
38
|
-
}
|
|
39
|
-
isValid() {
|
|
40
|
-
return this._handle !== null && this._handle !== undefined;
|
|
41
|
-
}
|
|
42
|
-
close() {
|
|
43
|
-
if (this.isValid()) {
|
|
44
|
-
log.debug('Thread', 'Closing thread handle');
|
|
45
|
-
const h = this._handle;
|
|
46
|
-
this._handle = null;
|
|
47
|
-
registry.unregister(this);
|
|
48
|
-
Kernel32.CloseHandle(h);
|
|
49
|
-
}
|
|
50
|
-
}
|
|
51
|
-
suspend() {
|
|
52
|
-
if (!this.isValid())
|
|
53
|
-
throw new Error('Thread handle is closed');
|
|
54
|
-
const count = Kernel32.SuspendThread(this._handle);
|
|
55
|
-
if (count === 0xffffffff) {
|
|
56
|
-
log.error('Thread', 'SuspendThread failed');
|
|
57
|
-
throw new Error('SuspendThread failed');
|
|
58
|
-
}
|
|
59
|
-
return count;
|
|
60
|
-
}
|
|
61
|
-
resume() {
|
|
62
|
-
if (!this.isValid())
|
|
63
|
-
throw new Error('Thread handle is closed');
|
|
64
|
-
const count = Kernel32.ResumeThread(this._handle);
|
|
65
|
-
if (count === 0xffffffff) {
|
|
66
|
-
log.error('Thread', 'ResumeThread failed');
|
|
67
|
-
throw new Error('ResumeThread failed');
|
|
68
|
-
}
|
|
69
|
-
return count;
|
|
70
|
-
}
|
|
71
|
-
getContext(flags = ContextFlags.FULL) {
|
|
72
|
-
if (!this.isValid())
|
|
73
|
-
throw new Error('Thread handle is closed');
|
|
74
|
-
const buf = Buffer.alloc(CONTEXT_SIZE);
|
|
75
|
-
// ContextFlags is at offset 0x30 (after 6 × uint64 P*Home registers)
|
|
76
|
-
buf.writeUInt32LE(flags, 0x30);
|
|
77
|
-
const success = Kernel32.GetThreadContext(this._handle, buf);
|
|
78
|
-
if (!success) {
|
|
79
|
-
log.error('Thread', 'GetThreadContext failed');
|
|
80
|
-
throw new Error('GetThreadContext failed');
|
|
81
|
-
}
|
|
82
|
-
return ffi.decode(buf, CONTEXT);
|
|
83
|
-
}
|
|
84
|
-
setContext(ctx) {
|
|
85
|
-
if (!this.isValid())
|
|
86
|
-
throw new Error('Thread handle is closed');
|
|
87
|
-
const buf = Buffer.alloc(CONTEXT_SIZE);
|
|
88
|
-
ffi.encode(buf, CONTEXT, ctx);
|
|
89
|
-
const success = Kernel32.SetThreadContext(this._handle, buf);
|
|
90
|
-
if (!success) {
|
|
91
|
-
log.error('Thread', 'SetThreadContext failed');
|
|
92
|
-
throw new Error('SetThreadContext failed');
|
|
93
|
-
}
|
|
94
|
-
}
|
|
95
|
-
get handle() {
|
|
96
|
-
return this._handle;
|
|
97
|
-
}
|
|
98
|
-
}
|
|
99
|
-
/**
|
|
100
|
-
* Represents the current thread (singleton)
|
|
101
|
-
*/
|
|
102
|
-
export class CurrentThread extends Thread {
|
|
103
|
-
constructor() {
|
|
104
|
-
// Current thread uses a pseudo-handle that doesn't need closing
|
|
105
|
-
super(Kernel32.GetCurrentThread(), false);
|
|
106
|
-
}
|
|
107
|
-
close() {
|
|
108
|
-
this._handle = null;
|
|
109
|
-
}
|
|
110
|
-
}
|
|
111
|
-
// Export a pre-initialized instance of the current thread
|
|
112
|
-
export const currentThread = new CurrentThread();
|
|
113
|
-
//# sourceMappingURL=thread.js.map
|
package/dist/thread.js.map
DELETED
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"thread.js","sourceRoot":"","sources":["../src/thread.ts"],"names":[],"mappings":"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"}
|