bunqueue 2.8.0 → 2.8.1

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 (291) hide show
  1. package/README.md +26 -11
  2. package/dist/application/backgroundTasks.d.ts.map +1 -1
  3. package/dist/application/backgroundTasks.js +83 -0
  4. package/dist/application/backgroundTasks.js.map +1 -1
  5. package/dist/application/clientTracking.d.ts +23 -0
  6. package/dist/application/clientTracking.d.ts.map +1 -1
  7. package/dist/application/clientTracking.js +80 -25
  8. package/dist/application/clientTracking.js.map +1 -1
  9. package/dist/application/contextFactory.d.ts +6 -0
  10. package/dist/application/contextFactory.d.ts.map +1 -1
  11. package/dist/application/contextFactory.js +7 -0
  12. package/dist/application/contextFactory.js.map +1 -1
  13. package/dist/application/dlqManager.d.ts.map +1 -1
  14. package/dist/application/dlqManager.js +5 -0
  15. package/dist/application/dlqManager.js.map +1 -1
  16. package/dist/application/eventsManager.js.map +1 -1
  17. package/dist/application/lockManager.d.ts +1 -1
  18. package/dist/application/lockManager.d.ts.map +1 -1
  19. package/dist/application/lockManager.js +1 -1
  20. package/dist/application/lockManager.js.map +1 -1
  21. package/dist/application/operations/ack.d.ts.map +1 -1
  22. package/dist/application/operations/ack.js +32 -33
  23. package/dist/application/operations/ack.js.map +1 -1
  24. package/dist/application/operations/jobManagement.d.ts +1 -1
  25. package/dist/application/operations/jobManagement.d.ts.map +1 -1
  26. package/dist/application/operations/jobManagement.js +3 -2
  27. package/dist/application/operations/jobManagement.js.map +1 -1
  28. package/dist/application/operations/push.js.map +1 -1
  29. package/dist/application/operations/queryOperations.d.ts.map +1 -1
  30. package/dist/application/operations/queryOperations.js +37 -3
  31. package/dist/application/operations/queryOperations.js.map +1 -1
  32. package/dist/application/operations/queueControl.d.ts +16 -4
  33. package/dist/application/operations/queueControl.d.ts.map +1 -1
  34. package/dist/application/operations/queueControl.js +119 -23
  35. package/dist/application/operations/queueControl.js.map +1 -1
  36. package/dist/application/queueManager.d.ts +17 -3
  37. package/dist/application/queueManager.d.ts.map +1 -1
  38. package/dist/application/queueManager.js +106 -27
  39. package/dist/application/queueManager.js.map +1 -1
  40. package/dist/application/stallDetection.js +1 -0
  41. package/dist/application/stallDetection.js.map +1 -1
  42. package/dist/application/types.d.ts +2 -1
  43. package/dist/application/types.d.ts.map +1 -1
  44. package/dist/cli/client.d.ts.map +1 -1
  45. package/dist/cli/client.js +15 -2
  46. package/dist/cli/client.js.map +1 -1
  47. package/dist/cli/index.d.ts.map +1 -1
  48. package/dist/cli/index.js +31 -2
  49. package/dist/cli/index.js.map +1 -1
  50. package/dist/cli/output.d.ts +1 -1
  51. package/dist/cli/output.d.ts.map +1 -1
  52. package/dist/cli/output.js +71 -9
  53. package/dist/cli/output.js.map +1 -1
  54. package/dist/client/bunqueue/batch.js +2 -2
  55. package/dist/client/bunqueue/batch.js.map +1 -1
  56. package/dist/client/bunqueue.d.ts.map +1 -1
  57. package/dist/client/bunqueue.js +3 -3
  58. package/dist/client/bunqueue.js.map +1 -1
  59. package/dist/client/flow.d.ts.map +1 -1
  60. package/dist/client/flow.js +3 -1
  61. package/dist/client/flow.js.map +1 -1
  62. package/dist/client/flowJobFactory.d.ts +8 -1
  63. package/dist/client/flowJobFactory.d.ts.map +1 -1
  64. package/dist/client/flowJobFactory.js +328 -56
  65. package/dist/client/flowJobFactory.js.map +1 -1
  66. package/dist/client/flowPush.d.ts.map +1 -1
  67. package/dist/client/flowPush.js +95 -46
  68. package/dist/client/flowPush.js.map +1 -1
  69. package/dist/client/jobConversion.d.ts.map +1 -1
  70. package/dist/client/jobConversion.js +12 -4
  71. package/dist/client/jobConversion.js.map +1 -1
  72. package/dist/client/queue/bullmqCompat.d.ts +1 -0
  73. package/dist/client/queue/bullmqCompat.d.ts.map +1 -1
  74. package/dist/client/queue/dlq.js.map +1 -1
  75. package/dist/client/queue/dlqOps.d.ts.map +1 -1
  76. package/dist/client/queue/dlqOps.js.map +1 -1
  77. package/dist/client/queue/helpers.js.map +1 -1
  78. package/dist/client/queue/jobProxy.d.ts +22 -3
  79. package/dist/client/queue/jobProxy.d.ts.map +1 -1
  80. package/dist/client/queue/jobProxy.js +347 -66
  81. package/dist/client/queue/jobProxy.js.map +1 -1
  82. package/dist/client/queue/operations/add.d.ts +1 -0
  83. package/dist/client/queue/operations/add.d.ts.map +1 -1
  84. package/dist/client/queue/operations/add.js +126 -29
  85. package/dist/client/queue/operations/add.js.map +1 -1
  86. package/dist/client/queue/operations/management.d.ts +1 -1
  87. package/dist/client/queue/operations/management.d.ts.map +1 -1
  88. package/dist/client/queue/operations/management.js +27 -9
  89. package/dist/client/queue/operations/management.js.map +1 -1
  90. package/dist/client/queue/operations/query.d.ts +12 -0
  91. package/dist/client/queue/operations/query.d.ts.map +1 -1
  92. package/dist/client/queue/operations/query.js +44 -4
  93. package/dist/client/queue/operations/query.js.map +1 -1
  94. package/dist/client/queue/queue.d.ts.map +1 -1
  95. package/dist/client/queue/queue.js +8 -1
  96. package/dist/client/queue/queue.js.map +1 -1
  97. package/dist/client/queue/scheduler.d.ts +2 -0
  98. package/dist/client/queue/scheduler.d.ts.map +1 -1
  99. package/dist/client/queue/scheduler.js +28 -0
  100. package/dist/client/queue/scheduler.js.map +1 -1
  101. package/dist/client/queue/stall.js.map +1 -1
  102. package/dist/client/sandboxed/worker.d.ts.map +1 -1
  103. package/dist/client/sandboxed/worker.js +57 -15
  104. package/dist/client/sandboxed/worker.js.map +1 -1
  105. package/dist/client/sandboxed/wrapper.d.ts.map +1 -1
  106. package/dist/client/sandboxed/wrapper.js +62 -10
  107. package/dist/client/sandboxed/wrapper.js.map +1 -1
  108. package/dist/client/tcp/client.d.ts +9 -0
  109. package/dist/client/tcp/client.d.ts.map +1 -1
  110. package/dist/client/tcp/client.js +84 -28
  111. package/dist/client/tcp/client.js.map +1 -1
  112. package/dist/client/tcp/connection.d.ts.map +1 -1
  113. package/dist/client/tcp/connection.js +6 -1
  114. package/dist/client/tcp/connection.js.map +1 -1
  115. package/dist/client/tcp/types.d.ts +7 -0
  116. package/dist/client/tcp/types.d.ts.map +1 -1
  117. package/dist/client/types.d.ts +8 -4
  118. package/dist/client/types.d.ts.map +1 -1
  119. package/dist/client/types.js.map +1 -1
  120. package/dist/client/worker/ackBatcher.d.ts.map +1 -1
  121. package/dist/client/worker/ackBatcher.js +18 -8
  122. package/dist/client/worker/ackBatcher.js.map +1 -1
  123. package/dist/client/worker/processor.d.ts.map +1 -1
  124. package/dist/client/worker/processor.js +54 -99
  125. package/dist/client/worker/processor.js.map +1 -1
  126. package/dist/client/worker/processorHandlers.d.ts +55 -0
  127. package/dist/client/worker/processorHandlers.d.ts.map +1 -0
  128. package/dist/client/worker/processorHandlers.js +373 -0
  129. package/dist/client/worker/processorHandlers.js.map +1 -0
  130. package/dist/client/workflow/compensator.d.ts +15 -0
  131. package/dist/client/workflow/compensator.d.ts.map +1 -0
  132. package/dist/client/workflow/compensator.js +46 -0
  133. package/dist/client/workflow/compensator.js.map +1 -0
  134. package/dist/client/workflow/emitter.d.ts.map +1 -1
  135. package/dist/client/workflow/emitter.js +15 -3
  136. package/dist/client/workflow/emitter.js.map +1 -1
  137. package/dist/client/workflow/engine.d.ts +8 -1
  138. package/dist/client/workflow/engine.d.ts.map +1 -1
  139. package/dist/client/workflow/engine.js +9 -0
  140. package/dist/client/workflow/engine.js.map +1 -1
  141. package/dist/client/workflow/executor.d.ts +5 -2
  142. package/dist/client/workflow/executor.d.ts.map +1 -1
  143. package/dist/client/workflow/executor.js +43 -60
  144. package/dist/client/workflow/executor.js.map +1 -1
  145. package/dist/client/workflow/index.d.ts +1 -1
  146. package/dist/client/workflow/index.d.ts.map +1 -1
  147. package/dist/client/workflow/loops.d.ts +1 -1
  148. package/dist/client/workflow/loops.d.ts.map +1 -1
  149. package/dist/client/workflow/loops.js +10 -1
  150. package/dist/client/workflow/loops.js.map +1 -1
  151. package/dist/client/workflow/recovery.d.ts +23 -0
  152. package/dist/client/workflow/recovery.d.ts.map +1 -0
  153. package/dist/client/workflow/recovery.js +74 -0
  154. package/dist/client/workflow/recovery.js.map +1 -0
  155. package/dist/client/workflow/runner.d.ts.map +1 -1
  156. package/dist/client/workflow/runner.js +7 -5
  157. package/dist/client/workflow/runner.js.map +1 -1
  158. package/dist/client/workflow/store.d.ts +2 -0
  159. package/dist/client/workflow/store.d.ts.map +1 -1
  160. package/dist/client/workflow/store.js +6 -0
  161. package/dist/client/workflow/store.js.map +1 -1
  162. package/dist/client/workflow/types.d.ts +41 -22
  163. package/dist/client/workflow/types.d.ts.map +1 -1
  164. package/dist/client/workflow/workflow.d.ts +17 -14
  165. package/dist/client/workflow/workflow.d.ts.map +1 -1
  166. package/dist/client/workflow/workflow.js +30 -20
  167. package/dist/client/workflow/workflow.js.map +1 -1
  168. package/dist/domain/queue/dlqShard.d.ts.map +1 -1
  169. package/dist/domain/queue/dlqShard.js +6 -0
  170. package/dist/domain/queue/dlqShard.js.map +1 -1
  171. package/dist/domain/queue/priorityQueue.d.ts +2 -2
  172. package/dist/domain/queue/priorityQueue.d.ts.map +1 -1
  173. package/dist/domain/queue/priorityQueue.js +5 -3
  174. package/dist/domain/queue/priorityQueue.js.map +1 -1
  175. package/dist/domain/types/command.d.ts +22 -0
  176. package/dist/domain/types/command.d.ts.map +1 -1
  177. package/dist/domain/types/cron.d.ts +21 -0
  178. package/dist/domain/types/cron.d.ts.map +1 -1
  179. package/dist/domain/types/cron.js +1 -0
  180. package/dist/domain/types/cron.js.map +1 -1
  181. package/dist/domain/types/job.d.ts.map +1 -1
  182. package/dist/domain/types/job.js +9 -2
  183. package/dist/domain/types/job.js.map +1 -1
  184. package/dist/domain/types/response.d.ts +2 -0
  185. package/dist/domain/types/response.d.ts.map +1 -1
  186. package/dist/domain/types/response.js.map +1 -1
  187. package/dist/infrastructure/backup/s3BackupOperations.d.ts.map +1 -1
  188. package/dist/infrastructure/backup/s3BackupOperations.js +44 -6
  189. package/dist/infrastructure/backup/s3BackupOperations.js.map +1 -1
  190. package/dist/infrastructure/cloud/cloudAgent.d.ts +1 -1
  191. package/dist/infrastructure/cloud/cloudAgent.d.ts.map +1 -1
  192. package/dist/infrastructure/cloud/cloudAgent.js +9 -11
  193. package/dist/infrastructure/cloud/cloudAgent.js.map +1 -1
  194. package/dist/infrastructure/cloud/commands.js +2 -2
  195. package/dist/infrastructure/cloud/commands.js.map +1 -1
  196. package/dist/infrastructure/cloud/redact.d.ts +11 -0
  197. package/dist/infrastructure/cloud/redact.d.ts.map +1 -0
  198. package/dist/infrastructure/cloud/redact.js +22 -0
  199. package/dist/infrastructure/cloud/redact.js.map +1 -0
  200. package/dist/infrastructure/cloud/snapshotCollector.d.ts +4 -0
  201. package/dist/infrastructure/cloud/snapshotCollector.d.ts.map +1 -1
  202. package/dist/infrastructure/cloud/snapshotCollector.js +32 -17
  203. package/dist/infrastructure/cloud/snapshotCollector.js.map +1 -1
  204. package/dist/infrastructure/cloud/snapshotHelpers.d.ts +9 -2
  205. package/dist/infrastructure/cloud/snapshotHelpers.d.ts.map +1 -1
  206. package/dist/infrastructure/cloud/snapshotHelpers.js +10 -8
  207. package/dist/infrastructure/cloud/snapshotHelpers.js.map +1 -1
  208. package/dist/infrastructure/persistence/schema.d.ts +2 -2
  209. package/dist/infrastructure/persistence/schema.d.ts.map +1 -1
  210. package/dist/infrastructure/persistence/schema.js +16 -2
  211. package/dist/infrastructure/persistence/schema.js.map +1 -1
  212. package/dist/infrastructure/persistence/sqlite.d.ts +54 -1
  213. package/dist/infrastructure/persistence/sqlite.d.ts.map +1 -1
  214. package/dist/infrastructure/persistence/sqlite.js +174 -2
  215. package/dist/infrastructure/persistence/sqlite.js.map +1 -1
  216. package/dist/infrastructure/persistence/sqliteBatch.d.ts +14 -0
  217. package/dist/infrastructure/persistence/sqliteBatch.d.ts.map +1 -1
  218. package/dist/infrastructure/persistence/sqliteBatch.js +29 -0
  219. package/dist/infrastructure/persistence/sqliteBatch.js.map +1 -1
  220. package/dist/infrastructure/persistence/sqliteSerializer.d.ts +16 -0
  221. package/dist/infrastructure/persistence/sqliteSerializer.d.ts.map +1 -1
  222. package/dist/infrastructure/persistence/sqliteSerializer.js +73 -8
  223. package/dist/infrastructure/persistence/sqliteSerializer.js.map +1 -1
  224. package/dist/infrastructure/persistence/statements.d.ts +2 -1
  225. package/dist/infrastructure/persistence/statements.d.ts.map +1 -1
  226. package/dist/infrastructure/persistence/statements.js +3 -2
  227. package/dist/infrastructure/persistence/statements.js.map +1 -1
  228. package/dist/infrastructure/scheduler/cronScheduler.d.ts.map +1 -1
  229. package/dist/infrastructure/scheduler/cronScheduler.js +19 -1
  230. package/dist/infrastructure/scheduler/cronScheduler.js.map +1 -1
  231. package/dist/infrastructure/server/handlers/advanced.d.ts +7 -1
  232. package/dist/infrastructure/server/handlers/advanced.d.ts.map +1 -1
  233. package/dist/infrastructure/server/handlers/advanced.js +41 -10
  234. package/dist/infrastructure/server/handlers/advanced.js.map +1 -1
  235. package/dist/infrastructure/server/handlers/core.d.ts.map +1 -1
  236. package/dist/infrastructure/server/handlers/core.js +8 -0
  237. package/dist/infrastructure/server/handlers/core.js.map +1 -1
  238. package/dist/infrastructure/server/handlers/cron.d.ts.map +1 -1
  239. package/dist/infrastructure/server/handlers/cron.js +1 -0
  240. package/dist/infrastructure/server/handlers/cron.js.map +1 -1
  241. package/dist/infrastructure/server/handlers/dashboard.d.ts.map +1 -1
  242. package/dist/infrastructure/server/handlers/dashboard.js +1 -0
  243. package/dist/infrastructure/server/handlers/dashboard.js.map +1 -1
  244. package/dist/infrastructure/server/handlers/dlq.js.map +1 -1
  245. package/dist/infrastructure/server/handlers/management.d.ts +1 -1
  246. package/dist/infrastructure/server/handlers/management.d.ts.map +1 -1
  247. package/dist/infrastructure/server/handlers/management.js +27 -12
  248. package/dist/infrastructure/server/handlers/management.js.map +1 -1
  249. package/dist/infrastructure/server/handlers/monitoring.js.map +1 -1
  250. package/dist/infrastructure/server/handlers/query.js.map +1 -1
  251. package/dist/infrastructure/server/httpRouteJobs.js.map +1 -1
  252. package/dist/infrastructure/server/httpRouteQueueConfig.js.map +1 -1
  253. package/dist/infrastructure/server/httpRouteQueues.js.map +1 -1
  254. package/dist/infrastructure/server/httpRouteResources.js.map +1 -1
  255. package/dist/infrastructure/server/protocol.d.ts +4 -0
  256. package/dist/infrastructure/server/protocol.d.ts.map +1 -1
  257. package/dist/infrastructure/server/protocol.js +17 -2
  258. package/dist/infrastructure/server/protocol.js.map +1 -1
  259. package/dist/infrastructure/server/socketWriteQueue.d.ts +67 -0
  260. package/dist/infrastructure/server/socketWriteQueue.d.ts.map +1 -0
  261. package/dist/infrastructure/server/socketWriteQueue.js +127 -0
  262. package/dist/infrastructure/server/socketWriteQueue.js.map +1 -0
  263. package/dist/infrastructure/server/tcp.d.ts +17 -0
  264. package/dist/infrastructure/server/tcp.d.ts.map +1 -1
  265. package/dist/infrastructure/server/tcp.js +112 -14
  266. package/dist/infrastructure/server/tcp.js.map +1 -1
  267. package/dist/infrastructure/server/wsHandler.js.map +1 -1
  268. package/dist/main.d.ts.map +1 -1
  269. package/dist/main.js +48 -43
  270. package/dist/main.js.map +1 -1
  271. package/dist/mcp/adapter.d.ts +3 -3
  272. package/dist/mcp/adapter.d.ts.map +1 -1
  273. package/dist/mcp/adapter.js +48 -15
  274. package/dist/mcp/adapter.js.map +1 -1
  275. package/dist/mcp/index.d.ts +3 -3
  276. package/dist/mcp/index.d.ts.map +1 -1
  277. package/dist/mcp/index.js +26 -89
  278. package/dist/mcp/index.js.map +1 -1
  279. package/dist/mcp/server.d.ts +16 -0
  280. package/dist/mcp/server.d.ts.map +1 -0
  281. package/dist/mcp/server.js +101 -0
  282. package/dist/mcp/server.js.map +1 -0
  283. package/dist/mcp/tools/queueTools.d.ts.map +1 -1
  284. package/dist/mcp/tools/queueTools.js +6 -3
  285. package/dist/mcp/tools/queueTools.js.map +1 -1
  286. package/dist/mcp/tools/webhookTools.js +1 -1
  287. package/dist/mcp/tools/webhookTools.js.map +1 -1
  288. package/dist/shared/lock.d.ts.map +1 -1
  289. package/dist/shared/lock.js +15 -0
  290. package/dist/shared/lock.js.map +1 -1
  291. package/package.json +12 -7
