@fedify/fedify 1.10.6 → 1.10.7

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 (101) hide show
  1. package/dist/{actor-Bhyv1XG8.cjs → actor-BGIAXtRd.cjs} +187 -187
  2. package/dist/{actor-Cl985C7Q.mjs → actor-C-_2S5Mn.mjs} +1 -1
  3. package/dist/{actor-D7XOmVKd.js → actor-Cujbx4Zv.js} +187 -187
  4. package/dist/{authdocloader-A-uvTiEn.mjs → authdocloader-1Sk2bqFx.mjs} +3 -3
  5. package/dist/{authdocloader-D_IgE19r.js → authdocloader-D4Y6iyTF.js} +3 -3
  6. package/dist/{authdocloader-BLlsL860.cjs → authdocloader-DQfruCir.cjs} +3 -3
  7. package/dist/{builder-BqZNPx3S.mjs → builder-CZbrDRl7.mjs} +4 -4
  8. package/dist/{client-Ds4v9YJZ.mjs → client-Dyb8MI3u.mjs} +1 -1
  9. package/dist/compat/mod.cjs +1 -1
  10. package/dist/compat/transformers.test.mjs +3 -3
  11. package/dist/{docloader-LthfAmat.js → docloader-Dtaju6oI.js} +1 -1
  12. package/dist/{docloader-DWWy7Mlm.cjs → docloader-Q3DfzuUi.cjs} +1 -1
  13. package/dist/{esm-CYg0RhgA.mjs → esm-DOJg552-.mjs} +1 -1
  14. package/dist/federation/builder.test.mjs +3 -3
  15. package/dist/federation/collection.test.mjs +1 -1
  16. package/dist/federation/handler.test.mjs +6 -6
  17. package/dist/federation/idempotency.test.mjs +5 -5
  18. package/dist/federation/inbox.test.mjs +3 -3
  19. package/dist/federation/keycache.test.mjs +3 -3
  20. package/dist/federation/kv.test.mjs +1 -1
  21. package/dist/federation/middleware.test.mjs +65 -11
  22. package/dist/federation/mod.cjs +2 -2
  23. package/dist/federation/mod.js +1 -1
  24. package/dist/federation/mq.test.mjs +1 -1
  25. package/dist/federation/retry.test.mjs +1 -1
  26. package/dist/federation/router.test.mjs +2 -2
  27. package/dist/federation/send.test.mjs +7 -7
  28. package/dist/{http-pZJd5Nkb.mjs → http-BRwSVBn1.mjs} +2 -2
  29. package/dist/{http-kyXntNm5.cjs → http-DCrun8ql.cjs} +3 -3
  30. package/dist/{http-CbNRWhO2.js → http-DRnRwr3i.js} +3 -3
  31. package/dist/{inbox-gr3hW-GD.mjs → inbox-pD1nbb_5.mjs} +1 -1
  32. package/dist/{key-Bzt8qD6I.cjs → key-Cmbps6xt.cjs} +1 -1
  33. package/dist/{key-DgYChyco.cjs → key-DEYIxAFs.cjs} +2 -2
  34. package/dist/{key-CTKl4AWD.mjs → key-DMO0TgTa.mjs} +1 -1
  35. package/dist/{key-Db4XYUx7.mjs → key-DdL5Oc59.mjs} +2 -2
  36. package/dist/{key-BR2q2bCE.js → key-vIzWPiil.js} +2 -2
  37. package/dist/{keycache-YHrypd98.mjs → keycache-BVR9f06Y.mjs} +1 -1
  38. package/dist/{keys-r0MYdjdV.mjs → keys-Co-0pK8a.mjs} +1 -1
  39. package/dist/{ld-iTK8z54J.mjs → ld-BFaDk5gX.mjs} +2 -2
  40. package/dist/{lookup-BzhBNUNH.mjs → lookup-CMYXdjVH.mjs} +1 -1
  41. package/dist/{lookup-BdSpYC1N.cjs → lookup-CZGJqSjm.cjs} +1 -1
  42. package/dist/{lookup-DZ9GTTzJ.js → lookup-jlmCTRsO.js} +1 -1
  43. package/dist/{middleware-DRNvNZa1.cjs → middleware-BWlZ-wms.cjs} +1 -1
  44. package/dist/{middleware-Bk0hNv-N.mjs → middleware-BXD5WJbj.mjs} +15 -15
  45. package/dist/{middleware-CZOiI7j6.cjs → middleware-BhMQrJXH.cjs} +11 -11
  46. package/dist/{middleware-Df-QFT32.js → middleware-CmA2E9Bu.js} +9 -9
  47. package/dist/{middleware-XbutA7xe.mjs → middleware-H3Ce7yn3.mjs} +1 -1
  48. package/dist/mod.cjs +10 -10
  49. package/dist/mod.js +9 -9
  50. package/dist/nodeinfo/client.test.mjs +3 -3
  51. package/dist/nodeinfo/handler.test.mjs +2 -2
  52. package/dist/nodeinfo/mod.cjs +1 -1
  53. package/dist/nodeinfo/mod.js +1 -1
  54. package/dist/nodeinfo/semver.test.mjs +1 -1
  55. package/dist/nodeinfo/types.test.mjs +1 -1
  56. package/dist/otel/exporter.test.mjs +1 -1
  57. package/dist/otel/mod.cjs +1 -1
  58. package/dist/{owner-CoLrSrJE.mjs → owner-CNdS8zxf.mjs} +3 -3
  59. package/dist/{proof-CzEaLrMm.mjs → proof-Co7YmDpv.mjs} +2 -2
  60. package/dist/{proof-CmhkztK1.js → proof-DHPbi_Mx.js} +3 -3
  61. package/dist/{proof-D9Y-Sfn8.cjs → proof-DcPdtve2.cjs} +3 -3
  62. package/dist/runtime/authdocloader.test.mjs +6 -6
  63. package/dist/runtime/docloader.test.mjs +3 -3
  64. package/dist/runtime/key.test.mjs +3 -3
  65. package/dist/runtime/langstr.test.mjs +2 -2
  66. package/dist/runtime/link.test.mjs +2 -2
  67. package/dist/runtime/mod.cjs +3 -3
  68. package/dist/runtime/mod.js +3 -3
  69. package/dist/runtime/multibase/multibase.test.mjs +2 -2
  70. package/dist/runtime/url.test.mjs +2 -2
  71. package/dist/{send-vtEBiKbR.mjs → send-BRCWNcMa.mjs} +2 -2
  72. package/dist/sig/http.test.mjs +6 -6
  73. package/dist/sig/key.test.mjs +4 -4
  74. package/dist/sig/ld.test.mjs +5 -5
  75. package/dist/sig/mod.cjs +3 -3
  76. package/dist/sig/mod.js +3 -3
  77. package/dist/sig/owner.test.mjs +5 -5
  78. package/dist/sig/proof.test.mjs +4 -4
  79. package/dist/testing/docloader.test.mjs +1 -1
  80. package/dist/testing/mod.mjs +1 -1
  81. package/dist/{testing-Csq3Xnki.mjs → testing-BLIh1cXz.mjs} +2 -2
  82. package/dist/{transformers-DQcMoinm.cjs → transformers-CLtJ5H8o.cjs} +1 -1
  83. package/dist/{types-BNAdhXAI.cjs → types-B34v-m2N.cjs} +1 -1
  84. package/dist/{types-9gce5lHU.js → types-CXZk86AG.js} +1 -1
  85. package/dist/vocab/actor.test.mjs +4 -4
  86. package/dist/vocab/cjs.test.mjs +1 -1
  87. package/dist/vocab/lookup.test.mjs +4 -4
  88. package/dist/vocab/mod.cjs +3 -3
  89. package/dist/vocab/mod.js +3 -3
  90. package/dist/vocab/type.test.mjs +2 -2
  91. package/dist/vocab/vocab.test.mjs +3 -3
  92. package/dist/{vocab-CeumAiRh.mjs → vocab-rT_94Pke.mjs} +186 -186
  93. package/dist/webfinger/handler.test.mjs +3 -3
  94. package/dist/webfinger/lookup.test.mjs +3 -3
  95. package/dist/webfinger/mod.cjs +1 -1
  96. package/dist/webfinger/mod.js +1 -1
  97. package/dist/x/cfworkers.cjs +1 -1
  98. package/dist/x/cfworkers.test.mjs +1 -1
  99. package/dist/x/hono.cjs +1 -1
  100. package/dist/x/sveltekit.cjs +1 -1
  101. package/package.json +1 -1
