@agentage/cli 0.2.0 → 0.3.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 (58) hide show
  1. package/README.md +111 -199
  2. package/dist/cli.js +2 -1
  3. package/dist/cli.js.map +1 -1
  4. package/dist/commands/agents.d.ts.map +1 -1
  5. package/dist/commands/agents.js +35 -2
  6. package/dist/commands/agents.js.map +1 -1
  7. package/dist/commands/login.d.ts.map +1 -1
  8. package/dist/commands/login.js +71 -3
  9. package/dist/commands/login.js.map +1 -1
  10. package/dist/commands/logout.d.ts.map +1 -1
  11. package/dist/commands/logout.js +22 -2
  12. package/dist/commands/logout.js.map +1 -1
  13. package/dist/commands/machines.d.ts.map +1 -1
  14. package/dist/commands/machines.js +45 -3
  15. package/dist/commands/machines.js.map +1 -1
  16. package/dist/commands/run.d.ts.map +1 -1
  17. package/dist/commands/run.js +113 -15
  18. package/dist/commands/run.js.map +1 -1
  19. package/dist/commands/status.d.ts.map +1 -1
  20. package/dist/commands/status.js +11 -1
  21. package/dist/commands/status.js.map +1 -1
  22. package/dist/daemon/config.d.ts.map +1 -1
  23. package/dist/daemon/config.js +10 -3
  24. package/dist/daemon/config.js.map +1 -1
  25. package/dist/daemon/routes.d.ts.map +1 -1
  26. package/dist/daemon/routes.js +92 -5
  27. package/dist/daemon/routes.js.map +1 -1
  28. package/dist/daemon-entry.js +5 -0
  29. package/dist/daemon-entry.js.map +1 -1
  30. package/dist/hub/auth-callback.d.ts +4 -0
  31. package/dist/hub/auth-callback.d.ts.map +1 -0
  32. package/dist/hub/auth-callback.js +75 -0
  33. package/dist/hub/auth-callback.js.map +1 -0
  34. package/dist/hub/auth.d.ts +21 -0
  35. package/dist/hub/auth.d.ts.map +1 -0
  36. package/dist/hub/auth.js +26 -0
  37. package/dist/hub/auth.js.map +1 -0
  38. package/dist/hub/hub-client.d.ts +33 -0
  39. package/dist/hub/hub-client.d.ts.map +1 -0
  40. package/dist/hub/hub-client.js +64 -0
  41. package/dist/hub/hub-client.js.map +1 -0
  42. package/dist/hub/hub-sync.d.ts +9 -0
  43. package/dist/hub/hub-sync.d.ts.map +1 -0
  44. package/dist/hub/hub-sync.js +150 -0
  45. package/dist/hub/hub-sync.js.map +1 -0
  46. package/dist/hub/hub-ws.d.ts +7 -0
  47. package/dist/hub/hub-ws.d.ts.map +1 -0
  48. package/dist/hub/hub-ws.js +105 -0
  49. package/dist/hub/hub-ws.js.map +1 -0
  50. package/dist/hub/reconnection.d.ts +13 -0
  51. package/dist/hub/reconnection.d.ts.map +1 -0
  52. package/dist/hub/reconnection.js +39 -0
  53. package/dist/hub/reconnection.js.map +1 -0
  54. package/dist/utils/version.d.ts +2 -0
  55. package/dist/utils/version.d.ts.map +1 -0
  56. package/dist/utils/version.js +5 -0
  57. package/dist/utils/version.js.map +1 -0
  58. package/package.json +7 -4
