@noble/post-quantum 0.5.4 → 0.6.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/utils.js CHANGED
@@ -3,11 +3,57 @@
3
3
  * @module
4
4
  */
5
5
  /*! noble-post-quantum - MIT License (c) 2024 Paul Miller (paulmillr.com) */
6
- import { abytes, abytes as abytes_, concatBytes, isBytes, randomBytes as randb, } from '@noble/hashes/utils.js';
7
- export { abytes } from '@noble/hashes/utils.js';
8
- export { concatBytes };
6
+ import { abytes, abytes as abytes_, concatBytes, isLE, randomBytes as randb, } from '@noble/hashes/utils.js';
7
+ /**
8
+ * Asserts that a value is a byte array and optionally checks its length.
9
+ * Returns the original reference unchanged on success, and currently also accepts Node `Buffer`
10
+ * values through the upstream validator.
11
+ * This helper throws on malformed input, so APIs that must return `false` need to guard lengths
12
+ * before decoding or before calling it.
13
+ * @example
14
+ * Validate that a value is a byte array with the expected length.
15
+ * ```ts
16
+ * abytes(new Uint8Array([1]), 1);
17
+ * ```
18
+ */
19
+ const abytesDoc = abytes;
20
+ export { abytesDoc as abytes };
21
+ /**
22
+ * Concatenates byte arrays into a new `Uint8Array`.
23
+ * Zero arguments return an empty `Uint8Array`.
24
+ * Invalid segments throw before allocation because each argument is validated first.
25
+ * @example
26
+ * Concatenate two byte arrays into one result.
27
+ * ```ts
28
+ * concatBytes(new Uint8Array([1]), new Uint8Array([2]));
29
+ * ```
30
+ */
31
+ const concatBytesDoc = concatBytes;
32
+ export { concatBytesDoc as concatBytes };
33
+ /**
34
+ * Returns cryptographically secure random bytes.
35
+ * Requires `globalThis.crypto.getRandomValues` and throws if that API is unavailable.
36
+ * `bytesLength` is validated by the upstream helper as a non-negative integer before allocation,
37
+ * so negative and fractional values both throw instead of truncating through JS `ToIndex`.
38
+ * @example
39
+ * Generate a fresh random seed.
40
+ * ```ts
41
+ * const seed = randomBytes(4);
42
+ * ```
43
+ */
9
44
  export const randomBytes = randb;
