@fedify/fedify 2.0.0-pr.445.1694 → 2.0.0-pr.451.1730

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 (193) hide show
  1. package/dist/{actor-T6RyhRgk.d.ts → actor-Cd2CREO0.d.ts} +2 -2
  2. package/dist/{actor-D8gCwLzv.js → actor-Cg8ZhoVF.js} +1 -1
  3. package/dist/{actor-CwZ2m5rG.cjs → actor-D020hlx3.cjs} +922 -1451
  4. package/dist/{actor-D6K058Tb.d.cts → actor-DDhZuMGl.d.cts} +2 -2
  5. package/dist/{actor-DoMcqXsW.js → actor-DPD6Gbdn.js} +190 -677
  6. package/dist/{assert_rejects-DiIiJbZn.js → assert_rejects-Ce45JcFg.js} +1 -1
  7. package/dist/{assert_is_error-BPGph1Jx.js → assert_throws-BNXdRGWP.js} +31 -1
  8. package/dist/{builder-1_skw-d2.js → builder-Dn87hy75.js} +7 -8
  9. package/dist/{client-bgSdkFa2.d.ts → client-Bkaw0_PR.d.ts} +1 -1
  10. package/dist/{client-CegPX0Rn.d.cts → client-Cle5j1T1.d.cts} +1 -1
  11. package/dist/{client-D5CBsPrc.js → client-D6-5okV1.js} +1 -1
  12. package/dist/compat/mod.d.cts +11 -11
  13. package/dist/compat/mod.d.ts +12 -12
  14. package/dist/compat/transformers.test.js +20 -20
  15. package/dist/{context-DiqjMRef.d.cts → context-BOYzcFSe.d.cts} +130 -97
  16. package/dist/{context-DBKpNBnc.d.ts → context-DqFifMwj.d.ts} +131 -98
  17. package/dist/{authdocloader-DYTNpaMA.js → docloader-B2BFBGqv.js} +18 -8
  18. package/dist/{esm-Dl5T1RNE.js → esm-CU0Dnk7T.js} +11 -11
  19. package/dist/federation/builder.test.js +8 -10
  20. package/dist/federation/collection.test.js +7 -9
  21. package/dist/federation/handler.test.js +25 -26
  22. package/dist/federation/idempotency.test.js +25 -26
  23. package/dist/federation/inbox.test.js +4 -6
  24. package/dist/federation/keycache.test.js +3 -4
  25. package/dist/federation/kv.test.js +6 -8
  26. package/dist/federation/middleware.test.js +26 -27
  27. package/dist/federation/mod.cjs +10 -11
  28. package/dist/federation/mod.d.cts +11 -11
  29. package/dist/federation/mod.d.ts +13 -13
  30. package/dist/federation/mod.js +10 -11
  31. package/dist/federation/mq.test.js +8 -10
  32. package/dist/federation/negotiation.test.js +7 -9
  33. package/dist/federation/retry.test.js +4 -5
  34. package/dist/federation/router.test.js +6 -8
  35. package/dist/federation/send.test.js +13 -15
  36. package/dist/{http-D-e6AFwR.d.cts → http-B6SKO6NJ.d.cts} +2 -2
  37. package/dist/{http-D6Uj2x2y.d.ts → http-BE7aFuqn.d.ts} +2 -2
  38. package/dist/{http-CAusBl_3.cjs → http-DMsjudj8.cjs} +289 -9
  39. package/dist/{http-CuS-d4U0.js → http-DN0v2zoF.js} +2 -2
  40. package/dist/{http-C_Qc2neP.js → http-DcDb8r1W.js} +256 -6
  41. package/dist/{inbox-IETv_Qez.js → inbox-CgGy7Hzc.js} +1 -1
  42. package/dist/{key-DnqhSgAv.js → key-jSvnymAk.js} +3 -2
  43. package/dist/{keycache-CSBkusP8.js → keycache-IVLjlAK9.js} +1 -1
  44. package/dist/{keys-D3_MDK7n.js → keys-BKM2Mqu2.js} +2 -1
  45. package/dist/{docloader-CYnQRIXv.cjs → kv-cache-BHIupktM.cjs} +69 -651
  46. package/dist/kv-cache-DNvS-egZ.js +4236 -0
  47. package/dist/{docloader-Czl3xV10.js → kv-cache-ydIs4Ul6.js} +68 -596
  48. package/dist/{ld-Isot0tiW.js → ld-CcsryBo0.js} +3 -2
  49. package/dist/{lookup-Dhm78GlK.js → lookup-BV3A9Zbc.js} +63 -2
  50. package/dist/{type-DaUr3Il7.js → lookup-BbEekiru.js} +588 -5303
  51. package/dist/{lookup-D6dro5Au.cjs → lookup-CMAGfQ1Q.cjs} +78 -5
  52. package/dist/{middleware-BuHr2fzh.js → middleware-D-vPitR-.js} +37 -38
  53. package/dist/{middleware-DQYscW90.js → middleware-Dm8sXYUr.js} +40 -40
  54. package/dist/middleware-DzA970CF.js +16 -0
  55. package/dist/middleware-VpoC5jyA.js +26 -0
  56. package/dist/middleware-W_-inBoE.cjs +16 -0
  57. package/dist/{middleware-Dgmdgrvb.cjs → middleware-ekn2KaOw.cjs} +57 -58
  58. package/dist/{mod-CxkWO3Mg.d.cts → mod--K7l84wp.d.cts} +3 -2
  59. package/dist/{mod-DBzN0aCM.d.ts → mod-CB80AlIA.d.ts} +1 -1
  60. package/dist/mod-CLKu6Uo_.d.cts +107 -0
  61. package/dist/{mod-Djzcw2ry.d.cts → mod-COlOrmr9.d.cts} +3 -3
  62. package/dist/{mod-DlU8ISoa.d.ts → mod-CRENK2dd.d.ts} +3 -2
  63. package/dist/{mod-D_y2y32N.d.ts → mod-CaWbCg0N.d.ts} +2 -2
  64. package/dist/mod-Cm97bAiT.d.ts +109 -0
  65. package/dist/{mod-Bpb5QLaZ.d.cts → mod-D9XZsft2.d.cts} +2 -2
  66. package/dist/{mod-BhUKmBJD.d.ts → mod-DLIidI_j.d.ts} +3 -3
  67. package/dist/{mod-jQ4OODsl.d.cts → mod-DuclhZjh.d.cts} +1 -1
  68. package/dist/mod.cjs +21 -32
  69. package/dist/mod.d.cts +14 -14
  70. package/dist/mod.d.ts +17 -17
  71. package/dist/mod.js +15 -16
  72. package/dist/nodeinfo/client.test.js +8 -10
  73. package/dist/nodeinfo/handler.test.js +24 -25
  74. package/dist/nodeinfo/mod.cjs +3 -3
  75. package/dist/nodeinfo/mod.d.cts +2 -3
  76. package/dist/nodeinfo/mod.d.ts +3 -4
  77. package/dist/nodeinfo/mod.js +3 -3
  78. package/dist/nodeinfo/types.test.js +7 -9
  79. package/dist/{owner-hd9lvQcP.d.ts → owner-CktUdA0h.d.ts} +3 -3
  80. package/dist/{owner-BN_tO3cY.d.cts → owner-dkg5OpSC.d.cts} +3 -3
  81. package/dist/{owner-ChSL4aJ7.js → owner-n5c_oZ_M.js} +3 -2
  82. package/dist/{proof-BiSCuwyA.js → proof-CLwByIT1.js} +5 -4
  83. package/dist/{proof-ONNmhInb.cjs → proof-CZfrp13P.cjs} +17 -16
  84. package/dist/{proof-x3IBewan.js → proof-CsFR7fiS.js} +2 -2
  85. package/dist/request-BbHkedIU.d.cts +35 -0
  86. package/dist/request-DKGQaofB.js +184 -0
  87. package/dist/request-U1t6zZtk.d.ts +39 -0
  88. package/dist/request-XHWUW2bi.cjs +208 -0
  89. package/dist/{send-D5fjmUEj.js → send-eW9JIzQV.js} +2 -2
  90. package/dist/sig/http.test.js +12 -13
  91. package/dist/sig/key.test.js +9 -11
  92. package/dist/sig/ld.test.js +8 -10
  93. package/dist/sig/mod.cjs +10 -11
  94. package/dist/sig/mod.d.cts +6 -7
  95. package/dist/sig/mod.d.ts +6 -7
  96. package/dist/sig/mod.js +6 -7
  97. package/dist/sig/owner.test.js +10 -12
  98. package/dist/sig/proof.test.js +13 -14
  99. package/dist/testing/docloader.test.js +6 -8
  100. package/dist/testing/mod.d.ts +122 -148
  101. package/dist/testing/mod.js +2 -3
  102. package/dist/{testing-tWr1VQxx.js → testing-ClYSmXdi.js} +1 -2
  103. package/dist/{types-D2Nyz0tR.cjs → types-BT0xc4-R.cjs} +3 -3
  104. package/dist/{types-DQuSDtDg.js → types-DaPoJTSc.js} +1 -1
  105. package/dist/{runtime/authdocloader.test.js → utils/docloader.test.js} +13 -15
  106. package/dist/utils/kv-cache.test.js +208 -0
  107. package/dist/utils/mod.cjs +14 -0
  108. package/dist/utils/mod.d.cts +6 -0
  109. package/dist/utils/mod.d.ts +8 -0
  110. package/dist/utils/mod.js +12 -0
  111. package/dist/utils/request.test.js +48 -0
  112. package/dist/utils/url.test.js +41 -0
  113. package/dist/vocab/actor.test.js +8 -10
  114. package/dist/vocab/lookup.test.js +7 -9
  115. package/dist/vocab/mod.cjs +4 -4
  116. package/dist/vocab/mod.d.cts +4 -5
  117. package/dist/vocab/mod.d.ts +4 -5
  118. package/dist/vocab/mod.js +4 -4
  119. package/dist/vocab/type.test.js +2 -3
  120. package/dist/vocab/vocab.test.js +9 -10
  121. package/dist/{vocab-Dd4VMrr0.cjs → vocab-CxTuoEVd.cjs} +6 -5
  122. package/dist/{vocab-Dw1-yVGg.d.cts → vocab-DCBw44JZ.d.cts} +2 -21
  123. package/dist/{vocab-BI0Ak5lL.d.ts → vocab-ivDKb439.d.ts} +2 -21
  124. package/dist/{vocab-w--qk7HF.js → vocab-yFT-fQBj.js} +4 -3
  125. package/dist/webfinger/handler.test.js +24 -25
  126. package/dist/webfinger/lookup.test.js +7 -9
  127. package/dist/webfinger/mod.cjs +3 -3
  128. package/dist/webfinger/mod.d.cts +2 -3
  129. package/dist/webfinger/mod.d.ts +2 -3
  130. package/dist/webfinger/mod.js +3 -3
  131. package/dist/x/cfworkers.d.cts +1 -1
  132. package/dist/x/cfworkers.d.ts +2 -2
  133. package/dist/x/cfworkers.test.js +6 -8
  134. package/dist/x/hono.d.cts +10 -10
  135. package/dist/x/hono.d.ts +11 -11
  136. package/dist/x/sveltekit.d.cts +10 -10
  137. package/dist/x/sveltekit.d.ts +11 -11
  138. package/package.json +16 -14
  139. package/dist/assert_throws-BOO88avQ.js +0 -39
  140. package/dist/authdocloader-Cv_qEn1G.js +0 -52
  141. package/dist/authdocloader-bsmVF6eO.cjs +0 -58
  142. package/dist/docloader-CxWcuWqQ.d.ts +0 -221
  143. package/dist/docloader-D-MrRyHl.d.cts +0 -219
  144. package/dist/key-BNJQQm3h.js +0 -260
  145. package/dist/key-C_ruQbbl.js +0 -10
  146. package/dist/key-DIMJMxf4.cjs +0 -10
  147. package/dist/key-DpFjiItf.js +0 -10
  148. package/dist/key-DuXv64tg.cjs +0 -290
  149. package/dist/lookup-CbtuFbtg.js +0 -331
  150. package/dist/middleware-BpR6186a.js +0 -26
  151. package/dist/middleware-DDMxdtWM.cjs +0 -17
  152. package/dist/middleware-T-knSMwl.js +0 -17
  153. package/dist/mod-CerN_Sza.d.ts +0 -104
  154. package/dist/mod-Cj1tHXBR.d.cts +0 -102
  155. package/dist/runtime/docloader.test.js +0 -522
  156. package/dist/runtime/key.test.js +0 -103
  157. package/dist/runtime/langstr.test.d.ts +0 -3
  158. package/dist/runtime/langstr.test.js +0 -39
  159. package/dist/runtime/link.test.d.ts +0 -3
  160. package/dist/runtime/link.test.js +0 -61
  161. package/dist/runtime/mod.cjs +0 -25
  162. package/dist/runtime/mod.d.cts +0 -6
  163. package/dist/runtime/mod.d.ts +0 -8
  164. package/dist/runtime/mod.js +0 -13
  165. package/dist/runtime/multibase/multibase.test.d.ts +0 -3
  166. package/dist/runtime/multibase/multibase.test.js +0 -358
  167. package/dist/runtime/url.test.js +0 -45
  168. /package/dist/{assert_not_equals-f3m3epl3.js → assert_not_equals-C80BG-_5.js} +0 -0
  169. /package/dist/{collection-CcnIw1qY.js → collection-BzWsN9pB.js} +0 -0
  170. /package/dist/{denokv-Bv33Xxea.js → denokv-CCssOzMJ.js} +0 -0
  171. /package/dist/{federation-H2_En3j5.cjs → federation-DOuZpcAw.cjs} +0 -0
  172. /package/dist/{federation-D1U8YY9t.js → federation-pZJsapBn.js} +0 -0
  173. /package/dist/{kv-63Cil1MD.d.cts → kv-BMKIFXNW.d.cts} +0 -0
  174. /package/dist/{kv-C7sopW2E.d.ts → kv-Dt06smFt.d.ts} +0 -0
  175. /package/dist/{mod-1pDWKvUL.d.ts → mod-B-ZQqbGe.d.ts} +0 -0
  176. /package/dist/{mod-g0xFzAP9.d.ts → mod-CjsiSl7_.d.ts} +0 -0
  177. /package/dist/{mq-CRGm1e_F.d.ts → mq-CPRJk4mZ.d.ts} +0 -0
  178. /package/dist/{negotiation-5NPJL6zp.js → negotiation-C4nFufNk.js} +0 -0
  179. /package/dist/{nodeinfo-DfycQ8Wf.js → nodeinfo-B0UefMXO.js} +0 -0
  180. /package/dist/{nodeinfo-Co9lJrWl.cjs → nodeinfo-ByTd7HpT.cjs} +0 -0
  181. /package/dist/{retry-D4GJ670a.js → retry-CfF8Gn4d.js} +0 -0
  182. /package/dist/{runtime-C58AJWSv.cjs → sig-DE_NC_VQ.cjs} +0 -0
  183. /package/dist/{runtime-DPYEDf-o.js → sig-Dx59zAgn.js} +0 -0
  184. /package/dist/{std__assert-X-_kMxKM.js → std__assert-DWivtrGR.js} +0 -0
  185. /package/dist/{types-BSuWJsOm.js → types-C2XVl6gj.js} +0 -0
  186. /package/dist/{runtime → utils}/docloader.test.d.ts +0 -0
  187. /package/dist/{runtime/authdocloader.test.d.ts → utils/kv-cache.test.d.ts} +0 -0
  188. /package/dist/{runtime/key.test.d.ts → utils/request.test.d.ts} +0 -0
  189. /package/dist/{runtime → utils}/url.test.d.ts +0 -0
  190. /package/dist/{sig-ByHXzqUi.cjs → utils-B6yXfxAQ.cjs} +0 -0
  191. /package/dist/{sig-Cj3tk-ig.js → utils-BXMGcmqK.js} +0 -0
  192. /package/dist/{webfinger-BjOEdFPs.cjs → webfinger-C949bxcD.cjs} +0 -0
  193. /package/dist/{webfinger-De_bU0iE.js → webfinger-qG8R5jc3.js} +0 -0
