@jshookmcp/jshook 0.2.9 → 0.3.1

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.
Files changed (316) hide show
  1. package/README.md +25 -50
  2. package/README.zh.md +25 -48
  3. package/dist/AntiCheatDetector-CGVGNfy5.mjs +1 -0
  4. package/dist/CacheAdapters-CdAxBmVW.mjs +1 -0
  5. package/dist/CodeInjector-BlgyqTOk.mjs +1 -0
  6. package/dist/ConsoleMonitor-Dkqc0HNi.mjs +490 -0
  7. package/dist/DOMInspector-BYY_EJ0C.mjs +95 -0
  8. package/dist/DarwinAPI-DC4HGGLl.mjs +1 -0
  9. package/dist/DetailedDataManager-BniBJlVv.mjs +1 -0
  10. package/dist/EventBus-DgciURGg.mjs +1 -0
  11. package/dist/EvidenceGraphBridge-BIfgB7HP.mjs +1 -0
  12. package/dist/ExtensionManager-erMpqcLk.mjs +1 -0
  13. package/dist/FingerprintManager-N7BZqjxP.mjs +1 -0
  14. package/dist/HardwareBreakpoint-OcJqNFVc.mjs +1 -0
  15. package/dist/HeapAnalyzer-CqAxZzeS.mjs +1 -0
  16. package/dist/{HookGeneratorBuilders.core.generators.storage-CtcdK78Q.mjs → HookGeneratorBuilders.core.generators.storage-Bf1fbrNK.mjs} +66 -174
  17. package/dist/InstrumentationSession-DxXs0sCp.mjs +1 -0
  18. package/dist/MCPServer.search.handlers.domain-DVbWL1bT.mjs +1 -0
  19. package/dist/MemoryController-BaqstM5w.mjs +2 -0
  20. package/dist/MemoryScanSession-CaxAjZJf.mjs +1 -0
  21. package/dist/MemoryScanner-BLYnMJy6.mjs +1 -0
  22. package/dist/NativeMemoryManager.impl-CI554XbY.mjs +1 -0
  23. package/dist/NativeMemoryManager.utils-DM4NC3FE.mjs +1 -0
  24. package/dist/PEAnalyzer-DJyaJTQJ.mjs +1 -0
  25. package/dist/PageController-D9jVkH0i.mjs +1 -0
  26. package/dist/PointerChainEngine-5nF9eNlu.mjs +1 -0
  27. package/dist/PrerequisiteError-Bl3dK8XA.mjs +1 -0
  28. package/dist/ProcessRegistry-Hf12LlR9.mjs +1 -0
  29. package/dist/ResponseBuilder-B2lu4KEl.mjs +1 -0
  30. package/dist/ReverseEvidenceGraph-B931HeoW.mjs +2 -0
  31. package/dist/ScriptManager-fgqiALgj.mjs +7 -0
  32. package/dist/Speedhack-l6s8L2Qw.mjs +1 -0
  33. package/dist/StealthVerifier-Dhbj4B4P.mjs +1 -0
  34. package/dist/StructureAnalyzer-A-WamfYE.mjs +2 -0
  35. package/dist/ToolCatalog-D_IKl1Hu.mjs +1 -0
  36. package/dist/ToolError-DWU_z7gp.mjs +1 -0
  37. package/dist/ToolProbe-xsfALmN3.mjs +1 -0
  38. package/dist/ToolRegistry-B0Zs-phN.mjs +1 -0
  39. package/dist/ToolRouter.policy-CFHoN_Lw.mjs +4 -0
  40. package/dist/TraceRecorder-Dd8jLXpi.mjs +272 -0
  41. package/dist/VersionDetector-DMoUWyNm.mjs +9 -0
  42. package/dist/Win32API-Bhi5xFBe.mjs +1 -0
  43. package/dist/Win32Debug-CQteFL4F.mjs +1 -0
  44. package/dist/WorkflowEngine-CxEp2WXH.mjs +1 -0
  45. package/dist/analysis-BuR-NgX8.mjs +5 -0
  46. package/dist/{antidebug-CqDTB_uk.mjs → antidebug-BOTZH6-0.mjs} +8 -259
  47. package/dist/artifactRetention-NBdncOEW.mjs +1 -0
  48. package/dist/artifacts-B5xQuEa_.mjs +1 -0
  49. package/dist/authorization-schema-B40obG1A.mjs +1 -0
  50. package/dist/betterSqlite3-CGaxz4AX.mjs +1 -0
  51. package/dist/binary-instrument-Cf9qqLlM.mjs +7 -0
  52. package/dist/bind-helpers-BlAOQrFQ.mjs +1 -0
  53. package/dist/boringssl-inspector-BST5vtKx.mjs +2 -0
  54. package/dist/browser-C4Le3xqA.mjs +11 -0
  55. package/dist/capabilities-DbYCv-HF.mjs +1 -0
  56. package/dist/chunk-C_pMuVsO.mjs +1 -0
  57. package/dist/collector-CKO8RPK8.mjs +1 -0
  58. package/dist/concurrency-CcK46d0h.mjs +1 -0
  59. package/dist/constants-Cp6hBrrx.mjs +1 -0
  60. package/dist/coordination-BbijHEHH.mjs +1 -0
  61. package/dist/debugger-CRJq_krh.mjs +1 -0
  62. package/dist/definitions-BGobEDQa.mjs +1 -0
  63. package/dist/definitions-BGwNSkVm.mjs +1 -0
  64. package/dist/definitions-BbxOUiP-.mjs +1 -0
  65. package/dist/definitions-CCP9gphV.mjs +1 -0
  66. package/dist/definitions-CIO9O-Sw.mjs +1 -0
  67. package/dist/definitions-CYFbewnd.mjs +1 -0
  68. package/dist/definitions-CdWEuIkI.mjs +1 -0
  69. package/dist/definitions-CoQFbggH.mjs +1 -0
  70. package/dist/definitions-CuJRsJ6N.mjs +1 -0
  71. package/dist/definitions-DI9YXsJk.mjs +1 -0
  72. package/dist/definitions-DJklW2sS.mjs +1 -0
  73. package/dist/definitions-DZ8uKusP.mjs +1 -0
  74. package/dist/definitions-Dds_zrWx.mjs +1 -0
  75. package/dist/definitions-Dgrg7f3D.mjs +1 -0
  76. package/dist/definitions-DtE0XLrT.mjs +1 -0
  77. package/dist/definitions-LaYTuwQd.mjs +26 -0
  78. package/dist/definitions-NoVp_9Pm.mjs +1 -0
  79. package/dist/definitions-OvGsfxdt.mjs +1 -0
  80. package/dist/definitions-jXPaVy4P.mjs +1 -0
  81. package/dist/encoding-DGcr6Aj_.mjs +2 -0
  82. package/dist/ensure-browser-core-Buls24LQ.mjs +1 -0
  83. package/dist/evidence-graph-bridge-B0yhGPcs.mjs +1 -0
  84. package/dist/factory-Cx_1LorX.mjs +1 -0
  85. package/dist/flat-target-session-CO5g78k3.mjs +1 -0
  86. package/dist/formatAddress-C7j2fDlM.mjs +1 -0
  87. package/dist/graphql-HLf3MS8H.mjs +62 -0
  88. package/dist/handlers-BLMa4X7l.mjs +54 -0
  89. package/dist/handlers-BP12ZsWc.mjs +4 -0
  90. package/dist/handlers-BZoPla6E.mjs +1 -0
  91. package/dist/handlers-BggKiVx9.mjs +2 -0
  92. package/dist/handlers-D3iev8g1.mjs +1 -0
  93. package/dist/handlers-D49r1-1P.mjs +1 -0
  94. package/dist/handlers-DCE45Ww8.mjs +2 -0
  95. package/dist/handlers-DW5AbYs5.mjs +5 -0
  96. package/dist/handlers-De5u62Ga2.mjs +1 -0
  97. package/dist/handlers-DmQzIc44.mjs +31 -0
  98. package/dist/handlers-DnJRGp7t.mjs +302 -0
  99. package/dist/handlers-Dv_runVv.mjs +2 -0
  100. package/dist/handlers-S9Ws0IGy.mjs +2 -0
  101. package/dist/{handlers-Bl8zkwz1.mjs → handlers-pVNpaw4A.mjs} +144 -841
  102. package/dist/handlers.impl-CD2_kOcC.mjs +1 -0
  103. package/dist/hooks-DDKppogd.mjs +600 -0
  104. package/dist/index.mjs +12 -5225
  105. package/dist/logger-sBC6IdRT.mjs +1 -0
  106. package/dist/maintenance-CutEO84j.mjs +1 -0
  107. package/dist/manifest-BFGxlDRh.mjs +123 -0
  108. package/dist/manifest-BPuE6oH2.mjs +1 -0
  109. package/dist/manifest-BXry5N09.mjs +1 -0
  110. package/dist/manifest-BeP_zJGb2.mjs +1 -0
  111. package/dist/manifest-C0g67k6U.mjs +1 -0
  112. package/dist/manifest-C1nZkTkO.mjs +1 -0
  113. package/dist/manifest-C7qV1z7F.mjs +1 -0
  114. package/dist/manifest-CDeUZGUZ.mjs +1 -0
  115. package/dist/manifest-CDiCtaQT.mjs +1 -0
  116. package/dist/manifest-CFn0359q2.mjs +1 -0
  117. package/dist/manifest-CGq4NpqH2.mjs +1 -0
  118. package/dist/manifest-CJMGt7Qy.mjs +1 -0
  119. package/dist/manifest-CRIJq4Hs.mjs +1 -0
  120. package/dist/manifest-C_hEIjSx.mjs +1 -0
  121. package/dist/manifest-CeQmtQOY.mjs +1 -0
  122. package/dist/manifest-Cq0j7GZt.mjs +1 -0
  123. package/dist/manifest-CtPmHAdn.mjs +1 -0
  124. package/dist/manifest-Cx2IVMUY.mjs +1 -0
  125. package/dist/manifest-D16xPXro.mjs +1 -0
  126. package/dist/manifest-D44TaRJU.mjs +1 -0
  127. package/dist/manifest-D610kxZr.mjs +2 -0
  128. package/dist/manifest-DC-SMF6b.mjs +1 -0
  129. package/dist/manifest-DD3rtxvV.mjs +1 -0
  130. package/dist/manifest-DKUorv5M.mjs +1 -0
  131. package/dist/manifest-DMJlcsTR.mjs +1 -0
  132. package/dist/manifest-DWUUWBz0.mjs +1 -0
  133. package/dist/manifest-De-6Wf2R.mjs +1 -0
  134. package/dist/manifest-Dgh0uDW-.mjs +1 -0
  135. package/dist/manifest-Dm0o3i2U.mjs +1 -0
  136. package/dist/manifest-DsVh7Y4U.mjs +1 -0
  137. package/dist/manifest-DtEFSRaq.mjs +1 -0
  138. package/dist/manifest-H-EpAyZQ.mjs +1 -0
  139. package/dist/manifest-ais9Afrw.mjs +1 -0
  140. package/dist/manifest-tmb54wmA.mjs +1 -0
  141. package/dist/manifest-yu2xiQqe.mjs +1 -0
  142. package/dist/manifest-zrbrpKCC.mjs +1 -0
  143. package/dist/matchesWildcardPattern-BGqLSmEs.mjs +1 -0
  144. package/dist/modules-p-PUNv9r.mjs +332 -0
  145. package/dist/mojo-ipc-VGlv3Qyp.mjs +9 -0
  146. package/dist/network-BjZ1Y-GB.mjs +7 -0
  147. package/dist/outputPaths-BonGThuc.mjs +2 -0
  148. package/dist/parse-args-Cuk7-xUt.mjs +1 -0
  149. package/dist/platform-C446Lf97.mjs +93 -0
  150. package/dist/playwright-cdp-fallback-BwVR-_T3.mjs +1 -0
  151. package/dist/process-C9f2A5zk.mjs +962 -0
  152. package/dist/proxy-CvRepxgV.mjs +1 -0
  153. package/dist/registry-DUHIPE-v.mjs +1 -0
  154. package/dist/response-C7rKQst4.mjs +1 -0
  155. package/dist/search-defaults-D2bY-rzH.mjs +1 -0
  156. package/dist/server/plugin-api.mjs +1 -293
  157. package/dist/shared-state-board-Cyg-xh_k.mjs +1 -0
  158. package/dist/sourcemap-D6Q1UuAp.mjs +1 -0
  159. package/dist/ssrf-policy-T96MR3r6.mjs +1 -0
  160. package/dist/streaming-CTX58tbb.mjs +1 -0
  161. package/dist/tool-builder-CI9914Tf.mjs +1 -0
  162. package/dist/transform-Cv9P2vVD.mjs +103 -0
  163. package/dist/types-CuyefmGT.mjs +1 -0
  164. package/dist/types-DtThH00r.mjs +1 -0
  165. package/dist/wasm-DaJa8J0V.mjs +174 -0
  166. package/dist/webcrack-CsLLJIs9.mjs +46 -0
  167. package/dist/workflow-CYIXtrWD.mjs +101 -0
  168. package/package.json +12 -7
  169. package/dist/AntiCheatDetector-BNk-EoBt.mjs +0 -244
  170. package/dist/CacheAdapters-CDe5WPSV.mjs +0 -80
  171. package/dist/CodeInjector-Cq8q01kp.mjs +0 -150
  172. package/dist/ConsoleMonitor-CPVQW1Y-.mjs +0 -2201
  173. package/dist/DarwinAPI-BNPxu0RH.mjs +0 -363
  174. package/dist/DetailedDataManager-BQQcxh64.mjs +0 -217
  175. package/dist/EventBus-DgPmwpeu.mjs +0 -141
  176. package/dist/EvidenceGraphBridge-SFesNera.mjs +0 -153
  177. package/dist/ExtensionManager-CWYgw0YW.mjs +0 -714
  178. package/dist/FingerprintManager-gzWtkKuf.mjs +0 -96
  179. package/dist/HardwareBreakpoint-B9gZCdFP.mjs +0 -239
  180. package/dist/HeapAnalyzer-BLDH0dCv.mjs +0 -284
  181. package/dist/InstrumentationSession-CvPC7Jwy.mjs +0 -244
  182. package/dist/MemoryController-CbVdCIJF.mjs +0 -167
  183. package/dist/MemoryScanSession-BsDZbLYm.mjs +0 -278
  184. package/dist/MemoryScanner-Bcpml6II.mjs +0 -425
  185. package/dist/NativeMemoryManager.impl-dZtA1ZGn.mjs +0 -482
  186. package/dist/NativeMemoryManager.utils-B-FjA2mJ.mjs +0 -165
  187. package/dist/PEAnalyzer-D1lzJ_VG.mjs +0 -385
  188. package/dist/PageController-Bqm2kZ_X.mjs +0 -417
  189. package/dist/PointerChainEngine-BOhyVsjx.mjs +0 -322
  190. package/dist/PrerequisiteError-Dl33Svkz.mjs +0 -20
  191. package/dist/ResponseBuilder-D3iFYx2N.mjs +0 -143
  192. package/dist/ReverseEvidenceGraph-Dlsk94LC.mjs +0 -269
  193. package/dist/ScriptManager-aHHq0X7U.mjs +0 -3000
  194. package/dist/Speedhack-CqdIFlQl.mjs +0 -156
  195. package/dist/StealthVerifier-Bo4T3bz8.mjs +0 -135
  196. package/dist/StructureAnalyzer-DhFaPvRO.mjs +0 -426
  197. package/dist/ToolCatalog-C0JGZoOm.mjs +0 -582
  198. package/dist/ToolError-jh9whhMd.mjs +0 -15
  199. package/dist/ToolProbe-oC7aPrkv.mjs +0 -45
  200. package/dist/ToolRegistry-BjaF4oNz.mjs +0 -131
  201. package/dist/ToolRouter.policy-BWV67ZK-.mjs +0 -304
  202. package/dist/TraceRecorder-DgxyVbdQ.mjs +0 -519
  203. package/dist/VersionDetector-CwVLVdDM.mjs +0 -104
  204. package/dist/Win32API-CePkipZY.mjs +0 -340
  205. package/dist/Win32Debug-BvKs-gxc.mjs +0 -274
  206. package/dist/WorkflowEngine-CuvkZtWu.mjs +0 -598
  207. package/dist/analysis-CL9uACt9.mjs +0 -463
  208. package/dist/artifactRetention-CFEprwPw.mjs +0 -591
  209. package/dist/artifacts-Bk2-_uPq.mjs +0 -59
  210. package/dist/betterSqlite3-0pqusHHH.mjs +0 -74
  211. package/dist/binary-instrument-CXfpx6fT.mjs +0 -979
  212. package/dist/bind-helpers-xFfRF-qm.mjs +0 -22
  213. package/dist/boringssl-inspector-BH2D3VKc.mjs +0 -180
  214. package/dist/browser-BpOr5PEx.mjs +0 -4082
  215. package/dist/chunk-CjcI7cDX.mjs +0 -15
  216. package/dist/concurrency-Bt0yv1kJ.mjs +0 -41
  217. package/dist/constants-B0OANIBL.mjs +0 -519
  218. package/dist/coordination-qUbyF8KU.mjs +0 -259
  219. package/dist/debugger-gnKxRSN0.mjs +0 -1271
  220. package/dist/definitions-6M-eejaT.mjs +0 -53
  221. package/dist/definitions-B18eyf0B.mjs +0 -18
  222. package/dist/definitions-B3QdlrHv.mjs +0 -34
  223. package/dist/definitions-B4rAvHNZ.mjs +0 -63
  224. package/dist/definitions-BB_4jnmy.mjs +0 -37
  225. package/dist/definitions-BMfYXoNC.mjs +0 -43
  226. package/dist/definitions-Beid2EB3.mjs +0 -27
  227. package/dist/definitions-C1UvM5Iy.mjs +0 -126
  228. package/dist/definitions-CXEI7QC72.mjs +0 -216
  229. package/dist/definitions-C_4r7Fo-2.mjs +0 -14
  230. package/dist/definitions-CkFDALoa.mjs +0 -26
  231. package/dist/definitions-Cke7zEb8.mjs +0 -94
  232. package/dist/definitions-ClJLzsJQ.mjs +0 -25
  233. package/dist/definitions-Cq-zroAU.mjs +0 -28
  234. package/dist/definitions-Cy3Sl6gV.mjs +0 -34
  235. package/dist/definitions-D3VsGcvz.mjs +0 -47
  236. package/dist/definitions-DVGfrn7y.mjs +0 -96
  237. package/dist/definitions-LKpC3-nL.mjs +0 -9
  238. package/dist/definitions-bAhHQJq9.mjs +0 -359
  239. package/dist/encoding-Bvz5jLRv.mjs +0 -1065
  240. package/dist/evidence-graph-bridge-C_fv9PuC.mjs +0 -135
  241. package/dist/factory-DxlGh9Xf.mjs +0 -575
  242. package/dist/formatAddress-DVkj9kpI.mjs +0 -17
  243. package/dist/graphql-DYWzJ29s.mjs +0 -1026
  244. package/dist/handlers-9sAbfIg-.mjs +0 -2552
  245. package/dist/handlers-C67ktuRN.mjs +0 -710
  246. package/dist/handlers-C87g8oCe.mjs +0 -276
  247. package/dist/handlers-CTsDAO6p.mjs +0 -681
  248. package/dist/handlers-Cgyg6c0U.mjs +0 -645
  249. package/dist/handlers-D6j6yka7.mjs +0 -2124
  250. package/dist/handlers-DdFzXLvF.mjs +0 -446
  251. package/dist/handlers-DeLOCd5m.mjs +0 -799
  252. package/dist/handlers-DlCJN4Td.mjs +0 -757
  253. package/dist/handlers-DxGIq15_2.mjs +0 -917
  254. package/dist/handlers-U6L4xhuF.mjs +0 -585
  255. package/dist/handlers-tB9Mp9ZK.mjs +0 -84
  256. package/dist/handlers-tiy7EIBp.mjs +0 -572
  257. package/dist/handlers.impl-DS0d9fUw.mjs +0 -761
  258. package/dist/hooks-CzCWByww.mjs +0 -898
  259. package/dist/logger-Dh_xb7_2.mjs +0 -93
  260. package/dist/maintenance-P7ePRXQC.mjs +0 -830
  261. package/dist/manifest-2ToTpjv8.mjs +0 -106
  262. package/dist/manifest-3g71z6Bg.mjs +0 -79
  263. package/dist/manifest-82baTv4U.mjs +0 -45
  264. package/dist/manifest-B3QVVeBS.mjs +0 -82
  265. package/dist/manifest-BB2J8IMJ.mjs +0 -149
  266. package/dist/manifest-BKbgbSiY.mjs +0 -60
  267. package/dist/manifest-Bcf-TJzH.mjs +0 -848
  268. package/dist/manifest-BmtZzQiQ2.mjs +0 -45
  269. package/dist/manifest-Bnd7kqEY.mjs +0 -55
  270. package/dist/manifest-BqQX6OQC2.mjs +0 -65
  271. package/dist/manifest-BqrQ4Tpj.mjs +0 -81
  272. package/dist/manifest-Br4RPFt5.mjs +0 -370
  273. package/dist/manifest-C5qDjysN.mjs +0 -107
  274. package/dist/manifest-C9RT5nk32.mjs +0 -34
  275. package/dist/manifest-CAhOuvSl.mjs +0 -204
  276. package/dist/manifest-CBYWCUBJ.mjs +0 -51
  277. package/dist/manifest-CFADCRa1.mjs +0 -37
  278. package/dist/manifest-CQVhavRF.mjs +0 -114
  279. package/dist/manifest-CT7zZBV1.mjs +0 -48
  280. package/dist/manifest-CV12bcrF.mjs +0 -121
  281. package/dist/manifest-CXsRWjjI.mjs +0 -224
  282. package/dist/manifest-CZLUCfG02.mjs +0 -95
  283. package/dist/manifest-D6phHKFd.mjs +0 -131
  284. package/dist/manifest-DCyjf4n2.mjs +0 -294
  285. package/dist/manifest-DHsnKgP6.mjs +0 -60
  286. package/dist/manifest-Df_dliIe.mjs +0 -55
  287. package/dist/manifest-Dh8WBmEW.mjs +0 -129
  288. package/dist/manifest-DhKRAT8_.mjs +0 -92
  289. package/dist/manifest-DlpTj4ic2.mjs +0 -193
  290. package/dist/manifest-DrbmZcFl2.mjs +0 -253
  291. package/dist/manifest-DuwHjUa5.mjs +0 -70
  292. package/dist/manifest-DzwvxPJX.mjs +0 -38
  293. package/dist/manifest-NXctwWQq.mjs +0 -68
  294. package/dist/manifest-Sc_0JQ13.mjs +0 -418
  295. package/dist/manifest-gZ4s_UtG.mjs +0 -96
  296. package/dist/manifest-qSleDqdO.mjs +0 -1023
  297. package/dist/modules-C184v-S9.mjs +0 -11365
  298. package/dist/mojo-ipc-B_H61Afw.mjs +0 -525
  299. package/dist/network-671Cw6hV.mjs +0 -3346
  300. package/dist/outputPaths-B1uGmrWZ.mjs +0 -1145
  301. package/dist/parse-args-BlRjqlkL.mjs +0 -39
  302. package/dist/platform-WmNn8Sxb.mjs +0 -2070
  303. package/dist/process-QcbIy5Zq.mjs +0 -1401
  304. package/dist/proxy-DqNs0bAd.mjs +0 -170
  305. package/dist/registry-D-6e18lB.mjs +0 -34
  306. package/dist/response-BQVP-xUn.mjs +0 -28
  307. package/dist/shared-state-board-DV-dpHFJ.mjs +0 -586
  308. package/dist/sourcemap-Dq8ez8vS.mjs +0 -650
  309. package/dist/ssrf-policy-ZaUfvhq7.mjs +0 -166
  310. package/dist/streaming-BUQ0VJsg.mjs +0 -725
  311. package/dist/tool-builder-DCbIC5Eo.mjs +0 -186
  312. package/dist/transform-CiYJfNX0.mjs +0 -1007
  313. package/dist/types-Bx92KJfT.mjs +0 -4
  314. package/dist/types-CPhOReNX.mjs +0 -37
  315. package/dist/wasm-DQTnHDs4.mjs +0 -531
  316. package/dist/workflow-f3xJOcjx.mjs +0 -725