@@ -0,0 +1,373 @@
1
+ /**
2
+ * Processor Handler Factories
3
+ * Creates callback handlers for job operations during processing
4
+ */
5
+ import { jobId } from '../../domain/types/job';
6
+ import { getSharedManager } from '../manager';
7
+ export function createProgressHandler(embedded, tcp, emitter, jobHolder) {
8
+ return async (id, progress, message) => {
9
+ if (embedded) {
10
+ const manager = getSharedManager();
11
+ await manager.updateProgress(jobId(id), progress, message);
12
+ }
13
+ else if (tcp) {
14
+ await tcp.send({ cmd: 'Progress', id, progress, message });
15
+ }
16
+ emitter.emit('progress', jobHolder.current, progress);
17
+ };
18
+ }
19
+ export function createLogHandler(embedded, tcp, emitter, jobHolder) {
20
+ return async (id, message) => {
21
+ if (embedded) {
22
+ const manager = getSharedManager();
23
+ manager.addLog(jobId(id), message);
24
+ }
25
+ else if (tcp) {
26
+ await tcp.send({ cmd: 'AddLog', id, message });
27
+ }
28
+ emitter.emit('log', jobHolder.current, message);
29
+ };
30
+ }
31
+ export function createGetStateHandler(embedded, tcp) {
32
+ return async (id) => {
33
+ if (embedded) {
34
+ const manager = getSharedManager();
35
+ return (await manager.getJobState(jobId(id)));
36
+ }
37
+ else if (tcp) {
38
+ const response = await tcp.send({ cmd: 'GetState', id });
39
+ return (response.state ?? 'unknown');
40
+ }
41
+ return 'unknown';
42
+ };
43
+ }
44
+ export function createGetChildrenValuesHandler(embedded, tcp) {
45
+ return async (id) => {
46
+ if (embedded) {
47
+ const manager = getSharedManager();
48
+ return manager.getChildrenValues(jobId(id));
49
+ }
50
+ else if (tcp) {
51
+ const response = await tcp.send({ cmd: 'GetChildrenValues', id });
52
+ const data = response.data;
53
+ return data?.values ?? {};
54
+ }
55
+ return {};
56
+ };
57
+ }
58
+ export function createGetFailedChildrenValuesHandler(embedded, tcp) {
59
+ return async (id) => {
60
+ if (embedded) {
61
+ const manager = getSharedManager();
62
+ return manager.getFailedChildrenValues(jobId(id));
63
+ }
64
+ if (!tcp)
65
+ return {};
66
+ const res = await tcp.send({ cmd: 'GetFailedChildrenValues', id });
67
+ return res.values ?? {};
68
+ };
69
+ }
70
+ export function createGetIgnoredChildrenFailuresHandler(embedded, tcp) {
71
+ return async (id) => {
72
+ if (embedded) {
73
+ const manager = getSharedManager();
74
+ return manager.getIgnoredChildrenFailures(jobId(id));
75
+ }
76
+ if (!tcp)
77
+ return {};
78
+ const res = await tcp.send({ cmd: 'GetIgnoredChildrenFailures', id });
79
+ return res.values ?? {};
80
+ };
81
+ }
82
+ export function createRemoveChildDependencyHandler(embedded, tcp) {
83
+ return async (id) => {
84
+ if (embedded) {
85
+ const manager = getSharedManager();
86
+ return manager.removeChildDependency(jobId(id));
87
+ }
88
+ if (!tcp)
89
+ return false;
90
+ const res = await tcp.send({ cmd: 'RemoveChildDependency', id });
91
+ return res.ok === true;
92
+ };
93
+ }
94
+ export function createRemoveUnprocessedChildrenHandler(embedded, tcp) {
95
+ return async (id) => {
96
+ if (embedded) {
97
+ const manager = getSharedManager();
98
+ return manager.removeUnprocessedChildren(jobId(id));
99
+ }
100
+ if (!tcp)
101
+ return;
102
+ await tcp.send({ cmd: 'RemoveUnprocessedChildren', id });
103
+ };
104
+ }
105
+ /** Issue #82: Create moveToFailed handler for use inside processor */
106
+ export function createMoveToFailedHandler(embedded, tcp, internalJob, token, onCalled) {
107
+ return async (_id, error, _lockToken) => {
108
+ if (embedded) {
109
+ const manager = getSharedManager();
110
+ await manager.fail(internalJob.id, error.message, token ?? undefined);
111
+ }
112
+ else if (tcp) {
113
+ await tcp.send({
114
+ cmd: 'FAIL',
115
+ id: internalJob.id,
116
+ error: error.message,
117
+ ...(token ? { token } : {}),
118
+ });
119
+ }
120
+ onCalled(error);
121
+ };
122
+ }
123
+ /** Issue #82: Create moveToCompleted handler for use inside processor */
124
+ export function createMoveToCompletedHandler(embedded, ackBatcher, internalJob, token, onCalled) {
125
+ return async (_id, returnValue, _lockToken) => {
126
+ if (embedded) {
127
+ const manager = getSharedManager();
128
+ await manager.ack(internalJob.id, returnValue, token ?? undefined);
129
+ }
130
+ else {
131
+ await ackBatcher.queue(String(internalJob.id), returnValue, token ?? undefined);
132
+ }
133
+ onCalled(returnValue);
134
+ return null;
135
+ };
136
+ }
137
+ // ============================================================
138
+ // Job mutation handlers (Issue #82 follow-up: wire remaining no-op methods)
139
+ // ============================================================
140
+ export function createRemoveHandler(embedded, tcp) {
141
+ return async (id) => {
142
+ if (embedded) {
143
+ await getSharedManager().cancel(jobId(id));
144
+ return;
145
+ }
146
+ if (!tcp)
147
+ return;
148
+ await tcp.send({ cmd: 'Cancel', id });
149
+ };
150
+ }
151
+ export function createRetryHandler(embedded, tcp, internalJob) {
152
+ return async (id) => {
153
+ // BullMQ contract: Job.retry() moves a failed job back to waiting.
154
+ // Dispatch by state so it also works on an active job that wants to requeue.
155
+ if (embedded) {
156
+ const mgr = getSharedManager();
157
+ const state = await mgr.getJobState(jobId(id));
158
+ if (state === 'failed') {
159
+ const count = mgr.retryDlq(internalJob.queue, jobId(id));
160
+ if (count === 0)
161
+ throw new Error(`Job ${id} is failed but not present in DLQ`);
162
+ return;
163
+ }
164
+ if (state === 'active') {
165
+ const ok = await mgr.moveActiveToWait(jobId(id));
166
+ if (!ok)
167
+ throw new Error(`Failed to retry active job ${id}`);
168
+ return;
169
+ }
170
+ if (state === 'waiting' || state === 'prioritized' || state === 'delayed')
171
+ return;
172
+ throw new Error(`Cannot retry job ${id} from state '${state}'`);
173
+ }
174
+ if (!tcp)
175
+ return;
176
+ const res = await tcp.send({ cmd: 'MoveToWait', id });
177
+ if (res.ok !== true) {
178
+ const err = typeof res.error === 'string' ? res.error : 'retry failed';
179
+ throw new Error(err);
180
+ }
181
+ };
182
+ }
183
+ export function createUpdateDataHandler(embedded, tcp) {
184
+ return async (id, data) => {
185
+ if (embedded) {
186
+ await getSharedManager().updateJobData(jobId(id), data);
187
+ return;
188
+ }
189
+ if (!tcp)
190
+ return;
191
+ await tcp.send({ cmd: 'Update', id, data });
192
+ };
193
+ }
194
+ export function createPromoteHandler(embedded, tcp) {
195
+ return async (id) => {
196
+ if (embedded) {
197
+ await getSharedManager().promote(jobId(id));
198
+ return;
199
+ }
200
+ if (!tcp)
201
+ return;
202
+ await tcp.send({ cmd: 'Promote', id });
203
+ };
204
+ }
205
+ export function createChangeDelayHandler(embedded, tcp) {
206
+ return async (id, delay) => {
207
+ if (embedded) {
208
+ await getSharedManager().changeDelay(jobId(id), delay);
209
+ return;
210
+ }
211
+ if (!tcp)
212
+ return;
213
+ await tcp.send({ cmd: 'ChangeDelay', id, delay });
214
+ };
215
+ }
216
+ export function createChangePriorityHandler(embedded, tcp) {
217
+ return async (id, opts) => {
218
+ if (embedded) {
219
+ await getSharedManager().changePriority(jobId(id), opts.priority, opts.lifo);
220
+ return;
221
+ }
222
+ if (!tcp)
223
+ return;
224
+ await tcp.send({ cmd: 'ChangePriority', id, priority: opts.priority, lifo: opts.lifo });
225
+ };
226
+ }
227
+ export function createExtendLockHandler(embedded, tcp) {
228
+ return async (id, token, duration) => {
229
+ if (embedded) {
230
+ const ok = await getSharedManager().extendLock(jobId(id), token, duration);
231
+ return ok ? duration : 0;
232
+ }
233
+ if (!tcp)
234
+ return 0;
235
+ const res = await tcp.send({ cmd: 'ExtendLock', id, token, duration });
236
+ return res.ok === true ? duration : 0;
237
+ };
238
+ }
239
+ export function createClearLogsHandler(embedded, tcp) {
240
+ return async (id, keepLogs) => {
241
+ if (embedded) {
242
+ getSharedManager().clearLogs(jobId(id), keepLogs);
243
+ return;
244
+ }
245
+ if (!tcp)
246
+ return;
247
+ await tcp.send({ cmd: 'ClearLogs', id, keepLogs });
248
+ };
249
+ }
250
+ export function createMoveToWaitHandler(embedded, tcp) {
251
+ return async (id, _token) => {
252
+ if (embedded) {
253
+ return await getSharedManager().moveActiveToWait(jobId(id));
254
+ }
255
+ if (!tcp)
256
+ return false;
257
+ const res = await tcp.send({ cmd: 'MoveToWait', id });
258
+ return res.ok === true;
259
+ };
260
+ }
261
+ export function createMoveToDelayedHandler(embedded, tcp) {
262
+ return async (id, timestamp, _token) => {
263
+ // BullMQ API passes absolute timestamp; server expects relative delay (ms)
264
+ const delay = Math.max(0, timestamp - Date.now());
265
+ if (embedded) {
266
+ await getSharedManager().moveToDelayed(jobId(id), delay);
267
+ return;
268
+ }
269
+ if (!tcp)
270
+ return;
271
+ await tcp.send({ cmd: 'MoveToDelayed', id, delay });
272
+ };
273
+ }
274
+ export function createMoveToWaitingChildrenHandler(embedded, tcp) {
275
+ return async (id) => {
276
+ if (embedded) {
277
+ return await getSharedManager().moveToWaitingChildren(jobId(id));
278
+ }
279
+ if (!tcp)
280
+ return false;
281
+ throw new Error('moveToWaitingChildren is not supported in TCP mode — no server command available');
282
+ };
283
+ }
284
+ export function createWaitUntilFinishedHandler(embedded, tcp) {
285
+ return async (id, _queueEvents, ttl) => {
286
+ const timeout = ttl ?? 30000;
287
+ if (embedded) {
288
+ const manager = getSharedManager();
289
+ const job = await manager.getJob(jobId(id));
290
+ if (!job)
291
+ throw new Error(`Job ${id} not found`);
292
+ if (job.completedAt)
293
+ return manager.getResult(jobId(id));
294
+ const completed = await manager.waitForJobCompletion(jobId(id), timeout);
295
+ if (!completed)
296
+ throw new Error(`waitUntilFinished timed out after ${timeout}ms`);
297
+ return manager.getResult(jobId(id));
298
+ }
299
+ if (!tcp)
300
+ throw new Error('waitUntilFinished: no connection');
301
+ const res = await tcp.send({ cmd: 'WaitJob', id, timeout });
302
+ const typed = res;
303
+ if (!typed.completed)
304
+ throw new Error(`waitUntilFinished timed out after ${timeout}ms`);
305
+ return typed.result;
306
+ };
307
+ }
308
+ export function createDiscardHandler(embedded, tcp) {
309
+ return (id) => {
310
+ if (embedded) {
311
+ void getSharedManager().discard(jobId(id));
312
+ return;
313
+ }
314
+ if (!tcp)
315
+ return;
316
+ void tcp.send({ cmd: 'Discard', id });
317
+ };
318
+ }
319
+ /**
320
+ * getDependencies — compute from internalJob.childrenIds by querying each child's state.
321
+ * No dedicated server API; derive from existing job state queries.
322
+ */
323
+ export function createGetDependenciesHandler(embedded, tcp, internalJob) {
324
+ return async () => {
325
+ const childIds = internalJob.childrenIds;
326
+ const processed = {};
327
+ const unprocessed = [];
328
+ for (const cid of childIds) {
329
+ let state = 'unknown';
330
+ let result;
331
+ if (embedded) {
332
+ const mgr = getSharedManager();
333
+ state = await mgr.getJobState(cid);
334
+ if (state === 'completed')
335
+ result = mgr.getResult(cid);
336
+ }
337
+ else if (tcp) {
338
+ const r = await tcp.send({ cmd: 'GetState', id: String(cid) });
339
+ state = r.state ?? 'unknown';
340
+ if (state === 'completed') {
341
+ const rr = await tcp.send({ cmd: 'GetResult', id: String(cid) });
342
+ result = rr.result;
343
+ }
344
+ }
345
+ const key = `${internalJob.queue}:${String(cid)}`;
346
+ if (state === 'completed' || state === 'failed') {
347
+ processed[key] = result ?? null;
348
+ }
349
+ else {
350
+ unprocessed.push(key);
351
+ }
352
+ }
353
+ return { processed, unprocessed };
354
+ };
355
+ }
356
+ export function createGetDependenciesCountHandler(embedded, tcp, internalJob) {
357
+ const getDeps = createGetDependenciesHandler(embedded, tcp, internalJob);
358
+ return async (id) => {
359
+ const deps = await getDeps(id);
360
+ return {
361
+ processed: Object.keys(deps.processed).length,
362
+ unprocessed: deps.unprocessed.length,
363
+ };
364
+ };
365
+ }
366
+ /**
367
+ * removeDeduplicationKey — no server primitive; throw explicit error so callers
368
+ * learn this isn't supported rather than silently getting `false`.
369
+ */
370
+ export function createRemoveDeduplicationKeyHandler() {
371
+ return () => Promise.reject(new Error('removeDeduplicationKey is not implemented — no server primitive available'));
372
+ }
373
+ //# sourceMappingURL=processorHandlers.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"processorHandlers.js","sourceRoot":"","sources":["../../../src/client/worker/processorHandlers.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,15 @@
1
+ /**
2
+ * Compensation logic - runs compensate handlers in reverse order on failure
3
+ */
4
+ import type { Execution } from './types';
5
+ import type { Workflow } from './workflow';
6
+ import type { WorkflowStore } from './store';
7
+ import type { WorkflowEmitter } from './emitter';
8
+ /** Sentinel error thrown when execution must pause for a signal */
9
+ export declare class WaitForSignalError extends Error {
10
+ readonly event: string;
11
+ constructor(event: string);
12
+ }
13
+ /** Run compensation handlers in reverse order for all completed steps */
14
+ export declare function runCompensation(exec: Execution, wf: Workflow, store: WorkflowStore, emitter: WorkflowEmitter | null): Promise<void>;
15
+ //# sourceMappingURL=compensator.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"compensator.d.ts","sourceRoot":"","sources":["../../../src/client/workflow/compensator.ts"],"names":[],"mappings":"AAAA;;GAEG;AAEH,OAAO,KAAK,EAAE,SAAS,EAAE,MAAM,SAAS,CAAC;AACzC,OAAO,KAAK,EAAE,QAAQ,EAAE,MAAM,YAAY,CAAC;AAC3C,OAAO,KAAK,EAAE,aAAa,EAAE,MAAM,SAAS,CAAC;AAC7C,OAAO,KAAK,EAAE,eAAe,EAAE,MAAM,WAAW,CAAC;AAGjD,mEAAmE;AACnE,qBAAa,kBAAmB,SAAQ,KAAK;IAC/B,QAAQ,CAAC,KAAK,EAAE,MAAM;gBAAb,KAAK,EAAE,MAAM;CAGnC;AAED,yEAAyE;AACzE,wBAAsB,eAAe,CACnC,IAAI,EAAE,SAAS,EACf,EAAE,EAAE,QAAQ,EACZ,KAAK,EAAE,aAAa,EACpB,OAAO,EAAE,eAAe,GAAG,IAAI,GAC9B,OAAO,CAAC,IAAI,CAAC,CAgCf"}
@@ -0,0 +1,46 @@
1
+ /**
2
+ * Compensation logic - runs compensate handlers in reverse order on failure
3
+ */
4
+ import { findStepDef, buildContext } from './runner';
5
+ /** Sentinel error thrown when execution must pause for a signal */
6
+ export class WaitForSignalError extends Error {
7
+ event;
8
+ constructor(event) {
9
+ super(`Waiting for signal: ${event}`);
10
+ this.event = event;
11
+ }
12
+ }
13
+ /** Run compensation handlers in reverse order for all completed steps */
14
+ export async function runCompensation(exec, wf, store, emitter) {
15
+ const completed = Object.entries(exec.steps)
16
+ .filter(([name, s]) => s.status === 'completed' && !name.startsWith('__'))
17
+ .reverse();
18
+ if (completed.length === 0)
19
+ return;
20
+ exec.state = 'compensating';
21
+ store.update(exec);
22
+ emitter?.emitWorkflow('workflow:compensating', exec.id, exec.workflowName, 'compensating');
23
+ const baseCtx = buildContext(exec);
24
+ for (const [name, record] of completed) {
25
+ const def = findStepDef(wf, name);
26
+ if (def?.compensate) {
27
+ // For forEach iterations, restore that iteration's __item/__index so the
28
+ // compensate handler knows exactly which item it is rolling back.
29
+ const ctx = record.loopIndex !== undefined
30
+ ? {
31
+ ...baseCtx,
32
+ steps: { ...baseCtx.steps, __item: record.loopItem, __index: record.loopIndex },
33
+ }
34
+ : baseCtx;
35
+ try {
36
+ await def.compensate(ctx);
37
+ }
38
+ catch {
39
+ // Compensation errors don't stop the chain
40
+ }
41
+ }
42
+ }
43
+ exec.state = 'failed';
44
+ store.update(exec);
45
+ }
46
+ //# sourceMappingURL=compensator.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"compensator.js","sourceRoot":"","sources":["../../../src/client/workflow/compensator.ts"],"names":[],"mappings":"AAAA;;GAEG;AAMH,OAAO,EAAE,WAAW,EAAE,YAAY,EAAE,MAAM,UAAU,CAAC;AAErD,mEAAmE;AACnE,MAAM,OAAO,kBAAmB,SAAQ,KAAK;IACtB;IAArB,YAAqB,KAAa;QAChC,KAAK,CAAC,uBAAuB,KAAK,EAAE,CAAC,CAAC;QADnB,UAAK,GAAL,KAAK,CAAQ;IAElC,CAAC;CACF;AAED,yEAAyE;AACzE,MAAM,CAAC,KAAK,UAAU,eAAe,CACnC,IAAe,EACf,EAAY,EACZ,KAAoB,EACpB,OAA+B;IAE/B,MAAM,SAAS,GAAG,MAAM,CAAC,OAAO,CAAC,IAAI,CAAC,KAAK,CAAC;SACzC,MAAM,CAAC,CAAC,CAAC,IAAI,EAAE,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,MAAM,KAAK,WAAW,IAAI,CAAC,IAAI,CAAC,UAAU,CAAC,IAAI,CAAC,CAAC;SACzE,OAAO,EAAE,CAAC;IACb,IAAI,SAAS,CAAC,MAAM,KAAK,CAAC;QAAE,OAAO;IAEnC,IAAI,CAAC,KAAK,GAAG,cAAc,CAAC;IAC5B,KAAK,CAAC,MAAM,CAAC,IAAI,CAAC,CAAC;IACnB,OAAO,EAAE,YAAY,CAAC,uBAAuB,EAAE,IAAI,CAAC,EAAE,EAAE,IAAI,CAAC,YAAY,EAAE,cAAc,CAAC,CAAC;IAE3F,MAAM,OAAO,GAAG,YAAY,CAAC,IAAI,CAAC,CAAC;IACnC,KAAK,MAAM,CAAC,IAAI,EAAE,MAAM,CAAC,IAAI,SAAS,EAAE,CAAC;QACvC,MAAM,GAAG,GAAG,WAAW,CAAC,EAAE,EAAE,IAAI,CAAC,CAAC;QAClC,IAAI,GAAG,EAAE,UAAU,EAAE,CAAC;YACpB,yEAAyE;YACzE,kEAAkE;YAClE,MAAM,GAAG,GACP,MAAM,CAAC,SAAS,KAAK,SAAS;gBAC5B,CAAC,CAAC;oBACE,GAAG,OAAO;oBACV,KAAK,EAAE,EAAE,GAAG,OAAO,CAAC,KAAK,EAAE,MAAM,EAAE,MAAM,CAAC,QAAQ,EAAE,OAAO,EAAE,MAAM,CAAC,SAAS,EAAE;iBAChF;gBACH,CAAC,CAAC,OAAO,CAAC;YACd,IAAI,CAAC;gBACH,MAAM,GAAG,CAAC,UAAU,CAAC,GAAG,CAAC,CAAC;YAC5B,CAAC;YAAC,MAAM,CAAC;gBACP,2CAA2C;YAC7C,CAAC;QACH,CAAC;IACH,CAAC;IACD,IAAI,CAAC,KAAK,GAAG,QAAQ,CAAC;IACtB,KAAK,CAAC,MAAM,CAAC,IAAI,CAAC,CAAC;AACrB,CAAC"}
@@ -1 +1 @@
1
- {"version":3,"file":"emitter.d.ts","sourceRoot":"","sources":["../../../src/client/workflow/emitter.ts"],"names":[],"mappings":"AAAA;;GAEG;AAEH,OAAO,KAAK,EACV,iBAAiB,EAEjB,SAAS,EACT,sBAAsB,EAEtB,qBAAqB,EACrB,cAAc,EACf,MAAM,SAAS,CAAC;AAEjB,qBAAa,eAAe;IAC1B,OAAO,CAAC,QAAQ,CAAC,SAAS,CAA4D;IACtF,OAAO,CAAC,QAAQ,CAAC,eAAe,CAAoC;IAEpE,EAAE,CAAC,IAAI,EAAE,iBAAiB,EAAE,QAAQ,EAAE,qBAAqB,GAAG,IAAI;IAUlE,KAAK,CAAC,QAAQ,EAAE,qBAAqB,GAAG,IAAI;IAK5C,GAAG,CAAC,IAAI,EAAE,iBAAiB,EAAE,QAAQ,EAAE,qBAAqB,GAAG,IAAI;IAKnE,MAAM,CAAC,QAAQ,EAAE,qBAAqB,GAAG,IAAI;IAK7C,QAAQ,CACN,IAAI,EAAE,cAAc,GAAG,gBAAgB,GAAG,aAAa,GAAG,YAAY,EACtE,WAAW,EAAE,MAAM,EACnB,YAAY,EAAE,MAAM,EACpB,QAAQ,EAAE,MAAM,EAChB,KAAK,CAAC,EAAE,OAAO,CACb,IAAI,CAAC,SAAS,EAAE,MAAM,GAAG,aAAa,GAAG,cAAc,GAAG,WAAW,GAAG,UAAU,CAAC,CACpF,GACA,IAAI;IAYP,YAAY,CACV,IAAI,EACA,kBAAkB,GAClB,oBAAoB,GACpB,iBAAiB,GACjB,uBAAuB,GACvB,kBAAkB,EACtB,WAAW,EAAE,MAAM,EACnB,YAAY,EAAE,MAAM,EACpB,KAAK,EAAE,cAAc,EACrB,KAAK,CAAC,EAAE,OAAO,CACb,IAAI,CAAC,sBAAsB,EAAE,MAAM,GAAG,aAAa,GAAG,cAAc,GAAG,WAAW,GAAG,OAAO,CAAC,CAC9F,GACA,IAAI;IAYP,UAAU,CACR,IAAI,EAAE,iBAAiB,GAAG,gBAAgB,EAC1C,WAAW,EAAE,MAAM,EACnB,YAAY,EAAE,MAAM,EACpB,KAAK,EAAE,MAAM,EACb,OAAO,CAAC,EAAE,OAAO,GAChB,IAAI;IAYP,kBAAkB,IAAI,IAAI;IAK1B,OAAO,CAAC,QAAQ;CAOjB"}
1
+ {"version":3,"file":"emitter.d.ts","sourceRoot":"","sources":["../../../src/client/workflow/emitter.ts"],"names":[],"mappings":"AAAA;;GAEG;AAEH,OAAO,KAAK,EACV,iBAAiB,EAEjB,SAAS,EACT,sBAAsB,EAEtB,qBAAqB,EACrB,cAAc,EACf,MAAM,SAAS,CAAC;AAEjB,qBAAa,eAAe;IAC1B,OAAO,CAAC,QAAQ,CAAC,SAAS,CAA4D;IACtF,OAAO,CAAC,QAAQ,CAAC,eAAe,CAAoC;IAEpE,EAAE,CAAC,IAAI,EAAE,iBAAiB,EAAE,QAAQ,EAAE,qBAAqB,GAAG,IAAI;IAUlE,KAAK,CAAC,QAAQ,EAAE,qBAAqB,GAAG,IAAI;IAK5C,GAAG,CAAC,IAAI,EAAE,iBAAiB,EAAE,QAAQ,EAAE,qBAAqB,GAAG,IAAI;IAKnE,MAAM,CAAC,QAAQ,EAAE,qBAAqB,GAAG,IAAI;IAK7C,QAAQ,CACN,IAAI,EAAE,cAAc,GAAG,gBAAgB,GAAG,aAAa,GAAG,YAAY,EACtE,WAAW,EAAE,MAAM,EACnB,YAAY,EAAE,MAAM,EACpB,QAAQ,EAAE,MAAM,EAChB,KAAK,CAAC,EAAE,OAAO,CACb,IAAI,CAAC,SAAS,EAAE,MAAM,GAAG,aAAa,GAAG,cAAc,GAAG,WAAW,GAAG,UAAU,CAAC,CACpF,GACA,IAAI;IAYP,YAAY,CACV,IAAI,EACA,kBAAkB,GAClB,oBAAoB,GACpB,iBAAiB,GACjB,uBAAuB,GACvB,kBAAkB,EACtB,WAAW,EAAE,MAAM,EACnB,YAAY,EAAE,MAAM,EACpB,KAAK,EAAE,cAAc,EACrB,KAAK,CAAC,EAAE,OAAO,CACb,IAAI,CAAC,sBAAsB,EAAE,MAAM,GAAG,aAAa,GAAG,cAAc,GAAG,WAAW,GAAG,OAAO,CAAC,CAC9F,GACA,IAAI;IAYP,UAAU,CACR,IAAI,EAAE,iBAAiB,GAAG,gBAAgB,EAC1C,WAAW,EAAE,MAAM,EACnB,YAAY,EAAE,MAAM,EACpB,KAAK,EAAE,MAAM,EACb,OAAO,CAAC,EAAE,OAAO,GAChB,IAAI;IAYP,kBAAkB,IAAI,IAAI;IAK1B,OAAO,CAAC,QAAQ;CAmBjB"}
@@ -65,11 +65,23 @@ export class WorkflowEmitter {
65
65
  dispatch(type, event) {
66
66
  const typed = this.listeners.get(type);
67
67
  if (typed) {
68
- for (const fn of typed)
68
+ for (const fn of typed) {
69
+ try {
70
+ fn(event);
71
+ }
72
+ catch {
73
+ /* listener errors must not break dispatch */
74
+ }
75
+ }
76
+ }
77
+ for (const fn of this.globalListeners) {
78
+ try {
69
79
  fn(event);
80
+ }
81
+ catch {
82
+ /* listener errors must not break dispatch */
83
+ }
70
84
  }
71
- for (const fn of this.globalListeners)
72
- fn(event);
73
85
  }
74
86
  }
