@fedify/fedify 2.0.0-dev.1566 → 2.0.0-dev.158

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 (297) hide show
  1. package/LICENSE +1 -1
  2. package/README.md +40 -18
  3. package/dist/{assert_rejects-DiIiJbZn.js → assert_rejects-Ce45JcFg.js} +1 -1
  4. package/dist/{assert_is_error-BPGph1Jx.js → assert_throws-BNXdRGWP.js} +31 -1
  5. package/dist/{builder-B2I70zuM.js → builder-BnWso6VP.js} +15 -8
  6. package/dist/chunk-DqRYRqnO.cjs +34 -0
  7. package/dist/client-94iWEfQa.d.cts +222 -0
  8. package/dist/{client-DF8anIB5.d.ts → client-BivSNrEg.d.ts} +3 -75
  9. package/dist/{client-BVDUd3WA.js → client-CgMTXmAD.js} +3 -22
  10. package/dist/compat/mod.cjs +10 -0
  11. package/dist/compat/mod.d.cts +7 -0
  12. package/dist/compat/mod.d.ts +6 -12
  13. package/dist/compat/mod.js +5 -5
  14. package/dist/compat/transformers.test.js +21 -20
  15. package/dist/compat-DmDDELst.cjs +4 -0
  16. package/dist/compat-nxUqe4Z-.js +4 -0
  17. package/dist/context-Bns6uTJq.js +109 -0
  18. package/dist/{context-9gCpIkiz.d.ts → context-CYZ2i00R.d.ts} +321 -129
  19. package/dist/context-D2MrtLch.d.cts +2447 -0
  20. package/dist/deno-CQV858ip.js +117 -0
  21. package/dist/{testing-CWE5Nn0S.js → dist-B5f6a8Tt.js} +90 -111
  22. package/dist/{authdocloader-BilVqAPe.js → docloader-Csc8gQux.js} +17 -8
  23. package/dist/{esm-eH43VACi.js → esm-DGl7uK1r.js} +32 -17
  24. package/dist/federation/builder.test.js +12 -13
  25. package/dist/federation/collection.test.js +6 -9
  26. package/dist/federation/handler.test.js +115 -148
  27. package/dist/federation/idempotency.test.js +202 -0
  28. package/dist/federation/inbox.test.js +5 -6
  29. package/dist/federation/keycache.test.js +4 -5
  30. package/dist/federation/kv.test.js +61 -9
  31. package/dist/federation/middleware.test.js +311 -131
  32. package/dist/federation/mod.cjs +25 -0
  33. package/dist/federation/mod.d.cts +7 -0
  34. package/dist/federation/mod.d.ts +7 -13
  35. package/dist/federation/mod.js +11 -16
  36. package/dist/federation/mq.test.js +9 -10
  37. package/dist/federation/negotiation.test.js +25 -0
  38. package/dist/federation/retry.test.js +2 -4
  39. package/dist/federation/router.test.js +6 -8
  40. package/dist/federation/send.test.js +55 -15
  41. package/dist/{webfinger/handler.test.js → federation/webfinger.test.js} +27 -26
  42. package/dist/federation-B431K2gm.cjs +266 -0
  43. package/dist/{federation-CMX7WzeL.js → federation-BbZwNNWj.js} +31 -9
  44. package/dist/{http-Cdjyj7h1.js → http-BizGfAHd.js} +375 -15
  45. package/dist/{http-BE2S7wC2.js → http-CXG5ZFqn.js} +4 -3
  46. package/dist/http-ClB3pLcL.d.cts +253 -0
  47. package/dist/{http-DqSNLFNY.d.ts → http-DLBDPal9.d.ts} +2 -2
  48. package/dist/http-DbACqYyq.cjs +1222 -0
  49. package/dist/{inbox-CtcEN1S1.js → inbox-B7ybw6fk.js} +25 -7
  50. package/dist/{key-q4xxkABj.js → key-C27c_yHR.js} +3 -2
  51. package/dist/{keycache-CtCHz6HR.js → keycache-DRxpZ5r9.js} +1 -1
  52. package/dist/{keys-BiuLoxwK.js → keys-ZbcByPg9.js} +2 -1
  53. package/dist/{kv-C7sopW2E.d.ts → kv-CtOmTRNc.d.ts} +30 -1
  54. package/dist/kv-D8q9fLkA.d.cts +110 -0
  55. package/dist/{kv-CRZrzyXm.js → kv-QzKcOQgP.js} +22 -0
  56. package/dist/kv-cache-B7dwGQFA.js +122 -0
  57. package/dist/kv-cache-BEeqyGER.js +107 -0
  58. package/dist/kv-cache-rPOPQdj9.cjs +134 -0
  59. package/dist/{ld-PkXepnwg.js → ld-D_Jn1aGa.js} +6 -4
  60. package/dist/middleware-BVqYHBWm.cjs +12 -0
  61. package/dist/{middleware-HDts7zkt.js → middleware-BjS6_zkf.js} +272 -271
  62. package/dist/middleware-CAJR7KGo.cjs +4242 -0
  63. package/dist/{middleware-BQHcEUgM.js → middleware-ClkhKNXU.js} +230 -327
  64. package/dist/middleware-DSz6sI16.js +26 -0
  65. package/dist/middleware-OcaFHSk8.js +12 -0
  66. package/dist/mod-BrS8tiad.d.cts +266 -0
  67. package/dist/mod-C81L6_lQ.d.cts +1 -0
  68. package/dist/mod-CJgbdSqb.d.ts +109 -0
  69. package/dist/mod-CNNTHyBC.d.cts +80 -0
  70. package/dist/mod-CS-MS7gZ.d.cts +62 -0
  71. package/dist/{mod-Bqxcp7eN.d.ts → mod-D_cmv2il.d.ts} +4 -4
  72. package/dist/mod-DcPRcifg.d.cts +107 -0
  73. package/dist/mod-DqFSzJA0.d.ts +64 -0
  74. package/dist/{mod-Drmz72EK.d.ts → mod-jOa7W503.d.ts} +3 -3
  75. package/dist/mod.cjs +55 -0
  76. package/dist/mod.d.cts +11 -0
  77. package/dist/mod.d.ts +11 -17
  78. package/dist/mod.js +15 -21
  79. package/dist/negotiation-5NPJL6zp.js +71 -0
  80. package/dist/nodeinfo/client.test.js +29 -111
  81. package/dist/nodeinfo/handler.test.js +26 -26
  82. package/dist/nodeinfo/mod.cjs +10 -0
  83. package/dist/nodeinfo/mod.d.cts +3 -0
  84. package/dist/nodeinfo/mod.d.ts +3 -5
  85. package/dist/nodeinfo/mod.js +6 -7
  86. package/dist/nodeinfo/types.test.js +7 -15
  87. package/dist/nodeinfo-BlLsRSiT.js +4 -0
  88. package/dist/nodeinfo-DuMYTpbZ.cjs +4 -0
  89. package/dist/otel/exporter.test.js +899 -0
  90. package/dist/otel/mod.cjs +262 -0
  91. package/dist/otel/mod.d.cts +230 -0
  92. package/dist/otel/mod.d.ts +232 -0
  93. package/dist/otel/mod.js +261 -0
  94. package/dist/{owner-CQPnQVtf.d.ts → owner-BgI8C-VY.d.ts} +2 -3
  95. package/dist/owner-C-zfmVAD.d.cts +66 -0
  96. package/dist/{owner-DZ5zP8JS.js → owner-Dc8rUE-H.js} +45 -8
  97. package/dist/{proof-ohtusUSV.js → proof-BdNM3iSl.js} +4 -3
  98. package/dist/proof-Bx2JqJ-D.cjs +709 -0
  99. package/dist/{proof-D8S7qgEZ.js → proof-CTYnbjx5.js} +53 -17
  100. package/dist/router-D9eI0s4b.js +118 -0
  101. package/dist/{send-BBi1tzS8.js → send-DBRRqVMa.js} +9 -4
  102. package/dist/sig/http.test.js +12 -14
  103. package/dist/sig/key.test.js +9 -11
  104. package/dist/sig/ld.test.js +8 -10
  105. package/dist/sig/mod.cjs +26 -0
  106. package/dist/sig/mod.d.cts +4 -0
  107. package/dist/sig/mod.d.ts +3 -7
  108. package/dist/sig/mod.js +6 -10
  109. package/dist/sig/owner.test.js +33 -12
  110. package/dist/sig/proof.test.js +13 -14
  111. package/dist/sig-CwuONEzF.js +4 -0
  112. package/dist/sig-DeXX2xnj.cjs +4 -0
  113. package/dist/testing/mod.d.ts +180 -6946
  114. package/dist/testing/mod.js +4 -4
  115. package/dist/transformers-BjBg6Lag.cjs +116 -0
  116. package/dist/{transformers-Dna8Fg7k.js → transformers-N_ip_y4P.js} +5 -5
  117. package/dist/{types-BIgY6c-l.js → types-BEdCLHqP.js} +1 -3
  118. package/dist/types-Q-qkJXBV.cjs +315 -0
  119. package/dist/{types-CTYFFnQp.js → types-hKTi53FO.js} +8 -169
  120. package/dist/{runtime/authdocloader.test.js → utils/docloader.test.js} +13 -15
  121. package/dist/utils/kv-cache.test.js +211 -0
  122. package/dist/utils/mod.cjs +10 -0
  123. package/dist/utils/mod.d.cts +4 -0
  124. package/dist/utils/mod.d.ts +6 -0
  125. package/dist/utils/mod.js +9 -0
  126. package/dist/utils-Db0ZmjcD.cjs +4 -0
  127. package/dist/utils-Wranxuoe.js +4 -0
  128. package/package.json +69 -55
  129. package/dist/actor-BKxX_F1w.js +0 -37311
  130. package/dist/actor-C22bXuuC.d.ts +0 -130
  131. package/dist/actor-DI_YpFlI.js +0 -146
  132. package/dist/assert_throws-BOO88avQ.js +0 -39
  133. package/dist/authdocloader-UdvnssIx.js +0 -52
  134. package/dist/compat-Bb5myD13.js +0 -4
  135. package/dist/denokv-Bv33Xxea.js +0 -57
  136. package/dist/docloader-4XS4XdXc.js +0 -4615
  137. package/dist/docloader-CxWcuWqQ.d.ts +0 -221
  138. package/dist/fixtures/activitypub.academy/users/brauca_darradiul.json +0 -83
  139. package/dist/fixtures/example.com/announce.json +0 -6
  140. package/dist/fixtures/example.com/collection.json +0 -19
  141. package/dist/fixtures/example.com/create.json +0 -6
  142. package/dist/fixtures/example.com/cross-origin-actor.json +0 -6
  143. package/dist/fixtures/example.com/hong-gildong.json +0 -11
  144. package/dist/fixtures/example.com/invite.json +0 -7
  145. package/dist/fixtures/example.com/key.json +0 -7
  146. package/dist/fixtures/example.com/key2.json +0 -6
  147. package/dist/fixtures/example.com/object.json +0 -6
  148. package/dist/fixtures/example.com/orderedcollectionpage.json +0 -24
  149. package/dist/fixtures/example.com/paged/a.json +0 -13
  150. package/dist/fixtures/example.com/paged/b.json +0 -16
  151. package/dist/fixtures/example.com/paged-collection.json +0 -6
  152. package/dist/fixtures/example.com/person.json +0 -22
  153. package/dist/fixtures/example.com/person2.json +0 -40
  154. package/dist/fixtures/example.com/test.json +0 -5
  155. package/dist/fixtures/example.com/users/handle.json +0 -16
  156. package/dist/fixtures/example.com/wrong-type.json +0 -3
  157. package/dist/fixtures/oeee.cafe/ap/users/3609fd4e-d51d-4db8-9f04-4189815864dd.json +0 -24
  158. package/dist/fixtures/remote.domain/users/bob.json +0 -20
  159. package/dist/fixtures/server.example/users/alice.json +0 -20
  160. package/dist/fixtures/w3id.org/identity/v1.json +0 -152
  161. package/dist/fixtures/w3id.org/security/data-integrity/v1.json +0 -74
  162. package/dist/fixtures/w3id.org/security/multikey/v1.json +0 -35
  163. package/dist/fixtures/w3id.org/security/v1.json +0 -50
  164. package/dist/fixtures/wizard.casa/users/hongminhee.json +0 -69
  165. package/dist/fixtures/www.w3.org/ns/activitystreams.json +0 -379
  166. package/dist/fixtures/www.w3.org/ns/did/v1.json +0 -58
  167. package/dist/key-C2_QSigr.js +0 -260
  168. package/dist/key-Ck2-lYS5.js +0 -10
  169. package/dist/key-II1NsE_S.js +0 -10
  170. package/dist/lookup-DCIN2EFw.js +0 -322
  171. package/dist/lookup-DVlWgAsd.js +0 -131
  172. package/dist/middleware-CTQfgVW8.js +0 -17
  173. package/dist/middleware-D3rOl6Au.js +0 -26
  174. package/dist/mod-Cxt4Kpf6.d.ts +0 -291
  175. package/dist/mod-DBzN0aCM.d.ts +0 -115
  176. package/dist/mod-TFoH2Ql8.d.ts +0 -104
  177. package/dist/mod-g0xFzAP9.d.ts +0 -2
  178. package/dist/mq-CRGm1e_F.d.ts +0 -143
  179. package/dist/nodeinfo/semver.test.js +0 -143
  180. package/dist/nodeinfo-CyEbLjHs.js +0 -4
  181. package/dist/runtime/docloader.test.js +0 -522
  182. package/dist/runtime/key.test.js +0 -103
  183. package/dist/runtime/langstr.test.js +0 -39
  184. package/dist/runtime/mod.d.ts +0 -8
  185. package/dist/runtime/mod.js +0 -13
  186. package/dist/runtime/multibase/multibase.test.d.ts +0 -3
  187. package/dist/runtime/multibase/multibase.test.js +0 -358
  188. package/dist/runtime/url.test.d.ts +0 -3
  189. package/dist/runtime/url.test.js +0 -45
  190. package/dist/runtime-BSkOVUWM.js +0 -4
  191. package/dist/semver-dArNLkR9.js +0 -149
  192. package/dist/sig-BXJO--F9.js +0 -4
  193. package/dist/src/vocab/accept.yaml +0 -15
  194. package/dist/src/vocab/activity.yaml +0 -98
  195. package/dist/src/vocab/add.yaml +0 -16
  196. package/dist/src/vocab/announce.yaml +0 -30
  197. package/dist/src/vocab/application.yaml +0 -324
  198. package/dist/src/vocab/arrive.yaml +0 -15
  199. package/dist/src/vocab/article.yaml +0 -46
  200. package/dist/src/vocab/audio.yaml +0 -11
  201. package/dist/src/vocab/block.yaml +0 -16
  202. package/dist/src/vocab/chatmessage.yaml +0 -50
  203. package/dist/src/vocab/collection.yaml +0 -154
  204. package/dist/src/vocab/collectionpage.yaml +0 -55
  205. package/dist/src/vocab/create.yaml +0 -28
  206. package/dist/src/vocab/dataintegrityproof.yaml +0 -56
  207. package/dist/src/vocab/delete.yaml +0 -27
  208. package/dist/src/vocab/didservice.yaml +0 -22
  209. package/dist/src/vocab/dislike.yaml +0 -14
  210. package/dist/src/vocab/document.yaml +0 -31
  211. package/dist/src/vocab/emoji.yaml +0 -12
  212. package/dist/src/vocab/emojireact.yaml +0 -17
  213. package/dist/src/vocab/endpoints.yaml +0 -85
  214. package/dist/src/vocab/event.yaml +0 -11
  215. package/dist/src/vocab/export.yaml +0 -9
  216. package/dist/src/vocab/flag.yaml +0 -15
  217. package/dist/src/vocab/follow.yaml +0 -19
  218. package/dist/src/vocab/group.yaml +0 -324
  219. package/dist/src/vocab/hashtag.yaml +0 -14
  220. package/dist/src/vocab/ignore.yaml +0 -14
  221. package/dist/src/vocab/image.yaml +0 -9
  222. package/dist/src/vocab/intransitiveactivity.yaml +0 -15
  223. package/dist/src/vocab/invite.yaml +0 -14
  224. package/dist/src/vocab/join.yaml +0 -14
  225. package/dist/src/vocab/key.yaml +0 -28
  226. package/dist/src/vocab/leave.yaml +0 -14
  227. package/dist/src/vocab/like.yaml +0 -16
  228. package/dist/src/vocab/link.yaml +0 -101
  229. package/dist/src/vocab/listen.yaml +0 -12
  230. package/dist/src/vocab/mention.yaml +0 -9
  231. package/dist/src/vocab/move.yaml +0 -15
  232. package/dist/src/vocab/multikey.yaml +0 -36
  233. package/dist/src/vocab/note.yaml +0 -48
  234. package/dist/src/vocab/object.yaml +0 -404
  235. package/dist/src/vocab/offer.yaml +0 -15
  236. package/dist/src/vocab/orderedcollection.yaml +0 -39
  237. package/dist/src/vocab/orderedcollectionpage.yaml +0 -50
  238. package/dist/src/vocab/organization.yaml +0 -324
  239. package/dist/src/vocab/page.yaml +0 -11
  240. package/dist/src/vocab/person.yaml +0 -324
  241. package/dist/src/vocab/place.yaml +0 -75
  242. package/dist/src/vocab/profile.yaml +0 -26
  243. package/dist/src/vocab/propertyvalue.yaml +0 -32
  244. package/dist/src/vocab/question.yaml +0 -103
  245. package/dist/src/vocab/read.yaml +0 -13
  246. package/dist/src/vocab/reject.yaml +0 -14
  247. package/dist/src/vocab/relationship.yaml +0 -52
  248. package/dist/src/vocab/remove.yaml +0 -14
  249. package/dist/src/vocab/service.yaml +0 -324
  250. package/dist/src/vocab/source.yaml +0 -26
  251. package/dist/src/vocab/tentativeaccept.yaml +0 -14
  252. package/dist/src/vocab/tentativereject.yaml +0 -14
  253. package/dist/src/vocab/tombstone.yaml +0 -24
  254. package/dist/src/vocab/travel.yaml +0 -16
  255. package/dist/src/vocab/undo.yaml +0 -26
  256. package/dist/src/vocab/update.yaml +0 -58
  257. package/dist/src/vocab/video.yaml +0 -11
  258. package/dist/src/vocab/view.yaml +0 -13
  259. package/dist/testing/docloader.test.js +0 -24
  260. package/dist/type-B7_rMIU9.js +0 -42006
  261. package/dist/vocab/actor.test.d.ts +0 -3
  262. package/dist/vocab/actor.test.js +0 -5965
  263. package/dist/vocab/lookup.test.d.ts +0 -3
  264. package/dist/vocab/lookup.test.js +0 -206
  265. package/dist/vocab/mod.d.ts +0 -8
  266. package/dist/vocab/mod.js +0 -10
  267. package/dist/vocab/schema.yaml +0 -247
  268. package/dist/vocab/type.test.d.ts +0 -3
  269. package/dist/vocab/type.test.js +0 -25
  270. package/dist/vocab/vocab.test.d.ts +0 -3
  271. package/dist/vocab/vocab.test.js +0 -3363
  272. package/dist/vocab-3Eie7Ze4.js +0 -246
  273. package/dist/vocab-SOE1ifCr.d.ts +0 -14634
  274. package/dist/webfinger/handler.test.d.ts +0 -3
  275. package/dist/webfinger/lookup.test.d.ts +0 -3
  276. package/dist/webfinger/lookup.test.js +0 -195
  277. package/dist/webfinger/mod.d.ts +0 -6
  278. package/dist/webfinger/mod.js +0 -9
  279. package/dist/webfinger-C3GIyXIg.js +0 -4
  280. package/dist/x/cfworkers.d.ts +0 -61
  281. package/dist/x/cfworkers.js +0 -98
  282. package/dist/x/cfworkers.test.d.ts +0 -3
  283. package/dist/x/cfworkers.test.js +0 -179
  284. package/dist/x/hono.d.ts +0 -56
  285. package/dist/x/hono.js +0 -60
  286. package/dist/x/sveltekit.d.ts +0 -48
  287. package/dist/x/sveltekit.js +0 -68
  288. /package/dist/{assert_not_equals-f3m3epl3.js → assert_not_equals-C80BG-_5.js} +0 -0
  289. /package/dist/{collection-CSzG2j1P.js → collection-CcnIw1qY.js} +0 -0
  290. /package/dist/{nodeinfo/semver.test.d.ts → federation/idempotency.test.d.ts} +0 -0
  291. /package/dist/{runtime/authdocloader.test.d.ts → federation/negotiation.test.d.ts} +0 -0
  292. /package/dist/{runtime/docloader.test.d.ts → federation/webfinger.test.d.ts} +0 -0
  293. /package/dist/{mod-1pDWKvUL.d.ts → mod-1E3W847c.d.ts} +0 -0
  294. /package/dist/{runtime/key.test.d.ts → otel/exporter.test.d.ts} +0 -0
  295. /package/dist/{std__assert-X-_kMxKM.js → std__assert-DWivtrGR.js} +0 -0
  296. /package/dist/{testing → utils}/docloader.test.d.ts +0 -0
  297. /package/dist/{runtime/langstr.test.d.ts → utils/kv-cache.test.d.ts} +0 -0
