@fedify/fedify 2.0.0-dev.1908 → 2.0.0-dev.196

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 (266) hide show
  1. package/LICENSE +1 -1
  2. package/README.md +68 -35
  3. package/dist/{builder-GG0LDRaK.js → builder-R1Sfe-tb.js} +5 -3
  4. package/dist/{client-BsGzbnV-.d.ts → client-CUTUGgvJ.d.ts} +18 -18
  5. package/dist/{client-pY7-3icS.js → client-Dg7OfUDA.js} +28 -23
  6. package/dist/{client-94iWEfQa.d.cts → client-by-PEGAJ.d.cts} +18 -18
  7. package/dist/compat/mod.cjs +1 -1
  8. package/dist/compat/mod.d.cts +6 -10
  9. package/dist/compat/mod.d.ts +6 -10
  10. package/dist/compat/mod.js +1 -1
  11. package/dist/compat/transformers.test.js +22 -21
  12. package/dist/context-Bns6uTJq.js +109 -0
  13. package/dist/{context-V-XS2_6O.d.ts → context-C7vzWilY.d.ts} +63 -65
  14. package/dist/{context-PxGADCsD.d.cts → context-CrB9RFy5.d.cts} +63 -65
  15. package/dist/deno-i60L3ZJW.js +117 -0
  16. package/dist/{testing-bgnt5CjE.js → dist-B5f6a8Tt.js} +90 -110
  17. package/dist/{docloader-Buj0Y50A.js → docloader-BuOglEYx.js} +3 -3
  18. package/dist/{esm-vPU_GxaY.js → esm-DGl7uK1r.js} +32 -17
  19. package/dist/federation/builder.test.js +7 -5
  20. package/dist/federation/collection.test.js +2 -3
  21. package/dist/federation/handler.test.js +110 -22
  22. package/dist/federation/idempotency.test.js +23 -22
  23. package/dist/federation/inbox.test.js +4 -3
  24. package/dist/federation/keycache.test.js +4 -4
  25. package/dist/federation/kv.test.js +56 -3
  26. package/dist/federation/middleware.test.js +95 -93
  27. package/dist/federation/mod.cjs +8 -10
  28. package/dist/federation/mod.d.cts +7 -11
  29. package/dist/federation/mod.d.ts +7 -11
  30. package/dist/federation/mod.js +8 -11
  31. package/dist/federation/mq.test.js +5 -6
  32. package/dist/federation/negotiation.test.js +2 -3
  33. package/dist/federation/retry.test.js +2 -3
  34. package/dist/federation/router.test.js +2 -2
  35. package/dist/federation/send.test.js +51 -9
  36. package/dist/{webfinger/handler.test.js → federation/webfinger.test.js} +24 -22
  37. package/dist/{federation-CRpdnOMS.cjs → federation-B431K2gm.cjs} +22 -0
  38. package/dist/{federation-jcR8-ZxP.js → federation-BbZwNNWj.js} +28 -6
  39. package/dist/{http-ByZmUHwe.js → http-B5BgMxiO.js} +119 -9
  40. package/dist/{http-CTi-owaL.cjs → http-B_jtB30-.cjs} +132 -16
  41. package/dist/{http-M8k5mKc0.d.cts → http-ClB3pLcL.d.cts} +1 -1
  42. package/dist/{http-BbO0ejuk.d.ts → http-DLBDPal9.d.ts} +1 -1
  43. package/dist/{http-DO88HCOK.js → http-uzkhnm0W.js} +3 -2
  44. package/dist/{inbox-BwIgnk8R.js → inbox-CxrUTds4.js} +2 -1
  45. package/dist/{key-CrKmngwF.js → key-DBHCloAO.js} +3 -3
  46. package/dist/{keycache-CFv8xdnH.js → keycache-DRxpZ5r9.js} +1 -1
  47. package/dist/{keys-B2yaEG79.js → keys-ZbcByPg9.js} +1 -1
  48. package/dist/{kv-Bxr0Q87_.d.cts → kv-B4vFhIYL.d.cts} +30 -1
  49. package/dist/{kv-BKNZ-Tb-.d.ts → kv-CYySNrsn.d.ts} +30 -1
  50. package/dist/{kv-CRZrzyXm.js → kv-QzKcOQgP.js} +22 -0
  51. package/dist/{kv-cache-DN9pfMBe.js → kv-cache-BEeqyGER.js} +14 -1
  52. package/dist/{kv-cache-CykGg2IP.js → kv-cache-BqWqxam4.js} +2 -2
  53. package/dist/{kv-cache-BbklA4EG.cjs → kv-cache-DY6hQ8Rf.cjs} +2 -2
  54. package/dist/{ld-Ckl2k3lF.js → ld-CZgNIUGN.js} +4 -3
  55. package/dist/{middleware-X0RaVmfv.cjs → middleware-BaoVtoMl.cjs} +210 -194
  56. package/dist/{middleware-Dv90Gwc-.js → middleware-BqPcChYv.js} +164 -154
  57. package/dist/middleware-CnrWiFJI.cjs +12 -0
  58. package/dist/{middleware-CdPISvYD.js → middleware-CxwWsgSo.js} +162 -165
  59. package/dist/middleware-DoFisLae.js +26 -0
  60. package/dist/middleware-ZN9cd_L8.js +12 -0
  61. package/dist/{mod-DMpuiKXi.d.cts → mod-0p9zUdzg.d.cts} +6 -6
  62. package/dist/mod-0qnPv4EC.d.cts +62 -0
  63. package/dist/{mod-DgxG-byT.d.cts → mod-BrS8tiad.d.cts} +2 -2
  64. package/dist/mod-C3SOvTD1.d.ts +64 -0
  65. package/dist/{mod-BoRKfJPE.d.cts → mod-D6pS5_xJ.d.cts} +4 -4
  66. package/dist/{mod-D5Z2tISD.d.ts → mod-jOa7W503.d.ts} +2 -2
  67. package/dist/{mod-Cdo6SYlJ.d.ts → mod-waqu-BL_.d.ts} +4 -4
  68. package/dist/{mod-aAE2wOWV.d.ts → mod-xc20HhMD.d.ts} +6 -6
  69. package/dist/mod.cjs +11 -93
  70. package/dist/mod.d.cts +11 -15
  71. package/dist/mod.d.ts +11 -15
  72. package/dist/mod.js +11 -15
  73. package/dist/nodeinfo/client.test.js +3 -4
  74. package/dist/nodeinfo/handler.test.js +22 -21
  75. package/dist/nodeinfo/mod.cjs +2 -2
  76. package/dist/nodeinfo/mod.d.cts +2 -2
  77. package/dist/nodeinfo/mod.d.ts +2 -2
  78. package/dist/nodeinfo/mod.js +2 -2
  79. package/dist/nodeinfo/types.test.js +2 -3
  80. package/dist/otel/exporter.test.js +893 -0
  81. package/dist/otel/mod.cjs +256 -0
  82. package/dist/otel/mod.d.cts +230 -0
  83. package/dist/otel/mod.d.ts +232 -0
  84. package/dist/otel/mod.js +255 -0
  85. package/dist/{owner-C8UEs7je.js → owner-BDvRiO5T.js} +44 -8
  86. package/dist/{owner-kQRGVXG1.d.ts → owner-BgI8C-VY.d.ts} +1 -2
  87. package/dist/{owner-B4HbyP8s.d.cts → owner-C-zfmVAD.d.cts} +1 -2
  88. package/dist/{proof-CDW6KgLA.js → proof-DzFse-Bn.js} +46 -11
  89. package/dist/{proof-CWKgvgzL.js → proof-XEPY5YKg.js} +3 -2
  90. package/dist/{proof-yc6sVqKg.cjs → proof-vmNsq1AQ.cjs} +63 -28
  91. package/dist/router-D9eI0s4b.js +118 -0
  92. package/dist/{send-z5jueBCW.js → send-BdhhZ2MN.js} +9 -4
  93. package/dist/sig/http.test.js +6 -7
  94. package/dist/sig/key.test.js +5 -5
  95. package/dist/sig/ld.test.js +6 -6
  96. package/dist/sig/mod.cjs +3 -5
  97. package/dist/sig/mod.d.cts +3 -5
  98. package/dist/sig/mod.d.ts +3 -5
  99. package/dist/sig/mod.js +3 -5
  100. package/dist/sig/owner.test.js +29 -6
  101. package/dist/sig/proof.test.js +6 -6
  102. package/dist/testing/mod.d.ts +70 -6999
  103. package/dist/testing/mod.js +4 -3
  104. package/dist/{transformers-CoBS-oFG.cjs → transformers-BjBg6Lag.cjs} +2 -2
  105. package/dist/{transformers-BFT6d7J5.js → transformers-N_ip_y4P.js} +2 -2
  106. package/dist/{types-BtUjyi5y.js → types-8l28uC8o.js} +30 -25
  107. package/dist/{types-CWgzGaqk.cjs → types-B6z6CqIz.cjs} +30 -25
  108. package/dist/{types-C2XVl6gj.js → types-CPz01LGH.js} +3 -3
  109. package/dist/utils/docloader.test.js +7 -8
  110. package/dist/utils/kv-cache.test.js +5 -3
  111. package/dist/utils/mod.cjs +3 -5
  112. package/dist/utils/mod.d.cts +3 -4
  113. package/dist/utils/mod.d.ts +3 -4
  114. package/dist/utils/mod.js +3 -5
  115. package/package.json +25 -36
  116. package/dist/actor-C6x8UgbE.cjs +0 -42079
  117. package/dist/actor-C76CDThG.js +0 -41647
  118. package/dist/actor-DqFajh9s.d.ts +0 -130
  119. package/dist/actor-DrFLTQdj.js +0 -146
  120. package/dist/actor-f2NtjyCg.d.cts +0 -128
  121. package/dist/fixtures/activitypub.academy/users/brauca_darradiul.json +0 -83
  122. package/dist/fixtures/example.com/announce.json +0 -6
  123. package/dist/fixtures/example.com/collection.json +0 -19
  124. package/dist/fixtures/example.com/create.json +0 -6
  125. package/dist/fixtures/example.com/cross-origin-actor.json +0 -6
  126. package/dist/fixtures/example.com/hong-gildong.json +0 -11
  127. package/dist/fixtures/example.com/invite.json +0 -7
  128. package/dist/fixtures/example.com/key.json +0 -7
  129. package/dist/fixtures/example.com/key2.json +0 -6
  130. package/dist/fixtures/example.com/object.json +0 -6
  131. package/dist/fixtures/example.com/orderedcollectionpage.json +0 -24
  132. package/dist/fixtures/example.com/paged/a.json +0 -13
  133. package/dist/fixtures/example.com/paged/b.json +0 -16
  134. package/dist/fixtures/example.com/paged-collection.json +0 -6
  135. package/dist/fixtures/example.com/person.json +0 -22
  136. package/dist/fixtures/example.com/person2.json +0 -40
  137. package/dist/fixtures/example.com/test.json +0 -5
  138. package/dist/fixtures/example.com/users/handle.json +0 -16
  139. package/dist/fixtures/example.com/wrong-type.json +0 -3
  140. package/dist/fixtures/media.example.com/avatars/test-avatar.jpg.json +0 -6
  141. package/dist/fixtures/oeee.cafe/ap/users/3609fd4e-d51d-4db8-9f04-4189815864dd.json +0 -24
  142. package/dist/fixtures/remote.domain/users/bob.json +0 -20
  143. package/dist/fixtures/server.example/users/alice.json +0 -20
  144. package/dist/fixtures/w3id.org/identity/v1.json +0 -152
  145. package/dist/fixtures/w3id.org/security/data-integrity/v1.json +0 -74
  146. package/dist/fixtures/w3id.org/security/multikey/v1.json +0 -35
  147. package/dist/fixtures/w3id.org/security/v1.json +0 -50
  148. package/dist/fixtures/wizard.casa/users/hongminhee.json +0 -69
  149. package/dist/fixtures/www.w3.org/ns/activitystreams.json +0 -379
  150. package/dist/fixtures/www.w3.org/ns/did/v1.json +0 -58
  151. package/dist/lookup-D17ydBQd.cjs +0 -265
  152. package/dist/lookup-DrCNfWHm.js +0 -253
  153. package/dist/lookup-yP6Lo5JV.js +0 -42178
  154. package/dist/middleware-BSCsvvh-.js +0 -26
  155. package/dist/middleware-GFpHLL1X.cjs +0 -15
  156. package/dist/middleware-pl3iXZpj.js +0 -15
  157. package/dist/mod-BlVovdcy.d.ts +0 -309
  158. package/dist/mod-BxRCHTz-.d.cts +0 -307
  159. package/dist/mod-C58MZ7Wx.d.cts +0 -113
  160. package/dist/mod-CcDPcLJW.d.cts +0 -1
  161. package/dist/mod-Ds0mpFZU.d.ts +0 -115
  162. package/dist/mod-bjzj5QIb.d.ts +0 -2
  163. package/dist/src/vocab/accept.yaml +0 -15
  164. package/dist/src/vocab/activity.yaml +0 -98
  165. package/dist/src/vocab/add.yaml +0 -16
  166. package/dist/src/vocab/announce.yaml +0 -30
  167. package/dist/src/vocab/application.yaml +0 -324
  168. package/dist/src/vocab/arrive.yaml +0 -15
  169. package/dist/src/vocab/article.yaml +0 -46
  170. package/dist/src/vocab/audio.yaml +0 -11
  171. package/dist/src/vocab/block.yaml +0 -16
  172. package/dist/src/vocab/chatmessage.yaml +0 -50
  173. package/dist/src/vocab/collection.yaml +0 -154
  174. package/dist/src/vocab/collectionpage.yaml +0 -55
  175. package/dist/src/vocab/create.yaml +0 -28
  176. package/dist/src/vocab/dataintegrityproof.yaml +0 -56
  177. package/dist/src/vocab/delete.yaml +0 -27
  178. package/dist/src/vocab/didservice.yaml +0 -22
  179. package/dist/src/vocab/dislike.yaml +0 -14
  180. package/dist/src/vocab/document.yaml +0 -31
  181. package/dist/src/vocab/emoji.yaml +0 -12
  182. package/dist/src/vocab/emojireact.yaml +0 -17
  183. package/dist/src/vocab/endpoints.yaml +0 -85
  184. package/dist/src/vocab/event.yaml +0 -11
  185. package/dist/src/vocab/export.yaml +0 -9
  186. package/dist/src/vocab/flag.yaml +0 -15
  187. package/dist/src/vocab/follow.yaml +0 -19
  188. package/dist/src/vocab/group.yaml +0 -324
  189. package/dist/src/vocab/hashtag.yaml +0 -14
  190. package/dist/src/vocab/ignore.yaml +0 -14
  191. package/dist/src/vocab/image.yaml +0 -9
  192. package/dist/src/vocab/intransitiveactivity.yaml +0 -15
  193. package/dist/src/vocab/invite.yaml +0 -14
  194. package/dist/src/vocab/join.yaml +0 -14
  195. package/dist/src/vocab/key.yaml +0 -28
  196. package/dist/src/vocab/leave.yaml +0 -14
  197. package/dist/src/vocab/like.yaml +0 -16
  198. package/dist/src/vocab/link.yaml +0 -101
  199. package/dist/src/vocab/listen.yaml +0 -12
  200. package/dist/src/vocab/mention.yaml +0 -9
  201. package/dist/src/vocab/move.yaml +0 -15
  202. package/dist/src/vocab/multikey.yaml +0 -36
  203. package/dist/src/vocab/note.yaml +0 -48
  204. package/dist/src/vocab/object.yaml +0 -404
  205. package/dist/src/vocab/offer.yaml +0 -15
  206. package/dist/src/vocab/orderedcollection.yaml +0 -39
  207. package/dist/src/vocab/orderedcollectionpage.yaml +0 -50
  208. package/dist/src/vocab/organization.yaml +0 -324
  209. package/dist/src/vocab/page.yaml +0 -11
  210. package/dist/src/vocab/person.yaml +0 -324
  211. package/dist/src/vocab/place.yaml +0 -75
  212. package/dist/src/vocab/profile.yaml +0 -26
  213. package/dist/src/vocab/propertyvalue.yaml +0 -32
  214. package/dist/src/vocab/question.yaml +0 -103
  215. package/dist/src/vocab/read.yaml +0 -13
  216. package/dist/src/vocab/reject.yaml +0 -14
  217. package/dist/src/vocab/relationship.yaml +0 -52
  218. package/dist/src/vocab/remove.yaml +0 -14
  219. package/dist/src/vocab/service.yaml +0 -324
  220. package/dist/src/vocab/source.yaml +0 -26
  221. package/dist/src/vocab/tentativeaccept.yaml +0 -14
  222. package/dist/src/vocab/tentativereject.yaml +0 -14
  223. package/dist/src/vocab/tombstone.yaml +0 -24
  224. package/dist/src/vocab/travel.yaml +0 -16
  225. package/dist/src/vocab/undo.yaml +0 -26
  226. package/dist/src/vocab/update.yaml +0 -58
  227. package/dist/src/vocab/video.yaml +0 -11
  228. package/dist/src/vocab/view.yaml +0 -13
  229. package/dist/testing/docloader.test.js +0 -22
  230. package/dist/vocab/actor.test.js +0 -5963
  231. package/dist/vocab/lookup.test.d.ts +0 -3
  232. package/dist/vocab/lookup.test.js +0 -454
  233. package/dist/vocab/mod.cjs +0 -86
  234. package/dist/vocab/mod.d.cts +0 -4
  235. package/dist/vocab/mod.d.ts +0 -6
  236. package/dist/vocab/mod.js +0 -9
  237. package/dist/vocab/type.test.d.ts +0 -3
  238. package/dist/vocab/type.test.js +0 -24
  239. package/dist/vocab/vocab.test.d.ts +0 -3
  240. package/dist/vocab/vocab.test.js +0 -9397
  241. package/dist/vocab-B4wXNBv8.js +0 -255
  242. package/dist/vocab-BCWe1Ih5.d.ts +0 -14905
  243. package/dist/vocab-CeDBzu-f.d.cts +0 -14903
  244. package/dist/vocab-Hqae4yux.cjs +0 -291
  245. package/dist/webfinger/handler.test.d.ts +0 -3
  246. package/dist/webfinger/lookup.test.d.ts +0 -3
  247. package/dist/webfinger/lookup.test.js +0 -193
  248. package/dist/webfinger/mod.cjs +0 -8
  249. package/dist/webfinger/mod.d.cts +0 -2
  250. package/dist/webfinger/mod.d.ts +0 -4
  251. package/dist/webfinger/mod.js +0 -8
  252. package/dist/webfinger-C72Y8lrh.js +0 -4
  253. package/dist/webfinger-vAtLmxOF.cjs +0 -4
  254. /package/dist/{collection-BzWsN9pB.js → collection-CcnIw1qY.js} +0 -0
  255. /package/dist/{testing/docloader.test.d.ts → federation/webfinger.test.d.ts} +0 -0
  256. /package/dist/{mod-CVgZgliM.d.ts → mod-1E3W847c.d.ts} +0 -0
  257. /package/dist/{mod-B-hUPT2N.d.cts → mod-C81L6_lQ.d.cts} +0 -0
  258. /package/dist/{negotiation-C4nFufNk.js → negotiation-5NPJL6zp.js} +0 -0
  259. /package/dist/{nodeinfo-BnthBobC.js → nodeinfo-BlLsRSiT.js} +0 -0
  260. /package/dist/{nodeinfo-CdN0rEnZ.cjs → nodeinfo-DuMYTpbZ.cjs} +0 -0
  261. /package/dist/{vocab/actor.test.d.ts → otel/exporter.test.d.ts} +0 -0
  262. /package/dist/{retry-CfF8Gn4d.js → retry-D4GJ670a.js} +0 -0
  263. /package/dist/{sig-C34-oHBl.js → sig-CwuONEzF.js} +0 -0
  264. /package/dist/{sig-YYj5tCnr.cjs → sig-DeXX2xnj.cjs} +0 -0
  265. /package/dist/{utils-DyRU1gdZ.cjs → utils-Db0ZmjcD.cjs} +0 -0
  266. /package/dist/{utils-D-Va7aXC.js → utils-Wranxuoe.js} +0 -0
