@aria-cli/tools 1.0.12 → 1.0.14
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/index.js +378 -70
- package/dist/network-runtime/index.js +8 -12
- package/dist-cjs/index.js +400 -435
- package/dist-cjs/network-runtime/index.js +8 -172
- package/package.json +8 -6
- package/dist/.tsbuildinfo +0 -1
- package/dist/ask-user-interaction.js +0 -22
- package/dist/cache/web-cache.js +0 -66
- package/dist/definitions/arion.js +0 -104
- package/dist/definitions/browser/browser.js +0 -418
- package/dist/definitions/browser/index.js +0 -4
- package/dist/definitions/browser/pw-downloads.js +0 -114
- package/dist/definitions/browser/pw-interactions.js +0 -199
- package/dist/definitions/browser/pw-responses.js +0 -76
- package/dist/definitions/browser/pw-session.js +0 -310
- package/dist/definitions/browser/pw-shared.js +0 -66
- package/dist/definitions/browser/pw-snapshot.js +0 -301
- package/dist/definitions/browser/pw-state.js +0 -62
- package/dist/definitions/browser/types.js +0 -4
- package/dist/definitions/code-intelligence.js +0 -470
- package/dist/definitions/core.js +0 -109
- package/dist/definitions/delegation.js +0 -512
- package/dist/definitions/deploy.js +0 -65
- package/dist/definitions/filesystem.js +0 -196
- package/dist/definitions/frg.js +0 -63
- package/dist/definitions/index.js +0 -20
- package/dist/definitions/memory.js +0 -123
- package/dist/definitions/messaging.js +0 -625
- package/dist/definitions/meta.js +0 -349
- package/dist/definitions/network.js +0 -159
- package/dist/definitions/outlook.js +0 -277
- package/dist/definitions/patch/apply-patch.js +0 -184
- package/dist/definitions/patch/fuzzy-match.js +0 -166
- package/dist/definitions/patch/index.js +0 -1
- package/dist/definitions/patch/patch-parser.js +0 -207
- package/dist/definitions/patch/sandbox-paths.js +0 -105
- package/dist/definitions/process/index.js +0 -4
- package/dist/definitions/process/process-registry.js +0 -213
- package/dist/definitions/process/process.js +0 -386
- package/dist/definitions/process/pty-keys.js +0 -254
- package/dist/definitions/process/session-slug.js +0 -142
- package/dist/definitions/quip.js +0 -195
- package/dist/definitions/search.js +0 -60
- package/dist/definitions/session-history.js +0 -69
- package/dist/definitions/shell.js +0 -181
- package/dist/definitions/slack.js +0 -180
- package/dist/definitions/web.js +0 -109
- package/dist/executors/apply-patch.js +0 -901
- package/dist/executors/arion.js +0 -119
- package/dist/executors/code-intelligence.js +0 -882
- package/dist/executors/deploy.js +0 -848
- package/dist/executors/filesystem.js +0 -1122
- package/dist/executors/frg-freshness.js +0 -576
- package/dist/executors/frg.js +0 -298
- package/dist/executors/index.js +0 -46
- package/dist/executors/learning-meta.js +0 -1146
- package/dist/executors/lsp-client.js +0 -296
- package/dist/executors/memory.js +0 -750
- package/dist/executors/meta.js +0 -220
- package/dist/executors/process-registry.js +0 -465
- package/dist/executors/pty-session-store.js +0 -30
- package/dist/executors/pty.js +0 -271
- package/dist/executors/restart.js +0 -119
- package/dist/executors/search-freshness.js +0 -195
- package/dist/executors/search-types.js +0 -52
- package/dist/executors/search.js +0 -66
- package/dist/executors/self-diagnose.js +0 -398
- package/dist/executors/session-history.js +0 -283
- package/dist/executors/shell-safety.js +0 -473
- package/dist/executors/shell.js +0 -954
- package/dist/executors/utils.js +0 -33
- package/dist/executors/web.js +0 -542
- package/dist/extraction/content-extraction.js +0 -235
- package/dist/extraction/index.js +0 -4
- package/dist/headless-control-contract.js +0 -967
- package/dist/local-control-http-auth.js +0 -2
- package/dist/mcp/client.js +0 -181
- package/dist/mcp/connection.js +0 -480
- package/dist/mcp/index.js +0 -10
- package/dist/mcp/jsonrpc.js +0 -144
- package/dist/mcp/types.js +0 -7
- package/dist/network-control-adapter.js +0 -72
- package/dist/network-runtime/address-types.js +0 -165
- package/dist/network-runtime/db-owner-fencing.js +0 -69
- package/dist/network-runtime/delivery-receipts.js +0 -267
- package/dist/network-runtime/direct-endpoint-authority.js +0 -25
- package/dist/network-runtime/local-control-contract.js +0 -627
- package/dist/network-runtime/node-store-contract.js +0 -34
- package/dist/network-runtime/pair-route-contract.js +0 -77
- package/dist/network-runtime/peer-capabilities.js +0 -28
- package/dist/network-runtime/peer-principal-ref.js +0 -12
- package/dist/network-runtime/peer-state-machine.js +0 -121
- package/dist/network-runtime/protocol-schemas.js +0 -205
- package/dist/network-runtime/runtime-bootstrap-contract.js +0 -60
- package/dist/outlook/desktop-session.js +0 -279
- package/dist/policy.js +0 -149
- package/dist/providers/brave.js +0 -62
- package/dist/providers/duckduckgo.js +0 -176
- package/dist/providers/exa.js +0 -63
- package/dist/providers/firecrawl.js +0 -55
- package/dist/providers/index.js +0 -7
- package/dist/providers/jina.js +0 -49
- package/dist/providers/router.js +0 -96
- package/dist/providers/search-provider.js +0 -32
- package/dist/providers/tavily.js +0 -54
- package/dist/quip/desktop-session.js +0 -317
- package/dist/registry/index.js +0 -1
- package/dist/registry/registry.js +0 -756
- package/dist/runtime-socket-local-control-client.js +0 -330
- package/dist/security/dns-normalization.js +0 -19
- package/dist/security/dns-pinning.js +0 -123
- package/dist/security/external-content.js +0 -91
- package/dist/security/ssrf.js +0 -181
- package/dist/slack/desktop-session.js +0 -324
- package/dist/tool-factory.js +0 -47
- package/dist/types.js +0 -7
- package/dist/utils/retry.js +0 -132
- package/dist/utils/safe-parse-json.js +0 -160
- package/dist/utils/url.js +0 -19
- package/dist-cjs/.tsbuildinfo +0 -1
- package/dist-cjs/ask-user-interaction.js +0 -27
- package/dist-cjs/cache/web-cache.js +0 -70
- package/dist-cjs/definitions/arion.js +0 -107
- package/dist-cjs/definitions/browser/browser.js +0 -421
- package/dist-cjs/definitions/browser/index.js +0 -8
- package/dist-cjs/definitions/browser/pw-downloads.js +0 -117
- package/dist-cjs/definitions/browser/pw-interactions.js +0 -213
- package/dist-cjs/definitions/browser/pw-responses.js +0 -84
- package/dist-cjs/definitions/browser/pw-session.js +0 -326
- package/dist-cjs/definitions/browser/pw-shared.js +0 -72
- package/dist-cjs/definitions/browser/pw-snapshot.js +0 -307
- package/dist-cjs/definitions/browser/pw-state.js +0 -70
- package/dist-cjs/definitions/browser/types.js +0 -5
- package/dist-cjs/definitions/code-intelligence.js +0 -473
- package/dist-cjs/definitions/core.js +0 -133
- package/dist-cjs/definitions/delegation.js +0 -515
- package/dist-cjs/definitions/deploy.js +0 -68
- package/dist-cjs/definitions/filesystem.js +0 -199
- package/dist-cjs/definitions/frg.js +0 -66
- package/dist-cjs/definitions/index.js +0 -43
- package/dist-cjs/definitions/memory.js +0 -126
- package/dist-cjs/definitions/messaging.js +0 -631
- package/dist-cjs/definitions/meta.js +0 -352
- package/dist-cjs/definitions/network.js +0 -162
- package/dist-cjs/definitions/outlook.js +0 -280
- package/dist-cjs/definitions/patch/apply-patch.js +0 -191
- package/dist-cjs/definitions/patch/fuzzy-match.js +0 -172
- package/dist-cjs/definitions/patch/index.js +0 -5
- package/dist-cjs/definitions/patch/patch-parser.js +0 -215
- package/dist-cjs/definitions/patch/sandbox-paths.js +0 -113
- package/dist-cjs/definitions/process/index.js +0 -8
- package/dist-cjs/definitions/process/process-registry.js +0 -231
- package/dist-cjs/definitions/process/process.js +0 -389
- package/dist-cjs/definitions/process/pty-keys.js +0 -259
- package/dist-cjs/definitions/process/session-slug.js +0 -145
- package/dist-cjs/definitions/quip.js +0 -198
- package/dist-cjs/definitions/search.js +0 -63
- package/dist-cjs/definitions/session-history.js +0 -72
- package/dist-cjs/definitions/shell.js +0 -184
- package/dist-cjs/definitions/slack.js +0 -183
- package/dist-cjs/definitions/web.js +0 -112
- package/dist-cjs/executors/apply-patch.js +0 -938
- package/dist-cjs/executors/arion.js +0 -125
- package/dist-cjs/executors/code-intelligence.js +0 -925
- package/dist-cjs/executors/deploy.js +0 -869
- package/dist-cjs/executors/filesystem.js +0 -1167
- package/dist-cjs/executors/frg-freshness.js +0 -627
- package/dist-cjs/executors/frg.js +0 -334
- package/dist-cjs/executors/index.js +0 -143
- package/dist-cjs/executors/learning-meta.js +0 -1165
- package/dist-cjs/executors/lsp-client.js +0 -310
- package/dist-cjs/executors/memory.js +0 -796
- package/dist-cjs/executors/meta.js +0 -226
- package/dist-cjs/executors/process-registry.js +0 -469
- package/dist-cjs/executors/pty-session-store.js +0 -34
- package/dist-cjs/executors/pty.js +0 -312
- package/dist-cjs/executors/restart.js +0 -155
- package/dist-cjs/executors/search-freshness.js +0 -234
- package/dist-cjs/executors/search-types.js +0 -56
- package/dist-cjs/executors/search.js +0 -102
- package/dist-cjs/executors/self-diagnose.js +0 -434
- package/dist-cjs/executors/session-history.js +0 -320
- package/dist-cjs/executors/shell-safety.js +0 -478
- package/dist-cjs/executors/shell.js +0 -1001
- package/dist-cjs/executors/utils.js +0 -73
- package/dist-cjs/executors/web.js +0 -547
- package/dist-cjs/extraction/content-extraction.js +0 -243
- package/dist-cjs/extraction/index.js +0 -8
- package/dist-cjs/headless-control-contract.js +0 -972
- package/dist-cjs/local-control-http-auth.js +0 -5
- package/dist-cjs/mcp/client.js +0 -185
- package/dist-cjs/mcp/connection.js +0 -484
- package/dist-cjs/mcp/index.js +0 -30
- package/dist-cjs/mcp/jsonrpc.js +0 -148
- package/dist-cjs/mcp/types.js +0 -8
- package/dist-cjs/network-control-adapter.js +0 -77
- package/dist-cjs/network-runtime/address-types.js +0 -168
- package/dist-cjs/network-runtime/db-owner-fencing.js +0 -76
- package/dist-cjs/network-runtime/delivery-receipts.js +0 -276
- package/dist-cjs/network-runtime/direct-endpoint-authority.js +0 -29
- package/dist-cjs/network-runtime/local-control-contract.js +0 -633
- package/dist-cjs/network-runtime/node-store-contract.js +0 -38
- package/dist-cjs/network-runtime/pair-route-contract.js +0 -80
- package/dist-cjs/network-runtime/peer-capabilities.js +0 -37
- package/dist-cjs/network-runtime/peer-principal-ref.js +0 -15
- package/dist-cjs/network-runtime/peer-state-machine.js +0 -129
- package/dist-cjs/network-runtime/protocol-schemas.js +0 -212
- package/dist-cjs/network-runtime/runtime-bootstrap-contract.js +0 -63
- package/dist-cjs/outlook/desktop-session.js +0 -318
- package/dist-cjs/policy.js +0 -155
- package/dist-cjs/providers/brave.js +0 -66
- package/dist-cjs/providers/duckduckgo.js +0 -180
- package/dist-cjs/providers/exa.js +0 -67
- package/dist-cjs/providers/firecrawl.js +0 -59
- package/dist-cjs/providers/index.js +0 -17
- package/dist-cjs/providers/jina.js +0 -53
- package/dist-cjs/providers/router.js +0 -100
- package/dist-cjs/providers/search-provider.js +0 -36
- package/dist-cjs/providers/tavily.js +0 -58
- package/dist-cjs/quip/desktop-session.js +0 -353
- package/dist-cjs/registry/index.js +0 -6
- package/dist-cjs/registry/registry.js +0 -761
- package/dist-cjs/runtime-socket-local-control-client.js +0 -367
- package/dist-cjs/security/dns-normalization.js +0 -22
- package/dist-cjs/security/dns-pinning.js +0 -160
- package/dist-cjs/security/external-content.js +0 -95
- package/dist-cjs/security/ssrf.js +0 -221
- package/dist-cjs/slack/desktop-session.js +0 -366
- package/dist-cjs/tool-factory.js +0 -50
- package/dist-cjs/types.js +0 -8
- package/dist-cjs/utils/retry.js +0 -169
- package/dist-cjs/utils/safe-parse-json.js +0 -164
- package/dist-cjs/utils/url.js +0 -23
|
@@ -1,277 +0,0 @@
|
|
|
1
|
-
import { execFile } from "node:child_process";
|
|
2
|
-
import { homedir } from "node:os";
|
|
3
|
-
import { join } from "node:path";
|
|
4
|
-
const OUTLOOK_PY = join(homedir(), ".aria", "tools", "outlook.py");
|
|
5
|
-
function runOutlook(args) {
|
|
6
|
-
return new Promise((resolve, reject) => {
|
|
7
|
-
execFile(OUTLOOK_PY, args, { timeout: 30_000 }, (err, stdout, stderr) => {
|
|
8
|
-
if (err) {
|
|
9
|
-
reject(new Error(stderr?.trim() || err.message));
|
|
10
|
-
}
|
|
11
|
-
else {
|
|
12
|
-
resolve(stdout);
|
|
13
|
-
}
|
|
14
|
-
});
|
|
15
|
-
});
|
|
16
|
-
}
|
|
17
|
-
function parseJson(raw) {
|
|
18
|
-
try {
|
|
19
|
-
return JSON.parse(raw);
|
|
20
|
-
}
|
|
21
|
-
catch {
|
|
22
|
-
return { raw };
|
|
23
|
-
}
|
|
24
|
-
}
|
|
25
|
-
// PascalCase → camelCase field mapper for Outlook REST v2 responses
|
|
26
|
-
function normalizeMessage(msg) {
|
|
27
|
-
const from = msg.From;
|
|
28
|
-
const emailAddr = from?.EmailAddress;
|
|
29
|
-
const toRaw = msg.ToRecipients;
|
|
30
|
-
const ccRaw = msg.CcRecipients;
|
|
31
|
-
const body = msg.Body;
|
|
32
|
-
const mapRecipient = (r) => {
|
|
33
|
-
const ea = r.EmailAddress;
|
|
34
|
-
return { name: ea?.Name ?? "", email: ea?.Address ?? "" };
|
|
35
|
-
};
|
|
36
|
-
return {
|
|
37
|
-
id: msg.Id ?? msg.id ?? "",
|
|
38
|
-
subject: msg.Subject ?? msg.subject ?? "",
|
|
39
|
-
from: emailAddr
|
|
40
|
-
? { name: emailAddr.Name ?? "", email: emailAddr.Address ?? "" }
|
|
41
|
-
: { name: "", email: "" },
|
|
42
|
-
toRecipients: toRaw?.map(mapRecipient) ?? [],
|
|
43
|
-
receivedDateTime: msg.ReceivedDateTime ?? msg.receivedDateTime ?? "",
|
|
44
|
-
isRead: msg.IsRead ?? msg.isRead ?? false,
|
|
45
|
-
hasAttachments: msg.HasAttachments ?? msg.hasAttachments ?? false,
|
|
46
|
-
bodyPreview: msg.BodyPreview ?? msg.bodyPreview ?? "",
|
|
47
|
-
conversationId: msg.ConversationId ?? msg.conversationId ?? "",
|
|
48
|
-
...(body
|
|
49
|
-
? {
|
|
50
|
-
body: {
|
|
51
|
-
contentType: body.ContentType ?? body.contentType ?? "text",
|
|
52
|
-
content: body.Content ?? body.content ?? "",
|
|
53
|
-
},
|
|
54
|
-
}
|
|
55
|
-
: {}),
|
|
56
|
-
...(ccRaw ? { ccRecipients: ccRaw.map(mapRecipient) } : {}),
|
|
57
|
-
importance: msg.Importance ?? msg.importance ?? "normal",
|
|
58
|
-
};
|
|
59
|
-
}
|
|
60
|
-
const check_outlook_messages = {
|
|
61
|
-
name: "check_outlook_messages",
|
|
62
|
-
description: "Read or search Outlook emails using the local Microsoft Office desktop session on this machine. " +
|
|
63
|
-
"Can list inbox messages, filter by read status, search by keyword, or retrieve a specific message by ID.",
|
|
64
|
-
category: "messaging",
|
|
65
|
-
parameters: {
|
|
66
|
-
type: "object",
|
|
67
|
-
properties: {
|
|
68
|
-
folder: {
|
|
69
|
-
type: "string",
|
|
70
|
-
description: 'Mail folder to read from (default "inbox"). Common values: inbox, drafts, sentitems, deleteditems.',
|
|
71
|
-
default: "inbox",
|
|
72
|
-
},
|
|
73
|
-
limit: {
|
|
74
|
-
type: "number",
|
|
75
|
-
description: "Maximum number of messages to return (default 20, max 50).",
|
|
76
|
-
default: 20,
|
|
77
|
-
},
|
|
78
|
-
filter: {
|
|
79
|
-
type: "string",
|
|
80
|
-
description: 'OData filter expression, e.g. "isRead eq false" or "from/emailAddress/address eq \'alice@example.com\'".',
|
|
81
|
-
},
|
|
82
|
-
search: {
|
|
83
|
-
type: "string",
|
|
84
|
-
description: "KQL search query to find messages by keyword across subject, body, and participants.",
|
|
85
|
-
},
|
|
86
|
-
messageId: {
|
|
87
|
-
type: "string",
|
|
88
|
-
description: "Optional message ID. When provided, returns the full message detail instead of a list.",
|
|
89
|
-
},
|
|
90
|
-
},
|
|
91
|
-
required: [],
|
|
92
|
-
},
|
|
93
|
-
riskLevel: "safe",
|
|
94
|
-
isReadOnly: true,
|
|
95
|
-
loadingTier: "always",
|
|
96
|
-
execute: async (input) => {
|
|
97
|
-
const typedInput = input;
|
|
98
|
-
try {
|
|
99
|
-
if (typeof typedInput.messageId === "string" && typedInput.messageId) {
|
|
100
|
-
const raw = await runOutlook(["read", typedInput.messageId]);
|
|
101
|
-
const msg = normalizeMessage(parseJson(raw));
|
|
102
|
-
return {
|
|
103
|
-
success: true,
|
|
104
|
-
message: `Fetched Outlook message: ${msg.subject}`,
|
|
105
|
-
data: msg,
|
|
106
|
-
};
|
|
107
|
-
}
|
|
108
|
-
const args = ["check"];
|
|
109
|
-
const folder = typeof typedInput.folder === "string" ? typedInput.folder : "inbox";
|
|
110
|
-
args.push("--folder", folder);
|
|
111
|
-
args.push("--limit", String(typeof typedInput.limit === "number" ? typedInput.limit : 20));
|
|
112
|
-
if (typeof typedInput.filter === "string")
|
|
113
|
-
args.push("--filter", typedInput.filter);
|
|
114
|
-
if (typeof typedInput.search === "string")
|
|
115
|
-
args.push("--search", typedInput.search);
|
|
116
|
-
const raw = await runOutlook(args);
|
|
117
|
-
const json = parseJson(raw);
|
|
118
|
-
const rawMessages = Array.isArray(json.value) ? json.value : [];
|
|
119
|
-
const messages = rawMessages
|
|
120
|
-
.filter((m) => !!m && typeof m === "object")
|
|
121
|
-
.map(normalizeMessage);
|
|
122
|
-
return {
|
|
123
|
-
success: true,
|
|
124
|
-
message: `Fetched ${messages.length} Outlook messages from ${folder}.`,
|
|
125
|
-
data: { accountEmail: "hole@axon.com", folder, messages, totalCount: messages.length },
|
|
126
|
-
};
|
|
127
|
-
}
|
|
128
|
-
catch (error) {
|
|
129
|
-
return {
|
|
130
|
-
success: false,
|
|
131
|
-
message: error instanceof Error ? error.message : "Outlook read failed.",
|
|
132
|
-
};
|
|
133
|
-
}
|
|
134
|
-
},
|
|
135
|
-
};
|
|
136
|
-
const send_outlook_message = {
|
|
137
|
-
name: "send_outlook_message",
|
|
138
|
-
description: "Send an email through the local Microsoft Office desktop session on this machine. " +
|
|
139
|
-
"Requires confirmation because it sends externally.",
|
|
140
|
-
category: "messaging",
|
|
141
|
-
parameters: {
|
|
142
|
-
type: "object",
|
|
143
|
-
properties: {
|
|
144
|
-
to: {
|
|
145
|
-
oneOf: [{ type: "string" }, { type: "array", items: { type: "string" } }],
|
|
146
|
-
description: "Recipient email address(es).",
|
|
147
|
-
},
|
|
148
|
-
cc: {
|
|
149
|
-
oneOf: [{ type: "string" }, { type: "array", items: { type: "string" } }],
|
|
150
|
-
description: "CC email address(es).",
|
|
151
|
-
},
|
|
152
|
-
subject: {
|
|
153
|
-
type: "string",
|
|
154
|
-
description: "Email subject line.",
|
|
155
|
-
},
|
|
156
|
-
body: {
|
|
157
|
-
type: "string",
|
|
158
|
-
description: "Email body content.",
|
|
159
|
-
},
|
|
160
|
-
bodyType: {
|
|
161
|
-
type: "string",
|
|
162
|
-
enum: ["text", "html"],
|
|
163
|
-
description: 'Body content type (default "text").',
|
|
164
|
-
default: "text",
|
|
165
|
-
},
|
|
166
|
-
},
|
|
167
|
-
required: ["to", "subject", "body"],
|
|
168
|
-
},
|
|
169
|
-
riskLevel: "dangerous",
|
|
170
|
-
requiresConfirmation: true,
|
|
171
|
-
isReadOnly: false,
|
|
172
|
-
loadingTier: "always",
|
|
173
|
-
execute: async (input) => {
|
|
174
|
-
const typedInput = input;
|
|
175
|
-
try {
|
|
176
|
-
const toArray = Array.isArray(typedInput.to)
|
|
177
|
-
? typedInput.to
|
|
178
|
-
: typeof typedInput.to === "string"
|
|
179
|
-
? [typedInput.to]
|
|
180
|
-
: [];
|
|
181
|
-
const args = [
|
|
182
|
-
"send",
|
|
183
|
-
"--to",
|
|
184
|
-
toArray.join(","),
|
|
185
|
-
"--subject",
|
|
186
|
-
String(typedInput.subject ?? ""),
|
|
187
|
-
"--body",
|
|
188
|
-
String(typedInput.body ?? ""),
|
|
189
|
-
];
|
|
190
|
-
if (typedInput.cc) {
|
|
191
|
-
const ccArray = Array.isArray(typedInput.cc) ? typedInput.cc : [typedInput.cc];
|
|
192
|
-
args.push("--cc", ccArray.join(","));
|
|
193
|
-
}
|
|
194
|
-
if (typedInput.bodyType === "html")
|
|
195
|
-
args.push("--html");
|
|
196
|
-
await runOutlook(args);
|
|
197
|
-
return {
|
|
198
|
-
success: true,
|
|
199
|
-
message: `Sent email to ${toArray.join(", ")}.`,
|
|
200
|
-
data: { status: "sent" },
|
|
201
|
-
};
|
|
202
|
-
}
|
|
203
|
-
catch (error) {
|
|
204
|
-
return {
|
|
205
|
-
success: false,
|
|
206
|
-
message: error instanceof Error ? error.message : "Outlook send failed.",
|
|
207
|
-
};
|
|
208
|
-
}
|
|
209
|
-
},
|
|
210
|
-
};
|
|
211
|
-
const reply_outlook_message = {
|
|
212
|
-
name: "reply_outlook_message",
|
|
213
|
-
description: "Reply to an Outlook email thread using the local Microsoft Office desktop session on this machine. " +
|
|
214
|
-
"Requires confirmation because it sends externally.",
|
|
215
|
-
category: "messaging",
|
|
216
|
-
parameters: {
|
|
217
|
-
type: "object",
|
|
218
|
-
properties: {
|
|
219
|
-
messageId: {
|
|
220
|
-
type: "string",
|
|
221
|
-
description: "The ID of the message to reply to.",
|
|
222
|
-
},
|
|
223
|
-
body: {
|
|
224
|
-
type: "string",
|
|
225
|
-
description: "Reply body content.",
|
|
226
|
-
},
|
|
227
|
-
bodyType: {
|
|
228
|
-
type: "string",
|
|
229
|
-
enum: ["text", "html"],
|
|
230
|
-
description: 'Body content type (default "text").',
|
|
231
|
-
default: "text",
|
|
232
|
-
},
|
|
233
|
-
replyAll: {
|
|
234
|
-
type: "boolean",
|
|
235
|
-
description: "Whether to reply to all recipients (default false — reply to sender only).",
|
|
236
|
-
default: false,
|
|
237
|
-
},
|
|
238
|
-
},
|
|
239
|
-
required: ["messageId", "body"],
|
|
240
|
-
},
|
|
241
|
-
riskLevel: "dangerous",
|
|
242
|
-
requiresConfirmation: true,
|
|
243
|
-
isReadOnly: false,
|
|
244
|
-
loadingTier: "always",
|
|
245
|
-
execute: async (input) => {
|
|
246
|
-
const typedInput = input;
|
|
247
|
-
try {
|
|
248
|
-
const args = [
|
|
249
|
-
"reply",
|
|
250
|
-
String(typedInput.messageId ?? ""),
|
|
251
|
-
"--body",
|
|
252
|
-
String(typedInput.body ?? ""),
|
|
253
|
-
];
|
|
254
|
-
if (typedInput.replyAll)
|
|
255
|
-
args.push("--reply-all");
|
|
256
|
-
if (typedInput.bodyType === "html")
|
|
257
|
-
args.push("--html");
|
|
258
|
-
await runOutlook(args);
|
|
259
|
-
return {
|
|
260
|
-
success: true,
|
|
261
|
-
message: "Replied to message.",
|
|
262
|
-
data: { status: "sent" },
|
|
263
|
-
};
|
|
264
|
-
}
|
|
265
|
-
catch (error) {
|
|
266
|
-
return {
|
|
267
|
-
success: false,
|
|
268
|
-
message: error instanceof Error ? error.message : "Outlook reply failed.",
|
|
269
|
-
};
|
|
270
|
-
}
|
|
271
|
-
},
|
|
272
|
-
};
|
|
273
|
-
export const OUTLOOK_TOOL_DEFINITIONS = [
|
|
274
|
-
check_outlook_messages,
|
|
275
|
-
send_outlook_message,
|
|
276
|
-
reply_outlook_message,
|
|
277
|
-
];
|
|
@@ -1,184 +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
|
-
import fs from "node:fs/promises";
|
|
5
|
-
import os from "node:os";
|
|
6
|
-
import path from "node:path";
|
|
7
|
-
import { parsePatchText, normalizeUnicodeSpaces } from "./patch-parser.js";
|
|
8
|
-
import { applyUpdateHunk } from "./fuzzy-match.js";
|
|
9
|
-
import { assertSandboxPath } from "./sandbox-paths.js";
|
|
10
|
-
// ── Path Helpers ───────────────────────────────────────────────────
|
|
11
|
-
function expandPath(filePath) {
|
|
12
|
-
const normalized = normalizeUnicodeSpaces(filePath);
|
|
13
|
-
if (normalized === "~") {
|
|
14
|
-
return os.homedir();
|
|
15
|
-
}
|
|
16
|
-
if (normalized.startsWith("~/")) {
|
|
17
|
-
return os.homedir() + normalized.slice(1);
|
|
18
|
-
}
|
|
19
|
-
return normalized;
|
|
20
|
-
}
|
|
21
|
-
function resolvePathFromCwd(filePath, cwd) {
|
|
22
|
-
const expanded = expandPath(filePath);
|
|
23
|
-
if (path.isAbsolute(expanded)) {
|
|
24
|
-
return path.normalize(expanded);
|
|
25
|
-
}
|
|
26
|
-
return path.resolve(cwd, expanded);
|
|
27
|
-
}
|
|
28
|
-
function toDisplayPath(resolved, cwd) {
|
|
29
|
-
const relative = path.relative(cwd, resolved);
|
|
30
|
-
if (!relative || relative === "") {
|
|
31
|
-
return path.basename(resolved);
|
|
32
|
-
}
|
|
33
|
-
if (relative.startsWith("..") || path.isAbsolute(relative)) {
|
|
34
|
-
return resolved;
|
|
35
|
-
}
|
|
36
|
-
return relative;
|
|
37
|
-
}
|
|
38
|
-
// ── Path Resolution with Sandbox Validation ────────────────────────
|
|
39
|
-
async function resolvePatchPath(filePath, cwd, purpose = "readWrite") {
|
|
40
|
-
const resolved = (await assertSandboxPath({
|
|
41
|
-
filePath,
|
|
42
|
-
cwd,
|
|
43
|
-
root: cwd,
|
|
44
|
-
allowFinalSymlink: purpose === "unlink",
|
|
45
|
-
})).resolved;
|
|
46
|
-
return {
|
|
47
|
-
resolved,
|
|
48
|
-
display: toDisplayPath(resolved, cwd),
|
|
49
|
-
};
|
|
50
|
-
}
|
|
51
|
-
// ── Summary Helpers ────────────────────────────────────────────────
|
|
52
|
-
function recordSummary(summary, seen, bucket, value) {
|
|
53
|
-
if (seen[bucket].has(value)) {
|
|
54
|
-
return;
|
|
55
|
-
}
|
|
56
|
-
seen[bucket].add(value);
|
|
57
|
-
summary[bucket].push(value);
|
|
58
|
-
}
|
|
59
|
-
function formatSummary(summary) {
|
|
60
|
-
const lines = ["Success. Updated the following files:"];
|
|
61
|
-
for (const file of summary.added) {
|
|
62
|
-
lines.push(`A ${file}`);
|
|
63
|
-
}
|
|
64
|
-
for (const file of summary.modified) {
|
|
65
|
-
lines.push(`M ${file}`);
|
|
66
|
-
}
|
|
67
|
-
for (const file of summary.deleted) {
|
|
68
|
-
lines.push(`D ${file}`);
|
|
69
|
-
}
|
|
70
|
-
return lines.join("\n");
|
|
71
|
-
}
|
|
72
|
-
// ── Directory Helper ───────────────────────────────────────────────
|
|
73
|
-
async function ensureDir(filePath) {
|
|
74
|
-
const parent = path.dirname(filePath);
|
|
75
|
-
if (!parent || parent === ".") {
|
|
76
|
-
return;
|
|
77
|
-
}
|
|
78
|
-
await fs.mkdir(parent, { recursive: true });
|
|
79
|
-
}
|
|
80
|
-
export async function applyPatch(input, options) {
|
|
81
|
-
const parsed = parsePatchText(input);
|
|
82
|
-
if (parsed.hunks.length === 0) {
|
|
83
|
-
return {
|
|
84
|
-
success: false,
|
|
85
|
-
summary: { added: [], modified: [], deleted: [] },
|
|
86
|
-
text: "No files were modified.",
|
|
87
|
-
};
|
|
88
|
-
}
|
|
89
|
-
const summary = {
|
|
90
|
-
added: [],
|
|
91
|
-
modified: [],
|
|
92
|
-
deleted: [],
|
|
93
|
-
};
|
|
94
|
-
const seen = {
|
|
95
|
-
added: new Set(),
|
|
96
|
-
modified: new Set(),
|
|
97
|
-
deleted: new Set(),
|
|
98
|
-
};
|
|
99
|
-
for (const hunk of parsed.hunks) {
|
|
100
|
-
if (hunk.kind === "add") {
|
|
101
|
-
const target = await resolvePatchPath(hunk.path, options.cwd);
|
|
102
|
-
await ensureDir(target.resolved);
|
|
103
|
-
await fs.writeFile(target.resolved, hunk.contents, "utf8");
|
|
104
|
-
recordSummary(summary, seen, "added", target.display);
|
|
105
|
-
continue;
|
|
106
|
-
}
|
|
107
|
-
if (hunk.kind === "delete") {
|
|
108
|
-
const target = await resolvePatchPath(hunk.path, options.cwd, "unlink");
|
|
109
|
-
await fs.rm(target.resolved);
|
|
110
|
-
recordSummary(summary, seen, "deleted", target.display);
|
|
111
|
-
continue;
|
|
112
|
-
}
|
|
113
|
-
// hunk.kind === "update"
|
|
114
|
-
const target = await resolvePatchPath(hunk.path, options.cwd);
|
|
115
|
-
const applied = await applyUpdateHunk(target.resolved, hunk.chunks, {
|
|
116
|
-
readFile: (p) => fs.readFile(p, "utf8"),
|
|
117
|
-
});
|
|
118
|
-
if (hunk.movePath) {
|
|
119
|
-
const moveTarget = await resolvePatchPath(hunk.movePath, options.cwd);
|
|
120
|
-
await ensureDir(moveTarget.resolved);
|
|
121
|
-
await fs.writeFile(moveTarget.resolved, applied, "utf8");
|
|
122
|
-
await fs.rm(target.resolved);
|
|
123
|
-
recordSummary(summary, seen, "modified", moveTarget.display);
|
|
124
|
-
}
|
|
125
|
-
else {
|
|
126
|
-
await fs.writeFile(target.resolved, applied, "utf8");
|
|
127
|
-
recordSummary(summary, seen, "modified", target.display);
|
|
128
|
-
}
|
|
129
|
-
}
|
|
130
|
-
return {
|
|
131
|
-
success: true,
|
|
132
|
-
summary,
|
|
133
|
-
text: formatSummary(summary),
|
|
134
|
-
};
|
|
135
|
-
}
|
|
136
|
-
// ── ARIA Tool Definition ───────────────────────────────────────────
|
|
137
|
-
export const applyPatchTool = {
|
|
138
|
-
name: "apply_patch",
|
|
139
|
-
description: "Apply a patch to files using a structured format. Supports adding, deleting, updating, and renaming files with fuzzy line matching for resilient text replacement.",
|
|
140
|
-
category: "filesystem",
|
|
141
|
-
parameters: {
|
|
142
|
-
type: "object",
|
|
143
|
-
properties: {
|
|
144
|
-
patch: {
|
|
145
|
-
type: "string",
|
|
146
|
-
description: "The patch text in *** Begin Patch / *** End Patch format",
|
|
147
|
-
},
|
|
148
|
-
cwd: {
|
|
149
|
-
type: "string",
|
|
150
|
-
description: "Working directory for relative paths (defaults to process.cwd())",
|
|
151
|
-
},
|
|
152
|
-
},
|
|
153
|
-
required: ["patch"],
|
|
154
|
-
},
|
|
155
|
-
riskLevel: "dangerous",
|
|
156
|
-
requiresConfirmation: true,
|
|
157
|
-
isReadOnly: false,
|
|
158
|
-
loadingTier: "always",
|
|
159
|
-
async execute(input, _context) {
|
|
160
|
-
const { patch, cwd } = input;
|
|
161
|
-
if (!patch || patch.trim() === "") {
|
|
162
|
-
return {
|
|
163
|
-
success: false,
|
|
164
|
-
message: "Patch content is empty.",
|
|
165
|
-
};
|
|
166
|
-
}
|
|
167
|
-
try {
|
|
168
|
-
const result = await applyPatch(patch, {
|
|
169
|
-
cwd: cwd ?? process.cwd(),
|
|
170
|
-
});
|
|
171
|
-
return {
|
|
172
|
-
success: result.success,
|
|
173
|
-
message: result.text,
|
|
174
|
-
};
|
|
175
|
-
}
|
|
176
|
-
catch (err) {
|
|
177
|
-
const message = err instanceof Error ? err.message : String(err);
|
|
178
|
-
return {
|
|
179
|
-
success: false,
|
|
180
|
-
message: `apply_patch failed: ${message}`,
|
|
181
|
-
};
|
|
182
|
-
}
|
|
183
|
-
},
|
|
184
|
-
};
|
|
@@ -1,166 +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
|
-
import fs from "node:fs/promises";
|
|
5
|
-
async function defaultReadFile(filePath) {
|
|
6
|
-
return fs.readFile(filePath, "utf8");
|
|
7
|
-
}
|
|
8
|
-
export async function applyUpdateHunk(filePath, chunks, options) {
|
|
9
|
-
const reader = options?.readFile ?? defaultReadFile;
|
|
10
|
-
const originalContents = await reader(filePath).catch((err) => {
|
|
11
|
-
throw new Error(`Failed to read file to update ${filePath}: ${err}`);
|
|
12
|
-
});
|
|
13
|
-
const originalLines = originalContents.split("\n");
|
|
14
|
-
if (originalLines.length > 0 && originalLines[originalLines.length - 1] === "") {
|
|
15
|
-
originalLines.pop();
|
|
16
|
-
}
|
|
17
|
-
const replacements = computeReplacements(originalLines, filePath, chunks);
|
|
18
|
-
let newLines = applyReplacements(originalLines, replacements);
|
|
19
|
-
if (newLines.length === 0 || newLines[newLines.length - 1] !== "") {
|
|
20
|
-
newLines = [...newLines, ""];
|
|
21
|
-
}
|
|
22
|
-
return newLines.join("\n");
|
|
23
|
-
}
|
|
24
|
-
function computeReplacements(originalLines, filePath, chunks) {
|
|
25
|
-
const replacements = [];
|
|
26
|
-
let lineIndex = 0;
|
|
27
|
-
for (const chunk of chunks) {
|
|
28
|
-
if (chunk.changeContext) {
|
|
29
|
-
const ctxIndex = seekSequence(originalLines, [chunk.changeContext], lineIndex, false);
|
|
30
|
-
if (ctxIndex === null) {
|
|
31
|
-
throw new Error(`Failed to find context '${chunk.changeContext}' in ${filePath}`);
|
|
32
|
-
}
|
|
33
|
-
lineIndex = ctxIndex + 1;
|
|
34
|
-
}
|
|
35
|
-
if (chunk.oldLines.length === 0) {
|
|
36
|
-
const insertionIndex = originalLines.length > 0 && originalLines[originalLines.length - 1] === ""
|
|
37
|
-
? originalLines.length - 1
|
|
38
|
-
: originalLines.length;
|
|
39
|
-
replacements.push([insertionIndex, 0, chunk.newLines]);
|
|
40
|
-
continue;
|
|
41
|
-
}
|
|
42
|
-
let pattern = chunk.oldLines;
|
|
43
|
-
let newSlice = chunk.newLines;
|
|
44
|
-
let found = seekSequence(originalLines, pattern, lineIndex, chunk.isEndOfFile);
|
|
45
|
-
if (found === null && pattern[pattern.length - 1] === "") {
|
|
46
|
-
pattern = pattern.slice(0, -1);
|
|
47
|
-
if (newSlice.length > 0 && newSlice[newSlice.length - 1] === "") {
|
|
48
|
-
newSlice = newSlice.slice(0, -1);
|
|
49
|
-
}
|
|
50
|
-
found = seekSequence(originalLines, pattern, lineIndex, chunk.isEndOfFile);
|
|
51
|
-
}
|
|
52
|
-
if (found === null) {
|
|
53
|
-
throw new Error(`Failed to find expected lines in ${filePath}:\n${chunk.oldLines.join("\n")}`);
|
|
54
|
-
}
|
|
55
|
-
replacements.push([found, pattern.length, newSlice]);
|
|
56
|
-
lineIndex = found + pattern.length;
|
|
57
|
-
}
|
|
58
|
-
replacements.sort((a, b) => a[0] - b[0]);
|
|
59
|
-
return replacements;
|
|
60
|
-
}
|
|
61
|
-
function applyReplacements(lines, replacements) {
|
|
62
|
-
const result = [...lines];
|
|
63
|
-
for (let rIdx = replacements.length - 1; rIdx >= 0; rIdx -= 1) {
|
|
64
|
-
const entry = replacements[rIdx];
|
|
65
|
-
const startIndex = entry[0];
|
|
66
|
-
const oldLen = entry[1];
|
|
67
|
-
const newLines = entry[2];
|
|
68
|
-
for (let i = 0; i < oldLen; i += 1) {
|
|
69
|
-
if (startIndex < result.length) {
|
|
70
|
-
result.splice(startIndex, 1);
|
|
71
|
-
}
|
|
72
|
-
}
|
|
73
|
-
for (let i = 0; i < newLines.length; i += 1) {
|
|
74
|
-
result.splice(startIndex + i, 0, newLines[i]);
|
|
75
|
-
}
|
|
76
|
-
}
|
|
77
|
-
return result;
|
|
78
|
-
}
|
|
79
|
-
function seekSequence(lines, pattern, start, eof) {
|
|
80
|
-
if (pattern.length === 0) {
|
|
81
|
-
return start;
|
|
82
|
-
}
|
|
83
|
-
if (pattern.length > lines.length) {
|
|
84
|
-
return null;
|
|
85
|
-
}
|
|
86
|
-
const maxStart = lines.length - pattern.length;
|
|
87
|
-
const searchStart = eof && lines.length >= pattern.length ? maxStart : start;
|
|
88
|
-
if (searchStart > maxStart) {
|
|
89
|
-
return null;
|
|
90
|
-
}
|
|
91
|
-
// Pass 1: exact match
|
|
92
|
-
for (let i = searchStart; i <= maxStart; i += 1) {
|
|
93
|
-
if (linesMatch(lines, pattern, i, (value) => value)) {
|
|
94
|
-
return i;
|
|
95
|
-
}
|
|
96
|
-
}
|
|
97
|
-
// Pass 2: trim trailing whitespace
|
|
98
|
-
for (let i = searchStart; i <= maxStart; i += 1) {
|
|
99
|
-
if (linesMatch(lines, pattern, i, (value) => value.trimEnd())) {
|
|
100
|
-
return i;
|
|
101
|
-
}
|
|
102
|
-
}
|
|
103
|
-
// Pass 3: trim all whitespace
|
|
104
|
-
for (let i = searchStart; i <= maxStart; i += 1) {
|
|
105
|
-
if (linesMatch(lines, pattern, i, (value) => value.trim())) {
|
|
106
|
-
return i;
|
|
107
|
-
}
|
|
108
|
-
}
|
|
109
|
-
// Pass 4: normalize punctuation + trim
|
|
110
|
-
for (let i = searchStart; i <= maxStart; i += 1) {
|
|
111
|
-
if (linesMatch(lines, pattern, i, (value) => normalizePunctuation(value.trim()))) {
|
|
112
|
-
return i;
|
|
113
|
-
}
|
|
114
|
-
}
|
|
115
|
-
return null;
|
|
116
|
-
}
|
|
117
|
-
function linesMatch(lines, pattern, start, normalize) {
|
|
118
|
-
for (let idx = 0; idx < pattern.length; idx += 1) {
|
|
119
|
-
if (normalize(lines[start + idx]) !== normalize(pattern[idx])) {
|
|
120
|
-
return false;
|
|
121
|
-
}
|
|
122
|
-
}
|
|
123
|
-
return true;
|
|
124
|
-
}
|
|
125
|
-
function normalizePunctuation(value) {
|
|
126
|
-
return Array.from(value)
|
|
127
|
-
.map((char) => {
|
|
128
|
-
switch (char) {
|
|
129
|
-
case "\u2010":
|
|
130
|
-
case "\u2011":
|
|
131
|
-
case "\u2012":
|
|
132
|
-
case "\u2013":
|
|
133
|
-
case "\u2014":
|
|
134
|
-
case "\u2015":
|
|
135
|
-
case "\u2212":
|
|
136
|
-
return "-";
|
|
137
|
-
case "\u2018":
|
|
138
|
-
case "\u2019":
|
|
139
|
-
case "\u201A":
|
|
140
|
-
case "\u201B":
|
|
141
|
-
return "'";
|
|
142
|
-
case "\u201C":
|
|
143
|
-
case "\u201D":
|
|
144
|
-
case "\u201E":
|
|
145
|
-
case "\u201F":
|
|
146
|
-
return '"';
|
|
147
|
-
case "\u00A0":
|
|
148
|
-
case "\u2002":
|
|
149
|
-
case "\u2003":
|
|
150
|
-
case "\u2004":
|
|
151
|
-
case "\u2005":
|
|
152
|
-
case "\u2006":
|
|
153
|
-
case "\u2007":
|
|
154
|
-
case "\u2008":
|
|
155
|
-
case "\u2009":
|
|
156
|
-
case "\u200A":
|
|
157
|
-
case "\u202F":
|
|
158
|
-
case "\u205F":
|
|
159
|
-
case "\u3000":
|
|
160
|
-
return " ";
|
|
161
|
-
default:
|
|
162
|
-
return char;
|
|
163
|
-
}
|
|
164
|
-
})
|
|
165
|
-
.join("");
|
|
166
|
-
}
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
export { applyPatchTool } from "./apply-patch.js";
|