75
87
  //# sourceMappingURL=emitter.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"emitter.js","sourceRoot":"","sources":["../../../src/client/workflow/emitter.ts"],"names":[],"mappings":"AAAA;;GAEG;AAYH,MAAM,OAAO,eAAe;IACT,SAAS,GAAG,IAAI,GAAG,EAAiD,CAAC;IACrE,eAAe,GAAG,IAAI,GAAG,EAAyB,CAAC;IAEpE,EAAE,CAAC,IAAuB,EAAE,QAA+B;QACzD,IAAI,GAAG,GAAG,IAAI,CAAC,SAAS,CAAC,GAAG,CAAC,IAAI,CAAC,CAAC;QACnC,IAAI,CAAC,GAAG,EAAE,CAAC;YACT,GAAG,GAAG,IAAI,GAAG,EAAE,CAAC;YAChB,IAAI,CAAC,SAAS,CAAC,GAAG,CAAC,IAAI,EAAE,GAAG,CAAC,CAAC;QAChC,CAAC;QACD,GAAG,CAAC,GAAG,CAAC,QAAQ,CAAC,CAAC;QAClB,OAAO,IAAI,CAAC;IACd,CAAC;IAED,KAAK,CAAC,QAA+B;QACnC,IAAI,CAAC,eAAe,CAAC,GAAG,CAAC,QAAQ,CAAC,CAAC;QACnC,OAAO,IAAI,CAAC;IACd,CAAC;IAED,GAAG,CAAC,IAAuB,EAAE,QAA+B;QAC1D,IAAI,CAAC,SAAS,CAAC,GAAG,CAAC,IAAI,CAAC,EAAE,MAAM,CAAC,QAAQ,CAAC,CAAC;QAC3C,OAAO,IAAI,CAAC;IACd,CAAC;IAED,MAAM,CAAC,QAA+B;QACpC,IAAI,CAAC,eAAe,CAAC,MAAM,CAAC,QAAQ,CAAC,CAAC;QACtC,OAAO,IAAI,CAAC;IACd,CAAC;IAED,QAAQ,CACN,IAAsE,EACtE,WAAmB,EACnB,YAAoB,EACpB,QAAgB,EAChB,KAEC;QAED,MAAM,KAAK,GAAc;YACvB,IAAI;YACJ,WAAW;YACX,YAAY;YACZ,SAAS,EAAE,IAAI,CAAC,GAAG,EAAE;YACrB,QAAQ;YACR,GAAG,KAAK;SACT,CAAC;QACF,IAAI,CAAC,QAAQ,CAAC,IAAI,EAAE,KAAK,CAAC,CAAC;IAC7B,CAAC;IAED,YAAY,CACV,IAKsB,EACtB,WAAmB,EACnB,YAAoB,EACpB,KAAqB,EACrB,KAEC;QAED,MAAM,KAAK,GAA2B;YACpC,IAAI;YACJ,WAAW;YACX,YAAY;YACZ,SAAS,EAAE,IAAI,CAAC,GAAG,EAAE;YACrB,KAAK;YACL,GAAG,KAAK;SACT,CAAC;QACF,IAAI,CAAC,QAAQ,CAAC,IAAI,EAAE,KAAK,CAAC,CAAC;IAC7B,CAAC;IAED,UAAU,CACR,IAA0C,EAC1C,WAAmB,EACnB,YAAoB,EACpB,KAAa,EACb,OAAiB;QAEjB,MAAM,GAAG,GAAgB;YACvB,IAAI;YACJ,WAAW;YACX,YAAY;YACZ,SAAS,EAAE,IAAI,CAAC,GAAG,EAAE;YACrB,KAAK;YACL,OAAO;SACR,CAAC;QACF,IAAI,CAAC,QAAQ,CAAC,IAAI,EAAE,GAAG,CAAC,CAAC;IAC3B,CAAC;IAED,kBAAkB;QAChB,IAAI,CAAC,SAAS,CAAC,KAAK,EAAE,CAAC;QACvB,IAAI,CAAC,eAAe,CAAC,KAAK,EAAE,CAAC;IAC/B,CAAC;IAEO,QAAQ,CAAC,IAAuB,EAAE,KAAoB;QAC5D,MAAM,KAAK,GAAG,IAAI,CAAC,SAAS,CAAC,GAAG,CAAC,IAAI,CAAC,CAAC;QACvC,IAAI,KAAK,EAAE,CAAC;YACV,KAAK,MAAM,EAAE,IAAI,KAAK;gBAAE,EAAE,CAAC,KAAK,CAAC,CAAC;QACpC,CAAC;QACD,KAAK,MAAM,EAAE,IAAI,IAAI,CAAC,eAAe;YAAE,EAAE,CAAC,KAAK,CAAC,CAAC;IACnD,CAAC;CACF"}
