@jshookmcp/jshook 0.3.0 → 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 (321) 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-CTbB4Lcx.mjs → HookGeneratorBuilders.core.generators.storage-Bf1fbrNK.mjs} +66 -101
  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-BRKeyt27.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-Dz9PYsCa.mjs → handlers-pVNpaw4A.mjs} +118 -904
  102. package/dist/handlers.impl-CD2_kOcC.mjs +1 -0
  103. package/dist/hooks-DDKppogd.mjs +600 -0
  104. package/dist/index.mjs +12 -5235
  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 +50 -78
  169. package/dist/AntiCheatDetector-CqGDXmfc.mjs +0 -350
  170. package/dist/CacheAdapters-jJFy20G-.mjs +0 -80
  171. package/dist/CodeInjector-BdjRfNx7.mjs +0 -150
  172. package/dist/ConsoleMonitor-DykL3IAw.mjs +0 -2269
  173. package/dist/DarwinAPI-ETyy0xyo.mjs +0 -363
  174. package/dist/DetailedDataManager-HT49OrvF.mjs +0 -217
  175. package/dist/EventBus-DFKvADm3.mjs +0 -141
  176. package/dist/EvidenceGraphBridge-318Oi0Lf.mjs +0 -153
  177. package/dist/ExtensionManager-BDMsY2Dz.mjs +0 -721
  178. package/dist/FingerprintManager-BN4UQWnX.mjs +0 -96
  179. package/dist/HardwareBreakpoint-Cc2AFq1Y.mjs +0 -239
  180. package/dist/HeapAnalyzer-DruMgsgj.mjs +0 -284
  181. package/dist/InstrumentationSession-DLH0vd-z.mjs +0 -244
  182. package/dist/MemoryController-CMtviNW_.mjs +0 -167
  183. package/dist/MemoryScanSession-ITgb_NMi.mjs +0 -278
  184. package/dist/MemoryScanner-CiL7Z3ey.mjs +0 -428
  185. package/dist/NativeMemoryManager.impl-D9Lkovvn.mjs +0 -485
  186. package/dist/NativeMemoryManager.utils-BBlAixF5.mjs +0 -165
  187. package/dist/PEAnalyzer-DMQ44gen.mjs +0 -385
  188. package/dist/PageController-BPJNqqBN.mjs +0 -431
  189. package/dist/PointerChainEngine-K7wN8Z-w.mjs +0 -325
  190. package/dist/PrerequisiteError-TuyZIs6n.mjs +0 -20
  191. package/dist/ProcessRegistry-zGg12QbE.mjs +0 -74
  192. package/dist/ResponseBuilder-CJXWmWNw.mjs +0 -143
  193. package/dist/ReverseEvidenceGraph-C02-gXOh.mjs +0 -269
  194. package/dist/ScriptManager-ZuWD-0Jg.mjs +0 -3003
  195. package/dist/Speedhack-D-z0umeT.mjs +0 -156
  196. package/dist/StealthVerifier-BWmPgQsv.mjs +0 -135
  197. package/dist/StructureAnalyzer-Cav5AVSL.mjs +0 -429
  198. package/dist/ToolCatalog-5OJdMiF0.mjs +0 -582
  199. package/dist/ToolError-jh9whhMd.mjs +0 -15
  200. package/dist/ToolProbe-DbCFGyrg.mjs +0 -45
  201. package/dist/ToolRegistry-B9krbTtI.mjs +0 -180
  202. package/dist/ToolRouter.policy-BGDAGyeH.mjs +0 -344
  203. package/dist/TraceRecorder-B41Z5XBj.mjs +0 -1286
  204. package/dist/VersionDetector-K3V4vGsw.mjs +0 -104
  205. package/dist/Win32API-C2kjj0ze.mjs +0 -346
  206. package/dist/Win32Debug-CKrGOTpo.mjs +0 -274
  207. package/dist/WorkflowEngine-DJ6M4opp.mjs +0 -569
  208. package/dist/analysis-BHeJW2Nb.mjs +0 -1234
  209. package/dist/artifactRetention-CPXkUJXp.mjs +0 -598
  210. package/dist/artifacts-DkfosXH3.mjs +0 -59
  211. package/dist/authorization-schema-DRqyJMSk.mjs +0 -31
  212. package/dist/betterSqlite3-DLSBZodi.mjs +0 -74
  213. package/dist/binary-instrument--V3MAhJ4.mjs +0 -971
  214. package/dist/bind-helpers-ClV34xdn.mjs +0 -42
  215. package/dist/boringssl-inspector-Bo_LOLaS.mjs +0 -180
  216. package/dist/browser-Dx3_S2cG.mjs +0 -4369
  217. package/dist/capabilities-CcHlvWgK.mjs +0 -33
  218. package/dist/chunk-CjcI7cDX.mjs +0 -15
  219. package/dist/concurrency-Drev_Vz9.mjs +0 -41
  220. package/dist/constants-CDZLOoVv.mjs +0 -534
  221. package/dist/coordination-DgItD9DL.mjs +0 -259
  222. package/dist/debugger-RS3RSAqs.mjs +0 -1288
  223. package/dist/definitions-BEoYofW5.mjs +0 -47
  224. package/dist/definitions-BRaefg3u.mjs +0 -365
  225. package/dist/definitions-BbkvZkiv.mjs +0 -96
  226. package/dist/definitions-BtWSHJ3o.mjs +0 -17
  227. package/dist/definitions-C1gCHO0i.mjs +0 -43
  228. package/dist/definitions-CDOg_b-l.mjs +0 -138
  229. package/dist/definitions-CVPD9hzZ.mjs +0 -54
  230. package/dist/definitions-Cea8Lgl7.mjs +0 -94
  231. package/dist/definitions-DAgIyjxM.mjs +0 -10
  232. package/dist/definitions-DJA27nsL.mjs +0 -66
  233. package/dist/definitions-DKPFU3LW.mjs +0 -25
  234. package/dist/definitions-DPRpZQ96.mjs +0 -47
  235. package/dist/definitions-DUE5gmdn.mjs +0 -18
  236. package/dist/definitions-DYVjOtxa.mjs +0 -26
  237. package/dist/definitions-DcYLVLCo.mjs +0 -37
  238. package/dist/definitions-Pp5LI2H4.mjs +0 -27
  239. package/dist/definitions-j9KdHVNR.mjs +0 -14
  240. package/dist/definitions-uzkjBwa7.mjs +0 -258
  241. package/dist/definitions-va-AnLuQ.mjs +0 -28
  242. package/dist/encoding-DJeqHmpd.mjs +0 -1079
  243. package/dist/evidence-graph-bridge-DcYizFk2.mjs +0 -136
  244. package/dist/factory-C90tBff6.mjs +0 -575
  245. package/dist/flat-target-session-Dgax2Cy3.mjs +0 -29
  246. package/dist/formatAddress-nnMvEohD.mjs +0 -17
  247. package/dist/graphql-CoHrhweh.mjs +0 -1197
  248. package/dist/handlers-4jmR0nMs.mjs +0 -898
  249. package/dist/handlers-BAHPxcch.mjs +0 -789
  250. package/dist/handlers-BOs9b907.mjs +0 -2600
  251. package/dist/handlers-BWXEy6ef.mjs +0 -917
  252. package/dist/handlers-Bndn6QvE.mjs +0 -111
  253. package/dist/handlers-BqC4bD4s.mjs +0 -681
  254. package/dist/handlers-BtYq60bM2.mjs +0 -276
  255. package/dist/handlers-BzgcB4iv.mjs +0 -799
  256. package/dist/handlers-CRyRWj2b.mjs +0 -859
  257. package/dist/handlers-CVv2H1uq.mjs +0 -592
  258. package/dist/handlers-Dl5a7JS4.mjs +0 -572
  259. package/dist/handlers-Dx2d7jt7.mjs +0 -2537
  260. package/dist/handlers-HujRKC3b.mjs +0 -661
  261. package/dist/handlers.impl-XWXkQfyi.mjs +0 -807
  262. package/dist/hooks-B1B8NRHL.mjs +0 -898
  263. package/dist/logger-Dh_xb7_2.mjs +0 -93
  264. package/dist/maintenance-PRMkLVRW.mjs +0 -835
  265. package/dist/manifest-67Bok-Si.mjs +0 -58
  266. package/dist/manifest-6lNTMZAB2.mjs +0 -87
  267. package/dist/manifest-B2duEHiH.mjs +0 -90
  268. package/dist/manifest-B6EY9Vm8.mjs +0 -57
  269. package/dist/manifest-B6nKSbyY.mjs +0 -95
  270. package/dist/manifest-BL8AQNPF.mjs +0 -106
  271. package/dist/manifest-BSZvJJmV.mjs +0 -47
  272. package/dist/manifest-BU7qzUyX.mjs +0 -418
  273. package/dist/manifest-Bl62e8WK.mjs +0 -49
  274. package/dist/manifest-Bo5cXjdt.mjs +0 -82
  275. package/dist/manifest-BpS4gtUK.mjs +0 -1347
  276. package/dist/manifest-Bv65_e2W.mjs +0 -101
  277. package/dist/manifest-BytNIF4Z.mjs +0 -117
  278. package/dist/manifest-C-xtsjS3.mjs +0 -81
  279. package/dist/manifest-CDYl7OhA.mjs +0 -66
  280. package/dist/manifest-CRZ3xmkD.mjs +0 -61
  281. package/dist/manifest-CoW6u4Tp.mjs +0 -132
  282. package/dist/manifest-Cq5zN_8A.mjs +0 -50
  283. package/dist/manifest-D7YZM_2e.mjs +0 -194
  284. package/dist/manifest-DE_VrAeQ.mjs +0 -314
  285. package/dist/manifest-DGsXSCpT.mjs +0 -39
  286. package/dist/manifest-DJ2vfEuW.mjs +0 -156
  287. package/dist/manifest-DPXDYhEu.mjs +0 -80
  288. package/dist/manifest-Dd4fQb0a.mjs +0 -322
  289. package/dist/manifest-Deq6opGg.mjs +0 -223
  290. package/dist/manifest-DfJTafJK.mjs +0 -37
  291. package/dist/manifest-DgOdgN_j.mjs +0 -50
  292. package/dist/manifest-DlbMW4v4.mjs +0 -47
  293. package/dist/manifest-DmVfbH0w.mjs +0 -374
  294. package/dist/manifest-Dog6Ddjr.mjs +0 -109
  295. package/dist/manifest-DvgU5FWb.mjs +0 -58
  296. package/dist/manifest-HsfDBs7j.mjs +0 -50
  297. package/dist/manifest-I8oQHvCG.mjs +0 -186
  298. package/dist/manifest-NvH_a-av.mjs +0 -786
  299. package/dist/manifest-cEJU1v0Z.mjs +0 -129
  300. package/dist/manifest-wOl5XLB12.mjs +0 -112
  301. package/dist/modules-tZozf0LQ.mjs +0 -10635
  302. package/dist/mojo-ipc-DXNEXEqb.mjs +0 -640
  303. package/dist/network-CPVvwvFg.mjs +0 -3852
  304. package/dist/outputPaths-um7lCRY3.mjs +0 -1141
  305. package/dist/parse-args-B4cY5Vx5.mjs +0 -39
  306. package/dist/platform-CYeFoTWp.mjs +0 -2161
  307. package/dist/process-BTbgcVc6.mjs +0 -1306
  308. package/dist/proxy-r8YN6nP1.mjs +0 -192
  309. package/dist/registry-Bl8ZQW61.mjs +0 -34
  310. package/dist/response-CWhh2aLo.mjs +0 -34
  311. package/dist/shared-state-board-BoZnSoj-.mjs +0 -586
  312. package/dist/sourcemap-BIDHUVXy.mjs +0 -934
  313. package/dist/ssrf-policy-Dsqd-DTX.mjs +0 -166
  314. package/dist/streaming-Dal6utPp.mjs +0 -725
  315. package/dist/tool-builder-BHJp32mV.mjs +0 -186
  316. package/dist/transform-DRVgGG90.mjs +0 -1011
  317. package/dist/types-Bx92KJfT.mjs +0 -4
  318. package/dist/types-DDBWs9UP.mjs +0 -37
  319. package/dist/wasm-BYx5UOeG.mjs +0 -1044
  320. package/dist/webcrack-Be0_FccV.mjs +0 -747
  321. package/dist/workflow-BpuKEtvn.mjs +0 -725
