@etohq/orchestration 1.0.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (74) hide show
  1. package/dist/index.d.ts +4 -0
  2. package/dist/index.d.ts.map +1 -0
  3. package/dist/index.js +20 -0
  4. package/dist/index.js.map +1 -0
  5. package/dist/joiner/helpers.d.ts +3 -0
  6. package/dist/joiner/helpers.d.ts.map +1 -0
  7. package/dist/joiner/helpers.js +69 -0
  8. package/dist/joiner/helpers.js.map +1 -0
  9. package/dist/joiner/index.d.ts +3 -0
  10. package/dist/joiner/index.d.ts.map +1 -0
  11. package/dist/joiner/index.js +19 -0
  12. package/dist/joiner/index.js.map +1 -0
  13. package/dist/joiner/remote-joiner.d.ts +39 -0
  14. package/dist/joiner/remote-joiner.d.ts.map +1 -0
  15. package/dist/joiner/remote-joiner.js +872 -0
  16. package/dist/joiner/remote-joiner.js.map +1 -0
  17. package/dist/transaction/datastore/abstract-storage.d.ts +42 -0
  18. package/dist/transaction/datastore/abstract-storage.d.ts.map +1 -0
  19. package/dist/transaction/datastore/abstract-storage.js +52 -0
  20. package/dist/transaction/datastore/abstract-storage.js.map +1 -0
  21. package/dist/transaction/datastore/base-in-memory-storage.d.ts +11 -0
  22. package/dist/transaction/datastore/base-in-memory-storage.d.ts.map +1 -0
  23. package/dist/transaction/datastore/base-in-memory-storage.js +33 -0
  24. package/dist/transaction/datastore/base-in-memory-storage.js.map +1 -0
  25. package/dist/transaction/distributed-transaction.d.ts +99 -0
  26. package/dist/transaction/distributed-transaction.d.ts.map +1 -0
  27. package/dist/transaction/distributed-transaction.js +260 -0
  28. package/dist/transaction/distributed-transaction.js.map +1 -0
  29. package/dist/transaction/errors.d.ts +27 -0
  30. package/dist/transaction/errors.d.ts.map +1 -0
  31. package/dist/transaction/errors.js +78 -0
  32. package/dist/transaction/errors.js.map +1 -0
  33. package/dist/transaction/index.d.ts +8 -0
  34. package/dist/transaction/index.d.ts.map +1 -0
  35. package/dist/transaction/index.js +24 -0
  36. package/dist/transaction/index.js.map +1 -0
  37. package/dist/transaction/orchestrator-builder.d.ts +36 -0
  38. package/dist/transaction/orchestrator-builder.d.ts.map +1 -0
  39. package/dist/transaction/orchestrator-builder.js +300 -0
  40. package/dist/transaction/orchestrator-builder.js.map +1 -0
  41. package/dist/transaction/transaction-orchestrator.d.ts +118 -0
  42. package/dist/transaction/transaction-orchestrator.d.ts.map +1 -0
  43. package/dist/transaction/transaction-orchestrator.js +924 -0
  44. package/dist/transaction/transaction-orchestrator.js.map +1 -0
  45. package/dist/transaction/transaction-step.d.ts +67 -0
  46. package/dist/transaction/transaction-step.d.ts.map +1 -0
  47. package/dist/transaction/transaction-step.js +146 -0
  48. package/dist/transaction/transaction-step.js.map +1 -0
  49. package/dist/transaction/types.d.ts +223 -0
  50. package/dist/transaction/types.d.ts.map +1 -0
  51. package/dist/transaction/types.js +23 -0
  52. package/dist/transaction/types.js.map +1 -0
  53. package/dist/tsconfig.tsbuildinfo +1 -0
  54. package/dist/workflow/global-workflow.d.ts +14 -0
  55. package/dist/workflow/global-workflow.d.ts.map +1 -0
  56. package/dist/workflow/global-workflow.js +93 -0
  57. package/dist/workflow/global-workflow.js.map +1 -0
  58. package/dist/workflow/index.d.ts +5 -0
  59. package/dist/workflow/index.d.ts.map +1 -0
  60. package/dist/workflow/index.js +21 -0
  61. package/dist/workflow/index.js.map +1 -0
  62. package/dist/workflow/local-workflow.d.ts +44 -0
  63. package/dist/workflow/local-workflow.d.ts.map +1 -0
  64. package/dist/workflow/local-workflow.js +327 -0
  65. package/dist/workflow/local-workflow.js.map +1 -0
  66. package/dist/workflow/scheduler.d.ts +12 -0
  67. package/dist/workflow/scheduler.d.ts.map +1 -0
  68. package/dist/workflow/scheduler.js +36 -0
  69. package/dist/workflow/scheduler.js.map +1 -0
  70. package/dist/workflow/workflow-manager.d.ts +38 -0
  71. package/dist/workflow/workflow-manager.d.ts.map +1 -0
  72. package/dist/workflow/workflow-manager.js +124 -0
  73. package/dist/workflow/workflow-manager.js.map +1 -0
  74. package/package.json +52 -0
