@fedify/fedify 2.3.0-dev.1079 → 2.3.0-dev.1110

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 (86) hide show
  1. package/dist/{builder-DqT-OPZ8.mjs → builder-B-Y6fwSu.mjs} +2 -2
  2. package/dist/{chunk-nlSIicah.js → chunk-CRNNMoPX.js} +2 -2
  3. package/dist/{client-z-8dc-e1.d.cts → client-CAM_bQXx.d.cts} +1 -0
  4. package/dist/{client-AtlibPOU.d.ts → client-CSddvgWN.d.ts} +1 -2
  5. package/dist/compat/mod.d.cts +2 -1
  6. package/dist/compat/mod.d.ts +2 -3
  7. package/dist/compat/mod.js +3 -3
  8. package/dist/compat/transformers.test.mjs +1 -1
  9. package/dist/{context-DrNqYkPw.d.ts → context-C0C_sRha.d.cts} +6 -7
  10. package/dist/{context-BKLGj9QO.d.cts → context-Dqgt8saU.d.ts} +6 -5
  11. package/dist/{deno-BxqkYxIf.mjs → deno-hqC7tKJn.mjs} +1 -1
  12. package/dist/{docloader-vsZP01ww.mjs → docloader-BOEuuXkX.mjs} +2 -2
  13. package/dist/federation/builder.test.mjs +1 -1
  14. package/dist/federation/handler.test.mjs +84 -2
  15. package/dist/federation/idempotency.test.mjs +2 -2
  16. package/dist/federation/middleware.test.mjs +383 -16
  17. package/dist/federation/mod.cjs +1 -1
  18. package/dist/federation/mod.d.cts +4 -3
  19. package/dist/federation/mod.d.ts +4 -5
  20. package/dist/federation/mod.js +2 -2
  21. package/dist/federation/send.test.mjs +3 -3
  22. package/dist/federation/webfinger.test.mjs +1 -1
  23. package/dist/{http-CrGuipxe.d.cts → http-BDZeS5om.d.ts} +2 -1
  24. package/dist/{http-DM4ZAFCe.mjs → http-BLopFpvC.mjs} +58 -10
  25. package/dist/{http-aQzN9Ayi.d.ts → http-C87EWkO0.d.cts} +2 -3
  26. package/dist/{http-DQ25_ruv.cjs → http-DV0il3vk.cjs} +57 -9
  27. package/dist/{http-b__OS_rJ.js → http-O8MYWwk8.js} +58 -10
  28. package/dist/{key-BNp_b9oE.mjs → key-DW1EVmtP.mjs} +1 -1
  29. package/dist/{kv-CbLNp3zQ.d.cts → kv-D6hNiMTK.d.ts} +1 -0
  30. package/dist/{kv-cache-D5vjOi5y.js → kv-cache-C3NWWiTg.js} +2 -2
  31. package/dist/{kv-cache-EaVpV2xQ.mjs → kv-cache-CiiNwT6W.mjs} +1 -1
  32. package/dist/{kv-cache-DzctboPD.cjs → kv-cache-Dya-TWMe.cjs} +2 -2
  33. package/dist/{kv-GFYnFoOl.d.ts → kv-gJ8LYbxX.d.cts} +1 -3
  34. package/dist/{ld-L9w529xq.mjs → ld-BNkk2Yal.mjs} +2 -2
  35. package/dist/{middleware-DZNHpEbh.js → middleware-CjzI3aYo.js} +309 -111
  36. package/dist/{middleware-CpCSD43m.mjs → middleware-D6FbOjuK.mjs} +1 -1
  37. package/dist/{middleware-CTdNwf_s.mjs → middleware-DA2WTBr4.mjs} +188 -114
  38. package/dist/{middleware-CMF242Rg.cjs → middleware-DUWeXjZR.cjs} +305 -107
  39. package/dist/{mod-CLgIXe9w.d.ts → mod-B0rWmfW5.d.cts} +4 -5
  40. package/dist/{mod-CMEbIaNh.d.cts → mod-BhU_H1I_.d.ts} +4 -3
  41. package/dist/{mod-B8Z8mBLk.d.ts → mod-CLPnQPsv.d.cts} +2 -3
  42. package/dist/{mod-Cr3f-ACa.d.cts → mod-DHO9lk3D.d.ts} +3 -2
  43. package/dist/{mod-CR8soWa9.d.ts → mod-DXY9JF28.d.cts} +3 -4
  44. package/dist/{mod-DClCOv0M.d.cts → mod-Dx3-hqyo.d.ts} +2 -1
  45. package/dist/mod.cjs +4 -4
  46. package/dist/mod.d.cts +9 -8
  47. package/dist/mod.d.ts +9 -10
  48. package/dist/mod.js +9 -9
  49. package/dist/nodeinfo/handler.test.mjs +1 -1
  50. package/dist/nodeinfo/mod.d.cts +2 -1
  51. package/dist/nodeinfo/mod.d.ts +2 -3
  52. package/dist/nodeinfo/mod.js +3 -3
  53. package/dist/otel/mod.d.cts +2 -1
  54. package/dist/otel/mod.d.ts +2 -3
  55. package/dist/otel/mod.js +2 -2
  56. package/dist/{owner-CptqhsOy.d.cts → owner-CnngXDNJ.d.ts} +2 -1
  57. package/dist/{owner-74ARJ5TL.d.ts → owner-DEvZuyOE.d.cts} +2 -3
  58. package/dist/{owner-C30LGgMz.mjs → owner-jvJAtR5O.mjs} +2 -2
  59. package/dist/{proof-CO1qAbN8.js → proof-5kT7OUPV.js} +2 -2
  60. package/dist/{proof-zrLeLWgt.cjs → proof-BD92WeqV.cjs} +1 -1
  61. package/dist/{proof-BjToRsXF.mjs → proof-mfmHH9j0.mjs} +2 -2
  62. package/dist/runtime/mod.d.cts +1 -0
  63. package/dist/runtime/mod.d.ts +1 -2
  64. package/dist/runtime/mod.js +3 -3
  65. package/dist/{send-DzbMznU6.mjs → send-hokVCPu6.mjs} +127 -3
  66. package/dist/sig/http.test.mjs +120 -2
  67. package/dist/sig/key.test.mjs +1 -1
  68. package/dist/sig/ld.test.mjs +2 -2
  69. package/dist/sig/mod.cjs +2 -2
  70. package/dist/sig/mod.d.cts +4 -3
  71. package/dist/sig/mod.d.ts +4 -5
  72. package/dist/sig/mod.js +4 -4
  73. package/dist/sig/owner.test.mjs +1 -1
  74. package/dist/sig/proof.test.mjs +1 -1
  75. package/dist/{transformers-ve6e2xcg.js → transformers-BGMIq1cs.js} +2 -2
  76. package/dist/{types-hvL8ElAs.js → types-CAY3OdLq.js} +2 -2
  77. package/dist/utils/docloader.test.mjs +2 -2
  78. package/dist/utils/kv-cache.test.mjs +1 -1
  79. package/dist/utils/mod.cjs +1 -1
  80. package/dist/utils/mod.d.cts +2 -1
  81. package/dist/utils/mod.d.ts +2 -3
  82. package/dist/utils/mod.js +3 -3
  83. package/dist/vocab/mod.d.cts +1 -0
  84. package/dist/vocab/mod.d.ts +1 -2
  85. package/dist/vocab/mod.js +2 -2
  86. package/package.json +7 -7
