@agent-relay/daemon 0.1.0

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 (109) hide show
  1. package/dist/agent-manager.d.ts +134 -0
  2. package/dist/agent-manager.d.ts.map +1 -0
  3. package/dist/agent-manager.js +578 -0
  4. package/dist/agent-manager.js.map +1 -0
  5. package/dist/agent-registry.d.ts +99 -0
  6. package/dist/agent-registry.d.ts.map +1 -0
  7. package/dist/agent-registry.js +213 -0
  8. package/dist/agent-registry.js.map +1 -0
  9. package/dist/agent-signing.d.ts +158 -0
  10. package/dist/agent-signing.d.ts.map +1 -0
  11. package/dist/agent-signing.js +523 -0
  12. package/dist/agent-signing.js.map +1 -0
  13. package/dist/api.d.ts +106 -0
  14. package/dist/api.d.ts.map +1 -0
  15. package/dist/api.js +876 -0
  16. package/dist/api.js.map +1 -0
  17. package/dist/auth.d.ts +94 -0
  18. package/dist/auth.d.ts.map +1 -0
  19. package/dist/auth.js +197 -0
  20. package/dist/auth.js.map +1 -0
  21. package/dist/channel-membership-store.d.ts +55 -0
  22. package/dist/channel-membership-store.d.ts.map +1 -0
  23. package/dist/channel-membership-store.js +176 -0
  24. package/dist/channel-membership-store.js.map +1 -0
  25. package/dist/cli-auth.d.ts +89 -0
  26. package/dist/cli-auth.d.ts.map +1 -0
  27. package/dist/cli-auth.js +792 -0
  28. package/dist/cli-auth.js.map +1 -0
  29. package/dist/cloud-sync.d.ts +150 -0
  30. package/dist/cloud-sync.d.ts.map +1 -0
  31. package/dist/cloud-sync.js +446 -0
  32. package/dist/cloud-sync.js.map +1 -0
  33. package/dist/connection.d.ts +130 -0
  34. package/dist/connection.d.ts.map +1 -0
  35. package/dist/connection.js +438 -0
  36. package/dist/connection.js.map +1 -0
  37. package/dist/consensus-integration.d.ts +167 -0
  38. package/dist/consensus-integration.d.ts.map +1 -0
  39. package/dist/consensus-integration.js +371 -0
  40. package/dist/consensus-integration.js.map +1 -0
  41. package/dist/consensus.d.ts +271 -0
  42. package/dist/consensus.d.ts.map +1 -0
  43. package/dist/consensus.js +632 -0
  44. package/dist/consensus.js.map +1 -0
  45. package/dist/delivery-tracker.d.ts +34 -0
  46. package/dist/delivery-tracker.d.ts.map +1 -0
  47. package/dist/delivery-tracker.js +104 -0
  48. package/dist/delivery-tracker.js.map +1 -0
  49. package/dist/enhanced-features.d.ts +118 -0
  50. package/dist/enhanced-features.d.ts.map +1 -0
  51. package/dist/enhanced-features.js +176 -0
  52. package/dist/enhanced-features.js.map +1 -0
  53. package/dist/index.d.ts +31 -0
  54. package/dist/index.d.ts.map +1 -0
  55. package/dist/index.js +37 -0
  56. package/dist/index.js.map +1 -0
  57. package/dist/migrations/index.d.ts +73 -0
  58. package/dist/migrations/index.d.ts.map +1 -0
  59. package/dist/migrations/index.js +241 -0
  60. package/dist/migrations/index.js.map +1 -0
  61. package/dist/orchestrator.d.ts +217 -0
  62. package/dist/orchestrator.d.ts.map +1 -0
  63. package/dist/orchestrator.js +1143 -0
  64. package/dist/orchestrator.js.map +1 -0
  65. package/dist/rate-limiter.d.ts +68 -0
  66. package/dist/rate-limiter.d.ts.map +1 -0
  67. package/dist/rate-limiter.js +130 -0
  68. package/dist/rate-limiter.js.map +1 -0
  69. package/dist/registry.d.ts +9 -0
  70. package/dist/registry.d.ts.map +1 -0
  71. package/dist/registry.js +9 -0
  72. package/dist/registry.js.map +1 -0
  73. package/dist/relay-ledger.d.ts +261 -0
  74. package/dist/relay-ledger.d.ts.map +1 -0
  75. package/dist/relay-ledger.js +532 -0
  76. package/dist/relay-ledger.js.map +1 -0
  77. package/dist/relay-watchdog.d.ts +125 -0
  78. package/dist/relay-watchdog.d.ts.map +1 -0
  79. package/dist/relay-watchdog.js +611 -0
  80. package/dist/relay-watchdog.js.map +1 -0
  81. package/dist/repo-manager.d.ts +116 -0
  82. package/dist/repo-manager.d.ts.map +1 -0
  83. package/dist/repo-manager.js +384 -0
  84. package/dist/repo-manager.js.map +1 -0
  85. package/dist/router.d.ts +370 -0
  86. package/dist/router.d.ts.map +1 -0
  87. package/dist/router.js +1437 -0
  88. package/dist/router.js.map +1 -0
  89. package/dist/server.d.ts +174 -0
  90. package/dist/server.d.ts.map +1 -0
  91. package/dist/server.js +1001 -0
  92. package/dist/server.js.map +1 -0
  93. package/dist/spawn-manager.d.ts +78 -0
  94. package/dist/spawn-manager.d.ts.map +1 -0
  95. package/dist/spawn-manager.js +165 -0
  96. package/dist/spawn-manager.js.map +1 -0
  97. package/dist/sync-queue.d.ts +116 -0
  98. package/dist/sync-queue.d.ts.map +1 -0
  99. package/dist/sync-queue.js +361 -0
  100. package/dist/sync-queue.js.map +1 -0
  101. package/dist/types.d.ts +133 -0
  102. package/dist/types.d.ts.map +1 -0
  103. package/dist/types.js +6 -0
  104. package/dist/types.js.map +1 -0
  105. package/dist/workspace-manager.d.ts +80 -0
  106. package/dist/workspace-manager.d.ts.map +1 -0
  107. package/dist/workspace-manager.js +314 -0
  108. package/dist/workspace-manager.js.map +1 -0
  109. package/package.json +52 -0
