@auto-engineer/pipeline 0.0.1 → 0.15.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.
Files changed (201) hide show
  1. package/.turbo/turbo-build.log +1 -1
  2. package/CHANGELOG.md +26 -0
  3. package/README.md +279 -0
  4. package/dist/src/builder/define.d.ts +6 -2
  5. package/dist/src/builder/define.d.ts.map +1 -1
  6. package/dist/src/builder/define.js +17 -7
  7. package/dist/src/builder/define.js.map +1 -1
  8. package/dist/src/builder/define.specs.js +3 -3
  9. package/dist/src/builder/define.specs.js.map +1 -1
  10. package/dist/src/core/descriptors.d.ts +6 -2
  11. package/dist/src/core/descriptors.d.ts.map +1 -1
  12. package/dist/src/graph/filter-graph.d.ts +3 -0
  13. package/dist/src/graph/filter-graph.d.ts.map +1 -0
  14. package/dist/src/graph/filter-graph.js +80 -0
  15. package/dist/src/graph/filter-graph.js.map +1 -0
  16. package/dist/src/graph/filter-graph.specs.d.ts +2 -0
  17. package/dist/src/graph/filter-graph.specs.d.ts.map +1 -0
  18. package/dist/src/graph/filter-graph.specs.js +204 -0
  19. package/dist/src/graph/filter-graph.specs.js.map +1 -0
  20. package/dist/src/graph/types.d.ts +8 -0
  21. package/dist/src/graph/types.d.ts.map +1 -1
  22. package/dist/src/index.d.ts +1 -0
  23. package/dist/src/index.d.ts.map +1 -1
  24. package/dist/src/index.js.map +1 -1
  25. package/dist/src/projections/await-tracker-projection.d.ts +31 -0
  26. package/dist/src/projections/await-tracker-projection.d.ts.map +1 -0
  27. package/dist/src/projections/await-tracker-projection.js +35 -0
  28. package/dist/src/projections/await-tracker-projection.js.map +1 -0
  29. package/dist/src/projections/index.d.ts +4 -0
  30. package/dist/src/projections/index.d.ts.map +1 -0
  31. package/dist/src/projections/index.js +4 -0
  32. package/dist/src/projections/index.js.map +1 -0
  33. package/dist/src/projections/item-status-projection.d.ts +22 -0
  34. package/dist/src/projections/item-status-projection.d.ts.map +1 -0
  35. package/dist/src/projections/item-status-projection.js +11 -0
  36. package/dist/src/projections/item-status-projection.js.map +1 -0
  37. package/dist/src/projections/item-status-projection.specs.d.ts +2 -0
  38. package/dist/src/projections/item-status-projection.specs.d.ts.map +1 -0
  39. package/dist/src/projections/item-status-projection.specs.js +119 -0
  40. package/dist/src/projections/item-status-projection.specs.js.map +1 -0
  41. package/dist/src/projections/latest-run-projection.d.ts +15 -0
  42. package/dist/src/projections/latest-run-projection.d.ts.map +1 -0
  43. package/dist/src/projections/latest-run-projection.js +7 -0
  44. package/dist/src/projections/latest-run-projection.js.map +1 -0
  45. package/dist/src/projections/latest-run-projection.specs.d.ts +2 -0
  46. package/dist/src/projections/latest-run-projection.specs.d.ts.map +1 -0
  47. package/dist/src/projections/latest-run-projection.specs.js +33 -0
  48. package/dist/src/projections/latest-run-projection.specs.js.map +1 -0
  49. package/dist/src/projections/message-log-projection.d.ts +51 -0
  50. package/dist/src/projections/message-log-projection.d.ts.map +1 -0
  51. package/dist/src/projections/message-log-projection.js +51 -0
  52. package/dist/src/projections/message-log-projection.js.map +1 -0
  53. package/dist/src/projections/message-log-projection.specs.d.ts +2 -0
  54. package/dist/src/projections/message-log-projection.specs.d.ts.map +1 -0
  55. package/dist/src/projections/message-log-projection.specs.js +101 -0
  56. package/dist/src/projections/message-log-projection.specs.js.map +1 -0
  57. package/dist/src/projections/node-status-projection.d.ts +23 -0
  58. package/dist/src/projections/node-status-projection.d.ts.map +1 -0
  59. package/dist/src/projections/node-status-projection.js +10 -0
  60. package/dist/src/projections/node-status-projection.js.map +1 -0
  61. package/dist/src/projections/node-status-projection.specs.d.ts +2 -0
  62. package/dist/src/projections/node-status-projection.specs.d.ts.map +1 -0
  63. package/dist/src/projections/node-status-projection.specs.js +116 -0
  64. package/dist/src/projections/node-status-projection.specs.js.map +1 -0
  65. package/dist/src/projections/phased-execution-projection.d.ts +77 -0
  66. package/dist/src/projections/phased-execution-projection.d.ts.map +1 -0
  67. package/dist/src/projections/phased-execution-projection.js +54 -0
  68. package/dist/src/projections/phased-execution-projection.js.map +1 -0
  69. package/dist/src/projections/phased-execution-projection.specs.d.ts +2 -0
  70. package/dist/src/projections/phased-execution-projection.specs.d.ts.map +1 -0
  71. package/dist/src/projections/phased-execution-projection.specs.js +171 -0
  72. package/dist/src/projections/phased-execution-projection.specs.js.map +1 -0
  73. package/dist/src/projections/settled-instance-projection.d.ts +67 -0
  74. package/dist/src/projections/settled-instance-projection.d.ts.map +1 -0
  75. package/dist/src/projections/settled-instance-projection.js +66 -0
  76. package/dist/src/projections/settled-instance-projection.js.map +1 -0
  77. package/dist/src/projections/settled-instance-projection.specs.d.ts +2 -0
  78. package/dist/src/projections/settled-instance-projection.specs.d.ts.map +1 -0
  79. package/dist/src/projections/settled-instance-projection.specs.js +217 -0
  80. package/dist/src/projections/settled-instance-projection.specs.js.map +1 -0
  81. package/dist/src/projections/stats-projection.d.ts +9 -0
  82. package/dist/src/projections/stats-projection.d.ts.map +1 -0
  83. package/dist/src/projections/stats-projection.js +16 -0
  84. package/dist/src/projections/stats-projection.js.map +1 -0
  85. package/dist/src/projections/stats-projection.specs.d.ts +2 -0
  86. package/dist/src/projections/stats-projection.specs.d.ts.map +1 -0
  87. package/dist/src/projections/stats-projection.specs.js +91 -0
  88. package/dist/src/projections/stats-projection.specs.js.map +1 -0
  89. package/dist/src/runtime/await-tracker.d.ts +17 -7
  90. package/dist/src/runtime/await-tracker.d.ts.map +1 -1
  91. package/dist/src/runtime/await-tracker.js +32 -29
  92. package/dist/src/runtime/await-tracker.js.map +1 -1
  93. package/dist/src/runtime/await-tracker.specs.js +56 -38
  94. package/dist/src/runtime/await-tracker.specs.js.map +1 -1
  95. package/dist/src/runtime/context.d.ts +1 -1
  96. package/dist/src/runtime/context.d.ts.map +1 -1
  97. package/dist/src/runtime/event-command-map.d.ts +3 -3
  98. package/dist/src/runtime/event-command-map.d.ts.map +1 -1
  99. package/dist/src/runtime/event-command-map.js +6 -2
  100. package/dist/src/runtime/event-command-map.js.map +1 -1
  101. package/dist/src/runtime/phased-executor.d.ts +15 -9
  102. package/dist/src/runtime/phased-executor.d.ts.map +1 -1
  103. package/dist/src/runtime/phased-executor.js +126 -104
  104. package/dist/src/runtime/phased-executor.js.map +1 -1
  105. package/dist/src/runtime/phased-executor.specs.js +243 -81
  106. package/dist/src/runtime/phased-executor.specs.js.map +1 -1
  107. package/dist/src/runtime/pipeline-runtime.d.ts.map +1 -1
  108. package/dist/src/runtime/pipeline-runtime.js +2 -2
  109. package/dist/src/runtime/pipeline-runtime.js.map +1 -1
  110. package/dist/src/runtime/pipeline-runtime.specs.js +35 -0
  111. package/dist/src/runtime/pipeline-runtime.specs.js.map +1 -1
  112. package/dist/src/runtime/settled-tracker.d.ts +12 -9
  113. package/dist/src/runtime/settled-tracker.d.ts.map +1 -1
  114. package/dist/src/runtime/settled-tracker.js +92 -77
  115. package/dist/src/runtime/settled-tracker.js.map +1 -1
  116. package/dist/src/runtime/settled-tracker.specs.js +568 -118
  117. package/dist/src/runtime/settled-tracker.specs.js.map +1 -1
  118. package/dist/src/server/pipeline-server.d.ts +31 -9
  119. package/dist/src/server/pipeline-server.d.ts.map +1 -1
  120. package/dist/src/server/pipeline-server.e2e.specs.js +2 -10
  121. package/dist/src/server/pipeline-server.e2e.specs.js.map +1 -1
  122. package/dist/src/server/pipeline-server.js +418 -134
  123. package/dist/src/server/pipeline-server.js.map +1 -1
  124. package/dist/src/server/pipeline-server.specs.js +777 -32
  125. package/dist/src/server/pipeline-server.specs.js.map +1 -1
  126. package/dist/src/server/sse-manager.specs.js +55 -35
  127. package/dist/src/server/sse-manager.specs.js.map +1 -1
  128. package/dist/src/store/index.d.ts +3 -0
  129. package/dist/src/store/index.d.ts.map +1 -0
  130. package/dist/src/store/index.js +3 -0
  131. package/dist/src/store/index.js.map +1 -0
  132. package/dist/src/store/pipeline-event-store.d.ts +10 -0
  133. package/dist/src/store/pipeline-event-store.d.ts.map +1 -0
  134. package/dist/src/store/pipeline-event-store.js +112 -0
  135. package/dist/src/store/pipeline-event-store.js.map +1 -0
  136. package/dist/src/store/pipeline-event-store.specs.d.ts +2 -0
  137. package/dist/src/store/pipeline-event-store.specs.d.ts.map +1 -0
  138. package/dist/src/store/pipeline-event-store.specs.js +287 -0
  139. package/dist/src/store/pipeline-event-store.specs.js.map +1 -0
  140. package/dist/src/store/pipeline-read-model.d.ts +49 -0
  141. package/dist/src/store/pipeline-read-model.d.ts.map +1 -0
  142. package/dist/src/store/pipeline-read-model.js +157 -0
  143. package/dist/src/store/pipeline-read-model.js.map +1 -0
  144. package/dist/src/store/pipeline-read-model.specs.d.ts +2 -0
  145. package/dist/src/store/pipeline-read-model.specs.d.ts.map +1 -0
  146. package/dist/src/store/pipeline-read-model.specs.js +830 -0
  147. package/dist/src/store/pipeline-read-model.specs.js.map +1 -0
  148. package/dist/src/testing/fixtures/kanban-full.pipeline.js +2 -2
  149. package/dist/src/testing/fixtures/kanban-full.pipeline.js.map +1 -1
  150. package/dist/src/testing/fixtures/kanban.pipeline.js +2 -2
  151. package/dist/src/testing/fixtures/kanban.pipeline.js.map +1 -1
  152. package/dist/tsconfig.tsbuildinfo +1 -1
  153. package/ketchup-plan.md +960 -0
  154. package/package.json +7 -3
  155. package/src/builder/define.specs.ts +3 -3
  156. package/src/builder/define.ts +24 -11
  157. package/src/core/descriptors.ts +7 -2
  158. package/src/graph/filter-graph.specs.ts +241 -0
  159. package/src/graph/filter-graph.ts +111 -0
  160. package/src/graph/types.ts +10 -0
  161. package/src/index.ts +1 -2
  162. package/src/projections/await-tracker-projection.ts +68 -0
  163. package/src/projections/index.ts +11 -0
  164. package/src/projections/item-status-projection.specs.ts +130 -0
  165. package/src/projections/item-status-projection.ts +32 -0
  166. package/src/projections/latest-run-projection.specs.ts +38 -0
  167. package/src/projections/latest-run-projection.ts +20 -0
  168. package/src/projections/message-log-projection.specs.ts +118 -0
  169. package/src/projections/message-log-projection.ts +113 -0
  170. package/src/projections/node-status-projection.specs.ts +127 -0
  171. package/src/projections/node-status-projection.ts +33 -0
  172. package/src/projections/phased-execution-projection.specs.ts +202 -0
  173. package/src/projections/phased-execution-projection.ts +146 -0
  174. package/src/projections/settled-instance-projection.specs.ts +249 -0
  175. package/src/projections/settled-instance-projection.ts +160 -0
  176. package/src/projections/stats-projection.specs.ts +105 -0
  177. package/src/projections/stats-projection.ts +26 -0
  178. package/src/runtime/await-tracker.specs.ts +57 -34
  179. package/src/runtime/await-tracker.ts +43 -31
  180. package/src/runtime/context.ts +1 -1
  181. package/src/runtime/event-command-map.ts +11 -4
  182. package/src/runtime/phased-executor.specs.ts +357 -81
  183. package/src/runtime/phased-executor.ts +142 -126
  184. package/src/runtime/pipeline-runtime.specs.ts +42 -0
  185. package/src/runtime/pipeline-runtime.ts +6 -4
  186. package/src/runtime/settled-tracker.specs.ts +716 -120
  187. package/src/runtime/settled-tracker.ts +104 -98
  188. package/src/server/pipeline-server.e2e.specs.ts +10 -16
  189. package/src/server/pipeline-server.specs.ts +964 -49
  190. package/src/server/pipeline-server.ts +522 -156
  191. package/src/server/sse-manager.specs.ts +67 -36
  192. package/src/store/index.ts +2 -0
  193. package/src/store/pipeline-event-store.specs.ts +309 -0
  194. package/src/store/pipeline-event-store.ts +156 -0
  195. package/src/store/pipeline-read-model.specs.ts +967 -0
  196. package/src/store/pipeline-read-model.ts +223 -0
  197. package/src/testing/fixtures/kanban-full.pipeline.ts +2 -2
  198. package/src/testing/fixtures/kanban.pipeline.ts +2 -2
  199. package/claude.md +0 -160
  200. package/docs/testing-analysis.md +0 -395
  201. package/pomodoro-plan.md +0 -651
