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

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-Bhc5FasL.cjs +42079 -0
  4. package/dist/{actor-7ivEf1H3.js → actor-C6cDxaJJ.js} +4 -1
  5. package/dist/{actor-DXTdNCfp.js → actor-DPvScYuz.js} +7058 -2722
  6. package/dist/{actor-C22bXuuC.d.ts → actor-DqFajh9s.d.ts} +2 -2
  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-DcDoTCBH.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-DpN-0qNU.js +109 -0
  28. package/dist/{context-DmlbRh9p.d.ts → context-mM0Nu5yo.d.ts} +335 -134
  29. package/dist/deno-DHmnBq8X.js +131 -0
  30. package/dist/{testing-BG_8Fyas.js → dist-lStjlyET.js} +73 -114
  31. package/dist/{authdocloader-D_IvQE4z.js → docloader-C2QNrF7j.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-zsOxPKCt.js → http-B1d-Jhbj.js} +260 -10
  53. package/dist/{http-DqSNLFNY.d.ts → http-BbO0ejuk.d.ts} +2 -2
  54. package/dist/http-CS6iqtXa.cjs +1106 -0
  55. package/dist/http-M8k5mKc0.d.cts +253 -0
  56. package/dist/{http-C7rxW7Kh.js → http-b10BrywC.js} +4 -3
  57. package/dist/{inbox-eK2W2MF3.js → inbox-gPnuScsy.js} +26 -7
  58. package/dist/{key-CYOcZ9G5.js → key-W6YaI4J_.js} +4 -2
  59. package/dist/{keycache-BLq6GT4_.js → keycache-DkTZcjkH.js} +1 -1
  60. package/dist/{keys-BIwlbtMN.js → keys-CfcSjjys.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-C6NrTtII.js +107 -0
  65. package/dist/kv-cache-DhRe6qxQ.js +122 -0
  66. package/dist/kv-cache-a7LD3ze0.cjs +134 -0
  67. package/dist/{ld-DWwLYT4e.js → ld-UYagkye9.js} +7 -4
  68. package/dist/lookup-C-ajaa9S.js +256 -0
  69. package/dist/{lookup-DNQyH8UQ.js → lookup-CjgzNtAk.js} +33 -125
  70. package/dist/lookup-DI7YTXtl.cjs +268 -0
  71. package/dist/{lookup-BHYMosdS.js → lookup-DP8Hm9oD.js} +3 -1
  72. package/dist/middleware-Botvlnr6.js +31 -0
  73. package/dist/{middleware-DakCaqXu.js → middleware-C2V0Hmj1.js} +105 -188
  74. package/dist/middleware-D5o8ITlx.cjs +4237 -0
  75. package/dist/middleware-ESmU0CBL.cjs +15 -0
  76. package/dist/middleware-JqrIzuk6.js +15 -0
  77. package/dist/{middleware-BcVqlHyD.js → middleware-V7PNM-lv.js} +143 -136
  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-DgNCw_Z-.js} +46 -8
  111. package/dist/{owner-CQPnQVtf.d.ts → owner-kQRGVXG1.d.ts} +3 -3
  112. package/dist/{proof-C6z-uqeO.js → proof-BwleRoo3.js} +5 -3
  113. package/dist/proof-M11sS3Oq.cjs +710 -0
  114. package/dist/{proof-CT1SITRP.js → proof-TlLZC_r7.js} +53 -16
  115. package/dist/router-CVRQXlZi.js +118 -0
  116. package/dist/{send-1zdmNlUo.js → send-BMU9B7Sm.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-SOE1ifCr.d.ts → vocab-BCWe1Ih5.d.ts} +292 -21
  154. package/dist/vocab-CeDBzu-f.d.cts +14903 -0
  155. package/dist/{type-I68qwqmo.js → vocab-Durhw0Gx.js} +6947 -7381
  156. package/dist/{vocab-Bg1J3mu4.js → vocab-NOF1dCjQ.js} +32 -18
  157. package/dist/vocab-Vw1RxMp6.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
@@ -1,12 +1,12 @@
1
1
 
2
- import { Temporal } from "@js-temporal/polyfill";
3
- import { URLPattern } from "urlpattern-polyfill";
4
-
5
- import { deno_default, getDocumentLoader } from "./docloader-BlVueewg.js";
6
- import { Object as Object$1, getTypeId } from "./actor-DXTdNCfp.js";
7
- import { lookupWebFinger } from "./lookup-BHYMosdS.js";
2
+ import { Temporal } from "@js-temporal/polyfill";
3
+ import { URLPattern } from "urlpattern-polyfill";
4
+
5
+ import { deno_default, lookupWebFinger } from "./lookup-C-ajaa9S.js";
6
+ import { Object as Object$1, getTypeId } from "./actor-DPvScYuz.js";
8
7
  import { getLogger } from "@logtape/logtape";
9
8
  import { SpanStatusCode, trace } from "@opentelemetry/api";
9
+ import { getDocumentLoader } from "@fedify/vocab-runtime";
10
10
  import { delay } from "es-toolkit";
11
11
 
12
12
  //#region src/vocab/handle.ts
@@ -136,9 +136,14 @@ async function lookupObject(identifier, options = {}) {
136
136
  if (result.id != null) span.setAttribute("activitypub.object.id", result.id.href);
137
137
  span.setAttribute("activitypub.object.type", getTypeId(result).href);
138
138
  if (result.replyTargetIds.length > 0) span.setAttribute("activitypub.object.in_reply_to", result.replyTargetIds.map((id) => id.href));
139
+ span.addEvent("activitypub.object.fetched", {
140
+ "activitypub.object.type": getTypeId(result).href,
141
+ "activitypub.object.json": JSON.stringify(await result.toJsonLd(options))
142
+ });
139
143
  }
