@aria-cli/tools 1.0.19 → 1.0.31
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/dist/.aria-build-stamp.json +1 -1
- package/dist/ask-user-interaction.js +23 -0
- package/dist/cache/web-cache.js +67 -0
- package/dist/definitions/arion.js +105 -0
- package/dist/definitions/browser/browser.js +419 -0
- package/dist/definitions/browser/index.js +5 -0
- package/dist/definitions/browser/pw-downloads.js +115 -0
- package/dist/definitions/browser/pw-interactions.js +200 -0
- package/dist/definitions/browser/pw-responses.js +77 -0
- package/dist/definitions/browser/pw-session.js +311 -0
- package/dist/definitions/browser/pw-shared.js +67 -0
- package/dist/definitions/browser/pw-snapshot.js +302 -0
- package/dist/definitions/browser/pw-state.js +63 -0
- package/dist/definitions/browser/types.js +5 -0
- package/dist/definitions/code-intelligence.js +471 -0
- package/dist/definitions/core.js +110 -0
- package/dist/definitions/delegation.js +513 -0
- package/dist/definitions/deploy.js +66 -0
- package/dist/definitions/filesystem.js +197 -0
- package/dist/definitions/frg.js +64 -0
- package/{dist-cjs/definitions/index.d.ts → dist/definitions/index.js} +2 -0
- package/dist/definitions/memory.js +124 -0
- package/dist/definitions/messaging.js +626 -0
- package/dist/definitions/meta.js +350 -0
- package/dist/definitions/network.js +160 -0
- package/dist/definitions/outlook.js +278 -0
- package/dist/definitions/patch/apply-patch.js +185 -0
- package/dist/definitions/patch/fuzzy-match.js +167 -0
- package/{dist-cjs/definitions/patch/index.d.ts → dist/definitions/patch/index.js} +1 -0
- package/dist/definitions/patch/patch-parser.js +208 -0
- package/dist/definitions/patch/sandbox-paths.js +106 -0
- package/dist/definitions/process/index.js +5 -0
- package/dist/definitions/process/process-registry.js +214 -0
- package/dist/definitions/process/process.js +387 -0
- package/dist/definitions/process/pty-keys.js +255 -0
- package/dist/definitions/process/session-slug.js +143 -0
- package/dist/definitions/quip.js +196 -0
- package/dist/definitions/search.js +61 -0
- package/dist/definitions/session-history.js +70 -0
- package/dist/definitions/shell.js +182 -0
- package/dist/definitions/slack.js +181 -0
- package/dist/definitions/web.js +110 -0
- package/dist/executors/apply-patch.js +902 -0
- package/dist/executors/arion.js +120 -0
- package/dist/executors/code-intelligence.js +883 -0
- package/dist/executors/deploy.js +849 -0
- package/dist/executors/filesystem.js +1119 -0
- package/dist/executors/frg-freshness.js +577 -0
- package/dist/executors/frg.js +299 -0
- package/{dist-cjs/executors/index.d.ts → dist/executors/index.js} +22 -19
- package/dist/executors/learning-meta.js +1147 -0
- package/dist/executors/lsp-client.js +297 -0
- package/dist/executors/memory.js +751 -0
- package/dist/executors/meta.js +221 -0
- package/dist/executors/process-registry.js +466 -0
- package/dist/executors/pty-session-store.js +31 -0
- package/dist/executors/pty.js +281 -0
- package/dist/executors/restart.js +120 -0
- package/dist/executors/search-freshness.js +196 -0
- package/dist/executors/search-types.js +53 -0
- package/dist/executors/search.js +67 -0
- package/dist/executors/self-diagnose.js +399 -0
- package/dist/executors/session-history.js +284 -0
- package/dist/executors/shell-safety.js +474 -0
- package/dist/executors/shell.js +955 -0
- package/dist/executors/utils.js +34 -0
- package/dist/executors/web.js +543 -0
- package/dist/extraction/content-extraction.js +248 -0
- package/dist/extraction/index.js +5 -0
- package/dist/headless-control-contract.js +968 -0
- package/dist/{index-v49pd2a0.js → index-45qvfjbf.js} +2 -2
- package/dist/index.js +71 -372
- package/dist/local-control-http-auth.js +3 -0
- package/dist/mcp/client.js +182 -0
- package/dist/mcp/connection.js +484 -0
- package/dist/mcp/index.js +11 -0
- package/dist/mcp/jsonrpc.js +145 -0
- package/dist/mcp/types.js +8 -0
- package/dist/network-control-adapter.js +73 -0
- package/dist/network-runtime/address-types.js +166 -0
- package/dist/network-runtime/db-owner-fencing.js +70 -0
- package/dist/network-runtime/delivery-receipts.js +270 -0
- package/dist/network-runtime/direct-endpoint-authority.js +26 -0
- package/dist/network-runtime/index.js +13 -1
- package/dist/network-runtime/local-control-contract.js +628 -0
- package/dist/network-runtime/node-store-contract.js +35 -0
- package/dist/network-runtime/pair-route-contract.js +78 -0
- package/dist/network-runtime/peer-capabilities.js +29 -0
- package/dist/network-runtime/peer-principal-ref.js +13 -0
- package/dist/network-runtime/peer-state-machine.js +122 -0
- package/dist/network-runtime/protocol-schemas.js +206 -0
- package/dist/network-runtime/runtime-bootstrap-contract.js +61 -0
- package/dist/outlook/desktop-session.js +280 -0
- package/dist/policy.js +150 -0
- package/dist/providers/brave.js +63 -0
- package/dist/providers/duckduckgo.js +177 -0
- package/dist/providers/exa.js +64 -0
- package/dist/providers/firecrawl.js +56 -0
- package/{dist-cjs/providers/index.d.ts → dist/providers/index.js} +1 -1
- package/dist/providers/jina.js +50 -0
- package/dist/providers/router.js +97 -0
- package/dist/providers/search-provider.js +33 -0
- package/dist/providers/tavily.js +55 -0
- package/dist/pty-w5c9dv33.js +1 -0
- package/dist/quip/desktop-session.js +318 -0
- package/{dist-cjs/registry/index.d.ts → dist/registry/index.js} +1 -0
- package/dist/registry/registry.js +757 -0
- package/dist/runtime-socket-local-control-client.js +331 -0
- package/dist/security/dns-normalization.js +20 -0
- package/dist/security/dns-pinning.js +124 -0
- package/dist/security/external-content.js +92 -0
- package/dist/security/ssrf.js +182 -0
- package/dist/slack/desktop-session.js +325 -0
- package/dist/tool-factory.js +48 -0
- package/dist/types.js +8 -0
- package/dist/utils/retry.js +133 -0
- package/dist/utils/safe-parse-json.js +161 -0
- package/dist/utils/url.js +20 -0
- package/dist-cjs/ask-user-interaction.js +28 -0
- package/dist-cjs/cache/web-cache.js +71 -0
- package/dist-cjs/definitions/arion.js +108 -0
- package/dist-cjs/definitions/browser/browser.js +422 -0
- package/dist-cjs/definitions/browser/index.js +9 -0
- package/dist-cjs/definitions/browser/pw-downloads.js +118 -0
- package/dist-cjs/definitions/browser/pw-interactions.js +214 -0
- package/dist-cjs/definitions/browser/pw-responses.js +85 -0
- package/dist-cjs/definitions/browser/pw-session.js +327 -0
- package/dist-cjs/definitions/browser/pw-shared.js +73 -0
- package/dist-cjs/definitions/browser/pw-snapshot.js +308 -0
- package/dist-cjs/definitions/browser/pw-state.js +71 -0
- package/dist-cjs/definitions/browser/types.js +6 -0
- package/dist-cjs/definitions/code-intelligence.js +474 -0
- package/dist-cjs/definitions/core.js +134 -0
- package/dist-cjs/definitions/delegation.js +516 -0
- package/dist-cjs/definitions/deploy.js +69 -0
- package/dist-cjs/definitions/filesystem.js +200 -0
- package/dist-cjs/definitions/frg.js +67 -0
- package/dist-cjs/definitions/index.js +44 -0
- package/dist-cjs/definitions/memory.js +127 -0
- package/dist-cjs/definitions/messaging.js +632 -0
- package/dist-cjs/definitions/meta.js +353 -0
- package/dist-cjs/definitions/network.js +163 -0
- package/dist-cjs/definitions/outlook.js +281 -0
- package/dist-cjs/definitions/patch/apply-patch.js +192 -0
- package/dist-cjs/definitions/patch/fuzzy-match.js +173 -0
- package/dist-cjs/definitions/patch/index.js +6 -0
- package/dist-cjs/definitions/patch/patch-parser.js +216 -0
- package/dist-cjs/definitions/patch/sandbox-paths.js +114 -0
- package/dist-cjs/definitions/process/index.js +9 -0
- package/dist-cjs/definitions/process/process-registry.js +232 -0
- package/dist-cjs/definitions/process/process.js +390 -0
- package/dist-cjs/definitions/process/pty-keys.js +260 -0
- package/dist-cjs/definitions/process/session-slug.js +146 -0
- package/dist-cjs/definitions/quip.js +199 -0
- package/dist-cjs/definitions/search.js +64 -0
- package/dist-cjs/definitions/session-history.js +73 -0
- package/dist-cjs/definitions/shell.js +185 -0
- package/dist-cjs/definitions/slack.js +184 -0
- package/dist-cjs/definitions/web.js +113 -0
- package/dist-cjs/executors/apply-patch.js +939 -0
- package/dist-cjs/executors/arion.js +126 -0
- package/dist-cjs/executors/code-intelligence.js +926 -0
- package/dist-cjs/executors/deploy.js +870 -0
- package/dist-cjs/executors/filesystem.js +1164 -0
- package/dist-cjs/executors/frg-freshness.js +628 -0
- package/dist-cjs/executors/frg.js +335 -0
- package/dist-cjs/executors/index.js +144 -0
- package/dist-cjs/executors/learning-meta.js +1166 -0
- package/dist-cjs/executors/memory.js +797 -0
- package/dist-cjs/executors/meta.js +227 -0
- package/dist-cjs/executors/process-registry.js +470 -0
- package/dist-cjs/executors/pty-session-store.js +35 -0
- package/dist-cjs/executors/pty.js +289 -0
- package/dist-cjs/executors/restart.js +156 -0
- package/dist-cjs/executors/search-freshness.js +235 -0
- package/dist-cjs/executors/search-types.js +57 -0
- package/dist-cjs/executors/search.js +103 -0
- package/dist-cjs/executors/self-diagnose.js +435 -0
- package/dist-cjs/executors/session-history.js +321 -0
- package/dist-cjs/executors/shell-safety.js +479 -0
- package/dist-cjs/executors/shell.js +1002 -0
- package/dist-cjs/executors/utils.js +74 -0
- package/dist-cjs/executors/web.js +548 -0
- package/dist-cjs/extraction/content-extraction.js +289 -0
- package/dist-cjs/extraction/index.js +9 -0
- package/dist-cjs/headless-control-contract.js +973 -0
- package/dist-cjs/index.js +436 -385
- package/dist-cjs/local-control-http-auth.js +6 -0
- package/dist-cjs/mcp/client.js +186 -0
- package/dist-cjs/mcp/connection.js +488 -0
- package/dist-cjs/mcp/index.js +31 -0
- package/dist-cjs/mcp/jsonrpc.js +149 -0
- package/dist-cjs/mcp/types.js +9 -0
- package/dist-cjs/network-control-adapter.js +78 -0
- package/dist-cjs/network-runtime/address-types.js +169 -0
- package/dist-cjs/network-runtime/db-owner-fencing.js +77 -0
- package/dist-cjs/network-runtime/delivery-receipts.js +279 -0
- package/dist-cjs/network-runtime/direct-endpoint-authority.js +30 -0
- package/dist-cjs/network-runtime/index.js +173 -8
- package/dist-cjs/network-runtime/local-control-contract.js +634 -0
- package/dist-cjs/network-runtime/node-store-contract.js +39 -0
- package/dist-cjs/network-runtime/pair-route-contract.js +81 -0
- package/dist-cjs/network-runtime/peer-capabilities.js +38 -0
- package/dist-cjs/network-runtime/peer-principal-ref.js +16 -0
- package/dist-cjs/network-runtime/peer-state-machine.js +130 -0
- package/dist-cjs/network-runtime/protocol-schemas.js +213 -0
- package/dist-cjs/network-runtime/runtime-bootstrap-contract.js +64 -0
- package/dist-cjs/outlook/desktop-session.js +319 -0
- package/dist-cjs/policy.js +156 -0
- package/dist-cjs/providers/brave.js +67 -0
- package/dist-cjs/providers/duckduckgo.js +181 -0
- package/dist-cjs/providers/exa.js +68 -0
- package/dist-cjs/providers/firecrawl.js +60 -0
- package/dist-cjs/providers/index.js +18 -0
- package/dist-cjs/providers/jina.js +54 -0
- package/dist-cjs/providers/router.js +101 -0
- package/dist-cjs/providers/search-provider.js +37 -0
- package/dist-cjs/providers/tavily.js +59 -0
- package/dist-cjs/quip/desktop-session.js +354 -0
- package/dist-cjs/registry/index.js +7 -0
- package/dist-cjs/registry/registry.js +762 -0
- package/dist-cjs/runtime-socket-local-control-client.js +368 -0
- package/dist-cjs/security/dns-normalization.js +23 -0
- package/dist-cjs/security/dns-pinning.js +161 -0
- package/dist-cjs/security/external-content.js +96 -0
- package/dist-cjs/security/ssrf.js +222 -0
- package/dist-cjs/slack/desktop-session.js +367 -0
- package/dist-cjs/tool-factory.js +51 -0
- package/dist-cjs/types.js +9 -0
- package/dist-cjs/utils/retry.js +170 -0
- package/dist-cjs/utils/safe-parse-json.js +165 -0
- package/dist-cjs/utils/url.js +24 -0
- package/package.json +11 -10
- package/dist/ask-user-interaction.d.ts +0 -10
- package/dist/cache/web-cache.d.ts +0 -52
- package/dist/definitions/arion.d.ts +0 -8
- package/dist/definitions/browser/browser.d.ts +0 -2
- package/dist/definitions/browser/index.d.ts +0 -1
- package/dist/definitions/browser/pw-downloads.d.ts +0 -13
- package/dist/definitions/browser/pw-interactions.d.ts +0 -78
- package/dist/definitions/browser/pw-responses.d.ts +0 -28
- package/dist/definitions/browser/pw-session.d.ts +0 -65
- package/dist/definitions/browser/pw-shared.d.ts +0 -22
- package/dist/definitions/browser/pw-snapshot.d.ts +0 -34
- package/dist/definitions/browser/pw-state.d.ts +0 -22
- package/dist/definitions/browser/types.d.ts +0 -277
- package/dist/definitions/code-intelligence.d.ts +0 -8
- package/dist/definitions/core.d.ts +0 -47
- package/dist/definitions/delegation.d.ts +0 -11
- package/dist/definitions/deploy.d.ts +0 -15
- package/dist/definitions/filesystem.d.ts +0 -9
- package/dist/definitions/frg.d.ts +0 -3
- package/dist/definitions/index.d.ts +0 -19
- package/dist/definitions/memory.d.ts +0 -8
- package/dist/definitions/messaging.d.ts +0 -11
- package/dist/definitions/meta.d.ts +0 -11
- package/dist/definitions/network.d.ts +0 -11
- package/dist/definitions/outlook.d.ts +0 -2
- package/dist/definitions/patch/apply-patch.d.ts +0 -11
- package/dist/definitions/patch/fuzzy-match.d.ts +0 -10
- package/dist/definitions/patch/index.d.ts +0 -1
- package/dist/definitions/patch/patch-parser.d.ts +0 -50
- package/dist/definitions/patch/sandbox-paths.d.ts +0 -18
- package/dist/definitions/process/index.d.ts +0 -1
- package/dist/definitions/process/process-registry.d.ts +0 -67
- package/dist/definitions/process/process.d.ts +0 -9
- package/dist/definitions/process/pty-keys.d.ts +0 -13
- package/dist/definitions/process/session-slug.d.ts +0 -1
- package/dist/definitions/quip.d.ts +0 -2
- package/dist/definitions/search.d.ts +0 -9
- package/dist/definitions/session-history.d.ts +0 -11
- package/dist/definitions/shell.d.ts +0 -8
- package/dist/definitions/slack.d.ts +0 -2
- package/dist/definitions/web.d.ts +0 -8
- package/dist/executors/apply-patch.d.ts +0 -51
- package/dist/executors/arion.d.ts +0 -50
- package/dist/executors/code-intelligence.d.ts +0 -138
- package/dist/executors/deploy.d.ts +0 -169
- package/dist/executors/filesystem.d.ts +0 -150
- package/dist/executors/frg-freshness.d.ts +0 -93
- package/dist/executors/frg.d.ts +0 -27
- package/dist/executors/index.d.ts +0 -44
- package/dist/executors/learning-meta.d.ts +0 -87
- package/dist/executors/lsp-client.d.ts +0 -38
- package/dist/executors/memory.d.ts +0 -203
- package/dist/executors/meta.d.ts +0 -73
- package/dist/executors/process-registry.d.ts +0 -98
- package/dist/executors/pty-session-store.d.ts +0 -14
- package/dist/executors/pty.d.ts +0 -133
- package/dist/executors/restart.d.ts +0 -13
- package/dist/executors/search-freshness.d.ts +0 -50
- package/dist/executors/search-types.d.ts +0 -52
- package/dist/executors/search.d.ts +0 -11
- package/dist/executors/self-diagnose.d.ts +0 -89
- package/dist/executors/session-history.d.ts +0 -75
- package/dist/executors/shell-safety.d.ts +0 -27
- package/dist/executors/shell.d.ts +0 -168
- package/dist/executors/utils.d.ts +0 -20
- package/dist/executors/web.d.ts +0 -89
- package/dist/extraction/content-extraction.d.ts +0 -48
- package/dist/extraction/index.d.ts +0 -4
- package/dist/headless-control-contract.d.ts +0 -3182
- package/dist/index.d.ts +0 -62
- package/dist/local-control-http-auth.d.ts +0 -2
- package/dist/mcp/client.d.ts +0 -68
- package/dist/mcp/connection.d.ts +0 -54
- package/dist/mcp/index.d.ts +0 -10
- package/dist/mcp/jsonrpc.d.ts +0 -36
- package/dist/mcp/types.d.ts +0 -178
- package/dist/network-control-adapter.d.ts +0 -4
- package/dist/network-runtime/address-types.d.ts +0 -201
- package/dist/network-runtime/db-owner-fencing.d.ts +0 -43
- package/dist/network-runtime/delivery-receipts.d.ts +0 -117
- package/dist/network-runtime/direct-endpoint-authority.d.ts +0 -8
- package/dist/network-runtime/index.d.ts +0 -24
- package/dist/network-runtime/local-control-contract.d.ts +0 -758
- package/dist/network-runtime/node-store-contract.d.ts +0 -49
- package/dist/network-runtime/pair-route-contract.d.ts +0 -100
- package/dist/network-runtime/peer-capabilities.d.ts +0 -10
- package/dist/network-runtime/peer-principal-ref.d.ts +0 -9
- package/dist/network-runtime/peer-state-machine.d.ts +0 -70
- package/dist/network-runtime/protocol-schemas.d.ts +0 -328
- package/dist/network-runtime/runtime-bootstrap-contract.d.ts +0 -81
- package/dist/outlook/desktop-session.d.ts +0 -68
- package/dist/policy.d.ts +0 -43
- package/dist/providers/brave.d.ts +0 -10
- package/dist/providers/duckduckgo.d.ts +0 -18
- package/dist/providers/exa.d.ts +0 -10
- package/dist/providers/firecrawl.d.ts +0 -10
- package/dist/providers/index.d.ts +0 -8
- package/dist/providers/jina.d.ts +0 -10
- package/dist/providers/router.d.ts +0 -21
- package/dist/providers/search-provider.d.ts +0 -35
- package/dist/providers/tavily.d.ts +0 -10
- package/dist/pty-cf6pmvx6.js +0 -1
- package/dist/quip/desktop-session.d.ts +0 -69
- package/dist/registry/index.d.ts +0 -1
- package/dist/registry/registry.d.ts +0 -156
- package/dist/runtime-socket-local-control-client.d.ts +0 -10
- package/dist/security/dns-normalization.d.ts +0 -6
- package/dist/security/dns-pinning.d.ts +0 -27
- package/dist/security/external-content.d.ts +0 -40
- package/dist/security/ssrf.d.ts +0 -40
- package/dist/slack/desktop-session.d.ts +0 -69
- package/dist/tool-factory.d.ts +0 -46
- package/dist/types.d.ts +0 -1192
- package/dist/utils/retry.d.ts +0 -11
- package/dist/utils/safe-parse-json.d.ts +0 -26
- package/dist/utils/url.d.ts +0 -10
- package/dist-cjs/ask-user-interaction.d.ts +0 -10
- package/dist-cjs/cache/web-cache.d.ts +0 -52
- package/dist-cjs/definitions/arion.d.ts +0 -8
- package/dist-cjs/definitions/browser/browser.d.ts +0 -2
- package/dist-cjs/definitions/browser/index.d.ts +0 -1
- package/dist-cjs/definitions/browser/pw-downloads.d.ts +0 -13
- package/dist-cjs/definitions/browser/pw-interactions.d.ts +0 -78
- package/dist-cjs/definitions/browser/pw-responses.d.ts +0 -28
- package/dist-cjs/definitions/browser/pw-session.d.ts +0 -65
- package/dist-cjs/definitions/browser/pw-shared.d.ts +0 -22
- package/dist-cjs/definitions/browser/pw-snapshot.d.ts +0 -34
- package/dist-cjs/definitions/browser/pw-state.d.ts +0 -22
- package/dist-cjs/definitions/browser/types.d.ts +0 -277
- package/dist-cjs/definitions/code-intelligence.d.ts +0 -8
- package/dist-cjs/definitions/core.d.ts +0 -47
- package/dist-cjs/definitions/delegation.d.ts +0 -11
- package/dist-cjs/definitions/deploy.d.ts +0 -15
- package/dist-cjs/definitions/filesystem.d.ts +0 -9
- package/dist-cjs/definitions/frg.d.ts +0 -3
- package/dist-cjs/definitions/memory.d.ts +0 -8
- package/dist-cjs/definitions/messaging.d.ts +0 -11
- package/dist-cjs/definitions/meta.d.ts +0 -11
- package/dist-cjs/definitions/network.d.ts +0 -11
- package/dist-cjs/definitions/outlook.d.ts +0 -2
- package/dist-cjs/definitions/patch/apply-patch.d.ts +0 -11
- package/dist-cjs/definitions/patch/fuzzy-match.d.ts +0 -10
- package/dist-cjs/definitions/patch/patch-parser.d.ts +0 -50
- package/dist-cjs/definitions/patch/sandbox-paths.d.ts +0 -18
- package/dist-cjs/definitions/process/index.d.ts +0 -1
- package/dist-cjs/definitions/process/process-registry.d.ts +0 -67
- package/dist-cjs/definitions/process/process.d.ts +0 -9
- package/dist-cjs/definitions/process/pty-keys.d.ts +0 -13
- package/dist-cjs/definitions/process/session-slug.d.ts +0 -1
- package/dist-cjs/definitions/quip.d.ts +0 -2
- package/dist-cjs/definitions/search.d.ts +0 -9
- package/dist-cjs/definitions/session-history.d.ts +0 -11
- package/dist-cjs/definitions/shell.d.ts +0 -8
- package/dist-cjs/definitions/slack.d.ts +0 -2
- package/dist-cjs/definitions/web.d.ts +0 -8
- package/dist-cjs/executors/apply-patch.d.ts +0 -51
- package/dist-cjs/executors/arion.d.ts +0 -50
- package/dist-cjs/executors/code-intelligence.d.ts +0 -138
- package/dist-cjs/executors/deploy.d.ts +0 -169
- package/dist-cjs/executors/filesystem.d.ts +0 -150
- package/dist-cjs/executors/frg-freshness.d.ts +0 -93
- package/dist-cjs/executors/frg.d.ts +0 -27
- package/dist-cjs/executors/learning-meta.d.ts +0 -87
- package/dist-cjs/executors/lsp-client.d.ts +0 -38
- package/dist-cjs/executors/memory.d.ts +0 -203
- package/dist-cjs/executors/meta.d.ts +0 -73
- package/dist-cjs/executors/process-registry.d.ts +0 -98
- package/dist-cjs/executors/pty-session-store.d.ts +0 -14
- package/dist-cjs/executors/pty.d.ts +0 -133
- package/dist-cjs/executors/restart.d.ts +0 -13
- package/dist-cjs/executors/search-freshness.d.ts +0 -50
- package/dist-cjs/executors/search-types.d.ts +0 -52
- package/dist-cjs/executors/search.d.ts +0 -11
- package/dist-cjs/executors/self-diagnose.d.ts +0 -89
- package/dist-cjs/executors/session-history.d.ts +0 -75
- package/dist-cjs/executors/shell-safety.d.ts +0 -27
- package/dist-cjs/executors/shell.d.ts +0 -168
- package/dist-cjs/executors/utils.d.ts +0 -20
- package/dist-cjs/executors/web.d.ts +0 -89
- package/dist-cjs/extraction/content-extraction.d.ts +0 -48
- package/dist-cjs/extraction/index.d.ts +0 -4
- package/dist-cjs/headless-control-contract.d.ts +0 -3182
- package/dist-cjs/index.d.ts +0 -62
- package/dist-cjs/local-control-http-auth.d.ts +0 -2
- package/dist-cjs/mcp/client.d.ts +0 -68
- package/dist-cjs/mcp/connection.d.ts +0 -54
- package/dist-cjs/mcp/index.d.ts +0 -10
- package/dist-cjs/mcp/jsonrpc.d.ts +0 -36
- package/dist-cjs/mcp/types.d.ts +0 -178
- package/dist-cjs/network-control-adapter.d.ts +0 -4
- package/dist-cjs/network-runtime/address-types.d.ts +0 -201
- package/dist-cjs/network-runtime/db-owner-fencing.d.ts +0 -43
- package/dist-cjs/network-runtime/delivery-receipts.d.ts +0 -117
- package/dist-cjs/network-runtime/direct-endpoint-authority.d.ts +0 -8
- package/dist-cjs/network-runtime/index.d.ts +0 -24
- package/dist-cjs/network-runtime/local-control-contract.d.ts +0 -758
- package/dist-cjs/network-runtime/node-store-contract.d.ts +0 -49
- package/dist-cjs/network-runtime/pair-route-contract.d.ts +0 -100
- package/dist-cjs/network-runtime/peer-capabilities.d.ts +0 -10
- package/dist-cjs/network-runtime/peer-principal-ref.d.ts +0 -9
- package/dist-cjs/network-runtime/peer-state-machine.d.ts +0 -70
- package/dist-cjs/network-runtime/protocol-schemas.d.ts +0 -328
- package/dist-cjs/network-runtime/runtime-bootstrap-contract.d.ts +0 -81
- package/dist-cjs/outlook/desktop-session.d.ts +0 -68
- package/dist-cjs/policy.d.ts +0 -43
- package/dist-cjs/providers/brave.d.ts +0 -10
- package/dist-cjs/providers/duckduckgo.d.ts +0 -18
- package/dist-cjs/providers/exa.d.ts +0 -10
- package/dist-cjs/providers/firecrawl.d.ts +0 -10
- package/dist-cjs/providers/jina.d.ts +0 -10
- package/dist-cjs/providers/router.d.ts +0 -21
- package/dist-cjs/providers/search-provider.d.ts +0 -35
- package/dist-cjs/providers/tavily.d.ts +0 -10
- package/dist-cjs/quip/desktop-session.d.ts +0 -69
- package/dist-cjs/registry/registry.d.ts +0 -156
- package/dist-cjs/runtime-socket-local-control-client.d.ts +0 -10
- package/dist-cjs/security/dns-normalization.d.ts +0 -6
- package/dist-cjs/security/dns-pinning.d.ts +0 -27
- package/dist-cjs/security/external-content.d.ts +0 -40
- package/dist-cjs/security/ssrf.d.ts +0 -40
- package/dist-cjs/slack/desktop-session.d.ts +0 -69
- package/dist-cjs/tool-factory.d.ts +0 -46
- package/dist-cjs/types.d.ts +0 -1192
- package/dist-cjs/utils/retry.d.ts +0 -11
- package/dist-cjs/utils/safe-parse-json.d.ts +0 -26
- package/dist-cjs/utils/url.d.ts +0 -10
|
@@ -0,0 +1,182 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* MCP Multi-Server Client
|
|
3
|
+
*
|
|
4
|
+
* Manages connections to multiple MCP servers and aggregates their capabilities.
|
|
5
|
+
*/
|
|
6
|
+
import { EventEmitter } from "events";
|
|
7
|
+
import { MCPServerConnection } from "./connection.js";
|
|
8
|
+
export class MCPClient extends EventEmitter {
|
|
9
|
+
servers = new Map();
|
|
10
|
+
serverConfigs = new Map();
|
|
11
|
+
reconnectTimers = new Map();
|
|
12
|
+
logger;
|
|
13
|
+
constructor(options) {
|
|
14
|
+
super();
|
|
15
|
+
this.logger = options?.logger ?? console;
|
|
16
|
+
}
|
|
17
|
+
/**
|
|
18
|
+
* Connect to an MCP server
|
|
19
|
+
*/
|
|
20
|
+
async connect(config) {
|
|
21
|
+
if (this.servers.has(config.name)) {
|
|
22
|
+
throw new Error(`Server already connected: ${config.name}`);
|
|
23
|
+
}
|
|
24
|
+
const connection = new MCPServerConnection(config);
|
|
25
|
+
await connection.initialize();
|
|
26
|
+
// Forward events
|
|
27
|
+
connection.on("tools/list_changed", () => this.emit("toolsChanged", config.name));
|
|
28
|
+
connection.on("resources/list_changed", () => this.emit("resourcesChanged", config.name));
|
|
29
|
+
connection.on("prompts/list_changed", () => this.emit("promptsChanged", config.name));
|
|
30
|
+
connection.on("exit", (code) => {
|
|
31
|
+
this.servers.delete(config.name);
|
|
32
|
+
this.emit("serverExit", config.name, code);
|
|
33
|
+
// Attempt auto-reconnect on unexpected exit
|
|
34
|
+
if (code !== 0 && this.serverConfigs.has(config.name)) {
|
|
35
|
+
this.reconnect(config.name, config).catch((err) => {
|
|
36
|
+
this.logger.warn("[MCPClient] Reconnect failed:", err?.message);
|
|
37
|
+
});
|
|
38
|
+
}
|
|
39
|
+
});
|
|
40
|
+
this.servers.set(config.name, connection);
|
|
41
|
+
this.serverConfigs.set(config.name, config);
|
|
42
|
+
return connection;
|
|
43
|
+
}
|
|
44
|
+
/**
|
|
45
|
+
* Disconnect from a specific server
|
|
46
|
+
*/
|
|
47
|
+
async disconnect(name) {
|
|
48
|
+
this.serverConfigs.delete(name);
|
|
49
|
+
// Cancel any pending reconnect timer for this server
|
|
50
|
+
const timer = this.reconnectTimers.get(name);
|
|
51
|
+
if (timer !== undefined) {
|
|
52
|
+
clearTimeout(timer);
|
|
53
|
+
this.reconnectTimers.delete(name);
|
|
54
|
+
}
|
|
55
|
+
const conn = this.servers.get(name);
|
|
56
|
+
if (conn) {
|
|
57
|
+
this.servers.delete(name);
|
|
58
|
+
conn.removeAllListeners();
|
|
59
|
+
await conn.shutdown();
|
|
60
|
+
}
|
|
61
|
+
}
|
|
62
|
+
/**
|
|
63
|
+
* Attempt to reconnect to a server with exponential backoff
|
|
64
|
+
*/
|
|
65
|
+
async reconnect(serverName, config, attempt = 0) {
|
|
66
|
+
const maxAttempts = 3;
|
|
67
|
+
const delay = Math.min(1000 * Math.pow(2, attempt), 30000);
|
|
68
|
+
if (attempt >= maxAttempts)
|
|
69
|
+
return;
|
|
70
|
+
await new Promise((resolve) => {
|
|
71
|
+
const timer = setTimeout(resolve, delay);
|
|
72
|
+
this.reconnectTimers.set(serverName, timer);
|
|
73
|
+
});
|
|
74
|
+
this.reconnectTimers.delete(serverName);
|
|
75
|
+
// Bail out if server was disconnected while we were waiting
|
|
76
|
+
if (!this.serverConfigs.has(serverName))
|
|
77
|
+
return;
|
|
78
|
+
// Guard against double-reconnect race: if another reconnect already
|
|
79
|
+
// re-established the connection, skip this attempt.
|
|
80
|
+
if (this.servers.has(serverName))
|
|
81
|
+
return;
|
|
82
|
+
try {
|
|
83
|
+
await this.connect(config);
|
|
84
|
+
}
|
|
85
|
+
catch {
|
|
86
|
+
await this.reconnect(serverName, config, attempt + 1);
|
|
87
|
+
}
|
|
88
|
+
}
|
|
89
|
+
/**
|
|
90
|
+
* Disconnect from all servers
|
|
91
|
+
*/
|
|
92
|
+
async disconnectAll() {
|
|
93
|
+
// Collect names from both active connections and pending reconnects
|
|
94
|
+
const names = new Set([...this.servers.keys(), ...this.reconnectTimers.keys()]);
|
|
95
|
+
await Promise.all([...names].map((name) => this.disconnect(name)));
|
|
96
|
+
}
|
|
97
|
+
/**
|
|
98
|
+
* Get connected server names
|
|
99
|
+
*/
|
|
100
|
+
getConnectedServers() {
|
|
101
|
+
return [...this.servers.keys()];
|
|
102
|
+
}
|
|
103
|
+
// ========== Tools ==========
|
|
104
|
+
/**
|
|
105
|
+
* List all tools from all connected servers
|
|
106
|
+
*/
|
|
107
|
+
async listAllTools() {
|
|
108
|
+
const results = await Promise.all([...this.servers.entries()].map(async ([name, conn]) => {
|
|
109
|
+
try {
|
|
110
|
+
const tools = await conn.listTools();
|
|
111
|
+
return tools.map((t) => ({ ...t, server: name }));
|
|
112
|
+
}
|
|
113
|
+
catch {
|
|
114
|
+
return [];
|
|
115
|
+
}
|
|
116
|
+
}));
|
|
117
|
+
return results.flat();
|
|
118
|
+
}
|
|
119
|
+
/**
|
|
120
|
+
* Call a tool on a specific server
|
|
121
|
+
*/
|
|
122
|
+
async callTool(server, tool, args, abortSignal) {
|
|
123
|
+
const conn = this.servers.get(server);
|
|
124
|
+
if (!conn) {
|
|
125
|
+
return { success: false, message: `Server not connected: ${server}` };
|
|
126
|
+
}
|
|
127
|
+
return conn.callTool(tool, args, abortSignal);
|
|
128
|
+
}
|
|
129
|
+
// ========== Resources ==========
|
|
130
|
+
/**
|
|
131
|
+
* List all resources from all connected servers
|
|
132
|
+
*/
|
|
133
|
+
async listAllResources() {
|
|
134
|
+
const results = await Promise.all([...this.servers.entries()].map(async ([name, conn]) => {
|
|
135
|
+
try {
|
|
136
|
+
const resources = await conn.listResources();
|
|
137
|
+
return resources.map((r) => ({ ...r, server: name }));
|
|
138
|
+
}
|
|
139
|
+
catch {
|
|
140
|
+
return [];
|
|
141
|
+
}
|
|
142
|
+
}));
|
|
143
|
+
return results.flat();
|
|
144
|
+
}
|
|
145
|
+
/**
|
|
146
|
+
* Read a resource from a specific server
|
|
147
|
+
*/
|
|
148
|
+
async readResource(server, uri) {
|
|
149
|
+
const conn = this.servers.get(server);
|
|
150
|
+
if (!conn) {
|
|
151
|
+
throw new Error(`Server not connected: ${server}`);
|
|
152
|
+
}
|
|
153
|
+
return conn.readResource(uri);
|
|
154
|
+
}
|
|
155
|
+
// ========== Prompts ==========
|
|
156
|
+
/**
|
|
157
|
+
* List all prompts from all connected servers
|
|
158
|
+
*/
|
|
159
|
+
async listAllPrompts() {
|
|
160
|
+
const results = await Promise.all([...this.servers.entries()].map(async ([name, conn]) => {
|
|
161
|
+
try {
|
|
162
|
+
const prompts = await conn.listPrompts();
|
|
163
|
+
return prompts.map((p) => ({ ...p, server: name }));
|
|
164
|
+
}
|
|
165
|
+
catch {
|
|
166
|
+
return [];
|
|
167
|
+
}
|
|
168
|
+
}));
|
|
169
|
+
return results.flat();
|
|
170
|
+
}
|
|
171
|
+
/**
|
|
172
|
+
* Get a prompt from a specific server
|
|
173
|
+
*/
|
|
174
|
+
async getPrompt(server, name, args) {
|
|
175
|
+
const conn = this.servers.get(server);
|
|
176
|
+
if (!conn) {
|
|
177
|
+
throw new Error(`Server not connected: ${server}`);
|
|
178
|
+
}
|
|
179
|
+
return conn.getPrompt(name, args);
|
|
180
|
+
}
|
|
181
|
+
}
|
|
182
|
+
//# sourceMappingURL=client.js.map
|
|
@@ -0,0 +1,484 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* MCP Server Connection
|
|
3
|
+
*
|
|
4
|
+
* Manages lifecycle and protocol methods for a single MCP server.
|
|
5
|
+
*/
|
|
6
|
+
import { spawn } from "child_process";
|
|
7
|
+
import { EventEmitter } from "events";
|
|
8
|
+
import { PassThrough, Writable } from "stream";
|
|
9
|
+
// Hardcoded version — updated by release script.
|
|
10
|
+
// DO NOT read from package.json — breaks when bun bundles the file.
|
|
11
|
+
const TOOLS_VERSION = "1.0.30";
|
|
12
|
+
import { JSONRPCClient } from "./jsonrpc.js";
|
|
13
|
+
function sanitizeGitEnv(env = process.env) {
|
|
14
|
+
const sanitized = {};
|
|
15
|
+
for (const [key, value] of Object.entries(env)) {
|
|
16
|
+
if (value === undefined)
|
|
17
|
+
continue;
|
|
18
|
+
if (key.toUpperCase().startsWith("GIT_"))
|
|
19
|
+
continue;
|
|
20
|
+
sanitized[key] = value;
|
|
21
|
+
}
|
|
22
|
+
return sanitized;
|
|
23
|
+
}
|
|
24
|
+
export class MCPServerConnection extends EventEmitter {
|
|
25
|
+
config;
|
|
26
|
+
process;
|
|
27
|
+
transport = "stdio";
|
|
28
|
+
rpc;
|
|
29
|
+
capabilities = {};
|
|
30
|
+
_initialized = false;
|
|
31
|
+
sseAbortController;
|
|
32
|
+
sseStreamPromise;
|
|
33
|
+
ssePostUrl;
|
|
34
|
+
sseSessionId;
|
|
35
|
+
sseOutput;
|
|
36
|
+
// Auto-reconnect state
|
|
37
|
+
_disconnecting = false;
|
|
38
|
+
_reconnecting = false;
|
|
39
|
+
_reconnectAttempts = 0;
|
|
40
|
+
static RECONNECT_BASE_DELAY_MS = 1000;
|
|
41
|
+
static RECONNECT_MAX_DELAY_MS = 30000;
|
|
42
|
+
static RECONNECT_MAX_ATTEMPTS = 5;
|
|
43
|
+
constructor(config) {
|
|
44
|
+
super();
|
|
45
|
+
this.config = config;
|
|
46
|
+
this.rpc = new JSONRPCClient();
|
|
47
|
+
}
|
|
48
|
+
get name() {
|
|
49
|
+
return this.config.name;
|
|
50
|
+
}
|
|
51
|
+
get initialized() {
|
|
52
|
+
return this._initialized;
|
|
53
|
+
}
|
|
54
|
+
/**
|
|
55
|
+
* Initialize connection to MCP server
|
|
56
|
+
*/
|
|
57
|
+
async initialize() {
|
|
58
|
+
// Reset disconnecting flag on fresh initialization so auto-reconnect is active.
|
|
59
|
+
// During reconnect, attemptReconnect() checks _disconnecting before each attempt.
|
|
60
|
+
if (!this._reconnecting) {
|
|
61
|
+
this._disconnecting = false;
|
|
62
|
+
this._reconnectAttempts = 0;
|
|
63
|
+
}
|
|
64
|
+
this.transport = this.config.transport ?? "stdio";
|
|
65
|
+
try {
|
|
66
|
+
if (this.transport === "stdio") {
|
|
67
|
+
await this.initializeStdioTransport();
|
|
68
|
+
}
|
|
69
|
+
else {
|
|
70
|
+
await this.initializeSSETransport();
|
|
71
|
+
}
|
|
72
|
+
// Forward notifications
|
|
73
|
+
this.rpc.on("notifications/tools/list_changed", () => this.emit("tools/list_changed"));
|
|
74
|
+
this.rpc.on("notifications/resources/list_changed", () => this.emit("resources/list_changed"));
|
|
75
|
+
this.rpc.on("notifications/prompts/list_changed", () => this.emit("prompts/list_changed"));
|
|
76
|
+
// MCP initialize handshake
|
|
77
|
+
const result = await this.rpc.request("initialize", {
|
|
78
|
+
protocolVersion: "2024-11-05",
|
|
79
|
+
capabilities: {
|
|
80
|
+
roots: { listChanged: true },
|
|
81
|
+
},
|
|
82
|
+
clientInfo: {
|
|
83
|
+
name: "aria-cli",
|
|
84
|
+
version: TOOLS_VERSION,
|
|
85
|
+
},
|
|
86
|
+
});
|
|
87
|
+
this.capabilities = result.capabilities || {};
|
|
88
|
+
this._initialized = true;
|
|
89
|
+
// Send initialized notification
|
|
90
|
+
this.rpc.notify("notifications/initialized", {});
|
|
91
|
+
return this.capabilities;
|
|
92
|
+
}
|
|
93
|
+
catch (error) {
|
|
94
|
+
await this.cleanupAfterInitializeFailure();
|
|
95
|
+
throw error;
|
|
96
|
+
}
|
|
97
|
+
}
|
|
98
|
+
/**
|
|
99
|
+
* Attempt to reconnect with exponential backoff.
|
|
100
|
+
* Called when the transport drops unexpectedly (not via explicit shutdown).
|
|
101
|
+
*/
|
|
102
|
+
async attemptReconnect() {
|
|
103
|
+
if (this._disconnecting || this._reconnecting) {
|
|
104
|
+
return;
|
|
105
|
+
}
|
|
106
|
+
this._reconnecting = true;
|
|
107
|
+
while (this._reconnectAttempts < MCPServerConnection.RECONNECT_MAX_ATTEMPTS &&
|
|
108
|
+
!this._disconnecting) {
|
|
109
|
+
this._reconnectAttempts++;
|
|
110
|
+
const delay = Math.min(MCPServerConnection.RECONNECT_BASE_DELAY_MS * Math.pow(2, this._reconnectAttempts - 1), MCPServerConnection.RECONNECT_MAX_DELAY_MS);
|
|
111
|
+
this.emit("log", {
|
|
112
|
+
level: "info",
|
|
113
|
+
message: `Reconnect attempt ${this._reconnectAttempts}/${MCPServerConnection.RECONNECT_MAX_ATTEMPTS} in ${delay}ms`,
|
|
114
|
+
});
|
|
115
|
+
await new Promise((resolve) => setTimeout(resolve, delay));
|
|
116
|
+
if (this._disconnecting) {
|
|
117
|
+
break;
|
|
118
|
+
}
|
|
119
|
+
try {
|
|
120
|
+
// Clean up stale RPC state before reconnecting
|
|
121
|
+
this.rpc.close();
|
|
122
|
+
this.rpc = new JSONRPCClient();
|
|
123
|
+
await this.initialize();
|
|
124
|
+
// Success — reset reconnect state
|
|
125
|
+
this._reconnectAttempts = 0;
|
|
126
|
+
this._reconnecting = false;
|
|
127
|
+
this.emit("reconnected");
|
|
128
|
+
return;
|
|
129
|
+
}
|
|
130
|
+
catch (error) {
|
|
131
|
+
this.emit("log", {
|
|
132
|
+
level: "error",
|
|
133
|
+
message: `Reconnect attempt ${this._reconnectAttempts} failed: ${error.message}`,
|
|
134
|
+
});
|
|
135
|
+
}
|
|
136
|
+
}
|
|
137
|
+
// All attempts exhausted or disconnecting flag was set
|
|
138
|
+
this._reconnecting = false;
|
|
139
|
+
if (!this._disconnecting) {
|
|
140
|
+
this._initialized = false;
|
|
141
|
+
this.emit("error", new Error(`Failed to reconnect after ${MCPServerConnection.RECONNECT_MAX_ATTEMPTS} attempts`));
|
|
142
|
+
}
|
|
143
|
+
}
|
|
144
|
+
async initializeStdioTransport() {
|
|
145
|
+
if (!this.config.command) {
|
|
146
|
+
throw new Error("Command required for stdio transport");
|
|
147
|
+
}
|
|
148
|
+
// Spawn server process
|
|
149
|
+
this.process = spawn(this.config.command, this.config.args || [], {
|
|
150
|
+
env: { ...sanitizeGitEnv(), ...sanitizeGitEnv(this.config.env ?? {}) },
|
|
151
|
+
stdio: ["pipe", "pipe", "pipe"],
|
|
152
|
+
});
|
|
153
|
+
if (!this.process.stdin || !this.process.stdout) {
|
|
154
|
+
throw new Error("Failed to create stdio streams");
|
|
155
|
+
}
|
|
156
|
+
this.rpc.connect(this.process.stdin, this.process.stdout);
|
|
157
|
+
// Handle stderr for logging
|
|
158
|
+
this.process.stderr?.on("data", (data) => {
|
|
159
|
+
this.emit("log", { level: "error", message: data.toString() });
|
|
160
|
+
});
|
|
161
|
+
this.process.on("exit", (code) => {
|
|
162
|
+
this._initialized = false;
|
|
163
|
+
this.rpc.close();
|
|
164
|
+
this.emit("exit", code);
|
|
165
|
+
// Attempt auto-reconnect on unexpected exit
|
|
166
|
+
if (!this._disconnecting) {
|
|
167
|
+
void this.attemptReconnect();
|
|
168
|
+
}
|
|
169
|
+
});
|
|
170
|
+
}
|
|
171
|
+
async initializeSSETransport() {
|
|
172
|
+
const url = this.config.url;
|
|
173
|
+
if (!url) {
|
|
174
|
+
throw new Error("URL required for sse transport");
|
|
175
|
+
}
|
|
176
|
+
const stdin = new Writable({
|
|
177
|
+
write: (chunk, _encoding, callback) => {
|
|
178
|
+
const payload = chunk.toString();
|
|
179
|
+
this.postSSEMessages(payload)
|
|
180
|
+
.then(() => callback())
|
|
181
|
+
.catch((err) => callback(err));
|
|
182
|
+
},
|
|
183
|
+
});
|
|
184
|
+
const stdout = new PassThrough();
|
|
185
|
+
this.sseOutput = stdout;
|
|
186
|
+
this.rpc.connect(stdin, stdout);
|
|
187
|
+
this.sseAbortController = new AbortController();
|
|
188
|
+
const response = await fetch(url, {
|
|
189
|
+
method: "GET",
|
|
190
|
+
headers: { Accept: "text/event-stream" },
|
|
191
|
+
signal: this.sseAbortController.signal,
|
|
192
|
+
});
|
|
193
|
+
if (!response.ok || !response.body) {
|
|
194
|
+
const errorText = await response.text();
|
|
195
|
+
throw new Error(`Failed to connect SSE transport: ${response.status} ${response.statusText} ${errorText}`);
|
|
196
|
+
}
|
|
197
|
+
this.sseSessionId = response.headers.get("mcp-session-id") ?? undefined;
|
|
198
|
+
this.ssePostUrl = url;
|
|
199
|
+
this.sseStreamPromise = this.consumeSSE(response.body, url);
|
|
200
|
+
}
|
|
201
|
+
async postSSEMessages(payload) {
|
|
202
|
+
const trimmed = payload.trim();
|
|
203
|
+
if (!trimmed) {
|
|
204
|
+
return;
|
|
205
|
+
}
|
|
206
|
+
const endpoint = this.ssePostUrl || this.config.url;
|
|
207
|
+
if (!endpoint) {
|
|
208
|
+
throw new Error("SSE transport endpoint is not configured");
|
|
209
|
+
}
|
|
210
|
+
const messages = trimmed
|
|
211
|
+
.split("\n")
|
|
212
|
+
.map((line) => line.trim())
|
|
213
|
+
.filter((line) => line.length > 0);
|
|
214
|
+
for (const message of messages) {
|
|
215
|
+
const response = await fetch(endpoint, {
|
|
216
|
+
method: "POST",
|
|
217
|
+
headers: {
|
|
218
|
+
"Content-Type": "application/json",
|
|
219
|
+
...(this.sseSessionId ? { "mcp-session-id": this.sseSessionId } : {}),
|
|
220
|
+
},
|
|
221
|
+
body: message,
|
|
222
|
+
});
|
|
223
|
+
if (!response.ok) {
|
|
224
|
+
const errorText = await response.text();
|
|
225
|
+
throw new Error(`SSE transport POST failed: ${response.status} ${response.statusText} ${errorText}`);
|
|
226
|
+
}
|
|
227
|
+
const responseText = (await response.text()).trim();
|
|
228
|
+
if (!responseText || !this.sseOutput) {
|
|
229
|
+
continue;
|
|
230
|
+
}
|
|
231
|
+
// Some servers return direct JSON-RPC responses on POST while others
|
|
232
|
+
// publish responses only via SSE. Forward direct JSON replies into RPC.
|
|
233
|
+
for (const line of responseText.split("\n")) {
|
|
234
|
+
const jsonLine = line.trim();
|
|
235
|
+
if (!jsonLine) {
|
|
236
|
+
continue;
|
|
237
|
+
}
|
|
238
|
+
if (jsonLine.startsWith("{") && jsonLine.endsWith("}")) {
|
|
239
|
+
this.sseOutput.write(`${jsonLine}\n`);
|
|
240
|
+
}
|
|
241
|
+
}
|
|
242
|
+
}
|
|
243
|
+
}
|
|
244
|
+
async consumeSSE(body, baseUrl) {
|
|
245
|
+
const reader = body.getReader();
|
|
246
|
+
const decoder = new TextDecoder();
|
|
247
|
+
let buffer = "";
|
|
248
|
+
let eventType = "";
|
|
249
|
+
let dataLines = [];
|
|
250
|
+
const dispatch = () => {
|
|
251
|
+
if (dataLines.length === 0) {
|
|
252
|
+
eventType = "";
|
|
253
|
+
return;
|
|
254
|
+
}
|
|
255
|
+
const data = dataLines.join("\n").trim();
|
|
256
|
+
const event = eventType || "message";
|
|
257
|
+
eventType = "";
|
|
258
|
+
dataLines = [];
|
|
259
|
+
if (!data) {
|
|
260
|
+
return;
|
|
261
|
+
}
|
|
262
|
+
if (event === "endpoint") {
|
|
263
|
+
this.ssePostUrl = new URL(data, baseUrl).toString();
|
|
264
|
+
return;
|
|
265
|
+
}
|
|
266
|
+
if (!this.sseOutput) {
|
|
267
|
+
return;
|
|
268
|
+
}
|
|
269
|
+
if (data.startsWith("{") && data.endsWith("}")) {
|
|
270
|
+
this.sseOutput.write(`${data}\n`);
|
|
271
|
+
}
|
|
272
|
+
};
|
|
273
|
+
try {
|
|
274
|
+
while (true) {
|
|
275
|
+
const { done, value } = await reader.read();
|
|
276
|
+
if (done) {
|
|
277
|
+
dispatch();
|
|
278
|
+
break;
|
|
279
|
+
}
|
|
280
|
+
buffer += decoder.decode(value, { stream: true });
|
|
281
|
+
const lines = buffer.split(/\r?\n/);
|
|
282
|
+
buffer = lines.pop() || "";
|
|
283
|
+
for (const line of lines) {
|
|
284
|
+
if (line === "") {
|
|
285
|
+
dispatch();
|
|
286
|
+
continue;
|
|
287
|
+
}
|
|
288
|
+
if (line.startsWith("event:")) {
|
|
289
|
+
eventType = line.slice(6).trim();
|
|
290
|
+
continue;
|
|
291
|
+
}
|
|
292
|
+
if (line.startsWith("data:")) {
|
|
293
|
+
dataLines.push(line.slice(5).trim());
|
|
294
|
+
}
|
|
295
|
+
}
|
|
296
|
+
}
|
|
297
|
+
}
|
|
298
|
+
catch (error) {
|
|
299
|
+
// Ignore abort errors from normal shutdown.
|
|
300
|
+
if (!(error instanceof DOMException && error.name === "AbortError")) {
|
|
301
|
+
this.emit("log", {
|
|
302
|
+
level: "error",
|
|
303
|
+
message: `SSE stream error: ${error.message}`,
|
|
304
|
+
});
|
|
305
|
+
}
|
|
306
|
+
}
|
|
307
|
+
finally {
|
|
308
|
+
if (this._initialized) {
|
|
309
|
+
this._initialized = false;
|
|
310
|
+
this.rpc.close();
|
|
311
|
+
this.emit("exit", 0);
|
|
312
|
+
// Attempt auto-reconnect on unexpected SSE stream end
|
|
313
|
+
if (!this._disconnecting) {
|
|
314
|
+
void this.attemptReconnect();
|
|
315
|
+
}
|
|
316
|
+
}
|
|
317
|
+
}
|
|
318
|
+
}
|
|
319
|
+
async cleanupAfterInitializeFailure() {
|
|
320
|
+
if (this.transport === "stdio") {
|
|
321
|
+
if (this.process && !this.process.killed) {
|
|
322
|
+
try {
|
|
323
|
+
this.process.kill("SIGTERM");
|
|
324
|
+
}
|
|
325
|
+
catch {
|
|
326
|
+
// Ignore kill failures during cleanup.
|
|
327
|
+
}
|
|
328
|
+
}
|
|
329
|
+
this.process = undefined;
|
|
330
|
+
}
|
|
331
|
+
else {
|
|
332
|
+
this.sseAbortController?.abort();
|
|
333
|
+
try {
|
|
334
|
+
await this.sseStreamPromise;
|
|
335
|
+
}
|
|
336
|
+
catch {
|
|
337
|
+
// Ignore stream errors during cleanup.
|
|
338
|
+
}
|
|
339
|
+
this.sseOutput?.end();
|
|
340
|
+
this.sseOutput = undefined;
|
|
341
|
+
}
|
|
342
|
+
this.rpc.close();
|
|
343
|
+
}
|
|
344
|
+
/**
|
|
345
|
+
* Gracefully shutdown the connection
|
|
346
|
+
*/
|
|
347
|
+
async shutdown() {
|
|
348
|
+
this._disconnecting = true;
|
|
349
|
+
if (!this._initialized)
|
|
350
|
+
return;
|
|
351
|
+
this._initialized = false;
|
|
352
|
+
if (this.transport === "sse") {
|
|
353
|
+
try {
|
|
354
|
+
await this.rpc.request("shutdown", {});
|
|
355
|
+
this.rpc.notify("notifications/exit", {});
|
|
356
|
+
}
|
|
357
|
+
catch {
|
|
358
|
+
// Best effort
|
|
359
|
+
}
|
|
360
|
+
this.sseAbortController?.abort();
|
|
361
|
+
try {
|
|
362
|
+
await this.sseStreamPromise;
|
|
363
|
+
}
|
|
364
|
+
catch {
|
|
365
|
+
// Ignore stream shutdown errors
|
|
366
|
+
}
|
|
367
|
+
this.sseOutput?.end();
|
|
368
|
+
this.sseOutput = undefined;
|
|
369
|
+
this.rpc.close();
|
|
370
|
+
return;
|
|
371
|
+
}
|
|
372
|
+
if (this.process) {
|
|
373
|
+
// Send MCP shutdown/exit protocol before killing
|
|
374
|
+
try {
|
|
375
|
+
await this.rpc.request("shutdown", {});
|
|
376
|
+
this.rpc.notify("notifications/exit", {});
|
|
377
|
+
// Give process a moment to clean up
|
|
378
|
+
await new Promise((resolve) => setTimeout(resolve, 500));
|
|
379
|
+
}
|
|
380
|
+
catch {
|
|
381
|
+
// Process may already be dead, proceed with kill
|
|
382
|
+
}
|
|
383
|
+
this.process.kill("SIGTERM");
|
|
384
|
+
// Await process exit before resolving
|
|
385
|
+
await new Promise((resolve) => {
|
|
386
|
+
// Escalate to SIGKILL if process doesn't exit within 5s
|
|
387
|
+
const killTimeout = setTimeout(() => {
|
|
388
|
+
try {
|
|
389
|
+
this.process?.kill("SIGKILL");
|
|
390
|
+
}
|
|
391
|
+
catch {
|
|
392
|
+
/* already dead */
|
|
393
|
+
}
|
|
394
|
+
}, 5000);
|
|
395
|
+
this.process.once("exit", () => {
|
|
396
|
+
clearTimeout(killTimeout);
|
|
397
|
+
this.rpc.close();
|
|
398
|
+
resolve();
|
|
399
|
+
});
|
|
400
|
+
});
|
|
401
|
+
}
|
|
402
|
+
else {
|
|
403
|
+
this.rpc.close();
|
|
404
|
+
}
|
|
405
|
+
}
|
|
406
|
+
// ========== Tools ==========
|
|
407
|
+
async listTools() {
|
|
408
|
+
const result = await this.rpc.request("tools/list", {});
|
|
409
|
+
return result.tools || [];
|
|
410
|
+
}
|
|
411
|
+
async callTool(name, args, abortSignal) {
|
|
412
|
+
// Early abort check before making the RPC call
|
|
413
|
+
if (abortSignal?.aborted) {
|
|
414
|
+
return { success: false, message: "Tool execution cancelled by user." };
|
|
415
|
+
}
|
|
416
|
+
try {
|
|
417
|
+
// Race the RPC call against the abort signal so user cancel
|
|
418
|
+
// doesn't block waiting for a slow MCP server response.
|
|
419
|
+
const rpcPromise = this.rpc.request("tools/call", {
|
|
420
|
+
name,
|
|
421
|
+
arguments: args,
|
|
422
|
+
});
|
|
423
|
+
let result;
|
|
424
|
+
if (abortSignal) {
|
|
425
|
+
result = await new Promise((resolve, reject) => {
|
|
426
|
+
const onAbort = () => reject(new DOMException("Aborted", "AbortError"));
|
|
427
|
+
abortSignal.addEventListener("abort", onAbort, { once: true });
|
|
428
|
+
rpcPromise.then((r) => {
|
|
429
|
+
abortSignal.removeEventListener("abort", onAbort);
|
|
430
|
+
resolve(r);
|
|
431
|
+
}, (e) => {
|
|
432
|
+
abortSignal.removeEventListener("abort", onAbort);
|
|
433
|
+
reject(e);
|
|
434
|
+
});
|
|
435
|
+
});
|
|
436
|
+
}
|
|
437
|
+
else {
|
|
438
|
+
result = await rpcPromise;
|
|
439
|
+
}
|
|
440
|
+
const text = result.content
|
|
441
|
+
?.filter((c) => c.type === "text")
|
|
442
|
+
.map((c) => c.text)
|
|
443
|
+
.join("\n") || "";
|
|
444
|
+
return {
|
|
445
|
+
success: !result.isError,
|
|
446
|
+
message: text,
|
|
447
|
+
data: result.content,
|
|
448
|
+
};
|
|
449
|
+
}
|
|
450
|
+
catch (error) {
|
|
451
|
+
if (error instanceof DOMException && error.name === "AbortError") {
|
|
452
|
+
return { success: false, message: "Tool execution cancelled by user." };
|
|
453
|
+
}
|
|
454
|
+
return {
|
|
455
|
+
success: false,
|
|
456
|
+
message: error.message,
|
|
457
|
+
};
|
|
458
|
+
}
|
|
459
|
+
}
|
|
460
|
+
// ========== Resources ==========
|
|
461
|
+
async listResources() {
|
|
462
|
+
const result = await this.rpc.request("resources/list", {});
|
|
463
|
+
return result.resources || [];
|
|
464
|
+
}
|
|
465
|
+
async readResource(uri) {
|
|
466
|
+
const result = await this.rpc.request("resources/read", {
|
|
467
|
+
uri,
|
|
468
|
+
});
|
|
469
|
+
return result.contents || [];
|
|
470
|
+
}
|
|
471
|
+
// ========== Prompts ==========
|
|
472
|
+
async listPrompts() {
|
|
473
|
+
const result = await this.rpc.request("prompts/list", {});
|
|
474
|
+
return result.prompts || [];
|
|
475
|
+
}
|
|
476
|
+
async getPrompt(name, args) {
|
|
477
|
+
const result = await this.rpc.request("prompts/get", {
|
|
478
|
+
name,
|
|
479
|
+
arguments: args,
|
|
480
|
+
});
|
|
481
|
+
return result.messages || [];
|
|
482
|
+
}
|
|
483
|
+
}
|
|
484
|
+
//# sourceMappingURL=connection.js.map
|
|
@@ -0,0 +1,11 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* MCP (Model Context Protocol) Module
|
|
3
|
+
*
|
|
4
|
+
* Provides client implementation for connecting to MCP servers
|
|
5
|
+
* and discovering tools, resources, and prompts dynamically.
|
|
6
|
+
*/
|
|
7
|
+
export * from "./types.js";
|
|
8
|
+
export { JSONRPCClient } from "./jsonrpc.js";
|
|
9
|
+
export { MCPServerConnection } from "./connection.js";
|
|
10
|
+
export { MCPClient } from "./client.js";
|
|
11
|
+
//# sourceMappingURL=index.js.map
|