@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
@@ -1,309 +0,0 @@
1
- import { Temporal } from "@js-temporal/polyfill";
2
- import { URLPattern } from "urlpattern-polyfill";
3
- import { DocumentLoader, GetUserAgentOptions } from "./docloader-CxWcuWqQ.js";
4
- import { Collection, Link, Object as Object$1 } from "./vocab-BI0Ak5lL.js";
5
- import { TracerProvider } from "@opentelemetry/api";
6
-
7
- //#region src/vocab/lookup.d.ts
8
- /**
9
- * Options for the {@link lookupObject} function.
10
- *
11
- * @since 0.2.0
12
- */
13
- interface LookupObjectOptions {
14
- /**
15
- * The document loader for loading remote JSON-LD documents.
16
- */
17
- documentLoader?: DocumentLoader;
18
- /**
19
- * The context loader for loading remote JSON-LD contexts.
20
- * @since 0.8.0
21
- */
22
- contextLoader?: DocumentLoader;
23
- /**
24
- * Whether to allow fetching an object with an `@id` having a different
25
- * origin than the object's URL. This is not recommended, as it may
26
- * lead to security issues. Only use this option if you know what you
27
- * are doing.
28
- *
29
- * How to handle the case when an object's `@id` has a different origin
30
- * than the object's URL:
31
- *
32
- * - `"ignore"` (default): Do not return the object, and log a warning.
33
- * - `"throw"`: Throw an error.
34
- * - `"trust"`: Bypass the check and return the object anyway. This
35
- * is not recommended, as it may lead to security issues. Only use
36
- * this option if you know what you are doing.
37
- *
38
- * @since 1.9.0
39
- */
40
- crossOrigin?: "ignore" | "throw" | "trust";
41
- /**
42
- * The options for making `User-Agent` header.
43
- * If a string is given, it is used as the `User-Agent` header value.
44
- * If an object is given, it is passed to {@link getUserAgent} to generate
45
- * the `User-Agent` header value.
46
- * @since 1.3.0
47
- */
48
- userAgent?: GetUserAgentOptions | string;
49
- /**
50
- * The OpenTelemetry tracer provider. If omitted, the global tracer provider
51
- * is used.
52
- * @since 1.3.0
53
- */
54
- tracerProvider?: TracerProvider;
55
- /**
56
- * AbortSignal for cancelling the request.
57
- * @since 1.8.0
58
- */
59
- signal?: AbortSignal;
60
- }
61
- /**
62
- * Looks up an ActivityStreams object by its URI (including `acct:` URIs)
63
- * or a fediverse handle (e.g., `@user@server` or `user@server`).
64
- *
65
- * @example
66
- * ``` typescript
67
- * // Look up an actor by its fediverse handle:
68
- * await lookupObject("@hongminhee@fosstodon.org");
69
- * // returning a `Person` object.
70
- *
71
- * // A fediverse handle can omit the leading '@':
72
- * await lookupObject("hongminhee@fosstodon.org");
73
- * // returning a `Person` object.
74
- *
75
- * // A `acct:` URI can be used as well:
76
- * await lookupObject("acct:hongminhee@fosstodon.org");
77
- * // returning a `Person` object.
78
- *
79
- * // Look up an object by its URI:
80
- * await lookupObject("https://todon.eu/@hongminhee/112060633798771581");
81
- * // returning a `Note` object.
82
- *
83
- * // It can be a `URL` object as well:
84
- * await lookupObject(new URL("https://todon.eu/@hongminhee/112060633798771581"));
85
- * // returning a `Note` object.
86
- * ```
87
- *
88
- * @param identifier The URI or fediverse handle to look up.
89
- * @param options Lookup options.
90
- * @returns The object, or `null` if not found.
91
- * @since 0.2.0
92
- */
93
- declare function lookupObject(identifier: string | URL, options?: LookupObjectOptions): Promise<Object$1 | null>;
94
- /**
95
- * Options for the {@link traverseCollection} function.
96
- * @since 1.1.0
97
- */
98
- interface TraverseCollectionOptions {
99
- /**
100
- * The document loader for loading remote JSON-LD documents.
101
- */
102
- documentLoader?: DocumentLoader;
103
- /**
104
- * The context loader for loading remote JSON-LD contexts.
105
- */
106
- contextLoader?: DocumentLoader;
107
- /**
108
- * Whether to suppress errors when fetching pages. If `true`,
109
- * errors will be logged but not thrown. Defaults to `false`.
110
- */
111
- suppressError?: boolean;
112
- /**
113
- * The interval to wait between fetching pages. Zero or negative
114
- * values will disable the interval. Disabled by default.
115
- *
116
- * @default `{ seconds: 0 }`
117
- */
118
- interval?: Temporal.Duration | Temporal.DurationLike;
119
- }
120
- /**
121
- * Traverses a collection, yielding each item in the collection.
122
- * If the collection is paginated, it will fetch the next page
123
- * automatically.
124
- *
125
- * @example
126
- * ``` typescript
127
- * const collection = await lookupObject(collectionUrl);
128
- * if (collection instanceof Collection) {
129
- * for await (const item of traverseCollection(collection)) {
130
- * console.log(item.id?.href);
131
- * }
132
- * }
133
- * ```
134
- *
135
- * @param collection The collection to traverse.
136
- * @param options Options for traversing the collection.
137
- * @returns An async iterable of each item in the collection.
138
- * @since 1.1.0
139
- */
140
- declare function traverseCollection(collection: Collection, options?: TraverseCollectionOptions): AsyncIterable<Object$1 | Link>;
141
- //#endregion
142
- //#region src/vocab/constants.d.ts
143
- /**
144
- * The special public collection for [public addressing]. *Do not mutate this
145
- * object.*
146
- *
147
- * [public addressing]: https://www.w3.org/TR/activitypub/#public-addressing
148
- *
149
- * @since 0.7.0
150
- */
151
- declare const PUBLIC_COLLECTION: URL;
152
- //#endregion
153
- //#region src/vocab/handle.d.ts
154
- /**
155
- * Represents a fediverse handle, which consists of a username and a host.
156
- * The username can be alphanumeric and may include special characters,
157
- * while the host is typically a domain name.
158
- * @since 1.8.0
159
- */
160
- interface FediverseHandle {
161
- /**
162
- * The username part of the fediverse handle.
163
- * It can include alphanumeric characters and some special characters.
164
- */
165
- readonly username: string;
166
- /**
167
- * The host part of the fediverse handle, typically a domain name.
168
- * It is the part after the `@` symbol in the handle.
169
- */
170
- readonly host: string;
171
- }
172
- /**
173
- * Parses a fediverse handle in the format `@user@server` or `user@server`.
174
- * The `user` part can contain alphanumeric characters and some special
175
- * characters except `@`. The `server` part is all characters after the `@`
176
- * symbol in the middle.
177
- *
178
- * @example
179
- * ```typescript
180
- * const handle = parseFediverseHandle("@username@example.com");
181
- * console.log(handle?.username); // "username"
182
- * console.log(handle?.host); // "example.com"
183
- * ```
184
- *
185
- * @param handle - The fediverse handle string to parse.
186
- * @returns A {@link FediverseHandle} object with `username` and `host`
187
- * if the input is valid; otherwise `null`.
188
- * @since 1.8.0
189
- */
190
- declare function parseFediverseHandle(handle: string): FediverseHandle | null;
191
- /**
192
- * Checks if a string is a valid fediverse handle in the format `@user@server`
193
- * or `user@server`. The `user` part can contain alphanumeric characters and
194
- * some special characters except `@`. The `server` part is all characters
195
- * after the `@` symbol in the middle.
196
- *
197
- * @example
198
- * ```typescript
199
- * console.log(isFediverseHandle("@username@example.com")); // true
200
- * console.log(isFediverseHandle("username@example.com")); // true
201
- * console.log(isFediverseHandle("@username@")); // false
202
- * ```
203
- *
204
- * @param handle - The string to test as a fediverse handle.
205
- * @returns `true` if the string matches the fediverse handle pattern;
206
- * otherwise `false`.
207
- * @since 1.8.0
208
- */
209
- declare function isFediverseHandle(handle: string): handle is `${string}@${string}`;
210
- /**
211
- * Converts a fediverse handle in the format `@user@server` or `user@server`
212
- * to an `acct:` URI, which is a URL-like identifier for ActivityPub actors.
213
- *
214
- * @example
215
- * ```typescript
216
- * const identifier = toAcctUrl("@username@example.com");
217
- * console.log(identifier?.href); // "acct:username@example.com"
218
- * ```
219
- *
220
- * @param handle - The fediverse handle string to convert.
221
- * @returns A `URL` object representing the `acct:` URI if conversion succeeds;
222
- * otherwise `null`.
223
- * @since 1.8.0
224
- */
225
- declare function toAcctUrl(handle: string): URL | null;
226
- //#endregion
227
- //#region src/vocab/type.d.ts
228
- /**
229
- * Returns the type URI of the given object.
230
- *
231
- * @example
232
- * ``` typescript
233
- * import { getTypeId, Person } from "@fedify/fedify";
234
- *
235
- * const obj = new Person({});
236
- * console.log(getTypeId(obj));
237
- * // => new URL("https://www.w3.org/ns/activitystreams#Person")
238
- * ```
239
- *
240
- * @param object The Activity Vocabulary object.
241
- * @returns The type URI of the object, e.g.,
242
- * `new URL("https://www.w3.org/ns/activitystreams#Person")`.
243
- * If the given `object` is `null` or `undefined`, returns `null` or
244
- * `undefined`, respectively.
245
- * @since 1.3.0
246
- */
247
- declare function getTypeId(object: Object$1 | Link): URL;
248
- /**
249
- * Returns the type URI of the given object.
250
- *
251
- * @example
252
- * ``` typescript
253
- * import { getTypeId, Person } from "@fedify/fedify";
254
- *
255
- * const obj = new Person({});
256
- * console.log(getTypeId(obj));
257
- * // => new URL("https://www.w3.org/ns/activitystreams#Person")
258
- * ```
259
- *
260
- * @param object The Activity Vocabulary object.
261
- * @returns The type URI of the object, e.g.,
262
- * `new URL("https://www.w3.org/ns/activitystreams#Person")`.
263
- * If the given `object` is `null` or `undefined`, returns `null` or
264
- * `undefined`, respectively.
265
- * @since 1.3.0
266
- */
267
- declare function getTypeId(object: Object$1 | Link | undefined): URL | undefined;
268
- /**
269
- * Returns the type URI of the given object.
270
- *
271
- * @example
272
- * ``` typescript
273
- * import { getTypeId, Person } from "@fedify/fedify";
274
- *
275
- * const obj = new Person({});
276
- * console.log(getTypeId(obj));
277
- * // => new URL("https://www.w3.org/ns/activitystreams#Person")
278
- * ```
279
- *
280
- * @param object The Activity Vocabulary object.
281
- * @returns The type URI of the object, e.g.,
282
- * `new URL("https://www.w3.org/ns/activitystreams#Person")`.
283
- * If the given `object` is `null` or `undefined`, returns `null` or
284
- * `undefined`, respectively.
285
- * @since 1.3.0
286
- */
287
- declare function getTypeId(object: Object$1 | Link | null): URL | null;
288
- /**
289
- * Returns the type URI of the given object.
290
- *
291
- * @example
292
- * ``` typescript
293
- * import { getTypeId, Person } from "@fedify/fedify";
294
- *
295
- * const obj = new Person({});
296
- * console.log(getTypeId(obj));
297
- * // => new URL("https://www.w3.org/ns/activitystreams#Person")
298
- * ```
299
- *
300
- * @param object The Activity Vocabulary object.
301
- * @returns The type URI of the object, e.g.,
302
- * `new URL("https://www.w3.org/ns/activitystreams#Person")`.
303
- * If the given `object` is `null` or `undefined`, returns `null` or
304
- * `undefined`, respectively.
305
- * @since 1.3.0
306
- */
307
- declare function getTypeId(object: Object$1 | Link | null | undefined): URL | null | undefined;
308
- //#endregion
309
- export { FediverseHandle, LookupObjectOptions, PUBLIC_COLLECTION, TraverseCollectionOptions, getTypeId, isFediverseHandle, lookupObject, parseFediverseHandle, toAcctUrl, traverseCollection };
@@ -1 +0,0 @@
1
- export { };
@@ -1,2 +0,0 @@
1
- import { Temporal } from "@js-temporal/polyfill";
2
- import { URLPattern } from "urlpattern-polyfill";
@@ -1,113 +0,0 @@
1
- import { GetUserAgentOptions } from "./docloader-D-MrRyHl.cjs";
2
- import { TracerProvider } from "@opentelemetry/api";
3
-
4
- //#region src/webfinger/jrd.d.ts
5
- /**
6
- * Describes a resource. See also
7
- * [RFC 7033 section 4.4](https://datatracker.ietf.org/doc/html/rfc7033#section-4.4).
8
- */
9
- interface ResourceDescriptor {
10
- /**
11
- * A URI that identifies the entity that this descriptor describes.
12
- */
13
- subject?: string;
14
- /**
15
- * URIs that identify the same entity as the `subject`.
16
- */
17
- aliases?: string[];
18
- /**
19
- * Conveys additional information about the `subject` of this descriptor.
20
- */
21
- properties?: Record<string, string>;
22
- /**
23
- * Links to other resources.
24
- */
25
- links?: Link[];
26
- }
27
- /**
28
- * Represents a link. See also
29
- * [RFC 7033 section 4.4.4](https://datatracker.ietf.org/doc/html/rfc7033#section-4.4.4).
30
- */
31
- interface Link {
32
- /**
33
- * The link's relation type, which is either a URI or a registered relation
34
- * type (see [RFC 5988](https://datatracker.ietf.org/doc/html/rfc5988)).
35
- */
36
- rel: string;
37
- /**
38
- * The media type of the target resource (see
39
- * [RFC 6838](https://datatracker.ietf.org/doc/html/rfc6838)).
40
- */
41
- type?: string;
42
- /**
43
- * A URI pointing to the target resource.
44
- */
45
- href?: string;
46
- /**
47
- * Human-readable titles describing the link relation. If the language is
48
- * unknown or unspecified, the key is `"und"`.
49
- */
50
- titles?: Record<string, string>;
51
- /**
52
- * Conveys additional information about the link relation.
53
- */
54
- properties?: Record<string, string>;
55
- /**
56
- * A URI Template (RFC 6570) that can be used to construct URIs by
57
- * substituting variables. Used primarily for subscription endpoints
58
- * where parameters like account URIs need to be dynamically inserted.
59
- * @since 1.9.0
60
- */
61
- template?: string;
62
- }
63
- //#endregion
64
- //#region src/webfinger/lookup.d.ts
65
- /**
66
- * Options for {@link lookupWebFinger}.
67
- * @since 1.3.0
68
- */
69
- interface LookupWebFingerOptions {
70
- /**
71
- * The options for making `User-Agent` header.
72
- * If a string is given, it is used as the `User-Agent` header value.
73
- * If an object is given, it is passed to {@link getUserAgent} to generate
74
- * the `User-Agent` header value.
75
- */
76
- userAgent?: GetUserAgentOptions | string;
77
- /**
78
- * Whether to allow private IP addresses in the URL.
79
- *
80
- * Mostly useful for testing purposes. *Do not use this in production.*
81
- *
82
- * Turned off by default.
83
- * @since 1.4.0
84
- */
85
- allowPrivateAddress?: boolean;
86
- /**
87
- * The maximum number of redirections to follow.
88
- * @default `5`
89
- * @since 1.8.0
90
- */
91
- maxRedirection?: number;
92
- /**
93
- * The OpenTelemetry tracer provider. If omitted, the global tracer provider
94
- * is used.
95
- */
96
- tracerProvider?: TracerProvider;
97
- /**
98
- * AbortSignal for cancelling the request.
99
- * @since 1.8.0
100
- * @
101
- */
102
- signal?: AbortSignal;
103
- }
104
- /**
105
- * Looks up a WebFinger resource.
106
- * @param resource The resource URL to look up.
107
- * @param options Extra options for looking up the resource.
108
- * @returns The resource descriptor, or `null` if not found.
109
- * @since 0.2.0
110
- */
111
- declare function lookupWebFinger(resource: URL | string, options?: LookupWebFingerOptions): Promise<ResourceDescriptor | null>;
112
- //#endregion
113
- export { Link, LookupWebFingerOptions, ResourceDescriptor, lookupWebFinger };
@@ -1,140 +0,0 @@
1
- //#region src/federation/mq.d.ts
2
- /**
3
- * Additional options for enqueuing a message in a queue.
4
- *
5
- * @since 0.5.0
6
- */
7
- interface MessageQueueEnqueueOptions {
8
- /**
9
- * The delay before the message is enqueued. No delay by default.
10
- *
11
- * It must not be negative.
12
- */
13
- delay?: Temporal.Duration;
14
- }
15
- /**
16
- * Additional options for listening to a message queue.
17
- *
18
- * @since 1.0.0
19
- */
20
- interface MessageQueueListenOptions {
21
- /**
22
- * The signal to abort listening to the message queue.
23
- */
24
- signal?: AbortSignal;
25
- }
26
- /**
27
- * An abstract interface for a message queue.
28
- *
29
- * @since 0.5.0
30
- */
31
- interface MessageQueue {
32
- /**
33
- * Whether the message queue backend provides native retry mechanisms.
34
- * When `true`, Fedify will skip its own retry logic and rely on the backend
35
- * to handle retries. When `false` or omitted, Fedify will handle retries
36
- * using its own retry policies.
37
- *
38
- * @default `false`
39
- * @since 1.7.0
40
- */
41
- readonly nativeRetrial?: boolean;
42
- /**
43
- * Enqueues a message in the queue.
44
- * @param message The message to enqueue.
45
- * @param options Additional options for enqueuing the message.
46
- */
47
- enqueue(message: any, options?: MessageQueueEnqueueOptions): Promise<void>;
48
- /**
49
- * Enqueues multiple messages in the queue. This operation is optional,
50
- * and may not be supported by all implementations. If not supported,
51
- * Fedify will invoke {@link enqueue} for each message.
52
- *
53
- * @param messages The messages to enqueue.
54
- * @param options Additional options for enqueuing the messages.
55
- */
56
- enqueueMany?: (messages: any[], options?: MessageQueueEnqueueOptions) => Promise<void>;
57
- /**
58
- * Listens for messages in the queue.
59
- * @param handler The handler for messages in the queue.
60
- * @param options Additional options for listening to the message queue.
61
- * @returns A promise that resolves when the listening is done. It never
62
- * rejects, and is resolved when the signal is aborted. If no
63
- * signal is provided, it never resolves.
64
- */
65
- listen(handler: (message: any) => Promise<void> | void, options?: MessageQueueListenOptions): Promise<void>;
66
- }
67
- /**
68
- * Additional options for {@link InProcessMessageQueue}.
69
- * @since 1.0.0
70
- */
71
- interface InProcessMessageQueueOptions {
72
- /**
73
- * The interval to poll for messages in the queue. 5 seconds by default.
74
- * @default `{ seconds: 5 }`
75
- */
76
- pollInterval?: Temporal.Duration | Temporal.DurationLike;
77
- }
78
- /**
79
- * A message queue that processes messages in the same process.
80
- * Do not use this in production as it does neither persist messages nor
81
- * distribute them across multiple processes.
82
- *
83
- * @since 0.5.0
84
- */
85
- declare class InProcessMessageQueue implements MessageQueue {
86
- #private;
87
- /**
88
- * In-process message queue does not provide native retry mechanisms.
89
- * @since 1.7.0
90
- */
91
- readonly nativeRetrial = false;
92
- /**
93
- * Constructs a new {@link InProcessMessageQueue} with the given options.
94
- * @param options Additional options for the in-process message queue.
95
- */
96
- constructor(options?: InProcessMessageQueueOptions);
97
- enqueue(message: any, options?: MessageQueueEnqueueOptions): Promise<void>;
98
- enqueueMany(messages: any[], options?: MessageQueueEnqueueOptions): Promise<void>;
99
- listen(handler: (message: any) => Promise<void> | void, options?: MessageQueueListenOptions): Promise<void>;
100
- }
101
- /**
102
- * A message queue that processes messages in parallel. It takes another
103
- * {@link MessageQueue}, and processes messages in parallel up to a certain
104
- * number of workers.
105
- *
106
- * Actually, it's rather a decorator than a queue itself.
107
- *
108
- * Note that the workers do not run in truly parallel, in the sense that they
109
- * are not running in separate threads or processes. They are running in the
110
- * same process, but are scheduled to run in parallel. Hence, this is useful
111
- * for I/O-bound tasks, but not for CPU-bound tasks, which is okay for Fedify's
112
- * workloads.
113
- *
114
- * @since 1.0.0
115
- */
116
- declare class ParallelMessageQueue implements MessageQueue {
117
- #private;
118
- readonly queue: MessageQueue;
119
- readonly workers: number;
120
- /**
121
- * Inherits the native retry capability from the wrapped queue.
122
- * @since 1.7.0
123
- */
124
- readonly nativeRetrial?: boolean;
125
- /**
126
- * Constructs a new {@link ParallelMessageQueue} with the given queue and
127
- * number of workers.
128
- * @param queue The message queue to use under the hood. Note that
129
- * {@link ParallelMessageQueue} cannot be nested.
130
- * @param workers The number of workers to process messages in parallel.
131
- * @throws {TypeError} If the given queue is an instance of
132
- * {@link ParallelMessageQueue}.
133
- */
134
- constructor(queue: MessageQueue, workers: number);
135
- enqueue(message: any, options?: MessageQueueEnqueueOptions): Promise<void>;
136
- enqueueMany(messages: any[], options?: MessageQueueEnqueueOptions): Promise<void>;
137
- listen(handler: (message: any) => Promise<void> | void, options?: MessageQueueListenOptions): Promise<void>;
138
- }
139
- //#endregion
140
- export { InProcessMessageQueue, InProcessMessageQueueOptions, MessageQueue, MessageQueueEnqueueOptions, MessageQueueListenOptions, ParallelMessageQueue };