@fedify/fedify 1.2.19 → 1.2.21

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (40) hide show
  1. package/CHANGES.md +93 -0
  2. package/esm/deps/jsr.io/@std/encoding/1.0.7/_validate_binary_like.js +26 -0
  3. package/esm/deps/jsr.io/@std/encoding/1.0.7/base64.js +163 -0
  4. package/esm/deps/jsr.io/@std/encoding/1.0.7/base64url.js +81 -0
  5. package/esm/deps/jsr.io/@std/encoding/1.0.7/hex.js +109 -0
  6. package/esm/federation/collection.js +1 -1
  7. package/esm/federation/handler.js +1 -1
  8. package/esm/runtime/key.js +3 -3
  9. package/esm/sig/http.js +1 -1
  10. package/esm/sig/ld.js +2 -2
  11. package/esm/vocab/undo.yaml +4 -0
  12. package/esm/vocab/vocab.js +30 -8
  13. package/package.json +1 -1
  14. package/types/deps/jsr.io/@std/encoding/{1.0.8 → 1.0.7}/_types.d.ts.map +1 -1
  15. package/types/deps/jsr.io/@std/encoding/1.0.7/_validate_binary_like.d.ts +2 -0
  16. package/types/deps/jsr.io/@std/encoding/1.0.7/_validate_binary_like.d.ts.map +1 -0
  17. package/types/deps/jsr.io/@std/encoding/1.0.7/base64.d.ts.map +1 -0
  18. package/types/deps/jsr.io/@std/encoding/1.0.7/base64url.d.ts.map +1 -0
  19. package/types/deps/jsr.io/@std/encoding/1.0.7/hex.d.ts.map +1 -0
  20. package/types/vocab/vocab.d.ts.map +1 -1
  21. package/esm/deps/jsr.io/@std/encoding/1.0.8/_common16.js +0 -45
  22. package/esm/deps/jsr.io/@std/encoding/1.0.8/_common64.js +0 -98
  23. package/esm/deps/jsr.io/@std/encoding/1.0.8/_common_detach.js +0 -13
  24. package/esm/deps/jsr.io/@std/encoding/1.0.8/base64.js +0 -82
  25. package/esm/deps/jsr.io/@std/encoding/1.0.8/base64url.js +0 -72
  26. package/esm/deps/jsr.io/@std/encoding/1.0.8/hex.js +0 -87
  27. package/types/deps/jsr.io/@std/encoding/1.0.8/_common16.d.ts +0 -21
  28. package/types/deps/jsr.io/@std/encoding/1.0.8/_common16.d.ts.map +0 -1
  29. package/types/deps/jsr.io/@std/encoding/1.0.8/_common64.d.ts +0 -21
  30. package/types/deps/jsr.io/@std/encoding/1.0.8/_common64.d.ts.map +0 -1
  31. package/types/deps/jsr.io/@std/encoding/1.0.8/_common_detach.d.ts +0 -4
  32. package/types/deps/jsr.io/@std/encoding/1.0.8/_common_detach.d.ts.map +0 -1
  33. package/types/deps/jsr.io/@std/encoding/1.0.8/base64.d.ts.map +0 -1
  34. package/types/deps/jsr.io/@std/encoding/1.0.8/base64url.d.ts.map +0 -1
  35. package/types/deps/jsr.io/@std/encoding/1.0.8/hex.d.ts.map +0 -1
  36. /package/esm/deps/jsr.io/@std/encoding/{1.0.8 → 1.0.7}/_types.js +0 -0
  37. /package/types/deps/jsr.io/@std/encoding/{1.0.8 → 1.0.7}/_types.d.ts +0 -0
  38. /package/types/deps/jsr.io/@std/encoding/{1.0.8 → 1.0.7}/base64.d.ts +0 -0
  39. /package/types/deps/jsr.io/@std/encoding/{1.0.8 → 1.0.7}/base64url.d.ts +0 -0
  40. /package/types/deps/jsr.io/@std/encoding/{1.0.8 → 1.0.7}/hex.d.ts +0 -0
package/CHANGES.md CHANGED
@@ -3,6 +3,39 @@
3
3
  Fedify changelog
4
4
  ================
5
5
 