@@ -0,0 +1,287 @@
1
+ import { describe, expect, it } from 'vitest';
2
+ import { createPipelineEventStore } from './pipeline-event-store.js';
3
+ describe('PipelineEventStore', () => {
4
+ describe('appendToStream', () => {
5
+ it('should append events and update projections', async () => {
6
+ const { eventStore, database, close } = createPipelineEventStore();
7
+ try {
8
+ await eventStore.appendToStream('pipeline-c1', [
9
+ {
10
+ type: 'ItemStatusChanged',
11
+ data: {
12
+ correlationId: 'c1',
13
+ commandType: 'Cmd',
14
+ itemKey: 'a',
15
+ requestId: 'r1',
16
+ status: 'running',
17
+ attemptCount: 1,
18
+ },
19
+ },
20
+ ]);
21
+ const collection = database.collection('ItemStatus');
22
+ const items = await collection.find();
23
+ expect(items.length).toBe(1);
24
+ expect(items[0]?.status).toBe('running');
25
+ }
26
+ finally {
27
+ await close();
28
+ }
29
+ });
30
+ it('should project NodeStatusChanged events', async () => {
31
+ const { eventStore, database, close } = createPipelineEventStore();
32
+ try {
33
+ await eventStore.appendToStream('pipeline-c1', [
34
+ {
35
+ type: 'NodeStatusChanged',
36
+ data: {
37
+ correlationId: 'c1',
38
+ commandName: 'Cmd',
39
+ nodeId: 'node-1',
40
+ status: 'running',
41
+ previousStatus: 'idle',
42
+ pendingCount: 1,
43
+ endedCount: 0,
44
+ },
45
+ },
46
+ ]);
47
+ const collection = database.collection('NodeStatus');
48
+ const nodes = await collection.find();
49
+ expect(nodes.length).toBe(1);
50
+ expect(nodes[0]?.status).toBe('running');
51
+ }
52
+ finally {
53
+ await close();
54
+ }
55
+ });
56
+ it('should update existing projection documents', async () => {
57
+ const { eventStore, database, close } = createPipelineEventStore();
58
+ try {
59
+ await eventStore.appendToStream('pipeline-c1', [
60
+ {
61
+ type: 'ItemStatusChanged',
62
+ data: {
63
+ correlationId: 'c1',
64
+ commandType: 'Cmd',
65
+ itemKey: 'a',
66
+ requestId: 'r1',
67
+ status: 'running',
68
+ attemptCount: 1,
69
+ },
70
+ },
71
+ ]);
72
+ await eventStore.appendToStream('pipeline-c1', [
73
+ {
74
+ type: 'ItemStatusChanged',
75
+ data: {
76
+ correlationId: 'c1',
77
+ commandType: 'Cmd',
78
+ itemKey: 'a',
79
+ requestId: 'r1',
80
+ status: 'success',
81
+ attemptCount: 1,
82
+ },
83
+ },
84
+ ]);
85
+ const collection = database.collection('ItemStatus');
86
+ const items = await collection.find();
87
+ expect(items.length).toBe(1);
88
+ expect(items[0]?.status).toBe('success');
89
+ }
90
+ finally {
91
+ await close();
92
+ }
93
+ });
94
+ });
95
+ describe('readModel integration', () => {
96
+ it('should provide working read model queries', async () => {
97
+ const { eventStore, readModel, close } = createPipelineEventStore();
98
+ try {
99
+ await eventStore.appendToStream('pipeline-c1', [
100
+ {
101
+ type: 'ItemStatusChanged',
102
+ data: {
103
+ correlationId: 'c1',
104
+ commandType: 'Cmd',
105
+ itemKey: 'a',
106
+ requestId: 'r1',
107
+ status: 'running',
108
+ attemptCount: 1,
109
+ },
110
+ },
111
+ {
112
+ type: 'ItemStatusChanged',
113
+ data: {
114
+ correlationId: 'c1',
115
+ commandType: 'Cmd',
116
+ itemKey: 'b',
117
+ requestId: 'r2',
118
+ status: 'success',
119
+ attemptCount: 1,
120
+ },
121
+ },
122
+ ]);
123
+ const stats = await readModel.computeCommandStats('c1', 'Cmd');
124
+ expect(stats).toEqual({
125
+ pendingCount: 1,
126
+ endedCount: 1,
127
+ aggregateStatus: 'running',
128
+ });
129
+ }
130
+ finally {
131
+ await close();
132
+ }
133
+ });
134
+ it('should detect correlation via read model', async () => {
135
+ const { eventStore, readModel, close } = createPipelineEventStore();
136
+ try {
137
+ expect(await readModel.hasCorrelation('c1')).toBe(false);
138
+ await eventStore.appendToStream('pipeline-c1', [
139
+ {
140
+ type: 'NodeStatusChanged',
141
+ data: {
142
+ correlationId: 'c1',
143
+ commandName: 'Cmd',
144
+ nodeId: 'node-1',
145
+ status: 'running',
146
+ previousStatus: 'idle',
147
+ pendingCount: 1,
148
+ endedCount: 0,
149
+ },
150
+ },
151
+ ]);
152
+ expect(await readModel.hasCorrelation('c1')).toBe(true);
153
+ }
154
+ finally {
155
+ await close();
156
+ }
157
+ });
158
+ });
159
+ describe('settled instance projection', () => {
160
+ it('should project SettledInstanceCreated events', async () => {
161
+ const { eventStore, database, close } = createPipelineEventStore();
162
+ try {
163
+ await eventStore.appendToStream('settled-c1', [
164
+ {
165
+ type: 'SettledInstanceCreated',
166
+ data: {
167
+ templateId: 'template-CmdA,CmdB',
168
+ correlationId: 'c1',
169
+ commandTypes: ['CmdA', 'CmdB'],
170
+ },
171
+ },
172
+ ]);
173
+ const collection = database.collection('SettledInstance');
174
+ const instances = await collection.find();
175
+ expect(instances.length).toBe(1);
176
+ expect(instances[0]?.status).toBe('active');
177
+ expect(instances[0]?.commandTrackers).toHaveLength(2);
178
+ }
179
+ finally {
180
+ await close();
181
+ }
182
+ });
183
+ it('should update settled instance through lifecycle events', async () => {
184
+ const { eventStore, database, close } = createPipelineEventStore();
185
+ try {
186
+ await eventStore.appendToStream('settled-c1', [
187
+ {
188
+ type: 'SettledInstanceCreated',
189
+ data: {
190
+ templateId: 'template-CmdA',
191
+ correlationId: 'c1',
192
+ commandTypes: ['CmdA'],
193
+ },
194
+ },
195
+ {
196
+ type: 'SettledCommandStarted',
197
+ data: {
198
+ templateId: 'template-CmdA',
199
+ correlationId: 'c1',
200
+ commandType: 'CmdA',
201
+ },
202
+ },
203
+ ]);
204
+ const collection = database.collection('SettledInstance');
205
+ const instances = await collection.find();
206
+ expect(instances.length).toBe(1);
207
+ expect(instances[0]?.commandTrackers[0]?.hasStarted).toBe(true);
208
+ expect(instances[0]?.commandTrackers[0]?.hasCompleted).toBe(false);
209
+ }
210
+ finally {
211
+ await close();
212
+ }
213
+ });
214
+ });
215
+ describe('phased execution projection', () => {
216
+ it('should project PhasedExecutionStarted events', async () => {
217
+ const { eventStore, database, close } = createPipelineEventStore();
218
+ try {
219
+ await eventStore.appendToStream('phased-c1', [
220
+ {
221
+ type: 'PhasedExecutionStarted',
222
+ data: {
223
+ executionId: 'exec-1',
224
+ correlationId: 'c1',
225
+ handlerId: 'handler-1',
226
+ triggerEvent: { type: 'TestEvent', correlationId: 'c1', data: {} },
227
+ items: [{ key: 'a', phase: 'prepare', dispatched: false, completed: false }],
228
+ phases: ['prepare', 'execute'],
229
+ },
230
+ },
231
+ ]);
232
+ const collection = database.collection('PhasedExecution');
233
+ const executions = await collection.find();
234
+ expect(executions.length).toBe(1);
235
+ expect(executions[0]?.status).toBe('active');
236
+ expect(executions[0]?.items).toHaveLength(1);
237
+ }
238
+ finally {
239
+ await close();
240
+ }
241
+ });
242
+ it('should update phased execution through lifecycle events', async () => {
243
+ const { eventStore, database, close } = createPipelineEventStore();
244
+ try {
245
+ await eventStore.appendToStream('phased-c1', [
246
+ {
247
+ type: 'PhasedExecutionStarted',
248
+ data: {
249
+ executionId: 'exec-1',
250
+ correlationId: 'c1',
251
+ handlerId: 'handler-1',
252
+ triggerEvent: { type: 'TestEvent', correlationId: 'c1', data: {} },
253
+ items: [{ key: 'a', phase: 'prepare', dispatched: false, completed: false }],
254
+ phases: ['prepare'],
255
+ },
256
+ },
257
+ {
258
+ type: 'PhasedItemDispatched',
259
+ data: { executionId: 'exec-1', itemKey: 'a', phase: 'prepare' },
260
+ },
261
+ {
262
+ type: 'PhasedItemCompleted',
263
+ data: {
264
+ executionId: 'exec-1',
265
+ itemKey: 'a',
266
+ resultEvent: { type: 'ItemDone', correlationId: 'c1', data: {} },
267
+ },
268
+ },
269
+ {
270
+ type: 'PhasedExecutionCompleted',
271
+ data: { executionId: 'exec-1', success: true, results: ['a'] },
272
+ },
273
+ ]);
274
+ const collection = database.collection('PhasedExecution');
275
+ const executions = await collection.find();
276
+ expect(executions.length).toBe(1);
277
+ expect(executions[0]?.status).toBe('completed');
278
+ expect(executions[0]?.items[0]?.dispatched).toBe(true);
279
+ expect(executions[0]?.items[0]?.completed).toBe(true);
280
+ }
281
+ finally {
282
+ await close();
283
+ }
284
+ });
285
+ });
286
+ });
287
+ //# sourceMappingURL=pipeline-event-store.specs.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"pipeline-event-store.specs.js","sourceRoot":"","sources":["../../../src/store/pipeline-event-store.specs.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,QAAQ,EAAE,MAAM,EAAE,EAAE,EAAE,MAAM,QAAQ,CAAC;AAK9C,OAAO,EAAE,wBAAwB,EAAE,MAAM,wBAAwB,CAAC;AAElE,QAAQ,CAAC,oBAAoB,EAAE,GAAG,EAAE;IAClC,QAAQ,CAAC,gBAAgB,EAAE,GAAG,EAAE;QAC9B,EAAE,CAAC,6CAA6C,EAAE,KAAK,IAAI,EAAE;YAC3D,MAAM,EAAE,UAAU,EAAE,QAAQ,EAAE,KAAK,EAAE,GAAG,wBAAwB,EAAE,CAAC;YACnE,IAAI,CAAC;gBACH,MAAM,UAAU,CAAC,cAAc,CAAC,aAAa,EAAE;oBAC7C;wBACE,IAAI,EAAE,mBAAmB;wBACzB,IAAI,EAAE;4BACJ,aAAa,EAAE,IAAI;4BACnB,WAAW,EAAE,KAAK;4BAClB,OAAO,EAAE,GAAG;4BACZ,SAAS,EAAE,IAAI;4BACf,MAAM,EAAE,SAAS;4BACjB,YAAY,EAAE,CAAC;yBAChB;qBACF;iBACF,CAAC,CAAC;gBAEH,MAAM,UAAU,GAAG,QAAQ,CAAC,UAAU,CAAuC,YAAY,CAAC,CAAC;gBAC3F,MAAM,KAAK,GAAG,MAAM,UAAU,CAAC,IAAI,EAAE,CAAC;gBAEtC,MAAM,CAAC,KAAK,CAAC,MAAM,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC;gBAC7B,MAAM,CAAC,KAAK,CAAC,CAAC,CAAC,EAAE,MAAM,CAAC,CAAC,IAAI,CAAC,SAAS,CAAC,CAAC;YAC3C,CAAC;oBAAS,CAAC;gBACT,MAAM,KAAK,EAAE,CAAC;YAChB,CAAC;QACH,CAAC,CAAC,CAAC;QAEH,EAAE,CAAC,yCAAyC,EAAE,KAAK,IAAI,EAAE;YACvD,MAAM,EAAE,UAAU,EAAE,QAAQ,EAAE,KAAK,EAAE,GAAG,wBAAwB,EAAE,CAAC;YACnE,IAAI,CAAC;gBACH,MAAM,UAAU,CAAC,cAAc,CAAC,aAAa,EAAE;oBAC7C;wBACE,IAAI,EAAE,mBAAmB;wBACzB,IAAI,EAAE;4BACJ,aAAa,EAAE,IAAI;4BACnB,WAAW,EAAE,KAAK;4BAClB,MAAM,EAAE,QAAQ;4BAChB,MAAM,EAAE,SAAS;4BACjB,cAAc,EAAE,MAAM;4BACtB,YAAY,EAAE,CAAC;4BACf,UAAU,EAAE,CAAC;yBACd;qBACF;iBACF,CAAC,CAAC;gBAEH,MAAM,UAAU,GAAG,QAAQ,CAAC,UAAU,CAAuC,YAAY,CAAC,CAAC;gBAC3F,MAAM,KAAK,GAAG,MAAM,UAAU,CAAC,IAAI,EAAE,CAAC;gBAEtC,MAAM,CAAC,KAAK,CAAC,MAAM,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC;gBAC7B,MAAM,CAAC,KAAK,CAAC,CAAC,CAAC,EAAE,MAAM,CAAC,CAAC,IAAI,CAAC,SAAS,CAAC,CAAC;YAC3C,CAAC;oBAAS,CAAC;gBACT,MAAM,KAAK,EAAE,CAAC;YAChB,CAAC;QACH,CAAC,CAAC,CAAC;QAEH,EAAE,CAAC,6CAA6C,EAAE,KAAK,IAAI,EAAE;YAC3D,MAAM,EAAE,UAAU,EAAE,QAAQ,EAAE,KAAK,EAAE,GAAG,wBAAwB,EAAE,CAAC;YACnE,IAAI,CAAC;gBACH,MAAM,UAAU,CAAC,cAAc,CAAC,aAAa,EAAE;oBAC7C;wBACE,IAAI,EAAE,mBAAmB;wBACzB,IAAI,EAAE;4BACJ,aAAa,EAAE,IAAI;4BACnB,WAAW,EAAE,KAAK;4BAClB,OAAO,EAAE,GAAG;4BACZ,SAAS,EAAE,IAAI;4BACf,MAAM,EAAE,SAAS;4BACjB,YAAY,EAAE,CAAC;yBAChB;qBACF;iBACF,CAAC,CAAC;gBAEH,MAAM,UAAU,CAAC,cAAc,CAAC,aAAa,EAAE;oBAC7C;wBACE,IAAI,EAAE,mBAAmB;wBACzB,IAAI,EAAE;4BACJ,aAAa,EAAE,IAAI;4BACnB,WAAW,EAAE,KAAK;4BAClB,OAAO,EAAE,GAAG;4BACZ,SAAS,EAAE,IAAI;4BACf,MAAM,EAAE,SAAS;4BACjB,YAAY,EAAE,CAAC;yBAChB;qBACF;iBACF,CAAC,CAAC;gBAEH,MAAM,UAAU,GAAG,QAAQ,CAAC,UAAU,CAAuC,YAAY,CAAC,CAAC;gBAC3F,MAAM,KAAK,GAAG,MAAM,UAAU,CAAC,IAAI,EAAE,CAAC;gBAEtC,MAAM,CAAC,KAAK,CAAC,MAAM,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC;gBAC7B,MAAM,CAAC,KAAK,CAAC,CAAC,CAAC,EAAE,MAAM,CAAC,CAAC,IAAI,CAAC,SAAS,CAAC,CAAC;YAC3C,CAAC;oBAAS,CAAC;gBACT,MAAM,KAAK,EAAE,CAAC;YAChB,CAAC;QACH,CAAC,CAAC,CAAC;IACL,CAAC,CAAC,CAAC;IAEH,QAAQ,CAAC,uBAAuB,EAAE,GAAG,EAAE;QACrC,EAAE,CAAC,2CAA2C,EAAE,KAAK,IAAI,EAAE;YACzD,MAAM,EAAE,UAAU,EAAE,SAAS,EAAE,KAAK,EAAE,GAAG,wBAAwB,EAAE,CAAC;YACpE,IAAI,CAAC;gBACH,MAAM,UAAU,CAAC,cAAc,CAAC,aAAa,EAAE;oBAC7C;wBACE,IAAI,EAAE,mBAAmB;wBACzB,IAAI,EAAE;4BACJ,aAAa,EAAE,IAAI;4BACnB,WAAW,EAAE,KAAK;4BAClB,OAAO,EAAE,GAAG;4BACZ,SAAS,EAAE,IAAI;4BACf,MAAM,EAAE,SAAS;4BACjB,YAAY,EAAE,CAAC;yBAChB;qBACF;oBACD;wBACE,IAAI,EAAE,mBAAmB;wBACzB,IAAI,EAAE;4BACJ,aAAa,EAAE,IAAI;4BACnB,WAAW,EAAE,KAAK;4BAClB,OAAO,EAAE,GAAG;4BACZ,SAAS,EAAE,IAAI;4BACf,MAAM,EAAE,SAAS;4BACjB,YAAY,EAAE,CAAC;yBAChB;qBACF;iBACF,CAAC,CAAC;gBAEH,MAAM,KAAK,GAAG,MAAM,SAAS,CAAC,mBAAmB,CAAC,IAAI,EAAE,KAAK,CAAC,CAAC;gBAE/D,MAAM,CAAC,KAAK,CAAC,CAAC,OAAO,CAAC;oBACpB,YAAY,EAAE,CAAC;oBACf,UAAU,EAAE,CAAC;oBACb,eAAe,EAAE,SAAS;iBAC3B,CAAC,CAAC;YACL,CAAC;oBAAS,CAAC;gBACT,MAAM,KAAK,EAAE,CAAC;YAChB,CAAC;QACH,CAAC,CAAC,CAAC;QAEH,EAAE,CAAC,0CAA0C,EAAE,KAAK,IAAI,EAAE;YACxD,MAAM,EAAE,UAAU,EAAE,SAAS,EAAE,KAAK,EAAE,GAAG,wBAAwB,EAAE,CAAC;YACpE,IAAI,CAAC;gBACH,MAAM,CAAC,MAAM,SAAS,CAAC,cAAc,CAAC,IAAI,CAAC,CAAC,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;gBAEzD,MAAM,UAAU,CAAC,cAAc,CAAC,aAAa,EAAE;oBAC7C;wBACE,IAAI,EAAE,mBAAmB;wBACzB,IAAI,EAAE;4BACJ,aAAa,EAAE,IAAI;4BACnB,WAAW,EAAE,KAAK;4BAClB,MAAM,EAAE,QAAQ;4BAChB,MAAM,EAAE,SAAS;4BACjB,cAAc,EAAE,MAAM;4BACtB,YAAY,EAAE,CAAC;4BACf,UAAU,EAAE,CAAC;yBACd;qBACF;iBACF,CAAC,CAAC;gBAEH,MAAM,CAAC,MAAM,SAAS,CAAC,cAAc,CAAC,IAAI,CAAC,CAAC,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;YAC1D,CAAC;oBAAS,CAAC;gBACT,MAAM,KAAK,EAAE,CAAC;YAChB,CAAC;QACH,CAAC,CAAC,CAAC;IACL,CAAC,CAAC,CAAC;IAEH,QAAQ,CAAC,6BAA6B,EAAE,GAAG,EAAE;QAC3C,EAAE,CAAC,8CAA8C,EAAE,KAAK,IAAI,EAAE;YAC5D,MAAM,EAAE,UAAU,EAAE,QAAQ,EAAE,KAAK,EAAE,GAAG,wBAAwB,EAAE,CAAC;YACnE,IAAI,CAAC;gBACH,MAAM,UAAU,CAAC,cAAc,CAAC,YAAY,EAAE;oBAC5C;wBACE,IAAI,EAAE,wBAAwB;wBAC9B,IAAI,EAAE;4BACJ,UAAU,EAAE,oBAAoB;4BAChC,aAAa,EAAE,IAAI;4BACnB,YAAY,EAAE,CAAC,MAAM,EAAE,MAAM,CAAC;yBAC/B;qBACF;iBACF,CAAC,CAAC;gBAEH,MAAM,UAAU,GAAG,QAAQ,CAAC,UAAU,CAA4C,iBAAiB,CAAC,CAAC;gBACrG,MAAM,SAAS,GAAG,MAAM,UAAU,CAAC,IAAI,EAAE,CAAC;gBAE1C,MAAM,CAAC,SAAS,CAAC,MAAM,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC;gBACjC,MAAM,CAAC,SAAS,CAAC,CAAC,CAAC,EAAE,MAAM,CAAC,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC;gBAC5C,MAAM,CAAC,SAAS,CAAC,CAAC,CAAC,EAAE,eAAe,CAAC,CAAC,YAAY,CAAC,CAAC,CAAC,CAAC;YACxD,CAAC;oBAAS,CAAC;gBACT,MAAM,KAAK,EAAE,CAAC;YAChB,CAAC;QACH,CAAC,CAAC,CAAC;QAEH,EAAE,CAAC,yDAAyD,EAAE,KAAK,IAAI,EAAE;YACvE,MAAM,EAAE,UAAU,EAAE,QAAQ,EAAE,KAAK,EAAE,GAAG,wBAAwB,EAAE,CAAC;YACnE,IAAI,CAAC;gBACH,MAAM,UAAU,CAAC,cAAc,CAAC,YAAY,EAAE;oBAC5C;wBACE,IAAI,EAAE,wBAAwB;wBAC9B,IAAI,EAAE;4BACJ,UAAU,EAAE,eAAe;4BAC3B,aAAa,EAAE,IAAI;4BACnB,YAAY,EAAE,CAAC,MAAM,CAAC;yBACvB;qBACF;oBACD;wBACE,IAAI,EAAE,uBAAuB;wBAC7B,IAAI,EAAE;4BACJ,UAAU,EAAE,eAAe;4BAC3B,aAAa,EAAE,IAAI;4BACnB,WAAW,EAAE,MAAM;yBACpB;qBACF;iBACF,CAAC,CAAC;gBAEH,MAAM,UAAU,GAAG,QAAQ,CAAC,UAAU,CAA4C,iBAAiB,CAAC,CAAC;gBACrG,MAAM,SAAS,GAAG,MAAM,UAAU,CAAC,IAAI,EAAE,CAAC;gBAE1C,MAAM,CAAC,SAAS,CAAC,MAAM,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC;gBACjC,MAAM,CAAC,SAAS,CAAC,CAAC,CAAC,EAAE,eAAe,CAAC,CAAC,CAAC,EAAE,UAAU,CAAC,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;gBAChE,MAAM,CAAC,SAAS,CAAC,CAAC,CAAC,EAAE,eAAe,CAAC,CAAC,CAAC,EAAE,YAAY,CAAC,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;YACrE,CAAC;oBAAS,CAAC;gBACT,MAAM,KAAK,EAAE,CAAC;YAChB,CAAC;QACH,CAAC,CAAC,CAAC;IACL,CAAC,CAAC,CAAC;IAEH,QAAQ,CAAC,6BAA6B,EAAE,GAAG,EAAE;QAC3C,EAAE,CAAC,8CAA8C,EAAE,KAAK,IAAI,EAAE;YAC5D,MAAM,EAAE,UAAU,EAAE,QAAQ,EAAE,KAAK,EAAE,GAAG,wBAAwB,EAAE,CAAC;YACnE,IAAI,CAAC;gBACH,MAAM,UAAU,CAAC,cAAc,CAAC,WAAW,EAAE;oBAC3C;wBACE,IAAI,EAAE,wBAAwB;wBAC9B,IAAI,EAAE;4BACJ,WAAW,EAAE,QAAQ;4BACrB,aAAa,EAAE,IAAI;4BACnB,SAAS,EAAE,WAAW;4BACtB,YAAY,EAAE,EAAE,IAAI,EAAE,WAAW,EAAE,aAAa,EAAE,IAAI,EAAE,IAAI,EAAE,EAAE,EAAE;4BAClE,KAAK,EAAE,CAAC,EAAE,GAAG,EAAE,GAAG,EAAE,KAAK,EAAE,SAAS,EAAE,UAAU,EAAE,KAAK,EAAE,SAAS,EAAE,KAAK,EAAE,CAAC;4BAC5E,MAAM,EAAE,CAAC,SAAS,EAAE,SAAS,CAAC;yBAC/B;qBACF;iBACF,CAAC,CAAC;gBAEH,MAAM,UAAU,GAAG,QAAQ,CAAC,UAAU,CAA4C,iBAAiB,CAAC,CAAC;gBACrG,MAAM,UAAU,GAAG,MAAM,UAAU,CAAC,IAAI,EAAE,CAAC;gBAE3C,MAAM,CAAC,UAAU,CAAC,MAAM,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC;gBAClC,MAAM,CAAC,UAAU,CAAC,CAAC,CAAC,EAAE,MAAM,CAAC,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC;gBAC7C,MAAM,CAAC,UAAU,CAAC,CAAC,CAAC,EAAE,KAAK,CAAC,CAAC,YAAY,CAAC,CAAC,CAAC,CAAC;YAC/C,CAAC;oBAAS,CAAC;gBACT,MAAM,KAAK,EAAE,CAAC;YAChB,CAAC;QACH,CAAC,CAAC,CAAC;QAEH,EAAE,CAAC,yDAAyD,EAAE,KAAK,IAAI,EAAE;YACvE,MAAM,EAAE,UAAU,EAAE,QAAQ,EAAE,KAAK,EAAE,GAAG,wBAAwB,EAAE,CAAC;YACnE,IAAI,CAAC;gBACH,MAAM,UAAU,CAAC,cAAc,CAAC,WAAW,EAAE;oBAC3C;wBACE,IAAI,EAAE,wBAAwB;wBAC9B,IAAI,EAAE;4BACJ,WAAW,EAAE,QAAQ;4BACrB,aAAa,EAAE,IAAI;4BACnB,SAAS,EAAE,WAAW;4BACtB,YAAY,EAAE,EAAE,IAAI,EAAE,WAAW,EAAE,aAAa,EAAE,IAAI,EAAE,IAAI,EAAE,EAAE,EAAE;4BAClE,KAAK,EAAE,CAAC,EAAE,GAAG,EAAE,GAAG,EAAE,KAAK,EAAE,SAAS,EAAE,UAAU,EAAE,KAAK,EAAE,SAAS,EAAE,KAAK,EAAE,CAAC;4BAC5E,MAAM,EAAE,CAAC,SAAS,CAAC;yBACpB;qBACF;oBACD;wBACE,IAAI,EAAE,sBAAsB;wBAC5B,IAAI,EAAE,EAAE,WAAW,EAAE,QAAQ,EAAE,OAAO,EAAE,GAAG,EAAE,KAAK,EAAE,SAAS,EAAE;qBAChE;oBACD;wBACE,IAAI,EAAE,qBAAqB;wBAC3B,IAAI,EAAE;4BACJ,WAAW,EAAE,QAAQ;4BACrB,OAAO,EAAE,GAAG;4BACZ,WAAW,EAAE,EAAE,IAAI,EAAE,UAAU,EAAE,aAAa,EAAE,IAAI,EAAE,IAAI,EAAE,EAAE,EAAE;yBACjE;qBACF;oBACD;wBACE,IAAI,EAAE,0BAA0B;wBAChC,IAAI,EAAE,EAAE,WAAW,EAAE,QAAQ,EAAE,OAAO,EAAE,IAAI,EAAE,OAAO,EAAE,CAAC,GAAG,CAAC,EAAE;qBAC/D;iBACF,CAAC,CAAC;gBAEH,MAAM,UAAU,GAAG,QAAQ,CAAC,UAAU,CAA4C,iBAAiB,CAAC,CAAC;gBACrG,MAAM,UAAU,GAAG,MAAM,UAAU,CAAC,IAAI,EAAE,CAAC;gBAE3C,MAAM,CAAC,UAAU,CAAC,MAAM,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC;gBAClC,MAAM,CAAC,UAAU,CAAC,CAAC,CAAC,EAAE,MAAM,CAAC,CAAC,IAAI,CAAC,WAAW,CAAC,CAAC;gBAChD,MAAM,CAAC,UAAU,CAAC,CAAC,CAAC,EAAE,KAAK,CAAC,CAAC,CAAC,EAAE,UAAU,CAAC,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;gBACvD,MAAM,CAAC,UAAU,CAAC,CAAC,CAAC,EAAE,KAAK,CAAC,CAAC,CAAC,EAAE,SAAS,CAAC,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;YACxD,CAAC;oBAAS,CAAC;gBACT,MAAM,KAAK,EAAE,CAAC;YAChB,CAAC;QACH,CAAC,CAAC,CAAC;IACL,CAAC,CAAC,CAAC;AACL,CAAC,CAAC,CAAC"}
@@ -0,0 +1,49 @@
1
+ import type { InMemoryDatabase } from '@event-driven-io/emmett';
2
+ import type { NodeStatus } from '../graph/types';
3
+ import type { AwaitTrackerDocument } from '../projections/await-tracker-projection';
4
+ import type { ItemStatusDocument } from '../projections/item-status-projection';
5
+ import type { MessageLogDocument } from '../projections/message-log-projection';
6
+ import type { NodeStatusDocument } from '../projections/node-status-projection';
7
+ import type { PhasedExecutionDocument } from '../projections/phased-execution-projection';
8
+ import type { SettledInstanceDocument } from '../projections/settled-instance-projection';
9
+ export interface CommandStats {
10
+ pendingCount: number;
11
+ endedCount: number;
12
+ aggregateStatus: NodeStatus;
13
+ }
14
+ export interface SettledStats {
15
+ status: NodeStatus;
16
+ pendingCount: number;
17
+ endedCount: number;
18
+ }
19
+ export interface MessageStats {
20
+ totalMessages: number;
21
+ totalCommands: number;
22
+ totalEvents: number;
23
+ }
24
+ export declare class PipelineReadModel {
25
+ private readonly itemStatusCollection;
26
+ private readonly nodeStatusCollection;
27
+ private readonly messageLogCollection;
28
+ private readonly statsCollection;
29
+ private readonly latestRunCollection;
30
+ private readonly settledInstanceCollection;
31
+ private readonly phasedExecutionCollection;
32
+ private readonly awaitTrackerCollection;
33
+ constructor(database: InMemoryDatabase);
34
+ computeCommandStats(correlationId: string, commandType: string): Promise<CommandStats>;
35
+ hasCorrelation(correlationId: string): Promise<boolean>;
36
+ getNodeStatus(correlationId: string, commandName: string): Promise<NodeStatusDocument | null>;
37
+ getItemStatus(correlationId: string, commandType: string, itemKey: string): Promise<ItemStatusDocument | null>;
38
+ getMessages(correlationId?: string): Promise<MessageLogDocument[]>;
39
+ getStats(): Promise<MessageStats>;
40
+ getLatestCorrelationId(): Promise<string | undefined>;
41
+ getSettledInstance(templateId: string, correlationId: string): Promise<SettledInstanceDocument | null>;
42
+ getActiveSettledInstances(correlationId: string): Promise<SettledInstanceDocument[]>;
43
+ getPhasedExecution(executionId: string): Promise<PhasedExecutionDocument | null>;
44
+ getActivePhasedExecutions(correlationId: string): Promise<PhasedExecutionDocument[]>;
45
+ getAwaitState(correlationId: string): Promise<AwaitTrackerDocument | null>;
46
+ computeSettledStats(correlationId: string, templateId: string): Promise<SettledStats>;
47
+ private hasFailedEvent;
48
+ }
49
+ //# sourceMappingURL=pipeline-read-model.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"pipeline-read-model.d.ts","sourceRoot":"","sources":["../../../src/store/pipeline-read-model.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,157 @@
1
+ export class PipelineReadModel {
2
+ constructor(database) {
3
+ this.itemStatusCollection = database.collection('ItemStatus');
4
+ this.nodeStatusCollection = database.collection('NodeStatus');
5
+ this.messageLogCollection = database.collection('MessageLog');
6
+ this.statsCollection = database.collection('Stats');
7
+ this.latestRunCollection = database.collection('LatestRun');
8
+ this.settledInstanceCollection = database.collection('SettledInstance');
9
+ this.phasedExecutionCollection = database.collection('PhasedExecution');
10
+ this.awaitTrackerCollection = database.collection('AwaitTracker');
11
+ }
12
+ async computeCommandStats(correlationId, commandType) {
13
+ const items = await this.itemStatusCollection.find((doc) => doc.correlationId === correlationId && doc.commandType === commandType);
14
+ if (items.length === 0) {
15
+ return { pendingCount: 0, endedCount: 0, aggregateStatus: 'idle' };
16
+ }
17
+ let pendingCount = 0;
18
+ let endedCount = 0;
19
+ let hasError = false;
20
+ for (const item of items) {
21
+ if (item.status === 'running') {
22
+ pendingCount++;
23
+ }
24
+ else {
25
+ endedCount++;
26
+ if (item.status === 'error') {
27
+ hasError = true;
28
+ }
29
+ }
30
+ }
31
+ let aggregateStatus;
32
+ if (pendingCount > 0) {
33
+ aggregateStatus = 'running';
34
+ }
35
+ else if (endedCount === 0) {
36
+ aggregateStatus = 'idle';
37
+ }
38
+ else if (hasError) {
39
+ aggregateStatus = 'error';
40
+ }
41
+ else {
42
+ aggregateStatus = 'success';
43
+ }
44
+ return { pendingCount, endedCount, aggregateStatus };
45
+ }
46
+ async hasCorrelation(correlationId) {
47
+ const nodes = await this.nodeStatusCollection.find((doc) => doc.correlationId === correlationId);
48
+ return nodes.length > 0;
49
+ }
50
+ async getNodeStatus(correlationId, commandName) {
51
+ const nodes = await this.nodeStatusCollection.find((doc) => doc.correlationId === correlationId && doc.commandName === commandName);
52
+ if (nodes.length === 0) {
53
+ return null;
54
+ }
55
+ const node = nodes[0];
56
+ return {
57
+ correlationId: node.correlationId,
58
+ commandName: node.commandName,
59
+ status: node.status,
60
+ pendingCount: node.pendingCount,
61
+ endedCount: node.endedCount,
62
+ };
63
+ }
64
+ async getItemStatus(correlationId, commandType, itemKey) {
65
+ const items = await this.itemStatusCollection.find((doc) => doc.correlationId === correlationId && doc.commandType === commandType && doc.itemKey === itemKey);
66
+ if (items.length === 0) {
67
+ return null;
68
+ }
69
+ const item = items[0];
70
+ return {
71
+ correlationId: item.correlationId,
72
+ commandType: item.commandType,
73
+ itemKey: item.itemKey,
74
+ currentRequestId: item.currentRequestId,
75
+ status: item.status,
76
+ attemptCount: item.attemptCount,
77
+ };
78
+ }
79
+ async getMessages(correlationId) {
80
+ if (correlationId) {
81
+ return this.messageLogCollection.find((doc) => doc.correlationId === correlationId);
82
+ }
83
+ return this.messageLogCollection.find(() => true);
84
+ }
85
+ async getStats() {
86
+ const docs = await this.statsCollection.find((doc) => doc.totalMessages !== undefined);
87
+ if (docs.length === 0) {
88
+ return { totalMessages: 0, totalCommands: 0, totalEvents: 0 };
89
+ }
90
+ const stats = docs[0];
91
+ return {
92
+ totalMessages: stats.totalMessages,
93
+ totalCommands: stats.totalCommands,
94
+ totalEvents: stats.totalEvents,
95
+ };
96
+ }
97
+ async getLatestCorrelationId() {
98
+ const docs = await this.latestRunCollection.find(() => true);
99
+ if (docs.length === 0) {
100
+ return undefined;
101
+ }
102
+ return docs[0].latestCorrelationId;
103
+ }
104
+ async getSettledInstance(templateId, correlationId) {
105
+ const instances = await this.settledInstanceCollection.find((doc) => doc.templateId === templateId && doc.correlationId === correlationId);
106
+ if (instances.length === 0) {
107
+ return null;
108
+ }
109
+ return instances[0];
110
+ }
111
+ async getActiveSettledInstances(correlationId) {
112
+ return this.settledInstanceCollection.find((doc) => doc.correlationId === correlationId && doc.status === 'active');
113
+ }
114
+ async getPhasedExecution(executionId) {
115
+ const executions = await this.phasedExecutionCollection.find((doc) => doc.executionId === executionId);
116
+ if (executions.length === 0) {
117
+ return null;
118
+ }
119
+ return executions[0];
120
+ }
121
+ async getActivePhasedExecutions(correlationId) {
122
+ return this.phasedExecutionCollection.find((doc) => doc.correlationId === correlationId && doc.status === 'active');
123
+ }
124
+ async getAwaitState(correlationId) {
125
+ const docs = await this.awaitTrackerCollection.find((doc) => doc.correlationId === correlationId && doc.status === 'pending');
126
+ if (docs.length === 0) {
127
+ return null;
128
+ }
129
+ return docs[0];
130
+ }
131
+ async computeSettledStats(correlationId, templateId) {
132
+ const instance = await this.getSettledInstance(templateId, correlationId);
133
+ if (instance === null) {
134
+ return { status: 'idle', pendingCount: 0, endedCount: 0 };
135
+ }
136
+ const endedCount = instance.firedCount ?? 0;
137
+ if (instance.status === 'active') {
138
+ const hasFailure = this.hasFailedEvent(instance);
139
+ const hasFiredBefore = endedCount > 0;
140
+ const status = hasFailure ? 'error' : hasFiredBefore ? 'success' : 'running';
141
+ return { status, pendingCount: 1, endedCount };
142
+ }
143
+ const status = this.hasFailedEvent(instance) ? 'error' : endedCount > 0 ? 'success' : 'idle';
144
+ return { status, pendingCount: 0, endedCount };
145
+ }
146
+ hasFailedEvent(instance) {
147
+ for (const tracker of instance.commandTrackers) {
148
+ for (const event of tracker.events) {
149
+ if (event.type.includes('Failed')) {
150
+ return true;
151
+ }
152
+ }
153
+ }
154
+ return false;
155
+ }
156
+ }
157
+ //# sourceMappingURL=pipeline-read-model.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"pipeline-read-model.js","sourceRoot":"","sources":["../../../src/store/pipeline-read-model.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,2 @@
1
+ export {};
2
+ //# sourceMappingURL=pipeline-read-model.specs.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"pipeline-read-model.specs.d.ts","sourceRoot":"","sources":["../../../src/store/pipeline-read-model.specs.ts"],"names":[],"mappings":""}