@fedify/fedify 2.0.0-dev.1690 → 2.0.0-dev.170
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.
- package/LICENSE +1 -1
- package/README.md +70 -34
- package/dist/{assert_rejects-DiIiJbZn.js → assert_rejects-Ce45JcFg.js} +1 -1
- package/dist/{assert_is_error-BPGph1Jx.js → assert_throws-BNXdRGWP.js} +31 -1
- package/dist/{builder-CYOcDUkj.js → builder-_MVsWtsS.js} +9 -8
- package/dist/{client-bgSdkFa2.d.ts → client-CUTUGgvJ.d.ts} +19 -19
- package/dist/{client-CnOdwLLN.js → client-Dg7OfUDA.js} +28 -23
- package/dist/{client-CegPX0Rn.d.cts → client-by-PEGAJ.d.cts} +19 -19
- package/dist/compat/mod.cjs +1 -1
- package/dist/compat/mod.d.cts +6 -12
- package/dist/compat/mod.d.ts +6 -12
- package/dist/compat/mod.js +1 -1
- package/dist/compat/transformers.test.js +19 -18
- package/dist/context-Bns6uTJq.js +109 -0
- package/dist/{context-ByZprN0S.d.ts → context-C7vzWilY.d.ts} +314 -182
- package/dist/{context-C5BsZkDr.d.cts → context-CrB9RFy5.d.cts} +314 -182
- package/dist/deno-DhWON59o.js +117 -0
- package/dist/{testing-BWNCAbL-.js → dist-B5f6a8Tt.js} +90 -111
- package/dist/{authdocloader-Brax1A32.js → docloader-Cni79dmb.js} +17 -8
- package/dist/{esm-DnIzfEj0.js → esm-DGl7uK1r.js} +32 -17
- package/dist/federation/builder.test.js +11 -11
- package/dist/federation/collection.test.js +5 -8
- package/dist/federation/handler.test.js +111 -24
- package/dist/federation/idempotency.test.js +24 -24
- package/dist/federation/inbox.test.js +5 -6
- package/dist/federation/keycache.test.js +4 -5
- package/dist/federation/kv.test.js +60 -9
- package/dist/federation/middleware.test.js +102 -101
- package/dist/federation/mod.cjs +8 -12
- package/dist/federation/mod.d.cts +7 -13
- package/dist/federation/mod.d.ts +7 -13
- package/dist/federation/mod.js +8 -13
- package/dist/federation/mq.test.js +9 -10
- package/dist/federation/negotiation.test.js +5 -8
- package/dist/federation/retry.test.js +2 -4
- package/dist/federation/router.test.js +6 -8
- package/dist/federation/send.test.js +55 -15
- package/dist/{webfinger/handler.test.js → federation/webfinger.test.js} +25 -24
- package/dist/{federation-H2_En3j5.cjs → federation-B431K2gm.cjs} +22 -0
- package/dist/{federation-D1U8YY9t.js → federation-BbZwNNWj.js} +28 -6
- package/dist/{http-C7vbQwbz.cjs → http-7RQPvAkX.cjs} +410 -14
- package/dist/{http-BxbM8sEy.js → http-CZXlv4xU.js} +371 -11
- package/dist/{http-D-e6AFwR.d.cts → http-ClB3pLcL.d.cts} +2 -2
- package/dist/{http-BNOYnVsU.js → http-CwsBL5_A.js} +3 -2
- package/dist/{http-D6Uj2x2y.d.ts → http-DLBDPal9.d.ts} +2 -2
- package/dist/{inbox-BRru9pX3.js → inbox-CukSCwad.js} +2 -1
- package/dist/{key-1KXru8Ug.js → key-DKkHKzvg.js} +3 -2
- package/dist/{keycache-CN61iGVj.js → keycache-DRxpZ5r9.js} +1 -1
- package/dist/{keys-BPdFKgiy.js → keys-ZbcByPg9.js} +2 -1
- package/dist/{kv-63Cil1MD.d.cts → kv-B4vFhIYL.d.cts} +30 -1
- package/dist/{kv-C7sopW2E.d.ts → kv-CYySNrsn.d.ts} +30 -1
- package/dist/{kv-CRZrzyXm.js → kv-QzKcOQgP.js} +22 -0
- package/dist/kv-cache-BEeqyGER.js +107 -0
- package/dist/kv-cache-BVA7CrnS.cjs +134 -0
- package/dist/kv-cache-HDuc4ZaJ.js +122 -0
- package/dist/{ld-Dv8DNNAT.js → ld-CM6OO5ar.js} +4 -2
- package/dist/middleware--i9t8nKh.js +26 -0
- package/dist/middleware-C567nJlD.cjs +12 -0
- package/dist/middleware-D9oWuacw.js +12 -0
- package/dist/{middleware-DY9B2lL8.js → middleware-DXRcwk_y.js} +185 -192
- package/dist/{middleware-BmoOlgc1.cjs → middleware-TufpQUzj.cjs} +251 -241
- package/dist/{middleware-Bz_A2jeJ.js → middleware-eDeNdyRA.js} +195 -191
- package/dist/mod-0p9zUdzg.d.cts +107 -0
- package/dist/mod-0qnPv4EC.d.cts +62 -0
- package/dist/{mod-Djzcw2ry.d.cts → mod-BrS8tiad.d.cts} +3 -3
- package/dist/mod-C3SOvTD1.d.ts +64 -0
- package/dist/{mod-8DMWKtQE.d.cts → mod-D6pS5_xJ.d.cts} +4 -4
- package/dist/{mod-BhUKmBJD.d.ts → mod-jOa7W503.d.ts} +3 -3
- package/dist/{mod-D6hQoxC5.d.ts → mod-waqu-BL_.d.ts} +4 -4
- package/dist/mod-xc20HhMD.d.ts +109 -0
- package/dist/mod.cjs +17 -112
- package/dist/mod.d.cts +11 -17
- package/dist/mod.d.ts +11 -17
- package/dist/mod.js +11 -17
- package/dist/nodeinfo/client.test.js +7 -10
- package/dist/nodeinfo/handler.test.js +23 -23
- package/dist/nodeinfo/mod.cjs +2 -3
- package/dist/nodeinfo/mod.d.cts +2 -4
- package/dist/nodeinfo/mod.d.ts +2 -4
- package/dist/nodeinfo/mod.js +2 -3
- package/dist/nodeinfo/types.test.js +6 -9
- package/dist/otel/exporter.test.js +893 -0
- package/dist/otel/mod.cjs +256 -0
- package/dist/otel/mod.d.cts +230 -0
- package/dist/otel/mod.d.ts +232 -0
- package/dist/otel/mod.js +255 -0
- package/dist/{owner-e3FYDhsk.js → owner-BOEfZQv2.js} +45 -8
- package/dist/{owner-hd9lvQcP.d.ts → owner-BgI8C-VY.d.ts} +2 -3
- package/dist/{owner-BN_tO3cY.d.cts → owner-C-zfmVAD.d.cts} +2 -3
- package/dist/{proof-B-eqv0Ug.cjs → proof-CaDQpGJD.cjs} +69 -33
- package/dist/{proof-DfgvA3al.js → proof-iYIDiv8I.js} +47 -11
- package/dist/{proof-6gFMwMNJ.js → proof-iw6KtIyj.js} +3 -2
- package/dist/router-D9eI0s4b.js +118 -0
- package/dist/{send-Tl9NOnmO.js → send-Bn8o0mjW.js} +9 -4
- package/dist/sig/http.test.js +11 -13
- package/dist/sig/key.test.js +9 -11
- package/dist/sig/ld.test.js +8 -10
- package/dist/sig/mod.cjs +7 -11
- package/dist/sig/mod.d.cts +3 -7
- package/dist/sig/mod.d.ts +3 -7
- package/dist/sig/mod.js +3 -7
- package/dist/sig/owner.test.js +33 -12
- package/dist/sig/proof.test.js +13 -14
- package/dist/testing/mod.d.ts +183 -7194
- package/dist/testing/mod.js +4 -4
- package/dist/{transformers-CoBS-oFG.cjs → transformers-BjBg6Lag.cjs} +2 -2
- package/dist/{transformers-BFT6d7J5.js → transformers-N_ip_y4P.js} +2 -2
- package/dist/{types-DqxyTxOf.js → types-8l28uC8o.js} +31 -26
- package/dist/{types-zqdWZh4O.cjs → types-B6z6CqIz.cjs} +33 -28
- package/dist/{types-BSuWJsOm.js → types-CPz01LGH.js} +3 -3
- package/dist/{runtime/authdocloader.test.js → utils/docloader.test.js} +13 -15
- package/dist/utils/kv-cache.test.js +211 -0
- package/dist/utils/mod.cjs +10 -0
- package/dist/utils/mod.d.cts +4 -0
- package/dist/utils/mod.d.ts +6 -0
- package/dist/utils/mod.js +9 -0
- package/package.json +34 -75
- package/dist/actor-Be0ThtXy.cjs +0 -42609
- package/dist/actor-ChbPLm6n.js +0 -42135
- package/dist/actor-D6K058Tb.d.cts +0 -128
- package/dist/actor-DuCeRiNh.js +0 -146
- package/dist/actor-T6RyhRgk.d.ts +0 -130
- package/dist/assert_throws-BOO88avQ.js +0 -39
- package/dist/authdocloader-CrxhFL8e.js +0 -52
- package/dist/authdocloader-OSn_teLV.cjs +0 -58
- package/dist/denokv-Bv33Xxea.js +0 -57
- package/dist/docloader-CCqXeagZ.cjs +0 -4861
- package/dist/docloader-CxWcuWqQ.d.ts +0 -221
- package/dist/docloader-D-MrRyHl.d.cts +0 -219
- package/dist/docloader-XK3y2jn5.js +0 -4795
- package/dist/fixtures/activitypub.academy/users/brauca_darradiul.json +0 -83
- package/dist/fixtures/example.com/announce.json +0 -6
- package/dist/fixtures/example.com/collection.json +0 -19
- package/dist/fixtures/example.com/create.json +0 -6
- package/dist/fixtures/example.com/cross-origin-actor.json +0 -6
- package/dist/fixtures/example.com/hong-gildong.json +0 -11
- package/dist/fixtures/example.com/invite.json +0 -7
- package/dist/fixtures/example.com/key.json +0 -7
- package/dist/fixtures/example.com/key2.json +0 -6
- package/dist/fixtures/example.com/object.json +0 -6
- package/dist/fixtures/example.com/orderedcollectionpage.json +0 -24
- package/dist/fixtures/example.com/paged/a.json +0 -13
- package/dist/fixtures/example.com/paged/b.json +0 -16
- package/dist/fixtures/example.com/paged-collection.json +0 -6
- package/dist/fixtures/example.com/person.json +0 -22
- package/dist/fixtures/example.com/person2.json +0 -40
- package/dist/fixtures/example.com/test.json +0 -5
- package/dist/fixtures/example.com/users/handle.json +0 -16
- package/dist/fixtures/example.com/wrong-type.json +0 -3
- package/dist/fixtures/media.example.com/avatars/test-avatar.jpg.json +0 -6
- package/dist/fixtures/oeee.cafe/ap/users/3609fd4e-d51d-4db8-9f04-4189815864dd.json +0 -24
- package/dist/fixtures/remote.domain/users/bob.json +0 -20
- package/dist/fixtures/server.example/users/alice.json +0 -20
- package/dist/fixtures/w3id.org/identity/v1.json +0 -152
- package/dist/fixtures/w3id.org/security/data-integrity/v1.json +0 -74
- package/dist/fixtures/w3id.org/security/multikey/v1.json +0 -35
- package/dist/fixtures/w3id.org/security/v1.json +0 -50
- package/dist/fixtures/wizard.casa/users/hongminhee.json +0 -69
- package/dist/fixtures/www.w3.org/ns/activitystreams.json +0 -379
- package/dist/fixtures/www.w3.org/ns/did/v1.json +0 -58
- package/dist/key-B3uag-rz.js +0 -10
- package/dist/key-BiBmb1Yy.cjs +0 -10
- package/dist/key-DK_nfU4I.js +0 -10
- package/dist/key-Z6ceKnZC.cjs +0 -290
- package/dist/key-jyNTxCvK.js +0 -260
- package/dist/lookup-BPviO8ij.js +0 -131
- package/dist/lookup-hnMAAU5r.cjs +0 -137
- package/dist/lookup-pV0JOsuV.js +0 -331
- package/dist/middleware-CI0-zw4U.js +0 -26
- package/dist/middleware-QNK-W-jE.cjs +0 -17
- package/dist/middleware-_vjt6FWU.js +0 -17
- package/dist/mod-CerN_Sza.d.ts +0 -104
- package/dist/mod-Cj1tHXBR.d.cts +0 -102
- package/dist/mod-CxkWO3Mg.d.cts +0 -307
- package/dist/mod-DBzN0aCM.d.ts +0 -115
- package/dist/mod-DlU8ISoa.d.ts +0 -309
- package/dist/mod-FZd39qVq.d.cts +0 -1
- package/dist/mod-g0xFzAP9.d.ts +0 -2
- package/dist/mod-jQ4OODsl.d.cts +0 -113
- package/dist/mq-B7R1Q-M5.d.cts +0 -140
- package/dist/mq-CRGm1e_F.d.ts +0 -143
- package/dist/runtime/docloader.test.js +0 -522
- package/dist/runtime/key.test.js +0 -103
- package/dist/runtime/langstr.test.d.ts +0 -3
- package/dist/runtime/langstr.test.js +0 -39
- package/dist/runtime/link.test.d.ts +0 -3
- package/dist/runtime/link.test.js +0 -61
- package/dist/runtime/mod.cjs +0 -25
- package/dist/runtime/mod.d.cts +0 -6
- package/dist/runtime/mod.d.ts +0 -8
- package/dist/runtime/mod.js +0 -13
- package/dist/runtime/multibase/multibase.test.d.ts +0 -3
- package/dist/runtime/multibase/multibase.test.js +0 -358
- package/dist/runtime/url.test.d.ts +0 -3
- package/dist/runtime/url.test.js +0 -45
- package/dist/src/vocab/accept.yaml +0 -15
- package/dist/src/vocab/activity.yaml +0 -98
- package/dist/src/vocab/add.yaml +0 -16
- package/dist/src/vocab/announce.yaml +0 -30
- package/dist/src/vocab/application.yaml +0 -324
- package/dist/src/vocab/arrive.yaml +0 -15
- package/dist/src/vocab/article.yaml +0 -46
- package/dist/src/vocab/audio.yaml +0 -11
- package/dist/src/vocab/block.yaml +0 -16
- package/dist/src/vocab/chatmessage.yaml +0 -50
- package/dist/src/vocab/collection.yaml +0 -154
- package/dist/src/vocab/collectionpage.yaml +0 -55
- package/dist/src/vocab/create.yaml +0 -28
- package/dist/src/vocab/dataintegrityproof.yaml +0 -56
- package/dist/src/vocab/delete.yaml +0 -27
- package/dist/src/vocab/didservice.yaml +0 -22
- package/dist/src/vocab/dislike.yaml +0 -14
- package/dist/src/vocab/document.yaml +0 -31
- package/dist/src/vocab/emoji.yaml +0 -12
- package/dist/src/vocab/emojireact.yaml +0 -17
- package/dist/src/vocab/endpoints.yaml +0 -85
- package/dist/src/vocab/event.yaml +0 -11
- package/dist/src/vocab/export.yaml +0 -9
- package/dist/src/vocab/flag.yaml +0 -15
- package/dist/src/vocab/follow.yaml +0 -19
- package/dist/src/vocab/group.yaml +0 -324
- package/dist/src/vocab/hashtag.yaml +0 -14
- package/dist/src/vocab/ignore.yaml +0 -14
- package/dist/src/vocab/image.yaml +0 -9
- package/dist/src/vocab/intransitiveactivity.yaml +0 -15
- package/dist/src/vocab/invite.yaml +0 -14
- package/dist/src/vocab/join.yaml +0 -14
- package/dist/src/vocab/key.yaml +0 -28
- package/dist/src/vocab/leave.yaml +0 -14
- package/dist/src/vocab/like.yaml +0 -16
- package/dist/src/vocab/link.yaml +0 -101
- package/dist/src/vocab/listen.yaml +0 -12
- package/dist/src/vocab/mention.yaml +0 -9
- package/dist/src/vocab/move.yaml +0 -15
- package/dist/src/vocab/multikey.yaml +0 -36
- package/dist/src/vocab/note.yaml +0 -48
- package/dist/src/vocab/object.yaml +0 -404
- package/dist/src/vocab/offer.yaml +0 -15
- package/dist/src/vocab/orderedcollection.yaml +0 -39
- package/dist/src/vocab/orderedcollectionpage.yaml +0 -50
- package/dist/src/vocab/organization.yaml +0 -324
- package/dist/src/vocab/page.yaml +0 -11
- package/dist/src/vocab/person.yaml +0 -324
- package/dist/src/vocab/place.yaml +0 -75
- package/dist/src/vocab/profile.yaml +0 -26
- package/dist/src/vocab/propertyvalue.yaml +0 -32
- package/dist/src/vocab/question.yaml +0 -103
- package/dist/src/vocab/read.yaml +0 -13
- package/dist/src/vocab/reject.yaml +0 -14
- package/dist/src/vocab/relationship.yaml +0 -52
- package/dist/src/vocab/remove.yaml +0 -14
- package/dist/src/vocab/service.yaml +0 -324
- package/dist/src/vocab/source.yaml +0 -26
- package/dist/src/vocab/tentativeaccept.yaml +0 -14
- package/dist/src/vocab/tentativereject.yaml +0 -14
- package/dist/src/vocab/tombstone.yaml +0 -24
- package/dist/src/vocab/travel.yaml +0 -16
- package/dist/src/vocab/undo.yaml +0 -26
- package/dist/src/vocab/update.yaml +0 -58
- package/dist/src/vocab/video.yaml +0 -11
- package/dist/src/vocab/view.yaml +0 -13
- package/dist/testing/docloader.test.js +0 -24
- package/dist/type-C69ZBu7f.js +0 -47010
- package/dist/vocab/actor.test.d.ts +0 -3
- package/dist/vocab/actor.test.js +0 -5965
- package/dist/vocab/lookup.test.d.ts +0 -3
- package/dist/vocab/lookup.test.js +0 -456
- package/dist/vocab/mod.cjs +0 -87
- package/dist/vocab/mod.d.cts +0 -6
- package/dist/vocab/mod.d.ts +0 -8
- package/dist/vocab/mod.js +0 -10
- package/dist/vocab/schema.yaml +0 -247
- package/dist/vocab/type.test.d.ts +0 -3
- package/dist/vocab/type.test.js +0 -25
- package/dist/vocab/vocab.test.d.ts +0 -3
- package/dist/vocab/vocab.test.js +0 -3787
- package/dist/vocab-B39-pFl9.cjs +0 -291
- package/dist/vocab-BI0Ak5lL.d.ts +0 -14924
- package/dist/vocab-BWoeZsME.js +0 -255
- package/dist/vocab-Dw1-yVGg.d.cts +0 -14922
- package/dist/webfinger/handler.test.d.ts +0 -3
- package/dist/webfinger/lookup.test.d.ts +0 -3
- package/dist/webfinger/lookup.test.js +0 -195
- package/dist/webfinger/mod.cjs +0 -9
- package/dist/webfinger/mod.d.cts +0 -4
- package/dist/webfinger/mod.d.ts +0 -6
- package/dist/webfinger/mod.js +0 -9
- package/dist/webfinger-BjOEdFPs.cjs +0 -4
- package/dist/webfinger-De_bU0iE.js +0 -4
- package/dist/x/cfworkers.cjs +0 -100
- package/dist/x/cfworkers.d.cts +0 -59
- package/dist/x/cfworkers.d.ts +0 -61
- package/dist/x/cfworkers.js +0 -98
- package/dist/x/cfworkers.test.d.ts +0 -3
- package/dist/x/cfworkers.test.js +0 -179
- package/dist/x/hono.cjs +0 -61
- package/dist/x/hono.d.cts +0 -54
- package/dist/x/hono.d.ts +0 -56
- package/dist/x/hono.js +0 -60
- package/dist/x/sveltekit.cjs +0 -69
- package/dist/x/sveltekit.d.cts +0 -46
- package/dist/x/sveltekit.d.ts +0 -48
- package/dist/x/sveltekit.js +0 -68
- /package/dist/{assert_not_equals-f3m3epl3.js → assert_not_equals-C80BG-_5.js} +0 -0
- /package/dist/{runtime/authdocloader.test.d.ts → federation/webfinger.test.d.ts} +0 -0
- /package/dist/{mod-1pDWKvUL.d.ts → mod-1E3W847c.d.ts} +0 -0
- /package/dist/{mod-C2tOeRkN.d.cts → mod-C81L6_lQ.d.cts} +0 -0
- /package/dist/{nodeinfo-DfycQ8Wf.js → nodeinfo-BlLsRSiT.js} +0 -0
- /package/dist/{nodeinfo-Co9lJrWl.cjs → nodeinfo-DuMYTpbZ.cjs} +0 -0
- /package/dist/{runtime/docloader.test.d.ts → otel/exporter.test.d.ts} +0 -0
- /package/dist/{runtime-DPYEDf-o.js → sig-CwuONEzF.js} +0 -0
- /package/dist/{runtime-C58AJWSv.cjs → sig-DeXX2xnj.cjs} +0 -0
- /package/dist/{std__assert-X-_kMxKM.js → std__assert-DWivtrGR.js} +0 -0
- /package/dist/{testing → utils}/docloader.test.d.ts +0 -0
- /package/dist/{runtime/key.test.d.ts → utils/kv-cache.test.d.ts} +0 -0
- /package/dist/{sig-ByHXzqUi.cjs → utils-Db0ZmjcD.cjs} +0 -0
- /package/dist/{sig-Cj3tk-ig.js → utils-Wranxuoe.js} +0 -0
|
@@ -1,195 +0,0 @@
|
|
|
1
|
-
|
|
2
|
-
import { Temporal } from "@js-temporal/polyfill";
|
|
3
|
-
import { URLPattern } from "urlpattern-polyfill";
|
|
4
|
-
globalThis.addEventListener = () => {};
|
|
5
|
-
|
|
6
|
-
import { lookupWebFinger } from "../type-C69ZBu7f.js";
|
|
7
|
-
import { assertEquals } from "../assert_equals-DSbWqCm3.js";
|
|
8
|
-
import "../assert-MZs1qjMx.js";
|
|
9
|
-
import "../assert_instance_of-DHz7EHNU.js";
|
|
10
|
-
import "../lookup-pV0JOsuV.js";
|
|
11
|
-
import { test } from "../testing-BWNCAbL-.js";
|
|
12
|
-
import "../std__assert-X-_kMxKM.js";
|
|
13
|
-
import "../assert_rejects-DiIiJbZn.js";
|
|
14
|
-
import "../assert_is_error-BPGph1Jx.js";
|
|
15
|
-
import "../assert_not_equals-f3m3epl3.js";
|
|
16
|
-
import "../assert_throws-BOO88avQ.js";
|
|
17
|
-
import { esm_default } from "../esm-DnIzfEj0.js";
|
|
18
|
-
import { withTimeout } from "es-toolkit";
|
|
19
|
-
|
|
20
|
-
//#region src/webfinger/lookup.test.ts
|
|
21
|
-
test({
|
|
22
|
-
name: "lookupWebFinger()",
|
|
23
|
-
sanitizeOps: false,
|
|
24
|
-
sanitizeResources: false,
|
|
25
|
-
async fn(t) {
|
|
26
|
-
await t.step("invalid resource", async () => {
|
|
27
|
-
assertEquals(await lookupWebFinger("acct:johndoe"), null);
|
|
28
|
-
assertEquals(await lookupWebFinger(new URL("acct:johndoe")), null);
|
|
29
|
-
assertEquals(await lookupWebFinger("acct:johndoe@"), null);
|
|
30
|
-
assertEquals(await lookupWebFinger(new URL("acct:johndoe@")), null);
|
|
31
|
-
});
|
|
32
|
-
await t.step("connection refused", async () => {
|
|
33
|
-
assertEquals(await lookupWebFinger("acct:johndoe@fedify-test.internal"), null);
|
|
34
|
-
assertEquals(await lookupWebFinger("https://fedify-test.internal/foo"), null);
|
|
35
|
-
});
|
|
36
|
-
esm_default.spyGlobal();
|
|
37
|
-
esm_default.get("begin:https://example.com/.well-known/webfinger?", { status: 404 });
|
|
38
|
-
await t.step("not found", async () => {
|
|
39
|
-
assertEquals(await lookupWebFinger("acct:johndoe@example.com"), null);
|
|
40
|
-
assertEquals(await lookupWebFinger("https://example.com/foo"), null);
|
|
41
|
-
});
|
|
42
|
-
const expected = {
|
|
43
|
-
subject: "acct:johndoe@example.com",
|
|
44
|
-
links: []
|
|
45
|
-
};
|
|
46
|
-
esm_default.removeRoutes();
|
|
47
|
-
esm_default.get("https://example.com/.well-known/webfinger?resource=acct%3Ajohndoe%40example.com", { body: expected });
|
|
48
|
-
await t.step("acct", async () => {
|
|
49
|
-
assertEquals(await lookupWebFinger("acct:johndoe@example.com"), expected);
|
|
50
|
-
});
|
|
51
|
-
const expected2 = {
|
|
52
|
-
subject: "https://example.com/foo",
|
|
53
|
-
links: []
|
|
54
|
-
};
|
|
55
|
-
esm_default.removeRoutes();
|
|
56
|
-
esm_default.get("https://example.com/.well-known/webfinger?resource=https%3A%2F%2Fexample.com%2Ffoo", { body: expected2 });
|
|
57
|
-
await t.step("https", async () => {
|
|
58
|
-
assertEquals(await lookupWebFinger("https://example.com/foo"), expected2);
|
|
59
|
-
});
|
|
60
|
-
esm_default.removeRoutes();
|
|
61
|
-
esm_default.get("begin:https://example.com/.well-known/webfinger?", { body: "not json" });
|
|
62
|
-
await t.step("invalid response", async () => {
|
|
63
|
-
assertEquals(await lookupWebFinger("acct:johndoe@example.com"), null);
|
|
64
|
-
});
|
|
65
|
-
esm_default.removeRoutes();
|
|
66
|
-
esm_default.get("begin:https://localhost/.well-known/webfinger?", {
|
|
67
|
-
subject: "acct:test@localhost",
|
|
68
|
-
links: [{
|
|
69
|
-
rel: "self",
|
|
70
|
-
type: "application/activity+json",
|
|
71
|
-
href: "https://localhost/actor"
|
|
72
|
-
}]
|
|
73
|
-
});
|
|
74
|
-
await t.step("private address", async () => {
|
|
75
|
-
assertEquals(await lookupWebFinger("acct:test@localhost"), null);
|
|
76
|
-
assertEquals(await lookupWebFinger("acct:test@localhost", { allowPrivateAddress: true }), {
|
|
77
|
-
subject: "acct:test@localhost",
|
|
78
|
-
links: [{
|
|
79
|
-
rel: "self",
|
|
80
|
-
type: "application/activity+json",
|
|
81
|
-
href: "https://localhost/actor"
|
|
82
|
-
}]
|
|
83
|
-
});
|
|
84
|
-
});
|
|
85
|
-
esm_default.removeRoutes();
|
|
86
|
-
esm_default.get("begin:https://example.com/.well-known/webfinger?", {
|
|
87
|
-
status: 302,
|
|
88
|
-
headers: { Location: "/.well-known/webfinger2" }
|
|
89
|
-
});
|
|
90
|
-
esm_default.get("begin:https://example.com/.well-known/webfinger2", { body: expected });
|
|
91
|
-
await t.step("redirection", async () => {
|
|
92
|
-
assertEquals(await lookupWebFinger("acct:johndoe@example.com"), expected);
|
|
93
|
-
});
|
|
94
|
-
esm_default.removeRoutes();
|
|
95
|
-
esm_default.get("begin:https://example.com/.well-known/webfinger?", {
|
|
96
|
-
status: 302,
|
|
97
|
-
headers: { Location: "/.well-known/webfinger" }
|
|
98
|
-
});
|
|
99
|
-
await t.step("infinite redirection", async () => {
|
|
100
|
-
const result = await withTimeout(() => lookupWebFinger("acct:johndoe@example.com"), 2e3);
|
|
101
|
-
assertEquals(result, null);
|
|
102
|
-
});
|
|
103
|
-
esm_default.removeRoutes();
|
|
104
|
-
esm_default.get("begin:https://example.com/.well-known/webfinger?", {
|
|
105
|
-
status: 302,
|
|
106
|
-
headers: { Location: "ftp://example.com/" }
|
|
107
|
-
});
|
|
108
|
-
await t.step("redirection to different protocol", async () => {
|
|
109
|
-
assertEquals(await lookupWebFinger("acct:johndoe@example.com"), null);
|
|
110
|
-
});
|
|
111
|
-
esm_default.removeRoutes();
|
|
112
|
-
esm_default.get("begin:https://example.com/.well-known/webfinger?", {
|
|
113
|
-
status: 302,
|
|
114
|
-
headers: { Location: "https://localhost/" }
|
|
115
|
-
});
|
|
116
|
-
await t.step("redirection to private address", async () => {
|
|
117
|
-
assertEquals(await lookupWebFinger("acct:johndoe@example.com"), null);
|
|
118
|
-
});
|
|
119
|
-
esm_default.removeRoutes();
|
|
120
|
-
let redirectCount = 0;
|
|
121
|
-
esm_default.get("begin:https://example.com/.well-known/webfinger", () => {
|
|
122
|
-
redirectCount++;
|
|
123
|
-
if (redirectCount < 3) return {
|
|
124
|
-
status: 302,
|
|
125
|
-
headers: { Location: `/.well-known/webfinger?redirect=${redirectCount}` }
|
|
126
|
-
};
|
|
127
|
-
return { body: expected };
|
|
128
|
-
});
|
|
129
|
-
await t.step("custom maxRedirection", async () => {
|
|
130
|
-
redirectCount = 0;
|
|
131
|
-
assertEquals(await lookupWebFinger("acct:johndoe@example.com", { maxRedirection: 2 }), null);
|
|
132
|
-
redirectCount = 0;
|
|
133
|
-
assertEquals(await lookupWebFinger("acct:johndoe@example.com", { maxRedirection: 3 }), expected);
|
|
134
|
-
redirectCount = 0;
|
|
135
|
-
assertEquals(await lookupWebFinger("acct:johndoe@example.com"), expected);
|
|
136
|
-
});
|
|
137
|
-
esm_default.removeRoutes();
|
|
138
|
-
esm_default.get("begin:https://example.com/.well-known/webfinger?", () => new Promise((resolve) => {
|
|
139
|
-
const timeoutId = setTimeout(() => {
|
|
140
|
-
resolve({ body: expected });
|
|
141
|
-
}, 1e3);
|
|
142
|
-
return () => clearTimeout(timeoutId);
|
|
143
|
-
}));
|
|
144
|
-
await t.step("request cancellation", async () => {
|
|
145
|
-
const controller = new AbortController();
|
|
146
|
-
const promise = lookupWebFinger("acct:johndoe@example.com", { signal: controller.signal });
|
|
147
|
-
controller.abort();
|
|
148
|
-
assertEquals(await promise, null);
|
|
149
|
-
});
|
|
150
|
-
esm_default.removeRoutes();
|
|
151
|
-
let redirectCount2 = 0;
|
|
152
|
-
esm_default.get("begin:https://example.com/.well-known/webfinger", () => {
|
|
153
|
-
redirectCount2++;
|
|
154
|
-
if (redirectCount2 === 1) return {
|
|
155
|
-
status: 302,
|
|
156
|
-
headers: { Location: "/.well-known/webfinger2" }
|
|
157
|
-
};
|
|
158
|
-
return new Promise((resolve) => {
|
|
159
|
-
const timeoutId = setTimeout(() => {
|
|
160
|
-
resolve({ body: expected });
|
|
161
|
-
}, 1e3);
|
|
162
|
-
return () => clearTimeout(timeoutId);
|
|
163
|
-
});
|
|
164
|
-
});
|
|
165
|
-
await t.step("cancellation during redirection", async () => {
|
|
166
|
-
const controller = new AbortController();
|
|
167
|
-
const promise = lookupWebFinger("acct:johndoe@example.com", { signal: controller.signal });
|
|
168
|
-
setTimeout(() => controller.abort(), 100);
|
|
169
|
-
assertEquals(await promise, null);
|
|
170
|
-
});
|
|
171
|
-
esm_default.removeRoutes();
|
|
172
|
-
esm_default.get("begin:https://example.com/.well-known/webfinger?", () => new Promise((resolve) => {
|
|
173
|
-
const timeoutId = setTimeout(() => {
|
|
174
|
-
resolve({ body: expected });
|
|
175
|
-
}, 500);
|
|
176
|
-
return () => clearTimeout(timeoutId);
|
|
177
|
-
}));
|
|
178
|
-
await t.step("cancellation with immediate abort", async () => {
|
|
179
|
-
const controller = new AbortController();
|
|
180
|
-
controller.abort();
|
|
181
|
-
const result = await lookupWebFinger("acct:johndoe@example.com", { signal: controller.signal });
|
|
182
|
-
assertEquals(result, null);
|
|
183
|
-
});
|
|
184
|
-
esm_default.removeRoutes();
|
|
185
|
-
esm_default.get("begin:https://example.com/.well-known/webfinger?", { body: expected });
|
|
186
|
-
await t.step("successful request with signal", async () => {
|
|
187
|
-
const controller = new AbortController();
|
|
188
|
-
const result = await lookupWebFinger("acct:johndoe@example.com", { signal: controller.signal });
|
|
189
|
-
assertEquals(result, expected);
|
|
190
|
-
});
|
|
191
|
-
esm_default.hardReset();
|
|
192
|
-
}
|
|
193
|
-
});
|
|
194
|
-
|
|
195
|
-
//#endregion
|
package/dist/webfinger/mod.cjs
DELETED
|
@@ -1,9 +0,0 @@
|
|
|
1
|
-
|
|
2
|
-
const { Temporal } = require("@js-temporal/polyfill");
|
|
3
|
-
const { URLPattern } = require("urlpattern-polyfill");
|
|
4
|
-
|
|
5
|
-
require('../docloader-CCqXeagZ.cjs');
|
|
6
|
-
const require_lookup = require('../lookup-hnMAAU5r.cjs');
|
|
7
|
-
require('../webfinger-BjOEdFPs.cjs');
|
|
8
|
-
|
|
9
|
-
exports.lookupWebFinger = require_lookup.lookupWebFinger;
|
package/dist/webfinger/mod.d.cts
DELETED
package/dist/webfinger/mod.d.ts
DELETED
|
@@ -1,6 +0,0 @@
|
|
|
1
|
-
import { Temporal } from "@js-temporal/polyfill";
|
|
2
|
-
import { URLPattern } from "urlpattern-polyfill";
|
|
3
|
-
import "../kv-C7sopW2E.js";
|
|
4
|
-
import "../docloader-CxWcuWqQ.js";
|
|
5
|
-
import { Link, LookupWebFingerOptions, ResourceDescriptor, lookupWebFinger } from "../mod-DBzN0aCM.js";
|
|
6
|
-
export { Link, LookupWebFingerOptions, ResourceDescriptor, lookupWebFinger };
|
package/dist/webfinger/mod.js
DELETED
|
@@ -1,9 +0,0 @@
|
|
|
1
|
-
|
|
2
|
-
import { Temporal } from "@js-temporal/polyfill";
|
|
3
|
-
import { URLPattern } from "urlpattern-polyfill";
|
|
4
|
-
|
|
5
|
-
import "../docloader-XK3y2jn5.js";
|
|
6
|
-
import { lookupWebFinger } from "../lookup-BPviO8ij.js";
|
|
7
|
-
import "../webfinger-De_bU0iE.js";
|
|
8
|
-
|
|
9
|
-
export { lookupWebFinger };
|
package/dist/x/cfworkers.cjs
DELETED
|
@@ -1,100 +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 __logtape_logtape = require_chunk.__toESM(require("@logtape/logtape"));
|
|
7
|
-
|
|
8
|
-
//#region src/x/cfworkers.ts
|
|
9
|
-
/**
|
|
10
|
-
* Implementation of the {@link KvStore} interface for Cloudflare Workers KV
|
|
11
|
-
* binding. This class provides a wrapper around Cloudflare's KV namespace to
|
|
12
|
-
* store and retrieve JSON-serializable values using structured keys.
|
|
13
|
-
*
|
|
14
|
-
* Note that this implementation does not support the {@link KvStore.cas}
|
|
15
|
-
* operation, as Cloudflare Workers KV does not support atomic compare-and-swap
|
|
16
|
-
* operations. If you need this functionality, consider using a different
|
|
17
|
-
* key–value store that supports atomic operations.
|
|
18
|
-
*
|
|
19
|
-
* @deprecated This class has been moved to `@fedify/cfworkers` package.
|
|
20
|
-
* Import `WorkersKvStore` from `@fedify/cfworkers` instead.
|
|
21
|
-
* This class will be removed in Fedify v2.0.
|
|
22
|
-
* @since 1.6.0
|
|
23
|
-
*/
|
|
24
|
-
var WorkersKvStore = class {
|
|
25
|
-
#namespace;
|
|
26
|
-
constructor(namespace) {
|
|
27
|
-
const logger = (0, __logtape_logtape.getLogger)(["fedify", "cfworkers"]);
|
|
28
|
-
logger.warn("The `@fedify/fedify/x/cfworkers` module is deprecated; use `WorkersKvStore` from `@fedify/cfworkers` package instead.");
|
|
29
|
-
this.#namespace = namespace;
|
|
30
|
-
}
|
|
31
|
-
#encodeKey(key) {
|
|
32
|
-
return JSON.stringify(key);
|
|
33
|
-
}
|
|
34
|
-
async get(key) {
|
|
35
|
-
const encodedKey = this.#encodeKey(key);
|
|
36
|
-
const { value, metadata } = await this.#namespace.getWithMetadata(encodedKey, "json");
|
|
37
|
-
return metadata == null || metadata.expires < Date.now() ? void 0 : value;
|
|
38
|
-
}
|
|
39
|
-
async set(key, value, options) {
|
|
40
|
-
const encodedKey = this.#encodeKey(key);
|
|
41
|
-
const metadata = options?.ttl == null ? {} : { expires: Date.now() + options.ttl.total("milliseconds") };
|
|
42
|
-
await this.#namespace.put(encodedKey, JSON.stringify(value), options?.ttl == null ? { metadata } : {
|
|
43
|
-
expirationTtl: Math.max(options.ttl.total("seconds"), 60),
|
|
44
|
-
metadata
|
|
45
|
-
});
|
|
46
|
-
}
|
|
47
|
-
delete(key) {
|
|
48
|
-
return this.#namespace.delete(this.#encodeKey(key));
|
|
49
|
-
}
|
|
50
|
-
};
|
|
51
|
-
/**
|
|
52
|
-
* Implementation of the {@link MessageQueue} interface for Cloudflare
|
|
53
|
-
* Workers Queues binding. This class provides a wrapper around Cloudflare's
|
|
54
|
-
* Queues to send messages to a queue.
|
|
55
|
-
*
|
|
56
|
-
* Note that this implementation does not support the `listen()` method,
|
|
57
|
-
* as Cloudflare Workers Queues do not support message consumption in the same
|
|
58
|
-
* way as other message queue systems. Instead, you should use
|
|
59
|
-
* the {@link Federation.processQueuedTask} method to process messages
|
|
60
|
-
* passed to the queue.
|
|
61
|
-
*
|
|
62
|
-
* @deprecated This class has been moved to `@fedify/cfworkers` package.
|
|
63
|
-
* Import `WorkersMessageQueue` from `@fedify/cfworkers` instead.
|
|
64
|
-
* This class will be removed in Fedify v2.0.
|
|
65
|
-
* @since 1.6.0
|
|
66
|
-
*/
|
|
67
|
-
var WorkersMessageQueue = class {
|
|
68
|
-
#queue;
|
|
69
|
-
/**
|
|
70
|
-
* Cloudflare Queues provide automatic retry with exponential backoff
|
|
71
|
-
* and Dead Letter Queues.
|
|
72
|
-
* @since 1.7.0
|
|
73
|
-
*/
|
|
74
|
-
nativeRetrial = true;
|
|
75
|
-
constructor(queue) {
|
|
76
|
-
const logger = (0, __logtape_logtape.getLogger)(["fedify", "cfworkers"]);
|
|
77
|
-
logger.warn("The `@fedify/fedify/x/cfworkers` module is deprecated; use `WorkersMessageQueue` from `@fedify/cfworkers` package instead.");
|
|
78
|
-
this.#queue = queue;
|
|
79
|
-
}
|
|
80
|
-
enqueue(message, options) {
|
|
81
|
-
return this.#queue.send(message, {
|
|
82
|
-
contentType: "json",
|
|
83
|
-
delaySeconds: options?.delay?.total("seconds") ?? 0
|
|
84
|
-
});
|
|
85
|
-
}
|
|
86
|
-
enqueueMany(messages, options) {
|
|
87
|
-
const requests = messages.map((msg) => ({
|
|
88
|
-
body: msg,
|
|
89
|
-
contentType: "json"
|
|
90
|
-
}));
|
|
91
|
-
return this.#queue.sendBatch(requests, { delaySeconds: options?.delay?.total("seconds") ?? 0 });
|
|
92
|
-
}
|
|
93
|
-
listen(_handler, _options) {
|
|
94
|
-
throw new TypeError("WorkersMessageQueue does not support listen(). Use Federation.processQueuedTask() method instead.");
|
|
95
|
-
}
|
|
96
|
-
};
|
|
97
|
-
|
|
98
|
-
//#endregion
|
|
99
|
-
exports.WorkersKvStore = WorkersKvStore;
|
|
100
|
-
exports.WorkersMessageQueue = WorkersMessageQueue;
|
package/dist/x/cfworkers.d.cts
DELETED
|
@@ -1,59 +0,0 @@
|
|
|
1
|
-
import { KvKey, KvStore, KvStoreSetOptions } from "../kv-63Cil1MD.cjs";
|
|
2
|
-
import { MessageQueue, MessageQueueEnqueueOptions, MessageQueueListenOptions } from "../mq-B7R1Q-M5.cjs";
|
|
3
|
-
import { KVNamespace, Queue } from "@cloudflare/workers-types/experimental";
|
|
4
|
-
|
|
5
|
-
//#region src/x/cfworkers.d.ts
|
|
6
|
-
|
|
7
|
-
/**
|
|
8
|
-
* Implementation of the {@link KvStore} interface for Cloudflare Workers KV
|
|
9
|
-
* binding. This class provides a wrapper around Cloudflare's KV namespace to
|
|
10
|
-
* store and retrieve JSON-serializable values using structured keys.
|
|
11
|
-
*
|
|
12
|
-
* Note that this implementation does not support the {@link KvStore.cas}
|
|
13
|
-
* operation, as Cloudflare Workers KV does not support atomic compare-and-swap
|
|
14
|
-
* operations. If you need this functionality, consider using a different
|
|
15
|
-
* key–value store that supports atomic operations.
|
|
16
|
-
*
|
|
17
|
-
* @deprecated This class has been moved to `@fedify/cfworkers` package.
|
|
18
|
-
* Import `WorkersKvStore` from `@fedify/cfworkers` instead.
|
|
19
|
-
* This class will be removed in Fedify v2.0.
|
|
20
|
-
* @since 1.6.0
|
|
21
|
-
*/
|
|
22
|
-
declare class WorkersKvStore implements KvStore {
|
|
23
|
-
#private;
|
|
24
|
-
constructor(namespace: KVNamespace<string>);
|
|
25
|
-
get<T = unknown>(key: KvKey): Promise<T | undefined>;
|
|
26
|
-
set(key: KvKey, value: unknown, options?: KvStoreSetOptions): Promise<void>;
|
|
27
|
-
delete(key: KvKey): Promise<void>;
|
|
28
|
-
}
|
|
29
|
-
/**
|
|
30
|
-
* Implementation of the {@link MessageQueue} interface for Cloudflare
|
|
31
|
-
* Workers Queues binding. This class provides a wrapper around Cloudflare's
|
|
32
|
-
* Queues to send messages to a queue.
|
|
33
|
-
*
|
|
34
|
-
* Note that this implementation does not support the `listen()` method,
|
|
35
|
-
* as Cloudflare Workers Queues do not support message consumption in the same
|
|
36
|
-
* way as other message queue systems. Instead, you should use
|
|
37
|
-
* the {@link Federation.processQueuedTask} method to process messages
|
|
38
|
-
* passed to the queue.
|
|
39
|
-
*
|
|
40
|
-
* @deprecated This class has been moved to `@fedify/cfworkers` package.
|
|
41
|
-
* Import `WorkersMessageQueue` from `@fedify/cfworkers` instead.
|
|
42
|
-
* This class will be removed in Fedify v2.0.
|
|
43
|
-
* @since 1.6.0
|
|
44
|
-
*/
|
|
45
|
-
declare class WorkersMessageQueue implements MessageQueue {
|
|
46
|
-
#private;
|
|
47
|
-
/**
|
|
48
|
-
* Cloudflare Queues provide automatic retry with exponential backoff
|
|
49
|
-
* and Dead Letter Queues.
|
|
50
|
-
* @since 1.7.0
|
|
51
|
-
*/
|
|
52
|
-
readonly nativeRetrial = true;
|
|
53
|
-
constructor(queue: Queue);
|
|
54
|
-
enqueue(message: any, options?: MessageQueueEnqueueOptions): Promise<void>;
|
|
55
|
-
enqueueMany(messages: any[], options?: MessageQueueEnqueueOptions): Promise<void>;
|
|
56
|
-
listen(_handler: (message: any) => Promise<void> | void, _options?: MessageQueueListenOptions): Promise<void>;
|
|
57
|
-
}
|
|
58
|
-
//#endregion
|
|
59
|
-
export { WorkersKvStore, WorkersMessageQueue };
|
package/dist/x/cfworkers.d.ts
DELETED
|
@@ -1,61 +0,0 @@
|
|
|
1
|
-
import { Temporal } from "@js-temporal/polyfill";
|
|
2
|
-
import { URLPattern } from "urlpattern-polyfill";
|
|
3
|
-
import { KvKey, KvStore, KvStoreSetOptions } from "../kv-C7sopW2E.js";
|
|
4
|
-
import { MessageQueue, MessageQueueEnqueueOptions, MessageQueueListenOptions } from "../mq-CRGm1e_F.js";
|
|
5
|
-
import { KVNamespace, Queue } from "@cloudflare/workers-types/experimental";
|
|
6
|
-
|
|
7
|
-
//#region src/x/cfworkers.d.ts
|
|
8
|
-
|
|
9
|
-
/**
|
|
10
|
-
* Implementation of the {@link KvStore} interface for Cloudflare Workers KV
|
|
11
|
-
* binding. This class provides a wrapper around Cloudflare's KV namespace to
|
|
12
|
-
* store and retrieve JSON-serializable values using structured keys.
|
|
13
|
-
*
|
|
14
|
-
* Note that this implementation does not support the {@link KvStore.cas}
|
|
15
|
-
* operation, as Cloudflare Workers KV does not support atomic compare-and-swap
|
|
16
|
-
* operations. If you need this functionality, consider using a different
|
|
17
|
-
* key–value store that supports atomic operations.
|
|
18
|
-
*
|
|
19
|
-
* @deprecated This class has been moved to `@fedify/cfworkers` package.
|
|
20
|
-
* Import `WorkersKvStore` from `@fedify/cfworkers` instead.
|
|
21
|
-
* This class will be removed in Fedify v2.0.
|
|
22
|
-
* @since 1.6.0
|
|
23
|
-
*/
|
|
24
|
-
declare class WorkersKvStore implements KvStore {
|
|
25
|
-
#private;
|
|
26
|
-
constructor(namespace: KVNamespace<string>);
|
|
27
|
-
get<T = unknown>(key: KvKey): Promise<T | undefined>;
|
|
28
|
-
set(key: KvKey, value: unknown, options?: KvStoreSetOptions): Promise<void>;
|
|
29
|
-
delete(key: KvKey): Promise<void>;
|
|
30
|
-
}
|
|
31
|
-
/**
|
|
32
|
-
* Implementation of the {@link MessageQueue} interface for Cloudflare
|
|
33
|
-
* Workers Queues binding. This class provides a wrapper around Cloudflare's
|
|
34
|
-
* Queues to send messages to a queue.
|
|
35
|
-
*
|
|
36
|
-
* Note that this implementation does not support the `listen()` method,
|
|
37
|
-
* as Cloudflare Workers Queues do not support message consumption in the same
|
|
38
|
-
* way as other message queue systems. Instead, you should use
|
|
39
|
-
* the {@link Federation.processQueuedTask} method to process messages
|
|
40
|
-
* passed to the queue.
|
|
41
|
-
*
|
|
42
|
-
* @deprecated This class has been moved to `@fedify/cfworkers` package.
|
|
43
|
-
* Import `WorkersMessageQueue` from `@fedify/cfworkers` instead.
|
|
44
|
-
* This class will be removed in Fedify v2.0.
|
|
45
|
-
* @since 1.6.0
|
|
46
|
-
*/
|
|
47
|
-
declare class WorkersMessageQueue implements MessageQueue {
|
|
48
|
-
#private;
|
|
49
|
-
/**
|
|
50
|
-
* Cloudflare Queues provide automatic retry with exponential backoff
|
|
51
|
-
* and Dead Letter Queues.
|
|
52
|
-
* @since 1.7.0
|
|
53
|
-
*/
|
|
54
|
-
readonly nativeRetrial = true;
|
|
55
|
-
constructor(queue: Queue);
|
|
56
|
-
enqueue(message: any, options?: MessageQueueEnqueueOptions): Promise<void>;
|
|
57
|
-
enqueueMany(messages: any[], options?: MessageQueueEnqueueOptions): Promise<void>;
|
|
58
|
-
listen(_handler: (message: any) => Promise<void> | void, _options?: MessageQueueListenOptions): Promise<void>;
|
|
59
|
-
}
|
|
60
|
-
//#endregion
|
|
61
|
-
export { WorkersKvStore, WorkersMessageQueue };
|
package/dist/x/cfworkers.js
DELETED
|
@@ -1,98 +0,0 @@
|
|
|
1
|
-
|
|
2
|
-
import { Temporal } from "@js-temporal/polyfill";
|
|
3
|
-
import { URLPattern } from "urlpattern-polyfill";
|
|
4
|
-
|
|
5
|
-
import { getLogger } from "@logtape/logtape";
|
|
6
|
-
|
|
7
|
-
//#region src/x/cfworkers.ts
|
|
8
|
-
/**
|
|
9
|
-
* Implementation of the {@link KvStore} interface for Cloudflare Workers KV
|
|
10
|
-
* binding. This class provides a wrapper around Cloudflare's KV namespace to
|
|
11
|
-
* store and retrieve JSON-serializable values using structured keys.
|
|
12
|
-
*
|
|
13
|
-
* Note that this implementation does not support the {@link KvStore.cas}
|
|
14
|
-
* operation, as Cloudflare Workers KV does not support atomic compare-and-swap
|
|
15
|
-
* operations. If you need this functionality, consider using a different
|
|
16
|
-
* key–value store that supports atomic operations.
|
|
17
|
-
*
|
|
18
|
-
* @deprecated This class has been moved to `@fedify/cfworkers` package.
|
|
19
|
-
* Import `WorkersKvStore` from `@fedify/cfworkers` instead.
|
|
20
|
-
* This class will be removed in Fedify v2.0.
|
|
21
|
-
* @since 1.6.0
|
|
22
|
-
*/
|
|
23
|
-
var WorkersKvStore = class {
|
|
24
|
-
#namespace;
|
|
25
|
-
constructor(namespace) {
|
|
26
|
-
const logger = getLogger(["fedify", "cfworkers"]);
|
|
27
|
-
logger.warn("The `@fedify/fedify/x/cfworkers` module is deprecated; use `WorkersKvStore` from `@fedify/cfworkers` package instead.");
|
|
28
|
-
this.#namespace = namespace;
|
|
29
|
-
}
|
|
30
|
-
#encodeKey(key) {
|
|
31
|
-
return JSON.stringify(key);
|
|
32
|
-
}
|
|
33
|
-
async get(key) {
|
|
34
|
-
const encodedKey = this.#encodeKey(key);
|
|
35
|
-
const { value, metadata } = await this.#namespace.getWithMetadata(encodedKey, "json");
|
|
36
|
-
return metadata == null || metadata.expires < Date.now() ? void 0 : value;
|
|
37
|
-
}
|
|
38
|
-
async set(key, value, options) {
|
|
39
|
-
const encodedKey = this.#encodeKey(key);
|
|
40
|
-
const metadata = options?.ttl == null ? {} : { expires: Date.now() + options.ttl.total("milliseconds") };
|
|
41
|
-
await this.#namespace.put(encodedKey, JSON.stringify(value), options?.ttl == null ? { metadata } : {
|
|
42
|
-
expirationTtl: Math.max(options.ttl.total("seconds"), 60),
|
|
43
|
-
metadata
|
|
44
|
-
});
|
|
45
|
-
}
|
|
46
|
-
delete(key) {
|
|
47
|
-
return this.#namespace.delete(this.#encodeKey(key));
|
|
48
|
-
}
|
|
49
|
-
};
|
|
50
|
-
/**
|
|
51
|
-
* Implementation of the {@link MessageQueue} interface for Cloudflare
|
|
52
|
-
* Workers Queues binding. This class provides a wrapper around Cloudflare's
|
|
53
|
-
* Queues to send messages to a queue.
|
|
54
|
-
*
|
|
55
|
-
* Note that this implementation does not support the `listen()` method,
|
|
56
|
-
* as Cloudflare Workers Queues do not support message consumption in the same
|
|
57
|
-
* way as other message queue systems. Instead, you should use
|
|
58
|
-
* the {@link Federation.processQueuedTask} method to process messages
|
|
59
|
-
* passed to the queue.
|
|
60
|
-
*
|
|
61
|
-
* @deprecated This class has been moved to `@fedify/cfworkers` package.
|
|
62
|
-
* Import `WorkersMessageQueue` from `@fedify/cfworkers` instead.
|
|
63
|
-
* This class will be removed in Fedify v2.0.
|
|
64
|
-
* @since 1.6.0
|
|
65
|
-
*/
|
|
66
|
-
var WorkersMessageQueue = class {
|
|
67
|
-
#queue;
|
|
68
|
-
/**
|
|
69
|
-
* Cloudflare Queues provide automatic retry with exponential backoff
|
|
70
|
-
* and Dead Letter Queues.
|
|
71
|
-
* @since 1.7.0
|
|
72
|
-
*/
|
|
73
|
-
nativeRetrial = true;
|
|
74
|
-
constructor(queue) {
|
|
75
|
-
const logger = getLogger(["fedify", "cfworkers"]);
|
|
76
|
-
logger.warn("The `@fedify/fedify/x/cfworkers` module is deprecated; use `WorkersMessageQueue` from `@fedify/cfworkers` package instead.");
|
|
77
|
-
this.#queue = queue;
|
|
78
|
-
}
|
|
79
|
-
enqueue(message, options) {
|
|
80
|
-
return this.#queue.send(message, {
|
|
81
|
-
contentType: "json",
|
|
82
|
-
delaySeconds: options?.delay?.total("seconds") ?? 0
|
|
83
|
-
});
|
|
84
|
-
}
|
|
85
|
-
enqueueMany(messages, options) {
|
|
86
|
-
const requests = messages.map((msg) => ({
|
|
87
|
-
body: msg,
|
|
88
|
-
contentType: "json"
|
|
89
|
-
}));
|
|
90
|
-
return this.#queue.sendBatch(requests, { delaySeconds: options?.delay?.total("seconds") ?? 0 });
|
|
91
|
-
}
|
|
92
|
-
listen(_handler, _options) {
|
|
93
|
-
throw new TypeError("WorkersMessageQueue does not support listen(). Use Federation.processQueuedTask() method instead.");
|
|
94
|
-
}
|
|
95
|
-
};
|
|
96
|
-
|
|
97
|
-
//#endregion
|
|
98
|
-
export { WorkersKvStore, WorkersMessageQueue };
|