@fedify/fedify 2.1.0 → 2.1.2

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.
Files changed (207) hide show
  1. package/dist/{accept-D7sAxyNa.js → accept-Dd__NiUL.mjs} +10 -8
  2. package/dist/{assert-MZs1qjMx.js → assert-ddO5KLpe.mjs} +5 -9
  3. package/dist/{assert_equals-DSbWqCm3.js → assert_equals-Ew3jOFa3.mjs} +55 -69
  4. package/dist/{assert_instance_of-DHz7EHNU.js → assert_instance_of-C4Ri6VuN.mjs} +5 -9
  5. package/dist/{assert_not_equals-f3m3epl3.js → assert_not_equals--wG9hV7u.mjs} +6 -13
  6. package/dist/{assert_rejects-0h7I2Esa.js → assert_rejects-B-qJtC9Z.mjs} +6 -11
  7. package/dist/{assert_throws-rjdMBf31.js → assert_throws-4NwKEy2q.mjs} +5 -10
  8. package/dist/{builder-WiHhZvjW.js → builder-DkJDAzes.mjs} +32 -41
  9. package/dist/{chunk-CGaQZ11T.cjs → chunk-DDcVe30Y.cjs} +23 -24
  10. package/dist/{chunk-DJNbSFdH.js → chunk-nlSIicah.js} +8 -8
  11. package/dist/{client-BxMZiQaD.d.ts → client-AtlibPOU.d.ts} +1 -1
  12. package/dist/{client-CoCIaTNO.js → client-DEpOVgY1.mjs} +9 -13
  13. package/dist/{client-C97KOq3x.d.cts → client-z-8dc-e1.d.cts} +1 -1
  14. package/dist/{collection-CSzG2j1P.js → collection-BD6-SZ6O.mjs} +7 -12
  15. package/dist/compat/mod.cjs +5 -8
  16. package/dist/compat/mod.d.cts +78 -6
  17. package/dist/compat/mod.d.ts +78 -6
  18. package/dist/compat/mod.js +4 -8
  19. package/dist/compat/transformers.test.mjs +62 -0
  20. package/dist/{context-DyJjQQ_H.d.ts → context-BOiMZBu5.d.ts} +9 -18
  21. package/dist/{context-BcqA-0BL.d.cts → context-BhZVy7RB.d.cts} +9 -18
  22. package/dist/{context-Aqenou7c.js → context-Juj6bdHC.mjs} +7 -11
  23. package/dist/deno-C5VMwnFV.mjs +8 -0
  24. package/dist/{docloader-bVO2EvL9.js → docloader-X9mcJ9Tz.mjs} +8 -14
  25. package/dist/{esm-nLm00z9V.js → esm-DVILvP5e.mjs} +50 -89
  26. package/dist/federation/builder.test.d.mts +2 -0
  27. package/dist/federation/{builder.test.js → builder.test.mjs} +21 -44
  28. package/dist/federation/collection.test.d.mts +2 -0
  29. package/dist/federation/collection.test.mjs +21 -0
  30. package/dist/federation/handler.test.d.mts +2 -0
  31. package/dist/federation/{handler.test.js → handler.test.mjs} +69 -131
  32. package/dist/federation/idempotency.test.d.mts +2 -0
  33. package/dist/federation/{idempotency.test.js → idempotency.test.mjs} +31 -63
  34. package/dist/federation/inbox.test.d.mts +2 -0
  35. package/dist/federation/{inbox.test.js → inbox.test.mjs} +8 -12
  36. package/dist/federation/keycache.test.d.mts +2 -0
  37. package/dist/federation/{keycache.test.js → keycache.test.mjs} +13 -19
  38. package/dist/federation/kv.test.d.mts +2 -0
  39. package/dist/federation/{kv.test.js → kv.test.mjs} +11 -22
  40. package/dist/federation/middleware.test.d.mts +2 -0
  41. package/dist/federation/{middleware.test.js → middleware.test.mjs} +173 -262
  42. package/dist/federation/mod.cjs +327 -16
  43. package/dist/federation/mod.d.cts +3 -6
  44. package/dist/federation/mod.d.ts +3 -6
  45. package/dist/federation/mod.js +322 -13
  46. package/dist/federation/mq.test.d.mts +2 -0
  47. package/dist/federation/{mq.test.js → mq.test.mjs} +21 -35
  48. package/dist/federation/negotiation.test.d.mts +2 -0
  49. package/dist/federation/{negotiation.test.js → negotiation.test.mjs} +9 -16
  50. package/dist/federation/retry.test.d.mts +2 -0
  51. package/dist/federation/{retry.test.js → retry.test.mjs} +8 -11
  52. package/dist/federation/router.test.d.mts +2 -0
  53. package/dist/federation/{router.test.js → router.test.mjs} +11 -16
  54. package/dist/federation/send.test.d.mts +2 -0
  55. package/dist/federation/{send.test.js → send.test.mjs} +22 -30
  56. package/dist/federation/webfinger.test.d.mts +2 -0
  57. package/dist/federation/{webfinger.test.js → webfinger.test.mjs} +22 -56
  58. package/dist/{http-DhH623ma.js → http-BLZWcpzg.js} +67 -187
  59. package/dist/{http-CKDim8Tw.js → http-BTLPIzFa.mjs} +37 -45
  60. package/dist/{http-BudnHZE2.d.cts → http-CrGuipxe.d.cts} +1 -6
  61. package/dist/{http-gvnJbMS1.cjs → http-CxodXLwi.cjs} +186 -300
  62. package/dist/{http-Dax_FIBo.d.ts → http-aQzN9Ayi.d.ts} +1 -6
  63. package/dist/{inbox-CA9AUEGa.js → inbox-mcbmhjTW.mjs} +18 -26
  64. package/dist/{key-BsSCz8Z_.js → key-1MaItIGc.mjs} +29 -37
  65. package/dist/{keycache-CpGWAUbj.js → keycache-CCSwkQcY.mjs} +5 -10
  66. package/dist/{keys-BFve7QQv.js → keys-BAK-tUlf.mjs} +5 -9
  67. package/dist/{kv-BL4nlICN.d.cts → kv-CbLNp3zQ.d.cts} +1 -1
  68. package/dist/{kv-DXEUEP6z.d.ts → kv-GFYnFoOl.d.ts} +1 -1
  69. package/dist/{kv-cache-Bw2F2ABq.js → kv-cache-B01V7s3h.mjs} +4 -8
  70. package/dist/{kv-cache-DK4GFVWx.cjs → kv-cache-DjC82_4n.cjs} +27 -34
  71. package/dist/{kv-cache-CxoHCR44.js → kv-cache-GIDK1oLs.js} +6 -13
  72. package/dist/{kv-QzKcOQgP.js → kv-tL2TOE9X.mjs} +6 -10
  73. package/dist/{ld-Bo_Rx0Fc.js → ld-94uHZ1eO.mjs} +17 -31
  74. package/dist/{middleware-BkrUA3da.js → middleware-B5Er10wE.js} +336 -383
  75. package/dist/middleware-CDuHbSVE.mjs +5 -0
  76. package/dist/middleware-CTyq5KB0.cjs +4 -0
  77. package/dist/{middleware-CpAnWzjC.cjs → middleware-CqDJSLoG.cjs} +532 -587
  78. package/dist/{middleware-CZ8jOOa3.js → middleware-DMZGXHm3.mjs} +282 -317
  79. package/dist/{mod-Bx9jcLB8.d.cts → mod-B505FZBC.d.cts} +3 -3
  80. package/dist/{mod-em2Il1eD.d.cts → mod-Bp_CzKd4.d.cts} +2 -2
  81. package/dist/{mod-Cs2dYEwI.d.ts → mod-D7PAuO6k.d.ts} +3 -3
  82. package/dist/{mod-D6MdymW7.d.ts → mod-DKOAow7a.d.ts} +2 -2
  83. package/dist/{mod-Coe7KEgX.d.cts → mod-DoJBjjnO.d.cts} +2 -2
  84. package/dist/{mod-D6dOd--H.d.ts → mod-DvxszxXC.d.ts} +2 -2
  85. package/dist/mod.cjs +29 -74
  86. package/dist/mod.d.cts +11 -14
  87. package/dist/mod.d.ts +11 -15
  88. package/dist/mod.js +17 -71
  89. package/dist/{negotiation-BlAuS_nr.js → negotiation-DnsfFF8I.mjs} +7 -11
  90. package/dist/nodeinfo/client.test.d.mts +2 -0
  91. package/dist/nodeinfo/{client.test.js → client.test.mjs} +22 -40
  92. package/dist/nodeinfo/handler.test.d.mts +2 -0
  93. package/dist/nodeinfo/{handler.test.js → handler.test.mjs} +13 -43
  94. package/dist/nodeinfo/mod.cjs +5 -8
  95. package/dist/nodeinfo/mod.d.cts +2 -3
  96. package/dist/nodeinfo/mod.d.ts +2 -3
  97. package/dist/nodeinfo/mod.js +4 -8
  98. package/dist/nodeinfo/types.test.d.mts +2 -0
  99. package/dist/nodeinfo/{types.test.js → types.test.mjs} +9 -16
  100. package/dist/otel/exporter.test.d.mts +2 -0
  101. package/dist/otel/{exporter.test.js → exporter.test.mjs} +124 -178
  102. package/dist/otel/mod.cjs +15 -20
  103. package/dist/otel/mod.d.cts +2 -2
  104. package/dist/otel/mod.d.ts +2 -2
  105. package/dist/otel/mod.js +8 -14
  106. package/dist/{owner-gd0Q9FuU.d.ts → owner-74ARJ5TL.d.ts} +1 -1
  107. package/dist/{owner-Bj_IbwIT.js → owner-B4aIDhg_.mjs} +11 -16
  108. package/dist/{owner-1AbPBOOZ.d.cts → owner-CptqhsOy.d.cts} +1 -1
  109. package/dist/{proof-u6Y358J-.js → proof-DYZWMWOC.mjs} +21 -33
  110. package/dist/{proof-BhFF_JVj.cjs → proof-DqCjiFwb.cjs} +133 -157
  111. package/dist/{proof-D5BQTIcU.js → proof-j-of9m5W.js} +33 -59
  112. package/dist/{retry-mqLf4b-R.js → retry-B_E3V_Dx.mjs} +4 -7
  113. package/dist/{router-D9eI0s4b.js → router-CrMLXoOr.mjs} +4 -8
  114. package/dist/runtime/mod.cjs +11 -13
  115. package/dist/runtime/mod.d.cts +6 -2
  116. package/dist/runtime/mod.d.ts +0 -1
  117. package/dist/runtime/mod.js +4 -7
  118. package/dist/{send-CE8h59oe.js → send-uLjD0uAe.mjs} +8 -13
  119. package/dist/sig/accept.test.d.mts +2 -0
  120. package/dist/sig/{accept.test.js → accept.test.mjs} +35 -70
  121. package/dist/sig/http.test.d.mts +2 -0
  122. package/dist/sig/{http.test.js → http.test.mjs} +209 -280
  123. package/dist/sig/key.test.d.mts +2 -0
  124. package/dist/sig/{key.test.js → key.test.mjs} +11 -18
  125. package/dist/sig/ld.test.d.mts +2 -0
  126. package/dist/sig/{ld.test.js → ld.test.mjs} +22 -35
  127. package/dist/sig/mod.cjs +6 -9
  128. package/dist/sig/mod.d.cts +3 -3
  129. package/dist/sig/mod.d.ts +3 -3
  130. package/dist/sig/mod.js +5 -9
  131. package/dist/sig/owner.test.d.mts +2 -0
  132. package/dist/sig/{owner.test.js → owner.test.mjs} +19 -34
  133. package/dist/sig/proof.test.d.mts +2 -0
  134. package/dist/sig/{proof.test.js → proof.test.mjs} +16 -27
  135. package/dist/{std__assert-X-_kMxKM.js → std__assert-Duiq_YC9.mjs} +12 -24
  136. package/dist/testing/{mod.d.ts → mod.d.mts} +26 -90
  137. package/dist/testing/mod.mjs +6 -0
  138. package/dist/{transformers-3g8GZwkZ.cjs → transformers-NeAONrAq.cjs} +20 -25
  139. package/dist/{transformers-C3FLHUd6.js → transformers-ve6e2xcg.js} +3 -7
  140. package/dist/{types-CPz01LGH.js → types-DCP0WLdt.mjs} +4 -7
  141. package/dist/{types-Cd_hszr_.cjs → types-KC4QAoxe.cjs} +29 -34
  142. package/dist/{types-C93Ob9cU.js → types-hvL8ElAs.js} +8 -13
  143. package/dist/utils/docloader.test.d.mts +2 -0
  144. package/dist/utils/{docloader.test.js → docloader.test.mjs} +14 -25
  145. package/dist/utils/kv-cache.test.d.mts +2 -0
  146. package/dist/utils/{kv-cache.test.js → kv-cache.test.mjs} +25 -40
  147. package/dist/utils/mod.cjs +5 -9
  148. package/dist/utils/mod.d.cts +1 -3
  149. package/dist/utils/mod.d.ts +1 -3
  150. package/dist/utils/mod.js +4 -9
  151. package/dist/vocab/cjs.test.d.mts +2 -0
  152. package/dist/vocab/cjs.test.mjs +14 -0
  153. package/dist/vocab/mod.cjs +10 -12
  154. package/dist/vocab/mod.js +3 -5
  155. package/package.json +7 -7
  156. package/dist/compat/transformers.test.d.ts +0 -3
  157. package/dist/compat/transformers.test.js +0 -88
  158. package/dist/compat-Bb4NuTUO.js +0 -4
  159. package/dist/compat-DmDDELst.cjs +0 -4
  160. package/dist/deno-BRMCYThi.js +0 -121
  161. package/dist/federation/builder.test.d.ts +0 -3
  162. package/dist/federation/collection.test.d.ts +0 -3
  163. package/dist/federation/collection.test.js +0 -32
  164. package/dist/federation/handler.test.d.ts +0 -3
  165. package/dist/federation/idempotency.test.d.ts +0 -3
  166. package/dist/federation/inbox.test.d.ts +0 -3
  167. package/dist/federation/keycache.test.d.ts +0 -3
  168. package/dist/federation/kv.test.d.ts +0 -3
  169. package/dist/federation/middleware.test.d.ts +0 -3
  170. package/dist/federation/mq.test.d.ts +0 -3
  171. package/dist/federation/negotiation.test.d.ts +0 -3
  172. package/dist/federation/retry.test.d.ts +0 -3
  173. package/dist/federation/router.test.d.ts +0 -3
  174. package/dist/federation/send.test.d.ts +0 -3
  175. package/dist/federation/webfinger.test.d.ts +0 -3
  176. package/dist/federation-Bp3HI26G.cjs +0 -350
  177. package/dist/federation-DaMfqRm4.js +0 -332
  178. package/dist/middleware-BtT_mKsB.cjs +0 -12
  179. package/dist/middleware-CUMoHNCA.js +0 -12
  180. package/dist/middleware-CzeVJTA1.js +0 -27
  181. package/dist/mod-B7QkWzrL.d.cts +0 -80
  182. package/dist/mod-Bh8mqlYw.d.cts +0 -9
  183. package/dist/mod-D6HodEq7.d.ts +0 -7
  184. package/dist/mod-SMHOMNpZ.d.ts +0 -82
  185. package/dist/mod-gq_Xfdz8.d.cts +0 -1
  186. package/dist/nodeinfo/client.test.d.ts +0 -3
  187. package/dist/nodeinfo/handler.test.d.ts +0 -3
  188. package/dist/nodeinfo/types.test.d.ts +0 -3
  189. package/dist/nodeinfo-DoESQxq5.js +0 -4
  190. package/dist/nodeinfo-DuMYTpbZ.cjs +0 -4
  191. package/dist/otel/exporter.test.d.ts +0 -3
  192. package/dist/runtime-c2Njxsry.cjs +0 -17
  193. package/dist/runtime-poamPCMb.js +0 -13
  194. package/dist/sig/accept.test.d.ts +0 -3
  195. package/dist/sig/http.test.d.ts +0 -3
  196. package/dist/sig/key.test.d.ts +0 -3
  197. package/dist/sig/ld.test.d.ts +0 -3
  198. package/dist/sig/owner.test.d.ts +0 -3
  199. package/dist/sig/proof.test.d.ts +0 -3
  200. package/dist/sig-BNhspNOf.js +0 -4
  201. package/dist/sig-vX39WyWI.cjs +0 -4
  202. package/dist/testing/mod.js +0 -10
  203. package/dist/utils/docloader.test.d.ts +0 -3
  204. package/dist/utils/kv-cache.test.d.ts +0 -3
  205. package/dist/utils-BQ9KqEK9.cjs +0 -4
  206. package/dist/utils-Dn5OPdSW.js +0 -4
  207. /package/dist/{mod-AGjRfPjT.d.ts → compat/transformers.test.d.mts} +0 -0
