@fedify/fedify 2.0.0-pr.490.2 → 2.0.0-pr.559.4

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 (267) hide show
  1. package/LICENSE +1 -1
  2. package/README.md +64 -37
  3. package/dist/{builder-4syLV1-z.js → builder-DTlQwmVF.js} +10 -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-PxGADCsD.d.cts → context-B6X-7loD.d.cts} +206 -74
  13. package/dist/{context-V-XS2_6O.d.ts → context-CJaICYPw.d.ts} +206 -74
  14. package/dist/context-CZ5llAss.js +109 -0
  15. package/dist/deno-DGx1JZHr.js +124 -0
  16. package/dist/{testing-BslrM_9E.js → dist-B5f6a8Tt.js} +90 -110
  17. package/dist/{docloader-DndkGj0O.js → docloader-D8UHsyqD.js} +3 -3
  18. package/dist/{esm-VlKMJQqV.js → esm-DGl7uK1r.js} +1 -1
  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 +24 -23
  22. package/dist/federation/idempotency.test.js +59 -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 +307 -93
  27. package/dist/federation/mod.cjs +9 -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 +167 -16
  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 +93 -11
  36. package/dist/{webfinger/handler.test.js → federation/webfinger.test.js} +24 -22
  37. package/dist/{federation-CRpdnOMS.cjs → federation-CE0CJ_0G.cjs} +116 -10
  38. package/dist/{federation-jcR8-ZxP.js → federation-D6FVaeAR.js} +122 -16
  39. package/dist/{http-YhR_TMMQ.js → http-CL3G0rnf.js} +126 -9
  40. package/dist/{http-M8k5mKc0.d.cts → http-ClB3pLcL.d.cts} +1 -1
  41. package/dist/{http-Dxpqz4hE.cjs → http-DKBUv5zZ.cjs} +139 -16
  42. package/dist/{http-BbO0ejuk.d.ts → http-DLBDPal9.d.ts} +1 -1
  43. package/dist/{http-DH47B-h3.js → http-LGtYlSfN.js} +3 -2
  44. package/dist/{inbox-CEyHvxOo.js → inbox-DbtWQY2D.js} +2 -1
  45. package/dist/{key-x7E5PYI0.js → key-BCtt1Ugy.js} +3 -3
  46. package/dist/{keycache-BRXuBDuy.js → keycache-DRxpZ5r9.js} +1 -1
  47. package/dist/{keys-DLk_8H-l.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-HFnFIjSD.js → kv-cache-0786BfqY.js} +3 -3
  52. package/dist/{kv-cache-DN9pfMBe.js → kv-cache-B__dHl7g.js} +15 -2
  53. package/dist/{kv-cache-BMpfJFTx.cjs → kv-cache-DCJojeTn.cjs} +3 -3
  54. package/dist/{ld-CRPaU6c8.js → ld-QlZPwGEH.js} +4 -3
  55. package/dist/middleware-B3jUPnDa.js +12 -0
  56. package/dist/middleware-BFiwWMA2.cjs +12 -0
  57. package/dist/middleware-DMx6DyIw.js +26 -0
  58. package/dist/{middleware-DfLpMu7C.js → middleware-Dm58nObp.js} +280 -166
  59. package/dist/{middleware-BIqFwRwI.js → middleware-WokE4qxc.js} +245 -178
  60. package/dist/{middleware-Ck7O6mb0.cjs → middleware-hWyKOO_6.cjs} +332 -206
  61. package/dist/{mod-DMpuiKXi.d.cts → mod-BHXq4Q3x.d.cts} +7 -7
  62. package/dist/{mod-DgxG-byT.d.cts → mod-BrS8tiad.d.cts} +2 -2
  63. package/dist/mod-CoMP50Rf.d.ts +64 -0
  64. package/dist/{mod-BoRKfJPE.d.cts → mod-DScazwCW.d.cts} +4 -4
  65. package/dist/mod-DTzN6Pv3.d.cts +62 -0
  66. package/dist/{mod-aAE2wOWV.d.ts → mod-DZmuPaKv.d.ts} +7 -7
  67. package/dist/{mod-D5Z2tISD.d.ts → mod-jOa7W503.d.ts} +2 -2
  68. package/dist/{mod-Cdo6SYlJ.d.ts → mod-xKJ57rwu.d.ts} +4 -4
  69. package/dist/mod.cjs +12 -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-kQRGVXG1.d.ts → owner-BgI8C-VY.d.ts} +1 -2
  86. package/dist/{owner-B4HbyP8s.d.cts → owner-C-zfmVAD.d.cts} +1 -2
  87. package/dist/{owner-CIWnopkT.js → owner-Cejm-F7S.js} +2 -2
  88. package/dist/{proof-D-5ri6rf.js → proof-BOQBHd-i.js} +3 -2
  89. package/dist/{proof-fEwcA7LA.cjs → proof-Bmi8ZIcW.cjs} +24 -25
  90. package/dist/{proof-C8-2l0zH.js → proof-CnaEQ_Ev.js} +4 -5
  91. package/dist/router-D9eI0s4b.js +118 -0
  92. package/dist/{send-CPGk9QKZ.js → send-jFxXfsN8.js} +38 -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 +6 -7
  101. package/dist/sig/proof.test.js +6 -6
  102. package/dist/testing/mod.d.ts +173 -7006
  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/dist/vocab/mod.cjs +8 -81
  116. package/dist/vocab/mod.d.cts +1 -4
  117. package/dist/vocab/mod.d.ts +1 -4
  118. package/dist/vocab/mod.js +1 -5
  119. package/package.json +27 -27
  120. package/dist/actor-BT-e5fn9.js +0 -146
  121. package/dist/actor-B_gRMloq.js +0 -41647
  122. package/dist/actor-CBfPjuWj.cjs +0 -42079
  123. package/dist/actor-DqFajh9s.d.ts +0 -130
  124. package/dist/actor-f2NtjyCg.d.cts +0 -128
  125. package/dist/fixtures/activitypub.academy/users/brauca_darradiul.json +0 -83
  126. package/dist/fixtures/example.com/announce.json +0 -6
  127. package/dist/fixtures/example.com/collection.json +0 -19
  128. package/dist/fixtures/example.com/create.json +0 -6
  129. package/dist/fixtures/example.com/cross-origin-actor.json +0 -6
  130. package/dist/fixtures/example.com/hong-gildong.json +0 -11
  131. package/dist/fixtures/example.com/invite.json +0 -7
  132. package/dist/fixtures/example.com/key.json +0 -7
  133. package/dist/fixtures/example.com/key2.json +0 -6
  134. package/dist/fixtures/example.com/object.json +0 -6
  135. package/dist/fixtures/example.com/orderedcollectionpage.json +0 -24
  136. package/dist/fixtures/example.com/paged/a.json +0 -13
  137. package/dist/fixtures/example.com/paged/b.json +0 -16
  138. package/dist/fixtures/example.com/paged-collection.json +0 -6
  139. package/dist/fixtures/example.com/person.json +0 -22
  140. package/dist/fixtures/example.com/person2.json +0 -40
  141. package/dist/fixtures/example.com/test.json +0 -5
  142. package/dist/fixtures/example.com/users/handle.json +0 -16
  143. package/dist/fixtures/example.com/wrong-type.json +0 -3
  144. package/dist/fixtures/media.example.com/avatars/test-avatar.jpg.json +0 -6
  145. package/dist/fixtures/oeee.cafe/ap/users/3609fd4e-d51d-4db8-9f04-4189815864dd.json +0 -24
  146. package/dist/fixtures/remote.domain/users/bob.json +0 -20
  147. package/dist/fixtures/server.example/users/alice.json +0 -20
  148. package/dist/fixtures/w3id.org/identity/v1.json +0 -152
  149. package/dist/fixtures/w3id.org/security/data-integrity/v1.json +0 -74
  150. package/dist/fixtures/w3id.org/security/multikey/v1.json +0 -35
  151. package/dist/fixtures/w3id.org/security/v1.json +0 -50
  152. package/dist/fixtures/wizard.casa/users/hongminhee.json +0 -69
  153. package/dist/fixtures/www.w3.org/ns/activitystreams.json +0 -379
  154. package/dist/fixtures/www.w3.org/ns/did/v1.json +0 -58
  155. package/dist/lookup-BTqtVATt.cjs +0 -266
  156. package/dist/lookup-DOSnR912.js +0 -254
  157. package/dist/lookup-Dj9-mgOn.js +0 -42184
  158. package/dist/middleware-CxswDtQn.js +0 -15
  159. package/dist/middleware-CyITsnX0.js +0 -26
  160. package/dist/middleware-Z8lc_drL.cjs +0 -15
  161. package/dist/mod-BlVovdcy.d.ts +0 -309
  162. package/dist/mod-BxRCHTz-.d.cts +0 -307
  163. package/dist/mod-C58MZ7Wx.d.cts +0 -113
  164. package/dist/mod-CcDPcLJW.d.cts +0 -1
  165. package/dist/mod-Ds0mpFZU.d.ts +0 -115
  166. package/dist/mod-bjzj5QIb.d.ts +0 -2
  167. package/dist/otel-1BmGPuZc.js +0 -64
  168. package/dist/src/vocab/accept.yaml +0 -15
  169. package/dist/src/vocab/activity.yaml +0 -98
  170. package/dist/src/vocab/add.yaml +0 -16
  171. package/dist/src/vocab/announce.yaml +0 -30
  172. package/dist/src/vocab/application.yaml +0 -324
  173. package/dist/src/vocab/arrive.yaml +0 -15
  174. package/dist/src/vocab/article.yaml +0 -46
  175. package/dist/src/vocab/audio.yaml +0 -11
  176. package/dist/src/vocab/block.yaml +0 -16
  177. package/dist/src/vocab/chatmessage.yaml +0 -50
  178. package/dist/src/vocab/collection.yaml +0 -154
  179. package/dist/src/vocab/collectionpage.yaml +0 -55
  180. package/dist/src/vocab/create.yaml +0 -28
  181. package/dist/src/vocab/dataintegrityproof.yaml +0 -56
  182. package/dist/src/vocab/delete.yaml +0 -27
  183. package/dist/src/vocab/didservice.yaml +0 -22
  184. package/dist/src/vocab/dislike.yaml +0 -14
  185. package/dist/src/vocab/document.yaml +0 -31
  186. package/dist/src/vocab/emoji.yaml +0 -12
  187. package/dist/src/vocab/emojireact.yaml +0 -17
  188. package/dist/src/vocab/endpoints.yaml +0 -85
  189. package/dist/src/vocab/event.yaml +0 -11
  190. package/dist/src/vocab/export.yaml +0 -9
  191. package/dist/src/vocab/flag.yaml +0 -15
  192. package/dist/src/vocab/follow.yaml +0 -19
  193. package/dist/src/vocab/group.yaml +0 -324
  194. package/dist/src/vocab/hashtag.yaml +0 -14
  195. package/dist/src/vocab/ignore.yaml +0 -14
  196. package/dist/src/vocab/image.yaml +0 -9
  197. package/dist/src/vocab/intransitiveactivity.yaml +0 -15
  198. package/dist/src/vocab/invite.yaml +0 -14
  199. package/dist/src/vocab/join.yaml +0 -14
  200. package/dist/src/vocab/key.yaml +0 -28
  201. package/dist/src/vocab/leave.yaml +0 -14
  202. package/dist/src/vocab/like.yaml +0 -16
  203. package/dist/src/vocab/link.yaml +0 -101
  204. package/dist/src/vocab/listen.yaml +0 -12
  205. package/dist/src/vocab/mention.yaml +0 -9
  206. package/dist/src/vocab/move.yaml +0 -15
  207. package/dist/src/vocab/multikey.yaml +0 -36
  208. package/dist/src/vocab/note.yaml +0 -48
  209. package/dist/src/vocab/object.yaml +0 -404
  210. package/dist/src/vocab/offer.yaml +0 -15
  211. package/dist/src/vocab/orderedcollection.yaml +0 -39
  212. package/dist/src/vocab/orderedcollectionpage.yaml +0 -50
  213. package/dist/src/vocab/organization.yaml +0 -324
  214. package/dist/src/vocab/page.yaml +0 -11
  215. package/dist/src/vocab/person.yaml +0 -324
  216. package/dist/src/vocab/place.yaml +0 -75
  217. package/dist/src/vocab/profile.yaml +0 -26
  218. package/dist/src/vocab/propertyvalue.yaml +0 -32
  219. package/dist/src/vocab/question.yaml +0 -103
  220. package/dist/src/vocab/read.yaml +0 -13
  221. package/dist/src/vocab/reject.yaml +0 -14
  222. package/dist/src/vocab/relationship.yaml +0 -52
  223. package/dist/src/vocab/remove.yaml +0 -14
  224. package/dist/src/vocab/service.yaml +0 -324
  225. package/dist/src/vocab/source.yaml +0 -26
  226. package/dist/src/vocab/tentativeaccept.yaml +0 -14
  227. package/dist/src/vocab/tentativereject.yaml +0 -14
  228. package/dist/src/vocab/tombstone.yaml +0 -24
  229. package/dist/src/vocab/travel.yaml +0 -16
  230. package/dist/src/vocab/undo.yaml +0 -26
  231. package/dist/src/vocab/update.yaml +0 -58
  232. package/dist/src/vocab/video.yaml +0 -11
  233. package/dist/src/vocab/view.yaml +0 -13
  234. package/dist/testing/docloader.test.js +0 -22
  235. package/dist/vocab/actor.test.js +0 -5963
  236. package/dist/vocab/lookup.test.d.ts +0 -3
  237. package/dist/vocab/lookup.test.js +0 -476
  238. package/dist/vocab/type.test.d.ts +0 -3
  239. package/dist/vocab/type.test.js +0 -24
  240. package/dist/vocab/vocab.test.d.ts +0 -3
  241. package/dist/vocab/vocab.test.js +0 -9397
  242. package/dist/vocab-BCWe1Ih5.d.ts +0 -14905
  243. package/dist/vocab-ByUp-A2_.js +0 -260
  244. package/dist/vocab-CeDBzu-f.d.cts +0 -14903
  245. package/dist/vocab-X_X5T8D3.cjs +0 -296
  246. package/dist/webfinger/handler.test.d.ts +0 -3
  247. package/dist/webfinger/lookup.test.d.ts +0 -3
  248. package/dist/webfinger/lookup.test.js +0 -193
  249. package/dist/webfinger/mod.cjs +0 -8
  250. package/dist/webfinger/mod.d.cts +0 -2
  251. package/dist/webfinger/mod.d.ts +0 -4
  252. package/dist/webfinger/mod.js +0 -8
  253. package/dist/webfinger-C72Y8lrh.js +0 -4
  254. package/dist/webfinger-vAtLmxOF.cjs +0 -4
  255. /package/dist/{collection-BzWsN9pB.js → collection-CcnIw1qY.js} +0 -0
  256. /package/dist/{testing/docloader.test.d.ts → federation/webfinger.test.d.ts} +0 -0
  257. /package/dist/{mod-CVgZgliM.d.ts → mod-1E3W847c.d.ts} +0 -0
  258. /package/dist/{mod-B-hUPT2N.d.cts → mod-C81L6_lQ.d.cts} +0 -0
  259. /package/dist/{negotiation-C4nFufNk.js → negotiation-5NPJL6zp.js} +0 -0
  260. /package/dist/{nodeinfo-BnthBobC.js → nodeinfo-BlLsRSiT.js} +0 -0
  261. /package/dist/{nodeinfo-CdN0rEnZ.cjs → nodeinfo-DuMYTpbZ.cjs} +0 -0
  262. /package/dist/{vocab/actor.test.d.ts → otel/exporter.test.d.ts} +0 -0
  263. /package/dist/{retry-CfF8Gn4d.js → retry-D4GJ670a.js} +0 -0
  264. /package/dist/{sig-C34-oHBl.js → sig-CwuONEzF.js} +0 -0
  265. /package/dist/{sig-YYj5tCnr.cjs → sig-DeXX2xnj.cjs} +0 -0
  266. /package/dist/{utils-DyRU1gdZ.cjs → utils-Db0ZmjcD.cjs} +0 -0
  267. /package/dist/{utils-D-Va7aXC.js → utils-Wranxuoe.js} +0 -0
@@ -1,296 +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-BTqtVATt.cjs');
7
- const require_actor = require('./actor-CBfPjuWj.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
- });
@@ -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-Dj9-mgOn.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-BslrM_9E.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-VlKMJQqV.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-BTqtVATt.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-DOSnR912.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