@fedify/fedify 2.0.0-dev.1485 → 2.0.0-dev.149

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 (311) hide show
  1. package/LICENSE +1 -1
  2. package/README.md +38 -18
  3. package/dist/actor-CCAL5-E_.cjs +42079 -0
  4. package/dist/{actor-7ivEf1H3.js → actor-DYdPViDz.js} +4 -1
  5. package/dist/{actor-C22bXuuC.d.ts → actor-DqFajh9s.d.ts} +2 -2
  6. package/dist/{actor-DXTdNCfp.js → actor-U_BZZ2ps.js} +7058 -2722
  7. package/dist/actor-f2NtjyCg.d.cts +128 -0
  8. package/dist/{assert-MZs1qjMx.js → assert-Dp5_aoAs.js} +1 -1
  9. package/dist/{assert_instance_of-DHz7EHNU.js → assert_instance_of-D1m8F7x0.js} +1 -1
  10. package/dist/{assert_not_equals-f3m3epl3.js → assert_not_equals-B2R_8p36.js} +1 -1
  11. package/dist/{assert_rejects-DiIiJbZn.js → assert_rejects-BoKYY0g1.js} +2 -2
  12. package/dist/{assert_is_error-BPGph1Jx.js → assert_throws-DjkXin1a.js} +32 -2
  13. package/dist/{builder-BPGqEvtB.js → builder-CYR2yKqn.js} +20 -8
  14. package/dist/chunk-DqRYRqnO.cjs +34 -0
  15. package/dist/chunk-HsBuZ-b2.js +41 -0
  16. package/dist/client-94iWEfQa.d.cts +222 -0
  17. package/dist/{client-DF8anIB5.d.ts → client-BsGzbnV-.d.ts} +3 -75
  18. package/dist/{client-g2FDBoeY.js → client-CD87uCL_.js} +4 -23
  19. package/dist/compat/mod.cjs +10 -0
  20. package/dist/compat/mod.d.cts +11 -0
  21. package/dist/compat/mod.d.ts +10 -12
  22. package/dist/compat/mod.js +5 -5
  23. package/dist/compat/transformers.test.js +29 -24
  24. package/dist/compat-DmDDELst.cjs +4 -0
  25. package/dist/compat-nxUqe4Z-.js +4 -0
  26. package/dist/context-DBQ7nMCw.d.cts +2449 -0
  27. package/dist/context-DH7LHJdw.js +109 -0
  28. package/dist/{context-DmlbRh9p.d.ts → context-mM0Nu5yo.d.ts} +335 -134
  29. package/dist/deno-BTeveqhY.js +131 -0
  30. package/dist/{testing-BG_8Fyas.js → dist-lStjlyET.js} +73 -114
  31. package/dist/{authdocloader-D_IvQE4z.js → docloader-BSGGKhrl.js} +17 -8
  32. package/dist/{esm-CPZhxxGc.js → esm-B52TuumP.js} +32 -17
  33. package/dist/federation/builder.test.js +16 -16
  34. package/dist/federation/collection.test.js +9 -12
  35. package/dist/federation/handler.test.js +123 -152
  36. package/dist/federation/idempotency.test.js +206 -0
  37. package/dist/federation/inbox.test.js +7 -7
  38. package/dist/federation/keycache.test.js +7 -8
  39. package/dist/federation/kv.test.js +64 -12
  40. package/dist/federation/middleware.test.js +281 -99
  41. package/dist/federation/mod.cjs +27 -0
  42. package/dist/federation/mod.d.cts +11 -0
  43. package/dist/federation/mod.d.ts +11 -13
  44. package/dist/federation/mod.js +13 -15
  45. package/dist/federation/mq.test.js +12 -13
  46. package/dist/federation/negotiation.test.js +25 -0
  47. package/dist/federation/retry.test.js +4 -6
  48. package/dist/federation/router.test.js +9 -11
  49. package/dist/federation/send.test.js +61 -18
  50. package/dist/federation-CoW-KDKv.cjs +266 -0
  51. package/dist/{federation-CMX7WzeL.js → federation-D0hkM4T7.js} +25 -3
  52. package/dist/{http-C7rxW7Kh.js → http-BIDOYI9f.js} +4 -3
  53. package/dist/{http-zsOxPKCt.js → http-BQRnmfXP.js} +260 -10
  54. package/dist/{http-DqSNLFNY.d.ts → http-BbO0ejuk.d.ts} +2 -2
  55. package/dist/http-DtYHWbwa.cjs +1106 -0
  56. package/dist/http-M8k5mKc0.d.cts +253 -0
  57. package/dist/{inbox-eK2W2MF3.js → inbox-DNjplQSR.js} +26 -7
  58. package/dist/{key-CYOcZ9G5.js → key-dws2_YsP.js} +4 -2
  59. package/dist/{keycache-BLq6GT4_.js → keycache-BbbXRjc-.js} +1 -1
  60. package/dist/{keys-BIwlbtMN.js → keys-C6QyjjIN.js} +2 -1
  61. package/dist/{kv-C7sopW2E.d.ts → kv-BpJND1Hr.d.ts} +30 -1
  62. package/dist/{kv-CRZrzyXm.js → kv-DaWUKuhD.js} +22 -0
  63. package/dist/kv-cD_d4hg-.d.cts +110 -0
  64. package/dist/kv-cache-1_lcnUMp.cjs +134 -0
  65. package/dist/kv-cache-BEP4OyiZ.js +122 -0
  66. package/dist/kv-cache-C6NrTtII.js +107 -0
  67. package/dist/{ld-DWwLYT4e.js → ld-C6UrncJk.js} +7 -4
  68. package/dist/lookup-BORWbouU.cjs +268 -0
  69. package/dist/lookup-BV72lfsA.js +256 -0
  70. package/dist/{lookup-DNQyH8UQ.js → lookup-BoiLMtAx.js} +33 -125
  71. package/dist/{lookup-BHYMosdS.js → lookup-yv_aH7K7.js} +3 -1
  72. package/dist/{middleware-BcVqlHyD.js → middleware--1K3DAB8.js} +143 -136
  73. package/dist/middleware-7Yg2p_nl.js +31 -0
  74. package/dist/{middleware-DakCaqXu.js → middleware-8Oymc6Na.js} +105 -188
  75. package/dist/middleware-C6YBw2qx.cjs +15 -0
  76. package/dist/middleware-D6XNERu3.js +15 -0
  77. package/dist/middleware-DBHDivdC.cjs +4237 -0
  78. package/dist/mod-B-hUPT2N.d.cts +1 -0
  79. package/dist/{mod-Cxt4Kpf6.d.ts → mod-BlVovdcy.d.ts} +20 -2
  80. package/dist/mod-BxRCHTz-.d.cts +307 -0
  81. package/dist/mod-C58MZ7Wx.d.cts +113 -0
  82. package/dist/mod-CAdoBu0x.d.ts +109 -0
  83. package/dist/mod-CcDPcLJW.d.cts +1 -0
  84. package/dist/{mod-Drmz72EK.d.ts → mod-D5Z2tISD.d.ts} +3 -3
  85. package/dist/mod-DgxG-byT.d.cts +266 -0
  86. package/dist/{lookup-3czM5mmU.d.ts → mod-Ds0mpFZU.d.ts} +9 -2
  87. package/dist/mod-Dy2fJtmN.d.cts +80 -0
  88. package/dist/{mod-0EysZ-dJ.d.ts → mod-GetHzY6F.d.ts} +2 -2
  89. package/dist/mod-fxr25Gv7.d.cts +107 -0
  90. package/dist/mod.cjs +137 -0
  91. package/dist/mod.d.cts +15 -0
  92. package/dist/mod.d.ts +15 -18
  93. package/dist/mod.js +19 -21
  94. package/dist/negotiation-B4NJHk1f.js +71 -0
  95. package/dist/nodeinfo/client.test.js +32 -114
  96. package/dist/nodeinfo/handler.test.js +35 -30
  97. package/dist/nodeinfo/mod.cjs +10 -0
  98. package/dist/nodeinfo/mod.d.cts +3 -0
  99. package/dist/nodeinfo/mod.d.ts +3 -5
  100. package/dist/nodeinfo/mod.js +6 -7
  101. package/dist/nodeinfo/types.test.js +10 -18
  102. package/dist/nodeinfo-BnthBobC.js +4 -0
  103. package/dist/nodeinfo-CdN0rEnZ.cjs +4 -0
  104. package/dist/otel/exporter.test.js +899 -0
  105. package/dist/otel/mod.cjs +262 -0
  106. package/dist/otel/mod.d.cts +230 -0
  107. package/dist/otel/mod.d.ts +232 -0
  108. package/dist/otel/mod.js +261 -0
  109. package/dist/owner-B4HbyP8s.d.cts +67 -0
  110. package/dist/{owner-smArESGi.js → owner-DQuVKHuY.js} +46 -8
  111. package/dist/{owner-CQPnQVtf.d.ts → owner-kQRGVXG1.d.ts} +3 -3
  112. package/dist/{proof-CT1SITRP.js → proof-BG2G4cDG.js} +53 -16
  113. package/dist/proof-C3K5Z8RT.cjs +710 -0
  114. package/dist/{proof-C6z-uqeO.js → proof-GrivUN5L.js} +5 -3
  115. package/dist/router-CVRQXlZi.js +118 -0
  116. package/dist/{send-1zdmNlUo.js → send-B_dTZyUD.js} +9 -4
  117. package/dist/sig/http.test.js +19 -17
  118. package/dist/sig/key.test.js +15 -14
  119. package/dist/sig/ld.test.js +13 -12
  120. package/dist/sig/mod.cjs +28 -0
  121. package/dist/sig/mod.d.cts +6 -0
  122. package/dist/sig/mod.d.ts +5 -7
  123. package/dist/sig/mod.js +8 -10
  124. package/dist/sig/owner.test.js +40 -15
  125. package/dist/sig/proof.test.js +19 -17
  126. package/dist/sig-C34-oHBl.js +4 -0
  127. package/dist/sig-YYj5tCnr.cjs +4 -0
  128. package/dist/{std__assert-X-_kMxKM.js → std__assert-Cm-MfI66.js} +1 -1
  129. package/dist/testing/mod.d.ts +410 -232
  130. package/dist/testing/mod.js +9 -4
  131. package/dist/{transformers-Dna8Fg7k.js → transformers-BFT6d7J5.js} +3 -3
  132. package/dist/transformers-CoBS-oFG.cjs +116 -0
  133. package/dist/type-BSNcIxTd.js +14 -0
  134. package/dist/{types-BzyGRkRt.js → types-BtUjyi5y.js} +9 -170
  135. package/dist/types-CWgzGaqk.cjs +315 -0
  136. package/dist/{types-BIgY6c-l.js → types-D2jhK2VG.js} +1 -3
  137. package/dist/{runtime/authdocloader.test.js → utils/docloader.test.js} +20 -18
  138. package/dist/utils/kv-cache.test.js +211 -0
  139. package/dist/utils/mod.cjs +12 -0
  140. package/dist/utils/mod.d.cts +5 -0
  141. package/dist/utils/mod.d.ts +7 -0
  142. package/dist/utils/mod.js +11 -0
  143. package/dist/utils-D-Va7aXC.js +4 -0
  144. package/dist/utils-DyRU1gdZ.cjs +4 -0
  145. package/dist/vocab/actor.test.js +15 -13
  146. package/dist/vocab/lookup.test.js +285 -12
  147. package/dist/vocab/mod.cjs +86 -0
  148. package/dist/vocab/mod.d.cts +4 -0
  149. package/dist/vocab/mod.d.ts +3 -5
  150. package/dist/vocab/mod.js +6 -7
  151. package/dist/vocab/type.test.js +4 -4
  152. package/dist/vocab/vocab.test.js +8058 -1987
  153. package/dist/{vocab-Bg1J3mu4.js → vocab-Aig1Fmi8.js} +32 -18
  154. package/dist/{vocab-SOE1ifCr.d.ts → vocab-BCWe1Ih5.d.ts} +292 -21
  155. package/dist/{type-I68qwqmo.js → vocab-C3nSleOZ.js} +6947 -7381
  156. package/dist/vocab-CeDBzu-f.d.cts +14903 -0
  157. package/dist/vocab-DFMYh9aV.cjs +296 -0
  158. package/dist/webfinger/handler.test.js +62 -29
  159. package/dist/webfinger/lookup.test.js +11 -12
  160. package/dist/webfinger/mod.cjs +8 -0
  161. package/dist/webfinger/mod.d.cts +2 -0
  162. package/dist/webfinger/mod.d.ts +1 -4
  163. package/dist/webfinger/mod.js +5 -6
  164. package/dist/webfinger-C72Y8lrh.js +4 -0
  165. package/dist/webfinger-vAtLmxOF.cjs +4 -0
  166. package/package.json +81 -45
  167. package/dist/assert_throws-BOO88avQ.js +0 -39
  168. package/dist/authdocloader-Bq0gEHRj.js +0 -52
  169. package/dist/compat-Bb5myD13.js +0 -4
  170. package/dist/denokv-Bv33Xxea.js +0 -57
  171. package/dist/docloader-BlVueewg.js +0 -4615
  172. package/dist/docloader-CxWcuWqQ.d.ts +0 -221
  173. package/dist/fixtures/activitypub.academy/users/brauca_darradiul.json +0 -83
  174. package/dist/fixtures/example.com/announce.json +0 -6
  175. package/dist/fixtures/example.com/collection.json +0 -19
  176. package/dist/fixtures/example.com/create.json +0 -6
  177. package/dist/fixtures/example.com/cross-origin-actor.json +0 -6
  178. package/dist/fixtures/example.com/hong-gildong.json +0 -11
  179. package/dist/fixtures/example.com/invite.json +0 -7
  180. package/dist/fixtures/example.com/key.json +0 -7
  181. package/dist/fixtures/example.com/key2.json +0 -6
  182. package/dist/fixtures/example.com/object.json +0 -6
  183. package/dist/fixtures/example.com/orderedcollectionpage.json +0 -24
  184. package/dist/fixtures/example.com/paged/a.json +0 -13
  185. package/dist/fixtures/example.com/paged/b.json +0 -16
  186. package/dist/fixtures/example.com/paged-collection.json +0 -6
  187. package/dist/fixtures/example.com/person.json +0 -22
  188. package/dist/fixtures/example.com/person2.json +0 -40
  189. package/dist/fixtures/example.com/test.json +0 -5
  190. package/dist/fixtures/example.com/users/handle.json +0 -16
  191. package/dist/fixtures/example.com/wrong-type.json +0 -3
  192. package/dist/fixtures/oeee.cafe/ap/users/3609fd4e-d51d-4db8-9f04-4189815864dd.json +0 -24
  193. package/dist/fixtures/remote.domain/users/bob.json +0 -20
  194. package/dist/fixtures/server.example/users/alice.json +0 -20
  195. package/dist/fixtures/w3id.org/identity/v1.json +0 -152
  196. package/dist/fixtures/w3id.org/security/data-integrity/v1.json +0 -74
  197. package/dist/fixtures/w3id.org/security/multikey/v1.json +0 -35
  198. package/dist/fixtures/w3id.org/security/v1.json +0 -50
  199. package/dist/fixtures/wizard.casa/users/hongminhee.json +0 -69
  200. package/dist/fixtures/www.w3.org/ns/activitystreams.json +0 -379
  201. package/dist/fixtures/www.w3.org/ns/did/v1.json +0 -58
  202. package/dist/key-Dn7Lram-.js +0 -260
  203. package/dist/key-S7WllAWz.js +0 -10
  204. package/dist/key-rRCUafNm.js +0 -10
  205. package/dist/middleware-CWbGhXnl.js +0 -26
  206. package/dist/middleware-D-OlNiyj.js +0 -17
  207. package/dist/mod-TFoH2Ql8.d.ts +0 -104
  208. package/dist/mod-g0xFzAP9.d.ts +0 -2
  209. package/dist/mq-CRGm1e_F.d.ts +0 -143
  210. package/dist/nodeinfo/semver.test.js +0 -143
  211. package/dist/nodeinfo-CyEbLjHs.js +0 -4
  212. package/dist/runtime/docloader.test.js +0 -522
  213. package/dist/runtime/key.test.js +0 -103
  214. package/dist/runtime/langstr.test.d.ts +0 -3
  215. package/dist/runtime/langstr.test.js +0 -39
  216. package/dist/runtime/mod.d.ts +0 -8
  217. package/dist/runtime/mod.js +0 -13
  218. package/dist/runtime/multibase/multibase.test.d.ts +0 -3
  219. package/dist/runtime/multibase/multibase.test.js +0 -358
  220. package/dist/runtime/url.test.d.ts +0 -3
  221. package/dist/runtime/url.test.js +0 -45
  222. package/dist/runtime-BSkOVUWM.js +0 -4
  223. package/dist/semver-dArNLkR9.js +0 -149
  224. package/dist/sig-BXJO--F9.js +0 -4
  225. package/dist/src/vocab/accept.yaml +0 -15
  226. package/dist/src/vocab/activity.yaml +0 -98
  227. package/dist/src/vocab/add.yaml +0 -16
  228. package/dist/src/vocab/announce.yaml +0 -30
  229. package/dist/src/vocab/application.yaml +0 -324
  230. package/dist/src/vocab/arrive.yaml +0 -15
  231. package/dist/src/vocab/article.yaml +0 -46
  232. package/dist/src/vocab/audio.yaml +0 -11
  233. package/dist/src/vocab/block.yaml +0 -16
  234. package/dist/src/vocab/chatmessage.yaml +0 -50
  235. package/dist/src/vocab/collection.yaml +0 -154
  236. package/dist/src/vocab/collectionpage.yaml +0 -55
  237. package/dist/src/vocab/create.yaml +0 -28
  238. package/dist/src/vocab/dataintegrityproof.yaml +0 -56
  239. package/dist/src/vocab/delete.yaml +0 -27
  240. package/dist/src/vocab/didservice.yaml +0 -22
  241. package/dist/src/vocab/dislike.yaml +0 -14
  242. package/dist/src/vocab/document.yaml +0 -31
  243. package/dist/src/vocab/emoji.yaml +0 -12
  244. package/dist/src/vocab/emojireact.yaml +0 -17
  245. package/dist/src/vocab/endpoints.yaml +0 -85
  246. package/dist/src/vocab/event.yaml +0 -11
  247. package/dist/src/vocab/export.yaml +0 -9
  248. package/dist/src/vocab/flag.yaml +0 -15
  249. package/dist/src/vocab/follow.yaml +0 -19
  250. package/dist/src/vocab/group.yaml +0 -324
  251. package/dist/src/vocab/hashtag.yaml +0 -14
  252. package/dist/src/vocab/ignore.yaml +0 -14
  253. package/dist/src/vocab/image.yaml +0 -9
  254. package/dist/src/vocab/intransitiveactivity.yaml +0 -15
  255. package/dist/src/vocab/invite.yaml +0 -14
  256. package/dist/src/vocab/join.yaml +0 -14
  257. package/dist/src/vocab/key.yaml +0 -28
  258. package/dist/src/vocab/leave.yaml +0 -14
  259. package/dist/src/vocab/like.yaml +0 -16
  260. package/dist/src/vocab/link.yaml +0 -101
  261. package/dist/src/vocab/listen.yaml +0 -12
  262. package/dist/src/vocab/mention.yaml +0 -9
  263. package/dist/src/vocab/move.yaml +0 -15
  264. package/dist/src/vocab/multikey.yaml +0 -36
  265. package/dist/src/vocab/note.yaml +0 -48
  266. package/dist/src/vocab/object.yaml +0 -404
  267. package/dist/src/vocab/offer.yaml +0 -15
  268. package/dist/src/vocab/orderedcollection.yaml +0 -39
  269. package/dist/src/vocab/orderedcollectionpage.yaml +0 -50
  270. package/dist/src/vocab/organization.yaml +0 -324
  271. package/dist/src/vocab/page.yaml +0 -11
  272. package/dist/src/vocab/person.yaml +0 -324
  273. package/dist/src/vocab/place.yaml +0 -75
  274. package/dist/src/vocab/profile.yaml +0 -26
  275. package/dist/src/vocab/propertyvalue.yaml +0 -32
  276. package/dist/src/vocab/question.yaml +0 -103
  277. package/dist/src/vocab/read.yaml +0 -13
  278. package/dist/src/vocab/reject.yaml +0 -14
  279. package/dist/src/vocab/relationship.yaml +0 -52
  280. package/dist/src/vocab/remove.yaml +0 -14
  281. package/dist/src/vocab/service.yaml +0 -324
  282. package/dist/src/vocab/source.yaml +0 -26
  283. package/dist/src/vocab/tentativeaccept.yaml +0 -14
  284. package/dist/src/vocab/tentativereject.yaml +0 -14
  285. package/dist/src/vocab/tombstone.yaml +0 -24
  286. package/dist/src/vocab/travel.yaml +0 -16
  287. package/dist/src/vocab/undo.yaml +0 -26
  288. package/dist/src/vocab/update.yaml +0 -58
  289. package/dist/src/vocab/video.yaml +0 -11
  290. package/dist/src/vocab/view.yaml +0 -13
  291. package/dist/testing/docloader.test.js +0 -24
  292. package/dist/vocab/schema.yaml +0 -247
  293. package/dist/webfinger-C3GIyXIg.js +0 -4
  294. package/dist/x/cfworkers.d.ts +0 -61
  295. package/dist/x/cfworkers.js +0 -98
  296. package/dist/x/cfworkers.test.d.ts +0 -3
  297. package/dist/x/cfworkers.test.js +0 -179
  298. package/dist/x/hono.d.ts +0 -56
  299. package/dist/x/hono.js +0 -60
  300. package/dist/x/sveltekit.d.ts +0 -48
  301. package/dist/x/sveltekit.js +0 -68
  302. /package/dist/{assert_equals-DSbWqCm3.js → assert_equals-Gbplq4lg.js} +0 -0
  303. /package/dist/{collection-CSzG2j1P.js → collection-CrkRM5Ep.js} +0 -0
  304. /package/dist/{nodeinfo/semver.test.d.ts → federation/idempotency.test.d.ts} +0 -0
  305. /package/dist/{runtime/authdocloader.test.d.ts → federation/negotiation.test.d.ts} +0 -0
  306. /package/dist/{mod-1pDWKvUL.d.ts → mod-CVgZgliM.d.ts} +0 -0
  307. /package/dist/{mod-GIh5OYxW.d.ts → mod-bjzj5QIb.d.ts} +0 -0
  308. /package/dist/{runtime/docloader.test.d.ts → otel/exporter.test.d.ts} +0 -0
  309. /package/dist/{retry-D4GJ670a.js → retry-Bz5pP75o.js} +0 -0
  310. /package/dist/{testing → utils}/docloader.test.d.ts +0 -0
  311. /package/dist/{runtime/key.test.d.ts → utils/kv-cache.test.d.ts} +0 -0
