@jshookmcp/jshook 0.2.2 → 0.2.5
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/LICENSE +661 -661
- package/README.md +15 -6
- package/README.zh.md +19 -4
- package/dist/native/scripts/linux/enum-windows.sh +12 -12
- package/dist/native/scripts/macos/enum-windows.applescript +22 -22
- package/dist/native/scripts/windows/enum-windows-by-class.ps1 +51 -51
- package/dist/native/scripts/windows/enum-windows.ps1 +44 -44
- package/dist/native/scripts/windows/inject-dll.ps1 +21 -21
- package/dist/packages/extension-sdk/src/bridges/shared.js +2 -2
- package/dist/packages/extension-sdk/src/plugin.d.ts +5 -0
- package/dist/packages/extension-sdk/src/plugin.js +119 -33
- package/dist/packages/extension-sdk/src/workflow.d.ts +156 -0
- package/dist/packages/extension-sdk/src/workflow.js +236 -0
- package/dist/src/config/search-defaults.js +161 -0
- package/dist/src/constants.d.ts +3 -0
- package/dist/src/constants.js +4 -1
- package/dist/src/index.d.ts +1 -1
- package/dist/src/index.js +13 -17
- package/dist/src/modules/analyzer/CodeAnalyzer.d.ts +1 -3
- package/dist/src/modules/analyzer/CodeAnalyzer.js +16 -28
- package/dist/src/modules/analyzer/CodeAnalyzerDataFlow.d.ts +1 -2
- package/dist/src/modules/analyzer/CodeAnalyzerDataFlow.js +1 -45
- package/dist/src/modules/analyzer/IntelligentAnalyzer.d.ts +1 -37
- package/dist/src/modules/analyzer/IntelligentAnalyzer.js +9 -142
- package/dist/src/modules/analyzer/PatternDetector.js +3 -3
- package/dist/src/modules/analyzer/PatternDetectorAuthPatterns.js +1 -1
- package/dist/src/modules/browser/BrowserDiscovery.d.ts +6 -5
- package/dist/src/modules/browser/BrowserDiscovery.js +3 -3
- package/dist/src/modules/browser/BrowserModeManager.d.ts +1 -1
- package/dist/src/modules/browser/BrowserModeManager.js +11 -10
- package/dist/src/modules/browser/TabRegistry.js +2 -2
- package/dist/src/modules/browser/UnifiedBrowserManager.d.ts +1 -0
- package/dist/src/modules/browser/UnifiedBrowserManager.js +19 -4
- package/dist/src/modules/captcha/AICaptchaDetector.d.ts +14 -23
- package/dist/src/modules/captcha/AICaptchaDetector.js +8 -202
- package/dist/src/modules/captcha/CaptchaDetector.d.ts +31 -17
- package/dist/src/modules/captcha/CaptchaDetector.js +1 -1
- package/dist/src/modules/collector/CodeCache.d.ts +2 -2
- package/dist/src/modules/collector/CodeCollector.d.ts +12 -9
- package/dist/src/modules/collector/CodeCollector.js +5 -6
- package/dist/src/modules/collector/DOMInspector.d.ts +3 -2
- package/dist/src/modules/collector/DOMInspector.js +49 -59
- package/dist/src/modules/collector/PageController.d.ts +17 -4
- package/dist/src/modules/collector/PageController.js +2 -5
- package/dist/src/modules/collector/PageScriptCollectors.js +3 -3
- package/dist/src/modules/crypto/CryptoDetector.d.ts +1 -4
- package/dist/src/modules/crypto/CryptoDetector.js +2 -42
- package/dist/src/modules/crypto/CryptoRules.js +1 -1
- package/dist/src/modules/debugger/BlackboxManager.js +1 -1
- package/dist/src/modules/debugger/DebuggerManager.impl.core.scope.js +1 -1
- package/dist/src/modules/debugger/ScriptManager.impl.extract-function-tree.js +5 -3
- package/dist/src/modules/debugger/WatchExpressionManager.js +1 -1
- package/dist/src/modules/deobfuscator/Deobfuscator.d.ts +1 -4
- package/dist/src/modules/deobfuscator/Deobfuscator.js +4 -39
- package/dist/src/modules/deobfuscator/JSVMPDeobfuscator.d.ts +0 -3
- package/dist/src/modules/deobfuscator/JSVMPDeobfuscator.js +2 -8
- package/dist/src/modules/deobfuscator/JSVMPDeobfuscator.restore.d.ts +2 -3
- package/dist/src/modules/deobfuscator/JSVMPDeobfuscator.restore.js +5 -57
- package/dist/src/modules/deobfuscator/JScramblerDeobfuscator.js +3 -4
- package/dist/src/modules/deobfuscator/PackerDeobfuscator.js +1 -1
- package/dist/src/modules/deobfuscator/VMDeobfuscator.d.ts +2 -10
- package/dist/src/modules/deobfuscator/VMDeobfuscator.js +3 -128
- package/dist/src/modules/deobfuscator/webcrack.js +15 -2
- package/dist/src/modules/emulator/AIEnvironmentAnalyzer.d.ts +5 -8
- package/dist/src/modules/emulator/AIEnvironmentAnalyzer.js +10 -102
- package/dist/src/modules/emulator/EnvironmentEmulator.d.ts +1 -5
- package/dist/src/modules/emulator/EnvironmentEmulator.js +7 -91
- package/dist/src/modules/emulator/EnvironmentEmulatorFetch.js +58 -61
- package/dist/src/modules/emulator/templates/chrome-env.d.ts +17 -7
- package/dist/src/modules/emulator/templates/chrome-env.js +14 -7
- package/dist/src/modules/external/ExternalToolRunner.d.ts +1 -1
- package/dist/src/modules/external/ExternalToolRunner.js +26 -23
- package/dist/src/modules/monitor/ConsoleMonitor.impl.core.class.d.ts +13 -0
- package/dist/src/modules/monitor/ConsoleMonitor.impl.core.class.js +42 -0
- package/dist/src/modules/monitor/FetchInterceptor.d.ts +46 -0
- package/dist/src/modules/monitor/FetchInterceptor.js +191 -0
- package/dist/src/modules/monitor/PerformanceMonitor.js +8 -7
- package/dist/src/modules/process/BaseMemoryManager.d.ts +1 -1
- package/dist/src/modules/process/LinuxProcessManager.js +4 -2
- package/dist/src/modules/process/MacProcessManager.js +1 -1
- package/dist/src/modules/process/MemoryManager.d.ts +1 -1
- package/dist/src/modules/process/MemoryManager.js +2 -2
- package/dist/src/modules/process/ProcessManager.impl.js +1 -1
- package/dist/src/modules/process/memory/AuditTrail.js +1 -1
- package/dist/src/modules/process/memory/reader.js +35 -3
- package/dist/src/modules/process/memory/regions.enumerate.js +1 -1
- package/dist/src/modules/process/memory/regions.protection.js +42 -9
- package/dist/src/modules/process/memory/scanner.d.ts +5 -1
- package/dist/src/modules/process/memory/scanner.darwin.js +57 -0
- package/dist/src/modules/process/memory/scanner.js +88 -4
- package/dist/src/modules/process/memory/writer.js +44 -4
- package/dist/src/modules/security/ExecutionSandbox.js +7 -8
- package/dist/src/modules/stealth/FingerprintManager.js +1 -1
- package/dist/src/modules/stealth/StealthScripts.d.ts +4 -2
- package/dist/src/modules/stealth/StealthScripts.js +53 -14
- package/dist/src/modules/stealth/StealthVerifier.d.ts +1 -1
- package/dist/src/modules/stealth/StealthVerifier.js +2 -4
- package/dist/src/modules/symbolic/JSVMPSymbolicExecutor.d.ts +14 -0
- package/dist/src/modules/symbolic/JSVMPSymbolicExecutor.js +181 -2
- package/dist/src/modules/trace/TraceDB.js +12 -6
- package/dist/src/modules/trace/TraceRecorder.js +1 -5
- package/dist/src/native/AntiCheatDetector.js +67 -16
- package/dist/src/native/CodeInjector.js +4 -4
- package/dist/src/native/HardwareBreakpoint.js +25 -16
- package/dist/src/native/HeapAnalyzer.js +2 -2
- package/dist/src/native/MemoryController.js +1 -1
- package/dist/src/native/MemoryScanSession.js +2 -2
- package/dist/src/native/MemoryScanner.js +4 -8
- package/dist/src/native/NativeMemoryManager.impl.js +2 -2
- package/dist/src/native/PEAnalyzer.js +14 -15
- package/dist/src/native/PointerChainEngine.js +2 -4
- package/dist/src/native/ScriptLoader.js +4 -9
- package/dist/src/native/Speedhack.js +1 -1
- package/dist/src/native/StructureAnalyzer.js +52 -33
- package/dist/src/native/Win32API.d.ts +1 -0
- package/dist/src/native/Win32API.js +13 -0
- package/dist/src/native/Win32Debug.js +19 -19
- package/dist/src/native/platform/darwin/DarwinAPI.d.ts +2 -0
- package/dist/src/native/platform/darwin/DarwinAPI.js +8 -0
- package/dist/src/native/platform/darwin/DarwinMemoryProvider.js +6 -1
- package/dist/src/server/MCPServer.context.d.ts +2 -1
- package/dist/src/server/MCPServer.d.ts +2 -1
- package/dist/src/server/MCPServer.domain.d.ts +1 -1
- package/dist/src/server/MCPServer.domain.js +81 -16
- package/dist/src/server/MCPServer.js +42 -14
- package/dist/src/server/MCPServer.resources.d.ts +2 -0
- package/dist/src/server/MCPServer.resources.js +91 -0
- package/dist/src/server/MCPServer.search.handlers.call.js +2 -1
- package/dist/src/server/MCPServer.search.helpers.js +2 -2
- package/dist/src/server/MCPServer.tools.js +1 -1
- package/dist/src/server/MCPServer.transport.js +12 -0
- package/dist/src/server/ToolCallContextGuard.d.ts +5 -0
- package/dist/src/server/ToolCallContextGuard.js +85 -0
- package/dist/src/server/ToolRouter.d.ts +26 -10
- package/dist/src/server/ToolRouter.intent.d.ts +26 -0
- package/dist/src/server/ToolRouter.intent.js +77 -0
- package/dist/src/server/ToolRouter.js +103 -284
- package/dist/src/server/ToolRouter.policy.d.ts +22 -0
- package/dist/src/server/ToolRouter.policy.js +163 -0
- package/dist/src/server/ToolRouter.probe.d.ts +17 -0
- package/dist/src/server/ToolRouter.probe.js +103 -0
- package/dist/src/server/ToolRouter.renderer.d.ts +9 -0
- package/dist/src/server/ToolRouter.renderer.js +52 -0
- package/dist/src/server/activation/ActivationController.js +15 -12
- package/dist/src/server/activation/CompoundConditionEngine.js +1 -1
- package/dist/src/server/activation/PredictiveBooster.js +1 -3
- package/dist/src/server/domains/analysis/definitions.js +155 -655
- package/dist/src/server/domains/analysis/handlers.impl.d.ts +8 -8
- package/dist/src/server/domains/analysis/handlers.impl.js +34 -28
- package/dist/src/server/domains/analysis/handlers.web-tools.js +4 -3
- package/dist/src/server/domains/analysis/manifest.js +6 -4
- package/dist/src/server/domains/antidebug/definitions.js +25 -111
- package/dist/src/server/domains/browser/definitions.tools.advanced.js +59 -88
- package/dist/src/server/domains/browser/definitions.tools.behavior.js +120 -227
- package/dist/src/server/domains/browser/definitions.tools.page-core.js +157 -386
- package/dist/src/server/domains/browser/definitions.tools.page-system.js +108 -250
- package/dist/src/server/domains/browser/definitions.tools.runtime.js +61 -174
- package/dist/src/server/domains/browser/definitions.tools.security.js +92 -237
- package/dist/src/server/domains/browser/handlers/camoufox-browser.js +3 -2
- package/dist/src/server/domains/browser/handlers/captcha-solver.js +3 -3
- package/dist/src/server/domains/browser/handlers/dom-query.js +2 -1
- package/dist/src/server/domains/browser/handlers/facade-initializer.d.ts +3 -3
- package/dist/src/server/domains/browser/handlers/facade-initializer.js +3 -3
- package/dist/src/server/domains/browser/handlers/framework-state.js +231 -3
- package/dist/src/server/domains/browser/handlers/indexeddb-dump.js +21 -20
- package/dist/src/server/domains/browser/handlers/script-management.js +1 -1
- package/dist/src/server/domains/browser/handlers/stealth-injection.js +8 -2
- package/dist/src/server/domains/browser/handlers.impl.d.ts +15 -12
- package/dist/src/server/domains/browser/handlers.impl.js +5 -6
- package/dist/src/server/domains/browser/manifest.js +37 -13
- package/dist/src/server/domains/coordination/definitions.js +50 -149
- package/dist/src/server/domains/coordination/index.d.ts +20 -1
- package/dist/src/server/domains/coordination/index.js +133 -0
- package/dist/src/server/domains/coordination/manifest.js +15 -0
- package/dist/src/server/domains/debugger/definitions.tools.advanced.js +72 -189
- package/dist/src/server/domains/debugger/definitions.tools.core.js +114 -288
- package/dist/src/server/domains/debugger/manifest.js +9 -2
- package/dist/src/server/domains/encoding/definitions.js +43 -153
- package/dist/src/server/domains/encoding/handlers.base.js +2 -2
- package/dist/src/server/domains/evidence/definitions.d.ts +2 -0
- package/dist/src/server/domains/evidence/definitions.js +42 -0
- package/dist/src/server/domains/evidence/handlers.d.ts +582 -0
- package/dist/src/server/domains/evidence/handlers.js +60 -0
- package/dist/src/server/domains/evidence/index.d.ts +2 -0
- package/dist/src/server/domains/evidence/index.js +2 -0
- package/dist/src/server/domains/evidence/manifest.d.ts +63 -0
- package/dist/src/server/domains/evidence/manifest.js +78 -0
- package/dist/src/server/domains/graphql/definitions.js +53 -141
- package/dist/src/server/domains/graphql/handlers.impl.core.runtime.replay.js +92 -114
- package/dist/src/server/domains/hooks/ai-handlers.d.ts +0 -7
- package/dist/src/server/domains/hooks/ai-handlers.js +4 -70
- package/dist/src/server/domains/hooks/definitions.js +69 -335
- package/dist/src/server/domains/hooks/manifest.d.ts +1 -1
- package/dist/src/server/domains/hooks/manifest.js +1 -2
- package/dist/src/server/domains/instrumentation/definitions.d.ts +2 -0
- package/dist/src/server/domains/instrumentation/definitions.js +99 -0
- package/dist/src/server/domains/instrumentation/handlers.d.ts +78 -0
- package/dist/src/server/domains/instrumentation/handlers.js +206 -0
- package/dist/src/server/domains/instrumentation/index.d.ts +2 -0
- package/dist/src/server/domains/instrumentation/index.js +2 -0
- package/dist/src/server/domains/instrumentation/manifest.d.ts +63 -0
- package/dist/src/server/domains/instrumentation/manifest.js +114 -0
- package/dist/src/server/domains/macro/definitions.js +16 -43
- package/dist/src/server/domains/maintenance/definitions.js +60 -219
- package/dist/src/server/domains/maintenance/handlers.d.ts +2 -2
- package/dist/src/server/domains/maintenance/handlers.extensions.js +78 -20
- package/dist/src/server/domains/maintenance/handlers.js +2 -2
- package/dist/src/server/domains/memory/definitions.js +387 -559
- package/dist/src/server/domains/memory/handlers/hooks.d.ts +55 -0
- package/dist/src/server/domains/memory/handlers/hooks.js +115 -0
- package/dist/src/server/domains/memory/handlers/integrity.d.ts +77 -0
- package/dist/src/server/domains/memory/handlers/integrity.js +180 -0
- package/dist/src/server/domains/memory/handlers/pointer-chain.d.ts +29 -0
- package/dist/src/server/domains/memory/handlers/pointer-chain.js +82 -0
- package/dist/src/server/domains/memory/handlers/readwrite.d.ts +41 -0
- package/dist/src/server/domains/memory/handlers/readwrite.js +78 -0
- package/dist/src/server/domains/memory/handlers/scan.d.ts +35 -0
- package/dist/src/server/domains/memory/handlers/scan.js +97 -0
- package/dist/src/server/domains/memory/handlers/session.d.ts +23 -0
- package/dist/src/server/domains/memory/handlers/session.js +49 -0
- package/dist/src/server/domains/memory/handlers/structure.d.ts +29 -0
- package/dist/src/server/domains/memory/handlers/structure.js +74 -0
- package/dist/src/server/domains/memory/handlers.impl.d.ts +49 -54
- package/dist/src/server/domains/memory/handlers.impl.js +63 -494
- package/dist/src/server/domains/memory/manifest.js +236 -64
- package/dist/src/server/domains/native-bridge/definitions.js +54 -192
- package/dist/src/server/domains/native-bridge/index.d.ts +1 -0
- package/dist/src/server/domains/native-bridge/index.js +2 -1
- package/dist/src/server/domains/network/auth-extractor.js +1 -1
- package/dist/src/server/domains/network/definitions.js +175 -578
- package/dist/src/server/domains/network/handlers.base.core.d.ts +64 -0
- package/dist/src/server/domains/network/handlers.base.core.js +623 -0
- package/dist/src/server/domains/network/handlers.base.d.ts +2 -124
- package/dist/src/server/domains/network/handlers.base.js +3 -878
- package/dist/src/server/domains/network/handlers.base.performance.d.ts +63 -0
- package/dist/src/server/domains/network/handlers.base.performance.js +193 -0
- package/dist/src/server/domains/network/handlers.base.types.d.ts +42 -0
- package/dist/src/server/domains/network/handlers.base.types.js +89 -0
- package/dist/src/server/domains/network/handlers.impl.core.runtime.d.ts +1 -1
- package/dist/src/server/domains/network/handlers.impl.core.runtime.intercept.d.ts +21 -0
- package/dist/src/server/domains/network/handlers.impl.core.runtime.intercept.js +186 -0
- package/dist/src/server/domains/network/handlers.impl.core.runtime.js +1 -1
- package/dist/src/server/domains/network/manifest.js +15 -0
- package/dist/src/server/domains/network/replay.js +1 -4
- package/dist/src/server/domains/platform/definitions.js +121 -112
- package/dist/src/server/domains/platform/handlers/bridge-handlers.d.ts +5 -1
- package/dist/src/server/domains/platform/handlers/bridge-handlers.js +194 -5
- package/dist/src/server/domains/platform/handlers/electron-asar-helpers.js +26 -6
- package/dist/src/server/domains/platform/handlers/electron-dual-cdp.d.ts +3 -0
- package/dist/src/server/domains/platform/handlers/electron-dual-cdp.js +170 -0
- package/dist/src/server/domains/platform/handlers/electron-fuse-handler.d.ts +3 -0
- package/dist/src/server/domains/platform/handlers/electron-fuse-handler.js +193 -0
- package/dist/src/server/domains/platform/handlers/electron-handlers.d.ts +6 -0
- package/dist/src/server/domains/platform/handlers/electron-handlers.js +95 -2
- package/dist/src/server/domains/platform/handlers/electron-ipc-sniffer.d.ts +2 -0
- package/dist/src/server/domains/platform/handlers/electron-ipc-sniffer.js +370 -0
- package/dist/src/server/domains/platform/handlers/electron-userdata-handler.d.ts +2 -0
- package/dist/src/server/domains/platform/handlers/electron-userdata-handler.js +78 -0
- package/dist/src/server/domains/platform/handlers/miniapp-handlers.d.ts +1 -1
- package/dist/src/server/domains/platform/handlers/miniapp-handlers.js +4 -4
- package/dist/src/server/domains/platform/handlers/v8-bytecode-handler.d.ts +2 -0
- package/dist/src/server/domains/platform/handlers/v8-bytecode-handler.js +207 -0
- package/dist/src/server/domains/platform/handlers.d.ts +48 -0
- package/dist/src/server/domains/platform/handlers.js +29 -0
- package/dist/src/server/domains/platform/manifest.js +38 -0
- package/dist/src/server/domains/process/definitions.js +163 -647
- package/dist/src/server/domains/process/handlers.base.d.ts +3 -95
- package/dist/src/server/domains/process/handlers.base.js +7 -462
- package/dist/src/server/domains/process/handlers.base.process.d.ts +61 -0
- package/dist/src/server/domains/process/handlers.base.process.js +417 -0
- package/dist/src/server/domains/process/handlers.base.types.d.ts +57 -0
- package/dist/src/server/domains/process/handlers.base.types.js +50 -0
- package/dist/src/server/domains/process/handlers.impl.core.runtime.inject.js +19 -17
- package/dist/src/server/domains/process/manifest.js +6 -1
- package/dist/src/server/domains/sandbox/definitions.js +11 -33
- package/dist/src/server/domains/sandbox/handlers.js +8 -3
- package/dist/src/server/domains/shared/ResponseBuilder.d.ts +209 -0
- package/dist/src/server/domains/shared/ResponseBuilder.js +48 -0
- package/dist/src/server/domains/shared/modules.d.ts +0 -2
- package/dist/src/server/domains/shared/modules.js +0 -1
- package/dist/src/server/domains/sourcemap/definitions.js +27 -111
- package/dist/src/server/domains/sourcemap/handlers.impl.sourcemap-common.js +7 -2
- package/dist/src/server/domains/sourcemap/handlers.impl.sourcemap-main.js +1 -1
- package/dist/src/server/domains/sourcemap/handlers.impl.sourcemap-parse-base.js +1 -1
- package/dist/src/server/domains/sourcemap/manifest.d.ts +1 -1
- package/dist/src/server/domains/sourcemap/manifest.js +1 -1
- package/dist/src/server/domains/streaming/definitions.js +36 -148
- package/dist/src/server/domains/streaming/handlers.impl.streaming-sse.js +163 -164
- package/dist/src/server/domains/streaming/handlers.impl.streaming-ws.js +1 -1
- package/dist/src/server/domains/trace/TraceSummarizer.d.ts +60 -0
- package/dist/src/server/domains/trace/TraceSummarizer.js +112 -0
- package/dist/src/server/domains/trace/definitions.tools.js +51 -176
- package/dist/src/server/domains/trace/handlers.d.ts +2 -1
- package/dist/src/server/domains/trace/handlers.js +62 -9
- package/dist/src/server/domains/trace/index.d.ts +2 -1
- package/dist/src/server/domains/trace/index.js +2 -1
- package/dist/src/server/domains/trace/manifest.js +18 -4
- package/dist/src/server/domains/transform/definitions.js +50 -210
- package/dist/src/server/domains/transform/handlers.impl.transform-base.js +6 -6
- package/dist/src/server/domains/transform/handlers.impl.transform-crypto.js +18 -19
- package/dist/src/server/domains/transform/manifest.d.ts +1 -1
- package/dist/src/server/domains/transform/manifest.js +1 -1
- package/dist/src/server/domains/wasm/definitions.js +55 -232
- package/dist/src/server/domains/wasm/handlers.js +3 -3
- package/dist/src/server/domains/workflow/definitions.js +144 -414
- package/dist/src/server/domains/workflow/handlers.impl.workflow-account-bundle.js +2 -2
- package/dist/src/server/domains/workflow/handlers.impl.workflow-base.d.ts +2 -0
- package/dist/src/server/domains/workflow/handlers.impl.workflow-base.js +126 -87
- package/dist/src/server/domains/workflow/handlers.impl.workflow-batch.js +5 -5
- package/dist/src/server/evidence/ReverseEvidenceGraph.d.ts +20 -0
- package/dist/src/server/evidence/ReverseEvidenceGraph.js +208 -0
- package/dist/src/server/evidence/index.d.ts +2 -0
- package/dist/src/server/evidence/index.js +1 -0
- package/dist/src/server/evidence/types.d.ts +22 -0
- package/dist/src/server/evidence/types.js +1 -0
- package/dist/src/server/extensions/ExtensionManager.d.ts +1 -0
- package/dist/src/server/extensions/ExtensionManager.discovery.js +72 -9
- package/dist/src/server/extensions/ExtensionManager.integrity.js +1 -1
- package/dist/src/server/extensions/ExtensionManager.js +193 -40
- package/dist/src/server/extensions/ExtensionManager.roots.d.ts +1 -1
- package/dist/src/server/extensions/ExtensionManager.roots.js +19 -9
- package/dist/src/server/extensions/plugin-config.js +1 -1
- package/dist/src/server/extensions/plugin-env.d.ts +1 -1
- package/dist/src/server/extensions/plugin-env.js +10 -4
- package/dist/src/server/extensions/types.d.ts +17 -0
- package/dist/src/server/extensions/types.js +1 -1
- package/dist/src/server/http/HttpMiddleware.js +1 -1
- package/dist/src/server/instrumentation/EvidenceGraphBridge.d.ts +13 -0
- package/dist/src/server/instrumentation/EvidenceGraphBridge.js +150 -0
- package/dist/src/server/instrumentation/InstrumentationSession.d.ts +60 -0
- package/dist/src/server/instrumentation/InstrumentationSession.js +269 -0
- package/dist/src/server/instrumentation/index.d.ts +2 -0
- package/dist/src/server/instrumentation/index.js +2 -0
- package/dist/src/server/instrumentation/types.d.ts +62 -0
- package/dist/src/server/instrumentation/types.js +7 -0
- package/dist/src/server/macros/MacroConfigLoader.d.ts +6 -5
- package/dist/src/server/macros/MacroConfigLoader.js +61 -59
- package/dist/src/server/macros/MacroRunner.js +6 -2
- package/dist/src/server/macros/builtins/index.d.ts +2 -3
- package/dist/src/server/macros/builtins/index.js +51 -7
- package/dist/src/server/plugins/PluginContract.d.ts +1 -1
- package/dist/src/server/registry/contracts.d.ts +7 -1
- package/dist/src/server/registry/discovery.js +5 -4
- package/dist/src/server/registry/ensure-browser-core.js +0 -3
- package/dist/src/server/registry/index.js +4 -4
- package/dist/src/server/registry/tool-builder.d.ts +46 -0
- package/dist/src/server/registry/tool-builder.js +105 -0
- package/dist/src/server/sandbox/MCPBridge.d.ts +9 -0
- package/dist/src/server/sandbox/MCPBridge.js +22 -0
- package/dist/src/server/sandbox/QuickJSSandbox.d.ts +4 -1
- package/dist/src/server/sandbox/QuickJSSandbox.js +162 -2
- package/dist/src/server/sandbox/types.d.ts +13 -0
- package/dist/src/server/search/AffinityGraph.d.ts +7 -1
- package/dist/src/server/search/AffinityGraph.js +24 -3
- package/dist/src/server/search/EmbeddingWorker.js +5 -3
- package/dist/src/server/search/FeedbackTracker.d.ts +9 -0
- package/dist/src/server/search/FeedbackTracker.js +26 -0
- package/dist/src/server/search/QueryNormalizer.d.ts +6 -0
- package/dist/src/server/search/QueryNormalizer.js +94 -0
- package/dist/src/server/search/ToolSearchEngineImpl.d.ts +2 -3
- package/dist/src/server/search/ToolSearchEngineImpl.js +38 -88
- package/dist/src/server/workflows/WorkflowContract.d.ts +24 -0
- package/dist/src/server/workflows/WorkflowContract.js +12 -0
- package/dist/src/server/workflows/WorkflowEngine.d.ts +1 -0
- package/dist/src/server/workflows/WorkflowEngine.js +136 -3
- package/dist/src/types/config.d.ts +0 -14
- package/dist/src/types/deobfuscator.d.ts +0 -1
- package/dist/src/types/index.d.ts +1 -1
- package/dist/src/utils/DetailedDataManager.js +2 -0
- package/dist/src/utils/RingBuffer.js +5 -5
- package/dist/src/utils/TokenBudgetManager.js +1 -1
- package/dist/src/utils/UnifiedCacheManager.d.ts +1 -1
- package/dist/src/utils/UnifiedCacheManager.js +3 -3
- package/dist/src/utils/artifactRetention.js +2 -2
- package/dist/src/utils/betterSqlite3.d.ts +11 -0
- package/dist/src/utils/betterSqlite3.js +88 -0
- package/dist/src/utils/browserExecutable.js +2 -2
- package/dist/src/utils/cliFastPath.js +17 -6
- package/dist/src/utils/config.js +4 -26
- package/dist/src/utils/environmentDoctor.js +138 -11
- package/dist/src/utils/outputPaths.js +16 -9
- package/dist/src/utils/parallel.js +1 -3
- package/package.json +76 -72
- package/scripts/postinstall.cjs +37 -37
- package/src/native/scripts/linux/enum-windows.sh +12 -12
- package/src/native/scripts/macos/enum-windows.applescript +22 -22
- package/src/native/scripts/windows/enum-windows-by-class.ps1 +51 -51
- package/src/native/scripts/windows/enum-windows.ps1 +44 -44
- package/src/native/scripts/windows/inject-dll.ps1 +21 -21
- package/workflows/.gitkeep +0 -0
- package/dist/src/modules/analyzer/AISummarizer.d.ts +0 -39
- package/dist/src/modules/analyzer/AISummarizer.js +0 -122
- package/dist/src/modules/hook/AIHookGenerator.d.ts +0 -52
- package/dist/src/modules/hook/AIHookGenerator.js +0 -360
- package/dist/src/modules/hook/AIHookGeneratorTemplates.d.ts +0 -9
- package/dist/src/modules/hook/AIHookGeneratorTemplates.js +0 -157
- package/dist/src/server/macros/builtins/deobfuscate-ast-flow.d.ts +0 -2
- package/dist/src/server/macros/builtins/deobfuscate-ast-flow.js +0 -25
- package/dist/src/server/macros/builtins/unpacker-flow.d.ts +0 -2
- package/dist/src/server/macros/builtins/unpacker-flow.js +0 -25
- package/dist/src/services/LLMService.d.ts +0 -37
- package/dist/src/services/LLMService.js +0 -233
- package/dist/src/services/prompts/analysis.d.ts +0 -9
- package/dist/src/services/prompts/analysis.js +0 -158
- package/dist/src/services/prompts/crypto.d.ts +0 -2
- package/dist/src/services/prompts/crypto.js +0 -108
- package/dist/src/services/prompts/deobfuscation.d.ts +0 -6
- package/dist/src/services/prompts/deobfuscation.js +0 -300
- package/dist/src/services/prompts/environment.d.ts +0 -16
- package/dist/src/services/prompts/environment.js +0 -372
- package/dist/src/services/prompts/intelligence.d.ts +0 -4
- package/dist/src/services/prompts/intelligence.js +0 -250
- package/dist/src/services/prompts/taint.d.ts +0 -2
- package/dist/src/services/prompts/taint.js +0 -54
|
@@ -0,0 +1,63 @@
|
|
|
1
|
+
import { NetworkHandlersCore } from './handlers.base.core.js';
|
|
2
|
+
export declare class NetworkHandlersPerformance extends NetworkHandlersCore {
|
|
3
|
+
handlePerformanceGetMetrics(args: Record<string, unknown>): Promise<{
|
|
4
|
+
content: {
|
|
5
|
+
type: string;
|
|
6
|
+
text: string;
|
|
7
|
+
}[];
|
|
8
|
+
}>;
|
|
9
|
+
handlePerformanceStartCoverage(_args: Record<string, unknown>): Promise<{
|
|
10
|
+
content: {
|
|
11
|
+
type: string;
|
|
12
|
+
text: string;
|
|
13
|
+
}[];
|
|
14
|
+
}>;
|
|
15
|
+
handlePerformanceStopCoverage(_args: Record<string, unknown>): Promise<{
|
|
16
|
+
content: {
|
|
17
|
+
type: string;
|
|
18
|
+
text: string;
|
|
19
|
+
}[];
|
|
20
|
+
}>;
|
|
21
|
+
handlePerformanceTakeHeapSnapshot(_args: Record<string, unknown>): Promise<{
|
|
22
|
+
content: {
|
|
23
|
+
type: string;
|
|
24
|
+
text: string;
|
|
25
|
+
}[];
|
|
26
|
+
}>;
|
|
27
|
+
handlePerformanceTraceStart(args: Record<string, unknown>): Promise<{
|
|
28
|
+
content: {
|
|
29
|
+
type: string;
|
|
30
|
+
text: string;
|
|
31
|
+
}[];
|
|
32
|
+
}>;
|
|
33
|
+
handlePerformanceTraceStop(args: Record<string, unknown>): Promise<{
|
|
34
|
+
content: {
|
|
35
|
+
type: string;
|
|
36
|
+
text: string;
|
|
37
|
+
}[];
|
|
38
|
+
}>;
|
|
39
|
+
handleProfilerCpuStart(_args: Record<string, unknown>): Promise<{
|
|
40
|
+
content: {
|
|
41
|
+
type: string;
|
|
42
|
+
text: string;
|
|
43
|
+
}[];
|
|
44
|
+
}>;
|
|
45
|
+
handleProfilerCpuStop(args: Record<string, unknown>): Promise<{
|
|
46
|
+
content: {
|
|
47
|
+
type: string;
|
|
48
|
+
text: string;
|
|
49
|
+
}[];
|
|
50
|
+
}>;
|
|
51
|
+
handleProfilerHeapSamplingStart(args: Record<string, unknown>): Promise<{
|
|
52
|
+
content: {
|
|
53
|
+
type: string;
|
|
54
|
+
text: string;
|
|
55
|
+
}[];
|
|
56
|
+
}>;
|
|
57
|
+
handleProfilerHeapSamplingStop(args: Record<string, unknown>): Promise<{
|
|
58
|
+
content: {
|
|
59
|
+
type: string;
|
|
60
|
+
text: string;
|
|
61
|
+
}[];
|
|
62
|
+
}>;
|
|
63
|
+
}
|
|
@@ -0,0 +1,193 @@
|
|
|
1
|
+
import { NetworkHandlersCore } from './handlers.base.core.js';
|
|
2
|
+
import { asOptionalBoolean, asOptionalNumber, asOptionalString, asOptionalStringArray, toCpuProfilePayload, } from './handlers.base.types.js';
|
|
3
|
+
export class NetworkHandlersPerformance extends NetworkHandlersCore {
|
|
4
|
+
async handlePerformanceGetMetrics(args) {
|
|
5
|
+
const includeTimeline = args.includeTimeline === true;
|
|
6
|
+
const monitor = this.getPerformanceMonitor();
|
|
7
|
+
const metrics = await monitor.getPerformanceMetrics();
|
|
8
|
+
const result = { success: true, metrics };
|
|
9
|
+
if (includeTimeline) {
|
|
10
|
+
result.timeline = await monitor.getPerformanceTimeline();
|
|
11
|
+
}
|
|
12
|
+
return { content: [{ type: 'text', text: JSON.stringify(result, null, 2) }] };
|
|
13
|
+
}
|
|
14
|
+
async handlePerformanceStartCoverage(_args) {
|
|
15
|
+
const monitor = this.getPerformanceMonitor();
|
|
16
|
+
await monitor.startCoverage();
|
|
17
|
+
return {
|
|
18
|
+
content: [
|
|
19
|
+
{
|
|
20
|
+
type: 'text',
|
|
21
|
+
text: JSON.stringify({ success: true, message: 'Code coverage collection started' }, null, 2),
|
|
22
|
+
},
|
|
23
|
+
],
|
|
24
|
+
};
|
|
25
|
+
}
|
|
26
|
+
async handlePerformanceStopCoverage(_args) {
|
|
27
|
+
const monitor = this.getPerformanceMonitor();
|
|
28
|
+
const coverage = await monitor.stopCoverage();
|
|
29
|
+
const avgCoverage = coverage.length > 0
|
|
30
|
+
? coverage.reduce((sum, info) => sum + info.coveragePercentage, 0) / coverage.length
|
|
31
|
+
: 0;
|
|
32
|
+
return {
|
|
33
|
+
content: [
|
|
34
|
+
{
|
|
35
|
+
type: 'text',
|
|
36
|
+
text: JSON.stringify({ success: true, coverage, totalScripts: coverage.length, avgCoverage }, null, 2),
|
|
37
|
+
},
|
|
38
|
+
],
|
|
39
|
+
};
|
|
40
|
+
}
|
|
41
|
+
async handlePerformanceTakeHeapSnapshot(_args) {
|
|
42
|
+
const monitor = this.getPerformanceMonitor();
|
|
43
|
+
const snapshot = await monitor.takeHeapSnapshot();
|
|
44
|
+
return {
|
|
45
|
+
content: [
|
|
46
|
+
{
|
|
47
|
+
type: 'text',
|
|
48
|
+
text: JSON.stringify({
|
|
49
|
+
success: true,
|
|
50
|
+
snapshotSize: snapshot.length,
|
|
51
|
+
message: 'Heap snapshot taken (data too large to return, saved internally)',
|
|
52
|
+
}, null, 2),
|
|
53
|
+
},
|
|
54
|
+
],
|
|
55
|
+
};
|
|
56
|
+
}
|
|
57
|
+
async handlePerformanceTraceStart(args) {
|
|
58
|
+
const monitor = this.getPerformanceMonitor();
|
|
59
|
+
const categories = asOptionalStringArray(args.categories);
|
|
60
|
+
const screenshots = asOptionalBoolean(args.screenshots);
|
|
61
|
+
await monitor.startTracing({ categories, screenshots });
|
|
62
|
+
return {
|
|
63
|
+
content: [
|
|
64
|
+
{
|
|
65
|
+
type: 'text',
|
|
66
|
+
text: JSON.stringify({
|
|
67
|
+
success: true,
|
|
68
|
+
message: 'Performance tracing started. Call performance_trace_stop to save the trace.',
|
|
69
|
+
}),
|
|
70
|
+
},
|
|
71
|
+
],
|
|
72
|
+
};
|
|
73
|
+
}
|
|
74
|
+
async handlePerformanceTraceStop(args) {
|
|
75
|
+
const monitor = this.getPerformanceMonitor();
|
|
76
|
+
const artifactPath = asOptionalString(args.artifactPath);
|
|
77
|
+
const result = await monitor.stopTracing({ artifactPath });
|
|
78
|
+
return {
|
|
79
|
+
content: [
|
|
80
|
+
{
|
|
81
|
+
type: 'text',
|
|
82
|
+
text: JSON.stringify({
|
|
83
|
+
success: true,
|
|
84
|
+
artifactPath: result.artifactPath,
|
|
85
|
+
eventCount: result.eventCount,
|
|
86
|
+
sizeBytes: result.sizeBytes,
|
|
87
|
+
sizeKB: (result.sizeBytes / 1024).toFixed(1),
|
|
88
|
+
hint: 'Open the trace file in Chrome DevTools → Performance tab → Load profile',
|
|
89
|
+
}, null, 2),
|
|
90
|
+
},
|
|
91
|
+
],
|
|
92
|
+
};
|
|
93
|
+
}
|
|
94
|
+
async handleProfilerCpuStart(_args) {
|
|
95
|
+
const monitor = this.getPerformanceMonitor();
|
|
96
|
+
await monitor.startCPUProfiling();
|
|
97
|
+
return {
|
|
98
|
+
content: [
|
|
99
|
+
{
|
|
100
|
+
type: 'text',
|
|
101
|
+
text: JSON.stringify({
|
|
102
|
+
success: true,
|
|
103
|
+
message: 'CPU profiling started. Call profiler_cpu_stop to save the profile.',
|
|
104
|
+
}),
|
|
105
|
+
},
|
|
106
|
+
],
|
|
107
|
+
};
|
|
108
|
+
}
|
|
109
|
+
async handleProfilerCpuStop(args) {
|
|
110
|
+
const monitor = this.getPerformanceMonitor();
|
|
111
|
+
const profileRaw = await monitor.stopCPUProfiling();
|
|
112
|
+
const profile = toCpuProfilePayload(profileRaw) || profileRaw;
|
|
113
|
+
const { writeFile } = await import('node:fs/promises');
|
|
114
|
+
const { resolveArtifactPath } = await import('../../../utils/artifacts.js');
|
|
115
|
+
const artifactPath = asOptionalString(args.artifactPath);
|
|
116
|
+
const profileJson = JSON.stringify(profile, null, 2);
|
|
117
|
+
let savedPath;
|
|
118
|
+
if (artifactPath) {
|
|
119
|
+
await writeFile(artifactPath, profileJson, 'utf-8');
|
|
120
|
+
savedPath = artifactPath;
|
|
121
|
+
}
|
|
122
|
+
else {
|
|
123
|
+
const { absolutePath, displayPath } = await resolveArtifactPath({
|
|
124
|
+
category: 'profiles',
|
|
125
|
+
toolName: 'cpu-profile',
|
|
126
|
+
ext: 'cpuprofile',
|
|
127
|
+
});
|
|
128
|
+
await writeFile(absolutePath, profileJson, 'utf-8');
|
|
129
|
+
savedPath = displayPath;
|
|
130
|
+
}
|
|
131
|
+
const hotFunctions = profile.nodes
|
|
132
|
+
.filter((n) => (n.hitCount || 0) > 0)
|
|
133
|
+
.toSorted((a, b) => (b.hitCount || 0) - (a.hitCount || 0))
|
|
134
|
+
.slice(0, 20)
|
|
135
|
+
.map((n) => ({
|
|
136
|
+
functionName: n.callFrame?.functionName || '(anonymous)',
|
|
137
|
+
url: n.callFrame?.url,
|
|
138
|
+
line: n.callFrame?.lineNumber,
|
|
139
|
+
hitCount: n.hitCount,
|
|
140
|
+
}));
|
|
141
|
+
return {
|
|
142
|
+
content: [
|
|
143
|
+
{
|
|
144
|
+
type: 'text',
|
|
145
|
+
text: JSON.stringify({
|
|
146
|
+
success: true,
|
|
147
|
+
artifactPath: savedPath,
|
|
148
|
+
totalNodes: profile.nodes.length,
|
|
149
|
+
totalSamples: profile.samples?.length || 0,
|
|
150
|
+
durationMs: profile.endTime - profile.startTime,
|
|
151
|
+
hotFunctions,
|
|
152
|
+
hint: 'Open the .cpuprofile file in Chrome DevTools → Performance tab',
|
|
153
|
+
}, null, 2),
|
|
154
|
+
},
|
|
155
|
+
],
|
|
156
|
+
};
|
|
157
|
+
}
|
|
158
|
+
async handleProfilerHeapSamplingStart(args) {
|
|
159
|
+
const monitor = this.getPerformanceMonitor();
|
|
160
|
+
const samplingInterval = asOptionalNumber(args.samplingInterval);
|
|
161
|
+
await monitor.startHeapSampling({ samplingInterval });
|
|
162
|
+
return {
|
|
163
|
+
content: [
|
|
164
|
+
{
|
|
165
|
+
type: 'text',
|
|
166
|
+
text: JSON.stringify({
|
|
167
|
+
success: true,
|
|
168
|
+
message: 'Heap sampling started. Call profiler_heap_sampling_stop to save the report.',
|
|
169
|
+
}),
|
|
170
|
+
},
|
|
171
|
+
],
|
|
172
|
+
};
|
|
173
|
+
}
|
|
174
|
+
async handleProfilerHeapSamplingStop(args) {
|
|
175
|
+
const monitor = this.getPerformanceMonitor();
|
|
176
|
+
const artifactPath = asOptionalString(args.artifactPath);
|
|
177
|
+
const topN = asOptionalNumber(args.topN);
|
|
178
|
+
const result = await monitor.stopHeapSampling({ artifactPath, topN });
|
|
179
|
+
return {
|
|
180
|
+
content: [
|
|
181
|
+
{
|
|
182
|
+
type: 'text',
|
|
183
|
+
text: JSON.stringify({
|
|
184
|
+
success: true,
|
|
185
|
+
artifactPath: result.artifactPath,
|
|
186
|
+
sampleCount: result.sampleCount,
|
|
187
|
+
topAllocations: result.topAllocations,
|
|
188
|
+
}, null, 2),
|
|
189
|
+
},
|
|
190
|
+
],
|
|
191
|
+
};
|
|
192
|
+
}
|
|
193
|
+
}
|
|
@@ -0,0 +1,42 @@
|
|
|
1
|
+
import { DetailedDataManager } from '../../../utils/DetailedDataManager.js';
|
|
2
|
+
export declare const EXCLUDED_RESOURCE_TYPES: Set<string>;
|
|
3
|
+
export declare const TYPE_SORT_PRIORITY: Record<string, number>;
|
|
4
|
+
export declare const DEFAULT_SORT_PRIORITY = 6;
|
|
5
|
+
export interface NetworkRequestPayload {
|
|
6
|
+
requestId?: string;
|
|
7
|
+
url: string;
|
|
8
|
+
method: string;
|
|
9
|
+
type?: string;
|
|
10
|
+
timestamp?: number;
|
|
11
|
+
[key: string]: unknown;
|
|
12
|
+
}
|
|
13
|
+
export interface NetworkResponsePayload {
|
|
14
|
+
status: number;
|
|
15
|
+
[key: string]: unknown;
|
|
16
|
+
}
|
|
17
|
+
export interface CpuProfileCallFramePayload {
|
|
18
|
+
functionName?: string;
|
|
19
|
+
url?: string;
|
|
20
|
+
lineNumber?: number;
|
|
21
|
+
}
|
|
22
|
+
export interface CpuProfileNodePayload {
|
|
23
|
+
hitCount?: number;
|
|
24
|
+
callFrame?: CpuProfileCallFramePayload;
|
|
25
|
+
}
|
|
26
|
+
export interface CpuProfilePayload {
|
|
27
|
+
nodes: CpuProfileNodePayload[];
|
|
28
|
+
samples?: unknown[];
|
|
29
|
+
startTime: number;
|
|
30
|
+
endTime: number;
|
|
31
|
+
}
|
|
32
|
+
export declare const isObjectRecord: (value: unknown) => value is Record<string, unknown>;
|
|
33
|
+
export declare const isNetworkRequestPayload: (value: unknown) => value is NetworkRequestPayload;
|
|
34
|
+
export declare const isNetworkResponsePayload: (value: unknown) => value is NetworkResponsePayload;
|
|
35
|
+
export declare const isFiniteNumber: (value: unknown) => value is number;
|
|
36
|
+
export declare const asOptionalString: (value: unknown) => string | undefined;
|
|
37
|
+
export declare const asOptionalBoolean: (value: unknown) => boolean | undefined;
|
|
38
|
+
export declare const asOptionalNumber: (value: unknown) => number | undefined;
|
|
39
|
+
export declare const asOptionalStringArray: (value: unknown) => string[] | undefined;
|
|
40
|
+
export declare const isCpuProfileNodePayload: (value: unknown) => value is CpuProfileNodePayload;
|
|
41
|
+
export declare const toCpuProfilePayload: (value: unknown) => CpuProfilePayload | null;
|
|
42
|
+
export declare function getDetailedDataManager(): DetailedDataManager;
|
|
@@ -0,0 +1,89 @@
|
|
|
1
|
+
import { DetailedDataManager } from '../../../utils/DetailedDataManager.js';
|
|
2
|
+
export const EXCLUDED_RESOURCE_TYPES = new Set([
|
|
3
|
+
'Image',
|
|
4
|
+
'Font',
|
|
5
|
+
'Stylesheet',
|
|
6
|
+
'Media',
|
|
7
|
+
'Manifest',
|
|
8
|
+
'Ping',
|
|
9
|
+
]);
|
|
10
|
+
export const TYPE_SORT_PRIORITY = {
|
|
11
|
+
XHR: 0,
|
|
12
|
+
Fetch: 1,
|
|
13
|
+
Document: 2,
|
|
14
|
+
Script: 3,
|
|
15
|
+
WebSocket: 4,
|
|
16
|
+
EventSource: 5,
|
|
17
|
+
};
|
|
18
|
+
export const DEFAULT_SORT_PRIORITY = 6;
|
|
19
|
+
export const isObjectRecord = (value) => typeof value === 'object' && value !== null;
|
|
20
|
+
export const isNetworkRequestPayload = (value) => {
|
|
21
|
+
if (!isObjectRecord(value)) {
|
|
22
|
+
return false;
|
|
23
|
+
}
|
|
24
|
+
return typeof value.url === 'string' && typeof value.method === 'string';
|
|
25
|
+
};
|
|
26
|
+
export const isNetworkResponsePayload = (value) => {
|
|
27
|
+
if (!isObjectRecord(value)) {
|
|
28
|
+
return false;
|
|
29
|
+
}
|
|
30
|
+
return typeof value.status === 'number';
|
|
31
|
+
};
|
|
32
|
+
export const isFiniteNumber = (value) => typeof value === 'number' && Number.isFinite(value);
|
|
33
|
+
export const asOptionalString = (value) => typeof value === 'string' ? value : undefined;
|
|
34
|
+
export const asOptionalBoolean = (value) => typeof value === 'boolean' ? value : undefined;
|
|
35
|
+
export const asOptionalNumber = (value) => typeof value === 'number' && Number.isFinite(value) ? value : undefined;
|
|
36
|
+
export const asOptionalStringArray = (value) => {
|
|
37
|
+
if (!Array.isArray(value)) {
|
|
38
|
+
return undefined;
|
|
39
|
+
}
|
|
40
|
+
return value.every((item) => typeof item === 'string') ? value : undefined;
|
|
41
|
+
};
|
|
42
|
+
export const isCpuProfileNodePayload = (value) => {
|
|
43
|
+
if (!isObjectRecord(value)) {
|
|
44
|
+
return false;
|
|
45
|
+
}
|
|
46
|
+
if (value.hitCount !== undefined && typeof value.hitCount !== 'number') {
|
|
47
|
+
return false;
|
|
48
|
+
}
|
|
49
|
+
if (value.callFrame !== undefined && !isObjectRecord(value.callFrame)) {
|
|
50
|
+
return false;
|
|
51
|
+
}
|
|
52
|
+
if (isObjectRecord(value.callFrame)) {
|
|
53
|
+
if (value.callFrame.functionName !== undefined &&
|
|
54
|
+
typeof value.callFrame.functionName !== 'string') {
|
|
55
|
+
return false;
|
|
56
|
+
}
|
|
57
|
+
if (value.callFrame.url !== undefined && typeof value.callFrame.url !== 'string') {
|
|
58
|
+
return false;
|
|
59
|
+
}
|
|
60
|
+
if (value.callFrame.lineNumber !== undefined &&
|
|
61
|
+
typeof value.callFrame.lineNumber !== 'number') {
|
|
62
|
+
return false;
|
|
63
|
+
}
|
|
64
|
+
}
|
|
65
|
+
return true;
|
|
66
|
+
};
|
|
67
|
+
export const toCpuProfilePayload = (value) => {
|
|
68
|
+
if (!isObjectRecord(value)) {
|
|
69
|
+
return null;
|
|
70
|
+
}
|
|
71
|
+
if (!Array.isArray(value.nodes)) {
|
|
72
|
+
return null;
|
|
73
|
+
}
|
|
74
|
+
if (typeof value.startTime !== 'number' || typeof value.endTime !== 'number') {
|
|
75
|
+
return null;
|
|
76
|
+
}
|
|
77
|
+
if (!value.nodes.every((node) => isCpuProfileNodePayload(node))) {
|
|
78
|
+
return null;
|
|
79
|
+
}
|
|
80
|
+
return {
|
|
81
|
+
nodes: value.nodes,
|
|
82
|
+
samples: Array.isArray(value.samples) ? value.samples : undefined,
|
|
83
|
+
startTime: value.startTime,
|
|
84
|
+
endTime: value.endTime,
|
|
85
|
+
};
|
|
86
|
+
};
|
|
87
|
+
export function getDetailedDataManager() {
|
|
88
|
+
return DetailedDataManager.getInstance();
|
|
89
|
+
}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
export {
|
|
1
|
+
export { AdvancedToolHandlersIntercept as AdvancedToolHandlers } from '../../domains/network/handlers.impl.core.runtime.intercept.js';
|
|
@@ -0,0 +1,21 @@
|
|
|
1
|
+
import { AdvancedToolHandlersRuntime as AdvancedToolHandlersReplay } from '../../domains/network/handlers.impl.core.runtime.replay.js';
|
|
2
|
+
export declare class AdvancedToolHandlersIntercept extends AdvancedToolHandlersReplay {
|
|
3
|
+
handleNetworkInterceptResponse(args: Record<string, unknown>): Promise<{
|
|
4
|
+
content: {
|
|
5
|
+
type: string;
|
|
6
|
+
text: string;
|
|
7
|
+
}[];
|
|
8
|
+
}>;
|
|
9
|
+
handleNetworkInterceptList(_args: Record<string, unknown>): Promise<{
|
|
10
|
+
content: {
|
|
11
|
+
type: string;
|
|
12
|
+
text: string;
|
|
13
|
+
}[];
|
|
14
|
+
}>;
|
|
15
|
+
handleNetworkInterceptDisable(args: Record<string, unknown>): Promise<{
|
|
16
|
+
content: {
|
|
17
|
+
type: string;
|
|
18
|
+
text: string;
|
|
19
|
+
}[];
|
|
20
|
+
}>;
|
|
21
|
+
}
|
|
@@ -0,0 +1,186 @@
|
|
|
1
|
+
import { AdvancedToolHandlersRuntime as AdvancedToolHandlersReplay } from '../../domains/network/handlers.impl.core.runtime.replay.js';
|
|
2
|
+
const isObjectRecord = (value) => typeof value === 'object' && value !== null;
|
|
3
|
+
export class AdvancedToolHandlersIntercept extends AdvancedToolHandlersReplay {
|
|
4
|
+
async handleNetworkInterceptResponse(args) {
|
|
5
|
+
try {
|
|
6
|
+
const rules = [];
|
|
7
|
+
if (Array.isArray(args.rules)) {
|
|
8
|
+
for (const rawRule of args.rules) {
|
|
9
|
+
if (isObjectRecord(rawRule) && typeof rawRule.urlPattern === 'string') {
|
|
10
|
+
rules.push({
|
|
11
|
+
urlPattern: rawRule.urlPattern,
|
|
12
|
+
urlPatternType: rawRule.urlPatternType === 'regex' ? 'regex' : 'glob',
|
|
13
|
+
stage: rawRule.stage === 'Request' ? 'Request' : 'Response',
|
|
14
|
+
responseCode: typeof rawRule.responseCode === 'number' ? rawRule.responseCode : 200,
|
|
15
|
+
responseHeaders: isObjectRecord(rawRule.responseHeaders)
|
|
16
|
+
? rawRule.responseHeaders
|
|
17
|
+
: undefined,
|
|
18
|
+
responseBody: typeof rawRule.responseBody === 'string'
|
|
19
|
+
? rawRule.responseBody
|
|
20
|
+
: typeof rawRule.responseBody === 'object'
|
|
21
|
+
? JSON.stringify(rawRule.responseBody)
|
|
22
|
+
: undefined,
|
|
23
|
+
});
|
|
24
|
+
}
|
|
25
|
+
}
|
|
26
|
+
}
|
|
27
|
+
else if (typeof args.urlPattern === 'string') {
|
|
28
|
+
rules.push({
|
|
29
|
+
urlPattern: args.urlPattern,
|
|
30
|
+
urlPatternType: args.urlPatternType === 'regex' ? 'regex' : 'glob',
|
|
31
|
+
stage: args.stage === 'Request' ? 'Request' : 'Response',
|
|
32
|
+
responseCode: typeof args.responseCode === 'number' ? args.responseCode : 200,
|
|
33
|
+
responseHeaders: isObjectRecord(args.responseHeaders)
|
|
34
|
+
? args.responseHeaders
|
|
35
|
+
: undefined,
|
|
36
|
+
responseBody: typeof args.responseBody === 'string'
|
|
37
|
+
? args.responseBody
|
|
38
|
+
: typeof args.responseBody === 'object' && args.responseBody !== null
|
|
39
|
+
? JSON.stringify(args.responseBody)
|
|
40
|
+
: undefined,
|
|
41
|
+
});
|
|
42
|
+
}
|
|
43
|
+
if (rules.length === 0) {
|
|
44
|
+
return {
|
|
45
|
+
content: [
|
|
46
|
+
{
|
|
47
|
+
type: 'text',
|
|
48
|
+
text: JSON.stringify({
|
|
49
|
+
success: false,
|
|
50
|
+
error: 'No valid rules provided. Provide either "urlPattern" (single) or "rules" array (batch).',
|
|
51
|
+
usage: {
|
|
52
|
+
single: {
|
|
53
|
+
urlPattern: '*api/status*',
|
|
54
|
+
responseCode: 200,
|
|
55
|
+
responseBody: '{"status":"active"}',
|
|
56
|
+
},
|
|
57
|
+
batch: {
|
|
58
|
+
rules: [
|
|
59
|
+
{
|
|
60
|
+
urlPattern: '*api/status*',
|
|
61
|
+
responseBody: '{"status":"active"}',
|
|
62
|
+
},
|
|
63
|
+
],
|
|
64
|
+
},
|
|
65
|
+
},
|
|
66
|
+
}, null, 2),
|
|
67
|
+
},
|
|
68
|
+
],
|
|
69
|
+
};
|
|
70
|
+
}
|
|
71
|
+
const createdRules = await this.consoleMonitor.enableFetchIntercept(rules);
|
|
72
|
+
const status = this.consoleMonitor.getFetchInterceptStatus();
|
|
73
|
+
return {
|
|
74
|
+
content: [
|
|
75
|
+
{
|
|
76
|
+
type: 'text',
|
|
77
|
+
text: JSON.stringify({
|
|
78
|
+
success: true,
|
|
79
|
+
message: `Added ${createdRules.length} interception rule(s)`,
|
|
80
|
+
createdRules: createdRules.map((r) => ({
|
|
81
|
+
id: r.id,
|
|
82
|
+
urlPattern: r.urlPattern,
|
|
83
|
+
stage: r.stage,
|
|
84
|
+
responseCode: r.responseCode,
|
|
85
|
+
})),
|
|
86
|
+
totalActiveRules: status.rules.length,
|
|
87
|
+
hint: 'Use network_intercept_list to see all rules and hit counts. Use network_intercept_disable to remove rules.',
|
|
88
|
+
}, null, 2),
|
|
89
|
+
},
|
|
90
|
+
],
|
|
91
|
+
};
|
|
92
|
+
}
|
|
93
|
+
catch (error) {
|
|
94
|
+
return {
|
|
95
|
+
content: [
|
|
96
|
+
{
|
|
97
|
+
type: 'text',
|
|
98
|
+
text: JSON.stringify({
|
|
99
|
+
success: false,
|
|
100
|
+
error: error instanceof Error ? error.message : String(error),
|
|
101
|
+
hint: 'Ensure browser is launched and a page is active before enabling interception.',
|
|
102
|
+
}, null, 2),
|
|
103
|
+
},
|
|
104
|
+
],
|
|
105
|
+
};
|
|
106
|
+
}
|
|
107
|
+
}
|
|
108
|
+
async handleNetworkInterceptList(_args) {
|
|
109
|
+
const status = this.consoleMonitor.getFetchInterceptStatus();
|
|
110
|
+
return {
|
|
111
|
+
content: [
|
|
112
|
+
{
|
|
113
|
+
type: 'text',
|
|
114
|
+
text: JSON.stringify({
|
|
115
|
+
success: true,
|
|
116
|
+
...status,
|
|
117
|
+
hint: status.rules.length > 0
|
|
118
|
+
? 'Use network_intercept_disable(ruleId) to remove a specific rule, or network_intercept_disable(all=true) to remove all.'
|
|
119
|
+
: 'No active interception rules. Use network_intercept_response to add rules.',
|
|
120
|
+
}, null, 2),
|
|
121
|
+
},
|
|
122
|
+
],
|
|
123
|
+
};
|
|
124
|
+
}
|
|
125
|
+
async handleNetworkInterceptDisable(args) {
|
|
126
|
+
const ruleId = typeof args.ruleId === 'string' ? args.ruleId : undefined;
|
|
127
|
+
const all = args.all === true;
|
|
128
|
+
if (!ruleId && !all) {
|
|
129
|
+
return {
|
|
130
|
+
content: [
|
|
131
|
+
{
|
|
132
|
+
type: 'text',
|
|
133
|
+
text: JSON.stringify({
|
|
134
|
+
success: false,
|
|
135
|
+
error: 'Provide either "ruleId" to remove a specific rule, or "all": true to disable all.',
|
|
136
|
+
}, null, 2),
|
|
137
|
+
},
|
|
138
|
+
],
|
|
139
|
+
};
|
|
140
|
+
}
|
|
141
|
+
try {
|
|
142
|
+
if (all) {
|
|
143
|
+
const result = await this.consoleMonitor.disableFetchIntercept();
|
|
144
|
+
return {
|
|
145
|
+
content: [
|
|
146
|
+
{
|
|
147
|
+
type: 'text',
|
|
148
|
+
text: JSON.stringify({
|
|
149
|
+
success: true,
|
|
150
|
+
message: `Disabled all interception. Removed ${result.removedRules} rule(s).`,
|
|
151
|
+
removedRules: result.removedRules,
|
|
152
|
+
}, null, 2),
|
|
153
|
+
},
|
|
154
|
+
],
|
|
155
|
+
};
|
|
156
|
+
}
|
|
157
|
+
const removed = await this.consoleMonitor.removeFetchInterceptRule(ruleId);
|
|
158
|
+
const status = this.consoleMonitor.getFetchInterceptStatus();
|
|
159
|
+
return {
|
|
160
|
+
content: [
|
|
161
|
+
{
|
|
162
|
+
type: 'text',
|
|
163
|
+
text: JSON.stringify({
|
|
164
|
+
success: removed,
|
|
165
|
+
message: removed ? `Rule ${ruleId} removed.` : `Rule ${ruleId} not found.`,
|
|
166
|
+
remainingRules: status.rules.length,
|
|
167
|
+
}, null, 2),
|
|
168
|
+
},
|
|
169
|
+
],
|
|
170
|
+
};
|
|
171
|
+
}
|
|
172
|
+
catch (error) {
|
|
173
|
+
return {
|
|
174
|
+
content: [
|
|
175
|
+
{
|
|
176
|
+
type: 'text',
|
|
177
|
+
text: JSON.stringify({
|
|
178
|
+
success: false,
|
|
179
|
+
error: error instanceof Error ? error.message : String(error),
|
|
180
|
+
}, null, 2),
|
|
181
|
+
},
|
|
182
|
+
],
|
|
183
|
+
};
|
|
184
|
+
}
|
|
185
|
+
}
|
|
186
|
+
}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
export {
|
|
1
|
+
export { AdvancedToolHandlersIntercept as AdvancedToolHandlers } from '../../domains/network/handlers.impl.core.runtime.intercept.js';
|
|
@@ -156,6 +156,21 @@ const manifest = {
|
|
|
156
156
|
domain: DOMAIN,
|
|
157
157
|
bind: b((h, a) => h.handleNetworkReplayRequest(a)),
|
|
158
158
|
},
|
|
159
|
+
{
|
|
160
|
+
tool: t('network_intercept_response'),
|
|
161
|
+
domain: DOMAIN,
|
|
162
|
+
bind: b((h, a) => h.handleNetworkInterceptResponse(a)),
|
|
163
|
+
},
|
|
164
|
+
{
|
|
165
|
+
tool: t('network_intercept_list'),
|
|
166
|
+
domain: DOMAIN,
|
|
167
|
+
bind: b((h, a) => h.handleNetworkInterceptList(a)),
|
|
168
|
+
},
|
|
169
|
+
{
|
|
170
|
+
tool: t('network_intercept_disable'),
|
|
171
|
+
domain: DOMAIN,
|
|
172
|
+
bind: b((h, a) => h.handleNetworkInterceptDisable(a)),
|
|
173
|
+
},
|
|
159
174
|
],
|
|
160
175
|
};
|
|
161
176
|
export default manifest;
|
|
@@ -126,14 +126,11 @@ export async function replayRequest(base, args, maxBodyBytes = 512_000) {
|
|
|
126
126
|
let currentBody = body;
|
|
127
127
|
let resp;
|
|
128
128
|
for (let hop = 0; hop < MAX_REDIRECTS; hop++) {
|
|
129
|
-
const { pinnedUrl
|
|
129
|
+
const { pinnedUrl } = await resolvePinned(currentUrl);
|
|
130
130
|
if (!pinnedUrl.startsWith('https://') && !LOOPBACK_HTTP_URL_RE.test(pinnedUrl)) {
|
|
131
131
|
throw new Error(`Replay blocked: insecure HTTP is only allowed for loopback targets, got "${currentUrl}"`);
|
|
132
132
|
}
|
|
133
133
|
const hopHeaders = { ...mergedHeaders };
|
|
134
|
-
if (pinnedUrl !== currentUrl && !hopHeaders['host'] && !hopHeaders['Host']) {
|
|
135
|
-
hopHeaders['Host'] = originalHost;
|
|
136
|
-
}
|
|
137
134
|
resp = await fetch(pinnedUrl, {
|
|
138
135
|
method: currentMethod,
|
|
139
136
|
headers: hopHeaders,
|