@platformatic/job-queue 0.0.1 → 0.1.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/README.md +511 -0
- package/dist/consumer.d.ts +43 -0
- package/dist/consumer.d.ts.map +1 -0
- package/dist/consumer.js +214 -0
- package/dist/consumer.js.map +1 -0
- package/dist/errors.d.ts +60 -0
- package/dist/errors.d.ts.map +1 -0
- package/dist/errors.js +141 -0
- package/dist/errors.js.map +1 -0
- package/dist/index.d.ts +12 -0
- package/dist/index.d.ts.map +1 -0
- package/dist/index.js +13 -0
- package/dist/index.js.map +1 -0
- package/dist/producer.d.ts +39 -0
- package/dist/producer.d.ts.map +1 -0
- package/dist/producer.js +163 -0
- package/dist/producer.js.map +1 -0
- package/dist/queue.d.ts +42 -0
- package/dist/queue.d.ts.map +1 -0
- package/dist/queue.js +153 -0
- package/dist/queue.js.map +1 -0
- package/dist/reaper.d.ts +52 -0
- package/dist/reaper.d.ts.map +1 -0
- package/dist/reaper.js +376 -0
- package/dist/reaper.js.map +1 -0
- package/dist/serde/index.d.ts +19 -0
- package/dist/serde/index.d.ts.map +1 -0
- package/dist/serde/index.js +18 -0
- package/dist/serde/index.js.map +1 -0
- package/dist/storage/file.d.ts +44 -0
- package/dist/storage/file.d.ts.map +1 -0
- package/dist/storage/file.js +601 -0
- package/dist/storage/file.js.map +1 -0
- package/dist/storage/memory.d.ts +39 -0
- package/dist/storage/memory.d.ts.map +1 -0
- package/dist/storage/memory.js +292 -0
- package/dist/storage/memory.js.map +1 -0
- package/dist/storage/redis.d.ts +47 -0
- package/dist/storage/redis.d.ts.map +1 -0
- package/dist/storage/redis.js +317 -0
- package/dist/storage/redis.js.map +1 -0
- package/dist/storage/types.d.ts +179 -0
- package/dist/storage/types.d.ts.map +1 -0
- package/dist/storage/types.js +2 -0
- package/dist/storage/types.js.map +1 -0
- package/dist/types.d.ts +126 -0
- package/dist/types.d.ts.map +1 -0
- package/dist/types.js +2 -0
- package/dist/types.js.map +1 -0
- package/dist/utils/id.d.ts +10 -0
- package/dist/utils/id.d.ts.map +1 -0
- package/dist/utils/id.js +18 -0
- package/dist/utils/id.js.map +1 -0
- package/dist/utils/state.d.ts +13 -0
- package/dist/utils/state.d.ts.map +1 -0
- package/dist/utils/state.js +22 -0
- package/dist/utils/state.js.map +1 -0
- package/package.json +45 -9
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"memory.d.ts","sourceRoot":"","sources":["../../src/storage/memory.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,292 @@
|
|
|
1
|
+
import { EventEmitter } from 'node:events';
|
|
2
|
+
/**
|
|
3
|
+
* In-memory storage implementation for testing and single-process scenarios
|
|
4
|
+
*/
|
|
5
|
+
export class MemoryStorage {
|
|
6
|
+
#queue = [];
|
|
7
|
+
#processingQueues = new Map();
|
|
8
|
+
#jobs = new Map();
|
|
9
|
+
#results = new Map();
|
|
10
|
+
#errors = new Map();
|
|
11
|
+
#workers = new Map();
|
|
12
|
+
#eventEmitter = new EventEmitter({ captureRejections: true });
|
|
13
|
+
#notifyEmitter = new EventEmitter({ captureRejections: true });
|
|
14
|
+
#cleanupInterval = null;
|
|
15
|
+
#dequeueWaiters = [];
|
|
16
|
+
constructor() {
|
|
17
|
+
// Disable max listeners warning for high-throughput scenarios
|
|
18
|
+
this.#eventEmitter.setMaxListeners(0);
|
|
19
|
+
this.#notifyEmitter.setMaxListeners(0);
|
|
20
|
+
}
|
|
21
|
+
async connect() {
|
|
22
|
+
// Already connected
|
|
23
|
+
if (this.#cleanupInterval)
|
|
24
|
+
return;
|
|
25
|
+
// Start TTL cleanup interval (every 1 second)
|
|
26
|
+
this.#cleanupInterval = setInterval(() => {
|
|
27
|
+
this.#cleanupExpired();
|
|
28
|
+
}, 1000);
|
|
29
|
+
}
|
|
30
|
+
async disconnect() {
|
|
31
|
+
if (this.#cleanupInterval) {
|
|
32
|
+
clearInterval(this.#cleanupInterval);
|
|
33
|
+
this.#cleanupInterval = null;
|
|
34
|
+
}
|
|
35
|
+
// Clear all dequeue waiters
|
|
36
|
+
for (const waiter of this.#dequeueWaiters) {
|
|
37
|
+
clearTimeout(waiter.timeoutId);
|
|
38
|
+
waiter.resolve(null);
|
|
39
|
+
}
|
|
40
|
+
this.#dequeueWaiters = [];
|
|
41
|
+
// Clear all event emitters
|
|
42
|
+
this.#eventEmitter.removeAllListeners();
|
|
43
|
+
this.#notifyEmitter.removeAllListeners();
|
|
44
|
+
}
|
|
45
|
+
async enqueue(id, message, timestamp) {
|
|
46
|
+
const existing = this.#jobs.get(id);
|
|
47
|
+
if (existing) {
|
|
48
|
+
return existing;
|
|
49
|
+
}
|
|
50
|
+
this.#jobs.set(id, `queued:${timestamp}`);
|
|
51
|
+
this.#queue.push(message);
|
|
52
|
+
// Publish event
|
|
53
|
+
this.#eventEmitter.emit('event', id, 'queued');
|
|
54
|
+
// Notify any waiting dequeue calls
|
|
55
|
+
this.#notifyDequeueWaiters();
|
|
56
|
+
return null;
|
|
57
|
+
}
|
|
58
|
+
async dequeue(workerId, timeout) {
|
|
59
|
+
// Try to get a job immediately
|
|
60
|
+
const message = this.#queue.shift();
|
|
61
|
+
if (message) {
|
|
62
|
+
this.#addToProcessingQueue(workerId, message);
|
|
63
|
+
return message;
|
|
64
|
+
}
|
|
65
|
+
// No job available, wait for one
|
|
66
|
+
return new Promise((resolve) => {
|
|
67
|
+
const timeoutId = setTimeout(() => {
|
|
68
|
+
// Remove this waiter from the list
|
|
69
|
+
const index = this.#dequeueWaiters.findIndex(w => w.resolve === resolve);
|
|
70
|
+
if (index !== -1) {
|
|
71
|
+
this.#dequeueWaiters.splice(index, 1);
|
|
72
|
+
}
|
|
73
|
+
resolve(null);
|
|
74
|
+
}, timeout * 1000);
|
|
75
|
+
this.#dequeueWaiters.push({ workerId, resolve, timeoutId });
|
|
76
|
+
});
|
|
77
|
+
}
|
|
78
|
+
#notifyDequeueWaiters() {
|
|
79
|
+
while (this.#dequeueWaiters.length > 0 && this.#queue.length > 0) {
|
|
80
|
+
const waiter = this.#dequeueWaiters.shift();
|
|
81
|
+
if (waiter) {
|
|
82
|
+
clearTimeout(waiter.timeoutId);
|
|
83
|
+
const message = this.#queue.shift();
|
|
84
|
+
if (message) {
|
|
85
|
+
this.#addToProcessingQueue(waiter.workerId, message);
|
|
86
|
+
waiter.resolve(message);
|
|
87
|
+
}
|
|
88
|
+
else {
|
|
89
|
+
waiter.resolve(null);
|
|
90
|
+
}
|
|
91
|
+
}
|
|
92
|
+
}
|
|
93
|
+
}
|
|
94
|
+
#addToProcessingQueue(workerId, message) {
|
|
95
|
+
let processingQueue = this.#processingQueues.get(workerId);
|
|
96
|
+
if (!processingQueue) {
|
|
97
|
+
processingQueue = [];
|
|
98
|
+
this.#processingQueues.set(workerId, processingQueue);
|
|
99
|
+
}
|
|
100
|
+
processingQueue.push(message);
|
|
101
|
+
}
|
|
102
|
+
async requeue(id, message, workerId) {
|
|
103
|
+
// Remove from processing queue
|
|
104
|
+
const processingQueue = this.#processingQueues.get(workerId);
|
|
105
|
+
if (processingQueue) {
|
|
106
|
+
const index = processingQueue.findIndex(m => m.equals(message));
|
|
107
|
+
if (index !== -1) {
|
|
108
|
+
processingQueue.splice(index, 1);
|
|
109
|
+
}
|
|
110
|
+
}
|
|
111
|
+
// Add back to main queue
|
|
112
|
+
this.#queue.unshift(message);
|
|
113
|
+
// Notify waiters
|
|
114
|
+
this.#notifyDequeueWaiters();
|
|
115
|
+
}
|
|
116
|
+
async ack(id, message, workerId) {
|
|
117
|
+
const processingQueue = this.#processingQueues.get(workerId);
|
|
118
|
+
if (processingQueue) {
|
|
119
|
+
const index = processingQueue.findIndex(m => m.equals(message));
|
|
120
|
+
if (index !== -1) {
|
|
121
|
+
processingQueue.splice(index, 1);
|
|
122
|
+
}
|
|
123
|
+
}
|
|
124
|
+
}
|
|
125
|
+
async getJobState(id) {
|
|
126
|
+
return this.#jobs.get(id) ?? null;
|
|
127
|
+
}
|
|
128
|
+
async setJobState(id, state) {
|
|
129
|
+
this.#jobs.set(id, state);
|
|
130
|
+
}
|
|
131
|
+
async deleteJob(id) {
|
|
132
|
+
const existed = this.#jobs.has(id);
|
|
133
|
+
this.#jobs.delete(id);
|
|
134
|
+
if (existed) {
|
|
135
|
+
this.#eventEmitter.emit('event', id, 'cancelled');
|
|
136
|
+
}
|
|
137
|
+
return existed;
|
|
138
|
+
}
|
|
139
|
+
async getJobStates(ids) {
|
|
140
|
+
const result = new Map();
|
|
141
|
+
for (const id of ids) {
|
|
142
|
+
result.set(id, this.#jobs.get(id) ?? null);
|
|
143
|
+
}
|
|
144
|
+
return result;
|
|
145
|
+
}
|
|
146
|
+
async setResult(id, result, ttlMs) {
|
|
147
|
+
this.#results.set(id, {
|
|
148
|
+
data: result,
|
|
149
|
+
expiresAt: Date.now() + ttlMs
|
|
150
|
+
});
|
|
151
|
+
}
|
|
152
|
+
async getResult(id) {
|
|
153
|
+
const stored = this.#results.get(id);
|
|
154
|
+
if (!stored)
|
|
155
|
+
return null;
|
|
156
|
+
if (Date.now() > stored.expiresAt) {
|
|
157
|
+
this.#results.delete(id);
|
|
158
|
+
return null;
|
|
159
|
+
}
|
|
160
|
+
return stored.data;
|
|
161
|
+
}
|
|
162
|
+
async setError(id, error, ttlMs) {
|
|
163
|
+
this.#errors.set(id, {
|
|
164
|
+
data: error,
|
|
165
|
+
expiresAt: Date.now() + ttlMs
|
|
166
|
+
});
|
|
167
|
+
}
|
|
168
|
+
async getError(id) {
|
|
169
|
+
const stored = this.#errors.get(id);
|
|
170
|
+
if (!stored)
|
|
171
|
+
return null;
|
|
172
|
+
if (Date.now() > stored.expiresAt) {
|
|
173
|
+
this.#errors.delete(id);
|
|
174
|
+
return null;
|
|
175
|
+
}
|
|
176
|
+
return stored.data;
|
|
177
|
+
}
|
|
178
|
+
async registerWorker(workerId, ttlMs) {
|
|
179
|
+
this.#workers.set(workerId, {
|
|
180
|
+
expiresAt: Date.now() + ttlMs
|
|
181
|
+
});
|
|
182
|
+
}
|
|
183
|
+
async refreshWorker(workerId, ttlMs) {
|
|
184
|
+
await this.registerWorker(workerId, ttlMs);
|
|
185
|
+
}
|
|
186
|
+
async unregisterWorker(workerId) {
|
|
187
|
+
this.#workers.delete(workerId);
|
|
188
|
+
this.#processingQueues.delete(workerId);
|
|
189
|
+
}
|
|
190
|
+
async getWorkers() {
|
|
191
|
+
const now = Date.now();
|
|
192
|
+
const activeWorkers = [];
|
|
193
|
+
for (const [workerId, info] of this.#workers) {
|
|
194
|
+
if (now <= info.expiresAt) {
|
|
195
|
+
activeWorkers.push(workerId);
|
|
196
|
+
}
|
|
197
|
+
}
|
|
198
|
+
return activeWorkers;
|
|
199
|
+
}
|
|
200
|
+
async getProcessingJobs(workerId) {
|
|
201
|
+
return this.#processingQueues.get(workerId) ?? [];
|
|
202
|
+
}
|
|
203
|
+
async subscribeToJob(id, handler) {
|
|
204
|
+
const eventName = `notify:${id}`;
|
|
205
|
+
this.#notifyEmitter.on(eventName, handler);
|
|
206
|
+
return async () => {
|
|
207
|
+
this.#notifyEmitter.off(eventName, handler);
|
|
208
|
+
};
|
|
209
|
+
}
|
|
210
|
+
async notifyJobComplete(id, status) {
|
|
211
|
+
this.#notifyEmitter.emit(`notify:${id}`, status);
|
|
212
|
+
}
|
|
213
|
+
async subscribeToEvents(handler) {
|
|
214
|
+
this.#eventEmitter.on('event', handler);
|
|
215
|
+
return async () => {
|
|
216
|
+
this.#eventEmitter.off('event', handler);
|
|
217
|
+
};
|
|
218
|
+
}
|
|
219
|
+
async publishEvent(id, event) {
|
|
220
|
+
this.#eventEmitter.emit('event', id, event);
|
|
221
|
+
}
|
|
222
|
+
async completeJob(id, message, workerId, result, resultTtlMs) {
|
|
223
|
+
const timestamp = Date.now();
|
|
224
|
+
// Set state to completed
|
|
225
|
+
this.#jobs.set(id, `completed:${timestamp}`);
|
|
226
|
+
// Store result
|
|
227
|
+
await this.setResult(id, result, resultTtlMs);
|
|
228
|
+
// Remove from processing queue
|
|
229
|
+
await this.ack(id, message, workerId);
|
|
230
|
+
// Publish notification
|
|
231
|
+
await this.notifyJobComplete(id, 'completed');
|
|
232
|
+
// Publish event
|
|
233
|
+
this.#eventEmitter.emit('event', id, 'completed');
|
|
234
|
+
}
|
|
235
|
+
async failJob(id, message, workerId, error, errorTtlMs) {
|
|
236
|
+
const timestamp = Date.now();
|
|
237
|
+
// Set state to failed
|
|
238
|
+
this.#jobs.set(id, `failed:${timestamp}`);
|
|
239
|
+
// Store error
|
|
240
|
+
await this.setError(id, error, errorTtlMs);
|
|
241
|
+
// Remove from processing queue
|
|
242
|
+
await this.ack(id, message, workerId);
|
|
243
|
+
// Publish notification
|
|
244
|
+
await this.notifyJobComplete(id, 'failed');
|
|
245
|
+
// Publish event
|
|
246
|
+
this.#eventEmitter.emit('event', id, 'failed');
|
|
247
|
+
}
|
|
248
|
+
async retryJob(id, message, workerId, attempts) {
|
|
249
|
+
const timestamp = Date.now();
|
|
250
|
+
// Set state to failing
|
|
251
|
+
this.#jobs.set(id, `failing:${timestamp}:${attempts}`);
|
|
252
|
+
// Move from processing queue to main queue
|
|
253
|
+
await this.requeue(id, message, workerId);
|
|
254
|
+
// Publish notification
|
|
255
|
+
await this.notifyJobComplete(id, 'failing');
|
|
256
|
+
// Publish event
|
|
257
|
+
this.#eventEmitter.emit('event', id, 'failing');
|
|
258
|
+
}
|
|
259
|
+
#cleanupExpired() {
|
|
260
|
+
const now = Date.now();
|
|
261
|
+
// Clean expired results
|
|
262
|
+
for (const [id, stored] of this.#results) {
|
|
263
|
+
if (now > stored.expiresAt) {
|
|
264
|
+
this.#results.delete(id);
|
|
265
|
+
}
|
|
266
|
+
}
|
|
267
|
+
// Clean expired errors
|
|
268
|
+
for (const [id, stored] of this.#errors) {
|
|
269
|
+
if (now > stored.expiresAt) {
|
|
270
|
+
this.#errors.delete(id);
|
|
271
|
+
}
|
|
272
|
+
}
|
|
273
|
+
// Clean expired workers
|
|
274
|
+
for (const [workerId, info] of this.#workers) {
|
|
275
|
+
if (now > info.expiresAt) {
|
|
276
|
+
this.#workers.delete(workerId);
|
|
277
|
+
}
|
|
278
|
+
}
|
|
279
|
+
}
|
|
280
|
+
/**
|
|
281
|
+
* Clear all data (useful for testing)
|
|
282
|
+
*/
|
|
283
|
+
clear() {
|
|
284
|
+
this.#queue = [];
|
|
285
|
+
this.#processingQueues.clear();
|
|
286
|
+
this.#jobs.clear();
|
|
287
|
+
this.#results.clear();
|
|
288
|
+
this.#errors.clear();
|
|
289
|
+
this.#workers.clear();
|
|
290
|
+
}
|
|
291
|
+
}
|
|
292
|
+
//# sourceMappingURL=memory.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"memory.js","sourceRoot":"","sources":["../../src/storage/memory.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,47 @@
|
|
|
1
|
+
import type { Storage } from './types.ts';
|
|
2
|
+
interface RedisStorageConfig {
|
|
3
|
+
url?: string;
|
|
4
|
+
keyPrefix?: string;
|
|
5
|
+
}
|
|
6
|
+
/**
|
|
7
|
+
* Redis/Valkey storage implementation
|
|
8
|
+
*/
|
|
9
|
+
export declare class RedisStorage implements Storage {
|
|
10
|
+
#private;
|
|
11
|
+
constructor(config?: RedisStorageConfig);
|
|
12
|
+
connect(): Promise<void>;
|
|
13
|
+
disconnect(): Promise<void>;
|
|
14
|
+
enqueue(id: string, message: Buffer, timestamp: number): Promise<string | null>;
|
|
15
|
+
dequeue(workerId: string, timeout: number): Promise<Buffer | null>;
|
|
16
|
+
requeue(id: string, message: Buffer, workerId: string): Promise<void>;
|
|
17
|
+
ack(id: string, message: Buffer, workerId: string): Promise<void>;
|
|
18
|
+
getJobState(id: string): Promise<string | null>;
|
|
19
|
+
setJobState(id: string, state: string): Promise<void>;
|
|
20
|
+
deleteJob(id: string): Promise<boolean>;
|
|
21
|
+
getJobStates(ids: string[]): Promise<Map<string, string | null>>;
|
|
22
|
+
setResult(id: string, result: Buffer, ttlMs: number): Promise<void>;
|
|
23
|
+
getResult(id: string): Promise<Buffer | null>;
|
|
24
|
+
setError(id: string, error: Buffer, ttlMs: number): Promise<void>;
|
|
25
|
+
getError(id: string): Promise<Buffer | null>;
|
|
26
|
+
registerWorker(workerId: string, ttlMs: number): Promise<void>;
|
|
27
|
+
refreshWorker(workerId: string, ttlMs: number): Promise<void>;
|
|
28
|
+
unregisterWorker(workerId: string): Promise<void>;
|
|
29
|
+
getWorkers(): Promise<string[]>;
|
|
30
|
+
getProcessingJobs(workerId: string): Promise<Buffer[]>;
|
|
31
|
+
subscribeToJob(id: string, handler: (status: 'completed' | 'failed' | 'failing') => void): Promise<() => Promise<void>>;
|
|
32
|
+
notifyJobComplete(id: string, status: 'completed' | 'failed' | 'failing'): Promise<void>;
|
|
33
|
+
subscribeToEvents(handler: (id: string, event: string) => void): Promise<() => Promise<void>>;
|
|
34
|
+
publishEvent(id: string, event: string): Promise<void>;
|
|
35
|
+
completeJob(id: string, message: Buffer, workerId: string, result: Buffer, resultTtlMs: number): Promise<void>;
|
|
36
|
+
failJob(id: string, message: Buffer, workerId: string, error: Buffer, errorTtlMs: number): Promise<void>;
|
|
37
|
+
retryJob(id: string, message: Buffer, workerId: string, attempts: number): Promise<void>;
|
|
38
|
+
/**
|
|
39
|
+
* Clear all data (useful for testing)
|
|
40
|
+
*/
|
|
41
|
+
clear(): Promise<void>;
|
|
42
|
+
acquireLeaderLock(lockKey: string, ownerId: string, ttlMs: number): Promise<boolean>;
|
|
43
|
+
renewLeaderLock(lockKey: string, ownerId: string, ttlMs: number): Promise<boolean>;
|
|
44
|
+
releaseLeaderLock(lockKey: string, ownerId: string): Promise<boolean>;
|
|
45
|
+
}
|
|
46
|
+
export {};
|
|
47
|
+
//# sourceMappingURL=redis.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"redis.d.ts","sourceRoot":"","sources":["../../src/storage/redis.ts"],"names":[],"mappings":"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"}
|