@agentage/cli 0.1.19 → 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.
- package/README.md +111 -199
- package/dist/cli.js +21 -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 +78 -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 +68 -57
- 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 +22 -21
- 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 +56 -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 +166 -22
- 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 +44 -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 +64 -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 +189 -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 +50 -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/hub/auth-callback.d.ts +4 -0
- package/dist/hub/auth-callback.d.ts.map +1 -0
- package/dist/hub/auth-callback.js +75 -0
- package/dist/hub/auth-callback.js.map +1 -0
- package/dist/hub/auth.d.ts +21 -0
- package/dist/hub/auth.d.ts.map +1 -0
- package/dist/hub/auth.js +26 -0
- package/dist/hub/auth.js.map +1 -0
- package/dist/hub/hub-client.d.ts +33 -0
- package/dist/hub/hub-client.d.ts.map +1 -0
- package/dist/hub/hub-client.js +64 -0
- package/dist/hub/hub-client.js.map +1 -0
- package/dist/hub/hub-sync.d.ts +9 -0
- package/dist/hub/hub-sync.d.ts.map +1 -0
- package/dist/hub/hub-sync.js +150 -0
- package/dist/hub/hub-sync.js.map +1 -0
- package/dist/hub/hub-ws.d.ts +7 -0
- package/dist/hub/hub-ws.d.ts.map +1 -0
- package/dist/hub/hub-ws.js +105 -0
- package/dist/hub/hub-ws.js.map +1 -0
- package/dist/hub/reconnection.d.ts +13 -0
- package/dist/hub/reconnection.d.ts.map +1 -0
- package/dist/hub/reconnection.js +39 -0
- package/dist/hub/reconnection.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/dist/utils/version.d.ts +1 -9
- package/dist/utils/version.d.ts.map +1 -1
- package/dist/utils/version.js +4 -32
- package/dist/utils/version.js.map +1 -1
- package/package.json +47 -54
- package/.github/copilot-instructions.md +0 -126
- package/.github/dependabot.yml +0 -41
- package/.github/workflows/ci.yml +0 -50
- package/.github/workflows/publish.yml +0 -170
- 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 -73
- 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/lockfile.types.d.ts +0 -1
- package/dist/types/lockfile.types.d.ts.map +0 -1
- package/dist/types/lockfile.types.js +0 -2
- package/dist/types/lockfile.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/lockfile.d.ts +0 -1
- package/dist/utils/lockfile.d.ts.map +0 -1
- package/dist/utils/lockfile.js +0 -2
- package/dist/utils/lockfile.js.map +0 -1
- package/dist/utils/lockfile.test.d.ts +0 -1
- package/dist/utils/lockfile.test.d.ts.map +0 -1
- package/dist/utils/lockfile.test.js +0 -7
- package/dist/utils/lockfile.test.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,50 @@
|
|
|
1
|
+
import { loadConfig } from './daemon/config.js';
|
|
2
|
+
import { logError, logInfo } from './daemon/logger.js';
|
|
3
|
+
import { writePidFile, removePidFile } from './daemon/daemon.js';
|
|
4
|
+
import { createDaemonServer } from './daemon/server.js';
|
|
5
|
+
import { scanAgents } from './discovery/scanner.js';
|
|
6
|
+
import { createMarkdownFactory } from './discovery/markdown-factory.js';
|
|
7
|
+
import { createCodeFactory } from './discovery/code-factory.js';
|
|
8
|
+
import { getHubSync } from './hub/hub-sync.js';
|
|
9
|
+
const main = async () => {
|
|
10
|
+
const config = loadConfig();
|
|
11
|
+
logInfo(`Daemon starting (PID ${process.pid})`);
|
|
12
|
+
writePidFile(process.pid);
|
|
13
|
+
const server = createDaemonServer();
|
|
14
|
+
const factories = [createMarkdownFactory(), createCodeFactory()];
|
|
15
|
+
server.setFactories(factories);
|
|
16
|
+
// Initial agent discovery
|
|
17
|
+
const agents = await scanAgents(config.discovery.dirs, factories);
|
|
18
|
+
server.updateAgents(agents);
|
|
19
|
+
logInfo(`Discovered ${agents.length} agent(s)`);
|
|
20
|
+
await server.start();
|
|
21
|
+
logInfo(`Daemon ready on port ${config.daemon.port}`);
|
|
22
|
+
// Initialize hub sync (registers + heartbeat if auth.json exists)
|
|
23
|
+
const hubSync = getHubSync();
|
|
24
|
+
await hubSync.start();
|
|
25
|
+
const shutdown = async () => {
|
|
26
|
+
logInfo('Daemon shutting down...');
|
|
27
|
+
await hubSync.stop();
|
|
28
|
+
await server.stop();
|
|
29
|
+
removePidFile();
|
|
30
|
+
process.exit(0);
|
|
31
|
+
};
|
|
32
|
+
process.on('SIGTERM', () => {
|
|
33
|
+
shutdown().catch((err) => {
|
|
34
|
+
logError(`Shutdown error: ${err instanceof Error ? err.message : String(err)}`);
|
|
35
|
+
process.exit(1);
|
|
36
|
+
});
|
|
37
|
+
});
|
|
38
|
+
process.on('SIGINT', () => {
|
|
39
|
+
shutdown().catch((err) => {
|
|
40
|
+
logError(`Shutdown error: ${err instanceof Error ? err.message : String(err)}`);
|
|
41
|
+
process.exit(1);
|
|
42
|
+
});
|
|
43
|
+
});
|
|
44
|
+
};
|
|
45
|
+
main().catch((err) => {
|
|
46
|
+
logError(`Daemon failed to start: ${err instanceof Error ? err.message : String(err)}`);
|
|
47
|
+
removePidFile();
|
|
48
|
+
process.exit(1);
|
|
49
|
+
});
|
|
50
|
+
//# sourceMappingURL=daemon-entry.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"daemon-entry.js","sourceRoot":"","sources":["../src/daemon-entry.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"code-factory.d.ts","sourceRoot":"","sources":["../../src/discovery/code-factory.ts"],"names":[],"mappings":"AACA,OAAO,EAAc,KAAK,YAAY,EAAE,MAAM,gBAAgB,CAAC;AAO/D,eAAO,MAAM,iBAAiB,QACxB,YAgCH,CAAC"}
|
|
@@ -0,0 +1,32 @@
|
|
|
1
|
+
import { basename } from 'node:path';
|
|
2
|
+
import { createJiti } from 'jiti';
|
|
3
|
+
import { logDebug, logWarn } from '../daemon/logger.js';
|
|
4
|
+
const matches = (filePath) => basename(filePath) === 'agent.ts' || basename(filePath) === 'agent.js';
|
|
5
|
+
export const createCodeFactory = () => async (filePath) => {
|
|
6
|
+
if (!matches(filePath))
|
|
7
|
+
return null;
|
|
8
|
+
logDebug(`Loading code agent from ${filePath}`);
|
|
9
|
+
try {
|
|
10
|
+
const jiti = createJiti(filePath, {
|
|
11
|
+
interopDefault: true,
|
|
12
|
+
moduleCache: false,
|
|
13
|
+
});
|
|
14
|
+
const mod = (await jiti.import(filePath));
|
|
15
|
+
const agent = mod.default ?? mod;
|
|
16
|
+
if (agent &&
|
|
17
|
+
typeof agent === 'object' &&
|
|
18
|
+
'manifest' in agent &&
|
|
19
|
+
'run' in agent &&
|
|
20
|
+
typeof agent.run === 'function') {
|
|
21
|
+
return agent;
|
|
22
|
+
}
|
|
23
|
+
logWarn(`Module at ${filePath} does not export a valid Agent`);
|
|
24
|
+
return null;
|
|
25
|
+
}
|
|
26
|
+
catch (err) {
|
|
27
|
+
const message = err instanceof Error ? err.message : String(err);
|
|
28
|
+
logWarn(`Failed to load code agent from ${filePath}: ${message}`);
|
|
29
|
+
return null;
|
|
30
|
+
}
|
|
31
|
+
};
|
|
32
|
+
//# sourceMappingURL=code-factory.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"code-factory.js","sourceRoot":"","sources":["../../src/discovery/code-factory.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,QAAQ,EAAE,MAAM,WAAW,CAAC;AAErC,OAAO,EAAE,UAAU,EAAE,MAAM,MAAM,CAAC;AAClC,OAAO,EAAE,QAAQ,EAAE,OAAO,EAAE,MAAM,qBAAqB,CAAC;AAExD,MAAM,OAAO,GAAG,CAAC,QAAgB,EAAW,EAAE,CAC5C,QAAQ,CAAC,QAAQ,CAAC,KAAK,UAAU,IAAI,QAAQ,CAAC,QAAQ,CAAC,KAAK,UAAU,CAAC;AAEzE,MAAM,CAAC,MAAM,iBAAiB,GAC5B,GAAiB,EAAE,CACnB,KAAK,EAAE,QAAgB,EAAyB,EAAE;IAChD,IAAI,CAAC,OAAO,CAAC,QAAQ,CAAC;QAAE,OAAO,IAAI,CAAC;IAEpC,QAAQ,CAAC,2BAA2B,QAAQ,EAAE,CAAC,CAAC;IAEhD,IAAI,CAAC;QACH,MAAM,IAAI,GAAG,UAAU,CAAC,QAAQ,EAAE;YAChC,cAAc,EAAE,IAAI;YACpB,WAAW,EAAE,KAAK;SACnB,CAAC,CAAC;QAEH,MAAM,GAAG,GAAG,CAAC,MAAM,IAAI,CAAC,MAAM,CAAC,QAAQ,CAAC,CAAkD,CAAC;QAC3F,MAAM,KAAK,GAAG,GAAG,CAAC,OAAO,IAAI,GAAG,CAAC;QAEjC,IACE,KAAK;YACL,OAAO,KAAK,KAAK,QAAQ;YACzB,UAAU,IAAI,KAAK;YACnB,KAAK,IAAI,KAAK;YACd,OAAO,KAAK,CAAC,GAAG,KAAK,UAAU,EAC/B,CAAC;YACD,OAAO,KAAc,CAAC;QACxB,CAAC;QAED,OAAO,CAAC,aAAa,QAAQ,gCAAgC,CAAC,CAAC;QAC/D,OAAO,IAAI,CAAC;IACd,CAAC;IAAC,OAAO,GAAY,EAAE,CAAC;QACtB,MAAM,OAAO,GAAG,GAAG,YAAY,KAAK,CAAC,CAAC,CAAC,GAAG,CAAC,OAAO,CAAC,CAAC,CAAC,MAAM,CAAC,GAAG,CAAC,CAAC;QACjE,OAAO,CAAC,kCAAkC,QAAQ,KAAK,OAAO,EAAE,CAAC,CAAC;QAClE,OAAO,IAAI,CAAC;IACd,CAAC;AACH,CAAC,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"markdown-factory.d.ts","sourceRoot":"","sources":["../../src/discovery/markdown-factory.ts"],"names":[],"mappings":"AAGA,OAAO,EAEL,KAAK,YAAY,EAIlB,MAAM,gBAAgB,CAAC;AAexB,eAAO,MAAM,qBAAqB,QAC5B,YAgEH,CAAC"}
|
|
@@ -0,0 +1,63 @@
|
|
|
1
|
+
import { readFileSync } from 'node:fs';
|
|
2
|
+
import { basename } from 'node:path';
|
|
3
|
+
import matter from 'gray-matter';
|
|
4
|
+
import { randomUUID } from 'node:crypto';
|
|
5
|
+
const matches = (filePath) => filePath.endsWith('.agent.md') || filePath.endsWith('/SKILL.md');
|
|
6
|
+
export const createMarkdownFactory = () => async (filePath) => {
|
|
7
|
+
if (!matches(filePath))
|
|
8
|
+
return null;
|
|
9
|
+
const raw = readFileSync(filePath, 'utf-8');
|
|
10
|
+
const { data, content } = matter(raw);
|
|
11
|
+
const fm = data;
|
|
12
|
+
const name = fm.name ?? basename(filePath, '.agent.md');
|
|
13
|
+
const systemPrompt = content.trim();
|
|
14
|
+
const agent = {
|
|
15
|
+
manifest: {
|
|
16
|
+
name,
|
|
17
|
+
description: fm.description,
|
|
18
|
+
version: fm.version,
|
|
19
|
+
tags: fm.tags,
|
|
20
|
+
path: filePath,
|
|
21
|
+
config: {
|
|
22
|
+
systemPrompt,
|
|
23
|
+
...(fm.model ? { model: fm.model } : {}),
|
|
24
|
+
...(fm.temperature !== undefined ? { temperature: fm.temperature } : {}),
|
|
25
|
+
},
|
|
26
|
+
},
|
|
27
|
+
async run(input) {
|
|
28
|
+
const runId = randomUUID();
|
|
29
|
+
let canceled = false;
|
|
30
|
+
async function* generateEvents() {
|
|
31
|
+
yield {
|
|
32
|
+
type: 'output',
|
|
33
|
+
data: { type: 'output', content: systemPrompt, format: 'text' },
|
|
34
|
+
timestamp: Date.now(),
|
|
35
|
+
};
|
|
36
|
+
if (!canceled) {
|
|
37
|
+
yield {
|
|
38
|
+
type: 'output',
|
|
39
|
+
data: { type: 'output', content: `\nTask: ${input.task}`, format: 'text' },
|
|
40
|
+
timestamp: Date.now(),
|
|
41
|
+
};
|
|
42
|
+
}
|
|
43
|
+
yield {
|
|
44
|
+
type: 'result',
|
|
45
|
+
data: { type: 'result', success: true, output: 'Agent execution complete' },
|
|
46
|
+
timestamp: Date.now(),
|
|
47
|
+
};
|
|
48
|
+
}
|
|
49
|
+
return {
|
|
50
|
+
runId,
|
|
51
|
+
events: generateEvents(),
|
|
52
|
+
cancel: () => {
|
|
53
|
+
canceled = true;
|
|
54
|
+
},
|
|
55
|
+
sendInput: () => {
|
|
56
|
+
// No-op for markdown agents
|
|
57
|
+
},
|
|
58
|
+
};
|
|
59
|
+
},
|
|
60
|
+
};
|
|
61
|
+
return agent;
|
|
62
|
+
};
|
|
63
|
+
//# sourceMappingURL=markdown-factory.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"markdown-factory.js","sourceRoot":"","sources":["../../src/discovery/markdown-factory.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"scanner.d.ts","sourceRoot":"","sources":["../../src/discovery/scanner.ts"],"names":[],"mappings":"AAEA,OAAO,EAAE,KAAK,KAAK,EAAE,KAAK,YAAY,EAAE,MAAM,gBAAgB,CAAC;AAuB/D,eAAO,MAAM,UAAU,GAAU,MAAM,MAAM,EAAE,EAAE,WAAW,YAAY,EAAE,KAAG,OAAO,CAAC,KAAK,EAAE,CA6B3F,CAAC"}
|
|
@@ -0,0 +1,50 @@
|
|
|
1
|
+
import { existsSync, readdirSync } from 'node:fs';
|
|
2
|
+
import { join } from 'node:path';
|
|
3
|
+
import { logDebug, logInfo, logWarn } from '../daemon/logger.js';
|
|
4
|
+
const getAllFiles = (dir) => {
|
|
5
|
+
const results = [];
|
|
6
|
+
if (!existsSync(dir)) {
|
|
7
|
+
logWarn(`Discovery dir does not exist: ${dir}`);
|
|
8
|
+
return results;
|
|
9
|
+
}
|
|
10
|
+
const entries = readdirSync(dir, { withFileTypes: true });
|
|
11
|
+
for (const entry of entries) {
|
|
12
|
+
const fullPath = join(dir, entry.name);
|
|
13
|
+
if (entry.isDirectory()) {
|
|
14
|
+
results.push(...getAllFiles(fullPath));
|
|
15
|
+
}
|
|
16
|
+
else {
|
|
17
|
+
results.push(fullPath);
|
|
18
|
+
}
|
|
19
|
+
}
|
|
20
|
+
return results;
|
|
21
|
+
};
|
|
22
|
+
export const scanAgents = async (dirs, factories) => {
|
|
23
|
+
const agents = [];
|
|
24
|
+
const seen = new Set();
|
|
25
|
+
for (const dir of dirs) {
|
|
26
|
+
const expandedDir = dir.replace(/^~/, process.env['HOME'] || '~');
|
|
27
|
+
logDebug(`Scanning directory: ${expandedDir}`);
|
|
28
|
+
const files = getAllFiles(expandedDir);
|
|
29
|
+
for (const file of files) {
|
|
30
|
+
for (const factory of factories) {
|
|
31
|
+
try {
|
|
32
|
+
const agent = await factory(file);
|
|
33
|
+
if (agent && !seen.has(agent.manifest.name)) {
|
|
34
|
+
agents.push(agent);
|
|
35
|
+
seen.add(agent.manifest.name);
|
|
36
|
+
logDebug(`Discovered agent: ${agent.manifest.name} from ${file}`);
|
|
37
|
+
break;
|
|
38
|
+
}
|
|
39
|
+
}
|
|
40
|
+
catch (err) {
|
|
41
|
+
const message = err instanceof Error ? err.message : String(err);
|
|
42
|
+
logWarn(`Factory error on ${file}: ${message}`);
|
|
43
|
+
}
|
|
44
|
+
}
|
|
45
|
+
}
|
|
46
|
+
}
|
|
47
|
+
logInfo(`Scan complete: ${agents.length} agent(s) found`);
|
|
48
|
+
return agents;
|
|
49
|
+
};
|
|
50
|
+
//# sourceMappingURL=scanner.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"scanner.js","sourceRoot":"","sources":["../../src/discovery/scanner.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,UAAU,EAAE,WAAW,EAAE,MAAM,SAAS,CAAC;AAClD,OAAO,EAAE,IAAI,EAAE,MAAM,WAAW,CAAC;AAEjC,OAAO,EAAE,QAAQ,EAAE,OAAO,EAAE,OAAO,EAAE,MAAM,qBAAqB,CAAC;AAEjE,MAAM,WAAW,GAAG,CAAC,GAAW,EAAY,EAAE;IAC5C,MAAM,OAAO,GAAa,EAAE,CAAC;IAE7B,IAAI,CAAC,UAAU,CAAC,GAAG,CAAC,EAAE,CAAC;QACrB,OAAO,CAAC,iCAAiC,GAAG,EAAE,CAAC,CAAC;QAChD,OAAO,OAAO,CAAC;IACjB,CAAC;IAED,MAAM,OAAO,GAAG,WAAW,CAAC,GAAG,EAAE,EAAE,aAAa,EAAE,IAAI,EAAE,CAAC,CAAC;IAC1D,KAAK,MAAM,KAAK,IAAI,OAAO,EAAE,CAAC;QAC5B,MAAM,QAAQ,GAAG,IAAI,CAAC,GAAG,EAAE,KAAK,CAAC,IAAI,CAAC,CAAC;QACvC,IAAI,KAAK,CAAC,WAAW,EAAE,EAAE,CAAC;YACxB,OAAO,CAAC,IAAI,CAAC,GAAG,WAAW,CAAC,QAAQ,CAAC,CAAC,CAAC;QACzC,CAAC;aAAM,CAAC;YACN,OAAO,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC;QACzB,CAAC;IACH,CAAC;IACD,OAAO,OAAO,CAAC;AACjB,CAAC,CAAC;AAEF,MAAM,CAAC,MAAM,UAAU,GAAG,KAAK,EAAE,IAAc,EAAE,SAAyB,EAAoB,EAAE;IAC9F,MAAM,MAAM,GAAY,EAAE,CAAC;IAC3B,MAAM,IAAI,GAAG,IAAI,GAAG,EAAU,CAAC;IAE/B,KAAK,MAAM,GAAG,IAAI,IAAI,EAAE,CAAC;QACvB,MAAM,WAAW,GAAG,GAAG,CAAC,OAAO,CAAC,IAAI,EAAE,OAAO,CAAC,GAAG,CAAC,MAAM,CAAC,IAAI,GAAG,CAAC,CAAC;QAClE,QAAQ,CAAC,uBAAuB,WAAW,EAAE,CAAC,CAAC;QAC/C,MAAM,KAAK,GAAG,WAAW,CAAC,WAAW,CAAC,CAAC;QAEvC,KAAK,MAAM,IAAI,IAAI,KAAK,EAAE,CAAC;YACzB,KAAK,MAAM,OAAO,IAAI,SAAS,EAAE,CAAC;gBAChC,IAAI,CAAC;oBACH,MAAM,KAAK,GAAG,MAAM,OAAO,CAAC,IAAI,CAAC,CAAC;oBAClC,IAAI,KAAK,IAAI,CAAC,IAAI,CAAC,GAAG,CAAC,KAAK,CAAC,QAAQ,CAAC,IAAI,CAAC,EAAE,CAAC;wBAC5C,MAAM,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;wBACnB,IAAI,CAAC,GAAG,CAAC,KAAK,CAAC,QAAQ,CAAC,IAAI,CAAC,CAAC;wBAC9B,QAAQ,CAAC,qBAAqB,KAAK,CAAC,QAAQ,CAAC,IAAI,SAAS,IAAI,EAAE,CAAC,CAAC;wBAClE,MAAM;oBACR,CAAC;gBACH,CAAC;gBAAC,OAAO,GAAY,EAAE,CAAC;oBACtB,MAAM,OAAO,GAAG,GAAG,YAAY,KAAK,CAAC,CAAC,CAAC,GAAG,CAAC,OAAO,CAAC,CAAC,CAAC,MAAM,CAAC,GAAG,CAAC,CAAC;oBACjE,OAAO,CAAC,oBAAoB,IAAI,KAAK,OAAO,EAAE,CAAC,CAAC;gBAClD,CAAC;YACH,CAAC;QACH,CAAC;IACH,CAAC;IAED,OAAO,CAAC,kBAAkB,MAAM,CAAC,MAAM,iBAAiB,CAAC,CAAC;IAC1D,OAAO,MAAM,CAAC;AAChB,CAAC,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"auth-callback.d.ts","sourceRoot":"","sources":["../../src/hub/auth-callback.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,KAAK,SAAS,EAAE,MAAM,WAAW,CAAC;AAsB3C,eAAO,MAAM,mBAAmB,QAAO,OAAO,CAAC,SAAS,CAwEpD,CAAC;AAEL,eAAO,MAAM,eAAe,QAAO,MAKlC,CAAC"}
|
|
@@ -0,0 +1,75 @@
|
|
|
1
|
+
import express from 'express';
|
|
2
|
+
const decodeJwtPayload = (token) => {
|
|
3
|
+
const parts = token.split('.');
|
|
4
|
+
if (parts.length !== 3) {
|
|
5
|
+
throw new Error('Invalid JWT format');
|
|
6
|
+
}
|
|
7
|
+
const payload = parts[1];
|
|
8
|
+
const json = Buffer.from(payload, 'base64url').toString('utf-8');
|
|
9
|
+
return JSON.parse(json);
|
|
10
|
+
};
|
|
11
|
+
export const startCallbackServer = () => new Promise((resolve, reject) => {
|
|
12
|
+
const app = express();
|
|
13
|
+
const server = app.listen(0, () => {
|
|
14
|
+
const addr = server.address();
|
|
15
|
+
const port = typeof addr === 'object' && addr ? addr.port : 0;
|
|
16
|
+
// Timeout after 120 seconds
|
|
17
|
+
const timeout = setTimeout(() => {
|
|
18
|
+
server.close();
|
|
19
|
+
reject(new Error('Login timed out — no callback received within 120 seconds'));
|
|
20
|
+
}, 120_000);
|
|
21
|
+
app.get('/auth/callback', (req, res) => {
|
|
22
|
+
clearTimeout(timeout);
|
|
23
|
+
const accessToken = req.query.access_token;
|
|
24
|
+
const refreshToken = req.query.refresh_token;
|
|
25
|
+
const expiresAt = req.query.expires_at;
|
|
26
|
+
if (accessToken) {
|
|
27
|
+
// Primary flow — tokens provided directly by the hub login page
|
|
28
|
+
try {
|
|
29
|
+
const payload = decodeJwtPayload(accessToken);
|
|
30
|
+
res.send('<html><body><h2>Login successful!</h2><p>You can close this window.</p></body></html>');
|
|
31
|
+
server.close();
|
|
32
|
+
resolve({
|
|
33
|
+
session: {
|
|
34
|
+
access_token: accessToken,
|
|
35
|
+
refresh_token: refreshToken ?? '',
|
|
36
|
+
expires_at: expiresAt ? Number(expiresAt) : 0,
|
|
37
|
+
},
|
|
38
|
+
user: {
|
|
39
|
+
id: payload.sub ?? '',
|
|
40
|
+
email: payload.email ?? '',
|
|
41
|
+
name: payload.user_metadata?.full_name ?? payload.user_metadata?.name ?? '',
|
|
42
|
+
avatar: payload.user_metadata?.avatar_url ?? '',
|
|
43
|
+
},
|
|
44
|
+
hub: {
|
|
45
|
+
url: '',
|
|
46
|
+
machineId: '',
|
|
47
|
+
},
|
|
48
|
+
});
|
|
49
|
+
}
|
|
50
|
+
catch (err) {
|
|
51
|
+
res.status(500).send('Failed to decode access token');
|
|
52
|
+
server.close();
|
|
53
|
+
reject(new Error(`Failed to decode access token: ${err instanceof Error ? err.message : String(err)}`));
|
|
54
|
+
}
|
|
55
|
+
return;
|
|
56
|
+
}
|
|
57
|
+
// No recognized params
|
|
58
|
+
res.status(400).send('Missing authentication parameters');
|
|
59
|
+
server.close();
|
|
60
|
+
reject(new Error('Missing authentication parameters in callback'));
|
|
61
|
+
});
|
|
62
|
+
// Export port for the caller to build the OAuth URL
|
|
63
|
+
server.callbackPort = port;
|
|
64
|
+
});
|
|
65
|
+
// Expose the server for the caller to read the port
|
|
66
|
+
startCallbackServer._server = server;
|
|
67
|
+
});
|
|
68
|
+
export const getCallbackPort = () => {
|
|
69
|
+
const server = startCallbackServer._server;
|
|
70
|
+
if (!server)
|
|
71
|
+
return 0;
|
|
72
|
+
const addr = server.address();
|
|
73
|
+
return typeof addr === 'object' && addr ? addr.port : 0;
|
|
74
|
+
};
|
|
75
|
+
//# sourceMappingURL=auth-callback.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"auth-callback.js","sourceRoot":"","sources":["../../src/hub/auth-callback.ts"],"names":[],"mappings":"AAAA,OAAO,OAAO,MAAM,SAAS,CAAC;AAa9B,MAAM,gBAAgB,GAAG,CAAC,KAAa,EAAc,EAAE;IACrD,MAAM,KAAK,GAAG,KAAK,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC;IAC/B,IAAI,KAAK,CAAC,MAAM,KAAK,CAAC,EAAE,CAAC;QACvB,MAAM,IAAI,KAAK,CAAC,oBAAoB,CAAC,CAAC;IACxC,CAAC;IACD,MAAM,OAAO,GAAG,KAAK,CAAC,CAAC,CAAC,CAAC;IACzB,MAAM,IAAI,GAAG,MAAM,CAAC,IAAI,CAAC,OAAO,EAAE,WAAW,CAAC,CAAC,QAAQ,CAAC,OAAO,CAAC,CAAC;IACjE,OAAO,IAAI,CAAC,KAAK,CAAC,IAAI,CAAe,CAAC;AACxC,CAAC,CAAC;AAEF,MAAM,CAAC,MAAM,mBAAmB,GAAG,GAAuB,EAAE,CAC1D,IAAI,OAAO,CAAC,CAAC,OAAO,EAAE,MAAM,EAAE,EAAE;IAC9B,MAAM,GAAG,GAAG,OAAO,EAAE,CAAC;IAEtB,MAAM,MAAM,GAAG,GAAG,CAAC,MAAM,CAAC,CAAC,EAAE,GAAG,EAAE;QAChC,MAAM,IAAI,GAAG,MAAM,CAAC,OAAO,EAAE,CAAC;QAC9B,MAAM,IAAI,GAAG,OAAO,IAAI,KAAK,QAAQ,IAAI,IAAI,CAAC,CAAC,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC,CAAC;QAE9D,4BAA4B;QAC5B,MAAM,OAAO,GAAG,UAAU,CAAC,GAAG,EAAE;YAC9B,MAAM,CAAC,KAAK,EAAE,CAAC;YACf,MAAM,CAAC,IAAI,KAAK,CAAC,2DAA2D,CAAC,CAAC,CAAC;QACjF,CAAC,EAAE,OAAO,CAAC,CAAC;QAEZ,GAAG,CAAC,GAAG,CAAC,gBAAgB,EAAE,CAAC,GAAG,EAAE,GAAG,EAAE,EAAE;YACrC,YAAY,CAAC,OAAO,CAAC,CAAC;YAEtB,MAAM,WAAW,GAAG,GAAG,CAAC,KAAK,CAAC,YAAkC,CAAC;YACjE,MAAM,YAAY,GAAG,GAAG,CAAC,KAAK,CAAC,aAAmC,CAAC;YACnE,MAAM,SAAS,GAAG,GAAG,CAAC,KAAK,CAAC,UAAgC,CAAC;YAE7D,IAAI,WAAW,EAAE,CAAC;gBAChB,gEAAgE;gBAChE,IAAI,CAAC;oBACH,MAAM,OAAO,GAAG,gBAAgB,CAAC,WAAW,CAAC,CAAC;oBAE9C,GAAG,CAAC,IAAI,CACN,uFAAuF,CACxF,CAAC;oBACF,MAAM,CAAC,KAAK,EAAE,CAAC;oBAEf,OAAO,CAAC;wBACN,OAAO,EAAE;4BACP,YAAY,EAAE,WAAW;4BACzB,aAAa,EAAE,YAAY,IAAI,EAAE;4BACjC,UAAU,EAAE,SAAS,CAAC,CAAC,CAAC,MAAM,CAAC,SAAS,CAAC,CAAC,CAAC,CAAC,CAAC;yBAC9C;wBACD,IAAI,EAAE;4BACJ,EAAE,EAAE,OAAO,CAAC,GAAG,IAAI,EAAE;4BACrB,KAAK,EAAE,OAAO,CAAC,KAAK,IAAI,EAAE;4BAC1B,IAAI,EAAE,OAAO,CAAC,aAAa,EAAE,SAAS,IAAI,OAAO,CAAC,aAAa,EAAE,IAAI,IAAI,EAAE;4BAC3E,MAAM,EAAE,OAAO,CAAC,aAAa,EAAE,UAAU,IAAI,EAAE;yBAChD;wBACD,GAAG,EAAE;4BACH,GAAG,EAAE,EAAE;4BACP,SAAS,EAAE,EAAE;yBACd;qBACF,CAAC,CAAC;gBACL,CAAC;gBAAC,OAAO,GAAG,EAAE,CAAC;oBACb,GAAG,CAAC,MAAM,CAAC,GAAG,CAAC,CAAC,IAAI,CAAC,+BAA+B,CAAC,CAAC;oBACtD,MAAM,CAAC,KAAK,EAAE,CAAC;oBACf,MAAM,CACJ,IAAI,KAAK,CACP,kCAAkC,GAAG,YAAY,KAAK,CAAC,CAAC,CAAC,GAAG,CAAC,OAAO,CAAC,CAAC,CAAC,MAAM,CAAC,GAAG,CAAC,EAAE,CACrF,CACF,CAAC;gBACJ,CAAC;gBACD,OAAO;YACT,CAAC;YAED,uBAAuB;YACvB,GAAG,CAAC,MAAM,CAAC,GAAG,CAAC,CAAC,IAAI,CAAC,mCAAmC,CAAC,CAAC;YAC1D,MAAM,CAAC,KAAK,EAAE,CAAC;YACf,MAAM,CAAC,IAAI,KAAK,CAAC,+CAA+C,CAAC,CAAC,CAAC;QACrE,CAAC,CAAC,CAAC;QAEH,oDAAoD;QACnD,MAAoC,CAAC,YAAY,GAAG,IAAI,CAAC;IAC5D,CAAC,CAAC,CAAC;IAEH,oDAAoD;IACnD,mBAAmD,CAAC,OAAO,GAAG,MAAM,CAAC;AACxE,CAAC,CAAC,CAAC;AAEL,MAAM,CAAC,MAAM,eAAe,GAAG,GAAW,EAAE;IAC1C,MAAM,MAAM,GAAI,mBAAgE,CAAC,OAAO,CAAC;IACzF,IAAI,CAAC,MAAM;QAAE,OAAO,CAAC,CAAC;IACtB,MAAM,IAAI,GAAG,MAAM,CAAC,OAAO,EAAE,CAAC;IAC9B,OAAO,OAAO,IAAI,KAAK,QAAQ,IAAI,IAAI,CAAC,CAAC,CAAE,IAAyB,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC,CAAC;AAChF,CAAC,CAAC"}
|
|
@@ -0,0 +1,21 @@
|
|
|
1
|
+
export interface AuthState {
|
|
2
|
+
session: {
|
|
3
|
+
access_token: string;
|
|
4
|
+
refresh_token: string;
|
|
5
|
+
expires_at: number;
|
|
6
|
+
};
|
|
7
|
+
user: {
|
|
8
|
+
id: string;
|
|
9
|
+
email: string;
|
|
10
|
+
name?: string;
|
|
11
|
+
avatar?: string;
|
|
12
|
+
};
|
|
13
|
+
hub: {
|
|
14
|
+
url: string;
|
|
15
|
+
machineId: string;
|
|
16
|
+
};
|
|
17
|
+
}
|
|
18
|
+
export declare const readAuth: () => AuthState | null;
|
|
19
|
+
export declare const saveAuth: (state: AuthState) => void;
|
|
20
|
+
export declare const deleteAuth: () => void;
|
|
21
|
+
//# sourceMappingURL=auth.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"auth.d.ts","sourceRoot":"","sources":["../../src/hub/auth.ts"],"names":[],"mappings":"AAIA,MAAM,WAAW,SAAS;IACxB,OAAO,EAAE;QACP,YAAY,EAAE,MAAM,CAAC;QACrB,aAAa,EAAE,MAAM,CAAC;QACtB,UAAU,EAAE,MAAM,CAAC;KACpB,CAAC;IACF,IAAI,EAAE;QACJ,EAAE,EAAE,MAAM,CAAC;QACX,KAAK,EAAE,MAAM,CAAC;QACd,IAAI,CAAC,EAAE,MAAM,CAAC;QACd,MAAM,CAAC,EAAE,MAAM,CAAC;KACjB,CAAC;IACF,GAAG,EAAE;QACH,GAAG,EAAE,MAAM,CAAC;QACZ,SAAS,EAAE,MAAM,CAAC;KACnB,CAAC;CACH;AAID,eAAO,MAAM,QAAQ,QAAO,SAAS,GAAG,IAUvC,CAAC;AAEF,eAAO,MAAM,QAAQ,GAAI,OAAO,SAAS,KAAG,IAE3C,CAAC;AAEF,eAAO,MAAM,UAAU,QAAO,IAK7B,CAAC"}
|
package/dist/hub/auth.js
ADDED
|
@@ -0,0 +1,26 @@
|
|
|
1
|
+
import { existsSync, readFileSync, writeFileSync, unlinkSync } from 'node:fs';
|
|
2
|
+
import { join } from 'node:path';
|
|
3
|
+
import { getConfigDir } from '../daemon/config.js';
|
|
4
|
+
const getAuthPath = () => join(getConfigDir(), 'auth.json');
|
|
5
|
+
export const readAuth = () => {
|
|
6
|
+
const path = getAuthPath();
|
|
7
|
+
if (!existsSync(path))
|
|
8
|
+
return null;
|
|
9
|
+
try {
|
|
10
|
+
const raw = readFileSync(path, 'utf-8');
|
|
11
|
+
return JSON.parse(raw);
|
|
12
|
+
}
|
|
13
|
+
catch {
|
|
14
|
+
return null;
|
|
15
|
+
}
|
|
16
|
+
};
|
|
17
|
+
export const saveAuth = (state) => {
|
|
18
|
+
writeFileSync(getAuthPath(), JSON.stringify(state, null, 2) + '\n', 'utf-8');
|
|
19
|
+
};
|
|
20
|
+
export const deleteAuth = () => {
|
|
21
|
+
const path = getAuthPath();
|
|
22
|
+
if (existsSync(path)) {
|
|
23
|
+
unlinkSync(path);
|
|
24
|
+
}
|
|
25
|
+
};
|
|
26
|
+
//# sourceMappingURL=auth.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"auth.js","sourceRoot":"","sources":["../../src/hub/auth.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,UAAU,EAAE,YAAY,EAAE,aAAa,EAAE,UAAU,EAAE,MAAM,SAAS,CAAC;AAC9E,OAAO,EAAE,IAAI,EAAE,MAAM,WAAW,CAAC;AACjC,OAAO,EAAE,YAAY,EAAE,MAAM,qBAAqB,CAAC;AAoBnD,MAAM,WAAW,GAAG,GAAW,EAAE,CAAC,IAAI,CAAC,YAAY,EAAE,EAAE,WAAW,CAAC,CAAC;AAEpE,MAAM,CAAC,MAAM,QAAQ,GAAG,GAAqB,EAAE;IAC7C,MAAM,IAAI,GAAG,WAAW,EAAE,CAAC;IAC3B,IAAI,CAAC,UAAU,CAAC,IAAI,CAAC;QAAE,OAAO,IAAI,CAAC;IAEnC,IAAI,CAAC;QACH,MAAM,GAAG,GAAG,YAAY,CAAC,IAAI,EAAE,OAAO,CAAC,CAAC;QACxC,OAAO,IAAI,CAAC,KAAK,CAAC,GAAG,CAAc,CAAC;IACtC,CAAC;IAAC,MAAM,CAAC;QACP,OAAO,IAAI,CAAC;IACd,CAAC;AACH,CAAC,CAAC;AAEF,MAAM,CAAC,MAAM,QAAQ,GAAG,CAAC,KAAgB,EAAQ,EAAE;IACjD,aAAa,CAAC,WAAW,EAAE,EAAE,IAAI,CAAC,SAAS,CAAC,KAAK,EAAE,IAAI,EAAE,CAAC,CAAC,GAAG,IAAI,EAAE,OAAO,CAAC,CAAC;AAC/E,CAAC,CAAC;AAEF,MAAM,CAAC,MAAM,UAAU,GAAG,GAAS,EAAE;IACnC,MAAM,IAAI,GAAG,WAAW,EAAE,CAAC;IAC3B,IAAI,UAAU,CAAC,IAAI,CAAC,EAAE,CAAC;QACrB,UAAU,CAAC,IAAI,CAAC,CAAC;IACnB,CAAC;AACH,CAAC,CAAC"}
|
|
@@ -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"}
|