@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.
- package/dist/agent-manager.d.ts +134 -0
- package/dist/agent-manager.d.ts.map +1 -0
- package/dist/agent-manager.js +578 -0
- package/dist/agent-manager.js.map +1 -0
- package/dist/agent-registry.d.ts +99 -0
- package/dist/agent-registry.d.ts.map +1 -0
- package/dist/agent-registry.js +213 -0
- package/dist/agent-registry.js.map +1 -0
- package/dist/agent-signing.d.ts +158 -0
- package/dist/agent-signing.d.ts.map +1 -0
- package/dist/agent-signing.js +523 -0
- package/dist/agent-signing.js.map +1 -0
- package/dist/api.d.ts +106 -0
- package/dist/api.d.ts.map +1 -0
- package/dist/api.js +876 -0
- package/dist/api.js.map +1 -0
- package/dist/auth.d.ts +94 -0
- package/dist/auth.d.ts.map +1 -0
- package/dist/auth.js +197 -0
- package/dist/auth.js.map +1 -0
- package/dist/channel-membership-store.d.ts +55 -0
- package/dist/channel-membership-store.d.ts.map +1 -0
- package/dist/channel-membership-store.js +176 -0
- package/dist/channel-membership-store.js.map +1 -0
- package/dist/cli-auth.d.ts +89 -0
- package/dist/cli-auth.d.ts.map +1 -0
- package/dist/cli-auth.js +792 -0
- package/dist/cli-auth.js.map +1 -0
- package/dist/cloud-sync.d.ts +150 -0
- package/dist/cloud-sync.d.ts.map +1 -0
- package/dist/cloud-sync.js +446 -0
- package/dist/cloud-sync.js.map +1 -0
- package/dist/connection.d.ts +130 -0
- package/dist/connection.d.ts.map +1 -0
- package/dist/connection.js +438 -0
- package/dist/connection.js.map +1 -0
- package/dist/consensus-integration.d.ts +167 -0
- package/dist/consensus-integration.d.ts.map +1 -0
- package/dist/consensus-integration.js +371 -0
- package/dist/consensus-integration.js.map +1 -0
- package/dist/consensus.d.ts +271 -0
- package/dist/consensus.d.ts.map +1 -0
- package/dist/consensus.js +632 -0
- package/dist/consensus.js.map +1 -0
- package/dist/delivery-tracker.d.ts +34 -0
- package/dist/delivery-tracker.d.ts.map +1 -0
- package/dist/delivery-tracker.js +104 -0
- package/dist/delivery-tracker.js.map +1 -0
- package/dist/enhanced-features.d.ts +118 -0
- package/dist/enhanced-features.d.ts.map +1 -0
- package/dist/enhanced-features.js +176 -0
- package/dist/enhanced-features.js.map +1 -0
- package/dist/index.d.ts +31 -0
- package/dist/index.d.ts.map +1 -0
- package/dist/index.js +37 -0
- package/dist/index.js.map +1 -0
- package/dist/migrations/index.d.ts +73 -0
- package/dist/migrations/index.d.ts.map +1 -0
- package/dist/migrations/index.js +241 -0
- package/dist/migrations/index.js.map +1 -0
- package/dist/orchestrator.d.ts +217 -0
- package/dist/orchestrator.d.ts.map +1 -0
- package/dist/orchestrator.js +1143 -0
- package/dist/orchestrator.js.map +1 -0
- package/dist/rate-limiter.d.ts +68 -0
- package/dist/rate-limiter.d.ts.map +1 -0
- package/dist/rate-limiter.js +130 -0
- package/dist/rate-limiter.js.map +1 -0
- package/dist/registry.d.ts +9 -0
- package/dist/registry.d.ts.map +1 -0
- package/dist/registry.js +9 -0
- package/dist/registry.js.map +1 -0
- package/dist/relay-ledger.d.ts +261 -0
- package/dist/relay-ledger.d.ts.map +1 -0
- package/dist/relay-ledger.js +532 -0
- package/dist/relay-ledger.js.map +1 -0
- package/dist/relay-watchdog.d.ts +125 -0
- package/dist/relay-watchdog.d.ts.map +1 -0
- package/dist/relay-watchdog.js +611 -0
- package/dist/relay-watchdog.js.map +1 -0
- package/dist/repo-manager.d.ts +116 -0
- package/dist/repo-manager.d.ts.map +1 -0
- package/dist/repo-manager.js +384 -0
- package/dist/repo-manager.js.map +1 -0
- package/dist/router.d.ts +370 -0
- package/dist/router.d.ts.map +1 -0
- package/dist/router.js +1437 -0
- package/dist/router.js.map +1 -0
- package/dist/server.d.ts +174 -0
- package/dist/server.d.ts.map +1 -0
- package/dist/server.js +1001 -0
- package/dist/server.js.map +1 -0
- package/dist/spawn-manager.d.ts +78 -0
- package/dist/spawn-manager.d.ts.map +1 -0
- package/dist/spawn-manager.js +165 -0
- package/dist/spawn-manager.js.map +1 -0
- package/dist/sync-queue.d.ts +116 -0
- package/dist/sync-queue.d.ts.map +1 -0
- package/dist/sync-queue.js +361 -0
- package/dist/sync-queue.js.map +1 -0
- package/dist/types.d.ts +133 -0
- package/dist/types.d.ts.map +1 -0
- package/dist/types.js +6 -0
- package/dist/types.js.map +1 -0
- package/dist/workspace-manager.d.ts +80 -0
- package/dist/workspace-manager.d.ts.map +1 -0
- package/dist/workspace-manager.js +314 -0
- package/dist/workspace-manager.js.map +1 -0
- 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":"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"}
|
|
@@ -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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"}
|