@agentage/cli 0.9.0 → 0.10.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
package/dist/cli.js CHANGED
@@ -14,6 +14,7 @@ import { registerWhoami } from './commands/whoami.js';
14
14
  import { registerCompletions } from './commands/completions.js';
15
15
  import { registerConfig } from './commands/config-cmd.js';
16
16
  import { registerInit } from './commands/init.js';
17
+ import { createCreateCommand } from './commands/create.js';
17
18
  const program = new Command();
18
19
  program.name('agentage').description('Agentage CLI — control plane for AI agents').version(VERSION);
19
20
  registerRun(program);
@@ -29,6 +30,7 @@ registerWhoami(program);
29
30
  registerCompletions(program);
30
31
  registerConfig(program);
31
32
  registerInit(program);
33
+ program.addCommand(createCreateCommand());
32
34
  program.parseAsync().then(() => {
33
35
  // Force exit — forked daemon process can keep the event loop alive
34
36
  setTimeout(() => process.exit(process.exitCode ?? 0), 100);
package/dist/cli.js.map CHANGED
@@ -1 +1 @@
1
- {"version":3,"file":"cli.js","sourceRoot":"","sources":["../src/cli.ts"],"names":[],"mappings":";AAEA,OAAO,EAAE,OAAO,EAAE,MAAM,WAAW,CAAC;AACpC,OAAO,EAAE,OAAO,EAAE,MAAM,oBAAoB,CAAC;AAC7C,OAAO,EAAE,WAAW,EAAE,MAAM,mBAAmB,CAAC;AAChD,OAAO,EAAE,cAAc,EAAE,MAAM,sBAAsB,CAAC;AACtD,OAAO,EAAE,YAAY,EAAE,MAAM,oBAAoB,CAAC;AAClD,OAAO,EAAE,gBAAgB,EAAE,MAAM,wBAAwB,CAAC;AAC1D,OAAO,EAAE,cAAc,EAAE,MAAM,sBAAsB,CAAC;AACtD,OAAO,EAAE,aAAa,EAAE,MAAM,qBAAqB,CAAC;AACpD,OAAO,EAAE,cAAc,EAAE,MAAM,sBAAsB,CAAC;AACtD,OAAO,EAAE,YAAY,EAAE,MAAM,oBAAoB,CAAC;AAClD,OAAO,EAAE,cAAc,EAAE,MAAM,0BAA0B,CAAC;AAC1D,OAAO,EAAE,cAAc,EAAE,MAAM,sBAAsB,CAAC;AACtD,OAAO,EAAE,mBAAmB,EAAE,MAAM,2BAA2B,CAAC;AAChE,OAAO,EAAE,cAAc,EAAE,MAAM,0BAA0B,CAAC;AAC1D,OAAO,EAAE,YAAY,EAAE,MAAM,oBAAoB,CAAC;AAElD,MAAM,OAAO,GAAG,IAAI,OAAO,EAAE,CAAC;AAE9B,OAAO,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC,WAAW,CAAC,4CAA4C,CAAC,CAAC,OAAO,CAAC,OAAO,CAAC,CAAC;AAEpG,WAAW,CAAC,OAAO,CAAC,CAAC;AACrB,cAAc,CAAC,OAAO,CAAC,CAAC;AACxB,YAAY,CAAC,OAAO,CAAC,CAAC;AACtB,gBAAgB,CAAC,OAAO,CAAC,CAAC;AAC1B,cAAc,CAAC,OAAO,CAAC,CAAC;AACxB,aAAa,CAAC,OAAO,CAAC,CAAC;AACvB,cAAc,CAAC,OAAO,CAAC,CAAC;AACxB,YAAY,CAAC,OAAO,CAAC,CAAC;AACtB,cAAc,CAAC,OAAO,CAAC,CAAC;AACxB,cAAc,CAAC,OAAO,CAAC,CAAC;AACxB,mBAAmB,CAAC,OAAO,CAAC,CAAC;AAC7B,cAAc,CAAC,OAAO,CAAC,CAAC;AACxB,YAAY,CAAC,OAAO,CAAC,CAAC;AAEtB,OAAO,CAAC,UAAU,EAAE,CAAC,IAAI,CAAC,GAAG,EAAE;IAC7B,mEAAmE;IACnE,UAAU,CAAC,GAAG,EAAE,CAAC,OAAO,CAAC,IAAI,CAAC,OAAO,CAAC,QAAQ,IAAI,CAAC,CAAC,EAAE,GAAG,CAAC,CAAC;AAC7D,CAAC,CAAC,CAAC"}
1
+ {"version":3,"file":"cli.js","sourceRoot":"","sources":["../src/cli.ts"],"names":[],"mappings":";AAEA,OAAO,EAAE,OAAO,EAAE,MAAM,WAAW,CAAC;AACpC,OAAO,EAAE,OAAO,EAAE,MAAM,oBAAoB,CAAC;AAC7C,OAAO,EAAE,WAAW,EAAE,MAAM,mBAAmB,CAAC;AAChD,OAAO,EAAE,cAAc,EAAE,MAAM,sBAAsB,CAAC;AACtD,OAAO,EAAE,YAAY,EAAE,MAAM,oBAAoB,CAAC;AAClD,OAAO,EAAE,gBAAgB,EAAE,MAAM,wBAAwB,CAAC;AAC1D,OAAO,EAAE,cAAc,EAAE,MAAM,sBAAsB,CAAC;AACtD,OAAO,EAAE,aAAa,EAAE,MAAM,qBAAqB,CAAC;AACpD,OAAO,EAAE,cAAc,EAAE,MAAM,sBAAsB,CAAC;AACtD,OAAO,EAAE,YAAY,EAAE,MAAM,oBAAoB,CAAC;AAClD,OAAO,EAAE,cAAc,EAAE,MAAM,0BAA0B,CAAC;AAC1D,OAAO,EAAE,cAAc,EAAE,MAAM,sBAAsB,CAAC;AACtD,OAAO,EAAE,mBAAmB,EAAE,MAAM,2BAA2B,CAAC;AAChE,OAAO,EAAE,cAAc,EAAE,MAAM,0BAA0B,CAAC;AAC1D,OAAO,EAAE,YAAY,EAAE,MAAM,oBAAoB,CAAC;AAClD,OAAO,EAAE,mBAAmB,EAAE,MAAM,sBAAsB,CAAC;AAE3D,MAAM,OAAO,GAAG,IAAI,OAAO,EAAE,CAAC;AAE9B,OAAO,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC,WAAW,CAAC,4CAA4C,CAAC,CAAC,OAAO,CAAC,OAAO,CAAC,CAAC;AAEpG,WAAW,CAAC,OAAO,CAAC,CAAC;AACrB,cAAc,CAAC,OAAO,CAAC,CAAC;AACxB,YAAY,CAAC,OAAO,CAAC,CAAC;AACtB,gBAAgB,CAAC,OAAO,CAAC,CAAC;AAC1B,cAAc,CAAC,OAAO,CAAC,CAAC;AACxB,aAAa,CAAC,OAAO,CAAC,CAAC;AACvB,cAAc,CAAC,OAAO,CAAC,CAAC;AACxB,YAAY,CAAC,OAAO,CAAC,CAAC;AACtB,cAAc,CAAC,OAAO,CAAC,CAAC;AACxB,cAAc,CAAC,OAAO,CAAC,CAAC;AACxB,mBAAmB,CAAC,OAAO,CAAC,CAAC;AAC7B,cAAc,CAAC,OAAO,CAAC,CAAC;AACxB,YAAY,CAAC,OAAO,CAAC,CAAC;AACtB,OAAO,CAAC,UAAU,CAAC,mBAAmB,EAAE,CAAC,CAAC;AAE1C,OAAO,CAAC,UAAU,EAAE,CAAC,IAAI,CAAC,GAAG,EAAE;IAC7B,mEAAmE;IACnE,UAAU,CAAC,GAAG,EAAE,CAAC,OAAO,CAAC,IAAI,CAAC,OAAO,CAAC,QAAQ,IAAI,CAAC,CAAC,EAAE,GAAG,CAAC,CAAC;AAC7D,CAAC,CAAC,CAAC"}
@@ -0,0 +1,3 @@
1
+ import { Command } from 'commander';
2
+ export declare const createCreateCommand: () => Command;
3
+ //# sourceMappingURL=create.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"create.d.ts","sourceRoot":"","sources":["../../src/commands/create.ts"],"names":[],"mappings":"AAEA,OAAO,EAAE,OAAO,EAAE,MAAM,WAAW,CAAC;AA0IpC,eAAO,MAAM,mBAAmB,QAAO,OAiDtC,CAAC"}
@@ -0,0 +1,173 @@
1
+ import { existsSync, mkdirSync, writeFileSync } from 'node:fs';
2
+ import { join, resolve } from 'node:path';
3
+ import { Command } from 'commander';
4
+ import chalk from 'chalk';
5
+ const TEMPLATES = {
6
+ simple: {
7
+ content: (name) => `import { createAgent } from '@agentage/core';
8
+
9
+ export const agent = createAgent({
10
+ name: '${name}',
11
+ description: 'A simple agent',
12
+ path: '',
13
+ async *run(input, { signal }) {
14
+ yield {
15
+ type: 'output',
16
+ data: { type: 'output', content: \`Running: \${input.task}\`, format: 'text' },
17
+ timestamp: Date.now(),
18
+ };
19
+
20
+ yield {
21
+ type: 'result',
22
+ data: { type: 'result', success: true, output: 'Done' },
23
+ timestamp: Date.now(),
24
+ };
25
+ },
26
+ });
27
+
28
+ export default agent;
29
+ `,
30
+ },
31
+ shell: {
32
+ content: (name) => `import { createAgent, type RunEvent } from '@agentage/core';
33
+ import { spawn } from 'node:child_process';
34
+ import { createInterface } from 'node:readline';
35
+
36
+ export const agent = createAgent({
37
+ name: '${name}',
38
+ description: 'Executes a shell command and streams output',
39
+ path: '',
40
+ async *run(input, { signal }) {
41
+ const events: RunEvent[] = [];
42
+ let exitCode: number | null = null;
43
+
44
+ await new Promise<void>((resolve) => {
45
+ const proc = spawn(input.task, { shell: true, stdio: ['ignore', 'pipe', 'pipe'] });
46
+ signal.addEventListener('abort', () => proc.kill(), { once: true });
47
+
48
+ if (proc.stdout) {
49
+ const rl = createInterface({ input: proc.stdout });
50
+ rl.on('line', (line) => {
51
+ events.push({ type: 'output', data: { type: 'output', content: line, format: 'text' }, timestamp: Date.now() });
52
+ });
53
+ }
54
+
55
+ proc.on('close', (code) => { exitCode = code; resolve(); });
56
+ proc.on('error', () => resolve());
57
+ });
58
+
59
+ for (const event of events) yield event;
60
+
61
+ yield {
62
+ type: 'result',
63
+ data: { type: 'result', success: exitCode === 0, output: exitCode === 0 ? 'Done' : \`Exited with code \${exitCode}\` },
64
+ timestamp: Date.now(),
65
+ };
66
+ },
67
+ });
68
+
69
+ export default agent;
70
+ `,
71
+ },
72
+ claude: {
73
+ deps: ['@anthropic-ai/claude-agent-sdk'],
74
+ content: (name) => `import { createAgent } from '@agentage/core';
75
+ import { query } from '@anthropic-ai/claude-agent-sdk';
76
+
77
+ export const agent = createAgent({
78
+ name: '${name}',
79
+ description: 'Runs a task using Claude Code',
80
+ path: '',
81
+ async *run(input, { signal }) {
82
+ if (!process.env['ANTHROPIC_API_KEY']) {
83
+ yield { type: 'error', data: { type: 'error', code: 'MISSING_API_KEY', message: 'ANTHROPIC_API_KEY not set', recoverable: false }, timestamp: Date.now() };
84
+ yield { type: 'result', data: { type: 'result', success: false, output: 'ANTHROPIC_API_KEY not set' }, timestamp: Date.now() };
85
+ return;
86
+ }
87
+
88
+ const controller = new AbortController();
89
+ signal.addEventListener('abort', () => controller.abort(), { once: true });
90
+
91
+ for await (const message of query({
92
+ prompt: input.task,
93
+ options: { allowedTools: ['Read', 'Glob', 'Grep', 'Bash'], abortController: controller, maxTurns: 10 },
94
+ })) {
95
+ if (message.type === 'result') {
96
+ yield { type: 'result', data: { type: 'result', success: message.subtype === 'success' }, timestamp: Date.now() };
97
+ }
98
+ }
99
+ },
100
+ });
101
+
102
+ export default agent;
103
+ `,
104
+ },
105
+ copilot: {
106
+ deps: ['@github/copilot-sdk'],
107
+ content: (name) => `import { createAgent } from '@agentage/core';
108
+ import { CopilotClient, approveAll } from '@github/copilot-sdk';
109
+
110
+ export const agent = createAgent({
111
+ name: '${name}',
112
+ description: 'Runs a task using GitHub Copilot',
113
+ path: '',
114
+ async *run(input, { signal }) {
115
+ const client = new CopilotClient();
116
+ try {
117
+ await client.start();
118
+ const session = await client.createSession({ model: 'gpt-4o', onPermissionRequest: approveAll });
119
+ signal.addEventListener('abort', () => session.abort(), { once: true });
120
+
121
+ const idle = new Promise<void>((resolve) => { session.on('session.idle', () => resolve()); });
122
+ await session.send({ prompt: input.task });
123
+ await idle;
124
+
125
+ yield { type: 'result', data: { type: 'result', success: true }, timestamp: Date.now() };
126
+ await session.disconnect();
127
+ } finally {
128
+ await client.stop().catch(() => {});
129
+ }
130
+ },
131
+ });
132
+
133
+ export default agent;
134
+ `,
135
+ },
136
+ };
137
+ const KEBAB_CASE = /^[a-z][a-z0-9]*(-[a-z0-9]+)*$/;
138
+ export const createCreateCommand = () => {
139
+ const cmd = new Command('create')
140
+ .description('Scaffold a new agent from a template')
141
+ .argument('<name>', 'Agent name (kebab-case)')
142
+ .option('-t, --template <template>', 'Template: simple, shell, claude, copilot', 'simple')
143
+ .option('-d, --dir <dir>', 'Output directory', '.')
144
+ .action(async (name, options) => {
145
+ if (!KEBAB_CASE.test(name)) {
146
+ console.error(chalk.red(`Invalid name "${name}". Use kebab-case (e.g. my-agent).`));
147
+ process.exitCode = 1;
148
+ return;
149
+ }
150
+ const template = TEMPLATES[options.template];
151
+ if (!template) {
152
+ console.error(chalk.red(`Unknown template "${options.template}". Available: ${Object.keys(TEMPLATES).join(', ')}`));
153
+ process.exitCode = 1;
154
+ return;
155
+ }
156
+ const dir = resolve(options.dir);
157
+ const filePath = join(dir, `${name}.agent.ts`);
158
+ if (existsSync(filePath)) {
159
+ console.error(chalk.red(`File already exists: ${filePath}`));
160
+ process.exitCode = 1;
161
+ return;
162
+ }
163
+ mkdirSync(dir, { recursive: true });
164
+ writeFileSync(filePath, template.content(name));
165
+ console.log(chalk.green(`Created ${filePath}`));
166
+ if (template.deps?.length) {
167
+ console.log(chalk.yellow(`\nInstall dependencies:\n npm install ${template.deps.join(' ')}`));
168
+ }
169
+ console.log(chalk.dim(`\nTo use:\n cp ${filePath} ~/.agentage/agents/\n agentage agents --refresh`));
170
+ });
171
+ return cmd;
172
+ };
173
+ //# sourceMappingURL=create.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"create.js","sourceRoot":"","sources":["../../src/commands/create.ts"],"names":[],"mappings":"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"}
@@ -1 +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"}
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;AAc/D,eAAO,MAAM,iBAAiB,QACxB,YAuCH,CAAC"}
@@ -1,7 +1,13 @@
1
1
  import { basename } from 'node:path';
2
2
  import { createJiti } from 'jiti';
3
3
  import { logDebug, logWarn } from '../daemon/logger.js';
4
- const matches = (filePath) => basename(filePath) === 'agent.ts' || basename(filePath) === 'agent.js';
4
+ const matches = (filePath) => {
5
+ const name = basename(filePath);
6
+ return (name === 'agent.ts' ||
7
+ name === 'agent.js' ||
8
+ (name.endsWith('.agent.ts') && name.length > '.agent.ts'.length) ||
9
+ (name.endsWith('.agent.js') && name.length > '.agent.js'.length));
10
+ };
5
11
  export const createCodeFactory = () => async (filePath) => {
6
12
  if (!matches(filePath))
7
13
  return null;
@@ -18,7 +24,12 @@ export const createCodeFactory = () => async (filePath) => {
18
24
  'manifest' in agent &&
19
25
  'run' in agent &&
20
26
  typeof agent.run === 'function') {
21
- return agent;
27
+ const agentObj = agent;
28
+ // Auto-inject path if missing (D2)
29
+ if (!agentObj.manifest.path) {
30
+ agentObj.manifest.path = filePath;
31
+ }
32
+ return agentObj;
22
33
  }
23
34
  logWarn(`Module at ${filePath} does not export a valid Agent`);
24
35
  return null;
@@ -1 +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"}
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;IAC5C,MAAM,IAAI,GAAG,QAAQ,CAAC,QAAQ,CAAC,CAAC;IAChC,OAAO,CACL,IAAI,KAAK,UAAU;QACnB,IAAI,KAAK,UAAU;QACnB,CAAC,IAAI,CAAC,QAAQ,CAAC,WAAW,CAAC,IAAI,IAAI,CAAC,MAAM,GAAG,WAAW,CAAC,MAAM,CAAC;QAChE,CAAC,IAAI,CAAC,QAAQ,CAAC,WAAW,CAAC,IAAI,IAAI,CAAC,MAAM,GAAG,WAAW,CAAC,MAAM,CAAC,CACjE,CAAC;AACJ,CAAC,CAAC;AAEF,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,MAAM,QAAQ,GAAG,KAAc,CAAC;YAEhC,mCAAmC;YACnC,IAAI,CAAC,QAAQ,CAAC,QAAQ,CAAC,IAAI,EAAE,CAAC;gBAC3B,QAAQ,CAAC,QAA6B,CAAC,IAAI,GAAG,QAAQ,CAAC;YAC1D,CAAC;YAED,OAAO,QAAQ,CAAC;QAClB,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,3 @@
1
+ export declare const agent: import("@agentage/core").Agent;
2
+ export default agent;
3
+ //# sourceMappingURL=countdown.agent.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"countdown.agent.d.ts","sourceRoot":"","sources":["../../src/examples/countdown.agent.ts"],"names":[],"mappings":"AAEA,eAAO,MAAM,KAAK,gCAsDhB,CAAC;AAEH,eAAe,KAAK,CAAC"}
@@ -0,0 +1,51 @@
1
+ import { createAgent } from '@agentage/core';
2
+ export const agent = createAgent({
3
+ name: 'countdown',
4
+ description: 'Counts down from 5 to 0 with 1-second delays',
5
+ version: '1.0.0',
6
+ tags: ['example', 'simple'],
7
+ path: '',
8
+ async *run(input, { signal }) {
9
+ const start = input.config?.start ? Number(input.config.start) : 5;
10
+ for (let i = start; i >= 0; i--) {
11
+ if (signal.aborted)
12
+ break;
13
+ yield {
14
+ type: 'output',
15
+ data: { type: 'output', content: `${i}`, format: 'text' },
16
+ timestamp: Date.now(),
17
+ };
18
+ yield {
19
+ type: 'output',
20
+ data: {
21
+ type: 'output',
22
+ content: { percent: ((start - i) / start) * 100, message: `${i}...` },
23
+ format: 'progress',
24
+ },
25
+ timestamp: Date.now(),
26
+ };
27
+ if (i > 0) {
28
+ await new Promise((resolve, reject) => {
29
+ const timer = setTimeout(resolve, 1000);
30
+ signal.addEventListener('abort', () => {
31
+ clearTimeout(timer);
32
+ reject(new DOMException('Aborted', 'AbortError'));
33
+ }, { once: true });
34
+ }).catch((err) => {
35
+ if (err instanceof DOMException && err.name === 'AbortError')
36
+ return;
37
+ throw err;
38
+ });
39
+ }
40
+ }
41
+ if (!signal.aborted) {
42
+ yield {
43
+ type: 'result',
44
+ data: { type: 'result', success: true, output: 'Countdown complete' },
45
+ timestamp: Date.now(),
46
+ };
47
+ }
48
+ },
49
+ });
50
+ export default agent;
51
+ //# sourceMappingURL=countdown.agent.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"countdown.agent.js","sourceRoot":"","sources":["../../src/examples/countdown.agent.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,WAAW,EAAE,MAAM,gBAAgB,CAAC;AAE7C,MAAM,CAAC,MAAM,KAAK,GAAG,WAAW,CAAC;IAC/B,IAAI,EAAE,WAAW;IACjB,WAAW,EAAE,8CAA8C;IAC3D,OAAO,EAAE,OAAO;IAChB,IAAI,EAAE,CAAC,SAAS,EAAE,QAAQ,CAAC;IAC3B,IAAI,EAAE,EAAE;IACR,KAAK,CAAC,CAAC,GAAG,CAAC,KAAK,EAAE,EAAE,MAAM,EAAE;QAC1B,MAAM,KAAK,GAAG,KAAK,CAAC,MAAM,EAAE,KAAK,CAAC,CAAC,CAAC,MAAM,CAAC,KAAK,CAAC,MAAM,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;QAEnE,KAAK,IAAI,CAAC,GAAG,KAAK,EAAE,CAAC,IAAI,CAAC,EAAE,CAAC,EAAE,EAAE,CAAC;YAChC,IAAI,MAAM,CAAC,OAAO;gBAAE,MAAM;YAE1B,MAAM;gBACJ,IAAI,EAAE,QAAiB;gBACvB,IAAI,EAAE,EAAE,IAAI,EAAE,QAAiB,EAAE,OAAO,EAAE,GAAG,CAAC,EAAE,EAAE,MAAM,EAAE,MAAM,EAAE;gBAClE,SAAS,EAAE,IAAI,CAAC,GAAG,EAAE;aACtB,CAAC;YAEF,MAAM;gBACJ,IAAI,EAAE,QAAiB;gBACvB,IAAI,EAAE;oBACJ,IAAI,EAAE,QAAiB;oBACvB,OAAO,EAAE,EAAE,OAAO,EAAE,CAAC,CAAC,KAAK,GAAG,CAAC,CAAC,GAAG,KAAK,CAAC,GAAG,GAAG,EAAE,OAAO,EAAE,GAAG,CAAC,KAAK,EAAE;oBACrE,MAAM,EAAE,UAAU;iBACnB;gBACD,SAAS,EAAE,IAAI,CAAC,GAAG,EAAE;aACtB,CAAC;YAEF,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC;gBACV,MAAM,IAAI,OAAO,CAAO,CAAC,OAAO,EAAE,MAAM,EAAE,EAAE;oBAC1C,MAAM,KAAK,GAAG,UAAU,CAAC,OAAO,EAAE,IAAI,CAAC,CAAC;oBACxC,MAAM,CAAC,gBAAgB,CACrB,OAAO,EACP,GAAG,EAAE;wBACH,YAAY,CAAC,KAAK,CAAC,CAAC;wBACpB,MAAM,CAAC,IAAI,YAAY,CAAC,SAAS,EAAE,YAAY,CAAC,CAAC,CAAC;oBACpD,CAAC,EACD,EAAE,IAAI,EAAE,IAAI,EAAE,CACf,CAAC;gBACJ,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC,GAAY,EAAE,EAAE;oBACxB,IAAI,GAAG,YAAY,YAAY,IAAI,GAAG,CAAC,IAAI,KAAK,YAAY;wBAAE,OAAO;oBACrE,MAAM,GAAG,CAAC;gBACZ,CAAC,CAAC,CAAC;YACL,CAAC;QACH,CAAC;QAED,IAAI,CAAC,MAAM,CAAC,OAAO,EAAE,CAAC;YACpB,MAAM;gBACJ,IAAI,EAAE,QAAiB;gBACvB,IAAI,EAAE,EAAE,IAAI,EAAE,QAAiB,EAAE,OAAO,EAAE,IAAI,EAAE,MAAM,EAAE,oBAAoB,EAAE;gBAC9E,SAAS,EAAE,IAAI,CAAC,GAAG,EAAE;aACtB,CAAC;QACJ,CAAC;IACH,CAAC;CACF,CAAC,CAAC;AAEH,eAAe,KAAK,CAAC"}
@@ -0,0 +1,3 @@
1
+ export declare const agent: import("@agentage/core").Agent;
2
+ export default agent;
3
+ //# sourceMappingURL=shell.agent.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"shell.agent.d.ts","sourceRoot":"","sources":["../../src/examples/shell.agent.ts"],"names":[],"mappings":"AAIA,eAAO,MAAM,KAAK,gCAsGhB,CAAC;AAEH,eAAe,KAAK,CAAC"}
@@ -0,0 +1,98 @@
1
+ import { createAgent } from '@agentage/core';
2
+ import { spawn } from 'node:child_process';
3
+ import { createInterface } from 'node:readline';
4
+ export const agent = createAgent({
5
+ name: 'shell',
6
+ description: 'Executes a shell command and streams output',
7
+ version: '1.0.0',
8
+ tags: ['example', 'shell'],
9
+ path: '',
10
+ async *run(input, { signal }) {
11
+ if (!input.task.trim()) {
12
+ yield {
13
+ type: 'error',
14
+ data: {
15
+ type: 'error',
16
+ code: 'EMPTY_COMMAND',
17
+ message: 'No command provided',
18
+ recoverable: false,
19
+ },
20
+ timestamp: Date.now(),
21
+ };
22
+ yield {
23
+ type: 'result',
24
+ data: { type: 'result', success: false, output: 'No command provided' },
25
+ timestamp: Date.now(),
26
+ };
27
+ return;
28
+ }
29
+ if (signal.aborted)
30
+ return;
31
+ const events = [];
32
+ let exitCode = null;
33
+ await new Promise((resolve) => {
34
+ const proc = spawn(input.task, {
35
+ shell: true,
36
+ stdio: ['ignore', 'pipe', 'pipe'],
37
+ });
38
+ if (signal.aborted) {
39
+ proc.kill('SIGKILL');
40
+ resolve();
41
+ return;
42
+ }
43
+ const onAbort = () => {
44
+ proc.kill('SIGKILL');
45
+ };
46
+ signal.addEventListener('abort', onAbort, { once: true });
47
+ if (proc.stdout) {
48
+ const rl = createInterface({ input: proc.stdout });
49
+ rl.on('line', (line) => {
50
+ events.push({
51
+ type: 'output',
52
+ data: { type: 'output', content: line, format: 'text' },
53
+ timestamp: Date.now(),
54
+ });
55
+ });
56
+ }
57
+ if (proc.stderr) {
58
+ const rl = createInterface({ input: proc.stderr });
59
+ rl.on('line', (line) => {
60
+ events.push({
61
+ type: 'error',
62
+ data: { type: 'error', code: 'STDERR', message: line, recoverable: true },
63
+ timestamp: Date.now(),
64
+ });
65
+ });
66
+ }
67
+ proc.on('error', (err) => {
68
+ events.push({
69
+ type: 'error',
70
+ data: { type: 'error', code: 'SPAWN_ERROR', message: err.message, recoverable: false },
71
+ timestamp: Date.now(),
72
+ });
73
+ resolve();
74
+ });
75
+ proc.on('close', (code) => {
76
+ exitCode = code;
77
+ signal.removeEventListener('abort', onAbort);
78
+ resolve();
79
+ });
80
+ });
81
+ for (const event of events) {
82
+ yield event;
83
+ }
84
+ if (!signal.aborted) {
85
+ yield {
86
+ type: 'result',
87
+ data: {
88
+ type: 'result',
89
+ success: exitCode === 0,
90
+ output: exitCode === 0 ? 'Command completed' : `Exited with code ${exitCode}`,
91
+ },
92
+ timestamp: Date.now(),
93
+ };
94
+ }
95
+ },
96
+ });
97
+ export default agent;
98
+ //# sourceMappingURL=shell.agent.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"shell.agent.js","sourceRoot":"","sources":["../../src/examples/shell.agent.ts"],"names":[],"mappings":"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"}
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@agentage/cli",
3
- "version": "0.9.0",
3
+ "version": "0.10.0",
4
4
  "description": "Agentage CLI and daemon — control plane for AI agents",
5
5
  "type": "module",
6
6
  "main": "./dist/index.js",
@@ -29,9 +29,9 @@
29
29
  "prepublishOnly": "npm run verify"
30
30
  },
31
31
  "dependencies": {
32
- "@agentage/core": "^0.2.0",
33
- "@agentage/platform": "^0.2.0",
34
- "@supabase/supabase-js": "2.99.3",
32
+ "@agentage/core": "^0.3.0",
33
+ "@agentage/platform": "^0.2.1",
34
+ "@supabase/supabase-js": "2.100.1",
35
35
  "chalk": "latest",
36
36
  "commander": "latest",
37
37
  "express": "latest",