10
- // Compares 2 u8a-s in kinda constant time
45
+ /**
46
+ * Compares two byte arrays in a length-constant way for equal lengths.
47
+ * Unequal lengths return `false` immediately, and there is no runtime type validation.
48
+ * @param a - First byte array.
49
+ * @param b - Second byte array.
50
+ * @returns Whether both arrays contain the same bytes.
51
+ * @example
52
+ * Compare two byte arrays for equality.
53
+ * ```ts
54
+ * equalBytes(new Uint8Array([1]), new Uint8Array([1]));
55
+ * ```
56
+ */
11
57
  export function equalBytes(a, b) {
12
58
  if (a.length !== b.length)
13
59
  return false;
@@ -16,25 +62,113 @@ export function equalBytes(a, b) {
16
62
  diff |= a[i] ^ b[i];
17
63
  return diff === 0;
18
64
  }
19
- // copy bytes to new u8a (aligned). Because Buffer.slice is broken.
65
+ /**
66
+ * Copies bytes into a fresh `Uint8Array`.
67
+ * Returns a detached plain `Uint8Array`, and currently accepts broader array-like / iterable
68
+ * inputs because it delegates directly to `Uint8Array.from(...)`.
69
+ * @param bytes - Source bytes.
70
+ * @returns Copy of the input bytes.
71
+ * @example
72
+ * Copy bytes into a fresh array.
73
+ * ```ts
74
+ * copyBytes(new Uint8Array([1, 2]));
75
+ * ```
76
+ */
20
77
  export function copyBytes(bytes) {
21
78
  return Uint8Array.from(bytes);
22
79
  }
80
+ /**
81
+ * Byte-swaps each 64-bit lane in place.
82
+ * Falcon's exact binary64 tables are stored as little-endian byte payloads, so BE runtimes need
83
+ * this boundary helper before aliasing them as host `Float64Array` lanes.
84
+ * @param arr - Byte buffer whose length is a multiple of 8.
85
+ * @returns The same buffer after in-place 64-bit lane byte swaps.
86
+ */
87
+ export function byteSwap64(arr) {
88
+ const bytes = new Uint8Array(arr.buffer, arr.byteOffset, arr.byteLength);
89
+ for (let i = 0; i < bytes.length; i += 8) {
90
+ const a0 = bytes[i + 0];
91
+ const a1 = bytes[i + 1];
92
+ const a2 = bytes[i + 2];
93
+ const a3 = bytes[i + 3];
94
+ bytes[i + 0] = bytes[i + 7];
95
+ bytes[i + 1] = bytes[i + 6];
96
+ bytes[i + 2] = bytes[i + 5];
97
+ bytes[i + 3] = bytes[i + 4];
98
+ bytes[i + 4] = a3;
99
+ bytes[i + 5] = a2;
100
+ bytes[i + 6] = a1;
101
+ bytes[i + 7] = a0;
102
+ }
103
+ return arr;
104
+ }
105
+ export const baswap64If = isLE
106
+ ? (arr) => arr
107
+ : byteSwap64;
108
+ /**
109
+ * Validates that an options bag is a plain object.
110
+ * @param opts - Options object to validate.
111
+ * @throws On wrong argument types. {@link TypeError}
112
+ * @example
113
+ * Validate that an options bag is a plain object.
114
+ * ```ts
115
+ * validateOpts({});
116
+ * ```
117
+ */
23
118
  export function validateOpts(opts) {
24
- // We try to catch u8a, since it was previously valid argument at this position
25
- if (typeof opts !== 'object' || opts === null || isBytes(opts))
26
- throw new Error('expected opts to be an object');
119
+ // Arrays silently passed here before, but these call sites expect named option-bag fields.
120
+ if (Object.prototype.toString.call(opts) !== '[object Object]')
121
+ throw new TypeError('expected valid options object');
27
122
  }
123
+ /**
124
+ * Validates common verification options.
125
+ * `context` itself is validated with `abytes(...)`, and individual algorithms may narrow support
126
+ * further after this shared plain-object gate.
127
+ * @param opts - Verification options. See {@link VerOpts}.
128
+ * @throws On wrong argument types. {@link TypeError}
129
+ * @example
130
+ * Validate common verification options.
131
+ * ```ts
132
+ * validateVerOpts({ context: new Uint8Array([1]) });
133
+ * ```
134
+ */
28
135
  export function validateVerOpts(opts) {
29
136
  validateOpts(opts);
30
137
  if (opts.context !== undefined)
31
138
  abytes(opts.context, undefined, 'opts.context');
32
139
  }
140
+ /**
141
+ * Validates common signing options.
142
+ * `extraEntropy` is validated with `abytes(...)`; exact lengths and extra algorithm-specific
143
+ * restrictions are enforced later by callers.
144
+ * @param opts - Signing options. See {@link SigOpts}.
145
+ * @throws On wrong argument types. {@link TypeError}
146
+ * @example
147
+ * Validate common signing options.
148
+ * ```ts
149
+ * validateSigOpts({ extraEntropy: new Uint8Array([1]) });
150
+ * ```
151
+ */
33
152
  export function validateSigOpts(opts) {
34
153
  validateVerOpts(opts);
35
154
  if (opts.extraEntropy !== false && opts.extraEntropy !== undefined)
36
155
  abytes(opts.extraEntropy, undefined, 'opts.extraEntropy');
37
156
  }
157
+ /**
158
+ * Builds a fixed-layout coder from byte lengths and nested coders.
159
+ * Raw-length fields decode as zero-copy `subarray(...)` views, and nested coders may preserve that
160
+ * aliasing too. Nested coder `encode(...)` results are treated as owned scratch: `splitCoder`
161
+ * copies them into the output and then zeroizes them with `fill(0)`. If a nested encoder forwards
162
+ * caller-owned bytes, it must do so only after detaching them into a disposable copy.
163
+ * @param label - Label used in validation errors.
164
+ * @param lengths - Field lengths or nested coders.
165
+ * @returns Composite fixed-length coder.
166
+ * @example
167
+ * Build a fixed-layout coder from byte lengths and nested coders.
168
+ * ```ts
169
+ * splitCoder('demo', 1, 2).encode([new Uint8Array([1]), new Uint8Array([2, 3])]);
170
+ * ```
171
+ */
38
172
  export function splitCoder(label, ...lengths) {
39
173
  const getLength = (c) => (typeof c === 'number' ? c : c.bytesLen);
40
174
  const bytesLen = lengths.reduce((sum, a) => sum + getLength(a), 0);
@@ -68,13 +202,32 @@ export function splitCoder(label, ...lengths) {
68
202
  };
69
203
  }
70
204
  // nano-packed.array (fixed size)
205
+ /**
206
+ * Builds a fixed-length vector coder from another fixed-length coder.
207
+ * Element decoding receives `subarray(...)` views, so aliasing depends on the element coder.
208
+ * Element coder `encode(...)` results are treated as owned scratch: `vecCoder` copies them into
209
+ * the output and then zeroizes them with `fill(0)`. If an element encoder forwards caller-owned
210
+ * bytes, it must do so only after detaching them into a disposable copy. `vecCoder` also trusts
211
+ * the `BytesCoderLen` contract: each encoded element must already be exactly `c.bytesLen` bytes.
212
+ * @param c - Element coder.
213
+ * @param vecLen - Number of elements in the vector.
214
+ * @returns Fixed-length vector coder.
215
+ * @example
216
+ * Build a fixed-length vector coder from another fixed-length coder.
217
+ * ```ts
218
+ * vecCoder(
219
+ * { bytesLen: 1, encode: (n: number) => Uint8Array.of(n), decode: (b: Uint8Array) => b[0] || 0 },
220
+ * 2
221
+ * ).encode([1, 2]);
222
+ * ```
223
+ */
71
224
  export function vecCoder(c, vecLen) {
72
225
  const bytesLen = vecLen * c.bytesLen;
73
226
  return {
74
227
  bytesLen,
75
228
  encode: (u) => {
76
229
  if (u.length !== vecLen)
77
- throw new Error(`vecCoder.encode: wrong length=${u.length}. Expected: ${vecLen}`);
230
+ throw new RangeError(`vecCoder.encode: wrong length=${u.length}. Expected: ${vecLen}`);
78
231
  const res = new Uint8Array(bytesLen);
79
232
  for (let i = 0, pos = 0; i < u.length; i++) {
80
233
  const b = c.encode(u[i]);
@@ -93,7 +246,17 @@ export function vecCoder(c, vecLen) {
93
246
  },
94
247
  };
95
248
  }
96
- // cleanBytes(Uint8Array.of(), [Uint16Array.of(), Uint32Array.of()])
249
+ /**
250
+ * Overwrites supported typed-array inputs with zeroes in place.
251
+ * Accepts direct typed arrays and one-level arrays of them.
252
+ * @param list - Typed arrays or one-level lists of typed arrays to clear.
253
+ * @example
254
+ * Overwrite typed arrays with zeroes.
255
+ * ```ts
256
+ * const buf = Uint8Array.of(1, 2, 3);
257
+ * cleanBytes(buf);
258
+ * ```
259
+ */
97
260
  export function cleanBytes(...list) {
98
261
  for (const t of list) {
99
262
  if (Array.isArray(t))
@@ -103,22 +266,72 @@ export function cleanBytes(...list) {
103
266
  t.fill(0);
104
267
  }
105
268
  }
269
+ /**
270
+ * Creates a 32-bit mask with the lowest `bits` bits set.
271
+ * @param bits - Number of low bits to keep.
272
+ * @returns Bit mask with `bits` ones.
273
+ * @example
274
+ * Create a low-bit mask for packed-field operations.
275
+ * ```ts
276
+ * const mask = getMask(4);
277
+ * ```
278
+ */
106
279
  export function getMask(bits) {
107
- return (1 << bits) - 1; // 4 -> 0b1111
280
+ if (!Number.isSafeInteger(bits) || bits < 0 || bits > 32)
281
+ throw new RangeError(`expected bits in [0..32], got ${bits}`);
282
+ // JS shifts are modulo 32, so bit 32 needs an explicit full-width mask.
283
+ return bits === 32 ? 0xffffffff : ~(-1 << bits) >>> 0;
108
284
  }
109
- export const EMPTY = Uint8Array.of();
285
+ /** Shared empty byte array used as the default context. */
286
+ export const EMPTY = /* @__PURE__ */ Uint8Array.of();
287
+ /**
288
+ * Builds the domain-separated message payload for the pure sign/verify paths.
289
+ * Context length `255` is valid; only `ctx.length > 255` is rejected.
290
+ * @param msg - Message bytes.
291
+ * @param ctx - Optional context bytes.
292
+ * @returns Domain-separated message payload.
293
+ * @throws On wrong argument ranges or values. {@link RangeError}
294
+ * @example
295
+ * Build the domain-separated payload before direct signing.
296
+ * ```ts
297
+ * const payload = getMessage(new Uint8Array([1, 2]));
298
+ * ```
299
+ */
110
300
  export function getMessage(msg, ctx = EMPTY) {
111
301
  abytes_(msg);
112
302
  abytes_(ctx);
113
303
  if (ctx.length > 255)
114
- throw new Error('context should be less than 255 bytes');
304
+ throw new RangeError('context should be 255 bytes or less');
115
305
  return concatBytes(new Uint8Array([0, ctx.length]), ctx, msg);
116
306
  }
307
+ // DER tag+length plus the shared NIST hash OID arc 2.16.840.1.101.3.4.2.* used by the
308
+ // FIPS 204 / FIPS 205 pre-hash wrappers; the final byte selects SHA-256, SHA-512, SHAKE128,
309
+ // SHAKE256, or another approved hash/XOF under that subtree.
117
310
  // 06 09 60 86 48 01 65 03 04 02
118
311
  const oidNistP = /* @__PURE__ */ Uint8Array.from([6, 9, 0x60, 0x86, 0x48, 1, 0x65, 3, 4, 2]);
312
+ /**
313
+ * Validates that a hash exposes a NIST hash OID and enough collision resistance.
314
+ * Current accepted surface is broader than the FIPS algorithm tables: any hash/XOF under the NIST
315
+ * `2.16.840.1.101.3.4.2.*` subtree is accepted if its effective `outputLen` is strong enough.
316
+ * XOF callers must pass a callable whose `outputLen` matches the digest length they actually intend
317
+ * to sign; bare `shake128` / `shake256` defaults are too short for the stronger prehash modes.
318
+ * @param hash - Hash function to validate.
319
+ * @param requiredStrength - Minimum required collision-resistance strength in bits.
320
+ * @throws If the hash metadata or collision resistance is insufficient. {@link Error}
321
+ * @example
322
+ * Validate that a hash exposes a NIST hash OID and enough collision resistance.
323
+ * ```ts
324
+ * import { sha256 } from '@noble/hashes/sha2.js';
325
+ * import { checkHash } from '@noble/post-quantum/utils.js';
326
+ * checkHash(sha256, 128);
327
+ * ```
328
+ */
119
329
  export function checkHash(hash, requiredStrength = 0) {
120
330
  if (!hash.oid || !equalBytes(hash.oid.subarray(0, 10), oidNistP))
121
331
  throw new Error('hash.oid is invalid: expected NIST hash');
332
+ // FIPS 204 / FIPS 205 require both collision and second-preimage strength; for approved NIST
333
+ // hashes/XOFs under this OID subtree, the collision bound from the configured digest length is
334
+ // the tighter runtime check, so enforce that lower bound here.
122
335
  const collisionResistance = (hash.outputLen * 8) / 2;
123
336
  if (requiredStrength > collisionResistance) {
124
337
  throw new Error('Pre-hash security strength too low: ' +
@@ -127,11 +340,29 @@ export function checkHash(hash, requiredStrength = 0) {
127
340
  requiredStrength);
128
341
  }
129
342
  }
343
+ /**
344
+ * Builds the domain-separated prehash payload for the prehash sign/verify paths.
345
+ * Callers are expected to vet `hash.oid` first, e.g. via `checkHash(...)`; calling this helper
346
+ * directly with a hash object that lacks `oid` currently throws later inside `concatBytes(...)`.
347
+ * Context length `255` is valid; only `ctx.length > 255` is rejected.
348
+ * @param hash - Prehash function.
349
+ * @param msg - Message bytes.
350
+ * @param ctx - Optional context bytes.
351
+ * @returns Domain-separated prehash payload.
352
+ * @throws On wrong argument ranges or values. {@link RangeError}
353
+ * @example
354
+ * Build the domain-separated prehash payload for external hashing.
355
+ * ```ts
356
+ * import { sha256 } from '@noble/hashes/sha2.js';
357
+ * import { getMessagePrehash } from '@noble/post-quantum/utils.js';
358
+ * getMessagePrehash(sha256, new Uint8Array([1, 2]));
359
+ * ```
360
+ */
130
361
  export function getMessagePrehash(hash, msg, ctx = EMPTY) {
131
362
  abytes_(msg);
132
363
  abytes_(ctx);
133
364
  if (ctx.length > 255)
134
- throw new Error('context should be less than 255 bytes');
365
+ throw new RangeError('context should be 255 bytes or less');
135
366
  const hashed = hash(msg);
136
367
  return concatBytes(new Uint8Array([1, ctx.length]), ctx, hash.oid, hashed);
137
368
  }
package/utils.js.map CHANGED
@@ -1 +1 @@
1
- {"version":3,"file":"utils.js","sourceRoot":"","sources":["src/utils.ts"],"names":[],"mappings":"AAAA;;;GAGG;AACH,4EAA4E;AAC5E,OAAO,EAGL,MAAM,EACN,MAAM,IAAI,OAAO,EACjB,WAAW,EACX,OAAO,EACP,WAAW,IAAI,KAAK,GACrB,MAAM,wBAAwB,CAAC;AAChC,OAAO,EAAE,MAAM,EAAE,MAAM,wBAAwB,CAAC;AAChD,OAAO,EAAE,WAAW,EAAE,CAAC;AACvB,MAAM,CAAC,MAAM,WAAW,GAAiB,KAAK,CAAC;AAE/C,0CAA0C;AAC1C,MAAM,UAAU,UAAU,CAAC,CAAa,EAAE,CAAa;IACrD,IAAI,CAAC,CAAC,MAAM,KAAK,CAAC,CAAC,MAAM;QAAE,OAAO,KAAK,CAAC;IACxC,IAAI,IAAI,GAAG,CAAC,CAAC;IACb,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,CAAC,CAAC,MAAM,EAAE,CAAC,EAAE;QAAE,IAAI,IAAI,CAAC,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,CAAC;IACvD,OAAO,IAAI,KAAK,CAAC,CAAC;AACpB,CAAC;AAED,mEAAmE;AACnE,MAAM,UAAU,SAAS,CAAC,KAAiB;IACzC,OAAO,UAAU,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;AAChC,CAAC;AAiBD,MAAM,UAAU,YAAY,CAAC,IAAY;IACvC,+EAA+E;IAC/E,IAAI,OAAO,IAAI,KAAK,QAAQ,IAAI,IAAI,KAAK,IAAI,IAAI,OAAO,CAAC,IAAI,CAAC;QAC5D,MAAM,IAAI,KAAK,CAAC,+BAA+B,CAAC,CAAC;AACrD,CAAC;AAED,MAAM,UAAU,eAAe,CAAC,IAAa;IAC3C,YAAY,CAAC,IAAI,CAAC,CAAC;IACnB,IAAI,IAAI,CAAC,OAAO,KAAK,SAAS;QAAE,MAAM,CAAC,IAAI,CAAC,OAAO,EAAE,SAAS,EAAE,cAAc,CAAC,CAAC;AAClF,CAAC;AAED,MAAM,UAAU,eAAe,CAAC,IAAa;IAC3C,eAAe,CAAC,IAAI,CAAC,CAAC;IACtB,IAAI,IAAI,CAAC,YAAY,KAAK,KAAK,IAAI,IAAI,CAAC,YAAY,KAAK,SAAS;QAChE,MAAM,CAAC,IAAI,CAAC,YAAY,EAAE,SAAS,EAAE,mBAAmB,CAAC,CAAC;AAC9D,CAAC;AAsCD,MAAM,UAAU,UAAU,CACxB,KAAa,EACb,GAAG,OAAU;IAEb,MAAM,SAAS,GAAG,CAAC,CAA8B,EAAE,EAAE,CAAC,CAAC,OAAO,CAAC,KAAK,QAAQ,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,QAAQ,CAAC,CAAC;IAC/F,MAAM,QAAQ,GAAW,OAAO,CAAC,MAAM,CAAC,CAAC,GAAW,EAAE,CAAC,EAAE,EAAE,CAAC,GAAG,GAAG,SAAS,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC;IACnF,OAAO;QACL,QAAQ;QACR,MAAM,EAAE,CAAC,IAAO,EAAE,EAAE;YAClB,MAAM,GAAG,GAAG,IAAI,UAAU,CAAC,QAAQ,CAAC,CAAC;YACrC,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,GAAG,GAAG,CAAC,EAAE,CAAC,GAAG,OAAO,CAAC,MAAM,EAAE,CAAC,EAAE,EAAE,CAAC;gBACjD,MAAM,CAAC,GAAG,OAAO,CAAC,CAAC,CAAC,CAAC;gBACrB,MAAM,CAAC,GAAG,SAAS,CAAC,CAAC,CAAC,CAAC;gBACvB,MAAM,CAAC,GAAe,OAAO,CAAC,KAAK,QAAQ,CAAC,CAAC,CAAE,IAAI,CAAC,CAAC,CAAS,CAAC,CAAC,CAAC,CAAC,CAAC,MAAM,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC,CAAC;gBACnF,OAAO,CAAC,CAAC,EAAE,CAAC,EAAE,KAAK,CAAC,CAAC;gBACrB,GAAG,CAAC,GAAG,CAAC,CAAC,EAAE,GAAG,CAAC,CAAC;gBAChB,IAAI,OAAO,CAAC,KAAK,QAAQ;oBAAE,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC,CAAC,QAAQ;gBAC9C,GAAG,IAAI,CAAC,CAAC;YACX,CAAC;YACD,OAAO,GAAG,CAAC;QACb,CAAC;QACD,MAAM,EAAE,CAAC,GAAe,EAAE,EAAE;YAC1B,OAAO,CAAC,GAAG,EAAE,QAAQ,EAAE,KAAK,CAAC,CAAC;YAC9B,MAAM,GAAG,GAAG,EAAE,CAAC;YACf,KAAK,MAAM,CAAC,IAAI,OAAO,EAAE,CAAC;gBACxB,MAAM,CAAC,GAAG,SAAS,CAAC,CAAC,CAAC,CAAC;gBACvB,MAAM,CAAC,GAAG,GAAG,CAAC,QAAQ,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC;gBAC7B,GAAG,CAAC,IAAI,CAAC,OAAO,CAAC,KAAK,QAAQ,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC,CAAC;gBAClD,GAAG,GAAG,GAAG,CAAC,QAAQ,CAAC,CAAC,CAAC,CAAC;YACxB,CAAC;YACD,OAAO,GAAkB,CAAC;QAC5B,CAAC;KACK,CAAC;AACX,CAAC;AACD,iCAAiC;AACjC,MAAM,UAAU,QAAQ,CAAI,CAAmB,EAAE,MAAc;IAC7D,MAAM,QAAQ,GAAG,MAAM,GAAG,CAAC,CAAC,QAAQ,CAAC;IACrC,OAAO;QACL,QAAQ;QACR,MAAM,EAAE,CAAC,CAAM,EAAc,EAAE;YAC7B,IAAI,CAAC,CAAC,MAAM,KAAK,MAAM;gBACrB,MAAM,IAAI,KAAK,CAAC,iCAAiC,CAAC,CAAC,MAAM,eAAe,MAAM,EAAE,CAAC,CAAC;YACpF,MAAM,GAAG,GAAG,IAAI,UAAU,CAAC,QAAQ,CAAC,CAAC;YACrC,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,GAAG,GAAG,CAAC,EAAE,CAAC,GAAG,CAAC,CAAC,MAAM,EAAE,CAAC,EAAE,EAAE,CAAC;gBAC3C,MAAM,CAAC,GAAG,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;gBACzB,GAAG,CAAC,GAAG,CAAC,CAAC,EAAE,GAAG,CAAC,CAAC;gBAChB,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC,CAAC,QAAQ;gBACnB,GAAG,IAAI,CAAC,CAAC,MAAM,CAAC;YAClB,CAAC;YACD,OAAO,GAAG,CAAC;QACb,CAAC;QACD,MAAM,EAAE,CAAC,CAAa,EAAO,EAAE;YAC7B,OAAO,CAAC,CAAC,EAAE,QAAQ,CAAC,CAAC;YACrB,MAAM,CAAC,GAAQ,EAAE,CAAC;YAClB,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,CAAC,CAAC,MAAM,EAAE,CAAC,IAAI,CAAC,CAAC,QAAQ;gBAC3C,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,QAAQ,CAAC,CAAC,EAAE,CAAC,GAAG,CAAC,CAAC,QAAQ,CAAC,CAAC,CAAC,CAAC;YAClD,OAAO,CAAC,CAAC;QACX,CAAC;KACF,CAAC;AACJ,CAAC;AAED,oEAAoE;AACpE,MAAM,UAAU,UAAU,CAAC,GAAG,IAAmC;IAC/D,KAAK,MAAM,CAAC,IAAI,IAAI,EAAE,CAAC;QACrB,IAAI,KAAK,CAAC,OAAO,CAAC,CAAC,CAAC;YAAE,KAAK,MAAM,CAAC,IAAI,CAAC;gBAAE,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC;;YAC9C,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC;IACjB,CAAC;AACH,CAAC;AAED,MAAM,UAAU,OAAO,CAAC,IAAY;IAClC,OAAO,CAAC,CAAC,IAAI,IAAI,CAAC,GAAG,CAAC,CAAC,CAAC,cAAc;AACxC,CAAC;AAED,MAAM,CAAC,MAAM,KAAK,GAAe,UAAU,CAAC,EAAE,EAAE,CAAC;AAEjD,MAAM,UAAU,UAAU,CAAC,GAAe,EAAE,MAAkB,KAAK;IACjE,OAAO,CAAC,GAAG,CAAC,CAAC;IACb,OAAO,CAAC,GAAG,CAAC,CAAC;IACb,IAAI,GAAG,CAAC,MAAM,GAAG,GAAG;QAAE,MAAM,IAAI,KAAK,CAAC,uCAAuC,CAAC,CAAC;IAC/E,OAAO,WAAW,CAAC,IAAI,UAAU,CAAC,CAAC,CAAC,EAAE,GAAG,CAAC,MAAM,CAAC,CAAC,EAAE,GAAG,EAAE,GAAG,CAAC,CAAC;AAChE,CAAC;AAED,gCAAgC;AAChC,MAAM,QAAQ,GAAG,eAAe,CAAC,UAAU,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,IAAI,EAAE,IAAI,EAAE,IAAI,EAAE,CAAC,EAAE,IAAI,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;AAE7F,MAAM,UAAU,SAAS,CAAC,IAAW,EAAE,mBAA2B,CAAC;IACjE,IAAI,CAAC,IAAI,CAAC,GAAG,IAAI,CAAC,UAAU,CAAC,IAAI,CAAC,GAAG,CAAC,QAAQ,CAAC,CAAC,EAAE,EAAE,CAAC,EAAE,QAAQ,CAAC;QAC9D,MAAM,IAAI,KAAK,CAAC,yCAAyC,CAAC,CAAC;IAC7D,MAAM,mBAAmB,GAAG,CAAC,IAAI,CAAC,SAAS,GAAG,CAAC,CAAC,GAAG,CAAC,CAAC;IACrD,IAAI,gBAAgB,GAAG,mBAAmB,EAAE,CAAC;QAC3C,MAAM,IAAI,KAAK,CACb,sCAAsC;YACpC,mBAAmB;YACnB,cAAc;YACd,gBAAgB,CACnB,CAAC;IACJ,CAAC;AACH,CAAC;AAED,MAAM,UAAU,iBAAiB,CAC/B,IAAW,EACX,GAAe,EACf,MAAkB,KAAK;IAEvB,OAAO,CAAC,GAAG,CAAC,CAAC;IACb,OAAO,CAAC,GAAG,CAAC,CAAC;IACb,IAAI,GAAG,CAAC,MAAM,GAAG,GAAG;QAAE,MAAM,IAAI,KAAK,CAAC,uCAAuC,CAAC,CAAC;IAC/E,MAAM,MAAM,GAAG,IAAI,CAAC,GAAG,CAAC,CAAC;IACzB,OAAO,WAAW,CAAC,IAAI,UAAU,CAAC,CAAC,CAAC,EAAE,GAAG,CAAC,MAAM,CAAC,CAAC,EAAE,GAAG,EAAE,IAAI,CAAC,GAAI,EAAE,MAAM,CAAC,CAAC;AAC9E,CAAC"}
1
+ {"version":3,"file":"utils.js","sourceRoot":"","sources":["src/utils.ts"],"names":[],"mappings":"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"}