@@ -1,18 +1,329 @@
1
-
2
- const { Temporal } = require("@js-temporal/polyfill");
3
- const { URLPattern } = require("urlpattern-polyfill");
4
-
5
- require('../transformers-3g8GZwkZ.cjs');
6
- require('../http-gvnJbMS1.cjs');
7
- const require_middleware = require('../middleware-CpAnWzjC.cjs');
8
- require('../proof-BhFF_JVj.cjs');
9
- const require_federation = require('../federation-Bp3HI26G.cjs');
10
- require('../types-Cd_hszr_.cjs');
11
- require('../kv-cache-DK4GFVWx.cjs');
12
-
13
- exports.InProcessMessageQueue = require_federation.InProcessMessageQueue;
14
- exports.MemoryKvStore = require_federation.MemoryKvStore;
15
- exports.ParallelMessageQueue = require_federation.ParallelMessageQueue;
1
+ const { Temporal } = require("@js-temporal/polyfill");
2
+ const { URLPattern } = require("urlpattern-polyfill");
3
+ Object.defineProperty(exports, Symbol.toStringTag, { value: "Module" });
4
+ require("../chunk-DDcVe30Y.cjs");
5
+ const require_middleware = require("../middleware-CqDJSLoG.cjs");
6
+ let es_toolkit = require("es-toolkit");
7
+ //#region src/federation/kv.ts
8
+ /**
9
+ * A key–value store that stores values in memory.
10
+ * Do not use this in production as it does not persist values.
11
+ *
12
+ * @since 0.5.0
13
+ */
14
+ var MemoryKvStore = class {
15
+ #values = {};
16
+ #encodeKey(key) {
17
+ return JSON.stringify(key);
18
+ }
19
+ /**
20
+ * {@inheritDoc KvStore.get}
21
+ */
22
+ get(key) {
23
+ const encodedKey = this.#encodeKey(key);
24
+ const entry = this.#values[encodedKey];
25
+ if (entry == null) return Promise.resolve(void 0);
26
+ const [value, expiration] = entry;
27
+ if (expiration != null && Temporal.Now.instant().until(expiration).sign < 0) {
28
+ delete this.#values[encodedKey];
29
+ return Promise.resolve(void 0);
30
+ }
31
+ return Promise.resolve(value);
32
+ }
33
+ /**
34
+ * {@inheritDoc KvStore.set}
35
+ */
36
+ set(key, value, options) {
37
+ const encodedKey = this.#encodeKey(key);
38
+ const expiration = options?.ttl == null ? null : Temporal.Now.instant().add(options.ttl.round({ largestUnit: "hour" }));
39
+ this.#values[encodedKey] = [value, expiration];
40
+ return Promise.resolve();
41
+ }
42
+ /**
43
+ * {@inheritDoc KvStore.delete}
44
+ */
45
+ delete(key) {
46
+ const encodedKey = this.#encodeKey(key);
47
+ delete this.#values[encodedKey];
48
+ return Promise.resolve();
49
+ }
50
+ /**
51
+ * {@inheritDoc KvStore.cas}
52
+ */
53
+ cas(key, expectedValue, newValue, options) {
54
+ const encodedKey = this.#encodeKey(key);
55
+ const entry = this.#values[encodedKey];
56
+ let currentValue;
57
+ if (entry == null) currentValue = void 0;
58
+ else {
59
+ const [value, expiration] = entry;
60
+ if (expiration != null && Temporal.Now.instant().until(expiration).sign < 0) {
61
+ delete this.#values[encodedKey];
62
+ currentValue = void 0;
63
+ } else currentValue = value;
64
+ }
65
+ if (!(0, es_toolkit.isEqual)(currentValue, expectedValue)) return Promise.resolve(false);
66
+ const expiration = options?.ttl == null ? null : Temporal.Now.instant().add(options.ttl.round({ largestUnit: "hour" }));
67
+ this.#values[encodedKey] = [newValue, expiration];
68
+ return Promise.resolve(true);
69
+ }
70
+ /**
71
+ * {@inheritDoc KvStore.list}
72
+ */
73
+ async *list(prefix) {
74
+ const now = Temporal.Now.instant();
75
+ for (const [encodedKey, entry] of Object.entries(this.#values)) {
76
+ const key = JSON.parse(encodedKey);
77
+ if (prefix != null) {
78
+ if (key.length < prefix.length) continue;
79
+ if (!prefix.every((p, i) => key[i] === p)) continue;
80
+ }
81
+ const [value, expiration] = entry;
82
+ if (expiration != null && now.until(expiration).sign < 0) {
83
+ delete this.#values[encodedKey];
84
+ continue;
85
+ }
86
+ yield {
87
+ key,
88
+ value
89
+ };
90
+ }
91
+ }
92
+ };
93
+ //#endregion
94
+ //#region src/federation/mq.ts
95
+ /**
96
+ * A message queue that processes messages in the same process.
97
+ * Do not use this in production as it does neither persist messages nor
98
+ * distribute them across multiple processes.
99
+ *
100
+ * @since 0.5.0
101
+ */
102
+ var InProcessMessageQueue = class {
103
+ #messages;
104
+ #monitors;
105
+ #pollIntervalMs;
106
+ /**
107
+ * Tracks which ordering keys are currently being processed to ensure
108
+ * sequential processing for messages with the same key.
109
+ */
110
+ #processingKeys;
111
+ /**
112
+ * In-process message queue does not provide native retry mechanisms.
113
+ * @since 1.7.0
114
+ */
115
+ nativeRetrial = false;
116
+ /**
117
+ * Constructs a new {@link InProcessMessageQueue} with the given options.
118
+ * @param options Additional options for the in-process message queue.
119
+ */
120
+ constructor(options = {}) {
121
+ this.#messages = [];
122
+ this.#monitors = {};
123
+ this.#pollIntervalMs = Temporal.Duration.from(options.pollInterval ?? { seconds: 5 }).total("millisecond");
124
+ this.#processingKeys = /* @__PURE__ */ new Set();
125
+ }
126
+ enqueue(message, options) {
127
+ const delay = options?.delay == null ? 0 : Math.max(options.delay.total("millisecond"), 0);
128
+ if (delay > 0) {
129
+ setTimeout(() => this.enqueue(message, {
130
+ ...options,
131
+ delay: void 0
132
+ }), delay);
133
+ return Promise.resolve();
134
+ }
135
+ const orderingKey = options?.orderingKey ?? null;
136
+ this.#messages.push({
137
+ message,
138
+ orderingKey
139
+ });
140
+ for (const monitorId in this.#monitors) this.#monitors[monitorId]();
141
+ return Promise.resolve();
142
+ }
143
+ enqueueMany(messages, options) {
144
+ if (messages.length === 0) return Promise.resolve();
145
+ const delay = options?.delay == null ? 0 : Math.max(options.delay.total("millisecond"), 0);
146
+ if (delay > 0) {
147
+ setTimeout(() => this.enqueueMany(messages, {
148
+ ...options,
149
+ delay: void 0
150
+ }), delay);
151
+ return Promise.resolve();
152
+ }
153
+ const orderingKey = options?.orderingKey ?? null;
154
+ for (const message of messages) this.#messages.push({
155
+ message,
156
+ orderingKey
157
+ });
158
+ for (const monitorId in this.#monitors) this.#monitors[monitorId]();
159
+ return Promise.resolve();
160
+ }
161
+ async listen(handler, options = {}) {
162
+ const signal = options.signal;
163
+ while (signal == null || !signal.aborted) {
164
+ const idx = this.#messages.findIndex((m) => m.orderingKey == null || !this.#processingKeys.has(m.orderingKey));
165
+ if (idx >= 0) {
166
+ const { message, orderingKey } = this.#messages.splice(idx, 1)[0];
167
+ if (orderingKey != null) this.#processingKeys.add(orderingKey);
168
+ try {
169
+ await handler(message);
170
+ } finally {
171
+ if (orderingKey != null) this.#processingKeys.delete(orderingKey);
172
+ }
173
+ } else if (this.#messages.length === 0) await this.#wait(this.#pollIntervalMs, signal);
174
+ else await this.#wait(10, signal);
175
+ }
176
+ }
177
+ #wait(ms, signal) {
178
+ let timer = null;
179
+ return Promise.any([new Promise((resolve) => {
180
+ signal?.addEventListener("abort", () => {
181
+ if (timer != null) clearTimeout(timer);
182
+ resolve();
183
+ }, { once: true });
184
+ const monitorId = crypto.randomUUID();
185
+ this.#monitors[monitorId] = () => {
186
+ delete this.#monitors[monitorId];
187
+ if (timer != null) clearTimeout(timer);
188
+ resolve();
189
+ };
190
+ }), new Promise((resolve) => timer = setTimeout(resolve, ms))]);
191
+ }
192
+ };
193
+ /**
194
+ * A message queue that processes messages in parallel. It takes another
195
+ * {@link MessageQueue}, and processes messages in parallel up to a certain
196
+ * number of workers.
197
+ *
198
+ * Actually, it's rather a decorator than a queue itself.
199
+ *
200
+ * Note that the workers do not run in truly parallel, in the sense that they
201
+ * are not running in separate threads or processes. They are running in the
202
+ * same process, but are scheduled to run in parallel. Hence, this is useful
203
+ * for I/O-bound tasks, but not for CPU-bound tasks, which is okay for Fedify's
204
+ * workloads.
205
+ *
206
+ * When using `ParallelMessageQueue`, the ordering guarantee is preserved
207
+ * *only if* the underlying queue implementation delivers messages in a wrapper
208
+ * format that includes the `__fedify_ordering_key__` property. Currently,
209
+ * only `DenoKvMessageQueue` and `WorkersMessageQueue` use this format.
210
+ * For other queue implementations (e.g., `InProcessMessageQueue`,
211
+ * `RedisMessageQueue`, `PostgresMessageQueue`, `SqliteMessageQueue`,
212
+ * `AmqpMessageQueue`), the ordering key cannot be detected by
213
+ * `ParallelMessageQueue`, so ordering guarantees are handled by those
214
+ * implementations directly rather than at the `ParallelMessageQueue` level.
215
+ *
216
+ * Messages with the same ordering key will never be processed concurrently
217
+ * by different workers, ensuring sequential processing within each key.
218
+ * Messages with different ordering keys (or no ordering key) can still be
219
+ * processed in parallel.
220
+ *
221
+ * @since 1.0.0
222
+ */
223
+ var ParallelMessageQueue = class ParallelMessageQueue {
224
+ queue;
225
+ workers;
226
+ /**
227
+ * Inherits the native retry capability from the wrapped queue.
228
+ * @since 1.7.0
229
+ */
230
+ nativeRetrial;
231
+ /**
232
+ * Tracks which ordering keys are currently being processed to ensure
233
+ * sequential processing for messages with the same key.
234
+ */
235
+ #processingKeys = /* @__PURE__ */ new Set();
236
+ /**
237
+ * Pending messages waiting for their ordering key to become available.
238
+ */
239
+ #pendingMessages = [];
240
+ /**
241
+ * Constructs a new {@link ParallelMessageQueue} with the given queue and
242
+ * number of workers.
243
+ * @param queue The message queue to use under the hood. Note that
244
+ * {@link ParallelMessageQueue} cannot be nested.
245
+ * @param workers The number of workers to process messages in parallel.
246
+ * @throws {TypeError} If the given queue is an instance of
247
+ * {@link ParallelMessageQueue}.
248
+ */
249
+ constructor(queue, workers) {
250
+ if (queue instanceof ParallelMessageQueue) throw new TypeError("Cannot nest ParallelMessageQueue.");
251
+ this.queue = queue;
252
+ this.workers = workers;
253
+ this.nativeRetrial = queue.nativeRetrial;
254
+ }
255
+ enqueue(message, options) {
256
+ return this.queue.enqueue(message, options);
257
+ }
258
+ async enqueueMany(messages, options) {
259
+ if (this.queue.enqueueMany == null) {
260
+ const errors = (await Promise.allSettled(messages.map((message) => this.queue.enqueue(message, options)))).filter((r) => r.status === "rejected").map((r) => r.reason);
261
+ if (errors.length > 1) throw new AggregateError(errors, "Failed to enqueue messages.");
262
+ else if (errors.length === 1) throw errors[0];
263
+ return;
264
+ }
265
+ await this.queue.enqueueMany(messages, options);
266
+ }
267
+ /**
268
+ * Extracts ordering key from a message if present.
269
+ *
270
+ * This method only works for queue implementations that deliver messages
271
+ * in the wrapper format with `__fedify_ordering_key__` property. Currently,
272
+ * only `DenoKvMessageQueue` and `WorkersMessageQueue` use this format.
273
+ *
274
+ * For other queue implementations (`InProcessMessageQueue`,
275
+ * `RedisMessageQueue`, `PostgresMessageQueue`, `SqliteMessageQueue`,
276
+ * `AmqpMessageQueue`), messages are delivered as raw payloads without the
277
+ * wrapper, so the ordering key cannot be detected here. Those
278
+ * implementations handle ordering guarantees internally.
279
+ */
280
+ #extractOrderingKey(message) {
281
+ if (message != null && typeof message === "object") {
282
+ if ("__fedify_ordering_key__" in message) return message.__fedify_ordering_key__;
283
+ }
284
+ }
285
+ listen(handler, options = {}) {
286
+ const workers = /* @__PURE__ */ new Map();
287
+ return this.queue.listen(async (message) => {
288
+ while (workers.size >= this.workers) {
289
+ const consumedId = await Promise.any(workers.values());
290
+ workers.delete(consumedId);
291
+ }
292
+ const workerId = crypto.randomUUID();
293
+ const orderingKey = this.#extractOrderingKey(message);
294
+ if (orderingKey != null && this.#processingKeys.has(orderingKey)) await new Promise((resolve) => {
295
+ this.#pendingMessages.push({
296
+ message,
297
+ orderingKey,
298
+ resolve
299
+ });
300
+ });
301
+ if (orderingKey != null) this.#processingKeys.add(orderingKey);
302
+ const promise = this.#work(workerId, handler, message, orderingKey);
303
+ workers.set(workerId, promise);
304
+ }, options);
305
+ }
306
+ async #work(workerId, handler, message, orderingKey) {
307
+ await this.#sleep(0);
308
+ try {
309
+ await handler(message);
310
+ } finally {
311
+ if (orderingKey != null) {
312
+ this.#processingKeys.delete(orderingKey);
313
+ const pendingIdx = this.#pendingMessages.findIndex((p) => p.orderingKey === orderingKey);
314
+ if (pendingIdx >= 0) this.#pendingMessages.splice(pendingIdx, 1)[0].resolve();
315
+ }
316
+ }
317
+ return workerId;
318
+ }
319
+ #sleep(ms) {
320
+ return new Promise((resolve) => setTimeout(resolve, ms));
321
+ }
322
+ };
323
+ //#endregion
324
+ exports.InProcessMessageQueue = InProcessMessageQueue;
325
+ exports.MemoryKvStore = MemoryKvStore;
326
+ exports.ParallelMessageQueue = ParallelMessageQueue;
16
327
  exports.Router = require_middleware.Router;
