@aria-cli/tools 1.0.18 → 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/{dns-pinning-vc0r0vpx.js → dns-pinning-7szqhtmq.js} +1 -1
- 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-x52t2mbj.js → index-45qvfjbf.js} +2 -2
- package/dist/{index-8xap0se3.js → index-b3sdwzh5.js} +1 -1
- package/dist/index-tvryzx00.js +2 -0
- package/dist/index.js +71 -372
- package/dist/local-control-http-auth.js +3 -0
- package/dist/{lsp-client-msnj763y.js → lsp-client-3qxptwyw.js} +1 -1
- 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/session-history-gk75e3ta.js +1 -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-a2fr1b3x.js +0 -2
- 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-ff59hy75.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/session-history-6gn52xhp.js +0 -1
- 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,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
|
|
@@ -0,0 +1,145 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* JSON-RPC 2.0 Client for MCP
|
|
3
|
+
*
|
|
4
|
+
* Handles newline-delimited JSON over stdio streams.
|
|
5
|
+
*/
|
|
6
|
+
import { EventEmitter } from "events";
|
|
7
|
+
import { randomUUID } from "crypto";
|
|
8
|
+
export class JSONRPCClient extends EventEmitter {
|
|
9
|
+
stdin;
|
|
10
|
+
stdout;
|
|
11
|
+
pending = new Map();
|
|
12
|
+
buffer = "";
|
|
13
|
+
requestTimeout;
|
|
14
|
+
constructor(options = {}) {
|
|
15
|
+
super();
|
|
16
|
+
this.requestTimeout = options.timeout ?? 30000;
|
|
17
|
+
}
|
|
18
|
+
/**
|
|
19
|
+
* Connect to a process via stdio streams
|
|
20
|
+
*/
|
|
21
|
+
connect(stdin, stdout) {
|
|
22
|
+
this.stdin = stdin;
|
|
23
|
+
this.stdout = stdout;
|
|
24
|
+
stdout.on("data", (chunk) => {
|
|
25
|
+
this.buffer += chunk.toString();
|
|
26
|
+
this.processBuffer();
|
|
27
|
+
});
|
|
28
|
+
stdout.on("error", (error) => {
|
|
29
|
+
this.emit("error", error);
|
|
30
|
+
});
|
|
31
|
+
stdout.on("end", () => {
|
|
32
|
+
this.emit("close");
|
|
33
|
+
});
|
|
34
|
+
}
|
|
35
|
+
processBuffer() {
|
|
36
|
+
let newlineIdx;
|
|
37
|
+
while ((newlineIdx = this.buffer.indexOf("\n")) !== -1) {
|
|
38
|
+
const line = this.buffer.slice(0, newlineIdx).trim();
|
|
39
|
+
this.buffer = this.buffer.slice(newlineIdx + 1);
|
|
40
|
+
if (line) {
|
|
41
|
+
try {
|
|
42
|
+
this.handleMessage(JSON.parse(line));
|
|
43
|
+
}
|
|
44
|
+
catch (e) {
|
|
45
|
+
this.emit("error", new Error(`Invalid JSON: ${line}`));
|
|
46
|
+
}
|
|
47
|
+
}
|
|
48
|
+
}
|
|
49
|
+
}
|
|
50
|
+
handleMessage(msg) {
|
|
51
|
+
// Ignore messages that aren't valid JSON-RPC 2.0
|
|
52
|
+
if (typeof msg !== "object" ||
|
|
53
|
+
msg === null ||
|
|
54
|
+
!("jsonrpc" in msg) ||
|
|
55
|
+
msg.jsonrpc !== "2.0")
|
|
56
|
+
return;
|
|
57
|
+
const rpcMsg = msg;
|
|
58
|
+
// Response to our request
|
|
59
|
+
if ("id" in rpcMsg && rpcMsg.id !== undefined) {
|
|
60
|
+
const response = rpcMsg;
|
|
61
|
+
const pending = this.pending.get(String(response.id));
|
|
62
|
+
if (pending) {
|
|
63
|
+
this.pending.delete(String(response.id));
|
|
64
|
+
clearTimeout(pending.timeout);
|
|
65
|
+
if (response.error) {
|
|
66
|
+
pending.reject(new Error(`${response.error.code}: ${response.error.message}`));
|
|
67
|
+
}
|
|
68
|
+
else {
|
|
69
|
+
pending.resolve(response.result);
|
|
70
|
+
}
|
|
71
|
+
}
|
|
72
|
+
return;
|
|
73
|
+
}
|
|
74
|
+
// Notification from server
|
|
75
|
+
if ("method" in rpcMsg) {
|
|
76
|
+
const notification = rpcMsg;
|
|
77
|
+
this.emit(notification.method, notification.params);
|
|
78
|
+
this.emit("notification", {
|
|
79
|
+
method: notification.method,
|
|
80
|
+
params: notification.params,
|
|
81
|
+
});
|
|
82
|
+
}
|
|
83
|
+
}
|
|
84
|
+
/**
|
|
85
|
+
* Send a request and wait for response
|
|
86
|
+
*/
|
|
87
|
+
async request(method, params) {
|
|
88
|
+
if (!this.stdin) {
|
|
89
|
+
throw new Error("Not connected");
|
|
90
|
+
}
|
|
91
|
+
const id = randomUUID();
|
|
92
|
+
const message = {
|
|
93
|
+
jsonrpc: "2.0",
|
|
94
|
+
id,
|
|
95
|
+
method,
|
|
96
|
+
params,
|
|
97
|
+
};
|
|
98
|
+
return new Promise((resolve, reject) => {
|
|
99
|
+
const timeout = setTimeout(() => {
|
|
100
|
+
if (this.pending.has(id)) {
|
|
101
|
+
this.pending.delete(id);
|
|
102
|
+
reject(new Error(`Request timeout: ${method}`));
|
|
103
|
+
}
|
|
104
|
+
}, this.requestTimeout);
|
|
105
|
+
this.pending.set(id, {
|
|
106
|
+
resolve: resolve,
|
|
107
|
+
reject,
|
|
108
|
+
timeout,
|
|
109
|
+
});
|
|
110
|
+
this.send(message);
|
|
111
|
+
});
|
|
112
|
+
}
|
|
113
|
+
/**
|
|
114
|
+
* Send a notification (no response expected)
|
|
115
|
+
*/
|
|
116
|
+
notify(method, params) {
|
|
117
|
+
const message = {
|
|
118
|
+
jsonrpc: "2.0",
|
|
119
|
+
method,
|
|
120
|
+
params,
|
|
121
|
+
};
|
|
122
|
+
this.send(message);
|
|
123
|
+
}
|
|
124
|
+
send(message) {
|
|
125
|
+
if (!this.stdin) {
|
|
126
|
+
throw new Error("Not connected");
|
|
127
|
+
}
|
|
128
|
+
this.stdin.write(JSON.stringify(message) + "\n");
|
|
129
|
+
}
|
|
130
|
+
/**
|
|
131
|
+
* Close and cleanup
|
|
132
|
+
*/
|
|
133
|
+
close() {
|
|
134
|
+
for (const [, pending] of this.pending) {
|
|
135
|
+
clearTimeout(pending.timeout);
|
|
136
|
+
pending.reject(new Error("Connection closed"));
|
|
137
|
+
}
|
|
138
|
+
this.pending.clear();
|
|
139
|
+
this.buffer = "";
|
|
140
|
+
this.stdin = undefined;
|
|
141
|
+
this.stdout?.removeAllListeners();
|
|
142
|
+
this.stdout = undefined;
|
|
143
|
+
}
|
|
144
|
+
}
|
|
145
|
+
//# sourceMappingURL=jsonrpc.js.map
|