@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,434 +0,0 @@
1
- "use strict";
2
- /**
3
- * @aria/tools - Self-diagnose tool executor
4
- *
5
- * Pure signal diagnostic tool. 5 sections, zero noise:
6
- * 1. runtime — process health + resource leaks
7
- * 2. errors — structured errors from JSONL (active + rotated)
8
- * 3. crashes — crash markers + dumps
9
- * 4. databases — sizes, WAL health, schema version
10
- * 5. daemon — daemon audit + delegation journal
11
- */
12
- var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
13
- if (k2 === undefined) k2 = k;
14
- var desc = Object.getOwnPropertyDescriptor(m, k);
15
- if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
16
- desc = { enumerable: true, get: function() { return m[k]; } };
17
- }
18
- Object.defineProperty(o, k2, desc);
19
- }) : (function(o, m, k, k2) {
20
- if (k2 === undefined) k2 = k;
21
- o[k2] = m[k];
22
- }));
23
- var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
24
- Object.defineProperty(o, "default", { enumerable: true, value: v });
25
- }) : function(o, v) {
26
- o["default"] = v;
27
- });
28
- var __importStar = (this && this.__importStar) || (function () {
29
- var ownKeys = function(o) {
30
- ownKeys = Object.getOwnPropertyNames || function (o) {
31
- var ar = [];
32
- for (var k in o) if (Object.prototype.hasOwnProperty.call(o, k)) ar[ar.length] = k;
33
- return ar;
34
- };
35
- return ownKeys(o);
36
- };
37
- return function (mod) {
38
- if (mod && mod.__esModule) return mod;
39
- var result = {};
40
- if (mod != null) for (var k = ownKeys(mod), i = 0; i < k.length; i++) if (k[i] !== "default") __createBinding(result, mod, k[i]);
41
- __setModuleDefault(result, mod);
42
- return result;
43
- };
44
- })();
45
- Object.defineProperty(exports, "__esModule", { value: true });
46
- exports.executeSelfDiagnose = executeSelfDiagnose;
47
- const fs = __importStar(require("node:fs/promises"));
48
- const path = __importStar(require("node:path"));
49
- const os = __importStar(require("node:os"));
50
- const utils_js_1 = require("./utils.js");
51
- // ============================================================================
52
- // Constants
53
- // ============================================================================
54
- const ALL_SECTIONS = ["runtime", "errors", "crashes", "databases", "daemon", "network"];
55
- const ARIA_HOME = path.join(os.homedir(), ".aria");
56
- // ============================================================================
57
- // Helpers
58
- // ============================================================================
59
- async function safeStat(p) {
60
- try {
61
- const s = await fs.stat(p);
62
- return { size: s.size, mtime: s.mtime };
63
- }
64
- catch {
65
- return null;
66
- }
67
- }
68
- function truncate(s, max) {
69
- if (!s)
70
- return "";
71
- return s.length <= max ? s : s.slice(0, max - 3) + "...";
72
- }
73
- async function dirCount(dir) {
74
- try {
75
- const entries = await fs.readdir(dir);
76
- return entries.length;
77
- }
78
- catch {
79
- return 0;
80
- }
81
- }
82
- async function tailJsonl(filePath, maxLines) {
83
- try {
84
- const content = await fs.readFile(filePath, "utf-8");
85
- const lines = content.trim().split("\n").slice(-maxLines);
86
- return lines
87
- .map((l) => {
88
- try {
89
- return JSON.parse(l);
90
- }
91
- catch {
92
- return null;
93
- }
94
- })
95
- .filter(Boolean);
96
- }
97
- catch {
98
- return [];
99
- }
100
- }
101
- // ============================================================================
102
- // Section: runtime
103
- // ============================================================================
104
- async function getRuntime(ctx) {
105
- const mem = process.memoryUsage();
106
- // Resource leak detection
107
- const socketDirs = await dirCount(path.join(ARIA_HOME, "sock"));
108
- const ownerFiles = await dirCount(path.join(ARIA_HOME, "run/owners"));
109
- // Stuck restart detection
110
- let relaunchPending = false;
111
- try {
112
- const entries = await fs.readdir(path.join(ARIA_HOME, "relaunch-pending"));
113
- relaunchPending = entries.length > 0;
114
- }
115
- catch {
116
- /* dir may not exist */
117
- }
118
- return {
119
- pid: process.pid,
120
- uptime_s: Math.round(process.uptime()),
121
- heap_mb: Math.round(mem.heapUsed / 1e6),
122
- rss_mb: Math.round(mem.rss / 1e6),
123
- node_version: process.version,
124
- platform: process.platform,
125
- arch: process.arch,
126
- cwd: process.cwd(),
127
- session_id: ctx.currentSessionId ?? null,
128
- socket_dirs: socketDirs,
129
- owner_files: ownerFiles,
130
- relaunch_pending: relaunchPending,
131
- };
132
- }
133
- // ============================================================================
134
- // Section: errors (active + rotated JSONL, merged, filtered)
135
- // ============================================================================
136
- async function getErrors(since, focus, limit) {
137
- // Read both active and rotated logs
138
- const active = path.join(ARIA_HOME, "error-events.jsonl");
139
- const rotated = path.join(ARIA_HOME, "error-events.jsonl.1");
140
- const [activeEntries, rotatedEntries] = await Promise.all([
141
- tailJsonl(active, 200),
142
- tailJsonl(rotated, 100),
143
- ]);
144
- const all = [
145
- ...rotatedEntries.map((e) => ({ ...e, _src: "rotated" })),
146
- ...activeEntries.map((e) => ({ ...e, _src: "active" })),
147
- ];
148
- const filtered = all.filter((entry) => {
149
- const ts = entry.timestamp;
150
- if (ts) {
151
- const d = new Date(ts);
152
- if (d < since)
153
- return false;
154
- }
155
- if (focus) {
156
- const haystack = [
157
- String(entry.message ?? ""),
158
- String(entry.category ?? ""),
159
- String(entry.stackTrace ?? ""),
160
- ]
161
- .join(" ")
162
- .toLowerCase();
163
- if (!haystack.includes(focus))
164
- return false;
165
- }
166
- return true;
167
- });
168
- return filtered.slice(-limit).map((entry) => ({
169
- timestamp: String(entry.timestamp ?? ""),
170
- severity: String(entry.severity ?? "unknown"),
171
- category: String(entry.category ?? ""),
172
- message: String(entry.message ?? ""),
173
- stackTrace: truncate(String(entry.stackTrace ?? ""), 500),
174
- source: String(entry._src),
175
- }));
176
- }
177
- // ============================================================================
178
- // Section: crashes
179
- // ============================================================================
180
- async function getCrashes(limit) {
181
- const results = [];
182
- for (const subdir of ["crash-markers", "crash-dumps"]) {
183
- const dir = path.join(ARIA_HOME, subdir);
184
- try {
185
- const files = await fs.readdir(dir);
186
- const jsonFiles = files.filter((f) => f.endsWith(".json"));
187
- const stats = await Promise.all(jsonFiles.map(async (f) => {
188
- const p = path.join(dir, f);
189
- const s = await safeStat(p);
190
- return { file: f, path: p, stat: s };
191
- }));
192
- const sorted = stats
193
- .filter((f) => f.stat)
194
- .sort((a, b) => b.stat.mtime.getTime() - a.stat.mtime.getTime());
195
- for (const { file, path: fp, stat } of sorted.slice(0, limit)) {
196
- try {
197
- const raw = await fs.readFile(fp, "utf-8");
198
- const parsed = JSON.parse(raw);
199
- if (subdir === "crash-markers") {
200
- results.push({
201
- file: `${subdir}/${file}`,
202
- timestamp: stat.mtime.toISOString(),
203
- content: parsed,
204
- });
205
- }
206
- else {
207
- const msg = parsed.error_message ?? parsed.message ?? parsed.error ?? "";
208
- results.push({
209
- file: `${subdir}/${file}`,
210
- size: stat.size,
211
- timestamp: stat.mtime.toISOString(),
212
- error_message: truncate(String(msg), 200),
213
- });
214
- }
215
- }
216
- catch {
217
- results.push({
218
- file: `${subdir}/${file}`,
219
- timestamp: stat.mtime.toISOString(),
220
- error_message: "Failed to parse",
221
- });
222
- }
223
- }
224
- }
225
- catch {
226
- /* dir may not exist */
227
- }
228
- }
229
- return results;
230
- }
231
- // ============================================================================
232
- // Section: databases (sizes, WAL health, schema version)
233
- // ============================================================================
234
- async function getDatabases() {
235
- const results = [];
236
- // Key database paths (only real ones, not empty legacy ghosts)
237
- const dbPaths = [
238
- {
239
- name: "memory.db (main)",
240
- path: path.join(ARIA_HOME, "arions/ARIA/memory.db"),
241
- checkSchema: true,
242
- },
243
- { name: "history.db", path: path.join(ARIA_HOME, "history.db") },
244
- { name: "investigation-metrics.db", path: path.join(ARIA_HOME, "investigation-metrics.db") },
245
- { name: "network/state.db", path: path.join(ARIA_HOME, "network/state.db") },
246
- { name: "node/node-state.db", path: path.join(ARIA_HOME, "node/node-state.db") },
247
- ];
248
- for (const db of dbPaths) {
249
- const stat = await safeStat(db.path);
250
- if (!stat || stat.size === 0)
251
- continue;
252
- // WAL size — a large WAL means checkpoint isn't running
253
- const walStat = await safeStat(db.path + "-wal");
254
- const walMb = walStat && walStat.size > 0 ? (walStat.size / 1e6).toFixed(1) : null;
255
- // Schema version for the main DB (lightweight: only reads one int)
256
- let schemaVersion;
257
- if (db.checkSchema) {
258
- try {
259
- // Use a child process to avoid importing better-sqlite3 / locking the DB
260
- const { execFileSync } = await Promise.resolve().then(() => __importStar(require("node:child_process")));
261
- const out = execFileSync("sqlite3", [db.path, "SELECT MAX(version) FROM schema_version;"], {
262
- timeout: 1000,
263
- encoding: "utf-8",
264
- }).trim();
265
- schemaVersion = parseInt(out, 10) || undefined;
266
- }
267
- catch {
268
- // sqlite3 CLI not available or query failed — not critical
269
- }
270
- }
271
- const info = {
272
- name: db.name,
273
- size_mb: (stat.size / 1e6).toFixed(1),
274
- wal_mb: walMb,
275
- modified: stat.mtime.toISOString(),
276
- };
277
- if (schemaVersion !== undefined)
278
- info.schema_version = schemaVersion;
279
- results.push(info);
280
- }
281
- return results;
282
- }
283
- // ============================================================================
284
- // Section: daemon (audit + delegation journal)
285
- // ============================================================================
286
- async function getDaemon(limit) {
287
- const results = [];
288
- // Daemon audit log — restart loops, crashes, startup events
289
- const auditPath = path.join(ARIA_HOME, "arions/ARIA/daemon/audit.jsonl");
290
- const auditEntries = await tailJsonl(auditPath, limit);
291
- if (auditEntries.length > 0) {
292
- results.push({ source: "daemon/audit", entries: auditEntries });
293
- }
294
- // Delegation journal — worker spawn/complete/fail
295
- const delegationPath = path.join(ARIA_HOME, "arions/ARIA/delegation-journal.jsonl");
296
- const delegationEntries = await tailJsonl(delegationPath, limit);
297
- if (delegationEntries.length > 0) {
298
- results.push({ source: "delegation-journal", entries: delegationEntries });
299
- }
300
- return results;
301
- }
302
- // ============================================================================
303
- // Section: network (identity, peers, tunnels, TLS, diagnostics)
304
- // ============================================================================
305
- async function getNetwork(limit) {
306
- // Node identity from network/config.json
307
- let nodeId = null;
308
- let displayName = null;
309
- let listenPort = null;
310
- let externalEndpoint = null;
311
- try {
312
- const raw = await fs.readFile(path.join(ARIA_HOME, "network/config.json"), "utf-8");
313
- const cfg = JSON.parse(raw);
314
- nodeId = cfg.nodeId ?? null;
315
- displayName = cfg.localDisplayNameSnapshot ?? null;
316
- listenPort = cfg.listenPort ?? null;
317
- if (cfg.externalEndpoint) {
318
- externalEndpoint = `${cfg.externalEndpoint.address}:${cfg.externalEndpoint.port}`;
319
- }
320
- // Never expose private keys — only the fact we have them
321
- }
322
- catch {
323
- /* config may not exist */
324
- }
325
- // Peers from network/state.db (using sqlite3 CLI to avoid locking)
326
- const peers = [];
327
- let peerCount = 0;
328
- try {
329
- const { execFileSync } = await Promise.resolve().then(() => __importStar(require("node:child_process")));
330
- const out = execFileSync("sqlite3", [
331
- path.join(ARIA_HOME, "network/state.db"),
332
- "-json",
333
- `SELECT nodeId, displayName, status, lastSeen FROM network_peers ORDER BY lastSeen DESC LIMIT ${limit};`,
334
- ], { timeout: 1000, encoding: "utf-8" }).trim();
335
- if (out) {
336
- const rows = JSON.parse(out);
337
- for (const row of rows) {
338
- peers.push({
339
- node_id: row.nodeId ?? "",
340
- name: row.displayName ?? "",
341
- status: row.status ?? "unknown",
342
- last_seen: row.lastSeen ? new Date(row.lastSeen).toISOString() : null,
343
- });
344
- }
345
- }
346
- const countOut = execFileSync("sqlite3", [path.join(ARIA_HOME, "network/state.db"), "SELECT COUNT(*) FROM network_peers;"], { timeout: 1000, encoding: "utf-8" }).trim();
347
- peerCount = parseInt(countOut, 10) || 0;
348
- }
349
- catch {
350
- /* sqlite3 CLI not available or query failed */
351
- }
352
- // TLS state
353
- let tlsCertsPresent = false;
354
- let trustedCas = 0;
355
- try {
356
- await fs.access(path.join(ARIA_HOME, "network/tls/server.pem"));
357
- tlsCertsPresent = true;
358
- }
359
- catch {
360
- /* no TLS certs */
361
- }
362
- try {
363
- const cas = await fs.readdir(path.join(ARIA_HOME, "network/trusted-cas"));
364
- trustedCas = cas.filter((f) => f.endsWith(".pem")).length;
365
- }
366
- catch {
367
- /* dir may not exist */
368
- }
369
- // Recent tunnel events (connection attempts, handshakes, failures)
370
- const tunnelEvents = await tailJsonl(path.join(ARIA_HOME, "audit/wireguard-secure-tunnel.jsonl"), limit);
371
- // Recent diagnostics (disconnects, reconnects, errors)
372
- const diagnostics = await tailJsonl(path.join(ARIA_HOME, "audit/wireguard-diagnostics.jsonl"), limit);
373
- return {
374
- node_id: nodeId,
375
- display_name: displayName,
376
- listen_port: listenPort,
377
- external_endpoint: externalEndpoint,
378
- peer_count: peerCount,
379
- peers,
380
- tls_certs_present: tlsCertsPresent,
381
- trusted_cas: trustedCas,
382
- recent_tunnel_events: tunnelEvents,
383
- recent_diagnostics: diagnostics,
384
- };
385
- }
386
- // ============================================================================
387
- // Main Executor
388
- // ============================================================================
389
- async function executeSelfDiagnose(input, ctx) {
390
- if (ctx.abortSignal?.aborted)
391
- return (0, utils_js_1.fail)("Operation cancelled");
392
- const startMs = Date.now();
393
- const limit = input.limit ?? 10;
394
- const since = input.since ? new Date(input.since) : new Date(Date.now() - 3600_000);
395
- const focus = input.focus?.toLowerCase();
396
- const requested = input.sections ?? ALL_SECTIONS;
397
- const sectionsToRun = requested.filter((s) => ALL_SECTIONS.includes(s));
398
- const sectionFns = {
399
- runtime: () => getRuntime(ctx),
400
- errors: () => getErrors(since, focus, limit),
401
- crashes: () => getCrashes(limit),
402
- databases: () => getDatabases(),
403
- daemon: () => getDaemon(limit),
404
- network: () => getNetwork(limit),
405
- };
406
- const results = {};
407
- const errors = [];
408
- const returned = [];
409
- const withTimeout = (fn, name) => Promise.race([
410
- fn().then((r) => {
411
- returned.push(name);
412
- return r;
413
- }),
414
- new Promise((_, reject) => setTimeout(() => reject(new Error(`${name} timed out`)), 2000)),
415
- ]).catch((err) => {
416
- errors.push(`${name}: ${err.message}`);
417
- return null;
418
- });
419
- await Promise.all(sectionsToRun.map(async (name) => {
420
- const fn = sectionFns[name];
421
- if (fn)
422
- results[name] = await withTimeout(fn, name);
423
- }));
424
- const elapsed = Date.now() - startMs;
425
- results._meta = {
426
- sections_requested: sectionsToRun,
427
- sections_returned: returned,
428
- elapsed_ms: elapsed,
429
- errors,
430
- };
431
- const msg = `Diagnostics: ${returned.length}/${sectionsToRun.length} sections in ${elapsed}ms` +
432
- (errors.length > 0 ? ` (${errors.length} errors)` : "");
433
- return (0, utils_js_1.success)(msg, results);
434
- }