|
1 | | -import type { KVNamespace } from "@cloudflare/workers-types/experimental"; |
| 1 | +/** |
| 2 | + * `KvStore` & `MessageQueue` adapters for Cloudflare Workers |
| 3 | + * ========================================================== |
| 4 | + * |
| 5 | + * This module provides `KvStore` and `MessageQueue` implementations that use |
| 6 | + * Cloudflare Workers' KV and Queues bindings, respectively. |
| 7 | + * |
| 8 | + * @module |
| 9 | + * @since 1.6.0 |
| 10 | + */ |
| 11 | +import type { |
| 12 | + KVNamespace, |
| 13 | + MessageSendRequest, |
| 14 | + Queue, |
| 15 | +} from "@cloudflare/workers-types/experimental"; |
2 | 16 | import type { KvKey, KvStore, KvStoreSetOptions } from "../federation/kv.ts"; |
| 17 | +import type { |
| 18 | + MessageQueue, |
| 19 | + MessageQueueEnqueueOptions, |
| 20 | + MessageQueueListenOptions, |
| 21 | +} from "../federation/mq.ts"; |
3 | 22 |
|
4 | 23 | interface KvMetadata { |
5 | 24 | expires?: number; |
6 | 25 | } |
7 | 26 |
|
8 | 27 | /** |
9 | | - * Implementation of the KvStore interface for Cloudflare Workers KV binding. |
10 | | - * This class provides a wrapper around Cloudflare's KV namespace to store and |
11 | | - * retrieve JSON-serializable values using structured keys. |
| 28 | + * Implementation of the {@link KvStore} interface for Cloudflare Workers KV |
| 29 | + * binding. This class provides a wrapper around Cloudflare's KV namespace to |
| 30 | + * store and retrieve JSON-serializable values using structured keys. |
12 | 31 | * @since 1.6.0 |
13 | 32 | */ |
14 | 33 | export class WorkersKvStore implements KvStore { |
@@ -58,3 +77,56 @@ export class WorkersKvStore implements KvStore { |
58 | 77 | return this.#namespace.delete(this.#encodeKey(key)); |
59 | 78 | } |
60 | 79 | } |
| 80 | + |
| 81 | +/** |
| 82 | + * Implementation of the {@link MessageQueue} interface for Cloudflare |
| 83 | + * Workers Queues binding. This class provides a wrapper around Cloudflare's |
| 84 | + * Queues to send messages to a queue. |
| 85 | + * |
| 86 | + * Note that this implementation does not support the `listen()` method, |
| 87 | + * as Cloudflare Workers Queues do not support message consumption in the same |
| 88 | + * way as other message queue systems. Instead, you should use |
| 89 | + * the {@link Federation.processQueuedTask} method to process messages |
| 90 | + * passed to the queue. |
| 91 | + * @since 1.6.0 |
| 92 | + */ |
| 93 | +export class WorkersMessageQueue implements MessageQueue { |
| 94 | + #queue: Queue; |
| 95 | + |
| 96 | + constructor(queue: Queue) { |
| 97 | + this.#queue = queue; |
| 98 | + } |
| 99 | + |
| 100 | + // deno-lint-ignore no-explicit-any |
| 101 | + enqueue(message: any, options?: MessageQueueEnqueueOptions): Promise<void> { |
| 102 | + return this.#queue.send(message, { |
| 103 | + contentType: "json", |
| 104 | + delaySeconds: options?.delay?.total("seconds") ?? 0, |
| 105 | + }); |
| 106 | + } |
| 107 | + |
| 108 | + enqueueMany( |
| 109 | + // deno-lint-ignore no-explicit-any |
| 110 | + messages: any[], |
| 111 | + options?: MessageQueueEnqueueOptions, |
| 112 | + ): Promise<void> { |
| 113 | + const requests: MessageSendRequest[] = messages.map((msg) => ({ |
| 114 | + body: msg, |
| 115 | + contentType: "json", |
| 116 | + })); |
| 117 | + return this.#queue.sendBatch(requests, { |
| 118 | + delaySeconds: options?.delay?.total("seconds") ?? 0, |
| 119 | + }); |
| 120 | + } |
| 121 | + |
| 122 | + listen( |
| 123 | + // deno-lint-ignore no-explicit-any |
| 124 | + _handler: (message: any) => Promise<void> | void, |
| 125 | + _options?: MessageQueueListenOptions, |
| 126 | + ): Promise<void> { |
| 127 | + throw new TypeError( |
| 128 | + "WorkersMessageQueue does not support listen(). " + |
| 129 | + "Use Federation.processQueuedTask() method instead.", |
| 130 | + ); |
| 131 | + } |
| 132 | +} |
0 commit comments