@cogitator-ai/workflows 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/LICENSE +21 -0
- package/README.md +97 -0
- package/dist/builder.d.ts +39 -0
- package/dist/builder.d.ts.map +1 -0
- package/dist/builder.js +224 -0
- package/dist/builder.js.map +1 -0
- package/dist/checkpoint.d.ts +33 -0
- package/dist/checkpoint.d.ts.map +1 -0
- package/dist/checkpoint.js +108 -0
- package/dist/checkpoint.js.map +1 -0
- package/dist/executor.d.ts +24 -0
- package/dist/executor.d.ts.map +1 -0
- package/dist/executor.js +207 -0
- package/dist/executor.js.map +1 -0
- package/dist/human/approval-store.d.ts +95 -0
- package/dist/human/approval-store.d.ts.map +1 -0
- package/dist/human/approval-store.js +377 -0
- package/dist/human/approval-store.js.map +1 -0
- package/dist/human/human-node.d.ts +104 -0
- package/dist/human/human-node.d.ts.map +1 -0
- package/dist/human/human-node.js +342 -0
- package/dist/human/human-node.js.map +1 -0
- package/dist/human/index.d.ts +17 -0
- package/dist/human/index.d.ts.map +1 -0
- package/dist/human/index.js +17 -0
- package/dist/human/index.js.map +1 -0
- package/dist/human/notifiers.d.ts +85 -0
- package/dist/human/notifiers.d.ts.map +1 -0
- package/dist/human/notifiers.js +289 -0
- package/dist/human/notifiers.js.map +1 -0
- package/dist/index.d.ts +32 -0
- package/dist/index.d.ts.map +1 -0
- package/dist/index.js +19 -0
- package/dist/index.js.map +1 -0
- package/dist/manager/index.d.ts +19 -0
- package/dist/manager/index.d.ts.map +1 -0
- package/dist/manager/index.js +17 -0
- package/dist/manager/index.js.map +1 -0
- package/dist/manager/run-store.d.ts +78 -0
- package/dist/manager/run-store.d.ts.map +1 -0
- package/dist/manager/run-store.js +390 -0
- package/dist/manager/run-store.js.map +1 -0
- package/dist/manager/scheduler.d.ts +159 -0
- package/dist/manager/scheduler.d.ts.map +1 -0
- package/dist/manager/scheduler.js +355 -0
- package/dist/manager/scheduler.js.map +1 -0
- package/dist/manager/workflow-manager.d.ts +114 -0
- package/dist/manager/workflow-manager.d.ts.map +1 -0
- package/dist/manager/workflow-manager.js +460 -0
- package/dist/manager/workflow-manager.js.map +1 -0
- package/dist/nodes/agent.d.ts +24 -0
- package/dist/nodes/agent.d.ts.map +1 -0
- package/dist/nodes/agent.js +37 -0
- package/dist/nodes/agent.js.map +1 -0
- package/dist/nodes/base.d.ts +12 -0
- package/dist/nodes/base.d.ts.map +1 -0
- package/dist/nodes/base.js +5 -0
- package/dist/nodes/base.js.map +1 -0
- package/dist/nodes/function.d.ts +27 -0
- package/dist/nodes/function.d.ts.map +1 -0
- package/dist/nodes/function.js +29 -0
- package/dist/nodes/function.js.map +1 -0
- package/dist/nodes/index.d.ts +8 -0
- package/dist/nodes/index.d.ts.map +1 -0
- package/dist/nodes/index.js +8 -0
- package/dist/nodes/index.js.map +1 -0
- package/dist/nodes/tool.d.ts +19 -0
- package/dist/nodes/tool.d.ts.map +1 -0
- package/dist/nodes/tool.js +26 -0
- package/dist/nodes/tool.js.map +1 -0
- package/dist/observability/exporters.d.ts +93 -0
- package/dist/observability/exporters.d.ts.map +1 -0
- package/dist/observability/exporters.js +330 -0
- package/dist/observability/exporters.js.map +1 -0
- package/dist/observability/index.d.ts +17 -0
- package/dist/observability/index.d.ts.map +1 -0
- package/dist/observability/index.js +17 -0
- package/dist/observability/index.js.map +1 -0
- package/dist/observability/metrics.d.ts +114 -0
- package/dist/observability/metrics.d.ts.map +1 -0
- package/dist/observability/metrics.js +435 -0
- package/dist/observability/metrics.js.map +1 -0
- package/dist/observability/span-attributes.d.ts +95 -0
- package/dist/observability/span-attributes.d.ts.map +1 -0
- package/dist/observability/span-attributes.js +142 -0
- package/dist/observability/span-attributes.js.map +1 -0
- package/dist/observability/tracer.d.ts +110 -0
- package/dist/observability/tracer.d.ts.map +1 -0
- package/dist/observability/tracer.js +409 -0
- package/dist/observability/tracer.js.map +1 -0
- package/dist/patterns/index.d.ts +15 -0
- package/dist/patterns/index.d.ts.map +1 -0
- package/dist/patterns/index.js +15 -0
- package/dist/patterns/index.js.map +1 -0
- package/dist/patterns/map-reduce.d.ts +223 -0
- package/dist/patterns/map-reduce.d.ts.map +1 -0
- package/dist/patterns/map-reduce.js +378 -0
- package/dist/patterns/map-reduce.js.map +1 -0
- package/dist/saga/circuit-breaker.d.ts +153 -0
- package/dist/saga/circuit-breaker.d.ts.map +1 -0
- package/dist/saga/circuit-breaker.js +306 -0
- package/dist/saga/circuit-breaker.js.map +1 -0
- package/dist/saga/compensation.d.ts +134 -0
- package/dist/saga/compensation.d.ts.map +1 -0
- package/dist/saga/compensation.js +240 -0
- package/dist/saga/compensation.js.map +1 -0
- package/dist/saga/dead-letter.d.ts +113 -0
- package/dist/saga/dead-letter.d.ts.map +1 -0
- package/dist/saga/dead-letter.js +307 -0
- package/dist/saga/dead-letter.js.map +1 -0
- package/dist/saga/idempotency.d.ts +95 -0
- package/dist/saga/idempotency.d.ts.map +1 -0
- package/dist/saga/idempotency.js +266 -0
- package/dist/saga/idempotency.js.map +1 -0
- package/dist/saga/index.d.ts +16 -0
- package/dist/saga/index.d.ts.map +1 -0
- package/dist/saga/index.js +16 -0
- package/dist/saga/index.js.map +1 -0
- package/dist/saga/retry.d.ts +59 -0
- package/dist/saga/retry.d.ts.map +1 -0
- package/dist/saga/retry.js +222 -0
- package/dist/saga/retry.js.map +1 -0
- package/dist/scheduler.d.ts +37 -0
- package/dist/scheduler.d.ts.map +1 -0
- package/dist/scheduler.js +151 -0
- package/dist/scheduler.js.map +1 -0
- package/dist/subworkflows/index.d.ts +16 -0
- package/dist/subworkflows/index.d.ts.map +1 -0
- package/dist/subworkflows/index.js +16 -0
- package/dist/subworkflows/index.js.map +1 -0
- package/dist/subworkflows/parallel-subworkflows.d.ts +139 -0
- package/dist/subworkflows/parallel-subworkflows.d.ts.map +1 -0
- package/dist/subworkflows/parallel-subworkflows.js +270 -0
- package/dist/subworkflows/parallel-subworkflows.js.map +1 -0
- package/dist/subworkflows/subworkflow-node.d.ts +136 -0
- package/dist/subworkflows/subworkflow-node.d.ts.map +1 -0
- package/dist/subworkflows/subworkflow-node.js +164 -0
- package/dist/subworkflows/subworkflow-node.js.map +1 -0
- package/dist/timers/cron-parser.d.ts +110 -0
- package/dist/timers/cron-parser.d.ts.map +1 -0
- package/dist/timers/cron-parser.js +412 -0
- package/dist/timers/cron-parser.js.map +1 -0
- package/dist/timers/index.d.ts +18 -0
- package/dist/timers/index.d.ts.map +1 -0
- package/dist/timers/index.js +18 -0
- package/dist/timers/index.js.map +1 -0
- package/dist/timers/timer-manager.d.ts +219 -0
- package/dist/timers/timer-manager.d.ts.map +1 -0
- package/dist/timers/timer-manager.js +351 -0
- package/dist/timers/timer-manager.js.map +1 -0
- package/dist/timers/timer-node.d.ts +144 -0
- package/dist/timers/timer-node.d.ts.map +1 -0
- package/dist/timers/timer-node.js +246 -0
- package/dist/timers/timer-node.js.map +1 -0
- package/dist/timers/timer-store.d.ts +90 -0
- package/dist/timers/timer-store.d.ts.map +1 -0
- package/dist/timers/timer-store.js +357 -0
- package/dist/timers/timer-store.js.map +1 -0
- package/dist/triggers/cron-trigger.d.ts +102 -0
- package/dist/triggers/cron-trigger.d.ts.map +1 -0
- package/dist/triggers/cron-trigger.js +309 -0
- package/dist/triggers/cron-trigger.js.map +1 -0
- package/dist/triggers/index.d.ts +14 -0
- package/dist/triggers/index.d.ts.map +1 -0
- package/dist/triggers/index.js +10 -0
- package/dist/triggers/index.js.map +1 -0
- package/dist/triggers/rate-limiter.d.ts +130 -0
- package/dist/triggers/rate-limiter.d.ts.map +1 -0
- package/dist/triggers/rate-limiter.js +294 -0
- package/dist/triggers/rate-limiter.js.map +1 -0
- package/dist/triggers/trigger-manager.d.ts +166 -0
- package/dist/triggers/trigger-manager.d.ts.map +1 -0
- package/dist/triggers/trigger-manager.js +436 -0
- package/dist/triggers/trigger-manager.js.map +1 -0
- package/dist/triggers/webhook-trigger.d.ts +150 -0
- package/dist/triggers/webhook-trigger.d.ts.map +1 -0
- package/dist/triggers/webhook-trigger.js +452 -0
- package/dist/triggers/webhook-trigger.js.map +1 -0
- package/package.json +44 -0
package/LICENSE
ADDED
|
@@ -0,0 +1,21 @@
|
|
|
1
|
+
MIT License
|
|
2
|
+
|
|
3
|
+
Copyright (c) 2025 Cogitator Contributors
|
|
4
|
+
|
|
5
|
+
Permission is hereby granted, free of charge, to any person obtaining a copy
|
|
6
|
+
of this software and associated documentation files (the "Software"), to deal
|
|
7
|
+
in the Software without restriction, including without limitation the rights
|
|
8
|
+
to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
|
|
9
|
+
copies of the Software, and to permit persons to whom the Software is
|
|
10
|
+
furnished to do so, subject to the following conditions:
|
|
11
|
+
|
|
12
|
+
The above copyright notice and this permission notice shall be included in all
|
|
13
|
+
copies or substantial portions of the Software.
|
|
14
|
+
|
|
15
|
+
THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
|
|
16
|
+
IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
|
|
17
|
+
FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
|
|
18
|
+
AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
|
|
19
|
+
LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
|
|
20
|
+
OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
|
|
21
|
+
SOFTWARE.
|
package/README.md
ADDED
|
@@ -0,0 +1,97 @@
|
|
|
1
|
+
# @cogitator-ai/workflows
|
|
2
|
+
|
|
3
|
+
DAG-based workflow engine for Cogitator agents. Build complex multi-step workflows with branching, loops, and checkpoints.
|
|
4
|
+
|
|
5
|
+
## Installation
|
|
6
|
+
|
|
7
|
+
```bash
|
|
8
|
+
pnpm add @cogitator-ai/workflows
|
|
9
|
+
```
|
|
10
|
+
|
|
11
|
+
## Usage
|
|
12
|
+
|
|
13
|
+
### Basic Workflow
|
|
14
|
+
|
|
15
|
+
```typescript
|
|
16
|
+
import { WorkflowBuilder, WorkflowExecutor } from '@cogitator-ai/workflows';
|
|
17
|
+
|
|
18
|
+
const workflow = new WorkflowBuilder<{ count: number }>('counter')
|
|
19
|
+
.initialState({ count: 0 })
|
|
20
|
+
.addNode('increment', async (ctx) => ({
|
|
21
|
+
state: { count: ctx.state.count + 1 },
|
|
22
|
+
}))
|
|
23
|
+
.addNode('done', async (ctx) => ({
|
|
24
|
+
output: `Final count: ${ctx.state.count}`,
|
|
25
|
+
}))
|
|
26
|
+
.build();
|
|
27
|
+
|
|
28
|
+
const executor = new WorkflowExecutor(cogitator);
|
|
29
|
+
const result = await executor.execute(workflow);
|
|
30
|
+
```
|
|
31
|
+
|
|
32
|
+
### Conditional Branching
|
|
33
|
+
|
|
34
|
+
```typescript
|
|
35
|
+
const workflow = new WorkflowBuilder('approval')
|
|
36
|
+
.addNode('review', reviewNode)
|
|
37
|
+
.addConditional('check', (state) => state.approved, {
|
|
38
|
+
after: ['review'],
|
|
39
|
+
})
|
|
40
|
+
.addNode('approve', approveNode, { after: ['check:true'] })
|
|
41
|
+
.addNode('reject', rejectNode, { after: ['check:false'] })
|
|
42
|
+
.build();
|
|
43
|
+
```
|
|
44
|
+
|
|
45
|
+
### Loops
|
|
46
|
+
|
|
47
|
+
```typescript
|
|
48
|
+
const workflow = new WorkflowBuilder('retry')
|
|
49
|
+
.addNode('attempt', attemptNode)
|
|
50
|
+
.addLoop('check', {
|
|
51
|
+
condition: (state) => !state.success && state.attempts < 3,
|
|
52
|
+
back: 'attempt',
|
|
53
|
+
exit: 'done',
|
|
54
|
+
after: ['attempt'],
|
|
55
|
+
})
|
|
56
|
+
.addNode('done', doneNode)
|
|
57
|
+
.build();
|
|
58
|
+
```
|
|
59
|
+
|
|
60
|
+
### Checkpoints
|
|
61
|
+
|
|
62
|
+
Resume workflows from saved state:
|
|
63
|
+
|
|
64
|
+
```typescript
|
|
65
|
+
import { FileCheckpointStore } from '@cogitator-ai/workflows';
|
|
66
|
+
|
|
67
|
+
const store = new FileCheckpointStore('./checkpoints');
|
|
68
|
+
|
|
69
|
+
// Save checkpoint
|
|
70
|
+
await executor.execute(workflow, {
|
|
71
|
+
checkpointStore: store,
|
|
72
|
+
checkpointInterval: 5000,
|
|
73
|
+
});
|
|
74
|
+
|
|
75
|
+
// Resume from checkpoint
|
|
76
|
+
const result = await executor.resume(checkpointId, store);
|
|
77
|
+
```
|
|
78
|
+
|
|
79
|
+
### Pre-built Nodes
|
|
80
|
+
|
|
81
|
+
```typescript
|
|
82
|
+
import { agentNode, toolNode, functionNode } from '@cogitator-ai/workflows';
|
|
83
|
+
|
|
84
|
+
const workflow = new WorkflowBuilder('pipeline')
|
|
85
|
+
.addNode('analyze', agentNode(analyzerAgent))
|
|
86
|
+
.addNode('transform', toolNode('json-transform', { mapping: '...' }))
|
|
87
|
+
.addNode('validate', functionNode(async (ctx) => ({ valid: true })))
|
|
88
|
+
.build();
|
|
89
|
+
```
|
|
90
|
+
|
|
91
|
+
## Documentation
|
|
92
|
+
|
|
93
|
+
See the [Cogitator documentation](https://github.com/eL1fe/cogitator) for full API reference.
|
|
94
|
+
|
|
95
|
+
## License
|
|
96
|
+
|
|
97
|
+
MIT
|
|
@@ -0,0 +1,39 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* WorkflowBuilder - Fluent API for constructing workflows
|
|
3
|
+
*/
|
|
4
|
+
import type { Workflow, WorkflowState, NodeFn, AddNodeOptions, AddConditionalOptions, AddLoopOptions } from '@cogitator-ai/types';
|
|
5
|
+
export declare class WorkflowBuilder<S extends WorkflowState = WorkflowState> {
|
|
6
|
+
private name;
|
|
7
|
+
private state;
|
|
8
|
+
private nodes;
|
|
9
|
+
private conditionals;
|
|
10
|
+
private loops;
|
|
11
|
+
private entryPointName;
|
|
12
|
+
constructor(name: string);
|
|
13
|
+
/**
|
|
14
|
+
* Set the initial state for the workflow
|
|
15
|
+
*/
|
|
16
|
+
initialState(state: S): this;
|
|
17
|
+
/**
|
|
18
|
+
* Set explicit entry point (first node to execute)
|
|
19
|
+
*/
|
|
20
|
+
entryPoint(nodeName: string): this;
|
|
21
|
+
/**
|
|
22
|
+
* Add a node to the workflow
|
|
23
|
+
*/
|
|
24
|
+
addNode(name: string, fn: NodeFn<S>, options?: AddNodeOptions): this;
|
|
25
|
+
/**
|
|
26
|
+
* Add a conditional routing node
|
|
27
|
+
*/
|
|
28
|
+
addConditional(name: string, condition: (state: S) => string | string[], options?: AddConditionalOptions): this;
|
|
29
|
+
/**
|
|
30
|
+
* Add a loop construct
|
|
31
|
+
*/
|
|
32
|
+
addLoop(name: string, options: AddLoopOptions): this;
|
|
33
|
+
/**
|
|
34
|
+
* Build and validate the workflow
|
|
35
|
+
*/
|
|
36
|
+
build(): Workflow<S>;
|
|
37
|
+
private validate;
|
|
38
|
+
}
|
|
39
|
+
//# sourceMappingURL=builder.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"builder.d.ts","sourceRoot":"","sources":["../src/builder.ts"],"names":[],"mappings":"AAAA;;GAEG;AAEH,OAAO,KAAK,EACV,QAAQ,EAER,aAAa,EACb,MAAM,EAEN,cAAc,EACd,qBAAqB,EACrB,cAAc,EAEf,MAAM,qBAAqB,CAAC;AAuB7B,qBAAa,eAAe,CAAC,CAAC,SAAS,aAAa,GAAG,aAAa;IAClE,OAAO,CAAC,IAAI,CAAS;IACrB,OAAO,CAAC,KAAK,CAAI;IACjB,OAAO,CAAC,KAAK,CAAyB;IACtC,OAAO,CAAC,YAAY,CAAgC;IACpD,OAAO,CAAC,KAAK,CAAyB;IACtC,OAAO,CAAC,cAAc,CAAuB;gBAEjC,IAAI,EAAE,MAAM;IAKxB;;OAEG;IACH,YAAY,CAAC,KAAK,EAAE,CAAC,GAAG,IAAI;IAK5B;;OAEG;IACH,UAAU,CAAC,QAAQ,EAAE,MAAM,GAAG,IAAI;IAKlC;;OAEG;IACH,OAAO,CAAC,IAAI,EAAE,MAAM,EAAE,EAAE,EAAE,MAAM,CAAC,CAAC,CAAC,EAAE,OAAO,CAAC,EAAE,cAAc,GAAG,IAAI;IAUpE;;OAEG;IACH,cAAc,CACZ,IAAI,EAAE,MAAM,EACZ,SAAS,EAAE,CAAC,KAAK,EAAE,CAAC,KAAK,MAAM,GAAG,MAAM,EAAE,EAC1C,OAAO,CAAC,EAAE,qBAAqB,GAC9B,IAAI;IASP;;OAEG;IACH,OAAO,CAAC,IAAI,EAAE,MAAM,EAAE,OAAO,EAAE,cAAc,GAAG,IAAI;IAWpD;;OAEG;IACH,KAAK,IAAI,QAAQ,CAAC,CAAC,CAAC;IAuIpB,OAAO,CAAC,QAAQ;CAwCjB"}
|
package/dist/builder.js
ADDED
|
@@ -0,0 +1,224 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* WorkflowBuilder - Fluent API for constructing workflows
|
|
3
|
+
*/
|
|
4
|
+
export class WorkflowBuilder {
|
|
5
|
+
name;
|
|
6
|
+
state;
|
|
7
|
+
nodes = [];
|
|
8
|
+
conditionals = [];
|
|
9
|
+
loops = [];
|
|
10
|
+
entryPointName = null;
|
|
11
|
+
constructor(name) {
|
|
12
|
+
this.name = name;
|
|
13
|
+
this.state = {};
|
|
14
|
+
}
|
|
15
|
+
/**
|
|
16
|
+
* Set the initial state for the workflow
|
|
17
|
+
*/
|
|
18
|
+
initialState(state) {
|
|
19
|
+
this.state = state;
|
|
20
|
+
return this;
|
|
21
|
+
}
|
|
22
|
+
/**
|
|
23
|
+
* Set explicit entry point (first node to execute)
|
|
24
|
+
*/
|
|
25
|
+
entryPoint(nodeName) {
|
|
26
|
+
this.entryPointName = nodeName;
|
|
27
|
+
return this;
|
|
28
|
+
}
|
|
29
|
+
/**
|
|
30
|
+
* Add a node to the workflow
|
|
31
|
+
*/
|
|
32
|
+
addNode(name, fn, options) {
|
|
33
|
+
this.nodes.push({
|
|
34
|
+
name,
|
|
35
|
+
fn,
|
|
36
|
+
config: options?.config,
|
|
37
|
+
after: options?.after ?? [],
|
|
38
|
+
});
|
|
39
|
+
return this;
|
|
40
|
+
}
|
|
41
|
+
/**
|
|
42
|
+
* Add a conditional routing node
|
|
43
|
+
*/
|
|
44
|
+
addConditional(name, condition, options) {
|
|
45
|
+
this.conditionals.push({
|
|
46
|
+
name,
|
|
47
|
+
condition,
|
|
48
|
+
after: options?.after ?? [],
|
|
49
|
+
});
|
|
50
|
+
return this;
|
|
51
|
+
}
|
|
52
|
+
/**
|
|
53
|
+
* Add a loop construct
|
|
54
|
+
*/
|
|
55
|
+
addLoop(name, options) {
|
|
56
|
+
this.loops.push({
|
|
57
|
+
name,
|
|
58
|
+
condition: options.condition,
|
|
59
|
+
back: options.back,
|
|
60
|
+
exit: options.exit,
|
|
61
|
+
after: options.after ?? [],
|
|
62
|
+
});
|
|
63
|
+
return this;
|
|
64
|
+
}
|
|
65
|
+
/**
|
|
66
|
+
* Build and validate the workflow
|
|
67
|
+
*/
|
|
68
|
+
build() {
|
|
69
|
+
const nodesMap = new Map();
|
|
70
|
+
for (const node of this.nodes) {
|
|
71
|
+
nodesMap.set(node.name, {
|
|
72
|
+
name: node.name,
|
|
73
|
+
fn: node.fn,
|
|
74
|
+
config: node.config,
|
|
75
|
+
});
|
|
76
|
+
}
|
|
77
|
+
for (const cond of this.conditionals) {
|
|
78
|
+
nodesMap.set(cond.name, {
|
|
79
|
+
name: cond.name,
|
|
80
|
+
fn: async (ctx) => ({ output: ctx.state }),
|
|
81
|
+
config: undefined,
|
|
82
|
+
});
|
|
83
|
+
}
|
|
84
|
+
for (const loop of this.loops) {
|
|
85
|
+
nodesMap.set(loop.name, {
|
|
86
|
+
name: loop.name,
|
|
87
|
+
fn: async (ctx) => ({ output: ctx.state }),
|
|
88
|
+
config: undefined,
|
|
89
|
+
});
|
|
90
|
+
}
|
|
91
|
+
const edges = [];
|
|
92
|
+
const conditionalNames = new Set(this.conditionals.map((c) => c.name));
|
|
93
|
+
const loopNames = new Set(this.loops.map((l) => l.name));
|
|
94
|
+
for (const node of this.nodes) {
|
|
95
|
+
for (const dep of node.after) {
|
|
96
|
+
if (conditionalNames.has(dep) || loopNames.has(dep)) {
|
|
97
|
+
continue;
|
|
98
|
+
}
|
|
99
|
+
edges.push({
|
|
100
|
+
type: 'sequential',
|
|
101
|
+
from: dep,
|
|
102
|
+
to: node.name,
|
|
103
|
+
});
|
|
104
|
+
}
|
|
105
|
+
}
|
|
106
|
+
for (const cond of this.conditionals) {
|
|
107
|
+
for (const dep of cond.after) {
|
|
108
|
+
edges.push({
|
|
109
|
+
type: 'sequential',
|
|
110
|
+
from: dep,
|
|
111
|
+
to: cond.name,
|
|
112
|
+
});
|
|
113
|
+
}
|
|
114
|
+
const targets = [];
|
|
115
|
+
for (const node of this.nodes) {
|
|
116
|
+
if (node.after.includes(cond.name)) {
|
|
117
|
+
targets.push(node.name);
|
|
118
|
+
}
|
|
119
|
+
}
|
|
120
|
+
if (targets.length > 0) {
|
|
121
|
+
edges.push({
|
|
122
|
+
type: 'conditional',
|
|
123
|
+
from: cond.name,
|
|
124
|
+
condition: cond.condition,
|
|
125
|
+
targets,
|
|
126
|
+
});
|
|
127
|
+
}
|
|
128
|
+
}
|
|
129
|
+
for (const loop of this.loops) {
|
|
130
|
+
for (const dep of loop.after) {
|
|
131
|
+
edges.push({
|
|
132
|
+
type: 'sequential',
|
|
133
|
+
from: dep,
|
|
134
|
+
to: loop.name,
|
|
135
|
+
});
|
|
136
|
+
}
|
|
137
|
+
edges.push({
|
|
138
|
+
type: 'loop',
|
|
139
|
+
from: loop.name,
|
|
140
|
+
condition: loop.condition,
|
|
141
|
+
back: loop.back,
|
|
142
|
+
exit: loop.exit,
|
|
143
|
+
});
|
|
144
|
+
}
|
|
145
|
+
let entryPoint = this.entryPointName;
|
|
146
|
+
if (!entryPoint) {
|
|
147
|
+
const allDeps = new Set();
|
|
148
|
+
for (const node of this.nodes) {
|
|
149
|
+
for (const dep of node.after) {
|
|
150
|
+
allDeps.add(dep);
|
|
151
|
+
}
|
|
152
|
+
}
|
|
153
|
+
for (const cond of this.conditionals) {
|
|
154
|
+
for (const dep of cond.after) {
|
|
155
|
+
allDeps.add(dep);
|
|
156
|
+
}
|
|
157
|
+
}
|
|
158
|
+
const roots = [];
|
|
159
|
+
for (const node of this.nodes) {
|
|
160
|
+
if (node.after.length === 0 && !allDeps.has(node.name)) {
|
|
161
|
+
roots.push(node.name);
|
|
162
|
+
}
|
|
163
|
+
}
|
|
164
|
+
if (roots.length === 0) {
|
|
165
|
+
entryPoint = this.nodes[0]?.name;
|
|
166
|
+
}
|
|
167
|
+
else if (roots.length === 1) {
|
|
168
|
+
entryPoint = roots[0];
|
|
169
|
+
}
|
|
170
|
+
else {
|
|
171
|
+
entryPoint = roots[0];
|
|
172
|
+
}
|
|
173
|
+
}
|
|
174
|
+
if (!entryPoint) {
|
|
175
|
+
throw new Error('Workflow has no nodes');
|
|
176
|
+
}
|
|
177
|
+
this.validate(nodesMap, edges, entryPoint);
|
|
178
|
+
return {
|
|
179
|
+
name: this.name,
|
|
180
|
+
initialState: this.state,
|
|
181
|
+
nodes: nodesMap,
|
|
182
|
+
edges,
|
|
183
|
+
entryPoint,
|
|
184
|
+
};
|
|
185
|
+
}
|
|
186
|
+
validate(nodes, edges, entryPoint) {
|
|
187
|
+
if (!nodes.has(entryPoint)) {
|
|
188
|
+
throw new Error(`Entry point '${entryPoint}' not found in nodes`);
|
|
189
|
+
}
|
|
190
|
+
for (const edge of edges) {
|
|
191
|
+
if (!nodes.has(edge.from)) {
|
|
192
|
+
throw new Error(`Edge references unknown node '${edge.from}'`);
|
|
193
|
+
}
|
|
194
|
+
if (edge.type === 'sequential') {
|
|
195
|
+
if (!nodes.has(edge.to)) {
|
|
196
|
+
throw new Error(`Edge references unknown node '${edge.to}'`);
|
|
197
|
+
}
|
|
198
|
+
}
|
|
199
|
+
else if (edge.type === 'parallel') {
|
|
200
|
+
for (const to of edge.to) {
|
|
201
|
+
if (!nodes.has(to)) {
|
|
202
|
+
throw new Error(`Edge references unknown node '${to}'`);
|
|
203
|
+
}
|
|
204
|
+
}
|
|
205
|
+
}
|
|
206
|
+
else if (edge.type === 'conditional') {
|
|
207
|
+
for (const target of edge.targets) {
|
|
208
|
+
if (!nodes.has(target)) {
|
|
209
|
+
throw new Error(`Conditional references unknown node '${target}'`);
|
|
210
|
+
}
|
|
211
|
+
}
|
|
212
|
+
}
|
|
213
|
+
else if (edge.type === 'loop') {
|
|
214
|
+
if (!nodes.has(edge.back)) {
|
|
215
|
+
throw new Error(`Loop references unknown back node '${edge.back}'`);
|
|
216
|
+
}
|
|
217
|
+
if (!nodes.has(edge.exit)) {
|
|
218
|
+
throw new Error(`Loop references unknown exit node '${edge.exit}'`);
|
|
219
|
+
}
|
|
220
|
+
}
|
|
221
|
+
}
|
|
222
|
+
}
|
|
223
|
+
}
|
|
224
|
+
//# sourceMappingURL=builder.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"builder.js","sourceRoot":"","sources":["../src/builder.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,33 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Checkpoint stores for workflow resume support
|
|
3
|
+
*/
|
|
4
|
+
import type { WorkflowCheckpoint, CheckpointStore } from '@cogitator-ai/types';
|
|
5
|
+
/**
|
|
6
|
+
* In-memory checkpoint store (for testing and short-lived workflows)
|
|
7
|
+
*/
|
|
8
|
+
export declare class InMemoryCheckpointStore implements CheckpointStore {
|
|
9
|
+
private checkpoints;
|
|
10
|
+
save(checkpoint: WorkflowCheckpoint): Promise<void>;
|
|
11
|
+
load(id: string): Promise<WorkflowCheckpoint | null>;
|
|
12
|
+
list(workflowName: string): Promise<WorkflowCheckpoint[]>;
|
|
13
|
+
delete(id: string): Promise<void>;
|
|
14
|
+
clear(): void;
|
|
15
|
+
}
|
|
16
|
+
/**
|
|
17
|
+
* File-based checkpoint store (persists to disk)
|
|
18
|
+
*/
|
|
19
|
+
export declare class FileCheckpointStore implements CheckpointStore {
|
|
20
|
+
private directory;
|
|
21
|
+
constructor(directory?: string);
|
|
22
|
+
private ensureDirectory;
|
|
23
|
+
private getFilePath;
|
|
24
|
+
save(checkpoint: WorkflowCheckpoint): Promise<void>;
|
|
25
|
+
load(id: string): Promise<WorkflowCheckpoint | null>;
|
|
26
|
+
list(workflowName: string): Promise<WorkflowCheckpoint[]>;
|
|
27
|
+
delete(id: string): Promise<void>;
|
|
28
|
+
}
|
|
29
|
+
/**
|
|
30
|
+
* Create a new checkpoint ID
|
|
31
|
+
*/
|
|
32
|
+
export declare function createCheckpointId(): string;
|
|
33
|
+
//# sourceMappingURL=checkpoint.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"checkpoint.d.ts","sourceRoot":"","sources":["../src/checkpoint.ts"],"names":[],"mappings":"AAAA;;GAEG;AAEH,OAAO,KAAK,EAAE,kBAAkB,EAAE,eAAe,EAAE,MAAM,qBAAqB,CAAC;AAK/E;;GAEG;AACH,qBAAa,uBAAwB,YAAW,eAAe;IAC7D,OAAO,CAAC,WAAW,CAAyC;IAEtD,IAAI,CAAC,UAAU,EAAE,kBAAkB,GAAG,OAAO,CAAC,IAAI,CAAC;IAInD,IAAI,CAAC,EAAE,EAAE,MAAM,GAAG,OAAO,CAAC,kBAAkB,GAAG,IAAI,CAAC;IAKpD,IAAI,CAAC,YAAY,EAAE,MAAM,GAAG,OAAO,CAAC,kBAAkB,EAAE,CAAC;IAUzD,MAAM,CAAC,EAAE,EAAE,MAAM,GAAG,OAAO,CAAC,IAAI,CAAC;IAIvC,KAAK,IAAI,IAAI;CAGd;AAED;;GAEG;AACH,qBAAa,mBAAoB,YAAW,eAAe;IACzD,OAAO,CAAC,SAAS,CAAS;gBAEd,SAAS,CAAC,EAAE,MAAM;YAIhB,eAAe;IAO7B,OAAO,CAAC,WAAW;IAIb,IAAI,CAAC,UAAU,EAAE,kBAAkB,GAAG,OAAO,CAAC,IAAI,CAAC;IAMnD,IAAI,CAAC,EAAE,EAAE,MAAM,GAAG,OAAO,CAAC,kBAAkB,GAAG,IAAI,CAAC;IAUpD,IAAI,CAAC,YAAY,EAAE,MAAM,GAAG,OAAO,CAAC,kBAAkB,EAAE,CAAC;IA2BzD,MAAM,CAAC,EAAE,EAAE,MAAM,GAAG,OAAO,CAAC,IAAI,CAAC;CAOxC;AAED;;GAEG;AACH,wBAAgB,kBAAkB,IAAI,MAAM,CAE3C"}
|
|
@@ -0,0 +1,108 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Checkpoint stores for workflow resume support
|
|
3
|
+
*/
|
|
4
|
+
import { nanoid } from 'nanoid';
|
|
5
|
+
import * as fs from 'node:fs/promises';
|
|
6
|
+
import * as path from 'node:path';
|
|
7
|
+
/**
|
|
8
|
+
* In-memory checkpoint store (for testing and short-lived workflows)
|
|
9
|
+
*/
|
|
10
|
+
export class InMemoryCheckpointStore {
|
|
11
|
+
checkpoints = new Map();
|
|
12
|
+
async save(checkpoint) {
|
|
13
|
+
this.checkpoints.set(checkpoint.id, { ...checkpoint });
|
|
14
|
+
}
|
|
15
|
+
async load(id) {
|
|
16
|
+
const checkpoint = this.checkpoints.get(id);
|
|
17
|
+
return checkpoint ? { ...checkpoint } : null;
|
|
18
|
+
}
|
|
19
|
+
async list(workflowName) {
|
|
20
|
+
const result = [];
|
|
21
|
+
for (const checkpoint of this.checkpoints.values()) {
|
|
22
|
+
if (checkpoint.workflowName === workflowName) {
|
|
23
|
+
result.push({ ...checkpoint });
|
|
24
|
+
}
|
|
25
|
+
}
|
|
26
|
+
return result.sort((a, b) => b.timestamp - a.timestamp);
|
|
27
|
+
}
|
|
28
|
+
async delete(id) {
|
|
29
|
+
this.checkpoints.delete(id);
|
|
30
|
+
}
|
|
31
|
+
clear() {
|
|
32
|
+
this.checkpoints.clear();
|
|
33
|
+
}
|
|
34
|
+
}
|
|
35
|
+
/**
|
|
36
|
+
* File-based checkpoint store (persists to disk)
|
|
37
|
+
*/
|
|
38
|
+
export class FileCheckpointStore {
|
|
39
|
+
directory;
|
|
40
|
+
constructor(directory) {
|
|
41
|
+
this.directory = directory ?? '.cogitator/checkpoints';
|
|
42
|
+
}
|
|
43
|
+
async ensureDirectory() {
|
|
44
|
+
try {
|
|
45
|
+
await fs.mkdir(this.directory, { recursive: true });
|
|
46
|
+
}
|
|
47
|
+
catch {
|
|
48
|
+
}
|
|
49
|
+
}
|
|
50
|
+
getFilePath(id) {
|
|
51
|
+
return path.join(this.directory, `${id}.json`);
|
|
52
|
+
}
|
|
53
|
+
async save(checkpoint) {
|
|
54
|
+
await this.ensureDirectory();
|
|
55
|
+
const filePath = this.getFilePath(checkpoint.id);
|
|
56
|
+
await fs.writeFile(filePath, JSON.stringify(checkpoint, null, 2), 'utf-8');
|
|
57
|
+
}
|
|
58
|
+
async load(id) {
|
|
59
|
+
try {
|
|
60
|
+
const filePath = this.getFilePath(id);
|
|
61
|
+
const content = await fs.readFile(filePath, 'utf-8');
|
|
62
|
+
return JSON.parse(content);
|
|
63
|
+
}
|
|
64
|
+
catch {
|
|
65
|
+
return null;
|
|
66
|
+
}
|
|
67
|
+
}
|
|
68
|
+
async list(workflowName) {
|
|
69
|
+
await this.ensureDirectory();
|
|
70
|
+
try {
|
|
71
|
+
const files = await fs.readdir(this.directory);
|
|
72
|
+
const checkpoints = [];
|
|
73
|
+
for (const file of files) {
|
|
74
|
+
if (!file.endsWith('.json'))
|
|
75
|
+
continue;
|
|
76
|
+
const filePath = path.join(this.directory, file);
|
|
77
|
+
try {
|
|
78
|
+
const content = await fs.readFile(filePath, 'utf-8');
|
|
79
|
+
const checkpoint = JSON.parse(content);
|
|
80
|
+
if (checkpoint.workflowName === workflowName) {
|
|
81
|
+
checkpoints.push(checkpoint);
|
|
82
|
+
}
|
|
83
|
+
}
|
|
84
|
+
catch {
|
|
85
|
+
}
|
|
86
|
+
}
|
|
87
|
+
return checkpoints.sort((a, b) => b.timestamp - a.timestamp);
|
|
88
|
+
}
|
|
89
|
+
catch {
|
|
90
|
+
return [];
|
|
91
|
+
}
|
|
92
|
+
}
|
|
93
|
+
async delete(id) {
|
|
94
|
+
try {
|
|
95
|
+
const filePath = this.getFilePath(id);
|
|
96
|
+
await fs.unlink(filePath);
|
|
97
|
+
}
|
|
98
|
+
catch {
|
|
99
|
+
}
|
|
100
|
+
}
|
|
101
|
+
}
|
|
102
|
+
/**
|
|
103
|
+
* Create a new checkpoint ID
|
|
104
|
+
*/
|
|
105
|
+
export function createCheckpointId() {
|
|
106
|
+
return `ckpt_${nanoid(12)}`;
|
|
107
|
+
}
|
|
108
|
+
//# sourceMappingURL=checkpoint.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"checkpoint.js","sourceRoot":"","sources":["../src/checkpoint.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,24 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* WorkflowExecutor - Main execution engine for workflows
|
|
3
|
+
*/
|
|
4
|
+
import type { Workflow, WorkflowState, WorkflowResult, WorkflowExecuteOptions, WorkflowEvent, CheckpointStore } from '@cogitator-ai/types';
|
|
5
|
+
import type { Cogitator } from '@cogitator-ai/core';
|
|
6
|
+
export declare class WorkflowExecutor {
|
|
7
|
+
private cogitator;
|
|
8
|
+
private checkpointStore;
|
|
9
|
+
private scheduler;
|
|
10
|
+
constructor(cogitator: Cogitator, checkpointStore?: CheckpointStore);
|
|
11
|
+
/**
|
|
12
|
+
* Execute a workflow
|
|
13
|
+
*/
|
|
14
|
+
execute<S extends WorkflowState>(workflow: Workflow<S>, input?: Partial<S>, options?: WorkflowExecuteOptions): Promise<WorkflowResult<S>>;
|
|
15
|
+
/**
|
|
16
|
+
* Resume a workflow from a checkpoint
|
|
17
|
+
*/
|
|
18
|
+
resume<S extends WorkflowState>(workflow: Workflow<S>, checkpointId: string, options?: WorkflowExecuteOptions): Promise<WorkflowResult<S>>;
|
|
19
|
+
/**
|
|
20
|
+
* Stream workflow execution events
|
|
21
|
+
*/
|
|
22
|
+
stream<S extends WorkflowState>(workflow: Workflow<S>, input?: Partial<S>, options?: Omit<WorkflowExecuteOptions, 'onNodeStart' | 'onNodeComplete' | 'onNodeError'>): AsyncIterable<WorkflowEvent>;
|
|
23
|
+
}
|
|
24
|
+
//# sourceMappingURL=executor.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"executor.d.ts","sourceRoot":"","sources":["../src/executor.ts"],"names":[],"mappings":"AAAA;;GAEG;AAEH,OAAO,KAAK,EACV,QAAQ,EACR,aAAa,EACb,cAAc,EACd,sBAAsB,EACtB,aAAa,EACb,eAAe,EAEhB,MAAM,qBAAqB,CAAC;AAC7B,OAAO,KAAK,EAAE,SAAS,EAAE,MAAM,oBAAoB,CAAC;AAQpD,qBAAa,gBAAgB;IAC3B,OAAO,CAAC,SAAS,CAAY;IAC7B,OAAO,CAAC,eAAe,CAAkB;IACzC,OAAO,CAAC,SAAS,CAAoB;gBAEzB,SAAS,EAAE,SAAS,EAAE,eAAe,CAAC,EAAE,eAAe;IAMnE;;OAEG;IACG,OAAO,CAAC,CAAC,SAAS,aAAa,EACnC,QAAQ,EAAE,QAAQ,CAAC,CAAC,CAAC,EACrB,KAAK,CAAC,EAAE,OAAO,CAAC,CAAC,CAAC,EAClB,OAAO,CAAC,EAAE,sBAAsB,GAC/B,OAAO,CAAC,cAAc,CAAC,CAAC,CAAC,CAAC;IA8I7B;;OAEG;IACG,MAAM,CAAC,CAAC,SAAS,aAAa,EAClC,QAAQ,EAAE,QAAQ,CAAC,CAAC,CAAC,EACrB,YAAY,EAAE,MAAM,EACpB,OAAO,CAAC,EAAE,sBAAsB,GAC/B,OAAO,CAAC,cAAc,CAAC,CAAC,CAAC,CAAC;IAsC7B;;OAEG;IACI,MAAM,CAAC,CAAC,SAAS,aAAa,EACnC,QAAQ,EAAE,QAAQ,CAAC,CAAC,CAAC,EACrB,KAAK,CAAC,EAAE,OAAO,CAAC,CAAC,CAAC,EAClB,OAAO,CAAC,EAAE,IAAI,CAAC,sBAAsB,EAAE,aAAa,GAAG,gBAAgB,GAAG,aAAa,CAAC,GACvF,aAAa,CAAC,aAAa,CAAC;CAiDhC"}
|