@jshookmcp/jshook 0.3.0 → 0.3.2

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 (346) hide show
  1. package/LICENSE +661 -661
  2. package/README.md +32 -49
  3. package/README.zh.md +32 -47
  4. package/dist/AntiCheatDetector-B6d4Qe9D.mjs +1 -0
  5. package/dist/BrowserSessionCoordinator-BJ-HOxo0.mjs +1 -0
  6. package/dist/CacheAdapters-CsNtQIR8.mjs +1 -0
  7. package/dist/CodeInjector-Cll_7bLJ.mjs +1 -0
  8. package/dist/ConsoleMonitor-CxDJV15E.mjs +306 -0
  9. package/dist/DOMInspector-C19J4zeq.mjs +95 -0
  10. package/dist/DarwinAPI-ZfQdpLNI.mjs +1 -0
  11. package/dist/DetailedDataManager-DmQ1LT-W.mjs +1 -0
  12. package/dist/EventBus-DL8iLA09.mjs +1 -0
  13. package/dist/EvidenceGraphBridge-BtbwXsLC.mjs +1 -0
  14. package/dist/ExtensionManager-BD724zkO.mjs +1 -0
  15. package/dist/ExtensionManager.tools-oVMJgPcN.mjs +1 -0
  16. package/dist/FingerprintManager-DT0EAUEo.mjs +1 -0
  17. package/dist/HardwareBreakpoint-BUfPdp0f.mjs +1 -0
  18. package/dist/HeapAnalyzer-B_aqY8oj.mjs +1 -0
  19. package/dist/{HookGeneratorBuilders.core.generators.storage-CTbB4Lcx.mjs → HookGeneratorBuilders.core.generators.storage-DzD6dIJd.mjs} +66 -101
  20. package/dist/InstrumentationSession-D_G1ZPyd.mjs +1 -0
  21. package/dist/MCPServer.search.handlers.domain-BbS-6LnX.mjs +1 -0
  22. package/dist/MemoryController-X1XNSn1n.mjs +2 -0
  23. package/dist/MemoryScanSession-DG_F-PjE.mjs +1 -0
  24. package/dist/MemoryScanner-g1_L1ub5.mjs +1 -0
  25. package/dist/NativeMemoryManager.impl-DniBe2wf.mjs +1 -0
  26. package/dist/NativeMemoryManager.utils-BHy1P_jM.mjs +1 -0
  27. package/dist/NetworkMonitor-B_-au6aV.mjs +185 -0
  28. package/dist/PEAnalyzer-yWQaGrcx.mjs +1 -0
  29. package/dist/PageController-Dfsm1_o7.mjs +1 -0
  30. package/dist/PointerChainEngine-BhCUkmxY.mjs +1 -0
  31. package/dist/PrerequisiteError-BjCQA-gK.mjs +1 -0
  32. package/dist/ProcessRegistry-C-bN48oR.mjs +1 -0
  33. package/dist/ResponseBuilder-BfWP-uaT.mjs +1 -0
  34. package/dist/ReverseEvidenceGraph-BhSYYdiI.mjs +2 -0
  35. package/dist/RingBuffer-Dm54ELKT.mjs +1 -0
  36. package/dist/ScriptManager-LWGPTdvD.mjs +7 -0
  37. package/dist/ServerRuntimeState-D2bWHqEE.mjs +1 -0
  38. package/dist/Speedhack-yseDPSZ9.mjs +1 -0
  39. package/dist/StealthVerifier-BmcxfwSF.mjs +1 -0
  40. package/dist/StructureAnalyzer-C5lpuZkg.mjs +2 -0
  41. package/dist/ToolCatalog-CYdD9F5f.mjs +1 -0
  42. package/dist/ToolError-DWU_z7gp.mjs +1 -0
  43. package/dist/ToolProbe-C7ZU2x7M.mjs +1 -0
  44. package/dist/ToolRegistry-C5oB8KP8.mjs +1 -0
  45. package/dist/ToolRouter.policy-CfhJczkt.mjs +4 -0
  46. package/dist/TraceRecorder-BiJWBXHX.mjs +272 -0
  47. package/dist/VersionDetector-CHT36Az0.mjs +9 -0
  48. package/dist/Win32API-eUCF57l_.mjs +1 -0
  49. package/dist/Win32Debug-CYrIQBvr.mjs +1 -0
  50. package/dist/WorkflowEngine-D876meOO.mjs +1 -0
  51. package/dist/analysis-D4swdMvq.mjs +6 -0
  52. package/dist/{antidebug-BRKeyt27.mjs → antidebug-7L3ygj_9.mjs} +8 -259
  53. package/dist/apk-packer-BqXcInnX.mjs +1 -0
  54. package/dist/artifactRetention-BCPQASm7.mjs +1 -0
  55. package/dist/artifacts-CkodUM4j.mjs +1 -0
  56. package/dist/authorization-schema-BOFwSXUN.mjs +1 -0
  57. package/dist/betterSqlite3-Brtq-SIQ.mjs +1 -0
  58. package/dist/binary-instrument-DU7V6TUM.mjs +7 -0
  59. package/dist/binary-secrets-PdMVoyt0.mjs +1 -0
  60. package/dist/bind-helpers-m2U8glkF.mjs +1 -0
  61. package/dist/boringssl-inspector-BBaJwwkU.mjs +2 -0
  62. package/dist/browser-Qqco2rOT.mjs +11 -0
  63. package/dist/capabilities-CyXuKUl1.mjs +1 -0
  64. package/dist/chunk-C_pMuVsO.mjs +1 -0
  65. package/dist/collector-Bpl6qy2L.mjs +1 -0
  66. package/dist/concurrency-DCr8WQ2M.mjs +1 -0
  67. package/dist/constants-BYj8Xek8.mjs +1 -0
  68. package/dist/coordination-CWXW1o8K.mjs +1 -0
  69. package/dist/dart-inspector-7AkPeZ_Q.mjs +0 -0
  70. package/dist/debugger-DyALjYMk.mjs +1 -0
  71. package/dist/definitions-BWxBke3r.mjs +1 -0
  72. package/dist/definitions-BYwATKc-.mjs +1 -0
  73. package/dist/definitions-B_83XfNQ.mjs +1 -0
  74. package/dist/definitions-Bf3H1EwV.mjs +1 -0
  75. package/dist/definitions-BftdXgXI.mjs +1 -0
  76. package/dist/definitions-Bio5XJYy.mjs +1 -0
  77. package/dist/definitions-C3qNgSn1.mjs +1 -0
  78. package/dist/definitions-CB6vmOer.mjs +1 -0
  79. package/dist/definitions-CMZRSy3k.mjs +1 -0
  80. package/dist/definitions-CQd7yCQH.mjs +1 -0
  81. package/dist/definitions-CT8ln6GQ.mjs +1 -0
  82. package/dist/definitions-Cenu6mxo.mjs +1 -0
  83. package/dist/definitions-D4g-MS10.mjs +1 -0
  84. package/dist/definitions-D5wl_8HN.mjs +1 -0
  85. package/dist/definitions-DAQm1Xar.mjs +1 -0
  86. package/dist/definitions-DP1vgxEY.mjs +1 -0
  87. package/dist/definitions-DxFNRQNK2.mjs +1 -0
  88. package/dist/definitions-Ibci7e_L.mjs +1 -0
  89. package/dist/definitions-OeLvmlQy.mjs +1 -0
  90. package/dist/definitions-RZYGD_Ey.mjs +1 -0
  91. package/dist/definitions-Tls8c0A0.mjs +1 -0
  92. package/dist/definitions-bybDvnG0.mjs +26 -0
  93. package/dist/definitions-l7TjdE6V.mjs +1 -0
  94. package/dist/encoding-ycOaz8Vr.mjs +2 -0
  95. package/dist/ensure-browser-core-DxWC-NTp.mjs +1 -0
  96. package/dist/evidence-graph-bridge-CV_UdYqj.mjs +1 -0
  97. package/dist/factory-CKr4fAE1.mjs +1 -0
  98. package/dist/flat-target-session-DvcQX7J5.mjs +1 -0
  99. package/dist/formatAddress-vLA_hOJt.mjs +1 -0
  100. package/dist/graphql-B2TiPEow.mjs +62 -0
  101. package/dist/handlers-0yKLRIfo.mjs +2 -0
  102. package/dist/handlers-8zN_vBIz.mjs +1 -0
  103. package/dist/handlers-B62K4FTc.mjs +1 -0
  104. package/dist/handlers-BpDlVVVU.mjs +1 -0
  105. package/dist/handlers-CMJK7m1c.mjs +31 -0
  106. package/dist/handlers-D2ZOul9p.mjs +54 -0
  107. package/dist/handlers-D5E40ssn.mjs +5 -0
  108. package/dist/handlers-DGbdQAgD.mjs +4 -0
  109. package/dist/handlers-DHO3rjsW.mjs +1 -0
  110. package/dist/handlers-FJ80VzUI.mjs +2 -0
  111. package/dist/handlers-VHWrxbM_.mjs +1 -0
  112. package/dist/handlers-l8QIKqBj.mjs +2 -0
  113. package/dist/handlers-mPFiNPe8.mjs +302 -0
  114. package/dist/{handlers-Dz9PYsCa.mjs → handlers-yo_xYzT8.mjs} +118 -904
  115. package/dist/handlers.impl-D9Hh8Bgl.mjs +1 -0
  116. package/dist/hooks-D4XLfgtV.mjs +600 -0
  117. package/dist/index.mjs +13 -5240
  118. package/dist/jadx-search-B_Yse0Zh.mjs +5 -0
  119. package/dist/logger-sBC6IdRT.mjs +1 -0
  120. package/dist/maintenance-BUpIukhg.mjs +1 -0
  121. package/dist/manifest-0Jpt_AQa.mjs +1 -0
  122. package/dist/manifest-B3fZbSWR.mjs +1 -0
  123. package/dist/manifest-B7NB2rh2.mjs +1 -0
  124. package/dist/manifest-BDi4nbH1.mjs +1 -0
  125. package/dist/manifest-BLDfkE7n.mjs +1 -0
  126. package/dist/manifest-BcXbB4gf.mjs +1 -0
  127. package/dist/manifest-Bdnc_vrc.mjs +1 -0
  128. package/dist/manifest-BuYKgCnp.mjs +1 -0
  129. package/dist/manifest-CBfNnGPV.mjs +1 -0
  130. package/dist/manifest-CPS1Xv69.mjs +1 -0
  131. package/dist/manifest-CQH9FhwI.mjs +1 -0
  132. package/dist/manifest-CRryuZF4.mjs +1 -0
  133. package/dist/manifest-CctIumog.mjs +1 -0
  134. package/dist/manifest-CvTe5ZGV2.mjs +1 -0
  135. package/dist/manifest-D-5GH0DV.mjs +1 -0
  136. package/dist/manifest-D3Ssf3IC.mjs +1 -0
  137. package/dist/manifest-D5ck3NvC.mjs +1 -0
  138. package/dist/manifest-D9jUUJAu.mjs +1 -0
  139. package/dist/manifest-DCx6w2XV.mjs +1 -0
  140. package/dist/manifest-DG19q-Ld.mjs +1 -0
  141. package/dist/manifest-DLMlD0Zc.mjs +1 -0
  142. package/dist/manifest-DYpn8w_h.mjs +1 -0
  143. package/dist/manifest-DYzWI8Xs.mjs +1 -0
  144. package/dist/manifest-D_obs5F4.mjs +1 -0
  145. package/dist/manifest-DujQqEQR.mjs +2 -0
  146. package/dist/manifest-DwL2ik8P.mjs +1 -0
  147. package/dist/manifest-ItF5P8A12.mjs +1 -0
  148. package/dist/manifest-KZphqIyX.mjs +1 -0
  149. package/dist/manifest-LG42zPLY2.mjs +1 -0
  150. package/dist/manifest-LLdI5m4T.mjs +1 -0
  151. package/dist/manifest-QYbQXJn0.mjs +1 -0
  152. package/dist/manifest-RcpX_MyZ.mjs +123 -0
  153. package/dist/manifest-YgVd8Sgz.mjs +1 -0
  154. package/dist/manifest-Zy7Odg5J.mjs +1 -0
  155. package/dist/manifest-ff1H7Pdp.mjs +1 -0
  156. package/dist/manifest-iuhF6pTL2.mjs +1 -0
  157. package/dist/manifest-nXHmtMSp2.mjs +1 -0
  158. package/dist/manifest-xWfu6iLo.mjs +1 -0
  159. package/dist/manifest-yC16OhL2.mjs +1 -0
  160. package/dist/manifest-ztWJoXy4.mjs +1 -0
  161. package/dist/matchesWildcardPattern-BAG6LvX5.mjs +1 -0
  162. package/dist/modules-BPBcSaM-.mjs +333 -0
  163. package/dist/mojo-ipc-BhwsdVUW.mjs +9 -0
  164. package/dist/native/scripts/linux/enum-windows.sh +12 -12
  165. package/dist/native/scripts/macos/enum-windows.applescript +22 -22
  166. package/dist/native-j8l473zn.mjs +961 -0
  167. package/dist/network-T0VRwNPd.mjs +7 -0
  168. package/dist/outputPaths-B4Ic4RZh.mjs +2 -0
  169. package/dist/parse-args-Bw413PlW.mjs +1 -0
  170. package/dist/platform-CzaQtISh.mjs +93 -0
  171. package/dist/playwright-cdp-fallback-DqFdx9-s.mjs +1 -0
  172. package/dist/process-CWhsCWrf.mjs +2 -0
  173. package/dist/proxy-DZFlDsG3.mjs +2 -0
  174. package/dist/registry-DH4sc1dt.mjs +1 -0
  175. package/dist/renderer-pid-9tJnZ_9N.mjs +1 -0
  176. package/dist/response-C7rKQst4.mjs +1 -0
  177. package/dist/search-defaults-lYBVn_3L.mjs +1 -0
  178. package/dist/server/plugin-api.d.mts +19 -36
  179. package/dist/server/plugin-api.mjs +1 -293
  180. package/dist/shared-state-board-BSjXLUV1.mjs +1 -0
  181. package/dist/sourcemap-Dh3Ai_ur.mjs +1 -0
  182. package/dist/ssrf-policy-CsIJGkpd.mjs +1 -0
  183. package/dist/streaming-BcJ0B6ao.mjs +1 -0
  184. package/dist/tool-builder-qif8M9-K.mjs +1 -0
  185. package/dist/transform-DOxzeWPB.mjs +103 -0
  186. package/dist/types-D9EiE5o9.mjs +1 -0
  187. package/dist/types-Fz69RzbZ.mjs +1 -0
  188. package/dist/wasm-CZ_HTfKR.mjs +174 -0
  189. package/dist/webcrack-C1iYG_EX.mjs +46 -0
  190. package/dist/workflow-BdwQmARn.mjs +101 -0
  191. package/package.json +55 -82
  192. package/src/native/scripts/linux/enum-windows.sh +12 -12
  193. package/src/native/scripts/macos/enum-windows.applescript +22 -22
  194. package/dist/AntiCheatDetector-CqGDXmfc.mjs +0 -350
  195. package/dist/CacheAdapters-jJFy20G-.mjs +0 -80
  196. package/dist/CodeInjector-BdjRfNx7.mjs +0 -150
  197. package/dist/ConsoleMonitor-DykL3IAw.mjs +0 -2269
  198. package/dist/DarwinAPI-ETyy0xyo.mjs +0 -363
  199. package/dist/DetailedDataManager-HT49OrvF.mjs +0 -217
  200. package/dist/EventBus-DFKvADm3.mjs +0 -141
  201. package/dist/EvidenceGraphBridge-318Oi0Lf.mjs +0 -153
  202. package/dist/ExtensionManager-BDMsY2Dz.mjs +0 -721
  203. package/dist/FingerprintManager-BN4UQWnX.mjs +0 -96
  204. package/dist/HardwareBreakpoint-Cc2AFq1Y.mjs +0 -239
  205. package/dist/HeapAnalyzer-DruMgsgj.mjs +0 -284
  206. package/dist/InstrumentationSession-DLH0vd-z.mjs +0 -244
  207. package/dist/MemoryController-CMtviNW_.mjs +0 -167
  208. package/dist/MemoryScanSession-ITgb_NMi.mjs +0 -278
  209. package/dist/MemoryScanner-CiL7Z3ey.mjs +0 -428
  210. package/dist/NativeMemoryManager.impl-D9Lkovvn.mjs +0 -485
  211. package/dist/NativeMemoryManager.utils-BBlAixF5.mjs +0 -165
  212. package/dist/PEAnalyzer-DMQ44gen.mjs +0 -385
  213. package/dist/PageController-BPJNqqBN.mjs +0 -431
  214. package/dist/PointerChainEngine-K7wN8Z-w.mjs +0 -325
  215. package/dist/PrerequisiteError-TuyZIs6n.mjs +0 -20
  216. package/dist/ProcessRegistry-zGg12QbE.mjs +0 -74
  217. package/dist/ResponseBuilder-CJXWmWNw.mjs +0 -143
  218. package/dist/ReverseEvidenceGraph-C02-gXOh.mjs +0 -269
  219. package/dist/ScriptManager-ZuWD-0Jg.mjs +0 -3003
  220. package/dist/Speedhack-D-z0umeT.mjs +0 -156
  221. package/dist/StealthVerifier-BWmPgQsv.mjs +0 -135
  222. package/dist/StructureAnalyzer-Cav5AVSL.mjs +0 -429
  223. package/dist/ToolCatalog-5OJdMiF0.mjs +0 -582
  224. package/dist/ToolError-jh9whhMd.mjs +0 -15
  225. package/dist/ToolProbe-DbCFGyrg.mjs +0 -45
  226. package/dist/ToolRegistry-B9krbTtI.mjs +0 -180
  227. package/dist/ToolRouter.policy-BGDAGyeH.mjs +0 -344
  228. package/dist/TraceRecorder-B41Z5XBj.mjs +0 -1286
  229. package/dist/VersionDetector-K3V4vGsw.mjs +0 -104
  230. package/dist/Win32API-C2kjj0ze.mjs +0 -346
  231. package/dist/Win32Debug-CKrGOTpo.mjs +0 -274
  232. package/dist/WorkflowEngine-DJ6M4opp.mjs +0 -569
  233. package/dist/analysis-BHeJW2Nb.mjs +0 -1234
  234. package/dist/artifactRetention-CPXkUJXp.mjs +0 -598
  235. package/dist/artifacts-DkfosXH3.mjs +0 -59
  236. package/dist/authorization-schema-DRqyJMSk.mjs +0 -31
  237. package/dist/betterSqlite3-DLSBZodi.mjs +0 -74
  238. package/dist/binary-instrument--V3MAhJ4.mjs +0 -971
  239. package/dist/bind-helpers-ClV34xdn.mjs +0 -42
  240. package/dist/boringssl-inspector-Bo_LOLaS.mjs +0 -180
  241. package/dist/browser-Dx3_S2cG.mjs +0 -4369
  242. package/dist/capabilities-CcHlvWgK.mjs +0 -33
  243. package/dist/chunk-CjcI7cDX.mjs +0 -15
  244. package/dist/concurrency-Drev_Vz9.mjs +0 -41
  245. package/dist/constants-CDZLOoVv.mjs +0 -534
  246. package/dist/coordination-DgItD9DL.mjs +0 -259
  247. package/dist/debugger-RS3RSAqs.mjs +0 -1288
  248. package/dist/definitions-BEoYofW5.mjs +0 -47
  249. package/dist/definitions-BRaefg3u.mjs +0 -365
  250. package/dist/definitions-BbkvZkiv.mjs +0 -96
  251. package/dist/definitions-BtWSHJ3o.mjs +0 -17
  252. package/dist/definitions-C1gCHO0i.mjs +0 -43
  253. package/dist/definitions-CDOg_b-l.mjs +0 -138
  254. package/dist/definitions-CVPD9hzZ.mjs +0 -54
  255. package/dist/definitions-Cea8Lgl7.mjs +0 -94
  256. package/dist/definitions-DAgIyjxM.mjs +0 -10
  257. package/dist/definitions-DJA27nsL.mjs +0 -66
  258. package/dist/definitions-DKPFU3LW.mjs +0 -25
  259. package/dist/definitions-DPRpZQ96.mjs +0 -47
  260. package/dist/definitions-DUE5gmdn.mjs +0 -18
  261. package/dist/definitions-DYVjOtxa.mjs +0 -26
  262. package/dist/definitions-DcYLVLCo.mjs +0 -37
  263. package/dist/definitions-Pp5LI2H4.mjs +0 -27
  264. package/dist/definitions-j9KdHVNR.mjs +0 -14
  265. package/dist/definitions-uzkjBwa7.mjs +0 -258
  266. package/dist/definitions-va-AnLuQ.mjs +0 -28
  267. package/dist/encoding-DJeqHmpd.mjs +0 -1079
  268. package/dist/evidence-graph-bridge-DcYizFk2.mjs +0 -136
  269. package/dist/factory-C90tBff6.mjs +0 -575
  270. package/dist/flat-target-session-Dgax2Cy3.mjs +0 -29
  271. package/dist/formatAddress-nnMvEohD.mjs +0 -17
  272. package/dist/graphql-CoHrhweh.mjs +0 -1197
  273. package/dist/handlers-4jmR0nMs.mjs +0 -898
  274. package/dist/handlers-BAHPxcch.mjs +0 -789
  275. package/dist/handlers-BOs9b907.mjs +0 -2600
  276. package/dist/handlers-BWXEy6ef.mjs +0 -917
  277. package/dist/handlers-Bndn6QvE.mjs +0 -111
  278. package/dist/handlers-BqC4bD4s.mjs +0 -681
  279. package/dist/handlers-BtYq60bM2.mjs +0 -276
  280. package/dist/handlers-BzgcB4iv.mjs +0 -799
  281. package/dist/handlers-CRyRWj2b.mjs +0 -859
  282. package/dist/handlers-CVv2H1uq.mjs +0 -592
  283. package/dist/handlers-Dl5a7JS4.mjs +0 -572
  284. package/dist/handlers-Dx2d7jt7.mjs +0 -2537
  285. package/dist/handlers-HujRKC3b.mjs +0 -661
  286. package/dist/handlers.impl-XWXkQfyi.mjs +0 -807
  287. package/dist/hooks-B1B8NRHL.mjs +0 -898
  288. package/dist/logger-Dh_xb7_2.mjs +0 -93
  289. package/dist/maintenance-PRMkLVRW.mjs +0 -835
  290. package/dist/manifest-67Bok-Si.mjs +0 -58
  291. package/dist/manifest-6lNTMZAB2.mjs +0 -87
  292. package/dist/manifest-B2duEHiH.mjs +0 -90
  293. package/dist/manifest-B6EY9Vm8.mjs +0 -57
  294. package/dist/manifest-B6nKSbyY.mjs +0 -95
  295. package/dist/manifest-BL8AQNPF.mjs +0 -106
  296. package/dist/manifest-BSZvJJmV.mjs +0 -47
  297. package/dist/manifest-BU7qzUyX.mjs +0 -418
  298. package/dist/manifest-Bl62e8WK.mjs +0 -49
  299. package/dist/manifest-Bo5cXjdt.mjs +0 -82
  300. package/dist/manifest-BpS4gtUK.mjs +0 -1347
  301. package/dist/manifest-Bv65_e2W.mjs +0 -101
  302. package/dist/manifest-BytNIF4Z.mjs +0 -117
  303. package/dist/manifest-C-xtsjS3.mjs +0 -81
  304. package/dist/manifest-CDYl7OhA.mjs +0 -66
  305. package/dist/manifest-CRZ3xmkD.mjs +0 -61
  306. package/dist/manifest-CoW6u4Tp.mjs +0 -132
  307. package/dist/manifest-Cq5zN_8A.mjs +0 -50
  308. package/dist/manifest-D7YZM_2e.mjs +0 -194
  309. package/dist/manifest-DE_VrAeQ.mjs +0 -314
  310. package/dist/manifest-DGsXSCpT.mjs +0 -39
  311. package/dist/manifest-DJ2vfEuW.mjs +0 -156
  312. package/dist/manifest-DPXDYhEu.mjs +0 -80
  313. package/dist/manifest-Dd4fQb0a.mjs +0 -322
  314. package/dist/manifest-Deq6opGg.mjs +0 -223
  315. package/dist/manifest-DfJTafJK.mjs +0 -37
  316. package/dist/manifest-DgOdgN_j.mjs +0 -50
  317. package/dist/manifest-DlbMW4v4.mjs +0 -47
  318. package/dist/manifest-DmVfbH0w.mjs +0 -374
  319. package/dist/manifest-Dog6Ddjr.mjs +0 -109
  320. package/dist/manifest-DvgU5FWb.mjs +0 -58
  321. package/dist/manifest-HsfDBs7j.mjs +0 -50
  322. package/dist/manifest-I8oQHvCG.mjs +0 -186
  323. package/dist/manifest-NvH_a-av.mjs +0 -786
  324. package/dist/manifest-cEJU1v0Z.mjs +0 -129
  325. package/dist/manifest-wOl5XLB12.mjs +0 -112
  326. package/dist/modules-tZozf0LQ.mjs +0 -10635
  327. package/dist/mojo-ipc-DXNEXEqb.mjs +0 -640
  328. package/dist/network-CPVvwvFg.mjs +0 -3852
  329. package/dist/outputPaths-um7lCRY3.mjs +0 -1141
  330. package/dist/parse-args-B4cY5Vx5.mjs +0 -39
  331. package/dist/platform-CYeFoTWp.mjs +0 -2161
  332. package/dist/process-BTbgcVc6.mjs +0 -1306
  333. package/dist/proxy-r8YN6nP1.mjs +0 -192
  334. package/dist/registry-Bl8ZQW61.mjs +0 -34
  335. package/dist/response-CWhh2aLo.mjs +0 -34
  336. package/dist/shared-state-board-BoZnSoj-.mjs +0 -586
  337. package/dist/sourcemap-BIDHUVXy.mjs +0 -934
  338. package/dist/ssrf-policy-Dsqd-DTX.mjs +0 -166
  339. package/dist/streaming-Dal6utPp.mjs +0 -725
  340. package/dist/tool-builder-BHJp32mV.mjs +0 -186
  341. package/dist/transform-DRVgGG90.mjs +0 -1011
  342. package/dist/types-Bx92KJfT.mjs +0 -4
  343. package/dist/types-DDBWs9UP.mjs +0 -37
  344. package/dist/wasm-BYx5UOeG.mjs +0 -1044
  345. package/dist/webcrack-Be0_FccV.mjs +0 -747
  346. package/dist/workflow-BpuKEtvn.mjs +0 -725