@@ -0,0 +1,93 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.GlobalWorkflow = void 0;
4
+ const utils_1 = require("@etohq/utils");
5
+ const awilix_1 = require("awilix");
6
+ const workflow_manager_1 = require("./workflow-manager");
7
+ class GlobalWorkflow extends workflow_manager_1.WorkflowManager {
8
+ constructor(modulesLoaded, context, subscribe) {
9
+ super();
10
+ let container;
11
+ if (!Array.isArray(modulesLoaded) && modulesLoaded) {
12
+ if (!("cradle" in modulesLoaded)) {
13
+ container = (0, utils_1.createEtoContainer)(modulesLoaded);
14
+ }
15
+ else {
16
+ container = modulesLoaded;
17
+ }
18
+ }
19
+ else if (Array.isArray(modulesLoaded) && modulesLoaded.length) {
20
+ container = (0, utils_1.createEtoContainer)();
21
+ for (const mod of modulesLoaded || []) {
22
+ const keyName = mod.__definition.key;
23
+ container.register(keyName, (0, awilix_1.asValue)(mod));
24
+ }
25
+ }
26
+ this.container = container;
27
+ this.context = context ?? {};
28
+ this.subscribe = subscribe ?? {};
29
+ }
30
+ async run(workflowId, uniqueTransactionId, input) {
31
+ if (!workflow_manager_1.WorkflowManager.workflows.has(workflowId)) {
32
+ throw new Error(`Workflow with id "${workflowId}" not found.`);
33
+ }
34
+ const workflow = workflow_manager_1.WorkflowManager.workflows.get(workflowId);
35
+ const orchestrator = workflow.orchestrator;
36
+ const transaction = await orchestrator.beginTransaction(uniqueTransactionId, workflow.handler(this.container, this.context), input);
37
+ if (this.subscribe.onStepBegin) {
38
+ transaction.once("stepBegin", this.subscribe.onStepBegin);
39
+ }
40
+ if (this.subscribe.onStepSuccess) {
41
+ transaction.once("stepSuccess", this.subscribe.onStepSuccess);
42
+ }
43
+ if (this.subscribe.onStepFailure) {
44
+ transaction.once("stepFailure", this.subscribe.onStepFailure);
45
+ }
46
+ if (this.subscribe.onStepAwaiting) {
47
+ transaction.once("stepAwaiting", this.subscribe.onStepAwaiting);
48
+ }
49
+ await orchestrator.resume(transaction);
50
+ return transaction;
51
+ }
52
+ async registerStepSuccess(workflowId, idempotencyKey, response) {
53
+ if (!workflow_manager_1.WorkflowManager.workflows.has(workflowId)) {
54
+ throw new Error(`Workflow with id "${workflowId}" not found.`);
55
+ }
56
+ const workflow = workflow_manager_1.WorkflowManager.workflows.get(workflowId);
57
+ const orchestrator = workflow.orchestrator;
58
+ orchestrator.once("resume", (transaction) => {
59
+ if (this.subscribe.onStepBegin) {
60
+ transaction.once("stepBegin", this.subscribe.onStepBegin);
61
+ }
62
+ if (this.subscribe.onStepSuccess) {
63
+ transaction.once("stepSuccess", this.subscribe.onStepSuccess);
64
+ }
65
+ if (this.subscribe.onStepFailure) {
66
+ transaction.once("stepFailure", this.subscribe.onStepFailure);
67
+ }
68
+ });
69
+ return await workflow.orchestrator.registerStepSuccess(idempotencyKey, workflow.handler(this.container, this.context), undefined, response);
70
+ }
71
+ async registerStepFailure(workflowId, idempotencyKey, error) {
72
+ if (!workflow_manager_1.WorkflowManager.workflows.has(workflowId)) {
73
+ throw new Error(`Workflow with id "${workflowId}" not found.`);
74
+ }
75
+ const workflow = workflow_manager_1.WorkflowManager.workflows.get(workflowId);
76
+ const orchestrator = workflow.orchestrator;
77
+ orchestrator.once("resume", (transaction) => {
78
+ if (this.subscribe.onStepBegin) {
79
+ transaction.once("stepBegin", this.subscribe.onStepBegin);
80
+ }
81
+ if (this.subscribe.onStepSuccess) {
82
+ transaction.once("stepSuccess", this.subscribe.onStepSuccess);
83
+ }
84
+ if (this.subscribe.onStepFailure) {
85
+ transaction.once("stepFailure", this.subscribe.onStepFailure);
86
+ }
87
+ });
88
+ return await workflow.orchestrator.registerStepFailure(idempotencyKey, error, workflow.handler(this.container, this.context));
89
+ }
90
+ }
91
+ exports.GlobalWorkflow = GlobalWorkflow;
92
+ GlobalWorkflow.workflows = new Map();
93
+ //# sourceMappingURL=global-workflow.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"global-workflow.js","sourceRoot":"","sources":["../../src/workflow/global-workflow.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,5 @@
1
+ export * from "./workflow-manager";
2
+ export * from "./local-workflow";
3
+ export * from "./global-workflow";
4
+ export * from "./scheduler";
5
+ //# sourceMappingURL=index.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/workflow/index.ts"],"names":[],"mappings":"AAAA,cAAc,oBAAoB,CAAA;AAClC,cAAc,kBAAkB,CAAA;AAChC,cAAc,mBAAmB,CAAA;AACjC,cAAc,aAAa,CAAA"}
@@ -0,0 +1,21 @@
1
+ "use strict";
2
+ var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
3
+ if (k2 === undefined) k2 = k;
4
+ var desc = Object.getOwnPropertyDescriptor(m, k);
5
+ if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
6
+ desc = { enumerable: true, get: function() { return m[k]; } };
7
+ }
8
+ Object.defineProperty(o, k2, desc);
9
+ }) : (function(o, m, k, k2) {
10
+ if (k2 === undefined) k2 = k;
11
+ o[k2] = m[k];
12
+ }));
13
+ var __exportStar = (this && this.__exportStar) || function(m, exports) {
14
+ for (var p in m) if (p !== "default" && !Object.prototype.hasOwnProperty.call(exports, p)) __createBinding(exports, m, p);
15
+ };
16
+ Object.defineProperty(exports, "__esModule", { value: true });
17
+ __exportStar(require("./workflow-manager"), exports);
18
+ __exportStar(require("./local-workflow"), exports);
19
+ __exportStar(require("./global-workflow"), exports);
20
+ __exportStar(require("./scheduler"), exports);
21
+ //# sourceMappingURL=index.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/workflow/index.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;AAAA,qDAAkC;AAClC,mDAAgC;AAChC,oDAAiC;AACjC,8CAA2B"}
@@ -0,0 +1,44 @@
1
+ import { Context, LoadedModule, EtoContainer } from "@etohq/types";
2
+ import { DistributedTransactionEvents, DistributedTransactionType, TransactionFlow, TransactionModelOptions, TransactionStepsDefinition } from "../transaction";
3
+ import { OrchestratorBuilder } from "../transaction/orchestrator-builder";
4
+ import { WorkflowDefinition, WorkflowStepHandler } from "./workflow-manager";
5
+ type StepHandler = {
6
+ invoke: WorkflowStepHandler;
7
+ compensate?: WorkflowStepHandler;
8
+ };
9
+ export declare class LocalWorkflow {
10
+ protected container_: EtoContainer;
11
+ protected workflowId: string;
12
+ protected flow: OrchestratorBuilder;
13
+ protected customOptions: Partial<TransactionModelOptions>;
14
+ protected workflow: WorkflowDefinition;
15
+ protected handlers: Map<string, StepHandler>;
16
+ protected etoContext?: Context;
17
+ get container(): EtoContainer;
18
+ set container(modulesLoaded: LoadedModule[] | EtoContainer);
19
+ constructor(workflowId: string, modulesLoaded?: LoadedModule[] | EtoContainer);
20
+ private resolveContainer;
21
+ private contextualizedEtoModules;
22
+ protected commit(): void;
23
+ getFlow(): TransactionStepsDefinition;
24
+ private registerEventCallbacks;
25
+ run(uniqueTransactionId: string, input?: unknown, context?: Context, subscribe?: DistributedTransactionEvents, flowMetadata?: TransactionFlow["metadata"]): Promise<DistributedTransactionType>;
26
+ getRunningTransaction(uniqueTransactionId: string, context?: Context): Promise<DistributedTransactionType>;
27
+ cancel(transactionOrTransactionId: string | DistributedTransactionType, context?: Context, subscribe?: DistributedTransactionEvents): Promise<DistributedTransactionType>;
28
+ registerStepSuccess(idempotencyKey: string, response?: unknown, context?: Context, subscribe?: DistributedTransactionEvents): Promise<DistributedTransactionType>;
29
+ registerStepFailure(idempotencyKey: string, error?: Error | any, context?: Context, subscribe?: DistributedTransactionEvents): Promise<DistributedTransactionType>;
30
+ setOptions(options: Partial<TransactionModelOptions>): this;
31
+ addAction(action: string, handler: StepHandler, options?: Partial<TransactionStepsDefinition>): OrchestratorBuilder;
32
+ replaceAction(existingAction: string, action: string, handler: StepHandler, options?: Partial<TransactionStepsDefinition>): OrchestratorBuilder;
33
+ insertActionBefore(existingAction: string, action: string, handler: StepHandler, options?: Partial<TransactionStepsDefinition>): OrchestratorBuilder;
34
+ insertActionAfter(existingAction: string, action: string, handler: StepHandler, options?: Partial<TransactionStepsDefinition>): OrchestratorBuilder;
35
+ appendAction(action: string, to: string, handler: StepHandler, options?: Partial<TransactionStepsDefinition>): OrchestratorBuilder;
36
+ moveAction(actionToMove: string, targetAction: string): OrchestratorBuilder;
37
+ moveAndMergeNextAction(actionToMove: string, targetAction: string): OrchestratorBuilder;
38
+ mergeActions(where: string, ...actions: string[]): OrchestratorBuilder;
39
+ deleteAction(action: string, parentSteps?: any): OrchestratorBuilder;
40
+ pruneAction(action: string): OrchestratorBuilder;
41
+ protected assertHandler(handler: StepHandler, action: string): void | never;
42
+ }
43
+ export {};
44
+ //# sourceMappingURL=local-workflow.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"local-workflow.d.ts","sourceRoot":"","sources":["../../src/workflow/local-workflow.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,327 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.LocalWorkflow = void 0;
4
+ const utils_1 = require("@etohq/utils");
5
+ const awilix_1 = require("awilix");
6
+ const transaction_1 = require("../transaction");
7
+ const orchestrator_builder_1 = require("../transaction/orchestrator-builder");
8
+ const workflow_manager_1 = require("./workflow-manager");
9
+ class LocalWorkflow {
10
+ get container() {
11
+ return this.container_;
12
+ }
13
+ set container(modulesLoaded) {
14
+ this.resolveContainer(modulesLoaded);
15
+ }
16
+ constructor(workflowId, modulesLoaded) {
17
+ this.customOptions = {};
18
+ const globalWorkflow = workflow_manager_1.WorkflowManager.getWorkflow(workflowId);
19
+ if (!globalWorkflow) {
20
+ throw new utils_1.EtoError(utils_1.EtoError.Types.NOT_FOUND, `Workflow with id "${workflowId}" not found.`);
21
+ }
22
+ const workflow = {
23
+ ...globalWorkflow,
24
+ orchestrator: transaction_1.TransactionOrchestrator.clone(globalWorkflow.orchestrator),
25
+ };
26
+ this.flow = new orchestrator_builder_1.OrchestratorBuilder(workflow.flow_);
27
+ this.workflowId = workflowId;
28
+ this.workflow = workflow;
29
+ this.handlers = new Map(workflow.handlers_);
30
+ this.resolveContainer(modulesLoaded);
31
+ }
32
+ resolveContainer(modulesLoaded) {
33
+ let container;
34
+ if (!Array.isArray(modulesLoaded) && modulesLoaded) {
35
+ if (!("cradle" in modulesLoaded)) {
36
+ container = (0, utils_1.createEtoContainer)(modulesLoaded);
37
+ }
38
+ else {
39
+ container = (0, utils_1.createEtoContainer)({}, modulesLoaded); // copy container
40
+ }
41
+ }
42
+ else if (Array.isArray(modulesLoaded) && modulesLoaded.length) {
43
+ container = (0, utils_1.createEtoContainer)();
44
+ for (const mod of modulesLoaded || []) {
45
+ const keyName = mod.__definition.key;
46
+ container.register(keyName, (0, awilix_1.asValue)(mod));
47
+ }
48
+ }
49
+ this.container_ = this.contextualizedEtoModules(container);
50
+ }
51
+ contextualizedEtoModules(container) {
52
+ if (!container) {
53
+ return (0, utils_1.createEtoContainer)();
54
+ }
55
+ // eslint-disable-next-line
56
+ const this_ = this;
57
+ const originalResolver = container.resolve;
58
+ container.resolve = function (keyName, opts) {
59
+ const resolved = originalResolver(keyName, opts);
60
+ if (resolved?.constructor?.__type !== utils_1.EtoModuleType) {
61
+ return resolved;
62
+ }
63
+ return new Proxy(resolved, {
64
+ get: function (target, prop) {
65
+ if (typeof target[prop] !== "function") {
66
+ return target[prop];
67
+ }
68
+ return async (...args) => {
69
+ const ctxIndex = utils_1.EtoContext.getIndex(target, prop);
70
+ const hasContext = args[ctxIndex]?.__type === utils_1.EtoContextType;
71
+ if (!hasContext && (0, utils_1.isDefined)(ctxIndex)) {
72
+ const context = this_.etoContext;
73
+ if (context?.__type === utils_1.EtoContextType) {
74
+ delete context?.manager;
75
+ delete context?.transactionManager;
76
+ args[ctxIndex] = context;
77
+ }
78
+ }
79
+ return await target[prop].apply(target, [...args]);
80
+ };
81
+ },
82
+ });
83
+ };
84
+ return container;
85
+ }
86
+ commit() {
87
+ const finalFlow = this.flow.build();
88
+ const globalWorkflow = workflow_manager_1.WorkflowManager.getWorkflow(this.workflowId);
89
+ const customOptions = {
90
+ ...globalWorkflow?.options,
91
+ ...this.customOptions,
92
+ };
93
+ this.workflow = {
94
+ id: this.workflowId,
95
+ flow_: finalFlow,
96
+ orchestrator: new transaction_1.TransactionOrchestrator({
97
+ id: this.workflowId,
98
+ definition: finalFlow,
99
+ options: customOptions,
100
+ }),
101
+ options: customOptions,
102
+ handler: workflow_manager_1.WorkflowManager.buildHandlers(this.handlers),
103
+ handlers_: this.handlers,
104
+ };
105
+ }
106
+ getFlow() {
107
+ if (this.flow.hasChanges) {
108
+ this.commit();
109
+ }
110
+ return this.workflow.flow_;
111
+ }
112
+ registerEventCallbacks({ orchestrator, transaction, subscribe, idempotencyKey, }) {
113
+ const modelId = orchestrator.id;
114
+ let transactionId;
115
+ if (transaction) {
116
+ transactionId = transaction.transactionId;
117
+ }
118
+ else if (idempotencyKey) {
119
+ const [, trxId] = idempotencyKey.split(":");
120
+ transactionId = trxId;
121
+ }
122
+ const eventWrapperMap = new Map();
123
+ for (const [key, handler] of Object.entries(subscribe ?? {})) {
124
+ eventWrapperMap.set(key, (args) => {
125
+ const { transaction } = args;
126
+ if (transaction.transactionId !== transactionId ||
127
+ transaction.modelId !== modelId) {
128
+ return;
129
+ }
130
+ handler(args);
131
+ });
132
+ }
133
+ if (subscribe?.onBegin) {
134
+ orchestrator.on(transaction_1.DistributedTransactionEvent.BEGIN, eventWrapperMap.get("onBegin"));
135
+ }
136
+ if (subscribe?.onResume) {
137
+ orchestrator.on(transaction_1.DistributedTransactionEvent.RESUME, eventWrapperMap.get("onResume"));
138
+ }
139
+ if (subscribe?.onCompensateBegin) {
140
+ orchestrator.on(transaction_1.DistributedTransactionEvent.COMPENSATE_BEGIN, eventWrapperMap.get("onCompensateBegin"));
141
+ }
142
+ if (subscribe?.onTimeout) {
143
+ orchestrator.on(transaction_1.DistributedTransactionEvent.TIMEOUT, eventWrapperMap.get("onTimeout"));
144
+ }
145
+ if (subscribe?.onFinish) {
146
+ orchestrator.on(transaction_1.DistributedTransactionEvent.FINISH, eventWrapperMap.get("onFinish"));
147
+ }
148
+ const resumeWrapper = ({ transaction }) => {
149
+ if (transaction.modelId !== modelId ||
150
+ transaction.transactionId !== transactionId) {
151
+ return;
152
+ }
153
+ if (subscribe?.onStepBegin) {
154
+ transaction.on(transaction_1.DistributedTransactionEvent.STEP_BEGIN, eventWrapperMap.get("onStepBegin"));
155
+ }
156
+ if (subscribe?.onStepSuccess) {
157
+ transaction.on(transaction_1.DistributedTransactionEvent.STEP_SUCCESS, eventWrapperMap.get("onStepSuccess"));
158
+ }
159
+ if (subscribe?.onStepFailure) {
160
+ transaction.on(transaction_1.DistributedTransactionEvent.STEP_FAILURE, eventWrapperMap.get("onStepFailure"));
161
+ }
162
+ if (subscribe?.onStepAwaiting) {
163
+ transaction.on(transaction_1.DistributedTransactionEvent.STEP_AWAITING, eventWrapperMap.get("onStepAwaiting"));
164
+ }
165
+ if (subscribe?.onCompensateStepSuccess) {
166
+ transaction.on(transaction_1.DistributedTransactionEvent.COMPENSATE_STEP_SUCCESS, eventWrapperMap.get("onCompensateStepSuccess"));
167
+ }
168
+ if (subscribe?.onCompensateStepFailure) {
169
+ transaction.on(transaction_1.DistributedTransactionEvent.COMPENSATE_STEP_FAILURE, eventWrapperMap.get("onCompensateStepFailure"));
170
+ }
171
+ if (subscribe?.onStepSkipped) {
172
+ transaction.on(transaction_1.DistributedTransactionEvent.STEP_SKIPPED, eventWrapperMap.get("onStepSkipped"));
173
+ }
174
+ };
175
+ if (transaction) {
176
+ resumeWrapper({ transaction });
177
+ }
178
+ else {
179
+ orchestrator.once("resume", resumeWrapper);
180
+ }
181
+ const cleanUp = () => {
182
+ subscribe?.onFinish &&
183
+ orchestrator.removeListener(transaction_1.DistributedTransactionEvent.FINISH, eventWrapperMap.get("onFinish"));
184
+ subscribe?.onResume &&
185
+ orchestrator.removeListener(transaction_1.DistributedTransactionEvent.RESUME, eventWrapperMap.get("onResume"));
186
+ subscribe?.onBegin &&
187
+ orchestrator.removeListener(transaction_1.DistributedTransactionEvent.BEGIN, eventWrapperMap.get("onBegin"));
188
+ subscribe?.onCompensateBegin &&
189
+ orchestrator.removeListener(transaction_1.DistributedTransactionEvent.COMPENSATE_BEGIN, eventWrapperMap.get("onCompensateBegin"));
190
+ subscribe?.onTimeout &&
191
+ orchestrator.removeListener(transaction_1.DistributedTransactionEvent.TIMEOUT, eventWrapperMap.get("onTimeout"));
192
+ orchestrator.removeListener(transaction_1.DistributedTransactionEvent.RESUME, resumeWrapper);
193
+ eventWrapperMap.clear();
194
+ };
195
+ return {
196
+ cleanUpEventListeners: cleanUp,
197
+ };
198
+ }
199
+ async run(uniqueTransactionId, input, context, subscribe, flowMetadata) {
200
+ if (this.flow.hasChanges) {
201
+ this.commit();
202
+ }
203
+ this.etoContext = context;
204
+ const { handler, orchestrator } = this.workflow;
205
+ const transaction = await orchestrator.beginTransaction(uniqueTransactionId, handler(this.container_, context), input, flowMetadata);
206
+ const { cleanUpEventListeners } = this.registerEventCallbacks({
207
+ orchestrator,
208
+ transaction,
209
+ subscribe,
210
+ });
211
+ await orchestrator.resume(transaction);
212
+ try {
213
+ return transaction;
214
+ }
215
+ finally {
216
+ cleanUpEventListeners();
217
+ }
218
+ }
219
+ async getRunningTransaction(uniqueTransactionId, context) {
220
+ this.etoContext = context;
221
+ const { handler, orchestrator } = this.workflow;
222
+ const transaction = await orchestrator.retrieveExistingTransaction(uniqueTransactionId, handler(this.container_, context));
223
+ return transaction;
224
+ }
225
+ async cancel(transactionOrTransactionId, context, subscribe) {
226
+ this.etoContext = context;
227
+ const { orchestrator } = this.workflow;
228
+ const transaction = (0, utils_1.isString)(transactionOrTransactionId)
229
+ ? await this.getRunningTransaction(transactionOrTransactionId, context)
230
+ : transactionOrTransactionId;
231
+ const { cleanUpEventListeners } = this.registerEventCallbacks({
232
+ orchestrator,
233
+ transaction,
234
+ subscribe,
235
+ });
236
+ await orchestrator.cancelTransaction(transaction);
237
+ try {
238
+ return transaction;
239
+ }
240
+ finally {
241
+ cleanUpEventListeners();
242
+ }
243
+ }
244
+ async registerStepSuccess(idempotencyKey, response, context, subscribe) {
245
+ this.etoContext = context;
246
+ const { handler, orchestrator } = this.workflow;
247
+ const { cleanUpEventListeners } = this.registerEventCallbacks({
248
+ orchestrator,
249
+ idempotencyKey,
250
+ subscribe,
251
+ });
252
+ const transaction = await orchestrator.registerStepSuccess(idempotencyKey, handler(this.container_, context), undefined, response);
253
+ try {
254
+ return transaction;
255
+ }
256
+ finally {
257
+ cleanUpEventListeners();
258
+ }
259
+ }
260
+ async registerStepFailure(idempotencyKey, error, context, subscribe) {
261
+ this.etoContext = context;
262
+ const { handler, orchestrator } = this.workflow;
263
+ const { cleanUpEventListeners } = this.registerEventCallbacks({
264
+ orchestrator,
265
+ idempotencyKey,
266
+ subscribe,
267
+ });
268
+ const transaction = await orchestrator.registerStepFailure(idempotencyKey, error, handler(this.container_, context));
269
+ try {
270
+ return transaction;
271
+ }
272
+ finally {
273
+ cleanUpEventListeners();
274
+ }
275
+ }
276
+ setOptions(options) {
277
+ this.customOptions = options;
278
+ return this;
279
+ }
280
+ addAction(action, handler, options = {}) {
281
+ this.assertHandler(handler, action);
282
+ this.handlers.set(action, handler);
283
+ return this.flow.addAction(action, options);
284
+ }
285
+ replaceAction(existingAction, action, handler, options = {}) {
286
+ this.assertHandler(handler, action);
287
+ this.handlers.set(action, handler);
288
+ return this.flow.replaceAction(existingAction, action, options);
289
+ }
290
+ insertActionBefore(existingAction, action, handler, options = {}) {
291
+ this.assertHandler(handler, action);
292
+ this.handlers.set(action, handler);
293
+ return this.flow.insertActionBefore(existingAction, action, options);
294
+ }
295
+ insertActionAfter(existingAction, action, handler, options = {}) {
296
+ this.assertHandler(handler, action);
297
+ this.handlers.set(action, handler);
298
+ return this.flow.insertActionAfter(existingAction, action, options);
299
+ }
300
+ appendAction(action, to, handler, options = {}) {
301
+ this.assertHandler(handler, action);
302
+ this.handlers.set(action, handler);
303
+ return this.flow.appendAction(action, to, options);
304
+ }
305
+ moveAction(actionToMove, targetAction) {
306
+ return this.flow.moveAction(actionToMove, targetAction);
307
+ }
308
+ moveAndMergeNextAction(actionToMove, targetAction) {
309
+ return this.flow.moveAndMergeNextAction(actionToMove, targetAction);
310
+ }
311
+ mergeActions(where, ...actions) {
312
+ return this.flow.mergeActions(where, ...actions);
313
+ }
314
+ deleteAction(action, parentSteps) {
315
+ return this.flow.deleteAction(action, parentSteps);
316
+ }
317
+ pruneAction(action) {
318
+ return this.flow.pruneAction(action);
319
+ }
320
+ assertHandler(handler, action) {
321
+ if (!handler?.invoke) {
322
+ throw new Error(`Handler for action "${action}" is missing invoke function.`);
323
+ }
324
+ }
325
+ }
326
+ exports.LocalWorkflow = LocalWorkflow;
327
+ //# sourceMappingURL=local-workflow.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"local-workflow.js","sourceRoot":"","sources":["../../src/workflow/local-workflow.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,12 @@
1
+ import { IDistributedSchedulerStorage } from "../transaction";
2
+ import { WorkflowDefinition } from "./workflow-manager";
3
+ declare class WorkflowScheduler {
4
+ private static storage;
5
+ static setStorage(storage: IDistributedSchedulerStorage): void;
6
+ scheduleWorkflow(workflow: WorkflowDefinition): Promise<void>;
7
+ clearWorkflow(workflow: WorkflowDefinition): Promise<void>;
8
+ clear(): Promise<void>;
9
+ }
10
+ declare const GlobalWorkflowScheduler: typeof WorkflowScheduler;
11
+ export { GlobalWorkflowScheduler as WorkflowScheduler };
12
+ //# sourceMappingURL=scheduler.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"scheduler.d.ts","sourceRoot":"","sources":["../../src/workflow/scheduler.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,4BAA4B,EAAoB,MAAM,gBAAgB,CAAA;AAC/E,OAAO,EAAE,kBAAkB,EAAE,MAAM,oBAAoB,CAAA;AAEvD,cAAM,iBAAiB;IACrB,OAAO,CAAC,MAAM,CAAC,OAAO,CAA8B;WACtC,UAAU,CAAC,OAAO,EAAE,4BAA4B;IAIjD,gBAAgB,CAAC,QAAQ,EAAE,kBAAkB;IAwB7C,aAAa,CAAC,QAAQ,EAAE,kBAAkB;IAI1C,KAAK;CAGnB;AAGD,QAAA,MAAM,uBAAuB,EACC,OAAO,iBAAiB,CAAA;AAEtD,OAAO,EAAE,uBAAuB,IAAI,iBAAiB,EAAE,CAAA"}
@@ -0,0 +1,36 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.WorkflowScheduler = void 0;
4
+ const utils_1 = require("@etohq/utils");
5
+ class WorkflowScheduler {
6
+ static setStorage(storage) {
7
+ this.storage = storage;
8
+ }
9
+ async scheduleWorkflow(workflow) {
10
+ const schedule = workflow.options?.schedule;
11
+ if (!schedule) {
12
+ throw new utils_1.EtoError(utils_1.EtoError.Types.INVALID_ARGUMENT, "Workflow schedule is not defined while registering a scheduled workflow");
13
+ }
14
+ const normalizedSchedule = typeof schedule === "string"
15
+ ? {
16
+ cron: schedule,
17
+ concurrency: "forbid",
18
+ }
19
+ : {
20
+ cron: schedule.cron,
21
+ concurrency: schedule.concurrency || "forbid",
22
+ numberOfExecutions: schedule.numberOfExecutions,
23
+ };
24
+ await WorkflowScheduler.storage.schedule(workflow.id, normalizedSchedule);
25
+ }
26
+ async clearWorkflow(workflow) {
27
+ await WorkflowScheduler.storage.remove(workflow.id);
28
+ }
29
+ async clear() {
30
+ await WorkflowScheduler.storage.removeAll();
31
+ }
32
+ }
33
+ global.WorkflowScheduler ??= WorkflowScheduler;
34
+ const GlobalWorkflowScheduler = global.WorkflowScheduler;
35
+ exports.WorkflowScheduler = GlobalWorkflowScheduler;
36
+ //# sourceMappingURL=scheduler.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"scheduler.js","sourceRoot":"","sources":["../../src/workflow/scheduler.ts"],"names":[],"mappings":";;;AAAA,wCAAuC;AAIvC,MAAM,iBAAiB;IAEd,MAAM,CAAC,UAAU,CAAC,OAAqC;QAC5D,IAAI,CAAC,OAAO,GAAG,OAAO,CAAA;IACxB,CAAC;IAEM,KAAK,CAAC,gBAAgB,CAAC,QAA4B;QACxD,MAAM,QAAQ,GAAG,QAAQ,CAAC,OAAO,EAAE,QAAQ,CAAA;QAC3C,IAAI,CAAC,QAAQ,EAAE,CAAC;YACd,MAAM,IAAI,gBAAQ,CAChB,gBAAQ,CAAC,KAAK,CAAC,gBAAgB,EAC/B,yEAAyE,CAC1E,CAAA;QACH,CAAC;QAED,MAAM,kBAAkB,GACtB,OAAO,QAAQ,KAAK,QAAQ;YAC1B,CAAC,CAAC;gBACE,IAAI,EAAE,QAAQ;gBACd,WAAW,EAAE,QAAQ;aACtB;YACH,CAAC,CAAC;gBACE,IAAI,EAAE,QAAQ,CAAC,IAAI;gBACnB,WAAW,EAAE,QAAQ,CAAC,WAAW,IAAI,QAAQ;gBAC7C,kBAAkB,EAAE,QAAQ,CAAC,kBAAkB;aAChD,CAAA;QAEP,MAAM,iBAAiB,CAAC,OAAO,CAAC,QAAQ,CAAC,QAAQ,CAAC,EAAE,EAAE,kBAAkB,CAAC,CAAA;IAC3E,CAAC;IAEM,KAAK,CAAC,aAAa,CAAC,QAA4B;QACrD,MAAM,iBAAiB,CAAC,OAAO,CAAC,MAAM,CAAC,QAAQ,CAAC,EAAE,CAAC,CAAA;IACrD,CAAC;IAEM,KAAK,CAAC,KAAK;QAChB,MAAM,iBAAiB,CAAC,OAAO,CAAC,SAAS,EAAE,CAAA;IAC7C,CAAC;CACF;AAED,MAAM,CAAC,iBAAiB,KAAK,iBAAiB,CAAA;AAC9C,MAAM,uBAAuB,GAC3B,MAAM,CAAC,iBAA6C,CAAA;AAElB,oDAAiB"}
@@ -0,0 +1,38 @@
1
+ import { Context, EtoContainer } from "@etohq/types";
2
+ import { DistributedTransactionType, TransactionMetadata, TransactionModelOptions, TransactionOrchestrator, TransactionStep, TransactionStepHandler, TransactionStepsDefinition } from "../transaction";
3
+ export interface WorkflowDefinition {
4
+ id: string;
5
+ handler: (container: EtoContainer, context?: Context) => TransactionStepHandler;
6
+ orchestrator: TransactionOrchestrator;
7
+ flow_: TransactionStepsDefinition;
8
+ handlers_: Map<string, {
9
+ invoke: WorkflowStepHandler;
10
+ compensate?: WorkflowStepHandler;
11
+ }>;
12
+ options: TransactionModelOptions;
13
+ requiredModules?: Set<string>;
14
+ optionalModules?: Set<string>;
15
+ }
16
+ export type WorkflowHandler = Map<string, {
17
+ invoke: WorkflowStepHandler;
18
+ compensate?: WorkflowStepHandler;
19
+ }>;
20
+ export type WorkflowStepHandlerArguments = {
21
+ container: EtoContainer;
22
+ payload: unknown;
23
+ invoke: {
24
+ [actions: string]: unknown;
25
+ };
26
+ compensate: {
27
+ [actions: string]: unknown;
28
+ };
29
+ metadata: TransactionMetadata;
30
+ transaction: DistributedTransactionType;
31
+ step: TransactionStep;
32
+ orchestrator: TransactionOrchestrator;
33
+ context?: Context;
34
+ };
35
+ export type WorkflowStepHandler = (args: WorkflowStepHandlerArguments) => Promise<unknown>;
36
+ declare const GlobalWorkflowManager: any;
37
+ export { GlobalWorkflowManager as WorkflowManager };
38
+ //# sourceMappingURL=workflow-manager.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"workflow-manager.d.ts","sourceRoot":"","sources":["../../src/workflow/workflow-manager.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,OAAO,EAAE,YAAY,EAAE,MAAM,cAAc,CAAA;AACpD,OAAO,EACL,0BAA0B,EAG1B,mBAAmB,EACnB,uBAAuB,EACvB,uBAAuB,EACvB,eAAe,EACf,sBAAsB,EACtB,0BAA0B,EAC3B,MAAM,gBAAgB,CAAA;AAGvB,MAAM,WAAW,kBAAkB;IACjC,EAAE,EAAE,MAAM,CAAA;IACV,OAAO,EAAE,CACP,SAAS,EAAE,YAAY,EACvB,OAAO,CAAC,EAAE,OAAO,KACd,sBAAsB,CAAA;IAC3B,YAAY,EAAE,uBAAuB,CAAA;IACrC,KAAK,EAAE,0BAA0B,CAAA;IACjC,SAAS,EAAE,GAAG,CACZ,MAAM,EACN;QAAE,MAAM,EAAE,mBAAmB,CAAC;QAAC,UAAU,CAAC,EAAE,mBAAmB,CAAA;KAAE,CAClE,CAAA;IACD,OAAO,EAAE,uBAAuB,CAAA;IAChC,eAAe,CAAC,EAAE,GAAG,CAAC,MAAM,CAAC,CAAA;IAC7B,eAAe,CAAC,EAAE,GAAG,CAAC,MAAM,CAAC,CAAA;CAC9B;AAED,MAAM,MAAM,eAAe,GAAG,GAAG,CAC/B,MAAM,EACN;IAAE,MAAM,EAAE,mBAAmB,CAAC;IAAC,UAAU,CAAC,EAAE,mBAAmB,CAAA;CAAE,CAClE,CAAA;AAED,MAAM,MAAM,4BAA4B,GAAG;IACzC,SAAS,EAAE,YAAY,CAAA;IACvB,OAAO,EAAE,OAAO,CAAA;IAChB,MAAM,EAAE;QAAE,CAAC,OAAO,EAAE,MAAM,GAAG,OAAO,CAAA;KAAE,CAAA;IACtC,UAAU,EAAE;QAAE,CAAC,OAAO,EAAE,MAAM,GAAG,OAAO,CAAA;KAAE,CAAA;IAC1C,QAAQ,EAAE,mBAAmB,CAAA;IAC7B,WAAW,EAAE,0BAA0B,CAAA;IACvC,IAAI,EAAE,eAAe,CAAA;IACrB,YAAY,EAAE,uBAAuB,CAAA;IACrC,OAAO,CAAC,EAAE,OAAO,CAAA;CAClB,CAAA;AAED,MAAM,MAAM,mBAAmB,GAAG,CAChC,IAAI,EAAE,4BAA4B,KAC/B,OAAO,CAAC,OAAO,CAAC,CAAA;AAoLrB,QAAA,MAAM,qBAAqB,KAAyB,CAAA;AAEpD,OAAO,EAAE,qBAAqB,IAAI,eAAe,EAAE,CAAA"}