17
328
  exports.RouterError = require_middleware.RouterError;
18
329
  exports.SendActivityError = require_middleware.SendActivityError;
@@ -23,4 +334,4 @@ exports.createFederationBuilder = require_middleware.createFederationBuilder;
23
334
  exports.digest = require_middleware.digest;
24
335
  exports.handleWebFinger = require_middleware.handleWebFinger;
25
336
  exports.respondWithObject = require_middleware.respondWithObject;
26
- exports.respondWithObjectIfAcceptable = require_middleware.respondWithObjectIfAcceptable;
337
+ exports.respondWithObjectIfAcceptable = require_middleware.respondWithObjectIfAcceptable;
@@ -1,7 +1,4 @@
1
- import "../client-C97KOq3x.cjs";
2
- import "../http-BudnHZE2.cjs";
3
- import "../owner-1AbPBOOZ.cjs";
4
- import { ActorAliasMapper, ActorCallbackSetters, ActorDispatcher, ActorHandleMapper, ActorKeyPair, ActorKeyPairsDispatcher, AuthorizePredicate, CollectionCallbackSetters, CollectionCounter, CollectionCursor, CollectionDispatcher, ConstructorWithTypeId, Context, CreateExponentialBackoffPolicyOptions, CustomCollectionCallbackSetters, CustomCollectionCounter, CustomCollectionCursor, CustomCollectionDispatcher, Federatable, Federation, FederationBuilder, FederationFetchOptions, FederationKvPrefixes, FederationOptions, FederationOrigin, FederationQueueOptions, FederationStartQueueOptions, ForwardActivityOptions, GetSignedKeyOptions, IdempotencyKeyCallback, IdempotencyStrategy, InProcessMessageQueue, InProcessMessageQueueOptions, InboxChallengePolicy, InboxContext, InboxErrorHandler, InboxListener, InboxListenerSetters, Message, MessageQueue, MessageQueueEnqueueOptions, MessageQueueListenOptions, NodeInfoDispatcher, ObjectAuthorizePredicate, ObjectCallbackSetters, ObjectDispatcher, OutboxErrorHandler, OutboxPermanentFailureHandler, PageItems, ParallelMessageQueue, ParseUriResult, RequestContext, RespondWithObjectOptions, RetryContext, RetryPolicy, Rfc6570Expression, RouteActivityOptions, Router, RouterError, RouterOptions, RouterRouteResult, SendActivityError, SendActivityOptions, SendActivityOptionsForCollection, SenderKeyPair, SharedInboxKeyDispatcher, UnverifiedActivityHandler, UnverifiedActivityReason, WebFingerLinksDispatcher, buildCollectionSynchronizationHeader, createExponentialBackoffPolicy, createFederation, createFederationBuilder, digest, respondWithObject, respondWithObjectIfAcceptable } from "../context-BcqA-0BL.cjs";
5
- import { KvKey, KvStore, KvStoreListEntry, KvStoreSetOptions, MemoryKvStore } from "../kv-BL4nlICN.cjs";
6
- import { WebFingerHandlerParameters, handleWebFinger } from "../mod-em2Il1eD.cjs";
1
+ import { $ as ActorKeyPairsDispatcher, A as createFederation, B as RouterRouteResult, C as InboxChallengePolicy, D as FederationKvPrefixes, E as Rfc6570Expression, F as Message, G as InProcessMessageQueueOptions, H as respondWithObject, I as createFederationBuilder, J as MessageQueueListenOptions, K as MessageQueue, L as Router, M as RetryContext, N as RetryPolicy, O as FederationOrigin, P as createExponentialBackoffPolicy, Q as ActorHandleMapper, R as RouterError, S as IdempotencyStrategy, St as digest, T as ObjectCallbackSetters, U as respondWithObjectIfAcceptable, V as RespondWithObjectOptions, W as InProcessMessageQueue, X as ActorAliasMapper, Y as ParallelMessageQueue, Z as ActorDispatcher, _ as FederationBuilder, _t as WebFingerLinksDispatcher, a as InboxContext, at as CustomCollectionCursor, b as FederationStartQueueOptions, bt as PageItems, c as RouteActivityOptions, ct as InboxListener, d as ActorCallbackSetters, dt as ObjectDispatcher, et as AuthorizePredicate, f as CollectionCallbackSetters, ft as OutboxErrorHandler, g as Federation, gt as UnverifiedActivityReason, h as Federatable, ht as UnverifiedActivityHandler, i as GetSignedKeyOptions, it as CustomCollectionCounter, j as CreateExponentialBackoffPolicyOptions, k as FederationQueueOptions, l as SendActivityOptions, lt as NodeInfoDispatcher, m as CustomCollectionCallbackSetters, mt as SharedInboxKeyDispatcher, n as Context, nt as CollectionCursor, o as ParseUriResult, ot as CustomCollectionDispatcher, p as ConstructorWithTypeId, pt as OutboxPermanentFailureHandler, q as MessageQueueEnqueueOptions, r as ForwardActivityOptions, rt as CollectionDispatcher, s as RequestContext, st as InboxErrorHandler, t as ActorKeyPair, tt as CollectionCounter, u as SendActivityOptionsForCollection, ut as ObjectAuthorizePredicate, v as FederationFetchOptions, vt as SendActivityError, w as InboxListenerSetters, x as IdempotencyKeyCallback, xt as buildCollectionSynchronizationHeader, y as FederationOptions, yt as SenderKeyPair, z as RouterOptions } from "../context-BhZVy7RB.cjs";
2
+ import { a as MemoryKvStore, i as KvStoreSetOptions, n as KvStore, r as KvStoreListEntry, t as KvKey } from "../kv-CbLNp3zQ.cjs";
3
+ import { n as handleWebFinger, t as WebFingerHandlerParameters } from "../mod-Bp_CzKd4.cjs";
7
4
  export { ActorAliasMapper, ActorCallbackSetters, ActorDispatcher, ActorHandleMapper, ActorKeyPair, ActorKeyPairsDispatcher, AuthorizePredicate, CollectionCallbackSetters, CollectionCounter, CollectionCursor, CollectionDispatcher, ConstructorWithTypeId, Context, CreateExponentialBackoffPolicyOptions, CustomCollectionCallbackSetters, CustomCollectionCounter, CustomCollectionCursor, CustomCollectionDispatcher, Federatable, Federation, FederationBuilder, FederationFetchOptions, FederationKvPrefixes, FederationOptions, FederationOrigin, FederationQueueOptions, FederationStartQueueOptions, ForwardActivityOptions, GetSignedKeyOptions, IdempotencyKeyCallback, IdempotencyStrategy, InProcessMessageQueue, InProcessMessageQueueOptions, InboxChallengePolicy, InboxContext, InboxErrorHandler, InboxListener, InboxListenerSetters, KvKey, KvStore, KvStoreListEntry, KvStoreSetOptions, MemoryKvStore, Message, MessageQueue, MessageQueueEnqueueOptions, MessageQueueListenOptions, NodeInfoDispatcher, ObjectAuthorizePredicate, ObjectCallbackSetters, ObjectDispatcher, OutboxErrorHandler, OutboxPermanentFailureHandler, PageItems, ParallelMessageQueue, ParseUriResult, RequestContext, RespondWithObjectOptions, RetryContext, RetryPolicy, Rfc6570Expression, RouteActivityOptions, Router, RouterError, RouterOptions, RouterRouteResult, SendActivityError, SendActivityOptions, SendActivityOptionsForCollection, SenderKeyPair, SharedInboxKeyDispatcher, UnverifiedActivityHandler, UnverifiedActivityReason, WebFingerHandlerParameters, WebFingerLinksDispatcher, buildCollectionSynchronizationHeader, createExponentialBackoffPolicy, createFederation, createFederationBuilder, digest, handleWebFinger, respondWithObject, respondWithObjectIfAcceptable };
