forked from cloudflare/miniflare
-
Notifications
You must be signed in to change notification settings - Fork 0
/
queues.ts
51 lines (40 loc) 路 1.21 KB
/
queues.ts
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
// Internal types:
export const kGetConsumer = Symbol("kGetConsumer");
export const kSetConsumer = Symbol("kSetConsumer");
export type QueueEventDispatcher = (batch: MessageBatch) => Promise<void>;
export interface QueueBroker {
getOrCreateQueue(name: string): Queue;
setConsumer(queue: Queue, consumer: Consumer): void;
}
export interface Consumer {
queueName: string;
maxBatchSize: number;
maxWaitMs: number;
maxRetries: number;
deadLetterQueue?: string;
dispatcher: QueueEventDispatcher;
}
// External types (exposed to user code):
export type MessageSendOptions = {
// Reserved
};
export type MessageSendRequest<Body = unknown> = {
body: Body;
} & MessageSendOptions;
export interface Queue<Body = unknown> {
send(message: Body, options?: MessageSendOptions): Promise<void>;
sendBatch(batch: Iterable<MessageSendRequest<Body>>): Promise<void>;
[kSetConsumer](consumer: Consumer): void;
[kGetConsumer](): Consumer | null;
}
export interface Message<Body = unknown> {
readonly id: string;
readonly timestamp: Date;
readonly body: Body;
retry(): void;
}
export interface MessageBatch<Body = unknown> {
readonly queue: string;
readonly messages: Message<Body>[];
retryAll(): void;
}