@fedify/fedify 1.4.8 → 1.4.10

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 (42) hide show
  1. package/CHANGES.md +161 -0
  2. package/esm/deno.js +2 -2
  3. package/esm/deps/jsr.io/@std/encoding/1.0.7/_validate_binary_like.js +26 -0
  4. package/esm/deps/jsr.io/@std/encoding/1.0.7/base64.js +163 -0
  5. package/esm/deps/jsr.io/@std/encoding/1.0.7/base64url.js +81 -0
  6. package/esm/deps/jsr.io/@std/encoding/1.0.7/hex.js +109 -0
  7. package/esm/federation/collection.js +1 -1
  8. package/esm/federation/handler.js +1 -1
  9. package/esm/runtime/key.js +3 -3
  10. package/esm/sig/http.js +2 -2
  11. package/esm/sig/ld.js +2 -2
  12. package/esm/sig/proof.js +1 -1
  13. package/esm/vocab/undo.yaml +4 -0
  14. package/esm/vocab/vocab.js +206 -184
  15. package/package.json +1 -1
  16. package/types/deps/jsr.io/@std/encoding/{1.0.8 → 1.0.7}/_types.d.ts.map +1 -1
  17. package/types/deps/jsr.io/@std/encoding/1.0.7/_validate_binary_like.d.ts +2 -0
  18. package/types/deps/jsr.io/@std/encoding/1.0.7/_validate_binary_like.d.ts.map +1 -0
  19. package/types/deps/jsr.io/@std/encoding/1.0.7/base64.d.ts.map +1 -0
  20. package/types/deps/jsr.io/@std/encoding/1.0.7/base64url.d.ts.map +1 -0
  21. package/types/deps/jsr.io/@std/encoding/1.0.7/hex.d.ts.map +1 -0
  22. package/types/vocab/vocab.d.ts.map +1 -1
  23. package/esm/deps/jsr.io/@std/encoding/1.0.8/_common16.js +0 -45
  24. package/esm/deps/jsr.io/@std/encoding/1.0.8/_common64.js +0 -98
  25. package/esm/deps/jsr.io/@std/encoding/1.0.8/_common_detach.js +0 -13
  26. package/esm/deps/jsr.io/@std/encoding/1.0.8/base64.js +0 -82
  27. package/esm/deps/jsr.io/@std/encoding/1.0.8/base64url.js +0 -72
  28. package/esm/deps/jsr.io/@std/encoding/1.0.8/hex.js +0 -87
  29. package/types/deps/jsr.io/@std/encoding/1.0.8/_common16.d.ts +0 -21
  30. package/types/deps/jsr.io/@std/encoding/1.0.8/_common16.d.ts.map +0 -1
  31. package/types/deps/jsr.io/@std/encoding/1.0.8/_common64.d.ts +0 -21
  32. package/types/deps/jsr.io/@std/encoding/1.0.8/_common64.d.ts.map +0 -1
  33. package/types/deps/jsr.io/@std/encoding/1.0.8/_common_detach.d.ts +0 -4
  34. package/types/deps/jsr.io/@std/encoding/1.0.8/_common_detach.d.ts.map +0 -1
  35. package/types/deps/jsr.io/@std/encoding/1.0.8/base64.d.ts.map +0 -1
  36. package/types/deps/jsr.io/@std/encoding/1.0.8/base64url.d.ts.map +0 -1
  37. package/types/deps/jsr.io/@std/encoding/1.0.8/hex.d.ts.map +0 -1
  38. /package/esm/deps/jsr.io/@std/encoding/{1.0.8 → 1.0.7}/_types.js +0 -0
  39. /package/types/deps/jsr.io/@std/encoding/{1.0.8 → 1.0.7}/_types.d.ts +0 -0
  40. /package/types/deps/jsr.io/@std/encoding/{1.0.8 → 1.0.7}/base64.d.ts +0 -0
  41. /package/types/deps/jsr.io/@std/encoding/{1.0.8 → 1.0.7}/base64url.d.ts +0 -0
  42. /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,40 @@
3
3
  Fedify changelog
4
4
  ================
5
5
 