@@ -0,0 +1,241 @@
1
+ /**
2
+ * SQLite Migration Runner for Relay Ledger
3
+ *
4
+ * Provides a lightweight migration system for the relay-ledger.db SQLite database.
5
+ * Tracks applied migrations in a __migrations table and runs them in order.
6
+ *
7
+ * Features:
8
+ * - Sequential migration execution by name
9
+ * - Idempotent (safe to run multiple times)
10
+ * - Tracks applied migrations with timestamps
11
+ * - Embedded SQL for portability (no file dependencies)
12
+ */
13
+ // ============================================================================
14
+ // Embedded Migrations
15
+ // ============================================================================
16
+ /**
17
+ * Embedded migrations - SQL is stored directly in code for portability.
18
+ * Add new migrations to this array in order.
19
+ */
20
+ const EMBEDDED_MIGRATIONS = [
21
+ {
22
+ name: '0001_initial',
23
+ sql: `
24
+ -- Relay Ledger - Initial Schema
25
+ -- Migration 0001: Initial tables for relay file tracking
26
+
27
+ -- Main relay files table
28
+ CREATE TABLE IF NOT EXISTS relay_files (
29
+ id INTEGER PRIMARY KEY AUTOINCREMENT,
30
+ file_id TEXT NOT NULL UNIQUE,
31
+ source_path TEXT NOT NULL,
32
+ archive_path TEXT,
33
+ agent_name TEXT NOT NULL,
34
+ message_type TEXT NOT NULL,
35
+ status TEXT NOT NULL DEFAULT 'pending',
36
+ retries INTEGER NOT NULL DEFAULT 0,
37
+ max_retries INTEGER NOT NULL DEFAULT 3,
38
+ discovered_at INTEGER NOT NULL,
39
+ processed_at INTEGER,
40
+ archived_at INTEGER,
41
+ error TEXT,
42
+ content_hash TEXT,
43
+ file_size INTEGER NOT NULL DEFAULT 0,
44
+ file_mtime_ns INTEGER,
45
+ file_inode INTEGER,
46
+ CONSTRAINT valid_status CHECK (status IN ('pending', 'processing', 'delivered', 'failed', 'archived'))
47
+ );
48
+
49
+ CREATE INDEX IF NOT EXISTS idx_relay_files_status ON relay_files(status);
50
+ CREATE INDEX IF NOT EXISTS idx_relay_files_agent ON relay_files(agent_name);
51
+ CREATE INDEX IF NOT EXISTS idx_relay_files_discovered ON relay_files(discovered_at);
52
+ CREATE INDEX IF NOT EXISTS idx_relay_files_source ON relay_files(source_path);
53
+
54
+ -- Agents registry table
55
+ CREATE TABLE IF NOT EXISTS agents (
56
+ id INTEGER PRIMARY KEY AUTOINCREMENT,
57
+ agent_name TEXT NOT NULL UNIQUE,
58
+ created_at INTEGER NOT NULL,
59
+ last_seen_at INTEGER NOT NULL,
60
+ status TEXT NOT NULL DEFAULT 'active',
61
+ metadata TEXT,
62
+ CONSTRAINT valid_agent_status CHECK (status IN ('active', 'inactive'))
63
+ );
64
+
65
+ CREATE INDEX IF NOT EXISTS idx_agents_status ON agents(status);
66
+ CREATE INDEX IF NOT EXISTS idx_agents_last_seen ON agents(last_seen_at);
67
+
68
+ -- Orchestrator state table (key-value store for crash recovery)
69
+ CREATE TABLE IF NOT EXISTS orchestrator_state (
70
+ key TEXT PRIMARY KEY,
71
+ value TEXT NOT NULL,
72
+ updated_at INTEGER NOT NULL
73
+ );
74
+
75
+ -- Pending operations table (crash recovery atomicity)
76
+ CREATE TABLE IF NOT EXISTS pending_operations (
77
+ id INTEGER PRIMARY KEY AUTOINCREMENT,
78
+ operation_type TEXT NOT NULL,
79
+ target_id TEXT NOT NULL,
80
+ payload TEXT,
81
+ created_at INTEGER NOT NULL,
82
+ attempts INTEGER NOT NULL DEFAULT 0,
83
+ last_attempt_at INTEGER,
84
+ error TEXT,
85
+ CONSTRAINT valid_operation_type CHECK (operation_type IN ('process', 'archive', 'cleanup'))
86
+ );
87
+
88
+ CREATE INDEX IF NOT EXISTS idx_pending_ops_type ON pending_operations(operation_type);
89
+ CREATE INDEX IF NOT EXISTS idx_pending_ops_target ON pending_operations(target_id);
90
+ `,
91
+ },
92
+ {
93
+ name: '0002_symlink_paths',
94
+ sql: `
95
+ -- Migration 0002: Add symlink path tracking for production workspace support
96
+ -- Workspaces in cloud/production may be symlinked for isolation.
97
+ -- We store both the original symlink path (for debugging) and canonical path (for operations).
98
+
99
+ -- Add symlink_path column to track original path (may be symlink)
100
+ ALTER TABLE relay_files ADD COLUMN symlink_path TEXT;
101
+
102
+ -- Create index for symlink lookups
103
+ CREATE INDEX IF NOT EXISTS idx_relay_files_symlink ON relay_files(symlink_path);
104
+ `,
105
+ },
106
+ ];
107
+ // ============================================================================
108
+ // Migration Runner
109
+ // ============================================================================
110
+ /**
111
+ * Create the migrations tracking table if it doesn't exist
112
+ */
113
+ export function ensureMigrationsTable(db) {
114
+ db.exec(`
115
+ CREATE TABLE IF NOT EXISTS __migrations (
116
+ id INTEGER PRIMARY KEY AUTOINCREMENT,
117
+ name TEXT NOT NULL UNIQUE,
118
+ applied_at INTEGER NOT NULL,
119
+ checksum TEXT NOT NULL
120
+ );
121
+ `);
122
+ }
123
+ /**
124
+ * Get all applied migrations
125
+ */
126
+ export function getAppliedMigrations(db) {
127
+ const rows = db.prepare(`
128
+ SELECT id, name, applied_at, checksum FROM __migrations ORDER BY id ASC
129
+ `).all();
130
+ return rows.map(row => ({
131
+ id: row.id,
132
+ name: row.name,
133
+ appliedAt: row.applied_at,
134
+ checksum: row.checksum,
135
+ }));
136
+ }
137
+ /**
138
+ * Check if a specific migration has been applied
139
+ */
140
+ export function isMigrationApplied(db, name) {
141
+ const row = db.prepare(`SELECT 1 FROM __migrations WHERE name = ?`).get(name);
142
+ return row !== undefined;
143
+ }
144
+ /**
145
+ * Record a migration as applied
146
+ */
147
+ export function recordMigration(db, name, checksum) {
148
+ db.prepare(`
149
+ INSERT INTO __migrations (name, applied_at, checksum) VALUES (?, ?, ?)
150
+ `).run(name, Date.now(), checksum);
151
+ }
152
+ /**
153
+ * Calculate a simple checksum for migration content
154
+ */
155
+ export function calculateChecksum(sql) {
156
+ // Simple hash for migration verification
157
+ let hash = 0;
158
+ for (let i = 0; i < sql.length; i++) {
159
+ const char = sql.charCodeAt(i);
160
+ hash = ((hash << 5) - hash) + char;
161
+ hash = hash & hash; // Convert to 32-bit integer
162
+ }
163
+ return Math.abs(hash).toString(16).padStart(8, '0');
164
+ }
165
+ /**
166
+ * Load migrations from embedded definitions
167
+ */
168
+ export function loadMigrationFiles() {
169
+ return EMBEDDED_MIGRATIONS.map(m => ({
170
+ name: m.name,
171
+ sql: m.sql,
172
+ checksum: calculateChecksum(m.sql),
173
+ }));
174
+ }
175
+ /**
176
+ * Run all pending migrations
177
+ */
178
+ export function runMigrations(db) {
179
+ const result = {
180
+ applied: [],
181
+ skipped: [],
182
+ errors: [],
183
+ };
184
+ // Ensure migrations table exists
185
+ ensureMigrationsTable(db);
186
+ // Load all migrations
187
+ const migrations = loadMigrationFiles();
188
+ // Get applied migrations
189
+ const applied = new Set(getAppliedMigrations(db).map(m => m.name));
190
+ // Run pending migrations in order
191
+ for (const migration of migrations) {
192
+ if (applied.has(migration.name)) {
193
+ result.skipped.push(migration.name);
194
+ continue;
195
+ }
196
+ try {
197
+ // Run migration in a transaction
198
+ db.transaction(() => {
199
+ db.exec(migration.sql);
200
+ recordMigration(db, migration.name, migration.checksum);
201
+ })();
202
+ result.applied.push(migration.name);
203
+ }
204
+ catch (err) {
205
+ const errorMessage = err instanceof Error ? err.message : String(err);
206
+ result.errors.push({ name: migration.name, error: errorMessage });
207
+ // Stop on first error
208
+ break;
209
+ }
210
+ }
211
+ return result;
212
+ }
213
+ /**
214
+ * Get pending migrations that haven't been applied yet
215
+ */
216
+ export function getPendingMigrations(db) {
217
+ ensureMigrationsTable(db);
218
+ const applied = new Set(getAppliedMigrations(db).map(m => m.name));
219
+ return loadMigrationFiles().filter(m => !applied.has(m.name));
220
+ }
221
+ /**
222
+ * Verify migration checksums match what was originally applied
223
+ */
224
+ export function verifyMigrations(db) {
225
+ const applied = getAppliedMigrations(db);
226
+ const files = loadMigrationFiles();
227
+ const fileMap = new Map(files.map(f => [f.name, f]));
228
+ const mismatches = [];
229
+ for (const record of applied) {
230
+ const file = fileMap.get(record.name);
231
+ if (file && file.checksum !== record.checksum) {
232
+ mismatches.push({
233
+ name: record.name,
234
+ expected: record.checksum,
235
+ actual: file.checksum,
236
+ });
237
+ }
238
+ }
239
+ return mismatches;
240
+ }
241
+ //# sourceMappingURL=index.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/migrations/index.ts"],"names":[],"mappings":"AAAA;;;;;;;;;;;GAWG;AA2BH,+EAA+E;AAC/E,sBAAsB;AACtB,+EAA+E;AAE/E;;;GAGG;AACH,MAAM,mBAAmB,GAAyC;IAChE;QACE,IAAI,EAAE,cAAc;QACpB,GAAG,EAAE;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;KAmEJ;KACF;IACD;QACE,IAAI,EAAE,oBAAoB;QAC1B,GAAG,EAAE;;;;;;;;;;KAUJ;KACF;CACF,CAAC;AAEF,+EAA+E;AAC/E,mBAAmB;AACnB,+EAA+E;AAE/E;;GAEG;AACH,MAAM,UAAU,qBAAqB,CAAC,EAAqB;IACzD,EAAE,CAAC,IAAI,CAAC;;;;;;;GAOP,CAAC,CAAC;AACL,CAAC;AAED;;GAEG;AACH,MAAM,UAAU,oBAAoB,CAAC,EAAqB;IACxD,MAAM,IAAI,GAAG,EAAE,CAAC,OAAO,CAAC;;GAEvB,CAAC,CAAC,GAAG,EAA+E,CAAC;IAEtF,OAAO,IAAI,CAAC,GAAG,CAAC,GAAG,CAAC,EAAE,CAAC,CAAC;QACtB,EAAE,EAAE,GAAG,CAAC,EAAE;QACV,IAAI,EAAE,GAAG,CAAC,IAAI;QACd,SAAS,EAAE,GAAG,CAAC,UAAU;QACzB,QAAQ,EAAE,GAAG,CAAC,QAAQ;KACvB,CAAC,CAAC,CAAC;AACN,CAAC;AAED;;GAEG;AACH,MAAM,UAAU,kBAAkB,CAAC,EAAqB,EAAE,IAAY;IACpE,MAAM,GAAG,GAAG,EAAE,CAAC,OAAO,CAAC,2CAA2C,CAAC,CAAC,GAAG,CAAC,IAAI,CAAC,CAAC;IAC9E,OAAO,GAAG,KAAK,SAAS,CAAC;AAC3B,CAAC;AAED;;GAEG;AACH,MAAM,UAAU,eAAe,CAAC,EAAqB,EAAE,IAAY,EAAE,QAAgB;IACnF,EAAE,CAAC,OAAO,CAAC;;GAEV,CAAC,CAAC,GAAG,CAAC,IAAI,EAAE,IAAI,CAAC,GAAG,EAAE,EAAE,QAAQ,CAAC,CAAC;AACrC,CAAC;AAED;;GAEG;AACH,MAAM,UAAU,iBAAiB,CAAC,GAAW;IAC3C,yCAAyC;IACzC,IAAI,IAAI,GAAG,CAAC,CAAC;IACb,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,GAAG,CAAC,MAAM,EAAE,CAAC,EAAE,EAAE,CAAC;QACpC,MAAM,IAAI,GAAG,GAAG,CAAC,UAAU,CAAC,CAAC,CAAC,CAAC;QAC/B,IAAI,GAAG,CAAC,CAAC,IAAI,IAAI,CAAC,CAAC,GAAG,IAAI,CAAC,GAAG,IAAI,CAAC;QACnC,IAAI,GAAG,IAAI,GAAG,IAAI,CAAC,CAAC,4BAA4B;IAClD,CAAC;IACD,OAAO,IAAI,CAAC,GAAG,CAAC,IAAI,CAAC,CAAC,QAAQ,CAAC,EAAE,CAAC,CAAC,QAAQ,CAAC,CAAC,EAAE,GAAG,CAAC,CAAC;AACtD,CAAC;AAED;;GAEG;AACH,MAAM,UAAU,kBAAkB;IAChC,OAAO,mBAAmB,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC;QACnC,IAAI,EAAE,CAAC,CAAC,IAAI;QACZ,GAAG,EAAE,CAAC,CAAC,GAAG;QACV,QAAQ,EAAE,iBAAiB,CAAC,CAAC,CAAC,GAAG,CAAC;KACnC,CAAC,CAAC,CAAC;AACN,CAAC;AAED;;GAEG;AACH,MAAM,UAAU,aAAa,CAAC,EAAqB;IACjD,MAAM,MAAM,GAAoB;QAC9B,OAAO,EAAE,EAAE;QACX,OAAO,EAAE,EAAE;QACX,MAAM,EAAE,EAAE;KACX,CAAC;IAEF,iCAAiC;IACjC,qBAAqB,CAAC,EAAE,CAAC,CAAC;IAE1B,sBAAsB;IACtB,MAAM,UAAU,GAAG,kBAAkB,EAAE,CAAC;IAExC,yBAAyB;IACzB,MAAM,OAAO,GAAG,IAAI,GAAG,CAAC,oBAAoB,CAAC,EAAE,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC;IAEnE,kCAAkC;IAClC,KAAK,MAAM,SAAS,IAAI,UAAU,EAAE,CAAC;QACnC,IAAI,OAAO,CAAC,GAAG,CAAC,SAAS,CAAC,IAAI,CAAC,EAAE,CAAC;YAChC,MAAM,CAAC,OAAO,CAAC,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,CAAC;YACpC,SAAS;QACX,CAAC;QAED,IAAI,CAAC;YACH,iCAAiC;YACjC,EAAE,CAAC,WAAW,CAAC,GAAG,EAAE;gBAClB,EAAE,CAAC,IAAI,CAAC,SAAS,CAAC,GAAG,CAAC,CAAC;gBACvB,eAAe,CAAC,EAAE,EAAE,SAAS,CAAC,IAAI,EAAE,SAAS,CAAC,QAAQ,CAAC,CAAC;YAC1D,CAAC,CAAC,EAAE,CAAC;YAEL,MAAM,CAAC,OAAO,CAAC,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,CAAC;QACtC,CAAC;QAAC,OAAO,GAAG,EAAE,CAAC;YACb,MAAM,YAAY,GAAG,GAAG,YAAY,KAAK,CAAC,CAAC,CAAC,GAAG,CAAC,OAAO,CAAC,CAAC,CAAC,MAAM,CAAC,GAAG,CAAC,CAAC;YACtE,MAAM,CAAC,MAAM,CAAC,IAAI,CAAC,EAAE,IAAI,EAAE,SAAS,CAAC,IAAI,EAAE,KAAK,EAAE,YAAY,EAAE,CAAC,CAAC;YAClE,sBAAsB;YACtB,MAAM;QACR,CAAC;IACH,CAAC;IAED,OAAO,MAAM,CAAC;AAChB,CAAC;AAED;;GAEG;AACH,MAAM,UAAU,oBAAoB,CAAC,EAAqB;IACxD,qBAAqB,CAAC,EAAE,CAAC,CAAC;IAC1B,MAAM,OAAO,GAAG,IAAI,GAAG,CAAC,oBAAoB,CAAC,EAAE,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC;IACnE,OAAO,kBAAkB,EAAE,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,OAAO,CAAC,GAAG,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC;AAChE,CAAC;AAED;;GAEG;AACH,MAAM,UAAU,gBAAgB,CAAC,EAAqB;IACpD,MAAM,OAAO,GAAG,oBAAoB,CAAC,EAAE,CAAC,CAAC;IACzC,MAAM,KAAK,GAAG,kBAAkB,EAAE,CAAC;IACnC,MAAM,OAAO,GAAG,IAAI,GAAG,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC,IAAI,EAAE,CAAC,CAAC,CAAC,CAAC,CAAC;IACrD,MAAM,UAAU,GAA8D,EAAE,CAAC;IAEjF,KAAK,MAAM,MAAM,IAAI,OAAO,EAAE,CAAC;QAC7B,MAAM,IAAI,GAAG,OAAO,CAAC,GAAG,CAAC,MAAM,CAAC,IAAI,CAAC,CAAC;QACtC,IAAI,IAAI,IAAI,IAAI,CAAC,QAAQ,KAAK,MAAM,CAAC,QAAQ,EAAE,CAAC;YAC9C,UAAU,CAAC,IAAI,CAAC;gBACd,IAAI,EAAE,MAAM,CAAC,IAAI;gBACjB,QAAQ,EAAE,MAAM,CAAC,QAAQ;gBACzB,MAAM,EAAE,IAAI,CAAC,QAAQ;aACtB,CAAC,CAAC;QACL,CAAC;IACH,CAAC;IAED,OAAO,UAAU,CAAC;AACpB,CAAC"}
@@ -0,0 +1,217 @@
1
+ /**
2
+ * Daemon Orchestrator
3
+ *
4
+ * Manages multiple workspace daemons and provides a unified API for the dashboard.
5
+ * This is the top-level service that runs by default, handling workspace switching
6
+ * and agent management across all connected repositories.
7
+ */
8
+ import { EventEmitter } from 'events';
9
+ import type { Workspace, Agent, AddWorkspaceRequest, SpawnAgentRequest } from './types.js';
10
+ export interface OrchestratorConfig {
11
+ /** Port for HTTP/WebSocket API */
12
+ port: number;
13
+ /** Host to bind to */
14
+ host: string;
15
+ /** Data directory for persistence */
16
+ dataDir: string;
17
+ /** Auto-start daemons for workspaces */
18
+ autoStartDaemons: boolean;
19
+ }
20
+ export declare class Orchestrator extends EventEmitter {
21
+ private config;
22
+ private workspaces;
23
+ private activeWorkspaceId?;
24
+ private server?;
25
+ private wss?;
26
+ private sessions;
27
+ private supervisor;
28
+ private workspacesFile;
29
+ private clientAlive;
30
+ private pingInterval?;
31
+ private heartbeatInterval?;
32
+ private memoryMonitor;
33
+ private agentHealth;
34
+ private memorySampleHandler?;
35
+ private memoryAlertHandler?;
36
+ constructor(config?: Partial<OrchestratorConfig>);
37
+ /**
38
+ * Start the orchestrator
39
+ */
40
+ start(): Promise<void>;
41
+ /**
42
+ * Stop the orchestrator
43
+ */
44
+ stop(): Promise<void>;
45
+ /**
46
+ * Add a workspace
47
+ */
48
+ addWorkspace(request: AddWorkspaceRequest): Workspace;
49
+ /**
50
+ * Remove a workspace
51
+ */
52
+ removeWorkspace(workspaceId: string): Promise<boolean>;
53
+ /**
54
+ * Switch to a workspace
55
+ */
56
+ switchWorkspace(workspaceId: string): Promise<Workspace>;
57
+ /**
58
+ * Get all workspaces
59
+ */
60
+ getWorkspaces(): Workspace[];
61
+ /**
62
+ * Get workspace by ID
63
+ */
64
+ getWorkspace(workspaceId: string): Workspace | undefined;
65
+ /**
66
+ * Get active workspace
67
+ */
68
+ getActiveWorkspace(): Workspace | undefined;
69
+ /**
70
+ * Spawn an agent in a workspace
71
+ */
72
+ spawnAgent(workspaceId: string, request: SpawnAgentRequest): Promise<Agent>;
73
+ /**
74
+ * Stop an agent
75
+ */
76
+ stopAgent(workspaceId: string, agentName: string): Promise<boolean>;
77
+ /**
78
+ * Get agents in a workspace
79
+ */
80
+ getAgents(workspaceId: string): Agent[];
81
+ /**
82
+ * Start daemon for a workspace
83
+ */
84
+ private startWorkspaceDaemon;
85
+ /**
86
+ * Stop daemon for a workspace
87
+ */
88
+ private stopWorkspaceDaemon;
89
+ /**
90
+ * Handle HTTP request
91
+ */
92
+ private handleRequest;
93
+ /**
94
+ * Handle WebSocket connection
95
+ */
96
+ private handleWebSocket;
97
+ /**
98
+ * Handle WebSocket message
99
+ */
100
+ private handleWebSocketMessage;
101
+ /**
102
+ * Send to WebSocket client
103
+ */
104
+ private sendToClient;
105
+ /**
106
+ * Broadcast event to all clients
107
+ */
108
+ private broadcastEvent;
109
+ /**
110
+ * Parse request body
111
+ */
112
+ private parseBody;
113
+ /**
114
+ * Load workspaces from disk
115
+ */
116
+ private loadWorkspaces;
117
+ /**
118
+ * Save workspaces to disk
119
+ */
120
+ private saveWorkspaces;
121
+ /**
122
+ * Find workspace by path
123
+ */
124
+ private findWorkspaceByPath;
125
+ /**
126
+ * Resolve path
127
+ */
128
+ private resolvePath;
129
+ /**
130
+ * Detect provider from workspace
131
+ */
132
+ private detectProvider;
133
+ /**
134
+ * Detect provider from CLI command
135
+ */
136
+ private detectProviderFromCli;
137
+ /**
138
+ * Get CLI command for provider
139
+ */
140
+ private getCliForProvider;
141
+ /**
142
+ * Get git info
143
+ */
144
+ private getGitInfo;
145
+ /**
146
+ * Convert to public workspace (without internal references)
147
+ */
148
+ private toPublicWorkspace;
149
+ /**
150
+ * Start agent health monitoring.
151
+ * Monitors PIDs for liveness and tracks memory/CPU usage.
152
+ */
153
+ private startHealthMonitoring;
154
+ /**
155
+ * Check all registered agents' PIDs are still alive.
156
+ * If a PID has died unexpectedly, broadcast a crash notification.
157
+ */
158
+ private checkAgentHeartbeats;
159
+ /**
160
+ * Check if a process is alive by sending signal 0.
161
+ */
162
+ private isProcessAlive;
163
+ /**
164
+ * Handle an agent crash - unregister and broadcast to other agents.
165
+ * Note: Agent is already removed from agentHealth map before this is called.
166
+ */
167
+ private handleAgentCrash;
168
+ /**
169
+ * Broadcast a resource alert (memory or CPU) to agents.
170
+ */
171
+ private broadcastResourceAlert;
172
+ /**
173
+ * Register an agent for health monitoring.
174
+ */
175
+ private registerAgentHealth;
176
+ /**
177
+ * Update PID for an agent (after restart).
178
+ *
179
+ * This method is intended for agent restart scenarios where the agent process
180
+ * is restarted with a new PID but should maintain continuity in health tracking.
181
+ * Currently unused but reserved for future auto-restart functionality.
182
+ *
183
+ * @param workspaceId - The workspace ID
184
+ * @param agentName - The agent name
185
+ * @param newPid - The new process ID after restart
186
+ */
187
+ private updateAgentHealthPid;
188
+ /**
189
+ * Mark an agent as releasing (to avoid crash announcement).
190
+ */
191
+ private markAgentReleasing;
192
+ /**
193
+ * Unregister an agent from health monitoring.
194
+ */
195
+ private unregisterAgentHealth;
196
+ /**
197
+ * Get health state for an agent.
198
+ */
199
+ private getAgentHealth;
200
+ /**
201
+ * Get health states for all agents in a workspace.
202
+ */
203
+ private getWorkspaceAgentHealth;
204
+ }
205
+ /**
206
+ * Start the orchestrator
207
+ */
208
+ export declare function startOrchestrator(config?: Partial<OrchestratorConfig>): Promise<Orchestrator>;
209
+ /**
210
+ * Stop the orchestrator
211
+ */
212
+ export declare function stopOrchestrator(): Promise<void>;
213
+ /**
214
+ * Get orchestrator instance
215
+ */
216
+ export declare function getOrchestrator(): Orchestrator | undefined;
217
+ //# sourceMappingURL=orchestrator.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"orchestrator.d.ts","sourceRoot":"","sources":["../src/orchestrator.ts"],"names":[],"mappings":"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"}