@@ -1,429 +0,0 @@
1
- import { dr as STRUCT_VTABLE_MAX_FUNCTIONS, lr as STRUCT_ANALYZE_DEFAULT_SIZE, ur as STRUCT_RTTI_MAX_STRING_LEN } from "./constants-CDZLOoVv.mjs";
2
- import { t as createPlatformProvider } from "./factory-C90tBff6.mjs";
3
- import { t as nativeMemoryManager } from "./NativeMemoryManager.impl-D9Lkovvn.mjs";
4
- //#region src/native/StructureAnalyzer.ts
5
- /**
6
- * Structure Analyzer — heuristic memory structure inference.
7
- *
8
- * Analyzes memory at a given address to infer field types, detect vtables,
9
- * parse RTTI, and export C-style struct definitions.
10
- *
11
- * Uses PlatformMemoryAPI for cross-platform memory operations.
12
- *
13
- * @module StructureAnalyzer
14
- */
15
- var StructureAnalyzer = class {
16
- providerCache = null;
17
- get provider() {
18
- if (!this.providerCache) this.providerCache = createPlatformProvider();
19
- return this.providerCache;
20
- }
21
- set provider(value) {
22
- this.providerCache = value;
23
- }
24
- /**
25
- * Infer the structure layout at a given address.
26
- */
27
- async analyzeStructure(pid, address, options) {
28
- const size = options?.size ?? STRUCT_ANALYZE_DEFAULT_SIZE;
29
- const baseAddr = BigInt(address.startsWith("0x") ? address : `0x${address}`);
30
- const handle = this.provider.openProcess(pid, false);
31
- try {
32
- const buf = this.provider.readMemory(handle, baseAddr, size).data;
33
- const fields = [];
34
- let offset = 0;
35
- while (offset < size) {
36
- const remaining = size - offset;
37
- if (remaining < 1) break;
38
- const classification = this.classifyValue(buf, handle, baseAddr, offset, remaining);
39
- fields.push({
40
- offset,
41
- size: classification.size,
42
- type: classification.type,
43
- name: `field_0x${offset.toString(16).padStart(2, "0").toUpperCase()}`,
44
- value: classification.value,
45
- confidence: classification.confidence,
46
- notes: classification.notes
47
- });
48
- offset += classification.size;
49
- }
50
- let vtableAddress;
51
- let className;
52
- let baseClasses;
53
- if (fields.length > 0 && fields[0].type === "vtable_ptr") {
54
- vtableAddress = fields[0].value;
55
- if (options?.parseRtti !== false && vtableAddress) try {
56
- const rtti = await this.parseRtti(pid, vtableAddress, handle);
57
- if (rtti) {
58
- className = rtti.className;
59
- baseClasses = rtti.baseClasses;
60
- }
61
- } catch {}
62
- }
63
- return {
64
- baseAddress: `0x${baseAddr.toString(16).toUpperCase()}`,
65
- totalSize: size,
66
- fields,
67
- vtableAddress,
68
- className,
69
- baseClasses,
70
- timestamp: Date.now()
71
- };
72
- } finally {
73
- this.provider.closeProcess(handle);
74
- }
75
- }
76
- /**
77
- * Parse vtable at given address.
78
- * A vtable is an array of function pointers in executable memory.
79
- */
80
- async parseVtable(pid, vtableAddress) {
81
- const vtableAddr = BigInt(vtableAddress.startsWith("0x") ? vtableAddress : `0x${vtableAddress}`);
82
- const handle = this.provider.openProcess(pid, false);
83
- try {
84
- const functions = [];
85
- const modules = await this.getModuleEntries(pid);
86
- for (let i = 0; i < STRUCT_VTABLE_MAX_FUNCTIONS; i++) {
87
- const ptrAddr = vtableAddr + BigInt(i * 8);
88
- let funcPtr;
89
- try {
90
- funcPtr = this.provider.readMemory(handle, ptrAddr, 8).data.readBigUInt64LE(0);
91
- } catch {
92
- break;
93
- }
94
- if (!this.isValidExecutablePointer(handle, funcPtr)) break;
95
- const modInfo = this.resolveToModule(funcPtr, modules);
96
- functions.push({
97
- index: i,
98
- address: `0x${funcPtr.toString(16).toUpperCase()}`,
99
- module: modInfo?.module,
100
- moduleOffset: modInfo?.offset
101
- });
102
- }
103
- let rttiName;
104
- let baseClassList;
105
- try {
106
- const rtti = await this.parseRtti(pid, vtableAddress, handle);
107
- if (rtti) {
108
- rttiName = rtti.className;
109
- baseClassList = rtti.baseClasses;
110
- }
111
- } catch {}
112
- return {
113
- address: `0x${vtableAddr.toString(16).toUpperCase()}`,
114
- functionCount: functions.length,
115
- functions,
116
- rttiName,
117
- baseClasses: baseClassList
118
- };
119
- } finally {
120
- this.provider.closeProcess(handle);
121
- }
122
- }
123
- /**
124
- * Parse RTTI Complete Object Locator (MSVC x64 layout).
125
- *
126
- * vtable[-1] → RTTI COL:
127
- * +0x00: signature (1 for x64)
128
- * +0x04: offset
129
- * +0x08: cdOffset
130
- * +0x0C: typeDescriptorRVA
131
- * +0x10: classDescriptorRVA
132
- * +0x14: objectLocatorRVA
133
- *
134
- * TypeDescriptor (at moduleBase + typeDescriptorRVA):
135
- * +0x00: pVFTable (pointer)
136
- * +0x08: spare (pointer)
137
- * +0x10: name (null-terminated mangled string)
138
- */
139
- async parseRtti(pid, vtableAddress, existingHandle) {
140
- const vtableAddr = BigInt(vtableAddress.startsWith("0x") ? vtableAddress : `0x${vtableAddress}`);
141
- const ownHandle = !existingHandle;
142
- const handle = existingHandle ?? this.provider.openProcess(pid, false);
143
- try {
144
- const colAddr = this.provider.readMemory(handle, vtableAddr - 8n, 8).data.readBigUInt64LE(0);
145
- if (!this.isValidReadablePointer(handle, colAddr)) return null;
146
- const colBuf = this.provider.readMemory(handle, colAddr, 24).data;
147
- if (colBuf.readUInt32LE(0) !== 1) return null;
148
- const typeDescRVA = colBuf.readUInt32LE(12);
149
- const classDescRVA = colBuf.readUInt32LE(16);
150
- const objectLocRVA = colBuf.readUInt32LE(20);
151
- const moduleBase = colAddr - BigInt(objectLocRVA);
152
- const typeDescAddr = moduleBase + BigInt(typeDescRVA);
153
- const className = this.readCString(handle, typeDescAddr + 16n, STRUCT_RTTI_MAX_STRING_LEN);
154
- if (!className) return null;
155
- const demangled = this.demangleMsvcName(className);
156
- const baseClasses = [];
157
- try {
158
- const classDescAddr = moduleBase + BigInt(classDescRVA);
159
- const classDescBuf = this.provider.readMemory(handle, classDescAddr, 16).data;
160
- const numBaseClasses = classDescBuf.readUInt32LE(8);
161
- const baseClassArrayRVA = classDescBuf.readUInt32LE(12);
162
- if (numBaseClasses > 0 && numBaseClasses < 20) {
163
- const baseArrayAddr = moduleBase + BigInt(baseClassArrayRVA);
164
- const baseArrayBuf = this.provider.readMemory(handle, baseArrayAddr, numBaseClasses * 4).data;
165
- for (let i = 1; i < numBaseClasses; i++) {
166
- const baseDescRVA = baseArrayBuf.readUInt32LE(i * 4);
167
- const baseDescAddr = moduleBase + BigInt(baseDescRVA);
168
- try {
169
- const baseTypeDescRVA = this.provider.readMemory(handle, baseDescAddr, 8).data.readUInt32LE(0);
170
- const baseTypeDescAddr = moduleBase + BigInt(baseTypeDescRVA);
171
- const baseName = this.readCString(handle, baseTypeDescAddr + 16n, STRUCT_RTTI_MAX_STRING_LEN);
172
- if (baseName) baseClasses.push(this.demangleMsvcName(baseName));
173
- } catch {
174
- break;
175
- }
176
- }
177
- }
178
- } catch {}
179
- return {
180
- className: demangled,
181
- baseClasses
182
- };
183
- } catch {
184
- return null;
185
- } finally {
186
- if (ownHandle) this.provider.closeProcess(handle);
187
- }
188
- }
189
- /**
190
- * Export an inferred struct as C-style definition.
191
- */
192
- exportToCStruct(structure, name) {
193
- const structName = name ?? structure.className ?? "UnknownStruct";
194
- const lines = [];
195
- lines.push(`struct ${structName} { // size: 0x${structure.totalSize.toString(16).toUpperCase()} (${structure.totalSize} bytes)`);
196
- for (const field of structure.fields) {
197
- const cType = this.fieldTypeToCType(field.type, field.size);
198
- const offsetStr = `0x${field.offset.toString(16).padStart(2, "0").toUpperCase()}`;
199
- const comment = field.notes ? `// +${offsetStr} ${field.notes}` : `// +${offsetStr} = ${field.value}`;
200
- if (field.type === "padding") lines.push(` uint8_t _pad_${field.offset.toString(16)}[${field.size}]; ${comment}`);
201
- else lines.push(` ${cType} ${field.name}; ${comment}`);
202
- }
203
- lines.push("};");
204
- return {
205
- name: structName,
206
- definition: lines.join("\n"),
207
- size: structure.totalSize,
208
- fieldCount: structure.fields.filter((f) => f.type !== "padding").length
209
- };
210
- }
211
- /**
212
- * Compare two structure instances to find differing vs constant fields.
213
- */
214
- async compareInstances(pid, address1, address2, size) {
215
- const analysisSize = size ?? STRUCT_ANALYZE_DEFAULT_SIZE;
216
- const [struct1, struct2] = await Promise.all([this.analyzeStructure(pid, address1, {
217
- size: analysisSize,
218
- parseRtti: false
219
- }), this.analyzeStructure(pid, address2, {
220
- size: analysisSize,
221
- parseRtti: false
222
- })]);
223
- const matching = [];
224
- const differing = [];
225
- const fieldMap2 = new Map(struct2.fields.map((f) => [f.offset, f]));
226
- for (const f1 of struct1.fields) {
227
- const f2 = fieldMap2.get(f1.offset);
228
- if (!f2) continue;
229
- if (f1.value === f2.value && f1.type === f2.type) matching.push(f1);
230
- else differing.push({
231
- offset: f1.offset,
232
- value1: f1.value,
233
- value2: f2.value,
234
- type: f1.type
235
- });
236
- }
237
- return {
238
- matching,
239
- differing
240
- };
241
- }
242
- /**
243
- * Classify the value at a given offset in the buffer.
244
- */
245
- classifyValue(buf, handle, _baseAddr, offset, remaining) {
246
- if (remaining >= 8) {
247
- const val64 = buf.readBigUInt64LE(offset);
248
- if (offset === 0 && val64 !== 0n) {
249
- if (this.isValidExecutablePointer(handle, val64)) try {
250
- const firstFunc = this.provider.readMemory(handle, val64, 16).data.readBigUInt64LE(0);
251
- if (this.isValidExecutablePointer(handle, firstFunc)) return {
252
- type: "vtable_ptr",
253
- size: 8,
254
- value: `0x${val64.toString(16).toUpperCase()}`,
255
- confidence: .9,
256
- notes: "likely vtable pointer (points to array of executable pointers)"
257
- };
258
- } catch {}
259
- }
260
- if (val64 !== 0n && val64 > 65536n && val64 < 140737488355327n) {
261
- if (this.isValidReadablePointer(handle, val64)) {
262
- const str = this.readCString(handle, val64, 64);
263
- if (str && str.length >= 2) return {
264
- type: "string_ptr",
265
- size: 8,
266
- value: `0x${val64.toString(16).toUpperCase()} → "${str.slice(0, 32)}${str.length > 32 ? "..." : ""}"`,
267
- confidence: .75,
268
- notes: `string pointer: "${str.slice(0, 64)}"`
269
- };
270
- return {
271
- type: "pointer",
272
- size: 8,
273
- value: `0x${val64.toString(16).toUpperCase()}`,
274
- confidence: .7,
275
- notes: "valid pointer to readable memory"
276
- };
277
- }
278
- }
279
- }
280
- if (remaining >= 4) {
281
- const val32u = buf.readUInt32LE(offset);
282
- const val32s = buf.readInt32LE(offset);
283
- const valFloat = buf.readFloatLE(offset);
284
- if (val32u === 0 && remaining >= 8 && buf.readUInt32LE(offset + 4) === 0) {
285
- let zeroLen = 0;
286
- for (let i = offset; i < buf.length && buf[i] === 0; i++) zeroLen++;
287
- const alignedPad = Math.min(zeroLen, remaining) & -8;
288
- return {
289
- type: "padding",
290
- size: alignedPad,
291
- value: `0x${"00".repeat(Math.min(alignedPad, 8))}`,
292
- confidence: .6
293
- };
294
- }
295
- if (val32u === 0) return {
296
- type: "int32",
297
- size: 4,
298
- value: "0",
299
- confidence: .4,
300
- notes: "zero value — could be int, bool, or padding"
301
- };
302
- if (val32u === 1) return {
303
- type: "bool",
304
- size: 4,
305
- value: "true",
306
- confidence: .5,
307
- notes: "value is 1 — could be boolean"
308
- };
309
- if (isFinite(valFloat) && !isNaN(valFloat) && Math.abs(valFloat) > 1e-10 && Math.abs(valFloat) < 1e8) {
310
- const intLooksReasonable = val32u > 0 && val32u < 1e5;
311
- const floatHasDecimals = Math.abs(valFloat - Math.round(valFloat)) > .001;
312
- if (floatHasDecimals || !intLooksReasonable && Math.abs(valFloat) < 1e4) return {
313
- type: "float",
314
- size: 4,
315
- value: valFloat.toFixed(6),
316
- confidence: floatHasDecimals ? .8 : .5,
317
- notes: floatHasDecimals ? "IEEE 754 float with fractional part" : "could be float or int"
318
- };
319
- }
320
- if (val32u < 2147483648) return {
321
- type: "int32",
322
- size: 4,
323
- value: val32s.toString(),
324
- confidence: .6
325
- };
326
- return {
327
- type: "uint32",
328
- size: 4,
329
- value: val32u.toString(),
330
- confidence: .5
331
- };
332
- }
333
- if (remaining >= 2) return {
334
- type: "uint16",
335
- size: 2,
336
- value: buf.readUInt16LE(offset).toString(),
337
- confidence: .4
338
- };
339
- return {
340
- type: "uint8",
341
- size: 1,
342
- value: buf.readUInt8(offset).toString(),
343
- confidence: .3
344
- };
345
- }
346
- isValidReadablePointer(handle, address) {
347
- try {
348
- const regionInfo = this.provider.queryRegion(handle, address);
349
- if (!regionInfo) return false;
350
- return regionInfo.isReadable;
351
- } catch {
352
- return false;
353
- }
354
- }
355
- isValidExecutablePointer(handle, address) {
356
- try {
357
- const regionInfo = this.provider.queryRegion(handle, address);
358
- if (!regionInfo) return false;
359
- return regionInfo.isReadable && regionInfo.isExecutable;
360
- } catch {
361
- return false;
362
- }
363
- }
364
- readCString(handle, address, maxLen) {
365
- try {
366
- const buf = this.provider.readMemory(handle, address, maxLen).data;
367
- const nullIdx = buf.indexOf(0);
368
- if (nullIdx < 0) return null;
369
- const str = buf.subarray(0, nullIdx).toString("ascii");
370
- if (/^[\x20-\x7E]+$/.test(str) && str.length >= 1) return str;
371
- return null;
372
- } catch {
373
- return null;
374
- }
375
- }
376
- demangleMsvcName(name) {
377
- const match = name.match(/\.?\?A[VU](.+?)@@/);
378
- if (match) return match[1];
379
- const enumMatch = name.match(/\.?\?AW4(.+?)@@/);
380
- if (enumMatch) return enumMatch[1];
381
- return name.replace(/^\./, "").replace(/@@$/, "");
382
- }
383
- fieldTypeToCType(type, size) {
384
- switch (type) {
385
- case "int8": return "int8_t";
386
- case "uint8": return "uint8_t";
387
- case "int16": return "int16_t";
388
- case "uint16": return "uint16_t";
389
- case "int32": return "int32_t";
390
- case "uint32": return "uint32_t";
391
- case "int64": return "int64_t";
392
- case "uint64": return "uint64_t";
393
- case "float": return "float";
394
- case "double": return "double";
395
- case "pointer": return "void*";
396
- case "vtable_ptr": return "void**";
397
- case "string_ptr": return "char*";
398
- case "bool": return "bool";
399
- case "padding": return `uint8_t[${size}]`;
400
- case "unknown": return `uint8_t[${size}]`;
401
- default: return `uint8_t[${size}]`;
402
- }
403
- }
404
- async getModuleEntries(pid) {
405
- const modules = /* @__PURE__ */ new Map();
406
- try {
407
- const result = await nativeMemoryManager.enumerateModules(pid);
408
- if (result.success && result.modules) for (const mod of result.modules) {
409
- const base = BigInt(mod.baseAddress.startsWith("0x") ? mod.baseAddress : `0x${mod.baseAddress}`);
410
- modules.set(mod.name.toLowerCase(), {
411
- name: mod.name,
412
- base,
413
- size: mod.size
414
- });
415
- }
416
- } catch {}
417
- return modules;
418
- }
419
- resolveToModule(address, moduleMap) {
420
- for (const entry of moduleMap.values()) if (address >= entry.base && address < entry.base + BigInt(entry.size)) return {
421
- module: entry.name,
422
- offset: Number(address - entry.base)
423
- };
424
- return null;
425
- }
426
- };
427
- const structureAnalyzer = new StructureAnalyzer();
428
- //#endregion
429
- export { StructureAnalyzer, structureAnalyzer };