@@ -1,156 +0,0 @@
1
- import { _ as WriteProcessMemory, b as openProcessForMemory, c as GetProcAddress, d as ReadProcessMemory, f as VirtualAllocEx, l as MEM, m as VirtualProtectEx, o as GetModuleHandle, p as VirtualFreeEx, t as CloseHandle, u as PAGE } from "./Win32API-CePkipZY.mjs";
2
- import { l as FlushInstructionCache } from "./Win32Debug-BvKs-gxc.mjs";
3
- //#region src/native/Speedhack.ts
4
- var Speedhack = class {
5
- states = /* @__PURE__ */ new Map();
6
- /** Apply speedhack to process with multiplier (1.0 = normal) */
7
- async apply(pid, speed) {
8
- if (this.states.has(pid)) await this.remove(pid);
9
- const handle = openProcessForMemory(pid, true);
10
- const hookedApis = [];
11
- const patchIds = [];
12
- try {
13
- const kernel32Base = GetModuleHandle("kernel32.dll");
14
- if (kernel32Base === 0n) throw new Error("Cannot find kernel32.dll");
15
- const sharedMem = VirtualAllocEx(handle, 0n, 4096, MEM.COMMIT | MEM.RESERVE, PAGE.EXECUTE_READWRITE);
16
- if (sharedMem === 0n) throw new Error("VirtualAllocEx failed for speedhack shared memory");
17
- const speedBuf = Buffer.alloc(8);
18
- speedBuf.writeDoubleLE(speed, 0);
19
- WriteProcessMemory(handle, sharedMem, speedBuf);
20
- const zeroBuf = Buffer.alloc(8, 0);
21
- WriteProcessMemory(handle, sharedMem + 8n, zeroBuf);
22
- WriteProcessMemory(handle, sharedMem + 16n, zeroBuf);
23
- const gettickAddr = GetProcAddress(kernel32Base, "GetTickCount64");
24
- if (gettickAddr !== 0n) {
25
- if (await this.hookTimeFunction(handle, gettickAddr, sharedMem, 256n, "gettick64")) {
26
- hookedApis.push("GetTickCount64");
27
- patchIds.push("gettick64");
28
- }
29
- }
30
- const qpcAddr = GetProcAddress(kernel32Base, "QueryPerformanceCounter");
31
- if (qpcAddr !== 0n) {
32
- if (await this.hookTimeFunction(handle, qpcAddr, sharedMem, 512n, "qpc")) {
33
- hookedApis.push("QueryPerformanceCounter");
34
- patchIds.push("qpc");
35
- }
36
- }
37
- this.states.set(pid, {
38
- pid,
39
- speed,
40
- hookedApis,
41
- isActive: true,
42
- allocatedMemory: `0x${sharedMem.toString(16).toUpperCase()}`,
43
- patchIds
44
- });
45
- return {
46
- success: hookedApis.length > 0,
47
- hookedApis
48
- };
49
- } catch (error) {
50
- CloseHandle(handle);
51
- throw error;
52
- } finally {
53
- CloseHandle(handle);
54
- }
55
- }
56
- /** Update speed multiplier (without re-hooking) */
57
- async setSpeed(pid, speed) {
58
- const state = this.states.get(pid);
59
- if (!state || !state.isActive || !state.allocatedMemory) return false;
60
- const addr = BigInt(state.allocatedMemory);
61
- const handle = openProcessForMemory(pid, true);
62
- try {
63
- const buf = Buffer.alloc(8);
64
- buf.writeDoubleLE(speed, 0);
65
- WriteProcessMemory(handle, addr, buf);
66
- state.speed = speed;
67
- return true;
68
- } finally {
69
- CloseHandle(handle);
70
- }
71
- }
72
- /** Get current speed multiplier */
73
- getSpeed(pid) {
74
- const state = this.states.get(pid);
75
- return state?.isActive ? state.speed : null;
76
- }
77
- /** Remove speedhack, restore original functions */
78
- async remove(pid) {
79
- const state = this.states.get(pid);
80
- if (!state) return false;
81
- const handle = openProcessForMemory(pid, true);
82
- try {
83
- if (state.allocatedMemory) {
84
- const allocAddr = BigInt(state.allocatedMemory);
85
- for (let i = 0; i < state.patchIds.length; i++) try {
86
- const metaBuf = ReadProcessMemory(handle, allocAddr + (3072n + BigInt(i * 32)), 32);
87
- const origAddr = metaBuf.readBigUInt64LE(0);
88
- const origSize = metaBuf.readUInt32LE(8);
89
- if (origAddr !== 0n && origSize > 0 && origSize <= 16) {
90
- const origBytes = metaBuf.subarray(12, 12 + origSize);
91
- const { oldProtect } = VirtualProtectEx(handle, origAddr, origSize, PAGE.EXECUTE_READWRITE);
92
- WriteProcessMemory(handle, origAddr, origBytes);
93
- FlushInstructionCache(handle, origAddr, origSize);
94
- VirtualProtectEx(handle, origAddr, origSize, oldProtect);
95
- }
96
- } catch {}
97
- VirtualFreeEx(handle, allocAddr, 0, MEM.RELEASE);
98
- }
99
- } finally {
100
- CloseHandle(handle);
101
- }
102
- state.isActive = false;
103
- this.states.delete(pid);
104
- return true;
105
- }
106
- /** Check if speedhack is active for a process */
107
- isActive(pid) {
108
- return this.states.get(pid)?.isActive ?? false;
109
- }
110
- /** List all active speedhacks */
111
- listActive() {
112
- return Array.from(this.states.values()).filter((s) => s.isActive);
113
- }
114
- /**
115
- * Hook a time function with a JMP trampoline.
116
- * Saves original bytes in shared memory for restoration.
117
- */
118
- async hookTimeFunction(handle, funcAddr, sharedMem, trampolineOffset, _hookId) {
119
- try {
120
- const origBytes = ReadProcessMemory(handle, funcAddr, 14);
121
- const trampolineAddr = sharedMem + trampolineOffset;
122
- WriteProcessMemory(handle, trampolineAddr, origBytes);
123
- const jumpBackAddr = funcAddr + 14n;
124
- const jumpBack = this.buildAbsoluteJump(jumpBackAddr);
125
- WriteProcessMemory(handle, trampolineAddr + 14n, Buffer.from(jumpBack));
126
- const jumpToTrampoline = this.buildAbsoluteJump(trampolineAddr);
127
- const { oldProtect } = VirtualProtectEx(handle, funcAddr, 14, PAGE.EXECUTE_READWRITE);
128
- WriteProcessMemory(handle, funcAddr, Buffer.from(jumpToTrampoline));
129
- FlushInstructionCache(handle, funcAddr, 14);
130
- VirtualProtectEx(handle, funcAddr, 14, oldProtect);
131
- const patchIndex = this.states.size;
132
- const metaOffset = 3072n + BigInt(patchIndex * 32);
133
- const metaBuf = Buffer.alloc(32);
134
- metaBuf.writeBigUInt64LE(funcAddr, 0);
135
- metaBuf.writeUInt32LE(14, 8);
136
- origBytes.copy(metaBuf, 12);
137
- WriteProcessMemory(handle, sharedMem + metaOffset, metaBuf);
138
- FlushInstructionCache(handle, trampolineAddr, 32);
139
- return true;
140
- } catch {
141
- return false;
142
- }
143
- }
144
- /** Build a 14-byte absolute JMP for x64: FF 25 00 00 00 00 [8-byte addr] */
145
- buildAbsoluteJump(target) {
146
- const buf = Buffer.alloc(14);
147
- buf[0] = 255;
148
- buf[1] = 37;
149
- buf.writeUInt32LE(0, 2);
150
- buf.writeBigUInt64LE(target, 6);
151
- return Array.from(buf);
152
- }
153
- };
154
- const speedhack = new Speedhack();
155
- //#endregion
156
- export { Speedhack, speedhack };
@@ -1,135 +0,0 @@
1
- import "rebrowser-puppeteer-core";
2
- //#region src/modules/stealth/StealthVerifier.ts
3
- var StealthVerifier = class {
4
- /**
5
- * Run all anti-detection checks on the given page.
6
- * Should be called AFTER stealth_inject for meaningful results.
7
- */
8
- async verify(page) {
9
- const checks = await page.evaluate(() => {
10
- const results = [];
11
- const wd = navigator.webdriver;
12
- results.push({
13
- name: "navigator.webdriver",
14
- passed: wd === void 0 || wd === false,
15
- expected: "undefined",
16
- actual: String(wd)
17
- });
18
- const win = window;
19
- const hasChrome = typeof win.chrome === "object" && win.chrome !== null;
20
- results.push({
21
- name: "window.chrome",
22
- passed: hasChrome,
23
- expected: "object",
24
- actual: typeof win.chrome
25
- });
26
- const chromeApp = hasChrome ? win.chrome.app : null;
27
- const hasAppIsInstalled = chromeApp && typeof chromeApp === "object" && "isInstalled" in chromeApp;
28
- results.push({
29
- name: "chrome.app.isInstalled",
30
- passed: Boolean(hasAppIsInstalled),
31
- expected: "exists (false)",
32
- actual: hasAppIsInstalled ? String(chromeApp.isInstalled) : "missing"
33
- });
34
- const pluginCount = navigator.plugins?.length ?? 0;
35
- results.push({
36
- name: "navigator.plugins",
37
- passed: pluginCount >= 3,
38
- expected: ">= 3",
39
- actual: String(pluginCount)
40
- });
41
- const langs = navigator.languages;
42
- results.push({
43
- name: "navigator.languages",
44
- passed: langs.length > 0,
45
- expected: "non-empty",
46
- actual: JSON.stringify(langs)
47
- });
48
- const ua = navigator.userAgent;
49
- const platform = navigator.platform;
50
- let platformConsistent = true;
51
- if (ua.includes("Windows") && !platform.includes("Win")) platformConsistent = false;
52
- if (ua.includes("Macintosh") && !platform.includes("Mac")) platformConsistent = false;
53
- if (ua.includes("Linux") && !platform.includes("Linux")) platformConsistent = false;
54
- results.push({
55
- name: "platform/UA consistency",
56
- passed: platformConsistent,
57
- expected: "consistent",
58
- actual: `UA=${ua.substring(0, 50)}... platform=${platform}`
59
- });
60
- let webglVendor = "unavailable";
61
- try {
62
- const gl = document.createElement("canvas").getContext("webgl");
63
- if (gl) {
64
- const debugInfo = gl.getExtension("WEBGL_debug_renderer_info");
65
- if (debugInfo) webglVendor = gl.getParameter(debugInfo.UNMASKED_VENDOR_WEBGL) || "empty";
66
- }
67
- } catch {
68
- webglVendor = "error";
69
- }
70
- results.push({
71
- name: "WebGL vendor",
72
- passed: webglVendor !== "empty" && webglVendor !== "error",
73
- expected: "non-empty vendor string",
74
- actual: webglVendor
75
- });
76
- const cdcKeys = Object.keys(document).filter((k) => k.startsWith("cdc_") || k.startsWith("$cdc_"));
77
- results.push({
78
- name: "cdc_ variables",
79
- passed: cdcKeys.length === 0,
80
- expected: "none",
81
- actual: cdcKeys.length === 0 ? "none" : cdcKeys.join(", ")
82
- });
83
- const hwc = navigator.hardwareConcurrency ?? 0;
84
- results.push({
85
- name: "hardwareConcurrency",
86
- passed: hwc >= 4,
87
- expected: ">= 4",
88
- actual: String(hwc)
89
- });
90
- const dm = navigator.deviceMemory;
91
- results.push({
92
- name: "deviceMemory",
93
- passed: dm !== void 0 && dm >= 4,
94
- expected: ">= 4",
95
- actual: String(dm ?? "undefined")
96
- });
97
- return results;
98
- });
99
- const passedCount = checks.filter((c) => c.passed).length;
100
- const totalCount = checks.length;
101
- const score = Math.round(passedCount / totalCount * 100);
102
- const recommendations = [];
103
- for (const check of checks) if (!check.passed) switch (check.name) {
104
- case "navigator.webdriver":
105
- recommendations.push("Run stealth_inject to hide navigator.webdriver");
106
- break;
107
- case "window.chrome":
108
- recommendations.push("Run stealth_inject to inject window.chrome object");
109
- break;
110
- case "chrome.app.isInstalled":
111
- recommendations.push("Update stealth scripts to include chrome.app structure");
112
- break;
113
- case "navigator.plugins":
114
- recommendations.push("Run stealth_inject to restore navigator.plugins");
115
- break;
116
- case "platform/UA consistency":
117
- recommendations.push("Run stealth_set_user_agent with matching platform before stealth_inject");
118
- break;
119
- case "cdc_ variables":
120
- recommendations.push("Run stealth_inject to clean up ChromeDriver cdc_ variables");
121
- break;
122
- default: recommendations.push(`Fix: ${check.name} — expected ${check.expected}, got ${check.actual}`);
123
- }
124
- return {
125
- passed: passedCount === totalCount,
126
- checks,
127
- score,
128
- passedCount,
129
- totalCount,
130
- recommendations
131
- };
132
- }
133
- };
134
- //#endregion
135
- export { StealthVerifier };