@gravito/stream 1.0.0-alpha.6 → 1.0.0-beta.1
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/README.md +8 -3
- package/dist/index.cjs +1016 -31676
- package/dist/index.d.cts +1132 -0
- package/dist/index.d.ts +1123 -36
- package/dist/index.js +1412 -0
- package/package.json +3 -3
- package/dist/Consumer.d.ts +0 -67
- package/dist/Consumer.d.ts.map +0 -1
- package/dist/Job.d.ts +0 -76
- package/dist/Job.d.ts.map +0 -1
- package/dist/OrbitQueue.d.ts +0 -74
- package/dist/OrbitQueue.d.ts.map +0 -1
- package/dist/QueueManager.d.ts +0 -86
- package/dist/QueueManager.d.ts.map +0 -1
- package/dist/Queueable.d.ts +0 -63
- package/dist/Queueable.d.ts.map +0 -1
- package/dist/Worker.d.ts +0 -48
- package/dist/Worker.d.ts.map +0 -1
- package/dist/core/src/ConfigManager.d.ts +0 -26
- package/dist/core/src/ConfigManager.d.ts.map +0 -1
- package/dist/core/src/Container.d.ts +0 -39
- package/dist/core/src/Container.d.ts.map +0 -1
- package/dist/core/src/Event.d.ts +0 -6
- package/dist/core/src/Event.d.ts.map +0 -1
- package/dist/core/src/EventManager.d.ts +0 -124
- package/dist/core/src/EventManager.d.ts.map +0 -1
- package/dist/core/src/GlobalErrorHandlers.d.ts +0 -32
- package/dist/core/src/GlobalErrorHandlers.d.ts.map +0 -1
- package/dist/core/src/HookManager.d.ts +0 -29
- package/dist/core/src/HookManager.d.ts.map +0 -1
- package/dist/core/src/Listener.d.ts +0 -5
- package/dist/core/src/Listener.d.ts.map +0 -1
- package/dist/core/src/Logger.d.ts +0 -21
- package/dist/core/src/Logger.d.ts.map +0 -1
- package/dist/core/src/PlanetCore.d.ts +0 -116
- package/dist/core/src/PlanetCore.d.ts.map +0 -1
- package/dist/core/src/Route.d.ts +0 -13
- package/dist/core/src/Route.d.ts.map +0 -1
- package/dist/core/src/Router.d.ts +0 -168
- package/dist/core/src/Router.d.ts.map +0 -1
- package/dist/core/src/ServiceProvider.d.ts +0 -17
- package/dist/core/src/ServiceProvider.d.ts.map +0 -1
- package/dist/core/src/exceptions/AuthenticationException.d.ts +0 -5
- package/dist/core/src/exceptions/AuthenticationException.d.ts.map +0 -1
- package/dist/core/src/exceptions/AuthorizationException.d.ts +0 -5
- package/dist/core/src/exceptions/AuthorizationException.d.ts.map +0 -1
- package/dist/core/src/exceptions/GravitoException.d.ts +0 -15
- package/dist/core/src/exceptions/GravitoException.d.ts.map +0 -1
- package/dist/core/src/exceptions/ModelNotFoundException.d.ts +0 -7
- package/dist/core/src/exceptions/ModelNotFoundException.d.ts.map +0 -1
- package/dist/core/src/exceptions/ValidationException.d.ts +0 -15
- package/dist/core/src/exceptions/ValidationException.d.ts.map +0 -1
- package/dist/core/src/exceptions/index.d.ts +0 -6
- package/dist/core/src/exceptions/index.d.ts.map +0 -1
- package/dist/core/src/helpers/Arr.d.ts +0 -15
- package/dist/core/src/helpers/Arr.d.ts.map +0 -1
- package/dist/core/src/helpers/Str.d.ts +0 -19
- package/dist/core/src/helpers/Str.d.ts.map +0 -1
- package/dist/core/src/helpers/data.d.ts +0 -6
- package/dist/core/src/helpers/data.d.ts.map +0 -1
- package/dist/core/src/helpers/errors.d.ts +0 -13
- package/dist/core/src/helpers/errors.d.ts.map +0 -1
- package/dist/core/src/helpers/response.d.ts +0 -19
- package/dist/core/src/helpers/response.d.ts.map +0 -1
- package/dist/core/src/helpers.d.ts +0 -39
- package/dist/core/src/helpers.d.ts.map +0 -1
- package/dist/core/src/http/CookieJar.d.ts +0 -34
- package/dist/core/src/http/CookieJar.d.ts.map +0 -1
- package/dist/core/src/http/middleware/ThrottleRequests.d.ts +0 -13
- package/dist/core/src/http/middleware/ThrottleRequests.d.ts.map +0 -1
- package/dist/core/src/index.d.ts +0 -32
- package/dist/core/src/index.d.ts.map +0 -1
- package/dist/core/src/security/Encrypter.d.ts +0 -25
- package/dist/core/src/security/Encrypter.d.ts.map +0 -1
- package/dist/core/src/security/Hasher.d.ts +0 -30
- package/dist/core/src/security/Hasher.d.ts.map +0 -1
- package/dist/core/src/types/events.d.ts +0 -95
- package/dist/core/src/types/events.d.ts.map +0 -1
- package/dist/drivers/DatabaseDriver.d.ts +0 -60
- package/dist/drivers/DatabaseDriver.d.ts.map +0 -1
- package/dist/drivers/KafkaDriver.d.ts +0 -134
- package/dist/drivers/KafkaDriver.d.ts.map +0 -1
- package/dist/drivers/MemoryDriver.d.ts +0 -45
- package/dist/drivers/MemoryDriver.d.ts.map +0 -1
- package/dist/drivers/QueueDriver.d.ts +0 -89
- package/dist/drivers/QueueDriver.d.ts.map +0 -1
- package/dist/drivers/RedisDriver.d.ts +0 -79
- package/dist/drivers/RedisDriver.d.ts.map +0 -1
- package/dist/drivers/SQSDriver.d.ts +0 -100
- package/dist/drivers/SQSDriver.d.ts.map +0 -1
- package/dist/index.cjs.map +0 -422
- package/dist/index.d.ts.map +0 -1
- package/dist/index.mjs +0 -32096
- package/dist/index.mjs.map +0 -422
- package/dist/orbit-db/src/DBService.d.ts +0 -270
- package/dist/orbit-db/src/DBService.d.ts.map +0 -1
- package/dist/orbit-db/src/EventBus.d.ts +0 -53
- package/dist/orbit-db/src/EventBus.d.ts.map +0 -1
- package/dist/orbit-db/src/MigrationDriver.d.ts +0 -55
- package/dist/orbit-db/src/MigrationDriver.d.ts.map +0 -1
- package/dist/orbit-db/src/Model.d.ts +0 -564
- package/dist/orbit-db/src/Model.d.ts.map +0 -1
- package/dist/orbit-db/src/ModelCollection.d.ts +0 -35
- package/dist/orbit-db/src/ModelCollection.d.ts.map +0 -1
- package/dist/orbit-db/src/index.d.ts +0 -34
- package/dist/orbit-db/src/index.d.ts.map +0 -1
- package/dist/orbit-db/src/types.d.ts +0 -146
- package/dist/orbit-db/src/types.d.ts.map +0 -1
- package/dist/orbit-queue/src/Consumer.d.ts +0 -67
- package/dist/orbit-queue/src/Consumer.d.ts.map +0 -1
- package/dist/orbit-queue/src/Job.d.ts +0 -76
- package/dist/orbit-queue/src/Job.d.ts.map +0 -1
- package/dist/orbit-queue/src/OrbitQueue.d.ts +0 -74
- package/dist/orbit-queue/src/OrbitQueue.d.ts.map +0 -1
- package/dist/orbit-queue/src/QueueManager.d.ts +0 -86
- package/dist/orbit-queue/src/QueueManager.d.ts.map +0 -1
- package/dist/orbit-queue/src/Queueable.d.ts +0 -63
- package/dist/orbit-queue/src/Queueable.d.ts.map +0 -1
- package/dist/orbit-queue/src/Worker.d.ts +0 -48
- package/dist/orbit-queue/src/Worker.d.ts.map +0 -1
- package/dist/orbit-queue/src/drivers/DatabaseDriver.d.ts +0 -60
- package/dist/orbit-queue/src/drivers/DatabaseDriver.d.ts.map +0 -1
- package/dist/orbit-queue/src/drivers/KafkaDriver.d.ts +0 -134
- package/dist/orbit-queue/src/drivers/KafkaDriver.d.ts.map +0 -1
- package/dist/orbit-queue/src/drivers/MemoryDriver.d.ts +0 -45
- package/dist/orbit-queue/src/drivers/MemoryDriver.d.ts.map +0 -1
- package/dist/orbit-queue/src/drivers/QueueDriver.d.ts +0 -89
- package/dist/orbit-queue/src/drivers/QueueDriver.d.ts.map +0 -1
- package/dist/orbit-queue/src/drivers/RedisDriver.d.ts +0 -79
- package/dist/orbit-queue/src/drivers/RedisDriver.d.ts.map +0 -1
- package/dist/orbit-queue/src/drivers/SQSDriver.d.ts +0 -100
- package/dist/orbit-queue/src/drivers/SQSDriver.d.ts.map +0 -1
- package/dist/orbit-queue/src/index.d.ts +0 -45
- package/dist/orbit-queue/src/index.d.ts.map +0 -1
- package/dist/orbit-queue/src/serializers/ClassNameSerializer.d.ts +0 -46
- package/dist/orbit-queue/src/serializers/ClassNameSerializer.d.ts.map +0 -1
- package/dist/orbit-queue/src/serializers/JobSerializer.d.ts +0 -36
- package/dist/orbit-queue/src/serializers/JobSerializer.d.ts.map +0 -1
- package/dist/orbit-queue/src/serializers/JsonSerializer.d.ts +0 -32
- package/dist/orbit-queue/src/serializers/JsonSerializer.d.ts.map +0 -1
- package/dist/orbit-queue/src/types.d.ts +0 -85
- package/dist/orbit-queue/src/types.d.ts.map +0 -1
- package/dist/serializers/ClassNameSerializer.d.ts +0 -46
- package/dist/serializers/ClassNameSerializer.d.ts.map +0 -1
- package/dist/serializers/JobSerializer.d.ts +0 -36
- package/dist/serializers/JobSerializer.d.ts.map +0 -1
- package/dist/serializers/JsonSerializer.d.ts +0 -32
- package/dist/serializers/JsonSerializer.d.ts.map +0 -1
- package/dist/types.d.ts +0 -85
- package/dist/types.d.ts.map +0 -1
|
@@ -1,89 +0,0 @@
|
|
|
1
|
-
import type { SerializedJob, TopicOptions } from '../types';
|
|
2
|
-
/**
|
|
3
|
-
* Queue driver interface.
|
|
4
|
-
*
|
|
5
|
-
* All queue drivers must implement this interface.
|
|
6
|
-
* Defines basic queue operations plus optional enterprise-grade capabilities.
|
|
7
|
-
*
|
|
8
|
-
* @example
|
|
9
|
-
* ```typescript
|
|
10
|
-
* class MyDriver implements QueueDriver {
|
|
11
|
-
* async push(queue: string, job: SerializedJob): Promise<void> {
|
|
12
|
-
* // push a job
|
|
13
|
-
* }
|
|
14
|
-
*
|
|
15
|
-
* async pop(queue: string): Promise<SerializedJob | null> {
|
|
16
|
-
* // pop a job
|
|
17
|
-
* }
|
|
18
|
-
*
|
|
19
|
-
* async size(queue: string): Promise<number> {
|
|
20
|
-
* // queue size
|
|
21
|
-
* }
|
|
22
|
-
*
|
|
23
|
-
* async clear(queue: string): Promise<void> {
|
|
24
|
-
* // clear queue
|
|
25
|
-
* }
|
|
26
|
-
* }
|
|
27
|
-
* ```
|
|
28
|
-
*/
|
|
29
|
-
export interface QueueDriver {
|
|
30
|
-
/**
|
|
31
|
-
* Push a job to a queue.
|
|
32
|
-
* @param queue - Queue name
|
|
33
|
-
* @param job - Serialized job
|
|
34
|
-
*/
|
|
35
|
-
push(queue: string, job: SerializedJob): Promise<void>;
|
|
36
|
-
/**
|
|
37
|
-
* Pop a job from a queue (non-blocking).
|
|
38
|
-
* @param queue - Queue name
|
|
39
|
-
* @returns Serialized job, or `null` if the queue is empty
|
|
40
|
-
*/
|
|
41
|
-
pop(queue: string): Promise<SerializedJob | null>;
|
|
42
|
-
/**
|
|
43
|
-
* Get queue size.
|
|
44
|
-
* @param queue - Queue name
|
|
45
|
-
* @returns Number of jobs in the queue
|
|
46
|
-
*/
|
|
47
|
-
size(queue: string): Promise<number>;
|
|
48
|
-
/**
|
|
49
|
-
* Clear a queue.
|
|
50
|
-
* @param queue - Queue name
|
|
51
|
-
*/
|
|
52
|
-
clear(queue: string): Promise<void>;
|
|
53
|
-
/**
|
|
54
|
-
* Push multiple jobs (optional, higher throughput).
|
|
55
|
-
* @param queue - Queue name
|
|
56
|
-
* @param jobs - Serialized job array
|
|
57
|
-
*/
|
|
58
|
-
pushMany?(queue: string, jobs: SerializedJob[]): Promise<void>;
|
|
59
|
-
/**
|
|
60
|
-
* Pop multiple jobs (optional, higher throughput).
|
|
61
|
-
* @param queue - Queue name
|
|
62
|
-
* @param count - Max number of jobs to pop
|
|
63
|
-
* @returns Serialized job array
|
|
64
|
-
*/
|
|
65
|
-
popMany?(queue: string, count: number): Promise<SerializedJob[]>;
|
|
66
|
-
/**
|
|
67
|
-
* Acknowledge a message (enterprise capability, e.g. Kafka/SQS).
|
|
68
|
-
* @param messageId - Message ID
|
|
69
|
-
*/
|
|
70
|
-
acknowledge?(messageId: string): Promise<void>;
|
|
71
|
-
/**
|
|
72
|
-
* Subscribe to a queue (push-based model, e.g. Kafka/SQS).
|
|
73
|
-
* @param queue - Queue name
|
|
74
|
-
* @param callback - Callback to process jobs
|
|
75
|
-
*/
|
|
76
|
-
subscribe?(queue: string, callback: (job: SerializedJob) => Promise<void>): Promise<void>;
|
|
77
|
-
/**
|
|
78
|
-
* Create a topic (Kafka, etc.).
|
|
79
|
-
* @param topic - Topic name
|
|
80
|
-
* @param options - Topic options
|
|
81
|
-
*/
|
|
82
|
-
createTopic?(topic: string, options?: TopicOptions): Promise<void>;
|
|
83
|
-
/**
|
|
84
|
-
* Delete a topic (Kafka, etc.).
|
|
85
|
-
* @param topic - Topic name
|
|
86
|
-
*/
|
|
87
|
-
deleteTopic?(topic: string): Promise<void>;
|
|
88
|
-
}
|
|
89
|
-
//# sourceMappingURL=QueueDriver.d.ts.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"QueueDriver.d.ts","sourceRoot":"","sources":["../../src/drivers/QueueDriver.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,aAAa,EAAE,YAAY,EAAE,MAAM,UAAU,CAAA;AAE3D;;;;;;;;;;;;;;;;;;;;;;;;;;GA0BG;AACH,MAAM,WAAW,WAAW;IAC1B;;;;OAIG;IACH,IAAI,CAAC,KAAK,EAAE,MAAM,EAAE,GAAG,EAAE,aAAa,GAAG,OAAO,CAAC,IAAI,CAAC,CAAA;IAEtD;;;;OAIG;IACH,GAAG,CAAC,KAAK,EAAE,MAAM,GAAG,OAAO,CAAC,aAAa,GAAG,IAAI,CAAC,CAAA;IAEjD;;;;OAIG;IACH,IAAI,CAAC,KAAK,EAAE,MAAM,GAAG,OAAO,CAAC,MAAM,CAAC,CAAA;IAEpC;;;OAGG;IACH,KAAK,CAAC,KAAK,EAAE,MAAM,GAAG,OAAO,CAAC,IAAI,CAAC,CAAA;IAEnC;;;;OAIG;IACH,QAAQ,CAAC,CAAC,KAAK,EAAE,MAAM,EAAE,IAAI,EAAE,aAAa,EAAE,GAAG,OAAO,CAAC,IAAI,CAAC,CAAA;IAE9D;;;;;OAKG;IACH,OAAO,CAAC,CAAC,KAAK,EAAE,MAAM,EAAE,KAAK,EAAE,MAAM,GAAG,OAAO,CAAC,aAAa,EAAE,CAAC,CAAA;IAEhE;;;OAGG;IACH,WAAW,CAAC,CAAC,SAAS,EAAE,MAAM,GAAG,OAAO,CAAC,IAAI,CAAC,CAAA;IAE9C;;;;OAIG;IACH,SAAS,CAAC,CAAC,KAAK,EAAE,MAAM,EAAE,QAAQ,EAAE,CAAC,GAAG,EAAE,aAAa,KAAK,OAAO,CAAC,IAAI,CAAC,GAAG,OAAO,CAAC,IAAI,CAAC,CAAA;IAEzF;;;;OAIG;IACH,WAAW,CAAC,CAAC,KAAK,EAAE,MAAM,EAAE,OAAO,CAAC,EAAE,YAAY,GAAG,OAAO,CAAC,IAAI,CAAC,CAAA;IAElE;;;OAGG;IACH,WAAW,CAAC,CAAC,KAAK,EAAE,MAAM,GAAG,OAAO,CAAC,IAAI,CAAC,CAAA;CAC3C"}
|
|
@@ -1,79 +0,0 @@
|
|
|
1
|
-
import type { SerializedJob } from '../types';
|
|
2
|
-
import type { QueueDriver } from './QueueDriver';
|
|
3
|
-
/**
|
|
4
|
-
* Redis driver configuration.
|
|
5
|
-
*/
|
|
6
|
-
export interface RedisDriverConfig {
|
|
7
|
-
/**
|
|
8
|
-
* Redis client instance (ioredis or node-redis).
|
|
9
|
-
*/
|
|
10
|
-
client: {
|
|
11
|
-
lpush: (key: string, ...values: string[]) => Promise<number>;
|
|
12
|
-
rpop: (key: string) => Promise<string | null>;
|
|
13
|
-
llen: (key: string) => Promise<number>;
|
|
14
|
-
del: (key: string) => Promise<number>;
|
|
15
|
-
lpushx?: (key: string, ...values: string[]) => Promise<number>;
|
|
16
|
-
rpoplpush?: (src: string, dst: string) => Promise<string | null>;
|
|
17
|
-
[key: string]: unknown;
|
|
18
|
-
};
|
|
19
|
-
/**
|
|
20
|
-
* Key prefix (default: `queue:`).
|
|
21
|
-
*/
|
|
22
|
-
prefix?: string;
|
|
23
|
-
}
|
|
24
|
-
/**
|
|
25
|
-
* Redis Driver
|
|
26
|
-
*
|
|
27
|
-
* Uses Redis as the queue backend.
|
|
28
|
-
* Implements FIFO via Redis Lists (LPUSH/RPOP).
|
|
29
|
-
*
|
|
30
|
-
* Requires `ioredis` or `redis`.
|
|
31
|
-
*
|
|
32
|
-
* @example
|
|
33
|
-
* ```typescript
|
|
34
|
-
* import Redis from 'ioredis'
|
|
35
|
-
*
|
|
36
|
-
* const redis = new Redis('redis://localhost:6379')
|
|
37
|
-
* const driver = new RedisDriver({ client: redis })
|
|
38
|
-
*
|
|
39
|
-
* await driver.push('default', serializedJob)
|
|
40
|
-
* ```
|
|
41
|
-
*/
|
|
42
|
-
export declare class RedisDriver implements QueueDriver {
|
|
43
|
-
private prefix;
|
|
44
|
-
private client;
|
|
45
|
-
constructor(config: RedisDriverConfig);
|
|
46
|
-
/**
|
|
47
|
-
* Get full Redis key for a queue.
|
|
48
|
-
*/
|
|
49
|
-
private getKey;
|
|
50
|
-
/**
|
|
51
|
-
* Push a job (LPUSH).
|
|
52
|
-
*/
|
|
53
|
-
push(queue: string, job: SerializedJob): Promise<void>;
|
|
54
|
-
/**
|
|
55
|
-
* Pop a job (RPOP, FIFO).
|
|
56
|
-
*/
|
|
57
|
-
pop(queue: string): Promise<SerializedJob | null>;
|
|
58
|
-
/**
|
|
59
|
-
* Parse Redis payload.
|
|
60
|
-
*/
|
|
61
|
-
private parsePayload;
|
|
62
|
-
/**
|
|
63
|
-
* Get queue size.
|
|
64
|
-
*/
|
|
65
|
-
size(queue: string): Promise<number>;
|
|
66
|
-
/**
|
|
67
|
-
* Clear a queue.
|
|
68
|
-
*/
|
|
69
|
-
clear(queue: string): Promise<void>;
|
|
70
|
-
/**
|
|
71
|
-
* Push multiple jobs.
|
|
72
|
-
*/
|
|
73
|
-
pushMany(queue: string, jobs: SerializedJob[]): Promise<void>;
|
|
74
|
-
/**
|
|
75
|
-
* Pop multiple jobs.
|
|
76
|
-
*/
|
|
77
|
-
popMany(queue: string, count: number): Promise<SerializedJob[]>;
|
|
78
|
-
}
|
|
79
|
-
//# sourceMappingURL=RedisDriver.d.ts.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"RedisDriver.d.ts","sourceRoot":"","sources":["../../src/drivers/RedisDriver.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,aAAa,EAAE,MAAM,UAAU,CAAA;AAC7C,OAAO,KAAK,EAAE,WAAW,EAAE,MAAM,eAAe,CAAA;AAEhD;;GAEG;AACH,MAAM,WAAW,iBAAiB;IAChC;;OAEG;IACH,MAAM,EAAE;QACN,KAAK,EAAE,CAAC,GAAG,EAAE,MAAM,EAAE,GAAG,MAAM,EAAE,MAAM,EAAE,KAAK,OAAO,CAAC,MAAM,CAAC,CAAA;QAC5D,IAAI,EAAE,CAAC,GAAG,EAAE,MAAM,KAAK,OAAO,CAAC,MAAM,GAAG,IAAI,CAAC,CAAA;QAC7C,IAAI,EAAE,CAAC,GAAG,EAAE,MAAM,KAAK,OAAO,CAAC,MAAM,CAAC,CAAA;QACtC,GAAG,EAAE,CAAC,GAAG,EAAE,MAAM,KAAK,OAAO,CAAC,MAAM,CAAC,CAAA;QACrC,MAAM,CAAC,EAAE,CAAC,GAAG,EAAE,MAAM,EAAE,GAAG,MAAM,EAAE,MAAM,EAAE,KAAK,OAAO,CAAC,MAAM,CAAC,CAAA;QAC9D,SAAS,CAAC,EAAE,CAAC,GAAG,EAAE,MAAM,EAAE,GAAG,EAAE,MAAM,KAAK,OAAO,CAAC,MAAM,GAAG,IAAI,CAAC,CAAA;QAChE,CAAC,GAAG,EAAE,MAAM,GAAG,OAAO,CAAA;KACvB,CAAA;IAED;;OAEG;IACH,MAAM,CAAC,EAAE,MAAM,CAAA;CAChB;AAED;;;;;;;;;;;;;;;;;GAiBG;AACH,qBAAa,WAAY,YAAW,WAAW;IAC7C,OAAO,CAAC,MAAM,CAAQ;IACtB,OAAO,CAAC,MAAM,CAA6B;gBAE/B,MAAM,EAAE,iBAAiB;IAWrC;;OAEG;IACH,OAAO,CAAC,MAAM;IAId;;OAEG;IACG,IAAI,CAAC,KAAK,EAAE,MAAM,EAAE,GAAG,EAAE,aAAa,GAAG,OAAO,CAAC,IAAI,CAAC;IA6B5D;;OAEG;IACG,GAAG,CAAC,KAAK,EAAE,MAAM,GAAG,OAAO,CAAC,aAAa,GAAG,IAAI,CAAC;IA4BvD;;OAEG;IACH,OAAO,CAAC,YAAY;IAcpB;;OAEG;IACG,IAAI,CAAC,KAAK,EAAE,MAAM,GAAG,OAAO,CAAC,MAAM,CAAC;IAK1C;;OAEG;IACG,KAAK,CAAC,KAAK,EAAE,MAAM,GAAG,OAAO,CAAC,IAAI,CAAC;IASzC;;OAEG;IACG,QAAQ,CAAC,KAAK,EAAE,MAAM,EAAE,IAAI,EAAE,aAAa,EAAE,GAAG,OAAO,CAAC,IAAI,CAAC;IAsBnE;;OAEG;IACG,OAAO,CAAC,KAAK,EAAE,MAAM,EAAE,KAAK,EAAE,MAAM,GAAG,OAAO,CAAC,aAAa,EAAE,CAAC;CAetE"}
|
|
@@ -1,100 +0,0 @@
|
|
|
1
|
-
import type { SerializedJob } from '../types';
|
|
2
|
-
import type { QueueDriver } from './QueueDriver';
|
|
3
|
-
/**
|
|
4
|
-
* SQS driver configuration.
|
|
5
|
-
*/
|
|
6
|
-
export interface SQSDriverConfig {
|
|
7
|
-
/**
|
|
8
|
-
* SQS client instance (`@aws-sdk/client-sqs`).
|
|
9
|
-
*/
|
|
10
|
-
client: {
|
|
11
|
-
send: (command: unknown) => Promise<{
|
|
12
|
-
MessageId?: string;
|
|
13
|
-
Messages?: Array<{
|
|
14
|
-
MessageId?: string;
|
|
15
|
-
ReceiptHandle?: string;
|
|
16
|
-
Body?: string;
|
|
17
|
-
}>;
|
|
18
|
-
}>;
|
|
19
|
-
};
|
|
20
|
-
/**
|
|
21
|
-
* Queue URL prefix (used to build full queue URLs).
|
|
22
|
-
*/
|
|
23
|
-
queueUrlPrefix?: string;
|
|
24
|
-
/**
|
|
25
|
-
* Visibility timeout (seconds, default: 30).
|
|
26
|
-
*/
|
|
27
|
-
visibilityTimeout?: number;
|
|
28
|
-
/**
|
|
29
|
-
* Long-polling duration (seconds, default: 20).
|
|
30
|
-
*/
|
|
31
|
-
waitTimeSeconds?: number;
|
|
32
|
-
}
|
|
33
|
-
/**
|
|
34
|
-
* SQS Driver
|
|
35
|
-
*
|
|
36
|
-
* Uses AWS SQS as the queue backend.
|
|
37
|
-
* Supports standard/FIFO queues, long polling, DLQ setups, etc.
|
|
38
|
-
*
|
|
39
|
-
* Requires `@aws-sdk/client-sqs`.
|
|
40
|
-
*
|
|
41
|
-
* @example
|
|
42
|
-
* ```typescript
|
|
43
|
-
* import { SQSClient } from '@aws-sdk/client-sqs'
|
|
44
|
-
*
|
|
45
|
-
* const sqs = new SQSClient({
|
|
46
|
-
* region: 'us-east-1',
|
|
47
|
-
* credentials: {
|
|
48
|
-
* accessKeyId: process.env.AWS_ACCESS_KEY_ID!,
|
|
49
|
-
* secretAccessKey: process.env.AWS_SECRET_ACCESS_KEY!,
|
|
50
|
-
* }
|
|
51
|
-
* })
|
|
52
|
-
*
|
|
53
|
-
* const driver = new SQSDriver({ client: sqs })
|
|
54
|
-
* await driver.push('default', serializedJob)
|
|
55
|
-
* ```
|
|
56
|
-
*/
|
|
57
|
-
export declare class SQSDriver implements QueueDriver {
|
|
58
|
-
private client;
|
|
59
|
-
private queueUrlPrefix;
|
|
60
|
-
private visibilityTimeout;
|
|
61
|
-
private waitTimeSeconds;
|
|
62
|
-
private queueUrls;
|
|
63
|
-
constructor(config: SQSDriverConfig);
|
|
64
|
-
/**
|
|
65
|
-
* Resolve the full queue URL.
|
|
66
|
-
*/
|
|
67
|
-
private getQueueUrl;
|
|
68
|
-
/**
|
|
69
|
-
* Push a job to SQS.
|
|
70
|
-
*/
|
|
71
|
-
push(queue: string, job: SerializedJob): Promise<void>;
|
|
72
|
-
/**
|
|
73
|
-
* Pop a job (long polling).
|
|
74
|
-
*/
|
|
75
|
-
pop(queue: string): Promise<SerializedJob | null>;
|
|
76
|
-
/**
|
|
77
|
-
* Get queue size (approximate).
|
|
78
|
-
*/
|
|
79
|
-
size(queue: string): Promise<number>;
|
|
80
|
-
/**
|
|
81
|
-
* Clear a queue by receiving and deleting messages.
|
|
82
|
-
*
|
|
83
|
-
* Note: SQS does not provide a direct "purge" API via this wrapper. This method will
|
|
84
|
-
* keep receiving and deleting messages until the queue is empty.
|
|
85
|
-
*/
|
|
86
|
-
clear(queue: string): Promise<void>;
|
|
87
|
-
/**
|
|
88
|
-
* Push multiple jobs.
|
|
89
|
-
*/
|
|
90
|
-
pushMany(queue: string, jobs: SerializedJob[]): Promise<void>;
|
|
91
|
-
/**
|
|
92
|
-
* Acknowledge is not supported via messageId.
|
|
93
|
-
*/
|
|
94
|
-
acknowledge(_messageId: string): Promise<void>;
|
|
95
|
-
/**
|
|
96
|
-
* Delete a message (acknowledge processing completion).
|
|
97
|
-
*/
|
|
98
|
-
deleteMessage(queue: string, receiptHandle: string): Promise<void>;
|
|
99
|
-
}
|
|
100
|
-
//# sourceMappingURL=SQSDriver.d.ts.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"SQSDriver.d.ts","sourceRoot":"","sources":["../../src/drivers/SQSDriver.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,aAAa,EAAE,MAAM,UAAU,CAAA;AAC7C,OAAO,KAAK,EAAE,WAAW,EAAE,MAAM,eAAe,CAAA;AAEhD;;GAEG;AACH,MAAM,WAAW,eAAe;IAC9B;;OAEG;IACH,MAAM,EAAE;QACN,IAAI,EAAE,CAAC,OAAO,EAAE,OAAO,KAAK,OAAO,CAAC;YAClC,SAAS,CAAC,EAAE,MAAM,CAAA;YAClB,QAAQ,CAAC,EAAE,KAAK,CAAC;gBACf,SAAS,CAAC,EAAE,MAAM,CAAA;gBAClB,aAAa,CAAC,EAAE,MAAM,CAAA;gBACtB,IAAI,CAAC,EAAE,MAAM,CAAA;aACd,CAAC,CAAA;SACH,CAAC,CAAA;KACH,CAAA;IAED;;OAEG;IACH,cAAc,CAAC,EAAE,MAAM,CAAA;IAEvB;;OAEG;IACH,iBAAiB,CAAC,EAAE,MAAM,CAAA;IAE1B;;OAEG;IACH,eAAe,CAAC,EAAE,MAAM,CAAA;CACzB;AAED;;;;;;;;;;;;;;;;;;;;;;;GAuBG;AACH,qBAAa,SAAU,YAAW,WAAW;IAC3C,OAAO,CAAC,MAAM,CAA2B;IACzC,OAAO,CAAC,cAAc,CAAQ;IAC9B,OAAO,CAAC,iBAAiB,CAAQ;IACjC,OAAO,CAAC,eAAe,CAAQ;IAC/B,OAAO,CAAC,SAAS,CAA4B;gBAEjC,MAAM,EAAE,eAAe;IAanC;;OAEG;YACW,WAAW;IAiBzB;;OAEG;IACG,IAAI,CAAC,KAAK,EAAE,MAAM,EAAE,GAAG,EAAE,aAAa,GAAG,OAAO,CAAC,IAAI,CAAC;IA0B5D;;OAEG;IACG,GAAG,CAAC,KAAK,EAAE,MAAM,GAAG,OAAO,CAAC,aAAa,GAAG,IAAI,CAAC;IAkCvD;;OAEG;IACG,IAAI,CAAC,KAAK,EAAE,MAAM,GAAG,OAAO,CAAC,MAAM,CAAC;IAmB1C;;;;;OAKG;IACG,KAAK,CAAC,KAAK,EAAE,MAAM,GAAG,OAAO,CAAC,IAAI,CAAC;IAuBzC;;OAEG;IACG,QAAQ,CAAC,KAAK,EAAE,MAAM,EAAE,IAAI,EAAE,aAAa,EAAE,GAAG,OAAO,CAAC,IAAI,CAAC;IAwCnE;;OAEG;IACG,WAAW,CAAC,UAAU,EAAE,MAAM,GAAG,OAAO,CAAC,IAAI,CAAC;IAKpD;;OAEG;IACG,aAAa,CAAC,KAAK,EAAE,MAAM,EAAE,aAAa,EAAE,MAAM,GAAG,OAAO,CAAC,IAAI,CAAC;CAWzE"}
|