@@ -1,8 +1,7 @@
1
- import { Temporal } from "@js-temporal/polyfill";
2
- import { URLPattern } from "urlpattern-polyfill";
1
+ /// <reference lib="esnext.temporal" />
3
2
  import { CryptographicKey, Multikey } from "@fedify/vocab";
4
- import { TracerProvider } from "@opentelemetry/api";
5
3
  import { DocumentLoader } from "@fedify/vocab-runtime";
4
+ import { TracerProvider } from "@opentelemetry/api";
6
5
 
7
6
  //#region src/sig/key.d.ts
8
7
  /**
@@ -11,7 +11,7 @@ let _opentelemetry_semantic_conventions = require("@opentelemetry/semantic-conve
11
11
  let byte_encodings_base64 = require("byte-encodings/base64");
12
12
  //#region deno.json
13
13
  var name = "@fedify/fedify";
14
- var version = "2.3.0-dev.1079+36ac23d1";
14
+ var version = "2.3.0-dev.1110+3ba84466";
15
15
  //#endregion
16
16
  //#region src/sig/accept.ts
17
17
  /**
@@ -497,6 +497,7 @@ async function fetchKeyInternal(keyId, cls, options = {}) {
497
497
  //#endregion
498
498
  //#region src/sig/http.ts
499
499
  const DEFAULT_MAX_REDIRECTION = 20;
500
+ const DOUBLE_KNOCK_TRANSPORT_RETRY_DELAY_MS = 100;
500
501
  /**
501
502
  * Signs a request using the given private key.
502
503
  * @param request The request to sign.
@@ -1325,6 +1326,59 @@ function createRedirectRequest(request, location, body) {
1325
1326
  cache: request.cache
1326
1327
  });
1327
1328
  }
1329
+ async function fetchDoubleKnockRequest(request, signedRequest, signal) {
1330
+ const maxAttempts = request.method === "GET" || request.method === "HEAD" ? 2 : 1;
1331
+ for (let attempt = 1;; attempt++) try {
1332
+ return await fetch(signedRequest, {
1333
+ redirect: "manual",
1334
+ signal
1335
+ });
1336
+ } catch (error) {
1337
+ const abortedSignal = getAbortedSignal(signal, request.signal, signedRequest.signal);
1338
+ if (abortedSignal != null) throw getAbortReason(abortedSignal);
1339
+ if (isAbortError(error)) throw error;
1340
+ if (attempt >= maxAttempts) throw createFetchError(request.url, error);
1341
+ await sleep(DOUBLE_KNOCK_TRANSPORT_RETRY_DELAY_MS, signal, request.signal, signedRequest.signal);
1342
+ }
1343
+ }
1344
+ function createFetchError(url, cause) {
1345
+ const error = new _fedify_vocab_runtime.FetchError(url, cause instanceof Error ? cause.message : String(cause));
1346
+ error.cause = cause;
1347
+ return error;
1348
+ }
1349
+ function isAbortError(error) {
1350
+ return error instanceof Error && error.name === "AbortError";
1351
+ }
1352
+ async function sleep(ms, ...signals) {
1353
+ const abortSignals = signals.filter((signal) => signal != null);
1354
+ const abortedSignal = getAbortedSignal(...abortSignals);
1355
+ if (abortedSignal != null) throw getAbortReason(abortedSignal);
1356
+ if (abortSignals.length < 1) {
1357
+ await new Promise((resolve) => setTimeout(resolve, ms));
1358
+ return;
1359
+ }
1360
+ await new Promise((resolve, reject) => {
1361
+ const removeAbortListeners = () => {
1362
+ for (const signal of abortSignals) signal.removeEventListener("abort", handleAbort);
1363
+ };
1364
+ const timeout = setTimeout(() => {
1365
+ removeAbortListeners();
1366
+ resolve();
1367
+ }, ms);
1368
+ function handleAbort(event) {
1369
+ clearTimeout(timeout);
1370
+ removeAbortListeners();
1371
+ reject(getAbortReason(event.currentTarget));
1372
+ }
1373
+ for (const signal of abortSignals) signal.addEventListener("abort", handleAbort, { once: true });
1374
+ });
1375
+ }
1376
+ function getAbortedSignal(...signals) {
1377
+ return signals.find((signal) => signal?.aborted);
1378
+ }
1379
+ function getAbortReason(signal) {
1380
+ return signal.reason ?? new DOMException("The operation was aborted.", "AbortError");
1381
+ }
1328
1382
  /**
1329
1383
  * Performs a double-knock request to the given URL. For the details of
1330
1384
  * double-knocking, see
@@ -1351,10 +1405,7 @@ async function doubleKnockInternal(request, identity, options, redirected = 0, v
1351
1405
  body
1352
1406
  });
1353
1407
  log?.(signedRequest);
1354
- let response = await fetch(signedRequest, {
1355
- redirect: "manual",
1356
- signal
1357
- });
1408
+ let response = await fetchDoubleKnockRequest(request, signedRequest, signal);
1358
1409
  if (response.status >= 300 && response.status < 400 && response.headers.has("Location")) {
1359
1410
  if (redirected >= maximumRedirection) throw new _fedify_vocab_runtime.FetchError(request.url, `Too many redirections (${redirected + 1})`);
1360
1411
  const redirectRequest = createRedirectRequest(request, response.headers.get("Location"), body);
@@ -1429,10 +1480,7 @@ async function doubleKnockInternal(request, identity, options, redirected = 0, v
1429
1480
  body
1430
1481
  });
1431
1482
  log?.(signedRequest);
1432
- response = await fetch(signedRequest, {
1433
- redirect: "manual",
1434
- signal
1435
- });
1483
+ response = await fetchDoubleKnockRequest(request, signedRequest, signal);
1436
1484
  if (response.status >= 300 && response.status < 400 && response.headers.has("Location")) {
1437
1485
  if (redirected >= maximumRedirection) throw new _fedify_vocab_runtime.FetchError(request.url, `Too many redirections (${redirected + 1})`);
1438
1486
  const redirectRequest = createRedirectRequest(request, response.headers.get("Location"), body);
@@ -1,5 +1,5 @@
1
1
  import { Temporal } from "@js-temporal/polyfill";
2
- import "urlpattern-polyfill";
2
+ import { URLPattern } from "urlpattern-polyfill";
3
3
  import { getLogger } from "@logtape/logtape";
4
4
  import { CryptographicKey, Object as Object$1, isActor } from "@fedify/vocab";
5
5
  import { SpanKind, SpanStatusCode, trace } from "@opentelemetry/api";
@@ -10,7 +10,7 @@ import { ATTR_HTTP_REQUEST_HEADER, ATTR_HTTP_REQUEST_METHOD, ATTR_URL_FULL } fro
10
10
  import { decodeBase64, encodeBase64 } from "byte-encodings/base64";
11
11
  //#region deno.json
12
12
  var name = "@fedify/fedify";
13
- var version = "2.3.0-dev.1079+36ac23d1";
13
+ var version = "2.3.0-dev.1110+3ba84466";
14
14
  //#endregion
15
15
  //#region src/sig/accept.ts
16
16
  /**
@@ -496,6 +496,7 @@ async function fetchKeyInternal(keyId, cls, options = {}) {
496
496
  //#endregion
497
497
  //#region src/sig/http.ts
498
498
  const DEFAULT_MAX_REDIRECTION = 20;
499
+ const DOUBLE_KNOCK_TRANSPORT_RETRY_DELAY_MS = 100;
499
500
  /**
500
501
  * Signs a request using the given private key.
501
502
  * @param request The request to sign.
@@ -1324,6 +1325,59 @@ function createRedirectRequest(request, location, body) {
1324
1325
  cache: request.cache
1325
1326
  });
1326
1327
  }
1328
+ async function fetchDoubleKnockRequest(request, signedRequest, signal) {
1329
+ const maxAttempts = request.method === "GET" || request.method === "HEAD" ? 2 : 1;
1330
+ for (let attempt = 1;; attempt++) try {
1331
+ return await fetch(signedRequest, {
1332
+ redirect: "manual",
1333
+ signal
1334
+ });
1335
+ } catch (error) {
1336
+ const abortedSignal = getAbortedSignal(signal, request.signal, signedRequest.signal);
1337
+ if (abortedSignal != null) throw getAbortReason(abortedSignal);
1338
+ if (isAbortError(error)) throw error;
1339
+ if (attempt >= maxAttempts) throw createFetchError(request.url, error);
1340
+ await sleep(DOUBLE_KNOCK_TRANSPORT_RETRY_DELAY_MS, signal, request.signal, signedRequest.signal);
1341
+ }
1342
+ }
1343
+ function createFetchError(url, cause) {
1344
+ const error = new FetchError(url, cause instanceof Error ? cause.message : String(cause));
1345
+ error.cause = cause;
1346
+ return error;
1347
+ }
1348
+ function isAbortError(error) {
1349
+ return error instanceof Error && error.name === "AbortError";
1350
+ }
1351
+ async function sleep(ms, ...signals) {
1352
+ const abortSignals = signals.filter((signal) => signal != null);
1353
+ const abortedSignal = getAbortedSignal(...abortSignals);
1354
+ if (abortedSignal != null) throw getAbortReason(abortedSignal);
1355
+ if (abortSignals.length < 1) {
1356
+ await new Promise((resolve) => setTimeout(resolve, ms));
1357
+ return;
1358
+ }
1359
+ await new Promise((resolve, reject) => {
1360
+ const removeAbortListeners = () => {
1361
+ for (const signal of abortSignals) signal.removeEventListener("abort", handleAbort);
1362
+ };
1363
+ const timeout = setTimeout(() => {
1364
+ removeAbortListeners();
1365
+ resolve();
1366
+ }, ms);
1367
+ function handleAbort(event) {
1368
+ clearTimeout(timeout);
1369
+ removeAbortListeners();
1370
+ reject(getAbortReason(event.currentTarget));
1371
+ }
1372
+ for (const signal of abortSignals) signal.addEventListener("abort", handleAbort, { once: true });
1373
+ });
1374
+ }
1375
+ function getAbortedSignal(...signals) {
1376
+ return signals.find((signal) => signal?.aborted);
1377
+ }
1378
+ function getAbortReason(signal) {
1379
+ return signal.reason ?? new DOMException("The operation was aborted.", "AbortError");
1380
+ }
1327
1381
  /**
1328
1382
  * Performs a double-knock request to the given URL. For the details of
1329
1383
  * double-knocking, see
@@ -1350,10 +1404,7 @@ async function doubleKnockInternal(request, identity, options, redirected = 0, v
1350
1404
  body
1351
1405
  });
1352
1406
  log?.(signedRequest);
1353
- let response = await fetch(signedRequest, {
1354
- redirect: "manual",
1355
- signal
1356
- });
1407
+ let response = await fetchDoubleKnockRequest(request, signedRequest, signal);
1357
1408
  if (response.status >= 300 && response.status < 400 && response.headers.has("Location")) {
1358
1409
  if (redirected >= maximumRedirection) throw new FetchError(request.url, `Too many redirections (${redirected + 1})`);
1359
1410
  const redirectRequest = createRedirectRequest(request, response.headers.get("Location"), body);
@@ -1428,10 +1479,7 @@ async function doubleKnockInternal(request, identity, options, redirected = 0, v
1428
1479
  body
1429
1480
  });
1430
1481
  log?.(signedRequest);
1431
- response = await fetch(signedRequest, {
1432
- redirect: "manual",
1433
- signal
1434
- });
1482
+ response = await fetchDoubleKnockRequest(request, signedRequest, signal);
1435
1483
  if (response.status >= 300 && response.status < 400 && response.headers.has("Location")) {
1436
1484
  if (redirected >= maximumRedirection) throw new FetchError(request.url, `Too many redirections (${redirected + 1})`);
1437
1485
  const redirectRequest = createRedirectRequest(request, response.headers.get("Location"), body);
@@ -1,7 +1,7 @@
1
1
  import "@js-temporal/polyfill";
2
2
  import "urlpattern-polyfill";
3
3
  globalThis.addEventListener = () => {};
4
- import { n as version, t as name } from "./deno-BxqkYxIf.mjs";
4
+ import { n as version, t as name } from "./deno-hqC7tKJn.mjs";
5
5
  import { getLogger } from "@logtape/logtape";
6
6
  import { CryptographicKey, Object as Object$1, isActor } from "@fedify/vocab";
7
7
  import { SpanKind, SpanStatusCode, trace } from "@opentelemetry/api";
@@ -1,3 +1,4 @@
1
+ /// <reference lib="esnext.temporal" />
1
2
  //#region src/federation/kv.d.ts
2
3
  /**
3
4
  * A key for a key–value store. An array of one or more strings.
@@ -1,6 +1,6 @@
1
1
  import { Temporal } from "@js-temporal/polyfill";
2
2
  import { URLPattern } from "urlpattern-polyfill";
3
- import { d as validateCryptoKey, t as doubleKnock } from "./http-b__OS_rJ.js";
3
+ import { d as validateCryptoKey, t as doubleKnock } from "./http-O8MYWwk8.js";
4
4
  import { getLogger } from "@logtape/logtape";
5
5
  import { curry } from "es-toolkit";
6
6
  import { UrlError, createActivityPubRequest, getRemoteDocument, logRequest, preloadedContexts, validatePublicUrl } from "@fedify/vocab-runtime";
@@ -97,7 +97,7 @@ function kvCache({ loader, kv, prefix, rules }) {
97
97
  }
98
98
  function matchRule(url, rules) {
99
99
  for (const [pattern, d] of rules) {
100
- const duration = d instanceof Temporal.Duration ? d : Temporal.Duration.from(d);
100
+ const duration = Temporal.Duration.from(d);
101
101
  if (typeof pattern === "string") {
102
102
  if (url === pattern) return duration;
103
103
  continue;
@@ -86,7 +86,7 @@ function kvCache({ loader, kv, prefix, rules }) {
86
86
  }
87
87
  function matchRule(url, rules) {
88
88
  for (const [pattern, d] of rules) {
89
- const duration = d instanceof Temporal.Duration ? d : Temporal.Duration.from(d);
89
+ const duration = Temporal.Duration.from(d);
90
90
  if (typeof pattern === "string") {
91
91
  if (url === pattern) return duration;
92
92
  continue;
@@ -1,7 +1,7 @@
1
1
  const { Temporal } = require("@js-temporal/polyfill");
2
2
  const { URLPattern } = require("urlpattern-polyfill");
3
3
  require("./chunk-DDcVe30Y.cjs");
4
- const require_http = require("./http-DQ25_ruv.cjs");
4
+ const require_http = require("./http-DV0il3vk.cjs");
5
5
  let _logtape_logtape = require("@logtape/logtape");
6
6
  let es_toolkit = require("es-toolkit");
7
7
  let _fedify_vocab_runtime = require("@fedify/vocab-runtime");
@@ -98,7 +98,7 @@ function kvCache({ loader, kv, prefix, rules }) {
98
98
  }
99
99
  function matchRule(url, rules) {
100
100
  for (const [pattern, d] of rules) {
101
- const duration = d instanceof Temporal.Duration ? d : Temporal.Duration.from(d);
101
+ const duration = Temporal.Duration.from(d);
102
102
  if (typeof pattern === "string") {
103
103
  if (url === pattern) return duration;
104
104
  continue;
@@ -1,6 +1,4 @@
1
- import { Temporal } from "@js-temporal/polyfill";
2
- import { URLPattern } from "urlpattern-polyfill";
3
-
1
+ /// <reference lib="esnext.temporal" />
4
2
  //#region src/federation/kv.d.ts
5
3
  /**
6
4
  * A key for a key–value store. An array of one or more strings.
@@ -1,8 +1,8 @@
1
1
  import "@js-temporal/polyfill";
2
2
  import "urlpattern-polyfill";
3
3
  globalThis.addEventListener = () => {};
4
- import { n as version, t as name } from "./deno-BxqkYxIf.mjs";
5
- import { n as fetchKey, o as validateCryptoKey } from "./key-BNp_b9oE.mjs";
4
+ import { n as version, t as name } from "./deno-hqC7tKJn.mjs";
5
+ import { n as fetchKey, o as validateCryptoKey } from "./key-DW1EVmtP.mjs";
6
6
  import { getLogger } from "@logtape/logtape";
7
7
  import { Activity, CryptographicKey, Object as Object$1, getTypeId } from "@fedify/vocab";
8
8
  import { SpanStatusCode, trace } from "@opentelemetry/api";