@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.
Files changed (233) hide show
  1. package/dist/index.js +378 -70
  2. package/dist/network-runtime/index.js +8 -12
  3. package/dist-cjs/index.js +400 -435
  4. package/dist-cjs/network-runtime/index.js +8 -172
  5. package/package.json +8 -6
  6. package/dist/.tsbuildinfo +0 -1
  7. package/dist/ask-user-interaction.js +0 -22
  8. package/dist/cache/web-cache.js +0 -66
  9. package/dist/definitions/arion.js +0 -104
  10. package/dist/definitions/browser/browser.js +0 -418
  11. package/dist/definitions/browser/index.js +0 -4
  12. package/dist/definitions/browser/pw-downloads.js +0 -114
  13. package/dist/definitions/browser/pw-interactions.js +0 -199
  14. package/dist/definitions/browser/pw-responses.js +0 -76
  15. package/dist/definitions/browser/pw-session.js +0 -310
  16. package/dist/definitions/browser/pw-shared.js +0 -66
  17. package/dist/definitions/browser/pw-snapshot.js +0 -301
  18. package/dist/definitions/browser/pw-state.js +0 -62
  19. package/dist/definitions/browser/types.js +0 -4
  20. package/dist/definitions/code-intelligence.js +0 -470
  21. package/dist/definitions/core.js +0 -109
  22. package/dist/definitions/delegation.js +0 -512
  23. package/dist/definitions/deploy.js +0 -65
  24. package/dist/definitions/filesystem.js +0 -196
  25. package/dist/definitions/frg.js +0 -63
  26. package/dist/definitions/index.js +0 -20
  27. package/dist/definitions/memory.js +0 -123
  28. package/dist/definitions/messaging.js +0 -625
  29. package/dist/definitions/meta.js +0 -349
  30. package/dist/definitions/network.js +0 -159
  31. package/dist/definitions/outlook.js +0 -277
  32. package/dist/definitions/patch/apply-patch.js +0 -184
  33. package/dist/definitions/patch/fuzzy-match.js +0 -166
  34. package/dist/definitions/patch/index.js +0 -1
  35. package/dist/definitions/patch/patch-parser.js +0 -207
  36. package/dist/definitions/patch/sandbox-paths.js +0 -105
  37. package/dist/definitions/process/index.js +0 -4
  38. package/dist/definitions/process/process-registry.js +0 -213
  39. package/dist/definitions/process/process.js +0 -386
  40. package/dist/definitions/process/pty-keys.js +0 -254
  41. package/dist/definitions/process/session-slug.js +0 -142
  42. package/dist/definitions/quip.js +0 -195
  43. package/dist/definitions/search.js +0 -60
  44. package/dist/definitions/session-history.js +0 -69
  45. package/dist/definitions/shell.js +0 -181
  46. package/dist/definitions/slack.js +0 -180
  47. package/dist/definitions/web.js +0 -109
  48. package/dist/executors/apply-patch.js +0 -901
  49. package/dist/executors/arion.js +0 -119
  50. package/dist/executors/code-intelligence.js +0 -882
  51. package/dist/executors/deploy.js +0 -848
  52. package/dist/executors/filesystem.js +0 -1122
  53. package/dist/executors/frg-freshness.js +0 -576
  54. package/dist/executors/frg.js +0 -298
  55. package/dist/executors/index.js +0 -46
  56. package/dist/executors/learning-meta.js +0 -1146
  57. package/dist/executors/lsp-client.js +0 -296
  58. package/dist/executors/memory.js +0 -750
  59. package/dist/executors/meta.js +0 -220
  60. package/dist/executors/process-registry.js +0 -465
  61. package/dist/executors/pty-session-store.js +0 -30
  62. package/dist/executors/pty.js +0 -271
  63. package/dist/executors/restart.js +0 -119
  64. package/dist/executors/search-freshness.js +0 -195
  65. package/dist/executors/search-types.js +0 -52
  66. package/dist/executors/search.js +0 -66
  67. package/dist/executors/self-diagnose.js +0 -398
  68. package/dist/executors/session-history.js +0 -283
  69. package/dist/executors/shell-safety.js +0 -473
  70. package/dist/executors/shell.js +0 -954
  71. package/dist/executors/utils.js +0 -33
  72. package/dist/executors/web.js +0 -542
  73. package/dist/extraction/content-extraction.js +0 -235
  74. package/dist/extraction/index.js +0 -4
  75. package/dist/headless-control-contract.js +0 -967
  76. package/dist/local-control-http-auth.js +0 -2
  77. package/dist/mcp/client.js +0 -181
  78. package/dist/mcp/connection.js +0 -480
  79. package/dist/mcp/index.js +0 -10
  80. package/dist/mcp/jsonrpc.js +0 -144
  81. package/dist/mcp/types.js +0 -7
  82. package/dist/network-control-adapter.js +0 -72
  83. package/dist/network-runtime/address-types.js +0 -165
  84. package/dist/network-runtime/db-owner-fencing.js +0 -69
  85. package/dist/network-runtime/delivery-receipts.js +0 -267
  86. package/dist/network-runtime/direct-endpoint-authority.js +0 -25
  87. package/dist/network-runtime/local-control-contract.js +0 -627
  88. package/dist/network-runtime/node-store-contract.js +0 -34
  89. package/dist/network-runtime/pair-route-contract.js +0 -77
  90. package/dist/network-runtime/peer-capabilities.js +0 -28
  91. package/dist/network-runtime/peer-principal-ref.js +0 -12
  92. package/dist/network-runtime/peer-state-machine.js +0 -121
  93. package/dist/network-runtime/protocol-schemas.js +0 -205
  94. package/dist/network-runtime/runtime-bootstrap-contract.js +0 -60
  95. package/dist/outlook/desktop-session.js +0 -279
  96. package/dist/policy.js +0 -149
  97. package/dist/providers/brave.js +0 -62
  98. package/dist/providers/duckduckgo.js +0 -176
  99. package/dist/providers/exa.js +0 -63
  100. package/dist/providers/firecrawl.js +0 -55
  101. package/dist/providers/index.js +0 -7
  102. package/dist/providers/jina.js +0 -49
  103. package/dist/providers/router.js +0 -96
  104. package/dist/providers/search-provider.js +0 -32
  105. package/dist/providers/tavily.js +0 -54
  106. package/dist/quip/desktop-session.js +0 -317
  107. package/dist/registry/index.js +0 -1
  108. package/dist/registry/registry.js +0 -756
  109. package/dist/runtime-socket-local-control-client.js +0 -330
  110. package/dist/security/dns-normalization.js +0 -19
  111. package/dist/security/dns-pinning.js +0 -123
  112. package/dist/security/external-content.js +0 -91
  113. package/dist/security/ssrf.js +0 -181
  114. package/dist/slack/desktop-session.js +0 -324
  115. package/dist/tool-factory.js +0 -47
  116. package/dist/types.js +0 -7
  117. package/dist/utils/retry.js +0 -132
  118. package/dist/utils/safe-parse-json.js +0 -160
  119. package/dist/utils/url.js +0 -19
  120. package/dist-cjs/.tsbuildinfo +0 -1
  121. package/dist-cjs/ask-user-interaction.js +0 -27
  122. package/dist-cjs/cache/web-cache.js +0 -70
  123. package/dist-cjs/definitions/arion.js +0 -107
  124. package/dist-cjs/definitions/browser/browser.js +0 -421
  125. package/dist-cjs/definitions/browser/index.js +0 -8
  126. package/dist-cjs/definitions/browser/pw-downloads.js +0 -117
  127. package/dist-cjs/definitions/browser/pw-interactions.js +0 -213
  128. package/dist-cjs/definitions/browser/pw-responses.js +0 -84
  129. package/dist-cjs/definitions/browser/pw-session.js +0 -326
  130. package/dist-cjs/definitions/browser/pw-shared.js +0 -72
  131. package/dist-cjs/definitions/browser/pw-snapshot.js +0 -307
  132. package/dist-cjs/definitions/browser/pw-state.js +0 -70
  133. package/dist-cjs/definitions/browser/types.js +0 -5
  134. package/dist-cjs/definitions/code-intelligence.js +0 -473
  135. package/dist-cjs/definitions/core.js +0 -133
  136. package/dist-cjs/definitions/delegation.js +0 -515
  137. package/dist-cjs/definitions/deploy.js +0 -68
  138. package/dist-cjs/definitions/filesystem.js +0 -199
  139. package/dist-cjs/definitions/frg.js +0 -66
  140. package/dist-cjs/definitions/index.js +0 -43
  141. package/dist-cjs/definitions/memory.js +0 -126
  142. package/dist-cjs/definitions/messaging.js +0 -631
  143. package/dist-cjs/definitions/meta.js +0 -352
  144. package/dist-cjs/definitions/network.js +0 -162
  145. package/dist-cjs/definitions/outlook.js +0 -280
  146. package/dist-cjs/definitions/patch/apply-patch.js +0 -191
  147. package/dist-cjs/definitions/patch/fuzzy-match.js +0 -172
  148. package/dist-cjs/definitions/patch/index.js +0 -5
  149. package/dist-cjs/definitions/patch/patch-parser.js +0 -215
  150. package/dist-cjs/definitions/patch/sandbox-paths.js +0 -113
  151. package/dist-cjs/definitions/process/index.js +0 -8
  152. package/dist-cjs/definitions/process/process-registry.js +0 -231
  153. package/dist-cjs/definitions/process/process.js +0 -389
  154. package/dist-cjs/definitions/process/pty-keys.js +0 -259
  155. package/dist-cjs/definitions/process/session-slug.js +0 -145
  156. package/dist-cjs/definitions/quip.js +0 -198
  157. package/dist-cjs/definitions/search.js +0 -63
  158. package/dist-cjs/definitions/session-history.js +0 -72
  159. package/dist-cjs/definitions/shell.js +0 -184
  160. package/dist-cjs/definitions/slack.js +0 -183
  161. package/dist-cjs/definitions/web.js +0 -112
  162. package/dist-cjs/executors/apply-patch.js +0 -938
  163. package/dist-cjs/executors/arion.js +0 -125
  164. package/dist-cjs/executors/code-intelligence.js +0 -925
  165. package/dist-cjs/executors/deploy.js +0 -869
  166. package/dist-cjs/executors/filesystem.js +0 -1167
  167. package/dist-cjs/executors/frg-freshness.js +0 -627
  168. package/dist-cjs/executors/frg.js +0 -334
  169. package/dist-cjs/executors/index.js +0 -143
  170. package/dist-cjs/executors/learning-meta.js +0 -1165
  171. package/dist-cjs/executors/lsp-client.js +0 -310
  172. package/dist-cjs/executors/memory.js +0 -796
  173. package/dist-cjs/executors/meta.js +0 -226
  174. package/dist-cjs/executors/process-registry.js +0 -469
  175. package/dist-cjs/executors/pty-session-store.js +0 -34
  176. package/dist-cjs/executors/pty.js +0 -312
  177. package/dist-cjs/executors/restart.js +0 -155
  178. package/dist-cjs/executors/search-freshness.js +0 -234
  179. package/dist-cjs/executors/search-types.js +0 -56
  180. package/dist-cjs/executors/search.js +0 -102
  181. package/dist-cjs/executors/self-diagnose.js +0 -434
  182. package/dist-cjs/executors/session-history.js +0 -320
  183. package/dist-cjs/executors/shell-safety.js +0 -478
  184. package/dist-cjs/executors/shell.js +0 -1001
  185. package/dist-cjs/executors/utils.js +0 -73
  186. package/dist-cjs/executors/web.js +0 -547
  187. package/dist-cjs/extraction/content-extraction.js +0 -243
  188. package/dist-cjs/extraction/index.js +0 -8
  189. package/dist-cjs/headless-control-contract.js +0 -972
  190. package/dist-cjs/local-control-http-auth.js +0 -5
  191. package/dist-cjs/mcp/client.js +0 -185
  192. package/dist-cjs/mcp/connection.js +0 -484
  193. package/dist-cjs/mcp/index.js +0 -30
  194. package/dist-cjs/mcp/jsonrpc.js +0 -148
  195. package/dist-cjs/mcp/types.js +0 -8
  196. package/dist-cjs/network-control-adapter.js +0 -77
  197. package/dist-cjs/network-runtime/address-types.js +0 -168
  198. package/dist-cjs/network-runtime/db-owner-fencing.js +0 -76
  199. package/dist-cjs/network-runtime/delivery-receipts.js +0 -276
  200. package/dist-cjs/network-runtime/direct-endpoint-authority.js +0 -29
  201. package/dist-cjs/network-runtime/local-control-contract.js +0 -633
  202. package/dist-cjs/network-runtime/node-store-contract.js +0 -38
  203. package/dist-cjs/network-runtime/pair-route-contract.js +0 -80
  204. package/dist-cjs/network-runtime/peer-capabilities.js +0 -37
  205. package/dist-cjs/network-runtime/peer-principal-ref.js +0 -15
  206. package/dist-cjs/network-runtime/peer-state-machine.js +0 -129
  207. package/dist-cjs/network-runtime/protocol-schemas.js +0 -212
  208. package/dist-cjs/network-runtime/runtime-bootstrap-contract.js +0 -63
  209. package/dist-cjs/outlook/desktop-session.js +0 -318
  210. package/dist-cjs/policy.js +0 -155
  211. package/dist-cjs/providers/brave.js +0 -66
  212. package/dist-cjs/providers/duckduckgo.js +0 -180
  213. package/dist-cjs/providers/exa.js +0 -67
  214. package/dist-cjs/providers/firecrawl.js +0 -59
  215. package/dist-cjs/providers/index.js +0 -17
  216. package/dist-cjs/providers/jina.js +0 -53
  217. package/dist-cjs/providers/router.js +0 -100
  218. package/dist-cjs/providers/search-provider.js +0 -36
  219. package/dist-cjs/providers/tavily.js +0 -58
  220. package/dist-cjs/quip/desktop-session.js +0 -353
  221. package/dist-cjs/registry/index.js +0 -6
  222. package/dist-cjs/registry/registry.js +0 -761
  223. package/dist-cjs/runtime-socket-local-control-client.js +0 -367
  224. package/dist-cjs/security/dns-normalization.js +0 -22
  225. package/dist-cjs/security/dns-pinning.js +0 -160
  226. package/dist-cjs/security/external-content.js +0 -95
  227. package/dist-cjs/security/ssrf.js +0 -221
  228. package/dist-cjs/slack/desktop-session.js +0 -366
  229. package/dist-cjs/tool-factory.js +0 -50
  230. package/dist-cjs/types.js +0 -8
  231. package/dist-cjs/utils/retry.js +0 -169
  232. package/dist-cjs/utils/safe-parse-json.js +0 -164
  233. package/dist-cjs/utils/url.js +0 -23
