@fedify/fedify 2.0.0-dev.1690 → 2.0.0-dev.170

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 (317) hide show
  1. package/LICENSE +1 -1
  2. package/README.md +70 -34
  3. package/dist/{assert_rejects-DiIiJbZn.js → assert_rejects-Ce45JcFg.js} +1 -1
  4. package/dist/{assert_is_error-BPGph1Jx.js → assert_throws-BNXdRGWP.js} +31 -1
  5. package/dist/{builder-CYOcDUkj.js → builder-_MVsWtsS.js} +9 -8
  6. package/dist/{client-bgSdkFa2.d.ts → client-CUTUGgvJ.d.ts} +19 -19
  7. package/dist/{client-CnOdwLLN.js → client-Dg7OfUDA.js} +28 -23
  8. package/dist/{client-CegPX0Rn.d.cts → client-by-PEGAJ.d.cts} +19 -19
  9. package/dist/compat/mod.cjs +1 -1
  10. package/dist/compat/mod.d.cts +6 -12
  11. package/dist/compat/mod.d.ts +6 -12
  12. package/dist/compat/mod.js +1 -1
  13. package/dist/compat/transformers.test.js +19 -18
  14. package/dist/context-Bns6uTJq.js +109 -0
  15. package/dist/{context-ByZprN0S.d.ts → context-C7vzWilY.d.ts} +314 -182
  16. package/dist/{context-C5BsZkDr.d.cts → context-CrB9RFy5.d.cts} +314 -182
  17. package/dist/deno-DhWON59o.js +117 -0
  18. package/dist/{testing-BWNCAbL-.js → dist-B5f6a8Tt.js} +90 -111
  19. package/dist/{authdocloader-Brax1A32.js → docloader-Cni79dmb.js} +17 -8
  20. package/dist/{esm-DnIzfEj0.js → esm-DGl7uK1r.js} +32 -17
  21. package/dist/federation/builder.test.js +11 -11
  22. package/dist/federation/collection.test.js +5 -8
  23. package/dist/federation/handler.test.js +111 -24
  24. package/dist/federation/idempotency.test.js +24 -24
  25. package/dist/federation/inbox.test.js +5 -6
  26. package/dist/federation/keycache.test.js +4 -5
  27. package/dist/federation/kv.test.js +60 -9
  28. package/dist/federation/middleware.test.js +102 -101
  29. package/dist/federation/mod.cjs +8 -12
  30. package/dist/federation/mod.d.cts +7 -13
  31. package/dist/federation/mod.d.ts +7 -13
  32. package/dist/federation/mod.js +8 -13
  33. package/dist/federation/mq.test.js +9 -10
  34. package/dist/federation/negotiation.test.js +5 -8
  35. package/dist/federation/retry.test.js +2 -4
  36. package/dist/federation/router.test.js +6 -8
  37. package/dist/federation/send.test.js +55 -15
  38. package/dist/{webfinger/handler.test.js → federation/webfinger.test.js} +25 -24
  39. package/dist/{federation-H2_En3j5.cjs → federation-B431K2gm.cjs} +22 -0
  40. package/dist/{federation-D1U8YY9t.js → federation-BbZwNNWj.js} +28 -6
  41. package/dist/{http-C7vbQwbz.cjs → http-7RQPvAkX.cjs} +410 -14
  42. package/dist/{http-BxbM8sEy.js → http-CZXlv4xU.js} +371 -11
  43. package/dist/{http-D-e6AFwR.d.cts → http-ClB3pLcL.d.cts} +2 -2
  44. package/dist/{http-BNOYnVsU.js → http-CwsBL5_A.js} +3 -2
  45. package/dist/{http-D6Uj2x2y.d.ts → http-DLBDPal9.d.ts} +2 -2
  46. package/dist/{inbox-BRru9pX3.js → inbox-CukSCwad.js} +2 -1
  47. package/dist/{key-1KXru8Ug.js → key-DKkHKzvg.js} +3 -2
  48. package/dist/{keycache-CN61iGVj.js → keycache-DRxpZ5r9.js} +1 -1
  49. package/dist/{keys-BPdFKgiy.js → keys-ZbcByPg9.js} +2 -1
  50. package/dist/{kv-63Cil1MD.d.cts → kv-B4vFhIYL.d.cts} +30 -1
  51. package/dist/{kv-C7sopW2E.d.ts → kv-CYySNrsn.d.ts} +30 -1
  52. package/dist/{kv-CRZrzyXm.js → kv-QzKcOQgP.js} +22 -0
  53. package/dist/kv-cache-BEeqyGER.js +107 -0
  54. package/dist/kv-cache-BVA7CrnS.cjs +134 -0
  55. package/dist/kv-cache-HDuc4ZaJ.js +122 -0
  56. package/dist/{ld-Dv8DNNAT.js → ld-CM6OO5ar.js} +4 -2
  57. package/dist/middleware--i9t8nKh.js +26 -0
  58. package/dist/middleware-C567nJlD.cjs +12 -0
  59. package/dist/middleware-D9oWuacw.js +12 -0
  60. package/dist/{middleware-DY9B2lL8.js → middleware-DXRcwk_y.js} +185 -192
  61. package/dist/{middleware-BmoOlgc1.cjs → middleware-TufpQUzj.cjs} +251 -241
  62. package/dist/{middleware-Bz_A2jeJ.js → middleware-eDeNdyRA.js} +195 -191
  63. package/dist/mod-0p9zUdzg.d.cts +107 -0
  64. package/dist/mod-0qnPv4EC.d.cts +62 -0
  65. package/dist/{mod-Djzcw2ry.d.cts → mod-BrS8tiad.d.cts} +3 -3
  66. package/dist/mod-C3SOvTD1.d.ts +64 -0
  67. package/dist/{mod-8DMWKtQE.d.cts → mod-D6pS5_xJ.d.cts} +4 -4
  68. package/dist/{mod-BhUKmBJD.d.ts → mod-jOa7W503.d.ts} +3 -3
  69. package/dist/{mod-D6hQoxC5.d.ts → mod-waqu-BL_.d.ts} +4 -4
  70. package/dist/mod-xc20HhMD.d.ts +109 -0
  71. package/dist/mod.cjs +17 -112
  72. package/dist/mod.d.cts +11 -17
  73. package/dist/mod.d.ts +11 -17
  74. package/dist/mod.js +11 -17
  75. package/dist/nodeinfo/client.test.js +7 -10
  76. package/dist/nodeinfo/handler.test.js +23 -23
  77. package/dist/nodeinfo/mod.cjs +2 -3
  78. package/dist/nodeinfo/mod.d.cts +2 -4
  79. package/dist/nodeinfo/mod.d.ts +2 -4
  80. package/dist/nodeinfo/mod.js +2 -3
  81. package/dist/nodeinfo/types.test.js +6 -9
  82. package/dist/otel/exporter.test.js +893 -0
  83. package/dist/otel/mod.cjs +256 -0
  84. package/dist/otel/mod.d.cts +230 -0
  85. package/dist/otel/mod.d.ts +232 -0
  86. package/dist/otel/mod.js +255 -0
  87. package/dist/{owner-e3FYDhsk.js → owner-BOEfZQv2.js} +45 -8
  88. package/dist/{owner-hd9lvQcP.d.ts → owner-BgI8C-VY.d.ts} +2 -3
  89. package/dist/{owner-BN_tO3cY.d.cts → owner-C-zfmVAD.d.cts} +2 -3
  90. package/dist/{proof-B-eqv0Ug.cjs → proof-CaDQpGJD.cjs} +69 -33
  91. package/dist/{proof-DfgvA3al.js → proof-iYIDiv8I.js} +47 -11
  92. package/dist/{proof-6gFMwMNJ.js → proof-iw6KtIyj.js} +3 -2
  93. package/dist/router-D9eI0s4b.js +118 -0
  94. package/dist/{send-Tl9NOnmO.js → send-Bn8o0mjW.js} +9 -4
  95. package/dist/sig/http.test.js +11 -13
  96. package/dist/sig/key.test.js +9 -11
  97. package/dist/sig/ld.test.js +8 -10
  98. package/dist/sig/mod.cjs +7 -11
  99. package/dist/sig/mod.d.cts +3 -7
  100. package/dist/sig/mod.d.ts +3 -7
  101. package/dist/sig/mod.js +3 -7
  102. package/dist/sig/owner.test.js +33 -12
  103. package/dist/sig/proof.test.js +13 -14
  104. package/dist/testing/mod.d.ts +183 -7194
  105. package/dist/testing/mod.js +4 -4
  106. package/dist/{transformers-CoBS-oFG.cjs → transformers-BjBg6Lag.cjs} +2 -2
  107. package/dist/{transformers-BFT6d7J5.js → transformers-N_ip_y4P.js} +2 -2
  108. package/dist/{types-DqxyTxOf.js → types-8l28uC8o.js} +31 -26
  109. package/dist/{types-zqdWZh4O.cjs → types-B6z6CqIz.cjs} +33 -28
  110. package/dist/{types-BSuWJsOm.js → types-CPz01LGH.js} +3 -3
  111. package/dist/{runtime/authdocloader.test.js → utils/docloader.test.js} +13 -15
  112. package/dist/utils/kv-cache.test.js +211 -0
  113. package/dist/utils/mod.cjs +10 -0
  114. package/dist/utils/mod.d.cts +4 -0
  115. package/dist/utils/mod.d.ts +6 -0
  116. package/dist/utils/mod.js +9 -0
  117. package/package.json +34 -75
  118. package/dist/actor-Be0ThtXy.cjs +0 -42609
  119. package/dist/actor-ChbPLm6n.js +0 -42135
  120. package/dist/actor-D6K058Tb.d.cts +0 -128
  121. package/dist/actor-DuCeRiNh.js +0 -146
  122. package/dist/actor-T6RyhRgk.d.ts +0 -130
  123. package/dist/assert_throws-BOO88avQ.js +0 -39
  124. package/dist/authdocloader-CrxhFL8e.js +0 -52
  125. package/dist/authdocloader-OSn_teLV.cjs +0 -58
  126. package/dist/denokv-Bv33Xxea.js +0 -57
  127. package/dist/docloader-CCqXeagZ.cjs +0 -4861
  128. package/dist/docloader-CxWcuWqQ.d.ts +0 -221
  129. package/dist/docloader-D-MrRyHl.d.cts +0 -219
  130. package/dist/docloader-XK3y2jn5.js +0 -4795
  131. package/dist/fixtures/activitypub.academy/users/brauca_darradiul.json +0 -83
  132. package/dist/fixtures/example.com/announce.json +0 -6
  133. package/dist/fixtures/example.com/collection.json +0 -19
  134. package/dist/fixtures/example.com/create.json +0 -6
  135. package/dist/fixtures/example.com/cross-origin-actor.json +0 -6
  136. package/dist/fixtures/example.com/hong-gildong.json +0 -11
  137. package/dist/fixtures/example.com/invite.json +0 -7
  138. package/dist/fixtures/example.com/key.json +0 -7
  139. package/dist/fixtures/example.com/key2.json +0 -6
  140. package/dist/fixtures/example.com/object.json +0 -6
  141. package/dist/fixtures/example.com/orderedcollectionpage.json +0 -24
  142. package/dist/fixtures/example.com/paged/a.json +0 -13
  143. package/dist/fixtures/example.com/paged/b.json +0 -16
  144. package/dist/fixtures/example.com/paged-collection.json +0 -6
  145. package/dist/fixtures/example.com/person.json +0 -22
  146. package/dist/fixtures/example.com/person2.json +0 -40
  147. package/dist/fixtures/example.com/test.json +0 -5
  148. package/dist/fixtures/example.com/users/handle.json +0 -16
  149. package/dist/fixtures/example.com/wrong-type.json +0 -3
  150. package/dist/fixtures/media.example.com/avatars/test-avatar.jpg.json +0 -6
  151. package/dist/fixtures/oeee.cafe/ap/users/3609fd4e-d51d-4db8-9f04-4189815864dd.json +0 -24
  152. package/dist/fixtures/remote.domain/users/bob.json +0 -20
  153. package/dist/fixtures/server.example/users/alice.json +0 -20
  154. package/dist/fixtures/w3id.org/identity/v1.json +0 -152
  155. package/dist/fixtures/w3id.org/security/data-integrity/v1.json +0 -74
  156. package/dist/fixtures/w3id.org/security/multikey/v1.json +0 -35
  157. package/dist/fixtures/w3id.org/security/v1.json +0 -50
  158. package/dist/fixtures/wizard.casa/users/hongminhee.json +0 -69
  159. package/dist/fixtures/www.w3.org/ns/activitystreams.json +0 -379
  160. package/dist/fixtures/www.w3.org/ns/did/v1.json +0 -58
  161. package/dist/key-B3uag-rz.js +0 -10
  162. package/dist/key-BiBmb1Yy.cjs +0 -10
  163. package/dist/key-DK_nfU4I.js +0 -10
  164. package/dist/key-Z6ceKnZC.cjs +0 -290
  165. package/dist/key-jyNTxCvK.js +0 -260
  166. package/dist/lookup-BPviO8ij.js +0 -131
  167. package/dist/lookup-hnMAAU5r.cjs +0 -137
  168. package/dist/lookup-pV0JOsuV.js +0 -331
  169. package/dist/middleware-CI0-zw4U.js +0 -26
  170. package/dist/middleware-QNK-W-jE.cjs +0 -17
  171. package/dist/middleware-_vjt6FWU.js +0 -17
  172. package/dist/mod-CerN_Sza.d.ts +0 -104
  173. package/dist/mod-Cj1tHXBR.d.cts +0 -102
  174. package/dist/mod-CxkWO3Mg.d.cts +0 -307
  175. package/dist/mod-DBzN0aCM.d.ts +0 -115
  176. package/dist/mod-DlU8ISoa.d.ts +0 -309
  177. package/dist/mod-FZd39qVq.d.cts +0 -1
  178. package/dist/mod-g0xFzAP9.d.ts +0 -2
  179. package/dist/mod-jQ4OODsl.d.cts +0 -113
  180. package/dist/mq-B7R1Q-M5.d.cts +0 -140
  181. package/dist/mq-CRGm1e_F.d.ts +0 -143
  182. package/dist/runtime/docloader.test.js +0 -522
  183. package/dist/runtime/key.test.js +0 -103
  184. package/dist/runtime/langstr.test.d.ts +0 -3
  185. package/dist/runtime/langstr.test.js +0 -39
  186. package/dist/runtime/link.test.d.ts +0 -3
  187. package/dist/runtime/link.test.js +0 -61
  188. package/dist/runtime/mod.cjs +0 -25
  189. package/dist/runtime/mod.d.cts +0 -6
  190. package/dist/runtime/mod.d.ts +0 -8
  191. package/dist/runtime/mod.js +0 -13
  192. package/dist/runtime/multibase/multibase.test.d.ts +0 -3
  193. package/dist/runtime/multibase/multibase.test.js +0 -358
  194. package/dist/runtime/url.test.d.ts +0 -3
  195. package/dist/runtime/url.test.js +0 -45
  196. package/dist/src/vocab/accept.yaml +0 -15
  197. package/dist/src/vocab/activity.yaml +0 -98
  198. package/dist/src/vocab/add.yaml +0 -16
  199. package/dist/src/vocab/announce.yaml +0 -30
  200. package/dist/src/vocab/application.yaml +0 -324
  201. package/dist/src/vocab/arrive.yaml +0 -15
  202. package/dist/src/vocab/article.yaml +0 -46
  203. package/dist/src/vocab/audio.yaml +0 -11
  204. package/dist/src/vocab/block.yaml +0 -16
  205. package/dist/src/vocab/chatmessage.yaml +0 -50
  206. package/dist/src/vocab/collection.yaml +0 -154
  207. package/dist/src/vocab/collectionpage.yaml +0 -55
  208. package/dist/src/vocab/create.yaml +0 -28
  209. package/dist/src/vocab/dataintegrityproof.yaml +0 -56
  210. package/dist/src/vocab/delete.yaml +0 -27
  211. package/dist/src/vocab/didservice.yaml +0 -22
  212. package/dist/src/vocab/dislike.yaml +0 -14
  213. package/dist/src/vocab/document.yaml +0 -31
  214. package/dist/src/vocab/emoji.yaml +0 -12
  215. package/dist/src/vocab/emojireact.yaml +0 -17
  216. package/dist/src/vocab/endpoints.yaml +0 -85
  217. package/dist/src/vocab/event.yaml +0 -11
  218. package/dist/src/vocab/export.yaml +0 -9
  219. package/dist/src/vocab/flag.yaml +0 -15
  220. package/dist/src/vocab/follow.yaml +0 -19
  221. package/dist/src/vocab/group.yaml +0 -324
  222. package/dist/src/vocab/hashtag.yaml +0 -14
  223. package/dist/src/vocab/ignore.yaml +0 -14
  224. package/dist/src/vocab/image.yaml +0 -9
  225. package/dist/src/vocab/intransitiveactivity.yaml +0 -15
  226. package/dist/src/vocab/invite.yaml +0 -14
  227. package/dist/src/vocab/join.yaml +0 -14
  228. package/dist/src/vocab/key.yaml +0 -28
  229. package/dist/src/vocab/leave.yaml +0 -14
  230. package/dist/src/vocab/like.yaml +0 -16
  231. package/dist/src/vocab/link.yaml +0 -101
  232. package/dist/src/vocab/listen.yaml +0 -12
  233. package/dist/src/vocab/mention.yaml +0 -9
  234. package/dist/src/vocab/move.yaml +0 -15
  235. package/dist/src/vocab/multikey.yaml +0 -36
  236. package/dist/src/vocab/note.yaml +0 -48
  237. package/dist/src/vocab/object.yaml +0 -404
  238. package/dist/src/vocab/offer.yaml +0 -15
  239. package/dist/src/vocab/orderedcollection.yaml +0 -39
  240. package/dist/src/vocab/orderedcollectionpage.yaml +0 -50
  241. package/dist/src/vocab/organization.yaml +0 -324
  242. package/dist/src/vocab/page.yaml +0 -11
  243. package/dist/src/vocab/person.yaml +0 -324
  244. package/dist/src/vocab/place.yaml +0 -75
  245. package/dist/src/vocab/profile.yaml +0 -26
  246. package/dist/src/vocab/propertyvalue.yaml +0 -32
  247. package/dist/src/vocab/question.yaml +0 -103
  248. package/dist/src/vocab/read.yaml +0 -13
  249. package/dist/src/vocab/reject.yaml +0 -14
  250. package/dist/src/vocab/relationship.yaml +0 -52
  251. package/dist/src/vocab/remove.yaml +0 -14
  252. package/dist/src/vocab/service.yaml +0 -324
  253. package/dist/src/vocab/source.yaml +0 -26
  254. package/dist/src/vocab/tentativeaccept.yaml +0 -14
  255. package/dist/src/vocab/tentativereject.yaml +0 -14
  256. package/dist/src/vocab/tombstone.yaml +0 -24
  257. package/dist/src/vocab/travel.yaml +0 -16
  258. package/dist/src/vocab/undo.yaml +0 -26
  259. package/dist/src/vocab/update.yaml +0 -58
  260. package/dist/src/vocab/video.yaml +0 -11
  261. package/dist/src/vocab/view.yaml +0 -13
  262. package/dist/testing/docloader.test.js +0 -24
  263. package/dist/type-C69ZBu7f.js +0 -47010
  264. package/dist/vocab/actor.test.d.ts +0 -3
  265. package/dist/vocab/actor.test.js +0 -5965
  266. package/dist/vocab/lookup.test.d.ts +0 -3
  267. package/dist/vocab/lookup.test.js +0 -456
  268. package/dist/vocab/mod.cjs +0 -87
  269. package/dist/vocab/mod.d.cts +0 -6
  270. package/dist/vocab/mod.d.ts +0 -8
  271. package/dist/vocab/mod.js +0 -10
  272. package/dist/vocab/schema.yaml +0 -247
  273. package/dist/vocab/type.test.d.ts +0 -3
  274. package/dist/vocab/type.test.js +0 -25
  275. package/dist/vocab/vocab.test.d.ts +0 -3
  276. package/dist/vocab/vocab.test.js +0 -3787
  277. package/dist/vocab-B39-pFl9.cjs +0 -291
  278. package/dist/vocab-BI0Ak5lL.d.ts +0 -14924
  279. package/dist/vocab-BWoeZsME.js +0 -255
  280. package/dist/vocab-Dw1-yVGg.d.cts +0 -14922
  281. package/dist/webfinger/handler.test.d.ts +0 -3
  282. package/dist/webfinger/lookup.test.d.ts +0 -3
  283. package/dist/webfinger/lookup.test.js +0 -195
  284. package/dist/webfinger/mod.cjs +0 -9
  285. package/dist/webfinger/mod.d.cts +0 -4
  286. package/dist/webfinger/mod.d.ts +0 -6
  287. package/dist/webfinger/mod.js +0 -9
  288. package/dist/webfinger-BjOEdFPs.cjs +0 -4
  289. package/dist/webfinger-De_bU0iE.js +0 -4
  290. package/dist/x/cfworkers.cjs +0 -100
  291. package/dist/x/cfworkers.d.cts +0 -59
  292. package/dist/x/cfworkers.d.ts +0 -61
  293. package/dist/x/cfworkers.js +0 -98
  294. package/dist/x/cfworkers.test.d.ts +0 -3
  295. package/dist/x/cfworkers.test.js +0 -179
  296. package/dist/x/hono.cjs +0 -61
  297. package/dist/x/hono.d.cts +0 -54
  298. package/dist/x/hono.d.ts +0 -56
  299. package/dist/x/hono.js +0 -60
  300. package/dist/x/sveltekit.cjs +0 -69
  301. package/dist/x/sveltekit.d.cts +0 -46
  302. package/dist/x/sveltekit.d.ts +0 -48
  303. package/dist/x/sveltekit.js +0 -68
  304. /package/dist/{assert_not_equals-f3m3epl3.js → assert_not_equals-C80BG-_5.js} +0 -0
  305. /package/dist/{runtime/authdocloader.test.d.ts → federation/webfinger.test.d.ts} +0 -0
  306. /package/dist/{mod-1pDWKvUL.d.ts → mod-1E3W847c.d.ts} +0 -0
  307. /package/dist/{mod-C2tOeRkN.d.cts → mod-C81L6_lQ.d.cts} +0 -0
  308. /package/dist/{nodeinfo-DfycQ8Wf.js → nodeinfo-BlLsRSiT.js} +0 -0
  309. /package/dist/{nodeinfo-Co9lJrWl.cjs → nodeinfo-DuMYTpbZ.cjs} +0 -0
  310. /package/dist/{runtime/docloader.test.d.ts → otel/exporter.test.d.ts} +0 -0
  311. /package/dist/{runtime-DPYEDf-o.js → sig-CwuONEzF.js} +0 -0
  312. /package/dist/{runtime-C58AJWSv.cjs → sig-DeXX2xnj.cjs} +0 -0
  313. /package/dist/{std__assert-X-_kMxKM.js → std__assert-DWivtrGR.js} +0 -0
  314. /package/dist/{testing → utils}/docloader.test.d.ts +0 -0
  315. /package/dist/{runtime/key.test.d.ts → utils/kv-cache.test.d.ts} +0 -0
  316. /package/dist/{sig-ByHXzqUi.cjs → utils-Db0ZmjcD.cjs} +0 -0
  317. /package/dist/{sig-Cj3tk-ig.js → utils-Wranxuoe.js} +0 -0
