@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,418 +0,0 @@
1
- import { t as createProgressDebouncer } from "./EventBus-DgPmwpeu.mjs";
2
- import { t as tool } from "./tool-builder-DCbIC5Eo.mjs";
3
- //#region src/server/domains/memory/definitions.ts
4
- const ScanValueTypeOptions = [
5
- "byte",
6
- "int8",
7
- "int16",
8
- "uint16",
9
- "int32",
10
- "uint32",
11
- "int64",
12
- "uint64",
13
- "float",
14
- "double",
15
- "string",
16
- "hex",
17
- "pointer"
18
- ];
19
- const ScanCompareModeOptions = [
20
- "exact",
21
- "unknown_initial",
22
- "changed",
23
- "unchanged",
24
- "increased",
25
- "decreased",
26
- "greater_than",
27
- "less_than",
28
- "between",
29
- "not_equal"
30
- ];
31
- const memoryScanToolDefinitions = [
32
- tool("memory_first_scan", (t) => t.desc("Start a new memory scan session.").string("value", "Value to search for (as string, e.g. \"100\", \"3.14\", \"48 65 6C 6C 6F\")").enum("valueType", [...ScanValueTypeOptions], "Data type of the value").number("alignment", "Alignment in bytes (0=unaligned, 4=4-byte aligned). Default: natural alignment for the type.").number("maxResults", "Maximum results to return (default: 1,000,000)").prop("regionFilter", {
33
- type: "object",
34
- properties: {
35
- writable: {
36
- type: "boolean",
37
- description: "Only scan writable regions"
38
- },
39
- executable: {
40
- type: "boolean",
41
- description: "Only scan executable regions"
42
- },
43
- moduleOnly: {
44
- type: "boolean",
45
- description: "Only scan module-backed regions"
46
- }
47
- },
48
- description: "Filter which memory regions to scan"
49
- }).requiredOpenWorld("pid", "value", "valueType")),
50
- tool("memory_next_scan", (t) => t.desc("Narrow an existing scan session.").enum("mode", [...ScanCompareModeOptions], "Comparison mode").string("value", "Target value for exact/greater_than/less_than/between/not_equal modes").string("value2", "Upper bound value for \"between\" mode").requiredOpenWorld("sessionId", "mode")),
51
- tool("memory_unknown_scan", (t) => t.desc("Start an unknown initial value scan.").enum("valueType", [...ScanValueTypeOptions], "Data type to capture").number("alignment", "Alignment in bytes (default: natural for type)").number("maxResults", "Maximum addresses to capture (default: 5,000,000)").prop("regionFilter", {
52
- type: "object",
53
- properties: {
54
- writable: { type: "boolean" },
55
- executable: { type: "boolean" },
56
- moduleOnly: { type: "boolean" }
57
- }
58
- }).requiredOpenWorld("pid", "valueType")),
59
- tool("memory_pointer_scan", (t) => t.desc("Find pointers to a target address.").string("targetAddress", "Target address to find pointers to (hex, e.g. \"0x7FF612340000\")").number("maxResults", "Maximum results (default: 10,000)").boolean("moduleOnly", "Only scan module-backed regions").required("pid", "targetAddress").query().openWorld()),
60
- tool("memory_group_scan", (t) => t.desc("Search for multiple values at known offsets simultaneously.").array("pattern", {
61
- type: "object",
62
- properties: {
63
- offset: {
64
- type: "number",
65
- description: "Byte offset from base"
66
- },
67
- value: {
68
- type: "string",
69
- description: "Expected value at offset"
70
- },
71
- type: {
72
- type: "string",
73
- enum: [...ScanValueTypeOptions],
74
- description: "Value type at offset"
75
- }
76
- },
77
- required: [
78
- "offset",
79
- "value",
80
- "type"
81
- ]
82
- }, "Array of {offset, value, type} patterns").number("alignment", "Alignment for base address (default: 4)").number("maxResults", "Maximum results (default: 1,000,000)").required("pid", "pattern").query()),
83
- tool("memory_scan_session", (t) => t.desc(`Manage scan sessions. Actions: list (all sessions), delete (by sessionId), export (as JSON).`).enum("action", [
84
- "list",
85
- "delete",
86
- "export"
87
- ], "Session management action").string("sessionId", "Scan session ID (required for delete/export)").required("action")),
88
- tool("memory_pointer_chain", (t) => t.desc(`Multi-level pointer chain operations.
89
-
90
- Actions:
91
- - scan: Find pointer chains to a target address
92
- - validate: Validate chains by re-dereferencing
93
- - resolve: Resolve a single chain to its current target
94
- - export: Export chains as JSON`).enum("action", [
95
- "scan",
96
- "validate",
97
- "resolve",
98
- "export"
99
- ], "Chain operation").number("pid", "Target process ID").string("targetAddress", "Target address hex (action=scan)").number("maxDepth", "Max chain depth 1-6 (action=scan, default: 4)").number("maxOffset", "Max offset per level in bytes (action=scan, default: 4096)").boolean("staticOnly", "Only module-relative chains (action=scan, default: false)").array("modules", { type: "string" }, "Only scan specific modules (action=scan)").number("maxResults", "Max chains to return (action=scan, default: 1000)").string("chains", "JSON PointerChain[] (action=validate/export)").string("chain", "JSON single PointerChain (action=resolve)").required("action")),
100
- tool("memory_structure_analyze", (t) => t.desc("Analyze memory at an address to infer data structure layout.").string("address", "Base address of the structure (hex)").number("size", "Size to analyze in bytes (default: 256)").array("otherInstances", { type: "string" }, "Additional instance addresses for cross-comparison").boolean("parseRtti", "Whether to attempt RTTI parsing (default: true)").required("pid", "address").query()),
101
- tool("memory_vtable_parse", (t) => t.desc("Parse a vtable to enumerate virtual function pointers and resolve them to module+offset. Also attempts RTTI parsing for class name and inheritance hierarchy.").number("pid", "Target process ID").string("vtableAddress", "Address of the vtable (hex)").required("pid", "vtableAddress").query()),
102
- tool("memory_structure_export_c", (t) => t.desc("Export an inferred structure as a C-style struct definition with offset comments and type annotations.").string("structure", "JSON string of InferredStruct to export").string("name", "Struct name (defaults to RTTI class name or \"UnknownStruct\")").required("structure").query()),
103
- tool("memory_structure_compare", (t) => t.desc("Compare two structure instances to identify which fields differ (dynamic values like health/position) vs which are constant (vtable, type flags). Useful for finding important fields.").number("pid", "Target process ID").string("address1", "First instance address (hex)").string("address2", "Second instance address (hex)").number("size", "Size to compare in bytes (default: 256)").required("pid", "address1", "address2").query()),
104
- tool("memory_breakpoint", (t) => t.desc(`Hardware breakpoint operations using x64 debug registers (DR0-DR3). Max 4 concurrent.
105
-
106
- Actions:
107
- - set: Set a breakpoint (requires pid, address, access)
108
- - remove: Remove by breakpointId
109
- - list: List all active breakpoints
110
- - trace: Set temporary breakpoint, collect N hits, then auto-remove`).enum("action", [
111
- "set",
112
- "remove",
113
- "list",
114
- "trace"
115
- ], "Breakpoint operation").number("pid", "Target process ID (action=set/trace)").string("address", "Address hex (action=set/trace)").enum("access", [
116
- "read",
117
- "write",
118
- "readwrite",
119
- "execute"
120
- ], "Access type (action=set/trace)").number("size", "Watch size in bytes (action=set, default: 4)").string("breakpointId", "Breakpoint ID (action=remove)").number("maxHits", "Max hits to collect (action=trace, default: 50)").number("timeoutMs", "Timeout ms (action=trace, default: 10000)").required("action").destructive()),
121
- tool("memory_patch_bytes", (t) => t.desc("Write bytes to target process at address. Saves original bytes for undo. Use for runtime code patching.").number("pid", "Target process ID").string("address", "Address to patch (hex)").array("bytes", { type: "number" }, "Byte values to write (e.g. [0x90, 0x90])").required("pid", "address", "bytes").destructive().openWorld()),
122
- tool("memory_patch_nop", (t) => t.desc("NOP out instructions at address (replace with 0x90). Useful for disabling checks or jumps.").number("pid", "Target process ID").string("address", "Address to NOP (hex)").number("count", "Number of bytes to NOP").required("pid", "address", "count").destructive()),
123
- tool("memory_patch_undo", (t) => t.desc("Undo a previous patch by restoring the original bytes.").string("patchId", "Patch ID to undo").required("patchId").destructive()),
124
- tool("memory_code_caves", (t) => t.desc("Find code caves (runs of 0x00 or 0xCC) in executable sections of loaded modules. Returns largest caves first.").number("pid", "Target process ID").number("minSize", "Minimum cave size in bytes (default: 16)").required("pid").query()),
125
- tool("memory_write_value", (t) => t.desc("Write a typed value to a memory address. Supports undo via memory_write_undo.").number("pid", "Target process ID").string("address", "Address to write to (hex)").string("value", "Value to write (as string)").enum("valueType", [...ScanValueTypeOptions], "Data type of the value").required("pid", "address", "value", "valueType").destructive()),
126
- tool("memory_freeze", (t) => t.desc(`Freeze or unfreeze a memory address. Freeze continuously writes a value to prevent changes; unfreeze stops it.`).enum("action", ["freeze", "unfreeze"], "Freeze operation").number("pid", "Target process ID (action=freeze)").string("address", "Address to freeze hex (action=freeze)").string("value", "Value to maintain (action=freeze)").enum("valueType", [...ScanValueTypeOptions], "Data type (action=freeze)").number("intervalMs", "Write interval ms (action=freeze, default: 100)").string("freezeId", "Freeze ID to remove (action=unfreeze)").required("action").destructive()),
127
- tool("memory_dump", (t) => t.desc("Dump memory region as hex with ASCII column. Outputs a formatted hex dump similar to xxd.").number("pid", "Target process ID").string("address", "Start address (hex)").number("size", "Size to dump in bytes (default: 256)").required("pid", "address").query()),
128
- tool("memory_speedhack", (t) => t.desc(`Speedhack: hook time APIs to scale process time. Speed 2.0 = 2x faster, 0.5 = half speed.
129
-
130
- Actions:
131
- - apply: Hook and apply speed multiplier (requires pid, speed)
132
- - set: Adjust speed on active hack (requires pid, speed)`).enum("action", ["apply", "set"], "Speedhack action").number("pid", "Target process ID").number("speed", "Speed multiplier").required("action", "pid", "speed").destructive()),
133
- tool("memory_write_history", (t) => t.desc("Undo or redo the last memory write operation.").enum("action", ["undo", "redo"], "History action").required("action").destructive().openWorld()),
134
- tool("memory_heap_enumerate", (t) => t.desc("Enumerate all heaps and heap blocks in a process via Toolhelp32 snapshot. Returns heap list with block counts, sizes, and overall statistics.").number("pid", "Target process ID").number("maxBlocks", "Maximum blocks to enumerate per heap (default: 10000)").required("pid").query()),
135
- tool("memory_heap_stats", (t) => t.desc("Get detailed heap statistics with size distribution buckets (0-64B, 64B-1KB, 1-64KB, 64KB-1MB, >1MB), fragmentation ratio, and aggregate metrics.").number("pid", "Target process ID").required("pid").query()),
136
- tool("memory_heap_anomalies", (t) => t.desc("Detect heap anomalies: heap spray patterns (many same-size blocks), possible use-after-free (non-zero free blocks), and suspicious block sizes (0 or >100MB).").number("pid", "Target process ID").required("pid").query()),
137
- tool("memory_pe_headers", (t) => t.desc("Parse PE headers (DOS, NT, File, Optional) from a module base address in process memory. Returns machine type, entry point, image base, section count, and data directory info.").number("pid", "Target process ID").string("moduleBase", "Module base address (hex, e.g. \"0x7ff612340000\")").required("pid", "moduleBase").query()),
138
- tool("memory_pe_imports_exports", (t) => t.desc("Parse import and/or export tables from a PE module in process memory. Returns DLL names, function names, ordinals, hints, and forwarded exports.").number("pid", "Target process ID").string("moduleBase", "Module base address (hex)").enum("table", [
139
- "imports",
140
- "exports",
141
- "both"
142
- ], "Which table to parse", { default: "both" }).required("pid", "moduleBase").query()),
143
- tool("memory_inline_hook_detect", (t) => t.desc("Detect inline hooks by comparing the first 16 bytes of each exported function on disk vs in memory. Identifies JMP rel32, JMP abs64, PUSH+RET hooks and decodes jump targets.").number("pid", "Target process ID").string("moduleName", "Module name filter (optional — scans all modules if omitted)").required("pid").query()),
144
- tool("memory_anticheat_detect", (t) => t.desc("Scan process imports for anti-debug/anti-cheat mechanisms: IsDebuggerPresent, NtQueryInformationProcess, timing checks (QPC, GetTickCount), thread hiding, heap flag checks, and DR register inspection. Each detection includes a bypass suggestion.").number("pid", "Target process ID").required("pid").query()),
145
- tool("memory_guard_pages", (t) => t.desc("Find all memory regions with PAGE_GUARD protection in a process. Guard pages are often used as anti-tampering mechanisms or stack overflow detection.").number("pid", "Target process ID").required("pid").query()),
146
- tool("memory_integrity_check", (t) => t.desc("Check executable memory regions against their corresponding on-disk PE files (.text sections) to detect modifications like inline hooks or code patches.").number("pid", "Target process ID").required("pid").query())
147
- ];
148
- //#endregion
149
- //#region src/server/domains/memory/manifest.ts
150
- const DOMAIN = "memory";
151
- const DEP_KEY = "memoryScanHandlers";
152
- const IS_WIN32 = (process.env.JSHOOK_REGISTRY_PLATFORM === "win32" || process.env.JSHOOK_REGISTRY_PLATFORM === "linux" || process.env.JSHOOK_REGISTRY_PLATFORM === "darwin" ? process.env.JSHOOK_REGISTRY_PLATFORM : process.platform) === "win32";
153
- let globalContext = null;
154
- async function ensure(ctx) {
155
- const { MemoryScanHandlers } = await import("./handlers.impl-DS0d9fUw.mjs");
156
- globalContext = ctx;
157
- const ctxAny = ctx;
158
- if (ctxAny[DEP_KEY]) return ctxAny[DEP_KEY];
159
- const [memoryScanner, scanSessionManager, pointerChainEngine, structureAnalyzer, codeInjector, memoryController] = await Promise.all([
160
- import("./MemoryScanner-Bcpml6II.mjs"),
161
- import("./MemoryScanSession-BsDZbLYm.mjs"),
162
- import("./PointerChainEngine-BOhyVsjx.mjs"),
163
- import("./StructureAnalyzer-DhFaPvRO.mjs"),
164
- import("./CodeInjector-Cq8q01kp.mjs"),
165
- import("./MemoryController-CbVdCIJF.mjs")
166
- ]);
167
- if (IS_WIN32) {
168
- const [hardwareBreakpointEngine, speedhack, heapAnalyzer, peAnalyzer, antiCheatDetector] = await Promise.all([
169
- import("./HardwareBreakpoint-B9gZCdFP.mjs"),
170
- import("./Speedhack-CqdIFlQl.mjs"),
171
- import("./HeapAnalyzer-BLDH0dCv.mjs"),
172
- import("./PEAnalyzer-D1lzJ_VG.mjs"),
173
- import("./AntiCheatDetector-BNk-EoBt.mjs")
174
- ]);
175
- ctxAny[DEP_KEY] = new MemoryScanHandlers(memoryScanner.memoryScanner, scanSessionManager.scanSessionManager, pointerChainEngine.pointerChainEngine, structureAnalyzer.structureAnalyzer, hardwareBreakpointEngine.hardwareBreakpointEngine, codeInjector.codeInjector, memoryController.memoryController, speedhack.speedhack, heapAnalyzer.heapAnalyzer, peAnalyzer.peAnalyzer, antiCheatDetector.antiCheatDetector, ctx.eventBus);
176
- } else ctxAny[DEP_KEY] = new MemoryScanHandlers(memoryScanner.memoryScanner, scanSessionManager.scanSessionManager, pointerChainEngine.pointerChainEngine, structureAnalyzer.structureAnalyzer, null, codeInjector.codeInjector, memoryController.memoryController, null, null, null, null, ctx.eventBus);
177
- return ctxAny[DEP_KEY];
178
- }
179
- function bindByKey(invoke) {
180
- return (deps) => {
181
- const handler = deps[DEP_KEY];
182
- return (args) => {
183
- const _meta = args._meta;
184
- let onProgress;
185
- if (_meta?.progressToken !== void 0 && globalContext) onProgress = createProgressDebouncer(globalContext.eventBus, _meta.progressToken);
186
- return invoke(handler, {
187
- ...args,
188
- onProgress
189
- });
190
- };
191
- };
192
- }
193
- function toolByName(name) {
194
- const tool = memoryScanToolDefinitions.find((t) => t.name === name);
195
- if (!tool) throw new Error(`Memory tool not found: ${name}`);
196
- return tool;
197
- }
198
- const WIN32_ONLY_TOOLS = new Set([
199
- "memory_heap_enumerate",
200
- "memory_heap_stats",
201
- "memory_heap_anomalies",
202
- "memory_pe_headers",
203
- "memory_pe_imports_exports",
204
- "memory_inline_hook_detect",
205
- "memory_anticheat_detect",
206
- "memory_guard_pages",
207
- "memory_integrity_check",
208
- "memory_breakpoint",
209
- "memory_speedhack"
210
- ]);
211
- const allRegistrations = [
212
- {
213
- tool: toolByName("memory_first_scan"),
214
- domain: DOMAIN,
215
- bind: bindByKey((h, a) => h.handleFirstScan(a))
216
- },
217
- {
218
- tool: toolByName("memory_next_scan"),
219
- domain: DOMAIN,
220
- bind: bindByKey((h, a) => h.handleNextScan(a))
221
- },
222
- {
223
- tool: toolByName("memory_unknown_scan"),
224
- domain: DOMAIN,
225
- bind: bindByKey((h, a) => h.handleUnknownScan(a))
226
- },
227
- {
228
- tool: toolByName("memory_pointer_scan"),
229
- domain: DOMAIN,
230
- bind: bindByKey((h, a) => h.handlePointerScan(a))
231
- },
232
- {
233
- tool: toolByName("memory_group_scan"),
234
- domain: DOMAIN,
235
- bind: bindByKey((h, a) => h.handleGroupScan(a))
236
- },
237
- {
238
- tool: toolByName("memory_scan_session"),
239
- domain: DOMAIN,
240
- bind: bindByKey((h, a) => h.handleScanSessionDispatch(a))
241
- },
242
- {
243
- tool: toolByName("memory_pointer_chain"),
244
- domain: DOMAIN,
245
- bind: bindByKey((h, a) => h.handlePointerChainDispatch(a))
246
- },
247
- {
248
- tool: toolByName("memory_structure_analyze"),
249
- domain: DOMAIN,
250
- bind: bindByKey((h, a) => h.handleStructureAnalyze(a))
251
- },
252
- {
253
- tool: toolByName("memory_vtable_parse"),
254
- domain: DOMAIN,
255
- bind: bindByKey((h, a) => h.handleVtableParse(a))
256
- },
257
- {
258
- tool: toolByName("memory_structure_export_c"),
259
- domain: DOMAIN,
260
- bind: bindByKey((h, a) => h.handleStructureExportC(a))
261
- },
262
- {
263
- tool: toolByName("memory_structure_compare"),
264
- domain: DOMAIN,
265
- bind: bindByKey((h, a) => h.handleStructureCompare(a))
266
- },
267
- {
268
- tool: toolByName("memory_breakpoint"),
269
- domain: DOMAIN,
270
- bind: bindByKey((h, a) => h.handleBreakpointDispatch(a))
271
- },
272
- {
273
- tool: toolByName("memory_patch_bytes"),
274
- domain: DOMAIN,
275
- bind: bindByKey((h, a) => h.handlePatchBytes(a))
276
- },
277
- {
278
- tool: toolByName("memory_patch_nop"),
279
- domain: DOMAIN,
280
- bind: bindByKey((h, a) => h.handlePatchNop(a))
281
- },
282
- {
283
- tool: toolByName("memory_patch_undo"),
284
- domain: DOMAIN,
285
- bind: bindByKey((h, a) => h.handlePatchUndo(a))
286
- },
287
- {
288
- tool: toolByName("memory_code_caves"),
289
- domain: DOMAIN,
290
- bind: bindByKey((h, a) => h.handleCodeCaves(a))
291
- },
292
- {
293
- tool: toolByName("memory_write_value"),
294
- domain: DOMAIN,
295
- bind: bindByKey((h, a) => h.handleWriteValue(a))
296
- },
297
- {
298
- tool: toolByName("memory_freeze"),
299
- domain: DOMAIN,
300
- bind: bindByKey((h, a) => h.handleFreezeDispatch(a))
301
- },
302
- {
303
- tool: toolByName("memory_dump"),
304
- domain: DOMAIN,
305
- bind: bindByKey((h, a) => h.handleDump(a))
306
- },
307
- {
308
- tool: toolByName("memory_speedhack"),
309
- domain: DOMAIN,
310
- bind: bindByKey((h, a) => h.handleSpeedhackDispatch(a))
311
- },
312
- {
313
- tool: toolByName("memory_write_history"),
314
- domain: DOMAIN,
315
- bind: bindByKey((h, a) => h.handleWriteHistoryDispatch(a))
316
- },
317
- {
318
- tool: toolByName("memory_heap_enumerate"),
319
- domain: DOMAIN,
320
- bind: bindByKey((h, a) => h.handleHeapEnumerate(a))
321
- },
322
- {
323
- tool: toolByName("memory_heap_stats"),
324
- domain: DOMAIN,
325
- bind: bindByKey((h, a) => h.handleHeapStats(a))
326
- },
327
- {
328
- tool: toolByName("memory_heap_anomalies"),
329
- domain: DOMAIN,
330
- bind: bindByKey((h, a) => h.handleHeapAnomalies(a))
331
- },
332
- {
333
- tool: toolByName("memory_pe_headers"),
334
- domain: DOMAIN,
335
- bind: bindByKey((h, a) => h.handlePEHeaders(a))
336
- },
337
- {
338
- tool: toolByName("memory_pe_imports_exports"),
339
- domain: DOMAIN,
340
- bind: bindByKey((h, a) => h.handlePEImportsExports(a))
341
- },
342
- {
343
- tool: toolByName("memory_inline_hook_detect"),
344
- domain: DOMAIN,
345
- bind: bindByKey((h, a) => h.handleInlineHookDetect(a))
346
- },
347
- {
348
- tool: toolByName("memory_anticheat_detect"),
349
- domain: DOMAIN,
350
- bind: bindByKey((h, a) => h.handleAntiCheatDetect(a))
351
- },
352
- {
353
- tool: toolByName("memory_guard_pages"),
354
- domain: DOMAIN,
355
- bind: bindByKey((h, a) => h.handleGuardPages(a))
356
- },
357
- {
358
- tool: toolByName("memory_integrity_check"),
359
- domain: DOMAIN,
360
- bind: bindByKey((h, a) => h.handleIntegrityCheck(a))
361
- }
362
- ];
363
- const manifest = {
364
- kind: "domain-manifest",
365
- version: 1,
366
- domain: DOMAIN,
367
- depKey: DEP_KEY,
368
- profiles: ["full"],
369
- ensure,
370
- registrations: IS_WIN32 ? allRegistrations : allRegistrations.filter((r) => !WIN32_ONLY_TOOLS.has(r.tool.name)),
371
- workflowRule: {
372
- patterns: [
373
- /memory\s*scan/i,
374
- /cheat\s*engine/i,
375
- /find\s*(value|address|variable|struct)/i,
376
- /scan\s*(for|memory)/i,
377
- /pointer\s*(chain|scan)/i,
378
- /struct(ure)?\s*(analy|infer|dissect)/i,
379
- /vtable|rtti/i,
380
- /breakpoint|watchpoint|hardware\s*bp/i,
381
- /patch\s*(byte|nop|code)/i,
382
- /code\s*cave/i,
383
- /freeze|unfreeze/i,
384
- /speedhack|time\s*(hack|scale)/i,
385
- /memory\s*(dump|hex)/i,
386
- /undo|redo/i,
387
- /heap|堆\s*(分析|枚举|异常)/i,
388
- /PE\s*(header|import|export)|inline.*hook/i,
389
- /anti.?cheat|anti.?debug|反作弊|反调试/i,
390
- /guard\s*page|integrity\s*check|代码完整性/i,
391
- /内存\s*(扫描|搜索|分析|结构|断点|注入|冻结|加速|堆|模块|反作弊)/i
392
- ],
393
- priority: 90,
394
- tools: [
395
- "memory_first_scan",
396
- "memory_next_scan",
397
- "memory_unknown_scan",
398
- "memory_pointer_chain",
399
- "memory_structure_analyze",
400
- "memory_vtable_parse",
401
- "memory_scan_session",
402
- ...IS_WIN32 ? ["memory_breakpoint", "memory_speedhack"] : [],
403
- "memory_patch_bytes",
404
- "memory_freeze",
405
- "memory_dump",
406
- ...IS_WIN32 ? [
407
- "memory_speedhack",
408
- "memory_heap_enumerate",
409
- "memory_pe_headers",
410
- "memory_anticheat_detect"
411
- ] : [],
412
- "memory_write_history"
413
- ],
414
- hint: IS_WIN32 ? "Memory domain: scan → narrow → pointer chain → structure | breakpoint trace → patch/NOP → freeze | speedhack | heap analysis | PE introspection | anti-cheat detection" : "Memory domain: scan → narrow → pointer chain → structure | patch/NOP → freeze | dump"
415
- }
416
- };
417
- //#endregion
418
- export { manifest as default };
@@ -1,96 +0,0 @@
1
- import { n as toolLookup } from "./registry-D-6e18lB.mjs";
2
- import { t as bindByDepKey } from "./bind-helpers-xFfRF-qm.mjs";
3
- import { t as tool } from "./tool-builder-DCbIC5Eo.mjs";
4
- //#region src/server/domains/extension-registry/definitions.ts
5
- const extensionRegistryTools = [
6
- tool("extension_list_installed", (t) => t.desc("List installed extensions from the local extension registry").query()),
7
- tool("extension_execute_in_context", (t) => t.desc("Load an extension and execute a named exported context function").string("pluginId", "Plugin identifier").string("contextName", "Exported function or context name").prop("args", {
8
- type: "object",
9
- description: "Arguments passed to the target context",
10
- additionalProperties: true
11
- }).requiredOpenWorld("pluginId", "contextName")),
12
- tool("extension_reload", (t) => t.desc("Reload an installed extension by unloading and loading it again").string("pluginId", "Plugin identifier").requiredOpenWorld("pluginId")),
13
- tool("extension_uninstall", (t) => t.desc("Uninstall an extension from the local extension registry").string("pluginId", "Plugin identifier").required("pluginId").destructive()),
14
- tool("webhook", (t) => t.desc("Manage webhook endpoints for external callbacks. Actions: create, list, delete, commands.").enum("action", [
15
- "create",
16
- "list",
17
- "delete",
18
- "commands"
19
- ], "Webhook operation").string("name", "Human-readable webhook name (action=create)").string("path", "URL path for the webhook endpoint (action=create)").string("secret", "Optional HMAC secret for webhook authentication (action=create)").string("url", "Optional external callback URL for webhook forwarding (action=create)").array("events", { type: "string" }, "List of events to subscribe to (action=create)").string("endpointId", "Webhook endpoint identifier (action=delete, commands)").string("status", "Filter commands by status: pending, processing, completed, failed (action=commands)").prop("command", {
20
- type: "object",
21
- description: "Command to enqueue (action=commands, if provided adds to queue instead of listing)",
22
- additionalProperties: true
23
- }).required("action"))
24
- ];
25
- //#endregion
26
- //#region src/server/domains/extension-registry/manifest.ts
27
- const DOMAIN = "extension-registry";
28
- const DEP_KEY = "extensionRegistryHandlers";
29
- const t = toolLookup(extensionRegistryTools);
30
- const b = (invoke) => bindByDepKey(DEP_KEY, invoke);
31
- async function ensure(ctx) {
32
- const { ExtensionRegistryHandlers } = await import("./handlers-DeLOCd5m.mjs");
33
- const existing = ctx.getDomainInstance(DEP_KEY);
34
- if (existing) return existing;
35
- const handlers = new ExtensionRegistryHandlers();
36
- ctx.setDomainInstance(DEP_KEY, handlers);
37
- handlers.startWebhookServer().catch(() => void 0);
38
- return handlers;
39
- }
40
- const manifest = {
41
- kind: "domain-manifest",
42
- version: 1,
43
- domain: DOMAIN,
44
- depKey: DEP_KEY,
45
- profiles: ["full"],
46
- ensure,
47
- registrations: [
48
- {
49
- tool: t("extension_list_installed"),
50
- domain: DOMAIN,
51
- bind: b((handlers) => handlers.handleListInstalled())
52
- },
53
- {
54
- tool: t("extension_execute_in_context"),
55
- domain: DOMAIN,
56
- bind: b((handlers, args) => handlers.handleExecuteInContext(args))
57
- },
58
- {
59
- tool: t("extension_reload"),
60
- domain: DOMAIN,
61
- bind: b((handlers, args) => handlers.handleReload(args))
62
- },
63
- {
64
- tool: t("extension_uninstall"),
65
- domain: DOMAIN,
66
- bind: b((handlers, args) => handlers.handleUninstall(args))
67
- },
68
- {
69
- tool: t("webhook"),
70
- domain: DOMAIN,
71
- bind: b((handlers, args) => handlers.handleWebhookDispatch(args))
72
- }
73
- ],
74
- workflowRule: {
75
- patterns: [/\b(extension|plugin|addon|webhook|c2|bluetooth|ble|hid|serial|esp32|registry)\b/i, /(install|uninstall|reload).*(extension|plugin)/i],
76
- priority: 70,
77
- tools: [
78
- "install_extension",
79
- "extension_list_installed",
80
- "webhook"
81
- ],
82
- hint: "Plugin + webhook C2 + BLE HID + serial flashing pipeline."
83
- },
84
- prerequisites: { webhook: [{
85
- condition: "Webhook listen port must be free",
86
- fix: "Pick an unused port via the `port` argument or stop the conflicting service"
87
- }] },
88
- toolDependencies: [{
89
- from: "webhook",
90
- to: "extension_list_installed",
91
- relation: "suggests",
92
- weight: .5
93
- }]
94
- };
95
- //#endregion
96
- export { manifest as default };