@agentage/cli 0.1.18 → 0.2.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/README.md +107 -190
- package/dist/cli.js +20 -244
- package/dist/cli.js.map +1 -1
- package/dist/commands/agents.d.ts +3 -0
- package/dist/commands/agents.d.ts.map +1 -0
- package/dist/commands/agents.js +45 -0
- package/dist/commands/agents.js.map +1 -0
- package/dist/commands/daemon-cmd.d.ts +3 -0
- package/dist/commands/daemon-cmd.d.ts.map +1 -0
- package/dist/commands/daemon-cmd.js +26 -0
- package/dist/commands/daemon-cmd.js.map +1 -0
- package/dist/commands/login.d.ts +2 -1
- package/dist/commands/login.d.ts.map +1 -1
- package/dist/commands/login.js +8 -65
- package/dist/commands/login.js.map +1 -1
- package/dist/commands/logout.d.ts +2 -1
- package/dist/commands/logout.d.ts.map +1 -1
- package/dist/commands/logout.js +7 -26
- package/dist/commands/logout.js.map +1 -1
- package/dist/commands/logs.d.ts +3 -0
- package/dist/commands/logs.d.ts.map +1 -0
- package/dist/commands/logs.js +45 -0
- package/dist/commands/logs.js.map +1 -0
- package/dist/commands/machines.d.ts +3 -0
- package/dist/commands/machines.d.ts.map +1 -0
- package/dist/commands/machines.js +14 -0
- package/dist/commands/machines.js.map +1 -0
- package/dist/commands/run.d.ts +2 -1
- package/dist/commands/run.d.ts.map +1 -1
- package/dist/commands/run.js +71 -27
- package/dist/commands/run.js.map +1 -1
- package/dist/commands/runs.d.ts +3 -0
- package/dist/commands/runs.d.ts.map +1 -0
- package/dist/commands/runs.js +73 -0
- package/dist/commands/runs.js.map +1 -0
- package/dist/commands/status.d.ts +3 -0
- package/dist/commands/status.d.ts.map +1 -0
- package/dist/commands/status.js +34 -0
- package/dist/commands/status.js.map +1 -0
- package/dist/daemon/config.d.ts +32 -0
- package/dist/daemon/config.d.ts.map +1 -0
- package/dist/daemon/config.js +57 -0
- package/dist/daemon/config.js.map +1 -0
- package/dist/daemon/daemon.d.ts +8 -0
- package/dist/daemon/daemon.d.ts.map +1 -0
- package/dist/daemon/daemon.js +106 -0
- package/dist/daemon/daemon.js.map +1 -0
- package/dist/daemon/logger.d.ts +10 -0
- package/dist/daemon/logger.d.ts.map +1 -0
- package/dist/daemon/logger.js +41 -0
- package/dist/daemon/logger.js.map +1 -0
- package/dist/daemon/routes.d.ts +7 -0
- package/dist/daemon/routes.d.ts.map +1 -0
- package/dist/daemon/routes.js +102 -0
- package/dist/daemon/routes.js.map +1 -0
- package/dist/daemon/run-manager.d.ts +13 -0
- package/dist/daemon/run-manager.d.ts.map +1 -0
- package/dist/daemon/run-manager.js +119 -0
- package/dist/daemon/run-manager.js.map +1 -0
- package/dist/daemon/server.d.ts +11 -0
- package/dist/daemon/server.d.ts.map +1 -0
- package/dist/daemon/server.js +59 -0
- package/dist/daemon/server.js.map +1 -0
- package/dist/daemon/websocket.d.ts +4 -0
- package/dist/daemon/websocket.d.ts.map +1 -0
- package/dist/daemon/websocket.js +88 -0
- package/dist/daemon/websocket.js.map +1 -0
- package/dist/daemon-entry.d.ts +2 -0
- package/dist/daemon-entry.d.ts.map +1 -0
- package/dist/daemon-entry.js +45 -0
- package/dist/daemon-entry.js.map +1 -0
- package/dist/discovery/code-factory.d.ts +3 -0
- package/dist/discovery/code-factory.d.ts.map +1 -0
- package/dist/discovery/code-factory.js +32 -0
- package/dist/discovery/code-factory.js.map +1 -0
- package/dist/discovery/markdown-factory.d.ts +3 -0
- package/dist/discovery/markdown-factory.d.ts.map +1 -0
- package/dist/discovery/markdown-factory.js +63 -0
- package/dist/discovery/markdown-factory.js.map +1 -0
- package/dist/discovery/scanner.d.ts +3 -0
- package/dist/discovery/scanner.d.ts.map +1 -0
- package/dist/discovery/scanner.js +50 -0
- package/dist/discovery/scanner.js.map +1 -0
- package/dist/index.d.ts +2 -2
- package/dist/index.d.ts.map +1 -1
- package/dist/index.js +1 -8
- package/dist/index.js.map +1 -1
- package/dist/utils/daemon-client.d.ts +5 -0
- package/dist/utils/daemon-client.d.ts.map +1 -0
- package/dist/utils/daemon-client.js +44 -0
- package/dist/utils/daemon-client.js.map +1 -0
- package/dist/utils/ensure-daemon.d.ts +2 -0
- package/dist/utils/ensure-daemon.d.ts.map +1 -0
- package/dist/utils/ensure-daemon.js +7 -0
- package/dist/utils/ensure-daemon.js.map +1 -0
- package/dist/utils/render.d.ts +3 -0
- package/dist/utils/render.d.ts.map +1 -0
- package/dist/utils/render.js +84 -0
- package/dist/utils/render.js.map +1 -0
- package/package.json +45 -58
- package/dist/cli.test.d.ts +0 -2
- package/dist/cli.test.d.ts.map +0 -1
- package/dist/cli.test.js +0 -67
- package/dist/cli.test.js.map +0 -1
- package/dist/commands/init.d.ts +0 -8
- package/dist/commands/init.d.ts.map +0 -1
- package/dist/commands/init.js +0 -39
- package/dist/commands/init.js.map +0 -1
- package/dist/commands/init.test.d.ts +0 -2
- package/dist/commands/init.test.d.ts.map +0 -1
- package/dist/commands/init.test.js +0 -79
- package/dist/commands/init.test.js.map +0 -1
- package/dist/commands/install.d.ts +0 -8
- package/dist/commands/install.d.ts.map +0 -1
- package/dist/commands/install.js +0 -90
- package/dist/commands/install.js.map +0 -1
- package/dist/commands/install.test.d.ts +0 -2
- package/dist/commands/install.test.d.ts.map +0 -1
- package/dist/commands/install.test.js +0 -172
- package/dist/commands/install.test.js.map +0 -1
- package/dist/commands/list.d.ts +0 -2
- package/dist/commands/list.d.ts.map +0 -1
- package/dist/commands/list.js +0 -145
- package/dist/commands/list.js.map +0 -1
- package/dist/commands/list.test.d.ts +0 -2
- package/dist/commands/list.test.d.ts.map +0 -1
- package/dist/commands/list.test.js +0 -120
- package/dist/commands/list.test.js.map +0 -1
- package/dist/commands/login.test.d.ts +0 -2
- package/dist/commands/login.test.d.ts.map +0 -1
- package/dist/commands/login.test.js +0 -157
- package/dist/commands/login.test.js.map +0 -1
- package/dist/commands/logout.test.d.ts +0 -2
- package/dist/commands/logout.test.d.ts.map +0 -1
- package/dist/commands/logout.test.js +0 -49
- package/dist/commands/logout.test.js.map +0 -1
- package/dist/commands/publish.d.ts +0 -10
- package/dist/commands/publish.d.ts.map +0 -1
- package/dist/commands/publish.js +0 -138
- package/dist/commands/publish.js.map +0 -1
- package/dist/commands/publish.test.d.ts +0 -2
- package/dist/commands/publish.test.d.ts.map +0 -1
- package/dist/commands/publish.test.js +0 -307
- package/dist/commands/publish.test.js.map +0 -1
- package/dist/commands/run.test.d.ts +0 -2
- package/dist/commands/run.test.d.ts.map +0 -1
- package/dist/commands/run.test.js +0 -105
- package/dist/commands/run.test.js.map +0 -1
- package/dist/commands/search.d.ts +0 -8
- package/dist/commands/search.d.ts.map +0 -1
- package/dist/commands/search.js +0 -41
- package/dist/commands/search.js.map +0 -1
- package/dist/commands/search.test.d.ts +0 -2
- package/dist/commands/search.test.d.ts.map +0 -1
- package/dist/commands/search.test.js +0 -138
- package/dist/commands/search.test.js.map +0 -1
- package/dist/commands/update.d.ts +0 -8
- package/dist/commands/update.d.ts.map +0 -1
- package/dist/commands/update.js +0 -28
- package/dist/commands/update.js.map +0 -1
- package/dist/commands/update.test.d.ts +0 -2
- package/dist/commands/update.test.d.ts.map +0 -1
- package/dist/commands/update.test.js +0 -134
- package/dist/commands/update.test.js.map +0 -1
- package/dist/commands/whoami.d.ts +0 -2
- package/dist/commands/whoami.d.ts.map +0 -1
- package/dist/commands/whoami.js +0 -55
- package/dist/commands/whoami.js.map +0 -1
- package/dist/commands/whoami.test.d.ts +0 -2
- package/dist/commands/whoami.test.d.ts.map +0 -1
- package/dist/commands/whoami.test.js +0 -119
- package/dist/commands/whoami.test.js.map +0 -1
- package/dist/index.test.d.ts +0 -2
- package/dist/index.test.d.ts.map +0 -1
- package/dist/index.test.js +0 -17
- package/dist/index.test.js.map +0 -1
- package/dist/schemas/agent.schema.d.ts +0 -22
- package/dist/schemas/agent.schema.d.ts.map +0 -1
- package/dist/schemas/agent.schema.js +0 -9
- package/dist/schemas/agent.schema.js.map +0 -1
- package/dist/schemas/agent.schema.test.d.ts +0 -2
- package/dist/schemas/agent.schema.test.d.ts.map +0 -1
- package/dist/schemas/agent.schema.test.js +0 -80
- package/dist/schemas/agent.schema.test.js.map +0 -1
- package/dist/services/auth.service.d.ts +0 -10
- package/dist/services/auth.service.d.ts.map +0 -1
- package/dist/services/auth.service.js +0 -99
- package/dist/services/auth.service.js.map +0 -1
- package/dist/services/auth.service.test.d.ts +0 -2
- package/dist/services/auth.service.test.d.ts.map +0 -1
- package/dist/services/auth.service.test.js +0 -218
- package/dist/services/auth.service.test.js.map +0 -1
- package/dist/services/registry.service.d.ts +0 -13
- package/dist/services/registry.service.d.ts.map +0 -1
- package/dist/services/registry.service.js +0 -74
- package/dist/services/registry.service.js.map +0 -1
- package/dist/services/registry.service.test.d.ts +0 -2
- package/dist/services/registry.service.test.d.ts.map +0 -1
- package/dist/services/registry.service.test.js +0 -222
- package/dist/services/registry.service.test.js.map +0 -1
- package/dist/types/config.types.d.ts +0 -177
- package/dist/types/config.types.d.ts.map +0 -1
- package/dist/types/config.types.js +0 -22
- package/dist/types/config.types.js.map +0 -1
- package/dist/types/registry.types.d.ts +0 -65
- package/dist/types/registry.types.d.ts.map +0 -1
- package/dist/types/registry.types.js +0 -2
- package/dist/types/registry.types.js.map +0 -1
- package/dist/utils/agent-parser.d.ts +0 -26
- package/dist/utils/agent-parser.d.ts.map +0 -1
- package/dist/utils/agent-parser.js +0 -45
- package/dist/utils/agent-parser.js.map +0 -1
- package/dist/utils/agent-parser.test.d.ts +0 -2
- package/dist/utils/agent-parser.test.d.ts.map +0 -1
- package/dist/utils/agent-parser.test.js +0 -102
- package/dist/utils/agent-parser.test.js.map +0 -1
- package/dist/utils/config.d.ts +0 -21
- package/dist/utils/config.d.ts.map +0 -1
- package/dist/utils/config.js +0 -99
- package/dist/utils/config.js.map +0 -1
- package/dist/utils/config.test.d.ts +0 -2
- package/dist/utils/config.test.d.ts.map +0 -1
- package/dist/utils/config.test.js +0 -214
- package/dist/utils/config.test.js.map +0 -1
- package/dist/utils/version.d.ts +0 -10
- package/dist/utils/version.d.ts.map +0 -1
- package/dist/utils/version.js +0 -33
- package/dist/utils/version.js.map +0 -1
- package/dist/utils/version.test.d.ts +0 -2
- package/dist/utils/version.test.d.ts.map +0 -1
- package/dist/utils/version.test.js +0 -30
- package/dist/utils/version.test.js.map +0 -1
|
@@ -0,0 +1,45 @@
|
|
|
1
|
+
import chalk from 'chalk';
|
|
2
|
+
import { ensureDaemon } from '../utils/ensure-daemon.js';
|
|
3
|
+
import { get, post } from '../utils/daemon-client.js';
|
|
4
|
+
export const registerAgents = (program) => {
|
|
5
|
+
program
|
|
6
|
+
.command('agents')
|
|
7
|
+
.description('List discovered agents')
|
|
8
|
+
.option('--refresh', 'Rescan directories first')
|
|
9
|
+
.option('--all', 'Show agents from all connected machines')
|
|
10
|
+
.option('--json', 'JSON output')
|
|
11
|
+
.action(async (opts) => {
|
|
12
|
+
await ensureDaemon();
|
|
13
|
+
if (opts.all) {
|
|
14
|
+
console.error(chalk.red("Not connected to hub. Run 'agentage login' first."));
|
|
15
|
+
process.exitCode = 1;
|
|
16
|
+
return;
|
|
17
|
+
}
|
|
18
|
+
let agents;
|
|
19
|
+
if (opts.refresh) {
|
|
20
|
+
agents = await post('/api/agents/refresh');
|
|
21
|
+
}
|
|
22
|
+
else {
|
|
23
|
+
agents = await get('/api/agents');
|
|
24
|
+
}
|
|
25
|
+
if (opts.json) {
|
|
26
|
+
console.log(JSON.stringify(agents, null, 2));
|
|
27
|
+
return;
|
|
28
|
+
}
|
|
29
|
+
if (agents.length === 0) {
|
|
30
|
+
console.log(chalk.gray('No agents discovered.'));
|
|
31
|
+
return;
|
|
32
|
+
}
|
|
33
|
+
const nameWidth = Math.max(12, ...agents.map((a) => a.name.length)) + 2;
|
|
34
|
+
const descWidth = Math.max(12, ...agents.map((a) => (a.description || '').length)) + 2;
|
|
35
|
+
console.log(chalk.bold('NAME'.padEnd(nameWidth)) +
|
|
36
|
+
chalk.bold('DESCRIPTION'.padEnd(descWidth)) +
|
|
37
|
+
chalk.bold('PATH'));
|
|
38
|
+
for (const agent of agents) {
|
|
39
|
+
console.log(agent.name.padEnd(nameWidth) +
|
|
40
|
+
(agent.description || '').padEnd(descWidth) +
|
|
41
|
+
chalk.gray(agent.path));
|
|
42
|
+
}
|
|
43
|
+
});
|
|
44
|
+
};
|
|
45
|
+
//# sourceMappingURL=agents.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"agents.js","sourceRoot":"","sources":["../../src/commands/agents.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,MAAM,OAAO,CAAC;AAE1B,OAAO,EAAE,YAAY,EAAE,MAAM,2BAA2B,CAAC;AACzD,OAAO,EAAE,GAAG,EAAE,IAAI,EAAE,MAAM,2BAA2B,CAAC;AAEtD,MAAM,CAAC,MAAM,cAAc,GAAG,CAAC,OAAgB,EAAQ,EAAE;IACvD,OAAO;SACJ,OAAO,CAAC,QAAQ,CAAC;SACjB,WAAW,CAAC,wBAAwB,CAAC;SACrC,MAAM,CAAC,WAAW,EAAE,0BAA0B,CAAC;SAC/C,MAAM,CAAC,OAAO,EAAE,yCAAyC,CAAC;SAC1D,MAAM,CAAC,QAAQ,EAAE,aAAa,CAAC;SAC/B,MAAM,CAAC,KAAK,EAAE,IAA0D,EAAE,EAAE;QAC3E,MAAM,YAAY,EAAE,CAAC;QAErB,IAAI,IAAI,CAAC,GAAG,EAAE,CAAC;YACb,OAAO,CAAC,KAAK,CAAC,KAAK,CAAC,GAAG,CAAC,mDAAmD,CAAC,CAAC,CAAC;YAC9E,OAAO,CAAC,QAAQ,GAAG,CAAC,CAAC;YACrB,OAAO;QACT,CAAC;QAED,IAAI,MAAuB,CAAC;QAC5B,IAAI,IAAI,CAAC,OAAO,EAAE,CAAC;YACjB,MAAM,GAAG,MAAM,IAAI,CAAkB,qBAAqB,CAAC,CAAC;QAC9D,CAAC;aAAM,CAAC;YACN,MAAM,GAAG,MAAM,GAAG,CAAkB,aAAa,CAAC,CAAC;QACrD,CAAC;QAED,IAAI,IAAI,CAAC,IAAI,EAAE,CAAC;YACd,OAAO,CAAC,GAAG,CAAC,IAAI,CAAC,SAAS,CAAC,MAAM,EAAE,IAAI,EAAE,CAAC,CAAC,CAAC,CAAC;YAC7C,OAAO;QACT,CAAC;QAED,IAAI,MAAM,CAAC,MAAM,KAAK,CAAC,EAAE,CAAC;YACxB,OAAO,CAAC,GAAG,CAAC,KAAK,CAAC,IAAI,CAAC,uBAAuB,CAAC,CAAC,CAAC;YACjD,OAAO;QACT,CAAC;QAED,MAAM,SAAS,GAAG,IAAI,CAAC,GAAG,CAAC,EAAE,EAAE,GAAG,MAAM,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC,GAAG,CAAC,CAAC;QACxE,MAAM,SAAS,GAAG,IAAI,CAAC,GAAG,CAAC,EAAE,EAAE,GAAG,MAAM,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,CAAC,WAAW,IAAI,EAAE,CAAC,CAAC,MAAM,CAAC,CAAC,GAAG,CAAC,CAAC;QAEvF,OAAO,CAAC,GAAG,CACT,KAAK,CAAC,IAAI,CAAC,MAAM,CAAC,MAAM,CAAC,SAAS,CAAC,CAAC;YAClC,KAAK,CAAC,IAAI,CAAC,aAAa,CAAC,MAAM,CAAC,SAAS,CAAC,CAAC;YAC3C,KAAK,CAAC,IAAI,CAAC,MAAM,CAAC,CACrB,CAAC;QAEF,KAAK,MAAM,KAAK,IAAI,MAAM,EAAE,CAAC;YAC3B,OAAO,CAAC,GAAG,CACT,KAAK,CAAC,IAAI,CAAC,MAAM,CAAC,SAAS,CAAC;gBAC1B,CAAC,KAAK,CAAC,WAAW,IAAI,EAAE,CAAC,CAAC,MAAM,CAAC,SAAS,CAAC;gBAC3C,KAAK,CAAC,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,CACzB,CAAC;QACJ,CAAC;IACH,CAAC,CAAC,CAAC;AACP,CAAC,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"daemon-cmd.d.ts","sourceRoot":"","sources":["../../src/commands/daemon-cmd.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,KAAK,OAAO,EAAE,MAAM,WAAW,CAAC;AAIzC,eAAO,MAAM,cAAc,GAAI,SAAS,OAAO,KAAG,IAwBjD,CAAC"}
|
|
@@ -0,0 +1,26 @@
|
|
|
1
|
+
import chalk from 'chalk';
|
|
2
|
+
import { getDaemonPid, restartDaemon, stopDaemon } from '../daemon/daemon.js';
|
|
3
|
+
export const registerDaemon = (program) => {
|
|
4
|
+
const daemon = program.command('daemon').description('Manage the daemon');
|
|
5
|
+
daemon
|
|
6
|
+
.command('stop')
|
|
7
|
+
.description('Stop the daemon')
|
|
8
|
+
.action(() => {
|
|
9
|
+
const pid = getDaemonPid();
|
|
10
|
+
if (pid === null) {
|
|
11
|
+
console.log(chalk.gray('Daemon is not running.'));
|
|
12
|
+
return;
|
|
13
|
+
}
|
|
14
|
+
stopDaemon();
|
|
15
|
+
console.log(chalk.green('Daemon stopped.'));
|
|
16
|
+
});
|
|
17
|
+
daemon
|
|
18
|
+
.command('restart')
|
|
19
|
+
.description('Restart the daemon')
|
|
20
|
+
.action(async () => {
|
|
21
|
+
await restartDaemon();
|
|
22
|
+
const pid = getDaemonPid();
|
|
23
|
+
console.log(chalk.green(`Daemon restarted (PID ${pid}, port 4243).`));
|
|
24
|
+
});
|
|
25
|
+
};
|
|
26
|
+
//# sourceMappingURL=daemon-cmd.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"daemon-cmd.js","sourceRoot":"","sources":["../../src/commands/daemon-cmd.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,MAAM,OAAO,CAAC;AAC1B,OAAO,EAAE,YAAY,EAAE,aAAa,EAAE,UAAU,EAAE,MAAM,qBAAqB,CAAC;AAE9E,MAAM,CAAC,MAAM,cAAc,GAAG,CAAC,OAAgB,EAAQ,EAAE;IACvD,MAAM,MAAM,GAAG,OAAO,CAAC,OAAO,CAAC,QAAQ,CAAC,CAAC,WAAW,CAAC,mBAAmB,CAAC,CAAC;IAE1E,MAAM;SACH,OAAO,CAAC,MAAM,CAAC;SACf,WAAW,CAAC,iBAAiB,CAAC;SAC9B,MAAM,CAAC,GAAG,EAAE;QACX,MAAM,GAAG,GAAG,YAAY,EAAE,CAAC;QAC3B,IAAI,GAAG,KAAK,IAAI,EAAE,CAAC;YACjB,OAAO,CAAC,GAAG,CAAC,KAAK,CAAC,IAAI,CAAC,wBAAwB,CAAC,CAAC,CAAC;YAClD,OAAO;QACT,CAAC;QACD,UAAU,EAAE,CAAC;QACb,OAAO,CAAC,GAAG,CAAC,KAAK,CAAC,KAAK,CAAC,iBAAiB,CAAC,CAAC,CAAC;IAC9C,CAAC,CAAC,CAAC;IAEL,MAAM;SACH,OAAO,CAAC,SAAS,CAAC;SAClB,WAAW,CAAC,oBAAoB,CAAC;SACjC,MAAM,CAAC,KAAK,IAAI,EAAE;QACjB,MAAM,aAAa,EAAE,CAAC;QACtB,MAAM,GAAG,GAAG,YAAY,EAAE,CAAC;QAC3B,OAAO,CAAC,GAAG,CAAC,KAAK,CAAC,KAAK,CAAC,yBAAyB,GAAG,eAAe,CAAC,CAAC,CAAC;IACxE,CAAC,CAAC,CAAC;AACP,CAAC,CAAC"}
|
package/dist/commands/login.d.ts
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"login.d.ts","sourceRoot":"","sources":["../../src/commands/login.ts"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"login.d.ts","sourceRoot":"","sources":["../../src/commands/login.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,KAAK,OAAO,EAAE,MAAM,WAAW,CAAC;AAGzC,eAAO,MAAM,aAAa,GAAI,SAAS,OAAO,KAAG,IAQhD,CAAC"}
|
package/dist/commands/login.js
CHANGED
|
@@ -1,68 +1,11 @@
|
|
|
1
1
|
import chalk from 'chalk';
|
|
2
|
-
|
|
3
|
-
|
|
4
|
-
|
|
5
|
-
|
|
6
|
-
|
|
7
|
-
|
|
8
|
-
|
|
9
|
-
|
|
10
|
-
}
|
|
11
|
-
const registryUrl = await getRegistryUrl();
|
|
12
|
-
console.log(chalk.blue('🔐 Logging in to'), chalk.cyan(registryUrl));
|
|
13
|
-
console.log();
|
|
14
|
-
console.log(chalk.gray('Requesting authentication code...'));
|
|
15
|
-
const deviceCode = await requestDeviceCode();
|
|
16
|
-
console.log();
|
|
17
|
-
console.log(chalk.bold('To complete login:'));
|
|
18
|
-
console.log();
|
|
19
|
-
console.log(' 1. Open:', chalk.cyan.underline(deviceCode.verification_uri));
|
|
20
|
-
console.log(' 2. Enter code:', chalk.bold.yellow(deviceCode.user_code));
|
|
21
|
-
console.log();
|
|
22
|
-
try {
|
|
23
|
-
const open = await import('open');
|
|
24
|
-
await open.default(deviceCode.verification_uri);
|
|
25
|
-
console.log(chalk.gray('(Browser opened automatically)'));
|
|
26
|
-
}
|
|
27
|
-
catch {
|
|
28
|
-
console.log(chalk.gray('(Could not open browser automatically - please open manually)'));
|
|
29
|
-
}
|
|
30
|
-
console.log();
|
|
31
|
-
console.log(chalk.gray('Waiting for authentication...'));
|
|
32
|
-
const tokenResponse = await pollForToken(deviceCode.device_code, deviceCode.interval, deviceCode.expires_in);
|
|
33
|
-
const currentConfig = await loadConfig();
|
|
34
|
-
await saveConfig({
|
|
35
|
-
...currentConfig,
|
|
36
|
-
auth: {
|
|
37
|
-
token: tokenResponse.access_token,
|
|
38
|
-
user: tokenResponse.user,
|
|
39
|
-
expiresAt: tokenResponse.expires_in
|
|
40
|
-
? new Date(Date.now() + tokenResponse.expires_in * 1000).toISOString()
|
|
41
|
-
: undefined,
|
|
42
|
-
},
|
|
43
|
-
});
|
|
44
|
-
console.log();
|
|
45
|
-
if (tokenResponse.user?.name) {
|
|
46
|
-
console.log(chalk.green('✅ Logged in as'), chalk.bold(tokenResponse.user.name));
|
|
47
|
-
}
|
|
48
|
-
else if (tokenResponse.user?.email) {
|
|
49
|
-
console.log(chalk.green('✅ Logged in as'), chalk.bold(tokenResponse.user.email));
|
|
50
|
-
}
|
|
51
|
-
else {
|
|
52
|
-
console.log(chalk.green('✅ Login successful!'));
|
|
53
|
-
}
|
|
54
|
-
}
|
|
55
|
-
catch (error) {
|
|
56
|
-
if (error instanceof AuthError) {
|
|
57
|
-
console.error(chalk.red('❌ Login failed:'), error.message);
|
|
58
|
-
if (error.code === 'expired_token') {
|
|
59
|
-
console.log(chalk.gray('Run'), chalk.cyan('agent login'), chalk.gray('to try again.'));
|
|
60
|
-
}
|
|
61
|
-
}
|
|
62
|
-
else {
|
|
63
|
-
console.error(chalk.red('❌ Login failed:'), error.message);
|
|
64
|
-
}
|
|
65
|
-
process.exit(1);
|
|
66
|
-
}
|
|
2
|
+
export const registerLogin = (program) => {
|
|
3
|
+
program
|
|
4
|
+
.command('login')
|
|
5
|
+
.description('Authenticate with hub')
|
|
6
|
+
.option('--hub <url>', 'Hub URL')
|
|
7
|
+
.action(() => {
|
|
8
|
+
console.log(chalk.yellow('Hub sync not yet available.'));
|
|
9
|
+
});
|
|
67
10
|
};
|
|
68
11
|
//# sourceMappingURL=login.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"login.js","sourceRoot":"","sources":["../../src/commands/login.ts"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"login.js","sourceRoot":"","sources":["../../src/commands/login.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,MAAM,OAAO,CAAC;AAE1B,MAAM,CAAC,MAAM,aAAa,GAAG,CAAC,OAAgB,EAAQ,EAAE;IACtD,OAAO;SACJ,OAAO,CAAC,OAAO,CAAC;SAChB,WAAW,CAAC,uBAAuB,CAAC;SACpC,MAAM,CAAC,aAAa,EAAE,SAAS,CAAC;SAChC,MAAM,CAAC,GAAG,EAAE;QACX,OAAO,CAAC,GAAG,CAAC,KAAK,CAAC,MAAM,CAAC,6BAA6B,CAAC,CAAC,CAAC;IAC3D,CAAC,CAAC,CAAC;AACP,CAAC,CAAC"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"logout.d.ts","sourceRoot":"","sources":["../../src/commands/logout.ts"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"logout.d.ts","sourceRoot":"","sources":["../../src/commands/logout.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,KAAK,OAAO,EAAE,MAAM,WAAW,CAAC;AAGzC,eAAO,MAAM,cAAc,GAAI,SAAS,OAAO,KAAG,IAOjD,CAAC"}
|
package/dist/commands/logout.js
CHANGED
|
@@ -1,29 +1,10 @@
|
|
|
1
1
|
import chalk from 'chalk';
|
|
2
|
-
|
|
3
|
-
|
|
4
|
-
|
|
5
|
-
|
|
6
|
-
|
|
7
|
-
|
|
8
|
-
|
|
9
|
-
return;
|
|
10
|
-
}
|
|
11
|
-
const userName = config.auth.user?.name || config.auth.user?.email;
|
|
12
|
-
console.log(chalk.gray('Logging out...'));
|
|
13
|
-
await logoutApi();
|
|
14
|
-
await clearConfig();
|
|
15
|
-
console.log();
|
|
16
|
-
if (userName) {
|
|
17
|
-
console.log(chalk.green('✅ Logged out from'), chalk.bold(userName));
|
|
18
|
-
}
|
|
19
|
-
else {
|
|
20
|
-
console.log(chalk.green('✅ Logged out successfully.'));
|
|
21
|
-
}
|
|
22
|
-
}
|
|
23
|
-
catch {
|
|
24
|
-
await clearConfig();
|
|
25
|
-
console.log(chalk.green('✅ Logged out locally.'));
|
|
26
|
-
console.log(chalk.gray('(Server logout may have failed, but local credentials cleared)'));
|
|
27
|
-
}
|
|
2
|
+
export const registerLogout = (program) => {
|
|
3
|
+
program
|
|
4
|
+
.command('logout')
|
|
5
|
+
.description('Disconnect from hub')
|
|
6
|
+
.action(() => {
|
|
7
|
+
console.log(chalk.yellow('Hub sync not yet available.'));
|
|
8
|
+
});
|
|
28
9
|
};
|
|
29
10
|
//# sourceMappingURL=logout.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"logout.js","sourceRoot":"","sources":["../../src/commands/logout.ts"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"logout.js","sourceRoot":"","sources":["../../src/commands/logout.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,MAAM,OAAO,CAAC;AAE1B,MAAM,CAAC,MAAM,cAAc,GAAG,CAAC,OAAgB,EAAQ,EAAE;IACvD,OAAO;SACJ,OAAO,CAAC,QAAQ,CAAC;SACjB,WAAW,CAAC,qBAAqB,CAAC;SAClC,MAAM,CAAC,GAAG,EAAE;QACX,OAAO,CAAC,GAAG,CAAC,KAAK,CAAC,MAAM,CAAC,6BAA6B,CAAC,CAAC,CAAC;IAC3D,CAAC,CAAC,CAAC;AACP,CAAC,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"logs.d.ts","sourceRoot":"","sources":["../../src/commands/logs.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,KAAK,OAAO,EAAE,MAAM,WAAW,CAAC;AAMzC,eAAO,MAAM,YAAY,GAAI,SAAS,OAAO,KAAG,IA8C/C,CAAC"}
|
|
@@ -0,0 +1,45 @@
|
|
|
1
|
+
import { existsSync, readFileSync, watchFile, unwatchFile } from 'node:fs';
|
|
2
|
+
import { join } from 'node:path';
|
|
3
|
+
import chalk from 'chalk';
|
|
4
|
+
import { getConfigDir } from '../daemon/config.js';
|
|
5
|
+
export const registerLogs = (program) => {
|
|
6
|
+
program
|
|
7
|
+
.command('logs')
|
|
8
|
+
.description('Tail daemon log')
|
|
9
|
+
.option('-f, --follow', 'Live tail')
|
|
10
|
+
.option('-n <lines>', 'Number of lines', '50')
|
|
11
|
+
.action((opts) => {
|
|
12
|
+
const logPath = join(getConfigDir(), 'daemon.log');
|
|
13
|
+
if (!existsSync(logPath)) {
|
|
14
|
+
console.log(chalk.gray('No daemon log found.'));
|
|
15
|
+
return;
|
|
16
|
+
}
|
|
17
|
+
const lines = parseInt(opts.n || '50', 10);
|
|
18
|
+
const content = readFileSync(logPath, 'utf-8');
|
|
19
|
+
const allLines = content.split('\n').filter(Boolean);
|
|
20
|
+
const tail = allLines.slice(-lines);
|
|
21
|
+
for (const line of tail) {
|
|
22
|
+
console.log(line);
|
|
23
|
+
}
|
|
24
|
+
if (opts.follow) {
|
|
25
|
+
let lastSize = Buffer.byteLength(content, 'utf-8');
|
|
26
|
+
watchFile(logPath, { interval: 500 }, () => {
|
|
27
|
+
const updated = readFileSync(logPath, 'utf-8');
|
|
28
|
+
const currentSize = Buffer.byteLength(updated, 'utf-8');
|
|
29
|
+
if (currentSize > lastSize) {
|
|
30
|
+
const newContent = updated.slice(lastSize);
|
|
31
|
+
const newLines = newContent.split('\n').filter(Boolean);
|
|
32
|
+
for (const line of newLines) {
|
|
33
|
+
console.log(line);
|
|
34
|
+
}
|
|
35
|
+
lastSize = currentSize;
|
|
36
|
+
}
|
|
37
|
+
});
|
|
38
|
+
process.on('SIGINT', () => {
|
|
39
|
+
unwatchFile(logPath);
|
|
40
|
+
process.exit(0);
|
|
41
|
+
});
|
|
42
|
+
}
|
|
43
|
+
});
|
|
44
|
+
};
|
|
45
|
+
//# sourceMappingURL=logs.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"logs.js","sourceRoot":"","sources":["../../src/commands/logs.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,UAAU,EAAE,YAAY,EAAE,SAAS,EAAE,WAAW,EAAE,MAAM,SAAS,CAAC;AAC3E,OAAO,EAAE,IAAI,EAAE,MAAM,WAAW,CAAC;AACjC,OAAO,KAAK,MAAM,OAAO,CAAC;AAC1B,OAAO,EAAE,YAAY,EAAE,MAAM,qBAAqB,CAAC;AAEnD,MAAM,CAAC,MAAM,YAAY,GAAG,CAAC,OAAgB,EAAQ,EAAE;IACrD,OAAO;SACJ,OAAO,CAAC,MAAM,CAAC;SACf,WAAW,CAAC,iBAAiB,CAAC;SAC9B,MAAM,CAAC,cAAc,EAAE,WAAW,CAAC;SACnC,MAAM,CAAC,YAAY,EAAE,iBAAiB,EAAE,IAAI,CAAC;SAC7C,MAAM,CAAC,CAAC,IAAsC,EAAE,EAAE;QACjD,MAAM,OAAO,GAAG,IAAI,CAAC,YAAY,EAAE,EAAE,YAAY,CAAC,CAAC;QAEnD,IAAI,CAAC,UAAU,CAAC,OAAO,CAAC,EAAE,CAAC;YACzB,OAAO,CAAC,GAAG,CAAC,KAAK,CAAC,IAAI,CAAC,sBAAsB,CAAC,CAAC,CAAC;YAChD,OAAO;QACT,CAAC;QAED,MAAM,KAAK,GAAG,QAAQ,CAAC,IAAI,CAAC,CAAC,IAAI,IAAI,EAAE,EAAE,CAAC,CAAC;QAC3C,MAAM,OAAO,GAAG,YAAY,CAAC,OAAO,EAAE,OAAO,CAAC,CAAC;QAC/C,MAAM,QAAQ,GAAG,OAAO,CAAC,KAAK,CAAC,IAAI,CAAC,CAAC,MAAM,CAAC,OAAO,CAAC,CAAC;QACrD,MAAM,IAAI,GAAG,QAAQ,CAAC,KAAK,CAAC,CAAC,KAAK,CAAC,CAAC;QAEpC,KAAK,MAAM,IAAI,IAAI,IAAI,EAAE,CAAC;YACxB,OAAO,CAAC,GAAG,CAAC,IAAI,CAAC,CAAC;QACpB,CAAC;QAED,IAAI,IAAI,CAAC,MAAM,EAAE,CAAC;YAChB,IAAI,QAAQ,GAAG,MAAM,CAAC,UAAU,CAAC,OAAO,EAAE,OAAO,CAAC,CAAC;YAEnD,SAAS,CAAC,OAAO,EAAE,EAAE,QAAQ,EAAE,GAAG,EAAE,EAAE,GAAG,EAAE;gBACzC,MAAM,OAAO,GAAG,YAAY,CAAC,OAAO,EAAE,OAAO,CAAC,CAAC;gBAC/C,MAAM,WAAW,GAAG,MAAM,CAAC,UAAU,CAAC,OAAO,EAAE,OAAO,CAAC,CAAC;gBAExD,IAAI,WAAW,GAAG,QAAQ,EAAE,CAAC;oBAC3B,MAAM,UAAU,GAAG,OAAO,CAAC,KAAK,CAAC,QAAQ,CAAC,CAAC;oBAC3C,MAAM,QAAQ,GAAG,UAAU,CAAC,KAAK,CAAC,IAAI,CAAC,CAAC,MAAM,CAAC,OAAO,CAAC,CAAC;oBACxD,KAAK,MAAM,IAAI,IAAI,QAAQ,EAAE,CAAC;wBAC5B,OAAO,CAAC,GAAG,CAAC,IAAI,CAAC,CAAC;oBACpB,CAAC;oBACD,QAAQ,GAAG,WAAW,CAAC;gBACzB,CAAC;YACH,CAAC,CAAC,CAAC;YAEH,OAAO,CAAC,EAAE,CAAC,QAAQ,EAAE,GAAG,EAAE;gBACxB,WAAW,CAAC,OAAO,CAAC,CAAC;gBACrB,OAAO,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC;YAClB,CAAC,CAAC,CAAC;QACL,CAAC;IACH,CAAC,CAAC,CAAC;AACP,CAAC,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"machines.d.ts","sourceRoot":"","sources":["../../src/commands/machines.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,KAAK,OAAO,EAAE,MAAM,WAAW,CAAC;AAIzC,eAAO,MAAM,gBAAgB,GAAI,SAAS,OAAO,KAAG,IAUnD,CAAC"}
|
|
@@ -0,0 +1,14 @@
|
|
|
1
|
+
import chalk from 'chalk';
|
|
2
|
+
import { ensureDaemon } from '../utils/ensure-daemon.js';
|
|
3
|
+
export const registerMachines = (program) => {
|
|
4
|
+
program
|
|
5
|
+
.command('machines')
|
|
6
|
+
.description('List connected machines')
|
|
7
|
+
.option('--json', 'JSON output')
|
|
8
|
+
.action(async () => {
|
|
9
|
+
await ensureDaemon();
|
|
10
|
+
console.error(chalk.red("Not connected to hub. Run 'agentage login' first."));
|
|
11
|
+
process.exitCode = 1;
|
|
12
|
+
});
|
|
13
|
+
};
|
|
14
|
+
//# sourceMappingURL=machines.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"machines.js","sourceRoot":"","sources":["../../src/commands/machines.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,MAAM,OAAO,CAAC;AAC1B,OAAO,EAAE,YAAY,EAAE,MAAM,2BAA2B,CAAC;AAEzD,MAAM,CAAC,MAAM,gBAAgB,GAAG,CAAC,OAAgB,EAAQ,EAAE;IACzD,OAAO;SACJ,OAAO,CAAC,UAAU,CAAC;SACnB,WAAW,CAAC,yBAAyB,CAAC;SACtC,MAAM,CAAC,QAAQ,EAAE,aAAa,CAAC;SAC/B,MAAM,CAAC,KAAK,IAAI,EAAE;QACjB,MAAM,YAAY,EAAE,CAAC;QACrB,OAAO,CAAC,KAAK,CAAC,KAAK,CAAC,GAAG,CAAC,mDAAmD,CAAC,CAAC,CAAC;QAC9E,OAAO,CAAC,QAAQ,GAAG,CAAC,CAAC;IACvB,CAAC,CAAC,CAAC;AACP,CAAC,CAAC"}
|
package/dist/commands/run.d.ts
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"run.d.ts","sourceRoot":"","sources":["../../src/commands/run.ts"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"run.d.ts","sourceRoot":"","sources":["../../src/commands/run.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,KAAK,OAAO,EAAE,MAAM,WAAW,CAAC;AA0BzC,eAAO,MAAM,WAAW,GAAI,SAAS,OAAO,KAAG,IA2C9C,CAAC"}
|
package/dist/commands/run.js
CHANGED
|
@@ -1,29 +1,73 @@
|
|
|
1
|
-
import
|
|
2
|
-
import {
|
|
3
|
-
import {
|
|
4
|
-
import {
|
|
5
|
-
|
|
6
|
-
export const
|
|
7
|
-
|
|
8
|
-
|
|
9
|
-
|
|
10
|
-
|
|
11
|
-
|
|
12
|
-
|
|
13
|
-
|
|
14
|
-
|
|
15
|
-
|
|
16
|
-
|
|
17
|
-
|
|
18
|
-
|
|
19
|
-
|
|
20
|
-
|
|
21
|
-
|
|
22
|
-
|
|
23
|
-
|
|
24
|
-
|
|
25
|
-
|
|
26
|
-
|
|
27
|
-
|
|
1
|
+
import chalk from 'chalk';
|
|
2
|
+
import { ensureDaemon } from '../utils/ensure-daemon.js';
|
|
3
|
+
import { connectWs, post } from '../utils/daemon-client.js';
|
|
4
|
+
import { renderEvent } from '../utils/render.js';
|
|
5
|
+
const TERMINAL_STATES = ['completed', 'failed', 'canceled'];
|
|
6
|
+
export const registerRun = (program) => {
|
|
7
|
+
program
|
|
8
|
+
.command('run')
|
|
9
|
+
.argument('<agent>', 'Agent name')
|
|
10
|
+
.argument('[prompt]', 'Task/prompt for the agent')
|
|
11
|
+
.description('Run an agent')
|
|
12
|
+
.option('-d, --detach', 'Run in background, print run ID')
|
|
13
|
+
.option('--json', 'Output events as JSON lines')
|
|
14
|
+
.option('--config <json>', 'Per-run config overrides (JSON)')
|
|
15
|
+
.option('--context <paths...>', 'Additional context files')
|
|
16
|
+
.action(async (agent, prompt, opts) => {
|
|
17
|
+
await ensureDaemon();
|
|
18
|
+
if (!prompt) {
|
|
19
|
+
console.error(chalk.red('Prompt is required. Usage: agentage run <agent> "<prompt>"'));
|
|
20
|
+
process.exitCode = 1;
|
|
21
|
+
return;
|
|
22
|
+
}
|
|
23
|
+
const config = opts.config
|
|
24
|
+
? JSON.parse(opts.config)
|
|
25
|
+
: undefined;
|
|
26
|
+
const { runId } = await post(`/api/agents/${agent}/run`, {
|
|
27
|
+
task: prompt,
|
|
28
|
+
config,
|
|
29
|
+
context: opts.context,
|
|
30
|
+
});
|
|
31
|
+
if (opts.detach) {
|
|
32
|
+
console.log(runId);
|
|
33
|
+
return;
|
|
34
|
+
}
|
|
35
|
+
// Stream events via WebSocket
|
|
36
|
+
await streamRun(runId, opts.json ?? false);
|
|
37
|
+
});
|
|
28
38
|
};
|
|
39
|
+
const streamRun = (runId, jsonMode) => new Promise((resolve) => {
|
|
40
|
+
const ws = connectWs((data) => {
|
|
41
|
+
const msg = data;
|
|
42
|
+
if (msg.type === 'run_event' && msg.runId === runId) {
|
|
43
|
+
if (jsonMode) {
|
|
44
|
+
console.log(JSON.stringify(msg.event));
|
|
45
|
+
}
|
|
46
|
+
else {
|
|
47
|
+
renderEvent(msg.event);
|
|
48
|
+
}
|
|
49
|
+
}
|
|
50
|
+
if (msg.type === 'run_state' && msg.run.id === runId) {
|
|
51
|
+
if (TERMINAL_STATES.includes(msg.run.state)) {
|
|
52
|
+
ws.close();
|
|
53
|
+
resolve();
|
|
54
|
+
}
|
|
55
|
+
}
|
|
56
|
+
});
|
|
57
|
+
ws.on('open', () => {
|
|
58
|
+
ws.send(JSON.stringify({ type: 'subscribe', runId }));
|
|
59
|
+
});
|
|
60
|
+
ws.on('error', () => {
|
|
61
|
+
resolve();
|
|
62
|
+
});
|
|
63
|
+
ws.on('close', () => {
|
|
64
|
+
resolve();
|
|
65
|
+
});
|
|
66
|
+
// Handle Ctrl+C
|
|
67
|
+
process.on('SIGINT', () => {
|
|
68
|
+
post(`/api/runs/${runId}/cancel`).catch(() => { });
|
|
69
|
+
ws.close();
|
|
70
|
+
resolve();
|
|
71
|
+
});
|
|
72
|
+
});
|
|
29
73
|
//# sourceMappingURL=run.js.map
|
package/dist/commands/run.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"run.js","sourceRoot":"","sources":["../../src/commands/run.ts"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"run.js","sourceRoot":"","sources":["../../src/commands/run.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"runs.d.ts","sourceRoot":"","sources":["../../src/commands/runs.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,KAAK,OAAO,EAAE,MAAM,WAAW,CAAC;AAMzC,eAAO,MAAM,YAAY,GAAI,SAAS,OAAO,KAAG,IAkD/C,CAAC"}
|
|
@@ -0,0 +1,73 @@
|
|
|
1
|
+
import chalk from 'chalk';
|
|
2
|
+
import { ensureDaemon } from '../utils/ensure-daemon.js';
|
|
3
|
+
import { get } from '../utils/daemon-client.js';
|
|
4
|
+
export const registerRuns = (program) => {
|
|
5
|
+
program
|
|
6
|
+
.command('runs')
|
|
7
|
+
.description('List runs')
|
|
8
|
+
.option('--all', 'All runs across all machines')
|
|
9
|
+
.option('--json', 'JSON output')
|
|
10
|
+
.action(async (opts) => {
|
|
11
|
+
await ensureDaemon();
|
|
12
|
+
if (opts.all) {
|
|
13
|
+
console.error(chalk.red("Not connected to hub. Run 'agentage login' first."));
|
|
14
|
+
process.exitCode = 1;
|
|
15
|
+
return;
|
|
16
|
+
}
|
|
17
|
+
const runs = await get('/api/runs');
|
|
18
|
+
if (opts.json) {
|
|
19
|
+
console.log(JSON.stringify(runs, null, 2));
|
|
20
|
+
return;
|
|
21
|
+
}
|
|
22
|
+
if (runs.length === 0) {
|
|
23
|
+
console.log(chalk.gray('No runs.'));
|
|
24
|
+
return;
|
|
25
|
+
}
|
|
26
|
+
console.log(chalk.bold('ID'.padEnd(12)) +
|
|
27
|
+
chalk.bold('AGENT'.padEnd(16)) +
|
|
28
|
+
chalk.bold('STATE'.padEnd(16)) +
|
|
29
|
+
chalk.bold('STARTED'.padEnd(16)) +
|
|
30
|
+
chalk.bold('DURATION'));
|
|
31
|
+
for (const run of runs) {
|
|
32
|
+
const started = run.startedAt ? timeAgo(run.startedAt) : '—';
|
|
33
|
+
const duration = run.startedAt && run.endedAt ? formatDuration(run.endedAt - run.startedAt) : '—';
|
|
34
|
+
const stateColor = getStateColor(run.state);
|
|
35
|
+
console.log(run.id.slice(0, 8).padEnd(12) +
|
|
36
|
+
run.agentName.padEnd(16) +
|
|
37
|
+
stateColor(run.state).padEnd(16 + (stateColor('').length - ''.length)) +
|
|
38
|
+
started.padEnd(16) +
|
|
39
|
+
duration);
|
|
40
|
+
}
|
|
41
|
+
});
|
|
42
|
+
};
|
|
43
|
+
const timeAgo = (ts) => {
|
|
44
|
+
const diff = Math.floor((Date.now() - ts) / 1000);
|
|
45
|
+
if (diff < 60)
|
|
46
|
+
return `${diff}s ago`;
|
|
47
|
+
if (diff < 3600)
|
|
48
|
+
return `${Math.floor(diff / 60)} min ago`;
|
|
49
|
+
return `${Math.floor(diff / 3600)}h ago`;
|
|
50
|
+
};
|
|
51
|
+
const formatDuration = (ms) => {
|
|
52
|
+
const seconds = Math.floor(ms / 1000);
|
|
53
|
+
const m = Math.floor(seconds / 60);
|
|
54
|
+
const s = seconds % 60;
|
|
55
|
+
if (m > 0)
|
|
56
|
+
return `${m}m ${s}s`;
|
|
57
|
+
return `${s}s`;
|
|
58
|
+
};
|
|
59
|
+
const getStateColor = (state) => {
|
|
60
|
+
switch (state) {
|
|
61
|
+
case 'completed':
|
|
62
|
+
return chalk.green;
|
|
63
|
+
case 'failed':
|
|
64
|
+
return chalk.red;
|
|
65
|
+
case 'canceled':
|
|
66
|
+
return chalk.yellow;
|
|
67
|
+
case 'working':
|
|
68
|
+
return chalk.blue;
|
|
69
|
+
default:
|
|
70
|
+
return chalk.gray;
|
|
71
|
+
}
|
|
72
|
+
};
|
|
73
|
+
//# sourceMappingURL=runs.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"runs.js","sourceRoot":"","sources":["../../src/commands/runs.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"status.d.ts","sourceRoot":"","sources":["../../src/commands/status.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,KAAK,OAAO,EAAE,MAAM,WAAW,CAAC;AAczC,eAAO,MAAM,cAAc,GAAI,SAAS,OAAO,KAAG,IAuBjD,CAAC"}
|
|
@@ -0,0 +1,34 @@
|
|
|
1
|
+
import chalk from 'chalk';
|
|
2
|
+
import { ensureDaemon } from '../utils/ensure-daemon.js';
|
|
3
|
+
import { get } from '../utils/daemon-client.js';
|
|
4
|
+
import { getDaemonPid } from '../daemon/daemon.js';
|
|
5
|
+
export const registerStatus = (program) => {
|
|
6
|
+
program
|
|
7
|
+
.command('status')
|
|
8
|
+
.description('Show daemon and connection status')
|
|
9
|
+
.action(async () => {
|
|
10
|
+
await ensureDaemon();
|
|
11
|
+
const health = await get('/api/health');
|
|
12
|
+
const agents = await get('/api/agents');
|
|
13
|
+
const runs = await get('/api/runs');
|
|
14
|
+
const pid = getDaemonPid();
|
|
15
|
+
const uptime = formatUptime(health.uptime);
|
|
16
|
+
const activeRuns = runs.length;
|
|
17
|
+
console.log(`Daemon: ${chalk.green('running')} (PID ${pid}, port 4243)`);
|
|
18
|
+
console.log(`Uptime: ${uptime}`);
|
|
19
|
+
console.log(`Hub: ${health.hubConnected ? chalk.green('connected') : chalk.yellow('not connected (standalone mode)')}`);
|
|
20
|
+
console.log(`Machine: ${health.machineId}`);
|
|
21
|
+
console.log(`Agents: ${agents.length} discovered`);
|
|
22
|
+
console.log(`Runs: ${activeRuns} active`);
|
|
23
|
+
});
|
|
24
|
+
};
|
|
25
|
+
const formatUptime = (seconds) => {
|
|
26
|
+
const h = Math.floor(seconds / 3600);
|
|
27
|
+
const m = Math.floor((seconds % 3600) / 60);
|
|
28
|
+
if (h > 0)
|
|
29
|
+
return `${h}h ${m}m`;
|
|
30
|
+
if (m > 0)
|
|
31
|
+
return `${m}m`;
|
|
32
|
+
return `${seconds}s`;
|
|
33
|
+
};
|
|
34
|
+
//# sourceMappingURL=status.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"status.js","sourceRoot":"","sources":["../../src/commands/status.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,MAAM,OAAO,CAAC;AAC1B,OAAO,EAAE,YAAY,EAAE,MAAM,2BAA2B,CAAC;AACzD,OAAO,EAAE,GAAG,EAAE,MAAM,2BAA2B,CAAC;AAChD,OAAO,EAAE,YAAY,EAAE,MAAM,qBAAqB,CAAC;AAUnD,MAAM,CAAC,MAAM,cAAc,GAAG,CAAC,OAAgB,EAAQ,EAAE;IACvD,OAAO;SACJ,OAAO,CAAC,QAAQ,CAAC;SACjB,WAAW,CAAC,mCAAmC,CAAC;SAChD,MAAM,CAAC,KAAK,IAAI,EAAE;QACjB,MAAM,YAAY,EAAE,CAAC;QACrB,MAAM,MAAM,GAAG,MAAM,GAAG,CAAiB,aAAa,CAAC,CAAC;QACxD,MAAM,MAAM,GAAG,MAAM,GAAG,CAAY,aAAa,CAAC,CAAC;QACnD,MAAM,IAAI,GAAG,MAAM,GAAG,CAAY,WAAW,CAAC,CAAC;QAC/C,MAAM,GAAG,GAAG,YAAY,EAAE,CAAC;QAE3B,MAAM,MAAM,GAAG,YAAY,CAAC,MAAM,CAAC,MAAM,CAAC,CAAC;QAC3C,MAAM,UAAU,GAAG,IAAI,CAAC,MAAM,CAAC;QAE/B,OAAO,CAAC,GAAG,CAAC,eAAe,KAAK,CAAC,KAAK,CAAC,SAAS,CAAC,SAAS,GAAG,cAAc,CAAC,CAAC;QAC7E,OAAO,CAAC,GAAG,CAAC,eAAe,MAAM,EAAE,CAAC,CAAC;QACrC,OAAO,CAAC,GAAG,CACT,eAAe,MAAM,CAAC,YAAY,CAAC,CAAC,CAAC,KAAK,CAAC,KAAK,CAAC,WAAW,CAAC,CAAC,CAAC,CAAC,KAAK,CAAC,MAAM,CAAC,iCAAiC,CAAC,EAAE,CAClH,CAAC;QACF,OAAO,CAAC,GAAG,CAAC,eAAe,MAAM,CAAC,SAAS,EAAE,CAAC,CAAC;QAC/C,OAAO,CAAC,GAAG,CAAC,eAAe,MAAM,CAAC,MAAM,aAAa,CAAC,CAAC;QACvD,OAAO,CAAC,GAAG,CAAC,eAAe,UAAU,SAAS,CAAC,CAAC;IAClD,CAAC,CAAC,CAAC;AACP,CAAC,CAAC;AAEF,MAAM,YAAY,GAAG,CAAC,OAAe,EAAU,EAAE;IAC/C,MAAM,CAAC,GAAG,IAAI,CAAC,KAAK,CAAC,OAAO,GAAG,IAAI,CAAC,CAAC;IACrC,MAAM,CAAC,GAAG,IAAI,CAAC,KAAK,CAAC,CAAC,OAAO,GAAG,IAAI,CAAC,GAAG,EAAE,CAAC,CAAC;IAC5C,IAAI,CAAC,GAAG,CAAC;QAAE,OAAO,GAAG,CAAC,KAAK,CAAC,GAAG,CAAC;IAChC,IAAI,CAAC,GAAG,CAAC;QAAE,OAAO,GAAG,CAAC,GAAG,CAAC;IAC1B,OAAO,GAAG,OAAO,GAAG,CAAC;AACvB,CAAC,CAAC"}
|