@@ -0,0 +1,296 @@
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_lookup = require('./lookup-BORWbouU.cjs');
7
+ const require_actor = require('./actor-CCAL5-E_.cjs');
8
+ const __logtape_logtape = require_chunk.__toESM(require("@logtape/logtape"));
9
+ const __opentelemetry_api = require_chunk.__toESM(require("@opentelemetry/api"));
10
+ const __fedify_vocab_runtime = require_chunk.__toESM(require("@fedify/vocab-runtime"));
11
+ const es_toolkit = require_chunk.__toESM(require("es-toolkit"));
12
+
13
+ //#region src/vocab/handle.ts
14
+ /**
15
+ * Regular expression to match a fediverse handle in the format `@user@server`
16
+ * or `user@server`. The `user` part can contain alphanumeric characters and
17
+ * some special characters except `@`. The `server` part is all characters
18
+ * after the `@` symbol in the middle.
19
+ */
20
+ const handleRegexp = /^@?((?:[-A-Za-z0-9._~!$&'()*+,;=]|%[A-Fa-f0-9]{2})+)@([^@]+)$/;
21
+ /**
22
+ * Parses a fediverse handle in the format `@user@server` or `user@server`.
23
+ * The `user` part can contain alphanumeric characters and some special
24
+ * characters except `@`. The `server` part is all characters after the `@`
25
+ * symbol in the middle.
26
+ *
27
+ * @example
28
+ * ```typescript
29
+ * const handle = parseFediverseHandle("@username@example.com");
30
+ * console.log(handle?.username); // "username"
31
+ * console.log(handle?.host); // "example.com"
32
+ * ```
33
+ *
34
+ * @param handle - The fediverse handle string to parse.
35
+ * @returns A {@link FediverseHandle} object with `username` and `host`
36
+ * if the input is valid; otherwise `null`.
37
+ * @since 1.8.0
38
+ */
39
+ function parseFediverseHandle(handle) {
40
+ const match = handleRegexp.exec(handle);
41
+ if (match) return {
42
+ username: match[1],
43
+ host: match[2]
44
+ };
45
+ return null;
46
+ }
47
+ /**
48
+ * Checks if a string is a valid fediverse handle in the format `@user@server`
49
+ * or `user@server`. The `user` part can contain alphanumeric characters and
50
+ * some special characters except `@`. The `server` part is all characters
51
+ * after the `@` symbol in the middle.
52
+ *
53
+ * @example
54
+ * ```typescript
55
+ * console.log(isFediverseHandle("@username@example.com")); // true
56
+ * console.log(isFediverseHandle("username@example.com")); // true
57
+ * console.log(isFediverseHandle("@username@")); // false
58
+ * ```
59
+ *
60
+ * @param handle - The string to test as a fediverse handle.
61
+ * @returns `true` if the string matches the fediverse handle pattern;
62
+ * otherwise `false`.
63
+ * @since 1.8.0
64
+ */
65
+ function isFediverseHandle(handle) {
66
+ return handleRegexp.test(handle);
67
+ }
68
+ /**
69
+ * Converts a fediverse handle in the format `@user@server` or `user@server`
70
+ * to an `acct:` URI, which is a URL-like identifier for ActivityPub actors.
71
+ *
72
+ * @example
73
+ * ```typescript
74
+ * const identifier = toAcctUrl("@username@example.com");
75
+ * console.log(identifier?.href); // "acct:username@example.com"
76
+ * ```
77
+ *
78
+ * @param handle - The fediverse handle string to convert.
79
+ * @returns A `URL` object representing the `acct:` URI if conversion succeeds;
80
+ * otherwise `null`.
81
+ * @since 1.8.0
82
+ */
83
+ function toAcctUrl(handle) {
84
+ const parsed = parseFediverseHandle(handle);
85
+ if (!parsed) return null;
86
+ const identifier = new URL(`acct:${parsed.username}@${parsed.host}`);
87
+ return identifier;
88
+ }
89
+
90
+ //#endregion
91
+ //#region src/vocab/lookup.ts
92
+ const logger = (0, __logtape_logtape.getLogger)([
93
+ "fedify",
94
+ "vocab",
95
+ "lookup"
96
+ ]);
97
+ /**
98
+ * Looks up an ActivityStreams object by its URI (including `acct:` URIs)
99
+ * or a fediverse handle (e.g., `@user@server` or `user@server`).
100
+ *
101
+ * @example
102
+ * ``` typescript
103
+ * // Look up an actor by its fediverse handle:
104
+ * await lookupObject("@hongminhee@fosstodon.org");
105
+ * // returning a `Person` object.
106
+ *
107
+ * // A fediverse handle can omit the leading '@':
108
+ * await lookupObject("hongminhee@fosstodon.org");
109
+ * // returning a `Person` object.
110
+ *
111
+ * // A `acct:` URI can be used as well:
112
+ * await lookupObject("acct:hongminhee@fosstodon.org");
113
+ * // returning a `Person` object.
114
+ *
115
+ * // Look up an object by its URI:
116
+ * await lookupObject("https://todon.eu/@hongminhee/112060633798771581");
117
+ * // returning a `Note` object.
118
+ *
119
+ * // It can be a `URL` object as well:
120
+ * await lookupObject(new URL("https://todon.eu/@hongminhee/112060633798771581"));
121
+ * // returning a `Note` object.
122
+ * ```
123
+ *
124
+ * @param identifier The URI or fediverse handle to look up.
125
+ * @param options Lookup options.
126
+ * @returns The object, or `null` if not found.
127
+ * @since 0.2.0
128
+ */
129
+ async function lookupObject(identifier, options = {}) {
130
+ const tracerProvider = options.tracerProvider ?? __opentelemetry_api.trace.getTracerProvider();
131
+ const tracer = tracerProvider.getTracer(require_lookup.deno_default.name, require_lookup.deno_default.version);
132
+ return await tracer.startActiveSpan("activitypub.lookup_object", async (span) => {
133
+ try {
134
+ const result = await lookupObjectInternal(identifier, options);
135
+ if (result == null) span.setStatus({ code: __opentelemetry_api.SpanStatusCode.ERROR });
136
+ else {
137
+ if (result.id != null) span.setAttribute("activitypub.object.id", result.id.href);
138
+ span.setAttribute("activitypub.object.type", require_actor.getTypeId(result).href);
139
+ if (result.replyTargetIds.length > 0) span.setAttribute("activitypub.object.in_reply_to", result.replyTargetIds.map((id) => id.href));
140
+ span.addEvent("activitypub.object.fetched", {
141
+ "activitypub.object.type": require_actor.getTypeId(result).href,
142
+ "activitypub.object.json": JSON.stringify(await result.toJsonLd(options))
143
+ });
144
+ }
145
+ return result;
146
+ } catch (error) {
147
+ span.recordException(error);
148
+ span.setStatus({
149
+ code: __opentelemetry_api.SpanStatusCode.ERROR,
150
+ message: String(error)
151
+ });
152
+ throw error;
153
+ } finally {
154
+ span.end();
155
+ }
156
+ });
157
+ }
158
+ async function lookupObjectInternal(identifier, options = {}) {
159
+ const documentLoader = options.documentLoader ?? (0, __fedify_vocab_runtime.getDocumentLoader)({ userAgent: options.userAgent });
160
+ if (typeof identifier === "string") identifier = toAcctUrl(identifier) ?? new URL(identifier);
161
+ let remoteDoc = null;
162
+ if (identifier.protocol === "http:" || identifier.protocol === "https:") try {
163
+ remoteDoc = await documentLoader(identifier.href, { signal: options.signal });
164
+ } catch (error) {
165
+ logger.debug("Failed to fetch remote document:\n{error}", { error });
166
+ }
167
+ if (remoteDoc == null) {
168
+ const jrd = await require_lookup.lookupWebFinger(identifier, {
169
+ userAgent: options.userAgent,
170
+ tracerProvider: options.tracerProvider,
171
+ allowPrivateAddress: "allowPrivateAddress" in options && options.allowPrivateAddress === true,
172
+ signal: options.signal
173
+ });
174
+ if (jrd?.links == null) return null;
175
+ for (const l of jrd.links) {
176
+ 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;
177
+ try {
178
+ remoteDoc = await documentLoader(l.href, { signal: options.signal });
179
+ break;
180
+ } catch (error) {
181
+ logger.debug("Failed to fetch remote document:\n{error}", { error });
182
+ continue;
183
+ }
184
+ }
185
+ }
186
+ if (remoteDoc == null) return null;
187
+ let object;
188
+ try {
189
+ object = await require_actor.Object.fromJsonLd(remoteDoc.document, {
190
+ documentLoader,
191
+ contextLoader: options.contextLoader,
192
+ tracerProvider: options.tracerProvider,
193
+ baseUrl: new URL(remoteDoc.documentUrl)
194
+ });
195
+ } catch (error) {
196
+ if (error instanceof TypeError) {
197
+ logger.debug("Failed to parse JSON-LD document: {error}\n{document}", {
198
+ ...remoteDoc,
199
+ error
200
+ });
201
+ return null;
202
+ }
203
+ throw error;
204
+ }
205
+ if (options.crossOrigin !== "trust" && object.id != null && object.id.origin !== new URL(remoteDoc.documentUrl).origin) {
206
+ 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".`);
207
+ 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\".", {
208
+ ...remoteDoc,
209
+ objectId: object.id.href
210
+ });
211
+ return null;
212
+ }
213
+ return object;
214
+ }
215
+ /**
216
+ * Traverses a collection, yielding each item in the collection.
217
+ * If the collection is paginated, it will fetch the next page
218
+ * automatically.
219
+ *
220
+ * @example
221
+ * ``` typescript
222
+ * const collection = await lookupObject(collectionUrl);
223
+ * if (collection instanceof Collection) {
224
+ * for await (const item of traverseCollection(collection)) {
225
+ * console.log(item.id?.href);
226
+ * }
227
+ * }
228
+ * ```
229
+ *
230
+ * @param collection The collection to traverse.
231
+ * @param options Options for traversing the collection.
232
+ * @returns An async iterable of each item in the collection.
233
+ * @since 1.1.0
234
+ */
235
+ async function* traverseCollection(collection, options = {}) {
236
+ if (collection.firstId == null) for await (const item of collection.getItems(options)) yield item;
237
+ else {
238
+ const interval = Temporal.Duration.from(options.interval ?? { seconds: 0 }).total("millisecond");
239
+ let page = await collection.getFirst(options);
240
+ while (page != null) {
241
+ for await (const item of page.getItems(options)) yield item;
242
+ if (interval > 0) await (0, es_toolkit.delay)(interval);
243
+ page = await page.getNext(options);
244
+ }
245
+ }
246
+ }
247
+
248
+ //#endregion
249
+ //#region src/vocab/constants.ts
250
+ /**
251
+ * The special public collection for [public addressing]. *Do not mutate this
252
+ * object.*
253
+ *
254
+ * [public addressing]: https://www.w3.org/TR/activitypub/#public-addressing
255
+ *
256
+ * @since 0.7.0
257
+ */
258
+ const PUBLIC_COLLECTION = new URL("https://www.w3.org/ns/activitystreams#Public");
259
+
260
+ //#endregion
261
+ Object.defineProperty(exports, 'PUBLIC_COLLECTION', {
262
+ enumerable: true,
263
+ get: function () {
264
+ return PUBLIC_COLLECTION;
265
+ }
266
+ });
267
+ Object.defineProperty(exports, 'isFediverseHandle', {
268
+ enumerable: true,
269
+ get: function () {
270
+ return isFediverseHandle;
271
+ }
272
+ });
273
+ Object.defineProperty(exports, 'lookupObject', {
274
+ enumerable: true,
275
+ get: function () {
276
+ return lookupObject;
277
+ }
278
+ });
279
+ Object.defineProperty(exports, 'parseFediverseHandle', {
280
+ enumerable: true,
281
+ get: function () {
282
+ return parseFediverseHandle;
283
+ }
284
+ });
285
+ Object.defineProperty(exports, 'toAcctUrl', {
286
+ enumerable: true,
287
+ get: function () {
288
+ return toAcctUrl;
289
+ }
290
+ });
291
+ Object.defineProperty(exports, 'traverseCollection', {
292
+ enumerable: true,
293
+ get: function () {
294
+ return traverseCollection;
295
+ }
296
+ });
@@ -3,35 +3,40 @@
3
3
  import { URLPattern } from "urlpattern-polyfill";
4
4
  globalThis.addEventListener = () => {};
5
5
 
6
- import { Image, Link, Person } from "../type-I68qwqmo.js";
7
- import { assertEquals } from "../assert_equals-DSbWqCm3.js";
8
- import "../assert-MZs1qjMx.js";
9
- import "../assert_instance_of-DHz7EHNU.js";
10
- import { MemoryKvStore } from "../kv-CRZrzyXm.js";
11
- import { createFederation, handleWebFinger } from "../middleware-DakCaqXu.js";
12
- import "../semver-dArNLkR9.js";
13
- import "../client-g2FDBoeY.js";
14
- import "../lookup-DNQyH8UQ.js";
15
- import "../types-BIgY6c-l.js";
16
- import "../actor-7ivEf1H3.js";
17
- import "../key-CYOcZ9G5.js";
18
- import "../http-C7rxW7Kh.js";
19
- import "../authdocloader-D_IvQE4z.js";
20
- import "../ld-DWwLYT4e.js";
21
- import "../owner-smArESGi.js";
22
- import "../proof-C6z-uqeO.js";
23
- import "../inbox-eK2W2MF3.js";
24
- import "../builder-BPGqEvtB.js";
25
- import "../collection-CSzG2j1P.js";
26
- import "../keycache-BLq6GT4_.js";
27
- import "../retry-D4GJ670a.js";
28
- import "../send-1zdmNlUo.js";
29
- import { createRequestContext, test } from "../testing-BG_8Fyas.js";
30
- import "../std__assert-X-_kMxKM.js";
31
- import "../assert_rejects-DiIiJbZn.js";
32
- import "../assert_is_error-BPGph1Jx.js";
33
- import "../assert_not_equals-f3m3epl3.js";
34
- import "../assert_throws-BOO88avQ.js";
6
+ import { test } from "../dist-lStjlyET.js";
7
+ import { assertEquals } from "../assert_equals-Gbplq4lg.js";
8
+ import "../assert-Dp5_aoAs.js";
9
+ import "../assert_instance_of-D1m8F7x0.js";
10
+ import { MemoryKvStore } from "../kv-DaWUKuhD.js";
11
+ import "../deno-BTeveqhY.js";
12
+ import { createFederation, handleWebFinger } from "../middleware-8Oymc6Na.js";
13
+ import "../client-CD87uCL_.js";
14
+ import "../router-CVRQXlZi.js";
15
+ import "../types-D2jhK2VG.js";
16
+ import { Image, Link, Person } from "../vocab-C3nSleOZ.js";
17
+ import "../lookup-yv_aH7K7.js";
18
+ import "../type-BSNcIxTd.js";
19
+ import "../actor-DYdPViDz.js";
20
+ import "../key-dws2_YsP.js";
21
+ import "../http-BIDOYI9f.js";
22
+ import "../ld-C6UrncJk.js";
23
+ import "../owner-DQuVKHuY.js";
24
+ import "../proof-GrivUN5L.js";
25
+ import "../docloader-BSGGKhrl.js";
26
+ import "../kv-cache-C6NrTtII.js";
27
+ import "../lookup-BoiLMtAx.js";
28
+ import "../inbox-DNjplQSR.js";
29
+ import "../builder-CYR2yKqn.js";
30
+ import "../collection-CrkRM5Ep.js";
31
+ import "../keycache-BbbXRjc-.js";
32
+ import "../negotiation-B4NJHk1f.js";
33
+ import "../retry-Bz5pP75o.js";
34
+ import "../send-B_dTZyUD.js";
35
+ import "../std__assert-Cm-MfI66.js";
36
+ import "../assert_rejects-BoKYY0g1.js";
37
+ import "../assert_throws-DjkXin1a.js";
38
+ import "../assert_not_equals-B2R_8p36.js";
39
+ import { createRequestContext } from "../context-DH7LHJdw.js";
35
40
 
36
41
  //#region src/webfinger/handler.test.ts
37
42
  test("handleWebFinger()", async (t) => {
@@ -505,6 +510,34 @@ test("handleWebFinger()", async (t) => {
505
510
  assertEquals(response.headers.get("Access-Control-Allow-Origin"), "*");
506
511
  assertEquals(await response.json(), expectedForHostnameWithPort);
507
512
  });
513
+ await t.step("webFingerLinksDispatcher", async () => {
514
+ const webFingerLinksDispatcher = (_ctx) => {
515
+ return [{
516
+ rel: "http://ostatus.org/schema/1.0/subscribe",
517
+ template: "https://example.com/follow?acct={uri}"
518
+ }];
519
+ };
520
+ const u = new URL(url);
521
+ u.searchParams.set("resource", "acct:someone@example.com");
522
+ const context = createContext(u);
523
+ const request = context.request;
524
+ const response = await handleWebFinger(request, {
525
+ context,
526
+ actorDispatcher,
527
+ webFingerLinksDispatcher,
528
+ onNotFound
529
+ });
530
+ assertEquals(response.status, 200);
531
+ const result = await response.json();
532
+ const expectedWithCustomLinks = {
533
+ ...expected,
534
+ links: [...expected.links, {
535
+ rel: "http://ostatus.org/schema/1.0/subscribe",
536
+ template: "https://example.com/follow?acct={uri}"
537
+ }]
538
+ };
539
+ assertEquals(result, expectedWithCustomLinks);
540
+ });
508
541
  });
509
542
 
510
543
  //#endregion
@@ -3,18 +3,17 @@
3
3
  import { URLPattern } from "urlpattern-polyfill";
4
4
  globalThis.addEventListener = () => {};
5
5
 
6
- import { lookupWebFinger } from "../type-I68qwqmo.js";
7
- import { assertEquals } from "../assert_equals-DSbWqCm3.js";
8
- import "../assert-MZs1qjMx.js";
9
- import "../assert_instance_of-DHz7EHNU.js";
10
- import "../lookup-DNQyH8UQ.js";
11
- import { test } from "../testing-BG_8Fyas.js";
12
- import "../std__assert-X-_kMxKM.js";
13
- import "../assert_rejects-DiIiJbZn.js";
14
- import "../assert_is_error-BPGph1Jx.js";
15
- import "../assert_not_equals-f3m3epl3.js";
16
- import "../assert_throws-BOO88avQ.js";
17
- import { esm_default } from "../esm-CPZhxxGc.js";
6
+ import { test } from "../dist-lStjlyET.js";
7
+ import { assertEquals } from "../assert_equals-Gbplq4lg.js";
8
+ import "../assert-Dp5_aoAs.js";
9
+ import "../assert_instance_of-D1m8F7x0.js";
10
+ import "../deno-BTeveqhY.js";
11
+ import { lookupWebFinger } from "../lookup-yv_aH7K7.js";
12
+ import "../std__assert-Cm-MfI66.js";
13
+ import "../assert_rejects-BoKYY0g1.js";
14
+ import "../assert_throws-DjkXin1a.js";
15
+ import "../assert_not_equals-B2R_8p36.js";
16
+ import { esm_default } from "../esm-B52TuumP.js";
18
17
  import { withTimeout } from "es-toolkit";
19
18
 
20
19
  //#region src/webfinger/lookup.test.ts
@@ -0,0 +1,8 @@
1
+
2
+ const { Temporal } = require("@js-temporal/polyfill");
3
+ const { URLPattern } = require("urlpattern-polyfill");
4
+
5
+ const require_lookup = require('../lookup-BORWbouU.cjs');
6
+ require('../webfinger-vAtLmxOF.cjs');
7
+
8
+ exports.lookupWebFinger = require_lookup.lookupWebFinger;
@@ -0,0 +1,2 @@
1
+ import { Link, LookupWebFingerOptions, ResourceDescriptor, lookupWebFinger } from "../mod-C58MZ7Wx.cjs";
2
+ export { Link, LookupWebFingerOptions, ResourceDescriptor, lookupWebFinger };
@@ -1,7 +1,4 @@
1
1
  import { Temporal } from "@js-temporal/polyfill";
2
2
  import { URLPattern } from "urlpattern-polyfill";
3
- import "../kv-C7sopW2E.js";
4
- import "../docloader-CxWcuWqQ.js";
5
- import { Link, LookupWebFingerOptions, ResourceDescriptor, lookupWebFinger } from "../lookup-3czM5mmU.js";
6
- import "../mod-GIh5OYxW.js";
3
+ import { Link, LookupWebFingerOptions, ResourceDescriptor, lookupWebFinger } from "../mod-Ds0mpFZU.js";
7
4
  export { Link, LookupWebFingerOptions, ResourceDescriptor, lookupWebFinger };
@@ -1,9 +1,8 @@
1
1
 
2
- import { Temporal } from "@js-temporal/polyfill";
3
- import { URLPattern } from "urlpattern-polyfill";
4
-
5
- import "../docloader-BlVueewg.js";
6
- import { lookupWebFinger } from "../lookup-BHYMosdS.js";
7
- import "../webfinger-C3GIyXIg.js";
2
+ import { Temporal } from "@js-temporal/polyfill";
3
+ import { URLPattern } from "urlpattern-polyfill";
4
+
5
+ import { lookupWebFinger } from "../lookup-BV72lfsA.js";
6
+ import "../webfinger-C72Y8lrh.js";
8
7
 
9
8
  export { lookupWebFinger };
@@ -0,0 +1,4 @@
1
+
2
+ import { Temporal } from "@js-temporal/polyfill";
3
+ import { URLPattern } from "urlpattern-polyfill";
4
+
@@ -0,0 +1,4 @@
1
+
2
+ const { Temporal } = require("@js-temporal/polyfill");
3
+ const { URLPattern } = require("urlpattern-polyfill");
4
+