windmill-cli 1.479.2 → 1.480.0
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/esm/deps/jsr.io/@std/encoding/1.0.4/_base32_common.js +183 -0
- package/esm/deps/jsr.io/@std/encoding/{1.0.8 → 1.0.4}/_validate_binary_like.js +1 -1
- package/esm/deps/jsr.io/@std/encoding/{1.0.8 → 1.0.4}/ascii85.js +1 -1
- package/esm/deps/jsr.io/@std/encoding/{1.0.8 → 1.0.4}/base32.js +22 -40
- package/esm/deps/jsr.io/@std/encoding/1.0.4/base32_stream.js +92 -0
- package/esm/deps/jsr.io/@std/encoding/1.0.4/base32hex.js +77 -0
- package/esm/deps/jsr.io/@std/encoding/1.0.4/base32hex_stream.js +92 -0
- package/esm/deps/jsr.io/@std/encoding/{1.0.8 → 1.0.4}/base58.js +1 -1
- package/esm/deps/jsr.io/@std/encoding/1.0.4/base64.js +163 -0
- package/esm/deps/jsr.io/@std/encoding/1.0.4/base64_stream.js +92 -0
- package/esm/deps/jsr.io/@std/encoding/1.0.4/base64url.js +81 -0
- package/esm/deps/jsr.io/@std/encoding/1.0.4/base64url_stream.js +93 -0
- package/esm/deps/jsr.io/@std/encoding/1.0.4/hex.js +109 -0
- package/esm/deps/jsr.io/@std/encoding/1.0.4/hex_stream.js +81 -0
- package/esm/deps/jsr.io/@std/encoding/{1.0.8 → 1.0.4}/mod.js +7 -2
- package/esm/deps/jsr.io/@std/encoding/{1.0.8 → 1.0.4}/varint.js +3 -1
- package/esm/deps.js +1 -1
- package/esm/gen/core/OpenAPI.js +1 -1
- package/esm/hub.js +3 -16
- package/esm/main.js +1 -1
- package/package.json +1 -1
- package/types/deps/jsr.io/@std/encoding/1.0.4/_base32_common.d.ts +17 -0
- package/types/deps/jsr.io/@std/encoding/1.0.4/_base32_common.d.ts.map +1 -0
- package/types/deps/jsr.io/@std/encoding/{1.0.8 → 1.0.4}/_validate_binary_like.d.ts.map +1 -1
- package/types/deps/jsr.io/@std/encoding/{1.0.8 → 1.0.4}/ascii85.d.ts +1 -3
- package/types/deps/jsr.io/@std/encoding/1.0.4/ascii85.d.ts.map +1 -0
- package/types/deps/jsr.io/@std/encoding/{1.0.8 → 1.0.4}/base32.d.ts +15 -17
- package/types/deps/jsr.io/@std/encoding/1.0.4/base32.d.ts.map +1 -0
- package/types/deps/jsr.io/@std/encoding/1.0.4/base32_stream.d.ts +48 -0
- package/types/deps/jsr.io/@std/encoding/1.0.4/base32_stream.d.ts.map +1 -0
- package/types/deps/jsr.io/@std/encoding/1.0.4/base32hex.d.ts +42 -0
- package/types/deps/jsr.io/@std/encoding/1.0.4/base32hex.d.ts.map +1 -0
- package/types/deps/jsr.io/@std/encoding/1.0.4/base32hex_stream.d.ts +48 -0
- package/types/deps/jsr.io/@std/encoding/1.0.4/base32hex_stream.d.ts.map +1 -0
- package/types/deps/jsr.io/@std/encoding/{1.0.8 → 1.0.4}/base58.d.ts +1 -3
- package/types/deps/jsr.io/@std/encoding/1.0.4/base58.d.ts.map +1 -0
- package/types/deps/jsr.io/@std/encoding/{1.0.8 → 1.0.4}/base64.d.ts +1 -3
- package/types/deps/jsr.io/@std/encoding/1.0.4/base64.d.ts.map +1 -0
- package/types/deps/jsr.io/@std/encoding/1.0.4/base64_stream.d.ts +48 -0
- package/types/deps/jsr.io/@std/encoding/1.0.4/base64_stream.d.ts.map +1 -0
- package/types/deps/jsr.io/@std/encoding/{1.0.8 → 1.0.4}/base64url.d.ts +1 -3
- package/types/deps/jsr.io/@std/encoding/1.0.4/base64url.d.ts.map +1 -0
- package/types/deps/jsr.io/@std/encoding/1.0.4/base64url_stream.d.ts +49 -0
- package/types/deps/jsr.io/@std/encoding/1.0.4/base64url_stream.d.ts.map +1 -0
- package/types/deps/jsr.io/@std/encoding/{1.0.8 → 1.0.4}/hex.d.ts +1 -3
- package/types/deps/jsr.io/@std/encoding/1.0.4/hex.d.ts.map +1 -0
- package/types/deps/jsr.io/@std/encoding/1.0.4/hex_stream.d.ts +48 -0
- package/types/deps/jsr.io/@std/encoding/1.0.4/hex_stream.d.ts.map +1 -0
- package/types/deps/jsr.io/@std/encoding/{1.0.8 → 1.0.4}/mod.d.ts +6 -0
- package/types/deps/jsr.io/@std/encoding/1.0.4/mod.d.ts.map +1 -0
- package/types/deps/jsr.io/@std/encoding/{1.0.8 → 1.0.4}/varint.d.ts +1 -3
- package/types/deps/jsr.io/@std/encoding/1.0.4/varint.d.ts.map +1 -0
- package/types/deps.d.ts +1 -1
- package/types/hub.d.ts.map +1 -1
- package/types/main.d.ts +1 -1
- package/esm/deps/jsr.io/@std/encoding/1.0.8/_common16.js +0 -45
- package/esm/deps/jsr.io/@std/encoding/1.0.8/_common32.js +0 -175
- package/esm/deps/jsr.io/@std/encoding/1.0.8/_common64.js +0 -98
- package/esm/deps/jsr.io/@std/encoding/1.0.8/_common_detach.js +0 -13
- package/esm/deps/jsr.io/@std/encoding/1.0.8/_types.js +0 -2
- package/esm/deps/jsr.io/@std/encoding/1.0.8/base64.js +0 -82
- package/esm/deps/jsr.io/@std/encoding/1.0.8/base64url.js +0 -72
- package/esm/deps/jsr.io/@std/encoding/1.0.8/hex.js +0 -87
- package/types/deps/jsr.io/@std/encoding/1.0.8/_common16.d.ts +0 -21
- package/types/deps/jsr.io/@std/encoding/1.0.8/_common16.d.ts.map +0 -1
- package/types/deps/jsr.io/@std/encoding/1.0.8/_common32.d.ts +0 -21
- package/types/deps/jsr.io/@std/encoding/1.0.8/_common32.d.ts.map +0 -1
- package/types/deps/jsr.io/@std/encoding/1.0.8/_common64.d.ts +0 -21
- package/types/deps/jsr.io/@std/encoding/1.0.8/_common64.d.ts.map +0 -1
- package/types/deps/jsr.io/@std/encoding/1.0.8/_common_detach.d.ts +0 -4
- package/types/deps/jsr.io/@std/encoding/1.0.8/_common_detach.d.ts.map +0 -1
- package/types/deps/jsr.io/@std/encoding/1.0.8/_types.d.ts +0 -9
- package/types/deps/jsr.io/@std/encoding/1.0.8/_types.d.ts.map +0 -1
- package/types/deps/jsr.io/@std/encoding/1.0.8/ascii85.d.ts.map +0 -1
- package/types/deps/jsr.io/@std/encoding/1.0.8/base32.d.ts.map +0 -1
- package/types/deps/jsr.io/@std/encoding/1.0.8/base58.d.ts.map +0 -1
- package/types/deps/jsr.io/@std/encoding/1.0.8/base64.d.ts.map +0 -1
- package/types/deps/jsr.io/@std/encoding/1.0.8/base64url.d.ts.map +0 -1
- package/types/deps/jsr.io/@std/encoding/1.0.8/hex.d.ts.map +0 -1
- package/types/deps/jsr.io/@std/encoding/1.0.8/mod.d.ts.map +0 -1
- package/types/deps/jsr.io/@std/encoding/1.0.8/varint.d.ts.map +0 -1
- /package/types/deps/jsr.io/@std/encoding/{1.0.8 → 1.0.4}/_validate_binary_like.d.ts +0 -0
|
@@ -0,0 +1,163 @@
|
|
|
1
|
+
// Copyright 2018-2024 the Deno authors. All rights reserved. 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,92 @@
|
|
|
1
|
+
// Copyright 2018-2024 the Deno authors. All rights reserved. MIT license.
|
|
2
|
+
// This module is browser compatible.
|
|
3
|
+
/**
|
|
4
|
+
* Utilities for encoding and decoding to and from base64 in a streaming manner.
|
|
5
|
+
*
|
|
6
|
+
* @experimental **UNSTABLE**: New API, yet to be vetted.
|
|
7
|
+
*
|
|
8
|
+
* @module
|
|
9
|
+
*/
|
|
10
|
+
import { decodeBase64, encodeBase64 } from "./base64.js";
|
|
11
|
+
/**
|
|
12
|
+
* Converts a Uint8Array stream into a base64-encoded stream.
|
|
13
|
+
*
|
|
14
|
+
* @experimental **UNSTABLE**: New API, yet to be vetted.
|
|
15
|
+
*
|
|
16
|
+
* @see {@link https://www.rfc-editor.org/rfc/rfc4648.html#section-4}
|
|
17
|
+
*
|
|
18
|
+
* @example Usage
|
|
19
|
+
* ```ts
|
|
20
|
+
* import { assertEquals } from "@std/assert";
|
|
21
|
+
* import { encodeBase64 } from "@std/encoding/base64";
|
|
22
|
+
* import { Base64EncoderStream } from "@std/encoding/base64-stream";
|
|
23
|
+
* import { toText } from "@std/streams/to-text";
|
|
24
|
+
*
|
|
25
|
+
* const stream = ReadableStream.from(["Hello,", " world!"])
|
|
26
|
+
* .pipeThrough(new TextEncoderStream())
|
|
27
|
+
* .pipeThrough(new Base64EncoderStream());
|
|
28
|
+
*
|
|
29
|
+
* assertEquals(await toText(stream), encodeBase64(new TextEncoder().encode("Hello, world!")));
|
|
30
|
+
* ```
|
|
31
|
+
*/
|
|
32
|
+
export class Base64EncoderStream extends TransformStream {
|
|
33
|
+
constructor() {
|
|
34
|
+
let push = new Uint8Array(0);
|
|
35
|
+
super({
|
|
36
|
+
transform(chunk, controller) {
|
|
37
|
+
const concat = new Uint8Array(push.length + chunk.length);
|
|
38
|
+
concat.set(push);
|
|
39
|
+
concat.set(chunk, push.length);
|
|
40
|
+
const remainder = -concat.length % 3;
|
|
41
|
+
controller.enqueue(encodeBase64(concat.slice(0, remainder || undefined)));
|
|
42
|
+
push = remainder ? concat.slice(remainder) : new Uint8Array(0);
|
|
43
|
+
},
|
|
44
|
+
flush(controller) {
|
|
45
|
+
if (push.length) {
|
|
46
|
+
controller.enqueue(encodeBase64(push));
|
|
47
|
+
}
|
|
48
|
+
},
|
|
49
|
+
});
|
|
50
|
+
}
|
|
51
|
+
}
|
|
52
|
+
/**
|
|
53
|
+
* Decodes a base64-encoded stream into a Uint8Array stream.
|
|
54
|
+
*
|
|
55
|
+
* @experimental **UNSTABLE**: New API, yet to be vetted.
|
|
56
|
+
*
|
|
57
|
+
* @see {@link https://www.rfc-editor.org/rfc/rfc4648.html#section-4}
|
|
58
|
+
*
|
|
59
|
+
* @example Usage
|
|
60
|
+
* ```ts
|
|
61
|
+
* import { assertEquals } from "@std/assert";
|
|
62
|
+
* import { Base64DecoderStream } from "@std/encoding/base64-stream";
|
|
63
|
+
* import { toText } from "@std/streams/to-text";
|
|
64
|
+
*
|
|
65
|
+
* const stream = ReadableStream.from(["SGVsbG8s", "IHdvcmxkIQ=="])
|
|
66
|
+
* .pipeThrough(new Base64DecoderStream())
|
|
67
|
+
* .pipeThrough(new TextDecoderStream());
|
|
68
|
+
*
|
|
69
|
+
* assertEquals(await toText(stream), "Hello, world!");
|
|
70
|
+
* ```
|
|
71
|
+
*/
|
|
72
|
+
export class Base64DecoderStream extends TransformStream {
|
|
73
|
+
constructor() {
|
|
74
|
+
let push = "";
|
|
75
|
+
super({
|
|
76
|
+
transform(chunk, controller) {
|
|
77
|
+
push += chunk;
|
|
78
|
+
if (push.length < 4) {
|
|
79
|
+
return;
|
|
80
|
+
}
|
|
81
|
+
const remainder = -push.length % 4;
|
|
82
|
+
controller.enqueue(decodeBase64(push.slice(0, remainder || undefined)));
|
|
83
|
+
push = remainder ? push.slice(remainder) : "";
|
|
84
|
+
},
|
|
85
|
+
flush(controller) {
|
|
86
|
+
if (push.length) {
|
|
87
|
+
controller.enqueue(decodeBase64(push));
|
|
88
|
+
}
|
|
89
|
+
},
|
|
90
|
+
});
|
|
91
|
+
}
|
|
92
|
+
}
|
|
@@ -0,0 +1,81 @@
|
|
|
1
|
+
// Copyright 2018-2024 the Deno authors. All rights reserved. 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,93 @@
|
|
|
1
|
+
// Copyright 2018-2024 the Deno authors. All rights reserved. MIT license.
|
|
2
|
+
// This module is browser compatible.
|
|
3
|
+
/**
|
|
4
|
+
* Utilities for encoding and decoding to and from base64url in a streaming manner.
|
|
5
|
+
*
|
|
6
|
+
* @experimental **UNSTABLE**: New API, yet to be vetted.
|
|
7
|
+
*
|
|
8
|
+
* @module
|
|
9
|
+
*/
|
|
10
|
+
import { decodeBase64Url, encodeBase64Url } from "./base64url.js";
|
|
11
|
+
/**
|
|
12
|
+
* Converts a Uint8Array stream into a base64url-encoded stream.
|
|
13
|
+
*
|
|
14
|
+
* @experimental **UNSTABLE**: New API, yet to be vetted.
|
|
15
|
+
*
|
|
16
|
+
* @see {@link https://www.rfc-editor.org/rfc/rfc4648.html#section-5}
|
|
17
|
+
*
|
|
18
|
+
* @example Usage
|
|
19
|
+
* ```ts
|
|
20
|
+
* import { assertEquals } from "@std/assert";
|
|
21
|
+
* import { encodeBase64Url } from "@std/encoding/base64url";
|
|
22
|
+
* import { Base64UrlEncoderStream } from "@std/encoding/base64url-stream";
|
|
23
|
+
* import { toText } from "@std/streams/to-text";
|
|
24
|
+
*
|
|
25
|
+
* const stream = ReadableStream.from(["Hello,", " world!"])
|
|
26
|
+
* .pipeThrough(new TextEncoderStream())
|
|
27
|
+
* .pipeThrough(new Base64UrlEncoderStream());
|
|
28
|
+
*
|
|
29
|
+
* assertEquals(await toText(stream), encodeBase64Url(new TextEncoder().encode("Hello, world!")));
|
|
30
|
+
* ```
|
|
31
|
+
*/
|
|
32
|
+
export class Base64UrlEncoderStream extends TransformStream {
|
|
33
|
+
constructor() {
|
|
34
|
+
let push = new Uint8Array(0);
|
|
35
|
+
super({
|
|
36
|
+
transform(chunk, controller) {
|
|
37
|
+
const concat = new Uint8Array(push.length + chunk.length);
|
|
38
|
+
concat.set(push);
|
|
39
|
+
concat.set(chunk, push.length);
|
|
40
|
+
const remainder = -concat.length % 3;
|
|
41
|
+
controller.enqueue(encodeBase64Url(concat.slice(0, remainder || undefined)));
|
|
42
|
+
push = remainder ? concat.slice(remainder) : new Uint8Array(0);
|
|
43
|
+
},
|
|
44
|
+
flush(controller) {
|
|
45
|
+
if (push.length) {
|
|
46
|
+
controller.enqueue(encodeBase64Url(push));
|
|
47
|
+
}
|
|
48
|
+
},
|
|
49
|
+
});
|
|
50
|
+
}
|
|
51
|
+
}
|
|
52
|
+
/**
|
|
53
|
+
* Decodes a base64url-encoded stream into a Uint8Array stream.
|
|
54
|
+
*
|
|
55
|
+
* @experimental **UNSTABLE**: New API, yet to be vetted.
|
|
56
|
+
*
|
|
57
|
+
* @see {@link https://www.rfc-editor.org/rfc/rfc4648.html#section-5}
|
|
58
|
+
*
|
|
59
|
+
* @example Usage
|
|
60
|
+
* ```ts
|
|
61
|
+
* import { assertEquals } from "@std/assert";
|
|
62
|
+
* import { encodeBase64Url } from "@std/encoding/base64url";
|
|
63
|
+
* import { Base64UrlDecoderStream } from "@std/encoding/base64url-stream";
|
|
64
|
+
* import { toText } from "@std/streams/to-text";
|
|
65
|
+
*
|
|
66
|
+
* const stream = ReadableStream.from(["SGVsbG8s", "IHdvcmxkIQ"])
|
|
67
|
+
* .pipeThrough(new Base64UrlDecoderStream())
|
|
68
|
+
* .pipeThrough(new TextDecoderStream());
|
|
69
|
+
*
|
|
70
|
+
* assertEquals(await toText(stream), "Hello, world!");
|
|
71
|
+
* ```
|
|
72
|
+
*/
|
|
73
|
+
export class Base64UrlDecoderStream extends TransformStream {
|
|
74
|
+
constructor() {
|
|
75
|
+
let push = "";
|
|
76
|
+
super({
|
|
77
|
+
transform(chunk, controller) {
|
|
78
|
+
push += chunk;
|
|
79
|
+
if (push.length < 4) {
|
|
80
|
+
return;
|
|
81
|
+
}
|
|
82
|
+
const remainder = -push.length % 4;
|
|
83
|
+
controller.enqueue(decodeBase64Url(push.slice(0, remainder || undefined)));
|
|
84
|
+
push = remainder ? push.slice(remainder) : "";
|
|
85
|
+
},
|
|
86
|
+
flush(controller) {
|
|
87
|
+
if (push.length) {
|
|
88
|
+
controller.enqueue(decodeBase64Url(push));
|
|
89
|
+
}
|
|
90
|
+
},
|
|
91
|
+
});
|
|
92
|
+
}
|
|
93
|
+
}
|
|
@@ -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-2024 the Deno authors. All rights reserved. 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
|
+
}
|
|
@@ -0,0 +1,81 @@
|
|
|
1
|
+
// Copyright 2018-2024 the Deno authors. All rights reserved. MIT license.
|
|
2
|
+
// This module is browser compatible.
|
|
3
|
+
/**
|
|
4
|
+
* Utilities for encoding and decoding to and from hex in a streaming manner.
|
|
5
|
+
*
|
|
6
|
+
* @experimental **UNSTABLE**: New API, yet to be vetted.
|
|
7
|
+
*
|
|
8
|
+
* @module
|
|
9
|
+
*/
|
|
10
|
+
import { decodeHex, encodeHex } from "./hex.js";
|
|
11
|
+
/**
|
|
12
|
+
* Converts a Uint8Array stream into a hex-encoded stream.
|
|
13
|
+
*
|
|
14
|
+
* @experimental **UNSTABLE**: New API, yet to be vetted.
|
|
15
|
+
*
|
|
16
|
+
* @see {@link https://www.rfc-editor.org/rfc/rfc4648.html#section-8}
|
|
17
|
+
*
|
|
18
|
+
* @example Usage
|
|
19
|
+
* ```ts
|
|
20
|
+
* import { assertEquals } from "@std/assert";
|
|
21
|
+
* import { encodeHex } from "@std/encoding/hex";
|
|
22
|
+
* import { HexEncoderStream } from "@std/encoding/hex-stream";
|
|
23
|
+
* import { toText } from "@std/streams/to-text";
|
|
24
|
+
*
|
|
25
|
+
* const stream = ReadableStream.from(["Hello,", " world!"])
|
|
26
|
+
* .pipeThrough(new TextEncoderStream())
|
|
27
|
+
* .pipeThrough(new HexEncoderStream());
|
|
28
|
+
*
|
|
29
|
+
* assertEquals(await toText(stream), encodeHex(new TextEncoder().encode("Hello, world!")));
|
|
30
|
+
* ```
|
|
31
|
+
*/
|
|
32
|
+
export class HexEncoderStream extends TransformStream {
|
|
33
|
+
constructor() {
|
|
34
|
+
super({
|
|
35
|
+
transform(chunk, controller) {
|
|
36
|
+
controller.enqueue(encodeHex(chunk));
|
|
37
|
+
},
|
|
38
|
+
});
|
|
39
|
+
}
|
|
40
|
+
}
|
|
41
|
+
/**
|
|
42
|
+
* Decodes a hex-encoded stream into a Uint8Array stream.
|
|
43
|
+
*
|
|
44
|
+
* @experimental **UNSTABLE**: New API, yet to be vetted.
|
|
45
|
+
*
|
|
46
|
+
* @see {@link https://www.rfc-editor.org/rfc/rfc4648.html#section-8}
|
|
47
|
+
*
|
|
48
|
+
* @example Usage
|
|
49
|
+
* ```ts
|
|
50
|
+
* import { assertEquals } from "@std/assert";
|
|
51
|
+
* import { HexDecoderStream } from "@std/encoding/hex-stream";
|
|
52
|
+
* import { toText } from "@std/streams/to-text";
|
|
53
|
+
*
|
|
54
|
+
* const stream = ReadableStream.from(["48656c6c6f2c", "20776f726c6421"])
|
|
55
|
+
* .pipeThrough(new HexDecoderStream())
|
|
56
|
+
* .pipeThrough(new TextDecoderStream());
|
|
57
|
+
*
|
|
58
|
+
* assertEquals(await toText(stream), "Hello, world!");
|
|
59
|
+
* ```
|
|
60
|
+
*/
|
|
61
|
+
export class HexDecoderStream extends TransformStream {
|
|
62
|
+
constructor() {
|
|
63
|
+
let push = "";
|
|
64
|
+
super({
|
|
65
|
+
transform(chunk, controller) {
|
|
66
|
+
push += chunk;
|
|
67
|
+
if (push.length < 2) {
|
|
68
|
+
return;
|
|
69
|
+
}
|
|
70
|
+
const remainder = -push.length % 2;
|
|
71
|
+
controller.enqueue(decodeHex(push.slice(0, remainder || undefined)));
|
|
72
|
+
push = remainder ? push.slice(remainder) : "";
|
|
73
|
+
},
|
|
74
|
+
flush(controller) {
|
|
75
|
+
if (push.length) {
|
|
76
|
+
controller.enqueue(decodeHex(push));
|
|
77
|
+
}
|
|
78
|
+
},
|
|
79
|
+
});
|
|
80
|
+
}
|
|
81
|
+
}
|
|
@@ -1,5 +1,4 @@
|
|
|
1
|
-
// Copyright 2018-
|
|
2
|
-
// This module is browser compatible.
|
|
1
|
+
// Copyright 2018-2024 the Deno authors. All rights reserved. MIT license.
|
|
3
2
|
/**
|
|
4
3
|
* Utilities for encoding and decoding common formats like hex, base64, and varint.
|
|
5
4
|
*
|
|
@@ -16,8 +15,14 @@
|
|
|
16
15
|
*/
|
|
17
16
|
export * from "./ascii85.js";
|
|
18
17
|
export * from "./base32.js";
|
|
18
|
+
export * from "./base32_stream.js";
|
|
19
|
+
export * from "./base32hex.js";
|
|
20
|
+
export * from "./base32hex_stream.js";
|
|
19
21
|
export * from "./base58.js";
|
|
20
22
|
export * from "./base64.js";
|
|
23
|
+
export * from "./base64_stream.js";
|
|
21
24
|
export * from "./base64url.js";
|
|
25
|
+
export * from "./base64url_stream.js";
|
|
22
26
|
export * from "./hex.js";
|
|
27
|
+
export * from "./hex_stream.js";
|
|
23
28
|
export * from "./varint.js";
|
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
// Copyright 2018-
|
|
1
|
+
// Copyright 2018-2024 the Deno authors. All rights reserved. MIT license.
|
|
2
2
|
// Copyright 2020 Keith Cirkel. All rights reserved. MIT license.
|
|
3
3
|
// Copyright 2023 Skye "MierenManz". All rights reserved. MIT license.
|
|
4
4
|
/**
|
|
@@ -24,6 +24,8 @@
|
|
|
24
24
|
*
|
|
25
25
|
* @module
|
|
26
26
|
*/
|
|
27
|
+
// This implementation is a port of https://deno.land/x/varint@v2.0.0 by @keithamus
|
|
28
|
+
// This module is browser compatible.
|
|
27
29
|
/**
|
|
28
30
|
* The maximum value of an unsigned 64-bit integer.
|
|
29
31
|
* Equivalent to `2n**64n - 1n`
|
package/esm/deps.js
CHANGED
|
@@ -15,7 +15,7 @@ export { CompletionsCommand } from "./deps/jsr.io/@windmill-labs/cliffy-command/
|
|
|
15
15
|
export { ensureDir } from "./deps/jsr.io/@std/fs/1.0.15/mod.js";
|
|
16
16
|
export { SEPARATOR as SEP } from "./deps/jsr.io/@std/path/1.0.8/mod.js";
|
|
17
17
|
export * as path from "./deps/jsr.io/@std/path/1.0.8/mod.js";
|
|
18
|
-
export { encodeHex } from "./deps/jsr.io/@std/encoding/1.0.
|
|
18
|
+
export { encodeHex } from "./deps/jsr.io/@std/encoding/1.0.4/mod.js";
|
|
19
19
|
export { writeAllSync } from "./deps/jsr.io/@std/io/0.225.2/write_all.js";
|
|
20
20
|
export { copy } from "./deps/jsr.io/@std/io/0.225.2/copy.js";
|
|
21
21
|
export { readAll } from "./deps/jsr.io/@std/io/0.225.2/read_all.js";
|
package/esm/gen/core/OpenAPI.js
CHANGED