@vitia.ai/secure-api-client-vue 0.1.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/LICENSE +21 -0
- package/README.md +46 -0
- package/dist/index.cjs +65 -0
- package/dist/index.cjs.map +1 -0
- package/dist/index.d.ts +104 -0
- package/dist/index.mjs +3084 -0
- package/dist/index.mjs.map +1 -0
- package/package.json +55 -0
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.mjs","sources":["../../../node_modules/.pnpm/@noble+hashes@1.8.0/node_modules/@noble/hashes/esm/crypto.js","../../../node_modules/.pnpm/@noble+hashes@1.8.0/node_modules/@noble/hashes/esm/utils.js","../../../node_modules/.pnpm/@noble+curves@1.9.7/node_modules/@noble/curves/esm/utils.js","../../../node_modules/.pnpm/@noble+curves@1.9.7/node_modules/@noble/curves/esm/abstract/modular.js","../../../node_modules/.pnpm/@noble+curves@1.9.7/node_modules/@noble/curves/esm/abstract/montgomery.js","../../../node_modules/.pnpm/@noble+curves@1.9.7/node_modules/@noble/curves/esm/ed25519.js","../../../node_modules/.pnpm/pvtsutils@1.3.6/node_modules/pvtsutils/build/index.es.js","../../../node_modules/.pnpm/pvutils@1.1.5/node_modules/pvutils/build/utils.es.js","../../../node_modules/.pnpm/asn1js@3.0.7/node_modules/asn1js/build/index.es.js","../src/crypto/spki.ts","../src/crypto/base64.ts","../src/crypto/toBuffer.ts","../src/crypto/hkdf.ts","../src/crypto/hmac.ts","../src/crypto/serverKey.ts","../src/notifications.ts","../src/SecureApiClient.ts","../src/plugin.ts"],"sourcesContent":["export const crypto = typeof globalThis === 'object' && 'crypto' in globalThis ? globalThis.crypto : undefined;\n//# sourceMappingURL=crypto.js.map","/**\n * Utilities for hex, bytes, CSPRNG.\n * @module\n */\n/*! noble-hashes - MIT License (c) 2022 Paul Miller (paulmillr.com) */\n// We use WebCrypto aka globalThis.crypto, which exists in browsers and node.js 16+.\n// node.js versions earlier than v19 don't declare it in global scope.\n// For node.js, package.json#exports field mapping rewrites import\n// from `crypto` to `cryptoNode`, which imports native module.\n// Makes the utils un-importable in browsers without a bundler.\n// Once node.js 18 is deprecated (2025-04-30), we can just drop the import.\nimport { crypto } from '@noble/hashes/crypto';\n/** Checks if something is Uint8Array. Be careful: nodejs Buffer will return true. */\nexport function isBytes(a) {\n return a instanceof Uint8Array || (ArrayBuffer.isView(a) && a.constructor.name === 'Uint8Array');\n}\n/** Asserts something is positive integer. */\nexport function anumber(n) {\n if (!Number.isSafeInteger(n) || n < 0)\n throw new Error('positive integer expected, got ' + n);\n}\n/** Asserts something is Uint8Array. */\nexport function abytes(b, ...lengths) {\n if (!isBytes(b))\n throw new Error('Uint8Array expected');\n if (lengths.length > 0 && !lengths.includes(b.length))\n throw new Error('Uint8Array expected of length ' + lengths + ', got length=' + b.length);\n}\n/** Asserts something is hash */\nexport function ahash(h) {\n if (typeof h !== 'function' || typeof h.create !== 'function')\n throw new Error('Hash should be wrapped by utils.createHasher');\n anumber(h.outputLen);\n anumber(h.blockLen);\n}\n/** Asserts a hash instance has not been destroyed / finished */\nexport function aexists(instance, checkFinished = true) {\n if (instance.destroyed)\n throw new Error('Hash instance has been destroyed');\n if (checkFinished && instance.finished)\n throw new Error('Hash#digest() has already been called');\n}\n/** Asserts output is properly-sized byte array */\nexport function aoutput(out, instance) {\n abytes(out);\n const min = instance.outputLen;\n if (out.length < min) {\n throw new Error('digestInto() expects output buffer of length at least ' + min);\n }\n}\n/** Cast u8 / u16 / u32 to u8. */\nexport function u8(arr) {\n return new Uint8Array(arr.buffer, arr.byteOffset, arr.byteLength);\n}\n/** Cast u8 / u16 / u32 to u32. */\nexport function u32(arr) {\n return new Uint32Array(arr.buffer, arr.byteOffset, Math.floor(arr.byteLength / 4));\n}\n/** Zeroize a byte array. Warning: JS provides no guarantees. */\nexport function clean(...arrays) {\n for (let i = 0; i < arrays.length; i++) {\n arrays[i].fill(0);\n }\n}\n/** Create DataView of an array for easy byte-level manipulation. */\nexport function createView(arr) {\n return new DataView(arr.buffer, arr.byteOffset, arr.byteLength);\n}\n/** The rotate right (circular right shift) operation for uint32 */\nexport function rotr(word, shift) {\n return (word << (32 - shift)) | (word >>> shift);\n}\n/** The rotate left (circular left shift) operation for uint32 */\nexport function rotl(word, shift) {\n return (word << shift) | ((word >>> (32 - shift)) >>> 0);\n}\n/** Is current platform little-endian? Most are. Big-Endian platform: IBM */\nexport const isLE = /* @__PURE__ */ (() => new Uint8Array(new Uint32Array([0x11223344]).buffer)[0] === 0x44)();\n/** The byte swap operation for uint32 */\nexport function byteSwap(word) {\n return (((word << 24) & 0xff000000) |\n ((word << 8) & 0xff0000) |\n ((word >>> 8) & 0xff00) |\n ((word >>> 24) & 0xff));\n}\n/** Conditionally byte swap if on a big-endian platform */\nexport const swap8IfBE = isLE\n ? (n) => n\n : (n) => byteSwap(n);\n/** @deprecated */\nexport const byteSwapIfBE = swap8IfBE;\n/** In place byte swap for Uint32Array */\nexport function byteSwap32(arr) {\n for (let i = 0; i < arr.length; i++) {\n arr[i] = byteSwap(arr[i]);\n }\n return arr;\n}\nexport const swap32IfBE = isLE\n ? (u) => u\n : byteSwap32;\n// Built-in hex conversion https://caniuse.com/mdn-javascript_builtins_uint8array_fromhex\nconst hasHexBuiltin = /* @__PURE__ */ (() => \n// @ts-ignore\ntypeof Uint8Array.from([]).toHex === 'function' && typeof Uint8Array.fromHex === 'function')();\n// Array where index 0xf0 (240) is mapped to string 'f0'\nconst hexes = /* @__PURE__ */ Array.from({ length: 256 }, (_, i) => i.toString(16).padStart(2, '0'));\n/**\n * Convert byte array to hex string. Uses built-in function, when available.\n * @example bytesToHex(Uint8Array.from([0xca, 0xfe, 0x01, 0x23])) // 'cafe0123'\n */\nexport function bytesToHex(bytes) {\n abytes(bytes);\n // @ts-ignore\n if (hasHexBuiltin)\n return bytes.toHex();\n // pre-caching improves the speed 6x\n let hex = '';\n for (let i = 0; i < bytes.length; i++) {\n hex += hexes[bytes[i]];\n }\n return hex;\n}\n// We use optimized technique to convert hex string to byte array\nconst asciis = { _0: 48, _9: 57, A: 65, F: 70, a: 97, f: 102 };\nfunction asciiToBase16(ch) {\n if (ch >= asciis._0 && ch <= asciis._9)\n return ch - asciis._0; // '2' => 50-48\n if (ch >= asciis.A && ch <= asciis.F)\n return ch - (asciis.A - 10); // 'B' => 66-(65-10)\n if (ch >= asciis.a && ch <= asciis.f)\n return ch - (asciis.a - 10); // 'b' => 98-(97-10)\n return;\n}\n/**\n * Convert hex string to byte array. Uses built-in function, when available.\n * @example hexToBytes('cafe0123') // Uint8Array.from([0xca, 0xfe, 0x01, 0x23])\n */\nexport function hexToBytes(hex) {\n if (typeof hex !== 'string')\n throw new Error('hex string expected, got ' + typeof hex);\n // @ts-ignore\n if (hasHexBuiltin)\n return Uint8Array.fromHex(hex);\n const hl = hex.length;\n const al = hl / 2;\n if (hl % 2)\n throw new Error('hex string expected, got unpadded hex of length ' + hl);\n const array = new Uint8Array(al);\n for (let ai = 0, hi = 0; ai < al; ai++, hi += 2) {\n const n1 = asciiToBase16(hex.charCodeAt(hi));\n const n2 = asciiToBase16(hex.charCodeAt(hi + 1));\n if (n1 === undefined || n2 === undefined) {\n const char = hex[hi] + hex[hi + 1];\n throw new Error('hex string expected, got non-hex character \"' + char + '\" at index ' + hi);\n }\n array[ai] = n1 * 16 + n2; // multiply first octet, e.g. 'a3' => 10*16+3 => 160 + 3 => 163\n }\n return array;\n}\n/**\n * There is no setImmediate in browser and setTimeout is slow.\n * Call of async fn will return Promise, which will be fullfiled only on\n * next scheduler queue processing step and this is exactly what we need.\n */\nexport const nextTick = async () => { };\n/** Returns control to thread each 'tick' ms to avoid blocking. */\nexport async function asyncLoop(iters, tick, cb) {\n let ts = Date.now();\n for (let i = 0; i < iters; i++) {\n cb(i);\n // Date.now() is not monotonic, so in case if clock goes backwards we return return control too\n const diff = Date.now() - ts;\n if (diff >= 0 && diff < tick)\n continue;\n await nextTick();\n ts += diff;\n }\n}\n/**\n * Converts string to bytes using UTF8 encoding.\n * @example utf8ToBytes('abc') // Uint8Array.from([97, 98, 99])\n */\nexport function utf8ToBytes(str) {\n if (typeof str !== 'string')\n throw new Error('string expected');\n return new Uint8Array(new TextEncoder().encode(str)); // https://bugzil.la/1681809\n}\n/**\n * Converts bytes to string using UTF8 encoding.\n * @example bytesToUtf8(Uint8Array.from([97, 98, 99])) // 'abc'\n */\nexport function bytesToUtf8(bytes) {\n return new TextDecoder().decode(bytes);\n}\n/**\n * Normalizes (non-hex) string or Uint8Array to Uint8Array.\n * Warning: when Uint8Array is passed, it would NOT get copied.\n * Keep in mind for future mutable operations.\n */\nexport function toBytes(data) {\n if (typeof data === 'string')\n data = utf8ToBytes(data);\n abytes(data);\n return data;\n}\n/**\n * Helper for KDFs: consumes uint8array or string.\n * When string is passed, does utf8 decoding, using TextDecoder.\n */\nexport function kdfInputToBytes(data) {\n if (typeof data === 'string')\n data = utf8ToBytes(data);\n abytes(data);\n return data;\n}\n/** Copies several Uint8Arrays into one. */\nexport function concatBytes(...arrays) {\n let sum = 0;\n for (let i = 0; i < arrays.length; i++) {\n const a = arrays[i];\n abytes(a);\n sum += a.length;\n }\n const res = new Uint8Array(sum);\n for (let i = 0, pad = 0; i < arrays.length; i++) {\n const a = arrays[i];\n res.set(a, pad);\n pad += a.length;\n }\n return res;\n}\nexport function checkOpts(defaults, opts) {\n if (opts !== undefined && {}.toString.call(opts) !== '[object Object]')\n throw new Error('options should be object or undefined');\n const merged = Object.assign(defaults, opts);\n return merged;\n}\n/** For runtime check if class implements interface */\nexport class Hash {\n}\n/** Wraps hash function, creating an interface on top of it */\nexport function createHasher(hashCons) {\n const hashC = (msg) => hashCons().update(toBytes(msg)).digest();\n const tmp = hashCons();\n hashC.outputLen = tmp.outputLen;\n hashC.blockLen = tmp.blockLen;\n hashC.create = () => hashCons();\n return hashC;\n}\nexport function createOptHasher(hashCons) {\n const hashC = (msg, opts) => hashCons(opts).update(toBytes(msg)).digest();\n const tmp = hashCons({});\n hashC.outputLen = tmp.outputLen;\n hashC.blockLen = tmp.blockLen;\n hashC.create = (opts) => hashCons(opts);\n return hashC;\n}\nexport function createXOFer(hashCons) {\n const hashC = (msg, opts) => hashCons(opts).update(toBytes(msg)).digest();\n const tmp = hashCons({});\n hashC.outputLen = tmp.outputLen;\n hashC.blockLen = tmp.blockLen;\n hashC.create = (opts) => hashCons(opts);\n return hashC;\n}\nexport const wrapConstructor = createHasher;\nexport const wrapConstructorWithOpts = createOptHasher;\nexport const wrapXOFConstructorWithOpts = createXOFer;\n/** Cryptographically secure PRNG. Uses internal OS-level `crypto.getRandomValues`. */\nexport function randomBytes(bytesLength = 32) {\n if (crypto && typeof crypto.getRandomValues === 'function') {\n return crypto.getRandomValues(new Uint8Array(bytesLength));\n }\n // Legacy Node.js compatibility\n if (crypto && typeof crypto.randomBytes === 'function') {\n return Uint8Array.from(crypto.randomBytes(bytesLength));\n }\n throw new Error('crypto.getRandomValues must be defined');\n}\n//# sourceMappingURL=utils.js.map","/**\n * Hex, bytes and number utilities.\n * @module\n */\n/*! noble-curves - MIT License (c) 2022 Paul Miller (paulmillr.com) */\nimport { abytes as abytes_, bytesToHex as bytesToHex_, concatBytes as concatBytes_, hexToBytes as hexToBytes_, isBytes as isBytes_, } from '@noble/hashes/utils.js';\nexport { abytes, anumber, bytesToHex, bytesToUtf8, concatBytes, hexToBytes, isBytes, randomBytes, utf8ToBytes, } from '@noble/hashes/utils.js';\nconst _0n = /* @__PURE__ */ BigInt(0);\nconst _1n = /* @__PURE__ */ BigInt(1);\nexport function abool(title, value) {\n if (typeof value !== 'boolean')\n throw new Error(title + ' boolean expected, got ' + value);\n}\n// tmp name until v2\nexport function _abool2(value, title = '') {\n if (typeof value !== 'boolean') {\n const prefix = title && `\"${title}\"`;\n throw new Error(prefix + 'expected boolean, got type=' + typeof value);\n }\n return value;\n}\n// tmp name until v2\n/** Asserts something is Uint8Array. */\nexport function _abytes2(value, length, title = '') {\n const bytes = isBytes_(value);\n const len = value?.length;\n const needsLen = length !== undefined;\n if (!bytes || (needsLen && len !== length)) {\n const prefix = title && `\"${title}\" `;\n const ofLen = needsLen ? ` of length ${length}` : '';\n const got = bytes ? `length=${len}` : `type=${typeof value}`;\n throw new Error(prefix + 'expected Uint8Array' + ofLen + ', got ' + got);\n }\n return value;\n}\n// Used in weierstrass, der\nexport function numberToHexUnpadded(num) {\n const hex = num.toString(16);\n return hex.length & 1 ? '0' + hex : hex;\n}\nexport function hexToNumber(hex) {\n if (typeof hex !== 'string')\n throw new Error('hex string expected, got ' + typeof hex);\n return hex === '' ? _0n : BigInt('0x' + hex); // Big Endian\n}\n// BE: Big Endian, LE: Little Endian\nexport function bytesToNumberBE(bytes) {\n return hexToNumber(bytesToHex_(bytes));\n}\nexport function bytesToNumberLE(bytes) {\n abytes_(bytes);\n return hexToNumber(bytesToHex_(Uint8Array.from(bytes).reverse()));\n}\nexport function numberToBytesBE(n, len) {\n return hexToBytes_(n.toString(16).padStart(len * 2, '0'));\n}\nexport function numberToBytesLE(n, len) {\n return numberToBytesBE(n, len).reverse();\n}\n// Unpadded, rarely used\nexport function numberToVarBytesBE(n) {\n return hexToBytes_(numberToHexUnpadded(n));\n}\n/**\n * Takes hex string or Uint8Array, converts to Uint8Array.\n * Validates output length.\n * Will throw error for other types.\n * @param title descriptive title for an error e.g. 'secret key'\n * @param hex hex string or Uint8Array\n * @param expectedLength optional, will compare to result array's length\n * @returns\n */\nexport function ensureBytes(title, hex, expectedLength) {\n let res;\n if (typeof hex === 'string') {\n try {\n res = hexToBytes_(hex);\n }\n catch (e) {\n throw new Error(title + ' must be hex string or Uint8Array, cause: ' + e);\n }\n }\n else if (isBytes_(hex)) {\n // Uint8Array.from() instead of hash.slice() because node.js Buffer\n // is instance of Uint8Array, and its slice() creates **mutable** copy\n res = Uint8Array.from(hex);\n }\n else {\n throw new Error(title + ' must be hex string or Uint8Array');\n }\n const len = res.length;\n if (typeof expectedLength === 'number' && len !== expectedLength)\n throw new Error(title + ' of length ' + expectedLength + ' expected, got ' + len);\n return res;\n}\n// Compares 2 u8a-s in kinda constant time\nexport function equalBytes(a, b) {\n if (a.length !== b.length)\n return false;\n let diff = 0;\n for (let i = 0; i < a.length; i++)\n diff |= a[i] ^ b[i];\n return diff === 0;\n}\n/**\n * Copies Uint8Array. We can't use u8a.slice(), because u8a can be Buffer,\n * and Buffer#slice creates mutable copy. Never use Buffers!\n */\nexport function copyBytes(bytes) {\n return Uint8Array.from(bytes);\n}\n/**\n * Decodes 7-bit ASCII string to Uint8Array, throws on non-ascii symbols\n * Should be safe to use for things expected to be ASCII.\n * Returns exact same result as utf8ToBytes for ASCII or throws.\n */\nexport function asciiToBytes(ascii) {\n return Uint8Array.from(ascii, (c, i) => {\n const charCode = c.charCodeAt(0);\n if (c.length !== 1 || charCode > 127) {\n throw new Error(`string contains non-ASCII character \"${ascii[i]}\" with code ${charCode} at position ${i}`);\n }\n return charCode;\n });\n}\n/**\n * @example utf8ToBytes('abc') // new Uint8Array([97, 98, 99])\n */\n// export const utf8ToBytes: typeof utf8ToBytes_ = utf8ToBytes_;\n/**\n * Converts bytes to string using UTF8 encoding.\n * @example bytesToUtf8(Uint8Array.from([97, 98, 99])) // 'abc'\n */\n// export const bytesToUtf8: typeof bytesToUtf8_ = bytesToUtf8_;\n// Is positive bigint\nconst isPosBig = (n) => typeof n === 'bigint' && _0n <= n;\nexport function inRange(n, min, max) {\n return isPosBig(n) && isPosBig(min) && isPosBig(max) && min <= n && n < max;\n}\n/**\n * Asserts min <= n < max. NOTE: It's < max and not <= max.\n * @example\n * aInRange('x', x, 1n, 256n); // would assume x is in (1n..255n)\n */\nexport function aInRange(title, n, min, max) {\n // Why min <= n < max and not a (min < n < max) OR b (min <= n <= max)?\n // consider P=256n, min=0n, max=P\n // - a for min=0 would require -1: `inRange('x', x, -1n, P)`\n // - b would commonly require subtraction: `inRange('x', x, 0n, P - 1n)`\n // - our way is the cleanest: `inRange('x', x, 0n, P)\n if (!inRange(n, min, max))\n throw new Error('expected valid ' + title + ': ' + min + ' <= n < ' + max + ', got ' + n);\n}\n// Bit operations\n/**\n * Calculates amount of bits in a bigint.\n * Same as `n.toString(2).length`\n * TODO: merge with nLength in modular\n */\nexport function bitLen(n) {\n let len;\n for (len = 0; n > _0n; n >>= _1n, len += 1)\n ;\n return len;\n}\n/**\n * Gets single bit at position.\n * NOTE: first bit position is 0 (same as arrays)\n * Same as `!!+Array.from(n.toString(2)).reverse()[pos]`\n */\nexport function bitGet(n, pos) {\n return (n >> BigInt(pos)) & _1n;\n}\n/**\n * Sets single bit at position.\n */\nexport function bitSet(n, pos, value) {\n return n | ((value ? _1n : _0n) << BigInt(pos));\n}\n/**\n * Calculate mask for N bits. Not using ** operator with bigints because of old engines.\n * Same as BigInt(`0b${Array(i).fill('1').join('')}`)\n */\nexport const bitMask = (n) => (_1n << BigInt(n)) - _1n;\n/**\n * Minimal HMAC-DRBG from NIST 800-90 for RFC6979 sigs.\n * @returns function that will call DRBG until 2nd arg returns something meaningful\n * @example\n * const drbg = createHmacDRBG<Key>(32, 32, hmac);\n * drbg(seed, bytesToKey); // bytesToKey must return Key or undefined\n */\nexport function createHmacDrbg(hashLen, qByteLen, hmacFn) {\n if (typeof hashLen !== 'number' || hashLen < 2)\n throw new Error('hashLen must be a number');\n if (typeof qByteLen !== 'number' || qByteLen < 2)\n throw new Error('qByteLen must be a number');\n if (typeof hmacFn !== 'function')\n throw new Error('hmacFn must be a function');\n // Step B, Step C: set hashLen to 8*ceil(hlen/8)\n const u8n = (len) => new Uint8Array(len); // creates Uint8Array\n const u8of = (byte) => Uint8Array.of(byte); // another shortcut\n let v = u8n(hashLen); // Minimal non-full-spec HMAC-DRBG from NIST 800-90 for RFC6979 sigs.\n let k = u8n(hashLen); // Steps B and C of RFC6979 3.2: set hashLen, in our case always same\n let i = 0; // Iterations counter, will throw when over 1000\n const reset = () => {\n v.fill(1);\n k.fill(0);\n i = 0;\n };\n const h = (...b) => hmacFn(k, v, ...b); // hmac(k)(v, ...values)\n const reseed = (seed = u8n(0)) => {\n // HMAC-DRBG reseed() function. Steps D-G\n k = h(u8of(0x00), seed); // k = hmac(k || v || 0x00 || seed)\n v = h(); // v = hmac(k || v)\n if (seed.length === 0)\n return;\n k = h(u8of(0x01), seed); // k = hmac(k || v || 0x01 || seed)\n v = h(); // v = hmac(k || v)\n };\n const gen = () => {\n // HMAC-DRBG generate() function\n if (i++ >= 1000)\n throw new Error('drbg: tried 1000 values');\n let len = 0;\n const out = [];\n while (len < qByteLen) {\n v = h();\n const sl = v.slice();\n out.push(sl);\n len += v.length;\n }\n return concatBytes_(...out);\n };\n const genUntil = (seed, pred) => {\n reset();\n reseed(seed); // Steps D-G\n let res = undefined; // Step H: grind until k is in [1..n-1]\n while (!(res = pred(gen())))\n reseed();\n reset();\n return res;\n };\n return genUntil;\n}\n// Validating curves and fields\nconst validatorFns = {\n bigint: (val) => typeof val === 'bigint',\n function: (val) => typeof val === 'function',\n boolean: (val) => typeof val === 'boolean',\n string: (val) => typeof val === 'string',\n stringOrUint8Array: (val) => typeof val === 'string' || isBytes_(val),\n isSafeInteger: (val) => Number.isSafeInteger(val),\n array: (val) => Array.isArray(val),\n field: (val, object) => object.Fp.isValid(val),\n hash: (val) => typeof val === 'function' && Number.isSafeInteger(val.outputLen),\n};\n// type Record<K extends string | number | symbol, T> = { [P in K]: T; }\nexport function validateObject(object, validators, optValidators = {}) {\n const checkField = (fieldName, type, isOptional) => {\n const checkVal = validatorFns[type];\n if (typeof checkVal !== 'function')\n throw new Error('invalid validator function');\n const val = object[fieldName];\n if (isOptional && val === undefined)\n return;\n if (!checkVal(val, object)) {\n throw new Error('param ' + String(fieldName) + ' is invalid. Expected ' + type + ', got ' + val);\n }\n };\n for (const [fieldName, type] of Object.entries(validators))\n checkField(fieldName, type, false);\n for (const [fieldName, type] of Object.entries(optValidators))\n checkField(fieldName, type, true);\n return object;\n}\n// validate type tests\n// const o: { a: number; b: number; c: number } = { a: 1, b: 5, c: 6 };\n// const z0 = validateObject(o, { a: 'isSafeInteger' }, { c: 'bigint' }); // Ok!\n// // Should fail type-check\n// const z1 = validateObject(o, { a: 'tmp' }, { c: 'zz' });\n// const z2 = validateObject(o, { a: 'isSafeInteger' }, { c: 'zz' });\n// const z3 = validateObject(o, { test: 'boolean', z: 'bug' });\n// const z4 = validateObject(o, { a: 'boolean', z: 'bug' });\nexport function isHash(val) {\n return typeof val === 'function' && Number.isSafeInteger(val.outputLen);\n}\nexport function _validateObject(object, fields, optFields = {}) {\n if (!object || typeof object !== 'object')\n throw new Error('expected valid options object');\n function checkField(fieldName, expectedType, isOpt) {\n const val = object[fieldName];\n if (isOpt && val === undefined)\n return;\n const current = typeof val;\n if (current !== expectedType || val === null)\n throw new Error(`param \"${fieldName}\" is invalid: expected ${expectedType}, got ${current}`);\n }\n Object.entries(fields).forEach(([k, v]) => checkField(k, v, false));\n Object.entries(optFields).forEach(([k, v]) => checkField(k, v, true));\n}\n/**\n * throws not implemented error\n */\nexport const notImplemented = () => {\n throw new Error('not implemented');\n};\n/**\n * Memoizes (caches) computation result.\n * Uses WeakMap: the value is going auto-cleaned by GC after last reference is removed.\n */\nexport function memoized(fn) {\n const map = new WeakMap();\n return (arg, ...args) => {\n const val = map.get(arg);\n if (val !== undefined)\n return val;\n const computed = fn(arg, ...args);\n map.set(arg, computed);\n return computed;\n };\n}\n//# sourceMappingURL=utils.js.map","/**\n * Utils for modular division and fields.\n * Field over 11 is a finite (Galois) field is integer number operations `mod 11`.\n * There is no division: it is replaced by modular multiplicative inverse.\n * @module\n */\n/*! noble-curves - MIT License (c) 2022 Paul Miller (paulmillr.com) */\nimport { _validateObject, anumber, bitMask, bytesToNumberBE, bytesToNumberLE, ensureBytes, numberToBytesBE, numberToBytesLE, } from \"../utils.js\";\n// prettier-ignore\nconst _0n = BigInt(0), _1n = BigInt(1), _2n = /* @__PURE__ */ BigInt(2), _3n = /* @__PURE__ */ BigInt(3);\n// prettier-ignore\nconst _4n = /* @__PURE__ */ BigInt(4), _5n = /* @__PURE__ */ BigInt(5), _7n = /* @__PURE__ */ BigInt(7);\n// prettier-ignore\nconst _8n = /* @__PURE__ */ BigInt(8), _9n = /* @__PURE__ */ BigInt(9), _16n = /* @__PURE__ */ BigInt(16);\n// Calculates a modulo b\nexport function mod(a, b) {\n const result = a % b;\n return result >= _0n ? result : b + result;\n}\n/**\n * Efficiently raise num to power and do modular division.\n * Unsafe in some contexts: uses ladder, so can expose bigint bits.\n * @example\n * pow(2n, 6n, 11n) // 64n % 11n == 9n\n */\nexport function pow(num, power, modulo) {\n return FpPow(Field(modulo), num, power);\n}\n/** Does `x^(2^power)` mod p. `pow2(30, 4)` == `30^(2^4)` */\nexport function pow2(x, power, modulo) {\n let res = x;\n while (power-- > _0n) {\n res *= res;\n res %= modulo;\n }\n return res;\n}\n/**\n * Inverses number over modulo.\n * Implemented using [Euclidean GCD](https://brilliant.org/wiki/extended-euclidean-algorithm/).\n */\nexport function invert(number, modulo) {\n if (number === _0n)\n throw new Error('invert: expected non-zero number');\n if (modulo <= _0n)\n throw new Error('invert: expected positive modulus, got ' + modulo);\n // Fermat's little theorem \"CT-like\" version inv(n) = n^(m-2) mod m is 30x slower.\n let a = mod(number, modulo);\n let b = modulo;\n // prettier-ignore\n let x = _0n, y = _1n, u = _1n, v = _0n;\n while (a !== _0n) {\n // JIT applies optimization if those two lines follow each other\n const q = b / a;\n const r = b % a;\n const m = x - u * q;\n const n = y - v * q;\n // prettier-ignore\n b = a, a = r, x = u, y = v, u = m, v = n;\n }\n const gcd = b;\n if (gcd !== _1n)\n throw new Error('invert: does not exist');\n return mod(x, modulo);\n}\nfunction assertIsSquare(Fp, root, n) {\n if (!Fp.eql(Fp.sqr(root), n))\n throw new Error('Cannot find square root');\n}\n// Not all roots are possible! Example which will throw:\n// const NUM =\n// n = 72057594037927816n;\n// Fp = Field(BigInt('0x1a0111ea397fe69a4b1ba7b6434bacd764774b84f38512bf6730d2a0f6b0f6241eabfffeb153ffffb9feffffffffaaab'));\nfunction sqrt3mod4(Fp, n) {\n const p1div4 = (Fp.ORDER + _1n) / _4n;\n const root = Fp.pow(n, p1div4);\n assertIsSquare(Fp, root, n);\n return root;\n}\nfunction sqrt5mod8(Fp, n) {\n const p5div8 = (Fp.ORDER - _5n) / _8n;\n const n2 = Fp.mul(n, _2n);\n const v = Fp.pow(n2, p5div8);\n const nv = Fp.mul(n, v);\n const i = Fp.mul(Fp.mul(nv, _2n), v);\n const root = Fp.mul(nv, Fp.sub(i, Fp.ONE));\n assertIsSquare(Fp, root, n);\n return root;\n}\n// Based on RFC9380, Kong algorithm\n// prettier-ignore\nfunction sqrt9mod16(P) {\n const Fp_ = Field(P);\n const tn = tonelliShanks(P);\n const c1 = tn(Fp_, Fp_.neg(Fp_.ONE)); // 1. c1 = sqrt(-1) in F, i.e., (c1^2) == -1 in F\n const c2 = tn(Fp_, c1); // 2. c2 = sqrt(c1) in F, i.e., (c2^2) == c1 in F\n const c3 = tn(Fp_, Fp_.neg(c1)); // 3. c3 = sqrt(-c1) in F, i.e., (c3^2) == -c1 in F\n const c4 = (P + _7n) / _16n; // 4. c4 = (q + 7) / 16 # Integer arithmetic\n return (Fp, n) => {\n let tv1 = Fp.pow(n, c4); // 1. tv1 = x^c4\n let tv2 = Fp.mul(tv1, c1); // 2. tv2 = c1 * tv1\n const tv3 = Fp.mul(tv1, c2); // 3. tv3 = c2 * tv1\n const tv4 = Fp.mul(tv1, c3); // 4. tv4 = c3 * tv1\n const e1 = Fp.eql(Fp.sqr(tv2), n); // 5. e1 = (tv2^2) == x\n const e2 = Fp.eql(Fp.sqr(tv3), n); // 6. e2 = (tv3^2) == x\n tv1 = Fp.cmov(tv1, tv2, e1); // 7. tv1 = CMOV(tv1, tv2, e1) # Select tv2 if (tv2^2) == x\n tv2 = Fp.cmov(tv4, tv3, e2); // 8. tv2 = CMOV(tv4, tv3, e2) # Select tv3 if (tv3^2) == x\n const e3 = Fp.eql(Fp.sqr(tv2), n); // 9. e3 = (tv2^2) == x\n const root = Fp.cmov(tv1, tv2, e3); // 10. z = CMOV(tv1, tv2, e3) # Select sqrt from tv1 & tv2\n assertIsSquare(Fp, root, n);\n return root;\n };\n}\n/**\n * Tonelli-Shanks square root search algorithm.\n * 1. https://eprint.iacr.org/2012/685.pdf (page 12)\n * 2. Square Roots from 1; 24, 51, 10 to Dan Shanks\n * @param P field order\n * @returns function that takes field Fp (created from P) and number n\n */\nexport function tonelliShanks(P) {\n // Initialization (precomputation).\n // Caching initialization could boost perf by 7%.\n if (P < _3n)\n throw new Error('sqrt is not defined for small field');\n // Factor P - 1 = Q * 2^S, where Q is odd\n let Q = P - _1n;\n let S = 0;\n while (Q % _2n === _0n) {\n Q /= _2n;\n S++;\n }\n // Find the first quadratic non-residue Z >= 2\n let Z = _2n;\n const _Fp = Field(P);\n while (FpLegendre(_Fp, Z) === 1) {\n // Basic primality test for P. After x iterations, chance of\n // not finding quadratic non-residue is 2^x, so 2^1000.\n if (Z++ > 1000)\n throw new Error('Cannot find square root: probably non-prime P');\n }\n // Fast-path; usually done before Z, but we do \"primality test\".\n if (S === 1)\n return sqrt3mod4;\n // Slow-path\n // TODO: test on Fp2 and others\n let cc = _Fp.pow(Z, Q); // c = z^Q\n const Q1div2 = (Q + _1n) / _2n;\n return function tonelliSlow(Fp, n) {\n if (Fp.is0(n))\n return n;\n // Check if n is a quadratic residue using Legendre symbol\n if (FpLegendre(Fp, n) !== 1)\n throw new Error('Cannot find square root');\n // Initialize variables for the main loop\n let M = S;\n let c = Fp.mul(Fp.ONE, cc); // c = z^Q, move cc from field _Fp into field Fp\n let t = Fp.pow(n, Q); // t = n^Q, first guess at the fudge factor\n let R = Fp.pow(n, Q1div2); // R = n^((Q+1)/2), first guess at the square root\n // Main loop\n // while t != 1\n while (!Fp.eql(t, Fp.ONE)) {\n if (Fp.is0(t))\n return Fp.ZERO; // if t=0 return R=0\n let i = 1;\n // Find the smallest i >= 1 such that t^(2^i) ≡ 1 (mod P)\n let t_tmp = Fp.sqr(t); // t^(2^1)\n while (!Fp.eql(t_tmp, Fp.ONE)) {\n i++;\n t_tmp = Fp.sqr(t_tmp); // t^(2^2)...\n if (i === M)\n throw new Error('Cannot find square root');\n }\n // Calculate the exponent for b: 2^(M - i - 1)\n const exponent = _1n << BigInt(M - i - 1); // bigint is important\n const b = Fp.pow(c, exponent); // b = 2^(M - i - 1)\n // Update variables\n M = i;\n c = Fp.sqr(b); // c = b^2\n t = Fp.mul(t, c); // t = (t * b^2)\n R = Fp.mul(R, b); // R = R*b\n }\n return R;\n };\n}\n/**\n * Square root for a finite field. Will try optimized versions first:\n *\n * 1. P ≡ 3 (mod 4)\n * 2. P ≡ 5 (mod 8)\n * 3. P ≡ 9 (mod 16)\n * 4. Tonelli-Shanks algorithm\n *\n * Different algorithms can give different roots, it is up to user to decide which one they want.\n * For example there is FpSqrtOdd/FpSqrtEven to choice root based on oddness (used for hash-to-curve).\n */\nexport function FpSqrt(P) {\n // P ≡ 3 (mod 4) => √n = n^((P+1)/4)\n if (P % _4n === _3n)\n return sqrt3mod4;\n // P ≡ 5 (mod 8) => Atkin algorithm, page 10 of https://eprint.iacr.org/2012/685.pdf\n if (P % _8n === _5n)\n return sqrt5mod8;\n // P ≡ 9 (mod 16) => Kong algorithm, page 11 of https://eprint.iacr.org/2012/685.pdf (algorithm 4)\n if (P % _16n === _9n)\n return sqrt9mod16(P);\n // Tonelli-Shanks algorithm\n return tonelliShanks(P);\n}\n// Little-endian check for first LE bit (last BE bit);\nexport const isNegativeLE = (num, modulo) => (mod(num, modulo) & _1n) === _1n;\n// prettier-ignore\nconst FIELD_FIELDS = [\n 'create', 'isValid', 'is0', 'neg', 'inv', 'sqrt', 'sqr',\n 'eql', 'add', 'sub', 'mul', 'pow', 'div',\n 'addN', 'subN', 'mulN', 'sqrN'\n];\nexport function validateField(field) {\n const initial = {\n ORDER: 'bigint',\n MASK: 'bigint',\n BYTES: 'number',\n BITS: 'number',\n };\n const opts = FIELD_FIELDS.reduce((map, val) => {\n map[val] = 'function';\n return map;\n }, initial);\n _validateObject(field, opts);\n // const max = 16384;\n // if (field.BYTES < 1 || field.BYTES > max) throw new Error('invalid field');\n // if (field.BITS < 1 || field.BITS > 8 * max) throw new Error('invalid field');\n return field;\n}\n// Generic field functions\n/**\n * Same as `pow` but for Fp: non-constant-time.\n * Unsafe in some contexts: uses ladder, so can expose bigint bits.\n */\nexport function FpPow(Fp, num, power) {\n if (power < _0n)\n throw new Error('invalid exponent, negatives unsupported');\n if (power === _0n)\n return Fp.ONE;\n if (power === _1n)\n return num;\n let p = Fp.ONE;\n let d = num;\n while (power > _0n) {\n if (power & _1n)\n p = Fp.mul(p, d);\n d = Fp.sqr(d);\n power >>= _1n;\n }\n return p;\n}\n/**\n * Efficiently invert an array of Field elements.\n * Exception-free. Will return `undefined` for 0 elements.\n * @param passZero map 0 to 0 (instead of undefined)\n */\nexport function FpInvertBatch(Fp, nums, passZero = false) {\n const inverted = new Array(nums.length).fill(passZero ? Fp.ZERO : undefined);\n // Walk from first to last, multiply them by each other MOD p\n const multipliedAcc = nums.reduce((acc, num, i) => {\n if (Fp.is0(num))\n return acc;\n inverted[i] = acc;\n return Fp.mul(acc, num);\n }, Fp.ONE);\n // Invert last element\n const invertedAcc = Fp.inv(multipliedAcc);\n // Walk from last to first, multiply them by inverted each other MOD p\n nums.reduceRight((acc, num, i) => {\n if (Fp.is0(num))\n return acc;\n inverted[i] = Fp.mul(acc, inverted[i]);\n return Fp.mul(acc, num);\n }, invertedAcc);\n return inverted;\n}\n// TODO: remove\nexport function FpDiv(Fp, lhs, rhs) {\n return Fp.mul(lhs, typeof rhs === 'bigint' ? invert(rhs, Fp.ORDER) : Fp.inv(rhs));\n}\n/**\n * Legendre symbol.\n * Legendre constant is used to calculate Legendre symbol (a | p)\n * which denotes the value of a^((p-1)/2) (mod p).\n *\n * * (a | p) ≡ 1 if a is a square (mod p), quadratic residue\n * * (a | p) ≡ -1 if a is not a square (mod p), quadratic non residue\n * * (a | p) ≡ 0 if a ≡ 0 (mod p)\n */\nexport function FpLegendre(Fp, n) {\n // We can use 3rd argument as optional cache of this value\n // but seems unneeded for now. The operation is very fast.\n const p1mod2 = (Fp.ORDER - _1n) / _2n;\n const powered = Fp.pow(n, p1mod2);\n const yes = Fp.eql(powered, Fp.ONE);\n const zero = Fp.eql(powered, Fp.ZERO);\n const no = Fp.eql(powered, Fp.neg(Fp.ONE));\n if (!yes && !zero && !no)\n throw new Error('invalid Legendre symbol result');\n return yes ? 1 : zero ? 0 : -1;\n}\n// This function returns True whenever the value x is a square in the field F.\nexport function FpIsSquare(Fp, n) {\n const l = FpLegendre(Fp, n);\n return l === 1;\n}\n// CURVE.n lengths\nexport function nLength(n, nBitLength) {\n // Bit size, byte size of CURVE.n\n if (nBitLength !== undefined)\n anumber(nBitLength);\n const _nBitLength = nBitLength !== undefined ? nBitLength : n.toString(2).length;\n const nByteLength = Math.ceil(_nBitLength / 8);\n return { nBitLength: _nBitLength, nByteLength };\n}\n/**\n * Creates a finite field. Major performance optimizations:\n * * 1. Denormalized operations like mulN instead of mul.\n * * 2. Identical object shape: never add or remove keys.\n * * 3. `Object.freeze`.\n * Fragile: always run a benchmark on a change.\n * Security note: operations don't check 'isValid' for all elements for performance reasons,\n * it is caller responsibility to check this.\n * This is low-level code, please make sure you know what you're doing.\n *\n * Note about field properties:\n * * CHARACTERISTIC p = prime number, number of elements in main subgroup.\n * * ORDER q = similar to cofactor in curves, may be composite `q = p^m`.\n *\n * @param ORDER field order, probably prime, or could be composite\n * @param bitLen how many bits the field consumes\n * @param isLE (default: false) if encoding / decoding should be in little-endian\n * @param redef optional faster redefinitions of sqrt and other methods\n */\nexport function Field(ORDER, bitLenOrOpts, // TODO: use opts only in v2?\nisLE = false, opts = {}) {\n if (ORDER <= _0n)\n throw new Error('invalid field: expected ORDER > 0, got ' + ORDER);\n let _nbitLength = undefined;\n let _sqrt = undefined;\n let modFromBytes = false;\n let allowedLengths = undefined;\n if (typeof bitLenOrOpts === 'object' && bitLenOrOpts != null) {\n if (opts.sqrt || isLE)\n throw new Error('cannot specify opts in two arguments');\n const _opts = bitLenOrOpts;\n if (_opts.BITS)\n _nbitLength = _opts.BITS;\n if (_opts.sqrt)\n _sqrt = _opts.sqrt;\n if (typeof _opts.isLE === 'boolean')\n isLE = _opts.isLE;\n if (typeof _opts.modFromBytes === 'boolean')\n modFromBytes = _opts.modFromBytes;\n allowedLengths = _opts.allowedLengths;\n }\n else {\n if (typeof bitLenOrOpts === 'number')\n _nbitLength = bitLenOrOpts;\n if (opts.sqrt)\n _sqrt = opts.sqrt;\n }\n const { nBitLength: BITS, nByteLength: BYTES } = nLength(ORDER, _nbitLength);\n if (BYTES > 2048)\n throw new Error('invalid field: expected ORDER of <= 2048 bytes');\n let sqrtP; // cached sqrtP\n const f = Object.freeze({\n ORDER,\n isLE,\n BITS,\n BYTES,\n MASK: bitMask(BITS),\n ZERO: _0n,\n ONE: _1n,\n allowedLengths: allowedLengths,\n create: (num) => mod(num, ORDER),\n isValid: (num) => {\n if (typeof num !== 'bigint')\n throw new Error('invalid field element: expected bigint, got ' + typeof num);\n return _0n <= num && num < ORDER; // 0 is valid element, but it's not invertible\n },\n is0: (num) => num === _0n,\n // is valid and invertible\n isValidNot0: (num) => !f.is0(num) && f.isValid(num),\n isOdd: (num) => (num & _1n) === _1n,\n neg: (num) => mod(-num, ORDER),\n eql: (lhs, rhs) => lhs === rhs,\n sqr: (num) => mod(num * num, ORDER),\n add: (lhs, rhs) => mod(lhs + rhs, ORDER),\n sub: (lhs, rhs) => mod(lhs - rhs, ORDER),\n mul: (lhs, rhs) => mod(lhs * rhs, ORDER),\n pow: (num, power) => FpPow(f, num, power),\n div: (lhs, rhs) => mod(lhs * invert(rhs, ORDER), ORDER),\n // Same as above, but doesn't normalize\n sqrN: (num) => num * num,\n addN: (lhs, rhs) => lhs + rhs,\n subN: (lhs, rhs) => lhs - rhs,\n mulN: (lhs, rhs) => lhs * rhs,\n inv: (num) => invert(num, ORDER),\n sqrt: _sqrt ||\n ((n) => {\n if (!sqrtP)\n sqrtP = FpSqrt(ORDER);\n return sqrtP(f, n);\n }),\n toBytes: (num) => (isLE ? numberToBytesLE(num, BYTES) : numberToBytesBE(num, BYTES)),\n fromBytes: (bytes, skipValidation = true) => {\n if (allowedLengths) {\n if (!allowedLengths.includes(bytes.length) || bytes.length > BYTES) {\n throw new Error('Field.fromBytes: expected ' + allowedLengths + ' bytes, got ' + bytes.length);\n }\n const padded = new Uint8Array(BYTES);\n // isLE add 0 to right, !isLE to the left.\n padded.set(bytes, isLE ? 0 : padded.length - bytes.length);\n bytes = padded;\n }\n if (bytes.length !== BYTES)\n throw new Error('Field.fromBytes: expected ' + BYTES + ' bytes, got ' + bytes.length);\n let scalar = isLE ? bytesToNumberLE(bytes) : bytesToNumberBE(bytes);\n if (modFromBytes)\n scalar = mod(scalar, ORDER);\n if (!skipValidation)\n if (!f.isValid(scalar))\n throw new Error('invalid field element: outside of range 0..ORDER');\n // NOTE: we don't validate scalar here, please use isValid. This done such way because some\n // protocol may allow non-reduced scalar that reduced later or changed some other way.\n return scalar;\n },\n // TODO: we don't need it here, move out to separate fn\n invertBatch: (lst) => FpInvertBatch(f, lst),\n // We can't move this out because Fp6, Fp12 implement it\n // and it's unclear what to return in there.\n cmov: (a, b, c) => (c ? b : a),\n });\n return Object.freeze(f);\n}\n// Generic random scalar, we can do same for other fields if via Fp2.mul(Fp2.ONE, Fp2.random)?\n// This allows unsafe methods like ignore bias or zero. These unsafe, but often used in different protocols (if deterministic RNG).\n// which mean we cannot force this via opts.\n// Not sure what to do with randomBytes, we can accept it inside opts if wanted.\n// Probably need to export getMinHashLength somewhere?\n// random(bytes?: Uint8Array, unsafeAllowZero = false, unsafeAllowBias = false) {\n// const LEN = !unsafeAllowBias ? getMinHashLength(ORDER) : BYTES;\n// if (bytes === undefined) bytes = randomBytes(LEN); // _opts.randomBytes?\n// const num = isLE ? bytesToNumberLE(bytes) : bytesToNumberBE(bytes);\n// // `mod(x, 11)` can sometimes produce 0. `mod(x, 10) + 1` is the same, but no 0\n// const reduced = unsafeAllowZero ? mod(num, ORDER) : mod(num, ORDER - _1n) + _1n;\n// return reduced;\n// },\nexport function FpSqrtOdd(Fp, elm) {\n if (!Fp.isOdd)\n throw new Error(\"Field doesn't have isOdd\");\n const root = Fp.sqrt(elm);\n return Fp.isOdd(root) ? root : Fp.neg(root);\n}\nexport function FpSqrtEven(Fp, elm) {\n if (!Fp.isOdd)\n throw new Error(\"Field doesn't have isOdd\");\n const root = Fp.sqrt(elm);\n return Fp.isOdd(root) ? Fp.neg(root) : root;\n}\n/**\n * \"Constant-time\" private key generation utility.\n * Same as mapKeyToField, but accepts less bytes (40 instead of 48 for 32-byte field).\n * Which makes it slightly more biased, less secure.\n * @deprecated use `mapKeyToField` instead\n */\nexport function hashToPrivateScalar(hash, groupOrder, isLE = false) {\n hash = ensureBytes('privateHash', hash);\n const hashLen = hash.length;\n const minLen = nLength(groupOrder).nByteLength + 8;\n if (minLen < 24 || hashLen < minLen || hashLen > 1024)\n throw new Error('hashToPrivateScalar: expected ' + minLen + '-1024 bytes of input, got ' + hashLen);\n const num = isLE ? bytesToNumberLE(hash) : bytesToNumberBE(hash);\n return mod(num, groupOrder - _1n) + _1n;\n}\n/**\n * Returns total number of bytes consumed by the field element.\n * For example, 32 bytes for usual 256-bit weierstrass curve.\n * @param fieldOrder number of field elements, usually CURVE.n\n * @returns byte length of field\n */\nexport function getFieldBytesLength(fieldOrder) {\n if (typeof fieldOrder !== 'bigint')\n throw new Error('field order must be bigint');\n const bitLength = fieldOrder.toString(2).length;\n return Math.ceil(bitLength / 8);\n}\n/**\n * Returns minimal amount of bytes that can be safely reduced\n * by field order.\n * Should be 2^-128 for 128-bit curve such as P256.\n * @param fieldOrder number of field elements, usually CURVE.n\n * @returns byte length of target hash\n */\nexport function getMinHashLength(fieldOrder) {\n const length = getFieldBytesLength(fieldOrder);\n return length + Math.ceil(length / 2);\n}\n/**\n * \"Constant-time\" private key generation utility.\n * Can take (n + n/2) or more bytes of uniform input e.g. from CSPRNG or KDF\n * and convert them into private scalar, with the modulo bias being negligible.\n * Needs at least 48 bytes of input for 32-byte private key.\n * https://research.kudelskisecurity.com/2020/07/28/the-definitive-guide-to-modulo-bias-and-how-to-avoid-it/\n * FIPS 186-5, A.2 https://csrc.nist.gov/publications/detail/fips/186/5/final\n * RFC 9380, https://www.rfc-editor.org/rfc/rfc9380#section-5\n * @param hash hash output from SHA3 or a similar function\n * @param groupOrder size of subgroup - (e.g. secp256k1.CURVE.n)\n * @param isLE interpret hash bytes as LE num\n * @returns valid private scalar\n */\nexport function mapHashToField(key, fieldOrder, isLE = false) {\n const len = key.length;\n const fieldLen = getFieldBytesLength(fieldOrder);\n const minLen = getMinHashLength(fieldOrder);\n // No small numbers: need to understand bias story. No huge numbers: easier to detect JS timings.\n if (len < 16 || len < minLen || len > 1024)\n throw new Error('expected ' + minLen + '-1024 bytes of input, got ' + len);\n const num = isLE ? bytesToNumberLE(key) : bytesToNumberBE(key);\n // `mod(x, 11)` can sometimes produce 0. `mod(x, 10) + 1` is the same, but no 0\n const reduced = mod(num, fieldOrder - _1n) + _1n;\n return isLE ? numberToBytesLE(reduced, fieldLen) : numberToBytesBE(reduced, fieldLen);\n}\n//# sourceMappingURL=modular.js.map","/**\n * Montgomery curve methods. It's not really whole montgomery curve,\n * just bunch of very specific methods for X25519 / X448 from\n * [RFC 7748](https://www.rfc-editor.org/rfc/rfc7748)\n * @module\n */\n/*! noble-curves - MIT License (c) 2022 Paul Miller (paulmillr.com) */\nimport { _validateObject, abytes, aInRange, bytesToNumberLE, ensureBytes, numberToBytesLE, randomBytes, } from \"../utils.js\";\nimport { mod } from \"./modular.js\";\nconst _0n = BigInt(0);\nconst _1n = BigInt(1);\nconst _2n = BigInt(2);\nfunction validateOpts(curve) {\n _validateObject(curve, {\n adjustScalarBytes: 'function',\n powPminus2: 'function',\n });\n return Object.freeze({ ...curve });\n}\nexport function montgomery(curveDef) {\n const CURVE = validateOpts(curveDef);\n const { P, type, adjustScalarBytes, powPminus2, randomBytes: rand } = CURVE;\n const is25519 = type === 'x25519';\n if (!is25519 && type !== 'x448')\n throw new Error('invalid type');\n const randomBytes_ = rand || randomBytes;\n const montgomeryBits = is25519 ? 255 : 448;\n const fieldLen = is25519 ? 32 : 56;\n const Gu = is25519 ? BigInt(9) : BigInt(5);\n // RFC 7748 #5:\n // The constant a24 is (486662 - 2) / 4 = 121665 for curve25519/X25519 and\n // (156326 - 2) / 4 = 39081 for curve448/X448\n // const a = is25519 ? 156326n : 486662n;\n const a24 = is25519 ? BigInt(121665) : BigInt(39081);\n // RFC: x25519 \"the resulting integer is of the form 2^254 plus\n // eight times a value between 0 and 2^251 - 1 (inclusive)\"\n // x448: \"2^447 plus four times a value between 0 and 2^445 - 1 (inclusive)\"\n const minScalar = is25519 ? _2n ** BigInt(254) : _2n ** BigInt(447);\n const maxAdded = is25519\n ? BigInt(8) * _2n ** BigInt(251) - _1n\n : BigInt(4) * _2n ** BigInt(445) - _1n;\n const maxScalar = minScalar + maxAdded + _1n; // (inclusive)\n const modP = (n) => mod(n, P);\n const GuBytes = encodeU(Gu);\n function encodeU(u) {\n return numberToBytesLE(modP(u), fieldLen);\n }\n function decodeU(u) {\n const _u = ensureBytes('u coordinate', u, fieldLen);\n // RFC: When receiving such an array, implementations of X25519\n // (but not X448) MUST mask the most significant bit in the final byte.\n if (is25519)\n _u[31] &= 127; // 0b0111_1111\n // RFC: Implementations MUST accept non-canonical values and process them as\n // if they had been reduced modulo the field prime. The non-canonical\n // values are 2^255 - 19 through 2^255 - 1 for X25519 and 2^448 - 2^224\n // - 1 through 2^448 - 1 for X448.\n return modP(bytesToNumberLE(_u));\n }\n function decodeScalar(scalar) {\n return bytesToNumberLE(adjustScalarBytes(ensureBytes('scalar', scalar, fieldLen)));\n }\n function scalarMult(scalar, u) {\n const pu = montgomeryLadder(decodeU(u), decodeScalar(scalar));\n // Some public keys are useless, of low-order. Curve author doesn't think\n // it needs to be validated, but we do it nonetheless.\n // https://cr.yp.to/ecdh.html#validate\n if (pu === _0n)\n throw new Error('invalid private or public key received');\n return encodeU(pu);\n }\n // Computes public key from private. By doing scalar multiplication of base point.\n function scalarMultBase(scalar) {\n return scalarMult(scalar, GuBytes);\n }\n // cswap from RFC7748 \"example code\"\n function cswap(swap, x_2, x_3) {\n // dummy = mask(swap) AND (x_2 XOR x_3)\n // Where mask(swap) is the all-1 or all-0 word of the same length as x_2\n // and x_3, computed, e.g., as mask(swap) = 0 - swap.\n const dummy = modP(swap * (x_2 - x_3));\n x_2 = modP(x_2 - dummy); // x_2 = x_2 XOR dummy\n x_3 = modP(x_3 + dummy); // x_3 = x_3 XOR dummy\n return { x_2, x_3 };\n }\n /**\n * Montgomery x-only multiplication ladder.\n * @param pointU u coordinate (x) on Montgomery Curve 25519\n * @param scalar by which the point would be multiplied\n * @returns new Point on Montgomery curve\n */\n function montgomeryLadder(u, scalar) {\n aInRange('u', u, _0n, P);\n aInRange('scalar', scalar, minScalar, maxScalar);\n const k = scalar;\n const x_1 = u;\n let x_2 = _1n;\n let z_2 = _0n;\n let x_3 = u;\n let z_3 = _1n;\n let swap = _0n;\n for (let t = BigInt(montgomeryBits - 1); t >= _0n; t--) {\n const k_t = (k >> t) & _1n;\n swap ^= k_t;\n ({ x_2, x_3 } = cswap(swap, x_2, x_3));\n ({ x_2: z_2, x_3: z_3 } = cswap(swap, z_2, z_3));\n swap = k_t;\n const A = x_2 + z_2;\n const AA = modP(A * A);\n const B = x_2 - z_2;\n const BB = modP(B * B);\n const E = AA - BB;\n const C = x_3 + z_3;\n const D = x_3 - z_3;\n const DA = modP(D * A);\n const CB = modP(C * B);\n const dacb = DA + CB;\n const da_cb = DA - CB;\n x_3 = modP(dacb * dacb);\n z_3 = modP(x_1 * modP(da_cb * da_cb));\n x_2 = modP(AA * BB);\n z_2 = modP(E * (AA + modP(a24 * E)));\n }\n ({ x_2, x_3 } = cswap(swap, x_2, x_3));\n ({ x_2: z_2, x_3: z_3 } = cswap(swap, z_2, z_3));\n const z2 = powPminus2(z_2); // `Fp.pow(x, P - _2n)` is much slower equivalent\n return modP(x_2 * z2); // Return x_2 * (z_2^(p - 2))\n }\n const lengths = {\n secretKey: fieldLen,\n publicKey: fieldLen,\n seed: fieldLen,\n };\n const randomSecretKey = (seed = randomBytes_(fieldLen)) => {\n abytes(seed, lengths.seed);\n return seed;\n };\n function keygen(seed) {\n const secretKey = randomSecretKey(seed);\n return { secretKey, publicKey: scalarMultBase(secretKey) };\n }\n const utils = {\n randomSecretKey,\n randomPrivateKey: randomSecretKey,\n };\n return {\n keygen,\n getSharedSecret: (secretKey, publicKey) => scalarMult(secretKey, publicKey),\n getPublicKey: (secretKey) => scalarMultBase(secretKey),\n scalarMult,\n scalarMultBase,\n utils,\n GuBytes: GuBytes.slice(),\n lengths,\n };\n}\n//# sourceMappingURL=montgomery.js.map","/**\n * ed25519 Twisted Edwards curve with following addons:\n * - X25519 ECDH\n * - Ristretto cofactor elimination\n * - Elligator hash-to-group / point indistinguishability\n * @module\n */\n/*! noble-curves - MIT License (c) 2022 Paul Miller (paulmillr.com) */\nimport { sha512 } from '@noble/hashes/sha2.js';\nimport { abytes, concatBytes, utf8ToBytes } from '@noble/hashes/utils.js';\nimport { pippenger } from \"./abstract/curve.js\";\nimport { PrimeEdwardsPoint, twistedEdwards, } from \"./abstract/edwards.js\";\nimport { _DST_scalar, createHasher, expand_message_xmd, } from \"./abstract/hash-to-curve.js\";\nimport { Field, FpInvertBatch, FpSqrtEven, isNegativeLE, mod, pow2, } from \"./abstract/modular.js\";\nimport { montgomery } from \"./abstract/montgomery.js\";\nimport { bytesToNumberLE, ensureBytes, equalBytes } from \"./utils.js\";\n// prettier-ignore\nconst _0n = /* @__PURE__ */ BigInt(0), _1n = BigInt(1), _2n = BigInt(2), _3n = BigInt(3);\n// prettier-ignore\nconst _5n = BigInt(5), _8n = BigInt(8);\n// P = 2n**255n-19n\nconst ed25519_CURVE_p = BigInt('0x7fffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffed');\n// N = 2n**252n + 27742317777372353535851937790883648493n\n// a = Fp.create(BigInt(-1))\n// d = -121665/121666 a.k.a. Fp.neg(121665 * Fp.inv(121666))\nconst ed25519_CURVE = /* @__PURE__ */ (() => ({\n p: ed25519_CURVE_p,\n n: BigInt('0x1000000000000000000000000000000014def9dea2f79cd65812631a5cf5d3ed'),\n h: _8n,\n a: BigInt('0x7fffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffec'),\n d: BigInt('0x52036cee2b6ffe738cc740797779e89800700a4d4141d8ab75eb4dca135978a3'),\n Gx: BigInt('0x216936d3cd6e53fec0a4e231fdd6dc5c692cc7609525a7b2c9562d608f25d51a'),\n Gy: BigInt('0x6666666666666666666666666666666666666666666666666666666666666658'),\n}))();\nfunction ed25519_pow_2_252_3(x) {\n // prettier-ignore\n const _10n = BigInt(10), _20n = BigInt(20), _40n = BigInt(40), _80n = BigInt(80);\n const P = ed25519_CURVE_p;\n const x2 = (x * x) % P;\n const b2 = (x2 * x) % P; // x^3, 11\n const b4 = (pow2(b2, _2n, P) * b2) % P; // x^15, 1111\n const b5 = (pow2(b4, _1n, P) * x) % P; // x^31\n const b10 = (pow2(b5, _5n, P) * b5) % P;\n const b20 = (pow2(b10, _10n, P) * b10) % P;\n const b40 = (pow2(b20, _20n, P) * b20) % P;\n const b80 = (pow2(b40, _40n, P) * b40) % P;\n const b160 = (pow2(b80, _80n, P) * b80) % P;\n const b240 = (pow2(b160, _80n, P) * b80) % P;\n const b250 = (pow2(b240, _10n, P) * b10) % P;\n const pow_p_5_8 = (pow2(b250, _2n, P) * x) % P;\n // ^ To pow to (p+3)/8, multiply it by x.\n return { pow_p_5_8, b2 };\n}\nfunction adjustScalarBytes(bytes) {\n // Section 5: For X25519, in order to decode 32 random bytes as an integer scalar,\n // set the three least significant bits of the first byte\n bytes[0] &= 248; // 0b1111_1000\n // and the most significant bit of the last to zero,\n bytes[31] &= 127; // 0b0111_1111\n // set the second most significant bit of the last byte to 1\n bytes[31] |= 64; // 0b0100_0000\n return bytes;\n}\n// √(-1) aka √(a) aka 2^((p-1)/4)\n// Fp.sqrt(Fp.neg(1))\nconst ED25519_SQRT_M1 = /* @__PURE__ */ BigInt('19681161376707505956807079304988542015446066515923890162744021073123829784752');\n// sqrt(u/v)\nfunction uvRatio(u, v) {\n const P = ed25519_CURVE_p;\n const v3 = mod(v * v * v, P); // v³\n const v7 = mod(v3 * v3 * v, P); // v⁷\n // (p+3)/8 and (p-5)/8\n const pow = ed25519_pow_2_252_3(u * v7).pow_p_5_8;\n let x = mod(u * v3 * pow, P); // (uv³)(uv⁷)^(p-5)/8\n const vx2 = mod(v * x * x, P); // vx²\n const root1 = x; // First root candidate\n const root2 = mod(x * ED25519_SQRT_M1, P); // Second root candidate\n const useRoot1 = vx2 === u; // If vx² = u (mod p), x is a square root\n const useRoot2 = vx2 === mod(-u, P); // If vx² = -u, set x <-- x * 2^((p-1)/4)\n const noRoot = vx2 === mod(-u * ED25519_SQRT_M1, P); // There is no valid root, vx² = -u√(-1)\n if (useRoot1)\n x = root1;\n if (useRoot2 || noRoot)\n x = root2; // We return root2 anyway, for const-time\n if (isNegativeLE(x, P))\n x = mod(-x, P);\n return { isValid: useRoot1 || useRoot2, value: x };\n}\nconst Fp = /* @__PURE__ */ (() => Field(ed25519_CURVE.p, { isLE: true }))();\nconst Fn = /* @__PURE__ */ (() => Field(ed25519_CURVE.n, { isLE: true }))();\nconst ed25519Defaults = /* @__PURE__ */ (() => ({\n ...ed25519_CURVE,\n Fp,\n hash: sha512,\n adjustScalarBytes,\n // dom2\n // Ratio of u to v. Allows us to combine inversion and square root. Uses algo from RFC8032 5.1.3.\n // Constant-time, u/√v\n uvRatio,\n}))();\n/**\n * ed25519 curve with EdDSA signatures.\n * @example\n * import { ed25519 } from '@noble/curves/ed25519';\n * const { secretKey, publicKey } = ed25519.keygen();\n * const msg = new TextEncoder().encode('hello');\n * const sig = ed25519.sign(msg, priv);\n * ed25519.verify(sig, msg, pub); // Default mode: follows ZIP215\n * ed25519.verify(sig, msg, pub, { zip215: false }); // RFC8032 / FIPS 186-5\n */\nexport const ed25519 = /* @__PURE__ */ (() => twistedEdwards(ed25519Defaults))();\nfunction ed25519_domain(data, ctx, phflag) {\n if (ctx.length > 255)\n throw new Error('Context is too big');\n return concatBytes(utf8ToBytes('SigEd25519 no Ed25519 collisions'), new Uint8Array([phflag ? 1 : 0, ctx.length]), ctx, data);\n}\n/** Context of ed25519. Uses context for domain separation. */\nexport const ed25519ctx = /* @__PURE__ */ (() => twistedEdwards({\n ...ed25519Defaults,\n domain: ed25519_domain,\n}))();\n/** Prehashed version of ed25519. Accepts already-hashed messages in sign() and verify(). */\nexport const ed25519ph = /* @__PURE__ */ (() => twistedEdwards(Object.assign({}, ed25519Defaults, {\n domain: ed25519_domain,\n prehash: sha512,\n})))();\n/**\n * ECDH using curve25519 aka x25519.\n * @example\n * import { x25519 } from '@noble/curves/ed25519';\n * const priv = 'a546e36bf0527c9d3b16154b82465edd62144c0ac1fc5a18506a2244ba449ac4';\n * const pub = 'e6db6867583030db3594c1a424b15f7c726624ec26b3353b10a903a6d0ab1c4c';\n * x25519.getSharedSecret(priv, pub) === x25519.scalarMult(priv, pub); // aliases\n * x25519.getPublicKey(priv) === x25519.scalarMultBase(priv);\n * x25519.getPublicKey(x25519.utils.randomSecretKey());\n */\nexport const x25519 = /* @__PURE__ */ (() => {\n const P = Fp.ORDER;\n return montgomery({\n P,\n type: 'x25519',\n powPminus2: (x) => {\n // x^(p-2) aka x^(2^255-21)\n const { pow_p_5_8, b2 } = ed25519_pow_2_252_3(x);\n return mod(pow2(pow_p_5_8, _3n, P) * b2, P);\n },\n adjustScalarBytes,\n });\n})();\n// Hash To Curve Elligator2 Map (NOTE: different from ristretto255 elligator)\n// NOTE: very important part is usage of FpSqrtEven for ELL2_C1_EDWARDS, since\n// SageMath returns different root first and everything falls apart\nconst ELL2_C1 = /* @__PURE__ */ (() => (ed25519_CURVE_p + _3n) / _8n)(); // 1. c1 = (q + 3) / 8 # Integer arithmetic\nconst ELL2_C2 = /* @__PURE__ */ (() => Fp.pow(_2n, ELL2_C1))(); // 2. c2 = 2^c1\nconst ELL2_C3 = /* @__PURE__ */ (() => Fp.sqrt(Fp.neg(Fp.ONE)))(); // 3. c3 = sqrt(-1)\n// prettier-ignore\nfunction map_to_curve_elligator2_curve25519(u) {\n const ELL2_C4 = (ed25519_CURVE_p - _5n) / _8n; // 4. c4 = (q - 5) / 8 # Integer arithmetic\n const ELL2_J = BigInt(486662);\n let tv1 = Fp.sqr(u); // 1. tv1 = u^2\n tv1 = Fp.mul(tv1, _2n); // 2. tv1 = 2 * tv1\n let xd = Fp.add(tv1, Fp.ONE); // 3. xd = tv1 + 1 # Nonzero: -1 is square (mod p), tv1 is not\n let x1n = Fp.neg(ELL2_J); // 4. x1n = -J # x1 = x1n / xd = -J / (1 + 2 * u^2)\n let tv2 = Fp.sqr(xd); // 5. tv2 = xd^2\n let gxd = Fp.mul(tv2, xd); // 6. gxd = tv2 * xd # gxd = xd^3\n let gx1 = Fp.mul(tv1, ELL2_J); // 7. gx1 = J * tv1 # x1n + J * xd\n gx1 = Fp.mul(gx1, x1n); // 8. gx1 = gx1 * x1n # x1n^2 + J * x1n * xd\n gx1 = Fp.add(gx1, tv2); // 9. gx1 = gx1 + tv2 # x1n^2 + J * x1n * xd + xd^2\n gx1 = Fp.mul(gx1, x1n); // 10. gx1 = gx1 * x1n # x1n^3 + J * x1n^2 * xd + x1n * xd^2\n let tv3 = Fp.sqr(gxd); // 11. tv3 = gxd^2\n tv2 = Fp.sqr(tv3); // 12. tv2 = tv3^2 # gxd^4\n tv3 = Fp.mul(tv3, gxd); // 13. tv3 = tv3 * gxd # gxd^3\n tv3 = Fp.mul(tv3, gx1); // 14. tv3 = tv3 * gx1 # gx1 * gxd^3\n tv2 = Fp.mul(tv2, tv3); // 15. tv2 = tv2 * tv3 # gx1 * gxd^7\n let y11 = Fp.pow(tv2, ELL2_C4); // 16. y11 = tv2^c4 # (gx1 * gxd^7)^((p - 5) / 8)\n y11 = Fp.mul(y11, tv3); // 17. y11 = y11 * tv3 # gx1*gxd^3*(gx1*gxd^7)^((p-5)/8)\n let y12 = Fp.mul(y11, ELL2_C3); // 18. y12 = y11 * c3\n tv2 = Fp.sqr(y11); // 19. tv2 = y11^2\n tv2 = Fp.mul(tv2, gxd); // 20. tv2 = tv2 * gxd\n let e1 = Fp.eql(tv2, gx1); // 21. e1 = tv2 == gx1\n let y1 = Fp.cmov(y12, y11, e1); // 22. y1 = CMOV(y12, y11, e1) # If g(x1) is square, this is its sqrt\n let x2n = Fp.mul(x1n, tv1); // 23. x2n = x1n * tv1 # x2 = x2n / xd = 2 * u^2 * x1n / xd\n let y21 = Fp.mul(y11, u); // 24. y21 = y11 * u\n y21 = Fp.mul(y21, ELL2_C2); // 25. y21 = y21 * c2\n let y22 = Fp.mul(y21, ELL2_C3); // 26. y22 = y21 * c3\n let gx2 = Fp.mul(gx1, tv1); // 27. gx2 = gx1 * tv1 # g(x2) = gx2 / gxd = 2 * u^2 * g(x1)\n tv2 = Fp.sqr(y21); // 28. tv2 = y21^2\n tv2 = Fp.mul(tv2, gxd); // 29. tv2 = tv2 * gxd\n let e2 = Fp.eql(tv2, gx2); // 30. e2 = tv2 == gx2\n let y2 = Fp.cmov(y22, y21, e2); // 31. y2 = CMOV(y22, y21, e2) # If g(x2) is square, this is its sqrt\n tv2 = Fp.sqr(y1); // 32. tv2 = y1^2\n tv2 = Fp.mul(tv2, gxd); // 33. tv2 = tv2 * gxd\n let e3 = Fp.eql(tv2, gx1); // 34. e3 = tv2 == gx1\n let xn = Fp.cmov(x2n, x1n, e3); // 35. xn = CMOV(x2n, x1n, e3) # If e3, x = x1, else x = x2\n let y = Fp.cmov(y2, y1, e3); // 36. y = CMOV(y2, y1, e3) # If e3, y = y1, else y = y2\n let e4 = Fp.isOdd(y); // 37. e4 = sgn0(y) == 1 # Fix sign of y\n y = Fp.cmov(y, Fp.neg(y), e3 !== e4); // 38. y = CMOV(y, -y, e3 XOR e4)\n return { xMn: xn, xMd: xd, yMn: y, yMd: _1n }; // 39. return (xn, xd, y, 1)\n}\nconst ELL2_C1_EDWARDS = /* @__PURE__ */ (() => FpSqrtEven(Fp, Fp.neg(BigInt(486664))))(); // sgn0(c1) MUST equal 0\nfunction map_to_curve_elligator2_edwards25519(u) {\n const { xMn, xMd, yMn, yMd } = map_to_curve_elligator2_curve25519(u); // 1. (xMn, xMd, yMn, yMd) =\n // map_to_curve_elligator2_curve25519(u)\n let xn = Fp.mul(xMn, yMd); // 2. xn = xMn * yMd\n xn = Fp.mul(xn, ELL2_C1_EDWARDS); // 3. xn = xn * c1\n let xd = Fp.mul(xMd, yMn); // 4. xd = xMd * yMn # xn / xd = c1 * xM / yM\n let yn = Fp.sub(xMn, xMd); // 5. yn = xMn - xMd\n let yd = Fp.add(xMn, xMd); // 6. yd = xMn + xMd # (n / d - 1) / (n / d + 1) = (n - d) / (n + d)\n let tv1 = Fp.mul(xd, yd); // 7. tv1 = xd * yd\n let e = Fp.eql(tv1, Fp.ZERO); // 8. e = tv1 == 0\n xn = Fp.cmov(xn, Fp.ZERO, e); // 9. xn = CMOV(xn, 0, e)\n xd = Fp.cmov(xd, Fp.ONE, e); // 10. xd = CMOV(xd, 1, e)\n yn = Fp.cmov(yn, Fp.ONE, e); // 11. yn = CMOV(yn, 1, e)\n yd = Fp.cmov(yd, Fp.ONE, e); // 12. yd = CMOV(yd, 1, e)\n const [xd_inv, yd_inv] = FpInvertBatch(Fp, [xd, yd], true); // batch division\n return { x: Fp.mul(xn, xd_inv), y: Fp.mul(yn, yd_inv) }; // 13. return (xn, xd, yn, yd)\n}\n/** Hashing to ed25519 points / field. RFC 9380 methods. */\nexport const ed25519_hasher = /* @__PURE__ */ (() => createHasher(ed25519.Point, (scalars) => map_to_curve_elligator2_edwards25519(scalars[0]), {\n DST: 'edwards25519_XMD:SHA-512_ELL2_RO_',\n encodeDST: 'edwards25519_XMD:SHA-512_ELL2_NU_',\n p: ed25519_CURVE_p,\n m: 1,\n k: 128,\n expand: 'xmd',\n hash: sha512,\n}))();\n// √(-1) aka √(a) aka 2^((p-1)/4)\nconst SQRT_M1 = ED25519_SQRT_M1;\n// √(ad - 1)\nconst SQRT_AD_MINUS_ONE = /* @__PURE__ */ BigInt('25063068953384623474111414158702152701244531502492656460079210482610430750235');\n// 1 / √(a-d)\nconst INVSQRT_A_MINUS_D = /* @__PURE__ */ BigInt('54469307008909316920995813868745141605393597292927456921205312896311721017578');\n// 1-d²\nconst ONE_MINUS_D_SQ = /* @__PURE__ */ BigInt('1159843021668779879193775521855586647937357759715417654439879720876111806838');\n// (d-1)²\nconst D_MINUS_ONE_SQ = /* @__PURE__ */ BigInt('40440834346308536858101042469323190826248399146238708352240133220865137265952');\n// Calculates 1/√(number)\nconst invertSqrt = (number) => uvRatio(_1n, number);\nconst MAX_255B = /* @__PURE__ */ BigInt('0x7fffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffff');\nconst bytes255ToNumberLE = (bytes) => ed25519.Point.Fp.create(bytesToNumberLE(bytes) & MAX_255B);\n/**\n * Computes Elligator map for Ristretto255.\n * Described in [RFC9380](https://www.rfc-editor.org/rfc/rfc9380#appendix-B) and on\n * the [website](https://ristretto.group/formulas/elligator.html).\n */\nfunction calcElligatorRistrettoMap(r0) {\n const { d } = ed25519_CURVE;\n const P = ed25519_CURVE_p;\n const mod = (n) => Fp.create(n);\n const r = mod(SQRT_M1 * r0 * r0); // 1\n const Ns = mod((r + _1n) * ONE_MINUS_D_SQ); // 2\n let c = BigInt(-1); // 3\n const D = mod((c - d * r) * mod(r + d)); // 4\n let { isValid: Ns_D_is_sq, value: s } = uvRatio(Ns, D); // 5\n let s_ = mod(s * r0); // 6\n if (!isNegativeLE(s_, P))\n s_ = mod(-s_);\n if (!Ns_D_is_sq)\n s = s_; // 7\n if (!Ns_D_is_sq)\n c = r; // 8\n const Nt = mod(c * (r - _1n) * D_MINUS_ONE_SQ - D); // 9\n const s2 = s * s;\n const W0 = mod((s + s) * D); // 10\n const W1 = mod(Nt * SQRT_AD_MINUS_ONE); // 11\n const W2 = mod(_1n - s2); // 12\n const W3 = mod(_1n + s2); // 13\n return new ed25519.Point(mod(W0 * W3), mod(W2 * W1), mod(W1 * W3), mod(W0 * W2));\n}\nfunction ristretto255_map(bytes) {\n abytes(bytes, 64);\n const r1 = bytes255ToNumberLE(bytes.subarray(0, 32));\n const R1 = calcElligatorRistrettoMap(r1);\n const r2 = bytes255ToNumberLE(bytes.subarray(32, 64));\n const R2 = calcElligatorRistrettoMap(r2);\n return new _RistrettoPoint(R1.add(R2));\n}\n/**\n * Wrapper over Edwards Point for ristretto255.\n *\n * Each ed25519/ExtendedPoint has 8 different equivalent points. This can be\n * a source of bugs for protocols like ring signatures. Ristretto was created to solve this.\n * Ristretto point operates in X:Y:Z:T extended coordinates like ExtendedPoint,\n * but it should work in its own namespace: do not combine those two.\n * See [RFC9496](https://www.rfc-editor.org/rfc/rfc9496).\n */\nclass _RistrettoPoint extends PrimeEdwardsPoint {\n constructor(ep) {\n super(ep);\n }\n static fromAffine(ap) {\n return new _RistrettoPoint(ed25519.Point.fromAffine(ap));\n }\n assertSame(other) {\n if (!(other instanceof _RistrettoPoint))\n throw new Error('RistrettoPoint expected');\n }\n init(ep) {\n return new _RistrettoPoint(ep);\n }\n /** @deprecated use `import { ristretto255_hasher } from '@noble/curves/ed25519.js';` */\n static hashToCurve(hex) {\n return ristretto255_map(ensureBytes('ristrettoHash', hex, 64));\n }\n static fromBytes(bytes) {\n abytes(bytes, 32);\n const { a, d } = ed25519_CURVE;\n const P = ed25519_CURVE_p;\n const mod = (n) => Fp.create(n);\n const s = bytes255ToNumberLE(bytes);\n // 1. Check that s_bytes is the canonical encoding of a field element, or else abort.\n // 3. Check that s is non-negative, or else abort\n if (!equalBytes(Fp.toBytes(s), bytes) || isNegativeLE(s, P))\n throw new Error('invalid ristretto255 encoding 1');\n const s2 = mod(s * s);\n const u1 = mod(_1n + a * s2); // 4 (a is -1)\n const u2 = mod(_1n - a * s2); // 5\n const u1_2 = mod(u1 * u1);\n const u2_2 = mod(u2 * u2);\n const v = mod(a * d * u1_2 - u2_2); // 6\n const { isValid, value: I } = invertSqrt(mod(v * u2_2)); // 7\n const Dx = mod(I * u2); // 8\n const Dy = mod(I * Dx * v); // 9\n let x = mod((s + s) * Dx); // 10\n if (isNegativeLE(x, P))\n x = mod(-x); // 10\n const y = mod(u1 * Dy); // 11\n const t = mod(x * y); // 12\n if (!isValid || isNegativeLE(t, P) || y === _0n)\n throw new Error('invalid ristretto255 encoding 2');\n return new _RistrettoPoint(new ed25519.Point(x, y, _1n, t));\n }\n /**\n * Converts ristretto-encoded string to ristretto point.\n * Described in [RFC9496](https://www.rfc-editor.org/rfc/rfc9496#name-decode).\n * @param hex Ristretto-encoded 32 bytes. Not every 32-byte string is valid ristretto encoding\n */\n static fromHex(hex) {\n return _RistrettoPoint.fromBytes(ensureBytes('ristrettoHex', hex, 32));\n }\n static msm(points, scalars) {\n return pippenger(_RistrettoPoint, ed25519.Point.Fn, points, scalars);\n }\n /**\n * Encodes ristretto point to Uint8Array.\n * Described in [RFC9496](https://www.rfc-editor.org/rfc/rfc9496#name-encode).\n */\n toBytes() {\n let { X, Y, Z, T } = this.ep;\n const P = ed25519_CURVE_p;\n const mod = (n) => Fp.create(n);\n const u1 = mod(mod(Z + Y) * mod(Z - Y)); // 1\n const u2 = mod(X * Y); // 2\n // Square root always exists\n const u2sq = mod(u2 * u2);\n const { value: invsqrt } = invertSqrt(mod(u1 * u2sq)); // 3\n const D1 = mod(invsqrt * u1); // 4\n const D2 = mod(invsqrt * u2); // 5\n const zInv = mod(D1 * D2 * T); // 6\n let D; // 7\n if (isNegativeLE(T * zInv, P)) {\n let _x = mod(Y * SQRT_M1);\n let _y = mod(X * SQRT_M1);\n X = _x;\n Y = _y;\n D = mod(D1 * INVSQRT_A_MINUS_D);\n }\n else {\n D = D2; // 8\n }\n if (isNegativeLE(X * zInv, P))\n Y = mod(-Y); // 9\n let s = mod((Z - Y) * D); // 10 (check footer's note, no sqrt(-a))\n if (isNegativeLE(s, P))\n s = mod(-s);\n return Fp.toBytes(s); // 11\n }\n /**\n * Compares two Ristretto points.\n * Described in [RFC9496](https://www.rfc-editor.org/rfc/rfc9496#name-equals).\n */\n equals(other) {\n this.assertSame(other);\n const { X: X1, Y: Y1 } = this.ep;\n const { X: X2, Y: Y2 } = other.ep;\n const mod = (n) => Fp.create(n);\n // (x1 * y2 == y1 * x2) | (y1 * y2 == x1 * x2)\n const one = mod(X1 * Y2) === mod(Y1 * X2);\n const two = mod(Y1 * Y2) === mod(X1 * X2);\n return one || two;\n }\n is0() {\n return this.equals(_RistrettoPoint.ZERO);\n }\n}\n// Do NOT change syntax: the following gymnastics is done,\n// because typescript strips comments, which makes bundlers disable tree-shaking.\n// prettier-ignore\n_RistrettoPoint.BASE = \n/* @__PURE__ */ (() => new _RistrettoPoint(ed25519.Point.BASE))();\n// prettier-ignore\n_RistrettoPoint.ZERO = \n/* @__PURE__ */ (() => new _RistrettoPoint(ed25519.Point.ZERO))();\n// prettier-ignore\n_RistrettoPoint.Fp = \n/* @__PURE__ */ (() => Fp)();\n// prettier-ignore\n_RistrettoPoint.Fn = \n/* @__PURE__ */ (() => Fn)();\nexport const ristretto255 = { Point: _RistrettoPoint };\n/** Hashing to ristretto255 points / field. RFC 9380 methods. */\nexport const ristretto255_hasher = {\n hashToCurve(msg, options) {\n const DST = options?.DST || 'ristretto255_XMD:SHA-512_R255MAP_RO_';\n const xmd = expand_message_xmd(msg, DST, 64, sha512);\n return ristretto255_map(xmd);\n },\n hashToScalar(msg, options = { DST: _DST_scalar }) {\n const xmd = expand_message_xmd(msg, options.DST, 64, sha512);\n return Fn.create(bytesToNumberLE(xmd));\n },\n};\n// export const ristretto255_oprf: OPRF = createORPF({\n// name: 'ristretto255-SHA512',\n// Point: RistrettoPoint,\n// hash: sha512,\n// hashToGroup: ristretto255_hasher.hashToCurve,\n// hashToScalar: ristretto255_hasher.hashToScalar,\n// });\n/**\n * Weird / bogus points, useful for debugging.\n * All 8 ed25519 points of 8-torsion subgroup can be generated from the point\n * T = `26e8958fc2b227b045c3f489f2ef98f0d5dfac05d3c63339b13802886d53fc05`.\n * ⟨T⟩ = { O, T, 2T, 3T, 4T, 5T, 6T, 7T }\n */\nexport const ED25519_TORSION_SUBGROUP = [\n '0100000000000000000000000000000000000000000000000000000000000000',\n 'c7176a703d4dd84fba3c0b760d10670f2a2053fa2c39ccc64ec7fd7792ac037a',\n '0000000000000000000000000000000000000000000000000000000000000080',\n '26e8958fc2b227b045c3f489f2ef98f0d5dfac05d3c63339b13802886d53fc05',\n 'ecffffffffffffffffffffffffffffffffffffffffffffffffffffffffffff7f',\n '26e8958fc2b227b045c3f489f2ef98f0d5dfac05d3c63339b13802886d53fc85',\n '0000000000000000000000000000000000000000000000000000000000000000',\n 'c7176a703d4dd84fba3c0b760d10670f2a2053fa2c39ccc64ec7fd7792ac03fa',\n];\n/** @deprecated use `ed25519.utils.toMontgomery` */\nexport function edwardsToMontgomeryPub(edwardsPub) {\n return ed25519.utils.toMontgomery(ensureBytes('pub', edwardsPub));\n}\n/** @deprecated use `ed25519.utils.toMontgomery` */\nexport const edwardsToMontgomery = edwardsToMontgomeryPub;\n/** @deprecated use `ed25519.utils.toMontgomerySecret` */\nexport function edwardsToMontgomeryPriv(edwardsPriv) {\n return ed25519.utils.toMontgomerySecret(ensureBytes('pub', edwardsPriv));\n}\n/** @deprecated use `ristretto255.Point` */\nexport const RistrettoPoint = _RistrettoPoint;\n/** @deprecated use `import { ed25519_hasher } from '@noble/curves/ed25519.js';` */\nexport const hashToCurve = /* @__PURE__ */ (() => ed25519_hasher.hashToCurve)();\n/** @deprecated use `import { ed25519_hasher } from '@noble/curves/ed25519.js';` */\nexport const encodeToCurve = /* @__PURE__ */ (() => ed25519_hasher.encodeToCurve)();\n/** @deprecated use `import { ristretto255_hasher } from '@noble/curves/ed25519.js';` */\nexport const hashToRistretto255 = /* @__PURE__ */ (() => ristretto255_hasher.hashToCurve)();\n/** @deprecated use `import { ristretto255_hasher } from '@noble/curves/ed25519.js';` */\nexport const hash_to_ristretto255 = /* @__PURE__ */ (() => ristretto255_hasher.hashToCurve)();\n//# sourceMappingURL=ed25519.js.map","/*!\n * MIT License\n * \n * Copyright (c) 2017-2024 Peculiar Ventures, LLC\n * \n * Permission is hereby granted, free of charge, to any person obtaining a copy\n * of this software and associated documentation files (the \"Software\"), to deal\n * in the Software without restriction, including without limitation the rights\n * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell\n * copies of the Software, and to permit persons to whom the Software is\n * furnished to do so, subject to the following conditions:\n * \n * The above copyright notice and this permission notice shall be included in all\n * copies or substantial portions of the Software.\n * \n * THE SOFTWARE IS PROVIDED \"AS IS\", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR\n * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,\n * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE\n * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER\n * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,\n * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE\n * SOFTWARE.\n * \n */\n\nconst ARRAY_BUFFER_NAME = \"[object ArrayBuffer]\";\nclass BufferSourceConverter {\n static isArrayBuffer(data) {\n return Object.prototype.toString.call(data) === ARRAY_BUFFER_NAME;\n }\n static toArrayBuffer(data) {\n if (this.isArrayBuffer(data)) {\n return data;\n }\n if (data.byteLength === data.buffer.byteLength) {\n return data.buffer;\n }\n if (data.byteOffset === 0 && data.byteLength === data.buffer.byteLength) {\n return data.buffer;\n }\n return this.toUint8Array(data.buffer)\n .slice(data.byteOffset, data.byteOffset + data.byteLength)\n .buffer;\n }\n static toUint8Array(data) {\n return this.toView(data, Uint8Array);\n }\n static toView(data, type) {\n if (data.constructor === type) {\n return data;\n }\n if (this.isArrayBuffer(data)) {\n return new type(data);\n }\n if (this.isArrayBufferView(data)) {\n return new type(data.buffer, data.byteOffset, data.byteLength);\n }\n throw new TypeError(\"The provided value is not of type '(ArrayBuffer or ArrayBufferView)'\");\n }\n static isBufferSource(data) {\n return this.isArrayBufferView(data)\n || this.isArrayBuffer(data);\n }\n static isArrayBufferView(data) {\n return ArrayBuffer.isView(data)\n || (data && this.isArrayBuffer(data.buffer));\n }\n static isEqual(a, b) {\n const aView = BufferSourceConverter.toUint8Array(a);\n const bView = BufferSourceConverter.toUint8Array(b);\n if (aView.length !== bView.byteLength) {\n return false;\n }\n for (let i = 0; i < aView.length; i++) {\n if (aView[i] !== bView[i]) {\n return false;\n }\n }\n return true;\n }\n static concat(...args) {\n let buffers;\n if (Array.isArray(args[0]) && !(args[1] instanceof Function)) {\n buffers = args[0];\n }\n else if (Array.isArray(args[0]) && args[1] instanceof Function) {\n buffers = args[0];\n }\n else {\n if (args[args.length - 1] instanceof Function) {\n buffers = args.slice(0, args.length - 1);\n }\n else {\n buffers = args;\n }\n }\n let size = 0;\n for (const buffer of buffers) {\n size += buffer.byteLength;\n }\n const res = new Uint8Array(size);\n let offset = 0;\n for (const buffer of buffers) {\n const view = this.toUint8Array(buffer);\n res.set(view, offset);\n offset += view.length;\n }\n if (args[args.length - 1] instanceof Function) {\n return this.toView(res, args[args.length - 1]);\n }\n return res.buffer;\n }\n}\n\nconst STRING_TYPE = \"string\";\nconst HEX_REGEX = /^[0-9a-f\\s]+$/i;\nconst BASE64_REGEX = /^(?:[A-Za-z0-9+/]{4})*(?:[A-Za-z0-9+/]{2}==|[A-Za-z0-9+/]{3}=)?$/;\nconst BASE64URL_REGEX = /^[a-zA-Z0-9-_]+$/;\nclass Utf8Converter {\n static fromString(text) {\n const s = unescape(encodeURIComponent(text));\n const uintArray = new Uint8Array(s.length);\n for (let i = 0; i < s.length; i++) {\n uintArray[i] = s.charCodeAt(i);\n }\n return uintArray.buffer;\n }\n static toString(buffer) {\n const buf = BufferSourceConverter.toUint8Array(buffer);\n let encodedString = \"\";\n for (let i = 0; i < buf.length; i++) {\n encodedString += String.fromCharCode(buf[i]);\n }\n const decodedString = decodeURIComponent(escape(encodedString));\n return decodedString;\n }\n}\nclass Utf16Converter {\n static toString(buffer, littleEndian = false) {\n const arrayBuffer = BufferSourceConverter.toArrayBuffer(buffer);\n const dataView = new DataView(arrayBuffer);\n let res = \"\";\n for (let i = 0; i < arrayBuffer.byteLength; i += 2) {\n const code = dataView.getUint16(i, littleEndian);\n res += String.fromCharCode(code);\n }\n return res;\n }\n static fromString(text, littleEndian = false) {\n const res = new ArrayBuffer(text.length * 2);\n const dataView = new DataView(res);\n for (let i = 0; i < text.length; i++) {\n dataView.setUint16(i * 2, text.charCodeAt(i), littleEndian);\n }\n return res;\n }\n}\nclass Convert {\n static isHex(data) {\n return typeof data === STRING_TYPE\n && HEX_REGEX.test(data);\n }\n static isBase64(data) {\n return typeof data === STRING_TYPE\n && BASE64_REGEX.test(data);\n }\n static isBase64Url(data) {\n return typeof data === STRING_TYPE\n && BASE64URL_REGEX.test(data);\n }\n static ToString(buffer, enc = \"utf8\") {\n const buf = BufferSourceConverter.toUint8Array(buffer);\n switch (enc.toLowerCase()) {\n case \"utf8\":\n return this.ToUtf8String(buf);\n case \"binary\":\n return this.ToBinary(buf);\n case \"hex\":\n return this.ToHex(buf);\n case \"base64\":\n return this.ToBase64(buf);\n case \"base64url\":\n return this.ToBase64Url(buf);\n case \"utf16le\":\n return Utf16Converter.toString(buf, true);\n case \"utf16\":\n case \"utf16be\":\n return Utf16Converter.toString(buf);\n default:\n throw new Error(`Unknown type of encoding '${enc}'`);\n }\n }\n static FromString(str, enc = \"utf8\") {\n if (!str) {\n return new ArrayBuffer(0);\n }\n switch (enc.toLowerCase()) {\n case \"utf8\":\n return this.FromUtf8String(str);\n case \"binary\":\n return this.FromBinary(str);\n case \"hex\":\n return this.FromHex(str);\n case \"base64\":\n return this.FromBase64(str);\n case \"base64url\":\n return this.FromBase64Url(str);\n case \"utf16le\":\n return Utf16Converter.fromString(str, true);\n case \"utf16\":\n case \"utf16be\":\n return Utf16Converter.fromString(str);\n default:\n throw new Error(`Unknown type of encoding '${enc}'`);\n }\n }\n static ToBase64(buffer) {\n const buf = BufferSourceConverter.toUint8Array(buffer);\n if (typeof btoa !== \"undefined\") {\n const binary = this.ToString(buf, \"binary\");\n return btoa(binary);\n }\n else {\n return Buffer.from(buf).toString(\"base64\");\n }\n }\n static FromBase64(base64) {\n const formatted = this.formatString(base64);\n if (!formatted) {\n return new ArrayBuffer(0);\n }\n if (!Convert.isBase64(formatted)) {\n throw new TypeError(\"Argument 'base64Text' is not Base64 encoded\");\n }\n if (typeof atob !== \"undefined\") {\n return this.FromBinary(atob(formatted));\n }\n else {\n return new Uint8Array(Buffer.from(formatted, \"base64\")).buffer;\n }\n }\n static FromBase64Url(base64url) {\n const formatted = this.formatString(base64url);\n if (!formatted) {\n return new ArrayBuffer(0);\n }\n if (!Convert.isBase64Url(formatted)) {\n throw new TypeError(\"Argument 'base64url' is not Base64Url encoded\");\n }\n return this.FromBase64(this.Base64Padding(formatted.replace(/\\-/g, \"+\").replace(/\\_/g, \"/\")));\n }\n static ToBase64Url(data) {\n return this.ToBase64(data).replace(/\\+/g, \"-\").replace(/\\//g, \"_\").replace(/\\=/g, \"\");\n }\n static FromUtf8String(text, encoding = Convert.DEFAULT_UTF8_ENCODING) {\n switch (encoding) {\n case \"ascii\":\n return this.FromBinary(text);\n case \"utf8\":\n return Utf8Converter.fromString(text);\n case \"utf16\":\n case \"utf16be\":\n return Utf16Converter.fromString(text);\n case \"utf16le\":\n case \"usc2\":\n return Utf16Converter.fromString(text, true);\n default:\n throw new Error(`Unknown type of encoding '${encoding}'`);\n }\n }\n static ToUtf8String(buffer, encoding = Convert.DEFAULT_UTF8_ENCODING) {\n switch (encoding) {\n case \"ascii\":\n return this.ToBinary(buffer);\n case \"utf8\":\n return Utf8Converter.toString(buffer);\n case \"utf16\":\n case \"utf16be\":\n return Utf16Converter.toString(buffer);\n case \"utf16le\":\n case \"usc2\":\n return Utf16Converter.toString(buffer, true);\n default:\n throw new Error(`Unknown type of encoding '${encoding}'`);\n }\n }\n static FromBinary(text) {\n const stringLength = text.length;\n const resultView = new Uint8Array(stringLength);\n for (let i = 0; i < stringLength; i++) {\n resultView[i] = text.charCodeAt(i);\n }\n return resultView.buffer;\n }\n static ToBinary(buffer) {\n const buf = BufferSourceConverter.toUint8Array(buffer);\n let res = \"\";\n for (let i = 0; i < buf.length; i++) {\n res += String.fromCharCode(buf[i]);\n }\n return res;\n }\n static ToHex(buffer) {\n const buf = BufferSourceConverter.toUint8Array(buffer);\n let result = \"\";\n const len = buf.length;\n for (let i = 0; i < len; i++) {\n const byte = buf[i];\n if (byte < 16) {\n result += \"0\";\n }\n result += byte.toString(16);\n }\n return result;\n }\n static FromHex(hexString) {\n let formatted = this.formatString(hexString);\n if (!formatted) {\n return new ArrayBuffer(0);\n }\n if (!Convert.isHex(formatted)) {\n throw new TypeError(\"Argument 'hexString' is not HEX encoded\");\n }\n if (formatted.length % 2) {\n formatted = `0${formatted}`;\n }\n const res = new Uint8Array(formatted.length / 2);\n for (let i = 0; i < formatted.length; i = i + 2) {\n const c = formatted.slice(i, i + 2);\n res[i / 2] = parseInt(c, 16);\n }\n return res.buffer;\n }\n static ToUtf16String(buffer, littleEndian = false) {\n return Utf16Converter.toString(buffer, littleEndian);\n }\n static FromUtf16String(text, littleEndian = false) {\n return Utf16Converter.fromString(text, littleEndian);\n }\n static Base64Padding(base64) {\n const padCount = 4 - (base64.length % 4);\n if (padCount < 4) {\n for (let i = 0; i < padCount; i++) {\n base64 += \"=\";\n }\n }\n return base64;\n }\n static formatString(data) {\n return (data === null || data === void 0 ? void 0 : data.replace(/[\\n\\r\\t ]/g, \"\")) || \"\";\n }\n}\nConvert.DEFAULT_UTF8_ENCODING = \"utf8\";\n\nfunction assign(target, ...sources) {\n const res = arguments[0];\n for (let i = 1; i < arguments.length; i++) {\n const obj = arguments[i];\n for (const prop in obj) {\n res[prop] = obj[prop];\n }\n }\n return res;\n}\nfunction combine(...buf) {\n const totalByteLength = buf.map((item) => item.byteLength).reduce((prev, cur) => prev + cur);\n const res = new Uint8Array(totalByteLength);\n let currentPos = 0;\n buf.map((item) => new Uint8Array(item)).forEach((arr) => {\n for (const item2 of arr) {\n res[currentPos++] = item2;\n }\n });\n return res.buffer;\n}\nfunction isEqual(bytes1, bytes2) {\n if (!(bytes1 && bytes2)) {\n return false;\n }\n if (bytes1.byteLength !== bytes2.byteLength) {\n return false;\n }\n const b1 = new Uint8Array(bytes1);\n const b2 = new Uint8Array(bytes2);\n for (let i = 0; i < bytes1.byteLength; i++) {\n if (b1[i] !== b2[i]) {\n return false;\n }\n }\n return true;\n}\n\nexport { BufferSourceConverter, Convert, assign, combine, isEqual };\n","/*!\n Copyright (c) Peculiar Ventures, LLC\n*/\n\nfunction getUTCDate(date) {\r\n return new Date(date.getTime() + (date.getTimezoneOffset() * 60000));\r\n}\r\nfunction getParametersValue(parameters, name, defaultValue) {\r\n var _a;\r\n if ((parameters instanceof Object) === false) {\r\n return defaultValue;\r\n }\r\n return (_a = parameters[name]) !== null && _a !== void 0 ? _a : defaultValue;\r\n}\r\nfunction bufferToHexCodes(inputBuffer, inputOffset = 0, inputLength = (inputBuffer.byteLength - inputOffset), insertSpace = false) {\r\n let result = \"\";\r\n for (const item of (new Uint8Array(inputBuffer, inputOffset, inputLength))) {\r\n const str = item.toString(16).toUpperCase();\r\n if (str.length === 1) {\r\n result += \"0\";\r\n }\r\n result += str;\r\n if (insertSpace) {\r\n result += \" \";\r\n }\r\n }\r\n return result.trim();\r\n}\r\nfunction checkBufferParams(baseBlock, inputBuffer, inputOffset, inputLength) {\r\n if (!(inputBuffer instanceof ArrayBuffer)) {\r\n baseBlock.error = \"Wrong parameter: inputBuffer must be \\\"ArrayBuffer\\\"\";\r\n return false;\r\n }\r\n if (!inputBuffer.byteLength) {\r\n baseBlock.error = \"Wrong parameter: inputBuffer has zero length\";\r\n return false;\r\n }\r\n if (inputOffset < 0) {\r\n baseBlock.error = \"Wrong parameter: inputOffset less than zero\";\r\n return false;\r\n }\r\n if (inputLength < 0) {\r\n baseBlock.error = \"Wrong parameter: inputLength less than zero\";\r\n return false;\r\n }\r\n if ((inputBuffer.byteLength - inputOffset - inputLength) < 0) {\r\n baseBlock.error = \"End of input reached before message was fully decoded (inconsistent offset and length values)\";\r\n return false;\r\n }\r\n return true;\r\n}\r\nfunction utilFromBase(inputBuffer, inputBase) {\r\n let result = 0;\r\n if (inputBuffer.length === 1) {\r\n return inputBuffer[0];\r\n }\r\n for (let i = (inputBuffer.length - 1); i >= 0; i--) {\r\n result += inputBuffer[(inputBuffer.length - 1) - i] * Math.pow(2, inputBase * i);\r\n }\r\n return result;\r\n}\r\nfunction utilToBase(value, base, reserved = (-1)) {\r\n const internalReserved = reserved;\r\n let internalValue = value;\r\n let result = 0;\r\n let biggest = Math.pow(2, base);\r\n for (let i = 1; i < 8; i++) {\r\n if (value < biggest) {\r\n let retBuf;\r\n if (internalReserved < 0) {\r\n retBuf = new ArrayBuffer(i);\r\n result = i;\r\n }\r\n else {\r\n if (internalReserved < i) {\r\n return (new ArrayBuffer(0));\r\n }\r\n retBuf = new ArrayBuffer(internalReserved);\r\n result = internalReserved;\r\n }\r\n const retView = new Uint8Array(retBuf);\r\n for (let j = (i - 1); j >= 0; j--) {\r\n const basis = Math.pow(2, j * base);\r\n retView[result - j - 1] = Math.floor(internalValue / basis);\r\n internalValue -= (retView[result - j - 1]) * basis;\r\n }\r\n return retBuf;\r\n }\r\n biggest *= Math.pow(2, base);\r\n }\r\n return new ArrayBuffer(0);\r\n}\r\nfunction utilConcatBuf(...buffers) {\r\n let outputLength = 0;\r\n let prevLength = 0;\r\n for (const buffer of buffers) {\r\n outputLength += buffer.byteLength;\r\n }\r\n const retBuf = new ArrayBuffer(outputLength);\r\n const retView = new Uint8Array(retBuf);\r\n for (const buffer of buffers) {\r\n retView.set(new Uint8Array(buffer), prevLength);\r\n prevLength += buffer.byteLength;\r\n }\r\n return retBuf;\r\n}\r\nfunction utilConcatView(...views) {\r\n let outputLength = 0;\r\n let prevLength = 0;\r\n for (const view of views) {\r\n outputLength += view.length;\r\n }\r\n const retBuf = new ArrayBuffer(outputLength);\r\n const retView = new Uint8Array(retBuf);\r\n for (const view of views) {\r\n retView.set(view, prevLength);\r\n prevLength += view.length;\r\n }\r\n return retView;\r\n}\r\nfunction utilDecodeTC() {\r\n const buf = new Uint8Array(this.valueHex);\r\n if (this.valueHex.byteLength >= 2) {\r\n const condition1 = (buf[0] === 0xFF) && (buf[1] & 0x80);\r\n const condition2 = (buf[0] === 0x00) && ((buf[1] & 0x80) === 0x00);\r\n if (condition1 || condition2) {\r\n this.warnings.push(\"Needlessly long format\");\r\n }\r\n }\r\n const bigIntBuffer = new ArrayBuffer(this.valueHex.byteLength);\r\n const bigIntView = new Uint8Array(bigIntBuffer);\r\n for (let i = 0; i < this.valueHex.byteLength; i++) {\r\n bigIntView[i] = 0;\r\n }\r\n bigIntView[0] = (buf[0] & 0x80);\r\n const bigInt = utilFromBase(bigIntView, 8);\r\n const smallIntBuffer = new ArrayBuffer(this.valueHex.byteLength);\r\n const smallIntView = new Uint8Array(smallIntBuffer);\r\n for (let j = 0; j < this.valueHex.byteLength; j++) {\r\n smallIntView[j] = buf[j];\r\n }\r\n smallIntView[0] &= 0x7F;\r\n const smallInt = utilFromBase(smallIntView, 8);\r\n return (smallInt - bigInt);\r\n}\r\nfunction utilEncodeTC(value) {\r\n const modValue = (value < 0) ? (value * (-1)) : value;\r\n let bigInt = 128;\r\n for (let i = 1; i < 8; i++) {\r\n if (modValue <= bigInt) {\r\n if (value < 0) {\r\n const smallInt = bigInt - modValue;\r\n const retBuf = utilToBase(smallInt, 8, i);\r\n const retView = new Uint8Array(retBuf);\r\n retView[0] |= 0x80;\r\n return retBuf;\r\n }\r\n let retBuf = utilToBase(modValue, 8, i);\r\n let retView = new Uint8Array(retBuf);\r\n if (retView[0] & 0x80) {\r\n const tempBuf = retBuf.slice(0);\r\n const tempView = new Uint8Array(tempBuf);\r\n retBuf = new ArrayBuffer(retBuf.byteLength + 1);\r\n retView = new Uint8Array(retBuf);\r\n for (let k = 0; k < tempBuf.byteLength; k++) {\r\n retView[k + 1] = tempView[k];\r\n }\r\n retView[0] = 0x00;\r\n }\r\n return retBuf;\r\n }\r\n bigInt *= Math.pow(2, 8);\r\n }\r\n return (new ArrayBuffer(0));\r\n}\r\nfunction isEqualBuffer(inputBuffer1, inputBuffer2) {\r\n if (inputBuffer1.byteLength !== inputBuffer2.byteLength) {\r\n return false;\r\n }\r\n const view1 = new Uint8Array(inputBuffer1);\r\n const view2 = new Uint8Array(inputBuffer2);\r\n for (let i = 0; i < view1.length; i++) {\r\n if (view1[i] !== view2[i]) {\r\n return false;\r\n }\r\n }\r\n return true;\r\n}\r\nfunction padNumber(inputNumber, fullLength) {\r\n const str = inputNumber.toString(10);\r\n if (fullLength < str.length) {\r\n return \"\";\r\n }\r\n const dif = fullLength - str.length;\r\n const padding = new Array(dif);\r\n for (let i = 0; i < dif; i++) {\r\n padding[i] = \"0\";\r\n }\r\n const paddingString = padding.join(\"\");\r\n return paddingString.concat(str);\r\n}\r\nconst base64Template = \"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/=\";\r\nconst base64UrlTemplate = \"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789-_=\";\r\nfunction toBase64(input, useUrlTemplate = false, skipPadding = false, skipLeadingZeros = false) {\r\n let i = 0;\r\n let flag1 = 0;\r\n let flag2 = 0;\r\n let output = \"\";\r\n const template = (useUrlTemplate) ? base64UrlTemplate : base64Template;\r\n if (skipLeadingZeros) {\r\n let nonZeroPosition = 0;\r\n for (let i = 0; i < input.length; i++) {\r\n if (input.charCodeAt(i) !== 0) {\r\n nonZeroPosition = i;\r\n break;\r\n }\r\n }\r\n input = input.slice(nonZeroPosition);\r\n }\r\n while (i < input.length) {\r\n const chr1 = input.charCodeAt(i++);\r\n if (i >= input.length) {\r\n flag1 = 1;\r\n }\r\n const chr2 = input.charCodeAt(i++);\r\n if (i >= input.length) {\r\n flag2 = 1;\r\n }\r\n const chr3 = input.charCodeAt(i++);\r\n const enc1 = chr1 >> 2;\r\n const enc2 = ((chr1 & 0x03) << 4) | (chr2 >> 4);\r\n let enc3 = ((chr2 & 0x0F) << 2) | (chr3 >> 6);\r\n let enc4 = chr3 & 0x3F;\r\n if (flag1 === 1) {\r\n enc3 = enc4 = 64;\r\n }\r\n else {\r\n if (flag2 === 1) {\r\n enc4 = 64;\r\n }\r\n }\r\n if (skipPadding) {\r\n if (enc3 === 64) {\r\n output += `${template.charAt(enc1)}${template.charAt(enc2)}`;\r\n }\r\n else {\r\n if (enc4 === 64) {\r\n output += `${template.charAt(enc1)}${template.charAt(enc2)}${template.charAt(enc3)}`;\r\n }\r\n else {\r\n output += `${template.charAt(enc1)}${template.charAt(enc2)}${template.charAt(enc3)}${template.charAt(enc4)}`;\r\n }\r\n }\r\n }\r\n else {\r\n output += `${template.charAt(enc1)}${template.charAt(enc2)}${template.charAt(enc3)}${template.charAt(enc4)}`;\r\n }\r\n }\r\n return output;\r\n}\r\nfunction fromBase64(input, useUrlTemplate = false, cutTailZeros = false) {\r\n const template = (useUrlTemplate) ? base64UrlTemplate : base64Template;\r\n function indexOf(toSearch) {\r\n for (let i = 0; i < 64; i++) {\r\n if (template.charAt(i) === toSearch)\r\n return i;\r\n }\r\n return 64;\r\n }\r\n function test(incoming) {\r\n return ((incoming === 64) ? 0x00 : incoming);\r\n }\r\n let i = 0;\r\n let output = \"\";\r\n while (i < input.length) {\r\n const enc1 = indexOf(input.charAt(i++));\r\n const enc2 = (i >= input.length) ? 0x00 : indexOf(input.charAt(i++));\r\n const enc3 = (i >= input.length) ? 0x00 : indexOf(input.charAt(i++));\r\n const enc4 = (i >= input.length) ? 0x00 : indexOf(input.charAt(i++));\r\n const chr1 = (test(enc1) << 2) | (test(enc2) >> 4);\r\n const chr2 = ((test(enc2) & 0x0F) << 4) | (test(enc3) >> 2);\r\n const chr3 = ((test(enc3) & 0x03) << 6) | test(enc4);\r\n output += String.fromCharCode(chr1);\r\n if (enc3 !== 64) {\r\n output += String.fromCharCode(chr2);\r\n }\r\n if (enc4 !== 64) {\r\n output += String.fromCharCode(chr3);\r\n }\r\n }\r\n if (cutTailZeros) {\r\n const outputLength = output.length;\r\n let nonZeroStart = (-1);\r\n for (let i = (outputLength - 1); i >= 0; i--) {\r\n if (output.charCodeAt(i) !== 0) {\r\n nonZeroStart = i;\r\n break;\r\n }\r\n }\r\n if (nonZeroStart !== (-1)) {\r\n output = output.slice(0, nonZeroStart + 1);\r\n }\r\n else {\r\n output = \"\";\r\n }\r\n }\r\n return output;\r\n}\r\nfunction arrayBufferToString(buffer) {\r\n let resultString = \"\";\r\n const view = new Uint8Array(buffer);\r\n for (const element of view) {\r\n resultString += String.fromCharCode(element);\r\n }\r\n return resultString;\r\n}\r\nfunction stringToArrayBuffer(str) {\r\n const stringLength = str.length;\r\n const resultBuffer = new ArrayBuffer(stringLength);\r\n const resultView = new Uint8Array(resultBuffer);\r\n for (let i = 0; i < stringLength; i++) {\r\n resultView[i] = str.charCodeAt(i);\r\n }\r\n return resultBuffer;\r\n}\r\nconst log2 = Math.log(2);\r\nfunction nearestPowerOf2(length) {\r\n const base = (Math.log(length) / log2);\r\n const floor = Math.floor(base);\r\n const round = Math.round(base);\r\n return ((floor === round) ? floor : round);\r\n}\r\nfunction clearProps(object, propsArray) {\r\n for (const prop of propsArray) {\r\n delete object[prop];\r\n }\r\n}\n\nexport { arrayBufferToString, bufferToHexCodes, checkBufferParams, clearProps, fromBase64, getParametersValue, getUTCDate, isEqualBuffer, nearestPowerOf2, padNumber, stringToArrayBuffer, toBase64, utilConcatBuf, utilConcatView, utilDecodeTC, utilEncodeTC, utilFromBase, utilToBase };\n","/*!\n * Copyright (c) 2014, GMO GlobalSign\n * Copyright (c) 2015-2022, Peculiar Ventures\n * All rights reserved.\n * \n * Author 2014-2019, Yury Strozhevsky\n * \n * Redistribution and use in source and binary forms, with or without modification,\n * are permitted provided that the following conditions are met:\n * \n * * Redistributions of source code must retain the above copyright notice, this\n * list of conditions and the following disclaimer.\n * \n * * Redistributions in binary form must reproduce the above copyright notice, this\n * list of conditions and the following disclaimer in the documentation and/or\n * other materials provided with the distribution.\n * \n * * Neither the name of the copyright holder nor the names of its\n * contributors may be used to endorse or promote products derived from\n * this software without specific prior written permission.\n * \n * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS \"AS IS\" AND\n * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED\n * WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE\n * DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE FOR\n * ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES\n * (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES;\n * LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON\n * ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT\n * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS\n * SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.\n * \n */\n\nimport * as pvtsutils from 'pvtsutils';\nimport * as pvutils from 'pvutils';\n\nfunction assertBigInt() {\n if (typeof BigInt === \"undefined\") {\n throw new Error(\"BigInt is not defined. Your environment doesn't implement BigInt.\");\n }\n}\nfunction concat(buffers) {\n let outputLength = 0;\n let prevLength = 0;\n for (let i = 0; i < buffers.length; i++) {\n const buffer = buffers[i];\n outputLength += buffer.byteLength;\n }\n const retView = new Uint8Array(outputLength);\n for (let i = 0; i < buffers.length; i++) {\n const buffer = buffers[i];\n retView.set(new Uint8Array(buffer), prevLength);\n prevLength += buffer.byteLength;\n }\n return retView.buffer;\n}\nfunction checkBufferParams(baseBlock, inputBuffer, inputOffset, inputLength) {\n if (!(inputBuffer instanceof Uint8Array)) {\n baseBlock.error = \"Wrong parameter: inputBuffer must be 'Uint8Array'\";\n return false;\n }\n if (!inputBuffer.byteLength) {\n baseBlock.error = \"Wrong parameter: inputBuffer has zero length\";\n return false;\n }\n if (inputOffset < 0) {\n baseBlock.error = \"Wrong parameter: inputOffset less than zero\";\n return false;\n }\n if (inputLength < 0) {\n baseBlock.error = \"Wrong parameter: inputLength less than zero\";\n return false;\n }\n if ((inputBuffer.byteLength - inputOffset - inputLength) < 0) {\n baseBlock.error = \"End of input reached before message was fully decoded (inconsistent offset and length values)\";\n return false;\n }\n return true;\n}\n\nclass ViewWriter {\n constructor() {\n this.items = [];\n }\n write(buf) {\n this.items.push(buf);\n }\n final() {\n return concat(this.items);\n }\n}\n\nconst powers2 = [new Uint8Array([1])];\nconst digitsString = \"0123456789\";\nconst NAME = \"name\";\nconst VALUE_HEX_VIEW = \"valueHexView\";\nconst IS_HEX_ONLY = \"isHexOnly\";\nconst ID_BLOCK = \"idBlock\";\nconst TAG_CLASS = \"tagClass\";\nconst TAG_NUMBER = \"tagNumber\";\nconst IS_CONSTRUCTED = \"isConstructed\";\nconst FROM_BER = \"fromBER\";\nconst TO_BER = \"toBER\";\nconst LOCAL = \"local\";\nconst EMPTY_STRING = \"\";\nconst EMPTY_BUFFER = new ArrayBuffer(0);\nconst EMPTY_VIEW = new Uint8Array(0);\nconst END_OF_CONTENT_NAME = \"EndOfContent\";\nconst OCTET_STRING_NAME = \"OCTET STRING\";\nconst BIT_STRING_NAME = \"BIT STRING\";\n\nfunction HexBlock(BaseClass) {\n var _a;\n return _a = class Some extends BaseClass {\n get valueHex() {\n return this.valueHexView.slice().buffer;\n }\n set valueHex(value) {\n this.valueHexView = new Uint8Array(value);\n }\n constructor(...args) {\n var _b;\n super(...args);\n const params = args[0] || {};\n this.isHexOnly = (_b = params.isHexOnly) !== null && _b !== void 0 ? _b : false;\n this.valueHexView = params.valueHex ? pvtsutils.BufferSourceConverter.toUint8Array(params.valueHex) : EMPTY_VIEW;\n }\n fromBER(inputBuffer, inputOffset, inputLength) {\n const view = inputBuffer instanceof ArrayBuffer ? new Uint8Array(inputBuffer) : inputBuffer;\n if (!checkBufferParams(this, view, inputOffset, inputLength)) {\n return -1;\n }\n const endLength = inputOffset + inputLength;\n this.valueHexView = view.subarray(inputOffset, endLength);\n if (!this.valueHexView.length) {\n this.warnings.push(\"Zero buffer length\");\n return inputOffset;\n }\n this.blockLength = inputLength;\n return endLength;\n }\n toBER(sizeOnly = false) {\n if (!this.isHexOnly) {\n this.error = \"Flag 'isHexOnly' is not set, abort\";\n return EMPTY_BUFFER;\n }\n if (sizeOnly) {\n return new ArrayBuffer(this.valueHexView.byteLength);\n }\n return (this.valueHexView.byteLength === this.valueHexView.buffer.byteLength)\n ? this.valueHexView.buffer\n : this.valueHexView.slice().buffer;\n }\n toJSON() {\n return {\n ...super.toJSON(),\n isHexOnly: this.isHexOnly,\n valueHex: pvtsutils.Convert.ToHex(this.valueHexView),\n };\n }\n },\n _a.NAME = \"hexBlock\",\n _a;\n}\n\nclass LocalBaseBlock {\n static blockName() {\n return this.NAME;\n }\n get valueBeforeDecode() {\n return this.valueBeforeDecodeView.slice().buffer;\n }\n set valueBeforeDecode(value) {\n this.valueBeforeDecodeView = new Uint8Array(value);\n }\n constructor({ blockLength = 0, error = EMPTY_STRING, warnings = [], valueBeforeDecode = EMPTY_VIEW, } = {}) {\n this.blockLength = blockLength;\n this.error = error;\n this.warnings = warnings;\n this.valueBeforeDecodeView = pvtsutils.BufferSourceConverter.toUint8Array(valueBeforeDecode);\n }\n toJSON() {\n return {\n blockName: this.constructor.NAME,\n blockLength: this.blockLength,\n error: this.error,\n warnings: this.warnings,\n valueBeforeDecode: pvtsutils.Convert.ToHex(this.valueBeforeDecodeView),\n };\n }\n}\nLocalBaseBlock.NAME = \"baseBlock\";\n\nclass ValueBlock extends LocalBaseBlock {\n fromBER(_inputBuffer, _inputOffset, _inputLength) {\n throw TypeError(\"User need to make a specific function in a class which extends 'ValueBlock'\");\n }\n toBER(_sizeOnly, _writer) {\n throw TypeError(\"User need to make a specific function in a class which extends 'ValueBlock'\");\n }\n}\nValueBlock.NAME = \"valueBlock\";\n\nclass LocalIdentificationBlock extends HexBlock(LocalBaseBlock) {\n constructor({ idBlock = {} } = {}) {\n var _a, _b, _c, _d;\n super();\n if (idBlock) {\n this.isHexOnly = (_a = idBlock.isHexOnly) !== null && _a !== void 0 ? _a : false;\n this.valueHexView = idBlock.valueHex\n ? pvtsutils.BufferSourceConverter.toUint8Array(idBlock.valueHex)\n : EMPTY_VIEW;\n this.tagClass = (_b = idBlock.tagClass) !== null && _b !== void 0 ? _b : -1;\n this.tagNumber = (_c = idBlock.tagNumber) !== null && _c !== void 0 ? _c : -1;\n this.isConstructed = (_d = idBlock.isConstructed) !== null && _d !== void 0 ? _d : false;\n }\n else {\n this.tagClass = -1;\n this.tagNumber = -1;\n this.isConstructed = false;\n }\n }\n toBER(sizeOnly = false) {\n let firstOctet = 0;\n switch (this.tagClass) {\n case 1:\n firstOctet |= 0x00;\n break;\n case 2:\n firstOctet |= 0x40;\n break;\n case 3:\n firstOctet |= 0x80;\n break;\n case 4:\n firstOctet |= 0xC0;\n break;\n default:\n this.error = \"Unknown tag class\";\n return EMPTY_BUFFER;\n }\n if (this.isConstructed)\n firstOctet |= 0x20;\n if (this.tagNumber < 31 && !this.isHexOnly) {\n const retView = new Uint8Array(1);\n if (!sizeOnly) {\n let number = this.tagNumber;\n number &= 0x1F;\n firstOctet |= number;\n retView[0] = firstOctet;\n }\n return retView.buffer;\n }\n if (!this.isHexOnly) {\n const encodedBuf = pvutils.utilToBase(this.tagNumber, 7);\n const encodedView = new Uint8Array(encodedBuf);\n const size = encodedBuf.byteLength;\n const retView = new Uint8Array(size + 1);\n retView[0] = (firstOctet | 0x1F);\n if (!sizeOnly) {\n for (let i = 0; i < (size - 1); i++)\n retView[i + 1] = encodedView[i] | 0x80;\n retView[size] = encodedView[size - 1];\n }\n return retView.buffer;\n }\n const retView = new Uint8Array(this.valueHexView.byteLength + 1);\n retView[0] = (firstOctet | 0x1F);\n if (!sizeOnly) {\n const curView = this.valueHexView;\n for (let i = 0; i < (curView.length - 1); i++)\n retView[i + 1] = curView[i] | 0x80;\n retView[this.valueHexView.byteLength] = curView[curView.length - 1];\n }\n return retView.buffer;\n }\n fromBER(inputBuffer, inputOffset, inputLength) {\n const inputView = pvtsutils.BufferSourceConverter.toUint8Array(inputBuffer);\n if (!checkBufferParams(this, inputView, inputOffset, inputLength)) {\n return -1;\n }\n const intBuffer = inputView.subarray(inputOffset, inputOffset + inputLength);\n if (intBuffer.length === 0) {\n this.error = \"Zero buffer length\";\n return -1;\n }\n const tagClassMask = intBuffer[0] & 0xC0;\n switch (tagClassMask) {\n case 0x00:\n this.tagClass = (1);\n break;\n case 0x40:\n this.tagClass = (2);\n break;\n case 0x80:\n this.tagClass = (3);\n break;\n case 0xC0:\n this.tagClass = (4);\n break;\n default:\n this.error = \"Unknown tag class\";\n return -1;\n }\n this.isConstructed = (intBuffer[0] & 0x20) === 0x20;\n this.isHexOnly = false;\n const tagNumberMask = intBuffer[0] & 0x1F;\n if (tagNumberMask !== 0x1F) {\n this.tagNumber = (tagNumberMask);\n this.blockLength = 1;\n }\n else {\n let count = 1;\n let intTagNumberBuffer = this.valueHexView = new Uint8Array(255);\n let tagNumberBufferMaxLength = 255;\n while (intBuffer[count] & 0x80) {\n intTagNumberBuffer[count - 1] = intBuffer[count] & 0x7F;\n count++;\n if (count >= intBuffer.length) {\n this.error = \"End of input reached before message was fully decoded\";\n return -1;\n }\n if (count === tagNumberBufferMaxLength) {\n tagNumberBufferMaxLength += 255;\n const tempBufferView = new Uint8Array(tagNumberBufferMaxLength);\n for (let i = 0; i < intTagNumberBuffer.length; i++)\n tempBufferView[i] = intTagNumberBuffer[i];\n intTagNumberBuffer = this.valueHexView = new Uint8Array(tagNumberBufferMaxLength);\n }\n }\n this.blockLength = (count + 1);\n intTagNumberBuffer[count - 1] = intBuffer[count] & 0x7F;\n const tempBufferView = new Uint8Array(count);\n for (let i = 0; i < count; i++)\n tempBufferView[i] = intTagNumberBuffer[i];\n intTagNumberBuffer = this.valueHexView = new Uint8Array(count);\n intTagNumberBuffer.set(tempBufferView);\n if (this.blockLength <= 9)\n this.tagNumber = pvutils.utilFromBase(intTagNumberBuffer, 7);\n else {\n this.isHexOnly = true;\n this.warnings.push(\"Tag too long, represented as hex-coded\");\n }\n }\n if (((this.tagClass === 1))\n && (this.isConstructed)) {\n switch (this.tagNumber) {\n case 1:\n case 2:\n case 5:\n case 6:\n case 9:\n case 13:\n case 14:\n case 23:\n case 24:\n case 31:\n case 32:\n case 33:\n case 34:\n this.error = \"Constructed encoding used for primitive type\";\n return -1;\n }\n }\n return (inputOffset + this.blockLength);\n }\n toJSON() {\n return {\n ...super.toJSON(),\n tagClass: this.tagClass,\n tagNumber: this.tagNumber,\n isConstructed: this.isConstructed,\n };\n }\n}\nLocalIdentificationBlock.NAME = \"identificationBlock\";\n\nclass LocalLengthBlock extends LocalBaseBlock {\n constructor({ lenBlock = {} } = {}) {\n var _a, _b, _c;\n super();\n this.isIndefiniteForm = (_a = lenBlock.isIndefiniteForm) !== null && _a !== void 0 ? _a : false;\n this.longFormUsed = (_b = lenBlock.longFormUsed) !== null && _b !== void 0 ? _b : false;\n this.length = (_c = lenBlock.length) !== null && _c !== void 0 ? _c : 0;\n }\n fromBER(inputBuffer, inputOffset, inputLength) {\n const view = pvtsutils.BufferSourceConverter.toUint8Array(inputBuffer);\n if (!checkBufferParams(this, view, inputOffset, inputLength)) {\n return -1;\n }\n const intBuffer = view.subarray(inputOffset, inputOffset + inputLength);\n if (intBuffer.length === 0) {\n this.error = \"Zero buffer length\";\n return -1;\n }\n if (intBuffer[0] === 0xFF) {\n this.error = \"Length block 0xFF is reserved by standard\";\n return -1;\n }\n this.isIndefiniteForm = intBuffer[0] === 0x80;\n if (this.isIndefiniteForm) {\n this.blockLength = 1;\n return (inputOffset + this.blockLength);\n }\n this.longFormUsed = !!(intBuffer[0] & 0x80);\n if (this.longFormUsed === false) {\n this.length = (intBuffer[0]);\n this.blockLength = 1;\n return (inputOffset + this.blockLength);\n }\n const count = intBuffer[0] & 0x7F;\n if (count > 8) {\n this.error = \"Too big integer\";\n return -1;\n }\n if ((count + 1) > intBuffer.length) {\n this.error = \"End of input reached before message was fully decoded\";\n return -1;\n }\n const lenOffset = inputOffset + 1;\n const lengthBufferView = view.subarray(lenOffset, lenOffset + count);\n if (lengthBufferView[count - 1] === 0x00)\n this.warnings.push(\"Needlessly long encoded length\");\n this.length = pvutils.utilFromBase(lengthBufferView, 8);\n if (this.longFormUsed && (this.length <= 127))\n this.warnings.push(\"Unnecessary usage of long length form\");\n this.blockLength = count + 1;\n return (inputOffset + this.blockLength);\n }\n toBER(sizeOnly = false) {\n let retBuf;\n let retView;\n if (this.length > 127)\n this.longFormUsed = true;\n if (this.isIndefiniteForm) {\n retBuf = new ArrayBuffer(1);\n if (sizeOnly === false) {\n retView = new Uint8Array(retBuf);\n retView[0] = 0x80;\n }\n return retBuf;\n }\n if (this.longFormUsed) {\n const encodedBuf = pvutils.utilToBase(this.length, 8);\n if (encodedBuf.byteLength > 127) {\n this.error = \"Too big length\";\n return (EMPTY_BUFFER);\n }\n retBuf = new ArrayBuffer(encodedBuf.byteLength + 1);\n if (sizeOnly)\n return retBuf;\n const encodedView = new Uint8Array(encodedBuf);\n retView = new Uint8Array(retBuf);\n retView[0] = encodedBuf.byteLength | 0x80;\n for (let i = 0; i < encodedBuf.byteLength; i++)\n retView[i + 1] = encodedView[i];\n return retBuf;\n }\n retBuf = new ArrayBuffer(1);\n if (sizeOnly === false) {\n retView = new Uint8Array(retBuf);\n retView[0] = this.length;\n }\n return retBuf;\n }\n toJSON() {\n return {\n ...super.toJSON(),\n isIndefiniteForm: this.isIndefiniteForm,\n longFormUsed: this.longFormUsed,\n length: this.length,\n };\n }\n}\nLocalLengthBlock.NAME = \"lengthBlock\";\n\nconst typeStore = {};\n\nclass BaseBlock extends LocalBaseBlock {\n constructor({ name = EMPTY_STRING, optional = false, primitiveSchema, ...parameters } = {}, valueBlockType) {\n super(parameters);\n this.name = name;\n this.optional = optional;\n if (primitiveSchema) {\n this.primitiveSchema = primitiveSchema;\n }\n this.idBlock = new LocalIdentificationBlock(parameters);\n this.lenBlock = new LocalLengthBlock(parameters);\n this.valueBlock = valueBlockType ? new valueBlockType(parameters) : new ValueBlock(parameters);\n }\n fromBER(inputBuffer, inputOffset, inputLength) {\n const resultOffset = this.valueBlock.fromBER(inputBuffer, inputOffset, (this.lenBlock.isIndefiniteForm)\n ? inputLength\n : this.lenBlock.length);\n if (resultOffset === -1) {\n this.error = this.valueBlock.error;\n return resultOffset;\n }\n if (!this.idBlock.error.length)\n this.blockLength += this.idBlock.blockLength;\n if (!this.lenBlock.error.length)\n this.blockLength += this.lenBlock.blockLength;\n if (!this.valueBlock.error.length)\n this.blockLength += this.valueBlock.blockLength;\n return resultOffset;\n }\n toBER(sizeOnly, writer) {\n const _writer = writer || new ViewWriter();\n if (!writer) {\n prepareIndefiniteForm(this);\n }\n const idBlockBuf = this.idBlock.toBER(sizeOnly);\n _writer.write(idBlockBuf);\n if (this.lenBlock.isIndefiniteForm) {\n _writer.write(new Uint8Array([0x80]).buffer);\n this.valueBlock.toBER(sizeOnly, _writer);\n _writer.write(new ArrayBuffer(2));\n }\n else {\n const valueBlockBuf = this.valueBlock.toBER(sizeOnly);\n this.lenBlock.length = valueBlockBuf.byteLength;\n const lenBlockBuf = this.lenBlock.toBER(sizeOnly);\n _writer.write(lenBlockBuf);\n _writer.write(valueBlockBuf);\n }\n if (!writer) {\n return _writer.final();\n }\n return EMPTY_BUFFER;\n }\n toJSON() {\n const object = {\n ...super.toJSON(),\n idBlock: this.idBlock.toJSON(),\n lenBlock: this.lenBlock.toJSON(),\n valueBlock: this.valueBlock.toJSON(),\n name: this.name,\n optional: this.optional,\n };\n if (this.primitiveSchema)\n object.primitiveSchema = this.primitiveSchema.toJSON();\n return object;\n }\n toString(encoding = \"ascii\") {\n if (encoding === \"ascii\") {\n return this.onAsciiEncoding();\n }\n return pvtsutils.Convert.ToHex(this.toBER());\n }\n onAsciiEncoding() {\n const name = this.constructor.NAME;\n const value = pvtsutils.Convert.ToHex(this.valueBlock.valueBeforeDecodeView);\n return `${name} : ${value}`;\n }\n isEqual(other) {\n if (this === other) {\n return true;\n }\n if (!(other instanceof this.constructor)) {\n return false;\n }\n const thisRaw = this.toBER();\n const otherRaw = other.toBER();\n return pvutils.isEqualBuffer(thisRaw, otherRaw);\n }\n}\nBaseBlock.NAME = \"BaseBlock\";\nfunction prepareIndefiniteForm(baseBlock) {\n var _a;\n if (baseBlock instanceof typeStore.Constructed) {\n for (const value of baseBlock.valueBlock.value) {\n if (prepareIndefiniteForm(value)) {\n baseBlock.lenBlock.isIndefiniteForm = true;\n }\n }\n }\n return !!((_a = baseBlock.lenBlock) === null || _a === void 0 ? void 0 : _a.isIndefiniteForm);\n}\n\nclass BaseStringBlock extends BaseBlock {\n getValue() {\n return this.valueBlock.value;\n }\n setValue(value) {\n this.valueBlock.value = value;\n }\n constructor({ value = EMPTY_STRING, ...parameters } = {}, stringValueBlockType) {\n super(parameters, stringValueBlockType);\n if (value) {\n this.fromString(value);\n }\n }\n fromBER(inputBuffer, inputOffset, inputLength) {\n const resultOffset = this.valueBlock.fromBER(inputBuffer, inputOffset, (this.lenBlock.isIndefiniteForm)\n ? inputLength\n : this.lenBlock.length);\n if (resultOffset === -1) {\n this.error = this.valueBlock.error;\n return resultOffset;\n }\n this.fromBuffer(this.valueBlock.valueHexView);\n if (!this.idBlock.error.length)\n this.blockLength += this.idBlock.blockLength;\n if (!this.lenBlock.error.length)\n this.blockLength += this.lenBlock.blockLength;\n if (!this.valueBlock.error.length)\n this.blockLength += this.valueBlock.blockLength;\n return resultOffset;\n }\n onAsciiEncoding() {\n return `${this.constructor.NAME} : '${this.valueBlock.value}'`;\n }\n}\nBaseStringBlock.NAME = \"BaseStringBlock\";\n\nclass LocalPrimitiveValueBlock extends HexBlock(ValueBlock) {\n constructor({ isHexOnly = true, ...parameters } = {}) {\n super(parameters);\n this.isHexOnly = isHexOnly;\n }\n}\nLocalPrimitiveValueBlock.NAME = \"PrimitiveValueBlock\";\n\nvar _a$w;\nclass Primitive extends BaseBlock {\n constructor(parameters = {}) {\n super(parameters, LocalPrimitiveValueBlock);\n this.idBlock.isConstructed = false;\n }\n}\n_a$w = Primitive;\n(() => {\n typeStore.Primitive = _a$w;\n})();\nPrimitive.NAME = \"PRIMITIVE\";\n\nfunction localChangeType(inputObject, newType) {\n if (inputObject instanceof newType) {\n return inputObject;\n }\n const newObject = new newType();\n newObject.idBlock = inputObject.idBlock;\n newObject.lenBlock = inputObject.lenBlock;\n newObject.warnings = inputObject.warnings;\n newObject.valueBeforeDecodeView = inputObject.valueBeforeDecodeView;\n return newObject;\n}\nfunction localFromBER(inputBuffer, inputOffset = 0, inputLength = inputBuffer.length) {\n const incomingOffset = inputOffset;\n let returnObject = new BaseBlock({}, ValueBlock);\n const baseBlock = new LocalBaseBlock();\n if (!checkBufferParams(baseBlock, inputBuffer, inputOffset, inputLength)) {\n returnObject.error = baseBlock.error;\n return {\n offset: -1,\n result: returnObject,\n };\n }\n const intBuffer = inputBuffer.subarray(inputOffset, inputOffset + inputLength);\n if (!intBuffer.length) {\n returnObject.error = \"Zero buffer length\";\n return {\n offset: -1,\n result: returnObject,\n };\n }\n let resultOffset = returnObject.idBlock.fromBER(inputBuffer, inputOffset, inputLength);\n if (returnObject.idBlock.warnings.length) {\n returnObject.warnings.concat(returnObject.idBlock.warnings);\n }\n if (resultOffset === -1) {\n returnObject.error = returnObject.idBlock.error;\n return {\n offset: -1,\n result: returnObject,\n };\n }\n inputOffset = resultOffset;\n inputLength -= returnObject.idBlock.blockLength;\n resultOffset = returnObject.lenBlock.fromBER(inputBuffer, inputOffset, inputLength);\n if (returnObject.lenBlock.warnings.length) {\n returnObject.warnings.concat(returnObject.lenBlock.warnings);\n }\n if (resultOffset === -1) {\n returnObject.error = returnObject.lenBlock.error;\n return {\n offset: -1,\n result: returnObject,\n };\n }\n inputOffset = resultOffset;\n inputLength -= returnObject.lenBlock.blockLength;\n if (!returnObject.idBlock.isConstructed\n && returnObject.lenBlock.isIndefiniteForm) {\n returnObject.error = \"Indefinite length form used for primitive encoding form\";\n return {\n offset: -1,\n result: returnObject,\n };\n }\n let newASN1Type = BaseBlock;\n switch (returnObject.idBlock.tagClass) {\n case 1:\n if ((returnObject.idBlock.tagNumber >= 37)\n && (returnObject.idBlock.isHexOnly === false)) {\n returnObject.error = \"UNIVERSAL 37 and upper tags are reserved by ASN.1 standard\";\n return {\n offset: -1,\n result: returnObject,\n };\n }\n switch (returnObject.idBlock.tagNumber) {\n case 0:\n if ((returnObject.idBlock.isConstructed)\n && (returnObject.lenBlock.length > 0)) {\n returnObject.error = \"Type [UNIVERSAL 0] is reserved\";\n return {\n offset: -1,\n result: returnObject,\n };\n }\n newASN1Type = typeStore.EndOfContent;\n break;\n case 1:\n newASN1Type = typeStore.Boolean;\n break;\n case 2:\n newASN1Type = typeStore.Integer;\n break;\n case 3:\n newASN1Type = typeStore.BitString;\n break;\n case 4:\n newASN1Type = typeStore.OctetString;\n break;\n case 5:\n newASN1Type = typeStore.Null;\n break;\n case 6:\n newASN1Type = typeStore.ObjectIdentifier;\n break;\n case 10:\n newASN1Type = typeStore.Enumerated;\n break;\n case 12:\n newASN1Type = typeStore.Utf8String;\n break;\n case 13:\n newASN1Type = typeStore.RelativeObjectIdentifier;\n break;\n case 14:\n newASN1Type = typeStore.TIME;\n break;\n case 15:\n returnObject.error = \"[UNIVERSAL 15] is reserved by ASN.1 standard\";\n return {\n offset: -1,\n result: returnObject,\n };\n case 16:\n newASN1Type = typeStore.Sequence;\n break;\n case 17:\n newASN1Type = typeStore.Set;\n break;\n case 18:\n newASN1Type = typeStore.NumericString;\n break;\n case 19:\n newASN1Type = typeStore.PrintableString;\n break;\n case 20:\n newASN1Type = typeStore.TeletexString;\n break;\n case 21:\n newASN1Type = typeStore.VideotexString;\n break;\n case 22:\n newASN1Type = typeStore.IA5String;\n break;\n case 23:\n newASN1Type = typeStore.UTCTime;\n break;\n case 24:\n newASN1Type = typeStore.GeneralizedTime;\n break;\n case 25:\n newASN1Type = typeStore.GraphicString;\n break;\n case 26:\n newASN1Type = typeStore.VisibleString;\n break;\n case 27:\n newASN1Type = typeStore.GeneralString;\n break;\n case 28:\n newASN1Type = typeStore.UniversalString;\n break;\n case 29:\n newASN1Type = typeStore.CharacterString;\n break;\n case 30:\n newASN1Type = typeStore.BmpString;\n break;\n case 31:\n newASN1Type = typeStore.DATE;\n break;\n case 32:\n newASN1Type = typeStore.TimeOfDay;\n break;\n case 33:\n newASN1Type = typeStore.DateTime;\n break;\n case 34:\n newASN1Type = typeStore.Duration;\n break;\n default: {\n const newObject = returnObject.idBlock.isConstructed\n ? new typeStore.Constructed()\n : new typeStore.Primitive();\n newObject.idBlock = returnObject.idBlock;\n newObject.lenBlock = returnObject.lenBlock;\n newObject.warnings = returnObject.warnings;\n returnObject = newObject;\n }\n }\n break;\n case 2:\n case 3:\n case 4:\n default: {\n newASN1Type = returnObject.idBlock.isConstructed\n ? typeStore.Constructed\n : typeStore.Primitive;\n }\n }\n returnObject = localChangeType(returnObject, newASN1Type);\n resultOffset = returnObject.fromBER(inputBuffer, inputOffset, returnObject.lenBlock.isIndefiniteForm ? inputLength : returnObject.lenBlock.length);\n returnObject.valueBeforeDecodeView = inputBuffer.subarray(incomingOffset, incomingOffset + returnObject.blockLength);\n return {\n offset: resultOffset,\n result: returnObject,\n };\n}\nfunction fromBER(inputBuffer) {\n if (!inputBuffer.byteLength) {\n const result = new BaseBlock({}, ValueBlock);\n result.error = \"Input buffer has zero length\";\n return {\n offset: -1,\n result,\n };\n }\n return localFromBER(pvtsutils.BufferSourceConverter.toUint8Array(inputBuffer).slice(), 0, inputBuffer.byteLength);\n}\n\nfunction checkLen(indefiniteLength, length) {\n if (indefiniteLength) {\n return 1;\n }\n return length;\n}\nclass LocalConstructedValueBlock extends ValueBlock {\n constructor({ value = [], isIndefiniteForm = false, ...parameters } = {}) {\n super(parameters);\n this.value = value;\n this.isIndefiniteForm = isIndefiniteForm;\n }\n fromBER(inputBuffer, inputOffset, inputLength) {\n const view = pvtsutils.BufferSourceConverter.toUint8Array(inputBuffer);\n if (!checkBufferParams(this, view, inputOffset, inputLength)) {\n return -1;\n }\n this.valueBeforeDecodeView = view.subarray(inputOffset, inputOffset + inputLength);\n if (this.valueBeforeDecodeView.length === 0) {\n this.warnings.push(\"Zero buffer length\");\n return inputOffset;\n }\n let currentOffset = inputOffset;\n while (checkLen(this.isIndefiniteForm, inputLength) > 0) {\n const returnObject = localFromBER(view, currentOffset, inputLength);\n if (returnObject.offset === -1) {\n this.error = returnObject.result.error;\n this.warnings.concat(returnObject.result.warnings);\n return -1;\n }\n currentOffset = returnObject.offset;\n this.blockLength += returnObject.result.blockLength;\n inputLength -= returnObject.result.blockLength;\n this.value.push(returnObject.result);\n if (this.isIndefiniteForm && returnObject.result.constructor.NAME === END_OF_CONTENT_NAME) {\n break;\n }\n }\n if (this.isIndefiniteForm) {\n if (this.value[this.value.length - 1].constructor.NAME === END_OF_CONTENT_NAME) {\n this.value.pop();\n }\n else {\n this.warnings.push(\"No EndOfContent block encoded\");\n }\n }\n return currentOffset;\n }\n toBER(sizeOnly, writer) {\n const _writer = writer || new ViewWriter();\n for (let i = 0; i < this.value.length; i++) {\n this.value[i].toBER(sizeOnly, _writer);\n }\n if (!writer) {\n return _writer.final();\n }\n return EMPTY_BUFFER;\n }\n toJSON() {\n const object = {\n ...super.toJSON(),\n isIndefiniteForm: this.isIndefiniteForm,\n value: [],\n };\n for (const value of this.value) {\n object.value.push(value.toJSON());\n }\n return object;\n }\n}\nLocalConstructedValueBlock.NAME = \"ConstructedValueBlock\";\n\nvar _a$v;\nclass Constructed extends BaseBlock {\n constructor(parameters = {}) {\n super(parameters, LocalConstructedValueBlock);\n this.idBlock.isConstructed = true;\n }\n fromBER(inputBuffer, inputOffset, inputLength) {\n this.valueBlock.isIndefiniteForm = this.lenBlock.isIndefiniteForm;\n const resultOffset = this.valueBlock.fromBER(inputBuffer, inputOffset, (this.lenBlock.isIndefiniteForm) ? inputLength : this.lenBlock.length);\n if (resultOffset === -1) {\n this.error = this.valueBlock.error;\n return resultOffset;\n }\n if (!this.idBlock.error.length)\n this.blockLength += this.idBlock.blockLength;\n if (!this.lenBlock.error.length)\n this.blockLength += this.lenBlock.blockLength;\n if (!this.valueBlock.error.length)\n this.blockLength += this.valueBlock.blockLength;\n return resultOffset;\n }\n onAsciiEncoding() {\n const values = [];\n for (const value of this.valueBlock.value) {\n values.push(value.toString(\"ascii\").split(\"\\n\").map((o) => ` ${o}`).join(\"\\n\"));\n }\n const blockName = this.idBlock.tagClass === 3\n ? `[${this.idBlock.tagNumber}]`\n : this.constructor.NAME;\n return values.length\n ? `${blockName} :\\n${values.join(\"\\n\")}`\n : `${blockName} :`;\n }\n}\n_a$v = Constructed;\n(() => {\n typeStore.Constructed = _a$v;\n})();\nConstructed.NAME = \"CONSTRUCTED\";\n\nclass LocalEndOfContentValueBlock extends ValueBlock {\n fromBER(inputBuffer, inputOffset, _inputLength) {\n return inputOffset;\n }\n toBER(_sizeOnly) {\n return EMPTY_BUFFER;\n }\n}\nLocalEndOfContentValueBlock.override = \"EndOfContentValueBlock\";\n\nvar _a$u;\nclass EndOfContent extends BaseBlock {\n constructor(parameters = {}) {\n super(parameters, LocalEndOfContentValueBlock);\n this.idBlock.tagClass = 1;\n this.idBlock.tagNumber = 0;\n }\n}\n_a$u = EndOfContent;\n(() => {\n typeStore.EndOfContent = _a$u;\n})();\nEndOfContent.NAME = END_OF_CONTENT_NAME;\n\nvar _a$t;\nclass Null extends BaseBlock {\n constructor(parameters = {}) {\n super(parameters, ValueBlock);\n this.idBlock.tagClass = 1;\n this.idBlock.tagNumber = 5;\n }\n fromBER(inputBuffer, inputOffset, inputLength) {\n if (this.lenBlock.length > 0)\n this.warnings.push(\"Non-zero length of value block for Null type\");\n if (!this.idBlock.error.length)\n this.blockLength += this.idBlock.blockLength;\n if (!this.lenBlock.error.length)\n this.blockLength += this.lenBlock.blockLength;\n this.blockLength += inputLength;\n if ((inputOffset + inputLength) > inputBuffer.byteLength) {\n this.error = \"End of input reached before message was fully decoded (inconsistent offset and length values)\";\n return -1;\n }\n return (inputOffset + inputLength);\n }\n toBER(sizeOnly, writer) {\n const retBuf = new ArrayBuffer(2);\n if (!sizeOnly) {\n const retView = new Uint8Array(retBuf);\n retView[0] = 0x05;\n retView[1] = 0x00;\n }\n if (writer) {\n writer.write(retBuf);\n }\n return retBuf;\n }\n onAsciiEncoding() {\n return `${this.constructor.NAME}`;\n }\n}\n_a$t = Null;\n(() => {\n typeStore.Null = _a$t;\n})();\nNull.NAME = \"NULL\";\n\nclass LocalBooleanValueBlock extends HexBlock(ValueBlock) {\n get value() {\n for (const octet of this.valueHexView) {\n if (octet > 0) {\n return true;\n }\n }\n return false;\n }\n set value(value) {\n this.valueHexView[0] = value ? 0xFF : 0x00;\n }\n constructor({ value, ...parameters } = {}) {\n super(parameters);\n if (parameters.valueHex) {\n this.valueHexView = pvtsutils.BufferSourceConverter.toUint8Array(parameters.valueHex);\n }\n else {\n this.valueHexView = new Uint8Array(1);\n }\n if (value) {\n this.value = value;\n }\n }\n fromBER(inputBuffer, inputOffset, inputLength) {\n const inputView = pvtsutils.BufferSourceConverter.toUint8Array(inputBuffer);\n if (!checkBufferParams(this, inputView, inputOffset, inputLength)) {\n return -1;\n }\n this.valueHexView = inputView.subarray(inputOffset, inputOffset + inputLength);\n if (inputLength > 1)\n this.warnings.push(\"Boolean value encoded in more then 1 octet\");\n this.isHexOnly = true;\n pvutils.utilDecodeTC.call(this);\n this.blockLength = inputLength;\n return (inputOffset + inputLength);\n }\n toBER() {\n return this.valueHexView.slice();\n }\n toJSON() {\n return {\n ...super.toJSON(),\n value: this.value,\n };\n }\n}\nLocalBooleanValueBlock.NAME = \"BooleanValueBlock\";\n\nvar _a$s;\nclass Boolean extends BaseBlock {\n getValue() {\n return this.valueBlock.value;\n }\n setValue(value) {\n this.valueBlock.value = value;\n }\n constructor(parameters = {}) {\n super(parameters, LocalBooleanValueBlock);\n this.idBlock.tagClass = 1;\n this.idBlock.tagNumber = 1;\n }\n onAsciiEncoding() {\n return `${this.constructor.NAME} : ${this.getValue}`;\n }\n}\n_a$s = Boolean;\n(() => {\n typeStore.Boolean = _a$s;\n})();\nBoolean.NAME = \"BOOLEAN\";\n\nclass LocalOctetStringValueBlock extends HexBlock(LocalConstructedValueBlock) {\n constructor({ isConstructed = false, ...parameters } = {}) {\n super(parameters);\n this.isConstructed = isConstructed;\n }\n fromBER(inputBuffer, inputOffset, inputLength) {\n let resultOffset = 0;\n if (this.isConstructed) {\n this.isHexOnly = false;\n resultOffset = LocalConstructedValueBlock.prototype.fromBER.call(this, inputBuffer, inputOffset, inputLength);\n if (resultOffset === -1)\n return resultOffset;\n for (let i = 0; i < this.value.length; i++) {\n const currentBlockName = this.value[i].constructor.NAME;\n if (currentBlockName === END_OF_CONTENT_NAME) {\n if (this.isIndefiniteForm)\n break;\n else {\n this.error = \"EndOfContent is unexpected, OCTET STRING may consists of OCTET STRINGs only\";\n return -1;\n }\n }\n if (currentBlockName !== OCTET_STRING_NAME) {\n this.error = \"OCTET STRING may consists of OCTET STRINGs only\";\n return -1;\n }\n }\n }\n else {\n this.isHexOnly = true;\n resultOffset = super.fromBER(inputBuffer, inputOffset, inputLength);\n this.blockLength = inputLength;\n }\n return resultOffset;\n }\n toBER(sizeOnly, writer) {\n if (this.isConstructed)\n return LocalConstructedValueBlock.prototype.toBER.call(this, sizeOnly, writer);\n return sizeOnly\n ? new ArrayBuffer(this.valueHexView.byteLength)\n : this.valueHexView.slice().buffer;\n }\n toJSON() {\n return {\n ...super.toJSON(),\n isConstructed: this.isConstructed,\n };\n }\n}\nLocalOctetStringValueBlock.NAME = \"OctetStringValueBlock\";\n\nvar _a$r;\nclass OctetString extends BaseBlock {\n constructor({ idBlock = {}, lenBlock = {}, ...parameters } = {}) {\n var _b, _c;\n (_b = parameters.isConstructed) !== null && _b !== void 0 ? _b : (parameters.isConstructed = !!((_c = parameters.value) === null || _c === void 0 ? void 0 : _c.length));\n super({\n idBlock: {\n isConstructed: parameters.isConstructed,\n ...idBlock,\n },\n lenBlock: {\n ...lenBlock,\n isIndefiniteForm: !!parameters.isIndefiniteForm,\n },\n ...parameters,\n }, LocalOctetStringValueBlock);\n this.idBlock.tagClass = 1;\n this.idBlock.tagNumber = 4;\n }\n fromBER(inputBuffer, inputOffset, inputLength) {\n this.valueBlock.isConstructed = this.idBlock.isConstructed;\n this.valueBlock.isIndefiniteForm = this.lenBlock.isIndefiniteForm;\n if (inputLength === 0) {\n if (this.idBlock.error.length === 0)\n this.blockLength += this.idBlock.blockLength;\n if (this.lenBlock.error.length === 0)\n this.blockLength += this.lenBlock.blockLength;\n return inputOffset;\n }\n if (!this.valueBlock.isConstructed) {\n const view = inputBuffer instanceof ArrayBuffer ? new Uint8Array(inputBuffer) : inputBuffer;\n const buf = view.subarray(inputOffset, inputOffset + inputLength);\n try {\n if (buf.byteLength) {\n const asn = localFromBER(buf, 0, buf.byteLength);\n if (asn.offset !== -1 && asn.offset === inputLength) {\n this.valueBlock.value = [asn.result];\n }\n }\n }\n catch {\n }\n }\n return super.fromBER(inputBuffer, inputOffset, inputLength);\n }\n onAsciiEncoding() {\n if (this.valueBlock.isConstructed || (this.valueBlock.value && this.valueBlock.value.length)) {\n return Constructed.prototype.onAsciiEncoding.call(this);\n }\n const name = this.constructor.NAME;\n const value = pvtsutils.Convert.ToHex(this.valueBlock.valueHexView);\n return `${name} : ${value}`;\n }\n getValue() {\n if (!this.idBlock.isConstructed) {\n return this.valueBlock.valueHexView.slice().buffer;\n }\n const array = [];\n for (const content of this.valueBlock.value) {\n if (content instanceof _a$r) {\n array.push(content.valueBlock.valueHexView);\n }\n }\n return pvtsutils.BufferSourceConverter.concat(array);\n }\n}\n_a$r = OctetString;\n(() => {\n typeStore.OctetString = _a$r;\n})();\nOctetString.NAME = OCTET_STRING_NAME;\n\nclass LocalBitStringValueBlock extends HexBlock(LocalConstructedValueBlock) {\n constructor({ unusedBits = 0, isConstructed = false, ...parameters } = {}) {\n super(parameters);\n this.unusedBits = unusedBits;\n this.isConstructed = isConstructed;\n this.blockLength = this.valueHexView.byteLength;\n }\n fromBER(inputBuffer, inputOffset, inputLength) {\n if (!inputLength) {\n return inputOffset;\n }\n let resultOffset = -1;\n if (this.isConstructed) {\n resultOffset = LocalConstructedValueBlock.prototype.fromBER.call(this, inputBuffer, inputOffset, inputLength);\n if (resultOffset === -1)\n return resultOffset;\n for (const value of this.value) {\n const currentBlockName = value.constructor.NAME;\n if (currentBlockName === END_OF_CONTENT_NAME) {\n if (this.isIndefiniteForm)\n break;\n else {\n this.error = \"EndOfContent is unexpected, BIT STRING may consists of BIT STRINGs only\";\n return -1;\n }\n }\n if (currentBlockName !== BIT_STRING_NAME) {\n this.error = \"BIT STRING may consists of BIT STRINGs only\";\n return -1;\n }\n const valueBlock = value.valueBlock;\n if ((this.unusedBits > 0) && (valueBlock.unusedBits > 0)) {\n this.error = \"Using of \\\"unused bits\\\" inside constructive BIT STRING allowed for least one only\";\n return -1;\n }\n this.unusedBits = valueBlock.unusedBits;\n }\n return resultOffset;\n }\n const inputView = pvtsutils.BufferSourceConverter.toUint8Array(inputBuffer);\n if (!checkBufferParams(this, inputView, inputOffset, inputLength)) {\n return -1;\n }\n const intBuffer = inputView.subarray(inputOffset, inputOffset + inputLength);\n this.unusedBits = intBuffer[0];\n if (this.unusedBits > 7) {\n this.error = \"Unused bits for BitString must be in range 0-7\";\n return -1;\n }\n if (!this.unusedBits) {\n const buf = intBuffer.subarray(1);\n try {\n if (buf.byteLength) {\n const asn = localFromBER(buf, 0, buf.byteLength);\n if (asn.offset !== -1 && asn.offset === (inputLength - 1)) {\n this.value = [asn.result];\n }\n }\n }\n catch {\n }\n }\n this.valueHexView = intBuffer.subarray(1);\n this.blockLength = intBuffer.length;\n return (inputOffset + inputLength);\n }\n toBER(sizeOnly, writer) {\n if (this.isConstructed) {\n return LocalConstructedValueBlock.prototype.toBER.call(this, sizeOnly, writer);\n }\n if (sizeOnly) {\n return new ArrayBuffer(this.valueHexView.byteLength + 1);\n }\n if (!this.valueHexView.byteLength) {\n const empty = new Uint8Array(1);\n empty[0] = 0;\n return empty.buffer;\n }\n const retView = new Uint8Array(this.valueHexView.length + 1);\n retView[0] = this.unusedBits;\n retView.set(this.valueHexView, 1);\n return retView.buffer;\n }\n toJSON() {\n return {\n ...super.toJSON(),\n unusedBits: this.unusedBits,\n isConstructed: this.isConstructed,\n };\n }\n}\nLocalBitStringValueBlock.NAME = \"BitStringValueBlock\";\n\nvar _a$q;\nclass BitString extends BaseBlock {\n constructor({ idBlock = {}, lenBlock = {}, ...parameters } = {}) {\n var _b, _c;\n (_b = parameters.isConstructed) !== null && _b !== void 0 ? _b : (parameters.isConstructed = !!((_c = parameters.value) === null || _c === void 0 ? void 0 : _c.length));\n super({\n idBlock: {\n isConstructed: parameters.isConstructed,\n ...idBlock,\n },\n lenBlock: {\n ...lenBlock,\n isIndefiniteForm: !!parameters.isIndefiniteForm,\n },\n ...parameters,\n }, LocalBitStringValueBlock);\n this.idBlock.tagClass = 1;\n this.idBlock.tagNumber = 3;\n }\n fromBER(inputBuffer, inputOffset, inputLength) {\n this.valueBlock.isConstructed = this.idBlock.isConstructed;\n this.valueBlock.isIndefiniteForm = this.lenBlock.isIndefiniteForm;\n return super.fromBER(inputBuffer, inputOffset, inputLength);\n }\n onAsciiEncoding() {\n if (this.valueBlock.isConstructed || (this.valueBlock.value && this.valueBlock.value.length)) {\n return Constructed.prototype.onAsciiEncoding.call(this);\n }\n else {\n const bits = [];\n const valueHex = this.valueBlock.valueHexView;\n for (const byte of valueHex) {\n bits.push(byte.toString(2).padStart(8, \"0\"));\n }\n const bitsStr = bits.join(\"\");\n const name = this.constructor.NAME;\n const value = bitsStr.substring(0, bitsStr.length - this.valueBlock.unusedBits);\n return `${name} : ${value}`;\n }\n }\n}\n_a$q = BitString;\n(() => {\n typeStore.BitString = _a$q;\n})();\nBitString.NAME = BIT_STRING_NAME;\n\nvar _a$p;\nfunction viewAdd(first, second) {\n const c = new Uint8Array([0]);\n const firstView = new Uint8Array(first);\n const secondView = new Uint8Array(second);\n let firstViewCopy = firstView.slice(0);\n const firstViewCopyLength = firstViewCopy.length - 1;\n const secondViewCopy = secondView.slice(0);\n const secondViewCopyLength = secondViewCopy.length - 1;\n let value = 0;\n const max = (secondViewCopyLength < firstViewCopyLength) ? firstViewCopyLength : secondViewCopyLength;\n let counter = 0;\n for (let i = max; i >= 0; i--, counter++) {\n switch (true) {\n case (counter < secondViewCopy.length):\n value = firstViewCopy[firstViewCopyLength - counter] + secondViewCopy[secondViewCopyLength - counter] + c[0];\n break;\n default:\n value = firstViewCopy[firstViewCopyLength - counter] + c[0];\n }\n c[0] = value / 10;\n switch (true) {\n case (counter >= firstViewCopy.length):\n firstViewCopy = pvutils.utilConcatView(new Uint8Array([value % 10]), firstViewCopy);\n break;\n default:\n firstViewCopy[firstViewCopyLength - counter] = value % 10;\n }\n }\n if (c[0] > 0)\n firstViewCopy = pvutils.utilConcatView(c, firstViewCopy);\n return firstViewCopy;\n}\nfunction power2(n) {\n if (n >= powers2.length) {\n for (let p = powers2.length; p <= n; p++) {\n const c = new Uint8Array([0]);\n let digits = (powers2[p - 1]).slice(0);\n for (let i = (digits.length - 1); i >= 0; i--) {\n const newValue = new Uint8Array([(digits[i] << 1) + c[0]]);\n c[0] = newValue[0] / 10;\n digits[i] = newValue[0] % 10;\n }\n if (c[0] > 0)\n digits = pvutils.utilConcatView(c, digits);\n powers2.push(digits);\n }\n }\n return powers2[n];\n}\nfunction viewSub(first, second) {\n let b = 0;\n const firstView = new Uint8Array(first);\n const secondView = new Uint8Array(second);\n const firstViewCopy = firstView.slice(0);\n const firstViewCopyLength = firstViewCopy.length - 1;\n const secondViewCopy = secondView.slice(0);\n const secondViewCopyLength = secondViewCopy.length - 1;\n let value;\n let counter = 0;\n for (let i = secondViewCopyLength; i >= 0; i--, counter++) {\n value = firstViewCopy[firstViewCopyLength - counter] - secondViewCopy[secondViewCopyLength - counter] - b;\n switch (true) {\n case (value < 0):\n b = 1;\n firstViewCopy[firstViewCopyLength - counter] = value + 10;\n break;\n default:\n b = 0;\n firstViewCopy[firstViewCopyLength - counter] = value;\n }\n }\n if (b > 0) {\n for (let i = (firstViewCopyLength - secondViewCopyLength + 1); i >= 0; i--, counter++) {\n value = firstViewCopy[firstViewCopyLength - counter] - b;\n if (value < 0) {\n b = 1;\n firstViewCopy[firstViewCopyLength - counter] = value + 10;\n }\n else {\n b = 0;\n firstViewCopy[firstViewCopyLength - counter] = value;\n break;\n }\n }\n }\n return firstViewCopy.slice();\n}\nclass LocalIntegerValueBlock extends HexBlock(ValueBlock) {\n setValueHex() {\n if (this.valueHexView.length >= 4) {\n this.warnings.push(\"Too big Integer for decoding, hex only\");\n this.isHexOnly = true;\n this._valueDec = 0;\n }\n else {\n this.isHexOnly = false;\n if (this.valueHexView.length > 0) {\n this._valueDec = pvutils.utilDecodeTC.call(this);\n }\n }\n }\n constructor({ value, ...parameters } = {}) {\n super(parameters);\n this._valueDec = 0;\n if (parameters.valueHex) {\n this.setValueHex();\n }\n if (value !== undefined) {\n this.valueDec = value;\n }\n }\n set valueDec(v) {\n this._valueDec = v;\n this.isHexOnly = false;\n this.valueHexView = new Uint8Array(pvutils.utilEncodeTC(v));\n }\n get valueDec() {\n return this._valueDec;\n }\n fromDER(inputBuffer, inputOffset, inputLength, expectedLength = 0) {\n const offset = this.fromBER(inputBuffer, inputOffset, inputLength);\n if (offset === -1)\n return offset;\n const view = this.valueHexView;\n if ((view[0] === 0x00) && ((view[1] & 0x80) !== 0)) {\n this.valueHexView = view.subarray(1);\n }\n else {\n if (expectedLength !== 0) {\n if (view.length < expectedLength) {\n if ((expectedLength - view.length) > 1)\n expectedLength = view.length + 1;\n this.valueHexView = view.subarray(expectedLength - view.length);\n }\n }\n }\n return offset;\n }\n toDER(sizeOnly = false) {\n const view = this.valueHexView;\n switch (true) {\n case ((view[0] & 0x80) !== 0):\n {\n const updatedView = new Uint8Array(this.valueHexView.length + 1);\n updatedView[0] = 0x00;\n updatedView.set(view, 1);\n this.valueHexView = updatedView;\n }\n break;\n case ((view[0] === 0x00) && ((view[1] & 0x80) === 0)):\n {\n this.valueHexView = this.valueHexView.subarray(1);\n }\n break;\n }\n return this.toBER(sizeOnly);\n }\n fromBER(inputBuffer, inputOffset, inputLength) {\n const resultOffset = super.fromBER(inputBuffer, inputOffset, inputLength);\n if (resultOffset === -1) {\n return resultOffset;\n }\n this.setValueHex();\n return resultOffset;\n }\n toBER(sizeOnly) {\n return sizeOnly\n ? new ArrayBuffer(this.valueHexView.length)\n : this.valueHexView.slice().buffer;\n }\n toJSON() {\n return {\n ...super.toJSON(),\n valueDec: this.valueDec,\n };\n }\n toString() {\n const firstBit = (this.valueHexView.length * 8) - 1;\n let digits = new Uint8Array((this.valueHexView.length * 8) / 3);\n let bitNumber = 0;\n let currentByte;\n const asn1View = this.valueHexView;\n let result = \"\";\n let flag = false;\n for (let byteNumber = (asn1View.byteLength - 1); byteNumber >= 0; byteNumber--) {\n currentByte = asn1View[byteNumber];\n for (let i = 0; i < 8; i++) {\n if ((currentByte & 1) === 1) {\n switch (bitNumber) {\n case firstBit:\n digits = viewSub(power2(bitNumber), digits);\n result = \"-\";\n break;\n default:\n digits = viewAdd(digits, power2(bitNumber));\n }\n }\n bitNumber++;\n currentByte >>= 1;\n }\n }\n for (let i = 0; i < digits.length; i++) {\n if (digits[i])\n flag = true;\n if (flag)\n result += digitsString.charAt(digits[i]);\n }\n if (flag === false)\n result += digitsString.charAt(0);\n return result;\n }\n}\n_a$p = LocalIntegerValueBlock;\nLocalIntegerValueBlock.NAME = \"IntegerValueBlock\";\n(() => {\n Object.defineProperty(_a$p.prototype, \"valueHex\", {\n set: function (v) {\n this.valueHexView = new Uint8Array(v);\n this.setValueHex();\n },\n get: function () {\n return this.valueHexView.slice().buffer;\n },\n });\n})();\n\nvar _a$o;\nclass Integer extends BaseBlock {\n constructor(parameters = {}) {\n super(parameters, LocalIntegerValueBlock);\n this.idBlock.tagClass = 1;\n this.idBlock.tagNumber = 2;\n }\n toBigInt() {\n assertBigInt();\n return BigInt(this.valueBlock.toString());\n }\n static fromBigInt(value) {\n assertBigInt();\n const bigIntValue = BigInt(value);\n const writer = new ViewWriter();\n const hex = bigIntValue.toString(16).replace(/^-/, \"\");\n const view = new Uint8Array(pvtsutils.Convert.FromHex(hex));\n if (bigIntValue < 0) {\n const first = new Uint8Array(view.length + (view[0] & 0x80 ? 1 : 0));\n first[0] |= 0x80;\n const firstInt = BigInt(`0x${pvtsutils.Convert.ToHex(first)}`);\n const secondInt = firstInt + bigIntValue;\n const second = pvtsutils.BufferSourceConverter.toUint8Array(pvtsutils.Convert.FromHex(secondInt.toString(16)));\n second[0] |= 0x80;\n writer.write(second);\n }\n else {\n if (view[0] & 0x80) {\n writer.write(new Uint8Array([0]));\n }\n writer.write(view);\n }\n const res = new _a$o({ valueHex: writer.final() });\n return res;\n }\n convertToDER() {\n const integer = new _a$o({ valueHex: this.valueBlock.valueHexView });\n integer.valueBlock.toDER();\n return integer;\n }\n convertFromDER() {\n return new _a$o({\n valueHex: this.valueBlock.valueHexView[0] === 0\n ? this.valueBlock.valueHexView.subarray(1)\n : this.valueBlock.valueHexView,\n });\n }\n onAsciiEncoding() {\n return `${this.constructor.NAME} : ${this.valueBlock.toString()}`;\n }\n}\n_a$o = Integer;\n(() => {\n typeStore.Integer = _a$o;\n})();\nInteger.NAME = \"INTEGER\";\n\nvar _a$n;\nclass Enumerated extends Integer {\n constructor(parameters = {}) {\n super(parameters);\n this.idBlock.tagClass = 1;\n this.idBlock.tagNumber = 10;\n }\n}\n_a$n = Enumerated;\n(() => {\n typeStore.Enumerated = _a$n;\n})();\nEnumerated.NAME = \"ENUMERATED\";\n\nclass LocalSidValueBlock extends HexBlock(ValueBlock) {\n constructor({ valueDec = -1, isFirstSid = false, ...parameters } = {}) {\n super(parameters);\n this.valueDec = valueDec;\n this.isFirstSid = isFirstSid;\n }\n fromBER(inputBuffer, inputOffset, inputLength) {\n if (!inputLength) {\n return inputOffset;\n }\n const inputView = pvtsutils.BufferSourceConverter.toUint8Array(inputBuffer);\n if (!checkBufferParams(this, inputView, inputOffset, inputLength)) {\n return -1;\n }\n const intBuffer = inputView.subarray(inputOffset, inputOffset + inputLength);\n this.valueHexView = new Uint8Array(inputLength);\n for (let i = 0; i < inputLength; i++) {\n this.valueHexView[i] = intBuffer[i] & 0x7F;\n this.blockLength++;\n if ((intBuffer[i] & 0x80) === 0x00)\n break;\n }\n const tempView = new Uint8Array(this.blockLength);\n for (let i = 0; i < this.blockLength; i++) {\n tempView[i] = this.valueHexView[i];\n }\n this.valueHexView = tempView;\n if ((intBuffer[this.blockLength - 1] & 0x80) !== 0x00) {\n this.error = \"End of input reached before message was fully decoded\";\n return -1;\n }\n if (this.valueHexView[0] === 0x00)\n this.warnings.push(\"Needlessly long format of SID encoding\");\n if (this.blockLength <= 8)\n this.valueDec = pvutils.utilFromBase(this.valueHexView, 7);\n else {\n this.isHexOnly = true;\n this.warnings.push(\"Too big SID for decoding, hex only\");\n }\n return (inputOffset + this.blockLength);\n }\n set valueBigInt(value) {\n assertBigInt();\n let bits = BigInt(value).toString(2);\n while (bits.length % 7) {\n bits = \"0\" + bits;\n }\n const bytes = new Uint8Array(bits.length / 7);\n for (let i = 0; i < bytes.length; i++) {\n bytes[i] = parseInt(bits.slice(i * 7, i * 7 + 7), 2) + (i + 1 < bytes.length ? 0x80 : 0);\n }\n this.fromBER(bytes.buffer, 0, bytes.length);\n }\n toBER(sizeOnly) {\n if (this.isHexOnly) {\n if (sizeOnly)\n return (new ArrayBuffer(this.valueHexView.byteLength));\n const curView = this.valueHexView;\n const retView = new Uint8Array(this.blockLength);\n for (let i = 0; i < (this.blockLength - 1); i++)\n retView[i] = curView[i] | 0x80;\n retView[this.blockLength - 1] = curView[this.blockLength - 1];\n return retView.buffer;\n }\n const encodedBuf = pvutils.utilToBase(this.valueDec, 7);\n if (encodedBuf.byteLength === 0) {\n this.error = \"Error during encoding SID value\";\n return EMPTY_BUFFER;\n }\n const retView = new Uint8Array(encodedBuf.byteLength);\n if (!sizeOnly) {\n const encodedView = new Uint8Array(encodedBuf);\n const len = encodedBuf.byteLength - 1;\n for (let i = 0; i < len; i++)\n retView[i] = encodedView[i] | 0x80;\n retView[len] = encodedView[len];\n }\n return retView;\n }\n toString() {\n let result = \"\";\n if (this.isHexOnly)\n result = pvtsutils.Convert.ToHex(this.valueHexView);\n else {\n if (this.isFirstSid) {\n let sidValue = this.valueDec;\n if (this.valueDec <= 39)\n result = \"0.\";\n else {\n if (this.valueDec <= 79) {\n result = \"1.\";\n sidValue -= 40;\n }\n else {\n result = \"2.\";\n sidValue -= 80;\n }\n }\n result += sidValue.toString();\n }\n else\n result = this.valueDec.toString();\n }\n return result;\n }\n toJSON() {\n return {\n ...super.toJSON(),\n valueDec: this.valueDec,\n isFirstSid: this.isFirstSid,\n };\n }\n}\nLocalSidValueBlock.NAME = \"sidBlock\";\n\nclass LocalObjectIdentifierValueBlock extends ValueBlock {\n constructor({ value = EMPTY_STRING, ...parameters } = {}) {\n super(parameters);\n this.value = [];\n if (value) {\n this.fromString(value);\n }\n }\n fromBER(inputBuffer, inputOffset, inputLength) {\n let resultOffset = inputOffset;\n while (inputLength > 0) {\n const sidBlock = new LocalSidValueBlock();\n resultOffset = sidBlock.fromBER(inputBuffer, resultOffset, inputLength);\n if (resultOffset === -1) {\n this.blockLength = 0;\n this.error = sidBlock.error;\n return resultOffset;\n }\n if (this.value.length === 0)\n sidBlock.isFirstSid = true;\n this.blockLength += sidBlock.blockLength;\n inputLength -= sidBlock.blockLength;\n this.value.push(sidBlock);\n }\n return resultOffset;\n }\n toBER(sizeOnly) {\n const retBuffers = [];\n for (let i = 0; i < this.value.length; i++) {\n const valueBuf = this.value[i].toBER(sizeOnly);\n if (valueBuf.byteLength === 0) {\n this.error = this.value[i].error;\n return EMPTY_BUFFER;\n }\n retBuffers.push(valueBuf);\n }\n return concat(retBuffers);\n }\n fromString(string) {\n this.value = [];\n let pos1 = 0;\n let pos2 = 0;\n let sid = \"\";\n let flag = false;\n do {\n pos2 = string.indexOf(\".\", pos1);\n if (pos2 === -1)\n sid = string.substring(pos1);\n else\n sid = string.substring(pos1, pos2);\n pos1 = pos2 + 1;\n if (flag) {\n const sidBlock = this.value[0];\n let plus = 0;\n switch (sidBlock.valueDec) {\n case 0:\n break;\n case 1:\n plus = 40;\n break;\n case 2:\n plus = 80;\n break;\n default:\n this.value = [];\n return;\n }\n const parsedSID = parseInt(sid, 10);\n if (isNaN(parsedSID))\n return;\n sidBlock.valueDec = parsedSID + plus;\n flag = false;\n }\n else {\n const sidBlock = new LocalSidValueBlock();\n if (sid > Number.MAX_SAFE_INTEGER) {\n assertBigInt();\n const sidValue = BigInt(sid);\n sidBlock.valueBigInt = sidValue;\n }\n else {\n sidBlock.valueDec = parseInt(sid, 10);\n if (isNaN(sidBlock.valueDec))\n return;\n }\n if (!this.value.length) {\n sidBlock.isFirstSid = true;\n flag = true;\n }\n this.value.push(sidBlock);\n }\n } while (pos2 !== -1);\n }\n toString() {\n let result = \"\";\n let isHexOnly = false;\n for (let i = 0; i < this.value.length; i++) {\n isHexOnly = this.value[i].isHexOnly;\n let sidStr = this.value[i].toString();\n if (i !== 0)\n result = `${result}.`;\n if (isHexOnly) {\n sidStr = `{${sidStr}}`;\n if (this.value[i].isFirstSid)\n result = `2.{${sidStr} - 80}`;\n else\n result += sidStr;\n }\n else\n result += sidStr;\n }\n return result;\n }\n toJSON() {\n const object = {\n ...super.toJSON(),\n value: this.toString(),\n sidArray: [],\n };\n for (let i = 0; i < this.value.length; i++) {\n object.sidArray.push(this.value[i].toJSON());\n }\n return object;\n }\n}\nLocalObjectIdentifierValueBlock.NAME = \"ObjectIdentifierValueBlock\";\n\nvar _a$m;\nclass ObjectIdentifier extends BaseBlock {\n getValue() {\n return this.valueBlock.toString();\n }\n setValue(value) {\n this.valueBlock.fromString(value);\n }\n constructor(parameters = {}) {\n super(parameters, LocalObjectIdentifierValueBlock);\n this.idBlock.tagClass = 1;\n this.idBlock.tagNumber = 6;\n }\n onAsciiEncoding() {\n return `${this.constructor.NAME} : ${this.valueBlock.toString() || \"empty\"}`;\n }\n toJSON() {\n return {\n ...super.toJSON(),\n value: this.getValue(),\n };\n }\n}\n_a$m = ObjectIdentifier;\n(() => {\n typeStore.ObjectIdentifier = _a$m;\n})();\nObjectIdentifier.NAME = \"OBJECT IDENTIFIER\";\n\nclass LocalRelativeSidValueBlock extends HexBlock(LocalBaseBlock) {\n constructor({ valueDec = 0, ...parameters } = {}) {\n super(parameters);\n this.valueDec = valueDec;\n }\n fromBER(inputBuffer, inputOffset, inputLength) {\n if (inputLength === 0)\n return inputOffset;\n const inputView = pvtsutils.BufferSourceConverter.toUint8Array(inputBuffer);\n if (!checkBufferParams(this, inputView, inputOffset, inputLength))\n return -1;\n const intBuffer = inputView.subarray(inputOffset, inputOffset + inputLength);\n this.valueHexView = new Uint8Array(inputLength);\n for (let i = 0; i < inputLength; i++) {\n this.valueHexView[i] = intBuffer[i] & 0x7F;\n this.blockLength++;\n if ((intBuffer[i] & 0x80) === 0x00)\n break;\n }\n const tempView = new Uint8Array(this.blockLength);\n for (let i = 0; i < this.blockLength; i++)\n tempView[i] = this.valueHexView[i];\n this.valueHexView = tempView;\n if ((intBuffer[this.blockLength - 1] & 0x80) !== 0x00) {\n this.error = \"End of input reached before message was fully decoded\";\n return -1;\n }\n if (this.valueHexView[0] === 0x00)\n this.warnings.push(\"Needlessly long format of SID encoding\");\n if (this.blockLength <= 8)\n this.valueDec = pvutils.utilFromBase(this.valueHexView, 7);\n else {\n this.isHexOnly = true;\n this.warnings.push(\"Too big SID for decoding, hex only\");\n }\n return (inputOffset + this.blockLength);\n }\n toBER(sizeOnly) {\n if (this.isHexOnly) {\n if (sizeOnly)\n return (new ArrayBuffer(this.valueHexView.byteLength));\n const curView = this.valueHexView;\n const retView = new Uint8Array(this.blockLength);\n for (let i = 0; i < (this.blockLength - 1); i++)\n retView[i] = curView[i] | 0x80;\n retView[this.blockLength - 1] = curView[this.blockLength - 1];\n return retView.buffer;\n }\n const encodedBuf = pvutils.utilToBase(this.valueDec, 7);\n if (encodedBuf.byteLength === 0) {\n this.error = \"Error during encoding SID value\";\n return EMPTY_BUFFER;\n }\n const retView = new Uint8Array(encodedBuf.byteLength);\n if (!sizeOnly) {\n const encodedView = new Uint8Array(encodedBuf);\n const len = encodedBuf.byteLength - 1;\n for (let i = 0; i < len; i++)\n retView[i] = encodedView[i] | 0x80;\n retView[len] = encodedView[len];\n }\n return retView.buffer;\n }\n toString() {\n let result = \"\";\n if (this.isHexOnly)\n result = pvtsutils.Convert.ToHex(this.valueHexView);\n else {\n result = this.valueDec.toString();\n }\n return result;\n }\n toJSON() {\n return {\n ...super.toJSON(),\n valueDec: this.valueDec,\n };\n }\n}\nLocalRelativeSidValueBlock.NAME = \"relativeSidBlock\";\n\nclass LocalRelativeObjectIdentifierValueBlock extends ValueBlock {\n constructor({ value = EMPTY_STRING, ...parameters } = {}) {\n super(parameters);\n this.value = [];\n if (value) {\n this.fromString(value);\n }\n }\n fromBER(inputBuffer, inputOffset, inputLength) {\n let resultOffset = inputOffset;\n while (inputLength > 0) {\n const sidBlock = new LocalRelativeSidValueBlock();\n resultOffset = sidBlock.fromBER(inputBuffer, resultOffset, inputLength);\n if (resultOffset === -1) {\n this.blockLength = 0;\n this.error = sidBlock.error;\n return resultOffset;\n }\n this.blockLength += sidBlock.blockLength;\n inputLength -= sidBlock.blockLength;\n this.value.push(sidBlock);\n }\n return resultOffset;\n }\n toBER(sizeOnly, _writer) {\n const retBuffers = [];\n for (let i = 0; i < this.value.length; i++) {\n const valueBuf = this.value[i].toBER(sizeOnly);\n if (valueBuf.byteLength === 0) {\n this.error = this.value[i].error;\n return EMPTY_BUFFER;\n }\n retBuffers.push(valueBuf);\n }\n return concat(retBuffers);\n }\n fromString(string) {\n this.value = [];\n let pos1 = 0;\n let pos2 = 0;\n let sid = \"\";\n do {\n pos2 = string.indexOf(\".\", pos1);\n if (pos2 === -1)\n sid = string.substring(pos1);\n else\n sid = string.substring(pos1, pos2);\n pos1 = pos2 + 1;\n const sidBlock = new LocalRelativeSidValueBlock();\n sidBlock.valueDec = parseInt(sid, 10);\n if (isNaN(sidBlock.valueDec))\n return true;\n this.value.push(sidBlock);\n } while (pos2 !== -1);\n return true;\n }\n toString() {\n let result = \"\";\n let isHexOnly = false;\n for (let i = 0; i < this.value.length; i++) {\n isHexOnly = this.value[i].isHexOnly;\n let sidStr = this.value[i].toString();\n if (i !== 0)\n result = `${result}.`;\n if (isHexOnly) {\n sidStr = `{${sidStr}}`;\n result += sidStr;\n }\n else\n result += sidStr;\n }\n return result;\n }\n toJSON() {\n const object = {\n ...super.toJSON(),\n value: this.toString(),\n sidArray: [],\n };\n for (let i = 0; i < this.value.length; i++)\n object.sidArray.push(this.value[i].toJSON());\n return object;\n }\n}\nLocalRelativeObjectIdentifierValueBlock.NAME = \"RelativeObjectIdentifierValueBlock\";\n\nvar _a$l;\nclass RelativeObjectIdentifier extends BaseBlock {\n getValue() {\n return this.valueBlock.toString();\n }\n setValue(value) {\n this.valueBlock.fromString(value);\n }\n constructor(parameters = {}) {\n super(parameters, LocalRelativeObjectIdentifierValueBlock);\n this.idBlock.tagClass = 1;\n this.idBlock.tagNumber = 13;\n }\n onAsciiEncoding() {\n return `${this.constructor.NAME} : ${this.valueBlock.toString() || \"empty\"}`;\n }\n toJSON() {\n return {\n ...super.toJSON(),\n value: this.getValue(),\n };\n }\n}\n_a$l = RelativeObjectIdentifier;\n(() => {\n typeStore.RelativeObjectIdentifier = _a$l;\n})();\nRelativeObjectIdentifier.NAME = \"RelativeObjectIdentifier\";\n\nvar _a$k;\nclass Sequence extends Constructed {\n constructor(parameters = {}) {\n super(parameters);\n this.idBlock.tagClass = 1;\n this.idBlock.tagNumber = 16;\n }\n}\n_a$k = Sequence;\n(() => {\n typeStore.Sequence = _a$k;\n})();\nSequence.NAME = \"SEQUENCE\";\n\nvar _a$j;\nclass Set extends Constructed {\n constructor(parameters = {}) {\n super(parameters);\n this.idBlock.tagClass = 1;\n this.idBlock.tagNumber = 17;\n }\n}\n_a$j = Set;\n(() => {\n typeStore.Set = _a$j;\n})();\nSet.NAME = \"SET\";\n\nclass LocalStringValueBlock extends HexBlock(ValueBlock) {\n constructor({ ...parameters } = {}) {\n super(parameters);\n this.isHexOnly = true;\n this.value = EMPTY_STRING;\n }\n toJSON() {\n return {\n ...super.toJSON(),\n value: this.value,\n };\n }\n}\nLocalStringValueBlock.NAME = \"StringValueBlock\";\n\nclass LocalSimpleStringValueBlock extends LocalStringValueBlock {\n}\nLocalSimpleStringValueBlock.NAME = \"SimpleStringValueBlock\";\n\nclass LocalSimpleStringBlock extends BaseStringBlock {\n constructor({ ...parameters } = {}) {\n super(parameters, LocalSimpleStringValueBlock);\n }\n fromBuffer(inputBuffer) {\n this.valueBlock.value = String.fromCharCode.apply(null, pvtsutils.BufferSourceConverter.toUint8Array(inputBuffer));\n }\n fromString(inputString) {\n const strLen = inputString.length;\n const view = this.valueBlock.valueHexView = new Uint8Array(strLen);\n for (let i = 0; i < strLen; i++)\n view[i] = inputString.charCodeAt(i);\n this.valueBlock.value = inputString;\n }\n}\nLocalSimpleStringBlock.NAME = \"SIMPLE STRING\";\n\nclass LocalUtf8StringValueBlock extends LocalSimpleStringBlock {\n fromBuffer(inputBuffer) {\n this.valueBlock.valueHexView = pvtsutils.BufferSourceConverter.toUint8Array(inputBuffer);\n try {\n this.valueBlock.value = pvtsutils.Convert.ToUtf8String(inputBuffer);\n }\n catch (ex) {\n this.warnings.push(`Error during \"decodeURIComponent\": ${ex}, using raw string`);\n this.valueBlock.value = pvtsutils.Convert.ToBinary(inputBuffer);\n }\n }\n fromString(inputString) {\n this.valueBlock.valueHexView = new Uint8Array(pvtsutils.Convert.FromUtf8String(inputString));\n this.valueBlock.value = inputString;\n }\n}\nLocalUtf8StringValueBlock.NAME = \"Utf8StringValueBlock\";\n\nvar _a$i;\nclass Utf8String extends LocalUtf8StringValueBlock {\n constructor(parameters = {}) {\n super(parameters);\n this.idBlock.tagClass = 1;\n this.idBlock.tagNumber = 12;\n }\n}\n_a$i = Utf8String;\n(() => {\n typeStore.Utf8String = _a$i;\n})();\nUtf8String.NAME = \"UTF8String\";\n\nclass LocalBmpStringValueBlock extends LocalSimpleStringBlock {\n fromBuffer(inputBuffer) {\n this.valueBlock.value = pvtsutils.Convert.ToUtf16String(inputBuffer);\n this.valueBlock.valueHexView = pvtsutils.BufferSourceConverter.toUint8Array(inputBuffer);\n }\n fromString(inputString) {\n this.valueBlock.value = inputString;\n this.valueBlock.valueHexView = new Uint8Array(pvtsutils.Convert.FromUtf16String(inputString));\n }\n}\nLocalBmpStringValueBlock.NAME = \"BmpStringValueBlock\";\n\nvar _a$h;\nclass BmpString extends LocalBmpStringValueBlock {\n constructor({ ...parameters } = {}) {\n super(parameters);\n this.idBlock.tagClass = 1;\n this.idBlock.tagNumber = 30;\n }\n}\n_a$h = BmpString;\n(() => {\n typeStore.BmpString = _a$h;\n})();\nBmpString.NAME = \"BMPString\";\n\nclass LocalUniversalStringValueBlock extends LocalSimpleStringBlock {\n fromBuffer(inputBuffer) {\n const copyBuffer = ArrayBuffer.isView(inputBuffer) ? inputBuffer.slice().buffer : inputBuffer.slice(0);\n const valueView = new Uint8Array(copyBuffer);\n for (let i = 0; i < valueView.length; i += 4) {\n valueView[i] = valueView[i + 3];\n valueView[i + 1] = valueView[i + 2];\n valueView[i + 2] = 0x00;\n valueView[i + 3] = 0x00;\n }\n this.valueBlock.value = String.fromCharCode.apply(null, new Uint32Array(copyBuffer));\n }\n fromString(inputString) {\n const strLength = inputString.length;\n const valueHexView = this.valueBlock.valueHexView = new Uint8Array(strLength * 4);\n for (let i = 0; i < strLength; i++) {\n const codeBuf = pvutils.utilToBase(inputString.charCodeAt(i), 8);\n const codeView = new Uint8Array(codeBuf);\n if (codeView.length > 4)\n continue;\n const dif = 4 - codeView.length;\n for (let j = (codeView.length - 1); j >= 0; j--)\n valueHexView[i * 4 + j + dif] = codeView[j];\n }\n this.valueBlock.value = inputString;\n }\n}\nLocalUniversalStringValueBlock.NAME = \"UniversalStringValueBlock\";\n\nvar _a$g;\nclass UniversalString extends LocalUniversalStringValueBlock {\n constructor({ ...parameters } = {}) {\n super(parameters);\n this.idBlock.tagClass = 1;\n this.idBlock.tagNumber = 28;\n }\n}\n_a$g = UniversalString;\n(() => {\n typeStore.UniversalString = _a$g;\n})();\nUniversalString.NAME = \"UniversalString\";\n\nvar _a$f;\nclass NumericString extends LocalSimpleStringBlock {\n constructor(parameters = {}) {\n super(parameters);\n this.idBlock.tagClass = 1;\n this.idBlock.tagNumber = 18;\n }\n}\n_a$f = NumericString;\n(() => {\n typeStore.NumericString = _a$f;\n})();\nNumericString.NAME = \"NumericString\";\n\nvar _a$e;\nclass PrintableString extends LocalSimpleStringBlock {\n constructor(parameters = {}) {\n super(parameters);\n this.idBlock.tagClass = 1;\n this.idBlock.tagNumber = 19;\n }\n}\n_a$e = PrintableString;\n(() => {\n typeStore.PrintableString = _a$e;\n})();\nPrintableString.NAME = \"PrintableString\";\n\nvar _a$d;\nclass TeletexString extends LocalSimpleStringBlock {\n constructor(parameters = {}) {\n super(parameters);\n this.idBlock.tagClass = 1;\n this.idBlock.tagNumber = 20;\n }\n}\n_a$d = TeletexString;\n(() => {\n typeStore.TeletexString = _a$d;\n})();\nTeletexString.NAME = \"TeletexString\";\n\nvar _a$c;\nclass VideotexString extends LocalSimpleStringBlock {\n constructor(parameters = {}) {\n super(parameters);\n this.idBlock.tagClass = 1;\n this.idBlock.tagNumber = 21;\n }\n}\n_a$c = VideotexString;\n(() => {\n typeStore.VideotexString = _a$c;\n})();\nVideotexString.NAME = \"VideotexString\";\n\nvar _a$b;\nclass IA5String extends LocalSimpleStringBlock {\n constructor(parameters = {}) {\n super(parameters);\n this.idBlock.tagClass = 1;\n this.idBlock.tagNumber = 22;\n }\n}\n_a$b = IA5String;\n(() => {\n typeStore.IA5String = _a$b;\n})();\nIA5String.NAME = \"IA5String\";\n\nvar _a$a;\nclass GraphicString extends LocalSimpleStringBlock {\n constructor(parameters = {}) {\n super(parameters);\n this.idBlock.tagClass = 1;\n this.idBlock.tagNumber = 25;\n }\n}\n_a$a = GraphicString;\n(() => {\n typeStore.GraphicString = _a$a;\n})();\nGraphicString.NAME = \"GraphicString\";\n\nvar _a$9;\nclass VisibleString extends LocalSimpleStringBlock {\n constructor(parameters = {}) {\n super(parameters);\n this.idBlock.tagClass = 1;\n this.idBlock.tagNumber = 26;\n }\n}\n_a$9 = VisibleString;\n(() => {\n typeStore.VisibleString = _a$9;\n})();\nVisibleString.NAME = \"VisibleString\";\n\nvar _a$8;\nclass GeneralString extends LocalSimpleStringBlock {\n constructor(parameters = {}) {\n super(parameters);\n this.idBlock.tagClass = 1;\n this.idBlock.tagNumber = 27;\n }\n}\n_a$8 = GeneralString;\n(() => {\n typeStore.GeneralString = _a$8;\n})();\nGeneralString.NAME = \"GeneralString\";\n\nvar _a$7;\nclass CharacterString extends LocalSimpleStringBlock {\n constructor(parameters = {}) {\n super(parameters);\n this.idBlock.tagClass = 1;\n this.idBlock.tagNumber = 29;\n }\n}\n_a$7 = CharacterString;\n(() => {\n typeStore.CharacterString = _a$7;\n})();\nCharacterString.NAME = \"CharacterString\";\n\nvar _a$6;\nclass UTCTime extends VisibleString {\n constructor({ value, valueDate, ...parameters } = {}) {\n super(parameters);\n this.year = 0;\n this.month = 0;\n this.day = 0;\n this.hour = 0;\n this.minute = 0;\n this.second = 0;\n if (value) {\n this.fromString(value);\n this.valueBlock.valueHexView = new Uint8Array(value.length);\n for (let i = 0; i < value.length; i++)\n this.valueBlock.valueHexView[i] = value.charCodeAt(i);\n }\n if (valueDate) {\n this.fromDate(valueDate);\n this.valueBlock.valueHexView = new Uint8Array(this.toBuffer());\n }\n this.idBlock.tagClass = 1;\n this.idBlock.tagNumber = 23;\n }\n fromBuffer(inputBuffer) {\n this.fromString(String.fromCharCode.apply(null, pvtsutils.BufferSourceConverter.toUint8Array(inputBuffer)));\n }\n toBuffer() {\n const str = this.toString();\n const buffer = new ArrayBuffer(str.length);\n const view = new Uint8Array(buffer);\n for (let i = 0; i < str.length; i++)\n view[i] = str.charCodeAt(i);\n return buffer;\n }\n fromDate(inputDate) {\n this.year = inputDate.getUTCFullYear();\n this.month = inputDate.getUTCMonth() + 1;\n this.day = inputDate.getUTCDate();\n this.hour = inputDate.getUTCHours();\n this.minute = inputDate.getUTCMinutes();\n this.second = inputDate.getUTCSeconds();\n }\n toDate() {\n return (new Date(Date.UTC(this.year, this.month - 1, this.day, this.hour, this.minute, this.second)));\n }\n fromString(inputString) {\n const parser = /(\\d{2})(\\d{2})(\\d{2})(\\d{2})(\\d{2})(\\d{2})Z/ig;\n const parserArray = parser.exec(inputString);\n if (parserArray === null) {\n this.error = \"Wrong input string for conversion\";\n return;\n }\n const year = parseInt(parserArray[1], 10);\n if (year >= 50)\n this.year = 1900 + year;\n else\n this.year = 2000 + year;\n this.month = parseInt(parserArray[2], 10);\n this.day = parseInt(parserArray[3], 10);\n this.hour = parseInt(parserArray[4], 10);\n this.minute = parseInt(parserArray[5], 10);\n this.second = parseInt(parserArray[6], 10);\n }\n toString(encoding = \"iso\") {\n if (encoding === \"iso\") {\n const outputArray = new Array(7);\n outputArray[0] = pvutils.padNumber(((this.year < 2000) ? (this.year - 1900) : (this.year - 2000)), 2);\n outputArray[1] = pvutils.padNumber(this.month, 2);\n outputArray[2] = pvutils.padNumber(this.day, 2);\n outputArray[3] = pvutils.padNumber(this.hour, 2);\n outputArray[4] = pvutils.padNumber(this.minute, 2);\n outputArray[5] = pvutils.padNumber(this.second, 2);\n outputArray[6] = \"Z\";\n return outputArray.join(\"\");\n }\n return super.toString(encoding);\n }\n onAsciiEncoding() {\n return `${this.constructor.NAME} : ${this.toDate().toISOString()}`;\n }\n toJSON() {\n return {\n ...super.toJSON(),\n year: this.year,\n month: this.month,\n day: this.day,\n hour: this.hour,\n minute: this.minute,\n second: this.second,\n };\n }\n}\n_a$6 = UTCTime;\n(() => {\n typeStore.UTCTime = _a$6;\n})();\nUTCTime.NAME = \"UTCTime\";\n\nvar _a$5;\nclass GeneralizedTime extends UTCTime {\n constructor(parameters = {}) {\n var _b;\n super(parameters);\n (_b = this.millisecond) !== null && _b !== void 0 ? _b : (this.millisecond = 0);\n this.idBlock.tagClass = 1;\n this.idBlock.tagNumber = 24;\n }\n fromDate(inputDate) {\n super.fromDate(inputDate);\n this.millisecond = inputDate.getUTCMilliseconds();\n }\n toDate() {\n const utcDate = Date.UTC(this.year, this.month - 1, this.day, this.hour, this.minute, this.second, this.millisecond);\n return (new Date(utcDate));\n }\n fromString(inputString) {\n let isUTC = false;\n let timeString = \"\";\n let dateTimeString = \"\";\n let fractionPart = 0;\n let parser;\n let hourDifference = 0;\n let minuteDifference = 0;\n if (inputString[inputString.length - 1] === \"Z\") {\n timeString = inputString.substring(0, inputString.length - 1);\n isUTC = true;\n }\n else {\n const number = new Number(inputString[inputString.length - 1]);\n if (isNaN(number.valueOf()))\n throw new Error(\"Wrong input string for conversion\");\n timeString = inputString;\n }\n if (isUTC) {\n if (timeString.indexOf(\"+\") !== -1)\n throw new Error(\"Wrong input string for conversion\");\n if (timeString.indexOf(\"-\") !== -1)\n throw new Error(\"Wrong input string for conversion\");\n }\n else {\n let multiplier = 1;\n let differencePosition = timeString.indexOf(\"+\");\n let differenceString = \"\";\n if (differencePosition === -1) {\n differencePosition = timeString.indexOf(\"-\");\n multiplier = -1;\n }\n if (differencePosition !== -1) {\n differenceString = timeString.substring(differencePosition + 1);\n timeString = timeString.substring(0, differencePosition);\n if ((differenceString.length !== 2) && (differenceString.length !== 4))\n throw new Error(\"Wrong input string for conversion\");\n let number = parseInt(differenceString.substring(0, 2), 10);\n if (isNaN(number.valueOf()))\n throw new Error(\"Wrong input string for conversion\");\n hourDifference = multiplier * number;\n if (differenceString.length === 4) {\n number = parseInt(differenceString.substring(2, 4), 10);\n if (isNaN(number.valueOf()))\n throw new Error(\"Wrong input string for conversion\");\n minuteDifference = multiplier * number;\n }\n }\n }\n let fractionPointPosition = timeString.indexOf(\".\");\n if (fractionPointPosition === -1)\n fractionPointPosition = timeString.indexOf(\",\");\n if (fractionPointPosition !== -1) {\n const fractionPartCheck = new Number(`0${timeString.substring(fractionPointPosition)}`);\n if (isNaN(fractionPartCheck.valueOf()))\n throw new Error(\"Wrong input string for conversion\");\n fractionPart = fractionPartCheck.valueOf();\n dateTimeString = timeString.substring(0, fractionPointPosition);\n }\n else\n dateTimeString = timeString;\n switch (true) {\n case (dateTimeString.length === 8):\n parser = /(\\d{4})(\\d{2})(\\d{2})/ig;\n if (fractionPointPosition !== -1)\n throw new Error(\"Wrong input string for conversion\");\n break;\n case (dateTimeString.length === 10):\n parser = /(\\d{4})(\\d{2})(\\d{2})(\\d{2})/ig;\n if (fractionPointPosition !== -1) {\n let fractionResult = 60 * fractionPart;\n this.minute = Math.floor(fractionResult);\n fractionResult = 60 * (fractionResult - this.minute);\n this.second = Math.floor(fractionResult);\n fractionResult = 1000 * (fractionResult - this.second);\n this.millisecond = Math.floor(fractionResult);\n }\n break;\n case (dateTimeString.length === 12):\n parser = /(\\d{4})(\\d{2})(\\d{2})(\\d{2})(\\d{2})/ig;\n if (fractionPointPosition !== -1) {\n let fractionResult = 60 * fractionPart;\n this.second = Math.floor(fractionResult);\n fractionResult = 1000 * (fractionResult - this.second);\n this.millisecond = Math.floor(fractionResult);\n }\n break;\n case (dateTimeString.length === 14):\n parser = /(\\d{4})(\\d{2})(\\d{2})(\\d{2})(\\d{2})(\\d{2})/ig;\n if (fractionPointPosition !== -1) {\n const fractionResult = 1000 * fractionPart;\n this.millisecond = Math.floor(fractionResult);\n }\n break;\n default:\n throw new Error(\"Wrong input string for conversion\");\n }\n const parserArray = parser.exec(dateTimeString);\n if (parserArray === null)\n throw new Error(\"Wrong input string for conversion\");\n for (let j = 1; j < parserArray.length; j++) {\n switch (j) {\n case 1:\n this.year = parseInt(parserArray[j], 10);\n break;\n case 2:\n this.month = parseInt(parserArray[j], 10);\n break;\n case 3:\n this.day = parseInt(parserArray[j], 10);\n break;\n case 4:\n this.hour = parseInt(parserArray[j], 10) + hourDifference;\n break;\n case 5:\n this.minute = parseInt(parserArray[j], 10) + minuteDifference;\n break;\n case 6:\n this.second = parseInt(parserArray[j], 10);\n break;\n default:\n throw new Error(\"Wrong input string for conversion\");\n }\n }\n if (isUTC === false) {\n const tempDate = new Date(this.year, this.month, this.day, this.hour, this.minute, this.second, this.millisecond);\n this.year = tempDate.getUTCFullYear();\n this.month = tempDate.getUTCMonth();\n this.day = tempDate.getUTCDay();\n this.hour = tempDate.getUTCHours();\n this.minute = tempDate.getUTCMinutes();\n this.second = tempDate.getUTCSeconds();\n this.millisecond = tempDate.getUTCMilliseconds();\n }\n }\n toString(encoding = \"iso\") {\n if (encoding === \"iso\") {\n const outputArray = [];\n outputArray.push(pvutils.padNumber(this.year, 4));\n outputArray.push(pvutils.padNumber(this.month, 2));\n outputArray.push(pvutils.padNumber(this.day, 2));\n outputArray.push(pvutils.padNumber(this.hour, 2));\n outputArray.push(pvutils.padNumber(this.minute, 2));\n outputArray.push(pvutils.padNumber(this.second, 2));\n if (this.millisecond !== 0) {\n outputArray.push(\".\");\n outputArray.push(pvutils.padNumber(this.millisecond, 3));\n }\n outputArray.push(\"Z\");\n return outputArray.join(\"\");\n }\n return super.toString(encoding);\n }\n toJSON() {\n return {\n ...super.toJSON(),\n millisecond: this.millisecond,\n };\n }\n}\n_a$5 = GeneralizedTime;\n(() => {\n typeStore.GeneralizedTime = _a$5;\n})();\nGeneralizedTime.NAME = \"GeneralizedTime\";\n\nvar _a$4;\nclass DATE extends Utf8String {\n constructor(parameters = {}) {\n super(parameters);\n this.idBlock.tagClass = 1;\n this.idBlock.tagNumber = 31;\n }\n}\n_a$4 = DATE;\n(() => {\n typeStore.DATE = _a$4;\n})();\nDATE.NAME = \"DATE\";\n\nvar _a$3;\nclass TimeOfDay extends Utf8String {\n constructor(parameters = {}) {\n super(parameters);\n this.idBlock.tagClass = 1;\n this.idBlock.tagNumber = 32;\n }\n}\n_a$3 = TimeOfDay;\n(() => {\n typeStore.TimeOfDay = _a$3;\n})();\nTimeOfDay.NAME = \"TimeOfDay\";\n\nvar _a$2;\nclass DateTime extends Utf8String {\n constructor(parameters = {}) {\n super(parameters);\n this.idBlock.tagClass = 1;\n this.idBlock.tagNumber = 33;\n }\n}\n_a$2 = DateTime;\n(() => {\n typeStore.DateTime = _a$2;\n})();\nDateTime.NAME = \"DateTime\";\n\nvar _a$1;\nclass Duration extends Utf8String {\n constructor(parameters = {}) {\n super(parameters);\n this.idBlock.tagClass = 1;\n this.idBlock.tagNumber = 34;\n }\n}\n_a$1 = Duration;\n(() => {\n typeStore.Duration = _a$1;\n})();\nDuration.NAME = \"Duration\";\n\nvar _a;\nclass TIME extends Utf8String {\n constructor(parameters = {}) {\n super(parameters);\n this.idBlock.tagClass = 1;\n this.idBlock.tagNumber = 14;\n }\n}\n_a = TIME;\n(() => {\n typeStore.TIME = _a;\n})();\nTIME.NAME = \"TIME\";\n\nclass Any {\n constructor({ name = EMPTY_STRING, optional = false } = {}) {\n this.name = name;\n this.optional = optional;\n }\n}\n\nclass Choice extends Any {\n constructor({ value = [], ...parameters } = {}) {\n super(parameters);\n this.value = value;\n }\n}\n\nclass Repeated extends Any {\n constructor({ value = new Any(), local = false, ...parameters } = {}) {\n super(parameters);\n this.value = value;\n this.local = local;\n }\n}\n\nclass RawData {\n get data() {\n return this.dataView.slice().buffer;\n }\n set data(value) {\n this.dataView = pvtsutils.BufferSourceConverter.toUint8Array(value);\n }\n constructor({ data = EMPTY_VIEW } = {}) {\n this.dataView = pvtsutils.BufferSourceConverter.toUint8Array(data);\n }\n fromBER(inputBuffer, inputOffset, inputLength) {\n const endLength = inputOffset + inputLength;\n this.dataView = pvtsutils.BufferSourceConverter.toUint8Array(inputBuffer).subarray(inputOffset, endLength);\n return endLength;\n }\n toBER(_sizeOnly) {\n return this.dataView.slice().buffer;\n }\n}\n\nfunction compareSchema(root, inputData, inputSchema) {\n if (inputSchema instanceof Choice) {\n for (const element of inputSchema.value) {\n const result = compareSchema(root, inputData, element);\n if (result.verified) {\n return {\n verified: true,\n result: root,\n };\n }\n }\n {\n const _result = {\n verified: false,\n result: { error: \"Wrong values for Choice type\" },\n };\n if (inputSchema.hasOwnProperty(NAME))\n _result.name = inputSchema.name;\n return _result;\n }\n }\n if (inputSchema instanceof Any) {\n if (inputSchema.hasOwnProperty(NAME))\n root[inputSchema.name] = inputData;\n return {\n verified: true,\n result: root,\n };\n }\n if ((root instanceof Object) === false) {\n return {\n verified: false,\n result: { error: \"Wrong root object\" },\n };\n }\n if ((inputData instanceof Object) === false) {\n return {\n verified: false,\n result: { error: \"Wrong ASN.1 data\" },\n };\n }\n if ((inputSchema instanceof Object) === false) {\n return {\n verified: false,\n result: { error: \"Wrong ASN.1 schema\" },\n };\n }\n if ((ID_BLOCK in inputSchema) === false) {\n return {\n verified: false,\n result: { error: \"Wrong ASN.1 schema\" },\n };\n }\n if ((FROM_BER in inputSchema.idBlock) === false) {\n return {\n verified: false,\n result: { error: \"Wrong ASN.1 schema\" },\n };\n }\n if ((TO_BER in inputSchema.idBlock) === false) {\n return {\n verified: false,\n result: { error: \"Wrong ASN.1 schema\" },\n };\n }\n const encodedId = inputSchema.idBlock.toBER(false);\n if (encodedId.byteLength === 0) {\n return {\n verified: false,\n result: { error: \"Error encoding idBlock for ASN.1 schema\" },\n };\n }\n const decodedOffset = inputSchema.idBlock.fromBER(encodedId, 0, encodedId.byteLength);\n if (decodedOffset === -1) {\n return {\n verified: false,\n result: { error: \"Error decoding idBlock for ASN.1 schema\" },\n };\n }\n if (inputSchema.idBlock.hasOwnProperty(TAG_CLASS) === false) {\n return {\n verified: false,\n result: { error: \"Wrong ASN.1 schema\" },\n };\n }\n if (inputSchema.idBlock.tagClass !== inputData.idBlock.tagClass) {\n return {\n verified: false,\n result: root,\n };\n }\n if (inputSchema.idBlock.hasOwnProperty(TAG_NUMBER) === false) {\n return {\n verified: false,\n result: { error: \"Wrong ASN.1 schema\" },\n };\n }\n if (inputSchema.idBlock.tagNumber !== inputData.idBlock.tagNumber) {\n return {\n verified: false,\n result: root,\n };\n }\n if (inputSchema.idBlock.hasOwnProperty(IS_CONSTRUCTED) === false) {\n return {\n verified: false,\n result: { error: \"Wrong ASN.1 schema\" },\n };\n }\n if (inputSchema.idBlock.isConstructed !== inputData.idBlock.isConstructed) {\n return {\n verified: false,\n result: root,\n };\n }\n if (!(IS_HEX_ONLY in inputSchema.idBlock)) {\n return {\n verified: false,\n result: { error: \"Wrong ASN.1 schema\" },\n };\n }\n if (inputSchema.idBlock.isHexOnly !== inputData.idBlock.isHexOnly) {\n return {\n verified: false,\n result: root,\n };\n }\n if (inputSchema.idBlock.isHexOnly) {\n if ((VALUE_HEX_VIEW in inputSchema.idBlock) === false) {\n return {\n verified: false,\n result: { error: \"Wrong ASN.1 schema\" },\n };\n }\n const schemaView = inputSchema.idBlock.valueHexView;\n const asn1View = inputData.idBlock.valueHexView;\n if (schemaView.length !== asn1View.length) {\n return {\n verified: false,\n result: root,\n };\n }\n for (let i = 0; i < schemaView.length; i++) {\n if (schemaView[i] !== asn1View[1]) {\n return {\n verified: false,\n result: root,\n };\n }\n }\n }\n if (inputSchema.name) {\n inputSchema.name = inputSchema.name.replace(/^\\s+|\\s+$/g, EMPTY_STRING);\n if (inputSchema.name)\n root[inputSchema.name] = inputData;\n }\n if (inputSchema instanceof typeStore.Constructed) {\n let admission = 0;\n let result = {\n verified: false,\n result: { error: \"Unknown error\" },\n };\n let maxLength = inputSchema.valueBlock.value.length;\n if (maxLength > 0) {\n if (inputSchema.valueBlock.value[0] instanceof Repeated) {\n maxLength = inputData.valueBlock.value.length;\n }\n }\n if (maxLength === 0) {\n return {\n verified: true,\n result: root,\n };\n }\n if ((inputData.valueBlock.value.length === 0)\n && (inputSchema.valueBlock.value.length !== 0)) {\n let _optional = true;\n for (let i = 0; i < inputSchema.valueBlock.value.length; i++)\n _optional = _optional && (inputSchema.valueBlock.value[i].optional || false);\n if (_optional) {\n return {\n verified: true,\n result: root,\n };\n }\n if (inputSchema.name) {\n inputSchema.name = inputSchema.name.replace(/^\\s+|\\s+$/g, EMPTY_STRING);\n if (inputSchema.name)\n delete root[inputSchema.name];\n }\n root.error = \"Inconsistent object length\";\n return {\n verified: false,\n result: root,\n };\n }\n for (let i = 0; i < maxLength; i++) {\n if ((i - admission) >= inputData.valueBlock.value.length) {\n if (inputSchema.valueBlock.value[i].optional === false) {\n const _result = {\n verified: false,\n result: root,\n };\n root.error = \"Inconsistent length between ASN.1 data and schema\";\n if (inputSchema.name) {\n inputSchema.name = inputSchema.name.replace(/^\\s+|\\s+$/g, EMPTY_STRING);\n if (inputSchema.name) {\n delete root[inputSchema.name];\n _result.name = inputSchema.name;\n }\n }\n return _result;\n }\n }\n else {\n if (inputSchema.valueBlock.value[0] instanceof Repeated) {\n result = compareSchema(root, inputData.valueBlock.value[i], inputSchema.valueBlock.value[0].value);\n if (result.verified === false) {\n if (inputSchema.valueBlock.value[0].optional)\n admission++;\n else {\n if (inputSchema.name) {\n inputSchema.name = inputSchema.name.replace(/^\\s+|\\s+$/g, EMPTY_STRING);\n if (inputSchema.name)\n delete root[inputSchema.name];\n }\n return result;\n }\n }\n if ((NAME in inputSchema.valueBlock.value[0]) && (inputSchema.valueBlock.value[0].name.length > 0)) {\n let arrayRoot = {};\n if ((LOCAL in inputSchema.valueBlock.value[0]) && (inputSchema.valueBlock.value[0].local))\n arrayRoot = inputData;\n else\n arrayRoot = root;\n if (typeof arrayRoot[inputSchema.valueBlock.value[0].name] === \"undefined\")\n arrayRoot[inputSchema.valueBlock.value[0].name] = [];\n arrayRoot[inputSchema.valueBlock.value[0].name].push(inputData.valueBlock.value[i]);\n }\n }\n else {\n result = compareSchema(root, inputData.valueBlock.value[i - admission], inputSchema.valueBlock.value[i]);\n if (result.verified === false) {\n if (inputSchema.valueBlock.value[i].optional)\n admission++;\n else {\n if (inputSchema.name) {\n inputSchema.name = inputSchema.name.replace(/^\\s+|\\s+$/g, EMPTY_STRING);\n if (inputSchema.name)\n delete root[inputSchema.name];\n }\n return result;\n }\n }\n }\n }\n }\n if (result.verified === false) {\n const _result = {\n verified: false,\n result: root,\n };\n if (inputSchema.name) {\n inputSchema.name = inputSchema.name.replace(/^\\s+|\\s+$/g, EMPTY_STRING);\n if (inputSchema.name) {\n delete root[inputSchema.name];\n _result.name = inputSchema.name;\n }\n }\n return _result;\n }\n return {\n verified: true,\n result: root,\n };\n }\n if (inputSchema.primitiveSchema\n && (VALUE_HEX_VIEW in inputData.valueBlock)) {\n const asn1 = localFromBER(inputData.valueBlock.valueHexView);\n if (asn1.offset === -1) {\n const _result = {\n verified: false,\n result: asn1.result,\n };\n if (inputSchema.name) {\n inputSchema.name = inputSchema.name.replace(/^\\s+|\\s+$/g, EMPTY_STRING);\n if (inputSchema.name) {\n delete root[inputSchema.name];\n _result.name = inputSchema.name;\n }\n }\n return _result;\n }\n return compareSchema(root, asn1.result, inputSchema.primitiveSchema);\n }\n return {\n verified: true,\n result: root,\n };\n}\nfunction verifySchema(inputBuffer, inputSchema) {\n if ((inputSchema instanceof Object) === false) {\n return {\n verified: false,\n result: { error: \"Wrong ASN.1 schema type\" },\n };\n }\n const asn1 = localFromBER(pvtsutils.BufferSourceConverter.toUint8Array(inputBuffer));\n if (asn1.offset === -1) {\n return {\n verified: false,\n result: asn1.result,\n };\n }\n return compareSchema(asn1.result, asn1.result, inputSchema);\n}\n\nexport { Any, BaseBlock, BaseStringBlock, BitString, BmpString, Boolean, CharacterString, Choice, Constructed, DATE, DateTime, Duration, EndOfContent, Enumerated, GeneralString, GeneralizedTime, GraphicString, HexBlock, IA5String, Integer, Null, NumericString, ObjectIdentifier, OctetString, Primitive, PrintableString, RawData, RelativeObjectIdentifier, Repeated, Sequence, Set, TIME, TeletexString, TimeOfDay, UTCTime, UniversalString, Utf8String, ValueBlock, VideotexString, ViewWriter, VisibleString, compareSchema, fromBER, verifySchema };\n","import * as asn1 from \"asn1js\";\n\n// X25519 raw pubkey <-> SPKI DER\n\nexport function x25519PubToSpkiDer(rawPub: Uint8Array): Uint8Array {\n const rawPubBuf = rawPub.slice().buffer;\n\n const algorithmIdentifier = new asn1.Sequence({\n value: [new asn1.ObjectIdentifier({ value: \"1.3.101.110\" })] // id-X25519\n });\n\n const subjectPublicKey = new asn1.BitString({\n valueHex: rawPubBuf\n });\n\n const spki = new asn1.Sequence({\n value: [algorithmIdentifier, subjectPublicKey]\n });\n\n return new Uint8Array(spki.toBER());\n}\n\nexport function spkiDerToX25519Pub(der: Uint8Array): Uint8Array {\n const derBuf = der.slice().buffer;\n const asn1obj = asn1.fromBER(derBuf);\n const spki = asn1obj.result as asn1.Sequence;\n const bitString = spki.valueBlock.value![1] as asn1.BitString;\n return new Uint8Array(bitString.valueBlock.valueHex);\n}\n","export function base64Encode(bytes: Uint8Array): string {\n let binary = \"\";\n for (let i = 0; i < bytes.length; i++) {\n binary += String.fromCharCode(bytes[i]);\n }\n return btoa(binary);\n}\n\n// crypto/base64.ts\nexport function base64Decode(b64: string): Uint8Array {\n // robust: trim whitespace\n const clean = b64.replace(/\\s+/g, \"\");\n const bin = atob(clean);\n const out = new Uint8Array(bin.length);\n for (let i = 0; i < bin.length; i++) out[i] = bin.charCodeAt(i);\n return out;\n}\n\nexport function bytesToBase64Url(bytes: Uint8Array): string {\n let bin = \"\";\n for (let i = 0; i < bytes.length; i++) bin += String.fromCharCode(bytes[i]);\n return btoa(bin).replace(/\\+/g, \"-\").replace(/\\//g, \"_\").replace(/=+$/g, \"\");\n}\n\nexport function base64UrlToBytes(b64url: string): Uint8Array {\n // url->std and pad\n const b64 = b64url.replace(/-/g, \"+\").replace(/_/g, \"/\")\n .padEnd(b64url.length + (4 - (b64url.length % 4 || 4)) % 4, \"=\");\n const bin = atob(b64);\n const out = new Uint8Array(bin.length);\n for (let i = 0; i < bin.length; i++) out[i] = bin.charCodeAt(i);\n return out;\n}","/**\n * Strictly convert ArrayBuffer/ArrayBufferView to a concrete ArrayBuffer slice\n * compatible with WebCrypto (avoids ArrayBufferLike / SharedArrayBuffer issues).\n */\nexport function toBufferSourceStrict(src: ArrayBuffer | ArrayBufferView): ArrayBuffer {\n if (src instanceof ArrayBuffer) {\n // Already a real ArrayBuffer.\n return src;\n }\n const view = src as ArrayBufferView;\n const { buffer, byteOffset, byteLength } = view;\n\n // If the backing buffer is a real ArrayBuffer, slice the exact region.\n if (buffer instanceof ArrayBuffer) {\n return buffer.slice(byteOffset, byteOffset + byteLength);\n }\n\n // Fallback: backing store could be SharedArrayBuffer or ArrayBufferLike.\n // Copy the bytes into a fresh Uint8Array (backed by a real ArrayBuffer).\n const copy = new Uint8Array(byteLength);\n copy.set(new Uint8Array(buffer as any, byteOffset, byteLength));\n return copy.buffer;\n}\n\nexport function toBufferSource(u8: Uint8Array): ArrayBuffer {\n // Force TS to treat this as a real ArrayBuffer\n return u8.buffer as ArrayBuffer;\n}\n","import { toBufferSource } from \"./toBuffer\";\n\nexport async function hkdfSha256(\n ikm: Uint8Array,\n salt: Uint8Array,\n info: Uint8Array,\n length: number\n): Promise<Uint8Array> {\n const ikmKey = await crypto.subtle.importKey(\n \"raw\",\n toBufferSource(ikm),\n \"HKDF\",\n false,\n [\"deriveBits\"]\n );\n\n const bits = await crypto.subtle.deriveBits(\n {\n name: \"HKDF\",\n hash: \"SHA-256\",\n salt: toBufferSource(salt),\n info: toBufferSource(info)\n },\n ikmKey,\n length * 8\n );\n\n return new Uint8Array(bits);\n}\n","import { toBufferSource } from \"./toBuffer\";\n\nexport async function importHmacKey(keyBytes: Uint8Array): Promise<CryptoKey> {\n return crypto.subtle.importKey(\n \"raw\",\n toBufferSource(keyBytes),\n {\n name: \"HMAC\",\n hash: \"SHA-256\"\n },\n false,\n [\"sign\"]\n );\n}\n\nexport async function hmacSha256(\n key: CryptoKey,\n data: Uint8Array\n): Promise<Uint8Array> {\n const sig = await crypto.subtle.sign(\n \"HMAC\",\n key,\n toBufferSource(data)\n );\n return new Uint8Array(sig);\n}\n","import { toBufferSourceStrict } from './toBuffer'\nfunction isDerEcdsaSignature(sig: Uint8Array): boolean {\n // Very loose check: DER SEQUENCE tag (0x30) and plausible overall length\n return sig.length >= 8 && sig[0] === 0x30;\n}\n\n// Convert 64-byte raw (r||s) to DER (same encoding you used for client)\nfunction rawEcdsaToDer(sig: Uint8Array): Uint8Array {\n const r = sig.slice(0, 32);\n const s = sig.slice(32, 64);\n\n function trimLeadingZeros(bytes: Uint8Array) {\n let i = 0;\n while (i < bytes.length - 1 && bytes[i] === 0) i++;\n return bytes.slice(i);\n }\n function encodeInt(bytes: Uint8Array) {\n const v = trimLeadingZeros(bytes);\n if (v[0] & 0x80) {\n const out = new Uint8Array(v.length + 1);\n out[0] = 0;\n out.set(v, 1);\n return out;\n }\n return v;\n }\n\n const rEnc = encodeInt(r);\n const sEnc = encodeInt(s);\n const totalLen = 2 + rEnc.length + 2 + sEnc.length;\n\n const out = new Uint8Array(2 + totalLen);\n let o = 0;\n out[o++] = 0x30; // SEQUENCE\n out[o++] = totalLen;\n out[o++] = 0x02; // INTEGER\n out[o++] = rEnc.length;\n out.set(rEnc, o); o += rEnc.length;\n out[o++] = 0x02; // INTEGER\n out[o++] = sEnc.length;\n out.set(sEnc, o);\n return out;\n}\n\nfunction toSafeArrayBuffer(u8: Uint8Array): ArrayBuffer {\n return Uint8Array.from(u8).buffer;\n}\n\nexport function pemToArrayBuffer(pem: string): ArrayBuffer {\n const b64 = pem\n .replace(/-----BEGIN PUBLIC KEY-----/, \"\")\n .replace(/-----END PUBLIC KEY-----/, \"\")\n .replace(/\\s+/g, \"\");\n const binary = atob(b64);\n const bytes = new Uint8Array(binary.length);\n for (let i = 0; i < binary.length; i++) bytes[i] = binary.charCodeAt(i);\n return bytes.buffer;\n}\n\nexport async function importServerP256Key(pem: string): Promise<CryptoKey> {\n const spki = pemToArrayBuffer(pem);\n return crypto.subtle.importKey(\n \"spki\",\n spki,\n { name: \"ECDSA\", namedCurve: \"P-256\" },\n true,\n [\"verify\"]\n );\n}\n\nfunction pemBodyToArrayBuffer(pem: string): ArrayBuffer {\n const m = pem.replace(/\\r/g, '').match(/-----BEGIN [^-]+-----([\\s\\S]*?)-----END [^-]+-----/);\n if (!m) throw new Error('Invalid PEM');\n const b64 = m[1].replace(/[\\n\\r\\s]/g, '');\n const bin = atob(b64);\n const out = new Uint8Array(bin.length);\n for (let i = 0; i < bin.length; i++) out[i] = bin.charCodeAt(i);\n return out.buffer;\n}\nfunction toB64url(bytes: Uint8Array) {\n let bin = ''; for (let i = 0; i < bytes.length; i++) bin += String.fromCharCode(bytes[i]);\n return btoa(bin).replace(/\\+/g,'-').replace(/\\//g,'_').replace(/=+$/,'');\n}\n\n// serverKey.ts\nexport async function verifyServerSignature(\n serverPublicKeyPem: string, // long-term P-256 public key controlling the HSM key\n message: Uint8Array, // EXACT server_pub_der from the response (base64-decoded)\n sig: Uint8Array // EXACT server_sig from the response (base64-decoded), length should be 64\n): Promise<boolean> {\n \nconst spkiDer = pemBodyToArrayBuffer(serverPublicKeyPem);\n\n const key = await crypto.subtle.importKey(\n \"spki\",\n spkiDer, // SPKI \"-----BEGIN PUBLIC KEY-----\"\n { name: \"ECDSA\", namedCurve: \"P-256\" },\n true,\n [\"verify\"]\n );\n\n // WebCrypto wants P1363 (r||s). Your AKV sig is already P1363 (64 bytes), so pass as-is:\n return crypto.subtle.verify(\n { name: \"ECDSA\", hash: \"SHA-256\" },\n key,\n toBufferSourceStrict(sig), // <= P1363 (64 bytes)\n toBufferSourceStrict(message) // <= raw SPKI DER bytes the server says it signed\n );\n}\n\nfunction isDerEcdsa(sig: Uint8Array): boolean {\n return sig.length >= 8 && sig[0] === 0x30;\n}\n\n// Convert DER (ASN.1 SEQUENCE { r INTEGER, s INTEGER }) -> P1363 (r||s)\nfunction derToP1363(der: Uint8Array): Uint8Array {\n if (der[0] !== 0x30) throw new Error(\"Not DER SEQUENCE\");\n // Minimal, robust-ish parser for ECDSA-Sig-Value\n let offset = 2; // skip 0x30, len\n if (der[1] & 0x80) offset = 2 + (der[1] & 0x7f); // long form length handling (optional)\n\n if (der[offset++] !== 0x02) throw new Error(\"Expected INTEGER (r)\");\n let rLen = der[offset++]; if (rLen & 0x80) { const n = rLen & 0x7f; rLen = parseLen(der, offset, n); offset += n; }\n let r = der.slice(offset, offset + rLen); offset += rLen;\n\n if (der[offset++] !== 0x02) throw new Error(\"Expected INTEGER (s)\");\n let sLen = der[offset++]; if (sLen & 0x80) { const n = sLen & 0x7f; sLen = parseLen(der, offset, n); offset += n; }\n let s = der.slice(offset, offset + sLen);\n\n // Remove possible leading 0x00 sign bytes\n if (r[0] === 0x00) r = r.slice(1);\n if (s[0] === 0x00) s = s.slice(1);\n\n // Left-pad to 32 bytes each for P-256\n const R = leftPad(r, 32);\n const S = leftPad(s, 32);\n const out = new Uint8Array(64);\n out.set(R, 0); out.set(S, 32);\n return out;\n\n function leftPad(x: Uint8Array, len: number) {\n if (x.length === len) return x;\n const out = new Uint8Array(len);\n out.set(x, len - x.length);\n return out;\n }\n function parseLen(buf: Uint8Array, off: number, n: number) {\n let v = 0; for (let i = 0; i < n; i++) v = (v << 8) | buf[off + i]; return v;\n }\n}","import type { SecureApiClient } from \"./SecureApiClient\";\n\ntype EventType = 'request' | 'status' | 'topic';\n\nexport class Notifications {\n private client: SecureApiClient;\n private ws: WebSocket | null = null;\n private listeners: Record<string, (msg: any) => void> = {};\n private subscriptions: Record<EventType, Record<string, Record<string, (msg: any) => void>>> = { 'request': {}, 'status': {}, 'topic': {} };\n private _shouldReconnect = true;\n private _reconnectAttempt = 0;\n private _connectPromise?: Promise<void>;\n\n constructor(client: SecureApiClient) {\n this.client = client;\n }\n\n private scheduleReconnect() {\n if (!this._shouldReconnect) return;\n const delay = Math.min(30000, 1000 * 2 ** this._reconnectAttempt); // capped exponential backoff\n this._reconnectAttempt++;\n setTimeout(() => {\n // Reset promise so next connect attempt can start\n this._connectPromise = undefined;\n this.connect().catch(() => {}); // swallow; next close will reschedule\n }, delay);\n }\n\n close() {\n this._shouldReconnect = false;\n this._connectPromise = undefined;\n this.ws?.close();\n this.ws = null;\n }\n\n async connect() {\n await this.client.ensureSession();\n if (!this.client.getAccessToken()) {\n throw new Error(\"Cannot connect to notifications: user is not logged in.\");\n }\n\n if (this.ws && (this.ws.readyState === WebSocket.OPEN || this.ws.readyState === WebSocket.CONNECTING)) return;\n\n if (this._connectPromise) return this._connectPromise;\n this._connectPromise = (async () => {\n const { url } = await this.client.get(\"/url/notifications\");\n\n this.ws = new WebSocket(url);\n\n this.ws.onopen = () => {\n this._reconnectAttempt = 0;\n console.log(\"Notifications connected\");\n };\n\n this.ws.onmessage = async (event) => {\n try {\n const raw = JSON.parse(event.data);\n\n const plaintext = await this.client.decryptAndVerify(raw);\n const requestSubscriptions = this.subscriptions.request[plaintext?.correlation_id];\n if(requestSubscriptions && Object.values(requestSubscriptions).length > 0) {\n Object.values(requestSubscriptions).forEach((fn) => fn(plaintext))\n }\n const statusSubscriptions = this.subscriptions.status[plaintext?.status];\n if(statusSubscriptions && Object.values(statusSubscriptions).length > 0) {\n Object.values(statusSubscriptions).forEach((fn) => fn(plaintext))\n }\n const topicSubscriptions = this.subscriptions.topic[plaintext?.topic];\n if(topicSubscriptions && Object.values(topicSubscriptions).length > 0) {\n Object.values(topicSubscriptions).forEach((fn) => fn(plaintext))\n }\n Object.values(this.listeners).forEach(fn => fn(plaintext));\n } catch (err) {\n console.warn(\"Failed to process notification:\", err);\n }\n };\n\n this.ws.onerror = (err) => {\n console.error(\"Notifications error\", err);\n };\n\n this.ws.onclose = () => {\n this.scheduleReconnect()\n console.log(\"Notifications closed\");\n };\n })()\n\n\n try {\n await this._connectPromise;\n } finally {\n // Clear only if the socket is actually open or definitively failed\n if (this.ws?.readyState === WebSocket.OPEN) {\n this._connectPromise = undefined;\n } else if (!this.ws || this.ws.readyState === WebSocket.CLOSED) {\n this._connectPromise = undefined;\n }\n }\n\n }\n\n generateRandomString = (length: number): string => {\n let result = '';\n while (result.length < length) {\n result += Math.random().toString(36).substring(2, 2 + (length - result.length));\n }\n return result;\n };\n\n unsuscribe(eventType: EventType, eventValue: string, label: string){\n delete this.subscriptions[eventType][eventValue][label];\n }\n\n unlisten(label: string){\n delete this.listeners[label];\n }\n\n suscribe(eventType: EventType, eventValue: string, fn: (msg: any) => void, label?: string){\n let _label = label;\n if(_label == undefined){\n _label = this.generateRandomString(16);\n }\n if(!this.subscriptions[eventType]) {\n this.subscriptions[eventType] = {} as any\n }\n if(!this.subscriptions[eventType][eventValue]) {\n this.subscriptions[eventType][eventValue] = {}\n }\n this.subscriptions[eventType][eventValue][_label] = fn;\n return () => this.unsuscribe(eventType, eventValue, _label!)\n }\n\n onMessage(fn: (msg: any) => void, label?: string) {\n let _label = label;\n if(_label == undefined){\n _label = this.generateRandomString(16);\n }\n this.listeners[_label] = fn;\n return () => this.unlisten(_label!)\n }\n\n disconnect() {\n this.ws?.close();\n this.ws = null;\n }\n}\n","import { x25519 } from \"@noble/curves/ed25519\";\nimport { x25519PubToSpkiDer, spkiDerToX25519Pub } from \"./crypto/spki\";\nimport { base64Encode, base64Decode } from \"./crypto/base64\";\nimport { hkdfSha256 } from \"./crypto/hkdf\";\nimport { importHmacKey, hmacSha256 } from \"./crypto/hmac\";\nimport { verifyServerSignature } from \"./crypto/serverKey\";\nimport { Notifications } from \"./notifications\";\n\nexport type LoginOptions =\n | { username: string; password: string; scope: string }\n | { email: string; socialLoginId: string; scope: string }\n | { jwt: string }\n | { refreshToken: string };\n\nexport type SecureApiClientConfig = {\n baseUrl: string;\n clientId: string;\n serverPublicKeyPem: string;\n clientIdentityPrivateKeyPem: string; // P-256 private key (PKCS8)\n};\n\nexport type SessionState = {\n sessionId: string;\n encKey: CryptoKey; // AES-GCM key\n macKey: CryptoKey; // HMAC-SHA256 key\n sessionExpiresAt: string;\n userId?: string;\n accessToken?: string;\n tokenType?: string;\n expiresAt?: number;\n refreshToken?: string;\n};\n\n// Persist only serializable fields (no CryptoKey)\ntype PersistedSession = {\n sessionId?: string;\n sessionExpiresAt?: string;\n userId?: string;\n accessToken?: string;\n tokenType?: string;\n expiresAt?: number;\n refreshToken?: string;\n};\n\nconst SESSION_STORAGE_KEY = 'secure_api_session_v1';\n\nexport class SecureApiClient {\n private baseUrl: string;\n private clientId: string;\n private session: SessionState | null = null;\n private serverPublicKeyPem: string;\n private clientIdentityKeyPromise: Promise<CryptoKey>;\n notifications: Notifications;\n\n constructor(config: SecureApiClientConfig) {\n this.baseUrl = config.baseUrl;\n this.clientId = config.clientId;\n this.serverPublicKeyPem = config.serverPublicKeyPem;\n this.clientIdentityKeyPromise = importClientIdentityKey(\n config.clientIdentityPrivateKeyPem\n );\n\n // Try to hydrate non-crypto session fields from localStorage\n this.loadPersistedSession();\n\n this.notifications = new Notifications(this);\n }\n\n private loadPersistedSession() {\n try {\n const raw = localStorage.getItem(SESSION_STORAGE_KEY);\n if (!raw) return;\n const persisted: PersistedSession = JSON.parse(raw);\n if (!persisted) return;\n // Partially hydrate; encKey/macKey will be (re)created on handshake\n if (persisted.sessionId && persisted.sessionExpiresAt) {\n this.session = {\n sessionId: persisted.sessionId,\n sessionExpiresAt: persisted.sessionExpiresAt,\n encKey: undefined as unknown as CryptoKey,\n macKey: undefined as unknown as CryptoKey,\n userId: persisted.userId,\n accessToken: persisted.accessToken,\n tokenType: persisted.tokenType,\n expiresAt: persisted.expiresAt,\n refreshToken: persisted.refreshToken\n };\n } else {\n // No session id; still keep token info if present\n this.session = {\n sessionId: '' as unknown as string,\n sessionExpiresAt: '' as unknown as string,\n encKey: undefined as unknown as CryptoKey,\n macKey: undefined as unknown as CryptoKey,\n userId: persisted.userId,\n accessToken: persisted.accessToken,\n tokenType: persisted.tokenType,\n expiresAt: persisted.expiresAt,\n refreshToken: persisted.refreshToken\n } as any;\n }\n } catch {\n // ignore\n }\n }\n\n private persistSession() {\n try {\n const s = this.session;\n const toStore: PersistedSession = s ? {\n sessionId: s.sessionId,\n sessionExpiresAt: s.sessionExpiresAt,\n userId: s.userId,\n accessToken: s.accessToken,\n tokenType: s.tokenType,\n expiresAt: s.expiresAt,\n refreshToken: s.refreshToken\n } : {};\n localStorage.setItem(SESSION_STORAGE_KEY, JSON.stringify(toStore));\n } catch {\n // ignore\n }\n }\n\n async handshake(): Promise<void> {\n const clientIdentityKey = await this.clientIdentityKeyPromise;\n\n // 1. Generate client X25519 keypair\n const clientPriv = x25519.utils.randomSecretKey();\n const clientPub = x25519.getPublicKey(clientPriv);\n\n // 2. Encode client pubkey as SPKI DER + base64\n const clientPubSpkiDer = x25519PubToSpkiDer(clientPub);\n const clientPubB64 = base64Encode(clientPubSpkiDer);\n\n // 3. Sign client_pub_der with long-term P-256 identity key\n const clientSigRaw = await crypto.subtle.sign(\n { name: \"ECDSA\", hash: \"SHA-256\" },\n clientIdentityKey,\n toSafeBufferSource(clientPubSpkiDer)\n );\n\n const clientSigDer = rawEcdsaToDer(new Uint8Array(clientSigRaw));\n const clientSigB64 = base64Encode(clientSigDer);\n\n // 4. Call /handshake\n const res = await fetch(`${this.baseUrl}/handshake`, {\n method: \"POST\",\n headers: {\n \"Content-Type\": \"application/json\"\n },\n body: JSON.stringify({\n client_id: this.clientId,\n user_id: this.getUserId(),\n client_pub: clientPubB64,\n client_sig: clientSigB64,\n client_alg: \"ES256\"\n })\n });\n\n if (!res.ok) {\n throw new Error(`Handshake failed: ${res.status} ${res.statusText}`);\n }\n\n const json = await res.json();\n const { session_id, server_pub, server_sig, session_expires_at } = json;\n (window as any).__akv = { server_pub, server_sig }\n if (!session_id || !server_pub || !server_sig) {\n throw new Error(\"Handshake response missing fields\");\n }\n\n const serverPubDer = base64Decode(server_pub);\n const serverSig = base64Decode(server_sig);\n\n const ok = await verifyServerSignature(\n this.serverPublicKeyPem,\n serverPubDer,\n serverSig\n );\n\n if (!ok) {\n throw new Error(\"Server signature verification failed\");\n }\n\n // 5. Convert server SPKI DER -> raw X25519 pubkey\n const serverPubRaw = spkiDerToX25519Pub(serverPubDer);\n\n // 6. Compute shared secret via X25519\n const sharedSecret = x25519.getSharedSecret(clientPriv, serverPubRaw);\n\n // 7. HKDF -> session key (HMAC-SHA256)\n const salt = new Uint8Array(0); // empty salt\n const info = new TextEncoder().encode(\"health-api-v1\"); // must match server\n const keyMaterial = await hkdfSha256(sharedSecret, salt, info, 64);\n\n const encKeyBytes = keyMaterial.slice(0, 32);\n const macKeyBytes = keyMaterial.slice(32, 64);\n\n const encKey = await crypto.subtle.importKey(\n \"raw\",\n encKeyBytes,\n \"AES-GCM\",\n false,\n [\"encrypt\", \"decrypt\"]\n );\n\n const macKey = await importHmacKey(macKeyBytes);\n\n this.updateSession({\n sessionId: session_id,\n encKey,\n macKey,\n sessionExpiresAt: session_expires_at\n })\n }\n\n getUserId() {\n return this.session?.userId\n }\n\n getAccessToken() {\n return this.session?.accessToken\n }\n\n public updateSession(partial: Partial<SessionState>) {\n if (!this.session) {\n this.session = partial as SessionState;\n this.persistSession();\n return;\n }\n Object.assign(this.session, partial);\n this.persistSession();\n }\n\n public getSession(): Readonly<SessionState> {\n if (!this.session) {\n throw new Error(\"No session\");\n }\n return this.session;\n }\n\n private async encryptBody(body: any | null) {\n if (!body) return { ciphertextB64: \"\", ivB64: \"\" };\n\n await this.ensureSession();\n const { encKey } = this.session!;\n\n const iv = crypto.getRandomValues(new Uint8Array(12));\n const plaintext = new TextEncoder().encode(JSON.stringify(body));\n\n const ciphertext = await crypto.subtle.encrypt(\n { name: \"AES-GCM\", iv },\n encKey,\n plaintext\n );\n\n return {\n ciphertextB64: base64Encode(new Uint8Array(ciphertext)),\n ivB64: base64Encode(iv)\n };\n }\n\n private async signRequest(\n method: string,\n path: string,\n body: any | null\n ): Promise<{ headers: Headers; payload: any }> {\n await this.ensureSession();\n const { sessionId, macKey } = this.session!;\n const payload = (method.toUpperCase() === 'GET') ? \"\" : {data: Array.isArray(body) ? body : [body]};\n const { ciphertextB64, ivB64 } = await this.encryptBody(payload);\n const ts = Math.floor(Date.now() / 1000).toString();\n const payloadToSign = `${method.toUpperCase()} ${path}\n${ts}\n${ciphertextB64}`;\n\n const mac = await hmacSha256(macKey, new TextEncoder().encode(payloadToSign));\n const macB64 = base64Encode(mac);\n const headers = new Headers({\n \"X-Session-Id\": sessionId,\n \"X-Client-Id\": this.clientId,\n \"X-Timestamp\": ts,\n \"X-Signature\": macB64,\n \"Content-Type\": \"application/json\",\n })\n\n if (this.getUserId()) {\n headers.append(\"X-User-Id\", this.getUserId()!)\n }\n\n if (this.getAccessToken() && !this.isTokenExpired()) {\n headers.append(\"Authorization\", `Bearer ${this.getAccessToken()!}`)\n }\n return {\n headers,\n payload: {\n content: ciphertextB64,\n iv: ivB64\n }\n };\n }\n\n async get<T = any>(path: string): Promise<T> {\n const { headers } = await this.signRequest(\"GET\", path, null);\n const res = await fetch(`${this.baseUrl}${path}`, {\n method: \"GET\",\n headers\n });\n if (!res.ok) {\n throw new Error(`GET ${path} failed: ${res.status} ${res.statusText}`);\n }\n return this.decryptAndVerify(await res.json());\n }\n\n async post<T = any>(path: string, body: any): Promise<T> {\n const { headers, payload } = await this.signRequest(\"POST\", path, body);\n const res = await fetch(`${this.baseUrl}${path}`, {\n method: \"POST\",\n headers,\n body: JSON.stringify(payload)\n });\n if (!res.ok) {\n throw new Error(`POST ${path} failed: ${res.status} ${res.statusText}`);\n }\n if (path.endsWith(\"/handshake\")) {\n return await res.json();\n }\n\n return this.decryptAndVerify(await res.json());\n }\n\n async ensureSession() {\n if (!this.session || !this.session.sessionId || !this.session.sessionExpiresAt || !this.session.encKey || !this.session.macKey) {\n await this.handshake();\n }\n const fiveMinutesFromNow = new Date(Date.now() + 5 * 60 * 1000);\n if (this.session?.sessionExpiresAt && new Date(this.session?.sessionExpiresAt) < fiveMinutesFromNow) {\n await this.extendHandshake()\n }\n if(this.session?.userId){\n if (this.isTokenExpired()) {\n await this.refresh()\n }\n\n }\n }\n\n async extendHandshake(){\n await this.post('/handshake/extend', {}).then(async (r) => {\n if(r){\n if(r.session_id !== this.session?.sessionId){\n await this.handshake()\n } else {\n this.updateSession({\n sessionExpiresAt: r.session_expires_at\n })\n }\n }\n }).catch(async (_e) => {\n await this.handshake();\n })\n }\n \n public async decryptAndVerify(msg: any): Promise<any> {\n const { ciphertext, iv, signature, ...metadata } = msg;\n\n if (!ciphertext || !iv || !signature) {\n throw new Error(\"Malformed notification\");\n }\n\n const { encKey, macKey } = this.getSession();\n\n // --- Verify MAC ---\n const mac = base64Decode(signature);\n\n const expected = await crypto.subtle.sign(\n \"HMAC\",\n macKey,\n new TextEncoder().encode(ciphertext)\n );\n\n if (!this.constantTimeEqual(mac, new Uint8Array(expected))) {\n throw new Error(\"Invalid notification signature\");\n }\n\n // --- Decrypt ---\n const ivBytes = Uint8Array.from(base64Decode(iv));\n const ciphertextBytes = Uint8Array.from(base64Decode(ciphertext)); \n\n const plaintextBytes = await crypto.subtle.decrypt(\n { name: \"AES-GCM\", iv: ivBytes },\n encKey,\n ciphertextBytes\n );\n\n const plaintext = new TextDecoder().decode(plaintextBytes);\n const cipherpart = JSON.parse(plaintext);\n return { ...cipherpart, ...metadata};\n }\n\n private constantTimeEqual(a: Uint8Array, b: Uint8Array): boolean {\n if (a.length !== b.length) return false;\n let diff = 0;\n for (let i = 0; i < a.length; i++) diff |= a[i] ^ b[i];\n return diff === 0;\n }\n \n \n async login(options: LoginOptions) {\n // 1. Ensure handshake\n await this.ensureSession();\n\n // 2. Build payload\n const payload: any = {};\n\n if (\"username\" in options && \"password\" in options) {\n payload.username = options.username;\n payload.password = options.password;\n payload.scope = options.scope;\n }\n\n if (\"email\" in options && \"socialLoginId\" in options) {\n payload.email = options.email;\n payload.social_login_id = options.socialLoginId;\n payload.scope = options.scope;\n }\n\n if (\"jwt\" in options) {\n this.updateSession({\n accessToken: options.jwt,\n tokenType: 'Bearer',\n })\n }\n\n if (\"refreshToken\" in options) {\n payload.refresh_token = options.refreshToken;\n }\n\n // 3. Sign request\n \n const decrypted = await this.post(\"/oauth/authorize\", payload);\n\n const {\n access_token,\n token_type,\n expires_at,\n refresh_token\n } = decrypted;\n\n if(access_token){\n this.updateSession({ accessToken: access_token });\n }\n if(token_type){\n this.updateSession({ tokenType: token_type });\n }\n if(expires_at){\n this.updateSession({ expiresAt: expires_at });\n }\n if(refresh_token){\n this.updateSession({ refreshToken: refresh_token });\n }\n\n // 7. Return token info\n return {\n accessToken: access_token,\n tokenType: token_type,\n expiresAt: expires_at,\n refreshToken: refresh_token\n };\n }\n\n async refresh() {\n const session = this.getSession();\n\n if (!session?.refreshToken) {\n throw new Error(\"No refresh token available\");\n }\n \n if(session && session.refreshToken) {\n return this.login({\n refreshToken: session.refreshToken\n });\n }\n }\n\n isTokenExpired() {\n const session = this.getSession();\n if (!session?.expiresAt) return true;\n if(session && session.expiresAt) {\n return Math.floor(Date.now() / 1000) >= session.expiresAt;\n }\n }\n}\n\nfunction pemToArrayBuffer(pem: string): ArrayBuffer {\n const b64 = pem\n .replace(/-----BEGIN PRIVATE KEY-----/, \"\")\n .replace(/-----END PRIVATE KEY-----/, \"\")\n .replace(/\\s+/g, \"\");\n const binary = atob(b64);\n const bytes = new Uint8Array(binary.length);\n for (let i = 0; i < binary.length; i++) {\n bytes[i] = binary.charCodeAt(i);\n }\n return bytes.buffer;\n}\n\nasync function importClientIdentityKey(pem: string): Promise<CryptoKey> {\n const pkcs8 = pemToArrayBuffer(pem);\n return crypto.subtle.importKey(\n \"pkcs8\",\n pkcs8,\n { name: \"ECDSA\", namedCurve: \"P-256\" },\n false,\n [\"sign\"]\n );\n}\n\nfunction toSafeBufferSource(u8: Uint8Array): ArrayBuffer {\n return Uint8Array.from(u8).buffer;\n}\n\nfunction rawEcdsaToDer(sig: Uint8Array): Uint8Array {\n const r = sig.slice(0, 32);\n const s = sig.slice(32, 64);\n\n function trimLeadingZeros(bytes: Uint8Array): Uint8Array {\n let i = 0;\n while (i < bytes.length - 1 && bytes[i] === 0) i++;\n return bytes.slice(i);\n }\n\n function encodeInt(bytes: Uint8Array): Uint8Array {\n const v = trimLeadingZeros(bytes);\n if (v[0] & 0x80) {\n const out = new Uint8Array(v.length + 1);\n out[0] = 0;\n out.set(v, 1);\n return out;\n }\n return v;\n }\n\n const rEnc = encodeInt(r);\n const sEnc = encodeInt(s);\n\n const totalLen = 2 + rEnc.length + 2 + sEnc.length;\n const out = new Uint8Array(2 + totalLen);\n let offset = 0;\n\n out[offset++] = 0x30; // SEQUENCE\n out[offset++] = totalLen;\n\n out[offset++] = 0x02; // INTEGER\n out[offset++] = rEnc.length;\n out.set(rEnc, offset);\n offset += rEnc.length;\n\n out[offset++] = 0x02; // INTEGER\n out[offset++] = sEnc.length;\n out.set(sEnc, offset);\n\n return out;\n}\n","import type { App } from 'vue';\nimport type { SecureApiClientConfig } from './SecureApiClient';\nimport { SecureApiClient } from './SecureApiClient';\n\nexport const SDK_CLIENT = Symbol('SDK_CLIENT');\nexport type SdkPluginOptions = SecureApiClientConfig;\n\nexport default {\n install(app: App, options: SdkPluginOptions) {\n const client = new SecureApiClient(options);\n app.provide(SDK_CLIENT, client);\n }\n};\n"],"names":["crypto","isBytes","a","anumber","abytes","b","lengths","hasHexBuiltin","hexes","_","i","bytesToHex","bytes","hex","asciis","asciiToBase16","ch","hexToBytes","hl","al","array","ai","hi","n1","n2","char","randomBytes","bytesLength","_0n","_1n","hexToNumber","bytesToNumberBE","bytesToHex_","bytesToNumberLE","abytes_","numberToBytesBE","len","hexToBytes_","numberToBytesLE","ensureBytes","title","expectedLength","res","e","isBytes_","isPosBig","inRange","min","max","aInRange","n","bitMask","_validateObject","object","fields","optFields","checkField","fieldName","expectedType","isOpt","val","current","k","v","_2n","_3n","_4n","_5n","_7n","_8n","_9n","_16n","mod","result","pow2","x","power","modulo","invert","number","u","q","r","m","assertIsSquare","Fp","root","sqrt3mod4","p1div4","sqrt5mod8","p5div8","nv","sqrt9mod16","P","Fp_","Field","tn","tonelliShanks","c1","c2","c3","c4","tv1","tv2","tv3","tv4","e1","e2","e3","Q","S","Z","_Fp","FpLegendre","cc","Q1div2","M","c","t","R","t_tmp","exponent","FpSqrt","FpPow","num","p","d","FpInvertBatch","nums","passZero","inverted","multipliedAcc","acc","invertedAcc","p1mod2","powered","yes","zero","no","nLength","nBitLength","_nBitLength","nByteLength","ORDER","bitLenOrOpts","isLE","opts","_nbitLength","_sqrt","modFromBytes","allowedLengths","_opts","BITS","BYTES","sqrtP","f","lhs","rhs","skipValidation","padded","scalar","lst","validateOpts","curve","montgomery","curveDef","CURVE","type","adjustScalarBytes","powPminus2","rand","is25519","randomBytes_","montgomeryBits","fieldLen","Gu","a24","minScalar","maxAdded","maxScalar","modP","GuBytes","encodeU","decodeU","_u","decodeScalar","scalarMult","pu","montgomeryLadder","scalarMultBase","cswap","swap","x_2","x_3","dummy","x_1","z_2","z_3","k_t","A","AA","B","BB","E","C","D","DA","CB","dacb","da_cb","z2","randomSecretKey","seed","keygen","secretKey","publicKey","ed25519_CURVE_p","ed25519_CURVE","ed25519_pow_2_252_3","_10n","_20n","_40n","_80n","b2","b4","b5","b10","b20","b40","b80","b160","b240","b250","x25519","pow_p_5_8","ARRAY_BUFFER_NAME","BufferSourceConverter","data","aView","bView","args","buffers","size","buffer","offset","view","STRING_TYPE","HEX_REGEX","BASE64_REGEX","BASE64URL_REGEX","Utf8Converter","text","s","uintArray","buf","encodedString","Utf16Converter","littleEndian","arrayBuffer","dataView","code","Convert","enc","str","binary","base64","formatted","base64url","encoding","stringLength","resultView","byte","hexString","padCount","utilFromBase","inputBuffer","inputBase","utilToBase","value","base","reserved","internalReserved","internalValue","biggest","retBuf","retView","j","basis","utilConcatView","views","outputLength","prevLength","utilDecodeTC","condition1","condition2","bigIntBuffer","bigIntView","bigInt","smallIntBuffer","smallIntView","utilEncodeTC","modValue","smallInt","tempBuf","tempView","isEqualBuffer","inputBuffer1","inputBuffer2","view1","view2","padNumber","inputNumber","fullLength","dif","padding","assertBigInt","concat","checkBufferParams","baseBlock","inputOffset","inputLength","ViewWriter","powers2","digitsString","EMPTY_STRING","EMPTY_BUFFER","EMPTY_VIEW","END_OF_CONTENT_NAME","OCTET_STRING_NAME","BIT_STRING_NAME","HexBlock","BaseClass","_a","_b","params","pvtsutils.BufferSourceConverter","endLength","sizeOnly","pvtsutils.Convert","LocalBaseBlock","blockLength","error","warnings","valueBeforeDecode","ValueBlock","_inputBuffer","_inputOffset","_inputLength","_sizeOnly","_writer","LocalIdentificationBlock","idBlock","_c","_d","firstOctet","encodedBuf","pvutils.utilToBase","encodedView","curView","inputView","intBuffer","tagNumberMask","count","intTagNumberBuffer","tagNumberBufferMaxLength","tempBufferView","pvutils.utilFromBase","LocalLengthBlock","lenBlock","lenOffset","lengthBufferView","typeStore","BaseBlock","name","optional","primitiveSchema","parameters","valueBlockType","resultOffset","writer","prepareIndefiniteForm","idBlockBuf","valueBlockBuf","lenBlockBuf","other","thisRaw","otherRaw","pvutils.isEqualBuffer","BaseStringBlock","stringValueBlockType","LocalPrimitiveValueBlock","isHexOnly","_a$w","Primitive","localChangeType","inputObject","newType","newObject","localFromBER","incomingOffset","returnObject","newASN1Type","fromBER","checkLen","indefiniteLength","length","LocalConstructedValueBlock","isIndefiniteForm","currentOffset","_a$v","Constructed","values","o","blockName","LocalEndOfContentValueBlock","_a$u","EndOfContent","_a$t","Null","LocalBooleanValueBlock","octet","pvutils.utilDecodeTC","_a$s","Boolean","LocalOctetStringValueBlock","isConstructed","currentBlockName","_a$r","OctetString","asn","content","LocalBitStringValueBlock","unusedBits","valueBlock","empty","_a$q","BitString","bits","valueHex","bitsStr","_a$p","viewAdd","first","second","firstView","secondView","firstViewCopy","firstViewCopyLength","secondViewCopy","secondViewCopyLength","counter","pvutils.utilConcatView","power2","digits","newValue","viewSub","LocalIntegerValueBlock","pvutils.utilEncodeTC","updatedView","firstBit","bitNumber","currentByte","asn1View","flag","byteNumber","_a$o","Integer","bigIntValue","secondInt","integer","_a$n","Enumerated","LocalSidValueBlock","valueDec","isFirstSid","sidValue","LocalObjectIdentifierValueBlock","sidBlock","retBuffers","valueBuf","string","pos1","pos2","sid","plus","parsedSID","sidStr","_a$m","ObjectIdentifier","LocalRelativeSidValueBlock","LocalRelativeObjectIdentifierValueBlock","_a$l","RelativeObjectIdentifier","_a$k","Sequence","_a$j","Set","LocalStringValueBlock","LocalSimpleStringValueBlock","LocalSimpleStringBlock","inputString","strLen","LocalUtf8StringValueBlock","ex","_a$i","Utf8String","LocalBmpStringValueBlock","_a$h","BmpString","LocalUniversalStringValueBlock","copyBuffer","valueView","strLength","valueHexView","codeBuf","codeView","_a$g","UniversalString","_a$f","NumericString","_a$e","PrintableString","_a$d","TeletexString","_a$c","VideotexString","_a$b","IA5String","_a$a","GraphicString","_a$9","VisibleString","_a$8","GeneralString","_a$7","CharacterString","_a$6","UTCTime","valueDate","inputDate","parserArray","year","outputArray","pvutils.padNumber","_a$5","GeneralizedTime","utcDate","isUTC","timeString","dateTimeString","fractionPart","parser","hourDifference","minuteDifference","multiplier","differencePosition","differenceString","fractionPointPosition","fractionPartCheck","fractionResult","tempDate","_a$4","DATE","_a$3","TimeOfDay","_a$2","DateTime","_a$1","Duration","TIME","x25519PubToSpkiDer","rawPub","rawPubBuf","algorithmIdentifier","asn1.Sequence","asn1.ObjectIdentifier","subjectPublicKey","asn1.BitString","spki","spkiDerToX25519Pub","der","derBuf","bitString","asn1.fromBER","base64Encode","base64Decode","b64","clean","bin","out","toBufferSourceStrict","src","byteOffset","byteLength","copy","toBufferSource","u8","hkdfSha256","ikm","salt","info","ikmKey","importHmacKey","keyBytes","hmacSha256","key","sig","pemBodyToArrayBuffer","pem","verifyServerSignature","serverPublicKeyPem","message","spkiDer","Notifications","client","delay","url","event","raw","plaintext","requestSubscriptions","fn","statusSubscriptions","topicSubscriptions","err","eventType","eventValue","label","_label","SESSION_STORAGE_KEY","SecureApiClient","config","importClientIdentityKey","persisted","toStore","clientIdentityKey","clientPriv","clientPub","clientPubSpkiDer","clientPubB64","clientSigRaw","toSafeBufferSource","clientSigDer","rawEcdsaToDer","clientSigB64","json","session_id","server_pub","server_sig","session_expires_at","serverPubDer","serverSig","serverPubRaw","sharedSecret","keyMaterial","encKeyBytes","macKeyBytes","encKey","macKey","partial","body","iv","ciphertext","method","path","sessionId","payload","ciphertextB64","ivB64","ts","payloadToSign","mac","macB64","headers","fiveMinutesFromNow","_e","msg","signature","metadata","expected","ivBytes","ciphertextBytes","plaintextBytes","diff","options","decrypted","access_token","token_type","expires_at","refresh_token","session","pemToArrayBuffer","pkcs8","trimLeadingZeros","encodeInt","rEnc","sEnc","totalLen","SDK_CLIENT","plugin","app"],"mappings":"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","x_google_ignoreList":[0,1,2,3,4,5,6,7,8]}
|