@@ -1,291 +0,0 @@
1
- import { Temporal } from "@js-temporal/polyfill";
2
- import { URLPattern } from "urlpattern-polyfill";
3
- import { DocumentLoader, GetUserAgentOptions } from "./docloader-CxWcuWqQ.js";
4
- import { Collection, Link, Object as Object$1 } from "./vocab-SOE1ifCr.js";
5
- import { TracerProvider } from "@opentelemetry/api";
6
-
7
- //#region src/vocab/lookup.d.ts
8
- /**
9
- * Options for the {@link lookupObject} function.
10
- *
11
- * @since 0.2.0
12
- */
13
- interface LookupObjectOptions {
14
- /**
15
- * The document loader for loading remote JSON-LD documents.
16
- */
17
- documentLoader?: DocumentLoader;
18
- /**
19
- * The context loader for loading remote JSON-LD contexts.
20
- * @since 0.8.0
21
- */
22
- contextLoader?: DocumentLoader;
23
- /**
24
- * The options for making `User-Agent` header.
25
- * If a string is given, it is used as the `User-Agent` header value.
26
- * If an object is given, it is passed to {@link getUserAgent} to generate
27
- * the `User-Agent` header value.
28
- * @since 1.3.0
29
- */
30
- userAgent?: GetUserAgentOptions | string;
31
- /**
32
- * The OpenTelemetry tracer provider. If omitted, the global tracer provider
33
- * is used.
34
- * @since 1.3.0
35
- */
36
- tracerProvider?: TracerProvider;
37
- /**
38
- * AbortSignal for cancelling the request.
39
- * @since 1.8.0
40
- */
41
- signal?: AbortSignal;
42
- }
43
- /**
44
- * Looks up an ActivityStreams object by its URI (including `acct:` URIs)
45
- * or a fediverse handle (e.g., `@user@server` or `user@server`).
46
- *
47
- * @example
48
- * ``` typescript
49
- * // Look up an actor by its fediverse handle:
50
- * await lookupObject("@hongminhee@fosstodon.org");
51
- * // returning a `Person` object.
52
- *
53
- * // A fediverse handle can omit the leading '@':
54
- * await lookupObject("hongminhee@fosstodon.org");
55
- * // returning a `Person` object.
56
- *
57
- * // A `acct:` URI can be used as well:
58
- * await lookupObject("acct:hongminhee@fosstodon.org");
59
- * // returning a `Person` object.
60
- *
61
- * // Look up an object by its URI:
62
- * await lookupObject("https://todon.eu/@hongminhee/112060633798771581");
63
- * // returning a `Note` object.
64
- *
65
- * // It can be a `URL` object as well:
66
- * await lookupObject(new URL("https://todon.eu/@hongminhee/112060633798771581"));
67
- * // returning a `Note` object.
68
- * ```
69
- *
70
- * @param identifier The URI or fediverse handle to look up.
71
- * @param options Lookup options.
72
- * @returns The object, or `null` if not found.
73
- * @since 0.2.0
74
- */
75
- declare function lookupObject(identifier: string | URL, options?: LookupObjectOptions): Promise<Object$1 | null>;
76
- /**
77
- * Options for the {@link traverseCollection} function.
78
- * @since 1.1.0
79
- */
80
- interface TraverseCollectionOptions {
81
- /**
82
- * The document loader for loading remote JSON-LD documents.
83
- */
84
- documentLoader?: DocumentLoader;
85
- /**
86
- * The context loader for loading remote JSON-LD contexts.
87
- */
88
- contextLoader?: DocumentLoader;
89
- /**
90
- * Whether to suppress errors when fetching pages. If `true`,
91
- * errors will be logged but not thrown. Defaults to `false`.
92
- */
93
- suppressError?: boolean;
94
- /**
95
- * The interval to wait between fetching pages. Zero or negative
96
- * values will disable the interval. Disabled by default.
97
- *
98
- * @default `{ seconds: 0 }`
99
- */
100
- interval?: Temporal.Duration | Temporal.DurationLike;
101
- }
102
- /**
103
- * Traverses a collection, yielding each item in the collection.
104
- * If the collection is paginated, it will fetch the next page
105
- * automatically.
106
- *
107
- * @example
108
- * ``` typescript
109
- * const collection = await lookupObject(collectionUrl);
110
- * if (collection instanceof Collection) {
111
- * for await (const item of traverseCollection(collection)) {
112
- * console.log(item.id?.href);
113
- * }
114
- * }
115
- * ```
116
- *
117
- * @param collection The collection to traverse.
118
- * @param options Options for traversing the collection.
119
- * @returns An async iterable of each item in the collection.
120
- * @since 1.1.0
121
- */
122
- declare function traverseCollection(collection: Collection, options?: TraverseCollectionOptions): AsyncIterable<Object$1 | Link>;
123
- //#endregion
124
- //#region src/vocab/constants.d.ts
125
- /**
126
- * The special public collection for [public addressing]. *Do not mutate this
127
- * object.*
128
- *
129
- * [public addressing]: https://www.w3.org/TR/activitypub/#public-addressing
130
- *
131
- * @since 0.7.0
132
- */
133
- declare const PUBLIC_COLLECTION: URL;
134
- //#endregion
135
- //#region src/vocab/handle.d.ts
136
- /**
137
- * Represents a fediverse handle, which consists of a username and a host.
138
- * The username can be alphanumeric and may include special characters,
139
- * while the host is typically a domain name.
140
- * @since 1.8.0
141
- */
142
- interface FediverseHandle {
143
- /**
144
- * The username part of the fediverse handle.
145
- * It can include alphanumeric characters and some special characters.
146
- */
147
- readonly username: string;
148
- /**
149
- * The host part of the fediverse handle, typically a domain name.
150
- * It is the part after the `@` symbol in the handle.
151
- */
152
- readonly host: string;
153
- }
154
- /**
155
- * Parses a fediverse handle in the format `@user@server` or `user@server`.
156
- * The `user` part can contain alphanumeric characters and some special
157
- * characters except `@`. The `server` part is all characters after the `@`
158
- * symbol in the middle.
159
- *
160
- * @example
161
- * ```typescript
162
- * const handle = parseFediverseHandle("@username@example.com");
163
- * console.log(handle?.username); // "username"
164
- * console.log(handle?.host); // "example.com"
165
- * ```
166
- *
167
- * @param handle - The fediverse handle string to parse.
168
- * @returns A {@link FediverseHandle} object with `username` and `host`
169
- * if the input is valid; otherwise `null`.
170
- * @since 1.8.0
171
- */
172
- declare function parseFediverseHandle(handle: string): FediverseHandle | null;
173
- /**
174
- * Checks if a string is a valid fediverse handle in the format `@user@server`
175
- * or `user@server`. The `user` part can contain alphanumeric characters and
176
- * some special characters except `@`. The `server` part is all characters
177
- * after the `@` symbol in the middle.
178
- *
179
- * @example
180
- * ```typescript
181
- * console.log(isFediverseHandle("@username@example.com")); // true
182
- * console.log(isFediverseHandle("username@example.com")); // true
183
- * console.log(isFediverseHandle("@username@")); // false
184
- * ```
185
- *
186
- * @param handle - The string to test as a fediverse handle.
187
- * @returns `true` if the string matches the fediverse handle pattern;
188
- * otherwise `false`.
189
- * @since 1.8.0
190
- */
191
- declare function isFediverseHandle(handle: string): handle is `${string}@${string}`;
192
- /**
193
- * Converts a fediverse handle in the format `@user@server` or `user@server`
194
- * to an `acct:` URI, which is a URL-like identifier for ActivityPub actors.
195
- *
196
- * @example
197
- * ```typescript
198
- * const identifier = toAcctUrl("@username@example.com");
199
- * console.log(identifier?.href); // "acct:username@example.com"
200
- * ```
201
- *
202
- * @param handle - The fediverse handle string to convert.
203
- * @returns A `URL` object representing the `acct:` URI if conversion succeeds;
204
- * otherwise `null`.
205
- * @since 1.8.0
206
- */
207
- declare function toAcctUrl(handle: string): URL | null;
208
- //#endregion
209
- //#region src/vocab/type.d.ts
210
- /**
211
- * Returns the type URI of the given object.
212
- *
213
- * @example
214
- * ``` typescript
215
- * import { getTypeId, Person } from "@fedify/fedify";
216
- *
217
- * const obj = new Person({});
218
- * console.log(getTypeId(obj));
219
- * // => new URL("https://www.w3.org/ns/activitystreams#Person")
220
- * ```
221
- *
222
- * @param object The Activity Vocabulary object.
223
- * @returns The type URI of the object, e.g.,
224
- * `new URL("https://www.w3.org/ns/activitystreams#Person")`.
225
- * If the given `object` is `null` or `undefined`, returns `null` or
226
- * `undefined`, respectively.
227
- * @since 1.3.0
228
- */
229
- declare function getTypeId(object: Object$1 | Link): URL;
230
- /**
231
- * Returns the type URI of the given object.
232
- *
233
- * @example
234
- * ``` typescript
235
- * import { getTypeId, Person } from "@fedify/fedify";
236
- *
237
- * const obj = new Person({});
238
- * console.log(getTypeId(obj));
239
- * // => new URL("https://www.w3.org/ns/activitystreams#Person")
240
- * ```
241
- *
242
- * @param object The Activity Vocabulary object.
243
- * @returns The type URI of the object, e.g.,
244
- * `new URL("https://www.w3.org/ns/activitystreams#Person")`.
245
- * If the given `object` is `null` or `undefined`, returns `null` or
246
- * `undefined`, respectively.
247
- * @since 1.3.0
248
- */
249
- declare function getTypeId(object: Object$1 | Link | undefined): URL | undefined;
250
- /**
251
- * Returns the type URI of the given object.
252
- *
253
- * @example
254
- * ``` typescript
255
- * import { getTypeId, Person } from "@fedify/fedify";
256
- *
257
- * const obj = new Person({});
258
- * console.log(getTypeId(obj));
259
- * // => new URL("https://www.w3.org/ns/activitystreams#Person")
260
- * ```
261
- *
262
- * @param object The Activity Vocabulary object.
263
- * @returns The type URI of the object, e.g.,
264
- * `new URL("https://www.w3.org/ns/activitystreams#Person")`.
265
- * If the given `object` is `null` or `undefined`, returns `null` or
266
- * `undefined`, respectively.
267
- * @since 1.3.0
268
- */
269
- declare function getTypeId(object: Object$1 | Link | null): URL | null;
270
- /**
271
- * Returns the type URI of the given object.
272
- *
273
- * @example
274
- * ``` typescript
275
- * import { getTypeId, Person } from "@fedify/fedify";
276
- *
277
- * const obj = new Person({});
278
- * console.log(getTypeId(obj));
279
- * // => new URL("https://www.w3.org/ns/activitystreams#Person")
280
- * ```
281
- *
282
- * @param object The Activity Vocabulary object.
283
- * @returns The type URI of the object, e.g.,
284
- * `new URL("https://www.w3.org/ns/activitystreams#Person")`.
285
- * If the given `object` is `null` or `undefined`, returns `null` or
286
- * `undefined`, respectively.
287
- * @since 1.3.0
288
- */
289
- declare function getTypeId(object: Object$1 | Link | null | undefined): URL | null | undefined;
290
- //#endregion
291
- export { FediverseHandle, LookupObjectOptions, PUBLIC_COLLECTION, TraverseCollectionOptions, getTypeId, isFediverseHandle, lookupObject, parseFediverseHandle, toAcctUrl, traverseCollection };
@@ -1,115 +0,0 @@
1
- import { Temporal } from "@js-temporal/polyfill";
2
- import { URLPattern } from "urlpattern-polyfill";
3
- import { GetUserAgentOptions } from "./docloader-CxWcuWqQ.js";
4
- import { TracerProvider } from "@opentelemetry/api";
5
-
6
- //#region src/webfinger/jrd.d.ts
7
- /**
8
- * Describes a resource. See also
9
- * [RFC 7033 section 4.4](https://datatracker.ietf.org/doc/html/rfc7033#section-4.4).
10
- */
11
- interface ResourceDescriptor {
12
- /**
13
- * A URI that identifies the entity that this descriptor describes.
14
- */
15
- subject?: string;
16
- /**
17
- * URIs that identify the same entity as the `subject`.
18
- */
19
- aliases?: string[];
20
- /**
21
- * Conveys additional information about the `subject` of this descriptor.
22
- */
23
- properties?: Record<string, string>;
24
- /**
25
- * Links to other resources.
26
- */
27
- links?: Link[];
28
- }
29
- /**
30
- * Represents a link. See also
31
- * [RFC 7033 section 4.4.4](https://datatracker.ietf.org/doc/html/rfc7033#section-4.4.4).
32
- */
33
- interface Link {
34
- /**
35
- * The link's relation type, which is either a URI or a registered relation
36
- * type (see [RFC 5988](https://datatracker.ietf.org/doc/html/rfc5988)).
37
- */
38
- rel: string;
39
- /**
40
- * The media type of the target resource (see
41
- * [RFC 6838](https://datatracker.ietf.org/doc/html/rfc6838)).
42
- */
43
- type?: string;
44
- /**
45
- * A URI pointing to the target resource.
46
- */
47
- href?: string;
48
- /**
49
- * Human-readable titles describing the link relation. If the language is
50
- * unknown or unspecified, the key is `"und"`.
51
- */
52
- titles?: Record<string, string>;
53
- /**
54
- * Conveys additional information about the link relation.
55
- */
56
- properties?: Record<string, string>;
57
- /**
58
- * A URI Template (RFC 6570) that can be used to construct URIs by
59
- * substituting variables. Used primarily for subscription endpoints
60
- * where parameters like account URIs need to be dynamically inserted.
61
- * @since 1.9.0
62
- */
63
- template?: string;
64
- }
65
- //#endregion
66
- //#region src/webfinger/lookup.d.ts
67
- /**
68
- * Options for {@link lookupWebFinger}.
69
- * @since 1.3.0
70
- */
71
- interface LookupWebFingerOptions {
72
- /**
73
- * The options for making `User-Agent` header.
74
- * If a string is given, it is used as the `User-Agent` header value.
75
- * If an object is given, it is passed to {@link getUserAgent} to generate
76
- * the `User-Agent` header value.
77
- */
78
- userAgent?: GetUserAgentOptions | string;
79
- /**
80
- * Whether to allow private IP addresses in the URL.
81
- *
82
- * Mostly useful for testing purposes. *Do not use this in production.*
83
- *
84
- * Turned off by default.
85
- * @since 1.4.0
86
- */
87
- allowPrivateAddress?: boolean;
88
- /**
89
- * The maximum number of redirections to follow.
90
- * @default `5`
91
- * @since 1.8.0
92
- */
93
- maxRedirection?: number;
94
- /**
95
- * The OpenTelemetry tracer provider. If omitted, the global tracer provider
96
- * is used.
97
- */
98
- tracerProvider?: TracerProvider;
99
- /**
100
- * AbortSignal for cancelling the request.
101
- * @since 1.8.0
102
- * @
103
- */
104
- signal?: AbortSignal;
105
- }
106
- /**
107
- * Looks up a WebFinger resource.
108
- * @param resource The resource URL to look up.
109
- * @param options Extra options for looking up the resource.
110
- * @returns The resource descriptor, or `null` if not found.
111
- * @since 0.2.0
112
- */
113
- declare function lookupWebFinger(resource: URL | string, options?: LookupWebFingerOptions): Promise<ResourceDescriptor | null>;
114
- //#endregion
115
- export { Link, LookupWebFingerOptions, ResourceDescriptor, lookupWebFinger };
@@ -1,104 +0,0 @@
1
- import { Temporal } from "@js-temporal/polyfill";
2
- import { URLPattern } from "urlpattern-polyfill";
3
- import { DocumentLoader, DocumentLoaderFactoryOptions } from "./docloader-CxWcuWqQ.js";
4
- import { HttpMessageSignaturesSpecDeterminer } from "./http-DqSNLFNY.js";
5
- import { TracerProvider } from "@opentelemetry/api";
6
-
7
- //#region src/runtime/authdocloader.d.ts
8
- /**
9
- * Options for {@link getAuthenticatedDocumentLoader}.
10
- * @see {@link getAuthenticatedDocumentLoader}
11
- * @since 1.3.0
12
- */
13
- interface GetAuthenticatedDocumentLoaderOptions extends DocumentLoaderFactoryOptions {
14
- /**
15
- * An optional spec determiner for HTTP Message Signatures.
16
- * It determines the spec to use for signing requests.
17
- * It is used for double-knocking
18
- * (see <https://swicg.github.io/activitypub-http-signature/#how-to-upgrade-supported-versions>).
19
- * @since 1.6.0
20
- */
21
- specDeterminer?: HttpMessageSignaturesSpecDeterminer;
22
- /**
23
- * The OpenTelemetry tracer provider. If omitted, the global tracer provider
24
- * is used.
25
- * @since 1.6.0
26
- */
27
- tracerProvider?: TracerProvider;
28
- }
29
- /**
30
- * Gets an authenticated {@link DocumentLoader} for the given identity.
31
- * Note that an authenticated document loader intentionally does not cache
32
- * the fetched documents.
33
- * @param identity The identity to get the document loader for.
34
- * The actor's key pair.
35
- * @param options The options for the document loader.
36
- * @returns The authenticated document loader.
37
- * @throws {TypeError} If the key is invalid or unsupported.
38
- * @since 0.4.0
39
- */
40
- declare function getAuthenticatedDocumentLoader(identity: {
41
- keyId: URL;
42
- privateKey: CryptoKey;
43
- }, {
44
- allowPrivateAddress,
45
- userAgent,
46
- specDeterminer,
47
- tracerProvider
48
- }?: GetAuthenticatedDocumentLoaderOptions): DocumentLoader;
49
- //#endregion
50
- //#region src/runtime/key.d.ts
51
- /**
52
- * Imports a PEM-SPKI formatted public key.
53
- * @param pem The PEM-SPKI formatted public key.
54
- * @returns The imported public key.
55
- * @throws {TypeError} If the key is invalid or unsupported.
56
- * @since 0.5.0
57
- */
58
- declare function importSpki(pem: string): Promise<CryptoKey>;
59
- /**
60
- * Exports a public key in PEM-SPKI format.
61
- * @param key The public key to export.
62
- * @returns The exported public key in PEM-SPKI format.
63
- * @throws {TypeError} If the key is invalid or unsupported.
64
- * @since 0.5.0
65
- */
66
- declare function exportSpki(key: CryptoKey): Promise<string>;
67
- /**
68
- * Imports a PEM-PKCS#1 formatted public key.
69
- * @param pem The PEM-PKCS#1 formatted public key.
70
- * @returns The imported public key.
71
- * @throws {TypeError} If the key is invalid or unsupported.
72
- * @since 1.5.0
73
- */
74
- declare function importPkcs1(pem: string): Promise<CryptoKey>;
75
- /**
76
- * Imports a PEM formatted public key (SPKI or PKCS#1).
77
- * @param pem The PEM formatted public key to import (SPKI or PKCS#1).
78
- * @returns The imported public key.
79
- * @throws {TypeError} If the key is invalid or unsupported.
80
- * @since 1.5.0
81
- */
82
- declare function importPem(pem: string): Promise<CryptoKey>;
83
- /**
84
- * Imports a [Multibase]-encoded public key.
85
- *
86
- * [Multibase]: https://www.w3.org/TR/vc-data-integrity/#multibase-0
87
- * @param key The Multibase-encoded public key.
88
- * @returns The imported public key.
89
- * @throws {TypeError} If the key is invalid or unsupported.
90
- * @since 0.10.0
91
- */
92
- declare function importMultibaseKey(key: string): Promise<CryptoKey>;
93
- /**
94
- * Exports a public key in [Multibase] format.
95
- *
96
- * [Multibase]: https://www.w3.org/TR/vc-data-integrity/#multibase-0
97
- * @param key The public key to export.
98
- * @returns The exported public key in Multibase format.
99
- * @throws {TypeError} If the key is invalid or unsupported.
100
- * @since 0.10.0
101
- */
102
- declare function exportMultibaseKey(key: CryptoKey): Promise<string>;
103
- //#endregion
104
- export { GetAuthenticatedDocumentLoaderOptions, exportMultibaseKey, exportSpki, getAuthenticatedDocumentLoader, importMultibaseKey, importPem, importPkcs1, importSpki };
@@ -1,2 +0,0 @@
1
- import { Temporal } from "@js-temporal/polyfill";
2
- import { URLPattern } from "urlpattern-polyfill";
@@ -1,143 +0,0 @@
1
- import { Temporal } from "@js-temporal/polyfill";
2
- import { URLPattern } from "urlpattern-polyfill";
3
-
4
- //#region src/federation/mq.d.ts
5
- /**
6
- * Additional options for enqueuing a message in a queue.
7
- *
8
- * @since 0.5.0
9
- */
10
- interface MessageQueueEnqueueOptions {
11
- /**
12
- * The delay before the message is enqueued. No delay by default.
13
- *
14
- * It must not be negative.
15
- */
16
- delay?: Temporal.Duration;
17
- }
18
- /**
19
- * Additional options for listening to a message queue.
20
- *
21
- * @since 1.0.0
22
- */
23
- interface MessageQueueListenOptions {
24
- /**
25
- * The signal to abort listening to the message queue.
26
- */
27
- signal?: AbortSignal;
28
- }
29
- /**
30
- * An abstract interface for a message queue.
31
- *
32
- * @since 0.5.0
33
- */
34
- interface MessageQueue {
35
- /**
36
- * Whether the message queue backend provides native retry mechanisms.
37
- * When `true`, Fedify will skip its own retry logic and rely on the backend
38
- * to handle retries. When `false` or omitted, Fedify will handle retries
39
- * using its own retry policies.
40
- *
41
- * @default `false`
42
- * @since 1.7.0
43
- */
44
- readonly nativeRetrial?: boolean;
45
- /**
46
- * Enqueues a message in the queue.
47
- * @param message The message to enqueue.
48
- * @param options Additional options for enqueuing the message.
49
- */
50
- enqueue(message: any, options?: MessageQueueEnqueueOptions): Promise<void>;
51
- /**
52
- * Enqueues multiple messages in the queue. This operation is optional,
53
- * and may not be supported by all implementations. If not supported,
54
- * Fedify will invoke {@link enqueue} for each message.
55
- *
56
- * @param messages The messages to enqueue.
57
- * @param options Additional options for enqueuing the messages.
58
- */
59
- enqueueMany?: (messages: any[], options?: MessageQueueEnqueueOptions) => Promise<void>;
60
- /**
61
- * Listens for messages in the queue.
62
- * @param handler The handler for messages in the queue.
63
- * @param options Additional options for listening to the message queue.
64
- * @returns A promise that resolves when the listening is done. It never
65
- * rejects, and is resolved when the signal is aborted. If no
66
- * signal is provided, it never resolves.
67
- */
68
- listen(handler: (message: any) => Promise<void> | void, options?: MessageQueueListenOptions): Promise<void>;
69
- }
70
- /**
71
- * Additional options for {@link InProcessMessageQueue}.
72
- * @since 1.0.0
73
- */
74
- interface InProcessMessageQueueOptions {
75
- /**
76
- * The interval to poll for messages in the queue. 5 seconds by default.
77
- * @default `{ seconds: 5 }`
78
- */
79
- pollInterval?: Temporal.Duration | Temporal.DurationLike;
80
- }
81
- /**
82
- * A message queue that processes messages in the same process.
83
- * Do not use this in production as it does neither persist messages nor
84
- * distribute them across multiple processes.
85
- *
86
- * @since 0.5.0
87
- */
88
- declare class InProcessMessageQueue implements MessageQueue {
89
- #private;
90
- /**
91
- * In-process message queue does not provide native retry mechanisms.
92
- * @since 1.7.0
93
- */
94
- readonly nativeRetrial = false;
95
- /**
96
- * Constructs a new {@link InProcessMessageQueue} with the given options.
97
- * @param options Additional options for the in-process message queue.
98
- */
99
- constructor(options?: InProcessMessageQueueOptions);
100
- enqueue(message: any, options?: MessageQueueEnqueueOptions): Promise<void>;
101
- enqueueMany(messages: any[], options?: MessageQueueEnqueueOptions): Promise<void>;
102
- listen(handler: (message: any) => Promise<void> | void, options?: MessageQueueListenOptions): Promise<void>;
103
- }
104
- /**
105
- * A message queue that processes messages in parallel. It takes another
106
- * {@link MessageQueue}, and processes messages in parallel up to a certain
107
- * number of workers.
108
- *
109
- * Actually, it's rather a decorator than a queue itself.
110
- *
111
- * Note that the workers do not run in truly parallel, in the sense that they
112
- * are not running in separate threads or processes. They are running in the
113
- * same process, but are scheduled to run in parallel. Hence, this is useful
114
- * for I/O-bound tasks, but not for CPU-bound tasks, which is okay for Fedify's
115
- * workloads.
116
- *
117
- * @since 1.0.0
118
- */
119
- declare class ParallelMessageQueue implements MessageQueue {
120
- #private;
121
- readonly queue: MessageQueue;
122
- readonly workers: number;
123
- /**
124
- * Inherits the native retry capability from the wrapped queue.
125
- * @since 1.7.0
126
- */
127
- readonly nativeRetrial?: boolean;
128
- /**
129
- * Constructs a new {@link ParallelMessageQueue} with the given queue and
130
- * number of workers.
131
- * @param queue The message queue to use under the hood. Note that
132
- * {@link ParallelMessageQueue} cannot be nested.
133
- * @param workers The number of workers to process messages in parallel.
134
- * @throws {TypeError} If the given queue is an instance of
135
- * {@link ParallelMessageQueue}.
136
- */
137
- constructor(queue: MessageQueue, workers: number);
138
- enqueue(message: any, options?: MessageQueueEnqueueOptions): Promise<void>;
139
- enqueueMany(messages: any[], options?: MessageQueueEnqueueOptions): Promise<void>;
140
- listen(handler: (message: any) => Promise<void> | void, options?: MessageQueueListenOptions): Promise<void>;
141
- }
142
- //#endregion
143
- export { InProcessMessageQueue, InProcessMessageQueueOptions, MessageQueue, MessageQueueEnqueueOptions, MessageQueueListenOptions, ParallelMessageQueue };