@@ -1,10 +0,0 @@
1
-
2
- const { Temporal } = require("@js-temporal/polyfill");
3
- const { URLPattern } = require("urlpattern-polyfill");
4
-
5
- require('./docloader-CYnQRIXv.cjs');
6
- require('./actor-CwZ2m5rG.cjs');
7
- require('./lookup-D6dro5Au.cjs');
8
- const require_key = require('./key-DuXv64tg.cjs');
9
-
10
- exports.validateCryptoKey = require_key.validateCryptoKey;
@@ -1,10 +0,0 @@
1
-
2
- import { Temporal } from "@js-temporal/polyfill";
3
- import { URLPattern } from "urlpattern-polyfill";
4
- globalThis.addEventListener = () => {};
5
-
6
- import "./type-DaUr3Il7.js";
7
- import "./actor-D8gCwLzv.js";
8
- import { exportJwk, fetchKey, generateCryptoKeyPair, importJwk, validateCryptoKey } from "./key-DnqhSgAv.js";
9
-
10
- export { validateCryptoKey };
@@ -1,290 +0,0 @@
1
-
2
- const { Temporal } = require("@js-temporal/polyfill");
3
- const { URLPattern } = require("urlpattern-polyfill");
4
-
5
- const require_chunk = require('./chunk-DqRYRqnO.cjs');
6
- const require_docloader = require('./docloader-CYnQRIXv.cjs');
7
- const require_actor = require('./actor-CwZ2m5rG.cjs');
8
- const __logtape_logtape = require_chunk.__toESM(require("@logtape/logtape"));
9
- const __opentelemetry_api = require_chunk.__toESM(require("@opentelemetry/api"));
10
-
11
- //#region src/sig/key.ts
12
- /**
13
- * Checks if the given key is valid and supported. No-op if the key is valid,
14
- * otherwise throws an error.
15
- * @param key The key to check.
16
- * @param type Which type of key to check. If not specified, the key can be
17
- * either public or private.
18
- * @throws {TypeError} If the key is invalid or unsupported.
19
- */
20
- function validateCryptoKey(key, type) {
21
- if (type != null && key.type !== type) throw new TypeError(`The key is not a ${type} key.`);
22
- if (!key.extractable) throw new TypeError("The key is not extractable.");
23
- if (key.algorithm.name !== "RSASSA-PKCS1-v1_5" && key.algorithm.name !== "Ed25519") throw new TypeError("Currently only RSASSA-PKCS1-v1_5 and Ed25519 keys are supported. More algorithms will be added in the future!");
24
- if (key.algorithm.name === "RSASSA-PKCS1-v1_5") {
25
- const algorithm = key.algorithm;
26
- if (algorithm.hash.name !== "SHA-256") throw new TypeError("For compatibility with the existing Fediverse software (e.g., Mastodon), hash algorithm for RSASSA-PKCS1-v1_5 keys must be SHA-256.");
27
- }
28
- }
29
- /**
30
- * Generates a key pair which is appropriate for Fedify.
31
- * @param algorithm The algorithm to use. Currently only RSASSA-PKCS1-v1_5 and
32
- * Ed25519 are supported.
33
- * @returns The generated key pair.
34
- * @throws {TypeError} If the algorithm is unsupported.
35
- */
36
- function generateCryptoKeyPair(algorithm) {
37
- if (algorithm == null) (0, __logtape_logtape.getLogger)([
38
- "fedify",
39
- "sig",
40
- "key"
41
- ]).warn("No algorithm specified. Using RSASSA-PKCS1-v1_5 by default, but it is recommended to specify the algorithm explicitly as the parameter will be required in the future.");
42
- if (algorithm == null || algorithm === "RSASSA-PKCS1-v1_5") return crypto.subtle.generateKey({
43
- name: "RSASSA-PKCS1-v1_5",
44
- modulusLength: 4096,
45
- publicExponent: new Uint8Array([
46
- 1,
47
- 0,
48
- 1
49
- ]),
50
- hash: "SHA-256"
51
- }, true, ["sign", "verify"]);
52
- else if (algorithm === "Ed25519") return crypto.subtle.generateKey("Ed25519", true, ["sign", "verify"]);
53
- throw new TypeError("Unsupported algorithm: " + algorithm);
54
- }
55
- /**
56
- * Exports a key in JWK format.
57
- * @param key The key to export. Either public or private key.
58
- * @returns The exported key in JWK format. The key is suitable for
59
- * serialization and storage.
60
- * @throws {TypeError} If the key is invalid or unsupported.
61
- */
62
- async function exportJwk(key) {
63
- validateCryptoKey(key);
64
- const jwk = await crypto.subtle.exportKey("jwk", key);
65
- if (jwk.crv === "Ed25519") jwk.alg = "Ed25519";
66
- return jwk;
67
- }
68
- /**
69
- * Imports a key from JWK format.
70
- * @param jwk The key in JWK format.
71
- * @param type Which type of key to import, either `"public"` or `"private"`.
72
- * @returns The imported key.
73
- * @throws {TypeError} If the key is invalid or unsupported.
74
- */
75
- async function importJwk(jwk, type) {
76
- let key;
77
- if (jwk.kty === "RSA" && jwk.alg === "RS256") key = await crypto.subtle.importKey("jwk", jwk, {
78
- name: "RSASSA-PKCS1-v1_5",
79
- hash: "SHA-256"
80
- }, true, type === "public" ? ["verify"] : ["sign"]);
81
- else if (jwk.kty === "OKP" && jwk.crv === "Ed25519") {
82
- if (navigator?.userAgent === "Cloudflare-Workers") {
83
- jwk = { ...jwk };
84
- delete jwk.alg;
85
- }
86
- key = await crypto.subtle.importKey("jwk", jwk, "Ed25519", true, type === "public" ? ["verify"] : ["sign"]);
87
- } else throw new TypeError("Unsupported JWK format.");
88
- validateCryptoKey(key, type);
89
- return key;
90
- }
91
- /**
92
- * Fetches a {@link CryptographicKey} or {@link Multikey} from the given URL.
93
- * If the given URL contains an {@link Actor} object, it tries to find
94
- * the corresponding key in the `publicKey` or `assertionMethod` property.
95
- * @template T The type of the key to fetch. Either {@link CryptographicKey}
96
- * or {@link Multikey}.
97
- * @param keyId The URL of the key.
98
- * @param cls The class of the key to fetch. Either {@link CryptographicKey}
99
- * or {@link Multikey}.
100
- * @param options Options for fetching the key. See {@link FetchKeyOptions}.
101
- * @returns The fetched key or `null` if the key is not found.
102
- * @since 1.3.0
103
- */
104
- function fetchKey(keyId, cls, options = {}) {
105
- const tracerProvider = options.tracerProvider ?? __opentelemetry_api.trace.getTracerProvider();
106
- const tracer = tracerProvider.getTracer(require_docloader.deno_default.name, require_docloader.deno_default.version);
107
- keyId = typeof keyId === "string" ? new URL(keyId) : keyId;
108
- return tracer.startActiveSpan("activitypub.fetch_key", {
109
- kind: __opentelemetry_api.SpanKind.CLIENT,
110
- attributes: {
111
- "http.method": "GET",
112
- "url.full": keyId.href,
113
- "url.scheme": keyId.protocol.replace(/:$/, ""),
114
- "url.domain": keyId.hostname,
115
- "url.path": keyId.pathname,
116
- "url.query": keyId.search.replace(/^\?/, ""),
117
- "url.fragment": keyId.hash.replace(/^#/, "")
118
- }
119
- }, async (span) => {
120
- try {
121
- const result = await fetchKeyInternal(keyId, cls, options);
122
- span.setAttribute("activitypub.actor.key.cached", result.cached);
123
- return result;
124
- } catch (e) {
125
- span.setStatus({
126
- code: __opentelemetry_api.SpanStatusCode.ERROR,
127
- message: String(e)
128
- });
129
- throw e;
130
- } finally {
131
- span.end();
132
- }
133
- });
134
- }
135
- async function fetchKeyInternal(keyId, cls, { documentLoader, contextLoader, keyCache, tracerProvider } = {}) {
136
- const logger = (0, __logtape_logtape.getLogger)([
137
- "fedify",
138
- "sig",
139
- "key"
140
- ]);
141
- const cacheKey = typeof keyId === "string" ? new URL(keyId) : keyId;
142
- keyId = typeof keyId === "string" ? keyId : keyId.href;
143
- if (keyCache != null) {
144
- const cachedKey = await keyCache.get(cacheKey);
145
- if (cachedKey instanceof cls && cachedKey.publicKey != null) {
146
- logger.debug("Key {keyId} found in cache.", { keyId });
147
- return {
148
- key: cachedKey,
149
- cached: true
150
- };
151
- } else if (cachedKey === null) {
152
- logger.debug("Entry {keyId} found in cache, but it is unavailable.", { keyId });
153
- return {
154
- key: null,
155
- cached: true
156
- };
157
- }
158
- }
159
- logger.debug("Fetching key {keyId} to verify signature...", { keyId });
160
- let document;
161
- try {
162
- const remoteDocument = await (documentLoader ?? require_docloader.getDocumentLoader())(keyId);
163
- document = remoteDocument.document;
164
- } catch (_) {
165
- logger.debug("Failed to fetch key {keyId}.", { keyId });
166
- await keyCache?.set(cacheKey, null);
167
- return {
168
- key: null,
169
- cached: false
170
- };
171
- }
172
- let object;
173
- try {
174
- object = await require_actor.Object.fromJsonLd(document, {
175
- documentLoader,
176
- contextLoader,
177
- tracerProvider
178
- });
179
- } catch (e) {
180
- if (!(e instanceof TypeError)) throw e;
181
- try {
182
- object = await cls.fromJsonLd(document, {
183
- documentLoader,
184
- contextLoader,
185
- tracerProvider
186
- });
187
- } catch (e$1) {
188
- if (e$1 instanceof TypeError) {
189
- logger.debug("Failed to verify; key {keyId} returned an invalid object.", { keyId });
190
- await keyCache?.set(cacheKey, null);
191
- return {
192
- key: null,
193
- cached: false
194
- };
195
- }
196
- throw e$1;
197
- }
198
- }
199
- let key = null;
200
- if (object instanceof cls) key = object;
201
- else if (require_actor.isActor(object)) {
202
- const keys = cls === require_actor.CryptographicKey ? object.getPublicKeys({
203
- documentLoader,
204
- contextLoader,
205
- tracerProvider
206
- }) : object.getAssertionMethods({
207
- documentLoader,
208
- contextLoader,
209
- tracerProvider
210
- });
211
- let length = 0;
212
- let lastKey = null;
213
- for await (const k of keys) {
214
- length++;
215
- lastKey = k;
216
- if (k.id?.href === keyId) {
217
- key = k;
218
- break;
219
- }
220
- }
221
- const keyIdUrl = new URL(keyId);
222
- if (key == null && keyIdUrl.hash === "" && length === 1) key = lastKey;
223
- if (key == null) {
224
- logger.debug("Failed to verify; object {keyId} returned an {actorType}, but has no key matching {keyId}.", {
225
- keyId,
226
- actorType: object.constructor.name
227
- });
228
- await keyCache?.set(cacheKey, null);
229
- return {
230
- key: null,
231
- cached: false
232
- };
233
- }
234
- } else {
235
- logger.debug("Failed to verify; key {keyId} returned an invalid object.", { keyId });
236
- await keyCache?.set(cacheKey, null);
237
- return {
238
- key: null,
239
- cached: false
240
- };
241
- }
242
- if (key.publicKey == null) {
243
- logger.debug("Failed to verify; key {keyId} has no publicKeyPem field.", { keyId });
244
- await keyCache?.set(cacheKey, null);
245
- return {
246
- key: null,
247
- cached: false
248
- };
249
- }
250
- if (keyCache != null) {
251
- await keyCache.set(cacheKey, key);
252
- logger.debug("Key {keyId} cached.", { keyId });
253
- }
254
- return {
255
- key,
256
- cached: false
257
- };
258
- }
259
-
260
- //#endregion
261
- Object.defineProperty(exports, 'exportJwk', {
262
- enumerable: true,
263
- get: function () {
264
- return exportJwk;
265
- }
266
- });
267
- Object.defineProperty(exports, 'fetchKey', {
268
- enumerable: true,
269
- get: function () {
270
- return fetchKey;
271
- }
272
- });
273
- Object.defineProperty(exports, 'generateCryptoKeyPair', {
274
- enumerable: true,
275
- get: function () {
276
- return generateCryptoKeyPair;
277
- }
278
- });
279
- Object.defineProperty(exports, 'importJwk', {
280
- enumerable: true,
281
- get: function () {
282
- return importJwk;
283
- }
284
- });
285
- Object.defineProperty(exports, 'validateCryptoKey', {
286
- enumerable: true,
287
- get: function () {
288
- return validateCryptoKey;
289
- }
290
- });
@@ -1,331 +0,0 @@
1
-
2
- import { Temporal } from "@js-temporal/polyfill";
3
- import { URLPattern } from "urlpattern-polyfill";
4
- globalThis.addEventListener = () => {};
5
-
6
- import { Object as Object$1, deno_default, getDocumentLoader, getTypeId, lookupWebFinger } from "./type-DaUr3Il7.js";
7
- import { cloneDeep, delay } from "es-toolkit";
8
- import { getLogger } from "@logtape/logtape";
9
- import { SpanStatusCode, trace } from "@opentelemetry/api";
10
- import { Router } from "uri-template-router";
11
- import { parseTemplate } from "url-template";
12
-
13
- //#region src/federation/router.ts
14
- function cloneInnerRouter(router) {
15
- const clone = new Router();
16
- clone.nid = router.nid;
17
- clone.fsm = cloneDeep(router.fsm);
18
- clone.routeSet = new Set(router.routeSet);
19
- clone.templateRouteMap = new Map(router.templateRouteMap);
20
- clone.valueRouteMap = new Map(router.valueRouteMap);
21
- clone.hierarchy = cloneDeep(router.hierarchy);
22
- return clone;
23
- }
24
- /**
25
- * URL router and constructor based on URI Template
26
- * ([RFC 6570](https://tools.ietf.org/html/rfc6570)).
27
- */
28
- var Router$1 = class Router$1 {
29
- #router;
30
- #templates;
31
- #templateStrings;
32
- /**
33
- * Whether to ignore trailing slashes when matching paths.
34
- * @since 1.6.0
35
- */
36
- trailingSlashInsensitive;
37
- /**
38
- * Create a new {@link Router}.
39
- * @param options Options for the router.
40
- */
41
- constructor(options = {}) {
42
- this.#router = new Router();
43
- this.#templates = {};
44
- this.#templateStrings = {};
45
- this.trailingSlashInsensitive = options.trailingSlashInsensitive ?? false;
46
- }
47
- clone() {
48
- const clone = new Router$1({ trailingSlashInsensitive: this.trailingSlashInsensitive });
49
- clone.#router = cloneInnerRouter(this.#router);
50
- clone.#templates = { ...this.#templates };
51
- clone.#templateStrings = { ...this.#templateStrings };
52
- return clone;
53
- }
54
- /**
55
- * Checks if a path name exists in the router.
56
- * @param name The name of the path.
57
- * @returns `true` if the path name exists, otherwise `false`.
58
- */
59
- has(name) {
60
- return name in this.#templates;
61
- }
62
- /**
63
- * Adds a new path rule to the router.
64
- * @param template The path pattern.
65
- * @param name The name of the path.
66
- * @returns The names of the variables in the path pattern.
67
- */
68
- add(template, name) {
69
- if (!template.startsWith("/")) throw new RouterError("Path must start with a slash.");
70
- const rule = this.#router.addTemplate(template, {}, name);
71
- this.#templates[name] = parseTemplate(template);
72
- this.#templateStrings[name] = template;
73
- return new Set(rule.variables.map((v) => v.varname));
74
- }
75
- /**
76
- * Resolves a path name and values from a URL, if any match.
77
- * @param url The URL to resolve.
78
- * @returns The name of the path and its values, if any match. Otherwise,
79
- * `null`.
80
- */
81
- route(url) {
82
- let match = this.#router.resolveURI(url);
83
- if (match == null) {
84
- if (!this.trailingSlashInsensitive) return null;
85
- url = url.endsWith("/") ? url.replace(/\/+$/, "") : `${url}/`;
86
- match = this.#router.resolveURI(url);
87
- if (match == null) return null;
88
- }
89
- return {
90
- name: match.matchValue,
91
- template: this.#templateStrings[match.matchValue],
92
- values: match.params
93
- };
94
- }
95
- /**
96
- * Constructs a URL/path from a path name and values.
97
- * @param name The name of the path.
98
- * @param values The values to expand the path with.
99
- * @returns The URL/path, if the name exists. Otherwise, `null`.
100
- */
101
- build(name, values) {
102
- if (name in this.#templates) return this.#templates[name].expand(values);
103
- return null;
104
- }
105
- };
106
- /**
107
- * An error thrown by the {@link Router}.
108
- */
109
- var RouterError = class extends Error {
110
- /**
111
- * Create a new {@link RouterError}.
112
- * @param message The error message.
113
- */
114
- constructor(message) {
115
- super(message);
116
- this.name = "RouterError";
117
- }
118
- };
119
-
120
- //#endregion
121
- //#region src/vocab/handle.ts
122
- /**
123
- * Regular expression to match a fediverse handle in the format `@user@server`
124
- * or `user@server`. The `user` part can contain alphanumeric characters and
125
- * some special characters except `@`. The `server` part is all characters
126
- * after the `@` symbol in the middle.
127
- */
128
- const handleRegexp = /^@?((?:[-A-Za-z0-9._~!$&'()*+,;=]|%[A-Fa-f0-9]{2})+)@([^@]+)$/;
129
- /**
130
- * Parses a fediverse handle in the format `@user@server` or `user@server`.
131
- * The `user` part can contain alphanumeric characters and some special
132
- * characters except `@`. The `server` part is all characters after the `@`
133
- * symbol in the middle.
134
- *
135
- * @example
136
- * ```typescript
137
- * const handle = parseFediverseHandle("@username@example.com");
138
- * console.log(handle?.username); // "username"
139
- * console.log(handle?.host); // "example.com"
140
- * ```
141
- *
142
- * @param handle - The fediverse handle string to parse.
143
- * @returns A {@link FediverseHandle} object with `username` and `host`
144
- * if the input is valid; otherwise `null`.
145
- * @since 1.8.0
146
- */
147
- function parseFediverseHandle(handle) {
148
- const match = handleRegexp.exec(handle);
149
- if (match) return {
150
- username: match[1],
151
- host: match[2]
152
- };
153
- return null;
154
- }
155
- /**
156
- * Converts a fediverse handle in the format `@user@server` or `user@server`
157
- * to an `acct:` URI, which is a URL-like identifier for ActivityPub actors.
158
- *
159
- * @example
160
- * ```typescript
161
- * const identifier = toAcctUrl("@username@example.com");
162
- * console.log(identifier?.href); // "acct:username@example.com"
163
- * ```
164
- *
165
- * @param handle - The fediverse handle string to convert.
166
- * @returns A `URL` object representing the `acct:` URI if conversion succeeds;
167
- * otherwise `null`.
168
- * @since 1.8.0
169
- */
170
- function toAcctUrl(handle) {
171
- const parsed = parseFediverseHandle(handle);
172
- if (!parsed) return null;
173
- const identifier = new URL(`acct:${parsed.username}@${parsed.host}`);
174
- return identifier;
175
- }
176
-
177
- //#endregion
178
- //#region src/vocab/lookup.ts
179
- const logger = getLogger([
180
- "fedify",
181
- "vocab",
182
- "lookup"
183
- ]);
184
- /**
185
- * Looks up an ActivityStreams object by its URI (including `acct:` URIs)
186
- * or a fediverse handle (e.g., `@user@server` or `user@server`).
187
- *
188
- * @example
189
- * ``` typescript
190
- * // Look up an actor by its fediverse handle:
191
- * await lookupObject("@hongminhee@fosstodon.org");
192
- * // returning a `Person` object.
193
- *
194
- * // A fediverse handle can omit the leading '@':
195
- * await lookupObject("hongminhee@fosstodon.org");
196
- * // returning a `Person` object.
197
- *
198
- * // A `acct:` URI can be used as well:
199
- * await lookupObject("acct:hongminhee@fosstodon.org");
200
- * // returning a `Person` object.
201
- *
202
- * // Look up an object by its URI:
203
- * await lookupObject("https://todon.eu/@hongminhee/112060633798771581");
204
- * // returning a `Note` object.
205
- *
206
- * // It can be a `URL` object as well:
207
- * await lookupObject(new URL("https://todon.eu/@hongminhee/112060633798771581"));
208
- * // returning a `Note` object.
209
- * ```
210
- *
211
- * @param identifier The URI or fediverse handle to look up.
212
- * @param options Lookup options.
213
- * @returns The object, or `null` if not found.
214
- * @since 0.2.0
215
- */
216
- async function lookupObject(identifier, options = {}) {
217
- const tracerProvider = options.tracerProvider ?? trace.getTracerProvider();
218
- const tracer = tracerProvider.getTracer(deno_default.name, deno_default.version);
219
- return await tracer.startActiveSpan("activitypub.lookup_object", async (span) => {
220
- try {
221
- const result = await lookupObjectInternal(identifier, options);
222
- if (result == null) span.setStatus({ code: SpanStatusCode.ERROR });
223
- else {
224
- if (result.id != null) span.setAttribute("activitypub.object.id", result.id.href);
225
- span.setAttribute("activitypub.object.type", getTypeId(result).href);
226
- if (result.replyTargetIds.length > 0) span.setAttribute("activitypub.object.in_reply_to", result.replyTargetIds.map((id) => id.href));
227
- }
228
- return result;
229
- } catch (error) {
230
- span.setStatus({
231
- code: SpanStatusCode.ERROR,
232
- message: String(error)
233
- });
234
- throw error;
235
- } finally {
236
- span.end();
237
- }
238
- });
239
- }
240
- async function lookupObjectInternal(identifier, options = {}) {
241
- const documentLoader = options.documentLoader ?? getDocumentLoader({ userAgent: options.userAgent });
242
- if (typeof identifier === "string") identifier = toAcctUrl(identifier) ?? new URL(identifier);
243
- let remoteDoc = null;
244
- if (identifier.protocol === "http:" || identifier.protocol === "https:") try {
245
- remoteDoc = await documentLoader(identifier.href, { signal: options.signal });
246
- } catch (error) {
247
- logger.debug("Failed to fetch remote document:\n{error}", { error });
248
- }
249
- if (remoteDoc == null) {
250
- const jrd = await lookupWebFinger(identifier, {
251
- userAgent: options.userAgent,
252
- tracerProvider: options.tracerProvider,
253
- allowPrivateAddress: "allowPrivateAddress" in options && options.allowPrivateAddress === true,
254
- signal: options.signal
255
- });
256
- if (jrd?.links == null) return null;
257
- for (const l of jrd.links) {
258
- if (l.type !== "application/activity+json" && !l.type?.match(/application\/ld\+json;\s*profile="https:\/\/www.w3.org\/ns\/activitystreams"/) || l.rel !== "self" || l.href == null) continue;
259
- try {
260
- remoteDoc = await documentLoader(l.href, { signal: options.signal });
261
- break;
262
- } catch (error) {
263
- logger.debug("Failed to fetch remote document:\n{error}", { error });
264
- continue;
265
- }
266
- }
267
- }
268
- if (remoteDoc == null) return null;
269
- let object;
270
- try {
271
- object = await Object$1.fromJsonLd(remoteDoc.document, {
272
- documentLoader,
273
- contextLoader: options.contextLoader,
274
- tracerProvider: options.tracerProvider,
275
- baseUrl: new URL(remoteDoc.documentUrl)
276
- });
277
- } catch (error) {
278
- if (error instanceof TypeError) {
279
- logger.debug("Failed to parse JSON-LD document: {error}\n{document}", {
280
- ...remoteDoc,
281
- error
282
- });
283
- return null;
284
- }
285
- throw error;
286
- }
287
- if (options.crossOrigin !== "trust" && object.id != null && object.id.origin !== new URL(remoteDoc.documentUrl).origin) {
288
- if (options.crossOrigin === "throw") throw new Error(`The object's @id (${object.id.href}) has a different origin than the document URL (${remoteDoc.documentUrl}); refusing to return the object. If you want to bypass this check and are aware of the security implications, set the crossOrigin option to "trust".`);
289
- logger.warn("The object's @id ({objectId}) has a different origin than the document URL ({documentUrl}); refusing to return the object. If you want to bypass this check and are aware of the security implications, set the crossOrigin option to \"trust\".", {
290
- ...remoteDoc,
291
- objectId: object.id.href
292
- });
293
- return null;
294
- }
295
- return object;
296
- }
297
- /**
298
- * Traverses a collection, yielding each item in the collection.
299
- * If the collection is paginated, it will fetch the next page
300
- * automatically.
301
- *
302
- * @example
303
- * ``` typescript
304
- * const collection = await lookupObject(collectionUrl);
305
- * if (collection instanceof Collection) {
306
- * for await (const item of traverseCollection(collection)) {
307
- * console.log(item.id?.href);
308
- * }
309
- * }
310
- * ```
311
- *
312
- * @param collection The collection to traverse.
313
- * @param options Options for traversing the collection.
314
- * @returns An async iterable of each item in the collection.
315
- * @since 1.1.0
316
- */
317
- async function* traverseCollection(collection, options = {}) {
318
- if (collection.firstId == null) for await (const item of collection.getItems(options)) yield item;
319
- else {
320
- const interval = Temporal.Duration.from(options.interval ?? { seconds: 0 }).total("millisecond");
321
- let page = await collection.getFirst(options);
322
- while (page != null) {
323
- for await (const item of page.getItems(options)) yield item;
324
- if (interval > 0) await delay(interval);
325
- page = await page.getNext(options);
326
- }
327
- }
328
- }
329
-
330
- //#endregion
331
- export { Router$1 as Router, RouterError, lookupObject, traverseCollection };
@@ -1,26 +0,0 @@
1
-
2
- import { Temporal } from "@js-temporal/polyfill";
3
- import { URLPattern } from "urlpattern-polyfill";
4
- globalThis.addEventListener = () => {};
5
-
6
- import "./type-DaUr3Il7.js";
7
- import { ContextImpl, FederationImpl, InboxContextImpl, KvSpecDeterminer, createFederation } from "./middleware-DQYscW90.js";
8
- import "./client-D5CBsPrc.js";
9
- import "./lookup-CbtuFbtg.js";
10
- import "./types-BSuWJsOm.js";
11
- import "./actor-D8gCwLzv.js";
12
- import "./key-DnqhSgAv.js";
13
- import "./http-CuS-d4U0.js";
14
- import "./authdocloader-DYTNpaMA.js";
15
- import "./ld-Isot0tiW.js";
16
- import "./owner-ChSL4aJ7.js";
17
- import "./proof-x3IBewan.js";
18
- import "./inbox-IETv_Qez.js";
19
- import "./builder-1_skw-d2.js";
20
- import "./collection-CcnIw1qY.js";
21
- import "./keycache-CSBkusP8.js";
22
- import "./negotiation-5NPJL6zp.js";
23
- import "./retry-D4GJ670a.js";
24
- import "./send-D5fjmUEj.js";
25
-
26
- export { FederationImpl };
@@ -1,17 +0,0 @@
1
-
2
- const { Temporal } = require("@js-temporal/polyfill");
3
- const { URLPattern } = require("urlpattern-polyfill");
4
-
5
- require('./transformers-CoBS-oFG.cjs');
6
- require('./docloader-CYnQRIXv.cjs');
7
- require('./actor-CwZ2m5rG.cjs');
8
- const require_middleware = require('./middleware-Dgmdgrvb.cjs');
9
- require('./lookup-D6dro5Au.cjs');
10
- require('./key-DuXv64tg.cjs');
11
- require('./http-CAusBl_3.cjs');
12
- require('./proof-ONNmhInb.cjs');
13
- require('./types-D2Nyz0tR.cjs');
14
- require('./authdocloader-bsmVF6eO.cjs');
15
- require('./vocab-Dd4VMrr0.cjs');
16
-
17
- exports.FederationImpl = require_middleware.FederationImpl;