@@ -1,180 +0,0 @@
1
- import { t as logger } from "./logger-Dh_xb7_2.mjs";
2
- import { J as EXTERNAL_TOOL_PROBE_CACHE_TTL_MS } from "./constants-CDZLOoVv.mjs";
3
- import { t as probeCommand } from "./ToolProbe-DbCFGyrg.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: "wabt.wasm2c",
34
- command: "wasm2c",
35
- versionArgs: ["--version"],
36
- required: false,
37
- envAllowlist: []
38
- },
39
- {
40
- name: "binaryen.wasm-opt",
41
- command: "wasm-opt",
42
- versionArgs: ["--version"],
43
- required: false,
44
- envAllowlist: []
45
- },
46
- {
47
- name: "runtime.wasmtime",
48
- command: "wasmtime",
49
- versionArgs: ["--version"],
50
- required: false,
51
- envAllowlist: []
52
- },
53
- {
54
- name: "runtime.wasmer",
55
- command: "wasmer",
56
- versionArgs: ["--version"],
57
- required: false,
58
- envAllowlist: []
59
- },
60
- {
61
- name: "miniapp.unpacker",
62
- command: "unveilr",
63
- versionArgs: ["--version"],
64
- required: false,
65
- envAllowlist: []
66
- },
67
- {
68
- name: "platform.jadx",
69
- command: "jadx",
70
- versionArgs: ["--version"],
71
- required: false,
72
- envAllowlist: []
73
- },
74
- {
75
- name: "analysis.ast-grep",
76
- command: "ast-grep",
77
- versionArgs: ["--version"],
78
- required: false,
79
- envAllowlist: []
80
- },
81
- {
82
- name: "analysis.wakaru",
83
- command: "wakaru",
84
- versionArgs: ["--version"],
85
- required: false,
86
- envAllowlist: []
87
- },
88
- {
89
- name: "analysis.restringer",
90
- command: "restringer",
91
- versionArgs: ["--version"],
92
- required: false,
93
- envAllowlist: []
94
- },
95
- {
96
- name: "analysis.z3",
97
- command: "z3",
98
- versionArgs: ["--version"],
99
- required: false,
100
- envAllowlist: []
101
- },
102
- {
103
- name: "syscall.strace",
104
- command: "strace",
105
- versionArgs: ["--version"],
106
- required: false,
107
- envAllowlist: []
108
- },
109
- {
110
- name: "syscall.bpftrace",
111
- command: "bpftrace",
112
- versionArgs: ["--version"],
113
- required: false,
114
- envAllowlist: []
115
- }
116
- ];
117
- var ToolRegistry = class {
118
- specs = /* @__PURE__ */ new Map();
119
- probeCache = /* @__PURE__ */ new Map();
120
- probeCacheExpiry = 0;
121
- PROBE_CACHE_TTL = EXTERNAL_TOOL_PROBE_CACHE_TTL_MS;
122
- constructor(additionalSpecs) {
123
- for (const spec of DEFAULT_SPECS) this.specs.set(spec.name, spec);
124
- if (additionalSpecs) for (const spec of additionalSpecs) this.specs.set(spec.name, spec);
125
- }
126
- /**
127
- * Get the spec for a tool. Throws if not registered.
128
- */
129
- getSpec(name) {
130
- const spec = this.specs.get(name);
131
- if (!spec) throw new Error(`Tool '${name}' is not registered in the allowlist`);
132
- return spec;
133
- }
134
- /**
135
- * Check if a tool name is registered.
136
- */
137
- isRegistered(name) {
138
- return this.specs.has(name);
139
- }
140
- /**
141
- * Get all registered tool names.
142
- */
143
- getRegisteredTools() {
144
- return Array.from(this.specs.keys());
145
- }
146
- /**
147
- * Probe all registered tools for availability. Results are cached.
148
- */
149
- async probeAll(force = false) {
150
- const now = Date.now();
151
- if (!force && this.probeCache.size > 0 && now < this.probeCacheExpiry) return Object.fromEntries(this.probeCache);
152
- const results = {};
153
- const promises = [];
154
- for (const [name, spec] of this.specs) promises.push(probeCommand(spec.command, spec.versionArgs).then((result) => {
155
- results[name] = result;
156
- this.probeCache.set(name, result);
157
- }));
158
- await Promise.all(promises);
159
- this.probeCacheExpiry = now + this.PROBE_CACHE_TTL;
160
- const available = Object.values(results).filter((r) => r.available).length;
161
- logger.info(`[ToolRegistry] Probed ${this.specs.size} tools: ${available} available`);
162
- return results;
163
- }
164
- /**
165
- * Get cached probe result for a specific tool.
166
- */
167
- getCachedProbe(name) {
168
- return this.probeCache.get(name);
169
- }
170
- /**
171
- * Register a new tool spec at runtime.
172
- */
173
- register(spec) {
174
- this.specs.set(spec.name, spec);
175
- this.probeCache.delete(spec.name);
176
- logger.debug(`[ToolRegistry] Registered tool: ${spec.name} -> ${spec.command}`);
177
- }
178
- };
179
- //#endregion
180
- export { ToolRegistry as t };
@@ -1,344 +0,0 @@
1
- import { f as getAllManifests, r as getToolDomain, t as allTools } from "./ToolCatalog-5OJdMiF0.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
- const STATELESS_COMPUTE_TASK_PATTERN = /(stateless|deterministic|pure compute|offline|decode|encode|hex|base64|protobuf|msgpack|checksum|hash|payload|frame|packet|bytes?|bytecode|pcap|protocol|state machine|field inference|ast transform|crypto harness|无状态|确定性|纯算|离线|解码|编码|十六进制|校验和|载荷|字节|协议|报文|帧|字段推断|状态机|构包)/i;
6
- let cachedWorkflowRules = null;
7
- const intentCache = /* @__PURE__ */ new Map();
8
- const INTENT_CACHE_MAX = 64;
9
- /**
10
- * Aggregate workflow rules declared by domain manifests.
11
- * All routing metadata is now declared in each domain's manifest.ts,
12
- * following the open-closed principle (no hardcoded rules here).
13
- *
14
- * Cached lazily — manifests are immutable at runtime.
15
- */
16
- function getEffectiveWorkflowRules() {
17
- if (cachedWorkflowRules) return cachedWorkflowRules;
18
- const rules = [];
19
- for (const m of getAllManifests()) if (m.workflowRule) rules.push({
20
- patterns: [...m.workflowRule.patterns],
21
- domain: m.domain,
22
- priority: m.workflowRule.priority,
23
- tools: [...m.workflowRule.tools],
24
- hint: m.workflowRule.hint
25
- });
26
- cachedWorkflowRules = [...rules].toSorted((a, b) => b.priority - a.priority);
27
- intentCache.clear();
28
- return cachedWorkflowRules;
29
- }
30
- function detectWorkflowIntent(query) {
31
- const cached = intentCache.get(query);
32
- if (cached !== void 0) return cached;
33
- const matches = [];
34
- for (const rule of getEffectiveWorkflowRules()) for (const pattern of rule.patterns) if (pattern.test(query)) {
35
- matches.push(rule);
36
- break;
37
- }
38
- const result = matches.length === 0 ? null : matches.toSorted((a, b) => b.priority - a.priority)[0];
39
- if (intentCache.size >= INTENT_CACHE_MAX) {
40
- const firstKey = intentCache.keys().next().value;
41
- if (firstKey !== void 0) intentCache.delete(firstKey);
42
- }
43
- intentCache.set(query, result);
44
- return result;
45
- }
46
- function matchWorkflowRoute(query, ctx) {
47
- let bestMatch = null;
48
- for (const [workflowId, runtimeRecord] of ctx.extensionWorkflowRuntimeById.entries()) {
49
- const route = runtimeRecord.route ?? runtimeRecord.workflow.route;
50
- if (!route) continue;
51
- const descriptor = ctx.extensionWorkflowsById.get(workflowId);
52
- const name = descriptor?.displayName ?? runtimeRecord.workflow.displayName;
53
- const description = descriptor?.description ?? runtimeRecord.workflow.description ?? "Workflow route";
54
- for (const pattern of route.triggerPatterns) {
55
- if (!pattern.test(query)) continue;
56
- const confidence = route.priority / 100;
57
- if (!bestMatch || confidence > bestMatch.confidence) bestMatch = {
58
- workflow: {
59
- id: workflowId,
60
- name,
61
- description,
62
- route
63
- },
64
- confidence,
65
- matchedPattern: pattern.source
66
- };
67
- break;
68
- }
69
- }
70
- return bestMatch;
71
- }
72
- function isBrowserOrNetworkTask(task, workflow) {
73
- if (workflow?.domain !== "browser" && workflow?.domain !== "network" && isStatelessComputeTask(task)) return false;
74
- return workflow?.domain === "browser" || workflow?.domain === "network" || BROWSER_OR_NETWORK_TASK_PATTERN.test(task);
75
- }
76
- function isMaintenanceTask(task) {
77
- return MAINTENANCE_TASK_PATTERN.test(task);
78
- }
79
- function isStatelessComputeTask(task) {
80
- return STATELESS_COMPUTE_TASK_PATTERN.test(task);
81
- }
82
- //#endregion
83
- //#region src/server/MCPServer.search.validation.ts
84
- /**
85
- * Input validation and tool-name normalization utilities for search meta-tool handlers.
86
- */
87
- function normalizeToolName(name) {
88
- const trimmed = name.trim();
89
- if (!trimmed.startsWith("mcp__")) return trimmed;
90
- const parts = trimmed.split("__");
91
- if (parts.length < 3) return trimmed;
92
- return parts.slice(2).join("__");
93
- }
94
- function validateToolNameArray(args) {
95
- const raw = args.names;
96
- if (!Array.isArray(raw)) return {
97
- names: [],
98
- error: "names must be an array"
99
- };
100
- const names = [];
101
- for (const item of raw) {
102
- if (typeof item !== "string" || item.trim().length === 0) return {
103
- names: [],
104
- error: "invalid tool name: expected non-empty string"
105
- };
106
- names.push(normalizeToolName(item));
107
- }
108
- return { names };
109
- }
110
- //#endregion
111
- //#region src/server/ToolRouter.probe.ts
112
- let allToolsByNameCache = null;
113
- function getAllToolsByName() {
114
- if (!allToolsByNameCache) allToolsByNameCache = new Map(allTools.map((t) => [t.name, t]));
115
- return allToolsByNameCache;
116
- }
117
- function getToolInputSchema(toolName, ctx) {
118
- const canonicalName = normalizeToolName(toolName);
119
- const builtInTool = getAllToolsByName().get(canonicalName);
120
- if (builtInTool) return builtInTool.inputSchema;
121
- const extTool = ctx.extensionToolsByName.get(canonicalName);
122
- if (extTool) return extTool.tool.inputSchema;
123
- const metaTool = ctx.metaToolsByName.get(canonicalName);
124
- if (metaTool) return metaTool.inputSchema;
125
- }
126
- function getToolDescription(toolName, ctx) {
127
- const canonicalName = normalizeToolName(toolName);
128
- const builtInTool = getAllToolsByName().get(canonicalName);
129
- if (builtInTool?.description) return builtInTool.description.split("\n")[0] || "No description available";
130
- const extTool = ctx.extensionToolsByName.get(canonicalName);
131
- if (extTool?.tool?.description) return extTool.tool.description.split("\n")[0] || "No description available";
132
- const metaTool = ctx.metaToolsByName.get(canonicalName);
133
- if (metaTool?.description) return metaTool.description.split("\n")[0] || "No description available";
134
- return "No description available";
135
- }
136
- function isToolActive(toolName, ctx) {
137
- const canonicalName = normalizeToolName(toolName);
138
- return new Set([...ctx.selectedTools.map((tool) => tool.name), ...ctx.activatedToolNames]).has(canonicalName);
139
- }
140
- function getAvailableToolNames(ctx) {
141
- return new Set([...allTools.map((tool) => tool.name), ...ctx.extensionToolsByName.keys()]);
142
- }
143
- function getToolDomainFromContext(toolName, ctx) {
144
- return getToolDomain(toolName) ?? ctx.extensionToolsByName.get(toolName)?.domain ?? null;
145
- }
146
- async function probeActivePage(ctx) {
147
- if (!ctx.pageController || typeof ctx.pageController.getPage !== "function") return false;
148
- try {
149
- return Boolean(await ctx.pageController.getPage());
150
- } catch {
151
- return false;
152
- }
153
- }
154
- function probeNetworkEnabled(ctx) {
155
- if (!ctx.consoleMonitor) return false;
156
- try {
157
- if (typeof ctx.consoleMonitor.getNetworkStatus === "function") return Boolean(ctx.consoleMonitor.getNetworkStatus().enabled);
158
- if (typeof ctx.consoleMonitor.isNetworkEnabled === "function") return Boolean(ctx.consoleMonitor.isNetworkEnabled());
159
- } catch {}
160
- return false;
161
- }
162
- function probeCapturedRequests(ctx) {
163
- if (!ctx.consoleMonitor || typeof ctx.consoleMonitor.getNetworkRequests !== "function") return 0;
164
- try {
165
- const requests = ctx.consoleMonitor.getNetworkRequests({ limit: 1 });
166
- return Array.isArray(requests) ? requests.length : 0;
167
- } catch {
168
- try {
169
- const requests = ctx.consoleMonitor.getNetworkRequests();
170
- return Array.isArray(requests) ? requests.length : 0;
171
- } catch {
172
- return 0;
173
- }
174
- }
175
- }
176
- async function getRoutingState(ctx) {
177
- return {
178
- hasActivePage: await probeActivePage(ctx),
179
- networkEnabled: probeNetworkEnabled(ctx),
180
- capturedRequestCount: probeCapturedRequests(ctx)
181
- };
182
- }
183
- //#endregion
184
- //#region src/server/ToolRouter.policy.ts
185
- function buildStatelessComputeSequence(task, availableToolNames) {
186
- if (!isStatelessComputeTask(task)) return [];
187
- const candidates = [];
188
- const pushIfAvailable = (name, description) => {
189
- if (availableToolNames.has(name) && !candidates.some((item) => item.name === name)) candidates.push({
190
- name,
191
- description
192
- });
193
- };
194
- pushIfAvailable("binary_detect_format", "Detect the payload encoding or container before decoding");
195
- pushIfAvailable("binary_decode", "Decode the payload into deterministic offline bytes or structured output");
196
- pushIfAvailable("proto_auto_detect", "Infer a likely protocol layout from repeated payload samples");
197
- pushIfAvailable("proto_infer_fields", "Derive stable field boundaries and candidate semantics");
198
- pushIfAvailable("proto_infer_state_machine", "Infer request/response state transitions from repeated samples");
199
- pushIfAvailable("crypto_test_harness", "Validate extracted signing or crypto logic with deterministic test vectors");
200
- pushIfAvailable("crypto_compare", "Compare competing crypto implementations against the same vectors");
201
- pushIfAvailable("network_get_requests", "Collect request or response samples only if payload bytes still need to be extracted");
202
- return candidates;
203
- }
204
- /**
205
- * Build a real runtime check function from the prerequisite condition string.
206
- * Returns true when the prerequisite IS satisfied, false when it is not.
207
- */
208
- function buildPrerequisiteCheck(condition) {
209
- if (condition.includes("Browser must be launched")) return (state) => state.hasActivePage;
210
- if (condition.includes("Network monitoring must be enabled")) return (state) => state.networkEnabled;
211
- if (condition.includes("Debugger must be enabled")) return (state) => state.hasActivePage;
212
- if (condition.includes("Debugger must be attached")) return (state) => state.hasActivePage;
213
- if (condition.includes("Page must be navigated")) return (state) => state.hasActivePage;
214
- if (condition.includes("WebSocket monitoring")) return (state) => state.hasActivePage;
215
- return () => false;
216
- }
217
- let cachedPrerequisites = null;
218
- /**
219
- * Aggregate prerequisite declarations from domain manifests.
220
- * Cached lazily — manifests are immutable at runtime.
221
- */
222
- function getEffectivePrerequisites() {
223
- if (cachedPrerequisites) return cachedPrerequisites;
224
- const merged = {};
225
- for (const m of getAllManifests()) if (m.prerequisites) for (const [toolName, entries] of Object.entries(m.prerequisites)) merged[toolName] = entries.map((e) => ({
226
- condition: e.condition,
227
- check: buildPrerequisiteCheck(e.condition),
228
- fix: e.fix
229
- }));
230
- cachedPrerequisites = merged;
231
- return cachedPrerequisites;
232
- }
233
- function buildWorkflowToolSequence(workflow, state, availableToolNames) {
234
- const sequence = [];
235
- const pushIfAvailable = (toolName) => {
236
- if (availableToolNames.has(toolName) && !sequence.includes(toolName)) sequence.push(toolName);
237
- };
238
- if ((workflow.domain === "browser" || workflow.domain === "network") && !state.hasActivePage) {
239
- pushIfAvailable("browser_launch");
240
- pushIfAvailable("browser_attach");
241
- }
242
- if (workflow.domain === "network") {
243
- if (state.hasActivePage && !state.networkEnabled) pushIfAvailable("network_monitor");
244
- if (state.hasActivePage && state.networkEnabled && state.capturedRequestCount > 0) pushIfAvailable("network_get_requests");
245
- }
246
- for (const toolName of workflow.tools) pushIfAvailable(toolName);
247
- if (workflow.domain === "network" && state.hasActivePage && state.networkEnabled) pushIfAvailable("network_get_requests");
248
- return sequence;
249
- }
250
- function buildPresetToolSequence(match, state, availableToolNames) {
251
- const sequence = [];
252
- const seen = /* @__PURE__ */ new Set();
253
- const requiresBrowserSession = match.workflow.route.requiredDomains.includes("browser") || match.workflow.route.requiredDomains.includes("network");
254
- const pushIfAvailable = (toolName, description) => {
255
- if (!availableToolNames.has(toolName) || seen.has(toolName)) return;
256
- seen.add(toolName);
257
- sequence.push({
258
- name: toolName,
259
- description
260
- });
261
- };
262
- if (!state.hasActivePage && requiresBrowserSession) {
263
- pushIfAvailable("browser_launch", "Launch a browser session before executing the preset");
264
- pushIfAvailable("browser_attach", "Attach preset tooling to the active browser session before capture begins");
265
- }
266
- for (const step of match.workflow.route.steps) pushIfAvailable(step.toolName, step.description);
267
- return sequence;
268
- }
269
- function buildPresetRecommendations(match, state, ctx, availableToolNames) {
270
- return buildPresetToolSequence(match, state, availableToolNames).map((plannedTool, index) => ({
271
- name: plannedTool.name,
272
- domain: getToolDomainFromContext(plannedTool.name, ctx),
273
- shortDescription: plannedTool.description,
274
- score: match.workflow.route.priority + match.confidence - index * .01,
275
- isActive: isToolActive(plannedTool.name, ctx)
276
- }));
277
- }
278
- function buildStatelessComputeRecommendations(task, ctx, availableToolNames) {
279
- return buildStatelessComputeSequence(task, availableToolNames).map((plannedTool, index) => ({
280
- name: plannedTool.name,
281
- domain: getToolDomainFromContext(plannedTool.name, ctx),
282
- shortDescription: plannedTool.description,
283
- score: 90 - index * .01,
284
- isActive: isToolActive(plannedTool.name, ctx)
285
- }));
286
- }
287
- function buildWorkflowRouteRecommendation(match, ctx) {
288
- return {
289
- name: "run_extension_workflow",
290
- domain: getToolDomainFromContext("run_extension_workflow", ctx),
291
- shortDescription: `Execute routed workflow ${match.workflow.name} (${match.workflow.id}) via run_extension_workflow`,
292
- score: match.workflow.route.priority + match.confidence,
293
- isActive: isToolActive("run_extension_workflow", ctx)
294
- };
295
- }
296
- function buildRouteMatchMetadata(match, ctx) {
297
- return {
298
- kind: match.workflow.route.kind,
299
- id: match.workflow.id,
300
- name: match.workflow.name,
301
- description: match.workflow.description,
302
- confidence: match.confidence,
303
- matchedPattern: match.matchedPattern,
304
- requiredDomains: [...match.workflow.route.requiredDomains],
305
- steps: match.workflow.route.steps.map((step) => ({
306
- id: step.id,
307
- toolName: step.toolName,
308
- domain: getToolDomain(step.toolName) ?? ctx.extensionToolsByName.get(step.toolName)?.domain ?? null,
309
- description: step.description,
310
- prerequisites: [...step.prerequisites],
311
- parallel: step.parallel,
312
- isActive: isToolActive(step.toolName, ctx)
313
- }))
314
- };
315
- }
316
- function rerankResultsForContext(results, task, workflow, state) {
317
- const browserOrNetworkTask = isBrowserOrNetworkTask(task, workflow);
318
- const maintenanceTask = isMaintenanceTask(task);
319
- const statelessComputeTask = isStatelessComputeTask(task);
320
- const reranked = results.map((result) => {
321
- let score = result.score;
322
- if (browserOrNetworkTask && !maintenanceTask && result.domain === "maintenance") score *= .1;
323
- if (statelessComputeTask) {
324
- if (result.domain === "browser" || result.domain === "network" || result.domain === "debugger" || result.domain === "hooks" || result.domain === "maintenance") score *= .35;
325
- if (result.domain === "core" || result.domain === "streaming" || result.domain === "workflow") score *= .2;
326
- if (result.domain === "encoding" || result.domain === "transform" || result.domain === "protocol-analysis" || result.domain === "sourcemap" || result.domain === "core") score *= 1.6;
327
- if (result.name === "binary_detect_format" || result.name === "binary_decode" || result.name === "crypto_test_harness" || result.name === "ast_transform_apply" || result.name === "proto_auto_detect" || result.name === "proto_infer_fields" || result.name === "proto_infer_state_machine" || result.name === "proto_fingerprint") score *= 1.25;
328
- }
329
- if (browserOrNetworkTask) {
330
- if (!state.hasActivePage && result.name === "browser_launch") score *= 1.4;
331
- if (!state.hasActivePage && result.name === "browser_attach") score *= 1.2;
332
- if (state.hasActivePage && !state.networkEnabled && result.name === "network_monitor") score *= 1.35;
333
- if (state.hasActivePage && state.networkEnabled && state.capturedRequestCount > 0 && result.name === "network_get_requests") score *= 1.5;
334
- }
335
- return {
336
- ...result,
337
- score
338
- };
339
- });
340
- reranked.sort((a, b) => b.score - a.score);
341
- return reranked;
342
- }
343
- //#endregion
344
- export { isBrowserOrNetworkTask as _, buildWorkflowToolSequence as a, matchWorkflowRoute as b, getAvailableToolNames as c, getToolDomainFromContext as d, getToolInputSchema as f, detectWorkflowIntent as g, validateToolNameArray as h, buildWorkflowRouteRecommendation as i, getRoutingState as l, normalizeToolName as m, buildRouteMatchMetadata as n, getEffectivePrerequisites as o, isToolActive as p, buildStatelessComputeRecommendations as r, rerankResultsForContext as s, buildPresetRecommendations as t, getToolDescription as u, isMaintenanceTask as v, isStatelessComputeTask as y };