Loading CHANGES.md +29 −0 Original line number Diff line number Diff line Loading @@ -8,6 +8,11 @@ Version 1.2.26 To be released. - Added a temporary workaround for invalid AT Protocol URIs from BridgyFed. URIs like `at://did:plc:...` that violate RFC 3986 URI syntax are now automatically URL-encoded to `at://did%3Aplc%3A...` to prevent parsing failures when processing bridged Bluesky content. [[#436]] Version 1.2.25 -------------- Loading Loading @@ -446,6 +451,17 @@ Released on October 31, 2024. [#118]: https://github.com/dahlia/fedify/issues/118 Version 1.1.26 -------------- Released on September 17, 2025. - Added a temporary workaround for invalid AT Protocol URIs from BridgyFed. URIs like `at://did:plc:...` that violate RFC 3986 URI syntax are now automatically URL-encoded to `at://did%3Aplc%3A...` to prevent parsing failures when processing bridged Bluesky content. [[#436]] Version 1.1.25 -------------- Loading Loading @@ -924,6 +940,19 @@ Released on October 20, 2024. [#150]: https://github.com/dahlia/fedify/issues/150 Version 1.0.29 -------------- Released on September 17, 2025. - Added a temporary workaround for invalid AT Protocol URIs from BridgyFed. URIs like `at://did:plc:...` that violate RFC 3986 URI syntax are now automatically URL-encoded to `at://did%3Aplc%3A...` to prevent parsing failures when processing bridged Bluesky content. [[#436]] [#436]: https://github.com/fedify-dev/fedify/issues/436 Version 1.0.28 -------------- Loading mise.toml 0 → 100644 +2 −0 Original line number Diff line number Diff line [tools] deno = "1.46.3" src/codegen/__snapshots__/class.test.ts.snap +30 −10 Original line number Diff line number Diff line Loading @@ -5649,7 +5649,9 @@ get urls(): ((URL | Link))[] { const decoded = typeof v === \\"object\\" && \\"@id\\" in v && typeof v[\\"@id\\"] === \\"string\\" && v[\\"@id\\"] !== \\"\\" && v[\\"@id\\"] !== \\"/\\" ? new URL(v[\\"@id\\"]) : typeof v === \\"object\\" && \\"@type\\" in v && v[\\"@id\\"] !== \\"\\" && v[\\"@id\\"] !== \\"/\\" ? v[\\"@id\\"].startsWith(\\"at://did:plc:\\") ? new URL(\\"at://did%3Aplc%3A\\" + v[\\"@id\\"].slice(13)) : new URL(v[\\"@id\\"]) : typeof v === \\"object\\" && \\"@type\\" in v && Array.isArray(v[\\"@type\\"])&& [\\"https://www.w3.org/ns/activitystreams#Link\\",\\"https://www.w3.org/ns/activitystreams#Hashtag\\",\\"https://www.w3.org/ns/activitystreams#Mention\\"].some( t => v[\\"@type\\"].includes(t)) ? await Link.fromJsonLd( v, options) : undefined Loading Loading @@ -10342,7 +10344,9 @@ get endpoints(): (URL)[] { : _2KM4fetG6FTJ1cphj76rzJ8Dyv7p_serviceEndpoint__array ) { if (v == null) continue; _2KM4fetG6FTJ1cphj76rzJ8Dyv7p_serviceEndpoint.push(new URL(v[\\"@id\\"])) _2KM4fetG6FTJ1cphj76rzJ8Dyv7p_serviceEndpoint.push(v[\\"@id\\"].startsWith(\\"at://did:plc:\\") ? new URL(\\"at://did%3Aplc%3A\\" + v[\\"@id\\"].slice(13)) : new URL(v[\\"@id\\"])) } instance.#_2KM4fetG6FTJ1cphj76rzJ8Dyv7p_serviceEndpoint = _2KM4fetG6FTJ1cphj76rzJ8Dyv7p_serviceEndpoint; Loading Loading @@ -23434,7 +23438,9 @@ proxyUrl?: URL | null;oauthAuthorizationEndpoint?: URL | null;oauthTokenEndpoint : _2JCYDbSxEHCCLdBYed33cCETfGyR_proxyUrl__array ) { if (v == null) continue; _2JCYDbSxEHCCLdBYed33cCETfGyR_proxyUrl.push(new URL(v[\\"@id\\"])) _2JCYDbSxEHCCLdBYed33cCETfGyR_proxyUrl.push(v[\\"@id\\"].startsWith(\\"at://did:plc:\\") ? new URL(\\"at://did%3Aplc%3A\\" + v[\\"@id\\"].slice(13)) : new URL(v[\\"@id\\"])) } instance.#_2JCYDbSxEHCCLdBYed33cCETfGyR_proxyUrl = _2JCYDbSxEHCCLdBYed33cCETfGyR_proxyUrl; const _25S6UmgzDead8hxL5sQFezZTAusd_oauthAuthorizationEndpoint: (URL)[] = []; Loading @@ -23449,7 +23455,9 @@ proxyUrl?: URL | null;oauthAuthorizationEndpoint?: URL | null;oauthTokenEndpoint : _25S6UmgzDead8hxL5sQFezZTAusd_oauthAuthorizationEndpoint__array ) { if (v == null) continue; _25S6UmgzDead8hxL5sQFezZTAusd_oauthAuthorizationEndpoint.push(new URL(v[\\"@id\\"])) _25S6UmgzDead8hxL5sQFezZTAusd_oauthAuthorizationEndpoint.push(v[\\"@id\\"].startsWith(\\"at://did:plc:\\") ? new URL(\\"at://did%3Aplc%3A\\" + v[\\"@id\\"].slice(13)) : new URL(v[\\"@id\\"])) } instance.#_25S6UmgzDead8hxL5sQFezZTAusd_oauthAuthorizationEndpoint = _25S6UmgzDead8hxL5sQFezZTAusd_oauthAuthorizationEndpoint; const _iAMxqrSba7yBCRB1FZ5kEVdKEZ3_oauthTokenEndpoint: (URL)[] = []; Loading @@ -23464,7 +23472,9 @@ proxyUrl?: URL | null;oauthAuthorizationEndpoint?: URL | null;oauthTokenEndpoint : _iAMxqrSba7yBCRB1FZ5kEVdKEZ3_oauthTokenEndpoint__array ) { if (v == null) continue; _iAMxqrSba7yBCRB1FZ5kEVdKEZ3_oauthTokenEndpoint.push(new URL(v[\\"@id\\"])) _iAMxqrSba7yBCRB1FZ5kEVdKEZ3_oauthTokenEndpoint.push(v[\\"@id\\"].startsWith(\\"at://did:plc:\\") ? new URL(\\"at://did%3Aplc%3A\\" + v[\\"@id\\"].slice(13)) : new URL(v[\\"@id\\"])) } instance.#_iAMxqrSba7yBCRB1FZ5kEVdKEZ3_oauthTokenEndpoint = _iAMxqrSba7yBCRB1FZ5kEVdKEZ3_oauthTokenEndpoint; const _8Bx9qN8oU7Bpt2xi6khaxWp1gMr_provideClientKey: (URL)[] = []; Loading @@ -23479,7 +23489,9 @@ proxyUrl?: URL | null;oauthAuthorizationEndpoint?: URL | null;oauthTokenEndpoint : _8Bx9qN8oU7Bpt2xi6khaxWp1gMr_provideClientKey__array ) { if (v == null) continue; _8Bx9qN8oU7Bpt2xi6khaxWp1gMr_provideClientKey.push(new URL(v[\\"@id\\"])) _8Bx9qN8oU7Bpt2xi6khaxWp1gMr_provideClientKey.push(v[\\"@id\\"].startsWith(\\"at://did:plc:\\") ? new URL(\\"at://did%3Aplc%3A\\" + v[\\"@id\\"].slice(13)) : new URL(v[\\"@id\\"])) } instance.#_8Bx9qN8oU7Bpt2xi6khaxWp1gMr_provideClientKey = _8Bx9qN8oU7Bpt2xi6khaxWp1gMr_provideClientKey; const _3dU7PMVQZJpsCpo2F4RQXxBXdPmS_signClientKey: (URL)[] = []; Loading @@ -23494,7 +23506,9 @@ proxyUrl?: URL | null;oauthAuthorizationEndpoint?: URL | null;oauthTokenEndpoint : _3dU7PMVQZJpsCpo2F4RQXxBXdPmS_signClientKey__array ) { if (v == null) continue; _3dU7PMVQZJpsCpo2F4RQXxBXdPmS_signClientKey.push(new URL(v[\\"@id\\"])) _3dU7PMVQZJpsCpo2F4RQXxBXdPmS_signClientKey.push(v[\\"@id\\"].startsWith(\\"at://did:plc:\\") ? new URL(\\"at://did%3Aplc%3A\\" + v[\\"@id\\"].slice(13)) : new URL(v[\\"@id\\"])) } instance.#_3dU7PMVQZJpsCpo2F4RQXxBXdPmS_signClientKey = _3dU7PMVQZJpsCpo2F4RQXxBXdPmS_signClientKey; const _3JprUSDLVqqX4dwHRi37qGZZCRCc_sharedInbox: (URL)[] = []; Loading @@ -23509,7 +23523,9 @@ proxyUrl?: URL | null;oauthAuthorizationEndpoint?: URL | null;oauthTokenEndpoint : _3JprUSDLVqqX4dwHRi37qGZZCRCc_sharedInbox__array ) { if (v == null) continue; _3JprUSDLVqqX4dwHRi37qGZZCRCc_sharedInbox.push(new URL(v[\\"@id\\"])) _3JprUSDLVqqX4dwHRi37qGZZCRCc_sharedInbox.push(v[\\"@id\\"].startsWith(\\"at://did:plc:\\") ? new URL(\\"at://did%3Aplc%3A\\" + v[\\"@id\\"].slice(13)) : new URL(v[\\"@id\\"])) } instance.#_3JprUSDLVqqX4dwHRi37qGZZCRCc_sharedInbox = _3JprUSDLVqqX4dwHRi37qGZZCRCc_sharedInbox; Loading Loading @@ -29731,7 +29747,9 @@ get names(): ((string | LanguageString))[] { : _pVjLsybKQdmkjuU7MHjiVmNnuj7_href__array ) { if (v == null) continue; _pVjLsybKQdmkjuU7MHjiVmNnuj7_href.push(new URL(v[\\"@id\\"])) _pVjLsybKQdmkjuU7MHjiVmNnuj7_href.push(v[\\"@id\\"].startsWith(\\"at://did:plc:\\") ? new URL(\\"at://did%3Aplc%3A\\" + v[\\"@id\\"].slice(13)) : new URL(v[\\"@id\\"])) } instance.#_pVjLsybKQdmkjuU7MHjiVmNnuj7_href = _pVjLsybKQdmkjuU7MHjiVmNnuj7_href; const _2a1c5GkfkQsnyyLybF8UXBQfFuHZ_rel: (string)[] = []; Loading Loading @@ -43748,7 +43766,9 @@ proofs?: (DataIntegrityProof | URL)[];accuracy?: number | null;altitude?: number typeof v === \\"object\\" && \\"@value\\" in v && (v[\\"@value\\"] == \\"cm\\" || v[\\"@value\\"] == \\"feet\\" || v[\\"@value\\"] == \\"inches\\" || v[\\"@value\\"] == \\"km\\" || v[\\"@value\\"] == \\"m\\" || v[\\"@value\\"] == \\"miles\\") ? v[\\"@value\\"] : typeof v === \\"object\\" && \\"@id\\" in v && typeof v[\\"@id\\"] === \\"string\\" && v[\\"@id\\"] !== \\"\\" && v[\\"@id\\"] !== \\"/\\" ? new URL(v[\\"@id\\"]) : undefined && v[\\"@id\\"] !== \\"\\" && v[\\"@id\\"] !== \\"/\\" ? v[\\"@id\\"].startsWith(\\"at://did:plc:\\") ? new URL(\\"at://did%3Aplc%3A\\" + v[\\"@id\\"].slice(13)) : new URL(v[\\"@id\\"]) : undefined ; if (typeof decoded === \\"undefined\\") continue; _oKrwxU4V8wiKhMW1QEYQibcJh8c_units.push(decoded); src/codegen/type.ts +3 −1 Original line number Diff line number Diff line Loading @@ -144,7 +144,9 @@ const scalarTypes: Record<string, ScalarType> = { && ${v}["@id"] !== "" && ${v}["@id"] !== "/"`; }, decoder(v) { return `new URL(${v}["@id"])`; return `${v}["@id"].startsWith("at://did:plc:") ? new URL("at://did%3Aplc%3A" + ${v}["@id"].slice(13)) : new URL(${v}["@id"])`; }, }, "http://www.w3.org/1999/02/22-rdf-syntax-ns#langString": { Loading src/vocab/vocab.test.ts +18 −0 Original line number Diff line number Diff line Loading @@ -32,6 +32,7 @@ import { type DataIntegrityProof, Follow, Hashtag, Link, Note, Object, OrderedCollectionPage, Loading Loading @@ -787,6 +788,23 @@ test("Actor.getOutbox()", async () => { assertEquals(outbox.totalItems, 1); }); test("Link.fromJsonLd()", async () => { const link = await Link.fromJsonLd({ "@context": "https://www.w3.org/ns/activitystreams", "type": "Link", "rel": "canonical", "href": "at://did:plc:ia76kvnndjutgedggx2ibrem/app.bsky.feed.post/3lyxjjs27jkqg", }); assertEquals(link.rel, "canonical"); assertEquals( link.href, new URL( "at://did%3Aplc%3Aia76kvnndjutgedggx2ibrem/app.bsky.feed.post/3lyxjjs27jkqg", ), ); }); function getAllProperties( type: TypeSchema, types: Record<string, TypeSchema>, Loading Loading
CHANGES.md +29 −0 Original line number Diff line number Diff line Loading @@ -8,6 +8,11 @@ Version 1.2.26 To be released. - Added a temporary workaround for invalid AT Protocol URIs from BridgyFed. URIs like `at://did:plc:...` that violate RFC 3986 URI syntax are now automatically URL-encoded to `at://did%3Aplc%3A...` to prevent parsing failures when processing bridged Bluesky content. [[#436]] Version 1.2.25 -------------- Loading Loading @@ -446,6 +451,17 @@ Released on October 31, 2024. [#118]: https://github.com/dahlia/fedify/issues/118 Version 1.1.26 -------------- Released on September 17, 2025. - Added a temporary workaround for invalid AT Protocol URIs from BridgyFed. URIs like `at://did:plc:...` that violate RFC 3986 URI syntax are now automatically URL-encoded to `at://did%3Aplc%3A...` to prevent parsing failures when processing bridged Bluesky content. [[#436]] Version 1.1.25 -------------- Loading Loading @@ -924,6 +940,19 @@ Released on October 20, 2024. [#150]: https://github.com/dahlia/fedify/issues/150 Version 1.0.29 -------------- Released on September 17, 2025. - Added a temporary workaround for invalid AT Protocol URIs from BridgyFed. URIs like `at://did:plc:...` that violate RFC 3986 URI syntax are now automatically URL-encoded to `at://did%3Aplc%3A...` to prevent parsing failures when processing bridged Bluesky content. [[#436]] [#436]: https://github.com/fedify-dev/fedify/issues/436 Version 1.0.28 -------------- Loading
src/codegen/__snapshots__/class.test.ts.snap +30 −10 Original line number Diff line number Diff line Loading @@ -5649,7 +5649,9 @@ get urls(): ((URL | Link))[] { const decoded = typeof v === \\"object\\" && \\"@id\\" in v && typeof v[\\"@id\\"] === \\"string\\" && v[\\"@id\\"] !== \\"\\" && v[\\"@id\\"] !== \\"/\\" ? new URL(v[\\"@id\\"]) : typeof v === \\"object\\" && \\"@type\\" in v && v[\\"@id\\"] !== \\"\\" && v[\\"@id\\"] !== \\"/\\" ? v[\\"@id\\"].startsWith(\\"at://did:plc:\\") ? new URL(\\"at://did%3Aplc%3A\\" + v[\\"@id\\"].slice(13)) : new URL(v[\\"@id\\"]) : typeof v === \\"object\\" && \\"@type\\" in v && Array.isArray(v[\\"@type\\"])&& [\\"https://www.w3.org/ns/activitystreams#Link\\",\\"https://www.w3.org/ns/activitystreams#Hashtag\\",\\"https://www.w3.org/ns/activitystreams#Mention\\"].some( t => v[\\"@type\\"].includes(t)) ? await Link.fromJsonLd( v, options) : undefined Loading Loading @@ -10342,7 +10344,9 @@ get endpoints(): (URL)[] { : _2KM4fetG6FTJ1cphj76rzJ8Dyv7p_serviceEndpoint__array ) { if (v == null) continue; _2KM4fetG6FTJ1cphj76rzJ8Dyv7p_serviceEndpoint.push(new URL(v[\\"@id\\"])) _2KM4fetG6FTJ1cphj76rzJ8Dyv7p_serviceEndpoint.push(v[\\"@id\\"].startsWith(\\"at://did:plc:\\") ? new URL(\\"at://did%3Aplc%3A\\" + v[\\"@id\\"].slice(13)) : new URL(v[\\"@id\\"])) } instance.#_2KM4fetG6FTJ1cphj76rzJ8Dyv7p_serviceEndpoint = _2KM4fetG6FTJ1cphj76rzJ8Dyv7p_serviceEndpoint; Loading Loading @@ -23434,7 +23438,9 @@ proxyUrl?: URL | null;oauthAuthorizationEndpoint?: URL | null;oauthTokenEndpoint : _2JCYDbSxEHCCLdBYed33cCETfGyR_proxyUrl__array ) { if (v == null) continue; _2JCYDbSxEHCCLdBYed33cCETfGyR_proxyUrl.push(new URL(v[\\"@id\\"])) _2JCYDbSxEHCCLdBYed33cCETfGyR_proxyUrl.push(v[\\"@id\\"].startsWith(\\"at://did:plc:\\") ? new URL(\\"at://did%3Aplc%3A\\" + v[\\"@id\\"].slice(13)) : new URL(v[\\"@id\\"])) } instance.#_2JCYDbSxEHCCLdBYed33cCETfGyR_proxyUrl = _2JCYDbSxEHCCLdBYed33cCETfGyR_proxyUrl; const _25S6UmgzDead8hxL5sQFezZTAusd_oauthAuthorizationEndpoint: (URL)[] = []; Loading @@ -23449,7 +23455,9 @@ proxyUrl?: URL | null;oauthAuthorizationEndpoint?: URL | null;oauthTokenEndpoint : _25S6UmgzDead8hxL5sQFezZTAusd_oauthAuthorizationEndpoint__array ) { if (v == null) continue; _25S6UmgzDead8hxL5sQFezZTAusd_oauthAuthorizationEndpoint.push(new URL(v[\\"@id\\"])) _25S6UmgzDead8hxL5sQFezZTAusd_oauthAuthorizationEndpoint.push(v[\\"@id\\"].startsWith(\\"at://did:plc:\\") ? new URL(\\"at://did%3Aplc%3A\\" + v[\\"@id\\"].slice(13)) : new URL(v[\\"@id\\"])) } instance.#_25S6UmgzDead8hxL5sQFezZTAusd_oauthAuthorizationEndpoint = _25S6UmgzDead8hxL5sQFezZTAusd_oauthAuthorizationEndpoint; const _iAMxqrSba7yBCRB1FZ5kEVdKEZ3_oauthTokenEndpoint: (URL)[] = []; Loading @@ -23464,7 +23472,9 @@ proxyUrl?: URL | null;oauthAuthorizationEndpoint?: URL | null;oauthTokenEndpoint : _iAMxqrSba7yBCRB1FZ5kEVdKEZ3_oauthTokenEndpoint__array ) { if (v == null) continue; _iAMxqrSba7yBCRB1FZ5kEVdKEZ3_oauthTokenEndpoint.push(new URL(v[\\"@id\\"])) _iAMxqrSba7yBCRB1FZ5kEVdKEZ3_oauthTokenEndpoint.push(v[\\"@id\\"].startsWith(\\"at://did:plc:\\") ? new URL(\\"at://did%3Aplc%3A\\" + v[\\"@id\\"].slice(13)) : new URL(v[\\"@id\\"])) } instance.#_iAMxqrSba7yBCRB1FZ5kEVdKEZ3_oauthTokenEndpoint = _iAMxqrSba7yBCRB1FZ5kEVdKEZ3_oauthTokenEndpoint; const _8Bx9qN8oU7Bpt2xi6khaxWp1gMr_provideClientKey: (URL)[] = []; Loading @@ -23479,7 +23489,9 @@ proxyUrl?: URL | null;oauthAuthorizationEndpoint?: URL | null;oauthTokenEndpoint : _8Bx9qN8oU7Bpt2xi6khaxWp1gMr_provideClientKey__array ) { if (v == null) continue; _8Bx9qN8oU7Bpt2xi6khaxWp1gMr_provideClientKey.push(new URL(v[\\"@id\\"])) _8Bx9qN8oU7Bpt2xi6khaxWp1gMr_provideClientKey.push(v[\\"@id\\"].startsWith(\\"at://did:plc:\\") ? new URL(\\"at://did%3Aplc%3A\\" + v[\\"@id\\"].slice(13)) : new URL(v[\\"@id\\"])) } instance.#_8Bx9qN8oU7Bpt2xi6khaxWp1gMr_provideClientKey = _8Bx9qN8oU7Bpt2xi6khaxWp1gMr_provideClientKey; const _3dU7PMVQZJpsCpo2F4RQXxBXdPmS_signClientKey: (URL)[] = []; Loading @@ -23494,7 +23506,9 @@ proxyUrl?: URL | null;oauthAuthorizationEndpoint?: URL | null;oauthTokenEndpoint : _3dU7PMVQZJpsCpo2F4RQXxBXdPmS_signClientKey__array ) { if (v == null) continue; _3dU7PMVQZJpsCpo2F4RQXxBXdPmS_signClientKey.push(new URL(v[\\"@id\\"])) _3dU7PMVQZJpsCpo2F4RQXxBXdPmS_signClientKey.push(v[\\"@id\\"].startsWith(\\"at://did:plc:\\") ? new URL(\\"at://did%3Aplc%3A\\" + v[\\"@id\\"].slice(13)) : new URL(v[\\"@id\\"])) } instance.#_3dU7PMVQZJpsCpo2F4RQXxBXdPmS_signClientKey = _3dU7PMVQZJpsCpo2F4RQXxBXdPmS_signClientKey; const _3JprUSDLVqqX4dwHRi37qGZZCRCc_sharedInbox: (URL)[] = []; Loading @@ -23509,7 +23523,9 @@ proxyUrl?: URL | null;oauthAuthorizationEndpoint?: URL | null;oauthTokenEndpoint : _3JprUSDLVqqX4dwHRi37qGZZCRCc_sharedInbox__array ) { if (v == null) continue; _3JprUSDLVqqX4dwHRi37qGZZCRCc_sharedInbox.push(new URL(v[\\"@id\\"])) _3JprUSDLVqqX4dwHRi37qGZZCRCc_sharedInbox.push(v[\\"@id\\"].startsWith(\\"at://did:plc:\\") ? new URL(\\"at://did%3Aplc%3A\\" + v[\\"@id\\"].slice(13)) : new URL(v[\\"@id\\"])) } instance.#_3JprUSDLVqqX4dwHRi37qGZZCRCc_sharedInbox = _3JprUSDLVqqX4dwHRi37qGZZCRCc_sharedInbox; Loading Loading @@ -29731,7 +29747,9 @@ get names(): ((string | LanguageString))[] { : _pVjLsybKQdmkjuU7MHjiVmNnuj7_href__array ) { if (v == null) continue; _pVjLsybKQdmkjuU7MHjiVmNnuj7_href.push(new URL(v[\\"@id\\"])) _pVjLsybKQdmkjuU7MHjiVmNnuj7_href.push(v[\\"@id\\"].startsWith(\\"at://did:plc:\\") ? new URL(\\"at://did%3Aplc%3A\\" + v[\\"@id\\"].slice(13)) : new URL(v[\\"@id\\"])) } instance.#_pVjLsybKQdmkjuU7MHjiVmNnuj7_href = _pVjLsybKQdmkjuU7MHjiVmNnuj7_href; const _2a1c5GkfkQsnyyLybF8UXBQfFuHZ_rel: (string)[] = []; Loading Loading @@ -43748,7 +43766,9 @@ proofs?: (DataIntegrityProof | URL)[];accuracy?: number | null;altitude?: number typeof v === \\"object\\" && \\"@value\\" in v && (v[\\"@value\\"] == \\"cm\\" || v[\\"@value\\"] == \\"feet\\" || v[\\"@value\\"] == \\"inches\\" || v[\\"@value\\"] == \\"km\\" || v[\\"@value\\"] == \\"m\\" || v[\\"@value\\"] == \\"miles\\") ? v[\\"@value\\"] : typeof v === \\"object\\" && \\"@id\\" in v && typeof v[\\"@id\\"] === \\"string\\" && v[\\"@id\\"] !== \\"\\" && v[\\"@id\\"] !== \\"/\\" ? new URL(v[\\"@id\\"]) : undefined && v[\\"@id\\"] !== \\"\\" && v[\\"@id\\"] !== \\"/\\" ? v[\\"@id\\"].startsWith(\\"at://did:plc:\\") ? new URL(\\"at://did%3Aplc%3A\\" + v[\\"@id\\"].slice(13)) : new URL(v[\\"@id\\"]) : undefined ; if (typeof decoded === \\"undefined\\") continue; _oKrwxU4V8wiKhMW1QEYQibcJh8c_units.push(decoded);
src/codegen/type.ts +3 −1 Original line number Diff line number Diff line Loading @@ -144,7 +144,9 @@ const scalarTypes: Record<string, ScalarType> = { && ${v}["@id"] !== "" && ${v}["@id"] !== "/"`; }, decoder(v) { return `new URL(${v}["@id"])`; return `${v}["@id"].startsWith("at://did:plc:") ? new URL("at://did%3Aplc%3A" + ${v}["@id"].slice(13)) : new URL(${v}["@id"])`; }, }, "http://www.w3.org/1999/02/22-rdf-syntax-ns#langString": { Loading
src/vocab/vocab.test.ts +18 −0 Original line number Diff line number Diff line Loading @@ -32,6 +32,7 @@ import { type DataIntegrityProof, Follow, Hashtag, Link, Note, Object, OrderedCollectionPage, Loading Loading @@ -787,6 +788,23 @@ test("Actor.getOutbox()", async () => { assertEquals(outbox.totalItems, 1); }); test("Link.fromJsonLd()", async () => { const link = await Link.fromJsonLd({ "@context": "https://www.w3.org/ns/activitystreams", "type": "Link", "rel": "canonical", "href": "at://did:plc:ia76kvnndjutgedggx2ibrem/app.bsky.feed.post/3lyxjjs27jkqg", }); assertEquals(link.rel, "canonical"); assertEquals( link.href, new URL( "at://did%3Aplc%3Aia76kvnndjutgedggx2ibrem/app.bsky.feed.post/3lyxjjs27jkqg", ), ); }); function getAllProperties( type: TypeSchema, types: Record<string, TypeSchema>, Loading