@aria-cli/tools 1.0.8 → 1.0.10
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/package.json +9 -6
- package/dist-cjs/.tsbuildinfo +0 -1
- package/dist-cjs/ask-user-interaction.d.ts +0 -10
- package/dist-cjs/ask-user-interaction.js +0 -28
- package/dist-cjs/ask-user-interaction.js.map +0 -1
- package/dist-cjs/cache/web-cache.d.ts +0 -52
- package/dist-cjs/cache/web-cache.js +0 -71
- package/dist-cjs/cache/web-cache.js.map +0 -1
- package/dist-cjs/definitions/arion.d.ts +0 -8
- package/dist-cjs/definitions/arion.js +0 -108
- package/dist-cjs/definitions/arion.js.map +0 -1
- package/dist-cjs/definitions/browser/browser.d.ts +0 -2
- package/dist-cjs/definitions/browser/browser.js +0 -422
- package/dist-cjs/definitions/browser/browser.js.map +0 -1
- package/dist-cjs/definitions/browser/index.d.ts +0 -1
- package/dist-cjs/definitions/browser/index.js +0 -9
- package/dist-cjs/definitions/browser/index.js.map +0 -1
- package/dist-cjs/definitions/browser/pw-downloads.d.ts +0 -13
- package/dist-cjs/definitions/browser/pw-downloads.js +0 -118
- package/dist-cjs/definitions/browser/pw-downloads.js.map +0 -1
- package/dist-cjs/definitions/browser/pw-interactions.d.ts +0 -78
- package/dist-cjs/definitions/browser/pw-interactions.js +0 -214
- package/dist-cjs/definitions/browser/pw-interactions.js.map +0 -1
- package/dist-cjs/definitions/browser/pw-responses.d.ts +0 -28
- package/dist-cjs/definitions/browser/pw-responses.js +0 -85
- package/dist-cjs/definitions/browser/pw-responses.js.map +0 -1
- package/dist-cjs/definitions/browser/pw-session.d.ts +0 -65
- package/dist-cjs/definitions/browser/pw-session.js +0 -327
- package/dist-cjs/definitions/browser/pw-session.js.map +0 -1
- package/dist-cjs/definitions/browser/pw-shared.d.ts +0 -22
- package/dist-cjs/definitions/browser/pw-shared.js +0 -73
- package/dist-cjs/definitions/browser/pw-shared.js.map +0 -1
- package/dist-cjs/definitions/browser/pw-snapshot.d.ts +0 -34
- package/dist-cjs/definitions/browser/pw-snapshot.js +0 -308
- package/dist-cjs/definitions/browser/pw-snapshot.js.map +0 -1
- package/dist-cjs/definitions/browser/pw-state.d.ts +0 -22
- package/dist-cjs/definitions/browser/pw-state.js +0 -71
- package/dist-cjs/definitions/browser/pw-state.js.map +0 -1
- package/dist-cjs/definitions/browser/types.d.ts +0 -277
- package/dist-cjs/definitions/browser/types.js +0 -6
- package/dist-cjs/definitions/browser/types.js.map +0 -1
- package/dist-cjs/definitions/code-intelligence.d.ts +0 -8
- package/dist-cjs/definitions/code-intelligence.js +0 -474
- package/dist-cjs/definitions/code-intelligence.js.map +0 -1
- package/dist-cjs/definitions/core.d.ts +0 -47
- package/dist-cjs/definitions/core.js +0 -134
- package/dist-cjs/definitions/core.js.map +0 -1
- package/dist-cjs/definitions/delegation.d.ts +0 -11
- package/dist-cjs/definitions/delegation.js +0 -516
- package/dist-cjs/definitions/delegation.js.map +0 -1
- package/dist-cjs/definitions/deploy.d.ts +0 -15
- package/dist-cjs/definitions/deploy.js +0 -69
- package/dist-cjs/definitions/deploy.js.map +0 -1
- package/dist-cjs/definitions/filesystem.d.ts +0 -9
- package/dist-cjs/definitions/filesystem.js +0 -200
- package/dist-cjs/definitions/filesystem.js.map +0 -1
- package/dist-cjs/definitions/frg.d.ts +0 -3
- package/dist-cjs/definitions/frg.js +0 -67
- package/dist-cjs/definitions/frg.js.map +0 -1
- package/dist-cjs/definitions/index.d.ts +0 -19
- package/dist-cjs/definitions/index.js +0 -44
- package/dist-cjs/definitions/index.js.map +0 -1
- package/dist-cjs/definitions/memory.d.ts +0 -8
- package/dist-cjs/definitions/memory.js +0 -127
- package/dist-cjs/definitions/memory.js.map +0 -1
- package/dist-cjs/definitions/messaging.d.ts +0 -11
- package/dist-cjs/definitions/messaging.js +0 -632
- package/dist-cjs/definitions/messaging.js.map +0 -1
- package/dist-cjs/definitions/meta.d.ts +0 -11
- package/dist-cjs/definitions/meta.js +0 -353
- package/dist-cjs/definitions/meta.js.map +0 -1
- package/dist-cjs/definitions/network.d.ts +0 -11
- package/dist-cjs/definitions/network.js +0 -163
- package/dist-cjs/definitions/network.js.map +0 -1
- package/dist-cjs/definitions/outlook.d.ts +0 -2
- package/dist-cjs/definitions/outlook.js +0 -281
- package/dist-cjs/definitions/outlook.js.map +0 -1
- package/dist-cjs/definitions/patch/apply-patch.d.ts +0 -11
- package/dist-cjs/definitions/patch/apply-patch.js +0 -192
- package/dist-cjs/definitions/patch/apply-patch.js.map +0 -1
- package/dist-cjs/definitions/patch/fuzzy-match.d.ts +0 -10
- package/dist-cjs/definitions/patch/fuzzy-match.js +0 -173
- package/dist-cjs/definitions/patch/fuzzy-match.js.map +0 -1
- package/dist-cjs/definitions/patch/index.d.ts +0 -1
- package/dist-cjs/definitions/patch/index.js +0 -6
- package/dist-cjs/definitions/patch/index.js.map +0 -1
- package/dist-cjs/definitions/patch/patch-parser.d.ts +0 -50
- package/dist-cjs/definitions/patch/patch-parser.js +0 -216
- package/dist-cjs/definitions/patch/patch-parser.js.map +0 -1
- package/dist-cjs/definitions/patch/sandbox-paths.d.ts +0 -18
- package/dist-cjs/definitions/patch/sandbox-paths.js +0 -114
- package/dist-cjs/definitions/patch/sandbox-paths.js.map +0 -1
- package/dist-cjs/definitions/process/index.d.ts +0 -1
- package/dist-cjs/definitions/process/index.js +0 -9
- package/dist-cjs/definitions/process/index.js.map +0 -1
- package/dist-cjs/definitions/process/process-registry.d.ts +0 -67
- package/dist-cjs/definitions/process/process-registry.js +0 -232
- package/dist-cjs/definitions/process/process-registry.js.map +0 -1
- package/dist-cjs/definitions/process/process.d.ts +0 -9
- package/dist-cjs/definitions/process/process.js +0 -390
- package/dist-cjs/definitions/process/process.js.map +0 -1
- package/dist-cjs/definitions/process/pty-keys.d.ts +0 -13
- package/dist-cjs/definitions/process/pty-keys.js +0 -260
- package/dist-cjs/definitions/process/pty-keys.js.map +0 -1
- package/dist-cjs/definitions/process/session-slug.d.ts +0 -1
- package/dist-cjs/definitions/process/session-slug.js +0 -146
- package/dist-cjs/definitions/process/session-slug.js.map +0 -1
- package/dist-cjs/definitions/quip.d.ts +0 -2
- package/dist-cjs/definitions/quip.js +0 -199
- package/dist-cjs/definitions/quip.js.map +0 -1
- package/dist-cjs/definitions/search.d.ts +0 -9
- package/dist-cjs/definitions/search.js +0 -64
- package/dist-cjs/definitions/search.js.map +0 -1
- package/dist-cjs/definitions/session-history.d.ts +0 -11
- package/dist-cjs/definitions/session-history.js +0 -73
- package/dist-cjs/definitions/session-history.js.map +0 -1
- package/dist-cjs/definitions/shell.d.ts +0 -8
- package/dist-cjs/definitions/shell.js +0 -185
- package/dist-cjs/definitions/shell.js.map +0 -1
- package/dist-cjs/definitions/slack.d.ts +0 -2
- package/dist-cjs/definitions/slack.js +0 -184
- package/dist-cjs/definitions/slack.js.map +0 -1
- package/dist-cjs/definitions/web.d.ts +0 -8
- package/dist-cjs/definitions/web.js +0 -113
- package/dist-cjs/definitions/web.js.map +0 -1
- package/dist-cjs/executors/apply-patch.d.ts +0 -51
- package/dist-cjs/executors/apply-patch.js +0 -939
- package/dist-cjs/executors/apply-patch.js.map +0 -1
- package/dist-cjs/executors/arion.d.ts +0 -50
- package/dist-cjs/executors/arion.js +0 -126
- package/dist-cjs/executors/arion.js.map +0 -1
- package/dist-cjs/executors/code-intelligence.d.ts +0 -138
- package/dist-cjs/executors/code-intelligence.js +0 -926
- package/dist-cjs/executors/code-intelligence.js.map +0 -1
- package/dist-cjs/executors/deploy.d.ts +0 -169
- package/dist-cjs/executors/deploy.js +0 -870
- package/dist-cjs/executors/deploy.js.map +0 -1
- package/dist-cjs/executors/filesystem.d.ts +0 -150
- package/dist-cjs/executors/filesystem.js +0 -1168
- package/dist-cjs/executors/filesystem.js.map +0 -1
- package/dist-cjs/executors/frg-freshness.d.ts +0 -93
- package/dist-cjs/executors/frg-freshness.js +0 -628
- package/dist-cjs/executors/frg-freshness.js.map +0 -1
- package/dist-cjs/executors/frg.d.ts +0 -27
- package/dist-cjs/executors/frg.js +0 -335
- package/dist-cjs/executors/frg.js.map +0 -1
- package/dist-cjs/executors/index.d.ts +0 -44
- package/dist-cjs/executors/index.js +0 -144
- package/dist-cjs/executors/index.js.map +0 -1
- package/dist-cjs/executors/learning-meta.d.ts +0 -87
- package/dist-cjs/executors/learning-meta.js +0 -1166
- package/dist-cjs/executors/learning-meta.js.map +0 -1
- package/dist-cjs/executors/lsp-client.d.ts +0 -38
- package/dist-cjs/executors/lsp-client.js +0 -311
- package/dist-cjs/executors/lsp-client.js.map +0 -1
- package/dist-cjs/executors/memory.d.ts +0 -203
- package/dist-cjs/executors/memory.js +0 -797
- package/dist-cjs/executors/memory.js.map +0 -1
- package/dist-cjs/executors/meta.d.ts +0 -73
- package/dist-cjs/executors/meta.js +0 -227
- package/dist-cjs/executors/meta.js.map +0 -1
- package/dist-cjs/executors/process-registry.d.ts +0 -98
- package/dist-cjs/executors/process-registry.js +0 -470
- package/dist-cjs/executors/process-registry.js.map +0 -1
- package/dist-cjs/executors/pty-session-store.d.ts +0 -14
- package/dist-cjs/executors/pty-session-store.js +0 -35
- package/dist-cjs/executors/pty-session-store.js.map +0 -1
- package/dist-cjs/executors/pty.d.ts +0 -133
- package/dist-cjs/executors/pty.js +0 -313
- package/dist-cjs/executors/pty.js.map +0 -1
- package/dist-cjs/executors/restart.d.ts +0 -13
- package/dist-cjs/executors/restart.js +0 -156
- package/dist-cjs/executors/restart.js.map +0 -1
- package/dist-cjs/executors/search-freshness.d.ts +0 -50
- package/dist-cjs/executors/search-freshness.js +0 -235
- package/dist-cjs/executors/search-freshness.js.map +0 -1
- package/dist-cjs/executors/search-types.d.ts +0 -52
- package/dist-cjs/executors/search-types.js +0 -57
- package/dist-cjs/executors/search-types.js.map +0 -1
- package/dist-cjs/executors/search.d.ts +0 -11
- package/dist-cjs/executors/search.js +0 -103
- package/dist-cjs/executors/search.js.map +0 -1
- package/dist-cjs/executors/self-diagnose.d.ts +0 -89
- package/dist-cjs/executors/self-diagnose.js +0 -435
- package/dist-cjs/executors/self-diagnose.js.map +0 -1
- package/dist-cjs/executors/session-history.d.ts +0 -75
- package/dist-cjs/executors/session-history.js +0 -321
- package/dist-cjs/executors/session-history.js.map +0 -1
- package/dist-cjs/executors/shell-safety.d.ts +0 -27
- package/dist-cjs/executors/shell-safety.js +0 -479
- package/dist-cjs/executors/shell-safety.js.map +0 -1
- package/dist-cjs/executors/shell.d.ts +0 -168
- package/dist-cjs/executors/shell.js +0 -1002
- package/dist-cjs/executors/shell.js.map +0 -1
- package/dist-cjs/executors/utils.d.ts +0 -20
- package/dist-cjs/executors/utils.js +0 -74
- package/dist-cjs/executors/utils.js.map +0 -1
- package/dist-cjs/executors/web.d.ts +0 -89
- package/dist-cjs/executors/web.js +0 -548
- package/dist-cjs/executors/web.js.map +0 -1
- package/dist-cjs/extraction/content-extraction.d.ts +0 -48
- package/dist-cjs/extraction/content-extraction.js +0 -244
- package/dist-cjs/extraction/content-extraction.js.map +0 -1
- package/dist-cjs/extraction/index.d.ts +0 -4
- package/dist-cjs/extraction/index.js +0 -9
- package/dist-cjs/extraction/index.js.map +0 -1
- package/dist-cjs/headless-control-contract.d.ts +0 -3182
- package/dist-cjs/headless-control-contract.js +0 -973
- package/dist-cjs/headless-control-contract.js.map +0 -1
- package/dist-cjs/index.d.ts +0 -62
- package/dist-cjs/index.js +0 -438
- package/dist-cjs/index.js.map +0 -1
- package/dist-cjs/local-control-http-auth.d.ts +0 -2
- package/dist-cjs/local-control-http-auth.js +0 -6
- package/dist-cjs/local-control-http-auth.js.map +0 -1
- package/dist-cjs/mcp/client.d.ts +0 -68
- package/dist-cjs/mcp/client.js +0 -186
- package/dist-cjs/mcp/client.js.map +0 -1
- package/dist-cjs/mcp/connection.d.ts +0 -54
- package/dist-cjs/mcp/connection.js +0 -485
- package/dist-cjs/mcp/connection.js.map +0 -1
- package/dist-cjs/mcp/index.d.ts +0 -10
- package/dist-cjs/mcp/index.js +0 -31
- package/dist-cjs/mcp/index.js.map +0 -1
- package/dist-cjs/mcp/jsonrpc.d.ts +0 -36
- package/dist-cjs/mcp/jsonrpc.js +0 -149
- package/dist-cjs/mcp/jsonrpc.js.map +0 -1
- package/dist-cjs/mcp/types.d.ts +0 -178
- package/dist-cjs/mcp/types.js +0 -9
- package/dist-cjs/mcp/types.js.map +0 -1
- package/dist-cjs/network-control-adapter.d.ts +0 -4
- package/dist-cjs/network-control-adapter.js +0 -78
- package/dist-cjs/network-control-adapter.js.map +0 -1
- package/dist-cjs/network-runtime/address-types.d.ts +0 -201
- package/dist-cjs/network-runtime/address-types.js +0 -169
- package/dist-cjs/network-runtime/address-types.js.map +0 -1
- package/dist-cjs/network-runtime/db-owner-fencing.d.ts +0 -43
- package/dist-cjs/network-runtime/db-owner-fencing.js +0 -77
- package/dist-cjs/network-runtime/db-owner-fencing.js.map +0 -1
- package/dist-cjs/network-runtime/delivery-receipts.d.ts +0 -117
- package/dist-cjs/network-runtime/delivery-receipts.js +0 -277
- package/dist-cjs/network-runtime/delivery-receipts.js.map +0 -1
- package/dist-cjs/network-runtime/direct-endpoint-authority.d.ts +0 -8
- package/dist-cjs/network-runtime/direct-endpoint-authority.js +0 -30
- package/dist-cjs/network-runtime/direct-endpoint-authority.js.map +0 -1
- package/dist-cjs/network-runtime/index.d.ts +0 -24
- package/dist-cjs/network-runtime/index.js +0 -173
- package/dist-cjs/network-runtime/index.js.map +0 -1
- package/dist-cjs/network-runtime/local-control-contract.d.ts +0 -758
- package/dist-cjs/network-runtime/local-control-contract.js +0 -634
- package/dist-cjs/network-runtime/local-control-contract.js.map +0 -1
- package/dist-cjs/network-runtime/node-store-contract.d.ts +0 -49
- package/dist-cjs/network-runtime/node-store-contract.js +0 -39
- package/dist-cjs/network-runtime/node-store-contract.js.map +0 -1
- package/dist-cjs/network-runtime/pair-route-contract.d.ts +0 -100
- package/dist-cjs/network-runtime/pair-route-contract.js +0 -81
- package/dist-cjs/network-runtime/pair-route-contract.js.map +0 -1
- package/dist-cjs/network-runtime/peer-capabilities.d.ts +0 -10
- package/dist-cjs/network-runtime/peer-capabilities.js +0 -38
- package/dist-cjs/network-runtime/peer-capabilities.js.map +0 -1
- package/dist-cjs/network-runtime/peer-principal-ref.d.ts +0 -9
- package/dist-cjs/network-runtime/peer-principal-ref.js +0 -16
- package/dist-cjs/network-runtime/peer-principal-ref.js.map +0 -1
- package/dist-cjs/network-runtime/peer-state-machine.d.ts +0 -70
- package/dist-cjs/network-runtime/peer-state-machine.js +0 -130
- package/dist-cjs/network-runtime/peer-state-machine.js.map +0 -1
- package/dist-cjs/network-runtime/protocol-schemas.d.ts +0 -328
- package/dist-cjs/network-runtime/protocol-schemas.js +0 -213
- package/dist-cjs/network-runtime/protocol-schemas.js.map +0 -1
- package/dist-cjs/network-runtime/runtime-bootstrap-contract.d.ts +0 -81
- package/dist-cjs/network-runtime/runtime-bootstrap-contract.js +0 -64
- package/dist-cjs/network-runtime/runtime-bootstrap-contract.js.map +0 -1
- package/dist-cjs/outlook/desktop-session.d.ts +0 -68
- package/dist-cjs/outlook/desktop-session.js +0 -319
- package/dist-cjs/outlook/desktop-session.js.map +0 -1
- package/dist-cjs/package.json +0 -3
- package/dist-cjs/policy.d.ts +0 -43
- package/dist-cjs/policy.js +0 -156
- package/dist-cjs/policy.js.map +0 -1
- package/dist-cjs/providers/brave.d.ts +0 -10
- package/dist-cjs/providers/brave.js +0 -67
- package/dist-cjs/providers/brave.js.map +0 -1
- package/dist-cjs/providers/duckduckgo.d.ts +0 -18
- package/dist-cjs/providers/duckduckgo.js +0 -181
- package/dist-cjs/providers/duckduckgo.js.map +0 -1
- package/dist-cjs/providers/exa.d.ts +0 -10
- package/dist-cjs/providers/exa.js +0 -68
- package/dist-cjs/providers/exa.js.map +0 -1
- package/dist-cjs/providers/firecrawl.d.ts +0 -10
- package/dist-cjs/providers/firecrawl.js +0 -60
- package/dist-cjs/providers/firecrawl.js.map +0 -1
- package/dist-cjs/providers/index.d.ts +0 -8
- package/dist-cjs/providers/index.js +0 -18
- package/dist-cjs/providers/index.js.map +0 -1
- package/dist-cjs/providers/jina.d.ts +0 -10
- package/dist-cjs/providers/jina.js +0 -54
- package/dist-cjs/providers/jina.js.map +0 -1
- package/dist-cjs/providers/router.d.ts +0 -21
- package/dist-cjs/providers/router.js +0 -101
- package/dist-cjs/providers/router.js.map +0 -1
- package/dist-cjs/providers/search-provider.d.ts +0 -35
- package/dist-cjs/providers/search-provider.js +0 -37
- package/dist-cjs/providers/search-provider.js.map +0 -1
- package/dist-cjs/providers/tavily.d.ts +0 -10
- package/dist-cjs/providers/tavily.js +0 -59
- package/dist-cjs/providers/tavily.js.map +0 -1
- package/dist-cjs/quip/desktop-session.d.ts +0 -69
- package/dist-cjs/quip/desktop-session.js +0 -354
- package/dist-cjs/quip/desktop-session.js.map +0 -1
- package/dist-cjs/registry/index.d.ts +0 -1
- package/dist-cjs/registry/index.js +0 -7
- package/dist-cjs/registry/index.js.map +0 -1
- package/dist-cjs/registry/registry.d.ts +0 -156
- package/dist-cjs/registry/registry.js +0 -762
- package/dist-cjs/registry/registry.js.map +0 -1
- package/dist-cjs/runtime-socket-local-control-client.d.ts +0 -10
- package/dist-cjs/runtime-socket-local-control-client.js +0 -368
- package/dist-cjs/runtime-socket-local-control-client.js.map +0 -1
- package/dist-cjs/security/dns-normalization.d.ts +0 -6
- package/dist-cjs/security/dns-normalization.js +0 -23
- package/dist-cjs/security/dns-normalization.js.map +0 -1
- package/dist-cjs/security/dns-pinning.d.ts +0 -27
- package/dist-cjs/security/dns-pinning.js +0 -161
- package/dist-cjs/security/dns-pinning.js.map +0 -1
- package/dist-cjs/security/external-content.d.ts +0 -40
- package/dist-cjs/security/external-content.js +0 -96
- package/dist-cjs/security/external-content.js.map +0 -1
- package/dist-cjs/security/ssrf.d.ts +0 -40
- package/dist-cjs/security/ssrf.js +0 -222
- package/dist-cjs/security/ssrf.js.map +0 -1
- package/dist-cjs/slack/desktop-session.d.ts +0 -69
- package/dist-cjs/slack/desktop-session.js +0 -367
- package/dist-cjs/slack/desktop-session.js.map +0 -1
- package/dist-cjs/tool-factory.d.ts +0 -46
- package/dist-cjs/tool-factory.js +0 -51
- package/dist-cjs/tool-factory.js.map +0 -1
- package/dist-cjs/types.d.ts +0 -1192
- package/dist-cjs/types.js +0 -9
- package/dist-cjs/types.js.map +0 -1
- package/dist-cjs/utils/retry.d.ts +0 -11
- package/dist-cjs/utils/retry.js +0 -170
- package/dist-cjs/utils/retry.js.map +0 -1
- package/dist-cjs/utils/safe-parse-json.d.ts +0 -26
- package/dist-cjs/utils/safe-parse-json.js +0 -165
- package/dist-cjs/utils/safe-parse-json.js.map +0 -1
- package/dist-cjs/utils/url.d.ts +0 -10
- package/dist-cjs/utils/url.js +0 -24
- package/dist-cjs/utils/url.js.map +0 -1
- package/src/__tests__/web-fetch-download.test.ts +0 -433
- package/src/__tests__/web-tools.test.ts +0 -619
- package/src/ask-user-interaction.ts +0 -33
- package/src/cache/web-cache.ts +0 -110
- package/src/definitions/arion.ts +0 -118
- package/src/definitions/browser/browser.ts +0 -502
- package/src/definitions/browser/index.ts +0 -5
- package/src/definitions/browser/pw-downloads.ts +0 -142
- package/src/definitions/browser/pw-interactions.ts +0 -282
- package/src/definitions/browser/pw-responses.ts +0 -98
- package/src/definitions/browser/pw-session.ts +0 -405
- package/src/definitions/browser/pw-shared.ts +0 -85
- package/src/definitions/browser/pw-snapshot.ts +0 -383
- package/src/definitions/browser/pw-state.ts +0 -101
- package/src/definitions/browser/types.ts +0 -203
- package/src/definitions/code-intelligence.ts +0 -526
- package/src/definitions/core.ts +0 -118
- package/src/definitions/delegation.ts +0 -567
- package/src/definitions/deploy.ts +0 -73
- package/src/definitions/filesystem.ts +0 -217
- package/src/definitions/frg.ts +0 -67
- package/src/definitions/index.ts +0 -28
- package/src/definitions/memory.ts +0 -150
- package/src/definitions/messaging.ts +0 -734
- package/src/definitions/meta.ts +0 -392
- package/src/definitions/network.ts +0 -179
- package/src/definitions/outlook.ts +0 -318
- package/src/definitions/patch/apply-patch.ts +0 -235
- package/src/definitions/patch/fuzzy-match.ts +0 -217
- package/src/definitions/patch/index.ts +0 -1
- package/src/definitions/patch/patch-parser.ts +0 -297
- package/src/definitions/patch/sandbox-paths.ts +0 -129
- package/src/definitions/process/index.ts +0 -5
- package/src/definitions/process/process-registry.ts +0 -303
- package/src/definitions/process/process.ts +0 -456
- package/src/definitions/process/pty-keys.ts +0 -298
- package/src/definitions/process/session-slug.ts +0 -147
- package/src/definitions/quip.ts +0 -225
- package/src/definitions/search.ts +0 -67
- package/src/definitions/session-history.ts +0 -79
- package/src/definitions/shell.ts +0 -202
- package/src/definitions/slack.ts +0 -211
- package/src/definitions/web.ts +0 -119
- package/src/executors/apply-patch.ts +0 -1035
- package/src/executors/arion.ts +0 -199
- package/src/executors/code-intelligence.ts +0 -1179
- package/src/executors/deploy.ts +0 -1066
- package/src/executors/filesystem.ts +0 -1428
- package/src/executors/frg-freshness.ts +0 -743
- package/src/executors/frg.ts +0 -394
- package/src/executors/index.ts +0 -280
- package/src/executors/learning-meta.ts +0 -1367
- package/src/executors/lsp-client.ts +0 -355
- package/src/executors/memory.ts +0 -978
- package/src/executors/meta.ts +0 -293
- package/src/executors/process-registry.ts +0 -570
- package/src/executors/pty-session-store.ts +0 -43
- package/src/executors/pty.ts +0 -342
- package/src/executors/restart.ts +0 -133
- package/src/executors/search-freshness.ts +0 -249
- package/src/executors/search-types.ts +0 -98
- package/src/executors/search.ts +0 -89
- package/src/executors/self-diagnose.ts +0 -552
- package/src/executors/session-history.ts +0 -435
- package/src/executors/shell-safety.ts +0 -519
- package/src/executors/shell.ts +0 -1243
- package/src/executors/utils.ts +0 -40
- package/src/executors/web.ts +0 -786
- package/src/extraction/content-extraction.ts +0 -281
- package/src/extraction/index.ts +0 -5
- package/src/headless-control-contract.ts +0 -1149
- package/src/index.ts +0 -788
- package/src/local-control-http-auth.ts +0 -2
- package/src/mcp/client.ts +0 -218
- package/src/mcp/connection.ts +0 -568
- package/src/mcp/index.ts +0 -11
- package/src/mcp/jsonrpc.ts +0 -195
- package/src/mcp/types.ts +0 -199
- package/src/network-control-adapter.ts +0 -88
- package/src/network-runtime/address-types.ts +0 -218
- package/src/network-runtime/db-owner-fencing.ts +0 -91
- package/src/network-runtime/delivery-receipts.ts +0 -372
- package/src/network-runtime/direct-endpoint-authority.ts +0 -35
- package/src/network-runtime/index.ts +0 -316
- package/src/network-runtime/local-control-contract.ts +0 -784
- package/src/network-runtime/node-store-contract.ts +0 -46
- package/src/network-runtime/pair-route-contract.ts +0 -97
- package/src/network-runtime/peer-capabilities.ts +0 -48
- package/src/network-runtime/peer-principal-ref.ts +0 -20
- package/src/network-runtime/peer-state-machine.ts +0 -160
- package/src/network-runtime/protocol-schemas.ts +0 -265
- package/src/network-runtime/runtime-bootstrap-contract.ts +0 -83
- package/src/outlook/desktop-session.ts +0 -409
- package/src/policy.ts +0 -171
- package/src/providers/brave.ts +0 -80
- package/src/providers/duckduckgo.ts +0 -199
- package/src/providers/exa.ts +0 -85
- package/src/providers/firecrawl.ts +0 -77
- package/src/providers/index.ts +0 -8
- package/src/providers/jina.ts +0 -70
- package/src/providers/router.ts +0 -121
- package/src/providers/search-provider.ts +0 -74
- package/src/providers/tavily.ts +0 -74
- package/src/quip/desktop-session.ts +0 -435
- package/src/registry/index.ts +0 -1
- package/src/registry/registry.ts +0 -905
- package/src/runtime-socket-local-control-client.ts +0 -632
- package/src/security/dns-normalization.ts +0 -34
- package/src/security/dns-pinning.ts +0 -138
- package/src/security/external-content.ts +0 -129
- package/src/security/ssrf.ts +0 -207
- package/src/slack/desktop-session.ts +0 -493
- package/src/tool-factory.ts +0 -91
- package/src/types.ts +0 -1341
- package/src/utils/retry.ts +0 -163
- package/src/utils/safe-parse-json.ts +0 -176
- package/src/utils/url.ts +0 -20
- package/tests/benchmarks/registry.bench.ts +0 -57
- package/tests/cache/web-cache.test.ts +0 -147
- package/tests/critical-integration.test.ts +0 -1465
- package/tests/definitions/apply-patch.test.ts +0 -586
- package/tests/definitions/browser.test.ts +0 -495
- package/tests/definitions/delegation-pause-resume.test.ts +0 -758
- package/tests/definitions/execution.test.ts +0 -671
- package/tests/definitions/messaging-inbox-scope.test.ts +0 -229
- package/tests/definitions/messaging.test.ts +0 -1468
- package/tests/definitions/outlook.test.ts +0 -30
- package/tests/definitions/process.test.ts +0 -469
- package/tests/definitions/slack.test.ts +0 -28
- package/tests/definitions/tool-inventory.test.ts +0 -218
- package/tests/e2e/delegation-quest-orchestration.e2e.test.ts +0 -433
- package/tests/e2e/memory-tool-discovery-contract.e2e.test.ts +0 -81
- package/tests/executors/apply-patch.test.ts +0 -538
- package/tests/executors/arion.test.ts +0 -309
- package/tests/executors/conversation-primitives.test.ts +0 -250
- package/tests/executors/deploy.test.ts +0 -746
- package/tests/executors/filesystem-tools.test.ts +0 -357
- package/tests/executors/filesystem.test.ts +0 -959
- package/tests/executors/frg-freshness.test.ts +0 -136
- package/tests/executors/frg-merge.test.ts +0 -70
- package/tests/executors/frg-session-content.test.ts +0 -40
- package/tests/executors/frg.test.ts +0 -56
- package/tests/executors/memory-bugfixes.test.ts +0 -257
- package/tests/executors/memory-real-memoria.integration.test.ts +0 -316
- package/tests/executors/memory.test.ts +0 -853
- package/tests/executors/meta-tools.test.ts +0 -411
- package/tests/executors/meta.test.ts +0 -683
- package/tests/executors/path-containment.test.ts +0 -51
- package/tests/executors/process-registry.test.ts +0 -505
- package/tests/executors/pty.test.ts +0 -664
- package/tests/executors/quest-security.test.ts +0 -249
- package/tests/executors/read-file-media.test.ts +0 -230
- package/tests/executors/recall-knowledge-schema.test.ts +0 -209
- package/tests/executors/recall-tags.test.ts +0 -278
- package/tests/executors/remember-null-safety.contract.test.ts +0 -41
- package/tests/executors/restart.test.ts +0 -67
- package/tests/executors/search-unified.test.ts +0 -381
- package/tests/executors/session-history.test.ts +0 -340
- package/tests/executors/session-transcript.test.ts +0 -561
- package/tests/executors/shell-abort.test.ts +0 -416
- package/tests/executors/shell-env-blocklist.test.ts +0 -648
- package/tests/executors/shell-env-process.test.ts +0 -245
- package/tests/executors/shell-process-registry.test.ts +0 -334
- package/tests/executors/shell-tools.test.ts +0 -393
- package/tests/executors/shell.test.ts +0 -690
- package/tests/executors/web-abort-vs-timeout.test.ts +0 -213
- package/tests/executors/web-integration.test.ts +0 -633
- package/tests/executors/web-symlink.test.ts +0 -18
- package/tests/executors/web.test.ts +0 -1400
- package/tests/executors/write-stdin.test.ts +0 -145
- package/tests/extraction/content-extraction.test.ts +0 -153
- package/tests/guards/tools-default-test-lane.integration.test.ts +0 -21
- package/tests/guards/tools-package-test-commands.e2e.test.ts +0 -43
- package/tests/guards/tools-test-lane-manifest.contract.test.ts +0 -76
- package/tests/guards/tools-vitest-workspace-alias.contract.test.ts +0 -63
- package/tests/helpers/async-waits.ts +0 -53
- package/tests/integration/headless-control-contract.integration.test.ts +0 -153
- package/tests/integration/memory-tool-schema-parity.integration.test.ts +0 -67
- package/tests/integration/meta-tools-round-trip.integration.test.ts +0 -506
- package/tests/integration/quest-round-trip.test.ts +0 -303
- package/tests/integration/registry-executor-flow.test.ts +0 -85
- package/tests/integration.test.ts +0 -177
- package/tests/loading-tier.test.ts +0 -126
- package/tests/mcp/client-reconnect.test.ts +0 -267
- package/tests/mcp/connection.test.ts +0 -846
- package/tests/mcp/injectable-logger.test.ts +0 -83
- package/tests/mcp/jsonrpc.test.ts +0 -109
- package/tests/mcp/lifecycle.test.ts +0 -879
- package/tests/network-runtime/address-types.contract.test.ts +0 -143
- package/tests/network-runtime/continuity-bind-schema.contract.test.ts +0 -203
- package/tests/network-runtime/local-control-contract.test.ts +0 -869
- package/tests/network-runtime/local-control-invite-token.contract.test.ts +0 -146
- package/tests/network-runtime/node-store-contract.test.ts +0 -11
- package/tests/network-runtime/pair-protocol-nodeid.contract.test.ts +0 -15
- package/tests/network-runtime/peer-state-machine.contract.test.ts +0 -148
- package/tests/network-runtime/protocol-schemas.contract.test.ts +0 -512
- package/tests/network-runtime/relay-pending-nodeid.contract.test.ts +0 -62
- package/tests/network-runtime/runtime-bootstrap-contract.test.ts +0 -227
- package/tests/network-runtime/runtime-socket-local-control-client.test.ts +0 -621
- package/tests/network-runtime/wait-for-message-script.test.ts +0 -288
- package/tests/parallel.test.ts +0 -71
- package/tests/policy.test.ts +0 -184
- package/tests/print-default-test-lane.ts +0 -14
- package/tests/print-test-lane-manifest.ts +0 -22
- package/tests/providers/brave.test.ts +0 -159
- package/tests/providers/duckduckgo.test.ts +0 -207
- package/tests/providers/exa.test.ts +0 -175
- package/tests/providers/firecrawl.test.ts +0 -168
- package/tests/providers/jina.test.ts +0 -144
- package/tests/providers/router.test.ts +0 -328
- package/tests/providers/tavily.test.ts +0 -165
- package/tests/registry/discovery.test.ts +0 -154
- package/tests/registry/injectable-logger.test.ts +0 -230
- package/tests/registry/input-validation.test.ts +0 -361
- package/tests/registry/interface-completeness.test.ts +0 -85
- package/tests/registry/mcp-integration.test.ts +0 -103
- package/tests/registry/mcp-read-only-hint.test.ts +0 -60
- package/tests/registry/memoria-discovery.test.ts +0 -390
- package/tests/registry/nested-validation.test.ts +0 -283
- package/tests/registry/pseudo-tool-filtering.test.ts +0 -258
- package/tests/registry/registration-lifecycle.test.ts +0 -133
- package/tests/registry-validation.test.ts +0 -424
- package/tests/registry.test.ts +0 -460
- package/tests/security/dns-pinning.test.ts +0 -162
- package/tests/security/external-content.test.ts +0 -144
- package/tests/security/ssrf.test.ts +0 -118
- package/tests/shell-safety-integration.test.ts +0 -32
- package/tests/shell-safety.test.ts +0 -365
- package/tests/slack/desktop-session.test.ts +0 -50
- package/tests/test-lane-manifest.ts +0 -440
- package/tests/test-utils.ts +0 -27
- package/tests/tool-factory.test.ts +0 -188
- package/tests/utils/retry.test.ts +0 -231
- package/tests/utils/url.test.ts +0 -63
- package/tsconfig.cjs.json +0 -24
- package/tsconfig.json +0 -12
- package/vitest.config.ts +0 -55
- package/vitest.e2e.config.ts +0 -24
- package/vitest.integration.config.ts +0 -24
- package/vitest.native.config.ts +0 -24
|
@@ -1,318 +0,0 @@
|
|
|
1
|
-
import type { JSONSchema7 } from "json-schema";
|
|
2
|
-
import type { Tool } from "../types.js";
|
|
3
|
-
import { execFile } from "node:child_process";
|
|
4
|
-
import { homedir } from "node:os";
|
|
5
|
-
import { join } from "node:path";
|
|
6
|
-
|
|
7
|
-
const OUTLOOK_PY = join(homedir(), ".aria", "tools", "outlook.py");
|
|
8
|
-
|
|
9
|
-
function runOutlook(args: string[]): Promise<string> {
|
|
10
|
-
return new Promise((resolve, reject) => {
|
|
11
|
-
execFile(OUTLOOK_PY, args, { timeout: 30_000 }, (err, stdout, stderr) => {
|
|
12
|
-
if (err) {
|
|
13
|
-
reject(new Error(stderr?.trim() || err.message));
|
|
14
|
-
} else {
|
|
15
|
-
resolve(stdout);
|
|
16
|
-
}
|
|
17
|
-
});
|
|
18
|
-
});
|
|
19
|
-
}
|
|
20
|
-
|
|
21
|
-
function parseJson(raw: string): Record<string, unknown> {
|
|
22
|
-
try {
|
|
23
|
-
return JSON.parse(raw) as Record<string, unknown>;
|
|
24
|
-
} catch {
|
|
25
|
-
return { raw };
|
|
26
|
-
}
|
|
27
|
-
}
|
|
28
|
-
|
|
29
|
-
// PascalCase → camelCase field mapper for Outlook REST v2 responses
|
|
30
|
-
function normalizeMessage(msg: Record<string, unknown>): Record<string, unknown> {
|
|
31
|
-
const from = msg.From as Record<string, unknown> | undefined;
|
|
32
|
-
const emailAddr = from?.EmailAddress as Record<string, unknown> | undefined;
|
|
33
|
-
const toRaw = msg.ToRecipients as Array<Record<string, unknown>> | undefined;
|
|
34
|
-
const ccRaw = msg.CcRecipients as Array<Record<string, unknown>> | undefined;
|
|
35
|
-
const body = msg.Body as Record<string, unknown> | undefined;
|
|
36
|
-
|
|
37
|
-
const mapRecipient = (r: Record<string, unknown>) => {
|
|
38
|
-
const ea = r.EmailAddress as Record<string, unknown> | undefined;
|
|
39
|
-
return { name: ea?.Name ?? "", email: ea?.Address ?? "" };
|
|
40
|
-
};
|
|
41
|
-
|
|
42
|
-
return {
|
|
43
|
-
id: msg.Id ?? msg.id ?? "",
|
|
44
|
-
subject: msg.Subject ?? msg.subject ?? "",
|
|
45
|
-
from: emailAddr
|
|
46
|
-
? { name: emailAddr.Name ?? "", email: emailAddr.Address ?? "" }
|
|
47
|
-
: { name: "", email: "" },
|
|
48
|
-
toRecipients: toRaw?.map(mapRecipient) ?? [],
|
|
49
|
-
receivedDateTime: msg.ReceivedDateTime ?? msg.receivedDateTime ?? "",
|
|
50
|
-
isRead: msg.IsRead ?? msg.isRead ?? false,
|
|
51
|
-
hasAttachments: msg.HasAttachments ?? msg.hasAttachments ?? false,
|
|
52
|
-
bodyPreview: msg.BodyPreview ?? msg.bodyPreview ?? "",
|
|
53
|
-
conversationId: msg.ConversationId ?? msg.conversationId ?? "",
|
|
54
|
-
...(body
|
|
55
|
-
? {
|
|
56
|
-
body: {
|
|
57
|
-
contentType: body.ContentType ?? body.contentType ?? "text",
|
|
58
|
-
content: body.Content ?? body.content ?? "",
|
|
59
|
-
},
|
|
60
|
-
}
|
|
61
|
-
: {}),
|
|
62
|
-
...(ccRaw ? { ccRecipients: ccRaw.map(mapRecipient) } : {}),
|
|
63
|
-
importance: msg.Importance ?? msg.importance ?? "normal",
|
|
64
|
-
};
|
|
65
|
-
}
|
|
66
|
-
|
|
67
|
-
type CheckOutlookMessagesInput = {
|
|
68
|
-
folder?: string;
|
|
69
|
-
limit?: number;
|
|
70
|
-
filter?: string;
|
|
71
|
-
search?: string;
|
|
72
|
-
messageId?: string;
|
|
73
|
-
};
|
|
74
|
-
|
|
75
|
-
type SendOutlookMessageInput = {
|
|
76
|
-
to?: string | string[];
|
|
77
|
-
cc?: string | string[];
|
|
78
|
-
subject?: string;
|
|
79
|
-
body?: string;
|
|
80
|
-
bodyType?: "text" | "html";
|
|
81
|
-
};
|
|
82
|
-
|
|
83
|
-
type ReplyOutlookMessageInput = {
|
|
84
|
-
messageId?: string;
|
|
85
|
-
body?: string;
|
|
86
|
-
bodyType?: "text" | "html";
|
|
87
|
-
replyAll?: boolean;
|
|
88
|
-
};
|
|
89
|
-
|
|
90
|
-
const check_outlook_messages: Tool = {
|
|
91
|
-
name: "check_outlook_messages",
|
|
92
|
-
description:
|
|
93
|
-
"Read or search Outlook emails using the local Microsoft Office desktop session on this machine. " +
|
|
94
|
-
"Can list inbox messages, filter by read status, search by keyword, or retrieve a specific message by ID.",
|
|
95
|
-
category: "messaging",
|
|
96
|
-
parameters: {
|
|
97
|
-
type: "object",
|
|
98
|
-
properties: {
|
|
99
|
-
folder: {
|
|
100
|
-
type: "string",
|
|
101
|
-
description:
|
|
102
|
-
'Mail folder to read from (default "inbox"). Common values: inbox, drafts, sentitems, deleteditems.',
|
|
103
|
-
default: "inbox",
|
|
104
|
-
},
|
|
105
|
-
limit: {
|
|
106
|
-
type: "number",
|
|
107
|
-
description: "Maximum number of messages to return (default 20, max 50).",
|
|
108
|
-
default: 20,
|
|
109
|
-
},
|
|
110
|
-
filter: {
|
|
111
|
-
type: "string",
|
|
112
|
-
description:
|
|
113
|
-
'OData filter expression, e.g. "isRead eq false" or "from/emailAddress/address eq \'alice@example.com\'".',
|
|
114
|
-
},
|
|
115
|
-
search: {
|
|
116
|
-
type: "string",
|
|
117
|
-
description:
|
|
118
|
-
"KQL search query to find messages by keyword across subject, body, and participants.",
|
|
119
|
-
},
|
|
120
|
-
messageId: {
|
|
121
|
-
type: "string",
|
|
122
|
-
description:
|
|
123
|
-
"Optional message ID. When provided, returns the full message detail instead of a list.",
|
|
124
|
-
},
|
|
125
|
-
},
|
|
126
|
-
required: [],
|
|
127
|
-
} as JSONSchema7,
|
|
128
|
-
riskLevel: "safe",
|
|
129
|
-
isReadOnly: true,
|
|
130
|
-
loadingTier: "always",
|
|
131
|
-
execute: async (input: unknown) => {
|
|
132
|
-
const typedInput = input as CheckOutlookMessagesInput;
|
|
133
|
-
try {
|
|
134
|
-
if (typeof typedInput.messageId === "string" && typedInput.messageId) {
|
|
135
|
-
const raw = await runOutlook(["read", typedInput.messageId]);
|
|
136
|
-
const msg = normalizeMessage(parseJson(raw));
|
|
137
|
-
return {
|
|
138
|
-
success: true,
|
|
139
|
-
message: `Fetched Outlook message: ${msg.subject}`,
|
|
140
|
-
data: msg,
|
|
141
|
-
};
|
|
142
|
-
}
|
|
143
|
-
|
|
144
|
-
const args = ["check"];
|
|
145
|
-
const folder = typeof typedInput.folder === "string" ? typedInput.folder : "inbox";
|
|
146
|
-
args.push("--folder", folder);
|
|
147
|
-
args.push("--limit", String(typeof typedInput.limit === "number" ? typedInput.limit : 20));
|
|
148
|
-
if (typeof typedInput.filter === "string") args.push("--filter", typedInput.filter);
|
|
149
|
-
if (typeof typedInput.search === "string") args.push("--search", typedInput.search);
|
|
150
|
-
|
|
151
|
-
const raw = await runOutlook(args);
|
|
152
|
-
const json = parseJson(raw);
|
|
153
|
-
const rawMessages = Array.isArray(json.value) ? json.value : [];
|
|
154
|
-
const messages = rawMessages
|
|
155
|
-
.filter((m): m is Record<string, unknown> => !!m && typeof m === "object")
|
|
156
|
-
.map(normalizeMessage);
|
|
157
|
-
|
|
158
|
-
return {
|
|
159
|
-
success: true,
|
|
160
|
-
message: `Fetched ${messages.length} Outlook messages from ${folder}.`,
|
|
161
|
-
data: { accountEmail: "hole@axon.com", folder, messages, totalCount: messages.length },
|
|
162
|
-
};
|
|
163
|
-
} catch (error) {
|
|
164
|
-
return {
|
|
165
|
-
success: false,
|
|
166
|
-
message: error instanceof Error ? error.message : "Outlook read failed.",
|
|
167
|
-
};
|
|
168
|
-
}
|
|
169
|
-
},
|
|
170
|
-
};
|
|
171
|
-
|
|
172
|
-
const send_outlook_message: Tool = {
|
|
173
|
-
name: "send_outlook_message",
|
|
174
|
-
description:
|
|
175
|
-
"Send an email through the local Microsoft Office desktop session on this machine. " +
|
|
176
|
-
"Requires confirmation because it sends externally.",
|
|
177
|
-
category: "messaging",
|
|
178
|
-
parameters: {
|
|
179
|
-
type: "object",
|
|
180
|
-
properties: {
|
|
181
|
-
to: {
|
|
182
|
-
oneOf: [{ type: "string" }, { type: "array", items: { type: "string" } }],
|
|
183
|
-
description: "Recipient email address(es).",
|
|
184
|
-
},
|
|
185
|
-
cc: {
|
|
186
|
-
oneOf: [{ type: "string" }, { type: "array", items: { type: "string" } }],
|
|
187
|
-
description: "CC email address(es).",
|
|
188
|
-
},
|
|
189
|
-
subject: {
|
|
190
|
-
type: "string",
|
|
191
|
-
description: "Email subject line.",
|
|
192
|
-
},
|
|
193
|
-
body: {
|
|
194
|
-
type: "string",
|
|
195
|
-
description: "Email body content.",
|
|
196
|
-
},
|
|
197
|
-
bodyType: {
|
|
198
|
-
type: "string",
|
|
199
|
-
enum: ["text", "html"],
|
|
200
|
-
description: 'Body content type (default "text").',
|
|
201
|
-
default: "text",
|
|
202
|
-
},
|
|
203
|
-
},
|
|
204
|
-
required: ["to", "subject", "body"],
|
|
205
|
-
} as JSONSchema7,
|
|
206
|
-
riskLevel: "dangerous",
|
|
207
|
-
requiresConfirmation: true,
|
|
208
|
-
isReadOnly: false,
|
|
209
|
-
loadingTier: "always",
|
|
210
|
-
execute: async (input: unknown) => {
|
|
211
|
-
const typedInput = input as SendOutlookMessageInput;
|
|
212
|
-
try {
|
|
213
|
-
const toArray = Array.isArray(typedInput.to)
|
|
214
|
-
? typedInput.to
|
|
215
|
-
: typeof typedInput.to === "string"
|
|
216
|
-
? [typedInput.to]
|
|
217
|
-
: [];
|
|
218
|
-
|
|
219
|
-
const args = [
|
|
220
|
-
"send",
|
|
221
|
-
"--to",
|
|
222
|
-
toArray.join(","),
|
|
223
|
-
"--subject",
|
|
224
|
-
String(typedInput.subject ?? ""),
|
|
225
|
-
"--body",
|
|
226
|
-
String(typedInput.body ?? ""),
|
|
227
|
-
];
|
|
228
|
-
|
|
229
|
-
if (typedInput.cc) {
|
|
230
|
-
const ccArray = Array.isArray(typedInput.cc) ? typedInput.cc : [typedInput.cc];
|
|
231
|
-
args.push("--cc", ccArray.join(","));
|
|
232
|
-
}
|
|
233
|
-
if (typedInput.bodyType === "html") args.push("--html");
|
|
234
|
-
|
|
235
|
-
await runOutlook(args);
|
|
236
|
-
|
|
237
|
-
return {
|
|
238
|
-
success: true,
|
|
239
|
-
message: `Sent email to ${toArray.join(", ")}.`,
|
|
240
|
-
data: { status: "sent" },
|
|
241
|
-
};
|
|
242
|
-
} catch (error) {
|
|
243
|
-
return {
|
|
244
|
-
success: false,
|
|
245
|
-
message: error instanceof Error ? error.message : "Outlook send failed.",
|
|
246
|
-
};
|
|
247
|
-
}
|
|
248
|
-
},
|
|
249
|
-
};
|
|
250
|
-
|
|
251
|
-
const reply_outlook_message: Tool = {
|
|
252
|
-
name: "reply_outlook_message",
|
|
253
|
-
description:
|
|
254
|
-
"Reply to an Outlook email thread using the local Microsoft Office desktop session on this machine. " +
|
|
255
|
-
"Requires confirmation because it sends externally.",
|
|
256
|
-
category: "messaging",
|
|
257
|
-
parameters: {
|
|
258
|
-
type: "object",
|
|
259
|
-
properties: {
|
|
260
|
-
messageId: {
|
|
261
|
-
type: "string",
|
|
262
|
-
description: "The ID of the message to reply to.",
|
|
263
|
-
},
|
|
264
|
-
body: {
|
|
265
|
-
type: "string",
|
|
266
|
-
description: "Reply body content.",
|
|
267
|
-
},
|
|
268
|
-
bodyType: {
|
|
269
|
-
type: "string",
|
|
270
|
-
enum: ["text", "html"],
|
|
271
|
-
description: 'Body content type (default "text").',
|
|
272
|
-
default: "text",
|
|
273
|
-
},
|
|
274
|
-
replyAll: {
|
|
275
|
-
type: "boolean",
|
|
276
|
-
description: "Whether to reply to all recipients (default false — reply to sender only).",
|
|
277
|
-
default: false,
|
|
278
|
-
},
|
|
279
|
-
},
|
|
280
|
-
required: ["messageId", "body"],
|
|
281
|
-
} as JSONSchema7,
|
|
282
|
-
riskLevel: "dangerous",
|
|
283
|
-
requiresConfirmation: true,
|
|
284
|
-
isReadOnly: false,
|
|
285
|
-
loadingTier: "always",
|
|
286
|
-
execute: async (input: unknown) => {
|
|
287
|
-
const typedInput = input as ReplyOutlookMessageInput;
|
|
288
|
-
try {
|
|
289
|
-
const args = [
|
|
290
|
-
"reply",
|
|
291
|
-
String(typedInput.messageId ?? ""),
|
|
292
|
-
"--body",
|
|
293
|
-
String(typedInput.body ?? ""),
|
|
294
|
-
];
|
|
295
|
-
if (typedInput.replyAll) args.push("--reply-all");
|
|
296
|
-
if (typedInput.bodyType === "html") args.push("--html");
|
|
297
|
-
|
|
298
|
-
await runOutlook(args);
|
|
299
|
-
|
|
300
|
-
return {
|
|
301
|
-
success: true,
|
|
302
|
-
message: "Replied to message.",
|
|
303
|
-
data: { status: "sent" },
|
|
304
|
-
};
|
|
305
|
-
} catch (error) {
|
|
306
|
-
return {
|
|
307
|
-
success: false,
|
|
308
|
-
message: error instanceof Error ? error.message : "Outlook reply failed.",
|
|
309
|
-
};
|
|
310
|
-
}
|
|
311
|
-
},
|
|
312
|
-
};
|
|
313
|
-
|
|
314
|
-
export const OUTLOOK_TOOL_DEFINITIONS = [
|
|
315
|
-
check_outlook_messages,
|
|
316
|
-
send_outlook_message,
|
|
317
|
-
reply_outlook_message,
|
|
318
|
-
];
|
|
@@ -1,235 +0,0 @@
|
|
|
1
|
-
// Originally from OpenClaw (MIT License, Copyright 2025 Peter Steinberger)
|
|
2
|
-
// https://github.com/openclaw/openclaw
|
|
3
|
-
// Modified for ARIA — stripped OpenClaw runtime, rewired to ARIA Tool interface
|
|
4
|
-
|
|
5
|
-
import fs from "node:fs/promises";
|
|
6
|
-
import os from "node:os";
|
|
7
|
-
import path from "node:path";
|
|
8
|
-
import type { JSONSchema7 } from "json-schema";
|
|
9
|
-
import type { Tool } from "../../types.js";
|
|
10
|
-
import { parsePatchText, normalizeUnicodeSpaces } from "./patch-parser.js";
|
|
11
|
-
import type { Hunk, ApplyPatchSummary } from "./patch-parser.js";
|
|
12
|
-
import { applyUpdateHunk } from "./fuzzy-match.js";
|
|
13
|
-
import { assertSandboxPath } from "./sandbox-paths.js";
|
|
14
|
-
|
|
15
|
-
// ── Path Helpers ───────────────────────────────────────────────────
|
|
16
|
-
|
|
17
|
-
function expandPath(filePath: string): string {
|
|
18
|
-
const normalized = normalizeUnicodeSpaces(filePath);
|
|
19
|
-
if (normalized === "~") {
|
|
20
|
-
return os.homedir();
|
|
21
|
-
}
|
|
22
|
-
if (normalized.startsWith("~/")) {
|
|
23
|
-
return os.homedir() + normalized.slice(1);
|
|
24
|
-
}
|
|
25
|
-
return normalized;
|
|
26
|
-
}
|
|
27
|
-
|
|
28
|
-
function resolvePathFromCwd(filePath: string, cwd: string): string {
|
|
29
|
-
const expanded = expandPath(filePath);
|
|
30
|
-
if (path.isAbsolute(expanded)) {
|
|
31
|
-
return path.normalize(expanded);
|
|
32
|
-
}
|
|
33
|
-
return path.resolve(cwd, expanded);
|
|
34
|
-
}
|
|
35
|
-
|
|
36
|
-
function toDisplayPath(resolved: string, cwd: string): string {
|
|
37
|
-
const relative = path.relative(cwd, resolved);
|
|
38
|
-
if (!relative || relative === "") {
|
|
39
|
-
return path.basename(resolved);
|
|
40
|
-
}
|
|
41
|
-
if (relative.startsWith("..") || path.isAbsolute(relative)) {
|
|
42
|
-
return resolved;
|
|
43
|
-
}
|
|
44
|
-
return relative;
|
|
45
|
-
}
|
|
46
|
-
|
|
47
|
-
// ── Path Resolution with Sandbox Validation ────────────────────────
|
|
48
|
-
|
|
49
|
-
async function resolvePatchPath(
|
|
50
|
-
filePath: string,
|
|
51
|
-
cwd: string,
|
|
52
|
-
purpose: "readWrite" | "unlink" = "readWrite",
|
|
53
|
-
): Promise<{ resolved: string; display: string }> {
|
|
54
|
-
const resolved = (
|
|
55
|
-
await assertSandboxPath({
|
|
56
|
-
filePath,
|
|
57
|
-
cwd,
|
|
58
|
-
root: cwd,
|
|
59
|
-
allowFinalSymlink: purpose === "unlink",
|
|
60
|
-
})
|
|
61
|
-
).resolved;
|
|
62
|
-
return {
|
|
63
|
-
resolved,
|
|
64
|
-
display: toDisplayPath(resolved, cwd),
|
|
65
|
-
};
|
|
66
|
-
}
|
|
67
|
-
|
|
68
|
-
// ── Summary Helpers ────────────────────────────────────────────────
|
|
69
|
-
|
|
70
|
-
function recordSummary(
|
|
71
|
-
summary: ApplyPatchSummary,
|
|
72
|
-
seen: {
|
|
73
|
-
added: Set<string>;
|
|
74
|
-
modified: Set<string>;
|
|
75
|
-
deleted: Set<string>;
|
|
76
|
-
},
|
|
77
|
-
bucket: keyof ApplyPatchSummary,
|
|
78
|
-
value: string,
|
|
79
|
-
) {
|
|
80
|
-
if (seen[bucket].has(value)) {
|
|
81
|
-
return;
|
|
82
|
-
}
|
|
83
|
-
seen[bucket].add(value);
|
|
84
|
-
summary[bucket].push(value);
|
|
85
|
-
}
|
|
86
|
-
|
|
87
|
-
function formatSummary(summary: ApplyPatchSummary): string {
|
|
88
|
-
const lines = ["Success. Updated the following files:"];
|
|
89
|
-
for (const file of summary.added) {
|
|
90
|
-
lines.push(`A ${file}`);
|
|
91
|
-
}
|
|
92
|
-
for (const file of summary.modified) {
|
|
93
|
-
lines.push(`M ${file}`);
|
|
94
|
-
}
|
|
95
|
-
for (const file of summary.deleted) {
|
|
96
|
-
lines.push(`D ${file}`);
|
|
97
|
-
}
|
|
98
|
-
return lines.join("\n");
|
|
99
|
-
}
|
|
100
|
-
|
|
101
|
-
// ── Directory Helper ───────────────────────────────────────────────
|
|
102
|
-
|
|
103
|
-
async function ensureDir(filePath: string) {
|
|
104
|
-
const parent = path.dirname(filePath);
|
|
105
|
-
if (!parent || parent === ".") {
|
|
106
|
-
return;
|
|
107
|
-
}
|
|
108
|
-
await fs.mkdir(parent, { recursive: true });
|
|
109
|
-
}
|
|
110
|
-
|
|
111
|
-
// ── Core Orchestrator ──────────────────────────────────────────────
|
|
112
|
-
|
|
113
|
-
export type ApplyPatchResult = {
|
|
114
|
-
success: boolean;
|
|
115
|
-
summary: ApplyPatchSummary;
|
|
116
|
-
text: string;
|
|
117
|
-
};
|
|
118
|
-
|
|
119
|
-
export async function applyPatch(
|
|
120
|
-
input: string,
|
|
121
|
-
options: { cwd: string },
|
|
122
|
-
): Promise<ApplyPatchResult> {
|
|
123
|
-
const parsed = parsePatchText(input);
|
|
124
|
-
if (parsed.hunks.length === 0) {
|
|
125
|
-
return {
|
|
126
|
-
success: false,
|
|
127
|
-
summary: { added: [], modified: [], deleted: [] },
|
|
128
|
-
text: "No files were modified.",
|
|
129
|
-
};
|
|
130
|
-
}
|
|
131
|
-
|
|
132
|
-
const summary: ApplyPatchSummary = {
|
|
133
|
-
added: [],
|
|
134
|
-
modified: [],
|
|
135
|
-
deleted: [],
|
|
136
|
-
};
|
|
137
|
-
const seen = {
|
|
138
|
-
added: new Set<string>(),
|
|
139
|
-
modified: new Set<string>(),
|
|
140
|
-
deleted: new Set<string>(),
|
|
141
|
-
};
|
|
142
|
-
|
|
143
|
-
for (const hunk of parsed.hunks) {
|
|
144
|
-
if (hunk.kind === "add") {
|
|
145
|
-
const target = await resolvePatchPath(hunk.path, options.cwd);
|
|
146
|
-
await ensureDir(target.resolved);
|
|
147
|
-
await fs.writeFile(target.resolved, hunk.contents, "utf8");
|
|
148
|
-
recordSummary(summary, seen, "added", target.display);
|
|
149
|
-
continue;
|
|
150
|
-
}
|
|
151
|
-
|
|
152
|
-
if (hunk.kind === "delete") {
|
|
153
|
-
const target = await resolvePatchPath(hunk.path, options.cwd, "unlink");
|
|
154
|
-
await fs.rm(target.resolved);
|
|
155
|
-
recordSummary(summary, seen, "deleted", target.display);
|
|
156
|
-
continue;
|
|
157
|
-
}
|
|
158
|
-
|
|
159
|
-
// hunk.kind === "update"
|
|
160
|
-
const target = await resolvePatchPath(hunk.path, options.cwd);
|
|
161
|
-
const applied = await applyUpdateHunk(target.resolved, hunk.chunks, {
|
|
162
|
-
readFile: (p) => fs.readFile(p, "utf8"),
|
|
163
|
-
});
|
|
164
|
-
|
|
165
|
-
if (hunk.movePath) {
|
|
166
|
-
const moveTarget = await resolvePatchPath(hunk.movePath, options.cwd);
|
|
167
|
-
await ensureDir(moveTarget.resolved);
|
|
168
|
-
await fs.writeFile(moveTarget.resolved, applied, "utf8");
|
|
169
|
-
await fs.rm(target.resolved);
|
|
170
|
-
recordSummary(summary, seen, "modified", moveTarget.display);
|
|
171
|
-
} else {
|
|
172
|
-
await fs.writeFile(target.resolved, applied, "utf8");
|
|
173
|
-
recordSummary(summary, seen, "modified", target.display);
|
|
174
|
-
}
|
|
175
|
-
}
|
|
176
|
-
|
|
177
|
-
return {
|
|
178
|
-
success: true,
|
|
179
|
-
summary,
|
|
180
|
-
text: formatSummary(summary),
|
|
181
|
-
};
|
|
182
|
-
}
|
|
183
|
-
|
|
184
|
-
// ── ARIA Tool Definition ───────────────────────────────────────────
|
|
185
|
-
|
|
186
|
-
export const applyPatchTool: Tool = {
|
|
187
|
-
name: "apply_patch",
|
|
188
|
-
description:
|
|
189
|
-
"Apply a patch to files using a structured format. Supports adding, deleting, updating, and renaming files with fuzzy line matching for resilient text replacement.",
|
|
190
|
-
category: "filesystem",
|
|
191
|
-
parameters: {
|
|
192
|
-
type: "object",
|
|
193
|
-
properties: {
|
|
194
|
-
patch: {
|
|
195
|
-
type: "string",
|
|
196
|
-
description: "The patch text in *** Begin Patch / *** End Patch format",
|
|
197
|
-
},
|
|
198
|
-
cwd: {
|
|
199
|
-
type: "string",
|
|
200
|
-
description: "Working directory for relative paths (defaults to process.cwd())",
|
|
201
|
-
},
|
|
202
|
-
},
|
|
203
|
-
required: ["patch"],
|
|
204
|
-
} as JSONSchema7,
|
|
205
|
-
riskLevel: "dangerous",
|
|
206
|
-
requiresConfirmation: true,
|
|
207
|
-
isReadOnly: false,
|
|
208
|
-
loadingTier: "always",
|
|
209
|
-
async execute(input, _context) {
|
|
210
|
-
const { patch, cwd } = input as { patch: string; cwd?: string };
|
|
211
|
-
|
|
212
|
-
if (!patch || patch.trim() === "") {
|
|
213
|
-
return {
|
|
214
|
-
success: false,
|
|
215
|
-
message: "Patch content is empty.",
|
|
216
|
-
};
|
|
217
|
-
}
|
|
218
|
-
|
|
219
|
-
try {
|
|
220
|
-
const result = await applyPatch(patch, {
|
|
221
|
-
cwd: cwd ?? process.cwd(),
|
|
222
|
-
});
|
|
223
|
-
return {
|
|
224
|
-
success: result.success,
|
|
225
|
-
message: result.text,
|
|
226
|
-
};
|
|
227
|
-
} catch (err) {
|
|
228
|
-
const message = err instanceof Error ? err.message : String(err);
|
|
229
|
-
return {
|
|
230
|
-
success: false,
|
|
231
|
-
message: `apply_patch failed: ${message}`,
|
|
232
|
-
};
|
|
233
|
-
}
|
|
234
|
-
},
|
|
235
|
-
};
|