condukt 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/dist/bridge/bridge.d.ts +34 -0
- package/dist/bridge/bridge.d.ts.map +1 -0
- package/dist/bridge/bridge.js +365 -0
- package/dist/bridge/bridge.js.map +1 -0
- package/dist/bridge/index.d.ts +3 -0
- package/dist/bridge/index.d.ts.map +1 -0
- package/dist/bridge/index.js +6 -0
- package/dist/bridge/index.js.map +1 -0
- package/dist/runtimes/copilot/copilot-adapter.d.ts +28 -0
- package/dist/runtimes/copilot/copilot-adapter.d.ts.map +1 -0
- package/dist/runtimes/copilot/copilot-adapter.js +50 -0
- package/dist/runtimes/copilot/copilot-adapter.js.map +1 -0
- package/dist/runtimes/copilot/copilot-backend.d.ts +49 -0
- package/dist/runtimes/copilot/copilot-backend.d.ts.map +1 -0
- package/dist/runtimes/copilot/copilot-backend.js +13 -0
- package/dist/runtimes/copilot/copilot-backend.js.map +1 -0
- package/dist/runtimes/copilot/index.d.ts +5 -0
- package/dist/runtimes/copilot/index.d.ts.map +1 -0
- package/dist/runtimes/copilot/index.js +11 -0
- package/dist/runtimes/copilot/index.js.map +1 -0
- package/dist/runtimes/copilot/process-killer.d.ts +13 -0
- package/dist/runtimes/copilot/process-killer.d.ts.map +1 -0
- package/dist/runtimes/copilot/process-killer.js +77 -0
- package/dist/runtimes/copilot/process-killer.js.map +1 -0
- package/dist/runtimes/copilot/subprocess-backend.d.ts +26 -0
- package/dist/runtimes/copilot/subprocess-backend.d.ts.map +1 -0
- package/dist/runtimes/copilot/subprocess-backend.js +308 -0
- package/dist/runtimes/copilot/subprocess-backend.js.map +1 -0
- package/dist/runtimes/mock/index.d.ts +3 -0
- package/dist/runtimes/mock/index.d.ts.map +1 -0
- package/dist/runtimes/mock/index.js +6 -0
- package/dist/runtimes/mock/index.js.map +1 -0
- package/dist/runtimes/mock/mock-runtime.d.ts +43 -0
- package/dist/runtimes/mock/mock-runtime.d.ts.map +1 -0
- package/dist/runtimes/mock/mock-runtime.js +153 -0
- package/dist/runtimes/mock/mock-runtime.js.map +1 -0
- package/dist/src/agent.d.ts +35 -0
- package/dist/src/agent.d.ts.map +1 -0
- package/dist/src/agent.js +257 -0
- package/dist/src/agent.js.map +1 -0
- package/dist/src/events.d.ts +153 -0
- package/dist/src/events.d.ts.map +1 -0
- package/dist/src/events.js +11 -0
- package/dist/src/events.js.map +1 -0
- package/dist/src/index.d.ts +8 -0
- package/dist/src/index.d.ts.map +1 -0
- package/dist/src/index.js +24 -0
- package/dist/src/index.js.map +1 -0
- package/dist/src/nodes.d.ts +63 -0
- package/dist/src/nodes.d.ts.map +1 -0
- package/dist/src/nodes.js +120 -0
- package/dist/src/nodes.js.map +1 -0
- package/dist/src/scheduler.d.ts +11 -0
- package/dist/src/scheduler.d.ts.map +1 -0
- package/dist/src/scheduler.js +478 -0
- package/dist/src/scheduler.js.map +1 -0
- package/dist/src/types.d.ts +201 -0
- package/dist/src/types.d.ts.map +1 -0
- package/dist/src/types.js +38 -0
- package/dist/src/types.js.map +1 -0
- package/dist/src/verify.d.ts +51 -0
- package/dist/src/verify.d.ts.map +1 -0
- package/dist/src/verify.js +126 -0
- package/dist/src/verify.js.map +1 -0
- package/dist/state/index.d.ts +5 -0
- package/dist/state/index.d.ts.map +1 -0
- package/dist/state/index.js +14 -0
- package/dist/state/index.js.map +1 -0
- package/dist/state/reducer.d.ts +11 -0
- package/dist/state/reducer.d.ts.map +1 -0
- package/dist/state/reducer.js +223 -0
- package/dist/state/reducer.js.map +1 -0
- package/dist/state/state-runtime.d.ts +30 -0
- package/dist/state/state-runtime.d.ts.map +1 -0
- package/dist/state/state-runtime.js +131 -0
- package/dist/state/state-runtime.js.map +1 -0
- package/dist/state/storage-memory.d.ts +24 -0
- package/dist/state/storage-memory.d.ts.map +1 -0
- package/dist/state/storage-memory.js +91 -0
- package/dist/state/storage-memory.js.map +1 -0
- package/dist/state/storage.d.ts +29 -0
- package/dist/state/storage.d.ts.map +1 -0
- package/dist/state/storage.js +175 -0
- package/dist/state/storage.js.map +1 -0
- package/dist/theme/index.d.ts +128 -0
- package/dist/theme/index.d.ts.map +1 -0
- package/dist/theme/index.js +59 -0
- package/dist/theme/index.js.map +1 -0
- package/dist/ui/ansi.d.ts +9 -0
- package/dist/ui/ansi.d.ts.map +1 -0
- package/dist/ui/ansi.js +78 -0
- package/dist/ui/ansi.js.map +1 -0
- package/dist/ui/components/FlowEdge.d.ts +5 -0
- package/dist/ui/components/FlowEdge.d.ts.map +1 -0
- package/dist/ui/components/FlowEdge.js +33 -0
- package/dist/ui/components/FlowEdge.js.map +1 -0
- package/dist/ui/components/FlowGraph.d.ts +10 -0
- package/dist/ui/components/FlowGraph.d.ts.map +1 -0
- package/dist/ui/components/FlowGraph.js +124 -0
- package/dist/ui/components/FlowGraph.js.map +1 -0
- package/dist/ui/components/FlowStatusBar.d.ts +7 -0
- package/dist/ui/components/FlowStatusBar.d.ts.map +1 -0
- package/dist/ui/components/FlowStatusBar.js +27 -0
- package/dist/ui/components/FlowStatusBar.js.map +1 -0
- package/dist/ui/components/MiniPipeline.d.ts +10 -0
- package/dist/ui/components/MiniPipeline.d.ts.map +1 -0
- package/dist/ui/components/MiniPipeline.js +155 -0
- package/dist/ui/components/MiniPipeline.js.map +1 -0
- package/dist/ui/components/NodeCard.d.ts +5 -0
- package/dist/ui/components/NodeCard.d.ts.map +1 -0
- package/dist/ui/components/NodeCard.js +39 -0
- package/dist/ui/components/NodeCard.js.map +1 -0
- package/dist/ui/components/NodeDetailPanel.d.ts +10 -0
- package/dist/ui/components/NodeDetailPanel.d.ts.map +1 -0
- package/dist/ui/components/NodeDetailPanel.js +38 -0
- package/dist/ui/components/NodeDetailPanel.js.map +1 -0
- package/dist/ui/components/node-panel/Controls.d.ts +16 -0
- package/dist/ui/components/node-panel/Controls.d.ts.map +1 -0
- package/dist/ui/components/node-panel/Controls.js +28 -0
- package/dist/ui/components/node-panel/Controls.js.map +1 -0
- package/dist/ui/components/node-panel/ErrorBar.d.ts +6 -0
- package/dist/ui/components/node-panel/ErrorBar.d.ts.map +1 -0
- package/dist/ui/components/node-panel/ErrorBar.js +14 -0
- package/dist/ui/components/node-panel/ErrorBar.js.map +1 -0
- package/dist/ui/components/node-panel/Gate.d.ts +13 -0
- package/dist/ui/components/node-panel/Gate.d.ts.map +1 -0
- package/dist/ui/components/node-panel/Gate.js +40 -0
- package/dist/ui/components/node-panel/Gate.js.map +1 -0
- package/dist/ui/components/node-panel/Header.d.ts +10 -0
- package/dist/ui/components/node-panel/Header.d.ts.map +1 -0
- package/dist/ui/components/node-panel/Header.js +19 -0
- package/dist/ui/components/node-panel/Header.js.map +1 -0
- package/dist/ui/components/node-panel/Info.d.ts +7 -0
- package/dist/ui/components/node-panel/Info.d.ts.map +1 -0
- package/dist/ui/components/node-panel/Info.js +23 -0
- package/dist/ui/components/node-panel/Info.js.map +1 -0
- package/dist/ui/components/node-panel/Output.d.ts +27 -0
- package/dist/ui/components/node-panel/Output.d.ts.map +1 -0
- package/dist/ui/components/node-panel/Output.js +66 -0
- package/dist/ui/components/node-panel/Output.js.map +1 -0
- package/dist/ui/components/node-panel/index.d.ts +47 -0
- package/dist/ui/components/node-panel/index.d.ts.map +1 -0
- package/dist/ui/components/node-panel/index.js +54 -0
- package/dist/ui/components/node-panel/index.js.map +1 -0
- package/dist/ui/components/node-panel/types.d.ts +23 -0
- package/dist/ui/components/node-panel/types.d.ts.map +1 -0
- package/dist/ui/components/node-panel/types.js +24 -0
- package/dist/ui/components/node-panel/types.js.map +1 -0
- package/dist/ui/core/components/Badge.d.ts +6 -0
- package/dist/ui/core/components/Badge.d.ts.map +1 -0
- package/dist/ui/core/components/Badge.js +11 -0
- package/dist/ui/core/components/Badge.js.map +1 -0
- package/dist/ui/core/components/Button.d.ts +9 -0
- package/dist/ui/core/components/Button.d.ts.map +1 -0
- package/dist/ui/core/components/Button.js +18 -0
- package/dist/ui/core/components/Button.js.map +1 -0
- package/dist/ui/core/components/ConfirmDialog.d.ts +11 -0
- package/dist/ui/core/components/ConfirmDialog.d.ts.map +1 -0
- package/dist/ui/core/components/ConfirmDialog.js +23 -0
- package/dist/ui/core/components/ConfirmDialog.js.map +1 -0
- package/dist/ui/core/components/ExecutionCard.d.ts +12 -0
- package/dist/ui/core/components/ExecutionCard.d.ts.map +1 -0
- package/dist/ui/core/components/ExecutionCard.js +15 -0
- package/dist/ui/core/components/ExecutionCard.js.map +1 -0
- package/dist/ui/core/components/NodeListItem.d.ts +10 -0
- package/dist/ui/core/components/NodeListItem.d.ts.map +1 -0
- package/dist/ui/core/components/NodeListItem.js +27 -0
- package/dist/ui/core/components/NodeListItem.js.map +1 -0
- package/dist/ui/core/components/PageHeader.d.ts +10 -0
- package/dist/ui/core/components/PageHeader.d.ts.map +1 -0
- package/dist/ui/core/components/PageHeader.js +9 -0
- package/dist/ui/core/components/PageHeader.js.map +1 -0
- package/dist/ui/core/components/SectionLabel.d.ts +6 -0
- package/dist/ui/core/components/SectionLabel.d.ts.map +1 -0
- package/dist/ui/core/components/SectionLabel.js +9 -0
- package/dist/ui/core/components/SectionLabel.js.map +1 -0
- package/dist/ui/core/components/Skeleton.d.ts +7 -0
- package/dist/ui/core/components/Skeleton.d.ts.map +1 -0
- package/dist/ui/core/components/Skeleton.js +26 -0
- package/dist/ui/core/components/Skeleton.js.map +1 -0
- package/dist/ui/core/components/Stat.d.ts +8 -0
- package/dist/ui/core/components/Stat.d.ts.map +1 -0
- package/dist/ui/core/components/Stat.js +9 -0
- package/dist/ui/core/components/Stat.js.map +1 -0
- package/dist/ui/core/components/Toast.d.ts +7 -0
- package/dist/ui/core/components/Toast.d.ts.map +1 -0
- package/dist/ui/core/components/Toast.js +28 -0
- package/dist/ui/core/components/Toast.js.map +1 -0
- package/dist/ui/core/components/__tests__/primitives.test.d.ts +2 -0
- package/dist/ui/core/components/__tests__/primitives.test.d.ts.map +1 -0
- package/dist/ui/core/components/__tests__/primitives.test.js +3 -0
- package/dist/ui/core/components/__tests__/primitives.test.js.map +1 -0
- package/dist/ui/core/components/index.d.ts +21 -0
- package/dist/ui/core/components/index.d.ts.map +1 -0
- package/dist/ui/core/components/index.js +24 -0
- package/dist/ui/core/components/index.js.map +1 -0
- package/dist/ui/core/index.d.ts +17 -0
- package/dist/ui/core/index.d.ts.map +1 -0
- package/dist/ui/core/index.js +56 -0
- package/dist/ui/core/index.js.map +1 -0
- package/dist/ui/core/utils.d.ts +6 -0
- package/dist/ui/core/utils.d.ts.map +1 -0
- package/dist/ui/core/utils.js +32 -0
- package/dist/ui/core/utils.js.map +1 -0
- package/dist/ui/graph/index.d.ts +4 -0
- package/dist/ui/graph/index.d.ts.map +1 -0
- package/dist/ui/graph/index.js +11 -0
- package/dist/ui/graph/index.js.map +1 -0
- package/dist/ui/hooks/useAutoSelectNode.d.ts +3 -0
- package/dist/ui/hooks/useAutoSelectNode.d.ts.map +1 -0
- package/dist/ui/hooks/useAutoSelectNode.js +36 -0
- package/dist/ui/hooks/useAutoSelectNode.js.map +1 -0
- package/dist/ui/hooks/useFlowExecution.d.ts +32 -0
- package/dist/ui/hooks/useFlowExecution.d.ts.map +1 -0
- package/dist/ui/hooks/useFlowExecution.js +113 -0
- package/dist/ui/hooks/useFlowExecution.js.map +1 -0
- package/dist/ui/hooks/useNodeNavigation.d.ts +3 -0
- package/dist/ui/hooks/useNodeNavigation.d.ts.map +1 -0
- package/dist/ui/hooks/useNodeNavigation.js +38 -0
- package/dist/ui/hooks/useNodeNavigation.js.map +1 -0
- package/dist/ui/hooks/useNodeOutput.d.ts +21 -0
- package/dist/ui/hooks/useNodeOutput.d.ts.map +1 -0
- package/dist/ui/hooks/useNodeOutput.js +75 -0
- package/dist/ui/hooks/useNodeOutput.js.map +1 -0
- package/dist/ui/index.d.ts +16 -0
- package/dist/ui/index.d.ts.map +1 -0
- package/dist/ui/index.js +37 -0
- package/dist/ui/index.js.map +1 -0
- package/dist/ui/utils.d.ts +3 -0
- package/dist/ui/utils.d.ts.map +1 -0
- package/dist/ui/utils.js +9 -0
- package/dist/ui/utils.js.map +1 -0
- package/package.json +87 -0
|
@@ -0,0 +1,223 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
/**
|
|
3
|
+
* Pure projection reducer — folds ExecutionEvents into ExecutionProjection.
|
|
4
|
+
*
|
|
5
|
+
* Zero I/O. Exhaustive switch with `never` default. All updates are immutable.
|
|
6
|
+
*/
|
|
7
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
8
|
+
exports.createEmptyProjection = createEmptyProjection;
|
|
9
|
+
exports.reduce = reduce;
|
|
10
|
+
exports.replayEvents = replayEvents;
|
|
11
|
+
// ---------------------------------------------------------------------------
|
|
12
|
+
// Factory
|
|
13
|
+
// ---------------------------------------------------------------------------
|
|
14
|
+
function createEmptyProjection(id, flowId) {
|
|
15
|
+
return {
|
|
16
|
+
id,
|
|
17
|
+
flowId: flowId ?? '',
|
|
18
|
+
status: 'pending',
|
|
19
|
+
params: {},
|
|
20
|
+
graph: {
|
|
21
|
+
nodes: [],
|
|
22
|
+
edges: [],
|
|
23
|
+
activeNodes: [],
|
|
24
|
+
completedPath: [],
|
|
25
|
+
},
|
|
26
|
+
totalCost: 0,
|
|
27
|
+
metadata: {},
|
|
28
|
+
};
|
|
29
|
+
}
|
|
30
|
+
// ---------------------------------------------------------------------------
|
|
31
|
+
// Helpers
|
|
32
|
+
// ---------------------------------------------------------------------------
|
|
33
|
+
function updateNode(state, nodeId, updater) {
|
|
34
|
+
const nodes = state.graph.nodes.map((n) => n.id === nodeId ? updater(n) : n);
|
|
35
|
+
// Recalculate activeNodes: nodes with status 'running' or 'gated'
|
|
36
|
+
const activeNodes = nodes
|
|
37
|
+
.filter((n) => n.status === 'running' || n.status === 'gated')
|
|
38
|
+
.map((n) => n.id);
|
|
39
|
+
return {
|
|
40
|
+
...state,
|
|
41
|
+
graph: { ...state.graph, nodes, activeNodes },
|
|
42
|
+
};
|
|
43
|
+
}
|
|
44
|
+
function updateEdge(state, source, target, newState) {
|
|
45
|
+
const edges = state.graph.edges.map((e) => {
|
|
46
|
+
if (e.source === source && e.target === target) {
|
|
47
|
+
return { ...e, state: newState };
|
|
48
|
+
}
|
|
49
|
+
// Mark sibling edges from the same source as 'not_taken' if still 'default'
|
|
50
|
+
if (e.source === source && e.state === 'default') {
|
|
51
|
+
return { ...e, state: 'not_taken' };
|
|
52
|
+
}
|
|
53
|
+
return e;
|
|
54
|
+
});
|
|
55
|
+
return { ...state, graph: { ...state.graph, edges } };
|
|
56
|
+
}
|
|
57
|
+
// ---------------------------------------------------------------------------
|
|
58
|
+
// Reducer
|
|
59
|
+
// ---------------------------------------------------------------------------
|
|
60
|
+
function reduce(state, event) {
|
|
61
|
+
switch (event.type) {
|
|
62
|
+
case 'run:started': {
|
|
63
|
+
const nodes = event.graph.nodes.map((n) => ({
|
|
64
|
+
id: n.id,
|
|
65
|
+
displayName: n.displayName,
|
|
66
|
+
nodeType: n.nodeType,
|
|
67
|
+
model: n.model,
|
|
68
|
+
status: 'pending',
|
|
69
|
+
attempt: 0,
|
|
70
|
+
output: n.output,
|
|
71
|
+
}));
|
|
72
|
+
const edges = event.graph.edges.map((e) => ({
|
|
73
|
+
source: e.source,
|
|
74
|
+
action: e.action,
|
|
75
|
+
target: e.target,
|
|
76
|
+
state: 'default',
|
|
77
|
+
}));
|
|
78
|
+
return {
|
|
79
|
+
...state,
|
|
80
|
+
status: 'running',
|
|
81
|
+
flowId: event.flowId,
|
|
82
|
+
params: { ...event.params },
|
|
83
|
+
startedAt: event.ts,
|
|
84
|
+
graph: {
|
|
85
|
+
nodes,
|
|
86
|
+
edges,
|
|
87
|
+
activeNodes: [],
|
|
88
|
+
completedPath: [],
|
|
89
|
+
},
|
|
90
|
+
};
|
|
91
|
+
}
|
|
92
|
+
case 'run:completed':
|
|
93
|
+
return {
|
|
94
|
+
...state,
|
|
95
|
+
status: event.status,
|
|
96
|
+
finishedAt: event.ts,
|
|
97
|
+
};
|
|
98
|
+
case 'run:resumed':
|
|
99
|
+
return {
|
|
100
|
+
...state,
|
|
101
|
+
status: 'running',
|
|
102
|
+
};
|
|
103
|
+
case 'node:started':
|
|
104
|
+
return updateNode(state, event.nodeId, (n) => ({
|
|
105
|
+
...n,
|
|
106
|
+
status: 'running',
|
|
107
|
+
startedAt: event.ts,
|
|
108
|
+
attempt: n.attempt + 1,
|
|
109
|
+
}));
|
|
110
|
+
case 'node:completed': {
|
|
111
|
+
// Don't overwrite 'skipped' status — gate rejection takes precedence over
|
|
112
|
+
// the scheduler's node:completed (which fires after the gate Promise resolves)
|
|
113
|
+
const existing = state.graph.nodes.find(n => n.id === event.nodeId);
|
|
114
|
+
if (existing?.status === 'skipped')
|
|
115
|
+
return state;
|
|
116
|
+
const updated = updateNode(state, event.nodeId, (n) => ({
|
|
117
|
+
...n,
|
|
118
|
+
status: 'completed',
|
|
119
|
+
action: event.action,
|
|
120
|
+
finishedAt: event.ts,
|
|
121
|
+
elapsedMs: event.elapsedMs,
|
|
122
|
+
}));
|
|
123
|
+
return {
|
|
124
|
+
...updated,
|
|
125
|
+
graph: {
|
|
126
|
+
...updated.graph,
|
|
127
|
+
completedPath: [...updated.graph.completedPath, event.nodeId],
|
|
128
|
+
},
|
|
129
|
+
};
|
|
130
|
+
}
|
|
131
|
+
case 'node:failed':
|
|
132
|
+
return updateNode(state, event.nodeId, (n) => ({
|
|
133
|
+
...n,
|
|
134
|
+
status: 'failed',
|
|
135
|
+
finishedAt: event.ts,
|
|
136
|
+
error: event.error,
|
|
137
|
+
}));
|
|
138
|
+
case 'node:killed':
|
|
139
|
+
return updateNode(state, event.nodeId, (n) => ({
|
|
140
|
+
...n,
|
|
141
|
+
status: 'killed',
|
|
142
|
+
finishedAt: event.ts,
|
|
143
|
+
}));
|
|
144
|
+
case 'node:skipped':
|
|
145
|
+
return updateNode(state, event.nodeId, (n) => ({
|
|
146
|
+
...n,
|
|
147
|
+
status: 'skipped',
|
|
148
|
+
finishedAt: event.ts,
|
|
149
|
+
}));
|
|
150
|
+
case 'node:gated':
|
|
151
|
+
return updateNode(state, event.nodeId, (n) => ({
|
|
152
|
+
...n,
|
|
153
|
+
status: 'gated',
|
|
154
|
+
gateData: event.gateData,
|
|
155
|
+
}));
|
|
156
|
+
case 'gate:resolved': {
|
|
157
|
+
const resolvedStatus = event.resolution === 'rejected' ? 'skipped' : 'completed';
|
|
158
|
+
const updated = updateNode(state, event.nodeId, (n) => ({
|
|
159
|
+
...n,
|
|
160
|
+
status: resolvedStatus,
|
|
161
|
+
action: event.resolution,
|
|
162
|
+
finishedAt: event.ts,
|
|
163
|
+
}));
|
|
164
|
+
// If not rejected, also add to completedPath
|
|
165
|
+
if (resolvedStatus === 'completed') {
|
|
166
|
+
return {
|
|
167
|
+
...updated,
|
|
168
|
+
graph: {
|
|
169
|
+
...updated.graph,
|
|
170
|
+
completedPath: [...updated.graph.completedPath, event.nodeId],
|
|
171
|
+
},
|
|
172
|
+
};
|
|
173
|
+
}
|
|
174
|
+
return updated;
|
|
175
|
+
}
|
|
176
|
+
case 'node:retrying':
|
|
177
|
+
return updateNode(state, event.nodeId, (n) => ({
|
|
178
|
+
...n,
|
|
179
|
+
status: 'retrying',
|
|
180
|
+
attempt: event.attempt,
|
|
181
|
+
error: undefined,
|
|
182
|
+
finishedAt: undefined,
|
|
183
|
+
elapsedMs: undefined,
|
|
184
|
+
}));
|
|
185
|
+
case 'edge:traversed':
|
|
186
|
+
return updateEdge(state, event.source, event.target, 'taken');
|
|
187
|
+
case 'artifact:written':
|
|
188
|
+
// Artifacts are stored separately — no projection change
|
|
189
|
+
return state;
|
|
190
|
+
case 'cost:recorded':
|
|
191
|
+
return {
|
|
192
|
+
...state,
|
|
193
|
+
totalCost: state.totalCost + event.cost,
|
|
194
|
+
};
|
|
195
|
+
case 'metadata': {
|
|
196
|
+
// CR1: array merge semantics — arrays accumulate, scalars overwrite
|
|
197
|
+
const existing = state.metadata[event.key];
|
|
198
|
+
let merged;
|
|
199
|
+
if (Array.isArray(existing) && Array.isArray(event.value)) {
|
|
200
|
+
merged = [...existing, ...event.value];
|
|
201
|
+
}
|
|
202
|
+
else {
|
|
203
|
+
merged = event.value;
|
|
204
|
+
}
|
|
205
|
+
return {
|
|
206
|
+
...state,
|
|
207
|
+
metadata: { ...state.metadata, [event.key]: merged },
|
|
208
|
+
};
|
|
209
|
+
}
|
|
210
|
+
default: {
|
|
211
|
+
// Exhaustiveness check — if this errors, a new event type was added without a case
|
|
212
|
+
const _exhaustive = event;
|
|
213
|
+
throw new Error(`Unhandled event type: ${_exhaustive.type}`);
|
|
214
|
+
}
|
|
215
|
+
}
|
|
216
|
+
}
|
|
217
|
+
// ---------------------------------------------------------------------------
|
|
218
|
+
// Replay
|
|
219
|
+
// ---------------------------------------------------------------------------
|
|
220
|
+
function replayEvents(id, events) {
|
|
221
|
+
return events.reduce((state, event) => reduce(state, event), createEmptyProjection(id));
|
|
222
|
+
}
|
|
223
|
+
//# sourceMappingURL=reducer.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"reducer.js","sourceRoot":"","sources":["../../state/reducer.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,30 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* StateRuntime — coordinates event flow, projection caching, and storage.
|
|
3
|
+
*
|
|
4
|
+
* Sits between the execution layer (which emits events) and the API layer
|
|
5
|
+
* (which serves projections). Uses a StorageEngine for persistence and
|
|
6
|
+
* an in-memory cache for fast reads.
|
|
7
|
+
*/
|
|
8
|
+
import type { StorageEngine, ExecutionProjection, OutputPage } from '../src/types';
|
|
9
|
+
import type { ExecutionEvent, OutputEvent } from '../src/events';
|
|
10
|
+
export declare class StateRuntime {
|
|
11
|
+
private readonly storage;
|
|
12
|
+
private readonly onEvent?;
|
|
13
|
+
private cache;
|
|
14
|
+
private locks;
|
|
15
|
+
constructor(storage: StorageEngine, onEvent?: ((event: ExecutionEvent) => void) | undefined);
|
|
16
|
+
handleEvent(event: ExecutionEvent): Promise<void>;
|
|
17
|
+
private _applyEvent;
|
|
18
|
+
handleOutput(event: OutputEvent): void;
|
|
19
|
+
writeArtifact(execId: string, nodeId: string, name: string, content: string): void;
|
|
20
|
+
getProjection(id: string): ExecutionProjection | null;
|
|
21
|
+
listExecutions(): ExecutionProjection[];
|
|
22
|
+
getNodeOutput(execId: string, nodeId: string, offset?: number, limit?: number): OutputPage;
|
|
23
|
+
getArtifact(execId: string, nodeId: string, name: string): string | null;
|
|
24
|
+
rebuildProjection(execId: string): ExecutionProjection;
|
|
25
|
+
/** R12a: Hydrate cache from storage. R12b: Mark running executions as crashed. */
|
|
26
|
+
recoverOnStartup(): void;
|
|
27
|
+
delete(execId: string): boolean;
|
|
28
|
+
shutdown(): void;
|
|
29
|
+
}
|
|
30
|
+
//# sourceMappingURL=state-runtime.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"state-runtime.d.ts","sourceRoot":"","sources":["../../state/state-runtime.ts"],"names":[],"mappings":"AAAA;;;;;;GAMG;AAEH,OAAO,KAAK,EACV,aAAa,EACb,mBAAmB,EACnB,UAAU,EACX,MAAM,cAAc,CAAC;AACtB,OAAO,KAAK,EAAE,cAAc,EAAE,WAAW,EAAE,MAAM,eAAe,CAAC;AAGjE,qBAAa,YAAY;IAMrB,OAAO,CAAC,QAAQ,CAAC,OAAO;IACxB,OAAO,CAAC,QAAQ,CAAC,OAAO,CAAC;IAN3B,OAAO,CAAC,KAAK,CAA0C;IAEvD,OAAO,CAAC,KAAK,CAAoC;gBAG9B,OAAO,EAAE,aAAa,EACtB,OAAO,CAAC,GAAE,CAAC,KAAK,EAAE,cAAc,KAAK,IAAI,aAAA;IAOtD,WAAW,CAAC,KAAK,EAAE,cAAc,GAAG,OAAO,CAAC,IAAI,CAAC;IAUvD,OAAO,CAAC,WAAW;IAsBnB,YAAY,CAAC,KAAK,EAAE,WAAW,GAAG,IAAI;IAMtC,aAAa,CAAC,MAAM,EAAE,MAAM,EAAE,MAAM,EAAE,MAAM,EAAE,IAAI,EAAE,MAAM,EAAE,OAAO,EAAE,MAAM,GAAG,IAAI;IAQlF,aAAa,CAAC,EAAE,EAAE,MAAM,GAAG,mBAAmB,GAAG,IAAI;IAIrD,cAAc,IAAI,mBAAmB,EAAE;IAIvC,aAAa,CAAC,MAAM,EAAE,MAAM,EAAE,MAAM,EAAE,MAAM,EAAE,MAAM,CAAC,EAAE,MAAM,EAAE,KAAK,CAAC,EAAE,MAAM,GAAG,UAAU;IAI1F,WAAW,CAAC,MAAM,EAAE,MAAM,EAAE,MAAM,EAAE,MAAM,EAAE,IAAI,EAAE,MAAM,GAAG,MAAM,GAAG,IAAI;IAQxE,iBAAiB,CAAC,MAAM,EAAE,MAAM,GAAG,mBAAmB;IAQtD,kFAAkF;IAClF,gBAAgB,IAAI,IAAI;IAmCxB,MAAM,CAAC,MAAM,EAAE,MAAM,GAAG,OAAO;IAK/B,QAAQ,IAAI,IAAI;CAUjB"}
|
|
@@ -0,0 +1,131 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
/**
|
|
3
|
+
* StateRuntime — coordinates event flow, projection caching, and storage.
|
|
4
|
+
*
|
|
5
|
+
* Sits between the execution layer (which emits events) and the API layer
|
|
6
|
+
* (which serves projections). Uses a StorageEngine for persistence and
|
|
7
|
+
* an in-memory cache for fast reads.
|
|
8
|
+
*/
|
|
9
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
10
|
+
exports.StateRuntime = void 0;
|
|
11
|
+
const reducer_1 = require("./reducer");
|
|
12
|
+
class StateRuntime {
|
|
13
|
+
storage;
|
|
14
|
+
onEvent;
|
|
15
|
+
cache = new Map();
|
|
16
|
+
// SYS-1: Per-execution async mutex — serializes events for each execution
|
|
17
|
+
locks = new Map();
|
|
18
|
+
constructor(storage, onEvent) {
|
|
19
|
+
this.storage = storage;
|
|
20
|
+
this.onEvent = onEvent;
|
|
21
|
+
}
|
|
22
|
+
// -------------------------------------------------------------------------
|
|
23
|
+
// Command handlers
|
|
24
|
+
// -------------------------------------------------------------------------
|
|
25
|
+
async handleEvent(event) {
|
|
26
|
+
const id = event.executionId;
|
|
27
|
+
// SYS-1: Serialize events per-execution via promise chain
|
|
28
|
+
const prev = this.locks.get(id) ?? Promise.resolve();
|
|
29
|
+
const next = prev.then(() => this._applyEvent(event));
|
|
30
|
+
this.locks.set(id, next.catch(() => { }));
|
|
31
|
+
await next;
|
|
32
|
+
}
|
|
33
|
+
_applyEvent(event) {
|
|
34
|
+
const id = event.executionId;
|
|
35
|
+
// 1. Append to event log
|
|
36
|
+
this.storage.appendEvent(id, event);
|
|
37
|
+
// 2. Get or create projection
|
|
38
|
+
let projection = this.cache.get(id) ?? (0, reducer_1.createEmptyProjection)(id);
|
|
39
|
+
// 3. Reduce
|
|
40
|
+
projection = (0, reducer_1.reduce)(projection, event);
|
|
41
|
+
// 4. Write projection
|
|
42
|
+
this.storage.writeProjection(id, projection);
|
|
43
|
+
// 5. Update cache
|
|
44
|
+
this.cache.set(id, projection);
|
|
45
|
+
// 6. Notify listeners
|
|
46
|
+
this.onEvent?.(event);
|
|
47
|
+
}
|
|
48
|
+
handleOutput(event) {
|
|
49
|
+
if (event.type === 'node:output') {
|
|
50
|
+
this.storage.appendOutput(event.executionId, event.nodeId, event.content);
|
|
51
|
+
}
|
|
52
|
+
}
|
|
53
|
+
writeArtifact(execId, nodeId, name, content) {
|
|
54
|
+
this.storage.writeArtifact(execId, nodeId, name, content);
|
|
55
|
+
}
|
|
56
|
+
// -------------------------------------------------------------------------
|
|
57
|
+
// Query handlers
|
|
58
|
+
// -------------------------------------------------------------------------
|
|
59
|
+
getProjection(id) {
|
|
60
|
+
return this.cache.get(id) ?? this.storage.readProjection(id);
|
|
61
|
+
}
|
|
62
|
+
listExecutions() {
|
|
63
|
+
return Array.from(this.cache.values());
|
|
64
|
+
}
|
|
65
|
+
getNodeOutput(execId, nodeId, offset, limit) {
|
|
66
|
+
return this.storage.readOutput(execId, nodeId, offset, limit);
|
|
67
|
+
}
|
|
68
|
+
getArtifact(execId, nodeId, name) {
|
|
69
|
+
return this.storage.readArtifact(execId, nodeId, name);
|
|
70
|
+
}
|
|
71
|
+
// -------------------------------------------------------------------------
|
|
72
|
+
// Recovery
|
|
73
|
+
// -------------------------------------------------------------------------
|
|
74
|
+
rebuildProjection(execId) {
|
|
75
|
+
const events = this.storage.readEvents(execId);
|
|
76
|
+
const projection = (0, reducer_1.replayEvents)(execId, events);
|
|
77
|
+
this.storage.writeProjection(execId, projection);
|
|
78
|
+
this.cache.set(execId, projection);
|
|
79
|
+
return projection;
|
|
80
|
+
}
|
|
81
|
+
/** R12a: Hydrate cache from storage. R12b: Mark running executions as crashed. */
|
|
82
|
+
recoverOnStartup() {
|
|
83
|
+
for (const id of this.storage.listExecutionIds()) {
|
|
84
|
+
// SYS-5: Replay from event log (source of truth), not disk projection
|
|
85
|
+
const events = this.storage.readEvents(id);
|
|
86
|
+
let projection;
|
|
87
|
+
if (events.length > 0) {
|
|
88
|
+
projection = (0, reducer_1.replayEvents)(id, events);
|
|
89
|
+
}
|
|
90
|
+
else {
|
|
91
|
+
// Fallback to disk projection if event log is empty (legacy data)
|
|
92
|
+
const diskProjection = this.storage.readProjection(id);
|
|
93
|
+
if (!diskProjection)
|
|
94
|
+
continue;
|
|
95
|
+
projection = diskProjection;
|
|
96
|
+
}
|
|
97
|
+
if (projection.status === 'running') {
|
|
98
|
+
// R12b: Append crash event and update projection
|
|
99
|
+
const crashEvent = {
|
|
100
|
+
type: 'run:completed',
|
|
101
|
+
executionId: id,
|
|
102
|
+
status: 'crashed',
|
|
103
|
+
ts: Date.now(),
|
|
104
|
+
};
|
|
105
|
+
this.storage.appendEvent(id, crashEvent);
|
|
106
|
+
projection = (0, reducer_1.reduce)(projection, crashEvent);
|
|
107
|
+
}
|
|
108
|
+
this.storage.writeProjection(id, projection);
|
|
109
|
+
this.cache.set(id, projection);
|
|
110
|
+
}
|
|
111
|
+
}
|
|
112
|
+
// -------------------------------------------------------------------------
|
|
113
|
+
// Lifecycle
|
|
114
|
+
// -------------------------------------------------------------------------
|
|
115
|
+
delete(execId) {
|
|
116
|
+
this.cache.delete(execId);
|
|
117
|
+
return this.storage.delete(execId);
|
|
118
|
+
}
|
|
119
|
+
shutdown() {
|
|
120
|
+
for (const id of this.cache.keys()) {
|
|
121
|
+
const projection = this.cache.get(id);
|
|
122
|
+
if (projection) {
|
|
123
|
+
for (const node of projection.graph.nodes) {
|
|
124
|
+
this.storage.closeOutput(id, node.id);
|
|
125
|
+
}
|
|
126
|
+
}
|
|
127
|
+
}
|
|
128
|
+
}
|
|
129
|
+
}
|
|
130
|
+
exports.StateRuntime = StateRuntime;
|
|
131
|
+
//# sourceMappingURL=state-runtime.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"state-runtime.js","sourceRoot":"","sources":["../../state/state-runtime.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,24 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* In-memory StorageEngine implementation — zero I/O, for tests.
|
|
3
|
+
*/
|
|
4
|
+
import type { StorageEngine, ExecutionProjection, OutputPage } from '../src/types';
|
|
5
|
+
import type { ExecutionEvent } from '../src/events';
|
|
6
|
+
export declare class MemoryStorage implements StorageEngine {
|
|
7
|
+
private events;
|
|
8
|
+
private projections;
|
|
9
|
+
private artifacts;
|
|
10
|
+
private outputs;
|
|
11
|
+
private closedOutputs;
|
|
12
|
+
appendEvent(execId: string, event: ExecutionEvent): void;
|
|
13
|
+
readEvents(execId: string): ExecutionEvent[];
|
|
14
|
+
writeProjection(execId: string, projection: ExecutionProjection): void;
|
|
15
|
+
readProjection(execId: string): ExecutionProjection | null;
|
|
16
|
+
writeArtifact(execId: string, nodeId: string, name: string, content: string): void;
|
|
17
|
+
readArtifact(execId: string, nodeId: string, name: string): string | null;
|
|
18
|
+
appendOutput(execId: string, nodeId: string, line: string): void;
|
|
19
|
+
readOutput(execId: string, nodeId: string, offset?: number, limit?: number): OutputPage;
|
|
20
|
+
closeOutput(execId: string, nodeId: string): void;
|
|
21
|
+
delete(execId: string): boolean;
|
|
22
|
+
listExecutionIds(): string[];
|
|
23
|
+
}
|
|
24
|
+
//# sourceMappingURL=storage-memory.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"storage-memory.d.ts","sourceRoot":"","sources":["../../state/storage-memory.ts"],"names":[],"mappings":"AAAA;;GAEG;AAEH,OAAO,KAAK,EACV,aAAa,EACb,mBAAmB,EACnB,UAAU,EACX,MAAM,cAAc,CAAC;AACtB,OAAO,KAAK,EAAE,cAAc,EAAE,MAAM,eAAe,CAAC;AAEpD,qBAAa,aAAc,YAAW,aAAa;IACjD,OAAO,CAAC,MAAM,CAAuC;IACrD,OAAO,CAAC,WAAW,CAA0C;IAC7D,OAAO,CAAC,SAAS,CAA6B;IAC9C,OAAO,CAAC,OAAO,CAA+B;IAC9C,OAAO,CAAC,aAAa,CAAqB;IAE1C,WAAW,CAAC,MAAM,EAAE,MAAM,EAAE,KAAK,EAAE,cAAc,GAAG,IAAI;IAMxD,UAAU,CAAC,MAAM,EAAE,MAAM,GAAG,cAAc,EAAE;IAI5C,eAAe,CAAC,MAAM,EAAE,MAAM,EAAE,UAAU,EAAE,mBAAmB,GAAG,IAAI;IAItE,cAAc,CAAC,MAAM,EAAE,MAAM,GAAG,mBAAmB,GAAG,IAAI;IAI1D,aAAa,CAAC,MAAM,EAAE,MAAM,EAAE,MAAM,EAAE,MAAM,EAAE,IAAI,EAAE,MAAM,EAAE,OAAO,EAAE,MAAM,GAAG,IAAI;IAIlF,YAAY,CAAC,MAAM,EAAE,MAAM,EAAE,MAAM,EAAE,MAAM,EAAE,IAAI,EAAE,MAAM,GAAG,MAAM,GAAG,IAAI;IAIzE,YAAY,CAAC,MAAM,EAAE,MAAM,EAAE,MAAM,EAAE,MAAM,EAAE,IAAI,EAAE,MAAM,GAAG,IAAI;IAOhE,UAAU,CAAC,MAAM,EAAE,MAAM,EAAE,MAAM,EAAE,MAAM,EAAE,MAAM,CAAC,EAAE,MAAM,EAAE,KAAK,CAAC,EAAE,MAAM,GAAG,UAAU;IAcvF,WAAW,CAAC,MAAM,EAAE,MAAM,EAAE,MAAM,EAAE,MAAM,GAAG,IAAI;IAIjD,MAAM,CAAC,MAAM,EAAE,MAAM,GAAG,OAAO;IAyB/B,gBAAgB,IAAI,MAAM,EAAE;CAQ7B"}
|
|
@@ -0,0 +1,91 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
/**
|
|
3
|
+
* In-memory StorageEngine implementation — zero I/O, for tests.
|
|
4
|
+
*/
|
|
5
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
6
|
+
exports.MemoryStorage = void 0;
|
|
7
|
+
class MemoryStorage {
|
|
8
|
+
events = new Map();
|
|
9
|
+
projections = new Map();
|
|
10
|
+
artifacts = new Map();
|
|
11
|
+
outputs = new Map();
|
|
12
|
+
closedOutputs = new Set();
|
|
13
|
+
appendEvent(execId, event) {
|
|
14
|
+
const arr = this.events.get(execId) ?? [];
|
|
15
|
+
arr.push(event);
|
|
16
|
+
this.events.set(execId, arr);
|
|
17
|
+
}
|
|
18
|
+
readEvents(execId) {
|
|
19
|
+
return [...(this.events.get(execId) ?? [])];
|
|
20
|
+
}
|
|
21
|
+
writeProjection(execId, projection) {
|
|
22
|
+
this.projections.set(execId, projection);
|
|
23
|
+
}
|
|
24
|
+
readProjection(execId) {
|
|
25
|
+
return this.projections.get(execId) ?? null;
|
|
26
|
+
}
|
|
27
|
+
writeArtifact(execId, nodeId, name, content) {
|
|
28
|
+
this.artifacts.set(`${execId}:${nodeId}:${name}`, content);
|
|
29
|
+
}
|
|
30
|
+
readArtifact(execId, nodeId, name) {
|
|
31
|
+
return this.artifacts.get(`${execId}:${nodeId}:${name}`) ?? null;
|
|
32
|
+
}
|
|
33
|
+
appendOutput(execId, nodeId, line) {
|
|
34
|
+
const key = `${execId}:${nodeId}`;
|
|
35
|
+
const arr = this.outputs.get(key) ?? [];
|
|
36
|
+
arr.push(line);
|
|
37
|
+
this.outputs.set(key, arr);
|
|
38
|
+
}
|
|
39
|
+
readOutput(execId, nodeId, offset, limit) {
|
|
40
|
+
const key = `${execId}:${nodeId}`;
|
|
41
|
+
const all = this.outputs.get(key) ?? [];
|
|
42
|
+
const start = offset ?? 0;
|
|
43
|
+
const end = limit != null ? start + limit : all.length;
|
|
44
|
+
const lines = all.slice(start, end);
|
|
45
|
+
return {
|
|
46
|
+
lines,
|
|
47
|
+
offset: start,
|
|
48
|
+
total: all.length,
|
|
49
|
+
hasMore: end < all.length,
|
|
50
|
+
};
|
|
51
|
+
}
|
|
52
|
+
closeOutput(execId, nodeId) {
|
|
53
|
+
this.closedOutputs.add(`${execId}:${nodeId}`);
|
|
54
|
+
}
|
|
55
|
+
delete(execId) {
|
|
56
|
+
let deleted = false;
|
|
57
|
+
if (this.events.delete(execId))
|
|
58
|
+
deleted = true;
|
|
59
|
+
if (this.projections.delete(execId))
|
|
60
|
+
deleted = true;
|
|
61
|
+
// Clean up artifacts and outputs with matching prefix
|
|
62
|
+
for (const key of this.artifacts.keys()) {
|
|
63
|
+
if (key.startsWith(`${execId}:`)) {
|
|
64
|
+
this.artifacts.delete(key);
|
|
65
|
+
deleted = true;
|
|
66
|
+
}
|
|
67
|
+
}
|
|
68
|
+
for (const key of this.outputs.keys()) {
|
|
69
|
+
if (key.startsWith(`${execId}:`)) {
|
|
70
|
+
this.outputs.delete(key);
|
|
71
|
+
deleted = true;
|
|
72
|
+
}
|
|
73
|
+
}
|
|
74
|
+
for (const key of this.closedOutputs) {
|
|
75
|
+
if (key.startsWith(`${execId}:`)) {
|
|
76
|
+
this.closedOutputs.delete(key);
|
|
77
|
+
}
|
|
78
|
+
}
|
|
79
|
+
return deleted;
|
|
80
|
+
}
|
|
81
|
+
listExecutionIds() {
|
|
82
|
+
// Union of all keys that have events or projections
|
|
83
|
+
const ids = new Set([
|
|
84
|
+
...this.events.keys(),
|
|
85
|
+
...this.projections.keys(),
|
|
86
|
+
]);
|
|
87
|
+
return [...ids];
|
|
88
|
+
}
|
|
89
|
+
}
|
|
90
|
+
exports.MemoryStorage = MemoryStorage;
|
|
91
|
+
//# sourceMappingURL=storage-memory.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"storage-memory.js","sourceRoot":"","sources":["../../state/storage-memory.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,29 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* File-based StorageEngine — JSONL event logs, atomic projection writes,
|
|
3
|
+
* per-node output files, flat artifact files.
|
|
4
|
+
*
|
|
5
|
+
* Directory structure:
|
|
6
|
+
* {rootDir}/{execId}/events.jsonl
|
|
7
|
+
* {rootDir}/{execId}/projection.json
|
|
8
|
+
* {rootDir}/{execId}/artifacts/{nodeId}/{name}
|
|
9
|
+
* {rootDir}/{execId}/output/{nodeId}.log
|
|
10
|
+
*/
|
|
11
|
+
import type { StorageEngine, ExecutionProjection, OutputPage } from '../src/types';
|
|
12
|
+
import type { ExecutionEvent } from '../src/events';
|
|
13
|
+
export declare class FileStorage implements StorageEngine {
|
|
14
|
+
private readonly rootDir;
|
|
15
|
+
constructor(rootDir: string);
|
|
16
|
+
private execDir;
|
|
17
|
+
appendEvent(execId: string, event: ExecutionEvent): void;
|
|
18
|
+
readEvents(execId: string): ExecutionEvent[];
|
|
19
|
+
writeProjection(execId: string, projection: ExecutionProjection): void;
|
|
20
|
+
readProjection(execId: string): ExecutionProjection | null;
|
|
21
|
+
writeArtifact(execId: string, nodeId: string, name: string, content: string): void;
|
|
22
|
+
readArtifact(execId: string, nodeId: string, name: string): string | null;
|
|
23
|
+
appendOutput(execId: string, nodeId: string, line: string): void;
|
|
24
|
+
readOutput(execId: string, nodeId: string, offset?: number, limit?: number): OutputPage;
|
|
25
|
+
closeOutput(_execId: string, _nodeId: string): void;
|
|
26
|
+
delete(execId: string): boolean;
|
|
27
|
+
listExecutionIds(): string[];
|
|
28
|
+
}
|
|
29
|
+
//# sourceMappingURL=storage.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"storage.d.ts","sourceRoot":"","sources":["../../state/storage.ts"],"names":[],"mappings":"AAAA;;;;;;;;;GASG;AAIH,OAAO,KAAK,EACV,aAAa,EACb,mBAAmB,EACnB,UAAU,EACX,MAAM,cAAc,CAAC;AACtB,OAAO,KAAK,EAAE,cAAc,EAAE,MAAM,eAAe,CAAC;AAmBpD,qBAAa,WAAY,YAAW,aAAa;IACnC,OAAO,CAAC,QAAQ,CAAC,OAAO;gBAAP,OAAO,EAAE,MAAM;IAE5C,OAAO,CAAC,OAAO;IAIf,WAAW,CAAC,MAAM,EAAE,MAAM,EAAE,KAAK,EAAE,cAAc,GAAG,IAAI;IAOxD,UAAU,CAAC,MAAM,EAAE,MAAM,GAAG,cAAc,EAAE;IAiB5C,eAAe,CAAC,MAAM,EAAE,MAAM,EAAE,UAAU,EAAE,mBAAmB,GAAG,IAAI;IAStE,cAAc,CAAC,MAAM,EAAE,MAAM,GAAG,mBAAmB,GAAG,IAAI;IAW1D,aAAa,CAAC,MAAM,EAAE,MAAM,EAAE,MAAM,EAAE,MAAM,EAAE,IAAI,EAAE,MAAM,EAAE,OAAO,EAAE,MAAM,GAAG,IAAI;IAOlF,YAAY,CAAC,MAAM,EAAE,MAAM,EAAE,MAAM,EAAE,MAAM,EAAE,IAAI,EAAE,MAAM,GAAG,MAAM,GAAG,IAAI;IAMzE,YAAY,CAAC,MAAM,EAAE,MAAM,EAAE,MAAM,EAAE,MAAM,EAAE,IAAI,EAAE,MAAM,GAAG,IAAI;IAOhE,UAAU,CAAC,MAAM,EAAE,MAAM,EAAE,MAAM,EAAE,MAAM,EAAE,MAAM,CAAC,EAAE,MAAM,EAAE,KAAK,CAAC,EAAE,MAAM,GAAG,UAAU;IAsBvF,WAAW,CAAC,OAAO,EAAE,MAAM,EAAE,OAAO,EAAE,MAAM,GAAG,IAAI;IAInD,MAAM,CAAC,MAAM,EAAE,MAAM,GAAG,OAAO;IAO/B,gBAAgB,IAAI,MAAM,EAAE;CAO7B"}
|