@@ -3,16 +3,376 @@
3
3
  const { URLPattern } = require("urlpattern-polyfill");
4
4
 
5
5
  const require_chunk = require('./chunk-DqRYRqnO.cjs');
6
- const require_docloader = require('./docloader-CCqXeagZ.cjs');
7
- const require_actor = require('./actor-Be0ThtXy.cjs');
8
- const require_key = require('./key-Z6ceKnZC.cjs');
9
6
  const __logtape_logtape = require_chunk.__toESM(require("@logtape/logtape"));
7
+ const __fedify_vocab = require_chunk.__toESM(require("@fedify/vocab"));
10
8
  const __opentelemetry_api = require_chunk.__toESM(require("@opentelemetry/api"));
11
- const byte_encodings_base64 = require_chunk.__toESM(require("byte-encodings/base64"));
12
9
  const byte_encodings_hex = require_chunk.__toESM(require("byte-encodings/hex"));
13
10
  const __opentelemetry_semantic_conventions = require_chunk.__toESM(require("@opentelemetry/semantic-conventions"));
11
+ const byte_encodings_base64 = require_chunk.__toESM(require("byte-encodings/base64"));
14
12
  const structured_field_values = require_chunk.__toESM(require("structured-field-values"));
13
+ const __fedify_vocab_runtime = require_chunk.__toESM(require("@fedify/vocab-runtime"));
15
14
 