@@ -1,291 +0,0 @@
1
-
2
- const { Temporal } = require("@js-temporal/polyfill");
3
- const { URLPattern } = require("urlpattern-polyfill");
4
-
5
- const require_chunk = require('./chunk-DqRYRqnO.cjs');
6
- const require_lookup = require('./lookup-D17ydBQd.cjs');
7
- const require_actor = require('./actor-C6x8UgbE.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
- }
141
- return result;
142
- } catch (error) {
143
- span.setStatus({
144
- code: __opentelemetry_api.SpanStatusCode.ERROR,
145
- message: String(error)
146
- });
147
- throw error;
148
- } finally {
149
- span.end();
150
- }
151
- });
152
- }
153
- async function lookupObjectInternal(identifier, options = {}) {
154
- const documentLoader = options.documentLoader ?? (0, __fedify_vocab_runtime.getDocumentLoader)({ userAgent: options.userAgent });
155
- if (typeof identifier === "string") identifier = toAcctUrl(identifier) ?? new URL(identifier);
156
- let remoteDoc = null;
157
- if (identifier.protocol === "http:" || identifier.protocol === "https:") try {
158
- remoteDoc = await documentLoader(identifier.href, { signal: options.signal });
159
- } catch (error) {
160
- logger.debug("Failed to fetch remote document:\n{error}", { error });
161
- }
162
- if (remoteDoc == null) {
163
- const jrd = await require_lookup.lookupWebFinger(identifier, {
164
- userAgent: options.userAgent,
165
- tracerProvider: options.tracerProvider,
166
- allowPrivateAddress: "allowPrivateAddress" in options && options.allowPrivateAddress === true,
167
- signal: options.signal
168
- });
169
- if (jrd?.links == null) return null;
170
- 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" || l.href == null) continue;
172
- try {
173
- remoteDoc = await documentLoader(l.href, { signal: options.signal });
174
- break;
175
- } catch (error) {
176
- logger.debug("Failed to fetch remote document:\n{error}", { error });
177
- continue;
178
- }
179
- }
180
- }
181
- if (remoteDoc == null) return null;
182
- let object;
183
- try {
184
- object = await require_actor.Object.fromJsonLd(remoteDoc.document, {
185
- documentLoader,
186
- contextLoader: options.contextLoader,
187
- tracerProvider: options.tracerProvider,
188
- baseUrl: new URL(remoteDoc.documentUrl)
189
- });
190
- } catch (error) {
191
- if (error instanceof TypeError) {
192
- logger.debug("Failed to parse JSON-LD document: {error}\n{document}", {
193
- ...remoteDoc,
194
- error
195
- });
196
- return null;
197
- }
198
- throw error;
199
- }
200
- if (options.crossOrigin !== "trust" && object.id != null && object.id.origin !== new URL(remoteDoc.documentUrl).origin) {
201
- 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".`);
202
- 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\".", {
203
- ...remoteDoc,
204
- objectId: object.id.href
205
- });
206
- return null;
207
- }
208
- return object;
209
- }
210
- /**
211
- * Traverses a collection, yielding each item in the collection.
212
- * If the collection is paginated, it will fetch the next page
213
- * automatically.
214
- *
215
- * @example
216
- * ``` typescript
217
- * const collection = await lookupObject(collectionUrl);
218
- * if (collection instanceof Collection) {
219
- * for await (const item of traverseCollection(collection)) {
220
- * console.log(item.id?.href);
221
- * }
222
- * }
223
- * ```
224
- *
225
- * @param collection The collection to traverse.
226
- * @param options Options for traversing the collection.
227
- * @returns An async iterable of each item in the collection.
228
- * @since 1.1.0
229
- */
230
- async function* traverseCollection(collection, options = {}) {
231
- if (collection.firstId == null) for await (const item of collection.getItems(options)) yield item;
232
- else {
233
- const interval = Temporal.Duration.from(options.interval ?? { seconds: 0 }).total("millisecond");
234
- let page = await collection.getFirst(options);
235
- while (page != null) {
236
- for await (const item of page.getItems(options)) yield item;
237
- if (interval > 0) await (0, es_toolkit.delay)(interval);
238
- page = await page.getNext(options);
239
- }
240
- }
241
- }
242
-
243
- //#endregion
244
- //#region src/vocab/constants.ts
245
- /**
246
- * The special public collection for [public addressing]. *Do not mutate this
247
- * object.*
248
- *
249
- * [public addressing]: https://www.w3.org/TR/activitypub/#public-addressing
250
- *
251
- * @since 0.7.0
252
- */
253
- const PUBLIC_COLLECTION = new URL("https://www.w3.org/ns/activitystreams#Public");
254
-
255
- //#endregion
256
- Object.defineProperty(exports, 'PUBLIC_COLLECTION', {
257
- enumerable: true,
258
- get: function () {
259
- return PUBLIC_COLLECTION;
260
- }
261
- });
262
- Object.defineProperty(exports, 'isFediverseHandle', {
263
- enumerable: true,
264
- get: function () {
265
- return isFediverseHandle;
266
- }
267
- });
268
- Object.defineProperty(exports, 'lookupObject', {
269
- enumerable: true,
270
- get: function () {
271
- return lookupObject;
272
- }
273
- });
274
- Object.defineProperty(exports, 'parseFediverseHandle', {
275
- enumerable: true,
276
- get: function () {
277
- return parseFediverseHandle;
278
- }
279
- });
280
- Object.defineProperty(exports, 'toAcctUrl', {
281
- enumerable: true,
282
- get: function () {
283
- return toAcctUrl;
284
- }
285
- });
286
- Object.defineProperty(exports, 'traverseCollection', {
287
- enumerable: true,
288
- get: function () {
289
- return traverseCollection;
290
- }
291
- });
@@ -1,3 +0,0 @@
1
- import { Temporal } from "@js-temporal/polyfill";
2
- import { URLPattern } from "urlpattern-polyfill";
3
- globalThis.addEventListener = () => {};
@@ -1,3 +0,0 @@
1
- import { Temporal } from "@js-temporal/polyfill";
2
- import { URLPattern } from "urlpattern-polyfill";
3
- globalThis.addEventListener = () => {};
@@ -1,193 +0,0 @@
1
-
2
- import { Temporal } from "@js-temporal/polyfill";
3
- import { URLPattern } from "urlpattern-polyfill";
4
- globalThis.addEventListener = () => {};
5
-
6
- import { lookupWebFinger } from "../lookup-yP6Lo5JV.js";
7
- import { assertEquals } from "../assert_equals-DSbWqCm3.js";
8
- import "../assert-MZs1qjMx.js";
9
- import "../assert_instance_of-DHz7EHNU.js";
10
- import { test } from "../testing-bgnt5CjE.js";
11
- import "../std__assert-DWivtrGR.js";
12
- import "../assert_rejects-Ce45JcFg.js";
13
- import "../assert_throws-BNXdRGWP.js";
14
- import "../assert_not_equals-C80BG-_5.js";
15
- import { esm_default } from "../esm-vPU_GxaY.js";
16
- import { withTimeout } from "es-toolkit";
17
-
18
- //#region src/webfinger/lookup.test.ts
19
- test({
20
- name: "lookupWebFinger()",
21
- sanitizeOps: false,
22
- sanitizeResources: false,
23
- async fn(t) {
24
- await t.step("invalid resource", async () => {
25
- assertEquals(await lookupWebFinger("acct:johndoe"), null);
26
- assertEquals(await lookupWebFinger(new URL("acct:johndoe")), null);
27
- assertEquals(await lookupWebFinger("acct:johndoe@"), null);
28
- assertEquals(await lookupWebFinger(new URL("acct:johndoe@")), null);
29
- });
30
- await t.step("connection refused", async () => {
31
- assertEquals(await lookupWebFinger("acct:johndoe@fedify-test.internal"), null);
32
- assertEquals(await lookupWebFinger("https://fedify-test.internal/foo"), null);
33
- });
34
- esm_default.spyGlobal();
35
- esm_default.get("begin:https://example.com/.well-known/webfinger?", { status: 404 });
36
- await t.step("not found", async () => {
37
- assertEquals(await lookupWebFinger("acct:johndoe@example.com"), null);
38
- assertEquals(await lookupWebFinger("https://example.com/foo"), null);
39
- });
40
- const expected = {
41
- subject: "acct:johndoe@example.com",
42
- links: []
43
- };
44
- esm_default.removeRoutes();
45
- esm_default.get("https://example.com/.well-known/webfinger?resource=acct%3Ajohndoe%40example.com", { body: expected });
46
- await t.step("acct", async () => {
47
- assertEquals(await lookupWebFinger("acct:johndoe@example.com"), expected);
48
- });
49
- const expected2 = {
50
- subject: "https://example.com/foo",
51
- links: []
52
- };
53
- esm_default.removeRoutes();
54
- esm_default.get("https://example.com/.well-known/webfinger?resource=https%3A%2F%2Fexample.com%2Ffoo", { body: expected2 });
55
- await t.step("https", async () => {
56
- assertEquals(await lookupWebFinger("https://example.com/foo"), expected2);
57
- });
58
- esm_default.removeRoutes();
59
- esm_default.get("begin:https://example.com/.well-known/webfinger?", { body: "not json" });
60
- await t.step("invalid response", async () => {
61
- assertEquals(await lookupWebFinger("acct:johndoe@example.com"), null);
62
- });
63
- esm_default.removeRoutes();
64
- esm_default.get("begin:https://localhost/.well-known/webfinger?", {
65
- subject: "acct:test@localhost",
66
- links: [{
67
- rel: "self",
68
- type: "application/activity+json",
69
- href: "https://localhost/actor"
70
- }]
71
- });
72
- await t.step("private address", async () => {
73
- assertEquals(await lookupWebFinger("acct:test@localhost"), null);
74
- assertEquals(await lookupWebFinger("acct:test@localhost", { allowPrivateAddress: true }), {
75
- subject: "acct:test@localhost",
76
- links: [{
77
- rel: "self",
78
- type: "application/activity+json",
79
- href: "https://localhost/actor"
80
- }]
81
- });
82
- });
83
- esm_default.removeRoutes();
84
- esm_default.get("begin:https://example.com/.well-known/webfinger?", {
85
- status: 302,
86
- headers: { Location: "/.well-known/webfinger2" }
87
- });
88
- esm_default.get("begin:https://example.com/.well-known/webfinger2", { body: expected });
89
- await t.step("redirection", async () => {
90
- assertEquals(await lookupWebFinger("acct:johndoe@example.com"), expected);
91
- });
92
- esm_default.removeRoutes();
93
- esm_default.get("begin:https://example.com/.well-known/webfinger?", {
94
- status: 302,
95
- headers: { Location: "/.well-known/webfinger" }
96
- });
97
- await t.step("infinite redirection", async () => {
98
- const result = await withTimeout(() => lookupWebFinger("acct:johndoe@example.com"), 2e3);
99
- assertEquals(result, null);
100
- });
101
- esm_default.removeRoutes();
102
- esm_default.get("begin:https://example.com/.well-known/webfinger?", {
103
- status: 302,
104
- headers: { Location: "ftp://example.com/" }
105
- });
106
- await t.step("redirection to different protocol", async () => {
107
- assertEquals(await lookupWebFinger("acct:johndoe@example.com"), null);
108
- });
109
- esm_default.removeRoutes();
110
- esm_default.get("begin:https://example.com/.well-known/webfinger?", {
111
- status: 302,
112
- headers: { Location: "https://localhost/" }
113
- });
114
- await t.step("redirection to private address", async () => {
115
- assertEquals(await lookupWebFinger("acct:johndoe@example.com"), null);
116
- });
117
- esm_default.removeRoutes();
118
- let redirectCount = 0;
119
- esm_default.get("begin:https://example.com/.well-known/webfinger", () => {
120
- redirectCount++;
121
- if (redirectCount < 3) return {
122
- status: 302,
123
- headers: { Location: `/.well-known/webfinger?redirect=${redirectCount}` }
124
- };
125
- return { body: expected };
126
- });
127
- await t.step("custom maxRedirection", async () => {
128
- redirectCount = 0;
129
- assertEquals(await lookupWebFinger("acct:johndoe@example.com", { maxRedirection: 2 }), null);
130
- redirectCount = 0;
131
- assertEquals(await lookupWebFinger("acct:johndoe@example.com", { maxRedirection: 3 }), expected);
132
- redirectCount = 0;
133
- assertEquals(await lookupWebFinger("acct:johndoe@example.com"), expected);
134
- });
135
- esm_default.removeRoutes();
136
- esm_default.get("begin:https://example.com/.well-known/webfinger?", () => new Promise((resolve) => {
137
- const timeoutId = setTimeout(() => {
138
- resolve({ body: expected });
139
- }, 1e3);
140
- return () => clearTimeout(timeoutId);
141
- }));
142
- await t.step("request cancellation", async () => {
143
- const controller = new AbortController();
144
- const promise = lookupWebFinger("acct:johndoe@example.com", { signal: controller.signal });
145
- controller.abort();
146
- assertEquals(await promise, null);
147
- });
148
- esm_default.removeRoutes();
149
- let redirectCount2 = 0;
150
- esm_default.get("begin:https://example.com/.well-known/webfinger", () => {
151
- redirectCount2++;
152
- if (redirectCount2 === 1) return {
153
- status: 302,
154
- headers: { Location: "/.well-known/webfinger2" }
155
- };
156
- return new Promise((resolve) => {
157
- const timeoutId = setTimeout(() => {
158
- resolve({ body: expected });
159
- }, 1e3);
160
- return () => clearTimeout(timeoutId);
161
- });
162
- });
163
- await t.step("cancellation during redirection", async () => {
164
- const controller = new AbortController();
165
- const promise = lookupWebFinger("acct:johndoe@example.com", { signal: controller.signal });
166
- setTimeout(() => controller.abort(), 100);
167
- assertEquals(await promise, null);
168
- });
169
- esm_default.removeRoutes();
170
- esm_default.get("begin:https://example.com/.well-known/webfinger?", () => new Promise((resolve) => {
171
- const timeoutId = setTimeout(() => {
172
- resolve({ body: expected });
173
- }, 500);
174
- return () => clearTimeout(timeoutId);
175
- }));
176
- await t.step("cancellation with immediate abort", async () => {
177
- const controller = new AbortController();
178
- controller.abort();
179
- const result = await lookupWebFinger("acct:johndoe@example.com", { signal: controller.signal });
180
- assertEquals(result, null);
181
- });
182
- esm_default.removeRoutes();
183
- esm_default.get("begin:https://example.com/.well-known/webfinger?", { body: expected });
184
- await t.step("successful request with signal", async () => {
185
- const controller = new AbortController();
186
- const result = await lookupWebFinger("acct:johndoe@example.com", { signal: controller.signal });
187
- assertEquals(result, expected);
188
- });
189
- esm_default.hardReset();
190
- }
191
- });
192
-
193
- //#endregion
@@ -1,8 +0,0 @@
1
-
2
- const { Temporal } = require("@js-temporal/polyfill");
3
- const { URLPattern } = require("urlpattern-polyfill");
4
-
5
- const require_lookup = require('../lookup-D17ydBQd.cjs');
6
- require('../webfinger-vAtLmxOF.cjs');
7
-
8
- exports.lookupWebFinger = require_lookup.lookupWebFinger;
@@ -1,2 +0,0 @@
1
- import { Link, LookupWebFingerOptions, ResourceDescriptor, lookupWebFinger } from "../mod-C58MZ7Wx.cjs";
2
- export { Link, LookupWebFingerOptions, ResourceDescriptor, lookupWebFinger };
@@ -1,4 +0,0 @@
1
- import { Temporal } from "@js-temporal/polyfill";
2
- import { URLPattern } from "urlpattern-polyfill";
3
- import { Link, LookupWebFingerOptions, ResourceDescriptor, lookupWebFinger } from "../mod-Ds0mpFZU.js";
4
- export { Link, LookupWebFingerOptions, ResourceDescriptor, lookupWebFinger };
@@ -1,8 +0,0 @@
1
-
2
- import { Temporal } from "@js-temporal/polyfill";
3
- import { URLPattern } from "urlpattern-polyfill";
4
-
5
- import { lookupWebFinger } from "../lookup-DrCNfWHm.js";
6
- import "../webfinger-C72Y8lrh.js";
7
-
8
- export { lookupWebFinger };
@@ -1,4 +0,0 @@
1
-
2
- import { Temporal } from "@js-temporal/polyfill";
3
- import { URLPattern } from "urlpattern-polyfill";
4
-
@@ -1,4 +0,0 @@
1
-
2
- const { Temporal } = require("@js-temporal/polyfill");
3
- const { URLPattern } = require("urlpattern-polyfill");
4
-
File without changes
File without changes
File without changes
File without changes
File without changes
File without changes
File without changes