@@ -1,9 +1,6 @@
1
1
  import { Temporal } from "@js-temporal/polyfill";
2
2
  import { URLPattern } from "urlpattern-polyfill";
3
- import "../client-BxMZiQaD.js";
4
- import "../http-Dax_FIBo.js";
5
- import "../owner-gd0Q9FuU.js";
6
- import { ActorAliasMapper, ActorCallbackSetters, ActorDispatcher, ActorHandleMapper, ActorKeyPair, ActorKeyPairsDispatcher, AuthorizePredicate, CollectionCallbackSetters, CollectionCounter, CollectionCursor, CollectionDispatcher, ConstructorWithTypeId, Context, CreateExponentialBackoffPolicyOptions, CustomCollectionCallbackSetters, CustomCollectionCounter, CustomCollectionCursor, CustomCollectionDispatcher, Federatable, Federation, FederationBuilder, FederationFetchOptions, FederationKvPrefixes, FederationOptions, FederationOrigin, FederationQueueOptions, FederationStartQueueOptions, ForwardActivityOptions, GetSignedKeyOptions, IdempotencyKeyCallback, IdempotencyStrategy, InProcessMessageQueue, InProcessMessageQueueOptions, InboxChallengePolicy, InboxContext, InboxErrorHandler, InboxListener, InboxListenerSetters, Message, MessageQueue, MessageQueueEnqueueOptions, MessageQueueListenOptions, NodeInfoDispatcher, ObjectAuthorizePredicate, ObjectCallbackSetters, ObjectDispatcher, OutboxErrorHandler, OutboxPermanentFailureHandler, PageItems, ParallelMessageQueue, ParseUriResult, RequestContext, RespondWithObjectOptions, RetryContext, RetryPolicy, Rfc6570Expression, RouteActivityOptions, Router, RouterError, RouterOptions, RouterRouteResult, SendActivityError, SendActivityOptions, SendActivityOptionsForCollection, SenderKeyPair, SharedInboxKeyDispatcher, UnverifiedActivityHandler, UnverifiedActivityReason, WebFingerLinksDispatcher, buildCollectionSynchronizationHeader, createExponentialBackoffPolicy, createFederation, createFederationBuilder, digest, respondWithObject, respondWithObjectIfAcceptable } from "../context-DyJjQQ_H.js";
7
- import { KvKey, KvStore, KvStoreListEntry, KvStoreSetOptions, MemoryKvStore } from "../kv-DXEUEP6z.js";
8
- import { WebFingerHandlerParameters, handleWebFinger } from "../mod-D6MdymW7.js";
3
+ import { $ as ActorKeyPairsDispatcher, A as createFederation, B as RouterRouteResult, C as InboxChallengePolicy, D as FederationKvPrefixes, E as Rfc6570Expression, F as Message, G as InProcessMessageQueueOptions, H as respondWithObject, I as createFederationBuilder, J as MessageQueueListenOptions, K as MessageQueue, L as Router, M as RetryContext, N as RetryPolicy, O as FederationOrigin, P as createExponentialBackoffPolicy, Q as ActorHandleMapper, R as RouterError, S as IdempotencyStrategy, St as digest, T as ObjectCallbackSetters, U as respondWithObjectIfAcceptable, V as RespondWithObjectOptions, W as InProcessMessageQueue, X as ActorAliasMapper, Y as ParallelMessageQueue, Z as ActorDispatcher, _ as FederationBuilder, _t as WebFingerLinksDispatcher, a as InboxContext, at as CustomCollectionCursor, b as FederationStartQueueOptions, bt as PageItems, c as RouteActivityOptions, ct as InboxListener, d as ActorCallbackSetters, dt as ObjectDispatcher, et as AuthorizePredicate, f as CollectionCallbackSetters, ft as OutboxErrorHandler, g as Federation, gt as UnverifiedActivityReason, h as Federatable, ht as UnverifiedActivityHandler, i as GetSignedKeyOptions, it as CustomCollectionCounter, j as CreateExponentialBackoffPolicyOptions, k as FederationQueueOptions, l as SendActivityOptions, lt as NodeInfoDispatcher, m as CustomCollectionCallbackSetters, mt as SharedInboxKeyDispatcher, n as Context, nt as CollectionCursor, o as ParseUriResult, ot as CustomCollectionDispatcher, p as ConstructorWithTypeId, pt as OutboxPermanentFailureHandler, q as MessageQueueEnqueueOptions, r as ForwardActivityOptions, rt as CollectionDispatcher, s as RequestContext, st as InboxErrorHandler, t as ActorKeyPair, tt as CollectionCounter, u as SendActivityOptionsForCollection, ut as ObjectAuthorizePredicate, v as FederationFetchOptions, vt as SendActivityError, w as InboxListenerSetters, x as IdempotencyKeyCallback, xt as buildCollectionSynchronizationHeader, y as FederationOptions, yt as SenderKeyPair, z as RouterOptions } from "../context-BOiMZBu5.js";
4
+ import { a as MemoryKvStore, i as KvStoreSetOptions, n as KvStore, r as KvStoreListEntry, t as KvKey } from "../kv-GFYnFoOl.js";
5
+ import { n as handleWebFinger, t as WebFingerHandlerParameters } from "../mod-DKOAow7a.js";
9
6
  export { ActorAliasMapper, ActorCallbackSetters, ActorDispatcher, ActorHandleMapper, ActorKeyPair, ActorKeyPairsDispatcher, AuthorizePredicate, CollectionCallbackSetters, CollectionCounter, CollectionCursor, CollectionDispatcher, ConstructorWithTypeId, Context, CreateExponentialBackoffPolicyOptions, CustomCollectionCallbackSetters, CustomCollectionCounter, CustomCollectionCursor, CustomCollectionDispatcher, Federatable, Federation, FederationBuilder, FederationFetchOptions, FederationKvPrefixes, FederationOptions, FederationOrigin, FederationQueueOptions, FederationStartQueueOptions, ForwardActivityOptions, GetSignedKeyOptions, IdempotencyKeyCallback, IdempotencyStrategy, InProcessMessageQueue, InProcessMessageQueueOptions, InboxChallengePolicy, InboxContext, InboxErrorHandler, InboxListener, InboxListenerSetters, KvKey, KvStore, KvStoreListEntry, KvStoreSetOptions, MemoryKvStore, Message, MessageQueue, MessageQueueEnqueueOptions, MessageQueueListenOptions, NodeInfoDispatcher, ObjectAuthorizePredicate, ObjectCallbackSetters, ObjectDispatcher, OutboxErrorHandler, OutboxPermanentFailureHandler, PageItems, ParallelMessageQueue, ParseUriResult, RequestContext, RespondWithObjectOptions, RetryContext, RetryPolicy, Rfc6570Expression, RouteActivityOptions, Router, RouterError, RouterOptions, RouterRouteResult, SendActivityError, SendActivityOptions, SendActivityOptionsForCollection, SenderKeyPair, SharedInboxKeyDispatcher, UnverifiedActivityHandler, UnverifiedActivityReason, WebFingerHandlerParameters, WebFingerLinksDispatcher, buildCollectionSynchronizationHeader, createExponentialBackoffPolicy, createFederation, createFederationBuilder, digest, handleWebFinger, respondWithObject, respondWithObjectIfAcceptable };