@@ -0,0 +1,33 @@
1
+ import { type AuthState } from './auth.js';
2
+ export interface HubClient {
3
+ register: (machineData: {
4
+ id: string;
5
+ name: string;
6
+ platform: string;
7
+ arch: string;
8
+ daemonVersion: string;
9
+ }) => Promise<{
10
+ machineId: string;
11
+ }>;
12
+ heartbeat: (machineId: string, data: {
13
+ agents: Array<{
14
+ name: string;
15
+ description?: string;
16
+ version?: string;
17
+ tags?: string[];
18
+ }>;
19
+ activeRunIds: string[];
20
+ }) => Promise<{
21
+ pendingCommands: unknown[];
22
+ }>;
23
+ deregister: (machineId: string) => Promise<void>;
24
+ getMachines: () => Promise<unknown[]>;
25
+ getAgents: (machineId?: string) => Promise<unknown[]>;
26
+ createRun: (machineId: string, agentName: string, input: string) => Promise<unknown>;
27
+ cancelRun: (runId: string) => Promise<void>;
28
+ sendRunInput: (runId: string, text: string) => Promise<void>;
29
+ getRun: (runId: string) => Promise<unknown>;
30
+ getRunEvents: (runId: string, after?: string) => Promise<unknown[]>;
31
+ }
32
+ export declare const createHubClient: (hubUrl: string, auth: AuthState) => HubClient;
33
+ //# sourceMappingURL=hub-client.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"hub-client.d.ts","sourceRoot":"","sources":["../../src/hub/hub-client.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,KAAK,SAAS,EAAE,MAAM,WAAW,CAAC;AAE3C,MAAM,WAAW,SAAS;IACxB,QAAQ,EAAE,CAAC,WAAW,EAAE;QACtB,EAAE,EAAE,MAAM,CAAC;QACX,IAAI,EAAE,MAAM,CAAC;QACb,QAAQ,EAAE,MAAM,CAAC;QACjB,IAAI,EAAE,MAAM,CAAC;QACb,aAAa,EAAE,MAAM,CAAC;KACvB,KAAK,OAAO,CAAC;QAAE,SAAS,EAAE,MAAM,CAAA;KAAE,CAAC,CAAC;IACrC,SAAS,EAAE,CACT,SAAS,EAAE,MAAM,EACjB,IAAI,EAAE;QACJ,MAAM,EAAE,KAAK,CAAC;YAAE,IAAI,EAAE,MAAM,CAAC;YAAC,WAAW,CAAC,EAAE,MAAM,CAAC;YAAC,OAAO,CAAC,EAAE,MAAM,CAAC;YAAC,IAAI,CAAC,EAAE,MAAM,EAAE,CAAA;SAAE,CAAC,CAAC;QACzF,YAAY,EAAE,MAAM,EAAE,CAAC;KACxB,KACE,OAAO,CAAC;QAAE,eAAe,EAAE,OAAO,EAAE,CAAA;KAAE,CAAC,CAAC;IAC7C,UAAU,EAAE,CAAC,SAAS,EAAE,MAAM,KAAK,OAAO,CAAC,IAAI,CAAC,CAAC;IACjD,WAAW,EAAE,MAAM,OAAO,CAAC,OAAO,EAAE,CAAC,CAAC;IACtC,SAAS,EAAE,CAAC,SAAS,CAAC,EAAE,MAAM,KAAK,OAAO,CAAC,OAAO,EAAE,CAAC,CAAC;IACtD,SAAS,EAAE,CAAC,SAAS,EAAE,MAAM,EAAE,SAAS,EAAE,MAAM,EAAE,KAAK,EAAE,MAAM,KAAK,OAAO,CAAC,OAAO,CAAC,CAAC;IACrF,SAAS,EAAE,CAAC,KAAK,EAAE,MAAM,KAAK,OAAO,CAAC,IAAI,CAAC,CAAC;IAC5C,YAAY,EAAE,CAAC,KAAK,EAAE,MAAM,EAAE,IAAI,EAAE,MAAM,KAAK,OAAO,CAAC,IAAI,CAAC,CAAC;IAC7D,MAAM,EAAE,CAAC,KAAK,EAAE,MAAM,KAAK,OAAO,CAAC,OAAO,CAAC,CAAC;IAC5C,YAAY,EAAE,CAAC,KAAK,EAAE,MAAM,EAAE,KAAK,CAAC,EAAE,MAAM,KAAK,OAAO,CAAC,OAAO,EAAE,CAAC,CAAC;CACrE;AAED,eAAO,MAAM,eAAe,GAAI,QAAQ,MAAM,EAAE,MAAM,SAAS,KAAG,SA8EjE,CAAC"}
@@ -0,0 +1,64 @@
1
+ export const createHubClient = (hubUrl, auth) => {
2
+ const headers = () => ({
3
+ 'Content-Type': 'application/json',
4
+ Authorization: `Bearer ${auth.session.access_token}`,
5
+ });
6
+ const apiUrl = `${hubUrl}/api`;
7
+ const request = async (method, path, body) => {
8
+ const res = await fetch(`${apiUrl}${path}`, {
9
+ method,
10
+ headers: headers(),
11
+ body: body ? JSON.stringify(body) : undefined,
12
+ });
13
+ const json = (await res.json());
14
+ if (!res.ok || !json.success) {
15
+ const errMsg = typeof json.error === 'object' && json.error !== null
16
+ ? (json.error.message ?? 'Unknown error')
17
+ : String(json.error ?? 'Request failed');
18
+ throw new Error(`Hub API error (${res.status}): ${errMsg}`);
19
+ }
20
+ return json.data;
21
+ };
22
+ return {
23
+ register: async (machineData) => {
24
+ const data = await request('POST', '/machines', machineData);
25
+ return data;
26
+ },
27
+ heartbeat: async (machineId, body) => {
28
+ const data = await request('POST', `/machines/${machineId}/heartbeat`, body);
29
+ return data;
30
+ },
31
+ deregister: async (machineId) => {
32
+ await request('DELETE', `/machines/${machineId}`);
33
+ },
34
+ getMachines: async () => {
35
+ const data = await request('GET', '/machines');
36
+ return data;
37
+ },
38
+ getAgents: async (machineId) => {
39
+ const path = machineId ? `/agents?machine=${machineId}` : '/agents';
40
+ const data = await request('GET', path);
41
+ return data;
42
+ },
43
+ createRun: async (machineId, agentName, input) => {
44
+ const data = await request('POST', '/runs', { machineId, agentName, input });
45
+ return data;
46
+ },
47
+ cancelRun: async (runId) => {
48
+ await request('POST', `/runs/${runId}/cancel`);
49
+ },
50
+ sendRunInput: async (runId, text) => {
51
+ await request('POST', `/runs/${runId}/input`, { text });
52
+ },
53
+ getRun: async (runId) => {
54
+ const data = await request('GET', `/runs/${runId}`);
55
+ return data;
56
+ },
57
+ getRunEvents: async (runId, after) => {
58
+ const path = after ? `/runs/${runId}/events?after=${after}` : `/runs/${runId}/events`;
59
+ const data = await request('GET', path);
60
+ return data;
61
+ },
62
+ };
63
+ };
64
+ //# sourceMappingURL=hub-client.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"hub-client.js","sourceRoot":"","sources":["../../src/hub/hub-client.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,9 @@
1
+ export interface HubSync {
2
+ start: () => Promise<void>;
3
+ stop: () => Promise<void>;
4
+ isConnected: () => boolean;
5
+ }
6
+ export declare const createHubSync: () => HubSync;
7
+ export declare const getHubSync: () => HubSync;
8
+ export declare const resetHubSync: () => void;
9
+ //# sourceMappingURL=hub-sync.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"hub-sync.d.ts","sourceRoot":"","sources":["../../src/hub/hub-sync.ts"],"names":[],"mappings":"AAcA,MAAM,WAAW,OAAO;IACtB,KAAK,EAAE,MAAM,OAAO,CAAC,IAAI,CAAC,CAAC;IAC3B,IAAI,EAAE,MAAM,OAAO,CAAC,IAAI,CAAC,CAAC;IAC1B,WAAW,EAAE,MAAM,OAAO,CAAC;CAC5B;AAED,eAAO,MAAM,aAAa,QAAO,OAsJhC,CAAC;AAKF,eAAO,MAAM,UAAU,QAAO,OAK7B,CAAC;AAEF,eAAO,MAAM,YAAY,QAAO,IAE/B,CAAC"}
@@ -0,0 +1,150 @@
1
+ import { platform, arch } from 'node:os';
2
+ import { loadConfig } from '../daemon/config.js';
3
+ import { readAuth, saveAuth } from './auth.js';
4
+ import { createHubClient } from './hub-client.js';
5
+ import { createHubWs } from './hub-ws.js';
6
+ import { createReconnector } from './reconnection.js';
7
+ import { logInfo, logWarn } from '../daemon/logger.js';
8
+ import { getAgents } from '../daemon/routes.js';
9
+ import { cancelRun, sendInput, getRuns } from '../daemon/run-manager.js';
10
+ import { VERSION } from '../utils/version.js';
11
+ const HEARTBEAT_INTERVAL_MS = 30_000;
12
+ export const createHubSync = () => {
13
+ let hubClient = null;
14
+ let hubWs = null;
15
+ let heartbeatTimer = null;
16
+ let reconnector = null;
17
+ let connected = false;
18
+ const connectAll = async (auth) => {
19
+ const config = loadConfig();
20
+ hubClient = createHubClient(auth.hub.url, auth);
21
+ const result = await hubClient.register({
22
+ id: config.machine.id,
23
+ name: config.machine.name,
24
+ platform: platform(),
25
+ arch: arch(),
26
+ daemonVersion: VERSION,
27
+ });
28
+ // Save machineId in auth
29
+ auth.hub.machineId = result.machineId;
30
+ saveAuth(auth);
31
+ logInfo(`Registered with hub as machine ${result.machineId}`);
32
+ // Connect WebSocket
33
+ hubWs = createHubWs(auth.hub.url, auth.session.access_token, auth.hub.machineId, () => {
34
+ // On disconnect — trigger reconnection
35
+ connected = false;
36
+ logWarn('[hub-sync] WS disconnected, will reconnect via heartbeat');
37
+ reconnector?.start();
38
+ });
39
+ hubWs.connect();
40
+ connected = true;
41
+ };
42
+ const startHeartbeat = (auth) => {
43
+ if (heartbeatTimer)
44
+ clearInterval(heartbeatTimer);
45
+ heartbeatTimer = setInterval(async () => {
46
+ if (!hubClient)
47
+ return;
48
+ try {
49
+ const agents = getAgents().map((a) => ({
50
+ name: a.manifest.name,
51
+ description: a.manifest.description,
52
+ version: a.manifest.version,
53
+ tags: a.manifest.tags,
54
+ }));
55
+ const activeRunIds = getRuns()
56
+ .filter((r) => r.state === 'working' || r.state === 'submitted')
57
+ .map((r) => r.id);
58
+ const response = await hubClient.heartbeat(auth.hub.machineId, {
59
+ agents,
60
+ activeRunIds,
61
+ });
62
+ // Process pending commands from hub
63
+ if (response.pendingCommands && Array.isArray(response.pendingCommands)) {
64
+ for (const cmd of response.pendingCommands) {
65
+ if (cmd.type === 'cancel') {
66
+ cancelRun(cmd.runId);
67
+ logInfo(`Processed pending cancel for run ${cmd.runId}`);
68
+ }
69
+ else if (cmd.type === 'input' && cmd.payload) {
70
+ sendInput(cmd.runId, cmd.payload);
71
+ logInfo(`Processed pending input for run ${cmd.runId}`);
72
+ }
73
+ }
74
+ }
75
+ }
76
+ catch (err) {
77
+ logWarn(`Heartbeat failed: ${err instanceof Error ? err.message : String(err)}`);
78
+ }
79
+ }, HEARTBEAT_INTERVAL_MS);
80
+ };
81
+ return {
82
+ start: async () => {
83
+ const auth = readAuth();
84
+ if (!auth) {
85
+ logInfo('No auth — running in standalone mode');
86
+ return;
87
+ }
88
+ reconnector = createReconnector({
89
+ onReconnect: async () => {
90
+ await connectAll(auth);
91
+ startHeartbeat(auth);
92
+ },
93
+ onError: (err) => {
94
+ logWarn(`Hub connection failed: ${err instanceof Error ? err.message : String(err)}. Retrying...`);
95
+ },
96
+ });
97
+ try {
98
+ await connectAll(auth);
99
+ startHeartbeat(auth);
100
+ logInfo(`Connected to hub at ${auth.hub.url}`);
101
+ }
102
+ catch (err) {
103
+ logWarn(`Initial hub connection failed: ${err instanceof Error ? err.message : String(err)}. Will retry.`);
104
+ connected = false;
105
+ reconnector.start();
106
+ }
107
+ },
108
+ stop: async () => {
109
+ if (heartbeatTimer) {
110
+ clearInterval(heartbeatTimer);
111
+ heartbeatTimer = null;
112
+ }
113
+ if (reconnector) {
114
+ reconnector.stop();
115
+ reconnector = null;
116
+ }
117
+ if (hubWs) {
118
+ hubWs.disconnect();
119
+ hubWs = null;
120
+ }
121
+ if (hubClient && connected) {
122
+ const auth = readAuth();
123
+ if (auth) {
124
+ try {
125
+ await hubClient.deregister(auth.hub.machineId);
126
+ logInfo('Deregistered from hub');
127
+ }
128
+ catch {
129
+ // Best effort
130
+ }
131
+ }
132
+ }
133
+ connected = false;
134
+ hubClient = null;
135
+ },
136
+ isConnected: () => connected,
137
+ };
138
+ };
139
+ // Module-level singleton — lazy initialized in daemon-entry
140
+ let _hubSync = null;
141
+ export const getHubSync = () => {
142
+ if (!_hubSync) {
143
+ _hubSync = createHubSync();
144
+ }
145
+ return _hubSync;
146
+ };
147
+ export const resetHubSync = () => {
148
+ _hubSync = null;
149
+ };
150
+ //# sourceMappingURL=hub-sync.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"hub-sync.js","sourceRoot":"","sources":["../../src/hub/hub-sync.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,7 @@
1
+ export interface HubWs {
2
+ connect: () => void;
3
+ disconnect: () => void;
4
+ isConnected: () => boolean;
5
+ }
6
+ export declare const createHubWs: (hubUrl: string, token: string, machineId: string, onDisconnect?: () => void) => HubWs;
7
+ //# sourceMappingURL=hub-ws.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"hub-ws.d.ts","sourceRoot":"","sources":["../../src/hub/hub-ws.ts"],"names":[],"mappings":"AA+BA,MAAM,WAAW,KAAK;IACpB,OAAO,EAAE,MAAM,IAAI,CAAC;IACpB,UAAU,EAAE,MAAM,IAAI,CAAC;IACvB,WAAW,EAAE,MAAM,OAAO,CAAC;CAC5B;AAED,eAAO,MAAM,WAAW,GACtB,QAAQ,MAAM,EACd,OAAO,MAAM,EACb,WAAW,MAAM,EACjB,eAAe,MAAM,IAAI,KACxB,KAqHF,CAAC"}
@@ -0,0 +1,105 @@
1
+ import WebSocket from 'ws';
2
+ import { logInfo, logError } from '../daemon/logger.js';
3
+ import { getAgents } from '../daemon/routes.js';
4
+ import { startRun, cancelRun, sendInput, onRunEvent, onRunStateChange, } from '../daemon/run-manager.js';
5
+ export const createHubWs = (hubUrl, token, machineId, onDisconnect) => {
6
+ let ws = null;
7
+ let connected = false;
8
+ const eventUnsubscribers = [];
9
+ const send = (message) => {
10
+ if (ws?.readyState === WebSocket.OPEN) {
11
+ ws.send(JSON.stringify(message));
12
+ }
13
+ };
14
+ const handleExecute = async (msg) => {
15
+ const agents = getAgents();
16
+ const agent = agents.find((a) => a.manifest.name === msg.agentName);
17
+ if (!agent) {
18
+ send({ type: 'execute_rejected', requestId: msg.requestId, reason: 'Agent not found' });
19
+ return;
20
+ }
21
+ try {
22
+ const runId = await startRun(agent, msg.input.task, msg.input.config, msg.input.context);
23
+ send({ type: 'execute_accepted', requestId: msg.requestId, runId });
24
+ // Subscribe to run events and stream to hub
25
+ const unsubEvent = onRunEvent((eventRunId, event) => {
26
+ if (eventRunId === runId) {
27
+ send({ type: 'run_event', runId, event });
28
+ }
29
+ });
30
+ const unsubState = onRunStateChange((run) => {
31
+ if (run.id === runId) {
32
+ send({ type: 'run_state', runId, state: run.state, error: run.error, stats: run.stats });
33
+ }
34
+ });
35
+ eventUnsubscribers.push(unsubEvent, unsubState);
36
+ }
37
+ catch (err) {
38
+ send({
39
+ type: 'execute_rejected',
40
+ requestId: msg.requestId,
41
+ reason: err instanceof Error ? err.message : String(err),
42
+ });
43
+ }
44
+ };
45
+ const handleMessage = (data) => {
46
+ try {
47
+ const msg = JSON.parse(data.toString());
48
+ switch (msg.type) {
49
+ case 'execute':
50
+ handleExecute(msg).catch((err) => {
51
+ logError(`Execute handler error: ${err instanceof Error ? err.message : String(err)}`);
52
+ });
53
+ break;
54
+ case 'cancel':
55
+ cancelRun(msg.runId);
56
+ logInfo(`Hub requested cancel for run ${msg.runId}`);
57
+ break;
58
+ case 'input':
59
+ sendInput(msg.runId, msg.text);
60
+ logInfo(`Hub sent input for run ${msg.runId}`);
61
+ break;
62
+ }
63
+ }
64
+ catch {
65
+ logError('[hub-ws] Failed to parse message from hub');
66
+ }
67
+ };
68
+ return {
69
+ connect: () => {
70
+ const wsUrl = hubUrl.replace(/^http/, 'ws');
71
+ const url = `${wsUrl}/ws?token=${encodeURIComponent(token)}&machineId=${encodeURIComponent(machineId)}`;
72
+ ws = new WebSocket(url);
73
+ ws.on('open', () => {
74
+ connected = true;
75
+ logInfo('[hub-ws] Connected to hub');
76
+ });
77
+ ws.on('message', handleMessage);
78
+ ws.on('close', () => {
79
+ connected = false;
80
+ logInfo('[hub-ws] Disconnected from hub');
81
+ cleanup();
82
+ onDisconnect?.();
83
+ });
84
+ ws.on('error', (err) => {
85
+ logError(`[hub-ws] Error: ${err.message}`);
86
+ });
87
+ },
88
+ disconnect: () => {
89
+ cleanup();
90
+ if (ws) {
91
+ ws.close();
92
+ ws = null;
93
+ }
94
+ connected = false;
95
+ },
96
+ isConnected: () => connected,
97
+ };
98
+ function cleanup() {
99
+ for (const unsub of eventUnsubscribers) {
100
+ unsub();
101
+ }
102
+ eventUnsubscribers.length = 0;
103
+ }
104
+ };
105
+ //# sourceMappingURL=hub-ws.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"hub-ws.js","sourceRoot":"","sources":["../../src/hub/hub-ws.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,13 @@
1
+ export interface Reconnector {
2
+ start: () => void;
3
+ stop: () => void;
4
+ reset: () => void;
5
+ }
6
+ export interface ReconnectorOptions {
7
+ initialDelayMs?: number;
8
+ maxDelayMs?: number;
9
+ onReconnect: () => Promise<void>;
10
+ onError?: (err: unknown) => void;
11
+ }
12
+ export declare const createReconnector: (opts: ReconnectorOptions) => Reconnector;
13
+ //# sourceMappingURL=reconnection.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"reconnection.d.ts","sourceRoot":"","sources":["../../src/hub/reconnection.ts"],"names":[],"mappings":"AAAA,MAAM,WAAW,WAAW;IAC1B,KAAK,EAAE,MAAM,IAAI,CAAC;IAClB,IAAI,EAAE,MAAM,IAAI,CAAC;IACjB,KAAK,EAAE,MAAM,IAAI,CAAC;CACnB;AAED,MAAM,WAAW,kBAAkB;IACjC,cAAc,CAAC,EAAE,MAAM,CAAC;IACxB,UAAU,CAAC,EAAE,MAAM,CAAC;IACpB,WAAW,EAAE,MAAM,OAAO,CAAC,IAAI,CAAC,CAAC;IACjC,OAAO,CAAC,EAAE,CAAC,GAAG,EAAE,OAAO,KAAK,IAAI,CAAC;CAClC;AAED,eAAO,MAAM,iBAAiB,GAAI,MAAM,kBAAkB,KAAG,WAyC5D,CAAC"}
@@ -0,0 +1,39 @@
1
+ export const createReconnector = (opts) => {
2
+ const initialDelay = opts.initialDelayMs ?? 1000;
3
+ const maxDelay = opts.maxDelayMs ?? 30_000;
4
+ let currentDelay = initialDelay;
5
+ let timer = null;
6
+ let stopped = false;
7
+ const attempt = async () => {
8
+ if (stopped)
9
+ return;
10
+ try {
11
+ await opts.onReconnect();
12
+ currentDelay = initialDelay;
13
+ }
14
+ catch (err) {
15
+ opts.onError?.(err);
16
+ timer = setTimeout(() => {
17
+ attempt();
18
+ }, currentDelay);
19
+ currentDelay = Math.min(currentDelay * 2, maxDelay);
20
+ }
21
+ };
22
+ return {
23
+ start: () => {
24
+ stopped = false;
25
+ attempt();
26
+ },
27
+ stop: () => {
28
+ stopped = true;
29
+ if (timer) {
30
+ clearTimeout(timer);
31
+ timer = null;
32
+ }
33
+ },
34
+ reset: () => {
35
+ currentDelay = initialDelay;
36
+ },
37
+ };
38
+ };
39
+ //# sourceMappingURL=reconnection.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"reconnection.js","sourceRoot":"","sources":["../../src/hub/reconnection.ts"],"names":[],"mappings":"AAaA,MAAM,CAAC,MAAM,iBAAiB,GAAG,CAAC,IAAwB,EAAe,EAAE;IACzE,MAAM,YAAY,GAAG,IAAI,CAAC,cAAc,IAAI,IAAI,CAAC;IACjD,MAAM,QAAQ,GAAG,IAAI,CAAC,UAAU,IAAI,MAAM,CAAC;IAE3C,IAAI,YAAY,GAAG,YAAY,CAAC;IAChC,IAAI,KAAK,GAAyC,IAAI,CAAC;IACvD,IAAI,OAAO,GAAG,KAAK,CAAC;IAEpB,MAAM,OAAO,GAAG,KAAK,IAAmB,EAAE;QACxC,IAAI,OAAO;YAAE,OAAO;QAEpB,IAAI,CAAC;YACH,MAAM,IAAI,CAAC,WAAW,EAAE,CAAC;YACzB,YAAY,GAAG,YAAY,CAAC;QAC9B,CAAC;QAAC,OAAO,GAAG,EAAE,CAAC;YACb,IAAI,CAAC,OAAO,EAAE,CAAC,GAAG,CAAC,CAAC;YACpB,KAAK,GAAG,UAAU,CAAC,GAAG,EAAE;gBACtB,OAAO,EAAE,CAAC;YACZ,CAAC,EAAE,YAAY,CAAC,CAAC;YACjB,YAAY,GAAG,IAAI,CAAC,GAAG,CAAC,YAAY,GAAG,CAAC,EAAE,QAAQ,CAAC,CAAC;QACtD,CAAC;IACH,CAAC,CAAC;IAEF,OAAO;QACL,KAAK,EAAE,GAAG,EAAE;YACV,OAAO,GAAG,KAAK,CAAC;YAChB,OAAO,EAAE,CAAC;QACZ,CAAC;QAED,IAAI,EAAE,GAAG,EAAE;YACT,OAAO,GAAG,IAAI,CAAC;YACf,IAAI,KAAK,EAAE,CAAC;gBACV,YAAY,CAAC,KAAK,CAAC,CAAC;gBACpB,KAAK,GAAG,IAAI,CAAC;YACf,CAAC;QACH,CAAC;QAED,KAAK,EAAE,GAAG,EAAE;YACV,YAAY,GAAG,YAAY,CAAC;QAC9B,CAAC;KACF,CAAC;AACJ,CAAC,CAAC"}
@@ -0,0 +1,2 @@
1
+ export declare const VERSION: string;
2
+ //# sourceMappingURL=version.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"version.d.ts","sourceRoot":"","sources":["../../src/utils/version.ts"],"names":[],"mappings":"AAKA,eAAO,MAAM,OAAO,QAAc,CAAC"}
@@ -0,0 +1,5 @@
1
+ import { createRequire } from 'node:module';
2
+ const require = createRequire(import.meta.url);
3
+ const pkg = require('../../package.json');
4
+ export const VERSION = pkg.version;
5
+ //# sourceMappingURL=version.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"version.js","sourceRoot":"","sources":["../../src/utils/version.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,aAAa,EAAE,MAAM,aAAa,CAAC;AAE5C,MAAM,OAAO,GAAG,aAAa,CAAC,MAAM,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC;AAC/C,MAAM,GAAG,GAAG,OAAO,CAAC,oBAAoB,CAAwB,CAAC;AAEjE,MAAM,CAAC,MAAM,OAAO,GAAG,GAAG,CAAC,OAAO,CAAC"}
package/package.json CHANGED
@@ -1,13 +1,15 @@
1
1
  {
2
2
  "name": "@agentage/cli",
3
- "version": "0.2.0",
3
+ "version": "0.3.0",
4
4
  "description": "Agentage CLI and daemon — control plane for AI agents",
5
5
  "type": "module",
6
6
  "main": "./dist/index.js",
7
7
  "bin": {
8
8
  "agentage": "./dist/cli.js"
9
9
  },
10
- "files": ["dist"],
10
+ "files": [
11
+ "dist"
12
+ ],
11
13
  "engines": {
12
14
  "node": ">=22.0.0",
13
15
  "npm": ">=10.0.0"
@@ -29,6 +31,7 @@
29
31
  "dependencies": {
30
32
  "@agentage/core": "^0.2.0",
31
33
  "@agentage/platform": "^0.2.0",
34
+ "@supabase/supabase-js": "2.99.3",
32
35
  "chalk": "latest",
33
36
  "commander": "latest",
34
37
  "express": "latest",
@@ -43,13 +46,13 @@
43
46
  "@types/ws": "latest",
44
47
  "@typescript-eslint/eslint-plugin": "latest",
45
48
  "@typescript-eslint/parser": "latest",
49
+ "@vitest/coverage-v8": "latest",
46
50
  "eslint": "latest",
47
51
  "eslint-config-prettier": "latest",
48
52
  "eslint-plugin-prettier": "latest",
49
53
  "prettier": "latest",
50
54
  "typescript": "latest",
51
- "vitest": "latest",
52
- "@vitest/coverage-v8": "latest"
55
+ "vitest": "latest"
53
56
  },
54
57
  "repository": {
55
58
  "type": "git",