@marktoflow/core 2.0.0-alpha.3
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/bundle.d.ts +43 -0
- package/dist/bundle.d.ts.map +1 -0
- package/dist/bundle.js +202 -0
- package/dist/bundle.js.map +1 -0
- package/dist/config.d.ts +33 -0
- package/dist/config.d.ts.map +1 -0
- package/dist/config.js +27 -0
- package/dist/config.js.map +1 -0
- package/dist/costs.d.ts +182 -0
- package/dist/costs.d.ts.map +1 -0
- package/dist/costs.js +464 -0
- package/dist/costs.js.map +1 -0
- package/dist/credentials.d.ts +162 -0
- package/dist/credentials.d.ts.map +1 -0
- package/dist/credentials.js +646 -0
- package/dist/credentials.js.map +1 -0
- package/dist/engine.d.ts +137 -0
- package/dist/engine.d.ts.map +1 -0
- package/dist/engine.js +514 -0
- package/dist/engine.js.map +1 -0
- package/dist/env.d.ts +59 -0
- package/dist/env.d.ts.map +1 -0
- package/dist/env.js +256 -0
- package/dist/env.js.map +1 -0
- package/dist/failover.d.ts +43 -0
- package/dist/failover.d.ts.map +1 -0
- package/dist/failover.js +53 -0
- package/dist/failover.js.map +1 -0
- package/dist/filewatcher.d.ts +32 -0
- package/dist/filewatcher.d.ts.map +1 -0
- package/dist/filewatcher.js +92 -0
- package/dist/filewatcher.js.map +1 -0
- package/dist/index.d.ts +36 -0
- package/dist/index.d.ts.map +1 -0
- package/dist/index.js +69 -0
- package/dist/index.js.map +1 -0
- package/dist/logging.d.ts +62 -0
- package/dist/logging.d.ts.map +1 -0
- package/dist/logging.js +211 -0
- package/dist/logging.js.map +1 -0
- package/dist/mcp-loader.d.ts +29 -0
- package/dist/mcp-loader.d.ts.map +1 -0
- package/dist/mcp-loader.js +60 -0
- package/dist/mcp-loader.js.map +1 -0
- package/dist/metrics.d.ts +19 -0
- package/dist/metrics.d.ts.map +1 -0
- package/dist/metrics.js +65 -0
- package/dist/metrics.js.map +1 -0
- package/dist/models.d.ts +419 -0
- package/dist/models.d.ts.map +1 -0
- package/dist/models.js +111 -0
- package/dist/models.js.map +1 -0
- package/dist/parser.d.ts +40 -0
- package/dist/parser.d.ts.map +1 -0
- package/dist/parser.js +287 -0
- package/dist/parser.js.map +1 -0
- package/dist/plugins.d.ts +105 -0
- package/dist/plugins.d.ts.map +1 -0
- package/dist/plugins.js +182 -0
- package/dist/plugins.js.map +1 -0
- package/dist/queue.d.ts +114 -0
- package/dist/queue.d.ts.map +1 -0
- package/dist/queue.js +385 -0
- package/dist/queue.js.map +1 -0
- package/dist/rollback.d.ts +117 -0
- package/dist/rollback.d.ts.map +1 -0
- package/dist/rollback.js +374 -0
- package/dist/rollback.js.map +1 -0
- package/dist/routing.d.ts +144 -0
- package/dist/routing.d.ts.map +1 -0
- package/dist/routing.js +457 -0
- package/dist/routing.js.map +1 -0
- package/dist/scheduler.d.ts +91 -0
- package/dist/scheduler.d.ts.map +1 -0
- package/dist/scheduler.js +259 -0
- package/dist/scheduler.js.map +1 -0
- package/dist/script-tool.d.ts +22 -0
- package/dist/script-tool.d.ts.map +1 -0
- package/dist/script-tool.js +90 -0
- package/dist/script-tool.js.map +1 -0
- package/dist/sdk-registry.d.ts +81 -0
- package/dist/sdk-registry.d.ts.map +1 -0
- package/dist/sdk-registry.js +264 -0
- package/dist/sdk-registry.js.map +1 -0
- package/dist/security.d.ts +155 -0
- package/dist/security.d.ts.map +1 -0
- package/dist/security.js +362 -0
- package/dist/security.js.map +1 -0
- package/dist/state.d.ts +67 -0
- package/dist/state.d.ts.map +1 -0
- package/dist/state.js +276 -0
- package/dist/state.js.map +1 -0
- package/dist/templates.d.ts +70 -0
- package/dist/templates.d.ts.map +1 -0
- package/dist/templates.js +244 -0
- package/dist/templates.js.map +1 -0
- package/dist/tool-base.d.ts +54 -0
- package/dist/tool-base.d.ts.map +1 -0
- package/dist/tool-base.js +43 -0
- package/dist/tool-base.js.map +1 -0
- package/dist/tool-registry.d.ts +24 -0
- package/dist/tool-registry.d.ts.map +1 -0
- package/dist/tool-registry.js +164 -0
- package/dist/tool-registry.js.map +1 -0
- package/dist/tools/custom-tool.d.ts +16 -0
- package/dist/tools/custom-tool.d.ts.map +1 -0
- package/dist/tools/custom-tool.js +85 -0
- package/dist/tools/custom-tool.js.map +1 -0
- package/dist/tools/mcp-tool.d.ts +16 -0
- package/dist/tools/mcp-tool.d.ts.map +1 -0
- package/dist/tools/mcp-tool.js +98 -0
- package/dist/tools/mcp-tool.js.map +1 -0
- package/dist/tools/openapi-tool.d.ts +17 -0
- package/dist/tools/openapi-tool.d.ts.map +1 -0
- package/dist/tools/openapi-tool.js +165 -0
- package/dist/tools/openapi-tool.js.map +1 -0
- package/dist/trigger-manager.d.ts +26 -0
- package/dist/trigger-manager.d.ts.map +1 -0
- package/dist/trigger-manager.js +107 -0
- package/dist/trigger-manager.js.map +1 -0
- package/dist/webhook.d.ts +95 -0
- package/dist/webhook.d.ts.map +1 -0
- package/dist/webhook.js +261 -0
- package/dist/webhook.js.map +1 -0
- package/package.json +60 -0
package/dist/queue.d.ts
ADDED
|
@@ -0,0 +1,114 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Message Queue Integration for marktoflow v2.0
|
|
3
|
+
*
|
|
4
|
+
* Supports Redis and RabbitMQ for distributed workflow execution.
|
|
5
|
+
*/
|
|
6
|
+
import { EventEmitter } from 'node:events';
|
|
7
|
+
export declare enum MessagePriority {
|
|
8
|
+
LOW = 0,
|
|
9
|
+
NORMAL = 1,
|
|
10
|
+
HIGH = 2,
|
|
11
|
+
CRITICAL = 3
|
|
12
|
+
}
|
|
13
|
+
export declare enum MessageStatus {
|
|
14
|
+
PENDING = "pending",
|
|
15
|
+
PROCESSING = "processing",
|
|
16
|
+
COMPLETED = "completed",
|
|
17
|
+
FAILED = "failed",
|
|
18
|
+
DEAD_LETTER = "dead_letter"
|
|
19
|
+
}
|
|
20
|
+
export interface QueueMessage {
|
|
21
|
+
id: string;
|
|
22
|
+
workflowId: string;
|
|
23
|
+
payload: Record<string, unknown>;
|
|
24
|
+
priority: MessagePriority;
|
|
25
|
+
status: MessageStatus;
|
|
26
|
+
createdAt: Date;
|
|
27
|
+
processedAt?: Date;
|
|
28
|
+
attempts: number;
|
|
29
|
+
maxAttempts: number;
|
|
30
|
+
error?: string;
|
|
31
|
+
metadata: Record<string, unknown>;
|
|
32
|
+
}
|
|
33
|
+
export interface QueueConfig {
|
|
34
|
+
name: string;
|
|
35
|
+
maxSize?: number;
|
|
36
|
+
messageTtl?: number;
|
|
37
|
+
deadLetterQueue?: string;
|
|
38
|
+
retryDelay?: number;
|
|
39
|
+
visibilityTimeout?: number;
|
|
40
|
+
}
|
|
41
|
+
export type MessageHandler = (message: QueueMessage) => Promise<void>;
|
|
42
|
+
export declare abstract class MessageQueue extends EventEmitter {
|
|
43
|
+
abstract connect(): Promise<void>;
|
|
44
|
+
abstract disconnect(): Promise<void>;
|
|
45
|
+
abstract publish(message: QueueMessage, queueName?: string): Promise<string>;
|
|
46
|
+
abstract consume(handler: MessageHandler, queueName?: string, batchSize?: number): Promise<void>;
|
|
47
|
+
abstract acknowledge(messageId: string): Promise<void>;
|
|
48
|
+
abstract reject(messageId: string, requeue?: boolean): Promise<void>;
|
|
49
|
+
abstract getQueueLength(queueName?: string): Promise<number>;
|
|
50
|
+
abstract purge(queueName?: string): Promise<number>;
|
|
51
|
+
abstract stop(): Promise<void>;
|
|
52
|
+
}
|
|
53
|
+
export declare class InMemoryQueue extends MessageQueue {
|
|
54
|
+
private queues;
|
|
55
|
+
private processing;
|
|
56
|
+
private deadLetter;
|
|
57
|
+
private running;
|
|
58
|
+
private config;
|
|
59
|
+
constructor(config?: QueueConfig);
|
|
60
|
+
connect(): Promise<void>;
|
|
61
|
+
disconnect(): Promise<void>;
|
|
62
|
+
private getQueue;
|
|
63
|
+
publish(message: QueueMessage, queueName?: string): Promise<string>;
|
|
64
|
+
consume(handler: MessageHandler, queueName?: string, batchSize?: number): Promise<void>;
|
|
65
|
+
acknowledge(messageId: string): Promise<void>;
|
|
66
|
+
reject(messageId: string, requeue?: boolean): Promise<void>;
|
|
67
|
+
getQueueLength(queueName?: string): Promise<number>;
|
|
68
|
+
purge(queueName?: string): Promise<number>;
|
|
69
|
+
stop(): Promise<void>;
|
|
70
|
+
}
|
|
71
|
+
export declare class RedisQueue extends MessageQueue {
|
|
72
|
+
private client;
|
|
73
|
+
private config;
|
|
74
|
+
private running;
|
|
75
|
+
private redisUrl;
|
|
76
|
+
constructor(redisUrl: string, config?: QueueConfig);
|
|
77
|
+
connect(): Promise<void>;
|
|
78
|
+
disconnect(): Promise<void>;
|
|
79
|
+
private queueKey;
|
|
80
|
+
private processingKey;
|
|
81
|
+
publish(message: QueueMessage, queueName?: string): Promise<string>;
|
|
82
|
+
consume(handler: MessageHandler, queueName?: string, batchSize?: number): Promise<void>;
|
|
83
|
+
acknowledge(messageId: string): Promise<void>;
|
|
84
|
+
reject(messageId: string, requeue?: boolean): Promise<void>;
|
|
85
|
+
getQueueLength(queueName?: string): Promise<number>;
|
|
86
|
+
purge(queueName?: string): Promise<number>;
|
|
87
|
+
stop(): Promise<void>;
|
|
88
|
+
}
|
|
89
|
+
export declare class RabbitMQQueue extends MessageQueue {
|
|
90
|
+
private connection;
|
|
91
|
+
private channel;
|
|
92
|
+
private config;
|
|
93
|
+
private amqpUrl;
|
|
94
|
+
private consumerTag;
|
|
95
|
+
constructor(amqpUrl: string, config?: QueueConfig);
|
|
96
|
+
connect(): Promise<void>;
|
|
97
|
+
disconnect(): Promise<void>;
|
|
98
|
+
publish(message: QueueMessage, queueName?: string): Promise<string>;
|
|
99
|
+
consume(handler: MessageHandler, queueName?: string, batchSize?: number): Promise<void>;
|
|
100
|
+
acknowledge(_messageId: string): Promise<void>;
|
|
101
|
+
reject(_messageId: string, _requeue?: boolean): Promise<void>;
|
|
102
|
+
getQueueLength(queueName?: string): Promise<number>;
|
|
103
|
+
purge(queueName?: string): Promise<number>;
|
|
104
|
+
stop(): Promise<void>;
|
|
105
|
+
}
|
|
106
|
+
export declare class WorkflowQueueManager {
|
|
107
|
+
private queue;
|
|
108
|
+
private workflowCallback?;
|
|
109
|
+
constructor(queue: MessageQueue, workflowCallback?: ((workflowId: string, inputs: Record<string, unknown>) => Promise<any>) | undefined);
|
|
110
|
+
enqueueWorkflow(workflowId: string, inputs?: Record<string, unknown>, priority?: MessagePriority, metadata?: Record<string, unknown>): Promise<string>;
|
|
111
|
+
startWorker(numWorkers?: number): Promise<void>;
|
|
112
|
+
stopWorker(): Promise<void>;
|
|
113
|
+
}
|
|
114
|
+
//# sourceMappingURL=queue.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"queue.d.ts","sourceRoot":"","sources":["../src/queue.ts"],"names":[],"mappings":"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"}
|
package/dist/queue.js
ADDED
|
@@ -0,0 +1,385 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Message Queue Integration for marktoflow v2.0
|
|
3
|
+
*
|
|
4
|
+
* Supports Redis and RabbitMQ for distributed workflow execution.
|
|
5
|
+
*/
|
|
6
|
+
import { EventEmitter } from 'node:events';
|
|
7
|
+
import { Redis } from 'ioredis';
|
|
8
|
+
import * as amqp from 'amqplib';
|
|
9
|
+
import { randomUUID } from 'node:crypto';
|
|
10
|
+
// ============================================================================
|
|
11
|
+
// Types
|
|
12
|
+
// ============================================================================
|
|
13
|
+
export var MessagePriority;
|
|
14
|
+
(function (MessagePriority) {
|
|
15
|
+
MessagePriority[MessagePriority["LOW"] = 0] = "LOW";
|
|
16
|
+
MessagePriority[MessagePriority["NORMAL"] = 1] = "NORMAL";
|
|
17
|
+
MessagePriority[MessagePriority["HIGH"] = 2] = "HIGH";
|
|
18
|
+
MessagePriority[MessagePriority["CRITICAL"] = 3] = "CRITICAL";
|
|
19
|
+
})(MessagePriority || (MessagePriority = {}));
|
|
20
|
+
export var MessageStatus;
|
|
21
|
+
(function (MessageStatus) {
|
|
22
|
+
MessageStatus["PENDING"] = "pending";
|
|
23
|
+
MessageStatus["PROCESSING"] = "processing";
|
|
24
|
+
MessageStatus["COMPLETED"] = "completed";
|
|
25
|
+
MessageStatus["FAILED"] = "failed";
|
|
26
|
+
MessageStatus["DEAD_LETTER"] = "dead_letter";
|
|
27
|
+
})(MessageStatus || (MessageStatus = {}));
|
|
28
|
+
// ============================================================================
|
|
29
|
+
// Abstract Message Queue
|
|
30
|
+
// ============================================================================
|
|
31
|
+
export class MessageQueue extends EventEmitter {
|
|
32
|
+
}
|
|
33
|
+
// ============================================================================
|
|
34
|
+
// InMemory Queue
|
|
35
|
+
// ============================================================================
|
|
36
|
+
export class InMemoryQueue extends MessageQueue {
|
|
37
|
+
queues = new Map();
|
|
38
|
+
processing = new Map();
|
|
39
|
+
deadLetter = new Map();
|
|
40
|
+
running = false;
|
|
41
|
+
config;
|
|
42
|
+
constructor(config = { name: 'marktoflow' }) {
|
|
43
|
+
super();
|
|
44
|
+
this.config = config;
|
|
45
|
+
}
|
|
46
|
+
async connect() { }
|
|
47
|
+
async disconnect() { this.running = false; }
|
|
48
|
+
getQueue(name) {
|
|
49
|
+
const queueName = name || this.config.name;
|
|
50
|
+
if (!this.queues.has(queueName)) {
|
|
51
|
+
this.queues.set(queueName, []);
|
|
52
|
+
}
|
|
53
|
+
return this.queues.get(queueName);
|
|
54
|
+
}
|
|
55
|
+
async publish(message, queueName) {
|
|
56
|
+
const queue = this.getQueue(queueName);
|
|
57
|
+
// Simple priority insertion
|
|
58
|
+
let inserted = false;
|
|
59
|
+
for (let i = 0; i < queue.length; i++) {
|
|
60
|
+
if (message.priority > queue[i].priority) {
|
|
61
|
+
queue.splice(i, 0, message);
|
|
62
|
+
inserted = true;
|
|
63
|
+
break;
|
|
64
|
+
}
|
|
65
|
+
}
|
|
66
|
+
if (!inserted) {
|
|
67
|
+
queue.push(message);
|
|
68
|
+
}
|
|
69
|
+
return message.id;
|
|
70
|
+
}
|
|
71
|
+
async consume(handler, queueName, batchSize = 1) {
|
|
72
|
+
this.running = true;
|
|
73
|
+
const queue = this.getQueue(queueName);
|
|
74
|
+
while (this.running) {
|
|
75
|
+
if (queue.length === 0) {
|
|
76
|
+
await new Promise(r => setTimeout(r, 100));
|
|
77
|
+
continue;
|
|
78
|
+
}
|
|
79
|
+
const batch = queue.splice(0, batchSize);
|
|
80
|
+
for (const message of batch) {
|
|
81
|
+
message.attempts++;
|
|
82
|
+
message.status = MessageStatus.PROCESSING;
|
|
83
|
+
this.processing.set(message.id, message);
|
|
84
|
+
try {
|
|
85
|
+
await handler(message);
|
|
86
|
+
await this.acknowledge(message.id);
|
|
87
|
+
}
|
|
88
|
+
catch (error) {
|
|
89
|
+
message.error = String(error);
|
|
90
|
+
await this.reject(message.id, message.attempts < message.maxAttempts);
|
|
91
|
+
}
|
|
92
|
+
}
|
|
93
|
+
}
|
|
94
|
+
}
|
|
95
|
+
async acknowledge(messageId) {
|
|
96
|
+
const message = this.processing.get(messageId);
|
|
97
|
+
if (message) {
|
|
98
|
+
message.status = MessageStatus.COMPLETED;
|
|
99
|
+
message.processedAt = new Date();
|
|
100
|
+
this.processing.delete(messageId);
|
|
101
|
+
}
|
|
102
|
+
}
|
|
103
|
+
async reject(messageId, requeue = true) {
|
|
104
|
+
const message = this.processing.get(messageId);
|
|
105
|
+
if (!message)
|
|
106
|
+
return;
|
|
107
|
+
this.processing.delete(messageId);
|
|
108
|
+
if (requeue) {
|
|
109
|
+
message.status = MessageStatus.PENDING;
|
|
110
|
+
await this.publish(message); // Re-insert with priority
|
|
111
|
+
}
|
|
112
|
+
else if (this.config.deadLetterQueue) {
|
|
113
|
+
message.status = MessageStatus.DEAD_LETTER;
|
|
114
|
+
if (!this.deadLetter.has(this.config.deadLetterQueue)) {
|
|
115
|
+
this.deadLetter.set(this.config.deadLetterQueue, []);
|
|
116
|
+
}
|
|
117
|
+
this.deadLetter.get(this.config.deadLetterQueue).push(message);
|
|
118
|
+
}
|
|
119
|
+
else {
|
|
120
|
+
message.status = MessageStatus.FAILED;
|
|
121
|
+
}
|
|
122
|
+
}
|
|
123
|
+
async getQueueLength(queueName) {
|
|
124
|
+
return this.getQueue(queueName).length;
|
|
125
|
+
}
|
|
126
|
+
async purge(queueName) {
|
|
127
|
+
const queue = this.getQueue(queueName);
|
|
128
|
+
const length = queue.length;
|
|
129
|
+
queue.length = 0;
|
|
130
|
+
return length;
|
|
131
|
+
}
|
|
132
|
+
async stop() {
|
|
133
|
+
this.running = false;
|
|
134
|
+
}
|
|
135
|
+
}
|
|
136
|
+
// ============================================================================
|
|
137
|
+
// Redis Queue
|
|
138
|
+
// ============================================================================
|
|
139
|
+
export class RedisQueue extends MessageQueue {
|
|
140
|
+
client = null;
|
|
141
|
+
config;
|
|
142
|
+
running = false;
|
|
143
|
+
redisUrl;
|
|
144
|
+
constructor(redisUrl, config = { name: 'marktoflow' }) {
|
|
145
|
+
super();
|
|
146
|
+
this.redisUrl = redisUrl;
|
|
147
|
+
this.config = config;
|
|
148
|
+
}
|
|
149
|
+
async connect() {
|
|
150
|
+
this.client = new Redis(this.redisUrl);
|
|
151
|
+
}
|
|
152
|
+
async disconnect() {
|
|
153
|
+
this.running = false;
|
|
154
|
+
if (this.client) {
|
|
155
|
+
await this.client.quit();
|
|
156
|
+
this.client = null;
|
|
157
|
+
}
|
|
158
|
+
}
|
|
159
|
+
queueKey(name) {
|
|
160
|
+
return `marktoflow:queue:${name || this.config.name}`;
|
|
161
|
+
}
|
|
162
|
+
processingKey(name) {
|
|
163
|
+
return `marktoflow:processing:${name || this.config.name}`;
|
|
164
|
+
}
|
|
165
|
+
async publish(message, queueName) {
|
|
166
|
+
if (!this.client)
|
|
167
|
+
throw new Error("Redis not connected");
|
|
168
|
+
const key = this.queueKey(queueName);
|
|
169
|
+
await this.client.zadd(key, -message.priority, JSON.stringify(message));
|
|
170
|
+
return message.id;
|
|
171
|
+
}
|
|
172
|
+
async consume(handler, queueName, batchSize = 1) {
|
|
173
|
+
if (!this.client)
|
|
174
|
+
throw new Error("Redis not connected");
|
|
175
|
+
this.running = true;
|
|
176
|
+
const key = this.queueKey(queueName);
|
|
177
|
+
const procKey = this.processingKey(queueName);
|
|
178
|
+
while (this.running) {
|
|
179
|
+
const results = await this.client.zpopmin(key, batchSize);
|
|
180
|
+
if (results.length === 0) {
|
|
181
|
+
await new Promise(r => setTimeout(r, 100));
|
|
182
|
+
continue;
|
|
183
|
+
}
|
|
184
|
+
for (let i = 0; i < results.length; i += 2) {
|
|
185
|
+
const msgJson = results[i];
|
|
186
|
+
const message = JSON.parse(msgJson);
|
|
187
|
+
message.attempts++;
|
|
188
|
+
message.status = MessageStatus.PROCESSING;
|
|
189
|
+
await this.client.hset(procKey, message.id, JSON.stringify(message));
|
|
190
|
+
try {
|
|
191
|
+
await handler(message);
|
|
192
|
+
await this.acknowledge(message.id);
|
|
193
|
+
}
|
|
194
|
+
catch (error) {
|
|
195
|
+
message.error = String(error);
|
|
196
|
+
await this.reject(message.id, message.attempts < message.maxAttempts);
|
|
197
|
+
}
|
|
198
|
+
}
|
|
199
|
+
}
|
|
200
|
+
}
|
|
201
|
+
async acknowledge(messageId) {
|
|
202
|
+
if (!this.client)
|
|
203
|
+
throw new Error("Redis not connected");
|
|
204
|
+
const procKey = this.processingKey();
|
|
205
|
+
await this.client.hdel(procKey, messageId);
|
|
206
|
+
}
|
|
207
|
+
async reject(messageId, requeue = true) {
|
|
208
|
+
if (!this.client)
|
|
209
|
+
throw new Error("Redis not connected");
|
|
210
|
+
const procKey = this.processingKey();
|
|
211
|
+
const msgJson = await this.client.hget(procKey, messageId);
|
|
212
|
+
if (msgJson) {
|
|
213
|
+
await this.client.hdel(procKey, messageId);
|
|
214
|
+
const message = JSON.parse(msgJson);
|
|
215
|
+
if (requeue) {
|
|
216
|
+
message.status = MessageStatus.PENDING;
|
|
217
|
+
await new Promise(r => setTimeout(r, (this.config.retryDelay || 5) * 1000));
|
|
218
|
+
await this.publish(message);
|
|
219
|
+
}
|
|
220
|
+
else if (this.config.deadLetterQueue) {
|
|
221
|
+
message.status = MessageStatus.DEAD_LETTER;
|
|
222
|
+
await this.publish(message, this.config.deadLetterQueue);
|
|
223
|
+
}
|
|
224
|
+
}
|
|
225
|
+
}
|
|
226
|
+
async getQueueLength(queueName) {
|
|
227
|
+
if (!this.client)
|
|
228
|
+
throw new Error("Redis not connected");
|
|
229
|
+
return this.client.zcard(this.queueKey(queueName));
|
|
230
|
+
}
|
|
231
|
+
async purge(queueName) {
|
|
232
|
+
if (!this.client)
|
|
233
|
+
throw new Error("Redis not connected");
|
|
234
|
+
const key = this.queueKey(queueName);
|
|
235
|
+
const count = await this.client.zcard(key);
|
|
236
|
+
await this.client.del(key);
|
|
237
|
+
return count;
|
|
238
|
+
}
|
|
239
|
+
async stop() {
|
|
240
|
+
this.running = false;
|
|
241
|
+
}
|
|
242
|
+
}
|
|
243
|
+
// ============================================================================
|
|
244
|
+
// RabbitMQ Queue
|
|
245
|
+
// ============================================================================
|
|
246
|
+
export class RabbitMQQueue extends MessageQueue {
|
|
247
|
+
connection = null;
|
|
248
|
+
channel = null;
|
|
249
|
+
config;
|
|
250
|
+
amqpUrl;
|
|
251
|
+
consumerTag = null;
|
|
252
|
+
constructor(amqpUrl, config = { name: 'marktoflow' }) {
|
|
253
|
+
super();
|
|
254
|
+
this.amqpUrl = amqpUrl;
|
|
255
|
+
this.config = config;
|
|
256
|
+
}
|
|
257
|
+
async connect() {
|
|
258
|
+
this.connection = await amqp.connect(this.amqpUrl);
|
|
259
|
+
this.channel = await this.connection.createChannel();
|
|
260
|
+
const args = {};
|
|
261
|
+
if (this.config.messageTtl)
|
|
262
|
+
args['x-message-ttl'] = this.config.messageTtl * 1000;
|
|
263
|
+
if (this.config.maxSize)
|
|
264
|
+
args['x-max-length'] = this.config.maxSize;
|
|
265
|
+
if (this.config.deadLetterQueue) {
|
|
266
|
+
args['x-dead-letter-exchange'] = '';
|
|
267
|
+
args['x-dead-letter-routing-key'] = this.config.deadLetterQueue;
|
|
268
|
+
await this.channel.assertQueue(this.config.deadLetterQueue, { durable: true });
|
|
269
|
+
}
|
|
270
|
+
await this.channel.assertQueue(this.config.name, {
|
|
271
|
+
durable: true,
|
|
272
|
+
arguments: args
|
|
273
|
+
});
|
|
274
|
+
}
|
|
275
|
+
async disconnect() {
|
|
276
|
+
if (this.channel)
|
|
277
|
+
await this.channel.close();
|
|
278
|
+
if (this.connection)
|
|
279
|
+
await this.connection.close();
|
|
280
|
+
this.channel = null;
|
|
281
|
+
this.connection = null;
|
|
282
|
+
}
|
|
283
|
+
async publish(message, queueName) {
|
|
284
|
+
if (!this.channel)
|
|
285
|
+
throw new Error("RabbitMQ not connected");
|
|
286
|
+
const queue = queueName || this.config.name;
|
|
287
|
+
this.channel.sendToQueue(queue, Buffer.from(JSON.stringify(message)), {
|
|
288
|
+
persistent: true,
|
|
289
|
+
priority: message.priority,
|
|
290
|
+
messageId: message.id,
|
|
291
|
+
timestamp: message.createdAt.getTime(),
|
|
292
|
+
});
|
|
293
|
+
return message.id;
|
|
294
|
+
}
|
|
295
|
+
async consume(handler, queueName, batchSize = 1) {
|
|
296
|
+
if (!this.channel)
|
|
297
|
+
throw new Error("RabbitMQ not connected");
|
|
298
|
+
const queue = queueName || this.config.name;
|
|
299
|
+
await this.channel.prefetch(batchSize);
|
|
300
|
+
const { consumerTag } = await this.channel.consume(queue, async (msg) => {
|
|
301
|
+
if (!msg)
|
|
302
|
+
return;
|
|
303
|
+
const message = JSON.parse(msg.content.toString());
|
|
304
|
+
message.attempts++;
|
|
305
|
+
try {
|
|
306
|
+
await handler(message);
|
|
307
|
+
this.channel?.ack(msg);
|
|
308
|
+
}
|
|
309
|
+
catch (error) {
|
|
310
|
+
message.error = String(error);
|
|
311
|
+
if (message.attempts < message.maxAttempts) {
|
|
312
|
+
this.channel?.nack(msg, false, true);
|
|
313
|
+
}
|
|
314
|
+
else {
|
|
315
|
+
this.channel?.nack(msg, false, false);
|
|
316
|
+
}
|
|
317
|
+
}
|
|
318
|
+
});
|
|
319
|
+
this.consumerTag = consumerTag;
|
|
320
|
+
}
|
|
321
|
+
async acknowledge(_messageId) {
|
|
322
|
+
// Handled in consume
|
|
323
|
+
}
|
|
324
|
+
async reject(_messageId, _requeue = true) {
|
|
325
|
+
// Handled in consume
|
|
326
|
+
}
|
|
327
|
+
async getQueueLength(queueName) {
|
|
328
|
+
if (!this.channel)
|
|
329
|
+
throw new Error("RabbitMQ not connected");
|
|
330
|
+
const q = await this.channel.assertQueue(queueName || this.config.name, { durable: true });
|
|
331
|
+
return q.messageCount;
|
|
332
|
+
}
|
|
333
|
+
async purge(queueName) {
|
|
334
|
+
if (!this.channel)
|
|
335
|
+
throw new Error("RabbitMQ not connected");
|
|
336
|
+
const q = await this.channel.purgeQueue(queueName || this.config.name);
|
|
337
|
+
return q.messageCount;
|
|
338
|
+
}
|
|
339
|
+
async stop() {
|
|
340
|
+
if (this.channel && this.consumerTag) {
|
|
341
|
+
await this.channel.cancel(this.consumerTag);
|
|
342
|
+
this.consumerTag = null;
|
|
343
|
+
}
|
|
344
|
+
}
|
|
345
|
+
}
|
|
346
|
+
// ============================================================================
|
|
347
|
+
// Workflow Queue Manager
|
|
348
|
+
// ============================================================================
|
|
349
|
+
export class WorkflowQueueManager {
|
|
350
|
+
queue;
|
|
351
|
+
workflowCallback;
|
|
352
|
+
constructor(queue, workflowCallback) {
|
|
353
|
+
this.queue = queue;
|
|
354
|
+
this.workflowCallback = workflowCallback;
|
|
355
|
+
}
|
|
356
|
+
async enqueueWorkflow(workflowId, inputs = {}, priority = MessagePriority.NORMAL, metadata = {}) {
|
|
357
|
+
const message = {
|
|
358
|
+
id: randomUUID(),
|
|
359
|
+
workflowId,
|
|
360
|
+
payload: inputs,
|
|
361
|
+
priority,
|
|
362
|
+
status: MessageStatus.PENDING,
|
|
363
|
+
createdAt: new Date(),
|
|
364
|
+
attempts: 0,
|
|
365
|
+
maxAttempts: 3,
|
|
366
|
+
metadata,
|
|
367
|
+
};
|
|
368
|
+
return this.queue.publish(message);
|
|
369
|
+
}
|
|
370
|
+
async startWorker(numWorkers = 1) {
|
|
371
|
+
if (!this.workflowCallback) {
|
|
372
|
+
throw new Error("No workflow callback configured");
|
|
373
|
+
}
|
|
374
|
+
const handler = async (message) => {
|
|
375
|
+
if (this.workflowCallback) {
|
|
376
|
+
await this.workflowCallback(message.workflowId, message.payload);
|
|
377
|
+
}
|
|
378
|
+
};
|
|
379
|
+
await this.queue.consume(handler, undefined, numWorkers);
|
|
380
|
+
}
|
|
381
|
+
async stopWorker() {
|
|
382
|
+
await this.queue.stop();
|
|
383
|
+
}
|
|
384
|
+
}
|
|
385
|
+
//# sourceMappingURL=queue.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"queue.js","sourceRoot":"","sources":["../src/queue.ts"],"names":[],"mappings":"AAAA;;;;GAIG;AAEH,OAAO,EAAE,YAAY,EAAE,MAAM,aAAa,CAAC;AAC3C,OAAO,EAAE,KAAK,EAAE,MAAM,SAAS,CAAC;AAChC,OAAO,KAAK,IAAI,MAAM,SAAS,CAAC;AAChC,OAAO,EAAE,UAAU,EAAE,MAAM,aAAa,CAAC;AAEzC,+EAA+E;AAC/E,QAAQ;AACR,+EAA+E;AAE/E,MAAM,CAAN,IAAY,eAKX;AALD,WAAY,eAAe;IACzB,mDAAO,CAAA;IACP,yDAAU,CAAA;IACV,qDAAQ,CAAA;IACR,6DAAY,CAAA;AACd,CAAC,EALW,eAAe,KAAf,eAAe,QAK1B;AAED,MAAM,CAAN,IAAY,aAMX;AAND,WAAY,aAAa;IACvB,oCAAmB,CAAA;IACnB,0CAAyB,CAAA;IACzB,wCAAuB,CAAA;IACvB,kCAAiB,CAAA;IACjB,4CAA2B,CAAA;AAC7B,CAAC,EANW,aAAa,KAAb,aAAa,QAMxB;AA2BD,+EAA+E;AAC/E,yBAAyB;AACzB,+EAA+E;AAE/E,MAAM,OAAgB,YAAa,SAAQ,YAAY;CAUtD;AAED,+EAA+E;AAC/E,iBAAiB;AACjB,+EAA+E;AAE/E,MAAM,OAAO,aAAc,SAAQ,YAAY;IACrC,MAAM,GAAgC,IAAI,GAAG,EAAE,CAAC;IAChD,UAAU,GAA8B,IAAI,GAAG,EAAE,CAAC;IAClD,UAAU,GAAgC,IAAI,GAAG,EAAE,CAAC;IACpD,OAAO,GAAG,KAAK,CAAC;IAChB,MAAM,CAAc;IAE5B,YAAY,SAAsB,EAAE,IAAI,EAAE,YAAY,EAAE;QACtD,KAAK,EAAE,CAAC;QACR,IAAI,CAAC,MAAM,GAAG,MAAM,CAAC;IACvB,CAAC;IAED,KAAK,CAAC,OAAO,KAAmB,CAAC;IACjC,KAAK,CAAC,UAAU,KAAoB,IAAI,CAAC,OAAO,GAAG,KAAK,CAAC,CAAC,CAAC;IAEnD,QAAQ,CAAC,IAAa;QAC5B,MAAM,SAAS,GAAG,IAAI,IAAI,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC;QAC3C,IAAI,CAAC,IAAI,CAAC,MAAM,CAAC,GAAG,CAAC,SAAS,CAAC,EAAE,CAAC;YAChC,IAAI,CAAC,MAAM,CAAC,GAAG,CAAC,SAAS,EAAE,EAAE,CAAC,CAAC;QACjC,CAAC;QACD,OAAO,IAAI,CAAC,MAAM,CAAC,GAAG,CAAC,SAAS,CAAE,CAAC;IACrC,CAAC;IAED,KAAK,CAAC,OAAO,CAAC,OAAqB,EAAE,SAAkB;QACrD,MAAM,KAAK,GAAG,IAAI,CAAC,QAAQ,CAAC,SAAS,CAAC,CAAC;QAEvC,4BAA4B;QAC5B,IAAI,QAAQ,GAAG,KAAK,CAAC;QACrB,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,KAAK,CAAC,MAAM,EAAE,CAAC,EAAE,EAAE,CAAC;YACtC,IAAI,OAAO,CAAC,QAAQ,GAAG,KAAK,CAAC,CAAC,CAAC,CAAC,QAAQ,EAAE,CAAC;gBACzC,KAAK,CAAC,MAAM,CAAC,CAAC,EAAE,CAAC,EAAE,OAAO,CAAC,CAAC;gBAC5B,QAAQ,GAAG,IAAI,CAAC;gBAChB,MAAM;YACR,CAAC;QACH,CAAC;QACD,IAAI,CAAC,QAAQ,EAAE,CAAC;YACd,KAAK,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC;QACtB,CAAC;QAED,OAAO,OAAO,CAAC,EAAE,CAAC;IACpB,CAAC;IAED,KAAK,CAAC,OAAO,CAAC,OAAuB,EAAE,SAAkB,EAAE,SAAS,GAAG,CAAC;QACtE,IAAI,CAAC,OAAO,GAAG,IAAI,CAAC;QACpB,MAAM,KAAK,GAAG,IAAI,CAAC,QAAQ,CAAC,SAAS,CAAC,CAAC;QAEvC,OAAO,IAAI,CAAC,OAAO,EAAE,CAAC;YACpB,IAAI,KAAK,CAAC,MAAM,KAAK,CAAC,EAAE,CAAC;gBACvB,MAAM,IAAI,OAAO,CAAC,CAAC,CAAC,EAAE,CAAC,UAAU,CAAC,CAAC,EAAE,GAAG,CAAC,CAAC,CAAC;gBAC3C,SAAS;YACX,CAAC;YAED,MAAM,KAAK,GAAG,KAAK,CAAC,MAAM,CAAC,CAAC,EAAE,SAAS,CAAC,CAAC;YAEzC,KAAK,MAAM,OAAO,IAAI,KAAK,EAAE,CAAC;gBAC5B,OAAO,CAAC,QAAQ,EAAE,CAAC;gBACnB,OAAO,CAAC,MAAM,GAAG,aAAa,CAAC,UAAU,CAAC;gBAC1C,IAAI,CAAC,UAAU,CAAC,GAAG,CAAC,OAAO,CAAC,EAAE,EAAE,OAAO,CAAC,CAAC;gBAEzC,IAAI,CAAC;oBACH,MAAM,OAAO,CAAC,OAAO,CAAC,CAAC;oBACvB,MAAM,IAAI,CAAC,WAAW,CAAC,OAAO,CAAC,EAAE,CAAC,CAAC;gBACrC,CAAC;gBAAC,OAAO,KAAK,EAAE,CAAC;oBACf,OAAO,CAAC,KAAK,GAAG,MAAM,CAAC,KAAK,CAAC,CAAC;oBAC9B,MAAM,IAAI,CAAC,MAAM,CAAC,OAAO,CAAC,EAAE,EAAE,OAAO,CAAC,QAAQ,GAAG,OAAO,CAAC,WAAW,CAAC,CAAC;gBACxE,CAAC;YACH,CAAC;QACH,CAAC;IACH,CAAC;IAED,KAAK,CAAC,WAAW,CAAC,SAAiB;QACjC,MAAM,OAAO,GAAG,IAAI,CAAC,UAAU,CAAC,GAAG,CAAC,SAAS,CAAC,CAAC;QAC/C,IAAI,OAAO,EAAE,CAAC;YACZ,OAAO,CAAC,MAAM,GAAG,aAAa,CAAC,SAAS,CAAC;YACzC,OAAO,CAAC,WAAW,GAAG,IAAI,IAAI,EAAE,CAAC;YACjC,IAAI,CAAC,UAAU,CAAC,MAAM,CAAC,SAAS,CAAC,CAAC;QACpC,CAAC;IACH,CAAC;IAED,KAAK,CAAC,MAAM,CAAC,SAAiB,EAAE,OAAO,GAAG,IAAI;QAC5C,MAAM,OAAO,GAAG,IAAI,CAAC,UAAU,CAAC,GAAG,CAAC,SAAS,CAAC,CAAC;QAC/C,IAAI,CAAC,OAAO;YAAE,OAAO;QAErB,IAAI,CAAC,UAAU,CAAC,MAAM,CAAC,SAAS,CAAC,CAAC;QAElC,IAAI,OAAO,EAAE,CAAC;YACZ,OAAO,CAAC,MAAM,GAAG,aAAa,CAAC,OAAO,CAAC;YACvC,MAAM,IAAI,CAAC,OAAO,CAAC,OAAO,CAAC,CAAC,CAAC,0BAA0B;QACzD,CAAC;aAAM,IAAI,IAAI,CAAC,MAAM,CAAC,eAAe,EAAE,CAAC;YACvC,OAAO,CAAC,MAAM,GAAG,aAAa,CAAC,WAAW,CAAC;YAC3C,IAAI,CAAC,IAAI,CAAC,UAAU,CAAC,GAAG,CAAC,IAAI,CAAC,MAAM,CAAC,eAAe,CAAC,EAAE,CAAC;gBACtD,IAAI,CAAC,UAAU,CAAC,GAAG,CAAC,IAAI,CAAC,MAAM,CAAC,eAAe,EAAE,EAAE,CAAC,CAAC;YACvD,CAAC;YACD,IAAI,CAAC,UAAU,CAAC,GAAG,CAAC,IAAI,CAAC,MAAM,CAAC,eAAe,CAAE,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC;QAClE,CAAC;aAAM,CAAC;YACN,OAAO,CAAC,MAAM,GAAG,aAAa,CAAC,MAAM,CAAC;QACxC,CAAC;IACH,CAAC;IAED,KAAK,CAAC,cAAc,CAAC,SAAkB;QACrC,OAAO,IAAI,CAAC,QAAQ,CAAC,SAAS,CAAC,CAAC,MAAM,CAAC;IACzC,CAAC;IAED,KAAK,CAAC,KAAK,CAAC,SAAkB;QAC5B,MAAM,KAAK,GAAG,IAAI,CAAC,QAAQ,CAAC,SAAS,CAAC,CAAC;QACvC,MAAM,MAAM,GAAG,KAAK,CAAC,MAAM,CAAC;QAC5B,KAAK,CAAC,MAAM,GAAG,CAAC,CAAC;QACjB,OAAO,MAAM,CAAC;IAChB,CAAC;IAED,KAAK,CAAC,IAAI;QACR,IAAI,CAAC,OAAO,GAAG,KAAK,CAAC;IACvB,CAAC;CACF;AAED,+EAA+E;AAC/E,cAAc;AACd,+EAA+E;AAE/E,MAAM,OAAO,UAAW,SAAQ,YAAY;IAClC,MAAM,GAAiB,IAAI,CAAC;IAC5B,MAAM,CAAc;IACpB,OAAO,GAAG,KAAK,CAAC;IAChB,QAAQ,CAAS;IAEzB,YAAY,QAAgB,EAAE,SAAsB,EAAE,IAAI,EAAE,YAAY,EAAE;QACxE,KAAK,EAAE,CAAC;QACR,IAAI,CAAC,QAAQ,GAAG,QAAQ,CAAC;QACzB,IAAI,CAAC,MAAM,GAAG,MAAM,CAAC;IACvB,CAAC;IAED,KAAK,CAAC,OAAO;QACX,IAAI,CAAC,MAAM,GAAG,IAAI,KAAK,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC;IACzC,CAAC;IAED,KAAK,CAAC,UAAU;QACd,IAAI,CAAC,OAAO,GAAG,KAAK,CAAC;QACrB,IAAI,IAAI,CAAC,MAAM,EAAE,CAAC;YAChB,MAAM,IAAI,CAAC,MAAM,CAAC,IAAI,EAAE,CAAC;YACzB,IAAI,CAAC,MAAM,GAAG,IAAI,CAAC;QACrB,CAAC;IACH,CAAC;IAEO,QAAQ,CAAC,IAAa;QAC5B,OAAO,oBAAoB,IAAI,IAAI,IAAI,CAAC,MAAM,CAAC,IAAI,EAAE,CAAC;IACxD,CAAC;IAEO,aAAa,CAAC,IAAa;QACjC,OAAO,yBAAyB,IAAI,IAAI,IAAI,CAAC,MAAM,CAAC,IAAI,EAAE,CAAC;IAC7D,CAAC;IAED,KAAK,CAAC,OAAO,CAAC,OAAqB,EAAE,SAAkB;QACrD,IAAI,CAAC,IAAI,CAAC,MAAM;YAAE,MAAM,IAAI,KAAK,CAAC,qBAAqB,CAAC,CAAC;QAEzD,MAAM,GAAG,GAAG,IAAI,CAAC,QAAQ,CAAC,SAAS,CAAC,CAAC;QACrC,MAAM,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,GAAG,EAAE,CAAC,OAAO,CAAC,QAAQ,EAAE,IAAI,CAAC,SAAS,CAAC,OAAO,CAAC,CAAC,CAAC;QACxE,OAAO,OAAO,CAAC,EAAE,CAAC;IACpB,CAAC;IAED,KAAK,CAAC,OAAO,CAAC,OAAuB,EAAE,SAAkB,EAAE,SAAS,GAAG,CAAC;QACtE,IAAI,CAAC,IAAI,CAAC,MAAM;YAAE,MAAM,IAAI,KAAK,CAAC,qBAAqB,CAAC,CAAC;QACzD,IAAI,CAAC,OAAO,GAAG,IAAI,CAAC;QACpB,MAAM,GAAG,GAAG,IAAI,CAAC,QAAQ,CAAC,SAAS,CAAC,CAAC;QACrC,MAAM,OAAO,GAAG,IAAI,CAAC,aAAa,CAAC,SAAS,CAAC,CAAC;QAE9C,OAAO,IAAI,CAAC,OAAO,EAAE,CAAC;YACpB,MAAM,OAAO,GAAG,MAAM,IAAI,CAAC,MAAM,CAAC,OAAO,CAAC,GAAG,EAAE,SAAS,CAAC,CAAC;YAE1D,IAAI,OAAO,CAAC,MAAM,KAAK,CAAC,EAAE,CAAC;gBACzB,MAAM,IAAI,OAAO,CAAC,CAAC,CAAC,EAAE,CAAC,UAAU,CAAC,CAAC,EAAE,GAAG,CAAC,CAAC,CAAC;gBAC3C,SAAS;YACX,CAAC;YAED,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,OAAO,CAAC,MAAM,EAAE,CAAC,IAAI,CAAC,EAAE,CAAC;gBAC3C,MAAM,OAAO,GAAG,OAAO,CAAC,CAAC,CAAC,CAAC;gBAC3B,MAAM,OAAO,GAAiB,IAAI,CAAC,KAAK,CAAC,OAAO,CAAC,CAAC;gBAElD,OAAO,CAAC,QAAQ,EAAE,CAAC;gBACnB,OAAO,CAAC,MAAM,GAAG,aAAa,CAAC,UAAU,CAAC;gBAE1C,MAAM,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,OAAO,EAAE,OAAO,CAAC,EAAE,EAAE,IAAI,CAAC,SAAS,CAAC,OAAO,CAAC,CAAC,CAAC;gBAErE,IAAI,CAAC;oBACH,MAAM,OAAO,CAAC,OAAO,CAAC,CAAC;oBACvB,MAAM,IAAI,CAAC,WAAW,CAAC,OAAO,CAAC,EAAE,CAAC,CAAC;gBACrC,CAAC;gBAAC,OAAO,KAAK,EAAE,CAAC;oBACf,OAAO,CAAC,KAAK,GAAG,MAAM,CAAC,KAAK,CAAC,CAAC;oBAC9B,MAAM,IAAI,CAAC,MAAM,CAAC,OAAO,CAAC,EAAE,EAAE,OAAO,CAAC,QAAQ,GAAG,OAAO,CAAC,WAAW,CAAC,CAAC;gBACxE,CAAC;YACH,CAAC;QACH,CAAC;IACH,CAAC;IAED,KAAK,CAAC,WAAW,CAAC,SAAiB;QACjC,IAAI,CAAC,IAAI,CAAC,MAAM;YAAE,MAAM,IAAI,KAAK,CAAC,qBAAqB,CAAC,CAAC;QACzD,MAAM,OAAO,GAAG,IAAI,CAAC,aAAa,EAAE,CAAC;QACrC,MAAM,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,OAAO,EAAE,SAAS,CAAC,CAAC;IAC7C,CAAC;IAED,KAAK,CAAC,MAAM,CAAC,SAAiB,EAAE,OAAO,GAAG,IAAI;QAC5C,IAAI,CAAC,IAAI,CAAC,MAAM;YAAE,MAAM,IAAI,KAAK,CAAC,qBAAqB,CAAC,CAAC;QACzD,MAAM,OAAO,GAAG,IAAI,CAAC,aAAa,EAAE,CAAC;QACrC,MAAM,OAAO,GAAG,MAAM,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,OAAO,EAAE,SAAS,CAAC,CAAC;QAE3D,IAAI,OAAO,EAAE,CAAC;YACZ,MAAM,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,OAAO,EAAE,SAAS,CAAC,CAAC;YAC3C,MAAM,OAAO,GAAiB,IAAI,CAAC,KAAK,CAAC,OAAO,CAAC,CAAC;YAElD,IAAI,OAAO,EAAE,CAAC;gBACZ,OAAO,CAAC,MAAM,GAAG,aAAa,CAAC,OAAO,CAAC;gBACvC,MAAM,IAAI,OAAO,CAAC,CAAC,CAAC,EAAE,CAAC,UAAU,CAAC,CAAC,EAAE,CAAC,IAAI,CAAC,MAAM,CAAC,UAAU,IAAI,CAAC,CAAC,GAAG,IAAI,CAAC,CAAC,CAAC;gBAC5E,MAAM,IAAI,CAAC,OAAO,CAAC,OAAO,CAAC,CAAC;YAC9B,CAAC;iBAAM,IAAI,IAAI,CAAC,MAAM,CAAC,eAAe,EAAE,CAAC;gBACvC,OAAO,CAAC,MAAM,GAAG,aAAa,CAAC,WAAW,CAAC;gBAC3C,MAAM,IAAI,CAAC,OAAO,CAAC,OAAO,EAAE,IAAI,CAAC,MAAM,CAAC,eAAe,CAAC,CAAC;YAC3D,CAAC;QACH,CAAC;IACH,CAAC;IAED,KAAK,CAAC,cAAc,CAAC,SAAkB;QACrC,IAAI,CAAC,IAAI,CAAC,MAAM;YAAE,MAAM,IAAI,KAAK,CAAC,qBAAqB,CAAC,CAAC;QACzD,OAAO,IAAI,CAAC,MAAM,CAAC,KAAK,CAAC,IAAI,CAAC,QAAQ,CAAC,SAAS,CAAC,CAAC,CAAC;IACrD,CAAC;IAED,KAAK,CAAC,KAAK,CAAC,SAAkB;QAC5B,IAAI,CAAC,IAAI,CAAC,MAAM;YAAE,MAAM,IAAI,KAAK,CAAC,qBAAqB,CAAC,CAAC;QACzD,MAAM,GAAG,GAAG,IAAI,CAAC,QAAQ,CAAC,SAAS,CAAC,CAAC;QACrC,MAAM,KAAK,GAAG,MAAM,IAAI,CAAC,MAAM,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC;QAC3C,MAAM,IAAI,CAAC,MAAM,CAAC,GAAG,CAAC,GAAG,CAAC,CAAC;QAC3B,OAAO,KAAK,CAAC;IACf,CAAC;IAED,KAAK,CAAC,IAAI;QACR,IAAI,CAAC,OAAO,GAAG,KAAK,CAAC;IACvB,CAAC;CACF;AAED,+EAA+E;AAC/E,iBAAiB;AACjB,+EAA+E;AAE/E,MAAM,OAAO,aAAc,SAAQ,YAAY;IACrC,UAAU,GAAQ,IAAI,CAAC;IACvB,OAAO,GAAQ,IAAI,CAAC;IACpB,MAAM,CAAc;IACpB,OAAO,CAAS;IAChB,WAAW,GAAkB,IAAI,CAAC;IAE1C,YAAY,OAAe,EAAE,SAAsB,EAAE,IAAI,EAAE,YAAY,EAAE;QACvE,KAAK,EAAE,CAAC;QACR,IAAI,CAAC,OAAO,GAAG,OAAO,CAAC;QACvB,IAAI,CAAC,MAAM,GAAG,MAAM,CAAC;IACvB,CAAC;IAED,KAAK,CAAC,OAAO;QACX,IAAI,CAAC,UAAU,GAAG,MAAM,IAAI,CAAC,OAAO,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC;QACnD,IAAI,CAAC,OAAO,GAAG,MAAM,IAAI,CAAC,UAAU,CAAC,aAAa,EAAE,CAAC;QAErD,MAAM,IAAI,GAAQ,EAAE,CAAC;QACrB,IAAI,IAAI,CAAC,MAAM,CAAC,UAAU;YAAE,IAAI,CAAC,eAAe,CAAC,GAAG,IAAI,CAAC,MAAM,CAAC,UAAU,GAAG,IAAI,CAAC;QAClF,IAAI,IAAI,CAAC,MAAM,CAAC,OAAO;YAAE,IAAI,CAAC,cAAc,CAAC,GAAG,IAAI,CAAC,MAAM,CAAC,OAAO,CAAC;QACpE,IAAI,IAAI,CAAC,MAAM,CAAC,eAAe,EAAE,CAAC;YAChC,IAAI,CAAC,wBAAwB,CAAC,GAAG,EAAE,CAAC;YACpC,IAAI,CAAC,2BAA2B,CAAC,GAAG,IAAI,CAAC,MAAM,CAAC,eAAe,CAAC;YAEhE,MAAM,IAAI,CAAC,OAAO,CAAC,WAAW,CAAC,IAAI,CAAC,MAAM,CAAC,eAAe,EAAE,EAAE,OAAO,EAAE,IAAI,EAAE,CAAC,CAAC;QACjF,CAAC;QAED,MAAM,IAAI,CAAC,OAAO,CAAC,WAAW,CAAC,IAAI,CAAC,MAAM,CAAC,IAAI,EAAE;YAC/C,OAAO,EAAE,IAAI;YACb,SAAS,EAAE,IAAI;SAChB,CAAC,CAAC;IACL,CAAC;IAED,KAAK,CAAC,UAAU;QACd,IAAI,IAAI,CAAC,OAAO;YAAE,MAAM,IAAI,CAAC,OAAO,CAAC,KAAK,EAAE,CAAC;QAC7C,IAAI,IAAI,CAAC,UAAU;YAAE,MAAM,IAAI,CAAC,UAAU,CAAC,KAAK,EAAE,CAAC;QACnD,IAAI,CAAC,OAAO,GAAG,IAAI,CAAC;QACpB,IAAI,CAAC,UAAU,GAAG,IAAI,CAAC;IACzB,CAAC;IAED,KAAK,CAAC,OAAO,CAAC,OAAqB,EAAE,SAAkB;QACrD,IAAI,CAAC,IAAI,CAAC,OAAO;YAAE,MAAM,IAAI,KAAK,CAAC,wBAAwB,CAAC,CAAC;QAC7D,MAAM,KAAK,GAAG,SAAS,IAAI,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC;QAE5C,IAAI,CAAC,OAAO,CAAC,WAAW,CAAC,KAAK,EAAE,MAAM,CAAC,IAAI,CAAC,IAAI,CAAC,SAAS,CAAC,OAAO,CAAC,CAAC,EAAE;YACpE,UAAU,EAAE,IAAI;YAChB,QAAQ,EAAE,OAAO,CAAC,QAAQ;YAC1B,SAAS,EAAE,OAAO,CAAC,EAAE;YACrB,SAAS,EAAE,OAAO,CAAC,SAAS,CAAC,OAAO,EAAE;SACvC,CAAC,CAAC;QAEH,OAAO,OAAO,CAAC,EAAE,CAAC;IACpB,CAAC;IAED,KAAK,CAAC,OAAO,CAAC,OAAuB,EAAE,SAAkB,EAAE,SAAS,GAAG,CAAC;QACtE,IAAI,CAAC,IAAI,CAAC,OAAO;YAAE,MAAM,IAAI,KAAK,CAAC,wBAAwB,CAAC,CAAC;QAC7D,MAAM,KAAK,GAAG,SAAS,IAAI,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC;QAE5C,MAAM,IAAI,CAAC,OAAO,CAAC,QAAQ,CAAC,SAAS,CAAC,CAAC;QAEvC,MAAM,EAAE,WAAW,EAAE,GAAG,MAAM,IAAI,CAAC,OAAO,CAAC,OAAO,CAAC,KAAK,EAAE,KAAK,EAAE,GAAQ,EAAE,EAAE;YAC3E,IAAI,CAAC,GAAG;gBAAE,OAAO;YAEjB,MAAM,OAAO,GAAiB,IAAI,CAAC,KAAK,CAAC,GAAG,CAAC,OAAO,CAAC,QAAQ,EAAE,CAAC,CAAC;YACjE,OAAO,CAAC,QAAQ,EAAE,CAAC;YAEnB,IAAI,CAAC;gBACH,MAAM,OAAO,CAAC,OAAO,CAAC,CAAC;gBACvB,IAAI,CAAC,OAAO,EAAE,GAAG,CAAC,GAAG,CAAC,CAAC;YACzB,CAAC;YAAC,OAAO,KAAK,EAAE,CAAC;gBACf,OAAO,CAAC,KAAK,GAAG,MAAM,CAAC,KAAK,CAAC,CAAC;gBAC9B,IAAI,OAAO,CAAC,QAAQ,GAAG,OAAO,CAAC,WAAW,EAAE,CAAC;oBAC3C,IAAI,CAAC,OAAO,EAAE,IAAI,CAAC,GAAG,EAAE,KAAK,EAAE,IAAI,CAAC,CAAC;gBACvC,CAAC;qBAAM,CAAC;oBACN,IAAI,CAAC,OAAO,EAAE,IAAI,CAAC,GAAG,EAAE,KAAK,EAAE,KAAK,CAAC,CAAC;gBACxC,CAAC;YACH,CAAC;QACH,CAAC,CAAC,CAAC;QAEH,IAAI,CAAC,WAAW,GAAG,WAAW,CAAC;IACjC,CAAC;IAED,KAAK,CAAC,WAAW,CAAC,UAAkB;QAClC,qBAAqB;IACvB,CAAC;IAED,KAAK,CAAC,MAAM,CAAC,UAAkB,EAAE,QAAQ,GAAG,IAAI;QAC9C,qBAAqB;IACvB,CAAC;IAED,KAAK,CAAC,cAAc,CAAC,SAAkB;QACrC,IAAI,CAAC,IAAI,CAAC,OAAO;YAAE,MAAM,IAAI,KAAK,CAAC,wBAAwB,CAAC,CAAC;QAC7D,MAAM,CAAC,GAAG,MAAM,IAAI,CAAC,OAAO,CAAC,WAAW,CAAC,SAAS,IAAI,IAAI,CAAC,MAAM,CAAC,IAAI,EAAE,EAAE,OAAO,EAAE,IAAI,EAAE,CAAC,CAAC;QAC3F,OAAO,CAAC,CAAC,YAAY,CAAC;IACxB,CAAC;IAED,KAAK,CAAC,KAAK,CAAC,SAAkB;QAC5B,IAAI,CAAC,IAAI,CAAC,OAAO;YAAE,MAAM,IAAI,KAAK,CAAC,wBAAwB,CAAC,CAAC;QAC7D,MAAM,CAAC,GAAG,MAAM,IAAI,CAAC,OAAO,CAAC,UAAU,CAAC,SAAS,IAAI,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,CAAC;QACvE,OAAO,CAAC,CAAC,YAAY,CAAC;IACxB,CAAC;IAED,KAAK,CAAC,IAAI;QACR,IAAI,IAAI,CAAC,OAAO,IAAI,IAAI,CAAC,WAAW,EAAE,CAAC;YACrC,MAAM,IAAI,CAAC,OAAO,CAAC,MAAM,CAAC,IAAI,CAAC,WAAW,CAAC,CAAC;YAC5C,IAAI,CAAC,WAAW,GAAG,IAAI,CAAC;QAC1B,CAAC;IACH,CAAC;CACF;AAED,+EAA+E;AAC/E,yBAAyB;AACzB,+EAA+E;AAE/E,MAAM,OAAO,oBAAoB;IACvB,KAAK,CAAe;IACpB,gBAAgB,CAAuF;IAE/G,YAAY,KAAmB,EAAE,gBAAsG;QACrI,IAAI,CAAC,KAAK,GAAG,KAAK,CAAC;QACnB,IAAI,CAAC,gBAAgB,GAAG,gBAAgB,CAAC;IAC3C,CAAC;IAED,KAAK,CAAC,eAAe,CACnB,UAAkB,EAClB,SAAkC,EAAE,EACpC,WAA4B,eAAe,CAAC,MAAM,EAClD,WAAoC,EAAE;QAEtC,MAAM,OAAO,GAAiB;YAC5B,EAAE,EAAE,UAAU,EAAE;YAChB,UAAU;YACV,OAAO,EAAE,MAAM;YACf,QAAQ;YACR,MAAM,EAAE,aAAa,CAAC,OAAO;YAC7B,SAAS,EAAE,IAAI,IAAI,EAAE;YACrB,QAAQ,EAAE,CAAC;YACX,WAAW,EAAE,CAAC;YACd,QAAQ;SACT,CAAC;QACF,OAAO,IAAI,CAAC,KAAK,CAAC,OAAO,CAAC,OAAO,CAAC,CAAC;IACrC,CAAC;IAED,KAAK,CAAC,WAAW,CAAC,UAAU,GAAG,CAAC;QAC9B,IAAI,CAAC,IAAI,CAAC,gBAAgB,EAAE,CAAC;YAC3B,MAAM,IAAI,KAAK,CAAC,iCAAiC,CAAC,CAAC;QACrD,CAAC;QAED,MAAM,OAAO,GAAmB,KAAK,EAAE,OAAO,EAAE,EAAE;YAChD,IAAI,IAAI,CAAC,gBAAgB,EAAE,CAAC;gBAC1B,MAAM,IAAI,CAAC,gBAAgB,CAAC,OAAO,CAAC,UAAU,EAAE,OAAO,CAAC,OAAO,CAAC,CAAC;YACnE,CAAC;QACH,CAAC,CAAC;QAEF,MAAM,IAAI,CAAC,KAAK,CAAC,OAAO,CAAC,OAAO,EAAE,SAAS,EAAE,UAAU,CAAC,CAAC;IAC3D,CAAC;IAED,KAAK,CAAC,UAAU;QACd,MAAM,IAAI,CAAC,KAAK,CAAC,IAAI,EAAE,CAAC;IAC1B,CAAC;CACF"}
|
|
@@ -0,0 +1,117 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Rollback capabilities for marktoflow.
|
|
3
|
+
*
|
|
4
|
+
* Provides step undo registry and transaction-like semantics for workflow execution.
|
|
5
|
+
*/
|
|
6
|
+
export declare enum RollbackStrategy {
|
|
7
|
+
NONE = "none",
|
|
8
|
+
COMPENSATE = "compensate",
|
|
9
|
+
RESTORE = "restore",
|
|
10
|
+
IDEMPOTENT = "idempotent"
|
|
11
|
+
}
|
|
12
|
+
export declare enum RollbackStatus {
|
|
13
|
+
PENDING = "pending",
|
|
14
|
+
IN_PROGRESS = "in_progress",
|
|
15
|
+
COMPLETED = "completed",
|
|
16
|
+
FAILED = "failed",
|
|
17
|
+
SKIPPED = "skipped"
|
|
18
|
+
}
|
|
19
|
+
export interface RollbackAction {
|
|
20
|
+
stepName: string;
|
|
21
|
+
stepIndex: number;
|
|
22
|
+
strategy: RollbackStrategy;
|
|
23
|
+
compensateAction?: string | undefined;
|
|
24
|
+
compensateInputs: Record<string, unknown>;
|
|
25
|
+
stateSnapshot: Record<string, unknown>;
|
|
26
|
+
executedAt: Date;
|
|
27
|
+
rollbackStatus: RollbackStatus;
|
|
28
|
+
rollbackError?: string | undefined;
|
|
29
|
+
metadata: Record<string, unknown>;
|
|
30
|
+
}
|
|
31
|
+
export interface RollbackResult {
|
|
32
|
+
success: boolean;
|
|
33
|
+
stepsRolledBack: number;
|
|
34
|
+
stepsFailed: number;
|
|
35
|
+
stepsSkipped: number;
|
|
36
|
+
errors: string[];
|
|
37
|
+
durationSeconds: number;
|
|
38
|
+
}
|
|
39
|
+
export interface CompensationHandler {
|
|
40
|
+
actionType: string;
|
|
41
|
+
compensate(action: RollbackAction, context: Record<string, unknown>): boolean;
|
|
42
|
+
compensateAsync(action: RollbackAction, context: Record<string, unknown>): Promise<boolean>;
|
|
43
|
+
}
|
|
44
|
+
export declare class DefaultCompensationHandler implements CompensationHandler {
|
|
45
|
+
actionType: string;
|
|
46
|
+
private handlers;
|
|
47
|
+
private asyncHandlers;
|
|
48
|
+
register(actionType: string, handler: (action: RollbackAction, context: Record<string, unknown>) => boolean): void;
|
|
49
|
+
registerAsync(actionType: string, handler: (action: RollbackAction, context: Record<string, unknown>) => unknown): void;
|
|
50
|
+
compensate(action: RollbackAction, context: Record<string, unknown>): boolean;
|
|
51
|
+
compensateAsync(action: RollbackAction, context: Record<string, unknown>): Promise<boolean>;
|
|
52
|
+
}
|
|
53
|
+
export declare class RollbackRegistry {
|
|
54
|
+
readonly maxHistory: number;
|
|
55
|
+
private actions;
|
|
56
|
+
private compensationHandler;
|
|
57
|
+
private customHandlers;
|
|
58
|
+
constructor(maxHistory?: number);
|
|
59
|
+
registerHandler(handler: CompensationHandler): void;
|
|
60
|
+
registerCompensation(actionType: string, handler: (action: RollbackAction, context: Record<string, unknown>) => boolean): void;
|
|
61
|
+
registerCompensationAsync(actionType: string, handler: (action: RollbackAction, context: Record<string, unknown>) => unknown): void;
|
|
62
|
+
record(params: {
|
|
63
|
+
stepName: string;
|
|
64
|
+
stepIndex: number;
|
|
65
|
+
strategy?: RollbackStrategy;
|
|
66
|
+
compensateAction?: string;
|
|
67
|
+
compensateInputs?: Record<string, unknown>;
|
|
68
|
+
stateSnapshot?: Record<string, unknown>;
|
|
69
|
+
metadata?: Record<string, unknown>;
|
|
70
|
+
}): RollbackAction;
|
|
71
|
+
getActions(): RollbackAction[];
|
|
72
|
+
getRollbackOrder(): RollbackAction[];
|
|
73
|
+
clear(): void;
|
|
74
|
+
rollbackAll(context?: Record<string, unknown>, stopOnError?: boolean): RollbackResult;
|
|
75
|
+
rollbackAllAsync(context?: Record<string, unknown>, stopOnError?: boolean): Promise<RollbackResult>;
|
|
76
|
+
rollbackTo(stepIndex: number, context?: Record<string, unknown>): RollbackResult;
|
|
77
|
+
rollbackToAsync(stepIndex: number, context?: Record<string, unknown>): Promise<RollbackResult>;
|
|
78
|
+
private executeCompensation;
|
|
79
|
+
private executeCompensationAsync;
|
|
80
|
+
}
|
|
81
|
+
export declare class TransactionContext {
|
|
82
|
+
readonly registry: RollbackRegistry;
|
|
83
|
+
readonly autoRollbackOnError: boolean;
|
|
84
|
+
private committed;
|
|
85
|
+
private rolledBack;
|
|
86
|
+
private context;
|
|
87
|
+
private savepoints;
|
|
88
|
+
constructor(registry?: RollbackRegistry, autoRollbackOnError?: boolean);
|
|
89
|
+
get isActive(): boolean;
|
|
90
|
+
recordStep(params: {
|
|
91
|
+
stepName: string;
|
|
92
|
+
stepIndex: number;
|
|
93
|
+
compensateAction?: string;
|
|
94
|
+
compensateInputs?: Record<string, unknown>;
|
|
95
|
+
stateSnapshot?: Record<string, unknown>;
|
|
96
|
+
strategy?: RollbackStrategy;
|
|
97
|
+
}): RollbackAction;
|
|
98
|
+
savepoint(name: string): void;
|
|
99
|
+
rollbackToSavepoint(name: string): RollbackResult;
|
|
100
|
+
rollbackToSavepointAsync(name: string): Promise<RollbackResult>;
|
|
101
|
+
commit(): void;
|
|
102
|
+
rollback(): RollbackResult;
|
|
103
|
+
rollbackAsync(): Promise<RollbackResult>;
|
|
104
|
+
setContext(key: string, value: unknown): void;
|
|
105
|
+
getContext(key: string, defaultValue?: unknown): unknown;
|
|
106
|
+
}
|
|
107
|
+
export declare class FileCompensationHandler implements CompensationHandler {
|
|
108
|
+
actionType: string;
|
|
109
|
+
compensate(action: RollbackAction): boolean;
|
|
110
|
+
compensateAsync(action: RollbackAction): Promise<boolean>;
|
|
111
|
+
}
|
|
112
|
+
export declare class GitCompensationHandler implements CompensationHandler {
|
|
113
|
+
actionType: string;
|
|
114
|
+
compensate(action: RollbackAction): boolean;
|
|
115
|
+
compensateAsync(action: RollbackAction): Promise<boolean>;
|
|
116
|
+
}
|
|
117
|
+
//# sourceMappingURL=rollback.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"rollback.d.ts","sourceRoot":"","sources":["../src/rollback.ts"],"names":[],"mappings":"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"}
|