cosmios 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 (73) hide show
  1. package/dist/adapters/claude-code.d.ts +7 -0
  2. package/dist/adapters/claude-code.d.ts.map +1 -0
  3. package/dist/adapters/claude-code.js +128 -0
  4. package/dist/adapters/claude-code.js.map +1 -0
  5. package/dist/adapters/codex.d.ts +7 -0
  6. package/dist/adapters/codex.d.ts.map +1 -0
  7. package/dist/adapters/codex.js +140 -0
  8. package/dist/adapters/codex.js.map +1 -0
  9. package/dist/adapters/interface.d.ts +18 -0
  10. package/dist/adapters/interface.d.ts.map +1 -0
  11. package/dist/adapters/interface.js +2 -0
  12. package/dist/adapters/interface.js.map +1 -0
  13. package/dist/api-client.d.ts +15 -0
  14. package/dist/api-client.d.ts.map +1 -0
  15. package/dist/api-client.js +170 -0
  16. package/dist/api-client.js.map +1 -0
  17. package/dist/cli.d.ts +3 -0
  18. package/dist/cli.d.ts.map +1 -0
  19. package/dist/cli.js +228 -0
  20. package/dist/cli.js.map +1 -0
  21. package/dist/config.d.ts +6 -0
  22. package/dist/config.d.ts.map +1 -0
  23. package/dist/config.js +27 -0
  24. package/dist/config.js.map +1 -0
  25. package/dist/connection.d.ts +26 -0
  26. package/dist/connection.d.ts.map +1 -0
  27. package/dist/connection.js +92 -0
  28. package/dist/connection.js.map +1 -0
  29. package/dist/heartbeat.d.ts +2 -0
  30. package/dist/heartbeat.d.ts.map +1 -0
  31. package/dist/heartbeat.js +101 -0
  32. package/dist/heartbeat.js.map +1 -0
  33. package/dist/index.d.ts +31 -0
  34. package/dist/index.d.ts.map +1 -0
  35. package/dist/index.js +116 -0
  36. package/dist/index.js.map +1 -0
  37. package/dist/journal.d.ts +13 -0
  38. package/dist/journal.d.ts.map +1 -0
  39. package/dist/journal.js +47 -0
  40. package/dist/journal.js.map +1 -0
  41. package/dist/log-sanitizer.d.ts +6 -0
  42. package/dist/log-sanitizer.d.ts.map +1 -0
  43. package/dist/log-sanitizer.js +36 -0
  44. package/dist/log-sanitizer.js.map +1 -0
  45. package/dist/logger.d.ts +12 -0
  46. package/dist/logger.d.ts.map +1 -0
  47. package/dist/logger.js +32 -0
  48. package/dist/logger.js.map +1 -0
  49. package/dist/poller.d.ts +8 -0
  50. package/dist/poller.d.ts.map +1 -0
  51. package/dist/poller.js +52 -0
  52. package/dist/poller.js.map +1 -0
  53. package/dist/preview-poller.d.ts +3 -0
  54. package/dist/preview-poller.d.ts.map +1 -0
  55. package/dist/preview-poller.js +499 -0
  56. package/dist/preview-poller.js.map +1 -0
  57. package/dist/rollback-poller.d.ts +2 -0
  58. package/dist/rollback-poller.d.ts.map +1 -0
  59. package/dist/rollback-poller.js +46 -0
  60. package/dist/rollback-poller.js.map +1 -0
  61. package/dist/run-handler.d.ts +16 -0
  62. package/dist/run-handler.d.ts.map +1 -0
  63. package/dist/run-handler.js +159 -0
  64. package/dist/run-handler.js.map +1 -0
  65. package/dist/snapshot.d.ts +3 -0
  66. package/dist/snapshot.d.ts.map +1 -0
  67. package/dist/snapshot.js +96 -0
  68. package/dist/snapshot.js.map +1 -0
  69. package/dist/types.d.ts +37 -0
  70. package/dist/types.d.ts.map +1 -0
  71. package/dist/types.js +2 -0
  72. package/dist/types.js.map +1 -0
  73. package/package.json +46 -0
