@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.
Files changed (72) hide show
  1. package/LICENSE +1 -0
  2. package/README.md +20 -0
  3. package/dist/commands/approve.d.ts +14 -0
  4. package/dist/commands/approve.d.ts.map +1 -0
  5. package/dist/commands/approve.js +60 -0
  6. package/dist/commands/approve.js.map +1 -0
  7. package/dist/commands/cancel.d.ts +7 -0
  8. package/dist/commands/cancel.d.ts.map +1 -0
  9. package/dist/commands/cancel.js +27 -0
  10. package/dist/commands/cancel.js.map +1 -0
  11. package/dist/commands/init.d.ts +10 -0
  12. package/dist/commands/init.d.ts.map +1 -0
  13. package/dist/commands/init.js +16 -0
  14. package/dist/commands/init.js.map +1 -0
  15. package/dist/commands/library.d.ts +7 -0
  16. package/dist/commands/library.d.ts.map +1 -0
  17. package/dist/commands/library.js +12 -0
  18. package/dist/commands/library.js.map +1 -0
  19. package/dist/commands/run.d.ts +18 -0
  20. package/dist/commands/run.d.ts.map +1 -0
  21. package/dist/commands/run.js +82 -0
  22. package/dist/commands/run.js.map +1 -0
  23. package/dist/commands/template.d.ts +13 -0
  24. package/dist/commands/template.d.ts.map +1 -0
  25. package/dist/commands/template.js +42 -0
  26. package/dist/commands/template.js.map +1 -0
  27. package/dist/commands/worker.d.ts +15 -0
  28. package/dist/commands/worker.d.ts.map +1 -0
  29. package/dist/commands/worker.js +108 -0
  30. package/dist/commands/worker.js.map +1 -0
  31. package/dist/commands/workflow.d.ts +8 -0
  32. package/dist/commands/workflow.d.ts.map +1 -0
  33. package/dist/commands/workflow.js +34 -0
  34. package/dist/commands/workflow.js.map +1 -0
  35. package/dist/config/index.d.ts +17 -0
  36. package/dist/config/index.d.ts.map +1 -0
  37. package/dist/config/index.js +76 -0
  38. package/dist/config/index.js.map +1 -0
  39. package/dist/help.d.ts +3 -0
  40. package/dist/help.d.ts.map +1 -0
  41. package/dist/help.js +45 -0
  42. package/dist/help.js.map +1 -0
  43. package/dist/library/agents/coder.yaml +27 -0
  44. package/dist/library/agents/pr-writer.yaml +28 -0
  45. package/dist/library/agents/repo-analyzer.yaml +31 -0
  46. package/dist/library/agents/repo-planner.yaml +35 -0
  47. package/dist/library/schemas/agent.analysis.v1.json +51 -0
  48. package/dist/library/schemas/agent.patch.v1.json +57 -0
  49. package/dist/library/schemas/agent.plan.v1.json +71 -0
  50. package/dist/library/schemas/agent.pr.v1.json +54 -0
  51. package/dist/library/workflows/code.bump_deps.yaml +268 -0
  52. package/dist/library/workflows/code.codegen.yaml +256 -0
  53. package/dist/library/workflows/code.docs_update.yaml +252 -0
  54. package/dist/library/workflows/code.hotfix.yaml +264 -0
  55. package/dist/library/workflows/code.refactor.yaml +256 -0
  56. package/dist/main.d.ts +3 -0
  57. package/dist/main.d.ts.map +1 -0
  58. package/dist/main.js +86 -0
  59. package/dist/main.js.map +1 -0
  60. package/dist/output/format.d.ts +2 -0
  61. package/dist/output/format.d.ts.map +1 -0
  62. package/dist/output/format.js +4 -0
  63. package/dist/output/format.js.map +1 -0
  64. package/dist/project.d.ts +42 -0
  65. package/dist/project.d.ts.map +1 -0
  66. package/dist/project.js +229 -0
  67. package/dist/project.js.map +1 -0
  68. package/dist/utils.d.ts +7 -0
  69. package/dist/utils.d.ts.map +1 -0
  70. package/dist/utils.js +39 -0
  71. package/dist/utils.js.map +1 -0
  72. 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"}