@claushaas/ergon-cli 0.1.2
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/LICENSE +1 -0
- package/README.md +20 -0
- package/dist/commands/approve.d.ts +14 -0
- package/dist/commands/approve.d.ts.map +1 -0
- package/dist/commands/approve.js +60 -0
- package/dist/commands/approve.js.map +1 -0
- package/dist/commands/cancel.d.ts +7 -0
- package/dist/commands/cancel.d.ts.map +1 -0
- package/dist/commands/cancel.js +27 -0
- package/dist/commands/cancel.js.map +1 -0
- package/dist/commands/init.d.ts +10 -0
- package/dist/commands/init.d.ts.map +1 -0
- package/dist/commands/init.js +16 -0
- package/dist/commands/init.js.map +1 -0
- package/dist/commands/library.d.ts +7 -0
- package/dist/commands/library.d.ts.map +1 -0
- package/dist/commands/library.js +12 -0
- package/dist/commands/library.js.map +1 -0
- package/dist/commands/run.d.ts +18 -0
- package/dist/commands/run.d.ts.map +1 -0
- package/dist/commands/run.js +82 -0
- package/dist/commands/run.js.map +1 -0
- package/dist/commands/template.d.ts +13 -0
- package/dist/commands/template.d.ts.map +1 -0
- package/dist/commands/template.js +42 -0
- package/dist/commands/template.js.map +1 -0
- package/dist/commands/worker.d.ts +15 -0
- package/dist/commands/worker.d.ts.map +1 -0
- package/dist/commands/worker.js +108 -0
- package/dist/commands/worker.js.map +1 -0
- package/dist/commands/workflow.d.ts +8 -0
- package/dist/commands/workflow.d.ts.map +1 -0
- package/dist/commands/workflow.js +34 -0
- package/dist/commands/workflow.js.map +1 -0
- package/dist/config/index.d.ts +17 -0
- package/dist/config/index.d.ts.map +1 -0
- package/dist/config/index.js +76 -0
- package/dist/config/index.js.map +1 -0
- package/dist/help.d.ts +3 -0
- package/dist/help.d.ts.map +1 -0
- package/dist/help.js +45 -0
- package/dist/help.js.map +1 -0
- package/dist/library/agents/coder.yaml +27 -0
- package/dist/library/agents/pr-writer.yaml +28 -0
- package/dist/library/agents/repo-analyzer.yaml +31 -0
- package/dist/library/agents/repo-planner.yaml +35 -0
- package/dist/library/schemas/agent.analysis.v1.json +51 -0
- package/dist/library/schemas/agent.patch.v1.json +57 -0
- package/dist/library/schemas/agent.plan.v1.json +71 -0
- package/dist/library/schemas/agent.pr.v1.json +54 -0
- package/dist/library/workflows/code.bump_deps.yaml +268 -0
- package/dist/library/workflows/code.codegen.yaml +256 -0
- package/dist/library/workflows/code.docs_update.yaml +252 -0
- package/dist/library/workflows/code.hotfix.yaml +264 -0
- package/dist/library/workflows/code.refactor.yaml +256 -0
- package/dist/main.d.ts +3 -0
- package/dist/main.d.ts.map +1 -0
- package/dist/main.js +86 -0
- package/dist/main.js.map +1 -0
- package/dist/output/format.d.ts +2 -0
- package/dist/output/format.d.ts.map +1 -0
- package/dist/output/format.js +4 -0
- package/dist/output/format.js.map +1 -0
- package/dist/project.d.ts +42 -0
- package/dist/project.d.ts.map +1 -0
- package/dist/project.js +229 -0
- package/dist/project.js.map +1 -0
- package/dist/utils.d.ts +7 -0
- package/dist/utils.d.ts.map +1 -0
- package/dist/utils.js +39 -0
- package/dist/utils.js.map +1 -0
- package/package.json +47 -0
package/LICENSE
ADDED
|
@@ -0,0 +1 @@
|
|
|
1
|
+
MIT
|
package/README.md
ADDED
|
@@ -0,0 +1,20 @@
|
|
|
1
|
+
# @claushaas/ergon-cli
|
|
2
|
+
|
|
3
|
+
Globally installable CLI for Ergon Flow.
|
|
4
|
+
|
|
5
|
+
Install:
|
|
6
|
+
|
|
7
|
+
```bash
|
|
8
|
+
pnpm add -g @claushaas/ergon-cli
|
|
9
|
+
```
|
|
10
|
+
|
|
11
|
+
Quickstart:
|
|
12
|
+
|
|
13
|
+
```bash
|
|
14
|
+
ergon init
|
|
15
|
+
ergon template list
|
|
16
|
+
```
|
|
17
|
+
|
|
18
|
+
Repository:
|
|
19
|
+
|
|
20
|
+
- https://github.com/claushaas/ergon-flow
|
|
@@ -0,0 +1,14 @@
|
|
|
1
|
+
export type ManualDecision = 'approve' | 'reject';
|
|
2
|
+
export interface ApproveCommandOptions {
|
|
3
|
+
dbPath?: string;
|
|
4
|
+
decision: string;
|
|
5
|
+
rootDir?: string;
|
|
6
|
+
}
|
|
7
|
+
export interface ParsedApproveCommandArgs {
|
|
8
|
+
decision: string;
|
|
9
|
+
stepId: string;
|
|
10
|
+
}
|
|
11
|
+
export declare function parseApproveCommandArgs(args: string[]): ParsedApproveCommandArgs;
|
|
12
|
+
export declare function decideManualStep(runId: string, stepId: string, commandOptions: ApproveCommandOptions): import("@claushaas/ergon-storage").DecideManualStepResult;
|
|
13
|
+
export declare function runApproveCommand(runId: string, stepId: string, commandOptions: ApproveCommandOptions): void;
|
|
14
|
+
//# sourceMappingURL=approve.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"approve.d.ts","sourceRoot":"","sources":["../../src/commands/approve.ts"],"names":[],"mappings":"AASA,MAAM,MAAM,cAAc,GAAG,SAAS,GAAG,QAAQ,CAAC;AAElD,MAAM,WAAW,qBAAqB;IACrC,MAAM,CAAC,EAAE,MAAM,CAAC;IAChB,QAAQ,EAAE,MAAM,CAAC;IACjB,OAAO,CAAC,EAAE,MAAM,CAAC;CACjB;AAED,MAAM,WAAW,wBAAwB;IACxC,QAAQ,EAAE,MAAM,CAAC;IACjB,MAAM,EAAE,MAAM,CAAC;CACf;AAkBD,wBAAgB,uBAAuB,CACtC,IAAI,EAAE,MAAM,EAAE,GACZ,wBAAwB,CAgC1B;AAED,wBAAgB,gBAAgB,CAC/B,KAAK,EAAE,MAAM,EACb,MAAM,EAAE,MAAM,EACd,cAAc,EAAE,qBAAqB,6DAiBrC;AAED,wBAAgB,iBAAiB,CAChC,KAAK,EAAE,MAAM,EACb,MAAM,EAAE,MAAM,EACd,cAAc,EAAE,qBAAqB,GACnC,IAAI,CAEN"}
|
|
@@ -0,0 +1,60 @@
|
|
|
1
|
+
import { openStorageDb, decideManualStep as persistManualDecision, } from '@claushaas/ergon-storage';
|
|
2
|
+
import { loadCliConfig } from '../config/index.js';
|
|
3
|
+
import { printJson } from '../output/format.js';
|
|
4
|
+
import { assertInitializedProject } from '../project.js';
|
|
5
|
+
import { assertValidStepId } from '../utils.js';
|
|
6
|
+
function assertManualDecision(value) {
|
|
7
|
+
if (value !== 'approve' && value !== 'reject') {
|
|
8
|
+
throw new Error(`Invalid decision "${value}". Expected "approve" or "reject".`);
|
|
9
|
+
}
|
|
10
|
+
return value;
|
|
11
|
+
}
|
|
12
|
+
function resolveCliActor() {
|
|
13
|
+
const username = process.env.USER?.trim() || process.env.USERNAME?.trim() || 'unknown';
|
|
14
|
+
return `cli:${username}`;
|
|
15
|
+
}
|
|
16
|
+
export function parseApproveCommandArgs(args) {
|
|
17
|
+
const positionalArgs = [...args];
|
|
18
|
+
const decisionIndex = positionalArgs.indexOf('--decision');
|
|
19
|
+
let decision;
|
|
20
|
+
if (decisionIndex >= 0) {
|
|
21
|
+
const value = positionalArgs[decisionIndex + 1];
|
|
22
|
+
if (!value || value.startsWith('--')) {
|
|
23
|
+
throw new Error('Missing value for "--decision". Expected "approve" or "reject".');
|
|
24
|
+
}
|
|
25
|
+
decision = value;
|
|
26
|
+
positionalArgs.splice(decisionIndex, 2);
|
|
27
|
+
}
|
|
28
|
+
if (!decision) {
|
|
29
|
+
throw new Error('Missing value for "--decision". Expected "approve" or "reject".');
|
|
30
|
+
}
|
|
31
|
+
const stepId = positionalArgs[0];
|
|
32
|
+
if (!stepId) {
|
|
33
|
+
throw new Error('Missing required argument: <step_id>');
|
|
34
|
+
}
|
|
35
|
+
return {
|
|
36
|
+
decision,
|
|
37
|
+
stepId,
|
|
38
|
+
};
|
|
39
|
+
}
|
|
40
|
+
export function decideManualStep(runId, stepId, commandOptions) {
|
|
41
|
+
const config = loadCliConfig(commandOptions.rootDir);
|
|
42
|
+
assertInitializedProject(config, 'approve');
|
|
43
|
+
const db = openStorageDb({
|
|
44
|
+
dbPath: commandOptions.dbPath ?? config.dbPath,
|
|
45
|
+
});
|
|
46
|
+
try {
|
|
47
|
+
const decision = assertManualDecision(commandOptions.decision);
|
|
48
|
+
const normalizedStepId = assertValidStepId(stepId);
|
|
49
|
+
return persistManualDecision(db, runId, normalizedStepId, decision, {
|
|
50
|
+
actor: resolveCliActor(),
|
|
51
|
+
});
|
|
52
|
+
}
|
|
53
|
+
finally {
|
|
54
|
+
db.close();
|
|
55
|
+
}
|
|
56
|
+
}
|
|
57
|
+
export function runApproveCommand(runId, stepId, commandOptions) {
|
|
58
|
+
printJson(decideManualStep(runId, stepId, commandOptions));
|
|
59
|
+
}
|
|
60
|
+
//# sourceMappingURL=approve.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"approve.js","sourceRoot":"","sources":["../../src/commands/approve.ts"],"names":[],"mappings":"AAAA,OAAO,EACN,aAAa,EACb,gBAAgB,IAAI,qBAAqB,GACzC,MAAM,0BAA0B,CAAC;AAClC,OAAO,EAAE,aAAa,EAAE,MAAM,oBAAoB,CAAC;AACnD,OAAO,EAAE,SAAS,EAAE,MAAM,qBAAqB,CAAC;AAChD,OAAO,EAAE,wBAAwB,EAAE,MAAM,eAAe,CAAC;AACzD,OAAO,EAAE,iBAAiB,EAAE,MAAM,aAAa,CAAC;AAehD,SAAS,oBAAoB,CAAC,KAAa;IAC1C,IAAI,KAAK,KAAK,SAAS,IAAI,KAAK,KAAK,QAAQ,EAAE,CAAC;QAC/C,MAAM,IAAI,KAAK,CACd,qBAAqB,KAAK,oCAAoC,CAC9D,CAAC;IACH,CAAC;IAED,OAAO,KAAK,CAAC;AACd,CAAC;AAED,SAAS,eAAe;IACvB,MAAM,QAAQ,GACb,OAAO,CAAC,GAAG,CAAC,IAAI,EAAE,IAAI,EAAE,IAAI,OAAO,CAAC,GAAG,CAAC,QAAQ,EAAE,IAAI,EAAE,IAAI,SAAS,CAAC;IACvE,OAAO,OAAO,QAAQ,EAAE,CAAC;AAC1B,CAAC;AAED,MAAM,UAAU,uBAAuB,CACtC,IAAc;IAEd,MAAM,cAAc,GAAG,CAAC,GAAG,IAAI,CAAC,CAAC;IACjC,MAAM,aAAa,GAAG,cAAc,CAAC,OAAO,CAAC,YAAY,CAAC,CAAC;IAC3D,IAAI,QAA4B,CAAC;IAEjC,IAAI,aAAa,IAAI,CAAC,EAAE,CAAC;QACxB,MAAM,KAAK,GAAG,cAAc,CAAC,aAAa,GAAG,CAAC,CAAC,CAAC;QAChD,IAAI,CAAC,KAAK,IAAI,KAAK,CAAC,UAAU,CAAC,IAAI,CAAC,EAAE,CAAC;YACtC,MAAM,IAAI,KAAK,CACd,iEAAiE,CACjE,CAAC;QACH,CAAC;QAED,QAAQ,GAAG,KAAK,CAAC;QACjB,cAAc,CAAC,MAAM,CAAC,aAAa,EAAE,CAAC,CAAC,CAAC;IACzC,CAAC;IAED,IAAI,CAAC,QAAQ,EAAE,CAAC;QACf,MAAM,IAAI,KAAK,CACd,iEAAiE,CACjE,CAAC;IACH,CAAC;IAED,MAAM,MAAM,GAAG,cAAc,CAAC,CAAC,CAAC,CAAC;IACjC,IAAI,CAAC,MAAM,EAAE,CAAC;QACb,MAAM,IAAI,KAAK,CAAC,sCAAsC,CAAC,CAAC;IACzD,CAAC;IAED,OAAO;QACN,QAAQ;QACR,MAAM;KACN,CAAC;AACH,CAAC;AAED,MAAM,UAAU,gBAAgB,CAC/B,KAAa,EACb,MAAc,EACd,cAAqC;IAErC,MAAM,MAAM,GAAG,aAAa,CAAC,cAAc,CAAC,OAAO,CAAC,CAAC;IACrD,wBAAwB,CAAC,MAAM,EAAE,SAAS,CAAC,CAAC;IAC5C,MAAM,EAAE,GAAG,aAAa,CAAC;QACxB,MAAM,EAAE,cAAc,CAAC,MAAM,IAAI,MAAM,CAAC,MAAM;KAC9C,CAAC,CAAC;IAEH,IAAI,CAAC;QACJ,MAAM,QAAQ,GAAG,oBAAoB,CAAC,cAAc,CAAC,QAAQ,CAAC,CAAC;QAC/D,MAAM,gBAAgB,GAAG,iBAAiB,CAAC,MAAM,CAAC,CAAC;QACnD,OAAO,qBAAqB,CAAC,EAAE,EAAE,KAAK,EAAE,gBAAgB,EAAE,QAAQ,EAAE;YACnE,KAAK,EAAE,eAAe,EAAE;SACxB,CAAC,CAAC;IACJ,CAAC;YAAS,CAAC;QACV,EAAE,CAAC,KAAK,EAAE,CAAC;IACZ,CAAC;AACF,CAAC;AAED,MAAM,UAAU,iBAAiB,CAChC,KAAa,EACb,MAAc,EACd,cAAqC;IAErC,SAAS,CAAC,gBAAgB,CAAC,KAAK,EAAE,MAAM,EAAE,cAAc,CAAC,CAAC,CAAC;AAC5D,CAAC"}
|
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
export interface CancelCommandOptions {
|
|
2
|
+
dbPath?: string;
|
|
3
|
+
rootDir?: string;
|
|
4
|
+
}
|
|
5
|
+
export declare function cancelWorkflowRun(runId: string, commandOptions?: CancelCommandOptions): import("@claushaas/ergon-storage").WorkflowRunRow;
|
|
6
|
+
export declare function runCancelCommand(runId: string, commandOptions?: CancelCommandOptions): void;
|
|
7
|
+
//# sourceMappingURL=cancel.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"cancel.d.ts","sourceRoot":"","sources":["../../src/commands/cancel.ts"],"names":[],"mappings":"AAKA,MAAM,WAAW,oBAAoB;IACpC,MAAM,CAAC,EAAE,MAAM,CAAC;IAChB,OAAO,CAAC,EAAE,MAAM,CAAC;CACjB;AAQD,wBAAgB,iBAAiB,CAChC,KAAK,EAAE,MAAM,EACb,cAAc,GAAE,oBAAyB,qDAezC;AAED,wBAAgB,gBAAgB,CAC/B,KAAK,EAAE,MAAM,EACb,cAAc,GAAE,oBAAyB,GACvC,IAAI,CAEN"}
|
|
@@ -0,0 +1,27 @@
|
|
|
1
|
+
import { cancelRun, openStorageDb } from '@claushaas/ergon-storage';
|
|
2
|
+
import { loadCliConfig } from '../config/index.js';
|
|
3
|
+
import { printJson } from '../output/format.js';
|
|
4
|
+
import { assertInitializedProject } from '../project.js';
|
|
5
|
+
function resolveCliActor() {
|
|
6
|
+
const username = process.env.USER?.trim() || process.env.USERNAME?.trim() || 'unknown';
|
|
7
|
+
return `cli:${username}`;
|
|
8
|
+
}
|
|
9
|
+
export function cancelWorkflowRun(runId, commandOptions = {}) {
|
|
10
|
+
const config = loadCliConfig(commandOptions.rootDir);
|
|
11
|
+
assertInitializedProject(config, 'cancel');
|
|
12
|
+
const db = openStorageDb({
|
|
13
|
+
dbPath: commandOptions.dbPath ?? config.dbPath,
|
|
14
|
+
});
|
|
15
|
+
try {
|
|
16
|
+
return cancelRun(db, runId, {
|
|
17
|
+
actor: resolveCliActor(),
|
|
18
|
+
});
|
|
19
|
+
}
|
|
20
|
+
finally {
|
|
21
|
+
db.close();
|
|
22
|
+
}
|
|
23
|
+
}
|
|
24
|
+
export function runCancelCommand(runId, commandOptions = {}) {
|
|
25
|
+
printJson(cancelWorkflowRun(runId, commandOptions));
|
|
26
|
+
}
|
|
27
|
+
//# sourceMappingURL=cancel.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"cancel.js","sourceRoot":"","sources":["../../src/commands/cancel.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,EAAE,aAAa,EAAE,MAAM,0BAA0B,CAAC;AACpE,OAAO,EAAE,aAAa,EAAE,MAAM,oBAAoB,CAAC;AACnD,OAAO,EAAE,SAAS,EAAE,MAAM,qBAAqB,CAAC;AAChD,OAAO,EAAE,wBAAwB,EAAE,MAAM,eAAe,CAAC;AAOzD,SAAS,eAAe;IACvB,MAAM,QAAQ,GACb,OAAO,CAAC,GAAG,CAAC,IAAI,EAAE,IAAI,EAAE,IAAI,OAAO,CAAC,GAAG,CAAC,QAAQ,EAAE,IAAI,EAAE,IAAI,SAAS,CAAC;IACvE,OAAO,OAAO,QAAQ,EAAE,CAAC;AAC1B,CAAC;AAED,MAAM,UAAU,iBAAiB,CAChC,KAAa,EACb,iBAAuC,EAAE;IAEzC,MAAM,MAAM,GAAG,aAAa,CAAC,cAAc,CAAC,OAAO,CAAC,CAAC;IACrD,wBAAwB,CAAC,MAAM,EAAE,QAAQ,CAAC,CAAC;IAC3C,MAAM,EAAE,GAAG,aAAa,CAAC;QACxB,MAAM,EAAE,cAAc,CAAC,MAAM,IAAI,MAAM,CAAC,MAAM;KAC9C,CAAC,CAAC;IAEH,IAAI,CAAC;QACJ,OAAO,SAAS,CAAC,EAAE,EAAE,KAAK,EAAE;YAC3B,KAAK,EAAE,eAAe,EAAE;SACxB,CAAC,CAAC;IACJ,CAAC;YAAS,CAAC;QACV,EAAE,CAAC,KAAK,EAAE,CAAC;IACZ,CAAC;AACF,CAAC;AAED,MAAM,UAAU,gBAAgB,CAC/B,KAAa,EACb,iBAAuC,EAAE;IAEzC,SAAS,CAAC,iBAAiB,CAAC,KAAK,EAAE,cAAc,CAAC,CAAC,CAAC;AACrD,CAAC"}
|
|
@@ -0,0 +1,10 @@
|
|
|
1
|
+
export interface InitCommandOptions {
|
|
2
|
+
rootDir?: string;
|
|
3
|
+
}
|
|
4
|
+
export declare function initProject(commandOptions?: InitCommandOptions): {
|
|
5
|
+
configPath: string;
|
|
6
|
+
libraryVersion: string;
|
|
7
|
+
rootDir: string;
|
|
8
|
+
};
|
|
9
|
+
export declare function runInitCommand(commandOptions?: InitCommandOptions): void;
|
|
10
|
+
//# sourceMappingURL=init.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"init.d.ts","sourceRoot":"","sources":["../../src/commands/init.ts"],"names":[],"mappings":"AAGA,MAAM,WAAW,kBAAkB;IAClC,OAAO,CAAC,EAAE,MAAM,CAAC;CACjB;AAED,wBAAgB,WAAW,CAAC,cAAc,GAAE,kBAAuB;;;;EAUlE;AAED,wBAAgB,cAAc,CAAC,cAAc,GAAE,kBAAuB,GAAG,IAAI,CAE5E"}
|
|
@@ -0,0 +1,16 @@
|
|
|
1
|
+
import { printJson } from '../output/format.js';
|
|
2
|
+
import { initializeProject, resolveProjectPaths } from '../project.js';
|
|
3
|
+
export function initProject(commandOptions = {}) {
|
|
4
|
+
const rootDir = commandOptions.rootDir ?? process.cwd();
|
|
5
|
+
const project = resolveProjectPaths(rootDir, rootDir);
|
|
6
|
+
const metadata = initializeProject({ rootDir: project.rootDir });
|
|
7
|
+
return {
|
|
8
|
+
configPath: project.configPath,
|
|
9
|
+
libraryVersion: metadata.library_version,
|
|
10
|
+
rootDir: project.rootDir,
|
|
11
|
+
};
|
|
12
|
+
}
|
|
13
|
+
export function runInitCommand(commandOptions = {}) {
|
|
14
|
+
printJson(initProject(commandOptions));
|
|
15
|
+
}
|
|
16
|
+
//# sourceMappingURL=init.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"init.js","sourceRoot":"","sources":["../../src/commands/init.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,EAAE,MAAM,qBAAqB,CAAC;AAChD,OAAO,EAAE,iBAAiB,EAAE,mBAAmB,EAAE,MAAM,eAAe,CAAC;AAMvE,MAAM,UAAU,WAAW,CAAC,iBAAqC,EAAE;IAClE,MAAM,OAAO,GAAG,cAAc,CAAC,OAAO,IAAI,OAAO,CAAC,GAAG,EAAE,CAAC;IACxD,MAAM,OAAO,GAAG,mBAAmB,CAAC,OAAO,EAAE,OAAO,CAAC,CAAC;IACtD,MAAM,QAAQ,GAAG,iBAAiB,CAAC,EAAE,OAAO,EAAE,OAAO,CAAC,OAAO,EAAE,CAAC,CAAC;IAEjE,OAAO;QACN,UAAU,EAAE,OAAO,CAAC,UAAU;QAC9B,cAAc,EAAE,QAAQ,CAAC,eAAe;QACxC,OAAO,EAAE,OAAO,CAAC,OAAO;KACxB,CAAC;AACH,CAAC;AAED,MAAM,UAAU,cAAc,CAAC,iBAAqC,EAAE;IACrE,SAAS,CAAC,WAAW,CAAC,cAAc,CAAC,CAAC,CAAC;AACxC,CAAC"}
|
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
export interface LibrarySyncCommandOptions {
|
|
2
|
+
force?: boolean;
|
|
3
|
+
rootDir?: string;
|
|
4
|
+
}
|
|
5
|
+
export declare function syncLibrary(commandOptions?: LibrarySyncCommandOptions): import("../project.js").SyncLibrarySummary;
|
|
6
|
+
export declare function runLibrarySyncCommand(commandOptions?: LibrarySyncCommandOptions): void;
|
|
7
|
+
//# sourceMappingURL=library.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"library.d.ts","sourceRoot":"","sources":["../../src/commands/library.ts"],"names":[],"mappings":"AAGA,MAAM,WAAW,yBAAyB;IACzC,KAAK,CAAC,EAAE,OAAO,CAAC;IAChB,OAAO,CAAC,EAAE,MAAM,CAAC;CACjB;AAED,wBAAgB,WAAW,CAAC,cAAc,GAAE,yBAA8B,8CAKzE;AAED,wBAAgB,qBAAqB,CACpC,cAAc,GAAE,yBAA8B,GAC5C,IAAI,CAEN"}
|
|
@@ -0,0 +1,12 @@
|
|
|
1
|
+
import { printJson } from '../output/format.js';
|
|
2
|
+
import { syncProjectLibrary } from '../project.js';
|
|
3
|
+
export function syncLibrary(commandOptions = {}) {
|
|
4
|
+
return syncProjectLibrary({
|
|
5
|
+
force: commandOptions.force,
|
|
6
|
+
rootDir: commandOptions.rootDir ?? process.cwd(),
|
|
7
|
+
});
|
|
8
|
+
}
|
|
9
|
+
export function runLibrarySyncCommand(commandOptions = {}) {
|
|
10
|
+
printJson(syncLibrary(commandOptions));
|
|
11
|
+
}
|
|
12
|
+
//# sourceMappingURL=library.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"library.js","sourceRoot":"","sources":["../../src/commands/library.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,EAAE,MAAM,qBAAqB,CAAC;AAChD,OAAO,EAAE,kBAAkB,EAAE,MAAM,eAAe,CAAC;AAOnD,MAAM,UAAU,WAAW,CAAC,iBAA4C,EAAE;IACzE,OAAO,kBAAkB,CAAC;QACzB,KAAK,EAAE,cAAc,CAAC,KAAK;QAC3B,OAAO,EAAE,cAAc,CAAC,OAAO,IAAI,OAAO,CAAC,GAAG,EAAE;KAChD,CAAC,CAAC;AACJ,CAAC;AAED,MAAM,UAAU,qBAAqB,CACpC,iBAA4C,EAAE;IAE9C,SAAS,CAAC,WAAW,CAAC,cAAc,CAAC,CAAC,CAAC;AACxC,CAAC"}
|
|
@@ -0,0 +1,18 @@
|
|
|
1
|
+
import { getRun, listStepRuns } from '@claushaas/ergon-storage';
|
|
2
|
+
export interface RunCommandOptions {
|
|
3
|
+
dbPath?: string;
|
|
4
|
+
inputs?: string;
|
|
5
|
+
rootDir?: string;
|
|
6
|
+
}
|
|
7
|
+
export interface RunStatusCommandOptions {
|
|
8
|
+
dbPath?: string;
|
|
9
|
+
rootDir?: string;
|
|
10
|
+
}
|
|
11
|
+
export declare function scheduleRun(workflowId: string, commandOptions?: RunCommandOptions): import("@claushaas/ergon-storage").WorkflowRunRow;
|
|
12
|
+
export declare function getRunStatus(runId: string, commandOptions?: RunStatusCommandOptions): {
|
|
13
|
+
run: NonNullable<ReturnType<typeof getRun>>;
|
|
14
|
+
stepRuns: ReturnType<typeof listStepRuns>;
|
|
15
|
+
};
|
|
16
|
+
export declare function runRunCommand(workflowId: string, commandOptions?: RunCommandOptions): void;
|
|
17
|
+
export declare function runRunStatusCommand(runId: string, commandOptions?: RunStatusCommandOptions): void;
|
|
18
|
+
//# sourceMappingURL=run.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"run.d.ts","sourceRoot":"","sources":["../../src/commands/run.ts"],"names":[],"mappings":"AAMA,OAAO,EAEN,MAAM,EAEN,YAAY,EAGZ,MAAM,0BAA0B,CAAC;AAUlC,MAAM,WAAW,iBAAiB;IACjC,MAAM,CAAC,EAAE,MAAM,CAAC;IAChB,MAAM,CAAC,EAAE,MAAM,CAAC;IAChB,OAAO,CAAC,EAAE,MAAM,CAAC;CACjB;AAED,MAAM,WAAW,uBAAuB;IACvC,MAAM,CAAC,EAAE,MAAM,CAAC;IAChB,OAAO,CAAC,EAAE,MAAM,CAAC;CACjB;AA+BD,wBAAgB,WAAW,CAC1B,UAAU,EAAE,MAAM,EAClB,cAAc,GAAE,iBAAsB,qDAiDtC;AAED,wBAAgB,YAAY,CAC3B,KAAK,EAAE,MAAM,EACb,cAAc,GAAE,uBAA4B,GAC1C;IACF,GAAG,EAAE,WAAW,CAAC,UAAU,CAAC,OAAO,MAAM,CAAC,CAAC,CAAC;IAC5C,QAAQ,EAAE,UAAU,CAAC,OAAO,YAAY,CAAC,CAAC;CAC1C,CAoBA;AAED,wBAAgB,aAAa,CAC5B,UAAU,EAAE,MAAM,EAClB,cAAc,GAAE,iBAAsB,GACpC,IAAI,CAEN;AAED,wBAAgB,mBAAmB,CAClC,KAAK,EAAE,MAAM,EACb,cAAc,GAAE,uBAA4B,GAC1C,IAAI,CAEN"}
|
|
@@ -0,0 +1,82 @@
|
|
|
1
|
+
import { readFileSync } from 'node:fs';
|
|
2
|
+
import path from 'node:path';
|
|
3
|
+
import { loadAndValidateTemplateFromFile, resolveWorkflowInputs, } from '@claushaas/ergon-engine';
|
|
4
|
+
import { createRun, getRun, getWorkflow, listStepRuns, openStorageDb, registerWorkflow, } from '@claushaas/ergon-storage';
|
|
5
|
+
import { loadCliConfig } from '../config/index.js';
|
|
6
|
+
import { printJson } from '../output/format.js';
|
|
7
|
+
import { assertInitializedProject } from '../project.js';
|
|
8
|
+
import { assertValidWorkflowId, hashFile, resolvePathWithinBase, } from '../utils.js';
|
|
9
|
+
function resolveWorkflowTemplatePath(workflowsDir, workflowId) {
|
|
10
|
+
return path.join(workflowsDir, `${assertValidWorkflowId(workflowId)}.yaml`);
|
|
11
|
+
}
|
|
12
|
+
function parseInputs(rawInputs, rootDir) {
|
|
13
|
+
if (!rawInputs) {
|
|
14
|
+
return {};
|
|
15
|
+
}
|
|
16
|
+
const trimmedInputs = rawInputs.trim();
|
|
17
|
+
const content = trimmedInputs.startsWith('{')
|
|
18
|
+
? trimmedInputs
|
|
19
|
+
: readFileSync(resolvePathWithinBase(rootDir, trimmedInputs, 'inputs path'), 'utf8');
|
|
20
|
+
const parsed = JSON.parse(content);
|
|
21
|
+
if (!parsed || typeof parsed !== 'object' || Array.isArray(parsed)) {
|
|
22
|
+
throw new Error('Run inputs must be a JSON object');
|
|
23
|
+
}
|
|
24
|
+
return parsed;
|
|
25
|
+
}
|
|
26
|
+
export function scheduleRun(workflowId, commandOptions = {}) {
|
|
27
|
+
const config = loadCliConfig(commandOptions.rootDir);
|
|
28
|
+
assertInitializedProject(config, 'run');
|
|
29
|
+
const db = openStorageDb({
|
|
30
|
+
dbPath: commandOptions.dbPath ?? config.dbPath,
|
|
31
|
+
});
|
|
32
|
+
try {
|
|
33
|
+
const templatePath = resolveWorkflowTemplatePath(config.workflowsDir, workflowId);
|
|
34
|
+
const { template } = loadAndValidateTemplateFromFile(templatePath);
|
|
35
|
+
const workflowHash = hashFile(templatePath);
|
|
36
|
+
registerWorkflow(db, {
|
|
37
|
+
description: template.workflow.description,
|
|
38
|
+
hash: workflowHash,
|
|
39
|
+
id: template.workflow.id,
|
|
40
|
+
sourcePath: path.relative(config.rootDir, templatePath),
|
|
41
|
+
version: template.workflow.version,
|
|
42
|
+
});
|
|
43
|
+
const workflow = getWorkflow(db, template.workflow.id, template.workflow.version);
|
|
44
|
+
if (!workflow) {
|
|
45
|
+
throw new Error(`Workflow "${template.workflow.id}" could not be registered`);
|
|
46
|
+
}
|
|
47
|
+
return createRun(db, workflow.id, resolveWorkflowInputs(template, parseInputs(commandOptions.inputs, config.rootDir)), {
|
|
48
|
+
workflowHash: workflow.hash,
|
|
49
|
+
workflowVersion: workflow.version,
|
|
50
|
+
});
|
|
51
|
+
}
|
|
52
|
+
finally {
|
|
53
|
+
db.close();
|
|
54
|
+
}
|
|
55
|
+
}
|
|
56
|
+
export function getRunStatus(runId, commandOptions = {}) {
|
|
57
|
+
const config = loadCliConfig(commandOptions.rootDir);
|
|
58
|
+
assertInitializedProject(config, 'run-status');
|
|
59
|
+
const db = openStorageDb({
|
|
60
|
+
dbPath: commandOptions.dbPath ?? config.dbPath,
|
|
61
|
+
});
|
|
62
|
+
try {
|
|
63
|
+
const run = getRun(db, runId);
|
|
64
|
+
if (!run) {
|
|
65
|
+
throw new Error(`Workflow run "${runId}" was not found`);
|
|
66
|
+
}
|
|
67
|
+
return {
|
|
68
|
+
run,
|
|
69
|
+
stepRuns: listStepRuns(db, runId),
|
|
70
|
+
};
|
|
71
|
+
}
|
|
72
|
+
finally {
|
|
73
|
+
db.close();
|
|
74
|
+
}
|
|
75
|
+
}
|
|
76
|
+
export function runRunCommand(workflowId, commandOptions = {}) {
|
|
77
|
+
printJson(scheduleRun(workflowId, commandOptions));
|
|
78
|
+
}
|
|
79
|
+
export function runRunStatusCommand(runId, commandOptions = {}) {
|
|
80
|
+
printJson(getRunStatus(runId, commandOptions));
|
|
81
|
+
}
|
|
82
|
+
//# sourceMappingURL=run.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"run.js","sourceRoot":"","sources":["../../src/commands/run.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,13 @@
|
|
|
1
|
+
export interface TemplateListCommandOptions {
|
|
2
|
+
rootDir?: string;
|
|
3
|
+
}
|
|
4
|
+
export declare function listTemplates(commandOptions?: TemplateListCommandOptions): Array<{
|
|
5
|
+
description?: string;
|
|
6
|
+
id: string;
|
|
7
|
+
path: string;
|
|
8
|
+
stepCount: number;
|
|
9
|
+
valid: boolean;
|
|
10
|
+
version: number;
|
|
11
|
+
}>;
|
|
12
|
+
export declare function runTemplateListCommand(commandOptions?: TemplateListCommandOptions): void;
|
|
13
|
+
//# sourceMappingURL=template.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"template.d.ts","sourceRoot":"","sources":["../../src/commands/template.ts"],"names":[],"mappings":"AASA,MAAM,WAAW,0BAA0B;IAC1C,OAAO,CAAC,EAAE,MAAM,CAAC;CACjB;AAED,wBAAgB,aAAa,CAC5B,cAAc,GAAE,0BAA+B,GAC7C,KAAK,CAAC;IACR,WAAW,CAAC,EAAE,MAAM,CAAC;IACrB,EAAE,EAAE,MAAM,CAAC;IACX,IAAI,EAAE,MAAM,CAAC;IACb,SAAS,EAAE,MAAM,CAAC;IAClB,KAAK,EAAE,OAAO,CAAC;IACf,OAAO,EAAE,MAAM,CAAC;CAChB,CAAC,CAkCD;AAED,wBAAgB,sBAAsB,CACrC,cAAc,GAAE,0BAA+B,GAC7C,IAAI,CAEN"}
|
|
@@ -0,0 +1,42 @@
|
|
|
1
|
+
import path from 'node:path';
|
|
2
|
+
import { loadAndValidateTemplateFromFile, loadTemplatesFromDir, } from '@claushaas/ergon-engine';
|
|
3
|
+
import { loadCliConfig } from '../config/index.js';
|
|
4
|
+
import { printJson } from '../output/format.js';
|
|
5
|
+
import { resolveEmbeddedTemplateDisplayPath } from '../utils.js';
|
|
6
|
+
export function listTemplates(commandOptions = {}) {
|
|
7
|
+
const config = loadCliConfig(commandOptions.rootDir);
|
|
8
|
+
const templatesDir = config.initialized
|
|
9
|
+
? config.workflowsDir
|
|
10
|
+
: config.embeddedWorkflowsDir;
|
|
11
|
+
return loadTemplatesFromDir(templatesDir).map((loadedTemplate) => {
|
|
12
|
+
try {
|
|
13
|
+
const validated = loadAndValidateTemplateFromFile(loadedTemplate.templatePath);
|
|
14
|
+
return {
|
|
15
|
+
description: validated.template.workflow.description,
|
|
16
|
+
id: validated.template.workflow.id,
|
|
17
|
+
path: config.initialized
|
|
18
|
+
? path.relative(config.rootDir, validated.templatePath)
|
|
19
|
+
: resolveEmbeddedTemplateDisplayPath(validated.templatePath),
|
|
20
|
+
stepCount: validated.template.steps.length,
|
|
21
|
+
valid: true,
|
|
22
|
+
version: validated.template.workflow.version,
|
|
23
|
+
};
|
|
24
|
+
}
|
|
25
|
+
catch (_error) {
|
|
26
|
+
return {
|
|
27
|
+
description: loadedTemplate.template.workflow.description,
|
|
28
|
+
id: loadedTemplate.template.workflow.id,
|
|
29
|
+
path: config.initialized
|
|
30
|
+
? path.relative(config.rootDir, loadedTemplate.templatePath)
|
|
31
|
+
: resolveEmbeddedTemplateDisplayPath(loadedTemplate.templatePath),
|
|
32
|
+
stepCount: loadedTemplate.template.steps.length,
|
|
33
|
+
valid: false,
|
|
34
|
+
version: loadedTemplate.template.workflow.version,
|
|
35
|
+
};
|
|
36
|
+
}
|
|
37
|
+
});
|
|
38
|
+
}
|
|
39
|
+
export function runTemplateListCommand(commandOptions = {}) {
|
|
40
|
+
printJson(listTemplates(commandOptions));
|
|
41
|
+
}
|
|
42
|
+
//# sourceMappingURL=template.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"template.js","sourceRoot":"","sources":["../../src/commands/template.ts"],"names":[],"mappings":"AAAA,OAAO,IAAI,MAAM,WAAW,CAAC;AAC7B,OAAO,EACN,+BAA+B,EAC/B,oBAAoB,GACpB,MAAM,yBAAyB,CAAC;AACjC,OAAO,EAAE,aAAa,EAAE,MAAM,oBAAoB,CAAC;AACnD,OAAO,EAAE,SAAS,EAAE,MAAM,qBAAqB,CAAC;AAChD,OAAO,EAAE,kCAAkC,EAAE,MAAM,aAAa,CAAC;AAMjE,MAAM,UAAU,aAAa,CAC5B,iBAA6C,EAAE;IAS/C,MAAM,MAAM,GAAG,aAAa,CAAC,cAAc,CAAC,OAAO,CAAC,CAAC;IACrD,MAAM,YAAY,GAAG,MAAM,CAAC,WAAW;QACtC,CAAC,CAAC,MAAM,CAAC,YAAY;QACrB,CAAC,CAAC,MAAM,CAAC,oBAAoB,CAAC;IAE/B,OAAO,oBAAoB,CAAC,YAAY,CAAC,CAAC,GAAG,CAAC,CAAC,cAAc,EAAE,EAAE;QAChE,IAAI,CAAC;YACJ,MAAM,SAAS,GAAG,+BAA+B,CAChD,cAAc,CAAC,YAAY,CAC3B,CAAC;YACF,OAAO;gBACN,WAAW,EAAE,SAAS,CAAC,QAAQ,CAAC,QAAQ,CAAC,WAAW;gBACpD,EAAE,EAAE,SAAS,CAAC,QAAQ,CAAC,QAAQ,CAAC,EAAE;gBAClC,IAAI,EAAE,MAAM,CAAC,WAAW;oBACvB,CAAC,CAAC,IAAI,CAAC,QAAQ,CAAC,MAAM,CAAC,OAAO,EAAE,SAAS,CAAC,YAAY,CAAC;oBACvD,CAAC,CAAC,kCAAkC,CAAC,SAAS,CAAC,YAAY,CAAC;gBAC7D,SAAS,EAAE,SAAS,CAAC,QAAQ,CAAC,KAAK,CAAC,MAAM;gBAC1C,KAAK,EAAE,IAAI;gBACX,OAAO,EAAE,SAAS,CAAC,QAAQ,CAAC,QAAQ,CAAC,OAAO;aAC5C,CAAC;QACH,CAAC;QAAC,OAAO,MAAM,EAAE,CAAC;YACjB,OAAO;gBACN,WAAW,EAAE,cAAc,CAAC,QAAQ,CAAC,QAAQ,CAAC,WAAW;gBACzD,EAAE,EAAE,cAAc,CAAC,QAAQ,CAAC,QAAQ,CAAC,EAAE;gBACvC,IAAI,EAAE,MAAM,CAAC,WAAW;oBACvB,CAAC,CAAC,IAAI,CAAC,QAAQ,CAAC,MAAM,CAAC,OAAO,EAAE,cAAc,CAAC,YAAY,CAAC;oBAC5D,CAAC,CAAC,kCAAkC,CAAC,cAAc,CAAC,YAAY,CAAC;gBAClE,SAAS,EAAE,cAAc,CAAC,QAAQ,CAAC,KAAK,CAAC,MAAM;gBAC/C,KAAK,EAAE,KAAK;gBACZ,OAAO,EAAE,cAAc,CAAC,QAAQ,CAAC,QAAQ,CAAC,OAAO;aACjD,CAAC;QACH,CAAC;IACF,CAAC,CAAC,CAAC;AACJ,CAAC;AAED,MAAM,UAAU,sBAAsB,CACrC,iBAA6C,EAAE;IAE/C,SAAS,CAAC,aAAa,CAAC,cAAc,CAAC,CAAC,CAAC;AAC1C,CAAC"}
|
|
@@ -0,0 +1,15 @@
|
|
|
1
|
+
export interface WorkerCommandOptions {
|
|
2
|
+
artifactBaseDir?: string;
|
|
3
|
+
dbPath?: string;
|
|
4
|
+
heartbeatIntervalMs?: number;
|
|
5
|
+
leaseDurationMs?: number;
|
|
6
|
+
leaseRenewIntervalMs?: number;
|
|
7
|
+
maxPollIntervalMs?: number;
|
|
8
|
+
maxRuns?: number;
|
|
9
|
+
pollIntervalMs?: number;
|
|
10
|
+
rootDir?: string;
|
|
11
|
+
workerId?: string;
|
|
12
|
+
}
|
|
13
|
+
export declare function parseWorkerCommandArgs(argv: string[]): WorkerCommandOptions;
|
|
14
|
+
export declare function runWorkerCommand(commandOptions?: WorkerCommandOptions): Promise<void>;
|
|
15
|
+
//# sourceMappingURL=worker.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"worker.d.ts","sourceRoot":"","sources":["../../src/commands/worker.ts"],"names":[],"mappings":"AASA,MAAM,WAAW,oBAAoB;IACpC,eAAe,CAAC,EAAE,MAAM,CAAC;IACzB,MAAM,CAAC,EAAE,MAAM,CAAC;IAChB,mBAAmB,CAAC,EAAE,MAAM,CAAC;IAC7B,eAAe,CAAC,EAAE,MAAM,CAAC;IACzB,oBAAoB,CAAC,EAAE,MAAM,CAAC;IAC9B,iBAAiB,CAAC,EAAE,MAAM,CAAC;IAC3B,OAAO,CAAC,EAAE,MAAM,CAAC;IACjB,cAAc,CAAC,EAAE,MAAM,CAAC;IACxB,OAAO,CAAC,EAAE,MAAM,CAAC;IACjB,QAAQ,CAAC,EAAE,MAAM,CAAC;CAClB;AA4BD,wBAAgB,sBAAsB,CAAC,IAAI,EAAE,MAAM,EAAE,GAAG,oBAAoB,CA2E3E;AAED,wBAAsB,gBAAgB,CACrC,cAAc,GAAE,oBAAyB,GACvC,OAAO,CAAC,IAAI,CAAC,CAqCf"}
|
|
@@ -0,0 +1,108 @@
|
|
|
1
|
+
import { randomUUID } from 'node:crypto';
|
|
2
|
+
import { createDefaultExecutorRegistry, startWorker, } from '@claushaas/ergon-engine';
|
|
3
|
+
import { openStorageDb } from '@claushaas/ergon-storage';
|
|
4
|
+
import { loadCliConfig } from '../config/index.js';
|
|
5
|
+
import { assertInitializedProject } from '../project.js';
|
|
6
|
+
function parseNumericFlag(value, flagName) {
|
|
7
|
+
if (value === undefined) {
|
|
8
|
+
return undefined;
|
|
9
|
+
}
|
|
10
|
+
const parsed = Number.parseInt(value, 10);
|
|
11
|
+
if (!Number.isFinite(parsed)) {
|
|
12
|
+
throw new Error(`Invalid numeric value for ${flagName}: ${value}`);
|
|
13
|
+
}
|
|
14
|
+
return parsed;
|
|
15
|
+
}
|
|
16
|
+
function readFlagValue(argv, index, flagName) {
|
|
17
|
+
const value = argv[index + 1];
|
|
18
|
+
if (value === undefined || value.startsWith('--')) {
|
|
19
|
+
throw new Error(`Missing value for ${flagName}`);
|
|
20
|
+
}
|
|
21
|
+
return value;
|
|
22
|
+
}
|
|
23
|
+
export function parseWorkerCommandArgs(argv) {
|
|
24
|
+
const options = {};
|
|
25
|
+
for (let index = 0; index < argv.length; index += 1) {
|
|
26
|
+
const token = argv[index];
|
|
27
|
+
switch (token) {
|
|
28
|
+
case '--artifact-base-dir':
|
|
29
|
+
options.artifactBaseDir = readFlagValue(argv, index, '--artifact-base-dir');
|
|
30
|
+
index += 1;
|
|
31
|
+
break;
|
|
32
|
+
case '--db':
|
|
33
|
+
options.dbPath = readFlagValue(argv, index, '--db');
|
|
34
|
+
index += 1;
|
|
35
|
+
break;
|
|
36
|
+
case '--heartbeat-interval-ms':
|
|
37
|
+
options.heartbeatIntervalMs = parseNumericFlag(readFlagValue(argv, index, '--heartbeat-interval-ms'), '--heartbeat-interval-ms');
|
|
38
|
+
index += 1;
|
|
39
|
+
break;
|
|
40
|
+
case '--lease-duration-ms':
|
|
41
|
+
options.leaseDurationMs = parseNumericFlag(readFlagValue(argv, index, '--lease-duration-ms'), '--lease-duration-ms');
|
|
42
|
+
index += 1;
|
|
43
|
+
break;
|
|
44
|
+
case '--lease-renew-interval-ms':
|
|
45
|
+
options.leaseRenewIntervalMs = parseNumericFlag(readFlagValue(argv, index, '--lease-renew-interval-ms'), '--lease-renew-interval-ms');
|
|
46
|
+
index += 1;
|
|
47
|
+
break;
|
|
48
|
+
case '--max-poll-interval-ms':
|
|
49
|
+
options.maxPollIntervalMs = parseNumericFlag(readFlagValue(argv, index, '--max-poll-interval-ms'), '--max-poll-interval-ms');
|
|
50
|
+
index += 1;
|
|
51
|
+
break;
|
|
52
|
+
case '--max-runs':
|
|
53
|
+
options.maxRuns = parseNumericFlag(readFlagValue(argv, index, '--max-runs'), '--max-runs');
|
|
54
|
+
index += 1;
|
|
55
|
+
break;
|
|
56
|
+
case '--poll-interval-ms':
|
|
57
|
+
options.pollIntervalMs = parseNumericFlag(readFlagValue(argv, index, '--poll-interval-ms'), '--poll-interval-ms');
|
|
58
|
+
index += 1;
|
|
59
|
+
break;
|
|
60
|
+
case '--root-dir':
|
|
61
|
+
options.rootDir = readFlagValue(argv, index, '--root-dir');
|
|
62
|
+
index += 1;
|
|
63
|
+
break;
|
|
64
|
+
case '--worker-id':
|
|
65
|
+
options.workerId = readFlagValue(argv, index, '--worker-id');
|
|
66
|
+
index += 1;
|
|
67
|
+
break;
|
|
68
|
+
default:
|
|
69
|
+
throw new Error(`Unknown worker option: ${token}`);
|
|
70
|
+
}
|
|
71
|
+
}
|
|
72
|
+
return options;
|
|
73
|
+
}
|
|
74
|
+
export async function runWorkerCommand(commandOptions = {}) {
|
|
75
|
+
const config = loadCliConfig(commandOptions.rootDir);
|
|
76
|
+
assertInitializedProject(config, 'worker start');
|
|
77
|
+
const db = openStorageDb({
|
|
78
|
+
dbPath: commandOptions.dbPath ?? config.dbPath,
|
|
79
|
+
});
|
|
80
|
+
try {
|
|
81
|
+
const workerId = commandOptions.workerId ?? `worker-${randomUUID()}`;
|
|
82
|
+
const executors = createDefaultExecutorRegistry({
|
|
83
|
+
providerConfigs: config.providerConfigs,
|
|
84
|
+
});
|
|
85
|
+
const result = await startWorker({
|
|
86
|
+
artifactBaseDir: commandOptions.artifactBaseDir ?? config.rootDir,
|
|
87
|
+
db,
|
|
88
|
+
executors,
|
|
89
|
+
heartbeatIntervalMs: commandOptions.heartbeatIntervalMs,
|
|
90
|
+
leaseDurationMs: commandOptions.leaseDurationMs,
|
|
91
|
+
leaseRenewIntervalMs: commandOptions.leaseRenewIntervalMs,
|
|
92
|
+
maxPollIntervalMs: commandOptions.maxPollIntervalMs,
|
|
93
|
+
maxRuns: commandOptions.maxRuns,
|
|
94
|
+
pollIntervalMs: commandOptions.pollIntervalMs,
|
|
95
|
+
rootDir: commandOptions.rootDir ?? config.rootDir,
|
|
96
|
+
workerId,
|
|
97
|
+
});
|
|
98
|
+
console.log(JSON.stringify({
|
|
99
|
+
dbPath: commandOptions.dbPath ?? config.dbPath,
|
|
100
|
+
processedRuns: result.processedRuns,
|
|
101
|
+
workerId: result.workerId,
|
|
102
|
+
}));
|
|
103
|
+
}
|
|
104
|
+
finally {
|
|
105
|
+
db.close();
|
|
106
|
+
}
|
|
107
|
+
}
|
|
108
|
+
//# sourceMappingURL=worker.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"worker.js","sourceRoot":"","sources":["../../src/commands/worker.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,8 @@
|
|
|
1
|
+
import { listWorkflows } from '@claushaas/ergon-storage';
|
|
2
|
+
export interface WorkflowListCommandOptions {
|
|
3
|
+
dbPath?: string;
|
|
4
|
+
rootDir?: string;
|
|
5
|
+
}
|
|
6
|
+
export declare function syncWorkflows(commandOptions?: WorkflowListCommandOptions): ReturnType<typeof listWorkflows>;
|
|
7
|
+
export declare function runWorkflowListCommand(commandOptions?: WorkflowListCommandOptions): void;
|
|
8
|
+
//# sourceMappingURL=workflow.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"workflow.d.ts","sourceRoot":"","sources":["../../src/commands/workflow.ts"],"names":[],"mappings":"AAKA,OAAO,EACN,aAAa,EAGb,MAAM,0BAA0B,CAAC;AAMlC,MAAM,WAAW,0BAA0B;IAC1C,MAAM,CAAC,EAAE,MAAM,CAAC;IAChB,OAAO,CAAC,EAAE,MAAM,CAAC;CACjB;AAED,wBAAgB,aAAa,CAC5B,cAAc,GAAE,0BAA+B,GAC7C,UAAU,CAAC,OAAO,aAAa,CAAC,CAyBlC;AAED,wBAAgB,sBAAsB,CACrC,cAAc,GAAE,0BAA+B,GAC7C,IAAI,CAEN"}
|
|
@@ -0,0 +1,34 @@
|
|
|
1
|
+
import path from 'node:path';
|
|
2
|
+
import { loadAndValidateTemplateFromFile, loadTemplatesFromDir, } from '@claushaas/ergon-engine';
|
|
3
|
+
import { listWorkflows, openStorageDb, registerWorkflow, } from '@claushaas/ergon-storage';
|
|
4
|
+
import { loadCliConfig } from '../config/index.js';
|
|
5
|
+
import { printJson } from '../output/format.js';
|
|
6
|
+
import { assertInitializedProject } from '../project.js';
|
|
7
|
+
import { hashFile } from '../utils.js';
|
|
8
|
+
export function syncWorkflows(commandOptions = {}) {
|
|
9
|
+
const config = loadCliConfig(commandOptions.rootDir);
|
|
10
|
+
assertInitializedProject(config, 'workflow list');
|
|
11
|
+
const db = openStorageDb({
|
|
12
|
+
dbPath: commandOptions.dbPath ?? config.dbPath,
|
|
13
|
+
});
|
|
14
|
+
try {
|
|
15
|
+
for (const loadedTemplate of loadTemplatesFromDir(config.workflowsDir)) {
|
|
16
|
+
const { template, templatePath } = loadAndValidateTemplateFromFile(loadedTemplate.templatePath);
|
|
17
|
+
registerWorkflow(db, {
|
|
18
|
+
description: template.workflow.description,
|
|
19
|
+
hash: hashFile(templatePath),
|
|
20
|
+
id: template.workflow.id,
|
|
21
|
+
sourcePath: path.relative(config.rootDir, templatePath),
|
|
22
|
+
version: template.workflow.version,
|
|
23
|
+
});
|
|
24
|
+
}
|
|
25
|
+
return listWorkflows(db);
|
|
26
|
+
}
|
|
27
|
+
finally {
|
|
28
|
+
db.close();
|
|
29
|
+
}
|
|
30
|
+
}
|
|
31
|
+
export function runWorkflowListCommand(commandOptions = {}) {
|
|
32
|
+
printJson(syncWorkflows(commandOptions));
|
|
33
|
+
}
|
|
34
|
+
//# sourceMappingURL=workflow.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"workflow.js","sourceRoot":"","sources":["../../src/commands/workflow.ts"],"names":[],"mappings":"AAAA,OAAO,IAAI,MAAM,WAAW,CAAC;AAC7B,OAAO,EACN,+BAA+B,EAC/B,oBAAoB,GACpB,MAAM,yBAAyB,CAAC;AACjC,OAAO,EACN,aAAa,EACb,aAAa,EACb,gBAAgB,GAChB,MAAM,0BAA0B,CAAC;AAClC,OAAO,EAAE,aAAa,EAAE,MAAM,oBAAoB,CAAC;AACnD,OAAO,EAAE,SAAS,EAAE,MAAM,qBAAqB,CAAC;AAChD,OAAO,EAAE,wBAAwB,EAAE,MAAM,eAAe,CAAC;AACzD,OAAO,EAAE,QAAQ,EAAE,MAAM,aAAa,CAAC;AAOvC,MAAM,UAAU,aAAa,CAC5B,iBAA6C,EAAE;IAE/C,MAAM,MAAM,GAAG,aAAa,CAAC,cAAc,CAAC,OAAO,CAAC,CAAC;IACrD,wBAAwB,CAAC,MAAM,EAAE,eAAe,CAAC,CAAC;IAClD,MAAM,EAAE,GAAG,aAAa,CAAC;QACxB,MAAM,EAAE,cAAc,CAAC,MAAM,IAAI,MAAM,CAAC,MAAM;KAC9C,CAAC,CAAC;IAEH,IAAI,CAAC;QACJ,KAAK,MAAM,cAAc,IAAI,oBAAoB,CAAC,MAAM,CAAC,YAAY,CAAC,EAAE,CAAC;YACxE,MAAM,EAAE,QAAQ,EAAE,YAAY,EAAE,GAAG,+BAA+B,CACjE,cAAc,CAAC,YAAY,CAC3B,CAAC;YACF,gBAAgB,CAAC,EAAE,EAAE;gBACpB,WAAW,EAAE,QAAQ,CAAC,QAAQ,CAAC,WAAW;gBAC1C,IAAI,EAAE,QAAQ,CAAC,YAAY,CAAC;gBAC5B,EAAE,EAAE,QAAQ,CAAC,QAAQ,CAAC,EAAE;gBACxB,UAAU,EAAE,IAAI,CAAC,QAAQ,CAAC,MAAM,CAAC,OAAO,EAAE,YAAY,CAAC;gBACvD,OAAO,EAAE,QAAQ,CAAC,QAAQ,CAAC,OAAO;aAClC,CAAC,CAAC;QACJ,CAAC;QAED,OAAO,aAAa,CAAC,EAAE,CAAC,CAAC;IAC1B,CAAC;YAAS,CAAC;QACV,EAAE,CAAC,KAAK,EAAE,CAAC;IACZ,CAAC;AACF,CAAC;AAED,MAAM,UAAU,sBAAsB,CACrC,iBAA6C,EAAE;IAE/C,SAAS,CAAC,aAAa,CAAC,cAAc,CAAC,CAAC,CAAC;AAC1C,CAAC"}
|
|
@@ -0,0 +1,17 @@
|
|
|
1
|
+
import { type ProjectLibraryMetadata } from '../project.js';
|
|
2
|
+
export interface CliConfig {
|
|
3
|
+
configPath: string;
|
|
4
|
+
dbPath: string;
|
|
5
|
+
embeddedLibraryDir: string;
|
|
6
|
+
embeddedWorkflowsDir: string;
|
|
7
|
+
ergonDir: string;
|
|
8
|
+
initialized: boolean;
|
|
9
|
+
libraryDir: string;
|
|
10
|
+
projectMetadata: ProjectLibraryMetadata | null;
|
|
11
|
+
providerConfigs: Record<string, unknown>;
|
|
12
|
+
rootDir: string;
|
|
13
|
+
storageDir: string;
|
|
14
|
+
workflowsDir: string;
|
|
15
|
+
}
|
|
16
|
+
export declare function loadCliConfig(cwd?: string): CliConfig;
|
|
17
|
+
//# sourceMappingURL=index.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/config/index.ts"],"names":[],"mappings":"AACA,OAAO,EAEN,KAAK,sBAAsB,EAE3B,MAAM,eAAe,CAAC;AAEvB,MAAM,WAAW,SAAS;IACzB,UAAU,EAAE,MAAM,CAAC;IACnB,MAAM,EAAE,MAAM,CAAC;IACf,kBAAkB,EAAE,MAAM,CAAC;IAC3B,oBAAoB,EAAE,MAAM,CAAC;IAC7B,QAAQ,EAAE,MAAM,CAAC;IACjB,WAAW,EAAE,OAAO,CAAC;IACrB,UAAU,EAAE,MAAM,CAAC;IACnB,eAAe,EAAE,sBAAsB,GAAG,IAAI,CAAC;IAC/C,eAAe,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,CAAC;IACzC,OAAO,EAAE,MAAM,CAAC;IAChB,UAAU,EAAE,MAAM,CAAC;IACnB,YAAY,EAAE,MAAM,CAAC;CACrB;AAWD,wBAAgB,aAAa,CAAC,GAAG,GAAE,MAAsB,GAAG,SAAS,CAyEpE"}
|