@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,131 +0,0 @@
1
- import { t as logger } from "./logger-Dh_xb7_2.mjs";
2
- import { q as EXTERNAL_TOOL_PROBE_CACHE_TTL_MS } from "./constants-B0OANIBL.mjs";
3
- import { t as probeCommand } from "./ToolProbe-oC7aPrkv.mjs";
4
- //#region src/modules/external/ToolRegistry.ts
5
- /**
6
- * External tool registry.
7
- * Maintains a whitelist of allowed external tools with their specifications.
8
- * Only registered tools can be invoked through ExternalToolRunner.
9
- */
10
- const DEFAULT_SPECS = [
11
- {
12
- name: "wabt.wasm2wat",
13
- command: "wasm2wat",
14
- versionArgs: ["--version"],
15
- required: false,
16
- envAllowlist: []
17
- },
18
- {
19
- name: "wabt.wasm-objdump",
20
- command: "wasm-objdump",
21
- versionArgs: ["--version"],
22
- required: false,
23
- envAllowlist: []
24
- },
25
- {
26
- name: "wabt.wasm-decompile",
27
- command: "wasm-decompile",
28
- versionArgs: ["--version"],
29
- required: false,
30
- envAllowlist: []
31
- },
32
- {
33
- name: "binaryen.wasm-opt",
34
- command: "wasm-opt",
35
- versionArgs: ["--version"],
36
- required: false,
37
- envAllowlist: []
38
- },
39
- {
40
- name: "runtime.wasmtime",
41
- command: "wasmtime",
42
- versionArgs: ["--version"],
43
- required: false,
44
- envAllowlist: []
45
- },
46
- {
47
- name: "runtime.wasmer",
48
- command: "wasmer",
49
- versionArgs: ["--version"],
50
- required: false,
51
- envAllowlist: []
52
- },
53
- {
54
- name: "miniapp.unpacker",
55
- command: "unveilr",
56
- versionArgs: ["--version"],
57
- required: false,
58
- envAllowlist: []
59
- },
60
- {
61
- name: "platform.jadx",
62
- command: "jadx",
63
- versionArgs: ["--version"],
64
- required: false,
65
- envAllowlist: []
66
- }
67
- ];
68
- var ToolRegistry = class {
69
- specs = /* @__PURE__ */ new Map();
70
- probeCache = /* @__PURE__ */ new Map();
71
- probeCacheExpiry = 0;
72
- PROBE_CACHE_TTL = EXTERNAL_TOOL_PROBE_CACHE_TTL_MS;
73
- constructor(additionalSpecs) {
74
- for (const spec of DEFAULT_SPECS) this.specs.set(spec.name, spec);
75
- if (additionalSpecs) for (const spec of additionalSpecs) this.specs.set(spec.name, spec);
76
- }
77
- /**
78
- * Get the spec for a tool. Throws if not registered.
79
- */
80
- getSpec(name) {
81
- const spec = this.specs.get(name);
82
- if (!spec) throw new Error(`Tool '${name}' is not registered in the allowlist`);
83
- return spec;
84
- }
85
- /**
86
- * Check if a tool name is registered.
87
- */
88
- isRegistered(name) {
89
- return this.specs.has(name);
90
- }
91
- /**
92
- * Get all registered tool names.
93
- */
94
- getRegisteredTools() {
95
- return Array.from(this.specs.keys());
96
- }
97
- /**
98
- * Probe all registered tools for availability. Results are cached.
99
- */
100
- async probeAll(force = false) {
101
- const now = Date.now();
102
- if (!force && this.probeCache.size > 0 && now < this.probeCacheExpiry) return Object.fromEntries(this.probeCache);
103
- const results = {};
104
- const promises = [];
105
- for (const [name, spec] of this.specs) promises.push(probeCommand(spec.command, spec.versionArgs).then((result) => {
106
- results[name] = result;
107
- this.probeCache.set(name, result);
108
- }));
109
- await Promise.all(promises);
110
- this.probeCacheExpiry = now + this.PROBE_CACHE_TTL;
111
- const available = Object.values(results).filter((r) => r.available).length;
112
- logger.info(`[ToolRegistry] Probed ${this.specs.size} tools: ${available} available`);
113
- return results;
114
- }
115
- /**
116
- * Get cached probe result for a specific tool.
117
- */
118
- getCachedProbe(name) {
119
- return this.probeCache.get(name);
120
- }
121
- /**
122
- * Register a new tool spec at runtime.
123
- */
124
- register(spec) {
125
- this.specs.set(spec.name, spec);
126
- this.probeCache.delete(spec.name);
127
- logger.debug(`[ToolRegistry] Registered tool: ${spec.name} -> ${spec.command}`);
128
- }
129
- };
130
- //#endregion
131
- export { ToolRegistry as t };
@@ -1,304 +0,0 @@
1
- import { f as getAllManifests, r as getToolDomain, t as allTools } from "./ToolCatalog-C0JGZoOm.mjs";
2
- //#region src/server/ToolRouter.intent.ts
3
- const BROWSER_OR_NETWORK_TASK_PATTERN = /(browser|page|navigate|click|type|screenshot|scrape|network|request|response|api|traffic|hook|capture|intercept|monitor|浏览器|页面|导航|点击|输入|截图|爬取|网络|请求|响应|接口|流量|抓包|拦截|监控)/i;
4
- const MAINTENANCE_TASK_PATTERN = /(token budget|cache|artifact|extension|plugin|reload|doctor|cleanup|memory|profile|tool list|令牌预算|缓存|工件|扩展|插件|重载|环境诊断|清理|内存|配置)/i;
5
- let _cachedWorkflowRules = null;
6
- const _intentCache = /* @__PURE__ */ new Map();
7
- const INTENT_CACHE_MAX = 64;
8
- /**
9
- * Aggregate workflow rules declared by domain manifests.
10
- * All routing metadata is now declared in each domain's manifest.ts,
11
- * following the open-closed principle (no hardcoded rules here).
12
- *
13
- * Cached lazily — manifests are immutable at runtime.
14
- */
15
- function getEffectiveWorkflowRules() {
16
- if (_cachedWorkflowRules) return _cachedWorkflowRules;
17
- const rules = [];
18
- for (const m of getAllManifests()) if (m.workflowRule) rules.push({
19
- patterns: [...m.workflowRule.patterns],
20
- domain: m.domain,
21
- priority: m.workflowRule.priority,
22
- tools: [...m.workflowRule.tools],
23
- hint: m.workflowRule.hint
24
- });
25
- _cachedWorkflowRules = [...rules].toSorted((a, b) => b.priority - a.priority);
26
- _intentCache.clear();
27
- return _cachedWorkflowRules;
28
- }
29
- function detectWorkflowIntent(query) {
30
- const cached = _intentCache.get(query);
31
- if (cached !== void 0) return cached;
32
- const matches = [];
33
- for (const rule of getEffectiveWorkflowRules()) for (const pattern of rule.patterns) if (pattern.test(query)) {
34
- matches.push(rule);
35
- break;
36
- }
37
- const result = matches.length === 0 ? null : matches.toSorted((a, b) => b.priority - a.priority)[0];
38
- if (_intentCache.size >= INTENT_CACHE_MAX) {
39
- const firstKey = _intentCache.keys().next().value;
40
- if (firstKey !== void 0) _intentCache.delete(firstKey);
41
- }
42
- _intentCache.set(query, result);
43
- return result;
44
- }
45
- function matchWorkflowRoute(query, ctx) {
46
- let bestMatch = null;
47
- for (const [workflowId, runtimeRecord] of ctx.extensionWorkflowRuntimeById.entries()) {
48
- const route = runtimeRecord.route ?? runtimeRecord.workflow.route;
49
- if (!route) continue;
50
- const descriptor = ctx.extensionWorkflowsById.get(workflowId);
51
- const name = descriptor?.displayName ?? runtimeRecord.workflow.displayName;
52
- const description = descriptor?.description ?? runtimeRecord.workflow.description ?? "Workflow route";
53
- for (const pattern of route.triggerPatterns) {
54
- if (!pattern.test(query)) continue;
55
- const confidence = route.priority / 100;
56
- if (!bestMatch || confidence > bestMatch.confidence) bestMatch = {
57
- workflow: {
58
- id: workflowId,
59
- name,
60
- description,
61
- route
62
- },
63
- confidence,
64
- matchedPattern: pattern.source
65
- };
66
- break;
67
- }
68
- }
69
- return bestMatch;
70
- }
71
- function isBrowserOrNetworkTask(task, workflow) {
72
- return workflow?.domain === "browser" || workflow?.domain === "network" || BROWSER_OR_NETWORK_TASK_PATTERN.test(task);
73
- }
74
- function isMaintenanceTask(task) {
75
- return MAINTENANCE_TASK_PATTERN.test(task);
76
- }
77
- //#endregion
78
- //#region src/server/MCPServer.search.validation.ts
79
- /**
80
- * Input validation and tool-name normalization utilities for search meta-tool handlers.
81
- */
82
- function normalizeToolName(name) {
83
- const trimmed = name.trim();
84
- if (!trimmed.startsWith("mcp__")) return trimmed;
85
- const parts = trimmed.split("__");
86
- if (parts.length < 3) return trimmed;
87
- return parts.slice(2).join("__");
88
- }
89
- function validateToolNameArray(args) {
90
- const raw = args.names;
91
- if (!Array.isArray(raw)) return {
92
- names: [],
93
- error: "names must be an array"
94
- };
95
- const names = [];
96
- for (const item of raw) {
97
- if (typeof item !== "string" || item.trim().length === 0) return {
98
- names: [],
99
- error: "invalid tool name: expected non-empty string"
100
- };
101
- names.push(normalizeToolName(item));
102
- }
103
- return { names };
104
- }
105
- //#endregion
106
- //#region src/server/ToolRouter.probe.ts
107
- let _allToolsByName = null;
108
- function getAllToolsByName() {
109
- if (!_allToolsByName) _allToolsByName = new Map(allTools.map((t) => [t.name, t]));
110
- return _allToolsByName;
111
- }
112
- function getToolInputSchema(toolName, ctx) {
113
- const canonicalName = normalizeToolName(toolName);
114
- const builtInTool = getAllToolsByName().get(canonicalName);
115
- if (builtInTool) return builtInTool.inputSchema;
116
- const extTool = ctx.extensionToolsByName.get(canonicalName);
117
- if (extTool) return extTool.tool.inputSchema;
118
- const metaTool = ctx.metaToolsByName.get(canonicalName);
119
- if (metaTool) return metaTool.inputSchema;
120
- }
121
- function getToolDescription(toolName, ctx) {
122
- const canonicalName = normalizeToolName(toolName);
123
- const builtInTool = getAllToolsByName().get(canonicalName);
124
- if (builtInTool?.description) return builtInTool.description.split("\n")[0] || "No description available";
125
- const extTool = ctx.extensionToolsByName.get(canonicalName);
126
- if (extTool?.tool?.description) return extTool.tool.description.split("\n")[0] || "No description available";
127
- const metaTool = ctx.metaToolsByName.get(canonicalName);
128
- if (metaTool?.description) return metaTool.description.split("\n")[0] || "No description available";
129
- return "No description available";
130
- }
131
- function isToolActive(toolName, ctx) {
132
- const canonicalName = normalizeToolName(toolName);
133
- return new Set([...ctx.selectedTools.map((tool) => tool.name), ...ctx.activatedToolNames]).has(canonicalName);
134
- }
135
- function getAvailableToolNames(ctx) {
136
- return new Set([...allTools.map((tool) => tool.name), ...ctx.extensionToolsByName.keys()]);
137
- }
138
- function getToolDomainFromContext(toolName, ctx) {
139
- return getToolDomain(toolName) ?? ctx.extensionToolsByName.get(toolName)?.domain ?? null;
140
- }
141
- async function probeActivePage(ctx) {
142
- if (!ctx.pageController || typeof ctx.pageController.getPage !== "function") return false;
143
- try {
144
- return Boolean(await ctx.pageController.getPage());
145
- } catch {
146
- return false;
147
- }
148
- }
149
- function probeNetworkEnabled(ctx) {
150
- if (!ctx.consoleMonitor) return false;
151
- try {
152
- if (typeof ctx.consoleMonitor.getNetworkStatus === "function") return Boolean(ctx.consoleMonitor.getNetworkStatus().enabled);
153
- if (typeof ctx.consoleMonitor.isNetworkEnabled === "function") return Boolean(ctx.consoleMonitor.isNetworkEnabled());
154
- } catch {}
155
- return false;
156
- }
157
- function probeCapturedRequests(ctx) {
158
- if (!ctx.consoleMonitor || typeof ctx.consoleMonitor.getNetworkRequests !== "function") return 0;
159
- try {
160
- const requests = ctx.consoleMonitor.getNetworkRequests({ limit: 1 });
161
- return Array.isArray(requests) ? requests.length : 0;
162
- } catch {
163
- try {
164
- const requests = ctx.consoleMonitor.getNetworkRequests();
165
- return Array.isArray(requests) ? requests.length : 0;
166
- } catch {
167
- return 0;
168
- }
169
- }
170
- }
171
- async function getRoutingState(ctx) {
172
- return {
173
- hasActivePage: await probeActivePage(ctx),
174
- networkEnabled: probeNetworkEnabled(ctx),
175
- capturedRequestCount: probeCapturedRequests(ctx)
176
- };
177
- }
178
- //#endregion
179
- //#region src/server/ToolRouter.policy.ts
180
- /**
181
- * Build a real runtime check function from the prerequisite condition string.
182
- * Returns true when the prerequisite IS satisfied, false when it is not.
183
- */
184
- function buildPrerequisiteCheck(condition) {
185
- if (condition.includes("Browser must be launched")) return (state) => state.hasActivePage;
186
- if (condition.includes("Network monitoring must be enabled")) return (state) => state.networkEnabled;
187
- if (condition.includes("Debugger must be enabled")) return (state) => state.hasActivePage;
188
- if (condition.includes("Debugger must be attached")) return (state) => state.hasActivePage;
189
- if (condition.includes("Page must be navigated")) return (state) => state.hasActivePage;
190
- if (condition.includes("WebSocket monitoring")) return (state) => state.hasActivePage;
191
- return () => false;
192
- }
193
- let _cachedPrerequisites = null;
194
- /**
195
- * Aggregate prerequisite declarations from domain manifests.
196
- * Cached lazily — manifests are immutable at runtime.
197
- */
198
- function getEffectivePrerequisites() {
199
- if (_cachedPrerequisites) return _cachedPrerequisites;
200
- const merged = {};
201
- for (const m of getAllManifests()) if (m.prerequisites) for (const [toolName, entries] of Object.entries(m.prerequisites)) merged[toolName] = entries.map((e) => ({
202
- condition: e.condition,
203
- check: buildPrerequisiteCheck(e.condition),
204
- fix: e.fix
205
- }));
206
- _cachedPrerequisites = merged;
207
- return _cachedPrerequisites;
208
- }
209
- function buildWorkflowToolSequence(workflow, state, availableToolNames) {
210
- const sequence = [];
211
- const pushIfAvailable = (toolName) => {
212
- if (availableToolNames.has(toolName) && !sequence.includes(toolName)) sequence.push(toolName);
213
- };
214
- if ((workflow.domain === "browser" || workflow.domain === "network") && !state.hasActivePage) {
215
- pushIfAvailable("browser_launch");
216
- pushIfAvailable("browser_attach");
217
- }
218
- if (workflow.domain === "network") {
219
- if (state.hasActivePage && !state.networkEnabled) pushIfAvailable("network_monitor");
220
- if (state.hasActivePage && state.networkEnabled && state.capturedRequestCount > 0) pushIfAvailable("network_get_requests");
221
- }
222
- for (const toolName of workflow.tools) pushIfAvailable(toolName);
223
- if (workflow.domain === "network" && state.hasActivePage && state.networkEnabled) pushIfAvailable("network_get_requests");
224
- return sequence;
225
- }
226
- function buildPresetToolSequence(match, state, availableToolNames) {
227
- const sequence = [];
228
- const seen = /* @__PURE__ */ new Set();
229
- const requiresBrowserSession = match.workflow.route.requiredDomains.includes("browser") || match.workflow.route.requiredDomains.includes("network");
230
- const pushIfAvailable = (toolName, description) => {
231
- if (!availableToolNames.has(toolName) || seen.has(toolName)) return;
232
- seen.add(toolName);
233
- sequence.push({
234
- name: toolName,
235
- description
236
- });
237
- };
238
- if (!state.hasActivePage && requiresBrowserSession) {
239
- pushIfAvailable("browser_launch", "Launch a browser session before executing the preset");
240
- pushIfAvailable("browser_attach", "Attach preset tooling to the active browser session before capture begins");
241
- }
242
- for (const step of match.workflow.route.steps) pushIfAvailable(step.toolName, step.description);
243
- return sequence;
244
- }
245
- function buildPresetRecommendations(match, state, ctx, availableToolNames) {
246
- return buildPresetToolSequence(match, state, availableToolNames).map((plannedTool, index) => ({
247
- name: plannedTool.name,
248
- domain: getToolDomainFromContext(plannedTool.name, ctx),
249
- shortDescription: plannedTool.description,
250
- score: match.workflow.route.priority + match.confidence - index * .01,
251
- isActive: isToolActive(plannedTool.name, ctx)
252
- }));
253
- }
254
- function buildWorkflowRouteRecommendation(match, ctx) {
255
- return {
256
- name: "run_extension_workflow",
257
- domain: getToolDomainFromContext("run_extension_workflow", ctx),
258
- shortDescription: `Execute routed workflow ${match.workflow.name} (${match.workflow.id}) via run_extension_workflow`,
259
- score: match.workflow.route.priority + match.confidence,
260
- isActive: isToolActive("run_extension_workflow", ctx)
261
- };
262
- }
263
- function buildRouteMatchMetadata(match, ctx) {
264
- return {
265
- kind: match.workflow.route.kind,
266
- id: match.workflow.id,
267
- name: match.workflow.name,
268
- description: match.workflow.description,
269
- confidence: match.confidence,
270
- matchedPattern: match.matchedPattern,
271
- requiredDomains: [...match.workflow.route.requiredDomains],
272
- steps: match.workflow.route.steps.map((step) => ({
273
- id: step.id,
274
- toolName: step.toolName,
275
- domain: getToolDomain(step.toolName) ?? ctx.extensionToolsByName.get(step.toolName)?.domain ?? null,
276
- description: step.description,
277
- prerequisites: [...step.prerequisites],
278
- parallel: step.parallel,
279
- isActive: isToolActive(step.toolName, ctx)
280
- }))
281
- };
282
- }
283
- function rerankResultsForContext(results, task, workflow, state) {
284
- const browserOrNetworkTask = isBrowserOrNetworkTask(task, workflow);
285
- const maintenanceTask = isMaintenanceTask(task);
286
- const reranked = results.map((result) => {
287
- let score = result.score;
288
- if (browserOrNetworkTask && !maintenanceTask && result.domain === "maintenance") score *= .1;
289
- if (browserOrNetworkTask) {
290
- if (!state.hasActivePage && result.name === "browser_launch") score *= 1.4;
291
- if (!state.hasActivePage && result.name === "browser_attach") score *= 1.2;
292
- if (state.hasActivePage && !state.networkEnabled && result.name === "network_monitor") score *= 1.35;
293
- if (state.hasActivePage && state.networkEnabled && state.capturedRequestCount > 0 && result.name === "network_get_requests") score *= 1.5;
294
- }
295
- return {
296
- ...result,
297
- score
298
- };
299
- });
300
- reranked.sort((a, b) => b.score - a.score);
301
- return reranked;
302
- }
303
- //#endregion
304
- export { isMaintenanceTask as _, getEffectivePrerequisites as a, getRoutingState as c, getToolInputSchema as d, isToolActive as f, isBrowserOrNetworkTask as g, detectWorkflowIntent as h, buildWorkflowToolSequence as i, getToolDescription as l, validateToolNameArray as m, buildRouteMatchMetadata as n, rerankResultsForContext as o, normalizeToolName as p, buildWorkflowRouteRecommendation as r, getAvailableToolNames as s, buildPresetRecommendations as t, getToolDomainFromContext as u, matchWorkflowRoute as v };