1
+ {"version":3,"file":"emitter.js","sourceRoot":"","sources":["../../../src/client/workflow/emitter.ts"],"names":[],"mappings":"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"}
@@ -3,7 +3,7 @@
3
3
  * Manages lifecycle of internal Queue, Worker, and Store.
4
4
  */
5
5
  import type { Workflow } from './workflow';
6
- import type { EngineOptions, RunHandle, Execution, ExecutionState, WorkflowEventType, WorkflowEventListener } from './types';
6
+ import type { EngineOptions, RunHandle, Execution, ExecutionState, RecoverResult, WorkflowEventType, WorkflowEventListener } from './types';
7
7
  export declare class Engine {
8
8
  private readonly queue;
9
9
  private readonly worker;
@@ -21,6 +21,13 @@ export declare class Engine {
21
21
  listExecutions(workflowName?: string, state?: ExecutionState): Execution[];
22
22
  /** Send a signal to a waiting execution */
23
23
  signal(executionId: string, event: string, payload?: unknown): Promise<void>;
24
+ /**
25
+ * Recover orphaned executions after a crash/restart.
26
+ * - 'running' executions: re-enqueued at their current step
27
+ * - 'waiting' executions: timeout timers re-armed (or resumed if signal arrived)
28
+ * - 'compensating' executions: compensation re-run (handlers must be idempotent)
29
+ */
30
+ recover(): Promise<RecoverResult>;
24
31
  /** Subscribe to a specific workflow event type */
25
32
  on(type: WorkflowEventType, listener: WorkflowEventListener): this;
26
33
  /** Subscribe to all workflow events */
@@ -1 +1 @@
1
- {"version":3,"file":"engine.d.ts","sourceRoot":"","sources":["../../../src/client/workflow/engine.ts"],"names":[],"mappings":"AAAA;;;GAGG;AAOH,OAAO,KAAK,EAAE,QAAQ,EAAE,MAAM,YAAY,CAAC;AAC3C,OAAO,KAAK,EACV,aAAa,EACb,SAAS,EACT,SAAS,EACT,cAAc,EAEd,iBAAiB,EACjB,qBAAqB,EACtB,MAAM,SAAS,CAAC;AAIjB,qBAAa,MAAM;IACjB,OAAO,CAAC,QAAQ,CAAC,KAAK,CAAQ;IAC9B,OAAO,CAAC,QAAQ,CAAC,MAAM,CAAS;IAChC,OAAO,CAAC,QAAQ,CAAC,KAAK,CAAgB;IACtC,OAAO,CAAC,QAAQ,CAAC,QAAQ,CAAmB;IAC5C,OAAO,CAAC,QAAQ,CAAC,OAAO,CAAkB;gBAE9B,IAAI,GAAE,aAAkB;IAiCpC,qCAAqC;IACrC,QAAQ,CAAC,QAAQ,EAAE,QAAQ,GAAG,IAAI;IAKlC,qCAAqC;IAC/B,KAAK,CAAC,YAAY,EAAE,MAAM,EAAE,KAAK,CAAC,EAAE,OAAO,GAAG,OAAO,CAAC,SAAS,CAAC;IAItE,gCAAgC;IAChC,YAAY,CAAC,EAAE,EAAE,MAAM,GAAG,SAAS,GAAG,IAAI;IAI1C,4CAA4C;IAC5C,cAAc,CAAC,YAAY,CAAC,EAAE,MAAM,EAAE,KAAK,CAAC,EAAE,cAAc,GAAG,SAAS,EAAE;IAI1E,2CAA2C;IACrC,MAAM,CAAC,WAAW,EAAE,MAAM,EAAE,KAAK,EAAE,MAAM,EAAE,OAAO,CAAC,EAAE,OAAO,GAAG,OAAO,CAAC,IAAI,CAAC;IAMlF,kDAAkD;IAClD,EAAE,CAAC,IAAI,EAAE,iBAAiB,EAAE,QAAQ,EAAE,qBAAqB,GAAG,IAAI;IAKlE,uCAAuC;IACvC,KAAK,CAAC,QAAQ,EAAE,qBAAqB,GAAG,IAAI;IAK5C,6CAA6C;IAC7C,GAAG,CAAC,IAAI,EAAE,iBAAiB,EAAE,QAAQ,EAAE,qBAAqB,GAAG,IAAI;IAKnE,uCAAuC;IACvC,MAAM,CAAC,QAAQ,EAAE,qBAAqB,GAAG,IAAI;IAK7C,uDAAuD;IACvD,SAAS,CAAC,WAAW,EAAE,MAAM,EAAE,QAAQ,EAAE,qBAAqB,GAAG,MAAM,IAAI;IAU3E,6CAA6C;IAC7C,OAAO,CAAC,QAAQ,EAAE,MAAM,EAAE,MAAM,CAAC,EAAE,cAAc,EAAE,GAAG,MAAM;IAI5D,iDAAiD;IACjD,OAAO,CAAC,QAAQ,EAAE,MAAM,EAAE,MAAM,CAAC,EAAE,cAAc,EAAE,GAAG,MAAM;IAI5D,mCAAmC;IACnC,gBAAgB,IAAI,MAAM;IAI1B,2BAA2B;IACrB,KAAK,CAAC,KAAK,UAAQ,GAAG,OAAO,CAAC,IAAI,CAAC;CAM1C"}
1
+ {"version":3,"file":"engine.d.ts","sourceRoot":"","sources":["../../../src/client/workflow/engine.ts"],"names":[],"mappings":"AAAA;;;GAGG;AAOH,OAAO,KAAK,EAAE,QAAQ,EAAE,MAAM,YAAY,CAAC;AAC3C,OAAO,KAAK,EACV,aAAa,EACb,SAAS,EACT,SAAS,EACT,cAAc,EACd,aAAa,EAEb,iBAAiB,EACjB,qBAAqB,EACtB,MAAM,SAAS,CAAC;AAIjB,qBAAa,MAAM;IACjB,OAAO,CAAC,QAAQ,CAAC,KAAK,CAAQ;IAC9B,OAAO,CAAC,QAAQ,CAAC,MAAM,CAAS;IAChC,OAAO,CAAC,QAAQ,CAAC,KAAK,CAAgB;IACtC,OAAO,CAAC,QAAQ,CAAC,QAAQ,CAAmB;IAC5C,OAAO,CAAC,QAAQ,CAAC,OAAO,CAAkB;gBAE9B,IAAI,GAAE,aAAkB;IAiCpC,qCAAqC;IACrC,QAAQ,CAAC,QAAQ,EAAE,QAAQ,GAAG,IAAI;IAKlC,qCAAqC;IAC/B,KAAK,CAAC,YAAY,EAAE,MAAM,EAAE,KAAK,CAAC,EAAE,OAAO,GAAG,OAAO,CAAC,SAAS,CAAC;IAItE,gCAAgC;IAChC,YAAY,CAAC,EAAE,EAAE,MAAM,GAAG,SAAS,GAAG,IAAI;IAI1C,4CAA4C;IAC5C,cAAc,CAAC,YAAY,CAAC,EAAE,MAAM,EAAE,KAAK,CAAC,EAAE,cAAc,GAAG,SAAS,EAAE;IAI1E,2CAA2C;IACrC,MAAM,CAAC,WAAW,EAAE,MAAM,EAAE,KAAK,EAAE,MAAM,EAAE,OAAO,CAAC,EAAE,OAAO,GAAG,OAAO,CAAC,IAAI,CAAC;IAIlF;;;;;OAKG;IACG,OAAO,IAAI,OAAO,CAAC,aAAa,CAAC;IAMvC,kDAAkD;IAClD,EAAE,CAAC,IAAI,EAAE,iBAAiB,EAAE,QAAQ,EAAE,qBAAqB,GAAG,IAAI;IAKlE,uCAAuC;IACvC,KAAK,CAAC,QAAQ,EAAE,qBAAqB,GAAG,IAAI;IAK5C,6CAA6C;IAC7C,GAAG,CAAC,IAAI,EAAE,iBAAiB,EAAE,QAAQ,EAAE,qBAAqB,GAAG,IAAI;IAKnE,uCAAuC;IACvC,MAAM,CAAC,QAAQ,EAAE,qBAAqB,GAAG,IAAI;IAK7C,uDAAuD;IACvD,SAAS,CAAC,WAAW,EAAE,MAAM,EAAE,QAAQ,EAAE,qBAAqB,GAAG,MAAM,IAAI;IAU3E,6CAA6C;IAC7C,OAAO,CAAC,QAAQ,EAAE,MAAM,EAAE,MAAM,CAAC,EAAE,cAAc,EAAE,GAAG,MAAM;IAI5D,iDAAiD;IACjD,OAAO,CAAC,QAAQ,EAAE,MAAM,EAAE,MAAM,CAAC,EAAE,cAAc,EAAE,GAAG,MAAM;IAI5D,mCAAmC;IACnC,gBAAgB,IAAI,MAAM;IAI1B,2BAA2B;IACrB,KAAK,CAAC,KAAK,UAAQ,GAAG,OAAO,CAAC,IAAI,CAAC;CAM1C"}
@@ -58,6 +58,15 @@ export class Engine {
58
58
  async signal(executionId, event, payload) {
59
59
  return this.executor.signal(executionId, event, payload);
60
60
  }
61
+ /**
62
+ * Recover orphaned executions after a crash/restart.
63
+ * - 'running' executions: re-enqueued at their current step
64
+ * - 'waiting' executions: timeout timers re-armed (or resumed if signal arrived)
65
+ * - 'compensating' executions: compensation re-run (handlers must be idempotent)
66
+ */
67
+ async recover() {
68
+ return this.executor.recover();
69
+ }
61
70
  // ============ Observability ============
62
71
  /** Subscribe to a specific workflow event type */
63
72
  on(type, listener) {
@@ -1 +1 @@
1
- {"version":3,"file":"engine.js","sourceRoot":"","sources":["../../../src/client/workflow/engine.ts"],"names":[],"mappings":"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"}
1
+ {"version":3,"file":"engine.js","sourceRoot":"","sources":["../../../src/client/workflow/engine.ts"],"names":[],"mappings":"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"}
@@ -3,20 +3,21 @@ import type { Queue } from '../queue/queue';
3
3
  import type { Workflow } from './workflow';
4
4
  import type { WorkflowStore } from './store';
5
5
  import type { WorkflowEmitter } from './emitter';
6
- import type { Execution, StepJobData, RunHandle } from './types';
6
+ import type { Execution, StepJobData, RunHandle, RecoverResult } from './types';
7
7
  export declare class WorkflowExecutor {
8
8
  private readonly store;
9
9
  private readonly queue;
10
10
  private readonly emitter;
11
11
  private readonly workflows;
12
12
  private readonly timeoutTimers;
13
+ private readonly updateFn;
13
14
  constructor(store: WorkflowStore, queue: Queue, emitter?: WorkflowEmitter | null);
14
15
  register(workflow: Workflow): void;
15
16
  start(workflowName: string, input: unknown): Promise<RunHandle>;
16
17
  processStep(data: StepJobData): Promise<unknown>;
17
18
  signal(executionId: string, event: string, payload: unknown): Promise<void>;
18
19
  getExecution(id: string): Execution | null;
19
- listExecutions(workflowName?: string, state?: Execution['state']): Execution[];
20
+ listExecutions(wfName?: string, state?: Execution['state']): Execution[];
20
21
  private executeNode;
21
22
  private runStep;
22
23
  private runBranch;
@@ -30,5 +31,7 @@ export declare class WorkflowExecutor {
30
31
  private enqueue;
31
32
  private scheduleTimeoutCheck;
32
33
  private compensate;
34
+ /** Recover orphaned executions after a crash/restart */
35
+ recover(): Promise<RecoverResult>;
33
36
  }
34
37
  //# sourceMappingURL=executor.d.ts.map
@@ -1 +1 @@
1
- {"version":3,"file":"executor.d.ts","sourceRoot":"","sources":["../../../src/client/workflow/executor.ts"],"names":[],"mappings":"AAAA,8CAA8C;AAC9C,OAAO,KAAK,EAAE,KAAK,EAAE,MAAM,gBAAgB,CAAC;AAC5C,OAAO,KAAK,EAAE,QAAQ,EAAE,MAAM,YAAY,CAAC;AAC3C,OAAO,KAAK,EAAE,aAAa,EAAE,MAAM,SAAS,CAAC;AAC7C,OAAO,KAAK,EAAE,eAAe,EAAE,MAAM,WAAW,CAAC;AACjD,OAAO,KAAK,EAAE,SAAS,EAAE,WAAW,EAAE,SAAS,EAAgC,MAAM,SAAS,CAAC;AAgB/F,qBAAa,gBAAgB;IAKzB,OAAO,CAAC,QAAQ,CAAC,KAAK;IACtB,OAAO,CAAC,QAAQ,CAAC,KAAK;IACtB,OAAO,CAAC,QAAQ,CAAC,OAAO;IAN1B,OAAO,CAAC,QAAQ,CAAC,SAAS,CAA+B;IACzD,OAAO,CAAC,QAAQ,CAAC,aAAa,CAAoD;gBAG/D,KAAK,EAAE,aAAa,EACpB,KAAK,EAAE,KAAK,EACZ,OAAO,GAAE,eAAe,GAAG,IAAW;IAGzD,QAAQ,CAAC,QAAQ,EAAE,QAAQ,GAAG,IAAI;IAS5B,KAAK,CAAC,YAAY,EAAE,MAAM,EAAE,KAAK,EAAE,OAAO,GAAG,OAAO,CAAC,SAAS,CAAC;IAwB/D,WAAW,CAAC,IAAI,EAAE,WAAW,GAAG,OAAO,CAAC,OAAO,CAAC;IA8BhD,MAAM,CAAC,WAAW,EAAE,MAAM,EAAE,KAAK,EAAE,MAAM,EAAE,OAAO,EAAE,OAAO,GAAG,OAAO,CAAC,IAAI,CAAC;IAgBjF,YAAY,CAAC,EAAE,EAAE,MAAM,GAAG,SAAS,GAAG,IAAI;IAI1C,cAAc,CAAC,YAAY,CAAC,EAAE,MAAM,EAAE,KAAK,CAAC,EAAE,SAAS,CAAC,OAAO,CAAC,GAAG,SAAS,EAAE;YAIhE,WAAW;YAiBX,OAAO;YAQP,SAAS;YAkBT,WAAW;YAYX,cAAc;YAiBd,UAAU;YA2CV,OAAO;YAaP,UAAU;YAYV,MAAM;YAWN,OAAO;YAYP,OAAO;IASrB,OAAO,CAAC,oBAAoB;YASd,UAAU;CAwBzB"}
1
+ {"version":3,"file":"executor.d.ts","sourceRoot":"","sources":["../../../src/client/workflow/executor.ts"],"names":[],"mappings":"AAAA,8CAA8C;AAC9C,OAAO,KAAK,EAAE,KAAK,EAAE,MAAM,gBAAgB,CAAC;AAC5C,OAAO,KAAK,EAAE,QAAQ,EAAE,MAAM,YAAY,CAAC;AAC3C,OAAO,KAAK,EAAE,aAAa,EAAE,MAAM,SAAS,CAAC;AAC7C,OAAO,KAAK,EAAE,eAAe,EAAE,MAAM,WAAW,CAAC;AACjD,OAAO,KAAK,EACV,SAAS,EACT,WAAW,EACX,SAAS,EACT,aAAa,EAGd,MAAM,SAAS,CAAC;AAWjB,qBAAa,gBAAgB;IAOzB,OAAO,CAAC,QAAQ,CAAC,KAAK;IACtB,OAAO,CAAC,QAAQ,CAAC,KAAK;IACtB,OAAO,CAAC,QAAQ,CAAC,OAAO;IAR1B,OAAO,CAAC,QAAQ,CAAC,SAAS,CAA+B;IACzD,OAAO,CAAC,QAAQ,CAAC,aAAa,CAAoD;IAElF,OAAO,CAAC,QAAQ,CAAC,QAAQ,CAAyB;gBAG/B,KAAK,EAAE,aAAa,EACpB,KAAK,EAAE,KAAK,EACZ,OAAO,GAAE,eAAe,GAAG,IAAW;IAOzD,QAAQ,CAAC,QAAQ,EAAE,QAAQ,GAAG,IAAI;IAS5B,KAAK,CAAC,YAAY,EAAE,MAAM,EAAE,KAAK,EAAE,OAAO,GAAG,OAAO,CAAC,SAAS,CAAC;IAuB/D,WAAW,CAAC,IAAI,EAAE,WAAW,GAAG,OAAO,CAAC,OAAO,CAAC;IA8BhD,MAAM,CAAC,WAAW,EAAE,MAAM,EAAE,KAAK,EAAE,MAAM,EAAE,OAAO,EAAE,OAAO,GAAG,OAAO,CAAC,IAAI,CAAC;IAejF,YAAY,CAAC,EAAE,EAAE,MAAM,GAAG,SAAS,GAAG,IAAI;IAG1C,cAAc,CAAC,MAAM,CAAC,EAAE,MAAM,EAAE,KAAK,CAAC,EAAE,SAAS,CAAC,OAAO,CAAC,GAAG,SAAS,EAAE;YAI1D,WAAW;YAiBX,OAAO;YAMP,SAAS;YAgBT,WAAW;YAgBX,cAAc;YAiBd,UAAU;YA0CV,OAAO;YAWP,UAAU;YAUV,MAAM;YAUN,OAAO;YAYP,OAAO;IASrB,OAAO,CAAC,oBAAoB;YAWd,UAAU;IAIxB,wDAAwD;IAClD,OAAO,IAAI,OAAO,CAAC,aAAa,CAAC;CAYxC"}