@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.
- package/README.md +25 -50
- package/README.zh.md +25 -48
- package/dist/AntiCheatDetector-CGVGNfy5.mjs +1 -0
- package/dist/CacheAdapters-CdAxBmVW.mjs +1 -0
- package/dist/CodeInjector-BlgyqTOk.mjs +1 -0
- package/dist/ConsoleMonitor-Dkqc0HNi.mjs +490 -0
- package/dist/DOMInspector-BYY_EJ0C.mjs +95 -0
- package/dist/DarwinAPI-DC4HGGLl.mjs +1 -0
- package/dist/DetailedDataManager-BniBJlVv.mjs +1 -0
- package/dist/EventBus-DgciURGg.mjs +1 -0
- package/dist/EvidenceGraphBridge-BIfgB7HP.mjs +1 -0
- package/dist/ExtensionManager-erMpqcLk.mjs +1 -0
- package/dist/FingerprintManager-N7BZqjxP.mjs +1 -0
- package/dist/HardwareBreakpoint-OcJqNFVc.mjs +1 -0
- package/dist/HeapAnalyzer-CqAxZzeS.mjs +1 -0
- package/dist/{HookGeneratorBuilders.core.generators.storage-CtcdK78Q.mjs → HookGeneratorBuilders.core.generators.storage-Bf1fbrNK.mjs} +66 -174
- package/dist/InstrumentationSession-DxXs0sCp.mjs +1 -0
- package/dist/MCPServer.search.handlers.domain-DVbWL1bT.mjs +1 -0
- package/dist/MemoryController-BaqstM5w.mjs +2 -0
- package/dist/MemoryScanSession-CaxAjZJf.mjs +1 -0
- package/dist/MemoryScanner-BLYnMJy6.mjs +1 -0
- package/dist/NativeMemoryManager.impl-CI554XbY.mjs +1 -0
- package/dist/NativeMemoryManager.utils-DM4NC3FE.mjs +1 -0
- package/dist/PEAnalyzer-DJyaJTQJ.mjs +1 -0
- package/dist/PageController-D9jVkH0i.mjs +1 -0
- package/dist/PointerChainEngine-5nF9eNlu.mjs +1 -0
- package/dist/PrerequisiteError-Bl3dK8XA.mjs +1 -0
- package/dist/ProcessRegistry-Hf12LlR9.mjs +1 -0
- package/dist/ResponseBuilder-B2lu4KEl.mjs +1 -0
- package/dist/ReverseEvidenceGraph-B931HeoW.mjs +2 -0
- package/dist/ScriptManager-fgqiALgj.mjs +7 -0
- package/dist/Speedhack-l6s8L2Qw.mjs +1 -0
- package/dist/StealthVerifier-Dhbj4B4P.mjs +1 -0
- package/dist/StructureAnalyzer-A-WamfYE.mjs +2 -0
- package/dist/ToolCatalog-D_IKl1Hu.mjs +1 -0
- package/dist/ToolError-DWU_z7gp.mjs +1 -0
- package/dist/ToolProbe-xsfALmN3.mjs +1 -0
- package/dist/ToolRegistry-B0Zs-phN.mjs +1 -0
- package/dist/ToolRouter.policy-CFHoN_Lw.mjs +4 -0
- package/dist/TraceRecorder-Dd8jLXpi.mjs +272 -0
- package/dist/VersionDetector-DMoUWyNm.mjs +9 -0
- package/dist/Win32API-Bhi5xFBe.mjs +1 -0
- package/dist/Win32Debug-CQteFL4F.mjs +1 -0
- package/dist/WorkflowEngine-CxEp2WXH.mjs +1 -0
- package/dist/analysis-BuR-NgX8.mjs +5 -0
- package/dist/{antidebug-CqDTB_uk.mjs → antidebug-BOTZH6-0.mjs} +8 -259
- package/dist/artifactRetention-NBdncOEW.mjs +1 -0
- package/dist/artifacts-B5xQuEa_.mjs +1 -0
- package/dist/authorization-schema-B40obG1A.mjs +1 -0
- package/dist/betterSqlite3-CGaxz4AX.mjs +1 -0
- package/dist/binary-instrument-Cf9qqLlM.mjs +7 -0
- package/dist/bind-helpers-BlAOQrFQ.mjs +1 -0
- package/dist/boringssl-inspector-BST5vtKx.mjs +2 -0
- package/dist/browser-C4Le3xqA.mjs +11 -0
- package/dist/capabilities-DbYCv-HF.mjs +1 -0
- package/dist/chunk-C_pMuVsO.mjs +1 -0
- package/dist/collector-CKO8RPK8.mjs +1 -0
- package/dist/concurrency-CcK46d0h.mjs +1 -0
- package/dist/constants-Cp6hBrrx.mjs +1 -0
- package/dist/coordination-BbijHEHH.mjs +1 -0
- package/dist/debugger-CRJq_krh.mjs +1 -0
- package/dist/definitions-BGobEDQa.mjs +1 -0
- package/dist/definitions-BGwNSkVm.mjs +1 -0
- package/dist/definitions-BbxOUiP-.mjs +1 -0
- package/dist/definitions-CCP9gphV.mjs +1 -0
- package/dist/definitions-CIO9O-Sw.mjs +1 -0
- package/dist/definitions-CYFbewnd.mjs +1 -0
- package/dist/definitions-CdWEuIkI.mjs +1 -0
- package/dist/definitions-CoQFbggH.mjs +1 -0
- package/dist/definitions-CuJRsJ6N.mjs +1 -0
- package/dist/definitions-DI9YXsJk.mjs +1 -0
- package/dist/definitions-DJklW2sS.mjs +1 -0
- package/dist/definitions-DZ8uKusP.mjs +1 -0
- package/dist/definitions-Dds_zrWx.mjs +1 -0
- package/dist/definitions-Dgrg7f3D.mjs +1 -0
- package/dist/definitions-DtE0XLrT.mjs +1 -0
- package/dist/definitions-LaYTuwQd.mjs +26 -0
- package/dist/definitions-NoVp_9Pm.mjs +1 -0
- package/dist/definitions-OvGsfxdt.mjs +1 -0
- package/dist/definitions-jXPaVy4P.mjs +1 -0
- package/dist/encoding-DGcr6Aj_.mjs +2 -0
- package/dist/ensure-browser-core-Buls24LQ.mjs +1 -0
- package/dist/evidence-graph-bridge-B0yhGPcs.mjs +1 -0
- package/dist/factory-Cx_1LorX.mjs +1 -0
- package/dist/flat-target-session-CO5g78k3.mjs +1 -0
- package/dist/formatAddress-C7j2fDlM.mjs +1 -0
- package/dist/graphql-HLf3MS8H.mjs +62 -0
- package/dist/handlers-BLMa4X7l.mjs +54 -0
- package/dist/handlers-BP12ZsWc.mjs +4 -0
- package/dist/handlers-BZoPla6E.mjs +1 -0
- package/dist/handlers-BggKiVx9.mjs +2 -0
- package/dist/handlers-D3iev8g1.mjs +1 -0
- package/dist/handlers-D49r1-1P.mjs +1 -0
- package/dist/handlers-DCE45Ww8.mjs +2 -0
- package/dist/handlers-DW5AbYs5.mjs +5 -0
- package/dist/handlers-De5u62Ga2.mjs +1 -0
- package/dist/handlers-DmQzIc44.mjs +31 -0
- package/dist/handlers-DnJRGp7t.mjs +302 -0
- package/dist/handlers-Dv_runVv.mjs +2 -0
- package/dist/handlers-S9Ws0IGy.mjs +2 -0
- package/dist/{handlers-Bl8zkwz1.mjs → handlers-pVNpaw4A.mjs} +144 -841
- package/dist/handlers.impl-CD2_kOcC.mjs +1 -0
- package/dist/hooks-DDKppogd.mjs +600 -0
- package/dist/index.mjs +12 -5225
- package/dist/logger-sBC6IdRT.mjs +1 -0
- package/dist/maintenance-CutEO84j.mjs +1 -0
- package/dist/manifest-BFGxlDRh.mjs +123 -0
- package/dist/manifest-BPuE6oH2.mjs +1 -0
- package/dist/manifest-BXry5N09.mjs +1 -0
- package/dist/manifest-BeP_zJGb2.mjs +1 -0
- package/dist/manifest-C0g67k6U.mjs +1 -0
- package/dist/manifest-C1nZkTkO.mjs +1 -0
- package/dist/manifest-C7qV1z7F.mjs +1 -0
- package/dist/manifest-CDeUZGUZ.mjs +1 -0
- package/dist/manifest-CDiCtaQT.mjs +1 -0
- package/dist/manifest-CFn0359q2.mjs +1 -0
- package/dist/manifest-CGq4NpqH2.mjs +1 -0
- package/dist/manifest-CJMGt7Qy.mjs +1 -0
- package/dist/manifest-CRIJq4Hs.mjs +1 -0
- package/dist/manifest-C_hEIjSx.mjs +1 -0
- package/dist/manifest-CeQmtQOY.mjs +1 -0
- package/dist/manifest-Cq0j7GZt.mjs +1 -0
- package/dist/manifest-CtPmHAdn.mjs +1 -0
- package/dist/manifest-Cx2IVMUY.mjs +1 -0
- package/dist/manifest-D16xPXro.mjs +1 -0
- package/dist/manifest-D44TaRJU.mjs +1 -0
- package/dist/manifest-D610kxZr.mjs +2 -0
- package/dist/manifest-DC-SMF6b.mjs +1 -0
- package/dist/manifest-DD3rtxvV.mjs +1 -0
- package/dist/manifest-DKUorv5M.mjs +1 -0
- package/dist/manifest-DMJlcsTR.mjs +1 -0
- package/dist/manifest-DWUUWBz0.mjs +1 -0
- package/dist/manifest-De-6Wf2R.mjs +1 -0
- package/dist/manifest-Dgh0uDW-.mjs +1 -0
- package/dist/manifest-Dm0o3i2U.mjs +1 -0
- package/dist/manifest-DsVh7Y4U.mjs +1 -0
- package/dist/manifest-DtEFSRaq.mjs +1 -0
- package/dist/manifest-H-EpAyZQ.mjs +1 -0
- package/dist/manifest-ais9Afrw.mjs +1 -0
- package/dist/manifest-tmb54wmA.mjs +1 -0
- package/dist/manifest-yu2xiQqe.mjs +1 -0
- package/dist/manifest-zrbrpKCC.mjs +1 -0
- package/dist/matchesWildcardPattern-BGqLSmEs.mjs +1 -0
- package/dist/modules-p-PUNv9r.mjs +332 -0
- package/dist/mojo-ipc-VGlv3Qyp.mjs +9 -0
- package/dist/network-BjZ1Y-GB.mjs +7 -0
- package/dist/outputPaths-BonGThuc.mjs +2 -0
- package/dist/parse-args-Cuk7-xUt.mjs +1 -0
- package/dist/platform-C446Lf97.mjs +93 -0
- package/dist/playwright-cdp-fallback-BwVR-_T3.mjs +1 -0
- package/dist/process-C9f2A5zk.mjs +962 -0
- package/dist/proxy-CvRepxgV.mjs +1 -0
- package/dist/registry-DUHIPE-v.mjs +1 -0
- package/dist/response-C7rKQst4.mjs +1 -0
- package/dist/search-defaults-D2bY-rzH.mjs +1 -0
- package/dist/server/plugin-api.mjs +1 -293
- package/dist/shared-state-board-Cyg-xh_k.mjs +1 -0
- package/dist/sourcemap-D6Q1UuAp.mjs +1 -0
- package/dist/ssrf-policy-T96MR3r6.mjs +1 -0
- package/dist/streaming-CTX58tbb.mjs +1 -0
- package/dist/tool-builder-CI9914Tf.mjs +1 -0
- package/dist/transform-Cv9P2vVD.mjs +103 -0
- package/dist/types-CuyefmGT.mjs +1 -0
- package/dist/types-DtThH00r.mjs +1 -0
- package/dist/wasm-DaJa8J0V.mjs +174 -0
- package/dist/webcrack-CsLLJIs9.mjs +46 -0
- package/dist/workflow-CYIXtrWD.mjs +101 -0
- package/package.json +12 -7
- package/dist/AntiCheatDetector-BNk-EoBt.mjs +0 -244
- package/dist/CacheAdapters-CDe5WPSV.mjs +0 -80
- package/dist/CodeInjector-Cq8q01kp.mjs +0 -150
- package/dist/ConsoleMonitor-CPVQW1Y-.mjs +0 -2201
- package/dist/DarwinAPI-BNPxu0RH.mjs +0 -363
- package/dist/DetailedDataManager-BQQcxh64.mjs +0 -217
- package/dist/EventBus-DgPmwpeu.mjs +0 -141
- package/dist/EvidenceGraphBridge-SFesNera.mjs +0 -153
- package/dist/ExtensionManager-CWYgw0YW.mjs +0 -714
- package/dist/FingerprintManager-gzWtkKuf.mjs +0 -96
- package/dist/HardwareBreakpoint-B9gZCdFP.mjs +0 -239
- package/dist/HeapAnalyzer-BLDH0dCv.mjs +0 -284
- package/dist/InstrumentationSession-CvPC7Jwy.mjs +0 -244
- package/dist/MemoryController-CbVdCIJF.mjs +0 -167
- package/dist/MemoryScanSession-BsDZbLYm.mjs +0 -278
- package/dist/MemoryScanner-Bcpml6II.mjs +0 -425
- package/dist/NativeMemoryManager.impl-dZtA1ZGn.mjs +0 -482
- package/dist/NativeMemoryManager.utils-B-FjA2mJ.mjs +0 -165
- package/dist/PEAnalyzer-D1lzJ_VG.mjs +0 -385
- package/dist/PageController-Bqm2kZ_X.mjs +0 -417
- package/dist/PointerChainEngine-BOhyVsjx.mjs +0 -322
- package/dist/PrerequisiteError-Dl33Svkz.mjs +0 -20
- package/dist/ResponseBuilder-D3iFYx2N.mjs +0 -143
- package/dist/ReverseEvidenceGraph-Dlsk94LC.mjs +0 -269
- package/dist/ScriptManager-aHHq0X7U.mjs +0 -3000
- package/dist/Speedhack-CqdIFlQl.mjs +0 -156
- package/dist/StealthVerifier-Bo4T3bz8.mjs +0 -135
- package/dist/StructureAnalyzer-DhFaPvRO.mjs +0 -426
- package/dist/ToolCatalog-C0JGZoOm.mjs +0 -582
- package/dist/ToolError-jh9whhMd.mjs +0 -15
- package/dist/ToolProbe-oC7aPrkv.mjs +0 -45
- package/dist/ToolRegistry-BjaF4oNz.mjs +0 -131
- package/dist/ToolRouter.policy-BWV67ZK-.mjs +0 -304
- package/dist/TraceRecorder-DgxyVbdQ.mjs +0 -519
- package/dist/VersionDetector-CwVLVdDM.mjs +0 -104
- package/dist/Win32API-CePkipZY.mjs +0 -340
- package/dist/Win32Debug-BvKs-gxc.mjs +0 -274
- package/dist/WorkflowEngine-CuvkZtWu.mjs +0 -598
- package/dist/analysis-CL9uACt9.mjs +0 -463
- package/dist/artifactRetention-CFEprwPw.mjs +0 -591
- package/dist/artifacts-Bk2-_uPq.mjs +0 -59
- package/dist/betterSqlite3-0pqusHHH.mjs +0 -74
- package/dist/binary-instrument-CXfpx6fT.mjs +0 -979
- package/dist/bind-helpers-xFfRF-qm.mjs +0 -22
- package/dist/boringssl-inspector-BH2D3VKc.mjs +0 -180
- package/dist/browser-BpOr5PEx.mjs +0 -4082
- package/dist/chunk-CjcI7cDX.mjs +0 -15
- package/dist/concurrency-Bt0yv1kJ.mjs +0 -41
- package/dist/constants-B0OANIBL.mjs +0 -519
- package/dist/coordination-qUbyF8KU.mjs +0 -259
- package/dist/debugger-gnKxRSN0.mjs +0 -1271
- package/dist/definitions-6M-eejaT.mjs +0 -53
- package/dist/definitions-B18eyf0B.mjs +0 -18
- package/dist/definitions-B3QdlrHv.mjs +0 -34
- package/dist/definitions-B4rAvHNZ.mjs +0 -63
- package/dist/definitions-BB_4jnmy.mjs +0 -37
- package/dist/definitions-BMfYXoNC.mjs +0 -43
- package/dist/definitions-Beid2EB3.mjs +0 -27
- package/dist/definitions-C1UvM5Iy.mjs +0 -126
- package/dist/definitions-CXEI7QC72.mjs +0 -216
- package/dist/definitions-C_4r7Fo-2.mjs +0 -14
- package/dist/definitions-CkFDALoa.mjs +0 -26
- package/dist/definitions-Cke7zEb8.mjs +0 -94
- package/dist/definitions-ClJLzsJQ.mjs +0 -25
- package/dist/definitions-Cq-zroAU.mjs +0 -28
- package/dist/definitions-Cy3Sl6gV.mjs +0 -34
- package/dist/definitions-D3VsGcvz.mjs +0 -47
- package/dist/definitions-DVGfrn7y.mjs +0 -96
- package/dist/definitions-LKpC3-nL.mjs +0 -9
- package/dist/definitions-bAhHQJq9.mjs +0 -359
- package/dist/encoding-Bvz5jLRv.mjs +0 -1065
- package/dist/evidence-graph-bridge-C_fv9PuC.mjs +0 -135
- package/dist/factory-DxlGh9Xf.mjs +0 -575
- package/dist/formatAddress-DVkj9kpI.mjs +0 -17
- package/dist/graphql-DYWzJ29s.mjs +0 -1026
- package/dist/handlers-9sAbfIg-.mjs +0 -2552
- package/dist/handlers-C67ktuRN.mjs +0 -710
- package/dist/handlers-C87g8oCe.mjs +0 -276
- package/dist/handlers-CTsDAO6p.mjs +0 -681
- package/dist/handlers-Cgyg6c0U.mjs +0 -645
- package/dist/handlers-D6j6yka7.mjs +0 -2124
- package/dist/handlers-DdFzXLvF.mjs +0 -446
- package/dist/handlers-DeLOCd5m.mjs +0 -799
- package/dist/handlers-DlCJN4Td.mjs +0 -757
- package/dist/handlers-DxGIq15_2.mjs +0 -917
- package/dist/handlers-U6L4xhuF.mjs +0 -585
- package/dist/handlers-tB9Mp9ZK.mjs +0 -84
- package/dist/handlers-tiy7EIBp.mjs +0 -572
- package/dist/handlers.impl-DS0d9fUw.mjs +0 -761
- package/dist/hooks-CzCWByww.mjs +0 -898
- package/dist/logger-Dh_xb7_2.mjs +0 -93
- package/dist/maintenance-P7ePRXQC.mjs +0 -830
- package/dist/manifest-2ToTpjv8.mjs +0 -106
- package/dist/manifest-3g71z6Bg.mjs +0 -79
- package/dist/manifest-82baTv4U.mjs +0 -45
- package/dist/manifest-B3QVVeBS.mjs +0 -82
- package/dist/manifest-BB2J8IMJ.mjs +0 -149
- package/dist/manifest-BKbgbSiY.mjs +0 -60
- package/dist/manifest-Bcf-TJzH.mjs +0 -848
- package/dist/manifest-BmtZzQiQ2.mjs +0 -45
- package/dist/manifest-Bnd7kqEY.mjs +0 -55
- package/dist/manifest-BqQX6OQC2.mjs +0 -65
- package/dist/manifest-BqrQ4Tpj.mjs +0 -81
- package/dist/manifest-Br4RPFt5.mjs +0 -370
- package/dist/manifest-C5qDjysN.mjs +0 -107
- package/dist/manifest-C9RT5nk32.mjs +0 -34
- package/dist/manifest-CAhOuvSl.mjs +0 -204
- package/dist/manifest-CBYWCUBJ.mjs +0 -51
- package/dist/manifest-CFADCRa1.mjs +0 -37
- package/dist/manifest-CQVhavRF.mjs +0 -114
- package/dist/manifest-CT7zZBV1.mjs +0 -48
- package/dist/manifest-CV12bcrF.mjs +0 -121
- package/dist/manifest-CXsRWjjI.mjs +0 -224
- package/dist/manifest-CZLUCfG02.mjs +0 -95
- package/dist/manifest-D6phHKFd.mjs +0 -131
- package/dist/manifest-DCyjf4n2.mjs +0 -294
- package/dist/manifest-DHsnKgP6.mjs +0 -60
- package/dist/manifest-Df_dliIe.mjs +0 -55
- package/dist/manifest-Dh8WBmEW.mjs +0 -129
- package/dist/manifest-DhKRAT8_.mjs +0 -92
- package/dist/manifest-DlpTj4ic2.mjs +0 -193
- package/dist/manifest-DrbmZcFl2.mjs +0 -253
- package/dist/manifest-DuwHjUa5.mjs +0 -70
- package/dist/manifest-DzwvxPJX.mjs +0 -38
- package/dist/manifest-NXctwWQq.mjs +0 -68
- package/dist/manifest-Sc_0JQ13.mjs +0 -418
- package/dist/manifest-gZ4s_UtG.mjs +0 -96
- package/dist/manifest-qSleDqdO.mjs +0 -1023
- package/dist/modules-C184v-S9.mjs +0 -11365
- package/dist/mojo-ipc-B_H61Afw.mjs +0 -525
- package/dist/network-671Cw6hV.mjs +0 -3346
- package/dist/outputPaths-B1uGmrWZ.mjs +0 -1145
- package/dist/parse-args-BlRjqlkL.mjs +0 -39
- package/dist/platform-WmNn8Sxb.mjs +0 -2070
- package/dist/process-QcbIy5Zq.mjs +0 -1401
- package/dist/proxy-DqNs0bAd.mjs +0 -170
- package/dist/registry-D-6e18lB.mjs +0 -34
- package/dist/response-BQVP-xUn.mjs +0 -28
- package/dist/shared-state-board-DV-dpHFJ.mjs +0 -586
- package/dist/sourcemap-Dq8ez8vS.mjs +0 -650
- package/dist/ssrf-policy-ZaUfvhq7.mjs +0 -166
- package/dist/streaming-BUQ0VJsg.mjs +0 -725
- package/dist/tool-builder-DCbIC5Eo.mjs +0 -186
- package/dist/transform-CiYJfNX0.mjs +0 -1007
- package/dist/types-Bx92KJfT.mjs +0 -4
- package/dist/types-CPhOReNX.mjs +0 -37
- package/dist/wasm-DQTnHDs4.mjs +0 -531
- package/dist/workflow-f3xJOcjx.mjs +0 -725
|
@@ -0,0 +1 @@
|
|
|
1
|
+
const e={gray:`\x1B[90m`,blue:`\x1B[34m`,yellow:`\x1B[33m`,red:`\x1B[31m`,green:`\x1B[32m`,reset:`\x1B[0m`},t=(t,n)=>`${t}${n}${e.reset}`,n=/^(auth(orization)?|cookie|set[_-]?cookie|x[_-]?api[_-]?key|token|access[_-]?token|refresh[_-]?token|id[_-]?token|secret|client[_-]?secret|password|passwd|api[_-]?key|private[_-]?key|credentials?|session[_-]?id|csrf[_-]?token)$/i,r=/^(Bearer\s+\S|eyJ[A-Za-z0-9_-]{10,}|[A-Fa-f0-9]{32,}|sk[_-][A-Za-z0-9]{20,})/;function i(e,t){return e&&n.test(e)&&typeof t==`string`||typeof t==`string`&&r.test(t)?`[REDACTED]`:t}const a=new class{level;listeners=[];constructor(e=`info`){this.level=e}shouldLog(e){let t=[`debug`,`info`,`warn`,`error`];return t.indexOf(e)>=t.indexOf(this.level)}formatMessage(e,t,...n){let r=`[${new Date().toISOString()}] [${e.toUpperCase()}]`,a=``;if(n.length>0)try{a=` `+JSON.stringify(n,i,void 0)}catch{a=` [unserializable]`}return`${r} ${t}${a}`}emit(e,t,n){for(let r of this.listeners)try{r(e,t,n)}catch{}}onLog(e){return this.listeners.push(e),()=>{this.listeners=this.listeners.filter(t=>t!==e)}}debug(n,...r){this.shouldLog(`debug`)&&(console.error(t(e.gray,this.formatMessage(`debug`,n,...r))),this.emit(`debug`,n,r))}info(n,...r){this.shouldLog(`info`)&&(console.error(t(e.blue,this.formatMessage(`info`,n,...r))),this.emit(`info`,n,r))}warn(n,...r){this.shouldLog(`warn`)&&(console.error(t(e.yellow,this.formatMessage(`warn`,n,...r))),this.emit(`warn`,n,r))}error(n,...r){this.shouldLog(`error`)&&(console.error(t(e.red,this.formatMessage(`error`,n,...r))),this.emit(`error`,n,r))}success(n,...r){this.shouldLog(`info`)&&(console.error(t(e.green,this.formatMessage(`info`,n,...r))),this.emit(`info`,n,r))}setLevel(e){this.level=e}}(process.env.LOG_LEVEL||`info`);export{a as t};
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
import{t as e}from"./logger-sBC6IdRT.mjs";import{$ as t,U as n,W as r,ht as i}from"./constants-Cp6hBrrx.mjs";import{n as a,t as o}from"./artifactRetention-NBdncOEW.mjs";import{a as s,n as c}from"./response-C7rKQst4.mjs";import{t as l}from"./types-CuyefmGT.mjs";import{i as u,l as d}from"./outputPaths-BonGThuc.mjs";import{r as f}from"./betterSqlite3-CGaxz4AX.mjs";import{r as p}from"./concurrency-CcK46d0h.mjs";import{t as m}from"./ToolRegistry-B0Zs-phN.mjs";import"./definitions-CdWEuIkI.mjs";import{createRequire as h}from"node:module";import{existsSync as g}from"node:fs";import{dirname as _,isAbsolute as v,relative as y,resolve as b}from"node:path";import{fileURLToPath as x}from"node:url";import{mkdir as S,readFile as C,writeFile as w}from"node:fs/promises";import{execFile as T}from"node:child_process";import{promisify as E}from"node:util";const D=E(T),O=h(import.meta.url);let k=null,A=0;function j(){let e=Date.now();return(!k||e-A>12e4)&&(k=new m,A=e),k}async function M(e){let n=e?.includeBridgeHealth??!0,r=j().probeAll(!0),o=p(()=>L(`git`,[`--version`])),s=p(()=>L(`python`,[`--version`])),c=p(()=>ee()),l=p(()=>L(`corepack`,[`--version`])),d=n?Promise.all([p(()=>z(`ghidra-bridge`,`${t.replace(/\/$/,``)}/health`)),p(()=>z(`ida-bridge`,`${i.replace(/\/$/,``)}/health`)),p(()=>z(`burp-mcp-sse`,process.env.BURP_MCP_SSE_URL?.trim()||`http://127.0.0.1:9876`))]):Promise.resolve([]),[f,m,h,g,_,v]=await Promise.all([r,o,s,c,l,d]),y=te(_,g),b=[N(`@modelcontextprotocol/sdk`),N(`rebrowser-puppeteer-core`),P(),N(`camoufox-js`,`Optional Firefox anti-detect driver`),N(`playwright-core`,`Optional browser automation dependency`),I()],x=[m,h,g,y,...Object.entries(f).map(([e,t])=>({name:e,status:t.available?`ok`:`missing`,detail:t.available?`${t.path??`PATH`}${t.version?` (${t.version})`:``}`:t.reason??`Unavailable`}))],S=ne(),C=re(b,x,v,S);return{success:[...b,...x,...v].every(e=>e.status!==`error`),generatedAt:new Date().toISOString(),runtime:{platform:process.platform,arch:process.arch,node:process.version,cwd:process.cwd(),projectRoot:u()},packages:b,commands:x,bridges:v,config:{transport:(process.env.MCP_TRANSPORT??`stdio`).toLowerCase(),toolProfile:(process.env.MCP_TOOL_PROFILE??`search`).toLowerCase(),pluginRoots:process.env.MCP_PLUGIN_ROOTS??`<jshook-install>/plugins`,workflowRoots:process.env.MCP_WORKFLOW_ROOTS??`<jshook-install>/workflows`,pluginSignatureRequired:process.env.MCP_PLUGIN_SIGNATURE_REQUIRED??(process.env.NODE_ENV===`production`?`true (production default)`:`false`),pluginStrictLoad:process.env.MCP_PLUGIN_STRICT_LOAD??(process.env.NODE_ENV===`production`?`true (production default)`:`false`),artifactRetention:a()},limitations:S,recommendations:C}}function N(e,t){try{let t=O(O.resolve(`${e}/package.json`));return{name:e,status:`ok`,detail:t.version?`installed (${t.version})`:`installed`}}catch{return{name:e,status:`missing`,detail:t??`Not installed`}}}function P(){let e=f();return{name:`better-sqlite3`,status:e.status,detail:e.detail}}function F(e){return e.status===`ok`||e.detail.includes(`npx fallback works`)}async function ee(){let e=await L(`pnpm`,[`--version`]);if(e.status===`ok`)return e;let t=await L(`npx`,[`pnpm`,`--version`],1e4);return t.status===`ok`?{name:`pnpm`,status:`warn`,detail:`direct pnpm command unavailable; npx fallback works (${t.detail})`}:e}function te(e,t){return e.status!==`missing`||!F(t)?e:{name:e.name,status:`warn`,detail:process.platform===`win32`?t.detail.includes(`npx fallback works`)?"corepack not found; use `npx pnpm` directly (common with nvm4w-managed Node on Windows)":`corepack not found; standalone pnpm is available (common with nvm4w-managed Node on Windows)`:t.detail.includes(`npx fallback works`)?"corepack not found; use `npx pnpm` directly":`corepack not found; standalone pnpm is available`}}function I(){try{let e=O(O.resolve(`koffi/package.json`)).version??`unknown`;if(process.platform===`win32`)return{name:`native-memory`,status:`ok`,detail:`koffi ${e} — Win32 kernel32.dll available`};if(process.platform===`darwin`)try{return O(`koffi`).load(`/usr/lib/libSystem.B.dylib`).unload(),delete O.cache[O.resolve(`koffi`)],{name:`native-memory`,status:`ok`,detail:`koffi ${e} — macOS libSystem.B.dylib available (Mach APIs need root + SIP config)`}}catch{return{name:`native-memory`,status:`warn`,detail:`koffi ${e} installed but cannot load libSystem.B.dylib`}}return{name:`native-memory`,status:`warn`,detail:`koffi ${e} — no native FFI memory provider for ${process.platform} (proc-based ops available on Linux)`}}catch{return{name:`native-memory`,status:`missing`,detail:`koffi not installed — native memory tools unavailable. Install with: pnpm add koffi`}}}async function L(e,t,n=4e3){try{let{stdout:r,stderr:i}=await D(e,t,{timeout:n,windowsHide:!0});return{name:e,status:`ok`,detail:`${r||i}`.trim().split(/\r?\n/)[0]||`available`}}catch(r){if(process.platform===`win32`)try{let{stdout:r,stderr:i}=await D(`cmd`,[`/c`,e,...t],{timeout:n,windowsHide:!0});return{name:e,status:`ok`,detail:`${`${r||i}`.trim().split(/\r?\n/)[0]||`available`} (via cmd)`}}catch(t){return R(e,t)}return R(e,r)}}function R(e,t){let n=t instanceof Error?t.message:String(t);return{name:e,status:/ENOENT|not recognized|not found/i.test(n)?`missing`:`warn`,detail:n}}async function z(e,t){try{let n=await fetch(t,{method:`GET`,signal:AbortSignal.timeout(3e3)});return{name:e,status:n.ok?`ok`:`warn`,detail:`${t} -> HTTP ${n.status}`}}catch(n){return{name:e,status:`warn`,detail:`${t} -> ${n instanceof Error?n.message:String(n)}`}}}function ne(){let e=[];return process.platform===`darwin`?(e.push(`26 cross-platform memory tools available (scan, pointer-chain, structure-analysis, heap). 15 Windows-only tools unavailable (PE analysis, anti-cheat, code injection, speedhack, hardware breakpoints).`),e.push(`Native memory operations (mach_vm_read/write) require root privileges and may require SIP configuration on ARM64.`)):process.platform===`linux`?(e.push(`Process management available via /proc. Native FFI memory provider not implemented — memory read/write uses /proc/pid/mem (requires root or CAP_SYS_PTRACE).`),e.push(`Camoufox runs on Linux, but some Chrome/CDP-heavy workflows are better served by the Chrome driver.`)):process.platform!==`win32`&&e.push(`Platform ${process.platform} is not supported for native memory operations. Use Windows or macOS.`),e}function re(e,t,n,r){let i=[],a=t.find(e=>e.name===`pnpm`),o=t.find(e=>e.name===`corepack`);return e.some(e=>e.name===`better-sqlite3`&&e.status!==`ok`)&&i.push("Install or rebuild the optional SQLite trace backend with `pnpm add -O better-sqlite3@12.6.2` or `npm rebuild better-sqlite3 --foreground-scripts` under the active Node version if you need trace tooling."),e.some(e=>e.name===`camoufox-js`&&e.status!==`ok`)&&i.push("Install optional browser dependencies with `pnpm run install:full` if you need Camoufox support."),t.some(e=>e.name.startsWith(`wabt.`)&&e.status!==`ok`)&&i.push(`Install wabt if you need full WASM disassembly/decompilation; otherwise the server will stay in basic mode.`),a&&!F(a)?i.push("Install pnpm or enable Corepack (`corepack enable`) before running package-management workflows."):a?.detail.includes(`npx fallback works`)?i.push("Use `npx pnpm` directly on this machine or repair the local pnpm/Corepack shim if scripts expect bare `pnpm`."):o?.status===`warn`&&o.detail.includes(`standalone pnpm`)&&i.push("Use `pnpm` or `npx pnpm` directly on this machine; `corepack` is optional and may be absent on nvm4w-managed Windows installs."),n.some(e=>e.status!==`ok`)&&i.push(`Check local bridge endpoints (Ghidra / IDA / Burp) before relying on native-bridge workflows.`),r.length>0&&i.push(`Review platform limitations before using process/memory tooling on non-Windows hosts.`),i}var ie=class{tokenBudget;unifiedCache;artifactCleanup;environmentDoctor;constructor(e){this.tokenBudget=e.tokenBudget,this.unifiedCache=e.unifiedCache,this.artifactCleanup=e.artifactCleanup??o,this.environmentDoctor=e.environmentDoctor??M}async handleGetTokenBudgetStats(){try{let e=this.tokenBudget.getStats();return c({success:!0,...e,sessionDuration:`${Math.round((Date.now()-e.sessionStartTime)/1e3)}s`})}catch(t){return e.error(`Failed to read token budget stats:`,t),c(s(t))}}async handleManualTokenCleanup(){try{let e=this.tokenBudget.getStats();this.tokenBudget.manualCleanup();let t=this.tokenBudget.getStats(),n=e.currentUsage-t.currentUsage;return c({success:!0,message:`Manual cleanup completed`,before:{usage:e.currentUsage,percentage:e.usagePercentage},after:{usage:t.currentUsage,percentage:t.usagePercentage},freed:{tokens:n,percentage:Math.round(n/e.maxTokens*100)}})}catch(t){return e.error(`Failed to perform manual cleanup:`,t),c(s(t))}}async handleResetTokenBudget(){try{return this.tokenBudget.reset(),c({success:!0,message:`Token budget reset successfully`,currentUsage:0,maxTokens:2e5,usagePercentage:0})}catch(t){return e.error(`Failed to reset token budget:`,t),c(s(t))}}async handleGetCacheStats(){try{return c({success:!0,...await this.unifiedCache.getGlobalStats()})}catch(t){return e.error(`Failed to get cache stats:`,t),c(s(t))}}async handleSmartCacheCleanup(t){try{return c({success:!0,...await this.unifiedCache.smartCleanup(t)})}catch(t){return e.error(`Failed to perform cache cleanup:`,t),c(s(t))}}async handleClearAllCaches(){try{return await this.unifiedCache.clearAll(),c({success:!0,message:`All caches cleared`})}catch(t){return e.error(`Failed to clear caches:`,t),c(s(t))}}async handleCleanupArtifacts(t){try{return c(await this.artifactCleanup({retentionDays:t.retentionDays,maxTotalBytes:t.maxTotalBytes,dryRun:t.dryRun}))}catch(t){return e.error(`Failed to cleanup artifacts:`,t),c(s(t))}}async handleEnvironmentDoctor(t){try{return c(await this.environmentDoctor({includeBridgeHealth:t.includeBridgeHealth}))}catch(t){return e.error(`Failed to run environment doctor:`,t),c(s(t))}}};const B=E(T);function V(){return x(new URL(`../../../../`,import.meta.url))}function ae(e){let t=e?.trim();if(t)return t.split(`,`).map(e=>e.trim()).find(e=>e.length>0)}function H(e){let t=e===`workflow`?`MCP_WORKFLOW_ROOTS`:`MCP_PLUGIN_ROOTS`,n=ae(process.env[t]);return n?b(n):b(V(),e===`workflow`?`workflows`:`plugins`)}function U(){let e=(process.env.EXTENSION_REGISTRY_BASE_URL??``).trim().replace(/\/+$/,``);if(!e)throw Error(`EXTENSION_REGISTRY_BASE_URL is not configured. Set it in .env or environment before browsing or installing extensions.`);return e}function W(e,t){let n=e?.trim();if(!n){if(t===`subpath`)return`.`;throw Error(`Registry source.${t} must be a non-empty string`)}return n}function G(e,t,n){let r=y(e,t).replace(/\\/g,`/`);if(r===`..`||r.startsWith(`../`)||v(r))throw Error(`Registry source.${n} must stay within ${e}: ${t}`)}function K(e,t){let n=b(e,W(t,`subpath`));return G(e,n,`subpath`),n}function q(e,t){let n=b(e,W(t,`entry`));return G(e,n,`entry`),n}function oe(e){let t=W(e,`entry`).replace(/\\/g,`/`),n=[t];if(!t.endsWith(`.ts`))return n;let r=`${t.slice(0,-3)}.js`;return n.unshift(r),t.startsWith(`dist/`)||n.unshift(`dist/${r}`),[...new Set(n)]}function se(e,t){let n=oe(t);for(let t of n)if(g(q(e,t)))return t;return W(t,`entry`)}async function ce(e,t,n,r){let i={version:1,kind:e,slug:t.slug,id:t.id,source:{type:t.source.type,repo:t.source.repo,ref:t.source.ref,commit:t.source.commit,subpath:W(t.source.subpath,`subpath`),entry:W(r,`entry`)}},a=b(n,l);return await w(a,`${JSON.stringify(i,null,2)}\n`,`utf8`),a}const J=`@jshookmcp/extension-sdk`,le=b(V(),`packages`,`extension-sdk`);function ue(){return d().paths.registryCacheDir}var Y=class extends Error{code;url;cachePath;status;constructor(e,t,n,r,i){super(n),this.code=e,this.url=t,this.cachePath=r,this.status=i,this.name=`RegistryFetchError`}};function de(e,t){return process.platform===`win32`?{command:`powershell.exe`,args:[`-NoProfile`,`-NonInteractive`,`-Command`,`${e} ${t.join(` `)}`]}:{command:e,args:t}}async function X(e,t,n){let r=de(e,t);return B(r.command,r.args,{...n,env:{...process.env,...n?.env,CI:`true`}})}async function fe(e){let t=b(e,`package.json`),n=b(e,`pnpm-lock.yaml`),r=b(e,`package-lock.json`);if(g(t))try{let e=await C(t,`utf8`),n=JSON.parse(e).packageManager?.trim().toLowerCase().split(`@`)[0];if(n===`pnpm`)return`pnpm`;if(n===`npm`)return`npm`}catch{}return g(n)?`pnpm`:g(r)?`npm`:`pnpm`}function Z(e){return b(ue(),`registry-${e}.json`)}async function pe(e){let t=Z(e);try{let e=await C(t,`utf8`);return JSON.parse(e)}catch{return null}}async function me(e,t){let n=Z(e);await S(_(n),{recursive:!0}),await w(n,JSON.stringify(t,null,2),`utf8`)}function Q(e,t,n){if(t instanceof Y)return t;if(t instanceof DOMException&&t.name===`AbortError`)return new Y(`timeout`,e,`Registry fetch timed out after 10000ms: ${e}`,n);let r=t instanceof Error?t.message:String(t);if(r.includes(`ENOTFOUND`)||r.includes(`getaddrinfo`))return new Y(`dns_failure`,e,`DNS resolution failed for registry URL: ${e}`,n);if(r.includes(`ECONNREFUSED`))return new Y(`connection_refused`,e,`Connection refused by registry server: ${e}`,n);if(r.includes(`CERT_`)||r.includes(`certificate`)||r.includes(`SSL`))return new Y(`tls_error`,e,`TLS/certificate error when connecting to registry: ${e}`,n);let i=r.match(/HTTP\s+(\d+)/i);return i?new Y(`http_error`,e,r,n,Number(i[1])):new Y(`fetch_failed`,e,r,n)}function he(e){return{success:!1,error:e.code,message:e.message,url:e.url,...typeof e.status==`number`?{status:e.status}:{}}}async function $(t,n){let r=new AbortController,i=setTimeout(()=>r.abort(),1e4),a=n?.cacheKey?Z(n.cacheKey):void 0;try{let i=await fetch(t,{signal:r.signal});if(!i.ok)throw new Y(`http_error`,t,`HTTP ${i.status} ${i.statusText} from ${t}`,a,i.status);let o=await i.json();if(n?.cacheKey)try{await me(n.cacheKey,o)}catch(r){e.warn(`[extensions] Failed to persist ${n.cacheKey} registry cache for ${t}:`,r)}return{data:o,stale:!1,source:`network`,cachePath:a}}catch(r){let i=Q(t,r,a);if(n?.cacheKey){let r=await pe(n.cacheKey);if(r)return e.warn(`[extensions] Using stale ${n.cacheKey} registry cache after ${i.code}: ${t}`),{data:r,stale:!0,source:`cache`,cachePath:a}}throw i}finally{clearTimeout(i)}}async function ge(t){let n=b(t,`package.json`);try{let r=await C(n,`utf8`),i=JSON.parse(r),a=[`dependencies`,`devDependencies`,`peerDependencies`,`optionalDependencies`],o=`file:${y(t,le).replace(/\\/g,`/`)||`.`}`,s=!1;for(let e of a){let t=i[e];if(!t||typeof t!=`object`)continue;let n=t,r=n[J];typeof r==`string`&&r.startsWith(`workspace:`)&&(n[J]=o,s=!0)}return s?(await w(n,`${JSON.stringify(i,null,2)}\n`,`utf8`),e.info(`[extensions] Rewrote ${J} dependency to local file path for ${t}`),!0):!1}catch(n){return e.warn(`[extensions] Failed to rewrite ${J} dependency for ${t}:`,n),!1}}async function _e(e,t){let[n,r]=await Promise.allSettled([$(`${e}/workflows.index.json`,{cacheKey:`workflows`}),$(`${e}/plugins.index.json`,{cacheKey:`plugins`})]);if(n.status===`fulfilled`){let e=(Array.isArray(n.value.data.workflows)?n.value.data.workflows:[]).find(e=>e.slug===t);if(e)return{entry:e,kind:`workflow`}}if(r.status===`fulfilled`){let e=(Array.isArray(r.value.data.plugins)?r.value.data.plugins:[]).find(e=>e.slug===t);if(e)return{entry:e,kind:`plugin`}}let i=n.status===`rejected`?n.reason instanceof Error?n.reason:Error(String(n.reason)):void 0,a=r.status===`rejected`?r.reason instanceof Error?r.reason:Error(String(r.reason)):void 0;throw Error(i&&a?`Failed to resolve extension slug "${t}": workflow registry error: ${i.message}; plugin registry error: ${a.message}`:a?`Extension "${t}" was not found in workflow registry, and plugin registry lookup failed: ${a.message}`:i?`Extension "${t}" was not found in plugin registry, and workflow registry lookup failed: ${i.message}`:`Extension "${t}" not found in workflow or plugin registry`)}var ve=class{ctx;constructor(e){this.ctx=e}async handleListExtensions(){try{return c({success:!0,...this.ctx.listExtensions()})}catch(t){return e.error(`Failed to list extensions:`,t),c(s(t))}}async handleReloadExtensions(){try{return c({success:!0,...await this.ctx.reloadExtensions()})}catch(t){return e.error(`Failed to reload extensions:`,t),c(s(t))}}async handleBrowseExtensionRegistry(t){try{let e=U(),n=t===`all`||t===`plugin`,r=t===`all`||t===`workflow`,i={success:!0},a=!1,o=n?$(`${e}/plugins.index.json`,{cacheKey:`plugins`}):void 0,s=r?$(`${e}/workflows.index.json`,{cacheKey:`workflows`}):void 0,[l,u]=await Promise.all([o??Promise.resolve(void 0),s??Promise.resolve(void 0)]);if(l){let e=Array.isArray(l.data.plugins)?l.data.plugins:[];i.plugins=e.map(e=>({slug:e.slug,id:e.id,name:e.meta.name,description:e.meta.description,author:e.meta.author,repo:e.source.repo,commit:e.source.commit,entry:e.source.entry})),i.pluginCount=e.length,i.pluginSource=l.source,a||=l.stale}if(u){let e=Array.isArray(u.data.workflows)?u.data.workflows:[];i.workflows=e.map(e=>({slug:e.slug,id:e.id,name:e.meta.name,description:e.meta.description,author:e.meta.author,repo:e.source.repo,commit:e.source.commit,entry:e.source.entry})),i.workflowCount=e.length,i.workflowSource=u.source,a||=u.stale}return a&&(i.stale=!0),c(i)}catch(t){return e.error(`Failed to browse extension registry:`,t),t instanceof Y?c(he(t)):c(s(t))}}async handleInstallExtension(t,i){try{let{entry:e,kind:a}=await _e(U(),t),o=a===`workflow`,s=H(o?`workflow`:`plugin`),l=i?b(i):b(s,t),u=K(l,e.source.subpath);if(q(u,e.source.entry),g(l))return c({success:!1,error:`Target directory already exists: ${l}`,hint:`Remove the existing directory first, or specify a different targetDir`});if(await S(_(l),{recursive:!0}),await B(`git`,[`clone`,e.source.repo,l],{timeout:r}),await B(`git`,[`-C`,l,`checkout`,e.source.commit],{timeout:n}),g(b(u,`package.json`))){await ge(u);let e=await fe(u);await X(e,e===`pnpm`?[`--ignore-workspace`,`install`,`--no-frozen-lockfile`,`--ignore-scripts`]:[`install`,`--ignore-scripts`],{cwd:u,timeout:Math.max(r,12e4)}),await X(e,e===`pnpm`?[`--ignore-workspace`,`run`,`--if-present`,`build`]:[`run`,`build`,`--if-present`],{cwd:u,timeout:Math.max(r,12e4)})}let d=se(u,e.source.entry),f=q(u,d);if(!g(f))return c({success:!1,error:`Installed extension entry not found: ${d}`,installDir:l,projectDir:u,expectedEntryFile:f,hint:`The registry source.entry or its compiled JS output must exist after clone/build before reloadExtensions can load it.`});let p=await ce(o?`workflow`:`plugin`,e,u,d),m=await this.ctx.reloadExtensions();return c({success:!0,installed:{slug:e.slug,id:e.id,name:e.meta.name,repo:e.source.repo,commit:e.source.commit,installDir:l,projectDir:u,entry:d,entryFile:f,metadataPath:p},reload:{addedTools:m.addedTools,pluginCount:m.pluginCount,workflowCount:m.workflowCount,errors:m.errors,warnings:m.warnings}})}catch(t){return e.error(`Failed to install extension:`,t),c(s(t))}}};export{ie as CoreMaintenanceHandlers,ve as ExtensionManagementHandlers};
|
|
@@ -0,0 +1,123 @@
|
|
|
1
|
+
import{t as e}from"./VersionDetector-DMoUWyNm.mjs";import{a as t,r as n,t as r}from"./parse-args-Cuk7-xUt.mjs";import{t as i}from"./bind-helpers-BlAOQrFQ.mjs";import{t as a}from"./tool-builder-CI9914Tf.mjs";import{spawn as o}from"node:child_process";function s(e){return typeof e==`object`&&!!e}function c(e){return typeof e==`number`&&Number.isFinite(e)?e:null}function l(e){return s(e)?`value`in e?l(e.value):`result`in e?l(e.result):e:e}function u(e){let t=l(e),n=typeof t==`string`?(()=>{try{return JSON.parse(t)}catch{return null}})():t;if(!s(n))return null;let r=c(n.jsHeapSizeUsed)??c(n.usedSize),i=c(n.jsHeapSizeTotal)??c(n.totalSize),a=c(n.jsHeapSizeLimit)??0;if(r===null&&i===null&&a===0)return null;let o={};return r!==null&&(o.jsHeapSizeUsed=r),i!==null&&(o.jsHeapSizeTotal=i),a>0&&(o.jsHeapSizeLimit=a),o}function d(e){return e.jsHeapSizeUsed>0||e.jsHeapSizeTotal>0||e.jsHeapSizeLimit>0}function f(e,t){if(!e&&!t)return null;let n={jsHeapSizeUsed:t?.jsHeapSizeUsed??e?.jsHeapSizeUsed??0,jsHeapSizeTotal:t?.jsHeapSizeTotal??e?.jsHeapSizeTotal??0,jsHeapSizeLimit:t?.jsHeapSizeLimit??e?.jsHeapSizeLimit??0};return d(n)?n:null}function ee(e){let t=l(e);if(!s(t)||!Array.isArray(t.metrics))return null;let n=new Map;for(let e of t.metrics){if(!s(e))continue;let t=typeof e.name==`string`?e.name:null,r=c(e.value);!t||r===null||n.set(t,r)}let r=n.get(`JSHeapUsedSize`)??0,i=n.get(`JSHeapTotalSize`)??0;return r===0&&i===0?null:{jsHeapSizeUsed:r,jsHeapSizeTotal:i}}function p(e){return s(e)&&typeof e.createCDPSession==`function`}function m(e){return s(e)&&typeof e.send==`function`&&typeof e.detach==`function`}var h=class{getPage;session=null;constructor(e){this.getPage=e}async enableHeapProfiler(){let e=await this.createSession();if(!e)throw Error(`V8InspectorClient: cannot create CDP session`);await e.send(`HeapProfiler.enable`),this.session=e}async takeHeapSnapshot(e){this.session||await this.enableHeapProfiler();let t=this.session;if(!t)throw Error(`V8InspectorClient: session not available for heap snapshot`);return new Promise((n,r)=>{let i=[],a=0,o=t=>{let n=t?.chunk;typeof n==`string`&&(i.push(n),a+=Buffer.byteLength(n,`utf8`),e?.(n))};t.on(`HeapProfiler.addHeapSnapshotChunk`,o),t.send(`HeapProfiler.takeHeapSnapshot`,{reportProgress:!1}).then(()=>{t.off(`HeapProfiler.addHeapSnapshotChunk`,o),n(a)}).catch(e=>{t.off(`HeapProfiler.addHeapSnapshotChunk`,o),r(e)})})}async getObjectByObjectId(e){let t=await this.createSession();if(!t)return null;try{let n=await t.send(`Runtime.getProperties`,{objectId:e,ownProperties:!0,accessorPropertiesOnly:!1,generatePreview:!0});if(Array.isArray(n.result))return{kind:`runtime-object`,properties:n.result,internalProperties:Array.isArray(n.internalProperties)?n.internalProperties:[],privateProperties:Array.isArray(n.privateProperties)?n.privateProperties:[],...n.exceptionDetails?{exceptionDetails:n.exceptionDetails}:{}}}catch{}try{return await t.send(`HeapProfiler.getObjectByHeapObjectId`,{objectId:e})}catch{return null}}async getHeapUsage(){this.session||await this.enableHeapProfiler();let e=this.session;if(!e)throw Error(`V8InspectorClient: session not available for heap usage`);let t=null;try{let n=await e.send(`Runtime.getHeapUsage`);t=f(t,u(n))}catch{}try{let n=await e.send(`HeapProfiler.getHeapUsage`);t=f(t,u(n))}catch{}try{let n=await e.send(`Performance.getMetrics`);t=f(t,ee(n))}catch{}try{let n=await e.send(`Runtime.evaluate`,{expression:`
|
|
2
|
+
(() => {
|
|
3
|
+
const m = performance.memory;
|
|
4
|
+
return m
|
|
5
|
+
? {
|
|
6
|
+
jsHeapSizeUsed: m.usedJSHeapSize,
|
|
7
|
+
jsHeapSizeTotal: m.totalJSHeapSize,
|
|
8
|
+
jsHeapSizeLimit: m.jsHeapSizeLimit
|
|
9
|
+
}
|
|
10
|
+
: null;
|
|
11
|
+
})()
|
|
12
|
+
`,returnByValue:!0});t=f(t,u(n))}catch{}if(!t)throw Error(`V8InspectorClient: heap usage metrics unavailable`);return t}async dispose(){this.session&&=(await this.session.detach().catch(()=>void 0),null)}async createSession(){if(this.session)return this.session;if(!this.getPage)return null;try{let e=await this.getPage();if(!p(e))return null;let t=await e.createCDPSession();return m(t)?(this.session=t,t):null}catch{return null}}};const g=[a(`v8_heap_snapshot_capture`,e=>e.desc(`Capture a V8 heap snapshot for offline analysis.`).query()),a(`v8_heap_snapshot_analyze`,e=>e.desc(`Analyze a heap snapshot: retained size, constructor distribution, dominators.`).string(`snapshotId`,`Snapshot ID`).required(`snapshotId`).query()),a(`v8_heap_diff`,e=>e.desc(`Compare two heap snapshots to find allocation changes.`).string(`beforeSnapshotId`,`Baseline snapshot ID`).string(`afterSnapshotId`,`Updated snapshot ID`).required(`beforeSnapshotId`,`afterSnapshotId`).query()),a(`v8_object_inspect`,e=>e.desc(`Inspect a live JS object by objectId with property enumeration.`).string(`address`,`Runtime objectId or compatible heap object id`).required(`address`).query()),a(`v8_heap_stats`,e=>e.desc(`Report V8 heap statistics: used, total, external.`).query()),a(`v8_bytecode_extract`,e=>e.desc(`Extract V8 bytecode for a script by scriptId, with source fallback.`).string(`scriptId`,`CDP scriptId`).number(`functionOffset`,`Optional function byte offset`).boolean(`includeSourceFallback`,`Include source-derived fallback output`).required(`scriptId`).query()),a(`v8_version_detect`,e=>e.desc(`Detect V8 engine version, flags, and runtime capabilities.`).query()),a(`v8_jit_inspect`,e=>e.desc(`Report JIT compilation status and optimization tier for a script.`).string(`scriptId`,`CDP scriptId`).required(`scriptId`).query())],_=new Map;function te(){return _}function v(e){return _.set(e.id,e),e}function y(e){return _.get(e)}function b(e){return typeof e==`object`&&!!e}function x(e){return b(e)&&typeof e.createCDPSession==`function`}function S(e){return b(e)?`value`in e?S(e.value):`result`in e?S(e.result):e:e}async function C(e,t){let n=`snapshot_${Date.now().toString(36)}`,r=new Date().toISOString(),i=[];if(t.client)try{let e=v({id:n,chunks:i,capturedAt:r,sizeBytes:await t.client.takeHeapSnapshot(e=>{i.push(e)})});return t.setSnapshot(n),{success:!0,snapshotId:e.id,capturedAt:e.capturedAt,sizeBytes:e.sizeBytes,chunks:[],simulated:!1}}catch{}try{let e=await t.getPage();if(x(e)){let i=await e.createCDPSession(),a=(e,t)=>i.send(e,t),o=()=>i.detach();await a(`HeapProfiler.enable`);let s=await a(`Runtime.evaluate`,{expression:`
|
|
13
|
+
(() => {
|
|
14
|
+
const m = performance.memory;
|
|
15
|
+
return m
|
|
16
|
+
? {
|
|
17
|
+
jsHeapSizeUsed: m.usedJSHeapSize,
|
|
18
|
+
jsHeapSizeTotal: m.totalJSHeapSize,
|
|
19
|
+
jsHeapSizeLimit: m.jsHeapSizeLimit
|
|
20
|
+
}
|
|
21
|
+
: null;
|
|
22
|
+
})()
|
|
23
|
+
`,returnByValue:!0});await o().catch(()=>void 0);let c=S(s),l=typeof c==`string`?(()=>{try{return JSON.parse(c)}catch{return null}})():c,u=0;b(l)&&typeof l.jsHeapSizeUsed==`number`&&(u=l.jsHeapSizeUsed);let d=v({id:n,chunks:[`{"simulated":true,"sizeBytes":${u}}`],capturedAt:r,sizeBytes:u});return t.setSnapshot(n),{success:!0,snapshotId:d.id,capturedAt:d.capturedAt,sizeBytes:d.sizeBytes,chunks:[],simulated:!0}}}catch{}let a=v({id:n,chunks:[`{}`],capturedAt:r,sizeBytes:0});return t.setSnapshot(n),{success:!0,snapshotId:a.id,capturedAt:a.capturedAt,sizeBytes:a.sizeBytes,chunks:[],simulated:!0}}const w=`__JSHOOK_BYTECODE_STATUS__:`,T=`__jshookBytecodeTarget__`;function ne(e){return/^[A-Za-z_$][\w$]*$/u.test(e)}function re(e){let t=e.trim();return t.length===0||t===`anonymous`?T:ne(t)?t:T}function ie(e){let t=e.trim();return t.startsWith(`function`)||t.startsWith(`async function`)||t.startsWith(`class `)||t.startsWith(`(`)||t.includes(`=>`)?!1:/^(?:async\s+)?(?:get\s+|set\s+)?\*?\s*[A-Za-z_$][\w$]*\s*\(/u.test(t)}function E(e){let t=e.sourceSlice.trim(),n=e.functionName.trim();return`
|
|
24
|
+
let ${T};
|
|
25
|
+
${ie(t)?`
|
|
26
|
+
try {
|
|
27
|
+
const __jshookHolder = { ${t} };
|
|
28
|
+
const __jshookCandidate = __jshookHolder[${JSON.stringify(n)}];
|
|
29
|
+
if (typeof __jshookCandidate === 'function') {
|
|
30
|
+
${T} = __jshookCandidate;
|
|
31
|
+
}
|
|
32
|
+
} catch {}
|
|
33
|
+
`:`
|
|
34
|
+
try {
|
|
35
|
+
${T} = (${t});
|
|
36
|
+
} catch {}
|
|
37
|
+
`}
|
|
38
|
+
|
|
39
|
+
if (typeof ${T} !== 'function') {
|
|
40
|
+
console.log(${JSON.stringify(`${w}resolve-failed`)});
|
|
41
|
+
} else {
|
|
42
|
+
try {
|
|
43
|
+
const __jshookArity =
|
|
44
|
+
typeof ${T}.length === 'number' && ${T}.length > 0
|
|
45
|
+
? ${T}.length
|
|
46
|
+
: 0;
|
|
47
|
+
Reflect.apply(${T}, globalThis, Array.from({ length: __jshookArity }, () => undefined));
|
|
48
|
+
} catch (error) {
|
|
49
|
+
console.log(${JSON.stringify(`${w}invoke-error:`)} + String(error));
|
|
50
|
+
}
|
|
51
|
+
console.log(${JSON.stringify(`${w}done`)});
|
|
52
|
+
}
|
|
53
|
+
`}function D(e,t){let n=e.split(/\r?\n/u),r=new Set(t.filter(e=>e.length>0)),i=null,a=!1,o=[];for(let e of n){let t=/^\[generated bytecode for function: (.+?) \(/u.exec(e);if(t?.[1]){if(a&&o.length>0)break;i=r.has(t[1])?t[1]:null,a=i!==null,a&&(o.length=0,o.push(e));continue}if(a){if(e.startsWith(w))break;o.push(e)}}return o.length===0?{bytecode:null,matchedFunctionName:null}:{bytecode:o.join(`
|
|
54
|
+
`).trim(),matchedFunctionName:i}}function O(e){let t=e.split(/\r?\n/u).find(e=>e.startsWith(w)&&e.length>27);return t?t.slice(27):null}function k(e,t,n){let r=O(e);if(r===`resolve-failed`)return`Unable to reconstruct an executable function from the captured source slice`;if(typeof r==`string`&&r.startsWith(`invoke-error:`))return`Function compiled but raised during isolated invocation: ${r.slice(13)}`;let i=t.trim();return i.length>0?i:n}async function A(e,t,n){return await new Promise(r=>{let i=o(process.execPath,[`--print-bytecode`,`--print-bytecode-filter=${t}`,`-`],{stdio:[`pipe`,`pipe`,`pipe`]}),a=``,s=``,c=!1,l=e=>{c||(c=!0,clearTimeout(u),r({stdout:a,stderr:s,error:e}))},u=setTimeout(()=>{i.kill(),l(`Timed out after ${n}ms while waiting for isolated bytecode output`)},n);i.stdout.setEncoding(`utf8`),i.stderr.setEncoding(`utf8`),i.stdout.on(`data`,e=>{a+=e}),i.stderr.on(`data`,e=>{s+=e}),i.on(`error`,e=>{l(e instanceof Error?e.message:String(e))}),i.on(`close`,e=>{l(e===0?null:`Bytecode printer exited with code ${e}`)}),i.stdin.end(e)})}async function j(e,t=15e3){let n=re(e.functionName),r=Array.from(new Set([n,T])),i=E(e);for(let e of r){let{stdout:a,stderr:o,error:s}=await A(i,e,t),c=D(a,r);if(c.bytecode){let e=c.matchedFunctionName===T?n:c.matchedFunctionName;return{available:!0,bytecode:c.bytecode,format:`ignition-bytecode`,functionName:e??n,reason:`Ignition bytecode emitted by an isolated V8 process via --print-bytecode from the extracted source slice`,rawIgnitionBytecodeAvailable:!0}}if(s&&e===r.at(-1))return{available:!1,bytecode:null,format:null,functionName:n,reason:k(a,o,s),rawIgnitionBytecodeAvailable:!1}}return{available:!1,bytecode:null,format:null,functionName:n,reason:`Isolated V8 bytecode printer did not emit a matching function block`,rawIgnitionBytecodeAvailable:!1}}function M(e){return typeof e==`object`&&!!e}function N(e){return M(e)&&typeof e.createCDPSession==`function`}function P(e){return typeof e==`number`&&Number.isFinite(e)?e:null}function F(e){return typeof e==`string`?e:null}function I(e){return Array.isArray(e)?e.filter(M):[]}function L(e){return e.split(`,`).map(e=>e.trim()).filter(e=>e.length>0)}function R(e){let t=e.trim();if(t.startsWith(`function `))return{opcode:`FunctionDeclaration`,operands:[]};if(t.startsWith(`return `))return{opcode:`Return`,operands:[t.slice(7)]};if(t.includes(`=>`))return{opcode:`CreateClosure`,operands:[]};if(t.includes(`(`)&&t.includes(`)`)){let e=/^([A-Za-z_$][\w$]*)\(/u.exec(t);if(e?.[1])return{opcode:`Call`,operands:[e[1]]}}if(t.includes(`=`)){let e=t.split(`=`,2),n=e[0],r=e[1];if(n&&r)return{opcode:`Store`,operands:[n.trim(),r.trim()]}}return t.startsWith(`if `)?{opcode:`JumpIfTrue`,operands:[t]}:t.startsWith(`for `)||t.startsWith(`while `)?{opcode:`Loop`,operands:[t]}:t.startsWith(`{`)||t.startsWith(`const `)||t.startsWith(`let `)?{opcode:`LoadLiteral`,operands:[t]}:{opcode:`Evaluate`,operands:[t]}}function z(e){let t=[`; pseudo-bytecode synthesized from script source`],n=0;for(let r of e.split(/\r?\n/u)){let e=r.trim();if(e.length===0)continue;let{opcode:i,operands:a}=R(e),o=a.join(`, `);t.push(`${n} ${i}${o.length>0?` ${o}`:``}`),n+=1}return t.join(`
|
|
55
|
+
`)}function B(e,t){if(typeof t==`number`&&t>=0&&t<e.length){let n=Math.max(0,t-120),r=Math.min(e.length,t+120),i=e.slice(n,r),a=/function\s+([A-Za-z_$][\w$]*)/u.exec(i);if(a?.[1])return a[1];let o=/([A-Za-z_$][\w$]*)\s*=\s*(?:async\s*)?\(/u.exec(i);if(o?.[1])return o[1]}return/function\s+([A-Za-z_$][\w$]*)/u.exec(e)?.[1]??`anonymous`}function V(e){let t=e.matchAll(/\{([^{}]+:[^{}]+)\}/gu),n=[],r=0;for(let e of t){let t=e[1];if(!t)continue;let i=t.split(`,`).map(e=>e.trim()).map(e=>{let[t]=e.split(`:`,1);return t?.trim()??``}).filter(e=>e.length>0).filter((e,t,n)=>n.indexOf(e)===t);i.length!==0&&(n.push({address:`hidden-class-${r}`,properties:i,transitionMap:i.length>1?i.join(` -> `):void 0}),r+=1)}return n}function ae(e){let t=e.result;return M(t)&&t.value!==void 0?t.value:t}function H(e){let t=F(e.reason);if(t)return t;let n=F(e.disassemblyError);if(n)return n;let r=F(e.disassemblyType);return r?`Native disassembly returned ${r} instead of text`:`Runtime disassembly output is not exposed through the current browser/CDP path`}var U=class{getPage;versionDetector;constructor(t){this.getPage=t,this.versionDetector=new e(t)}async extractBytecode(e,t){let n=await this.resolveScriptFunctionContext(e,t);return n?{functionName:n.functionName,bytecode:z(n.sourceSlice),sourcePosition:n.sourcePosition}:null}async attemptNativeBytecodeExtraction(e,t){let n=await this.resolveScriptFunctionContext(e,t);if(!n)return null;if(!await this.versionDetector.supportsNativesSyntax())return{available:!1,bytecode:null,format:null,functionName:n.functionName,rawIgnitionBytecodeAvailable:!1,reason:`V8 natives syntax is unavailable in the current browser target`,sourcePosition:n.sourcePosition,supportsNativesSyntax:!1};let r=await this.createSession();if(!r)return{available:!1,bytecode:null,format:null,functionName:n.functionName,rawIgnitionBytecodeAvailable:!1,reason:`Browser/page CDP session is unavailable for native bytecode inspection`,sourcePosition:n.sourcePosition,supportsNativesSyntax:!0};try{let e=await r.send(`Runtime.evaluate`,{expression:this.buildNativeExtractionExpression(n.functionName),returnByValue:!0,awaitPromise:!1});if(!M(e))return{available:!1,bytecode:null,format:null,functionName:n.functionName,rawIgnitionBytecodeAvailable:!1,reason:`Runtime.evaluate did not return structured data`,sourcePosition:n.sourcePosition,supportsNativesSyntax:!0};if(e.exceptionDetails)return{available:!1,bytecode:null,format:null,functionName:n.functionName,rawIgnitionBytecodeAvailable:!1,reason:`Runtime.evaluate raised an exception while probing native bytecode`,sourcePosition:n.sourcePosition,supportsNativesSyntax:!0};let t=ae(e),i=M(t)?t:{},a=F(i.disassembly),o=P(i.nativeSourcePosition);if(a&&a.length>0)return{available:!0,bytecode:a,format:`v8-disassembly`,functionName:n.functionName,rawIgnitionBytecodeAvailable:!1,reason:`Native V8 disassembly text returned via %DisassembleFunction`,sourcePosition:o??n.sourcePosition,supportsNativesSyntax:!0};let s=await j(n);return s.available&&s.bytecode?{available:!0,bytecode:s.bytecode,format:s.format,functionName:s.functionName,rawIgnitionBytecodeAvailable:s.rawIgnitionBytecodeAvailable,reason:s.reason,sourcePosition:o??n.sourcePosition,supportsNativesSyntax:!0}:{available:!1,bytecode:null,format:null,functionName:n.functionName,rawIgnitionBytecodeAvailable:!1,reason:`${H(i)}; isolated printer: ${s.reason}`,sourcePosition:o??n.sourcePosition,supportsNativesSyntax:!0}}catch(e){return{available:!1,bytecode:null,format:null,functionName:n.functionName,rawIgnitionBytecodeAvailable:!1,reason:e instanceof Error?e.message:String(e),sourcePosition:n.sourcePosition,supportsNativesSyntax:!0}}finally{await r.detach().catch(()=>void 0)}}disassembleBytecode(e){let t=[];for(let n of e.split(/\r?\n/u)){let e=n.trim();if(e.length===0||e.startsWith(`;`))continue;let r=/^\d+\s+\w+>\s+[0-9A-Fa-f]+\s+@\s*(\d+)\s*:\s*(?:[0-9A-Fa-f]{2}(?:\s+[0-9A-Fa-f]{2})*\s+)?([A-Za-z_][\w.]*)\s*(.*)$/u.exec(e)??/^(\d+)\s*@\s*([A-Za-z_][\w.]*)\s*(.*)$/u.exec(e)??/^(?:0x[0-9a-fA-F]+\s+@)?\s*(\d+)\s*[: ]\s*([A-Za-z_][\w.]*)\s*(.*)$/u.exec(e)??/^(\d+)\s+([A-Za-z_][\w.]*)\s*(.*)$/u.exec(e);if(!r)continue;let i=Number(r[1]);Number.isFinite(i)&&t.push({offset:i,opcode:r[2]??`Unknown`,operands:L(r[3]??``)})}return t}async findHiddenClasses(e){let t=await this.getScriptSource(e);return t?V(t):[]}buildNativeExtractionExpression(e){return`
|
|
56
|
+
(() => {
|
|
57
|
+
const functionName = ${JSON.stringify(e)};
|
|
58
|
+
try {
|
|
59
|
+
const candidate = globalThis[functionName];
|
|
60
|
+
if (typeof candidate !== 'function') {
|
|
61
|
+
return {
|
|
62
|
+
functionName,
|
|
63
|
+
reason: 'Resolved function is not reachable via globalThis in the current target',
|
|
64
|
+
};
|
|
65
|
+
}
|
|
66
|
+
|
|
67
|
+
const nativeSourcePosition = (() => {
|
|
68
|
+
try {
|
|
69
|
+
return %FunctionGetScriptSourcePosition(candidate);
|
|
70
|
+
} catch (error) {
|
|
71
|
+
return null;
|
|
72
|
+
}
|
|
73
|
+
})();
|
|
74
|
+
|
|
75
|
+
try {
|
|
76
|
+
const disassembly = %DisassembleFunction(candidate);
|
|
77
|
+
return {
|
|
78
|
+
functionName,
|
|
79
|
+
disassembly: typeof disassembly === 'string' ? disassembly : null,
|
|
80
|
+
disassemblyType: typeof disassembly,
|
|
81
|
+
nativeSourcePosition:
|
|
82
|
+
typeof nativeSourcePosition === 'number' ? nativeSourcePosition : null,
|
|
83
|
+
};
|
|
84
|
+
} catch (error) {
|
|
85
|
+
return {
|
|
86
|
+
functionName,
|
|
87
|
+
disassemblyError: String(error),
|
|
88
|
+
nativeSourcePosition:
|
|
89
|
+
typeof nativeSourcePosition === 'number' ? nativeSourcePosition : null,
|
|
90
|
+
};
|
|
91
|
+
}
|
|
92
|
+
} catch (error) {
|
|
93
|
+
return {
|
|
94
|
+
functionName,
|
|
95
|
+
reason: String(error),
|
|
96
|
+
};
|
|
97
|
+
}
|
|
98
|
+
})()
|
|
99
|
+
`}async resolveScriptFunctionContext(e,t){let n=await this.getScriptSource(e);if(!n)return null;let r=await this.getCoverageFunctions(e),i=(typeof t==`number`?r.find(e=>t>=e.startOffset&&t<=e.endOffset):void 0)??r.find(e=>e.functionName.length>0&&e.functionName!==`anonymous`)??r[0],a=i?.functionName&&i.functionName.length>0&&i.functionName!==`anonymous`?i.functionName:B(n,t),o=i&&i.endOffset>i.startOffset?n.slice(i.startOffset,i.endOffset):n;return{functionName:a,sourcePosition:typeof t==`number`?t:i?i.startOffset:void 0,sourceSlice:o}}async getCoverageFunctions(e){let t=await this.createSession();if(!t)return[];try{await t.send(`Profiler.enable`),await t.send(`Profiler.startPreciseCoverage`,{callCount:!0,detailed:!0});let n=await t.send(`Profiler.takePreciseCoverage`),r=(M(n)?I(n.result):[]).find(t=>typeof t.scriptId==`string`&&t.scriptId===e);if(!r)return[];let i=I(r.functions),a=[];for(let e of i){let t=I(e.ranges)[0];if(!t)continue;let n=P(t.startOffset),r=P(t.endOffset);n===null||r===null||a.push({functionName:F(e.functionName)??`anonymous`,startOffset:n,endOffset:r})}return a}catch{return[]}finally{await t.send(`Profiler.stopPreciseCoverage`).catch(()=>void 0),await t.send(`Profiler.disable`).catch(()=>void 0),await t.detach().catch(()=>void 0)}}async getScriptSource(e){let t=await this.createSession();if(!t)return null;try{await t.send(`Debugger.enable`);let n=await t.send(`Debugger.getScriptSource`,{scriptId:e});if(!M(n))return null;let r=n.scriptSource;return typeof r==`string`?r:null}catch{return null}finally{await t.send(`Debugger.disable`).catch(()=>void 0),await t.detach().catch(()=>void 0)}}async createSession(){if(!this.getPage)return null;try{let e=await this.getPage();return N(e)?await e.createCDPSession():null}catch{return null}}};function W(e){return typeof e==`object`&&!!e}function G(e){return W(e)&&typeof e.createCDPSession==`function`}function K(e){if(typeof e==`number`&&Number.isFinite(e))return e;if(W(e)&&typeof e.value==`number`){let t=e.value;return typeof t==`number`&&Number.isFinite(t)?t:null}return null}function q(e){return e===null?{optimized:!1,tier:`unknown`}:e&128?{optimized:!0,tier:`maglev`}:e&64?{optimized:!0,tier:`turbofan`}:e&16||e&32?{optimized:!0,tier:`optimized`}:{optimized:!1,tier:`interpreted`}}var J=class{getPage;bytecodeExtractor;versionDetector;optimizedFunctionsCache=[];constructor(t){this.getPage=t,this.bytecodeExtractor=new U(t),this.versionDetector=new e(t)}async inspectJIT(e){let t=await this.bytecodeExtractor.findHiddenClasses(e),n=await this.bytecodeExtractor.extractBytecode(e),r=new Set;n&&r.add(n.functionName);for(let e of t){let t=e.properties[0];t&&r.add(t)}r.size===0&&r.add(`anonymous`);let i=await this.versionDetector.supportsNativesSyntax(),a=[];for(let e of r){let{optimized:t,tier:n}=q(i?await this.getOptimizationStatus(e):null);a.push({functionName:e,optimized:t,tier:n})}return this.optimizedFunctionsCache=a,{functions:a,supportsNativesSyntax:i,inspectionMode:i?`native-status`:`heuristic`}}async forceDeoptimization(e){if(!await this.versionDetector.supportsNativesSyntax())return;let t=await this.createSession();if(t)try{await t.send(`Runtime.evaluate`,{expression:`
|
|
100
|
+
(() => {
|
|
101
|
+
try {
|
|
102
|
+
const candidate = eval(${JSON.stringify(e)});
|
|
103
|
+
if (typeof candidate === 'function') {
|
|
104
|
+
%DeoptimizeFunction(candidate);
|
|
105
|
+
}
|
|
106
|
+
} catch (error) {
|
|
107
|
+
return undefined;
|
|
108
|
+
}
|
|
109
|
+
return undefined;
|
|
110
|
+
})()
|
|
111
|
+
`,returnByValue:!0,awaitPromise:!1})}finally{await t.detach().catch(()=>void 0)}}async getOptimizedFunctions(){return[...this.optimizedFunctionsCache]}async getOptimizationStatus(e){let t=await this.createSession();if(!t)return null;try{let n=await t.send(`Runtime.evaluate`,{expression:`
|
|
112
|
+
(() => {
|
|
113
|
+
try {
|
|
114
|
+
const candidate = globalThis[${JSON.stringify(e)}];
|
|
115
|
+
if (typeof candidate !== 'function') {
|
|
116
|
+
return null;
|
|
117
|
+
}
|
|
118
|
+
return %GetOptimizationStatus(candidate);
|
|
119
|
+
} catch (error) {
|
|
120
|
+
return null;
|
|
121
|
+
}
|
|
122
|
+
})()
|
|
123
|
+
`,returnByValue:!0,awaitPromise:!1});return W(n)?K(n.result):null}catch{return null}finally{await t.detach().catch(()=>void 0)}}async createSession(){if(!this.getPage)return null;try{let e=await this.getPage();return G(e)?await e.createCDPSession():null}catch{return null}}};async function oe(e,i){let a=t(e,`scriptId`,``).trim(),o=n(e,`functionOffset`),s=r(e,`includeSourceFallback`,!1);if(a.length===0)return{success:!1,error:`scriptId is required`};let c=new U(i?.getPage),l=await c.attemptNativeBytecodeExtraction(a,o??void 0);if(!l)return{success:!1,error:`Unable to inspect bytecode for scriptId "${a}"`};let u=await c.findHiddenClasses(a);if(l.available&&l.bytecode){let e={functionName:l.functionName,bytecode:l.bytecode,sourcePosition:l.sourcePosition};return{success:!0,scriptId:a,functionOffset:o??null,mode:`native`,bytecodeAvailable:!0,format:l.format,rawIgnitionBytecodeAvailable:l.rawIgnitionBytecodeAvailable,supportsNativesSyntax:l.supportsNativesSyntax,reason:l.reason,extraction:e,disassembly:c.disassembleBytecode(l.bytecode),hiddenClasses:u,sourceFallback:null}}let d=s?await c.extractBytecode(a,o??void 0):null;return{success:!0,scriptId:a,functionOffset:o??null,mode:d?`source-fallback`:`unavailable`,bytecodeAvailable:!1,format:null,rawIgnitionBytecodeAvailable:l.rawIgnitionBytecodeAvailable,supportsNativesSyntax:l.supportsNativesSyntax,reason:l.reason,extraction:null,disassembly:[],hiddenClasses:u,sourceFallback:d?{format:`pseudo-bytecode`,extraction:d,disassembly:c.disassembleBytecode(d.bytecode)}:null}}async function se(e,n){let r=t(e,`scriptId`,``).trim();if(r.length===0)return{success:!1,error:`scriptId is required`};let i=await new J(n?.getPage).inspectJIT(r);return{success:!0,scriptId:r,inspectionMode:i.inspectionMode,supportsNativesSyntax:i.supportsNativesSyntax,functions:i.functions}}function ce(e){return{kind:`runtime-object`,source:`debugger-session`,propertyCount:e.length,properties:e}}function Y(e,t){let n=e[t];if(typeof n!=`string`||n.length===0)throw Error(`${t} is required`);return n}function X(e){let t=e.pageController;if(!t)throw Error(`PageController not available`);return t}function Z(e){return new h(Q(e))}function Q(e){let t=X(e);return async()=>await t.getPage()}var $=class{deps;currentSnapshotId=null;constructor(e){this.deps=e}async handle(e,t){let n={v8_heap_snapshot_capture:e=>this.v8_heap_snapshot_capture(e),v8_heap_snapshot_analyze:e=>this.v8_heap_snapshot_analyze(e),v8_heap_diff:e=>this.v8_heap_diff(e),v8_object_inspect:e=>this.v8_object_inspect(e),v8_heap_stats:e=>this.v8_heap_stats(e),v8_bytecode_extract:e=>this.v8_bytecode_extract(e),v8_version_detect:e=>this.v8_version_detect(e),v8_jit_inspect:e=>this.v8_jit_inspect(e)}[e];if(!n)throw Error(`Unknown v8-inspector tool: ${e}`);return n(t)}async v8_heap_snapshot_capture(e){X(this.deps.ctx);let t=await C(e,{getPage:Q(this.deps.ctx),getSnapshot:()=>this.currentSnapshotId,setSnapshot:e=>{this.currentSnapshotId=e},client:this.deps.client});return t.success&&t.snapshotId&&this.deps.ctx.eventBus.emit(`v8:heap_captured`,{snapshotId:t.snapshotId,sizeBytes:t.sizeBytes,timestamp:t.capturedAt}),t}async v8_heap_snapshot_analyze(e){let t=Y(e,`snapshotId`),n=y(t);if(!n)throw Error(`Snapshot ${t} not found`);return{success:!0,snapshotId:t,summary:{chunkCount:n.chunks.length,sizeBytes:n.sizeBytes},objectAddress:`0x${n.sizeBytes.toString(16)}`}}async v8_heap_diff(e){let t=typeof e.beforeSnapshotId==`string`?e.beforeSnapshotId:void 0,n=typeof e.afterSnapshotId==`string`?e.afterSnapshotId:void 0;if(!t||!n)throw Error(`Both beforeSnapshotId and afterSnapshotId are required`);let r=y(t);if(!r)throw Error(`Snapshot ${t} not found`);let i=y(n);if(!i)throw Error(`Snapshot ${n} not found`);return{success:!0,beforeSnapshotId:t,afterSnapshotId:n,sizeDeltaBytes:i.sizeBytes-r.sizeBytes}}async v8_object_inspect(e){let t=Y(e,`address`),n=await this.inspectObjectViaDebugger(t);if(!n)try{n=await this.deps.client.getObjectByObjectId(t)??void 0}catch{}return{success:!0,address:t,...n?{objectData:n}:{}}}async v8_heap_stats(e){X(this.deps.ctx);let t;try{t=await this.deps.client.getHeapUsage()}catch{}return{success:!0,snapshotCount:te().size,...t?{heapUsage:t}:{}}}async v8_bytecode_extract(e){return oe(e,{getPage:this.deps.ctx.pageController?Q(this.deps.ctx):void 0})}async v8_version_detect(e){if(!this.deps.ctx.pageController)return{success:!1,error:`PageController not available`};let{VersionDetector:t}=await import(`./VersionDetector-DMoUWyNm.mjs`).then(e=>e.n),n=new t(Q(this.deps.ctx));return{success:!0,version:await n.detectV8Version(),features:{nativesSyntax:await n.supportsNativesSyntax()}}}async v8_jit_inspect(e){return se(e,{getPage:this.deps.ctx.pageController?Q(this.deps.ctx):void 0})}async inspectObjectViaDebugger(e){let t=this.deps.ctx.debuggerManager;if(!(!t||typeof t.getObjectPropertiesById!=`function`))try{let n=await t.getObjectPropertiesById(e);return Array.isArray(n)?ce(n):void 0}catch{return}}};const le=g.map(e=>({tool:e,domain:`v8-inspector`,bind:i(`v8InspectorHandlers`,(t,n)=>t.handle(e.name,n))}));async function ue(e){if(!e.pageController)throw Error(`v8-inspector: PageController not available`);let t=new $({ctx:e,client:Z(e)});return e.v8InspectorHandlers=t,t}const de={kind:`domain-manifest`,version:1,domain:`v8-inspector`,depKey:`v8InspectorHandlers`,profiles:[`workflow`,`full`],registrations:le,ensure:ue,prerequisites:{v8_heap_snapshot_capture:[{condition:`Browser must be connected`,fix:`Call browser_launch or browser_attach first`}],v8_heap_snapshot_analyze:[{condition:`A snapshotId must be provided`,fix:`Capture a heap snapshot before analysis`}],v8_heap_diff:[{condition:`Both snapshot identifiers are required`,fix:`Capture before/after snapshots before diffing`}]},toolDependencies:[{from:`v8_heap_snapshot_capture`,to:`browser_attach`,relation:`requires`,weight:.8},{from:`v8_object_inspect`,to:`v8_heap_snapshot_analyze`,relation:`precedes`,weight:.6}],workflowRule:{patterns:[/v8.*heap/i,/heap.*snapshot/i,/jit/i,/object.*address/i],priority:80,tools:[`v8_heap_snapshot_capture`,`v8_heap_snapshot_analyze`,`v8_object_inspect`,`v8_heap_stats`],hint:`Capture a heap snapshot, analyze it, then inspect interesting objects by address.`}};export{$ as V8InspectorHandlers,de as default};
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
import{t as e}from"./registry-DUHIPE-v.mjs";import{n as t}from"./bind-helpers-BlAOQrFQ.mjs";import{t as n}from"./tool-builder-CI9914Tf.mjs";const r=[n(`trace_recording`,e=>e.desc(`Start or stop trace recording into a SQLite database.`).enum(`action`,[`start`,`stop`],`Recording action`).array(`cdpDomains`,{type:`string`},`CDP domains to record (default: Debugger, Runtime, Network, Page)`).boolean(`recordMemoryDeltas`,`Record memory write deltas`,{default:!0}).boolean(`recordResponseBodies`,`Persist response bodies when available.`,{default:!0}).boolean(`streamResponseChunks`,`Capture response chunks when the browser supports it.`,{default:!0}).number(`networkBodyMaxBytes`,`Maximum response body bytes to persist per request`,{default:10485760,minimum:1024,maximum:104857600}).number(`networkInlineBodyBytes`,`Bodies up to this size are stored inline in SQLite; larger ones go to artifacts`,{default:262144,minimum:1024,maximum:10485760}).required(`action`).idempotent()),n(`start_trace_recording`,e=>e.desc(`Start recording debugger traces into a SQLite database for time-travel.`).array(`cdpDomains`,{type:`string`},`CDP domains to record (default: Debugger, Runtime, Network, Page)`).boolean(`recordMemoryDeltas`,`Record memory write deltas`,{default:!0}).boolean(`recordResponseBodies`,`Persist response bodies when available.`,{default:!0}).boolean(`streamResponseChunks`,`Capture response chunks when the browser supports it.`,{default:!0}).number(`networkBodyMaxBytes`,`Maximum response body bytes to persist per request`,{default:10485760,minimum:1024,maximum:104857600}).number(`networkInlineBodyBytes`,`Bodies up to this size are stored inline in SQLite; larger ones go to artifacts`,{default:262144,minimum:1024,maximum:10485760}).idempotent()),n(`stop_trace_recording`,e=>e.desc(`Stop trace recording and return the final session summary.`).idempotent()),n(`query_trace_sql`,e=>e.desc(`Execute a read-only SQL query against a trace database.`).string(`sql`,`SQL query to execute (SELECT only — write operations are rejected)`).string(`dbPath`,`Path to trace DB file. Uses the active recording if omitted.`).required(`sql`).query()),n(`seek_to_timestamp`,e=>e.desc(`Reconstruct trace state at a specific timestamp.`).number(`timestamp`,`Target timestamp in milliseconds`).string(`dbPath`,`Path to trace DB file. Uses the active recording if omitted.`).number(`windowMs`,`Time window around timestamp to include in ms`,{default:100}).enum(`timeDomain`,[`wall`,`monotonic`],`Interpret timestamp using wall or monotonic time`,{default:`wall`}).required(`timestamp`).query()),n(`trace_get_network_flow`,e=>e.desc(`Get a recorded request-scoped network flow from a trace.`).string(`requestId`,`Network requestId to retrieve from the trace`).string(`dbPath`,`Path to trace DB file. Uses the active recording if omitted.`).boolean(`includeBody`,`Include persisted response body metadata/content when available`,{default:!0}).boolean(`includeChunks`,`Include recorded response chunk timing data`,{default:!0}).boolean(`includeEvents`,`Include related network events from the trace`,{default:!0}).number(`chunkLimit`,`Maximum number of chunks to return`,{default:200,minimum:1,maximum:5e3}).number(`maxBodyBytes`,`Maximum response body bytes to inline before summarizing`,{default:1e5,minimum:1024,maximum:52428800}).boolean(`returnSummary`,`Return body summary even when body is within maxBodyBytes`,{default:!1}).required(`requestId`).query()),n(`diff_heap_snapshots`,e=>e.desc(`Compare two heap snapshots from a trace.`).number(`snapshotId1`,`First snapshot ID (earlier)`).number(`snapshotId2`,`Second snapshot ID (later)`).string(`dbPath`,`Path to trace DB file. Uses the active recording if omitted.`).required(`snapshotId1`,`snapshotId2`).query()),n(`export_trace`,e=>e.desc(`Export a trace database to Chrome Trace Event JSON.`).string(`dbPath`,`Path to trace DB file. Uses the active recording if omitted.`).string(`outputPath`,`Output JSON file path. Auto-generated if omitted.`).idempotent()),n(`summarize_trace`,e=>e.desc(`Generate a compact summary of a trace database.`).enum(`detail`,[`compact`,`balanced`,`full`],`Summary detail level`,{default:`balanced`}).string(`dbPath`,`Path to trace DB file. Uses the active recording if omitted.`).query())],i=`trace`,a=`traceHandlers`,o=t({domain:i,depKey:a,lookup:e(r),entries:[{tool:`trace_recording`,method:`handleTraceRecording`},{tool:`start_trace_recording`,method:`handleStartTraceRecording`},{tool:`stop_trace_recording`,method:`handleStopTraceRecording`},{tool:`query_trace_sql`,method:`handleQueryTraceSql`},{tool:`seek_to_timestamp`,method:`handleSeekToTimestamp`},{tool:`trace_get_network_flow`,method:`handleGetTraceNetworkFlow`},{tool:`diff_heap_snapshots`,method:`handleDiffHeapSnapshots`},{tool:`export_trace`,method:`handleExportTrace`},{tool:`summarize_trace`,method:`handleSummarizeTrace`}]});async function s(e){let{TraceRecorder:t}=await import(`./TraceRecorder-Dd8jLXpi.mjs`),{TraceToolHandlers:n}=await import(`./handlers-DmQzIc44.mjs`);return(!e.traceRecorder||!e.traceHandlers)&&(e.traceRecorder||=new t,e.traceHandlers||=new n(e.traceRecorder,e)),e.traceHandlers}const c={kind:`domain-manifest`,version:1,domain:i,depKey:a,profiles:[`full`],ensure:s,prerequisites:{},workflowRule:{patterns:[/trace/i,/time.?travel/i,/replay/i,/recorded?\s+events?/i],priority:70,tools:[`trace_recording`,`start_trace_recording`,`stop_trace_recording`,`query_trace_sql`,`seek_to_timestamp`,`trace_get_network_flow`,`diff_heap_snapshots`,`export_trace`,`summarize_trace`],hint:`Start recording → perform actions → stop recording → summarize/query/seek/diff/export`},registrations:o};export{c as default};
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
import{t as e}from"./registry-DUHIPE-v.mjs";import{n as t}from"./bind-helpers-BlAOQrFQ.mjs";import{t as n}from"./tool-builder-CI9914Tf.mjs";const r=[n(`adb_apk_analyze`,e=>e.desc(`Analyze an installed APK: package, permissions, activities, and security info.`).string(`serial`,`Required. Android device serial or emulator id.`).string(`packageName`,`Required. Android package name, for example com.example.app.`).requiredOpenWorld(`serial`,`packageName`)),n(`adb_webview_list`,e=>e.desc(`List debuggable WebView targets connected via ADB.`).string(`serial`,`Required. Android device serial or emulator id.`).number(`hostPort`,`Optional. Local port to use for forwarding.`,{default:9222}).requiredOpenWorld(`serial`)),n(`adb_webview_attach`,e=>e.desc(`Attach to a WebView via ADB; returns WebSocket debugger URL for CDP.`).string(`serial`,`Required. Android device serial or emulator id.`).string(`targetId`,`Required. WebView target id returned by adb_webview_list.`).number(`hostPort`,`Optional. Local port to use for forwarding.`,{default:9222}).requiredOpenWorld(`serial`,`targetId`))],i=`adb-bridge`,a=`adbBridgeHandlers`,o=t({domain:i,depKey:a,lookup:e(r),entries:[{tool:`adb_apk_analyze`,method:`handleAnalyzeApk`},{tool:`adb_webview_list`,method:`handleWebViewList`},{tool:`adb_webview_attach`,method:`handleWebViewAttach`}]});async function s(e){let{ADBBridgeHandlers:t}=await import(`./handlers-S9Ws0IGy.mjs`),n=e.getDomainInstance(a);if(n)return n;let r=new t;return e.setDomainInstance(a,r),r}const c={kind:`domain-manifest`,version:1,domain:i,depKey:a,profiles:[`full`],registrations:o,ensure:s,workflowRule:{patterns:[/(android|adb|mobile|apk|device).*(list|shell|pull|analyze|dump)/i,/(adb|android).*(webview|chrome|debug|cdp|inspect)/i],priority:75,tools:[`adb_apk_analyze`,`adb_webview_list`,`adb_webview_attach`],hint:`Android/ADB: list devices → run shell commands → pull/analyze APK → debug WebViews via CDP`},prerequisites:{"*":[{condition:`ADB server binary must be in PATH`,fix:`Install Android Platform Tools: https://developer.android.com/studio/command-line/adb`}],adb_webview_list:[{condition:`App must have android:debuggable="true"`,fix:`Use a debug build of the Android app`}],adb_webview_attach:[{condition:`App must have android:debuggable="true"`,fix:`Use a debug build of the Android app`}]},toolDependencies:[{from:`browser`,to:`adb-bridge`,relation:`uses`,weight:.7}]};export{c as default};
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
import{t as e}from"./registry-DUHIPE-v.mjs";import{n as t}from"./bind-helpers-BlAOQrFQ.mjs";import{t as n}from"./ensure-browser-core-Buls24LQ.mjs";import{n as r,t as i}from"./definitions-CCP9gphV.mjs";const a=`hooks`,o=`aiHookHandlers`,s=e([...i,...r]),c=t({domain:a,depKey:o,lookup:s,entries:[{tool:`ai_hook`,method:`handleAIHook`}]}),l=t({domain:a,depKey:`hookPresetHandlers`,lookup:s,entries:[{tool:`hook_preset`,method:`handleHookPreset`}]});async function u(e){let{AIHookToolHandlers:t,HookPresetToolHandlers:r}=await import(`./hooks-DDKppogd.mjs`);return await n(e),(!e.aiHookHandlers||!e.hookPresetHandlers)&&(e.aiHookHandlers||=new t(e.pageController),e.hookPresetHandlers||=new r(e.pageController)),e.aiHookHandlers}const d={kind:`domain-manifest`,version:1,domain:a,depKey:o,secondaryDepKeys:[`hookPresetHandlers`],profiles:[`full`],ensure:u,registrations:[...c,...l]};export{d as default};
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
import{t as e}from"./registry-DUHIPE-v.mjs";import{n as t}from"./bind-helpers-BlAOQrFQ.mjs";import{t as n}from"./definitions-BGobEDQa.mjs";import{resolve as r}from"node:path";const i=`shared-state-board`,a=`sharedStateBoardHandlers`,o=t({domain:i,depKey:a,lookup:e(n),entries:[{tool:`state_board`,method:`handleDispatch`},{tool:`state_board_watch`,method:`handleWatchDispatch`},{tool:`state_board_io`,method:`handleIODispatch`}]});async function s(e){let{SharedStateBoardHandlers:t}=await import(`./shared-state-board-Cyg-xh_k.mjs`);e.sharedStateBoardHandlers||=new t;let n=e.getDomainInstance(`snapshotScheduler`),i=e.getDomainInstance(`snapshotStateDir`);return e.sharedStateBoardHandlers.setPersistNotifier(n?()=>n.notifyDirty():void 0),n&&i&&!e.getDomainInstance(`sharedStateBoardSnapshotRegistered`)&&(n.register(r(i,`state-board`,`current.json`),e.sharedStateBoardHandlers.getStore()),e.setDomainInstance(`sharedStateBoardSnapshotRegistered`,!0)),e.sharedStateBoardHandlers}const c={kind:`domain-manifest`,version:1,domain:i,depKey:a,profiles:[`workflow`,`full`],ensure:s,registrations:o};export{c as default};
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
import{t as e}from"./registry-DUHIPE-v.mjs";import{n as t}from"./bind-helpers-BlAOQrFQ.mjs";import{t as n}from"./tool-builder-CI9914Tf.mjs";const r=[n(`extension_list_installed`,e=>e.desc(`List installed extensions from the local registry.`).query()),n(`extension_execute_in_context`,e=>e.desc(`Load an extension and execute a named exported context function.`).string(`pluginId`,`Plugin identifier`).string(`contextName`,`Exported function or context name`).prop(`args`,{type:`object`,description:`Arguments passed to the target context`,additionalProperties:!0}).requiredOpenWorld(`pluginId`,`contextName`)),n(`extension_reload`,e=>e.desc(`Reload an installed extension by unloading and loading it again.`).string(`pluginId`,`Plugin identifier`).requiredOpenWorld(`pluginId`)),n(`extension_uninstall`,e=>e.desc(`Uninstall an extension from the local registry.`).string(`pluginId`,`Plugin identifier`).required(`pluginId`).destructive()),n(`webhook`,e=>e.desc(`Manage webhook endpoints for external callbacks. Actions: create, list, delete, commands.`).enum(`action`,[`create`,`list`,`delete`,`commands`],`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`,{type:`object`,description:`Command to enqueue (action=commands, if provided adds to queue instead of listing)`,additionalProperties:!0}).required(`action`))],i=`extension-registry`,a=`extensionRegistryHandlers`,o=t({domain:i,depKey:a,lookup:e(r),entries:[{tool:`extension_list_installed`,method:`handleListInstalled`},{tool:`extension_execute_in_context`,method:`handleExecuteInContext`},{tool:`extension_reload`,method:`handleReload`},{tool:`extension_uninstall`,method:`handleUninstall`},{tool:`webhook`,method:`handleWebhookDispatch`}]});async function s(e){let{ExtensionRegistryHandlers:t}=await import(`./handlers-BZoPla6E.mjs`),n=e.getDomainInstance(a);if(n)return n;let r=new t;return e.setDomainInstance(a,r),r.startWebhookServer().catch(()=>void 0),r}const c={kind:`domain-manifest`,version:1,domain:i,depKey:a,profiles:[`full`],ensure:s,registrations:o,workflowRule:{patterns:[/\b(extension|plugin|addon|webhook|c2|bluetooth|ble|hid|serial|esp32|registry)\b/i,/(install|uninstall|reload).*(extension|plugin)/i],priority:70,tools:[`install_extension`,`extension_list_installed`,`webhook`],hint:`Plugin + webhook C2 + BLE HID + serial flashing pipeline.`},prerequisites:{webhook:[{condition:`Webhook listen port must be free`,fix:"Pick an unused port via the `port` argument or stop the conflicting service"}]},toolDependencies:[{from:`webhook`,to:`extension_list_installed`,relation:`suggests`,weight:.5}]};export{c as default};
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
import{t as e}from"./registry-DUHIPE-v.mjs";import{n as t}from"./bind-helpers-BlAOQrFQ.mjs";import{t as n}from"./definitions-Dgrg7f3D.mjs";const r=`network`,i=`advancedHandlers`,a=t({domain:r,depKey:i,lookup:e(n),entries:[{tool:`network_enable`,method:`handleNetworkEnable`},{tool:`network_disable`,method:`handleNetworkDisable`},{tool:`network_get_status`,method:`handleNetworkGetStatus`},{tool:`network_monitor`,method:`handleNetworkMonitor`},{tool:`network_get_requests`,method:`handleNetworkGetRequests`},{tool:`network_get_response_body`,method:`handleNetworkGetResponseBody`},{tool:`network_get_stats`,method:`handleNetworkGetStats`},{tool:`performance_get_metrics`,method:`handlePerformanceGetMetrics`},{tool:`performance_coverage`,method:`handlePerformanceCoverage`},{tool:`performance_take_heap_snapshot`,method:`handlePerformanceTakeHeapSnapshot`},{tool:`performance_trace`,method:`handlePerformanceTraceDispatch`},{tool:`profiler_cpu`,method:`handleProfilerCpuDispatch`},{tool:`profiler_heap_sampling`,method:`handleProfilerHeapSamplingDispatch`},{tool:`console_get_exceptions`,method:`handleConsoleGetExceptions`},{tool:`console_inject`,method:`handleConsoleInjectDispatch`},{tool:`console_inject_fetch_interceptor`,method:`handleConsoleInjectFetchInterceptor`},{tool:`console_inject_xhr_interceptor`,method:`handleConsoleInjectXhrInterceptor`},{tool:`console_buffers`,method:`handleConsoleBuffersDispatch`},{tool:`http_request_build`,method:`handleHttpRequestBuild`},{tool:`http_plain_request`,method:`handleHttpPlainRequest`},{tool:`http2_probe`,method:`handleHttp2Probe`},{tool:`http2_frame_build`,method:`handleHttp2FrameBuild`},{tool:`network_rtt_measure`,method:`handleNetworkRttMeasure`},{tool:`network_latency_stats`,method:`handleNetworkLatencyStats`},{tool:`network_traceroute`,method:`handleNetworkTraceroute`},{tool:`network_icmp_probe`,method:`handleNetworkIcmpProbe`},{tool:`dns_resolve`,method:`handleDnsResolve`},{tool:`dns_reverse`,method:`handleDnsReverse`},{tool:`dns_probe`,method:`handleDnsProbe`},{tool:`dns_cname_chain`,method:`handleDnsCnameChain`},{tool:`dns_bulk_resolve`,method:`handleDnsBulkResolve`},{tool:`network_extract_auth`,method:`handleNetworkExtractAuth`},{tool:`network_export_har`,method:`handleNetworkExportHar`},{tool:`network_replay_request`,method:`handleNetworkReplayRequest`},{tool:`network_intercept`,method:`handleNetworkInterceptDispatch`},{tool:`network_tls_fingerprint`,method:`handleNetworkTlsFingerprint`},{tool:`network_bot_detect_analyze`,method:`handleNetworkBotDetectAnalyze`}]}),o=new Set([`http_request_build`,`http_plain_request`,`http2_probe`,`http2_frame_build`,`network_rtt_measure`,`network_latency_stats`,`network_traceroute`,`network_icmp_probe`,`dns_resolve`,`dns_reverse`,`dns_probe`,`dns_cname_chain`,`dns_bulk_resolve`]);async function s(e){let{AdvancedToolHandlers:t}=await import(`./network-BjZ1Y-GB.mjs`);if(!(e.activatedToolNames instanceof Set)||[...e.activatedToolNames].some(e=>!o.has(e))){let{ensureBrowserCore:t}=await import(`./ensure-browser-core-Buls24LQ.mjs`).then(e=>e.n);await t(e)}return e.advancedHandlers||=new t(e.collector,e.consoleMonitor,e.eventBus,()=>e.traceRecorder??null),e.advancedHandlers}const c={kind:`domain-manifest`,version:1,domain:r,depKey:i,profiles:[`workflow`,`full`],ensure:s,workflowRule:{patterns:[/(capture|intercept|monitor|hook).*(network|request|response|api|traffic)/i,/(抓包|拦截|监控|hook).*(网络|请求|响应|api|流量)/i],priority:100,tools:[`network_monitor`,`page_navigate`,`network_get_requests`],hint:`Network capture workflow: bootstrap browser/page state -> enable capture -> navigate or act -> inspect captured requests. (Tip: list_extension_workflows can suggest higher-level recipes.)`},prerequisites:{network_get_requests:[{condition:`Browser must be launched`,fix:`Call browser_launch or browser_attach first`},{condition:`Network monitoring must be enabled`,fix:`Call network_monitor(enable) first`}],network_get_response_body:[{condition:`Browser must be launched`,fix:`Call browser_launch or browser_attach first`},{condition:`Network monitoring must be enabled`,fix:`Call network_monitor(enable) first`}],network_extract_auth:[{condition:`Network monitoring must be enabled`,fix:`Call network_monitor(enable) first`}]},registrations:a};export{c as default};
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
import{t as e}from"./registry-DUHIPE-v.mjs";import{n as t}from"./bind-helpers-BlAOQrFQ.mjs";import{t as n}from"./definitions-DZ8uKusP.mjs";const r=`proxy`,i=`proxyHandlers`,a=t({domain:r,depKey:i,lookup:e(n),entries:[{tool:`proxy_start`,method:`handleProxyStart`},{tool:`proxy_stop`,method:`handleProxyStop`},{tool:`proxy_status`,method:`handleProxyStatus`},{tool:`proxy_export_ca`,method:`handleProxyExportCa`},{tool:`proxy_add_rule`,method:`handleProxyAddRule`},{tool:`proxy_get_requests`,method:`handleProxyGetRequests`},{tool:`proxy_clear_logs`,method:`handleProxyClearLogs`},{tool:`proxy_setup_adb_device`,method:`handleProxySetupAdbDevice`}]});async function o(e){let{ProxyHandlers:t}=await import(`./proxy-CvRepxgV.mjs`);return e.proxyHandlers||=new t,e.proxyHandlers}const s={kind:`domain-manifest`,version:1,domain:r,depKey:i,profiles:[`full`],ensure:o,registrations:a};export{s as default};
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
import{t as e}from"./registry-DUHIPE-v.mjs";import{n as t}from"./bind-helpers-BlAOQrFQ.mjs";import{t as n}from"./definitions-CIO9O-Sw.mjs";const r=`wasm`,i=`wasmHandlers`,a=t({domain:r,depKey:i,lookup:e(n),entries:[{tool:`wasm_capabilities`,method:`handleWasmCapabilities`},{tool:`wasm_dump`,method:`handleWasmDump`},{tool:`wasm_disassemble`,method:`handleWasmDisassemble`},{tool:`wasm_decompile`,method:`handleWasmDecompile`},{tool:`wasm_inspect_sections`,method:`handleWasmInspectSections`},{tool:`wasm_offline_run`,method:`handleWasmOfflineRun`},{tool:`wasm_optimize`,method:`handleWasmOptimize`},{tool:`wasm_vmp_trace`,method:`handleWasmVmpTrace`},{tool:`wasm_memory_inspect`,method:`handleWasmMemoryInspect`},{tool:`wasm_to_c`,method:`handleWasmToC`},{tool:`wasm_detect_obfuscation`,method:`handleWasmDetectObfuscation`},{tool:`wasm_instrument_trace`,method:`handleWasmInstrumentTrace`}]});async function o(e){let{CodeCollector:t}=await import(`./collector-CKO8RPK8.mjs`),{WasmToolHandlers:n}=await import(`./wasm-DaJa8J0V.mjs`);return e.collector||(e.collector=new t(e.config.puppeteer),e.registerCaches()),e.wasmHandlers||=new n(e.collector),e.wasmHandlers}const s={kind:`domain-manifest`,version:1,domain:r,depKey:i,profiles:[`full`],ensure:o,registrations:a};export{s as default};
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
import{t as e}from"./registry-DUHIPE-v.mjs";import{n as t}from"./bind-helpers-BlAOQrFQ.mjs";import{i as n,n as r,r as i,t as a}from"./definitions-CdWEuIkI.mjs";const o=`maintenance`,s=`coreMaintenanceHandlers`,c=[...n,...r,...a],l=[...i],u=e([...c,...l]),d=t({domain:o,depKey:s,lookup:u,entries:[{tool:`get_token_budget_stats`,method:`handleGetTokenBudgetStats`,profiles:[`workflow`,`full`]},{tool:`manual_token_cleanup`,method:`handleManualTokenCleanup`},{tool:`reset_token_budget`,method:`handleResetTokenBudget`},{tool:`get_cache_stats`,method:`handleGetCacheStats`,profiles:[`workflow`,`full`]},{tool:`smart_cache_cleanup`,method:`handleSmartCacheCleanup`,mapArgs:e=>[e.targetSize]},{tool:`clear_all_caches`,method:`handleClearAllCaches`},{tool:`cleanup_artifacts`,method:`handleCleanupArtifacts`,mapArgs:e=>[{retentionDays:e.retentionDays,maxTotalBytes:e.maxTotalBytes,dryRun:e.dryRun}]},{tool:`doctor_environment`,method:`handleEnvironmentDoctor`,mapArgs:e=>[{includeBridgeHealth:e.includeBridgeHealth}]}]}),f=t({domain:o,depKey:`extensionManagementHandlers`,lookup:u,entries:[{tool:`list_extensions`,method:`handleListExtensions`,profiles:[`workflow`,`full`]},{tool:`reload_extensions`,method:`handleReloadExtensions`},{tool:`browse_extension_registry`,method:`handleBrowseExtensionRegistry`,profiles:[`workflow`,`full`],mapArgs:e=>[e.kind??`all`]},{tool:`install_extension`,method:`handleInstallExtension`,mapArgs:e=>[e.slug,e.targetDir]}]});async function p(e){let{CoreMaintenanceHandlers:t,ExtensionManagementHandlers:n}=await import(`./maintenance-CutEO84j.mjs`);return(!e.coreMaintenanceHandlers||!e.extensionManagementHandlers)&&(e.coreMaintenanceHandlers||=new t({tokenBudget:e.tokenBudget,unifiedCache:e.unifiedCache}),e.extensionManagementHandlers||=new n(e)),e.coreMaintenanceHandlers}const m={kind:`domain-manifest`,version:1,domain:o,depKey:s,secondaryDepKeys:[`extensionManagementHandlers`],profiles:[`workflow`,`full`],ensure:p,registrations:[...d,...f]};export{m as default};
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
import{t as e}from"./registry-DUHIPE-v.mjs";import{n as t}from"./bind-helpers-BlAOQrFQ.mjs";import{t as n}from"./tool-builder-CI9914Tf.mjs";const r=[n(`mojo_ipc_capabilities`,e=>e.desc(`Report Mojo IPC monitoring availability.`).query()),n(`mojo_monitor`,e=>e.desc(`Start or stop Mojo IPC monitoring for the active Chromium-based target.`).enum(`action`,[`start`,`stop`],`Monitor action`).string(`deviceId`,`Optional device or transport identifier (action=start)`).required(`action`)),n(`mojo_decode_message`,e=>e.desc(`Decode a Mojo IPC hex payload into a structured field map.`).string(`hexPayload`,`Hex-encoded Mojo IPC payload`).required(`hexPayload`).query()),n(`mojo_list_interfaces`,e=>e.desc(`List discovered Mojo IPC interfaces and their pending message counts.`).query()),n(`mojo_messages_get`,e=>e.desc(`Retrieve captured Mojo IPC messages from the active monitoring session.`).number(`limit`,`Maximum number of messages to retrieve (default 100)`).string(`interface`,`Filter messages by interface name`).query())],i=`mojo-ipc`,a=`mojoIpcHandlers`,o=t({domain:i,depKey:a,lookup:e(r),entries:[{tool:`mojo_ipc_capabilities`,method:`handleMojoIpcCapabilities`},{tool:`mojo_monitor`,method:`handleMojoMonitorDispatch`},{tool:`mojo_decode_message`,method:`handleMojoDecodeMessage`},{tool:`mojo_list_interfaces`,method:`handleMojoListInterfaces`},{tool:`mojo_messages_get`,method:`handleMojoMessagesGet`}]});async function s(e){let{MojoIPCHandlers:t}=await import(`./mojo-ipc-VGlv3Qyp.mjs`),n=e.getDomainInstance(a);if(n)return n;let r=new t(void 0,void 0,e.eventBus);return e.setDomainInstance(a,r),r}const c={kind:`domain-manifest`,version:1,domain:i,depKey:a,profiles:[`full`],registrations:o,ensure:s,workflowRule:{patterns:[/\b(mojo|ipc|chromium\s?(ipc|message)|interface\s?(broker|registry))\b/i,/(mojo|ipc|chromium).*(monitor|capture|hook|trace)/i],priority:75,tools:[`mojo_monitor`,`mojo_decode_message`,`mojo_list_interfaces`],hint:`Mojo IPC: start monitor → capture messages → decode payloads → correlate with CDP`},prerequisites:{mojo_monitor:[{condition:`Frida must be available for real process attachment`,fix:`Install Frida and ensure the Chromium target process is launched first`}],mojo_decode_message:[{condition:`Captured message payload hex is required`,fix:`Start a monitoring session via mojo_monitor and capture traffic first`}]},toolDependencies:[{from:`browser`,to:`mojo-ipc`,relation:`uses`,weight:.8}]};export{c as default,r as t};
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
import{t as e}from"./registry-DUHIPE-v.mjs";import{n as t}from"./bind-helpers-BlAOQrFQ.mjs";import{t as n}from"./tool-builder-CI9914Tf.mjs";const r=[n(`run_macro`,e=>e.desc(`Execute a registered macro by ID with inline progress and atomic bailout.`).string(`macroId`,`Macro ID to execute`).prop(`inputOverrides`,{type:`object`,description:`Per-step input overrides keyed by step ID`,additionalProperties:{type:`object`,additionalProperties:!0}}).required(`macroId`)),n(`list_macros`,e=>e.desc(`List all available macros.`).query())],i=`macro`,a=`macroHandlers`,o=t({domain:i,depKey:a,lookup:e(r),entries:[{tool:`run_macro`,method:`handleRunMacro`},{tool:`list_macros`,method:`handleListMacros`}]});async function s(e){let{MacroToolHandlers:t}=await import(`./handlers-DCE45Ww8.mjs`),n=e.getDomainInstance(a);if(n)return n;let r=new t(e);return e.setDomainInstance(a,r),r}const c={kind:`domain-manifest`,version:1,domain:i,depKey:a,profiles:[`full`],ensure:s,registrations:o};export{c as default};
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
import{t as e}from"./registry-DUHIPE-v.mjs";import{n as t}from"./bind-helpers-BlAOQrFQ.mjs";import{t as n}from"./tool-builder-CI9914Tf.mjs";const r=[n(`execute_sandbox_script`,e=>e.desc(`Execute JavaScript in an isolated sandbox.`).string(`code`,`JavaScript source code to execute inside the sandbox`).string(`sessionId`,`Session ID for scratchpad persistence across executions`).number(`timeoutMs`,`Execution timeout in ms`,{default:1e3}).boolean(`autoCorrect`,`Retry failed scripts up to 2 times with error context`,{default:!1}).required(`code`))],i=`sandbox`,a=`sandboxHandlers`,o=t({domain:i,depKey:a,lookup:e(r),entries:[{tool:`execute_sandbox_script`,method:`handleExecuteSandboxScript`}]});async function s(e){let{SandboxToolHandlers:t}=await import(`./handlers-DnJRGp7t.mjs`),n=e.getDomainInstance(a);if(n)return n;let r=new t(e);return e.setDomainInstance(a,r),r}const c={kind:`domain-manifest`,version:1,domain:i,depKey:a,profiles:[`full`],ensure:s,registrations:o};export{c as default};
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
import{t as e}from"./registry-DUHIPE-v.mjs";import{n as t}from"./bind-helpers-BlAOQrFQ.mjs";import{t as n}from"./ensure-browser-core-Buls24LQ.mjs";import{t as r}from"./definitions-DtE0XLrT.mjs";const i=`workflow`,a=`workflowHandlers`,o=t({domain:i,depKey:a,lookup:e(r),entries:[{tool:`page_script_register`,method:`handlePageScriptRegister`},{tool:`page_script_run`,method:`handlePageScriptRun`},{tool:`api_probe_batch`,method:`handleApiProbeBatch`},{tool:`js_bundle_search`,method:`handleJsBundleSearch`},{tool:`list_extension_workflows`,method:`handleListExtensionWorkflows`},{tool:`run_extension_workflow`,method:`handleRunExtensionWorkflow`}]});async function s(e){let{WorkflowHandlers:t}=await import(`./workflow-CYIXtrWD.mjs`);await n(e);let r=e.handlerDeps.browserHandlers,i=e.handlerDeps.advancedHandlers;return e.workflowHandlers||=new t({browserHandlers:r,advancedHandlers:i,serverContext:e}),e.workflowHandlers}const c={kind:`domain-manifest`,version:1,domain:i,depKey:a,profiles:[`workflow`,`full`],ensure:s,workflowRule:{patterns:[/(workflow|extension|run)/i,/(工作流|扩展|运行)/i],priority:95,tools:[`run_extension_workflow`,`list_extension_workflows`],hint:`Extension workflow: list available workflows -> run the best matching workflow`},prerequisites:{page_script_run:[{condition:`Browser must be launched`,fix:`Call browser_launch or browser_attach first`}],api_probe_batch:[{condition:`Browser must be launched`,fix:`Call browser_launch or browser_attach first`},{condition:`Network monitoring must be enabled`,fix:`Call network_monitor(enable) first`}],js_bundle_search:[{condition:`Browser must be launched`,fix:`Call browser_launch or browser_attach first`}],run_extension_workflow:[{condition:`Browser must be launched`,fix:`Call browser_launch or browser_attach first`}]},registrations:o};export{c as default};
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
import{i as e}from"./response-C7rKQst4.mjs";import{t}from"./registry-DUHIPE-v.mjs";import{n}from"./bind-helpers-BlAOQrFQ.mjs";import{t as r}from"./tool-builder-CI9914Tf.mjs";const i=[r(`payload_template_build`,e=>e.desc(`Build a deterministic payload from field definitions.`).array(`fields`,{type:`object`,properties:{name:{type:`string`,description:`Field name`},type:{type:`string`,enum:[`u8`,`u16`,`u32`,`i8`,`i16`,`i32`,`string`,`bytes`],description:`Field type`},value:{description:`Numeric or string field value`},encoding:{type:`string`,enum:[`utf8`,`ascii`,`hex`,`base64`],description:`String/bytes encoding override`},length:{type:`number`,description:`Optional fixed length`},padByte:{type:`number`,description:`Optional pad byte`}},required:[`name`,`type`,`value`]},`Field definitions in output order`).enum(`endian`,[`big`,`little`],`Integer byte order`,{default:`big`}).required(`fields`).idempotent()),r(`payload_mutate`,e=>e.desc(`Apply deterministic byte-level mutations to a hex payload.`).string(`hexPayload`,`Source payload as a hex string`).array(`mutations`,{type:`object`,properties:{strategy:{type:`string`,enum:[`set_byte`,`flip_bit`,`overwrite_bytes`,`append_bytes`,`truncate`,`increment_integer`],description:`Mutation strategy`},offset:{type:`number`,description:`Zero-based byte offset`},value:{type:`number`,description:`Byte value for set_byte`},bit:{type:`number`,description:`Bit index for flip_bit`},data:{type:`string`,description:`Mutation data for overwrite/append`},encoding:{type:`string`,enum:[`utf8`,`ascii`,`hex`,`base64`],description:`Data encoding for overwrite/append`},length:{type:`number`,description:`Target length for truncate`},width:{type:`number`,enum:[1,2,4],description:`Integer width in bytes`},delta:{type:`number`,description:`Increment/decrement delta`},endian:{type:`string`,enum:[`big`,`little`],description:`Integer byte order`},signed:{type:`boolean`,description:`Treat increment target as signed`}},required:[`strategy`]},`Byte-level mutations to apply in order`).required(`hexPayload`,`mutations`)),r(`ethernet_frame_build`,e=>e.desc(`Build a deterministic Ethernet II frame from source/destination MAC addresses, EtherType, and payload bytes.`).string(`destinationMac`,`Destination MAC address in colon, dash, dotted, or plain hex form`).string(`sourceMac`,`Source MAC address in colon, dash, dotted, or plain hex form`).string(`etherType`,`EtherType name (arp, ipv4, ipv6, vlan) or a 16-bit hex value such as 0800`).string(`payloadHex`,`Frame payload as a hex string`).required(`destinationMac`,`sourceMac`,`etherType`,`payloadHex`).idempotent()),r(`arp_build`,e=>e.desc(`Build a deterministic ARP payload for Ethernet/IPv4.`).enum(`operation`,[`request`,`reply`],`ARP operation code`,{default:`request`}).string(`senderMac`,`Sender hardware address`).string(`senderIp`,`Sender IPv4 address`).string(`targetMac`,`Target hardware address (use zeros for requests)`,{default:`00:00:00:00:00:00`}).string(`targetIp`,`Target IPv4 address`).number(`hardwareType`,`Hardware type number. Default: 1 (Ethernet)`,{default:1}).string(`protocolType`,`Protocol type name (ipv4) or 16-bit hex value. Default: ipv4`,{default:`ipv4`}).number(`hardwareSize`,`Hardware address size in bytes. Default: 6`,{default:6}).number(`protocolSize`,`Protocol address size in bytes. Default: 4`,{default:4}).required(`senderMac`,`senderIp`,`targetIp`).idempotent()),r(`raw_ip_packet_build`,e=>e.desc(`Build a deterministic IPv4 or IPv6 packet.`).enum(`version`,[`ipv4`,`ipv6`],`IP version`,{default:`ipv4`}).string(`sourceIp`,`Source IPv4/IPv6 address`).string(`destinationIp`,`Destination IPv4/IPv6 address`).string(`protocol`,`Protocol/next-header name (icmp, tcp, udp, icmpv6) or an 8-bit integer string/hex value`).string(`payloadHex`,`Inner payload as a hex string`,{default:``}).number(`ttl`,`IPv4 TTL or IPv6 hop limit fallback. Default: 64`,{default:64}).number(`hopLimit`,`Explicit IPv6 hop limit override`).number(`identification`,`IPv4 identification field. Default: 0`,{default:0}).boolean(`dontFragment`,`Set the IPv4 DF flag`,{default:!1}).boolean(`moreFragments`,`Set the IPv4 MF flag`,{default:!1}).number(`fragmentOffset`,`IPv4 fragment offset in 8-byte units. Default: 0`,{default:0}).number(`dscp`,`IPv4 DSCP or IPv6 traffic-class DSCP value (0-63). Default: 0`,{default:0}).number(`ecn`,`IPv4/IPv6 ECN bits (0-3). Default: 0`,{default:0}).number(`flowLabel`,`IPv6 flow label (0-1048575). Default: 0`,{default:0}).required(`version`,`sourceIp`,`destinationIp`,`protocol`).idempotent()),r(`icmp_echo_build`,e=>e.desc(`Build a deterministic ICMPv4 echo request or reply payload with an automatically computed checksum.`).enum(`operation`,[`request`,`reply`],`ICMP echo operation`,{default:`request`}).number(`identifier`,`ICMP echo identifier field. Default: 0`,{default:0}).number(`sequenceNumber`,`ICMP echo sequence number field. Default: 0`,{default:0}).string(`payloadHex`,`Optional ICMP payload as a hex string`,{default:``}).idempotent()),r(`checksum_apply`,e=>e.desc(`Apply a deterministic 16-bit Internet checksum across a payload slice, optionally zeroing and writing the checksum field back into the packet.`).string(`hexPayload`,`Source payload as a hex string`).number(`startOffset`,`Inclusive start offset for checksum range. Default: 0`,{default:0}).number(`endOffset`,`Exclusive end offset for checksum range. Default: payload length`).number(`zeroOffset`,`Optional checksum field offset to zero before calculation`).number(`zeroLength`,`Checksum field width in bytes when zeroOffset is set. Default: 2`,{default:2}).number(`writeOffset`,`Optional destination offset for writing the computed checksum. Defaults to zeroOffset when provided`).enum(`endian`,[`big`,`little`],`Byte order used when writing the checksum back`,{default:`big`}).required(`hexPayload`).idempotent()),r(`pcap_write`,e=>e.desc(`Write a compact classic PCAP file from deterministic packet byte records.`).string(`path`,`Destination path for the PCAP file`).array(`packets`,{type:`object`,properties:{dataHex:{type:`string`,description:`Packet bytes as a hex string`},timestampSeconds:{type:`number`,description:`Unix timestamp seconds. Defaults to 0 when omitted`},timestampFraction:{type:`number`,description:`Microsecond or nanosecond fraction depending on timestampPrecision`},originalLength:{type:`number`,description:`Original on-wire packet length. Defaults to included length`}},required:[`dataHex`]},`Packet records to serialize in order`).enum(`endianness`,[`little`,`big`],`PCAP byte order for numeric fields`,{default:`little`}).enum(`timestampPrecision`,[`micro`,`nano`],`Timestamp precision marker in the PCAP magic`,{default:`micro`}).number(`snapLength`,`Global snapshot length. Default: 65535`,{default:65535}).string(`linkType`,`Link-layer type name (ethernet, raw, loopback) or integer string`,{default:`ethernet`}).required(`path`,`packets`).idempotent()),r(`pcap_read`,e=>e.desc(`Read a classic PCAP file and return compact deterministic packet summaries. PCAPNG is intentionally not supported.`).string(`path`,`Path to the PCAP file to parse`).number(`maxPackets`,`Maximum number of packet records to decode`).number(`maxBytesPerPacket`,`Maximum payload bytes to return per packet before truncating the reported hex payload`).required(`path`).query()),r(`proto_define_pattern`,e=>e.desc(`Define a protocol pattern with delimiter, byte order, and field layout.`).string(`name`,`Pattern name`).prop(`spec`,{type:`object`,description:`Pattern specification object`,additionalProperties:!0}).required(`spec`).idempotent()),r(`proto_auto_detect`,e=>e.desc(`Auto-detect a protocol pattern from one or more hex payload samples.`).array(`hexPayloads`,{type:`string`},`Hex payload samples`).required(`hexPayloads`).query()),r(`proto_export_schema`,e=>e.desc(`Export a protocol pattern to a .proto-like schema definition.`).string(`patternId`,`Pattern ID to export`).required(`patternId`).query()),r(`proto_infer_fields`,e=>e.desc(`Infer likely protocol fields from repeated hex payload samples.`).array(`hexPayloads`,{type:`string`},`Hex payload samples`).required(`hexPayloads`).query()),r(`proto_infer_state_machine`,e=>e.desc(`Infer a protocol state machine from captured message sequences.`).array(`messages`,{type:`object`,properties:{direction:{type:`string`,enum:[`req`,`res`],description:`Message direction`},timestamp:{type:`number`,description:`Message timestamp`},fields:{type:`object`,description:`Decoded message fields`,additionalProperties:!0},raw:{type:`string`,description:`Raw message or payload summary`}},required:[`direction`,`timestamp`,`fields`,`raw`]},`Captured protocol messages`).required(`messages`).query()),r(`proto_visualize_state`,e=>e.desc(`Generate a Mermaid state diagram from a protocol state machine definition.`).prop(`stateMachine`,{type:`object`,description:`State machine definition with states and transitions`,additionalProperties:!0}).query()),r(`proto_fingerprint`,e=>e.desc(`Identify protocol type from hex payload samples.`).array(`hexPayloads`,{type:`string`},`Hex payload samples to fingerprint`).boolean(`includeKnownProtocols`,`Match against known protocol signatures`,{default:!0}).boolean(`includeFieldHints`,`Suggest likely field boundaries`,{default:!0}).required(`hexPayloads`).query())],a=`protocol-analysis`,o=`protocolAnalysisHandlers`,s=n({domain:a,depKey:o,lookup:t(i),wrapResult:e,entries:[{tool:`proto_define_pattern`,method:`handleDefinePattern`},{tool:`proto_auto_detect`,method:`handleAutoDetect`},{tool:`proto_infer_fields`,method:`handleInferFields`},{tool:`proto_infer_state_machine`,method:`handleInferStateMachine`},{tool:`proto_export_schema`,method:`handleExportSchema`},{tool:`proto_visualize_state`,method:`handleVisualizeState`},{tool:`payload_template_build`,method:`handlePayloadTemplateBuild`},{tool:`payload_mutate`,method:`handlePayloadMutate`},{tool:`ethernet_frame_build`,method:`handleEthernetFrameBuild`},{tool:`arp_build`,method:`handleArpBuild`},{tool:`raw_ip_packet_build`,method:`handleRawIpPacketBuild`},{tool:`icmp_echo_build`,method:`handleIcmpEchoBuild`},{tool:`checksum_apply`,method:`handleChecksumApply`},{tool:`pcap_write`,method:`handlePcapWrite`},{tool:`pcap_read`,method:`handlePcapRead`},{tool:`proto_fingerprint`,method:`handleProtoFingerprint`}]});async function c(e){let{ProtocolAnalysisHandlers:t}=await import(`./handlers-BP12ZsWc.mjs`),n=e.getDomainInstance(o);if(n)return n;let r=new t(void 0,void 0,e.eventBus);return e.setDomainInstance(o,r),r}const l={kind:`domain-manifest`,version:1,domain:a,depKey:o,profiles:[`full`],ensure:c,registrations:s,prerequisites:{proto_auto_detect:[{condition:`At least one hex payload sample is required`,fix:`Capture traffic using network monitoring tools first`}],proto_infer_state_machine:[{condition:`Multiple message samples are required for state machine inference`,fix:`Capture message sequences with mojo-ipc or network tools`}]},workflowRule:{patterns:[/protocol\s+(reverse|analysis|pattern|state\s*machine|schema)/i,/custom\s+protocol|binary\s+protocol|wire\s+format/i,/infer\s+(protocol|fields|state\s*machine)/i,/proto.*export|proto.*schema|proto.*diagram/i,/payload\s+(template|build|mutate)|packet\s+(template|mutate)/i,/ethernet|arp|ipv4|ipv6|pcap|internet\s+checksum|raw\s+packet/i,/(decode|payload|bytes?|hex|protobuf|msgpack).*(protocol|field|state\s*machine)/i,/(base64|hex|protobuf|msgpack).*(payload|protocol|field|decode)/i,/(crypto\s*harness|checksum|payload\s+rebuild|payload\s+template).*(protocol|payload|decode)/i,/(无状态|纯算|确定性|解码|载荷|字节|报文).*(协议|字段|状态机)/i],priority:.6,tools:[`binary_detect_format`,`binary_decode`,`proto_auto_detect`,`proto_infer_fields`,`proto_define_pattern`,`proto_infer_state_machine`,`proto_export_schema`,`proto_visualize_state`,`payload_template_build`,`payload_mutate`,`checksum_apply`,`crypto_test_harness`,`ethernet_frame_build`,`arp_build`,`raw_ip_packet_build`,`icmp_echo_build`,`pcap_write`,`pcap_read`],hint:`Capture or craft packet bytes -> build Ethernet/ARP/IP/ICMP headers -> apply deterministic checksums and payload mutations -> read/write compact PCAP files -> infer fields or state machines from resulting payloads`},toolDependencies:[{from:`network_get_requests`,to:`binary_decode`,relation:`suggests`,weight:.9},{from:`binary_decode`,to:`proto_auto_detect`,relation:`precedes`,weight:.95},{from:`proto_auto_detect`,to:`proto_infer_fields`,relation:`precedes`,weight:.95},{from:`proto_infer_fields`,to:`proto_infer_state_machine`,relation:`precedes`,weight:.9},{from:`detect_crypto`,to:`crypto_test_harness`,relation:`suggests`,weight:.8},{from:`network`,to:`protocol-analysis`,relation:`uses`,weight:.7}]};export{l as default};
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
import{t as e}from"./registry-DUHIPE-v.mjs";import{n as t}from"./bind-helpers-BlAOQrFQ.mjs";import{t as n}from"./definitions-OvGsfxdt.mjs";const r=`process`,i=`processHandlers`,a=e(n),o=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;async function s(e){let{ProcessToolHandlers:t}=await import(`./process-C9f2A5zk.mjs`);return e.processHandlers||=new t,e.processHandlers}const c=o===`win32`,l=new Set([`check_debug_port`]),u=t({domain:r,depKey:i,lookup:a,entries:[{tool:`electron_attach`,method:`handleElectronAttach`},{tool:`process_windows`,method:`handleProcessWindows`},{tool:`process_check_debug_port`,method:`handleProcessCheckDebugPort`},{tool:`process_launch_debug`,method:`handleProcessLaunchDebug`},{tool:`memory_read`,method:`handleMemoryRead`},{tool:`memory_write`,method:`handleMemoryWrite`},{tool:`memory_scan`,method:`handleMemoryScan`},{tool:`memory_check_protection`,method:`handleMemoryCheckProtection`},{tool:`memory_scan_filtered`,method:`handleMemoryScanFiltered`},{tool:`memory_batch_write`,method:`handleMemoryBatchWrite`},{tool:`memory_dump_region`,method:`handleMemoryDumpRegion`},{tool:`memory_list_regions`,method:`handleMemoryListRegions`},{tool:`memory_audit_export`,method:`handleMemoryAuditExport`},{tool:`inject_dll`,method:`handleInjectDll`},{tool:`inject_shellcode`,method:`handleInjectShellcode`},{tool:`check_debug_port`,method:`handleCheckDebugPort`},{tool:`enumerate_modules`,method:`handleEnumerateModules`}]}),d={kind:`domain-manifest`,version:1,domain:r,depKey:i,profiles:[`full`],ensure:s,registrations:c?u:u.filter(e=>!l.has(e.tool.name))};export{d as default};
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
import{t as e}from"./registry-DUHIPE-v.mjs";import{n as t}from"./bind-helpers-BlAOQrFQ.mjs";import{t as n}from"./ensure-browser-core-Buls24LQ.mjs";import{t as r}from"./tool-builder-CI9914Tf.mjs";const i=[r(`canvas_engine_fingerprint`,e=>e.desc(`Detect Canvas/WebGL game engines in the page.`).query()),r(`canvas_scene_dump`,e=>e.desc(`Extract the full scene tree / display list from a detected canvas engine.`).string(`canvasId`,`Canvas element ID or index to target`).number(`maxDepth`,`Maximum tree traversal depth`,{default:20}).boolean(`onlyInteractive`,`Only include interactive (mouseEnabled) nodes`,{default:!1}).boolean(`onlyVisible`,`Only include visible nodes`,{default:!1}).query()),r(`canvas_pick_object_at_point`,e=>e.desc(`Pick / hit-test the topmost object at a given screen coordinate using the engine's hit-test system`).number(`x`,`Screen X coordinate`).number(`y`,`Screen Y coordinate`).string(`canvasId`,`Canvas element ID or index to target`).boolean(`highlight`,`Draw a highlight rectangle on the picked object`,{default:!1}).required(`x`,`y`).readOnly()),r(`canvas_trace_click_handler`,e=>e.desc(`Trace a click event from DOM to JS call stack.`).number(`x`,`Screen X coordinate to click`).number(`y`,`Screen Y coordinate to click`).string(`canvasId`,`Canvas element ID or index to target`).enum(`breakpointType`,[`click`,`mousedown`,`pointerdown`],`Event breakpoint type`,{default:`click`}).number(`maxFrames`,`Maximum call stack frames to capture`,{default:50}).requiredOpenWorld(`x`,`y`))],a=`canvas`,o=`canvasHandlers`,s=t({domain:a,depKey:o,lookup:e(i),entries:[{tool:`canvas_engine_fingerprint`,method:`handleFingerprint`},{tool:`canvas_scene_dump`,method:`handleSceneDump`},{tool:`canvas_pick_object_at_point`,method:`handlePick`},{tool:`canvas_trace_click_handler`,method:`handleTraceClick`}]});async function c(e){let{DebuggerManager:t}=await import(`./modules-p-PUNv9r.mjs`).then(e=>e.t),{TraceRecorder:r}=await import(`./TraceRecorder-Dd8jLXpi.mjs`),{ReverseEvidenceGraph:i}=await import(`./ReverseEvidenceGraph-B931HeoW.mjs`).then(e=>e.t),{CanvasToolHandlers:a}=await import(`./handlers-pVNpaw4A.mjs`);await n(e),e.debuggerManager||=new t(e.collector),e.traceRecorder||=new r;let o=e.getDomainInstance(`evidenceGraph`);return o||(o=new i,e.setDomainInstance(`evidenceGraph`,o)),e.canvasHandlers||=new a({pageController:e.pageController,debuggerManager:e.debuggerManager,traceRecorder:e.traceRecorder,evidenceStore:o}),e.canvasHandlers}const l={kind:`domain-manifest`,version:1,domain:a,depKey:o,profiles:[`full`],ensure:c,workflowRule:{patterns:[/(canvas|scene|engine|game).*(pick|dump|trace|reverse)/i,/(canvas|webgl|webgpu|scene).*(graph|tree|node)/i,/(laya|pixi|phaser|cocos|unity).*(reverse|scene|dump|hook)/i],priority:80,tools:[`canvas_engine_fingerprint`,`canvas_scene_dump`,`canvas_pick_object_at_point`,`canvas_trace_click_handler`],hint:`Canvas reverse: fingerprint engine → dump scene tree → pick object at point → trace click to handler`},prerequisites:{canvas_engine_fingerprint:[{condition:`Browser must be running`,fix:`Call browser_launch or browser_attach first`}],canvas_scene_dump:[{condition:`Browser must be running`,fix:`Call browser_launch or browser_attach first`}],canvas_pick_object_at_point:[{condition:`Browser must be running`,fix:`Call browser_launch or browser_attach first`}],canvas_trace_click_handler:[{condition:`Debugger must be enabled`,fix:`Call debugger_lifecycle({ action: 'enable' }) first`}]},registrations:s};export{l as default};
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
import{t as e}from"./registry-DUHIPE-v.mjs";import{n as t}from"./bind-helpers-BlAOQrFQ.mjs";import{t as n}from"./ensure-browser-core-Buls24LQ.mjs";import{t as r}from"./definitions-LaYTuwQd.mjs";const i=`debugger`,a=`debuggerHandlers`,o=t({domain:i,depKey:a,lookup:e(r),entries:[{tool:`debugger_lifecycle`,method:`handleDebuggerLifecycle`},{tool:`debugger_pause`,method:`handleDebuggerPause`},{tool:`debugger_resume`,method:`handleDebuggerResume`},{tool:`debugger_step`,method:`handleDebuggerStep`},{tool:`breakpoint`,method:`handleBreakpoint`},{tool:`get_call_stack`,method:`handleGetCallStack`},{tool:`debugger_evaluate`,method:`handleDebuggerEvaluateDispatch`},{tool:`debugger_wait_for_paused`,method:`handleDebuggerWaitForPaused`},{tool:`debugger_get_paused_state`,method:`handleDebuggerGetPausedState`},{tool:`get_object_properties`,method:`handleGetObjectProperties`},{tool:`get_scope_variables_enhanced`,method:`handleGetScopeVariablesEnhanced`},{tool:`debugger_session`,method:`handleDebuggerSession`},{tool:`watch`,method:`handleWatch`},{tool:`blackbox_add`,method:`handleBlackboxAdd`},{tool:`blackbox_add_common`,method:`handleBlackboxAddCommon`},{tool:`blackbox_list`,method:`handleBlackboxList`}]});async function s(e){let{DebuggerManager:t,RuntimeInspector:r}=await import(`./modules-p-PUNv9r.mjs`).then(e=>e.t),{DebuggerToolHandlers:i}=await import(`./debugger-CRJq_krh.mjs`);return await n(e),(!e.debuggerManager||!e.runtimeInspector||!e.debuggerHandlers)&&(e.debuggerManager||=new t(e.collector),e.runtimeInspector||=new r(e.collector,e.debuggerManager),e.debuggerHandlers||=new i(e.debuggerManager,e.runtimeInspector,e.eventBus)),e.debuggerHandlers}const c={kind:`domain-manifest`,version:1,domain:i,depKey:a,profiles:[`workflow`,`full`],ensure:s,prerequisites:{debugger_lifecycle:[{condition:`Browser must be launched`,fix:`Call browser_launch or browser_attach first`}],breakpoint:[{condition:`Browser must be launched`,fix:`Call browser_launch and debugger_lifecycle(enable) first`}]},registrations:o};export{c as default};
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
import{t as e}from"./registry-DUHIPE-v.mjs";import{n as t}from"./bind-helpers-BlAOQrFQ.mjs";import{t as n}from"./definitions-BGwNSkVm.mjs";const r=`antidebug`,i=`antidebugHandlers`,a=t({domain:r,depKey:i,lookup:e(n),entries:[{tool:`antidebug_bypass`,method:`handleAntidebugBypass`},{tool:`antidebug_detect_protections`,method:`handleAntiDebugDetectProtections`}]});async function o(e){let{CodeCollector:t}=await import(`./collector-CKO8RPK8.mjs`),{AntiDebugToolHandlers:n}=await import(`./antidebug-BOTZH6-0.mjs`);return e.collector||(e.collector=new t(e.config.puppeteer),e.registerCaches()),e.antidebugHandlers||=new n(e.collector),e.antidebugHandlers}const s={kind:`domain-manifest`,version:1,domain:r,depKey:i,profiles:[`full`],ensure:o,registrations:a};export{s as default};
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
import{t as e}from"./registry-DUHIPE-v.mjs";import{n as t}from"./bind-helpers-BlAOQrFQ.mjs";import{t as n}from"./definitions-DJklW2sS.mjs";const r=`platform`,i=`platformHandlers`,a=t({domain:r,depKey:i,lookup:e(n),entries:[{tool:`platform_capabilities`,method:`handlePlatformCapabilities`},{tool:`miniapp_pkg_scan`,method:`handleMiniappPkgScan`},{tool:`miniapp_pkg_unpack`,method:`handleMiniappPkgUnpack`},{tool:`miniapp_pkg_analyze`,method:`handleMiniappPkgAnalyze`},{tool:`asar_extract`,method:`handleAsarExtract`},{tool:`electron_inspect_app`,method:`handleElectronInspectApp`},{tool:`electron_scan_userdata`,method:`handleElectronScanUserdata`},{tool:`asar_search`,method:`handleAsarSearch`},{tool:`electron_check_fuses`,method:`handleElectronCheckFuses`},{tool:`electron_patch_fuses`,method:`handleElectronPatchFuses`},{tool:`v8_bytecode_decompile`,method:`handleV8BytecodeDecompile`},{tool:`electron_launch_debug`,method:`handleElectronLaunchDebug`},{tool:`electron_debug_status`,method:`handleElectronDebugStatus`},{tool:`electron_ipc_sniff`,method:`handleElectronIPCSniff`}]});async function o(e){let{CodeCollector:t}=await import(`./collector-CKO8RPK8.mjs`),{PlatformToolHandlers:n}=await import(`./platform-C446Lf97.mjs`);return e.collector||(e.collector=new t(e.config.puppeteer),e.registerCaches()),e.platformHandlers||=new n(e.collector),e.platformHandlers}const s={kind:`domain-manifest`,version:1,domain:r,depKey:i,profiles:[`full`],ensure:o,registrations:a};export{s as default};
|
|
@@ -0,0 +1,2 @@
|
|
|
1
|
+
import{t as e}from"./logger-sBC6IdRT.mjs";import{t}from"./EventBus-DgciURGg.mjs";import{t as n}from"./registry-DUHIPE-v.mjs";import{t as r}from"./ensure-browser-core-Buls24LQ.mjs";import{t as i}from"./definitions-CuJRsJ6N.mjs";const a=2e3;var o=class{bridge;constructor(e){this.bridge=e}isAvailable(){return this.bridge.isSamplingSupported()}async suggestVariableNames(t,n){if(!this.bridge.isSamplingSupported())return e.debug(`LLMDeobfuscator: sampling not available, skipping name suggestion`),null;let r=n.slice(0,20),i=t.slice(0,a),o=[`Given this obfuscated JavaScript code, suggest meaningful variable/function names`,`for these identifiers: ${r.join(`, `)}`,``,"```javascript",i,"```",``,`Respond ONLY with a valid JSON array of objects with fields:`,` { "original": "<old_name>", "suggested": "<new_name>", "confidence": "high"|"medium"|"low" }`,``,`Rules:`,`- Use camelCase for variables/functions, PascalCase for classes`,`- If uncertain, use confidence "low"`,`- If the name is already meaningful, keep it and mark confidence "high"`].join(`
|
|
2
|
+
`),s=await this.bridge.sampleText({systemPrompt:`You are an expert JavaScript reverse engineer. You specialize in deobfuscation and renaming obfuscated identifiers to semantically meaningful names. Output only valid JSON.`,userMessage:o,maxTokens:256,temperature:.3,modelHint:`haiku`});return s?this.parseNameSuggestions(s,r):null}async inferFunctionPurpose(e){if(!this.bridge.isSamplingSupported())return null;let t=e.slice(0,a);return(await this.bridge.sampleText({systemPrompt:`You are a JavaScript reverse engineer. Analyze code and describe its purpose in one concise sentence.`,userMessage:`What does this function do?\n\n\`\`\`javascript\n${t}\n\`\`\`\n\nRespond with a single sentence.`,maxTokens:100,temperature:.2,modelHint:`haiku`}))?.trim()??null}parseNameSuggestions(t,n){try{let r=t.match(/\[[\s\S]*\]/);if(!r)return e.warn(`LLMDeobfuscator: no JSON array found in LLM response`),[];let i=JSON.parse(r[0]);if(!Array.isArray(i))return[];let a=new Set(n);return i.filter(e=>typeof e==`object`&&!!e&&typeof e.original==`string`&&typeof e.suggested==`string`).filter(e=>a.has(e.original)).map(e=>({original:e.original,suggested:e.suggested,confidence:[`high`,`medium`,`low`].includes(e.confidence)?e.confidence:`low`}))}catch(t){return e.warn(`LLMDeobfuscator: failed to parse LLM response:`,t),[]}}};const s=`core`,c=`coreAnalysisHandlers`,l=n(i);let u=null;function d(e){return n=>{let r=n[c];return n=>{let i=n._meta,a;return i?.progressToken!==void 0&&u&&(a=t(u.eventBus,i.progressToken)),e(r,{...n,onProgress:a})}}}const f=d;async function p(e){let{Deobfuscator:t,AdvancedDeobfuscator:n,ObfuscationDetector:i,CodeAnalyzer:a,CryptoDetector:o,HookManager:s}=await import(`./modules-p-PUNv9r.mjs`).then(e=>e.t),{CoreAnalysisHandlers:c}=await import(`./analysis-BuR-NgX8.mjs`);return u=e,await r(e),(!e.deobfuscator||!e.advancedDeobfuscator||!e.obfuscationDetector||!e.analyzer||!e.cryptoDetector||!e.hookManager||!e.coreAnalysisHandlers)&&(e.deobfuscator||=new t,e.advancedDeobfuscator||=new n,e.obfuscationDetector||=new i,e.analyzer||=new a,e.cryptoDetector||=new o,e.hookManager||=new s,e.coreAnalysisHandlers||=new c({collector:e.collector,scriptManager:e.scriptManager,deobfuscator:e.deobfuscator,advancedDeobfuscator:e.advancedDeobfuscator,obfuscationDetector:e.obfuscationDetector,analyzer:e.analyzer,cryptoDetector:e.cryptoDetector,hookManager:e.hookManager})),e.coreAnalysisHandlers}const m={kind:`domain-manifest`,version:1,domain:s,depKey:c,profiles:[`workflow`,`full`],ensure:p,workflowRule:{patterns:[/(deobfuscate|deobfusc|beautify|analyze).*(javascript|js|script|code)/i,/(反混淆|美化|分析).*(javascript|js|脚本|代码)/i],priority:85,tools:[`deobfuscate`,`extract_function_tree`,`llm_suggest_names`],hint:`JavaScript analysis workflow: collect -> deobfuscate -> inspect function tree | LLM-powered naming`},prerequisites:{collect_code:[{condition:`Browser must be launched`,fix:`Call browser_launch or browser_attach first`}]},registrations:[{tool:l(`collect_code`),domain:s,bind:f((e,t)=>e.handleCollectCode(t))},{tool:l(`search_in_scripts`),domain:s,profiles:[`search`,`workflow`,`full`],bind:f((e,t)=>e.handleSearchInScripts(t))},{tool:l(`extract_function_tree`),domain:s,bind:f((e,t)=>e.handleExtractFunctionTree(t))},{tool:l(`deobfuscate`),domain:s,bind:f((e,t)=>e.handleDeobfuscate(t))},{tool:l(`understand_code`),domain:s,profiles:[`search`,`workflow`,`full`],bind:f((e,t)=>e.handleUnderstandCode(t))},{tool:l(`detect_crypto`),domain:s,profiles:[`search`,`workflow`,`full`],bind:f((e,t)=>e.handleDetectCrypto(t))},{tool:l(`manage_hooks`),domain:s,bind:f((e,t)=>e.handleManageHooks(t))},{tool:l(`detect_obfuscation`),domain:s,profiles:[`search`,`workflow`,`full`],bind:f((e,t)=>e.handleDetectObfuscation(t))},{tool:l(`webcrack_unpack`),domain:s,bind:f((e,t)=>e.handleWebcrackUnpack(t))},{tool:l(`clear_collected_data`),domain:s,bind:f(e=>e.handleClearCollectedData())},{tool:l(`get_collection_stats`),domain:s,bind:f(e=>e.handleGetCollectionStats())},{tool:l(`webpack_enumerate`),domain:s,bind:f((e,t)=>e.handleWebpackEnumerate(t))},{tool:l(`llm_suggest_names`),domain:s,bind:d(async(e,t)=>{if(!u)return{content:[{type:`text`,text:JSON.stringify({success:!1,error:`Server context not initialized`})}]};let n=new o(u.samplingBridge);if(!n.isAvailable())return{content:[{type:`text`,text:JSON.stringify({success:!1,error:`Sampling not supported by this client`,hint:`The connected MCP client does not declare sampling capabilities. Try using Claude Desktop or another sampling-capable client.`})}]};let r=typeof t.code==`string`?t.code:``,i=Array.isArray(t.identifiers)?t.identifiers.filter(e=>typeof e==`string`):[],a=await n.suggestVariableNames(r,i);return{content:[{type:`text`,text:JSON.stringify({success:!0,suggestions:a??[],samplingUsed:!0})}]}})},{tool:l(`js_deobfuscate_jsvmp`),domain:s,bind:f((e,t)=>e.handleJsDeobfuscateJsvmp(t))},{tool:l(`js_deobfuscate_pipeline`),domain:s,bind:f((e,t)=>e.handleJsDeobfuscatePipeline(t))},{tool:l(`js_analyze_vm`),domain:s,bind:f((e,t)=>e.handleJsAnalyzeVm(t))},{tool:l(`js_solve_constraints`),domain:s,bind:f((e,t)=>e.handleJsSolveConstraints(t))},{tool:l(`analysis_ast_match`),domain:s,bind:f((e,t)=>e.handleAnalysisAstMatch(t))},{tool:l(`analysis_deflat_control_flow`),domain:s,bind:f((e,t)=>e.handleAnalysisDeflatControlFlow(t))},{tool:l(`analysis_decode_string_array`),domain:s,bind:f((e,t)=>e.handleAnalysisDecodeStringArray(t))}]};export{m as default};
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
import{t as e}from"./registry-DUHIPE-v.mjs";import{n as t}from"./bind-helpers-BlAOQrFQ.mjs";import{t as n}from"./ensure-browser-core-Buls24LQ.mjs";import{t as r}from"./definitions-NoVp_9Pm.mjs";const i=`encoding`,a=`encodingHandlers`,o=t({domain:i,depKey:a,lookup:e(r),entries:[{tool:`binary_detect_format`,method:`handleBinaryDetectFormat`},{tool:`binary_decode`,method:`handleBinaryDecode`},{tool:`binary_encode`,method:`handleBinaryEncode`},{tool:`binary_entropy_analysis`,method:`handleBinaryEntropyAnalysis`},{tool:`protobuf_decode_raw`,method:`handleProtobufDecodeRaw`}]});async function s(e){let{EncodingToolHandlers:t}=await import(`./encoding-DGcr6Aj_.mjs`);return await n(e),e.encodingHandlers||=new t(e.collector,async t=>e.consoleMonitor?.getResponseBody(t)??null),e.encodingHandlers}const c={kind:`domain-manifest`,version:1,domain:i,depKey:a,profiles:[`workflow`,`full`],ensure:s,registrations:o};export{c as default};
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
import{t as e}from"./registry-DUHIPE-v.mjs";import{n as t}from"./bind-helpers-BlAOQrFQ.mjs";import{t as n}from"./tool-builder-CI9914Tf.mjs";const r=[n(`binary_instrument_capabilities`,e=>e.desc(`Report binary instrumentation backend availability.`).query()),n(`frida_attach`,e=>e.desc(`Attach Frida to a local target and open a session.`).string(`target`,`Process name, PID, or binary path to attach to`).required(`target`)),n(`frida_enumerate_modules`,e=>e.desc(`List loaded modules in an attached Frida session.`).string(`sessionId`,`Session id returned by frida_attach`).required(`sessionId`).query()),n(`ghidra_analyze`,e=>e.desc(`Analyze a binary and return metadata.`).string(`binaryPath`,`Path to the binary file`).number(`timeout`,`Optional timeout in milliseconds for headless analysis`).required(`binaryPath`)),n(`generate_hooks`,e=>e.desc(`Generate a Frida interceptor script for a list of symbols.`).array(`symbols`,{type:`string`},`Symbol names to hook`).object(`options`,{includeArgs:{type:`boolean`,description:`Emit argument logging on function entry`},includeRetAddr:{type:`boolean`,description:`Emit return-address logging on function entry`}},`Optional Frida hook generation flags`).required(`symbols`)),n(`unidbg_emulate`,e=>e.desc(`Emulate a native function with Unidbg when available.`).string(`binaryPath`,`Path to the binary file`).string(`functionName`,`Function name to emulate`).array(`args`,{type:`string`},`Optional string arguments forwarded to emulation`).required(`binaryPath`,`functionName`)),n(`frida_run_script`,e=>e.desc(`Execute a Frida JavaScript snippet inside an attached Frida session.`).string(`sessionId`,`Session id returned by frida_attach`).string(`script`,`Frida JavaScript to execute`).required(`sessionId`,`script`)),n(`frida_detach`,e=>e.desc(`Detach from a Frida session and clean up resources.`).string(`sessionId`,`Session id returned by frida_attach`).required(`sessionId`)),n(`frida_list_sessions`,e=>e.desc(`List all active Frida attach sessions with target info.`).query()),n(`frida_generate_script`,e=>e.desc(`Generate a Frida interceptor or hook script from built-in templates.`).string(`target`,`Target binary or module name`).string(`template`,`Hook template type: trace, intercept, replace, log`).string(`functionName`,`Function name to generate hook for`).required(`target`,`template`)),n(`get_available_plugins`,e=>e.desc(`List installed binary analysis plugins.`).query()),n(`ghidra_decompile`,e=>e.desc(`Decompile a function using Ghidra.`).string(`binaryPath`,`Path to the binary file`).string(`functionName`,`Function name to decompile`).required(`binaryPath`,`functionName`)),n(`ida_decompile`,e=>e.desc(`Decompile a function using IDA Pro.`).string(`binaryPath`,`Path to the binary file`).string(`functionName`,`Function name to decompile`).required(`binaryPath`,`functionName`)),n(`jadx_decompile`,e=>e.desc(`Decompile an APK class or method using JADX.`).string(`apkPath`,`Path to the APK file`).string(`className`,`Fully qualified class name`).string(`methodName`,`Method name to decompile`).required(`apkPath`,`className`)),n(`unidbg_launch`,e=>e.desc(`Emulate a native shared library in Unidbg.`).string(`soPath`,`Path to the .so library file`).string(`arch`,`Architecture: arm or arm64`).required(`soPath`)),n(`unidbg_call`,e=>e.desc(`Call a JNI function in a running Unidbg emulator session.`).string(`sessionId`,`Session id from unidbg_launch`).string(`functionName`,`JNI function name to call`).required(`sessionId`,`functionName`)),n(`unidbg_trace`,e=>e.desc(`Get execution trace from Unidbg session with configurable detail.`).string(`sessionId`,`Session id from unidbg_launch`).required(`sessionId`)),n(`export_hook_script`,e=>e.desc(`Export generated hook templates as a complete, runnable Frida script.`).string(`hookTemplates`,`JSON array of hook template objects`)),n(`frida_enumerate_functions`,e=>e.desc(`Enumerate exported functions for a specific module in a Frida session.`).string(`sessionId`,`Session id returned by frida_attach`).string(`moduleName`,`Module name to enumerate exports from`).required(`sessionId`,`moduleName`).query()),n(`frida_find_symbols`,e=>e.desc(`Search for symbols matching a pattern in a Frida session.`).string(`sessionId`,`Session id returned by frida_attach`).string(`pattern`,`Symbol search pattern (e.g. "exports:*libssl*SSL*")`).required(`sessionId`,`pattern`).query())],i=`binary-instrument`,a=`binaryInstrumentHandlers`,o=t({domain:i,depKey:a,lookup:e(r),entries:[{tool:`binary_instrument_capabilities`,method:`handleBinaryInstrumentCapabilities`},{tool:`frida_attach`,method:`handleFridaAttach`},{tool:`frida_enumerate_modules`,method:`handleFridaEnumerateModules`},{tool:`ghidra_analyze`,method:`handleGhidraAnalyze`},{tool:`generate_hooks`,method:`handleGenerateHooks`},{tool:`unidbg_emulate`,method:`handleUnidbgEmulate`},{tool:`frida_run_script`,method:`handleFridaRunScript`},{tool:`frida_detach`,method:`handleFridaDetach`},{tool:`frida_list_sessions`,method:`handleFridaListSessions`},{tool:`frida_generate_script`,method:`handleFridaGenerateScript`},{tool:`get_available_plugins`,method:`handleGetAvailablePlugins`},{tool:`ghidra_decompile`,method:`handleGhidraDecompile`},{tool:`ida_decompile`,method:`handleIdaDecompile`},{tool:`jadx_decompile`,method:`handleJadxDecompile`},{tool:`unidbg_launch`,method:`handleUnidbgLaunch`},{tool:`unidbg_call`,method:`handleUnidbgCall`},{tool:`unidbg_trace`,method:`handleUnidbgTrace`},{tool:`export_hook_script`,method:`handleExportHookScript`},{tool:`frida_enumerate_functions`,method:`handleFridaEnumerateFunctions`},{tool:`frida_find_symbols`,method:`handleFridaFindSymbols`}]});async function s(e){let{BinaryInstrumentHandlers:t}=await import(`./handlers-D3iev8g1.mjs`),{GhidraAnalyzer:n,HookGenerator:r}=await import(`./binary-instrument-Cf9qqLlM.mjs`).then(e=>e.t),i=e.getDomainInstance(a);return i||(i=new t(e,new n,new r),e.setDomainInstance(a,i)),i}const c={kind:`domain-manifest`,version:1,domain:i,depKey:a,profiles:[`full`],ensure:s,registrations:o,workflowRule:{patterns:[/\b(frida|ghidra|ida|unidbg|jadx|binary|disassemb|decompil|dump\s?so)\b/i,/(binary|native|so|dll|elf|apk).*(analyze|hook|instrument|decompile)/i],priority:88,tools:[`frida_attach`,`ghidra_analyze`,`generate_hooks`,`unidbg_launch`],hint:`Binary analysis pipeline: attach Frida → decompile (Ghidra/IDA/JADX) → generate hook scripts → emulatewith Unidbg.`},prerequisites:{frida_attach:[{condition:`plugin_frida_bridge must be installed and frida-server reachable`,fix:`Install @jshookmcpextension/plugin-frida-bridge; launch frida-server on the target`}],frida_run_script:[{condition:`A Frida session must be active`,fix:`Call frida_attach before running a script`}],ghidra_analyze:[{condition:`plugin_ghidra_bridge must be installed with Ghidra headless available`,fix:`Install @jshookmcpextension/plugin-ghidra-bridge and configure Ghidra path`}],ida_decompile:[{condition:`plugin_ida_bridge must be installed`,fix:`Install @jshookmcpextension/plugin-ida-bridge and provide IDA Pro license`}],jadx_decompile:[{condition:`plugin_jadx_bridge must be installed`,fix:`Install @jshookmcpextension/plugin-jadx-bridge`}],unidbg_launch:[{condition:`Java 17+ and unidbg JAR must be reachable`,fix:`Install JDK 17+ and download unidbg from its official release`}],generate_hooks:[{condition:`Ghidra analysis output required`,fix:`Run ghidra_analyze first and pass the output to generate_hooks`}]},toolDependencies:[{from:`process`,to:`binary-instrument`,relation:`uses`,weight:.6}]};export{c as default};
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
import{t as e}from"./registry-DUHIPE-v.mjs";import{n as t}from"./bind-helpers-BlAOQrFQ.mjs";import{t as n}from"./definitions-CYFbewnd.mjs";const r=`sourcemap`,i=`sourcemapHandlers`,a=t({domain:r,depKey:i,lookup:e(n),entries:[{tool:`sourcemap_discover`,method:`handleSourcemapDiscover`},{tool:`sourcemap_fetch_and_parse`,method:`handleSourcemapFetchAndParse`},{tool:`sourcemap_coverage`,method:`handleSourcemapCoverage`},{tool:`sourcemap_lookup`,method:`handleSourcemapLookup`},{tool:`sourcemap_reconstruct_tree`,method:`handleSourcemapReconstructTree`},{tool:`sourcemap_parse_v4`,method:`handleSourcemapParseV4`}]});async function o(e){let{CodeCollector:t}=await import(`./collector-CKO8RPK8.mjs`),{SourcemapToolHandlers:n}=await import(`./sourcemap-D6Q1UuAp.mjs`);return e.collector||(e.collector=new t(e.config.puppeteer),e.registerCaches()),e.sourcemapHandlers||=new n(e.collector),e.sourcemapHandlers}const s={kind:`domain-manifest`,version:1,domain:r,depKey:i,profiles:[`full`],ensure:o,registrations:a};export{s as default};
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
import{i as e}from"./response-C7rKQst4.mjs";import{t}from"./registry-DUHIPE-v.mjs";import{n}from"./bind-helpers-BlAOQrFQ.mjs";const r=[`TLSv1`,`TLSv1.1`,`TLSv1.2`,`TLSv1.3`];function i(e,t,n={},r=[]){return{name:e,description:t,inputSchema:{type:`object`,properties:n,required:r}}}const a=[i(`tls_cert_pin_bypass_frida`,`Bypass certificate pinning via Frida injection (supports BoringSSL, Chrome, OkHttp).`)],o=[i(`net_raw_tcp_send`,`Send raw TCP data to a remote host; accepts hex or text input.`,{host:{type:`string`,default:`127.0.0.1`,description:`Target host address`},port:{type:`number`,description:`Target port number (1-65535)`},dataHex:{type:`string`,description:`Hex-encoded data to send`},dataText:{type:`string`,description:`Text data to send (alternative to dataHex)`},timeout:{type:`number`,default:5e3,description:`Connection timeout in ms`}},[`port`]),i(`net_raw_tcp_listen`,`Listen on a local TCP port for one incoming connection.`,{port:{type:`number`,description:`Local port to listen on (1-65535)`},timeout:{type:`number`,default:1e4,description:`Listen timeout in ms`}},[`port`]),i(`net_raw_udp_send`,`Send a raw UDP datagram and wait for a response.`,{host:{type:`string`,default:`127.0.0.1`,description:`Target host address`},port:{type:`number`,description:`Target port number (1-65535)`},dataHex:{type:`string`,description:`Hex-encoded data to send`},dataText:{type:`string`,description:`Text data to send (alternative to dataHex)`},timeout:{type:`number`,default:5e3,description:`Response timeout in ms`}},[`port`]),i(`net_raw_udp_listen`,`Listen on a local UDP port for an incoming datagram.`,{port:{type:`number`,description:`Local port to listen on (1-65535)`},timeout:{type:`number`,default:1e4,description:`Listen timeout in ms`}},[`port`])],s=[i(`tcp_open`,`Open a TCP session.`,{host:{type:`string`,default:`127.0.0.1`,description:`Target host name or IP address`},port:{type:`number`,description:`Target TCP port`},timeoutMs:{type:`number`,default:5e3,description:`Connection timeout in milliseconds`},noDelay:{type:`boolean`,default:!0,description:`Enable TCP_NODELAY on the socket after connect`}},[`port`]),i(`tcp_write`,`Write data to an open TCP session.`,{sessionId:{type:`string`,description:`TCP session ID`},dataHex:{type:`string`,description:`Hex-encoded payload to write`},dataText:{type:`string`,description:`UTF-8 text payload to write`},timeoutMs:{type:`number`,default:5e3,description:`Write timeout in milliseconds`}},[`sessionId`]),i(`tcp_read_until`,`Read from an open TCP session until a delimiter or byte limit is reached.`,{sessionId:{type:`string`,description:`TCP session ID`},delimiterHex:{type:`string`,description:`Hex-encoded delimiter to stop at`},delimiterText:{type:`string`,description:`UTF-8 delimiter to stop at`},includeDelimiter:{type:`boolean`,default:!0,description:`Include the delimiter bytes in the returned payload`},maxBytes:{type:`number`,description:`Optional maximum number of bytes to return even if no delimiter matches`},timeoutMs:{type:`number`,default:5e3,description:`Read timeout in milliseconds`}},[`sessionId`]),i(`tcp_close`,`Close an open TCP session.`,{sessionId:{type:`string`,description:`TCP session ID`},force:{type:`boolean`,default:!1,description:`Destroy the socket immediately instead of sending FIN first`},timeoutMs:{type:`number`,default:1e3,description:`Close wait timeout in milliseconds before forcing socket destruction`}},[`sessionId`]),i(`tls_open`,`Open a TLS session.`,{host:{type:`string`,description:`Target host name or IP address`},port:{type:`number`,default:443,description:`Target TLS port`},servername:{type:`string`,description:`Optional SNI and hostname validation override`},alpnProtocols:{type:`array`,items:{type:`string`},description:`Optional ALPN protocols to offer`},timeoutMs:{type:`number`,default:5e3,description:`Connection timeout in milliseconds`},minVersion:{type:`string`,enum:[...r],description:`Optional minimum TLS version`},maxVersion:{type:`string`,enum:[...r],description:`Optional maximum TLS version`},caPem:{type:`string`,description:`Optional PEM-encoded CA bundle`},caPath:{type:`string`,description:`Optional path to a PEM-encoded CA bundle`},allowInvalidCertificates:{type:`boolean`,default:!1,description:`Allow untrusted certificate chains while still reporting the failure`},skipHostnameCheck:{type:`boolean`,default:!1,description:`Skip hostname verification while still reporting the requested target`}},[`host`]),i(`tls_write`,`Write data to an open TLS session.`,{sessionId:{type:`string`,description:`TLS session ID`},dataHex:{type:`string`,description:`Hex-encoded payload to write`},dataText:{type:`string`,description:`UTF-8 text payload to write`},timeoutMs:{type:`number`,default:5e3,description:`Write timeout in milliseconds`}},[`sessionId`]),i(`tls_read_until`,`Read from an open TLS session until a delimiter or byte limit is reached.`,{sessionId:{type:`string`,description:`TLS session ID`},delimiterHex:{type:`string`,description:`Hex-encoded delimiter to stop at`},delimiterText:{type:`string`,description:`UTF-8 delimiter to stop at`},includeDelimiter:{type:`boolean`,default:!0,description:`Include the delimiter bytes in the returned payload`},maxBytes:{type:`number`,description:`Optional maximum number of bytes to return even if no delimiter matches`},timeoutMs:{type:`number`,default:5e3,description:`Read timeout in milliseconds`}},[`sessionId`]),i(`tls_close`,`Close an open TLS session.`,{sessionId:{type:`string`,description:`TLS session ID`},force:{type:`boolean`,default:!1,description:`Destroy the TLS socket immediately instead of sending close_notify/FIN first`},timeoutMs:{type:`number`,default:1e3,description:`Close wait timeout in milliseconds before forcing socket destruction`}},[`sessionId`])],c=[i(`tls_keylog_enable`,`Enable SSLKEYLOGFILE output for BoringSSL-compatible clients.`),i(`tls_keylog_parse`,`Parse an SSLKEYLOGFILE and summarize available key material.`,{path:{type:`string`,description:`Path to SSLKEYLOGFILE`}}),i(`tls_keylog_disable`,`Disable SSLKEYLOGFILE capture and unset the environment variable.`,{path:{type:`string`,description:`Path to disable`}}),i(`tls_decrypt_payload`,`Decrypt a TLS payload using a provided key, nonce, and algorithm.`,{encryptedHex:{type:`string`,description:`Hex-encoded encrypted payload`},keyHex:{type:`string`,description:`Hex-encoded decryption key`},nonceHex:{type:`string`,description:`Hex-encoded nonce/IV`},algorithm:{type:`string`,description:`Cipher algorithm`,default:`aes-256-gcm`},authTagHex:{type:`string`,description:`Hex-encoded authentication tag`}},[`encryptedHex`,`keyHex`,`nonceHex`]),i(`tls_keylog_summarize`,`Summarize the contents of an SSLKEYLOGFILE by label distribution.`,{content:{type:`string`,description:`Inline keylog content to summarize`}}),i(`tls_keylog_lookup_secret`,`Look up a TLS secret by client random hex from the parsed keylog.`,{clientRandom:{type:`string`,description:`Hex-encoded client random`},label:{type:`string`,description:`Optional label filter`}},[`clientRandom`]),i(`tls_cert_pin_bypass`,`Return a certificate pinning bypass strategy for the selected platform.`,{target:{type:`string`,enum:[`android`,`ios`,`desktop`],description:`Target platform for bypass strategy`}},[`target`]),i(`tls_parse_handshake`,`Parse TLS handshake metadata from raw hex.`,{rawHex:{type:`string`,description:`Hex-encoded TLS handshake record`},decrypt:{type:`boolean`,description:`Attempt payload decryption using the loaded keylog`}},[`rawHex`]),i(`tls_cipher_suites`,`List TLS cipher suites.`,{filter:{type:`string`,description:`Keyword filter for cipher suite names`}}),i(`tls_parse_certificate`,`Parse a TLS Certificate message from raw hex and extract fingerprints.`,{rawHex:{type:`string`,description:`Hex-encoded certificate data`}},[`rawHex`]),i(`tls_probe_endpoint`,`Probe a TLS endpoint and report handshake and certificate details.`,{host:{type:`string`,description:`Target host name or IP address`},port:{type:`number`,default:443,description:`Target TLS port`},servername:{type:`string`,description:`Optional SNI and hostname validation override`},alpnProtocols:{type:`array`,items:{type:`string`},description:`Optional ALPN protocols to offer`},timeoutMs:{type:`number`,default:5e3,description:`Probe timeout in milliseconds`},minVersion:{type:`string`,enum:[...r],description:`Optional minimum TLS version`},maxVersion:{type:`string`,enum:[...r],description:`Optional maximum TLS version`},caPem:{type:`string`,description:`Optional PEM-encoded CA bundle`},caPath:{type:`string`,description:`Optional path to a PEM-encoded CA bundle`},allowInvalidCertificates:{type:`boolean`,default:!1,description:`Allow untrusted certificate chains while still reporting the failure`},skipHostnameCheck:{type:`boolean`,default:!1,description:`Skip hostname verification while still reporting the requested target`}},[`host`])],l=[i(`websocket_open`,`Open a WebSocket session.`,{url:{type:`string`,description:`WebSocket URL`},scheme:{type:`string`,enum:[`ws`,`wss`],default:`ws`,description:`WebSocket transport scheme`},host:{type:`string`,description:`Target host name or IP address`},port:{type:`number`,description:`Target port`},path:{type:`string`,default:`/`,description:`Request path`},subprotocols:{type:`array`,items:{type:`string`},description:`Optional subprotocols to offer`},timeoutMs:{type:`number`,default:5e3,description:`Handshake timeout in milliseconds`},servername:{type:`string`,description:`Optional SNI and hostname validation override`},alpnProtocols:{type:`array`,items:{type:`string`},description:`Optional ALPN protocols to offer`},minVersion:{type:`string`,enum:[...r],description:`Optional minimum TLS version`},maxVersion:{type:`string`,enum:[...r],description:`Optional maximum TLS version`},caPem:{type:`string`,description:`Optional PEM-encoded CA bundle`},caPath:{type:`string`,description:`Optional path to a PEM-encoded CA bundle`},allowInvalidCertificates:{type:`boolean`,default:!1,description:`Allow untrusted certificate chains`},skipHostnameCheck:{type:`boolean`,default:!1,description:`Skip hostname verification`}}),i(`websocket_send_frame`,`Send a WebSocket frame.`,{sessionId:{type:`string`,description:`WebSocket session ID`},frameType:{type:`string`,enum:[`text`,`binary`,`ping`,`pong`,`close`],description:`Outgoing frame opcode`},dataText:{type:`string`,description:`UTF-8 payload for text/ping/pong/close frames`},dataHex:{type:`string`,description:`Hex-encoded payload for binary/ping/pong/close frames`},closeCode:{type:`number`,description:`Optional close status code`},closeReason:{type:`string`,description:`Optional close reason`},timeoutMs:{type:`number`,default:5e3,description:`Write timeout in milliseconds`}},[`sessionId`,`frameType`]),i(`websocket_read_frame`,`Read the next queued WebSocket frame from an open session.`,{sessionId:{type:`string`,description:`WebSocket session ID`},timeoutMs:{type:`number`,default:5e3,description:`Read timeout in milliseconds`}},[`sessionId`]),i(`websocket_close`,`Close an open WebSocket session.`,{sessionId:{type:`string`,description:`WebSocket session ID`},force:{type:`boolean`,default:!1,description:`Destroy the underlying socket immediately without sending a close frame first`},closeCode:{type:`number`,description:`Optional close status code`},closeReason:{type:`string`,description:`Optional close reason`},timeoutMs:{type:`number`,default:1e3,description:`Close wait timeout in milliseconds before forcing socket destruction`}},[`sessionId`])],u=[...c,...s,...l,...a,...o],d=`boringssl-inspector`,f=`boringsslInspectorHandlers`,p=[`workflow`,`full`],m=n({domain:d,depKey:f,lookup:t(u),wrapResult:e,entries:[{tool:`tls_keylog_enable`,method:`handleTlsKeylogEnable`},{tool:`tls_keylog_parse`,method:`handleTlsKeylogParse`},{tool:`tls_keylog_disable`,method:`handleTlsKeylogDisable`},{tool:`tls_decrypt_payload`,method:`handleTlsDecryptPayload`},{tool:`tls_keylog_summarize`,method:`handleTlsKeylogSummarize`},{tool:`tls_keylog_lookup_secret`,method:`handleTlsKeylogLookupSecret`},{tool:`tls_cert_pin_bypass`,method:`handleTlsCertPinBypass`},{tool:`tls_parse_handshake`,method:`handleParseHandshake`},{tool:`tls_cipher_suites`,method:`handleCipherSuites`},{tool:`tls_parse_certificate`,method:`handleParseCertificate`},{tool:`tls_probe_endpoint`,method:`handleTlsProbeEndpoint`},{tool:`tcp_open`,method:`handleTcpOpen`},{tool:`tcp_write`,method:`handleTcpWrite`},{tool:`tcp_read_until`,method:`handleTcpReadUntil`},{tool:`tcp_close`,method:`handleTcpClose`},{tool:`tls_open`,method:`handleTlsOpen`},{tool:`tls_write`,method:`handleTlsWrite`},{tool:`tls_read_until`,method:`handleTlsReadUntil`},{tool:`tls_close`,method:`handleTlsClose`},{tool:`websocket_open`,method:`handleWebSocketOpen`},{tool:`websocket_send_frame`,method:`handleWebSocketSendFrame`},{tool:`websocket_read_frame`,method:`handleWebSocketReadFrame`},{tool:`websocket_close`,method:`handleWebSocketClose`},{tool:`tls_cert_pin_bypass_frida`,method:`handleBypassCertPinning`},{tool:`net_raw_tcp_send`,method:`handleRawTcpSend`},{tool:`net_raw_tcp_listen`,method:`handleRawTcpListen`},{tool:`net_raw_udp_send`,method:`handleRawUdpSend`},{tool:`net_raw_udp_listen`,method:`handleRawUdpListen`}]});async function h(e){let{BoringsslInspectorHandlers:t}=await import(`./handlers-DW5AbYs5.mjs`),{TLSKeyLogExtractor:n}=await import(`./boringssl-inspector-BST5vtKx.mjs`).then(e=>e.t),r=e.getDomainInstance(f);if(r)return r;let i=new t(new n);return i.setExtensionInvoke(async t=>{try{let n=e.getDomainInstance(`binaryInstrumentHandlers`);if(n&&typeof n.handleFridaRunScript==`function`)return n.handleFridaRunScript(t)}catch{}return null}),i.setEventBus(e.eventBus),e.setDomainInstance(f,i),i}const g={kind:`domain-manifest`,version:1,domain:d,depKey:f,profiles:p,registrations:m,ensure:h,workflowRule:{patterns:[/\b(tls|ssl|boringssl|cert(ificate)?|pinning|handshake|keylog|websocket)\b/i,/(tls|ssl|cert|pinning|websocket).*(hook|bypass|intercept|dump|log|frame|session)/i],priority:80,tools:[`tls_probe_endpoint`,`websocket_open`,`websocket_send_frame`,`websocket_read_frame`,`tls_keylog_enable`,`tls_keylog_parse`,`tls_decrypt_payload`,`tls_cert_pin_bypass`],hint:`TLS/WebSocket analysis: probe endpoint → open ws/wss session → exchange frames → inspecttrust/cipher/ALPN → enable keylog or bypass pinning when needed.`},prerequisites:{tls_probe_endpoint:[{condition:`Target scope must be explicitly authorized and routable from the MCP host`,fix:`Verify target authorization, port reachability, and provide servername/custom CA options when needed`}],tls_keylog_enable:[{condition:`Target process must allow SSLKEYLOGFILE or be attachable by Frida`,fix:`Launch the target with SSLKEYLOGFILE env set, or enable Frida-based hooking`}],tls_decrypt_payload:[{condition:`A keylog session must be active with captured secrets`,fix:`Run tls_keylog_enable and reproduce TLS traffic before decrypting`}],tls_cert_pin_bypass_frida:[{condition:`Frida must be available on PATH and attached to the target`,fix:`Install Frida and attach via binary-instrument:frida_attach before running the bypass`}]},toolDependencies:[{from:`network`,to:`boringssl-inspector`,relation:`uses`,weight:.8}]};export{g as default};
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
import{t as e}from"./registry-DUHIPE-v.mjs";import{n as t}from"./bind-helpers-BlAOQrFQ.mjs";import{t as n}from"./definitions-DI9YXsJk.mjs";const r=`graphql`,i=`graphqlHandlers`,a=t({domain:r,depKey:i,lookup:e(n),entries:[{tool:`call_graph_analyze`,method:`handleCallGraphAnalyze`},{tool:`script_replace_persist`,method:`handleScriptReplacePersist`},{tool:`graphql_introspect`,method:`handleGraphqlIntrospect`},{tool:`graphql_extract_queries`,method:`handleGraphqlExtractQueries`},{tool:`graphql_replay`,method:`handleGraphqlReplay`},{tool:`graphql_enum_schema`,method:`handleGraphqlEnumSchema`}]});async function o(e){let{CodeCollector:t,ConsoleMonitor:n}=await import(`./collector-CKO8RPK8.mjs`),{GraphQLToolHandlers:r}=await import(`./graphql-HLf3MS8H.mjs`);return e.collector||(e.collector=new t(e.config.puppeteer),e.registerCaches()),e.consoleMonitor||=new n(e.collector),e.graphqlHandlers||=new r({collector:e.collector,consoleMonitor:e.consoleMonitor}),e.graphqlHandlers}const s={kind:`domain-manifest`,version:1,domain:r,depKey:i,profiles:[`workflow`,`full`],ensure:o,registrations:a};export{s as default};
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
import{t as e}from"./registry-DUHIPE-v.mjs";import{n as t}from"./bind-helpers-BlAOQrFQ.mjs";import{t as n}from"./tool-builder-CI9914Tf.mjs";import{resolve as r}from"node:path";const i=[n(`evidence_query`,e=>e.desc(`Query reverse evidence graph by URL, function name, or script ID to find associated nodes.`).enum(`by`,[`url`,`function`,`script`],`Query dimension`).string(`value`,`Search value: URL/fragment, function name, or script ID`).required(`by`,`value`).query()),n(`evidence_export`,e=>e.desc(`Export the reverse evidence graph as JSON snapshot or Markdown report.`).enum(`format`,[`json`,`markdown`],`Export format`).required(`format`).query()),n(`evidence_chain`,e=>e.desc(`Get full provenance chain from a node ID in specified direction.`).string(`nodeId`,`Evidence node ID to start from`).enum(`direction`,[`forward`,`backward`],`Traversal direction`,{default:`forward`}).required(`nodeId`).query())],a=`evidence`,o=`evidenceHandlers`,s=t({domain:a,depKey:o,lookup:e(i),entries:[{tool:`evidence_query`,method:`handleQueryDispatch`},{tool:`evidence_export`,method:`handleExportDispatch`},{tool:`evidence_chain`,method:`handleChain`}]});async function c(e){let{ReverseEvidenceGraph:t}=await import(`./ReverseEvidenceGraph-B931HeoW.mjs`).then(e=>e.t),{EvidenceGraphBridge:n}=await import(`./EvidenceGraphBridge-BIfgB7HP.mjs`),{EvidenceHandlers:i}=await import(`./handlers-Dv_runVv.mjs`),a=e.getDomainInstance(`evidenceGraph`);a||(a=new t,a.setEventBus(e.eventBus),e.setDomainInstance(`evidenceGraph`,a));let o=e.getDomainInstance(`evidenceGraphBridge`);o||(o=new n(a),e.setDomainInstance(`evidenceGraphBridge`,o)),e.getDomainInstance(`instrumentationSessionManager`)?.setEvidenceBridge(o),e.evidenceHandlers||=new i(a);let s=e.getDomainInstance(`snapshotScheduler`),c=e.getDomainInstance(`snapshotStateDir`);return a.setPersistNotifier(s?()=>s.notifyDirty():void 0),s&&c&&!e.getDomainInstance(`evidenceGraphSnapshotRegistered`)&&(s.register(r(c,`evidence-graph`,`current.json`),a),e.setDomainInstance(`evidenceGraphSnapshotRegistered`,!0)),e.evidenceHandlers}const l={kind:`domain-manifest`,version:1,domain:a,depKey:o,profiles:[`full`],ensure:c,workflowRule:{patterns:[/(evidence|provenance|chain).*(graph|query|export|report)/i,/(证据|溯源|链).*(图|查询|导出|报告)/i],priority:90,tools:[`evidence_query`,`evidence_export`],hint:`Evidence graph: query by URL/function/scriptId → get provenance chain → export as JSON or Markdown report`},registrations:s};export{l as default};
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
import{t as e}from"./registry-DUHIPE-v.mjs";import{n as t}from"./bind-helpers-BlAOQrFQ.mjs";import{t as n}from"./tool-builder-CI9914Tf.mjs";const r=[`etw`,`strace`,`dtrace`],i={type:`object`,properties:{timestamp:{type:`number`,description:`Relative elapsed time in milliseconds since bpftrace start`},pid:{type:`number`,description:`Process identifier`},syscall:{type:`string`,description:`Observed syscall name`},args:{type:`array`,description:`Stringified syscall arguments`,items:{type:`string`}},returnValue:{type:`number`,description:`Numeric syscall return value if available`},duration:{type:`number`,description:`Execution duration in milliseconds if available`}},required:[`timestamp`,`pid`,`syscall`,`args`]},a=[n(`syscall_start_monitor`,e=>e.desc(`Start syscall monitoring.`).enum(`backend`,r,`Syscall capture backend`).number(`pid`,`Optional PID to scope monitoring to a single process`).boolean(`simulate`,`Use synthetic events instead of a real system tracer`,{default:!1}).required(`backend`)),n(`syscall_stop_monitor`,e=>e.desc(`Stop syscall interception and release all captured events.`).idempotent()),n(`syscall_capture_events`,e=>e.desc(`Capture syscall events from the active or last monitoring session.`).prop(`filter`,{type:`object`,description:`Optional event filter`,properties:{name:{type:`array`,description:`Restrict events to specific syscall names`,items:{type:`string`}},pid:{type:`number`,description:`Restrict events to a specific process ID`}}}).query()),n(`syscall_correlate_js`,e=>e.desc(`Correlate captured syscalls with likely JavaScript functions.`).array(`syscallEvents`,i,`Syscall events to correlate`).required(`syscallEvents`).query()),n(`syscall_filter`,e=>e.desc(`Filter captured syscall events by name, PID, or return value.`).array(`names`,{type:`string`},`Syscall names to keep`).query()),n(`syscall_get_stats`,e=>e.desc(`Get syscall monitoring statistics.`).query()),n(`syscall_ebpf_trace`,e=>e.desc(`Trace syscalls on Linux with eBPF. Requires root or CAP_BPF.`).number(`pid`,`Process ID to trace. 0 = trace all.`,{default:0}).array(`syscalls`,{type:`string`},`Specific syscall names to trace (empty = all)`).number(`durationSec`,`Trace duration in seconds`,{default:10,minimum:1,maximum:300}).boolean(`simulate`,`Use synthetic events when bpftrace is unavailable`,{default:!1}).query())],o=`syscall-hook`,s=`syscallHookHandlers`,c=t({domain:o,depKey:s,lookup:e(a),entries:[{tool:`syscall_start_monitor`,method:`handleSyscallStartMonitor`},{tool:`syscall_stop_monitor`,method:`handleSyscallStopMonitor`},{tool:`syscall_capture_events`,method:`handleSyscallCaptureEvents`},{tool:`syscall_correlate_js`,method:`handleSyscallCorrelateJs`},{tool:`syscall_filter`,method:`handleSyscallFilter`},{tool:`syscall_get_stats`,method:`handleSyscallGetStats`},{tool:`syscall_ebpf_trace`,method:`handleSyscallEbpfTrace`}]});async function l(e){let{SyscallHookHandlers:t}=await import(`./handlers-BLMa4X7l.mjs`),n=e.getDomainInstance(s);if(n)return n;let r=new t(void 0,void 0,e.eventBus);return e.setDomainInstance(s,r),r}const u={kind:`domain-manifest`,version:1,domain:o,depKey:s,profiles:[`full`],ensure:l,registrations:c,workflowRule:{patterns:[/\b(syscall|etw|strace|dtrace|kernel|system\s?call)\b/i,/(syscall|kernel).*(trace|monitor|capture|filter)/i],priority:78,tools:[`syscall_start_monitor`,`syscall_capture_events`,`syscall_correlate_js`],hint:`Syscall tracing: start monitor (ETW/strace/dtrace) → capture events → correlate with JS stacks.`},prerequisites:{syscall_start_monitor:[{condition:`Administrator/root privileges required for ETW and dtrace; Linux strace needs ptrace_scope=0`,fix:`Run the MCP server with elevated privileges, or relax kernel restrictions on Linux`}],syscall_correlate_js:[{condition:`A debugger or v8-inspector session must expose JS stacks`,fix:`Attach the debugger or v8-inspector domain before correlating`}]},toolDependencies:[{from:`memory`,to:`syscall-hook`,relation:`uses`,weight:.5}]};export{u as default};
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
import{t as e}from"./registry-DUHIPE-v.mjs";import{n as t}from"./bind-helpers-BlAOQrFQ.mjs";import{t as n}from"./definitions-Dds_zrWx.mjs";const r=`transform`,i=`transformHandlers`,a=t({domain:r,depKey:i,lookup:e(n),entries:[{tool:`ast_transform_preview`,method:`handleAstTransformPreview`},{tool:`ast_transform_chain`,method:`handleAstTransformChain`},{tool:`ast_transform_apply`,method:`handleAstTransformApply`},{tool:`crypto_extract_standalone`,method:`handleCryptoExtractStandalone`},{tool:`crypto_test_harness`,method:`handleCryptoTestHarness`},{tool:`crypto_compare`,method:`handleCryptoCompare`}]});async function o(e){let{CodeCollector:t}=await import(`./collector-CKO8RPK8.mjs`),{TransformToolHandlers:n}=await import(`./transform-Cv9P2vVD.mjs`);return e.collector||(e.collector=new t(e.config.puppeteer),e.registerCaches()),e.transformHandlers||=new n(e.collector),e.transformHandlers}const s={kind:`domain-manifest`,version:1,domain:r,depKey:i,profiles:[`full`],ensure:o,registrations:a};export{s as default};
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
import{t as e}from"./registry-DUHIPE-v.mjs";import{n as t}from"./bind-helpers-BlAOQrFQ.mjs";import{t as n}from"./tool-builder-CI9914Tf.mjs";import{t as r}from"./authorization-schema-B40obG1A.mjs";const i=[`before-load-inject`,`runtime-hook`,`network-intercept`,`function-trace`],a=[n(`instrumentation_session`,e=>e.desc(`Start, stop, or query status of an instrumentation recording session.`).enum(`action`,[`create`,`list`,`destroy`,`status`],`Session operation`).string(`name`,`Optional session name for create`).string(`sessionId`,`Session ID (required for destroy/status)`).required(`action`)),n(`instrumentation_operation`,e=>e.desc(`Manage operations inside an instrumentation session.`).enum(`action`,[`register`,`list`],`Operation`).string(`sessionId`,`Session ID`).enum(`type`,i,`Instrumentation type (action=register)`).string(`target`,`Function name, URL pattern, or script target (action=register)`).object(`config`,{},`Operation-specific config (action=register)`).required(`action`,`sessionId`)),n(`instrumentation_artifact`,e=>e.desc(`Manage artifacts captured by instrumentation operations.`).enum(`action`,[`record`,`query`],`Artifact operation`).string(`sessionId`,`Session ID`).string(`operationId`,`Operation ID (action=record)`).object(`data`,{},`Captured artifact payload (action=record)`).enum(`type`,i,`Optional artifact type filter (action=query)`).number(`limit`,`Max artifacts to return (action=query, default: 50)`,{default:50}).required(`action`,`sessionId`)),n(`instrumentation_hook_preset`,e=>e.desc(`Apply hook presets inside an instrumentation session.`).string(`sessionId`,`Session ID`).string(`preset`,`Single preset id to inject`).array(`presets`,{type:`string`},`Multiple preset ids to inject in one call`).boolean(`captureStack`,`Whether injected presets should capture stack traces`,{default:!1}).boolean(`logToConsole`,`Whether injected presets should log to console`,{default:!0}).enum(`method`,[`evaluate`,`evaluateOnNewDocument`],`Injection method forwarded to hook_preset`,{default:`evaluate`}).prop(`customTemplate`,{type:`object`,additionalProperties:!0,description:`Optional inline custom preset definition`}).prop(`customTemplates`,{type:`array`,items:{type:`object`,additionalProperties:!0},description:`Optional inline custom preset definitions`}).requiredOpenWorld(`sessionId`)),n(`instrumentation_network_replay`,e=>e.desc(`Replay a captured network request inside an instrumentation session.`).string(`sessionId`,`Session ID`).string(`requestId`,`Captured request ID returned by network_get_requests`).object(`headerPatch`,{additionalProperties:{type:`string`}},`Optional request header overrides`).string(`bodyPatch`,`Optional raw request body override`).string(`methodOverride`,`Optional HTTP method override`).string(`urlOverride`,`Optional destination URL override`).object(`authorization`,r,`Optional request-scoped authorization for private-network or insecure-HTTP replay.`).string(`authorizationCapability`,`Optional base64url-encoded request-scoped authorization capability.`).number(`timeoutMs`,`Optional replay timeout in milliseconds`).boolean(`dryRun`,`Preview the replay without sending the request`,{default:!0}).requiredOpenWorld(`sessionId`,`requestId`))],o=`instrumentation`,s=`instrumentationHandlers`,c=t({domain:o,depKey:s,lookup:e(a),entries:[{tool:`instrumentation_session`,method:`handleSessionDispatch`},{tool:`instrumentation_operation`,method:`handleOperationDispatch`},{tool:`instrumentation_artifact`,method:`handleArtifactDispatch`},{tool:`instrumentation_hook_preset`,method:`handleHookPreset`},{tool:`instrumentation_network_replay`,method:`handleNetworkReplay`}]});async function l(e){let{ReverseEvidenceGraph:t}=await import(`./ReverseEvidenceGraph-B931HeoW.mjs`).then(e=>e.t),{InstrumentationSessionManager:n}=await import(`./InstrumentationSession-DxXs0sCp.mjs`),{EvidenceGraphBridge:r}=await import(`./EvidenceGraphBridge-BIfgB7HP.mjs`),{InstrumentationHandlers:i}=await import(`./handlers-De5u62Ga2.mjs`),a=e.handlerDeps.hookPresetHandlers,o=e.handlerDeps.advancedHandlers,s=e.getDomainInstance(`evidenceGraph`);s||(s=new t,e.setDomainInstance(`evidenceGraph`,s));let c=e.getDomainInstance(`instrumentationSessionManager`);c||(c=new n,e.setDomainInstance(`instrumentationSessionManager`,c));let l=e.getDomainInstance(`evidenceGraphBridge`);return l||(l=new r(s),e.setDomainInstance(`evidenceGraphBridge`,l)),c.setEvidenceBridge(l),e.instrumentationHandlers||=new i(c,{hookPresetHandlers:a,advancedHandlers:o}),e.instrumentationHandlers}const u={kind:`domain-manifest`,version:1,domain:o,depKey:s,profiles:[`full`],ensure:l,workflowRule:{patterns:[/(hook|intercept|trace|instrument).*(session|unified|manage|all)/i,/(session|统一|会话).*(hook|拦截|追踪|仪器化|instrument)/i],priority:95,tools:[`instrumentation_session`,`instrumentation_operation`,`instrumentation_artifact`,`instrumentation_hook_preset`,`instrumentation_network_replay`],hint:`Instrumentation session: create session → attach hook presets / network replay → record artifacts → query artifacts → destroy when done`},registrations:c};export{u as default};
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
import{t as e}from"./EventBus-DgciURGg.mjs";import{t}from"./tool-builder-CI9914Tf.mjs";const n=[`byte`,`int8`,`int16`,`uint16`,`int32`,`uint32`,`int64`,`uint64`,`float`,`double`,`string`,`hex`,`pointer`],r=[`exact`,`unknown_initial`,`changed`,`unchanged`,`increased`,`decreased`,`greater_than`,`less_than`,`between`,`not_equal`],i=[t(`memory_first_scan`,e=>e.desc(`Start a new memory scan session.`).number(`pid`,`Target process ID`).string(`value`,`Value to search for (as string, e.g. "100", "3.14", "48 65 6C 6C 6F")`).enum(`valueType`,[...n],`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`,{type:`object`,properties:{writable:{type:`boolean`,description:`Only scan writable regions`},executable:{type:`boolean`,description:`Only scan executable regions`},moduleOnly:{type:`boolean`,description:`Only scan module-backed regions`}},description:`Filter which memory regions to scan`}).requiredOpenWorld(`pid`,`value`,`valueType`)),t(`memory_next_scan`,e=>e.desc(`Narrow an existing scan session.`).string(`sessionId`,`Scan session ID`).enum(`mode`,[...r],`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`)),t(`memory_unknown_scan`,e=>e.desc(`Start an unknown initial value scan.`).number(`pid`,`Target process ID`).enum(`valueType`,[...n],`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`,{type:`object`,properties:{writable:{type:`boolean`},executable:{type:`boolean`},moduleOnly:{type:`boolean`}}}).requiredOpenWorld(`pid`,`valueType`)),t(`memory_pointer_scan`,e=>e.desc(`Find pointers to a target address.`).number(`pid`,`Target process ID`).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()),t(`memory_group_scan`,e=>e.desc(`Search for multiple values at known offsets simultaneously.`).number(`pid`,`Target process ID`).array(`pattern`,{type:`object`,properties:{offset:{type:`number`,description:`Byte offset from base`},value:{type:`string`,description:`Expected value at offset`},type:{type:`string`,enum:[...n],description:`Value type at offset`}},required:[`offset`,`value`,`type`]},`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()),t(`memory_scan_session`,e=>e.desc(`Manage scan sessions. Actions: list (all sessions), delete (by sessionId), export (as JSON).`).enum(`action`,[`list`,`delete`,`export`],`Session management action`).string(`sessionId`,`Scan session ID (required for delete/export)`).required(`action`)),t(`memory_pointer_chain`,e=>e.desc(`Pointer chain operations: scan (find chains to target), validate, resolve, or export as JSON.`).enum(`action`,[`scan`,`validate`,`resolve`,`export`],`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`)),t(`memory_structure_analyze`,e=>e.desc(`Analyze memory at an address to infer data structure layout.`).number(`pid`,`Target process ID`).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()),t(`memory_vtable_parse`,e=>e.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()),t(`memory_structure_export_c`,e=>e.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()),t(`memory_structure_compare`,e=>e.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()),t(`memory_breakpoint`,e=>e.desc(`Hardware breakpoint via x64 debug registers (DR0-DR3). Actions: set, remove, list, trace.`).enum(`action`,[`set`,`remove`,`list`,`trace`],`Breakpoint operation`).number(`pid`,`Target process ID (action=set/trace)`).string(`address`,`Address hex (action=set/trace)`).enum(`access`,[`read`,`write`,`readwrite`,`execute`],`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()),t(`memory_patch_bytes`,e=>e.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()),t(`memory_patch_nop`,e=>e.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()),t(`memory_patch_undo`,e=>e.desc(`Undo a previous patch by restoring the original bytes.`).string(`patchId`,`Patch ID to undo`).required(`patchId`).destructive()),t(`memory_code_caves`,e=>e.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()),t(`memory_write_value`,e=>e.desc(`Write a typed value to a memory address. Supports undo/redo via memory_write_history(action=undo|redo).`).number(`pid`,`Target process ID`).string(`address`,`Address to write to (hex)`).string(`value`,`Value to write (as string)`).enum(`valueType`,[...n],`Data type of the value`).required(`pid`,`address`,`value`,`valueType`).destructive()),t(`memory_freeze`,e=>e.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`,[...n],`Data type (action=freeze)`).number(`intervalMs`,`Write interval ms (action=freeze, default: 100)`).string(`freezeId`,`Freeze ID to remove (action=unfreeze)`).required(`action`).destructive()),t(`memory_dump`,e=>e.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()),t(`memory_speedhack`,e=>e.desc(`Hook time APIs to scale process time. Actions: apply (hook + set speed), set (adjust speed).`).enum(`action`,[`apply`,`set`],`Speedhack action`).number(`pid`,`Target process ID`).number(`speed`,`Speed multiplier`).required(`action`,`pid`,`speed`).destructive()),t(`memory_write_history`,e=>e.desc(`Undo or redo the last memory write operation.`).enum(`action`,[`undo`,`redo`],`History action`).required(`action`).destructive().openWorld()),t(`memory_heap_enumerate`,e=>e.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()),t(`memory_heap_stats`,e=>e.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()),t(`memory_heap_anomalies`,e=>e.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()),t(`memory_pe_headers`,e=>e.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()),t(`memory_pe_imports_exports`,e=>e.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`,[`imports`,`exports`,`both`],`Which table to parse`,{default:`both`}).required(`pid`,`moduleBase`).query()),t(`memory_inline_hook_detect`,e=>e.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()),t(`memory_anticheat_detect`,e=>e.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()),t(`memory_guard_pages`,e=>e.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()),t(`memory_integrity_check`,e=>e.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())],a=`memory`,o=`memoryScanHandlers`,s=(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`;let c=null;async function l(e){let{MemoryScanHandlers:t}=await import(`./handlers.impl-CD2_kOcC.mjs`);c=e;let n=e;if(n[o])return n[o];let[r,i,a,l,u,d]=await Promise.all([import(`./MemoryScanner-BLYnMJy6.mjs`),import(`./MemoryScanSession-CaxAjZJf.mjs`),import(`./PointerChainEngine-5nF9eNlu.mjs`),import(`./StructureAnalyzer-A-WamfYE.mjs`),import(`./CodeInjector-BlgyqTOk.mjs`),import(`./MemoryController-BaqstM5w.mjs`)]);if(s){let[s,c,f,p,m]=await Promise.all([import(`./HardwareBreakpoint-OcJqNFVc.mjs`),import(`./Speedhack-l6s8L2Qw.mjs`),import(`./HeapAnalyzer-CqAxZzeS.mjs`),import(`./PEAnalyzer-DJyaJTQJ.mjs`),import(`./AntiCheatDetector-CGVGNfy5.mjs`)]);n[o]=new t(r.memoryScanner,i.scanSessionManager,a.pointerChainEngine,l.structureAnalyzer,s.hardwareBreakpointEngine,u.codeInjector,d.memoryController,c.speedhack,f.heapAnalyzer,p.peAnalyzer,m.antiCheatDetector,e.eventBus)}else n[o]=new t(r.memoryScanner,i.scanSessionManager,a.pointerChainEngine,l.structureAnalyzer,null,u.codeInjector,d.memoryController,null,null,null,null,e.eventBus);return n[o]}function u(t){return n=>{let r=n[o];return n=>{let i=n._meta,a;return i?.progressToken!==void 0&&c&&(a=e(c.eventBus,i.progressToken)),t(r,{...n,onProgress:a})}}}function d(e){let t=i.find(t=>t.name===e);if(!t)throw Error(`Memory tool not found: ${e}`);return t}const f=new Set([`memory_heap_enumerate`,`memory_heap_stats`,`memory_heap_anomalies`,`memory_pe_headers`,`memory_pe_imports_exports`,`memory_inline_hook_detect`,`memory_anticheat_detect`,`memory_guard_pages`,`memory_integrity_check`,`memory_breakpoint`,`memory_speedhack`]),p=[{tool:d(`memory_first_scan`),domain:a,bind:u((e,t)=>e.handleFirstScan(t))},{tool:d(`memory_next_scan`),domain:a,bind:u((e,t)=>e.handleNextScan(t))},{tool:d(`memory_unknown_scan`),domain:a,bind:u((e,t)=>e.handleUnknownScan(t))},{tool:d(`memory_pointer_scan`),domain:a,bind:u((e,t)=>e.handlePointerScan(t))},{tool:d(`memory_group_scan`),domain:a,bind:u((e,t)=>e.handleGroupScan(t))},{tool:d(`memory_scan_session`),domain:a,bind:u((e,t)=>e.handleScanSessionDispatch(t))},{tool:d(`memory_pointer_chain`),domain:a,bind:u((e,t)=>e.handlePointerChainDispatch(t))},{tool:d(`memory_structure_analyze`),domain:a,bind:u((e,t)=>e.handleStructureAnalyze(t))},{tool:d(`memory_vtable_parse`),domain:a,bind:u((e,t)=>e.handleVtableParse(t))},{tool:d(`memory_structure_export_c`),domain:a,bind:u((e,t)=>e.handleStructureExportC(t))},{tool:d(`memory_structure_compare`),domain:a,bind:u((e,t)=>e.handleStructureCompare(t))},{tool:d(`memory_breakpoint`),domain:a,bind:u((e,t)=>e.handleBreakpointDispatch(t))},{tool:d(`memory_patch_bytes`),domain:a,bind:u((e,t)=>e.handlePatchBytes(t))},{tool:d(`memory_patch_nop`),domain:a,bind:u((e,t)=>e.handlePatchNop(t))},{tool:d(`memory_patch_undo`),domain:a,bind:u((e,t)=>e.handlePatchUndo(t))},{tool:d(`memory_code_caves`),domain:a,bind:u((e,t)=>e.handleCodeCaves(t))},{tool:d(`memory_write_value`),domain:a,bind:u((e,t)=>e.handleWriteValue(t))},{tool:d(`memory_freeze`),domain:a,bind:u((e,t)=>e.handleFreezeDispatch(t))},{tool:d(`memory_dump`),domain:a,bind:u((e,t)=>e.handleDump(t))},{tool:d(`memory_speedhack`),domain:a,bind:u((e,t)=>e.handleSpeedhackDispatch(t))},{tool:d(`memory_write_history`),domain:a,bind:u((e,t)=>e.handleWriteHistoryDispatch(t))},{tool:d(`memory_heap_enumerate`),domain:a,bind:u((e,t)=>e.handleHeapEnumerate(t))},{tool:d(`memory_heap_stats`),domain:a,bind:u((e,t)=>e.handleHeapStats(t))},{tool:d(`memory_heap_anomalies`),domain:a,bind:u((e,t)=>e.handleHeapAnomalies(t))},{tool:d(`memory_pe_headers`),domain:a,bind:u((e,t)=>e.handlePEHeaders(t))},{tool:d(`memory_pe_imports_exports`),domain:a,bind:u((e,t)=>e.handlePEImportsExports(t))},{tool:d(`memory_inline_hook_detect`),domain:a,bind:u((e,t)=>e.handleInlineHookDetect(t))},{tool:d(`memory_anticheat_detect`),domain:a,bind:u((e,t)=>e.handleAntiCheatDetect(t))},{tool:d(`memory_guard_pages`),domain:a,bind:u((e,t)=>e.handleGuardPages(t))},{tool:d(`memory_integrity_check`),domain:a,bind:u((e,t)=>e.handleIntegrityCheck(t))}],m={kind:`domain-manifest`,version:1,domain:a,depKey:o,profiles:[`full`],ensure:l,registrations:s?p:p.filter(e=>!f.has(e.tool.name)),workflowRule:{patterns:[/memory\s*scan/i,/cheat\s*engine/i,/find\s*(value|address|variable|struct)/i,/scan\s*(for|memory)/i,/pointer\s*(chain|scan)/i,/struct(ure)?\s*(analy|infer|dissect)/i,/vtable|rtti/i,/breakpoint|watchpoint|hardware\s*bp/i,/patch\s*(byte|nop|code)/i,/code\s*cave/i,/freeze|unfreeze/i,/speedhack|time\s*(hack|scale)/i,/memory\s*(dump|hex)/i,/undo|redo/i,/heap|堆\s*(分析|枚举|异常)/i,/PE\s*(header|import|export)|inline.*hook/i,/anti.?cheat|anti.?debug|反作弊|反调试/i,/guard\s*page|integrity\s*check|代码完整性/i,/内存\s*(扫描|搜索|分析|结构|断点|注入|冻结|加速|堆|模块|反作弊)/i],priority:90,tools:[`memory_first_scan`,`memory_next_scan`,`memory_unknown_scan`,`memory_pointer_chain`,`memory_structure_analyze`,`memory_vtable_parse`,`memory_scan_session`,...s?[`memory_breakpoint`,`memory_speedhack`]:[],`memory_patch_bytes`,`memory_freeze`,`memory_dump`,...s?[`memory_speedhack`,`memory_heap_enumerate`,`memory_pe_headers`,`memory_anticheat_detect`]:[],`memory_write_history`],hint:s?`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`}};export{m as default};
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
import{i as e}from"./response-C7rKQst4.mjs";import{t}from"./registry-DUHIPE-v.mjs";import{n}from"./bind-helpers-BlAOQrFQ.mjs";const r=[{name:`skia_detect_renderer`,description:`Detect the active Skia renderer backend from the current page context.`,inputSchema:{type:`object`,properties:{},required:[]}},{name:`skia_extract_scene`,description:`Extract a lightweight Skia scene tree from the selected canvas.`,inputSchema:{type:`object`,properties:{canvasId:{type:`string`}},required:[]}},{name:`skia_correlate_objects`,description:`Correlate requested Skia node identifiers with the extracted scene tree.`,inputSchema:{type:`object`,properties:{canvasId:{type:`string`,description:`Optional canvas element ID to target for correlation.`},skiaNodeIds:{type:`array`,items:{type:`string`},description:`Optional list of Skia node identifiers to correlate.`}},required:[]}}],i=`skia-capture`,a=`skiaCaptureHandlers`,o=[`workflow`,`full`],s=n({domain:i,depKey:a,lookup:t(r),wrapResult:e,entries:[{tool:`skia_detect_renderer`,method:`handleSkiaDetectRenderer`},{tool:`skia_extract_scene`,method:`handleSkiaExtractScene`},{tool:`skia_correlate_objects`,method:`handleSkiaCorrelateObjects`}]});async function c(e){let{SkiaCaptureHandlers:t}=await import(`./handlers-D49r1-1P.mjs`),n=e.getDomainInstance(a);if(n)return n;let r=new t({pageController:e.pageController??null,eventBus:e.eventBus});return e.setDomainInstance(a,r),r}const l={kind:`domain-manifest`,version:1,domain:i,depKey:a,profiles:o,registrations:s,ensure:c,workflowRule:{patterns:[/\b(skia|gpu|render(er)?|scene\s?(tree|graph)|draw\s?call|raster|paint|layer)\b/i,/skia.*(render|detect|scene)/i,/canvas.*skia/i,/gpu.*backend/i],priority:78,tools:[`skia_detect_renderer`,`skia_extract_scene`,`skia_correlate_objects`],hint:`Skia pipeline analysis: detect GPU backend → dump scene tree → correlate with JS objects.`},prerequisites:{skia_detect_renderer:[{condition:`Browser must be running with CDP attached`,fix:`Call browser_launch or browser_attach first`}],skia_extract_scene:[{condition:`Browser must be running with CDP attached`,fix:`Call browser_launch or browser_attach first`}],skia_correlate_objects:[{condition:`V8 heap snapshot should be available for robust matching`,fix:`Run v8_heap_snapshot_capture before correlation`}]},toolDependencies:[{from:`canvas`,to:`skia-capture`,relation:`uses`,weight:.9},{from:`skia_correlate_objects`,to:`v8_heap_snapshot_capture`,relation:`precedes`,weight:.6}]};export{l as default};
|