@@ -1,318 +0,0 @@
1
- "use strict";
2
- var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
3
- if (k2 === undefined) k2 = k;
4
- var desc = Object.getOwnPropertyDescriptor(m, k);
5
- if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
6
- desc = { enumerable: true, get: function() { return m[k]; } };
7
- }
8
- Object.defineProperty(o, k2, desc);
9
- }) : (function(o, m, k, k2) {
10
- if (k2 === undefined) k2 = k;
11
- o[k2] = m[k];
12
- }));
13
- var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
14
- Object.defineProperty(o, "default", { enumerable: true, value: v });
15
- }) : function(o, v) {
16
- o["default"] = v;
17
- });
18
- var __importStar = (this && this.__importStar) || (function () {
19
- var ownKeys = function(o) {
20
- ownKeys = Object.getOwnPropertyNames || function (o) {
21
- var ar = [];
22
- for (var k in o) if (Object.prototype.hasOwnProperty.call(o, k)) ar[ar.length] = k;
23
- return ar;
24
- };
25
- return ownKeys(o);
26
- };
27
- return function (mod) {
28
- if (mod && mod.__esModule) return mod;
29
- var result = {};
30
- if (mod != null) for (var k = ownKeys(mod), i = 0; i < k.length; i++) if (k[i] !== "default") __createBinding(result, mod, k[i]);
31
- __setModuleDefault(result, mod);
32
- return result;
33
- };
34
- })();
35
- var __importDefault = (this && this.__importDefault) || function (mod) {
36
- return (mod && mod.__esModule) ? mod : { "default": mod };
37
- };
38
- Object.defineProperty(exports, "__esModule", { value: true });
39
- exports.createOutlookDesktopClient = createOutlookDesktopClient;
40
- const node_os_1 = __importDefault(require("node:os"));
41
- const node_path_1 = __importDefault(require("node:path"));
42
- const node_fs_1 = require("node:fs");
43
- const OUTLOOK_SESSION_DIR = node_path_1.default.join(node_os_1.default.homedir(), ".aria", "outlook-session");
44
- const OUTLOOK_TOKEN_CACHE = node_path_1.default.join(node_os_1.default.homedir(), ".aria", "cache", "outlook-token.json");
45
- const OUTLOOK_WEB_URL = "https://outlook.office.com/mail/";
46
- // Outlook web uses outlook.office.com-scoped tokens, not graph.microsoft.com.
47
- // The Outlook REST v2 API at outlook.office.com/api/v2.0 accepts these tokens.
48
- const OUTLOOK_REST_API_BASE = "https://outlook.office.com/api/v2.0";
49
- const DEFAULT_BOOTSTRAP_TIMEOUT_MS = 60_000;
50
- async function loadCachedToken() {
51
- try {
52
- const raw = await node_fs_1.promises.readFile(OUTLOOK_TOKEN_CACHE, "utf-8");
53
- const cached = JSON.parse(raw);
54
- // Token valid if >5 min remaining
55
- if (cached.bearerToken && cached.expiresAt > Date.now() + 5 * 60_000) {
56
- return cached;
57
- }
58
- }
59
- catch {
60
- // no cache or invalid
61
- }
62
- return null;
63
- }
64
- async function saveCachedToken(token, email) {
65
- // Decode JWT to get expiry
66
- let exp = Date.now() + 60 * 60_000; // default 1h
67
- try {
68
- const part = token.split(".")[1];
69
- if (!part)
70
- throw new Error("no payload");
71
- const payload = JSON.parse(Buffer.from(part, "base64").toString());
72
- if (payload.exp)
73
- exp = payload.exp * 1000;
74
- }
75
- catch {
76
- /* best-effort */
77
- }
78
- const cached = { bearerToken: token, accountEmail: email, expiresAt: exp };
79
- await node_fs_1.promises.mkdir(node_path_1.default.dirname(OUTLOOK_TOKEN_CACHE), { recursive: true });
80
- await node_fs_1.promises.writeFile(OUTLOOK_TOKEN_CACHE, JSON.stringify(cached, null, 2));
81
- }
82
- // Outlook REST v2 returns PascalCase keys (Subject, From, EmailAddress)
83
- // while Graph API uses camelCase (subject, from, emailAddress).
84
- // Helper to read a field with either casing.
85
- function field(obj, camelKey) {
86
- if (camelKey in obj)
87
- return obj[camelKey];
88
- const pascalKey = camelKey.charAt(0).toUpperCase() + camelKey.slice(1);
89
- return obj[pascalKey];
90
- }
91
- function fieldStr(obj, camelKey) {
92
- const v = field(obj, camelKey);
93
- return typeof v === "string" ? v : "";
94
- }
95
- function parseRecipient(recipient) {
96
- const emailAddress = field(recipient, "emailAddress") ?? null;
97
- if (!emailAddress || typeof emailAddress !== "object")
98
- return null;
99
- return {
100
- name: fieldStr(emailAddress, "name"),
101
- email: fieldStr(emailAddress, "address"),
102
- };
103
- }
104
- function parseRecipients(raw) {
105
- if (!Array.isArray(raw))
106
- return [];
107
- return raw
108
- .filter((r) => !!r && typeof r === "object")
109
- .map(parseRecipient)
110
- .filter((r) => r !== null);
111
- }
112
- function toMessageView(msg) {
113
- const fromRaw = field(msg, "from");
114
- const from = fromRaw && typeof fromRaw === "object"
115
- ? parseRecipient(fromRaw)
116
- : null;
117
- return {
118
- id: fieldStr(msg, "id") || fieldStr(msg, "Id"),
119
- subject: fieldStr(msg, "subject"),
120
- from: from ?? { name: "", email: "" },
121
- toRecipients: parseRecipients(field(msg, "toRecipients")),
122
- receivedDateTime: fieldStr(msg, "receivedDateTime"),
123
- isRead: field(msg, "isRead") === true,
124
- hasAttachments: field(msg, "hasAttachments") === true,
125
- bodyPreview: fieldStr(msg, "bodyPreview"),
126
- conversationId: fieldStr(msg, "conversationId"),
127
- };
128
- }
129
- function toMessageDetail(msg) {
130
- const view = toMessageView(msg);
131
- const bodyRaw = field(msg, "body");
132
- const body = bodyRaw && typeof bodyRaw === "object" ? bodyRaw : {};
133
- return {
134
- ...view,
135
- body: {
136
- contentType: fieldStr(body, "contentType") || "text",
137
- content: fieldStr(body, "content"),
138
- },
139
- ccRecipients: parseRecipients(field(msg, "ccRecipients")),
140
- importance: fieldStr(msg, "importance") || "normal",
141
- };
142
- }
143
- async function waitForMailBearerToken(page, timeoutMs) {
144
- return new Promise((resolve, reject) => {
145
- const timer = setTimeout(() => {
146
- page.off("request", handleRequest);
147
- reject(new Error("Timed out waiting for a Mail-scoped bearer token. " +
148
- "Ensure you are logged in to outlook.office.com."));
149
- }, timeoutMs);
150
- const seen = new Set();
151
- const handleRequest = (request) => {
152
- const authHeader = request.headers()["authorization"];
153
- if (!authHeader || !authHeader.startsWith("Bearer "))
154
- return;
155
- const bearerToken = authHeader.slice(7);
156
- const dedup = bearerToken.substring(0, 30);
157
- if (seen.has(dedup))
158
- return;
159
- seen.add(dedup);
160
- // Decode JWT payload to extract email and scopes
161
- let accountEmail = "";
162
- let scp = "";
163
- try {
164
- const payloadB64 = bearerToken.split(".")[1];
165
- if (payloadB64) {
166
- const payload = JSON.parse(Buffer.from(payloadB64, "base64url").toString("utf8"));
167
- scp = typeof payload.scp === "string" ? payload.scp : "";
168
- accountEmail =
169
- typeof payload.upn === "string"
170
- ? payload.upn
171
- : typeof payload.preferred_username === "string"
172
- ? payload.preferred_username
173
- : typeof payload.unique_name === "string"
174
- ? payload.unique_name
175
- : "";
176
- }
177
- }
178
- catch {
179
- // JWT decode is best-effort
180
- }
181
- // Only accept tokens with Mail.Read scope (from outlook.cloud.microsoft)
182
- if (!scp.includes("Mail.Read"))
183
- return;
184
- clearTimeout(timer);
185
- page.off("request", handleRequest);
186
- resolve({ bearerToken, accountEmail });
187
- };
188
- page.on("request", handleRequest);
189
- });
190
- }
191
- // Stateless client using a cached bearer token (no Playwright needed)
192
- function createStatelessClient(bearerToken, accountEmail) {
193
- const invokeApi = async (method, endpoint, body) => {
194
- const url = `${OUTLOOK_REST_API_BASE}${endpoint}`;
195
- const headers = {
196
- Authorization: `Bearer ${bearerToken}`,
197
- "Content-Type": "application/json",
198
- };
199
- const resp = await fetch(url, {
200
- method,
201
- headers,
202
- body: body ? JSON.stringify(body) : undefined,
203
- });
204
- if (resp.status === 204)
205
- return { status: 204 };
206
- const text = await resp.text();
207
- let json;
208
- try {
209
- json = JSON.parse(text);
210
- }
211
- catch {
212
- throw new Error(`Outlook API ${method} ${endpoint} returned non-JSON (HTTP ${resp.status}).`);
213
- }
214
- if (resp.status >= 400) {
215
- const error = json.error && typeof json.error === "object" ? json.error : {};
216
- const code = typeof error.code === "string" ? error.code : `http_${resp.status}`;
217
- const message = typeof error.message === "string" ? error.message : "Unknown error";
218
- throw new Error(`Outlook API ${method} ${endpoint} failed: ${code} — ${message}`);
219
- }
220
- return json;
221
- };
222
- return buildClientMethods(invokeApi, accountEmail, async () => {
223
- /* no-op close */
224
- });
225
- }
226
- async function createOutlookDesktopClient(opts) {
227
- const timeoutMs = opts?.bootstrapTimeoutMs ?? DEFAULT_BOOTSTRAP_TIMEOUT_MS;
228
- // Strategy 1: Use cached token if still valid (no Playwright needed)
229
- const cached = await loadCachedToken();
230
- if (cached) {
231
- return createStatelessClient(cached.bearerToken, cached.accountEmail);
232
- }
233
- // Strategy 2: Launch Playwright headful to get a fresh token via SSO
234
- // Must be headful — Microsoft SSO blocks headless Chromium
235
- await node_fs_1.promises.mkdir(OUTLOOK_SESSION_DIR, { recursive: true });
236
- const playwright = await Promise.resolve().then(() => __importStar(require("playwright")));
237
- const context = await playwright.chromium.launchPersistentContext(OUTLOOK_SESSION_DIR, {
238
- headless: false,
239
- args: ["--start-maximized"],
240
- viewport: null,
241
- });
242
- const page = context.pages()[0] ?? (await context.newPage());
243
- const bootstrapPromise = waitForMailBearerToken(page, timeoutMs);
244
- await page.goto(OUTLOOK_WEB_URL, {
245
- waitUntil: "domcontentloaded",
246
- timeout: timeoutMs,
247
- });
248
- const { bearerToken, accountEmail } = await bootstrapPromise;
249
- // Cache the token for subsequent calls (avoids launching Playwright)
250
- await saveCachedToken(bearerToken, accountEmail);
251
- // Close browser immediately — we have the token, use stateless client
252
- await page.close().catch(() => undefined);
253
- await context.close().catch(() => undefined);
254
- return createStatelessClient(bearerToken, accountEmail);
255
- }
256
- function buildClientMethods(invokeApi, accountEmail, closeFn) {
257
- return {
258
- getAccountEmail: () => accountEmail,
259
- listMessages: async ({ folder = "inbox", limit = 20, filter, search }) => {
260
- const params = new URLSearchParams();
261
- params.set("$top", String(Math.max(1, Math.min(limit, 50))));
262
- params.set("$select", "Id,Subject,From,ToRecipients,ReceivedDateTime,IsRead,HasAttachments,BodyPreview,ConversationId");
263
- params.set("$orderby", "ReceivedDateTime desc");
264
- if (filter)
265
- params.set("$filter", filter);
266
- if (search)
267
- params.set("$search", `"${search}"`);
268
- const endpoint = `/me/mailFolders/${encodeURIComponent(folder)}/messages?${params.toString()}`;
269
- const json = await invokeApi("GET", endpoint);
270
- const rawMessages = Array.isArray(json.value) ? json.value : [];
271
- const messages = rawMessages
272
- .filter((m) => !!m && typeof m === "object")
273
- .map(toMessageView);
274
- return {
275
- accountEmail,
276
- folder,
277
- messages,
278
- totalCount: typeof json["@odata.count"] === "number" ? json["@odata.count"] : messages.length,
279
- };
280
- },
281
- getMessage: async ({ messageId }) => {
282
- const json = await invokeApi("GET", `/me/messages/${encodeURIComponent(messageId)}`);
283
- return toMessageDetail(json);
284
- },
285
- sendMessage: async ({ to, cc, subject, body, bodyType = "text" }) => {
286
- const toRecipients = to.map((email) => ({
287
- EmailAddress: { Address: email },
288
- }));
289
- const ccRecipients = (cc ?? []).map((email) => ({
290
- EmailAddress: { Address: email },
291
- }));
292
- await invokeApi("POST", "/me/sendMail", {
293
- Message: {
294
- Subject: subject,
295
- Body: { ContentType: bodyType === "html" ? "HTML" : "Text", Content: body },
296
- ToRecipients: toRecipients,
297
- ...(ccRecipients.length > 0 ? { CcRecipients: ccRecipients } : {}),
298
- },
299
- });
300
- return { accountEmail, status: "sent" };
301
- },
302
- replyMessage: async ({ messageId, body, bodyType = "text", replyAll = false }) => {
303
- const replyMethod = replyAll ? "ReplyAll" : "Reply";
304
- await invokeApi("POST", `/me/messages/${encodeURIComponent(messageId)}/${replyMethod}`, {
305
- Comment: body,
306
- ...(bodyType === "html"
307
- ? {
308
- Message: {
309
- Body: { ContentType: "HTML", Content: body },
310
- },
311
- }
312
- : {}),
313
- });
314
- return { accountEmail, status: "sent" };
315
- },
316
- close: closeFn,
317
- };
318
- }
@@ -1,155 +0,0 @@
1
- "use strict";
2
- /**
3
- * Tool Policy Engine
4
- *
5
- * Evaluates whether a tool is allowed based on allow/deny lists with group expansion.
6
- * Supports layered policy merging (intersection semantics) for arion + RunOptions policies.
7
- */
8
- Object.defineProperty(exports, "__esModule", { value: true });
9
- exports.TOOL_GROUPS = void 0;
10
- exports.expandGroups = expandGroups;
11
- exports.isToolAllowed = isToolAllowed;
12
- exports.mergePolicies = mergePolicies;
13
- /** Built-in tool groups */
14
- exports.TOOL_GROUPS = {
15
- "group:memory": [
16
- "remember",
17
- "recall",
18
- "forget",
19
- "recall_knowledge",
20
- "reflect",
21
- "search",
22
- "learn",
23
- "session_history",
24
- ],
25
- "group:web": ["web_search", "web_fetch", "browse", "browser"],
26
- "group:filesystem": ["read_file", "write_file", "edit_file", "glob", "grep", "ls", "apply_patch"],
27
- "group:shell": [
28
- "bash",
29
- "exec",
30
- "spawn",
31
- "kill",
32
- "list_processes",
33
- "wait_process",
34
- "write_stdin",
35
- "process",
36
- ],
37
- "group:arion": [
38
- "hatch_arion",
39
- "wake_arion",
40
- "rest_arion",
41
- "retire_arion",
42
- "delegate_arion",
43
- "manage_network",
44
- "list_clients",
45
- "deploy",
46
- ],
47
- "group:meta": [
48
- "ask_user",
49
- "quest_update",
50
- "quest_list",
51
- "search",
52
- "learn",
53
- "learn_tool",
54
- "learn_skill",
55
- "create_tool",
56
- "create_skill",
57
- "use_skill",
58
- "restart",
59
- "spawn_worker",
60
- "check_delegation",
61
- "pause_delegation",
62
- "resume_delegation",
63
- "quest_report",
64
- "self_diagnose",
65
- ],
66
- };
67
- /**
68
- * Expand group references in a policy list.
69
- * "group:memory" → ["remember", "recall", "forget", "reflect"]
70
- * Individual tool names pass through unchanged.
71
- * Unknown group names are ignored (treated as empty).
72
- */
73
- function expandGroups(names) {
74
- const result = new Set();
75
- for (const name of names) {
76
- const lower = name.toLowerCase();
77
- if (lower.startsWith("group:")) {
78
- const members = exports.TOOL_GROUPS[lower];
79
- if (members) {
80
- for (const member of members) {
81
- result.add(member.toLowerCase());
82
- }
83
- }
84
- // Unknown group names are silently ignored
85
- }
86
- else {
87
- result.add(lower);
88
- }
89
- }
90
- return result;
91
- }
92
- /**
93
- * Evaluate whether a tool is allowed by a policy.
94
- * Rules:
95
- * 1. If allow is empty/undefined and restrictAllow is false/undefined
96
- * → all tools allowed (then check deny)
97
- * 2. If allow is non-empty OR restrictAllow=true
98
- * → only listed tools/groups allowed (empty allow + restrictAllow=true denies all)
99
- * 3. Deny always wins over allow
100
- */
101
- function isToolAllowed(toolName, policy) {
102
- const normalized = toolName.toLowerCase();
103
- // Check allow list: when restricted, tool must be in allowed set.
104
- const isAllowRestricted = policy.restrictAllow === true || (policy.allow !== undefined && policy.allow.length > 0);
105
- if (isAllowRestricted) {
106
- const allowed = expandGroups(policy.allow ?? []);
107
- if (!allowed.has(normalized)) {
108
- return false;
109
- }
110
- }
111
- // Check deny list: deny always wins
112
- if (policy.deny && policy.deny.length > 0) {
113
- const denied = expandGroups(policy.deny);
114
- if (denied.has(normalized)) {
115
- return false;
116
- }
117
- }
118
- return true;
119
- }
120
- /**
121
- * Merge two policies (intersection). Used for layered evaluation:
122
- * arion policy ∩ RunOptions policy = effective policy.
123
- * A tool must be allowed by BOTH layers.
124
- */
125
- function mergePolicies(a, b) {
126
- // Merge deny: union of both deny lists
127
- const mergedDeny = [...(a.deny ?? []), ...(b.deny ?? [])];
128
- // Merge allow with restriction semantics:
129
- // - both restricted: intersection (possibly empty = deny all)
130
- // - one restricted: inherit that restriction
131
- // - neither restricted: unrestricted
132
- const aRestricts = a.restrictAllow === true || (a.allow?.length ?? 0) > 0;
133
- const bRestricts = b.restrictAllow === true || (b.allow?.length ?? 0) > 0;
134
- let mergedAllow;
135
- let mergedRestrictAllow = false;
136
- if (aRestricts && bRestricts) {
137
- const expandedA = expandGroups(a.allow ?? []);
138
- const expandedB = expandGroups(b.allow ?? []);
139
- mergedAllow = [...expandedA].filter((name) => expandedB.has(name));
140
- mergedRestrictAllow = true;
141
- }
142
- else if (aRestricts) {
143
- mergedAllow = [...(a.allow ?? [])];
144
- mergedRestrictAllow = true;
145
- }
146
- else if (bRestricts) {
147
- mergedAllow = [...(b.allow ?? [])];
148
- mergedRestrictAllow = true;
149
- }
150
- return {
151
- ...(mergedAllow !== undefined ? { allow: mergedAllow } : {}),
152
- ...(mergedRestrictAllow ? { restrictAllow: true } : {}),
153
- ...(mergedDeny.length ? { deny: mergedDeny } : {}),
154
- };
155
- }
@@ -1,66 +0,0 @@
1
- "use strict";
2
- Object.defineProperty(exports, "__esModule", { value: true });
3
- exports.BraveSearchProvider = void 0;
4
- const search_provider_js_1 = require("./search-provider.js");
5
- class BraveSearchProvider {
6
- env;
7
- name = "brave";
8
- requiresApiKey = true;
9
- priority = 1;
10
- constructor(env = process.env) {
11
- this.env = env;
12
- }
13
- isAvailable() {
14
- const apiKey = (0, search_provider_js_1.resolveSearchProviderEnv)(this.env).BRAVE_API_KEY;
15
- return Boolean(apiKey && apiKey.trim().length > 0);
16
- }
17
- async search(query, options) {
18
- const apiKey = (0, search_provider_js_1.resolveSearchProviderEnv)(this.env).BRAVE_API_KEY;
19
- if (!apiKey) {
20
- throw new Error("BRAVE_API_KEY environment variable is not set");
21
- }
22
- const limit = options?.limit ?? 5;
23
- const url = new URL("https://api.search.brave.com/res/v1/web/search");
24
- url.searchParams.set("q", query);
25
- url.searchParams.set("count", String(limit));
26
- // Handle timeRange option (map to Brave's freshness parameter)
27
- if (options?.timeRange) {
28
- const freshnessMap = {
29
- day: "pd",
30
- week: "pw",
31
- month: "pm",
32
- year: "py",
33
- };
34
- const freshness = freshnessMap[options.timeRange];
35
- if (freshness) {
36
- url.searchParams.set("freshness", freshness);
37
- }
38
- }
39
- const { signal, cleanup } = (0, search_provider_js_1.createProviderAbortSignal)(30_000, options?.signal);
40
- try {
41
- const response = await fetch(url.toString(), {
42
- method: "GET",
43
- headers: {
44
- Accept: "application/json",
45
- "X-Subscription-Token": apiKey,
46
- },
47
- signal,
48
- });
49
- if (!response.ok) {
50
- throw new Error(`Brave Search API error: ${response.status} ${response.statusText}`);
51
- }
52
- const json = await response.json();
53
- const webResults = json.web?.results || [];
54
- return webResults.map((r) => ({
55
- title: r.title,
56
- url: r.url,
57
- content: r.description,
58
- score: r.relevance_score,
59
- }));
60
- }
61
- finally {
62
- cleanup();
63
- }
64
- }
65
- }
66
- exports.BraveSearchProvider = BraveSearchProvider;