6
+ Version 1.2.21
7
+ --------------
8
+
9
+ Released on April 8, 2025.
10
+
11
+ - Activity Vocabulary API became to accept [RFC 3339] date-time strings
12
+ without a timezone offset. This is not a bug fix, but improves
13
+ interoperability with some implementations that do not include a timezone
14
+ offset in their date-time strings including WordPress. [[#226]]
15
+
16
+ - Added the following default context to `Undo` class:
17
+
18
+ ~~~~ json
19
+ {
20
+ "litepub": "http://litepub.social/ns#",
21
+ "toot": "http://joinmastodon.org/ns#",
22
+ "EmojiReact": "litepub:EmojiReact",
23
+ "Emoji": "toot:Emoji"
24
+ }
25
+ ~~~~
26
+
27
+
28
+ Version 1.2.20
29
+ --------------
30
+
31
+ Released on March 26, 2025.
32
+
33
+ - Fixed a `TypeError` thrown by the followers collection dispatcher when
34
+ the `base-url` parameter was provided.
35
+ - Fixed a `TypeError` thrown by the `signRequest()` function on Node.js.
36
+ [[#222]]
37
+
38
+
6
39
  Version 1.2.19
7
40
  --------------
8
41
 
@@ -358,6 +391,39 @@ Released on October 31, 2024.
358
391
  [#118]: https://github.com/dahlia/fedify/issues/118
359
392
 
360
393
 
394
+ Version 1.1.21
395
+ --------------
396
+
397
+ Released on April 8, 2025.
398
+
399
+ - Activity Vocabulary API became to accept [RFC 3339] date-time strings
400
+ without a timezone offset. This is not a bug fix, but improves
401
+ interoperability with some implementations that do not include a timezone
402
+ offset in their date-time strings including WordPress. [[#226]]
403
+
404
+ - Added the following default context to `Undo` class:
405
+
406
+ ~~~~ json
407
+ {
408
+ "litepub": "http://litepub.social/ns#",
409
+ "toot": "http://joinmastodon.org/ns#",
410
+ "EmojiReact": "litepub:EmojiReact",
411
+ "Emoji": "toot:Emoji"
412
+ }
413
+ ~~~~
414
+
415
+
416
+ Version 1.1.20
417
+ --------------
418
+
419
+ Released on March 26, 2025.
420
+
421
+ - Fixed a `TypeError` thrown by the followers collection dispatcher when
422
+ the `base-url` parameter was provided.
423
+ - Fixed a `TypeError` thrown by the `signRequest()` function on Node.js.
424
+ [[#222]]
425
+
426
+
361
427
  Version 1.1.19
362
428
  --------------
363
429
 
@@ -754,6 +820,33 @@ Released on October 20, 2024.
754
820
  [#150]: https://github.com/dahlia/fedify/issues/150
755
821
 
756
822
 
823
+ Version 1.0.24
824
+ --------------
825
+
826
+ Released on April 8, 2025.
827
+
828
+ - Activity Vocabulary API became to accept [RFC 3339] date-time strings
829
+ without a timezone offset. This is not a bug fix, but improves
830
+ interoperability with some implementations that do not include a timezone
831
+ offset in their date-time strings including WordPress. [[#226]]
832
+
833
+ [RFC 3339]: https://datatracker.ietf.org/doc/html/rfc3339
834
+ [#226]: https://github.com/fedify-dev/fedify/issues/226
835
+
836
+
837
+ Version 1.0.23
838
+ --------------
839
+
840
+ Released on March 26, 2025.
841
+
842
+ - Fixed a `TypeError` thrown by the followers collection dispatcher when
843
+ the `base-url` parameter was provided.
844
+ - Fixed a `TypeError` thrown by the `signRequest()` function on Node.js.
845
+ [[#222]]
846
+
847
+ [#222]: https://github.com/fedify-dev/fedify/issues/222
848
+
849
+
757
850
  Version 1.0.22
758
851
  --------------
759
852
 
@@ -0,0 +1,26 @@
1
+ // Copyright 2018-2025 the Deno authors. MIT license.
2
+ const encoder = new TextEncoder();
3
+ function getTypeName(value) {
4
+ const type = typeof value;
5
+ if (type !== "object") {
6
+ return type;
7
+ }
8
+ else if (value === null) {
9
+ return "null";
10
+ }
11
+ else {
12
+ return value?.constructor?.name ?? "object";
13
+ }
14
+ }
15
+ export function validateBinaryLike(source) {
16
+ if (typeof source === "string") {
17
+ return encoder.encode(source);
18
+ }
19
+ else if (source instanceof Uint8Array) {
20
+ return source;
21
+ }
22
+ else if (source instanceof ArrayBuffer) {
23
+ return new Uint8Array(source);
24
+ }
25
+ throw new TypeError(`Cannot validate the input as it must be a Uint8Array, a string, or an ArrayBuffer: received a value of the type ${getTypeName(source)}`);
26
+ }
@@ -0,0 +1,163 @@
1
+ // Copyright 2018-2025 the Deno authors. MIT license.
2
+ // This module is browser compatible.
3
+ /**
4
+ * Utilities for
5
+ * {@link https://www.rfc-editor.org/rfc/rfc4648.html#section-4 | base64}
6
+ * encoding and decoding.
7
+ *
8
+ * ```ts
9
+ * import {
10
+ * encodeBase64,
11
+ * decodeBase64,
12
+ * } from "@std/encoding/base64";
13
+ * import { assertEquals } from "@std/assert";
14
+ *
15
+ * const foobar = new TextEncoder().encode("foobar");
16
+ *
17
+ * assertEquals(encodeBase64(foobar), "Zm9vYmFy");
18
+ * assertEquals(decodeBase64("Zm9vYmFy"), foobar);
19
+ * ```
20
+ *
21
+ * @module
22
+ */
23
+ import { validateBinaryLike } from "./_validate_binary_like.js";
24
+ const base64abc = [
25
+ "A",
26
+ "B",
27
+ "C",
28
+ "D",
29
+ "E",
30
+ "F",
31
+ "G",
32
+ "H",
33
+ "I",
34
+ "J",
35
+ "K",
36
+ "L",
37
+ "M",
38
+ "N",
39
+ "O",
40
+ "P",
41
+ "Q",
42
+ "R",
43
+ "S",
44
+ "T",
45
+ "U",
46
+ "V",
47
+ "W",
48
+ "X",
49
+ "Y",
50
+ "Z",
51
+ "a",
52
+ "b",
53
+ "c",
54
+ "d",
55
+ "e",
56
+ "f",
57
+ "g",
58
+ "h",
59
+ "i",
60
+ "j",
61
+ "k",
62
+ "l",
63
+ "m",
64
+ "n",
65
+ "o",
66
+ "p",
67
+ "q",
68
+ "r",
69
+ "s",
70
+ "t",
71
+ "u",
72
+ "v",
73
+ "w",
74
+ "x",
75
+ "y",
76
+ "z",
77
+ "0",
78
+ "1",
79
+ "2",
80
+ "3",
81
+ "4",
82
+ "5",
83
+ "6",
84
+ "7",
85
+ "8",
86
+ "9",
87
+ "+",
88
+ "/",
89
+ ];
90
+ /**
91
+ * Converts data into a base64-encoded string.
92
+ *
93
+ * @see {@link https://www.rfc-editor.org/rfc/rfc4648.html#section-4}
94
+ *
95
+ * @param data The data to encode.
96
+ * @returns The base64-encoded string.
97
+ *
98
+ * @example Usage
99
+ * ```ts
100
+ * import { encodeBase64 } from "@std/encoding/base64";
101
+ * import { assertEquals } from "@std/assert";
102
+ *
103
+ * assertEquals(encodeBase64("foobar"), "Zm9vYmFy");
104
+ * ```
105
+ */
106
+ export function encodeBase64(data) {
107
+ // CREDIT: https://gist.github.com/enepomnyaschih/72c423f727d395eeaa09697058238727
108
+ const uint8 = validateBinaryLike(data);
109
+ let result = "";
110
+ let i;
111
+ const l = uint8.length;
112
+ for (i = 2; i < l; i += 3) {
113
+ result += base64abc[(uint8[i - 2]) >> 2];
114
+ result += base64abc[(((uint8[i - 2]) & 0x03) << 4) |
115
+ ((uint8[i - 1]) >> 4)];
116
+ result += base64abc[(((uint8[i - 1]) & 0x0f) << 2) |
117
+ ((uint8[i]) >> 6)];
118
+ result += base64abc[(uint8[i]) & 0x3f];
119
+ }
120
+ if (i === l + 1) {
121
+ // 1 octet yet to write
122
+ result += base64abc[(uint8[i - 2]) >> 2];
123
+ result += base64abc[((uint8[i - 2]) & 0x03) << 4];
124
+ result += "==";
125
+ }
126
+ if (i === l) {
127
+ // 2 octets yet to write
128
+ result += base64abc[(uint8[i - 2]) >> 2];
129
+ result += base64abc[(((uint8[i - 2]) & 0x03) << 4) |
130
+ ((uint8[i - 1]) >> 4)];
131
+ result += base64abc[((uint8[i - 1]) & 0x0f) << 2];
132
+ result += "=";
133
+ }
134
+ return result;
135
+ }
136
+ /**
137
+ * Decodes a base64-encoded string.
138
+ *
139
+ * @see {@link https://www.rfc-editor.org/rfc/rfc4648.html#section-4}
140
+ *
141
+ * @param b64 The base64-encoded string to decode.
142
+ * @returns The decoded data.
143
+ *
144
+ * @example Usage
145
+ * ```ts
146
+ * import { decodeBase64 } from "@std/encoding/base64";
147
+ * import { assertEquals } from "@std/assert";
148
+ *
149
+ * assertEquals(
150
+ * decodeBase64("Zm9vYmFy"),
151
+ * new TextEncoder().encode("foobar")
152
+ * );
153
+ * ```
154
+ */
155
+ export function decodeBase64(b64) {
156
+ const binString = atob(b64);
157
+ const size = binString.length;
158
+ const bytes = new Uint8Array(size);
159
+ for (let i = 0; i < size; i++) {
160
+ bytes[i] = binString.charCodeAt(i);
161
+ }
162
+ return bytes;
163
+ }
@@ -0,0 +1,81 @@
1
+ // Copyright 2018-2025 the Deno authors. MIT license.
2
+ // This module is browser compatible.
3
+ /**
4
+ * Utilities for
5
+ * {@link https://www.rfc-editor.org/rfc/rfc4648.html#section-5 | base64url}
6
+ * encoding and decoding.
7
+ *
8
+ * @module
9
+ */
10
+ import * as base64 from "./base64.js";
11
+ /**
12
+ * Some variants allow or require omitting the padding '=' signs:
13
+ * https://en.wikipedia.org/wiki/Base64#The_URL_applications
14
+ *
15
+ * @param base64url
16
+ */
17
+ function addPaddingToBase64url(base64url) {
18
+ if (base64url.length % 4 === 2)
19
+ return base64url + "==";
20
+ if (base64url.length % 4 === 3)
21
+ return base64url + "=";
22
+ if (base64url.length % 4 === 1) {
23
+ throw new TypeError("Illegal base64url string");
24
+ }
25
+ return base64url;
26
+ }
27
+ function convertBase64urlToBase64(b64url) {
28
+ if (!/^[-_A-Z0-9]*?={0,2}$/i.test(b64url)) {
29
+ // Contains characters not part of base64url spec.
30
+ throw new TypeError("Failed to decode base64url: invalid character");
31
+ }
32
+ return addPaddingToBase64url(b64url).replace(/\-/g, "+").replace(/_/g, "/");
33
+ }
34
+ function convertBase64ToBase64url(b64) {
35
+ return b64.endsWith("=")
36
+ ? b64.endsWith("==")
37
+ ? b64.replace(/\+/g, "-").replace(/\//g, "_").slice(0, -2)
38
+ : b64.replace(/\+/g, "-").replace(/\//g, "_").slice(0, -1)
39
+ : b64.replace(/\+/g, "-").replace(/\//g, "_");
40
+ }
41
+ /**
42
+ * Convert data into a base64url-encoded string.
43
+ *
44
+ * @see {@link https://www.rfc-editor.org/rfc/rfc4648.html#section-5}
45
+ *
46
+ * @param data The data to encode.
47
+ * @returns The base64url-encoded string.
48
+ *
49
+ * @example Usage
50
+ * ```ts
51
+ * import { encodeBase64Url } from "@std/encoding/base64url";
52
+ * import { assertEquals } from "@std/assert";
53
+ *
54
+ * assertEquals(encodeBase64Url("foobar"), "Zm9vYmFy");
55
+ * ```
56
+ */
57
+ export function encodeBase64Url(data) {
58
+ return convertBase64ToBase64url(base64.encodeBase64(data));
59
+ }
60
+ /**
61
+ * Decodes a given base64url-encoded string.
62
+ *
63
+ * @see {@link https://www.rfc-editor.org/rfc/rfc4648.html#section-5}
64
+ *
65
+ * @param b64url The base64url-encoded string to decode.
66
+ * @returns The decoded data.
67
+ *
68
+ * @example Usage
69
+ * ```ts
70
+ * import { decodeBase64Url } from "@std/encoding/base64url";
71
+ * import { assertEquals } from "@std/assert";
72
+ *
73
+ * assertEquals(
74
+ * decodeBase64Url("Zm9vYmFy"),
75
+ * new TextEncoder().encode("foobar")
76
+ * );
77
+ * ```
78
+ */
79
+ export function decodeBase64Url(b64url) {
80
+ return base64.decodeBase64(convertBase64urlToBase64(b64url));
81
+ }
@@ -0,0 +1,109 @@
1
+ // Copyright 2009 The Go Authors. All rights reserved.
2
+ // https://github.com/golang/go/blob/master/LICENSE
3
+ // Copyright 2018-2025 the Deno authors. MIT license.
4
+ // This module is browser compatible.
5
+ /**
6
+ * Port of the Go
7
+ * {@link https://github.com/golang/go/blob/go1.12.5/src/encoding/hex/hex.go | encoding/hex}
8
+ * library.
9
+ *
10
+ * ```ts
11
+ * import {
12
+ * decodeHex,
13
+ * encodeHex,
14
+ * } from "@std/encoding/hex";
15
+ * import { assertEquals } from "@std/assert";
16
+ *
17
+ * assertEquals(encodeHex("abc"), "616263");
18
+ *
19
+ * assertEquals(
20
+ * decodeHex("616263"),
21
+ * new TextEncoder().encode("abc"),
22
+ * );
23
+ * ```
24
+ *
25
+ * @module
26
+ */
27
+ import { validateBinaryLike } from "./_validate_binary_like.js";
28
+ const hexTable = new TextEncoder().encode("0123456789abcdef");
29
+ const textEncoder = new TextEncoder();
30
+ const textDecoder = new TextDecoder();
31
+ function errInvalidByte(byte) {
32
+ return new TypeError(`Invalid byte '${String.fromCharCode(byte)}'`);
33
+ }
34
+ function errLength(len) {
35
+ return new RangeError(`Cannot decode the hex string as the input length should be even: length is ${len}`);
36
+ }
37
+ /** Converts a hex character into its value. */
38
+ function fromHexChar(byte) {
39
+ // '0' <= byte && byte <= '9'
40
+ if (48 <= byte && byte <= 57)
41
+ return byte - 48;
42
+ // 'a' <= byte && byte <= 'f'
43
+ if (97 <= byte && byte <= 102)
44
+ return byte - 97 + 10;
45
+ // 'A' <= byte && byte <= 'F'
46
+ if (65 <= byte && byte <= 70)
47
+ return byte - 65 + 10;
48
+ throw errInvalidByte(byte);
49
+ }
50
+ /**
51
+ * Converts data into a hex-encoded string.
52
+ *
53
+ * @param src The data to encode.
54
+ *
55
+ * @returns The hex-encoded string.
56
+ *
57
+ * @example Usage
58
+ * ```ts
59
+ * import { encodeHex } from "@std/encoding/hex";
60
+ * import { assertEquals } from "@std/assert";
61
+ *
62
+ * assertEquals(encodeHex("abc"), "616263");
63
+ * ```
64
+ */
65
+ export function encodeHex(src) {
66
+ const u8 = validateBinaryLike(src);
67
+ const dst = new Uint8Array(u8.length * 2);
68
+ for (let i = 0; i < u8.length; i++) {
69
+ const v = u8[i];
70
+ dst[i * 2] = hexTable[v >> 4];
71
+ dst[i * 2 + 1] = hexTable[v & 0x0f];
72
+ }
73
+ return textDecoder.decode(dst);
74
+ }
75
+ /**
76
+ * Decodes the given hex-encoded string. If the input is malformed, an error is
77
+ * thrown.
78
+ *
79
+ * @param src The hex-encoded string to decode.
80
+ *
81
+ * @returns The decoded data.
82
+ *
83
+ * @example Usage
84
+ * ```ts
85
+ * import { decodeHex } from "@std/encoding/hex";
86
+ * import { assertEquals } from "@std/assert";
87
+ *
88
+ * assertEquals(
89
+ * decodeHex("616263"),
90
+ * new TextEncoder().encode("abc"),
91
+ * );
92
+ * ```
93
+ */
94
+ export function decodeHex(src) {
95
+ const u8 = textEncoder.encode(src);
96
+ const dst = new Uint8Array(u8.length / 2);
97
+ for (let i = 0; i < dst.length; i++) {
98
+ const a = fromHexChar(u8[i * 2]);
99
+ const b = fromHexChar(u8[i * 2 + 1]);
100
+ dst[i] = (a << 4) | b;
101
+ }
102
+ if (u8.length % 2 === 1) {
103
+ // Check for invalid char before reporting bad length,
104
+ // since the invalid char (if present) is an earlier problem.
105
+ fromHexChar(u8[dst.length * 2]);
106
+ throw errLength(u8.length);
107
+ }
108
+ return dst;
109
+ }
@@ -1,5 +1,5 @@
1
1
  import * as dntShim from "../_dnt.shims.js";
2
- import { encodeHex } from "../deps/jsr.io/@std/encoding/1.0.8/hex.js";
2
+ import { encodeHex } from "../deps/jsr.io/@std/encoding/1.0.7/hex.js";
3
3
  /**
4
4
  * Calculates the [partial follower collection digest][1].
5
5
  *
@@ -102,7 +102,7 @@ export async function handleCollection(request, { name, identifier, uriGetter, f
102
102
  }
103
103
  collection = new OrderedCollection({
104
104
  id: baseUri,
105
- totalItems: Number(totalItems),
105
+ totalItems: totalItems == null ? null : Number(totalItems),
106
106
  first,
107
107
  last,
108
108
  });
@@ -1,9 +1,9 @@
1
1
  import * as dntShim from "../_dnt.shims.js";
2
2
  import { createPublicKey } from "node:crypto";
3
3
  import { concat } from "../deps/jsr.io/@std/bytes/1.0.5/concat.js";
4
- import { decodeBase64, encodeBase64 } from "../deps/jsr.io/@std/encoding/1.0.8/base64.js";
5
- import { decodeBase64Url } from "../deps/jsr.io/@std/encoding/1.0.8/base64url.js";
6
- import { decodeHex } from "../deps/jsr.io/@std/encoding/1.0.8/hex.js";
4
+ import { decodeBase64, encodeBase64 } from "../deps/jsr.io/@std/encoding/1.0.7/base64.js";
5
+ import { decodeBase64Url } from "../deps/jsr.io/@std/encoding/1.0.7/base64url.js";
6
+ import { decodeHex } from "../deps/jsr.io/@std/encoding/1.0.7/hex.js";
7
7
  import { Integer, Sequence } from "asn1js";
8
8
  import { decode, encode } from "multibase";
9
9
  import { addPrefix, getCodeFromData, rmPrefix } from "multicodec";
package/esm/sig/http.js CHANGED
@@ -1,7 +1,7 @@
1
1
  import * as dntShim from "../_dnt.shims.js";
2
2
  import { getLogger } from "@logtape/logtape";
3
3
  import { equals } from "../deps/jsr.io/@std/bytes/1.0.5/mod.js";
4
- import { decodeBase64, encodeBase64 } from "../deps/jsr.io/@std/encoding/1.0.8/base64.js";
4
+ import { decodeBase64, encodeBase64 } from "../deps/jsr.io/@std/encoding/1.0.7/base64.js";
5
5
  import { CryptographicKey } from "../vocab/vocab.js";
6
6
  import { fetchKey, validateCryptoKey } from "./key.js";
7
7
  /**
package/esm/sig/ld.js CHANGED
@@ -1,7 +1,7 @@
1
1
  import * as dntShim from "../_dnt.shims.js";
2
2
  import { getLogger } from "@logtape/logtape";
3
- import { decodeBase64, encodeBase64 } from "../deps/jsr.io/@std/encoding/1.0.8/base64.js";
4
- import { encodeHex } from "../deps/jsr.io/@std/encoding/1.0.8/hex.js";
3
+ import { decodeBase64, encodeBase64 } from "../deps/jsr.io/@std/encoding/1.0.7/base64.js";
4
+ import { encodeHex } from "../deps/jsr.io/@std/encoding/1.0.7/hex.js";
5
5
  // @ts-ignore TS7016
6
6
  import jsonld from "jsonld";
7
7
  import { fetchDocumentLoader, } from "../runtime/docloader.js";
@@ -19,4 +19,8 @@ defaultContext:
19
19
  - "https://w3id.org/security/data-integrity/v1"
20
20
  - "https://www.w3.org/ns/did/v1"
21
21
  - "https://w3id.org/security/multikey/v1"
22
+ - litepub: "http://litepub.social/ns#"
23
+ toot: "http://joinmastodon.org/ns#"
24
+ EmojiReact: "litepub:EmojiReact"
25
+ Emoji: "toot:Emoji"
22
26
  properties: []
@@ -4216,7 +4216,9 @@ export class Object {
4216
4216
  : _219RwDanjScTv5tYCjwGZVCM7KZ9_endTime__array) {
4217
4217
  if (v == null)
4218
4218
  continue;
4219
- _219RwDanjScTv5tYCjwGZVCM7KZ9_endTime.push(dntShim.Temporal.Instant.from(v["@value"]));
4219
+ _219RwDanjScTv5tYCjwGZVCM7KZ9_endTime.push(dntShim.Temporal.Instant.from(v["@value"].substring(19).match(/[Z+-]/)
4220
+ ? v["@value"]
4221
+ : v["@value"] + "Z"));
4220
4222
  }
4221
4223
  instance.#_219RwDanjScTv5tYCjwGZVCM7KZ9_endTime =
4222
4224
  _219RwDanjScTv5tYCjwGZVCM7KZ9_endTime;
@@ -4640,7 +4642,9 @@ export class Object {
4640
4642
  : _5e258TDXtuhaFRPZiGoDfEpjdMr_published__array) {
4641
4643
  if (v == null)
4642
4644
  continue;
4643
- _5e258TDXtuhaFRPZiGoDfEpjdMr_published.push(dntShim.Temporal.Instant.from(v["@value"]));
4645
+ _5e258TDXtuhaFRPZiGoDfEpjdMr_published.push(dntShim.Temporal.Instant.from(v["@value"].substring(19).match(/[Z+-]/)
4646
+ ? v["@value"]
4647
+ : v["@value"] + "Z"));
4644
4648
  }
4645
4649
  instance.#_5e258TDXtuhaFRPZiGoDfEpjdMr_published =
4646
4650
  _5e258TDXtuhaFRPZiGoDfEpjdMr_published;
@@ -4675,7 +4679,9 @@ export class Object {
4675
4679
  : _2w3Jmue4up8iVDUA51WZqomEF438_startTime__array) {
4676
4680
  if (v == null)
4677
4681
  continue;
4678
- _2w3Jmue4up8iVDUA51WZqomEF438_startTime.push(dntShim.Temporal.Instant.from(v["@value"]));
4682
+ _2w3Jmue4up8iVDUA51WZqomEF438_startTime.push(dntShim.Temporal.Instant.from(v["@value"].substring(19).match(/[Z+-]/)
4683
+ ? v["@value"]
4684
+ : v["@value"] + "Z"));
4679
4685
  }
4680
4686
  instance.#_2w3Jmue4up8iVDUA51WZqomEF438_startTime =
4681
4687
  _2w3Jmue4up8iVDUA51WZqomEF438_startTime;
@@ -4805,7 +4811,9 @@ export class Object {
4805
4811
  : _385aB7ySixcf5Un6z3VsWmThgCzQ_updated__array) {
4806
4812
  if (v == null)
4807
4813
  continue;
4808
- _385aB7ySixcf5Un6z3VsWmThgCzQ_updated.push(dntShim.Temporal.Instant.from(v["@value"]));
4814
+ _385aB7ySixcf5Un6z3VsWmThgCzQ_updated.push(dntShim.Temporal.Instant.from(v["@value"].substring(19).match(/[Z+-]/)
4815
+ ? v["@value"]
4816
+ : v["@value"] + "Z"));
4809
4817
  }
4810
4818
  instance.#_385aB7ySixcf5Un6z3VsWmThgCzQ_updated =
4811
4819
  _385aB7ySixcf5Un6z3VsWmThgCzQ_updated;
@@ -8858,7 +8866,9 @@ export class DataIntegrityProof {
8858
8866
  : _3qzP3ukEZoUziK5FEiA1RhU4aqac__array) {
8859
8867
  if (v == null)
8860
8868
  continue;
8861
- _3qzP3ukEZoUziK5FEiA1RhU4aqac.push(dntShim.Temporal.Instant.from(v["@value"]));
8869
+ _3qzP3ukEZoUziK5FEiA1RhU4aqac.push(dntShim.Temporal.Instant.from(v["@value"].substring(19).match(/[Z+-]/)
8870
+ ? v["@value"]
8871
+ : v["@value"] + "Z"));
8862
8872
  }
8863
8873
  instance.#_3qzP3ukEZoUziK5FEiA1RhU4aqac = _3qzP3ukEZoUziK5FEiA1RhU4aqac;
8864
8874
  if (!("_fromSubclass" in options) || !options._fromSubclass) {
@@ -34289,8 +34299,12 @@ export class Question extends IntransitiveActivity {
34289
34299
  continue;
34290
34300
  const decoded = typeof v === "object" && "@type" in v &&
34291
34301
  "@value" in v && typeof v["@value"] === "string" &&
34292
- v["@type"] === "http://www.w3.org/2001/XMLSchema#dateTime"
34293
- ? dntShim.Temporal.Instant.from(v["@value"])
34302
+ v["@type"] === "http://www.w3.org/2001/XMLSchema#dateTime" &&
34303
+ // Check if the value is a valid RFC 3339 date-time string
34304
+ new Date(v["@value"]).toString() !== "Invalid Date"
34305
+ ? dntShim.Temporal.Instant.from(v["@value"].substring(19).match(/[Z+-]/)
34306
+ ? v["@value"]
34307
+ : v["@value"] + "Z")
34294
34308
  : typeof v === "object" && "@value" in v &&
34295
34309
  typeof v["@value"] === "boolean"
34296
34310
  ? v["@value"]
@@ -39953,7 +39967,9 @@ export class Tombstone extends Object {
39953
39967
  : _8g8g4LiVMhFTXskuDEqx4ascxUr_deleted__array) {
39954
39968
  if (v == null)
39955
39969
  continue;
39956
- _8g8g4LiVMhFTXskuDEqx4ascxUr_deleted.push(dntShim.Temporal.Instant.from(v["@value"]));
39970
+ _8g8g4LiVMhFTXskuDEqx4ascxUr_deleted.push(dntShim.Temporal.Instant.from(v["@value"].substring(19).match(/[Z+-]/)
39971
+ ? v["@value"]
39972
+ : v["@value"] + "Z"));
39957
39973
  }
39958
39974
  instance.#_8g8g4LiVMhFTXskuDEqx4ascxUr_deleted =
39959
39975
  _8g8g4LiVMhFTXskuDEqx4ascxUr_deleted;
@@ -40230,6 +40246,12 @@ export class Undo extends Activity {
40230
40246
  "https://w3id.org/security/data-integrity/v1",
40231
40247
  "https://www.w3.org/ns/did/v1",
40232
40248
  "https://w3id.org/security/multikey/v1",
40249
+ {
40250
+ "litepub": "http://litepub.social/ns#",
40251
+ "toot": "http://joinmastodon.org/ns#",
40252
+ "EmojiReact": "litepub:EmojiReact",
40253
+ "Emoji": "toot:Emoji",
40254
+ },
40233
40255
  ];
40234
40256
  const compacted = await jsonld.compact(values, docContext, { documentLoader: options.contextLoader });
40235
40257
  if (docContext != null) {
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@fedify/fedify",
3
- "version": "1.2.19",
3
+ "version": "1.2.21",
4
4
  "description": "An ActivityPub server framework",
5
5
  "keywords": [
6
6
  "ActivityPub",
@@ -1 +1 @@
1
- {"version":3,"file":"_types.d.ts","sourceRoot":"","sources":["../../../../../../src/deps/jsr.io/@std/encoding/1.0.8/_types.ts"],"names":[],"mappings":"AAEA;;;;;;GAMG;AAEH,MAAM,MAAM,WAAW,GAAG,UAAU,CAAC,UAAU,CAAC,OAAO,CAAC,CAAC,CAAC"}
1
+ {"version":3,"file":"_types.d.ts","sourceRoot":"","sources":["../../../../../../src/deps/jsr.io/@std/encoding/1.0.7/_types.ts"],"names":[],"mappings":"AAEA;;;;;;GAMG;AAEH,MAAM,MAAM,WAAW,GAAG,UAAU,CAAC,UAAU,CAAC,OAAO,CAAC,CAAC,CAAC"}
@@ -0,0 +1,2 @@
1
+ export declare function validateBinaryLike(source: unknown): Uint8Array;
2
+ //# sourceMappingURL=_validate_binary_like.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"_validate_binary_like.d.ts","sourceRoot":"","sources":["../../../../../../src/deps/jsr.io/@std/encoding/1.0.7/_validate_binary_like.ts"],"names":[],"mappings":"AAeA,wBAAgB,kBAAkB,CAAC,MAAM,EAAE,OAAO,GAAG,UAAU,CAa9D"}
@@ -0,0 +1 @@
1
+ {"version":3,"file":"base64.d.ts","sourceRoot":"","sources":["../../../../../../src/deps/jsr.io/@std/encoding/1.0.7/base64.ts"],"names":[],"mappings":"AAyBA,OAAO,KAAK,EAAE,WAAW,EAAE,MAAM,aAAa,CAAC;AAC/C,YAAY,EAAE,WAAW,EAAE,CAAC;AAqE5B;;;;;;;;;;;;;;;GAeG;AACH,wBAAgB,YAAY,CAAC,IAAI,EAAE,WAAW,GAAG,UAAU,GAAG,MAAM,GAAG,MAAM,CAmC5E;AAED;;;;;;;;;;;;;;;;;;GAkBG;AACH,wBAAgB,YAAY,CAAC,GAAG,EAAE,MAAM,GAAG,WAAW,CAQrD"}
@@ -0,0 +1 @@
1
+ {"version":3,"file":"base64url.d.ts","sourceRoot":"","sources":["../../../../../../src/deps/jsr.io/@std/encoding/1.0.7/base64url.ts"],"names":[],"mappings":"AAYA,OAAO,KAAK,EAAE,WAAW,EAAE,MAAM,aAAa,CAAC;AAC/C,YAAY,EAAE,WAAW,EAAE,CAAC;AAiC5B;;;;;;;;;;;;;;;GAeG;AACH,wBAAgB,eAAe,CAC7B,IAAI,EAAE,WAAW,GAAG,UAAU,GAAG,MAAM,GACtC,MAAM,CAER;AAED;;;;;;;;;;;;;;;;;;GAkBG;AACH,wBAAgB,eAAe,CAAC,MAAM,EAAE,MAAM,GAAG,WAAW,CAE3D"}