@fedify/fedify 2.0.0-pr.412.1559 → 2.0.0-pr.412.1692
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/actor-CrTGiTZd.cjs +42609 -0
- package/dist/{actor-Cc6B76eG.js → actor-D5S46edz.js} +1 -1
- package/dist/actor-D6K058Tb.d.cts +128 -0
- package/dist/{actor-CTAuCsWy.js → actor-G2S5sPEA.js} +6951 -2127
- package/dist/{actor-C22bXuuC.d.ts → actor-T6RyhRgk.d.ts} +1 -1
- package/dist/{authdocloader-BFVqUbyo.js → authdocloader-C5AvdCCi.js} +6 -6
- package/dist/authdocloader-CQMPmpaO.cjs +58 -0
- package/dist/{authdocloader-CLgDGafZ.js → authdocloader-SjwloJUA.js} +3 -3
- package/dist/{builder-BOEBObR8.js → builder-OA47XRft.js} +10 -4
- package/dist/chunk-DqRYRqnO.cjs +34 -0
- package/dist/{client-De-z2UnN.js → client-Bmd-i8x8.js} +3 -22
- package/dist/client-CegPX0Rn.d.cts +222 -0
- package/dist/{client-DF8anIB5.d.ts → client-bgSdkFa2.d.ts} +2 -74
- package/dist/compat/mod.cjs +10 -0
- package/dist/compat/mod.d.cts +13 -0
- package/dist/compat/mod.d.ts +8 -8
- package/dist/compat/mod.js +5 -5
- package/dist/compat/transformers.test.js +19 -19
- package/dist/compat-DmDDELst.cjs +4 -0
- package/dist/compat-nxUqe4Z-.js +4 -0
- package/dist/{context-9gCpIkiz.d.ts → context-ByZprN0S.d.ts} +67 -7
- package/dist/context-C5BsZkDr.d.cts +2315 -0
- package/dist/docloader-7Ey7wNHx.cjs +4861 -0
- package/dist/{docloader-DEhniCVa.js → docloader-CkweNhUH.js} +189 -9
- package/dist/docloader-D-MrRyHl.d.cts +219 -0
- package/dist/{esm-CHdxdkuH.js → esm-CwHz8Y8t.js} +1 -1
- package/dist/federation/builder.test.js +6 -7
- package/dist/federation/collection.test.js +4 -4
- package/dist/federation/handler.test.js +23 -143
- package/dist/federation/idempotency.test.js +202 -0
- package/dist/federation/inbox.test.js +4 -4
- package/dist/federation/keycache.test.js +4 -4
- package/dist/federation/kv.test.js +4 -3
- package/dist/federation/middleware.test.js +231 -52
- package/dist/federation/mod.cjs +29 -0
- package/dist/federation/mod.d.cts +13 -0
- package/dist/federation/mod.d.ts +8 -8
- package/dist/federation/mod.js +15 -15
- package/dist/federation/mq.test.js +3 -3
- package/dist/federation/negotiation.test.d.ts +3 -0
- package/dist/federation/negotiation.test.js +28 -0
- package/dist/federation/retry.test.js +3 -3
- package/dist/federation/router.test.js +3 -3
- package/dist/federation/send.test.js +10 -10
- package/dist/{federation-CMX7WzeL.js → federation-D1U8YY9t.js} +3 -3
- package/dist/federation-H2_En3j5.cjs +244 -0
- package/dist/fixtures/media.example.com/avatars/test-avatar.jpg.json +6 -0
- package/dist/http-BiBofurJ.cjs +826 -0
- package/dist/{http-l0TEupZK.js → http-C5tC93Hn.js} +7 -7
- package/dist/http-D-e6AFwR.d.cts +253 -0
- package/dist/{http-DqSNLFNY.d.ts → http-D6Uj2x2y.d.ts} +1 -1
- package/dist/{http-CcdM1brU.js → http-DGjdMiLc.js} +3 -3
- package/dist/{inbox-B6DZbGNf.js → inbox-BoDY3z8G.js} +24 -7
- package/dist/key-CZR7QraT.cjs +290 -0
- package/dist/key-Cf8MffVe.cjs +10 -0
- package/dist/{key-DxA6xRtZ.js → key-CkxrAIyp.js} +5 -5
- package/dist/key-Dk0j88Jo.js +10 -0
- package/dist/{key-CUZQgVlf.js → key-Epcl5jpz.js} +3 -3
- package/dist/{key-CzLv1phF.js → key-IxRhZpOF.js} +2 -2
- package/dist/{keycache-B8HdZJSt.js → keycache-TEniXNel.js} +1 -1
- package/dist/{keys-zZwiKkfx.js → keys-bZxcrZ9Z.js} +1 -1
- package/dist/kv-63Cil1MD.d.cts +81 -0
- package/dist/{ld-CBcQdZ6N.js → ld-DW7A0uIc.js} +4 -4
- package/dist/{lookup-Bn_HEC_d.js → lookup-DhQCVVja.js} +21 -12
- package/dist/lookup-DiV4LFBg.cjs +137 -0
- package/dist/{lookup-dtdr2ftf.js → lookup-cVRa2QM-.js} +4 -4
- package/dist/middleware-Be1JStOx.js +17 -0
- package/dist/middleware-CDOK7WOb.js +26 -0
- package/dist/{middleware-BRgu1IH8.js → middleware-Cgr3PtaJ.js} +58 -149
- package/dist/{middleware-CxEkcFW0.js → middleware-DvvYAIsd.js} +87 -91
- package/dist/middleware-EjIW2mZB.cjs +17 -0
- package/dist/middleware-TfuVoceY.cjs +4231 -0
- package/dist/mod-8DMWKtQE.d.cts +80 -0
- package/dist/{mod-Drmz72EK.d.ts → mod-BhUKmBJD.d.ts} +2 -2
- package/dist/mod-C2tOeRkN.d.cts +1 -0
- package/dist/{mod-TFoH2Ql8.d.ts → mod-CerN_Sza.d.ts} +1 -1
- package/dist/mod-Cj1tHXBR.d.cts +102 -0
- package/dist/mod-CxkWO3Mg.d.cts +307 -0
- package/dist/{mod-Bqxcp7eN.d.ts → mod-D6hQoxC5.d.ts} +2 -2
- package/dist/mod-Djzcw2ry.d.cts +266 -0
- package/dist/{mod-Cxt4Kpf6.d.ts → mod-DlU8ISoa.d.ts} +19 -1
- package/dist/mod-FZd39qVq.d.cts +1 -0
- package/dist/mod-jQ4OODsl.d.cts +113 -0
- package/dist/mod.cjs +150 -0
- package/dist/mod.d.cts +17 -0
- package/dist/mod.d.ts +11 -11
- package/dist/mod.js +21 -21
- package/dist/mq-B7R1Q-M5.d.cts +140 -0
- package/dist/negotiation-5NPJL6zp.js +71 -0
- package/dist/nodeinfo/client.test.js +27 -106
- package/dist/nodeinfo/handler.test.js +20 -20
- package/dist/nodeinfo/mod.cjs +11 -0
- package/dist/nodeinfo/mod.d.cts +5 -0
- package/dist/nodeinfo/mod.d.ts +2 -2
- package/dist/nodeinfo/mod.js +7 -7
- package/dist/nodeinfo/types.test.js +5 -10
- package/dist/nodeinfo-Co9lJrWl.cjs +4 -0
- package/dist/nodeinfo-DfycQ8Wf.js +4 -0
- package/dist/{owner-VEIjmR8r.js → owner-6Vc3UXXE.js} +2 -2
- package/dist/owner-BN_tO3cY.d.cts +67 -0
- package/dist/{owner-CQPnQVtf.d.ts → owner-hd9lvQcP.d.ts} +2 -2
- package/dist/{proof-DoSQAGkE.js → proof-C1jhbeNv.js} +3 -3
- package/dist/proof-CRJWXFfT.cjs +673 -0
- package/dist/{proof-tgUlT8hw.js → proof-Chi90OXv.js} +9 -9
- package/dist/runtime/authdocloader.test.js +9 -9
- package/dist/runtime/docloader.test.js +4 -4
- package/dist/runtime/key.test.js +5 -5
- package/dist/runtime/langstr.test.js +3 -3
- package/dist/runtime/link.test.d.ts +3 -0
- package/dist/runtime/link.test.js +61 -0
- package/dist/runtime/mod.cjs +25 -0
- package/dist/runtime/mod.d.cts +6 -0
- package/dist/runtime/mod.d.ts +3 -3
- package/dist/runtime/mod.js +10 -10
- package/dist/runtime/multibase/multibase.test.js +3 -3
- package/dist/runtime/url.test.js +3 -3
- package/dist/runtime-C58AJWSv.cjs +4 -0
- package/dist/runtime-DPYEDf-o.js +4 -0
- package/dist/{send-BzS7w-QF.js → send-DjATl6i3.js} +2 -2
- package/dist/sig/http.test.js +9 -9
- package/dist/sig/key.test.js +6 -6
- package/dist/sig/ld.test.js +7 -7
- package/dist/sig/mod.cjs +30 -0
- package/dist/sig/mod.d.cts +8 -0
- package/dist/sig/mod.d.ts +5 -5
- package/dist/sig/mod.js +10 -10
- package/dist/sig/owner.test.js +7 -7
- package/dist/sig/proof.test.js +7 -7
- package/dist/sig-ByHXzqUi.cjs +4 -0
- package/dist/sig-Cj3tk-ig.js +4 -0
- package/dist/testing/docloader.test.js +3 -3
- package/dist/testing/mod.d.ts +273 -28
- package/dist/testing/mod.js +3 -3
- package/dist/{testing-Z2omCvKy.js → testing-BnfPB5T-.js} +2 -2
- package/dist/{transformers-Dna8Fg7k.js → transformers-BFT6d7J5.js} +3 -3
- package/dist/transformers-CoBS-oFG.cjs +116 -0
- package/dist/{type-SK-d7Tbw.js → type-NEA09tSC.js} +7262 -2258
- package/dist/{types-BIgY6c-l.js → types-BSuWJsOm.js} +1 -3
- package/dist/types-CmmUQisS.cjs +315 -0
- package/dist/{types-DgPvoUWN.js → types-dLXLjVLf.js} +8 -169
- package/dist/vocab/actor.test.js +5 -5
- package/dist/vocab/lookup.test.js +255 -5
- package/dist/vocab/mod.cjs +87 -0
- package/dist/vocab/mod.d.cts +6 -0
- package/dist/vocab/mod.d.ts +3 -3
- package/dist/vocab/mod.js +7 -7
- package/dist/vocab/type.test.js +3 -3
- package/dist/vocab/vocab.test.js +433 -9
- package/dist/{vocab-SOE1ifCr.d.ts → vocab-BI0Ak5lL.d.ts} +290 -0
- package/dist/vocab-C5Y-0fGj.cjs +291 -0
- package/dist/vocab-Dw1-yVGg.d.cts +14922 -0
- package/dist/{vocab-CvD6Vbml.js → vocab-rWbHpc2J.js} +26 -17
- package/dist/webfinger/handler.test.js +19 -19
- package/dist/webfinger/lookup.test.js +4 -4
- package/dist/webfinger/mod.cjs +9 -0
- package/dist/webfinger/mod.d.cts +4 -0
- package/dist/webfinger/mod.js +6 -6
- package/dist/webfinger-BjOEdFPs.cjs +4 -0
- package/dist/webfinger-De_bU0iE.js +4 -0
- package/dist/x/cfworkers.cjs +100 -0
- package/dist/x/cfworkers.d.cts +59 -0
- package/dist/x/cfworkers.js +3 -3
- package/dist/x/cfworkers.test.js +3 -3
- package/dist/x/hono.cjs +61 -0
- package/dist/x/hono.d.cts +54 -0
- package/dist/x/hono.d.ts +7 -7
- package/dist/x/hono.js +3 -3
- package/dist/x/sveltekit.cjs +69 -0
- package/dist/x/sveltekit.d.cts +46 -0
- package/dist/x/sveltekit.d.ts +7 -7
- package/dist/x/sveltekit.js +3 -3
- package/package.json +68 -13
- package/dist/compat-Bb5myD13.js +0 -4
- package/dist/key-Deb0_wWL.js +0 -10
- package/dist/middleware-BE_geSiJ.js +0 -17
- package/dist/middleware-BnU6hzVp.js +0 -26
- package/dist/nodeinfo/semver.test.js +0 -143
- package/dist/nodeinfo-CyEbLjHs.js +0 -4
- package/dist/runtime-BSkOVUWM.js +0 -4
- package/dist/semver-dArNLkR9.js +0 -149
- package/dist/sig-BXJO--F9.js +0 -4
- package/dist/webfinger-C3GIyXIg.js +0 -4
- /package/dist/{collection-CSzG2j1P.js → collection-CcnIw1qY.js} +0 -0
- /package/dist/{nodeinfo/semver.test.d.ts → federation/idempotency.test.d.ts} +0 -0
@@ -3,24 +3,24 @@
|
|
3
3
|
import { URLPattern } from "urlpattern-polyfill";
|
4
4
|
globalThis.addEventListener = () => {};
|
5
5
|
|
6
|
-
import { Activity, Application, Endpoints, Group, Person, Service } from "../type-
|
6
|
+
import { Activity, Application, Endpoints, Group, Person, Service } from "../type-NEA09tSC.js";
|
7
7
|
import { assertEquals } from "../assert_equals-DSbWqCm3.js";
|
8
8
|
import { assert } from "../assert-MZs1qjMx.js";
|
9
9
|
import "../assert_instance_of-DHz7EHNU.js";
|
10
|
-
import "../lookup-
|
11
|
-
import "../actor-
|
12
|
-
import "../key-
|
13
|
-
import { verifyRequest } from "../http-
|
14
|
-
import { doesActorOwnKey } from "../owner-
|
15
|
-
import { extractInboxes, sendActivity } from "../send-
|
16
|
-
import { mockDocumentLoader, test } from "../testing-
|
10
|
+
import "../lookup-DhQCVVja.js";
|
11
|
+
import "../actor-D5S46edz.js";
|
12
|
+
import "../key-IxRhZpOF.js";
|
13
|
+
import { verifyRequest } from "../http-DGjdMiLc.js";
|
14
|
+
import { doesActorOwnKey } from "../owner-6Vc3UXXE.js";
|
15
|
+
import { extractInboxes, sendActivity } from "../send-DjATl6i3.js";
|
16
|
+
import { mockDocumentLoader, test } from "../testing-BnfPB5T-.js";
|
17
17
|
import "../std__assert-X-_kMxKM.js";
|
18
18
|
import { assertFalse, assertRejects } from "../assert_rejects-DiIiJbZn.js";
|
19
19
|
import "../assert_is_error-BPGph1Jx.js";
|
20
20
|
import { assertNotEquals } from "../assert_not_equals-f3m3epl3.js";
|
21
21
|
import "../assert_throws-BOO88avQ.js";
|
22
|
-
import { ed25519Multikey, ed25519PrivateKey, rsaPrivateKey2, rsaPublicKey2 } from "../keys-
|
23
|
-
import { esm_default } from "../esm-
|
22
|
+
import { ed25519Multikey, ed25519PrivateKey, rsaPrivateKey2, rsaPublicKey2 } from "../keys-bZxcrZ9Z.js";
|
23
|
+
import { esm_default } from "../esm-CwHz8Y8t.js";
|
24
24
|
|
25
25
|
//#region src/federation/send.test.ts
|
26
26
|
test("extractInboxes()", () => {
|
@@ -1,7 +1,7 @@
|
|
1
1
|
|
2
|
-
|
3
|
-
|
4
|
-
|
2
|
+
import { Temporal } from "@js-temporal/polyfill";
|
3
|
+
import { URLPattern } from "urlpattern-polyfill";
|
4
|
+
|
5
5
|
import { isEqual } from "es-toolkit";
|
6
6
|
|
7
7
|
//#region src/federation/kv.ts
|
@@ -0,0 +1,244 @@
|
|
1
|
+
|
2
|
+
const { Temporal } = require("@js-temporal/polyfill");
|
3
|
+
const { URLPattern } = require("urlpattern-polyfill");
|
4
|
+
|
5
|
+
const require_chunk = require('./chunk-DqRYRqnO.cjs');
|
6
|
+
const es_toolkit = require_chunk.__toESM(require("es-toolkit"));
|
7
|
+
|
8
|
+
//#region src/federation/kv.ts
|
9
|
+
/**
|
10
|
+
* A key–value store that stores values in memory.
|
11
|
+
* Do not use this in production as it does not persist values.
|
12
|
+
*
|
13
|
+
* @since 0.5.0
|
14
|
+
*/
|
15
|
+
var MemoryKvStore = class {
|
16
|
+
#values = {};
|
17
|
+
#encodeKey(key) {
|
18
|
+
return JSON.stringify(key);
|
19
|
+
}
|
20
|
+
/**
|
21
|
+
* {@inheritDoc KvStore.get}
|
22
|
+
*/
|
23
|
+
get(key) {
|
24
|
+
const encodedKey = this.#encodeKey(key);
|
25
|
+
const entry = this.#values[encodedKey];
|
26
|
+
if (entry == null) return Promise.resolve(void 0);
|
27
|
+
const [value, expiration] = entry;
|
28
|
+
if (expiration != null && Temporal.Now.instant().until(expiration).sign < 0) {
|
29
|
+
delete this.#values[encodedKey];
|
30
|
+
return Promise.resolve(void 0);
|
31
|
+
}
|
32
|
+
return Promise.resolve(value);
|
33
|
+
}
|
34
|
+
/**
|
35
|
+
* {@inheritDoc KvStore.set}
|
36
|
+
*/
|
37
|
+
set(key, value, options) {
|
38
|
+
const encodedKey = this.#encodeKey(key);
|
39
|
+
const expiration = options?.ttl == null ? null : Temporal.Now.instant().add(options.ttl.round({ largestUnit: "hour" }));
|
40
|
+
this.#values[encodedKey] = [value, expiration];
|
41
|
+
return Promise.resolve();
|
42
|
+
}
|
43
|
+
/**
|
44
|
+
* {@inheritDoc KvStore.delete}
|
45
|
+
*/
|
46
|
+
delete(key) {
|
47
|
+
const encodedKey = this.#encodeKey(key);
|
48
|
+
delete this.#values[encodedKey];
|
49
|
+
return Promise.resolve();
|
50
|
+
}
|
51
|
+
/**
|
52
|
+
* {@inheritDoc KvStore.cas}
|
53
|
+
*/
|
54
|
+
cas(key, expectedValue, newValue, options) {
|
55
|
+
const encodedKey = this.#encodeKey(key);
|
56
|
+
const entry = this.#values[encodedKey];
|
57
|
+
let currentValue;
|
58
|
+
if (entry == null) currentValue = void 0;
|
59
|
+
else {
|
60
|
+
const [value, expiration$1] = entry;
|
61
|
+
if (expiration$1 != null && Temporal.Now.instant().until(expiration$1).sign < 0) {
|
62
|
+
delete this.#values[encodedKey];
|
63
|
+
currentValue = void 0;
|
64
|
+
} else currentValue = value;
|
65
|
+
}
|
66
|
+
if (!(0, es_toolkit.isEqual)(currentValue, expectedValue)) return Promise.resolve(false);
|
67
|
+
const expiration = options?.ttl == null ? null : Temporal.Now.instant().add(options.ttl.round({ largestUnit: "hour" }));
|
68
|
+
this.#values[encodedKey] = [newValue, expiration];
|
69
|
+
return Promise.resolve(true);
|
70
|
+
}
|
71
|
+
};
|
72
|
+
|
73
|
+
//#endregion
|
74
|
+
//#region src/federation/mq.ts
|
75
|
+
/**
|
76
|
+
* A message queue that processes messages in the same process.
|
77
|
+
* Do not use this in production as it does neither persist messages nor
|
78
|
+
* distribute them across multiple processes.
|
79
|
+
*
|
80
|
+
* @since 0.5.0
|
81
|
+
*/
|
82
|
+
var InProcessMessageQueue = class {
|
83
|
+
#messages;
|
84
|
+
#monitors;
|
85
|
+
#pollIntervalMs;
|
86
|
+
/**
|
87
|
+
* In-process message queue does not provide native retry mechanisms.
|
88
|
+
* @since 1.7.0
|
89
|
+
*/
|
90
|
+
nativeRetrial = false;
|
91
|
+
/**
|
92
|
+
* Constructs a new {@link InProcessMessageQueue} with the given options.
|
93
|
+
* @param options Additional options for the in-process message queue.
|
94
|
+
*/
|
95
|
+
constructor(options = {}) {
|
96
|
+
this.#messages = [];
|
97
|
+
this.#monitors = {};
|
98
|
+
this.#pollIntervalMs = Temporal.Duration.from(options.pollInterval ?? { seconds: 5 }).total("millisecond");
|
99
|
+
}
|
100
|
+
enqueue(message, options) {
|
101
|
+
const delay = options?.delay == null ? 0 : Math.max(options.delay.total("millisecond"), 0);
|
102
|
+
if (delay > 0) {
|
103
|
+
setTimeout(() => this.enqueue(message, {
|
104
|
+
...options,
|
105
|
+
delay: void 0
|
106
|
+
}), delay);
|
107
|
+
return Promise.resolve();
|
108
|
+
}
|
109
|
+
this.#messages.push(message);
|
110
|
+
for (const monitorId in this.#monitors) this.#monitors[monitorId]();
|
111
|
+
return Promise.resolve();
|
112
|
+
}
|
113
|
+
enqueueMany(messages, options) {
|
114
|
+
if (messages.length === 0) return Promise.resolve();
|
115
|
+
const delay = options?.delay == null ? 0 : Math.max(options.delay.total("millisecond"), 0);
|
116
|
+
if (delay > 0) {
|
117
|
+
setTimeout(() => this.enqueueMany(messages, {
|
118
|
+
...options,
|
119
|
+
delay: void 0
|
120
|
+
}), delay);
|
121
|
+
return Promise.resolve();
|
122
|
+
}
|
123
|
+
this.#messages.push(...messages);
|
124
|
+
for (const monitorId in this.#monitors) this.#monitors[monitorId]();
|
125
|
+
return Promise.resolve();
|
126
|
+
}
|
127
|
+
async listen(handler, options = {}) {
|
128
|
+
const signal = options.signal;
|
129
|
+
while (signal == null || !signal.aborted) {
|
130
|
+
while (this.#messages.length > 0) {
|
131
|
+
const message = this.#messages.shift();
|
132
|
+
await handler(message);
|
133
|
+
}
|
134
|
+
await this.#wait(this.#pollIntervalMs, signal);
|
135
|
+
}
|
136
|
+
}
|
137
|
+
#wait(ms, signal) {
|
138
|
+
let timer = null;
|
139
|
+
return Promise.any([new Promise((resolve) => {
|
140
|
+
signal?.addEventListener("abort", () => {
|
141
|
+
if (timer != null) clearTimeout(timer);
|
142
|
+
resolve();
|
143
|
+
}, { once: true });
|
144
|
+
const monitorId = crypto.randomUUID();
|
145
|
+
this.#monitors[monitorId] = () => {
|
146
|
+
delete this.#monitors[monitorId];
|
147
|
+
if (timer != null) clearTimeout(timer);
|
148
|
+
resolve();
|
149
|
+
};
|
150
|
+
}), new Promise((resolve) => timer = setTimeout(resolve, ms))]);
|
151
|
+
}
|
152
|
+
};
|
153
|
+
/**
|
154
|
+
* A message queue that processes messages in parallel. It takes another
|
155
|
+
* {@link MessageQueue}, and processes messages in parallel up to a certain
|
156
|
+
* number of workers.
|
157
|
+
*
|
158
|
+
* Actually, it's rather a decorator than a queue itself.
|
159
|
+
*
|
160
|
+
* Note that the workers do not run in truly parallel, in the sense that they
|
161
|
+
* are not running in separate threads or processes. They are running in the
|
162
|
+
* same process, but are scheduled to run in parallel. Hence, this is useful
|
163
|
+
* for I/O-bound tasks, but not for CPU-bound tasks, which is okay for Fedify's
|
164
|
+
* workloads.
|
165
|
+
*
|
166
|
+
* @since 1.0.0
|
167
|
+
*/
|
168
|
+
var ParallelMessageQueue = class ParallelMessageQueue {
|
169
|
+
queue;
|
170
|
+
workers;
|
171
|
+
/**
|
172
|
+
* Inherits the native retry capability from the wrapped queue.
|
173
|
+
* @since 1.7.0
|
174
|
+
*/
|
175
|
+
nativeRetrial;
|
176
|
+
/**
|
177
|
+
* Constructs a new {@link ParallelMessageQueue} with the given queue and
|
178
|
+
* number of workers.
|
179
|
+
* @param queue The message queue to use under the hood. Note that
|
180
|
+
* {@link ParallelMessageQueue} cannot be nested.
|
181
|
+
* @param workers The number of workers to process messages in parallel.
|
182
|
+
* @throws {TypeError} If the given queue is an instance of
|
183
|
+
* {@link ParallelMessageQueue}.
|
184
|
+
*/
|
185
|
+
constructor(queue, workers) {
|
186
|
+
if (queue instanceof ParallelMessageQueue) throw new TypeError("Cannot nest ParallelMessageQueue.");
|
187
|
+
this.queue = queue;
|
188
|
+
this.workers = workers;
|
189
|
+
this.nativeRetrial = queue.nativeRetrial;
|
190
|
+
}
|
191
|
+
enqueue(message, options) {
|
192
|
+
return this.queue.enqueue(message, options);
|
193
|
+
}
|
194
|
+
async enqueueMany(messages, options) {
|
195
|
+
if (this.queue.enqueueMany == null) {
|
196
|
+
const results = await Promise.allSettled(messages.map((message) => this.queue.enqueue(message, options)));
|
197
|
+
const errors = results.filter((r) => r.status === "rejected").map((r) => r.reason);
|
198
|
+
if (errors.length > 1) throw new AggregateError(errors, "Failed to enqueue messages.");
|
199
|
+
else if (errors.length === 1) throw errors[0];
|
200
|
+
return;
|
201
|
+
}
|
202
|
+
await this.queue.enqueueMany(messages, options);
|
203
|
+
}
|
204
|
+
listen(handler, options = {}) {
|
205
|
+
const workers = /* @__PURE__ */ new Map();
|
206
|
+
return this.queue.listen(async (message) => {
|
207
|
+
while (workers.size >= this.workers) {
|
208
|
+
const consumedId = await Promise.any(workers.values());
|
209
|
+
workers.delete(consumedId);
|
210
|
+
}
|
211
|
+
const workerId = crypto.randomUUID();
|
212
|
+
const promise = this.#work(workerId, handler, message);
|
213
|
+
workers.set(workerId, promise);
|
214
|
+
}, options);
|
215
|
+
}
|
216
|
+
async #work(workerId, handler, message) {
|
217
|
+
await this.#sleep(0);
|
218
|
+
await handler(message);
|
219
|
+
return workerId;
|
220
|
+
}
|
221
|
+
#sleep(ms) {
|
222
|
+
return new Promise((resolve) => setTimeout(resolve, ms));
|
223
|
+
}
|
224
|
+
};
|
225
|
+
|
226
|
+
//#endregion
|
227
|
+
Object.defineProperty(exports, 'InProcessMessageQueue', {
|
228
|
+
enumerable: true,
|
229
|
+
get: function () {
|
230
|
+
return InProcessMessageQueue;
|
231
|
+
}
|
232
|
+
});
|
233
|
+
Object.defineProperty(exports, 'MemoryKvStore', {
|
234
|
+
enumerable: true,
|
235
|
+
get: function () {
|
236
|
+
return MemoryKvStore;
|
237
|
+
}
|
238
|
+
});
|
239
|
+
Object.defineProperty(exports, 'ParallelMessageQueue', {
|
240
|
+
enumerable: true,
|
241
|
+
get: function () {
|
242
|
+
return ParallelMessageQueue;
|
243
|
+
}
|
244
|
+
});
|