agent-oven 0.1.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/CLAUDE.md +164 -0
- package/LICENSE +21 -0
- package/README.md +447 -0
- package/dist/cli/commands/add.d.ts +6 -0
- package/dist/cli/commands/add.d.ts.map +1 -0
- package/dist/cli/commands/add.js +150 -0
- package/dist/cli/commands/add.js.map +1 -0
- package/dist/cli/commands/daemon.d.ts +6 -0
- package/dist/cli/commands/daemon.d.ts.map +1 -0
- package/dist/cli/commands/daemon.js +97 -0
- package/dist/cli/commands/daemon.js.map +1 -0
- package/dist/cli/commands/delete.d.ts +6 -0
- package/dist/cli/commands/delete.d.ts.map +1 -0
- package/dist/cli/commands/delete.js +34 -0
- package/dist/cli/commands/delete.js.map +1 -0
- package/dist/cli/commands/down.d.ts +6 -0
- package/dist/cli/commands/down.d.ts.map +1 -0
- package/dist/cli/commands/down.js +53 -0
- package/dist/cli/commands/down.js.map +1 -0
- package/dist/cli/commands/list.d.ts +6 -0
- package/dist/cli/commands/list.d.ts.map +1 -0
- package/dist/cli/commands/list.js +41 -0
- package/dist/cli/commands/list.js.map +1 -0
- package/dist/cli/commands/logs.d.ts +6 -0
- package/dist/cli/commands/logs.d.ts.map +1 -0
- package/dist/cli/commands/logs.js +124 -0
- package/dist/cli/commands/logs.js.map +1 -0
- package/dist/cli/commands/run.d.ts +6 -0
- package/dist/cli/commands/run.d.ts.map +1 -0
- package/dist/cli/commands/run.js +45 -0
- package/dist/cli/commands/run.js.map +1 -0
- package/dist/cli/commands/scheduler-tick.d.ts +8 -0
- package/dist/cli/commands/scheduler-tick.d.ts.map +1 -0
- package/dist/cli/commands/scheduler-tick.js +25 -0
- package/dist/cli/commands/scheduler-tick.js.map +1 -0
- package/dist/cli/commands/show.d.ts +6 -0
- package/dist/cli/commands/show.d.ts.map +1 -0
- package/dist/cli/commands/show.js +81 -0
- package/dist/cli/commands/show.js.map +1 -0
- package/dist/cli/commands/status.d.ts +6 -0
- package/dist/cli/commands/status.d.ts.map +1 -0
- package/dist/cli/commands/status.js +63 -0
- package/dist/cli/commands/status.js.map +1 -0
- package/dist/cli/commands/toggle.d.ts +6 -0
- package/dist/cli/commands/toggle.d.ts.map +1 -0
- package/dist/cli/commands/toggle.js +24 -0
- package/dist/cli/commands/toggle.js.map +1 -0
- package/dist/cli/commands/up.d.ts +6 -0
- package/dist/cli/commands/up.d.ts.map +1 -0
- package/dist/cli/commands/up.js +48 -0
- package/dist/cli/commands/up.js.map +1 -0
- package/dist/cli/utils/errors.d.ts +17 -0
- package/dist/cli/utils/errors.d.ts.map +1 -0
- package/dist/cli/utils/errors.js +37 -0
- package/dist/cli/utils/errors.js.map +1 -0
- package/dist/cli/utils/output.d.ts +17 -0
- package/dist/cli/utils/output.d.ts.map +1 -0
- package/dist/cli/utils/output.js +52 -0
- package/dist/cli/utils/output.js.map +1 -0
- package/dist/cli/utils/prompts.d.ts +8 -0
- package/dist/cli/utils/prompts.d.ts.map +1 -0
- package/dist/cli/utils/prompts.js +27 -0
- package/dist/cli/utils/prompts.js.map +1 -0
- package/dist/cli.d.ts +8 -0
- package/dist/cli.d.ts.map +1 -0
- package/dist/cli.js +71 -0
- package/dist/cli.js.map +1 -0
- package/dist/core/auth.d.ts +40 -0
- package/dist/core/auth.d.ts.map +1 -0
- package/dist/core/auth.js +114 -0
- package/dist/core/auth.js.map +1 -0
- package/dist/core/config.d.ts +43 -0
- package/dist/core/config.d.ts.map +1 -0
- package/dist/core/config.js +179 -0
- package/dist/core/config.js.map +1 -0
- package/dist/core/docker.d.ts +60 -0
- package/dist/core/docker.d.ts.map +1 -0
- package/dist/core/docker.js +507 -0
- package/dist/core/docker.js.map +1 -0
- package/dist/core/index.d.ts +10 -0
- package/dist/core/index.d.ts.map +1 -0
- package/dist/core/index.js +10 -0
- package/dist/core/index.js.map +1 -0
- package/dist/core/jobs.d.ts +53 -0
- package/dist/core/jobs.d.ts.map +1 -0
- package/dist/core/jobs.js +264 -0
- package/dist/core/jobs.js.map +1 -0
- package/dist/core/scheduler-runner.d.ts +15 -0
- package/dist/core/scheduler-runner.d.ts.map +1 -0
- package/dist/core/scheduler-runner.js +230 -0
- package/dist/core/scheduler-runner.js.map +1 -0
- package/dist/core/scheduler.d.ts +41 -0
- package/dist/core/scheduler.d.ts.map +1 -0
- package/dist/core/scheduler.js +373 -0
- package/dist/core/scheduler.js.map +1 -0
- package/dist/core/setup.d.ts +84 -0
- package/dist/core/setup.d.ts.map +1 -0
- package/dist/core/setup.js +315 -0
- package/dist/core/setup.js.map +1 -0
- package/dist/core/types.d.ts +181 -0
- package/dist/core/types.d.ts.map +1 -0
- package/dist/core/types.js +12 -0
- package/dist/core/types.js.map +1 -0
- package/dist/tui/App.d.ts +7 -0
- package/dist/tui/App.d.ts.map +1 -0
- package/dist/tui/App.js +103 -0
- package/dist/tui/App.js.map +1 -0
- package/dist/tui/components/Dashboard.d.ts +9 -0
- package/dist/tui/components/Dashboard.d.ts.map +1 -0
- package/dist/tui/components/Dashboard.js +70 -0
- package/dist/tui/components/Dashboard.js.map +1 -0
- package/dist/tui/components/InitWizard.d.ts +2 -0
- package/dist/tui/components/InitWizard.d.ts.map +1 -0
- package/dist/tui/components/InitWizard.js +522 -0
- package/dist/tui/components/InitWizard.js.map +1 -0
- package/dist/tui/components/JobDetail.d.ts +12 -0
- package/dist/tui/components/JobDetail.d.ts.map +1 -0
- package/dist/tui/components/JobDetail.js +137 -0
- package/dist/tui/components/JobDetail.js.map +1 -0
- package/dist/tui/components/JobForm.d.ts +10 -0
- package/dist/tui/components/JobForm.d.ts.map +1 -0
- package/dist/tui/components/JobForm.js +183 -0
- package/dist/tui/components/JobForm.js.map +1 -0
- package/dist/tui/components/JobList.d.ts +11 -0
- package/dist/tui/components/JobList.d.ts.map +1 -0
- package/dist/tui/components/JobList.js +136 -0
- package/dist/tui/components/JobList.js.map +1 -0
- package/dist/tui/components/LogViewer.d.ts +10 -0
- package/dist/tui/components/LogViewer.d.ts.map +1 -0
- package/dist/tui/components/LogViewer.js +184 -0
- package/dist/tui/components/LogViewer.js.map +1 -0
- package/dist/tui/index.d.ts +11 -0
- package/dist/tui/index.d.ts.map +1 -0
- package/dist/tui/index.js +11 -0
- package/dist/tui/index.js.map +1 -0
- package/dist/tui/types.d.ts +21 -0
- package/dist/tui/types.d.ts.map +1 -0
- package/dist/tui/types.js +5 -0
- package/dist/tui/types.js.map +1 -0
- package/images/base-tasks/Dockerfile +33 -0
- package/images/node-tasks/Dockerfile +36 -0
- package/images/pipeline-runner/Dockerfile +43 -0
- package/images/pipeline-runner/entrypoint.sh +60 -0
- package/images/python-tasks/Dockerfile +43 -0
- package/package.json +91 -0
- package/scheduler.sh +522 -0
|
@@ -0,0 +1,150 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* `agent-oven add <id>` — Add a new job
|
|
3
|
+
*/
|
|
4
|
+
import { requireConfig, handleError } from '../utils/errors.js';
|
|
5
|
+
import { addJob, validateJob } from '../../core/jobs.js';
|
|
6
|
+
import { validateCron } from '../../core/scheduler.js';
|
|
7
|
+
import { success, error } from '../utils/output.js';
|
|
8
|
+
function collectRepeatable(value, previous) {
|
|
9
|
+
return [...previous, value];
|
|
10
|
+
}
|
|
11
|
+
export function register(program) {
|
|
12
|
+
program
|
|
13
|
+
.command('add <id>')
|
|
14
|
+
.description('Add a new job')
|
|
15
|
+
.requiredOption('--name <name>', 'Human-readable job name')
|
|
16
|
+
.option('--type <type>', 'Job type (docker or agent-pipeline)', 'docker')
|
|
17
|
+
.option('--image <image>', 'Docker image (required for docker type)')
|
|
18
|
+
.option('--command <cmd>', 'Command to run (required for docker type; JSON array or string)')
|
|
19
|
+
.option('--repo <url>', 'Git repo URL (required for pipeline type)')
|
|
20
|
+
.option('--pipeline <name>', 'Pipeline name (required for pipeline type)')
|
|
21
|
+
.option('--branch <branch>', 'Git branch (default: main)')
|
|
22
|
+
.option('--schedule <cron>', 'Cron expression (mutually exclusive with --once)')
|
|
23
|
+
.option('--once <datetime>', 'ISO 8601 datetime for one-time run')
|
|
24
|
+
.option('-v, --volume <vol>', 'Volume mount (repeatable)', collectRepeatable, [])
|
|
25
|
+
.option('-e, --env <kv>', 'Environment variable KEY=VALUE (repeatable)', collectRepeatable, [])
|
|
26
|
+
.option('--timeout <seconds>', 'Timeout in seconds', parseInt)
|
|
27
|
+
.option('--cpus <n>', 'CPU limit', parseFloat)
|
|
28
|
+
.option('--memory <size>', 'Memory limit (e.g., 512m, 2g)')
|
|
29
|
+
.option('--disabled', 'Create job as disabled')
|
|
30
|
+
.action(async (id, opts) => {
|
|
31
|
+
try {
|
|
32
|
+
const config = requireConfig();
|
|
33
|
+
// Build schedule
|
|
34
|
+
if (!opts.schedule && !opts.once) {
|
|
35
|
+
error('Either --schedule or --once is required');
|
|
36
|
+
process.exit(1);
|
|
37
|
+
}
|
|
38
|
+
if (opts.schedule && opts.once) {
|
|
39
|
+
error('--schedule and --once are mutually exclusive');
|
|
40
|
+
process.exit(1);
|
|
41
|
+
}
|
|
42
|
+
let schedule;
|
|
43
|
+
if (opts.schedule) {
|
|
44
|
+
const cronErr = validateCron(opts.schedule);
|
|
45
|
+
if (cronErr) {
|
|
46
|
+
error(`Invalid cron expression: ${cronErr}`);
|
|
47
|
+
process.exit(1);
|
|
48
|
+
}
|
|
49
|
+
schedule = { type: 'cron', cron: opts.schedule };
|
|
50
|
+
}
|
|
51
|
+
else {
|
|
52
|
+
const d = new Date(opts.once);
|
|
53
|
+
if (isNaN(d.getTime())) {
|
|
54
|
+
error('Invalid datetime for --once');
|
|
55
|
+
process.exit(1);
|
|
56
|
+
}
|
|
57
|
+
schedule = { type: 'once', datetime: opts.once };
|
|
58
|
+
}
|
|
59
|
+
// Build env record
|
|
60
|
+
const env = {};
|
|
61
|
+
for (const kv of opts.env) {
|
|
62
|
+
const eqIdx = kv.indexOf('=');
|
|
63
|
+
if (eqIdx === -1) {
|
|
64
|
+
error(`Invalid env format: '${kv}' (expected KEY=VALUE)`);
|
|
65
|
+
process.exit(1);
|
|
66
|
+
}
|
|
67
|
+
env[kv.slice(0, eqIdx)] = kv.slice(eqIdx + 1);
|
|
68
|
+
}
|
|
69
|
+
// Build resources
|
|
70
|
+
const resources = (opts.timeout || opts.cpus || opts.memory) ? {
|
|
71
|
+
timeout: opts.timeout,
|
|
72
|
+
cpus: opts.cpus,
|
|
73
|
+
memory: opts.memory,
|
|
74
|
+
} : undefined;
|
|
75
|
+
// Build job options
|
|
76
|
+
let jobOptions;
|
|
77
|
+
if (opts.type === 'agent-pipeline') {
|
|
78
|
+
if (!opts.repo) {
|
|
79
|
+
error('--repo is required for pipeline jobs');
|
|
80
|
+
process.exit(1);
|
|
81
|
+
}
|
|
82
|
+
if (!opts.pipeline) {
|
|
83
|
+
error('--pipeline is required for pipeline jobs');
|
|
84
|
+
process.exit(1);
|
|
85
|
+
}
|
|
86
|
+
jobOptions = {
|
|
87
|
+
id,
|
|
88
|
+
name: opts.name,
|
|
89
|
+
type: 'agent-pipeline',
|
|
90
|
+
source: { repo: opts.repo, branch: opts.branch },
|
|
91
|
+
pipeline: opts.pipeline,
|
|
92
|
+
schedule,
|
|
93
|
+
enabled: !opts.disabled,
|
|
94
|
+
...(Object.keys(env).length > 0 ? { env } : {}),
|
|
95
|
+
...(resources ? { resources } : {}),
|
|
96
|
+
};
|
|
97
|
+
}
|
|
98
|
+
else {
|
|
99
|
+
if (!opts.image) {
|
|
100
|
+
error('--image is required for docker jobs');
|
|
101
|
+
process.exit(1);
|
|
102
|
+
}
|
|
103
|
+
if (!opts.command) {
|
|
104
|
+
error('--command is required for docker jobs');
|
|
105
|
+
process.exit(1);
|
|
106
|
+
}
|
|
107
|
+
// Parse command: JSON array or single string
|
|
108
|
+
let command;
|
|
109
|
+
if (opts.command.startsWith('[')) {
|
|
110
|
+
try {
|
|
111
|
+
command = JSON.parse(opts.command);
|
|
112
|
+
}
|
|
113
|
+
catch {
|
|
114
|
+
error('Invalid JSON array for --command');
|
|
115
|
+
process.exit(1);
|
|
116
|
+
}
|
|
117
|
+
}
|
|
118
|
+
else {
|
|
119
|
+
command = opts.command;
|
|
120
|
+
}
|
|
121
|
+
jobOptions = {
|
|
122
|
+
id,
|
|
123
|
+
name: opts.name,
|
|
124
|
+
type: 'docker',
|
|
125
|
+
image: opts.image,
|
|
126
|
+
command,
|
|
127
|
+
schedule,
|
|
128
|
+
enabled: !opts.disabled,
|
|
129
|
+
...(opts.volume.length > 0 ? { volumes: opts.volume } : {}),
|
|
130
|
+
...(Object.keys(env).length > 0 ? { env } : {}),
|
|
131
|
+
...(resources ? { resources } : {}),
|
|
132
|
+
};
|
|
133
|
+
}
|
|
134
|
+
// Validate
|
|
135
|
+
const errors = validateJob(jobOptions);
|
|
136
|
+
if (errors.length > 0) {
|
|
137
|
+
for (const e of errors) {
|
|
138
|
+
error(e);
|
|
139
|
+
}
|
|
140
|
+
process.exit(1);
|
|
141
|
+
}
|
|
142
|
+
addJob(config, jobOptions);
|
|
143
|
+
success(`Job '${id}' added`);
|
|
144
|
+
}
|
|
145
|
+
catch (err) {
|
|
146
|
+
handleError(err);
|
|
147
|
+
}
|
|
148
|
+
});
|
|
149
|
+
}
|
|
150
|
+
//# sourceMappingURL=add.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"add.js","sourceRoot":"","sources":["../../../src/cli/commands/add.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"daemon.d.ts","sourceRoot":"","sources":["../../../src/cli/commands/daemon.ts"],"names":[],"mappings":"AAAA;;GAEG;AAIH,OAAO,KAAK,EAAE,OAAO,EAAE,MAAM,WAAW,CAAC;AAMzC,wBAAgB,QAAQ,CAAC,OAAO,EAAE,OAAO,GAAG,IAAI,CA6F/C"}
|
|
@@ -0,0 +1,97 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* `agent-oven daemon <action>` — Manage the scheduler daemon
|
|
3
|
+
*/
|
|
4
|
+
import * as fs from 'node:fs';
|
|
5
|
+
import { execa } from 'execa';
|
|
6
|
+
import { handleError } from '../utils/errors.js';
|
|
7
|
+
import { getLaunchdPlistPath } from '../../core/config.js';
|
|
8
|
+
import { getSchedulerStatus } from '../../core/docker.js';
|
|
9
|
+
import { success, error, info, statusIcon } from '../utils/output.js';
|
|
10
|
+
export function register(program) {
|
|
11
|
+
const cmd = program
|
|
12
|
+
.command('daemon')
|
|
13
|
+
.description('Manage the scheduler daemon');
|
|
14
|
+
cmd
|
|
15
|
+
.command('status')
|
|
16
|
+
.description('Show daemon status')
|
|
17
|
+
.action(async () => {
|
|
18
|
+
try {
|
|
19
|
+
const plistPath = getLaunchdPlistPath();
|
|
20
|
+
const plistExists = fs.existsSync(plistPath);
|
|
21
|
+
const status = await getSchedulerStatus();
|
|
22
|
+
console.log('\nScheduler Daemon');
|
|
23
|
+
console.log(` Plist: ${plistExists ? statusIcon(true) + ' ' + plistPath : statusIcon(false) + ' Not found'}`);
|
|
24
|
+
console.log(` Loaded: ${statusIcon(status.loaded)} ${status.loaded ? 'Yes' : 'No'}`);
|
|
25
|
+
if (status.lastExitStatus !== undefined) {
|
|
26
|
+
console.log(` Last exit: ${status.lastExitStatus}`);
|
|
27
|
+
}
|
|
28
|
+
console.log();
|
|
29
|
+
}
|
|
30
|
+
catch (err) {
|
|
31
|
+
handleError(err);
|
|
32
|
+
}
|
|
33
|
+
});
|
|
34
|
+
cmd
|
|
35
|
+
.command('start')
|
|
36
|
+
.description('Start the scheduler daemon')
|
|
37
|
+
.action(async () => {
|
|
38
|
+
try {
|
|
39
|
+
const plistPath = getLaunchdPlistPath();
|
|
40
|
+
if (!fs.existsSync(plistPath)) {
|
|
41
|
+
error(`Plist not found at ${plistPath}. Run \`agent-oven init\` first.`);
|
|
42
|
+
process.exit(1);
|
|
43
|
+
}
|
|
44
|
+
const status = await getSchedulerStatus();
|
|
45
|
+
if (status.loaded) {
|
|
46
|
+
info('Daemon is already loaded');
|
|
47
|
+
return;
|
|
48
|
+
}
|
|
49
|
+
await execa('launchctl', ['load', plistPath]);
|
|
50
|
+
success('Daemon started');
|
|
51
|
+
}
|
|
52
|
+
catch (err) {
|
|
53
|
+
handleError(err);
|
|
54
|
+
}
|
|
55
|
+
});
|
|
56
|
+
cmd
|
|
57
|
+
.command('stop')
|
|
58
|
+
.description('Stop the scheduler daemon')
|
|
59
|
+
.action(async () => {
|
|
60
|
+
try {
|
|
61
|
+
const plistPath = getLaunchdPlistPath();
|
|
62
|
+
const status = await getSchedulerStatus();
|
|
63
|
+
if (!status.loaded) {
|
|
64
|
+
info('Daemon is not loaded');
|
|
65
|
+
return;
|
|
66
|
+
}
|
|
67
|
+
await execa('launchctl', ['unload', plistPath]);
|
|
68
|
+
success('Daemon stopped');
|
|
69
|
+
}
|
|
70
|
+
catch (err) {
|
|
71
|
+
handleError(err);
|
|
72
|
+
}
|
|
73
|
+
});
|
|
74
|
+
cmd
|
|
75
|
+
.command('restart')
|
|
76
|
+
.description('Restart the scheduler daemon')
|
|
77
|
+
.action(async () => {
|
|
78
|
+
try {
|
|
79
|
+
const plistPath = getLaunchdPlistPath();
|
|
80
|
+
if (!fs.existsSync(plistPath)) {
|
|
81
|
+
error(`Plist not found at ${plistPath}. Run \`agent-oven init\` first.`);
|
|
82
|
+
process.exit(1);
|
|
83
|
+
}
|
|
84
|
+
const status = await getSchedulerStatus();
|
|
85
|
+
if (status.loaded) {
|
|
86
|
+
await execa('launchctl', ['unload', plistPath]);
|
|
87
|
+
info('Daemon stopped');
|
|
88
|
+
}
|
|
89
|
+
await execa('launchctl', ['load', plistPath]);
|
|
90
|
+
success('Daemon started');
|
|
91
|
+
}
|
|
92
|
+
catch (err) {
|
|
93
|
+
handleError(err);
|
|
94
|
+
}
|
|
95
|
+
});
|
|
96
|
+
}
|
|
97
|
+
//# sourceMappingURL=daemon.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"daemon.js","sourceRoot":"","sources":["../../../src/cli/commands/daemon.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"delete.d.ts","sourceRoot":"","sources":["../../../src/cli/commands/delete.ts"],"names":[],"mappings":"AAAA;;GAEG;AAEH,OAAO,KAAK,EAAE,OAAO,EAAE,MAAM,WAAW,CAAC;AAMzC,wBAAgB,QAAQ,CAAC,OAAO,EAAE,OAAO,GAAG,IAAI,CA2B/C"}
|
|
@@ -0,0 +1,34 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* `agent-oven delete <id>` — Delete a job
|
|
3
|
+
*/
|
|
4
|
+
import { requireConfig, requireJob, handleError } from '../utils/errors.js';
|
|
5
|
+
import { removeJob } from '../../core/jobs.js';
|
|
6
|
+
import { success, info } from '../utils/output.js';
|
|
7
|
+
import { confirm } from '../utils/prompts.js';
|
|
8
|
+
export function register(program) {
|
|
9
|
+
program
|
|
10
|
+
.command('delete <id>')
|
|
11
|
+
.alias('rm')
|
|
12
|
+
.description('Delete a job')
|
|
13
|
+
.option('-y, --yes', 'Skip confirmation')
|
|
14
|
+
.action(async (id, opts) => {
|
|
15
|
+
try {
|
|
16
|
+
const config = requireConfig();
|
|
17
|
+
const job = requireJob(config, id);
|
|
18
|
+
info(`Job '${id}' (${job.name}) — type: ${job.type}`);
|
|
19
|
+
if (!opts.yes) {
|
|
20
|
+
const ok = await confirm(`Delete job '${id}'?`);
|
|
21
|
+
if (!ok) {
|
|
22
|
+
info('Cancelled');
|
|
23
|
+
return;
|
|
24
|
+
}
|
|
25
|
+
}
|
|
26
|
+
removeJob(config, id);
|
|
27
|
+
success(`Job '${id}' deleted`);
|
|
28
|
+
}
|
|
29
|
+
catch (err) {
|
|
30
|
+
handleError(err);
|
|
31
|
+
}
|
|
32
|
+
});
|
|
33
|
+
}
|
|
34
|
+
//# sourceMappingURL=delete.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"delete.js","sourceRoot":"","sources":["../../../src/cli/commands/delete.ts"],"names":[],"mappings":"AAAA;;GAEG;AAGH,OAAO,EAAE,aAAa,EAAE,UAAU,EAAE,WAAW,EAAE,MAAM,oBAAoB,CAAC;AAC5E,OAAO,EAAE,SAAS,EAAE,MAAM,oBAAoB,CAAC;AAC/C,OAAO,EAAE,OAAO,EAAE,IAAI,EAAE,MAAM,oBAAoB,CAAC;AACnD,OAAO,EAAE,OAAO,EAAE,MAAM,qBAAqB,CAAC;AAE9C,MAAM,UAAU,QAAQ,CAAC,OAAgB;IACvC,OAAO;SACJ,OAAO,CAAC,aAAa,CAAC;SACtB,KAAK,CAAC,IAAI,CAAC;SACX,WAAW,CAAC,cAAc,CAAC;SAC3B,MAAM,CAAC,WAAW,EAAE,mBAAmB,CAAC;SACxC,MAAM,CAAC,KAAK,EAAE,EAAU,EAAE,IAAuB,EAAE,EAAE;QACpD,IAAI,CAAC;YACH,MAAM,MAAM,GAAG,aAAa,EAAE,CAAC;YAC/B,MAAM,GAAG,GAAG,UAAU,CAAC,MAAM,EAAE,EAAE,CAAC,CAAC;YAEnC,IAAI,CAAC,QAAQ,EAAE,MAAM,GAAG,CAAC,IAAI,aAAa,GAAG,CAAC,IAAI,EAAE,CAAC,CAAC;YAEtD,IAAI,CAAC,IAAI,CAAC,GAAG,EAAE,CAAC;gBACd,MAAM,EAAE,GAAG,MAAM,OAAO,CAAC,eAAe,EAAE,IAAI,CAAC,CAAC;gBAChD,IAAI,CAAC,EAAE,EAAE,CAAC;oBACR,IAAI,CAAC,WAAW,CAAC,CAAC;oBAClB,OAAO;gBACT,CAAC;YACH,CAAC;YAED,SAAS,CAAC,MAAM,EAAE,EAAE,CAAC,CAAC;YACtB,OAAO,CAAC,QAAQ,EAAE,WAAW,CAAC,CAAC;QACjC,CAAC;QAAC,OAAO,GAAG,EAAE,CAAC;YACb,WAAW,CAAC,GAAG,CAAC,CAAC;QACnB,CAAC;IACH,CAAC,CAAC,CAAC;AACP,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"down.d.ts","sourceRoot":"","sources":["../../../src/cli/commands/down.ts"],"names":[],"mappings":"AAAA;;GAEG;AAGH,OAAO,KAAK,EAAE,OAAO,EAAE,MAAM,WAAW,CAAC;AAOzC,wBAAgB,QAAQ,CAAC,OAAO,EAAE,OAAO,GAAG,IAAI,CA2C/C"}
|
|
@@ -0,0 +1,53 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* `agent-oven down` — Stop daemon + Colima
|
|
3
|
+
*/
|
|
4
|
+
import { execa } from 'execa';
|
|
5
|
+
import { handleError } from '../utils/errors.js';
|
|
6
|
+
import { getLaunchdPlistPath } from '../../core/config.js';
|
|
7
|
+
import { getRunningContainers, stopColima, getSchedulerStatus } from '../../core/docker.js';
|
|
8
|
+
import { success, warn, info } from '../utils/output.js';
|
|
9
|
+
import { confirm } from '../utils/prompts.js';
|
|
10
|
+
export function register(program) {
|
|
11
|
+
program
|
|
12
|
+
.command('down')
|
|
13
|
+
.description('Stop the scheduler daemon and Colima')
|
|
14
|
+
.option('--force', 'Skip warning about running containers')
|
|
15
|
+
.action(async (opts) => {
|
|
16
|
+
try {
|
|
17
|
+
// Check for running containers
|
|
18
|
+
if (!opts.force) {
|
|
19
|
+
const containers = await getRunningContainers();
|
|
20
|
+
if (containers.length > 0) {
|
|
21
|
+
warn(`${containers.length} container(s) still running:`);
|
|
22
|
+
for (const c of containers) {
|
|
23
|
+
console.log(` ${c.name} (${c.image})`);
|
|
24
|
+
}
|
|
25
|
+
const ok = await confirm('Stop everything anyway?');
|
|
26
|
+
if (!ok) {
|
|
27
|
+
info('Cancelled');
|
|
28
|
+
return;
|
|
29
|
+
}
|
|
30
|
+
}
|
|
31
|
+
}
|
|
32
|
+
// Step 1: Unload daemon
|
|
33
|
+
const plistPath = getLaunchdPlistPath();
|
|
34
|
+
const sched = await getSchedulerStatus();
|
|
35
|
+
if (sched.loaded) {
|
|
36
|
+
await execa('launchctl', ['unload', plistPath]);
|
|
37
|
+
success('Scheduler daemon stopped');
|
|
38
|
+
}
|
|
39
|
+
else {
|
|
40
|
+
info('Scheduler daemon was not loaded');
|
|
41
|
+
}
|
|
42
|
+
// Step 2: Stop Colima
|
|
43
|
+
info('Stopping Colima...');
|
|
44
|
+
await stopColima();
|
|
45
|
+
success('Colima stopped');
|
|
46
|
+
success('System is down');
|
|
47
|
+
}
|
|
48
|
+
catch (err) {
|
|
49
|
+
handleError(err);
|
|
50
|
+
}
|
|
51
|
+
});
|
|
52
|
+
}
|
|
53
|
+
//# sourceMappingURL=down.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"down.js","sourceRoot":"","sources":["../../../src/cli/commands/down.ts"],"names":[],"mappings":"AAAA;;GAEG;AAEH,OAAO,EAAE,KAAK,EAAE,MAAM,OAAO,CAAC;AAE9B,OAAO,EAAE,WAAW,EAAE,MAAM,oBAAoB,CAAC;AACjD,OAAO,EAAE,mBAAmB,EAAE,MAAM,sBAAsB,CAAC;AAC3D,OAAO,EAAE,oBAAoB,EAAE,UAAU,EAAE,kBAAkB,EAAE,MAAM,sBAAsB,CAAC;AAC5F,OAAO,EAAE,OAAO,EAAE,IAAI,EAAE,IAAI,EAAE,MAAM,oBAAoB,CAAC;AACzD,OAAO,EAAE,OAAO,EAAE,MAAM,qBAAqB,CAAC;AAE9C,MAAM,UAAU,QAAQ,CAAC,OAAgB;IACvC,OAAO;SACJ,OAAO,CAAC,MAAM,CAAC;SACf,WAAW,CAAC,sCAAsC,CAAC;SACnD,MAAM,CAAC,SAAS,EAAE,uCAAuC,CAAC;SAC1D,MAAM,CAAC,KAAK,EAAE,IAAyB,EAAE,EAAE;QAC1C,IAAI,CAAC;YACH,+BAA+B;YAC/B,IAAI,CAAC,IAAI,CAAC,KAAK,EAAE,CAAC;gBAChB,MAAM,UAAU,GAAG,MAAM,oBAAoB,EAAE,CAAC;gBAChD,IAAI,UAAU,CAAC,MAAM,GAAG,CAAC,EAAE,CAAC;oBAC1B,IAAI,CAAC,GAAG,UAAU,CAAC,MAAM,8BAA8B,CAAC,CAAC;oBACzD,KAAK,MAAM,CAAC,IAAI,UAAU,EAAE,CAAC;wBAC3B,OAAO,CAAC,GAAG,CAAC,KAAK,CAAC,CAAC,IAAI,KAAK,CAAC,CAAC,KAAK,GAAG,CAAC,CAAC;oBAC1C,CAAC;oBACD,MAAM,EAAE,GAAG,MAAM,OAAO,CAAC,yBAAyB,CAAC,CAAC;oBACpD,IAAI,CAAC,EAAE,EAAE,CAAC;wBACR,IAAI,CAAC,WAAW,CAAC,CAAC;wBAClB,OAAO;oBACT,CAAC;gBACH,CAAC;YACH,CAAC;YAED,wBAAwB;YACxB,MAAM,SAAS,GAAG,mBAAmB,EAAE,CAAC;YACxC,MAAM,KAAK,GAAG,MAAM,kBAAkB,EAAE,CAAC;YACzC,IAAI,KAAK,CAAC,MAAM,EAAE,CAAC;gBACjB,MAAM,KAAK,CAAC,WAAW,EAAE,CAAC,QAAQ,EAAE,SAAS,CAAC,CAAC,CAAC;gBAChD,OAAO,CAAC,0BAA0B,CAAC,CAAC;YACtC,CAAC;iBAAM,CAAC;gBACN,IAAI,CAAC,iCAAiC,CAAC,CAAC;YAC1C,CAAC;YAED,sBAAsB;YACtB,IAAI,CAAC,oBAAoB,CAAC,CAAC;YAC3B,MAAM,UAAU,EAAE,CAAC;YACnB,OAAO,CAAC,gBAAgB,CAAC,CAAC;YAE1B,OAAO,CAAC,gBAAgB,CAAC,CAAC;QAC5B,CAAC;QAAC,OAAO,GAAG,EAAE,CAAC;YACb,WAAW,CAAC,GAAG,CAAC,CAAC;QACnB,CAAC;IACH,CAAC,CAAC,CAAC;AACP,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"list.d.ts","sourceRoot":"","sources":["../../../src/cli/commands/list.ts"],"names":[],"mappings":"AAAA;;GAEG;AAEH,OAAO,KAAK,EAAE,OAAO,EAAE,MAAM,WAAW,CAAC;AAMzC,wBAAgB,QAAQ,CAAC,OAAO,EAAE,OAAO,GAAG,IAAI,CAoC/C"}
|
|
@@ -0,0 +1,41 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* `agent-oven list` — List all jobs
|
|
3
|
+
*/
|
|
4
|
+
import { requireConfig, handleError } from '../utils/errors.js';
|
|
5
|
+
import { printTable } from '../utils/output.js';
|
|
6
|
+
import { listJobs } from '../../core/jobs.js';
|
|
7
|
+
import { describeSchedule, getNextRun, formatRelativeTime } from '../../core/scheduler.js';
|
|
8
|
+
export function register(program) {
|
|
9
|
+
program
|
|
10
|
+
.command('list')
|
|
11
|
+
.alias('ls')
|
|
12
|
+
.description('List all jobs')
|
|
13
|
+
.option('--json', 'Output as JSON')
|
|
14
|
+
.action(async (opts) => {
|
|
15
|
+
try {
|
|
16
|
+
const config = requireConfig();
|
|
17
|
+
const jobs = listJobs(config);
|
|
18
|
+
if (opts.json) {
|
|
19
|
+
console.log(JSON.stringify(jobs, null, 2));
|
|
20
|
+
return;
|
|
21
|
+
}
|
|
22
|
+
if (jobs.length === 0) {
|
|
23
|
+
console.log('No jobs configured. Use `agent-oven add` to create one.');
|
|
24
|
+
return;
|
|
25
|
+
}
|
|
26
|
+
const rows = jobs.map((job) => {
|
|
27
|
+
const schedule = describeSchedule(job.schedule);
|
|
28
|
+
const next = getNextRun(job.schedule);
|
|
29
|
+
const nextStr = next ? formatRelativeTime(next) : '—';
|
|
30
|
+
const enabled = job.enabled !== false;
|
|
31
|
+
const status = enabled ? 'enabled' : 'disabled';
|
|
32
|
+
return [job.id, job.type, schedule, nextStr, status];
|
|
33
|
+
});
|
|
34
|
+
printTable(['ID', 'TYPE', 'SCHEDULE', 'NEXT RUN', 'STATUS'], rows);
|
|
35
|
+
}
|
|
36
|
+
catch (err) {
|
|
37
|
+
handleError(err);
|
|
38
|
+
}
|
|
39
|
+
});
|
|
40
|
+
}
|
|
41
|
+
//# sourceMappingURL=list.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"list.js","sourceRoot":"","sources":["../../../src/cli/commands/list.ts"],"names":[],"mappings":"AAAA;;GAEG;AAGH,OAAO,EAAE,aAAa,EAAE,WAAW,EAAE,MAAM,oBAAoB,CAAC;AAChE,OAAO,EAAE,UAAU,EAAE,MAAM,oBAAoB,CAAC;AAChD,OAAO,EAAE,QAAQ,EAAE,MAAM,oBAAoB,CAAC;AAC9C,OAAO,EAAE,gBAAgB,EAAE,UAAU,EAAE,kBAAkB,EAAE,MAAM,yBAAyB,CAAC;AAE3F,MAAM,UAAU,QAAQ,CAAC,OAAgB;IACvC,OAAO;SACJ,OAAO,CAAC,MAAM,CAAC;SACf,KAAK,CAAC,IAAI,CAAC;SACX,WAAW,CAAC,eAAe,CAAC;SAC5B,MAAM,CAAC,QAAQ,EAAE,gBAAgB,CAAC;SAClC,MAAM,CAAC,KAAK,EAAE,IAAwB,EAAE,EAAE;QACzC,IAAI,CAAC;YACH,MAAM,MAAM,GAAG,aAAa,EAAE,CAAC;YAC/B,MAAM,IAAI,GAAG,QAAQ,CAAC,MAAM,CAAC,CAAC;YAE9B,IAAI,IAAI,CAAC,IAAI,EAAE,CAAC;gBACd,OAAO,CAAC,GAAG,CAAC,IAAI,CAAC,SAAS,CAAC,IAAI,EAAE,IAAI,EAAE,CAAC,CAAC,CAAC,CAAC;gBAC3C,OAAO;YACT,CAAC;YAED,IAAI,IAAI,CAAC,MAAM,KAAK,CAAC,EAAE,CAAC;gBACtB,OAAO,CAAC,GAAG,CAAC,yDAAyD,CAAC,CAAC;gBACvE,OAAO;YACT,CAAC;YAED,MAAM,IAAI,GAAG,IAAI,CAAC,GAAG,CAAC,CAAC,GAAG,EAAE,EAAE;gBAC5B,MAAM,QAAQ,GAAG,gBAAgB,CAAC,GAAG,CAAC,QAAQ,CAAC,CAAC;gBAChD,MAAM,IAAI,GAAG,UAAU,CAAC,GAAG,CAAC,QAAQ,CAAC,CAAC;gBACtC,MAAM,OAAO,GAAG,IAAI,CAAC,CAAC,CAAC,kBAAkB,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC,GAAG,CAAC;gBACtD,MAAM,OAAO,GAAG,GAAG,CAAC,OAAO,KAAK,KAAK,CAAC;gBACtC,MAAM,MAAM,GAAG,OAAO,CAAC,CAAC,CAAC,SAAS,CAAC,CAAC,CAAC,UAAU,CAAC;gBAEhD,OAAO,CAAC,GAAG,CAAC,EAAE,EAAE,GAAG,CAAC,IAAI,EAAE,QAAQ,EAAE,OAAO,EAAE,MAAM,CAAC,CAAC;YACvD,CAAC,CAAC,CAAC;YAEH,UAAU,CAAC,CAAC,IAAI,EAAE,MAAM,EAAE,UAAU,EAAE,UAAU,EAAE,QAAQ,CAAC,EAAE,IAAI,CAAC,CAAC;QACrE,CAAC;QAAC,OAAO,GAAG,EAAE,CAAC;YACb,WAAW,CAAC,GAAG,CAAC,CAAC;QACnB,CAAC;IACH,CAAC,CAAC,CAAC;AACP,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"logs.d.ts","sourceRoot":"","sources":["../../../src/cli/commands/logs.ts"],"names":[],"mappings":"AAAA;;GAEG;AAGH,OAAO,KAAK,EAAE,OAAO,EAAE,MAAM,WAAW,CAAC;AAMzC,wBAAgB,QAAQ,CAAC,OAAO,EAAE,OAAO,GAAG,IAAI,CA2E/C"}
|
|
@@ -0,0 +1,124 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* `agent-oven logs [id]` — View logs
|
|
3
|
+
*/
|
|
4
|
+
import * as fs from 'node:fs';
|
|
5
|
+
import { requireConfig, handleError } from '../utils/errors.js';
|
|
6
|
+
import { readSchedulerLog, getJobLogFiles, readJobLog } from '../../core/docker.js';
|
|
7
|
+
import { getJob } from '../../core/jobs.js';
|
|
8
|
+
import { error, info } from '../utils/output.js';
|
|
9
|
+
export function register(program) {
|
|
10
|
+
program
|
|
11
|
+
.command('logs [id]')
|
|
12
|
+
.description('View logs (scheduler log if no id, job log if id given)')
|
|
13
|
+
.option('-n, --lines <n>', 'Number of lines to show', '50')
|
|
14
|
+
.option('--all', 'List available log files for a job')
|
|
15
|
+
.option('--run <n>', 'Nth most recent run (default: 1)', '1')
|
|
16
|
+
.option('-f, --follow', 'Follow log output')
|
|
17
|
+
.action(async (id, opts) => {
|
|
18
|
+
try {
|
|
19
|
+
const config = requireConfig();
|
|
20
|
+
const lines = parseInt(opts.lines, 10) || 50;
|
|
21
|
+
const runIndex = parseInt(opts.run, 10) - 1;
|
|
22
|
+
if (!id) {
|
|
23
|
+
// Scheduler log
|
|
24
|
+
if (opts.follow) {
|
|
25
|
+
await followLog(config, null, lines);
|
|
26
|
+
}
|
|
27
|
+
else {
|
|
28
|
+
const log = readSchedulerLog(config, lines);
|
|
29
|
+
if (!log) {
|
|
30
|
+
info('No scheduler log found');
|
|
31
|
+
}
|
|
32
|
+
else {
|
|
33
|
+
console.log(log);
|
|
34
|
+
}
|
|
35
|
+
}
|
|
36
|
+
return;
|
|
37
|
+
}
|
|
38
|
+
// Job log
|
|
39
|
+
const job = getJob(config, id);
|
|
40
|
+
if (!job) {
|
|
41
|
+
error(`Job '${id}' not found`);
|
|
42
|
+
process.exit(1);
|
|
43
|
+
}
|
|
44
|
+
const logFiles = getJobLogFiles(config, id);
|
|
45
|
+
if (logFiles.length === 0) {
|
|
46
|
+
info(`No logs found for job '${id}'`);
|
|
47
|
+
return;
|
|
48
|
+
}
|
|
49
|
+
if (opts.all) {
|
|
50
|
+
info(`Log files for '${id}':`);
|
|
51
|
+
logFiles.forEach((f, i) => {
|
|
52
|
+
const basename = f.split('/').pop() ?? f;
|
|
53
|
+
console.log(` ${i + 1}. ${basename}`);
|
|
54
|
+
});
|
|
55
|
+
return;
|
|
56
|
+
}
|
|
57
|
+
if (runIndex >= logFiles.length) {
|
|
58
|
+
error(`Only ${logFiles.length} log file(s) available for job '${id}'`);
|
|
59
|
+
process.exit(1);
|
|
60
|
+
}
|
|
61
|
+
const logFile = logFiles[runIndex];
|
|
62
|
+
if (opts.follow) {
|
|
63
|
+
await followLog(config, logFile, lines);
|
|
64
|
+
}
|
|
65
|
+
else {
|
|
66
|
+
const content = readJobLog(logFile);
|
|
67
|
+
const allLines = content.split('\n');
|
|
68
|
+
const output = allLines.slice(-lines).join('\n');
|
|
69
|
+
console.log(output);
|
|
70
|
+
}
|
|
71
|
+
}
|
|
72
|
+
catch (err) {
|
|
73
|
+
handleError(err);
|
|
74
|
+
}
|
|
75
|
+
});
|
|
76
|
+
}
|
|
77
|
+
/**
|
|
78
|
+
* Tail -f behavior: print last N lines, then poll for new content
|
|
79
|
+
*/
|
|
80
|
+
async function followLog(_config, logFile, lines) {
|
|
81
|
+
let filePath;
|
|
82
|
+
if (logFile) {
|
|
83
|
+
filePath = logFile;
|
|
84
|
+
}
|
|
85
|
+
else {
|
|
86
|
+
const { getSchedulerLogPath } = await import('../../core/config.js');
|
|
87
|
+
const { loadConfig } = await import('../../core/config.js');
|
|
88
|
+
filePath = getSchedulerLogPath(loadConfig());
|
|
89
|
+
}
|
|
90
|
+
if (!fs.existsSync(filePath)) {
|
|
91
|
+
info('Waiting for log file...');
|
|
92
|
+
}
|
|
93
|
+
let lastSize = 0;
|
|
94
|
+
// Print initial content
|
|
95
|
+
if (fs.existsSync(filePath)) {
|
|
96
|
+
const content = fs.readFileSync(filePath, 'utf-8');
|
|
97
|
+
const allLines = content.split('\n');
|
|
98
|
+
console.log(allLines.slice(-lines).join('\n'));
|
|
99
|
+
lastSize = Buffer.byteLength(content, 'utf-8');
|
|
100
|
+
}
|
|
101
|
+
// Poll for new content
|
|
102
|
+
const interval = setInterval(() => {
|
|
103
|
+
if (!fs.existsSync(filePath))
|
|
104
|
+
return;
|
|
105
|
+
const stat = fs.statSync(filePath);
|
|
106
|
+
if (stat.size > lastSize) {
|
|
107
|
+
const fd = fs.openSync(filePath, 'r');
|
|
108
|
+
const buf = Buffer.alloc(stat.size - lastSize);
|
|
109
|
+
fs.readSync(fd, buf, 0, buf.length, lastSize);
|
|
110
|
+
fs.closeSync(fd);
|
|
111
|
+
process.stdout.write(buf.toString('utf-8'));
|
|
112
|
+
lastSize = stat.size;
|
|
113
|
+
}
|
|
114
|
+
}, 500);
|
|
115
|
+
// Wait for Ctrl+C
|
|
116
|
+
process.on('SIGINT', () => {
|
|
117
|
+
clearInterval(interval);
|
|
118
|
+
console.log();
|
|
119
|
+
process.exit(0);
|
|
120
|
+
});
|
|
121
|
+
// Keep process alive
|
|
122
|
+
await new Promise(() => { });
|
|
123
|
+
}
|
|
124
|
+
//# sourceMappingURL=logs.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"logs.js","sourceRoot":"","sources":["../../../src/cli/commands/logs.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"run.d.ts","sourceRoot":"","sources":["../../../src/cli/commands/run.ts"],"names":[],"mappings":"AAAA;;GAEG;AAEH,OAAO,KAAK,EAAE,OAAO,EAAE,MAAM,WAAW,CAAC;AAKzC,wBAAgB,QAAQ,CAAC,OAAO,EAAE,OAAO,GAAG,IAAI,CAuC/C"}
|