@aria-cli/tools 1.0.9 → 1.0.11
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 -5
- 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
|
-
};
|