140
144
  return result;
141
145
  } catch (error) {
146
+ span.recordException(error);
142
147
  span.setStatus({
143
148
  code: SpanStatusCode.ERROR,
144
149
  message: String(error)
@@ -152,14 +157,13 @@ async function lookupObject(identifier, options = {}) {
152
157
  async function lookupObjectInternal(identifier, options = {}) {
153
158
  const documentLoader = options.documentLoader ?? getDocumentLoader({ userAgent: options.userAgent });
154
159
  if (typeof identifier === "string") identifier = toAcctUrl(identifier) ?? new URL(identifier);
155
- let document = null;
160
+ let remoteDoc = null;
156
161
  if (identifier.protocol === "http:" || identifier.protocol === "https:") try {
157
- const remoteDoc = await documentLoader(identifier.href, { signal: options.signal });
158
- document = remoteDoc.document;
162
+ remoteDoc = await documentLoader(identifier.href, { signal: options.signal });
159
163
  } catch (error) {
160
164
  logger.debug("Failed to fetch remote document:\n{error}", { error });
161
165
  }
162
- if (document == null) {
166
+ if (remoteDoc == null) {
163
167
  const jrd = await lookupWebFinger(identifier, {
164
168
  userAgent: options.userAgent,
165
169
  tracerProvider: options.tracerProvider,
@@ -168,10 +172,9 @@ async function lookupObjectInternal(identifier, options = {}) {
168
172
  });
169
173
  if (jrd?.links == null) return null;
170
174
  for (const l of jrd.links) {
171
- if (l.type !== "application/activity+json" && !l.type?.match(/application\/ld\+json;\s*profile="https:\/\/www.w3.org\/ns\/activitystreams"/) || l.rel !== "self") continue;
175
+ 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;
172
176
  try {
173
- const remoteDoc = await documentLoader(l.href, { signal: options.signal });
174
- document = remoteDoc.document;
177
+ remoteDoc = await documentLoader(l.href, { signal: options.signal });
175
178
  break;
176
179
  } catch (error) {
177
180
  logger.debug("Failed to fetch remote document:\n{error}", { error });
@@ -179,23 +182,34 @@ async function lookupObjectInternal(identifier, options = {}) {
179
182
  }
180
183
  }
181
184
  }
182
- if (document == null) return null;
185
+ if (remoteDoc == null) return null;
186
+ let object;
183
187
  try {
184
- return await Object$1.fromJsonLd(document, {
188
+ object = await Object$1.fromJsonLd(remoteDoc.document, {
185
189
  documentLoader,
186
190
  contextLoader: options.contextLoader,
187
- tracerProvider: options.tracerProvider
191
+ tracerProvider: options.tracerProvider,
192
+ baseUrl: new URL(remoteDoc.documentUrl)
188
193
  });
189
194
  } catch (error) {
190
195
  if (error instanceof TypeError) {
191
196
  logger.debug("Failed to parse JSON-LD document: {error}\n{document}", {
192
- error,
193
- document
197
+ ...remoteDoc,
198
+ error
194
199
  });
195
200
  return null;
196
201
  }
197
202
  throw error;
198
203
  }
204
+ if (options.crossOrigin !== "trust" && object.id != null && object.id.origin !== new URL(remoteDoc.documentUrl).origin) {
205
+ 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".`);
206
+ 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\".", {
207
+ ...remoteDoc,
208
+ objectId: object.id.href
209
+ });
210
+ return null;
211
+ }
212
+ return object;
199
213
  }
200
214
  /**
201
215
  * Traverses a collection, yielding each item in the collection.
@@ -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-DI7YTXtl.cjs');
7
+ const require_actor = require('./actor-Bhc5FasL.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-DHmnBq8X.js";
12
+ import { createFederation, handleWebFinger } from "../middleware-C2V0Hmj1.js";
13
+ import "../client-CD87uCL_.js";
14
+ import "../router-CVRQXlZi.js";
15
+ import "../types-D2jhK2VG.js";
16
+ import { Image, Link, Person } from "../vocab-Durhw0Gx.js";
17
+ import "../lookup-DP8Hm9oD.js";
18
+ import "../type-BSNcIxTd.js";
19
+ import "../actor-C6cDxaJJ.js";
20
+ import "../key-W6YaI4J_.js";
21
+ import "../http-b10BrywC.js";
22
+ import "../ld-UYagkye9.js";
23
+ import "../owner-DgNCw_Z-.js";
24
+ import "../proof-BwleRoo3.js";
25
+ import "../docloader-C2QNrF7j.js";
26
+ import "../kv-cache-C6NrTtII.js";
27
+ import "../lookup-CjgzNtAk.js";
28
+ import "../inbox-gPnuScsy.js";
29
+ import "../builder-DcDoTCBH.js";
30
+ import "../collection-CrkRM5Ep.js";
31
+ import "../keycache-DkTZcjkH.js";
32
+ import "../negotiation-B4NJHk1f.js";
33
+ import "../retry-Bz5pP75o.js";
34
+ import "../send-BMU9B7Sm.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-DpN-0qNU.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-DHmnBq8X.js";
11
+ import { lookupWebFinger } from "../lookup-DP8Hm9oD.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-DI7YTXtl.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-C-ajaa9S.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
+