@fedify/fedify 2.0.0-pr.449.1725 → 2.0.0-pr.451.1731
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/dist/{actor-C0gLJq8I.js → actor-CRQwUlsr.js} +190 -677
- package/dist/{actor-T6RyhRgk.d.ts → actor-Cd2CREO0.d.ts} +2 -2
- package/dist/{actor-CsRJa7wV.cjs → actor-Ci-5y3ml.cjs} +922 -1451
- package/dist/{actor-D6K058Tb.d.cts → actor-DDhZuMGl.d.cts} +2 -2
- package/dist/{actor-VrXd7EdX.js → actor-GwnlqPRv.js} +1 -1
- 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-JjsppXTK.js → builder-BflZmL4k.js} +3 -4
- package/dist/{client-bgSdkFa2.d.ts → client-Bkaw0_PR.d.ts} +1 -1
- package/dist/{client-CegPX0Rn.d.cts → client-Cle5j1T1.d.cts} +1 -1
- package/dist/{client-BS-GE3XI.js → client-DylapB-t.js} +1 -1
- package/dist/compat/mod.d.cts +11 -11
- package/dist/compat/mod.d.ts +12 -12
- package/dist/compat/transformers.test.js +20 -20
- package/dist/{context-DYCJXr7J.d.cts → context-BOYzcFSe.d.cts} +10 -10
- package/dist/{context-B1X8-X33.d.ts → context-DqFifMwj.d.ts} +11 -11
- package/dist/{authdocloader-C8LXxsmU.js → docloader-BpcE9hBI.js} +18 -8
- package/dist/{esm-CvUgdJZ_.js → esm-DjbC-dsH.js} +11 -11
- package/dist/federation/builder.test.js +8 -10
- package/dist/federation/collection.test.js +7 -9
- package/dist/federation/handler.test.js +25 -26
- package/dist/federation/idempotency.test.js +25 -26
- package/dist/federation/inbox.test.js +4 -6
- package/dist/federation/keycache.test.js +3 -4
- package/dist/federation/kv.test.js +6 -8
- package/dist/federation/middleware.test.js +26 -27
- package/dist/federation/mod.cjs +10 -11
- package/dist/federation/mod.d.cts +10 -10
- package/dist/federation/mod.d.ts +12 -12
- package/dist/federation/mod.js +10 -11
- package/dist/federation/mq.test.js +8 -10
- package/dist/federation/negotiation.test.js +7 -9
- package/dist/federation/retry.test.js +4 -5
- package/dist/federation/router.test.js +6 -8
- package/dist/federation/send.test.js +13 -15
- package/dist/{http-D-e6AFwR.d.cts → http-B6SKO6NJ.d.cts} +2 -2
- package/dist/{http-D6Uj2x2y.d.ts → http-BE7aFuqn.d.ts} +2 -2
- package/dist/{http-DVQEn98K.js → http-BzsavjR2.js} +256 -6
- package/dist/{http-DbyMqL2X.js → http-CCUJdi0H.js} +2 -2
- package/dist/{http-D_BI5KHC.cjs → http-DtUGyvkU.cjs} +289 -9
- package/dist/{inbox-DQlf_-Dz.js → inbox-DizLjfhC.js} +1 -1
- package/dist/{key-BSJX6n9o.js → key-De1MJH3k.js} +3 -2
- package/dist/{keycache-CcIfdj0m.js → keycache-D2HiBv4F.js} +1 -1
- package/dist/{keys-DnSaJmvD.js → keys-B4ZjS1Ot.js} +2 -1
- package/dist/{docloader-BdF5STdg.cjs → kv-cache-3VK2-wq_.cjs} +69 -651
- package/dist/kv-cache-DNvS-egZ.js +4236 -0
- package/dist/{docloader-AMdJU291.js → kv-cache-rR-Cnl95.js} +68 -596
- package/dist/{ld-CAJ6Q2od.js → ld-Dux3_Cw2.js} +3 -2
- package/dist/{type-COb6KNlm.js → lookup-Bep-EOgr.js} +588 -5303
- package/dist/{lookup-B2Bsau2g.cjs → lookup-BmGuy-Ps.cjs} +78 -5
- package/dist/{lookup-BGCuyJRy.js → lookup-Bql--V-C.js} +63 -2
- package/dist/{middleware-1oxZY_0z.js → middleware-BBTmHKGh.js} +11 -11
- package/dist/middleware-BUZSGsQH.js +16 -0
- package/dist/middleware-BusTq7Js.cjs +16 -0
- package/dist/{middleware-BDqkoMAQ.js → middleware-D7tP9Tq6.js} +18 -17
- package/dist/{middleware-D0XMPoN8.cjs → middleware-DrpnHeGO.cjs} +31 -31
- package/dist/middleware-tZdLtCWz.js +26 -0
- package/dist/{mod-CxkWO3Mg.d.cts → mod--K7l84wp.d.cts} +3 -2
- package/dist/{mod-DBzN0aCM.d.ts → mod-CB80AlIA.d.ts} +1 -1
- package/dist/mod-CLKu6Uo_.d.cts +107 -0
- package/dist/{mod-Djzcw2ry.d.cts → mod-COlOrmr9.d.cts} +3 -3
- package/dist/{mod-DlU8ISoa.d.ts → mod-CRENK2dd.d.ts} +3 -2
- package/dist/{mod-DcKxhFQ8.d.ts → mod-CaWbCg0N.d.ts} +2 -2
- package/dist/mod-Cm97bAiT.d.ts +109 -0
- package/dist/{mod-twdvV2hR.d.cts → mod-D9XZsft2.d.cts} +2 -2
- package/dist/{mod-BhUKmBJD.d.ts → mod-DLIidI_j.d.ts} +3 -3
- package/dist/{mod-jQ4OODsl.d.cts → mod-DuclhZjh.d.cts} +1 -1
- package/dist/mod.cjs +21 -32
- package/dist/mod.d.cts +14 -14
- package/dist/mod.d.ts +17 -17
- package/dist/mod.js +15 -16
- package/dist/nodeinfo/client.test.js +8 -10
- package/dist/nodeinfo/handler.test.js +24 -25
- package/dist/nodeinfo/mod.cjs +3 -3
- package/dist/nodeinfo/mod.d.cts +2 -3
- package/dist/nodeinfo/mod.d.ts +3 -4
- package/dist/nodeinfo/mod.js +3 -3
- package/dist/nodeinfo/types.test.js +7 -9
- package/dist/{owner-hd9lvQcP.d.ts → owner-CktUdA0h.d.ts} +3 -3
- package/dist/{owner-CaIfLBwg.js → owner-Zq8du9WO.js} +3 -2
- package/dist/{owner-BN_tO3cY.d.cts → owner-dkg5OpSC.d.cts} +3 -3
- package/dist/{proof-AhyVJcNZ.cjs → proof-0PY1LDZY.cjs} +17 -16
- package/dist/{proof-BQwXHakc.js → proof-C5S_3hdJ.js} +2 -2
- package/dist/{proof-CKXppjee.js → proof-aIlK5BTc.js} +5 -4
- package/dist/request-BbHkedIU.d.cts +35 -0
- package/dist/request-Bc5CHBqO.cjs +208 -0
- package/dist/request-C0Ags1gQ.js +184 -0
- package/dist/request-U1t6zZtk.d.ts +39 -0
- package/dist/{send-DQd3R1Oc.js → send-BbVnlsQO.js} +2 -2
- package/dist/sig/http.test.js +12 -13
- package/dist/sig/key.test.js +9 -11
- package/dist/sig/ld.test.js +8 -10
- package/dist/sig/mod.cjs +10 -11
- package/dist/sig/mod.d.cts +6 -7
- package/dist/sig/mod.d.ts +6 -7
- package/dist/sig/mod.js +6 -7
- package/dist/sig/owner.test.js +10 -12
- package/dist/sig/proof.test.js +13 -14
- package/dist/testing/docloader.test.js +6 -8
- package/dist/testing/mod.d.ts +3 -62
- package/dist/testing/mod.js +2 -3
- package/dist/{testing-BljKU-GG.js → testing-BkidWE0N.js} +1 -2
- package/dist/{types-DI0yutHB.cjs → types-BDNYgodm.cjs} +3 -3
- package/dist/{types-CEn4wB51.js → types-CXnyjUdK.js} +1 -1
- package/dist/{runtime/authdocloader.test.js → utils/docloader.test.js} +13 -15
- package/dist/utils/kv-cache.test.js +208 -0
- package/dist/utils/mod.cjs +14 -0
- package/dist/utils/mod.d.cts +6 -0
- package/dist/utils/mod.d.ts +8 -0
- package/dist/utils/mod.js +12 -0
- package/dist/utils/request.test.js +48 -0
- package/dist/utils/url.test.js +41 -0
- package/dist/vocab/actor.test.js +8 -10
- package/dist/vocab/lookup.test.js +7 -9
- package/dist/vocab/mod.cjs +4 -4
- package/dist/vocab/mod.d.cts +4 -5
- package/dist/vocab/mod.d.ts +4 -5
- package/dist/vocab/mod.js +4 -4
- package/dist/vocab/type.test.js +2 -3
- package/dist/vocab/vocab.test.js +9 -10
- package/dist/{vocab-CkWH9P5l.js → vocab-BiKK7m2H.js} +4 -3
- package/dist/{vocab-Dw1-yVGg.d.cts → vocab-DCBw44JZ.d.cts} +2 -21
- package/dist/{vocab-NZXL5Pr-.cjs → vocab-Dapemq3v.cjs} +6 -5
- package/dist/{vocab-BI0Ak5lL.d.ts → vocab-ivDKb439.d.ts} +2 -21
- package/dist/webfinger/handler.test.js +24 -25
- package/dist/webfinger/lookup.test.js +7 -9
- package/dist/webfinger/mod.cjs +3 -3
- package/dist/webfinger/mod.d.cts +2 -3
- package/dist/webfinger/mod.d.ts +2 -3
- package/dist/webfinger/mod.js +3 -3
- package/dist/x/cfworkers.d.cts +1 -1
- package/dist/x/cfworkers.d.ts +2 -2
- package/dist/x/cfworkers.test.js +6 -8
- package/dist/x/hono.d.cts +10 -10
- package/dist/x/hono.d.ts +11 -11
- package/dist/x/sveltekit.d.cts +10 -10
- package/dist/x/sveltekit.d.ts +11 -11
- package/package.json +16 -14
- package/dist/assert_throws-BOO88avQ.js +0 -39
- package/dist/authdocloader-6F9IP-VO.js +0 -52
- package/dist/authdocloader-BkuVo8LL.cjs +0 -58
- package/dist/docloader-CxWcuWqQ.d.ts +0 -221
- package/dist/docloader-D-MrRyHl.d.cts +0 -219
- package/dist/key-BBzfhQGE.js +0 -10
- package/dist/key-BMz_uAnc.cjs +0 -10
- package/dist/key-D-RgWfcf.cjs +0 -290
- package/dist/key-DFefr8X2.js +0 -260
- package/dist/key-DW2DrPGl.js +0 -10
- package/dist/lookup-C3pnuyiD.js +0 -331
- package/dist/middleware-B8WWe8Q2.js +0 -26
- package/dist/middleware-DipQbJmB.js +0 -17
- package/dist/middleware-mLaQeD_Z.cjs +0 -17
- package/dist/mod-CerN_Sza.d.ts +0 -104
- package/dist/mod-Cj1tHXBR.d.cts +0 -102
- 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.js +0 -45
- /package/dist/{assert_not_equals-f3m3epl3.js → assert_not_equals-C80BG-_5.js} +0 -0
- /package/dist/{collection-CcnIw1qY.js → collection-BzWsN9pB.js} +0 -0
- /package/dist/{denokv-Bv33Xxea.js → denokv-CCssOzMJ.js} +0 -0
- /package/dist/{federation-H2_En3j5.cjs → federation-DOuZpcAw.cjs} +0 -0
- /package/dist/{federation-D1U8YY9t.js → federation-pZJsapBn.js} +0 -0
- /package/dist/{kv-63Cil1MD.d.cts → kv-BMKIFXNW.d.cts} +0 -0
- /package/dist/{kv-C7sopW2E.d.ts → kv-Dt06smFt.d.ts} +0 -0
- /package/dist/{mod-1pDWKvUL.d.ts → mod-B-ZQqbGe.d.ts} +0 -0
- /package/dist/{mod-g0xFzAP9.d.ts → mod-CjsiSl7_.d.ts} +0 -0
- /package/dist/{mq-CRGm1e_F.d.ts → mq-CPRJk4mZ.d.ts} +0 -0
- /package/dist/{negotiation-5NPJL6zp.js → negotiation-C4nFufNk.js} +0 -0
- /package/dist/{nodeinfo-DfycQ8Wf.js → nodeinfo-B0UefMXO.js} +0 -0
- /package/dist/{nodeinfo-Co9lJrWl.cjs → nodeinfo-ByTd7HpT.cjs} +0 -0
- /package/dist/{retry-D4GJ670a.js → retry-CfF8Gn4d.js} +0 -0
- /package/dist/{runtime-C58AJWSv.cjs → sig-DE_NC_VQ.cjs} +0 -0
- /package/dist/{runtime-DPYEDf-o.js → sig-Dx59zAgn.js} +0 -0
- /package/dist/{std__assert-X-_kMxKM.js → std__assert-DWivtrGR.js} +0 -0
- /package/dist/{types-BSuWJsOm.js → types-C2XVl6gj.js} +0 -0
- /package/dist/{runtime → utils}/docloader.test.d.ts +0 -0
- /package/dist/{runtime/authdocloader.test.d.ts → utils/kv-cache.test.d.ts} +0 -0
- /package/dist/{runtime/key.test.d.ts → utils/request.test.d.ts} +0 -0
- /package/dist/{runtime → utils}/url.test.d.ts +0 -0
- /package/dist/{sig-ByHXzqUi.cjs → utils-B6yXfxAQ.cjs} +0 -0
- /package/dist/{sig-Cj3tk-ig.js → utils-BXMGcmqK.js} +0 -0
- /package/dist/{webfinger-BjOEdFPs.cjs → webfinger-C949bxcD.cjs} +0 -0
- /package/dist/{webfinger-De_bU0iE.js → webfinger-qG8R5jc3.js} +0 -0
package/dist/lookup-C3pnuyiD.js
DELETED
@@ -1,331 +0,0 @@
|
|
1
|
-
|
2
|
-
import { Temporal } from "@js-temporal/polyfill";
|
3
|
-
import { URLPattern } from "urlpattern-polyfill";
|
4
|
-
globalThis.addEventListener = () => {};
|
5
|
-
|
6
|
-
import { Object as Object$1, deno_default, getDocumentLoader, getTypeId, lookupWebFinger } from "./type-COb6KNlm.js";
|
7
|
-
import { cloneDeep, delay } from "es-toolkit";
|
8
|
-
import { getLogger } from "@logtape/logtape";
|
9
|
-
import { SpanStatusCode, trace } from "@opentelemetry/api";
|
10
|
-
import { Router } from "uri-template-router";
|
11
|
-
import { parseTemplate } from "url-template";
|
12
|
-
|
13
|
-
//#region src/federation/router.ts
|
14
|
-
function cloneInnerRouter(router) {
|
15
|
-
const clone = new Router();
|
16
|
-
clone.nid = router.nid;
|
17
|
-
clone.fsm = cloneDeep(router.fsm);
|
18
|
-
clone.routeSet = new Set(router.routeSet);
|
19
|
-
clone.templateRouteMap = new Map(router.templateRouteMap);
|
20
|
-
clone.valueRouteMap = new Map(router.valueRouteMap);
|
21
|
-
clone.hierarchy = cloneDeep(router.hierarchy);
|
22
|
-
return clone;
|
23
|
-
}
|
24
|
-
/**
|
25
|
-
* URL router and constructor based on URI Template
|
26
|
-
* ([RFC 6570](https://tools.ietf.org/html/rfc6570)).
|
27
|
-
*/
|
28
|
-
var Router$1 = class Router$1 {
|
29
|
-
#router;
|
30
|
-
#templates;
|
31
|
-
#templateStrings;
|
32
|
-
/**
|
33
|
-
* Whether to ignore trailing slashes when matching paths.
|
34
|
-
* @since 1.6.0
|
35
|
-
*/
|
36
|
-
trailingSlashInsensitive;
|
37
|
-
/**
|
38
|
-
* Create a new {@link Router}.
|
39
|
-
* @param options Options for the router.
|
40
|
-
*/
|
41
|
-
constructor(options = {}) {
|
42
|
-
this.#router = new Router();
|
43
|
-
this.#templates = {};
|
44
|
-
this.#templateStrings = {};
|
45
|
-
this.trailingSlashInsensitive = options.trailingSlashInsensitive ?? false;
|
46
|
-
}
|
47
|
-
clone() {
|
48
|
-
const clone = new Router$1({ trailingSlashInsensitive: this.trailingSlashInsensitive });
|
49
|
-
clone.#router = cloneInnerRouter(this.#router);
|
50
|
-
clone.#templates = { ...this.#templates };
|
51
|
-
clone.#templateStrings = { ...this.#templateStrings };
|
52
|
-
return clone;
|
53
|
-
}
|
54
|
-
/**
|
55
|
-
* Checks if a path name exists in the router.
|
56
|
-
* @param name The name of the path.
|
57
|
-
* @returns `true` if the path name exists, otherwise `false`.
|
58
|
-
*/
|
59
|
-
has(name) {
|
60
|
-
return name in this.#templates;
|
61
|
-
}
|
62
|
-
/**
|
63
|
-
* Adds a new path rule to the router.
|
64
|
-
* @param template The path pattern.
|
65
|
-
* @param name The name of the path.
|
66
|
-
* @returns The names of the variables in the path pattern.
|
67
|
-
*/
|
68
|
-
add(template, name) {
|
69
|
-
if (!template.startsWith("/")) throw new RouterError("Path must start with a slash.");
|
70
|
-
const rule = this.#router.addTemplate(template, {}, name);
|
71
|
-
this.#templates[name] = parseTemplate(template);
|
72
|
-
this.#templateStrings[name] = template;
|
73
|
-
return new Set(rule.variables.map((v) => v.varname));
|
74
|
-
}
|
75
|
-
/**
|
76
|
-
* Resolves a path name and values from a URL, if any match.
|
77
|
-
* @param url The URL to resolve.
|
78
|
-
* @returns The name of the path and its values, if any match. Otherwise,
|
79
|
-
* `null`.
|
80
|
-
*/
|
81
|
-
route(url) {
|
82
|
-
let match = this.#router.resolveURI(url);
|
83
|
-
if (match == null) {
|
84
|
-
if (!this.trailingSlashInsensitive) return null;
|
85
|
-
url = url.endsWith("/") ? url.replace(/\/+$/, "") : `${url}/`;
|
86
|
-
match = this.#router.resolveURI(url);
|
87
|
-
if (match == null) return null;
|
88
|
-
}
|
89
|
-
return {
|
90
|
-
name: match.matchValue,
|
91
|
-
template: this.#templateStrings[match.matchValue],
|
92
|
-
values: match.params
|
93
|
-
};
|
94
|
-
}
|
95
|
-
/**
|
96
|
-
* Constructs a URL/path from a path name and values.
|
97
|
-
* @param name The name of the path.
|
98
|
-
* @param values The values to expand the path with.
|
99
|
-
* @returns The URL/path, if the name exists. Otherwise, `null`.
|
100
|
-
*/
|
101
|
-
build(name, values) {
|
102
|
-
if (name in this.#templates) return this.#templates[name].expand(values);
|
103
|
-
return null;
|
104
|
-
}
|
105
|
-
};
|
106
|
-
/**
|
107
|
-
* An error thrown by the {@link Router}.
|
108
|
-
*/
|
109
|
-
var RouterError = class extends Error {
|
110
|
-
/**
|
111
|
-
* Create a new {@link RouterError}.
|
112
|
-
* @param message The error message.
|
113
|
-
*/
|
114
|
-
constructor(message) {
|
115
|
-
super(message);
|
116
|
-
this.name = "RouterError";
|
117
|
-
}
|
118
|
-
};
|
119
|
-
|
120
|
-
//#endregion
|
121
|
-
//#region src/vocab/handle.ts
|
122
|
-
/**
|
123
|
-
* Regular expression to match a fediverse handle in the format `@user@server`
|
124
|
-
* or `user@server`. The `user` part can contain alphanumeric characters and
|
125
|
-
* some special characters except `@`. The `server` part is all characters
|
126
|
-
* after the `@` symbol in the middle.
|
127
|
-
*/
|
128
|
-
const handleRegexp = /^@?((?:[-A-Za-z0-9._~!$&'()*+,;=]|%[A-Fa-f0-9]{2})+)@([^@]+)$/;
|
129
|
-
/**
|
130
|
-
* Parses a fediverse handle in the format `@user@server` or `user@server`.
|
131
|
-
* The `user` part can contain alphanumeric characters and some special
|
132
|
-
* characters except `@`. The `server` part is all characters after the `@`
|
133
|
-
* symbol in the middle.
|
134
|
-
*
|
135
|
-
* @example
|
136
|
-
* ```typescript
|
137
|
-
* const handle = parseFediverseHandle("@username@example.com");
|
138
|
-
* console.log(handle?.username); // "username"
|
139
|
-
* console.log(handle?.host); // "example.com"
|
140
|
-
* ```
|
141
|
-
*
|
142
|
-
* @param handle - The fediverse handle string to parse.
|
143
|
-
* @returns A {@link FediverseHandle} object with `username` and `host`
|
144
|
-
* if the input is valid; otherwise `null`.
|
145
|
-
* @since 1.8.0
|
146
|
-
*/
|
147
|
-
function parseFediverseHandle(handle) {
|
148
|
-
const match = handleRegexp.exec(handle);
|
149
|
-
if (match) return {
|
150
|
-
username: match[1],
|
151
|
-
host: match[2]
|
152
|
-
};
|
153
|
-
return null;
|
154
|
-
}
|
155
|
-
/**
|
156
|
-
* Converts a fediverse handle in the format `@user@server` or `user@server`
|
157
|
-
* to an `acct:` URI, which is a URL-like identifier for ActivityPub actors.
|
158
|
-
*
|
159
|
-
* @example
|
160
|
-
* ```typescript
|
161
|
-
* const identifier = toAcctUrl("@username@example.com");
|
162
|
-
* console.log(identifier?.href); // "acct:username@example.com"
|
163
|
-
* ```
|
164
|
-
*
|
165
|
-
* @param handle - The fediverse handle string to convert.
|
166
|
-
* @returns A `URL` object representing the `acct:` URI if conversion succeeds;
|
167
|
-
* otherwise `null`.
|
168
|
-
* @since 1.8.0
|
169
|
-
*/
|
170
|
-
function toAcctUrl(handle) {
|
171
|
-
const parsed = parseFediverseHandle(handle);
|
172
|
-
if (!parsed) return null;
|
173
|
-
const identifier = new URL(`acct:${parsed.username}@${parsed.host}`);
|
174
|
-
return identifier;
|
175
|
-
}
|
176
|
-
|
177
|
-
//#endregion
|
178
|
-
//#region src/vocab/lookup.ts
|
179
|
-
const logger = getLogger([
|
180
|
-
"fedify",
|
181
|
-
"vocab",
|
182
|
-
"lookup"
|
183
|
-
]);
|
184
|
-
/**
|
185
|
-
* Looks up an ActivityStreams object by its URI (including `acct:` URIs)
|
186
|
-
* or a fediverse handle (e.g., `@user@server` or `user@server`).
|
187
|
-
*
|
188
|
-
* @example
|
189
|
-
* ``` typescript
|
190
|
-
* // Look up an actor by its fediverse handle:
|
191
|
-
* await lookupObject("@hongminhee@fosstodon.org");
|
192
|
-
* // returning a `Person` object.
|
193
|
-
*
|
194
|
-
* // A fediverse handle can omit the leading '@':
|
195
|
-
* await lookupObject("hongminhee@fosstodon.org");
|
196
|
-
* // returning a `Person` object.
|
197
|
-
*
|
198
|
-
* // A `acct:` URI can be used as well:
|
199
|
-
* await lookupObject("acct:hongminhee@fosstodon.org");
|
200
|
-
* // returning a `Person` object.
|
201
|
-
*
|
202
|
-
* // Look up an object by its URI:
|
203
|
-
* await lookupObject("https://todon.eu/@hongminhee/112060633798771581");
|
204
|
-
* // returning a `Note` object.
|
205
|
-
*
|
206
|
-
* // It can be a `URL` object as well:
|
207
|
-
* await lookupObject(new URL("https://todon.eu/@hongminhee/112060633798771581"));
|
208
|
-
* // returning a `Note` object.
|
209
|
-
* ```
|
210
|
-
*
|
211
|
-
* @param identifier The URI or fediverse handle to look up.
|
212
|
-
* @param options Lookup options.
|
213
|
-
* @returns The object, or `null` if not found.
|
214
|
-
* @since 0.2.0
|
215
|
-
*/
|
216
|
-
async function lookupObject(identifier, options = {}) {
|
217
|
-
const tracerProvider = options.tracerProvider ?? trace.getTracerProvider();
|
218
|
-
const tracer = tracerProvider.getTracer(deno_default.name, deno_default.version);
|
219
|
-
return await tracer.startActiveSpan("activitypub.lookup_object", async (span) => {
|
220
|
-
try {
|
221
|
-
const result = await lookupObjectInternal(identifier, options);
|
222
|
-
if (result == null) span.setStatus({ code: SpanStatusCode.ERROR });
|
223
|
-
else {
|
224
|
-
if (result.id != null) span.setAttribute("activitypub.object.id", result.id.href);
|
225
|
-
span.setAttribute("activitypub.object.type", getTypeId(result).href);
|
226
|
-
if (result.replyTargetIds.length > 0) span.setAttribute("activitypub.object.in_reply_to", result.replyTargetIds.map((id) => id.href));
|
227
|
-
}
|
228
|
-
return result;
|
229
|
-
} catch (error) {
|
230
|
-
span.setStatus({
|
231
|
-
code: SpanStatusCode.ERROR,
|
232
|
-
message: String(error)
|
233
|
-
});
|
234
|
-
throw error;
|
235
|
-
} finally {
|
236
|
-
span.end();
|
237
|
-
}
|
238
|
-
});
|
239
|
-
}
|
240
|
-
async function lookupObjectInternal(identifier, options = {}) {
|
241
|
-
const documentLoader = options.documentLoader ?? getDocumentLoader({ userAgent: options.userAgent });
|
242
|
-
if (typeof identifier === "string") identifier = toAcctUrl(identifier) ?? new URL(identifier);
|
243
|
-
let remoteDoc = null;
|
244
|
-
if (identifier.protocol === "http:" || identifier.protocol === "https:") try {
|
245
|
-
remoteDoc = await documentLoader(identifier.href, { signal: options.signal });
|
246
|
-
} catch (error) {
|
247
|
-
logger.debug("Failed to fetch remote document:\n{error}", { error });
|
248
|
-
}
|
249
|
-
if (remoteDoc == null) {
|
250
|
-
const jrd = await lookupWebFinger(identifier, {
|
251
|
-
userAgent: options.userAgent,
|
252
|
-
tracerProvider: options.tracerProvider,
|
253
|
-
allowPrivateAddress: "allowPrivateAddress" in options && options.allowPrivateAddress === true,
|
254
|
-
signal: options.signal
|
255
|
-
});
|
256
|
-
if (jrd?.links == null) return null;
|
257
|
-
for (const l of jrd.links) {
|
258
|
-
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;
|
259
|
-
try {
|
260
|
-
remoteDoc = await documentLoader(l.href, { signal: options.signal });
|
261
|
-
break;
|
262
|
-
} catch (error) {
|
263
|
-
logger.debug("Failed to fetch remote document:\n{error}", { error });
|
264
|
-
continue;
|
265
|
-
}
|
266
|
-
}
|
267
|
-
}
|
268
|
-
if (remoteDoc == null) return null;
|
269
|
-
let object;
|
270
|
-
try {
|
271
|
-
object = await Object$1.fromJsonLd(remoteDoc.document, {
|
272
|
-
documentLoader,
|
273
|
-
contextLoader: options.contextLoader,
|
274
|
-
tracerProvider: options.tracerProvider,
|
275
|
-
baseUrl: new URL(remoteDoc.documentUrl)
|
276
|
-
});
|
277
|
-
} catch (error) {
|
278
|
-
if (error instanceof TypeError) {
|
279
|
-
logger.debug("Failed to parse JSON-LD document: {error}\n{document}", {
|
280
|
-
...remoteDoc,
|
281
|
-
error
|
282
|
-
});
|
283
|
-
return null;
|
284
|
-
}
|
285
|
-
throw error;
|
286
|
-
}
|
287
|
-
if (options.crossOrigin !== "trust" && object.id != null && object.id.origin !== new URL(remoteDoc.documentUrl).origin) {
|
288
|
-
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".`);
|
289
|
-
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\".", {
|
290
|
-
...remoteDoc,
|
291
|
-
objectId: object.id.href
|
292
|
-
});
|
293
|
-
return null;
|
294
|
-
}
|
295
|
-
return object;
|
296
|
-
}
|
297
|
-
/**
|
298
|
-
* Traverses a collection, yielding each item in the collection.
|
299
|
-
* If the collection is paginated, it will fetch the next page
|
300
|
-
* automatically.
|
301
|
-
*
|
302
|
-
* @example
|
303
|
-
* ``` typescript
|
304
|
-
* const collection = await lookupObject(collectionUrl);
|
305
|
-
* if (collection instanceof Collection) {
|
306
|
-
* for await (const item of traverseCollection(collection)) {
|
307
|
-
* console.log(item.id?.href);
|
308
|
-
* }
|
309
|
-
* }
|
310
|
-
* ```
|
311
|
-
*
|
312
|
-
* @param collection The collection to traverse.
|
313
|
-
* @param options Options for traversing the collection.
|
314
|
-
* @returns An async iterable of each item in the collection.
|
315
|
-
* @since 1.1.0
|
316
|
-
*/
|
317
|
-
async function* traverseCollection(collection, options = {}) {
|
318
|
-
if (collection.firstId == null) for await (const item of collection.getItems(options)) yield item;
|
319
|
-
else {
|
320
|
-
const interval = Temporal.Duration.from(options.interval ?? { seconds: 0 }).total("millisecond");
|
321
|
-
let page = await collection.getFirst(options);
|
322
|
-
while (page != null) {
|
323
|
-
for await (const item of page.getItems(options)) yield item;
|
324
|
-
if (interval > 0) await delay(interval);
|
325
|
-
page = await page.getNext(options);
|
326
|
-
}
|
327
|
-
}
|
328
|
-
}
|
329
|
-
|
330
|
-
//#endregion
|
331
|
-
export { Router$1 as Router, RouterError, lookupObject, traverseCollection };
|
@@ -1,26 +0,0 @@
|
|
1
|
-
|
2
|
-
import { Temporal } from "@js-temporal/polyfill";
|
3
|
-
import { URLPattern } from "urlpattern-polyfill";
|
4
|
-
globalThis.addEventListener = () => {};
|
5
|
-
|
6
|
-
import "./type-COb6KNlm.js";
|
7
|
-
import { ContextImpl, FederationImpl, InboxContextImpl, KvSpecDeterminer, createFederation } from "./middleware-BDqkoMAQ.js";
|
8
|
-
import "./client-BS-GE3XI.js";
|
9
|
-
import "./lookup-C3pnuyiD.js";
|
10
|
-
import "./types-BSuWJsOm.js";
|
11
|
-
import "./actor-VrXd7EdX.js";
|
12
|
-
import "./key-BSJX6n9o.js";
|
13
|
-
import "./http-DbyMqL2X.js";
|
14
|
-
import "./authdocloader-C8LXxsmU.js";
|
15
|
-
import "./ld-CAJ6Q2od.js";
|
16
|
-
import "./owner-CaIfLBwg.js";
|
17
|
-
import "./proof-BQwXHakc.js";
|
18
|
-
import "./inbox-DQlf_-Dz.js";
|
19
|
-
import "./builder-JjsppXTK.js";
|
20
|
-
import "./collection-CcnIw1qY.js";
|
21
|
-
import "./keycache-CcIfdj0m.js";
|
22
|
-
import "./negotiation-5NPJL6zp.js";
|
23
|
-
import "./retry-D4GJ670a.js";
|
24
|
-
import "./send-DQd3R1Oc.js";
|
25
|
-
|
26
|
-
export { FederationImpl };
|
@@ -1,17 +0,0 @@
|
|
1
|
-
|
2
|
-
import { Temporal } from "@js-temporal/polyfill";
|
3
|
-
import { URLPattern } from "urlpattern-polyfill";
|
4
|
-
|
5
|
-
import "./transformers-BFT6d7J5.js";
|
6
|
-
import "./docloader-AMdJU291.js";
|
7
|
-
import "./actor-C0gLJq8I.js";
|
8
|
-
import { ContextImpl, FederationImpl, InboxContextImpl, KvSpecDeterminer, createFederation } from "./middleware-1oxZY_0z.js";
|
9
|
-
import "./lookup-BGCuyJRy.js";
|
10
|
-
import "./key-DFefr8X2.js";
|
11
|
-
import "./http-DVQEn98K.js";
|
12
|
-
import "./proof-CKXppjee.js";
|
13
|
-
import "./types-CEn4wB51.js";
|
14
|
-
import "./authdocloader-6F9IP-VO.js";
|
15
|
-
import "./vocab-CkWH9P5l.js";
|
16
|
-
|
17
|
-
export { FederationImpl };
|
@@ -1,17 +0,0 @@
|
|
1
|
-
|
2
|
-
const { Temporal } = require("@js-temporal/polyfill");
|
3
|
-
const { URLPattern } = require("urlpattern-polyfill");
|
4
|
-
|
5
|
-
require('./transformers-CoBS-oFG.cjs');
|
6
|
-
require('./docloader-BdF5STdg.cjs');
|
7
|
-
require('./actor-CsRJa7wV.cjs');
|
8
|
-
const require_middleware = require('./middleware-D0XMPoN8.cjs');
|
9
|
-
require('./lookup-B2Bsau2g.cjs');
|
10
|
-
require('./key-D-RgWfcf.cjs');
|
11
|
-
require('./http-D_BI5KHC.cjs');
|
12
|
-
require('./proof-AhyVJcNZ.cjs');
|
13
|
-
require('./types-DI0yutHB.cjs');
|
14
|
-
require('./authdocloader-BkuVo8LL.cjs');
|
15
|
-
require('./vocab-NZXL5Pr-.cjs');
|
16
|
-
|
17
|
-
exports.FederationImpl = require_middleware.FederationImpl;
|
package/dist/mod-CerN_Sza.d.ts
DELETED
@@ -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-D6Uj2x2y.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 };
|
package/dist/mod-Cj1tHXBR.d.cts
DELETED
@@ -1,102 +0,0 @@
|
|
1
|
-
import { DocumentLoader, DocumentLoaderFactoryOptions } from "./docloader-D-MrRyHl.cjs";
|
2
|
-
import { HttpMessageSignaturesSpecDeterminer } from "./http-D-e6AFwR.cjs";
|
3
|
-
import { TracerProvider } from "@opentelemetry/api";
|
4
|
-
|
5
|
-
//#region src/runtime/authdocloader.d.ts
|
6
|
-
/**
|
7
|
-
* Options for {@link getAuthenticatedDocumentLoader}.
|
8
|
-
* @see {@link getAuthenticatedDocumentLoader}
|
9
|
-
* @since 1.3.0
|
10
|
-
*/
|
11
|
-
interface GetAuthenticatedDocumentLoaderOptions extends DocumentLoaderFactoryOptions {
|
12
|
-
/**
|
13
|
-
* An optional spec determiner for HTTP Message Signatures.
|
14
|
-
* It determines the spec to use for signing requests.
|
15
|
-
* It is used for double-knocking
|
16
|
-
* (see <https://swicg.github.io/activitypub-http-signature/#how-to-upgrade-supported-versions>).
|
17
|
-
* @since 1.6.0
|
18
|
-
*/
|
19
|
-
specDeterminer?: HttpMessageSignaturesSpecDeterminer;
|
20
|
-
/**
|
21
|
-
* The OpenTelemetry tracer provider. If omitted, the global tracer provider
|
22
|
-
* is used.
|
23
|
-
* @since 1.6.0
|
24
|
-
*/
|
25
|
-
tracerProvider?: TracerProvider;
|
26
|
-
}
|
27
|
-
/**
|
28
|
-
* Gets an authenticated {@link DocumentLoader} for the given identity.
|
29
|
-
* Note that an authenticated document loader intentionally does not cache
|
30
|
-
* the fetched documents.
|
31
|
-
* @param identity The identity to get the document loader for.
|
32
|
-
* The actor's key pair.
|
33
|
-
* @param options The options for the document loader.
|
34
|
-
* @returns The authenticated document loader.
|
35
|
-
* @throws {TypeError} If the key is invalid or unsupported.
|
36
|
-
* @since 0.4.0
|
37
|
-
*/
|
38
|
-
declare function getAuthenticatedDocumentLoader(identity: {
|
39
|
-
keyId: URL;
|
40
|
-
privateKey: CryptoKey;
|
41
|
-
}, {
|
42
|
-
allowPrivateAddress,
|
43
|
-
userAgent,
|
44
|
-
specDeterminer,
|
45
|
-
tracerProvider
|
46
|
-
}?: GetAuthenticatedDocumentLoaderOptions): DocumentLoader;
|
47
|
-
//#endregion
|
48
|
-
//#region src/runtime/key.d.ts
|
49
|
-
/**
|
50
|
-
* Imports a PEM-SPKI formatted public key.
|
51
|
-
* @param pem The PEM-SPKI formatted public key.
|
52
|
-
* @returns The imported public key.
|
53
|
-
* @throws {TypeError} If the key is invalid or unsupported.
|
54
|
-
* @since 0.5.0
|
55
|
-
*/
|
56
|
-
declare function importSpki(pem: string): Promise<CryptoKey>;
|
57
|
-
/**
|
58
|
-
* Exports a public key in PEM-SPKI format.
|
59
|
-
* @param key The public key to export.
|
60
|
-
* @returns The exported public key in PEM-SPKI format.
|
61
|
-
* @throws {TypeError} If the key is invalid or unsupported.
|
62
|
-
* @since 0.5.0
|
63
|
-
*/
|
64
|
-
declare function exportSpki(key: CryptoKey): Promise<string>;
|
65
|
-
/**
|
66
|
-
* Imports a PEM-PKCS#1 formatted public key.
|
67
|
-
* @param pem The PEM-PKCS#1 formatted public key.
|
68
|
-
* @returns The imported public key.
|
69
|
-
* @throws {TypeError} If the key is invalid or unsupported.
|
70
|
-
* @since 1.5.0
|
71
|
-
*/
|
72
|
-
declare function importPkcs1(pem: string): Promise<CryptoKey>;
|
73
|
-
/**
|
74
|
-
* Imports a PEM formatted public key (SPKI or PKCS#1).
|
75
|
-
* @param pem The PEM formatted public key to import (SPKI or PKCS#1).
|
76
|
-
* @returns The imported public key.
|
77
|
-
* @throws {TypeError} If the key is invalid or unsupported.
|
78
|
-
* @since 1.5.0
|
79
|
-
*/
|
80
|
-
declare function importPem(pem: string): Promise<CryptoKey>;
|
81
|
-
/**
|
82
|
-
* Imports a [Multibase]-encoded public key.
|
83
|
-
*
|
84
|
-
* [Multibase]: https://www.w3.org/TR/vc-data-integrity/#multibase-0
|
85
|
-
* @param key The Multibase-encoded public key.
|
86
|
-
* @returns The imported public key.
|
87
|
-
* @throws {TypeError} If the key is invalid or unsupported.
|
88
|
-
* @since 0.10.0
|
89
|
-
*/
|
90
|
-
declare function importMultibaseKey(key: string): Promise<CryptoKey>;
|
91
|
-
/**
|
92
|
-
* Exports a public key in [Multibase] format.
|
93
|
-
*
|
94
|
-
* [Multibase]: https://www.w3.org/TR/vc-data-integrity/#multibase-0
|
95
|
-
* @param key The public key to export.
|
96
|
-
* @returns The exported public key in Multibase format.
|
97
|
-
* @throws {TypeError} If the key is invalid or unsupported.
|
98
|
-
* @since 0.10.0
|
99
|
-
*/
|
100
|
-
declare function exportMultibaseKey(key: CryptoKey): Promise<string>;
|
101
|
-
//#endregion
|
102
|
-
export { GetAuthenticatedDocumentLoaderOptions, exportMultibaseKey, exportSpki, getAuthenticatedDocumentLoader, importMultibaseKey, importPem, importPkcs1, importSpki };
|