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.
- package/README.md +26 -11
- package/dist/application/backgroundTasks.d.ts.map +1 -1
- package/dist/application/backgroundTasks.js +83 -0
- package/dist/application/backgroundTasks.js.map +1 -1
- package/dist/application/clientTracking.d.ts +23 -0
- package/dist/application/clientTracking.d.ts.map +1 -1
- package/dist/application/clientTracking.js +80 -25
- package/dist/application/clientTracking.js.map +1 -1
- package/dist/application/contextFactory.d.ts +6 -0
- package/dist/application/contextFactory.d.ts.map +1 -1
- package/dist/application/contextFactory.js +7 -0
- package/dist/application/contextFactory.js.map +1 -1
- package/dist/application/dlqManager.d.ts.map +1 -1
- package/dist/application/dlqManager.js +5 -0
- package/dist/application/dlqManager.js.map +1 -1
- package/dist/application/eventsManager.js.map +1 -1
- package/dist/application/lockManager.d.ts +1 -1
- package/dist/application/lockManager.d.ts.map +1 -1
- package/dist/application/lockManager.js +1 -1
- package/dist/application/lockManager.js.map +1 -1
- package/dist/application/operations/ack.d.ts.map +1 -1
- package/dist/application/operations/ack.js +32 -33
- package/dist/application/operations/ack.js.map +1 -1
- package/dist/application/operations/jobManagement.d.ts +1 -1
- package/dist/application/operations/jobManagement.d.ts.map +1 -1
- package/dist/application/operations/jobManagement.js +3 -2
- package/dist/application/operations/jobManagement.js.map +1 -1
- package/dist/application/operations/push.js.map +1 -1
- package/dist/application/operations/queryOperations.d.ts.map +1 -1
- package/dist/application/operations/queryOperations.js +37 -3
- package/dist/application/operations/queryOperations.js.map +1 -1
- package/dist/application/operations/queueControl.d.ts +16 -4
- package/dist/application/operations/queueControl.d.ts.map +1 -1
- package/dist/application/operations/queueControl.js +119 -23
- package/dist/application/operations/queueControl.js.map +1 -1
- package/dist/application/queueManager.d.ts +17 -3
- package/dist/application/queueManager.d.ts.map +1 -1
- package/dist/application/queueManager.js +106 -27
- package/dist/application/queueManager.js.map +1 -1
- package/dist/application/stallDetection.js +1 -0
- package/dist/application/stallDetection.js.map +1 -1
- package/dist/application/types.d.ts +2 -1
- package/dist/application/types.d.ts.map +1 -1
- package/dist/cli/client.d.ts.map +1 -1
- package/dist/cli/client.js +15 -2
- package/dist/cli/client.js.map +1 -1
- package/dist/cli/index.d.ts.map +1 -1
- package/dist/cli/index.js +31 -2
- package/dist/cli/index.js.map +1 -1
- package/dist/cli/output.d.ts +1 -1
- package/dist/cli/output.d.ts.map +1 -1
- package/dist/cli/output.js +71 -9
- package/dist/cli/output.js.map +1 -1
- package/dist/client/bunqueue/batch.js +2 -2
- package/dist/client/bunqueue/batch.js.map +1 -1
- package/dist/client/bunqueue.d.ts.map +1 -1
- package/dist/client/bunqueue.js +3 -3
- package/dist/client/bunqueue.js.map +1 -1
- package/dist/client/flow.d.ts.map +1 -1
- package/dist/client/flow.js +3 -1
- package/dist/client/flow.js.map +1 -1
- package/dist/client/flowJobFactory.d.ts +8 -1
- package/dist/client/flowJobFactory.d.ts.map +1 -1
- package/dist/client/flowJobFactory.js +328 -56
- package/dist/client/flowJobFactory.js.map +1 -1
- package/dist/client/flowPush.d.ts.map +1 -1
- package/dist/client/flowPush.js +95 -46
- package/dist/client/flowPush.js.map +1 -1
- package/dist/client/jobConversion.d.ts.map +1 -1
- package/dist/client/jobConversion.js +12 -4
- package/dist/client/jobConversion.js.map +1 -1
- package/dist/client/queue/bullmqCompat.d.ts +1 -0
- package/dist/client/queue/bullmqCompat.d.ts.map +1 -1
- package/dist/client/queue/dlq.js.map +1 -1
- package/dist/client/queue/dlqOps.d.ts.map +1 -1
- package/dist/client/queue/dlqOps.js.map +1 -1
- package/dist/client/queue/helpers.js.map +1 -1
- package/dist/client/queue/jobProxy.d.ts +22 -3
- package/dist/client/queue/jobProxy.d.ts.map +1 -1
- package/dist/client/queue/jobProxy.js +347 -66
- package/dist/client/queue/jobProxy.js.map +1 -1
- package/dist/client/queue/operations/add.d.ts +1 -0
- package/dist/client/queue/operations/add.d.ts.map +1 -1
- package/dist/client/queue/operations/add.js +126 -29
- package/dist/client/queue/operations/add.js.map +1 -1
- package/dist/client/queue/operations/management.d.ts +1 -1
- package/dist/client/queue/operations/management.d.ts.map +1 -1
- package/dist/client/queue/operations/management.js +27 -9
- package/dist/client/queue/operations/management.js.map +1 -1
- package/dist/client/queue/operations/query.d.ts +12 -0
- package/dist/client/queue/operations/query.d.ts.map +1 -1
- package/dist/client/queue/operations/query.js +44 -4
- package/dist/client/queue/operations/query.js.map +1 -1
- package/dist/client/queue/queue.d.ts.map +1 -1
- package/dist/client/queue/queue.js +8 -1
- package/dist/client/queue/queue.js.map +1 -1
- package/dist/client/queue/scheduler.d.ts +2 -0
- package/dist/client/queue/scheduler.d.ts.map +1 -1
- package/dist/client/queue/scheduler.js +28 -0
- package/dist/client/queue/scheduler.js.map +1 -1
- package/dist/client/queue/stall.js.map +1 -1
- package/dist/client/sandboxed/worker.d.ts.map +1 -1
- package/dist/client/sandboxed/worker.js +57 -15
- package/dist/client/sandboxed/worker.js.map +1 -1
- package/dist/client/sandboxed/wrapper.d.ts.map +1 -1
- package/dist/client/sandboxed/wrapper.js +62 -10
- package/dist/client/sandboxed/wrapper.js.map +1 -1
- package/dist/client/tcp/client.d.ts +9 -0
- package/dist/client/tcp/client.d.ts.map +1 -1
- package/dist/client/tcp/client.js +84 -28
- package/dist/client/tcp/client.js.map +1 -1
- package/dist/client/tcp/connection.d.ts.map +1 -1
- package/dist/client/tcp/connection.js +6 -1
- package/dist/client/tcp/connection.js.map +1 -1
- package/dist/client/tcp/types.d.ts +7 -0
- package/dist/client/tcp/types.d.ts.map +1 -1
- package/dist/client/types.d.ts +8 -4
- package/dist/client/types.d.ts.map +1 -1
- package/dist/client/types.js.map +1 -1
- package/dist/client/worker/ackBatcher.d.ts.map +1 -1
- package/dist/client/worker/ackBatcher.js +18 -8
- package/dist/client/worker/ackBatcher.js.map +1 -1
- package/dist/client/worker/processor.d.ts.map +1 -1
- package/dist/client/worker/processor.js +54 -99
- package/dist/client/worker/processor.js.map +1 -1
- package/dist/client/worker/processorHandlers.d.ts +55 -0
- package/dist/client/worker/processorHandlers.d.ts.map +1 -0
- package/dist/client/worker/processorHandlers.js +373 -0
- package/dist/client/worker/processorHandlers.js.map +1 -0
- package/dist/client/workflow/compensator.d.ts +15 -0
- package/dist/client/workflow/compensator.d.ts.map +1 -0
- package/dist/client/workflow/compensator.js +46 -0
- package/dist/client/workflow/compensator.js.map +1 -0
- package/dist/client/workflow/emitter.d.ts.map +1 -1
- package/dist/client/workflow/emitter.js +15 -3
- package/dist/client/workflow/emitter.js.map +1 -1
- package/dist/client/workflow/engine.d.ts +8 -1
- package/dist/client/workflow/engine.d.ts.map +1 -1
- package/dist/client/workflow/engine.js +9 -0
- package/dist/client/workflow/engine.js.map +1 -1
- package/dist/client/workflow/executor.d.ts +5 -2
- package/dist/client/workflow/executor.d.ts.map +1 -1
- package/dist/client/workflow/executor.js +43 -60
- package/dist/client/workflow/executor.js.map +1 -1
- package/dist/client/workflow/index.d.ts +1 -1
- package/dist/client/workflow/index.d.ts.map +1 -1
- package/dist/client/workflow/loops.d.ts +1 -1
- package/dist/client/workflow/loops.d.ts.map +1 -1
- package/dist/client/workflow/loops.js +10 -1
- package/dist/client/workflow/loops.js.map +1 -1
- package/dist/client/workflow/recovery.d.ts +23 -0
- package/dist/client/workflow/recovery.d.ts.map +1 -0
- package/dist/client/workflow/recovery.js +74 -0
- package/dist/client/workflow/recovery.js.map +1 -0
- package/dist/client/workflow/runner.d.ts.map +1 -1
- package/dist/client/workflow/runner.js +7 -5
- package/dist/client/workflow/runner.js.map +1 -1
- package/dist/client/workflow/store.d.ts +2 -0
- package/dist/client/workflow/store.d.ts.map +1 -1
- package/dist/client/workflow/store.js +6 -0
- package/dist/client/workflow/store.js.map +1 -1
- package/dist/client/workflow/types.d.ts +41 -22
- package/dist/client/workflow/types.d.ts.map +1 -1
- package/dist/client/workflow/workflow.d.ts +17 -14
- package/dist/client/workflow/workflow.d.ts.map +1 -1
- package/dist/client/workflow/workflow.js +30 -20
- package/dist/client/workflow/workflow.js.map +1 -1
- package/dist/domain/queue/dlqShard.d.ts.map +1 -1
- package/dist/domain/queue/dlqShard.js +6 -0
- package/dist/domain/queue/dlqShard.js.map +1 -1
- package/dist/domain/queue/priorityQueue.d.ts +2 -2
- package/dist/domain/queue/priorityQueue.d.ts.map +1 -1
- package/dist/domain/queue/priorityQueue.js +5 -3
- package/dist/domain/queue/priorityQueue.js.map +1 -1
- package/dist/domain/types/command.d.ts +22 -0
- package/dist/domain/types/command.d.ts.map +1 -1
- package/dist/domain/types/cron.d.ts +21 -0
- package/dist/domain/types/cron.d.ts.map +1 -1
- package/dist/domain/types/cron.js +1 -0
- package/dist/domain/types/cron.js.map +1 -1
- package/dist/domain/types/job.d.ts.map +1 -1
- package/dist/domain/types/job.js +9 -2
- package/dist/domain/types/job.js.map +1 -1
- package/dist/domain/types/response.d.ts +2 -0
- package/dist/domain/types/response.d.ts.map +1 -1
- package/dist/domain/types/response.js.map +1 -1
- package/dist/infrastructure/backup/s3BackupOperations.d.ts.map +1 -1
- package/dist/infrastructure/backup/s3BackupOperations.js +44 -6
- package/dist/infrastructure/backup/s3BackupOperations.js.map +1 -1
- package/dist/infrastructure/cloud/cloudAgent.d.ts +1 -1
- package/dist/infrastructure/cloud/cloudAgent.d.ts.map +1 -1
- package/dist/infrastructure/cloud/cloudAgent.js +9 -11
- package/dist/infrastructure/cloud/cloudAgent.js.map +1 -1
- package/dist/infrastructure/cloud/commands.js +2 -2
- package/dist/infrastructure/cloud/commands.js.map +1 -1
- package/dist/infrastructure/cloud/redact.d.ts +11 -0
- package/dist/infrastructure/cloud/redact.d.ts.map +1 -0
- package/dist/infrastructure/cloud/redact.js +22 -0
- package/dist/infrastructure/cloud/redact.js.map +1 -0
- package/dist/infrastructure/cloud/snapshotCollector.d.ts +4 -0
- package/dist/infrastructure/cloud/snapshotCollector.d.ts.map +1 -1
- package/dist/infrastructure/cloud/snapshotCollector.js +32 -17
- package/dist/infrastructure/cloud/snapshotCollector.js.map +1 -1
- package/dist/infrastructure/cloud/snapshotHelpers.d.ts +9 -2
- package/dist/infrastructure/cloud/snapshotHelpers.d.ts.map +1 -1
- package/dist/infrastructure/cloud/snapshotHelpers.js +10 -8
- package/dist/infrastructure/cloud/snapshotHelpers.js.map +1 -1
- package/dist/infrastructure/persistence/schema.d.ts +2 -2
- package/dist/infrastructure/persistence/schema.d.ts.map +1 -1
- package/dist/infrastructure/persistence/schema.js +16 -2
- package/dist/infrastructure/persistence/schema.js.map +1 -1
- package/dist/infrastructure/persistence/sqlite.d.ts +54 -1
- package/dist/infrastructure/persistence/sqlite.d.ts.map +1 -1
- package/dist/infrastructure/persistence/sqlite.js +174 -2
- package/dist/infrastructure/persistence/sqlite.js.map +1 -1
- package/dist/infrastructure/persistence/sqliteBatch.d.ts +14 -0
- package/dist/infrastructure/persistence/sqliteBatch.d.ts.map +1 -1
- package/dist/infrastructure/persistence/sqliteBatch.js +29 -0
- package/dist/infrastructure/persistence/sqliteBatch.js.map +1 -1
- package/dist/infrastructure/persistence/sqliteSerializer.d.ts +16 -0
- package/dist/infrastructure/persistence/sqliteSerializer.d.ts.map +1 -1
- package/dist/infrastructure/persistence/sqliteSerializer.js +73 -8
- package/dist/infrastructure/persistence/sqliteSerializer.js.map +1 -1
- package/dist/infrastructure/persistence/statements.d.ts +2 -1
- package/dist/infrastructure/persistence/statements.d.ts.map +1 -1
- package/dist/infrastructure/persistence/statements.js +3 -2
- package/dist/infrastructure/persistence/statements.js.map +1 -1
- package/dist/infrastructure/scheduler/cronScheduler.d.ts.map +1 -1
- package/dist/infrastructure/scheduler/cronScheduler.js +19 -1
- package/dist/infrastructure/scheduler/cronScheduler.js.map +1 -1
- package/dist/infrastructure/server/handlers/advanced.d.ts +7 -1
- package/dist/infrastructure/server/handlers/advanced.d.ts.map +1 -1
- package/dist/infrastructure/server/handlers/advanced.js +41 -10
- package/dist/infrastructure/server/handlers/advanced.js.map +1 -1
- package/dist/infrastructure/server/handlers/core.d.ts.map +1 -1
- package/dist/infrastructure/server/handlers/core.js +8 -0
- package/dist/infrastructure/server/handlers/core.js.map +1 -1
- package/dist/infrastructure/server/handlers/cron.d.ts.map +1 -1
- package/dist/infrastructure/server/handlers/cron.js +1 -0
- package/dist/infrastructure/server/handlers/cron.js.map +1 -1
- package/dist/infrastructure/server/handlers/dashboard.d.ts.map +1 -1
- package/dist/infrastructure/server/handlers/dashboard.js +1 -0
- package/dist/infrastructure/server/handlers/dashboard.js.map +1 -1
- package/dist/infrastructure/server/handlers/dlq.js.map +1 -1
- package/dist/infrastructure/server/handlers/management.d.ts +1 -1
- package/dist/infrastructure/server/handlers/management.d.ts.map +1 -1
- package/dist/infrastructure/server/handlers/management.js +27 -12
- package/dist/infrastructure/server/handlers/management.js.map +1 -1
- package/dist/infrastructure/server/handlers/monitoring.js.map +1 -1
- package/dist/infrastructure/server/handlers/query.js.map +1 -1
- package/dist/infrastructure/server/httpRouteJobs.js.map +1 -1
- package/dist/infrastructure/server/httpRouteQueueConfig.js.map +1 -1
- package/dist/infrastructure/server/httpRouteQueues.js.map +1 -1
- package/dist/infrastructure/server/httpRouteResources.js.map +1 -1
- package/dist/infrastructure/server/protocol.d.ts +4 -0
- package/dist/infrastructure/server/protocol.d.ts.map +1 -1
- package/dist/infrastructure/server/protocol.js +17 -2
- package/dist/infrastructure/server/protocol.js.map +1 -1
- package/dist/infrastructure/server/socketWriteQueue.d.ts +67 -0
- package/dist/infrastructure/server/socketWriteQueue.d.ts.map +1 -0
- package/dist/infrastructure/server/socketWriteQueue.js +127 -0
- package/dist/infrastructure/server/socketWriteQueue.js.map +1 -0
- package/dist/infrastructure/server/tcp.d.ts +17 -0
- package/dist/infrastructure/server/tcp.d.ts.map +1 -1
- package/dist/infrastructure/server/tcp.js +112 -14
- package/dist/infrastructure/server/tcp.js.map +1 -1
- package/dist/infrastructure/server/wsHandler.js.map +1 -1
- package/dist/main.d.ts.map +1 -1
- package/dist/main.js +48 -43
- package/dist/main.js.map +1 -1
- package/dist/mcp/adapter.d.ts +3 -3
- package/dist/mcp/adapter.d.ts.map +1 -1
- package/dist/mcp/adapter.js +48 -15
- package/dist/mcp/adapter.js.map +1 -1
- package/dist/mcp/index.d.ts +3 -3
- package/dist/mcp/index.d.ts.map +1 -1
- package/dist/mcp/index.js +26 -89
- package/dist/mcp/index.js.map +1 -1
- package/dist/mcp/server.d.ts +16 -0
- package/dist/mcp/server.d.ts.map +1 -0
- package/dist/mcp/server.js +101 -0
- package/dist/mcp/server.js.map +1 -0
- package/dist/mcp/tools/queueTools.d.ts.map +1 -1
- package/dist/mcp/tools/queueTools.js +6 -3
- package/dist/mcp/tools/queueTools.js.map +1 -1
- package/dist/mcp/tools/webhookTools.js +1 -1
- package/dist/mcp/tools/webhookTools.js.map +1 -1
- package/dist/shared/lock.d.ts.map +1 -1
- package/dist/shared/lock.js +15 -0
- package/dist/shared/lock.js.map +1 -1
- 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;
|
|
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;
|
|
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,EAAE,CAAC;gBACvB,IAAI,CAAC;oBACH,EAAE,CAAC,KAAK,CAAC,CAAC;gBACZ,CAAC;gBAAC,MAAM,CAAC;oBACP,6CAA6C;gBAC/C,CAAC;YACH,CAAC;QACH,CAAC;QACD,KAAK,MAAM,EAAE,IAAI,IAAI,CAAC,eAAe,EAAE,CAAC;YACtC,IAAI,CAAC;gBACH,EAAE,CAAC,KAAK,CAAC,CAAC;YACZ,CAAC;YAAC,MAAM,CAAC;gBACP,6CAA6C;YAC/C,CAAC;QACH,CAAC;IACH,CAAC;CACF"}
|
|
@@ -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,
|
|
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":"AAAA;;;GAGG;AAEH,OAAO,EAAE,KAAK,EAAE,MAAM,gBAAgB,CAAC;AACvC,OAAO,EAAE,MAAM,EAAE,MAAM,kBAAkB,CAAC;AAC1C,OAAO,EAAE,aAAa,EAAE,MAAM,SAAS,CAAC;AACxC,OAAO,EAAE,gBAAgB,EAAE,MAAM,YAAY,CAAC;AAC9C,OAAO,EAAE,eAAe,EAAE,MAAM,WAAW,CAAC;
|
|
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(
|
|
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,
|
|
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"}
|