package/dist/cli.js ADDED
@@ -0,0 +1,228 @@
1
+ #!/usr/bin/env node
2
+ import { hostname, platform } from 'node:os';
3
+ import { loadConfig, saveConfig, getConfigPath } from './config.js';
4
+ import { connectRunner } from './api-client.js';
5
+ import { CosmiosRunner } from './index.js';
6
+ // ANSI colors — degrade gracefully if TTY not supported
7
+ const tty = process.stdout.isTTY;
8
+ const c = {
9
+ green: (s) => tty ? `\x1b[32m${s}\x1b[0m` : s,
10
+ red: (s) => tty ? `\x1b[31m${s}\x1b[0m` : s,
11
+ yellow: (s) => tty ? `\x1b[33m${s}\x1b[0m` : s,
12
+ blue: (s) => tty ? `\x1b[34m${s}\x1b[0m` : s,
13
+ gray: (s) => tty ? `\x1b[90m${s}\x1b[0m` : s,
14
+ bold: (s) => tty ? `\x1b[1m${s}\x1b[0m` : s,
15
+ cyan: (s) => tty ? `\x1b[36m${s}\x1b[0m` : s,
16
+ };
17
+ function log(msg) { process.stdout.write(msg + '\n'); }
18
+ function err(msg) { process.stderr.write(c.red('✗') + ' ' + msg + '\n'); }
19
+ function ok(msg) { log(c.green('✓') + ' ' + msg); }
20
+ function info(msg) { log(c.gray('·') + ' ' + msg); }
21
+ const [, , command, ...args] = process.argv;
22
+ // Parse --flag value pairs from args
23
+ function parseFlags(a) {
24
+ const flags = {};
25
+ for (let i = 0; i < a.length; i++) {
26
+ if (a[i].startsWith('--') && i + 1 < a.length && !a[i + 1].startsWith('--')) {
27
+ flags[a[i].slice(2)] = a[i + 1];
28
+ i++;
29
+ }
30
+ }
31
+ return flags;
32
+ }
33
+ // ─── register ────────────────────────────────────────────────────────────────
34
+ async function cmdRegister() {
35
+ const serverUrl = args[0];
36
+ const apiKey = args[1];
37
+ if (!serverUrl || !apiKey) {
38
+ err('usage: cosmios register <server_url> <api_key>');
39
+ process.exit(1);
40
+ }
41
+ log(c.bold('Registering runner…'));
42
+ try {
43
+ const remote = await connectRunner(serverUrl, apiKey, { hostname: hostname(), os: platform() });
44
+ saveConfig({
45
+ runner_id: remote.runner_id,
46
+ api_key: apiKey,
47
+ server_url: serverUrl,
48
+ supabase_url: remote.supabase_url,
49
+ supabase_anon_key: remote.supabase_anon_key
50
+ });
51
+ ok('Registered');
52
+ info(`runner_id ${c.cyan(remote.runner_id)}`);
53
+ info(`server ${c.cyan(serverUrl)}`);
54
+ info(`config ${c.gray(getConfigPath())}`);
55
+ }
56
+ catch (e) {
57
+ err(`Registration failed: ${e instanceof Error ? e.message : String(e)}`);
58
+ process.exit(1);
59
+ }
60
+ }
61
+ // ─── start ───────────────────────────────────────────────────────────────────
62
+ async function cmdStart() {
63
+ const config = loadConfig();
64
+ if (!config) {
65
+ err('Not registered. Run: cosmios register <server_url> <api_key>');
66
+ process.exit(1);
67
+ }
68
+ const runner = CosmiosRunner.fromConfig();
69
+ let wasConnected = false;
70
+ let disconnectTimer = null;
71
+ runner.onStatusChange((status) => {
72
+ if (status === 'connected') {
73
+ if (disconnectTimer) {
74
+ clearTimeout(disconnectTimer);
75
+ disconnectTimer = null;
76
+ }
77
+ if (!wasConnected)
78
+ log(c.green('◉') + ' Realtime connected');
79
+ wasConnected = true;
80
+ }
81
+ else if (status === 'disconnected' && wasConnected) {
82
+ // Only log if disconnected for more than 5s (skip transient blips)
83
+ if (!disconnectTimer) {
84
+ disconnectTimer = setTimeout(() => {
85
+ log(c.yellow('○') + ' Realtime disconnected — reconnecting…');
86
+ disconnectTimer = null;
87
+ }, 5_000);
88
+ }
89
+ }
90
+ });
91
+ await runner.start();
92
+ log(c.bold('\nCOSMIOS Runner') + c.gray(` · ${config.runner_id.slice(0, 8)}`));
93
+ log(c.gray('Polling for runs every 3s. Press Ctrl+C to stop.\n'));
94
+ process.on('SIGINT', () => { runner.stop(); process.exit(0); });
95
+ process.on('SIGTERM', () => { runner.stop(); process.exit(0); });
96
+ process.stdin.resume();
97
+ }
98
+ // ─── status ──────────────────────────────────────────────────────────────────
99
+ async function cmdStatus() {
100
+ const config = loadConfig();
101
+ if (!config) {
102
+ err('Not registered. Run: cosmios register <server_url> <api_key>');
103
+ process.exit(1);
104
+ }
105
+ try {
106
+ await connectRunner(config.server_url, config.api_key, { hostname: hostname(), os: platform() });
107
+ ok(c.green('online'));
108
+ info(`runner_id ${c.cyan(config.runner_id)}`);
109
+ info(`server ${c.cyan(config.server_url)}`);
110
+ info(`config ${c.gray(getConfigPath())}`);
111
+ }
112
+ catch (e) {
113
+ err(`offline — ${e instanceof Error ? e.message : String(e)}`);
114
+ process.exit(1);
115
+ }
116
+ }
117
+ // ─── run ─────────────────────────────────────────────────────────────────────
118
+ async function cmdRun() {
119
+ const config = loadConfig();
120
+ if (!config) {
121
+ err('Not registered. Run: cosmios register <server_url> <api_key>');
122
+ process.exit(1);
123
+ }
124
+ const flags = parseFlags(args);
125
+ const workspace = flags['workspace'] ?? flags['w'];
126
+ const task = flags['task'] ?? flags['t'];
127
+ if (!workspace || !task) {
128
+ err('usage: cosmios run --workspace <path> --task "<description>"');
129
+ process.exit(1);
130
+ }
131
+ log(c.bold('Dispatching run…'));
132
+ info(`workspace ${c.cyan(workspace)}`);
133
+ info(`task ${c.cyan(task)}`);
134
+ // Create run via server API
135
+ const createRes = await fetch(`${config.server_url}/api/runs`, {
136
+ method: 'POST',
137
+ headers: { 'content-type': 'application/json', authorization: `Bearer ${config.api_key}` },
138
+ body: JSON.stringify({ workspace, agent: 'claude-code', command: task })
139
+ }).catch(e => { throw new Error(`network_error:${e.message}`); });
140
+ if (!createRes.ok) {
141
+ const body = await createRes.json().catch(() => ({}));
142
+ err(`Failed to create run: ${body.error ?? createRes.status}`);
143
+ process.exit(1);
144
+ }
145
+ const { run_id } = await createRes.json();
146
+ ok(`Run created: ${c.cyan(run_id.slice(0, 8))}`);
147
+ log('');
148
+ // Stream logs by polling
149
+ const TERMINAL = new Set(['completed', 'failed', 'cancelled', 'rollback_available', 'rolled_back']);
150
+ const deadline = Date.now() + 10 * 60 * 1000; // 10 min timeout
151
+ let lastStatus = 'created';
152
+ let lastEventCount = 0;
153
+ while (Date.now() < deadline) {
154
+ await sleep(1500);
155
+ const pollRes = await fetch(`${config.server_url}/api/runs/${run_id}`, {
156
+ headers: { authorization: `Bearer ${config.api_key}` }
157
+ }).catch(() => null);
158
+ if (!pollRes?.ok)
159
+ continue;
160
+ const data = await pollRes.json().catch(() => null);
161
+ if (!data)
162
+ continue;
163
+ // Print new log lines
164
+ const events = data.events ?? [];
165
+ for (let i = lastEventCount; i < events.length; i++) {
166
+ const ev = events[i];
167
+ if (ev.type === 'log') {
168
+ const d = ev.data;
169
+ const line = d.message ?? '';
170
+ if (d.stream === 'stderr') {
171
+ process.stderr.write(c.red(line) + '\n');
172
+ }
173
+ else {
174
+ process.stdout.write(line + '\n');
175
+ }
176
+ }
177
+ }
178
+ lastEventCount = events.length;
179
+ // Status change
180
+ if (data.status !== lastStatus) {
181
+ log('');
182
+ if (data.status === 'running')
183
+ log(c.blue('▶') + ' Running…');
184
+ else if (data.status === 'snapshotting')
185
+ log(c.yellow('◎') + ' Snapshotting…');
186
+ else if (data.status === 'completed')
187
+ ok('Completed');
188
+ else if (data.status === 'failed')
189
+ err('Failed');
190
+ else if (data.status === 'rollback_available')
191
+ log(c.cyan('↩') + ' Rollback available');
192
+ lastStatus = data.status;
193
+ }
194
+ if (TERMINAL.has(data.status))
195
+ break;
196
+ }
197
+ process.exit(lastStatus === 'completed' || lastStatus === 'rollback_available' ? 0 : 1);
198
+ }
199
+ function sleep(ms) {
200
+ return new Promise(r => setTimeout(r, ms));
201
+ }
202
+ // ─── router ──────────────────────────────────────────────────────────────────
203
+ const commands = {
204
+ register: cmdRegister,
205
+ start: cmdStart,
206
+ status: cmdStatus,
207
+ run: cmdRun,
208
+ };
209
+ const handler = commands[command ?? ''];
210
+ if (!handler) {
211
+ log(c.bold('cosmios') + c.gray(' — COSMIOS Runner'));
212
+ log('');
213
+ log('Commands:');
214
+ log(` ${c.cyan('register')} <server_url> <api_key> Register this machine`);
215
+ log(` ${c.cyan('start')} Start the runner daemon`);
216
+ log(` ${c.cyan('status')} Check connection status`);
217
+ log(` ${c.cyan('run')} --workspace <path> --task "<text>" Dispatch a run`);
218
+ log('');
219
+ log('Examples:');
220
+ log(c.gray(' cosmios register https://myapp.com rs_live_xxx'));
221
+ log(c.gray(' cosmios run --workspace /my/project --task "add unit tests to auth.ts"'));
222
+ process.exit(command ? 1 : 0);
223
+ }
224
+ handler().catch((e) => {
225
+ err(e instanceof Error ? e.message : String(e));
226
+ process.exit(1);
227
+ });
228
+ //# sourceMappingURL=cli.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"cli.js","sourceRoot":"","sources":["../src/cli.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,6 @@
1
+ import type { RunnerConfig } from './types.js';
2
+ export declare function getConfigDir(): string;
3
+ export declare function getConfigPath(): string;
4
+ export declare function loadConfig(): RunnerConfig | null;
5
+ export declare function saveConfig(config: RunnerConfig): void;
6
+ //# sourceMappingURL=config.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"config.d.ts","sourceRoot":"","sources":["../src/config.ts"],"names":[],"mappings":"AAGA,OAAO,KAAK,EAAE,YAAY,EAAE,MAAM,YAAY,CAAC;AAK/C,wBAAgB,YAAY,IAAI,MAAM,CAErC;AAED,wBAAgB,aAAa,IAAI,MAAM,CAEtC;AAED,wBAAgB,UAAU,IAAI,YAAY,GAAG,IAAI,CAQhD;AAED,wBAAgB,UAAU,CAAC,MAAM,EAAE,YAAY,GAAG,IAAI,CAGrD"}
package/dist/config.js ADDED
@@ -0,0 +1,27 @@
1
+ import { readFileSync, writeFileSync, mkdirSync, existsSync } from 'node:fs';
2
+ import { homedir } from 'node:os';
3
+ import { join } from 'node:path';
4
+ const CONFIG_DIR = join(homedir(), '.cosmios');
5
+ const CONFIG_PATH = join(CONFIG_DIR, 'config.json');
6
+ export function getConfigDir() {
7
+ return CONFIG_DIR;
8
+ }
9
+ export function getConfigPath() {
10
+ return CONFIG_PATH;
11
+ }
12
+ export function loadConfig() {
13
+ if (!existsSync(CONFIG_PATH))
14
+ return null;
15
+ try {
16
+ const raw = readFileSync(CONFIG_PATH, 'utf8');
17
+ return JSON.parse(raw);
18
+ }
19
+ catch {
20
+ return null;
21
+ }
22
+ }
23
+ export function saveConfig(config) {
24
+ mkdirSync(CONFIG_DIR, { recursive: true });
25
+ writeFileSync(CONFIG_PATH, JSON.stringify(config, null, 2), { mode: 0o600 });
26
+ }
27
+ //# sourceMappingURL=config.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"config.js","sourceRoot":"","sources":["../src/config.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,YAAY,EAAE,aAAa,EAAE,SAAS,EAAE,UAAU,EAAE,MAAM,SAAS,CAAC;AAC7E,OAAO,EAAE,OAAO,EAAE,MAAM,SAAS,CAAC;AAClC,OAAO,EAAE,IAAI,EAAE,MAAM,WAAW,CAAC;AAGjC,MAAM,UAAU,GAAG,IAAI,CAAC,OAAO,EAAE,EAAE,UAAU,CAAC,CAAC;AAC/C,MAAM,WAAW,GAAG,IAAI,CAAC,UAAU,EAAE,aAAa,CAAC,CAAC;AAEpD,MAAM,UAAU,YAAY;IAC1B,OAAO,UAAU,CAAC;AACpB,CAAC;AAED,MAAM,UAAU,aAAa;IAC3B,OAAO,WAAW,CAAC;AACrB,CAAC;AAED,MAAM,UAAU,UAAU;IACxB,IAAI,CAAC,UAAU,CAAC,WAAW,CAAC;QAAE,OAAO,IAAI,CAAC;IAC1C,IAAI,CAAC;QACH,MAAM,GAAG,GAAG,YAAY,CAAC,WAAW,EAAE,MAAM,CAAC,CAAC;QAC9C,OAAO,IAAI,CAAC,KAAK,CAAC,GAAG,CAAiB,CAAC;IACzC,CAAC;IAAC,MAAM,CAAC;QACP,OAAO,IAAI,CAAC;IACd,CAAC;AACH,CAAC;AAED,MAAM,UAAU,UAAU,CAAC,MAAoB;IAC7C,SAAS,CAAC,UAAU,EAAE,EAAE,SAAS,EAAE,IAAI,EAAE,CAAC,CAAC;IAC3C,aAAa,CAAC,WAAW,EAAE,IAAI,CAAC,SAAS,CAAC,MAAM,EAAE,IAAI,EAAE,CAAC,CAAC,EAAE,EAAE,IAAI,EAAE,KAAK,EAAE,CAAC,CAAC;AAC/E,CAAC"}
@@ -0,0 +1,26 @@
1
+ import type { RunnerConfig, ConnectionStatus } from './types.js';
2
+ export interface ConnectionOptions {
3
+ config: RunnerConfig;
4
+ onStatusChange?: (status: ConnectionStatus) => void;
5
+ onMessage?: (event: string, payload: unknown) => void;
6
+ }
7
+ export declare class RunnerConnection {
8
+ private supabase;
9
+ private channel;
10
+ private config;
11
+ private onStatusChange?;
12
+ private onMessage?;
13
+ private reconnectAttempt;
14
+ private reconnectTimer;
15
+ private keepaliveTimer;
16
+ private stopped;
17
+ constructor(options: ConnectionOptions);
18
+ updateConfig(config: RunnerConfig): void;
19
+ connect(): void;
20
+ disconnect(): void;
21
+ private startKeepalive;
22
+ private stopKeepalive;
23
+ private clearReconnectTimer;
24
+ private scheduleReconnect;
25
+ }
26
+ //# sourceMappingURL=connection.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"connection.d.ts","sourceRoot":"","sources":["../src/connection.ts"],"names":[],"mappings":"AAEA,OAAO,KAAK,EAAE,YAAY,EAAE,gBAAgB,EAAE,MAAM,YAAY,CAAC;AAMjE,MAAM,WAAW,iBAAiB;IAChC,MAAM,EAAE,YAAY,CAAC;IACrB,cAAc,CAAC,EAAE,CAAC,MAAM,EAAE,gBAAgB,KAAK,IAAI,CAAC;IACpD,SAAS,CAAC,EAAE,CAAC,KAAK,EAAE,MAAM,EAAE,OAAO,EAAE,OAAO,KAAK,IAAI,CAAC;CACvD;AAED,qBAAa,gBAAgB;IAC3B,OAAO,CAAC,QAAQ,CAAkC;IAClD,OAAO,CAAC,OAAO,CAAgC;IAC/C,OAAO,CAAC,MAAM,CAAe;IAC7B,OAAO,CAAC,cAAc,CAAC,CAAqC;IAC5D,OAAO,CAAC,SAAS,CAAC,CAA4C;IAC9D,OAAO,CAAC,gBAAgB,CAAK;IAC7B,OAAO,CAAC,cAAc,CAA8C;IACpE,OAAO,CAAC,cAAc,CAA+C;IACrE,OAAO,CAAC,OAAO,CAAS;gBAEZ,OAAO,EAAE,iBAAiB;IAWtC,YAAY,CAAC,MAAM,EAAE,YAAY,GAAG,IAAI;IAIxC,OAAO,IAAI,IAAI;IA2Bf,UAAU,IAAI,IAAI;IAWlB,OAAO,CAAC,cAAc;IAOtB,OAAO,CAAC,aAAa;IAOrB,OAAO,CAAC,mBAAmB;IAO3B,OAAO,CAAC,iBAAiB;CAe1B"}
@@ -0,0 +1,92 @@
1
+ import { createClient } from '@supabase/supabase-js';
2
+ const RECONNECT_BASE_MS = 2_000;
3
+ const RECONNECT_MAX_MS = 60_000;
4
+ const KEEPALIVE_MS = 25_000;
5
+ export class RunnerConnection {
6
+ supabase;
7
+ channel = null;
8
+ config;
9
+ onStatusChange;
10
+ onMessage;
11
+ reconnectAttempt = 0;
12
+ reconnectTimer = null;
13
+ keepaliveTimer = null;
14
+ stopped = false;
15
+ constructor(options) {
16
+ this.config = options.config;
17
+ this.onStatusChange = options.onStatusChange;
18
+ this.onMessage = options.onMessage;
19
+ this.supabase = createClient(options.config.supabase_url, options.config.supabase_anon_key, { auth: { persistSession: false } });
20
+ }
21
+ updateConfig(config) {
22
+ this.config = config;
23
+ }
24
+ connect() {
25
+ if (this.stopped)
26
+ return;
27
+ this.onStatusChange?.('connecting');
28
+ const channelName = `runner:${this.config.runner_id}`;
29
+ this.channel = this.supabase.channel(channelName, {
30
+ config: { broadcast: { self: false } }
31
+ });
32
+ this.channel
33
+ .on('broadcast', { event: '*' }, ({ event, payload }) => {
34
+ this.onMessage?.(event, payload);
35
+ })
36
+ .subscribe((status) => {
37
+ if (status === 'SUBSCRIBED') {
38
+ this.reconnectAttempt = 0;
39
+ this.startKeepalive();
40
+ this.onStatusChange?.('connected');
41
+ }
42
+ else if (status === 'CLOSED' || status === 'CHANNEL_ERROR') {
43
+ this.stopKeepalive();
44
+ this.onStatusChange?.('disconnected');
45
+ this.scheduleReconnect();
46
+ }
47
+ });
48
+ }
49
+ disconnect() {
50
+ this.stopped = true;
51
+ this.clearReconnectTimer();
52
+ this.stopKeepalive();
53
+ if (this.channel) {
54
+ this.supabase.removeChannel(this.channel);
55
+ this.channel = null;
56
+ }
57
+ this.onStatusChange?.('disconnected');
58
+ }
59
+ startKeepalive() {
60
+ this.stopKeepalive();
61
+ this.keepaliveTimer = setInterval(() => {
62
+ this.channel?.send({ type: 'broadcast', event: 'ping', payload: {} });
63
+ }, KEEPALIVE_MS);
64
+ }
65
+ stopKeepalive() {
66
+ if (this.keepaliveTimer) {
67
+ clearInterval(this.keepaliveTimer);
68
+ this.keepaliveTimer = null;
69
+ }
70
+ }
71
+ clearReconnectTimer() {
72
+ if (this.reconnectTimer) {
73
+ clearTimeout(this.reconnectTimer);
74
+ this.reconnectTimer = null;
75
+ }
76
+ }
77
+ scheduleReconnect() {
78
+ if (this.stopped)
79
+ return;
80
+ this.clearReconnectTimer();
81
+ const delay = Math.min(RECONNECT_BASE_MS * 2 ** this.reconnectAttempt, RECONNECT_MAX_MS);
82
+ this.reconnectAttempt++;
83
+ this.reconnectTimer = setTimeout(() => {
84
+ if (this.channel) {
85
+ this.supabase.removeChannel(this.channel);
86
+ this.channel = null;
87
+ }
88
+ this.connect();
89
+ }, delay);
90
+ }
91
+ }
92
+ //# sourceMappingURL=connection.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"connection.js","sourceRoot":"","sources":["../src/connection.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,2 @@
1
+ export declare function startHeartbeat(serverUrl: string, apiKey: string, onError?: (err: Error) => void): () => void;
2
+ //# sourceMappingURL=heartbeat.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"heartbeat.d.ts","sourceRoot":"","sources":["../src/heartbeat.ts"],"names":[],"mappings":"AAsFA,wBAAgB,cAAc,CAC5B,SAAS,EAAE,MAAM,EACjB,MAAM,EAAE,MAAM,EACd,OAAO,CAAC,EAAE,CAAC,GAAG,EAAE,KAAK,KAAK,IAAI,GAC7B,MAAM,IAAI,CAoBZ"}
@@ -0,0 +1,101 @@
1
+ import { sendHeartbeat, replayJournal } from './api-client.js';
2
+ import { statfs } from 'node:fs/promises';
3
+ import { cpus, freemem, totalmem } from 'node:os';
4
+ import { journalSize } from './journal.js';
5
+ const HEARTBEAT_INTERVAL_MS = 30_000;
6
+ let previousCpuSample = null;
7
+ function round2(value) {
8
+ return Number(value.toFixed(2));
9
+ }
10
+ function takeCpuSample() {
11
+ const cores = cpus();
12
+ if (!cores || cores.length === 0)
13
+ return null;
14
+ let idle = 0;
15
+ let total = 0;
16
+ for (const core of cores) {
17
+ idle += core.times.idle;
18
+ total += core.times.user + core.times.nice + core.times.sys + core.times.irq + core.times.idle;
19
+ }
20
+ return { idle, total };
21
+ }
22
+ function readCpuUsagePercent() {
23
+ const current = takeCpuSample();
24
+ if (!current)
25
+ return undefined;
26
+ if (!previousCpuSample) {
27
+ previousCpuSample = current;
28
+ return undefined;
29
+ }
30
+ const idleDiff = current.idle - previousCpuSample.idle;
31
+ const totalDiff = current.total - previousCpuSample.total;
32
+ previousCpuSample = current;
33
+ if (totalDiff <= 0)
34
+ return undefined;
35
+ const usage = (1 - idleDiff / totalDiff) * 100;
36
+ if (!Number.isFinite(usage))
37
+ return undefined;
38
+ return Math.max(0, Math.min(100, round2(usage)));
39
+ }
40
+ function readRamUsagePercent() {
41
+ const total = totalmem();
42
+ if (!total)
43
+ return undefined;
44
+ const used = total - freemem();
45
+ const usage = (used / total) * 100;
46
+ if (!Number.isFinite(usage))
47
+ return undefined;
48
+ return Math.max(0, Math.min(100, round2(usage)));
49
+ }
50
+ async function readDiskUsagePercent() {
51
+ try {
52
+ const stats = await statfs(process.cwd());
53
+ const blocks = Number(stats.blocks);
54
+ const available = Number(stats.bavail);
55
+ if (!Number.isFinite(blocks) || blocks <= 0 || !Number.isFinite(available)) {
56
+ return undefined;
57
+ }
58
+ const usedRatio = 1 - available / blocks;
59
+ const usage = usedRatio * 100;
60
+ if (!Number.isFinite(usage))
61
+ return undefined;
62
+ return Math.max(0, Math.min(100, round2(usage)));
63
+ }
64
+ catch {
65
+ return undefined;
66
+ }
67
+ }
68
+ async function collectHeartbeatMetrics() {
69
+ const cpu = readCpuUsagePercent();
70
+ const ram = readRamUsagePercent();
71
+ const disk = await readDiskUsagePercent();
72
+ const payload = {};
73
+ if (typeof cpu === 'number')
74
+ payload.cpu_usage_percent = cpu;
75
+ if (typeof ram === 'number')
76
+ payload.ram_usage_percent = ram;
77
+ if (typeof disk === 'number')
78
+ payload.disk_usage_percent = disk;
79
+ return payload;
80
+ }
81
+ export function startHeartbeat(serverUrl, apiKey, onError) {
82
+ const interval = setInterval(async () => {
83
+ try {
84
+ const metrics = await collectHeartbeatMetrics();
85
+ await sendHeartbeat(serverUrl, apiKey, metrics);
86
+ // On successful heartbeat, replay any buffered journal events
87
+ if (journalSize() > 0) {
88
+ await replayJournal(serverUrl, apiKey);
89
+ }
90
+ }
91
+ catch (err) {
92
+ onError?.(err instanceof Error ? err : new Error(String(err)));
93
+ }
94
+ }, HEARTBEAT_INTERVAL_MS);
95
+ // NodeJS: don't block process exit on heartbeat timer
96
+ if (typeof interval === 'object' && 'unref' in interval) {
97
+ interval.unref();
98
+ }
99
+ return () => clearInterval(interval);
100
+ }
101
+ //# sourceMappingURL=heartbeat.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"heartbeat.js","sourceRoot":"","sources":["../src/heartbeat.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,aAAa,EAAE,aAAa,EAAE,MAAM,iBAAiB,CAAC;AAC/D,OAAO,EAAE,MAAM,EAAE,MAAM,kBAAkB,CAAC;AAC1C,OAAO,EAAE,IAAI,EAAE,OAAO,EAAE,QAAQ,EAAE,MAAM,SAAS,CAAC;AAClD,OAAO,EAAE,WAAW,EAAE,MAAM,cAAc,CAAC;AAG3C,MAAM,qBAAqB,GAAG,MAAM,CAAC;AAIrC,IAAI,iBAAiB,GAAqB,IAAI,CAAC;AAE/C,SAAS,MAAM,CAAC,KAAa;IAC3B,OAAO,MAAM,CAAC,KAAK,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC,CAAC;AAClC,CAAC;AAED,SAAS,aAAa;IACpB,MAAM,KAAK,GAAG,IAAI,EAAE,CAAC;IACrB,IAAI,CAAC,KAAK,IAAI,KAAK,CAAC,MAAM,KAAK,CAAC;QAAE,OAAO,IAAI,CAAC;IAE9C,IAAI,IAAI,GAAG,CAAC,CAAC;IACb,IAAI,KAAK,GAAG,CAAC,CAAC;IACd,KAAK,MAAM,IAAI,IAAI,KAAK,EAAE,CAAC;QACzB,IAAI,IAAI,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC;QACxB,KAAK,IAAI,IAAI,CAAC,KAAK,CAAC,IAAI,GAAG,IAAI,CAAC,KAAK,CAAC,IAAI,GAAG,IAAI,CAAC,KAAK,CAAC,GAAG,GAAG,IAAI,CAAC,KAAK,CAAC,GAAG,GAAG,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC;IACjG,CAAC;IACD,OAAO,EAAE,IAAI,EAAE,KAAK,EAAE,CAAC;AACzB,CAAC;AAED,SAAS,mBAAmB;IAC1B,MAAM,OAAO,GAAG,aAAa,EAAE,CAAC;IAChC,IAAI,CAAC,OAAO;QAAE,OAAO,SAAS,CAAC;IAE/B,IAAI,CAAC,iBAAiB,EAAE,CAAC;QACvB,iBAAiB,GAAG,OAAO,CAAC;QAC5B,OAAO,SAAS,CAAC;IACnB,CAAC;IAED,MAAM,QAAQ,GAAG,OAAO,CAAC,IAAI,GAAG,iBAAiB,CAAC,IAAI,CAAC;IACvD,MAAM,SAAS,GAAG,OAAO,CAAC,KAAK,GAAG,iBAAiB,CAAC,KAAK,CAAC;IAC1D,iBAAiB,GAAG,OAAO,CAAC;IAE5B,IAAI,SAAS,IAAI,CAAC;QAAE,OAAO,SAAS,CAAC;IACrC,MAAM,KAAK,GAAG,CAAC,CAAC,GAAG,QAAQ,GAAG,SAAS,CAAC,GAAG,GAAG,CAAC;IAC/C,IAAI,CAAC,MAAM,CAAC,QAAQ,CAAC,KAAK,CAAC;QAAE,OAAO,SAAS,CAAC;IAC9C,OAAO,IAAI,CAAC,GAAG,CAAC,CAAC,EAAE,IAAI,CAAC,GAAG,CAAC,GAAG,EAAE,MAAM,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC;AACnD,CAAC;AAED,SAAS,mBAAmB;IAC1B,MAAM,KAAK,GAAG,QAAQ,EAAE,CAAC;IACzB,IAAI,CAAC,KAAK;QAAE,OAAO,SAAS,CAAC;IAC7B,MAAM,IAAI,GAAG,KAAK,GAAG,OAAO,EAAE,CAAC;IAC/B,MAAM,KAAK,GAAG,CAAC,IAAI,GAAG,KAAK,CAAC,GAAG,GAAG,CAAC;IACnC,IAAI,CAAC,MAAM,CAAC,QAAQ,CAAC,KAAK,CAAC;QAAE,OAAO,SAAS,CAAC;IAC9C,OAAO,IAAI,CAAC,GAAG,CAAC,CAAC,EAAE,IAAI,CAAC,GAAG,CAAC,GAAG,EAAE,MAAM,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC;AACnD,CAAC;AAED,KAAK,UAAU,oBAAoB;IACjC,IAAI,CAAC;QACH,MAAM,KAAK,GAAG,MAAM,MAAM,CAAC,OAAO,CAAC,GAAG,EAAE,CAAC,CAAC;QAC1C,MAAM,MAAM,GAAG,MAAM,CAAC,KAAK,CAAC,MAAM,CAAC,CAAC;QACpC,MAAM,SAAS,GAAG,MAAM,CAAC,KAAK,CAAC,MAAM,CAAC,CAAC;QACvC,IAAI,CAAC,MAAM,CAAC,QAAQ,CAAC,MAAM,CAAC,IAAI,MAAM,IAAI,CAAC,IAAI,CAAC,MAAM,CAAC,QAAQ,CAAC,SAAS,CAAC,EAAE,CAAC;YAC3E,OAAO,SAAS,CAAC;QACnB,CAAC;QACD,MAAM,SAAS,GAAG,CAAC,GAAG,SAAS,GAAG,MAAM,CAAC;QACzC,MAAM,KAAK,GAAG,SAAS,GAAG,GAAG,CAAC;QAC9B,IAAI,CAAC,MAAM,CAAC,QAAQ,CAAC,KAAK,CAAC;YAAE,OAAO,SAAS,CAAC;QAC9C,OAAO,IAAI,CAAC,GAAG,CAAC,CAAC,EAAE,IAAI,CAAC,GAAG,CAAC,GAAG,EAAE,MAAM,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC;IACnD,CAAC;IAAC,MAAM,CAAC;QACP,OAAO,SAAS,CAAC;IACnB,CAAC;AACH,CAAC;AAED,KAAK,UAAU,uBAAuB;IACpC,MAAM,GAAG,GAAG,mBAAmB,EAAE,CAAC;IAClC,MAAM,GAAG,GAAG,mBAAmB,EAAE,CAAC;IAClC,MAAM,IAAI,GAAG,MAAM,oBAAoB,EAAE,CAAC;IAE1C,MAAM,OAAO,GAAqB,EAAE,CAAC;IACrC,IAAI,OAAO,GAAG,KAAK,QAAQ;QAAE,OAAO,CAAC,iBAAiB,GAAG,GAAG,CAAC;IAC7D,IAAI,OAAO,GAAG,KAAK,QAAQ;QAAE,OAAO,CAAC,iBAAiB,GAAG,GAAG,CAAC;IAC7D,IAAI,OAAO,IAAI,KAAK,QAAQ;QAAE,OAAO,CAAC,kBAAkB,GAAG,IAAI,CAAC;IAChE,OAAO,OAAO,CAAC;AACjB,CAAC;AAED,MAAM,UAAU,cAAc,CAC5B,SAAiB,EACjB,MAAc,EACd,OAA8B;IAE9B,MAAM,QAAQ,GAAG,WAAW,CAAC,KAAK,IAAI,EAAE;QACtC,IAAI,CAAC;YACH,MAAM,OAAO,GAAG,MAAM,uBAAuB,EAAE,CAAC;YAChD,MAAM,aAAa,CAAC,SAAS,EAAE,MAAM,EAAE,OAAO,CAAC,CAAC;YAChD,8DAA8D;YAC9D,IAAI,WAAW,EAAE,GAAG,CAAC,EAAE,CAAC;gBACtB,MAAM,aAAa,CAAC,SAAS,EAAE,MAAM,CAAC,CAAC;YACzC,CAAC;QACH,CAAC;QAAC,OAAO,GAAG,EAAE,CAAC;YACb,OAAO,EAAE,CAAC,GAAG,YAAY,KAAK,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,IAAI,KAAK,CAAC,MAAM,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC;QACjE,CAAC;IACH,CAAC,EAAE,qBAAqB,CAAC,CAAC;IAE1B,sDAAsD;IACtD,IAAI,OAAO,QAAQ,KAAK,QAAQ,IAAI,OAAO,IAAI,QAAQ,EAAE,CAAC;QACvD,QAA2B,CAAC,KAAK,EAAE,CAAC;IACvC,CAAC;IAED,OAAO,GAAG,EAAE,CAAC,aAAa,CAAC,QAAQ,CAAC,CAAC;AACvC,CAAC"}
@@ -0,0 +1,31 @@
1
+ import { type RunExecutor } from './run-handler.js';
2
+ import type { RunnerConfig, ConnectionStatus } from './types.js';
3
+ export { log, createLogger, setLogLevel } from './logger.js';
4
+ export { loadConfig, saveConfig, getConfigPath, getConfigDir } from './config.js';
5
+ export { connectRunner, sendHeartbeat, updateRunStatus, appendRunEvent } from './api-client.js';
6
+ export { type RunExecutor, type RunDispatch } from './run-handler.js';
7
+ export { ClaudeCodeAdapter } from './adapters/claude-code.js';
8
+ export { CodexAdapter } from './adapters/codex.js';
9
+ export type { Adapter, AdapterConfig } from './adapters/interface.js';
10
+ export type { RunnerConfig, Run, RunStatus, ConnectionStatus } from './types.js';
11
+ type MessageHandler = (payload: unknown) => void;
12
+ export declare class CosmiosRunner {
13
+ private config;
14
+ private connection;
15
+ private stopHeartbeat;
16
+ private messageHandlers;
17
+ private statusHandlers;
18
+ private executor;
19
+ private stopPoller;
20
+ private stopRollbackPoller;
21
+ private stopPreviewPoller;
22
+ constructor(config: RunnerConfig);
23
+ static fromConfig(): CosmiosRunner;
24
+ start(): Promise<void>;
25
+ setExecutor(executor: RunExecutor): void;
26
+ on(event: string, handler: MessageHandler): void;
27
+ onStatusChange(handler: (status: ConnectionStatus) => void): void;
28
+ stop(): void;
29
+ getRunnerId(): string;
30
+ }
31
+ //# sourceMappingURL=index.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":"AAKA,OAAO,EAAqB,KAAK,WAAW,EAAE,MAAM,kBAAkB,CAAC;AAQvE,OAAO,KAAK,EAAE,YAAY,EAAE,gBAAgB,EAAE,MAAM,YAAY,CAAC;AAEjE,OAAO,EAAE,GAAG,EAAE,YAAY,EAAE,WAAW,EAAE,MAAM,aAAa,CAAC;AAC7D,OAAO,EAAE,UAAU,EAAE,UAAU,EAAE,aAAa,EAAE,YAAY,EAAE,MAAM,aAAa,CAAC;AAClF,OAAO,EAAE,aAAa,EAAE,aAAa,EAAE,eAAe,EAAE,cAAc,EAAE,MAAM,iBAAiB,CAAC;AAChG,OAAO,EAAE,KAAK,WAAW,EAAE,KAAK,WAAW,EAAE,MAAM,kBAAkB,CAAC;AACtE,OAAO,EAAE,iBAAiB,EAAE,MAAM,2BAA2B,CAAC;AAC9D,OAAO,EAAE,YAAY,EAAE,MAAM,qBAAqB,CAAC;AACnD,YAAY,EAAE,OAAO,EAAE,aAAa,EAAE,MAAM,yBAAyB,CAAC;AACtE,YAAY,EAAE,YAAY,EAAE,GAAG,EAAE,SAAS,EAAE,gBAAgB,EAAE,MAAM,YAAY,CAAC;AAEjF,KAAK,cAAc,GAAG,CAAC,OAAO,EAAE,OAAO,KAAK,IAAI,CAAC;AAEjD,qBAAa,aAAa;IACxB,OAAO,CAAC,MAAM,CAAe;IAC7B,OAAO,CAAC,UAAU,CAAiC;IACnD,OAAO,CAAC,aAAa,CAA6B;IAClD,OAAO,CAAC,eAAe,CAAqC;IAC5D,OAAO,CAAC,cAAc,CAAiD;IACvE,OAAO,CAAC,QAAQ,CAOd;IACF,OAAO,CAAC,UAAU,CAA6B;IAC/C,OAAO,CAAC,kBAAkB,CAA6B;IACvD,OAAO,CAAC,iBAAiB,CAA6B;gBAE1C,MAAM,EAAE,YAAY;IAIhC,MAAM,CAAC,UAAU,IAAI,aAAa;IAM5B,KAAK,IAAI,OAAO,CAAC,IAAI,CAAC;IAyF5B,WAAW,CAAC,QAAQ,EAAE,WAAW,GAAG,IAAI;IAIxC,EAAE,CAAC,KAAK,EAAE,MAAM,EAAE,OAAO,EAAE,cAAc,GAAG,IAAI;IAIhD,cAAc,CAAC,OAAO,EAAE,CAAC,MAAM,EAAE,gBAAgB,KAAK,IAAI,GAAG,IAAI;IAIjE,IAAI,IAAI,IAAI;IASZ,WAAW,IAAI,MAAM;CAGtB"}