6
+ Version 1.4.10
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.4.9
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
+
36
+ - Fixed a `TypeError` thrown by the `signRequest()` function on Node.js.
37
+ [[#222]]
38
+
39
+
6
40
  Version 1.4.8
7
41
  -------------
8
42
 
@@ -193,6 +227,40 @@ Released on February 5, 2025.
193
227
  [#195]: https://github.com/fedify-dev/fedify/issues/195
194
228
 
195
229
 
230
+ Version 1.3.17
231
+ --------------
232
+
233
+ Released on April 8, 2025.
234
+
235
+ - Activity Vocabulary API became to accept [RFC 3339] date-time strings
236
+ without a timezone offset. This is not a bug fix, but improves
237
+ interoperability with some implementations that do not include a timezone
238
+ offset in their date-time strings including WordPress. [[#226]]
239
+
240
+ - Added the following default context to `Undo` class:
241
+
242
+ ~~~~ json
243
+ {
244
+ "litepub": "http://litepub.social/ns#",
245
+ "toot": "http://joinmastodon.org/ns#",
246
+ "EmojiReact": "litepub:EmojiReact",
247
+ "Emoji": "toot:Emoji"
248
+ }
249
+ ~~~~
250
+
251
+
252
+ Version 1.3.16
253
+ --------------
254
+
255
+ Released on March 26, 2025.
256
+
257
+ - Fixed a `TypeError` thrown by the followers collection dispatcher when
258
+ the `base-url` parameter was provided.
259
+
260
+ - Fixed a `TypeError` thrown by the `signRequest()` function on Node.js.
261
+ [[#222]]
262
+
263
+
196
264
  Version 1.3.15
197
265
  --------------
198
266
 
@@ -499,6 +567,39 @@ Released on November 30, 2024.
499
567
  [#193]: https://github.com/fedify-dev/fedify/issues/193
500
568
 
501
569
 
570
+ Version 1.2.21
571
+ --------------
572
+
573
+ Released on April 8, 2025.
574
+
575
+ - Activity Vocabulary API became to accept [RFC 3339] date-time strings
576
+ without a timezone offset. This is not a bug fix, but improves
577
+ interoperability with some implementations that do not include a timezone
578
+ offset in their date-time strings including WordPress. [[#226]]
579
+
580
+ - Added the following default context to `Undo` class:
581
+
582
+ ~~~~ json
583
+ {
584
+ "litepub": "http://litepub.social/ns#",
585
+ "toot": "http://joinmastodon.org/ns#",
586
+ "EmojiReact": "litepub:EmojiReact",
587
+ "Emoji": "toot:Emoji"
588
+ }
589
+ ~~~~
590
+
591
+
592
+ Version 1.2.20
593
+ --------------
594
+
595
+ Released on March 26, 2025.
596
+
597
+ - Fixed a `TypeError` thrown by the followers collection dispatcher when
598
+ the `base-url` parameter was provided.
599
+ - Fixed a `TypeError` thrown by the `signRequest()` function on Node.js.
600
+ [[#222]]
601
+
602
+
502
603
  Version 1.2.19
503
604
  --------------
504
605
 
@@ -854,6 +955,39 @@ Released on October 31, 2024.
854
955
  [#118]: https://github.com/fedify-dev/fedify/issues/118
855
956
 
856
957
 
958
+ Version 1.1.21
959
+ --------------
960
+
961
+ Released on April 8, 2025.
962
+
963
+ - Activity Vocabulary API became to accept [RFC 3339] date-time strings
964
+ without a timezone offset. This is not a bug fix, but improves
965
+ interoperability with some implementations that do not include a timezone
966
+ offset in their date-time strings including WordPress. [[#226]]
967
+
968
+ - Added the following default context to `Undo` class:
969
+
970
+ ~~~~ json
971
+ {
972
+ "litepub": "http://litepub.social/ns#",
973
+ "toot": "http://joinmastodon.org/ns#",
974
+ "EmojiReact": "litepub:EmojiReact",
975
+ "Emoji": "toot:Emoji"
976
+ }
977
+ ~~~~
978
+
979
+
980
+ Version 1.1.20
981
+ --------------
982
+
983
+ Released on March 26, 2025.
984
+
985
+ - Fixed a `TypeError` thrown by the followers collection dispatcher when
986
+ the `base-url` parameter was provided.
987
+ - Fixed a `TypeError` thrown by the `signRequest()` function on Node.js.
988
+ [[#222]]
989
+
990
+
857
991
  Version 1.1.19
858
992
  --------------
859
993
 
@@ -1250,6 +1384,33 @@ Released on October 20, 2024.
1250
1384
  [#150]: https://github.com/fedify-dev/fedify/issues/150
1251
1385
 
1252
1386
 
1387
+ Version 1.0.24
1388
+ --------------
1389
+
1390
+ Released on April 8, 2025.
1391
+
1392
+ - Activity Vocabulary API became to accept [RFC 3339] date-time strings
1393
+ without a timezone offset. This is not a bug fix, but improves
1394
+ interoperability with some implementations that do not include a timezone
1395
+ offset in their date-time strings including WordPress. [[#226]]
1396
+
1397
+ [RFC 3339]: https://datatracker.ietf.org/doc/html/rfc3339
1398
+ [#226]: https://github.com/fedify-dev/fedify/issues/226
1399
+
1400
+
1401
+ Version 1.0.23
1402
+ --------------
1403
+
1404
+ Released on March 26, 2025.
1405
+
1406
+ - Fixed a `TypeError` thrown by the followers collection dispatcher when
1407
+ the `base-url` parameter was provided.
1408
+ - Fixed a `TypeError` thrown by the `signRequest()` function on Node.js.
1409
+ [[#222]]
1410
+
1411
+ [#222]: https://github.com/fedify-dev/fedify/issues/222
1412
+
1413
+
1253
1414
  Version 1.0.22
1254
1415
  --------------
1255
1416
 
package/esm/deno.js CHANGED
@@ -1,6 +1,6 @@
1
1
  export default {
2
2
  "name": "@fedify/fedify",
3
- "version": "1.4.8",
3
+ "version": "1.4.10",
4
4
  "license": "MIT",
5
5
  "exports": {
6
6
  ".": "./mod.ts",
@@ -41,7 +41,7 @@ export default {
41
41
  "@std/async": "jsr:@std/async@^1.0.5",
42
42
  "@std/bytes": "jsr:@std/bytes@^1.0.2",
43
43
  "@std/collections": "jsr:@std/collections@^1.0.6",
44
- "@std/encoding": "jsr:@std/encoding@^1.0.5",
44
+ "@std/encoding": "jsr:@std/encoding@1.0.7",
45
45
  "@std/fs": "jsr:@std/fs@^1.0.3",
46
46
  "@std/http": "jsr:@std/http@^1.0.6",
47
47
  "@std/path": "jsr:@std/path@^1.0.6",
@@ -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
  *
@@ -135,7 +135,7 @@ export async function handleCollection(request, { name, identifier, uriGetter, f
135
135
  }
136
136
  collection = new OrderedCollection({
137
137
  id: baseUri,
138
- totalItems: Number(totalItems),
138
+ totalItems: totalItems == null ? null : Number(totalItems),
139
139
  first,
140
140
  last,
141
141
  });
@@ -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
@@ -3,8 +3,8 @@ import { getLogger } from "@logtape/logtape";
3
3
  import { SpanStatusCode, trace, } from "@opentelemetry/api";
4
4
  import { ATTR_HTTP_REQUEST_HEADER, ATTR_HTTP_REQUEST_METHOD, ATTR_URL_FULL, } from "@opentelemetry/semantic-conventions";
5
5
  import { equals } from "../deps/jsr.io/@std/bytes/1.0.5/mod.js";
6
- import { decodeBase64, encodeBase64 } from "../deps/jsr.io/@std/encoding/1.0.8/base64.js";
7
- import { encodeHex } from "../deps/jsr.io/@std/encoding/1.0.8/hex.js";
6
+ import { decodeBase64, encodeBase64 } from "../deps/jsr.io/@std/encoding/1.0.7/base64.js";
7
+ import { encodeHex } from "../deps/jsr.io/@std/encoding/1.0.7/hex.js";
8
8
  import metadata from "../deno.js";
9
9
  import { CryptographicKey } from "../vocab/vocab.js";
10
10
  import { fetchKey, validateCryptoKey } from "./key.js";
package/esm/sig/ld.js CHANGED
@@ -1,8 +1,8 @@
1
1
  import * as dntShim from "../_dnt.shims.js";
2
2
  import { getLogger } from "@logtape/logtape";
3
3
  import { SpanStatusCode, trace } from "@opentelemetry/api";
4
- import { decodeBase64, encodeBase64 } from "../deps/jsr.io/@std/encoding/1.0.8/base64.js";
5
- import { encodeHex } 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 { encodeHex } from "../deps/jsr.io/@std/encoding/1.0.7/hex.js";
6
6
  // @ts-ignore TS7016
7
7
  import jsonld from "jsonld";
8
8
  import metadata from "../deno.js";
package/esm/sig/proof.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 { SpanStatusCode, trace } from "@opentelemetry/api";
4
- import { encodeHex } from "../deps/jsr.io/@std/encoding/1.0.8/hex.js";
4
+ import { encodeHex } from "../deps/jsr.io/@std/encoding/1.0.7/hex.js";
5
5
  // @ts-ignore: json-canon is not typed
6
6
  import serialize from "json-canon";
7
7
  import metadata from "../deno.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: []