@@ -1,9 +1,9 @@
1
1
  import "@js-temporal/polyfill";
2
2
  import "urlpattern-polyfill";
3
3
  globalThis.addEventListener = () => {};
4
- import { $ as UrlError, K as createRequest, Q as logRequest, Y as getRemoteDocument, rt as validatePublicUrl } from "./vocab-CeumAiRh.mjs";
5
- import { a as validateCryptoKey } from "./key-Db4XYUx7.mjs";
6
- import { n as doubleKnock } from "./http-pZJd5Nkb.mjs";
4
+ import { $ as UrlError, K as createRequest, Q as logRequest, Y as getRemoteDocument, rt as validatePublicUrl } from "./vocab-rT_94Pke.mjs";
5
+ import { a as validateCryptoKey } from "./key-DdL5Oc59.mjs";
6
+ import { n as doubleKnock } from "./http-BRwSVBn1.mjs";
7
7
  import { getLogger } from "@logtape/logtape";
8
8
  //#region src/runtime/authdocloader.ts
9
9
  const logger = getLogger([
@@ -1,8 +1,8 @@
1
1
  import "@js-temporal/polyfill";
2
2
  import "urlpattern-polyfill";
3
- import { a as getRemoteDocument, c as logRequest, l as UrlError, n as createRequest, u as validatePublicUrl } from "./docloader-LthfAmat.js";
4
- import { o as validateCryptoKey } from "./key-BR2q2bCE.js";
5
- import { t as doubleKnock } from "./http-CbNRWhO2.js";
3
+ import { a as getRemoteDocument, c as logRequest, l as UrlError, n as createRequest, u as validatePublicUrl } from "./docloader-Dtaju6oI.js";
4
+ import { o as validateCryptoKey } from "./key-vIzWPiil.js";
5
+ import { t as doubleKnock } from "./http-DRnRwr3i.js";
6
6
  import { getLogger } from "@logtape/logtape";
7
7
  //#region src/runtime/authdocloader.ts
8
8
  const logger = getLogger([
@@ -1,8 +1,8 @@
1
1
  const { Temporal } = require("@js-temporal/polyfill");
2
2
  const { URLPattern } = require("urlpattern-polyfill");
3
- const require_docloader = require("./docloader-DWWy7Mlm.cjs");
4
- const require_key = require("./key-DgYChyco.cjs");
5
- const require_http = require("./http-kyXntNm5.cjs");
3
+ const require_docloader = require("./docloader-Q3DfzuUi.cjs");
4
+ const require_key = require("./key-DEYIxAFs.cjs");
5
+ const require_http = require("./http-DCrun8ql.cjs");
6
6
  //#region src/runtime/authdocloader.ts
7
7
  const logger = (0, require("@logtape/logtape").getLogger)([
8
8
  "fedify",
@@ -1,9 +1,9 @@
1
1
  import "@js-temporal/polyfill";
2
2
  import "urlpattern-polyfill";
3
3
  globalThis.addEventListener = () => {};
4
- import { U as getTypeId, ot as name, st as version } from "./vocab-CeumAiRh.mjs";
5
- import { i as RouterError, r as Router } from "./lookup-BzhBNUNH.mjs";
6
- import { t as InboxListenerSet } from "./inbox-gr3hW-GD.mjs";
4
+ import { U as getTypeId, ot as name, st as version } from "./vocab-rT_94Pke.mjs";
5
+ import { i as RouterError, r as Router } from "./lookup-CMYXdjVH.mjs";
6
+ import { t as InboxListenerSet } from "./inbox-pD1nbb_5.mjs";
7
7
  import { getLogger } from "@logtape/logtape";
8
8
  import { SpanKind, SpanStatusCode, trace } from "@opentelemetry/api";
9
9
  //#region src/federation/builder.ts
@@ -40,7 +40,7 @@ var FederationBuilderImpl = class {
40
40
  this.collectionTypeIds = {};
41
41
  }
42
42
  async build(options) {
43
- const { FederationImpl } = await import("./middleware-XbutA7xe.mjs");
43
+ const { FederationImpl } = await import("./middleware-H3Ce7yn3.mjs");
44
44
  const f = new FederationImpl(options);
45
45
  const trailingSlashInsensitiveValue = f.router.trailingSlashInsensitive;
46
46
  f.router = this.router.clone();
@@ -1,7 +1,7 @@
1
1
  import "@js-temporal/polyfill";
2
2
  import "urlpattern-polyfill";
3
3
  globalThis.addEventListener = () => {};
4
- import { X as getUserAgent } from "./vocab-CeumAiRh.mjs";
4
+ import { X as getUserAgent } from "./vocab-rT_94Pke.mjs";
5
5
  import { n as parseSemVer } from "./semver-CgD82xxg.mjs";
6
6
  import { getLogger } from "@logtape/logtape";
7
7
  //#region src/nodeinfo/client.ts
@@ -1,7 +1,7 @@
1
1
  const { Temporal } = require("@js-temporal/polyfill");
2
2
  const { URLPattern } = require("urlpattern-polyfill");
3
3
  Object.defineProperty(exports, Symbol.toStringTag, { value: "Module" });
4
- const require_transformers = require("../transformers-DQcMoinm.cjs");
4
+ const require_transformers = require("../transformers-CLtJ5H8o.cjs");
5
5
  exports.actorDehydrator = require_transformers.actorDehydrator;
6
6
  exports.autoIdAssigner = require_transformers.autoIdAssigner;
7
7
  exports.getDefaultActivityTransformers = require_transformers.getDefaultActivityTransformers;
@@ -1,13 +1,13 @@
1
1
  import "@js-temporal/polyfill";
2
2
  import "urlpattern-polyfill";
3
3
  globalThis.addEventListener = () => {};
4
- import { C as Person, u as Follow } from "../vocab-CeumAiRh.mjs";
5
- import { t as test } from "../testing-Csq3Xnki.mjs";
4
+ import { C as Person, u as Follow } from "../vocab-rT_94Pke.mjs";
5
+ import { t as test } from "../testing-BLIh1cXz.mjs";
6
6
  import { t as assertEquals } from "../assert_equals-Ew3jOFa3.mjs";
7
7
  import { t as assertInstanceOf } from "../assert_instance_of-C4Ri6VuN.mjs";
8
8
  import { t as assert } from "../assert-DikXweDx.mjs";
9
9
  import { t as MemoryKvStore } from "../kv-OuT2IU64.mjs";
10
- import { _ as actorDehydrator, n as FederationImpl, v as autoIdAssigner } from "../middleware-Bk0hNv-N.mjs";
10
+ import { _ as actorDehydrator, n as FederationImpl, v as autoIdAssigner } from "../middleware-BXD5WJbj.mjs";
11
11
  //#region src/compat/transformers.test.ts
12
12
  const context = new FederationImpl({ kv: new MemoryKvStore() }).createContext(new URL("http://example.com/"));
13
13
  test("autoIdAssigner", async () => {
@@ -7,7 +7,7 @@ import { lookup } from "node:dns/promises";
7
7
  import { isIP } from "node:net";
8
8
  //#region deno.json
9
9
  var name = "@fedify/fedify";
10
- var version = "1.10.6";
10
+ var version = "1.10.7";
11
11
  //#endregion
12
12
  //#region src/runtime/contexts.ts
13
13
  const preloadedContexts = {
@@ -30,7 +30,7 @@ let node_dns_promises = require("node:dns/promises");
30
30
  let node_net = require("node:net");
31
31
  //#region deno.json
32
32
  var name = "@fedify/fedify";
33
- var version = "1.10.6";
33
+ var version = "1.10.7";
34
34
  //#endregion
35
35
  //#region src/runtime/contexts.ts
36
36
  const preloadedContexts = {
@@ -1,7 +1,7 @@
1
1
  import "@js-temporal/polyfill";
2
2
  import "urlpattern-polyfill";
3
3
  globalThis.addEventListener = () => {};
4
- import { ct as __commonJSMin, dt as __toESM } from "./vocab-CeumAiRh.mjs";
4
+ import { ct as __commonJSMin, dt as __toESM } from "./vocab-rT_94Pke.mjs";
5
5
  //#region ../../node_modules/.pnpm/glob-to-regexp@0.4.1/node_modules/glob-to-regexp/index.js
6
6
  var require_glob_to_regexp = /* @__PURE__ */ __commonJSMin(((exports, module) => {
7
7
  module.exports = function(glob, opts) {
@@ -1,14 +1,14 @@
1
1
  import "@js-temporal/polyfill";
2
2
  import "urlpattern-polyfill";
3
3
  globalThis.addEventListener = () => {};
4
- import { C as Person, _ as Note, t as Activity } from "../vocab-CeumAiRh.mjs";
5
- import { t as test } from "../testing-Csq3Xnki.mjs";
4
+ import { C as Person, _ as Note, t as Activity } from "../vocab-rT_94Pke.mjs";
5
+ import { t as test } from "../testing-BLIh1cXz.mjs";
6
6
  import { t as assertEquals } from "../assert_equals-Ew3jOFa3.mjs";
7
7
  import { a as assertExists } from "../std__assert-2v7gYiZp.mjs";
8
8
  import { t as assertThrows } from "../assert_throws-BIL7gChy.mjs";
9
9
  import { t as MemoryKvStore } from "../kv-OuT2IU64.mjs";
10
10
  import { n as parseSemVer } from "../semver-CgD82xxg.mjs";
11
- import { n as createFederationBuilder } from "../builder-BqZNPx3S.mjs";
11
+ import { n as createFederationBuilder } from "../builder-CZbrDRl7.mjs";
12
12
  //#region src/federation/builder.test.ts
13
13
  test("FederationBuilder", async (t) => {
14
14
  await t.step("should build a Federation object with registered components", async () => {
@@ -1,7 +1,7 @@
1
1
  import "@js-temporal/polyfill";
2
2
  import "urlpattern-polyfill";
3
3
  globalThis.addEventListener = () => {};
4
- import { t as test } from "../testing-Csq3Xnki.mjs";
4
+ import { t as test } from "../testing-BLIh1cXz.mjs";
5
5
  import { t as assertEquals } from "../assert_equals-Ew3jOFa3.mjs";
6
6
  import "../std__assert-2v7gYiZp.mjs";
7
7
  import { n as digest, t as buildCollectionSynchronizationHeader } from "../collection-BD6-SZ6O.mjs";
@@ -1,18 +1,18 @@
1
1
  import "@js-temporal/polyfill";
2
2
  import "urlpattern-polyfill";
3
3
  globalThis.addEventListener = () => {};
4
- import { C as Person, _ as Note, o as Create } from "../vocab-CeumAiRh.mjs";
5
- import { a as mockDocumentLoader, i as createRequestContext, r as createInboxContext, t as test } from "../testing-Csq3Xnki.mjs";
4
+ import { C as Person, _ as Note, o as Create } from "../vocab-rT_94Pke.mjs";
5
+ import { a as mockDocumentLoader, i as createRequestContext, r as createInboxContext, t as test } from "../testing-BLIh1cXz.mjs";
6
6
  import { t as assertEquals } from "../assert_equals-Ew3jOFa3.mjs";
7
7
  import "../std__assert-2v7gYiZp.mjs";
8
8
  import { n as assertFalse } from "../assert_rejects-CJC9ThS-.mjs";
9
9
  import { t as assert } from "../assert-DikXweDx.mjs";
10
10
  import { t as MemoryKvStore } from "../kv-OuT2IU64.mjs";
11
- import { a as createFederation, c as handleCollection, d as handleObject, f as respondWithObject, l as handleCustomCollection, o as acceptsJsonLd, p as respondWithObjectIfAcceptable, s as handleActor, u as handleInbox } from "../middleware-Bk0hNv-N.mjs";
12
- import { s as signRequest } from "../http-pZJd5Nkb.mjs";
13
- import { t as InboxListenerSet } from "../inbox-gr3hW-GD.mjs";
11
+ import { a as createFederation, c as handleCollection, d as handleObject, f as respondWithObject, l as handleCustomCollection, o as acceptsJsonLd, p as respondWithObjectIfAcceptable, s as handleActor, u as handleInbox } from "../middleware-BXD5WJbj.mjs";
12
+ import { s as signRequest } from "../http-BRwSVBn1.mjs";
13
+ import { t as InboxListenerSet } from "../inbox-pD1nbb_5.mjs";
14
14
  import { t as createTestTracerProvider } from "../otel-0v4Zy01l.mjs";
15
- import { a as rsaPrivateKey3, c as rsaPublicKey3, s as rsaPublicKey2 } from "../keys-r0MYdjdV.mjs";
15
+ import { a as rsaPrivateKey3, c as rsaPublicKey3, s as rsaPublicKey2 } from "../keys-Co-0pK8a.mjs";
16
16
  //#region src/federation/handler.test.ts
17
17
  test("acceptsJsonLd()", () => {
18
18
  assert(acceptsJsonLd(new Request("https://example.com/", { headers: { Accept: "application/activity+json" } })));
@@ -1,14 +1,14 @@
1
1
  import "@js-temporal/polyfill";
2
2
  import "urlpattern-polyfill";
3
3
  globalThis.addEventListener = () => {};
4
- import { C as Person, o as Create, u as Follow } from "../vocab-CeumAiRh.mjs";
5
- import { a as mockDocumentLoader, t as test } from "../testing-Csq3Xnki.mjs";
4
+ import { C as Person, o as Create, u as Follow } from "../vocab-rT_94Pke.mjs";
5
+ import { a as mockDocumentLoader, t as test } from "../testing-BLIh1cXz.mjs";
6
6
  import { t as assertEquals } from "../assert_equals-Ew3jOFa3.mjs";
7
7
  import "../std__assert-2v7gYiZp.mjs";
8
8
  import { t as MemoryKvStore } from "../kv-OuT2IU64.mjs";
9
- import { a as createFederation } from "../middleware-Bk0hNv-N.mjs";
10
- import { n as signObject } from "../proof-CzEaLrMm.mjs";
11
- import { n as ed25519PrivateKey, r as ed25519PublicKey, t as ed25519Multikey } from "../keys-r0MYdjdV.mjs";
9
+ import { a as createFederation } from "../middleware-BXD5WJbj.mjs";
10
+ import { n as signObject } from "../proof-Co7YmDpv.mjs";
11
+ import { n as ed25519PrivateKey, r as ed25519PublicKey, t as ed25519Multikey } from "../keys-Co-0pK8a.mjs";
12
12
  //#region src/federation/idempotency.test.ts
13
13
  const kv = new MemoryKvStore();
14
14
  const federationOptions = {
@@ -1,11 +1,11 @@
1
1
  import "@js-temporal/polyfill";
2
2
  import "urlpattern-polyfill";
3
3
  globalThis.addEventListener = () => {};
4
- import { O as Update, m as Invite, o as Create, t as Activity, y as Offer } from "../vocab-CeumAiRh.mjs";
5
- import { t as test } from "../testing-Csq3Xnki.mjs";
4
+ import { O as Update, m as Invite, o as Create, t as Activity, y as Offer } from "../vocab-rT_94Pke.mjs";
5
+ import { t as test } from "../testing-BLIh1cXz.mjs";
6
6
  import { t as assertEquals } from "../assert_equals-Ew3jOFa3.mjs";
7
7
  import { t as assertThrows } from "../assert_throws-BIL7gChy.mjs";
8
- import { t as InboxListenerSet } from "../inbox-gr3hW-GD.mjs";
8
+ import { t as InboxListenerSet } from "../inbox-pD1nbb_5.mjs";
9
9
  //#region src/federation/inbox.test.ts
10
10
  test("InboxListenerSet", () => {
11
11
  const listeners = new InboxListenerSet();
@@ -1,13 +1,13 @@
1
1
  import "@js-temporal/polyfill";
2
2
  import "urlpattern-polyfill";
3
3
  globalThis.addEventListener = () => {};
4
- import { g as Multikey, s as CryptographicKey } from "../vocab-CeumAiRh.mjs";
5
- import { t as test } from "../testing-Csq3Xnki.mjs";
4
+ import { g as Multikey, s as CryptographicKey } from "../vocab-rT_94Pke.mjs";
5
+ import { t as test } from "../testing-BLIh1cXz.mjs";
6
6
  import { t as assertEquals } from "../assert_equals-Ew3jOFa3.mjs";
7
7
  import { t as assertInstanceOf } from "../assert_instance_of-C4Ri6VuN.mjs";
8
8
  import { t as assert } from "../assert-DikXweDx.mjs";
9
9
  import { t as MemoryKvStore } from "../kv-OuT2IU64.mjs";
10
- import { t as KvKeyCache } from "../keycache-YHrypd98.mjs";
10
+ import { t as KvKeyCache } from "../keycache-BVR9f06Y.mjs";
11
11
  //#region src/federation/keycache.test.ts
12
12
  test("KvKeyCache.set()", async () => {
13
13
  const kv = new MemoryKvStore();
@@ -1,7 +1,7 @@
1
1
  import { Temporal } from "@js-temporal/polyfill";
2
2
  import "urlpattern-polyfill";
3
3
  globalThis.addEventListener = () => {};
4
- import { t as test } from "../testing-Csq3Xnki.mjs";
4
+ import { t as test } from "../testing-BLIh1cXz.mjs";
5
5
  import { t as assertEquals } from "../assert_equals-Ew3jOFa3.mjs";
6
6
  import "../std__assert-2v7gYiZp.mjs";
7
7
  import { t as MemoryKvStore } from "../kv-OuT2IU64.mjs";
@@ -1,9 +1,9 @@
1
1
  import { Temporal } from "@js-temporal/polyfill";
2
2
  import "urlpattern-polyfill";
3
3
  globalThis.addEventListener = () => {};
4
- import { C as Person, G as FetchError, U as getTypeId, _ as Note, g as Multikey, m as Invite, n as Announce, o as Create, q as fetchDocumentLoader, t as Activity, v as Object$1, y as Offer } from "../vocab-CeumAiRh.mjs";
5
- import { i as RouterError, t as lookupObject } from "../lookup-BzhBNUNH.mjs";
6
- import { a as mockDocumentLoader, t as test } from "../testing-Csq3Xnki.mjs";
4
+ import { C as Person, G as FetchError, U as getTypeId, _ as Note, g as Multikey, m as Invite, n as Announce, o as Create, q as fetchDocumentLoader, t as Activity, v as Object$1, y as Offer } from "../vocab-rT_94Pke.mjs";
5
+ import { i as RouterError, t as lookupObject } from "../lookup-CMYXdjVH.mjs";
6
+ import { a as mockDocumentLoader, t as test } from "../testing-BLIh1cXz.mjs";
7
7
  import { t as assertEquals } from "../assert_equals-Ew3jOFa3.mjs";
8
8
  import { n as assertStrictEquals } from "../std__assert-2v7gYiZp.mjs";
9
9
  import { n as assertFalse, t as assertRejects } from "../assert_rejects-CJC9ThS-.mjs";
@@ -12,14 +12,14 @@ import { t as assertNotEquals } from "../assert_not_equals--wG9hV7u.mjs";
12
12
  import { t as assertThrows } from "../assert_throws-BIL7gChy.mjs";
13
13
  import { t as assert } from "../assert-DikXweDx.mjs";
14
14
  import { t as MemoryKvStore } from "../kv-OuT2IU64.mjs";
15
- import { a as createFederation, i as KvSpecDeterminer, n as FederationImpl, r as InboxContextImpl, t as ContextImpl } from "../middleware-Bk0hNv-N.mjs";
16
- import { l as verifyRequest, s as signRequest } from "../http-pZJd5Nkb.mjs";
17
- import { t as getAuthenticatedDocumentLoader } from "../authdocloader-A-uvTiEn.mjs";
18
- import { a as signJsonLd, o as verifyJsonLd, r as detachSignature } from "../ld-iTK8z54J.mjs";
19
- import { t as doesActorOwnKey } from "../owner-CoLrSrJE.mjs";
20
- import { n as signObject, r as verifyObject } from "../proof-CzEaLrMm.mjs";
21
- import { t as esm_default } from "../esm-CYg0RhgA.mjs";
22
- import { a as rsaPrivateKey3, c as rsaPublicKey3, i as rsaPrivateKey2, n as ed25519PrivateKey, r as ed25519PublicKey, s as rsaPublicKey2, t as ed25519Multikey } from "../keys-r0MYdjdV.mjs";
15
+ import { a as createFederation, i as KvSpecDeterminer, n as FederationImpl, r as InboxContextImpl, t as ContextImpl } from "../middleware-BXD5WJbj.mjs";
16
+ import { l as verifyRequest, s as signRequest } from "../http-BRwSVBn1.mjs";
17
+ import { t as getAuthenticatedDocumentLoader } from "../authdocloader-1Sk2bqFx.mjs";
18
+ import { a as signJsonLd, o as verifyJsonLd, r as detachSignature } from "../ld-BFaDk5gX.mjs";
19
+ import { t as doesActorOwnKey } from "../owner-CNdS8zxf.mjs";
20
+ import { n as signObject, r as verifyObject } from "../proof-Co7YmDpv.mjs";
21
+ import { t as esm_default } from "../esm-DOJg552-.mjs";
22
+ import { a as rsaPrivateKey3, c as rsaPublicKey3, i as rsaPrivateKey2, n as ed25519PrivateKey, r as ed25519PublicKey, s as rsaPublicKey2, t as ed25519Multikey } from "../keys-Co-0pK8a.mjs";
23
23
  //#region src/testing/fixtures/example.com/person.json
24
24
  var person_default = {
25
25
  "@context": ["https://www.w3.org/ns/activitystreams", "https://w3id.org/security/v1"],
@@ -1468,6 +1468,60 @@ test("ContextImpl.sendActivity()", async (t) => {
1468
1468
  type: "fanout"
1469
1469
  }]);
1470
1470
  });
1471
+ await t.step("fanout: fanoutQueue.enqueue() is awaited before sendActivity() returns", async () => {
1472
+ const asyncEnqueued = [];
1473
+ const fed = new FederationImpl({
1474
+ kv,
1475
+ contextLoader: mockDocumentLoader,
1476
+ queue: {
1477
+ enqueue(message) {
1478
+ return new Promise((resolve) => {
1479
+ setTimeout(() => {
1480
+ asyncEnqueued.push(message);
1481
+ resolve();
1482
+ }, 0);
1483
+ });
1484
+ },
1485
+ async listen() {}
1486
+ },
1487
+ manuallyStartQueue: true
1488
+ });
1489
+ fed.setActorDispatcher("/{identifier}", async (ctx, identifier) => {
1490
+ if (identifier !== "john") return null;
1491
+ const keys = await ctx.getActorKeyPairs(identifier);
1492
+ return new Person({
1493
+ id: ctx.getActorUri(identifier),
1494
+ preferredUsername: "john",
1495
+ publicKey: keys[0].cryptographicKey,
1496
+ assertionMethods: keys.map((k) => k.multikey)
1497
+ });
1498
+ }).setKeyPairsDispatcher((_ctx, identifier) => {
1499
+ if (identifier !== "john") return [];
1500
+ return [{
1501
+ privateKey: rsaPrivateKey2,
1502
+ publicKey: rsaPublicKey2.publicKey
1503
+ }, {
1504
+ privateKey: ed25519PrivateKey,
1505
+ publicKey: ed25519PublicKey.publicKey
1506
+ }];
1507
+ });
1508
+ const ctx3 = new ContextImpl({
1509
+ data: void 0,
1510
+ federation: fed,
1511
+ url: new URL("https://example.com/"),
1512
+ documentLoader: fetchDocumentLoader,
1513
+ contextLoader: fetchDocumentLoader
1514
+ });
1515
+ const activity = new Create({
1516
+ id: new URL("https://example.com/activity/1"),
1517
+ actor: new URL("https://example.com/person")
1518
+ });
1519
+ await ctx3.sendActivity({ username: "john" }, {
1520
+ id: new URL("https://example.com/recipient"),
1521
+ inboxId: new URL("https://example.com/inbox")
1522
+ }, activity, { fanout: "force" });
1523
+ assertEquals(asyncEnqueued.length, 1, "fanoutQueue.enqueue() must be awaited before sendActivity() returns");
1524
+ });
1471
1525
  collectionSyncHeader = null;
1472
1526
  await t.step("followers collection without syncCollection", async () => {
1473
1527
  const ctx = new ContextImpl({
@@ -1,8 +1,8 @@
1
1
  const { Temporal } = require("@js-temporal/polyfill");
2
2
  const { URLPattern } = require("urlpattern-polyfill");
3
3
  Object.defineProperty(exports, Symbol.toStringTag, { value: "Module" });
4
- require("../docloader-DWWy7Mlm.cjs");
5
- const require_middleware = require("../middleware-CZOiI7j6.cjs");
4
+ require("../docloader-Q3DfzuUi.cjs");
5
+ const require_middleware = require("../middleware-BhMQrJXH.cjs");
6
6
  let es_toolkit = require("es-toolkit");
7
7
  //#region src/federation/kv.ts
8
8
  /**
@@ -1,6 +1,6 @@
1
1
  import { Temporal } from "@js-temporal/polyfill";
2
2
  import "urlpattern-polyfill";
3
- import { a as respondWithObjectIfAcceptable, c as createFederationBuilder, i as respondWithObject, l as Router, o as buildCollectionSynchronizationHeader, r as createExponentialBackoffPolicy, s as digest, t as createFederation, u as RouterError } from "../middleware-Df-QFT32.js";
3
+ import { a as respondWithObjectIfAcceptable, c as createFederationBuilder, i as respondWithObject, l as Router, o as buildCollectionSynchronizationHeader, r as createExponentialBackoffPolicy, s as digest, t as createFederation, u as RouterError } from "../middleware-CmA2E9Bu.js";
4
4
  import { isEqual } from "es-toolkit";
5
5
  //#region src/federation/kv.ts
6
6
  /**
@@ -1,7 +1,7 @@
1
1
  import { Temporal } from "@js-temporal/polyfill";
2
2
  import "urlpattern-polyfill";
3
3
  globalThis.addEventListener = () => {};
4
- import { t as test } from "../testing-Csq3Xnki.mjs";
4
+ import { t as test } from "../testing-BLIh1cXz.mjs";
5
5
  import { t as assertEquals } from "../assert_equals-Ew3jOFa3.mjs";
6
6
  import { i as assertGreaterOrEqual, r as assertGreater } from "../std__assert-2v7gYiZp.mjs";
7
7
  import { n as assertFalse } from "../assert_rejects-CJC9ThS-.mjs";
@@ -1,7 +1,7 @@
1
1
  import { Temporal } from "@js-temporal/polyfill";
2
2
  import "urlpattern-polyfill";
3
3
  globalThis.addEventListener = () => {};
4
- import { t as test } from "../testing-Csq3Xnki.mjs";
4
+ import { t as test } from "../testing-BLIh1cXz.mjs";
5
5
  import { l as AssertionError, t as assertEquals } from "../assert_equals-Ew3jOFa3.mjs";
6
6
  import { t as assertNotEquals } from "../assert_not_equals--wG9hV7u.mjs";
7
7
  import { t as createExponentialBackoffPolicy } from "../retry-Ddbq3AcK.mjs";
@@ -1,8 +1,8 @@
1
1
  import "@js-temporal/polyfill";
2
2
  import "urlpattern-polyfill";
3
3
  globalThis.addEventListener = () => {};
4
- import { i as RouterError, r as Router } from "../lookup-BzhBNUNH.mjs";
5
- import { t as test } from "../testing-Csq3Xnki.mjs";
4
+ import { i as RouterError, r as Router } from "../lookup-CMYXdjVH.mjs";
5
+ import { t as test } from "../testing-BLIh1cXz.mjs";
6
6
  import { t as assertEquals } from "../assert_equals-Ew3jOFa3.mjs";
7
7
  import "../std__assert-2v7gYiZp.mjs";
8
8
  import { n as assertFalse } from "../assert_rejects-CJC9ThS-.mjs";
@@ -1,19 +1,19 @@
1
1
  import "@js-temporal/polyfill";
2
2
  import "urlpattern-polyfill";
3
3
  globalThis.addEventListener = () => {};
4
- import { C as Person, E as Service, d as Group, l as Endpoints, r as Application, t as Activity } from "../vocab-CeumAiRh.mjs";
5
- import { a as mockDocumentLoader, t as test } from "../testing-Csq3Xnki.mjs";
4
+ import { C as Person, E as Service, d as Group, l as Endpoints, r as Application, t as Activity } from "../vocab-rT_94Pke.mjs";
5
+ import { a as mockDocumentLoader, t as test } from "../testing-BLIh1cXz.mjs";
6
6
  import { t as assertEquals } from "../assert_equals-Ew3jOFa3.mjs";
7
7
  import "../std__assert-2v7gYiZp.mjs";
8
8
  import { n as assertFalse, t as assertRejects } from "../assert_rejects-CJC9ThS-.mjs";
9
9
  import { t as assertNotEquals } from "../assert_not_equals--wG9hV7u.mjs";
10
10
  import { t as assert } from "../assert-DikXweDx.mjs";
11
- import { l as verifyRequest } from "../http-pZJd5Nkb.mjs";
12
- import { t as doesActorOwnKey } from "../owner-CoLrSrJE.mjs";
13
- import { n as sendActivity, t as extractInboxes } from "../send-vtEBiKbR.mjs";
14
- import { t as esm_default } from "../esm-CYg0RhgA.mjs";
11
+ import { l as verifyRequest } from "../http-BRwSVBn1.mjs";
12
+ import { t as doesActorOwnKey } from "../owner-CNdS8zxf.mjs";
13
+ import { n as sendActivity, t as extractInboxes } from "../send-BRCWNcMa.mjs";
14
+ import { t as esm_default } from "../esm-DOJg552-.mjs";
15
15
  import { t as createTestTracerProvider } from "../otel-0v4Zy01l.mjs";
16
- import { i as rsaPrivateKey2, n as ed25519PrivateKey, s as rsaPublicKey2, t as ed25519Multikey } from "../keys-r0MYdjdV.mjs";
16
+ import { i as rsaPrivateKey2, n as ed25519PrivateKey, s as rsaPublicKey2, t as ed25519Multikey } from "../keys-Co-0pK8a.mjs";
17
17
  //#region src/federation/send.test.ts
18
18
  test("extractInboxes()", () => {
19
19
  const recipients = [
@@ -1,8 +1,8 @@
1
1
  import { Temporal } from "@js-temporal/polyfill";
2
2
  import "urlpattern-polyfill";
3
3
  globalThis.addEventListener = () => {};
4
- import { G as FetchError, ot as name, s as CryptographicKey, st as version } from "./vocab-CeumAiRh.mjs";
5
- import { a as validateCryptoKey, n as fetchKey } from "./key-Db4XYUx7.mjs";
4
+ import { G as FetchError, ot as name, s as CryptographicKey, st as version } from "./vocab-rT_94Pke.mjs";
5
+ import { a as validateCryptoKey, n as fetchKey } from "./key-DdL5Oc59.mjs";
6
6
  import { getLogger } from "@logtape/logtape";
7
7
  import { SpanStatusCode, trace } from "@opentelemetry/api";
8
8
  import { decodeBase64, encodeBase64 } from "byte-encodings/base64";
@@ -1,8 +1,8 @@
1
1
  const { Temporal } = require("@js-temporal/polyfill");
2
2
  const { URLPattern } = require("urlpattern-polyfill");
3
- const require_docloader = require("./docloader-DWWy7Mlm.cjs");
4
- const require_actor = require("./actor-Bhyv1XG8.cjs");
5
- const require_key = require("./key-DgYChyco.cjs");
3
+ const require_docloader = require("./docloader-Q3DfzuUi.cjs");
4
+ const require_actor = require("./actor-BGIAXtRd.cjs");
5
+ const require_key = require("./key-DEYIxAFs.cjs");
6
6
  let _logtape_logtape = require("@logtape/logtape");
7
7
  let _opentelemetry_api = require("@opentelemetry/api");
8
8
  let byte_encodings_base64 = require("byte-encodings/base64");
@@ -1,8 +1,8 @@
1
1
  import { Temporal } from "@js-temporal/polyfill";
2
2
  import "urlpattern-polyfill";
3
- import { d as name, f as version, t as FetchError } from "./docloader-LthfAmat.js";
4
- import { y as CryptographicKey } from "./actor-D7XOmVKd.js";
5
- import { n as fetchKey, o as validateCryptoKey } from "./key-BR2q2bCE.js";
3
+ import { d as name, f as version, t as FetchError } from "./docloader-Dtaju6oI.js";
4
+ import { y as CryptographicKey } from "./actor-Cujbx4Zv.js";
5
+ import { n as fetchKey, o as validateCryptoKey } from "./key-vIzWPiil.js";
6
6
  import { getLogger } from "@logtape/logtape";
7
7
  import { SpanStatusCode, trace } from "@opentelemetry/api";
8
8
  import { decodeBase64, encodeBase64 } from "byte-encodings/base64";
@@ -1,7 +1,7 @@
1
1
  import { Temporal } from "@js-temporal/polyfill";
2
2
  import "urlpattern-polyfill";
3
3
  globalThis.addEventListener = () => {};
4
- import { U as getTypeId, ot as name, st as version, t as Activity } from "./vocab-CeumAiRh.mjs";
4
+ import { U as getTypeId, ot as name, st as version, t as Activity } from "./vocab-rT_94Pke.mjs";
5
5
  import { getLogger } from "@logtape/logtape";
6
6
  import { SpanKind, SpanStatusCode, context, propagation, trace } from "@opentelemetry/api";
7
7
  //#region src/federation/inbox.ts
@@ -1,4 +1,4 @@
1
1
  const { Temporal } = require("@js-temporal/polyfill");
2
2
  const { URLPattern } = require("urlpattern-polyfill");
3
- const require_key = require("./key-DgYChyco.cjs");
3
+ const require_key = require("./key-DEYIxAFs.cjs");
4
4
  exports.validateCryptoKey = require_key.validateCryptoKey;
@@ -1,7 +1,7 @@
1
1
  const { Temporal } = require("@js-temporal/polyfill");
2
2
  const { URLPattern } = require("urlpattern-polyfill");
3
- const require_docloader = require("./docloader-DWWy7Mlm.cjs");
4
- const require_actor = require("./actor-Bhyv1XG8.cjs");
3
+ const require_docloader = require("./docloader-Q3DfzuUi.cjs");
4
+ const require_actor = require("./actor-BGIAXtRd.cjs");
5
5
  let _logtape_logtape = require("@logtape/logtape");
6
6
  let _opentelemetry_api = require("@opentelemetry/api");
7
7
  //#region src/sig/key.ts
@@ -1,5 +1,5 @@
1
1
  import "@js-temporal/polyfill";
2
2
  import "urlpattern-polyfill";
3
3
  globalThis.addEventListener = () => {};
4
- import { a as validateCryptoKey } from "./key-Db4XYUx7.mjs";
4
+ import { a as validateCryptoKey } from "./key-DdL5Oc59.mjs";
5
5
  export { validateCryptoKey };
@@ -1,8 +1,8 @@
1
1
  import "@js-temporal/polyfill";
2
2
  import "urlpattern-polyfill";
3
3
  globalThis.addEventListener = () => {};
4
- import { J as getDocumentLoader, ot as name, s as CryptographicKey, st as version, v as Object$1 } from "./vocab-CeumAiRh.mjs";
5
- import { i as isActor } from "./actor-Cl985C7Q.mjs";
4
+ import { J as getDocumentLoader, ot as name, s as CryptographicKey, st as version, v as Object$1 } from "./vocab-rT_94Pke.mjs";
5
+ import { i as isActor } from "./actor-C-_2S5Mn.mjs";
6
6
  import { getLogger } from "@logtape/logtape";
7
7
  import { SpanKind, SpanStatusCode, trace } from "@opentelemetry/api";
8
8
  //#region src/sig/key.ts
@@ -1,8 +1,8 @@
1
1
  import "@js-temporal/polyfill";
2
2
  import "urlpattern-polyfill";
3
3
  import { t as __exportAll } from "./rolldown-runtime-C7fyD9f2.js";
4
- import { d as name, f as version, i as getDocumentLoader } from "./docloader-LthfAmat.js";
5
- import { i as isActor, q as Object$1, y as CryptographicKey } from "./actor-D7XOmVKd.js";
4
+ import { d as name, f as version, i as getDocumentLoader } from "./docloader-Dtaju6oI.js";
5
+ import { i as isActor, q as Object$1, y as CryptographicKey } from "./actor-Cujbx4Zv.js";
6
6
  import { getLogger } from "@logtape/logtape";
7
7
  import { SpanKind, SpanStatusCode, trace } from "@opentelemetry/api";
8
8
  //#region src/sig/key.ts
@@ -1,7 +1,7 @@
1
1
  import { Temporal } from "@js-temporal/polyfill";
2
2
  import "urlpattern-polyfill";
3
3
  globalThis.addEventListener = () => {};
4
- import { g as Multikey, s as CryptographicKey } from "./vocab-CeumAiRh.mjs";
4
+ import { g as Multikey, s as CryptographicKey } from "./vocab-rT_94Pke.mjs";
5
5
  //#region src/federation/keycache.ts
6
6
  const NULL_KEY_CACHE_VALUE = { _fedify: "key-unavailable" };
7
7
  const NULL_KEY_CACHE_TTL = Temporal.Duration.from({ minutes: 5 });
@@ -1,7 +1,7 @@
1
1
  import "@js-temporal/polyfill";
2
2
  import "urlpattern-polyfill";
3
3
  globalThis.addEventListener = () => {};
4
- import { I as importSpki, g as Multikey, s as CryptographicKey } from "./vocab-CeumAiRh.mjs";
4
+ import { I as importSpki, g as Multikey, s as CryptographicKey } from "./vocab-rT_94Pke.mjs";
5
5
  //#region src/testing/keys.ts
6
6
  const rsaPublicKey1 = new CryptographicKey({
7
7
  id: new URL("https://example.com/key"),
@@ -1,8 +1,8 @@
1
1
  import "@js-temporal/polyfill";
2
2
  import "urlpattern-polyfill";
3
3
  globalThis.addEventListener = () => {};
4
- import { J as getDocumentLoader, U as getTypeId, ot as name, s as CryptographicKey, st as version, t as Activity, v as Object$1 } from "./vocab-CeumAiRh.mjs";
5
- import { a as validateCryptoKey, n as fetchKey } from "./key-Db4XYUx7.mjs";
4
+ import { J as getDocumentLoader, U as getTypeId, ot as name, s as CryptographicKey, st as version, t as Activity, v as Object$1 } from "./vocab-rT_94Pke.mjs";
5
+ import { a as validateCryptoKey, n as fetchKey } from "./key-DdL5Oc59.mjs";
6
6
  import { getLogger } from "@logtape/logtape";
7
7
  import { SpanStatusCode, trace } from "@opentelemetry/api";
8
8
  import jsonld from "jsonld";
@@ -1,7 +1,7 @@
1
1
  import { Temporal } from "@js-temporal/polyfill";
2
2
  import "urlpattern-polyfill";
3
3
  globalThis.addEventListener = () => {};
4
- import { J as getDocumentLoader, U as getTypeId, W as lookupWebFinger, ot as name, st as version, v as Object$1 } from "./vocab-CeumAiRh.mjs";
4
+ import { J as getDocumentLoader, U as getTypeId, W as lookupWebFinger, ot as name, st as version, v as Object$1 } from "./vocab-rT_94Pke.mjs";
5
5
  import { getLogger } from "@logtape/logtape";
6
6
  import { SpanStatusCode, trace } from "@opentelemetry/api";
7
7
  import { cloneDeep, delay } from "es-toolkit";
@@ -1,6 +1,6 @@
1
1
  const { Temporal } = require("@js-temporal/polyfill");
2
2
  const { URLPattern } = require("urlpattern-polyfill");
3
- const require_docloader = require("./docloader-DWWy7Mlm.cjs");
3
+ const require_docloader = require("./docloader-Q3DfzuUi.cjs");
4
4
  let _logtape_logtape = require("@logtape/logtape");
5
5
  let _opentelemetry_api = require("@opentelemetry/api");
6
6
  //#region src/webfinger/lookup.ts
@@ -1,6 +1,6 @@
1
1
  import "@js-temporal/polyfill";
2
2
  import "urlpattern-polyfill";
3
- import { d as name, f as version, l as UrlError, o as getUserAgent, u as validatePublicUrl } from "./docloader-LthfAmat.js";
3
+ import { d as name, f as version, l as UrlError, o as getUserAgent, u as validatePublicUrl } from "./docloader-Dtaju6oI.js";
4
4
  import { getLogger } from "@logtape/logtape";
5
5
  import { SpanKind, SpanStatusCode, trace } from "@opentelemetry/api";
6
6
  //#region src/webfinger/lookup.ts
@@ -1,4 +1,4 @@
1
1
  const { Temporal } = require("@js-temporal/polyfill");
2
2
  const { URLPattern } = require("urlpattern-polyfill");
3
- const require_middleware = require("./middleware-CZOiI7j6.cjs");
3
+ const require_middleware = require("./middleware-BhMQrJXH.cjs");
4
4
  exports.FederationImpl = require_middleware.FederationImpl;