15
+ //#region deno.json
16
+ var name = "@fedify/fedify";
17
+ var version = "2.0.0-dev.170+a03fedcd";
18
+ var license = "MIT";
19
+ var exports$1 = {
20
+ ".": "./src/mod.ts",
21
+ "./compat": "./src/compat/mod.ts",
22
+ "./federation": "./src/federation/mod.ts",
23
+ "./nodeinfo": "./src/nodeinfo/mod.ts",
24
+ "./otel": "./src/otel/mod.ts",
25
+ "./sig": "./src/sig/mod.ts",
26
+ "./utils": "./src/utils/mod.ts"
27
+ };
28
+ var imports = {
29
+ "@multiformats/base-x": "npm:@multiformats/base-x@^4.0.1",
30
+ "@opentelemetry/core": "npm:@opentelemetry/core@^2.0.0",
31
+ "@opentelemetry/sdk-trace-base": "npm:@opentelemetry/sdk-trace-base@^2.0.0",
32
+ "@opentelemetry/semantic-conventions": "npm:@opentelemetry/semantic-conventions@^1.27.0",
33
+ "@std/assert": "jsr:@std/assert@^0.226.0",
34
+ "@std/url": "jsr:@std/url@^0.225.1",
35
+ "asn1js": "npm:asn1js@^3.0.7",
36
+ "fast-check": "npm:fast-check@^3.22.0",
37
+ "fetch-mock": "npm:fetch-mock@^12.5.2",
38
+ "json-canon": "npm:json-canon@^1.0.1",
39
+ "jsonld": "npm:jsonld@^9.0.0",
40
+ "multicodec": "npm:multicodec@^3.2.1",
41
+ "pkijs": "npm:pkijs@^3.3.3",
42
+ "structured-field-values": "npm:structured-field-values@^2.0.4",
43
+ "uri-template-router": "npm:uri-template-router@^1.0.0",
44
+ "url-template": "npm:url-template@^3.1.1"
45
+ };
46
+ var exclude = [
47
+ ".test-report.xml",
48
+ "apidoc/",
49
+ "dist/",
50
+ "node_modules/",
51
+ "npm/",
52
+ "pnpm-lock.yaml",
53
+ "src/cfworkers/dist/",
54
+ "src/cfworkers/fixtures/",
55
+ "src/cfworkers/imports.ts",
56
+ "src/cfworkers/README.md",
57
+ "src/cfworkers/server.ts",
58
+ "src/cfworkers/server.js",
59
+ "src/cfworkers/server.js.map"
60
+ ];
61
+ var publish = { "exclude": ["**/*.test.ts", "src/testing/"] };
62
+ var tasks = {
63
+ "codegen": "deno task -f @fedify/vocab compile",
64
+ "cache": {
65
+ "command": "deno cache src/mod.ts",
66
+ "dependencies": ["codegen"]
67
+ },
68
+ "check": {
69
+ "command": "deno fmt --check && deno lint && deno check src/**/*.ts",
70
+ "dependencies": ["codegen"]
71
+ },
72
+ "test": {
73
+ "command": "deno test --check --doc --allow-read --allow-write --allow-env --unstable-kv --trace-leaks --parallel",
74
+ "dependencies": ["codegen"]
75
+ },
76
+ "coverage": "deno task test --clean --coverage && deno coverage --html coverage",
77
+ "bench": {
78
+ "command": "deno bench --allow-read --allow-write --allow-net --allow-env --allow-run --unstable-kv",
79
+ "dependencies": ["codegen"]
80
+ },
81
+ "apidoc": {
82
+ "command": "deno doc --html --name=Fedify --output=apidoc/ src/mod.ts",
83
+ "dependencies": ["codegen"]
84
+ },
85
+ "publish": {
86
+ "command": "deno publish",
87
+ "dependencies": ["codegen"]
88
+ },
89
+ "pnpm:install": "pnpm install --silent",
90
+ "pnpm:build": {
91
+ "command": "pnpm exec tsdown",
92
+ "dependencies": ["pnpm:build-vocab"]
93
+ },
94
+ "test:node": {
95
+ "command": "cd dist/ && node --test",
96
+ "dependencies": ["pnpm:build"]
97
+ },
98
+ "test:bun": {
99
+ "command": "cd dist/ && bun test --timeout 60000",
100
+ "dependencies": ["pnpm:build"]
101
+ },
102
+ "test:cfworkers": {
103
+ "command": "pnpm exec wrangler deploy --dry-run --outdir src/cfworkers && node --import=tsx src/cfworkers/client.ts",
104
+ "dependencies": ["pnpm:build"]
105
+ },
106
+ "test-all": { "dependencies": [
107
+ "check",
108
+ "test",
109
+ "test:node",
110
+ "test:bun",
111
+ "test:cfworkers"
112
+ ] }
113
+ };
114
+ var deno_default = {
115
+ name,
116
+ version,
117
+ license,
118
+ exports: exports$1,
119
+ imports,
120
+ exclude,
121
+ publish,
122
+ tasks
123
+ };
124
+
125
+ //#endregion
126
+ //#region src/sig/key.ts
127
+ /**
128
+ * Checks if the given key is valid and supported. No-op if the key is valid,
129
+ * otherwise throws an error.
130
+ * @param key The key to check.
131
+ * @param type Which type of key to check. If not specified, the key can be
132
+ * either public or private.
133
+ * @throws {TypeError} If the key is invalid or unsupported.
134
+ */
135
+ function validateCryptoKey(key, type) {
136
+ if (type != null && key.type !== type) throw new TypeError(`The key is not a ${type} key.`);
137
+ if (!key.extractable) throw new TypeError("The key is not extractable.");
138
+ 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!");
139
+ if (key.algorithm.name === "RSASSA-PKCS1-v1_5") {
140
+ const algorithm = key.algorithm;
141
+ 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.");
142
+ }
143
+ }
144
+ /**
145
+ * Generates a key pair which is appropriate for Fedify.
146
+ * @param algorithm The algorithm to use. Currently only RSASSA-PKCS1-v1_5 and
147
+ * Ed25519 are supported.
148
+ * @returns The generated key pair.
149
+ * @throws {TypeError} If the algorithm is unsupported.
150
+ */
151
+ function generateCryptoKeyPair(algorithm) {
152
+ if (algorithm == null) (0, __logtape_logtape.getLogger)([
153
+ "fedify",
154
+ "sig",
155
+ "key"
156
+ ]).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.");
157
+ if (algorithm == null || algorithm === "RSASSA-PKCS1-v1_5") return crypto.subtle.generateKey({
158
+ name: "RSASSA-PKCS1-v1_5",
159
+ modulusLength: 4096,
160
+ publicExponent: new Uint8Array([
161
+ 1,
162
+ 0,
163
+ 1
164
+ ]),
165
+ hash: "SHA-256"
166
+ }, true, ["sign", "verify"]);
167
+ else if (algorithm === "Ed25519") return crypto.subtle.generateKey("Ed25519", true, ["sign", "verify"]);
168
+ throw new TypeError("Unsupported algorithm: " + algorithm);
169
+ }
170
+ /**
171
+ * Exports a key in JWK format.
172
+ * @param key The key to export. Either public or private key.
173
+ * @returns The exported key in JWK format. The key is suitable for
174
+ * serialization and storage.
175
+ * @throws {TypeError} If the key is invalid or unsupported.
176
+ */
177
+ async function exportJwk(key) {
178
+ validateCryptoKey(key);
179
+ const jwk = await crypto.subtle.exportKey("jwk", key);
180
+ if (jwk.crv === "Ed25519") jwk.alg = "Ed25519";
181
+ return jwk;
182
+ }
183
+ /**
184
+ * Imports a key from JWK format.
185
+ * @param jwk The key in JWK format.
186
+ * @param type Which type of key to import, either `"public"` or `"private"`.
187
+ * @returns The imported key.
188
+ * @throws {TypeError} If the key is invalid or unsupported.
189
+ */
190
+ async function importJwk(jwk, type) {
191
+ let key;
192
+ if (jwk.kty === "RSA" && jwk.alg === "RS256") key = await crypto.subtle.importKey("jwk", jwk, {
193
+ name: "RSASSA-PKCS1-v1_5",
194
+ hash: "SHA-256"
195
+ }, true, type === "public" ? ["verify"] : ["sign"]);
196
+ else if (jwk.kty === "OKP" && jwk.crv === "Ed25519") {
197
+ if (navigator?.userAgent === "Cloudflare-Workers") {
198
+ jwk = { ...jwk };
199
+ delete jwk.alg;
200
+ }
201
+ key = await crypto.subtle.importKey("jwk", jwk, "Ed25519", true, type === "public" ? ["verify"] : ["sign"]);
202
+ } else throw new TypeError("Unsupported JWK format.");
203
+ validateCryptoKey(key, type);
204
+ return key;
205
+ }
206
+ /**
207
+ * Fetches a {@link CryptographicKey} or {@link Multikey} from the given URL.
208
+ * If the given URL contains an {@link Actor} object, it tries to find
209
+ * the corresponding key in the `publicKey` or `assertionMethod` property.
210
+ * @template T The type of the key to fetch. Either {@link CryptographicKey}
211
+ * or {@link Multikey}.
212
+ * @param keyId The URL of the key.
213
+ * @param cls The class of the key to fetch. Either {@link CryptographicKey}
214
+ * or {@link Multikey}.
215
+ * @param options Options for fetching the key. See {@link FetchKeyOptions}.
216
+ * @returns The fetched key or `null` if the key is not found.
217
+ * @since 1.3.0
218
+ */
219
+ function fetchKey(keyId, cls, options = {}) {
220
+ const tracerProvider = options.tracerProvider ?? __opentelemetry_api.trace.getTracerProvider();
221
+ const tracer = tracerProvider.getTracer(deno_default.name, deno_default.version);
222
+ keyId = typeof keyId === "string" ? new URL(keyId) : keyId;
223
+ return tracer.startActiveSpan("activitypub.fetch_key", {
224
+ kind: __opentelemetry_api.SpanKind.CLIENT,
225
+ attributes: {
226
+ "http.method": "GET",
227
+ "url.full": keyId.href,
228
+ "url.scheme": keyId.protocol.replace(/:$/, ""),
229
+ "url.domain": keyId.hostname,
230
+ "url.path": keyId.pathname,
231
+ "url.query": keyId.search.replace(/^\?/, ""),
232
+ "url.fragment": keyId.hash.replace(/^#/, "")
233
+ }
234
+ }, async (span) => {
235
+ try {
236
+ const result = await fetchKeyInternal(keyId, cls, options);
237
+ span.setAttribute("activitypub.actor.key.cached", result.cached);
238
+ return result;
239
+ } catch (e) {
240
+ span.setStatus({
241
+ code: __opentelemetry_api.SpanStatusCode.ERROR,
242
+ message: String(e)
243
+ });
244
+ throw e;
245
+ } finally {
246
+ span.end();
247
+ }
248
+ });
249
+ }
250
+ async function fetchKeyInternal(keyId, cls, { documentLoader, contextLoader, keyCache, tracerProvider } = {}) {
251
+ const logger = (0, __logtape_logtape.getLogger)([
252
+ "fedify",
253
+ "sig",
254
+ "key"
255
+ ]);
256
+ const cacheKey = typeof keyId === "string" ? new URL(keyId) : keyId;
257
+ keyId = typeof keyId === "string" ? keyId : keyId.href;
258
+ if (keyCache != null) {
259
+ const cachedKey = await keyCache.get(cacheKey);
260
+ if (cachedKey instanceof cls && cachedKey.publicKey != null) {
261
+ logger.debug("Key {keyId} found in cache.", { keyId });
262
+ return {
263
+ key: cachedKey,
264
+ cached: true
265
+ };
266
+ } else if (cachedKey === null) {
267
+ logger.debug("Entry {keyId} found in cache, but it is unavailable.", { keyId });
268
+ return {
269
+ key: null,
270
+ cached: true
271
+ };
272
+ }
273
+ }
274
+ logger.debug("Fetching key {keyId} to verify signature...", { keyId });
275
+ let document;
276
+ try {
277
+ const remoteDocument = await (documentLoader ?? (0, __fedify_vocab_runtime.getDocumentLoader)())(keyId);
278
+ document = remoteDocument.document;
279
+ } catch (_) {
280
+ logger.debug("Failed to fetch key {keyId}.", { keyId });
281
+ await keyCache?.set(cacheKey, null);
282
+ return {
283
+ key: null,
284
+ cached: false
285
+ };
286
+ }
287
+ let object;
288
+ try {
289
+ object = await __fedify_vocab.Object.fromJsonLd(document, {
290
+ documentLoader,
291
+ contextLoader,
292
+ tracerProvider
293
+ });
294
+ } catch (e) {
295
+ if (!(e instanceof TypeError)) throw e;
296
+ try {
297
+ object = await cls.fromJsonLd(document, {
298
+ documentLoader,
299
+ contextLoader,
300
+ tracerProvider
301
+ });
302
+ } catch (e$1) {
303
+ if (e$1 instanceof TypeError) {
304
+ logger.debug("Failed to verify; key {keyId} returned an invalid object.", { keyId });
305
+ await keyCache?.set(cacheKey, null);
306
+ return {
307
+ key: null,
308
+ cached: false
309
+ };
310
+ }
311
+ throw e$1;
312
+ }
313
+ }
314
+ let key = null;
315
+ if (object instanceof cls) key = object;
316
+ else if ((0, __fedify_vocab.isActor)(object)) {
317
+ const keys = cls === __fedify_vocab.CryptographicKey ? object.getPublicKeys({
318
+ documentLoader,
319
+ contextLoader,
320
+ tracerProvider
321
+ }) : object.getAssertionMethods({
322
+ documentLoader,
323
+ contextLoader,
324
+ tracerProvider
325
+ });
326
+ let length = 0;
327
+ let lastKey = null;
328
+ for await (const k of keys) {
329
+ length++;
330
+ lastKey = k;
331
+ if (k.id?.href === keyId) {
332
+ key = k;
333
+ break;
334
+ }
335
+ }
336
+ const keyIdUrl = new URL(keyId);
337
+ if (key == null && keyIdUrl.hash === "" && length === 1) key = lastKey;
338
+ if (key == null) {
339
+ logger.debug("Failed to verify; object {keyId} returned an {actorType}, but has no key matching {keyId}.", {
340
+ keyId,
341
+ actorType: object.constructor.name
342
+ });
343
+ await keyCache?.set(cacheKey, null);
344
+ return {
345
+ key: null,
346
+ cached: false
347
+ };
348
+ }
349
+ } else {
350
+ logger.debug("Failed to verify; key {keyId} returned an invalid object.", { keyId });
351
+ await keyCache?.set(cacheKey, null);
352
+ return {
353
+ key: null,
354
+ cached: false
355
+ };
356
+ }
357
+ if (key.publicKey == null) {
358
+ logger.debug("Failed to verify; key {keyId} has no publicKeyPem field.", { keyId });
359
+ await keyCache?.set(cacheKey, null);
360
+ return {
361
+ key: null,
362
+ cached: false
363
+ };
364
+ }
365
+ if (keyCache != null) {
366
+ await keyCache.set(cacheKey, key);
367
+ logger.debug("Key {keyId} cached.", { keyId });
368
+ }
369
+ return {
370
+ key,
371
+ cached: false
372
+ };
373
+ }
374
+
375
+ //#endregion
16
376
  //#region src/sig/http.ts
17
377
  /**
18
378
  * Signs a request using the given private key.
@@ -24,9 +384,9 @@ const structured_field_values = require_chunk.__toESM(require("structured-field-
24
384
  * @throws {TypeError} If the private key is invalid or unsupported.
25
385
  */
26
386
  async function signRequest(request, privateKey, keyId, options = {}) {
27
- require_key.validateCryptoKey(privateKey, "private");
387
+ validateCryptoKey(privateKey, "private");
28
388
  const tracerProvider = options.tracerProvider ?? __opentelemetry_api.trace.getTracerProvider();
29
- const tracer = tracerProvider.getTracer(require_docloader.deno_default.name, require_docloader.deno_default.version);
389
+ const tracer = tracerProvider.getTracer(deno_default.name, deno_default.version);
30
390
  return await tracer.startActiveSpan("http_signatures.sign", async (span) => {
31
391
  try {
32
392
  const spec = options.spec ?? "draft-cavage-http-signatures-12";
@@ -36,7 +396,7 @@ async function signRequest(request, privateKey, keyId, options = {}) {
36
396
  if (span.isRecording()) {
37
397
  span.setAttribute(__opentelemetry_semantic_conventions.ATTR_HTTP_REQUEST_METHOD, signed.method);
38
398
  span.setAttribute(__opentelemetry_semantic_conventions.ATTR_URL_FULL, signed.url);
39
- for (const [name, value] of signed.headers) span.setAttribute((0, __opentelemetry_semantic_conventions.ATTR_HTTP_REQUEST_HEADER)(name), value);
399
+ for (const [name$1, value] of signed.headers) span.setAttribute((0, __opentelemetry_semantic_conventions.ATTR_HTTP_REQUEST_HEADER)(name$1), value);
40
400
  span.setAttribute("http_signatures.key_id", keyId.href);
41
401
  }
42
402
  return signed;
@@ -64,8 +424,8 @@ async function signRequestDraft(request, privateKey, keyId, span, currentTime, b
64
424
  }
65
425
  if (!headers.has("Date")) headers.set("Date", currentTime == null ? (/* @__PURE__ */ new Date()).toUTCString() : new Date(currentTime.toString()).toUTCString());
66
426
  const serialized = [["(request-target)", `${request.method.toLowerCase()} ${url.pathname}`], ...headers];
67
- const headerNames = serialized.map(([name]) => name);
68
- const message = serialized.map(([name, value]) => `${name}: ${value.trim()}`).join("\n");
427
+ const headerNames = serialized.map(([name$1]) => name$1);
428
+ const message = serialized.map(([name$1, value]) => `${name$1}: ${value.trim()}`).join("\n");
69
429
  const signature = await crypto.subtle.sign("RSASSA-PKCS1-v1_5", privateKey, new TextEncoder().encode(message));
70
430
  const sigHeader = `keyId="${keyId.href}",algorithm="rsa-sha256",headers="${headerNames.join(" ")}",signature="${(0, byte_encodings_base64.encodeBase64)(signature)}"`;
71
431
  headers.set("Signature", sigHeader);
@@ -255,12 +615,12 @@ const supportedHashAlgorithms = {
255
615
  */
256
616
  async function verifyRequest(request, options = {}) {
257
617
  const tracerProvider = options.tracerProvider ?? __opentelemetry_api.trace.getTracerProvider();
258
- const tracer = tracerProvider.getTracer(require_docloader.deno_default.name, require_docloader.deno_default.version);
618
+ const tracer = tracerProvider.getTracer(deno_default.name, deno_default.version);
259
619
  return await tracer.startActiveSpan("http_signatures.verify", async (span) => {
260
620
  if (span.isRecording()) {
261
621
  span.setAttribute(__opentelemetry_semantic_conventions.ATTR_HTTP_REQUEST_METHOD, request.method);
262
622
  span.setAttribute(__opentelemetry_semantic_conventions.ATTR_URL_FULL, request.url);
263
- for (const [name, value] of request.headers) span.setAttribute((0, __opentelemetry_semantic_conventions.ATTR_HTTP_REQUEST_HEADER)(name), value);
623
+ for (const [name$1, value] of request.headers) span.setAttribute((0, __opentelemetry_semantic_conventions.ATTR_HTTP_REQUEST_HEADER)(name$1), value);
264
624
  }
265
625
  try {
266
626
  let spec = options.spec;
@@ -427,7 +787,7 @@ async function verifyRequestDraft(request, span, { documentLoader, contextLoader
427
787
  const { keyId, headers, signature } = sigValues;
428
788
  span?.setAttribute("http_signatures.key_id", keyId);
429
789
  if ("algorithm" in sigValues) span?.setAttribute("http_signatures.algorithm", sigValues.algorithm);
430
- const { key, cached } = await require_key.fetchKey(new URL(keyId), require_actor.CryptographicKey, {
790
+ const { key, cached } = await fetchKey(new URL(keyId), __fedify_vocab.CryptographicKey, {
431
791
  documentLoader,
432
792
  contextLoader,
433
793
  keyCache,
@@ -443,7 +803,7 @@ async function verifyRequestDraft(request, span, { documentLoader, contextLoader
443
803
  logger.debug("Failed to verify; required headers missing in the Signature header: {headers}.", { headers });
444
804
  return null;
445
805
  }
446
- const message = headerNames.map((name) => `${name}: ` + (name === "(request-target)" ? `${request.method.toLowerCase()} ${new URL(request.url).pathname}` : name === "(created)" ? sigValues.created ?? "" : name === "(expires)" ? sigValues.expires ?? "" : name === "host" ? request.headers.get("host") ?? new URL(request.url).host : request.headers.get(name))).join("\n");
806
+ const message = headerNames.map((name$1) => `${name$1}: ` + (name$1 === "(request-target)" ? `${request.method.toLowerCase()} ${new URL(request.url).pathname}` : name$1 === "(created)" ? sigValues.created ?? "" : name$1 === "(expires)" ? sigValues.expires ?? "" : name$1 === "host" ? request.headers.get("host") ?? new URL(request.url).host : request.headers.get(name$1))).join("\n");
447
807
  const sig = (0, byte_encodings_base64.decodeBase64)(signature);
448
808
  span?.setAttribute("http_signatures.signature", (0, byte_encodings_hex.encodeHex)(sig));
449
809
  const verified = await crypto.subtle.verify("RSASSA-PKCS1-v1_5", key.publicKey, sig, new TextEncoder().encode(message));
@@ -620,7 +980,7 @@ async function verifyRequestRfc9421(request, span, { documentLoader, contextLoad
620
980
  }
621
981
  span?.setAttribute("http_signatures.key_id", sigInput.keyId);
622
982
  span?.setAttribute("http_signatures.created", sigInput.created.toString());
623
- const { key, cached } = await require_key.fetchKey(new URL(sigInput.keyId), require_actor.CryptographicKey, {
983
+ const { key, cached } = await fetchKey(new URL(sigInput.keyId), __fedify_vocab.CryptographicKey, {
624
984
  documentLoader,
625
985
  contextLoader,
626
986
  keyCache,
@@ -806,18 +1166,54 @@ function timingSafeEqual(a, b) {
806
1166
  }
807
1167
 
808
1168
  //#endregion
1169
+ Object.defineProperty(exports, 'deno_default', {
1170
+ enumerable: true,
1171
+ get: function () {
1172
+ return deno_default;
1173
+ }
1174
+ });
809
1175
  Object.defineProperty(exports, 'doubleKnock', {
810
1176
  enumerable: true,
811
1177
  get: function () {
812
1178
  return doubleKnock;
813
1179
  }
814
1180
  });
1181
+ Object.defineProperty(exports, 'exportJwk', {
1182
+ enumerable: true,
1183
+ get: function () {
1184
+ return exportJwk;
1185
+ }
1186
+ });
1187
+ Object.defineProperty(exports, 'fetchKey', {
1188
+ enumerable: true,
1189
+ get: function () {
1190
+ return fetchKey;
1191
+ }
1192
+ });
1193
+ Object.defineProperty(exports, 'generateCryptoKeyPair', {
1194
+ enumerable: true,
1195
+ get: function () {
1196
+ return generateCryptoKeyPair;
1197
+ }
1198
+ });
1199
+ Object.defineProperty(exports, 'importJwk', {
1200
+ enumerable: true,
1201
+ get: function () {
1202
+ return importJwk;
1203
+ }
1204
+ });
815
1205
  Object.defineProperty(exports, 'signRequest', {
816
1206
  enumerable: true,
817
1207
  get: function () {
818
1208
  return signRequest;
819
1209
  }
820
1210
  });
1211
+ Object.defineProperty(exports, 'validateCryptoKey', {
1212
+ enumerable: true,
1213
+ get: function () {
1214
+ return validateCryptoKey;
1215
+ }
1216
+ });
821
1217
  Object.defineProperty(exports, 'verifyRequest', {
822
1218
  enumerable: true,
823
1219
  get: function () {