// @bun var __create = Object.create; var __getProtoOf = Object.getPrototypeOf; var __defProp = Object.defineProperty; var __getOwnPropNames = Object.getOwnPropertyNames; var __hasOwnProp = Object.prototype.hasOwnProperty; var __toESM = (mod, isNodeMode, target) => { target = mod != null ? __create(__getProtoOf(mod)) : {}; const to = isNodeMode || !mod || !mod.__esModule ? __defProp(target, "default", { value: mod, enumerable: true }) : target; for (let key of __getOwnPropNames(mod)) if (!__hasOwnProp.call(to, key)) __defProp(to, key, { get: () => mod[key], enumerable: true }); return to; }; var __commonJS = (cb, mod) => () => (mod || cb((mod = { exports: {} }).exports, mod), mod.exports); var __require = import.meta.require; // ../eve/node_modules/safe-buffer/index.js var require_safe_buffer = __commonJS((exports, module) => { /*! safe-buffer. MIT License. Feross Aboukhadijeh */ var buffer = __require("buffer"); var Buffer2 = buffer.Buffer; function copyProps(src, dst) { for (var key in src) { dst[key] = src[key]; } } if (Buffer2.from && Buffer2.alloc && Buffer2.allocUnsafe && Buffer2.allocUnsafeSlow) { module.exports = buffer; } else { copyProps(buffer, exports); exports.Buffer = SafeBuffer; } function SafeBuffer(arg, encodingOrOffset, length) { return Buffer2(arg, encodingOrOffset, length); } SafeBuffer.prototype = Object.create(Buffer2.prototype); copyProps(Buffer2, SafeBuffer); SafeBuffer.from = function(arg, encodingOrOffset, length) { if (typeof arg === "number") { throw new TypeError("Argument must not be a number"); } return Buffer2(arg, encodingOrOffset, length); }; SafeBuffer.alloc = function(size, fill, encoding) { if (typeof size !== "number") { throw new TypeError("Argument must be a number"); } var buf = Buffer2(size); if (fill !== undefined) { if (typeof encoding === "string") { buf.fill(fill, encoding); } else { buf.fill(fill); } } else { buf.fill(0); } return buf; }; SafeBuffer.allocUnsafe = function(size) { if (typeof size !== "number") { throw new TypeError("Argument must be a number"); } return Buffer2(size); }; SafeBuffer.allocUnsafeSlow = function(size) { if (typeof size !== "number") { throw new TypeError("Argument must be a number"); } return buffer.SlowBuffer(size); }; }); // ../eve/node_modules/jws/lib/data-stream.js var require_data_stream = __commonJS((exports, module) => { var Buffer2 = require_safe_buffer().Buffer; var Stream = __require("stream"); var util = __require("util"); function DataStream(data) { this.buffer = null; this.writable = true; this.readable = true; if (!data) { this.buffer = Buffer2.alloc(0); return this; } if (typeof data.pipe === "function") { this.buffer = Buffer2.alloc(0); data.pipe(this); return this; } if (data.length || typeof data === "object") { this.buffer = data; this.writable = false; process.nextTick(function() { this.emit("end", data); this.readable = false; this.emit("close"); }.bind(this)); return this; } throw new TypeError("Unexpected data type (" + typeof data + ")"); } util.inherits(DataStream, Stream); DataStream.prototype.write = function write(data) { this.buffer = Buffer2.concat([this.buffer, Buffer2.from(data)]); this.emit("data", data); }; DataStream.prototype.end = function end(data) { if (data) this.write(data); this.emit("end", data); this.emit("close"); this.writable = false; this.readable = false; }; module.exports = DataStream; }); // ../eve/node_modules/ecdsa-sig-formatter/src/param-bytes-for-alg.js var require_param_bytes_for_alg = __commonJS((exports, module) => { function getParamSize(keySize) { var result = (keySize / 8 | 0) + (keySize % 8 === 0 ? 0 : 1); return result; } var paramBytesForAlg = { ES256: getParamSize(256), ES384: getParamSize(384), ES512: getParamSize(521) }; function getParamBytesForAlg(alg) { var paramBytes = paramBytesForAlg[alg]; if (paramBytes) { return paramBytes; } throw new Error('Unknown algorithm "' + alg + '"'); } module.exports = getParamBytesForAlg; }); // ../eve/node_modules/ecdsa-sig-formatter/src/ecdsa-sig-formatter.js var require_ecdsa_sig_formatter = __commonJS((exports, module) => { var Buffer2 = require_safe_buffer().Buffer; var getParamBytesForAlg = require_param_bytes_for_alg(); var MAX_OCTET = 128; var CLASS_UNIVERSAL = 0; var PRIMITIVE_BIT = 32; var TAG_SEQ = 16; var TAG_INT = 2; var ENCODED_TAG_SEQ = TAG_SEQ | PRIMITIVE_BIT | CLASS_UNIVERSAL << 6; var ENCODED_TAG_INT = TAG_INT | CLASS_UNIVERSAL << 6; function base64Url(base64) { return base64.replace(/=/g, "").replace(/\+/g, "-").replace(/\//g, "_"); } function signatureAsBuffer(signature) { if (Buffer2.isBuffer(signature)) { return signature; } else if (typeof signature === "string") { return Buffer2.from(signature, "base64"); } throw new TypeError("ECDSA signature must be a Base64 string or a Buffer"); } function derToJose(signature, alg) { signature = signatureAsBuffer(signature); var paramBytes = getParamBytesForAlg(alg); var maxEncodedParamLength = paramBytes + 1; var inputLength = signature.length; var offset = 0; if (signature[offset++] !== ENCODED_TAG_SEQ) { throw new Error('Could not find expected "seq"'); } var seqLength = signature[offset++]; if (seqLength === (MAX_OCTET | 1)) { seqLength = signature[offset++]; } if (inputLength - offset < seqLength) { throw new Error('"seq" specified length of "' + seqLength + '", only "' + (inputLength - offset) + '" remaining'); } if (signature[offset++] !== ENCODED_TAG_INT) { throw new Error('Could not find expected "int" for "r"'); } var rLength = signature[offset++]; if (inputLength - offset - 2 < rLength) { throw new Error('"r" specified length of "' + rLength + '", only "' + (inputLength - offset - 2) + '" available'); } if (maxEncodedParamLength < rLength) { throw new Error('"r" specified length of "' + rLength + '", max of "' + maxEncodedParamLength + '" is acceptable'); } var rOffset = offset; offset += rLength; if (signature[offset++] !== ENCODED_TAG_INT) { throw new Error('Could not find expected "int" for "s"'); } var sLength = signature[offset++]; if (inputLength - offset !== sLength) { throw new Error('"s" specified length of "' + sLength + '", expected "' + (inputLength - offset) + '"'); } if (maxEncodedParamLength < sLength) { throw new Error('"s" specified length of "' + sLength + '", max of "' + maxEncodedParamLength + '" is acceptable'); } var sOffset = offset; offset += sLength; if (offset !== inputLength) { throw new Error('Expected to consume entire buffer, but "' + (inputLength - offset) + '" bytes remain'); } var rPadding = paramBytes - rLength, sPadding = paramBytes - sLength; var dst = Buffer2.allocUnsafe(rPadding + rLength + sPadding + sLength); for (offset = 0;offset < rPadding; ++offset) { dst[offset] = 0; } signature.copy(dst, offset, rOffset + Math.max(-rPadding, 0), rOffset + rLength); offset = paramBytes; for (var o = offset;offset < o + sPadding; ++offset) { dst[offset] = 0; } signature.copy(dst, offset, sOffset + Math.max(-sPadding, 0), sOffset + sLength); dst = dst.toString("base64"); dst = base64Url(dst); return dst; } function countPadding(buf, start, stop) { var padding = 0; while (start + padding < stop && buf[start + padding] === 0) { ++padding; } var needsSign = buf[start + padding] >= MAX_OCTET; if (needsSign) { --padding; } return padding; } function joseToDer(signature, alg) { signature = signatureAsBuffer(signature); var paramBytes = getParamBytesForAlg(alg); var signatureBytes = signature.length; if (signatureBytes !== paramBytes * 2) { throw new TypeError('"' + alg + '" signatures must be "' + paramBytes * 2 + '" bytes, saw "' + signatureBytes + '"'); } var rPadding = countPadding(signature, 0, paramBytes); var sPadding = countPadding(signature, paramBytes, signature.length); var rLength = paramBytes - rPadding; var sLength = paramBytes - sPadding; var rsBytes = 1 + 1 + rLength + 1 + 1 + sLength; var shortLength = rsBytes < MAX_OCTET; var dst = Buffer2.allocUnsafe((shortLength ? 2 : 3) + rsBytes); var offset = 0; dst[offset++] = ENCODED_TAG_SEQ; if (shortLength) { dst[offset++] = rsBytes; } else { dst[offset++] = MAX_OCTET | 1; dst[offset++] = rsBytes & 255; } dst[offset++] = ENCODED_TAG_INT; dst[offset++] = rLength; if (rPadding < 0) { dst[offset++] = 0; offset += signature.copy(dst, offset, 0, paramBytes); } else { offset += signature.copy(dst, offset, rPadding, paramBytes); } dst[offset++] = ENCODED_TAG_INT; dst[offset++] = sLength; if (sPadding < 0) { dst[offset++] = 0; signature.copy(dst, offset, paramBytes); } else { signature.copy(dst, offset, paramBytes + sPadding); } return dst; } module.exports = { derToJose, joseToDer }; }); // ../eve/node_modules/buffer-equal-constant-time/index.js var require_buffer_equal_constant_time = __commonJS((exports, module) => { var Buffer2 = __require("buffer").Buffer; var SlowBuffer = __require("buffer").SlowBuffer; module.exports = bufferEq; function bufferEq(a, b) { if (!Buffer2.isBuffer(a) || !Buffer2.isBuffer(b)) { return false; } if (a.length !== b.length) { return false; } var c = 0; for (var i = 0;i < a.length; i++) { c |= a[i] ^ b[i]; } return c === 0; } bufferEq.install = function() { Buffer2.prototype.equal = SlowBuffer.prototype.equal = function equal(that) { return bufferEq(this, that); }; }; var origBufEqual = Buffer2.prototype.equal; var origSlowBufEqual = SlowBuffer.prototype.equal; bufferEq.restore = function() { Buffer2.prototype.equal = origBufEqual; SlowBuffer.prototype.equal = origSlowBufEqual; }; }); // ../eve/node_modules/jwa/index.js var require_jwa = __commonJS((exports, module) => { var Buffer2 = require_safe_buffer().Buffer; var crypto2 = __require("crypto"); var formatEcdsa = require_ecdsa_sig_formatter(); var util = __require("util"); var MSG_INVALID_ALGORITHM = `"%s" is not a valid algorithm. Supported algorithms are: "HS256", "HS384", "HS512", "RS256", "RS384", "RS512", "PS256", "PS384", "PS512", "ES256", "ES384", "ES512" and "none".`; var MSG_INVALID_SECRET = "secret must be a string or buffer"; var MSG_INVALID_VERIFIER_KEY = "key must be a string or a buffer"; var MSG_INVALID_SIGNER_KEY = "key must be a string, a buffer or an object"; var supportsKeyObjects = typeof crypto2.createPublicKey === "function"; if (supportsKeyObjects) { MSG_INVALID_VERIFIER_KEY += " or a KeyObject"; MSG_INVALID_SECRET += "or a KeyObject"; } function checkIsPublicKey(key) { if (Buffer2.isBuffer(key)) { return; } if (typeof key === "string") { return; } if (!supportsKeyObjects) { throw typeError(MSG_INVALID_VERIFIER_KEY); } if (typeof key !== "object") { throw typeError(MSG_INVALID_VERIFIER_KEY); } if (typeof key.type !== "string") { throw typeError(MSG_INVALID_VERIFIER_KEY); } if (typeof key.asymmetricKeyType !== "string") { throw typeError(MSG_INVALID_VERIFIER_KEY); } if (typeof key.export !== "function") { throw typeError(MSG_INVALID_VERIFIER_KEY); } } function checkIsPrivateKey(key) { if (Buffer2.isBuffer(key)) { return; } if (typeof key === "string") { return; } if (typeof key === "object") { return; } throw typeError(MSG_INVALID_SIGNER_KEY); } function checkIsSecretKey(key) { if (Buffer2.isBuffer(key)) { return; } if (typeof key === "string") { return key; } if (!supportsKeyObjects) { throw typeError(MSG_INVALID_SECRET); } if (typeof key !== "object") { throw typeError(MSG_INVALID_SECRET); } if (key.type !== "secret") { throw typeError(MSG_INVALID_SECRET); } if (typeof key.export !== "function") { throw typeError(MSG_INVALID_SECRET); } } function fromBase64(base64) { return base64.replace(/=/g, "").replace(/\+/g, "-").replace(/\//g, "_"); } function toBase64(base64url) { base64url = base64url.toString(); var padding = 4 - base64url.length % 4; if (padding !== 4) { for (var i = 0;i < padding; ++i) { base64url += "="; } } return base64url.replace(/\-/g, "+").replace(/_/g, "/"); } function typeError(template) { var args = [].slice.call(arguments, 1); var errMsg = util.format.bind(util, template).apply(null, args); return new TypeError(errMsg); } function bufferOrString(obj) { return Buffer2.isBuffer(obj) || typeof obj === "string"; } function normalizeInput(thing) { if (!bufferOrString(thing)) thing = JSON.stringify(thing); return thing; } function createHmacSigner(bits) { return function sign(thing, secret) { checkIsSecretKey(secret); thing = normalizeInput(thing); var hmac = crypto2.createHmac("sha" + bits, secret); var sig = (hmac.update(thing), hmac.digest("base64")); return fromBase64(sig); }; } var bufferEqual; var timingSafeEqual = "timingSafeEqual" in crypto2 ? function timingSafeEqual(a, b) { if (a.byteLength !== b.byteLength) { return false; } return crypto2.timingSafeEqual(a, b); } : function timingSafeEqual(a, b) { if (!bufferEqual) { bufferEqual = require_buffer_equal_constant_time(); } return bufferEqual(a, b); }; function createHmacVerifier(bits) { return function verify(thing, signature, secret) { var computedSig = createHmacSigner(bits)(thing, secret); return timingSafeEqual(Buffer2.from(signature), Buffer2.from(computedSig)); }; } function createKeySigner(bits) { return function sign(thing, privateKey) { checkIsPrivateKey(privateKey); thing = normalizeInput(thing); var signer = crypto2.createSign("RSA-SHA" + bits); var sig = (signer.update(thing), signer.sign(privateKey, "base64")); return fromBase64(sig); }; } function createKeyVerifier(bits) { return function verify(thing, signature, publicKey) { checkIsPublicKey(publicKey); thing = normalizeInput(thing); signature = toBase64(signature); var verifier = crypto2.createVerify("RSA-SHA" + bits); verifier.update(thing); return verifier.verify(publicKey, signature, "base64"); }; } function createPSSKeySigner(bits) { return function sign(thing, privateKey) { checkIsPrivateKey(privateKey); thing = normalizeInput(thing); var signer = crypto2.createSign("RSA-SHA" + bits); var sig = (signer.update(thing), signer.sign({ key: privateKey, padding: crypto2.constants.RSA_PKCS1_PSS_PADDING, saltLength: crypto2.constants.RSA_PSS_SALTLEN_DIGEST }, "base64")); return fromBase64(sig); }; } function createPSSKeyVerifier(bits) { return function verify(thing, signature, publicKey) { checkIsPublicKey(publicKey); thing = normalizeInput(thing); signature = toBase64(signature); var verifier = crypto2.createVerify("RSA-SHA" + bits); verifier.update(thing); return verifier.verify({ key: publicKey, padding: crypto2.constants.RSA_PKCS1_PSS_PADDING, saltLength: crypto2.constants.RSA_PSS_SALTLEN_DIGEST }, signature, "base64"); }; } function createECDSASigner(bits) { var inner = createKeySigner(bits); return function sign() { var signature = inner.apply(null, arguments); signature = formatEcdsa.derToJose(signature, "ES" + bits); return signature; }; } function createECDSAVerifer(bits) { var inner = createKeyVerifier(bits); return function verify(thing, signature, publicKey) { signature = formatEcdsa.joseToDer(signature, "ES" + bits).toString("base64"); var result = inner(thing, signature, publicKey); return result; }; } function createNoneSigner() { return function sign() { return ""; }; } function createNoneVerifier() { return function verify(thing, signature) { return signature === ""; }; } module.exports = function jwa(algorithm) { var signerFactories = { hs: createHmacSigner, rs: createKeySigner, ps: createPSSKeySigner, es: createECDSASigner, none: createNoneSigner }; var verifierFactories = { hs: createHmacVerifier, rs: createKeyVerifier, ps: createPSSKeyVerifier, es: createECDSAVerifer, none: createNoneVerifier }; var match = algorithm.match(/^(RS|PS|ES|HS)(256|384|512)$|^(none)$/i); if (!match) throw typeError(MSG_INVALID_ALGORITHM, algorithm); var algo = (match[1] || match[3]).toLowerCase(); var bits = match[2]; return { sign: signerFactories[algo](bits), verify: verifierFactories[algo](bits) }; }; }); // ../eve/node_modules/jws/lib/tostring.js var require_tostring = __commonJS((exports, module) => { var Buffer2 = __require("buffer").Buffer; module.exports = function toString(obj) { if (typeof obj === "string") return obj; if (typeof obj === "number" || Buffer2.isBuffer(obj)) return obj.toString(); return JSON.stringify(obj); }; }); // ../eve/node_modules/jws/lib/sign-stream.js var require_sign_stream = __commonJS((exports, module) => { var Buffer2 = require_safe_buffer().Buffer; var DataStream = require_data_stream(); var jwa = require_jwa(); var Stream = __require("stream"); var toString = require_tostring(); var util = __require("util"); function base64url(string, encoding) { return Buffer2.from(string, encoding).toString("base64").replace(/=/g, "").replace(/\+/g, "-").replace(/\//g, "_"); } function jwsSecuredInput(header, payload, encoding) { encoding = encoding || "utf8"; var encodedHeader = base64url(toString(header), "binary"); var encodedPayload = base64url(toString(payload), encoding); return util.format("%s.%s", encodedHeader, encodedPayload); } function jwsSign(opts) { var header = opts.header; var payload = opts.payload; var secretOrKey = opts.secret || opts.privateKey; var encoding = opts.encoding; var algo = jwa(header.alg); var securedInput = jwsSecuredInput(header, payload, encoding); var signature = algo.sign(securedInput, secretOrKey); return util.format("%s.%s", securedInput, signature); } function SignStream(opts) { var secret = opts.secret || opts.privateKey || opts.key; var secretStream = new DataStream(secret); this.readable = true; this.header = opts.header; this.encoding = opts.encoding; this.secret = this.privateKey = this.key = secretStream; this.payload = new DataStream(opts.payload); this.secret.once("close", function() { if (!this.payload.writable && this.readable) this.sign(); }.bind(this)); this.payload.once("close", function() { if (!this.secret.writable && this.readable) this.sign(); }.bind(this)); } util.inherits(SignStream, Stream); SignStream.prototype.sign = function sign() { try { var signature = jwsSign({ header: this.header, payload: this.payload.buffer, secret: this.secret.buffer, encoding: this.encoding }); this.emit("done", signature); this.emit("data", signature); this.emit("end"); this.readable = false; return signature; } catch (e) { this.readable = false; this.emit("error", e); this.emit("close"); } }; SignStream.sign = jwsSign; module.exports = SignStream; }); // ../eve/node_modules/jws/lib/verify-stream.js var require_verify_stream = __commonJS((exports, module) => { var Buffer2 = require_safe_buffer().Buffer; var DataStream = require_data_stream(); var jwa = require_jwa(); var Stream = __require("stream"); var toString = require_tostring(); var util = __require("util"); var JWS_REGEX = /^[a-zA-Z0-9\-_]+?\.[a-zA-Z0-9\-_]+?\.([a-zA-Z0-9\-_]+)?$/; function isObject(thing) { return Object.prototype.toString.call(thing) === "[object Object]"; } function safeJsonParse(thing) { if (isObject(thing)) return thing; try { return JSON.parse(thing); } catch (e) { return; } } function headerFromJWS(jwsSig) { var encodedHeader = jwsSig.split(".", 1)[0]; return safeJsonParse(Buffer2.from(encodedHeader, "base64").toString("binary")); } function securedInputFromJWS(jwsSig) { return jwsSig.split(".", 2).join("."); } function signatureFromJWS(jwsSig) { return jwsSig.split(".")[2]; } function payloadFromJWS(jwsSig, encoding) { encoding = encoding || "utf8"; var payload = jwsSig.split(".")[1]; return Buffer2.from(payload, "base64").toString(encoding); } function isValidJws(string) { return JWS_REGEX.test(string) && !!headerFromJWS(string); } function jwsVerify(jwsSig, algorithm, secretOrKey) { if (!algorithm) { var err = new Error("Missing algorithm parameter for jws.verify"); err.code = "MISSING_ALGORITHM"; throw err; } jwsSig = toString(jwsSig); var signature = signatureFromJWS(jwsSig); var securedInput = securedInputFromJWS(jwsSig); var algo = jwa(algorithm); return algo.verify(securedInput, signature, secretOrKey); } function jwsDecode(jwsSig, opts) { opts = opts || {}; jwsSig = toString(jwsSig); if (!isValidJws(jwsSig)) return null; var header = headerFromJWS(jwsSig); if (!header) return null; var payload = payloadFromJWS(jwsSig); if (header.typ === "JWT" || opts.json) payload = JSON.parse(payload, opts.encoding); return { header, payload, signature: signatureFromJWS(jwsSig) }; } function VerifyStream(opts) { opts = opts || {}; var secretOrKey = opts.secret || opts.publicKey || opts.key; var secretStream = new DataStream(secretOrKey); this.readable = true; this.algorithm = opts.algorithm; this.encoding = opts.encoding; this.secret = this.publicKey = this.key = secretStream; this.signature = new DataStream(opts.signature); this.secret.once("close", function() { if (!this.signature.writable && this.readable) this.verify(); }.bind(this)); this.signature.once("close", function() { if (!this.secret.writable && this.readable) this.verify(); }.bind(this)); } util.inherits(VerifyStream, Stream); VerifyStream.prototype.verify = function verify() { try { var valid = jwsVerify(this.signature.buffer, this.algorithm, this.key.buffer); var obj = jwsDecode(this.signature.buffer, this.encoding); this.emit("done", valid, obj); this.emit("data", valid); this.emit("end"); this.readable = false; return valid; } catch (e) { this.readable = false; this.emit("error", e); this.emit("close"); } }; VerifyStream.decode = jwsDecode; VerifyStream.isValid = isValidJws; VerifyStream.verify = jwsVerify; module.exports = VerifyStream; }); // ../eve/node_modules/jws/index.js var require_jws = __commonJS((exports) => { var SignStream = require_sign_stream(); var VerifyStream = require_verify_stream(); var ALGORITHMS = [ "HS256", "HS384", "HS512", "RS256", "RS384", "RS512", "PS256", "PS384", "PS512", "ES256", "ES384", "ES512" ]; exports.ALGORITHMS = ALGORITHMS; exports.sign = SignStream.sign; exports.verify = VerifyStream.verify; exports.decode = VerifyStream.decode; exports.isValid = VerifyStream.isValid; exports.createSign = function createSign(opts) { return new SignStream(opts); }; exports.createVerify = function createVerify(opts) { return new VerifyStream(opts); }; }); // ../eve/node_modules/jsonwebtoken/decode.js var require_decode = __commonJS((exports, module) => { var jws = require_jws(); module.exports = function(jwt, options2) { options2 = options2 || {}; var decoded = jws.decode(jwt, options2); if (!decoded) { return null; } var payload = decoded.payload; if (typeof payload === "string") { try { var obj = JSON.parse(payload); if (obj !== null && typeof obj === "object") { payload = obj; } } catch (e) {} } if (options2.complete === true) { return { header: decoded.header, payload, signature: decoded.signature }; } return payload; }; }); // ../eve/node_modules/jsonwebtoken/lib/JsonWebTokenError.js var require_JsonWebTokenError = __commonJS((exports, module) => { var JsonWebTokenError = function(message, error) { Error.call(this, message); if (Error.captureStackTrace) { Error.captureStackTrace(this, this.constructor); } this.name = "JsonWebTokenError"; this.message = message; if (error) this.inner = error; }; JsonWebTokenError.prototype = Object.create(Error.prototype); JsonWebTokenError.prototype.constructor = JsonWebTokenError; module.exports = JsonWebTokenError; }); // ../eve/node_modules/jsonwebtoken/lib/NotBeforeError.js var require_NotBeforeError = __commonJS((exports, module) => { var JsonWebTokenError = require_JsonWebTokenError(); var NotBeforeError = function(message, date) { JsonWebTokenError.call(this, message); this.name = "NotBeforeError"; this.date = date; }; NotBeforeError.prototype = Object.create(JsonWebTokenError.prototype); NotBeforeError.prototype.constructor = NotBeforeError; module.exports = NotBeforeError; }); // ../eve/node_modules/jsonwebtoken/lib/TokenExpiredError.js var require_TokenExpiredError = __commonJS((exports, module) => { var JsonWebTokenError = require_JsonWebTokenError(); var TokenExpiredError = function(message, expiredAt) { JsonWebTokenError.call(this, message); this.name = "TokenExpiredError"; this.expiredAt = expiredAt; }; TokenExpiredError.prototype = Object.create(JsonWebTokenError.prototype); TokenExpiredError.prototype.constructor = TokenExpiredError; module.exports = TokenExpiredError; }); // ../eve/node_modules/ms/index.js var require_ms = __commonJS((exports, module) => { var s = 1000; var m = s * 60; var h = m * 60; var d = h * 24; var w = d * 7; var y = d * 365.25; module.exports = function(val, options2) { options2 = options2 || {}; var type = typeof val; if (type === "string" && val.length > 0) { return parse(val); } else if (type === "number" && isFinite(val)) { return options2.long ? fmtLong(val) : fmtShort(val); } throw new Error("val is not a non-empty string or a valid number. val=" + JSON.stringify(val)); }; function parse(str) { str = String(str); if (str.length > 100) { return; } var match = /^(-?(?:\d+)?\.?\d+) *(milliseconds?|msecs?|ms|seconds?|secs?|s|minutes?|mins?|m|hours?|hrs?|h|days?|d|weeks?|w|years?|yrs?|y)?$/i.exec(str); if (!match) { return; } var n = parseFloat(match[1]); var type = (match[2] || "ms").toLowerCase(); switch (type) { case "years": case "year": case "yrs": case "yr": case "y": return n * y; case "weeks": case "week": case "w": return n * w; case "days": case "day": case "d": return n * d; case "hours": case "hour": case "hrs": case "hr": case "h": return n * h; case "minutes": case "minute": case "mins": case "min": case "m": return n * m; case "seconds": case "second": case "secs": case "sec": case "s": return n * s; case "milliseconds": case "millisecond": case "msecs": case "msec": case "ms": return n; default: return; } } function fmtShort(ms) { var msAbs = Math.abs(ms); if (msAbs >= d) { return Math.round(ms / d) + "d"; } if (msAbs >= h) { return Math.round(ms / h) + "h"; } if (msAbs >= m) { return Math.round(ms / m) + "m"; } if (msAbs >= s) { return Math.round(ms / s) + "s"; } return ms + "ms"; } function fmtLong(ms) { var msAbs = Math.abs(ms); if (msAbs >= d) { return plural(ms, msAbs, d, "day"); } if (msAbs >= h) { return plural(ms, msAbs, h, "hour"); } if (msAbs >= m) { return plural(ms, msAbs, m, "minute"); } if (msAbs >= s) { return plural(ms, msAbs, s, "second"); } return ms + " ms"; } function plural(ms, msAbs, n, name) { var isPlural = msAbs >= n * 1.5; return Math.round(ms / n) + " " + name + (isPlural ? "s" : ""); } }); // ../eve/node_modules/jsonwebtoken/lib/timespan.js var require_timespan = __commonJS((exports, module) => { var ms = require_ms(); module.exports = function(time, iat) { var timestamp = iat || Math.floor(Date.now() / 1000); if (typeof time === "string") { var milliseconds = ms(time); if (typeof milliseconds === "undefined") { return; } return Math.floor(timestamp + milliseconds / 1000); } else if (typeof time === "number") { return timestamp + time; } else { return; } }; }); // ../eve/node_modules/semver/internal/constants.js var require_constants = __commonJS((exports, module) => { var SEMVER_SPEC_VERSION = "2.0.0"; var MAX_LENGTH = 256; var MAX_SAFE_INTEGER = Number.MAX_SAFE_INTEGER || 9007199254740991; var MAX_SAFE_COMPONENT_LENGTH = 16; var MAX_SAFE_BUILD_LENGTH = MAX_LENGTH - 6; var RELEASE_TYPES = [ "major", "premajor", "minor", "preminor", "patch", "prepatch", "prerelease" ]; module.exports = { MAX_LENGTH, MAX_SAFE_COMPONENT_LENGTH, MAX_SAFE_BUILD_LENGTH, MAX_SAFE_INTEGER, RELEASE_TYPES, SEMVER_SPEC_VERSION, FLAG_INCLUDE_PRERELEASE: 1, FLAG_LOOSE: 2 }; }); // ../eve/node_modules/semver/internal/debug.js var require_debug = __commonJS((exports, module) => { var debug = typeof process === "object" && process.env && process.env.NODE_DEBUG && /\bsemver\b/i.test(process.env.NODE_DEBUG) ? (...args) => console.error("SEMVER", ...args) : () => {}; module.exports = debug; }); // ../eve/node_modules/semver/internal/re.js var require_re = __commonJS((exports, module) => { var { MAX_SAFE_COMPONENT_LENGTH, MAX_SAFE_BUILD_LENGTH, MAX_LENGTH } = require_constants(); var debug = require_debug(); exports = module.exports = {}; var re = exports.re = []; var safeRe = exports.safeRe = []; var src = exports.src = []; var safeSrc = exports.safeSrc = []; var t = exports.t = {}; var R = 0; var LETTERDASHNUMBER = "[a-zA-Z0-9-]"; var safeRegexReplacements = [ ["\\s", 1], ["\\d", MAX_LENGTH], [LETTERDASHNUMBER, MAX_SAFE_BUILD_LENGTH] ]; var makeSafeRegex = (value) => { for (const [token, max] of safeRegexReplacements) { value = value.split(`${token}*`).join(`${token}{0,${max}}`).split(`${token}+`).join(`${token}{1,${max}}`); } return value; }; var createToken = (name, value, isGlobal) => { const safe = makeSafeRegex(value); const index = R++; debug(name, index, value); t[name] = index; src[index] = value; safeSrc[index] = safe; re[index] = new RegExp(value, isGlobal ? "g" : undefined); safeRe[index] = new RegExp(safe, isGlobal ? "g" : undefined); }; createToken("NUMERICIDENTIFIER", "0|[1-9]\\d*"); createToken("NUMERICIDENTIFIERLOOSE", "\\d+"); createToken("NONNUMERICIDENTIFIER", `\\d*[a-zA-Z-]${LETTERDASHNUMBER}*`); createToken("MAINVERSION", `(${src[t.NUMERICIDENTIFIER]})\\.` + `(${src[t.NUMERICIDENTIFIER]})\\.` + `(${src[t.NUMERICIDENTIFIER]})`); createToken("MAINVERSIONLOOSE", `(${src[t.NUMERICIDENTIFIERLOOSE]})\\.` + `(${src[t.NUMERICIDENTIFIERLOOSE]})\\.` + `(${src[t.NUMERICIDENTIFIERLOOSE]})`); createToken("PRERELEASEIDENTIFIER", `(?:${src[t.NONNUMERICIDENTIFIER]}|${src[t.NUMERICIDENTIFIER]})`); createToken("PRERELEASEIDENTIFIERLOOSE", `(?:${src[t.NONNUMERICIDENTIFIER]}|${src[t.NUMERICIDENTIFIERLOOSE]})`); createToken("PRERELEASE", `(?:-(${src[t.PRERELEASEIDENTIFIER]}(?:\\.${src[t.PRERELEASEIDENTIFIER]})*))`); createToken("PRERELEASELOOSE", `(?:-?(${src[t.PRERELEASEIDENTIFIERLOOSE]}(?:\\.${src[t.PRERELEASEIDENTIFIERLOOSE]})*))`); createToken("BUILDIDENTIFIER", `${LETTERDASHNUMBER}+`); createToken("BUILD", `(?:\\+(${src[t.BUILDIDENTIFIER]}(?:\\.${src[t.BUILDIDENTIFIER]})*))`); createToken("FULLPLAIN", `v?${src[t.MAINVERSION]}${src[t.PRERELEASE]}?${src[t.BUILD]}?`); createToken("FULL", `^${src[t.FULLPLAIN]}$`); createToken("LOOSEPLAIN", `[v=\\s]*${src[t.MAINVERSIONLOOSE]}${src[t.PRERELEASELOOSE]}?${src[t.BUILD]}?`); createToken("LOOSE", `^${src[t.LOOSEPLAIN]}$`); createToken("GTLT", "((?:<|>)?=?)"); createToken("XRANGEIDENTIFIERLOOSE", `${src[t.NUMERICIDENTIFIERLOOSE]}|x|X|\\*`); createToken("XRANGEIDENTIFIER", `${src[t.NUMERICIDENTIFIER]}|x|X|\\*`); createToken("XRANGEPLAIN", `[v=\\s]*(${src[t.XRANGEIDENTIFIER]})` + `(?:\\.(${src[t.XRANGEIDENTIFIER]})` + `(?:\\.(${src[t.XRANGEIDENTIFIER]})` + `(?:${src[t.PRERELEASE]})?${src[t.BUILD]}?` + `)?)?`); createToken("XRANGEPLAINLOOSE", `[v=\\s]*(${src[t.XRANGEIDENTIFIERLOOSE]})` + `(?:\\.(${src[t.XRANGEIDENTIFIERLOOSE]})` + `(?:\\.(${src[t.XRANGEIDENTIFIERLOOSE]})` + `(?:${src[t.PRERELEASELOOSE]})?${src[t.BUILD]}?` + `)?)?`); createToken("XRANGE", `^${src[t.GTLT]}\\s*${src[t.XRANGEPLAIN]}$`); createToken("XRANGELOOSE", `^${src[t.GTLT]}\\s*${src[t.XRANGEPLAINLOOSE]}$`); createToken("COERCEPLAIN", `${"(^|[^\\d])" + "(\\d{1,"}${MAX_SAFE_COMPONENT_LENGTH}})` + `(?:\\.(\\d{1,${MAX_SAFE_COMPONENT_LENGTH}}))?` + `(?:\\.(\\d{1,${MAX_SAFE_COMPONENT_LENGTH}}))?`); createToken("COERCE", `${src[t.COERCEPLAIN]}(?:$|[^\\d])`); createToken("COERCEFULL", src[t.COERCEPLAIN] + `(?:${src[t.PRERELEASE]})?` + `(?:${src[t.BUILD]})?` + `(?:$|[^\\d])`); createToken("COERCERTL", src[t.COERCE], true); createToken("COERCERTLFULL", src[t.COERCEFULL], true); createToken("LONETILDE", "(?:~>?)"); createToken("TILDETRIM", `(\\s*)${src[t.LONETILDE]}\\s+`, true); exports.tildeTrimReplace = "$1~"; createToken("TILDE", `^${src[t.LONETILDE]}${src[t.XRANGEPLAIN]}$`); createToken("TILDELOOSE", `^${src[t.LONETILDE]}${src[t.XRANGEPLAINLOOSE]}$`); createToken("LONECARET", "(?:\\^)"); createToken("CARETTRIM", `(\\s*)${src[t.LONECARET]}\\s+`, true); exports.caretTrimReplace = "$1^"; createToken("CARET", `^${src[t.LONECARET]}${src[t.XRANGEPLAIN]}$`); createToken("CARETLOOSE", `^${src[t.LONECARET]}${src[t.XRANGEPLAINLOOSE]}$`); createToken("COMPARATORLOOSE", `^${src[t.GTLT]}\\s*(${src[t.LOOSEPLAIN]})$|^$`); createToken("COMPARATOR", `^${src[t.GTLT]}\\s*(${src[t.FULLPLAIN]})$|^$`); createToken("COMPARATORTRIM", `(\\s*)${src[t.GTLT]}\\s*(${src[t.LOOSEPLAIN]}|${src[t.XRANGEPLAIN]})`, true); exports.comparatorTrimReplace = "$1$2$3"; createToken("HYPHENRANGE", `^\\s*(${src[t.XRANGEPLAIN]})` + `\\s+-\\s+` + `(${src[t.XRANGEPLAIN]})` + `\\s*$`); createToken("HYPHENRANGELOOSE", `^\\s*(${src[t.XRANGEPLAINLOOSE]})` + `\\s+-\\s+` + `(${src[t.XRANGEPLAINLOOSE]})` + `\\s*$`); createToken("STAR", "(<|>)?=?\\s*\\*"); createToken("GTE0", "^\\s*>=\\s*0\\.0\\.0\\s*$"); createToken("GTE0PRE", "^\\s*>=\\s*0\\.0\\.0-0\\s*$"); }); // ../eve/node_modules/semver/internal/parse-options.js var require_parse_options = __commonJS((exports, module) => { var looseOption = Object.freeze({ loose: true }); var emptyOpts = Object.freeze({}); var parseOptions = (options2) => { if (!options2) { return emptyOpts; } if (typeof options2 !== "object") { return looseOption; } return options2; }; module.exports = parseOptions; }); // ../eve/node_modules/semver/internal/identifiers.js var require_identifiers = __commonJS((exports, module) => { var numeric = /^[0-9]+$/; var compareIdentifiers = (a, b) => { const anum = numeric.test(a); const bnum = numeric.test(b); if (anum && bnum) { a = +a; b = +b; } return a === b ? 0 : anum && !bnum ? -1 : bnum && !anum ? 1 : a < b ? -1 : 1; }; var rcompareIdentifiers = (a, b) => compareIdentifiers(b, a); module.exports = { compareIdentifiers, rcompareIdentifiers }; }); // ../eve/node_modules/semver/classes/semver.js var require_semver = __commonJS((exports, module) => { var debug = require_debug(); var { MAX_LENGTH, MAX_SAFE_INTEGER } = require_constants(); var { safeRe: re, t } = require_re(); var parseOptions = require_parse_options(); var { compareIdentifiers } = require_identifiers(); class SemVer { constructor(version, options2) { options2 = parseOptions(options2); if (version instanceof SemVer) { if (version.loose === !!options2.loose && version.includePrerelease === !!options2.includePrerelease) { return version; } else { version = version.version; } } else if (typeof version !== "string") { throw new TypeError(`Invalid version. Must be a string. Got type "${typeof version}".`); } if (version.length > MAX_LENGTH) { throw new TypeError(`version is longer than ${MAX_LENGTH} characters`); } debug("SemVer", version, options2); this.options = options2; this.loose = !!options2.loose; this.includePrerelease = !!options2.includePrerelease; const m = version.trim().match(options2.loose ? re[t.LOOSE] : re[t.FULL]); if (!m) { throw new TypeError(`Invalid Version: ${version}`); } this.raw = version; this.major = +m[1]; this.minor = +m[2]; this.patch = +m[3]; if (this.major > MAX_SAFE_INTEGER || this.major < 0) { throw new TypeError("Invalid major version"); } if (this.minor > MAX_SAFE_INTEGER || this.minor < 0) { throw new TypeError("Invalid minor version"); } if (this.patch > MAX_SAFE_INTEGER || this.patch < 0) { throw new TypeError("Invalid patch version"); } if (!m[4]) { this.prerelease = []; } else { this.prerelease = m[4].split(".").map((id) => { if (/^[0-9]+$/.test(id)) { const num = +id; if (num >= 0 && num < MAX_SAFE_INTEGER) { return num; } } return id; }); } this.build = m[5] ? m[5].split(".") : []; this.format(); } format() { this.version = `${this.major}.${this.minor}.${this.patch}`; if (this.prerelease.length) { this.version += `-${this.prerelease.join(".")}`; } return this.version; } toString() { return this.version; } compare(other) { debug("SemVer.compare", this.version, this.options, other); if (!(other instanceof SemVer)) { if (typeof other === "string" && other === this.version) { return 0; } other = new SemVer(other, this.options); } if (other.version === this.version) { return 0; } return this.compareMain(other) || this.comparePre(other); } compareMain(other) { if (!(other instanceof SemVer)) { other = new SemVer(other, this.options); } return compareIdentifiers(this.major, other.major) || compareIdentifiers(this.minor, other.minor) || compareIdentifiers(this.patch, other.patch); } comparePre(other) { if (!(other instanceof SemVer)) { other = new SemVer(other, this.options); } if (this.prerelease.length && !other.prerelease.length) { return -1; } else if (!this.prerelease.length && other.prerelease.length) { return 1; } else if (!this.prerelease.length && !other.prerelease.length) { return 0; } let i = 0; do { const a = this.prerelease[i]; const b = other.prerelease[i]; debug("prerelease compare", i, a, b); if (a === undefined && b === undefined) { return 0; } else if (b === undefined) { return 1; } else if (a === undefined) { return -1; } else if (a === b) { continue; } else { return compareIdentifiers(a, b); } } while (++i); } compareBuild(other) { if (!(other instanceof SemVer)) { other = new SemVer(other, this.options); } let i = 0; do { const a = this.build[i]; const b = other.build[i]; debug("build compare", i, a, b); if (a === undefined && b === undefined) { return 0; } else if (b === undefined) { return 1; } else if (a === undefined) { return -1; } else if (a === b) { continue; } else { return compareIdentifiers(a, b); } } while (++i); } inc(release, identifier, identifierBase) { if (release.startsWith("pre")) { if (!identifier && identifierBase === false) { throw new Error("invalid increment argument: identifier is empty"); } if (identifier) { const match = `-${identifier}`.match(this.options.loose ? re[t.PRERELEASELOOSE] : re[t.PRERELEASE]); if (!match || match[1] !== identifier) { throw new Error(`invalid identifier: ${identifier}`); } } } switch (release) { case "premajor": this.prerelease.length = 0; this.patch = 0; this.minor = 0; this.major++; this.inc("pre", identifier, identifierBase); break; case "preminor": this.prerelease.length = 0; this.patch = 0; this.minor++; this.inc("pre", identifier, identifierBase); break; case "prepatch": this.prerelease.length = 0; this.inc("patch", identifier, identifierBase); this.inc("pre", identifier, identifierBase); break; case "prerelease": if (this.prerelease.length === 0) { this.inc("patch", identifier, identifierBase); } this.inc("pre", identifier, identifierBase); break; case "release": if (this.prerelease.length === 0) { throw new Error(`version ${this.raw} is not a prerelease`); } this.prerelease.length = 0; break; case "major": if (this.minor !== 0 || this.patch !== 0 || this.prerelease.length === 0) { this.major++; } this.minor = 0; this.patch = 0; this.prerelease = []; break; case "minor": if (this.patch !== 0 || this.prerelease.length === 0) { this.minor++; } this.patch = 0; this.prerelease = []; break; case "patch": if (this.prerelease.length === 0) { this.patch++; } this.prerelease = []; break; case "pre": { const base = Number(identifierBase) ? 1 : 0; if (this.prerelease.length === 0) { this.prerelease = [base]; } else { let i = this.prerelease.length; while (--i >= 0) { if (typeof this.prerelease[i] === "number") { this.prerelease[i]++; i = -2; } } if (i === -1) { if (identifier === this.prerelease.join(".") && identifierBase === false) { throw new Error("invalid increment argument: identifier already exists"); } this.prerelease.push(base); } } if (identifier) { let prerelease = [identifier, base]; if (identifierBase === false) { prerelease = [identifier]; } if (compareIdentifiers(this.prerelease[0], identifier) === 0) { if (isNaN(this.prerelease[1])) { this.prerelease = prerelease; } } else { this.prerelease = prerelease; } } break; } default: throw new Error(`invalid increment argument: ${release}`); } this.raw = this.format(); if (this.build.length) { this.raw += `+${this.build.join(".")}`; } return this; } } module.exports = SemVer; }); // ../eve/node_modules/semver/functions/parse.js var require_parse = __commonJS((exports, module) => { var SemVer = require_semver(); var parse = (version, options2, throwErrors = false) => { if (version instanceof SemVer) { return version; } try { return new SemVer(version, options2); } catch (er) { if (!throwErrors) { return null; } throw er; } }; module.exports = parse; }); // ../eve/node_modules/semver/functions/valid.js var require_valid = __commonJS((exports, module) => { var parse = require_parse(); var valid = (version, options2) => { const v = parse(version, options2); return v ? v.version : null; }; module.exports = valid; }); // ../eve/node_modules/semver/functions/clean.js var require_clean = __commonJS((exports, module) => { var parse = require_parse(); var clean = (version, options2) => { const s = parse(version.trim().replace(/^[=v]+/, ""), options2); return s ? s.version : null; }; module.exports = clean; }); // ../eve/node_modules/semver/functions/inc.js var require_inc = __commonJS((exports, module) => { var SemVer = require_semver(); var inc = (version, release, options2, identifier, identifierBase) => { if (typeof options2 === "string") { identifierBase = identifier; identifier = options2; options2 = undefined; } try { return new SemVer(version instanceof SemVer ? version.version : version, options2).inc(release, identifier, identifierBase).version; } catch (er) { return null; } }; module.exports = inc; }); // ../eve/node_modules/semver/functions/diff.js var require_diff = __commonJS((exports, module) => { var parse = require_parse(); var diff = (version1, version2) => { const v1 = parse(version1, null, true); const v2 = parse(version2, null, true); const comparison = v1.compare(v2); if (comparison === 0) { return null; } const v1Higher = comparison > 0; const highVersion = v1Higher ? v1 : v2; const lowVersion = v1Higher ? v2 : v1; const highHasPre = !!highVersion.prerelease.length; const lowHasPre = !!lowVersion.prerelease.length; if (lowHasPre && !highHasPre) { if (!lowVersion.patch && !lowVersion.minor) { return "major"; } if (lowVersion.compareMain(highVersion) === 0) { if (lowVersion.minor && !lowVersion.patch) { return "minor"; } return "patch"; } } const prefix = highHasPre ? "pre" : ""; if (v1.major !== v2.major) { return prefix + "major"; } if (v1.minor !== v2.minor) { return prefix + "minor"; } if (v1.patch !== v2.patch) { return prefix + "patch"; } return "prerelease"; }; module.exports = diff; }); // ../eve/node_modules/semver/functions/major.js var require_major = __commonJS((exports, module) => { var SemVer = require_semver(); var major = (a, loose) => new SemVer(a, loose).major; module.exports = major; }); // ../eve/node_modules/semver/functions/minor.js var require_minor = __commonJS((exports, module) => { var SemVer = require_semver(); var minor = (a, loose) => new SemVer(a, loose).minor; module.exports = minor; }); // ../eve/node_modules/semver/functions/patch.js var require_patch = __commonJS((exports, module) => { var SemVer = require_semver(); var patch = (a, loose) => new SemVer(a, loose).patch; module.exports = patch; }); // ../eve/node_modules/semver/functions/prerelease.js var require_prerelease = __commonJS((exports, module) => { var parse = require_parse(); var prerelease = (version, options2) => { const parsed = parse(version, options2); return parsed && parsed.prerelease.length ? parsed.prerelease : null; }; module.exports = prerelease; }); // ../eve/node_modules/semver/functions/compare.js var require_compare = __commonJS((exports, module) => { var SemVer = require_semver(); var compare = (a, b, loose) => new SemVer(a, loose).compare(new SemVer(b, loose)); module.exports = compare; }); // ../eve/node_modules/semver/functions/rcompare.js var require_rcompare = __commonJS((exports, module) => { var compare = require_compare(); var rcompare = (a, b, loose) => compare(b, a, loose); module.exports = rcompare; }); // ../eve/node_modules/semver/functions/compare-loose.js var require_compare_loose = __commonJS((exports, module) => { var compare = require_compare(); var compareLoose = (a, b) => compare(a, b, true); module.exports = compareLoose; }); // ../eve/node_modules/semver/functions/compare-build.js var require_compare_build = __commonJS((exports, module) => { var SemVer = require_semver(); var compareBuild = (a, b, loose) => { const versionA = new SemVer(a, loose); const versionB = new SemVer(b, loose); return versionA.compare(versionB) || versionA.compareBuild(versionB); }; module.exports = compareBuild; }); // ../eve/node_modules/semver/functions/sort.js var require_sort = __commonJS((exports, module) => { var compareBuild = require_compare_build(); var sort = (list, loose) => list.sort((a, b) => compareBuild(a, b, loose)); module.exports = sort; }); // ../eve/node_modules/semver/functions/rsort.js var require_rsort = __commonJS((exports, module) => { var compareBuild = require_compare_build(); var rsort = (list, loose) => list.sort((a, b) => compareBuild(b, a, loose)); module.exports = rsort; }); // ../eve/node_modules/semver/functions/gt.js var require_gt = __commonJS((exports, module) => { var compare = require_compare(); var gt = (a, b, loose) => compare(a, b, loose) > 0; module.exports = gt; }); // ../eve/node_modules/semver/functions/lt.js var require_lt = __commonJS((exports, module) => { var compare = require_compare(); var lt = (a, b, loose) => compare(a, b, loose) < 0; module.exports = lt; }); // ../eve/node_modules/semver/functions/eq.js var require_eq = __commonJS((exports, module) => { var compare = require_compare(); var eq = (a, b, loose) => compare(a, b, loose) === 0; module.exports = eq; }); // ../eve/node_modules/semver/functions/neq.js var require_neq = __commonJS((exports, module) => { var compare = require_compare(); var neq = (a, b, loose) => compare(a, b, loose) !== 0; module.exports = neq; }); // ../eve/node_modules/semver/functions/gte.js var require_gte = __commonJS((exports, module) => { var compare = require_compare(); var gte = (a, b, loose) => compare(a, b, loose) >= 0; module.exports = gte; }); // ../eve/node_modules/semver/functions/lte.js var require_lte = __commonJS((exports, module) => { var compare = require_compare(); var lte = (a, b, loose) => compare(a, b, loose) <= 0; module.exports = lte; }); // ../eve/node_modules/semver/functions/cmp.js var require_cmp = __commonJS((exports, module) => { var eq = require_eq(); var neq = require_neq(); var gt = require_gt(); var gte = require_gte(); var lt = require_lt(); var lte = require_lte(); var cmp = (a, op, b, loose) => { switch (op) { case "===": if (typeof a === "object") { a = a.version; } if (typeof b === "object") { b = b.version; } return a === b; case "!==": if (typeof a === "object") { a = a.version; } if (typeof b === "object") { b = b.version; } return a !== b; case "": case "=": case "==": return eq(a, b, loose); case "!=": return neq(a, b, loose); case ">": return gt(a, b, loose); case ">=": return gte(a, b, loose); case "<": return lt(a, b, loose); case "<=": return lte(a, b, loose); default: throw new TypeError(`Invalid operator: ${op}`); } }; module.exports = cmp; }); // ../eve/node_modules/semver/functions/coerce.js var require_coerce = __commonJS((exports, module) => { var SemVer = require_semver(); var parse = require_parse(); var { safeRe: re, t } = require_re(); var coerce = (version, options2) => { if (version instanceof SemVer) { return version; } if (typeof version === "number") { version = String(version); } if (typeof version !== "string") { return null; } options2 = options2 || {}; let match = null; if (!options2.rtl) { match = version.match(options2.includePrerelease ? re[t.COERCEFULL] : re[t.COERCE]); } else { const coerceRtlRegex = options2.includePrerelease ? re[t.COERCERTLFULL] : re[t.COERCERTL]; let next; while ((next = coerceRtlRegex.exec(version)) && (!match || match.index + match[0].length !== version.length)) { if (!match || next.index + next[0].length !== match.index + match[0].length) { match = next; } coerceRtlRegex.lastIndex = next.index + next[1].length + next[2].length; } coerceRtlRegex.lastIndex = -1; } if (match === null) { return null; } const major = match[2]; const minor = match[3] || "0"; const patch = match[4] || "0"; const prerelease = options2.includePrerelease && match[5] ? `-${match[5]}` : ""; const build = options2.includePrerelease && match[6] ? `+${match[6]}` : ""; return parse(`${major}.${minor}.${patch}${prerelease}${build}`, options2); }; module.exports = coerce; }); // ../eve/node_modules/semver/internal/lrucache.js var require_lrucache = __commonJS((exports, module) => { class LRUCache { constructor() { this.max = 1000; this.map = new Map; } get(key) { const value = this.map.get(key); if (value === undefined) { return; } else { this.map.delete(key); this.map.set(key, value); return value; } } delete(key) { return this.map.delete(key); } set(key, value) { const deleted = this.delete(key); if (!deleted && value !== undefined) { if (this.map.size >= this.max) { const firstKey = this.map.keys().next().value; this.delete(firstKey); } this.map.set(key, value); } return this; } } module.exports = LRUCache; }); // ../eve/node_modules/semver/classes/range.js var require_range = __commonJS((exports, module) => { var SPACE_CHARACTERS = /\s+/g; class Range { constructor(range, options2) { options2 = parseOptions(options2); if (range instanceof Range) { if (range.loose === !!options2.loose && range.includePrerelease === !!options2.includePrerelease) { return range; } else { return new Range(range.raw, options2); } } if (range instanceof Comparator) { this.raw = range.value; this.set = [[range]]; this.formatted = undefined; return this; } this.options = options2; this.loose = !!options2.loose; this.includePrerelease = !!options2.includePrerelease; this.raw = range.trim().replace(SPACE_CHARACTERS, " "); this.set = this.raw.split("||").map((r) => this.parseRange(r.trim())).filter((c) => c.length); if (!this.set.length) { throw new TypeError(`Invalid SemVer Range: ${this.raw}`); } if (this.set.length > 1) { const first = this.set[0]; this.set = this.set.filter((c) => !isNullSet(c[0])); if (this.set.length === 0) { this.set = [first]; } else if (this.set.length > 1) { for (const c of this.set) { if (c.length === 1 && isAny(c[0])) { this.set = [c]; break; } } } } this.formatted = undefined; } get range() { if (this.formatted === undefined) { this.formatted = ""; for (let i = 0;i < this.set.length; i++) { if (i > 0) { this.formatted += "||"; } const comps = this.set[i]; for (let k = 0;k < comps.length; k++) { if (k > 0) { this.formatted += " "; } this.formatted += comps[k].toString().trim(); } } } return this.formatted; } format() { return this.range; } toString() { return this.range; } parseRange(range) { const memoOpts = (this.options.includePrerelease && FLAG_INCLUDE_PRERELEASE) | (this.options.loose && FLAG_LOOSE); const memoKey = memoOpts + ":" + range; const cached = cache.get(memoKey); if (cached) { return cached; } const loose = this.options.loose; const hr = loose ? re[t.HYPHENRANGELOOSE] : re[t.HYPHENRANGE]; range = range.replace(hr, hyphenReplace(this.options.includePrerelease)); debug("hyphen replace", range); range = range.replace(re[t.COMPARATORTRIM], comparatorTrimReplace); debug("comparator trim", range); range = range.replace(re[t.TILDETRIM], tildeTrimReplace); debug("tilde trim", range); range = range.replace(re[t.CARETTRIM], caretTrimReplace); debug("caret trim", range); let rangeList = range.split(" ").map((comp) => parseComparator(comp, this.options)).join(" ").split(/\s+/).map((comp) => replaceGTE0(comp, this.options)); if (loose) { rangeList = rangeList.filter((comp) => { debug("loose invalid filter", comp, this.options); return !!comp.match(re[t.COMPARATORLOOSE]); }); } debug("range list", rangeList); const rangeMap = new Map; const comparators = rangeList.map((comp) => new Comparator(comp, this.options)); for (const comp of comparators) { if (isNullSet(comp)) { return [comp]; } rangeMap.set(comp.value, comp); } if (rangeMap.size > 1 && rangeMap.has("")) { rangeMap.delete(""); } const result = [...rangeMap.values()]; cache.set(memoKey, result); return result; } intersects(range, options2) { if (!(range instanceof Range)) { throw new TypeError("a Range is required"); } return this.set.some((thisComparators) => { return isSatisfiable(thisComparators, options2) && range.set.some((rangeComparators) => { return isSatisfiable(rangeComparators, options2) && thisComparators.every((thisComparator) => { return rangeComparators.every((rangeComparator) => { return thisComparator.intersects(rangeComparator, options2); }); }); }); }); } test(version) { if (!version) { return false; } if (typeof version === "string") { try { version = new SemVer(version, this.options); } catch (er) { return false; } } for (let i = 0;i < this.set.length; i++) { if (testSet(this.set[i], version, this.options)) { return true; } } return false; } } module.exports = Range; var LRU = require_lrucache(); var cache = new LRU; var parseOptions = require_parse_options(); var Comparator = require_comparator(); var debug = require_debug(); var SemVer = require_semver(); var { safeRe: re, t, comparatorTrimReplace, tildeTrimReplace, caretTrimReplace } = require_re(); var { FLAG_INCLUDE_PRERELEASE, FLAG_LOOSE } = require_constants(); var isNullSet = (c) => c.value === "<0.0.0-0"; var isAny = (c) => c.value === ""; var isSatisfiable = (comparators, options2) => { let result = true; const remainingComparators = comparators.slice(); let testComparator = remainingComparators.pop(); while (result && remainingComparators.length) { result = remainingComparators.every((otherComparator) => { return testComparator.intersects(otherComparator, options2); }); testComparator = remainingComparators.pop(); } return result; }; var parseComparator = (comp, options2) => { debug("comp", comp, options2); comp = replaceCarets(comp, options2); debug("caret", comp); comp = replaceTildes(comp, options2); debug("tildes", comp); comp = replaceXRanges(comp, options2); debug("xrange", comp); comp = replaceStars(comp, options2); debug("stars", comp); return comp; }; var isX = (id) => !id || id.toLowerCase() === "x" || id === "*"; var replaceTildes = (comp, options2) => { return comp.trim().split(/\s+/).map((c) => replaceTilde(c, options2)).join(" "); }; var replaceTilde = (comp, options2) => { const r = options2.loose ? re[t.TILDELOOSE] : re[t.TILDE]; return comp.replace(r, (_, M, m, p, pr) => { debug("tilde", comp, _, M, m, p, pr); let ret; if (isX(M)) { ret = ""; } else if (isX(m)) { ret = `>=${M}.0.0 <${+M + 1}.0.0-0`; } else if (isX(p)) { ret = `>=${M}.${m}.0 <${M}.${+m + 1}.0-0`; } else if (pr) { debug("replaceTilde pr", pr); ret = `>=${M}.${m}.${p}-${pr} <${M}.${+m + 1}.0-0`; } else { ret = `>=${M}.${m}.${p} <${M}.${+m + 1}.0-0`; } debug("tilde return", ret); return ret; }); }; var replaceCarets = (comp, options2) => { return comp.trim().split(/\s+/).map((c) => replaceCaret(c, options2)).join(" "); }; var replaceCaret = (comp, options2) => { debug("caret", comp, options2); const r = options2.loose ? re[t.CARETLOOSE] : re[t.CARET]; const z = options2.includePrerelease ? "-0" : ""; return comp.replace(r, (_, M, m, p, pr) => { debug("caret", comp, _, M, m, p, pr); let ret; if (isX(M)) { ret = ""; } else if (isX(m)) { ret = `>=${M}.0.0${z} <${+M + 1}.0.0-0`; } else if (isX(p)) { if (M === "0") { ret = `>=${M}.${m}.0${z} <${M}.${+m + 1}.0-0`; } else { ret = `>=${M}.${m}.0${z} <${+M + 1}.0.0-0`; } } else if (pr) { debug("replaceCaret pr", pr); if (M === "0") { if (m === "0") { ret = `>=${M}.${m}.${p}-${pr} <${M}.${m}.${+p + 1}-0`; } else { ret = `>=${M}.${m}.${p}-${pr} <${M}.${+m + 1}.0-0`; } } else { ret = `>=${M}.${m}.${p}-${pr} <${+M + 1}.0.0-0`; } } else { debug("no pr"); if (M === "0") { if (m === "0") { ret = `>=${M}.${m}.${p}${z} <${M}.${m}.${+p + 1}-0`; } else { ret = `>=${M}.${m}.${p}${z} <${M}.${+m + 1}.0-0`; } } else { ret = `>=${M}.${m}.${p} <${+M + 1}.0.0-0`; } } debug("caret return", ret); return ret; }); }; var replaceXRanges = (comp, options2) => { debug("replaceXRanges", comp, options2); return comp.split(/\s+/).map((c) => replaceXRange(c, options2)).join(" "); }; var replaceXRange = (comp, options2) => { comp = comp.trim(); const r = options2.loose ? re[t.XRANGELOOSE] : re[t.XRANGE]; return comp.replace(r, (ret, gtlt, M, m, p, pr) => { debug("xRange", comp, ret, gtlt, M, m, p, pr); const xM = isX(M); const xm = xM || isX(m); const xp = xm || isX(p); const anyX = xp; if (gtlt === "=" && anyX) { gtlt = ""; } pr = options2.includePrerelease ? "-0" : ""; if (xM) { if (gtlt === ">" || gtlt === "<") { ret = "<0.0.0-0"; } else { ret = "*"; } } else if (gtlt && anyX) { if (xm) { m = 0; } p = 0; if (gtlt === ">") { gtlt = ">="; if (xm) { M = +M + 1; m = 0; p = 0; } else { m = +m + 1; p = 0; } } else if (gtlt === "<=") { gtlt = "<"; if (xm) { M = +M + 1; } else { m = +m + 1; } } if (gtlt === "<") { pr = "-0"; } ret = `${gtlt + M}.${m}.${p}${pr}`; } else if (xm) { ret = `>=${M}.0.0${pr} <${+M + 1}.0.0-0`; } else if (xp) { ret = `>=${M}.${m}.0${pr} <${M}.${+m + 1}.0-0`; } debug("xRange return", ret); return ret; }); }; var replaceStars = (comp, options2) => { debug("replaceStars", comp, options2); return comp.trim().replace(re[t.STAR], ""); }; var replaceGTE0 = (comp, options2) => { debug("replaceGTE0", comp, options2); return comp.trim().replace(re[options2.includePrerelease ? t.GTE0PRE : t.GTE0], ""); }; var hyphenReplace = (incPr) => ($0, from, fM, fm, fp, fpr, fb, to, tM, tm, tp, tpr) => { if (isX(fM)) { from = ""; } else if (isX(fm)) { from = `>=${fM}.0.0${incPr ? "-0" : ""}`; } else if (isX(fp)) { from = `>=${fM}.${fm}.0${incPr ? "-0" : ""}`; } else if (fpr) { from = `>=${from}`; } else { from = `>=${from}${incPr ? "-0" : ""}`; } if (isX(tM)) { to = ""; } else if (isX(tm)) { to = `<${+tM + 1}.0.0-0`; } else if (isX(tp)) { to = `<${tM}.${+tm + 1}.0-0`; } else if (tpr) { to = `<=${tM}.${tm}.${tp}-${tpr}`; } else if (incPr) { to = `<${tM}.${tm}.${+tp + 1}-0`; } else { to = `<=${to}`; } return `${from} ${to}`.trim(); }; var testSet = (set, version, options2) => { for (let i = 0;i < set.length; i++) { if (!set[i].test(version)) { return false; } } if (version.prerelease.length && !options2.includePrerelease) { for (let i = 0;i < set.length; i++) { debug(set[i].semver); if (set[i].semver === Comparator.ANY) { continue; } if (set[i].semver.prerelease.length > 0) { const allowed = set[i].semver; if (allowed.major === version.major && allowed.minor === version.minor && allowed.patch === version.patch) { return true; } } } return false; } return true; }; }); // ../eve/node_modules/semver/classes/comparator.js var require_comparator = __commonJS((exports, module) => { var ANY = Symbol("SemVer ANY"); class Comparator { static get ANY() { return ANY; } constructor(comp, options2) { options2 = parseOptions(options2); if (comp instanceof Comparator) { if (comp.loose === !!options2.loose) { return comp; } else { comp = comp.value; } } comp = comp.trim().split(/\s+/).join(" "); debug("comparator", comp, options2); this.options = options2; this.loose = !!options2.loose; this.parse(comp); if (this.semver === ANY) { this.value = ""; } else { this.value = this.operator + this.semver.version; } debug("comp", this); } parse(comp) { const r = this.options.loose ? re[t.COMPARATORLOOSE] : re[t.COMPARATOR]; const m = comp.match(r); if (!m) { throw new TypeError(`Invalid comparator: ${comp}`); } this.operator = m[1] !== undefined ? m[1] : ""; if (this.operator === "=") { this.operator = ""; } if (!m[2]) { this.semver = ANY; } else { this.semver = new SemVer(m[2], this.options.loose); } } toString() { return this.value; } test(version) { debug("Comparator.test", version, this.options.loose); if (this.semver === ANY || version === ANY) { return true; } if (typeof version === "string") { try { version = new SemVer(version, this.options); } catch (er) { return false; } } return cmp(version, this.operator, this.semver, this.options); } intersects(comp, options2) { if (!(comp instanceof Comparator)) { throw new TypeError("a Comparator is required"); } if (this.operator === "") { if (this.value === "") { return true; } return new Range(comp.value, options2).test(this.value); } else if (comp.operator === "") { if (comp.value === "") { return true; } return new Range(this.value, options2).test(comp.semver); } options2 = parseOptions(options2); if (options2.includePrerelease && (this.value === "<0.0.0-0" || comp.value === "<0.0.0-0")) { return false; } if (!options2.includePrerelease && (this.value.startsWith("<0.0.0") || comp.value.startsWith("<0.0.0"))) { return false; } if (this.operator.startsWith(">") && comp.operator.startsWith(">")) { return true; } if (this.operator.startsWith("<") && comp.operator.startsWith("<")) { return true; } if (this.semver.version === comp.semver.version && this.operator.includes("=") && comp.operator.includes("=")) { return true; } if (cmp(this.semver, "<", comp.semver, options2) && this.operator.startsWith(">") && comp.operator.startsWith("<")) { return true; } if (cmp(this.semver, ">", comp.semver, options2) && this.operator.startsWith("<") && comp.operator.startsWith(">")) { return true; } return false; } } module.exports = Comparator; var parseOptions = require_parse_options(); var { safeRe: re, t } = require_re(); var cmp = require_cmp(); var debug = require_debug(); var SemVer = require_semver(); var Range = require_range(); }); // ../eve/node_modules/semver/functions/satisfies.js var require_satisfies = __commonJS((exports, module) => { var Range = require_range(); var satisfies = (version, range, options2) => { try { range = new Range(range, options2); } catch (er) { return false; } return range.test(version); }; module.exports = satisfies; }); // ../eve/node_modules/semver/ranges/to-comparators.js var require_to_comparators = __commonJS((exports, module) => { var Range = require_range(); var toComparators = (range, options2) => new Range(range, options2).set.map((comp) => comp.map((c) => c.value).join(" ").trim().split(" ")); module.exports = toComparators; }); // ../eve/node_modules/semver/ranges/max-satisfying.js var require_max_satisfying = __commonJS((exports, module) => { var SemVer = require_semver(); var Range = require_range(); var maxSatisfying = (versions, range, options2) => { let max = null; let maxSV = null; let rangeObj = null; try { rangeObj = new Range(range, options2); } catch (er) { return null; } versions.forEach((v) => { if (rangeObj.test(v)) { if (!max || maxSV.compare(v) === -1) { max = v; maxSV = new SemVer(max, options2); } } }); return max; }; module.exports = maxSatisfying; }); // ../eve/node_modules/semver/ranges/min-satisfying.js var require_min_satisfying = __commonJS((exports, module) => { var SemVer = require_semver(); var Range = require_range(); var minSatisfying = (versions, range, options2) => { let min = null; let minSV = null; let rangeObj = null; try { rangeObj = new Range(range, options2); } catch (er) { return null; } versions.forEach((v) => { if (rangeObj.test(v)) { if (!min || minSV.compare(v) === 1) { min = v; minSV = new SemVer(min, options2); } } }); return min; }; module.exports = minSatisfying; }); // ../eve/node_modules/semver/ranges/min-version.js var require_min_version = __commonJS((exports, module) => { var SemVer = require_semver(); var Range = require_range(); var gt = require_gt(); var minVersion = (range, loose) => { range = new Range(range, loose); let minver = new SemVer("0.0.0"); if (range.test(minver)) { return minver; } minver = new SemVer("0.0.0-0"); if (range.test(minver)) { return minver; } minver = null; for (let i = 0;i < range.set.length; ++i) { const comparators = range.set[i]; let setMin = null; comparators.forEach((comparator) => { const compver = new SemVer(comparator.semver.version); switch (comparator.operator) { case ">": if (compver.prerelease.length === 0) { compver.patch++; } else { compver.prerelease.push(0); } compver.raw = compver.format(); case "": case ">=": if (!setMin || gt(compver, setMin)) { setMin = compver; } break; case "<": case "<=": break; default: throw new Error(`Unexpected operation: ${comparator.operator}`); } }); if (setMin && (!minver || gt(minver, setMin))) { minver = setMin; } } if (minver && range.test(minver)) { return minver; } return null; }; module.exports = minVersion; }); // ../eve/node_modules/semver/ranges/valid.js var require_valid2 = __commonJS((exports, module) => { var Range = require_range(); var validRange = (range, options2) => { try { return new Range(range, options2).range || "*"; } catch (er) { return null; } }; module.exports = validRange; }); // ../eve/node_modules/semver/ranges/outside.js var require_outside = __commonJS((exports, module) => { var SemVer = require_semver(); var Comparator = require_comparator(); var { ANY } = Comparator; var Range = require_range(); var satisfies = require_satisfies(); var gt = require_gt(); var lt = require_lt(); var lte = require_lte(); var gte = require_gte(); var outside = (version, range, hilo, options2) => { version = new SemVer(version, options2); range = new Range(range, options2); let gtfn, ltefn, ltfn, comp, ecomp; switch (hilo) { case ">": gtfn = gt; ltefn = lte; ltfn = lt; comp = ">"; ecomp = ">="; break; case "<": gtfn = lt; ltefn = gte; ltfn = gt; comp = "<"; ecomp = "<="; break; default: throw new TypeError('Must provide a hilo val of "<" or ">"'); } if (satisfies(version, range, options2)) { return false; } for (let i = 0;i < range.set.length; ++i) { const comparators = range.set[i]; let high = null; let low = null; comparators.forEach((comparator) => { if (comparator.semver === ANY) { comparator = new Comparator(">=0.0.0"); } high = high || comparator; low = low || comparator; if (gtfn(comparator.semver, high.semver, options2)) { high = comparator; } else if (ltfn(comparator.semver, low.semver, options2)) { low = comparator; } }); if (high.operator === comp || high.operator === ecomp) { return false; } if ((!low.operator || low.operator === comp) && ltefn(version, low.semver)) { return false; } else if (low.operator === ecomp && ltfn(version, low.semver)) { return false; } } return true; }; module.exports = outside; }); // ../eve/node_modules/semver/ranges/gtr.js var require_gtr = __commonJS((exports, module) => { var outside = require_outside(); var gtr = (version, range, options2) => outside(version, range, ">", options2); module.exports = gtr; }); // ../eve/node_modules/semver/ranges/ltr.js var require_ltr = __commonJS((exports, module) => { var outside = require_outside(); var ltr = (version, range, options2) => outside(version, range, "<", options2); module.exports = ltr; }); // ../eve/node_modules/semver/ranges/intersects.js var require_intersects = __commonJS((exports, module) => { var Range = require_range(); var intersects = (r1, r2, options2) => { r1 = new Range(r1, options2); r2 = new Range(r2, options2); return r1.intersects(r2, options2); }; module.exports = intersects; }); // ../eve/node_modules/semver/ranges/simplify.js var require_simplify = __commonJS((exports, module) => { var satisfies = require_satisfies(); var compare = require_compare(); module.exports = (versions, range, options2) => { const set = []; let first = null; let prev = null; const v = versions.sort((a, b) => compare(a, b, options2)); for (const version of v) { const included = satisfies(version, range, options2); if (included) { prev = version; if (!first) { first = version; } } else { if (prev) { set.push([first, prev]); } prev = null; first = null; } } if (first) { set.push([first, null]); } const ranges = []; for (const [min, max] of set) { if (min === max) { ranges.push(min); } else if (!max && min === v[0]) { ranges.push("*"); } else if (!max) { ranges.push(`>=${min}`); } else if (min === v[0]) { ranges.push(`<=${max}`); } else { ranges.push(`${min} - ${max}`); } } const simplified = ranges.join(" || "); const original = typeof range.raw === "string" ? range.raw : String(range); return simplified.length < original.length ? simplified : range; }; }); // ../eve/node_modules/semver/ranges/subset.js var require_subset = __commonJS((exports, module) => { var Range = require_range(); var Comparator = require_comparator(); var { ANY } = Comparator; var satisfies = require_satisfies(); var compare = require_compare(); var subset = (sub, dom, options2 = {}) => { if (sub === dom) { return true; } sub = new Range(sub, options2); dom = new Range(dom, options2); let sawNonNull = false; OUTER: for (const simpleSub of sub.set) { for (const simpleDom of dom.set) { const isSub = simpleSubset(simpleSub, simpleDom, options2); sawNonNull = sawNonNull || isSub !== null; if (isSub) { continue OUTER; } } if (sawNonNull) { return false; } } return true; }; var minimumVersionWithPreRelease = [new Comparator(">=0.0.0-0")]; var minimumVersion = [new Comparator(">=0.0.0")]; var simpleSubset = (sub, dom, options2) => { if (sub === dom) { return true; } if (sub.length === 1 && sub[0].semver === ANY) { if (dom.length === 1 && dom[0].semver === ANY) { return true; } else if (options2.includePrerelease) { sub = minimumVersionWithPreRelease; } else { sub = minimumVersion; } } if (dom.length === 1 && dom[0].semver === ANY) { if (options2.includePrerelease) { return true; } else { dom = minimumVersion; } } const eqSet = new Set; let gt, lt; for (const c of sub) { if (c.operator === ">" || c.operator === ">=") { gt = higherGT(gt, c, options2); } else if (c.operator === "<" || c.operator === "<=") { lt = lowerLT(lt, c, options2); } else { eqSet.add(c.semver); } } if (eqSet.size > 1) { return null; } let gtltComp; if (gt && lt) { gtltComp = compare(gt.semver, lt.semver, options2); if (gtltComp > 0) { return null; } else if (gtltComp === 0 && (gt.operator !== ">=" || lt.operator !== "<=")) { return null; } } for (const eq of eqSet) { if (gt && !satisfies(eq, String(gt), options2)) { return null; } if (lt && !satisfies(eq, String(lt), options2)) { return null; } for (const c of dom) { if (!satisfies(eq, String(c), options2)) { return false; } } return true; } let higher, lower; let hasDomLT, hasDomGT; let needDomLTPre = lt && !options2.includePrerelease && lt.semver.prerelease.length ? lt.semver : false; let needDomGTPre = gt && !options2.includePrerelease && gt.semver.prerelease.length ? gt.semver : false; if (needDomLTPre && needDomLTPre.prerelease.length === 1 && lt.operator === "<" && needDomLTPre.prerelease[0] === 0) { needDomLTPre = false; } for (const c of dom) { hasDomGT = hasDomGT || c.operator === ">" || c.operator === ">="; hasDomLT = hasDomLT || c.operator === "<" || c.operator === "<="; if (gt) { if (needDomGTPre) { if (c.semver.prerelease && c.semver.prerelease.length && c.semver.major === needDomGTPre.major && c.semver.minor === needDomGTPre.minor && c.semver.patch === needDomGTPre.patch) { needDomGTPre = false; } } if (c.operator === ">" || c.operator === ">=") { higher = higherGT(gt, c, options2); if (higher === c && higher !== gt) { return false; } } else if (gt.operator === ">=" && !satisfies(gt.semver, String(c), options2)) { return false; } } if (lt) { if (needDomLTPre) { if (c.semver.prerelease && c.semver.prerelease.length && c.semver.major === needDomLTPre.major && c.semver.minor === needDomLTPre.minor && c.semver.patch === needDomLTPre.patch) { needDomLTPre = false; } } if (c.operator === "<" || c.operator === "<=") { lower = lowerLT(lt, c, options2); if (lower === c && lower !== lt) { return false; } } else if (lt.operator === "<=" && !satisfies(lt.semver, String(c), options2)) { return false; } } if (!c.operator && (lt || gt) && gtltComp !== 0) { return false; } } if (gt && hasDomLT && !lt && gtltComp !== 0) { return false; } if (lt && hasDomGT && !gt && gtltComp !== 0) { return false; } if (needDomGTPre || needDomLTPre) { return false; } return true; }; var higherGT = (a, b, options2) => { if (!a) { return b; } const comp = compare(a.semver, b.semver, options2); return comp > 0 ? a : comp < 0 ? b : b.operator === ">" && a.operator === ">=" ? b : a; }; var lowerLT = (a, b, options2) => { if (!a) { return b; } const comp = compare(a.semver, b.semver, options2); return comp < 0 ? a : comp > 0 ? b : b.operator === "<" && a.operator === "<=" ? b : a; }; module.exports = subset; }); // ../eve/node_modules/semver/index.js var require_semver2 = __commonJS((exports, module) => { var internalRe = require_re(); var constants = require_constants(); var SemVer = require_semver(); var identifiers = require_identifiers(); var parse = require_parse(); var valid = require_valid(); var clean = require_clean(); var inc = require_inc(); var diff = require_diff(); var major = require_major(); var minor = require_minor(); var patch = require_patch(); var prerelease = require_prerelease(); var compare = require_compare(); var rcompare = require_rcompare(); var compareLoose = require_compare_loose(); var compareBuild = require_compare_build(); var sort = require_sort(); var rsort = require_rsort(); var gt = require_gt(); var lt = require_lt(); var eq = require_eq(); var neq = require_neq(); var gte = require_gte(); var lte = require_lte(); var cmp = require_cmp(); var coerce = require_coerce(); var Comparator = require_comparator(); var Range = require_range(); var satisfies = require_satisfies(); var toComparators = require_to_comparators(); var maxSatisfying = require_max_satisfying(); var minSatisfying = require_min_satisfying(); var minVersion = require_min_version(); var validRange = require_valid2(); var outside = require_outside(); var gtr = require_gtr(); var ltr = require_ltr(); var intersects = require_intersects(); var simplifyRange = require_simplify(); var subset = require_subset(); module.exports = { parse, valid, clean, inc, diff, major, minor, patch, prerelease, compare, rcompare, compareLoose, compareBuild, sort, rsort, gt, lt, eq, neq, gte, lte, cmp, coerce, Comparator, Range, satisfies, toComparators, maxSatisfying, minSatisfying, minVersion, validRange, outside, gtr, ltr, intersects, simplifyRange, subset, SemVer, re: internalRe.re, src: internalRe.src, tokens: internalRe.t, SEMVER_SPEC_VERSION: constants.SEMVER_SPEC_VERSION, RELEASE_TYPES: constants.RELEASE_TYPES, compareIdentifiers: identifiers.compareIdentifiers, rcompareIdentifiers: identifiers.rcompareIdentifiers }; }); // ../eve/node_modules/jsonwebtoken/lib/asymmetricKeyDetailsSupported.js var require_asymmetricKeyDetailsSupported = __commonJS((exports, module) => { var semver = require_semver2(); module.exports = semver.satisfies(process.version, ">=15.7.0"); }); // ../eve/node_modules/jsonwebtoken/lib/rsaPssKeyDetailsSupported.js var require_rsaPssKeyDetailsSupported = __commonJS((exports, module) => { var semver = require_semver2(); module.exports = semver.satisfies(process.version, ">=16.9.0"); }); // ../eve/node_modules/jsonwebtoken/lib/validateAsymmetricKey.js var require_validateAsymmetricKey = __commonJS((exports, module) => { var ASYMMETRIC_KEY_DETAILS_SUPPORTED = require_asymmetricKeyDetailsSupported(); var RSA_PSS_KEY_DETAILS_SUPPORTED = require_rsaPssKeyDetailsSupported(); var allowedAlgorithmsForKeys = { ec: ["ES256", "ES384", "ES512"], rsa: ["RS256", "PS256", "RS384", "PS384", "RS512", "PS512"], "rsa-pss": ["PS256", "PS384", "PS512"] }; var allowedCurves = { ES256: "prime256v1", ES384: "secp384r1", ES512: "secp521r1" }; module.exports = function(algorithm, key) { if (!algorithm || !key) return; const keyType = key.asymmetricKeyType; if (!keyType) return; const allowedAlgorithms = allowedAlgorithmsForKeys[keyType]; if (!allowedAlgorithms) { throw new Error(`Unknown key type "${keyType}".`); } if (!allowedAlgorithms.includes(algorithm)) { throw new Error(`"alg" parameter for "${keyType}" key type must be one of: ${allowedAlgorithms.join(", ")}.`); } if (ASYMMETRIC_KEY_DETAILS_SUPPORTED) { switch (keyType) { case "ec": const keyCurve = key.asymmetricKeyDetails.namedCurve; const allowedCurve = allowedCurves[algorithm]; if (keyCurve !== allowedCurve) { throw new Error(`"alg" parameter "${algorithm}" requires curve "${allowedCurve}".`); } break; case "rsa-pss": if (RSA_PSS_KEY_DETAILS_SUPPORTED) { const length = parseInt(algorithm.slice(-3), 10); const { hashAlgorithm, mgf1HashAlgorithm, saltLength } = key.asymmetricKeyDetails; if (hashAlgorithm !== `sha${length}` || mgf1HashAlgorithm !== hashAlgorithm) { throw new Error(`Invalid key for this operation, its RSA-PSS parameters do not meet the requirements of "alg" ${algorithm}.`); } if (saltLength !== undefined && saltLength > length >> 3) { throw new Error(`Invalid key for this operation, its RSA-PSS parameter saltLength does not meet the requirements of "alg" ${algorithm}.`); } } break; } } }; }); // ../eve/node_modules/jsonwebtoken/lib/psSupported.js var require_psSupported = __commonJS((exports, module) => { var semver = require_semver2(); module.exports = semver.satisfies(process.version, "^6.12.0 || >=8.0.0"); }); // ../eve/node_modules/jsonwebtoken/verify.js var require_verify = __commonJS((exports, module) => { var JsonWebTokenError = require_JsonWebTokenError(); var NotBeforeError = require_NotBeforeError(); var TokenExpiredError = require_TokenExpiredError(); var decode = require_decode(); var timespan = require_timespan(); var validateAsymmetricKey = require_validateAsymmetricKey(); var PS_SUPPORTED = require_psSupported(); var jws = require_jws(); var { KeyObject, createSecretKey, createPublicKey } = __require("crypto"); var PUB_KEY_ALGS = ["RS256", "RS384", "RS512"]; var EC_KEY_ALGS = ["ES256", "ES384", "ES512"]; var RSA_KEY_ALGS = ["RS256", "RS384", "RS512"]; var HS_ALGS = ["HS256", "HS384", "HS512"]; if (PS_SUPPORTED) { PUB_KEY_ALGS.splice(PUB_KEY_ALGS.length, 0, "PS256", "PS384", "PS512"); RSA_KEY_ALGS.splice(RSA_KEY_ALGS.length, 0, "PS256", "PS384", "PS512"); } module.exports = function(jwtString, secretOrPublicKey, options2, callback) { if (typeof options2 === "function" && !callback) { callback = options2; options2 = {}; } if (!options2) { options2 = {}; } options2 = Object.assign({}, options2); let done; if (callback) { done = callback; } else { done = function(err, data) { if (err) throw err; return data; }; } if (options2.clockTimestamp && typeof options2.clockTimestamp !== "number") { return done(new JsonWebTokenError("clockTimestamp must be a number")); } if (options2.nonce !== undefined && (typeof options2.nonce !== "string" || options2.nonce.trim() === "")) { return done(new JsonWebTokenError("nonce must be a non-empty string")); } if (options2.allowInvalidAsymmetricKeyTypes !== undefined && typeof options2.allowInvalidAsymmetricKeyTypes !== "boolean") { return done(new JsonWebTokenError("allowInvalidAsymmetricKeyTypes must be a boolean")); } const clockTimestamp = options2.clockTimestamp || Math.floor(Date.now() / 1000); if (!jwtString) { return done(new JsonWebTokenError("jwt must be provided")); } if (typeof jwtString !== "string") { return done(new JsonWebTokenError("jwt must be a string")); } const parts = jwtString.split("."); if (parts.length !== 3) { return done(new JsonWebTokenError("jwt malformed")); } let decodedToken; try { decodedToken = decode(jwtString, { complete: true }); } catch (err) { return done(err); } if (!decodedToken) { return done(new JsonWebTokenError("invalid token")); } const header = decodedToken.header; let getSecret; if (typeof secretOrPublicKey === "function") { if (!callback) { return done(new JsonWebTokenError("verify must be called asynchronous if secret or public key is provided as a callback")); } getSecret = secretOrPublicKey; } else { getSecret = function(header2, secretCallback) { return secretCallback(null, secretOrPublicKey); }; } return getSecret(header, function(err, secretOrPublicKey2) { if (err) { return done(new JsonWebTokenError("error in secret or public key callback: " + err.message)); } const hasSignature = parts[2].trim() !== ""; if (!hasSignature && secretOrPublicKey2) { return done(new JsonWebTokenError("jwt signature is required")); } if (hasSignature && !secretOrPublicKey2) { return done(new JsonWebTokenError("secret or public key must be provided")); } if (!hasSignature && !options2.algorithms) { return done(new JsonWebTokenError('please specify "none" in "algorithms" to verify unsigned tokens')); } if (secretOrPublicKey2 != null && !(secretOrPublicKey2 instanceof KeyObject)) { try { secretOrPublicKey2 = createPublicKey(secretOrPublicKey2); } catch (_) { try { secretOrPublicKey2 = createSecretKey(typeof secretOrPublicKey2 === "string" ? Buffer.from(secretOrPublicKey2) : secretOrPublicKey2); } catch (_2) { return done(new JsonWebTokenError("secretOrPublicKey is not valid key material")); } } } if (!options2.algorithms) { if (secretOrPublicKey2.type === "secret") { options2.algorithms = HS_ALGS; } else if (["rsa", "rsa-pss"].includes(secretOrPublicKey2.asymmetricKeyType)) { options2.algorithms = RSA_KEY_ALGS; } else if (secretOrPublicKey2.asymmetricKeyType === "ec") { options2.algorithms = EC_KEY_ALGS; } else { options2.algorithms = PUB_KEY_ALGS; } } if (options2.algorithms.indexOf(decodedToken.header.alg) === -1) { return done(new JsonWebTokenError("invalid algorithm")); } if (header.alg.startsWith("HS") && secretOrPublicKey2.type !== "secret") { return done(new JsonWebTokenError(`secretOrPublicKey must be a symmetric key when using ${header.alg}`)); } else if (/^(?:RS|PS|ES)/.test(header.alg) && secretOrPublicKey2.type !== "public") { return done(new JsonWebTokenError(`secretOrPublicKey must be an asymmetric key when using ${header.alg}`)); } if (!options2.allowInvalidAsymmetricKeyTypes) { try { validateAsymmetricKey(header.alg, secretOrPublicKey2); } catch (e) { return done(e); } } let valid; try { valid = jws.verify(jwtString, decodedToken.header.alg, secretOrPublicKey2); } catch (e) { return done(e); } if (!valid) { return done(new JsonWebTokenError("invalid signature")); } const payload = decodedToken.payload; if (typeof payload.nbf !== "undefined" && !options2.ignoreNotBefore) { if (typeof payload.nbf !== "number") { return done(new JsonWebTokenError("invalid nbf value")); } if (payload.nbf > clockTimestamp + (options2.clockTolerance || 0)) { return done(new NotBeforeError("jwt not active", new Date(payload.nbf * 1000))); } } if (typeof payload.exp !== "undefined" && !options2.ignoreExpiration) { if (typeof payload.exp !== "number") { return done(new JsonWebTokenError("invalid exp value")); } if (clockTimestamp >= payload.exp + (options2.clockTolerance || 0)) { return done(new TokenExpiredError("jwt expired", new Date(payload.exp * 1000))); } } if (options2.audience) { const audiences = Array.isArray(options2.audience) ? options2.audience : [options2.audience]; const target = Array.isArray(payload.aud) ? payload.aud : [payload.aud]; const match = target.some(function(targetAudience) { return audiences.some(function(audience) { return audience instanceof RegExp ? audience.test(targetAudience) : audience === targetAudience; }); }); if (!match) { return done(new JsonWebTokenError("jwt audience invalid. expected: " + audiences.join(" or "))); } } if (options2.issuer) { const invalid_issuer = typeof options2.issuer === "string" && payload.iss !== options2.issuer || Array.isArray(options2.issuer) && options2.issuer.indexOf(payload.iss) === -1; if (invalid_issuer) { return done(new JsonWebTokenError("jwt issuer invalid. expected: " + options2.issuer)); } } if (options2.subject) { if (payload.sub !== options2.subject) { return done(new JsonWebTokenError("jwt subject invalid. expected: " + options2.subject)); } } if (options2.jwtid) { if (payload.jti !== options2.jwtid) { return done(new JsonWebTokenError("jwt jwtid invalid. expected: " + options2.jwtid)); } } if (options2.nonce) { if (payload.nonce !== options2.nonce) { return done(new JsonWebTokenError("jwt nonce invalid. expected: " + options2.nonce)); } } if (options2.maxAge) { if (typeof payload.iat !== "number") { return done(new JsonWebTokenError("iat required when maxAge is specified")); } const maxAgeTimestamp = timespan(options2.maxAge, payload.iat); if (typeof maxAgeTimestamp === "undefined") { return done(new JsonWebTokenError('"maxAge" should be a number of seconds or string representing a timespan eg: "1d", "20h", 60')); } if (clockTimestamp >= maxAgeTimestamp + (options2.clockTolerance || 0)) { return done(new TokenExpiredError("maxAge exceeded", new Date(maxAgeTimestamp * 1000))); } } if (options2.complete === true) { const signature = decodedToken.signature; return done(null, { header, payload, signature }); } return done(null, payload); }); }; }); // ../eve/node_modules/lodash.includes/index.js var require_lodash = __commonJS((exports, module) => { var INFINITY = 1 / 0; var MAX_SAFE_INTEGER = 9007199254740991; var MAX_INTEGER = 179769313486231570000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000; var NAN = 0 / 0; var argsTag = "[object Arguments]"; var funcTag = "[object Function]"; var genTag = "[object GeneratorFunction]"; var stringTag = "[object String]"; var symbolTag = "[object Symbol]"; var reTrim = /^\s+|\s+$/g; var reIsBadHex = /^[-+]0x[0-9a-f]+$/i; var reIsBinary = /^0b[01]+$/i; var reIsOctal = /^0o[0-7]+$/i; var reIsUint = /^(?:0|[1-9]\d*)$/; var freeParseInt = parseInt; function arrayMap(array, iteratee) { var index = -1, length = array ? array.length : 0, result = Array(length); while (++index < length) { result[index] = iteratee(array[index], index, array); } return result; } function baseFindIndex(array, predicate, fromIndex, fromRight) { var length = array.length, index = fromIndex + (fromRight ? 1 : -1); while (fromRight ? index-- : ++index < length) { if (predicate(array[index], index, array)) { return index; } } return -1; } function baseIndexOf(array, value, fromIndex) { if (value !== value) { return baseFindIndex(array, baseIsNaN, fromIndex); } var index = fromIndex - 1, length = array.length; while (++index < length) { if (array[index] === value) { return index; } } return -1; } function baseIsNaN(value) { return value !== value; } function baseTimes(n, iteratee) { var index = -1, result = Array(n); while (++index < n) { result[index] = iteratee(index); } return result; } function baseValues(object, props) { return arrayMap(props, function(key) { return object[key]; }); } function overArg(func, transform) { return function(arg) { return func(transform(arg)); }; } var objectProto = Object.prototype; var hasOwnProperty = objectProto.hasOwnProperty; var objectToString = objectProto.toString; var propertyIsEnumerable = objectProto.propertyIsEnumerable; var nativeKeys = overArg(Object.keys, Object); var nativeMax = Math.max; function arrayLikeKeys(value, inherited) { var result = isArray(value) || isArguments(value) ? baseTimes(value.length, String) : []; var length = result.length, skipIndexes = !!length; for (var key in value) { if ((inherited || hasOwnProperty.call(value, key)) && !(skipIndexes && (key == "length" || isIndex(key, length)))) { result.push(key); } } return result; } function baseKeys(object) { if (!isPrototype(object)) { return nativeKeys(object); } var result = []; for (var key in Object(object)) { if (hasOwnProperty.call(object, key) && key != "constructor") { result.push(key); } } return result; } function isIndex(value, length) { length = length == null ? MAX_SAFE_INTEGER : length; return !!length && (typeof value == "number" || reIsUint.test(value)) && (value > -1 && value % 1 == 0 && value < length); } function isPrototype(value) { var Ctor = value && value.constructor, proto = typeof Ctor == "function" && Ctor.prototype || objectProto; return value === proto; } function includes(collection, value, fromIndex, guard) { collection = isArrayLike(collection) ? collection : values(collection); fromIndex = fromIndex && !guard ? toInteger(fromIndex) : 0; var length = collection.length; if (fromIndex < 0) { fromIndex = nativeMax(length + fromIndex, 0); } return isString(collection) ? fromIndex <= length && collection.indexOf(value, fromIndex) > -1 : !!length && baseIndexOf(collection, value, fromIndex) > -1; } function isArguments(value) { return isArrayLikeObject(value) && hasOwnProperty.call(value, "callee") && (!propertyIsEnumerable.call(value, "callee") || objectToString.call(value) == argsTag); } var isArray = Array.isArray; function isArrayLike(value) { return value != null && isLength(value.length) && !isFunction(value); } function isArrayLikeObject(value) { return isObjectLike(value) && isArrayLike(value); } function isFunction(value) { var tag = isObject(value) ? objectToString.call(value) : ""; return tag == funcTag || tag == genTag; } function isLength(value) { return typeof value == "number" && value > -1 && value % 1 == 0 && value <= MAX_SAFE_INTEGER; } function isObject(value) { var type = typeof value; return !!value && (type == "object" || type == "function"); } function isObjectLike(value) { return !!value && typeof value == "object"; } function isString(value) { return typeof value == "string" || !isArray(value) && isObjectLike(value) && objectToString.call(value) == stringTag; } function isSymbol(value) { return typeof value == "symbol" || isObjectLike(value) && objectToString.call(value) == symbolTag; } function toFinite(value) { if (!value) { return value === 0 ? value : 0; } value = toNumber(value); if (value === INFINITY || value === -INFINITY) { var sign = value < 0 ? -1 : 1; return sign * MAX_INTEGER; } return value === value ? value : 0; } function toInteger(value) { var result = toFinite(value), remainder = result % 1; return result === result ? remainder ? result - remainder : result : 0; } function toNumber(value) { if (typeof value == "number") { return value; } if (isSymbol(value)) { return NAN; } if (isObject(value)) { var other = typeof value.valueOf == "function" ? value.valueOf() : value; value = isObject(other) ? other + "" : other; } if (typeof value != "string") { return value === 0 ? value : +value; } value = value.replace(reTrim, ""); var isBinary = reIsBinary.test(value); return isBinary || reIsOctal.test(value) ? freeParseInt(value.slice(2), isBinary ? 2 : 8) : reIsBadHex.test(value) ? NAN : +value; } function keys(object) { return isArrayLike(object) ? arrayLikeKeys(object) : baseKeys(object); } function values(object) { return object ? baseValues(object, keys(object)) : []; } module.exports = includes; }); // ../eve/node_modules/lodash.isboolean/index.js var require_lodash2 = __commonJS((exports, module) => { var boolTag = "[object Boolean]"; var objectProto = Object.prototype; var objectToString = objectProto.toString; function isBoolean(value) { return value === true || value === false || isObjectLike(value) && objectToString.call(value) == boolTag; } function isObjectLike(value) { return !!value && typeof value == "object"; } module.exports = isBoolean; }); // ../eve/node_modules/lodash.isinteger/index.js var require_lodash3 = __commonJS((exports, module) => { var INFINITY = 1 / 0; var MAX_INTEGER = 179769313486231570000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000; var NAN = 0 / 0; var symbolTag = "[object Symbol]"; var reTrim = /^\s+|\s+$/g; var reIsBadHex = /^[-+]0x[0-9a-f]+$/i; var reIsBinary = /^0b[01]+$/i; var reIsOctal = /^0o[0-7]+$/i; var freeParseInt = parseInt; var objectProto = Object.prototype; var objectToString = objectProto.toString; function isInteger(value) { return typeof value == "number" && value == toInteger(value); } function isObject(value) { var type = typeof value; return !!value && (type == "object" || type == "function"); } function isObjectLike(value) { return !!value && typeof value == "object"; } function isSymbol(value) { return typeof value == "symbol" || isObjectLike(value) && objectToString.call(value) == symbolTag; } function toFinite(value) { if (!value) { return value === 0 ? value : 0; } value = toNumber(value); if (value === INFINITY || value === -INFINITY) { var sign = value < 0 ? -1 : 1; return sign * MAX_INTEGER; } return value === value ? value : 0; } function toInteger(value) { var result = toFinite(value), remainder = result % 1; return result === result ? remainder ? result - remainder : result : 0; } function toNumber(value) { if (typeof value == "number") { return value; } if (isSymbol(value)) { return NAN; } if (isObject(value)) { var other = typeof value.valueOf == "function" ? value.valueOf() : value; value = isObject(other) ? other + "" : other; } if (typeof value != "string") { return value === 0 ? value : +value; } value = value.replace(reTrim, ""); var isBinary = reIsBinary.test(value); return isBinary || reIsOctal.test(value) ? freeParseInt(value.slice(2), isBinary ? 2 : 8) : reIsBadHex.test(value) ? NAN : +value; } module.exports = isInteger; }); // ../eve/node_modules/lodash.isnumber/index.js var require_lodash4 = __commonJS((exports, module) => { var numberTag = "[object Number]"; var objectProto = Object.prototype; var objectToString = objectProto.toString; function isObjectLike(value) { return !!value && typeof value == "object"; } function isNumber(value) { return typeof value == "number" || isObjectLike(value) && objectToString.call(value) == numberTag; } module.exports = isNumber; }); // ../eve/node_modules/lodash.isplainobject/index.js var require_lodash5 = __commonJS((exports, module) => { var objectTag = "[object Object]"; function isHostObject(value) { var result = false; if (value != null && typeof value.toString != "function") { try { result = !!(value + ""); } catch (e) {} } return result; } function overArg(func, transform) { return function(arg) { return func(transform(arg)); }; } var funcProto = Function.prototype; var objectProto = Object.prototype; var funcToString = funcProto.toString; var hasOwnProperty = objectProto.hasOwnProperty; var objectCtorString = funcToString.call(Object); var objectToString = objectProto.toString; var getPrototype = overArg(Object.getPrototypeOf, Object); function isObjectLike(value) { return !!value && typeof value == "object"; } function isPlainObject(value) { if (!isObjectLike(value) || objectToString.call(value) != objectTag || isHostObject(value)) { return false; } var proto = getPrototype(value); if (proto === null) { return true; } var Ctor = hasOwnProperty.call(proto, "constructor") && proto.constructor; return typeof Ctor == "function" && Ctor instanceof Ctor && funcToString.call(Ctor) == objectCtorString; } module.exports = isPlainObject; }); // ../eve/node_modules/lodash.isstring/index.js var require_lodash6 = __commonJS((exports, module) => { var stringTag = "[object String]"; var objectProto = Object.prototype; var objectToString = objectProto.toString; var isArray = Array.isArray; function isObjectLike(value) { return !!value && typeof value == "object"; } function isString(value) { return typeof value == "string" || !isArray(value) && isObjectLike(value) && objectToString.call(value) == stringTag; } module.exports = isString; }); // ../eve/node_modules/lodash.once/index.js var require_lodash7 = __commonJS((exports, module) => { var FUNC_ERROR_TEXT = "Expected a function"; var INFINITY = 1 / 0; var MAX_INTEGER = 179769313486231570000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000; var NAN = 0 / 0; var symbolTag = "[object Symbol]"; var reTrim = /^\s+|\s+$/g; var reIsBadHex = /^[-+]0x[0-9a-f]+$/i; var reIsBinary = /^0b[01]+$/i; var reIsOctal = /^0o[0-7]+$/i; var freeParseInt = parseInt; var objectProto = Object.prototype; var objectToString = objectProto.toString; function before(n, func) { var result; if (typeof func != "function") { throw new TypeError(FUNC_ERROR_TEXT); } n = toInteger(n); return function() { if (--n > 0) { result = func.apply(this, arguments); } if (n <= 1) { func = undefined; } return result; }; } function once(func) { return before(2, func); } function isObject(value) { var type = typeof value; return !!value && (type == "object" || type == "function"); } function isObjectLike(value) { return !!value && typeof value == "object"; } function isSymbol(value) { return typeof value == "symbol" || isObjectLike(value) && objectToString.call(value) == symbolTag; } function toFinite(value) { if (!value) { return value === 0 ? value : 0; } value = toNumber(value); if (value === INFINITY || value === -INFINITY) { var sign = value < 0 ? -1 : 1; return sign * MAX_INTEGER; } return value === value ? value : 0; } function toInteger(value) { var result = toFinite(value), remainder = result % 1; return result === result ? remainder ? result - remainder : result : 0; } function toNumber(value) { if (typeof value == "number") { return value; } if (isSymbol(value)) { return NAN; } if (isObject(value)) { var other = typeof value.valueOf == "function" ? value.valueOf() : value; value = isObject(other) ? other + "" : other; } if (typeof value != "string") { return value === 0 ? value : +value; } value = value.replace(reTrim, ""); var isBinary = reIsBinary.test(value); return isBinary || reIsOctal.test(value) ? freeParseInt(value.slice(2), isBinary ? 2 : 8) : reIsBadHex.test(value) ? NAN : +value; } module.exports = once; }); // ../eve/node_modules/jsonwebtoken/sign.js var require_sign = __commonJS((exports, module) => { var timespan = require_timespan(); var PS_SUPPORTED = require_psSupported(); var validateAsymmetricKey = require_validateAsymmetricKey(); var jws = require_jws(); var includes = require_lodash(); var isBoolean = require_lodash2(); var isInteger = require_lodash3(); var isNumber = require_lodash4(); var isPlainObject = require_lodash5(); var isString = require_lodash6(); var once = require_lodash7(); var { KeyObject, createSecretKey, createPrivateKey } = __require("crypto"); var SUPPORTED_ALGS = ["RS256", "RS384", "RS512", "ES256", "ES384", "ES512", "HS256", "HS384", "HS512", "none"]; if (PS_SUPPORTED) { SUPPORTED_ALGS.splice(3, 0, "PS256", "PS384", "PS512"); } var sign_options_schema = { expiresIn: { isValid: function(value) { return isInteger(value) || isString(value) && value; }, message: '"expiresIn" should be a number of seconds or string representing a timespan' }, notBefore: { isValid: function(value) { return isInteger(value) || isString(value) && value; }, message: '"notBefore" should be a number of seconds or string representing a timespan' }, audience: { isValid: function(value) { return isString(value) || Array.isArray(value); }, message: '"audience" must be a string or array' }, algorithm: { isValid: includes.bind(null, SUPPORTED_ALGS), message: '"algorithm" must be a valid string enum value' }, header: { isValid: isPlainObject, message: '"header" must be an object' }, encoding: { isValid: isString, message: '"encoding" must be a string' }, issuer: { isValid: isString, message: '"issuer" must be a string' }, subject: { isValid: isString, message: '"subject" must be a string' }, jwtid: { isValid: isString, message: '"jwtid" must be a string' }, noTimestamp: { isValid: isBoolean, message: '"noTimestamp" must be a boolean' }, keyid: { isValid: isString, message: '"keyid" must be a string' }, mutatePayload: { isValid: isBoolean, message: '"mutatePayload" must be a boolean' }, allowInsecureKeySizes: { isValid: isBoolean, message: '"allowInsecureKeySizes" must be a boolean' }, allowInvalidAsymmetricKeyTypes: { isValid: isBoolean, message: '"allowInvalidAsymmetricKeyTypes" must be a boolean' } }; var registered_claims_schema = { iat: { isValid: isNumber, message: '"iat" should be a number of seconds' }, exp: { isValid: isNumber, message: '"exp" should be a number of seconds' }, nbf: { isValid: isNumber, message: '"nbf" should be a number of seconds' } }; function validate(schema, allowUnknown, object, parameterName) { if (!isPlainObject(object)) { throw new Error('Expected "' + parameterName + '" to be a plain object.'); } Object.keys(object).forEach(function(key) { const validator = schema[key]; if (!validator) { if (!allowUnknown) { throw new Error('"' + key + '" is not allowed in "' + parameterName + '"'); } return; } if (!validator.isValid(object[key])) { throw new Error(validator.message); } }); } function validateOptions(options2) { return validate(sign_options_schema, false, options2, "options"); } function validatePayload(payload) { return validate(registered_claims_schema, true, payload, "payload"); } var options_to_payload = { audience: "aud", issuer: "iss", subject: "sub", jwtid: "jti" }; var options_for_objects = [ "expiresIn", "notBefore", "noTimestamp", "audience", "issuer", "subject", "jwtid" ]; module.exports = function(payload, secretOrPrivateKey, options2, callback) { if (typeof options2 === "function") { callback = options2; options2 = {}; } else { options2 = options2 || {}; } const isObjectPayload = typeof payload === "object" && !Buffer.isBuffer(payload); const header = Object.assign({ alg: options2.algorithm || "HS256", typ: isObjectPayload ? "JWT" : undefined, kid: options2.keyid }, options2.header); function failure(err) { if (callback) { return callback(err); } throw err; } if (!secretOrPrivateKey && options2.algorithm !== "none") { return failure(new Error("secretOrPrivateKey must have a value")); } if (secretOrPrivateKey != null && !(secretOrPrivateKey instanceof KeyObject)) { try { secretOrPrivateKey = createPrivateKey(secretOrPrivateKey); } catch (_) { try { secretOrPrivateKey = createSecretKey(typeof secretOrPrivateKey === "string" ? Buffer.from(secretOrPrivateKey) : secretOrPrivateKey); } catch (_2) { return failure(new Error("secretOrPrivateKey is not valid key material")); } } } if (header.alg.startsWith("HS") && secretOrPrivateKey.type !== "secret") { return failure(new Error(`secretOrPrivateKey must be a symmetric key when using ${header.alg}`)); } else if (/^(?:RS|PS|ES)/.test(header.alg)) { if (secretOrPrivateKey.type !== "private") { return failure(new Error(`secretOrPrivateKey must be an asymmetric key when using ${header.alg}`)); } if (!options2.allowInsecureKeySizes && !header.alg.startsWith("ES") && secretOrPrivateKey.asymmetricKeyDetails !== undefined && secretOrPrivateKey.asymmetricKeyDetails.modulusLength < 2048) { return failure(new Error(`secretOrPrivateKey has a minimum key size of 2048 bits for ${header.alg}`)); } } if (typeof payload === "undefined") { return failure(new Error("payload is required")); } else if (isObjectPayload) { try { validatePayload(payload); } catch (error) { return failure(error); } if (!options2.mutatePayload) { payload = Object.assign({}, payload); } } else { const invalid_options = options_for_objects.filter(function(opt) { return typeof options2[opt] !== "undefined"; }); if (invalid_options.length > 0) { return failure(new Error("invalid " + invalid_options.join(",") + " option for " + typeof payload + " payload")); } } if (typeof payload.exp !== "undefined" && typeof options2.expiresIn !== "undefined") { return failure(new Error('Bad "options.expiresIn" option the payload already has an "exp" property.')); } if (typeof payload.nbf !== "undefined" && typeof options2.notBefore !== "undefined") { return failure(new Error('Bad "options.notBefore" option the payload already has an "nbf" property.')); } try { validateOptions(options2); } catch (error) { return failure(error); } if (!options2.allowInvalidAsymmetricKeyTypes) { try { validateAsymmetricKey(header.alg, secretOrPrivateKey); } catch (error) { return failure(error); } } const timestamp = payload.iat || Math.floor(Date.now() / 1000); if (options2.noTimestamp) { delete payload.iat; } else if (isObjectPayload) { payload.iat = timestamp; } if (typeof options2.notBefore !== "undefined") { try { payload.nbf = timespan(options2.notBefore, timestamp); } catch (err) { return failure(err); } if (typeof payload.nbf === "undefined") { return failure(new Error('"notBefore" should be a number of seconds or string representing a timespan eg: "1d", "20h", 60')); } } if (typeof options2.expiresIn !== "undefined" && typeof payload === "object") { try { payload.exp = timespan(options2.expiresIn, timestamp); } catch (err) { return failure(err); } if (typeof payload.exp === "undefined") { return failure(new Error('"expiresIn" should be a number of seconds or string representing a timespan eg: "1d", "20h", 60')); } } Object.keys(options_to_payload).forEach(function(key) { const claim = options_to_payload[key]; if (typeof options2[key] !== "undefined") { if (typeof payload[claim] !== "undefined") { return failure(new Error('Bad "options.' + key + '" option. The payload already has an "' + claim + '" property.')); } payload[claim] = options2[key]; } }); const encoding = options2.encoding || "utf8"; if (typeof callback === "function") { callback = callback && once(callback); jws.createSign({ header, privateKey: secretOrPrivateKey, payload, encoding }).once("error", callback).once("done", function(signature) { if (!options2.allowInsecureKeySizes && /^(?:RS|PS)/.test(header.alg) && signature.length < 256) { return callback(new Error(`secretOrPrivateKey has a minimum key size of 2048 bits for ${header.alg}`)); } callback(null, signature); }); } else { let signature = jws.sign({ header, payload, secret: secretOrPrivateKey, encoding }); if (!options2.allowInsecureKeySizes && /^(?:RS|PS)/.test(header.alg) && signature.length < 256) { throw new Error(`secretOrPrivateKey has a minimum key size of 2048 bits for ${header.alg}`); } return signature; } }; }); // ../eve/node_modules/jsonwebtoken/index.js var require_jsonwebtoken = __commonJS((exports, module) => { module.exports = { decode: require_decode(), verify: require_verify(), sign: require_sign(), JsonWebTokenError: require_JsonWebTokenError(), NotBeforeError: require_NotBeforeError(), TokenExpiredError: require_TokenExpiredError() }; }); // ../eve/node_modules/bn.js/lib/bn.js var require_bn = __commonJS((exports, module) => { (function(module2, exports2) { function assert(val, msg) { if (!val) throw new Error(msg || "Assertion failed"); } function inherits(ctor, superCtor) { ctor.super_ = superCtor; var TempCtor = function() {}; TempCtor.prototype = superCtor.prototype; ctor.prototype = new TempCtor; ctor.prototype.constructor = ctor; } function BN(number, base, endian) { if (BN.isBN(number)) { return number; } this.negative = 0; this.words = null; this.length = 0; this.red = null; if (number !== null) { if (base === "le" || base === "be") { endian = base; base = 10; } this._init(number || 0, base || 10, endian || "be"); } } if (typeof module2 === "object") { module2.exports = BN; } else { exports2.BN = BN; } BN.BN = BN; BN.wordSize = 26; var Buffer2; try { if (typeof window !== "undefined" && typeof window.Buffer !== "undefined") { Buffer2 = window.Buffer; } else { Buffer2 = __require("buffer").Buffer; } } catch (e) {} BN.isBN = function isBN(num) { if (num instanceof BN) { return true; } return num !== null && typeof num === "object" && num.constructor.wordSize === BN.wordSize && Array.isArray(num.words); }; BN.max = function max(left, right) { if (left.cmp(right) > 0) return left; return right; }; BN.min = function min(left, right) { if (left.cmp(right) < 0) return left; return right; }; BN.prototype._init = function init(number, base, endian) { if (typeof number === "number") { return this._initNumber(number, base, endian); } if (typeof number === "object") { return this._initArray(number, base, endian); } if (base === "hex") { base = 16; } assert(base === (base | 0) && base >= 2 && base <= 36); number = number.toString().replace(/\s+/g, ""); var start = 0; if (number[0] === "-") { start++; this.negative = 1; } if (start < number.length) { if (base === 16) { this._parseHex(number, start, endian); } else { this._parseBase(number, base, start); if (endian === "le") { this._initArray(this.toArray(), base, endian); } } } }; BN.prototype._initNumber = function _initNumber(number, base, endian) { if (number < 0) { this.negative = 1; number = -number; } if (number < 67108864) { this.words = [number & 67108863]; this.length = 1; } else if (number < 4503599627370496) { this.words = [ number & 67108863, number / 67108864 & 67108863 ]; this.length = 2; } else { assert(number < 9007199254740992); this.words = [ number & 67108863, number / 67108864 & 67108863, 1 ]; this.length = 3; } if (endian !== "le") return; this._initArray(this.toArray(), base, endian); }; BN.prototype._initArray = function _initArray(number, base, endian) { assert(typeof number.length === "number"); if (number.length <= 0) { this.words = [0]; this.length = 1; return this; } this.length = Math.ceil(number.length / 3); this.words = new Array(this.length); for (var i = 0;i < this.length; i++) { this.words[i] = 0; } var j, w; var off = 0; if (endian === "be") { for (i = number.length - 1, j = 0;i >= 0; i -= 3) { w = number[i] | number[i - 1] << 8 | number[i - 2] << 16; this.words[j] |= w << off & 67108863; this.words[j + 1] = w >>> 26 - off & 67108863; off += 24; if (off >= 26) { off -= 26; j++; } } } else if (endian === "le") { for (i = 0, j = 0;i < number.length; i += 3) { w = number[i] | number[i + 1] << 8 | number[i + 2] << 16; this.words[j] |= w << off & 67108863; this.words[j + 1] = w >>> 26 - off & 67108863; off += 24; if (off >= 26) { off -= 26; j++; } } } return this.strip(); }; function parseHex4Bits(string, index) { var c = string.charCodeAt(index); if (c >= 65 && c <= 70) { return c - 55; } else if (c >= 97 && c <= 102) { return c - 87; } else { return c - 48 & 15; } } function parseHexByte(string, lowerBound, index) { var r = parseHex4Bits(string, index); if (index - 1 >= lowerBound) { r |= parseHex4Bits(string, index - 1) << 4; } return r; } BN.prototype._parseHex = function _parseHex(number, start, endian) { this.length = Math.ceil((number.length - start) / 6); this.words = new Array(this.length); for (var i = 0;i < this.length; i++) { this.words[i] = 0; } var off = 0; var j = 0; var w; if (endian === "be") { for (i = number.length - 1;i >= start; i -= 2) { w = parseHexByte(number, start, i) << off; this.words[j] |= w & 67108863; if (off >= 18) { off -= 18; j += 1; this.words[j] |= w >>> 26; } else { off += 8; } } } else { var parseLength = number.length - start; for (i = parseLength % 2 === 0 ? start + 1 : start;i < number.length; i += 2) { w = parseHexByte(number, start, i) << off; this.words[j] |= w & 67108863; if (off >= 18) { off -= 18; j += 1; this.words[j] |= w >>> 26; } else { off += 8; } } } this.strip(); }; function parseBase(str, start, end, mul) { var r = 0; var len = Math.min(str.length, end); for (var i = start;i < len; i++) { var c = str.charCodeAt(i) - 48; r *= mul; if (c >= 49) { r += c - 49 + 10; } else if (c >= 17) { r += c - 17 + 10; } else { r += c; } } return r; } BN.prototype._parseBase = function _parseBase(number, base, start) { this.words = [0]; this.length = 1; for (var limbLen = 0, limbPow = 1;limbPow <= 67108863; limbPow *= base) { limbLen++; } limbLen--; limbPow = limbPow / base | 0; var total = number.length - start; var mod = total % limbLen; var end = Math.min(total, total - mod) + start; var word = 0; for (var i = start;i < end; i += limbLen) { word = parseBase(number, i, i + limbLen, base); this.imuln(limbPow); if (this.words[0] + word < 67108864) { this.words[0] += word; } else { this._iaddn(word); } } if (mod !== 0) { var pow = 1; word = parseBase(number, i, number.length, base); for (i = 0;i < mod; i++) { pow *= base; } this.imuln(pow); if (this.words[0] + word < 67108864) { this.words[0] += word; } else { this._iaddn(word); } } this.strip(); }; BN.prototype.copy = function copy(dest) { dest.words = new Array(this.length); for (var i = 0;i < this.length; i++) { dest.words[i] = this.words[i]; } dest.length = this.length; dest.negative = this.negative; dest.red = this.red; }; BN.prototype.clone = function clone() { var r = new BN(null); this.copy(r); return r; }; BN.prototype._expand = function _expand(size) { while (this.length < size) { this.words[this.length++] = 0; } return this; }; BN.prototype.strip = function strip() { while (this.length > 1 && this.words[this.length - 1] === 0) { this.length--; } return this._normSign(); }; BN.prototype._normSign = function _normSign() { if (this.length === 1 && this.words[0] === 0) { this.negative = 0; } return this; }; BN.prototype.inspect = function inspect() { return (this.red ? ""; }; var zeros = [ "", "0", "00", "000", "0000", "00000", "000000", "0000000", "00000000", "000000000", "0000000000", "00000000000", "000000000000", "0000000000000", "00000000000000", "000000000000000", "0000000000000000", "00000000000000000", "000000000000000000", "0000000000000000000", "00000000000000000000", "000000000000000000000", "0000000000000000000000", "00000000000000000000000", "000000000000000000000000", "0000000000000000000000000" ]; var groupSizes = [ 0, 0, 25, 16, 12, 11, 10, 9, 8, 8, 7, 7, 7, 7, 6, 6, 6, 6, 6, 6, 6, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5 ]; var groupBases = [ 0, 0, 33554432, 43046721, 16777216, 48828125, 60466176, 40353607, 16777216, 43046721, 1e7, 19487171, 35831808, 62748517, 7529536, 11390625, 16777216, 24137569, 34012224, 47045881, 64000000, 4084101, 5153632, 6436343, 7962624, 9765625, 11881376, 14348907, 17210368, 20511149, 24300000, 28629151, 33554432, 39135393, 45435424, 52521875, 60466176 ]; BN.prototype.toString = function toString(base, padding) { base = base || 10; padding = padding | 0 || 1; var out; if (base === 16 || base === "hex") { out = ""; var off = 0; var carry = 0; for (var i = 0;i < this.length; i++) { var w = this.words[i]; var word = ((w << off | carry) & 16777215).toString(16); carry = w >>> 24 - off & 16777215; off += 2; if (off >= 26) { off -= 26; i--; } if (carry !== 0 || i !== this.length - 1) { out = zeros[6 - word.length] + word + out; } else { out = word + out; } } if (carry !== 0) { out = carry.toString(16) + out; } while (out.length % padding !== 0) { out = "0" + out; } if (this.negative !== 0) { out = "-" + out; } return out; } if (base === (base | 0) && base >= 2 && base <= 36) { var groupSize = groupSizes[base]; var groupBase = groupBases[base]; out = ""; var c = this.clone(); c.negative = 0; while (!c.isZero()) { var r = c.modn(groupBase).toString(base); c = c.idivn(groupBase); if (!c.isZero()) { out = zeros[groupSize - r.length] + r + out; } else { out = r + out; } } if (this.isZero()) { out = "0" + out; } while (out.length % padding !== 0) { out = "0" + out; } if (this.negative !== 0) { out = "-" + out; } return out; } assert(false, "Base should be between 2 and 36"); }; BN.prototype.toNumber = function toNumber() { var ret = this.words[0]; if (this.length === 2) { ret += this.words[1] * 67108864; } else if (this.length === 3 && this.words[2] === 1) { ret += 4503599627370496 + this.words[1] * 67108864; } else if (this.length > 2) { assert(false, "Number can only safely store up to 53 bits"); } return this.negative !== 0 ? -ret : ret; }; BN.prototype.toJSON = function toJSON() { return this.toString(16); }; BN.prototype.toBuffer = function toBuffer(endian, length) { assert(typeof Buffer2 !== "undefined"); return this.toArrayLike(Buffer2, endian, length); }; BN.prototype.toArray = function toArray(endian, length) { return this.toArrayLike(Array, endian, length); }; BN.prototype.toArrayLike = function toArrayLike(ArrayType, endian, length) { var byteLength = this.byteLength(); var reqLength = length || Math.max(1, byteLength); assert(byteLength <= reqLength, "byte array longer than desired length"); assert(reqLength > 0, "Requested array length <= 0"); this.strip(); var littleEndian = endian === "le"; var res = new ArrayType(reqLength); var b, i; var q = this.clone(); if (!littleEndian) { for (i = 0;i < reqLength - byteLength; i++) { res[i] = 0; } for (i = 0;!q.isZero(); i++) { b = q.andln(255); q.iushrn(8); res[reqLength - i - 1] = b; } } else { for (i = 0;!q.isZero(); i++) { b = q.andln(255); q.iushrn(8); res[i] = b; } for (;i < reqLength; i++) { res[i] = 0; } } return res; }; if (Math.clz32) { BN.prototype._countBits = function _countBits(w) { return 32 - Math.clz32(w); }; } else { BN.prototype._countBits = function _countBits(w) { var t = w; var r = 0; if (t >= 4096) { r += 13; t >>>= 13; } if (t >= 64) { r += 7; t >>>= 7; } if (t >= 8) { r += 4; t >>>= 4; } if (t >= 2) { r += 2; t >>>= 2; } return r + t; }; } BN.prototype._zeroBits = function _zeroBits(w) { if (w === 0) return 26; var t = w; var r = 0; if ((t & 8191) === 0) { r += 13; t >>>= 13; } if ((t & 127) === 0) { r += 7; t >>>= 7; } if ((t & 15) === 0) { r += 4; t >>>= 4; } if ((t & 3) === 0) { r += 2; t >>>= 2; } if ((t & 1) === 0) { r++; } return r; }; BN.prototype.bitLength = function bitLength() { var w = this.words[this.length - 1]; var hi = this._countBits(w); return (this.length - 1) * 26 + hi; }; function toBitArray(num) { var w = new Array(num.bitLength()); for (var bit = 0;bit < w.length; bit++) { var off = bit / 26 | 0; var wbit = bit % 26; w[bit] = (num.words[off] & 1 << wbit) >>> wbit; } return w; } BN.prototype.zeroBits = function zeroBits() { if (this.isZero()) return 0; var r = 0; for (var i = 0;i < this.length; i++) { var b = this._zeroBits(this.words[i]); r += b; if (b !== 26) break; } return r; }; BN.prototype.byteLength = function byteLength() { return Math.ceil(this.bitLength() / 8); }; BN.prototype.toTwos = function toTwos(width) { if (this.negative !== 0) { return this.abs().inotn(width).iaddn(1); } return this.clone(); }; BN.prototype.fromTwos = function fromTwos(width) { if (this.testn(width - 1)) { return this.notn(width).iaddn(1).ineg(); } return this.clone(); }; BN.prototype.isNeg = function isNeg() { return this.negative !== 0; }; BN.prototype.neg = function neg() { return this.clone().ineg(); }; BN.prototype.ineg = function ineg() { if (!this.isZero()) { this.negative ^= 1; } return this; }; BN.prototype.iuor = function iuor(num) { while (this.length < num.length) { this.words[this.length++] = 0; } for (var i = 0;i < num.length; i++) { this.words[i] = this.words[i] | num.words[i]; } return this.strip(); }; BN.prototype.ior = function ior(num) { assert((this.negative | num.negative) === 0); return this.iuor(num); }; BN.prototype.or = function or(num) { if (this.length > num.length) return this.clone().ior(num); return num.clone().ior(this); }; BN.prototype.uor = function uor(num) { if (this.length > num.length) return this.clone().iuor(num); return num.clone().iuor(this); }; BN.prototype.iuand = function iuand(num) { var b; if (this.length > num.length) { b = num; } else { b = this; } for (var i = 0;i < b.length; i++) { this.words[i] = this.words[i] & num.words[i]; } this.length = b.length; return this.strip(); }; BN.prototype.iand = function iand(num) { assert((this.negative | num.negative) === 0); return this.iuand(num); }; BN.prototype.and = function and(num) { if (this.length > num.length) return this.clone().iand(num); return num.clone().iand(this); }; BN.prototype.uand = function uand(num) { if (this.length > num.length) return this.clone().iuand(num); return num.clone().iuand(this); }; BN.prototype.iuxor = function iuxor(num) { var a; var b; if (this.length > num.length) { a = this; b = num; } else { a = num; b = this; } for (var i = 0;i < b.length; i++) { this.words[i] = a.words[i] ^ b.words[i]; } if (this !== a) { for (;i < a.length; i++) { this.words[i] = a.words[i]; } } this.length = a.length; return this.strip(); }; BN.prototype.ixor = function ixor(num) { assert((this.negative | num.negative) === 0); return this.iuxor(num); }; BN.prototype.xor = function xor(num) { if (this.length > num.length) return this.clone().ixor(num); return num.clone().ixor(this); }; BN.prototype.uxor = function uxor(num) { if (this.length > num.length) return this.clone().iuxor(num); return num.clone().iuxor(this); }; BN.prototype.inotn = function inotn(width) { assert(typeof width === "number" && width >= 0); var bytesNeeded = Math.ceil(width / 26) | 0; var bitsLeft = width % 26; this._expand(bytesNeeded); if (bitsLeft > 0) { bytesNeeded--; } for (var i = 0;i < bytesNeeded; i++) { this.words[i] = ~this.words[i] & 67108863; } if (bitsLeft > 0) { this.words[i] = ~this.words[i] & 67108863 >> 26 - bitsLeft; } return this.strip(); }; BN.prototype.notn = function notn(width) { return this.clone().inotn(width); }; BN.prototype.setn = function setn(bit, val) { assert(typeof bit === "number" && bit >= 0); var off = bit / 26 | 0; var wbit = bit % 26; this._expand(off + 1); if (val) { this.words[off] = this.words[off] | 1 << wbit; } else { this.words[off] = this.words[off] & ~(1 << wbit); } return this.strip(); }; BN.prototype.iadd = function iadd(num) { var r; if (this.negative !== 0 && num.negative === 0) { this.negative = 0; r = this.isub(num); this.negative ^= 1; return this._normSign(); } else if (this.negative === 0 && num.negative !== 0) { num.negative = 0; r = this.isub(num); num.negative = 1; return r._normSign(); } var a, b; if (this.length > num.length) { a = this; b = num; } else { a = num; b = this; } var carry = 0; for (var i = 0;i < b.length; i++) { r = (a.words[i] | 0) + (b.words[i] | 0) + carry; this.words[i] = r & 67108863; carry = r >>> 26; } for (;carry !== 0 && i < a.length; i++) { r = (a.words[i] | 0) + carry; this.words[i] = r & 67108863; carry = r >>> 26; } this.length = a.length; if (carry !== 0) { this.words[this.length] = carry; this.length++; } else if (a !== this) { for (;i < a.length; i++) { this.words[i] = a.words[i]; } } return this; }; BN.prototype.add = function add(num) { var res; if (num.negative !== 0 && this.negative === 0) { num.negative = 0; res = this.sub(num); num.negative ^= 1; return res; } else if (num.negative === 0 && this.negative !== 0) { this.negative = 0; res = num.sub(this); this.negative = 1; return res; } if (this.length > num.length) return this.clone().iadd(num); return num.clone().iadd(this); }; BN.prototype.isub = function isub(num) { if (num.negative !== 0) { num.negative = 0; var r = this.iadd(num); num.negative = 1; return r._normSign(); } else if (this.negative !== 0) { this.negative = 0; this.iadd(num); this.negative = 1; return this._normSign(); } var cmp = this.cmp(num); if (cmp === 0) { this.negative = 0; this.length = 1; this.words[0] = 0; return this; } var a, b; if (cmp > 0) { a = this; b = num; } else { a = num; b = this; } var carry = 0; for (var i = 0;i < b.length; i++) { r = (a.words[i] | 0) - (b.words[i] | 0) + carry; carry = r >> 26; this.words[i] = r & 67108863; } for (;carry !== 0 && i < a.length; i++) { r = (a.words[i] | 0) + carry; carry = r >> 26; this.words[i] = r & 67108863; } if (carry === 0 && i < a.length && a !== this) { for (;i < a.length; i++) { this.words[i] = a.words[i]; } } this.length = Math.max(this.length, i); if (a !== this) { this.negative = 1; } return this.strip(); }; BN.prototype.sub = function sub(num) { return this.clone().isub(num); }; function smallMulTo(self2, num, out) { out.negative = num.negative ^ self2.negative; var len = self2.length + num.length | 0; out.length = len; len = len - 1 | 0; var a = self2.words[0] | 0; var b = num.words[0] | 0; var r = a * b; var lo = r & 67108863; var carry = r / 67108864 | 0; out.words[0] = lo; for (var k = 1;k < len; k++) { var ncarry = carry >>> 26; var rword = carry & 67108863; var maxJ = Math.min(k, num.length - 1); for (var j = Math.max(0, k - self2.length + 1);j <= maxJ; j++) { var i = k - j | 0; a = self2.words[i] | 0; b = num.words[j] | 0; r = a * b + rword; ncarry += r / 67108864 | 0; rword = r & 67108863; } out.words[k] = rword | 0; carry = ncarry | 0; } if (carry !== 0) { out.words[k] = carry | 0; } else { out.length--; } return out.strip(); } var comb10MulTo = function comb10MulTo(self2, num, out) { var a = self2.words; var b = num.words; var o = out.words; var c = 0; var lo; var mid; var hi; var a0 = a[0] | 0; var al0 = a0 & 8191; var ah0 = a0 >>> 13; var a1 = a[1] | 0; var al1 = a1 & 8191; var ah1 = a1 >>> 13; var a2 = a[2] | 0; var al2 = a2 & 8191; var ah2 = a2 >>> 13; var a3 = a[3] | 0; var al3 = a3 & 8191; var ah3 = a3 >>> 13; var a4 = a[4] | 0; var al4 = a4 & 8191; var ah4 = a4 >>> 13; var a5 = a[5] | 0; var al5 = a5 & 8191; var ah5 = a5 >>> 13; var a6 = a[6] | 0; var al6 = a6 & 8191; var ah6 = a6 >>> 13; var a7 = a[7] | 0; var al7 = a7 & 8191; var ah7 = a7 >>> 13; var a8 = a[8] | 0; var al8 = a8 & 8191; var ah8 = a8 >>> 13; var a9 = a[9] | 0; var al9 = a9 & 8191; var ah9 = a9 >>> 13; var b0 = b[0] | 0; var bl0 = b0 & 8191; var bh0 = b0 >>> 13; var b1 = b[1] | 0; var bl1 = b1 & 8191; var bh1 = b1 >>> 13; var b2 = b[2] | 0; var bl2 = b2 & 8191; var bh2 = b2 >>> 13; var b3 = b[3] | 0; var bl3 = b3 & 8191; var bh3 = b3 >>> 13; var b4 = b[4] | 0; var bl4 = b4 & 8191; var bh4 = b4 >>> 13; var b5 = b[5] | 0; var bl5 = b5 & 8191; var bh5 = b5 >>> 13; var b6 = b[6] | 0; var bl6 = b6 & 8191; var bh6 = b6 >>> 13; var b7 = b[7] | 0; var bl7 = b7 & 8191; var bh7 = b7 >>> 13; var b8 = b[8] | 0; var bl8 = b8 & 8191; var bh8 = b8 >>> 13; var b9 = b[9] | 0; var bl9 = b9 & 8191; var bh9 = b9 >>> 13; out.negative = self2.negative ^ num.negative; out.length = 19; lo = Math.imul(al0, bl0); mid = Math.imul(al0, bh0); mid = mid + Math.imul(ah0, bl0) | 0; hi = Math.imul(ah0, bh0); var w0 = (c + lo | 0) + ((mid & 8191) << 13) | 0; c = (hi + (mid >>> 13) | 0) + (w0 >>> 26) | 0; w0 &= 67108863; lo = Math.imul(al1, bl0); mid = Math.imul(al1, bh0); mid = mid + Math.imul(ah1, bl0) | 0; hi = Math.imul(ah1, bh0); lo = lo + Math.imul(al0, bl1) | 0; mid = mid + Math.imul(al0, bh1) | 0; mid = mid + Math.imul(ah0, bl1) | 0; hi = hi + Math.imul(ah0, bh1) | 0; var w1 = (c + lo | 0) + ((mid & 8191) << 13) | 0; c = (hi + (mid >>> 13) | 0) + (w1 >>> 26) | 0; w1 &= 67108863; lo = Math.imul(al2, bl0); mid = Math.imul(al2, bh0); mid = mid + Math.imul(ah2, bl0) | 0; hi = Math.imul(ah2, bh0); lo = lo + Math.imul(al1, bl1) | 0; mid = mid + Math.imul(al1, bh1) | 0; mid = mid + Math.imul(ah1, bl1) | 0; hi = hi + Math.imul(ah1, bh1) | 0; lo = lo + Math.imul(al0, bl2) | 0; mid = mid + Math.imul(al0, bh2) | 0; mid = mid + Math.imul(ah0, bl2) | 0; hi = hi + Math.imul(ah0, bh2) | 0; var w2 = (c + lo | 0) + ((mid & 8191) << 13) | 0; c = (hi + (mid >>> 13) | 0) + (w2 >>> 26) | 0; w2 &= 67108863; lo = Math.imul(al3, bl0); mid = Math.imul(al3, bh0); mid = mid + Math.imul(ah3, bl0) | 0; hi = Math.imul(ah3, bh0); lo = lo + Math.imul(al2, bl1) | 0; mid = mid + Math.imul(al2, bh1) | 0; mid = mid + Math.imul(ah2, bl1) | 0; hi = hi + Math.imul(ah2, bh1) | 0; lo = lo + Math.imul(al1, bl2) | 0; mid = mid + Math.imul(al1, bh2) | 0; mid = mid + Math.imul(ah1, bl2) | 0; hi = hi + Math.imul(ah1, bh2) | 0; lo = lo + Math.imul(al0, bl3) | 0; mid = mid + Math.imul(al0, bh3) | 0; mid = mid + Math.imul(ah0, bl3) | 0; hi = hi + Math.imul(ah0, bh3) | 0; var w3 = (c + lo | 0) + ((mid & 8191) << 13) | 0; c = (hi + (mid >>> 13) | 0) + (w3 >>> 26) | 0; w3 &= 67108863; lo = Math.imul(al4, bl0); mid = Math.imul(al4, bh0); mid = mid + Math.imul(ah4, bl0) | 0; hi = Math.imul(ah4, bh0); lo = lo + Math.imul(al3, bl1) | 0; mid = mid + Math.imul(al3, bh1) | 0; mid = mid + Math.imul(ah3, bl1) | 0; hi = hi + Math.imul(ah3, bh1) | 0; lo = lo + Math.imul(al2, bl2) | 0; mid = mid + Math.imul(al2, bh2) | 0; mid = mid + Math.imul(ah2, bl2) | 0; hi = hi + Math.imul(ah2, bh2) | 0; lo = lo + Math.imul(al1, bl3) | 0; mid = mid + Math.imul(al1, bh3) | 0; mid = mid + Math.imul(ah1, bl3) | 0; hi = hi + Math.imul(ah1, bh3) | 0; lo = lo + Math.imul(al0, bl4) | 0; mid = mid + Math.imul(al0, bh4) | 0; mid = mid + Math.imul(ah0, bl4) | 0; hi = hi + Math.imul(ah0, bh4) | 0; var w4 = (c + lo | 0) + ((mid & 8191) << 13) | 0; c = (hi + (mid >>> 13) | 0) + (w4 >>> 26) | 0; w4 &= 67108863; lo = Math.imul(al5, bl0); mid = Math.imul(al5, bh0); mid = mid + Math.imul(ah5, bl0) | 0; hi = Math.imul(ah5, bh0); lo = lo + Math.imul(al4, bl1) | 0; mid = mid + Math.imul(al4, bh1) | 0; mid = mid + Math.imul(ah4, bl1) | 0; hi = hi + Math.imul(ah4, bh1) | 0; lo = lo + Math.imul(al3, bl2) | 0; mid = mid + Math.imul(al3, bh2) | 0; mid = mid + Math.imul(ah3, bl2) | 0; hi = hi + Math.imul(ah3, bh2) | 0; lo = lo + Math.imul(al2, bl3) | 0; mid = mid + Math.imul(al2, bh3) | 0; mid = mid + Math.imul(ah2, bl3) | 0; hi = hi + Math.imul(ah2, bh3) | 0; lo = lo + Math.imul(al1, bl4) | 0; mid = mid + Math.imul(al1, bh4) | 0; mid = mid + Math.imul(ah1, bl4) | 0; hi = hi + Math.imul(ah1, bh4) | 0; lo = lo + Math.imul(al0, bl5) | 0; mid = mid + Math.imul(al0, bh5) | 0; mid = mid + Math.imul(ah0, bl5) | 0; hi = hi + Math.imul(ah0, bh5) | 0; var w5 = (c + lo | 0) + ((mid & 8191) << 13) | 0; c = (hi + (mid >>> 13) | 0) + (w5 >>> 26) | 0; w5 &= 67108863; lo = Math.imul(al6, bl0); mid = Math.imul(al6, bh0); mid = mid + Math.imul(ah6, bl0) | 0; hi = Math.imul(ah6, bh0); lo = lo + Math.imul(al5, bl1) | 0; mid = mid + Math.imul(al5, bh1) | 0; mid = mid + Math.imul(ah5, bl1) | 0; hi = hi + Math.imul(ah5, bh1) | 0; lo = lo + Math.imul(al4, bl2) | 0; mid = mid + Math.imul(al4, bh2) | 0; mid = mid + Math.imul(ah4, bl2) | 0; hi = hi + Math.imul(ah4, bh2) | 0; lo = lo + Math.imul(al3, bl3) | 0; mid = mid + Math.imul(al3, bh3) | 0; mid = mid + Math.imul(ah3, bl3) | 0; hi = hi + Math.imul(ah3, bh3) | 0; lo = lo + Math.imul(al2, bl4) | 0; mid = mid + Math.imul(al2, bh4) | 0; mid = mid + Math.imul(ah2, bl4) | 0; hi = hi + Math.imul(ah2, bh4) | 0; lo = lo + Math.imul(al1, bl5) | 0; mid = mid + Math.imul(al1, bh5) | 0; mid = mid + Math.imul(ah1, bl5) | 0; hi = hi + Math.imul(ah1, bh5) | 0; lo = lo + Math.imul(al0, bl6) | 0; mid = mid + Math.imul(al0, bh6) | 0; mid = mid + Math.imul(ah0, bl6) | 0; hi = hi + Math.imul(ah0, bh6) | 0; var w6 = (c + lo | 0) + ((mid & 8191) << 13) | 0; c = (hi + (mid >>> 13) | 0) + (w6 >>> 26) | 0; w6 &= 67108863; lo = Math.imul(al7, bl0); mid = Math.imul(al7, bh0); mid = mid + Math.imul(ah7, bl0) | 0; hi = Math.imul(ah7, bh0); lo = lo + Math.imul(al6, bl1) | 0; mid = mid + Math.imul(al6, bh1) | 0; mid = mid + Math.imul(ah6, bl1) | 0; hi = hi + Math.imul(ah6, bh1) | 0; lo = lo + Math.imul(al5, bl2) | 0; mid = mid + Math.imul(al5, bh2) | 0; mid = mid + Math.imul(ah5, bl2) | 0; hi = hi + Math.imul(ah5, bh2) | 0; lo = lo + Math.imul(al4, bl3) | 0; mid = mid + Math.imul(al4, bh3) | 0; mid = mid + Math.imul(ah4, bl3) | 0; hi = hi + Math.imul(ah4, bh3) | 0; lo = lo + Math.imul(al3, bl4) | 0; mid = mid + Math.imul(al3, bh4) | 0; mid = mid + Math.imul(ah3, bl4) | 0; hi = hi + Math.imul(ah3, bh4) | 0; lo = lo + Math.imul(al2, bl5) | 0; mid = mid + Math.imul(al2, bh5) | 0; mid = mid + Math.imul(ah2, bl5) | 0; hi = hi + Math.imul(ah2, bh5) | 0; lo = lo + Math.imul(al1, bl6) | 0; mid = mid + Math.imul(al1, bh6) | 0; mid = mid + Math.imul(ah1, bl6) | 0; hi = hi + Math.imul(ah1, bh6) | 0; lo = lo + Math.imul(al0, bl7) | 0; mid = mid + Math.imul(al0, bh7) | 0; mid = mid + Math.imul(ah0, bl7) | 0; hi = hi + Math.imul(ah0, bh7) | 0; var w7 = (c + lo | 0) + ((mid & 8191) << 13) | 0; c = (hi + (mid >>> 13) | 0) + (w7 >>> 26) | 0; w7 &= 67108863; lo = Math.imul(al8, bl0); mid = Math.imul(al8, bh0); mid = mid + Math.imul(ah8, bl0) | 0; hi = Math.imul(ah8, bh0); lo = lo + Math.imul(al7, bl1) | 0; mid = mid + Math.imul(al7, bh1) | 0; mid = mid + Math.imul(ah7, bl1) | 0; hi = hi + Math.imul(ah7, bh1) | 0; lo = lo + Math.imul(al6, bl2) | 0; mid = mid + Math.imul(al6, bh2) | 0; mid = mid + Math.imul(ah6, bl2) | 0; hi = hi + Math.imul(ah6, bh2) | 0; lo = lo + Math.imul(al5, bl3) | 0; mid = mid + Math.imul(al5, bh3) | 0; mid = mid + Math.imul(ah5, bl3) | 0; hi = hi + Math.imul(ah5, bh3) | 0; lo = lo + Math.imul(al4, bl4) | 0; mid = mid + Math.imul(al4, bh4) | 0; mid = mid + Math.imul(ah4, bl4) | 0; hi = hi + Math.imul(ah4, bh4) | 0; lo = lo + Math.imul(al3, bl5) | 0; mid = mid + Math.imul(al3, bh5) | 0; mid = mid + Math.imul(ah3, bl5) | 0; hi = hi + Math.imul(ah3, bh5) | 0; lo = lo + Math.imul(al2, bl6) | 0; mid = mid + Math.imul(al2, bh6) | 0; mid = mid + Math.imul(ah2, bl6) | 0; hi = hi + Math.imul(ah2, bh6) | 0; lo = lo + Math.imul(al1, bl7) | 0; mid = mid + Math.imul(al1, bh7) | 0; mid = mid + Math.imul(ah1, bl7) | 0; hi = hi + Math.imul(ah1, bh7) | 0; lo = lo + Math.imul(al0, bl8) | 0; mid = mid + Math.imul(al0, bh8) | 0; mid = mid + Math.imul(ah0, bl8) | 0; hi = hi + Math.imul(ah0, bh8) | 0; var w8 = (c + lo | 0) + ((mid & 8191) << 13) | 0; c = (hi + (mid >>> 13) | 0) + (w8 >>> 26) | 0; w8 &= 67108863; lo = Math.imul(al9, bl0); mid = Math.imul(al9, bh0); mid = mid + Math.imul(ah9, bl0) | 0; hi = Math.imul(ah9, bh0); lo = lo + Math.imul(al8, bl1) | 0; mid = mid + Math.imul(al8, bh1) | 0; mid = mid + Math.imul(ah8, bl1) | 0; hi = hi + Math.imul(ah8, bh1) | 0; lo = lo + Math.imul(al7, bl2) | 0; mid = mid + Math.imul(al7, bh2) | 0; mid = mid + Math.imul(ah7, bl2) | 0; hi = hi + Math.imul(ah7, bh2) | 0; lo = lo + Math.imul(al6, bl3) | 0; mid = mid + Math.imul(al6, bh3) | 0; mid = mid + Math.imul(ah6, bl3) | 0; hi = hi + Math.imul(ah6, bh3) | 0; lo = lo + Math.imul(al5, bl4) | 0; mid = mid + Math.imul(al5, bh4) | 0; mid = mid + Math.imul(ah5, bl4) | 0; hi = hi + Math.imul(ah5, bh4) | 0; lo = lo + Math.imul(al4, bl5) | 0; mid = mid + Math.imul(al4, bh5) | 0; mid = mid + Math.imul(ah4, bl5) | 0; hi = hi + Math.imul(ah4, bh5) | 0; lo = lo + Math.imul(al3, bl6) | 0; mid = mid + Math.imul(al3, bh6) | 0; mid = mid + Math.imul(ah3, bl6) | 0; hi = hi + Math.imul(ah3, bh6) | 0; lo = lo + Math.imul(al2, bl7) | 0; mid = mid + Math.imul(al2, bh7) | 0; mid = mid + Math.imul(ah2, bl7) | 0; hi = hi + Math.imul(ah2, bh7) | 0; lo = lo + Math.imul(al1, bl8) | 0; mid = mid + Math.imul(al1, bh8) | 0; mid = mid + Math.imul(ah1, bl8) | 0; hi = hi + Math.imul(ah1, bh8) | 0; lo = lo + Math.imul(al0, bl9) | 0; mid = mid + Math.imul(al0, bh9) | 0; mid = mid + Math.imul(ah0, bl9) | 0; hi = hi + Math.imul(ah0, bh9) | 0; var w9 = (c + lo | 0) + ((mid & 8191) << 13) | 0; c = (hi + (mid >>> 13) | 0) + (w9 >>> 26) | 0; w9 &= 67108863; lo = Math.imul(al9, bl1); mid = Math.imul(al9, bh1); mid = mid + Math.imul(ah9, bl1) | 0; hi = Math.imul(ah9, bh1); lo = lo + Math.imul(al8, bl2) | 0; mid = mid + Math.imul(al8, bh2) | 0; mid = mid + Math.imul(ah8, bl2) | 0; hi = hi + Math.imul(ah8, bh2) | 0; lo = lo + Math.imul(al7, bl3) | 0; mid = mid + Math.imul(al7, bh3) | 0; mid = mid + Math.imul(ah7, bl3) | 0; hi = hi + Math.imul(ah7, bh3) | 0; lo = lo + Math.imul(al6, bl4) | 0; mid = mid + Math.imul(al6, bh4) | 0; mid = mid + Math.imul(ah6, bl4) | 0; hi = hi + Math.imul(ah6, bh4) | 0; lo = lo + Math.imul(al5, bl5) | 0; mid = mid + Math.imul(al5, bh5) | 0; mid = mid + Math.imul(ah5, bl5) | 0; hi = hi + Math.imul(ah5, bh5) | 0; lo = lo + Math.imul(al4, bl6) | 0; mid = mid + Math.imul(al4, bh6) | 0; mid = mid + Math.imul(ah4, bl6) | 0; hi = hi + Math.imul(ah4, bh6) | 0; lo = lo + Math.imul(al3, bl7) | 0; mid = mid + Math.imul(al3, bh7) | 0; mid = mid + Math.imul(ah3, bl7) | 0; hi = hi + Math.imul(ah3, bh7) | 0; lo = lo + Math.imul(al2, bl8) | 0; mid = mid + Math.imul(al2, bh8) | 0; mid = mid + Math.imul(ah2, bl8) | 0; hi = hi + Math.imul(ah2, bh8) | 0; lo = lo + Math.imul(al1, bl9) | 0; mid = mid + Math.imul(al1, bh9) | 0; mid = mid + Math.imul(ah1, bl9) | 0; hi = hi + Math.imul(ah1, bh9) | 0; var w10 = (c + lo | 0) + ((mid & 8191) << 13) | 0; c = (hi + (mid >>> 13) | 0) + (w10 >>> 26) | 0; w10 &= 67108863; lo = Math.imul(al9, bl2); mid = Math.imul(al9, bh2); mid = mid + Math.imul(ah9, bl2) | 0; hi = Math.imul(ah9, bh2); lo = lo + Math.imul(al8, bl3) | 0; mid = mid + Math.imul(al8, bh3) | 0; mid = mid + Math.imul(ah8, bl3) | 0; hi = hi + Math.imul(ah8, bh3) | 0; lo = lo + Math.imul(al7, bl4) | 0; mid = mid + Math.imul(al7, bh4) | 0; mid = mid + Math.imul(ah7, bl4) | 0; hi = hi + Math.imul(ah7, bh4) | 0; lo = lo + Math.imul(al6, bl5) | 0; mid = mid + Math.imul(al6, bh5) | 0; mid = mid + Math.imul(ah6, bl5) | 0; hi = hi + Math.imul(ah6, bh5) | 0; lo = lo + Math.imul(al5, bl6) | 0; mid = mid + Math.imul(al5, bh6) | 0; mid = mid + Math.imul(ah5, bl6) | 0; hi = hi + Math.imul(ah5, bh6) | 0; lo = lo + Math.imul(al4, bl7) | 0; mid = mid + Math.imul(al4, bh7) | 0; mid = mid + Math.imul(ah4, bl7) | 0; hi = hi + Math.imul(ah4, bh7) | 0; lo = lo + Math.imul(al3, bl8) | 0; mid = mid + Math.imul(al3, bh8) | 0; mid = mid + Math.imul(ah3, bl8) | 0; hi = hi + Math.imul(ah3, bh8) | 0; lo = lo + Math.imul(al2, bl9) | 0; mid = mid + Math.imul(al2, bh9) | 0; mid = mid + Math.imul(ah2, bl9) | 0; hi = hi + Math.imul(ah2, bh9) | 0; var w11 = (c + lo | 0) + ((mid & 8191) << 13) | 0; c = (hi + (mid >>> 13) | 0) + (w11 >>> 26) | 0; w11 &= 67108863; lo = Math.imul(al9, bl3); mid = Math.imul(al9, bh3); mid = mid + Math.imul(ah9, bl3) | 0; hi = Math.imul(ah9, bh3); lo = lo + Math.imul(al8, bl4) | 0; mid = mid + Math.imul(al8, bh4) | 0; mid = mid + Math.imul(ah8, bl4) | 0; hi = hi + Math.imul(ah8, bh4) | 0; lo = lo + Math.imul(al7, bl5) | 0; mid = mid + Math.imul(al7, bh5) | 0; mid = mid + Math.imul(ah7, bl5) | 0; hi = hi + Math.imul(ah7, bh5) | 0; lo = lo + Math.imul(al6, bl6) | 0; mid = mid + Math.imul(al6, bh6) | 0; mid = mid + Math.imul(ah6, bl6) | 0; hi = hi + Math.imul(ah6, bh6) | 0; lo = lo + Math.imul(al5, bl7) | 0; mid = mid + Math.imul(al5, bh7) | 0; mid = mid + Math.imul(ah5, bl7) | 0; hi = hi + Math.imul(ah5, bh7) | 0; lo = lo + Math.imul(al4, bl8) | 0; mid = mid + Math.imul(al4, bh8) | 0; mid = mid + Math.imul(ah4, bl8) | 0; hi = hi + Math.imul(ah4, bh8) | 0; lo = lo + Math.imul(al3, bl9) | 0; mid = mid + Math.imul(al3, bh9) | 0; mid = mid + Math.imul(ah3, bl9) | 0; hi = hi + Math.imul(ah3, bh9) | 0; var w12 = (c + lo | 0) + ((mid & 8191) << 13) | 0; c = (hi + (mid >>> 13) | 0) + (w12 >>> 26) | 0; w12 &= 67108863; lo = Math.imul(al9, bl4); mid = Math.imul(al9, bh4); mid = mid + Math.imul(ah9, bl4) | 0; hi = Math.imul(ah9, bh4); lo = lo + Math.imul(al8, bl5) | 0; mid = mid + Math.imul(al8, bh5) | 0; mid = mid + Math.imul(ah8, bl5) | 0; hi = hi + Math.imul(ah8, bh5) | 0; lo = lo + Math.imul(al7, bl6) | 0; mid = mid + Math.imul(al7, bh6) | 0; mid = mid + Math.imul(ah7, bl6) | 0; hi = hi + Math.imul(ah7, bh6) | 0; lo = lo + Math.imul(al6, bl7) | 0; mid = mid + Math.imul(al6, bh7) | 0; mid = mid + Math.imul(ah6, bl7) | 0; hi = hi + Math.imul(ah6, bh7) | 0; lo = lo + Math.imul(al5, bl8) | 0; mid = mid + Math.imul(al5, bh8) | 0; mid = mid + Math.imul(ah5, bl8) | 0; hi = hi + Math.imul(ah5, bh8) | 0; lo = lo + Math.imul(al4, bl9) | 0; mid = mid + Math.imul(al4, bh9) | 0; mid = mid + Math.imul(ah4, bl9) | 0; hi = hi + Math.imul(ah4, bh9) | 0; var w13 = (c + lo | 0) + ((mid & 8191) << 13) | 0; c = (hi + (mid >>> 13) | 0) + (w13 >>> 26) | 0; w13 &= 67108863; lo = Math.imul(al9, bl5); mid = Math.imul(al9, bh5); mid = mid + Math.imul(ah9, bl5) | 0; hi = Math.imul(ah9, bh5); lo = lo + Math.imul(al8, bl6) | 0; mid = mid + Math.imul(al8, bh6) | 0; mid = mid + Math.imul(ah8, bl6) | 0; hi = hi + Math.imul(ah8, bh6) | 0; lo = lo + Math.imul(al7, bl7) | 0; mid = mid + Math.imul(al7, bh7) | 0; mid = mid + Math.imul(ah7, bl7) | 0; hi = hi + Math.imul(ah7, bh7) | 0; lo = lo + Math.imul(al6, bl8) | 0; mid = mid + Math.imul(al6, bh8) | 0; mid = mid + Math.imul(ah6, bl8) | 0; hi = hi + Math.imul(ah6, bh8) | 0; lo = lo + Math.imul(al5, bl9) | 0; mid = mid + Math.imul(al5, bh9) | 0; mid = mid + Math.imul(ah5, bl9) | 0; hi = hi + Math.imul(ah5, bh9) | 0; var w14 = (c + lo | 0) + ((mid & 8191) << 13) | 0; c = (hi + (mid >>> 13) | 0) + (w14 >>> 26) | 0; w14 &= 67108863; lo = Math.imul(al9, bl6); mid = Math.imul(al9, bh6); mid = mid + Math.imul(ah9, bl6) | 0; hi = Math.imul(ah9, bh6); lo = lo + Math.imul(al8, bl7) | 0; mid = mid + Math.imul(al8, bh7) | 0; mid = mid + Math.imul(ah8, bl7) | 0; hi = hi + Math.imul(ah8, bh7) | 0; lo = lo + Math.imul(al7, bl8) | 0; mid = mid + Math.imul(al7, bh8) | 0; mid = mid + Math.imul(ah7, bl8) | 0; hi = hi + Math.imul(ah7, bh8) | 0; lo = lo + Math.imul(al6, bl9) | 0; mid = mid + Math.imul(al6, bh9) | 0; mid = mid + Math.imul(ah6, bl9) | 0; hi = hi + Math.imul(ah6, bh9) | 0; var w15 = (c + lo | 0) + ((mid & 8191) << 13) | 0; c = (hi + (mid >>> 13) | 0) + (w15 >>> 26) | 0; w15 &= 67108863; lo = Math.imul(al9, bl7); mid = Math.imul(al9, bh7); mid = mid + Math.imul(ah9, bl7) | 0; hi = Math.imul(ah9, bh7); lo = lo + Math.imul(al8, bl8) | 0; mid = mid + Math.imul(al8, bh8) | 0; mid = mid + Math.imul(ah8, bl8) | 0; hi = hi + Math.imul(ah8, bh8) | 0; lo = lo + Math.imul(al7, bl9) | 0; mid = mid + Math.imul(al7, bh9) | 0; mid = mid + Math.imul(ah7, bl9) | 0; hi = hi + Math.imul(ah7, bh9) | 0; var w16 = (c + lo | 0) + ((mid & 8191) << 13) | 0; c = (hi + (mid >>> 13) | 0) + (w16 >>> 26) | 0; w16 &= 67108863; lo = Math.imul(al9, bl8); mid = Math.imul(al9, bh8); mid = mid + Math.imul(ah9, bl8) | 0; hi = Math.imul(ah9, bh8); lo = lo + Math.imul(al8, bl9) | 0; mid = mid + Math.imul(al8, bh9) | 0; mid = mid + Math.imul(ah8, bl9) | 0; hi = hi + Math.imul(ah8, bh9) | 0; var w17 = (c + lo | 0) + ((mid & 8191) << 13) | 0; c = (hi + (mid >>> 13) | 0) + (w17 >>> 26) | 0; w17 &= 67108863; lo = Math.imul(al9, bl9); mid = Math.imul(al9, bh9); mid = mid + Math.imul(ah9, bl9) | 0; hi = Math.imul(ah9, bh9); var w18 = (c + lo | 0) + ((mid & 8191) << 13) | 0; c = (hi + (mid >>> 13) | 0) + (w18 >>> 26) | 0; w18 &= 67108863; o[0] = w0; o[1] = w1; o[2] = w2; o[3] = w3; o[4] = w4; o[5] = w5; o[6] = w6; o[7] = w7; o[8] = w8; o[9] = w9; o[10] = w10; o[11] = w11; o[12] = w12; o[13] = w13; o[14] = w14; o[15] = w15; o[16] = w16; o[17] = w17; o[18] = w18; if (c !== 0) { o[19] = c; out.length++; } return out; }; if (!Math.imul) { comb10MulTo = smallMulTo; } function bigMulTo(self2, num, out) { out.negative = num.negative ^ self2.negative; out.length = self2.length + num.length; var carry = 0; var hncarry = 0; for (var k = 0;k < out.length - 1; k++) { var ncarry = hncarry; hncarry = 0; var rword = carry & 67108863; var maxJ = Math.min(k, num.length - 1); for (var j = Math.max(0, k - self2.length + 1);j <= maxJ; j++) { var i = k - j; var a = self2.words[i] | 0; var b = num.words[j] | 0; var r = a * b; var lo = r & 67108863; ncarry = ncarry + (r / 67108864 | 0) | 0; lo = lo + rword | 0; rword = lo & 67108863; ncarry = ncarry + (lo >>> 26) | 0; hncarry += ncarry >>> 26; ncarry &= 67108863; } out.words[k] = rword; carry = ncarry; ncarry = hncarry; } if (carry !== 0) { out.words[k] = carry; } else { out.length--; } return out.strip(); } function jumboMulTo(self2, num, out) { var fftm = new FFTM; return fftm.mulp(self2, num, out); } BN.prototype.mulTo = function mulTo(num, out) { var res; var len = this.length + num.length; if (this.length === 10 && num.length === 10) { res = comb10MulTo(this, num, out); } else if (len < 63) { res = smallMulTo(this, num, out); } else if (len < 1024) { res = bigMulTo(this, num, out); } else { res = jumboMulTo(this, num, out); } return res; }; function FFTM(x, y) { this.x = x; this.y = y; } FFTM.prototype.makeRBT = function makeRBT(N) { var t = new Array(N); var l = BN.prototype._countBits(N) - 1; for (var i = 0;i < N; i++) { t[i] = this.revBin(i, l, N); } return t; }; FFTM.prototype.revBin = function revBin(x, l, N) { if (x === 0 || x === N - 1) return x; var rb = 0; for (var i = 0;i < l; i++) { rb |= (x & 1) << l - i - 1; x >>= 1; } return rb; }; FFTM.prototype.permute = function permute(rbt, rws, iws, rtws, itws, N) { for (var i = 0;i < N; i++) { rtws[i] = rws[rbt[i]]; itws[i] = iws[rbt[i]]; } }; FFTM.prototype.transform = function transform(rws, iws, rtws, itws, N, rbt) { this.permute(rbt, rws, iws, rtws, itws, N); for (var s = 1;s < N; s <<= 1) { var l = s << 1; var rtwdf = Math.cos(2 * Math.PI / l); var itwdf = Math.sin(2 * Math.PI / l); for (var p = 0;p < N; p += l) { var rtwdf_ = rtwdf; var itwdf_ = itwdf; for (var j = 0;j < s; j++) { var re = rtws[p + j]; var ie = itws[p + j]; var ro = rtws[p + j + s]; var io = itws[p + j + s]; var rx = rtwdf_ * ro - itwdf_ * io; io = rtwdf_ * io + itwdf_ * ro; ro = rx; rtws[p + j] = re + ro; itws[p + j] = ie + io; rtws[p + j + s] = re - ro; itws[p + j + s] = ie - io; if (j !== l) { rx = rtwdf * rtwdf_ - itwdf * itwdf_; itwdf_ = rtwdf * itwdf_ + itwdf * rtwdf_; rtwdf_ = rx; } } } } }; FFTM.prototype.guessLen13b = function guessLen13b(n, m) { var N = Math.max(m, n) | 1; var odd = N & 1; var i = 0; for (N = N / 2 | 0;N; N = N >>> 1) { i++; } return 1 << i + 1 + odd; }; FFTM.prototype.conjugate = function conjugate(rws, iws, N) { if (N <= 1) return; for (var i = 0;i < N / 2; i++) { var t = rws[i]; rws[i] = rws[N - i - 1]; rws[N - i - 1] = t; t = iws[i]; iws[i] = -iws[N - i - 1]; iws[N - i - 1] = -t; } }; FFTM.prototype.normalize13b = function normalize13b(ws, N) { var carry = 0; for (var i = 0;i < N / 2; i++) { var w = Math.round(ws[2 * i + 1] / N) * 8192 + Math.round(ws[2 * i] / N) + carry; ws[i] = w & 67108863; if (w < 67108864) { carry = 0; } else { carry = w / 67108864 | 0; } } return ws; }; FFTM.prototype.convert13b = function convert13b(ws, len, rws, N) { var carry = 0; for (var i = 0;i < len; i++) { carry = carry + (ws[i] | 0); rws[2 * i] = carry & 8191; carry = carry >>> 13; rws[2 * i + 1] = carry & 8191; carry = carry >>> 13; } for (i = 2 * len;i < N; ++i) { rws[i] = 0; } assert(carry === 0); assert((carry & ~8191) === 0); }; FFTM.prototype.stub = function stub(N) { var ph = new Array(N); for (var i = 0;i < N; i++) { ph[i] = 0; } return ph; }; FFTM.prototype.mulp = function mulp(x, y, out) { var N = 2 * this.guessLen13b(x.length, y.length); var rbt = this.makeRBT(N); var _ = this.stub(N); var rws = new Array(N); var rwst = new Array(N); var iwst = new Array(N); var nrws = new Array(N); var nrwst = new Array(N); var niwst = new Array(N); var rmws = out.words; rmws.length = N; this.convert13b(x.words, x.length, rws, N); this.convert13b(y.words, y.length, nrws, N); this.transform(rws, _, rwst, iwst, N, rbt); this.transform(nrws, _, nrwst, niwst, N, rbt); for (var i = 0;i < N; i++) { var rx = rwst[i] * nrwst[i] - iwst[i] * niwst[i]; iwst[i] = rwst[i] * niwst[i] + iwst[i] * nrwst[i]; rwst[i] = rx; } this.conjugate(rwst, iwst, N); this.transform(rwst, iwst, rmws, _, N, rbt); this.conjugate(rmws, _, N); this.normalize13b(rmws, N); out.negative = x.negative ^ y.negative; out.length = x.length + y.length; return out.strip(); }; BN.prototype.mul = function mul(num) { var out = new BN(null); out.words = new Array(this.length + num.length); return this.mulTo(num, out); }; BN.prototype.mulf = function mulf(num) { var out = new BN(null); out.words = new Array(this.length + num.length); return jumboMulTo(this, num, out); }; BN.prototype.imul = function imul(num) { return this.clone().mulTo(num, this); }; BN.prototype.imuln = function imuln(num) { assert(typeof num === "number"); assert(num < 67108864); var carry = 0; for (var i = 0;i < this.length; i++) { var w = (this.words[i] | 0) * num; var lo = (w & 67108863) + (carry & 67108863); carry >>= 26; carry += w / 67108864 | 0; carry += lo >>> 26; this.words[i] = lo & 67108863; } if (carry !== 0) { this.words[i] = carry; this.length++; } this.length = num === 0 ? 1 : this.length; return this; }; BN.prototype.muln = function muln(num) { return this.clone().imuln(num); }; BN.prototype.sqr = function sqr() { return this.mul(this); }; BN.prototype.isqr = function isqr() { return this.imul(this.clone()); }; BN.prototype.pow = function pow(num) { var w = toBitArray(num); if (w.length === 0) return new BN(1); var res = this; for (var i = 0;i < w.length; i++, res = res.sqr()) { if (w[i] !== 0) break; } if (++i < w.length) { for (var q = res.sqr();i < w.length; i++, q = q.sqr()) { if (w[i] === 0) continue; res = res.mul(q); } } return res; }; BN.prototype.iushln = function iushln(bits) { assert(typeof bits === "number" && bits >= 0); var r = bits % 26; var s = (bits - r) / 26; var carryMask = 67108863 >>> 26 - r << 26 - r; var i; if (r !== 0) { var carry = 0; for (i = 0;i < this.length; i++) { var newCarry = this.words[i] & carryMask; var c = (this.words[i] | 0) - newCarry << r; this.words[i] = c | carry; carry = newCarry >>> 26 - r; } if (carry) { this.words[i] = carry; this.length++; } } if (s !== 0) { for (i = this.length - 1;i >= 0; i--) { this.words[i + s] = this.words[i]; } for (i = 0;i < s; i++) { this.words[i] = 0; } this.length += s; } return this.strip(); }; BN.prototype.ishln = function ishln(bits) { assert(this.negative === 0); return this.iushln(bits); }; BN.prototype.iushrn = function iushrn(bits, hint, extended) { assert(typeof bits === "number" && bits >= 0); var h; if (hint) { h = (hint - hint % 26) / 26; } else { h = 0; } var r = bits % 26; var s = Math.min((bits - r) / 26, this.length); var mask = 67108863 ^ 67108863 >>> r << r; var maskedWords = extended; h -= s; h = Math.max(0, h); if (maskedWords) { for (var i = 0;i < s; i++) { maskedWords.words[i] = this.words[i]; } maskedWords.length = s; } if (s === 0) {} else if (this.length > s) { this.length -= s; for (i = 0;i < this.length; i++) { this.words[i] = this.words[i + s]; } } else { this.words[0] = 0; this.length = 1; } var carry = 0; for (i = this.length - 1;i >= 0 && (carry !== 0 || i >= h); i--) { var word = this.words[i] | 0; this.words[i] = carry << 26 - r | word >>> r; carry = word & mask; } if (maskedWords && carry !== 0) { maskedWords.words[maskedWords.length++] = carry; } if (this.length === 0) { this.words[0] = 0; this.length = 1; } return this.strip(); }; BN.prototype.ishrn = function ishrn(bits, hint, extended) { assert(this.negative === 0); return this.iushrn(bits, hint, extended); }; BN.prototype.shln = function shln(bits) { return this.clone().ishln(bits); }; BN.prototype.ushln = function ushln(bits) { return this.clone().iushln(bits); }; BN.prototype.shrn = function shrn(bits) { return this.clone().ishrn(bits); }; BN.prototype.ushrn = function ushrn(bits) { return this.clone().iushrn(bits); }; BN.prototype.testn = function testn(bit) { assert(typeof bit === "number" && bit >= 0); var r = bit % 26; var s = (bit - r) / 26; var q = 1 << r; if (this.length <= s) return false; var w = this.words[s]; return !!(w & q); }; BN.prototype.imaskn = function imaskn(bits) { assert(typeof bits === "number" && bits >= 0); var r = bits % 26; var s = (bits - r) / 26; assert(this.negative === 0, "imaskn works only with positive numbers"); if (this.length <= s) { return this; } if (r !== 0) { s++; } this.length = Math.min(s, this.length); if (r !== 0) { var mask = 67108863 ^ 67108863 >>> r << r; this.words[this.length - 1] &= mask; } return this.strip(); }; BN.prototype.maskn = function maskn(bits) { return this.clone().imaskn(bits); }; BN.prototype.iaddn = function iaddn(num) { assert(typeof num === "number"); assert(num < 67108864); if (num < 0) return this.isubn(-num); if (this.negative !== 0) { if (this.length === 1 && (this.words[0] | 0) < num) { this.words[0] = num - (this.words[0] | 0); this.negative = 0; return this; } this.negative = 0; this.isubn(num); this.negative = 1; return this; } return this._iaddn(num); }; BN.prototype._iaddn = function _iaddn(num) { this.words[0] += num; for (var i = 0;i < this.length && this.words[i] >= 67108864; i++) { this.words[i] -= 67108864; if (i === this.length - 1) { this.words[i + 1] = 1; } else { this.words[i + 1]++; } } this.length = Math.max(this.length, i + 1); return this; }; BN.prototype.isubn = function isubn(num) { assert(typeof num === "number"); assert(num < 67108864); if (num < 0) return this.iaddn(-num); if (this.negative !== 0) { this.negative = 0; this.iaddn(num); this.negative = 1; return this; } this.words[0] -= num; if (this.length === 1 && this.words[0] < 0) { this.words[0] = -this.words[0]; this.negative = 1; } else { for (var i = 0;i < this.length && this.words[i] < 0; i++) { this.words[i] += 67108864; this.words[i + 1] -= 1; } } return this.strip(); }; BN.prototype.addn = function addn(num) { return this.clone().iaddn(num); }; BN.prototype.subn = function subn(num) { return this.clone().isubn(num); }; BN.prototype.iabs = function iabs() { this.negative = 0; return this; }; BN.prototype.abs = function abs() { return this.clone().iabs(); }; BN.prototype._ishlnsubmul = function _ishlnsubmul(num, mul, shift) { var len = num.length + shift; var i; this._expand(len); var w; var carry = 0; for (i = 0;i < num.length; i++) { w = (this.words[i + shift] | 0) + carry; var right = (num.words[i] | 0) * mul; w -= right & 67108863; carry = (w >> 26) - (right / 67108864 | 0); this.words[i + shift] = w & 67108863; } for (;i < this.length - shift; i++) { w = (this.words[i + shift] | 0) + carry; carry = w >> 26; this.words[i + shift] = w & 67108863; } if (carry === 0) return this.strip(); assert(carry === -1); carry = 0; for (i = 0;i < this.length; i++) { w = -(this.words[i] | 0) + carry; carry = w >> 26; this.words[i] = w & 67108863; } this.negative = 1; return this.strip(); }; BN.prototype._wordDiv = function _wordDiv(num, mode) { var shift = this.length - num.length; var a = this.clone(); var b = num; var bhi = b.words[b.length - 1] | 0; var bhiBits = this._countBits(bhi); shift = 26 - bhiBits; if (shift !== 0) { b = b.ushln(shift); a.iushln(shift); bhi = b.words[b.length - 1] | 0; } var m = a.length - b.length; var q; if (mode !== "mod") { q = new BN(null); q.length = m + 1; q.words = new Array(q.length); for (var i = 0;i < q.length; i++) { q.words[i] = 0; } } var diff = a.clone()._ishlnsubmul(b, 1, m); if (diff.negative === 0) { a = diff; if (q) { q.words[m] = 1; } } for (var j = m - 1;j >= 0; j--) { var qj = (a.words[b.length + j] | 0) * 67108864 + (a.words[b.length + j - 1] | 0); qj = Math.min(qj / bhi | 0, 67108863); a._ishlnsubmul(b, qj, j); while (a.negative !== 0) { qj--; a.negative = 0; a._ishlnsubmul(b, 1, j); if (!a.isZero()) { a.negative ^= 1; } } if (q) { q.words[j] = qj; } } if (q) { q.strip(); } a.strip(); if (mode !== "div" && shift !== 0) { a.iushrn(shift); } return { div: q || null, mod: a }; }; BN.prototype.divmod = function divmod(num, mode, positive) { assert(!num.isZero()); if (this.isZero()) { return { div: new BN(0), mod: new BN(0) }; } var div, mod, res; if (this.negative !== 0 && num.negative === 0) { res = this.neg().divmod(num, mode); if (mode !== "mod") { div = res.div.neg(); } if (mode !== "div") { mod = res.mod.neg(); if (positive && mod.negative !== 0) { mod.iadd(num); } } return { div, mod }; } if (this.negative === 0 && num.negative !== 0) { res = this.divmod(num.neg(), mode); if (mode !== "mod") { div = res.div.neg(); } return { div, mod: res.mod }; } if ((this.negative & num.negative) !== 0) { res = this.neg().divmod(num.neg(), mode); if (mode !== "div") { mod = res.mod.neg(); if (positive && mod.negative !== 0) { mod.isub(num); } } return { div: res.div, mod }; } if (num.length > this.length || this.cmp(num) < 0) { return { div: new BN(0), mod: this }; } if (num.length === 1) { if (mode === "div") { return { div: this.divn(num.words[0]), mod: null }; } if (mode === "mod") { return { div: null, mod: new BN(this.modn(num.words[0])) }; } return { div: this.divn(num.words[0]), mod: new BN(this.modn(num.words[0])) }; } return this._wordDiv(num, mode); }; BN.prototype.div = function div(num) { return this.divmod(num, "div", false).div; }; BN.prototype.mod = function mod(num) { return this.divmod(num, "mod", false).mod; }; BN.prototype.umod = function umod(num) { return this.divmod(num, "mod", true).mod; }; BN.prototype.divRound = function divRound(num) { var dm = this.divmod(num); if (dm.mod.isZero()) return dm.div; var mod = dm.div.negative !== 0 ? dm.mod.isub(num) : dm.mod; var half = num.ushrn(1); var r2 = num.andln(1); var cmp = mod.cmp(half); if (cmp < 0 || r2 === 1 && cmp === 0) return dm.div; return dm.div.negative !== 0 ? dm.div.isubn(1) : dm.div.iaddn(1); }; BN.prototype.modn = function modn(num) { assert(num <= 67108863); var p = (1 << 26) % num; var acc = 0; for (var i = this.length - 1;i >= 0; i--) { acc = (p * acc + (this.words[i] | 0)) % num; } return acc; }; BN.prototype.idivn = function idivn(num) { assert(num <= 67108863); var carry = 0; for (var i = this.length - 1;i >= 0; i--) { var w = (this.words[i] | 0) + carry * 67108864; this.words[i] = w / num | 0; carry = w % num; } return this.strip(); }; BN.prototype.divn = function divn(num) { return this.clone().idivn(num); }; BN.prototype.egcd = function egcd(p) { assert(p.negative === 0); assert(!p.isZero()); var x = this; var y = p.clone(); if (x.negative !== 0) { x = x.umod(p); } else { x = x.clone(); } var A = new BN(1); var B = new BN(0); var C = new BN(0); var D = new BN(1); var g = 0; while (x.isEven() && y.isEven()) { x.iushrn(1); y.iushrn(1); ++g; } var yp = y.clone(); var xp = x.clone(); while (!x.isZero()) { for (var i = 0, im = 1;(x.words[0] & im) === 0 && i < 26; ++i, im <<= 1) ; if (i > 0) { x.iushrn(i); while (i-- > 0) { if (A.isOdd() || B.isOdd()) { A.iadd(yp); B.isub(xp); } A.iushrn(1); B.iushrn(1); } } for (var j = 0, jm = 1;(y.words[0] & jm) === 0 && j < 26; ++j, jm <<= 1) ; if (j > 0) { y.iushrn(j); while (j-- > 0) { if (C.isOdd() || D.isOdd()) { C.iadd(yp); D.isub(xp); } C.iushrn(1); D.iushrn(1); } } if (x.cmp(y) >= 0) { x.isub(y); A.isub(C); B.isub(D); } else { y.isub(x); C.isub(A); D.isub(B); } } return { a: C, b: D, gcd: y.iushln(g) }; }; BN.prototype._invmp = function _invmp(p) { assert(p.negative === 0); assert(!p.isZero()); var a = this; var b = p.clone(); if (a.negative !== 0) { a = a.umod(p); } else { a = a.clone(); } var x1 = new BN(1); var x2 = new BN(0); var delta = b.clone(); while (a.cmpn(1) > 0 && b.cmpn(1) > 0) { for (var i = 0, im = 1;(a.words[0] & im) === 0 && i < 26; ++i, im <<= 1) ; if (i > 0) { a.iushrn(i); while (i-- > 0) { if (x1.isOdd()) { x1.iadd(delta); } x1.iushrn(1); } } for (var j = 0, jm = 1;(b.words[0] & jm) === 0 && j < 26; ++j, jm <<= 1) ; if (j > 0) { b.iushrn(j); while (j-- > 0) { if (x2.isOdd()) { x2.iadd(delta); } x2.iushrn(1); } } if (a.cmp(b) >= 0) { a.isub(b); x1.isub(x2); } else { b.isub(a); x2.isub(x1); } } var res; if (a.cmpn(1) === 0) { res = x1; } else { res = x2; } if (res.cmpn(0) < 0) { res.iadd(p); } return res; }; BN.prototype.gcd = function gcd(num) { if (this.isZero()) return num.abs(); if (num.isZero()) return this.abs(); var a = this.clone(); var b = num.clone(); a.negative = 0; b.negative = 0; for (var shift = 0;a.isEven() && b.isEven(); shift++) { a.iushrn(1); b.iushrn(1); } do { while (a.isEven()) { a.iushrn(1); } while (b.isEven()) { b.iushrn(1); } var r = a.cmp(b); if (r < 0) { var t = a; a = b; b = t; } else if (r === 0 || b.cmpn(1) === 0) { break; } a.isub(b); } while (true); return b.iushln(shift); }; BN.prototype.invm = function invm(num) { return this.egcd(num).a.umod(num); }; BN.prototype.isEven = function isEven() { return (this.words[0] & 1) === 0; }; BN.prototype.isOdd = function isOdd() { return (this.words[0] & 1) === 1; }; BN.prototype.andln = function andln(num) { return this.words[0] & num; }; BN.prototype.bincn = function bincn(bit) { assert(typeof bit === "number"); var r = bit % 26; var s = (bit - r) / 26; var q = 1 << r; if (this.length <= s) { this._expand(s + 1); this.words[s] |= q; return this; } var carry = q; for (var i = s;carry !== 0 && i < this.length; i++) { var w = this.words[i] | 0; w += carry; carry = w >>> 26; w &= 67108863; this.words[i] = w; } if (carry !== 0) { this.words[i] = carry; this.length++; } return this; }; BN.prototype.isZero = function isZero() { return this.length === 1 && this.words[0] === 0; }; BN.prototype.cmpn = function cmpn(num) { var negative = num < 0; if (this.negative !== 0 && !negative) return -1; if (this.negative === 0 && negative) return 1; this.strip(); var res; if (this.length > 1) { res = 1; } else { if (negative) { num = -num; } assert(num <= 67108863, "Number is too big"); var w = this.words[0] | 0; res = w === num ? 0 : w < num ? -1 : 1; } if (this.negative !== 0) return -res | 0; return res; }; BN.prototype.cmp = function cmp(num) { if (this.negative !== 0 && num.negative === 0) return -1; if (this.negative === 0 && num.negative !== 0) return 1; var res = this.ucmp(num); if (this.negative !== 0) return -res | 0; return res; }; BN.prototype.ucmp = function ucmp(num) { if (this.length > num.length) return 1; if (this.length < num.length) return -1; var res = 0; for (var i = this.length - 1;i >= 0; i--) { var a = this.words[i] | 0; var b = num.words[i] | 0; if (a === b) continue; if (a < b) { res = -1; } else if (a > b) { res = 1; } break; } return res; }; BN.prototype.gtn = function gtn(num) { return this.cmpn(num) === 1; }; BN.prototype.gt = function gt(num) { return this.cmp(num) === 1; }; BN.prototype.gten = function gten(num) { return this.cmpn(num) >= 0; }; BN.prototype.gte = function gte(num) { return this.cmp(num) >= 0; }; BN.prototype.ltn = function ltn(num) { return this.cmpn(num) === -1; }; BN.prototype.lt = function lt(num) { return this.cmp(num) === -1; }; BN.prototype.lten = function lten(num) { return this.cmpn(num) <= 0; }; BN.prototype.lte = function lte(num) { return this.cmp(num) <= 0; }; BN.prototype.eqn = function eqn(num) { return this.cmpn(num) === 0; }; BN.prototype.eq = function eq(num) { return this.cmp(num) === 0; }; BN.red = function red(num) { return new Red(num); }; BN.prototype.toRed = function toRed(ctx) { assert(!this.red, "Already a number in reduction context"); assert(this.negative === 0, "red works only with positives"); return ctx.convertTo(this)._forceRed(ctx); }; BN.prototype.fromRed = function fromRed() { assert(this.red, "fromRed works only with numbers in reduction context"); return this.red.convertFrom(this); }; BN.prototype._forceRed = function _forceRed(ctx) { this.red = ctx; return this; }; BN.prototype.forceRed = function forceRed(ctx) { assert(!this.red, "Already a number in reduction context"); return this._forceRed(ctx); }; BN.prototype.redAdd = function redAdd(num) { assert(this.red, "redAdd works only with red numbers"); return this.red.add(this, num); }; BN.prototype.redIAdd = function redIAdd(num) { assert(this.red, "redIAdd works only with red numbers"); return this.red.iadd(this, num); }; BN.prototype.redSub = function redSub(num) { assert(this.red, "redSub works only with red numbers"); return this.red.sub(this, num); }; BN.prototype.redISub = function redISub(num) { assert(this.red, "redISub works only with red numbers"); return this.red.isub(this, num); }; BN.prototype.redShl = function redShl(num) { assert(this.red, "redShl works only with red numbers"); return this.red.shl(this, num); }; BN.prototype.redMul = function redMul(num) { assert(this.red, "redMul works only with red numbers"); this.red._verify2(this, num); return this.red.mul(this, num); }; BN.prototype.redIMul = function redIMul(num) { assert(this.red, "redMul works only with red numbers"); this.red._verify2(this, num); return this.red.imul(this, num); }; BN.prototype.redSqr = function redSqr() { assert(this.red, "redSqr works only with red numbers"); this.red._verify1(this); return this.red.sqr(this); }; BN.prototype.redISqr = function redISqr() { assert(this.red, "redISqr works only with red numbers"); this.red._verify1(this); return this.red.isqr(this); }; BN.prototype.redSqrt = function redSqrt() { assert(this.red, "redSqrt works only with red numbers"); this.red._verify1(this); return this.red.sqrt(this); }; BN.prototype.redInvm = function redInvm() { assert(this.red, "redInvm works only with red numbers"); this.red._verify1(this); return this.red.invm(this); }; BN.prototype.redNeg = function redNeg() { assert(this.red, "redNeg works only with red numbers"); this.red._verify1(this); return this.red.neg(this); }; BN.prototype.redPow = function redPow(num) { assert(this.red && !num.red, "redPow(normalNum)"); this.red._verify1(this); return this.red.pow(this, num); }; var primes = { k256: null, p224: null, p192: null, p25519: null }; function MPrime(name, p) { this.name = name; this.p = new BN(p, 16); this.n = this.p.bitLength(); this.k = new BN(1).iushln(this.n).isub(this.p); this.tmp = this._tmp(); } MPrime.prototype._tmp = function _tmp() { var tmp = new BN(null); tmp.words = new Array(Math.ceil(this.n / 13)); return tmp; }; MPrime.prototype.ireduce = function ireduce(num) { var r = num; var rlen; do { this.split(r, this.tmp); r = this.imulK(r); r = r.iadd(this.tmp); rlen = r.bitLength(); } while (rlen > this.n); var cmp = rlen < this.n ? -1 : r.ucmp(this.p); if (cmp === 0) { r.words[0] = 0; r.length = 1; } else if (cmp > 0) { r.isub(this.p); } else { if (r.strip !== undefined) { r.strip(); } else { r._strip(); } } return r; }; MPrime.prototype.split = function split(input, out) { input.iushrn(this.n, 0, out); }; MPrime.prototype.imulK = function imulK(num) { return num.imul(this.k); }; function K256() { MPrime.call(this, "k256", "ffffffff ffffffff ffffffff ffffffff ffffffff ffffffff fffffffe fffffc2f"); } inherits(K256, MPrime); K256.prototype.split = function split(input, output) { var mask = 4194303; var outLen = Math.min(input.length, 9); for (var i = 0;i < outLen; i++) { output.words[i] = input.words[i]; } output.length = outLen; if (input.length <= 9) { input.words[0] = 0; input.length = 1; return; } var prev = input.words[9]; output.words[output.length++] = prev & mask; for (i = 10;i < input.length; i++) { var next = input.words[i] | 0; input.words[i - 10] = (next & mask) << 4 | prev >>> 22; prev = next; } prev >>>= 22; input.words[i - 10] = prev; if (prev === 0 && input.length > 10) { input.length -= 10; } else { input.length -= 9; } }; K256.prototype.imulK = function imulK(num) { num.words[num.length] = 0; num.words[num.length + 1] = 0; num.length += 2; var lo = 0; for (var i = 0;i < num.length; i++) { var w = num.words[i] | 0; lo += w * 977; num.words[i] = lo & 67108863; lo = w * 64 + (lo / 67108864 | 0); } if (num.words[num.length - 1] === 0) { num.length--; if (num.words[num.length - 1] === 0) { num.length--; } } return num; }; function P224() { MPrime.call(this, "p224", "ffffffff ffffffff ffffffff ffffffff 00000000 00000000 00000001"); } inherits(P224, MPrime); function P192() { MPrime.call(this, "p192", "ffffffff ffffffff ffffffff fffffffe ffffffff ffffffff"); } inherits(P192, MPrime); function P25519() { MPrime.call(this, "25519", "7fffffffffffffff ffffffffffffffff ffffffffffffffff ffffffffffffffed"); } inherits(P25519, MPrime); P25519.prototype.imulK = function imulK(num) { var carry = 0; for (var i = 0;i < num.length; i++) { var hi = (num.words[i] | 0) * 19 + carry; var lo = hi & 67108863; hi >>>= 26; num.words[i] = lo; carry = hi; } if (carry !== 0) { num.words[num.length++] = carry; } return num; }; BN._prime = function prime(name) { if (primes[name]) return primes[name]; var prime; if (name === "k256") { prime = new K256; } else if (name === "p224") { prime = new P224; } else if (name === "p192") { prime = new P192; } else if (name === "p25519") { prime = new P25519; } else { throw new Error("Unknown prime " + name); } primes[name] = prime; return prime; }; function Red(m) { if (typeof m === "string") { var prime = BN._prime(m); this.m = prime.p; this.prime = prime; } else { assert(m.gtn(1), "modulus must be greater than 1"); this.m = m; this.prime = null; } } Red.prototype._verify1 = function _verify1(a) { assert(a.negative === 0, "red works only with positives"); assert(a.red, "red works only with red numbers"); }; Red.prototype._verify2 = function _verify2(a, b) { assert((a.negative | b.negative) === 0, "red works only with positives"); assert(a.red && a.red === b.red, "red works only with red numbers"); }; Red.prototype.imod = function imod(a) { if (this.prime) return this.prime.ireduce(a)._forceRed(this); return a.umod(this.m)._forceRed(this); }; Red.prototype.neg = function neg(a) { if (a.isZero()) { return a.clone(); } return this.m.sub(a)._forceRed(this); }; Red.prototype.add = function add(a, b) { this._verify2(a, b); var res = a.add(b); if (res.cmp(this.m) >= 0) { res.isub(this.m); } return res._forceRed(this); }; Red.prototype.iadd = function iadd(a, b) { this._verify2(a, b); var res = a.iadd(b); if (res.cmp(this.m) >= 0) { res.isub(this.m); } return res; }; Red.prototype.sub = function sub(a, b) { this._verify2(a, b); var res = a.sub(b); if (res.cmpn(0) < 0) { res.iadd(this.m); } return res._forceRed(this); }; Red.prototype.isub = function isub(a, b) { this._verify2(a, b); var res = a.isub(b); if (res.cmpn(0) < 0) { res.iadd(this.m); } return res; }; Red.prototype.shl = function shl(a, num) { this._verify1(a); return this.imod(a.ushln(num)); }; Red.prototype.imul = function imul(a, b) { this._verify2(a, b); return this.imod(a.imul(b)); }; Red.prototype.mul = function mul(a, b) { this._verify2(a, b); return this.imod(a.mul(b)); }; Red.prototype.isqr = function isqr(a) { return this.imul(a, a.clone()); }; Red.prototype.sqr = function sqr(a) { return this.mul(a, a); }; Red.prototype.sqrt = function sqrt(a) { if (a.isZero()) return a.clone(); var mod3 = this.m.andln(3); assert(mod3 % 2 === 1); if (mod3 === 3) { var pow = this.m.add(new BN(1)).iushrn(2); return this.pow(a, pow); } var q = this.m.subn(1); var s = 0; while (!q.isZero() && q.andln(1) === 0) { s++; q.iushrn(1); } assert(!q.isZero()); var one = new BN(1).toRed(this); var nOne = one.redNeg(); var lpow = this.m.subn(1).iushrn(1); var z = this.m.bitLength(); z = new BN(2 * z * z).toRed(this); while (this.pow(z, lpow).cmp(nOne) !== 0) { z.redIAdd(nOne); } var c = this.pow(z, q); var r = this.pow(a, q.addn(1).iushrn(1)); var t = this.pow(a, q); var m = s; while (t.cmp(one) !== 0) { var tmp = t; for (var i = 0;tmp.cmp(one) !== 0; i++) { tmp = tmp.redSqr(); } assert(i < m); var b = this.pow(c, new BN(1).iushln(m - i - 1)); r = r.redMul(b); c = b.redSqr(); t = t.redMul(c); m = i; } return r; }; Red.prototype.invm = function invm(a) { var inv = a._invmp(this.m); if (inv.negative !== 0) { inv.negative = 0; return this.imod(inv).redNeg(); } else { return this.imod(inv); } }; Red.prototype.pow = function pow(a, num) { if (num.isZero()) return new BN(1).toRed(this); if (num.cmpn(1) === 0) return a.clone(); var windowSize = 4; var wnd = new Array(1 << windowSize); wnd[0] = new BN(1).toRed(this); wnd[1] = a; for (var i = 2;i < wnd.length; i++) { wnd[i] = this.mul(wnd[i - 1], a); } var res = wnd[0]; var current = 0; var currentLen = 0; var start = num.bitLength() % 26; if (start === 0) { start = 26; } for (i = num.length - 1;i >= 0; i--) { var word = num.words[i]; for (var j = start - 1;j >= 0; j--) { var bit = word >> j & 1; if (res !== wnd[0]) { res = this.sqr(res); } if (bit === 0 && current === 0) { currentLen = 0; continue; } current <<= 1; current |= bit; currentLen++; if (currentLen !== windowSize && (i !== 0 || j !== 0)) continue; res = this.mul(res, wnd[current]); currentLen = 0; current = 0; } start = 26; } return res; }; Red.prototype.convertTo = function convertTo(num) { var r = num.umod(this.m); return r === num ? r.clone() : r; }; Red.prototype.convertFrom = function convertFrom(num) { var res = num.clone(); res.red = null; return res; }; BN.mont = function mont(num) { return new Mont(num); }; function Mont(m) { Red.call(this, m); this.shift = this.m.bitLength(); if (this.shift % 26 !== 0) { this.shift += 26 - this.shift % 26; } this.r = new BN(1).iushln(this.shift); this.r2 = this.imod(this.r.sqr()); this.rinv = this.r._invmp(this.m); this.minv = this.rinv.mul(this.r).isubn(1).div(this.m); this.minv = this.minv.umod(this.r); this.minv = this.r.sub(this.minv); } inherits(Mont, Red); Mont.prototype.convertTo = function convertTo(num) { return this.imod(num.ushln(this.shift)); }; Mont.prototype.convertFrom = function convertFrom(num) { var r = this.imod(num.mul(this.rinv)); r.red = null; return r; }; Mont.prototype.imul = function imul(a, b) { if (a.isZero() || b.isZero()) { a.words[0] = 0; a.length = 1; return a; } var t = a.imul(b); var c = t.maskn(this.shift).mul(this.minv).imaskn(this.shift).mul(this.m); var u = t.isub(c).iushrn(this.shift); var res = u; if (u.cmp(this.m) >= 0) { res = u.isub(this.m); } else if (u.cmpn(0) < 0) { res = u.iadd(this.m); } return res._forceRed(this); }; Mont.prototype.mul = function mul(a, b) { if (a.isZero() || b.isZero()) return new BN(0)._forceRed(this); var t = a.mul(b); var c = t.maskn(this.shift).mul(this.minv).imaskn(this.shift).mul(this.m); var u = t.isub(c).iushrn(this.shift); var res = u; if (u.cmp(this.m) >= 0) { res = u.isub(this.m); } else if (u.cmpn(0) < 0) { res = u.iadd(this.m); } return res._forceRed(this); }; Mont.prototype.invm = function invm(a) { var res = this.imod(a._invmp(this.m).mul(this.r2)); return res._forceRed(this); }; })(typeof module === "undefined" || module, exports); }); // ../eve/node_modules/inherits/inherits_browser.js var require_inherits_browser = __commonJS((exports, module) => { if (typeof Object.create === "function") { module.exports = function inherits(ctor, superCtor) { if (superCtor) { ctor.super_ = superCtor; ctor.prototype = Object.create(superCtor.prototype, { constructor: { value: ctor, enumerable: false, writable: true, configurable: true } }); } }; } else { module.exports = function inherits(ctor, superCtor) { if (superCtor) { ctor.super_ = superCtor; var TempCtor = function() {}; TempCtor.prototype = superCtor.prototype; ctor.prototype = new TempCtor; ctor.prototype.constructor = ctor; } }; } }); // ../eve/node_modules/inherits/inherits.js var require_inherits = __commonJS((exports, module) => { try { util = __require("util"); if (typeof util.inherits !== "function") throw ""; module.exports = util.inherits; } catch (e) { module.exports = require_inherits_browser(); } var util; }); // ../eve/node_modules/safer-buffer/safer.js var require_safer = __commonJS((exports, module) => { var buffer = __require("buffer"); var Buffer2 = buffer.Buffer; var safer = {}; var key; for (key in buffer) { if (!buffer.hasOwnProperty(key)) continue; if (key === "SlowBuffer" || key === "Buffer") continue; safer[key] = buffer[key]; } var Safer = safer.Buffer = {}; for (key in Buffer2) { if (!Buffer2.hasOwnProperty(key)) continue; if (key === "allocUnsafe" || key === "allocUnsafeSlow") continue; Safer[key] = Buffer2[key]; } safer.Buffer.prototype = Buffer2.prototype; if (!Safer.from || Safer.from === Uint8Array.from) { Safer.from = function(value, encodingOrOffset, length) { if (typeof value === "number") { throw new TypeError('The "value" argument must not be of type number. Received type ' + typeof value); } if (value && typeof value.length === "undefined") { throw new TypeError("The first argument must be one of type string, Buffer, ArrayBuffer, Array, or Array-like Object. Received type " + typeof value); } return Buffer2(value, encodingOrOffset, length); }; } if (!Safer.alloc) { Safer.alloc = function(size, fill, encoding) { if (typeof size !== "number") { throw new TypeError('The "size" argument must be of type number. Received type ' + typeof size); } if (size < 0 || size >= 2 * (1 << 30)) { throw new RangeError('The value "' + size + '" is invalid for option "size"'); } var buf = Buffer2(size); if (!fill || fill.length === 0) { buf.fill(0); } else if (typeof encoding === "string") { buf.fill(fill, encoding); } else { buf.fill(fill); } return buf; }; } if (!safer.kStringMaxLength) { try { safer.kStringMaxLength = process.binding("buffer").kStringMaxLength; } catch (e) {} } if (!safer.constants) { safer.constants = { MAX_LENGTH: safer.kMaxLength }; if (safer.kStringMaxLength) { safer.constants.MAX_STRING_LENGTH = safer.kStringMaxLength; } } module.exports = safer; }); // ../eve/node_modules/asn1.js/lib/asn1/base/reporter.js var require_reporter = __commonJS((exports) => { var inherits = require_inherits(); function Reporter(options2) { this._reporterState = { obj: null, path: [], options: options2 || {}, errors: [] }; } exports.Reporter = Reporter; Reporter.prototype.isError = function isError(obj) { return obj instanceof ReporterError; }; Reporter.prototype.save = function save() { const state = this._reporterState; return { obj: state.obj, pathLen: state.path.length }; }; Reporter.prototype.restore = function restore(data) { const state = this._reporterState; state.obj = data.obj; state.path = state.path.slice(0, data.pathLen); }; Reporter.prototype.enterKey = function enterKey(key) { return this._reporterState.path.push(key); }; Reporter.prototype.exitKey = function exitKey(index) { const state = this._reporterState; state.path = state.path.slice(0, index - 1); }; Reporter.prototype.leaveKey = function leaveKey(index, key, value) { const state = this._reporterState; this.exitKey(index); if (state.obj !== null) state.obj[key] = value; }; Reporter.prototype.path = function path() { return this._reporterState.path.join("/"); }; Reporter.prototype.enterObject = function enterObject() { const state = this._reporterState; const prev = state.obj; state.obj = {}; return prev; }; Reporter.prototype.leaveObject = function leaveObject(prev) { const state = this._reporterState; const now = state.obj; state.obj = prev; return now; }; Reporter.prototype.error = function error(msg) { let err; const state = this._reporterState; const inherited = msg instanceof ReporterError; if (inherited) { err = msg; } else { err = new ReporterError(state.path.map(function(elem) { return "[" + JSON.stringify(elem) + "]"; }).join(""), msg.message || msg, msg.stack); } if (!state.options.partial) throw err; if (!inherited) state.errors.push(err); return err; }; Reporter.prototype.wrapResult = function wrapResult(result) { const state = this._reporterState; if (!state.options.partial) return result; return { result: this.isError(result) ? null : result, errors: state.errors }; }; function ReporterError(path, msg) { this.path = path; this.rethrow(msg); } inherits(ReporterError, Error); ReporterError.prototype.rethrow = function rethrow(msg) { this.message = msg + " at: " + (this.path || "(shallow)"); if (Error.captureStackTrace) Error.captureStackTrace(this, ReporterError); if (!this.stack) { try { throw new Error(this.message); } catch (e) { this.stack = e.stack; } } return this; }; }); // ../eve/node_modules/asn1.js/lib/asn1/base/buffer.js var require_buffer = __commonJS((exports) => { var inherits = require_inherits(); var Reporter = require_reporter().Reporter; var Buffer2 = require_safer().Buffer; function DecoderBuffer(base, options2) { Reporter.call(this, options2); if (!Buffer2.isBuffer(base)) { this.error("Input not Buffer"); return; } this.base = base; this.offset = 0; this.length = base.length; } inherits(DecoderBuffer, Reporter); exports.DecoderBuffer = DecoderBuffer; DecoderBuffer.isDecoderBuffer = function isDecoderBuffer(data) { if (data instanceof DecoderBuffer) { return true; } const isCompatible = typeof data === "object" && Buffer2.isBuffer(data.base) && data.constructor.name === "DecoderBuffer" && typeof data.offset === "number" && typeof data.length === "number" && typeof data.save === "function" && typeof data.restore === "function" && typeof data.isEmpty === "function" && typeof data.readUInt8 === "function" && typeof data.skip === "function" && typeof data.raw === "function"; return isCompatible; }; DecoderBuffer.prototype.save = function save() { return { offset: this.offset, reporter: Reporter.prototype.save.call(this) }; }; DecoderBuffer.prototype.restore = function restore(save) { const res = new DecoderBuffer(this.base); res.offset = save.offset; res.length = this.offset; this.offset = save.offset; Reporter.prototype.restore.call(this, save.reporter); return res; }; DecoderBuffer.prototype.isEmpty = function isEmpty() { return this.offset === this.length; }; DecoderBuffer.prototype.readUInt8 = function readUInt8(fail) { if (this.offset + 1 <= this.length) return this.base.readUInt8(this.offset++, true); else return this.error(fail || "DecoderBuffer overrun"); }; DecoderBuffer.prototype.skip = function skip(bytes, fail) { if (!(this.offset + bytes <= this.length)) return this.error(fail || "DecoderBuffer overrun"); const res = new DecoderBuffer(this.base); res._reporterState = this._reporterState; res.offset = this.offset; res.length = this.offset + bytes; this.offset += bytes; return res; }; DecoderBuffer.prototype.raw = function raw(save) { return this.base.slice(save ? save.offset : this.offset, this.length); }; function EncoderBuffer(value, reporter) { if (Array.isArray(value)) { this.length = 0; this.value = value.map(function(item) { if (!EncoderBuffer.isEncoderBuffer(item)) item = new EncoderBuffer(item, reporter); this.length += item.length; return item; }, this); } else if (typeof value === "number") { if (!(0 <= value && value <= 255)) return reporter.error("non-byte EncoderBuffer value"); this.value = value; this.length = 1; } else if (typeof value === "string") { this.value = value; this.length = Buffer2.byteLength(value); } else if (Buffer2.isBuffer(value)) { this.value = value; this.length = value.length; } else { return reporter.error("Unsupported type: " + typeof value); } } exports.EncoderBuffer = EncoderBuffer; EncoderBuffer.isEncoderBuffer = function isEncoderBuffer(data) { if (data instanceof EncoderBuffer) { return true; } const isCompatible = typeof data === "object" && data.constructor.name === "EncoderBuffer" && typeof data.length === "number" && typeof data.join === "function"; return isCompatible; }; EncoderBuffer.prototype.join = function join(out, offset) { if (!out) out = Buffer2.alloc(this.length); if (!offset) offset = 0; if (this.length === 0) return out; if (Array.isArray(this.value)) { this.value.forEach(function(item) { item.join(out, offset); offset += item.length; }); } else { if (typeof this.value === "number") out[offset] = this.value; else if (typeof this.value === "string") out.write(this.value, offset); else if (Buffer2.isBuffer(this.value)) this.value.copy(out, offset); offset += this.length; } return out; }; }); // ../eve/node_modules/minimalistic-assert/index.js var require_minimalistic_assert = __commonJS((exports, module) => { module.exports = assert; function assert(val, msg) { if (!val) throw new Error(msg || "Assertion failed"); } assert.equal = function assertEqual(l, r, msg) { if (l != r) throw new Error(msg || "Assertion failed: " + l + " != " + r); }; }); // ../eve/node_modules/asn1.js/lib/asn1/base/node.js var require_node = __commonJS((exports, module) => { var Reporter = require_reporter().Reporter; var EncoderBuffer = require_buffer().EncoderBuffer; var DecoderBuffer = require_buffer().DecoderBuffer; var assert = require_minimalistic_assert(); var tags = [ "seq", "seqof", "set", "setof", "objid", "bool", "gentime", "utctime", "null_", "enum", "int", "objDesc", "bitstr", "bmpstr", "charstr", "genstr", "graphstr", "ia5str", "iso646str", "numstr", "octstr", "printstr", "t61str", "unistr", "utf8str", "videostr" ]; var methods = [ "key", "obj", "use", "optional", "explicit", "implicit", "def", "choice", "any", "contains" ].concat(tags); var overrided = [ "_peekTag", "_decodeTag", "_use", "_decodeStr", "_decodeObjid", "_decodeTime", "_decodeNull", "_decodeInt", "_decodeBool", "_decodeList", "_encodeComposite", "_encodeStr", "_encodeObjid", "_encodeTime", "_encodeNull", "_encodeInt", "_encodeBool" ]; function Node(enc, parent, name) { const state = {}; this._baseState = state; state.name = name; state.enc = enc; state.parent = parent || null; state.children = null; state.tag = null; state.args = null; state.reverseArgs = null; state.choice = null; state.optional = false; state.any = false; state.obj = false; state.use = null; state.useDecoder = null; state.key = null; state["default"] = null; state.explicit = null; state.implicit = null; state.contains = null; if (!state.parent) { state.children = []; this._wrap(); } } module.exports = Node; var stateProps = [ "enc", "parent", "children", "tag", "args", "reverseArgs", "choice", "optional", "any", "obj", "use", "alteredUse", "key", "default", "explicit", "implicit", "contains" ]; Node.prototype.clone = function clone() { const state = this._baseState; const cstate = {}; stateProps.forEach(function(prop) { cstate[prop] = state[prop]; }); const res = new this.constructor(cstate.parent); res._baseState = cstate; return res; }; Node.prototype._wrap = function wrap() { const state = this._baseState; methods.forEach(function(method) { this[method] = function _wrappedMethod() { const clone = new this.constructor(this); state.children.push(clone); return clone[method].apply(clone, arguments); }; }, this); }; Node.prototype._init = function init(body) { const state = this._baseState; assert(state.parent === null); body.call(this); state.children = state.children.filter(function(child) { return child._baseState.parent === this; }, this); assert.equal(state.children.length, 1, "Root node can have only one child"); }; Node.prototype._useArgs = function useArgs(args) { const state = this._baseState; const children = args.filter(function(arg) { return arg instanceof this.constructor; }, this); args = args.filter(function(arg) { return !(arg instanceof this.constructor); }, this); if (children.length !== 0) { assert(state.children === null); state.children = children; children.forEach(function(child) { child._baseState.parent = this; }, this); } if (args.length !== 0) { assert(state.args === null); state.args = args; state.reverseArgs = args.map(function(arg) { if (typeof arg !== "object" || arg.constructor !== Object) return arg; const res = {}; Object.keys(arg).forEach(function(key) { if (key == (key | 0)) key |= 0; const value = arg[key]; res[value] = key; }); return res; }); } }; overrided.forEach(function(method) { Node.prototype[method] = function _overrided() { const state = this._baseState; throw new Error(method + " not implemented for encoding: " + state.enc); }; }); tags.forEach(function(tag) { Node.prototype[tag] = function _tagMethod() { const state = this._baseState; const args = Array.prototype.slice.call(arguments); assert(state.tag === null); state.tag = tag; this._useArgs(args); return this; }; }); Node.prototype.use = function use(item) { assert(item); const state = this._baseState; assert(state.use === null); state.use = item; return this; }; Node.prototype.optional = function optional() { const state = this._baseState; state.optional = true; return this; }; Node.prototype.def = function def(val) { const state = this._baseState; assert(state["default"] === null); state["default"] = val; state.optional = true; return this; }; Node.prototype.explicit = function explicit(num) { const state = this._baseState; assert(state.explicit === null && state.implicit === null); state.explicit = num; return this; }; Node.prototype.implicit = function implicit(num) { const state = this._baseState; assert(state.explicit === null && state.implicit === null); state.implicit = num; return this; }; Node.prototype.obj = function obj() { const state = this._baseState; const args = Array.prototype.slice.call(arguments); state.obj = true; if (args.length !== 0) this._useArgs(args); return this; }; Node.prototype.key = function key(newKey) { const state = this._baseState; assert(state.key === null); state.key = newKey; return this; }; Node.prototype.any = function any() { const state = this._baseState; state.any = true; return this; }; Node.prototype.choice = function choice(obj) { const state = this._baseState; assert(state.choice === null); state.choice = obj; this._useArgs(Object.keys(obj).map(function(key) { return obj[key]; })); return this; }; Node.prototype.contains = function contains(item) { const state = this._baseState; assert(state.use === null); state.contains = item; return this; }; Node.prototype._decode = function decode(input, options2) { const state = this._baseState; if (state.parent === null) return input.wrapResult(state.children[0]._decode(input, options2)); let result = state["default"]; let present = true; let prevKey = null; if (state.key !== null) prevKey = input.enterKey(state.key); if (state.optional) { let tag = null; if (state.explicit !== null) tag = state.explicit; else if (state.implicit !== null) tag = state.implicit; else if (state.tag !== null) tag = state.tag; if (tag === null && !state.any) { const save = input.save(); try { if (state.choice === null) this._decodeGeneric(state.tag, input, options2); else this._decodeChoice(input, options2); present = true; } catch (e) { present = false; } input.restore(save); } else { present = this._peekTag(input, tag, state.any); if (input.isError(present)) return present; } } let prevObj; if (state.obj && present) prevObj = input.enterObject(); if (present) { if (state.explicit !== null) { const explicit = this._decodeTag(input, state.explicit); if (input.isError(explicit)) return explicit; input = explicit; } const start = input.offset; if (state.use === null && state.choice === null) { let save; if (state.any) save = input.save(); const body = this._decodeTag(input, state.implicit !== null ? state.implicit : state.tag, state.any); if (input.isError(body)) return body; if (state.any) result = input.raw(save); else input = body; } if (options2 && options2.track && state.tag !== null) options2.track(input.path(), start, input.length, "tagged"); if (options2 && options2.track && state.tag !== null) options2.track(input.path(), input.offset, input.length, "content"); if (state.any) {} else if (state.choice === null) { result = this._decodeGeneric(state.tag, input, options2); } else { result = this._decodeChoice(input, options2); } if (input.isError(result)) return result; if (!state.any && state.choice === null && state.children !== null) { state.children.forEach(function decodeChildren(child) { child._decode(input, options2); }); } if (state.contains && (state.tag === "octstr" || state.tag === "bitstr")) { const data = new DecoderBuffer(result); result = this._getUse(state.contains, input._reporterState.obj)._decode(data, options2); } } if (state.obj && present) result = input.leaveObject(prevObj); if (state.key !== null && (result !== null || present === true)) input.leaveKey(prevKey, state.key, result); else if (prevKey !== null) input.exitKey(prevKey); return result; }; Node.prototype._decodeGeneric = function decodeGeneric(tag, input, options2) { const state = this._baseState; if (tag === "seq" || tag === "set") return null; if (tag === "seqof" || tag === "setof") return this._decodeList(input, tag, state.args[0], options2); else if (/str$/.test(tag)) return this._decodeStr(input, tag, options2); else if (tag === "objid" && state.args) return this._decodeObjid(input, state.args[0], state.args[1], options2); else if (tag === "objid") return this._decodeObjid(input, null, null, options2); else if (tag === "gentime" || tag === "utctime") return this._decodeTime(input, tag, options2); else if (tag === "null_") return this._decodeNull(input, options2); else if (tag === "bool") return this._decodeBool(input, options2); else if (tag === "objDesc") return this._decodeStr(input, tag, options2); else if (tag === "int" || tag === "enum") return this._decodeInt(input, state.args && state.args[0], options2); if (state.use !== null) { return this._getUse(state.use, input._reporterState.obj)._decode(input, options2); } else { return input.error("unknown tag: " + tag); } }; Node.prototype._getUse = function _getUse(entity, obj) { const state = this._baseState; state.useDecoder = this._use(entity, obj); assert(state.useDecoder._baseState.parent === null); state.useDecoder = state.useDecoder._baseState.children[0]; if (state.implicit !== state.useDecoder._baseState.implicit) { state.useDecoder = state.useDecoder.clone(); state.useDecoder._baseState.implicit = state.implicit; } return state.useDecoder; }; Node.prototype._decodeChoice = function decodeChoice(input, options2) { const state = this._baseState; let result = null; let match = false; Object.keys(state.choice).some(function(key) { const save = input.save(); const node = state.choice[key]; try { const value = node._decode(input, options2); if (input.isError(value)) return false; result = { type: key, value }; match = true; } catch (e) { input.restore(save); return false; } return true; }, this); if (!match) return input.error("Choice not matched"); return result; }; Node.prototype._createEncoderBuffer = function createEncoderBuffer(data) { return new EncoderBuffer(data, this.reporter); }; Node.prototype._encode = function encode(data, reporter, parent) { const state = this._baseState; if (state["default"] !== null && state["default"] === data) return; const result = this._encodeValue(data, reporter, parent); if (result === undefined) return; if (this._skipDefault(result, reporter, parent)) return; return result; }; Node.prototype._encodeValue = function encode(data, reporter, parent) { const state = this._baseState; if (state.parent === null) return state.children[0]._encode(data, reporter || new Reporter); let result = null; this.reporter = reporter; if (state.optional && data === undefined) { if (state["default"] !== null) data = state["default"]; else return; } let content = null; let primitive = false; if (state.any) { result = this._createEncoderBuffer(data); } else if (state.choice) { result = this._encodeChoice(data, reporter); } else if (state.contains) { content = this._getUse(state.contains, parent)._encode(data, reporter); primitive = true; } else if (state.children) { content = state.children.map(function(child) { if (child._baseState.tag === "null_") return child._encode(null, reporter, data); if (child._baseState.key === null) return reporter.error("Child should have a key"); const prevKey = reporter.enterKey(child._baseState.key); if (typeof data !== "object") return reporter.error("Child expected, but input is not object"); const res = child._encode(data[child._baseState.key], reporter, data); reporter.leaveKey(prevKey); return res; }, this).filter(function(child) { return child; }); content = this._createEncoderBuffer(content); } else { if (state.tag === "seqof" || state.tag === "setof") { if (!(state.args && state.args.length === 1)) return reporter.error("Too many args for : " + state.tag); if (!Array.isArray(data)) return reporter.error("seqof/setof, but data is not Array"); const child = this.clone(); child._baseState.implicit = null; content = this._createEncoderBuffer(data.map(function(item) { const state2 = this._baseState; return this._getUse(state2.args[0], data)._encode(item, reporter); }, child)); } else if (state.use !== null) { result = this._getUse(state.use, parent)._encode(data, reporter); } else { content = this._encodePrimitive(state.tag, data); primitive = true; } } if (!state.any && state.choice === null) { const tag = state.implicit !== null ? state.implicit : state.tag; const cls = state.implicit === null ? "universal" : "context"; if (tag === null) { if (state.use === null) reporter.error("Tag could be omitted only for .use()"); } else { if (state.use === null) result = this._encodeComposite(tag, primitive, cls, content); } } if (state.explicit !== null) result = this._encodeComposite(state.explicit, false, "context", result); return result; }; Node.prototype._encodeChoice = function encodeChoice(data, reporter) { const state = this._baseState; const node = state.choice[data.type]; if (!node) { assert(false, data.type + " not found in " + JSON.stringify(Object.keys(state.choice))); } return node._encode(data.value, reporter); }; Node.prototype._encodePrimitive = function encodePrimitive(tag, data) { const state = this._baseState; if (/str$/.test(tag)) return this._encodeStr(data, tag); else if (tag === "objid" && state.args) return this._encodeObjid(data, state.reverseArgs[0], state.args[1]); else if (tag === "objid") return this._encodeObjid(data, null, null); else if (tag === "gentime" || tag === "utctime") return this._encodeTime(data, tag); else if (tag === "null_") return this._encodeNull(); else if (tag === "int" || tag === "enum") return this._encodeInt(data, state.args && state.reverseArgs[0]); else if (tag === "bool") return this._encodeBool(data); else if (tag === "objDesc") return this._encodeStr(data, tag); else throw new Error("Unsupported tag: " + tag); }; Node.prototype._isNumstr = function isNumstr(str) { return /^[0-9 ]*$/.test(str); }; Node.prototype._isPrintstr = function isPrintstr(str) { return /^[A-Za-z0-9 '()+,-./:=?]*$/.test(str); }; }); // ../eve/node_modules/asn1.js/lib/asn1/constants/der.js var require_der = __commonJS((exports) => { function reverse(map) { const res = {}; Object.keys(map).forEach(function(key) { if ((key | 0) == key) key = key | 0; const value = map[key]; res[value] = key; }); return res; } exports.tagClass = { 0: "universal", 1: "application", 2: "context", 3: "private" }; exports.tagClassByName = reverse(exports.tagClass); exports.tag = { 0: "end", 1: "bool", 2: "int", 3: "bitstr", 4: "octstr", 5: "null_", 6: "objid", 7: "objDesc", 8: "external", 9: "real", 10: "enum", 11: "embed", 12: "utf8str", 13: "relativeOid", 16: "seq", 17: "set", 18: "numstr", 19: "printstr", 20: "t61str", 21: "videostr", 22: "ia5str", 23: "utctime", 24: "gentime", 25: "graphstr", 26: "iso646str", 27: "genstr", 28: "unistr", 29: "charstr", 30: "bmpstr" }; exports.tagByName = reverse(exports.tag); }); // ../eve/node_modules/asn1.js/lib/asn1/encoders/der.js var require_der2 = __commonJS((exports, module) => { var inherits = require_inherits(); var Buffer2 = require_safer().Buffer; var Node = require_node(); var der = require_der(); function DEREncoder(entity) { this.enc = "der"; this.name = entity.name; this.entity = entity; this.tree = new DERNode; this.tree._init(entity.body); } module.exports = DEREncoder; DEREncoder.prototype.encode = function encode(data, reporter) { return this.tree._encode(data, reporter).join(); }; function DERNode(parent) { Node.call(this, "der", parent); } inherits(DERNode, Node); DERNode.prototype._encodeComposite = function encodeComposite(tag, primitive, cls, content) { const encodedTag = encodeTag(tag, primitive, cls, this.reporter); if (content.length < 128) { const header2 = Buffer2.alloc(2); header2[0] = encodedTag; header2[1] = content.length; return this._createEncoderBuffer([header2, content]); } let lenOctets = 1; for (let i = content.length;i >= 256; i >>= 8) lenOctets++; const header = Buffer2.alloc(1 + 1 + lenOctets); header[0] = encodedTag; header[1] = 128 | lenOctets; for (let i = 1 + lenOctets, j = content.length;j > 0; i--, j >>= 8) header[i] = j & 255; return this._createEncoderBuffer([header, content]); }; DERNode.prototype._encodeStr = function encodeStr(str, tag) { if (tag === "bitstr") { return this._createEncoderBuffer([str.unused | 0, str.data]); } else if (tag === "bmpstr") { const buf = Buffer2.alloc(str.length * 2); for (let i = 0;i < str.length; i++) { buf.writeUInt16BE(str.charCodeAt(i), i * 2); } return this._createEncoderBuffer(buf); } else if (tag === "numstr") { if (!this._isNumstr(str)) { return this.reporter.error("Encoding of string type: numstr supports " + "only digits and space"); } return this._createEncoderBuffer(str); } else if (tag === "printstr") { if (!this._isPrintstr(str)) { return this.reporter.error("Encoding of string type: printstr supports " + "only latin upper and lower case letters, " + "digits, space, apostrophe, left and rigth " + "parenthesis, plus sign, comma, hyphen, " + "dot, slash, colon, equal sign, " + "question mark"); } return this._createEncoderBuffer(str); } else if (/str$/.test(tag)) { return this._createEncoderBuffer(str); } else if (tag === "objDesc") { return this._createEncoderBuffer(str); } else { return this.reporter.error("Encoding of string type: " + tag + " unsupported"); } }; DERNode.prototype._encodeObjid = function encodeObjid(id, values, relative) { if (typeof id === "string") { if (!values) return this.reporter.error("string objid given, but no values map found"); if (!values.hasOwnProperty(id)) return this.reporter.error("objid not found in values map"); id = values[id].split(/[\s.]+/g); for (let i = 0;i < id.length; i++) id[i] |= 0; } else if (Array.isArray(id)) { id = id.slice(); for (let i = 0;i < id.length; i++) id[i] |= 0; } if (!Array.isArray(id)) { return this.reporter.error("objid() should be either array or string, " + "got: " + JSON.stringify(id)); } if (!relative) { if (id[1] >= 40) return this.reporter.error("Second objid identifier OOB"); id.splice(0, 2, id[0] * 40 + id[1]); } let size = 0; for (let i = 0;i < id.length; i++) { let ident = id[i]; for (size++;ident >= 128; ident >>= 7) size++; } const objid = Buffer2.alloc(size); let offset = objid.length - 1; for (let i = id.length - 1;i >= 0; i--) { let ident = id[i]; objid[offset--] = ident & 127; while ((ident >>= 7) > 0) objid[offset--] = 128 | ident & 127; } return this._createEncoderBuffer(objid); }; function two(num) { if (num < 10) return "0" + num; else return num; } DERNode.prototype._encodeTime = function encodeTime(time, tag) { let str; const date = new Date(time); if (tag === "gentime") { str = [ two(date.getUTCFullYear()), two(date.getUTCMonth() + 1), two(date.getUTCDate()), two(date.getUTCHours()), two(date.getUTCMinutes()), two(date.getUTCSeconds()), "Z" ].join(""); } else if (tag === "utctime") { str = [ two(date.getUTCFullYear() % 100), two(date.getUTCMonth() + 1), two(date.getUTCDate()), two(date.getUTCHours()), two(date.getUTCMinutes()), two(date.getUTCSeconds()), "Z" ].join(""); } else { this.reporter.error("Encoding " + tag + " time is not supported yet"); } return this._encodeStr(str, "octstr"); }; DERNode.prototype._encodeNull = function encodeNull() { return this._createEncoderBuffer(""); }; DERNode.prototype._encodeInt = function encodeInt(num, values) { if (typeof num === "string") { if (!values) return this.reporter.error("String int or enum given, but no values map"); if (!values.hasOwnProperty(num)) { return this.reporter.error("Values map doesn't contain: " + JSON.stringify(num)); } num = values[num]; } if (typeof num !== "number" && !Buffer2.isBuffer(num)) { const numArray = num.toArray(); if (!num.sign && numArray[0] & 128) { numArray.unshift(0); } num = Buffer2.from(numArray); } if (Buffer2.isBuffer(num)) { let size2 = num.length; if (num.length === 0) size2++; const out2 = Buffer2.alloc(size2); num.copy(out2); if (num.length === 0) out2[0] = 0; return this._createEncoderBuffer(out2); } if (num < 128) return this._createEncoderBuffer(num); if (num < 256) return this._createEncoderBuffer([0, num]); let size = 1; for (let i = num;i >= 256; i >>= 8) size++; const out = new Array(size); for (let i = out.length - 1;i >= 0; i--) { out[i] = num & 255; num >>= 8; } if (out[0] & 128) { out.unshift(0); } return this._createEncoderBuffer(Buffer2.from(out)); }; DERNode.prototype._encodeBool = function encodeBool(value) { return this._createEncoderBuffer(value ? 255 : 0); }; DERNode.prototype._use = function use(entity, obj) { if (typeof entity === "function") entity = entity(obj); return entity._getEncoder("der").tree; }; DERNode.prototype._skipDefault = function skipDefault(dataBuffer, reporter, parent) { const state = this._baseState; let i; if (state["default"] === null) return false; const data = dataBuffer.join(); if (state.defaultBuffer === undefined) state.defaultBuffer = this._encodeValue(state["default"], reporter, parent).join(); if (data.length !== state.defaultBuffer.length) return false; for (i = 0;i < data.length; i++) if (data[i] !== state.defaultBuffer[i]) return false; return true; }; function encodeTag(tag, primitive, cls, reporter) { let res; if (tag === "seqof") tag = "seq"; else if (tag === "setof") tag = "set"; if (der.tagByName.hasOwnProperty(tag)) res = der.tagByName[tag]; else if (typeof tag === "number" && (tag | 0) === tag) res = tag; else return reporter.error("Unknown tag: " + tag); if (res >= 31) return reporter.error("Multi-octet tag encoding unsupported"); if (!primitive) res |= 32; res |= der.tagClassByName[cls || "universal"] << 6; return res; } }); // ../eve/node_modules/asn1.js/lib/asn1/encoders/pem.js var require_pem = __commonJS((exports, module) => { var inherits = require_inherits(); var DEREncoder = require_der2(); function PEMEncoder(entity) { DEREncoder.call(this, entity); this.enc = "pem"; } inherits(PEMEncoder, DEREncoder); module.exports = PEMEncoder; PEMEncoder.prototype.encode = function encode(data, options2) { const buf = DEREncoder.prototype.encode.call(this, data); const p = buf.toString("base64"); const out = ["-----BEGIN " + options2.label + "-----"]; for (let i = 0;i < p.length; i += 64) out.push(p.slice(i, i + 64)); out.push("-----END " + options2.label + "-----"); return out.join(` `); }; }); // ../eve/node_modules/asn1.js/lib/asn1/encoders/index.js var require_encoders = __commonJS((exports) => { var encoders = exports; encoders.der = require_der2(); encoders.pem = require_pem(); }); // ../eve/node_modules/asn1.js/lib/asn1/decoders/der.js var require_der3 = __commonJS((exports, module) => { var inherits = require_inherits(); var bignum = require_bn(); var DecoderBuffer = require_buffer().DecoderBuffer; var Node = require_node(); var der = require_der(); function DERDecoder(entity) { this.enc = "der"; this.name = entity.name; this.entity = entity; this.tree = new DERNode; this.tree._init(entity.body); } module.exports = DERDecoder; DERDecoder.prototype.decode = function decode(data, options2) { if (!DecoderBuffer.isDecoderBuffer(data)) { data = new DecoderBuffer(data, options2); } return this.tree._decode(data, options2); }; function DERNode(parent) { Node.call(this, "der", parent); } inherits(DERNode, Node); DERNode.prototype._peekTag = function peekTag(buffer, tag, any) { if (buffer.isEmpty()) return false; const state = buffer.save(); const decodedTag = derDecodeTag(buffer, 'Failed to peek tag: "' + tag + '"'); if (buffer.isError(decodedTag)) return decodedTag; buffer.restore(state); return decodedTag.tag === tag || decodedTag.tagStr === tag || decodedTag.tagStr + "of" === tag || any; }; DERNode.prototype._decodeTag = function decodeTag(buffer, tag, any) { const decodedTag = derDecodeTag(buffer, 'Failed to decode tag of "' + tag + '"'); if (buffer.isError(decodedTag)) return decodedTag; let len = derDecodeLen(buffer, decodedTag.primitive, 'Failed to get length of "' + tag + '"'); if (buffer.isError(len)) return len; if (!any && decodedTag.tag !== tag && decodedTag.tagStr !== tag && decodedTag.tagStr + "of" !== tag) { return buffer.error('Failed to match tag: "' + tag + '"'); } if (decodedTag.primitive || len !== null) return buffer.skip(len, 'Failed to match body of: "' + tag + '"'); const state = buffer.save(); const res = this._skipUntilEnd(buffer, 'Failed to skip indefinite length body: "' + this.tag + '"'); if (buffer.isError(res)) return res; len = buffer.offset - state.offset; buffer.restore(state); return buffer.skip(len, 'Failed to match body of: "' + tag + '"'); }; DERNode.prototype._skipUntilEnd = function skipUntilEnd(buffer, fail) { for (;; ) { const tag = derDecodeTag(buffer, fail); if (buffer.isError(tag)) return tag; const len = derDecodeLen(buffer, tag.primitive, fail); if (buffer.isError(len)) return len; let res; if (tag.primitive || len !== null) res = buffer.skip(len); else res = this._skipUntilEnd(buffer, fail); if (buffer.isError(res)) return res; if (tag.tagStr === "end") break; } }; DERNode.prototype._decodeList = function decodeList(buffer, tag, decoder, options2) { const result = []; while (!buffer.isEmpty()) { const possibleEnd = this._peekTag(buffer, "end"); if (buffer.isError(possibleEnd)) return possibleEnd; const res = decoder.decode(buffer, "der", options2); if (buffer.isError(res) && possibleEnd) break; result.push(res); } return result; }; DERNode.prototype._decodeStr = function decodeStr(buffer, tag) { if (tag === "bitstr") { const unused = buffer.readUInt8(); if (buffer.isError(unused)) return unused; return { unused, data: buffer.raw() }; } else if (tag === "bmpstr") { const raw = buffer.raw(); if (raw.length % 2 === 1) return buffer.error("Decoding of string type: bmpstr length mismatch"); let str = ""; for (let i = 0;i < raw.length / 2; i++) { str += String.fromCharCode(raw.readUInt16BE(i * 2)); } return str; } else if (tag === "numstr") { const numstr = buffer.raw().toString("ascii"); if (!this._isNumstr(numstr)) { return buffer.error("Decoding of string type: " + "numstr unsupported characters"); } return numstr; } else if (tag === "octstr") { return buffer.raw(); } else if (tag === "objDesc") { return buffer.raw(); } else if (tag === "printstr") { const printstr = buffer.raw().toString("ascii"); if (!this._isPrintstr(printstr)) { return buffer.error("Decoding of string type: " + "printstr unsupported characters"); } return printstr; } else if (/str$/.test(tag)) { return buffer.raw().toString(); } else { return buffer.error("Decoding of string type: " + tag + " unsupported"); } }; DERNode.prototype._decodeObjid = function decodeObjid(buffer, values, relative) { let result; const identifiers = []; let ident = 0; let subident = 0; while (!buffer.isEmpty()) { subident = buffer.readUInt8(); ident <<= 7; ident |= subident & 127; if ((subident & 128) === 0) { identifiers.push(ident); ident = 0; } } if (subident & 128) identifiers.push(ident); const first = identifiers[0] / 40 | 0; const second = identifiers[0] % 40; if (relative) result = identifiers; else result = [first, second].concat(identifiers.slice(1)); if (values) { let tmp = values[result.join(" ")]; if (tmp === undefined) tmp = values[result.join(".")]; if (tmp !== undefined) result = tmp; } return result; }; DERNode.prototype._decodeTime = function decodeTime(buffer, tag) { const str = buffer.raw().toString(); let year; let mon; let day; let hour; let min; let sec; if (tag === "gentime") { year = str.slice(0, 4) | 0; mon = str.slice(4, 6) | 0; day = str.slice(6, 8) | 0; hour = str.slice(8, 10) | 0; min = str.slice(10, 12) | 0; sec = str.slice(12, 14) | 0; } else if (tag === "utctime") { year = str.slice(0, 2) | 0; mon = str.slice(2, 4) | 0; day = str.slice(4, 6) | 0; hour = str.slice(6, 8) | 0; min = str.slice(8, 10) | 0; sec = str.slice(10, 12) | 0; if (year < 70) year = 2000 + year; else year = 1900 + year; } else { return buffer.error("Decoding " + tag + " time is not supported yet"); } return Date.UTC(year, mon - 1, day, hour, min, sec, 0); }; DERNode.prototype._decodeNull = function decodeNull() { return null; }; DERNode.prototype._decodeBool = function decodeBool(buffer) { const res = buffer.readUInt8(); if (buffer.isError(res)) return res; else return res !== 0; }; DERNode.prototype._decodeInt = function decodeInt(buffer, values) { const raw = buffer.raw(); let res = new bignum(raw); if (values) res = values[res.toString(10)] || res; return res; }; DERNode.prototype._use = function use(entity, obj) { if (typeof entity === "function") entity = entity(obj); return entity._getDecoder("der").tree; }; function derDecodeTag(buf, fail) { let tag = buf.readUInt8(fail); if (buf.isError(tag)) return tag; const cls = der.tagClass[tag >> 6]; const primitive = (tag & 32) === 0; if ((tag & 31) === 31) { let oct = tag; tag = 0; while ((oct & 128) === 128) { oct = buf.readUInt8(fail); if (buf.isError(oct)) return oct; tag <<= 7; tag |= oct & 127; } } else { tag &= 31; } const tagStr = der.tag[tag]; return { cls, primitive, tag, tagStr }; } function derDecodeLen(buf, primitive, fail) { let len = buf.readUInt8(fail); if (buf.isError(len)) return len; if (!primitive && len === 128) return null; if ((len & 128) === 0) { return len; } const num = len & 127; if (num > 4) return buf.error("length octect is too long"); len = 0; for (let i = 0;i < num; i++) { len <<= 8; const j = buf.readUInt8(fail); if (buf.isError(j)) return j; len |= j; } return len; } }); // ../eve/node_modules/asn1.js/lib/asn1/decoders/pem.js var require_pem2 = __commonJS((exports, module) => { var inherits = require_inherits(); var Buffer2 = require_safer().Buffer; var DERDecoder = require_der3(); function PEMDecoder(entity) { DERDecoder.call(this, entity); this.enc = "pem"; } inherits(PEMDecoder, DERDecoder); module.exports = PEMDecoder; PEMDecoder.prototype.decode = function decode(data, options2) { const lines = data.toString().split(/[\r\n]+/g); const label = options2.label.toUpperCase(); const re = /^-----(BEGIN|END) ([^-]+)-----$/; let start = -1; let end = -1; for (let i = 0;i < lines.length; i++) { const match = lines[i].match(re); if (match === null) continue; if (match[2] !== label) continue; if (start === -1) { if (match[1] !== "BEGIN") break; start = i; } else { if (match[1] !== "END") break; end = i; break; } } if (start === -1 || end === -1) throw new Error("PEM section not found for: " + label); const base64 = lines.slice(start + 1, end).join(""); base64.replace(/[^a-z0-9+/=]+/gi, ""); const input = Buffer2.from(base64, "base64"); return DERDecoder.prototype.decode.call(this, input, options2); }; }); // ../eve/node_modules/asn1.js/lib/asn1/decoders/index.js var require_decoders = __commonJS((exports) => { var decoders = exports; decoders.der = require_der3(); decoders.pem = require_pem2(); }); // ../eve/node_modules/asn1.js/lib/asn1/api.js var require_api = __commonJS((exports) => { var encoders = require_encoders(); var decoders = require_decoders(); var inherits = require_inherits(); var api = exports; api.define = function define(name, body) { return new Entity(name, body); }; function Entity(name, body) { this.name = name; this.body = body; this.decoders = {}; this.encoders = {}; } Entity.prototype._createNamed = function createNamed(Base) { const name = this.name; function Generated(entity) { this._initNamed(entity, name); } inherits(Generated, Base); Generated.prototype._initNamed = function _initNamed(entity, name2) { Base.call(this, entity, name2); }; return new Generated(this); }; Entity.prototype._getDecoder = function _getDecoder(enc) { enc = enc || "der"; if (!this.decoders.hasOwnProperty(enc)) this.decoders[enc] = this._createNamed(decoders[enc]); return this.decoders[enc]; }; Entity.prototype.decode = function decode(data, enc, options2) { return this._getDecoder(enc).decode(data, options2); }; Entity.prototype._getEncoder = function _getEncoder(enc) { enc = enc || "der"; if (!this.encoders.hasOwnProperty(enc)) this.encoders[enc] = this._createNamed(encoders[enc]); return this.encoders[enc]; }; Entity.prototype.encode = function encode(data, enc, reporter) { return this._getEncoder(enc).encode(data, reporter); }; }); // ../eve/node_modules/asn1.js/lib/asn1/base/index.js var require_base = __commonJS((exports) => { var base = exports; base.Reporter = require_reporter().Reporter; base.DecoderBuffer = require_buffer().DecoderBuffer; base.EncoderBuffer = require_buffer().EncoderBuffer; base.Node = require_node(); }); // ../eve/node_modules/asn1.js/lib/asn1/constants/index.js var require_constants2 = __commonJS((exports) => { var constants = exports; constants._reverse = function reverse(map) { const res = {}; Object.keys(map).forEach(function(key) { if ((key | 0) == key) key = key | 0; const value = map[key]; res[value] = key; }); return res; }; constants.der = require_der(); }); // ../eve/node_modules/asn1.js/lib/asn1.js var require_asn1 = __commonJS((exports) => { var asn1 = exports; asn1.bignum = require_bn(); asn1.define = require_api().define; asn1.base = require_base(); asn1.constants = require_constants2(); asn1.decoders = require_decoders(); asn1.encoders = require_encoders(); }); // ../eve/node_modules/elliptic/package.json var require_package = __commonJS((exports, module) => { module.exports = { name: "elliptic", version: "6.6.1", description: "EC cryptography", main: "lib/elliptic.js", files: [ "lib" ], scripts: { lint: "eslint lib test", "lint:fix": "npm run lint -- --fix", unit: "istanbul test _mocha --reporter=spec test/index.js", test: "npm run lint && npm run unit", version: "grunt dist && git add dist/" }, repository: { type: "git", url: "git@github.com:indutny/elliptic" }, keywords: [ "EC", "Elliptic", "curve", "Cryptography" ], author: "Fedor Indutny ", license: "MIT", bugs: { url: "https://github.com/indutny/elliptic/issues" }, homepage: "https://github.com/indutny/elliptic", devDependencies: { brfs: "^2.0.2", coveralls: "^3.1.0", eslint: "^7.6.0", grunt: "^1.2.1", "grunt-browserify": "^5.3.0", "grunt-cli": "^1.3.2", "grunt-contrib-connect": "^3.0.0", "grunt-contrib-copy": "^1.0.0", "grunt-contrib-uglify": "^5.0.0", "grunt-mocha-istanbul": "^5.0.2", "grunt-saucelabs": "^9.0.1", istanbul: "^0.4.5", mocha: "^8.0.1" }, dependencies: { "bn.js": "^4.11.9", brorand: "^1.1.0", "hash.js": "^1.0.0", "hmac-drbg": "^1.0.1", inherits: "^2.0.4", "minimalistic-assert": "^1.0.1", "minimalistic-crypto-utils": "^1.0.1" } }; }); // ../eve/node_modules/minimalistic-crypto-utils/lib/utils.js var require_utils = __commonJS((exports) => { var utils = exports; function toArray(msg, enc) { if (Array.isArray(msg)) return msg.slice(); if (!msg) return []; var res = []; if (typeof msg !== "string") { for (var i = 0;i < msg.length; i++) res[i] = msg[i] | 0; return res; } if (enc === "hex") { msg = msg.replace(/[^a-z0-9]+/ig, ""); if (msg.length % 2 !== 0) msg = "0" + msg; for (var i = 0;i < msg.length; i += 2) res.push(parseInt(msg[i] + msg[i + 1], 16)); } else { for (var i = 0;i < msg.length; i++) { var c = msg.charCodeAt(i); var hi = c >> 8; var lo = c & 255; if (hi) res.push(hi, lo); else res.push(lo); } } return res; } utils.toArray = toArray; function zero2(word) { if (word.length === 1) return "0" + word; else return word; } utils.zero2 = zero2; function toHex(msg) { var res = ""; for (var i = 0;i < msg.length; i++) res += zero2(msg[i].toString(16)); return res; } utils.toHex = toHex; utils.encode = function encode(arr, enc) { if (enc === "hex") return toHex(arr); else return arr; }; }); // ../eve/node_modules/elliptic/lib/elliptic/utils.js var require_utils2 = __commonJS((exports) => { var utils = exports; var BN = require_bn(); var minAssert = require_minimalistic_assert(); var minUtils = require_utils(); utils.assert = minAssert; utils.toArray = minUtils.toArray; utils.zero2 = minUtils.zero2; utils.toHex = minUtils.toHex; utils.encode = minUtils.encode; function getNAF(num, w, bits) { var naf = new Array(Math.max(num.bitLength(), bits) + 1); var i; for (i = 0;i < naf.length; i += 1) { naf[i] = 0; } var ws = 1 << w + 1; var k = num.clone(); for (i = 0;i < naf.length; i++) { var z; var mod = k.andln(ws - 1); if (k.isOdd()) { if (mod > (ws >> 1) - 1) z = (ws >> 1) - mod; else z = mod; k.isubn(z); } else { z = 0; } naf[i] = z; k.iushrn(1); } return naf; } utils.getNAF = getNAF; function getJSF(k1, k2) { var jsf = [ [], [] ]; k1 = k1.clone(); k2 = k2.clone(); var d1 = 0; var d2 = 0; var m8; while (k1.cmpn(-d1) > 0 || k2.cmpn(-d2) > 0) { var m14 = k1.andln(3) + d1 & 3; var m24 = k2.andln(3) + d2 & 3; if (m14 === 3) m14 = -1; if (m24 === 3) m24 = -1; var u1; if ((m14 & 1) === 0) { u1 = 0; } else { m8 = k1.andln(7) + d1 & 7; if ((m8 === 3 || m8 === 5) && m24 === 2) u1 = -m14; else u1 = m14; } jsf[0].push(u1); var u2; if ((m24 & 1) === 0) { u2 = 0; } else { m8 = k2.andln(7) + d2 & 7; if ((m8 === 3 || m8 === 5) && m14 === 2) u2 = -m24; else u2 = m24; } jsf[1].push(u2); if (2 * d1 === u1 + 1) d1 = 1 - d1; if (2 * d2 === u2 + 1) d2 = 1 - d2; k1.iushrn(1); k2.iushrn(1); } return jsf; } utils.getJSF = getJSF; function cachedProperty(obj, name, computer) { var key = "_" + name; obj.prototype[name] = function cachedProperty() { return this[key] !== undefined ? this[key] : this[key] = computer.call(this); }; } utils.cachedProperty = cachedProperty; function parseBytes(bytes) { return typeof bytes === "string" ? utils.toArray(bytes, "hex") : bytes; } utils.parseBytes = parseBytes; function intFromLE(bytes) { return new BN(bytes, "hex", "le"); } utils.intFromLE = intFromLE; }); // ../eve/node_modules/brorand/index.js var require_brorand = __commonJS((exports, module) => { var r; module.exports = function rand(len) { if (!r) r = new Rand(null); return r.generate(len); }; function Rand(rand) { this.rand = rand; } module.exports.Rand = Rand; Rand.prototype.generate = function generate(len) { return this._rand(len); }; Rand.prototype._rand = function _rand(n) { if (this.rand.getBytes) return this.rand.getBytes(n); var res = new Uint8Array(n); for (var i = 0;i < res.length; i++) res[i] = this.rand.getByte(); return res; }; if (typeof self === "object") { if (self.crypto && self.crypto.getRandomValues) { Rand.prototype._rand = function _rand(n) { var arr = new Uint8Array(n); self.crypto.getRandomValues(arr); return arr; }; } else if (self.msCrypto && self.msCrypto.getRandomValues) { Rand.prototype._rand = function _rand(n) { var arr = new Uint8Array(n); self.msCrypto.getRandomValues(arr); return arr; }; } else if (typeof window === "object") { Rand.prototype._rand = function() { throw new Error("Not implemented yet"); }; } } else { try { crypto2 = __require("crypto"); if (typeof crypto2.randomBytes !== "function") throw new Error("Not supported"); Rand.prototype._rand = function _rand(n) { return crypto2.randomBytes(n); }; } catch (e) {} } var crypto2; }); // ../eve/node_modules/elliptic/lib/elliptic/curve/base.js var require_base2 = __commonJS((exports, module) => { var BN = require_bn(); var utils = require_utils2(); var getNAF = utils.getNAF; var getJSF = utils.getJSF; var assert = utils.assert; function BaseCurve(type, conf) { this.type = type; this.p = new BN(conf.p, 16); this.red = conf.prime ? BN.red(conf.prime) : BN.mont(this.p); this.zero = new BN(0).toRed(this.red); this.one = new BN(1).toRed(this.red); this.two = new BN(2).toRed(this.red); this.n = conf.n && new BN(conf.n, 16); this.g = conf.g && this.pointFromJSON(conf.g, conf.gRed); this._wnafT1 = new Array(4); this._wnafT2 = new Array(4); this._wnafT3 = new Array(4); this._wnafT4 = new Array(4); this._bitLength = this.n ? this.n.bitLength() : 0; var adjustCount = this.n && this.p.div(this.n); if (!adjustCount || adjustCount.cmpn(100) > 0) { this.redN = null; } else { this._maxwellTrick = true; this.redN = this.n.toRed(this.red); } } module.exports = BaseCurve; BaseCurve.prototype.point = function point() { throw new Error("Not implemented"); }; BaseCurve.prototype.validate = function validate() { throw new Error("Not implemented"); }; BaseCurve.prototype._fixedNafMul = function _fixedNafMul(p, k) { assert(p.precomputed); var doubles = p._getDoubles(); var naf = getNAF(k, 1, this._bitLength); var I = (1 << doubles.step + 1) - (doubles.step % 2 === 0 ? 2 : 1); I /= 3; var repr = []; var j; var nafW; for (j = 0;j < naf.length; j += doubles.step) { nafW = 0; for (var l = j + doubles.step - 1;l >= j; l--) nafW = (nafW << 1) + naf[l]; repr.push(nafW); } var a = this.jpoint(null, null, null); var b = this.jpoint(null, null, null); for (var i = I;i > 0; i--) { for (j = 0;j < repr.length; j++) { nafW = repr[j]; if (nafW === i) b = b.mixedAdd(doubles.points[j]); else if (nafW === -i) b = b.mixedAdd(doubles.points[j].neg()); } a = a.add(b); } return a.toP(); }; BaseCurve.prototype._wnafMul = function _wnafMul(p, k) { var w = 4; var nafPoints = p._getNAFPoints(w); w = nafPoints.wnd; var wnd = nafPoints.points; var naf = getNAF(k, w, this._bitLength); var acc = this.jpoint(null, null, null); for (var i = naf.length - 1;i >= 0; i--) { for (var l = 0;i >= 0 && naf[i] === 0; i--) l++; if (i >= 0) l++; acc = acc.dblp(l); if (i < 0) break; var z = naf[i]; assert(z !== 0); if (p.type === "affine") { if (z > 0) acc = acc.mixedAdd(wnd[z - 1 >> 1]); else acc = acc.mixedAdd(wnd[-z - 1 >> 1].neg()); } else { if (z > 0) acc = acc.add(wnd[z - 1 >> 1]); else acc = acc.add(wnd[-z - 1 >> 1].neg()); } } return p.type === "affine" ? acc.toP() : acc; }; BaseCurve.prototype._wnafMulAdd = function _wnafMulAdd(defW, points, coeffs, len, jacobianResult) { var wndWidth = this._wnafT1; var wnd = this._wnafT2; var naf = this._wnafT3; var max = 0; var i; var j; var p; for (i = 0;i < len; i++) { p = points[i]; var nafPoints = p._getNAFPoints(defW); wndWidth[i] = nafPoints.wnd; wnd[i] = nafPoints.points; } for (i = len - 1;i >= 1; i -= 2) { var a = i - 1; var b = i; if (wndWidth[a] !== 1 || wndWidth[b] !== 1) { naf[a] = getNAF(coeffs[a], wndWidth[a], this._bitLength); naf[b] = getNAF(coeffs[b], wndWidth[b], this._bitLength); max = Math.max(naf[a].length, max); max = Math.max(naf[b].length, max); continue; } var comb = [ points[a], null, null, points[b] ]; if (points[a].y.cmp(points[b].y) === 0) { comb[1] = points[a].add(points[b]); comb[2] = points[a].toJ().mixedAdd(points[b].neg()); } else if (points[a].y.cmp(points[b].y.redNeg()) === 0) { comb[1] = points[a].toJ().mixedAdd(points[b]); comb[2] = points[a].add(points[b].neg()); } else { comb[1] = points[a].toJ().mixedAdd(points[b]); comb[2] = points[a].toJ().mixedAdd(points[b].neg()); } var index = [ -3, -1, -5, -7, 0, 7, 5, 1, 3 ]; var jsf = getJSF(coeffs[a], coeffs[b]); max = Math.max(jsf[0].length, max); naf[a] = new Array(max); naf[b] = new Array(max); for (j = 0;j < max; j++) { var ja = jsf[0][j] | 0; var jb = jsf[1][j] | 0; naf[a][j] = index[(ja + 1) * 3 + (jb + 1)]; naf[b][j] = 0; wnd[a] = comb; } } var acc = this.jpoint(null, null, null); var tmp = this._wnafT4; for (i = max;i >= 0; i--) { var k = 0; while (i >= 0) { var zero = true; for (j = 0;j < len; j++) { tmp[j] = naf[j][i] | 0; if (tmp[j] !== 0) zero = false; } if (!zero) break; k++; i--; } if (i >= 0) k++; acc = acc.dblp(k); if (i < 0) break; for (j = 0;j < len; j++) { var z = tmp[j]; if (z === 0) continue; else if (z > 0) p = wnd[j][z - 1 >> 1]; else if (z < 0) p = wnd[j][-z - 1 >> 1].neg(); if (p.type === "affine") acc = acc.mixedAdd(p); else acc = acc.add(p); } } for (i = 0;i < len; i++) wnd[i] = null; if (jacobianResult) return acc; else return acc.toP(); }; function BasePoint(curve, type) { this.curve = curve; this.type = type; this.precomputed = null; } BaseCurve.BasePoint = BasePoint; BasePoint.prototype.eq = function eq() { throw new Error("Not implemented"); }; BasePoint.prototype.validate = function validate() { return this.curve.validate(this); }; BaseCurve.prototype.decodePoint = function decodePoint(bytes, enc) { bytes = utils.toArray(bytes, enc); var len = this.p.byteLength(); if ((bytes[0] === 4 || bytes[0] === 6 || bytes[0] === 7) && bytes.length - 1 === 2 * len) { if (bytes[0] === 6) assert(bytes[bytes.length - 1] % 2 === 0); else if (bytes[0] === 7) assert(bytes[bytes.length - 1] % 2 === 1); var res = this.point(bytes.slice(1, 1 + len), bytes.slice(1 + len, 1 + 2 * len)); return res; } else if ((bytes[0] === 2 || bytes[0] === 3) && bytes.length - 1 === len) { return this.pointFromX(bytes.slice(1, 1 + len), bytes[0] === 3); } throw new Error("Unknown point format"); }; BasePoint.prototype.encodeCompressed = function encodeCompressed(enc) { return this.encode(enc, true); }; BasePoint.prototype._encode = function _encode(compact) { var len = this.curve.p.byteLength(); var x = this.getX().toArray("be", len); if (compact) return [this.getY().isEven() ? 2 : 3].concat(x); return [4].concat(x, this.getY().toArray("be", len)); }; BasePoint.prototype.encode = function encode(enc, compact) { return utils.encode(this._encode(compact), enc); }; BasePoint.prototype.precompute = function precompute(power) { if (this.precomputed) return this; var precomputed = { doubles: null, naf: null, beta: null }; precomputed.naf = this._getNAFPoints(8); precomputed.doubles = this._getDoubles(4, power); precomputed.beta = this._getBeta(); this.precomputed = precomputed; return this; }; BasePoint.prototype._hasDoubles = function _hasDoubles(k) { if (!this.precomputed) return false; var doubles = this.precomputed.doubles; if (!doubles) return false; return doubles.points.length >= Math.ceil((k.bitLength() + 1) / doubles.step); }; BasePoint.prototype._getDoubles = function _getDoubles(step, power) { if (this.precomputed && this.precomputed.doubles) return this.precomputed.doubles; var doubles = [this]; var acc = this; for (var i = 0;i < power; i += step) { for (var j = 0;j < step; j++) acc = acc.dbl(); doubles.push(acc); } return { step, points: doubles }; }; BasePoint.prototype._getNAFPoints = function _getNAFPoints(wnd) { if (this.precomputed && this.precomputed.naf) return this.precomputed.naf; var res = [this]; var max = (1 << wnd) - 1; var dbl = max === 1 ? null : this.dbl(); for (var i = 1;i < max; i++) res[i] = res[i - 1].add(dbl); return { wnd, points: res }; }; BasePoint.prototype._getBeta = function _getBeta() { return null; }; BasePoint.prototype.dblp = function dblp(k) { var r = this; for (var i = 0;i < k; i++) r = r.dbl(); return r; }; }); // ../eve/node_modules/elliptic/lib/elliptic/curve/short.js var require_short = __commonJS((exports, module) => { var utils = require_utils2(); var BN = require_bn(); var inherits = require_inherits(); var Base = require_base2(); var assert = utils.assert; function ShortCurve(conf) { Base.call(this, "short", conf); this.a = new BN(conf.a, 16).toRed(this.red); this.b = new BN(conf.b, 16).toRed(this.red); this.tinv = this.two.redInvm(); this.zeroA = this.a.fromRed().cmpn(0) === 0; this.threeA = this.a.fromRed().sub(this.p).cmpn(-3) === 0; this.endo = this._getEndomorphism(conf); this._endoWnafT1 = new Array(4); this._endoWnafT2 = new Array(4); } inherits(ShortCurve, Base); module.exports = ShortCurve; ShortCurve.prototype._getEndomorphism = function _getEndomorphism(conf) { if (!this.zeroA || !this.g || !this.n || this.p.modn(3) !== 1) return; var beta; var lambda; if (conf.beta) { beta = new BN(conf.beta, 16).toRed(this.red); } else { var betas = this._getEndoRoots(this.p); beta = betas[0].cmp(betas[1]) < 0 ? betas[0] : betas[1]; beta = beta.toRed(this.red); } if (conf.lambda) { lambda = new BN(conf.lambda, 16); } else { var lambdas = this._getEndoRoots(this.n); if (this.g.mul(lambdas[0]).x.cmp(this.g.x.redMul(beta)) === 0) { lambda = lambdas[0]; } else { lambda = lambdas[1]; assert(this.g.mul(lambda).x.cmp(this.g.x.redMul(beta)) === 0); } } var basis; if (conf.basis) { basis = conf.basis.map(function(vec) { return { a: new BN(vec.a, 16), b: new BN(vec.b, 16) }; }); } else { basis = this._getEndoBasis(lambda); } return { beta, lambda, basis }; }; ShortCurve.prototype._getEndoRoots = function _getEndoRoots(num) { var red = num === this.p ? this.red : BN.mont(num); var tinv = new BN(2).toRed(red).redInvm(); var ntinv = tinv.redNeg(); var s = new BN(3).toRed(red).redNeg().redSqrt().redMul(tinv); var l1 = ntinv.redAdd(s).fromRed(); var l2 = ntinv.redSub(s).fromRed(); return [l1, l2]; }; ShortCurve.prototype._getEndoBasis = function _getEndoBasis(lambda) { var aprxSqrt = this.n.ushrn(Math.floor(this.n.bitLength() / 2)); var u = lambda; var v = this.n.clone(); var x1 = new BN(1); var y1 = new BN(0); var x2 = new BN(0); var y2 = new BN(1); var a0; var b0; var a1; var b1; var a2; var b2; var prevR; var i = 0; var r; var x; while (u.cmpn(0) !== 0) { var q = v.div(u); r = v.sub(q.mul(u)); x = x2.sub(q.mul(x1)); var y = y2.sub(q.mul(y1)); if (!a1 && r.cmp(aprxSqrt) < 0) { a0 = prevR.neg(); b0 = x1; a1 = r.neg(); b1 = x; } else if (a1 && ++i === 2) { break; } prevR = r; v = u; u = r; x2 = x1; x1 = x; y2 = y1; y1 = y; } a2 = r.neg(); b2 = x; var len1 = a1.sqr().add(b1.sqr()); var len2 = a2.sqr().add(b2.sqr()); if (len2.cmp(len1) >= 0) { a2 = a0; b2 = b0; } if (a1.negative) { a1 = a1.neg(); b1 = b1.neg(); } if (a2.negative) { a2 = a2.neg(); b2 = b2.neg(); } return [ { a: a1, b: b1 }, { a: a2, b: b2 } ]; }; ShortCurve.prototype._endoSplit = function _endoSplit(k) { var basis = this.endo.basis; var v1 = basis[0]; var v2 = basis[1]; var c1 = v2.b.mul(k).divRound(this.n); var c2 = v1.b.neg().mul(k).divRound(this.n); var p1 = c1.mul(v1.a); var p2 = c2.mul(v2.a); var q1 = c1.mul(v1.b); var q2 = c2.mul(v2.b); var k1 = k.sub(p1).sub(p2); var k2 = q1.add(q2).neg(); return { k1, k2 }; }; ShortCurve.prototype.pointFromX = function pointFromX(x, odd) { x = new BN(x, 16); if (!x.red) x = x.toRed(this.red); var y2 = x.redSqr().redMul(x).redIAdd(x.redMul(this.a)).redIAdd(this.b); var y = y2.redSqrt(); if (y.redSqr().redSub(y2).cmp(this.zero) !== 0) throw new Error("invalid point"); var isOdd = y.fromRed().isOdd(); if (odd && !isOdd || !odd && isOdd) y = y.redNeg(); return this.point(x, y); }; ShortCurve.prototype.validate = function validate(point) { if (point.inf) return true; var x = point.x; var y = point.y; var ax = this.a.redMul(x); var rhs = x.redSqr().redMul(x).redIAdd(ax).redIAdd(this.b); return y.redSqr().redISub(rhs).cmpn(0) === 0; }; ShortCurve.prototype._endoWnafMulAdd = function _endoWnafMulAdd(points, coeffs, jacobianResult) { var npoints = this._endoWnafT1; var ncoeffs = this._endoWnafT2; for (var i = 0;i < points.length; i++) { var split = this._endoSplit(coeffs[i]); var p = points[i]; var beta = p._getBeta(); if (split.k1.negative) { split.k1.ineg(); p = p.neg(true); } if (split.k2.negative) { split.k2.ineg(); beta = beta.neg(true); } npoints[i * 2] = p; npoints[i * 2 + 1] = beta; ncoeffs[i * 2] = split.k1; ncoeffs[i * 2 + 1] = split.k2; } var res = this._wnafMulAdd(1, npoints, ncoeffs, i * 2, jacobianResult); for (var j = 0;j < i * 2; j++) { npoints[j] = null; ncoeffs[j] = null; } return res; }; function Point(curve, x, y, isRed) { Base.BasePoint.call(this, curve, "affine"); if (x === null && y === null) { this.x = null; this.y = null; this.inf = true; } else { this.x = new BN(x, 16); this.y = new BN(y, 16); if (isRed) { this.x.forceRed(this.curve.red); this.y.forceRed(this.curve.red); } if (!this.x.red) this.x = this.x.toRed(this.curve.red); if (!this.y.red) this.y = this.y.toRed(this.curve.red); this.inf = false; } } inherits(Point, Base.BasePoint); ShortCurve.prototype.point = function point(x, y, isRed) { return new Point(this, x, y, isRed); }; ShortCurve.prototype.pointFromJSON = function pointFromJSON(obj, red) { return Point.fromJSON(this, obj, red); }; Point.prototype._getBeta = function _getBeta() { if (!this.curve.endo) return; var pre = this.precomputed; if (pre && pre.beta) return pre.beta; var beta = this.curve.point(this.x.redMul(this.curve.endo.beta), this.y); if (pre) { var curve = this.curve; var endoMul = function(p) { return curve.point(p.x.redMul(curve.endo.beta), p.y); }; pre.beta = beta; beta.precomputed = { beta: null, naf: pre.naf && { wnd: pre.naf.wnd, points: pre.naf.points.map(endoMul) }, doubles: pre.doubles && { step: pre.doubles.step, points: pre.doubles.points.map(endoMul) } }; } return beta; }; Point.prototype.toJSON = function toJSON() { if (!this.precomputed) return [this.x, this.y]; return [this.x, this.y, this.precomputed && { doubles: this.precomputed.doubles && { step: this.precomputed.doubles.step, points: this.precomputed.doubles.points.slice(1) }, naf: this.precomputed.naf && { wnd: this.precomputed.naf.wnd, points: this.precomputed.naf.points.slice(1) } }]; }; Point.fromJSON = function fromJSON(curve, obj, red) { if (typeof obj === "string") obj = JSON.parse(obj); var res = curve.point(obj[0], obj[1], red); if (!obj[2]) return res; function obj2point(obj2) { return curve.point(obj2[0], obj2[1], red); } var pre = obj[2]; res.precomputed = { beta: null, doubles: pre.doubles && { step: pre.doubles.step, points: [res].concat(pre.doubles.points.map(obj2point)) }, naf: pre.naf && { wnd: pre.naf.wnd, points: [res].concat(pre.naf.points.map(obj2point)) } }; return res; }; Point.prototype.inspect = function inspect() { if (this.isInfinity()) return ""; return ""; }; Point.prototype.isInfinity = function isInfinity() { return this.inf; }; Point.prototype.add = function add(p) { if (this.inf) return p; if (p.inf) return this; if (this.eq(p)) return this.dbl(); if (this.neg().eq(p)) return this.curve.point(null, null); if (this.x.cmp(p.x) === 0) return this.curve.point(null, null); var c = this.y.redSub(p.y); if (c.cmpn(0) !== 0) c = c.redMul(this.x.redSub(p.x).redInvm()); var nx = c.redSqr().redISub(this.x).redISub(p.x); var ny = c.redMul(this.x.redSub(nx)).redISub(this.y); return this.curve.point(nx, ny); }; Point.prototype.dbl = function dbl() { if (this.inf) return this; var ys1 = this.y.redAdd(this.y); if (ys1.cmpn(0) === 0) return this.curve.point(null, null); var a = this.curve.a; var x2 = this.x.redSqr(); var dyinv = ys1.redInvm(); var c = x2.redAdd(x2).redIAdd(x2).redIAdd(a).redMul(dyinv); var nx = c.redSqr().redISub(this.x.redAdd(this.x)); var ny = c.redMul(this.x.redSub(nx)).redISub(this.y); return this.curve.point(nx, ny); }; Point.prototype.getX = function getX() { return this.x.fromRed(); }; Point.prototype.getY = function getY() { return this.y.fromRed(); }; Point.prototype.mul = function mul(k) { k = new BN(k, 16); if (this.isInfinity()) return this; else if (this._hasDoubles(k)) return this.curve._fixedNafMul(this, k); else if (this.curve.endo) return this.curve._endoWnafMulAdd([this], [k]); else return this.curve._wnafMul(this, k); }; Point.prototype.mulAdd = function mulAdd(k1, p2, k2) { var points = [this, p2]; var coeffs = [k1, k2]; if (this.curve.endo) return this.curve._endoWnafMulAdd(points, coeffs); else return this.curve._wnafMulAdd(1, points, coeffs, 2); }; Point.prototype.jmulAdd = function jmulAdd(k1, p2, k2) { var points = [this, p2]; var coeffs = [k1, k2]; if (this.curve.endo) return this.curve._endoWnafMulAdd(points, coeffs, true); else return this.curve._wnafMulAdd(1, points, coeffs, 2, true); }; Point.prototype.eq = function eq(p) { return this === p || this.inf === p.inf && (this.inf || this.x.cmp(p.x) === 0 && this.y.cmp(p.y) === 0); }; Point.prototype.neg = function neg(_precompute) { if (this.inf) return this; var res = this.curve.point(this.x, this.y.redNeg()); if (_precompute && this.precomputed) { var pre = this.precomputed; var negate = function(p) { return p.neg(); }; res.precomputed = { naf: pre.naf && { wnd: pre.naf.wnd, points: pre.naf.points.map(negate) }, doubles: pre.doubles && { step: pre.doubles.step, points: pre.doubles.points.map(negate) } }; } return res; }; Point.prototype.toJ = function toJ() { if (this.inf) return this.curve.jpoint(null, null, null); var res = this.curve.jpoint(this.x, this.y, this.curve.one); return res; }; function JPoint(curve, x, y, z) { Base.BasePoint.call(this, curve, "jacobian"); if (x === null && y === null && z === null) { this.x = this.curve.one; this.y = this.curve.one; this.z = new BN(0); } else { this.x = new BN(x, 16); this.y = new BN(y, 16); this.z = new BN(z, 16); } if (!this.x.red) this.x = this.x.toRed(this.curve.red); if (!this.y.red) this.y = this.y.toRed(this.curve.red); if (!this.z.red) this.z = this.z.toRed(this.curve.red); this.zOne = this.z === this.curve.one; } inherits(JPoint, Base.BasePoint); ShortCurve.prototype.jpoint = function jpoint(x, y, z) { return new JPoint(this, x, y, z); }; JPoint.prototype.toP = function toP() { if (this.isInfinity()) return this.curve.point(null, null); var zinv = this.z.redInvm(); var zinv2 = zinv.redSqr(); var ax = this.x.redMul(zinv2); var ay = this.y.redMul(zinv2).redMul(zinv); return this.curve.point(ax, ay); }; JPoint.prototype.neg = function neg() { return this.curve.jpoint(this.x, this.y.redNeg(), this.z); }; JPoint.prototype.add = function add(p) { if (this.isInfinity()) return p; if (p.isInfinity()) return this; var pz2 = p.z.redSqr(); var z2 = this.z.redSqr(); var u1 = this.x.redMul(pz2); var u2 = p.x.redMul(z2); var s1 = this.y.redMul(pz2.redMul(p.z)); var s2 = p.y.redMul(z2.redMul(this.z)); var h = u1.redSub(u2); var r = s1.redSub(s2); if (h.cmpn(0) === 0) { if (r.cmpn(0) !== 0) return this.curve.jpoint(null, null, null); else return this.dbl(); } var h2 = h.redSqr(); var h3 = h2.redMul(h); var v = u1.redMul(h2); var nx = r.redSqr().redIAdd(h3).redISub(v).redISub(v); var ny = r.redMul(v.redISub(nx)).redISub(s1.redMul(h3)); var nz = this.z.redMul(p.z).redMul(h); return this.curve.jpoint(nx, ny, nz); }; JPoint.prototype.mixedAdd = function mixedAdd(p) { if (this.isInfinity()) return p.toJ(); if (p.isInfinity()) return this; var z2 = this.z.redSqr(); var u1 = this.x; var u2 = p.x.redMul(z2); var s1 = this.y; var s2 = p.y.redMul(z2).redMul(this.z); var h = u1.redSub(u2); var r = s1.redSub(s2); if (h.cmpn(0) === 0) { if (r.cmpn(0) !== 0) return this.curve.jpoint(null, null, null); else return this.dbl(); } var h2 = h.redSqr(); var h3 = h2.redMul(h); var v = u1.redMul(h2); var nx = r.redSqr().redIAdd(h3).redISub(v).redISub(v); var ny = r.redMul(v.redISub(nx)).redISub(s1.redMul(h3)); var nz = this.z.redMul(h); return this.curve.jpoint(nx, ny, nz); }; JPoint.prototype.dblp = function dblp(pow) { if (pow === 0) return this; if (this.isInfinity()) return this; if (!pow) return this.dbl(); var i; if (this.curve.zeroA || this.curve.threeA) { var r = this; for (i = 0;i < pow; i++) r = r.dbl(); return r; } var a = this.curve.a; var tinv = this.curve.tinv; var jx = this.x; var jy = this.y; var jz = this.z; var jz4 = jz.redSqr().redSqr(); var jyd = jy.redAdd(jy); for (i = 0;i < pow; i++) { var jx2 = jx.redSqr(); var jyd2 = jyd.redSqr(); var jyd4 = jyd2.redSqr(); var c = jx2.redAdd(jx2).redIAdd(jx2).redIAdd(a.redMul(jz4)); var t1 = jx.redMul(jyd2); var nx = c.redSqr().redISub(t1.redAdd(t1)); var t2 = t1.redISub(nx); var dny = c.redMul(t2); dny = dny.redIAdd(dny).redISub(jyd4); var nz = jyd.redMul(jz); if (i + 1 < pow) jz4 = jz4.redMul(jyd4); jx = nx; jz = nz; jyd = dny; } return this.curve.jpoint(jx, jyd.redMul(tinv), jz); }; JPoint.prototype.dbl = function dbl() { if (this.isInfinity()) return this; if (this.curve.zeroA) return this._zeroDbl(); else if (this.curve.threeA) return this._threeDbl(); else return this._dbl(); }; JPoint.prototype._zeroDbl = function _zeroDbl() { var nx; var ny; var nz; if (this.zOne) { var xx = this.x.redSqr(); var yy = this.y.redSqr(); var yyyy = yy.redSqr(); var s = this.x.redAdd(yy).redSqr().redISub(xx).redISub(yyyy); s = s.redIAdd(s); var m = xx.redAdd(xx).redIAdd(xx); var t = m.redSqr().redISub(s).redISub(s); var yyyy8 = yyyy.redIAdd(yyyy); yyyy8 = yyyy8.redIAdd(yyyy8); yyyy8 = yyyy8.redIAdd(yyyy8); nx = t; ny = m.redMul(s.redISub(t)).redISub(yyyy8); nz = this.y.redAdd(this.y); } else { var a = this.x.redSqr(); var b = this.y.redSqr(); var c = b.redSqr(); var d = this.x.redAdd(b).redSqr().redISub(a).redISub(c); d = d.redIAdd(d); var e = a.redAdd(a).redIAdd(a); var f = e.redSqr(); var c8 = c.redIAdd(c); c8 = c8.redIAdd(c8); c8 = c8.redIAdd(c8); nx = f.redISub(d).redISub(d); ny = e.redMul(d.redISub(nx)).redISub(c8); nz = this.y.redMul(this.z); nz = nz.redIAdd(nz); } return this.curve.jpoint(nx, ny, nz); }; JPoint.prototype._threeDbl = function _threeDbl() { var nx; var ny; var nz; if (this.zOne) { var xx = this.x.redSqr(); var yy = this.y.redSqr(); var yyyy = yy.redSqr(); var s = this.x.redAdd(yy).redSqr().redISub(xx).redISub(yyyy); s = s.redIAdd(s); var m = xx.redAdd(xx).redIAdd(xx).redIAdd(this.curve.a); var t = m.redSqr().redISub(s).redISub(s); nx = t; var yyyy8 = yyyy.redIAdd(yyyy); yyyy8 = yyyy8.redIAdd(yyyy8); yyyy8 = yyyy8.redIAdd(yyyy8); ny = m.redMul(s.redISub(t)).redISub(yyyy8); nz = this.y.redAdd(this.y); } else { var delta = this.z.redSqr(); var gamma = this.y.redSqr(); var beta = this.x.redMul(gamma); var alpha = this.x.redSub(delta).redMul(this.x.redAdd(delta)); alpha = alpha.redAdd(alpha).redIAdd(alpha); var beta4 = beta.redIAdd(beta); beta4 = beta4.redIAdd(beta4); var beta8 = beta4.redAdd(beta4); nx = alpha.redSqr().redISub(beta8); nz = this.y.redAdd(this.z).redSqr().redISub(gamma).redISub(delta); var ggamma8 = gamma.redSqr(); ggamma8 = ggamma8.redIAdd(ggamma8); ggamma8 = ggamma8.redIAdd(ggamma8); ggamma8 = ggamma8.redIAdd(ggamma8); ny = alpha.redMul(beta4.redISub(nx)).redISub(ggamma8); } return this.curve.jpoint(nx, ny, nz); }; JPoint.prototype._dbl = function _dbl() { var a = this.curve.a; var jx = this.x; var jy = this.y; var jz = this.z; var jz4 = jz.redSqr().redSqr(); var jx2 = jx.redSqr(); var jy2 = jy.redSqr(); var c = jx2.redAdd(jx2).redIAdd(jx2).redIAdd(a.redMul(jz4)); var jxd4 = jx.redAdd(jx); jxd4 = jxd4.redIAdd(jxd4); var t1 = jxd4.redMul(jy2); var nx = c.redSqr().redISub(t1.redAdd(t1)); var t2 = t1.redISub(nx); var jyd8 = jy2.redSqr(); jyd8 = jyd8.redIAdd(jyd8); jyd8 = jyd8.redIAdd(jyd8); jyd8 = jyd8.redIAdd(jyd8); var ny = c.redMul(t2).redISub(jyd8); var nz = jy.redAdd(jy).redMul(jz); return this.curve.jpoint(nx, ny, nz); }; JPoint.prototype.trpl = function trpl() { if (!this.curve.zeroA) return this.dbl().add(this); var xx = this.x.redSqr(); var yy = this.y.redSqr(); var zz = this.z.redSqr(); var yyyy = yy.redSqr(); var m = xx.redAdd(xx).redIAdd(xx); var mm = m.redSqr(); var e = this.x.redAdd(yy).redSqr().redISub(xx).redISub(yyyy); e = e.redIAdd(e); e = e.redAdd(e).redIAdd(e); e = e.redISub(mm); var ee = e.redSqr(); var t = yyyy.redIAdd(yyyy); t = t.redIAdd(t); t = t.redIAdd(t); t = t.redIAdd(t); var u = m.redIAdd(e).redSqr().redISub(mm).redISub(ee).redISub(t); var yyu4 = yy.redMul(u); yyu4 = yyu4.redIAdd(yyu4); yyu4 = yyu4.redIAdd(yyu4); var nx = this.x.redMul(ee).redISub(yyu4); nx = nx.redIAdd(nx); nx = nx.redIAdd(nx); var ny = this.y.redMul(u.redMul(t.redISub(u)).redISub(e.redMul(ee))); ny = ny.redIAdd(ny); ny = ny.redIAdd(ny); ny = ny.redIAdd(ny); var nz = this.z.redAdd(e).redSqr().redISub(zz).redISub(ee); return this.curve.jpoint(nx, ny, nz); }; JPoint.prototype.mul = function mul(k, kbase) { k = new BN(k, kbase); return this.curve._wnafMul(this, k); }; JPoint.prototype.eq = function eq(p) { if (p.type === "affine") return this.eq(p.toJ()); if (this === p) return true; var z2 = this.z.redSqr(); var pz2 = p.z.redSqr(); if (this.x.redMul(pz2).redISub(p.x.redMul(z2)).cmpn(0) !== 0) return false; var z3 = z2.redMul(this.z); var pz3 = pz2.redMul(p.z); return this.y.redMul(pz3).redISub(p.y.redMul(z3)).cmpn(0) === 0; }; JPoint.prototype.eqXToP = function eqXToP(x) { var zs = this.z.redSqr(); var rx = x.toRed(this.curve.red).redMul(zs); if (this.x.cmp(rx) === 0) return true; var xc = x.clone(); var t = this.curve.redN.redMul(zs); for (;; ) { xc.iadd(this.curve.n); if (xc.cmp(this.curve.p) >= 0) return false; rx.redIAdd(t); if (this.x.cmp(rx) === 0) return true; } }; JPoint.prototype.inspect = function inspect() { if (this.isInfinity()) return ""; return ""; }; JPoint.prototype.isInfinity = function isInfinity() { return this.z.cmpn(0) === 0; }; }); // ../eve/node_modules/elliptic/lib/elliptic/curve/mont.js var require_mont = __commonJS((exports, module) => { var BN = require_bn(); var inherits = require_inherits(); var Base = require_base2(); var utils = require_utils2(); function MontCurve(conf) { Base.call(this, "mont", conf); this.a = new BN(conf.a, 16).toRed(this.red); this.b = new BN(conf.b, 16).toRed(this.red); this.i4 = new BN(4).toRed(this.red).redInvm(); this.two = new BN(2).toRed(this.red); this.a24 = this.i4.redMul(this.a.redAdd(this.two)); } inherits(MontCurve, Base); module.exports = MontCurve; MontCurve.prototype.validate = function validate(point) { var x = point.normalize().x; var x2 = x.redSqr(); var rhs = x2.redMul(x).redAdd(x2.redMul(this.a)).redAdd(x); var y = rhs.redSqrt(); return y.redSqr().cmp(rhs) === 0; }; function Point(curve, x, z) { Base.BasePoint.call(this, curve, "projective"); if (x === null && z === null) { this.x = this.curve.one; this.z = this.curve.zero; } else { this.x = new BN(x, 16); this.z = new BN(z, 16); if (!this.x.red) this.x = this.x.toRed(this.curve.red); if (!this.z.red) this.z = this.z.toRed(this.curve.red); } } inherits(Point, Base.BasePoint); MontCurve.prototype.decodePoint = function decodePoint(bytes, enc) { return this.point(utils.toArray(bytes, enc), 1); }; MontCurve.prototype.point = function point(x, z) { return new Point(this, x, z); }; MontCurve.prototype.pointFromJSON = function pointFromJSON(obj) { return Point.fromJSON(this, obj); }; Point.prototype.precompute = function precompute() {}; Point.prototype._encode = function _encode() { return this.getX().toArray("be", this.curve.p.byteLength()); }; Point.fromJSON = function fromJSON(curve, obj) { return new Point(curve, obj[0], obj[1] || curve.one); }; Point.prototype.inspect = function inspect() { if (this.isInfinity()) return ""; return ""; }; Point.prototype.isInfinity = function isInfinity() { return this.z.cmpn(0) === 0; }; Point.prototype.dbl = function dbl() { var a = this.x.redAdd(this.z); var aa = a.redSqr(); var b = this.x.redSub(this.z); var bb = b.redSqr(); var c = aa.redSub(bb); var nx = aa.redMul(bb); var nz = c.redMul(bb.redAdd(this.curve.a24.redMul(c))); return this.curve.point(nx, nz); }; Point.prototype.add = function add() { throw new Error("Not supported on Montgomery curve"); }; Point.prototype.diffAdd = function diffAdd(p, diff) { var a = this.x.redAdd(this.z); var b = this.x.redSub(this.z); var c = p.x.redAdd(p.z); var d = p.x.redSub(p.z); var da = d.redMul(a); var cb = c.redMul(b); var nx = diff.z.redMul(da.redAdd(cb).redSqr()); var nz = diff.x.redMul(da.redISub(cb).redSqr()); return this.curve.point(nx, nz); }; Point.prototype.mul = function mul(k) { var t = k.clone(); var a = this; var b = this.curve.point(null, null); var c = this; for (var bits = [];t.cmpn(0) !== 0; t.iushrn(1)) bits.push(t.andln(1)); for (var i = bits.length - 1;i >= 0; i--) { if (bits[i] === 0) { a = a.diffAdd(b, c); b = b.dbl(); } else { b = a.diffAdd(b, c); a = a.dbl(); } } return b; }; Point.prototype.mulAdd = function mulAdd() { throw new Error("Not supported on Montgomery curve"); }; Point.prototype.jumlAdd = function jumlAdd() { throw new Error("Not supported on Montgomery curve"); }; Point.prototype.eq = function eq(other) { return this.getX().cmp(other.getX()) === 0; }; Point.prototype.normalize = function normalize() { this.x = this.x.redMul(this.z.redInvm()); this.z = this.curve.one; return this; }; Point.prototype.getX = function getX() { this.normalize(); return this.x.fromRed(); }; }); // ../eve/node_modules/elliptic/lib/elliptic/curve/edwards.js var require_edwards = __commonJS((exports, module) => { var utils = require_utils2(); var BN = require_bn(); var inherits = require_inherits(); var Base = require_base2(); var assert = utils.assert; function EdwardsCurve(conf) { this.twisted = (conf.a | 0) !== 1; this.mOneA = this.twisted && (conf.a | 0) === -1; this.extended = this.mOneA; Base.call(this, "edwards", conf); this.a = new BN(conf.a, 16).umod(this.red.m); this.a = this.a.toRed(this.red); this.c = new BN(conf.c, 16).toRed(this.red); this.c2 = this.c.redSqr(); this.d = new BN(conf.d, 16).toRed(this.red); this.dd = this.d.redAdd(this.d); assert(!this.twisted || this.c.fromRed().cmpn(1) === 0); this.oneC = (conf.c | 0) === 1; } inherits(EdwardsCurve, Base); module.exports = EdwardsCurve; EdwardsCurve.prototype._mulA = function _mulA(num) { if (this.mOneA) return num.redNeg(); else return this.a.redMul(num); }; EdwardsCurve.prototype._mulC = function _mulC(num) { if (this.oneC) return num; else return this.c.redMul(num); }; EdwardsCurve.prototype.jpoint = function jpoint(x, y, z, t) { return this.point(x, y, z, t); }; EdwardsCurve.prototype.pointFromX = function pointFromX(x, odd) { x = new BN(x, 16); if (!x.red) x = x.toRed(this.red); var x2 = x.redSqr(); var rhs = this.c2.redSub(this.a.redMul(x2)); var lhs = this.one.redSub(this.c2.redMul(this.d).redMul(x2)); var y2 = rhs.redMul(lhs.redInvm()); var y = y2.redSqrt(); if (y.redSqr().redSub(y2).cmp(this.zero) !== 0) throw new Error("invalid point"); var isOdd = y.fromRed().isOdd(); if (odd && !isOdd || !odd && isOdd) y = y.redNeg(); return this.point(x, y); }; EdwardsCurve.prototype.pointFromY = function pointFromY(y, odd) { y = new BN(y, 16); if (!y.red) y = y.toRed(this.red); var y2 = y.redSqr(); var lhs = y2.redSub(this.c2); var rhs = y2.redMul(this.d).redMul(this.c2).redSub(this.a); var x2 = lhs.redMul(rhs.redInvm()); if (x2.cmp(this.zero) === 0) { if (odd) throw new Error("invalid point"); else return this.point(this.zero, y); } var x = x2.redSqrt(); if (x.redSqr().redSub(x2).cmp(this.zero) !== 0) throw new Error("invalid point"); if (x.fromRed().isOdd() !== odd) x = x.redNeg(); return this.point(x, y); }; EdwardsCurve.prototype.validate = function validate(point) { if (point.isInfinity()) return true; point.normalize(); var x2 = point.x.redSqr(); var y2 = point.y.redSqr(); var lhs = x2.redMul(this.a).redAdd(y2); var rhs = this.c2.redMul(this.one.redAdd(this.d.redMul(x2).redMul(y2))); return lhs.cmp(rhs) === 0; }; function Point(curve, x, y, z, t) { Base.BasePoint.call(this, curve, "projective"); if (x === null && y === null && z === null) { this.x = this.curve.zero; this.y = this.curve.one; this.z = this.curve.one; this.t = this.curve.zero; this.zOne = true; } else { this.x = new BN(x, 16); this.y = new BN(y, 16); this.z = z ? new BN(z, 16) : this.curve.one; this.t = t && new BN(t, 16); if (!this.x.red) this.x = this.x.toRed(this.curve.red); if (!this.y.red) this.y = this.y.toRed(this.curve.red); if (!this.z.red) this.z = this.z.toRed(this.curve.red); if (this.t && !this.t.red) this.t = this.t.toRed(this.curve.red); this.zOne = this.z === this.curve.one; if (this.curve.extended && !this.t) { this.t = this.x.redMul(this.y); if (!this.zOne) this.t = this.t.redMul(this.z.redInvm()); } } } inherits(Point, Base.BasePoint); EdwardsCurve.prototype.pointFromJSON = function pointFromJSON(obj) { return Point.fromJSON(this, obj); }; EdwardsCurve.prototype.point = function point(x, y, z, t) { return new Point(this, x, y, z, t); }; Point.fromJSON = function fromJSON(curve, obj) { return new Point(curve, obj[0], obj[1], obj[2]); }; Point.prototype.inspect = function inspect() { if (this.isInfinity()) return ""; return ""; }; Point.prototype.isInfinity = function isInfinity() { return this.x.cmpn(0) === 0 && (this.y.cmp(this.z) === 0 || this.zOne && this.y.cmp(this.curve.c) === 0); }; Point.prototype._extDbl = function _extDbl() { var a = this.x.redSqr(); var b = this.y.redSqr(); var c = this.z.redSqr(); c = c.redIAdd(c); var d = this.curve._mulA(a); var e = this.x.redAdd(this.y).redSqr().redISub(a).redISub(b); var g = d.redAdd(b); var f = g.redSub(c); var h = d.redSub(b); var nx = e.redMul(f); var ny = g.redMul(h); var nt = e.redMul(h); var nz = f.redMul(g); return this.curve.point(nx, ny, nz, nt); }; Point.prototype._projDbl = function _projDbl() { var b = this.x.redAdd(this.y).redSqr(); var c = this.x.redSqr(); var d = this.y.redSqr(); var nx; var ny; var nz; var e; var h; var j; if (this.curve.twisted) { e = this.curve._mulA(c); var f = e.redAdd(d); if (this.zOne) { nx = b.redSub(c).redSub(d).redMul(f.redSub(this.curve.two)); ny = f.redMul(e.redSub(d)); nz = f.redSqr().redSub(f).redSub(f); } else { h = this.z.redSqr(); j = f.redSub(h).redISub(h); nx = b.redSub(c).redISub(d).redMul(j); ny = f.redMul(e.redSub(d)); nz = f.redMul(j); } } else { e = c.redAdd(d); h = this.curve._mulC(this.z).redSqr(); j = e.redSub(h).redSub(h); nx = this.curve._mulC(b.redISub(e)).redMul(j); ny = this.curve._mulC(e).redMul(c.redISub(d)); nz = e.redMul(j); } return this.curve.point(nx, ny, nz); }; Point.prototype.dbl = function dbl() { if (this.isInfinity()) return this; if (this.curve.extended) return this._extDbl(); else return this._projDbl(); }; Point.prototype._extAdd = function _extAdd(p) { var a = this.y.redSub(this.x).redMul(p.y.redSub(p.x)); var b = this.y.redAdd(this.x).redMul(p.y.redAdd(p.x)); var c = this.t.redMul(this.curve.dd).redMul(p.t); var d = this.z.redMul(p.z.redAdd(p.z)); var e = b.redSub(a); var f = d.redSub(c); var g = d.redAdd(c); var h = b.redAdd(a); var nx = e.redMul(f); var ny = g.redMul(h); var nt = e.redMul(h); var nz = f.redMul(g); return this.curve.point(nx, ny, nz, nt); }; Point.prototype._projAdd = function _projAdd(p) { var a = this.z.redMul(p.z); var b = a.redSqr(); var c = this.x.redMul(p.x); var d = this.y.redMul(p.y); var e = this.curve.d.redMul(c).redMul(d); var f = b.redSub(e); var g = b.redAdd(e); var tmp = this.x.redAdd(this.y).redMul(p.x.redAdd(p.y)).redISub(c).redISub(d); var nx = a.redMul(f).redMul(tmp); var ny; var nz; if (this.curve.twisted) { ny = a.redMul(g).redMul(d.redSub(this.curve._mulA(c))); nz = f.redMul(g); } else { ny = a.redMul(g).redMul(d.redSub(c)); nz = this.curve._mulC(f).redMul(g); } return this.curve.point(nx, ny, nz); }; Point.prototype.add = function add(p) { if (this.isInfinity()) return p; if (p.isInfinity()) return this; if (this.curve.extended) return this._extAdd(p); else return this._projAdd(p); }; Point.prototype.mul = function mul(k) { if (this._hasDoubles(k)) return this.curve._fixedNafMul(this, k); else return this.curve._wnafMul(this, k); }; Point.prototype.mulAdd = function mulAdd(k1, p, k2) { return this.curve._wnafMulAdd(1, [this, p], [k1, k2], 2, false); }; Point.prototype.jmulAdd = function jmulAdd(k1, p, k2) { return this.curve._wnafMulAdd(1, [this, p], [k1, k2], 2, true); }; Point.prototype.normalize = function normalize() { if (this.zOne) return this; var zi = this.z.redInvm(); this.x = this.x.redMul(zi); this.y = this.y.redMul(zi); if (this.t) this.t = this.t.redMul(zi); this.z = this.curve.one; this.zOne = true; return this; }; Point.prototype.neg = function neg() { return this.curve.point(this.x.redNeg(), this.y, this.z, this.t && this.t.redNeg()); }; Point.prototype.getX = function getX() { this.normalize(); return this.x.fromRed(); }; Point.prototype.getY = function getY() { this.normalize(); return this.y.fromRed(); }; Point.prototype.eq = function eq(other) { return this === other || this.getX().cmp(other.getX()) === 0 && this.getY().cmp(other.getY()) === 0; }; Point.prototype.eqXToP = function eqXToP(x) { var rx = x.toRed(this.curve.red).redMul(this.z); if (this.x.cmp(rx) === 0) return true; var xc = x.clone(); var t = this.curve.redN.redMul(this.z); for (;; ) { xc.iadd(this.curve.n); if (xc.cmp(this.curve.p) >= 0) return false; rx.redIAdd(t); if (this.x.cmp(rx) === 0) return true; } }; Point.prototype.toP = Point.prototype.normalize; Point.prototype.mixedAdd = Point.prototype.add; }); // ../eve/node_modules/elliptic/lib/elliptic/curve/index.js var require_curve = __commonJS((exports) => { var curve = exports; curve.base = require_base2(); curve.short = require_short(); curve.mont = require_mont(); curve.edwards = require_edwards(); }); // ../eve/node_modules/hash.js/lib/hash/utils.js var require_utils3 = __commonJS((exports) => { var assert = require_minimalistic_assert(); var inherits = require_inherits(); exports.inherits = inherits; function isSurrogatePair(msg, i) { if ((msg.charCodeAt(i) & 64512) !== 55296) { return false; } if (i < 0 || i + 1 >= msg.length) { return false; } return (msg.charCodeAt(i + 1) & 64512) === 56320; } function toArray(msg, enc) { if (Array.isArray(msg)) return msg.slice(); if (!msg) return []; var res = []; if (typeof msg === "string") { if (!enc) { var p = 0; for (var i = 0;i < msg.length; i++) { var c = msg.charCodeAt(i); if (c < 128) { res[p++] = c; } else if (c < 2048) { res[p++] = c >> 6 | 192; res[p++] = c & 63 | 128; } else if (isSurrogatePair(msg, i)) { c = 65536 + ((c & 1023) << 10) + (msg.charCodeAt(++i) & 1023); res[p++] = c >> 18 | 240; res[p++] = c >> 12 & 63 | 128; res[p++] = c >> 6 & 63 | 128; res[p++] = c & 63 | 128; } else { res[p++] = c >> 12 | 224; res[p++] = c >> 6 & 63 | 128; res[p++] = c & 63 | 128; } } } else if (enc === "hex") { msg = msg.replace(/[^a-z0-9]+/ig, ""); if (msg.length % 2 !== 0) msg = "0" + msg; for (i = 0;i < msg.length; i += 2) res.push(parseInt(msg[i] + msg[i + 1], 16)); } } else { for (i = 0;i < msg.length; i++) res[i] = msg[i] | 0; } return res; } exports.toArray = toArray; function toHex(msg) { var res = ""; for (var i = 0;i < msg.length; i++) res += zero2(msg[i].toString(16)); return res; } exports.toHex = toHex; function htonl(w) { var res = w >>> 24 | w >>> 8 & 65280 | w << 8 & 16711680 | (w & 255) << 24; return res >>> 0; } exports.htonl = htonl; function toHex32(msg, endian) { var res = ""; for (var i = 0;i < msg.length; i++) { var w = msg[i]; if (endian === "little") w = htonl(w); res += zero8(w.toString(16)); } return res; } exports.toHex32 = toHex32; function zero2(word) { if (word.length === 1) return "0" + word; else return word; } exports.zero2 = zero2; function zero8(word) { if (word.length === 7) return "0" + word; else if (word.length === 6) return "00" + word; else if (word.length === 5) return "000" + word; else if (word.length === 4) return "0000" + word; else if (word.length === 3) return "00000" + word; else if (word.length === 2) return "000000" + word; else if (word.length === 1) return "0000000" + word; else return word; } exports.zero8 = zero8; function join32(msg, start, end, endian) { var len = end - start; assert(len % 4 === 0); var res = new Array(len / 4); for (var i = 0, k = start;i < res.length; i++, k += 4) { var w; if (endian === "big") w = msg[k] << 24 | msg[k + 1] << 16 | msg[k + 2] << 8 | msg[k + 3]; else w = msg[k + 3] << 24 | msg[k + 2] << 16 | msg[k + 1] << 8 | msg[k]; res[i] = w >>> 0; } return res; } exports.join32 = join32; function split32(msg, endian) { var res = new Array(msg.length * 4); for (var i = 0, k = 0;i < msg.length; i++, k += 4) { var m = msg[i]; if (endian === "big") { res[k] = m >>> 24; res[k + 1] = m >>> 16 & 255; res[k + 2] = m >>> 8 & 255; res[k + 3] = m & 255; } else { res[k + 3] = m >>> 24; res[k + 2] = m >>> 16 & 255; res[k + 1] = m >>> 8 & 255; res[k] = m & 255; } } return res; } exports.split32 = split32; function rotr32(w, b) { return w >>> b | w << 32 - b; } exports.rotr32 = rotr32; function rotl32(w, b) { return w << b | w >>> 32 - b; } exports.rotl32 = rotl32; function sum32(a, b) { return a + b >>> 0; } exports.sum32 = sum32; function sum32_3(a, b, c) { return a + b + c >>> 0; } exports.sum32_3 = sum32_3; function sum32_4(a, b, c, d) { return a + b + c + d >>> 0; } exports.sum32_4 = sum32_4; function sum32_5(a, b, c, d, e) { return a + b + c + d + e >>> 0; } exports.sum32_5 = sum32_5; function sum64(buf, pos, ah, al) { var bh = buf[pos]; var bl = buf[pos + 1]; var lo = al + bl >>> 0; var hi = (lo < al ? 1 : 0) + ah + bh; buf[pos] = hi >>> 0; buf[pos + 1] = lo; } exports.sum64 = sum64; function sum64_hi(ah, al, bh, bl) { var lo = al + bl >>> 0; var hi = (lo < al ? 1 : 0) + ah + bh; return hi >>> 0; } exports.sum64_hi = sum64_hi; function sum64_lo(ah, al, bh, bl) { var lo = al + bl; return lo >>> 0; } exports.sum64_lo = sum64_lo; function sum64_4_hi(ah, al, bh, bl, ch, cl, dh, dl) { var carry = 0; var lo = al; lo = lo + bl >>> 0; carry += lo < al ? 1 : 0; lo = lo + cl >>> 0; carry += lo < cl ? 1 : 0; lo = lo + dl >>> 0; carry += lo < dl ? 1 : 0; var hi = ah + bh + ch + dh + carry; return hi >>> 0; } exports.sum64_4_hi = sum64_4_hi; function sum64_4_lo(ah, al, bh, bl, ch, cl, dh, dl) { var lo = al + bl + cl + dl; return lo >>> 0; } exports.sum64_4_lo = sum64_4_lo; function sum64_5_hi(ah, al, bh, bl, ch, cl, dh, dl, eh, el) { var carry = 0; var lo = al; lo = lo + bl >>> 0; carry += lo < al ? 1 : 0; lo = lo + cl >>> 0; carry += lo < cl ? 1 : 0; lo = lo + dl >>> 0; carry += lo < dl ? 1 : 0; lo = lo + el >>> 0; carry += lo < el ? 1 : 0; var hi = ah + bh + ch + dh + eh + carry; return hi >>> 0; } exports.sum64_5_hi = sum64_5_hi; function sum64_5_lo(ah, al, bh, bl, ch, cl, dh, dl, eh, el) { var lo = al + bl + cl + dl + el; return lo >>> 0; } exports.sum64_5_lo = sum64_5_lo; function rotr64_hi(ah, al, num) { var r = al << 32 - num | ah >>> num; return r >>> 0; } exports.rotr64_hi = rotr64_hi; function rotr64_lo(ah, al, num) { var r = ah << 32 - num | al >>> num; return r >>> 0; } exports.rotr64_lo = rotr64_lo; function shr64_hi(ah, al, num) { return ah >>> num; } exports.shr64_hi = shr64_hi; function shr64_lo(ah, al, num) { var r = ah << 32 - num | al >>> num; return r >>> 0; } exports.shr64_lo = shr64_lo; }); // ../eve/node_modules/hash.js/lib/hash/common.js var require_common = __commonJS((exports) => { var utils = require_utils3(); var assert = require_minimalistic_assert(); function BlockHash() { this.pending = null; this.pendingTotal = 0; this.blockSize = this.constructor.blockSize; this.outSize = this.constructor.outSize; this.hmacStrength = this.constructor.hmacStrength; this.padLength = this.constructor.padLength / 8; this.endian = "big"; this._delta8 = this.blockSize / 8; this._delta32 = this.blockSize / 32; } exports.BlockHash = BlockHash; BlockHash.prototype.update = function update(msg, enc) { msg = utils.toArray(msg, enc); if (!this.pending) this.pending = msg; else this.pending = this.pending.concat(msg); this.pendingTotal += msg.length; if (this.pending.length >= this._delta8) { msg = this.pending; var r = msg.length % this._delta8; this.pending = msg.slice(msg.length - r, msg.length); if (this.pending.length === 0) this.pending = null; msg = utils.join32(msg, 0, msg.length - r, this.endian); for (var i = 0;i < msg.length; i += this._delta32) this._update(msg, i, i + this._delta32); } return this; }; BlockHash.prototype.digest = function digest(enc) { this.update(this._pad()); assert(this.pending === null); return this._digest(enc); }; BlockHash.prototype._pad = function pad() { var len = this.pendingTotal; var bytes = this._delta8; var k = bytes - (len + this.padLength) % bytes; var res = new Array(k + this.padLength); res[0] = 128; for (var i = 1;i < k; i++) res[i] = 0; len <<= 3; if (this.endian === "big") { for (var t = 8;t < this.padLength; t++) res[i++] = 0; res[i++] = 0; res[i++] = 0; res[i++] = 0; res[i++] = 0; res[i++] = len >>> 24 & 255; res[i++] = len >>> 16 & 255; res[i++] = len >>> 8 & 255; res[i++] = len & 255; } else { res[i++] = len & 255; res[i++] = len >>> 8 & 255; res[i++] = len >>> 16 & 255; res[i++] = len >>> 24 & 255; res[i++] = 0; res[i++] = 0; res[i++] = 0; res[i++] = 0; for (t = 8;t < this.padLength; t++) res[i++] = 0; } return res; }; }); // ../eve/node_modules/hash.js/lib/hash/sha/common.js var require_common2 = __commonJS((exports) => { var utils = require_utils3(); var rotr32 = utils.rotr32; function ft_1(s, x, y, z) { if (s === 0) return ch32(x, y, z); if (s === 1 || s === 3) return p32(x, y, z); if (s === 2) return maj32(x, y, z); } exports.ft_1 = ft_1; function ch32(x, y, z) { return x & y ^ ~x & z; } exports.ch32 = ch32; function maj32(x, y, z) { return x & y ^ x & z ^ y & z; } exports.maj32 = maj32; function p32(x, y, z) { return x ^ y ^ z; } exports.p32 = p32; function s0_256(x) { return rotr32(x, 2) ^ rotr32(x, 13) ^ rotr32(x, 22); } exports.s0_256 = s0_256; function s1_256(x) { return rotr32(x, 6) ^ rotr32(x, 11) ^ rotr32(x, 25); } exports.s1_256 = s1_256; function g0_256(x) { return rotr32(x, 7) ^ rotr32(x, 18) ^ x >>> 3; } exports.g0_256 = g0_256; function g1_256(x) { return rotr32(x, 17) ^ rotr32(x, 19) ^ x >>> 10; } exports.g1_256 = g1_256; }); // ../eve/node_modules/hash.js/lib/hash/sha/1.js var require_1 = __commonJS((exports, module) => { var utils = require_utils3(); var common = require_common(); var shaCommon = require_common2(); var rotl32 = utils.rotl32; var sum32 = utils.sum32; var sum32_5 = utils.sum32_5; var ft_1 = shaCommon.ft_1; var BlockHash = common.BlockHash; var sha1_K = [ 1518500249, 1859775393, 2400959708, 3395469782 ]; function SHA1() { if (!(this instanceof SHA1)) return new SHA1; BlockHash.call(this); this.h = [ 1732584193, 4023233417, 2562383102, 271733878, 3285377520 ]; this.W = new Array(80); } utils.inherits(SHA1, BlockHash); module.exports = SHA1; SHA1.blockSize = 512; SHA1.outSize = 160; SHA1.hmacStrength = 80; SHA1.padLength = 64; SHA1.prototype._update = function _update(msg, start) { var W = this.W; for (var i = 0;i < 16; i++) W[i] = msg[start + i]; for (;i < W.length; i++) W[i] = rotl32(W[i - 3] ^ W[i - 8] ^ W[i - 14] ^ W[i - 16], 1); var a = this.h[0]; var b = this.h[1]; var c = this.h[2]; var d = this.h[3]; var e = this.h[4]; for (i = 0;i < W.length; i++) { var s = ~~(i / 20); var t = sum32_5(rotl32(a, 5), ft_1(s, b, c, d), e, W[i], sha1_K[s]); e = d; d = c; c = rotl32(b, 30); b = a; a = t; } this.h[0] = sum32(this.h[0], a); this.h[1] = sum32(this.h[1], b); this.h[2] = sum32(this.h[2], c); this.h[3] = sum32(this.h[3], d); this.h[4] = sum32(this.h[4], e); }; SHA1.prototype._digest = function digest(enc) { if (enc === "hex") return utils.toHex32(this.h, "big"); else return utils.split32(this.h, "big"); }; }); // ../eve/node_modules/hash.js/lib/hash/sha/256.js var require_256 = __commonJS((exports, module) => { var utils = require_utils3(); var common = require_common(); var shaCommon = require_common2(); var assert = require_minimalistic_assert(); var sum32 = utils.sum32; var sum32_4 = utils.sum32_4; var sum32_5 = utils.sum32_5; var ch32 = shaCommon.ch32; var maj32 = shaCommon.maj32; var s0_256 = shaCommon.s0_256; var s1_256 = shaCommon.s1_256; var g0_256 = shaCommon.g0_256; var g1_256 = shaCommon.g1_256; var BlockHash = common.BlockHash; var sha256_K = [ 1116352408, 1899447441, 3049323471, 3921009573, 961987163, 1508970993, 2453635748, 2870763221, 3624381080, 310598401, 607225278, 1426881987, 1925078388, 2162078206, 2614888103, 3248222580, 3835390401, 4022224774, 264347078, 604807628, 770255983, 1249150122, 1555081692, 1996064986, 2554220882, 2821834349, 2952996808, 3210313671, 3336571891, 3584528711, 113926993, 338241895, 666307205, 773529912, 1294757372, 1396182291, 1695183700, 1986661051, 2177026350, 2456956037, 2730485921, 2820302411, 3259730800, 3345764771, 3516065817, 3600352804, 4094571909, 275423344, 430227734, 506948616, 659060556, 883997877, 958139571, 1322822218, 1537002063, 1747873779, 1955562222, 2024104815, 2227730452, 2361852424, 2428436474, 2756734187, 3204031479, 3329325298 ]; function SHA256() { if (!(this instanceof SHA256)) return new SHA256; BlockHash.call(this); this.h = [ 1779033703, 3144134277, 1013904242, 2773480762, 1359893119, 2600822924, 528734635, 1541459225 ]; this.k = sha256_K; this.W = new Array(64); } utils.inherits(SHA256, BlockHash); module.exports = SHA256; SHA256.blockSize = 512; SHA256.outSize = 256; SHA256.hmacStrength = 192; SHA256.padLength = 64; SHA256.prototype._update = function _update(msg, start) { var W = this.W; for (var i = 0;i < 16; i++) W[i] = msg[start + i]; for (;i < W.length; i++) W[i] = sum32_4(g1_256(W[i - 2]), W[i - 7], g0_256(W[i - 15]), W[i - 16]); var a = this.h[0]; var b = this.h[1]; var c = this.h[2]; var d = this.h[3]; var e = this.h[4]; var f = this.h[5]; var g = this.h[6]; var h = this.h[7]; assert(this.k.length === W.length); for (i = 0;i < W.length; i++) { var T1 = sum32_5(h, s1_256(e), ch32(e, f, g), this.k[i], W[i]); var T2 = sum32(s0_256(a), maj32(a, b, c)); h = g; g = f; f = e; e = sum32(d, T1); d = c; c = b; b = a; a = sum32(T1, T2); } this.h[0] = sum32(this.h[0], a); this.h[1] = sum32(this.h[1], b); this.h[2] = sum32(this.h[2], c); this.h[3] = sum32(this.h[3], d); this.h[4] = sum32(this.h[4], e); this.h[5] = sum32(this.h[5], f); this.h[6] = sum32(this.h[6], g); this.h[7] = sum32(this.h[7], h); }; SHA256.prototype._digest = function digest(enc) { if (enc === "hex") return utils.toHex32(this.h, "big"); else return utils.split32(this.h, "big"); }; }); // ../eve/node_modules/hash.js/lib/hash/sha/224.js var require_224 = __commonJS((exports, module) => { var utils = require_utils3(); var SHA256 = require_256(); function SHA224() { if (!(this instanceof SHA224)) return new SHA224; SHA256.call(this); this.h = [ 3238371032, 914150663, 812702999, 4144912697, 4290775857, 1750603025, 1694076839, 3204075428 ]; } utils.inherits(SHA224, SHA256); module.exports = SHA224; SHA224.blockSize = 512; SHA224.outSize = 224; SHA224.hmacStrength = 192; SHA224.padLength = 64; SHA224.prototype._digest = function digest(enc) { if (enc === "hex") return utils.toHex32(this.h.slice(0, 7), "big"); else return utils.split32(this.h.slice(0, 7), "big"); }; }); // ../eve/node_modules/hash.js/lib/hash/sha/512.js var require_512 = __commonJS((exports, module) => { var utils = require_utils3(); var common = require_common(); var assert = require_minimalistic_assert(); var rotr64_hi = utils.rotr64_hi; var rotr64_lo = utils.rotr64_lo; var shr64_hi = utils.shr64_hi; var shr64_lo = utils.shr64_lo; var sum64 = utils.sum64; var sum64_hi = utils.sum64_hi; var sum64_lo = utils.sum64_lo; var sum64_4_hi = utils.sum64_4_hi; var sum64_4_lo = utils.sum64_4_lo; var sum64_5_hi = utils.sum64_5_hi; var sum64_5_lo = utils.sum64_5_lo; var BlockHash = common.BlockHash; var sha512_K = [ 1116352408, 3609767458, 1899447441, 602891725, 3049323471, 3964484399, 3921009573, 2173295548, 961987163, 4081628472, 1508970993, 3053834265, 2453635748, 2937671579, 2870763221, 3664609560, 3624381080, 2734883394, 310598401, 1164996542, 607225278, 1323610764, 1426881987, 3590304994, 1925078388, 4068182383, 2162078206, 991336113, 2614888103, 633803317, 3248222580, 3479774868, 3835390401, 2666613458, 4022224774, 944711139, 264347078, 2341262773, 604807628, 2007800933, 770255983, 1495990901, 1249150122, 1856431235, 1555081692, 3175218132, 1996064986, 2198950837, 2554220882, 3999719339, 2821834349, 766784016, 2952996808, 2566594879, 3210313671, 3203337956, 3336571891, 1034457026, 3584528711, 2466948901, 113926993, 3758326383, 338241895, 168717936, 666307205, 1188179964, 773529912, 1546045734, 1294757372, 1522805485, 1396182291, 2643833823, 1695183700, 2343527390, 1986661051, 1014477480, 2177026350, 1206759142, 2456956037, 344077627, 2730485921, 1290863460, 2820302411, 3158454273, 3259730800, 3505952657, 3345764771, 106217008, 3516065817, 3606008344, 3600352804, 1432725776, 4094571909, 1467031594, 275423344, 851169720, 430227734, 3100823752, 506948616, 1363258195, 659060556, 3750685593, 883997877, 3785050280, 958139571, 3318307427, 1322822218, 3812723403, 1537002063, 2003034995, 1747873779, 3602036899, 1955562222, 1575990012, 2024104815, 1125592928, 2227730452, 2716904306, 2361852424, 442776044, 2428436474, 593698344, 2756734187, 3733110249, 3204031479, 2999351573, 3329325298, 3815920427, 3391569614, 3928383900, 3515267271, 566280711, 3940187606, 3454069534, 4118630271, 4000239992, 116418474, 1914138554, 174292421, 2731055270, 289380356, 3203993006, 460393269, 320620315, 685471733, 587496836, 852142971, 1086792851, 1017036298, 365543100, 1126000580, 2618297676, 1288033470, 3409855158, 1501505948, 4234509866, 1607167915, 987167468, 1816402316, 1246189591 ]; function SHA512() { if (!(this instanceof SHA512)) return new SHA512; BlockHash.call(this); this.h = [ 1779033703, 4089235720, 3144134277, 2227873595, 1013904242, 4271175723, 2773480762, 1595750129, 1359893119, 2917565137, 2600822924, 725511199, 528734635, 4215389547, 1541459225, 327033209 ]; this.k = sha512_K; this.W = new Array(160); } utils.inherits(SHA512, BlockHash); module.exports = SHA512; SHA512.blockSize = 1024; SHA512.outSize = 512; SHA512.hmacStrength = 192; SHA512.padLength = 128; SHA512.prototype._prepareBlock = function _prepareBlock(msg, start) { var W = this.W; for (var i = 0;i < 32; i++) W[i] = msg[start + i]; for (;i < W.length; i += 2) { var c0_hi = g1_512_hi(W[i - 4], W[i - 3]); var c0_lo = g1_512_lo(W[i - 4], W[i - 3]); var c1_hi = W[i - 14]; var c1_lo = W[i - 13]; var c2_hi = g0_512_hi(W[i - 30], W[i - 29]); var c2_lo = g0_512_lo(W[i - 30], W[i - 29]); var c3_hi = W[i - 32]; var c3_lo = W[i - 31]; W[i] = sum64_4_hi(c0_hi, c0_lo, c1_hi, c1_lo, c2_hi, c2_lo, c3_hi, c3_lo); W[i + 1] = sum64_4_lo(c0_hi, c0_lo, c1_hi, c1_lo, c2_hi, c2_lo, c3_hi, c3_lo); } }; SHA512.prototype._update = function _update(msg, start) { this._prepareBlock(msg, start); var W = this.W; var ah = this.h[0]; var al = this.h[1]; var bh = this.h[2]; var bl = this.h[3]; var ch = this.h[4]; var cl = this.h[5]; var dh = this.h[6]; var dl = this.h[7]; var eh = this.h[8]; var el = this.h[9]; var fh = this.h[10]; var fl = this.h[11]; var gh = this.h[12]; var gl = this.h[13]; var hh = this.h[14]; var hl = this.h[15]; assert(this.k.length === W.length); for (var i = 0;i < W.length; i += 2) { var c0_hi = hh; var c0_lo = hl; var c1_hi = s1_512_hi(eh, el); var c1_lo = s1_512_lo(eh, el); var c2_hi = ch64_hi(eh, el, fh, fl, gh, gl); var c2_lo = ch64_lo(eh, el, fh, fl, gh, gl); var c3_hi = this.k[i]; var c3_lo = this.k[i + 1]; var c4_hi = W[i]; var c4_lo = W[i + 1]; var T1_hi = sum64_5_hi(c0_hi, c0_lo, c1_hi, c1_lo, c2_hi, c2_lo, c3_hi, c3_lo, c4_hi, c4_lo); var T1_lo = sum64_5_lo(c0_hi, c0_lo, c1_hi, c1_lo, c2_hi, c2_lo, c3_hi, c3_lo, c4_hi, c4_lo); c0_hi = s0_512_hi(ah, al); c0_lo = s0_512_lo(ah, al); c1_hi = maj64_hi(ah, al, bh, bl, ch, cl); c1_lo = maj64_lo(ah, al, bh, bl, ch, cl); var T2_hi = sum64_hi(c0_hi, c0_lo, c1_hi, c1_lo); var T2_lo = sum64_lo(c0_hi, c0_lo, c1_hi, c1_lo); hh = gh; hl = gl; gh = fh; gl = fl; fh = eh; fl = el; eh = sum64_hi(dh, dl, T1_hi, T1_lo); el = sum64_lo(dl, dl, T1_hi, T1_lo); dh = ch; dl = cl; ch = bh; cl = bl; bh = ah; bl = al; ah = sum64_hi(T1_hi, T1_lo, T2_hi, T2_lo); al = sum64_lo(T1_hi, T1_lo, T2_hi, T2_lo); } sum64(this.h, 0, ah, al); sum64(this.h, 2, bh, bl); sum64(this.h, 4, ch, cl); sum64(this.h, 6, dh, dl); sum64(this.h, 8, eh, el); sum64(this.h, 10, fh, fl); sum64(this.h, 12, gh, gl); sum64(this.h, 14, hh, hl); }; SHA512.prototype._digest = function digest(enc) { if (enc === "hex") return utils.toHex32(this.h, "big"); else return utils.split32(this.h, "big"); }; function ch64_hi(xh, xl, yh, yl, zh) { var r = xh & yh ^ ~xh & zh; if (r < 0) r += 4294967296; return r; } function ch64_lo(xh, xl, yh, yl, zh, zl) { var r = xl & yl ^ ~xl & zl; if (r < 0) r += 4294967296; return r; } function maj64_hi(xh, xl, yh, yl, zh) { var r = xh & yh ^ xh & zh ^ yh & zh; if (r < 0) r += 4294967296; return r; } function maj64_lo(xh, xl, yh, yl, zh, zl) { var r = xl & yl ^ xl & zl ^ yl & zl; if (r < 0) r += 4294967296; return r; } function s0_512_hi(xh, xl) { var c0_hi = rotr64_hi(xh, xl, 28); var c1_hi = rotr64_hi(xl, xh, 2); var c2_hi = rotr64_hi(xl, xh, 7); var r = c0_hi ^ c1_hi ^ c2_hi; if (r < 0) r += 4294967296; return r; } function s0_512_lo(xh, xl) { var c0_lo = rotr64_lo(xh, xl, 28); var c1_lo = rotr64_lo(xl, xh, 2); var c2_lo = rotr64_lo(xl, xh, 7); var r = c0_lo ^ c1_lo ^ c2_lo; if (r < 0) r += 4294967296; return r; } function s1_512_hi(xh, xl) { var c0_hi = rotr64_hi(xh, xl, 14); var c1_hi = rotr64_hi(xh, xl, 18); var c2_hi = rotr64_hi(xl, xh, 9); var r = c0_hi ^ c1_hi ^ c2_hi; if (r < 0) r += 4294967296; return r; } function s1_512_lo(xh, xl) { var c0_lo = rotr64_lo(xh, xl, 14); var c1_lo = rotr64_lo(xh, xl, 18); var c2_lo = rotr64_lo(xl, xh, 9); var r = c0_lo ^ c1_lo ^ c2_lo; if (r < 0) r += 4294967296; return r; } function g0_512_hi(xh, xl) { var c0_hi = rotr64_hi(xh, xl, 1); var c1_hi = rotr64_hi(xh, xl, 8); var c2_hi = shr64_hi(xh, xl, 7); var r = c0_hi ^ c1_hi ^ c2_hi; if (r < 0) r += 4294967296; return r; } function g0_512_lo(xh, xl) { var c0_lo = rotr64_lo(xh, xl, 1); var c1_lo = rotr64_lo(xh, xl, 8); var c2_lo = shr64_lo(xh, xl, 7); var r = c0_lo ^ c1_lo ^ c2_lo; if (r < 0) r += 4294967296; return r; } function g1_512_hi(xh, xl) { var c0_hi = rotr64_hi(xh, xl, 19); var c1_hi = rotr64_hi(xl, xh, 29); var c2_hi = shr64_hi(xh, xl, 6); var r = c0_hi ^ c1_hi ^ c2_hi; if (r < 0) r += 4294967296; return r; } function g1_512_lo(xh, xl) { var c0_lo = rotr64_lo(xh, xl, 19); var c1_lo = rotr64_lo(xl, xh, 29); var c2_lo = shr64_lo(xh, xl, 6); var r = c0_lo ^ c1_lo ^ c2_lo; if (r < 0) r += 4294967296; return r; } }); // ../eve/node_modules/hash.js/lib/hash/sha/384.js var require_384 = __commonJS((exports, module) => { var utils = require_utils3(); var SHA512 = require_512(); function SHA384() { if (!(this instanceof SHA384)) return new SHA384; SHA512.call(this); this.h = [ 3418070365, 3238371032, 1654270250, 914150663, 2438529370, 812702999, 355462360, 4144912697, 1731405415, 4290775857, 2394180231, 1750603025, 3675008525, 1694076839, 1203062813, 3204075428 ]; } utils.inherits(SHA384, SHA512); module.exports = SHA384; SHA384.blockSize = 1024; SHA384.outSize = 384; SHA384.hmacStrength = 192; SHA384.padLength = 128; SHA384.prototype._digest = function digest(enc) { if (enc === "hex") return utils.toHex32(this.h.slice(0, 12), "big"); else return utils.split32(this.h.slice(0, 12), "big"); }; }); // ../eve/node_modules/hash.js/lib/hash/sha.js var require_sha = __commonJS((exports) => { exports.sha1 = require_1(); exports.sha224 = require_224(); exports.sha256 = require_256(); exports.sha384 = require_384(); exports.sha512 = require_512(); }); // ../eve/node_modules/hash.js/lib/hash/ripemd.js var require_ripemd = __commonJS((exports) => { var utils = require_utils3(); var common = require_common(); var rotl32 = utils.rotl32; var sum32 = utils.sum32; var sum32_3 = utils.sum32_3; var sum32_4 = utils.sum32_4; var BlockHash = common.BlockHash; function RIPEMD160() { if (!(this instanceof RIPEMD160)) return new RIPEMD160; BlockHash.call(this); this.h = [1732584193, 4023233417, 2562383102, 271733878, 3285377520]; this.endian = "little"; } utils.inherits(RIPEMD160, BlockHash); exports.ripemd160 = RIPEMD160; RIPEMD160.blockSize = 512; RIPEMD160.outSize = 160; RIPEMD160.hmacStrength = 192; RIPEMD160.padLength = 64; RIPEMD160.prototype._update = function update(msg, start) { var A = this.h[0]; var B = this.h[1]; var C = this.h[2]; var D = this.h[3]; var E = this.h[4]; var Ah = A; var Bh = B; var Ch = C; var Dh = D; var Eh = E; for (var j = 0;j < 80; j++) { var T = sum32(rotl32(sum32_4(A, f(j, B, C, D), msg[r[j] + start], K(j)), s[j]), E); A = E; E = D; D = rotl32(C, 10); C = B; B = T; T = sum32(rotl32(sum32_4(Ah, f(79 - j, Bh, Ch, Dh), msg[rh[j] + start], Kh(j)), sh[j]), Eh); Ah = Eh; Eh = Dh; Dh = rotl32(Ch, 10); Ch = Bh; Bh = T; } T = sum32_3(this.h[1], C, Dh); this.h[1] = sum32_3(this.h[2], D, Eh); this.h[2] = sum32_3(this.h[3], E, Ah); this.h[3] = sum32_3(this.h[4], A, Bh); this.h[4] = sum32_3(this.h[0], B, Ch); this.h[0] = T; }; RIPEMD160.prototype._digest = function digest(enc) { if (enc === "hex") return utils.toHex32(this.h, "little"); else return utils.split32(this.h, "little"); }; function f(j, x, y, z) { if (j <= 15) return x ^ y ^ z; else if (j <= 31) return x & y | ~x & z; else if (j <= 47) return (x | ~y) ^ z; else if (j <= 63) return x & z | y & ~z; else return x ^ (y | ~z); } function K(j) { if (j <= 15) return 0; else if (j <= 31) return 1518500249; else if (j <= 47) return 1859775393; else if (j <= 63) return 2400959708; else return 2840853838; } function Kh(j) { if (j <= 15) return 1352829926; else if (j <= 31) return 1548603684; else if (j <= 47) return 1836072691; else if (j <= 63) return 2053994217; else return 0; } var r = [ 0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14, 15, 7, 4, 13, 1, 10, 6, 15, 3, 12, 0, 9, 5, 2, 14, 11, 8, 3, 10, 14, 4, 9, 15, 8, 1, 2, 7, 0, 6, 13, 11, 5, 12, 1, 9, 11, 10, 0, 8, 12, 4, 13, 3, 7, 15, 14, 5, 6, 2, 4, 0, 5, 9, 7, 12, 2, 10, 14, 1, 3, 8, 11, 6, 15, 13 ]; var rh = [ 5, 14, 7, 0, 9, 2, 11, 4, 13, 6, 15, 8, 1, 10, 3, 12, 6, 11, 3, 7, 0, 13, 5, 10, 14, 15, 8, 12, 4, 9, 1, 2, 15, 5, 1, 3, 7, 14, 6, 9, 11, 8, 12, 2, 10, 0, 4, 13, 8, 6, 4, 1, 3, 11, 15, 0, 5, 12, 2, 13, 9, 7, 10, 14, 12, 15, 10, 4, 1, 5, 8, 7, 6, 2, 13, 14, 0, 3, 9, 11 ]; var s = [ 11, 14, 15, 12, 5, 8, 7, 9, 11, 13, 14, 15, 6, 7, 9, 8, 7, 6, 8, 13, 11, 9, 7, 15, 7, 12, 15, 9, 11, 7, 13, 12, 11, 13, 6, 7, 14, 9, 13, 15, 14, 8, 13, 6, 5, 12, 7, 5, 11, 12, 14, 15, 14, 15, 9, 8, 9, 14, 5, 6, 8, 6, 5, 12, 9, 15, 5, 11, 6, 8, 13, 12, 5, 12, 13, 14, 11, 8, 5, 6 ]; var sh = [ 8, 9, 9, 11, 13, 15, 15, 5, 7, 7, 8, 11, 14, 14, 12, 6, 9, 13, 15, 7, 12, 8, 9, 11, 7, 7, 12, 7, 6, 15, 13, 11, 9, 7, 15, 11, 8, 6, 6, 14, 12, 13, 5, 14, 13, 13, 7, 5, 15, 5, 8, 11, 14, 14, 6, 14, 6, 9, 12, 9, 12, 5, 15, 8, 8, 5, 12, 9, 12, 5, 14, 6, 8, 13, 6, 5, 15, 13, 11, 11 ]; }); // ../eve/node_modules/hash.js/lib/hash/hmac.js var require_hmac = __commonJS((exports, module) => { var utils = require_utils3(); var assert = require_minimalistic_assert(); function Hmac(hash, key, enc) { if (!(this instanceof Hmac)) return new Hmac(hash, key, enc); this.Hash = hash; this.blockSize = hash.blockSize / 8; this.outSize = hash.outSize / 8; this.inner = null; this.outer = null; this._init(utils.toArray(key, enc)); } module.exports = Hmac; Hmac.prototype._init = function init(key) { if (key.length > this.blockSize) key = new this.Hash().update(key).digest(); assert(key.length <= this.blockSize); for (var i = key.length;i < this.blockSize; i++) key.push(0); for (i = 0;i < key.length; i++) key[i] ^= 54; this.inner = new this.Hash().update(key); for (i = 0;i < key.length; i++) key[i] ^= 106; this.outer = new this.Hash().update(key); }; Hmac.prototype.update = function update(msg, enc) { this.inner.update(msg, enc); return this; }; Hmac.prototype.digest = function digest(enc) { this.outer.update(this.inner.digest()); return this.outer.digest(enc); }; }); // ../eve/node_modules/hash.js/lib/hash.js var require_hash = __commonJS((exports) => { var hash = exports; hash.utils = require_utils3(); hash.common = require_common(); hash.sha = require_sha(); hash.ripemd = require_ripemd(); hash.hmac = require_hmac(); hash.sha1 = hash.sha.sha1; hash.sha256 = hash.sha.sha256; hash.sha224 = hash.sha.sha224; hash.sha384 = hash.sha.sha384; hash.sha512 = hash.sha.sha512; hash.ripemd160 = hash.ripemd.ripemd160; }); // ../eve/node_modules/elliptic/lib/elliptic/precomputed/secp256k1.js var require_secp256k1 = __commonJS((exports, module) => { module.exports = { doubles: { step: 4, points: [ [ "e60fce93b59e9ec53011aabc21c23e97b2a31369b87a5ae9c44ee89e2a6dec0a", "f7e3507399e595929db99f34f57937101296891e44d23f0be1f32cce69616821" ], [ "8282263212c609d9ea2a6e3e172de238d8c39cabd5ac1ca10646e23fd5f51508", "11f8a8098557dfe45e8256e830b60ace62d613ac2f7b17bed31b6eaff6e26caf" ], [ "175e159f728b865a72f99cc6c6fc846de0b93833fd2222ed73fce5b551e5b739", "d3506e0d9e3c79eba4ef97a51ff71f5eacb5955add24345c6efa6ffee9fed695" ], [ "363d90d447b00c9c99ceac05b6262ee053441c7e55552ffe526bad8f83ff4640", "4e273adfc732221953b445397f3363145b9a89008199ecb62003c7f3bee9de9" ], [ "8b4b5f165df3c2be8c6244b5b745638843e4a781a15bcd1b69f79a55dffdf80c", "4aad0a6f68d308b4b3fbd7813ab0da04f9e336546162ee56b3eff0c65fd4fd36" ], [ "723cbaa6e5db996d6bf771c00bd548c7b700dbffa6c0e77bcb6115925232fcda", "96e867b5595cc498a921137488824d6e2660a0653779494801dc069d9eb39f5f" ], [ "eebfa4d493bebf98ba5feec812c2d3b50947961237a919839a533eca0e7dd7fa", "5d9a8ca3970ef0f269ee7edaf178089d9ae4cdc3a711f712ddfd4fdae1de8999" ], [ "100f44da696e71672791d0a09b7bde459f1215a29b3c03bfefd7835b39a48db0", "cdd9e13192a00b772ec8f3300c090666b7ff4a18ff5195ac0fbd5cd62bc65a09" ], [ "e1031be262c7ed1b1dc9227a4a04c017a77f8d4464f3b3852c8acde6e534fd2d", "9d7061928940405e6bb6a4176597535af292dd419e1ced79a44f18f29456a00d" ], [ "feea6cae46d55b530ac2839f143bd7ec5cf8b266a41d6af52d5e688d9094696d", "e57c6b6c97dce1bab06e4e12bf3ecd5c981c8957cc41442d3155debf18090088" ], [ "da67a91d91049cdcb367be4be6ffca3cfeed657d808583de33fa978bc1ec6cb1", "9bacaa35481642bc41f463f7ec9780e5dec7adc508f740a17e9ea8e27a68be1d" ], [ "53904faa0b334cdda6e000935ef22151ec08d0f7bb11069f57545ccc1a37b7c0", "5bc087d0bc80106d88c9eccac20d3c1c13999981e14434699dcb096b022771c8" ], [ "8e7bcd0bd35983a7719cca7764ca906779b53a043a9b8bcaeff959f43ad86047", "10b7770b2a3da4b3940310420ca9514579e88e2e47fd68b3ea10047e8460372a" ], [ "385eed34c1cdff21e6d0818689b81bde71a7f4f18397e6690a841e1599c43862", "283bebc3e8ea23f56701de19e9ebf4576b304eec2086dc8cc0458fe5542e5453" ], [ "6f9d9b803ecf191637c73a4413dfa180fddf84a5947fbc9c606ed86c3fac3a7", "7c80c68e603059ba69b8e2a30e45c4d47ea4dd2f5c281002d86890603a842160" ], [ "3322d401243c4e2582a2147c104d6ecbf774d163db0f5e5313b7e0e742d0e6bd", "56e70797e9664ef5bfb019bc4ddaf9b72805f63ea2873af624f3a2e96c28b2a0" ], [ "85672c7d2de0b7da2bd1770d89665868741b3f9af7643397721d74d28134ab83", "7c481b9b5b43b2eb6374049bfa62c2e5e77f17fcc5298f44c8e3094f790313a6" ], [ "948bf809b1988a46b06c9f1919413b10f9226c60f668832ffd959af60c82a0a", "53a562856dcb6646dc6b74c5d1c3418c6d4dff08c97cd2bed4cb7f88d8c8e589" ], [ "6260ce7f461801c34f067ce0f02873a8f1b0e44dfc69752accecd819f38fd8e8", "bc2da82b6fa5b571a7f09049776a1ef7ecd292238051c198c1a84e95b2b4ae17" ], [ "e5037de0afc1d8d43d8348414bbf4103043ec8f575bfdc432953cc8d2037fa2d", "4571534baa94d3b5f9f98d09fb990bddbd5f5b03ec481f10e0e5dc841d755bda" ], [ "e06372b0f4a207adf5ea905e8f1771b4e7e8dbd1c6a6c5b725866a0ae4fce725", "7a908974bce18cfe12a27bb2ad5a488cd7484a7787104870b27034f94eee31dd" ], [ "213c7a715cd5d45358d0bbf9dc0ce02204b10bdde2a3f58540ad6908d0559754", "4b6dad0b5ae462507013ad06245ba190bb4850f5f36a7eeddff2c27534b458f2" ], [ "4e7c272a7af4b34e8dbb9352a5419a87e2838c70adc62cddf0cc3a3b08fbd53c", "17749c766c9d0b18e16fd09f6def681b530b9614bff7dd33e0b3941817dcaae6" ], [ "fea74e3dbe778b1b10f238ad61686aa5c76e3db2be43057632427e2840fb27b6", "6e0568db9b0b13297cf674deccb6af93126b596b973f7b77701d3db7f23cb96f" ], [ "76e64113f677cf0e10a2570d599968d31544e179b760432952c02a4417bdde39", "c90ddf8dee4e95cf577066d70681f0d35e2a33d2b56d2032b4b1752d1901ac01" ], [ "c738c56b03b2abe1e8281baa743f8f9a8f7cc643df26cbee3ab150242bcbb891", "893fb578951ad2537f718f2eacbfbbbb82314eef7880cfe917e735d9699a84c3" ], [ "d895626548b65b81e264c7637c972877d1d72e5f3a925014372e9f6588f6c14b", "febfaa38f2bc7eae728ec60818c340eb03428d632bb067e179363ed75d7d991f" ], [ "b8da94032a957518eb0f6433571e8761ceffc73693e84edd49150a564f676e03", "2804dfa44805a1e4d7c99cc9762808b092cc584d95ff3b511488e4e74efdf6e7" ], [ "e80fea14441fb33a7d8adab9475d7fab2019effb5156a792f1a11778e3c0df5d", "eed1de7f638e00771e89768ca3ca94472d155e80af322ea9fcb4291b6ac9ec78" ], [ "a301697bdfcd704313ba48e51d567543f2a182031efd6915ddc07bbcc4e16070", "7370f91cfb67e4f5081809fa25d40f9b1735dbf7c0a11a130c0d1a041e177ea1" ], [ "90ad85b389d6b936463f9d0512678de208cc330b11307fffab7ac63e3fb04ed4", "e507a3620a38261affdcbd9427222b839aefabe1582894d991d4d48cb6ef150" ], [ "8f68b9d2f63b5f339239c1ad981f162ee88c5678723ea3351b7b444c9ec4c0da", "662a9f2dba063986de1d90c2b6be215dbbea2cfe95510bfdf23cbf79501fff82" ], [ "e4f3fb0176af85d65ff99ff9198c36091f48e86503681e3e6686fd5053231e11", "1e63633ad0ef4f1c1661a6d0ea02b7286cc7e74ec951d1c9822c38576feb73bc" ], [ "8c00fa9b18ebf331eb961537a45a4266c7034f2f0d4e1d0716fb6eae20eae29e", "efa47267fea521a1a9dc343a3736c974c2fadafa81e36c54e7d2a4c66702414b" ], [ "e7a26ce69dd4829f3e10cec0a9e98ed3143d084f308b92c0997fddfc60cb3e41", "2a758e300fa7984b471b006a1aafbb18d0a6b2c0420e83e20e8a9421cf2cfd51" ], [ "b6459e0ee3662ec8d23540c223bcbdc571cbcb967d79424f3cf29eb3de6b80ef", "67c876d06f3e06de1dadf16e5661db3c4b3ae6d48e35b2ff30bf0b61a71ba45" ], [ "d68a80c8280bb840793234aa118f06231d6f1fc67e73c5a5deda0f5b496943e8", "db8ba9fff4b586d00c4b1f9177b0e28b5b0e7b8f7845295a294c84266b133120" ], [ "324aed7df65c804252dc0270907a30b09612aeb973449cea4095980fc28d3d5d", "648a365774b61f2ff130c0c35aec1f4f19213b0c7e332843967224af96ab7c84" ], [ "4df9c14919cde61f6d51dfdbe5fee5dceec4143ba8d1ca888e8bd373fd054c96", "35ec51092d8728050974c23a1d85d4b5d506cdc288490192ebac06cad10d5d" ], [ "9c3919a84a474870faed8a9c1cc66021523489054d7f0308cbfc99c8ac1f98cd", "ddb84f0f4a4ddd57584f044bf260e641905326f76c64c8e6be7e5e03d4fc599d" ], [ "6057170b1dd12fdf8de05f281d8e06bb91e1493a8b91d4cc5a21382120a959e5", "9a1af0b26a6a4807add9a2daf71df262465152bc3ee24c65e899be932385a2a8" ], [ "a576df8e23a08411421439a4518da31880cef0fba7d4df12b1a6973eecb94266", "40a6bf20e76640b2c92b97afe58cd82c432e10a7f514d9f3ee8be11ae1b28ec8" ], [ "7778a78c28dec3e30a05fe9629de8c38bb30d1f5cf9a3a208f763889be58ad71", "34626d9ab5a5b22ff7098e12f2ff580087b38411ff24ac563b513fc1fd9f43ac" ], [ "928955ee637a84463729fd30e7afd2ed5f96274e5ad7e5cb09eda9c06d903ac", "c25621003d3f42a827b78a13093a95eeac3d26efa8a8d83fc5180e935bcd091f" ], [ "85d0fef3ec6db109399064f3a0e3b2855645b4a907ad354527aae75163d82751", "1f03648413a38c0be29d496e582cf5663e8751e96877331582c237a24eb1f962" ], [ "ff2b0dce97eece97c1c9b6041798b85dfdfb6d8882da20308f5404824526087e", "493d13fef524ba188af4c4dc54d07936c7b7ed6fb90e2ceb2c951e01f0c29907" ], [ "827fbbe4b1e880ea9ed2b2e6301b212b57f1ee148cd6dd28780e5e2cf856e241", "c60f9c923c727b0b71bef2c67d1d12687ff7a63186903166d605b68baec293ec" ], [ "eaa649f21f51bdbae7be4ae34ce6e5217a58fdce7f47f9aa7f3b58fa2120e2b3", "be3279ed5bbbb03ac69a80f89879aa5a01a6b965f13f7e59d47a5305ba5ad93d" ], [ "e4a42d43c5cf169d9391df6decf42ee541b6d8f0c9a137401e23632dda34d24f", "4d9f92e716d1c73526fc99ccfb8ad34ce886eedfa8d8e4f13a7f7131deba9414" ], [ "1ec80fef360cbdd954160fadab352b6b92b53576a88fea4947173b9d4300bf19", "aeefe93756b5340d2f3a4958a7abbf5e0146e77f6295a07b671cdc1cc107cefd" ], [ "146a778c04670c2f91b00af4680dfa8bce3490717d58ba889ddb5928366642be", "b318e0ec3354028add669827f9d4b2870aaa971d2f7e5ed1d0b297483d83efd0" ], [ "fa50c0f61d22e5f07e3acebb1aa07b128d0012209a28b9776d76a8793180eef9", "6b84c6922397eba9b72cd2872281a68a5e683293a57a213b38cd8d7d3f4f2811" ], [ "da1d61d0ca721a11b1a5bf6b7d88e8421a288ab5d5bba5220e53d32b5f067ec2", "8157f55a7c99306c79c0766161c91e2966a73899d279b48a655fba0f1ad836f1" ], [ "a8e282ff0c9706907215ff98e8fd416615311de0446f1e062a73b0610d064e13", "7f97355b8db81c09abfb7f3c5b2515888b679a3e50dd6bd6cef7c73111f4cc0c" ], [ "174a53b9c9a285872d39e56e6913cab15d59b1fa512508c022f382de8319497c", "ccc9dc37abfc9c1657b4155f2c47f9e6646b3a1d8cb9854383da13ac079afa73" ], [ "959396981943785c3d3e57edf5018cdbe039e730e4918b3d884fdff09475b7ba", "2e7e552888c331dd8ba0386a4b9cd6849c653f64c8709385e9b8abf87524f2fd" ], [ "d2a63a50ae401e56d645a1153b109a8fcca0a43d561fba2dbb51340c9d82b151", "e82d86fb6443fcb7565aee58b2948220a70f750af484ca52d4142174dcf89405" ], [ "64587e2335471eb890ee7896d7cfdc866bacbdbd3839317b3436f9b45617e073", "d99fcdd5bf6902e2ae96dd6447c299a185b90a39133aeab358299e5e9faf6589" ], [ "8481bde0e4e4d885b3a546d3e549de042f0aa6cea250e7fd358d6c86dd45e458", "38ee7b8cba5404dd84a25bf39cecb2ca900a79c42b262e556d64b1b59779057e" ], [ "13464a57a78102aa62b6979ae817f4637ffcfed3c4b1ce30bcd6303f6caf666b", "69be159004614580ef7e433453ccb0ca48f300a81d0942e13f495a907f6ecc27" ], [ "bc4a9df5b713fe2e9aef430bcc1dc97a0cd9ccede2f28588cada3a0d2d83f366", "d3a81ca6e785c06383937adf4b798caa6e8a9fbfa547b16d758d666581f33c1" ], [ "8c28a97bf8298bc0d23d8c749452a32e694b65e30a9472a3954ab30fe5324caa", "40a30463a3305193378fedf31f7cc0eb7ae784f0451cb9459e71dc73cbef9482" ], [ "8ea9666139527a8c1dd94ce4f071fd23c8b350c5a4bb33748c4ba111faccae0", "620efabbc8ee2782e24e7c0cfb95c5d735b783be9cf0f8e955af34a30e62b945" ], [ "dd3625faef5ba06074669716bbd3788d89bdde815959968092f76cc4eb9a9787", "7a188fa3520e30d461da2501045731ca941461982883395937f68d00c644a573" ], [ "f710d79d9eb962297e4f6232b40e8f7feb2bc63814614d692c12de752408221e", "ea98e67232d3b3295d3b535532115ccac8612c721851617526ae47a9c77bfc82" ] ] }, naf: { wnd: 7, points: [ [ "f9308a019258c31049344f85f89d5229b531c845836f99b08601f113bce036f9", "388f7b0f632de8140fe337e62a37f3566500a99934c2231b6cb9fd7584b8e672" ], [ "2f8bde4d1a07209355b4a7250a5c5128e88b84bddc619ab7cba8d569b240efe4", "d8ac222636e5e3d6d4dba9dda6c9c426f788271bab0d6840dca87d3aa6ac62d6" ], [ "5cbdf0646e5db4eaa398f365f2ea7a0e3d419b7e0330e39ce92bddedcac4f9bc", "6aebca40ba255960a3178d6d861a54dba813d0b813fde7b5a5082628087264da" ], [ "acd484e2f0c7f65309ad178a9f559abde09796974c57e714c35f110dfc27ccbe", "cc338921b0a7d9fd64380971763b61e9add888a4375f8e0f05cc262ac64f9c37" ], [ "774ae7f858a9411e5ef4246b70c65aac5649980be5c17891bbec17895da008cb", "d984a032eb6b5e190243dd56d7b7b365372db1e2dff9d6a8301d74c9c953c61b" ], [ "f28773c2d975288bc7d1d205c3748651b075fbc6610e58cddeeddf8f19405aa8", "ab0902e8d880a89758212eb65cdaf473a1a06da521fa91f29b5cb52db03ed81" ], [ "d7924d4f7d43ea965a465ae3095ff41131e5946f3c85f79e44adbcf8e27e080e", "581e2872a86c72a683842ec228cc6defea40af2bd896d3a5c504dc9ff6a26b58" ], [ "defdea4cdb677750a420fee807eacf21eb9898ae79b9768766e4faa04a2d4a34", "4211ab0694635168e997b0ead2a93daeced1f4a04a95c0f6cfb199f69e56eb77" ], [ "2b4ea0a797a443d293ef5cff444f4979f06acfebd7e86d277475656138385b6c", "85e89bc037945d93b343083b5a1c86131a01f60c50269763b570c854e5c09b7a" ], [ "352bbf4a4cdd12564f93fa332ce333301d9ad40271f8107181340aef25be59d5", "321eb4075348f534d59c18259dda3e1f4a1b3b2e71b1039c67bd3d8bcf81998c" ], [ "2fa2104d6b38d11b0230010559879124e42ab8dfeff5ff29dc9cdadd4ecacc3f", "2de1068295dd865b64569335bd5dd80181d70ecfc882648423ba76b532b7d67" ], [ "9248279b09b4d68dab21a9b066edda83263c3d84e09572e269ca0cd7f5453714", "73016f7bf234aade5d1aa71bdea2b1ff3fc0de2a887912ffe54a32ce97cb3402" ], [ "daed4f2be3a8bf278e70132fb0beb7522f570e144bf615c07e996d443dee8729", "a69dce4a7d6c98e8d4a1aca87ef8d7003f83c230f3afa726ab40e52290be1c55" ], [ "c44d12c7065d812e8acf28d7cbb19f9011ecd9e9fdf281b0e6a3b5e87d22e7db", "2119a460ce326cdc76c45926c982fdac0e106e861edf61c5a039063f0e0e6482" ], [ "6a245bf6dc698504c89a20cfded60853152b695336c28063b61c65cbd269e6b4", "e022cf42c2bd4a708b3f5126f16a24ad8b33ba48d0423b6efd5e6348100d8a82" ], [ "1697ffa6fd9de627c077e3d2fe541084ce13300b0bec1146f95ae57f0d0bd6a5", "b9c398f186806f5d27561506e4557433a2cf15009e498ae7adee9d63d01b2396" ], [ "605bdb019981718b986d0f07e834cb0d9deb8360ffb7f61df982345ef27a7479", "2972d2de4f8d20681a78d93ec96fe23c26bfae84fb14db43b01e1e9056b8c49" ], [ "62d14dab4150bf497402fdc45a215e10dcb01c354959b10cfe31c7e9d87ff33d", "80fc06bd8cc5b01098088a1950eed0db01aa132967ab472235f5642483b25eaf" ], [ "80c60ad0040f27dade5b4b06c408e56b2c50e9f56b9b8b425e555c2f86308b6f", "1c38303f1cc5c30f26e66bad7fe72f70a65eed4cbe7024eb1aa01f56430bd57a" ], [ "7a9375ad6167ad54aa74c6348cc54d344cc5dc9487d847049d5eabb0fa03c8fb", "d0e3fa9eca8726909559e0d79269046bdc59ea10c70ce2b02d499ec224dc7f7" ], [ "d528ecd9b696b54c907a9ed045447a79bb408ec39b68df504bb51f459bc3ffc9", "eecf41253136e5f99966f21881fd656ebc4345405c520dbc063465b521409933" ], [ "49370a4b5f43412ea25f514e8ecdad05266115e4a7ecb1387231808f8b45963", "758f3f41afd6ed428b3081b0512fd62a54c3f3afbb5b6764b653052a12949c9a" ], [ "77f230936ee88cbbd73df930d64702ef881d811e0e1498e2f1c13eb1fc345d74", "958ef42a7886b6400a08266e9ba1b37896c95330d97077cbbe8eb3c7671c60d6" ], [ "f2dac991cc4ce4b9ea44887e5c7c0bce58c80074ab9d4dbaeb28531b7739f530", "e0dedc9b3b2f8dad4da1f32dec2531df9eb5fbeb0598e4fd1a117dba703a3c37" ], [ "463b3d9f662621fb1b4be8fbbe2520125a216cdfc9dae3debcba4850c690d45b", "5ed430d78c296c3543114306dd8622d7c622e27c970a1de31cb377b01af7307e" ], [ "f16f804244e46e2a09232d4aff3b59976b98fac14328a2d1a32496b49998f247", "cedabd9b82203f7e13d206fcdf4e33d92a6c53c26e5cce26d6579962c4e31df6" ], [ "caf754272dc84563b0352b7a14311af55d245315ace27c65369e15f7151d41d1", "cb474660ef35f5f2a41b643fa5e460575f4fa9b7962232a5c32f908318a04476" ], [ "2600ca4b282cb986f85d0f1709979d8b44a09c07cb86d7c124497bc86f082120", "4119b88753c15bd6a693b03fcddbb45d5ac6be74ab5f0ef44b0be9475a7e4b40" ], [ "7635ca72d7e8432c338ec53cd12220bc01c48685e24f7dc8c602a7746998e435", "91b649609489d613d1d5e590f78e6d74ecfc061d57048bad9e76f302c5b9c61" ], [ "754e3239f325570cdbbf4a87deee8a66b7f2b33479d468fbc1a50743bf56cc18", "673fb86e5bda30fb3cd0ed304ea49a023ee33d0197a695d0c5d98093c536683" ], [ "e3e6bd1071a1e96aff57859c82d570f0330800661d1c952f9fe2694691d9b9e8", "59c9e0bba394e76f40c0aa58379a3cb6a5a2283993e90c4167002af4920e37f5" ], [ "186b483d056a033826ae73d88f732985c4ccb1f32ba35f4b4cc47fdcf04aa6eb", "3b952d32c67cf77e2e17446e204180ab21fb8090895138b4a4a797f86e80888b" ], [ "df9d70a6b9876ce544c98561f4be4f725442e6d2b737d9c91a8321724ce0963f", "55eb2dafd84d6ccd5f862b785dc39d4ab157222720ef9da217b8c45cf2ba2417" ], [ "5edd5cc23c51e87a497ca815d5dce0f8ab52554f849ed8995de64c5f34ce7143", "efae9c8dbc14130661e8cec030c89ad0c13c66c0d17a2905cdc706ab7399a868" ], [ "290798c2b6476830da12fe02287e9e777aa3fba1c355b17a722d362f84614fba", "e38da76dcd440621988d00bcf79af25d5b29c094db2a23146d003afd41943e7a" ], [ "af3c423a95d9f5b3054754efa150ac39cd29552fe360257362dfdecef4053b45", "f98a3fd831eb2b749a93b0e6f35cfb40c8cd5aa667a15581bc2feded498fd9c6" ], [ "766dbb24d134e745cccaa28c99bf274906bb66b26dcf98df8d2fed50d884249a", "744b1152eacbe5e38dcc887980da38b897584a65fa06cedd2c924f97cbac5996" ], [ "59dbf46f8c94759ba21277c33784f41645f7b44f6c596a58ce92e666191abe3e", "c534ad44175fbc300f4ea6ce648309a042ce739a7919798cd85e216c4a307f6e" ], [ "f13ada95103c4537305e691e74e9a4a8dd647e711a95e73cb62dc6018cfd87b8", "e13817b44ee14de663bf4bc808341f326949e21a6a75c2570778419bdaf5733d" ], [ "7754b4fa0e8aced06d4167a2c59cca4cda1869c06ebadfb6488550015a88522c", "30e93e864e669d82224b967c3020b8fa8d1e4e350b6cbcc537a48b57841163a2" ], [ "948dcadf5990e048aa3874d46abef9d701858f95de8041d2a6828c99e2262519", "e491a42537f6e597d5d28a3224b1bc25df9154efbd2ef1d2cbba2cae5347d57e" ], [ "7962414450c76c1689c7b48f8202ec37fb224cf5ac0bfa1570328a8a3d7c77ab", "100b610ec4ffb4760d5c1fc133ef6f6b12507a051f04ac5760afa5b29db83437" ], [ "3514087834964b54b15b160644d915485a16977225b8847bb0dd085137ec47ca", "ef0afbb2056205448e1652c48e8127fc6039e77c15c2378b7e7d15a0de293311" ], [ "d3cc30ad6b483e4bc79ce2c9dd8bc54993e947eb8df787b442943d3f7b527eaf", "8b378a22d827278d89c5e9be8f9508ae3c2ad46290358630afb34db04eede0a4" ], [ "1624d84780732860ce1c78fcbfefe08b2b29823db913f6493975ba0ff4847610", "68651cf9b6da903e0914448c6cd9d4ca896878f5282be4c8cc06e2a404078575" ], [ "733ce80da955a8a26902c95633e62a985192474b5af207da6df7b4fd5fc61cd4", "f5435a2bd2badf7d485a4d8b8db9fcce3e1ef8e0201e4578c54673bc1dc5ea1d" ], [ "15d9441254945064cf1a1c33bbd3b49f8966c5092171e699ef258dfab81c045c", "d56eb30b69463e7234f5137b73b84177434800bacebfc685fc37bbe9efe4070d" ], [ "a1d0fcf2ec9de675b612136e5ce70d271c21417c9d2b8aaaac138599d0717940", "edd77f50bcb5a3cab2e90737309667f2641462a54070f3d519212d39c197a629" ], [ "e22fbe15c0af8ccc5780c0735f84dbe9a790badee8245c06c7ca37331cb36980", "a855babad5cd60c88b430a69f53a1a7a38289154964799be43d06d77d31da06" ], [ "311091dd9860e8e20ee13473c1155f5f69635e394704eaa74009452246cfa9b3", "66db656f87d1f04fffd1f04788c06830871ec5a64feee685bd80f0b1286d8374" ], [ "34c1fd04d301be89b31c0442d3e6ac24883928b45a9340781867d4232ec2dbdf", "9414685e97b1b5954bd46f730174136d57f1ceeb487443dc5321857ba73abee" ], [ "f219ea5d6b54701c1c14de5b557eb42a8d13f3abbcd08affcc2a5e6b049b8d63", "4cb95957e83d40b0f73af4544cccf6b1f4b08d3c07b27fb8d8c2962a400766d1" ], [ "d7b8740f74a8fbaab1f683db8f45de26543a5490bca627087236912469a0b448", "fa77968128d9c92ee1010f337ad4717eff15db5ed3c049b3411e0315eaa4593b" ], [ "32d31c222f8f6f0ef86f7c98d3a3335ead5bcd32abdd94289fe4d3091aa824bf", "5f3032f5892156e39ccd3d7915b9e1da2e6dac9e6f26e961118d14b8462e1661" ], [ "7461f371914ab32671045a155d9831ea8793d77cd59592c4340f86cbc18347b5", "8ec0ba238b96bec0cbdddcae0aa442542eee1ff50c986ea6b39847b3cc092ff6" ], [ "ee079adb1df1860074356a25aa38206a6d716b2c3e67453d287698bad7b2b2d6", "8dc2412aafe3be5c4c5f37e0ecc5f9f6a446989af04c4e25ebaac479ec1c8c1e" ], [ "16ec93e447ec83f0467b18302ee620f7e65de331874c9dc72bfd8616ba9da6b5", "5e4631150e62fb40d0e8c2a7ca5804a39d58186a50e497139626778e25b0674d" ], [ "eaa5f980c245f6f038978290afa70b6bd8855897f98b6aa485b96065d537bd99", "f65f5d3e292c2e0819a528391c994624d784869d7e6ea67fb18041024edc07dc" ], [ "78c9407544ac132692ee1910a02439958ae04877151342ea96c4b6b35a49f51", "f3e0319169eb9b85d5404795539a5e68fa1fbd583c064d2462b675f194a3ddb4" ], [ "494f4be219a1a77016dcd838431aea0001cdc8ae7a6fc688726578d9702857a5", "42242a969283a5f339ba7f075e36ba2af925ce30d767ed6e55f4b031880d562c" ], [ "a598a8030da6d86c6bc7f2f5144ea549d28211ea58faa70ebf4c1e665c1fe9b5", "204b5d6f84822c307e4b4a7140737aec23fc63b65b35f86a10026dbd2d864e6b" ], [ "c41916365abb2b5d09192f5f2dbeafec208f020f12570a184dbadc3e58595997", "4f14351d0087efa49d245b328984989d5caf9450f34bfc0ed16e96b58fa9913" ], [ "841d6063a586fa475a724604da03bc5b92a2e0d2e0a36acfe4c73a5514742881", "73867f59c0659e81904f9a1c7543698e62562d6744c169ce7a36de01a8d6154" ], [ "5e95bb399a6971d376026947f89bde2f282b33810928be4ded112ac4d70e20d5", "39f23f366809085beebfc71181313775a99c9aed7d8ba38b161384c746012865" ], [ "36e4641a53948fd476c39f8a99fd974e5ec07564b5315d8bf99471bca0ef2f66", "d2424b1b1abe4eb8164227b085c9aa9456ea13493fd563e06fd51cf5694c78fc" ], [ "336581ea7bfbbb290c191a2f507a41cf5643842170e914faeab27c2c579f726", "ead12168595fe1be99252129b6e56b3391f7ab1410cd1e0ef3dcdcabd2fda224" ], [ "8ab89816dadfd6b6a1f2634fcf00ec8403781025ed6890c4849742706bd43ede", "6fdcef09f2f6d0a044e654aef624136f503d459c3e89845858a47a9129cdd24e" ], [ "1e33f1a746c9c5778133344d9299fcaa20b0938e8acff2544bb40284b8c5fb94", "60660257dd11b3aa9c8ed618d24edff2306d320f1d03010e33a7d2057f3b3b6" ], [ "85b7c1dcb3cec1b7ee7f30ded79dd20a0ed1f4cc18cbcfcfa410361fd8f08f31", "3d98a9cdd026dd43f39048f25a8847f4fcafad1895d7a633c6fed3c35e999511" ], [ "29df9fbd8d9e46509275f4b125d6d45d7fbe9a3b878a7af872a2800661ac5f51", "b4c4fe99c775a606e2d8862179139ffda61dc861c019e55cd2876eb2a27d84b" ], [ "a0b1cae06b0a847a3fea6e671aaf8adfdfe58ca2f768105c8082b2e449fce252", "ae434102edde0958ec4b19d917a6a28e6b72da1834aff0e650f049503a296cf2" ], [ "4e8ceafb9b3e9a136dc7ff67e840295b499dfb3b2133e4ba113f2e4c0e121e5", "cf2174118c8b6d7a4b48f6d534ce5c79422c086a63460502b827ce62a326683c" ], [ "d24a44e047e19b6f5afb81c7ca2f69080a5076689a010919f42725c2b789a33b", "6fb8d5591b466f8fc63db50f1c0f1c69013f996887b8244d2cdec417afea8fa3" ], [ "ea01606a7a6c9cdd249fdfcfacb99584001edd28abbab77b5104e98e8e3b35d4", "322af4908c7312b0cfbfe369f7a7b3cdb7d4494bc2823700cfd652188a3ea98d" ], [ "af8addbf2b661c8a6c6328655eb96651252007d8c5ea31be4ad196de8ce2131f", "6749e67c029b85f52a034eafd096836b2520818680e26ac8f3dfbcdb71749700" ], [ "e3ae1974566ca06cc516d47e0fb165a674a3dabcfca15e722f0e3450f45889", "2aeabe7e4531510116217f07bf4d07300de97e4874f81f533420a72eeb0bd6a4" ], [ "591ee355313d99721cf6993ffed1e3e301993ff3ed258802075ea8ced397e246", "b0ea558a113c30bea60fc4775460c7901ff0b053d25ca2bdeee98f1a4be5d196" ], [ "11396d55fda54c49f19aa97318d8da61fa8584e47b084945077cf03255b52984", "998c74a8cd45ac01289d5833a7beb4744ff536b01b257be4c5767bea93ea57a4" ], [ "3c5d2a1ba39c5a1790000738c9e0c40b8dcdfd5468754b6405540157e017aa7a", "b2284279995a34e2f9d4de7396fc18b80f9b8b9fdd270f6661f79ca4c81bd257" ], [ "cc8704b8a60a0defa3a99a7299f2e9c3fbc395afb04ac078425ef8a1793cc030", "bdd46039feed17881d1e0862db347f8cf395b74fc4bcdc4e940b74e3ac1f1b13" ], [ "c533e4f7ea8555aacd9777ac5cad29b97dd4defccc53ee7ea204119b2889b197", "6f0a256bc5efdf429a2fb6242f1a43a2d9b925bb4a4b3a26bb8e0f45eb596096" ], [ "c14f8f2ccb27d6f109f6d08d03cc96a69ba8c34eec07bbcf566d48e33da6593", "c359d6923bb398f7fd4473e16fe1c28475b740dd098075e6c0e8649113dc3a38" ], [ "a6cbc3046bc6a450bac24789fa17115a4c9739ed75f8f21ce441f72e0b90e6ef", "21ae7f4680e889bb130619e2c0f95a360ceb573c70603139862afd617fa9b9f" ], [ "347d6d9a02c48927ebfb86c1359b1caf130a3c0267d11ce6344b39f99d43cc38", "60ea7f61a353524d1c987f6ecec92f086d565ab687870cb12689ff1e31c74448" ], [ "da6545d2181db8d983f7dcb375ef5866d47c67b1bf31c8cf855ef7437b72656a", "49b96715ab6878a79e78f07ce5680c5d6673051b4935bd897fea824b77dc208a" ], [ "c40747cc9d012cb1a13b8148309c6de7ec25d6945d657146b9d5994b8feb1111", "5ca560753be2a12fc6de6caf2cb489565db936156b9514e1bb5e83037e0fa2d4" ], [ "4e42c8ec82c99798ccf3a610be870e78338c7f713348bd34c8203ef4037f3502", "7571d74ee5e0fb92a7a8b33a07783341a5492144cc54bcc40a94473693606437" ], [ "3775ab7089bc6af823aba2e1af70b236d251cadb0c86743287522a1b3b0dedea", "be52d107bcfa09d8bcb9736a828cfa7fac8db17bf7a76a2c42ad961409018cf7" ], [ "cee31cbf7e34ec379d94fb814d3d775ad954595d1314ba8846959e3e82f74e26", "8fd64a14c06b589c26b947ae2bcf6bfa0149ef0be14ed4d80f448a01c43b1c6d" ], [ "b4f9eaea09b6917619f6ea6a4eb5464efddb58fd45b1ebefcdc1a01d08b47986", "39e5c9925b5a54b07433a4f18c61726f8bb131c012ca542eb24a8ac07200682a" ], [ "d4263dfc3d2df923a0179a48966d30ce84e2515afc3dccc1b77907792ebcc60e", "62dfaf07a0f78feb30e30d6295853ce189e127760ad6cf7fae164e122a208d54" ], [ "48457524820fa65a4f8d35eb6930857c0032acc0a4a2de422233eeda897612c4", "25a748ab367979d98733c38a1fa1c2e7dc6cc07db2d60a9ae7a76aaa49bd0f77" ], [ "dfeeef1881101f2cb11644f3a2afdfc2045e19919152923f367a1767c11cceda", "ecfb7056cf1de042f9420bab396793c0c390bde74b4bbdff16a83ae09a9a7517" ], [ "6d7ef6b17543f8373c573f44e1f389835d89bcbc6062ced36c82df83b8fae859", "cd450ec335438986dfefa10c57fea9bcc521a0959b2d80bbf74b190dca712d10" ], [ "e75605d59102a5a2684500d3b991f2e3f3c88b93225547035af25af66e04541f", "f5c54754a8f71ee540b9b48728473e314f729ac5308b06938360990e2bfad125" ], [ "eb98660f4c4dfaa06a2be453d5020bc99a0c2e60abe388457dd43fefb1ed620c", "6cb9a8876d9cb8520609af3add26cd20a0a7cd8a9411131ce85f44100099223e" ], [ "13e87b027d8514d35939f2e6892b19922154596941888336dc3563e3b8dba942", "fef5a3c68059a6dec5d624114bf1e91aac2b9da568d6abeb2570d55646b8adf1" ], [ "ee163026e9fd6fe017c38f06a5be6fc125424b371ce2708e7bf4491691e5764a", "1acb250f255dd61c43d94ccc670d0f58f49ae3fa15b96623e5430da0ad6c62b2" ], [ "b268f5ef9ad51e4d78de3a750c2dc89b1e626d43505867999932e5db33af3d80", "5f310d4b3c99b9ebb19f77d41c1dee018cf0d34fd4191614003e945a1216e423" ], [ "ff07f3118a9df035e9fad85eb6c7bfe42b02f01ca99ceea3bf7ffdba93c4750d", "438136d603e858a3a5c440c38eccbaddc1d2942114e2eddd4740d098ced1f0d8" ], [ "8d8b9855c7c052a34146fd20ffb658bea4b9f69e0d825ebec16e8c3ce2b526a1", "cdb559eedc2d79f926baf44fb84ea4d44bcf50fee51d7ceb30e2e7f463036758" ], [ "52db0b5384dfbf05bfa9d472d7ae26dfe4b851ceca91b1eba54263180da32b63", "c3b997d050ee5d423ebaf66a6db9f57b3180c902875679de924b69d84a7b375" ], [ "e62f9490d3d51da6395efd24e80919cc7d0f29c3f3fa48c6fff543becbd43352", "6d89ad7ba4876b0b22c2ca280c682862f342c8591f1daf5170e07bfd9ccafa7d" ], [ "7f30ea2476b399b4957509c88f77d0191afa2ff5cb7b14fd6d8e7d65aaab1193", "ca5ef7d4b231c94c3b15389a5f6311e9daff7bb67b103e9880ef4bff637acaec" ], [ "5098ff1e1d9f14fb46a210fada6c903fef0fb7b4a1dd1d9ac60a0361800b7a00", "9731141d81fc8f8084d37c6e7542006b3ee1b40d60dfe5362a5b132fd17ddc0" ], [ "32b78c7de9ee512a72895be6b9cbefa6e2f3c4ccce445c96b9f2c81e2778ad58", "ee1849f513df71e32efc3896ee28260c73bb80547ae2275ba497237794c8753c" ], [ "e2cb74fddc8e9fbcd076eef2a7c72b0ce37d50f08269dfc074b581550547a4f7", "d3aa2ed71c9dd2247a62df062736eb0baddea9e36122d2be8641abcb005cc4a4" ], [ "8438447566d4d7bedadc299496ab357426009a35f235cb141be0d99cd10ae3a8", "c4e1020916980a4da5d01ac5e6ad330734ef0d7906631c4f2390426b2edd791f" ], [ "4162d488b89402039b584c6fc6c308870587d9c46f660b878ab65c82c711d67e", "67163e903236289f776f22c25fb8a3afc1732f2b84b4e95dbda47ae5a0852649" ], [ "3fad3fa84caf0f34f0f89bfd2dcf54fc175d767aec3e50684f3ba4a4bf5f683d", "cd1bc7cb6cc407bb2f0ca647c718a730cf71872e7d0d2a53fa20efcdfe61826" ], [ "674f2600a3007a00568c1a7ce05d0816c1fb84bf1370798f1c69532faeb1a86b", "299d21f9413f33b3edf43b257004580b70db57da0b182259e09eecc69e0d38a5" ], [ "d32f4da54ade74abb81b815ad1fb3b263d82d6c692714bcff87d29bd5ee9f08f", "f9429e738b8e53b968e99016c059707782e14f4535359d582fc416910b3eea87" ], [ "30e4e670435385556e593657135845d36fbb6931f72b08cb1ed954f1e3ce3ff6", "462f9bce619898638499350113bbc9b10a878d35da70740dc695a559eb88db7b" ], [ "be2062003c51cc3004682904330e4dee7f3dcd10b01e580bf1971b04d4cad297", "62188bc49d61e5428573d48a74e1c655b1c61090905682a0d5558ed72dccb9bc" ], [ "93144423ace3451ed29e0fb9ac2af211cb6e84a601df5993c419859fff5df04a", "7c10dfb164c3425f5c71a3f9d7992038f1065224f72bb9d1d902a6d13037b47c" ], [ "b015f8044f5fcbdcf21ca26d6c34fb8197829205c7b7d2a7cb66418c157b112c", "ab8c1e086d04e813744a655b2df8d5f83b3cdc6faa3088c1d3aea1454e3a1d5f" ], [ "d5e9e1da649d97d89e4868117a465a3a4f8a18de57a140d36b3f2af341a21b52", "4cb04437f391ed73111a13cc1d4dd0db1693465c2240480d8955e8592f27447a" ], [ "d3ae41047dd7ca065dbf8ed77b992439983005cd72e16d6f996a5316d36966bb", "bd1aeb21ad22ebb22a10f0303417c6d964f8cdd7df0aca614b10dc14d125ac46" ], [ "463e2763d885f958fc66cdd22800f0a487197d0a82e377b49f80af87c897b065", "bfefacdb0e5d0fd7df3a311a94de062b26b80c61fbc97508b79992671ef7ca7f" ], [ "7985fdfd127c0567c6f53ec1bb63ec3158e597c40bfe747c83cddfc910641917", "603c12daf3d9862ef2b25fe1de289aed24ed291e0ec6708703a5bd567f32ed03" ], [ "74a1ad6b5f76e39db2dd249410eac7f99e74c59cb83d2d0ed5ff1543da7703e9", "cc6157ef18c9c63cd6193d83631bbea0093e0968942e8c33d5737fd790e0db08" ], [ "30682a50703375f602d416664ba19b7fc9bab42c72747463a71d0896b22f6da3", "553e04f6b018b4fa6c8f39e7f311d3176290d0e0f19ca73f17714d9977a22ff8" ], [ "9e2158f0d7c0d5f26c3791efefa79597654e7a2b2464f52b1ee6c1347769ef57", "712fcdd1b9053f09003a3481fa7762e9ffd7c8ef35a38509e2fbf2629008373" ], [ "176e26989a43c9cfeba4029c202538c28172e566e3c4fce7322857f3be327d66", "ed8cc9d04b29eb877d270b4878dc43c19aefd31f4eee09ee7b47834c1fa4b1c3" ], [ "75d46efea3771e6e68abb89a13ad747ecf1892393dfc4f1b7004788c50374da8", "9852390a99507679fd0b86fd2b39a868d7efc22151346e1a3ca4726586a6bed8" ], [ "809a20c67d64900ffb698c4c825f6d5f2310fb0451c869345b7319f645605721", "9e994980d9917e22b76b061927fa04143d096ccc54963e6a5ebfa5f3f8e286c1" ], [ "1b38903a43f7f114ed4500b4eac7083fdefece1cf29c63528d563446f972c180", "4036edc931a60ae889353f77fd53de4a2708b26b6f5da72ad3394119daf408f9" ] ] } }; }); // ../eve/node_modules/elliptic/lib/elliptic/curves.js var require_curves = __commonJS((exports) => { var curves = exports; var hash = require_hash(); var curve = require_curve(); var utils = require_utils2(); var assert = utils.assert; function PresetCurve(options2) { if (options2.type === "short") this.curve = new curve.short(options2); else if (options2.type === "edwards") this.curve = new curve.edwards(options2); else this.curve = new curve.mont(options2); this.g = this.curve.g; this.n = this.curve.n; this.hash = options2.hash; assert(this.g.validate(), "Invalid curve"); assert(this.g.mul(this.n).isInfinity(), "Invalid curve, G*N != O"); } curves.PresetCurve = PresetCurve; function defineCurve(name, options2) { Object.defineProperty(curves, name, { configurable: true, enumerable: true, get: function() { var curve2 = new PresetCurve(options2); Object.defineProperty(curves, name, { configurable: true, enumerable: true, value: curve2 }); return curve2; } }); } defineCurve("p192", { type: "short", prime: "p192", p: "ffffffff ffffffff ffffffff fffffffe ffffffff ffffffff", a: "ffffffff ffffffff ffffffff fffffffe ffffffff fffffffc", b: "64210519 e59c80e7 0fa7e9ab 72243049 feb8deec c146b9b1", n: "ffffffff ffffffff ffffffff 99def836 146bc9b1 b4d22831", hash: hash.sha256, gRed: false, g: [ "188da80e b03090f6 7cbf20eb 43a18800 f4ff0afd 82ff1012", "07192b95 ffc8da78 631011ed 6b24cdd5 73f977a1 1e794811" ] }); defineCurve("p224", { type: "short", prime: "p224", p: "ffffffff ffffffff ffffffff ffffffff 00000000 00000000 00000001", a: "ffffffff ffffffff ffffffff fffffffe ffffffff ffffffff fffffffe", b: "b4050a85 0c04b3ab f5413256 5044b0b7 d7bfd8ba 270b3943 2355ffb4", n: "ffffffff ffffffff ffffffff ffff16a2 e0b8f03e 13dd2945 5c5c2a3d", hash: hash.sha256, gRed: false, g: [ "b70e0cbd 6bb4bf7f 321390b9 4a03c1d3 56c21122 343280d6 115c1d21", "bd376388 b5f723fb 4c22dfe6 cd4375a0 5a074764 44d58199 85007e34" ] }); defineCurve("p256", { type: "short", prime: null, p: "ffffffff 00000001 00000000 00000000 00000000 ffffffff ffffffff ffffffff", a: "ffffffff 00000001 00000000 00000000 00000000 ffffffff ffffffff fffffffc", b: "5ac635d8 aa3a93e7 b3ebbd55 769886bc 651d06b0 cc53b0f6 3bce3c3e 27d2604b", n: "ffffffff 00000000 ffffffff ffffffff bce6faad a7179e84 f3b9cac2 fc632551", hash: hash.sha256, gRed: false, g: [ "6b17d1f2 e12c4247 f8bce6e5 63a440f2 77037d81 2deb33a0 f4a13945 d898c296", "4fe342e2 fe1a7f9b 8ee7eb4a 7c0f9e16 2bce3357 6b315ece cbb64068 37bf51f5" ] }); defineCurve("p384", { type: "short", prime: null, p: "ffffffff ffffffff ffffffff ffffffff ffffffff ffffffff ffffffff " + "fffffffe ffffffff 00000000 00000000 ffffffff", a: "ffffffff ffffffff ffffffff ffffffff ffffffff ffffffff ffffffff " + "fffffffe ffffffff 00000000 00000000 fffffffc", b: "b3312fa7 e23ee7e4 988e056b e3f82d19 181d9c6e fe814112 0314088f " + "5013875a c656398d 8a2ed19d 2a85c8ed d3ec2aef", n: "ffffffff ffffffff ffffffff ffffffff ffffffff ffffffff c7634d81 " + "f4372ddf 581a0db2 48b0a77a ecec196a ccc52973", hash: hash.sha384, gRed: false, g: [ "aa87ca22 be8b0537 8eb1c71e f320ad74 6e1d3b62 8ba79b98 59f741e0 82542a38 " + "5502f25d bf55296c 3a545e38 72760ab7", "3617de4a 96262c6f 5d9e98bf 9292dc29 f8f41dbd 289a147c e9da3113 b5f0b8c0 " + "0a60b1ce 1d7e819d 7a431d7c 90ea0e5f" ] }); defineCurve("p521", { type: "short", prime: null, p: "000001ff ffffffff ffffffff ffffffff ffffffff ffffffff " + "ffffffff ffffffff ffffffff ffffffff ffffffff ffffffff " + "ffffffff ffffffff ffffffff ffffffff ffffffff", a: "000001ff ffffffff ffffffff ffffffff ffffffff ffffffff " + "ffffffff ffffffff ffffffff ffffffff ffffffff ffffffff " + "ffffffff ffffffff ffffffff ffffffff fffffffc", b: "00000051 953eb961 8e1c9a1f 929a21a0 b68540ee a2da725b " + "99b315f3 b8b48991 8ef109e1 56193951 ec7e937b 1652c0bd " + "3bb1bf07 3573df88 3d2c34f1 ef451fd4 6b503f00", n: "000001ff ffffffff ffffffff ffffffff ffffffff ffffffff " + "ffffffff ffffffff fffffffa 51868783 bf2f966b 7fcc0148 " + "f709a5d0 3bb5c9b8 899c47ae bb6fb71e 91386409", hash: hash.sha512, gRed: false, g: [ "000000c6 858e06b7 0404e9cd 9e3ecb66 2395b442 9c648139 " + "053fb521 f828af60 6b4d3dba a14b5e77 efe75928 fe1dc127 " + "a2ffa8de 3348b3c1 856a429b f97e7e31 c2e5bd66", "00000118 39296a78 9a3bc004 5c8a5fb4 2c7d1bd9 98f54449 " + "579b4468 17afbd17 273e662c 97ee7299 5ef42640 c550b901 " + "3fad0761 353c7086 a272c240 88be9476 9fd16650" ] }); defineCurve("curve25519", { type: "mont", prime: "p25519", p: "7fffffffffffffff ffffffffffffffff ffffffffffffffff ffffffffffffffed", a: "76d06", b: "1", n: "1000000000000000 0000000000000000 14def9dea2f79cd6 5812631a5cf5d3ed", hash: hash.sha256, gRed: false, g: [ "9" ] }); defineCurve("ed25519", { type: "edwards", prime: "p25519", p: "7fffffffffffffff ffffffffffffffff ffffffffffffffff ffffffffffffffed", a: "-1", c: "1", d: "52036cee2b6ffe73 8cc740797779e898 00700a4d4141d8ab 75eb4dca135978a3", n: "1000000000000000 0000000000000000 14def9dea2f79cd6 5812631a5cf5d3ed", hash: hash.sha256, gRed: false, g: [ "216936d3cd6e53fec0a4e231fdd6dc5c692cc7609525a7b2c9562d608f25d51a", "6666666666666666666666666666666666666666666666666666666666666658" ] }); var pre; try { pre = require_secp256k1(); } catch (e) { pre = undefined; } defineCurve("secp256k1", { type: "short", prime: "k256", p: "ffffffff ffffffff ffffffff ffffffff ffffffff ffffffff fffffffe fffffc2f", a: "0", b: "7", n: "ffffffff ffffffff ffffffff fffffffe baaedce6 af48a03b bfd25e8c d0364141", h: "1", hash: hash.sha256, beta: "7ae96a2b657c07106e64479eac3434e99cf0497512f58995c1396c28719501ee", lambda: "5363ad4cc05c30e0a5261c028812645a122e22ea20816678df02967c1b23bd72", basis: [ { a: "3086d221a7d46bcde86c90e49284eb15", b: "-e4437ed6010e88286f547fa90abfe4c3" }, { a: "114ca50f7a8e2f3f657c1108d9d44cfd8", b: "3086d221a7d46bcde86c90e49284eb15" } ], gRed: false, g: [ "79be667ef9dcbbac55a06295ce870b07029bfcdb2dce28d959f2815b16f81798", "483ada7726a3c4655da4fbfc0e1108a8fd17b448a68554199c47d08ffb10d4b8", pre ] }); }); // ../eve/node_modules/hmac-drbg/lib/hmac-drbg.js var require_hmac_drbg = __commonJS((exports, module) => { var hash = require_hash(); var utils = require_utils(); var assert = require_minimalistic_assert(); function HmacDRBG(options2) { if (!(this instanceof HmacDRBG)) return new HmacDRBG(options2); this.hash = options2.hash; this.predResist = !!options2.predResist; this.outLen = this.hash.outSize; this.minEntropy = options2.minEntropy || this.hash.hmacStrength; this._reseed = null; this.reseedInterval = null; this.K = null; this.V = null; var entropy = utils.toArray(options2.entropy, options2.entropyEnc || "hex"); var nonce = utils.toArray(options2.nonce, options2.nonceEnc || "hex"); var pers = utils.toArray(options2.pers, options2.persEnc || "hex"); assert(entropy.length >= this.minEntropy / 8, "Not enough entropy. Minimum is: " + this.minEntropy + " bits"); this._init(entropy, nonce, pers); } module.exports = HmacDRBG; HmacDRBG.prototype._init = function init(entropy, nonce, pers) { var seed = entropy.concat(nonce).concat(pers); this.K = new Array(this.outLen / 8); this.V = new Array(this.outLen / 8); for (var i = 0;i < this.V.length; i++) { this.K[i] = 0; this.V[i] = 1; } this._update(seed); this._reseed = 1; this.reseedInterval = 281474976710656; }; HmacDRBG.prototype._hmac = function hmac() { return new hash.hmac(this.hash, this.K); }; HmacDRBG.prototype._update = function update(seed) { var kmac = this._hmac().update(this.V).update([0]); if (seed) kmac = kmac.update(seed); this.K = kmac.digest(); this.V = this._hmac().update(this.V).digest(); if (!seed) return; this.K = this._hmac().update(this.V).update([1]).update(seed).digest(); this.V = this._hmac().update(this.V).digest(); }; HmacDRBG.prototype.reseed = function reseed(entropy, entropyEnc, add, addEnc) { if (typeof entropyEnc !== "string") { addEnc = add; add = entropyEnc; entropyEnc = null; } entropy = utils.toArray(entropy, entropyEnc); add = utils.toArray(add, addEnc); assert(entropy.length >= this.minEntropy / 8, "Not enough entropy. Minimum is: " + this.minEntropy + " bits"); this._update(entropy.concat(add || [])); this._reseed = 1; }; HmacDRBG.prototype.generate = function generate(len, enc, add, addEnc) { if (this._reseed > this.reseedInterval) throw new Error("Reseed is required"); if (typeof enc !== "string") { addEnc = add; add = enc; enc = null; } if (add) { add = utils.toArray(add, addEnc || "hex"); this._update(add); } var temp = []; while (temp.length < len) { this.V = this._hmac().update(this.V).digest(); temp = temp.concat(this.V); } var res = temp.slice(0, len); this._update(add); this._reseed++; return utils.encode(res, enc); }; }); // ../eve/node_modules/elliptic/lib/elliptic/ec/key.js var require_key = __commonJS((exports, module) => { var BN = require_bn(); var utils = require_utils2(); var assert = utils.assert; function KeyPair(ec, options2) { this.ec = ec; this.priv = null; this.pub = null; if (options2.priv) this._importPrivate(options2.priv, options2.privEnc); if (options2.pub) this._importPublic(options2.pub, options2.pubEnc); } module.exports = KeyPair; KeyPair.fromPublic = function fromPublic(ec, pub, enc) { if (pub instanceof KeyPair) return pub; return new KeyPair(ec, { pub, pubEnc: enc }); }; KeyPair.fromPrivate = function fromPrivate(ec, priv, enc) { if (priv instanceof KeyPair) return priv; return new KeyPair(ec, { priv, privEnc: enc }); }; KeyPair.prototype.validate = function validate() { var pub = this.getPublic(); if (pub.isInfinity()) return { result: false, reason: "Invalid public key" }; if (!pub.validate()) return { result: false, reason: "Public key is not a point" }; if (!pub.mul(this.ec.curve.n).isInfinity()) return { result: false, reason: "Public key * N != O" }; return { result: true, reason: null }; }; KeyPair.prototype.getPublic = function getPublic(compact, enc) { if (typeof compact === "string") { enc = compact; compact = null; } if (!this.pub) this.pub = this.ec.g.mul(this.priv); if (!enc) return this.pub; return this.pub.encode(enc, compact); }; KeyPair.prototype.getPrivate = function getPrivate(enc) { if (enc === "hex") return this.priv.toString(16, 2); else return this.priv; }; KeyPair.prototype._importPrivate = function _importPrivate(key, enc) { this.priv = new BN(key, enc || 16); this.priv = this.priv.umod(this.ec.curve.n); }; KeyPair.prototype._importPublic = function _importPublic(key, enc) { if (key.x || key.y) { if (this.ec.curve.type === "mont") { assert(key.x, "Need x coordinate"); } else if (this.ec.curve.type === "short" || this.ec.curve.type === "edwards") { assert(key.x && key.y, "Need both x and y coordinate"); } this.pub = this.ec.curve.point(key.x, key.y); return; } this.pub = this.ec.curve.decodePoint(key, enc); }; KeyPair.prototype.derive = function derive(pub) { if (!pub.validate()) { assert(pub.validate(), "public point not validated"); } return pub.mul(this.priv).getX(); }; KeyPair.prototype.sign = function sign(msg, enc, options2) { return this.ec.sign(msg, this, enc, options2); }; KeyPair.prototype.verify = function verify(msg, signature, options2) { return this.ec.verify(msg, signature, this, undefined, options2); }; KeyPair.prototype.inspect = function inspect() { return ""; }; }); // ../eve/node_modules/elliptic/lib/elliptic/ec/signature.js var require_signature = __commonJS((exports, module) => { var BN = require_bn(); var utils = require_utils2(); var assert = utils.assert; function Signature(options2, enc) { if (options2 instanceof Signature) return options2; if (this._importDER(options2, enc)) return; assert(options2.r && options2.s, "Signature without r or s"); this.r = new BN(options2.r, 16); this.s = new BN(options2.s, 16); if (options2.recoveryParam === undefined) this.recoveryParam = null; else this.recoveryParam = options2.recoveryParam; } module.exports = Signature; function Position() { this.place = 0; } function getLength(buf, p) { var initial = buf[p.place++]; if (!(initial & 128)) { return initial; } var octetLen = initial & 15; if (octetLen === 0 || octetLen > 4) { return false; } if (buf[p.place] === 0) { return false; } var val = 0; for (var i = 0, off = p.place;i < octetLen; i++, off++) { val <<= 8; val |= buf[off]; val >>>= 0; } if (val <= 127) { return false; } p.place = off; return val; } function rmPadding(buf) { var i = 0; var len = buf.length - 1; while (!buf[i] && !(buf[i + 1] & 128) && i < len) { i++; } if (i === 0) { return buf; } return buf.slice(i); } Signature.prototype._importDER = function _importDER(data, enc) { data = utils.toArray(data, enc); var p = new Position; if (data[p.place++] !== 48) { return false; } var len = getLength(data, p); if (len === false) { return false; } if (len + p.place !== data.length) { return false; } if (data[p.place++] !== 2) { return false; } var rlen = getLength(data, p); if (rlen === false) { return false; } if ((data[p.place] & 128) !== 0) { return false; } var r = data.slice(p.place, rlen + p.place); p.place += rlen; if (data[p.place++] !== 2) { return false; } var slen = getLength(data, p); if (slen === false) { return false; } if (data.length !== slen + p.place) { return false; } if ((data[p.place] & 128) !== 0) { return false; } var s = data.slice(p.place, slen + p.place); if (r[0] === 0) { if (r[1] & 128) { r = r.slice(1); } else { return false; } } if (s[0] === 0) { if (s[1] & 128) { s = s.slice(1); } else { return false; } } this.r = new BN(r); this.s = new BN(s); this.recoveryParam = null; return true; }; function constructLength(arr, len) { if (len < 128) { arr.push(len); return; } var octets = 1 + (Math.log(len) / Math.LN2 >>> 3); arr.push(octets | 128); while (--octets) { arr.push(len >>> (octets << 3) & 255); } arr.push(len); } Signature.prototype.toDER = function toDER(enc) { var r = this.r.toArray(); var s = this.s.toArray(); if (r[0] & 128) r = [0].concat(r); if (s[0] & 128) s = [0].concat(s); r = rmPadding(r); s = rmPadding(s); while (!s[0] && !(s[1] & 128)) { s = s.slice(1); } var arr = [2]; constructLength(arr, r.length); arr = arr.concat(r); arr.push(2); constructLength(arr, s.length); var backHalf = arr.concat(s); var res = [48]; constructLength(res, backHalf.length); res = res.concat(backHalf); return utils.encode(res, enc); }; }); // ../eve/node_modules/elliptic/lib/elliptic/ec/index.js var require_ec = __commonJS((exports, module) => { var BN = require_bn(); var HmacDRBG = require_hmac_drbg(); var utils = require_utils2(); var curves = require_curves(); var rand = require_brorand(); var assert = utils.assert; var KeyPair = require_key(); var Signature = require_signature(); function EC(options2) { if (!(this instanceof EC)) return new EC(options2); if (typeof options2 === "string") { assert(Object.prototype.hasOwnProperty.call(curves, options2), "Unknown curve " + options2); options2 = curves[options2]; } if (options2 instanceof curves.PresetCurve) options2 = { curve: options2 }; this.curve = options2.curve.curve; this.n = this.curve.n; this.nh = this.n.ushrn(1); this.g = this.curve.g; this.g = options2.curve.g; this.g.precompute(options2.curve.n.bitLength() + 1); this.hash = options2.hash || options2.curve.hash; } module.exports = EC; EC.prototype.keyPair = function keyPair(options2) { return new KeyPair(this, options2); }; EC.prototype.keyFromPrivate = function keyFromPrivate(priv, enc) { return KeyPair.fromPrivate(this, priv, enc); }; EC.prototype.keyFromPublic = function keyFromPublic(pub, enc) { return KeyPair.fromPublic(this, pub, enc); }; EC.prototype.genKeyPair = function genKeyPair(options2) { if (!options2) options2 = {}; var drbg = new HmacDRBG({ hash: this.hash, pers: options2.pers, persEnc: options2.persEnc || "utf8", entropy: options2.entropy || rand(this.hash.hmacStrength), entropyEnc: options2.entropy && options2.entropyEnc || "utf8", nonce: this.n.toArray() }); var bytes = this.n.byteLength(); var ns2 = this.n.sub(new BN(2)); for (;; ) { var priv = new BN(drbg.generate(bytes)); if (priv.cmp(ns2) > 0) continue; priv.iaddn(1); return this.keyFromPrivate(priv); } }; EC.prototype._truncateToN = function _truncateToN(msg, truncOnly, bitLength) { var byteLength; if (BN.isBN(msg) || typeof msg === "number") { msg = new BN(msg, 16); byteLength = msg.byteLength(); } else if (typeof msg === "object") { byteLength = msg.length; msg = new BN(msg, 16); } else { var str = msg.toString(); byteLength = str.length + 1 >>> 1; msg = new BN(str, 16); } if (typeof bitLength !== "number") { bitLength = byteLength * 8; } var delta = bitLength - this.n.bitLength(); if (delta > 0) msg = msg.ushrn(delta); if (!truncOnly && msg.cmp(this.n) >= 0) return msg.sub(this.n); else return msg; }; EC.prototype.sign = function sign(msg, key, enc, options2) { if (typeof enc === "object") { options2 = enc; enc = null; } if (!options2) options2 = {}; if (typeof msg !== "string" && typeof msg !== "number" && !BN.isBN(msg)) { assert(typeof msg === "object" && msg && typeof msg.length === "number", "Expected message to be an array-like, a hex string, or a BN instance"); assert(msg.length >>> 0 === msg.length); for (var i = 0;i < msg.length; i++) assert((msg[i] & 255) === msg[i]); } key = this.keyFromPrivate(key, enc); msg = this._truncateToN(msg, false, options2.msgBitLength); assert(!msg.isNeg(), "Can not sign a negative message"); var bytes = this.n.byteLength(); var bkey = key.getPrivate().toArray("be", bytes); var nonce = msg.toArray("be", bytes); assert(new BN(nonce).eq(msg), "Can not sign message"); var drbg = new HmacDRBG({ hash: this.hash, entropy: bkey, nonce, pers: options2.pers, persEnc: options2.persEnc || "utf8" }); var ns1 = this.n.sub(new BN(1)); for (var iter = 0;; iter++) { var k = options2.k ? options2.k(iter) : new BN(drbg.generate(this.n.byteLength())); k = this._truncateToN(k, true); if (k.cmpn(1) <= 0 || k.cmp(ns1) >= 0) continue; var kp = this.g.mul(k); if (kp.isInfinity()) continue; var kpX = kp.getX(); var r = kpX.umod(this.n); if (r.cmpn(0) === 0) continue; var s = k.invm(this.n).mul(r.mul(key.getPrivate()).iadd(msg)); s = s.umod(this.n); if (s.cmpn(0) === 0) continue; var recoveryParam = (kp.getY().isOdd() ? 1 : 0) | (kpX.cmp(r) !== 0 ? 2 : 0); if (options2.canonical && s.cmp(this.nh) > 0) { s = this.n.sub(s); recoveryParam ^= 1; } return new Signature({ r, s, recoveryParam }); } }; EC.prototype.verify = function verify(msg, signature, key, enc, options2) { if (!options2) options2 = {}; msg = this._truncateToN(msg, false, options2.msgBitLength); key = this.keyFromPublic(key, enc); signature = new Signature(signature, "hex"); var r = signature.r; var s = signature.s; if (r.cmpn(1) < 0 || r.cmp(this.n) >= 0) return false; if (s.cmpn(1) < 0 || s.cmp(this.n) >= 0) return false; var sinv = s.invm(this.n); var u1 = sinv.mul(msg).umod(this.n); var u2 = sinv.mul(r).umod(this.n); var p; if (!this.curve._maxwellTrick) { p = this.g.mulAdd(u1, key.getPublic(), u2); if (p.isInfinity()) return false; return p.getX().umod(this.n).cmp(r) === 0; } p = this.g.jmulAdd(u1, key.getPublic(), u2); if (p.isInfinity()) return false; return p.eqXToP(r); }; EC.prototype.recoverPubKey = function(msg, signature, j, enc) { assert((3 & j) === j, "The recovery param is more than two bits"); signature = new Signature(signature, enc); var n = this.n; var e = new BN(msg); var r = signature.r; var s = signature.s; var isYOdd = j & 1; var isSecondKey = j >> 1; if (r.cmp(this.curve.p.umod(this.curve.n)) >= 0 && isSecondKey) throw new Error("Unable to find sencond key candinate"); if (isSecondKey) r = this.curve.pointFromX(r.add(this.curve.n), isYOdd); else r = this.curve.pointFromX(r, isYOdd); var rInv = signature.r.invm(n); var s1 = n.sub(e).mul(rInv).umod(n); var s2 = s.mul(rInv).umod(n); return this.g.mulAdd(s1, r, s2); }; EC.prototype.getKeyRecoveryParam = function(e, signature, Q, enc) { signature = new Signature(signature, enc); if (signature.recoveryParam !== null) return signature.recoveryParam; for (var i = 0;i < 4; i++) { var Qprime; try { Qprime = this.recoverPubKey(e, signature, i); } catch (e2) { continue; } if (Qprime.eq(Q)) return i; } throw new Error("Unable to find valid recovery factor"); }; }); // ../eve/node_modules/elliptic/lib/elliptic/eddsa/key.js var require_key2 = __commonJS((exports, module) => { var utils = require_utils2(); var assert = utils.assert; var parseBytes = utils.parseBytes; var cachedProperty = utils.cachedProperty; function KeyPair(eddsa, params) { this.eddsa = eddsa; this._secret = parseBytes(params.secret); if (eddsa.isPoint(params.pub)) this._pub = params.pub; else this._pubBytes = parseBytes(params.pub); } KeyPair.fromPublic = function fromPublic(eddsa, pub) { if (pub instanceof KeyPair) return pub; return new KeyPair(eddsa, { pub }); }; KeyPair.fromSecret = function fromSecret(eddsa, secret) { if (secret instanceof KeyPair) return secret; return new KeyPair(eddsa, { secret }); }; KeyPair.prototype.secret = function secret() { return this._secret; }; cachedProperty(KeyPair, "pubBytes", function pubBytes() { return this.eddsa.encodePoint(this.pub()); }); cachedProperty(KeyPair, "pub", function pub() { if (this._pubBytes) return this.eddsa.decodePoint(this._pubBytes); return this.eddsa.g.mul(this.priv()); }); cachedProperty(KeyPair, "privBytes", function privBytes() { var eddsa = this.eddsa; var hash = this.hash(); var lastIx = eddsa.encodingLength - 1; var a = hash.slice(0, eddsa.encodingLength); a[0] &= 248; a[lastIx] &= 127; a[lastIx] |= 64; return a; }); cachedProperty(KeyPair, "priv", function priv() { return this.eddsa.decodeInt(this.privBytes()); }); cachedProperty(KeyPair, "hash", function hash() { return this.eddsa.hash().update(this.secret()).digest(); }); cachedProperty(KeyPair, "messagePrefix", function messagePrefix() { return this.hash().slice(this.eddsa.encodingLength); }); KeyPair.prototype.sign = function sign(message) { assert(this._secret, "KeyPair can only verify"); return this.eddsa.sign(message, this); }; KeyPair.prototype.verify = function verify(message, sig) { return this.eddsa.verify(message, sig, this); }; KeyPair.prototype.getSecret = function getSecret(enc) { assert(this._secret, "KeyPair is public only"); return utils.encode(this.secret(), enc); }; KeyPair.prototype.getPublic = function getPublic(enc) { return utils.encode(this.pubBytes(), enc); }; module.exports = KeyPair; }); // ../eve/node_modules/elliptic/lib/elliptic/eddsa/signature.js var require_signature2 = __commonJS((exports, module) => { var BN = require_bn(); var utils = require_utils2(); var assert = utils.assert; var cachedProperty = utils.cachedProperty; var parseBytes = utils.parseBytes; function Signature(eddsa, sig) { this.eddsa = eddsa; if (typeof sig !== "object") sig = parseBytes(sig); if (Array.isArray(sig)) { assert(sig.length === eddsa.encodingLength * 2, "Signature has invalid size"); sig = { R: sig.slice(0, eddsa.encodingLength), S: sig.slice(eddsa.encodingLength) }; } assert(sig.R && sig.S, "Signature without R or S"); if (eddsa.isPoint(sig.R)) this._R = sig.R; if (sig.S instanceof BN) this._S = sig.S; this._Rencoded = Array.isArray(sig.R) ? sig.R : sig.Rencoded; this._Sencoded = Array.isArray(sig.S) ? sig.S : sig.Sencoded; } cachedProperty(Signature, "S", function S() { return this.eddsa.decodeInt(this.Sencoded()); }); cachedProperty(Signature, "R", function R() { return this.eddsa.decodePoint(this.Rencoded()); }); cachedProperty(Signature, "Rencoded", function Rencoded() { return this.eddsa.encodePoint(this.R()); }); cachedProperty(Signature, "Sencoded", function Sencoded() { return this.eddsa.encodeInt(this.S()); }); Signature.prototype.toBytes = function toBytes() { return this.Rencoded().concat(this.Sencoded()); }; Signature.prototype.toHex = function toHex() { return utils.encode(this.toBytes(), "hex").toUpperCase(); }; module.exports = Signature; }); // ../eve/node_modules/elliptic/lib/elliptic/eddsa/index.js var require_eddsa = __commonJS((exports, module) => { var hash = require_hash(); var curves = require_curves(); var utils = require_utils2(); var assert = utils.assert; var parseBytes = utils.parseBytes; var KeyPair = require_key2(); var Signature = require_signature2(); function EDDSA(curve) { assert(curve === "ed25519", "only tested with ed25519 so far"); if (!(this instanceof EDDSA)) return new EDDSA(curve); curve = curves[curve].curve; this.curve = curve; this.g = curve.g; this.g.precompute(curve.n.bitLength() + 1); this.pointClass = curve.point().constructor; this.encodingLength = Math.ceil(curve.n.bitLength() / 8); this.hash = hash.sha512; } module.exports = EDDSA; EDDSA.prototype.sign = function sign(message, secret) { message = parseBytes(message); var key = this.keyFromSecret(secret); var r = this.hashInt(key.messagePrefix(), message); var R = this.g.mul(r); var Rencoded = this.encodePoint(R); var s_ = this.hashInt(Rencoded, key.pubBytes(), message).mul(key.priv()); var S = r.add(s_).umod(this.curve.n); return this.makeSignature({ R, S, Rencoded }); }; EDDSA.prototype.verify = function verify(message, sig, pub) { message = parseBytes(message); sig = this.makeSignature(sig); if (sig.S().gte(sig.eddsa.curve.n) || sig.S().isNeg()) { return false; } var key = this.keyFromPublic(pub); var h = this.hashInt(sig.Rencoded(), key.pubBytes(), message); var SG = this.g.mul(sig.S()); var RplusAh = sig.R().add(key.pub().mul(h)); return RplusAh.eq(SG); }; EDDSA.prototype.hashInt = function hashInt() { var hash2 = this.hash(); for (var i = 0;i < arguments.length; i++) hash2.update(arguments[i]); return utils.intFromLE(hash2.digest()).umod(this.curve.n); }; EDDSA.prototype.keyFromPublic = function keyFromPublic(pub) { return KeyPair.fromPublic(this, pub); }; EDDSA.prototype.keyFromSecret = function keyFromSecret(secret) { return KeyPair.fromSecret(this, secret); }; EDDSA.prototype.makeSignature = function makeSignature(sig) { if (sig instanceof Signature) return sig; return new Signature(this, sig); }; EDDSA.prototype.encodePoint = function encodePoint(point) { var enc = point.getY().toArray("le", this.encodingLength); enc[this.encodingLength - 1] |= point.getX().isOdd() ? 128 : 0; return enc; }; EDDSA.prototype.decodePoint = function decodePoint(bytes) { bytes = utils.parseBytes(bytes); var lastIx = bytes.length - 1; var normed = bytes.slice(0, lastIx).concat(bytes[lastIx] & ~128); var xIsOdd = (bytes[lastIx] & 128) !== 0; var y = utils.intFromLE(normed); return this.curve.pointFromY(y, xIsOdd); }; EDDSA.prototype.encodeInt = function encodeInt(num) { return num.toArray("le", this.encodingLength); }; EDDSA.prototype.decodeInt = function decodeInt(bytes) { return utils.intFromLE(bytes); }; EDDSA.prototype.isPoint = function isPoint(val) { return val instanceof this.pointClass; }; }); // ../eve/node_modules/elliptic/lib/elliptic.js var require_elliptic = __commonJS((exports) => { var elliptic = exports; elliptic.version = require_package().version; elliptic.utils = require_utils2(); elliptic.rand = require_brorand(); elliptic.curve = require_curve(); elliptic.curves = require_curves(); elliptic.ec = require_ec(); elliptic.eddsa = require_eddsa(); }); // ../eve/node_modules/jwk-to-pem/src/b64-to-bn.js var require_b64_to_bn = __commonJS((exports, module) => { var BN = require_asn1().bignum; var Buffer2 = require_safe_buffer().Buffer; module.exports = function base64ToBigNum(val, zero) { var buf = Buffer2.from(val, "base64"); var bn = val = new BN(buf, 10, "be").iabs(); if (zero) { buf.fill(0); } return bn; }; }); // ../eve/node_modules/jwk-to-pem/src/asn1/algorithm-identifier.js var require_algorithm_identifier = __commonJS((exports, module) => { module.exports = require_asn1().define("AlgorithmIdentifer", function() { this.seq().obj(this.key("algorithm").objid(), this.key("parameters").optional().any()); }); }); // ../eve/node_modules/jwk-to-pem/src/asn1/public-key-info.js var require_public_key_info = __commonJS((exports, module) => { var AlgorithmIdentifier = require_algorithm_identifier(); module.exports = require_asn1().define("PublicKeyInfo", function() { this.seq().obj(this.key("algorithm").use(AlgorithmIdentifier), this.key("PublicKey").bitstr()); }); }); // ../eve/node_modules/jwk-to-pem/src/asn1/version.js var require_version = __commonJS((exports, module) => { module.exports = require_asn1().define("Version", function() { this.int(); }); }); // ../eve/node_modules/jwk-to-pem/src/asn1/private-key-info.js var require_private_key_info = __commonJS((exports, module) => { var AlgorithmIdentifier = require_algorithm_identifier(); var Version = require_version(); module.exports = require_asn1().define("PrivateKeyInfo", function() { this.seq().obj(this.key("version").use(Version), this.key("privateKeyAlgorithm").use(AlgorithmIdentifier), this.key("privateKey").octstr(), this.key("attributes").optional().any()); }); }); // ../eve/node_modules/jwk-to-pem/src/ec.js var require_ec2 = __commonJS((exports, module) => { var asn1 = require_asn1(); var Buffer2 = require_safe_buffer().Buffer; var EC = require_elliptic().ec; var b64ToBn = require_b64_to_bn(); var PublicKeyInfo = require_public_key_info(); var PrivateKeyInfo = require_private_key_info(); var Version = require_version(); var ECParameters = asn1.define("ECParameters", function() { this.choice({ namedCurve: this.objid() }); }); var ecPrivkeyVer1 = 1; var ECPrivateKey = asn1.define("ECPrivateKey", function() { this.seq().obj(this.key("version").use(Version), this.key("privateKey").octstr(), this.key("parameters").explicit(0).optional().any(), this.key("publicKey").explicit(1).optional().bitstr()); }); var curves = { "P-256": "p256", "P-384": "p384", "P-521": "p521" }; var oids = { "P-256": [1, 2, 840, 10045, 3, 1, 7], "P-384": [1, 3, 132, 0, 34], "P-521": [1, 3, 132, 0, 35] }; var parameters = {}; var algorithms = {}; Object.keys(oids).forEach(function(crv) { parameters[crv] = ECParameters.encode({ type: "namedCurve", value: oids[crv] }, "der"); algorithms[crv] = { algorithm: [1, 2, 840, 10045, 2, 1], parameters: parameters[crv] }; }); oids = null; function ecJwkToBuffer(jwk, opts) { if (typeof jwk.crv !== "string") { throw new TypeError('Expected "jwk.crv" to be a String'); } var hasD = typeof jwk.d === "string"; var xyTypes = hasD ? ["undefined", "string"] : ["string"]; if (xyTypes.indexOf(typeof jwk.x) === -1) { throw new TypeError('Expected "jwk.x" to be a String'); } if (xyTypes.indexOf(typeof jwk.y) === -1) { throw new TypeError('Expected "jwk.y" to be a String'); } if (opts.private && !hasD) { throw new TypeError('Expected "jwk.d" to be a String'); } var curveName = curves[jwk.crv]; if (!curveName) { throw new Error('Unsupported curve "' + jwk.crv + '"'); } var curve = new EC(curveName); var key = {}; var hasPub = jwk.x && jwk.y; if (hasPub) { key.pub = { x: b64ToBn(jwk.x, false), y: b64ToBn(jwk.y, false) }; } if (opts.private || !hasPub) { key.priv = b64ToBn(jwk.d, true); } key = curve.keyPair(key); var keyValidation = key.validate(); if (!keyValidation.result) { throw new Error('Invalid key for curve: "' + keyValidation.reason + '"'); } var result = keyToPem(jwk.crv, key, opts); return result; } function keyToPem(crv, key, opts) { var compact = false; var publicKey = key.getPublic(compact, "hex"); publicKey = Buffer2.from(publicKey, "hex"); publicKey = { unused: 0, data: publicKey }; var result; if (opts.private) { var privateKey = key.getPrivate("hex"); privateKey = Buffer2.from(privateKey, "hex"); result = PrivateKeyInfo.encode({ version: 0, privateKeyAlgorithm: algorithms[crv], privateKey: ECPrivateKey.encode({ version: ecPrivkeyVer1, privateKey, parameters: parameters[crv], publicKey }, "der") }, "pem", { label: "PRIVATE KEY" }); privateKey.fill(0); } else { result = PublicKeyInfo.encode({ algorithm: algorithms[crv], PublicKey: publicKey }, "pem", { label: "PUBLIC KEY" }); } if (result.slice(-1) !== ` `) { result += ` `; } return result; } module.exports = ecJwkToBuffer; }); // ../eve/node_modules/jwk-to-pem/src/rsa.js var require_rsa = __commonJS((exports, module) => { var asn1 = require_asn1(); var b64ToBn = require_b64_to_bn(); var PublicKeyInfo = require_public_key_info(); var PrivateKeyInfo = require_private_key_info(); var Version = require_version(); var RSAPrivateKey = asn1.define("RSAPrivateKey", function() { this.seq().obj(this.key("version").use(Version), this.key("modulus").int(), this.key("publicExponent").int(), this.key("privateExponent").int(), this.key("prime1").int(), this.key("prime2").int(), this.key("exponent1").int(), this.key("exponent2").int(), this.key("coefficient").int()); }); var RSAPublicKey = asn1.define("RSAPublicKey", function() { this.seq().obj(this.key("modulus").int(), this.key("publicExponent").int()); }); var algorithm = { algorithm: [1, 2, 840, 113549, 1, 1, 1], parameters: [5, 0] }; function rsaJwkToBuffer(jwk, opts) { if (typeof jwk.e !== "string") { throw new TypeError('Expected "jwk.e" to be a String'); } if (typeof jwk.n !== "string") { throw new TypeError('Expected "jwk.n" to be a String'); } if (opts.private) { if (typeof jwk.d !== "string") { throw new TypeError('Expected "jwk.d" to be a String'); } if (typeof jwk.p !== "string") { throw new TypeError('Expected "jwk.p" to be a String'); } if (typeof jwk.q !== "string") { throw new TypeError('Expected "jwk.q" to be a String'); } if (typeof jwk.dp !== "string") { throw new TypeError('Expected "jwk.dp" to be a String'); } if (typeof jwk.dq !== "string") { throw new TypeError('Expected "jwk.dq" to be a String'); } if (typeof jwk.qi !== "string") { throw new TypeError('Expected "jwk.qi" to be a String'); } } var pem; if (opts.private) { pem = PrivateKeyInfo.encode({ version: 0, privateKeyAlgorithm: algorithm, privateKey: RSAPrivateKey.encode({ version: 0, modulus: b64ToBn(jwk.n, false), publicExponent: b64ToBn(jwk.e, false), privateExponent: b64ToBn(jwk.d, true), prime1: b64ToBn(jwk.p, true), prime2: b64ToBn(jwk.q, true), exponent1: b64ToBn(jwk.dp, true), exponent2: b64ToBn(jwk.dq, true), coefficient: b64ToBn(jwk.qi, true) }, "der") }, "pem", { label: "PRIVATE KEY" }); } else { pem = PublicKeyInfo.encode({ algorithm, PublicKey: { unused: 0, data: RSAPublicKey.encode({ modulus: b64ToBn(jwk.n, false), publicExponent: b64ToBn(jwk.e, false) }, "der") } }, "pem", { label: "PUBLIC KEY" }); } if (pem.slice(-1) !== ` `) { pem += ` `; } return pem; } module.exports = rsaJwkToBuffer; }); // ../eve/node_modules/jwk-to-pem/src/jwk-to-pem.js var require_jwk_to_pem = __commonJS((exports, module) => { var ec = require_ec2(); var rsa = require_rsa(); function jwkToBuffer(jwk, opts) { if (typeof jwk !== "object" || jwk === null) { throw new TypeError('Expected "jwk" to be an Object'); } var kty = jwk.kty; if (typeof kty !== "string") { throw new TypeError('Expected "jwk.kty" to be a String'); } opts = opts || {}; opts.private = opts.private === true; switch (kty) { case "EC": { return ec(jwk, opts); } case "RSA": { return rsa(jwk, opts); } default: { throw new Error('Unsupported key type "' + kty + '"'); } } } module.exports = jwkToBuffer; }); // ../eve/dist/esi/options.js var CLIENT_ID = process.env.EVE_CLIENT_ID || ""; var CLIENT_SECRET = process.env.EVE_CLIENT_SECRET || ""; var CALLBACK_URL = process.env.EVE_CALLBACK_URL || ""; var USER_AGENT = process.env.ESI_USER_AGENT || ""; var options = { client_id: CLIENT_ID, client_secret: CLIENT_SECRET, callback_url: CALLBACK_URL, user_agent: USER_AGENT }; // ../eve/dist/_virtual/rolldown_runtime.js var __defProp2 = Object.defineProperty; var __export = (target, all) => { for (var name in all) __defProp2(target, name, { get: all[name], enumerable: true }); }; // ../eve/node_modules/jwt-decode/build/esm/index.js class InvalidTokenError extends Error { } InvalidTokenError.prototype.name = "InvalidTokenError"; function b64DecodeUnicode(str) { return decodeURIComponent(atob(str).replace(/(.)/g, (m, p) => { let code = p.charCodeAt(0).toString(16).toUpperCase(); if (code.length < 2) { code = "0" + code; } return "%" + code; })); } function base64UrlDecode(str) { let output = str.replace(/-/g, "+").replace(/_/g, "/"); switch (output.length % 4) { case 0: break; case 2: output += "=="; break; case 3: output += "="; break; default: throw new Error("base64 string is not of the correct length"); } try { return b64DecodeUnicode(output); } catch (err) { return atob(output); } } function jwtDecode(token, options2) { if (typeof token !== "string") { throw new InvalidTokenError("Invalid token specified: must be a string"); } options2 || (options2 = {}); const pos = options2.header === true ? 0 : 1; const part = token.split(".")[pos]; if (typeof part !== "string") { throw new InvalidTokenError(`Invalid token specified: missing part #${pos + 1}`); } let decoded; try { decoded = base64UrlDecode(part); } catch (e) { throw new InvalidTokenError(`Invalid token specified: invalid base64 for part #${pos + 1} (${e.message})`); } try { return JSON.parse(decoded); } catch (e) { throw new InvalidTokenError(`Invalid token specified: invalid json for part #${pos + 1} (${e.message})`); } } // ../eve/node_modules/@oslojs/encoding/dist/base32.js var EncodingPadding; (function(EncodingPadding2) { EncodingPadding2[EncodingPadding2["Include"] = 0] = "Include"; EncodingPadding2[EncodingPadding2["None"] = 1] = "None"; })(EncodingPadding || (EncodingPadding = {})); var DecodingPadding; (function(DecodingPadding2) { DecodingPadding2[DecodingPadding2["Required"] = 0] = "Required"; DecodingPadding2[DecodingPadding2["Ignore"] = 1] = "Ignore"; })(DecodingPadding || (DecodingPadding = {})); // ../eve/node_modules/@oslojs/encoding/dist/base64.js function encodeBase64urlNoPadding(bytes) { return encodeBase64_internal(bytes, base64urlAlphabet, EncodingPadding2.None); } function encodeBase64_internal(bytes, alphabet, padding) { let result = ""; for (let i = 0;i < bytes.byteLength; i += 3) { let buffer = 0; let bufferBitSize = 0; for (let j = 0;j < 3 && i + j < bytes.byteLength; j++) { buffer = buffer << 8 | bytes[i + j]; bufferBitSize += 8; } for (let j = 0;j < 4; j++) { if (bufferBitSize >= 6) { result += alphabet[buffer >> bufferBitSize - 6 & 63]; bufferBitSize -= 6; } else if (bufferBitSize > 0) { result += alphabet[buffer << 6 - bufferBitSize & 63]; bufferBitSize = 0; } else if (padding === EncodingPadding2.Include) { result += "="; } } } return result; } var base64urlAlphabet = "ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789-_"; var EncodingPadding2; (function(EncodingPadding3) { EncodingPadding3[EncodingPadding3["Include"] = 0] = "Include"; EncodingPadding3[EncodingPadding3["None"] = 1] = "None"; })(EncodingPadding2 || (EncodingPadding2 = {})); var DecodingPadding2; (function(DecodingPadding3) { DecodingPadding3[DecodingPadding3["Required"] = 0] = "Required"; DecodingPadding3[DecodingPadding3["Ignore"] = 1] = "Ignore"; })(DecodingPadding2 || (DecodingPadding2 = {})); // ../eve/dist/esi/auth.js var import_jsonwebtoken = __toESM(require_jsonwebtoken(), 1); var import_jwk_to_pem = __toESM(require_jwk_to_pem(), 1); var auth_exports = {}; __export(auth_exports, { characterIdFromToken: () => characterIdFromToken, createAuthorizationURL: () => createAuthorizationURL, refresh: () => refresh, validateAuthorizationCode: () => validateAuthorizationCode, validateToken: () => validateToken }); function generateState() { const randomValues = new Uint8Array(32); crypto.getRandomValues(randomValues); return encodeBase64urlNoPadding(randomValues); } async function createAuthorizationURL(scopes = "publicData") { const state = generateState(); const url = new URL("https://login.eveonline.com/v2/oauth/authorize/"); url.searchParams.set("response_type", "code"); url.searchParams.set("redirect_uri", options.callback_url); url.searchParams.set("client_id", options.client_id); url.searchParams.set("state", state); url.searchParams.set("scope", Array.isArray(scopes) ? scopes.join(" ") : scopes); return { url, state }; } async function validateAuthorizationCode(code) { try { const response = await fetch("https://login.eveonline.com/v2/oauth/token", { method: "POST", headers: { "Content-Type": "application/x-www-form-urlencoded", Authorization: `Basic ${Buffer.from(`${options.client_id}:${options.client_secret}`).toString("base64")}` }, body: new URLSearchParams({ grant_type: "authorization_code", code }) }); return await response.json(); } catch (error) { console.error(`failed to validate EVE authorization code`, error); throw `${error}`; } } var eveAuthPublicKey; async function validateToken(token) { if (!eveAuthPublicKey) try { const eveJWKS = await (await fetch("https://login.eveonline.com/oauth/jwks")).json(); eveAuthPublicKey = import_jwk_to_pem.default(eveJWKS.keys[0]); } catch (err) { console.error(`failed to get EVE Auth public keys`, err); } try { const decoded = import_jsonwebtoken.default.verify(token, eveAuthPublicKey); return decoded; } catch (err) { console.error(`failed to validate EVE token`, err); return null; } } async function refresh({ refresh_token }, scopes) { const params = { grant_type: "refresh_token", refresh_token, scope: "" }; if (scopes) params["scope"] = Array.isArray(scopes) ? scopes.join(" ") : scopes; const response = await fetch("https://login.eveonline.com/v2/oauth/token", { method: "POST", headers: { "Content-Type": "application/x-www-form-urlencoded", Authorization: `Basic ${Buffer.from(`${options.client_id}:${options.client_secret}`).toString("base64")}` }, body: new URLSearchParams(params) }); return await response.json(); } function characterIdFromToken(token) { const payload = jwtDecode(token); return parseInt(payload.sub.split(":")[2]); } // ../eve/dist/esi/scopes.js var ESI_LATEST_URL = "https://esi.evetech.net/latest"; function joinScopes(...scopes) { return scopes.join(" "); } var SCOPES = /* @__PURE__ */ function(SCOPES$1) { SCOPES$1["PUBLIC_DATA"] = "publicData"; SCOPES$1["CALENDAR_RESPOND_CALENDAR_EVENTS"] = "esi-calendar.respond_calendar_events.v1"; SCOPES$1["CALENDAR_READ_CALENDAR_EVENTS"] = "esi-calendar.read_calendar_events.v1"; SCOPES$1["LOCATION_READ_LOCATION"] = "esi-location.read_location.v1"; SCOPES$1["LOCATION_READ_SHIP_TYPE"] = "esi-location.read_ship_type.v1"; SCOPES$1["MAIL_ORGANIZE_MAIL"] = "esi-mail.organize_mail.v1"; SCOPES$1["MAIL_READ_MAIL"] = "esi-mail.read_mail.v1"; SCOPES$1["MAIL_SEND_MAIL"] = "esi-mail.send_mail.v1"; SCOPES$1["SKILLS_READ_SKILLS"] = "esi-skills.read_skills.v1"; SCOPES$1["SKILLS_READ_SKILLQUEUE"] = "esi-skills.read_skillqueue.v1"; SCOPES$1["WALLET_READ_CHARACTER_WALLET"] = "esi-wallet.read_character_wallet.v1"; SCOPES$1["WALLET_READ_CORPORATION_WALLET"] = "esi-wallet.read_corporation_wallet.v1"; SCOPES$1["SEARCH_SEARCH_STRUCTURES"] = "esi-search.search_structures.v1"; SCOPES$1["CLONES_READ_CLONES"] = "esi-clones.read_clones.v1"; SCOPES$1["CHARACTERS_READ_CONTACTS"] = "esi-characters.read_contacts.v1"; SCOPES$1["UNIVERSE_READ_STRUCTURES"] = "esi-universe.read_structures.v1"; SCOPES$1["KILLMAILS_READ_KILLMAILS"] = "esi-killmails.read_killmails.v1"; SCOPES$1["CORPORATIONS_READ_CORPORATION_MEMBERSHIP"] = "esi-corporations.read_corporation_membership.v1"; SCOPES$1["ASSETS_READ_ASSETS"] = "esi-assets.read_assets.v1"; SCOPES$1["PLANETS_MANAGE_PLANETS"] = "esi-planets.manage_planets.v1"; SCOPES$1["FLEETS_READ_FLEET"] = "esi-fleets.read_fleet.v1"; SCOPES$1["FLEETS_WRITE_FLEET"] = "esi-fleets.write_fleet.v1"; SCOPES$1["UI_OPEN_WINDOW"] = "esi-ui.open_window.v1"; SCOPES$1["UI_WRITE_WAYPOINT"] = "esi-ui.write_waypoint.v1"; SCOPES$1["CHARACTERS_WRITE_CONTACTS"] = "esi-characters.write_contacts.v1"; SCOPES$1["FITTINGS_READ_FITTINGS"] = "esi-fittings.read_fittings.v1"; SCOPES$1["FITTINGS_WRITE_FITTINGS"] = "esi-fittings.write_fittings.v1"; SCOPES$1["MARKETS_STRUCTURE_MARKETS"] = "esi-markets.structure_markets.v1"; SCOPES$1["CORPORATIONS_READ_STRUCTURES"] = "esi-corporations.read_structures.v1"; SCOPES$1["CHARACTERS_READ_LOYALTY"] = "esi-characters.read_loyalty.v1"; SCOPES$1["CHARACTERS_READ_OPPORTUNITIES"] = "esi-characters.read_opportunities.v1"; SCOPES$1["CHARACTERS_READ_CHAT_CHANNELS"] = "esi-characters.read_chat_channels.v1"; SCOPES$1["CHARACTERS_READ_MEDALS"] = "esi-characters.read_medals.v1"; SCOPES$1["CHARACTERS_READ_STANDINGS"] = "esi-characters.read_standings.v1"; SCOPES$1["CHARACTERS_READ_AGENTS_RESEARCH"] = "esi-characters.read_agents_research.v1"; SCOPES$1["INDUSTRY_READ_CHARACTER_JOBS"] = "esi-industry.read_character_jobs.v1"; SCOPES$1["MARKETS_READ_CHARACTER_ORDERS"] = "esi-markets.read_character_orders.v1"; SCOPES$1["CHARACTERS_READ_BLUEPRINTS"] = "esi-characters.read_blueprints.v1"; SCOPES$1["CHARACTERS_READ_CORPORATION_ROLES"] = "esi-characters.read_corporation_roles.v1"; SCOPES$1["LOCATION_READ_ONLINE"] = "esi-location.read_online.v1"; SCOPES$1["CONTRACTS_READ_CHARACTER_CONTRACTS"] = "esi-contracts.read_character_contracts.v1"; SCOPES$1["CLONES_READ_IMPLANTS"] = "esi-clones.read_implants.v1"; SCOPES$1["CHARACTERS_READ_FATIGUE"] = "esi-characters.read_fatigue.v1"; SCOPES$1["KILLMAILS_READ_CORPORATION_KILLMAILS"] = "esi-killmails.read_corporation_killmails.v1"; SCOPES$1["CORPORATIONS_TRACK_MEMBERS"] = "esi-corporations.track_members.v1"; SCOPES$1["WALLET_READ_CORPORATION_WALLETS"] = "esi-wallet.read_corporation_wallets.v1"; SCOPES$1["CHARACTERS_READ_NOTIFICATIONS"] = "esi-characters.read_notifications.v1"; SCOPES$1["CORPORATIONS_READ_DIVISIONS"] = "esi-corporations.read_divisions.v1"; SCOPES$1["CORPORATIONS_READ_CONTACTS"] = "esi-corporations.read_contacts.v1"; SCOPES$1["ASSETS_READ_CORPORATION_ASSETS"] = "esi-assets.read_corporation_assets.v1"; SCOPES$1["CORPORATIONS_READ_TITLES"] = "esi-corporations.read_titles.v1"; SCOPES$1["CORPORATIONS_READ_BLUEPRINTS"] = "esi-corporations.read_blueprints.v1"; SCOPES$1["CONTRACTS_READ_CORPORATION_CONTRACTS"] = "esi-contracts.read_corporation_contracts.v1"; SCOPES$1["CORPORATIONS_READ_STANDINGS"] = "esi-corporations.read_standings.v1"; SCOPES$1["CORPORATIONS_READ_STARBASES"] = "esi-corporations.read_starbases.v1"; SCOPES$1["INDUSTRY_READ_CORPORATION_JOBS"] = "esi-industry.read_corporation_jobs.v1"; SCOPES$1["MARKETS_READ_CORPORATION_ORDERS"] = "esi-markets.read_corporation_orders.v1"; SCOPES$1["CORPORATIONS_READ_CONTAINER_LOGS"] = "esi-corporations.read_container_logs.v1"; SCOPES$1["INDUSTRY_READ_CHARACTER_MINING"] = "esi-industry.read_character_mining.v1"; SCOPES$1["INDUSTRY_READ_CORPORATION_MINING"] = "esi-industry.read_corporation_mining.v1"; SCOPES$1["PLANETS_READ_CUSTOMS_OFFICES"] = "esi-planets.read_customs_offices.v1"; SCOPES$1["CORPORATIONS_READ_FACILITIES"] = "esi-corporations.read_facilities.v1"; SCOPES$1["CORPORATIONS_READ_MEDALS"] = "esi-corporations.read_medals.v1"; SCOPES$1["CHARACTERS_READ_TITLES"] = "esi-characters.read_titles.v1"; SCOPES$1["ALLIANCES_READ_CONTACTS"] = "esi-alliances.read_contacts.v1"; SCOPES$1["CHARACTERS_READ_FW_STATS"] = "esi-characters.read_fw_stats.v1"; SCOPES$1["CORPORATIONS_READ_FW_STATS"] = "esi-corporations.read_fw_stats.v1"; return SCOPES$1; }({}); // ../eve/node_modules/drizzle-orm/entity.js var entityKind = Symbol.for("drizzle:entityKind"); var hasOwnEntityKind = Symbol.for("drizzle:hasOwnEntityKind"); function is(value, type) { if (!value || typeof value !== "object") { return false; } if (value instanceof type) { return true; } if (!Object.prototype.hasOwnProperty.call(type, entityKind)) { throw new Error(`Class "${type.name ?? ""}" doesn't look like a Drizzle entity. If this is incorrect and the class is provided by Drizzle, please report this as a bug.`); } let cls = Object.getPrototypeOf(value).constructor; if (cls) { while (cls) { if (entityKind in cls && cls[entityKind] === type[entityKind]) { return true; } cls = Object.getPrototypeOf(cls); } } return false; } // ../eve/node_modules/drizzle-orm/column.js class Column { constructor(table, config) { this.table = table; this.config = config; this.name = config.name; this.keyAsName = config.keyAsName; this.notNull = config.notNull; this.default = config.default; this.defaultFn = config.defaultFn; this.onUpdateFn = config.onUpdateFn; this.hasDefault = config.hasDefault; this.primary = config.primaryKey; this.isUnique = config.isUnique; this.uniqueName = config.uniqueName; this.uniqueType = config.uniqueType; this.dataType = config.dataType; this.columnType = config.columnType; this.generated = config.generated; this.generatedIdentity = config.generatedIdentity; } static [entityKind] = "Column"; name; keyAsName; primary; notNull; default; defaultFn; onUpdateFn; hasDefault; isUnique; uniqueName; uniqueType; dataType; columnType; enumValues = undefined; generated = undefined; generatedIdentity = undefined; config; mapFromDriverValue(value) { return value; } mapToDriverValue(value) { return value; } shouldDisableInsert() { return this.config.generated !== undefined && this.config.generated.type !== "byDefault"; } } // ../eve/node_modules/drizzle-orm/column-builder.js class ColumnBuilder { static [entityKind] = "ColumnBuilder"; config; constructor(name, dataType, columnType) { this.config = { name, keyAsName: name === "", notNull: false, default: undefined, hasDefault: false, primaryKey: false, isUnique: false, uniqueName: undefined, uniqueType: undefined, dataType, columnType, generated: undefined }; } $type() { return this; } notNull() { this.config.notNull = true; return this; } default(value) { this.config.default = value; this.config.hasDefault = true; return this; } $defaultFn(fn) { this.config.defaultFn = fn; this.config.hasDefault = true; return this; } $default = this.$defaultFn; $onUpdateFn(fn) { this.config.onUpdateFn = fn; this.config.hasDefault = true; return this; } $onUpdate = this.$onUpdateFn; primaryKey() { this.config.primaryKey = true; this.config.notNull = true; return this; } setName(name) { if (this.config.name !== "") return; this.config.name = name; } } // ../eve/node_modules/drizzle-orm/table.utils.js var TableName = Symbol.for("drizzle:Name"); // ../eve/node_modules/drizzle-orm/tracing-utils.js function iife(fn, ...args) { return fn(...args); } // ../eve/node_modules/drizzle-orm/pg-core/unique-constraint.js function uniqueKeyName(table, columns) { return `${table[TableName]}_${columns.join("_")}_unique`; } // ../eve/node_modules/drizzle-orm/pg-core/columns/common.js class PgColumn extends Column { constructor(table, config) { if (!config.uniqueName) { config.uniqueName = uniqueKeyName(table, [config.name]); } super(table, config); this.table = table; } static [entityKind] = "PgColumn"; } class ExtraConfigColumn extends PgColumn { static [entityKind] = "ExtraConfigColumn"; getSQLType() { return this.getSQLType(); } indexConfig = { order: this.config.order ?? "asc", nulls: this.config.nulls ?? "last", opClass: this.config.opClass }; defaultConfig = { order: "asc", nulls: "last", opClass: undefined }; asc() { this.indexConfig.order = "asc"; return this; } desc() { this.indexConfig.order = "desc"; return this; } nullsFirst() { this.indexConfig.nulls = "first"; return this; } nullsLast() { this.indexConfig.nulls = "last"; return this; } op(opClass) { this.indexConfig.opClass = opClass; return this; } } // ../eve/node_modules/drizzle-orm/pg-core/columns/enum.js class PgEnumObjectColumn extends PgColumn { static [entityKind] = "PgEnumObjectColumn"; enum; enumValues = this.config.enum.enumValues; constructor(table, config) { super(table, config); this.enum = config.enum; } getSQLType() { return this.enum.enumName; } } var isPgEnumSym = Symbol.for("drizzle:isPgEnum"); function isPgEnum(obj) { return !!obj && typeof obj === "function" && isPgEnumSym in obj && obj[isPgEnumSym] === true; } class PgEnumColumn extends PgColumn { static [entityKind] = "PgEnumColumn"; enum = this.config.enum; enumValues = this.config.enum.enumValues; constructor(table, config) { super(table, config); this.enum = config.enum; } getSQLType() { return this.enum.enumName; } } // ../eve/node_modules/drizzle-orm/subquery.js class Subquery { static [entityKind] = "Subquery"; constructor(sql, fields, alias, isWith = false, usedTables = []) { this._ = { brand: "Subquery", sql, selectedFields: fields, alias, isWith, usedTables }; } } class WithSubquery extends Subquery { static [entityKind] = "WithSubquery"; } // ../eve/node_modules/drizzle-orm/version.js var version = "0.44.5"; // ../eve/node_modules/drizzle-orm/tracing.js var otel; var rawTracer; var tracer = { startActiveSpan(name, fn) { if (!otel) { return fn(); } if (!rawTracer) { rawTracer = otel.trace.getTracer("drizzle-orm", version); } return iife((otel2, rawTracer2) => rawTracer2.startActiveSpan(name, (span) => { try { return fn(span); } catch (e) { span.setStatus({ code: otel2.SpanStatusCode.ERROR, message: e instanceof Error ? e.message : "Unknown error" }); throw e; } finally { span.end(); } }), otel, rawTracer); } }; // ../eve/node_modules/drizzle-orm/view-common.js var ViewBaseConfig = Symbol.for("drizzle:ViewBaseConfig"); // ../eve/node_modules/drizzle-orm/table.js var Schema = Symbol.for("drizzle:Schema"); var Columns = Symbol.for("drizzle:Columns"); var ExtraConfigColumns = Symbol.for("drizzle:ExtraConfigColumns"); var OriginalName = Symbol.for("drizzle:OriginalName"); var BaseName = Symbol.for("drizzle:BaseName"); var IsAlias = Symbol.for("drizzle:IsAlias"); var ExtraConfigBuilder = Symbol.for("drizzle:ExtraConfigBuilder"); var IsDrizzleTable = Symbol.for("drizzle:IsDrizzleTable"); class Table { static [entityKind] = "Table"; static Symbol = { Name: TableName, Schema, OriginalName, Columns, ExtraConfigColumns, BaseName, IsAlias, ExtraConfigBuilder }; [TableName]; [OriginalName]; [Schema]; [Columns]; [ExtraConfigColumns]; [BaseName]; [IsAlias] = false; [IsDrizzleTable] = true; [ExtraConfigBuilder] = undefined; constructor(name, schema, baseName) { this[TableName] = this[OriginalName] = name; this[Schema] = schema; this[BaseName] = baseName; } } function getTableName(table) { return table[TableName]; } function getTableUniqueName(table) { return `${table[Schema] ?? "public"}.${table[TableName]}`; } // ../eve/node_modules/drizzle-orm/sql/sql.js function isSQLWrapper(value) { return value !== null && value !== undefined && typeof value.getSQL === "function"; } function mergeQueries(queries) { const result = { sql: "", params: [] }; for (const query of queries) { result.sql += query.sql; result.params.push(...query.params); if (query.typings?.length) { if (!result.typings) { result.typings = []; } result.typings.push(...query.typings); } } return result; } class StringChunk { static [entityKind] = "StringChunk"; value; constructor(value) { this.value = Array.isArray(value) ? value : [value]; } getSQL() { return new SQL([this]); } } class SQL { constructor(queryChunks) { this.queryChunks = queryChunks; for (const chunk of queryChunks) { if (is(chunk, Table)) { const schemaName = chunk[Table.Symbol.Schema]; this.usedTables.push(schemaName === undefined ? chunk[Table.Symbol.Name] : schemaName + "." + chunk[Table.Symbol.Name]); } } } static [entityKind] = "SQL"; decoder = noopDecoder; shouldInlineParams = false; usedTables = []; append(query) { this.queryChunks.push(...query.queryChunks); return this; } toQuery(config) { return tracer.startActiveSpan("drizzle.buildSQL", (span) => { const query = this.buildQueryFromSourceParams(this.queryChunks, config); span?.setAttributes({ "drizzle.query.text": query.sql, "drizzle.query.params": JSON.stringify(query.params) }); return query; }); } buildQueryFromSourceParams(chunks, _config) { const config = Object.assign({}, _config, { inlineParams: _config.inlineParams || this.shouldInlineParams, paramStartIndex: _config.paramStartIndex || { value: 0 } }); const { casing, escapeName, escapeParam, prepareTyping, inlineParams, paramStartIndex } = config; return mergeQueries(chunks.map((chunk) => { if (is(chunk, StringChunk)) { return { sql: chunk.value.join(""), params: [] }; } if (is(chunk, Name)) { return { sql: escapeName(chunk.value), params: [] }; } if (chunk === undefined) { return { sql: "", params: [] }; } if (Array.isArray(chunk)) { const result = [new StringChunk("(")]; for (const [i, p] of chunk.entries()) { result.push(p); if (i < chunk.length - 1) { result.push(new StringChunk(", ")); } } result.push(new StringChunk(")")); return this.buildQueryFromSourceParams(result, config); } if (is(chunk, SQL)) { return this.buildQueryFromSourceParams(chunk.queryChunks, { ...config, inlineParams: inlineParams || chunk.shouldInlineParams }); } if (is(chunk, Table)) { const schemaName = chunk[Table.Symbol.Schema]; const tableName = chunk[Table.Symbol.Name]; return { sql: schemaName === undefined || chunk[IsAlias] ? escapeName(tableName) : escapeName(schemaName) + "." + escapeName(tableName), params: [] }; } if (is(chunk, Column)) { const columnName = casing.getColumnCasing(chunk); if (_config.invokeSource === "indexes") { return { sql: escapeName(columnName), params: [] }; } const schemaName = chunk.table[Table.Symbol.Schema]; return { sql: chunk.table[IsAlias] || schemaName === undefined ? escapeName(chunk.table[Table.Symbol.Name]) + "." + escapeName(columnName) : escapeName(schemaName) + "." + escapeName(chunk.table[Table.Symbol.Name]) + "." + escapeName(columnName), params: [] }; } if (is(chunk, View)) { const schemaName = chunk[ViewBaseConfig].schema; const viewName = chunk[ViewBaseConfig].name; return { sql: schemaName === undefined || chunk[ViewBaseConfig].isAlias ? escapeName(viewName) : escapeName(schemaName) + "." + escapeName(viewName), params: [] }; } if (is(chunk, Param)) { if (is(chunk.value, Placeholder)) { return { sql: escapeParam(paramStartIndex.value++, chunk), params: [chunk], typings: ["none"] }; } const mappedValue = chunk.value === null ? null : chunk.encoder.mapToDriverValue(chunk.value); if (is(mappedValue, SQL)) { return this.buildQueryFromSourceParams([mappedValue], config); } if (inlineParams) { return { sql: this.mapInlineParam(mappedValue, config), params: [] }; } let typings = ["none"]; if (prepareTyping) { typings = [prepareTyping(chunk.encoder)]; } return { sql: escapeParam(paramStartIndex.value++, mappedValue), params: [mappedValue], typings }; } if (is(chunk, Placeholder)) { return { sql: escapeParam(paramStartIndex.value++, chunk), params: [chunk], typings: ["none"] }; } if (is(chunk, SQL.Aliased) && chunk.fieldAlias !== undefined) { return { sql: escapeName(chunk.fieldAlias), params: [] }; } if (is(chunk, Subquery)) { if (chunk._.isWith) { return { sql: escapeName(chunk._.alias), params: [] }; } return this.buildQueryFromSourceParams([ new StringChunk("("), chunk._.sql, new StringChunk(") "), new Name(chunk._.alias) ], config); } if (isPgEnum(chunk)) { if (chunk.schema) { return { sql: escapeName(chunk.schema) + "." + escapeName(chunk.enumName), params: [] }; } return { sql: escapeName(chunk.enumName), params: [] }; } if (isSQLWrapper(chunk)) { if (chunk.shouldOmitSQLParens?.()) { return this.buildQueryFromSourceParams([chunk.getSQL()], config); } return this.buildQueryFromSourceParams([ new StringChunk("("), chunk.getSQL(), new StringChunk(")") ], config); } if (inlineParams) { return { sql: this.mapInlineParam(chunk, config), params: [] }; } return { sql: escapeParam(paramStartIndex.value++, chunk), params: [chunk], typings: ["none"] }; })); } mapInlineParam(chunk, { escapeString }) { if (chunk === null) { return "null"; } if (typeof chunk === "number" || typeof chunk === "boolean") { return chunk.toString(); } if (typeof chunk === "string") { return escapeString(chunk); } if (typeof chunk === "object") { const mappedValueAsString = chunk.toString(); if (mappedValueAsString === "[object Object]") { return escapeString(JSON.stringify(chunk)); } return escapeString(mappedValueAsString); } throw new Error("Unexpected param value: " + chunk); } getSQL() { return this; } as(alias) { if (alias === undefined) { return this; } return new SQL.Aliased(this, alias); } mapWith(decoder) { this.decoder = typeof decoder === "function" ? { mapFromDriverValue: decoder } : decoder; return this; } inlineParams() { this.shouldInlineParams = true; return this; } if(condition) { return condition ? this : undefined; } } class Name { constructor(value) { this.value = value; } static [entityKind] = "Name"; brand; getSQL() { return new SQL([this]); } } function isDriverValueEncoder(value) { return typeof value === "object" && value !== null && "mapToDriverValue" in value && typeof value.mapToDriverValue === "function"; } var noopDecoder = { mapFromDriverValue: (value) => value }; var noopEncoder = { mapToDriverValue: (value) => value }; var noopMapper = { ...noopDecoder, ...noopEncoder }; class Param { constructor(value, encoder = noopEncoder) { this.value = value; this.encoder = encoder; } static [entityKind] = "Param"; brand; getSQL() { return new SQL([this]); } } function sql(strings, ...params) { const queryChunks = []; if (params.length > 0 || strings.length > 0 && strings[0] !== "") { queryChunks.push(new StringChunk(strings[0])); } for (const [paramIndex, param2] of params.entries()) { queryChunks.push(param2, new StringChunk(strings[paramIndex + 1])); } return new SQL(queryChunks); } ((sql2) => { function empty() { return new SQL([]); } sql2.empty = empty; function fromList(list) { return new SQL(list); } sql2.fromList = fromList; function raw(str) { return new SQL([new StringChunk(str)]); } sql2.raw = raw; function join(chunks, separator) { const result = []; for (const [i, chunk] of chunks.entries()) { if (i > 0 && separator !== undefined) { result.push(separator); } result.push(chunk); } return new SQL(result); } sql2.join = join; function identifier(value) { return new Name(value); } sql2.identifier = identifier; function placeholder2(name2) { return new Placeholder(name2); } sql2.placeholder = placeholder2; function param2(value, encoder) { return new Param(value, encoder); } sql2.param = param2; })(sql || (sql = {})); ((SQL2) => { class Aliased { constructor(sql2, fieldAlias) { this.sql = sql2; this.fieldAlias = fieldAlias; } static [entityKind] = "SQL.Aliased"; isSelectionField = false; getSQL() { return this.sql; } clone() { return new Aliased(this.sql, this.fieldAlias); } } SQL2.Aliased = Aliased; })(SQL || (SQL = {})); class Placeholder { constructor(name2) { this.name = name2; } static [entityKind] = "Placeholder"; getSQL() { return new SQL([this]); } } function fillPlaceholders(params, values) { return params.map((p) => { if (is(p, Placeholder)) { if (!(p.name in values)) { throw new Error(`No value for placeholder "${p.name}" was provided`); } return values[p.name]; } if (is(p, Param) && is(p.value, Placeholder)) { if (!(p.value.name in values)) { throw new Error(`No value for placeholder "${p.value.name}" was provided`); } return p.encoder.mapToDriverValue(values[p.value.name]); } return p; }); } var IsDrizzleView = Symbol.for("drizzle:IsDrizzleView"); class View { static [entityKind] = "View"; [ViewBaseConfig]; [IsDrizzleView] = true; constructor({ name: name2, schema, selectedFields, query }) { this[ViewBaseConfig] = { name: name2, originalName: name2, schema, selectedFields, query, isExisting: !query, isAlias: false }; } getSQL() { return new SQL([this]); } } Column.prototype.getSQL = function() { return new SQL([this]); }; Table.prototype.getSQL = function() { return new SQL([this]); }; Subquery.prototype.getSQL = function() { return new SQL([this]); }; // ../eve/node_modules/drizzle-orm/alias.js class ColumnAliasProxyHandler { constructor(table) { this.table = table; } static [entityKind] = "ColumnAliasProxyHandler"; get(columnObj, prop) { if (prop === "table") { return this.table; } return columnObj[prop]; } } class TableAliasProxyHandler { constructor(alias, replaceOriginalName) { this.alias = alias; this.replaceOriginalName = replaceOriginalName; } static [entityKind] = "TableAliasProxyHandler"; get(target, prop) { if (prop === Table.Symbol.IsAlias) { return true; } if (prop === Table.Symbol.Name) { return this.alias; } if (this.replaceOriginalName && prop === Table.Symbol.OriginalName) { return this.alias; } if (prop === ViewBaseConfig) { return { ...target[ViewBaseConfig], name: this.alias, isAlias: true }; } if (prop === Table.Symbol.Columns) { const columns = target[Table.Symbol.Columns]; if (!columns) { return columns; } const proxiedColumns = {}; Object.keys(columns).map((key) => { proxiedColumns[key] = new Proxy(columns[key], new ColumnAliasProxyHandler(new Proxy(target, this))); }); return proxiedColumns; } const value = target[prop]; if (is(value, Column)) { return new Proxy(value, new ColumnAliasProxyHandler(new Proxy(target, this))); } return value; } } function aliasedTable(table, tableAlias) { return new Proxy(table, new TableAliasProxyHandler(tableAlias, false)); } function aliasedTableColumn(column, tableAlias) { return new Proxy(column, new ColumnAliasProxyHandler(new Proxy(column.table, new TableAliasProxyHandler(tableAlias, false)))); } function mapColumnsInAliasedSQLToAlias(query, alias) { return new SQL.Aliased(mapColumnsInSQLToAlias(query.sql, alias), query.fieldAlias); } function mapColumnsInSQLToAlias(query, alias) { return sql.join(query.queryChunks.map((c) => { if (is(c, Column)) { return aliasedTableColumn(c, alias); } if (is(c, SQL)) { return mapColumnsInSQLToAlias(c, alias); } if (is(c, SQL.Aliased)) { return mapColumnsInAliasedSQLToAlias(c, alias); } return c; })); } // ../eve/node_modules/drizzle-orm/utils.js function mapResultRow(columns, row, joinsNotNullableMap) { const nullifyMap = {}; const result = columns.reduce((result2, { path, field }, columnIndex) => { let decoder; if (is(field, Column)) { decoder = field; } else if (is(field, SQL)) { decoder = field.decoder; } else { decoder = field.sql.decoder; } let node = result2; for (const [pathChunkIndex, pathChunk] of path.entries()) { if (pathChunkIndex < path.length - 1) { if (!(pathChunk in node)) { node[pathChunk] = {}; } node = node[pathChunk]; } else { const rawValue = row[columnIndex]; const value = node[pathChunk] = rawValue === null ? null : decoder.mapFromDriverValue(rawValue); if (joinsNotNullableMap && is(field, Column) && path.length === 2) { const objectName = path[0]; if (!(objectName in nullifyMap)) { nullifyMap[objectName] = value === null ? getTableName(field.table) : false; } else if (typeof nullifyMap[objectName] === "string" && nullifyMap[objectName] !== getTableName(field.table)) { nullifyMap[objectName] = false; } } } } return result2; }, {}); if (joinsNotNullableMap && Object.keys(nullifyMap).length > 0) { for (const [objectName, tableName] of Object.entries(nullifyMap)) { if (typeof tableName === "string" && !joinsNotNullableMap[tableName]) { result[objectName] = null; } } } return result; } function orderSelectedFields(fields, pathPrefix) { return Object.entries(fields).reduce((result, [name, field]) => { if (typeof name !== "string") { return result; } const newPath = pathPrefix ? [...pathPrefix, name] : [name]; if (is(field, Column) || is(field, SQL) || is(field, SQL.Aliased)) { result.push({ path: newPath, field }); } else if (is(field, Table)) { result.push(...orderSelectedFields(field[Table.Symbol.Columns], newPath)); } else { result.push(...orderSelectedFields(field, newPath)); } return result; }, []); } function haveSameKeys(left, right) { const leftKeys = Object.keys(left); const rightKeys = Object.keys(right); if (leftKeys.length !== rightKeys.length) { return false; } for (const [index, key] of leftKeys.entries()) { if (key !== rightKeys[index]) { return false; } } return true; } function mapUpdateSet(table, values) { const entries = Object.entries(values).filter(([, value]) => value !== undefined).map(([key, value]) => { if (is(value, SQL) || is(value, Column)) { return [key, value]; } else { return [key, new Param(value, table[Table.Symbol.Columns][key])]; } }); if (entries.length === 0) { throw new Error("No values to set"); } return Object.fromEntries(entries); } function applyMixins(baseClass, extendedClasses) { for (const extendedClass of extendedClasses) { for (const name of Object.getOwnPropertyNames(extendedClass.prototype)) { if (name === "constructor") continue; Object.defineProperty(baseClass.prototype, name, Object.getOwnPropertyDescriptor(extendedClass.prototype, name) || /* @__PURE__ */ Object.create(null)); } } } function getTableColumns(table) { return table[Table.Symbol.Columns]; } function getTableLikeName(table) { return is(table, Subquery) ? table._.alias : is(table, View) ? table[ViewBaseConfig].name : is(table, SQL) ? undefined : table[Table.Symbol.IsAlias] ? table[Table.Symbol.Name] : table[Table.Symbol.BaseName]; } function getColumnNameAndConfig(a, b) { return { name: typeof a === "string" && a.length > 0 ? a : "", config: typeof a === "object" ? a : b }; } function isConfig(data) { if (typeof data !== "object" || data === null) return false; if (data.constructor.name !== "Object") return false; if ("logger" in data) { const type = typeof data["logger"]; if (type !== "boolean" && (type !== "object" || typeof data["logger"]["logQuery"] !== "function") && type !== "undefined") return false; return true; } if ("schema" in data) { const type = typeof data["schema"]; if (type !== "object" && type !== "undefined") return false; return true; } if ("casing" in data) { const type = typeof data["casing"]; if (type !== "string" && type !== "undefined") return false; return true; } if ("mode" in data) { if (data["mode"] !== "default" || data["mode"] !== "planetscale" || data["mode"] !== undefined) return false; return true; } if ("connection" in data) { const type = typeof data["connection"]; if (type !== "string" && type !== "object" && type !== "undefined") return false; return true; } if ("client" in data) { const type = typeof data["client"]; if (type !== "object" && type !== "function" && type !== "undefined") return false; return true; } if (Object.keys(data).length === 0) return true; return false; } var textDecoder = typeof TextDecoder === "undefined" ? null : new TextDecoder; // ../eve/node_modules/drizzle-orm/sqlite-core/foreign-keys.js class ForeignKeyBuilder { static [entityKind] = "SQLiteForeignKeyBuilder"; reference; _onUpdate; _onDelete; constructor(config, actions) { this.reference = () => { const { name, columns, foreignColumns } = config(); return { name, columns, foreignTable: foreignColumns[0].table, foreignColumns }; }; if (actions) { this._onUpdate = actions.onUpdate; this._onDelete = actions.onDelete; } } onUpdate(action) { this._onUpdate = action; return this; } onDelete(action) { this._onDelete = action; return this; } build(table) { return new ForeignKey(table, this); } } class ForeignKey { constructor(table, builder) { this.table = table; this.reference = builder.reference; this.onUpdate = builder._onUpdate; this.onDelete = builder._onDelete; } static [entityKind] = "SQLiteForeignKey"; reference; onUpdate; onDelete; getName() { const { name, columns, foreignColumns } = this.reference(); const columnNames = columns.map((column) => column.name); const foreignColumnNames = foreignColumns.map((column) => column.name); const chunks = [ this.table[TableName], ...columnNames, foreignColumns[0].table[TableName], ...foreignColumnNames ]; return name ?? `${chunks.join("_")}_fk`; } } // ../eve/node_modules/drizzle-orm/sqlite-core/unique-constraint.js function uniqueKeyName2(table, columns) { return `${table[TableName]}_${columns.join("_")}_unique`; } // ../eve/node_modules/drizzle-orm/sqlite-core/columns/common.js class SQLiteColumnBuilder extends ColumnBuilder { static [entityKind] = "SQLiteColumnBuilder"; foreignKeyConfigs = []; references(ref, actions = {}) { this.foreignKeyConfigs.push({ ref, actions }); return this; } unique(name) { this.config.isUnique = true; this.config.uniqueName = name; return this; } generatedAlwaysAs(as, config) { this.config.generated = { as, type: "always", mode: config?.mode ?? "virtual" }; return this; } buildForeignKeys(column, table) { return this.foreignKeyConfigs.map(({ ref, actions }) => { return ((ref2, actions2) => { const builder = new ForeignKeyBuilder(() => { const foreignColumn = ref2(); return { columns: [column], foreignColumns: [foreignColumn] }; }); if (actions2.onUpdate) { builder.onUpdate(actions2.onUpdate); } if (actions2.onDelete) { builder.onDelete(actions2.onDelete); } return builder.build(table); })(ref, actions); }); } } class SQLiteColumn extends Column { constructor(table, config) { if (!config.uniqueName) { config.uniqueName = uniqueKeyName2(table, [config.name]); } super(table, config); this.table = table; } static [entityKind] = "SQLiteColumn"; } // ../eve/node_modules/drizzle-orm/sqlite-core/columns/blob.js class SQLiteBigIntBuilder extends SQLiteColumnBuilder { static [entityKind] = "SQLiteBigIntBuilder"; constructor(name) { super(name, "bigint", "SQLiteBigInt"); } build(table) { return new SQLiteBigInt(table, this.config); } } class SQLiteBigInt extends SQLiteColumn { static [entityKind] = "SQLiteBigInt"; getSQLType() { return "blob"; } mapFromDriverValue(value) { if (typeof Buffer !== "undefined" && Buffer.from) { const buf = Buffer.isBuffer(value) ? value : value instanceof ArrayBuffer ? Buffer.from(value) : value.buffer ? Buffer.from(value.buffer, value.byteOffset, value.byteLength) : Buffer.from(value); return BigInt(buf.toString("utf8")); } return BigInt(textDecoder.decode(value)); } mapToDriverValue(value) { return Buffer.from(value.toString()); } } class SQLiteBlobJsonBuilder extends SQLiteColumnBuilder { static [entityKind] = "SQLiteBlobJsonBuilder"; constructor(name) { super(name, "json", "SQLiteBlobJson"); } build(table) { return new SQLiteBlobJson(table, this.config); } } class SQLiteBlobJson extends SQLiteColumn { static [entityKind] = "SQLiteBlobJson"; getSQLType() { return "blob"; } mapFromDriverValue(value) { if (typeof Buffer !== "undefined" && Buffer.from) { const buf = Buffer.isBuffer(value) ? value : value instanceof ArrayBuffer ? Buffer.from(value) : value.buffer ? Buffer.from(value.buffer, value.byteOffset, value.byteLength) : Buffer.from(value); return JSON.parse(buf.toString("utf8")); } return JSON.parse(textDecoder.decode(value)); } mapToDriverValue(value) { return Buffer.from(JSON.stringify(value)); } } class SQLiteBlobBufferBuilder extends SQLiteColumnBuilder { static [entityKind] = "SQLiteBlobBufferBuilder"; constructor(name) { super(name, "buffer", "SQLiteBlobBuffer"); } build(table) { return new SQLiteBlobBuffer(table, this.config); } } class SQLiteBlobBuffer extends SQLiteColumn { static [entityKind] = "SQLiteBlobBuffer"; mapFromDriverValue(value) { if (Buffer.isBuffer(value)) { return value; } return Buffer.from(value); } getSQLType() { return "blob"; } } function blob(a, b) { const { name, config } = getColumnNameAndConfig(a, b); if (config?.mode === "json") { return new SQLiteBlobJsonBuilder(name); } if (config?.mode === "bigint") { return new SQLiteBigIntBuilder(name); } return new SQLiteBlobBufferBuilder(name); } // ../eve/node_modules/drizzle-orm/sqlite-core/columns/custom.js class SQLiteCustomColumnBuilder extends SQLiteColumnBuilder { static [entityKind] = "SQLiteCustomColumnBuilder"; constructor(name, fieldConfig, customTypeParams) { super(name, "custom", "SQLiteCustomColumn"); this.config.fieldConfig = fieldConfig; this.config.customTypeParams = customTypeParams; } build(table) { return new SQLiteCustomColumn(table, this.config); } } class SQLiteCustomColumn extends SQLiteColumn { static [entityKind] = "SQLiteCustomColumn"; sqlName; mapTo; mapFrom; constructor(table, config) { super(table, config); this.sqlName = config.customTypeParams.dataType(config.fieldConfig); this.mapTo = config.customTypeParams.toDriver; this.mapFrom = config.customTypeParams.fromDriver; } getSQLType() { return this.sqlName; } mapFromDriverValue(value) { return typeof this.mapFrom === "function" ? this.mapFrom(value) : value; } mapToDriverValue(value) { return typeof this.mapTo === "function" ? this.mapTo(value) : value; } } function customType(customTypeParams) { return (a, b) => { const { name, config } = getColumnNameAndConfig(a, b); return new SQLiteCustomColumnBuilder(name, config, customTypeParams); }; } // ../eve/node_modules/drizzle-orm/sqlite-core/columns/integer.js class SQLiteBaseIntegerBuilder extends SQLiteColumnBuilder { static [entityKind] = "SQLiteBaseIntegerBuilder"; constructor(name, dataType, columnType) { super(name, dataType, columnType); this.config.autoIncrement = false; } primaryKey(config) { if (config?.autoIncrement) { this.config.autoIncrement = true; } this.config.hasDefault = true; return super.primaryKey(); } } class SQLiteBaseInteger extends SQLiteColumn { static [entityKind] = "SQLiteBaseInteger"; autoIncrement = this.config.autoIncrement; getSQLType() { return "integer"; } } class SQLiteIntegerBuilder extends SQLiteBaseIntegerBuilder { static [entityKind] = "SQLiteIntegerBuilder"; constructor(name) { super(name, "number", "SQLiteInteger"); } build(table) { return new SQLiteInteger(table, this.config); } } class SQLiteInteger extends SQLiteBaseInteger { static [entityKind] = "SQLiteInteger"; } class SQLiteTimestampBuilder extends SQLiteBaseIntegerBuilder { static [entityKind] = "SQLiteTimestampBuilder"; constructor(name, mode) { super(name, "date", "SQLiteTimestamp"); this.config.mode = mode; } defaultNow() { return this.default(sql`(cast((julianday('now') - 2440587.5)*86400000 as integer))`); } build(table) { return new SQLiteTimestamp(table, this.config); } } class SQLiteTimestamp extends SQLiteBaseInteger { static [entityKind] = "SQLiteTimestamp"; mode = this.config.mode; mapFromDriverValue(value) { if (this.config.mode === "timestamp") { return new Date(value * 1000); } return new Date(value); } mapToDriverValue(value) { const unix = value.getTime(); if (this.config.mode === "timestamp") { return Math.floor(unix / 1000); } return unix; } } class SQLiteBooleanBuilder extends SQLiteBaseIntegerBuilder { static [entityKind] = "SQLiteBooleanBuilder"; constructor(name, mode) { super(name, "boolean", "SQLiteBoolean"); this.config.mode = mode; } build(table) { return new SQLiteBoolean(table, this.config); } } class SQLiteBoolean extends SQLiteBaseInteger { static [entityKind] = "SQLiteBoolean"; mode = this.config.mode; mapFromDriverValue(value) { return Number(value) === 1; } mapToDriverValue(value) { return value ? 1 : 0; } } function integer(a, b) { const { name, config } = getColumnNameAndConfig(a, b); if (config?.mode === "timestamp" || config?.mode === "timestamp_ms") { return new SQLiteTimestampBuilder(name, config.mode); } if (config?.mode === "boolean") { return new SQLiteBooleanBuilder(name, config.mode); } return new SQLiteIntegerBuilder(name); } // ../eve/node_modules/drizzle-orm/sqlite-core/columns/numeric.js class SQLiteNumericBuilder extends SQLiteColumnBuilder { static [entityKind] = "SQLiteNumericBuilder"; constructor(name) { super(name, "string", "SQLiteNumeric"); } build(table) { return new SQLiteNumeric(table, this.config); } } class SQLiteNumeric extends SQLiteColumn { static [entityKind] = "SQLiteNumeric"; mapFromDriverValue(value) { if (typeof value === "string") return value; return String(value); } getSQLType() { return "numeric"; } } class SQLiteNumericNumberBuilder extends SQLiteColumnBuilder { static [entityKind] = "SQLiteNumericNumberBuilder"; constructor(name) { super(name, "number", "SQLiteNumericNumber"); } build(table) { return new SQLiteNumericNumber(table, this.config); } } class SQLiteNumericNumber extends SQLiteColumn { static [entityKind] = "SQLiteNumericNumber"; mapFromDriverValue(value) { if (typeof value === "number") return value; return Number(value); } mapToDriverValue = String; getSQLType() { return "numeric"; } } class SQLiteNumericBigIntBuilder extends SQLiteColumnBuilder { static [entityKind] = "SQLiteNumericBigIntBuilder"; constructor(name) { super(name, "bigint", "SQLiteNumericBigInt"); } build(table) { return new SQLiteNumericBigInt(table, this.config); } } class SQLiteNumericBigInt extends SQLiteColumn { static [entityKind] = "SQLiteNumericBigInt"; mapFromDriverValue = BigInt; mapToDriverValue = String; getSQLType() { return "numeric"; } } function numeric(a, b) { const { name, config } = getColumnNameAndConfig(a, b); const mode = config?.mode; return mode === "number" ? new SQLiteNumericNumberBuilder(name) : mode === "bigint" ? new SQLiteNumericBigIntBuilder(name) : new SQLiteNumericBuilder(name); } // ../eve/node_modules/drizzle-orm/sqlite-core/columns/real.js class SQLiteRealBuilder extends SQLiteColumnBuilder { static [entityKind] = "SQLiteRealBuilder"; constructor(name) { super(name, "number", "SQLiteReal"); } build(table) { return new SQLiteReal(table, this.config); } } class SQLiteReal extends SQLiteColumn { static [entityKind] = "SQLiteReal"; getSQLType() { return "real"; } } function real(name) { return new SQLiteRealBuilder(name ?? ""); } // ../eve/node_modules/drizzle-orm/sqlite-core/columns/text.js class SQLiteTextBuilder extends SQLiteColumnBuilder { static [entityKind] = "SQLiteTextBuilder"; constructor(name, config) { super(name, "string", "SQLiteText"); this.config.enumValues = config.enum; this.config.length = config.length; } build(table) { return new SQLiteText(table, this.config); } } class SQLiteText extends SQLiteColumn { static [entityKind] = "SQLiteText"; enumValues = this.config.enumValues; length = this.config.length; constructor(table, config) { super(table, config); } getSQLType() { return `text${this.config.length ? `(${this.config.length})` : ""}`; } } class SQLiteTextJsonBuilder extends SQLiteColumnBuilder { static [entityKind] = "SQLiteTextJsonBuilder"; constructor(name) { super(name, "json", "SQLiteTextJson"); } build(table) { return new SQLiteTextJson(table, this.config); } } class SQLiteTextJson extends SQLiteColumn { static [entityKind] = "SQLiteTextJson"; getSQLType() { return "text"; } mapFromDriverValue(value) { return JSON.parse(value); } mapToDriverValue(value) { return JSON.stringify(value); } } function text(a, b = {}) { const { name, config } = getColumnNameAndConfig(a, b); if (config.mode === "json") { return new SQLiteTextJsonBuilder(name); } return new SQLiteTextBuilder(name, config); } // ../eve/node_modules/drizzle-orm/selection-proxy.js class SelectionProxyHandler { static [entityKind] = "SelectionProxyHandler"; config; constructor(config) { this.config = { ...config }; } get(subquery, prop) { if (prop === "_") { return { ...subquery["_"], selectedFields: new Proxy(subquery._.selectedFields, this) }; } if (prop === ViewBaseConfig) { return { ...subquery[ViewBaseConfig], selectedFields: new Proxy(subquery[ViewBaseConfig].selectedFields, this) }; } if (typeof prop === "symbol") { return subquery[prop]; } const columns = is(subquery, Subquery) ? subquery._.selectedFields : is(subquery, View) ? subquery[ViewBaseConfig].selectedFields : subquery; const value = columns[prop]; if (is(value, SQL.Aliased)) { if (this.config.sqlAliasedBehavior === "sql" && !value.isSelectionField) { return value.sql; } const newValue = value.clone(); newValue.isSelectionField = true; return newValue; } if (is(value, SQL)) { if (this.config.sqlBehavior === "sql") { return value; } throw new Error(`You tried to reference "${prop}" field from a subquery, which is a raw SQL field, but it doesn't have an alias declared. Please add an alias to the field using ".as('alias')" method.`); } if (is(value, Column)) { if (this.config.alias) { return new Proxy(value, new ColumnAliasProxyHandler(new Proxy(value.table, new TableAliasProxyHandler(this.config.alias, this.config.replaceOriginalName ?? false)))); } return value; } if (typeof value !== "object" || value === null) { return value; } return new Proxy(value, new SelectionProxyHandler(this.config)); } } // ../eve/node_modules/drizzle-orm/query-promise.js class QueryPromise { static [entityKind] = "QueryPromise"; [Symbol.toStringTag] = "QueryPromise"; catch(onRejected) { return this.then(undefined, onRejected); } finally(onFinally) { return this.then((value) => { onFinally?.(); return value; }, (reason) => { onFinally?.(); throw reason; }); } then(onFulfilled, onRejected) { return this.execute().then(onFulfilled, onRejected); } } // ../eve/node_modules/drizzle-orm/sqlite-core/columns/all.js function getSQLiteColumnBuilders() { return { blob, customType, integer, numeric, real, text }; } // ../eve/node_modules/drizzle-orm/sqlite-core/table.js var InlineForeignKeys = Symbol.for("drizzle:SQLiteInlineForeignKeys"); class SQLiteTable extends Table { static [entityKind] = "SQLiteTable"; static Symbol = Object.assign({}, Table.Symbol, { InlineForeignKeys }); [Table.Symbol.Columns]; [InlineForeignKeys] = []; [Table.Symbol.ExtraConfigBuilder] = undefined; } function sqliteTableBase(name, columns, extraConfig, schema, baseName = name) { const rawTable = new SQLiteTable(name, schema, baseName); const parsedColumns = typeof columns === "function" ? columns(getSQLiteColumnBuilders()) : columns; const builtColumns = Object.fromEntries(Object.entries(parsedColumns).map(([name2, colBuilderBase]) => { const colBuilder = colBuilderBase; colBuilder.setName(name2); const column = colBuilder.build(rawTable); rawTable[InlineForeignKeys].push(...colBuilder.buildForeignKeys(column, rawTable)); return [name2, column]; })); const table = Object.assign(rawTable, builtColumns); table[Table.Symbol.Columns] = builtColumns; table[Table.Symbol.ExtraConfigColumns] = builtColumns; if (extraConfig) { table[SQLiteTable.Symbol.ExtraConfigBuilder] = extraConfig; } return table; } var sqliteTable = (name, columns, extraConfig) => { return sqliteTableBase(name, columns, extraConfig); }; // ../eve/node_modules/drizzle-orm/sqlite-core/indexes.js class IndexBuilderOn { constructor(name, unique) { this.name = name; this.unique = unique; } static [entityKind] = "SQLiteIndexBuilderOn"; on(...columns) { return new IndexBuilder(this.name, columns, this.unique); } } class IndexBuilder { static [entityKind] = "SQLiteIndexBuilder"; config; constructor(name, columns, unique) { this.config = { name, columns, unique, where: undefined }; } where(condition) { this.config.where = condition; return this; } build(table) { return new Index(this.config, table); } } class Index { static [entityKind] = "SQLiteIndex"; config; constructor(config, table) { this.config = { ...config, table }; } } function index(name) { return new IndexBuilderOn(name, false); } // ../eve/node_modules/drizzle-orm/sqlite-core/utils.js function extractUsedTable(table) { if (is(table, SQLiteTable)) { return [`${table[Table.Symbol.BaseName]}`]; } if (is(table, Subquery)) { return table._.usedTables ?? []; } if (is(table, SQL)) { return table.usedTables ?? []; } return []; } // ../eve/node_modules/drizzle-orm/sqlite-core/query-builders/delete.js class SQLiteDeleteBase extends QueryPromise { constructor(table, session, dialect, withList) { super(); this.table = table; this.session = session; this.dialect = dialect; this.config = { table, withList }; } static [entityKind] = "SQLiteDelete"; config; where(where) { this.config.where = where; return this; } orderBy(...columns) { if (typeof columns[0] === "function") { const orderBy = columns[0](new Proxy(this.config.table[Table.Symbol.Columns], new SelectionProxyHandler({ sqlAliasedBehavior: "alias", sqlBehavior: "sql" }))); const orderByArray = Array.isArray(orderBy) ? orderBy : [orderBy]; this.config.orderBy = orderByArray; } else { const orderByArray = columns; this.config.orderBy = orderByArray; } return this; } limit(limit) { this.config.limit = limit; return this; } returning(fields = this.table[SQLiteTable.Symbol.Columns]) { this.config.returning = orderSelectedFields(fields); return this; } getSQL() { return this.dialect.buildDeleteQuery(this.config); } toSQL() { const { typings: _typings, ...rest } = this.dialect.sqlToQuery(this.getSQL()); return rest; } _prepare(isOneTimeQuery = true) { return this.session[isOneTimeQuery ? "prepareOneTimeQuery" : "prepareQuery"](this.dialect.sqlToQuery(this.getSQL()), this.config.returning, this.config.returning ? "all" : "run", true, undefined, { type: "delete", tables: extractUsedTable(this.config.table) }); } prepare() { return this._prepare(false); } run = (placeholderValues) => { return this._prepare().run(placeholderValues); }; all = (placeholderValues) => { return this._prepare().all(placeholderValues); }; get = (placeholderValues) => { return this._prepare().get(placeholderValues); }; values = (placeholderValues) => { return this._prepare().values(placeholderValues); }; async execute(placeholderValues) { return this._prepare().execute(placeholderValues); } $dynamic() { return this; } } // ../eve/node_modules/drizzle-orm/casing.js function toSnakeCase(input) { const words = input.replace(/['\u2019]/g, "").match(/[\da-z]+|[A-Z]+(?![a-z])|[A-Z][\da-z]+/g) ?? []; return words.map((word) => word.toLowerCase()).join("_"); } function toCamelCase(input) { const words = input.replace(/['\u2019]/g, "").match(/[\da-z]+|[A-Z]+(?![a-z])|[A-Z][\da-z]+/g) ?? []; return words.reduce((acc, word, i) => { const formattedWord = i === 0 ? word.toLowerCase() : `${word[0].toUpperCase()}${word.slice(1)}`; return acc + formattedWord; }, ""); } function noopCase(input) { return input; } class CasingCache { static [entityKind] = "CasingCache"; cache = {}; cachedTables = {}; convert; constructor(casing) { this.convert = casing === "snake_case" ? toSnakeCase : casing === "camelCase" ? toCamelCase : noopCase; } getColumnCasing(column) { if (!column.keyAsName) return column.name; const schema = column.table[Table.Symbol.Schema] ?? "public"; const tableName = column.table[Table.Symbol.OriginalName]; const key = `${schema}.${tableName}.${column.name}`; if (!this.cache[key]) { this.cacheTable(column.table); } return this.cache[key]; } cacheTable(table) { const schema = table[Table.Symbol.Schema] ?? "public"; const tableName = table[Table.Symbol.OriginalName]; const tableKey = `${schema}.${tableName}`; if (!this.cachedTables[tableKey]) { for (const column of Object.values(table[Table.Symbol.Columns])) { const columnKey = `${tableKey}.${column.name}`; this.cache[columnKey] = this.convert(column.name); } this.cachedTables[tableKey] = true; } } clearCache() { this.cache = {}; this.cachedTables = {}; } } // ../eve/node_modules/drizzle-orm/errors.js class DrizzleError extends Error { static [entityKind] = "DrizzleError"; constructor({ message, cause }) { super(message); this.name = "DrizzleError"; this.cause = cause; } } class DrizzleQueryError extends Error { constructor(query, params, cause) { super(`Failed query: ${query} params: ${params}`); this.query = query; this.params = params; this.cause = cause; Error.captureStackTrace(this, DrizzleQueryError); if (cause) this.cause = cause; } } class TransactionRollbackError extends DrizzleError { static [entityKind] = "TransactionRollbackError"; constructor() { super({ message: "Rollback" }); } } // ../eve/node_modules/drizzle-orm/pg-core/table.js var InlineForeignKeys2 = Symbol.for("drizzle:PgInlineForeignKeys"); var EnableRLS = Symbol.for("drizzle:EnableRLS"); class PgTable extends Table { static [entityKind] = "PgTable"; static Symbol = Object.assign({}, Table.Symbol, { InlineForeignKeys: InlineForeignKeys2, EnableRLS }); [InlineForeignKeys2] = []; [EnableRLS] = false; [Table.Symbol.ExtraConfigBuilder] = undefined; [Table.Symbol.ExtraConfigColumns] = {}; } // ../eve/node_modules/drizzle-orm/pg-core/primary-keys.js class PrimaryKeyBuilder { static [entityKind] = "PgPrimaryKeyBuilder"; columns; name; constructor(columns, name) { this.columns = columns; this.name = name; } build(table) { return new PrimaryKey(table, this.columns, this.name); } } class PrimaryKey { constructor(table, columns, name) { this.table = table; this.columns = columns; this.name = name; } static [entityKind] = "PgPrimaryKey"; columns; name; getName() { return this.name ?? `${this.table[PgTable.Symbol.Name]}_${this.columns.map((column) => column.name).join("_")}_pk`; } } // ../eve/node_modules/drizzle-orm/sql/expressions/conditions.js function bindIfParam(value, column) { if (isDriverValueEncoder(column) && !isSQLWrapper(value) && !is(value, Param) && !is(value, Placeholder) && !is(value, Column) && !is(value, Table) && !is(value, View)) { return new Param(value, column); } return value; } var eq = (left, right) => { return sql`${left} = ${bindIfParam(right, left)}`; }; var ne = (left, right) => { return sql`${left} <> ${bindIfParam(right, left)}`; }; function and(...unfilteredConditions) { const conditions = unfilteredConditions.filter((c) => c !== undefined); if (conditions.length === 0) { return; } if (conditions.length === 1) { return new SQL(conditions); } return new SQL([ new StringChunk("("), sql.join(conditions, new StringChunk(" and ")), new StringChunk(")") ]); } function or(...unfilteredConditions) { const conditions = unfilteredConditions.filter((c) => c !== undefined); if (conditions.length === 0) { return; } if (conditions.length === 1) { return new SQL(conditions); } return new SQL([ new StringChunk("("), sql.join(conditions, new StringChunk(" or ")), new StringChunk(")") ]); } function not(condition) { return sql`not ${condition}`; } var gt = (left, right) => { return sql`${left} > ${bindIfParam(right, left)}`; }; var gte = (left, right) => { return sql`${left} >= ${bindIfParam(right, left)}`; }; var lt = (left, right) => { return sql`${left} < ${bindIfParam(right, left)}`; }; var lte = (left, right) => { return sql`${left} <= ${bindIfParam(right, left)}`; }; function inArray(column, values) { if (Array.isArray(values)) { if (values.length === 0) { return sql`false`; } return sql`${column} in ${values.map((v) => bindIfParam(v, column))}`; } return sql`${column} in ${bindIfParam(values, column)}`; } function notInArray(column, values) { if (Array.isArray(values)) { if (values.length === 0) { return sql`true`; } return sql`${column} not in ${values.map((v) => bindIfParam(v, column))}`; } return sql`${column} not in ${bindIfParam(values, column)}`; } function isNull(value) { return sql`${value} is null`; } function isNotNull(value) { return sql`${value} is not null`; } function exists(subquery) { return sql`exists ${subquery}`; } function notExists(subquery) { return sql`not exists ${subquery}`; } function between(column, min, max) { return sql`${column} between ${bindIfParam(min, column)} and ${bindIfParam(max, column)}`; } function notBetween(column, min, max) { return sql`${column} not between ${bindIfParam(min, column)} and ${bindIfParam(max, column)}`; } function like(column, value) { return sql`${column} like ${value}`; } function notLike(column, value) { return sql`${column} not like ${value}`; } function ilike(column, value) { return sql`${column} ilike ${value}`; } function notIlike(column, value) { return sql`${column} not ilike ${value}`; } // ../eve/node_modules/drizzle-orm/sql/expressions/select.js function asc(column) { return sql`${column} asc`; } function desc(column) { return sql`${column} desc`; } // ../eve/node_modules/drizzle-orm/relations.js class Relation { constructor(sourceTable, referencedTable, relationName) { this.sourceTable = sourceTable; this.referencedTable = referencedTable; this.relationName = relationName; this.referencedTableName = referencedTable[Table.Symbol.Name]; } static [entityKind] = "Relation"; referencedTableName; fieldName; } class Relations { constructor(table, config) { this.table = table; this.config = config; } static [entityKind] = "Relations"; } class One extends Relation { constructor(sourceTable, referencedTable, config, isNullable) { super(sourceTable, referencedTable, config?.relationName); this.config = config; this.isNullable = isNullable; } static [entityKind] = "One"; withFieldName(fieldName) { const relation = new One(this.sourceTable, this.referencedTable, this.config, this.isNullable); relation.fieldName = fieldName; return relation; } } class Many extends Relation { constructor(sourceTable, referencedTable, config) { super(sourceTable, referencedTable, config?.relationName); this.config = config; } static [entityKind] = "Many"; withFieldName(fieldName) { const relation = new Many(this.sourceTable, this.referencedTable, this.config); relation.fieldName = fieldName; return relation; } } function getOperators() { return { and, between, eq, exists, gt, gte, ilike, inArray, isNull, isNotNull, like, lt, lte, ne, not, notBetween, notExists, notLike, notIlike, notInArray, or, sql }; } function getOrderByOperators() { return { sql, asc, desc }; } function extractTablesRelationalConfig(schema, configHelpers) { if (Object.keys(schema).length === 1 && "default" in schema && !is(schema["default"], Table)) { schema = schema["default"]; } const tableNamesMap = {}; const relationsBuffer = {}; const tablesConfig = {}; for (const [key, value] of Object.entries(schema)) { if (is(value, Table)) { const dbName = getTableUniqueName(value); const bufferedRelations = relationsBuffer[dbName]; tableNamesMap[dbName] = key; tablesConfig[key] = { tsName: key, dbName: value[Table.Symbol.Name], schema: value[Table.Symbol.Schema], columns: value[Table.Symbol.Columns], relations: bufferedRelations?.relations ?? {}, primaryKey: bufferedRelations?.primaryKey ?? [] }; for (const column of Object.values(value[Table.Symbol.Columns])) { if (column.primary) { tablesConfig[key].primaryKey.push(column); } } const extraConfig = value[Table.Symbol.ExtraConfigBuilder]?.(value[Table.Symbol.ExtraConfigColumns]); if (extraConfig) { for (const configEntry of Object.values(extraConfig)) { if (is(configEntry, PrimaryKeyBuilder)) { tablesConfig[key].primaryKey.push(...configEntry.columns); } } } } else if (is(value, Relations)) { const dbName = getTableUniqueName(value.table); const tableName = tableNamesMap[dbName]; const relations2 = value.config(configHelpers(value.table)); let primaryKey; for (const [relationName, relation] of Object.entries(relations2)) { if (tableName) { const tableConfig = tablesConfig[tableName]; tableConfig.relations[relationName] = relation; if (primaryKey) { tableConfig.primaryKey.push(...primaryKey); } } else { if (!(dbName in relationsBuffer)) { relationsBuffer[dbName] = { relations: {}, primaryKey }; } relationsBuffer[dbName].relations[relationName] = relation; } } } } return { tables: tablesConfig, tableNamesMap }; } function relations(table, relations2) { return new Relations(table, (helpers) => Object.fromEntries(Object.entries(relations2(helpers)).map(([key, value]) => [ key, value.withFieldName(key) ]))); } function createOne(sourceTable) { return function one(table, config) { return new One(sourceTable, table, config, config?.fields.reduce((res, f) => res && f.notNull, true) ?? false); }; } function createMany(sourceTable) { return function many(referencedTable, config) { return new Many(sourceTable, referencedTable, config); }; } function normalizeRelation(schema, tableNamesMap, relation) { if (is(relation, One) && relation.config) { return { fields: relation.config.fields, references: relation.config.references }; } const referencedTableTsName = tableNamesMap[getTableUniqueName(relation.referencedTable)]; if (!referencedTableTsName) { throw new Error(`Table "${relation.referencedTable[Table.Symbol.Name]}" not found in schema`); } const referencedTableConfig = schema[referencedTableTsName]; if (!referencedTableConfig) { throw new Error(`Table "${referencedTableTsName}" not found in schema`); } const sourceTable = relation.sourceTable; const sourceTableTsName = tableNamesMap[getTableUniqueName(sourceTable)]; if (!sourceTableTsName) { throw new Error(`Table "${sourceTable[Table.Symbol.Name]}" not found in schema`); } const reverseRelations = []; for (const referencedTableRelation of Object.values(referencedTableConfig.relations)) { if (relation.relationName && relation !== referencedTableRelation && referencedTableRelation.relationName === relation.relationName || !relation.relationName && referencedTableRelation.referencedTable === relation.sourceTable) { reverseRelations.push(referencedTableRelation); } } if (reverseRelations.length > 1) { throw relation.relationName ? new Error(`There are multiple relations with name "${relation.relationName}" in table "${referencedTableTsName}"`) : new Error(`There are multiple relations between "${referencedTableTsName}" and "${relation.sourceTable[Table.Symbol.Name]}". Please specify relation name`); } if (reverseRelations[0] && is(reverseRelations[0], One) && reverseRelations[0].config) { return { fields: reverseRelations[0].config.references, references: reverseRelations[0].config.fields }; } throw new Error(`There is not enough information to infer relation "${sourceTableTsName}.${relation.fieldName}"`); } function createTableRelationsHelpers(sourceTable) { return { one: createOne(sourceTable), many: createMany(sourceTable) }; } function mapRelationalRow(tablesConfig, tableConfig, row, buildQueryResultSelection, mapColumnValue = (value) => value) { const result = {}; for (const [ selectionItemIndex, selectionItem ] of buildQueryResultSelection.entries()) { if (selectionItem.isJson) { const relation = tableConfig.relations[selectionItem.tsKey]; const rawSubRows = row[selectionItemIndex]; const subRows = typeof rawSubRows === "string" ? JSON.parse(rawSubRows) : rawSubRows; result[selectionItem.tsKey] = is(relation, One) ? subRows && mapRelationalRow(tablesConfig, tablesConfig[selectionItem.relationTableTsKey], subRows, selectionItem.selection, mapColumnValue) : subRows.map((subRow) => mapRelationalRow(tablesConfig, tablesConfig[selectionItem.relationTableTsKey], subRow, selectionItem.selection, mapColumnValue)); } else { const value = mapColumnValue(row[selectionItemIndex]); const field = selectionItem.field; let decoder; if (is(field, Column)) { decoder = field; } else if (is(field, SQL)) { decoder = field.decoder; } else { decoder = field.sql.decoder; } result[selectionItem.tsKey] = value === null ? null : decoder.mapFromDriverValue(value); } } return result; } // ../eve/node_modules/drizzle-orm/sqlite-core/view-base.js class SQLiteViewBase extends View { static [entityKind] = "SQLiteViewBase"; } // ../eve/node_modules/drizzle-orm/sqlite-core/dialect.js class SQLiteDialect { static [entityKind] = "SQLiteDialect"; casing; constructor(config) { this.casing = new CasingCache(config?.casing); } escapeName(name) { return `"${name}"`; } escapeParam(_num) { return "?"; } escapeString(str) { return `'${str.replace(/'/g, "''")}'`; } buildWithCTE(queries) { if (!queries?.length) return; const withSqlChunks = [sql`with `]; for (const [i, w] of queries.entries()) { withSqlChunks.push(sql`${sql.identifier(w._.alias)} as (${w._.sql})`); if (i < queries.length - 1) { withSqlChunks.push(sql`, `); } } withSqlChunks.push(sql` `); return sql.join(withSqlChunks); } buildDeleteQuery({ table, where, returning, withList, limit, orderBy }) { const withSql = this.buildWithCTE(withList); const returningSql = returning ? sql` returning ${this.buildSelection(returning, { isSingleTable: true })}` : undefined; const whereSql = where ? sql` where ${where}` : undefined; const orderBySql = this.buildOrderBy(orderBy); const limitSql = this.buildLimit(limit); return sql`${withSql}delete from ${table}${whereSql}${returningSql}${orderBySql}${limitSql}`; } buildUpdateSet(table, set) { const tableColumns = table[Table.Symbol.Columns]; const columnNames = Object.keys(tableColumns).filter((colName) => set[colName] !== undefined || tableColumns[colName]?.onUpdateFn !== undefined); const setSize = columnNames.length; return sql.join(columnNames.flatMap((colName, i) => { const col = tableColumns[colName]; const value = set[colName] ?? sql.param(col.onUpdateFn(), col); const res = sql`${sql.identifier(this.casing.getColumnCasing(col))} = ${value}`; if (i < setSize - 1) { return [res, sql.raw(", ")]; } return [res]; })); } buildUpdateQuery({ table, set, where, returning, withList, joins, from, limit, orderBy }) { const withSql = this.buildWithCTE(withList); const setSql = this.buildUpdateSet(table, set); const fromSql = from && sql.join([sql.raw(" from "), this.buildFromTable(from)]); const joinsSql = this.buildJoins(joins); const returningSql = returning ? sql` returning ${this.buildSelection(returning, { isSingleTable: true })}` : undefined; const whereSql = where ? sql` where ${where}` : undefined; const orderBySql = this.buildOrderBy(orderBy); const limitSql = this.buildLimit(limit); return sql`${withSql}update ${table} set ${setSql}${fromSql}${joinsSql}${whereSql}${returningSql}${orderBySql}${limitSql}`; } buildSelection(fields, { isSingleTable = false } = {}) { const columnsLen = fields.length; const chunks = fields.flatMap(({ field }, i) => { const chunk = []; if (is(field, SQL.Aliased) && field.isSelectionField) { chunk.push(sql.identifier(field.fieldAlias)); } else if (is(field, SQL.Aliased) || is(field, SQL)) { const query = is(field, SQL.Aliased) ? field.sql : field; if (isSingleTable) { chunk.push(new SQL(query.queryChunks.map((c) => { if (is(c, Column)) { return sql.identifier(this.casing.getColumnCasing(c)); } return c; }))); } else { chunk.push(query); } if (is(field, SQL.Aliased)) { chunk.push(sql` as ${sql.identifier(field.fieldAlias)}`); } } else if (is(field, Column)) { const tableName = field.table[Table.Symbol.Name]; if (field.columnType === "SQLiteNumericBigInt") { if (isSingleTable) { chunk.push(sql`cast(${sql.identifier(this.casing.getColumnCasing(field))} as text)`); } else { chunk.push(sql`cast(${sql.identifier(tableName)}.${sql.identifier(this.casing.getColumnCasing(field))} as text)`); } } else { if (isSingleTable) { chunk.push(sql.identifier(this.casing.getColumnCasing(field))); } else { chunk.push(sql`${sql.identifier(tableName)}.${sql.identifier(this.casing.getColumnCasing(field))}`); } } } if (i < columnsLen - 1) { chunk.push(sql`, `); } return chunk; }); return sql.join(chunks); } buildJoins(joins) { if (!joins || joins.length === 0) { return; } const joinsArray = []; if (joins) { for (const [index2, joinMeta] of joins.entries()) { if (index2 === 0) { joinsArray.push(sql` `); } const table = joinMeta.table; const onSql = joinMeta.on ? sql` on ${joinMeta.on}` : undefined; if (is(table, SQLiteTable)) { const tableName = table[SQLiteTable.Symbol.Name]; const tableSchema = table[SQLiteTable.Symbol.Schema]; const origTableName = table[SQLiteTable.Symbol.OriginalName]; const alias = tableName === origTableName ? undefined : joinMeta.alias; joinsArray.push(sql`${sql.raw(joinMeta.joinType)} join ${tableSchema ? sql`${sql.identifier(tableSchema)}.` : undefined}${sql.identifier(origTableName)}${alias && sql` ${sql.identifier(alias)}`}${onSql}`); } else { joinsArray.push(sql`${sql.raw(joinMeta.joinType)} join ${table}${onSql}`); } if (index2 < joins.length - 1) { joinsArray.push(sql` `); } } } return sql.join(joinsArray); } buildLimit(limit) { return typeof limit === "object" || typeof limit === "number" && limit >= 0 ? sql` limit ${limit}` : undefined; } buildOrderBy(orderBy) { const orderByList = []; if (orderBy) { for (const [index2, orderByValue] of orderBy.entries()) { orderByList.push(orderByValue); if (index2 < orderBy.length - 1) { orderByList.push(sql`, `); } } } return orderByList.length > 0 ? sql` order by ${sql.join(orderByList)}` : undefined; } buildFromTable(table) { if (is(table, Table) && table[Table.Symbol.IsAlias]) { return sql`${sql`${sql.identifier(table[Table.Symbol.Schema] ?? "")}.`.if(table[Table.Symbol.Schema])}${sql.identifier(table[Table.Symbol.OriginalName])} ${sql.identifier(table[Table.Symbol.Name])}`; } return table; } buildSelectQuery({ withList, fields, fieldsFlat, where, having, table, joins, orderBy, groupBy, limit, offset, distinct, setOperators }) { const fieldsList = fieldsFlat ?? orderSelectedFields(fields); for (const f of fieldsList) { if (is(f.field, Column) && getTableName(f.field.table) !== (is(table, Subquery) ? table._.alias : is(table, SQLiteViewBase) ? table[ViewBaseConfig].name : is(table, SQL) ? undefined : getTableName(table)) && !((table2) => joins?.some(({ alias }) => alias === (table2[Table.Symbol.IsAlias] ? getTableName(table2) : table2[Table.Symbol.BaseName])))(f.field.table)) { const tableName = getTableName(f.field.table); throw new Error(`Your "${f.path.join("->")}" field references a column "${tableName}"."${f.field.name}", but the table "${tableName}" is not part of the query! Did you forget to join it?`); } } const isSingleTable = !joins || joins.length === 0; const withSql = this.buildWithCTE(withList); const distinctSql = distinct ? sql` distinct` : undefined; const selection = this.buildSelection(fieldsList, { isSingleTable }); const tableSql = this.buildFromTable(table); const joinsSql = this.buildJoins(joins); const whereSql = where ? sql` where ${where}` : undefined; const havingSql = having ? sql` having ${having}` : undefined; const groupByList = []; if (groupBy) { for (const [index2, groupByValue] of groupBy.entries()) { groupByList.push(groupByValue); if (index2 < groupBy.length - 1) { groupByList.push(sql`, `); } } } const groupBySql = groupByList.length > 0 ? sql` group by ${sql.join(groupByList)}` : undefined; const orderBySql = this.buildOrderBy(orderBy); const limitSql = this.buildLimit(limit); const offsetSql = offset ? sql` offset ${offset}` : undefined; const finalQuery = sql`${withSql}select${distinctSql} ${selection} from ${tableSql}${joinsSql}${whereSql}${groupBySql}${havingSql}${orderBySql}${limitSql}${offsetSql}`; if (setOperators.length > 0) { return this.buildSetOperations(finalQuery, setOperators); } return finalQuery; } buildSetOperations(leftSelect, setOperators) { const [setOperator, ...rest] = setOperators; if (!setOperator) { throw new Error("Cannot pass undefined values to any set operator"); } if (rest.length === 0) { return this.buildSetOperationQuery({ leftSelect, setOperator }); } return this.buildSetOperations(this.buildSetOperationQuery({ leftSelect, setOperator }), rest); } buildSetOperationQuery({ leftSelect, setOperator: { type, isAll, rightSelect, limit, orderBy, offset } }) { const leftChunk = sql`${leftSelect.getSQL()} `; const rightChunk = sql`${rightSelect.getSQL()}`; let orderBySql; if (orderBy && orderBy.length > 0) { const orderByValues = []; for (const singleOrderBy of orderBy) { if (is(singleOrderBy, SQLiteColumn)) { orderByValues.push(sql.identifier(singleOrderBy.name)); } else if (is(singleOrderBy, SQL)) { for (let i = 0;i < singleOrderBy.queryChunks.length; i++) { const chunk = singleOrderBy.queryChunks[i]; if (is(chunk, SQLiteColumn)) { singleOrderBy.queryChunks[i] = sql.identifier(this.casing.getColumnCasing(chunk)); } } orderByValues.push(sql`${singleOrderBy}`); } else { orderByValues.push(sql`${singleOrderBy}`); } } orderBySql = sql` order by ${sql.join(orderByValues, sql`, `)}`; } const limitSql = typeof limit === "object" || typeof limit === "number" && limit >= 0 ? sql` limit ${limit}` : undefined; const operatorChunk = sql.raw(`${type} ${isAll ? "all " : ""}`); const offsetSql = offset ? sql` offset ${offset}` : undefined; return sql`${leftChunk}${operatorChunk}${rightChunk}${orderBySql}${limitSql}${offsetSql}`; } buildInsertQuery({ table, values: valuesOrSelect, onConflict, returning, withList, select }) { const valuesSqlList = []; const columns = table[Table.Symbol.Columns]; const colEntries = Object.entries(columns).filter(([_, col]) => !col.shouldDisableInsert()); const insertOrder = colEntries.map(([, column]) => sql.identifier(this.casing.getColumnCasing(column))); if (select) { const select2 = valuesOrSelect; if (is(select2, SQL)) { valuesSqlList.push(select2); } else { valuesSqlList.push(select2.getSQL()); } } else { const values = valuesOrSelect; valuesSqlList.push(sql.raw("values ")); for (const [valueIndex, value] of values.entries()) { const valueList = []; for (const [fieldName, col] of colEntries) { const colValue = value[fieldName]; if (colValue === undefined || is(colValue, Param) && colValue.value === undefined) { let defaultValue; if (col.default !== null && col.default !== undefined) { defaultValue = is(col.default, SQL) ? col.default : sql.param(col.default, col); } else if (col.defaultFn !== undefined) { const defaultFnResult = col.defaultFn(); defaultValue = is(defaultFnResult, SQL) ? defaultFnResult : sql.param(defaultFnResult, col); } else if (!col.default && col.onUpdateFn !== undefined) { const onUpdateFnResult = col.onUpdateFn(); defaultValue = is(onUpdateFnResult, SQL) ? onUpdateFnResult : sql.param(onUpdateFnResult, col); } else { defaultValue = sql`null`; } valueList.push(defaultValue); } else { valueList.push(colValue); } } valuesSqlList.push(valueList); if (valueIndex < values.length - 1) { valuesSqlList.push(sql`, `); } } } const withSql = this.buildWithCTE(withList); const valuesSql = sql.join(valuesSqlList); const returningSql = returning ? sql` returning ${this.buildSelection(returning, { isSingleTable: true })}` : undefined; const onConflictSql = onConflict?.length ? sql.join(onConflict) : undefined; return sql`${withSql}insert into ${table} ${insertOrder} ${valuesSql}${onConflictSql}${returningSql}`; } sqlToQuery(sql2, invokeSource) { return sql2.toQuery({ casing: this.casing, escapeName: this.escapeName, escapeParam: this.escapeParam, escapeString: this.escapeString, invokeSource }); } buildRelationalQuery({ fullSchema, schema, tableNamesMap, table, tableConfig, queryConfig: config, tableAlias, nestedQueryRelation, joinOn }) { let selection = []; let limit, offset, orderBy = [], where; const joins = []; if (config === true) { const selectionEntries = Object.entries(tableConfig.columns); selection = selectionEntries.map(([key, value]) => ({ dbKey: value.name, tsKey: key, field: aliasedTableColumn(value, tableAlias), relationTableTsKey: undefined, isJson: false, selection: [] })); } else { const aliasedColumns = Object.fromEntries(Object.entries(tableConfig.columns).map(([key, value]) => [key, aliasedTableColumn(value, tableAlias)])); if (config.where) { const whereSql = typeof config.where === "function" ? config.where(aliasedColumns, getOperators()) : config.where; where = whereSql && mapColumnsInSQLToAlias(whereSql, tableAlias); } const fieldsSelection = []; let selectedColumns = []; if (config.columns) { let isIncludeMode = false; for (const [field, value] of Object.entries(config.columns)) { if (value === undefined) { continue; } if (field in tableConfig.columns) { if (!isIncludeMode && value === true) { isIncludeMode = true; } selectedColumns.push(field); } } if (selectedColumns.length > 0) { selectedColumns = isIncludeMode ? selectedColumns.filter((c) => config.columns?.[c] === true) : Object.keys(tableConfig.columns).filter((key) => !selectedColumns.includes(key)); } } else { selectedColumns = Object.keys(tableConfig.columns); } for (const field of selectedColumns) { const column = tableConfig.columns[field]; fieldsSelection.push({ tsKey: field, value: column }); } let selectedRelations = []; if (config.with) { selectedRelations = Object.entries(config.with).filter((entry) => !!entry[1]).map(([tsKey, queryConfig]) => ({ tsKey, queryConfig, relation: tableConfig.relations[tsKey] })); } let extras; if (config.extras) { extras = typeof config.extras === "function" ? config.extras(aliasedColumns, { sql }) : config.extras; for (const [tsKey, value] of Object.entries(extras)) { fieldsSelection.push({ tsKey, value: mapColumnsInAliasedSQLToAlias(value, tableAlias) }); } } for (const { tsKey, value } of fieldsSelection) { selection.push({ dbKey: is(value, SQL.Aliased) ? value.fieldAlias : tableConfig.columns[tsKey].name, tsKey, field: is(value, Column) ? aliasedTableColumn(value, tableAlias) : value, relationTableTsKey: undefined, isJson: false, selection: [] }); } let orderByOrig = typeof config.orderBy === "function" ? config.orderBy(aliasedColumns, getOrderByOperators()) : config.orderBy ?? []; if (!Array.isArray(orderByOrig)) { orderByOrig = [orderByOrig]; } orderBy = orderByOrig.map((orderByValue) => { if (is(orderByValue, Column)) { return aliasedTableColumn(orderByValue, tableAlias); } return mapColumnsInSQLToAlias(orderByValue, tableAlias); }); limit = config.limit; offset = config.offset; for (const { tsKey: selectedRelationTsKey, queryConfig: selectedRelationConfigValue, relation } of selectedRelations) { const normalizedRelation = normalizeRelation(schema, tableNamesMap, relation); const relationTableName = getTableUniqueName(relation.referencedTable); const relationTableTsName = tableNamesMap[relationTableName]; const relationTableAlias = `${tableAlias}_${selectedRelationTsKey}`; const joinOn2 = and(...normalizedRelation.fields.map((field2, i) => eq(aliasedTableColumn(normalizedRelation.references[i], relationTableAlias), aliasedTableColumn(field2, tableAlias)))); const builtRelation = this.buildRelationalQuery({ fullSchema, schema, tableNamesMap, table: fullSchema[relationTableTsName], tableConfig: schema[relationTableTsName], queryConfig: is(relation, One) ? selectedRelationConfigValue === true ? { limit: 1 } : { ...selectedRelationConfigValue, limit: 1 } : selectedRelationConfigValue, tableAlias: relationTableAlias, joinOn: joinOn2, nestedQueryRelation: relation }); const field = sql`(${builtRelation.sql})`.as(selectedRelationTsKey); selection.push({ dbKey: selectedRelationTsKey, tsKey: selectedRelationTsKey, field, relationTableTsKey: relationTableTsName, isJson: true, selection: builtRelation.selection }); } } if (selection.length === 0) { throw new DrizzleError({ message: `No fields selected for table "${tableConfig.tsName}" ("${tableAlias}"). You need to have at least one item in "columns", "with" or "extras". If you need to select all columns, omit the "columns" key or set it to undefined.` }); } let result; where = and(joinOn, where); if (nestedQueryRelation) { let field = sql`json_array(${sql.join(selection.map(({ field: field2 }) => is(field2, SQLiteColumn) ? sql.identifier(this.casing.getColumnCasing(field2)) : is(field2, SQL.Aliased) ? field2.sql : field2), sql`, `)})`; if (is(nestedQueryRelation, Many)) { field = sql`coalesce(json_group_array(${field}), json_array())`; } const nestedSelection = [{ dbKey: "data", tsKey: "data", field: field.as("data"), isJson: true, relationTableTsKey: tableConfig.tsName, selection }]; const needsSubquery = limit !== undefined || offset !== undefined || orderBy.length > 0; if (needsSubquery) { result = this.buildSelectQuery({ table: aliasedTable(table, tableAlias), fields: {}, fieldsFlat: [ { path: [], field: sql.raw("*") } ], where, limit, offset, orderBy, setOperators: [] }); where = undefined; limit = undefined; offset = undefined; orderBy = undefined; } else { result = aliasedTable(table, tableAlias); } result = this.buildSelectQuery({ table: is(result, SQLiteTable) ? result : new Subquery(result, {}, tableAlias), fields: {}, fieldsFlat: nestedSelection.map(({ field: field2 }) => ({ path: [], field: is(field2, Column) ? aliasedTableColumn(field2, tableAlias) : field2 })), joins, where, limit, offset, orderBy, setOperators: [] }); } else { result = this.buildSelectQuery({ table: aliasedTable(table, tableAlias), fields: {}, fieldsFlat: selection.map(({ field }) => ({ path: [], field: is(field, Column) ? aliasedTableColumn(field, tableAlias) : field })), joins, where, limit, offset, orderBy, setOperators: [] }); } return { tableTsKey: tableConfig.tsName, sql: result, selection }; } } class SQLiteSyncDialect extends SQLiteDialect { static [entityKind] = "SQLiteSyncDialect"; migrate(migrations, session, config) { const migrationsTable = config === undefined ? "__drizzle_migrations" : typeof config === "string" ? "__drizzle_migrations" : config.migrationsTable ?? "__drizzle_migrations"; const migrationTableCreate = sql` CREATE TABLE IF NOT EXISTS ${sql.identifier(migrationsTable)} ( id SERIAL PRIMARY KEY, hash text NOT NULL, created_at numeric ) `; session.run(migrationTableCreate); const dbMigrations = session.values(sql`SELECT id, hash, created_at FROM ${sql.identifier(migrationsTable)} ORDER BY created_at DESC LIMIT 1`); const lastDbMigration = dbMigrations[0] ?? undefined; session.run(sql`BEGIN`); try { for (const migration of migrations) { if (!lastDbMigration || Number(lastDbMigration[2]) < migration.folderMillis) { for (const stmt of migration.sql) { session.run(sql.raw(stmt)); } session.run(sql`INSERT INTO ${sql.identifier(migrationsTable)} ("hash", "created_at") VALUES(${migration.hash}, ${migration.folderMillis})`); } } session.run(sql`COMMIT`); } catch (e) { session.run(sql`ROLLBACK`); throw e; } } } // ../eve/node_modules/drizzle-orm/query-builders/query-builder.js class TypedQueryBuilder { static [entityKind] = "TypedQueryBuilder"; getSelectedFields() { return this._.selectedFields; } } // ../eve/node_modules/drizzle-orm/sqlite-core/query-builders/select.js class SQLiteSelectBuilder { static [entityKind] = "SQLiteSelectBuilder"; fields; session; dialect; withList; distinct; constructor(config) { this.fields = config.fields; this.session = config.session; this.dialect = config.dialect; this.withList = config.withList; this.distinct = config.distinct; } from(source) { const isPartialSelect = !!this.fields; let fields; if (this.fields) { fields = this.fields; } else if (is(source, Subquery)) { fields = Object.fromEntries(Object.keys(source._.selectedFields).map((key) => [key, source[key]])); } else if (is(source, SQLiteViewBase)) { fields = source[ViewBaseConfig].selectedFields; } else if (is(source, SQL)) { fields = {}; } else { fields = getTableColumns(source); } return new SQLiteSelectBase({ table: source, fields, isPartialSelect, session: this.session, dialect: this.dialect, withList: this.withList, distinct: this.distinct }); } } class SQLiteSelectQueryBuilderBase extends TypedQueryBuilder { static [entityKind] = "SQLiteSelectQueryBuilder"; _; config; joinsNotNullableMap; tableName; isPartialSelect; session; dialect; cacheConfig = undefined; usedTables = /* @__PURE__ */ new Set; constructor({ table, fields, isPartialSelect, session, dialect, withList, distinct }) { super(); this.config = { withList, table, fields: { ...fields }, distinct, setOperators: [] }; this.isPartialSelect = isPartialSelect; this.session = session; this.dialect = dialect; this._ = { selectedFields: fields, config: this.config }; this.tableName = getTableLikeName(table); this.joinsNotNullableMap = typeof this.tableName === "string" ? { [this.tableName]: true } : {}; for (const item of extractUsedTable(table)) this.usedTables.add(item); } getUsedTables() { return [...this.usedTables]; } createJoin(joinType) { return (table, on) => { const baseTableName = this.tableName; const tableName = getTableLikeName(table); for (const item of extractUsedTable(table)) this.usedTables.add(item); if (typeof tableName === "string" && this.config.joins?.some((join) => join.alias === tableName)) { throw new Error(`Alias "${tableName}" is already used in this query`); } if (!this.isPartialSelect) { if (Object.keys(this.joinsNotNullableMap).length === 1 && typeof baseTableName === "string") { this.config.fields = { [baseTableName]: this.config.fields }; } if (typeof tableName === "string" && !is(table, SQL)) { const selection = is(table, Subquery) ? table._.selectedFields : is(table, View) ? table[ViewBaseConfig].selectedFields : table[Table.Symbol.Columns]; this.config.fields[tableName] = selection; } } if (typeof on === "function") { on = on(new Proxy(this.config.fields, new SelectionProxyHandler({ sqlAliasedBehavior: "sql", sqlBehavior: "sql" }))); } if (!this.config.joins) { this.config.joins = []; } this.config.joins.push({ on, table, joinType, alias: tableName }); if (typeof tableName === "string") { switch (joinType) { case "left": { this.joinsNotNullableMap[tableName] = false; break; } case "right": { this.joinsNotNullableMap = Object.fromEntries(Object.entries(this.joinsNotNullableMap).map(([key]) => [key, false])); this.joinsNotNullableMap[tableName] = true; break; } case "cross": case "inner": { this.joinsNotNullableMap[tableName] = true; break; } case "full": { this.joinsNotNullableMap = Object.fromEntries(Object.entries(this.joinsNotNullableMap).map(([key]) => [key, false])); this.joinsNotNullableMap[tableName] = false; break; } } } return this; }; } leftJoin = this.createJoin("left"); rightJoin = this.createJoin("right"); innerJoin = this.createJoin("inner"); fullJoin = this.createJoin("full"); crossJoin = this.createJoin("cross"); createSetOperator(type, isAll) { return (rightSelection) => { const rightSelect = typeof rightSelection === "function" ? rightSelection(getSQLiteSetOperators()) : rightSelection; if (!haveSameKeys(this.getSelectedFields(), rightSelect.getSelectedFields())) { throw new Error("Set operator error (union / intersect / except): selected fields are not the same or are in a different order"); } this.config.setOperators.push({ type, isAll, rightSelect }); return this; }; } union = this.createSetOperator("union", false); unionAll = this.createSetOperator("union", true); intersect = this.createSetOperator("intersect", false); except = this.createSetOperator("except", false); addSetOperators(setOperators) { this.config.setOperators.push(...setOperators); return this; } where(where) { if (typeof where === "function") { where = where(new Proxy(this.config.fields, new SelectionProxyHandler({ sqlAliasedBehavior: "sql", sqlBehavior: "sql" }))); } this.config.where = where; return this; } having(having) { if (typeof having === "function") { having = having(new Proxy(this.config.fields, new SelectionProxyHandler({ sqlAliasedBehavior: "sql", sqlBehavior: "sql" }))); } this.config.having = having; return this; } groupBy(...columns) { if (typeof columns[0] === "function") { const groupBy = columns[0](new Proxy(this.config.fields, new SelectionProxyHandler({ sqlAliasedBehavior: "alias", sqlBehavior: "sql" }))); this.config.groupBy = Array.isArray(groupBy) ? groupBy : [groupBy]; } else { this.config.groupBy = columns; } return this; } orderBy(...columns) { if (typeof columns[0] === "function") { const orderBy = columns[0](new Proxy(this.config.fields, new SelectionProxyHandler({ sqlAliasedBehavior: "alias", sqlBehavior: "sql" }))); const orderByArray = Array.isArray(orderBy) ? orderBy : [orderBy]; if (this.config.setOperators.length > 0) { this.config.setOperators.at(-1).orderBy = orderByArray; } else { this.config.orderBy = orderByArray; } } else { const orderByArray = columns; if (this.config.setOperators.length > 0) { this.config.setOperators.at(-1).orderBy = orderByArray; } else { this.config.orderBy = orderByArray; } } return this; } limit(limit) { if (this.config.setOperators.length > 0) { this.config.setOperators.at(-1).limit = limit; } else { this.config.limit = limit; } return this; } offset(offset) { if (this.config.setOperators.length > 0) { this.config.setOperators.at(-1).offset = offset; } else { this.config.offset = offset; } return this; } getSQL() { return this.dialect.buildSelectQuery(this.config); } toSQL() { const { typings: _typings, ...rest } = this.dialect.sqlToQuery(this.getSQL()); return rest; } as(alias) { const usedTables = []; usedTables.push(...extractUsedTable(this.config.table)); if (this.config.joins) { for (const it of this.config.joins) usedTables.push(...extractUsedTable(it.table)); } return new Proxy(new Subquery(this.getSQL(), this.config.fields, alias, false, [...new Set(usedTables)]), new SelectionProxyHandler({ alias, sqlAliasedBehavior: "alias", sqlBehavior: "error" })); } getSelectedFields() { return new Proxy(this.config.fields, new SelectionProxyHandler({ alias: this.tableName, sqlAliasedBehavior: "alias", sqlBehavior: "error" })); } $dynamic() { return this; } } class SQLiteSelectBase extends SQLiteSelectQueryBuilderBase { static [entityKind] = "SQLiteSelect"; _prepare(isOneTimeQuery = true) { if (!this.session) { throw new Error("Cannot execute a query on a query builder. Please use a database instance instead."); } const fieldsList = orderSelectedFields(this.config.fields); const query = this.session[isOneTimeQuery ? "prepareOneTimeQuery" : "prepareQuery"](this.dialect.sqlToQuery(this.getSQL()), fieldsList, "all", true, undefined, { type: "select", tables: [...this.usedTables] }, this.cacheConfig); query.joinsNotNullableMap = this.joinsNotNullableMap; return query; } $withCache(config) { this.cacheConfig = config === undefined ? { config: {}, enable: true, autoInvalidate: true } : config === false ? { enable: false } : { enable: true, autoInvalidate: true, ...config }; return this; } prepare() { return this._prepare(false); } run = (placeholderValues) => { return this._prepare().run(placeholderValues); }; all = (placeholderValues) => { return this._prepare().all(placeholderValues); }; get = (placeholderValues) => { return this._prepare().get(placeholderValues); }; values = (placeholderValues) => { return this._prepare().values(placeholderValues); }; async execute() { return this.all(); } } applyMixins(SQLiteSelectBase, [QueryPromise]); function createSetOperator(type, isAll) { return (leftSelect, rightSelect, ...restSelects) => { const setOperators = [rightSelect, ...restSelects].map((select) => ({ type, isAll, rightSelect: select })); for (const setOperator of setOperators) { if (!haveSameKeys(leftSelect.getSelectedFields(), setOperator.rightSelect.getSelectedFields())) { throw new Error("Set operator error (union / intersect / except): selected fields are not the same or are in a different order"); } } return leftSelect.addSetOperators(setOperators); }; } var getSQLiteSetOperators = () => ({ union, unionAll, intersect, except }); var union = createSetOperator("union", false); var unionAll = createSetOperator("union", true); var intersect = createSetOperator("intersect", false); var except = createSetOperator("except", false); // ../eve/node_modules/drizzle-orm/sqlite-core/query-builders/query-builder.js class QueryBuilder { static [entityKind] = "SQLiteQueryBuilder"; dialect; dialectConfig; constructor(dialect) { this.dialect = is(dialect, SQLiteDialect) ? dialect : undefined; this.dialectConfig = is(dialect, SQLiteDialect) ? undefined : dialect; } $with = (alias, selection) => { const queryBuilder = this; const as = (qb) => { if (typeof qb === "function") { qb = qb(queryBuilder); } return new Proxy(new WithSubquery(qb.getSQL(), selection ?? ("getSelectedFields" in qb ? qb.getSelectedFields() ?? {} : {}), alias, true), new SelectionProxyHandler({ alias, sqlAliasedBehavior: "alias", sqlBehavior: "error" })); }; return { as }; }; with(...queries) { const self2 = this; function select(fields) { return new SQLiteSelectBuilder({ fields: fields ?? undefined, session: undefined, dialect: self2.getDialect(), withList: queries }); } function selectDistinct(fields) { return new SQLiteSelectBuilder({ fields: fields ?? undefined, session: undefined, dialect: self2.getDialect(), withList: queries, distinct: true }); } return { select, selectDistinct }; } select(fields) { return new SQLiteSelectBuilder({ fields: fields ?? undefined, session: undefined, dialect: this.getDialect() }); } selectDistinct(fields) { return new SQLiteSelectBuilder({ fields: fields ?? undefined, session: undefined, dialect: this.getDialect(), distinct: true }); } getDialect() { if (!this.dialect) { this.dialect = new SQLiteSyncDialect(this.dialectConfig); } return this.dialect; } } // ../eve/node_modules/drizzle-orm/sqlite-core/query-builders/insert.js class SQLiteInsertBuilder { constructor(table, session, dialect, withList) { this.table = table; this.session = session; this.dialect = dialect; this.withList = withList; } static [entityKind] = "SQLiteInsertBuilder"; values(values) { values = Array.isArray(values) ? values : [values]; if (values.length === 0) { throw new Error("values() must be called with at least one value"); } const mappedValues = values.map((entry) => { const result = {}; const cols = this.table[Table.Symbol.Columns]; for (const colKey of Object.keys(entry)) { const colValue = entry[colKey]; result[colKey] = is(colValue, SQL) ? colValue : new Param(colValue, cols[colKey]); } return result; }); return new SQLiteInsertBase(this.table, mappedValues, this.session, this.dialect, this.withList); } select(selectQuery) { const select = typeof selectQuery === "function" ? selectQuery(new QueryBuilder) : selectQuery; if (!is(select, SQL) && !haveSameKeys(this.table[Columns], select._.selectedFields)) { throw new Error("Insert select error: selected fields are not the same or are in a different order compared to the table definition"); } return new SQLiteInsertBase(this.table, select, this.session, this.dialect, this.withList, true); } } class SQLiteInsertBase extends QueryPromise { constructor(table, values, session, dialect, withList, select) { super(); this.session = session; this.dialect = dialect; this.config = { table, values, withList, select }; } static [entityKind] = "SQLiteInsert"; config; returning(fields = this.config.table[SQLiteTable.Symbol.Columns]) { this.config.returning = orderSelectedFields(fields); return this; } onConflictDoNothing(config = {}) { if (!this.config.onConflict) this.config.onConflict = []; if (config.target === undefined) { this.config.onConflict.push(sql` on conflict do nothing`); } else { const targetSql = Array.isArray(config.target) ? sql`${config.target}` : sql`${[config.target]}`; const whereSql = config.where ? sql` where ${config.where}` : sql``; this.config.onConflict.push(sql` on conflict ${targetSql} do nothing${whereSql}`); } return this; } onConflictDoUpdate(config) { if (config.where && (config.targetWhere || config.setWhere)) { throw new Error('You cannot use both "where" and "targetWhere"/"setWhere" at the same time - "where" is deprecated, use "targetWhere" or "setWhere" instead.'); } if (!this.config.onConflict) this.config.onConflict = []; const whereSql = config.where ? sql` where ${config.where}` : undefined; const targetWhereSql = config.targetWhere ? sql` where ${config.targetWhere}` : undefined; const setWhereSql = config.setWhere ? sql` where ${config.setWhere}` : undefined; const targetSql = Array.isArray(config.target) ? sql`${config.target}` : sql`${[config.target]}`; const setSql = this.dialect.buildUpdateSet(this.config.table, mapUpdateSet(this.config.table, config.set)); this.config.onConflict.push(sql` on conflict ${targetSql}${targetWhereSql} do update set ${setSql}${whereSql}${setWhereSql}`); return this; } getSQL() { return this.dialect.buildInsertQuery(this.config); } toSQL() { const { typings: _typings, ...rest } = this.dialect.sqlToQuery(this.getSQL()); return rest; } _prepare(isOneTimeQuery = true) { return this.session[isOneTimeQuery ? "prepareOneTimeQuery" : "prepareQuery"](this.dialect.sqlToQuery(this.getSQL()), this.config.returning, this.config.returning ? "all" : "run", true, undefined, { type: "insert", tables: extractUsedTable(this.config.table) }); } prepare() { return this._prepare(false); } run = (placeholderValues) => { return this._prepare().run(placeholderValues); }; all = (placeholderValues) => { return this._prepare().all(placeholderValues); }; get = (placeholderValues) => { return this._prepare().get(placeholderValues); }; values = (placeholderValues) => { return this._prepare().values(placeholderValues); }; async execute() { return this.config.returning ? this.all() : this.run(); } $dynamic() { return this; } } // ../eve/node_modules/drizzle-orm/sqlite-core/query-builders/update.js class SQLiteUpdateBuilder { constructor(table, session, dialect, withList) { this.table = table; this.session = session; this.dialect = dialect; this.withList = withList; } static [entityKind] = "SQLiteUpdateBuilder"; set(values) { return new SQLiteUpdateBase(this.table, mapUpdateSet(this.table, values), this.session, this.dialect, this.withList); } } class SQLiteUpdateBase extends QueryPromise { constructor(table, set, session, dialect, withList) { super(); this.session = session; this.dialect = dialect; this.config = { set, table, withList, joins: [] }; } static [entityKind] = "SQLiteUpdate"; config; from(source) { this.config.from = source; return this; } createJoin(joinType) { return (table, on) => { const tableName = getTableLikeName(table); if (typeof tableName === "string" && this.config.joins.some((join) => join.alias === tableName)) { throw new Error(`Alias "${tableName}" is already used in this query`); } if (typeof on === "function") { const from = this.config.from ? is(table, SQLiteTable) ? table[Table.Symbol.Columns] : is(table, Subquery) ? table._.selectedFields : is(table, SQLiteViewBase) ? table[ViewBaseConfig].selectedFields : undefined : undefined; on = on(new Proxy(this.config.table[Table.Symbol.Columns], new SelectionProxyHandler({ sqlAliasedBehavior: "sql", sqlBehavior: "sql" })), from && new Proxy(from, new SelectionProxyHandler({ sqlAliasedBehavior: "sql", sqlBehavior: "sql" }))); } this.config.joins.push({ on, table, joinType, alias: tableName }); return this; }; } leftJoin = this.createJoin("left"); rightJoin = this.createJoin("right"); innerJoin = this.createJoin("inner"); fullJoin = this.createJoin("full"); where(where) { this.config.where = where; return this; } orderBy(...columns) { if (typeof columns[0] === "function") { const orderBy = columns[0](new Proxy(this.config.table[Table.Symbol.Columns], new SelectionProxyHandler({ sqlAliasedBehavior: "alias", sqlBehavior: "sql" }))); const orderByArray = Array.isArray(orderBy) ? orderBy : [orderBy]; this.config.orderBy = orderByArray; } else { const orderByArray = columns; this.config.orderBy = orderByArray; } return this; } limit(limit) { this.config.limit = limit; return this; } returning(fields = this.config.table[SQLiteTable.Symbol.Columns]) { this.config.returning = orderSelectedFields(fields); return this; } getSQL() { return this.dialect.buildUpdateQuery(this.config); } toSQL() { const { typings: _typings, ...rest } = this.dialect.sqlToQuery(this.getSQL()); return rest; } _prepare(isOneTimeQuery = true) { return this.session[isOneTimeQuery ? "prepareOneTimeQuery" : "prepareQuery"](this.dialect.sqlToQuery(this.getSQL()), this.config.returning, this.config.returning ? "all" : "run", true, undefined, { type: "insert", tables: extractUsedTable(this.config.table) }); } prepare() { return this._prepare(false); } run = (placeholderValues) => { return this._prepare().run(placeholderValues); }; all = (placeholderValues) => { return this._prepare().all(placeholderValues); }; get = (placeholderValues) => { return this._prepare().get(placeholderValues); }; values = (placeholderValues) => { return this._prepare().values(placeholderValues); }; async execute() { return this.config.returning ? this.all() : this.run(); } $dynamic() { return this; } } // ../eve/node_modules/drizzle-orm/sqlite-core/query-builders/count.js class SQLiteCountBuilder extends SQL { constructor(params) { super(SQLiteCountBuilder.buildEmbeddedCount(params.source, params.filters).queryChunks); this.params = params; this.session = params.session; this.sql = SQLiteCountBuilder.buildCount(params.source, params.filters); } sql; static [entityKind] = "SQLiteCountBuilderAsync"; [Symbol.toStringTag] = "SQLiteCountBuilderAsync"; session; static buildEmbeddedCount(source, filters) { return sql`(select count(*) from ${source}${sql.raw(" where ").if(filters)}${filters})`; } static buildCount(source, filters) { return sql`select count(*) from ${source}${sql.raw(" where ").if(filters)}${filters}`; } then(onfulfilled, onrejected) { return Promise.resolve(this.session.count(this.sql)).then(onfulfilled, onrejected); } catch(onRejected) { return this.then(undefined, onRejected); } finally(onFinally) { return this.then((value) => { onFinally?.(); return value; }, (reason) => { onFinally?.(); throw reason; }); } } // ../eve/node_modules/drizzle-orm/sqlite-core/query-builders/query.js class RelationalQueryBuilder { constructor(mode, fullSchema, schema, tableNamesMap, table, tableConfig, dialect, session) { this.mode = mode; this.fullSchema = fullSchema; this.schema = schema; this.tableNamesMap = tableNamesMap; this.table = table; this.tableConfig = tableConfig; this.dialect = dialect; this.session = session; } static [entityKind] = "SQLiteAsyncRelationalQueryBuilder"; findMany(config) { return this.mode === "sync" ? new SQLiteSyncRelationalQuery(this.fullSchema, this.schema, this.tableNamesMap, this.table, this.tableConfig, this.dialect, this.session, config ? config : {}, "many") : new SQLiteRelationalQuery(this.fullSchema, this.schema, this.tableNamesMap, this.table, this.tableConfig, this.dialect, this.session, config ? config : {}, "many"); } findFirst(config) { return this.mode === "sync" ? new SQLiteSyncRelationalQuery(this.fullSchema, this.schema, this.tableNamesMap, this.table, this.tableConfig, this.dialect, this.session, config ? { ...config, limit: 1 } : { limit: 1 }, "first") : new SQLiteRelationalQuery(this.fullSchema, this.schema, this.tableNamesMap, this.table, this.tableConfig, this.dialect, this.session, config ? { ...config, limit: 1 } : { limit: 1 }, "first"); } } class SQLiteRelationalQuery extends QueryPromise { constructor(fullSchema, schema, tableNamesMap, table, tableConfig, dialect, session, config, mode) { super(); this.fullSchema = fullSchema; this.schema = schema; this.tableNamesMap = tableNamesMap; this.table = table; this.tableConfig = tableConfig; this.dialect = dialect; this.session = session; this.config = config; this.mode = mode; } static [entityKind] = "SQLiteAsyncRelationalQuery"; mode; getSQL() { return this.dialect.buildRelationalQuery({ fullSchema: this.fullSchema, schema: this.schema, tableNamesMap: this.tableNamesMap, table: this.table, tableConfig: this.tableConfig, queryConfig: this.config, tableAlias: this.tableConfig.tsName }).sql; } _prepare(isOneTimeQuery = false) { const { query, builtQuery } = this._toSQL(); return this.session[isOneTimeQuery ? "prepareOneTimeQuery" : "prepareQuery"](builtQuery, undefined, this.mode === "first" ? "get" : "all", true, (rawRows, mapColumnValue) => { const rows = rawRows.map((row) => mapRelationalRow(this.schema, this.tableConfig, row, query.selection, mapColumnValue)); if (this.mode === "first") { return rows[0]; } return rows; }); } prepare() { return this._prepare(false); } _toSQL() { const query = this.dialect.buildRelationalQuery({ fullSchema: this.fullSchema, schema: this.schema, tableNamesMap: this.tableNamesMap, table: this.table, tableConfig: this.tableConfig, queryConfig: this.config, tableAlias: this.tableConfig.tsName }); const builtQuery = this.dialect.sqlToQuery(query.sql); return { query, builtQuery }; } toSQL() { return this._toSQL().builtQuery; } executeRaw() { if (this.mode === "first") { return this._prepare(false).get(); } return this._prepare(false).all(); } async execute() { return this.executeRaw(); } } class SQLiteSyncRelationalQuery extends SQLiteRelationalQuery { static [entityKind] = "SQLiteSyncRelationalQuery"; sync() { return this.executeRaw(); } } // ../eve/node_modules/drizzle-orm/sqlite-core/query-builders/raw.js class SQLiteRaw extends QueryPromise { constructor(execute, getSQL, action, dialect, mapBatchResult) { super(); this.execute = execute; this.getSQL = getSQL; this.dialect = dialect; this.mapBatchResult = mapBatchResult; this.config = { action }; } static [entityKind] = "SQLiteRaw"; config; getQuery() { return { ...this.dialect.sqlToQuery(this.getSQL()), method: this.config.action }; } mapResult(result, isFromBatch) { return isFromBatch ? this.mapBatchResult(result) : result; } _prepare() { return this; } isResponseInArrayMode() { return false; } } // ../eve/node_modules/drizzle-orm/sqlite-core/db.js class BaseSQLiteDatabase { constructor(resultKind, dialect, session, schema) { this.resultKind = resultKind; this.dialect = dialect; this.session = session; this._ = schema ? { schema: schema.schema, fullSchema: schema.fullSchema, tableNamesMap: schema.tableNamesMap } : { schema: undefined, fullSchema: {}, tableNamesMap: {} }; this.query = {}; const query = this.query; if (this._.schema) { for (const [tableName, columns] of Object.entries(this._.schema)) { query[tableName] = new RelationalQueryBuilder(resultKind, schema.fullSchema, this._.schema, this._.tableNamesMap, schema.fullSchema[tableName], columns, dialect, session); } } this.$cache = { invalidate: async (_params) => {} }; } static [entityKind] = "BaseSQLiteDatabase"; query; $with = (alias, selection) => { const self2 = this; const as = (qb) => { if (typeof qb === "function") { qb = qb(new QueryBuilder(self2.dialect)); } return new Proxy(new WithSubquery(qb.getSQL(), selection ?? ("getSelectedFields" in qb ? qb.getSelectedFields() ?? {} : {}), alias, true), new SelectionProxyHandler({ alias, sqlAliasedBehavior: "alias", sqlBehavior: "error" })); }; return { as }; }; $count(source, filters) { return new SQLiteCountBuilder({ source, filters, session: this.session }); } with(...queries) { const self2 = this; function select(fields) { return new SQLiteSelectBuilder({ fields: fields ?? undefined, session: self2.session, dialect: self2.dialect, withList: queries }); } function selectDistinct(fields) { return new SQLiteSelectBuilder({ fields: fields ?? undefined, session: self2.session, dialect: self2.dialect, withList: queries, distinct: true }); } function update(table) { return new SQLiteUpdateBuilder(table, self2.session, self2.dialect, queries); } function insert(into) { return new SQLiteInsertBuilder(into, self2.session, self2.dialect, queries); } function delete_(from) { return new SQLiteDeleteBase(from, self2.session, self2.dialect, queries); } return { select, selectDistinct, update, insert, delete: delete_ }; } select(fields) { return new SQLiteSelectBuilder({ fields: fields ?? undefined, session: this.session, dialect: this.dialect }); } selectDistinct(fields) { return new SQLiteSelectBuilder({ fields: fields ?? undefined, session: this.session, dialect: this.dialect, distinct: true }); } update(table) { return new SQLiteUpdateBuilder(table, this.session, this.dialect); } $cache; insert(into) { return new SQLiteInsertBuilder(into, this.session, this.dialect); } delete(from) { return new SQLiteDeleteBase(from, this.session, this.dialect); } run(query) { const sequel = typeof query === "string" ? sql.raw(query) : query.getSQL(); if (this.resultKind === "async") { return new SQLiteRaw(async () => this.session.run(sequel), () => sequel, "run", this.dialect, this.session.extractRawRunValueFromBatchResult.bind(this.session)); } return this.session.run(sequel); } all(query) { const sequel = typeof query === "string" ? sql.raw(query) : query.getSQL(); if (this.resultKind === "async") { return new SQLiteRaw(async () => this.session.all(sequel), () => sequel, "all", this.dialect, this.session.extractRawAllValueFromBatchResult.bind(this.session)); } return this.session.all(sequel); } get(query) { const sequel = typeof query === "string" ? sql.raw(query) : query.getSQL(); if (this.resultKind === "async") { return new SQLiteRaw(async () => this.session.get(sequel), () => sequel, "get", this.dialect, this.session.extractRawGetValueFromBatchResult.bind(this.session)); } return this.session.get(sequel); } values(query) { const sequel = typeof query === "string" ? sql.raw(query) : query.getSQL(); if (this.resultKind === "async") { return new SQLiteRaw(async () => this.session.values(sequel), () => sequel, "values", this.dialect, this.session.extractRawValuesValueFromBatchResult.bind(this.session)); } return this.session.values(sequel); } transaction(transaction, config) { return this.session.transaction(transaction, config); } } // ../eve/node_modules/drizzle-orm/cache/core/cache.js class Cache { static [entityKind] = "Cache"; } class NoopCache extends Cache { strategy() { return "all"; } static [entityKind] = "NoopCache"; async get(_key) { return; } async put(_hashedQuery, _response, _tables, _config) {} async onMutate(_params) {} } async function hashQuery(sql2, params) { const dataToHash = `${sql2}-${JSON.stringify(params)}`; const encoder = new TextEncoder; const data = encoder.encode(dataToHash); const hashBuffer = await crypto.subtle.digest("SHA-256", data); const hashArray = [...new Uint8Array(hashBuffer)]; const hashHex = hashArray.map((b) => b.toString(16).padStart(2, "0")).join(""); return hashHex; } // ../eve/node_modules/drizzle-orm/sqlite-core/session.js class ExecuteResultSync extends QueryPromise { constructor(resultCb) { super(); this.resultCb = resultCb; } static [entityKind] = "ExecuteResultSync"; async execute() { return this.resultCb(); } sync() { return this.resultCb(); } } class SQLitePreparedQuery { constructor(mode, executeMethod, query, cache, queryMetadata, cacheConfig) { this.mode = mode; this.executeMethod = executeMethod; this.query = query; this.cache = cache; this.queryMetadata = queryMetadata; this.cacheConfig = cacheConfig; if (cache && cache.strategy() === "all" && cacheConfig === undefined) { this.cacheConfig = { enable: true, autoInvalidate: true }; } if (!this.cacheConfig?.enable) { this.cacheConfig = undefined; } } static [entityKind] = "PreparedQuery"; joinsNotNullableMap; async queryWithCache(queryString, params, query) { if (this.cache === undefined || is(this.cache, NoopCache) || this.queryMetadata === undefined) { try { return await query(); } catch (e) { throw new DrizzleQueryError(queryString, params, e); } } if (this.cacheConfig && !this.cacheConfig.enable) { try { return await query(); } catch (e) { throw new DrizzleQueryError(queryString, params, e); } } if ((this.queryMetadata.type === "insert" || this.queryMetadata.type === "update" || this.queryMetadata.type === "delete") && this.queryMetadata.tables.length > 0) { try { const [res] = await Promise.all([ query(), this.cache.onMutate({ tables: this.queryMetadata.tables }) ]); return res; } catch (e) { throw new DrizzleQueryError(queryString, params, e); } } if (!this.cacheConfig) { try { return await query(); } catch (e) { throw new DrizzleQueryError(queryString, params, e); } } if (this.queryMetadata.type === "select") { const fromCache = await this.cache.get(this.cacheConfig.tag ?? await hashQuery(queryString, params), this.queryMetadata.tables, this.cacheConfig.tag !== undefined, this.cacheConfig.autoInvalidate); if (fromCache === undefined) { let result; try { result = await query(); } catch (e) { throw new DrizzleQueryError(queryString, params, e); } await this.cache.put(this.cacheConfig.tag ?? await hashQuery(queryString, params), result, this.cacheConfig.autoInvalidate ? this.queryMetadata.tables : [], this.cacheConfig.tag !== undefined, this.cacheConfig.config); return result; } return fromCache; } try { return await query(); } catch (e) { throw new DrizzleQueryError(queryString, params, e); } } getQuery() { return this.query; } mapRunResult(result, _isFromBatch) { return result; } mapAllResult(_result, _isFromBatch) { throw new Error("Not implemented"); } mapGetResult(_result, _isFromBatch) { throw new Error("Not implemented"); } execute(placeholderValues) { if (this.mode === "async") { return this[this.executeMethod](placeholderValues); } return new ExecuteResultSync(() => this[this.executeMethod](placeholderValues)); } mapResult(response, isFromBatch) { switch (this.executeMethod) { case "run": { return this.mapRunResult(response, isFromBatch); } case "all": { return this.mapAllResult(response, isFromBatch); } case "get": { return this.mapGetResult(response, isFromBatch); } } } } class SQLiteSession { constructor(dialect) { this.dialect = dialect; } static [entityKind] = "SQLiteSession"; prepareOneTimeQuery(query, fields, executeMethod, isResponseInArrayMode, customResultMapper, queryMetadata, cacheConfig) { return this.prepareQuery(query, fields, executeMethod, isResponseInArrayMode, customResultMapper, queryMetadata, cacheConfig); } run(query) { const staticQuery = this.dialect.sqlToQuery(query); try { return this.prepareOneTimeQuery(staticQuery, undefined, "run", false).run(); } catch (err) { throw new DrizzleError({ cause: err, message: `Failed to run the query '${staticQuery.sql}'` }); } } extractRawRunValueFromBatchResult(result) { return result; } all(query) { return this.prepareOneTimeQuery(this.dialect.sqlToQuery(query), undefined, "run", false).all(); } extractRawAllValueFromBatchResult(_result) { throw new Error("Not implemented"); } get(query) { return this.prepareOneTimeQuery(this.dialect.sqlToQuery(query), undefined, "run", false).get(); } extractRawGetValueFromBatchResult(_result) { throw new Error("Not implemented"); } values(query) { return this.prepareOneTimeQuery(this.dialect.sqlToQuery(query), undefined, "run", false).values(); } async count(sql2) { const result = await this.values(sql2); return result[0][0]; } extractRawValuesValueFromBatchResult(_result) { throw new Error("Not implemented"); } } class SQLiteTransaction extends BaseSQLiteDatabase { constructor(resultType, dialect, session, schema, nestedIndex = 0) { super(resultType, dialect, session, schema); this.schema = schema; this.nestedIndex = nestedIndex; } static [entityKind] = "SQLiteTransaction"; rollback() { throw new TransactionRollbackError; } } // ../eve/node_modules/drizzle-orm/logger.js class ConsoleLogWriter { static [entityKind] = "ConsoleLogWriter"; write(message) { console.log(message); } } class DefaultLogger { static [entityKind] = "DefaultLogger"; writer; constructor(config) { this.writer = config?.writer ?? new ConsoleLogWriter; } logQuery(query, params) { const stringifiedParams = params.map((p) => { try { return JSON.stringify(p); } catch { return String(p); } }); const paramsStr = stringifiedParams.length ? ` -- params: [${stringifiedParams.join(", ")}]` : ""; this.writer.write(`Query: ${query}${paramsStr}`); } } class NoopLogger { static [entityKind] = "NoopLogger"; logQuery() {} } // ../eve/dist/db/schema.js var schema_exports = {}; __export(schema_exports, { characters: () => characters, charactersRelations: () => charactersRelations, miningFleetParticipants: () => miningFleetParticipants, miningFleetParticipantsRelations: () => miningFleetParticipantsRelations, miningFleets: () => miningFleets, miningFleetsRelations: () => miningFleetsRelations, resumeCommands: () => resumeCommands, shared: () => shared, users: () => users, usersRelations: () => usersRelations }); var shared = { createdAt: integer("created_at").notNull(), updatedAt: integer("updated_at") }; var users = sqliteTable("users", { id: integer().primaryKey().unique().notNull(), discordID: text("discord_id").unique().notNull(), mainCharacter: integer("main_character"), ...shared }, (table) => [index("idx_discord_id").on(table.discordID), index("idx_main_character").on(table.mainCharacter)]); var usersRelations = relations(users, ({ one, many }) => ({ characters: many(characters), main: one(characters, { fields: [users.mainCharacter], references: [characters.id] }) })); var characters = sqliteTable("characters", { id: integer("id").primaryKey({ autoIncrement: true }), eveID: integer("eve_id").notNull(), userID: integer("user_id").notNull(), name: text().notNull(), accessToken: text("access_token").notNull(), expiresAt: integer("expires_at").notNull(), refreshToken: text("refresh_token").notNull(), ...shared }, (table) => [index("idx_user_id").on(table.userID), index("idx_eve_id").on(table.eveID)]); var charactersRelations = relations(characters, ({ one }) => ({ user: one(users, { fields: [characters.userID], references: [users.id] }) })); var resumeCommands = sqliteTable("resumecommands", { id: text().primaryKey(), command: text().notNull(), params: text().notNull(), context: text().notNull(), ...shared }); var miningFleets = sqliteTable("mining_fleets", { id: integer("id").primaryKey({ autoIncrement: true }), name: text("name").notNull(), description: text("description"), creatorDiscordId: text("creator_discord_id").notNull(), startTime: integer("start_time").notNull(), endTime: integer("end_time"), status: text("status", { enum: [ "configuring", "active", "ended", "generating_report", "completed", "failed" ] }).notNull().default("configuring"), taxRate: real("tax_rate").notNull().default(0), publicMessageId: text("public_message_id").unique(), publicChannelId: text("public_channel_id"), reportData: text("report_data"), creatorEphemeralMessageId: text("creator_ephemeral_message_id"), ...shared }, (table) => [ index("idx_fleet_creator_discord_id").on(table.creatorDiscordId), index("idx_fleet_status").on(table.status), index("idx_fleet_public_message_id").on(table.publicMessageId) ]); var miningFleetParticipants = sqliteTable("mining_fleet_participants", { id: integer("id").primaryKey({ autoIncrement: true }), fleetId: integer("fleet_id").notNull().references(() => miningFleets.id, { onDelete: "cascade" }), characterId: integer("character_id").notNull().references(() => characters.id, { onDelete: "cascade" }), discordId: text("discord_id").notNull(), role: text("role", { enum: [ "miner", "security", "hauler" ] }).notNull(), joinTime: integer("join_time").notNull(), ...shared }, (table) => [ index("idx_participant_fleet_id").on(table.fleetId), index("idx_participant_character_id").on(table.characterId), index("idx_participant_discord_id").on(table.discordId) ]); var miningFleetsRelations = relations(miningFleets, ({ many }) => ({ participants: many(miningFleetParticipants) })); var miningFleetParticipantsRelations = relations(miningFleetParticipants, ({ one }) => ({ fleet: one(miningFleets, { fields: [miningFleetParticipants.fleetId], references: [miningFleets.id] }), character: one(characters, { fields: [miningFleetParticipants.characterId], references: [characters.id] }) })); // ../eve/dist/db/models/user.model.js var UserHelper = class { static find(id) { const result = db.select({ id: users.id, discordID: users.discordID, createdAt: users.createdAt, updatedAt: users.updatedAt, mainCharacterID: users.mainCharacter, characterIDsString: sql`json_group_array(characters.id)` }).from(users).where(eq(users.id, id)).leftJoin(characters, eq(users.id, characters.userID)).get(); return this.createFromQuery(result); } static findByDiscordId(id) { const result = db.select({ id: users.id, discordID: users.discordID, createdAt: users.createdAt, updatedAt: users.updatedAt, mainCharacterID: users.mainCharacter, characterIDsString: sql`json_group_array(characters.id)` }).from(users).where(eq(users.discordID, id)).leftJoin(characters, eq(users.id, characters.userID)).get(); return this.createFromQuery(result); } static findAll() { const result = db.select({ id: users.id, discordID: users.discordID, createdAt: users.createdAt, updatedAt: users.updatedAt, mainCharacterID: users.mainCharacter, characterIDsString: sql`json_group_array(characters.id)` }).from(users).leftJoin(characters, eq(users.id, characters.userID)).all(); return this.createFromQuery(result); } static findByCharacterId(id) { const result = db.select({ id: users.id, discordID: users.discordID, createdAt: users.createdAt, updatedAt: users.updatedAt, mainCharacterID: users.mainCharacter, characterIDsString: sql`json_group_array(characters.id)` }).from(users).leftJoin(characters, eq(users.id, characters.userID)).where(eq(characters.id, id)).all(); return this.createFromQuery(result); } static findByCharacterName(name) { const result = db.select({ id: users.id, discordID: users.discordID, createdAt: users.createdAt, updatedAt: users.updatedAt, mainCharacterID: users.mainCharacter, characterIDsString: sql`json_group_array(characters.id)` }).from(users).leftJoin(characters, eq(users.id, characters.userID)).where(eq(characters.name, name)).all(); return this.createFromQuery(result); } static createFromQuery(query) { if (!query) return []; if (Array.isArray(query)) return query.map((user) => { return { id: user.id, discordID: user.discordID, createdAt: new Date(user.createdAt), updatedAt: new Date(user.updatedAt), characterIDs: user.characterIDsString ? JSON.parse(user.characterIDsString ?? "[]").map((s) => Number(s)).sort() : [], mainCharacterID: user.mainCharacterID }; }); else return { id: query.id, discordID: query.discordID, createdAt: new Date(query.createdAt), updatedAt: new Date(query.updatedAt), characterIDs: query.characterIDsString ? JSON.parse(query.characterIDsString ?? "[]").map((s) => Number(s)).sort() : [], mainCharacterID: query.mainCharacterID }; } static create(discordID) { this.save({ discordID, createdAt: /* @__PURE__ */ new Date, updatedAt: /* @__PURE__ */ new Date }); return this.findByDiscordId(discordID); } static save(user) { db.insert(users).values({ id: user.id, discordID: user.discordID, mainCharacter: user.mainCharacterID, createdAt: user.createdAt.getTime(), updatedAt: user.updatedAt.getTime() }).onConflictDoUpdate({ target: users.id, set: { discordID: user.discordID, mainCharacter: user.mainCharacterID, updatedAt: user.updatedAt.getTime() } }).run(); return user; } static delete(user) { db.delete(users).where(eq(users.id, user.id)).run(); } static getCharacter(user, index2) { if (!user.characterIDs) return; if (index2 >= user.characterIDs.length) return; return CharacterHelper.find(user.characterIDs[index2]); } }; // ../eve/dist/db/models/resume-command.model.js var ResumeCommand = class ResumeCommand2 { id; command; params; context; created = /* @__PURE__ */ new Date; constructor() { this.created = /* @__PURE__ */ new Date; } static find(messageId) { const result = db.select().from(resumeCommands).where(eq(resumeCommands.id, messageId)).get(); return this.createFromQuery(result); } static create(messageId, command, params = {}, context = {}) { const resume = new ResumeCommand2; resume.id = messageId; resume.command = command; resume.params = JSON.stringify(params); resume.context = JSON.stringify(context); return resume; } static createFromQuery(query) { if (!query) return null; const resume = new ResumeCommand2; resume.id = query.id; resume.command = query.command; resume.params = query.params; resume.context = query.context; resume.created = query.created; return resume; } save() { db.insert(resumeCommands).values({ id: this.id, command: this.command, params: this.params, context: this.context, createdAt: this.created.getTime() }).onConflictDoUpdate({ target: resumeCommands.id, set: { command: this.command, params: this.params, context: this.context } }).run(); return this; } delete() { db.delete(resumeCommands).where(eq(resumeCommands.id, this.id)).run(); } static delete(messageId) { db.delete(resumeCommands).where(eq(resumeCommands.id, messageId)).run(); } }; // ../eve/dist/db/models/index.js var models_exports = {}; __export(models_exports, { CharacterHelper: () => CharacterHelper, ResumeCommand: () => ResumeCommand, UserHelper: () => UserHelper }); // ../eve/node_modules/drizzle-orm/bun-sqlite/driver.js import { Database } from "bun:sqlite"; // ../eve/node_modules/drizzle-orm/bun-sqlite/session.js class SQLiteBunSession extends SQLiteSession { constructor(client, dialect, schema, options2 = {}) { super(dialect); this.client = client; this.schema = schema; this.logger = options2.logger ?? new NoopLogger; } static [entityKind] = "SQLiteBunSession"; logger; exec(query) { this.client.exec(query); } prepareQuery(query, fields, executeMethod, isResponseInArrayMode, customResultMapper) { const stmt = this.client.prepare(query.sql); return new PreparedQuery(stmt, query, this.logger, fields, executeMethod, isResponseInArrayMode, customResultMapper); } transaction(transaction, config = {}) { const tx = new SQLiteBunTransaction("sync", this.dialect, this, this.schema); let result; const nativeTx = this.client.transaction(() => { result = transaction(tx); }); nativeTx[config.behavior ?? "deferred"](); return result; } } class SQLiteBunTransaction extends SQLiteTransaction { static [entityKind] = "SQLiteBunTransaction"; transaction(transaction) { const savepointName = `sp${this.nestedIndex}`; const tx = new SQLiteBunTransaction("sync", this.dialect, this.session, this.schema, this.nestedIndex + 1); this.session.run(sql.raw(`savepoint ${savepointName}`)); try { const result = transaction(tx); this.session.run(sql.raw(`release savepoint ${savepointName}`)); return result; } catch (err) { this.session.run(sql.raw(`rollback to savepoint ${savepointName}`)); throw err; } } } class PreparedQuery extends SQLitePreparedQuery { constructor(stmt, query, logger, fields, executeMethod, _isResponseInArrayMode, customResultMapper) { super("sync", executeMethod, query); this.stmt = stmt; this.logger = logger; this.fields = fields; this._isResponseInArrayMode = _isResponseInArrayMode; this.customResultMapper = customResultMapper; } static [entityKind] = "SQLiteBunPreparedQuery"; run(placeholderValues) { const params = fillPlaceholders(this.query.params, placeholderValues ?? {}); this.logger.logQuery(this.query.sql, params); return this.stmt.run(...params); } all(placeholderValues) { const { fields, query, logger, joinsNotNullableMap, stmt, customResultMapper } = this; if (!fields && !customResultMapper) { const params = fillPlaceholders(query.params, placeholderValues ?? {}); logger.logQuery(query.sql, params); return stmt.all(...params); } const rows = this.values(placeholderValues); if (customResultMapper) { return customResultMapper(rows); } return rows.map((row) => mapResultRow(fields, row, joinsNotNullableMap)); } get(placeholderValues) { const params = fillPlaceholders(this.query.params, placeholderValues ?? {}); this.logger.logQuery(this.query.sql, params); const row = this.stmt.values(...params)[0]; if (!row) { return; } const { fields, joinsNotNullableMap, customResultMapper } = this; if (!fields && !customResultMapper) { return row; } if (customResultMapper) { return customResultMapper([row]); } return mapResultRow(fields, row, joinsNotNullableMap); } values(placeholderValues) { const params = fillPlaceholders(this.query.params, placeholderValues ?? {}); this.logger.logQuery(this.query.sql, params); return this.stmt.values(...params); } isResponseInArrayMode() { return this._isResponseInArrayMode; } } // ../eve/node_modules/drizzle-orm/bun-sqlite/driver.js class BunSQLiteDatabase extends BaseSQLiteDatabase { static [entityKind] = "BunSQLiteDatabase"; } function construct(client, config = {}) { const dialect = new SQLiteSyncDialect({ casing: config.casing }); let logger; if (config.logger === true) { logger = new DefaultLogger; } else if (config.logger !== false) { logger = config.logger; } let schema; if (config.schema) { const tablesConfig = extractTablesRelationalConfig(config.schema, createTableRelationsHelpers); schema = { fullSchema: config.schema, schema: tablesConfig.tables, tableNamesMap: tablesConfig.tableNamesMap }; } const session = new SQLiteBunSession(client, dialect, schema, { logger }); const db2 = new BunSQLiteDatabase("sync", dialect, session, schema); db2.$client = client; return db2; } function drizzle(...params) { if (params[0] === undefined || typeof params[0] === "string") { const instance = params[0] === undefined ? new Database : new Database(params[0]); return construct(instance, params[1]); } if (isConfig(params[0])) { const { connection, client, ...drizzleConfig } = params[0]; if (client) return construct(client, drizzleConfig); if (typeof connection === "object") { const { source, ...opts } = connection; const options2 = Object.values(opts).filter((v) => v !== undefined).length ? opts : undefined; const instance2 = new Database(source, options2); return construct(instance2, drizzleConfig); } const instance = new Database(connection); return construct(instance, drizzleConfig); } return construct(params[0], params[1]); } ((drizzle2) => { function mock(config) { return construct({}, config); } drizzle2.mock = mock; })(drizzle || (drizzle = {})); // ../eve/dist/db/index.js import { Database as Database2 } from "bun:sqlite"; import { join } from "path"; var DB_PATH = process.env.AUTH_DB_PATH || join(process.cwd(), "../../db/kitten.db"); console.log("Using DB_PATH:", DB_PATH); var sqlite = new Database2(DB_PATH); var db = drizzle(sqlite, { schema: { users, characters, resumeCommands, miningFleets, miningFleetParticipants } }); // ../eve/dist/db/models/character.model.js var CharacterHelper = class CharacterHelper2 { static hasValidToken(character) { return /* @__PURE__ */ new Date < character.expiresAt; } static getScopes(character) { const decoded = jwtDecode(character.accessToken); return typeof decoded.scp === "string" ? [decoded.scp] : decoded.scp; } static hasOnlyPublicScope(character) { return this.getScopes(character).length === 1 && this.hasScope(character, "publicData"); } static getTokens(character) { return { access_token: character.accessToken, refresh_token: character.refreshToken, expires_in: (character.expiresAt.getTime() - Date.now()) / 1000 }; } static hasScope(character, scope) { return this.getScopes(character).includes(scope); } static hasAllScopes(character, scopes) { const has = this.getScopes(character); return scopes.every((scope) => has.includes(scope)); } static find(id) { const result = db.select().from(characters).where(eq(characters.id, id)).limit(1).get(); const c = this.createCharacters(result); return c ? c[0] : undefined; } static findByUser(user) { const result = db.select().from(characters).where(eq(characters.userID, user.id)).all(); return this.createCharacters(result); } static findByUserAndEveID(userID, eveID) { const result = db.select().from(characters).where(and(eq(characters.userID, userID), eq(characters.eveID, eveID))).limit(1).get(); const c = this.createCharacters(result); return c ? c[0] : undefined; } static findByName(userID, name) { const result = db.select().from(characters).where(and(eq(characters.name, name), eq(characters.userID, userID))).limit(1).get(); const c = this.createCharacters(result); return c ? c[0] : undefined; } static findAll() { const result = db.select().from(characters).all(); return this.createCharacters(result); } static create(eveID, name, user, tokens) { return this.save({ eveID, userID: user.id, accessToken: tokens.access_token, expiresAt: /* @__PURE__ */ new Date(tokens.expires_in * 1000), refreshToken: tokens.refresh_token, name, createdAt: /* @__PURE__ */ new Date }); } static createCharacters(query) { if (!query) return []; if (Array.isArray(query)) return query.map((character) => { return { id: character.id, eveID: character.eveID, userID: character.userID, accessToken: character.accessToken, expiresAt: new Date(character.expiresAt), refreshToken: character.refreshToken, name: character.name, createdAt: new Date(character.createdAt), updatedAt: new Date(character.updatedAt) }; }); else return [{ id: query.id, eveID: query.eveID, userID: query.userID, accessToken: query.accessToken, expiresAt: new Date(query.expiresAt), refreshToken: query.refreshToken, name: query.name, createdAt: new Date(query.createdAt), updatedAt: new Date(query.updatedAt) }]; } static save(character) { db.insert(characters).values({ id: character.id, eveID: character.eveID, userID: character.userID, name: character.name, accessToken: character.accessToken, expiresAt: character.expiresAt.getTime(), refreshToken: character.refreshToken, createdAt: Date.now(), updatedAt: Date.now() }).onConflictDoUpdate({ target: characters.id, set: { eveID: character.eveID, userID: character.userID, name: character.name, accessToken: character.accessToken, expiresAt: character.expiresAt.getTime(), refreshToken: character.refreshToken, updatedAt: Date.now() } }).run(); return CharacterHelper2.findByUserAndEveID(character.userID, character.eveID); } static delete(character) { db.delete(characters).where(eq(characters.id, character.id)).run(); } static async refreshTokens(character, scopes) { const tokens = await refresh({ refresh_token: character.refreshToken }, scopes); const decoded = await validateToken(tokens.access_token); if (!decoded) { console.error(`Failed to validate token for character ${character.eveID}`); return character; } character.accessToken = tokens.access_token; character.expiresAt = new Date(Date.now() + tokens.expires_in * 1000); character.refreshToken = tokens.refresh_token; this.save(character); return character; } }; // ../eve/dist/esi/fetch.js var cache = /* @__PURE__ */ new Map; function cleanCache() { const now = Date.now(); for (const [key, value] of cache) if (value.expires < now) cache.delete(key); } setInterval(cleanCache, 1000 * 60 * 15); var defaultCacheDuration = 1000 * 60 * 30; async function esiFetch(path, character, { method = "GET", body, noCache = false, cacheDuration = defaultCacheDuration } = {}) { try { const headers = { "User-Agent": options.user_agent, Accept: "application/json" }; if (character) { if (!CharacterHelper.hasValidToken(character)) { await CharacterHelper.refreshTokens(character); if (!CharacterHelper.hasValidToken(character)) throw new Error(`Failed to refresh token for character: ${character.eveID}`); } headers["Authorization"] = `Bearer ${character.accessToken}`; } const init = { headers, method: method || "GET", body: body || undefined }; const url = new URL(`${ESI_LATEST_URL}${path.startsWith("/") ? path : "/" + path}`); url.searchParams.set("datasource", "tranquility"); if (!noCache && init.method === "GET") { const cached = cache.get(url.href); if (cached && cached?.expires > Date.now()) return cached.data; } const res = await fetch(url, init); const data = await res.json(); if (!res.ok) { console.error(`ESI request failure at ${path} | ${res.status}:${res.statusText} => ${JSON.stringify(data)}`); return null; } if (init.method === "GET") cache.set(url.href, { expires: Math.max(res.headers.get("expires") && new Date(Number(res.headers.get("expires") || "")).getTime() || 0, Date.now() + cacheDuration), data }); return data; } catch (err) { console.error(`ESI request failure at ${path} | ${JSON.stringify(err)}`, err); return null; } } // ../eve/dist/esi/character.js var character_exports = {}; __export(character_exports, { getCharacterAffiliations: () => getCharacterAffiliations, getCharacterAgentResearch: () => getCharacterAgentResearch, getCharacterAssetLocations: () => getCharacterAssetLocations, getCharacterAssetNames: () => getCharacterAssetNames, getCharacterAssets: () => getCharacterAssets, getCharacterBlueprints: () => getCharacterBlueprints, getCharacterClones: () => getCharacterClones, getCharacterContactNotifications: () => getCharacterContactNotifications, getCharacterCorporationHistory: () => getCharacterCorporationHistory, getCharacterCurrentShip: () => getCharacterCurrentShip, getCharacterImplants: () => getCharacterImplants, getCharacterJumpFatigue: () => getCharacterJumpFatigue, getCharacterLocation: () => getCharacterLocation, getCharacterMedals: () => getCharacterMedals, getCharacterNotifications: () => getCharacterNotifications, getCharacterOnline: () => getCharacterOnline, getCharacterPortraits: () => getCharacterPortraits, getCharacterPublicData: () => getCharacterPublicData, getCharacterRoles: () => getCharacterRoles, getCharacterStandings: () => getCharacterStandings, getCharacterTitles: () => getCharacterTitles, getCharacterWallet: () => getCharacterWallet, getCharacterWalletJournal: () => getCharacterWalletJournal, getCharacterWalletTransactions: () => getCharacterWalletTransactions, getPortraitURL: () => getPortraitURL }); function getCharacterPublicData(id) { return esiFetch(`/characters/${id}/`); } function getCharacterAffiliations(ids) { return esiFetch(`/characters/affiliation/`, undefined, { method: "POST", body: JSON.stringify(ids) })[0]; } function getCharacterPortraits(id) { return esiFetch(`/characters/${id}/portrait/`); } function getCharacterCorporationHistory(id) { return esiFetch(`/characters/${id}/corporationhistory/`); } function getPortraitURL(id) { return `https://images.evetech.net/characters/${id}/portrait`; } function getCharacterRoles(character) { if (!CharacterHelper.hasScope(character, "esi-characters.read_corporation_roles.v1")) return null; return esiFetch(`/characters/${character.eveID}/roles/`, character); } function getCharacterTitles(character) { if (!CharacterHelper.hasScope(character, "esi-characters.read_titles.v1")) return null; return esiFetch(`/characters/${character.eveID}/titles/`, character); } function getCharacterStandings(character) { if (!CharacterHelper.hasScope(character, "esi-characters.read_standings.v1")) return null; return esiFetch(`/characters/${character.eveID}/standings/`, character); } function getCharacterNotifications(character) { if (!CharacterHelper.hasScope(character, "esi-characters.read_notifications.v1")) return null; return esiFetch(`/characters/${character.eveID}/notifications/`, character); } function getCharacterContactNotifications(character) { if (!CharacterHelper.hasScope(character, "esi-characters.read_notifications.v1")) return null; return esiFetch(`/characters/${character.eveID}/notifications/contacts`, character); } function getCharacterMedals(character) { if (!CharacterHelper.hasScope(character, "esi-characters.read_medals.v1")) return null; return esiFetch(`/characters/${character.eveID}/medals/`, character); } function getCharacterJumpFatigue(character) { if (!CharacterHelper.hasScope(character, "esi-characters.read_fatigue.v1")) return null; return esiFetch(`/characters/${character.eveID}/fatigue/`, character); } function getCharacterBlueprints(character) { if (!CharacterHelper.hasScope(character, "esi-characters.read_blueprints.v1")) return null; return esiFetch(`/characters/${character.eveID}/blueprints/`, character); } function getCharacterAgentResearch(character) { if (!CharacterHelper.hasScope(character, "esi-characters.read_agents_research.v1")) return null; return esiFetch(`/characters/${character.eveID}/agents_research/`, character); } function getCharacterClones(character) { if (!CharacterHelper.hasScope(character, "esi-clones.read_clones.v1")) return null; return esiFetch(`/characters/${character.eveID}/clones/`, character); } function getCharacterImplants(character) { if (!CharacterHelper.hasScope(character, "esi-clones.read_implants.v1")) return null; return esiFetch(`/characters/${character.eveID}/implants/`, character); } function getCharacterAssets(character) { if (!CharacterHelper.hasScope(character, "esi-assets.read_assets.v1")) return null; return esiFetch(`/characters/${character.eveID}/assets/`, character); } function getCharacterAssetLocations(character, ids) { if (!CharacterHelper.hasScope(character, "esi-assets.read_assets.v1")) return null; return esiFetch(`/characters/${character.eveID}/assets/locations/`, character, { method: "POST", body: JSON.stringify(ids) }); } function getCharacterAssetNames(character, ids) { if (!CharacterHelper.hasScope(character, "esi-assets.read_assets.v1")) return null; return esiFetch(`/characters/${character.eveID}/assets/names/`, character, { method: "POST", body: JSON.stringify(ids) }); } function getCharacterWallet(character) { if (!CharacterHelper.hasScope(character, "esi-wallet.read_character_wallet.v1")) return null; return esiFetch(`/characters/${character.eveID}/wallet/`, character); } function getCharacterWalletTransactions(character, fromId) { if (!CharacterHelper.hasScope(character, "esi-wallet.read_character_wallet.v1")) return null; return esiFetch(`/characters/${character.eveID}/wallet/transactions/`, character, { method: "POST", body: JSON.stringify(fromId) }); } function getCharacterWalletJournal(character, page = 1) { if (!CharacterHelper.hasScope(character, "esi-wallet.read_character_wallet.v1")) return null; return esiFetch(`/characters/${character.eveID}/wallet/journal/?page=${page}`, character); } function getCharacterLocation(character) { if (!CharacterHelper.hasScope(character, "esi-location.read_location.v1")) return null; return esiFetch(`/characters/${character.eveID}/location/`, character); } function getCharacterOnline(character) { if (!CharacterHelper.hasScope(character, "esi-location.read_online.v1")) return null; return esiFetch(`/characters/${character.eveID}/online/`, character); } function getCharacterCurrentShip(character) { if (!CharacterHelper.hasScope(character, "esi-location.read_ship_type.v1")) return null; return esiFetch(`/characters/${character.eveID}/ship/`, character); } // ../eve/dist/esi/corporation.js var corporation_exports = {}; __export(corporation_exports, { getCorporationAllianceHistory: () => getCorporationAllianceHistory, getCorporationAssetLocations: () => getCorporationAssetLocations, getCorporationAssetNames: () => getCorporationAssetNames, getCorporationAssets: () => getCorporationAssets, getCorporationData: () => getCorporationData, getCorporationIcons: () => getCorporationIcons }); async function getCorporationData(id) { return await esiFetch(`/corporations/${id}/`); } async function getCorporationAllianceHistory(id) { return await esiFetch(`/corporations/${id}/alliancehistory/`); } async function getCorporationIcons(id) { return await esiFetch(`/corporations/${id}/icons/`); } async function getCorporationAssets(id, character) { if (!CharacterHelper.hasScope(character, "esi-assets.read_corporation_assets.v1")) return null; return await esiFetch(`/corporations/${id}/assets/`, character); } async function getCorporationAssetLocations(id, character, ids) { if (!CharacterHelper.hasScope(character, "esi-assets.read_corporation_assets.v1")) return null; return await esiFetch(`/corporations/${id}/assets/locations/`, character, { method: "POST", body: JSON.stringify(ids) }); } async function getCorporationAssetNames(id, character, ids) { if (!CharacterHelper.hasScope(character, "esi-assets.read_corporation_assets.v1")) return null; return await esiFetch(`/corporations/${id}/assets/names/`, character, { method: "POST", body: JSON.stringify(ids) }); } // ../eve/dist/esi/alliance.js var alliance_exports = {}; __export(alliance_exports, { getAllianceCorporations: () => getAllianceCorporations, getAllianceData: () => getAllianceData, getAllianceIcons: () => getAllianceIcons }); async function getAllianceData(id) { return await esiFetch(`/alliances/${id}/`); } async function getAllianceCorporations(id) { return await esiFetch(`/alliances/${id}/corporations/`); } async function getAllianceIcons(id) { return await esiFetch(`/alliances/${id}/icons/`); } // ../eve/dist/esi/skills.js function getCharacterSkillQueue(character) { if (!CharacterHelper.hasScope(character, "esi-skills.read_skillqueue.v1")) return null; return esiFetch(`/characters/${character.eveID}/skillqueue`, character); } function calculateTrainingPercentage(queuedSkill) { const trainingStartPosition = (queuedSkill.training_start_sp - queuedSkill.level_start_sp) / queuedSkill.level_end_sp; const timePosition = ((/* @__PURE__ */ new Date()).getTime() - new Date(queuedSkill.start_date).getTime()) / (new Date(queuedSkill.finish_date).getTime() - new Date(queuedSkill.start_date).getTime()); return trainingStartPosition + (1 - trainingStartPosition) * timePosition; } // src/utils/cookies.ts function getCookies(headers) { if (!headers) return {}; const cookieHeader = headers.get("Cookie"); const cookies = {}; if (cookieHeader === null) return {}; for (const kv of cookieHeader.split(";")) { const [cookieKey, ...cookieVal] = kv.split("="); const key = cookieKey.trim(); cookies[key] = cookieVal.join("="); } return cookies; } function setCookie(response, key, value, maxAge) { response.headers.append("Set-Cookie", `${key}=${value}${maxAge ? "; Path=/; Max-Age=" + maxAge : ""}`); } function removeCookie(response, key) { response.headers.append("Set-Cookie", `${key}=""; Path=/; Max-Age=-1;`); } // node_modules/oslo/dist/encoding/hex.js var hexDecodeMap = new Map([ ["0", 0], ["1", 1], ["2", 2], ["3", 3], ["4", 4], ["5", 5], ["6", 6], ["7", 7], ["8", 8], ["9", 9], ["A", 10], ["B", 11], ["C", 12], ["D", 13], ["E", 14], ["F", 15], ["a", 10], ["b", 11], ["c", 12], ["d", 13], ["e", 14], ["f", 15] ]); // node_modules/oslo/dist/encoding/base32.js class Base32Encoding { alphabet; padding; decodeMap = new Map; constructor(alphabet2, options2) { if (alphabet2.length !== 32) { throw new Error("Invalid alphabet"); } this.alphabet = alphabet2; this.padding = options2?.padding ?? "="; if (this.alphabet.includes(this.padding) || this.padding.length !== 1) { throw new Error("Invalid padding"); } for (let i = 0;i < alphabet2.length; i++) { this.decodeMap.set(alphabet2[i], i); } } encode(data, options2) { let result = ""; let buffer = 0; let shift = 0; for (let i = 0;i < data.length; i++) { buffer = buffer << 8 | data[i]; shift += 8; while (shift >= 5) { shift -= 5; result += this.alphabet[buffer >> shift & 31]; } } if (shift > 0) { result += this.alphabet[buffer << 5 - shift & 31]; } const includePadding = options2?.includePadding ?? true; if (includePadding) { const padCount = (8 - result.length % 8) % 8; for (let i = 0;i < padCount; i++) { result += "="; } } return result; } decode(data, options2) { const strict = options2?.strict ?? true; const chunkCount = Math.ceil(data.length / 8); const result = []; for (let i = 0;i < chunkCount; i++) { let padCount = 0; const chunks = []; for (let j = 0;j < 8; j++) { const encoded = data[i * 8 + j]; if (encoded === "=") { if (i + 1 !== chunkCount) { throw new Error(`Invalid character: ${encoded}`); } padCount += 1; continue; } if (encoded === undefined) { if (strict) { throw new Error("Invalid data"); } padCount += 1; continue; } const value = this.decodeMap.get(encoded) ?? null; if (value === null) { throw new Error(`Invalid character: ${encoded}`); } chunks.push(value); } if (padCount === 8 || padCount === 7 || padCount === 5 || padCount === 2) { throw new Error("Invalid padding"); } const byte1 = (chunks[0] << 3) + (chunks[1] >> 2); result.push(byte1); if (padCount < 6) { const byte2 = ((chunks[1] & 3) << 6) + (chunks[2] << 1) + (chunks[3] >> 4); result.push(byte2); } if (padCount < 4) { const byte3 = ((chunks[3] & 255) << 4) + (chunks[4] >> 1); result.push(byte3); } if (padCount < 3) { const byte4 = ((chunks[4] & 1) << 7) + (chunks[5] << 2) + (chunks[6] >> 3); result.push(byte4); } if (padCount < 1) { const byte5 = ((chunks[6] & 7) << 5) + chunks[7]; result.push(byte5); } } return Uint8Array.from(result); } } var base32 = new Base32Encoding("ABCDEFGHIJKLMNOPQRSTUVWXYZ234567"); var base32hex = new Base32Encoding("0123456789ABCDEFGHIJKLMNOPQRSTUV"); // node_modules/oslo/dist/encoding/base64.js class Base64Encoding { alphabet; padding; decodeMap = new Map; constructor(alphabet2, options2) { if (alphabet2.length !== 64) { throw new Error("Invalid alphabet"); } this.alphabet = alphabet2; this.padding = options2?.padding ?? "="; if (this.alphabet.includes(this.padding) || this.padding.length !== 1) { throw new Error("Invalid padding"); } for (let i = 0;i < alphabet2.length; i++) { this.decodeMap.set(alphabet2[i], i); } } encode(data, options2) { let result = ""; let buffer = 0; let shift = 0; for (let i = 0;i < data.length; i++) { buffer = buffer << 8 | data[i]; shift += 8; while (shift >= 6) { shift += -6; result += this.alphabet[buffer >> shift & 63]; } } if (shift > 0) { result += this.alphabet[buffer << 6 - shift & 63]; } const includePadding = options2?.includePadding ?? true; if (includePadding) { const padCount = (4 - result.length % 4) % 4; for (let i = 0;i < padCount; i++) { result += "="; } } return result; } decode(data, options2) { const strict = options2?.strict ?? true; const chunkCount = Math.ceil(data.length / 4); const result = []; for (let i = 0;i < chunkCount; i++) { let padCount = 0; let buffer = 0; for (let j = 0;j < 4; j++) { const encoded = data[i * 4 + j]; if (encoded === "=") { if (i + 1 !== chunkCount) { throw new Error(`Invalid character: ${encoded}`); } padCount += 1; continue; } if (encoded === undefined) { if (strict) { throw new Error("Invalid data"); } padCount += 1; continue; } const value = this.decodeMap.get(encoded) ?? null; if (value === null) { throw new Error(`Invalid character: ${encoded}`); } buffer += value << 6 * (3 - j); } result.push(buffer >> 16 & 255); if (padCount < 2) { result.push(buffer >> 8 & 255); } if (padCount < 1) { result.push(buffer & 255); } } return Uint8Array.from(result); } } var base64 = new Base64Encoding("ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/"); var base64url = new Base64Encoding("ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789-_"); // node_modules/oslo/dist/oauth2/index.js class OAuth2RequestError extends Error { request; description; constructor(request, body) { super(body.error ?? ""); this.request = request; this.description = body.error_description ?? null; } } // src/middleware.ts async function middleware(req) { req.store.set("options", options); const redirect = async (scopes) => { const { url, state } = await createAuthorizationURL(scopes); const response = new Response("", { status: 302 }); setCookie(response, "state", state, 60 * 10); response.headers.set("location", url.href); return response; }; const eveauth = { validateAuthorizationCode: (code) => { try { return validateAuthorizationCode(code); } catch (error) { throw new OAuth2RequestError(req, { error: `Failed to authenticate with EVE Online ${error}` }); } }, validateToken, validate: async (response) => { const query = new URL(req.url).searchParams; const code = query.get("code"); if (!code) { throw Error(`code missing from query parameters, there may be an error with the OAuth provider`); } const cookies = getCookies(req.headers); if (cookies["state"] !== query.get("state")) throw Error("invalid state"); removeCookie(response, "state"); try { const tokens = await validateAuthorizationCode(code); const decoded = await validateToken(tokens.access_token); if (!decoded) throw "Invalid Token"; return tokens; } catch (error) { throw new OAuth2RequestError(req, { error: `Failed to authenticate with EVE Online ${error}` }); } }, redirect }; req.store.set("eveauth", eveauth); } export { middleware as default }; //# debugId=F43A0BF57718A84E64756E2164756E21 //# sourceMappingURL=data:application/json;base64,{
  "version": 3,
  "sources": ["..\\..\\eve\\node_modules\\safe-buffer\\index.js", "..\\..\\eve\\node_modules\\jws\\lib\\data-stream.js", "..\\..\\eve\\node_modules\\ecdsa-sig-formatter\\src\\param-bytes-for-alg.js", "..\\..\\eve\\node_modules\\ecdsa-sig-formatter\\src\\ecdsa-sig-formatter.js", "..\\..\\eve\\node_modules\\buffer-equal-constant-time\\index.js", "..\\..\\eve\\node_modules\\jwa\\index.js", "..\\..\\eve\\node_modules\\jws\\lib\\tostring.js", "..\\..\\eve\\node_modules\\jws\\lib\\sign-stream.js", "..\\..\\eve\\node_modules\\jws\\lib\\verify-stream.js", "..\\..\\eve\\node_modules\\jws\\index.js", "..\\..\\eve\\node_modules\\jsonwebtoken\\decode.js", "..\\..\\eve\\node_modules\\jsonwebtoken\\lib\\JsonWebTokenError.js", "..\\..\\eve\\node_modules\\jsonwebtoken\\lib\\NotBeforeError.js", "..\\..\\eve\\node_modules\\jsonwebtoken\\lib\\TokenExpiredError.js", "..\\..\\eve\\node_modules\\ms\\index.js", "..\\..\\eve\\node_modules\\jsonwebtoken\\lib\\timespan.js", "..\\..\\eve\\node_modules\\semver\\internal\\constants.js", "..\\..\\eve\\node_modules\\semver\\internal\\debug.js", "..\\..\\eve\\node_modules\\semver\\internal\\re.js", "..\\..\\eve\\node_modules\\semver\\internal\\parse-options.js", "..\\..\\eve\\node_modules\\semver\\internal\\identifiers.js", "..\\..\\eve\\node_modules\\semver\\classes\\semver.js", "..\\..\\eve\\node_modules\\semver\\functions\\parse.js", "..\\..\\eve\\node_modules\\semver\\functions\\valid.js", "..\\..\\eve\\node_modules\\semver\\functions\\clean.js", "..\\..\\eve\\node_modules\\semver\\functions\\inc.js", "..\\..\\eve\\node_modules\\semver\\functions\\diff.js", "..\\..\\eve\\node_modules\\semver\\functions\\major.js", "..\\..\\eve\\node_modules\\semver\\functions\\minor.js", "..\\..\\eve\\node_modules\\semver\\functions\\patch.js", "..\\..\\eve\\node_modules\\semver\\functions\\prerelease.js", "..\\..\\eve\\node_modules\\semver\\functions\\compare.js", "..\\..\\eve\\node_modules\\semver\\functions\\rcompare.js", "..\\..\\eve\\node_modules\\semver\\functions\\compare-loose.js", "..\\..\\eve\\node_modules\\semver\\functions\\compare-build.js", "..\\..\\eve\\node_modules\\semver\\functions\\sort.js", "..\\..\\eve\\node_modules\\semver\\functions\\rsort.js", "..\\..\\eve\\node_modules\\semver\\functions\\gt.js", "..\\..\\eve\\node_modules\\semver\\functions\\lt.js", "..\\..\\eve\\node_modules\\semver\\functions\\eq.js", "..\\..\\eve\\node_modules\\semver\\functions\\neq.js", "..\\..\\eve\\node_modules\\semver\\functions\\gte.js", "..\\..\\eve\\node_modules\\semver\\functions\\lte.js", "..\\..\\eve\\node_modules\\semver\\functions\\cmp.js", "..\\..\\eve\\node_modules\\semver\\functions\\coerce.js", "..\\..\\eve\\node_modules\\semver\\internal\\lrucache.js", "..\\..\\eve\\node_modules\\semver\\classes\\range.js", "..\\..\\eve\\node_modules\\semver\\classes\\comparator.js", "..\\..\\eve\\node_modules\\semver\\functions\\satisfies.js", "..\\..\\eve\\node_modules\\semver\\ranges\\to-comparators.js", "..\\..\\eve\\node_modules\\semver\\ranges\\max-satisfying.js", "..\\..\\eve\\node_modules\\semver\\ranges\\min-satisfying.js", "..\\..\\eve\\node_modules\\semver\\ranges\\min-version.js", "..\\..\\eve\\node_modules\\semver\\ranges\\valid.js", "..\\..\\eve\\node_modules\\semver\\ranges\\outside.js", "..\\..\\eve\\node_modules\\semver\\ranges\\gtr.js", "..\\..\\eve\\node_modules\\semver\\ranges\\ltr.js", "..\\..\\eve\\node_modules\\semver\\ranges\\intersects.js", "..\\..\\eve\\node_modules\\semver\\ranges\\simplify.js", "..\\..\\eve\\node_modules\\semver\\ranges\\subset.js", "..\\..\\eve\\node_modules\\semver\\index.js", "..\\..\\eve\\node_modules\\jsonwebtoken\\lib\\asymmetricKeyDetailsSupported.js", "..\\..\\eve\\node_modules\\jsonwebtoken\\lib\\rsaPssKeyDetailsSupported.js", "..\\..\\eve\\node_modules\\jsonwebtoken\\lib\\validateAsymmetricKey.js", "..\\..\\eve\\node_modules\\jsonwebtoken\\lib\\psSupported.js", "..\\..\\eve\\node_modules\\jsonwebtoken\\verify.js", "..\\..\\eve\\node_modules\\lodash.includes\\index.js", "..\\..\\eve\\node_modules\\lodash.isboolean\\index.js", "..\\..\\eve\\node_modules\\lodash.isinteger\\index.js", "..\\..\\eve\\node_modules\\lodash.isnumber\\index.js", "..\\..\\eve\\node_modules\\lodash.isplainobject\\index.js", "..\\..\\eve\\node_modules\\lodash.isstring\\index.js", "..\\..\\eve\\node_modules\\lodash.once\\index.js", "..\\..\\eve\\node_modules\\jsonwebtoken\\sign.js", "..\\..\\eve\\node_modules\\jsonwebtoken\\index.js", "..\\..\\eve\\node_modules\\bn.js\\lib\\bn.js", "..\\..\\eve\\node_modules\\inherits\\inherits_browser.js", "..\\..\\eve\\node_modules\\inherits\\inherits.js", "..\\..\\eve\\node_modules\\safer-buffer\\safer.js", "..\\..\\eve\\node_modules\\asn1.js\\lib\\asn1\\base\\reporter.js", "..\\..\\eve\\node_modules\\asn1.js\\lib\\asn1\\base\\buffer.js", "..\\..\\eve\\node_modules\\minimalistic-assert\\index.js", "..\\..\\eve\\node_modules\\asn1.js\\lib\\asn1\\base\\node.js", "..\\..\\eve\\node_modules\\asn1.js\\lib\\asn1\\constants\\der.js", "..\\..\\eve\\node_modules\\asn1.js\\lib\\asn1\\encoders\\der.js", "..\\..\\eve\\node_modules\\asn1.js\\lib\\asn1\\encoders\\pem.js", "..\\..\\eve\\node_modules\\asn1.js\\lib\\asn1\\encoders\\index.js", "..\\..\\eve\\node_modules\\asn1.js\\lib\\asn1\\decoders\\der.js", "..\\..\\eve\\node_modules\\asn1.js\\lib\\asn1\\decoders\\pem.js", "..\\..\\eve\\node_modules\\asn1.js\\lib\\asn1\\decoders\\index.js", "..\\..\\eve\\node_modules\\asn1.js\\lib\\asn1\\api.js", "..\\..\\eve\\node_modules\\asn1.js\\lib\\asn1\\base\\index.js", "..\\..\\eve\\node_modules\\asn1.js\\lib\\asn1\\constants\\index.js", "..\\..\\eve\\node_modules\\asn1.js\\lib\\asn1.js", "..\\..\\eve\\node_modules\\minimalistic-crypto-utils\\lib\\utils.js", "..\\..\\eve\\node_modules\\elliptic\\lib\\elliptic\\utils.js", "..\\..\\eve\\node_modules\\brorand\\index.js", "..\\..\\eve\\node_modules\\elliptic\\lib\\elliptic\\curve\\base.js", "..\\..\\eve\\node_modules\\elliptic\\lib\\elliptic\\curve\\short.js", "..\\..\\eve\\node_modules\\elliptic\\lib\\elliptic\\curve\\mont.js", "..\\..\\eve\\node_modules\\elliptic\\lib\\elliptic\\curve\\edwards.js", "..\\..\\eve\\node_modules\\elliptic\\lib\\elliptic\\curve\\index.js", "..\\..\\eve\\node_modules\\hash.js\\lib\\hash\\utils.js", "..\\..\\eve\\node_modules\\hash.js\\lib\\hash\\common.js", "..\\..\\eve\\node_modules\\hash.js\\lib\\hash\\sha\\common.js", "..\\..\\eve\\node_modules\\hash.js\\lib\\hash\\sha\\1.js", "..\\..\\eve\\node_modules\\hash.js\\lib\\hash\\sha\\256.js", "..\\..\\eve\\node_modules\\hash.js\\lib\\hash\\sha\\224.js", "..\\..\\eve\\node_modules\\hash.js\\lib\\hash\\sha\\512.js", "..\\..\\eve\\node_modules\\hash.js\\lib\\hash\\sha\\384.js", "..\\..\\eve\\node_modules\\hash.js\\lib\\hash\\sha.js", "..\\..\\eve\\node_modules\\hash.js\\lib\\hash\\ripemd.js", "..\\..\\eve\\node_modules\\hash.js\\lib\\hash\\hmac.js", "..\\..\\eve\\node_modules\\hash.js\\lib\\hash.js", "..\\..\\eve\\node_modules\\elliptic\\lib\\elliptic\\precomputed\\secp256k1.js", "..\\..\\eve\\node_modules\\elliptic\\lib\\elliptic\\curves.js", "..\\..\\eve\\node_modules\\hmac-drbg\\lib\\hmac-drbg.js", "..\\..\\eve\\node_modules\\elliptic\\lib\\elliptic\\ec\\key.js", "..\\..\\eve\\node_modules\\elliptic\\lib\\elliptic\\ec\\signature.js", "..\\..\\eve\\node_modules\\elliptic\\lib\\elliptic\\ec\\index.js", "..\\..\\eve\\node_modules\\elliptic\\lib\\elliptic\\eddsa\\key.js", "..\\..\\eve\\node_modules\\elliptic\\lib\\elliptic\\eddsa\\signature.js", "..\\..\\eve\\node_modules\\elliptic\\lib\\elliptic\\eddsa\\index.js", "..\\..\\eve\\node_modules\\elliptic\\lib\\elliptic.js", "..\\..\\eve\\node_modules\\jwk-to-pem\\src\\b64-to-bn.js", "..\\..\\eve\\node_modules\\jwk-to-pem\\src\\asn1\\algorithm-identifier.js", "..\\..\\eve\\node_modules\\jwk-to-pem\\src\\asn1\\public-key-info.js", "..\\..\\eve\\node_modules\\jwk-to-pem\\src\\asn1\\version.js", "..\\..\\eve\\node_modules\\jwk-to-pem\\src\\asn1\\private-key-info.js", "..\\..\\eve\\node_modules\\jwk-to-pem\\src\\ec.js", "..\\..\\eve\\node_modules\\jwk-to-pem\\src\\rsa.js", "..\\..\\eve\\node_modules\\jwk-to-pem\\src\\jwk-to-pem.js", "..\\..\\eve\\dist\\esi\\options.js", "..\\..\\eve\\dist\\_virtual\\rolldown_runtime.js", "..\\..\\eve\\node_modules\\jwt-decode\\build\\esm\\index.js", "..\\..\\eve\\node_modules\\@oslojs\\encoding\\dist\\base32.js", "..\\..\\eve\\node_modules\\@oslojs\\encoding\\dist\\base64.js", "..\\..\\eve\\dist\\esi\\auth.js", "..\\..\\eve\\dist\\esi\\scopes.js", "..\\..\\eve\\node_modules\\drizzle-orm\\entity.js", "..\\..\\eve\\node_modules\\drizzle-orm\\column.js", "..\\..\\eve\\node_modules\\drizzle-orm\\column-builder.js", "..\\..\\eve\\node_modules\\drizzle-orm\\table.utils.js", "..\\..\\eve\\node_modules\\drizzle-orm\\tracing-utils.js", "..\\..\\eve\\node_modules\\drizzle-orm\\pg-core\\unique-constraint.js", "..\\..\\eve\\node_modules\\drizzle-orm\\pg-core\\columns\\common.js", "..\\..\\eve\\node_modules\\drizzle-orm\\pg-core\\columns\\enum.js", "..\\..\\eve\\node_modules\\drizzle-orm\\subquery.js", "..\\..\\eve\\node_modules\\drizzle-orm\\version.js", "..\\..\\eve\\node_modules\\drizzle-orm\\tracing.js", "..\\..\\eve\\node_modules\\drizzle-orm\\view-common.js", "..\\..\\eve\\node_modules\\drizzle-orm\\table.js", "..\\..\\eve\\node_modules\\drizzle-orm\\sql\\sql.js", "..\\..\\eve\\node_modules\\drizzle-orm\\alias.js", "..\\..\\eve\\node_modules\\drizzle-orm\\utils.js", "..\\..\\eve\\node_modules\\drizzle-orm\\sqlite-core\\foreign-keys.js", "..\\..\\eve\\node_modules\\drizzle-orm\\sqlite-core\\unique-constraint.js", "..\\..\\eve\\node_modules\\drizzle-orm\\sqlite-core\\columns\\common.js", "..\\..\\eve\\node_modules\\drizzle-orm\\sqlite-core\\columns\\blob.js", "..\\..\\eve\\node_modules\\drizzle-orm\\sqlite-core\\columns\\custom.js", "..\\..\\eve\\node_modules\\drizzle-orm\\sqlite-core\\columns\\integer.js", "..\\..\\eve\\node_modules\\drizzle-orm\\sqlite-core\\columns\\numeric.js", "..\\..\\eve\\node_modules\\drizzle-orm\\sqlite-core\\columns\\real.js", "..\\..\\eve\\node_modules\\drizzle-orm\\sqlite-core\\columns\\text.js", "..\\..\\eve\\node_modules\\drizzle-orm\\selection-proxy.js", "..\\..\\eve\\node_modules\\drizzle-orm\\query-promise.js", "..\\..\\eve\\node_modules\\drizzle-orm\\sqlite-core\\columns\\all.js", "..\\..\\eve\\node_modules\\drizzle-orm\\sqlite-core\\table.js", "..\\..\\eve\\node_modules\\drizzle-orm\\sqlite-core\\indexes.js", "..\\..\\eve\\node_modules\\drizzle-orm\\sqlite-core\\utils.js", "..\\..\\eve\\node_modules\\drizzle-orm\\sqlite-core\\query-builders\\delete.js", "..\\..\\eve\\node_modules\\drizzle-orm\\casing.js", "..\\..\\eve\\node_modules\\drizzle-orm\\errors.js", "..\\..\\eve\\node_modules\\drizzle-orm\\pg-core\\table.js", "..\\..\\eve\\node_modules\\drizzle-orm\\pg-core\\primary-keys.js", "..\\..\\eve\\node_modules\\drizzle-orm\\sql\\expressions\\conditions.js", "..\\..\\eve\\node_modules\\drizzle-orm\\sql\\expressions\\select.js", "..\\..\\eve\\node_modules\\drizzle-orm\\relations.js", "..\\..\\eve\\node_modules\\drizzle-orm\\sqlite-core\\view-base.js", "..\\..\\eve\\node_modules\\drizzle-orm\\sqlite-core\\dialect.js", "..\\..\\eve\\node_modules\\drizzle-orm\\query-builders\\query-builder.js", "..\\..\\eve\\node_modules\\drizzle-orm\\sqlite-core\\query-builders\\select.js", "..\\..\\eve\\node_modules\\drizzle-orm\\sqlite-core\\query-builders\\query-builder.js", "..\\..\\eve\\node_modules\\drizzle-orm\\sqlite-core\\query-builders\\insert.js", "..\\..\\eve\\node_modules\\drizzle-orm\\sqlite-core\\query-builders\\update.js", "..\\..\\eve\\node_modules\\drizzle-orm\\sqlite-core\\query-builders\\count.js", "..\\..\\eve\\node_modules\\drizzle-orm\\sqlite-core\\query-builders\\query.js", "..\\..\\eve\\node_modules\\drizzle-orm\\sqlite-core\\query-builders\\raw.js", "..\\..\\eve\\node_modules\\drizzle-orm\\sqlite-core\\db.js", "..\\..\\eve\\node_modules\\drizzle-orm\\cache\\core\\cache.js", "..\\..\\eve\\node_modules\\drizzle-orm\\sqlite-core\\session.js", "..\\..\\eve\\node_modules\\drizzle-orm\\logger.js", "..\\..\\eve\\dist\\db\\schema.js", "..\\..\\eve\\dist\\db\\models\\user.model.js", "..\\..\\eve\\dist\\db\\models\\resume-command.model.js", "..\\..\\eve\\dist\\db\\models\\index.js", "..\\..\\eve\\node_modules\\drizzle-orm\\bun-sqlite\\driver.js", "..\\..\\eve\\node_modules\\drizzle-orm\\bun-sqlite\\session.js", "..\\..\\eve\\dist\\db\\index.js", "..\\..\\eve\\dist\\db\\models\\character.model.js", "..\\..\\eve\\dist\\esi\\fetch.js", "..\\..\\eve\\dist\\esi\\character.js", "..\\..\\eve\\dist\\esi\\corporation.js", "..\\..\\eve\\dist\\esi\\alliance.js", "..\\..\\eve\\dist\\esi\\skills.js", "..\\src\\utils\\cookies.ts", "..\\node_modules\\oslo\\dist\\encoding\\hex.js", "..\\node_modules\\oslo\\dist\\encoding\\base32.js", "..\\node_modules\\oslo\\dist\\encoding\\base64.js", "..\\node_modules\\oslo\\dist\\oauth2\\index.js", "..\\src\\middleware.ts"],
  "sourcesContent": [
    "/*! safe-buffer. MIT License. Feross Aboukhadijeh <https://feross.org/opensource> */\n/* eslint-disable node/no-deprecated-api */\nvar buffer = require('buffer')\nvar Buffer = buffer.Buffer\n\n// alternative to using Object.keys for old browsers\nfunction copyProps (src, dst) {\n  for (var key in src) {\n    dst[key] = src[key]\n  }\n}\nif (Buffer.from && Buffer.alloc && Buffer.allocUnsafe && Buffer.allocUnsafeSlow) {\n  module.exports = buffer\n} else {\n  // Copy properties from require('buffer')\n  copyProps(buffer, exports)\n  exports.Buffer = SafeBuffer\n}\n\nfunction SafeBuffer (arg, encodingOrOffset, length) {\n  return Buffer(arg, encodingOrOffset, length)\n}\n\nSafeBuffer.prototype = Object.create(Buffer.prototype)\n\n// Copy static methods from Buffer\ncopyProps(Buffer, SafeBuffer)\n\nSafeBuffer.from = function (arg, encodingOrOffset, length) {\n  if (typeof arg === 'number') {\n    throw new TypeError('Argument must not be a number')\n  }\n  return Buffer(arg, encodingOrOffset, length)\n}\n\nSafeBuffer.alloc = function (size, fill, encoding) {\n  if (typeof size !== 'number') {\n    throw new TypeError('Argument must be a number')\n  }\n  var buf = Buffer(size)\n  if (fill !== undefined) {\n    if (typeof encoding === 'string') {\n      buf.fill(fill, encoding)\n    } else {\n      buf.fill(fill)\n    }\n  } else {\n    buf.fill(0)\n  }\n  return buf\n}\n\nSafeBuffer.allocUnsafe = function (size) {\n  if (typeof size !== 'number') {\n    throw new TypeError('Argument must be a number')\n  }\n  return Buffer(size)\n}\n\nSafeBuffer.allocUnsafeSlow = function (size) {\n  if (typeof size !== 'number') {\n    throw new TypeError('Argument must be a number')\n  }\n  return buffer.SlowBuffer(size)\n}\n",
    "/*global module, process*/\nvar Buffer = require('safe-buffer').Buffer;\nvar Stream = require('stream');\nvar util = require('util');\n\nfunction DataStream(data) {\n  this.buffer = null;\n  this.writable = true;\n  this.readable = true;\n\n  // No input\n  if (!data) {\n    this.buffer = Buffer.alloc(0);\n    return this;\n  }\n\n  // Stream\n  if (typeof data.pipe === 'function') {\n    this.buffer = Buffer.alloc(0);\n    data.pipe(this);\n    return this;\n  }\n\n  // Buffer or String\n  // or Object (assumedly a passworded key)\n  if (data.length || typeof data === 'object') {\n    this.buffer = data;\n    this.writable = false;\n    process.nextTick(function () {\n      this.emit('end', data);\n      this.readable = false;\n      this.emit('close');\n    }.bind(this));\n    return this;\n  }\n\n  throw new TypeError('Unexpected data type ('+ typeof data + ')');\n}\nutil.inherits(DataStream, Stream);\n\nDataStream.prototype.write = function write(data) {\n  this.buffer = Buffer.concat([this.buffer, Buffer.from(data)]);\n  this.emit('data', data);\n};\n\nDataStream.prototype.end = function end(data) {\n  if (data)\n    this.write(data);\n  this.emit('end', data);\n  this.emit('close');\n  this.writable = false;\n  this.readable = false;\n};\n\nmodule.exports = DataStream;\n",
    "'use strict';\n\nfunction getParamSize(keySize) {\n\tvar result = ((keySize / 8) | 0) + (keySize % 8 === 0 ? 0 : 1);\n\treturn result;\n}\n\nvar paramBytesForAlg = {\n\tES256: getParamSize(256),\n\tES384: getParamSize(384),\n\tES512: getParamSize(521)\n};\n\nfunction getParamBytesForAlg(alg) {\n\tvar paramBytes = paramBytesForAlg[alg];\n\tif (paramBytes) {\n\t\treturn paramBytes;\n\t}\n\n\tthrow new Error('Unknown algorithm \"' + alg + '\"');\n}\n\nmodule.exports = getParamBytesForAlg;\n",
    "'use strict';\n\nvar Buffer = require('safe-buffer').Buffer;\n\nvar getParamBytesForAlg = require('./param-bytes-for-alg');\n\nvar MAX_OCTET = 0x80,\n\tCLASS_UNIVERSAL = 0,\n\tPRIMITIVE_BIT = 0x20,\n\tTAG_SEQ = 0x10,\n\tTAG_INT = 0x02,\n\tENCODED_TAG_SEQ = (TAG_SEQ | PRIMITIVE_BIT) | (CLASS_UNIVERSAL << 6),\n\tENCODED_TAG_INT = TAG_INT | (CLASS_UNIVERSAL << 6);\n\nfunction base64Url(base64) {\n\treturn base64\n\t\t.replace(/=/g, '')\n\t\t.replace(/\\+/g, '-')\n\t\t.replace(/\\//g, '_');\n}\n\nfunction signatureAsBuffer(signature) {\n\tif (Buffer.isBuffer(signature)) {\n\t\treturn signature;\n\t} else if ('string' === typeof signature) {\n\t\treturn Buffer.from(signature, 'base64');\n\t}\n\n\tthrow new TypeError('ECDSA signature must be a Base64 string or a Buffer');\n}\n\nfunction derToJose(signature, alg) {\n\tsignature = signatureAsBuffer(signature);\n\tvar paramBytes = getParamBytesForAlg(alg);\n\n\t// the DER encoded param should at most be the param size, plus a padding\n\t// zero, since due to being a signed integer\n\tvar maxEncodedParamLength = paramBytes + 1;\n\n\tvar inputLength = signature.length;\n\n\tvar offset = 0;\n\tif (signature[offset++] !== ENCODED_TAG_SEQ) {\n\t\tthrow new Error('Could not find expected \"seq\"');\n\t}\n\n\tvar seqLength = signature[offset++];\n\tif (seqLength === (MAX_OCTET | 1)) {\n\t\tseqLength = signature[offset++];\n\t}\n\n\tif (inputLength - offset < seqLength) {\n\t\tthrow new Error('\"seq\" specified length of \"' + seqLength + '\", only \"' + (inputLength - offset) + '\" remaining');\n\t}\n\n\tif (signature[offset++] !== ENCODED_TAG_INT) {\n\t\tthrow new Error('Could not find expected \"int\" for \"r\"');\n\t}\n\n\tvar rLength = signature[offset++];\n\n\tif (inputLength - offset - 2 < rLength) {\n\t\tthrow new Error('\"r\" specified length of \"' + rLength + '\", only \"' + (inputLength - offset - 2) + '\" available');\n\t}\n\n\tif (maxEncodedParamLength < rLength) {\n\t\tthrow new Error('\"r\" specified length of \"' + rLength + '\", max of \"' + maxEncodedParamLength + '\" is acceptable');\n\t}\n\n\tvar rOffset = offset;\n\toffset += rLength;\n\n\tif (signature[offset++] !== ENCODED_TAG_INT) {\n\t\tthrow new Error('Could not find expected \"int\" for \"s\"');\n\t}\n\n\tvar sLength = signature[offset++];\n\n\tif (inputLength - offset !== sLength) {\n\t\tthrow new Error('\"s\" specified length of \"' + sLength + '\", expected \"' + (inputLength - offset) + '\"');\n\t}\n\n\tif (maxEncodedParamLength < sLength) {\n\t\tthrow new Error('\"s\" specified length of \"' + sLength + '\", max of \"' + maxEncodedParamLength + '\" is acceptable');\n\t}\n\n\tvar sOffset = offset;\n\toffset += sLength;\n\n\tif (offset !== inputLength) {\n\t\tthrow new Error('Expected to consume entire buffer, but \"' + (inputLength - offset) + '\" bytes remain');\n\t}\n\n\tvar rPadding = paramBytes - rLength,\n\t\tsPadding = paramBytes - sLength;\n\n\tvar dst = Buffer.allocUnsafe(rPadding + rLength + sPadding + sLength);\n\n\tfor (offset = 0; offset < rPadding; ++offset) {\n\t\tdst[offset] = 0;\n\t}\n\tsignature.copy(dst, offset, rOffset + Math.max(-rPadding, 0), rOffset + rLength);\n\n\toffset = paramBytes;\n\n\tfor (var o = offset; offset < o + sPadding; ++offset) {\n\t\tdst[offset] = 0;\n\t}\n\tsignature.copy(dst, offset, sOffset + Math.max(-sPadding, 0), sOffset + sLength);\n\n\tdst = dst.toString('base64');\n\tdst = base64Url(dst);\n\n\treturn dst;\n}\n\nfunction countPadding(buf, start, stop) {\n\tvar padding = 0;\n\twhile (start + padding < stop && buf[start + padding] === 0) {\n\t\t++padding;\n\t}\n\n\tvar needsSign = buf[start + padding] >= MAX_OCTET;\n\tif (needsSign) {\n\t\t--padding;\n\t}\n\n\treturn padding;\n}\n\nfunction joseToDer(signature, alg) {\n\tsignature = signatureAsBuffer(signature);\n\tvar paramBytes = getParamBytesForAlg(alg);\n\n\tvar signatureBytes = signature.length;\n\tif (signatureBytes !== paramBytes * 2) {\n\t\tthrow new TypeError('\"' + alg + '\" signatures must be \"' + paramBytes * 2 + '\" bytes, saw \"' + signatureBytes + '\"');\n\t}\n\n\tvar rPadding = countPadding(signature, 0, paramBytes);\n\tvar sPadding = countPadding(signature, paramBytes, signature.length);\n\tvar rLength = paramBytes - rPadding;\n\tvar sLength = paramBytes - sPadding;\n\n\tvar rsBytes = 1 + 1 + rLength + 1 + 1 + sLength;\n\n\tvar shortLength = rsBytes < MAX_OCTET;\n\n\tvar dst = Buffer.allocUnsafe((shortLength ? 2 : 3) + rsBytes);\n\n\tvar offset = 0;\n\tdst[offset++] = ENCODED_TAG_SEQ;\n\tif (shortLength) {\n\t\t// Bit 8 has value \"0\"\n\t\t// bits 7-1 give the length.\n\t\tdst[offset++] = rsBytes;\n\t} else {\n\t\t// Bit 8 of first octet has value \"1\"\n\t\t// bits 7-1 give the number of additional length octets.\n\t\tdst[offset++] = MAX_OCTET\t| 1;\n\t\t// length, base 256\n\t\tdst[offset++] = rsBytes & 0xff;\n\t}\n\tdst[offset++] = ENCODED_TAG_INT;\n\tdst[offset++] = rLength;\n\tif (rPadding < 0) {\n\t\tdst[offset++] = 0;\n\t\toffset += signature.copy(dst, offset, 0, paramBytes);\n\t} else {\n\t\toffset += signature.copy(dst, offset, rPadding, paramBytes);\n\t}\n\tdst[offset++] = ENCODED_TAG_INT;\n\tdst[offset++] = sLength;\n\tif (sPadding < 0) {\n\t\tdst[offset++] = 0;\n\t\tsignature.copy(dst, offset, paramBytes);\n\t} else {\n\t\tsignature.copy(dst, offset, paramBytes + sPadding);\n\t}\n\n\treturn dst;\n}\n\nmodule.exports = {\n\tderToJose: derToJose,\n\tjoseToDer: joseToDer\n};\n",
    "/*jshint node:true */\n'use strict';\nvar Buffer = require('buffer').Buffer; // browserify\nvar SlowBuffer = require('buffer').SlowBuffer;\n\nmodule.exports = bufferEq;\n\nfunction bufferEq(a, b) {\n\n  // shortcutting on type is necessary for correctness\n  if (!Buffer.isBuffer(a) || !Buffer.isBuffer(b)) {\n    return false;\n  }\n\n  // buffer sizes should be well-known information, so despite this\n  // shortcutting, it doesn't leak any information about the *contents* of the\n  // buffers.\n  if (a.length !== b.length) {\n    return false;\n  }\n\n  var c = 0;\n  for (var i = 0; i < a.length; i++) {\n    /*jshint bitwise:false */\n    c |= a[i] ^ b[i]; // XOR\n  }\n  return c === 0;\n}\n\nbufferEq.install = function() {\n  Buffer.prototype.equal = SlowBuffer.prototype.equal = function equal(that) {\n    return bufferEq(this, that);\n  };\n};\n\nvar origBufEqual = Buffer.prototype.equal;\nvar origSlowBufEqual = SlowBuffer.prototype.equal;\nbufferEq.restore = function() {\n  Buffer.prototype.equal = origBufEqual;\n  SlowBuffer.prototype.equal = origSlowBufEqual;\n};\n",
    "var Buffer = require('safe-buffer').Buffer;\nvar crypto = require('crypto');\nvar formatEcdsa = require('ecdsa-sig-formatter');\nvar util = require('util');\n\nvar MSG_INVALID_ALGORITHM = '\"%s\" is not a valid algorithm.\\n  Supported algorithms are:\\n  \"HS256\", \"HS384\", \"HS512\", \"RS256\", \"RS384\", \"RS512\", \"PS256\", \"PS384\", \"PS512\", \"ES256\", \"ES384\", \"ES512\" and \"none\".'\nvar MSG_INVALID_SECRET = 'secret must be a string or buffer';\nvar MSG_INVALID_VERIFIER_KEY = 'key must be a string or a buffer';\nvar MSG_INVALID_SIGNER_KEY = 'key must be a string, a buffer or an object';\n\nvar supportsKeyObjects = typeof crypto.createPublicKey === 'function';\nif (supportsKeyObjects) {\n  MSG_INVALID_VERIFIER_KEY += ' or a KeyObject';\n  MSG_INVALID_SECRET += 'or a KeyObject';\n}\n\nfunction checkIsPublicKey(key) {\n  if (Buffer.isBuffer(key)) {\n    return;\n  }\n\n  if (typeof key === 'string') {\n    return;\n  }\n\n  if (!supportsKeyObjects) {\n    throw typeError(MSG_INVALID_VERIFIER_KEY);\n  }\n\n  if (typeof key !== 'object') {\n    throw typeError(MSG_INVALID_VERIFIER_KEY);\n  }\n\n  if (typeof key.type !== 'string') {\n    throw typeError(MSG_INVALID_VERIFIER_KEY);\n  }\n\n  if (typeof key.asymmetricKeyType !== 'string') {\n    throw typeError(MSG_INVALID_VERIFIER_KEY);\n  }\n\n  if (typeof key.export !== 'function') {\n    throw typeError(MSG_INVALID_VERIFIER_KEY);\n  }\n};\n\nfunction checkIsPrivateKey(key) {\n  if (Buffer.isBuffer(key)) {\n    return;\n  }\n\n  if (typeof key === 'string') {\n    return;\n  }\n\n  if (typeof key === 'object') {\n    return;\n  }\n\n  throw typeError(MSG_INVALID_SIGNER_KEY);\n};\n\nfunction checkIsSecretKey(key) {\n  if (Buffer.isBuffer(key)) {\n    return;\n  }\n\n  if (typeof key === 'string') {\n    return key;\n  }\n\n  if (!supportsKeyObjects) {\n    throw typeError(MSG_INVALID_SECRET);\n  }\n\n  if (typeof key !== 'object') {\n    throw typeError(MSG_INVALID_SECRET);\n  }\n\n  if (key.type !== 'secret') {\n    throw typeError(MSG_INVALID_SECRET);\n  }\n\n  if (typeof key.export !== 'function') {\n    throw typeError(MSG_INVALID_SECRET);\n  }\n}\n\nfunction fromBase64(base64) {\n  return base64\n    .replace(/=/g, '')\n    .replace(/\\+/g, '-')\n    .replace(/\\//g, '_');\n}\n\nfunction toBase64(base64url) {\n  base64url = base64url.toString();\n\n  var padding = 4 - base64url.length % 4;\n  if (padding !== 4) {\n    for (var i = 0; i < padding; ++i) {\n      base64url += '=';\n    }\n  }\n\n  return base64url\n    .replace(/\\-/g, '+')\n    .replace(/_/g, '/');\n}\n\nfunction typeError(template) {\n  var args = [].slice.call(arguments, 1);\n  var errMsg = util.format.bind(util, template).apply(null, args);\n  return new TypeError(errMsg);\n}\n\nfunction bufferOrString(obj) {\n  return Buffer.isBuffer(obj) || typeof obj === 'string';\n}\n\nfunction normalizeInput(thing) {\n  if (!bufferOrString(thing))\n    thing = JSON.stringify(thing);\n  return thing;\n}\n\nfunction createHmacSigner(bits) {\n  return function sign(thing, secret) {\n    checkIsSecretKey(secret);\n    thing = normalizeInput(thing);\n    var hmac = crypto.createHmac('sha' + bits, secret);\n    var sig = (hmac.update(thing), hmac.digest('base64'))\n    return fromBase64(sig);\n  }\n}\n\nvar bufferEqual;\nvar timingSafeEqual = 'timingSafeEqual' in crypto ? function timingSafeEqual(a, b) {\n  if (a.byteLength !== b.byteLength) {\n    return false;\n  }\n\n  return crypto.timingSafeEqual(a, b)\n} : function timingSafeEqual(a, b) {\n  if (!bufferEqual) {\n    bufferEqual = require('buffer-equal-constant-time');\n  }\n\n  return bufferEqual(a, b)\n}\n\nfunction createHmacVerifier(bits) {\n  return function verify(thing, signature, secret) {\n    var computedSig = createHmacSigner(bits)(thing, secret);\n    return timingSafeEqual(Buffer.from(signature), Buffer.from(computedSig));\n  }\n}\n\nfunction createKeySigner(bits) {\n return function sign(thing, privateKey) {\n    checkIsPrivateKey(privateKey);\n    thing = normalizeInput(thing);\n    // Even though we are specifying \"RSA\" here, this works with ECDSA\n    // keys as well.\n    var signer = crypto.createSign('RSA-SHA' + bits);\n    var sig = (signer.update(thing), signer.sign(privateKey, 'base64'));\n    return fromBase64(sig);\n  }\n}\n\nfunction createKeyVerifier(bits) {\n  return function verify(thing, signature, publicKey) {\n    checkIsPublicKey(publicKey);\n    thing = normalizeInput(thing);\n    signature = toBase64(signature);\n    var verifier = crypto.createVerify('RSA-SHA' + bits);\n    verifier.update(thing);\n    return verifier.verify(publicKey, signature, 'base64');\n  }\n}\n\nfunction createPSSKeySigner(bits) {\n  return function sign(thing, privateKey) {\n    checkIsPrivateKey(privateKey);\n    thing = normalizeInput(thing);\n    var signer = crypto.createSign('RSA-SHA' + bits);\n    var sig = (signer.update(thing), signer.sign({\n      key: privateKey,\n      padding: crypto.constants.RSA_PKCS1_PSS_PADDING,\n      saltLength: crypto.constants.RSA_PSS_SALTLEN_DIGEST\n    }, 'base64'));\n    return fromBase64(sig);\n  }\n}\n\nfunction createPSSKeyVerifier(bits) {\n  return function verify(thing, signature, publicKey) {\n    checkIsPublicKey(publicKey);\n    thing = normalizeInput(thing);\n    signature = toBase64(signature);\n    var verifier = crypto.createVerify('RSA-SHA' + bits);\n    verifier.update(thing);\n    return verifier.verify({\n      key: publicKey,\n      padding: crypto.constants.RSA_PKCS1_PSS_PADDING,\n      saltLength: crypto.constants.RSA_PSS_SALTLEN_DIGEST\n    }, signature, 'base64');\n  }\n}\n\nfunction createECDSASigner(bits) {\n  var inner = createKeySigner(bits);\n  return function sign() {\n    var signature = inner.apply(null, arguments);\n    signature = formatEcdsa.derToJose(signature, 'ES' + bits);\n    return signature;\n  };\n}\n\nfunction createECDSAVerifer(bits) {\n  var inner = createKeyVerifier(bits);\n  return function verify(thing, signature, publicKey) {\n    signature = formatEcdsa.joseToDer(signature, 'ES' + bits).toString('base64');\n    var result = inner(thing, signature, publicKey);\n    return result;\n  };\n}\n\nfunction createNoneSigner() {\n  return function sign() {\n    return '';\n  }\n}\n\nfunction createNoneVerifier() {\n  return function verify(thing, signature) {\n    return signature === '';\n  }\n}\n\nmodule.exports = function jwa(algorithm) {\n  var signerFactories = {\n    hs: createHmacSigner,\n    rs: createKeySigner,\n    ps: createPSSKeySigner,\n    es: createECDSASigner,\n    none: createNoneSigner,\n  }\n  var verifierFactories = {\n    hs: createHmacVerifier,\n    rs: createKeyVerifier,\n    ps: createPSSKeyVerifier,\n    es: createECDSAVerifer,\n    none: createNoneVerifier,\n  }\n  var match = algorithm.match(/^(RS|PS|ES|HS)(256|384|512)$|^(none)$/i);\n  if (!match)\n    throw typeError(MSG_INVALID_ALGORITHM, algorithm);\n  var algo = (match[1] || match[3]).toLowerCase();\n  var bits = match[2];\n\n  return {\n    sign: signerFactories[algo](bits),\n    verify: verifierFactories[algo](bits),\n  }\n};\n",
    "/*global module*/\nvar Buffer = require('buffer').Buffer;\n\nmodule.exports = function toString(obj) {\n  if (typeof obj === 'string')\n    return obj;\n  if (typeof obj === 'number' || Buffer.isBuffer(obj))\n    return obj.toString();\n  return JSON.stringify(obj);\n};\n",
    "/*global module*/\nvar Buffer = require('safe-buffer').Buffer;\nvar DataStream = require('./data-stream');\nvar jwa = require('jwa');\nvar Stream = require('stream');\nvar toString = require('./tostring');\nvar util = require('util');\n\nfunction base64url(string, encoding) {\n  return Buffer\n    .from(string, encoding)\n    .toString('base64')\n    .replace(/=/g, '')\n    .replace(/\\+/g, '-')\n    .replace(/\\//g, '_');\n}\n\nfunction jwsSecuredInput(header, payload, encoding) {\n  encoding = encoding || 'utf8';\n  var encodedHeader = base64url(toString(header), 'binary');\n  var encodedPayload = base64url(toString(payload), encoding);\n  return util.format('%s.%s', encodedHeader, encodedPayload);\n}\n\nfunction jwsSign(opts) {\n  var header = opts.header;\n  var payload = opts.payload;\n  var secretOrKey = opts.secret || opts.privateKey;\n  var encoding = opts.encoding;\n  var algo = jwa(header.alg);\n  var securedInput = jwsSecuredInput(header, payload, encoding);\n  var signature = algo.sign(securedInput, secretOrKey);\n  return util.format('%s.%s', securedInput, signature);\n}\n\nfunction SignStream(opts) {\n  var secret = opts.secret||opts.privateKey||opts.key;\n  var secretStream = new DataStream(secret);\n  this.readable = true;\n  this.header = opts.header;\n  this.encoding = opts.encoding;\n  this.secret = this.privateKey = this.key = secretStream;\n  this.payload = new DataStream(opts.payload);\n  this.secret.once('close', function () {\n    if (!this.payload.writable && this.readable)\n      this.sign();\n  }.bind(this));\n\n  this.payload.once('close', function () {\n    if (!this.secret.writable && this.readable)\n      this.sign();\n  }.bind(this));\n}\nutil.inherits(SignStream, Stream);\n\nSignStream.prototype.sign = function sign() {\n  try {\n    var signature = jwsSign({\n      header: this.header,\n      payload: this.payload.buffer,\n      secret: this.secret.buffer,\n      encoding: this.encoding\n    });\n    this.emit('done', signature);\n    this.emit('data', signature);\n    this.emit('end');\n    this.readable = false;\n    return signature;\n  } catch (e) {\n    this.readable = false;\n    this.emit('error', e);\n    this.emit('close');\n  }\n};\n\nSignStream.sign = jwsSign;\n\nmodule.exports = SignStream;\n",
    "/*global module*/\nvar Buffer = require('safe-buffer').Buffer;\nvar DataStream = require('./data-stream');\nvar jwa = require('jwa');\nvar Stream = require('stream');\nvar toString = require('./tostring');\nvar util = require('util');\nvar JWS_REGEX = /^[a-zA-Z0-9\\-_]+?\\.[a-zA-Z0-9\\-_]+?\\.([a-zA-Z0-9\\-_]+)?$/;\n\nfunction isObject(thing) {\n  return Object.prototype.toString.call(thing) === '[object Object]';\n}\n\nfunction safeJsonParse(thing) {\n  if (isObject(thing))\n    return thing;\n  try { return JSON.parse(thing); }\n  catch (e) { return undefined; }\n}\n\nfunction headerFromJWS(jwsSig) {\n  var encodedHeader = jwsSig.split('.', 1)[0];\n  return safeJsonParse(Buffer.from(encodedHeader, 'base64').toString('binary'));\n}\n\nfunction securedInputFromJWS(jwsSig) {\n  return jwsSig.split('.', 2).join('.');\n}\n\nfunction signatureFromJWS(jwsSig) {\n  return jwsSig.split('.')[2];\n}\n\nfunction payloadFromJWS(jwsSig, encoding) {\n  encoding = encoding || 'utf8';\n  var payload = jwsSig.split('.')[1];\n  return Buffer.from(payload, 'base64').toString(encoding);\n}\n\nfunction isValidJws(string) {\n  return JWS_REGEX.test(string) && !!headerFromJWS(string);\n}\n\nfunction jwsVerify(jwsSig, algorithm, secretOrKey) {\n  if (!algorithm) {\n    var err = new Error(\"Missing algorithm parameter for jws.verify\");\n    err.code = \"MISSING_ALGORITHM\";\n    throw err;\n  }\n  jwsSig = toString(jwsSig);\n  var signature = signatureFromJWS(jwsSig);\n  var securedInput = securedInputFromJWS(jwsSig);\n  var algo = jwa(algorithm);\n  return algo.verify(securedInput, signature, secretOrKey);\n}\n\nfunction jwsDecode(jwsSig, opts) {\n  opts = opts || {};\n  jwsSig = toString(jwsSig);\n\n  if (!isValidJws(jwsSig))\n    return null;\n\n  var header = headerFromJWS(jwsSig);\n\n  if (!header)\n    return null;\n\n  var payload = payloadFromJWS(jwsSig);\n  if (header.typ === 'JWT' || opts.json)\n    payload = JSON.parse(payload, opts.encoding);\n\n  return {\n    header: header,\n    payload: payload,\n    signature: signatureFromJWS(jwsSig)\n  };\n}\n\nfunction VerifyStream(opts) {\n  opts = opts || {};\n  var secretOrKey = opts.secret||opts.publicKey||opts.key;\n  var secretStream = new DataStream(secretOrKey);\n  this.readable = true;\n  this.algorithm = opts.algorithm;\n  this.encoding = opts.encoding;\n  this.secret = this.publicKey = this.key = secretStream;\n  this.signature = new DataStream(opts.signature);\n  this.secret.once('close', function () {\n    if (!this.signature.writable && this.readable)\n      this.verify();\n  }.bind(this));\n\n  this.signature.once('close', function () {\n    if (!this.secret.writable && this.readable)\n      this.verify();\n  }.bind(this));\n}\nutil.inherits(VerifyStream, Stream);\nVerifyStream.prototype.verify = function verify() {\n  try {\n    var valid = jwsVerify(this.signature.buffer, this.algorithm, this.key.buffer);\n    var obj = jwsDecode(this.signature.buffer, this.encoding);\n    this.emit('done', valid, obj);\n    this.emit('data', valid);\n    this.emit('end');\n    this.readable = false;\n    return valid;\n  } catch (e) {\n    this.readable = false;\n    this.emit('error', e);\n    this.emit('close');\n  }\n};\n\nVerifyStream.decode = jwsDecode;\nVerifyStream.isValid = isValidJws;\nVerifyStream.verify = jwsVerify;\n\nmodule.exports = VerifyStream;\n",
    "/*global exports*/\nvar SignStream = require('./lib/sign-stream');\nvar VerifyStream = require('./lib/verify-stream');\n\nvar ALGORITHMS = [\n  'HS256', 'HS384', 'HS512',\n  'RS256', 'RS384', 'RS512',\n  'PS256', 'PS384', 'PS512',\n  'ES256', 'ES384', 'ES512'\n];\n\nexports.ALGORITHMS = ALGORITHMS;\nexports.sign = SignStream.sign;\nexports.verify = VerifyStream.verify;\nexports.decode = VerifyStream.decode;\nexports.isValid = VerifyStream.isValid;\nexports.createSign = function createSign(opts) {\n  return new SignStream(opts);\n};\nexports.createVerify = function createVerify(opts) {\n  return new VerifyStream(opts);\n};\n",
    "var jws = require('jws');\n\nmodule.exports = function (jwt, options) {\n  options = options || {};\n  var decoded = jws.decode(jwt, options);\n  if (!decoded) { return null; }\n  var payload = decoded.payload;\n\n  //try parse the payload\n  if(typeof payload === 'string') {\n    try {\n      var obj = JSON.parse(payload);\n      if(obj !== null && typeof obj === 'object') {\n        payload = obj;\n      }\n    } catch (e) { }\n  }\n\n  //return header if `complete` option is enabled.  header includes claims\n  //such as `kid` and `alg` used to select the key within a JWKS needed to\n  //verify the signature\n  if (options.complete === true) {\n    return {\n      header: decoded.header,\n      payload: payload,\n      signature: decoded.signature\n    };\n  }\n  return payload;\n};\n",
    "var JsonWebTokenError = function (message, error) {\n  Error.call(this, message);\n  if(Error.captureStackTrace) {\n    Error.captureStackTrace(this, this.constructor);\n  }\n  this.name = 'JsonWebTokenError';\n  this.message = message;\n  if (error) this.inner = error;\n};\n\nJsonWebTokenError.prototype = Object.create(Error.prototype);\nJsonWebTokenError.prototype.constructor = JsonWebTokenError;\n\nmodule.exports = JsonWebTokenError;\n",
    "var JsonWebTokenError = require('./JsonWebTokenError');\n\nvar NotBeforeError = function (message, date) {\n  JsonWebTokenError.call(this, message);\n  this.name = 'NotBeforeError';\n  this.date = date;\n};\n\nNotBeforeError.prototype = Object.create(JsonWebTokenError.prototype);\n\nNotBeforeError.prototype.constructor = NotBeforeError;\n\nmodule.exports = NotBeforeError;",
    "var JsonWebTokenError = require('./JsonWebTokenError');\n\nvar TokenExpiredError = function (message, expiredAt) {\n  JsonWebTokenError.call(this, message);\n  this.name = 'TokenExpiredError';\n  this.expiredAt = expiredAt;\n};\n\nTokenExpiredError.prototype = Object.create(JsonWebTokenError.prototype);\n\nTokenExpiredError.prototype.constructor = TokenExpiredError;\n\nmodule.exports = TokenExpiredError;",
    "/**\n * Helpers.\n */\n\nvar s = 1000;\nvar m = s * 60;\nvar h = m * 60;\nvar d = h * 24;\nvar w = d * 7;\nvar y = d * 365.25;\n\n/**\n * Parse or format the given `val`.\n *\n * Options:\n *\n *  - `long` verbose formatting [false]\n *\n * @param {String|Number} val\n * @param {Object} [options]\n * @throws {Error} throw an error if val is not a non-empty string or a number\n * @return {String|Number}\n * @api public\n */\n\nmodule.exports = function (val, options) {\n  options = options || {};\n  var type = typeof val;\n  if (type === 'string' && val.length > 0) {\n    return parse(val);\n  } else if (type === 'number' && isFinite(val)) {\n    return options.long ? fmtLong(val) : fmtShort(val);\n  }\n  throw new Error(\n    'val is not a non-empty string or a valid number. val=' +\n      JSON.stringify(val)\n  );\n};\n\n/**\n * Parse the given `str` and return milliseconds.\n *\n * @param {String} str\n * @return {Number}\n * @api private\n */\n\nfunction parse(str) {\n  str = String(str);\n  if (str.length > 100) {\n    return;\n  }\n  var match = /^(-?(?:\\d+)?\\.?\\d+) *(milliseconds?|msecs?|ms|seconds?|secs?|s|minutes?|mins?|m|hours?|hrs?|h|days?|d|weeks?|w|years?|yrs?|y)?$/i.exec(\n    str\n  );\n  if (!match) {\n    return;\n  }\n  var n = parseFloat(match[1]);\n  var type = (match[2] || 'ms').toLowerCase();\n  switch (type) {\n    case 'years':\n    case 'year':\n    case 'yrs':\n    case 'yr':\n    case 'y':\n      return n * y;\n    case 'weeks':\n    case 'week':\n    case 'w':\n      return n * w;\n    case 'days':\n    case 'day':\n    case 'd':\n      return n * d;\n    case 'hours':\n    case 'hour':\n    case 'hrs':\n    case 'hr':\n    case 'h':\n      return n * h;\n    case 'minutes':\n    case 'minute':\n    case 'mins':\n    case 'min':\n    case 'm':\n      return n * m;\n    case 'seconds':\n    case 'second':\n    case 'secs':\n    case 'sec':\n    case 's':\n      return n * s;\n    case 'milliseconds':\n    case 'millisecond':\n    case 'msecs':\n    case 'msec':\n    case 'ms':\n      return n;\n    default:\n      return undefined;\n  }\n}\n\n/**\n * Short format for `ms`.\n *\n * @param {Number} ms\n * @return {String}\n * @api private\n */\n\nfunction fmtShort(ms) {\n  var msAbs = Math.abs(ms);\n  if (msAbs >= d) {\n    return Math.round(ms / d) + 'd';\n  }\n  if (msAbs >= h) {\n    return Math.round(ms / h) + 'h';\n  }\n  if (msAbs >= m) {\n    return Math.round(ms / m) + 'm';\n  }\n  if (msAbs >= s) {\n    return Math.round(ms / s) + 's';\n  }\n  return ms + 'ms';\n}\n\n/**\n * Long format for `ms`.\n *\n * @param {Number} ms\n * @return {String}\n * @api private\n */\n\nfunction fmtLong(ms) {\n  var msAbs = Math.abs(ms);\n  if (msAbs >= d) {\n    return plural(ms, msAbs, d, 'day');\n  }\n  if (msAbs >= h) {\n    return plural(ms, msAbs, h, 'hour');\n  }\n  if (msAbs >= m) {\n    return plural(ms, msAbs, m, 'minute');\n  }\n  if (msAbs >= s) {\n    return plural(ms, msAbs, s, 'second');\n  }\n  return ms + ' ms';\n}\n\n/**\n * Pluralization helper.\n */\n\nfunction plural(ms, msAbs, n, name) {\n  var isPlural = msAbs >= n * 1.5;\n  return Math.round(ms / n) + ' ' + name + (isPlural ? 's' : '');\n}\n",
    "var ms = require('ms');\n\nmodule.exports = function (time, iat) {\n  var timestamp = iat || Math.floor(Date.now() / 1000);\n\n  if (typeof time === 'string') {\n    var milliseconds = ms(time);\n    if (typeof milliseconds === 'undefined') {\n      return;\n    }\n    return Math.floor(timestamp + milliseconds / 1000);\n  } else if (typeof time === 'number') {\n    return timestamp + time;\n  } else {\n    return;\n  }\n\n};",
    "'use strict'\n\n// Note: this is the semver.org version of the spec that it implements\n// Not necessarily the package version of this code.\nconst SEMVER_SPEC_VERSION = '2.0.0'\n\nconst MAX_LENGTH = 256\nconst MAX_SAFE_INTEGER = Number.MAX_SAFE_INTEGER ||\n/* istanbul ignore next */ 9007199254740991\n\n// Max safe segment length for coercion.\nconst MAX_SAFE_COMPONENT_LENGTH = 16\n\n// Max safe length for a build identifier. The max length minus 6 characters for\n// the shortest version with a build 0.0.0+BUILD.\nconst MAX_SAFE_BUILD_LENGTH = MAX_LENGTH - 6\n\nconst RELEASE_TYPES = [\n  'major',\n  'premajor',\n  'minor',\n  'preminor',\n  'patch',\n  'prepatch',\n  'prerelease',\n]\n\nmodule.exports = {\n  MAX_LENGTH,\n  MAX_SAFE_COMPONENT_LENGTH,\n  MAX_SAFE_BUILD_LENGTH,\n  MAX_SAFE_INTEGER,\n  RELEASE_TYPES,\n  SEMVER_SPEC_VERSION,\n  FLAG_INCLUDE_PRERELEASE: 0b001,\n  FLAG_LOOSE: 0b010,\n}\n",
    "'use strict'\n\nconst debug = (\n  typeof process === 'object' &&\n  process.env &&\n  process.env.NODE_DEBUG &&\n  /\\bsemver\\b/i.test(process.env.NODE_DEBUG)\n) ? (...args) => console.error('SEMVER', ...args)\n  : () => {}\n\nmodule.exports = debug\n",
    "'use strict'\n\nconst {\n  MAX_SAFE_COMPONENT_LENGTH,\n  MAX_SAFE_BUILD_LENGTH,\n  MAX_LENGTH,\n} = require('./constants')\nconst debug = require('./debug')\nexports = module.exports = {}\n\n// The actual regexps go on exports.re\nconst re = exports.re = []\nconst safeRe = exports.safeRe = []\nconst src = exports.src = []\nconst safeSrc = exports.safeSrc = []\nconst t = exports.t = {}\nlet R = 0\n\nconst LETTERDASHNUMBER = '[a-zA-Z0-9-]'\n\n// Replace some greedy regex tokens to prevent regex dos issues. These regex are\n// used internally via the safeRe object since all inputs in this library get\n// normalized first to trim and collapse all extra whitespace. The original\n// regexes are exported for userland consumption and lower level usage. A\n// future breaking change could export the safer regex only with a note that\n// all input should have extra whitespace removed.\nconst safeRegexReplacements = [\n  ['\\\\s', 1],\n  ['\\\\d', MAX_LENGTH],\n  [LETTERDASHNUMBER, MAX_SAFE_BUILD_LENGTH],\n]\n\nconst makeSafeRegex = (value) => {\n  for (const [token, max] of safeRegexReplacements) {\n    value = value\n      .split(`${token}*`).join(`${token}{0,${max}}`)\n      .split(`${token}+`).join(`${token}{1,${max}}`)\n  }\n  return value\n}\n\nconst createToken = (name, value, isGlobal) => {\n  const safe = makeSafeRegex(value)\n  const index = R++\n  debug(name, index, value)\n  t[name] = index\n  src[index] = value\n  safeSrc[index] = safe\n  re[index] = new RegExp(value, isGlobal ? 'g' : undefined)\n  safeRe[index] = new RegExp(safe, isGlobal ? 'g' : undefined)\n}\n\n// The following Regular Expressions can be used for tokenizing,\n// validating, and parsing SemVer version strings.\n\n// ## Numeric Identifier\n// A single `0`, or a non-zero digit followed by zero or more digits.\n\ncreateToken('NUMERICIDENTIFIER', '0|[1-9]\\\\d*')\ncreateToken('NUMERICIDENTIFIERLOOSE', '\\\\d+')\n\n// ## Non-numeric Identifier\n// Zero or more digits, followed by a letter or hyphen, and then zero or\n// more letters, digits, or hyphens.\n\ncreateToken('NONNUMERICIDENTIFIER', `\\\\d*[a-zA-Z-]${LETTERDASHNUMBER}*`)\n\n// ## Main Version\n// Three dot-separated numeric identifiers.\n\ncreateToken('MAINVERSION', `(${src[t.NUMERICIDENTIFIER]})\\\\.` +\n                   `(${src[t.NUMERICIDENTIFIER]})\\\\.` +\n                   `(${src[t.NUMERICIDENTIFIER]})`)\n\ncreateToken('MAINVERSIONLOOSE', `(${src[t.NUMERICIDENTIFIERLOOSE]})\\\\.` +\n                        `(${src[t.NUMERICIDENTIFIERLOOSE]})\\\\.` +\n                        `(${src[t.NUMERICIDENTIFIERLOOSE]})`)\n\n// ## Pre-release Version Identifier\n// A numeric identifier, or a non-numeric identifier.\n// Non-numberic identifiers include numberic identifiers but can be longer.\n// Therefore non-numberic identifiers must go first.\n\ncreateToken('PRERELEASEIDENTIFIER', `(?:${src[t.NONNUMERICIDENTIFIER]\n}|${src[t.NUMERICIDENTIFIER]})`)\n\ncreateToken('PRERELEASEIDENTIFIERLOOSE', `(?:${src[t.NONNUMERICIDENTIFIER]\n}|${src[t.NUMERICIDENTIFIERLOOSE]})`)\n\n// ## Pre-release Version\n// Hyphen, followed by one or more dot-separated pre-release version\n// identifiers.\n\ncreateToken('PRERELEASE', `(?:-(${src[t.PRERELEASEIDENTIFIER]\n}(?:\\\\.${src[t.PRERELEASEIDENTIFIER]})*))`)\n\ncreateToken('PRERELEASELOOSE', `(?:-?(${src[t.PRERELEASEIDENTIFIERLOOSE]\n}(?:\\\\.${src[t.PRERELEASEIDENTIFIERLOOSE]})*))`)\n\n// ## Build Metadata Identifier\n// Any combination of digits, letters, or hyphens.\n\ncreateToken('BUILDIDENTIFIER', `${LETTERDASHNUMBER}+`)\n\n// ## Build Metadata\n// Plus sign, followed by one or more period-separated build metadata\n// identifiers.\n\ncreateToken('BUILD', `(?:\\\\+(${src[t.BUILDIDENTIFIER]\n}(?:\\\\.${src[t.BUILDIDENTIFIER]})*))`)\n\n// ## Full Version String\n// A main version, followed optionally by a pre-release version and\n// build metadata.\n\n// Note that the only major, minor, patch, and pre-release sections of\n// the version string are capturing groups.  The build metadata is not a\n// capturing group, because it should not ever be used in version\n// comparison.\n\ncreateToken('FULLPLAIN', `v?${src[t.MAINVERSION]\n}${src[t.PRERELEASE]}?${\n  src[t.BUILD]}?`)\n\ncreateToken('FULL', `^${src[t.FULLPLAIN]}$`)\n\n// like full, but allows v1.2.3 and =1.2.3, which people do sometimes.\n// also, 1.0.0alpha1 (prerelease without the hyphen) which is pretty\n// common in the npm registry.\ncreateToken('LOOSEPLAIN', `[v=\\\\s]*${src[t.MAINVERSIONLOOSE]\n}${src[t.PRERELEASELOOSE]}?${\n  src[t.BUILD]}?`)\n\ncreateToken('LOOSE', `^${src[t.LOOSEPLAIN]}$`)\n\ncreateToken('GTLT', '((?:<|>)?=?)')\n\n// Something like \"2.*\" or \"1.2.x\".\n// Note that \"x.x\" is a valid xRange identifer, meaning \"any version\"\n// Only the first item is strictly required.\ncreateToken('XRANGEIDENTIFIERLOOSE', `${src[t.NUMERICIDENTIFIERLOOSE]}|x|X|\\\\*`)\ncreateToken('XRANGEIDENTIFIER', `${src[t.NUMERICIDENTIFIER]}|x|X|\\\\*`)\n\ncreateToken('XRANGEPLAIN', `[v=\\\\s]*(${src[t.XRANGEIDENTIFIER]})` +\n                   `(?:\\\\.(${src[t.XRANGEIDENTIFIER]})` +\n                   `(?:\\\\.(${src[t.XRANGEIDENTIFIER]})` +\n                   `(?:${src[t.PRERELEASE]})?${\n                     src[t.BUILD]}?` +\n                   `)?)?`)\n\ncreateToken('XRANGEPLAINLOOSE', `[v=\\\\s]*(${src[t.XRANGEIDENTIFIERLOOSE]})` +\n                        `(?:\\\\.(${src[t.XRANGEIDENTIFIERLOOSE]})` +\n                        `(?:\\\\.(${src[t.XRANGEIDENTIFIERLOOSE]})` +\n                        `(?:${src[t.PRERELEASELOOSE]})?${\n                          src[t.BUILD]}?` +\n                        `)?)?`)\n\ncreateToken('XRANGE', `^${src[t.GTLT]}\\\\s*${src[t.XRANGEPLAIN]}$`)\ncreateToken('XRANGELOOSE', `^${src[t.GTLT]}\\\\s*${src[t.XRANGEPLAINLOOSE]}$`)\n\n// Coercion.\n// Extract anything that could conceivably be a part of a valid semver\ncreateToken('COERCEPLAIN', `${'(^|[^\\\\d])' +\n              '(\\\\d{1,'}${MAX_SAFE_COMPONENT_LENGTH}})` +\n              `(?:\\\\.(\\\\d{1,${MAX_SAFE_COMPONENT_LENGTH}}))?` +\n              `(?:\\\\.(\\\\d{1,${MAX_SAFE_COMPONENT_LENGTH}}))?`)\ncreateToken('COERCE', `${src[t.COERCEPLAIN]}(?:$|[^\\\\d])`)\ncreateToken('COERCEFULL', src[t.COERCEPLAIN] +\n              `(?:${src[t.PRERELEASE]})?` +\n              `(?:${src[t.BUILD]})?` +\n              `(?:$|[^\\\\d])`)\ncreateToken('COERCERTL', src[t.COERCE], true)\ncreateToken('COERCERTLFULL', src[t.COERCEFULL], true)\n\n// Tilde ranges.\n// Meaning is \"reasonably at or greater than\"\ncreateToken('LONETILDE', '(?:~>?)')\n\ncreateToken('TILDETRIM', `(\\\\s*)${src[t.LONETILDE]}\\\\s+`, true)\nexports.tildeTrimReplace = '$1~'\n\ncreateToken('TILDE', `^${src[t.LONETILDE]}${src[t.XRANGEPLAIN]}$`)\ncreateToken('TILDELOOSE', `^${src[t.LONETILDE]}${src[t.XRANGEPLAINLOOSE]}$`)\n\n// Caret ranges.\n// Meaning is \"at least and backwards compatible with\"\ncreateToken('LONECARET', '(?:\\\\^)')\n\ncreateToken('CARETTRIM', `(\\\\s*)${src[t.LONECARET]}\\\\s+`, true)\nexports.caretTrimReplace = '$1^'\n\ncreateToken('CARET', `^${src[t.LONECARET]}${src[t.XRANGEPLAIN]}$`)\ncreateToken('CARETLOOSE', `^${src[t.LONECARET]}${src[t.XRANGEPLAINLOOSE]}$`)\n\n// A simple gt/lt/eq thing, or just \"\" to indicate \"any version\"\ncreateToken('COMPARATORLOOSE', `^${src[t.GTLT]}\\\\s*(${src[t.LOOSEPLAIN]})$|^$`)\ncreateToken('COMPARATOR', `^${src[t.GTLT]}\\\\s*(${src[t.FULLPLAIN]})$|^$`)\n\n// An expression to strip any whitespace between the gtlt and the thing\n// it modifies, so that `> 1.2.3` ==> `>1.2.3`\ncreateToken('COMPARATORTRIM', `(\\\\s*)${src[t.GTLT]\n}\\\\s*(${src[t.LOOSEPLAIN]}|${src[t.XRANGEPLAIN]})`, true)\nexports.comparatorTrimReplace = '$1$2$3'\n\n// Something like `1.2.3 - 1.2.4`\n// Note that these all use the loose form, because they'll be\n// checked against either the strict or loose comparator form\n// later.\ncreateToken('HYPHENRANGE', `^\\\\s*(${src[t.XRANGEPLAIN]})` +\n                   `\\\\s+-\\\\s+` +\n                   `(${src[t.XRANGEPLAIN]})` +\n                   `\\\\s*$`)\n\ncreateToken('HYPHENRANGELOOSE', `^\\\\s*(${src[t.XRANGEPLAINLOOSE]})` +\n                        `\\\\s+-\\\\s+` +\n                        `(${src[t.XRANGEPLAINLOOSE]})` +\n                        `\\\\s*$`)\n\n// Star ranges basically just allow anything at all.\ncreateToken('STAR', '(<|>)?=?\\\\s*\\\\*')\n// >=0.0.0 is like a star\ncreateToken('GTE0', '^\\\\s*>=\\\\s*0\\\\.0\\\\.0\\\\s*$')\ncreateToken('GTE0PRE', '^\\\\s*>=\\\\s*0\\\\.0\\\\.0-0\\\\s*$')\n",
    "'use strict'\n\n// parse out just the options we care about\nconst looseOption = Object.freeze({ loose: true })\nconst emptyOpts = Object.freeze({ })\nconst parseOptions = options => {\n  if (!options) {\n    return emptyOpts\n  }\n\n  if (typeof options !== 'object') {\n    return looseOption\n  }\n\n  return options\n}\nmodule.exports = parseOptions\n",
    "'use strict'\n\nconst numeric = /^[0-9]+$/\nconst compareIdentifiers = (a, b) => {\n  const anum = numeric.test(a)\n  const bnum = numeric.test(b)\n\n  if (anum && bnum) {\n    a = +a\n    b = +b\n  }\n\n  return a === b ? 0\n    : (anum && !bnum) ? -1\n    : (bnum && !anum) ? 1\n    : a < b ? -1\n    : 1\n}\n\nconst rcompareIdentifiers = (a, b) => compareIdentifiers(b, a)\n\nmodule.exports = {\n  compareIdentifiers,\n  rcompareIdentifiers,\n}\n",
    "'use strict'\n\nconst debug = require('../internal/debug')\nconst { MAX_LENGTH, MAX_SAFE_INTEGER } = require('../internal/constants')\nconst { safeRe: re, t } = require('../internal/re')\n\nconst parseOptions = require('../internal/parse-options')\nconst { compareIdentifiers } = require('../internal/identifiers')\nclass SemVer {\n  constructor (version, options) {\n    options = parseOptions(options)\n\n    if (version instanceof SemVer) {\n      if (version.loose === !!options.loose &&\n        version.includePrerelease === !!options.includePrerelease) {\n        return version\n      } else {\n        version = version.version\n      }\n    } else if (typeof version !== 'string') {\n      throw new TypeError(`Invalid version. Must be a string. Got type \"${typeof version}\".`)\n    }\n\n    if (version.length > MAX_LENGTH) {\n      throw new TypeError(\n        `version is longer than ${MAX_LENGTH} characters`\n      )\n    }\n\n    debug('SemVer', version, options)\n    this.options = options\n    this.loose = !!options.loose\n    // this isn't actually relevant for versions, but keep it so that we\n    // don't run into trouble passing this.options around.\n    this.includePrerelease = !!options.includePrerelease\n\n    const m = version.trim().match(options.loose ? re[t.LOOSE] : re[t.FULL])\n\n    if (!m) {\n      throw new TypeError(`Invalid Version: ${version}`)\n    }\n\n    this.raw = version\n\n    // these are actually numbers\n    this.major = +m[1]\n    this.minor = +m[2]\n    this.patch = +m[3]\n\n    if (this.major > MAX_SAFE_INTEGER || this.major < 0) {\n      throw new TypeError('Invalid major version')\n    }\n\n    if (this.minor > MAX_SAFE_INTEGER || this.minor < 0) {\n      throw new TypeError('Invalid minor version')\n    }\n\n    if (this.patch > MAX_SAFE_INTEGER || this.patch < 0) {\n      throw new TypeError('Invalid patch version')\n    }\n\n    // numberify any prerelease numeric ids\n    if (!m[4]) {\n      this.prerelease = []\n    } else {\n      this.prerelease = m[4].split('.').map((id) => {\n        if (/^[0-9]+$/.test(id)) {\n          const num = +id\n          if (num >= 0 && num < MAX_SAFE_INTEGER) {\n            return num\n          }\n        }\n        return id\n      })\n    }\n\n    this.build = m[5] ? m[5].split('.') : []\n    this.format()\n  }\n\n  format () {\n    this.version = `${this.major}.${this.minor}.${this.patch}`\n    if (this.prerelease.length) {\n      this.version += `-${this.prerelease.join('.')}`\n    }\n    return this.version\n  }\n\n  toString () {\n    return this.version\n  }\n\n  compare (other) {\n    debug('SemVer.compare', this.version, this.options, other)\n    if (!(other instanceof SemVer)) {\n      if (typeof other === 'string' && other === this.version) {\n        return 0\n      }\n      other = new SemVer(other, this.options)\n    }\n\n    if (other.version === this.version) {\n      return 0\n    }\n\n    return this.compareMain(other) || this.comparePre(other)\n  }\n\n  compareMain (other) {\n    if (!(other instanceof SemVer)) {\n      other = new SemVer(other, this.options)\n    }\n\n    return (\n      compareIdentifiers(this.major, other.major) ||\n      compareIdentifiers(this.minor, other.minor) ||\n      compareIdentifiers(this.patch, other.patch)\n    )\n  }\n\n  comparePre (other) {\n    if (!(other instanceof SemVer)) {\n      other = new SemVer(other, this.options)\n    }\n\n    // NOT having a prerelease is > having one\n    if (this.prerelease.length && !other.prerelease.length) {\n      return -1\n    } else if (!this.prerelease.length && other.prerelease.length) {\n      return 1\n    } else if (!this.prerelease.length && !other.prerelease.length) {\n      return 0\n    }\n\n    let i = 0\n    do {\n      const a = this.prerelease[i]\n      const b = other.prerelease[i]\n      debug('prerelease compare', i, a, b)\n      if (a === undefined && b === undefined) {\n        return 0\n      } else if (b === undefined) {\n        return 1\n      } else if (a === undefined) {\n        return -1\n      } else if (a === b) {\n        continue\n      } else {\n        return compareIdentifiers(a, b)\n      }\n    } while (++i)\n  }\n\n  compareBuild (other) {\n    if (!(other instanceof SemVer)) {\n      other = new SemVer(other, this.options)\n    }\n\n    let i = 0\n    do {\n      const a = this.build[i]\n      const b = other.build[i]\n      debug('build compare', i, a, b)\n      if (a === undefined && b === undefined) {\n        return 0\n      } else if (b === undefined) {\n        return 1\n      } else if (a === undefined) {\n        return -1\n      } else if (a === b) {\n        continue\n      } else {\n        return compareIdentifiers(a, b)\n      }\n    } while (++i)\n  }\n\n  // preminor will bump the version up to the next minor release, and immediately\n  // down to pre-release. premajor and prepatch work the same way.\n  inc (release, identifier, identifierBase) {\n    if (release.startsWith('pre')) {\n      if (!identifier && identifierBase === false) {\n        throw new Error('invalid increment argument: identifier is empty')\n      }\n      // Avoid an invalid semver results\n      if (identifier) {\n        const match = `-${identifier}`.match(this.options.loose ? re[t.PRERELEASELOOSE] : re[t.PRERELEASE])\n        if (!match || match[1] !== identifier) {\n          throw new Error(`invalid identifier: ${identifier}`)\n        }\n      }\n    }\n\n    switch (release) {\n      case 'premajor':\n        this.prerelease.length = 0\n        this.patch = 0\n        this.minor = 0\n        this.major++\n        this.inc('pre', identifier, identifierBase)\n        break\n      case 'preminor':\n        this.prerelease.length = 0\n        this.patch = 0\n        this.minor++\n        this.inc('pre', identifier, identifierBase)\n        break\n      case 'prepatch':\n        // If this is already a prerelease, it will bump to the next version\n        // drop any prereleases that might already exist, since they are not\n        // relevant at this point.\n        this.prerelease.length = 0\n        this.inc('patch', identifier, identifierBase)\n        this.inc('pre', identifier, identifierBase)\n        break\n      // If the input is a non-prerelease version, this acts the same as\n      // prepatch.\n      case 'prerelease':\n        if (this.prerelease.length === 0) {\n          this.inc('patch', identifier, identifierBase)\n        }\n        this.inc('pre', identifier, identifierBase)\n        break\n      case 'release':\n        if (this.prerelease.length === 0) {\n          throw new Error(`version ${this.raw} is not a prerelease`)\n        }\n        this.prerelease.length = 0\n        break\n\n      case 'major':\n        // If this is a pre-major version, bump up to the same major version.\n        // Otherwise increment major.\n        // 1.0.0-5 bumps to 1.0.0\n        // 1.1.0 bumps to 2.0.0\n        if (\n          this.minor !== 0 ||\n          this.patch !== 0 ||\n          this.prerelease.length === 0\n        ) {\n          this.major++\n        }\n        this.minor = 0\n        this.patch = 0\n        this.prerelease = []\n        break\n      case 'minor':\n        // If this is a pre-minor version, bump up to the same minor version.\n        // Otherwise increment minor.\n        // 1.2.0-5 bumps to 1.2.0\n        // 1.2.1 bumps to 1.3.0\n        if (this.patch !== 0 || this.prerelease.length === 0) {\n          this.minor++\n        }\n        this.patch = 0\n        this.prerelease = []\n        break\n      case 'patch':\n        // If this is not a pre-release version, it will increment the patch.\n        // If it is a pre-release it will bump up to the same patch version.\n        // 1.2.0-5 patches to 1.2.0\n        // 1.2.0 patches to 1.2.1\n        if (this.prerelease.length === 0) {\n          this.patch++\n        }\n        this.prerelease = []\n        break\n      // This probably shouldn't be used publicly.\n      // 1.0.0 'pre' would become 1.0.0-0 which is the wrong direction.\n      case 'pre': {\n        const base = Number(identifierBase) ? 1 : 0\n\n        if (this.prerelease.length === 0) {\n          this.prerelease = [base]\n        } else {\n          let i = this.prerelease.length\n          while (--i >= 0) {\n            if (typeof this.prerelease[i] === 'number') {\n              this.prerelease[i]++\n              i = -2\n            }\n          }\n          if (i === -1) {\n            // didn't increment anything\n            if (identifier === this.prerelease.join('.') && identifierBase === false) {\n              throw new Error('invalid increment argument: identifier already exists')\n            }\n            this.prerelease.push(base)\n          }\n        }\n        if (identifier) {\n          // 1.2.0-beta.1 bumps to 1.2.0-beta.2,\n          // 1.2.0-beta.fooblz or 1.2.0-beta bumps to 1.2.0-beta.0\n          let prerelease = [identifier, base]\n          if (identifierBase === false) {\n            prerelease = [identifier]\n          }\n          if (compareIdentifiers(this.prerelease[0], identifier) === 0) {\n            if (isNaN(this.prerelease[1])) {\n              this.prerelease = prerelease\n            }\n          } else {\n            this.prerelease = prerelease\n          }\n        }\n        break\n      }\n      default:\n        throw new Error(`invalid increment argument: ${release}`)\n    }\n    this.raw = this.format()\n    if (this.build.length) {\n      this.raw += `+${this.build.join('.')}`\n    }\n    return this\n  }\n}\n\nmodule.exports = SemVer\n",
    "'use strict'\n\nconst SemVer = require('../classes/semver')\nconst parse = (version, options, throwErrors = false) => {\n  if (version instanceof SemVer) {\n    return version\n  }\n  try {\n    return new SemVer(version, options)\n  } catch (er) {\n    if (!throwErrors) {\n      return null\n    }\n    throw er\n  }\n}\n\nmodule.exports = parse\n",
    "'use strict'\n\nconst parse = require('./parse')\nconst valid = (version, options) => {\n  const v = parse(version, options)\n  return v ? v.version : null\n}\nmodule.exports = valid\n",
    "'use strict'\n\nconst parse = require('./parse')\nconst clean = (version, options) => {\n  const s = parse(version.trim().replace(/^[=v]+/, ''), options)\n  return s ? s.version : null\n}\nmodule.exports = clean\n",
    "'use strict'\n\nconst SemVer = require('../classes/semver')\n\nconst inc = (version, release, options, identifier, identifierBase) => {\n  if (typeof (options) === 'string') {\n    identifierBase = identifier\n    identifier = options\n    options = undefined\n  }\n\n  try {\n    return new SemVer(\n      version instanceof SemVer ? version.version : version,\n      options\n    ).inc(release, identifier, identifierBase).version\n  } catch (er) {\n    return null\n  }\n}\nmodule.exports = inc\n",
    "'use strict'\n\nconst parse = require('./parse.js')\n\nconst diff = (version1, version2) => {\n  const v1 = parse(version1, null, true)\n  const v2 = parse(version2, null, true)\n  const comparison = v1.compare(v2)\n\n  if (comparison === 0) {\n    return null\n  }\n\n  const v1Higher = comparison > 0\n  const highVersion = v1Higher ? v1 : v2\n  const lowVersion = v1Higher ? v2 : v1\n  const highHasPre = !!highVersion.prerelease.length\n  const lowHasPre = !!lowVersion.prerelease.length\n\n  if (lowHasPre && !highHasPre) {\n    // Going from prerelease -> no prerelease requires some special casing\n\n    // If the low version has only a major, then it will always be a major\n    // Some examples:\n    // 1.0.0-1 -> 1.0.0\n    // 1.0.0-1 -> 1.1.1\n    // 1.0.0-1 -> 2.0.0\n    if (!lowVersion.patch && !lowVersion.minor) {\n      return 'major'\n    }\n\n    // If the main part has no difference\n    if (lowVersion.compareMain(highVersion) === 0) {\n      if (lowVersion.minor && !lowVersion.patch) {\n        return 'minor'\n      }\n      return 'patch'\n    }\n  }\n\n  // add the `pre` prefix if we are going to a prerelease version\n  const prefix = highHasPre ? 'pre' : ''\n\n  if (v1.major !== v2.major) {\n    return prefix + 'major'\n  }\n\n  if (v1.minor !== v2.minor) {\n    return prefix + 'minor'\n  }\n\n  if (v1.patch !== v2.patch) {\n    return prefix + 'patch'\n  }\n\n  // high and low are preleases\n  return 'prerelease'\n}\n\nmodule.exports = diff\n",
    "'use strict'\n\nconst SemVer = require('../classes/semver')\nconst major = (a, loose) => new SemVer(a, loose).major\nmodule.exports = major\n",
    "'use strict'\n\nconst SemVer = require('../classes/semver')\nconst minor = (a, loose) => new SemVer(a, loose).minor\nmodule.exports = minor\n",
    "'use strict'\n\nconst SemVer = require('../classes/semver')\nconst patch = (a, loose) => new SemVer(a, loose).patch\nmodule.exports = patch\n",
    "'use strict'\n\nconst parse = require('./parse')\nconst prerelease = (version, options) => {\n  const parsed = parse(version, options)\n  return (parsed && parsed.prerelease.length) ? parsed.prerelease : null\n}\nmodule.exports = prerelease\n",
    "'use strict'\n\nconst SemVer = require('../classes/semver')\nconst compare = (a, b, loose) =>\n  new SemVer(a, loose).compare(new SemVer(b, loose))\n\nmodule.exports = compare\n",
    "'use strict'\n\nconst compare = require('./compare')\nconst rcompare = (a, b, loose) => compare(b, a, loose)\nmodule.exports = rcompare\n",
    "'use strict'\n\nconst compare = require('./compare')\nconst compareLoose = (a, b) => compare(a, b, true)\nmodule.exports = compareLoose\n",
    "'use strict'\n\nconst SemVer = require('../classes/semver')\nconst compareBuild = (a, b, loose) => {\n  const versionA = new SemVer(a, loose)\n  const versionB = new SemVer(b, loose)\n  return versionA.compare(versionB) || versionA.compareBuild(versionB)\n}\nmodule.exports = compareBuild\n",
    "'use strict'\n\nconst compareBuild = require('./compare-build')\nconst sort = (list, loose) => list.sort((a, b) => compareBuild(a, b, loose))\nmodule.exports = sort\n",
    "'use strict'\n\nconst compareBuild = require('./compare-build')\nconst rsort = (list, loose) => list.sort((a, b) => compareBuild(b, a, loose))\nmodule.exports = rsort\n",
    "'use strict'\n\nconst compare = require('./compare')\nconst gt = (a, b, loose) => compare(a, b, loose) > 0\nmodule.exports = gt\n",
    "'use strict'\n\nconst compare = require('./compare')\nconst lt = (a, b, loose) => compare(a, b, loose) < 0\nmodule.exports = lt\n",
    "'use strict'\n\nconst compare = require('./compare')\nconst eq = (a, b, loose) => compare(a, b, loose) === 0\nmodule.exports = eq\n",
    "'use strict'\n\nconst compare = require('./compare')\nconst neq = (a, b, loose) => compare(a, b, loose) !== 0\nmodule.exports = neq\n",
    "'use strict'\n\nconst compare = require('./compare')\nconst gte = (a, b, loose) => compare(a, b, loose) >= 0\nmodule.exports = gte\n",
    "'use strict'\n\nconst compare = require('./compare')\nconst lte = (a, b, loose) => compare(a, b, loose) <= 0\nmodule.exports = lte\n",
    "'use strict'\n\nconst eq = require('./eq')\nconst neq = require('./neq')\nconst gt = require('./gt')\nconst gte = require('./gte')\nconst lt = require('./lt')\nconst lte = require('./lte')\n\nconst cmp = (a, op, b, loose) => {\n  switch (op) {\n    case '===':\n      if (typeof a === 'object') {\n        a = a.version\n      }\n      if (typeof b === 'object') {\n        b = b.version\n      }\n      return a === b\n\n    case '!==':\n      if (typeof a === 'object') {\n        a = a.version\n      }\n      if (typeof b === 'object') {\n        b = b.version\n      }\n      return a !== b\n\n    case '':\n    case '=':\n    case '==':\n      return eq(a, b, loose)\n\n    case '!=':\n      return neq(a, b, loose)\n\n    case '>':\n      return gt(a, b, loose)\n\n    case '>=':\n      return gte(a, b, loose)\n\n    case '<':\n      return lt(a, b, loose)\n\n    case '<=':\n      return lte(a, b, loose)\n\n    default:\n      throw new TypeError(`Invalid operator: ${op}`)\n  }\n}\nmodule.exports = cmp\n",
    "'use strict'\n\nconst SemVer = require('../classes/semver')\nconst parse = require('./parse')\nconst { safeRe: re, t } = require('../internal/re')\n\nconst coerce = (version, options) => {\n  if (version instanceof SemVer) {\n    return version\n  }\n\n  if (typeof version === 'number') {\n    version = String(version)\n  }\n\n  if (typeof version !== 'string') {\n    return null\n  }\n\n  options = options || {}\n\n  let match = null\n  if (!options.rtl) {\n    match = version.match(options.includePrerelease ? re[t.COERCEFULL] : re[t.COERCE])\n  } else {\n    // Find the right-most coercible string that does not share\n    // a terminus with a more left-ward coercible string.\n    // Eg, '1.2.3.4' wants to coerce '2.3.4', not '3.4' or '4'\n    // With includePrerelease option set, '1.2.3.4-rc' wants to coerce '2.3.4-rc', not '2.3.4'\n    //\n    // Walk through the string checking with a /g regexp\n    // Manually set the index so as to pick up overlapping matches.\n    // Stop when we get a match that ends at the string end, since no\n    // coercible string can be more right-ward without the same terminus.\n    const coerceRtlRegex = options.includePrerelease ? re[t.COERCERTLFULL] : re[t.COERCERTL]\n    let next\n    while ((next = coerceRtlRegex.exec(version)) &&\n        (!match || match.index + match[0].length !== version.length)\n    ) {\n      if (!match ||\n            next.index + next[0].length !== match.index + match[0].length) {\n        match = next\n      }\n      coerceRtlRegex.lastIndex = next.index + next[1].length + next[2].length\n    }\n    // leave it in a clean state\n    coerceRtlRegex.lastIndex = -1\n  }\n\n  if (match === null) {\n    return null\n  }\n\n  const major = match[2]\n  const minor = match[3] || '0'\n  const patch = match[4] || '0'\n  const prerelease = options.includePrerelease && match[5] ? `-${match[5]}` : ''\n  const build = options.includePrerelease && match[6] ? `+${match[6]}` : ''\n\n  return parse(`${major}.${minor}.${patch}${prerelease}${build}`, options)\n}\nmodule.exports = coerce\n",
    "'use strict'\n\nclass LRUCache {\n  constructor () {\n    this.max = 1000\n    this.map = new Map()\n  }\n\n  get (key) {\n    const value = this.map.get(key)\n    if (value === undefined) {\n      return undefined\n    } else {\n      // Remove the key from the map and add it to the end\n      this.map.delete(key)\n      this.map.set(key, value)\n      return value\n    }\n  }\n\n  delete (key) {\n    return this.map.delete(key)\n  }\n\n  set (key, value) {\n    const deleted = this.delete(key)\n\n    if (!deleted && value !== undefined) {\n      // If cache is full, delete the least recently used item\n      if (this.map.size >= this.max) {\n        const firstKey = this.map.keys().next().value\n        this.delete(firstKey)\n      }\n\n      this.map.set(key, value)\n    }\n\n    return this\n  }\n}\n\nmodule.exports = LRUCache\n",
    "'use strict'\n\nconst SPACE_CHARACTERS = /\\s+/g\n\n// hoisted class for cyclic dependency\nclass Range {\n  constructor (range, options) {\n    options = parseOptions(options)\n\n    if (range instanceof Range) {\n      if (\n        range.loose === !!options.loose &&\n        range.includePrerelease === !!options.includePrerelease\n      ) {\n        return range\n      } else {\n        return new Range(range.raw, options)\n      }\n    }\n\n    if (range instanceof Comparator) {\n      // just put it in the set and return\n      this.raw = range.value\n      this.set = [[range]]\n      this.formatted = undefined\n      return this\n    }\n\n    this.options = options\n    this.loose = !!options.loose\n    this.includePrerelease = !!options.includePrerelease\n\n    // First reduce all whitespace as much as possible so we do not have to rely\n    // on potentially slow regexes like \\s*. This is then stored and used for\n    // future error messages as well.\n    this.raw = range.trim().replace(SPACE_CHARACTERS, ' ')\n\n    // First, split on ||\n    this.set = this.raw\n      .split('||')\n      // map the range to a 2d array of comparators\n      .map(r => this.parseRange(r.trim()))\n      // throw out any comparator lists that are empty\n      // this generally means that it was not a valid range, which is allowed\n      // in loose mode, but will still throw if the WHOLE range is invalid.\n      .filter(c => c.length)\n\n    if (!this.set.length) {\n      throw new TypeError(`Invalid SemVer Range: ${this.raw}`)\n    }\n\n    // if we have any that are not the null set, throw out null sets.\n    if (this.set.length > 1) {\n      // keep the first one, in case they're all null sets\n      const first = this.set[0]\n      this.set = this.set.filter(c => !isNullSet(c[0]))\n      if (this.set.length === 0) {\n        this.set = [first]\n      } else if (this.set.length > 1) {\n        // if we have any that are *, then the range is just *\n        for (const c of this.set) {\n          if (c.length === 1 && isAny(c[0])) {\n            this.set = [c]\n            break\n          }\n        }\n      }\n    }\n\n    this.formatted = undefined\n  }\n\n  get range () {\n    if (this.formatted === undefined) {\n      this.formatted = ''\n      for (let i = 0; i < this.set.length; i++) {\n        if (i > 0) {\n          this.formatted += '||'\n        }\n        const comps = this.set[i]\n        for (let k = 0; k < comps.length; k++) {\n          if (k > 0) {\n            this.formatted += ' '\n          }\n          this.formatted += comps[k].toString().trim()\n        }\n      }\n    }\n    return this.formatted\n  }\n\n  format () {\n    return this.range\n  }\n\n  toString () {\n    return this.range\n  }\n\n  parseRange (range) {\n    // memoize range parsing for performance.\n    // this is a very hot path, and fully deterministic.\n    const memoOpts =\n      (this.options.includePrerelease && FLAG_INCLUDE_PRERELEASE) |\n      (this.options.loose && FLAG_LOOSE)\n    const memoKey = memoOpts + ':' + range\n    const cached = cache.get(memoKey)\n    if (cached) {\n      return cached\n    }\n\n    const loose = this.options.loose\n    // `1.2.3 - 1.2.4` => `>=1.2.3 <=1.2.4`\n    const hr = loose ? re[t.HYPHENRANGELOOSE] : re[t.HYPHENRANGE]\n    range = range.replace(hr, hyphenReplace(this.options.includePrerelease))\n    debug('hyphen replace', range)\n\n    // `> 1.2.3 < 1.2.5` => `>1.2.3 <1.2.5`\n    range = range.replace(re[t.COMPARATORTRIM], comparatorTrimReplace)\n    debug('comparator trim', range)\n\n    // `~ 1.2.3` => `~1.2.3`\n    range = range.replace(re[t.TILDETRIM], tildeTrimReplace)\n    debug('tilde trim', range)\n\n    // `^ 1.2.3` => `^1.2.3`\n    range = range.replace(re[t.CARETTRIM], caretTrimReplace)\n    debug('caret trim', range)\n\n    // At this point, the range is completely trimmed and\n    // ready to be split into comparators.\n\n    let rangeList = range\n      .split(' ')\n      .map(comp => parseComparator(comp, this.options))\n      .join(' ')\n      .split(/\\s+/)\n      // >=0.0.0 is equivalent to *\n      .map(comp => replaceGTE0(comp, this.options))\n\n    if (loose) {\n      // in loose mode, throw out any that are not valid comparators\n      rangeList = rangeList.filter(comp => {\n        debug('loose invalid filter', comp, this.options)\n        return !!comp.match(re[t.COMPARATORLOOSE])\n      })\n    }\n    debug('range list', rangeList)\n\n    // if any comparators are the null set, then replace with JUST null set\n    // if more than one comparator, remove any * comparators\n    // also, don't include the same comparator more than once\n    const rangeMap = new Map()\n    const comparators = rangeList.map(comp => new Comparator(comp, this.options))\n    for (const comp of comparators) {\n      if (isNullSet(comp)) {\n        return [comp]\n      }\n      rangeMap.set(comp.value, comp)\n    }\n    if (rangeMap.size > 1 && rangeMap.has('')) {\n      rangeMap.delete('')\n    }\n\n    const result = [...rangeMap.values()]\n    cache.set(memoKey, result)\n    return result\n  }\n\n  intersects (range, options) {\n    if (!(range instanceof Range)) {\n      throw new TypeError('a Range is required')\n    }\n\n    return this.set.some((thisComparators) => {\n      return (\n        isSatisfiable(thisComparators, options) &&\n        range.set.some((rangeComparators) => {\n          return (\n            isSatisfiable(rangeComparators, options) &&\n            thisComparators.every((thisComparator) => {\n              return rangeComparators.every((rangeComparator) => {\n                return thisComparator.intersects(rangeComparator, options)\n              })\n            })\n          )\n        })\n      )\n    })\n  }\n\n  // if ANY of the sets match ALL of its comparators, then pass\n  test (version) {\n    if (!version) {\n      return false\n    }\n\n    if (typeof version === 'string') {\n      try {\n        version = new SemVer(version, this.options)\n      } catch (er) {\n        return false\n      }\n    }\n\n    for (let i = 0; i < this.set.length; i++) {\n      if (testSet(this.set[i], version, this.options)) {\n        return true\n      }\n    }\n    return false\n  }\n}\n\nmodule.exports = Range\n\nconst LRU = require('../internal/lrucache')\nconst cache = new LRU()\n\nconst parseOptions = require('../internal/parse-options')\nconst Comparator = require('./comparator')\nconst debug = require('../internal/debug')\nconst SemVer = require('./semver')\nconst {\n  safeRe: re,\n  t,\n  comparatorTrimReplace,\n  tildeTrimReplace,\n  caretTrimReplace,\n} = require('../internal/re')\nconst { FLAG_INCLUDE_PRERELEASE, FLAG_LOOSE } = require('../internal/constants')\n\nconst isNullSet = c => c.value === '<0.0.0-0'\nconst isAny = c => c.value === ''\n\n// take a set of comparators and determine whether there\n// exists a version which can satisfy it\nconst isSatisfiable = (comparators, options) => {\n  let result = true\n  const remainingComparators = comparators.slice()\n  let testComparator = remainingComparators.pop()\n\n  while (result && remainingComparators.length) {\n    result = remainingComparators.every((otherComparator) => {\n      return testComparator.intersects(otherComparator, options)\n    })\n\n    testComparator = remainingComparators.pop()\n  }\n\n  return result\n}\n\n// comprised of xranges, tildes, stars, and gtlt's at this point.\n// already replaced the hyphen ranges\n// turn into a set of JUST comparators.\nconst parseComparator = (comp, options) => {\n  debug('comp', comp, options)\n  comp = replaceCarets(comp, options)\n  debug('caret', comp)\n  comp = replaceTildes(comp, options)\n  debug('tildes', comp)\n  comp = replaceXRanges(comp, options)\n  debug('xrange', comp)\n  comp = replaceStars(comp, options)\n  debug('stars', comp)\n  return comp\n}\n\nconst isX = id => !id || id.toLowerCase() === 'x' || id === '*'\n\n// ~, ~> --> * (any, kinda silly)\n// ~2, ~2.x, ~2.x.x, ~>2, ~>2.x ~>2.x.x --> >=2.0.0 <3.0.0-0\n// ~2.0, ~2.0.x, ~>2.0, ~>2.0.x --> >=2.0.0 <2.1.0-0\n// ~1.2, ~1.2.x, ~>1.2, ~>1.2.x --> >=1.2.0 <1.3.0-0\n// ~1.2.3, ~>1.2.3 --> >=1.2.3 <1.3.0-0\n// ~1.2.0, ~>1.2.0 --> >=1.2.0 <1.3.0-0\n// ~0.0.1 --> >=0.0.1 <0.1.0-0\nconst replaceTildes = (comp, options) => {\n  return comp\n    .trim()\n    .split(/\\s+/)\n    .map((c) => replaceTilde(c, options))\n    .join(' ')\n}\n\nconst replaceTilde = (comp, options) => {\n  const r = options.loose ? re[t.TILDELOOSE] : re[t.TILDE]\n  return comp.replace(r, (_, M, m, p, pr) => {\n    debug('tilde', comp, _, M, m, p, pr)\n    let ret\n\n    if (isX(M)) {\n      ret = ''\n    } else if (isX(m)) {\n      ret = `>=${M}.0.0 <${+M + 1}.0.0-0`\n    } else if (isX(p)) {\n      // ~1.2 == >=1.2.0 <1.3.0-0\n      ret = `>=${M}.${m}.0 <${M}.${+m + 1}.0-0`\n    } else if (pr) {\n      debug('replaceTilde pr', pr)\n      ret = `>=${M}.${m}.${p}-${pr\n      } <${M}.${+m + 1}.0-0`\n    } else {\n      // ~1.2.3 == >=1.2.3 <1.3.0-0\n      ret = `>=${M}.${m}.${p\n      } <${M}.${+m + 1}.0-0`\n    }\n\n    debug('tilde return', ret)\n    return ret\n  })\n}\n\n// ^ --> * (any, kinda silly)\n// ^2, ^2.x, ^2.x.x --> >=2.0.0 <3.0.0-0\n// ^2.0, ^2.0.x --> >=2.0.0 <3.0.0-0\n// ^1.2, ^1.2.x --> >=1.2.0 <2.0.0-0\n// ^1.2.3 --> >=1.2.3 <2.0.0-0\n// ^1.2.0 --> >=1.2.0 <2.0.0-0\n// ^0.0.1 --> >=0.0.1 <0.0.2-0\n// ^0.1.0 --> >=0.1.0 <0.2.0-0\nconst replaceCarets = (comp, options) => {\n  return comp\n    .trim()\n    .split(/\\s+/)\n    .map((c) => replaceCaret(c, options))\n    .join(' ')\n}\n\nconst replaceCaret = (comp, options) => {\n  debug('caret', comp, options)\n  const r = options.loose ? re[t.CARETLOOSE] : re[t.CARET]\n  const z = options.includePrerelease ? '-0' : ''\n  return comp.replace(r, (_, M, m, p, pr) => {\n    debug('caret', comp, _, M, m, p, pr)\n    let ret\n\n    if (isX(M)) {\n      ret = ''\n    } else if (isX(m)) {\n      ret = `>=${M}.0.0${z} <${+M + 1}.0.0-0`\n    } else if (isX(p)) {\n      if (M === '0') {\n        ret = `>=${M}.${m}.0${z} <${M}.${+m + 1}.0-0`\n      } else {\n        ret = `>=${M}.${m}.0${z} <${+M + 1}.0.0-0`\n      }\n    } else if (pr) {\n      debug('replaceCaret pr', pr)\n      if (M === '0') {\n        if (m === '0') {\n          ret = `>=${M}.${m}.${p}-${pr\n          } <${M}.${m}.${+p + 1}-0`\n        } else {\n          ret = `>=${M}.${m}.${p}-${pr\n          } <${M}.${+m + 1}.0-0`\n        }\n      } else {\n        ret = `>=${M}.${m}.${p}-${pr\n        } <${+M + 1}.0.0-0`\n      }\n    } else {\n      debug('no pr')\n      if (M === '0') {\n        if (m === '0') {\n          ret = `>=${M}.${m}.${p\n          }${z} <${M}.${m}.${+p + 1}-0`\n        } else {\n          ret = `>=${M}.${m}.${p\n          }${z} <${M}.${+m + 1}.0-0`\n        }\n      } else {\n        ret = `>=${M}.${m}.${p\n        } <${+M + 1}.0.0-0`\n      }\n    }\n\n    debug('caret return', ret)\n    return ret\n  })\n}\n\nconst replaceXRanges = (comp, options) => {\n  debug('replaceXRanges', comp, options)\n  return comp\n    .split(/\\s+/)\n    .map((c) => replaceXRange(c, options))\n    .join(' ')\n}\n\nconst replaceXRange = (comp, options) => {\n  comp = comp.trim()\n  const r = options.loose ? re[t.XRANGELOOSE] : re[t.XRANGE]\n  return comp.replace(r, (ret, gtlt, M, m, p, pr) => {\n    debug('xRange', comp, ret, gtlt, M, m, p, pr)\n    const xM = isX(M)\n    const xm = xM || isX(m)\n    const xp = xm || isX(p)\n    const anyX = xp\n\n    if (gtlt === '=' && anyX) {\n      gtlt = ''\n    }\n\n    // if we're including prereleases in the match, then we need\n    // to fix this to -0, the lowest possible prerelease value\n    pr = options.includePrerelease ? '-0' : ''\n\n    if (xM) {\n      if (gtlt === '>' || gtlt === '<') {\n        // nothing is allowed\n        ret = '<0.0.0-0'\n      } else {\n        // nothing is forbidden\n        ret = '*'\n      }\n    } else if (gtlt && anyX) {\n      // we know patch is an x, because we have any x at all.\n      // replace X with 0\n      if (xm) {\n        m = 0\n      }\n      p = 0\n\n      if (gtlt === '>') {\n        // >1 => >=2.0.0\n        // >1.2 => >=1.3.0\n        gtlt = '>='\n        if (xm) {\n          M = +M + 1\n          m = 0\n          p = 0\n        } else {\n          m = +m + 1\n          p = 0\n        }\n      } else if (gtlt === '<=') {\n        // <=0.7.x is actually <0.8.0, since any 0.7.x should\n        // pass.  Similarly, <=7.x is actually <8.0.0, etc.\n        gtlt = '<'\n        if (xm) {\n          M = +M + 1\n        } else {\n          m = +m + 1\n        }\n      }\n\n      if (gtlt === '<') {\n        pr = '-0'\n      }\n\n      ret = `${gtlt + M}.${m}.${p}${pr}`\n    } else if (xm) {\n      ret = `>=${M}.0.0${pr} <${+M + 1}.0.0-0`\n    } else if (xp) {\n      ret = `>=${M}.${m}.0${pr\n      } <${M}.${+m + 1}.0-0`\n    }\n\n    debug('xRange return', ret)\n\n    return ret\n  })\n}\n\n// Because * is AND-ed with everything else in the comparator,\n// and '' means \"any version\", just remove the *s entirely.\nconst replaceStars = (comp, options) => {\n  debug('replaceStars', comp, options)\n  // Looseness is ignored here.  star is always as loose as it gets!\n  return comp\n    .trim()\n    .replace(re[t.STAR], '')\n}\n\nconst replaceGTE0 = (comp, options) => {\n  debug('replaceGTE0', comp, options)\n  return comp\n    .trim()\n    .replace(re[options.includePrerelease ? t.GTE0PRE : t.GTE0], '')\n}\n\n// This function is passed to string.replace(re[t.HYPHENRANGE])\n// M, m, patch, prerelease, build\n// 1.2 - 3.4.5 => >=1.2.0 <=3.4.5\n// 1.2.3 - 3.4 => >=1.2.0 <3.5.0-0 Any 3.4.x will do\n// 1.2 - 3.4 => >=1.2.0 <3.5.0-0\n// TODO build?\nconst hyphenReplace = incPr => ($0,\n  from, fM, fm, fp, fpr, fb,\n  to, tM, tm, tp, tpr) => {\n  if (isX(fM)) {\n    from = ''\n  } else if (isX(fm)) {\n    from = `>=${fM}.0.0${incPr ? '-0' : ''}`\n  } else if (isX(fp)) {\n    from = `>=${fM}.${fm}.0${incPr ? '-0' : ''}`\n  } else if (fpr) {\n    from = `>=${from}`\n  } else {\n    from = `>=${from}${incPr ? '-0' : ''}`\n  }\n\n  if (isX(tM)) {\n    to = ''\n  } else if (isX(tm)) {\n    to = `<${+tM + 1}.0.0-0`\n  } else if (isX(tp)) {\n    to = `<${tM}.${+tm + 1}.0-0`\n  } else if (tpr) {\n    to = `<=${tM}.${tm}.${tp}-${tpr}`\n  } else if (incPr) {\n    to = `<${tM}.${tm}.${+tp + 1}-0`\n  } else {\n    to = `<=${to}`\n  }\n\n  return `${from} ${to}`.trim()\n}\n\nconst testSet = (set, version, options) => {\n  for (let i = 0; i < set.length; i++) {\n    if (!set[i].test(version)) {\n      return false\n    }\n  }\n\n  if (version.prerelease.length && !options.includePrerelease) {\n    // Find the set of versions that are allowed to have prereleases\n    // For example, ^1.2.3-pr.1 desugars to >=1.2.3-pr.1 <2.0.0\n    // That should allow `1.2.3-pr.2` to pass.\n    // However, `1.2.4-alpha.notready` should NOT be allowed,\n    // even though it's within the range set by the comparators.\n    for (let i = 0; i < set.length; i++) {\n      debug(set[i].semver)\n      if (set[i].semver === Comparator.ANY) {\n        continue\n      }\n\n      if (set[i].semver.prerelease.length > 0) {\n        const allowed = set[i].semver\n        if (allowed.major === version.major &&\n            allowed.minor === version.minor &&\n            allowed.patch === version.patch) {\n          return true\n        }\n      }\n    }\n\n    // Version has a -pre, but it's not one of the ones we like.\n    return false\n  }\n\n  return true\n}\n",
    "'use strict'\n\nconst ANY = Symbol('SemVer ANY')\n// hoisted class for cyclic dependency\nclass Comparator {\n  static get ANY () {\n    return ANY\n  }\n\n  constructor (comp, options) {\n    options = parseOptions(options)\n\n    if (comp instanceof Comparator) {\n      if (comp.loose === !!options.loose) {\n        return comp\n      } else {\n        comp = comp.value\n      }\n    }\n\n    comp = comp.trim().split(/\\s+/).join(' ')\n    debug('comparator', comp, options)\n    this.options = options\n    this.loose = !!options.loose\n    this.parse(comp)\n\n    if (this.semver === ANY) {\n      this.value = ''\n    } else {\n      this.value = this.operator + this.semver.version\n    }\n\n    debug('comp', this)\n  }\n\n  parse (comp) {\n    const r = this.options.loose ? re[t.COMPARATORLOOSE] : re[t.COMPARATOR]\n    const m = comp.match(r)\n\n    if (!m) {\n      throw new TypeError(`Invalid comparator: ${comp}`)\n    }\n\n    this.operator = m[1] !== undefined ? m[1] : ''\n    if (this.operator === '=') {\n      this.operator = ''\n    }\n\n    // if it literally is just '>' or '' then allow anything.\n    if (!m[2]) {\n      this.semver = ANY\n    } else {\n      this.semver = new SemVer(m[2], this.options.loose)\n    }\n  }\n\n  toString () {\n    return this.value\n  }\n\n  test (version) {\n    debug('Comparator.test', version, this.options.loose)\n\n    if (this.semver === ANY || version === ANY) {\n      return true\n    }\n\n    if (typeof version === 'string') {\n      try {\n        version = new SemVer(version, this.options)\n      } catch (er) {\n        return false\n      }\n    }\n\n    return cmp(version, this.operator, this.semver, this.options)\n  }\n\n  intersects (comp, options) {\n    if (!(comp instanceof Comparator)) {\n      throw new TypeError('a Comparator is required')\n    }\n\n    if (this.operator === '') {\n      if (this.value === '') {\n        return true\n      }\n      return new Range(comp.value, options).test(this.value)\n    } else if (comp.operator === '') {\n      if (comp.value === '') {\n        return true\n      }\n      return new Range(this.value, options).test(comp.semver)\n    }\n\n    options = parseOptions(options)\n\n    // Special cases where nothing can possibly be lower\n    if (options.includePrerelease &&\n      (this.value === '<0.0.0-0' || comp.value === '<0.0.0-0')) {\n      return false\n    }\n    if (!options.includePrerelease &&\n      (this.value.startsWith('<0.0.0') || comp.value.startsWith('<0.0.0'))) {\n      return false\n    }\n\n    // Same direction increasing (> or >=)\n    if (this.operator.startsWith('>') && comp.operator.startsWith('>')) {\n      return true\n    }\n    // Same direction decreasing (< or <=)\n    if (this.operator.startsWith('<') && comp.operator.startsWith('<')) {\n      return true\n    }\n    // same SemVer and both sides are inclusive (<= or >=)\n    if (\n      (this.semver.version === comp.semver.version) &&\n      this.operator.includes('=') && comp.operator.includes('=')) {\n      return true\n    }\n    // opposite directions less than\n    if (cmp(this.semver, '<', comp.semver, options) &&\n      this.operator.startsWith('>') && comp.operator.startsWith('<')) {\n      return true\n    }\n    // opposite directions greater than\n    if (cmp(this.semver, '>', comp.semver, options) &&\n      this.operator.startsWith('<') && comp.operator.startsWith('>')) {\n      return true\n    }\n    return false\n  }\n}\n\nmodule.exports = Comparator\n\nconst parseOptions = require('../internal/parse-options')\nconst { safeRe: re, t } = require('../internal/re')\nconst cmp = require('../functions/cmp')\nconst debug = require('../internal/debug')\nconst SemVer = require('./semver')\nconst Range = require('./range')\n",
    "'use strict'\n\nconst Range = require('../classes/range')\nconst satisfies = (version, range, options) => {\n  try {\n    range = new Range(range, options)\n  } catch (er) {\n    return false\n  }\n  return range.test(version)\n}\nmodule.exports = satisfies\n",
    "'use strict'\n\nconst Range = require('../classes/range')\n\n// Mostly just for testing and legacy API reasons\nconst toComparators = (range, options) =>\n  new Range(range, options).set\n    .map(comp => comp.map(c => c.value).join(' ').trim().split(' '))\n\nmodule.exports = toComparators\n",
    "'use strict'\n\nconst SemVer = require('../classes/semver')\nconst Range = require('../classes/range')\n\nconst maxSatisfying = (versions, range, options) => {\n  let max = null\n  let maxSV = null\n  let rangeObj = null\n  try {\n    rangeObj = new Range(range, options)\n  } catch (er) {\n    return null\n  }\n  versions.forEach((v) => {\n    if (rangeObj.test(v)) {\n      // satisfies(v, range, options)\n      if (!max || maxSV.compare(v) === -1) {\n        // compare(max, v, true)\n        max = v\n        maxSV = new SemVer(max, options)\n      }\n    }\n  })\n  return max\n}\nmodule.exports = maxSatisfying\n",
    "'use strict'\n\nconst SemVer = require('../classes/semver')\nconst Range = require('../classes/range')\nconst minSatisfying = (versions, range, options) => {\n  let min = null\n  let minSV = null\n  let rangeObj = null\n  try {\n    rangeObj = new Range(range, options)\n  } catch (er) {\n    return null\n  }\n  versions.forEach((v) => {\n    if (rangeObj.test(v)) {\n      // satisfies(v, range, options)\n      if (!min || minSV.compare(v) === 1) {\n        // compare(min, v, true)\n        min = v\n        minSV = new SemVer(min, options)\n      }\n    }\n  })\n  return min\n}\nmodule.exports = minSatisfying\n",
    "'use strict'\n\nconst SemVer = require('../classes/semver')\nconst Range = require('../classes/range')\nconst gt = require('../functions/gt')\n\nconst minVersion = (range, loose) => {\n  range = new Range(range, loose)\n\n  let minver = new SemVer('0.0.0')\n  if (range.test(minver)) {\n    return minver\n  }\n\n  minver = new SemVer('0.0.0-0')\n  if (range.test(minver)) {\n    return minver\n  }\n\n  minver = null\n  for (let i = 0; i < range.set.length; ++i) {\n    const comparators = range.set[i]\n\n    let setMin = null\n    comparators.forEach((comparator) => {\n      // Clone to avoid manipulating the comparator's semver object.\n      const compver = new SemVer(comparator.semver.version)\n      switch (comparator.operator) {\n        case '>':\n          if (compver.prerelease.length === 0) {\n            compver.patch++\n          } else {\n            compver.prerelease.push(0)\n          }\n          compver.raw = compver.format()\n          /* fallthrough */\n        case '':\n        case '>=':\n          if (!setMin || gt(compver, setMin)) {\n            setMin = compver\n          }\n          break\n        case '<':\n        case '<=':\n          /* Ignore maximum versions */\n          break\n        /* istanbul ignore next */\n        default:\n          throw new Error(`Unexpected operation: ${comparator.operator}`)\n      }\n    })\n    if (setMin && (!minver || gt(minver, setMin))) {\n      minver = setMin\n    }\n  }\n\n  if (minver && range.test(minver)) {\n    return minver\n  }\n\n  return null\n}\nmodule.exports = minVersion\n",
    "'use strict'\n\nconst Range = require('../classes/range')\nconst validRange = (range, options) => {\n  try {\n    // Return '*' instead of '' so that truthiness works.\n    // This will throw if it's invalid anyway\n    return new Range(range, options).range || '*'\n  } catch (er) {\n    return null\n  }\n}\nmodule.exports = validRange\n",
    "'use strict'\n\nconst SemVer = require('../classes/semver')\nconst Comparator = require('../classes/comparator')\nconst { ANY } = Comparator\nconst Range = require('../classes/range')\nconst satisfies = require('../functions/satisfies')\nconst gt = require('../functions/gt')\nconst lt = require('../functions/lt')\nconst lte = require('../functions/lte')\nconst gte = require('../functions/gte')\n\nconst outside = (version, range, hilo, options) => {\n  version = new SemVer(version, options)\n  range = new Range(range, options)\n\n  let gtfn, ltefn, ltfn, comp, ecomp\n  switch (hilo) {\n    case '>':\n      gtfn = gt\n      ltefn = lte\n      ltfn = lt\n      comp = '>'\n      ecomp = '>='\n      break\n    case '<':\n      gtfn = lt\n      ltefn = gte\n      ltfn = gt\n      comp = '<'\n      ecomp = '<='\n      break\n    default:\n      throw new TypeError('Must provide a hilo val of \"<\" or \">\"')\n  }\n\n  // If it satisfies the range it is not outside\n  if (satisfies(version, range, options)) {\n    return false\n  }\n\n  // From now on, variable terms are as if we're in \"gtr\" mode.\n  // but note that everything is flipped for the \"ltr\" function.\n\n  for (let i = 0; i < range.set.length; ++i) {\n    const comparators = range.set[i]\n\n    let high = null\n    let low = null\n\n    comparators.forEach((comparator) => {\n      if (comparator.semver === ANY) {\n        comparator = new Comparator('>=0.0.0')\n      }\n      high = high || comparator\n      low = low || comparator\n      if (gtfn(comparator.semver, high.semver, options)) {\n        high = comparator\n      } else if (ltfn(comparator.semver, low.semver, options)) {\n        low = comparator\n      }\n    })\n\n    // If the edge version comparator has a operator then our version\n    // isn't outside it\n    if (high.operator === comp || high.operator === ecomp) {\n      return false\n    }\n\n    // If the lowest version comparator has an operator and our version\n    // is less than it then it isn't higher than the range\n    if ((!low.operator || low.operator === comp) &&\n        ltefn(version, low.semver)) {\n      return false\n    } else if (low.operator === ecomp && ltfn(version, low.semver)) {\n      return false\n    }\n  }\n  return true\n}\n\nmodule.exports = outside\n",
    "'use strict'\n\n// Determine if version is greater than all the versions possible in the range.\nconst outside = require('./outside')\nconst gtr = (version, range, options) => outside(version, range, '>', options)\nmodule.exports = gtr\n",
    "'use strict'\n\nconst outside = require('./outside')\n// Determine if version is less than all the versions possible in the range\nconst ltr = (version, range, options) => outside(version, range, '<', options)\nmodule.exports = ltr\n",
    "'use strict'\n\nconst Range = require('../classes/range')\nconst intersects = (r1, r2, options) => {\n  r1 = new Range(r1, options)\n  r2 = new Range(r2, options)\n  return r1.intersects(r2, options)\n}\nmodule.exports = intersects\n",
    "'use strict'\n\n// given a set of versions and a range, create a \"simplified\" range\n// that includes the same versions that the original range does\n// If the original range is shorter than the simplified one, return that.\nconst satisfies = require('../functions/satisfies.js')\nconst compare = require('../functions/compare.js')\nmodule.exports = (versions, range, options) => {\n  const set = []\n  let first = null\n  let prev = null\n  const v = versions.sort((a, b) => compare(a, b, options))\n  for (const version of v) {\n    const included = satisfies(version, range, options)\n    if (included) {\n      prev = version\n      if (!first) {\n        first = version\n      }\n    } else {\n      if (prev) {\n        set.push([first, prev])\n      }\n      prev = null\n      first = null\n    }\n  }\n  if (first) {\n    set.push([first, null])\n  }\n\n  const ranges = []\n  for (const [min, max] of set) {\n    if (min === max) {\n      ranges.push(min)\n    } else if (!max && min === v[0]) {\n      ranges.push('*')\n    } else if (!max) {\n      ranges.push(`>=${min}`)\n    } else if (min === v[0]) {\n      ranges.push(`<=${max}`)\n    } else {\n      ranges.push(`${min} - ${max}`)\n    }\n  }\n  const simplified = ranges.join(' || ')\n  const original = typeof range.raw === 'string' ? range.raw : String(range)\n  return simplified.length < original.length ? simplified : range\n}\n",
    "'use strict'\n\nconst Range = require('../classes/range.js')\nconst Comparator = require('../classes/comparator.js')\nconst { ANY } = Comparator\nconst satisfies = require('../functions/satisfies.js')\nconst compare = require('../functions/compare.js')\n\n// Complex range `r1 || r2 || ...` is a subset of `R1 || R2 || ...` iff:\n// - Every simple range `r1, r2, ...` is a null set, OR\n// - Every simple range `r1, r2, ...` which is not a null set is a subset of\n//   some `R1, R2, ...`\n//\n// Simple range `c1 c2 ...` is a subset of simple range `C1 C2 ...` iff:\n// - If c is only the ANY comparator\n//   - If C is only the ANY comparator, return true\n//   - Else if in prerelease mode, return false\n//   - else replace c with `[>=0.0.0]`\n// - If C is only the ANY comparator\n//   - if in prerelease mode, return true\n//   - else replace C with `[>=0.0.0]`\n// - Let EQ be the set of = comparators in c\n// - If EQ is more than one, return true (null set)\n// - Let GT be the highest > or >= comparator in c\n// - Let LT be the lowest < or <= comparator in c\n// - If GT and LT, and GT.semver > LT.semver, return true (null set)\n// - If any C is a = range, and GT or LT are set, return false\n// - If EQ\n//   - If GT, and EQ does not satisfy GT, return true (null set)\n//   - If LT, and EQ does not satisfy LT, return true (null set)\n//   - If EQ satisfies every C, return true\n//   - Else return false\n// - If GT\n//   - If GT.semver is lower than any > or >= comp in C, return false\n//   - If GT is >=, and GT.semver does not satisfy every C, return false\n//   - If GT.semver has a prerelease, and not in prerelease mode\n//     - If no C has a prerelease and the GT.semver tuple, return false\n// - If LT\n//   - If LT.semver is greater than any < or <= comp in C, return false\n//   - If LT is <=, and LT.semver does not satisfy every C, return false\n//   - If GT.semver has a prerelease, and not in prerelease mode\n//     - If no C has a prerelease and the LT.semver tuple, return false\n// - Else return true\n\nconst subset = (sub, dom, options = {}) => {\n  if (sub === dom) {\n    return true\n  }\n\n  sub = new Range(sub, options)\n  dom = new Range(dom, options)\n  let sawNonNull = false\n\n  OUTER: for (const simpleSub of sub.set) {\n    for (const simpleDom of dom.set) {\n      const isSub = simpleSubset(simpleSub, simpleDom, options)\n      sawNonNull = sawNonNull || isSub !== null\n      if (isSub) {\n        continue OUTER\n      }\n    }\n    // the null set is a subset of everything, but null simple ranges in\n    // a complex range should be ignored.  so if we saw a non-null range,\n    // then we know this isn't a subset, but if EVERY simple range was null,\n    // then it is a subset.\n    if (sawNonNull) {\n      return false\n    }\n  }\n  return true\n}\n\nconst minimumVersionWithPreRelease = [new Comparator('>=0.0.0-0')]\nconst minimumVersion = [new Comparator('>=0.0.0')]\n\nconst simpleSubset = (sub, dom, options) => {\n  if (sub === dom) {\n    return true\n  }\n\n  if (sub.length === 1 && sub[0].semver === ANY) {\n    if (dom.length === 1 && dom[0].semver === ANY) {\n      return true\n    } else if (options.includePrerelease) {\n      sub = minimumVersionWithPreRelease\n    } else {\n      sub = minimumVersion\n    }\n  }\n\n  if (dom.length === 1 && dom[0].semver === ANY) {\n    if (options.includePrerelease) {\n      return true\n    } else {\n      dom = minimumVersion\n    }\n  }\n\n  const eqSet = new Set()\n  let gt, lt\n  for (const c of sub) {\n    if (c.operator === '>' || c.operator === '>=') {\n      gt = higherGT(gt, c, options)\n    } else if (c.operator === '<' || c.operator === '<=') {\n      lt = lowerLT(lt, c, options)\n    } else {\n      eqSet.add(c.semver)\n    }\n  }\n\n  if (eqSet.size > 1) {\n    return null\n  }\n\n  let gtltComp\n  if (gt && lt) {\n    gtltComp = compare(gt.semver, lt.semver, options)\n    if (gtltComp > 0) {\n      return null\n    } else if (gtltComp === 0 && (gt.operator !== '>=' || lt.operator !== '<=')) {\n      return null\n    }\n  }\n\n  // will iterate one or zero times\n  for (const eq of eqSet) {\n    if (gt && !satisfies(eq, String(gt), options)) {\n      return null\n    }\n\n    if (lt && !satisfies(eq, String(lt), options)) {\n      return null\n    }\n\n    for (const c of dom) {\n      if (!satisfies(eq, String(c), options)) {\n        return false\n      }\n    }\n\n    return true\n  }\n\n  let higher, lower\n  let hasDomLT, hasDomGT\n  // if the subset has a prerelease, we need a comparator in the superset\n  // with the same tuple and a prerelease, or it's not a subset\n  let needDomLTPre = lt &&\n    !options.includePrerelease &&\n    lt.semver.prerelease.length ? lt.semver : false\n  let needDomGTPre = gt &&\n    !options.includePrerelease &&\n    gt.semver.prerelease.length ? gt.semver : false\n  // exception: <1.2.3-0 is the same as <1.2.3\n  if (needDomLTPre && needDomLTPre.prerelease.length === 1 &&\n      lt.operator === '<' && needDomLTPre.prerelease[0] === 0) {\n    needDomLTPre = false\n  }\n\n  for (const c of dom) {\n    hasDomGT = hasDomGT || c.operator === '>' || c.operator === '>='\n    hasDomLT = hasDomLT || c.operator === '<' || c.operator === '<='\n    if (gt) {\n      if (needDomGTPre) {\n        if (c.semver.prerelease && c.semver.prerelease.length &&\n            c.semver.major === needDomGTPre.major &&\n            c.semver.minor === needDomGTPre.minor &&\n            c.semver.patch === needDomGTPre.patch) {\n          needDomGTPre = false\n        }\n      }\n      if (c.operator === '>' || c.operator === '>=') {\n        higher = higherGT(gt, c, options)\n        if (higher === c && higher !== gt) {\n          return false\n        }\n      } else if (gt.operator === '>=' && !satisfies(gt.semver, String(c), options)) {\n        return false\n      }\n    }\n    if (lt) {\n      if (needDomLTPre) {\n        if (c.semver.prerelease && c.semver.prerelease.length &&\n            c.semver.major === needDomLTPre.major &&\n            c.semver.minor === needDomLTPre.minor &&\n            c.semver.patch === needDomLTPre.patch) {\n          needDomLTPre = false\n        }\n      }\n      if (c.operator === '<' || c.operator === '<=') {\n        lower = lowerLT(lt, c, options)\n        if (lower === c && lower !== lt) {\n          return false\n        }\n      } else if (lt.operator === '<=' && !satisfies(lt.semver, String(c), options)) {\n        return false\n      }\n    }\n    if (!c.operator && (lt || gt) && gtltComp !== 0) {\n      return false\n    }\n  }\n\n  // if there was a < or >, and nothing in the dom, then must be false\n  // UNLESS it was limited by another range in the other direction.\n  // Eg, >1.0.0 <1.0.1 is still a subset of <2.0.0\n  if (gt && hasDomLT && !lt && gtltComp !== 0) {\n    return false\n  }\n\n  if (lt && hasDomGT && !gt && gtltComp !== 0) {\n    return false\n  }\n\n  // we needed a prerelease range in a specific tuple, but didn't get one\n  // then this isn't a subset.  eg >=1.2.3-pre is not a subset of >=1.0.0,\n  // because it includes prereleases in the 1.2.3 tuple\n  if (needDomGTPre || needDomLTPre) {\n    return false\n  }\n\n  return true\n}\n\n// >=1.2.3 is lower than >1.2.3\nconst higherGT = (a, b, options) => {\n  if (!a) {\n    return b\n  }\n  const comp = compare(a.semver, b.semver, options)\n  return comp > 0 ? a\n    : comp < 0 ? b\n    : b.operator === '>' && a.operator === '>=' ? b\n    : a\n}\n\n// <=1.2.3 is higher than <1.2.3\nconst lowerLT = (a, b, options) => {\n  if (!a) {\n    return b\n  }\n  const comp = compare(a.semver, b.semver, options)\n  return comp < 0 ? a\n    : comp > 0 ? b\n    : b.operator === '<' && a.operator === '<=' ? b\n    : a\n}\n\nmodule.exports = subset\n",
    "'use strict'\n\n// just pre-load all the stuff that index.js lazily exports\nconst internalRe = require('./internal/re')\nconst constants = require('./internal/constants')\nconst SemVer = require('./classes/semver')\nconst identifiers = require('./internal/identifiers')\nconst parse = require('./functions/parse')\nconst valid = require('./functions/valid')\nconst clean = require('./functions/clean')\nconst inc = require('./functions/inc')\nconst diff = require('./functions/diff')\nconst major = require('./functions/major')\nconst minor = require('./functions/minor')\nconst patch = require('./functions/patch')\nconst prerelease = require('./functions/prerelease')\nconst compare = require('./functions/compare')\nconst rcompare = require('./functions/rcompare')\nconst compareLoose = require('./functions/compare-loose')\nconst compareBuild = require('./functions/compare-build')\nconst sort = require('./functions/sort')\nconst rsort = require('./functions/rsort')\nconst gt = require('./functions/gt')\nconst lt = require('./functions/lt')\nconst eq = require('./functions/eq')\nconst neq = require('./functions/neq')\nconst gte = require('./functions/gte')\nconst lte = require('./functions/lte')\nconst cmp = require('./functions/cmp')\nconst coerce = require('./functions/coerce')\nconst Comparator = require('./classes/comparator')\nconst Range = require('./classes/range')\nconst satisfies = require('./functions/satisfies')\nconst toComparators = require('./ranges/to-comparators')\nconst maxSatisfying = require('./ranges/max-satisfying')\nconst minSatisfying = require('./ranges/min-satisfying')\nconst minVersion = require('./ranges/min-version')\nconst validRange = require('./ranges/valid')\nconst outside = require('./ranges/outside')\nconst gtr = require('./ranges/gtr')\nconst ltr = require('./ranges/ltr')\nconst intersects = require('./ranges/intersects')\nconst simplifyRange = require('./ranges/simplify')\nconst subset = require('./ranges/subset')\nmodule.exports = {\n  parse,\n  valid,\n  clean,\n  inc,\n  diff,\n  major,\n  minor,\n  patch,\n  prerelease,\n  compare,\n  rcompare,\n  compareLoose,\n  compareBuild,\n  sort,\n  rsort,\n  gt,\n  lt,\n  eq,\n  neq,\n  gte,\n  lte,\n  cmp,\n  coerce,\n  Comparator,\n  Range,\n  satisfies,\n  toComparators,\n  maxSatisfying,\n  minSatisfying,\n  minVersion,\n  validRange,\n  outside,\n  gtr,\n  ltr,\n  intersects,\n  simplifyRange,\n  subset,\n  SemVer,\n  re: internalRe.re,\n  src: internalRe.src,\n  tokens: internalRe.t,\n  SEMVER_SPEC_VERSION: constants.SEMVER_SPEC_VERSION,\n  RELEASE_TYPES: constants.RELEASE_TYPES,\n  compareIdentifiers: identifiers.compareIdentifiers,\n  rcompareIdentifiers: identifiers.rcompareIdentifiers,\n}\n",
    "const semver = require('semver');\n\nmodule.exports = semver.satisfies(process.version, '>=15.7.0');\n",
    "const semver = require('semver');\n\nmodule.exports = semver.satisfies(process.version, '>=16.9.0');\n",
    "const ASYMMETRIC_KEY_DETAILS_SUPPORTED = require('./asymmetricKeyDetailsSupported');\nconst RSA_PSS_KEY_DETAILS_SUPPORTED = require('./rsaPssKeyDetailsSupported');\n\nconst allowedAlgorithmsForKeys = {\n  'ec': ['ES256', 'ES384', 'ES512'],\n  'rsa': ['RS256', 'PS256', 'RS384', 'PS384', 'RS512', 'PS512'],\n  'rsa-pss': ['PS256', 'PS384', 'PS512']\n};\n\nconst allowedCurves = {\n  ES256: 'prime256v1',\n  ES384: 'secp384r1',\n  ES512: 'secp521r1',\n};\n\nmodule.exports = function(algorithm, key) {\n  if (!algorithm || !key) return;\n\n  const keyType = key.asymmetricKeyType;\n  if (!keyType) return;\n\n  const allowedAlgorithms = allowedAlgorithmsForKeys[keyType];\n\n  if (!allowedAlgorithms) {\n    throw new Error(`Unknown key type \"${keyType}\".`);\n  }\n\n  if (!allowedAlgorithms.includes(algorithm)) {\n    throw new Error(`\"alg\" parameter for \"${keyType}\" key type must be one of: ${allowedAlgorithms.join(', ')}.`)\n  }\n\n  /*\n   * Ignore the next block from test coverage because it gets executed\n   * conditionally depending on the Node version. Not ignoring it would\n   * prevent us from reaching the target % of coverage for versions of\n   * Node under 15.7.0.\n   */\n  /* istanbul ignore next */\n  if (ASYMMETRIC_KEY_DETAILS_SUPPORTED) {\n    switch (keyType) {\n    case 'ec':\n      const keyCurve = key.asymmetricKeyDetails.namedCurve;\n      const allowedCurve = allowedCurves[algorithm];\n\n      if (keyCurve !== allowedCurve) {\n        throw new Error(`\"alg\" parameter \"${algorithm}\" requires curve \"${allowedCurve}\".`);\n      }\n      break;\n\n    case 'rsa-pss':\n      if (RSA_PSS_KEY_DETAILS_SUPPORTED) {\n        const length = parseInt(algorithm.slice(-3), 10);\n        const { hashAlgorithm, mgf1HashAlgorithm, saltLength } = key.asymmetricKeyDetails;\n\n        if (hashAlgorithm !== `sha${length}` || mgf1HashAlgorithm !== hashAlgorithm) {\n          throw new Error(`Invalid key for this operation, its RSA-PSS parameters do not meet the requirements of \"alg\" ${algorithm}.`);\n        }\n\n        if (saltLength !== undefined && saltLength > length >> 3) {\n          throw new Error(`Invalid key for this operation, its RSA-PSS parameter saltLength does not meet the requirements of \"alg\" ${algorithm}.`)\n        }\n      }\n      break;\n    }\n  }\n}\n",
    "var semver = require('semver');\n\nmodule.exports = semver.satisfies(process.version, '^6.12.0 || >=8.0.0');\n",
    "const JsonWebTokenError = require('./lib/JsonWebTokenError');\nconst NotBeforeError = require('./lib/NotBeforeError');\nconst TokenExpiredError = require('./lib/TokenExpiredError');\nconst decode = require('./decode');\nconst timespan = require('./lib/timespan');\nconst validateAsymmetricKey = require('./lib/validateAsymmetricKey');\nconst PS_SUPPORTED = require('./lib/psSupported');\nconst jws = require('jws');\nconst {KeyObject, createSecretKey, createPublicKey} = require(\"crypto\");\n\nconst PUB_KEY_ALGS = ['RS256', 'RS384', 'RS512'];\nconst EC_KEY_ALGS = ['ES256', 'ES384', 'ES512'];\nconst RSA_KEY_ALGS = ['RS256', 'RS384', 'RS512'];\nconst HS_ALGS = ['HS256', 'HS384', 'HS512'];\n\nif (PS_SUPPORTED) {\n  PUB_KEY_ALGS.splice(PUB_KEY_ALGS.length, 0, 'PS256', 'PS384', 'PS512');\n  RSA_KEY_ALGS.splice(RSA_KEY_ALGS.length, 0, 'PS256', 'PS384', 'PS512');\n}\n\nmodule.exports = function (jwtString, secretOrPublicKey, options, callback) {\n  if ((typeof options === 'function') && !callback) {\n    callback = options;\n    options = {};\n  }\n\n  if (!options) {\n    options = {};\n  }\n\n  //clone this object since we are going to mutate it.\n  options = Object.assign({}, options);\n\n  let done;\n\n  if (callback) {\n    done = callback;\n  } else {\n    done = function(err, data) {\n      if (err) throw err;\n      return data;\n    };\n  }\n\n  if (options.clockTimestamp && typeof options.clockTimestamp !== 'number') {\n    return done(new JsonWebTokenError('clockTimestamp must be a number'));\n  }\n\n  if (options.nonce !== undefined && (typeof options.nonce !== 'string' || options.nonce.trim() === '')) {\n    return done(new JsonWebTokenError('nonce must be a non-empty string'));\n  }\n\n  if (options.allowInvalidAsymmetricKeyTypes !== undefined && typeof options.allowInvalidAsymmetricKeyTypes !== 'boolean') {\n    return done(new JsonWebTokenError('allowInvalidAsymmetricKeyTypes must be a boolean'));\n  }\n\n  const clockTimestamp = options.clockTimestamp || Math.floor(Date.now() / 1000);\n\n  if (!jwtString){\n    return done(new JsonWebTokenError('jwt must be provided'));\n  }\n\n  if (typeof jwtString !== 'string') {\n    return done(new JsonWebTokenError('jwt must be a string'));\n  }\n\n  const parts = jwtString.split('.');\n\n  if (parts.length !== 3){\n    return done(new JsonWebTokenError('jwt malformed'));\n  }\n\n  let decodedToken;\n\n  try {\n    decodedToken = decode(jwtString, { complete: true });\n  } catch(err) {\n    return done(err);\n  }\n\n  if (!decodedToken) {\n    return done(new JsonWebTokenError('invalid token'));\n  }\n\n  const header = decodedToken.header;\n  let getSecret;\n\n  if(typeof secretOrPublicKey === 'function') {\n    if(!callback) {\n      return done(new JsonWebTokenError('verify must be called asynchronous if secret or public key is provided as a callback'));\n    }\n\n    getSecret = secretOrPublicKey;\n  }\n  else {\n    getSecret = function(header, secretCallback) {\n      return secretCallback(null, secretOrPublicKey);\n    };\n  }\n\n  return getSecret(header, function(err, secretOrPublicKey) {\n    if(err) {\n      return done(new JsonWebTokenError('error in secret or public key callback: ' + err.message));\n    }\n\n    const hasSignature = parts[2].trim() !== '';\n\n    if (!hasSignature && secretOrPublicKey){\n      return done(new JsonWebTokenError('jwt signature is required'));\n    }\n\n    if (hasSignature && !secretOrPublicKey) {\n      return done(new JsonWebTokenError('secret or public key must be provided'));\n    }\n\n    if (!hasSignature && !options.algorithms) {\n      return done(new JsonWebTokenError('please specify \"none\" in \"algorithms\" to verify unsigned tokens'));\n    }\n\n    if (secretOrPublicKey != null && !(secretOrPublicKey instanceof KeyObject)) {\n      try {\n        secretOrPublicKey = createPublicKey(secretOrPublicKey);\n      } catch (_) {\n        try {\n          secretOrPublicKey = createSecretKey(typeof secretOrPublicKey === 'string' ? Buffer.from(secretOrPublicKey) : secretOrPublicKey);\n        } catch (_) {\n          return done(new JsonWebTokenError('secretOrPublicKey is not valid key material'))\n        }\n      }\n    }\n\n    if (!options.algorithms) {\n      if (secretOrPublicKey.type === 'secret') {\n        options.algorithms = HS_ALGS;\n      } else if (['rsa', 'rsa-pss'].includes(secretOrPublicKey.asymmetricKeyType)) {\n        options.algorithms = RSA_KEY_ALGS\n      } else if (secretOrPublicKey.asymmetricKeyType === 'ec') {\n        options.algorithms = EC_KEY_ALGS\n      } else {\n        options.algorithms = PUB_KEY_ALGS\n      }\n    }\n\n    if (options.algorithms.indexOf(decodedToken.header.alg) === -1) {\n      return done(new JsonWebTokenError('invalid algorithm'));\n    }\n\n    if (header.alg.startsWith('HS') && secretOrPublicKey.type !== 'secret') {\n      return done(new JsonWebTokenError((`secretOrPublicKey must be a symmetric key when using ${header.alg}`)))\n    } else if (/^(?:RS|PS|ES)/.test(header.alg) && secretOrPublicKey.type !== 'public') {\n      return done(new JsonWebTokenError((`secretOrPublicKey must be an asymmetric key when using ${header.alg}`)))\n    }\n\n    if (!options.allowInvalidAsymmetricKeyTypes) {\n      try {\n        validateAsymmetricKey(header.alg, secretOrPublicKey);\n      } catch (e) {\n        return done(e);\n      }\n    }\n\n    let valid;\n\n    try {\n      valid = jws.verify(jwtString, decodedToken.header.alg, secretOrPublicKey);\n    } catch (e) {\n      return done(e);\n    }\n\n    if (!valid) {\n      return done(new JsonWebTokenError('invalid signature'));\n    }\n\n    const payload = decodedToken.payload;\n\n    if (typeof payload.nbf !== 'undefined' && !options.ignoreNotBefore) {\n      if (typeof payload.nbf !== 'number') {\n        return done(new JsonWebTokenError('invalid nbf value'));\n      }\n      if (payload.nbf > clockTimestamp + (options.clockTolerance || 0)) {\n        return done(new NotBeforeError('jwt not active', new Date(payload.nbf * 1000)));\n      }\n    }\n\n    if (typeof payload.exp !== 'undefined' && !options.ignoreExpiration) {\n      if (typeof payload.exp !== 'number') {\n        return done(new JsonWebTokenError('invalid exp value'));\n      }\n      if (clockTimestamp >= payload.exp + (options.clockTolerance || 0)) {\n        return done(new TokenExpiredError('jwt expired', new Date(payload.exp * 1000)));\n      }\n    }\n\n    if (options.audience) {\n      const audiences = Array.isArray(options.audience) ? options.audience : [options.audience];\n      const target = Array.isArray(payload.aud) ? payload.aud : [payload.aud];\n\n      const match = target.some(function (targetAudience) {\n        return audiences.some(function (audience) {\n          return audience instanceof RegExp ? audience.test(targetAudience) : audience === targetAudience;\n        });\n      });\n\n      if (!match) {\n        return done(new JsonWebTokenError('jwt audience invalid. expected: ' + audiences.join(' or ')));\n      }\n    }\n\n    if (options.issuer) {\n      const invalid_issuer =\n              (typeof options.issuer === 'string' && payload.iss !== options.issuer) ||\n              (Array.isArray(options.issuer) && options.issuer.indexOf(payload.iss) === -1);\n\n      if (invalid_issuer) {\n        return done(new JsonWebTokenError('jwt issuer invalid. expected: ' + options.issuer));\n      }\n    }\n\n    if (options.subject) {\n      if (payload.sub !== options.subject) {\n        return done(new JsonWebTokenError('jwt subject invalid. expected: ' + options.subject));\n      }\n    }\n\n    if (options.jwtid) {\n      if (payload.jti !== options.jwtid) {\n        return done(new JsonWebTokenError('jwt jwtid invalid. expected: ' + options.jwtid));\n      }\n    }\n\n    if (options.nonce) {\n      if (payload.nonce !== options.nonce) {\n        return done(new JsonWebTokenError('jwt nonce invalid. expected: ' + options.nonce));\n      }\n    }\n\n    if (options.maxAge) {\n      if (typeof payload.iat !== 'number') {\n        return done(new JsonWebTokenError('iat required when maxAge is specified'));\n      }\n\n      const maxAgeTimestamp = timespan(options.maxAge, payload.iat);\n      if (typeof maxAgeTimestamp === 'undefined') {\n        return done(new JsonWebTokenError('\"maxAge\" should be a number of seconds or string representing a timespan eg: \"1d\", \"20h\", 60'));\n      }\n      if (clockTimestamp >= maxAgeTimestamp + (options.clockTolerance || 0)) {\n        return done(new TokenExpiredError('maxAge exceeded', new Date(maxAgeTimestamp * 1000)));\n      }\n    }\n\n    if (options.complete === true) {\n      const signature = decodedToken.signature;\n\n      return done(null, {\n        header: header,\n        payload: payload,\n        signature: signature\n      });\n    }\n\n    return done(null, payload);\n  });\n};\n",
    "/**\n * lodash (Custom Build) <https://lodash.com/>\n * Build: `lodash modularize exports=\"npm\" -o ./`\n * Copyright jQuery Foundation and other contributors <https://jquery.org/>\n * Released under MIT license <https://lodash.com/license>\n * Based on Underscore.js 1.8.3 <http://underscorejs.org/LICENSE>\n * Copyright Jeremy Ashkenas, DocumentCloud and Investigative Reporters & Editors\n */\n\n/** Used as references for various `Number` constants. */\nvar INFINITY = 1 / 0,\n    MAX_SAFE_INTEGER = 9007199254740991,\n    MAX_INTEGER = 1.7976931348623157e+308,\n    NAN = 0 / 0;\n\n/** `Object#toString` result references. */\nvar argsTag = '[object Arguments]',\n    funcTag = '[object Function]',\n    genTag = '[object GeneratorFunction]',\n    stringTag = '[object String]',\n    symbolTag = '[object Symbol]';\n\n/** Used to match leading and trailing whitespace. */\nvar reTrim = /^\\s+|\\s+$/g;\n\n/** Used to detect bad signed hexadecimal string values. */\nvar reIsBadHex = /^[-+]0x[0-9a-f]+$/i;\n\n/** Used to detect binary string values. */\nvar reIsBinary = /^0b[01]+$/i;\n\n/** Used to detect octal string values. */\nvar reIsOctal = /^0o[0-7]+$/i;\n\n/** Used to detect unsigned integer values. */\nvar reIsUint = /^(?:0|[1-9]\\d*)$/;\n\n/** Built-in method references without a dependency on `root`. */\nvar freeParseInt = parseInt;\n\n/**\n * A specialized version of `_.map` for arrays without support for iteratee\n * shorthands.\n *\n * @private\n * @param {Array} [array] The array to iterate over.\n * @param {Function} iteratee The function invoked per iteration.\n * @returns {Array} Returns the new mapped array.\n */\nfunction arrayMap(array, iteratee) {\n  var index = -1,\n      length = array ? array.length : 0,\n      result = Array(length);\n\n  while (++index < length) {\n    result[index] = iteratee(array[index], index, array);\n  }\n  return result;\n}\n\n/**\n * The base implementation of `_.findIndex` and `_.findLastIndex` without\n * support for iteratee shorthands.\n *\n * @private\n * @param {Array} array The array to inspect.\n * @param {Function} predicate The function invoked per iteration.\n * @param {number} fromIndex The index to search from.\n * @param {boolean} [fromRight] Specify iterating from right to left.\n * @returns {number} Returns the index of the matched value, else `-1`.\n */\nfunction baseFindIndex(array, predicate, fromIndex, fromRight) {\n  var length = array.length,\n      index = fromIndex + (fromRight ? 1 : -1);\n\n  while ((fromRight ? index-- : ++index < length)) {\n    if (predicate(array[index], index, array)) {\n      return index;\n    }\n  }\n  return -1;\n}\n\n/**\n * The base implementation of `_.indexOf` without `fromIndex` bounds checks.\n *\n * @private\n * @param {Array} array The array to inspect.\n * @param {*} value The value to search for.\n * @param {number} fromIndex The index to search from.\n * @returns {number} Returns the index of the matched value, else `-1`.\n */\nfunction baseIndexOf(array, value, fromIndex) {\n  if (value !== value) {\n    return baseFindIndex(array, baseIsNaN, fromIndex);\n  }\n  var index = fromIndex - 1,\n      length = array.length;\n\n  while (++index < length) {\n    if (array[index] === value) {\n      return index;\n    }\n  }\n  return -1;\n}\n\n/**\n * The base implementation of `_.isNaN` without support for number objects.\n *\n * @private\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is `NaN`, else `false`.\n */\nfunction baseIsNaN(value) {\n  return value !== value;\n}\n\n/**\n * The base implementation of `_.times` without support for iteratee shorthands\n * or max array length checks.\n *\n * @private\n * @param {number} n The number of times to invoke `iteratee`.\n * @param {Function} iteratee The function invoked per iteration.\n * @returns {Array} Returns the array of results.\n */\nfunction baseTimes(n, iteratee) {\n  var index = -1,\n      result = Array(n);\n\n  while (++index < n) {\n    result[index] = iteratee(index);\n  }\n  return result;\n}\n\n/**\n * The base implementation of `_.values` and `_.valuesIn` which creates an\n * array of `object` property values corresponding to the property names\n * of `props`.\n *\n * @private\n * @param {Object} object The object to query.\n * @param {Array} props The property names to get values for.\n * @returns {Object} Returns the array of property values.\n */\nfunction baseValues(object, props) {\n  return arrayMap(props, function(key) {\n    return object[key];\n  });\n}\n\n/**\n * Creates a unary function that invokes `func` with its argument transformed.\n *\n * @private\n * @param {Function} func The function to wrap.\n * @param {Function} transform The argument transform.\n * @returns {Function} Returns the new function.\n */\nfunction overArg(func, transform) {\n  return function(arg) {\n    return func(transform(arg));\n  };\n}\n\n/** Used for built-in method references. */\nvar objectProto = Object.prototype;\n\n/** Used to check objects for own properties. */\nvar hasOwnProperty = objectProto.hasOwnProperty;\n\n/**\n * Used to resolve the\n * [`toStringTag`](http://ecma-international.org/ecma-262/7.0/#sec-object.prototype.tostring)\n * of values.\n */\nvar objectToString = objectProto.toString;\n\n/** Built-in value references. */\nvar propertyIsEnumerable = objectProto.propertyIsEnumerable;\n\n/* Built-in method references for those with the same name as other `lodash` methods. */\nvar nativeKeys = overArg(Object.keys, Object),\n    nativeMax = Math.max;\n\n/**\n * Creates an array of the enumerable property names of the array-like `value`.\n *\n * @private\n * @param {*} value The value to query.\n * @param {boolean} inherited Specify returning inherited property names.\n * @returns {Array} Returns the array of property names.\n */\nfunction arrayLikeKeys(value, inherited) {\n  // Safari 8.1 makes `arguments.callee` enumerable in strict mode.\n  // Safari 9 makes `arguments.length` enumerable in strict mode.\n  var result = (isArray(value) || isArguments(value))\n    ? baseTimes(value.length, String)\n    : [];\n\n  var length = result.length,\n      skipIndexes = !!length;\n\n  for (var key in value) {\n    if ((inherited || hasOwnProperty.call(value, key)) &&\n        !(skipIndexes && (key == 'length' || isIndex(key, length)))) {\n      result.push(key);\n    }\n  }\n  return result;\n}\n\n/**\n * The base implementation of `_.keys` which doesn't treat sparse arrays as dense.\n *\n * @private\n * @param {Object} object The object to query.\n * @returns {Array} Returns the array of property names.\n */\nfunction baseKeys(object) {\n  if (!isPrototype(object)) {\n    return nativeKeys(object);\n  }\n  var result = [];\n  for (var key in Object(object)) {\n    if (hasOwnProperty.call(object, key) && key != 'constructor') {\n      result.push(key);\n    }\n  }\n  return result;\n}\n\n/**\n * Checks if `value` is a valid array-like index.\n *\n * @private\n * @param {*} value The value to check.\n * @param {number} [length=MAX_SAFE_INTEGER] The upper bounds of a valid index.\n * @returns {boolean} Returns `true` if `value` is a valid index, else `false`.\n */\nfunction isIndex(value, length) {\n  length = length == null ? MAX_SAFE_INTEGER : length;\n  return !!length &&\n    (typeof value == 'number' || reIsUint.test(value)) &&\n    (value > -1 && value % 1 == 0 && value < length);\n}\n\n/**\n * Checks if `value` is likely a prototype object.\n *\n * @private\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is a prototype, else `false`.\n */\nfunction isPrototype(value) {\n  var Ctor = value && value.constructor,\n      proto = (typeof Ctor == 'function' && Ctor.prototype) || objectProto;\n\n  return value === proto;\n}\n\n/**\n * Checks if `value` is in `collection`. If `collection` is a string, it's\n * checked for a substring of `value`, otherwise\n * [`SameValueZero`](http://ecma-international.org/ecma-262/7.0/#sec-samevaluezero)\n * is used for equality comparisons. If `fromIndex` is negative, it's used as\n * the offset from the end of `collection`.\n *\n * @static\n * @memberOf _\n * @since 0.1.0\n * @category Collection\n * @param {Array|Object|string} collection The collection to inspect.\n * @param {*} value The value to search for.\n * @param {number} [fromIndex=0] The index to search from.\n * @param- {Object} [guard] Enables use as an iteratee for methods like `_.reduce`.\n * @returns {boolean} Returns `true` if `value` is found, else `false`.\n * @example\n *\n * _.includes([1, 2, 3], 1);\n * // => true\n *\n * _.includes([1, 2, 3], 1, 2);\n * // => false\n *\n * _.includes({ 'a': 1, 'b': 2 }, 1);\n * // => true\n *\n * _.includes('abcd', 'bc');\n * // => true\n */\nfunction includes(collection, value, fromIndex, guard) {\n  collection = isArrayLike(collection) ? collection : values(collection);\n  fromIndex = (fromIndex && !guard) ? toInteger(fromIndex) : 0;\n\n  var length = collection.length;\n  if (fromIndex < 0) {\n    fromIndex = nativeMax(length + fromIndex, 0);\n  }\n  return isString(collection)\n    ? (fromIndex <= length && collection.indexOf(value, fromIndex) > -1)\n    : (!!length && baseIndexOf(collection, value, fromIndex) > -1);\n}\n\n/**\n * Checks if `value` is likely an `arguments` object.\n *\n * @static\n * @memberOf _\n * @since 0.1.0\n * @category Lang\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is an `arguments` object,\n *  else `false`.\n * @example\n *\n * _.isArguments(function() { return arguments; }());\n * // => true\n *\n * _.isArguments([1, 2, 3]);\n * // => false\n */\nfunction isArguments(value) {\n  // Safari 8.1 makes `arguments.callee` enumerable in strict mode.\n  return isArrayLikeObject(value) && hasOwnProperty.call(value, 'callee') &&\n    (!propertyIsEnumerable.call(value, 'callee') || objectToString.call(value) == argsTag);\n}\n\n/**\n * Checks if `value` is classified as an `Array` object.\n *\n * @static\n * @memberOf _\n * @since 0.1.0\n * @category Lang\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is an array, else `false`.\n * @example\n *\n * _.isArray([1, 2, 3]);\n * // => true\n *\n * _.isArray(document.body.children);\n * // => false\n *\n * _.isArray('abc');\n * // => false\n *\n * _.isArray(_.noop);\n * // => false\n */\nvar isArray = Array.isArray;\n\n/**\n * Checks if `value` is array-like. A value is considered array-like if it's\n * not a function and has a `value.length` that's an integer greater than or\n * equal to `0` and less than or equal to `Number.MAX_SAFE_INTEGER`.\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category Lang\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is array-like, else `false`.\n * @example\n *\n * _.isArrayLike([1, 2, 3]);\n * // => true\n *\n * _.isArrayLike(document.body.children);\n * // => true\n *\n * _.isArrayLike('abc');\n * // => true\n *\n * _.isArrayLike(_.noop);\n * // => false\n */\nfunction isArrayLike(value) {\n  return value != null && isLength(value.length) && !isFunction(value);\n}\n\n/**\n * This method is like `_.isArrayLike` except that it also checks if `value`\n * is an object.\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category Lang\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is an array-like object,\n *  else `false`.\n * @example\n *\n * _.isArrayLikeObject([1, 2, 3]);\n * // => true\n *\n * _.isArrayLikeObject(document.body.children);\n * // => true\n *\n * _.isArrayLikeObject('abc');\n * // => false\n *\n * _.isArrayLikeObject(_.noop);\n * // => false\n */\nfunction isArrayLikeObject(value) {\n  return isObjectLike(value) && isArrayLike(value);\n}\n\n/**\n * Checks if `value` is classified as a `Function` object.\n *\n * @static\n * @memberOf _\n * @since 0.1.0\n * @category Lang\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is a function, else `false`.\n * @example\n *\n * _.isFunction(_);\n * // => true\n *\n * _.isFunction(/abc/);\n * // => false\n */\nfunction isFunction(value) {\n  // The use of `Object#toString` avoids issues with the `typeof` operator\n  // in Safari 8-9 which returns 'object' for typed array and other constructors.\n  var tag = isObject(value) ? objectToString.call(value) : '';\n  return tag == funcTag || tag == genTag;\n}\n\n/**\n * Checks if `value` is a valid array-like length.\n *\n * **Note:** This method is loosely based on\n * [`ToLength`](http://ecma-international.org/ecma-262/7.0/#sec-tolength).\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category Lang\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is a valid length, else `false`.\n * @example\n *\n * _.isLength(3);\n * // => true\n *\n * _.isLength(Number.MIN_VALUE);\n * // => false\n *\n * _.isLength(Infinity);\n * // => false\n *\n * _.isLength('3');\n * // => false\n */\nfunction isLength(value) {\n  return typeof value == 'number' &&\n    value > -1 && value % 1 == 0 && value <= MAX_SAFE_INTEGER;\n}\n\n/**\n * Checks if `value` is the\n * [language type](http://www.ecma-international.org/ecma-262/7.0/#sec-ecmascript-language-types)\n * of `Object`. (e.g. arrays, functions, objects, regexes, `new Number(0)`, and `new String('')`)\n *\n * @static\n * @memberOf _\n * @since 0.1.0\n * @category Lang\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is an object, else `false`.\n * @example\n *\n * _.isObject({});\n * // => true\n *\n * _.isObject([1, 2, 3]);\n * // => true\n *\n * _.isObject(_.noop);\n * // => true\n *\n * _.isObject(null);\n * // => false\n */\nfunction isObject(value) {\n  var type = typeof value;\n  return !!value && (type == 'object' || type == 'function');\n}\n\n/**\n * Checks if `value` is object-like. A value is object-like if it's not `null`\n * and has a `typeof` result of \"object\".\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category Lang\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is object-like, else `false`.\n * @example\n *\n * _.isObjectLike({});\n * // => true\n *\n * _.isObjectLike([1, 2, 3]);\n * // => true\n *\n * _.isObjectLike(_.noop);\n * // => false\n *\n * _.isObjectLike(null);\n * // => false\n */\nfunction isObjectLike(value) {\n  return !!value && typeof value == 'object';\n}\n\n/**\n * Checks if `value` is classified as a `String` primitive or object.\n *\n * @static\n * @since 0.1.0\n * @memberOf _\n * @category Lang\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is a string, else `false`.\n * @example\n *\n * _.isString('abc');\n * // => true\n *\n * _.isString(1);\n * // => false\n */\nfunction isString(value) {\n  return typeof value == 'string' ||\n    (!isArray(value) && isObjectLike(value) && objectToString.call(value) == stringTag);\n}\n\n/**\n * Checks if `value` is classified as a `Symbol` primitive or object.\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category Lang\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is a symbol, else `false`.\n * @example\n *\n * _.isSymbol(Symbol.iterator);\n * // => true\n *\n * _.isSymbol('abc');\n * // => false\n */\nfunction isSymbol(value) {\n  return typeof value == 'symbol' ||\n    (isObjectLike(value) && objectToString.call(value) == symbolTag);\n}\n\n/**\n * Converts `value` to a finite number.\n *\n * @static\n * @memberOf _\n * @since 4.12.0\n * @category Lang\n * @param {*} value The value to convert.\n * @returns {number} Returns the converted number.\n * @example\n *\n * _.toFinite(3.2);\n * // => 3.2\n *\n * _.toFinite(Number.MIN_VALUE);\n * // => 5e-324\n *\n * _.toFinite(Infinity);\n * // => 1.7976931348623157e+308\n *\n * _.toFinite('3.2');\n * // => 3.2\n */\nfunction toFinite(value) {\n  if (!value) {\n    return value === 0 ? value : 0;\n  }\n  value = toNumber(value);\n  if (value === INFINITY || value === -INFINITY) {\n    var sign = (value < 0 ? -1 : 1);\n    return sign * MAX_INTEGER;\n  }\n  return value === value ? value : 0;\n}\n\n/**\n * Converts `value` to an integer.\n *\n * **Note:** This method is loosely based on\n * [`ToInteger`](http://www.ecma-international.org/ecma-262/7.0/#sec-tointeger).\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category Lang\n * @param {*} value The value to convert.\n * @returns {number} Returns the converted integer.\n * @example\n *\n * _.toInteger(3.2);\n * // => 3\n *\n * _.toInteger(Number.MIN_VALUE);\n * // => 0\n *\n * _.toInteger(Infinity);\n * // => 1.7976931348623157e+308\n *\n * _.toInteger('3.2');\n * // => 3\n */\nfunction toInteger(value) {\n  var result = toFinite(value),\n      remainder = result % 1;\n\n  return result === result ? (remainder ? result - remainder : result) : 0;\n}\n\n/**\n * Converts `value` to a number.\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category Lang\n * @param {*} value The value to process.\n * @returns {number} Returns the number.\n * @example\n *\n * _.toNumber(3.2);\n * // => 3.2\n *\n * _.toNumber(Number.MIN_VALUE);\n * // => 5e-324\n *\n * _.toNumber(Infinity);\n * // => Infinity\n *\n * _.toNumber('3.2');\n * // => 3.2\n */\nfunction toNumber(value) {\n  if (typeof value == 'number') {\n    return value;\n  }\n  if (isSymbol(value)) {\n    return NAN;\n  }\n  if (isObject(value)) {\n    var other = typeof value.valueOf == 'function' ? value.valueOf() : value;\n    value = isObject(other) ? (other + '') : other;\n  }\n  if (typeof value != 'string') {\n    return value === 0 ? value : +value;\n  }\n  value = value.replace(reTrim, '');\n  var isBinary = reIsBinary.test(value);\n  return (isBinary || reIsOctal.test(value))\n    ? freeParseInt(value.slice(2), isBinary ? 2 : 8)\n    : (reIsBadHex.test(value) ? NAN : +value);\n}\n\n/**\n * Creates an array of the own enumerable property names of `object`.\n *\n * **Note:** Non-object values are coerced to objects. See the\n * [ES spec](http://ecma-international.org/ecma-262/7.0/#sec-object.keys)\n * for more details.\n *\n * @static\n * @since 0.1.0\n * @memberOf _\n * @category Object\n * @param {Object} object The object to query.\n * @returns {Array} Returns the array of property names.\n * @example\n *\n * function Foo() {\n *   this.a = 1;\n *   this.b = 2;\n * }\n *\n * Foo.prototype.c = 3;\n *\n * _.keys(new Foo);\n * // => ['a', 'b'] (iteration order is not guaranteed)\n *\n * _.keys('hi');\n * // => ['0', '1']\n */\nfunction keys(object) {\n  return isArrayLike(object) ? arrayLikeKeys(object) : baseKeys(object);\n}\n\n/**\n * Creates an array of the own enumerable string keyed property values of `object`.\n *\n * **Note:** Non-object values are coerced to objects.\n *\n * @static\n * @since 0.1.0\n * @memberOf _\n * @category Object\n * @param {Object} object The object to query.\n * @returns {Array} Returns the array of property values.\n * @example\n *\n * function Foo() {\n *   this.a = 1;\n *   this.b = 2;\n * }\n *\n * Foo.prototype.c = 3;\n *\n * _.values(new Foo);\n * // => [1, 2] (iteration order is not guaranteed)\n *\n * _.values('hi');\n * // => ['h', 'i']\n */\nfunction values(object) {\n  return object ? baseValues(object, keys(object)) : [];\n}\n\nmodule.exports = includes;\n",
    "/**\n * lodash 3.0.3 (Custom Build) <https://lodash.com/>\n * Build: `lodash modularize exports=\"npm\" -o ./`\n * Copyright 2012-2016 The Dojo Foundation <http://dojofoundation.org/>\n * Based on Underscore.js 1.8.3 <http://underscorejs.org/LICENSE>\n * Copyright 2009-2016 Jeremy Ashkenas, DocumentCloud and Investigative Reporters & Editors\n * Available under MIT license <https://lodash.com/license>\n */\n\n/** `Object#toString` result references. */\nvar boolTag = '[object Boolean]';\n\n/** Used for built-in method references. */\nvar objectProto = Object.prototype;\n\n/**\n * Used to resolve the [`toStringTag`](http://ecma-international.org/ecma-262/6.0/#sec-object.prototype.tostring)\n * of values.\n */\nvar objectToString = objectProto.toString;\n\n/**\n * Checks if `value` is classified as a boolean primitive or object.\n *\n * @static\n * @memberOf _\n * @category Lang\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is correctly classified, else `false`.\n * @example\n *\n * _.isBoolean(false);\n * // => true\n *\n * _.isBoolean(null);\n * // => false\n */\nfunction isBoolean(value) {\n  return value === true || value === false ||\n    (isObjectLike(value) && objectToString.call(value) == boolTag);\n}\n\n/**\n * Checks if `value` is object-like. A value is object-like if it's not `null`\n * and has a `typeof` result of \"object\".\n *\n * @static\n * @memberOf _\n * @category Lang\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is object-like, else `false`.\n * @example\n *\n * _.isObjectLike({});\n * // => true\n *\n * _.isObjectLike([1, 2, 3]);\n * // => true\n *\n * _.isObjectLike(_.noop);\n * // => false\n *\n * _.isObjectLike(null);\n * // => false\n */\nfunction isObjectLike(value) {\n  return !!value && typeof value == 'object';\n}\n\nmodule.exports = isBoolean;\n",
    "/**\n * lodash (Custom Build) <https://lodash.com/>\n * Build: `lodash modularize exports=\"npm\" -o ./`\n * Copyright jQuery Foundation and other contributors <https://jquery.org/>\n * Released under MIT license <https://lodash.com/license>\n * Based on Underscore.js 1.8.3 <http://underscorejs.org/LICENSE>\n * Copyright Jeremy Ashkenas, DocumentCloud and Investigative Reporters & Editors\n */\n\n/** Used as references for various `Number` constants. */\nvar INFINITY = 1 / 0,\n    MAX_INTEGER = 1.7976931348623157e+308,\n    NAN = 0 / 0;\n\n/** `Object#toString` result references. */\nvar symbolTag = '[object Symbol]';\n\n/** Used to match leading and trailing whitespace. */\nvar reTrim = /^\\s+|\\s+$/g;\n\n/** Used to detect bad signed hexadecimal string values. */\nvar reIsBadHex = /^[-+]0x[0-9a-f]+$/i;\n\n/** Used to detect binary string values. */\nvar reIsBinary = /^0b[01]+$/i;\n\n/** Used to detect octal string values. */\nvar reIsOctal = /^0o[0-7]+$/i;\n\n/** Built-in method references without a dependency on `root`. */\nvar freeParseInt = parseInt;\n\n/** Used for built-in method references. */\nvar objectProto = Object.prototype;\n\n/**\n * Used to resolve the\n * [`toStringTag`](http://ecma-international.org/ecma-262/7.0/#sec-object.prototype.tostring)\n * of values.\n */\nvar objectToString = objectProto.toString;\n\n/**\n * Checks if `value` is an integer.\n *\n * **Note:** This method is based on\n * [`Number.isInteger`](https://mdn.io/Number/isInteger).\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category Lang\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is an integer, else `false`.\n * @example\n *\n * _.isInteger(3);\n * // => true\n *\n * _.isInteger(Number.MIN_VALUE);\n * // => false\n *\n * _.isInteger(Infinity);\n * // => false\n *\n * _.isInteger('3');\n * // => false\n */\nfunction isInteger(value) {\n  return typeof value == 'number' && value == toInteger(value);\n}\n\n/**\n * Checks if `value` is the\n * [language type](http://www.ecma-international.org/ecma-262/7.0/#sec-ecmascript-language-types)\n * of `Object`. (e.g. arrays, functions, objects, regexes, `new Number(0)`, and `new String('')`)\n *\n * @static\n * @memberOf _\n * @since 0.1.0\n * @category Lang\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is an object, else `false`.\n * @example\n *\n * _.isObject({});\n * // => true\n *\n * _.isObject([1, 2, 3]);\n * // => true\n *\n * _.isObject(_.noop);\n * // => true\n *\n * _.isObject(null);\n * // => false\n */\nfunction isObject(value) {\n  var type = typeof value;\n  return !!value && (type == 'object' || type == 'function');\n}\n\n/**\n * Checks if `value` is object-like. A value is object-like if it's not `null`\n * and has a `typeof` result of \"object\".\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category Lang\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is object-like, else `false`.\n * @example\n *\n * _.isObjectLike({});\n * // => true\n *\n * _.isObjectLike([1, 2, 3]);\n * // => true\n *\n * _.isObjectLike(_.noop);\n * // => false\n *\n * _.isObjectLike(null);\n * // => false\n */\nfunction isObjectLike(value) {\n  return !!value && typeof value == 'object';\n}\n\n/**\n * Checks if `value` is classified as a `Symbol` primitive or object.\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category Lang\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is a symbol, else `false`.\n * @example\n *\n * _.isSymbol(Symbol.iterator);\n * // => true\n *\n * _.isSymbol('abc');\n * // => false\n */\nfunction isSymbol(value) {\n  return typeof value == 'symbol' ||\n    (isObjectLike(value) && objectToString.call(value) == symbolTag);\n}\n\n/**\n * Converts `value` to a finite number.\n *\n * @static\n * @memberOf _\n * @since 4.12.0\n * @category Lang\n * @param {*} value The value to convert.\n * @returns {number} Returns the converted number.\n * @example\n *\n * _.toFinite(3.2);\n * // => 3.2\n *\n * _.toFinite(Number.MIN_VALUE);\n * // => 5e-324\n *\n * _.toFinite(Infinity);\n * // => 1.7976931348623157e+308\n *\n * _.toFinite('3.2');\n * // => 3.2\n */\nfunction toFinite(value) {\n  if (!value) {\n    return value === 0 ? value : 0;\n  }\n  value = toNumber(value);\n  if (value === INFINITY || value === -INFINITY) {\n    var sign = (value < 0 ? -1 : 1);\n    return sign * MAX_INTEGER;\n  }\n  return value === value ? value : 0;\n}\n\n/**\n * Converts `value` to an integer.\n *\n * **Note:** This method is loosely based on\n * [`ToInteger`](http://www.ecma-international.org/ecma-262/7.0/#sec-tointeger).\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category Lang\n * @param {*} value The value to convert.\n * @returns {number} Returns the converted integer.\n * @example\n *\n * _.toInteger(3.2);\n * // => 3\n *\n * _.toInteger(Number.MIN_VALUE);\n * // => 0\n *\n * _.toInteger(Infinity);\n * // => 1.7976931348623157e+308\n *\n * _.toInteger('3.2');\n * // => 3\n */\nfunction toInteger(value) {\n  var result = toFinite(value),\n      remainder = result % 1;\n\n  return result === result ? (remainder ? result - remainder : result) : 0;\n}\n\n/**\n * Converts `value` to a number.\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category Lang\n * @param {*} value The value to process.\n * @returns {number} Returns the number.\n * @example\n *\n * _.toNumber(3.2);\n * // => 3.2\n *\n * _.toNumber(Number.MIN_VALUE);\n * // => 5e-324\n *\n * _.toNumber(Infinity);\n * // => Infinity\n *\n * _.toNumber('3.2');\n * // => 3.2\n */\nfunction toNumber(value) {\n  if (typeof value == 'number') {\n    return value;\n  }\n  if (isSymbol(value)) {\n    return NAN;\n  }\n  if (isObject(value)) {\n    var other = typeof value.valueOf == 'function' ? value.valueOf() : value;\n    value = isObject(other) ? (other + '') : other;\n  }\n  if (typeof value != 'string') {\n    return value === 0 ? value : +value;\n  }\n  value = value.replace(reTrim, '');\n  var isBinary = reIsBinary.test(value);\n  return (isBinary || reIsOctal.test(value))\n    ? freeParseInt(value.slice(2), isBinary ? 2 : 8)\n    : (reIsBadHex.test(value) ? NAN : +value);\n}\n\nmodule.exports = isInteger;\n",
    "/**\n * lodash 3.0.3 (Custom Build) <https://lodash.com/>\n * Build: `lodash modularize exports=\"npm\" -o ./`\n * Copyright 2012-2016 The Dojo Foundation <http://dojofoundation.org/>\n * Based on Underscore.js 1.8.3 <http://underscorejs.org/LICENSE>\n * Copyright 2009-2016 Jeremy Ashkenas, DocumentCloud and Investigative Reporters & Editors\n * Available under MIT license <https://lodash.com/license>\n */\n\n/** `Object#toString` result references. */\nvar numberTag = '[object Number]';\n\n/** Used for built-in method references. */\nvar objectProto = Object.prototype;\n\n/**\n * Used to resolve the [`toStringTag`](http://ecma-international.org/ecma-262/6.0/#sec-object.prototype.tostring)\n * of values.\n */\nvar objectToString = objectProto.toString;\n\n/**\n * Checks if `value` is object-like. A value is object-like if it's not `null`\n * and has a `typeof` result of \"object\".\n *\n * @static\n * @memberOf _\n * @category Lang\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is object-like, else `false`.\n * @example\n *\n * _.isObjectLike({});\n * // => true\n *\n * _.isObjectLike([1, 2, 3]);\n * // => true\n *\n * _.isObjectLike(_.noop);\n * // => false\n *\n * _.isObjectLike(null);\n * // => false\n */\nfunction isObjectLike(value) {\n  return !!value && typeof value == 'object';\n}\n\n/**\n * Checks if `value` is classified as a `Number` primitive or object.\n *\n * **Note:** To exclude `Infinity`, `-Infinity`, and `NaN`, which are classified\n * as numbers, use the `_.isFinite` method.\n *\n * @static\n * @memberOf _\n * @category Lang\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is correctly classified, else `false`.\n * @example\n *\n * _.isNumber(3);\n * // => true\n *\n * _.isNumber(Number.MIN_VALUE);\n * // => true\n *\n * _.isNumber(Infinity);\n * // => true\n *\n * _.isNumber('3');\n * // => false\n */\nfunction isNumber(value) {\n  return typeof value == 'number' ||\n    (isObjectLike(value) && objectToString.call(value) == numberTag);\n}\n\nmodule.exports = isNumber;\n",
    "/**\n * lodash (Custom Build) <https://lodash.com/>\n * Build: `lodash modularize exports=\"npm\" -o ./`\n * Copyright jQuery Foundation and other contributors <https://jquery.org/>\n * Released under MIT license <https://lodash.com/license>\n * Based on Underscore.js 1.8.3 <http://underscorejs.org/LICENSE>\n * Copyright Jeremy Ashkenas, DocumentCloud and Investigative Reporters & Editors\n */\n\n/** `Object#toString` result references. */\nvar objectTag = '[object Object]';\n\n/**\n * Checks if `value` is a host object in IE < 9.\n *\n * @private\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is a host object, else `false`.\n */\nfunction isHostObject(value) {\n  // Many host objects are `Object` objects that can coerce to strings\n  // despite having improperly defined `toString` methods.\n  var result = false;\n  if (value != null && typeof value.toString != 'function') {\n    try {\n      result = !!(value + '');\n    } catch (e) {}\n  }\n  return result;\n}\n\n/**\n * Creates a unary function that invokes `func` with its argument transformed.\n *\n * @private\n * @param {Function} func The function to wrap.\n * @param {Function} transform The argument transform.\n * @returns {Function} Returns the new function.\n */\nfunction overArg(func, transform) {\n  return function(arg) {\n    return func(transform(arg));\n  };\n}\n\n/** Used for built-in method references. */\nvar funcProto = Function.prototype,\n    objectProto = Object.prototype;\n\n/** Used to resolve the decompiled source of functions. */\nvar funcToString = funcProto.toString;\n\n/** Used to check objects for own properties. */\nvar hasOwnProperty = objectProto.hasOwnProperty;\n\n/** Used to infer the `Object` constructor. */\nvar objectCtorString = funcToString.call(Object);\n\n/**\n * Used to resolve the\n * [`toStringTag`](http://ecma-international.org/ecma-262/7.0/#sec-object.prototype.tostring)\n * of values.\n */\nvar objectToString = objectProto.toString;\n\n/** Built-in value references. */\nvar getPrototype = overArg(Object.getPrototypeOf, Object);\n\n/**\n * Checks if `value` is object-like. A value is object-like if it's not `null`\n * and has a `typeof` result of \"object\".\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category Lang\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is object-like, else `false`.\n * @example\n *\n * _.isObjectLike({});\n * // => true\n *\n * _.isObjectLike([1, 2, 3]);\n * // => true\n *\n * _.isObjectLike(_.noop);\n * // => false\n *\n * _.isObjectLike(null);\n * // => false\n */\nfunction isObjectLike(value) {\n  return !!value && typeof value == 'object';\n}\n\n/**\n * Checks if `value` is a plain object, that is, an object created by the\n * `Object` constructor or one with a `[[Prototype]]` of `null`.\n *\n * @static\n * @memberOf _\n * @since 0.8.0\n * @category Lang\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is a plain object, else `false`.\n * @example\n *\n * function Foo() {\n *   this.a = 1;\n * }\n *\n * _.isPlainObject(new Foo);\n * // => false\n *\n * _.isPlainObject([1, 2, 3]);\n * // => false\n *\n * _.isPlainObject({ 'x': 0, 'y': 0 });\n * // => true\n *\n * _.isPlainObject(Object.create(null));\n * // => true\n */\nfunction isPlainObject(value) {\n  if (!isObjectLike(value) ||\n      objectToString.call(value) != objectTag || isHostObject(value)) {\n    return false;\n  }\n  var proto = getPrototype(value);\n  if (proto === null) {\n    return true;\n  }\n  var Ctor = hasOwnProperty.call(proto, 'constructor') && proto.constructor;\n  return (typeof Ctor == 'function' &&\n    Ctor instanceof Ctor && funcToString.call(Ctor) == objectCtorString);\n}\n\nmodule.exports = isPlainObject;\n",
    "/**\n * lodash 4.0.1 (Custom Build) <https://lodash.com/>\n * Build: `lodash modularize exports=\"npm\" -o ./`\n * Copyright 2012-2016 The Dojo Foundation <http://dojofoundation.org/>\n * Based on Underscore.js 1.8.3 <http://underscorejs.org/LICENSE>\n * Copyright 2009-2016 Jeremy Ashkenas, DocumentCloud and Investigative Reporters & Editors\n * Available under MIT license <https://lodash.com/license>\n */\n\n/** `Object#toString` result references. */\nvar stringTag = '[object String]';\n\n/** Used for built-in method references. */\nvar objectProto = Object.prototype;\n\n/**\n * Used to resolve the [`toStringTag`](http://ecma-international.org/ecma-262/6.0/#sec-object.prototype.tostring)\n * of values.\n */\nvar objectToString = objectProto.toString;\n\n/**\n * Checks if `value` is classified as an `Array` object.\n *\n * @static\n * @memberOf _\n * @type Function\n * @category Lang\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is correctly classified, else `false`.\n * @example\n *\n * _.isArray([1, 2, 3]);\n * // => true\n *\n * _.isArray(document.body.children);\n * // => false\n *\n * _.isArray('abc');\n * // => false\n *\n * _.isArray(_.noop);\n * // => false\n */\nvar isArray = Array.isArray;\n\n/**\n * Checks if `value` is object-like. A value is object-like if it's not `null`\n * and has a `typeof` result of \"object\".\n *\n * @static\n * @memberOf _\n * @category Lang\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is object-like, else `false`.\n * @example\n *\n * _.isObjectLike({});\n * // => true\n *\n * _.isObjectLike([1, 2, 3]);\n * // => true\n *\n * _.isObjectLike(_.noop);\n * // => false\n *\n * _.isObjectLike(null);\n * // => false\n */\nfunction isObjectLike(value) {\n  return !!value && typeof value == 'object';\n}\n\n/**\n * Checks if `value` is classified as a `String` primitive or object.\n *\n * @static\n * @memberOf _\n * @category Lang\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is correctly classified, else `false`.\n * @example\n *\n * _.isString('abc');\n * // => true\n *\n * _.isString(1);\n * // => false\n */\nfunction isString(value) {\n  return typeof value == 'string' ||\n    (!isArray(value) && isObjectLike(value) && objectToString.call(value) == stringTag);\n}\n\nmodule.exports = isString;\n",
    "/**\n * lodash (Custom Build) <https://lodash.com/>\n * Build: `lodash modularize exports=\"npm\" -o ./`\n * Copyright jQuery Foundation and other contributors <https://jquery.org/>\n * Released under MIT license <https://lodash.com/license>\n * Based on Underscore.js 1.8.3 <http://underscorejs.org/LICENSE>\n * Copyright Jeremy Ashkenas, DocumentCloud and Investigative Reporters & Editors\n */\n\n/** Used as the `TypeError` message for \"Functions\" methods. */\nvar FUNC_ERROR_TEXT = 'Expected a function';\n\n/** Used as references for various `Number` constants. */\nvar INFINITY = 1 / 0,\n    MAX_INTEGER = 1.7976931348623157e+308,\n    NAN = 0 / 0;\n\n/** `Object#toString` result references. */\nvar symbolTag = '[object Symbol]';\n\n/** Used to match leading and trailing whitespace. */\nvar reTrim = /^\\s+|\\s+$/g;\n\n/** Used to detect bad signed hexadecimal string values. */\nvar reIsBadHex = /^[-+]0x[0-9a-f]+$/i;\n\n/** Used to detect binary string values. */\nvar reIsBinary = /^0b[01]+$/i;\n\n/** Used to detect octal string values. */\nvar reIsOctal = /^0o[0-7]+$/i;\n\n/** Built-in method references without a dependency on `root`. */\nvar freeParseInt = parseInt;\n\n/** Used for built-in method references. */\nvar objectProto = Object.prototype;\n\n/**\n * Used to resolve the\n * [`toStringTag`](http://ecma-international.org/ecma-262/7.0/#sec-object.prototype.tostring)\n * of values.\n */\nvar objectToString = objectProto.toString;\n\n/**\n * Creates a function that invokes `func`, with the `this` binding and arguments\n * of the created function, while it's called less than `n` times. Subsequent\n * calls to the created function return the result of the last `func` invocation.\n *\n * @static\n * @memberOf _\n * @since 3.0.0\n * @category Function\n * @param {number} n The number of calls at which `func` is no longer invoked.\n * @param {Function} func The function to restrict.\n * @returns {Function} Returns the new restricted function.\n * @example\n *\n * jQuery(element).on('click', _.before(5, addContactToList));\n * // => Allows adding up to 4 contacts to the list.\n */\nfunction before(n, func) {\n  var result;\n  if (typeof func != 'function') {\n    throw new TypeError(FUNC_ERROR_TEXT);\n  }\n  n = toInteger(n);\n  return function() {\n    if (--n > 0) {\n      result = func.apply(this, arguments);\n    }\n    if (n <= 1) {\n      func = undefined;\n    }\n    return result;\n  };\n}\n\n/**\n * Creates a function that is restricted to invoking `func` once. Repeat calls\n * to the function return the value of the first invocation. The `func` is\n * invoked with the `this` binding and arguments of the created function.\n *\n * @static\n * @memberOf _\n * @since 0.1.0\n * @category Function\n * @param {Function} func The function to restrict.\n * @returns {Function} Returns the new restricted function.\n * @example\n *\n * var initialize = _.once(createApplication);\n * initialize();\n * initialize();\n * // => `createApplication` is invoked once\n */\nfunction once(func) {\n  return before(2, func);\n}\n\n/**\n * Checks if `value` is the\n * [language type](http://www.ecma-international.org/ecma-262/7.0/#sec-ecmascript-language-types)\n * of `Object`. (e.g. arrays, functions, objects, regexes, `new Number(0)`, and `new String('')`)\n *\n * @static\n * @memberOf _\n * @since 0.1.0\n * @category Lang\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is an object, else `false`.\n * @example\n *\n * _.isObject({});\n * // => true\n *\n * _.isObject([1, 2, 3]);\n * // => true\n *\n * _.isObject(_.noop);\n * // => true\n *\n * _.isObject(null);\n * // => false\n */\nfunction isObject(value) {\n  var type = typeof value;\n  return !!value && (type == 'object' || type == 'function');\n}\n\n/**\n * Checks if `value` is object-like. A value is object-like if it's not `null`\n * and has a `typeof` result of \"object\".\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category Lang\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is object-like, else `false`.\n * @example\n *\n * _.isObjectLike({});\n * // => true\n *\n * _.isObjectLike([1, 2, 3]);\n * // => true\n *\n * _.isObjectLike(_.noop);\n * // => false\n *\n * _.isObjectLike(null);\n * // => false\n */\nfunction isObjectLike(value) {\n  return !!value && typeof value == 'object';\n}\n\n/**\n * Checks if `value` is classified as a `Symbol` primitive or object.\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category Lang\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is a symbol, else `false`.\n * @example\n *\n * _.isSymbol(Symbol.iterator);\n * // => true\n *\n * _.isSymbol('abc');\n * // => false\n */\nfunction isSymbol(value) {\n  return typeof value == 'symbol' ||\n    (isObjectLike(value) && objectToString.call(value) == symbolTag);\n}\n\n/**\n * Converts `value` to a finite number.\n *\n * @static\n * @memberOf _\n * @since 4.12.0\n * @category Lang\n * @param {*} value The value to convert.\n * @returns {number} Returns the converted number.\n * @example\n *\n * _.toFinite(3.2);\n * // => 3.2\n *\n * _.toFinite(Number.MIN_VALUE);\n * // => 5e-324\n *\n * _.toFinite(Infinity);\n * // => 1.7976931348623157e+308\n *\n * _.toFinite('3.2');\n * // => 3.2\n */\nfunction toFinite(value) {\n  if (!value) {\n    return value === 0 ? value : 0;\n  }\n  value = toNumber(value);\n  if (value === INFINITY || value === -INFINITY) {\n    var sign = (value < 0 ? -1 : 1);\n    return sign * MAX_INTEGER;\n  }\n  return value === value ? value : 0;\n}\n\n/**\n * Converts `value` to an integer.\n *\n * **Note:** This method is loosely based on\n * [`ToInteger`](http://www.ecma-international.org/ecma-262/7.0/#sec-tointeger).\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category Lang\n * @param {*} value The value to convert.\n * @returns {number} Returns the converted integer.\n * @example\n *\n * _.toInteger(3.2);\n * // => 3\n *\n * _.toInteger(Number.MIN_VALUE);\n * // => 0\n *\n * _.toInteger(Infinity);\n * // => 1.7976931348623157e+308\n *\n * _.toInteger('3.2');\n * // => 3\n */\nfunction toInteger(value) {\n  var result = toFinite(value),\n      remainder = result % 1;\n\n  return result === result ? (remainder ? result - remainder : result) : 0;\n}\n\n/**\n * Converts `value` to a number.\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category Lang\n * @param {*} value The value to process.\n * @returns {number} Returns the number.\n * @example\n *\n * _.toNumber(3.2);\n * // => 3.2\n *\n * _.toNumber(Number.MIN_VALUE);\n * // => 5e-324\n *\n * _.toNumber(Infinity);\n * // => Infinity\n *\n * _.toNumber('3.2');\n * // => 3.2\n */\nfunction toNumber(value) {\n  if (typeof value == 'number') {\n    return value;\n  }\n  if (isSymbol(value)) {\n    return NAN;\n  }\n  if (isObject(value)) {\n    var other = typeof value.valueOf == 'function' ? value.valueOf() : value;\n    value = isObject(other) ? (other + '') : other;\n  }\n  if (typeof value != 'string') {\n    return value === 0 ? value : +value;\n  }\n  value = value.replace(reTrim, '');\n  var isBinary = reIsBinary.test(value);\n  return (isBinary || reIsOctal.test(value))\n    ? freeParseInt(value.slice(2), isBinary ? 2 : 8)\n    : (reIsBadHex.test(value) ? NAN : +value);\n}\n\nmodule.exports = once;\n",
    "const timespan = require('./lib/timespan');\nconst PS_SUPPORTED = require('./lib/psSupported');\nconst validateAsymmetricKey = require('./lib/validateAsymmetricKey');\nconst jws = require('jws');\nconst includes = require('lodash.includes');\nconst isBoolean = require('lodash.isboolean');\nconst isInteger = require('lodash.isinteger');\nconst isNumber = require('lodash.isnumber');\nconst isPlainObject = require('lodash.isplainobject');\nconst isString = require('lodash.isstring');\nconst once = require('lodash.once');\nconst { KeyObject, createSecretKey, createPrivateKey } = require('crypto')\n\nconst SUPPORTED_ALGS = ['RS256', 'RS384', 'RS512', 'ES256', 'ES384', 'ES512', 'HS256', 'HS384', 'HS512', 'none'];\nif (PS_SUPPORTED) {\n  SUPPORTED_ALGS.splice(3, 0, 'PS256', 'PS384', 'PS512');\n}\n\nconst sign_options_schema = {\n  expiresIn: { isValid: function(value) { return isInteger(value) || (isString(value) && value); }, message: '\"expiresIn\" should be a number of seconds or string representing a timespan' },\n  notBefore: { isValid: function(value) { return isInteger(value) || (isString(value) && value); }, message: '\"notBefore\" should be a number of seconds or string representing a timespan' },\n  audience: { isValid: function(value) { return isString(value) || Array.isArray(value); }, message: '\"audience\" must be a string or array' },\n  algorithm: { isValid: includes.bind(null, SUPPORTED_ALGS), message: '\"algorithm\" must be a valid string enum value' },\n  header: { isValid: isPlainObject, message: '\"header\" must be an object' },\n  encoding: { isValid: isString, message: '\"encoding\" must be a string' },\n  issuer: { isValid: isString, message: '\"issuer\" must be a string' },\n  subject: { isValid: isString, message: '\"subject\" must be a string' },\n  jwtid: { isValid: isString, message: '\"jwtid\" must be a string' },\n  noTimestamp: { isValid: isBoolean, message: '\"noTimestamp\" must be a boolean' },\n  keyid: { isValid: isString, message: '\"keyid\" must be a string' },\n  mutatePayload: { isValid: isBoolean, message: '\"mutatePayload\" must be a boolean' },\n  allowInsecureKeySizes: { isValid: isBoolean, message: '\"allowInsecureKeySizes\" must be a boolean'},\n  allowInvalidAsymmetricKeyTypes: { isValid: isBoolean, message: '\"allowInvalidAsymmetricKeyTypes\" must be a boolean'}\n};\n\nconst registered_claims_schema = {\n  iat: { isValid: isNumber, message: '\"iat\" should be a number of seconds' },\n  exp: { isValid: isNumber, message: '\"exp\" should be a number of seconds' },\n  nbf: { isValid: isNumber, message: '\"nbf\" should be a number of seconds' }\n};\n\nfunction validate(schema, allowUnknown, object, parameterName) {\n  if (!isPlainObject(object)) {\n    throw new Error('Expected \"' + parameterName + '\" to be a plain object.');\n  }\n  Object.keys(object)\n    .forEach(function(key) {\n      const validator = schema[key];\n      if (!validator) {\n        if (!allowUnknown) {\n          throw new Error('\"' + key + '\" is not allowed in \"' + parameterName + '\"');\n        }\n        return;\n      }\n      if (!validator.isValid(object[key])) {\n        throw new Error(validator.message);\n      }\n    });\n}\n\nfunction validateOptions(options) {\n  return validate(sign_options_schema, false, options, 'options');\n}\n\nfunction validatePayload(payload) {\n  return validate(registered_claims_schema, true, payload, 'payload');\n}\n\nconst options_to_payload = {\n  'audience': 'aud',\n  'issuer': 'iss',\n  'subject': 'sub',\n  'jwtid': 'jti'\n};\n\nconst options_for_objects = [\n  'expiresIn',\n  'notBefore',\n  'noTimestamp',\n  'audience',\n  'issuer',\n  'subject',\n  'jwtid',\n];\n\nmodule.exports = function (payload, secretOrPrivateKey, options, callback) {\n  if (typeof options === 'function') {\n    callback = options;\n    options = {};\n  } else {\n    options = options || {};\n  }\n\n  const isObjectPayload = typeof payload === 'object' &&\n                        !Buffer.isBuffer(payload);\n\n  const header = Object.assign({\n    alg: options.algorithm || 'HS256',\n    typ: isObjectPayload ? 'JWT' : undefined,\n    kid: options.keyid\n  }, options.header);\n\n  function failure(err) {\n    if (callback) {\n      return callback(err);\n    }\n    throw err;\n  }\n\n  if (!secretOrPrivateKey && options.algorithm !== 'none') {\n    return failure(new Error('secretOrPrivateKey must have a value'));\n  }\n\n  if (secretOrPrivateKey != null && !(secretOrPrivateKey instanceof KeyObject)) {\n    try {\n      secretOrPrivateKey = createPrivateKey(secretOrPrivateKey)\n    } catch (_) {\n      try {\n        secretOrPrivateKey = createSecretKey(typeof secretOrPrivateKey === 'string' ? Buffer.from(secretOrPrivateKey) : secretOrPrivateKey)\n      } catch (_) {\n        return failure(new Error('secretOrPrivateKey is not valid key material'));\n      }\n    }\n  }\n\n  if (header.alg.startsWith('HS') && secretOrPrivateKey.type !== 'secret') {\n    return failure(new Error((`secretOrPrivateKey must be a symmetric key when using ${header.alg}`)))\n  } else if (/^(?:RS|PS|ES)/.test(header.alg)) {\n    if (secretOrPrivateKey.type !== 'private') {\n      return failure(new Error((`secretOrPrivateKey must be an asymmetric key when using ${header.alg}`)))\n    }\n    if (!options.allowInsecureKeySizes &&\n      !header.alg.startsWith('ES') &&\n      secretOrPrivateKey.asymmetricKeyDetails !== undefined && //KeyObject.asymmetricKeyDetails is supported in Node 15+\n      secretOrPrivateKey.asymmetricKeyDetails.modulusLength < 2048) {\n      return failure(new Error(`secretOrPrivateKey has a minimum key size of 2048 bits for ${header.alg}`));\n    }\n  }\n\n  if (typeof payload === 'undefined') {\n    return failure(new Error('payload is required'));\n  } else if (isObjectPayload) {\n    try {\n      validatePayload(payload);\n    }\n    catch (error) {\n      return failure(error);\n    }\n    if (!options.mutatePayload) {\n      payload = Object.assign({},payload);\n    }\n  } else {\n    const invalid_options = options_for_objects.filter(function (opt) {\n      return typeof options[opt] !== 'undefined';\n    });\n\n    if (invalid_options.length > 0) {\n      return failure(new Error('invalid ' + invalid_options.join(',') + ' option for ' + (typeof payload ) + ' payload'));\n    }\n  }\n\n  if (typeof payload.exp !== 'undefined' && typeof options.expiresIn !== 'undefined') {\n    return failure(new Error('Bad \"options.expiresIn\" option the payload already has an \"exp\" property.'));\n  }\n\n  if (typeof payload.nbf !== 'undefined' && typeof options.notBefore !== 'undefined') {\n    return failure(new Error('Bad \"options.notBefore\" option the payload already has an \"nbf\" property.'));\n  }\n\n  try {\n    validateOptions(options);\n  }\n  catch (error) {\n    return failure(error);\n  }\n\n  if (!options.allowInvalidAsymmetricKeyTypes) {\n    try {\n      validateAsymmetricKey(header.alg, secretOrPrivateKey);\n    } catch (error) {\n      return failure(error);\n    }\n  }\n\n  const timestamp = payload.iat || Math.floor(Date.now() / 1000);\n\n  if (options.noTimestamp) {\n    delete payload.iat;\n  } else if (isObjectPayload) {\n    payload.iat = timestamp;\n  }\n\n  if (typeof options.notBefore !== 'undefined') {\n    try {\n      payload.nbf = timespan(options.notBefore, timestamp);\n    }\n    catch (err) {\n      return failure(err);\n    }\n    if (typeof payload.nbf === 'undefined') {\n      return failure(new Error('\"notBefore\" should be a number of seconds or string representing a timespan eg: \"1d\", \"20h\", 60'));\n    }\n  }\n\n  if (typeof options.expiresIn !== 'undefined' && typeof payload === 'object') {\n    try {\n      payload.exp = timespan(options.expiresIn, timestamp);\n    }\n    catch (err) {\n      return failure(err);\n    }\n    if (typeof payload.exp === 'undefined') {\n      return failure(new Error('\"expiresIn\" should be a number of seconds or string representing a timespan eg: \"1d\", \"20h\", 60'));\n    }\n  }\n\n  Object.keys(options_to_payload).forEach(function (key) {\n    const claim = options_to_payload[key];\n    if (typeof options[key] !== 'undefined') {\n      if (typeof payload[claim] !== 'undefined') {\n        return failure(new Error('Bad \"options.' + key + '\" option. The payload already has an \"' + claim + '\" property.'));\n      }\n      payload[claim] = options[key];\n    }\n  });\n\n  const encoding = options.encoding || 'utf8';\n\n  if (typeof callback === 'function') {\n    callback = callback && once(callback);\n\n    jws.createSign({\n      header: header,\n      privateKey: secretOrPrivateKey,\n      payload: payload,\n      encoding: encoding\n    }).once('error', callback)\n      .once('done', function (signature) {\n        // TODO: Remove in favor of the modulus length check before signing once node 15+ is the minimum supported version\n        if(!options.allowInsecureKeySizes && /^(?:RS|PS)/.test(header.alg) && signature.length < 256) {\n          return callback(new Error(`secretOrPrivateKey has a minimum key size of 2048 bits for ${header.alg}`))\n        }\n        callback(null, signature);\n      });\n  } else {\n    let signature = jws.sign({header: header, payload: payload, secret: secretOrPrivateKey, encoding: encoding});\n    // TODO: Remove in favor of the modulus length check before signing once node 15+ is the minimum supported version\n    if(!options.allowInsecureKeySizes && /^(?:RS|PS)/.test(header.alg) && signature.length < 256) {\n      throw new Error(`secretOrPrivateKey has a minimum key size of 2048 bits for ${header.alg}`)\n    }\n    return signature\n  }\n};\n",
    "module.exports = {\n  decode: require('./decode'),\n  verify: require('./verify'),\n  sign: require('./sign'),\n  JsonWebTokenError: require('./lib/JsonWebTokenError'),\n  NotBeforeError: require('./lib/NotBeforeError'),\n  TokenExpiredError: require('./lib/TokenExpiredError'),\n};\n",
    "(function (module, exports) {\n  'use strict';\n\n  // Utils\n  function assert (val, msg) {\n    if (!val) throw new Error(msg || 'Assertion failed');\n  }\n\n  // Could use `inherits` module, but don't want to move from single file\n  // architecture yet.\n  function inherits (ctor, superCtor) {\n    ctor.super_ = superCtor;\n    var TempCtor = function () {};\n    TempCtor.prototype = superCtor.prototype;\n    ctor.prototype = new TempCtor();\n    ctor.prototype.constructor = ctor;\n  }\n\n  // BN\n\n  function BN (number, base, endian) {\n    if (BN.isBN(number)) {\n      return number;\n    }\n\n    this.negative = 0;\n    this.words = null;\n    this.length = 0;\n\n    // Reduction context\n    this.red = null;\n\n    if (number !== null) {\n      if (base === 'le' || base === 'be') {\n        endian = base;\n        base = 10;\n      }\n\n      this._init(number || 0, base || 10, endian || 'be');\n    }\n  }\n  if (typeof module === 'object') {\n    module.exports = BN;\n  } else {\n    exports.BN = BN;\n  }\n\n  BN.BN = BN;\n  BN.wordSize = 26;\n\n  var Buffer;\n  try {\n    if (typeof window !== 'undefined' && typeof window.Buffer !== 'undefined') {\n      Buffer = window.Buffer;\n    } else {\n      Buffer = require('buffer').Buffer;\n    }\n  } catch (e) {\n  }\n\n  BN.isBN = function isBN (num) {\n    if (num instanceof BN) {\n      return true;\n    }\n\n    return num !== null && typeof num === 'object' &&\n      num.constructor.wordSize === BN.wordSize && Array.isArray(num.words);\n  };\n\n  BN.max = function max (left, right) {\n    if (left.cmp(right) > 0) return left;\n    return right;\n  };\n\n  BN.min = function min (left, right) {\n    if (left.cmp(right) < 0) return left;\n    return right;\n  };\n\n  BN.prototype._init = function init (number, base, endian) {\n    if (typeof number === 'number') {\n      return this._initNumber(number, base, endian);\n    }\n\n    if (typeof number === 'object') {\n      return this._initArray(number, base, endian);\n    }\n\n    if (base === 'hex') {\n      base = 16;\n    }\n    assert(base === (base | 0) && base >= 2 && base <= 36);\n\n    number = number.toString().replace(/\\s+/g, '');\n    var start = 0;\n    if (number[0] === '-') {\n      start++;\n      this.negative = 1;\n    }\n\n    if (start < number.length) {\n      if (base === 16) {\n        this._parseHex(number, start, endian);\n      } else {\n        this._parseBase(number, base, start);\n        if (endian === 'le') {\n          this._initArray(this.toArray(), base, endian);\n        }\n      }\n    }\n  };\n\n  BN.prototype._initNumber = function _initNumber (number, base, endian) {\n    if (number < 0) {\n      this.negative = 1;\n      number = -number;\n    }\n    if (number < 0x4000000) {\n      this.words = [ number & 0x3ffffff ];\n      this.length = 1;\n    } else if (number < 0x10000000000000) {\n      this.words = [\n        number & 0x3ffffff,\n        (number / 0x4000000) & 0x3ffffff\n      ];\n      this.length = 2;\n    } else {\n      assert(number < 0x20000000000000); // 2 ^ 53 (unsafe)\n      this.words = [\n        number & 0x3ffffff,\n        (number / 0x4000000) & 0x3ffffff,\n        1\n      ];\n      this.length = 3;\n    }\n\n    if (endian !== 'le') return;\n\n    // Reverse the bytes\n    this._initArray(this.toArray(), base, endian);\n  };\n\n  BN.prototype._initArray = function _initArray (number, base, endian) {\n    // Perhaps a Uint8Array\n    assert(typeof number.length === 'number');\n    if (number.length <= 0) {\n      this.words = [ 0 ];\n      this.length = 1;\n      return this;\n    }\n\n    this.length = Math.ceil(number.length / 3);\n    this.words = new Array(this.length);\n    for (var i = 0; i < this.length; i++) {\n      this.words[i] = 0;\n    }\n\n    var j, w;\n    var off = 0;\n    if (endian === 'be') {\n      for (i = number.length - 1, j = 0; i >= 0; i -= 3) {\n        w = number[i] | (number[i - 1] << 8) | (number[i - 2] << 16);\n        this.words[j] |= (w << off) & 0x3ffffff;\n        this.words[j + 1] = (w >>> (26 - off)) & 0x3ffffff;\n        off += 24;\n        if (off >= 26) {\n          off -= 26;\n          j++;\n        }\n      }\n    } else if (endian === 'le') {\n      for (i = 0, j = 0; i < number.length; i += 3) {\n        w = number[i] | (number[i + 1] << 8) | (number[i + 2] << 16);\n        this.words[j] |= (w << off) & 0x3ffffff;\n        this.words[j + 1] = (w >>> (26 - off)) & 0x3ffffff;\n        off += 24;\n        if (off >= 26) {\n          off -= 26;\n          j++;\n        }\n      }\n    }\n    return this.strip();\n  };\n\n  function parseHex4Bits (string, index) {\n    var c = string.charCodeAt(index);\n    // 'A' - 'F'\n    if (c >= 65 && c <= 70) {\n      return c - 55;\n    // 'a' - 'f'\n    } else if (c >= 97 && c <= 102) {\n      return c - 87;\n    // '0' - '9'\n    } else {\n      return (c - 48) & 0xf;\n    }\n  }\n\n  function parseHexByte (string, lowerBound, index) {\n    var r = parseHex4Bits(string, index);\n    if (index - 1 >= lowerBound) {\n      r |= parseHex4Bits(string, index - 1) << 4;\n    }\n    return r;\n  }\n\n  BN.prototype._parseHex = function _parseHex (number, start, endian) {\n    // Create possibly bigger array to ensure that it fits the number\n    this.length = Math.ceil((number.length - start) / 6);\n    this.words = new Array(this.length);\n    for (var i = 0; i < this.length; i++) {\n      this.words[i] = 0;\n    }\n\n    // 24-bits chunks\n    var off = 0;\n    var j = 0;\n\n    var w;\n    if (endian === 'be') {\n      for (i = number.length - 1; i >= start; i -= 2) {\n        w = parseHexByte(number, start, i) << off;\n        this.words[j] |= w & 0x3ffffff;\n        if (off >= 18) {\n          off -= 18;\n          j += 1;\n          this.words[j] |= w >>> 26;\n        } else {\n          off += 8;\n        }\n      }\n    } else {\n      var parseLength = number.length - start;\n      for (i = parseLength % 2 === 0 ? start + 1 : start; i < number.length; i += 2) {\n        w = parseHexByte(number, start, i) << off;\n        this.words[j] |= w & 0x3ffffff;\n        if (off >= 18) {\n          off -= 18;\n          j += 1;\n          this.words[j] |= w >>> 26;\n        } else {\n          off += 8;\n        }\n      }\n    }\n\n    this.strip();\n  };\n\n  function parseBase (str, start, end, mul) {\n    var r = 0;\n    var len = Math.min(str.length, end);\n    for (var i = start; i < len; i++) {\n      var c = str.charCodeAt(i) - 48;\n\n      r *= mul;\n\n      // 'a'\n      if (c >= 49) {\n        r += c - 49 + 0xa;\n\n      // 'A'\n      } else if (c >= 17) {\n        r += c - 17 + 0xa;\n\n      // '0' - '9'\n      } else {\n        r += c;\n      }\n    }\n    return r;\n  }\n\n  BN.prototype._parseBase = function _parseBase (number, base, start) {\n    // Initialize as zero\n    this.words = [ 0 ];\n    this.length = 1;\n\n    // Find length of limb in base\n    for (var limbLen = 0, limbPow = 1; limbPow <= 0x3ffffff; limbPow *= base) {\n      limbLen++;\n    }\n    limbLen--;\n    limbPow = (limbPow / base) | 0;\n\n    var total = number.length - start;\n    var mod = total % limbLen;\n    var end = Math.min(total, total - mod) + start;\n\n    var word = 0;\n    for (var i = start; i < end; i += limbLen) {\n      word = parseBase(number, i, i + limbLen, base);\n\n      this.imuln(limbPow);\n      if (this.words[0] + word < 0x4000000) {\n        this.words[0] += word;\n      } else {\n        this._iaddn(word);\n      }\n    }\n\n    if (mod !== 0) {\n      var pow = 1;\n      word = parseBase(number, i, number.length, base);\n\n      for (i = 0; i < mod; i++) {\n        pow *= base;\n      }\n\n      this.imuln(pow);\n      if (this.words[0] + word < 0x4000000) {\n        this.words[0] += word;\n      } else {\n        this._iaddn(word);\n      }\n    }\n\n    this.strip();\n  };\n\n  BN.prototype.copy = function copy (dest) {\n    dest.words = new Array(this.length);\n    for (var i = 0; i < this.length; i++) {\n      dest.words[i] = this.words[i];\n    }\n    dest.length = this.length;\n    dest.negative = this.negative;\n    dest.red = this.red;\n  };\n\n  BN.prototype.clone = function clone () {\n    var r = new BN(null);\n    this.copy(r);\n    return r;\n  };\n\n  BN.prototype._expand = function _expand (size) {\n    while (this.length < size) {\n      this.words[this.length++] = 0;\n    }\n    return this;\n  };\n\n  // Remove leading `0` from `this`\n  BN.prototype.strip = function strip () {\n    while (this.length > 1 && this.words[this.length - 1] === 0) {\n      this.length--;\n    }\n    return this._normSign();\n  };\n\n  BN.prototype._normSign = function _normSign () {\n    // -0 = 0\n    if (this.length === 1 && this.words[0] === 0) {\n      this.negative = 0;\n    }\n    return this;\n  };\n\n  BN.prototype.inspect = function inspect () {\n    return (this.red ? '<BN-R: ' : '<BN: ') + this.toString(16) + '>';\n  };\n\n  /*\n\n  var zeros = [];\n  var groupSizes = [];\n  var groupBases = [];\n\n  var s = '';\n  var i = -1;\n  while (++i < BN.wordSize) {\n    zeros[i] = s;\n    s += '0';\n  }\n  groupSizes[0] = 0;\n  groupSizes[1] = 0;\n  groupBases[0] = 0;\n  groupBases[1] = 0;\n  var base = 2 - 1;\n  while (++base < 36 + 1) {\n    var groupSize = 0;\n    var groupBase = 1;\n    while (groupBase < (1 << BN.wordSize) / base) {\n      groupBase *= base;\n      groupSize += 1;\n    }\n    groupSizes[base] = groupSize;\n    groupBases[base] = groupBase;\n  }\n\n  */\n\n  var zeros = [\n    '',\n    '0',\n    '00',\n    '000',\n    '0000',\n    '00000',\n    '000000',\n    '0000000',\n    '00000000',\n    '000000000',\n    '0000000000',\n    '00000000000',\n    '000000000000',\n    '0000000000000',\n    '00000000000000',\n    '000000000000000',\n    '0000000000000000',\n    '00000000000000000',\n    '000000000000000000',\n    '0000000000000000000',\n    '00000000000000000000',\n    '000000000000000000000',\n    '0000000000000000000000',\n    '00000000000000000000000',\n    '000000000000000000000000',\n    '0000000000000000000000000'\n  ];\n\n  var groupSizes = [\n    0, 0,\n    25, 16, 12, 11, 10, 9, 8,\n    8, 7, 7, 7, 7, 6, 6,\n    6, 6, 6, 6, 6, 5, 5,\n    5, 5, 5, 5, 5, 5, 5,\n    5, 5, 5, 5, 5, 5, 5\n  ];\n\n  var groupBases = [\n    0, 0,\n    33554432, 43046721, 16777216, 48828125, 60466176, 40353607, 16777216,\n    43046721, 10000000, 19487171, 35831808, 62748517, 7529536, 11390625,\n    16777216, 24137569, 34012224, 47045881, 64000000, 4084101, 5153632,\n    6436343, 7962624, 9765625, 11881376, 14348907, 17210368, 20511149,\n    24300000, 28629151, 33554432, 39135393, 45435424, 52521875, 60466176\n  ];\n\n  BN.prototype.toString = function toString (base, padding) {\n    base = base || 10;\n    padding = padding | 0 || 1;\n\n    var out;\n    if (base === 16 || base === 'hex') {\n      out = '';\n      var off = 0;\n      var carry = 0;\n      for (var i = 0; i < this.length; i++) {\n        var w = this.words[i];\n        var word = (((w << off) | carry) & 0xffffff).toString(16);\n        carry = (w >>> (24 - off)) & 0xffffff;\n        off += 2;\n        if (off >= 26) {\n          off -= 26;\n          i--;\n        }\n        if (carry !== 0 || i !== this.length - 1) {\n          out = zeros[6 - word.length] + word + out;\n        } else {\n          out = word + out;\n        }\n      }\n      if (carry !== 0) {\n        out = carry.toString(16) + out;\n      }\n      while (out.length % padding !== 0) {\n        out = '0' + out;\n      }\n      if (this.negative !== 0) {\n        out = '-' + out;\n      }\n      return out;\n    }\n\n    if (base === (base | 0) && base >= 2 && base <= 36) {\n      // var groupSize = Math.floor(BN.wordSize * Math.LN2 / Math.log(base));\n      var groupSize = groupSizes[base];\n      // var groupBase = Math.pow(base, groupSize);\n      var groupBase = groupBases[base];\n      out = '';\n      var c = this.clone();\n      c.negative = 0;\n      while (!c.isZero()) {\n        var r = c.modn(groupBase).toString(base);\n        c = c.idivn(groupBase);\n\n        if (!c.isZero()) {\n          out = zeros[groupSize - r.length] + r + out;\n        } else {\n          out = r + out;\n        }\n      }\n      if (this.isZero()) {\n        out = '0' + out;\n      }\n      while (out.length % padding !== 0) {\n        out = '0' + out;\n      }\n      if (this.negative !== 0) {\n        out = '-' + out;\n      }\n      return out;\n    }\n\n    assert(false, 'Base should be between 2 and 36');\n  };\n\n  BN.prototype.toNumber = function toNumber () {\n    var ret = this.words[0];\n    if (this.length === 2) {\n      ret += this.words[1] * 0x4000000;\n    } else if (this.length === 3 && this.words[2] === 0x01) {\n      // NOTE: at this stage it is known that the top bit is set\n      ret += 0x10000000000000 + (this.words[1] * 0x4000000);\n    } else if (this.length > 2) {\n      assert(false, 'Number can only safely store up to 53 bits');\n    }\n    return (this.negative !== 0) ? -ret : ret;\n  };\n\n  BN.prototype.toJSON = function toJSON () {\n    return this.toString(16);\n  };\n\n  BN.prototype.toBuffer = function toBuffer (endian, length) {\n    assert(typeof Buffer !== 'undefined');\n    return this.toArrayLike(Buffer, endian, length);\n  };\n\n  BN.prototype.toArray = function toArray (endian, length) {\n    return this.toArrayLike(Array, endian, length);\n  };\n\n  BN.prototype.toArrayLike = function toArrayLike (ArrayType, endian, length) {\n    var byteLength = this.byteLength();\n    var reqLength = length || Math.max(1, byteLength);\n    assert(byteLength <= reqLength, 'byte array longer than desired length');\n    assert(reqLength > 0, 'Requested array length <= 0');\n\n    this.strip();\n    var littleEndian = endian === 'le';\n    var res = new ArrayType(reqLength);\n\n    var b, i;\n    var q = this.clone();\n    if (!littleEndian) {\n      // Assume big-endian\n      for (i = 0; i < reqLength - byteLength; i++) {\n        res[i] = 0;\n      }\n\n      for (i = 0; !q.isZero(); i++) {\n        b = q.andln(0xff);\n        q.iushrn(8);\n\n        res[reqLength - i - 1] = b;\n      }\n    } else {\n      for (i = 0; !q.isZero(); i++) {\n        b = q.andln(0xff);\n        q.iushrn(8);\n\n        res[i] = b;\n      }\n\n      for (; i < reqLength; i++) {\n        res[i] = 0;\n      }\n    }\n\n    return res;\n  };\n\n  if (Math.clz32) {\n    BN.prototype._countBits = function _countBits (w) {\n      return 32 - Math.clz32(w);\n    };\n  } else {\n    BN.prototype._countBits = function _countBits (w) {\n      var t = w;\n      var r = 0;\n      if (t >= 0x1000) {\n        r += 13;\n        t >>>= 13;\n      }\n      if (t >= 0x40) {\n        r += 7;\n        t >>>= 7;\n      }\n      if (t >= 0x8) {\n        r += 4;\n        t >>>= 4;\n      }\n      if (t >= 0x02) {\n        r += 2;\n        t >>>= 2;\n      }\n      return r + t;\n    };\n  }\n\n  BN.prototype._zeroBits = function _zeroBits (w) {\n    // Short-cut\n    if (w === 0) return 26;\n\n    var t = w;\n    var r = 0;\n    if ((t & 0x1fff) === 0) {\n      r += 13;\n      t >>>= 13;\n    }\n    if ((t & 0x7f) === 0) {\n      r += 7;\n      t >>>= 7;\n    }\n    if ((t & 0xf) === 0) {\n      r += 4;\n      t >>>= 4;\n    }\n    if ((t & 0x3) === 0) {\n      r += 2;\n      t >>>= 2;\n    }\n    if ((t & 0x1) === 0) {\n      r++;\n    }\n    return r;\n  };\n\n  // Return number of used bits in a BN\n  BN.prototype.bitLength = function bitLength () {\n    var w = this.words[this.length - 1];\n    var hi = this._countBits(w);\n    return (this.length - 1) * 26 + hi;\n  };\n\n  function toBitArray (num) {\n    var w = new Array(num.bitLength());\n\n    for (var bit = 0; bit < w.length; bit++) {\n      var off = (bit / 26) | 0;\n      var wbit = bit % 26;\n\n      w[bit] = (num.words[off] & (1 << wbit)) >>> wbit;\n    }\n\n    return w;\n  }\n\n  // Number of trailing zero bits\n  BN.prototype.zeroBits = function zeroBits () {\n    if (this.isZero()) return 0;\n\n    var r = 0;\n    for (var i = 0; i < this.length; i++) {\n      var b = this._zeroBits(this.words[i]);\n      r += b;\n      if (b !== 26) break;\n    }\n    return r;\n  };\n\n  BN.prototype.byteLength = function byteLength () {\n    return Math.ceil(this.bitLength() / 8);\n  };\n\n  BN.prototype.toTwos = function toTwos (width) {\n    if (this.negative !== 0) {\n      return this.abs().inotn(width).iaddn(1);\n    }\n    return this.clone();\n  };\n\n  BN.prototype.fromTwos = function fromTwos (width) {\n    if (this.testn(width - 1)) {\n      return this.notn(width).iaddn(1).ineg();\n    }\n    return this.clone();\n  };\n\n  BN.prototype.isNeg = function isNeg () {\n    return this.negative !== 0;\n  };\n\n  // Return negative clone of `this`\n  BN.prototype.neg = function neg () {\n    return this.clone().ineg();\n  };\n\n  BN.prototype.ineg = function ineg () {\n    if (!this.isZero()) {\n      this.negative ^= 1;\n    }\n\n    return this;\n  };\n\n  // Or `num` with `this` in-place\n  BN.prototype.iuor = function iuor (num) {\n    while (this.length < num.length) {\n      this.words[this.length++] = 0;\n    }\n\n    for (var i = 0; i < num.length; i++) {\n      this.words[i] = this.words[i] | num.words[i];\n    }\n\n    return this.strip();\n  };\n\n  BN.prototype.ior = function ior (num) {\n    assert((this.negative | num.negative) === 0);\n    return this.iuor(num);\n  };\n\n  // Or `num` with `this`\n  BN.prototype.or = function or (num) {\n    if (this.length > num.length) return this.clone().ior(num);\n    return num.clone().ior(this);\n  };\n\n  BN.prototype.uor = function uor (num) {\n    if (this.length > num.length) return this.clone().iuor(num);\n    return num.clone().iuor(this);\n  };\n\n  // And `num` with `this` in-place\n  BN.prototype.iuand = function iuand (num) {\n    // b = min-length(num, this)\n    var b;\n    if (this.length > num.length) {\n      b = num;\n    } else {\n      b = this;\n    }\n\n    for (var i = 0; i < b.length; i++) {\n      this.words[i] = this.words[i] & num.words[i];\n    }\n\n    this.length = b.length;\n\n    return this.strip();\n  };\n\n  BN.prototype.iand = function iand (num) {\n    assert((this.negative | num.negative) === 0);\n    return this.iuand(num);\n  };\n\n  // And `num` with `this`\n  BN.prototype.and = function and (num) {\n    if (this.length > num.length) return this.clone().iand(num);\n    return num.clone().iand(this);\n  };\n\n  BN.prototype.uand = function uand (num) {\n    if (this.length > num.length) return this.clone().iuand(num);\n    return num.clone().iuand(this);\n  };\n\n  // Xor `num` with `this` in-place\n  BN.prototype.iuxor = function iuxor (num) {\n    // a.length > b.length\n    var a;\n    var b;\n    if (this.length > num.length) {\n      a = this;\n      b = num;\n    } else {\n      a = num;\n      b = this;\n    }\n\n    for (var i = 0; i < b.length; i++) {\n      this.words[i] = a.words[i] ^ b.words[i];\n    }\n\n    if (this !== a) {\n      for (; i < a.length; i++) {\n        this.words[i] = a.words[i];\n      }\n    }\n\n    this.length = a.length;\n\n    return this.strip();\n  };\n\n  BN.prototype.ixor = function ixor (num) {\n    assert((this.negative | num.negative) === 0);\n    return this.iuxor(num);\n  };\n\n  // Xor `num` with `this`\n  BN.prototype.xor = function xor (num) {\n    if (this.length > num.length) return this.clone().ixor(num);\n    return num.clone().ixor(this);\n  };\n\n  BN.prototype.uxor = function uxor (num) {\n    if (this.length > num.length) return this.clone().iuxor(num);\n    return num.clone().iuxor(this);\n  };\n\n  // Not ``this`` with ``width`` bitwidth\n  BN.prototype.inotn = function inotn (width) {\n    assert(typeof width === 'number' && width >= 0);\n\n    var bytesNeeded = Math.ceil(width / 26) | 0;\n    var bitsLeft = width % 26;\n\n    // Extend the buffer with leading zeroes\n    this._expand(bytesNeeded);\n\n    if (bitsLeft > 0) {\n      bytesNeeded--;\n    }\n\n    // Handle complete words\n    for (var i = 0; i < bytesNeeded; i++) {\n      this.words[i] = ~this.words[i] & 0x3ffffff;\n    }\n\n    // Handle the residue\n    if (bitsLeft > 0) {\n      this.words[i] = ~this.words[i] & (0x3ffffff >> (26 - bitsLeft));\n    }\n\n    // And remove leading zeroes\n    return this.strip();\n  };\n\n  BN.prototype.notn = function notn (width) {\n    return this.clone().inotn(width);\n  };\n\n  // Set `bit` of `this`\n  BN.prototype.setn = function setn (bit, val) {\n    assert(typeof bit === 'number' && bit >= 0);\n\n    var off = (bit / 26) | 0;\n    var wbit = bit % 26;\n\n    this._expand(off + 1);\n\n    if (val) {\n      this.words[off] = this.words[off] | (1 << wbit);\n    } else {\n      this.words[off] = this.words[off] & ~(1 << wbit);\n    }\n\n    return this.strip();\n  };\n\n  // Add `num` to `this` in-place\n  BN.prototype.iadd = function iadd (num) {\n    var r;\n\n    // negative + positive\n    if (this.negative !== 0 && num.negative === 0) {\n      this.negative = 0;\n      r = this.isub(num);\n      this.negative ^= 1;\n      return this._normSign();\n\n    // positive + negative\n    } else if (this.negative === 0 && num.negative !== 0) {\n      num.negative = 0;\n      r = this.isub(num);\n      num.negative = 1;\n      return r._normSign();\n    }\n\n    // a.length > b.length\n    var a, b;\n    if (this.length > num.length) {\n      a = this;\n      b = num;\n    } else {\n      a = num;\n      b = this;\n    }\n\n    var carry = 0;\n    for (var i = 0; i < b.length; i++) {\n      r = (a.words[i] | 0) + (b.words[i] | 0) + carry;\n      this.words[i] = r & 0x3ffffff;\n      carry = r >>> 26;\n    }\n    for (; carry !== 0 && i < a.length; i++) {\n      r = (a.words[i] | 0) + carry;\n      this.words[i] = r & 0x3ffffff;\n      carry = r >>> 26;\n    }\n\n    this.length = a.length;\n    if (carry !== 0) {\n      this.words[this.length] = carry;\n      this.length++;\n    // Copy the rest of the words\n    } else if (a !== this) {\n      for (; i < a.length; i++) {\n        this.words[i] = a.words[i];\n      }\n    }\n\n    return this;\n  };\n\n  // Add `num` to `this`\n  BN.prototype.add = function add (num) {\n    var res;\n    if (num.negative !== 0 && this.negative === 0) {\n      num.negative = 0;\n      res = this.sub(num);\n      num.negative ^= 1;\n      return res;\n    } else if (num.negative === 0 && this.negative !== 0) {\n      this.negative = 0;\n      res = num.sub(this);\n      this.negative = 1;\n      return res;\n    }\n\n    if (this.length > num.length) return this.clone().iadd(num);\n\n    return num.clone().iadd(this);\n  };\n\n  // Subtract `num` from `this` in-place\n  BN.prototype.isub = function isub (num) {\n    // this - (-num) = this + num\n    if (num.negative !== 0) {\n      num.negative = 0;\n      var r = this.iadd(num);\n      num.negative = 1;\n      return r._normSign();\n\n    // -this - num = -(this + num)\n    } else if (this.negative !== 0) {\n      this.negative = 0;\n      this.iadd(num);\n      this.negative = 1;\n      return this._normSign();\n    }\n\n    // At this point both numbers are positive\n    var cmp = this.cmp(num);\n\n    // Optimization - zeroify\n    if (cmp === 0) {\n      this.negative = 0;\n      this.length = 1;\n      this.words[0] = 0;\n      return this;\n    }\n\n    // a > b\n    var a, b;\n    if (cmp > 0) {\n      a = this;\n      b = num;\n    } else {\n      a = num;\n      b = this;\n    }\n\n    var carry = 0;\n    for (var i = 0; i < b.length; i++) {\n      r = (a.words[i] | 0) - (b.words[i] | 0) + carry;\n      carry = r >> 26;\n      this.words[i] = r & 0x3ffffff;\n    }\n    for (; carry !== 0 && i < a.length; i++) {\n      r = (a.words[i] | 0) + carry;\n      carry = r >> 26;\n      this.words[i] = r & 0x3ffffff;\n    }\n\n    // Copy rest of the words\n    if (carry === 0 && i < a.length && a !== this) {\n      for (; i < a.length; i++) {\n        this.words[i] = a.words[i];\n      }\n    }\n\n    this.length = Math.max(this.length, i);\n\n    if (a !== this) {\n      this.negative = 1;\n    }\n\n    return this.strip();\n  };\n\n  // Subtract `num` from `this`\n  BN.prototype.sub = function sub (num) {\n    return this.clone().isub(num);\n  };\n\n  function smallMulTo (self, num, out) {\n    out.negative = num.negative ^ self.negative;\n    var len = (self.length + num.length) | 0;\n    out.length = len;\n    len = (len - 1) | 0;\n\n    // Peel one iteration (compiler can't do it, because of code complexity)\n    var a = self.words[0] | 0;\n    var b = num.words[0] | 0;\n    var r = a * b;\n\n    var lo = r & 0x3ffffff;\n    var carry = (r / 0x4000000) | 0;\n    out.words[0] = lo;\n\n    for (var k = 1; k < len; k++) {\n      // Sum all words with the same `i + j = k` and accumulate `ncarry`,\n      // note that ncarry could be >= 0x3ffffff\n      var ncarry = carry >>> 26;\n      var rword = carry & 0x3ffffff;\n      var maxJ = Math.min(k, num.length - 1);\n      for (var j = Math.max(0, k - self.length + 1); j <= maxJ; j++) {\n        var i = (k - j) | 0;\n        a = self.words[i] | 0;\n        b = num.words[j] | 0;\n        r = a * b + rword;\n        ncarry += (r / 0x4000000) | 0;\n        rword = r & 0x3ffffff;\n      }\n      out.words[k] = rword | 0;\n      carry = ncarry | 0;\n    }\n    if (carry !== 0) {\n      out.words[k] = carry | 0;\n    } else {\n      out.length--;\n    }\n\n    return out.strip();\n  }\n\n  // TODO(indutny): it may be reasonable to omit it for users who don't need\n  // to work with 256-bit numbers, otherwise it gives 20% improvement for 256-bit\n  // multiplication (like elliptic secp256k1).\n  var comb10MulTo = function comb10MulTo (self, num, out) {\n    var a = self.words;\n    var b = num.words;\n    var o = out.words;\n    var c = 0;\n    var lo;\n    var mid;\n    var hi;\n    var a0 = a[0] | 0;\n    var al0 = a0 & 0x1fff;\n    var ah0 = a0 >>> 13;\n    var a1 = a[1] | 0;\n    var al1 = a1 & 0x1fff;\n    var ah1 = a1 >>> 13;\n    var a2 = a[2] | 0;\n    var al2 = a2 & 0x1fff;\n    var ah2 = a2 >>> 13;\n    var a3 = a[3] | 0;\n    var al3 = a3 & 0x1fff;\n    var ah3 = a3 >>> 13;\n    var a4 = a[4] | 0;\n    var al4 = a4 & 0x1fff;\n    var ah4 = a4 >>> 13;\n    var a5 = a[5] | 0;\n    var al5 = a5 & 0x1fff;\n    var ah5 = a5 >>> 13;\n    var a6 = a[6] | 0;\n    var al6 = a6 & 0x1fff;\n    var ah6 = a6 >>> 13;\n    var a7 = a[7] | 0;\n    var al7 = a7 & 0x1fff;\n    var ah7 = a7 >>> 13;\n    var a8 = a[8] | 0;\n    var al8 = a8 & 0x1fff;\n    var ah8 = a8 >>> 13;\n    var a9 = a[9] | 0;\n    var al9 = a9 & 0x1fff;\n    var ah9 = a9 >>> 13;\n    var b0 = b[0] | 0;\n    var bl0 = b0 & 0x1fff;\n    var bh0 = b0 >>> 13;\n    var b1 = b[1] | 0;\n    var bl1 = b1 & 0x1fff;\n    var bh1 = b1 >>> 13;\n    var b2 = b[2] | 0;\n    var bl2 = b2 & 0x1fff;\n    var bh2 = b2 >>> 13;\n    var b3 = b[3] | 0;\n    var bl3 = b3 & 0x1fff;\n    var bh3 = b3 >>> 13;\n    var b4 = b[4] | 0;\n    var bl4 = b4 & 0x1fff;\n    var bh4 = b4 >>> 13;\n    var b5 = b[5] | 0;\n    var bl5 = b5 & 0x1fff;\n    var bh5 = b5 >>> 13;\n    var b6 = b[6] | 0;\n    var bl6 = b6 & 0x1fff;\n    var bh6 = b6 >>> 13;\n    var b7 = b[7] | 0;\n    var bl7 = b7 & 0x1fff;\n    var bh7 = b7 >>> 13;\n    var b8 = b[8] | 0;\n    var bl8 = b8 & 0x1fff;\n    var bh8 = b8 >>> 13;\n    var b9 = b[9] | 0;\n    var bl9 = b9 & 0x1fff;\n    var bh9 = b9 >>> 13;\n\n    out.negative = self.negative ^ num.negative;\n    out.length = 19;\n    /* k = 0 */\n    lo = Math.imul(al0, bl0);\n    mid = Math.imul(al0, bh0);\n    mid = (mid + Math.imul(ah0, bl0)) | 0;\n    hi = Math.imul(ah0, bh0);\n    var w0 = (((c + lo) | 0) + ((mid & 0x1fff) << 13)) | 0;\n    c = (((hi + (mid >>> 13)) | 0) + (w0 >>> 26)) | 0;\n    w0 &= 0x3ffffff;\n    /* k = 1 */\n    lo = Math.imul(al1, bl0);\n    mid = Math.imul(al1, bh0);\n    mid = (mid + Math.imul(ah1, bl0)) | 0;\n    hi = Math.imul(ah1, bh0);\n    lo = (lo + Math.imul(al0, bl1)) | 0;\n    mid = (mid + Math.imul(al0, bh1)) | 0;\n    mid = (mid + Math.imul(ah0, bl1)) | 0;\n    hi = (hi + Math.imul(ah0, bh1)) | 0;\n    var w1 = (((c + lo) | 0) + ((mid & 0x1fff) << 13)) | 0;\n    c = (((hi + (mid >>> 13)) | 0) + (w1 >>> 26)) | 0;\n    w1 &= 0x3ffffff;\n    /* k = 2 */\n    lo = Math.imul(al2, bl0);\n    mid = Math.imul(al2, bh0);\n    mid = (mid + Math.imul(ah2, bl0)) | 0;\n    hi = Math.imul(ah2, bh0);\n    lo = (lo + Math.imul(al1, bl1)) | 0;\n    mid = (mid + Math.imul(al1, bh1)) | 0;\n    mid = (mid + Math.imul(ah1, bl1)) | 0;\n    hi = (hi + Math.imul(ah1, bh1)) | 0;\n    lo = (lo + Math.imul(al0, bl2)) | 0;\n    mid = (mid + Math.imul(al0, bh2)) | 0;\n    mid = (mid + Math.imul(ah0, bl2)) | 0;\n    hi = (hi + Math.imul(ah0, bh2)) | 0;\n    var w2 = (((c + lo) | 0) + ((mid & 0x1fff) << 13)) | 0;\n    c = (((hi + (mid >>> 13)) | 0) + (w2 >>> 26)) | 0;\n    w2 &= 0x3ffffff;\n    /* k = 3 */\n    lo = Math.imul(al3, bl0);\n    mid = Math.imul(al3, bh0);\n    mid = (mid + Math.imul(ah3, bl0)) | 0;\n    hi = Math.imul(ah3, bh0);\n    lo = (lo + Math.imul(al2, bl1)) | 0;\n    mid = (mid + Math.imul(al2, bh1)) | 0;\n    mid = (mid + Math.imul(ah2, bl1)) | 0;\n    hi = (hi + Math.imul(ah2, bh1)) | 0;\n    lo = (lo + Math.imul(al1, bl2)) | 0;\n    mid = (mid + Math.imul(al1, bh2)) | 0;\n    mid = (mid + Math.imul(ah1, bl2)) | 0;\n    hi = (hi + Math.imul(ah1, bh2)) | 0;\n    lo = (lo + Math.imul(al0, bl3)) | 0;\n    mid = (mid + Math.imul(al0, bh3)) | 0;\n    mid = (mid + Math.imul(ah0, bl3)) | 0;\n    hi = (hi + Math.imul(ah0, bh3)) | 0;\n    var w3 = (((c + lo) | 0) + ((mid & 0x1fff) << 13)) | 0;\n    c = (((hi + (mid >>> 13)) | 0) + (w3 >>> 26)) | 0;\n    w3 &= 0x3ffffff;\n    /* k = 4 */\n    lo = Math.imul(al4, bl0);\n    mid = Math.imul(al4, bh0);\n    mid = (mid + Math.imul(ah4, bl0)) | 0;\n    hi = Math.imul(ah4, bh0);\n    lo = (lo + Math.imul(al3, bl1)) | 0;\n    mid = (mid + Math.imul(al3, bh1)) | 0;\n    mid = (mid + Math.imul(ah3, bl1)) | 0;\n    hi = (hi + Math.imul(ah3, bh1)) | 0;\n    lo = (lo + Math.imul(al2, bl2)) | 0;\n    mid = (mid + Math.imul(al2, bh2)) | 0;\n    mid = (mid + Math.imul(ah2, bl2)) | 0;\n    hi = (hi + Math.imul(ah2, bh2)) | 0;\n    lo = (lo + Math.imul(al1, bl3)) | 0;\n    mid = (mid + Math.imul(al1, bh3)) | 0;\n    mid = (mid + Math.imul(ah1, bl3)) | 0;\n    hi = (hi + Math.imul(ah1, bh3)) | 0;\n    lo = (lo + Math.imul(al0, bl4)) | 0;\n    mid = (mid + Math.imul(al0, bh4)) | 0;\n    mid = (mid + Math.imul(ah0, bl4)) | 0;\n    hi = (hi + Math.imul(ah0, bh4)) | 0;\n    var w4 = (((c + lo) | 0) + ((mid & 0x1fff) << 13)) | 0;\n    c = (((hi + (mid >>> 13)) | 0) + (w4 >>> 26)) | 0;\n    w4 &= 0x3ffffff;\n    /* k = 5 */\n    lo = Math.imul(al5, bl0);\n    mid = Math.imul(al5, bh0);\n    mid = (mid + Math.imul(ah5, bl0)) | 0;\n    hi = Math.imul(ah5, bh0);\n    lo = (lo + Math.imul(al4, bl1)) | 0;\n    mid = (mid + Math.imul(al4, bh1)) | 0;\n    mid = (mid + Math.imul(ah4, bl1)) | 0;\n    hi = (hi + Math.imul(ah4, bh1)) | 0;\n    lo = (lo + Math.imul(al3, bl2)) | 0;\n    mid = (mid + Math.imul(al3, bh2)) | 0;\n    mid = (mid + Math.imul(ah3, bl2)) | 0;\n    hi = (hi + Math.imul(ah3, bh2)) | 0;\n    lo = (lo + Math.imul(al2, bl3)) | 0;\n    mid = (mid + Math.imul(al2, bh3)) | 0;\n    mid = (mid + Math.imul(ah2, bl3)) | 0;\n    hi = (hi + Math.imul(ah2, bh3)) | 0;\n    lo = (lo + Math.imul(al1, bl4)) | 0;\n    mid = (mid + Math.imul(al1, bh4)) | 0;\n    mid = (mid + Math.imul(ah1, bl4)) | 0;\n    hi = (hi + Math.imul(ah1, bh4)) | 0;\n    lo = (lo + Math.imul(al0, bl5)) | 0;\n    mid = (mid + Math.imul(al0, bh5)) | 0;\n    mid = (mid + Math.imul(ah0, bl5)) | 0;\n    hi = (hi + Math.imul(ah0, bh5)) | 0;\n    var w5 = (((c + lo) | 0) + ((mid & 0x1fff) << 13)) | 0;\n    c = (((hi + (mid >>> 13)) | 0) + (w5 >>> 26)) | 0;\n    w5 &= 0x3ffffff;\n    /* k = 6 */\n    lo = Math.imul(al6, bl0);\n    mid = Math.imul(al6, bh0);\n    mid = (mid + Math.imul(ah6, bl0)) | 0;\n    hi = Math.imul(ah6, bh0);\n    lo = (lo + Math.imul(al5, bl1)) | 0;\n    mid = (mid + Math.imul(al5, bh1)) | 0;\n    mid = (mid + Math.imul(ah5, bl1)) | 0;\n    hi = (hi + Math.imul(ah5, bh1)) | 0;\n    lo = (lo + Math.imul(al4, bl2)) | 0;\n    mid = (mid + Math.imul(al4, bh2)) | 0;\n    mid = (mid + Math.imul(ah4, bl2)) | 0;\n    hi = (hi + Math.imul(ah4, bh2)) | 0;\n    lo = (lo + Math.imul(al3, bl3)) | 0;\n    mid = (mid + Math.imul(al3, bh3)) | 0;\n    mid = (mid + Math.imul(ah3, bl3)) | 0;\n    hi = (hi + Math.imul(ah3, bh3)) | 0;\n    lo = (lo + Math.imul(al2, bl4)) | 0;\n    mid = (mid + Math.imul(al2, bh4)) | 0;\n    mid = (mid + Math.imul(ah2, bl4)) | 0;\n    hi = (hi + Math.imul(ah2, bh4)) | 0;\n    lo = (lo + Math.imul(al1, bl5)) | 0;\n    mid = (mid + Math.imul(al1, bh5)) | 0;\n    mid = (mid + Math.imul(ah1, bl5)) | 0;\n    hi = (hi + Math.imul(ah1, bh5)) | 0;\n    lo = (lo + Math.imul(al0, bl6)) | 0;\n    mid = (mid + Math.imul(al0, bh6)) | 0;\n    mid = (mid + Math.imul(ah0, bl6)) | 0;\n    hi = (hi + Math.imul(ah0, bh6)) | 0;\n    var w6 = (((c + lo) | 0) + ((mid & 0x1fff) << 13)) | 0;\n    c = (((hi + (mid >>> 13)) | 0) + (w6 >>> 26)) | 0;\n    w6 &= 0x3ffffff;\n    /* k = 7 */\n    lo = Math.imul(al7, bl0);\n    mid = Math.imul(al7, bh0);\n    mid = (mid + Math.imul(ah7, bl0)) | 0;\n    hi = Math.imul(ah7, bh0);\n    lo = (lo + Math.imul(al6, bl1)) | 0;\n    mid = (mid + Math.imul(al6, bh1)) | 0;\n    mid = (mid + Math.imul(ah6, bl1)) | 0;\n    hi = (hi + Math.imul(ah6, bh1)) | 0;\n    lo = (lo + Math.imul(al5, bl2)) | 0;\n    mid = (mid + Math.imul(al5, bh2)) | 0;\n    mid = (mid + Math.imul(ah5, bl2)) | 0;\n    hi = (hi + Math.imul(ah5, bh2)) | 0;\n    lo = (lo + Math.imul(al4, bl3)) | 0;\n    mid = (mid + Math.imul(al4, bh3)) | 0;\n    mid = (mid + Math.imul(ah4, bl3)) | 0;\n    hi = (hi + Math.imul(ah4, bh3)) | 0;\n    lo = (lo + Math.imul(al3, bl4)) | 0;\n    mid = (mid + Math.imul(al3, bh4)) | 0;\n    mid = (mid + Math.imul(ah3, bl4)) | 0;\n    hi = (hi + Math.imul(ah3, bh4)) | 0;\n    lo = (lo + Math.imul(al2, bl5)) | 0;\n    mid = (mid + Math.imul(al2, bh5)) | 0;\n    mid = (mid + Math.imul(ah2, bl5)) | 0;\n    hi = (hi + Math.imul(ah2, bh5)) | 0;\n    lo = (lo + Math.imul(al1, bl6)) | 0;\n    mid = (mid + Math.imul(al1, bh6)) | 0;\n    mid = (mid + Math.imul(ah1, bl6)) | 0;\n    hi = (hi + Math.imul(ah1, bh6)) | 0;\n    lo = (lo + Math.imul(al0, bl7)) | 0;\n    mid = (mid + Math.imul(al0, bh7)) | 0;\n    mid = (mid + Math.imul(ah0, bl7)) | 0;\n    hi = (hi + Math.imul(ah0, bh7)) | 0;\n    var w7 = (((c + lo) | 0) + ((mid & 0x1fff) << 13)) | 0;\n    c = (((hi + (mid >>> 13)) | 0) + (w7 >>> 26)) | 0;\n    w7 &= 0x3ffffff;\n    /* k = 8 */\n    lo = Math.imul(al8, bl0);\n    mid = Math.imul(al8, bh0);\n    mid = (mid + Math.imul(ah8, bl0)) | 0;\n    hi = Math.imul(ah8, bh0);\n    lo = (lo + Math.imul(al7, bl1)) | 0;\n    mid = (mid + Math.imul(al7, bh1)) | 0;\n    mid = (mid + Math.imul(ah7, bl1)) | 0;\n    hi = (hi + Math.imul(ah7, bh1)) | 0;\n    lo = (lo + Math.imul(al6, bl2)) | 0;\n    mid = (mid + Math.imul(al6, bh2)) | 0;\n    mid = (mid + Math.imul(ah6, bl2)) | 0;\n    hi = (hi + Math.imul(ah6, bh2)) | 0;\n    lo = (lo + Math.imul(al5, bl3)) | 0;\n    mid = (mid + Math.imul(al5, bh3)) | 0;\n    mid = (mid + Math.imul(ah5, bl3)) | 0;\n    hi = (hi + Math.imul(ah5, bh3)) | 0;\n    lo = (lo + Math.imul(al4, bl4)) | 0;\n    mid = (mid + Math.imul(al4, bh4)) | 0;\n    mid = (mid + Math.imul(ah4, bl4)) | 0;\n    hi = (hi + Math.imul(ah4, bh4)) | 0;\n    lo = (lo + Math.imul(al3, bl5)) | 0;\n    mid = (mid + Math.imul(al3, bh5)) | 0;\n    mid = (mid + Math.imul(ah3, bl5)) | 0;\n    hi = (hi + Math.imul(ah3, bh5)) | 0;\n    lo = (lo + Math.imul(al2, bl6)) | 0;\n    mid = (mid + Math.imul(al2, bh6)) | 0;\n    mid = (mid + Math.imul(ah2, bl6)) | 0;\n    hi = (hi + Math.imul(ah2, bh6)) | 0;\n    lo = (lo + Math.imul(al1, bl7)) | 0;\n    mid = (mid + Math.imul(al1, bh7)) | 0;\n    mid = (mid + Math.imul(ah1, bl7)) | 0;\n    hi = (hi + Math.imul(ah1, bh7)) | 0;\n    lo = (lo + Math.imul(al0, bl8)) | 0;\n    mid = (mid + Math.imul(al0, bh8)) | 0;\n    mid = (mid + Math.imul(ah0, bl8)) | 0;\n    hi = (hi + Math.imul(ah0, bh8)) | 0;\n    var w8 = (((c + lo) | 0) + ((mid & 0x1fff) << 13)) | 0;\n    c = (((hi + (mid >>> 13)) | 0) + (w8 >>> 26)) | 0;\n    w8 &= 0x3ffffff;\n    /* k = 9 */\n    lo = Math.imul(al9, bl0);\n    mid = Math.imul(al9, bh0);\n    mid = (mid + Math.imul(ah9, bl0)) | 0;\n    hi = Math.imul(ah9, bh0);\n    lo = (lo + Math.imul(al8, bl1)) | 0;\n    mid = (mid + Math.imul(al8, bh1)) | 0;\n    mid = (mid + Math.imul(ah8, bl1)) | 0;\n    hi = (hi + Math.imul(ah8, bh1)) | 0;\n    lo = (lo + Math.imul(al7, bl2)) | 0;\n    mid = (mid + Math.imul(al7, bh2)) | 0;\n    mid = (mid + Math.imul(ah7, bl2)) | 0;\n    hi = (hi + Math.imul(ah7, bh2)) | 0;\n    lo = (lo + Math.imul(al6, bl3)) | 0;\n    mid = (mid + Math.imul(al6, bh3)) | 0;\n    mid = (mid + Math.imul(ah6, bl3)) | 0;\n    hi = (hi + Math.imul(ah6, bh3)) | 0;\n    lo = (lo + Math.imul(al5, bl4)) | 0;\n    mid = (mid + Math.imul(al5, bh4)) | 0;\n    mid = (mid + Math.imul(ah5, bl4)) | 0;\n    hi = (hi + Math.imul(ah5, bh4)) | 0;\n    lo = (lo + Math.imul(al4, bl5)) | 0;\n    mid = (mid + Math.imul(al4, bh5)) | 0;\n    mid = (mid + Math.imul(ah4, bl5)) | 0;\n    hi = (hi + Math.imul(ah4, bh5)) | 0;\n    lo = (lo + Math.imul(al3, bl6)) | 0;\n    mid = (mid + Math.imul(al3, bh6)) | 0;\n    mid = (mid + Math.imul(ah3, bl6)) | 0;\n    hi = (hi + Math.imul(ah3, bh6)) | 0;\n    lo = (lo + Math.imul(al2, bl7)) | 0;\n    mid = (mid + Math.imul(al2, bh7)) | 0;\n    mid = (mid + Math.imul(ah2, bl7)) | 0;\n    hi = (hi + Math.imul(ah2, bh7)) | 0;\n    lo = (lo + Math.imul(al1, bl8)) | 0;\n    mid = (mid + Math.imul(al1, bh8)) | 0;\n    mid = (mid + Math.imul(ah1, bl8)) | 0;\n    hi = (hi + Math.imul(ah1, bh8)) | 0;\n    lo = (lo + Math.imul(al0, bl9)) | 0;\n    mid = (mid + Math.imul(al0, bh9)) | 0;\n    mid = (mid + Math.imul(ah0, bl9)) | 0;\n    hi = (hi + Math.imul(ah0, bh9)) | 0;\n    var w9 = (((c + lo) | 0) + ((mid & 0x1fff) << 13)) | 0;\n    c = (((hi + (mid >>> 13)) | 0) + (w9 >>> 26)) | 0;\n    w9 &= 0x3ffffff;\n    /* k = 10 */\n    lo = Math.imul(al9, bl1);\n    mid = Math.imul(al9, bh1);\n    mid = (mid + Math.imul(ah9, bl1)) | 0;\n    hi = Math.imul(ah9, bh1);\n    lo = (lo + Math.imul(al8, bl2)) | 0;\n    mid = (mid + Math.imul(al8, bh2)) | 0;\n    mid = (mid + Math.imul(ah8, bl2)) | 0;\n    hi = (hi + Math.imul(ah8, bh2)) | 0;\n    lo = (lo + Math.imul(al7, bl3)) | 0;\n    mid = (mid + Math.imul(al7, bh3)) | 0;\n    mid = (mid + Math.imul(ah7, bl3)) | 0;\n    hi = (hi + Math.imul(ah7, bh3)) | 0;\n    lo = (lo + Math.imul(al6, bl4)) | 0;\n    mid = (mid + Math.imul(al6, bh4)) | 0;\n    mid = (mid + Math.imul(ah6, bl4)) | 0;\n    hi = (hi + Math.imul(ah6, bh4)) | 0;\n    lo = (lo + Math.imul(al5, bl5)) | 0;\n    mid = (mid + Math.imul(al5, bh5)) | 0;\n    mid = (mid + Math.imul(ah5, bl5)) | 0;\n    hi = (hi + Math.imul(ah5, bh5)) | 0;\n    lo = (lo + Math.imul(al4, bl6)) | 0;\n    mid = (mid + Math.imul(al4, bh6)) | 0;\n    mid = (mid + Math.imul(ah4, bl6)) | 0;\n    hi = (hi + Math.imul(ah4, bh6)) | 0;\n    lo = (lo + Math.imul(al3, bl7)) | 0;\n    mid = (mid + Math.imul(al3, bh7)) | 0;\n    mid = (mid + Math.imul(ah3, bl7)) | 0;\n    hi = (hi + Math.imul(ah3, bh7)) | 0;\n    lo = (lo + Math.imul(al2, bl8)) | 0;\n    mid = (mid + Math.imul(al2, bh8)) | 0;\n    mid = (mid + Math.imul(ah2, bl8)) | 0;\n    hi = (hi + Math.imul(ah2, bh8)) | 0;\n    lo = (lo + Math.imul(al1, bl9)) | 0;\n    mid = (mid + Math.imul(al1, bh9)) | 0;\n    mid = (mid + Math.imul(ah1, bl9)) | 0;\n    hi = (hi + Math.imul(ah1, bh9)) | 0;\n    var w10 = (((c + lo) | 0) + ((mid & 0x1fff) << 13)) | 0;\n    c = (((hi + (mid >>> 13)) | 0) + (w10 >>> 26)) | 0;\n    w10 &= 0x3ffffff;\n    /* k = 11 */\n    lo = Math.imul(al9, bl2);\n    mid = Math.imul(al9, bh2);\n    mid = (mid + Math.imul(ah9, bl2)) | 0;\n    hi = Math.imul(ah9, bh2);\n    lo = (lo + Math.imul(al8, bl3)) | 0;\n    mid = (mid + Math.imul(al8, bh3)) | 0;\n    mid = (mid + Math.imul(ah8, bl3)) | 0;\n    hi = (hi + Math.imul(ah8, bh3)) | 0;\n    lo = (lo + Math.imul(al7, bl4)) | 0;\n    mid = (mid + Math.imul(al7, bh4)) | 0;\n    mid = (mid + Math.imul(ah7, bl4)) | 0;\n    hi = (hi + Math.imul(ah7, bh4)) | 0;\n    lo = (lo + Math.imul(al6, bl5)) | 0;\n    mid = (mid + Math.imul(al6, bh5)) | 0;\n    mid = (mid + Math.imul(ah6, bl5)) | 0;\n    hi = (hi + Math.imul(ah6, bh5)) | 0;\n    lo = (lo + Math.imul(al5, bl6)) | 0;\n    mid = (mid + Math.imul(al5, bh6)) | 0;\n    mid = (mid + Math.imul(ah5, bl6)) | 0;\n    hi = (hi + Math.imul(ah5, bh6)) | 0;\n    lo = (lo + Math.imul(al4, bl7)) | 0;\n    mid = (mid + Math.imul(al4, bh7)) | 0;\n    mid = (mid + Math.imul(ah4, bl7)) | 0;\n    hi = (hi + Math.imul(ah4, bh7)) | 0;\n    lo = (lo + Math.imul(al3, bl8)) | 0;\n    mid = (mid + Math.imul(al3, bh8)) | 0;\n    mid = (mid + Math.imul(ah3, bl8)) | 0;\n    hi = (hi + Math.imul(ah3, bh8)) | 0;\n    lo = (lo + Math.imul(al2, bl9)) | 0;\n    mid = (mid + Math.imul(al2, bh9)) | 0;\n    mid = (mid + Math.imul(ah2, bl9)) | 0;\n    hi = (hi + Math.imul(ah2, bh9)) | 0;\n    var w11 = (((c + lo) | 0) + ((mid & 0x1fff) << 13)) | 0;\n    c = (((hi + (mid >>> 13)) | 0) + (w11 >>> 26)) | 0;\n    w11 &= 0x3ffffff;\n    /* k = 12 */\n    lo = Math.imul(al9, bl3);\n    mid = Math.imul(al9, bh3);\n    mid = (mid + Math.imul(ah9, bl3)) | 0;\n    hi = Math.imul(ah9, bh3);\n    lo = (lo + Math.imul(al8, bl4)) | 0;\n    mid = (mid + Math.imul(al8, bh4)) | 0;\n    mid = (mid + Math.imul(ah8, bl4)) | 0;\n    hi = (hi + Math.imul(ah8, bh4)) | 0;\n    lo = (lo + Math.imul(al7, bl5)) | 0;\n    mid = (mid + Math.imul(al7, bh5)) | 0;\n    mid = (mid + Math.imul(ah7, bl5)) | 0;\n    hi = (hi + Math.imul(ah7, bh5)) | 0;\n    lo = (lo + Math.imul(al6, bl6)) | 0;\n    mid = (mid + Math.imul(al6, bh6)) | 0;\n    mid = (mid + Math.imul(ah6, bl6)) | 0;\n    hi = (hi + Math.imul(ah6, bh6)) | 0;\n    lo = (lo + Math.imul(al5, bl7)) | 0;\n    mid = (mid + Math.imul(al5, bh7)) | 0;\n    mid = (mid + Math.imul(ah5, bl7)) | 0;\n    hi = (hi + Math.imul(ah5, bh7)) | 0;\n    lo = (lo + Math.imul(al4, bl8)) | 0;\n    mid = (mid + Math.imul(al4, bh8)) | 0;\n    mid = (mid + Math.imul(ah4, bl8)) | 0;\n    hi = (hi + Math.imul(ah4, bh8)) | 0;\n    lo = (lo + Math.imul(al3, bl9)) | 0;\n    mid = (mid + Math.imul(al3, bh9)) | 0;\n    mid = (mid + Math.imul(ah3, bl9)) | 0;\n    hi = (hi + Math.imul(ah3, bh9)) | 0;\n    var w12 = (((c + lo) | 0) + ((mid & 0x1fff) << 13)) | 0;\n    c = (((hi + (mid >>> 13)) | 0) + (w12 >>> 26)) | 0;\n    w12 &= 0x3ffffff;\n    /* k = 13 */\n    lo = Math.imul(al9, bl4);\n    mid = Math.imul(al9, bh4);\n    mid = (mid + Math.imul(ah9, bl4)) | 0;\n    hi = Math.imul(ah9, bh4);\n    lo = (lo + Math.imul(al8, bl5)) | 0;\n    mid = (mid + Math.imul(al8, bh5)) | 0;\n    mid = (mid + Math.imul(ah8, bl5)) | 0;\n    hi = (hi + Math.imul(ah8, bh5)) | 0;\n    lo = (lo + Math.imul(al7, bl6)) | 0;\n    mid = (mid + Math.imul(al7, bh6)) | 0;\n    mid = (mid + Math.imul(ah7, bl6)) | 0;\n    hi = (hi + Math.imul(ah7, bh6)) | 0;\n    lo = (lo + Math.imul(al6, bl7)) | 0;\n    mid = (mid + Math.imul(al6, bh7)) | 0;\n    mid = (mid + Math.imul(ah6, bl7)) | 0;\n    hi = (hi + Math.imul(ah6, bh7)) | 0;\n    lo = (lo + Math.imul(al5, bl8)) | 0;\n    mid = (mid + Math.imul(al5, bh8)) | 0;\n    mid = (mid + Math.imul(ah5, bl8)) | 0;\n    hi = (hi + Math.imul(ah5, bh8)) | 0;\n    lo = (lo + Math.imul(al4, bl9)) | 0;\n    mid = (mid + Math.imul(al4, bh9)) | 0;\n    mid = (mid + Math.imul(ah4, bl9)) | 0;\n    hi = (hi + Math.imul(ah4, bh9)) | 0;\n    var w13 = (((c + lo) | 0) + ((mid & 0x1fff) << 13)) | 0;\n    c = (((hi + (mid >>> 13)) | 0) + (w13 >>> 26)) | 0;\n    w13 &= 0x3ffffff;\n    /* k = 14 */\n    lo = Math.imul(al9, bl5);\n    mid = Math.imul(al9, bh5);\n    mid = (mid + Math.imul(ah9, bl5)) | 0;\n    hi = Math.imul(ah9, bh5);\n    lo = (lo + Math.imul(al8, bl6)) | 0;\n    mid = (mid + Math.imul(al8, bh6)) | 0;\n    mid = (mid + Math.imul(ah8, bl6)) | 0;\n    hi = (hi + Math.imul(ah8, bh6)) | 0;\n    lo = (lo + Math.imul(al7, bl7)) | 0;\n    mid = (mid + Math.imul(al7, bh7)) | 0;\n    mid = (mid + Math.imul(ah7, bl7)) | 0;\n    hi = (hi + Math.imul(ah7, bh7)) | 0;\n    lo = (lo + Math.imul(al6, bl8)) | 0;\n    mid = (mid + Math.imul(al6, bh8)) | 0;\n    mid = (mid + Math.imul(ah6, bl8)) | 0;\n    hi = (hi + Math.imul(ah6, bh8)) | 0;\n    lo = (lo + Math.imul(al5, bl9)) | 0;\n    mid = (mid + Math.imul(al5, bh9)) | 0;\n    mid = (mid + Math.imul(ah5, bl9)) | 0;\n    hi = (hi + Math.imul(ah5, bh9)) | 0;\n    var w14 = (((c + lo) | 0) + ((mid & 0x1fff) << 13)) | 0;\n    c = (((hi + (mid >>> 13)) | 0) + (w14 >>> 26)) | 0;\n    w14 &= 0x3ffffff;\n    /* k = 15 */\n    lo = Math.imul(al9, bl6);\n    mid = Math.imul(al9, bh6);\n    mid = (mid + Math.imul(ah9, bl6)) | 0;\n    hi = Math.imul(ah9, bh6);\n    lo = (lo + Math.imul(al8, bl7)) | 0;\n    mid = (mid + Math.imul(al8, bh7)) | 0;\n    mid = (mid + Math.imul(ah8, bl7)) | 0;\n    hi = (hi + Math.imul(ah8, bh7)) | 0;\n    lo = (lo + Math.imul(al7, bl8)) | 0;\n    mid = (mid + Math.imul(al7, bh8)) | 0;\n    mid = (mid + Math.imul(ah7, bl8)) | 0;\n    hi = (hi + Math.imul(ah7, bh8)) | 0;\n    lo = (lo + Math.imul(al6, bl9)) | 0;\n    mid = (mid + Math.imul(al6, bh9)) | 0;\n    mid = (mid + Math.imul(ah6, bl9)) | 0;\n    hi = (hi + Math.imul(ah6, bh9)) | 0;\n    var w15 = (((c + lo) | 0) + ((mid & 0x1fff) << 13)) | 0;\n    c = (((hi + (mid >>> 13)) | 0) + (w15 >>> 26)) | 0;\n    w15 &= 0x3ffffff;\n    /* k = 16 */\n    lo = Math.imul(al9, bl7);\n    mid = Math.imul(al9, bh7);\n    mid = (mid + Math.imul(ah9, bl7)) | 0;\n    hi = Math.imul(ah9, bh7);\n    lo = (lo + Math.imul(al8, bl8)) | 0;\n    mid = (mid + Math.imul(al8, bh8)) | 0;\n    mid = (mid + Math.imul(ah8, bl8)) | 0;\n    hi = (hi + Math.imul(ah8, bh8)) | 0;\n    lo = (lo + Math.imul(al7, bl9)) | 0;\n    mid = (mid + Math.imul(al7, bh9)) | 0;\n    mid = (mid + Math.imul(ah7, bl9)) | 0;\n    hi = (hi + Math.imul(ah7, bh9)) | 0;\n    var w16 = (((c + lo) | 0) + ((mid & 0x1fff) << 13)) | 0;\n    c = (((hi + (mid >>> 13)) | 0) + (w16 >>> 26)) | 0;\n    w16 &= 0x3ffffff;\n    /* k = 17 */\n    lo = Math.imul(al9, bl8);\n    mid = Math.imul(al9, bh8);\n    mid = (mid + Math.imul(ah9, bl8)) | 0;\n    hi = Math.imul(ah9, bh8);\n    lo = (lo + Math.imul(al8, bl9)) | 0;\n    mid = (mid + Math.imul(al8, bh9)) | 0;\n    mid = (mid + Math.imul(ah8, bl9)) | 0;\n    hi = (hi + Math.imul(ah8, bh9)) | 0;\n    var w17 = (((c + lo) | 0) + ((mid & 0x1fff) << 13)) | 0;\n    c = (((hi + (mid >>> 13)) | 0) + (w17 >>> 26)) | 0;\n    w17 &= 0x3ffffff;\n    /* k = 18 */\n    lo = Math.imul(al9, bl9);\n    mid = Math.imul(al9, bh9);\n    mid = (mid + Math.imul(ah9, bl9)) | 0;\n    hi = Math.imul(ah9, bh9);\n    var w18 = (((c + lo) | 0) + ((mid & 0x1fff) << 13)) | 0;\n    c = (((hi + (mid >>> 13)) | 0) + (w18 >>> 26)) | 0;\n    w18 &= 0x3ffffff;\n    o[0] = w0;\n    o[1] = w1;\n    o[2] = w2;\n    o[3] = w3;\n    o[4] = w4;\n    o[5] = w5;\n    o[6] = w6;\n    o[7] = w7;\n    o[8] = w8;\n    o[9] = w9;\n    o[10] = w10;\n    o[11] = w11;\n    o[12] = w12;\n    o[13] = w13;\n    o[14] = w14;\n    o[15] = w15;\n    o[16] = w16;\n    o[17] = w17;\n    o[18] = w18;\n    if (c !== 0) {\n      o[19] = c;\n      out.length++;\n    }\n    return out;\n  };\n\n  // Polyfill comb\n  if (!Math.imul) {\n    comb10MulTo = smallMulTo;\n  }\n\n  function bigMulTo (self, num, out) {\n    out.negative = num.negative ^ self.negative;\n    out.length = self.length + num.length;\n\n    var carry = 0;\n    var hncarry = 0;\n    for (var k = 0; k < out.length - 1; k++) {\n      // Sum all words with the same `i + j = k` and accumulate `ncarry`,\n      // note that ncarry could be >= 0x3ffffff\n      var ncarry = hncarry;\n      hncarry = 0;\n      var rword = carry & 0x3ffffff;\n      var maxJ = Math.min(k, num.length - 1);\n      for (var j = Math.max(0, k - self.length + 1); j <= maxJ; j++) {\n        var i = k - j;\n        var a = self.words[i] | 0;\n        var b = num.words[j] | 0;\n        var r = a * b;\n\n        var lo = r & 0x3ffffff;\n        ncarry = (ncarry + ((r / 0x4000000) | 0)) | 0;\n        lo = (lo + rword) | 0;\n        rword = lo & 0x3ffffff;\n        ncarry = (ncarry + (lo >>> 26)) | 0;\n\n        hncarry += ncarry >>> 26;\n        ncarry &= 0x3ffffff;\n      }\n      out.words[k] = rword;\n      carry = ncarry;\n      ncarry = hncarry;\n    }\n    if (carry !== 0) {\n      out.words[k] = carry;\n    } else {\n      out.length--;\n    }\n\n    return out.strip();\n  }\n\n  function jumboMulTo (self, num, out) {\n    var fftm = new FFTM();\n    return fftm.mulp(self, num, out);\n  }\n\n  BN.prototype.mulTo = function mulTo (num, out) {\n    var res;\n    var len = this.length + num.length;\n    if (this.length === 10 && num.length === 10) {\n      res = comb10MulTo(this, num, out);\n    } else if (len < 63) {\n      res = smallMulTo(this, num, out);\n    } else if (len < 1024) {\n      res = bigMulTo(this, num, out);\n    } else {\n      res = jumboMulTo(this, num, out);\n    }\n\n    return res;\n  };\n\n  // Cooley-Tukey algorithm for FFT\n  // slightly revisited to rely on looping instead of recursion\n\n  function FFTM (x, y) {\n    this.x = x;\n    this.y = y;\n  }\n\n  FFTM.prototype.makeRBT = function makeRBT (N) {\n    var t = new Array(N);\n    var l = BN.prototype._countBits(N) - 1;\n    for (var i = 0; i < N; i++) {\n      t[i] = this.revBin(i, l, N);\n    }\n\n    return t;\n  };\n\n  // Returns binary-reversed representation of `x`\n  FFTM.prototype.revBin = function revBin (x, l, N) {\n    if (x === 0 || x === N - 1) return x;\n\n    var rb = 0;\n    for (var i = 0; i < l; i++) {\n      rb |= (x & 1) << (l - i - 1);\n      x >>= 1;\n    }\n\n    return rb;\n  };\n\n  // Performs \"tweedling\" phase, therefore 'emulating'\n  // behaviour of the recursive algorithm\n  FFTM.prototype.permute = function permute (rbt, rws, iws, rtws, itws, N) {\n    for (var i = 0; i < N; i++) {\n      rtws[i] = rws[rbt[i]];\n      itws[i] = iws[rbt[i]];\n    }\n  };\n\n  FFTM.prototype.transform = function transform (rws, iws, rtws, itws, N, rbt) {\n    this.permute(rbt, rws, iws, rtws, itws, N);\n\n    for (var s = 1; s < N; s <<= 1) {\n      var l = s << 1;\n\n      var rtwdf = Math.cos(2 * Math.PI / l);\n      var itwdf = Math.sin(2 * Math.PI / l);\n\n      for (var p = 0; p < N; p += l) {\n        var rtwdf_ = rtwdf;\n        var itwdf_ = itwdf;\n\n        for (var j = 0; j < s; j++) {\n          var re = rtws[p + j];\n          var ie = itws[p + j];\n\n          var ro = rtws[p + j + s];\n          var io = itws[p + j + s];\n\n          var rx = rtwdf_ * ro - itwdf_ * io;\n\n          io = rtwdf_ * io + itwdf_ * ro;\n          ro = rx;\n\n          rtws[p + j] = re + ro;\n          itws[p + j] = ie + io;\n\n          rtws[p + j + s] = re - ro;\n          itws[p + j + s] = ie - io;\n\n          /* jshint maxdepth : false */\n          if (j !== l) {\n            rx = rtwdf * rtwdf_ - itwdf * itwdf_;\n\n            itwdf_ = rtwdf * itwdf_ + itwdf * rtwdf_;\n            rtwdf_ = rx;\n          }\n        }\n      }\n    }\n  };\n\n  FFTM.prototype.guessLen13b = function guessLen13b (n, m) {\n    var N = Math.max(m, n) | 1;\n    var odd = N & 1;\n    var i = 0;\n    for (N = N / 2 | 0; N; N = N >>> 1) {\n      i++;\n    }\n\n    return 1 << i + 1 + odd;\n  };\n\n  FFTM.prototype.conjugate = function conjugate (rws, iws, N) {\n    if (N <= 1) return;\n\n    for (var i = 0; i < N / 2; i++) {\n      var t = rws[i];\n\n      rws[i] = rws[N - i - 1];\n      rws[N - i - 1] = t;\n\n      t = iws[i];\n\n      iws[i] = -iws[N - i - 1];\n      iws[N - i - 1] = -t;\n    }\n  };\n\n  FFTM.prototype.normalize13b = function normalize13b (ws, N) {\n    var carry = 0;\n    for (var i = 0; i < N / 2; i++) {\n      var w = Math.round(ws[2 * i + 1] / N) * 0x2000 +\n        Math.round(ws[2 * i] / N) +\n        carry;\n\n      ws[i] = w & 0x3ffffff;\n\n      if (w < 0x4000000) {\n        carry = 0;\n      } else {\n        carry = w / 0x4000000 | 0;\n      }\n    }\n\n    return ws;\n  };\n\n  FFTM.prototype.convert13b = function convert13b (ws, len, rws, N) {\n    var carry = 0;\n    for (var i = 0; i < len; i++) {\n      carry = carry + (ws[i] | 0);\n\n      rws[2 * i] = carry & 0x1fff; carry = carry >>> 13;\n      rws[2 * i + 1] = carry & 0x1fff; carry = carry >>> 13;\n    }\n\n    // Pad with zeroes\n    for (i = 2 * len; i < N; ++i) {\n      rws[i] = 0;\n    }\n\n    assert(carry === 0);\n    assert((carry & ~0x1fff) === 0);\n  };\n\n  FFTM.prototype.stub = function stub (N) {\n    var ph = new Array(N);\n    for (var i = 0; i < N; i++) {\n      ph[i] = 0;\n    }\n\n    return ph;\n  };\n\n  FFTM.prototype.mulp = function mulp (x, y, out) {\n    var N = 2 * this.guessLen13b(x.length, y.length);\n\n    var rbt = this.makeRBT(N);\n\n    var _ = this.stub(N);\n\n    var rws = new Array(N);\n    var rwst = new Array(N);\n    var iwst = new Array(N);\n\n    var nrws = new Array(N);\n    var nrwst = new Array(N);\n    var niwst = new Array(N);\n\n    var rmws = out.words;\n    rmws.length = N;\n\n    this.convert13b(x.words, x.length, rws, N);\n    this.convert13b(y.words, y.length, nrws, N);\n\n    this.transform(rws, _, rwst, iwst, N, rbt);\n    this.transform(nrws, _, nrwst, niwst, N, rbt);\n\n    for (var i = 0; i < N; i++) {\n      var rx = rwst[i] * nrwst[i] - iwst[i] * niwst[i];\n      iwst[i] = rwst[i] * niwst[i] + iwst[i] * nrwst[i];\n      rwst[i] = rx;\n    }\n\n    this.conjugate(rwst, iwst, N);\n    this.transform(rwst, iwst, rmws, _, N, rbt);\n    this.conjugate(rmws, _, N);\n    this.normalize13b(rmws, N);\n\n    out.negative = x.negative ^ y.negative;\n    out.length = x.length + y.length;\n    return out.strip();\n  };\n\n  // Multiply `this` by `num`\n  BN.prototype.mul = function mul (num) {\n    var out = new BN(null);\n    out.words = new Array(this.length + num.length);\n    return this.mulTo(num, out);\n  };\n\n  // Multiply employing FFT\n  BN.prototype.mulf = function mulf (num) {\n    var out = new BN(null);\n    out.words = new Array(this.length + num.length);\n    return jumboMulTo(this, num, out);\n  };\n\n  // In-place Multiplication\n  BN.prototype.imul = function imul (num) {\n    return this.clone().mulTo(num, this);\n  };\n\n  BN.prototype.imuln = function imuln (num) {\n    assert(typeof num === 'number');\n    assert(num < 0x4000000);\n\n    // Carry\n    var carry = 0;\n    for (var i = 0; i < this.length; i++) {\n      var w = (this.words[i] | 0) * num;\n      var lo = (w & 0x3ffffff) + (carry & 0x3ffffff);\n      carry >>= 26;\n      carry += (w / 0x4000000) | 0;\n      // NOTE: lo is 27bit maximum\n      carry += lo >>> 26;\n      this.words[i] = lo & 0x3ffffff;\n    }\n\n    if (carry !== 0) {\n      this.words[i] = carry;\n      this.length++;\n    }\n    this.length = num === 0 ? 1 : this.length;\n\n    return this;\n  };\n\n  BN.prototype.muln = function muln (num) {\n    return this.clone().imuln(num);\n  };\n\n  // `this` * `this`\n  BN.prototype.sqr = function sqr () {\n    return this.mul(this);\n  };\n\n  // `this` * `this` in-place\n  BN.prototype.isqr = function isqr () {\n    return this.imul(this.clone());\n  };\n\n  // Math.pow(`this`, `num`)\n  BN.prototype.pow = function pow (num) {\n    var w = toBitArray(num);\n    if (w.length === 0) return new BN(1);\n\n    // Skip leading zeroes\n    var res = this;\n    for (var i = 0; i < w.length; i++, res = res.sqr()) {\n      if (w[i] !== 0) break;\n    }\n\n    if (++i < w.length) {\n      for (var q = res.sqr(); i < w.length; i++, q = q.sqr()) {\n        if (w[i] === 0) continue;\n\n        res = res.mul(q);\n      }\n    }\n\n    return res;\n  };\n\n  // Shift-left in-place\n  BN.prototype.iushln = function iushln (bits) {\n    assert(typeof bits === 'number' && bits >= 0);\n    var r = bits % 26;\n    var s = (bits - r) / 26;\n    var carryMask = (0x3ffffff >>> (26 - r)) << (26 - r);\n    var i;\n\n    if (r !== 0) {\n      var carry = 0;\n\n      for (i = 0; i < this.length; i++) {\n        var newCarry = this.words[i] & carryMask;\n        var c = ((this.words[i] | 0) - newCarry) << r;\n        this.words[i] = c | carry;\n        carry = newCarry >>> (26 - r);\n      }\n\n      if (carry) {\n        this.words[i] = carry;\n        this.length++;\n      }\n    }\n\n    if (s !== 0) {\n      for (i = this.length - 1; i >= 0; i--) {\n        this.words[i + s] = this.words[i];\n      }\n\n      for (i = 0; i < s; i++) {\n        this.words[i] = 0;\n      }\n\n      this.length += s;\n    }\n\n    return this.strip();\n  };\n\n  BN.prototype.ishln = function ishln (bits) {\n    // TODO(indutny): implement me\n    assert(this.negative === 0);\n    return this.iushln(bits);\n  };\n\n  // Shift-right in-place\n  // NOTE: `hint` is a lowest bit before trailing zeroes\n  // NOTE: if `extended` is present - it will be filled with destroyed bits\n  BN.prototype.iushrn = function iushrn (bits, hint, extended) {\n    assert(typeof bits === 'number' && bits >= 0);\n    var h;\n    if (hint) {\n      h = (hint - (hint % 26)) / 26;\n    } else {\n      h = 0;\n    }\n\n    var r = bits % 26;\n    var s = Math.min((bits - r) / 26, this.length);\n    var mask = 0x3ffffff ^ ((0x3ffffff >>> r) << r);\n    var maskedWords = extended;\n\n    h -= s;\n    h = Math.max(0, h);\n\n    // Extended mode, copy masked part\n    if (maskedWords) {\n      for (var i = 0; i < s; i++) {\n        maskedWords.words[i] = this.words[i];\n      }\n      maskedWords.length = s;\n    }\n\n    if (s === 0) {\n      // No-op, we should not move anything at all\n    } else if (this.length > s) {\n      this.length -= s;\n      for (i = 0; i < this.length; i++) {\n        this.words[i] = this.words[i + s];\n      }\n    } else {\n      this.words[0] = 0;\n      this.length = 1;\n    }\n\n    var carry = 0;\n    for (i = this.length - 1; i >= 0 && (carry !== 0 || i >= h); i--) {\n      var word = this.words[i] | 0;\n      this.words[i] = (carry << (26 - r)) | (word >>> r);\n      carry = word & mask;\n    }\n\n    // Push carried bits as a mask\n    if (maskedWords && carry !== 0) {\n      maskedWords.words[maskedWords.length++] = carry;\n    }\n\n    if (this.length === 0) {\n      this.words[0] = 0;\n      this.length = 1;\n    }\n\n    return this.strip();\n  };\n\n  BN.prototype.ishrn = function ishrn (bits, hint, extended) {\n    // TODO(indutny): implement me\n    assert(this.negative === 0);\n    return this.iushrn(bits, hint, extended);\n  };\n\n  // Shift-left\n  BN.prototype.shln = function shln (bits) {\n    return this.clone().ishln(bits);\n  };\n\n  BN.prototype.ushln = function ushln (bits) {\n    return this.clone().iushln(bits);\n  };\n\n  // Shift-right\n  BN.prototype.shrn = function shrn (bits) {\n    return this.clone().ishrn(bits);\n  };\n\n  BN.prototype.ushrn = function ushrn (bits) {\n    return this.clone().iushrn(bits);\n  };\n\n  // Test if n bit is set\n  BN.prototype.testn = function testn (bit) {\n    assert(typeof bit === 'number' && bit >= 0);\n    var r = bit % 26;\n    var s = (bit - r) / 26;\n    var q = 1 << r;\n\n    // Fast case: bit is much higher than all existing words\n    if (this.length <= s) return false;\n\n    // Check bit and return\n    var w = this.words[s];\n\n    return !!(w & q);\n  };\n\n  // Return only lowers bits of number (in-place)\n  BN.prototype.imaskn = function imaskn (bits) {\n    assert(typeof bits === 'number' && bits >= 0);\n    var r = bits % 26;\n    var s = (bits - r) / 26;\n\n    assert(this.negative === 0, 'imaskn works only with positive numbers');\n\n    if (this.length <= s) {\n      return this;\n    }\n\n    if (r !== 0) {\n      s++;\n    }\n    this.length = Math.min(s, this.length);\n\n    if (r !== 0) {\n      var mask = 0x3ffffff ^ ((0x3ffffff >>> r) << r);\n      this.words[this.length - 1] &= mask;\n    }\n\n    return this.strip();\n  };\n\n  // Return only lowers bits of number\n  BN.prototype.maskn = function maskn (bits) {\n    return this.clone().imaskn(bits);\n  };\n\n  // Add plain number `num` to `this`\n  BN.prototype.iaddn = function iaddn (num) {\n    assert(typeof num === 'number');\n    assert(num < 0x4000000);\n    if (num < 0) return this.isubn(-num);\n\n    // Possible sign change\n    if (this.negative !== 0) {\n      if (this.length === 1 && (this.words[0] | 0) < num) {\n        this.words[0] = num - (this.words[0] | 0);\n        this.negative = 0;\n        return this;\n      }\n\n      this.negative = 0;\n      this.isubn(num);\n      this.negative = 1;\n      return this;\n    }\n\n    // Add without checks\n    return this._iaddn(num);\n  };\n\n  BN.prototype._iaddn = function _iaddn (num) {\n    this.words[0] += num;\n\n    // Carry\n    for (var i = 0; i < this.length && this.words[i] >= 0x4000000; i++) {\n      this.words[i] -= 0x4000000;\n      if (i === this.length - 1) {\n        this.words[i + 1] = 1;\n      } else {\n        this.words[i + 1]++;\n      }\n    }\n    this.length = Math.max(this.length, i + 1);\n\n    return this;\n  };\n\n  // Subtract plain number `num` from `this`\n  BN.prototype.isubn = function isubn (num) {\n    assert(typeof num === 'number');\n    assert(num < 0x4000000);\n    if (num < 0) return this.iaddn(-num);\n\n    if (this.negative !== 0) {\n      this.negative = 0;\n      this.iaddn(num);\n      this.negative = 1;\n      return this;\n    }\n\n    this.words[0] -= num;\n\n    if (this.length === 1 && this.words[0] < 0) {\n      this.words[0] = -this.words[0];\n      this.negative = 1;\n    } else {\n      // Carry\n      for (var i = 0; i < this.length && this.words[i] < 0; i++) {\n        this.words[i] += 0x4000000;\n        this.words[i + 1] -= 1;\n      }\n    }\n\n    return this.strip();\n  };\n\n  BN.prototype.addn = function addn (num) {\n    return this.clone().iaddn(num);\n  };\n\n  BN.prototype.subn = function subn (num) {\n    return this.clone().isubn(num);\n  };\n\n  BN.prototype.iabs = function iabs () {\n    this.negative = 0;\n\n    return this;\n  };\n\n  BN.prototype.abs = function abs () {\n    return this.clone().iabs();\n  };\n\n  BN.prototype._ishlnsubmul = function _ishlnsubmul (num, mul, shift) {\n    var len = num.length + shift;\n    var i;\n\n    this._expand(len);\n\n    var w;\n    var carry = 0;\n    for (i = 0; i < num.length; i++) {\n      w = (this.words[i + shift] | 0) + carry;\n      var right = (num.words[i] | 0) * mul;\n      w -= right & 0x3ffffff;\n      carry = (w >> 26) - ((right / 0x4000000) | 0);\n      this.words[i + shift] = w & 0x3ffffff;\n    }\n    for (; i < this.length - shift; i++) {\n      w = (this.words[i + shift] | 0) + carry;\n      carry = w >> 26;\n      this.words[i + shift] = w & 0x3ffffff;\n    }\n\n    if (carry === 0) return this.strip();\n\n    // Subtraction overflow\n    assert(carry === -1);\n    carry = 0;\n    for (i = 0; i < this.length; i++) {\n      w = -(this.words[i] | 0) + carry;\n      carry = w >> 26;\n      this.words[i] = w & 0x3ffffff;\n    }\n    this.negative = 1;\n\n    return this.strip();\n  };\n\n  BN.prototype._wordDiv = function _wordDiv (num, mode) {\n    var shift = this.length - num.length;\n\n    var a = this.clone();\n    var b = num;\n\n    // Normalize\n    var bhi = b.words[b.length - 1] | 0;\n    var bhiBits = this._countBits(bhi);\n    shift = 26 - bhiBits;\n    if (shift !== 0) {\n      b = b.ushln(shift);\n      a.iushln(shift);\n      bhi = b.words[b.length - 1] | 0;\n    }\n\n    // Initialize quotient\n    var m = a.length - b.length;\n    var q;\n\n    if (mode !== 'mod') {\n      q = new BN(null);\n      q.length = m + 1;\n      q.words = new Array(q.length);\n      for (var i = 0; i < q.length; i++) {\n        q.words[i] = 0;\n      }\n    }\n\n    var diff = a.clone()._ishlnsubmul(b, 1, m);\n    if (diff.negative === 0) {\n      a = diff;\n      if (q) {\n        q.words[m] = 1;\n      }\n    }\n\n    for (var j = m - 1; j >= 0; j--) {\n      var qj = (a.words[b.length + j] | 0) * 0x4000000 +\n        (a.words[b.length + j - 1] | 0);\n\n      // NOTE: (qj / bhi) is (0x3ffffff * 0x4000000 + 0x3ffffff) / 0x2000000 max\n      // (0x7ffffff)\n      qj = Math.min((qj / bhi) | 0, 0x3ffffff);\n\n      a._ishlnsubmul(b, qj, j);\n      while (a.negative !== 0) {\n        qj--;\n        a.negative = 0;\n        a._ishlnsubmul(b, 1, j);\n        if (!a.isZero()) {\n          a.negative ^= 1;\n        }\n      }\n      if (q) {\n        q.words[j] = qj;\n      }\n    }\n    if (q) {\n      q.strip();\n    }\n    a.strip();\n\n    // Denormalize\n    if (mode !== 'div' && shift !== 0) {\n      a.iushrn(shift);\n    }\n\n    return {\n      div: q || null,\n      mod: a\n    };\n  };\n\n  // NOTE: 1) `mode` can be set to `mod` to request mod only,\n  //       to `div` to request div only, or be absent to\n  //       request both div & mod\n  //       2) `positive` is true if unsigned mod is requested\n  BN.prototype.divmod = function divmod (num, mode, positive) {\n    assert(!num.isZero());\n\n    if (this.isZero()) {\n      return {\n        div: new BN(0),\n        mod: new BN(0)\n      };\n    }\n\n    var div, mod, res;\n    if (this.negative !== 0 && num.negative === 0) {\n      res = this.neg().divmod(num, mode);\n\n      if (mode !== 'mod') {\n        div = res.div.neg();\n      }\n\n      if (mode !== 'div') {\n        mod = res.mod.neg();\n        if (positive && mod.negative !== 0) {\n          mod.iadd(num);\n        }\n      }\n\n      return {\n        div: div,\n        mod: mod\n      };\n    }\n\n    if (this.negative === 0 && num.negative !== 0) {\n      res = this.divmod(num.neg(), mode);\n\n      if (mode !== 'mod') {\n        div = res.div.neg();\n      }\n\n      return {\n        div: div,\n        mod: res.mod\n      };\n    }\n\n    if ((this.negative & num.negative) !== 0) {\n      res = this.neg().divmod(num.neg(), mode);\n\n      if (mode !== 'div') {\n        mod = res.mod.neg();\n        if (positive && mod.negative !== 0) {\n          mod.isub(num);\n        }\n      }\n\n      return {\n        div: res.div,\n        mod: mod\n      };\n    }\n\n    // Both numbers are positive at this point\n\n    // Strip both numbers to approximate shift value\n    if (num.length > this.length || this.cmp(num) < 0) {\n      return {\n        div: new BN(0),\n        mod: this\n      };\n    }\n\n    // Very short reduction\n    if (num.length === 1) {\n      if (mode === 'div') {\n        return {\n          div: this.divn(num.words[0]),\n          mod: null\n        };\n      }\n\n      if (mode === 'mod') {\n        return {\n          div: null,\n          mod: new BN(this.modn(num.words[0]))\n        };\n      }\n\n      return {\n        div: this.divn(num.words[0]),\n        mod: new BN(this.modn(num.words[0]))\n      };\n    }\n\n    return this._wordDiv(num, mode);\n  };\n\n  // Find `this` / `num`\n  BN.prototype.div = function div (num) {\n    return this.divmod(num, 'div', false).div;\n  };\n\n  // Find `this` % `num`\n  BN.prototype.mod = function mod (num) {\n    return this.divmod(num, 'mod', false).mod;\n  };\n\n  BN.prototype.umod = function umod (num) {\n    return this.divmod(num, 'mod', true).mod;\n  };\n\n  // Find Round(`this` / `num`)\n  BN.prototype.divRound = function divRound (num) {\n    var dm = this.divmod(num);\n\n    // Fast case - exact division\n    if (dm.mod.isZero()) return dm.div;\n\n    var mod = dm.div.negative !== 0 ? dm.mod.isub(num) : dm.mod;\n\n    var half = num.ushrn(1);\n    var r2 = num.andln(1);\n    var cmp = mod.cmp(half);\n\n    // Round down\n    if (cmp < 0 || r2 === 1 && cmp === 0) return dm.div;\n\n    // Round up\n    return dm.div.negative !== 0 ? dm.div.isubn(1) : dm.div.iaddn(1);\n  };\n\n  BN.prototype.modn = function modn (num) {\n    assert(num <= 0x3ffffff);\n    var p = (1 << 26) % num;\n\n    var acc = 0;\n    for (var i = this.length - 1; i >= 0; i--) {\n      acc = (p * acc + (this.words[i] | 0)) % num;\n    }\n\n    return acc;\n  };\n\n  // In-place division by number\n  BN.prototype.idivn = function idivn (num) {\n    assert(num <= 0x3ffffff);\n\n    var carry = 0;\n    for (var i = this.length - 1; i >= 0; i--) {\n      var w = (this.words[i] | 0) + carry * 0x4000000;\n      this.words[i] = (w / num) | 0;\n      carry = w % num;\n    }\n\n    return this.strip();\n  };\n\n  BN.prototype.divn = function divn (num) {\n    return this.clone().idivn(num);\n  };\n\n  BN.prototype.egcd = function egcd (p) {\n    assert(p.negative === 0);\n    assert(!p.isZero());\n\n    var x = this;\n    var y = p.clone();\n\n    if (x.negative !== 0) {\n      x = x.umod(p);\n    } else {\n      x = x.clone();\n    }\n\n    // A * x + B * y = x\n    var A = new BN(1);\n    var B = new BN(0);\n\n    // C * x + D * y = y\n    var C = new BN(0);\n    var D = new BN(1);\n\n    var g = 0;\n\n    while (x.isEven() && y.isEven()) {\n      x.iushrn(1);\n      y.iushrn(1);\n      ++g;\n    }\n\n    var yp = y.clone();\n    var xp = x.clone();\n\n    while (!x.isZero()) {\n      for (var i = 0, im = 1; (x.words[0] & im) === 0 && i < 26; ++i, im <<= 1);\n      if (i > 0) {\n        x.iushrn(i);\n        while (i-- > 0) {\n          if (A.isOdd() || B.isOdd()) {\n            A.iadd(yp);\n            B.isub(xp);\n          }\n\n          A.iushrn(1);\n          B.iushrn(1);\n        }\n      }\n\n      for (var j = 0, jm = 1; (y.words[0] & jm) === 0 && j < 26; ++j, jm <<= 1);\n      if (j > 0) {\n        y.iushrn(j);\n        while (j-- > 0) {\n          if (C.isOdd() || D.isOdd()) {\n            C.iadd(yp);\n            D.isub(xp);\n          }\n\n          C.iushrn(1);\n          D.iushrn(1);\n        }\n      }\n\n      if (x.cmp(y) >= 0) {\n        x.isub(y);\n        A.isub(C);\n        B.isub(D);\n      } else {\n        y.isub(x);\n        C.isub(A);\n        D.isub(B);\n      }\n    }\n\n    return {\n      a: C,\n      b: D,\n      gcd: y.iushln(g)\n    };\n  };\n\n  // This is reduced incarnation of the binary EEA\n  // above, designated to invert members of the\n  // _prime_ fields F(p) at a maximal speed\n  BN.prototype._invmp = function _invmp (p) {\n    assert(p.negative === 0);\n    assert(!p.isZero());\n\n    var a = this;\n    var b = p.clone();\n\n    if (a.negative !== 0) {\n      a = a.umod(p);\n    } else {\n      a = a.clone();\n    }\n\n    var x1 = new BN(1);\n    var x2 = new BN(0);\n\n    var delta = b.clone();\n\n    while (a.cmpn(1) > 0 && b.cmpn(1) > 0) {\n      for (var i = 0, im = 1; (a.words[0] & im) === 0 && i < 26; ++i, im <<= 1);\n      if (i > 0) {\n        a.iushrn(i);\n        while (i-- > 0) {\n          if (x1.isOdd()) {\n            x1.iadd(delta);\n          }\n\n          x1.iushrn(1);\n        }\n      }\n\n      for (var j = 0, jm = 1; (b.words[0] & jm) === 0 && j < 26; ++j, jm <<= 1);\n      if (j > 0) {\n        b.iushrn(j);\n        while (j-- > 0) {\n          if (x2.isOdd()) {\n            x2.iadd(delta);\n          }\n\n          x2.iushrn(1);\n        }\n      }\n\n      if (a.cmp(b) >= 0) {\n        a.isub(b);\n        x1.isub(x2);\n      } else {\n        b.isub(a);\n        x2.isub(x1);\n      }\n    }\n\n    var res;\n    if (a.cmpn(1) === 0) {\n      res = x1;\n    } else {\n      res = x2;\n    }\n\n    if (res.cmpn(0) < 0) {\n      res.iadd(p);\n    }\n\n    return res;\n  };\n\n  BN.prototype.gcd = function gcd (num) {\n    if (this.isZero()) return num.abs();\n    if (num.isZero()) return this.abs();\n\n    var a = this.clone();\n    var b = num.clone();\n    a.negative = 0;\n    b.negative = 0;\n\n    // Remove common factor of two\n    for (var shift = 0; a.isEven() && b.isEven(); shift++) {\n      a.iushrn(1);\n      b.iushrn(1);\n    }\n\n    do {\n      while (a.isEven()) {\n        a.iushrn(1);\n      }\n      while (b.isEven()) {\n        b.iushrn(1);\n      }\n\n      var r = a.cmp(b);\n      if (r < 0) {\n        // Swap `a` and `b` to make `a` always bigger than `b`\n        var t = a;\n        a = b;\n        b = t;\n      } else if (r === 0 || b.cmpn(1) === 0) {\n        break;\n      }\n\n      a.isub(b);\n    } while (true);\n\n    return b.iushln(shift);\n  };\n\n  // Invert number in the field F(num)\n  BN.prototype.invm = function invm (num) {\n    return this.egcd(num).a.umod(num);\n  };\n\n  BN.prototype.isEven = function isEven () {\n    return (this.words[0] & 1) === 0;\n  };\n\n  BN.prototype.isOdd = function isOdd () {\n    return (this.words[0] & 1) === 1;\n  };\n\n  // And first word and num\n  BN.prototype.andln = function andln (num) {\n    return this.words[0] & num;\n  };\n\n  // Increment at the bit position in-line\n  BN.prototype.bincn = function bincn (bit) {\n    assert(typeof bit === 'number');\n    var r = bit % 26;\n    var s = (bit - r) / 26;\n    var q = 1 << r;\n\n    // Fast case: bit is much higher than all existing words\n    if (this.length <= s) {\n      this._expand(s + 1);\n      this.words[s] |= q;\n      return this;\n    }\n\n    // Add bit and propagate, if needed\n    var carry = q;\n    for (var i = s; carry !== 0 && i < this.length; i++) {\n      var w = this.words[i] | 0;\n      w += carry;\n      carry = w >>> 26;\n      w &= 0x3ffffff;\n      this.words[i] = w;\n    }\n    if (carry !== 0) {\n      this.words[i] = carry;\n      this.length++;\n    }\n    return this;\n  };\n\n  BN.prototype.isZero = function isZero () {\n    return this.length === 1 && this.words[0] === 0;\n  };\n\n  BN.prototype.cmpn = function cmpn (num) {\n    var negative = num < 0;\n\n    if (this.negative !== 0 && !negative) return -1;\n    if (this.negative === 0 && negative) return 1;\n\n    this.strip();\n\n    var res;\n    if (this.length > 1) {\n      res = 1;\n    } else {\n      if (negative) {\n        num = -num;\n      }\n\n      assert(num <= 0x3ffffff, 'Number is too big');\n\n      var w = this.words[0] | 0;\n      res = w === num ? 0 : w < num ? -1 : 1;\n    }\n    if (this.negative !== 0) return -res | 0;\n    return res;\n  };\n\n  // Compare two numbers and return:\n  // 1 - if `this` > `num`\n  // 0 - if `this` == `num`\n  // -1 - if `this` < `num`\n  BN.prototype.cmp = function cmp (num) {\n    if (this.negative !== 0 && num.negative === 0) return -1;\n    if (this.negative === 0 && num.negative !== 0) return 1;\n\n    var res = this.ucmp(num);\n    if (this.negative !== 0) return -res | 0;\n    return res;\n  };\n\n  // Unsigned comparison\n  BN.prototype.ucmp = function ucmp (num) {\n    // At this point both numbers have the same sign\n    if (this.length > num.length) return 1;\n    if (this.length < num.length) return -1;\n\n    var res = 0;\n    for (var i = this.length - 1; i >= 0; i--) {\n      var a = this.words[i] | 0;\n      var b = num.words[i] | 0;\n\n      if (a === b) continue;\n      if (a < b) {\n        res = -1;\n      } else if (a > b) {\n        res = 1;\n      }\n      break;\n    }\n    return res;\n  };\n\n  BN.prototype.gtn = function gtn (num) {\n    return this.cmpn(num) === 1;\n  };\n\n  BN.prototype.gt = function gt (num) {\n    return this.cmp(num) === 1;\n  };\n\n  BN.prototype.gten = function gten (num) {\n    return this.cmpn(num) >= 0;\n  };\n\n  BN.prototype.gte = function gte (num) {\n    return this.cmp(num) >= 0;\n  };\n\n  BN.prototype.ltn = function ltn (num) {\n    return this.cmpn(num) === -1;\n  };\n\n  BN.prototype.lt = function lt (num) {\n    return this.cmp(num) === -1;\n  };\n\n  BN.prototype.lten = function lten (num) {\n    return this.cmpn(num) <= 0;\n  };\n\n  BN.prototype.lte = function lte (num) {\n    return this.cmp(num) <= 0;\n  };\n\n  BN.prototype.eqn = function eqn (num) {\n    return this.cmpn(num) === 0;\n  };\n\n  BN.prototype.eq = function eq (num) {\n    return this.cmp(num) === 0;\n  };\n\n  //\n  // A reduce context, could be using montgomery or something better, depending\n  // on the `m` itself.\n  //\n  BN.red = function red (num) {\n    return new Red(num);\n  };\n\n  BN.prototype.toRed = function toRed (ctx) {\n    assert(!this.red, 'Already a number in reduction context');\n    assert(this.negative === 0, 'red works only with positives');\n    return ctx.convertTo(this)._forceRed(ctx);\n  };\n\n  BN.prototype.fromRed = function fromRed () {\n    assert(this.red, 'fromRed works only with numbers in reduction context');\n    return this.red.convertFrom(this);\n  };\n\n  BN.prototype._forceRed = function _forceRed (ctx) {\n    this.red = ctx;\n    return this;\n  };\n\n  BN.prototype.forceRed = function forceRed (ctx) {\n    assert(!this.red, 'Already a number in reduction context');\n    return this._forceRed(ctx);\n  };\n\n  BN.prototype.redAdd = function redAdd (num) {\n    assert(this.red, 'redAdd works only with red numbers');\n    return this.red.add(this, num);\n  };\n\n  BN.prototype.redIAdd = function redIAdd (num) {\n    assert(this.red, 'redIAdd works only with red numbers');\n    return this.red.iadd(this, num);\n  };\n\n  BN.prototype.redSub = function redSub (num) {\n    assert(this.red, 'redSub works only with red numbers');\n    return this.red.sub(this, num);\n  };\n\n  BN.prototype.redISub = function redISub (num) {\n    assert(this.red, 'redISub works only with red numbers');\n    return this.red.isub(this, num);\n  };\n\n  BN.prototype.redShl = function redShl (num) {\n    assert(this.red, 'redShl works only with red numbers');\n    return this.red.shl(this, num);\n  };\n\n  BN.prototype.redMul = function redMul (num) {\n    assert(this.red, 'redMul works only with red numbers');\n    this.red._verify2(this, num);\n    return this.red.mul(this, num);\n  };\n\n  BN.prototype.redIMul = function redIMul (num) {\n    assert(this.red, 'redMul works only with red numbers');\n    this.red._verify2(this, num);\n    return this.red.imul(this, num);\n  };\n\n  BN.prototype.redSqr = function redSqr () {\n    assert(this.red, 'redSqr works only with red numbers');\n    this.red._verify1(this);\n    return this.red.sqr(this);\n  };\n\n  BN.prototype.redISqr = function redISqr () {\n    assert(this.red, 'redISqr works only with red numbers');\n    this.red._verify1(this);\n    return this.red.isqr(this);\n  };\n\n  // Square root over p\n  BN.prototype.redSqrt = function redSqrt () {\n    assert(this.red, 'redSqrt works only with red numbers');\n    this.red._verify1(this);\n    return this.red.sqrt(this);\n  };\n\n  BN.prototype.redInvm = function redInvm () {\n    assert(this.red, 'redInvm works only with red numbers');\n    this.red._verify1(this);\n    return this.red.invm(this);\n  };\n\n  // Return negative clone of `this` % `red modulo`\n  BN.prototype.redNeg = function redNeg () {\n    assert(this.red, 'redNeg works only with red numbers');\n    this.red._verify1(this);\n    return this.red.neg(this);\n  };\n\n  BN.prototype.redPow = function redPow (num) {\n    assert(this.red && !num.red, 'redPow(normalNum)');\n    this.red._verify1(this);\n    return this.red.pow(this, num);\n  };\n\n  // Prime numbers with efficient reduction\n  var primes = {\n    k256: null,\n    p224: null,\n    p192: null,\n    p25519: null\n  };\n\n  // Pseudo-Mersenne prime\n  function MPrime (name, p) {\n    // P = 2 ^ N - K\n    this.name = name;\n    this.p = new BN(p, 16);\n    this.n = this.p.bitLength();\n    this.k = new BN(1).iushln(this.n).isub(this.p);\n\n    this.tmp = this._tmp();\n  }\n\n  MPrime.prototype._tmp = function _tmp () {\n    var tmp = new BN(null);\n    tmp.words = new Array(Math.ceil(this.n / 13));\n    return tmp;\n  };\n\n  MPrime.prototype.ireduce = function ireduce (num) {\n    // Assumes that `num` is less than `P^2`\n    // num = HI * (2 ^ N - K) + HI * K + LO = HI * K + LO (mod P)\n    var r = num;\n    var rlen;\n\n    do {\n      this.split(r, this.tmp);\n      r = this.imulK(r);\n      r = r.iadd(this.tmp);\n      rlen = r.bitLength();\n    } while (rlen > this.n);\n\n    var cmp = rlen < this.n ? -1 : r.ucmp(this.p);\n    if (cmp === 0) {\n      r.words[0] = 0;\n      r.length = 1;\n    } else if (cmp > 0) {\n      r.isub(this.p);\n    } else {\n      if (r.strip !== undefined) {\n        // r is BN v4 instance\n        r.strip();\n      } else {\n        // r is BN v5 instance\n        r._strip();\n      }\n    }\n\n    return r;\n  };\n\n  MPrime.prototype.split = function split (input, out) {\n    input.iushrn(this.n, 0, out);\n  };\n\n  MPrime.prototype.imulK = function imulK (num) {\n    return num.imul(this.k);\n  };\n\n  function K256 () {\n    MPrime.call(\n      this,\n      'k256',\n      'ffffffff ffffffff ffffffff ffffffff ffffffff ffffffff fffffffe fffffc2f');\n  }\n  inherits(K256, MPrime);\n\n  K256.prototype.split = function split (input, output) {\n    // 256 = 9 * 26 + 22\n    var mask = 0x3fffff;\n\n    var outLen = Math.min(input.length, 9);\n    for (var i = 0; i < outLen; i++) {\n      output.words[i] = input.words[i];\n    }\n    output.length = outLen;\n\n    if (input.length <= 9) {\n      input.words[0] = 0;\n      input.length = 1;\n      return;\n    }\n\n    // Shift by 9 limbs\n    var prev = input.words[9];\n    output.words[output.length++] = prev & mask;\n\n    for (i = 10; i < input.length; i++) {\n      var next = input.words[i] | 0;\n      input.words[i - 10] = ((next & mask) << 4) | (prev >>> 22);\n      prev = next;\n    }\n    prev >>>= 22;\n    input.words[i - 10] = prev;\n    if (prev === 0 && input.length > 10) {\n      input.length -= 10;\n    } else {\n      input.length -= 9;\n    }\n  };\n\n  K256.prototype.imulK = function imulK (num) {\n    // K = 0x1000003d1 = [ 0x40, 0x3d1 ]\n    num.words[num.length] = 0;\n    num.words[num.length + 1] = 0;\n    num.length += 2;\n\n    // bounded at: 0x40 * 0x3ffffff + 0x3d0 = 0x100000390\n    var lo = 0;\n    for (var i = 0; i < num.length; i++) {\n      var w = num.words[i] | 0;\n      lo += w * 0x3d1;\n      num.words[i] = lo & 0x3ffffff;\n      lo = w * 0x40 + ((lo / 0x4000000) | 0);\n    }\n\n    // Fast length reduction\n    if (num.words[num.length - 1] === 0) {\n      num.length--;\n      if (num.words[num.length - 1] === 0) {\n        num.length--;\n      }\n    }\n    return num;\n  };\n\n  function P224 () {\n    MPrime.call(\n      this,\n      'p224',\n      'ffffffff ffffffff ffffffff ffffffff 00000000 00000000 00000001');\n  }\n  inherits(P224, MPrime);\n\n  function P192 () {\n    MPrime.call(\n      this,\n      'p192',\n      'ffffffff ffffffff ffffffff fffffffe ffffffff ffffffff');\n  }\n  inherits(P192, MPrime);\n\n  function P25519 () {\n    // 2 ^ 255 - 19\n    MPrime.call(\n      this,\n      '25519',\n      '7fffffffffffffff ffffffffffffffff ffffffffffffffff ffffffffffffffed');\n  }\n  inherits(P25519, MPrime);\n\n  P25519.prototype.imulK = function imulK (num) {\n    // K = 0x13\n    var carry = 0;\n    for (var i = 0; i < num.length; i++) {\n      var hi = (num.words[i] | 0) * 0x13 + carry;\n      var lo = hi & 0x3ffffff;\n      hi >>>= 26;\n\n      num.words[i] = lo;\n      carry = hi;\n    }\n    if (carry !== 0) {\n      num.words[num.length++] = carry;\n    }\n    return num;\n  };\n\n  // Exported mostly for testing purposes, use plain name instead\n  BN._prime = function prime (name) {\n    // Cached version of prime\n    if (primes[name]) return primes[name];\n\n    var prime;\n    if (name === 'k256') {\n      prime = new K256();\n    } else if (name === 'p224') {\n      prime = new P224();\n    } else if (name === 'p192') {\n      prime = new P192();\n    } else if (name === 'p25519') {\n      prime = new P25519();\n    } else {\n      throw new Error('Unknown prime ' + name);\n    }\n    primes[name] = prime;\n\n    return prime;\n  };\n\n  //\n  // Base reduction engine\n  //\n  function Red (m) {\n    if (typeof m === 'string') {\n      var prime = BN._prime(m);\n      this.m = prime.p;\n      this.prime = prime;\n    } else {\n      assert(m.gtn(1), 'modulus must be greater than 1');\n      this.m = m;\n      this.prime = null;\n    }\n  }\n\n  Red.prototype._verify1 = function _verify1 (a) {\n    assert(a.negative === 0, 'red works only with positives');\n    assert(a.red, 'red works only with red numbers');\n  };\n\n  Red.prototype._verify2 = function _verify2 (a, b) {\n    assert((a.negative | b.negative) === 0, 'red works only with positives');\n    assert(a.red && a.red === b.red,\n      'red works only with red numbers');\n  };\n\n  Red.prototype.imod = function imod (a) {\n    if (this.prime) return this.prime.ireduce(a)._forceRed(this);\n    return a.umod(this.m)._forceRed(this);\n  };\n\n  Red.prototype.neg = function neg (a) {\n    if (a.isZero()) {\n      return a.clone();\n    }\n\n    return this.m.sub(a)._forceRed(this);\n  };\n\n  Red.prototype.add = function add (a, b) {\n    this._verify2(a, b);\n\n    var res = a.add(b);\n    if (res.cmp(this.m) >= 0) {\n      res.isub(this.m);\n    }\n    return res._forceRed(this);\n  };\n\n  Red.prototype.iadd = function iadd (a, b) {\n    this._verify2(a, b);\n\n    var res = a.iadd(b);\n    if (res.cmp(this.m) >= 0) {\n      res.isub(this.m);\n    }\n    return res;\n  };\n\n  Red.prototype.sub = function sub (a, b) {\n    this._verify2(a, b);\n\n    var res = a.sub(b);\n    if (res.cmpn(0) < 0) {\n      res.iadd(this.m);\n    }\n    return res._forceRed(this);\n  };\n\n  Red.prototype.isub = function isub (a, b) {\n    this._verify2(a, b);\n\n    var res = a.isub(b);\n    if (res.cmpn(0) < 0) {\n      res.iadd(this.m);\n    }\n    return res;\n  };\n\n  Red.prototype.shl = function shl (a, num) {\n    this._verify1(a);\n    return this.imod(a.ushln(num));\n  };\n\n  Red.prototype.imul = function imul (a, b) {\n    this._verify2(a, b);\n    return this.imod(a.imul(b));\n  };\n\n  Red.prototype.mul = function mul (a, b) {\n    this._verify2(a, b);\n    return this.imod(a.mul(b));\n  };\n\n  Red.prototype.isqr = function isqr (a) {\n    return this.imul(a, a.clone());\n  };\n\n  Red.prototype.sqr = function sqr (a) {\n    return this.mul(a, a);\n  };\n\n  Red.prototype.sqrt = function sqrt (a) {\n    if (a.isZero()) return a.clone();\n\n    var mod3 = this.m.andln(3);\n    assert(mod3 % 2 === 1);\n\n    // Fast case\n    if (mod3 === 3) {\n      var pow = this.m.add(new BN(1)).iushrn(2);\n      return this.pow(a, pow);\n    }\n\n    // Tonelli-Shanks algorithm (Totally unoptimized and slow)\n    //\n    // Find Q and S, that Q * 2 ^ S = (P - 1)\n    var q = this.m.subn(1);\n    var s = 0;\n    while (!q.isZero() && q.andln(1) === 0) {\n      s++;\n      q.iushrn(1);\n    }\n    assert(!q.isZero());\n\n    var one = new BN(1).toRed(this);\n    var nOne = one.redNeg();\n\n    // Find quadratic non-residue\n    // NOTE: Max is such because of generalized Riemann hypothesis.\n    var lpow = this.m.subn(1).iushrn(1);\n    var z = this.m.bitLength();\n    z = new BN(2 * z * z).toRed(this);\n\n    while (this.pow(z, lpow).cmp(nOne) !== 0) {\n      z.redIAdd(nOne);\n    }\n\n    var c = this.pow(z, q);\n    var r = this.pow(a, q.addn(1).iushrn(1));\n    var t = this.pow(a, q);\n    var m = s;\n    while (t.cmp(one) !== 0) {\n      var tmp = t;\n      for (var i = 0; tmp.cmp(one) !== 0; i++) {\n        tmp = tmp.redSqr();\n      }\n      assert(i < m);\n      var b = this.pow(c, new BN(1).iushln(m - i - 1));\n\n      r = r.redMul(b);\n      c = b.redSqr();\n      t = t.redMul(c);\n      m = i;\n    }\n\n    return r;\n  };\n\n  Red.prototype.invm = function invm (a) {\n    var inv = a._invmp(this.m);\n    if (inv.negative !== 0) {\n      inv.negative = 0;\n      return this.imod(inv).redNeg();\n    } else {\n      return this.imod(inv);\n    }\n  };\n\n  Red.prototype.pow = function pow (a, num) {\n    if (num.isZero()) return new BN(1).toRed(this);\n    if (num.cmpn(1) === 0) return a.clone();\n\n    var windowSize = 4;\n    var wnd = new Array(1 << windowSize);\n    wnd[0] = new BN(1).toRed(this);\n    wnd[1] = a;\n    for (var i = 2; i < wnd.length; i++) {\n      wnd[i] = this.mul(wnd[i - 1], a);\n    }\n\n    var res = wnd[0];\n    var current = 0;\n    var currentLen = 0;\n    var start = num.bitLength() % 26;\n    if (start === 0) {\n      start = 26;\n    }\n\n    for (i = num.length - 1; i >= 0; i--) {\n      var word = num.words[i];\n      for (var j = start - 1; j >= 0; j--) {\n        var bit = (word >> j) & 1;\n        if (res !== wnd[0]) {\n          res = this.sqr(res);\n        }\n\n        if (bit === 0 && current === 0) {\n          currentLen = 0;\n          continue;\n        }\n\n        current <<= 1;\n        current |= bit;\n        currentLen++;\n        if (currentLen !== windowSize && (i !== 0 || j !== 0)) continue;\n\n        res = this.mul(res, wnd[current]);\n        currentLen = 0;\n        current = 0;\n      }\n      start = 26;\n    }\n\n    return res;\n  };\n\n  Red.prototype.convertTo = function convertTo (num) {\n    var r = num.umod(this.m);\n\n    return r === num ? r.clone() : r;\n  };\n\n  Red.prototype.convertFrom = function convertFrom (num) {\n    var res = num.clone();\n    res.red = null;\n    return res;\n  };\n\n  //\n  // Montgomery method engine\n  //\n\n  BN.mont = function mont (num) {\n    return new Mont(num);\n  };\n\n  function Mont (m) {\n    Red.call(this, m);\n\n    this.shift = this.m.bitLength();\n    if (this.shift % 26 !== 0) {\n      this.shift += 26 - (this.shift % 26);\n    }\n\n    this.r = new BN(1).iushln(this.shift);\n    this.r2 = this.imod(this.r.sqr());\n    this.rinv = this.r._invmp(this.m);\n\n    this.minv = this.rinv.mul(this.r).isubn(1).div(this.m);\n    this.minv = this.minv.umod(this.r);\n    this.minv = this.r.sub(this.minv);\n  }\n  inherits(Mont, Red);\n\n  Mont.prototype.convertTo = function convertTo (num) {\n    return this.imod(num.ushln(this.shift));\n  };\n\n  Mont.prototype.convertFrom = function convertFrom (num) {\n    var r = this.imod(num.mul(this.rinv));\n    r.red = null;\n    return r;\n  };\n\n  Mont.prototype.imul = function imul (a, b) {\n    if (a.isZero() || b.isZero()) {\n      a.words[0] = 0;\n      a.length = 1;\n      return a;\n    }\n\n    var t = a.imul(b);\n    var c = t.maskn(this.shift).mul(this.minv).imaskn(this.shift).mul(this.m);\n    var u = t.isub(c).iushrn(this.shift);\n    var res = u;\n\n    if (u.cmp(this.m) >= 0) {\n      res = u.isub(this.m);\n    } else if (u.cmpn(0) < 0) {\n      res = u.iadd(this.m);\n    }\n\n    return res._forceRed(this);\n  };\n\n  Mont.prototype.mul = function mul (a, b) {\n    if (a.isZero() || b.isZero()) return new BN(0)._forceRed(this);\n\n    var t = a.mul(b);\n    var c = t.maskn(this.shift).mul(this.minv).imaskn(this.shift).mul(this.m);\n    var u = t.isub(c).iushrn(this.shift);\n    var res = u;\n    if (u.cmp(this.m) >= 0) {\n      res = u.isub(this.m);\n    } else if (u.cmpn(0) < 0) {\n      res = u.iadd(this.m);\n    }\n\n    return res._forceRed(this);\n  };\n\n  Mont.prototype.invm = function invm (a) {\n    // (AR)^-1 * R^2 = (A^-1 * R^-1) * R^2 = A^-1 * R\n    var res = this.imod(a._invmp(this.m).mul(this.r2));\n    return res._forceRed(this);\n  };\n})(typeof module === 'undefined' || module, this);\n",
    "if (typeof Object.create === 'function') {\n  // implementation from standard node.js 'util' module\n  module.exports = function inherits(ctor, superCtor) {\n    if (superCtor) {\n      ctor.super_ = superCtor\n      ctor.prototype = Object.create(superCtor.prototype, {\n        constructor: {\n          value: ctor,\n          enumerable: false,\n          writable: true,\n          configurable: true\n        }\n      })\n    }\n  };\n} else {\n  // old school shim for old browsers\n  module.exports = function inherits(ctor, superCtor) {\n    if (superCtor) {\n      ctor.super_ = superCtor\n      var TempCtor = function () {}\n      TempCtor.prototype = superCtor.prototype\n      ctor.prototype = new TempCtor()\n      ctor.prototype.constructor = ctor\n    }\n  }\n}\n",
    "try {\n  var util = require('util');\n  /* istanbul ignore next */\n  if (typeof util.inherits !== 'function') throw '';\n  module.exports = util.inherits;\n} catch (e) {\n  /* istanbul ignore next */\n  module.exports = require('./inherits_browser.js');\n}\n",
    "/* eslint-disable node/no-deprecated-api */\n\n'use strict'\n\nvar buffer = require('buffer')\nvar Buffer = buffer.Buffer\n\nvar safer = {}\n\nvar key\n\nfor (key in buffer) {\n  if (!buffer.hasOwnProperty(key)) continue\n  if (key === 'SlowBuffer' || key === 'Buffer') continue\n  safer[key] = buffer[key]\n}\n\nvar Safer = safer.Buffer = {}\nfor (key in Buffer) {\n  if (!Buffer.hasOwnProperty(key)) continue\n  if (key === 'allocUnsafe' || key === 'allocUnsafeSlow') continue\n  Safer[key] = Buffer[key]\n}\n\nsafer.Buffer.prototype = Buffer.prototype\n\nif (!Safer.from || Safer.from === Uint8Array.from) {\n  Safer.from = function (value, encodingOrOffset, length) {\n    if (typeof value === 'number') {\n      throw new TypeError('The \"value\" argument must not be of type number. Received type ' + typeof value)\n    }\n    if (value && typeof value.length === 'undefined') {\n      throw new TypeError('The first argument must be one of type string, Buffer, ArrayBuffer, Array, or Array-like Object. Received type ' + typeof value)\n    }\n    return Buffer(value, encodingOrOffset, length)\n  }\n}\n\nif (!Safer.alloc) {\n  Safer.alloc = function (size, fill, encoding) {\n    if (typeof size !== 'number') {\n      throw new TypeError('The \"size\" argument must be of type number. Received type ' + typeof size)\n    }\n    if (size < 0 || size >= 2 * (1 << 30)) {\n      throw new RangeError('The value \"' + size + '\" is invalid for option \"size\"')\n    }\n    var buf = Buffer(size)\n    if (!fill || fill.length === 0) {\n      buf.fill(0)\n    } else if (typeof encoding === 'string') {\n      buf.fill(fill, encoding)\n    } else {\n      buf.fill(fill)\n    }\n    return buf\n  }\n}\n\nif (!safer.kStringMaxLength) {\n  try {\n    safer.kStringMaxLength = process.binding('buffer').kStringMaxLength\n  } catch (e) {\n    // we can't determine kStringMaxLength in environments where process.binding\n    // is unsupported, so let's not set it\n  }\n}\n\nif (!safer.constants) {\n  safer.constants = {\n    MAX_LENGTH: safer.kMaxLength\n  }\n  if (safer.kStringMaxLength) {\n    safer.constants.MAX_STRING_LENGTH = safer.kStringMaxLength\n  }\n}\n\nmodule.exports = safer\n",
    "'use strict';\n\nconst inherits = require('inherits');\n\nfunction Reporter(options) {\n  this._reporterState = {\n    obj: null,\n    path: [],\n    options: options || {},\n    errors: []\n  };\n}\nexports.Reporter = Reporter;\n\nReporter.prototype.isError = function isError(obj) {\n  return obj instanceof ReporterError;\n};\n\nReporter.prototype.save = function save() {\n  const state = this._reporterState;\n\n  return { obj: state.obj, pathLen: state.path.length };\n};\n\nReporter.prototype.restore = function restore(data) {\n  const state = this._reporterState;\n\n  state.obj = data.obj;\n  state.path = state.path.slice(0, data.pathLen);\n};\n\nReporter.prototype.enterKey = function enterKey(key) {\n  return this._reporterState.path.push(key);\n};\n\nReporter.prototype.exitKey = function exitKey(index) {\n  const state = this._reporterState;\n\n  state.path = state.path.slice(0, index - 1);\n};\n\nReporter.prototype.leaveKey = function leaveKey(index, key, value) {\n  const state = this._reporterState;\n\n  this.exitKey(index);\n  if (state.obj !== null)\n    state.obj[key] = value;\n};\n\nReporter.prototype.path = function path() {\n  return this._reporterState.path.join('/');\n};\n\nReporter.prototype.enterObject = function enterObject() {\n  const state = this._reporterState;\n\n  const prev = state.obj;\n  state.obj = {};\n  return prev;\n};\n\nReporter.prototype.leaveObject = function leaveObject(prev) {\n  const state = this._reporterState;\n\n  const now = state.obj;\n  state.obj = prev;\n  return now;\n};\n\nReporter.prototype.error = function error(msg) {\n  let err;\n  const state = this._reporterState;\n\n  const inherited = msg instanceof ReporterError;\n  if (inherited) {\n    err = msg;\n  } else {\n    err = new ReporterError(state.path.map(function(elem) {\n      return '[' + JSON.stringify(elem) + ']';\n    }).join(''), msg.message || msg, msg.stack);\n  }\n\n  if (!state.options.partial)\n    throw err;\n\n  if (!inherited)\n    state.errors.push(err);\n\n  return err;\n};\n\nReporter.prototype.wrapResult = function wrapResult(result) {\n  const state = this._reporterState;\n  if (!state.options.partial)\n    return result;\n\n  return {\n    result: this.isError(result) ? null : result,\n    errors: state.errors\n  };\n};\n\nfunction ReporterError(path, msg) {\n  this.path = path;\n  this.rethrow(msg);\n}\ninherits(ReporterError, Error);\n\nReporterError.prototype.rethrow = function rethrow(msg) {\n  this.message = msg + ' at: ' + (this.path || '(shallow)');\n  if (Error.captureStackTrace)\n    Error.captureStackTrace(this, ReporterError);\n\n  if (!this.stack) {\n    try {\n      // IE only adds stack when thrown\n      throw new Error(this.message);\n    } catch (e) {\n      this.stack = e.stack;\n    }\n  }\n  return this;\n};\n",
    "'use strict';\n\nconst inherits = require('inherits');\nconst Reporter = require('../base/reporter').Reporter;\nconst Buffer = require('safer-buffer').Buffer;\n\nfunction DecoderBuffer(base, options) {\n  Reporter.call(this, options);\n  if (!Buffer.isBuffer(base)) {\n    this.error('Input not Buffer');\n    return;\n  }\n\n  this.base = base;\n  this.offset = 0;\n  this.length = base.length;\n}\ninherits(DecoderBuffer, Reporter);\nexports.DecoderBuffer = DecoderBuffer;\n\nDecoderBuffer.isDecoderBuffer = function isDecoderBuffer(data) {\n  if (data instanceof DecoderBuffer) {\n    return true;\n  }\n\n  // Or accept compatible API\n  const isCompatible = typeof data === 'object' &&\n    Buffer.isBuffer(data.base) &&\n    data.constructor.name === 'DecoderBuffer' &&\n    typeof data.offset === 'number' &&\n    typeof data.length === 'number' &&\n    typeof data.save === 'function' &&\n    typeof data.restore === 'function' &&\n    typeof data.isEmpty === 'function' &&\n    typeof data.readUInt8 === 'function' &&\n    typeof data.skip === 'function' &&\n    typeof data.raw === 'function';\n\n  return isCompatible;\n};\n\nDecoderBuffer.prototype.save = function save() {\n  return { offset: this.offset, reporter: Reporter.prototype.save.call(this) };\n};\n\nDecoderBuffer.prototype.restore = function restore(save) {\n  // Return skipped data\n  const res = new DecoderBuffer(this.base);\n  res.offset = save.offset;\n  res.length = this.offset;\n\n  this.offset = save.offset;\n  Reporter.prototype.restore.call(this, save.reporter);\n\n  return res;\n};\n\nDecoderBuffer.prototype.isEmpty = function isEmpty() {\n  return this.offset === this.length;\n};\n\nDecoderBuffer.prototype.readUInt8 = function readUInt8(fail) {\n  if (this.offset + 1 <= this.length)\n    return this.base.readUInt8(this.offset++, true);\n  else\n    return this.error(fail || 'DecoderBuffer overrun');\n};\n\nDecoderBuffer.prototype.skip = function skip(bytes, fail) {\n  if (!(this.offset + bytes <= this.length))\n    return this.error(fail || 'DecoderBuffer overrun');\n\n  const res = new DecoderBuffer(this.base);\n\n  // Share reporter state\n  res._reporterState = this._reporterState;\n\n  res.offset = this.offset;\n  res.length = this.offset + bytes;\n  this.offset += bytes;\n  return res;\n};\n\nDecoderBuffer.prototype.raw = function raw(save) {\n  return this.base.slice(save ? save.offset : this.offset, this.length);\n};\n\nfunction EncoderBuffer(value, reporter) {\n  if (Array.isArray(value)) {\n    this.length = 0;\n    this.value = value.map(function(item) {\n      if (!EncoderBuffer.isEncoderBuffer(item))\n        item = new EncoderBuffer(item, reporter);\n      this.length += item.length;\n      return item;\n    }, this);\n  } else if (typeof value === 'number') {\n    if (!(0 <= value && value <= 0xff))\n      return reporter.error('non-byte EncoderBuffer value');\n    this.value = value;\n    this.length = 1;\n  } else if (typeof value === 'string') {\n    this.value = value;\n    this.length = Buffer.byteLength(value);\n  } else if (Buffer.isBuffer(value)) {\n    this.value = value;\n    this.length = value.length;\n  } else {\n    return reporter.error('Unsupported type: ' + typeof value);\n  }\n}\nexports.EncoderBuffer = EncoderBuffer;\n\nEncoderBuffer.isEncoderBuffer = function isEncoderBuffer(data) {\n  if (data instanceof EncoderBuffer) {\n    return true;\n  }\n\n  // Or accept compatible API\n  const isCompatible = typeof data === 'object' &&\n    data.constructor.name === 'EncoderBuffer' &&\n    typeof data.length === 'number' &&\n    typeof data.join === 'function';\n\n  return isCompatible;\n};\n\nEncoderBuffer.prototype.join = function join(out, offset) {\n  if (!out)\n    out = Buffer.alloc(this.length);\n  if (!offset)\n    offset = 0;\n\n  if (this.length === 0)\n    return out;\n\n  if (Array.isArray(this.value)) {\n    this.value.forEach(function(item) {\n      item.join(out, offset);\n      offset += item.length;\n    });\n  } else {\n    if (typeof this.value === 'number')\n      out[offset] = this.value;\n    else if (typeof this.value === 'string')\n      out.write(this.value, offset);\n    else if (Buffer.isBuffer(this.value))\n      this.value.copy(out, offset);\n    offset += this.length;\n  }\n\n  return out;\n};\n",
    "module.exports = assert;\n\nfunction assert(val, msg) {\n  if (!val)\n    throw new Error(msg || 'Assertion failed');\n}\n\nassert.equal = function assertEqual(l, r, msg) {\n  if (l != r)\n    throw new Error(msg || ('Assertion failed: ' + l + ' != ' + r));\n};\n",
    "'use strict';\n\nconst Reporter = require('../base/reporter').Reporter;\nconst EncoderBuffer = require('../base/buffer').EncoderBuffer;\nconst DecoderBuffer = require('../base/buffer').DecoderBuffer;\nconst assert = require('minimalistic-assert');\n\n// Supported tags\nconst tags = [\n  'seq', 'seqof', 'set', 'setof', 'objid', 'bool',\n  'gentime', 'utctime', 'null_', 'enum', 'int', 'objDesc',\n  'bitstr', 'bmpstr', 'charstr', 'genstr', 'graphstr', 'ia5str', 'iso646str',\n  'numstr', 'octstr', 'printstr', 't61str', 'unistr', 'utf8str', 'videostr'\n];\n\n// Public methods list\nconst methods = [\n  'key', 'obj', 'use', 'optional', 'explicit', 'implicit', 'def', 'choice',\n  'any', 'contains'\n].concat(tags);\n\n// Overrided methods list\nconst overrided = [\n  '_peekTag', '_decodeTag', '_use',\n  '_decodeStr', '_decodeObjid', '_decodeTime',\n  '_decodeNull', '_decodeInt', '_decodeBool', '_decodeList',\n\n  '_encodeComposite', '_encodeStr', '_encodeObjid', '_encodeTime',\n  '_encodeNull', '_encodeInt', '_encodeBool'\n];\n\nfunction Node(enc, parent, name) {\n  const state = {};\n  this._baseState = state;\n\n  state.name = name;\n  state.enc = enc;\n\n  state.parent = parent || null;\n  state.children = null;\n\n  // State\n  state.tag = null;\n  state.args = null;\n  state.reverseArgs = null;\n  state.choice = null;\n  state.optional = false;\n  state.any = false;\n  state.obj = false;\n  state.use = null;\n  state.useDecoder = null;\n  state.key = null;\n  state['default'] = null;\n  state.explicit = null;\n  state.implicit = null;\n  state.contains = null;\n\n  // Should create new instance on each method\n  if (!state.parent) {\n    state.children = [];\n    this._wrap();\n  }\n}\nmodule.exports = Node;\n\nconst stateProps = [\n  'enc', 'parent', 'children', 'tag', 'args', 'reverseArgs', 'choice',\n  'optional', 'any', 'obj', 'use', 'alteredUse', 'key', 'default', 'explicit',\n  'implicit', 'contains'\n];\n\nNode.prototype.clone = function clone() {\n  const state = this._baseState;\n  const cstate = {};\n  stateProps.forEach(function(prop) {\n    cstate[prop] = state[prop];\n  });\n  const res = new this.constructor(cstate.parent);\n  res._baseState = cstate;\n  return res;\n};\n\nNode.prototype._wrap = function wrap() {\n  const state = this._baseState;\n  methods.forEach(function(method) {\n    this[method] = function _wrappedMethod() {\n      const clone = new this.constructor(this);\n      state.children.push(clone);\n      return clone[method].apply(clone, arguments);\n    };\n  }, this);\n};\n\nNode.prototype._init = function init(body) {\n  const state = this._baseState;\n\n  assert(state.parent === null);\n  body.call(this);\n\n  // Filter children\n  state.children = state.children.filter(function(child) {\n    return child._baseState.parent === this;\n  }, this);\n  assert.equal(state.children.length, 1, 'Root node can have only one child');\n};\n\nNode.prototype._useArgs = function useArgs(args) {\n  const state = this._baseState;\n\n  // Filter children and args\n  const children = args.filter(function(arg) {\n    return arg instanceof this.constructor;\n  }, this);\n  args = args.filter(function(arg) {\n    return !(arg instanceof this.constructor);\n  }, this);\n\n  if (children.length !== 0) {\n    assert(state.children === null);\n    state.children = children;\n\n    // Replace parent to maintain backward link\n    children.forEach(function(child) {\n      child._baseState.parent = this;\n    }, this);\n  }\n  if (args.length !== 0) {\n    assert(state.args === null);\n    state.args = args;\n    state.reverseArgs = args.map(function(arg) {\n      if (typeof arg !== 'object' || arg.constructor !== Object)\n        return arg;\n\n      const res = {};\n      Object.keys(arg).forEach(function(key) {\n        if (key == (key | 0))\n          key |= 0;\n        const value = arg[key];\n        res[value] = key;\n      });\n      return res;\n    });\n  }\n};\n\n//\n// Overrided methods\n//\n\noverrided.forEach(function(method) {\n  Node.prototype[method] = function _overrided() {\n    const state = this._baseState;\n    throw new Error(method + ' not implemented for encoding: ' + state.enc);\n  };\n});\n\n//\n// Public methods\n//\n\ntags.forEach(function(tag) {\n  Node.prototype[tag] = function _tagMethod() {\n    const state = this._baseState;\n    const args = Array.prototype.slice.call(arguments);\n\n    assert(state.tag === null);\n    state.tag = tag;\n\n    this._useArgs(args);\n\n    return this;\n  };\n});\n\nNode.prototype.use = function use(item) {\n  assert(item);\n  const state = this._baseState;\n\n  assert(state.use === null);\n  state.use = item;\n\n  return this;\n};\n\nNode.prototype.optional = function optional() {\n  const state = this._baseState;\n\n  state.optional = true;\n\n  return this;\n};\n\nNode.prototype.def = function def(val) {\n  const state = this._baseState;\n\n  assert(state['default'] === null);\n  state['default'] = val;\n  state.optional = true;\n\n  return this;\n};\n\nNode.prototype.explicit = function explicit(num) {\n  const state = this._baseState;\n\n  assert(state.explicit === null && state.implicit === null);\n  state.explicit = num;\n\n  return this;\n};\n\nNode.prototype.implicit = function implicit(num) {\n  const state = this._baseState;\n\n  assert(state.explicit === null && state.implicit === null);\n  state.implicit = num;\n\n  return this;\n};\n\nNode.prototype.obj = function obj() {\n  const state = this._baseState;\n  const args = Array.prototype.slice.call(arguments);\n\n  state.obj = true;\n\n  if (args.length !== 0)\n    this._useArgs(args);\n\n  return this;\n};\n\nNode.prototype.key = function key(newKey) {\n  const state = this._baseState;\n\n  assert(state.key === null);\n  state.key = newKey;\n\n  return this;\n};\n\nNode.prototype.any = function any() {\n  const state = this._baseState;\n\n  state.any = true;\n\n  return this;\n};\n\nNode.prototype.choice = function choice(obj) {\n  const state = this._baseState;\n\n  assert(state.choice === null);\n  state.choice = obj;\n  this._useArgs(Object.keys(obj).map(function(key) {\n    return obj[key];\n  }));\n\n  return this;\n};\n\nNode.prototype.contains = function contains(item) {\n  const state = this._baseState;\n\n  assert(state.use === null);\n  state.contains = item;\n\n  return this;\n};\n\n//\n// Decoding\n//\n\nNode.prototype._decode = function decode(input, options) {\n  const state = this._baseState;\n\n  // Decode root node\n  if (state.parent === null)\n    return input.wrapResult(state.children[0]._decode(input, options));\n\n  let result = state['default'];\n  let present = true;\n\n  let prevKey = null;\n  if (state.key !== null)\n    prevKey = input.enterKey(state.key);\n\n  // Check if tag is there\n  if (state.optional) {\n    let tag = null;\n    if (state.explicit !== null)\n      tag = state.explicit;\n    else if (state.implicit !== null)\n      tag = state.implicit;\n    else if (state.tag !== null)\n      tag = state.tag;\n\n    if (tag === null && !state.any) {\n      // Trial and Error\n      const save = input.save();\n      try {\n        if (state.choice === null)\n          this._decodeGeneric(state.tag, input, options);\n        else\n          this._decodeChoice(input, options);\n        present = true;\n      } catch (e) {\n        present = false;\n      }\n      input.restore(save);\n    } else {\n      present = this._peekTag(input, tag, state.any);\n\n      if (input.isError(present))\n        return present;\n    }\n  }\n\n  // Push object on stack\n  let prevObj;\n  if (state.obj && present)\n    prevObj = input.enterObject();\n\n  if (present) {\n    // Unwrap explicit values\n    if (state.explicit !== null) {\n      const explicit = this._decodeTag(input, state.explicit);\n      if (input.isError(explicit))\n        return explicit;\n      input = explicit;\n    }\n\n    const start = input.offset;\n\n    // Unwrap implicit and normal values\n    if (state.use === null && state.choice === null) {\n      let save;\n      if (state.any)\n        save = input.save();\n      const body = this._decodeTag(\n        input,\n        state.implicit !== null ? state.implicit : state.tag,\n        state.any\n      );\n      if (input.isError(body))\n        return body;\n\n      if (state.any)\n        result = input.raw(save);\n      else\n        input = body;\n    }\n\n    if (options && options.track && state.tag !== null)\n      options.track(input.path(), start, input.length, 'tagged');\n\n    if (options && options.track && state.tag !== null)\n      options.track(input.path(), input.offset, input.length, 'content');\n\n    // Select proper method for tag\n    if (state.any) {\n      // no-op\n    } else if (state.choice === null) {\n      result = this._decodeGeneric(state.tag, input, options);\n    } else {\n      result = this._decodeChoice(input, options);\n    }\n\n    if (input.isError(result))\n      return result;\n\n    // Decode children\n    if (!state.any && state.choice === null && state.children !== null) {\n      state.children.forEach(function decodeChildren(child) {\n        // NOTE: We are ignoring errors here, to let parser continue with other\n        // parts of encoded data\n        child._decode(input, options);\n      });\n    }\n\n    // Decode contained/encoded by schema, only in bit or octet strings\n    if (state.contains && (state.tag === 'octstr' || state.tag === 'bitstr')) {\n      const data = new DecoderBuffer(result);\n      result = this._getUse(state.contains, input._reporterState.obj)\n        ._decode(data, options);\n    }\n  }\n\n  // Pop object\n  if (state.obj && present)\n    result = input.leaveObject(prevObj);\n\n  // Set key\n  if (state.key !== null && (result !== null || present === true))\n    input.leaveKey(prevKey, state.key, result);\n  else if (prevKey !== null)\n    input.exitKey(prevKey);\n\n  return result;\n};\n\nNode.prototype._decodeGeneric = function decodeGeneric(tag, input, options) {\n  const state = this._baseState;\n\n  if (tag === 'seq' || tag === 'set')\n    return null;\n  if (tag === 'seqof' || tag === 'setof')\n    return this._decodeList(input, tag, state.args[0], options);\n  else if (/str$/.test(tag))\n    return this._decodeStr(input, tag, options);\n  else if (tag === 'objid' && state.args)\n    return this._decodeObjid(input, state.args[0], state.args[1], options);\n  else if (tag === 'objid')\n    return this._decodeObjid(input, null, null, options);\n  else if (tag === 'gentime' || tag === 'utctime')\n    return this._decodeTime(input, tag, options);\n  else if (tag === 'null_')\n    return this._decodeNull(input, options);\n  else if (tag === 'bool')\n    return this._decodeBool(input, options);\n  else if (tag === 'objDesc')\n    return this._decodeStr(input, tag, options);\n  else if (tag === 'int' || tag === 'enum')\n    return this._decodeInt(input, state.args && state.args[0], options);\n\n  if (state.use !== null) {\n    return this._getUse(state.use, input._reporterState.obj)\n      ._decode(input, options);\n  } else {\n    return input.error('unknown tag: ' + tag);\n  }\n};\n\nNode.prototype._getUse = function _getUse(entity, obj) {\n\n  const state = this._baseState;\n  // Create altered use decoder if implicit is set\n  state.useDecoder = this._use(entity, obj);\n  assert(state.useDecoder._baseState.parent === null);\n  state.useDecoder = state.useDecoder._baseState.children[0];\n  if (state.implicit !== state.useDecoder._baseState.implicit) {\n    state.useDecoder = state.useDecoder.clone();\n    state.useDecoder._baseState.implicit = state.implicit;\n  }\n  return state.useDecoder;\n};\n\nNode.prototype._decodeChoice = function decodeChoice(input, options) {\n  const state = this._baseState;\n  let result = null;\n  let match = false;\n\n  Object.keys(state.choice).some(function(key) {\n    const save = input.save();\n    const node = state.choice[key];\n    try {\n      const value = node._decode(input, options);\n      if (input.isError(value))\n        return false;\n\n      result = { type: key, value: value };\n      match = true;\n    } catch (e) {\n      input.restore(save);\n      return false;\n    }\n    return true;\n  }, this);\n\n  if (!match)\n    return input.error('Choice not matched');\n\n  return result;\n};\n\n//\n// Encoding\n//\n\nNode.prototype._createEncoderBuffer = function createEncoderBuffer(data) {\n  return new EncoderBuffer(data, this.reporter);\n};\n\nNode.prototype._encode = function encode(data, reporter, parent) {\n  const state = this._baseState;\n  if (state['default'] !== null && state['default'] === data)\n    return;\n\n  const result = this._encodeValue(data, reporter, parent);\n  if (result === undefined)\n    return;\n\n  if (this._skipDefault(result, reporter, parent))\n    return;\n\n  return result;\n};\n\nNode.prototype._encodeValue = function encode(data, reporter, parent) {\n  const state = this._baseState;\n\n  // Decode root node\n  if (state.parent === null)\n    return state.children[0]._encode(data, reporter || new Reporter());\n\n  let result = null;\n\n  // Set reporter to share it with a child class\n  this.reporter = reporter;\n\n  // Check if data is there\n  if (state.optional && data === undefined) {\n    if (state['default'] !== null)\n      data = state['default'];\n    else\n      return;\n  }\n\n  // Encode children first\n  let content = null;\n  let primitive = false;\n  if (state.any) {\n    // Anything that was given is translated to buffer\n    result = this._createEncoderBuffer(data);\n  } else if (state.choice) {\n    result = this._encodeChoice(data, reporter);\n  } else if (state.contains) {\n    content = this._getUse(state.contains, parent)._encode(data, reporter);\n    primitive = true;\n  } else if (state.children) {\n    content = state.children.map(function(child) {\n      if (child._baseState.tag === 'null_')\n        return child._encode(null, reporter, data);\n\n      if (child._baseState.key === null)\n        return reporter.error('Child should have a key');\n      const prevKey = reporter.enterKey(child._baseState.key);\n\n      if (typeof data !== 'object')\n        return reporter.error('Child expected, but input is not object');\n\n      const res = child._encode(data[child._baseState.key], reporter, data);\n      reporter.leaveKey(prevKey);\n\n      return res;\n    }, this).filter(function(child) {\n      return child;\n    });\n    content = this._createEncoderBuffer(content);\n  } else {\n    if (state.tag === 'seqof' || state.tag === 'setof') {\n      // TODO(indutny): this should be thrown on DSL level\n      if (!(state.args && state.args.length === 1))\n        return reporter.error('Too many args for : ' + state.tag);\n\n      if (!Array.isArray(data))\n        return reporter.error('seqof/setof, but data is not Array');\n\n      const child = this.clone();\n      child._baseState.implicit = null;\n      content = this._createEncoderBuffer(data.map(function(item) {\n        const state = this._baseState;\n\n        return this._getUse(state.args[0], data)._encode(item, reporter);\n      }, child));\n    } else if (state.use !== null) {\n      result = this._getUse(state.use, parent)._encode(data, reporter);\n    } else {\n      content = this._encodePrimitive(state.tag, data);\n      primitive = true;\n    }\n  }\n\n  // Encode data itself\n  if (!state.any && state.choice === null) {\n    const tag = state.implicit !== null ? state.implicit : state.tag;\n    const cls = state.implicit === null ? 'universal' : 'context';\n\n    if (tag === null) {\n      if (state.use === null)\n        reporter.error('Tag could be omitted only for .use()');\n    } else {\n      if (state.use === null)\n        result = this._encodeComposite(tag, primitive, cls, content);\n    }\n  }\n\n  // Wrap in explicit\n  if (state.explicit !== null)\n    result = this._encodeComposite(state.explicit, false, 'context', result);\n\n  return result;\n};\n\nNode.prototype._encodeChoice = function encodeChoice(data, reporter) {\n  const state = this._baseState;\n\n  const node = state.choice[data.type];\n  if (!node) {\n    assert(\n      false,\n      data.type + ' not found in ' +\n            JSON.stringify(Object.keys(state.choice)));\n  }\n  return node._encode(data.value, reporter);\n};\n\nNode.prototype._encodePrimitive = function encodePrimitive(tag, data) {\n  const state = this._baseState;\n\n  if (/str$/.test(tag))\n    return this._encodeStr(data, tag);\n  else if (tag === 'objid' && state.args)\n    return this._encodeObjid(data, state.reverseArgs[0], state.args[1]);\n  else if (tag === 'objid')\n    return this._encodeObjid(data, null, null);\n  else if (tag === 'gentime' || tag === 'utctime')\n    return this._encodeTime(data, tag);\n  else if (tag === 'null_')\n    return this._encodeNull();\n  else if (tag === 'int' || tag === 'enum')\n    return this._encodeInt(data, state.args && state.reverseArgs[0]);\n  else if (tag === 'bool')\n    return this._encodeBool(data);\n  else if (tag === 'objDesc')\n    return this._encodeStr(data, tag);\n  else\n    throw new Error('Unsupported tag: ' + tag);\n};\n\nNode.prototype._isNumstr = function isNumstr(str) {\n  return /^[0-9 ]*$/.test(str);\n};\n\nNode.prototype._isPrintstr = function isPrintstr(str) {\n  return /^[A-Za-z0-9 '()+,-./:=?]*$/.test(str);\n};\n",
    "'use strict';\n\n// Helper\nfunction reverse(map) {\n  const res = {};\n\n  Object.keys(map).forEach(function(key) {\n    // Convert key to integer if it is stringified\n    if ((key | 0) == key)\n      key = key | 0;\n\n    const value = map[key];\n    res[value] = key;\n  });\n\n  return res;\n}\n\nexports.tagClass = {\n  0: 'universal',\n  1: 'application',\n  2: 'context',\n  3: 'private'\n};\nexports.tagClassByName = reverse(exports.tagClass);\n\nexports.tag = {\n  0x00: 'end',\n  0x01: 'bool',\n  0x02: 'int',\n  0x03: 'bitstr',\n  0x04: 'octstr',\n  0x05: 'null_',\n  0x06: 'objid',\n  0x07: 'objDesc',\n  0x08: 'external',\n  0x09: 'real',\n  0x0a: 'enum',\n  0x0b: 'embed',\n  0x0c: 'utf8str',\n  0x0d: 'relativeOid',\n  0x10: 'seq',\n  0x11: 'set',\n  0x12: 'numstr',\n  0x13: 'printstr',\n  0x14: 't61str',\n  0x15: 'videostr',\n  0x16: 'ia5str',\n  0x17: 'utctime',\n  0x18: 'gentime',\n  0x19: 'graphstr',\n  0x1a: 'iso646str',\n  0x1b: 'genstr',\n  0x1c: 'unistr',\n  0x1d: 'charstr',\n  0x1e: 'bmpstr'\n};\nexports.tagByName = reverse(exports.tag);\n",
    "'use strict';\n\nconst inherits = require('inherits');\nconst Buffer = require('safer-buffer').Buffer;\nconst Node = require('../base/node');\n\n// Import DER constants\nconst der = require('../constants/der');\n\nfunction DEREncoder(entity) {\n  this.enc = 'der';\n  this.name = entity.name;\n  this.entity = entity;\n\n  // Construct base tree\n  this.tree = new DERNode();\n  this.tree._init(entity.body);\n}\nmodule.exports = DEREncoder;\n\nDEREncoder.prototype.encode = function encode(data, reporter) {\n  return this.tree._encode(data, reporter).join();\n};\n\n// Tree methods\n\nfunction DERNode(parent) {\n  Node.call(this, 'der', parent);\n}\ninherits(DERNode, Node);\n\nDERNode.prototype._encodeComposite = function encodeComposite(tag,\n  primitive,\n  cls,\n  content) {\n  const encodedTag = encodeTag(tag, primitive, cls, this.reporter);\n\n  // Short form\n  if (content.length < 0x80) {\n    const header = Buffer.alloc(2);\n    header[0] = encodedTag;\n    header[1] = content.length;\n    return this._createEncoderBuffer([ header, content ]);\n  }\n\n  // Long form\n  // Count octets required to store length\n  let lenOctets = 1;\n  for (let i = content.length; i >= 0x100; i >>= 8)\n    lenOctets++;\n\n  const header = Buffer.alloc(1 + 1 + lenOctets);\n  header[0] = encodedTag;\n  header[1] = 0x80 | lenOctets;\n\n  for (let i = 1 + lenOctets, j = content.length; j > 0; i--, j >>= 8)\n    header[i] = j & 0xff;\n\n  return this._createEncoderBuffer([ header, content ]);\n};\n\nDERNode.prototype._encodeStr = function encodeStr(str, tag) {\n  if (tag === 'bitstr') {\n    return this._createEncoderBuffer([ str.unused | 0, str.data ]);\n  } else if (tag === 'bmpstr') {\n    const buf = Buffer.alloc(str.length * 2);\n    for (let i = 0; i < str.length; i++) {\n      buf.writeUInt16BE(str.charCodeAt(i), i * 2);\n    }\n    return this._createEncoderBuffer(buf);\n  } else if (tag === 'numstr') {\n    if (!this._isNumstr(str)) {\n      return this.reporter.error('Encoding of string type: numstr supports ' +\n                                 'only digits and space');\n    }\n    return this._createEncoderBuffer(str);\n  } else if (tag === 'printstr') {\n    if (!this._isPrintstr(str)) {\n      return this.reporter.error('Encoding of string type: printstr supports ' +\n                                 'only latin upper and lower case letters, ' +\n                                 'digits, space, apostrophe, left and rigth ' +\n                                 'parenthesis, plus sign, comma, hyphen, ' +\n                                 'dot, slash, colon, equal sign, ' +\n                                 'question mark');\n    }\n    return this._createEncoderBuffer(str);\n  } else if (/str$/.test(tag)) {\n    return this._createEncoderBuffer(str);\n  } else if (tag === 'objDesc') {\n    return this._createEncoderBuffer(str);\n  } else {\n    return this.reporter.error('Encoding of string type: ' + tag +\n                               ' unsupported');\n  }\n};\n\nDERNode.prototype._encodeObjid = function encodeObjid(id, values, relative) {\n  if (typeof id === 'string') {\n    if (!values)\n      return this.reporter.error('string objid given, but no values map found');\n    if (!values.hasOwnProperty(id))\n      return this.reporter.error('objid not found in values map');\n    id = values[id].split(/[\\s.]+/g);\n    for (let i = 0; i < id.length; i++)\n      id[i] |= 0;\n  } else if (Array.isArray(id)) {\n    id = id.slice();\n    for (let i = 0; i < id.length; i++)\n      id[i] |= 0;\n  }\n\n  if (!Array.isArray(id)) {\n    return this.reporter.error('objid() should be either array or string, ' +\n                               'got: ' + JSON.stringify(id));\n  }\n\n  if (!relative) {\n    if (id[1] >= 40)\n      return this.reporter.error('Second objid identifier OOB');\n    id.splice(0, 2, id[0] * 40 + id[1]);\n  }\n\n  // Count number of octets\n  let size = 0;\n  for (let i = 0; i < id.length; i++) {\n    let ident = id[i];\n    for (size++; ident >= 0x80; ident >>= 7)\n      size++;\n  }\n\n  const objid = Buffer.alloc(size);\n  let offset = objid.length - 1;\n  for (let i = id.length - 1; i >= 0; i--) {\n    let ident = id[i];\n    objid[offset--] = ident & 0x7f;\n    while ((ident >>= 7) > 0)\n      objid[offset--] = 0x80 | (ident & 0x7f);\n  }\n\n  return this._createEncoderBuffer(objid);\n};\n\nfunction two(num) {\n  if (num < 10)\n    return '0' + num;\n  else\n    return num;\n}\n\nDERNode.prototype._encodeTime = function encodeTime(time, tag) {\n  let str;\n  const date = new Date(time);\n\n  if (tag === 'gentime') {\n    str = [\n      two(date.getUTCFullYear()),\n      two(date.getUTCMonth() + 1),\n      two(date.getUTCDate()),\n      two(date.getUTCHours()),\n      two(date.getUTCMinutes()),\n      two(date.getUTCSeconds()),\n      'Z'\n    ].join('');\n  } else if (tag === 'utctime') {\n    str = [\n      two(date.getUTCFullYear() % 100),\n      two(date.getUTCMonth() + 1),\n      two(date.getUTCDate()),\n      two(date.getUTCHours()),\n      two(date.getUTCMinutes()),\n      two(date.getUTCSeconds()),\n      'Z'\n    ].join('');\n  } else {\n    this.reporter.error('Encoding ' + tag + ' time is not supported yet');\n  }\n\n  return this._encodeStr(str, 'octstr');\n};\n\nDERNode.prototype._encodeNull = function encodeNull() {\n  return this._createEncoderBuffer('');\n};\n\nDERNode.prototype._encodeInt = function encodeInt(num, values) {\n  if (typeof num === 'string') {\n    if (!values)\n      return this.reporter.error('String int or enum given, but no values map');\n    if (!values.hasOwnProperty(num)) {\n      return this.reporter.error('Values map doesn\\'t contain: ' +\n                                 JSON.stringify(num));\n    }\n    num = values[num];\n  }\n\n  // Bignum, assume big endian\n  if (typeof num !== 'number' && !Buffer.isBuffer(num)) {\n    const numArray = num.toArray();\n    if (!num.sign && numArray[0] & 0x80) {\n      numArray.unshift(0);\n    }\n    num = Buffer.from(numArray);\n  }\n\n  if (Buffer.isBuffer(num)) {\n    let size = num.length;\n    if (num.length === 0)\n      size++;\n\n    const out = Buffer.alloc(size);\n    num.copy(out);\n    if (num.length === 0)\n      out[0] = 0;\n    return this._createEncoderBuffer(out);\n  }\n\n  if (num < 0x80)\n    return this._createEncoderBuffer(num);\n\n  if (num < 0x100)\n    return this._createEncoderBuffer([0, num]);\n\n  let size = 1;\n  for (let i = num; i >= 0x100; i >>= 8)\n    size++;\n\n  const out = new Array(size);\n  for (let i = out.length - 1; i >= 0; i--) {\n    out[i] = num & 0xff;\n    num >>= 8;\n  }\n  if(out[0] & 0x80) {\n    out.unshift(0);\n  }\n\n  return this._createEncoderBuffer(Buffer.from(out));\n};\n\nDERNode.prototype._encodeBool = function encodeBool(value) {\n  return this._createEncoderBuffer(value ? 0xff : 0);\n};\n\nDERNode.prototype._use = function use(entity, obj) {\n  if (typeof entity === 'function')\n    entity = entity(obj);\n  return entity._getEncoder('der').tree;\n};\n\nDERNode.prototype._skipDefault = function skipDefault(dataBuffer, reporter, parent) {\n  const state = this._baseState;\n  let i;\n  if (state['default'] === null)\n    return false;\n\n  const data = dataBuffer.join();\n  if (state.defaultBuffer === undefined)\n    state.defaultBuffer = this._encodeValue(state['default'], reporter, parent).join();\n\n  if (data.length !== state.defaultBuffer.length)\n    return false;\n\n  for (i=0; i < data.length; i++)\n    if (data[i] !== state.defaultBuffer[i])\n      return false;\n\n  return true;\n};\n\n// Utility methods\n\nfunction encodeTag(tag, primitive, cls, reporter) {\n  let res;\n\n  if (tag === 'seqof')\n    tag = 'seq';\n  else if (tag === 'setof')\n    tag = 'set';\n\n  if (der.tagByName.hasOwnProperty(tag))\n    res = der.tagByName[tag];\n  else if (typeof tag === 'number' && (tag | 0) === tag)\n    res = tag;\n  else\n    return reporter.error('Unknown tag: ' + tag);\n\n  if (res >= 0x1f)\n    return reporter.error('Multi-octet tag encoding unsupported');\n\n  if (!primitive)\n    res |= 0x20;\n\n  res |= (der.tagClassByName[cls || 'universal'] << 6);\n\n  return res;\n}\n",
    "'use strict';\n\nconst inherits = require('inherits');\n\nconst DEREncoder = require('./der');\n\nfunction PEMEncoder(entity) {\n  DEREncoder.call(this, entity);\n  this.enc = 'pem';\n}\ninherits(PEMEncoder, DEREncoder);\nmodule.exports = PEMEncoder;\n\nPEMEncoder.prototype.encode = function encode(data, options) {\n  const buf = DEREncoder.prototype.encode.call(this, data);\n\n  const p = buf.toString('base64');\n  const out = [ '-----BEGIN ' + options.label + '-----' ];\n  for (let i = 0; i < p.length; i += 64)\n    out.push(p.slice(i, i + 64));\n  out.push('-----END ' + options.label + '-----');\n  return out.join('\\n');\n};\n",
    "'use strict';\n\nconst encoders = exports;\n\nencoders.der = require('./der');\nencoders.pem = require('./pem');\n",
    "'use strict';\n\nconst inherits = require('inherits');\n\nconst bignum = require('bn.js');\nconst DecoderBuffer = require('../base/buffer').DecoderBuffer;\nconst Node = require('../base/node');\n\n// Import DER constants\nconst der = require('../constants/der');\n\nfunction DERDecoder(entity) {\n  this.enc = 'der';\n  this.name = entity.name;\n  this.entity = entity;\n\n  // Construct base tree\n  this.tree = new DERNode();\n  this.tree._init(entity.body);\n}\nmodule.exports = DERDecoder;\n\nDERDecoder.prototype.decode = function decode(data, options) {\n  if (!DecoderBuffer.isDecoderBuffer(data)) {\n    data = new DecoderBuffer(data, options);\n  }\n\n  return this.tree._decode(data, options);\n};\n\n// Tree methods\n\nfunction DERNode(parent) {\n  Node.call(this, 'der', parent);\n}\ninherits(DERNode, Node);\n\nDERNode.prototype._peekTag = function peekTag(buffer, tag, any) {\n  if (buffer.isEmpty())\n    return false;\n\n  const state = buffer.save();\n  const decodedTag = derDecodeTag(buffer, 'Failed to peek tag: \"' + tag + '\"');\n  if (buffer.isError(decodedTag))\n    return decodedTag;\n\n  buffer.restore(state);\n\n  return decodedTag.tag === tag || decodedTag.tagStr === tag ||\n    (decodedTag.tagStr + 'of') === tag || any;\n};\n\nDERNode.prototype._decodeTag = function decodeTag(buffer, tag, any) {\n  const decodedTag = derDecodeTag(buffer,\n    'Failed to decode tag of \"' + tag + '\"');\n  if (buffer.isError(decodedTag))\n    return decodedTag;\n\n  let len = derDecodeLen(buffer,\n    decodedTag.primitive,\n    'Failed to get length of \"' + tag + '\"');\n\n  // Failure\n  if (buffer.isError(len))\n    return len;\n\n  if (!any &&\n      decodedTag.tag !== tag &&\n      decodedTag.tagStr !== tag &&\n      decodedTag.tagStr + 'of' !== tag) {\n    return buffer.error('Failed to match tag: \"' + tag + '\"');\n  }\n\n  if (decodedTag.primitive || len !== null)\n    return buffer.skip(len, 'Failed to match body of: \"' + tag + '\"');\n\n  // Indefinite length... find END tag\n  const state = buffer.save();\n  const res = this._skipUntilEnd(\n    buffer,\n    'Failed to skip indefinite length body: \"' + this.tag + '\"');\n  if (buffer.isError(res))\n    return res;\n\n  len = buffer.offset - state.offset;\n  buffer.restore(state);\n  return buffer.skip(len, 'Failed to match body of: \"' + tag + '\"');\n};\n\nDERNode.prototype._skipUntilEnd = function skipUntilEnd(buffer, fail) {\n  for (;;) {\n    const tag = derDecodeTag(buffer, fail);\n    if (buffer.isError(tag))\n      return tag;\n    const len = derDecodeLen(buffer, tag.primitive, fail);\n    if (buffer.isError(len))\n      return len;\n\n    let res;\n    if (tag.primitive || len !== null)\n      res = buffer.skip(len);\n    else\n      res = this._skipUntilEnd(buffer, fail);\n\n    // Failure\n    if (buffer.isError(res))\n      return res;\n\n    if (tag.tagStr === 'end')\n      break;\n  }\n};\n\nDERNode.prototype._decodeList = function decodeList(buffer, tag, decoder,\n  options) {\n  const result = [];\n  while (!buffer.isEmpty()) {\n    const possibleEnd = this._peekTag(buffer, 'end');\n    if (buffer.isError(possibleEnd))\n      return possibleEnd;\n\n    const res = decoder.decode(buffer, 'der', options);\n    if (buffer.isError(res) && possibleEnd)\n      break;\n    result.push(res);\n  }\n  return result;\n};\n\nDERNode.prototype._decodeStr = function decodeStr(buffer, tag) {\n  if (tag === 'bitstr') {\n    const unused = buffer.readUInt8();\n    if (buffer.isError(unused))\n      return unused;\n    return { unused: unused, data: buffer.raw() };\n  } else if (tag === 'bmpstr') {\n    const raw = buffer.raw();\n    if (raw.length % 2 === 1)\n      return buffer.error('Decoding of string type: bmpstr length mismatch');\n\n    let str = '';\n    for (let i = 0; i < raw.length / 2; i++) {\n      str += String.fromCharCode(raw.readUInt16BE(i * 2));\n    }\n    return str;\n  } else if (tag === 'numstr') {\n    const numstr = buffer.raw().toString('ascii');\n    if (!this._isNumstr(numstr)) {\n      return buffer.error('Decoding of string type: ' +\n                          'numstr unsupported characters');\n    }\n    return numstr;\n  } else if (tag === 'octstr') {\n    return buffer.raw();\n  } else if (tag === 'objDesc') {\n    return buffer.raw();\n  } else if (tag === 'printstr') {\n    const printstr = buffer.raw().toString('ascii');\n    if (!this._isPrintstr(printstr)) {\n      return buffer.error('Decoding of string type: ' +\n                          'printstr unsupported characters');\n    }\n    return printstr;\n  } else if (/str$/.test(tag)) {\n    return buffer.raw().toString();\n  } else {\n    return buffer.error('Decoding of string type: ' + tag + ' unsupported');\n  }\n};\n\nDERNode.prototype._decodeObjid = function decodeObjid(buffer, values, relative) {\n  let result;\n  const identifiers = [];\n  let ident = 0;\n  let subident = 0;\n  while (!buffer.isEmpty()) {\n    subident = buffer.readUInt8();\n    ident <<= 7;\n    ident |= subident & 0x7f;\n    if ((subident & 0x80) === 0) {\n      identifiers.push(ident);\n      ident = 0;\n    }\n  }\n  if (subident & 0x80)\n    identifiers.push(ident);\n\n  const first = (identifiers[0] / 40) | 0;\n  const second = identifiers[0] % 40;\n\n  if (relative)\n    result = identifiers;\n  else\n    result = [first, second].concat(identifiers.slice(1));\n\n  if (values) {\n    let tmp = values[result.join(' ')];\n    if (tmp === undefined)\n      tmp = values[result.join('.')];\n    if (tmp !== undefined)\n      result = tmp;\n  }\n\n  return result;\n};\n\nDERNode.prototype._decodeTime = function decodeTime(buffer, tag) {\n  const str = buffer.raw().toString();\n\n  let year;\n  let mon;\n  let day;\n  let hour;\n  let min;\n  let sec;\n  if (tag === 'gentime') {\n    year = str.slice(0, 4) | 0;\n    mon = str.slice(4, 6) | 0;\n    day = str.slice(6, 8) | 0;\n    hour = str.slice(8, 10) | 0;\n    min = str.slice(10, 12) | 0;\n    sec = str.slice(12, 14) | 0;\n  } else if (tag === 'utctime') {\n    year = str.slice(0, 2) | 0;\n    mon = str.slice(2, 4) | 0;\n    day = str.slice(4, 6) | 0;\n    hour = str.slice(6, 8) | 0;\n    min = str.slice(8, 10) | 0;\n    sec = str.slice(10, 12) | 0;\n    if (year < 70)\n      year = 2000 + year;\n    else\n      year = 1900 + year;\n  } else {\n    return buffer.error('Decoding ' + tag + ' time is not supported yet');\n  }\n\n  return Date.UTC(year, mon - 1, day, hour, min, sec, 0);\n};\n\nDERNode.prototype._decodeNull = function decodeNull() {\n  return null;\n};\n\nDERNode.prototype._decodeBool = function decodeBool(buffer) {\n  const res = buffer.readUInt8();\n  if (buffer.isError(res))\n    return res;\n  else\n    return res !== 0;\n};\n\nDERNode.prototype._decodeInt = function decodeInt(buffer, values) {\n  // Bigint, return as it is (assume big endian)\n  const raw = buffer.raw();\n  let res = new bignum(raw);\n\n  if (values)\n    res = values[res.toString(10)] || res;\n\n  return res;\n};\n\nDERNode.prototype._use = function use(entity, obj) {\n  if (typeof entity === 'function')\n    entity = entity(obj);\n  return entity._getDecoder('der').tree;\n};\n\n// Utility methods\n\nfunction derDecodeTag(buf, fail) {\n  let tag = buf.readUInt8(fail);\n  if (buf.isError(tag))\n    return tag;\n\n  const cls = der.tagClass[tag >> 6];\n  const primitive = (tag & 0x20) === 0;\n\n  // Multi-octet tag - load\n  if ((tag & 0x1f) === 0x1f) {\n    let oct = tag;\n    tag = 0;\n    while ((oct & 0x80) === 0x80) {\n      oct = buf.readUInt8(fail);\n      if (buf.isError(oct))\n        return oct;\n\n      tag <<= 7;\n      tag |= oct & 0x7f;\n    }\n  } else {\n    tag &= 0x1f;\n  }\n  const tagStr = der.tag[tag];\n\n  return {\n    cls: cls,\n    primitive: primitive,\n    tag: tag,\n    tagStr: tagStr\n  };\n}\n\nfunction derDecodeLen(buf, primitive, fail) {\n  let len = buf.readUInt8(fail);\n  if (buf.isError(len))\n    return len;\n\n  // Indefinite form\n  if (!primitive && len === 0x80)\n    return null;\n\n  // Definite form\n  if ((len & 0x80) === 0) {\n    // Short form\n    return len;\n  }\n\n  // Long form\n  const num = len & 0x7f;\n  if (num > 4)\n    return buf.error('length octect is too long');\n\n  len = 0;\n  for (let i = 0; i < num; i++) {\n    len <<= 8;\n    const j = buf.readUInt8(fail);\n    if (buf.isError(j))\n      return j;\n    len |= j;\n  }\n\n  return len;\n}\n",
    "'use strict';\n\nconst inherits = require('inherits');\nconst Buffer = require('safer-buffer').Buffer;\n\nconst DERDecoder = require('./der');\n\nfunction PEMDecoder(entity) {\n  DERDecoder.call(this, entity);\n  this.enc = 'pem';\n}\ninherits(PEMDecoder, DERDecoder);\nmodule.exports = PEMDecoder;\n\nPEMDecoder.prototype.decode = function decode(data, options) {\n  const lines = data.toString().split(/[\\r\\n]+/g);\n\n  const label = options.label.toUpperCase();\n\n  const re = /^-----(BEGIN|END) ([^-]+)-----$/;\n  let start = -1;\n  let end = -1;\n  for (let i = 0; i < lines.length; i++) {\n    const match = lines[i].match(re);\n    if (match === null)\n      continue;\n\n    if (match[2] !== label)\n      continue;\n\n    if (start === -1) {\n      if (match[1] !== 'BEGIN')\n        break;\n      start = i;\n    } else {\n      if (match[1] !== 'END')\n        break;\n      end = i;\n      break;\n    }\n  }\n  if (start === -1 || end === -1)\n    throw new Error('PEM section not found for: ' + label);\n\n  const base64 = lines.slice(start + 1, end).join('');\n  // Remove excessive symbols\n  base64.replace(/[^a-z0-9+/=]+/gi, '');\n\n  const input = Buffer.from(base64, 'base64');\n  return DERDecoder.prototype.decode.call(this, input, options);\n};\n",
    "'use strict';\n\nconst decoders = exports;\n\ndecoders.der = require('./der');\ndecoders.pem = require('./pem');\n",
    "'use strict';\n\nconst encoders = require('./encoders');\nconst decoders = require('./decoders');\nconst inherits = require('inherits');\n\nconst api = exports;\n\napi.define = function define(name, body) {\n  return new Entity(name, body);\n};\n\nfunction Entity(name, body) {\n  this.name = name;\n  this.body = body;\n\n  this.decoders = {};\n  this.encoders = {};\n}\n\nEntity.prototype._createNamed = function createNamed(Base) {\n  const name = this.name;\n\n  function Generated(entity) {\n    this._initNamed(entity, name);\n  }\n  inherits(Generated, Base);\n  Generated.prototype._initNamed = function _initNamed(entity, name) {\n    Base.call(this, entity, name);\n  };\n\n  return new Generated(this);\n};\n\nEntity.prototype._getDecoder = function _getDecoder(enc) {\n  enc = enc || 'der';\n  // Lazily create decoder\n  if (!this.decoders.hasOwnProperty(enc))\n    this.decoders[enc] = this._createNamed(decoders[enc]);\n  return this.decoders[enc];\n};\n\nEntity.prototype.decode = function decode(data, enc, options) {\n  return this._getDecoder(enc).decode(data, options);\n};\n\nEntity.prototype._getEncoder = function _getEncoder(enc) {\n  enc = enc || 'der';\n  // Lazily create encoder\n  if (!this.encoders.hasOwnProperty(enc))\n    this.encoders[enc] = this._createNamed(encoders[enc]);\n  return this.encoders[enc];\n};\n\nEntity.prototype.encode = function encode(data, enc, /* internal */ reporter) {\n  return this._getEncoder(enc).encode(data, reporter);\n};\n",
    "'use strict';\n\nconst base = exports;\n\nbase.Reporter = require('./reporter').Reporter;\nbase.DecoderBuffer = require('./buffer').DecoderBuffer;\nbase.EncoderBuffer = require('./buffer').EncoderBuffer;\nbase.Node = require('./node');\n",
    "'use strict';\n\nconst constants = exports;\n\n// Helper\nconstants._reverse = function reverse(map) {\n  const res = {};\n\n  Object.keys(map).forEach(function(key) {\n    // Convert key to integer if it is stringified\n    if ((key | 0) == key)\n      key = key | 0;\n\n    const value = map[key];\n    res[value] = key;\n  });\n\n  return res;\n};\n\nconstants.der = require('./der');\n",
    "'use strict';\n\nconst asn1 = exports;\n\nasn1.bignum = require('bn.js');\n\nasn1.define = require('./asn1/api').define;\nasn1.base = require('./asn1/base');\nasn1.constants = require('./asn1/constants');\nasn1.decoders = require('./asn1/decoders');\nasn1.encoders = require('./asn1/encoders');\n",
    "'use strict';\n\nvar utils = exports;\n\nfunction toArray(msg, enc) {\n  if (Array.isArray(msg))\n    return msg.slice();\n  if (!msg)\n    return [];\n  var res = [];\n  if (typeof msg !== 'string') {\n    for (var i = 0; i < msg.length; i++)\n      res[i] = msg[i] | 0;\n    return res;\n  }\n  if (enc === 'hex') {\n    msg = msg.replace(/[^a-z0-9]+/ig, '');\n    if (msg.length % 2 !== 0)\n      msg = '0' + msg;\n    for (var i = 0; i < msg.length; i += 2)\n      res.push(parseInt(msg[i] + msg[i + 1], 16));\n  } else {\n    for (var i = 0; i < msg.length; i++) {\n      var c = msg.charCodeAt(i);\n      var hi = c >> 8;\n      var lo = c & 0xff;\n      if (hi)\n        res.push(hi, lo);\n      else\n        res.push(lo);\n    }\n  }\n  return res;\n}\nutils.toArray = toArray;\n\nfunction zero2(word) {\n  if (word.length === 1)\n    return '0' + word;\n  else\n    return word;\n}\nutils.zero2 = zero2;\n\nfunction toHex(msg) {\n  var res = '';\n  for (var i = 0; i < msg.length; i++)\n    res += zero2(msg[i].toString(16));\n  return res;\n}\nutils.toHex = toHex;\n\nutils.encode = function encode(arr, enc) {\n  if (enc === 'hex')\n    return toHex(arr);\n  else\n    return arr;\n};\n",
    "'use strict';\n\nvar utils = exports;\nvar BN = require('bn.js');\nvar minAssert = require('minimalistic-assert');\nvar minUtils = require('minimalistic-crypto-utils');\n\nutils.assert = minAssert;\nutils.toArray = minUtils.toArray;\nutils.zero2 = minUtils.zero2;\nutils.toHex = minUtils.toHex;\nutils.encode = minUtils.encode;\n\n// Represent num in a w-NAF form\nfunction getNAF(num, w, bits) {\n  var naf = new Array(Math.max(num.bitLength(), bits) + 1);\n  var i;\n  for (i = 0; i < naf.length; i += 1) {\n    naf[i] = 0;\n  }\n\n  var ws = 1 << (w + 1);\n  var k = num.clone();\n\n  for (i = 0; i < naf.length; i++) {\n    var z;\n    var mod = k.andln(ws - 1);\n    if (k.isOdd()) {\n      if (mod > (ws >> 1) - 1)\n        z = (ws >> 1) - mod;\n      else\n        z = mod;\n      k.isubn(z);\n    } else {\n      z = 0;\n    }\n\n    naf[i] = z;\n    k.iushrn(1);\n  }\n\n  return naf;\n}\nutils.getNAF = getNAF;\n\n// Represent k1, k2 in a Joint Sparse Form\nfunction getJSF(k1, k2) {\n  var jsf = [\n    [],\n    [],\n  ];\n\n  k1 = k1.clone();\n  k2 = k2.clone();\n  var d1 = 0;\n  var d2 = 0;\n  var m8;\n  while (k1.cmpn(-d1) > 0 || k2.cmpn(-d2) > 0) {\n    // First phase\n    var m14 = (k1.andln(3) + d1) & 3;\n    var m24 = (k2.andln(3) + d2) & 3;\n    if (m14 === 3)\n      m14 = -1;\n    if (m24 === 3)\n      m24 = -1;\n    var u1;\n    if ((m14 & 1) === 0) {\n      u1 = 0;\n    } else {\n      m8 = (k1.andln(7) + d1) & 7;\n      if ((m8 === 3 || m8 === 5) && m24 === 2)\n        u1 = -m14;\n      else\n        u1 = m14;\n    }\n    jsf[0].push(u1);\n\n    var u2;\n    if ((m24 & 1) === 0) {\n      u2 = 0;\n    } else {\n      m8 = (k2.andln(7) + d2) & 7;\n      if ((m8 === 3 || m8 === 5) && m14 === 2)\n        u2 = -m24;\n      else\n        u2 = m24;\n    }\n    jsf[1].push(u2);\n\n    // Second phase\n    if (2 * d1 === u1 + 1)\n      d1 = 1 - d1;\n    if (2 * d2 === u2 + 1)\n      d2 = 1 - d2;\n    k1.iushrn(1);\n    k2.iushrn(1);\n  }\n\n  return jsf;\n}\nutils.getJSF = getJSF;\n\nfunction cachedProperty(obj, name, computer) {\n  var key = '_' + name;\n  obj.prototype[name] = function cachedProperty() {\n    return this[key] !== undefined ? this[key] :\n      this[key] = computer.call(this);\n  };\n}\nutils.cachedProperty = cachedProperty;\n\nfunction parseBytes(bytes) {\n  return typeof bytes === 'string' ? utils.toArray(bytes, 'hex') :\n    bytes;\n}\nutils.parseBytes = parseBytes;\n\nfunction intFromLE(bytes) {\n  return new BN(bytes, 'hex', 'le');\n}\nutils.intFromLE = intFromLE;\n\n",
    "var r;\n\nmodule.exports = function rand(len) {\n  if (!r)\n    r = new Rand(null);\n\n  return r.generate(len);\n};\n\nfunction Rand(rand) {\n  this.rand = rand;\n}\nmodule.exports.Rand = Rand;\n\nRand.prototype.generate = function generate(len) {\n  return this._rand(len);\n};\n\n// Emulate crypto API using randy\nRand.prototype._rand = function _rand(n) {\n  if (this.rand.getBytes)\n    return this.rand.getBytes(n);\n\n  var res = new Uint8Array(n);\n  for (var i = 0; i < res.length; i++)\n    res[i] = this.rand.getByte();\n  return res;\n};\n\nif (typeof self === 'object') {\n  if (self.crypto && self.crypto.getRandomValues) {\n    // Modern browsers\n    Rand.prototype._rand = function _rand(n) {\n      var arr = new Uint8Array(n);\n      self.crypto.getRandomValues(arr);\n      return arr;\n    };\n  } else if (self.msCrypto && self.msCrypto.getRandomValues) {\n    // IE\n    Rand.prototype._rand = function _rand(n) {\n      var arr = new Uint8Array(n);\n      self.msCrypto.getRandomValues(arr);\n      return arr;\n    };\n\n  // Safari's WebWorkers do not have `crypto`\n  } else if (typeof window === 'object') {\n    // Old junk\n    Rand.prototype._rand = function() {\n      throw new Error('Not implemented yet');\n    };\n  }\n} else {\n  // Node.js or Web worker with no crypto support\n  try {\n    var crypto = require('crypto');\n    if (typeof crypto.randomBytes !== 'function')\n      throw new Error('Not supported');\n\n    Rand.prototype._rand = function _rand(n) {\n      return crypto.randomBytes(n);\n    };\n  } catch (e) {\n  }\n}\n",
    "'use strict';\n\nvar BN = require('bn.js');\nvar utils = require('../utils');\nvar getNAF = utils.getNAF;\nvar getJSF = utils.getJSF;\nvar assert = utils.assert;\n\nfunction BaseCurve(type, conf) {\n  this.type = type;\n  this.p = new BN(conf.p, 16);\n\n  // Use Montgomery, when there is no fast reduction for the prime\n  this.red = conf.prime ? BN.red(conf.prime) : BN.mont(this.p);\n\n  // Useful for many curves\n  this.zero = new BN(0).toRed(this.red);\n  this.one = new BN(1).toRed(this.red);\n  this.two = new BN(2).toRed(this.red);\n\n  // Curve configuration, optional\n  this.n = conf.n && new BN(conf.n, 16);\n  this.g = conf.g && this.pointFromJSON(conf.g, conf.gRed);\n\n  // Temporary arrays\n  this._wnafT1 = new Array(4);\n  this._wnafT2 = new Array(4);\n  this._wnafT3 = new Array(4);\n  this._wnafT4 = new Array(4);\n\n  this._bitLength = this.n ? this.n.bitLength() : 0;\n\n  // Generalized Greg Maxwell's trick\n  var adjustCount = this.n && this.p.div(this.n);\n  if (!adjustCount || adjustCount.cmpn(100) > 0) {\n    this.redN = null;\n  } else {\n    this._maxwellTrick = true;\n    this.redN = this.n.toRed(this.red);\n  }\n}\nmodule.exports = BaseCurve;\n\nBaseCurve.prototype.point = function point() {\n  throw new Error('Not implemented');\n};\n\nBaseCurve.prototype.validate = function validate() {\n  throw new Error('Not implemented');\n};\n\nBaseCurve.prototype._fixedNafMul = function _fixedNafMul(p, k) {\n  assert(p.precomputed);\n  var doubles = p._getDoubles();\n\n  var naf = getNAF(k, 1, this._bitLength);\n  var I = (1 << (doubles.step + 1)) - (doubles.step % 2 === 0 ? 2 : 1);\n  I /= 3;\n\n  // Translate into more windowed form\n  var repr = [];\n  var j;\n  var nafW;\n  for (j = 0; j < naf.length; j += doubles.step) {\n    nafW = 0;\n    for (var l = j + doubles.step - 1; l >= j; l--)\n      nafW = (nafW << 1) + naf[l];\n    repr.push(nafW);\n  }\n\n  var a = this.jpoint(null, null, null);\n  var b = this.jpoint(null, null, null);\n  for (var i = I; i > 0; i--) {\n    for (j = 0; j < repr.length; j++) {\n      nafW = repr[j];\n      if (nafW === i)\n        b = b.mixedAdd(doubles.points[j]);\n      else if (nafW === -i)\n        b = b.mixedAdd(doubles.points[j].neg());\n    }\n    a = a.add(b);\n  }\n  return a.toP();\n};\n\nBaseCurve.prototype._wnafMul = function _wnafMul(p, k) {\n  var w = 4;\n\n  // Precompute window\n  var nafPoints = p._getNAFPoints(w);\n  w = nafPoints.wnd;\n  var wnd = nafPoints.points;\n\n  // Get NAF form\n  var naf = getNAF(k, w, this._bitLength);\n\n  // Add `this`*(N+1) for every w-NAF index\n  var acc = this.jpoint(null, null, null);\n  for (var i = naf.length - 1; i >= 0; i--) {\n    // Count zeroes\n    for (var l = 0; i >= 0 && naf[i] === 0; i--)\n      l++;\n    if (i >= 0)\n      l++;\n    acc = acc.dblp(l);\n\n    if (i < 0)\n      break;\n    var z = naf[i];\n    assert(z !== 0);\n    if (p.type === 'affine') {\n      // J +- P\n      if (z > 0)\n        acc = acc.mixedAdd(wnd[(z - 1) >> 1]);\n      else\n        acc = acc.mixedAdd(wnd[(-z - 1) >> 1].neg());\n    } else {\n      // J +- J\n      if (z > 0)\n        acc = acc.add(wnd[(z - 1) >> 1]);\n      else\n        acc = acc.add(wnd[(-z - 1) >> 1].neg());\n    }\n  }\n  return p.type === 'affine' ? acc.toP() : acc;\n};\n\nBaseCurve.prototype._wnafMulAdd = function _wnafMulAdd(defW,\n  points,\n  coeffs,\n  len,\n  jacobianResult) {\n  var wndWidth = this._wnafT1;\n  var wnd = this._wnafT2;\n  var naf = this._wnafT3;\n\n  // Fill all arrays\n  var max = 0;\n  var i;\n  var j;\n  var p;\n  for (i = 0; i < len; i++) {\n    p = points[i];\n    var nafPoints = p._getNAFPoints(defW);\n    wndWidth[i] = nafPoints.wnd;\n    wnd[i] = nafPoints.points;\n  }\n\n  // Comb small window NAFs\n  for (i = len - 1; i >= 1; i -= 2) {\n    var a = i - 1;\n    var b = i;\n    if (wndWidth[a] !== 1 || wndWidth[b] !== 1) {\n      naf[a] = getNAF(coeffs[a], wndWidth[a], this._bitLength);\n      naf[b] = getNAF(coeffs[b], wndWidth[b], this._bitLength);\n      max = Math.max(naf[a].length, max);\n      max = Math.max(naf[b].length, max);\n      continue;\n    }\n\n    var comb = [\n      points[a], /* 1 */\n      null, /* 3 */\n      null, /* 5 */\n      points[b], /* 7 */\n    ];\n\n    // Try to avoid Projective points, if possible\n    if (points[a].y.cmp(points[b].y) === 0) {\n      comb[1] = points[a].add(points[b]);\n      comb[2] = points[a].toJ().mixedAdd(points[b].neg());\n    } else if (points[a].y.cmp(points[b].y.redNeg()) === 0) {\n      comb[1] = points[a].toJ().mixedAdd(points[b]);\n      comb[2] = points[a].add(points[b].neg());\n    } else {\n      comb[1] = points[a].toJ().mixedAdd(points[b]);\n      comb[2] = points[a].toJ().mixedAdd(points[b].neg());\n    }\n\n    var index = [\n      -3, /* -1 -1 */\n      -1, /* -1 0 */\n      -5, /* -1 1 */\n      -7, /* 0 -1 */\n      0, /* 0 0 */\n      7, /* 0 1 */\n      5, /* 1 -1 */\n      1, /* 1 0 */\n      3,  /* 1 1 */\n    ];\n\n    var jsf = getJSF(coeffs[a], coeffs[b]);\n    max = Math.max(jsf[0].length, max);\n    naf[a] = new Array(max);\n    naf[b] = new Array(max);\n    for (j = 0; j < max; j++) {\n      var ja = jsf[0][j] | 0;\n      var jb = jsf[1][j] | 0;\n\n      naf[a][j] = index[(ja + 1) * 3 + (jb + 1)];\n      naf[b][j] = 0;\n      wnd[a] = comb;\n    }\n  }\n\n  var acc = this.jpoint(null, null, null);\n  var tmp = this._wnafT4;\n  for (i = max; i >= 0; i--) {\n    var k = 0;\n\n    while (i >= 0) {\n      var zero = true;\n      for (j = 0; j < len; j++) {\n        tmp[j] = naf[j][i] | 0;\n        if (tmp[j] !== 0)\n          zero = false;\n      }\n      if (!zero)\n        break;\n      k++;\n      i--;\n    }\n    if (i >= 0)\n      k++;\n    acc = acc.dblp(k);\n    if (i < 0)\n      break;\n\n    for (j = 0; j < len; j++) {\n      var z = tmp[j];\n      p;\n      if (z === 0)\n        continue;\n      else if (z > 0)\n        p = wnd[j][(z - 1) >> 1];\n      else if (z < 0)\n        p = wnd[j][(-z - 1) >> 1].neg();\n\n      if (p.type === 'affine')\n        acc = acc.mixedAdd(p);\n      else\n        acc = acc.add(p);\n    }\n  }\n  // Zeroify references\n  for (i = 0; i < len; i++)\n    wnd[i] = null;\n\n  if (jacobianResult)\n    return acc;\n  else\n    return acc.toP();\n};\n\nfunction BasePoint(curve, type) {\n  this.curve = curve;\n  this.type = type;\n  this.precomputed = null;\n}\nBaseCurve.BasePoint = BasePoint;\n\nBasePoint.prototype.eq = function eq(/*other*/) {\n  throw new Error('Not implemented');\n};\n\nBasePoint.prototype.validate = function validate() {\n  return this.curve.validate(this);\n};\n\nBaseCurve.prototype.decodePoint = function decodePoint(bytes, enc) {\n  bytes = utils.toArray(bytes, enc);\n\n  var len = this.p.byteLength();\n\n  // uncompressed, hybrid-odd, hybrid-even\n  if ((bytes[0] === 0x04 || bytes[0] === 0x06 || bytes[0] === 0x07) &&\n      bytes.length - 1 === 2 * len) {\n    if (bytes[0] === 0x06)\n      assert(bytes[bytes.length - 1] % 2 === 0);\n    else if (bytes[0] === 0x07)\n      assert(bytes[bytes.length - 1] % 2 === 1);\n\n    var res =  this.point(bytes.slice(1, 1 + len),\n      bytes.slice(1 + len, 1 + 2 * len));\n\n    return res;\n  } else if ((bytes[0] === 0x02 || bytes[0] === 0x03) &&\n              bytes.length - 1 === len) {\n    return this.pointFromX(bytes.slice(1, 1 + len), bytes[0] === 0x03);\n  }\n  throw new Error('Unknown point format');\n};\n\nBasePoint.prototype.encodeCompressed = function encodeCompressed(enc) {\n  return this.encode(enc, true);\n};\n\nBasePoint.prototype._encode = function _encode(compact) {\n  var len = this.curve.p.byteLength();\n  var x = this.getX().toArray('be', len);\n\n  if (compact)\n    return [ this.getY().isEven() ? 0x02 : 0x03 ].concat(x);\n\n  return [ 0x04 ].concat(x, this.getY().toArray('be', len));\n};\n\nBasePoint.prototype.encode = function encode(enc, compact) {\n  return utils.encode(this._encode(compact), enc);\n};\n\nBasePoint.prototype.precompute = function precompute(power) {\n  if (this.precomputed)\n    return this;\n\n  var precomputed = {\n    doubles: null,\n    naf: null,\n    beta: null,\n  };\n  precomputed.naf = this._getNAFPoints(8);\n  precomputed.doubles = this._getDoubles(4, power);\n  precomputed.beta = this._getBeta();\n  this.precomputed = precomputed;\n\n  return this;\n};\n\nBasePoint.prototype._hasDoubles = function _hasDoubles(k) {\n  if (!this.precomputed)\n    return false;\n\n  var doubles = this.precomputed.doubles;\n  if (!doubles)\n    return false;\n\n  return doubles.points.length >= Math.ceil((k.bitLength() + 1) / doubles.step);\n};\n\nBasePoint.prototype._getDoubles = function _getDoubles(step, power) {\n  if (this.precomputed && this.precomputed.doubles)\n    return this.precomputed.doubles;\n\n  var doubles = [ this ];\n  var acc = this;\n  for (var i = 0; i < power; i += step) {\n    for (var j = 0; j < step; j++)\n      acc = acc.dbl();\n    doubles.push(acc);\n  }\n  return {\n    step: step,\n    points: doubles,\n  };\n};\n\nBasePoint.prototype._getNAFPoints = function _getNAFPoints(wnd) {\n  if (this.precomputed && this.precomputed.naf)\n    return this.precomputed.naf;\n\n  var res = [ this ];\n  var max = (1 << wnd) - 1;\n  var dbl = max === 1 ? null : this.dbl();\n  for (var i = 1; i < max; i++)\n    res[i] = res[i - 1].add(dbl);\n  return {\n    wnd: wnd,\n    points: res,\n  };\n};\n\nBasePoint.prototype._getBeta = function _getBeta() {\n  return null;\n};\n\nBasePoint.prototype.dblp = function dblp(k) {\n  var r = this;\n  for (var i = 0; i < k; i++)\n    r = r.dbl();\n  return r;\n};\n",
    "'use strict';\n\nvar utils = require('../utils');\nvar BN = require('bn.js');\nvar inherits = require('inherits');\nvar Base = require('./base');\n\nvar assert = utils.assert;\n\nfunction ShortCurve(conf) {\n  Base.call(this, 'short', conf);\n\n  this.a = new BN(conf.a, 16).toRed(this.red);\n  this.b = new BN(conf.b, 16).toRed(this.red);\n  this.tinv = this.two.redInvm();\n\n  this.zeroA = this.a.fromRed().cmpn(0) === 0;\n  this.threeA = this.a.fromRed().sub(this.p).cmpn(-3) === 0;\n\n  // If the curve is endomorphic, precalculate beta and lambda\n  this.endo = this._getEndomorphism(conf);\n  this._endoWnafT1 = new Array(4);\n  this._endoWnafT2 = new Array(4);\n}\ninherits(ShortCurve, Base);\nmodule.exports = ShortCurve;\n\nShortCurve.prototype._getEndomorphism = function _getEndomorphism(conf) {\n  // No efficient endomorphism\n  if (!this.zeroA || !this.g || !this.n || this.p.modn(3) !== 1)\n    return;\n\n  // Compute beta and lambda, that lambda * P = (beta * Px; Py)\n  var beta;\n  var lambda;\n  if (conf.beta) {\n    beta = new BN(conf.beta, 16).toRed(this.red);\n  } else {\n    var betas = this._getEndoRoots(this.p);\n    // Choose the smallest beta\n    beta = betas[0].cmp(betas[1]) < 0 ? betas[0] : betas[1];\n    beta = beta.toRed(this.red);\n  }\n  if (conf.lambda) {\n    lambda = new BN(conf.lambda, 16);\n  } else {\n    // Choose the lambda that is matching selected beta\n    var lambdas = this._getEndoRoots(this.n);\n    if (this.g.mul(lambdas[0]).x.cmp(this.g.x.redMul(beta)) === 0) {\n      lambda = lambdas[0];\n    } else {\n      lambda = lambdas[1];\n      assert(this.g.mul(lambda).x.cmp(this.g.x.redMul(beta)) === 0);\n    }\n  }\n\n  // Get basis vectors, used for balanced length-two representation\n  var basis;\n  if (conf.basis) {\n    basis = conf.basis.map(function(vec) {\n      return {\n        a: new BN(vec.a, 16),\n        b: new BN(vec.b, 16),\n      };\n    });\n  } else {\n    basis = this._getEndoBasis(lambda);\n  }\n\n  return {\n    beta: beta,\n    lambda: lambda,\n    basis: basis,\n  };\n};\n\nShortCurve.prototype._getEndoRoots = function _getEndoRoots(num) {\n  // Find roots of for x^2 + x + 1 in F\n  // Root = (-1 +- Sqrt(-3)) / 2\n  //\n  var red = num === this.p ? this.red : BN.mont(num);\n  var tinv = new BN(2).toRed(red).redInvm();\n  var ntinv = tinv.redNeg();\n\n  var s = new BN(3).toRed(red).redNeg().redSqrt().redMul(tinv);\n\n  var l1 = ntinv.redAdd(s).fromRed();\n  var l2 = ntinv.redSub(s).fromRed();\n  return [ l1, l2 ];\n};\n\nShortCurve.prototype._getEndoBasis = function _getEndoBasis(lambda) {\n  // aprxSqrt >= sqrt(this.n)\n  var aprxSqrt = this.n.ushrn(Math.floor(this.n.bitLength() / 2));\n\n  // 3.74\n  // Run EGCD, until r(L + 1) < aprxSqrt\n  var u = lambda;\n  var v = this.n.clone();\n  var x1 = new BN(1);\n  var y1 = new BN(0);\n  var x2 = new BN(0);\n  var y2 = new BN(1);\n\n  // NOTE: all vectors are roots of: a + b * lambda = 0 (mod n)\n  var a0;\n  var b0;\n  // First vector\n  var a1;\n  var b1;\n  // Second vector\n  var a2;\n  var b2;\n\n  var prevR;\n  var i = 0;\n  var r;\n  var x;\n  while (u.cmpn(0) !== 0) {\n    var q = v.div(u);\n    r = v.sub(q.mul(u));\n    x = x2.sub(q.mul(x1));\n    var y = y2.sub(q.mul(y1));\n\n    if (!a1 && r.cmp(aprxSqrt) < 0) {\n      a0 = prevR.neg();\n      b0 = x1;\n      a1 = r.neg();\n      b1 = x;\n    } else if (a1 && ++i === 2) {\n      break;\n    }\n    prevR = r;\n\n    v = u;\n    u = r;\n    x2 = x1;\n    x1 = x;\n    y2 = y1;\n    y1 = y;\n  }\n  a2 = r.neg();\n  b2 = x;\n\n  var len1 = a1.sqr().add(b1.sqr());\n  var len2 = a2.sqr().add(b2.sqr());\n  if (len2.cmp(len1) >= 0) {\n    a2 = a0;\n    b2 = b0;\n  }\n\n  // Normalize signs\n  if (a1.negative) {\n    a1 = a1.neg();\n    b1 = b1.neg();\n  }\n  if (a2.negative) {\n    a2 = a2.neg();\n    b2 = b2.neg();\n  }\n\n  return [\n    { a: a1, b: b1 },\n    { a: a2, b: b2 },\n  ];\n};\n\nShortCurve.prototype._endoSplit = function _endoSplit(k) {\n  var basis = this.endo.basis;\n  var v1 = basis[0];\n  var v2 = basis[1];\n\n  var c1 = v2.b.mul(k).divRound(this.n);\n  var c2 = v1.b.neg().mul(k).divRound(this.n);\n\n  var p1 = c1.mul(v1.a);\n  var p2 = c2.mul(v2.a);\n  var q1 = c1.mul(v1.b);\n  var q2 = c2.mul(v2.b);\n\n  // Calculate answer\n  var k1 = k.sub(p1).sub(p2);\n  var k2 = q1.add(q2).neg();\n  return { k1: k1, k2: k2 };\n};\n\nShortCurve.prototype.pointFromX = function pointFromX(x, odd) {\n  x = new BN(x, 16);\n  if (!x.red)\n    x = x.toRed(this.red);\n\n  var y2 = x.redSqr().redMul(x).redIAdd(x.redMul(this.a)).redIAdd(this.b);\n  var y = y2.redSqrt();\n  if (y.redSqr().redSub(y2).cmp(this.zero) !== 0)\n    throw new Error('invalid point');\n\n  // XXX Is there any way to tell if the number is odd without converting it\n  // to non-red form?\n  var isOdd = y.fromRed().isOdd();\n  if (odd && !isOdd || !odd && isOdd)\n    y = y.redNeg();\n\n  return this.point(x, y);\n};\n\nShortCurve.prototype.validate = function validate(point) {\n  if (point.inf)\n    return true;\n\n  var x = point.x;\n  var y = point.y;\n\n  var ax = this.a.redMul(x);\n  var rhs = x.redSqr().redMul(x).redIAdd(ax).redIAdd(this.b);\n  return y.redSqr().redISub(rhs).cmpn(0) === 0;\n};\n\nShortCurve.prototype._endoWnafMulAdd =\n    function _endoWnafMulAdd(points, coeffs, jacobianResult) {\n      var npoints = this._endoWnafT1;\n      var ncoeffs = this._endoWnafT2;\n      for (var i = 0; i < points.length; i++) {\n        var split = this._endoSplit(coeffs[i]);\n        var p = points[i];\n        var beta = p._getBeta();\n\n        if (split.k1.negative) {\n          split.k1.ineg();\n          p = p.neg(true);\n        }\n        if (split.k2.negative) {\n          split.k2.ineg();\n          beta = beta.neg(true);\n        }\n\n        npoints[i * 2] = p;\n        npoints[i * 2 + 1] = beta;\n        ncoeffs[i * 2] = split.k1;\n        ncoeffs[i * 2 + 1] = split.k2;\n      }\n      var res = this._wnafMulAdd(1, npoints, ncoeffs, i * 2, jacobianResult);\n\n      // Clean-up references to points and coefficients\n      for (var j = 0; j < i * 2; j++) {\n        npoints[j] = null;\n        ncoeffs[j] = null;\n      }\n      return res;\n    };\n\nfunction Point(curve, x, y, isRed) {\n  Base.BasePoint.call(this, curve, 'affine');\n  if (x === null && y === null) {\n    this.x = null;\n    this.y = null;\n    this.inf = true;\n  } else {\n    this.x = new BN(x, 16);\n    this.y = new BN(y, 16);\n    // Force redgomery representation when loading from JSON\n    if (isRed) {\n      this.x.forceRed(this.curve.red);\n      this.y.forceRed(this.curve.red);\n    }\n    if (!this.x.red)\n      this.x = this.x.toRed(this.curve.red);\n    if (!this.y.red)\n      this.y = this.y.toRed(this.curve.red);\n    this.inf = false;\n  }\n}\ninherits(Point, Base.BasePoint);\n\nShortCurve.prototype.point = function point(x, y, isRed) {\n  return new Point(this, x, y, isRed);\n};\n\nShortCurve.prototype.pointFromJSON = function pointFromJSON(obj, red) {\n  return Point.fromJSON(this, obj, red);\n};\n\nPoint.prototype._getBeta = function _getBeta() {\n  if (!this.curve.endo)\n    return;\n\n  var pre = this.precomputed;\n  if (pre && pre.beta)\n    return pre.beta;\n\n  var beta = this.curve.point(this.x.redMul(this.curve.endo.beta), this.y);\n  if (pre) {\n    var curve = this.curve;\n    var endoMul = function(p) {\n      return curve.point(p.x.redMul(curve.endo.beta), p.y);\n    };\n    pre.beta = beta;\n    beta.precomputed = {\n      beta: null,\n      naf: pre.naf && {\n        wnd: pre.naf.wnd,\n        points: pre.naf.points.map(endoMul),\n      },\n      doubles: pre.doubles && {\n        step: pre.doubles.step,\n        points: pre.doubles.points.map(endoMul),\n      },\n    };\n  }\n  return beta;\n};\n\nPoint.prototype.toJSON = function toJSON() {\n  if (!this.precomputed)\n    return [ this.x, this.y ];\n\n  return [ this.x, this.y, this.precomputed && {\n    doubles: this.precomputed.doubles && {\n      step: this.precomputed.doubles.step,\n      points: this.precomputed.doubles.points.slice(1),\n    },\n    naf: this.precomputed.naf && {\n      wnd: this.precomputed.naf.wnd,\n      points: this.precomputed.naf.points.slice(1),\n    },\n  } ];\n};\n\nPoint.fromJSON = function fromJSON(curve, obj, red) {\n  if (typeof obj === 'string')\n    obj = JSON.parse(obj);\n  var res = curve.point(obj[0], obj[1], red);\n  if (!obj[2])\n    return res;\n\n  function obj2point(obj) {\n    return curve.point(obj[0], obj[1], red);\n  }\n\n  var pre = obj[2];\n  res.precomputed = {\n    beta: null,\n    doubles: pre.doubles && {\n      step: pre.doubles.step,\n      points: [ res ].concat(pre.doubles.points.map(obj2point)),\n    },\n    naf: pre.naf && {\n      wnd: pre.naf.wnd,\n      points: [ res ].concat(pre.naf.points.map(obj2point)),\n    },\n  };\n  return res;\n};\n\nPoint.prototype.inspect = function inspect() {\n  if (this.isInfinity())\n    return '<EC Point Infinity>';\n  return '<EC Point x: ' + this.x.fromRed().toString(16, 2) +\n      ' y: ' + this.y.fromRed().toString(16, 2) + '>';\n};\n\nPoint.prototype.isInfinity = function isInfinity() {\n  return this.inf;\n};\n\nPoint.prototype.add = function add(p) {\n  // O + P = P\n  if (this.inf)\n    return p;\n\n  // P + O = P\n  if (p.inf)\n    return this;\n\n  // P + P = 2P\n  if (this.eq(p))\n    return this.dbl();\n\n  // P + (-P) = O\n  if (this.neg().eq(p))\n    return this.curve.point(null, null);\n\n  // P + Q = O\n  if (this.x.cmp(p.x) === 0)\n    return this.curve.point(null, null);\n\n  var c = this.y.redSub(p.y);\n  if (c.cmpn(0) !== 0)\n    c = c.redMul(this.x.redSub(p.x).redInvm());\n  var nx = c.redSqr().redISub(this.x).redISub(p.x);\n  var ny = c.redMul(this.x.redSub(nx)).redISub(this.y);\n  return this.curve.point(nx, ny);\n};\n\nPoint.prototype.dbl = function dbl() {\n  if (this.inf)\n    return this;\n\n  // 2P = O\n  var ys1 = this.y.redAdd(this.y);\n  if (ys1.cmpn(0) === 0)\n    return this.curve.point(null, null);\n\n  var a = this.curve.a;\n\n  var x2 = this.x.redSqr();\n  var dyinv = ys1.redInvm();\n  var c = x2.redAdd(x2).redIAdd(x2).redIAdd(a).redMul(dyinv);\n\n  var nx = c.redSqr().redISub(this.x.redAdd(this.x));\n  var ny = c.redMul(this.x.redSub(nx)).redISub(this.y);\n  return this.curve.point(nx, ny);\n};\n\nPoint.prototype.getX = function getX() {\n  return this.x.fromRed();\n};\n\nPoint.prototype.getY = function getY() {\n  return this.y.fromRed();\n};\n\nPoint.prototype.mul = function mul(k) {\n  k = new BN(k, 16);\n  if (this.isInfinity())\n    return this;\n  else if (this._hasDoubles(k))\n    return this.curve._fixedNafMul(this, k);\n  else if (this.curve.endo)\n    return this.curve._endoWnafMulAdd([ this ], [ k ]);\n  else\n    return this.curve._wnafMul(this, k);\n};\n\nPoint.prototype.mulAdd = function mulAdd(k1, p2, k2) {\n  var points = [ this, p2 ];\n  var coeffs = [ k1, k2 ];\n  if (this.curve.endo)\n    return this.curve._endoWnafMulAdd(points, coeffs);\n  else\n    return this.curve._wnafMulAdd(1, points, coeffs, 2);\n};\n\nPoint.prototype.jmulAdd = function jmulAdd(k1, p2, k2) {\n  var points = [ this, p2 ];\n  var coeffs = [ k1, k2 ];\n  if (this.curve.endo)\n    return this.curve._endoWnafMulAdd(points, coeffs, true);\n  else\n    return this.curve._wnafMulAdd(1, points, coeffs, 2, true);\n};\n\nPoint.prototype.eq = function eq(p) {\n  return this === p ||\n         this.inf === p.inf &&\n             (this.inf || this.x.cmp(p.x) === 0 && this.y.cmp(p.y) === 0);\n};\n\nPoint.prototype.neg = function neg(_precompute) {\n  if (this.inf)\n    return this;\n\n  var res = this.curve.point(this.x, this.y.redNeg());\n  if (_precompute && this.precomputed) {\n    var pre = this.precomputed;\n    var negate = function(p) {\n      return p.neg();\n    };\n    res.precomputed = {\n      naf: pre.naf && {\n        wnd: pre.naf.wnd,\n        points: pre.naf.points.map(negate),\n      },\n      doubles: pre.doubles && {\n        step: pre.doubles.step,\n        points: pre.doubles.points.map(negate),\n      },\n    };\n  }\n  return res;\n};\n\nPoint.prototype.toJ = function toJ() {\n  if (this.inf)\n    return this.curve.jpoint(null, null, null);\n\n  var res = this.curve.jpoint(this.x, this.y, this.curve.one);\n  return res;\n};\n\nfunction JPoint(curve, x, y, z) {\n  Base.BasePoint.call(this, curve, 'jacobian');\n  if (x === null && y === null && z === null) {\n    this.x = this.curve.one;\n    this.y = this.curve.one;\n    this.z = new BN(0);\n  } else {\n    this.x = new BN(x, 16);\n    this.y = new BN(y, 16);\n    this.z = new BN(z, 16);\n  }\n  if (!this.x.red)\n    this.x = this.x.toRed(this.curve.red);\n  if (!this.y.red)\n    this.y = this.y.toRed(this.curve.red);\n  if (!this.z.red)\n    this.z = this.z.toRed(this.curve.red);\n\n  this.zOne = this.z === this.curve.one;\n}\ninherits(JPoint, Base.BasePoint);\n\nShortCurve.prototype.jpoint = function jpoint(x, y, z) {\n  return new JPoint(this, x, y, z);\n};\n\nJPoint.prototype.toP = function toP() {\n  if (this.isInfinity())\n    return this.curve.point(null, null);\n\n  var zinv = this.z.redInvm();\n  var zinv2 = zinv.redSqr();\n  var ax = this.x.redMul(zinv2);\n  var ay = this.y.redMul(zinv2).redMul(zinv);\n\n  return this.curve.point(ax, ay);\n};\n\nJPoint.prototype.neg = function neg() {\n  return this.curve.jpoint(this.x, this.y.redNeg(), this.z);\n};\n\nJPoint.prototype.add = function add(p) {\n  // O + P = P\n  if (this.isInfinity())\n    return p;\n\n  // P + O = P\n  if (p.isInfinity())\n    return this;\n\n  // 12M + 4S + 7A\n  var pz2 = p.z.redSqr();\n  var z2 = this.z.redSqr();\n  var u1 = this.x.redMul(pz2);\n  var u2 = p.x.redMul(z2);\n  var s1 = this.y.redMul(pz2.redMul(p.z));\n  var s2 = p.y.redMul(z2.redMul(this.z));\n\n  var h = u1.redSub(u2);\n  var r = s1.redSub(s2);\n  if (h.cmpn(0) === 0) {\n    if (r.cmpn(0) !== 0)\n      return this.curve.jpoint(null, null, null);\n    else\n      return this.dbl();\n  }\n\n  var h2 = h.redSqr();\n  var h3 = h2.redMul(h);\n  var v = u1.redMul(h2);\n\n  var nx = r.redSqr().redIAdd(h3).redISub(v).redISub(v);\n  var ny = r.redMul(v.redISub(nx)).redISub(s1.redMul(h3));\n  var nz = this.z.redMul(p.z).redMul(h);\n\n  return this.curve.jpoint(nx, ny, nz);\n};\n\nJPoint.prototype.mixedAdd = function mixedAdd(p) {\n  // O + P = P\n  if (this.isInfinity())\n    return p.toJ();\n\n  // P + O = P\n  if (p.isInfinity())\n    return this;\n\n  // 8M + 3S + 7A\n  var z2 = this.z.redSqr();\n  var u1 = this.x;\n  var u2 = p.x.redMul(z2);\n  var s1 = this.y;\n  var s2 = p.y.redMul(z2).redMul(this.z);\n\n  var h = u1.redSub(u2);\n  var r = s1.redSub(s2);\n  if (h.cmpn(0) === 0) {\n    if (r.cmpn(0) !== 0)\n      return this.curve.jpoint(null, null, null);\n    else\n      return this.dbl();\n  }\n\n  var h2 = h.redSqr();\n  var h3 = h2.redMul(h);\n  var v = u1.redMul(h2);\n\n  var nx = r.redSqr().redIAdd(h3).redISub(v).redISub(v);\n  var ny = r.redMul(v.redISub(nx)).redISub(s1.redMul(h3));\n  var nz = this.z.redMul(h);\n\n  return this.curve.jpoint(nx, ny, nz);\n};\n\nJPoint.prototype.dblp = function dblp(pow) {\n  if (pow === 0)\n    return this;\n  if (this.isInfinity())\n    return this;\n  if (!pow)\n    return this.dbl();\n\n  var i;\n  if (this.curve.zeroA || this.curve.threeA) {\n    var r = this;\n    for (i = 0; i < pow; i++)\n      r = r.dbl();\n    return r;\n  }\n\n  // 1M + 2S + 1A + N * (4S + 5M + 8A)\n  // N = 1 => 6M + 6S + 9A\n  var a = this.curve.a;\n  var tinv = this.curve.tinv;\n\n  var jx = this.x;\n  var jy = this.y;\n  var jz = this.z;\n  var jz4 = jz.redSqr().redSqr();\n\n  // Reuse results\n  var jyd = jy.redAdd(jy);\n  for (i = 0; i < pow; i++) {\n    var jx2 = jx.redSqr();\n    var jyd2 = jyd.redSqr();\n    var jyd4 = jyd2.redSqr();\n    var c = jx2.redAdd(jx2).redIAdd(jx2).redIAdd(a.redMul(jz4));\n\n    var t1 = jx.redMul(jyd2);\n    var nx = c.redSqr().redISub(t1.redAdd(t1));\n    var t2 = t1.redISub(nx);\n    var dny = c.redMul(t2);\n    dny = dny.redIAdd(dny).redISub(jyd4);\n    var nz = jyd.redMul(jz);\n    if (i + 1 < pow)\n      jz4 = jz4.redMul(jyd4);\n\n    jx = nx;\n    jz = nz;\n    jyd = dny;\n  }\n\n  return this.curve.jpoint(jx, jyd.redMul(tinv), jz);\n};\n\nJPoint.prototype.dbl = function dbl() {\n  if (this.isInfinity())\n    return this;\n\n  if (this.curve.zeroA)\n    return this._zeroDbl();\n  else if (this.curve.threeA)\n    return this._threeDbl();\n  else\n    return this._dbl();\n};\n\nJPoint.prototype._zeroDbl = function _zeroDbl() {\n  var nx;\n  var ny;\n  var nz;\n  // Z = 1\n  if (this.zOne) {\n    // hyperelliptic.org/EFD/g1p/auto-shortw-jacobian-0.html\n    //     #doubling-mdbl-2007-bl\n    // 1M + 5S + 14A\n\n    // XX = X1^2\n    var xx = this.x.redSqr();\n    // YY = Y1^2\n    var yy = this.y.redSqr();\n    // YYYY = YY^2\n    var yyyy = yy.redSqr();\n    // S = 2 * ((X1 + YY)^2 - XX - YYYY)\n    var s = this.x.redAdd(yy).redSqr().redISub(xx).redISub(yyyy);\n    s = s.redIAdd(s);\n    // M = 3 * XX + a; a = 0\n    var m = xx.redAdd(xx).redIAdd(xx);\n    // T = M ^ 2 - 2*S\n    var t = m.redSqr().redISub(s).redISub(s);\n\n    // 8 * YYYY\n    var yyyy8 = yyyy.redIAdd(yyyy);\n    yyyy8 = yyyy8.redIAdd(yyyy8);\n    yyyy8 = yyyy8.redIAdd(yyyy8);\n\n    // X3 = T\n    nx = t;\n    // Y3 = M * (S - T) - 8 * YYYY\n    ny = m.redMul(s.redISub(t)).redISub(yyyy8);\n    // Z3 = 2*Y1\n    nz = this.y.redAdd(this.y);\n  } else {\n    // hyperelliptic.org/EFD/g1p/auto-shortw-jacobian-0.html\n    //     #doubling-dbl-2009-l\n    // 2M + 5S + 13A\n\n    // A = X1^2\n    var a = this.x.redSqr();\n    // B = Y1^2\n    var b = this.y.redSqr();\n    // C = B^2\n    var c = b.redSqr();\n    // D = 2 * ((X1 + B)^2 - A - C)\n    var d = this.x.redAdd(b).redSqr().redISub(a).redISub(c);\n    d = d.redIAdd(d);\n    // E = 3 * A\n    var e = a.redAdd(a).redIAdd(a);\n    // F = E^2\n    var f = e.redSqr();\n\n    // 8 * C\n    var c8 = c.redIAdd(c);\n    c8 = c8.redIAdd(c8);\n    c8 = c8.redIAdd(c8);\n\n    // X3 = F - 2 * D\n    nx = f.redISub(d).redISub(d);\n    // Y3 = E * (D - X3) - 8 * C\n    ny = e.redMul(d.redISub(nx)).redISub(c8);\n    // Z3 = 2 * Y1 * Z1\n    nz = this.y.redMul(this.z);\n    nz = nz.redIAdd(nz);\n  }\n\n  return this.curve.jpoint(nx, ny, nz);\n};\n\nJPoint.prototype._threeDbl = function _threeDbl() {\n  var nx;\n  var ny;\n  var nz;\n  // Z = 1\n  if (this.zOne) {\n    // hyperelliptic.org/EFD/g1p/auto-shortw-jacobian-3.html\n    //     #doubling-mdbl-2007-bl\n    // 1M + 5S + 15A\n\n    // XX = X1^2\n    var xx = this.x.redSqr();\n    // YY = Y1^2\n    var yy = this.y.redSqr();\n    // YYYY = YY^2\n    var yyyy = yy.redSqr();\n    // S = 2 * ((X1 + YY)^2 - XX - YYYY)\n    var s = this.x.redAdd(yy).redSqr().redISub(xx).redISub(yyyy);\n    s = s.redIAdd(s);\n    // M = 3 * XX + a\n    var m = xx.redAdd(xx).redIAdd(xx).redIAdd(this.curve.a);\n    // T = M^2 - 2 * S\n    var t = m.redSqr().redISub(s).redISub(s);\n    // X3 = T\n    nx = t;\n    // Y3 = M * (S - T) - 8 * YYYY\n    var yyyy8 = yyyy.redIAdd(yyyy);\n    yyyy8 = yyyy8.redIAdd(yyyy8);\n    yyyy8 = yyyy8.redIAdd(yyyy8);\n    ny = m.redMul(s.redISub(t)).redISub(yyyy8);\n    // Z3 = 2 * Y1\n    nz = this.y.redAdd(this.y);\n  } else {\n    // hyperelliptic.org/EFD/g1p/auto-shortw-jacobian-3.html#doubling-dbl-2001-b\n    // 3M + 5S\n\n    // delta = Z1^2\n    var delta = this.z.redSqr();\n    // gamma = Y1^2\n    var gamma = this.y.redSqr();\n    // beta = X1 * gamma\n    var beta = this.x.redMul(gamma);\n    // alpha = 3 * (X1 - delta) * (X1 + delta)\n    var alpha = this.x.redSub(delta).redMul(this.x.redAdd(delta));\n    alpha = alpha.redAdd(alpha).redIAdd(alpha);\n    // X3 = alpha^2 - 8 * beta\n    var beta4 = beta.redIAdd(beta);\n    beta4 = beta4.redIAdd(beta4);\n    var beta8 = beta4.redAdd(beta4);\n    nx = alpha.redSqr().redISub(beta8);\n    // Z3 = (Y1 + Z1)^2 - gamma - delta\n    nz = this.y.redAdd(this.z).redSqr().redISub(gamma).redISub(delta);\n    // Y3 = alpha * (4 * beta - X3) - 8 * gamma^2\n    var ggamma8 = gamma.redSqr();\n    ggamma8 = ggamma8.redIAdd(ggamma8);\n    ggamma8 = ggamma8.redIAdd(ggamma8);\n    ggamma8 = ggamma8.redIAdd(ggamma8);\n    ny = alpha.redMul(beta4.redISub(nx)).redISub(ggamma8);\n  }\n\n  return this.curve.jpoint(nx, ny, nz);\n};\n\nJPoint.prototype._dbl = function _dbl() {\n  var a = this.curve.a;\n\n  // 4M + 6S + 10A\n  var jx = this.x;\n  var jy = this.y;\n  var jz = this.z;\n  var jz4 = jz.redSqr().redSqr();\n\n  var jx2 = jx.redSqr();\n  var jy2 = jy.redSqr();\n\n  var c = jx2.redAdd(jx2).redIAdd(jx2).redIAdd(a.redMul(jz4));\n\n  var jxd4 = jx.redAdd(jx);\n  jxd4 = jxd4.redIAdd(jxd4);\n  var t1 = jxd4.redMul(jy2);\n  var nx = c.redSqr().redISub(t1.redAdd(t1));\n  var t2 = t1.redISub(nx);\n\n  var jyd8 = jy2.redSqr();\n  jyd8 = jyd8.redIAdd(jyd8);\n  jyd8 = jyd8.redIAdd(jyd8);\n  jyd8 = jyd8.redIAdd(jyd8);\n  var ny = c.redMul(t2).redISub(jyd8);\n  var nz = jy.redAdd(jy).redMul(jz);\n\n  return this.curve.jpoint(nx, ny, nz);\n};\n\nJPoint.prototype.trpl = function trpl() {\n  if (!this.curve.zeroA)\n    return this.dbl().add(this);\n\n  // hyperelliptic.org/EFD/g1p/auto-shortw-jacobian-0.html#tripling-tpl-2007-bl\n  // 5M + 10S + ...\n\n  // XX = X1^2\n  var xx = this.x.redSqr();\n  // YY = Y1^2\n  var yy = this.y.redSqr();\n  // ZZ = Z1^2\n  var zz = this.z.redSqr();\n  // YYYY = YY^2\n  var yyyy = yy.redSqr();\n  // M = 3 * XX + a * ZZ2; a = 0\n  var m = xx.redAdd(xx).redIAdd(xx);\n  // MM = M^2\n  var mm = m.redSqr();\n  // E = 6 * ((X1 + YY)^2 - XX - YYYY) - MM\n  var e = this.x.redAdd(yy).redSqr().redISub(xx).redISub(yyyy);\n  e = e.redIAdd(e);\n  e = e.redAdd(e).redIAdd(e);\n  e = e.redISub(mm);\n  // EE = E^2\n  var ee = e.redSqr();\n  // T = 16*YYYY\n  var t = yyyy.redIAdd(yyyy);\n  t = t.redIAdd(t);\n  t = t.redIAdd(t);\n  t = t.redIAdd(t);\n  // U = (M + E)^2 - MM - EE - T\n  var u = m.redIAdd(e).redSqr().redISub(mm).redISub(ee).redISub(t);\n  // X3 = 4 * (X1 * EE - 4 * YY * U)\n  var yyu4 = yy.redMul(u);\n  yyu4 = yyu4.redIAdd(yyu4);\n  yyu4 = yyu4.redIAdd(yyu4);\n  var nx = this.x.redMul(ee).redISub(yyu4);\n  nx = nx.redIAdd(nx);\n  nx = nx.redIAdd(nx);\n  // Y3 = 8 * Y1 * (U * (T - U) - E * EE)\n  var ny = this.y.redMul(u.redMul(t.redISub(u)).redISub(e.redMul(ee)));\n  ny = ny.redIAdd(ny);\n  ny = ny.redIAdd(ny);\n  ny = ny.redIAdd(ny);\n  // Z3 = (Z1 + E)^2 - ZZ - EE\n  var nz = this.z.redAdd(e).redSqr().redISub(zz).redISub(ee);\n\n  return this.curve.jpoint(nx, ny, nz);\n};\n\nJPoint.prototype.mul = function mul(k, kbase) {\n  k = new BN(k, kbase);\n\n  return this.curve._wnafMul(this, k);\n};\n\nJPoint.prototype.eq = function eq(p) {\n  if (p.type === 'affine')\n    return this.eq(p.toJ());\n\n  if (this === p)\n    return true;\n\n  // x1 * z2^2 == x2 * z1^2\n  var z2 = this.z.redSqr();\n  var pz2 = p.z.redSqr();\n  if (this.x.redMul(pz2).redISub(p.x.redMul(z2)).cmpn(0) !== 0)\n    return false;\n\n  // y1 * z2^3 == y2 * z1^3\n  var z3 = z2.redMul(this.z);\n  var pz3 = pz2.redMul(p.z);\n  return this.y.redMul(pz3).redISub(p.y.redMul(z3)).cmpn(0) === 0;\n};\n\nJPoint.prototype.eqXToP = function eqXToP(x) {\n  var zs = this.z.redSqr();\n  var rx = x.toRed(this.curve.red).redMul(zs);\n  if (this.x.cmp(rx) === 0)\n    return true;\n\n  var xc = x.clone();\n  var t = this.curve.redN.redMul(zs);\n  for (;;) {\n    xc.iadd(this.curve.n);\n    if (xc.cmp(this.curve.p) >= 0)\n      return false;\n\n    rx.redIAdd(t);\n    if (this.x.cmp(rx) === 0)\n      return true;\n  }\n};\n\nJPoint.prototype.inspect = function inspect() {\n  if (this.isInfinity())\n    return '<EC JPoint Infinity>';\n  return '<EC JPoint x: ' + this.x.toString(16, 2) +\n      ' y: ' + this.y.toString(16, 2) +\n      ' z: ' + this.z.toString(16, 2) + '>';\n};\n\nJPoint.prototype.isInfinity = function isInfinity() {\n  // XXX This code assumes that zero is always zero in red\n  return this.z.cmpn(0) === 0;\n};\n",
    "'use strict';\n\nvar BN = require('bn.js');\nvar inherits = require('inherits');\nvar Base = require('./base');\n\nvar utils = require('../utils');\n\nfunction MontCurve(conf) {\n  Base.call(this, 'mont', conf);\n\n  this.a = new BN(conf.a, 16).toRed(this.red);\n  this.b = new BN(conf.b, 16).toRed(this.red);\n  this.i4 = new BN(4).toRed(this.red).redInvm();\n  this.two = new BN(2).toRed(this.red);\n  this.a24 = this.i4.redMul(this.a.redAdd(this.two));\n}\ninherits(MontCurve, Base);\nmodule.exports = MontCurve;\n\nMontCurve.prototype.validate = function validate(point) {\n  var x = point.normalize().x;\n  var x2 = x.redSqr();\n  var rhs = x2.redMul(x).redAdd(x2.redMul(this.a)).redAdd(x);\n  var y = rhs.redSqrt();\n\n  return y.redSqr().cmp(rhs) === 0;\n};\n\nfunction Point(curve, x, z) {\n  Base.BasePoint.call(this, curve, 'projective');\n  if (x === null && z === null) {\n    this.x = this.curve.one;\n    this.z = this.curve.zero;\n  } else {\n    this.x = new BN(x, 16);\n    this.z = new BN(z, 16);\n    if (!this.x.red)\n      this.x = this.x.toRed(this.curve.red);\n    if (!this.z.red)\n      this.z = this.z.toRed(this.curve.red);\n  }\n}\ninherits(Point, Base.BasePoint);\n\nMontCurve.prototype.decodePoint = function decodePoint(bytes, enc) {\n  return this.point(utils.toArray(bytes, enc), 1);\n};\n\nMontCurve.prototype.point = function point(x, z) {\n  return new Point(this, x, z);\n};\n\nMontCurve.prototype.pointFromJSON = function pointFromJSON(obj) {\n  return Point.fromJSON(this, obj);\n};\n\nPoint.prototype.precompute = function precompute() {\n  // No-op\n};\n\nPoint.prototype._encode = function _encode() {\n  return this.getX().toArray('be', this.curve.p.byteLength());\n};\n\nPoint.fromJSON = function fromJSON(curve, obj) {\n  return new Point(curve, obj[0], obj[1] || curve.one);\n};\n\nPoint.prototype.inspect = function inspect() {\n  if (this.isInfinity())\n    return '<EC Point Infinity>';\n  return '<EC Point x: ' + this.x.fromRed().toString(16, 2) +\n      ' z: ' + this.z.fromRed().toString(16, 2) + '>';\n};\n\nPoint.prototype.isInfinity = function isInfinity() {\n  // XXX This code assumes that zero is always zero in red\n  return this.z.cmpn(0) === 0;\n};\n\nPoint.prototype.dbl = function dbl() {\n  // http://hyperelliptic.org/EFD/g1p/auto-montgom-xz.html#doubling-dbl-1987-m-3\n  // 2M + 2S + 4A\n\n  // A = X1 + Z1\n  var a = this.x.redAdd(this.z);\n  // AA = A^2\n  var aa = a.redSqr();\n  // B = X1 - Z1\n  var b = this.x.redSub(this.z);\n  // BB = B^2\n  var bb = b.redSqr();\n  // C = AA - BB\n  var c = aa.redSub(bb);\n  // X3 = AA * BB\n  var nx = aa.redMul(bb);\n  // Z3 = C * (BB + A24 * C)\n  var nz = c.redMul(bb.redAdd(this.curve.a24.redMul(c)));\n  return this.curve.point(nx, nz);\n};\n\nPoint.prototype.add = function add() {\n  throw new Error('Not supported on Montgomery curve');\n};\n\nPoint.prototype.diffAdd = function diffAdd(p, diff) {\n  // http://hyperelliptic.org/EFD/g1p/auto-montgom-xz.html#diffadd-dadd-1987-m-3\n  // 4M + 2S + 6A\n\n  // A = X2 + Z2\n  var a = this.x.redAdd(this.z);\n  // B = X2 - Z2\n  var b = this.x.redSub(this.z);\n  // C = X3 + Z3\n  var c = p.x.redAdd(p.z);\n  // D = X3 - Z3\n  var d = p.x.redSub(p.z);\n  // DA = D * A\n  var da = d.redMul(a);\n  // CB = C * B\n  var cb = c.redMul(b);\n  // X5 = Z1 * (DA + CB)^2\n  var nx = diff.z.redMul(da.redAdd(cb).redSqr());\n  // Z5 = X1 * (DA - CB)^2\n  var nz = diff.x.redMul(da.redISub(cb).redSqr());\n  return this.curve.point(nx, nz);\n};\n\nPoint.prototype.mul = function mul(k) {\n  var t = k.clone();\n  var a = this; // (N / 2) * Q + Q\n  var b = this.curve.point(null, null); // (N / 2) * Q\n  var c = this; // Q\n\n  for (var bits = []; t.cmpn(0) !== 0; t.iushrn(1))\n    bits.push(t.andln(1));\n\n  for (var i = bits.length - 1; i >= 0; i--) {\n    if (bits[i] === 0) {\n      // N * Q + Q = ((N / 2) * Q + Q)) + (N / 2) * Q\n      a = a.diffAdd(b, c);\n      // N * Q = 2 * ((N / 2) * Q + Q))\n      b = b.dbl();\n    } else {\n      // N * Q = ((N / 2) * Q + Q) + ((N / 2) * Q)\n      b = a.diffAdd(b, c);\n      // N * Q + Q = 2 * ((N / 2) * Q + Q)\n      a = a.dbl();\n    }\n  }\n  return b;\n};\n\nPoint.prototype.mulAdd = function mulAdd() {\n  throw new Error('Not supported on Montgomery curve');\n};\n\nPoint.prototype.jumlAdd = function jumlAdd() {\n  throw new Error('Not supported on Montgomery curve');\n};\n\nPoint.prototype.eq = function eq(other) {\n  return this.getX().cmp(other.getX()) === 0;\n};\n\nPoint.prototype.normalize = function normalize() {\n  this.x = this.x.redMul(this.z.redInvm());\n  this.z = this.curve.one;\n  return this;\n};\n\nPoint.prototype.getX = function getX() {\n  // Normalize coordinates\n  this.normalize();\n\n  return this.x.fromRed();\n};\n",
    "'use strict';\n\nvar utils = require('../utils');\nvar BN = require('bn.js');\nvar inherits = require('inherits');\nvar Base = require('./base');\n\nvar assert = utils.assert;\n\nfunction EdwardsCurve(conf) {\n  // NOTE: Important as we are creating point in Base.call()\n  this.twisted = (conf.a | 0) !== 1;\n  this.mOneA = this.twisted && (conf.a | 0) === -1;\n  this.extended = this.mOneA;\n\n  Base.call(this, 'edwards', conf);\n\n  this.a = new BN(conf.a, 16).umod(this.red.m);\n  this.a = this.a.toRed(this.red);\n  this.c = new BN(conf.c, 16).toRed(this.red);\n  this.c2 = this.c.redSqr();\n  this.d = new BN(conf.d, 16).toRed(this.red);\n  this.dd = this.d.redAdd(this.d);\n\n  assert(!this.twisted || this.c.fromRed().cmpn(1) === 0);\n  this.oneC = (conf.c | 0) === 1;\n}\ninherits(EdwardsCurve, Base);\nmodule.exports = EdwardsCurve;\n\nEdwardsCurve.prototype._mulA = function _mulA(num) {\n  if (this.mOneA)\n    return num.redNeg();\n  else\n    return this.a.redMul(num);\n};\n\nEdwardsCurve.prototype._mulC = function _mulC(num) {\n  if (this.oneC)\n    return num;\n  else\n    return this.c.redMul(num);\n};\n\n// Just for compatibility with Short curve\nEdwardsCurve.prototype.jpoint = function jpoint(x, y, z, t) {\n  return this.point(x, y, z, t);\n};\n\nEdwardsCurve.prototype.pointFromX = function pointFromX(x, odd) {\n  x = new BN(x, 16);\n  if (!x.red)\n    x = x.toRed(this.red);\n\n  var x2 = x.redSqr();\n  var rhs = this.c2.redSub(this.a.redMul(x2));\n  var lhs = this.one.redSub(this.c2.redMul(this.d).redMul(x2));\n\n  var y2 = rhs.redMul(lhs.redInvm());\n  var y = y2.redSqrt();\n  if (y.redSqr().redSub(y2).cmp(this.zero) !== 0)\n    throw new Error('invalid point');\n\n  var isOdd = y.fromRed().isOdd();\n  if (odd && !isOdd || !odd && isOdd)\n    y = y.redNeg();\n\n  return this.point(x, y);\n};\n\nEdwardsCurve.prototype.pointFromY = function pointFromY(y, odd) {\n  y = new BN(y, 16);\n  if (!y.red)\n    y = y.toRed(this.red);\n\n  // x^2 = (y^2 - c^2) / (c^2 d y^2 - a)\n  var y2 = y.redSqr();\n  var lhs = y2.redSub(this.c2);\n  var rhs = y2.redMul(this.d).redMul(this.c2).redSub(this.a);\n  var x2 = lhs.redMul(rhs.redInvm());\n\n  if (x2.cmp(this.zero) === 0) {\n    if (odd)\n      throw new Error('invalid point');\n    else\n      return this.point(this.zero, y);\n  }\n\n  var x = x2.redSqrt();\n  if (x.redSqr().redSub(x2).cmp(this.zero) !== 0)\n    throw new Error('invalid point');\n\n  if (x.fromRed().isOdd() !== odd)\n    x = x.redNeg();\n\n  return this.point(x, y);\n};\n\nEdwardsCurve.prototype.validate = function validate(point) {\n  if (point.isInfinity())\n    return true;\n\n  // Curve: A * X^2 + Y^2 = C^2 * (1 + D * X^2 * Y^2)\n  point.normalize();\n\n  var x2 = point.x.redSqr();\n  var y2 = point.y.redSqr();\n  var lhs = x2.redMul(this.a).redAdd(y2);\n  var rhs = this.c2.redMul(this.one.redAdd(this.d.redMul(x2).redMul(y2)));\n\n  return lhs.cmp(rhs) === 0;\n};\n\nfunction Point(curve, x, y, z, t) {\n  Base.BasePoint.call(this, curve, 'projective');\n  if (x === null && y === null && z === null) {\n    this.x = this.curve.zero;\n    this.y = this.curve.one;\n    this.z = this.curve.one;\n    this.t = this.curve.zero;\n    this.zOne = true;\n  } else {\n    this.x = new BN(x, 16);\n    this.y = new BN(y, 16);\n    this.z = z ? new BN(z, 16) : this.curve.one;\n    this.t = t && new BN(t, 16);\n    if (!this.x.red)\n      this.x = this.x.toRed(this.curve.red);\n    if (!this.y.red)\n      this.y = this.y.toRed(this.curve.red);\n    if (!this.z.red)\n      this.z = this.z.toRed(this.curve.red);\n    if (this.t && !this.t.red)\n      this.t = this.t.toRed(this.curve.red);\n    this.zOne = this.z === this.curve.one;\n\n    // Use extended coordinates\n    if (this.curve.extended && !this.t) {\n      this.t = this.x.redMul(this.y);\n      if (!this.zOne)\n        this.t = this.t.redMul(this.z.redInvm());\n    }\n  }\n}\ninherits(Point, Base.BasePoint);\n\nEdwardsCurve.prototype.pointFromJSON = function pointFromJSON(obj) {\n  return Point.fromJSON(this, obj);\n};\n\nEdwardsCurve.prototype.point = function point(x, y, z, t) {\n  return new Point(this, x, y, z, t);\n};\n\nPoint.fromJSON = function fromJSON(curve, obj) {\n  return new Point(curve, obj[0], obj[1], obj[2]);\n};\n\nPoint.prototype.inspect = function inspect() {\n  if (this.isInfinity())\n    return '<EC Point Infinity>';\n  return '<EC Point x: ' + this.x.fromRed().toString(16, 2) +\n      ' y: ' + this.y.fromRed().toString(16, 2) +\n      ' z: ' + this.z.fromRed().toString(16, 2) + '>';\n};\n\nPoint.prototype.isInfinity = function isInfinity() {\n  // XXX This code assumes that zero is always zero in red\n  return this.x.cmpn(0) === 0 &&\n    (this.y.cmp(this.z) === 0 ||\n    (this.zOne && this.y.cmp(this.curve.c) === 0));\n};\n\nPoint.prototype._extDbl = function _extDbl() {\n  // hyperelliptic.org/EFD/g1p/auto-twisted-extended-1.html\n  //     #doubling-dbl-2008-hwcd\n  // 4M + 4S\n\n  // A = X1^2\n  var a = this.x.redSqr();\n  // B = Y1^2\n  var b = this.y.redSqr();\n  // C = 2 * Z1^2\n  var c = this.z.redSqr();\n  c = c.redIAdd(c);\n  // D = a * A\n  var d = this.curve._mulA(a);\n  // E = (X1 + Y1)^2 - A - B\n  var e = this.x.redAdd(this.y).redSqr().redISub(a).redISub(b);\n  // G = D + B\n  var g = d.redAdd(b);\n  // F = G - C\n  var f = g.redSub(c);\n  // H = D - B\n  var h = d.redSub(b);\n  // X3 = E * F\n  var nx = e.redMul(f);\n  // Y3 = G * H\n  var ny = g.redMul(h);\n  // T3 = E * H\n  var nt = e.redMul(h);\n  // Z3 = F * G\n  var nz = f.redMul(g);\n  return this.curve.point(nx, ny, nz, nt);\n};\n\nPoint.prototype._projDbl = function _projDbl() {\n  // hyperelliptic.org/EFD/g1p/auto-twisted-projective.html\n  //     #doubling-dbl-2008-bbjlp\n  //     #doubling-dbl-2007-bl\n  // and others\n  // Generally 3M + 4S or 2M + 4S\n\n  // B = (X1 + Y1)^2\n  var b = this.x.redAdd(this.y).redSqr();\n  // C = X1^2\n  var c = this.x.redSqr();\n  // D = Y1^2\n  var d = this.y.redSqr();\n\n  var nx;\n  var ny;\n  var nz;\n  var e;\n  var h;\n  var j;\n  if (this.curve.twisted) {\n    // E = a * C\n    e = this.curve._mulA(c);\n    // F = E + D\n    var f = e.redAdd(d);\n    if (this.zOne) {\n      // X3 = (B - C - D) * (F - 2)\n      nx = b.redSub(c).redSub(d).redMul(f.redSub(this.curve.two));\n      // Y3 = F * (E - D)\n      ny = f.redMul(e.redSub(d));\n      // Z3 = F^2 - 2 * F\n      nz = f.redSqr().redSub(f).redSub(f);\n    } else {\n      // H = Z1^2\n      h = this.z.redSqr();\n      // J = F - 2 * H\n      j = f.redSub(h).redISub(h);\n      // X3 = (B-C-D)*J\n      nx = b.redSub(c).redISub(d).redMul(j);\n      // Y3 = F * (E - D)\n      ny = f.redMul(e.redSub(d));\n      // Z3 = F * J\n      nz = f.redMul(j);\n    }\n  } else {\n    // E = C + D\n    e = c.redAdd(d);\n    // H = (c * Z1)^2\n    h = this.curve._mulC(this.z).redSqr();\n    // J = E - 2 * H\n    j = e.redSub(h).redSub(h);\n    // X3 = c * (B - E) * J\n    nx = this.curve._mulC(b.redISub(e)).redMul(j);\n    // Y3 = c * E * (C - D)\n    ny = this.curve._mulC(e).redMul(c.redISub(d));\n    // Z3 = E * J\n    nz = e.redMul(j);\n  }\n  return this.curve.point(nx, ny, nz);\n};\n\nPoint.prototype.dbl = function dbl() {\n  if (this.isInfinity())\n    return this;\n\n  // Double in extended coordinates\n  if (this.curve.extended)\n    return this._extDbl();\n  else\n    return this._projDbl();\n};\n\nPoint.prototype._extAdd = function _extAdd(p) {\n  // hyperelliptic.org/EFD/g1p/auto-twisted-extended-1.html\n  //     #addition-add-2008-hwcd-3\n  // 8M\n\n  // A = (Y1 - X1) * (Y2 - X2)\n  var a = this.y.redSub(this.x).redMul(p.y.redSub(p.x));\n  // B = (Y1 + X1) * (Y2 + X2)\n  var b = this.y.redAdd(this.x).redMul(p.y.redAdd(p.x));\n  // C = T1 * k * T2\n  var c = this.t.redMul(this.curve.dd).redMul(p.t);\n  // D = Z1 * 2 * Z2\n  var d = this.z.redMul(p.z.redAdd(p.z));\n  // E = B - A\n  var e = b.redSub(a);\n  // F = D - C\n  var f = d.redSub(c);\n  // G = D + C\n  var g = d.redAdd(c);\n  // H = B + A\n  var h = b.redAdd(a);\n  // X3 = E * F\n  var nx = e.redMul(f);\n  // Y3 = G * H\n  var ny = g.redMul(h);\n  // T3 = E * H\n  var nt = e.redMul(h);\n  // Z3 = F * G\n  var nz = f.redMul(g);\n  return this.curve.point(nx, ny, nz, nt);\n};\n\nPoint.prototype._projAdd = function _projAdd(p) {\n  // hyperelliptic.org/EFD/g1p/auto-twisted-projective.html\n  //     #addition-add-2008-bbjlp\n  //     #addition-add-2007-bl\n  // 10M + 1S\n\n  // A = Z1 * Z2\n  var a = this.z.redMul(p.z);\n  // B = A^2\n  var b = a.redSqr();\n  // C = X1 * X2\n  var c = this.x.redMul(p.x);\n  // D = Y1 * Y2\n  var d = this.y.redMul(p.y);\n  // E = d * C * D\n  var e = this.curve.d.redMul(c).redMul(d);\n  // F = B - E\n  var f = b.redSub(e);\n  // G = B + E\n  var g = b.redAdd(e);\n  // X3 = A * F * ((X1 + Y1) * (X2 + Y2) - C - D)\n  var tmp = this.x.redAdd(this.y).redMul(p.x.redAdd(p.y)).redISub(c).redISub(d);\n  var nx = a.redMul(f).redMul(tmp);\n  var ny;\n  var nz;\n  if (this.curve.twisted) {\n    // Y3 = A * G * (D - a * C)\n    ny = a.redMul(g).redMul(d.redSub(this.curve._mulA(c)));\n    // Z3 = F * G\n    nz = f.redMul(g);\n  } else {\n    // Y3 = A * G * (D - C)\n    ny = a.redMul(g).redMul(d.redSub(c));\n    // Z3 = c * F * G\n    nz = this.curve._mulC(f).redMul(g);\n  }\n  return this.curve.point(nx, ny, nz);\n};\n\nPoint.prototype.add = function add(p) {\n  if (this.isInfinity())\n    return p;\n  if (p.isInfinity())\n    return this;\n\n  if (this.curve.extended)\n    return this._extAdd(p);\n  else\n    return this._projAdd(p);\n};\n\nPoint.prototype.mul = function mul(k) {\n  if (this._hasDoubles(k))\n    return this.curve._fixedNafMul(this, k);\n  else\n    return this.curve._wnafMul(this, k);\n};\n\nPoint.prototype.mulAdd = function mulAdd(k1, p, k2) {\n  return this.curve._wnafMulAdd(1, [ this, p ], [ k1, k2 ], 2, false);\n};\n\nPoint.prototype.jmulAdd = function jmulAdd(k1, p, k2) {\n  return this.curve._wnafMulAdd(1, [ this, p ], [ k1, k2 ], 2, true);\n};\n\nPoint.prototype.normalize = function normalize() {\n  if (this.zOne)\n    return this;\n\n  // Normalize coordinates\n  var zi = this.z.redInvm();\n  this.x = this.x.redMul(zi);\n  this.y = this.y.redMul(zi);\n  if (this.t)\n    this.t = this.t.redMul(zi);\n  this.z = this.curve.one;\n  this.zOne = true;\n  return this;\n};\n\nPoint.prototype.neg = function neg() {\n  return this.curve.point(this.x.redNeg(),\n    this.y,\n    this.z,\n    this.t && this.t.redNeg());\n};\n\nPoint.prototype.getX = function getX() {\n  this.normalize();\n  return this.x.fromRed();\n};\n\nPoint.prototype.getY = function getY() {\n  this.normalize();\n  return this.y.fromRed();\n};\n\nPoint.prototype.eq = function eq(other) {\n  return this === other ||\n         this.getX().cmp(other.getX()) === 0 &&\n         this.getY().cmp(other.getY()) === 0;\n};\n\nPoint.prototype.eqXToP = function eqXToP(x) {\n  var rx = x.toRed(this.curve.red).redMul(this.z);\n  if (this.x.cmp(rx) === 0)\n    return true;\n\n  var xc = x.clone();\n  var t = this.curve.redN.redMul(this.z);\n  for (;;) {\n    xc.iadd(this.curve.n);\n    if (xc.cmp(this.curve.p) >= 0)\n      return false;\n\n    rx.redIAdd(t);\n    if (this.x.cmp(rx) === 0)\n      return true;\n  }\n};\n\n// Compatibility with BaseCurve\nPoint.prototype.toP = Point.prototype.normalize;\nPoint.prototype.mixedAdd = Point.prototype.add;\n",
    "'use strict';\n\nvar curve = exports;\n\ncurve.base = require('./base');\ncurve.short = require('./short');\ncurve.mont = require('./mont');\ncurve.edwards = require('./edwards');\n",
    "'use strict';\n\nvar assert = require('minimalistic-assert');\nvar inherits = require('inherits');\n\nexports.inherits = inherits;\n\nfunction isSurrogatePair(msg, i) {\n  if ((msg.charCodeAt(i) & 0xFC00) !== 0xD800) {\n    return false;\n  }\n  if (i < 0 || i + 1 >= msg.length) {\n    return false;\n  }\n  return (msg.charCodeAt(i + 1) & 0xFC00) === 0xDC00;\n}\n\nfunction toArray(msg, enc) {\n  if (Array.isArray(msg))\n    return msg.slice();\n  if (!msg)\n    return [];\n  var res = [];\n  if (typeof msg === 'string') {\n    if (!enc) {\n      // Inspired by stringToUtf8ByteArray() in closure-library by Google\n      // https://github.com/google/closure-library/blob/8598d87242af59aac233270742c8984e2b2bdbe0/closure/goog/crypt/crypt.js#L117-L143\n      // Apache License 2.0\n      // https://github.com/google/closure-library/blob/master/LICENSE\n      var p = 0;\n      for (var i = 0; i < msg.length; i++) {\n        var c = msg.charCodeAt(i);\n        if (c < 128) {\n          res[p++] = c;\n        } else if (c < 2048) {\n          res[p++] = (c >> 6) | 192;\n          res[p++] = (c & 63) | 128;\n        } else if (isSurrogatePair(msg, i)) {\n          c = 0x10000 + ((c & 0x03FF) << 10) + (msg.charCodeAt(++i) & 0x03FF);\n          res[p++] = (c >> 18) | 240;\n          res[p++] = ((c >> 12) & 63) | 128;\n          res[p++] = ((c >> 6) & 63) | 128;\n          res[p++] = (c & 63) | 128;\n        } else {\n          res[p++] = (c >> 12) | 224;\n          res[p++] = ((c >> 6) & 63) | 128;\n          res[p++] = (c & 63) | 128;\n        }\n      }\n    } else if (enc === 'hex') {\n      msg = msg.replace(/[^a-z0-9]+/ig, '');\n      if (msg.length % 2 !== 0)\n        msg = '0' + msg;\n      for (i = 0; i < msg.length; i += 2)\n        res.push(parseInt(msg[i] + msg[i + 1], 16));\n    }\n  } else {\n    for (i = 0; i < msg.length; i++)\n      res[i] = msg[i] | 0;\n  }\n  return res;\n}\nexports.toArray = toArray;\n\nfunction toHex(msg) {\n  var res = '';\n  for (var i = 0; i < msg.length; i++)\n    res += zero2(msg[i].toString(16));\n  return res;\n}\nexports.toHex = toHex;\n\nfunction htonl(w) {\n  var res = (w >>> 24) |\n            ((w >>> 8) & 0xff00) |\n            ((w << 8) & 0xff0000) |\n            ((w & 0xff) << 24);\n  return res >>> 0;\n}\nexports.htonl = htonl;\n\nfunction toHex32(msg, endian) {\n  var res = '';\n  for (var i = 0; i < msg.length; i++) {\n    var w = msg[i];\n    if (endian === 'little')\n      w = htonl(w);\n    res += zero8(w.toString(16));\n  }\n  return res;\n}\nexports.toHex32 = toHex32;\n\nfunction zero2(word) {\n  if (word.length === 1)\n    return '0' + word;\n  else\n    return word;\n}\nexports.zero2 = zero2;\n\nfunction zero8(word) {\n  if (word.length === 7)\n    return '0' + word;\n  else if (word.length === 6)\n    return '00' + word;\n  else if (word.length === 5)\n    return '000' + word;\n  else if (word.length === 4)\n    return '0000' + word;\n  else if (word.length === 3)\n    return '00000' + word;\n  else if (word.length === 2)\n    return '000000' + word;\n  else if (word.length === 1)\n    return '0000000' + word;\n  else\n    return word;\n}\nexports.zero8 = zero8;\n\nfunction join32(msg, start, end, endian) {\n  var len = end - start;\n  assert(len % 4 === 0);\n  var res = new Array(len / 4);\n  for (var i = 0, k = start; i < res.length; i++, k += 4) {\n    var w;\n    if (endian === 'big')\n      w = (msg[k] << 24) | (msg[k + 1] << 16) | (msg[k + 2] << 8) | msg[k + 3];\n    else\n      w = (msg[k + 3] << 24) | (msg[k + 2] << 16) | (msg[k + 1] << 8) | msg[k];\n    res[i] = w >>> 0;\n  }\n  return res;\n}\nexports.join32 = join32;\n\nfunction split32(msg, endian) {\n  var res = new Array(msg.length * 4);\n  for (var i = 0, k = 0; i < msg.length; i++, k += 4) {\n    var m = msg[i];\n    if (endian === 'big') {\n      res[k] = m >>> 24;\n      res[k + 1] = (m >>> 16) & 0xff;\n      res[k + 2] = (m >>> 8) & 0xff;\n      res[k + 3] = m & 0xff;\n    } else {\n      res[k + 3] = m >>> 24;\n      res[k + 2] = (m >>> 16) & 0xff;\n      res[k + 1] = (m >>> 8) & 0xff;\n      res[k] = m & 0xff;\n    }\n  }\n  return res;\n}\nexports.split32 = split32;\n\nfunction rotr32(w, b) {\n  return (w >>> b) | (w << (32 - b));\n}\nexports.rotr32 = rotr32;\n\nfunction rotl32(w, b) {\n  return (w << b) | (w >>> (32 - b));\n}\nexports.rotl32 = rotl32;\n\nfunction sum32(a, b) {\n  return (a + b) >>> 0;\n}\nexports.sum32 = sum32;\n\nfunction sum32_3(a, b, c) {\n  return (a + b + c) >>> 0;\n}\nexports.sum32_3 = sum32_3;\n\nfunction sum32_4(a, b, c, d) {\n  return (a + b + c + d) >>> 0;\n}\nexports.sum32_4 = sum32_4;\n\nfunction sum32_5(a, b, c, d, e) {\n  return (a + b + c + d + e) >>> 0;\n}\nexports.sum32_5 = sum32_5;\n\nfunction sum64(buf, pos, ah, al) {\n  var bh = buf[pos];\n  var bl = buf[pos + 1];\n\n  var lo = (al + bl) >>> 0;\n  var hi = (lo < al ? 1 : 0) + ah + bh;\n  buf[pos] = hi >>> 0;\n  buf[pos + 1] = lo;\n}\nexports.sum64 = sum64;\n\nfunction sum64_hi(ah, al, bh, bl) {\n  var lo = (al + bl) >>> 0;\n  var hi = (lo < al ? 1 : 0) + ah + bh;\n  return hi >>> 0;\n}\nexports.sum64_hi = sum64_hi;\n\nfunction sum64_lo(ah, al, bh, bl) {\n  var lo = al + bl;\n  return lo >>> 0;\n}\nexports.sum64_lo = sum64_lo;\n\nfunction sum64_4_hi(ah, al, bh, bl, ch, cl, dh, dl) {\n  var carry = 0;\n  var lo = al;\n  lo = (lo + bl) >>> 0;\n  carry += lo < al ? 1 : 0;\n  lo = (lo + cl) >>> 0;\n  carry += lo < cl ? 1 : 0;\n  lo = (lo + dl) >>> 0;\n  carry += lo < dl ? 1 : 0;\n\n  var hi = ah + bh + ch + dh + carry;\n  return hi >>> 0;\n}\nexports.sum64_4_hi = sum64_4_hi;\n\nfunction sum64_4_lo(ah, al, bh, bl, ch, cl, dh, dl) {\n  var lo = al + bl + cl + dl;\n  return lo >>> 0;\n}\nexports.sum64_4_lo = sum64_4_lo;\n\nfunction sum64_5_hi(ah, al, bh, bl, ch, cl, dh, dl, eh, el) {\n  var carry = 0;\n  var lo = al;\n  lo = (lo + bl) >>> 0;\n  carry += lo < al ? 1 : 0;\n  lo = (lo + cl) >>> 0;\n  carry += lo < cl ? 1 : 0;\n  lo = (lo + dl) >>> 0;\n  carry += lo < dl ? 1 : 0;\n  lo = (lo + el) >>> 0;\n  carry += lo < el ? 1 : 0;\n\n  var hi = ah + bh + ch + dh + eh + carry;\n  return hi >>> 0;\n}\nexports.sum64_5_hi = sum64_5_hi;\n\nfunction sum64_5_lo(ah, al, bh, bl, ch, cl, dh, dl, eh, el) {\n  var lo = al + bl + cl + dl + el;\n\n  return lo >>> 0;\n}\nexports.sum64_5_lo = sum64_5_lo;\n\nfunction rotr64_hi(ah, al, num) {\n  var r = (al << (32 - num)) | (ah >>> num);\n  return r >>> 0;\n}\nexports.rotr64_hi = rotr64_hi;\n\nfunction rotr64_lo(ah, al, num) {\n  var r = (ah << (32 - num)) | (al >>> num);\n  return r >>> 0;\n}\nexports.rotr64_lo = rotr64_lo;\n\nfunction shr64_hi(ah, al, num) {\n  return ah >>> num;\n}\nexports.shr64_hi = shr64_hi;\n\nfunction shr64_lo(ah, al, num) {\n  var r = (ah << (32 - num)) | (al >>> num);\n  return r >>> 0;\n}\nexports.shr64_lo = shr64_lo;\n",
    "'use strict';\n\nvar utils = require('./utils');\nvar assert = require('minimalistic-assert');\n\nfunction BlockHash() {\n  this.pending = null;\n  this.pendingTotal = 0;\n  this.blockSize = this.constructor.blockSize;\n  this.outSize = this.constructor.outSize;\n  this.hmacStrength = this.constructor.hmacStrength;\n  this.padLength = this.constructor.padLength / 8;\n  this.endian = 'big';\n\n  this._delta8 = this.blockSize / 8;\n  this._delta32 = this.blockSize / 32;\n}\nexports.BlockHash = BlockHash;\n\nBlockHash.prototype.update = function update(msg, enc) {\n  // Convert message to array, pad it, and join into 32bit blocks\n  msg = utils.toArray(msg, enc);\n  if (!this.pending)\n    this.pending = msg;\n  else\n    this.pending = this.pending.concat(msg);\n  this.pendingTotal += msg.length;\n\n  // Enough data, try updating\n  if (this.pending.length >= this._delta8) {\n    msg = this.pending;\n\n    // Process pending data in blocks\n    var r = msg.length % this._delta8;\n    this.pending = msg.slice(msg.length - r, msg.length);\n    if (this.pending.length === 0)\n      this.pending = null;\n\n    msg = utils.join32(msg, 0, msg.length - r, this.endian);\n    for (var i = 0; i < msg.length; i += this._delta32)\n      this._update(msg, i, i + this._delta32);\n  }\n\n  return this;\n};\n\nBlockHash.prototype.digest = function digest(enc) {\n  this.update(this._pad());\n  assert(this.pending === null);\n\n  return this._digest(enc);\n};\n\nBlockHash.prototype._pad = function pad() {\n  var len = this.pendingTotal;\n  var bytes = this._delta8;\n  var k = bytes - ((len + this.padLength) % bytes);\n  var res = new Array(k + this.padLength);\n  res[0] = 0x80;\n  for (var i = 1; i < k; i++)\n    res[i] = 0;\n\n  // Append length\n  len <<= 3;\n  if (this.endian === 'big') {\n    for (var t = 8; t < this.padLength; t++)\n      res[i++] = 0;\n\n    res[i++] = 0;\n    res[i++] = 0;\n    res[i++] = 0;\n    res[i++] = 0;\n    res[i++] = (len >>> 24) & 0xff;\n    res[i++] = (len >>> 16) & 0xff;\n    res[i++] = (len >>> 8) & 0xff;\n    res[i++] = len & 0xff;\n  } else {\n    res[i++] = len & 0xff;\n    res[i++] = (len >>> 8) & 0xff;\n    res[i++] = (len >>> 16) & 0xff;\n    res[i++] = (len >>> 24) & 0xff;\n    res[i++] = 0;\n    res[i++] = 0;\n    res[i++] = 0;\n    res[i++] = 0;\n\n    for (t = 8; t < this.padLength; t++)\n      res[i++] = 0;\n  }\n\n  return res;\n};\n",
    "'use strict';\n\nvar utils = require('../utils');\nvar rotr32 = utils.rotr32;\n\nfunction ft_1(s, x, y, z) {\n  if (s === 0)\n    return ch32(x, y, z);\n  if (s === 1 || s === 3)\n    return p32(x, y, z);\n  if (s === 2)\n    return maj32(x, y, z);\n}\nexports.ft_1 = ft_1;\n\nfunction ch32(x, y, z) {\n  return (x & y) ^ ((~x) & z);\n}\nexports.ch32 = ch32;\n\nfunction maj32(x, y, z) {\n  return (x & y) ^ (x & z) ^ (y & z);\n}\nexports.maj32 = maj32;\n\nfunction p32(x, y, z) {\n  return x ^ y ^ z;\n}\nexports.p32 = p32;\n\nfunction s0_256(x) {\n  return rotr32(x, 2) ^ rotr32(x, 13) ^ rotr32(x, 22);\n}\nexports.s0_256 = s0_256;\n\nfunction s1_256(x) {\n  return rotr32(x, 6) ^ rotr32(x, 11) ^ rotr32(x, 25);\n}\nexports.s1_256 = s1_256;\n\nfunction g0_256(x) {\n  return rotr32(x, 7) ^ rotr32(x, 18) ^ (x >>> 3);\n}\nexports.g0_256 = g0_256;\n\nfunction g1_256(x) {\n  return rotr32(x, 17) ^ rotr32(x, 19) ^ (x >>> 10);\n}\nexports.g1_256 = g1_256;\n",
    "'use strict';\n\nvar utils = require('../utils');\nvar common = require('../common');\nvar shaCommon = require('./common');\n\nvar rotl32 = utils.rotl32;\nvar sum32 = utils.sum32;\nvar sum32_5 = utils.sum32_5;\nvar ft_1 = shaCommon.ft_1;\nvar BlockHash = common.BlockHash;\n\nvar sha1_K = [\n  0x5A827999, 0x6ED9EBA1,\n  0x8F1BBCDC, 0xCA62C1D6\n];\n\nfunction SHA1() {\n  if (!(this instanceof SHA1))\n    return new SHA1();\n\n  BlockHash.call(this);\n  this.h = [\n    0x67452301, 0xefcdab89, 0x98badcfe,\n    0x10325476, 0xc3d2e1f0 ];\n  this.W = new Array(80);\n}\n\nutils.inherits(SHA1, BlockHash);\nmodule.exports = SHA1;\n\nSHA1.blockSize = 512;\nSHA1.outSize = 160;\nSHA1.hmacStrength = 80;\nSHA1.padLength = 64;\n\nSHA1.prototype._update = function _update(msg, start) {\n  var W = this.W;\n\n  for (var i = 0; i < 16; i++)\n    W[i] = msg[start + i];\n\n  for(; i < W.length; i++)\n    W[i] = rotl32(W[i - 3] ^ W[i - 8] ^ W[i - 14] ^ W[i - 16], 1);\n\n  var a = this.h[0];\n  var b = this.h[1];\n  var c = this.h[2];\n  var d = this.h[3];\n  var e = this.h[4];\n\n  for (i = 0; i < W.length; i++) {\n    var s = ~~(i / 20);\n    var t = sum32_5(rotl32(a, 5), ft_1(s, b, c, d), e, W[i], sha1_K[s]);\n    e = d;\n    d = c;\n    c = rotl32(b, 30);\n    b = a;\n    a = t;\n  }\n\n  this.h[0] = sum32(this.h[0], a);\n  this.h[1] = sum32(this.h[1], b);\n  this.h[2] = sum32(this.h[2], c);\n  this.h[3] = sum32(this.h[3], d);\n  this.h[4] = sum32(this.h[4], e);\n};\n\nSHA1.prototype._digest = function digest(enc) {\n  if (enc === 'hex')\n    return utils.toHex32(this.h, 'big');\n  else\n    return utils.split32(this.h, 'big');\n};\n",
    "'use strict';\n\nvar utils = require('../utils');\nvar common = require('../common');\nvar shaCommon = require('./common');\nvar assert = require('minimalistic-assert');\n\nvar sum32 = utils.sum32;\nvar sum32_4 = utils.sum32_4;\nvar sum32_5 = utils.sum32_5;\nvar ch32 = shaCommon.ch32;\nvar maj32 = shaCommon.maj32;\nvar s0_256 = shaCommon.s0_256;\nvar s1_256 = shaCommon.s1_256;\nvar g0_256 = shaCommon.g0_256;\nvar g1_256 = shaCommon.g1_256;\n\nvar BlockHash = common.BlockHash;\n\nvar sha256_K = [\n  0x428a2f98, 0x71374491, 0xb5c0fbcf, 0xe9b5dba5,\n  0x3956c25b, 0x59f111f1, 0x923f82a4, 0xab1c5ed5,\n  0xd807aa98, 0x12835b01, 0x243185be, 0x550c7dc3,\n  0x72be5d74, 0x80deb1fe, 0x9bdc06a7, 0xc19bf174,\n  0xe49b69c1, 0xefbe4786, 0x0fc19dc6, 0x240ca1cc,\n  0x2de92c6f, 0x4a7484aa, 0x5cb0a9dc, 0x76f988da,\n  0x983e5152, 0xa831c66d, 0xb00327c8, 0xbf597fc7,\n  0xc6e00bf3, 0xd5a79147, 0x06ca6351, 0x14292967,\n  0x27b70a85, 0x2e1b2138, 0x4d2c6dfc, 0x53380d13,\n  0x650a7354, 0x766a0abb, 0x81c2c92e, 0x92722c85,\n  0xa2bfe8a1, 0xa81a664b, 0xc24b8b70, 0xc76c51a3,\n  0xd192e819, 0xd6990624, 0xf40e3585, 0x106aa070,\n  0x19a4c116, 0x1e376c08, 0x2748774c, 0x34b0bcb5,\n  0x391c0cb3, 0x4ed8aa4a, 0x5b9cca4f, 0x682e6ff3,\n  0x748f82ee, 0x78a5636f, 0x84c87814, 0x8cc70208,\n  0x90befffa, 0xa4506ceb, 0xbef9a3f7, 0xc67178f2\n];\n\nfunction SHA256() {\n  if (!(this instanceof SHA256))\n    return new SHA256();\n\n  BlockHash.call(this);\n  this.h = [\n    0x6a09e667, 0xbb67ae85, 0x3c6ef372, 0xa54ff53a,\n    0x510e527f, 0x9b05688c, 0x1f83d9ab, 0x5be0cd19\n  ];\n  this.k = sha256_K;\n  this.W = new Array(64);\n}\nutils.inherits(SHA256, BlockHash);\nmodule.exports = SHA256;\n\nSHA256.blockSize = 512;\nSHA256.outSize = 256;\nSHA256.hmacStrength = 192;\nSHA256.padLength = 64;\n\nSHA256.prototype._update = function _update(msg, start) {\n  var W = this.W;\n\n  for (var i = 0; i < 16; i++)\n    W[i] = msg[start + i];\n  for (; i < W.length; i++)\n    W[i] = sum32_4(g1_256(W[i - 2]), W[i - 7], g0_256(W[i - 15]), W[i - 16]);\n\n  var a = this.h[0];\n  var b = this.h[1];\n  var c = this.h[2];\n  var d = this.h[3];\n  var e = this.h[4];\n  var f = this.h[5];\n  var g = this.h[6];\n  var h = this.h[7];\n\n  assert(this.k.length === W.length);\n  for (i = 0; i < W.length; i++) {\n    var T1 = sum32_5(h, s1_256(e), ch32(e, f, g), this.k[i], W[i]);\n    var T2 = sum32(s0_256(a), maj32(a, b, c));\n    h = g;\n    g = f;\n    f = e;\n    e = sum32(d, T1);\n    d = c;\n    c = b;\n    b = a;\n    a = sum32(T1, T2);\n  }\n\n  this.h[0] = sum32(this.h[0], a);\n  this.h[1] = sum32(this.h[1], b);\n  this.h[2] = sum32(this.h[2], c);\n  this.h[3] = sum32(this.h[3], d);\n  this.h[4] = sum32(this.h[4], e);\n  this.h[5] = sum32(this.h[5], f);\n  this.h[6] = sum32(this.h[6], g);\n  this.h[7] = sum32(this.h[7], h);\n};\n\nSHA256.prototype._digest = function digest(enc) {\n  if (enc === 'hex')\n    return utils.toHex32(this.h, 'big');\n  else\n    return utils.split32(this.h, 'big');\n};\n",
    "'use strict';\n\nvar utils = require('../utils');\nvar SHA256 = require('./256');\n\nfunction SHA224() {\n  if (!(this instanceof SHA224))\n    return new SHA224();\n\n  SHA256.call(this);\n  this.h = [\n    0xc1059ed8, 0x367cd507, 0x3070dd17, 0xf70e5939,\n    0xffc00b31, 0x68581511, 0x64f98fa7, 0xbefa4fa4 ];\n}\nutils.inherits(SHA224, SHA256);\nmodule.exports = SHA224;\n\nSHA224.blockSize = 512;\nSHA224.outSize = 224;\nSHA224.hmacStrength = 192;\nSHA224.padLength = 64;\n\nSHA224.prototype._digest = function digest(enc) {\n  // Just truncate output\n  if (enc === 'hex')\n    return utils.toHex32(this.h.slice(0, 7), 'big');\n  else\n    return utils.split32(this.h.slice(0, 7), 'big');\n};\n\n",
    "'use strict';\n\nvar utils = require('../utils');\nvar common = require('../common');\nvar assert = require('minimalistic-assert');\n\nvar rotr64_hi = utils.rotr64_hi;\nvar rotr64_lo = utils.rotr64_lo;\nvar shr64_hi = utils.shr64_hi;\nvar shr64_lo = utils.shr64_lo;\nvar sum64 = utils.sum64;\nvar sum64_hi = utils.sum64_hi;\nvar sum64_lo = utils.sum64_lo;\nvar sum64_4_hi = utils.sum64_4_hi;\nvar sum64_4_lo = utils.sum64_4_lo;\nvar sum64_5_hi = utils.sum64_5_hi;\nvar sum64_5_lo = utils.sum64_5_lo;\n\nvar BlockHash = common.BlockHash;\n\nvar sha512_K = [\n  0x428a2f98, 0xd728ae22, 0x71374491, 0x23ef65cd,\n  0xb5c0fbcf, 0xec4d3b2f, 0xe9b5dba5, 0x8189dbbc,\n  0x3956c25b, 0xf348b538, 0x59f111f1, 0xb605d019,\n  0x923f82a4, 0xaf194f9b, 0xab1c5ed5, 0xda6d8118,\n  0xd807aa98, 0xa3030242, 0x12835b01, 0x45706fbe,\n  0x243185be, 0x4ee4b28c, 0x550c7dc3, 0xd5ffb4e2,\n  0x72be5d74, 0xf27b896f, 0x80deb1fe, 0x3b1696b1,\n  0x9bdc06a7, 0x25c71235, 0xc19bf174, 0xcf692694,\n  0xe49b69c1, 0x9ef14ad2, 0xefbe4786, 0x384f25e3,\n  0x0fc19dc6, 0x8b8cd5b5, 0x240ca1cc, 0x77ac9c65,\n  0x2de92c6f, 0x592b0275, 0x4a7484aa, 0x6ea6e483,\n  0x5cb0a9dc, 0xbd41fbd4, 0x76f988da, 0x831153b5,\n  0x983e5152, 0xee66dfab, 0xa831c66d, 0x2db43210,\n  0xb00327c8, 0x98fb213f, 0xbf597fc7, 0xbeef0ee4,\n  0xc6e00bf3, 0x3da88fc2, 0xd5a79147, 0x930aa725,\n  0x06ca6351, 0xe003826f, 0x14292967, 0x0a0e6e70,\n  0x27b70a85, 0x46d22ffc, 0x2e1b2138, 0x5c26c926,\n  0x4d2c6dfc, 0x5ac42aed, 0x53380d13, 0x9d95b3df,\n  0x650a7354, 0x8baf63de, 0x766a0abb, 0x3c77b2a8,\n  0x81c2c92e, 0x47edaee6, 0x92722c85, 0x1482353b,\n  0xa2bfe8a1, 0x4cf10364, 0xa81a664b, 0xbc423001,\n  0xc24b8b70, 0xd0f89791, 0xc76c51a3, 0x0654be30,\n  0xd192e819, 0xd6ef5218, 0xd6990624, 0x5565a910,\n  0xf40e3585, 0x5771202a, 0x106aa070, 0x32bbd1b8,\n  0x19a4c116, 0xb8d2d0c8, 0x1e376c08, 0x5141ab53,\n  0x2748774c, 0xdf8eeb99, 0x34b0bcb5, 0xe19b48a8,\n  0x391c0cb3, 0xc5c95a63, 0x4ed8aa4a, 0xe3418acb,\n  0x5b9cca4f, 0x7763e373, 0x682e6ff3, 0xd6b2b8a3,\n  0x748f82ee, 0x5defb2fc, 0x78a5636f, 0x43172f60,\n  0x84c87814, 0xa1f0ab72, 0x8cc70208, 0x1a6439ec,\n  0x90befffa, 0x23631e28, 0xa4506ceb, 0xde82bde9,\n  0xbef9a3f7, 0xb2c67915, 0xc67178f2, 0xe372532b,\n  0xca273ece, 0xea26619c, 0xd186b8c7, 0x21c0c207,\n  0xeada7dd6, 0xcde0eb1e, 0xf57d4f7f, 0xee6ed178,\n  0x06f067aa, 0x72176fba, 0x0a637dc5, 0xa2c898a6,\n  0x113f9804, 0xbef90dae, 0x1b710b35, 0x131c471b,\n  0x28db77f5, 0x23047d84, 0x32caab7b, 0x40c72493,\n  0x3c9ebe0a, 0x15c9bebc, 0x431d67c4, 0x9c100d4c,\n  0x4cc5d4be, 0xcb3e42b6, 0x597f299c, 0xfc657e2a,\n  0x5fcb6fab, 0x3ad6faec, 0x6c44198c, 0x4a475817\n];\n\nfunction SHA512() {\n  if (!(this instanceof SHA512))\n    return new SHA512();\n\n  BlockHash.call(this);\n  this.h = [\n    0x6a09e667, 0xf3bcc908,\n    0xbb67ae85, 0x84caa73b,\n    0x3c6ef372, 0xfe94f82b,\n    0xa54ff53a, 0x5f1d36f1,\n    0x510e527f, 0xade682d1,\n    0x9b05688c, 0x2b3e6c1f,\n    0x1f83d9ab, 0xfb41bd6b,\n    0x5be0cd19, 0x137e2179 ];\n  this.k = sha512_K;\n  this.W = new Array(160);\n}\nutils.inherits(SHA512, BlockHash);\nmodule.exports = SHA512;\n\nSHA512.blockSize = 1024;\nSHA512.outSize = 512;\nSHA512.hmacStrength = 192;\nSHA512.padLength = 128;\n\nSHA512.prototype._prepareBlock = function _prepareBlock(msg, start) {\n  var W = this.W;\n\n  // 32 x 32bit words\n  for (var i = 0; i < 32; i++)\n    W[i] = msg[start + i];\n  for (; i < W.length; i += 2) {\n    var c0_hi = g1_512_hi(W[i - 4], W[i - 3]);  // i - 2\n    var c0_lo = g1_512_lo(W[i - 4], W[i - 3]);\n    var c1_hi = W[i - 14];  // i - 7\n    var c1_lo = W[i - 13];\n    var c2_hi = g0_512_hi(W[i - 30], W[i - 29]);  // i - 15\n    var c2_lo = g0_512_lo(W[i - 30], W[i - 29]);\n    var c3_hi = W[i - 32];  // i - 16\n    var c3_lo = W[i - 31];\n\n    W[i] = sum64_4_hi(\n      c0_hi, c0_lo,\n      c1_hi, c1_lo,\n      c2_hi, c2_lo,\n      c3_hi, c3_lo);\n    W[i + 1] = sum64_4_lo(\n      c0_hi, c0_lo,\n      c1_hi, c1_lo,\n      c2_hi, c2_lo,\n      c3_hi, c3_lo);\n  }\n};\n\nSHA512.prototype._update = function _update(msg, start) {\n  this._prepareBlock(msg, start);\n\n  var W = this.W;\n\n  var ah = this.h[0];\n  var al = this.h[1];\n  var bh = this.h[2];\n  var bl = this.h[3];\n  var ch = this.h[4];\n  var cl = this.h[5];\n  var dh = this.h[6];\n  var dl = this.h[7];\n  var eh = this.h[8];\n  var el = this.h[9];\n  var fh = this.h[10];\n  var fl = this.h[11];\n  var gh = this.h[12];\n  var gl = this.h[13];\n  var hh = this.h[14];\n  var hl = this.h[15];\n\n  assert(this.k.length === W.length);\n  for (var i = 0; i < W.length; i += 2) {\n    var c0_hi = hh;\n    var c0_lo = hl;\n    var c1_hi = s1_512_hi(eh, el);\n    var c1_lo = s1_512_lo(eh, el);\n    var c2_hi = ch64_hi(eh, el, fh, fl, gh, gl);\n    var c2_lo = ch64_lo(eh, el, fh, fl, gh, gl);\n    var c3_hi = this.k[i];\n    var c3_lo = this.k[i + 1];\n    var c4_hi = W[i];\n    var c4_lo = W[i + 1];\n\n    var T1_hi = sum64_5_hi(\n      c0_hi, c0_lo,\n      c1_hi, c1_lo,\n      c2_hi, c2_lo,\n      c3_hi, c3_lo,\n      c4_hi, c4_lo);\n    var T1_lo = sum64_5_lo(\n      c0_hi, c0_lo,\n      c1_hi, c1_lo,\n      c2_hi, c2_lo,\n      c3_hi, c3_lo,\n      c4_hi, c4_lo);\n\n    c0_hi = s0_512_hi(ah, al);\n    c0_lo = s0_512_lo(ah, al);\n    c1_hi = maj64_hi(ah, al, bh, bl, ch, cl);\n    c1_lo = maj64_lo(ah, al, bh, bl, ch, cl);\n\n    var T2_hi = sum64_hi(c0_hi, c0_lo, c1_hi, c1_lo);\n    var T2_lo = sum64_lo(c0_hi, c0_lo, c1_hi, c1_lo);\n\n    hh = gh;\n    hl = gl;\n\n    gh = fh;\n    gl = fl;\n\n    fh = eh;\n    fl = el;\n\n    eh = sum64_hi(dh, dl, T1_hi, T1_lo);\n    el = sum64_lo(dl, dl, T1_hi, T1_lo);\n\n    dh = ch;\n    dl = cl;\n\n    ch = bh;\n    cl = bl;\n\n    bh = ah;\n    bl = al;\n\n    ah = sum64_hi(T1_hi, T1_lo, T2_hi, T2_lo);\n    al = sum64_lo(T1_hi, T1_lo, T2_hi, T2_lo);\n  }\n\n  sum64(this.h, 0, ah, al);\n  sum64(this.h, 2, bh, bl);\n  sum64(this.h, 4, ch, cl);\n  sum64(this.h, 6, dh, dl);\n  sum64(this.h, 8, eh, el);\n  sum64(this.h, 10, fh, fl);\n  sum64(this.h, 12, gh, gl);\n  sum64(this.h, 14, hh, hl);\n};\n\nSHA512.prototype._digest = function digest(enc) {\n  if (enc === 'hex')\n    return utils.toHex32(this.h, 'big');\n  else\n    return utils.split32(this.h, 'big');\n};\n\nfunction ch64_hi(xh, xl, yh, yl, zh) {\n  var r = (xh & yh) ^ ((~xh) & zh);\n  if (r < 0)\n    r += 0x100000000;\n  return r;\n}\n\nfunction ch64_lo(xh, xl, yh, yl, zh, zl) {\n  var r = (xl & yl) ^ ((~xl) & zl);\n  if (r < 0)\n    r += 0x100000000;\n  return r;\n}\n\nfunction maj64_hi(xh, xl, yh, yl, zh) {\n  var r = (xh & yh) ^ (xh & zh) ^ (yh & zh);\n  if (r < 0)\n    r += 0x100000000;\n  return r;\n}\n\nfunction maj64_lo(xh, xl, yh, yl, zh, zl) {\n  var r = (xl & yl) ^ (xl & zl) ^ (yl & zl);\n  if (r < 0)\n    r += 0x100000000;\n  return r;\n}\n\nfunction s0_512_hi(xh, xl) {\n  var c0_hi = rotr64_hi(xh, xl, 28);\n  var c1_hi = rotr64_hi(xl, xh, 2);  // 34\n  var c2_hi = rotr64_hi(xl, xh, 7);  // 39\n\n  var r = c0_hi ^ c1_hi ^ c2_hi;\n  if (r < 0)\n    r += 0x100000000;\n  return r;\n}\n\nfunction s0_512_lo(xh, xl) {\n  var c0_lo = rotr64_lo(xh, xl, 28);\n  var c1_lo = rotr64_lo(xl, xh, 2);  // 34\n  var c2_lo = rotr64_lo(xl, xh, 7);  // 39\n\n  var r = c0_lo ^ c1_lo ^ c2_lo;\n  if (r < 0)\n    r += 0x100000000;\n  return r;\n}\n\nfunction s1_512_hi(xh, xl) {\n  var c0_hi = rotr64_hi(xh, xl, 14);\n  var c1_hi = rotr64_hi(xh, xl, 18);\n  var c2_hi = rotr64_hi(xl, xh, 9);  // 41\n\n  var r = c0_hi ^ c1_hi ^ c2_hi;\n  if (r < 0)\n    r += 0x100000000;\n  return r;\n}\n\nfunction s1_512_lo(xh, xl) {\n  var c0_lo = rotr64_lo(xh, xl, 14);\n  var c1_lo = rotr64_lo(xh, xl, 18);\n  var c2_lo = rotr64_lo(xl, xh, 9);  // 41\n\n  var r = c0_lo ^ c1_lo ^ c2_lo;\n  if (r < 0)\n    r += 0x100000000;\n  return r;\n}\n\nfunction g0_512_hi(xh, xl) {\n  var c0_hi = rotr64_hi(xh, xl, 1);\n  var c1_hi = rotr64_hi(xh, xl, 8);\n  var c2_hi = shr64_hi(xh, xl, 7);\n\n  var r = c0_hi ^ c1_hi ^ c2_hi;\n  if (r < 0)\n    r += 0x100000000;\n  return r;\n}\n\nfunction g0_512_lo(xh, xl) {\n  var c0_lo = rotr64_lo(xh, xl, 1);\n  var c1_lo = rotr64_lo(xh, xl, 8);\n  var c2_lo = shr64_lo(xh, xl, 7);\n\n  var r = c0_lo ^ c1_lo ^ c2_lo;\n  if (r < 0)\n    r += 0x100000000;\n  return r;\n}\n\nfunction g1_512_hi(xh, xl) {\n  var c0_hi = rotr64_hi(xh, xl, 19);\n  var c1_hi = rotr64_hi(xl, xh, 29);  // 61\n  var c2_hi = shr64_hi(xh, xl, 6);\n\n  var r = c0_hi ^ c1_hi ^ c2_hi;\n  if (r < 0)\n    r += 0x100000000;\n  return r;\n}\n\nfunction g1_512_lo(xh, xl) {\n  var c0_lo = rotr64_lo(xh, xl, 19);\n  var c1_lo = rotr64_lo(xl, xh, 29);  // 61\n  var c2_lo = shr64_lo(xh, xl, 6);\n\n  var r = c0_lo ^ c1_lo ^ c2_lo;\n  if (r < 0)\n    r += 0x100000000;\n  return r;\n}\n",
    "'use strict';\n\nvar utils = require('../utils');\n\nvar SHA512 = require('./512');\n\nfunction SHA384() {\n  if (!(this instanceof SHA384))\n    return new SHA384();\n\n  SHA512.call(this);\n  this.h = [\n    0xcbbb9d5d, 0xc1059ed8,\n    0x629a292a, 0x367cd507,\n    0x9159015a, 0x3070dd17,\n    0x152fecd8, 0xf70e5939,\n    0x67332667, 0xffc00b31,\n    0x8eb44a87, 0x68581511,\n    0xdb0c2e0d, 0x64f98fa7,\n    0x47b5481d, 0xbefa4fa4 ];\n}\nutils.inherits(SHA384, SHA512);\nmodule.exports = SHA384;\n\nSHA384.blockSize = 1024;\nSHA384.outSize = 384;\nSHA384.hmacStrength = 192;\nSHA384.padLength = 128;\n\nSHA384.prototype._digest = function digest(enc) {\n  if (enc === 'hex')\n    return utils.toHex32(this.h.slice(0, 12), 'big');\n  else\n    return utils.split32(this.h.slice(0, 12), 'big');\n};\n",
    "'use strict';\n\nexports.sha1 = require('./sha/1');\nexports.sha224 = require('./sha/224');\nexports.sha256 = require('./sha/256');\nexports.sha384 = require('./sha/384');\nexports.sha512 = require('./sha/512');\n",
    "'use strict';\n\nvar utils = require('./utils');\nvar common = require('./common');\n\nvar rotl32 = utils.rotl32;\nvar sum32 = utils.sum32;\nvar sum32_3 = utils.sum32_3;\nvar sum32_4 = utils.sum32_4;\nvar BlockHash = common.BlockHash;\n\nfunction RIPEMD160() {\n  if (!(this instanceof RIPEMD160))\n    return new RIPEMD160();\n\n  BlockHash.call(this);\n\n  this.h = [ 0x67452301, 0xefcdab89, 0x98badcfe, 0x10325476, 0xc3d2e1f0 ];\n  this.endian = 'little';\n}\nutils.inherits(RIPEMD160, BlockHash);\nexports.ripemd160 = RIPEMD160;\n\nRIPEMD160.blockSize = 512;\nRIPEMD160.outSize = 160;\nRIPEMD160.hmacStrength = 192;\nRIPEMD160.padLength = 64;\n\nRIPEMD160.prototype._update = function update(msg, start) {\n  var A = this.h[0];\n  var B = this.h[1];\n  var C = this.h[2];\n  var D = this.h[3];\n  var E = this.h[4];\n  var Ah = A;\n  var Bh = B;\n  var Ch = C;\n  var Dh = D;\n  var Eh = E;\n  for (var j = 0; j < 80; j++) {\n    var T = sum32(\n      rotl32(\n        sum32_4(A, f(j, B, C, D), msg[r[j] + start], K(j)),\n        s[j]),\n      E);\n    A = E;\n    E = D;\n    D = rotl32(C, 10);\n    C = B;\n    B = T;\n    T = sum32(\n      rotl32(\n        sum32_4(Ah, f(79 - j, Bh, Ch, Dh), msg[rh[j] + start], Kh(j)),\n        sh[j]),\n      Eh);\n    Ah = Eh;\n    Eh = Dh;\n    Dh = rotl32(Ch, 10);\n    Ch = Bh;\n    Bh = T;\n  }\n  T = sum32_3(this.h[1], C, Dh);\n  this.h[1] = sum32_3(this.h[2], D, Eh);\n  this.h[2] = sum32_3(this.h[3], E, Ah);\n  this.h[3] = sum32_3(this.h[4], A, Bh);\n  this.h[4] = sum32_3(this.h[0], B, Ch);\n  this.h[0] = T;\n};\n\nRIPEMD160.prototype._digest = function digest(enc) {\n  if (enc === 'hex')\n    return utils.toHex32(this.h, 'little');\n  else\n    return utils.split32(this.h, 'little');\n};\n\nfunction f(j, x, y, z) {\n  if (j <= 15)\n    return x ^ y ^ z;\n  else if (j <= 31)\n    return (x & y) | ((~x) & z);\n  else if (j <= 47)\n    return (x | (~y)) ^ z;\n  else if (j <= 63)\n    return (x & z) | (y & (~z));\n  else\n    return x ^ (y | (~z));\n}\n\nfunction K(j) {\n  if (j <= 15)\n    return 0x00000000;\n  else if (j <= 31)\n    return 0x5a827999;\n  else if (j <= 47)\n    return 0x6ed9eba1;\n  else if (j <= 63)\n    return 0x8f1bbcdc;\n  else\n    return 0xa953fd4e;\n}\n\nfunction Kh(j) {\n  if (j <= 15)\n    return 0x50a28be6;\n  else if (j <= 31)\n    return 0x5c4dd124;\n  else if (j <= 47)\n    return 0x6d703ef3;\n  else if (j <= 63)\n    return 0x7a6d76e9;\n  else\n    return 0x00000000;\n}\n\nvar r = [\n  0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14, 15,\n  7, 4, 13, 1, 10, 6, 15, 3, 12, 0, 9, 5, 2, 14, 11, 8,\n  3, 10, 14, 4, 9, 15, 8, 1, 2, 7, 0, 6, 13, 11, 5, 12,\n  1, 9, 11, 10, 0, 8, 12, 4, 13, 3, 7, 15, 14, 5, 6, 2,\n  4, 0, 5, 9, 7, 12, 2, 10, 14, 1, 3, 8, 11, 6, 15, 13\n];\n\nvar rh = [\n  5, 14, 7, 0, 9, 2, 11, 4, 13, 6, 15, 8, 1, 10, 3, 12,\n  6, 11, 3, 7, 0, 13, 5, 10, 14, 15, 8, 12, 4, 9, 1, 2,\n  15, 5, 1, 3, 7, 14, 6, 9, 11, 8, 12, 2, 10, 0, 4, 13,\n  8, 6, 4, 1, 3, 11, 15, 0, 5, 12, 2, 13, 9, 7, 10, 14,\n  12, 15, 10, 4, 1, 5, 8, 7, 6, 2, 13, 14, 0, 3, 9, 11\n];\n\nvar s = [\n  11, 14, 15, 12, 5, 8, 7, 9, 11, 13, 14, 15, 6, 7, 9, 8,\n  7, 6, 8, 13, 11, 9, 7, 15, 7, 12, 15, 9, 11, 7, 13, 12,\n  11, 13, 6, 7, 14, 9, 13, 15, 14, 8, 13, 6, 5, 12, 7, 5,\n  11, 12, 14, 15, 14, 15, 9, 8, 9, 14, 5, 6, 8, 6, 5, 12,\n  9, 15, 5, 11, 6, 8, 13, 12, 5, 12, 13, 14, 11, 8, 5, 6\n];\n\nvar sh = [\n  8, 9, 9, 11, 13, 15, 15, 5, 7, 7, 8, 11, 14, 14, 12, 6,\n  9, 13, 15, 7, 12, 8, 9, 11, 7, 7, 12, 7, 6, 15, 13, 11,\n  9, 7, 15, 11, 8, 6, 6, 14, 12, 13, 5, 14, 13, 13, 7, 5,\n  15, 5, 8, 11, 14, 14, 6, 14, 6, 9, 12, 9, 12, 5, 15, 8,\n  8, 5, 12, 9, 12, 5, 14, 6, 8, 13, 6, 5, 15, 13, 11, 11\n];\n",
    "'use strict';\n\nvar utils = require('./utils');\nvar assert = require('minimalistic-assert');\n\nfunction Hmac(hash, key, enc) {\n  if (!(this instanceof Hmac))\n    return new Hmac(hash, key, enc);\n  this.Hash = hash;\n  this.blockSize = hash.blockSize / 8;\n  this.outSize = hash.outSize / 8;\n  this.inner = null;\n  this.outer = null;\n\n  this._init(utils.toArray(key, enc));\n}\nmodule.exports = Hmac;\n\nHmac.prototype._init = function init(key) {\n  // Shorten key, if needed\n  if (key.length > this.blockSize)\n    key = new this.Hash().update(key).digest();\n  assert(key.length <= this.blockSize);\n\n  // Add padding to key\n  for (var i = key.length; i < this.blockSize; i++)\n    key.push(0);\n\n  for (i = 0; i < key.length; i++)\n    key[i] ^= 0x36;\n  this.inner = new this.Hash().update(key);\n\n  // 0x36 ^ 0x5c = 0x6a\n  for (i = 0; i < key.length; i++)\n    key[i] ^= 0x6a;\n  this.outer = new this.Hash().update(key);\n};\n\nHmac.prototype.update = function update(msg, enc) {\n  this.inner.update(msg, enc);\n  return this;\n};\n\nHmac.prototype.digest = function digest(enc) {\n  this.outer.update(this.inner.digest());\n  return this.outer.digest(enc);\n};\n",
    "var hash = exports;\n\nhash.utils = require('./hash/utils');\nhash.common = require('./hash/common');\nhash.sha = require('./hash/sha');\nhash.ripemd = require('./hash/ripemd');\nhash.hmac = require('./hash/hmac');\n\n// Proxy hash functions to the main object\nhash.sha1 = hash.sha.sha1;\nhash.sha256 = hash.sha.sha256;\nhash.sha224 = hash.sha.sha224;\nhash.sha384 = hash.sha.sha384;\nhash.sha512 = hash.sha.sha512;\nhash.ripemd160 = hash.ripemd.ripemd160;\n",
    "module.exports = {\n  doubles: {\n    step: 4,\n    points: [\n      [\n        'e60fce93b59e9ec53011aabc21c23e97b2a31369b87a5ae9c44ee89e2a6dec0a',\n        'f7e3507399e595929db99f34f57937101296891e44d23f0be1f32cce69616821',\n      ],\n      [\n        '8282263212c609d9ea2a6e3e172de238d8c39cabd5ac1ca10646e23fd5f51508',\n        '11f8a8098557dfe45e8256e830b60ace62d613ac2f7b17bed31b6eaff6e26caf',\n      ],\n      [\n        '175e159f728b865a72f99cc6c6fc846de0b93833fd2222ed73fce5b551e5b739',\n        'd3506e0d9e3c79eba4ef97a51ff71f5eacb5955add24345c6efa6ffee9fed695',\n      ],\n      [\n        '363d90d447b00c9c99ceac05b6262ee053441c7e55552ffe526bad8f83ff4640',\n        '4e273adfc732221953b445397f3363145b9a89008199ecb62003c7f3bee9de9',\n      ],\n      [\n        '8b4b5f165df3c2be8c6244b5b745638843e4a781a15bcd1b69f79a55dffdf80c',\n        '4aad0a6f68d308b4b3fbd7813ab0da04f9e336546162ee56b3eff0c65fd4fd36',\n      ],\n      [\n        '723cbaa6e5db996d6bf771c00bd548c7b700dbffa6c0e77bcb6115925232fcda',\n        '96e867b5595cc498a921137488824d6e2660a0653779494801dc069d9eb39f5f',\n      ],\n      [\n        'eebfa4d493bebf98ba5feec812c2d3b50947961237a919839a533eca0e7dd7fa',\n        '5d9a8ca3970ef0f269ee7edaf178089d9ae4cdc3a711f712ddfd4fdae1de8999',\n      ],\n      [\n        '100f44da696e71672791d0a09b7bde459f1215a29b3c03bfefd7835b39a48db0',\n        'cdd9e13192a00b772ec8f3300c090666b7ff4a18ff5195ac0fbd5cd62bc65a09',\n      ],\n      [\n        'e1031be262c7ed1b1dc9227a4a04c017a77f8d4464f3b3852c8acde6e534fd2d',\n        '9d7061928940405e6bb6a4176597535af292dd419e1ced79a44f18f29456a00d',\n      ],\n      [\n        'feea6cae46d55b530ac2839f143bd7ec5cf8b266a41d6af52d5e688d9094696d',\n        'e57c6b6c97dce1bab06e4e12bf3ecd5c981c8957cc41442d3155debf18090088',\n      ],\n      [\n        'da67a91d91049cdcb367be4be6ffca3cfeed657d808583de33fa978bc1ec6cb1',\n        '9bacaa35481642bc41f463f7ec9780e5dec7adc508f740a17e9ea8e27a68be1d',\n      ],\n      [\n        '53904faa0b334cdda6e000935ef22151ec08d0f7bb11069f57545ccc1a37b7c0',\n        '5bc087d0bc80106d88c9eccac20d3c1c13999981e14434699dcb096b022771c8',\n      ],\n      [\n        '8e7bcd0bd35983a7719cca7764ca906779b53a043a9b8bcaeff959f43ad86047',\n        '10b7770b2a3da4b3940310420ca9514579e88e2e47fd68b3ea10047e8460372a',\n      ],\n      [\n        '385eed34c1cdff21e6d0818689b81bde71a7f4f18397e6690a841e1599c43862',\n        '283bebc3e8ea23f56701de19e9ebf4576b304eec2086dc8cc0458fe5542e5453',\n      ],\n      [\n        '6f9d9b803ecf191637c73a4413dfa180fddf84a5947fbc9c606ed86c3fac3a7',\n        '7c80c68e603059ba69b8e2a30e45c4d47ea4dd2f5c281002d86890603a842160',\n      ],\n      [\n        '3322d401243c4e2582a2147c104d6ecbf774d163db0f5e5313b7e0e742d0e6bd',\n        '56e70797e9664ef5bfb019bc4ddaf9b72805f63ea2873af624f3a2e96c28b2a0',\n      ],\n      [\n        '85672c7d2de0b7da2bd1770d89665868741b3f9af7643397721d74d28134ab83',\n        '7c481b9b5b43b2eb6374049bfa62c2e5e77f17fcc5298f44c8e3094f790313a6',\n      ],\n      [\n        '948bf809b1988a46b06c9f1919413b10f9226c60f668832ffd959af60c82a0a',\n        '53a562856dcb6646dc6b74c5d1c3418c6d4dff08c97cd2bed4cb7f88d8c8e589',\n      ],\n      [\n        '6260ce7f461801c34f067ce0f02873a8f1b0e44dfc69752accecd819f38fd8e8',\n        'bc2da82b6fa5b571a7f09049776a1ef7ecd292238051c198c1a84e95b2b4ae17',\n      ],\n      [\n        'e5037de0afc1d8d43d8348414bbf4103043ec8f575bfdc432953cc8d2037fa2d',\n        '4571534baa94d3b5f9f98d09fb990bddbd5f5b03ec481f10e0e5dc841d755bda',\n      ],\n      [\n        'e06372b0f4a207adf5ea905e8f1771b4e7e8dbd1c6a6c5b725866a0ae4fce725',\n        '7a908974bce18cfe12a27bb2ad5a488cd7484a7787104870b27034f94eee31dd',\n      ],\n      [\n        '213c7a715cd5d45358d0bbf9dc0ce02204b10bdde2a3f58540ad6908d0559754',\n        '4b6dad0b5ae462507013ad06245ba190bb4850f5f36a7eeddff2c27534b458f2',\n      ],\n      [\n        '4e7c272a7af4b34e8dbb9352a5419a87e2838c70adc62cddf0cc3a3b08fbd53c',\n        '17749c766c9d0b18e16fd09f6def681b530b9614bff7dd33e0b3941817dcaae6',\n      ],\n      [\n        'fea74e3dbe778b1b10f238ad61686aa5c76e3db2be43057632427e2840fb27b6',\n        '6e0568db9b0b13297cf674deccb6af93126b596b973f7b77701d3db7f23cb96f',\n      ],\n      [\n        '76e64113f677cf0e10a2570d599968d31544e179b760432952c02a4417bdde39',\n        'c90ddf8dee4e95cf577066d70681f0d35e2a33d2b56d2032b4b1752d1901ac01',\n      ],\n      [\n        'c738c56b03b2abe1e8281baa743f8f9a8f7cc643df26cbee3ab150242bcbb891',\n        '893fb578951ad2537f718f2eacbfbbbb82314eef7880cfe917e735d9699a84c3',\n      ],\n      [\n        'd895626548b65b81e264c7637c972877d1d72e5f3a925014372e9f6588f6c14b',\n        'febfaa38f2bc7eae728ec60818c340eb03428d632bb067e179363ed75d7d991f',\n      ],\n      [\n        'b8da94032a957518eb0f6433571e8761ceffc73693e84edd49150a564f676e03',\n        '2804dfa44805a1e4d7c99cc9762808b092cc584d95ff3b511488e4e74efdf6e7',\n      ],\n      [\n        'e80fea14441fb33a7d8adab9475d7fab2019effb5156a792f1a11778e3c0df5d',\n        'eed1de7f638e00771e89768ca3ca94472d155e80af322ea9fcb4291b6ac9ec78',\n      ],\n      [\n        'a301697bdfcd704313ba48e51d567543f2a182031efd6915ddc07bbcc4e16070',\n        '7370f91cfb67e4f5081809fa25d40f9b1735dbf7c0a11a130c0d1a041e177ea1',\n      ],\n      [\n        '90ad85b389d6b936463f9d0512678de208cc330b11307fffab7ac63e3fb04ed4',\n        'e507a3620a38261affdcbd9427222b839aefabe1582894d991d4d48cb6ef150',\n      ],\n      [\n        '8f68b9d2f63b5f339239c1ad981f162ee88c5678723ea3351b7b444c9ec4c0da',\n        '662a9f2dba063986de1d90c2b6be215dbbea2cfe95510bfdf23cbf79501fff82',\n      ],\n      [\n        'e4f3fb0176af85d65ff99ff9198c36091f48e86503681e3e6686fd5053231e11',\n        '1e63633ad0ef4f1c1661a6d0ea02b7286cc7e74ec951d1c9822c38576feb73bc',\n      ],\n      [\n        '8c00fa9b18ebf331eb961537a45a4266c7034f2f0d4e1d0716fb6eae20eae29e',\n        'efa47267fea521a1a9dc343a3736c974c2fadafa81e36c54e7d2a4c66702414b',\n      ],\n      [\n        'e7a26ce69dd4829f3e10cec0a9e98ed3143d084f308b92c0997fddfc60cb3e41',\n        '2a758e300fa7984b471b006a1aafbb18d0a6b2c0420e83e20e8a9421cf2cfd51',\n      ],\n      [\n        'b6459e0ee3662ec8d23540c223bcbdc571cbcb967d79424f3cf29eb3de6b80ef',\n        '67c876d06f3e06de1dadf16e5661db3c4b3ae6d48e35b2ff30bf0b61a71ba45',\n      ],\n      [\n        'd68a80c8280bb840793234aa118f06231d6f1fc67e73c5a5deda0f5b496943e8',\n        'db8ba9fff4b586d00c4b1f9177b0e28b5b0e7b8f7845295a294c84266b133120',\n      ],\n      [\n        '324aed7df65c804252dc0270907a30b09612aeb973449cea4095980fc28d3d5d',\n        '648a365774b61f2ff130c0c35aec1f4f19213b0c7e332843967224af96ab7c84',\n      ],\n      [\n        '4df9c14919cde61f6d51dfdbe5fee5dceec4143ba8d1ca888e8bd373fd054c96',\n        '35ec51092d8728050974c23a1d85d4b5d506cdc288490192ebac06cad10d5d',\n      ],\n      [\n        '9c3919a84a474870faed8a9c1cc66021523489054d7f0308cbfc99c8ac1f98cd',\n        'ddb84f0f4a4ddd57584f044bf260e641905326f76c64c8e6be7e5e03d4fc599d',\n      ],\n      [\n        '6057170b1dd12fdf8de05f281d8e06bb91e1493a8b91d4cc5a21382120a959e5',\n        '9a1af0b26a6a4807add9a2daf71df262465152bc3ee24c65e899be932385a2a8',\n      ],\n      [\n        'a576df8e23a08411421439a4518da31880cef0fba7d4df12b1a6973eecb94266',\n        '40a6bf20e76640b2c92b97afe58cd82c432e10a7f514d9f3ee8be11ae1b28ec8',\n      ],\n      [\n        '7778a78c28dec3e30a05fe9629de8c38bb30d1f5cf9a3a208f763889be58ad71',\n        '34626d9ab5a5b22ff7098e12f2ff580087b38411ff24ac563b513fc1fd9f43ac',\n      ],\n      [\n        '928955ee637a84463729fd30e7afd2ed5f96274e5ad7e5cb09eda9c06d903ac',\n        'c25621003d3f42a827b78a13093a95eeac3d26efa8a8d83fc5180e935bcd091f',\n      ],\n      [\n        '85d0fef3ec6db109399064f3a0e3b2855645b4a907ad354527aae75163d82751',\n        '1f03648413a38c0be29d496e582cf5663e8751e96877331582c237a24eb1f962',\n      ],\n      [\n        'ff2b0dce97eece97c1c9b6041798b85dfdfb6d8882da20308f5404824526087e',\n        '493d13fef524ba188af4c4dc54d07936c7b7ed6fb90e2ceb2c951e01f0c29907',\n      ],\n      [\n        '827fbbe4b1e880ea9ed2b2e6301b212b57f1ee148cd6dd28780e5e2cf856e241',\n        'c60f9c923c727b0b71bef2c67d1d12687ff7a63186903166d605b68baec293ec',\n      ],\n      [\n        'eaa649f21f51bdbae7be4ae34ce6e5217a58fdce7f47f9aa7f3b58fa2120e2b3',\n        'be3279ed5bbbb03ac69a80f89879aa5a01a6b965f13f7e59d47a5305ba5ad93d',\n      ],\n      [\n        'e4a42d43c5cf169d9391df6decf42ee541b6d8f0c9a137401e23632dda34d24f',\n        '4d9f92e716d1c73526fc99ccfb8ad34ce886eedfa8d8e4f13a7f7131deba9414',\n      ],\n      [\n        '1ec80fef360cbdd954160fadab352b6b92b53576a88fea4947173b9d4300bf19',\n        'aeefe93756b5340d2f3a4958a7abbf5e0146e77f6295a07b671cdc1cc107cefd',\n      ],\n      [\n        '146a778c04670c2f91b00af4680dfa8bce3490717d58ba889ddb5928366642be',\n        'b318e0ec3354028add669827f9d4b2870aaa971d2f7e5ed1d0b297483d83efd0',\n      ],\n      [\n        'fa50c0f61d22e5f07e3acebb1aa07b128d0012209a28b9776d76a8793180eef9',\n        '6b84c6922397eba9b72cd2872281a68a5e683293a57a213b38cd8d7d3f4f2811',\n      ],\n      [\n        'da1d61d0ca721a11b1a5bf6b7d88e8421a288ab5d5bba5220e53d32b5f067ec2',\n        '8157f55a7c99306c79c0766161c91e2966a73899d279b48a655fba0f1ad836f1',\n      ],\n      [\n        'a8e282ff0c9706907215ff98e8fd416615311de0446f1e062a73b0610d064e13',\n        '7f97355b8db81c09abfb7f3c5b2515888b679a3e50dd6bd6cef7c73111f4cc0c',\n      ],\n      [\n        '174a53b9c9a285872d39e56e6913cab15d59b1fa512508c022f382de8319497c',\n        'ccc9dc37abfc9c1657b4155f2c47f9e6646b3a1d8cb9854383da13ac079afa73',\n      ],\n      [\n        '959396981943785c3d3e57edf5018cdbe039e730e4918b3d884fdff09475b7ba',\n        '2e7e552888c331dd8ba0386a4b9cd6849c653f64c8709385e9b8abf87524f2fd',\n      ],\n      [\n        'd2a63a50ae401e56d645a1153b109a8fcca0a43d561fba2dbb51340c9d82b151',\n        'e82d86fb6443fcb7565aee58b2948220a70f750af484ca52d4142174dcf89405',\n      ],\n      [\n        '64587e2335471eb890ee7896d7cfdc866bacbdbd3839317b3436f9b45617e073',\n        'd99fcdd5bf6902e2ae96dd6447c299a185b90a39133aeab358299e5e9faf6589',\n      ],\n      [\n        '8481bde0e4e4d885b3a546d3e549de042f0aa6cea250e7fd358d6c86dd45e458',\n        '38ee7b8cba5404dd84a25bf39cecb2ca900a79c42b262e556d64b1b59779057e',\n      ],\n      [\n        '13464a57a78102aa62b6979ae817f4637ffcfed3c4b1ce30bcd6303f6caf666b',\n        '69be159004614580ef7e433453ccb0ca48f300a81d0942e13f495a907f6ecc27',\n      ],\n      [\n        'bc4a9df5b713fe2e9aef430bcc1dc97a0cd9ccede2f28588cada3a0d2d83f366',\n        'd3a81ca6e785c06383937adf4b798caa6e8a9fbfa547b16d758d666581f33c1',\n      ],\n      [\n        '8c28a97bf8298bc0d23d8c749452a32e694b65e30a9472a3954ab30fe5324caa',\n        '40a30463a3305193378fedf31f7cc0eb7ae784f0451cb9459e71dc73cbef9482',\n      ],\n      [\n        '8ea9666139527a8c1dd94ce4f071fd23c8b350c5a4bb33748c4ba111faccae0',\n        '620efabbc8ee2782e24e7c0cfb95c5d735b783be9cf0f8e955af34a30e62b945',\n      ],\n      [\n        'dd3625faef5ba06074669716bbd3788d89bdde815959968092f76cc4eb9a9787',\n        '7a188fa3520e30d461da2501045731ca941461982883395937f68d00c644a573',\n      ],\n      [\n        'f710d79d9eb962297e4f6232b40e8f7feb2bc63814614d692c12de752408221e',\n        'ea98e67232d3b3295d3b535532115ccac8612c721851617526ae47a9c77bfc82',\n      ],\n    ],\n  },\n  naf: {\n    wnd: 7,\n    points: [\n      [\n        'f9308a019258c31049344f85f89d5229b531c845836f99b08601f113bce036f9',\n        '388f7b0f632de8140fe337e62a37f3566500a99934c2231b6cb9fd7584b8e672',\n      ],\n      [\n        '2f8bde4d1a07209355b4a7250a5c5128e88b84bddc619ab7cba8d569b240efe4',\n        'd8ac222636e5e3d6d4dba9dda6c9c426f788271bab0d6840dca87d3aa6ac62d6',\n      ],\n      [\n        '5cbdf0646e5db4eaa398f365f2ea7a0e3d419b7e0330e39ce92bddedcac4f9bc',\n        '6aebca40ba255960a3178d6d861a54dba813d0b813fde7b5a5082628087264da',\n      ],\n      [\n        'acd484e2f0c7f65309ad178a9f559abde09796974c57e714c35f110dfc27ccbe',\n        'cc338921b0a7d9fd64380971763b61e9add888a4375f8e0f05cc262ac64f9c37',\n      ],\n      [\n        '774ae7f858a9411e5ef4246b70c65aac5649980be5c17891bbec17895da008cb',\n        'd984a032eb6b5e190243dd56d7b7b365372db1e2dff9d6a8301d74c9c953c61b',\n      ],\n      [\n        'f28773c2d975288bc7d1d205c3748651b075fbc6610e58cddeeddf8f19405aa8',\n        'ab0902e8d880a89758212eb65cdaf473a1a06da521fa91f29b5cb52db03ed81',\n      ],\n      [\n        'd7924d4f7d43ea965a465ae3095ff41131e5946f3c85f79e44adbcf8e27e080e',\n        '581e2872a86c72a683842ec228cc6defea40af2bd896d3a5c504dc9ff6a26b58',\n      ],\n      [\n        'defdea4cdb677750a420fee807eacf21eb9898ae79b9768766e4faa04a2d4a34',\n        '4211ab0694635168e997b0ead2a93daeced1f4a04a95c0f6cfb199f69e56eb77',\n      ],\n      [\n        '2b4ea0a797a443d293ef5cff444f4979f06acfebd7e86d277475656138385b6c',\n        '85e89bc037945d93b343083b5a1c86131a01f60c50269763b570c854e5c09b7a',\n      ],\n      [\n        '352bbf4a4cdd12564f93fa332ce333301d9ad40271f8107181340aef25be59d5',\n        '321eb4075348f534d59c18259dda3e1f4a1b3b2e71b1039c67bd3d8bcf81998c',\n      ],\n      [\n        '2fa2104d6b38d11b0230010559879124e42ab8dfeff5ff29dc9cdadd4ecacc3f',\n        '2de1068295dd865b64569335bd5dd80181d70ecfc882648423ba76b532b7d67',\n      ],\n      [\n        '9248279b09b4d68dab21a9b066edda83263c3d84e09572e269ca0cd7f5453714',\n        '73016f7bf234aade5d1aa71bdea2b1ff3fc0de2a887912ffe54a32ce97cb3402',\n      ],\n      [\n        'daed4f2be3a8bf278e70132fb0beb7522f570e144bf615c07e996d443dee8729',\n        'a69dce4a7d6c98e8d4a1aca87ef8d7003f83c230f3afa726ab40e52290be1c55',\n      ],\n      [\n        'c44d12c7065d812e8acf28d7cbb19f9011ecd9e9fdf281b0e6a3b5e87d22e7db',\n        '2119a460ce326cdc76c45926c982fdac0e106e861edf61c5a039063f0e0e6482',\n      ],\n      [\n        '6a245bf6dc698504c89a20cfded60853152b695336c28063b61c65cbd269e6b4',\n        'e022cf42c2bd4a708b3f5126f16a24ad8b33ba48d0423b6efd5e6348100d8a82',\n      ],\n      [\n        '1697ffa6fd9de627c077e3d2fe541084ce13300b0bec1146f95ae57f0d0bd6a5',\n        'b9c398f186806f5d27561506e4557433a2cf15009e498ae7adee9d63d01b2396',\n      ],\n      [\n        '605bdb019981718b986d0f07e834cb0d9deb8360ffb7f61df982345ef27a7479',\n        '2972d2de4f8d20681a78d93ec96fe23c26bfae84fb14db43b01e1e9056b8c49',\n      ],\n      [\n        '62d14dab4150bf497402fdc45a215e10dcb01c354959b10cfe31c7e9d87ff33d',\n        '80fc06bd8cc5b01098088a1950eed0db01aa132967ab472235f5642483b25eaf',\n      ],\n      [\n        '80c60ad0040f27dade5b4b06c408e56b2c50e9f56b9b8b425e555c2f86308b6f',\n        '1c38303f1cc5c30f26e66bad7fe72f70a65eed4cbe7024eb1aa01f56430bd57a',\n      ],\n      [\n        '7a9375ad6167ad54aa74c6348cc54d344cc5dc9487d847049d5eabb0fa03c8fb',\n        'd0e3fa9eca8726909559e0d79269046bdc59ea10c70ce2b02d499ec224dc7f7',\n      ],\n      [\n        'd528ecd9b696b54c907a9ed045447a79bb408ec39b68df504bb51f459bc3ffc9',\n        'eecf41253136e5f99966f21881fd656ebc4345405c520dbc063465b521409933',\n      ],\n      [\n        '49370a4b5f43412ea25f514e8ecdad05266115e4a7ecb1387231808f8b45963',\n        '758f3f41afd6ed428b3081b0512fd62a54c3f3afbb5b6764b653052a12949c9a',\n      ],\n      [\n        '77f230936ee88cbbd73df930d64702ef881d811e0e1498e2f1c13eb1fc345d74',\n        '958ef42a7886b6400a08266e9ba1b37896c95330d97077cbbe8eb3c7671c60d6',\n      ],\n      [\n        'f2dac991cc4ce4b9ea44887e5c7c0bce58c80074ab9d4dbaeb28531b7739f530',\n        'e0dedc9b3b2f8dad4da1f32dec2531df9eb5fbeb0598e4fd1a117dba703a3c37',\n      ],\n      [\n        '463b3d9f662621fb1b4be8fbbe2520125a216cdfc9dae3debcba4850c690d45b',\n        '5ed430d78c296c3543114306dd8622d7c622e27c970a1de31cb377b01af7307e',\n      ],\n      [\n        'f16f804244e46e2a09232d4aff3b59976b98fac14328a2d1a32496b49998f247',\n        'cedabd9b82203f7e13d206fcdf4e33d92a6c53c26e5cce26d6579962c4e31df6',\n      ],\n      [\n        'caf754272dc84563b0352b7a14311af55d245315ace27c65369e15f7151d41d1',\n        'cb474660ef35f5f2a41b643fa5e460575f4fa9b7962232a5c32f908318a04476',\n      ],\n      [\n        '2600ca4b282cb986f85d0f1709979d8b44a09c07cb86d7c124497bc86f082120',\n        '4119b88753c15bd6a693b03fcddbb45d5ac6be74ab5f0ef44b0be9475a7e4b40',\n      ],\n      [\n        '7635ca72d7e8432c338ec53cd12220bc01c48685e24f7dc8c602a7746998e435',\n        '91b649609489d613d1d5e590f78e6d74ecfc061d57048bad9e76f302c5b9c61',\n      ],\n      [\n        '754e3239f325570cdbbf4a87deee8a66b7f2b33479d468fbc1a50743bf56cc18',\n        '673fb86e5bda30fb3cd0ed304ea49a023ee33d0197a695d0c5d98093c536683',\n      ],\n      [\n        'e3e6bd1071a1e96aff57859c82d570f0330800661d1c952f9fe2694691d9b9e8',\n        '59c9e0bba394e76f40c0aa58379a3cb6a5a2283993e90c4167002af4920e37f5',\n      ],\n      [\n        '186b483d056a033826ae73d88f732985c4ccb1f32ba35f4b4cc47fdcf04aa6eb',\n        '3b952d32c67cf77e2e17446e204180ab21fb8090895138b4a4a797f86e80888b',\n      ],\n      [\n        'df9d70a6b9876ce544c98561f4be4f725442e6d2b737d9c91a8321724ce0963f',\n        '55eb2dafd84d6ccd5f862b785dc39d4ab157222720ef9da217b8c45cf2ba2417',\n      ],\n      [\n        '5edd5cc23c51e87a497ca815d5dce0f8ab52554f849ed8995de64c5f34ce7143',\n        'efae9c8dbc14130661e8cec030c89ad0c13c66c0d17a2905cdc706ab7399a868',\n      ],\n      [\n        '290798c2b6476830da12fe02287e9e777aa3fba1c355b17a722d362f84614fba',\n        'e38da76dcd440621988d00bcf79af25d5b29c094db2a23146d003afd41943e7a',\n      ],\n      [\n        'af3c423a95d9f5b3054754efa150ac39cd29552fe360257362dfdecef4053b45',\n        'f98a3fd831eb2b749a93b0e6f35cfb40c8cd5aa667a15581bc2feded498fd9c6',\n      ],\n      [\n        '766dbb24d134e745cccaa28c99bf274906bb66b26dcf98df8d2fed50d884249a',\n        '744b1152eacbe5e38dcc887980da38b897584a65fa06cedd2c924f97cbac5996',\n      ],\n      [\n        '59dbf46f8c94759ba21277c33784f41645f7b44f6c596a58ce92e666191abe3e',\n        'c534ad44175fbc300f4ea6ce648309a042ce739a7919798cd85e216c4a307f6e',\n      ],\n      [\n        'f13ada95103c4537305e691e74e9a4a8dd647e711a95e73cb62dc6018cfd87b8',\n        'e13817b44ee14de663bf4bc808341f326949e21a6a75c2570778419bdaf5733d',\n      ],\n      [\n        '7754b4fa0e8aced06d4167a2c59cca4cda1869c06ebadfb6488550015a88522c',\n        '30e93e864e669d82224b967c3020b8fa8d1e4e350b6cbcc537a48b57841163a2',\n      ],\n      [\n        '948dcadf5990e048aa3874d46abef9d701858f95de8041d2a6828c99e2262519',\n        'e491a42537f6e597d5d28a3224b1bc25df9154efbd2ef1d2cbba2cae5347d57e',\n      ],\n      [\n        '7962414450c76c1689c7b48f8202ec37fb224cf5ac0bfa1570328a8a3d7c77ab',\n        '100b610ec4ffb4760d5c1fc133ef6f6b12507a051f04ac5760afa5b29db83437',\n      ],\n      [\n        '3514087834964b54b15b160644d915485a16977225b8847bb0dd085137ec47ca',\n        'ef0afbb2056205448e1652c48e8127fc6039e77c15c2378b7e7d15a0de293311',\n      ],\n      [\n        'd3cc30ad6b483e4bc79ce2c9dd8bc54993e947eb8df787b442943d3f7b527eaf',\n        '8b378a22d827278d89c5e9be8f9508ae3c2ad46290358630afb34db04eede0a4',\n      ],\n      [\n        '1624d84780732860ce1c78fcbfefe08b2b29823db913f6493975ba0ff4847610',\n        '68651cf9b6da903e0914448c6cd9d4ca896878f5282be4c8cc06e2a404078575',\n      ],\n      [\n        '733ce80da955a8a26902c95633e62a985192474b5af207da6df7b4fd5fc61cd4',\n        'f5435a2bd2badf7d485a4d8b8db9fcce3e1ef8e0201e4578c54673bc1dc5ea1d',\n      ],\n      [\n        '15d9441254945064cf1a1c33bbd3b49f8966c5092171e699ef258dfab81c045c',\n        'd56eb30b69463e7234f5137b73b84177434800bacebfc685fc37bbe9efe4070d',\n      ],\n      [\n        'a1d0fcf2ec9de675b612136e5ce70d271c21417c9d2b8aaaac138599d0717940',\n        'edd77f50bcb5a3cab2e90737309667f2641462a54070f3d519212d39c197a629',\n      ],\n      [\n        'e22fbe15c0af8ccc5780c0735f84dbe9a790badee8245c06c7ca37331cb36980',\n        'a855babad5cd60c88b430a69f53a1a7a38289154964799be43d06d77d31da06',\n      ],\n      [\n        '311091dd9860e8e20ee13473c1155f5f69635e394704eaa74009452246cfa9b3',\n        '66db656f87d1f04fffd1f04788c06830871ec5a64feee685bd80f0b1286d8374',\n      ],\n      [\n        '34c1fd04d301be89b31c0442d3e6ac24883928b45a9340781867d4232ec2dbdf',\n        '9414685e97b1b5954bd46f730174136d57f1ceeb487443dc5321857ba73abee',\n      ],\n      [\n        'f219ea5d6b54701c1c14de5b557eb42a8d13f3abbcd08affcc2a5e6b049b8d63',\n        '4cb95957e83d40b0f73af4544cccf6b1f4b08d3c07b27fb8d8c2962a400766d1',\n      ],\n      [\n        'd7b8740f74a8fbaab1f683db8f45de26543a5490bca627087236912469a0b448',\n        'fa77968128d9c92ee1010f337ad4717eff15db5ed3c049b3411e0315eaa4593b',\n      ],\n      [\n        '32d31c222f8f6f0ef86f7c98d3a3335ead5bcd32abdd94289fe4d3091aa824bf',\n        '5f3032f5892156e39ccd3d7915b9e1da2e6dac9e6f26e961118d14b8462e1661',\n      ],\n      [\n        '7461f371914ab32671045a155d9831ea8793d77cd59592c4340f86cbc18347b5',\n        '8ec0ba238b96bec0cbdddcae0aa442542eee1ff50c986ea6b39847b3cc092ff6',\n      ],\n      [\n        'ee079adb1df1860074356a25aa38206a6d716b2c3e67453d287698bad7b2b2d6',\n        '8dc2412aafe3be5c4c5f37e0ecc5f9f6a446989af04c4e25ebaac479ec1c8c1e',\n      ],\n      [\n        '16ec93e447ec83f0467b18302ee620f7e65de331874c9dc72bfd8616ba9da6b5',\n        '5e4631150e62fb40d0e8c2a7ca5804a39d58186a50e497139626778e25b0674d',\n      ],\n      [\n        'eaa5f980c245f6f038978290afa70b6bd8855897f98b6aa485b96065d537bd99',\n        'f65f5d3e292c2e0819a528391c994624d784869d7e6ea67fb18041024edc07dc',\n      ],\n      [\n        '78c9407544ac132692ee1910a02439958ae04877151342ea96c4b6b35a49f51',\n        'f3e0319169eb9b85d5404795539a5e68fa1fbd583c064d2462b675f194a3ddb4',\n      ],\n      [\n        '494f4be219a1a77016dcd838431aea0001cdc8ae7a6fc688726578d9702857a5',\n        '42242a969283a5f339ba7f075e36ba2af925ce30d767ed6e55f4b031880d562c',\n      ],\n      [\n        'a598a8030da6d86c6bc7f2f5144ea549d28211ea58faa70ebf4c1e665c1fe9b5',\n        '204b5d6f84822c307e4b4a7140737aec23fc63b65b35f86a10026dbd2d864e6b',\n      ],\n      [\n        'c41916365abb2b5d09192f5f2dbeafec208f020f12570a184dbadc3e58595997',\n        '4f14351d0087efa49d245b328984989d5caf9450f34bfc0ed16e96b58fa9913',\n      ],\n      [\n        '841d6063a586fa475a724604da03bc5b92a2e0d2e0a36acfe4c73a5514742881',\n        '73867f59c0659e81904f9a1c7543698e62562d6744c169ce7a36de01a8d6154',\n      ],\n      [\n        '5e95bb399a6971d376026947f89bde2f282b33810928be4ded112ac4d70e20d5',\n        '39f23f366809085beebfc71181313775a99c9aed7d8ba38b161384c746012865',\n      ],\n      [\n        '36e4641a53948fd476c39f8a99fd974e5ec07564b5315d8bf99471bca0ef2f66',\n        'd2424b1b1abe4eb8164227b085c9aa9456ea13493fd563e06fd51cf5694c78fc',\n      ],\n      [\n        '336581ea7bfbbb290c191a2f507a41cf5643842170e914faeab27c2c579f726',\n        'ead12168595fe1be99252129b6e56b3391f7ab1410cd1e0ef3dcdcabd2fda224',\n      ],\n      [\n        '8ab89816dadfd6b6a1f2634fcf00ec8403781025ed6890c4849742706bd43ede',\n        '6fdcef09f2f6d0a044e654aef624136f503d459c3e89845858a47a9129cdd24e',\n      ],\n      [\n        '1e33f1a746c9c5778133344d9299fcaa20b0938e8acff2544bb40284b8c5fb94',\n        '60660257dd11b3aa9c8ed618d24edff2306d320f1d03010e33a7d2057f3b3b6',\n      ],\n      [\n        '85b7c1dcb3cec1b7ee7f30ded79dd20a0ed1f4cc18cbcfcfa410361fd8f08f31',\n        '3d98a9cdd026dd43f39048f25a8847f4fcafad1895d7a633c6fed3c35e999511',\n      ],\n      [\n        '29df9fbd8d9e46509275f4b125d6d45d7fbe9a3b878a7af872a2800661ac5f51',\n        'b4c4fe99c775a606e2d8862179139ffda61dc861c019e55cd2876eb2a27d84b',\n      ],\n      [\n        'a0b1cae06b0a847a3fea6e671aaf8adfdfe58ca2f768105c8082b2e449fce252',\n        'ae434102edde0958ec4b19d917a6a28e6b72da1834aff0e650f049503a296cf2',\n      ],\n      [\n        '4e8ceafb9b3e9a136dc7ff67e840295b499dfb3b2133e4ba113f2e4c0e121e5',\n        'cf2174118c8b6d7a4b48f6d534ce5c79422c086a63460502b827ce62a326683c',\n      ],\n      [\n        'd24a44e047e19b6f5afb81c7ca2f69080a5076689a010919f42725c2b789a33b',\n        '6fb8d5591b466f8fc63db50f1c0f1c69013f996887b8244d2cdec417afea8fa3',\n      ],\n      [\n        'ea01606a7a6c9cdd249fdfcfacb99584001edd28abbab77b5104e98e8e3b35d4',\n        '322af4908c7312b0cfbfe369f7a7b3cdb7d4494bc2823700cfd652188a3ea98d',\n      ],\n      [\n        'af8addbf2b661c8a6c6328655eb96651252007d8c5ea31be4ad196de8ce2131f',\n        '6749e67c029b85f52a034eafd096836b2520818680e26ac8f3dfbcdb71749700',\n      ],\n      [\n        'e3ae1974566ca06cc516d47e0fb165a674a3dabcfca15e722f0e3450f45889',\n        '2aeabe7e4531510116217f07bf4d07300de97e4874f81f533420a72eeb0bd6a4',\n      ],\n      [\n        '591ee355313d99721cf6993ffed1e3e301993ff3ed258802075ea8ced397e246',\n        'b0ea558a113c30bea60fc4775460c7901ff0b053d25ca2bdeee98f1a4be5d196',\n      ],\n      [\n        '11396d55fda54c49f19aa97318d8da61fa8584e47b084945077cf03255b52984',\n        '998c74a8cd45ac01289d5833a7beb4744ff536b01b257be4c5767bea93ea57a4',\n      ],\n      [\n        '3c5d2a1ba39c5a1790000738c9e0c40b8dcdfd5468754b6405540157e017aa7a',\n        'b2284279995a34e2f9d4de7396fc18b80f9b8b9fdd270f6661f79ca4c81bd257',\n      ],\n      [\n        'cc8704b8a60a0defa3a99a7299f2e9c3fbc395afb04ac078425ef8a1793cc030',\n        'bdd46039feed17881d1e0862db347f8cf395b74fc4bcdc4e940b74e3ac1f1b13',\n      ],\n      [\n        'c533e4f7ea8555aacd9777ac5cad29b97dd4defccc53ee7ea204119b2889b197',\n        '6f0a256bc5efdf429a2fb6242f1a43a2d9b925bb4a4b3a26bb8e0f45eb596096',\n      ],\n      [\n        'c14f8f2ccb27d6f109f6d08d03cc96a69ba8c34eec07bbcf566d48e33da6593',\n        'c359d6923bb398f7fd4473e16fe1c28475b740dd098075e6c0e8649113dc3a38',\n      ],\n      [\n        'a6cbc3046bc6a450bac24789fa17115a4c9739ed75f8f21ce441f72e0b90e6ef',\n        '21ae7f4680e889bb130619e2c0f95a360ceb573c70603139862afd617fa9b9f',\n      ],\n      [\n        '347d6d9a02c48927ebfb86c1359b1caf130a3c0267d11ce6344b39f99d43cc38',\n        '60ea7f61a353524d1c987f6ecec92f086d565ab687870cb12689ff1e31c74448',\n      ],\n      [\n        'da6545d2181db8d983f7dcb375ef5866d47c67b1bf31c8cf855ef7437b72656a',\n        '49b96715ab6878a79e78f07ce5680c5d6673051b4935bd897fea824b77dc208a',\n      ],\n      [\n        'c40747cc9d012cb1a13b8148309c6de7ec25d6945d657146b9d5994b8feb1111',\n        '5ca560753be2a12fc6de6caf2cb489565db936156b9514e1bb5e83037e0fa2d4',\n      ],\n      [\n        '4e42c8ec82c99798ccf3a610be870e78338c7f713348bd34c8203ef4037f3502',\n        '7571d74ee5e0fb92a7a8b33a07783341a5492144cc54bcc40a94473693606437',\n      ],\n      [\n        '3775ab7089bc6af823aba2e1af70b236d251cadb0c86743287522a1b3b0dedea',\n        'be52d107bcfa09d8bcb9736a828cfa7fac8db17bf7a76a2c42ad961409018cf7',\n      ],\n      [\n        'cee31cbf7e34ec379d94fb814d3d775ad954595d1314ba8846959e3e82f74e26',\n        '8fd64a14c06b589c26b947ae2bcf6bfa0149ef0be14ed4d80f448a01c43b1c6d',\n      ],\n      [\n        'b4f9eaea09b6917619f6ea6a4eb5464efddb58fd45b1ebefcdc1a01d08b47986',\n        '39e5c9925b5a54b07433a4f18c61726f8bb131c012ca542eb24a8ac07200682a',\n      ],\n      [\n        'd4263dfc3d2df923a0179a48966d30ce84e2515afc3dccc1b77907792ebcc60e',\n        '62dfaf07a0f78feb30e30d6295853ce189e127760ad6cf7fae164e122a208d54',\n      ],\n      [\n        '48457524820fa65a4f8d35eb6930857c0032acc0a4a2de422233eeda897612c4',\n        '25a748ab367979d98733c38a1fa1c2e7dc6cc07db2d60a9ae7a76aaa49bd0f77',\n      ],\n      [\n        'dfeeef1881101f2cb11644f3a2afdfc2045e19919152923f367a1767c11cceda',\n        'ecfb7056cf1de042f9420bab396793c0c390bde74b4bbdff16a83ae09a9a7517',\n      ],\n      [\n        '6d7ef6b17543f8373c573f44e1f389835d89bcbc6062ced36c82df83b8fae859',\n        'cd450ec335438986dfefa10c57fea9bcc521a0959b2d80bbf74b190dca712d10',\n      ],\n      [\n        'e75605d59102a5a2684500d3b991f2e3f3c88b93225547035af25af66e04541f',\n        'f5c54754a8f71ee540b9b48728473e314f729ac5308b06938360990e2bfad125',\n      ],\n      [\n        'eb98660f4c4dfaa06a2be453d5020bc99a0c2e60abe388457dd43fefb1ed620c',\n        '6cb9a8876d9cb8520609af3add26cd20a0a7cd8a9411131ce85f44100099223e',\n      ],\n      [\n        '13e87b027d8514d35939f2e6892b19922154596941888336dc3563e3b8dba942',\n        'fef5a3c68059a6dec5d624114bf1e91aac2b9da568d6abeb2570d55646b8adf1',\n      ],\n      [\n        'ee163026e9fd6fe017c38f06a5be6fc125424b371ce2708e7bf4491691e5764a',\n        '1acb250f255dd61c43d94ccc670d0f58f49ae3fa15b96623e5430da0ad6c62b2',\n      ],\n      [\n        'b268f5ef9ad51e4d78de3a750c2dc89b1e626d43505867999932e5db33af3d80',\n        '5f310d4b3c99b9ebb19f77d41c1dee018cf0d34fd4191614003e945a1216e423',\n      ],\n      [\n        'ff07f3118a9df035e9fad85eb6c7bfe42b02f01ca99ceea3bf7ffdba93c4750d',\n        '438136d603e858a3a5c440c38eccbaddc1d2942114e2eddd4740d098ced1f0d8',\n      ],\n      [\n        '8d8b9855c7c052a34146fd20ffb658bea4b9f69e0d825ebec16e8c3ce2b526a1',\n        'cdb559eedc2d79f926baf44fb84ea4d44bcf50fee51d7ceb30e2e7f463036758',\n      ],\n      [\n        '52db0b5384dfbf05bfa9d472d7ae26dfe4b851ceca91b1eba54263180da32b63',\n        'c3b997d050ee5d423ebaf66a6db9f57b3180c902875679de924b69d84a7b375',\n      ],\n      [\n        'e62f9490d3d51da6395efd24e80919cc7d0f29c3f3fa48c6fff543becbd43352',\n        '6d89ad7ba4876b0b22c2ca280c682862f342c8591f1daf5170e07bfd9ccafa7d',\n      ],\n      [\n        '7f30ea2476b399b4957509c88f77d0191afa2ff5cb7b14fd6d8e7d65aaab1193',\n        'ca5ef7d4b231c94c3b15389a5f6311e9daff7bb67b103e9880ef4bff637acaec',\n      ],\n      [\n        '5098ff1e1d9f14fb46a210fada6c903fef0fb7b4a1dd1d9ac60a0361800b7a00',\n        '9731141d81fc8f8084d37c6e7542006b3ee1b40d60dfe5362a5b132fd17ddc0',\n      ],\n      [\n        '32b78c7de9ee512a72895be6b9cbefa6e2f3c4ccce445c96b9f2c81e2778ad58',\n        'ee1849f513df71e32efc3896ee28260c73bb80547ae2275ba497237794c8753c',\n      ],\n      [\n        'e2cb74fddc8e9fbcd076eef2a7c72b0ce37d50f08269dfc074b581550547a4f7',\n        'd3aa2ed71c9dd2247a62df062736eb0baddea9e36122d2be8641abcb005cc4a4',\n      ],\n      [\n        '8438447566d4d7bedadc299496ab357426009a35f235cb141be0d99cd10ae3a8',\n        'c4e1020916980a4da5d01ac5e6ad330734ef0d7906631c4f2390426b2edd791f',\n      ],\n      [\n        '4162d488b89402039b584c6fc6c308870587d9c46f660b878ab65c82c711d67e',\n        '67163e903236289f776f22c25fb8a3afc1732f2b84b4e95dbda47ae5a0852649',\n      ],\n      [\n        '3fad3fa84caf0f34f0f89bfd2dcf54fc175d767aec3e50684f3ba4a4bf5f683d',\n        'cd1bc7cb6cc407bb2f0ca647c718a730cf71872e7d0d2a53fa20efcdfe61826',\n      ],\n      [\n        '674f2600a3007a00568c1a7ce05d0816c1fb84bf1370798f1c69532faeb1a86b',\n        '299d21f9413f33b3edf43b257004580b70db57da0b182259e09eecc69e0d38a5',\n      ],\n      [\n        'd32f4da54ade74abb81b815ad1fb3b263d82d6c692714bcff87d29bd5ee9f08f',\n        'f9429e738b8e53b968e99016c059707782e14f4535359d582fc416910b3eea87',\n      ],\n      [\n        '30e4e670435385556e593657135845d36fbb6931f72b08cb1ed954f1e3ce3ff6',\n        '462f9bce619898638499350113bbc9b10a878d35da70740dc695a559eb88db7b',\n      ],\n      [\n        'be2062003c51cc3004682904330e4dee7f3dcd10b01e580bf1971b04d4cad297',\n        '62188bc49d61e5428573d48a74e1c655b1c61090905682a0d5558ed72dccb9bc',\n      ],\n      [\n        '93144423ace3451ed29e0fb9ac2af211cb6e84a601df5993c419859fff5df04a',\n        '7c10dfb164c3425f5c71a3f9d7992038f1065224f72bb9d1d902a6d13037b47c',\n      ],\n      [\n        'b015f8044f5fcbdcf21ca26d6c34fb8197829205c7b7d2a7cb66418c157b112c',\n        'ab8c1e086d04e813744a655b2df8d5f83b3cdc6faa3088c1d3aea1454e3a1d5f',\n      ],\n      [\n        'd5e9e1da649d97d89e4868117a465a3a4f8a18de57a140d36b3f2af341a21b52',\n        '4cb04437f391ed73111a13cc1d4dd0db1693465c2240480d8955e8592f27447a',\n      ],\n      [\n        'd3ae41047dd7ca065dbf8ed77b992439983005cd72e16d6f996a5316d36966bb',\n        'bd1aeb21ad22ebb22a10f0303417c6d964f8cdd7df0aca614b10dc14d125ac46',\n      ],\n      [\n        '463e2763d885f958fc66cdd22800f0a487197d0a82e377b49f80af87c897b065',\n        'bfefacdb0e5d0fd7df3a311a94de062b26b80c61fbc97508b79992671ef7ca7f',\n      ],\n      [\n        '7985fdfd127c0567c6f53ec1bb63ec3158e597c40bfe747c83cddfc910641917',\n        '603c12daf3d9862ef2b25fe1de289aed24ed291e0ec6708703a5bd567f32ed03',\n      ],\n      [\n        '74a1ad6b5f76e39db2dd249410eac7f99e74c59cb83d2d0ed5ff1543da7703e9',\n        'cc6157ef18c9c63cd6193d83631bbea0093e0968942e8c33d5737fd790e0db08',\n      ],\n      [\n        '30682a50703375f602d416664ba19b7fc9bab42c72747463a71d0896b22f6da3',\n        '553e04f6b018b4fa6c8f39e7f311d3176290d0e0f19ca73f17714d9977a22ff8',\n      ],\n      [\n        '9e2158f0d7c0d5f26c3791efefa79597654e7a2b2464f52b1ee6c1347769ef57',\n        '712fcdd1b9053f09003a3481fa7762e9ffd7c8ef35a38509e2fbf2629008373',\n      ],\n      [\n        '176e26989a43c9cfeba4029c202538c28172e566e3c4fce7322857f3be327d66',\n        'ed8cc9d04b29eb877d270b4878dc43c19aefd31f4eee09ee7b47834c1fa4b1c3',\n      ],\n      [\n        '75d46efea3771e6e68abb89a13ad747ecf1892393dfc4f1b7004788c50374da8',\n        '9852390a99507679fd0b86fd2b39a868d7efc22151346e1a3ca4726586a6bed8',\n      ],\n      [\n        '809a20c67d64900ffb698c4c825f6d5f2310fb0451c869345b7319f645605721',\n        '9e994980d9917e22b76b061927fa04143d096ccc54963e6a5ebfa5f3f8e286c1',\n      ],\n      [\n        '1b38903a43f7f114ed4500b4eac7083fdefece1cf29c63528d563446f972c180',\n        '4036edc931a60ae889353f77fd53de4a2708b26b6f5da72ad3394119daf408f9',\n      ],\n    ],\n  },\n};\n",
    "'use strict';\n\nvar curves = exports;\n\nvar hash = require('hash.js');\nvar curve = require('./curve');\nvar utils = require('./utils');\n\nvar assert = utils.assert;\n\nfunction PresetCurve(options) {\n  if (options.type === 'short')\n    this.curve = new curve.short(options);\n  else if (options.type === 'edwards')\n    this.curve = new curve.edwards(options);\n  else\n    this.curve = new curve.mont(options);\n  this.g = this.curve.g;\n  this.n = this.curve.n;\n  this.hash = options.hash;\n\n  assert(this.g.validate(), 'Invalid curve');\n  assert(this.g.mul(this.n).isInfinity(), 'Invalid curve, G*N != O');\n}\ncurves.PresetCurve = PresetCurve;\n\nfunction defineCurve(name, options) {\n  Object.defineProperty(curves, name, {\n    configurable: true,\n    enumerable: true,\n    get: function() {\n      var curve = new PresetCurve(options);\n      Object.defineProperty(curves, name, {\n        configurable: true,\n        enumerable: true,\n        value: curve,\n      });\n      return curve;\n    },\n  });\n}\n\ndefineCurve('p192', {\n  type: 'short',\n  prime: 'p192',\n  p: 'ffffffff ffffffff ffffffff fffffffe ffffffff ffffffff',\n  a: 'ffffffff ffffffff ffffffff fffffffe ffffffff fffffffc',\n  b: '64210519 e59c80e7 0fa7e9ab 72243049 feb8deec c146b9b1',\n  n: 'ffffffff ffffffff ffffffff 99def836 146bc9b1 b4d22831',\n  hash: hash.sha256,\n  gRed: false,\n  g: [\n    '188da80e b03090f6 7cbf20eb 43a18800 f4ff0afd 82ff1012',\n    '07192b95 ffc8da78 631011ed 6b24cdd5 73f977a1 1e794811',\n  ],\n});\n\ndefineCurve('p224', {\n  type: 'short',\n  prime: 'p224',\n  p: 'ffffffff ffffffff ffffffff ffffffff 00000000 00000000 00000001',\n  a: 'ffffffff ffffffff ffffffff fffffffe ffffffff ffffffff fffffffe',\n  b: 'b4050a85 0c04b3ab f5413256 5044b0b7 d7bfd8ba 270b3943 2355ffb4',\n  n: 'ffffffff ffffffff ffffffff ffff16a2 e0b8f03e 13dd2945 5c5c2a3d',\n  hash: hash.sha256,\n  gRed: false,\n  g: [\n    'b70e0cbd 6bb4bf7f 321390b9 4a03c1d3 56c21122 343280d6 115c1d21',\n    'bd376388 b5f723fb 4c22dfe6 cd4375a0 5a074764 44d58199 85007e34',\n  ],\n});\n\ndefineCurve('p256', {\n  type: 'short',\n  prime: null,\n  p: 'ffffffff 00000001 00000000 00000000 00000000 ffffffff ffffffff ffffffff',\n  a: 'ffffffff 00000001 00000000 00000000 00000000 ffffffff ffffffff fffffffc',\n  b: '5ac635d8 aa3a93e7 b3ebbd55 769886bc 651d06b0 cc53b0f6 3bce3c3e 27d2604b',\n  n: 'ffffffff 00000000 ffffffff ffffffff bce6faad a7179e84 f3b9cac2 fc632551',\n  hash: hash.sha256,\n  gRed: false,\n  g: [\n    '6b17d1f2 e12c4247 f8bce6e5 63a440f2 77037d81 2deb33a0 f4a13945 d898c296',\n    '4fe342e2 fe1a7f9b 8ee7eb4a 7c0f9e16 2bce3357 6b315ece cbb64068 37bf51f5',\n  ],\n});\n\ndefineCurve('p384', {\n  type: 'short',\n  prime: null,\n  p: 'ffffffff ffffffff ffffffff ffffffff ffffffff ffffffff ffffffff ' +\n     'fffffffe ffffffff 00000000 00000000 ffffffff',\n  a: 'ffffffff ffffffff ffffffff ffffffff ffffffff ffffffff ffffffff ' +\n     'fffffffe ffffffff 00000000 00000000 fffffffc',\n  b: 'b3312fa7 e23ee7e4 988e056b e3f82d19 181d9c6e fe814112 0314088f ' +\n     '5013875a c656398d 8a2ed19d 2a85c8ed d3ec2aef',\n  n: 'ffffffff ffffffff ffffffff ffffffff ffffffff ffffffff c7634d81 ' +\n     'f4372ddf 581a0db2 48b0a77a ecec196a ccc52973',\n  hash: hash.sha384,\n  gRed: false,\n  g: [\n    'aa87ca22 be8b0537 8eb1c71e f320ad74 6e1d3b62 8ba79b98 59f741e0 82542a38 ' +\n    '5502f25d bf55296c 3a545e38 72760ab7',\n    '3617de4a 96262c6f 5d9e98bf 9292dc29 f8f41dbd 289a147c e9da3113 b5f0b8c0 ' +\n    '0a60b1ce 1d7e819d 7a431d7c 90ea0e5f',\n  ],\n});\n\ndefineCurve('p521', {\n  type: 'short',\n  prime: null,\n  p: '000001ff ffffffff ffffffff ffffffff ffffffff ffffffff ' +\n     'ffffffff ffffffff ffffffff ffffffff ffffffff ffffffff ' +\n     'ffffffff ffffffff ffffffff ffffffff ffffffff',\n  a: '000001ff ffffffff ffffffff ffffffff ffffffff ffffffff ' +\n     'ffffffff ffffffff ffffffff ffffffff ffffffff ffffffff ' +\n     'ffffffff ffffffff ffffffff ffffffff fffffffc',\n  b: '00000051 953eb961 8e1c9a1f 929a21a0 b68540ee a2da725b ' +\n     '99b315f3 b8b48991 8ef109e1 56193951 ec7e937b 1652c0bd ' +\n     '3bb1bf07 3573df88 3d2c34f1 ef451fd4 6b503f00',\n  n: '000001ff ffffffff ffffffff ffffffff ffffffff ffffffff ' +\n     'ffffffff ffffffff fffffffa 51868783 bf2f966b 7fcc0148 ' +\n     'f709a5d0 3bb5c9b8 899c47ae bb6fb71e 91386409',\n  hash: hash.sha512,\n  gRed: false,\n  g: [\n    '000000c6 858e06b7 0404e9cd 9e3ecb66 2395b442 9c648139 ' +\n    '053fb521 f828af60 6b4d3dba a14b5e77 efe75928 fe1dc127 ' +\n    'a2ffa8de 3348b3c1 856a429b f97e7e31 c2e5bd66',\n    '00000118 39296a78 9a3bc004 5c8a5fb4 2c7d1bd9 98f54449 ' +\n    '579b4468 17afbd17 273e662c 97ee7299 5ef42640 c550b901 ' +\n    '3fad0761 353c7086 a272c240 88be9476 9fd16650',\n  ],\n});\n\ndefineCurve('curve25519', {\n  type: 'mont',\n  prime: 'p25519',\n  p: '7fffffffffffffff ffffffffffffffff ffffffffffffffff ffffffffffffffed',\n  a: '76d06',\n  b: '1',\n  n: '1000000000000000 0000000000000000 14def9dea2f79cd6 5812631a5cf5d3ed',\n  hash: hash.sha256,\n  gRed: false,\n  g: [\n    '9',\n  ],\n});\n\ndefineCurve('ed25519', {\n  type: 'edwards',\n  prime: 'p25519',\n  p: '7fffffffffffffff ffffffffffffffff ffffffffffffffff ffffffffffffffed',\n  a: '-1',\n  c: '1',\n  // -121665 * (121666^(-1)) (mod P)\n  d: '52036cee2b6ffe73 8cc740797779e898 00700a4d4141d8ab 75eb4dca135978a3',\n  n: '1000000000000000 0000000000000000 14def9dea2f79cd6 5812631a5cf5d3ed',\n  hash: hash.sha256,\n  gRed: false,\n  g: [\n    '216936d3cd6e53fec0a4e231fdd6dc5c692cc7609525a7b2c9562d608f25d51a',\n\n    // 4/5\n    '6666666666666666666666666666666666666666666666666666666666666658',\n  ],\n});\n\nvar pre;\ntry {\n  pre = require('./precomputed/secp256k1');\n} catch (e) {\n  pre = undefined;\n}\n\ndefineCurve('secp256k1', {\n  type: 'short',\n  prime: 'k256',\n  p: 'ffffffff ffffffff ffffffff ffffffff ffffffff ffffffff fffffffe fffffc2f',\n  a: '0',\n  b: '7',\n  n: 'ffffffff ffffffff ffffffff fffffffe baaedce6 af48a03b bfd25e8c d0364141',\n  h: '1',\n  hash: hash.sha256,\n\n  // Precomputed endomorphism\n  beta: '7ae96a2b657c07106e64479eac3434e99cf0497512f58995c1396c28719501ee',\n  lambda: '5363ad4cc05c30e0a5261c028812645a122e22ea20816678df02967c1b23bd72',\n  basis: [\n    {\n      a: '3086d221a7d46bcde86c90e49284eb15',\n      b: '-e4437ed6010e88286f547fa90abfe4c3',\n    },\n    {\n      a: '114ca50f7a8e2f3f657c1108d9d44cfd8',\n      b: '3086d221a7d46bcde86c90e49284eb15',\n    },\n  ],\n\n  gRed: false,\n  g: [\n    '79be667ef9dcbbac55a06295ce870b07029bfcdb2dce28d959f2815b16f81798',\n    '483ada7726a3c4655da4fbfc0e1108a8fd17b448a68554199c47d08ffb10d4b8',\n    pre,\n  ],\n});\n",
    "'use strict';\n\nvar hash = require('hash.js');\nvar utils = require('minimalistic-crypto-utils');\nvar assert = require('minimalistic-assert');\n\nfunction HmacDRBG(options) {\n  if (!(this instanceof HmacDRBG))\n    return new HmacDRBG(options);\n  this.hash = options.hash;\n  this.predResist = !!options.predResist;\n\n  this.outLen = this.hash.outSize;\n  this.minEntropy = options.minEntropy || this.hash.hmacStrength;\n\n  this._reseed = null;\n  this.reseedInterval = null;\n  this.K = null;\n  this.V = null;\n\n  var entropy = utils.toArray(options.entropy, options.entropyEnc || 'hex');\n  var nonce = utils.toArray(options.nonce, options.nonceEnc || 'hex');\n  var pers = utils.toArray(options.pers, options.persEnc || 'hex');\n  assert(entropy.length >= (this.minEntropy / 8),\n         'Not enough entropy. Minimum is: ' + this.minEntropy + ' bits');\n  this._init(entropy, nonce, pers);\n}\nmodule.exports = HmacDRBG;\n\nHmacDRBG.prototype._init = function init(entropy, nonce, pers) {\n  var seed = entropy.concat(nonce).concat(pers);\n\n  this.K = new Array(this.outLen / 8);\n  this.V = new Array(this.outLen / 8);\n  for (var i = 0; i < this.V.length; i++) {\n    this.K[i] = 0x00;\n    this.V[i] = 0x01;\n  }\n\n  this._update(seed);\n  this._reseed = 1;\n  this.reseedInterval = 0x1000000000000;  // 2^48\n};\n\nHmacDRBG.prototype._hmac = function hmac() {\n  return new hash.hmac(this.hash, this.K);\n};\n\nHmacDRBG.prototype._update = function update(seed) {\n  var kmac = this._hmac()\n                 .update(this.V)\n                 .update([ 0x00 ]);\n  if (seed)\n    kmac = kmac.update(seed);\n  this.K = kmac.digest();\n  this.V = this._hmac().update(this.V).digest();\n  if (!seed)\n    return;\n\n  this.K = this._hmac()\n               .update(this.V)\n               .update([ 0x01 ])\n               .update(seed)\n               .digest();\n  this.V = this._hmac().update(this.V).digest();\n};\n\nHmacDRBG.prototype.reseed = function reseed(entropy, entropyEnc, add, addEnc) {\n  // Optional entropy enc\n  if (typeof entropyEnc !== 'string') {\n    addEnc = add;\n    add = entropyEnc;\n    entropyEnc = null;\n  }\n\n  entropy = utils.toArray(entropy, entropyEnc);\n  add = utils.toArray(add, addEnc);\n\n  assert(entropy.length >= (this.minEntropy / 8),\n         'Not enough entropy. Minimum is: ' + this.minEntropy + ' bits');\n\n  this._update(entropy.concat(add || []));\n  this._reseed = 1;\n};\n\nHmacDRBG.prototype.generate = function generate(len, enc, add, addEnc) {\n  if (this._reseed > this.reseedInterval)\n    throw new Error('Reseed is required');\n\n  // Optional encoding\n  if (typeof enc !== 'string') {\n    addEnc = add;\n    add = enc;\n    enc = null;\n  }\n\n  // Optional additional data\n  if (add) {\n    add = utils.toArray(add, addEnc || 'hex');\n    this._update(add);\n  }\n\n  var temp = [];\n  while (temp.length < len) {\n    this.V = this._hmac().update(this.V).digest();\n    temp = temp.concat(this.V);\n  }\n\n  var res = temp.slice(0, len);\n  this._update(add);\n  this._reseed++;\n  return utils.encode(res, enc);\n};\n",
    "'use strict';\n\nvar BN = require('bn.js');\nvar utils = require('../utils');\nvar assert = utils.assert;\n\nfunction KeyPair(ec, options) {\n  this.ec = ec;\n  this.priv = null;\n  this.pub = null;\n\n  // KeyPair(ec, { priv: ..., pub: ... })\n  if (options.priv)\n    this._importPrivate(options.priv, options.privEnc);\n  if (options.pub)\n    this._importPublic(options.pub, options.pubEnc);\n}\nmodule.exports = KeyPair;\n\nKeyPair.fromPublic = function fromPublic(ec, pub, enc) {\n  if (pub instanceof KeyPair)\n    return pub;\n\n  return new KeyPair(ec, {\n    pub: pub,\n    pubEnc: enc,\n  });\n};\n\nKeyPair.fromPrivate = function fromPrivate(ec, priv, enc) {\n  if (priv instanceof KeyPair)\n    return priv;\n\n  return new KeyPair(ec, {\n    priv: priv,\n    privEnc: enc,\n  });\n};\n\nKeyPair.prototype.validate = function validate() {\n  var pub = this.getPublic();\n\n  if (pub.isInfinity())\n    return { result: false, reason: 'Invalid public key' };\n  if (!pub.validate())\n    return { result: false, reason: 'Public key is not a point' };\n  if (!pub.mul(this.ec.curve.n).isInfinity())\n    return { result: false, reason: 'Public key * N != O' };\n\n  return { result: true, reason: null };\n};\n\nKeyPair.prototype.getPublic = function getPublic(compact, enc) {\n  // compact is optional argument\n  if (typeof compact === 'string') {\n    enc = compact;\n    compact = null;\n  }\n\n  if (!this.pub)\n    this.pub = this.ec.g.mul(this.priv);\n\n  if (!enc)\n    return this.pub;\n\n  return this.pub.encode(enc, compact);\n};\n\nKeyPair.prototype.getPrivate = function getPrivate(enc) {\n  if (enc === 'hex')\n    return this.priv.toString(16, 2);\n  else\n    return this.priv;\n};\n\nKeyPair.prototype._importPrivate = function _importPrivate(key, enc) {\n  this.priv = new BN(key, enc || 16);\n\n  // Ensure that the priv won't be bigger than n, otherwise we may fail\n  // in fixed multiplication method\n  this.priv = this.priv.umod(this.ec.curve.n);\n};\n\nKeyPair.prototype._importPublic = function _importPublic(key, enc) {\n  if (key.x || key.y) {\n    // Montgomery points only have an `x` coordinate.\n    // Weierstrass/Edwards points on the other hand have both `x` and\n    // `y` coordinates.\n    if (this.ec.curve.type === 'mont') {\n      assert(key.x, 'Need x coordinate');\n    } else if (this.ec.curve.type === 'short' ||\n               this.ec.curve.type === 'edwards') {\n      assert(key.x && key.y, 'Need both x and y coordinate');\n    }\n    this.pub = this.ec.curve.point(key.x, key.y);\n    return;\n  }\n  this.pub = this.ec.curve.decodePoint(key, enc);\n};\n\n// ECDH\nKeyPair.prototype.derive = function derive(pub) {\n  if(!pub.validate()) {\n    assert(pub.validate(), 'public point not validated');\n  }\n  return pub.mul(this.priv).getX();\n};\n\n// ECDSA\nKeyPair.prototype.sign = function sign(msg, enc, options) {\n  return this.ec.sign(msg, this, enc, options);\n};\n\nKeyPair.prototype.verify = function verify(msg, signature, options) {\n  return this.ec.verify(msg, signature, this, undefined, options);\n};\n\nKeyPair.prototype.inspect = function inspect() {\n  return '<Key priv: ' + (this.priv && this.priv.toString(16, 2)) +\n         ' pub: ' + (this.pub && this.pub.inspect()) + ' >';\n};\n",
    "'use strict';\n\nvar BN = require('bn.js');\n\nvar utils = require('../utils');\nvar assert = utils.assert;\n\nfunction Signature(options, enc) {\n  if (options instanceof Signature)\n    return options;\n\n  if (this._importDER(options, enc))\n    return;\n\n  assert(options.r && options.s, 'Signature without r or s');\n  this.r = new BN(options.r, 16);\n  this.s = new BN(options.s, 16);\n  if (options.recoveryParam === undefined)\n    this.recoveryParam = null;\n  else\n    this.recoveryParam = options.recoveryParam;\n}\nmodule.exports = Signature;\n\nfunction Position() {\n  this.place = 0;\n}\n\nfunction getLength(buf, p) {\n  var initial = buf[p.place++];\n  if (!(initial & 0x80)) {\n    return initial;\n  }\n  var octetLen = initial & 0xf;\n\n  // Indefinite length or overflow\n  if (octetLen === 0 || octetLen > 4) {\n    return false;\n  }\n\n  if(buf[p.place] === 0x00) {\n    return false;\n  }\n\n  var val = 0;\n  for (var i = 0, off = p.place; i < octetLen; i++, off++) {\n    val <<= 8;\n    val |= buf[off];\n    val >>>= 0;\n  }\n\n  // Leading zeroes\n  if (val <= 0x7f) {\n    return false;\n  }\n\n  p.place = off;\n  return val;\n}\n\nfunction rmPadding(buf) {\n  var i = 0;\n  var len = buf.length - 1;\n  while (!buf[i] && !(buf[i + 1] & 0x80) && i < len) {\n    i++;\n  }\n  if (i === 0) {\n    return buf;\n  }\n  return buf.slice(i);\n}\n\nSignature.prototype._importDER = function _importDER(data, enc) {\n  data = utils.toArray(data, enc);\n  var p = new Position();\n  if (data[p.place++] !== 0x30) {\n    return false;\n  }\n  var len = getLength(data, p);\n  if (len === false) {\n    return false;\n  }\n  if ((len + p.place) !== data.length) {\n    return false;\n  }\n  if (data[p.place++] !== 0x02) {\n    return false;\n  }\n  var rlen = getLength(data, p);\n  if (rlen === false) {\n    return false;\n  }\n  if ((data[p.place] & 128) !== 0) {\n    return false;\n  }\n  var r = data.slice(p.place, rlen + p.place);\n  p.place += rlen;\n  if (data[p.place++] !== 0x02) {\n    return false;\n  }\n  var slen = getLength(data, p);\n  if (slen === false) {\n    return false;\n  }\n  if (data.length !== slen + p.place) {\n    return false;\n  }\n  if ((data[p.place] & 128) !== 0) {\n    return false;\n  }\n  var s = data.slice(p.place, slen + p.place);\n  if (r[0] === 0) {\n    if (r[1] & 0x80) {\n      r = r.slice(1);\n    } else {\n      // Leading zeroes\n      return false;\n    }\n  }\n  if (s[0] === 0) {\n    if (s[1] & 0x80) {\n      s = s.slice(1);\n    } else {\n      // Leading zeroes\n      return false;\n    }\n  }\n\n  this.r = new BN(r);\n  this.s = new BN(s);\n  this.recoveryParam = null;\n\n  return true;\n};\n\nfunction constructLength(arr, len) {\n  if (len < 0x80) {\n    arr.push(len);\n    return;\n  }\n  var octets = 1 + (Math.log(len) / Math.LN2 >>> 3);\n  arr.push(octets | 0x80);\n  while (--octets) {\n    arr.push((len >>> (octets << 3)) & 0xff);\n  }\n  arr.push(len);\n}\n\nSignature.prototype.toDER = function toDER(enc) {\n  var r = this.r.toArray();\n  var s = this.s.toArray();\n\n  // Pad values\n  if (r[0] & 0x80)\n    r = [ 0 ].concat(r);\n  // Pad values\n  if (s[0] & 0x80)\n    s = [ 0 ].concat(s);\n\n  r = rmPadding(r);\n  s = rmPadding(s);\n\n  while (!s[0] && !(s[1] & 0x80)) {\n    s = s.slice(1);\n  }\n  var arr = [ 0x02 ];\n  constructLength(arr, r.length);\n  arr = arr.concat(r);\n  arr.push(0x02);\n  constructLength(arr, s.length);\n  var backHalf = arr.concat(s);\n  var res = [ 0x30 ];\n  constructLength(res, backHalf.length);\n  res = res.concat(backHalf);\n  return utils.encode(res, enc);\n};\n",
    "'use strict';\n\nvar BN = require('bn.js');\nvar HmacDRBG = require('hmac-drbg');\nvar utils = require('../utils');\nvar curves = require('../curves');\nvar rand = require('brorand');\nvar assert = utils.assert;\n\nvar KeyPair = require('./key');\nvar Signature = require('./signature');\n\nfunction EC(options) {\n  if (!(this instanceof EC))\n    return new EC(options);\n\n  // Shortcut `elliptic.ec(curve-name)`\n  if (typeof options === 'string') {\n    assert(Object.prototype.hasOwnProperty.call(curves, options),\n      'Unknown curve ' + options);\n\n    options = curves[options];\n  }\n\n  // Shortcut for `elliptic.ec(elliptic.curves.curveName)`\n  if (options instanceof curves.PresetCurve)\n    options = { curve: options };\n\n  this.curve = options.curve.curve;\n  this.n = this.curve.n;\n  this.nh = this.n.ushrn(1);\n  this.g = this.curve.g;\n\n  // Point on curve\n  this.g = options.curve.g;\n  this.g.precompute(options.curve.n.bitLength() + 1);\n\n  // Hash for function for DRBG\n  this.hash = options.hash || options.curve.hash;\n}\nmodule.exports = EC;\n\nEC.prototype.keyPair = function keyPair(options) {\n  return new KeyPair(this, options);\n};\n\nEC.prototype.keyFromPrivate = function keyFromPrivate(priv, enc) {\n  return KeyPair.fromPrivate(this, priv, enc);\n};\n\nEC.prototype.keyFromPublic = function keyFromPublic(pub, enc) {\n  return KeyPair.fromPublic(this, pub, enc);\n};\n\nEC.prototype.genKeyPair = function genKeyPair(options) {\n  if (!options)\n    options = {};\n\n  // Instantiate Hmac_DRBG\n  var drbg = new HmacDRBG({\n    hash: this.hash,\n    pers: options.pers,\n    persEnc: options.persEnc || 'utf8',\n    entropy: options.entropy || rand(this.hash.hmacStrength),\n    entropyEnc: options.entropy && options.entropyEnc || 'utf8',\n    nonce: this.n.toArray(),\n  });\n\n  var bytes = this.n.byteLength();\n  var ns2 = this.n.sub(new BN(2));\n  for (;;) {\n    var priv = new BN(drbg.generate(bytes));\n    if (priv.cmp(ns2) > 0)\n      continue;\n\n    priv.iaddn(1);\n    return this.keyFromPrivate(priv);\n  }\n};\n\nEC.prototype._truncateToN = function _truncateToN(msg, truncOnly, bitLength) {\n  var byteLength;\n  if (BN.isBN(msg) || typeof msg === 'number') {\n    msg = new BN(msg, 16);\n    byteLength = msg.byteLength();\n  } else if (typeof msg === 'object') {\n    // BN assumes an array-like input and asserts length\n    byteLength = msg.length;\n    msg = new BN(msg, 16);\n  } else {\n    // BN converts the value to string\n    var str = msg.toString();\n    // HEX encoding\n    byteLength = (str.length + 1) >>> 1;\n    msg = new BN(str, 16);\n  }\n  // Allow overriding\n  if (typeof bitLength !== 'number') {\n    bitLength = byteLength * 8;\n  }\n  var delta = bitLength - this.n.bitLength();\n  if (delta > 0)\n    msg = msg.ushrn(delta);\n  if (!truncOnly && msg.cmp(this.n) >= 0)\n    return msg.sub(this.n);\n  else\n    return msg;\n};\n\nEC.prototype.sign = function sign(msg, key, enc, options) {\n  if (typeof enc === 'object') {\n    options = enc;\n    enc = null;\n  }\n  if (!options)\n    options = {};\n\n  if (typeof msg !== 'string' && typeof msg !== 'number' && !BN.isBN(msg)) {\n    assert(typeof msg === 'object' && msg && typeof msg.length === 'number',\n      'Expected message to be an array-like, a hex string, or a BN instance');\n    assert((msg.length >>> 0) === msg.length); // non-negative 32-bit integer\n    for (var i = 0; i < msg.length; i++) assert((msg[i] & 255) === msg[i]);\n  }\n\n  key = this.keyFromPrivate(key, enc);\n  msg = this._truncateToN(msg, false, options.msgBitLength);\n\n  // Would fail further checks, but let's make the error message clear\n  assert(!msg.isNeg(), 'Can not sign a negative message');\n\n  // Zero-extend key to provide enough entropy\n  var bytes = this.n.byteLength();\n  var bkey = key.getPrivate().toArray('be', bytes);\n\n  // Zero-extend nonce to have the same byte size as N\n  var nonce = msg.toArray('be', bytes);\n\n  // Recheck nonce to be bijective to msg\n  assert((new BN(nonce)).eq(msg), 'Can not sign message');\n\n  // Instantiate Hmac_DRBG\n  var drbg = new HmacDRBG({\n    hash: this.hash,\n    entropy: bkey,\n    nonce: nonce,\n    pers: options.pers,\n    persEnc: options.persEnc || 'utf8',\n  });\n\n  // Number of bytes to generate\n  var ns1 = this.n.sub(new BN(1));\n\n  for (var iter = 0; ; iter++) {\n    var k = options.k ?\n      options.k(iter) :\n      new BN(drbg.generate(this.n.byteLength()));\n    k = this._truncateToN(k, true);\n    if (k.cmpn(1) <= 0 || k.cmp(ns1) >= 0)\n      continue;\n\n    var kp = this.g.mul(k);\n    if (kp.isInfinity())\n      continue;\n\n    var kpX = kp.getX();\n    var r = kpX.umod(this.n);\n    if (r.cmpn(0) === 0)\n      continue;\n\n    var s = k.invm(this.n).mul(r.mul(key.getPrivate()).iadd(msg));\n    s = s.umod(this.n);\n    if (s.cmpn(0) === 0)\n      continue;\n\n    var recoveryParam = (kp.getY().isOdd() ? 1 : 0) |\n                        (kpX.cmp(r) !== 0 ? 2 : 0);\n\n    // Use complement of `s`, if it is > `n / 2`\n    if (options.canonical && s.cmp(this.nh) > 0) {\n      s = this.n.sub(s);\n      recoveryParam ^= 1;\n    }\n\n    return new Signature({ r: r, s: s, recoveryParam: recoveryParam });\n  }\n};\n\nEC.prototype.verify = function verify(msg, signature, key, enc, options) {\n  if (!options)\n    options = {};\n\n  msg = this._truncateToN(msg, false, options.msgBitLength);\n  key = this.keyFromPublic(key, enc);\n  signature = new Signature(signature, 'hex');\n\n  // Perform primitive values validation\n  var r = signature.r;\n  var s = signature.s;\n  if (r.cmpn(1) < 0 || r.cmp(this.n) >= 0)\n    return false;\n  if (s.cmpn(1) < 0 || s.cmp(this.n) >= 0)\n    return false;\n\n  // Validate signature\n  var sinv = s.invm(this.n);\n  var u1 = sinv.mul(msg).umod(this.n);\n  var u2 = sinv.mul(r).umod(this.n);\n  var p;\n\n  if (!this.curve._maxwellTrick) {\n    p = this.g.mulAdd(u1, key.getPublic(), u2);\n    if (p.isInfinity())\n      return false;\n\n    return p.getX().umod(this.n).cmp(r) === 0;\n  }\n\n  // NOTE: Greg Maxwell's trick, inspired by:\n  // https://git.io/vad3K\n\n  p = this.g.jmulAdd(u1, key.getPublic(), u2);\n  if (p.isInfinity())\n    return false;\n\n  // Compare `p.x` of Jacobian point with `r`,\n  // this will do `p.x == r * p.z^2` instead of multiplying `p.x` by the\n  // inverse of `p.z^2`\n  return p.eqXToP(r);\n};\n\nEC.prototype.recoverPubKey = function(msg, signature, j, enc) {\n  assert((3 & j) === j, 'The recovery param is more than two bits');\n  signature = new Signature(signature, enc);\n\n  var n = this.n;\n  var e = new BN(msg);\n  var r = signature.r;\n  var s = signature.s;\n\n  // A set LSB signifies that the y-coordinate is odd\n  var isYOdd = j & 1;\n  var isSecondKey = j >> 1;\n  if (r.cmp(this.curve.p.umod(this.curve.n)) >= 0 && isSecondKey)\n    throw new Error('Unable to find sencond key candinate');\n\n  // 1.1. Let x = r + jn.\n  if (isSecondKey)\n    r = this.curve.pointFromX(r.add(this.curve.n), isYOdd);\n  else\n    r = this.curve.pointFromX(r, isYOdd);\n\n  var rInv = signature.r.invm(n);\n  var s1 = n.sub(e).mul(rInv).umod(n);\n  var s2 = s.mul(rInv).umod(n);\n\n  // 1.6.1 Compute Q = r^-1 (sR -  eG)\n  //               Q = r^-1 (sR + -eG)\n  return this.g.mulAdd(s1, r, s2);\n};\n\nEC.prototype.getKeyRecoveryParam = function(e, signature, Q, enc) {\n  signature = new Signature(signature, enc);\n  if (signature.recoveryParam !== null)\n    return signature.recoveryParam;\n\n  for (var i = 0; i < 4; i++) {\n    var Qprime;\n    try {\n      Qprime = this.recoverPubKey(e, signature, i);\n    } catch (e) {\n      continue;\n    }\n\n    if (Qprime.eq(Q))\n      return i;\n  }\n  throw new Error('Unable to find valid recovery factor');\n};\n",
    "'use strict';\n\nvar utils = require('../utils');\nvar assert = utils.assert;\nvar parseBytes = utils.parseBytes;\nvar cachedProperty = utils.cachedProperty;\n\n/**\n* @param {EDDSA} eddsa - instance\n* @param {Object} params - public/private key parameters\n*\n* @param {Array<Byte>} [params.secret] - secret seed bytes\n* @param {Point} [params.pub] - public key point (aka `A` in eddsa terms)\n* @param {Array<Byte>} [params.pub] - public key point encoded as bytes\n*\n*/\nfunction KeyPair(eddsa, params) {\n  this.eddsa = eddsa;\n  this._secret = parseBytes(params.secret);\n  if (eddsa.isPoint(params.pub))\n    this._pub = params.pub;\n  else\n    this._pubBytes = parseBytes(params.pub);\n}\n\nKeyPair.fromPublic = function fromPublic(eddsa, pub) {\n  if (pub instanceof KeyPair)\n    return pub;\n  return new KeyPair(eddsa, { pub: pub });\n};\n\nKeyPair.fromSecret = function fromSecret(eddsa, secret) {\n  if (secret instanceof KeyPair)\n    return secret;\n  return new KeyPair(eddsa, { secret: secret });\n};\n\nKeyPair.prototype.secret = function secret() {\n  return this._secret;\n};\n\ncachedProperty(KeyPair, 'pubBytes', function pubBytes() {\n  return this.eddsa.encodePoint(this.pub());\n});\n\ncachedProperty(KeyPair, 'pub', function pub() {\n  if (this._pubBytes)\n    return this.eddsa.decodePoint(this._pubBytes);\n  return this.eddsa.g.mul(this.priv());\n});\n\ncachedProperty(KeyPair, 'privBytes', function privBytes() {\n  var eddsa = this.eddsa;\n  var hash = this.hash();\n  var lastIx = eddsa.encodingLength - 1;\n\n  var a = hash.slice(0, eddsa.encodingLength);\n  a[0] &= 248;\n  a[lastIx] &= 127;\n  a[lastIx] |= 64;\n\n  return a;\n});\n\ncachedProperty(KeyPair, 'priv', function priv() {\n  return this.eddsa.decodeInt(this.privBytes());\n});\n\ncachedProperty(KeyPair, 'hash', function hash() {\n  return this.eddsa.hash().update(this.secret()).digest();\n});\n\ncachedProperty(KeyPair, 'messagePrefix', function messagePrefix() {\n  return this.hash().slice(this.eddsa.encodingLength);\n});\n\nKeyPair.prototype.sign = function sign(message) {\n  assert(this._secret, 'KeyPair can only verify');\n  return this.eddsa.sign(message, this);\n};\n\nKeyPair.prototype.verify = function verify(message, sig) {\n  return this.eddsa.verify(message, sig, this);\n};\n\nKeyPair.prototype.getSecret = function getSecret(enc) {\n  assert(this._secret, 'KeyPair is public only');\n  return utils.encode(this.secret(), enc);\n};\n\nKeyPair.prototype.getPublic = function getPublic(enc) {\n  return utils.encode(this.pubBytes(), enc);\n};\n\nmodule.exports = KeyPair;\n",
    "'use strict';\n\nvar BN = require('bn.js');\nvar utils = require('../utils');\nvar assert = utils.assert;\nvar cachedProperty = utils.cachedProperty;\nvar parseBytes = utils.parseBytes;\n\n/**\n* @param {EDDSA} eddsa - eddsa instance\n* @param {Array<Bytes>|Object} sig -\n* @param {Array<Bytes>|Point} [sig.R] - R point as Point or bytes\n* @param {Array<Bytes>|bn} [sig.S] - S scalar as bn or bytes\n* @param {Array<Bytes>} [sig.Rencoded] - R point encoded\n* @param {Array<Bytes>} [sig.Sencoded] - S scalar encoded\n*/\nfunction Signature(eddsa, sig) {\n  this.eddsa = eddsa;\n\n  if (typeof sig !== 'object')\n    sig = parseBytes(sig);\n\n  if (Array.isArray(sig)) {\n    assert(sig.length === eddsa.encodingLength * 2, 'Signature has invalid size');\n    sig = {\n      R: sig.slice(0, eddsa.encodingLength),\n      S: sig.slice(eddsa.encodingLength),\n    };\n  }\n\n  assert(sig.R && sig.S, 'Signature without R or S');\n\n  if (eddsa.isPoint(sig.R))\n    this._R = sig.R;\n  if (sig.S instanceof BN)\n    this._S = sig.S;\n\n  this._Rencoded = Array.isArray(sig.R) ? sig.R : sig.Rencoded;\n  this._Sencoded = Array.isArray(sig.S) ? sig.S : sig.Sencoded;\n}\n\ncachedProperty(Signature, 'S', function S() {\n  return this.eddsa.decodeInt(this.Sencoded());\n});\n\ncachedProperty(Signature, 'R', function R() {\n  return this.eddsa.decodePoint(this.Rencoded());\n});\n\ncachedProperty(Signature, 'Rencoded', function Rencoded() {\n  return this.eddsa.encodePoint(this.R());\n});\n\ncachedProperty(Signature, 'Sencoded', function Sencoded() {\n  return this.eddsa.encodeInt(this.S());\n});\n\nSignature.prototype.toBytes = function toBytes() {\n  return this.Rencoded().concat(this.Sencoded());\n};\n\nSignature.prototype.toHex = function toHex() {\n  return utils.encode(this.toBytes(), 'hex').toUpperCase();\n};\n\nmodule.exports = Signature;\n",
    "'use strict';\n\nvar hash = require('hash.js');\nvar curves = require('../curves');\nvar utils = require('../utils');\nvar assert = utils.assert;\nvar parseBytes = utils.parseBytes;\nvar KeyPair = require('./key');\nvar Signature = require('./signature');\n\nfunction EDDSA(curve) {\n  assert(curve === 'ed25519', 'only tested with ed25519 so far');\n\n  if (!(this instanceof EDDSA))\n    return new EDDSA(curve);\n\n  curve = curves[curve].curve;\n  this.curve = curve;\n  this.g = curve.g;\n  this.g.precompute(curve.n.bitLength() + 1);\n\n  this.pointClass = curve.point().constructor;\n  this.encodingLength = Math.ceil(curve.n.bitLength() / 8);\n  this.hash = hash.sha512;\n}\n\nmodule.exports = EDDSA;\n\n/**\n* @param {Array|String} message - message bytes\n* @param {Array|String|KeyPair} secret - secret bytes or a keypair\n* @returns {Signature} - signature\n*/\nEDDSA.prototype.sign = function sign(message, secret) {\n  message = parseBytes(message);\n  var key = this.keyFromSecret(secret);\n  var r = this.hashInt(key.messagePrefix(), message);\n  var R = this.g.mul(r);\n  var Rencoded = this.encodePoint(R);\n  var s_ = this.hashInt(Rencoded, key.pubBytes(), message)\n    .mul(key.priv());\n  var S = r.add(s_).umod(this.curve.n);\n  return this.makeSignature({ R: R, S: S, Rencoded: Rencoded });\n};\n\n/**\n* @param {Array} message - message bytes\n* @param {Array|String|Signature} sig - sig bytes\n* @param {Array|String|Point|KeyPair} pub - public key\n* @returns {Boolean} - true if public key matches sig of message\n*/\nEDDSA.prototype.verify = function verify(message, sig, pub) {\n  message = parseBytes(message);\n  sig = this.makeSignature(sig);\n  if (sig.S().gte(sig.eddsa.curve.n) || sig.S().isNeg()) {\n    return false;\n  }\n  var key = this.keyFromPublic(pub);\n  var h = this.hashInt(sig.Rencoded(), key.pubBytes(), message);\n  var SG = this.g.mul(sig.S());\n  var RplusAh = sig.R().add(key.pub().mul(h));\n  return RplusAh.eq(SG);\n};\n\nEDDSA.prototype.hashInt = function hashInt() {\n  var hash = this.hash();\n  for (var i = 0; i < arguments.length; i++)\n    hash.update(arguments[i]);\n  return utils.intFromLE(hash.digest()).umod(this.curve.n);\n};\n\nEDDSA.prototype.keyFromPublic = function keyFromPublic(pub) {\n  return KeyPair.fromPublic(this, pub);\n};\n\nEDDSA.prototype.keyFromSecret = function keyFromSecret(secret) {\n  return KeyPair.fromSecret(this, secret);\n};\n\nEDDSA.prototype.makeSignature = function makeSignature(sig) {\n  if (sig instanceof Signature)\n    return sig;\n  return new Signature(this, sig);\n};\n\n/**\n* * https://tools.ietf.org/html/draft-josefsson-eddsa-ed25519-03#section-5.2\n*\n* EDDSA defines methods for encoding and decoding points and integers. These are\n* helper convenience methods, that pass along to utility functions implied\n* parameters.\n*\n*/\nEDDSA.prototype.encodePoint = function encodePoint(point) {\n  var enc = point.getY().toArray('le', this.encodingLength);\n  enc[this.encodingLength - 1] |= point.getX().isOdd() ? 0x80 : 0;\n  return enc;\n};\n\nEDDSA.prototype.decodePoint = function decodePoint(bytes) {\n  bytes = utils.parseBytes(bytes);\n\n  var lastIx = bytes.length - 1;\n  var normed = bytes.slice(0, lastIx).concat(bytes[lastIx] & ~0x80);\n  var xIsOdd = (bytes[lastIx] & 0x80) !== 0;\n\n  var y = utils.intFromLE(normed);\n  return this.curve.pointFromY(y, xIsOdd);\n};\n\nEDDSA.prototype.encodeInt = function encodeInt(num) {\n  return num.toArray('le', this.encodingLength);\n};\n\nEDDSA.prototype.decodeInt = function decodeInt(bytes) {\n  return utils.intFromLE(bytes);\n};\n\nEDDSA.prototype.isPoint = function isPoint(val) {\n  return val instanceof this.pointClass;\n};\n",
    "'use strict';\n\nvar elliptic = exports;\n\nelliptic.version = require('../package.json').version;\nelliptic.utils = require('./elliptic/utils');\nelliptic.rand = require('brorand');\nelliptic.curve = require('./elliptic/curve');\nelliptic.curves = require('./elliptic/curves');\n\n// Protocols\nelliptic.ec = require('./elliptic/ec');\nelliptic.eddsa = require('./elliptic/eddsa');\n",
    "'use strict';\n\nvar BN = require('asn1.js').bignum,\n\tBuffer = require('safe-buffer').Buffer;\n\nmodule.exports = function base64ToBigNum(val, zero) {\n\tvar buf = Buffer.from(val, 'base64');\n\tvar bn = val = new BN(buf, 10, 'be').iabs();\n\tif (zero) {\n\t\tbuf.fill(0);\n\t}\n\treturn bn;\n};\n",
    "'use strict';\n\nmodule.exports = require('asn1.js').define('AlgorithmIdentifer', /* @this */ function() {\n\tthis.seq().obj(\n\t\tthis.key('algorithm').objid(),\n\t\tthis.key('parameters').optional().any()\n\t);\n});\n",
    "'use strict';\n\nvar AlgorithmIdentifier = require('./algorithm-identifier');\n\nmodule.exports = require('asn1.js').define('PublicKeyInfo', /* @this */ function() {\n\tthis.seq().obj(\n\t\tthis.key('algorithm').use(AlgorithmIdentifier),\n\t\tthis.key('PublicKey').bitstr()\n\t);\n});\n",
    "'use strict';\n\nmodule.exports = require('asn1.js').define('Version', /* @this */ function() {\n\tthis.int();\n});\n",
    "'use strict';\n\nvar AlgorithmIdentifier = require('./algorithm-identifier');\nvar Version = require('./version');\n\nmodule.exports = require('asn1.js').define('PrivateKeyInfo', /* @this */ function() {\n\tthis.seq().obj(\n\t\tthis.key('version').use(Version),\n\t\tthis.key('privateKeyAlgorithm').use(AlgorithmIdentifier),\n\t\tthis.key('privateKey').octstr(),\n\t\tthis.key('attributes').optional().any()\n\t);\n});\n",
    "'use strict';\n\nvar asn1 = require('asn1.js'),\n\tBuffer = require('safe-buffer').Buffer,\n\tEC = require('elliptic').ec;\n\nvar b64ToBn = require('./b64-to-bn');\n\nvar PublicKeyInfo = require('./asn1/public-key-info'),\n\tPrivateKeyInfo = require('./asn1/private-key-info'),\n\tVersion = require('./asn1/version');\n\nvar ECParameters = asn1.define('ECParameters', /* @this */ function() {\n\tthis.choice({\n\t\tnamedCurve: this.objid()\n\t});\n});\n\nvar ecPrivkeyVer1 = 1;\n\nvar ECPrivateKey = asn1.define('ECPrivateKey', /* @this */ function() {\n\tthis.seq().obj(\n\t\tthis.key('version').use(Version),\n\t\tthis.key('privateKey').octstr(),\n\t\tthis.key('parameters').explicit(0).optional().any(),\n\t\tthis.key('publicKey').explicit(1).optional().bitstr()\n\t);\n});\n\nvar curves = {\n\t'P-256': 'p256',\n\t'P-384': 'p384',\n\t'P-521': 'p521'\n};\n\nvar oids = {\n\t'P-256': [1, 2, 840, 10045, 3, 1, 7],\n\t'P-384': [1, 3, 132, 0, 34],\n\t'P-521': [1, 3, 132, 0, 35]\n};\nvar parameters = {};\nvar algorithms = {};\nObject.keys(oids).forEach(function(crv) {\n\tparameters[crv] = ECParameters.encode({\n\t\ttype: 'namedCurve',\n\t\tvalue: oids[crv]\n\t}, 'der');\n\talgorithms[crv] = {\n\t\talgorithm:  [1, 2, 840, 10045, 2, 1],\n\t\tparameters: parameters[crv]\n\t};\n});\noids = null;\n\nfunction ecJwkToBuffer(jwk, opts) {\n\tif ('string' !== typeof jwk.crv) {\n\t\tthrow new TypeError('Expected \"jwk.crv\" to be a String');\n\t}\n\n\tvar hasD = 'string' === typeof jwk.d;\n\tvar xyTypes = hasD\n\t\t? ['undefined', 'string']\n\t\t: ['string'];\n\n\tif (-1 === xyTypes.indexOf(typeof jwk.x)) {\n\t\tthrow new TypeError('Expected \"jwk.x\" to be a String');\n\t}\n\n\tif (-1 === xyTypes.indexOf(typeof jwk.y)) {\n\t\tthrow new TypeError('Expected \"jwk.y\" to be a String');\n\t}\n\n\tif (opts.private && !hasD) {\n\t\tthrow new TypeError('Expected \"jwk.d\" to be a String');\n\t}\n\n\tvar curveName = curves[jwk.crv];\n\tif (!curveName) {\n\t\tthrow new Error('Unsupported curve \"' + jwk.crv + '\"');\n\t}\n\n\tvar curve = new EC(curveName);\n\n\tvar key = {};\n\n\tvar hasPub = jwk.x && jwk.y;\n\tif (hasPub) {\n\t\tkey.pub = {\n\t\t\tx: b64ToBn(jwk.x, false),\n\t\t\ty: b64ToBn(jwk.y, false)\n\t\t};\n\t}\n\n\tif (opts.private || !hasPub) {\n\t\tkey.priv = b64ToBn(jwk.d, true);\n\t}\n\n\tkey = curve.keyPair(key);\n\n\tvar keyValidation = key.validate();\n\tif (!keyValidation.result) {\n\t\tthrow new Error('Invalid key for curve: \"' + keyValidation.reason + '\"');\n\t}\n\n\tvar result = keyToPem(jwk.crv, key, opts);\n\n\treturn result;\n}\n\nfunction keyToPem(crv, key, opts) {\n\tvar compact = false;\n\tvar publicKey = key.getPublic(compact, 'hex');\n\tpublicKey = Buffer.from(publicKey, 'hex');\n\tpublicKey = {\n\t\tunused: 0,\n\t\tdata: publicKey\n\t};\n\n\tvar result;\n\tif (opts.private) {\n\t\tvar privateKey = key.getPrivate('hex');\n\t\tprivateKey = Buffer.from(privateKey, 'hex');\n\n\t\tresult = PrivateKeyInfo.encode({\n\t\t\tversion: 0,\n\t\t\tprivateKeyAlgorithm: algorithms[crv],\n\t\t\tprivateKey: ECPrivateKey.encode({\n\t\t\t\tversion: ecPrivkeyVer1,\n\t\t\t\tprivateKey: privateKey,\n\t\t\t\tparameters: parameters[crv],\n\t\t\t\tpublicKey: publicKey\n\t\t\t}, 'der')\n\t\t}, 'pem', {\n\t\t\tlabel: 'PRIVATE KEY'\n\t\t});\n\n\t\tprivateKey.fill(0);\n\t} else {\n\t\tresult = PublicKeyInfo.encode({\n\t\t\talgorithm: algorithms[crv],\n\t\t\tPublicKey: publicKey\n\t\t}, 'pem', {\n\t\t\tlabel: 'PUBLIC KEY'\n\t\t});\n\t}\n\n\t// This is in an if incase asn1.js adds a trailing \\n\n\t// istanbul ignore else\n\tif ('\\n' !== result.slice(-1)) {\n\t\tresult += '\\n';\n\t}\n\n\treturn result;\n}\n\nmodule.exports = ecJwkToBuffer;\n",
    "'use strict';\n\nvar asn1 = require('asn1.js');\n\nvar b64ToBn = require('./b64-to-bn');\n\nvar PublicKeyInfo = require('./asn1/public-key-info'),\n\tPrivateKeyInfo = require('./asn1/private-key-info'),\n\tVersion = require('./asn1/version');\n\nvar RSAPrivateKey = asn1.define('RSAPrivateKey', /* @this */ function() {\n\tthis.seq().obj(\n\t\tthis.key('version').use(Version),\n\t\tthis.key('modulus').int(),\n\t\tthis.key('publicExponent').int(),\n\t\tthis.key('privateExponent').int(),\n\t\tthis.key('prime1').int(),\n\t\tthis.key('prime2').int(),\n\t\tthis.key('exponent1').int(),\n\t\tthis.key('exponent2').int(),\n\t\tthis.key('coefficient').int()\n\t);\n});\n\nvar RSAPublicKey = asn1.define('RSAPublicKey', /* @this */ function() {\n\tthis.seq().obj(\n\t\tthis.key('modulus').int(),\n\t\tthis.key('publicExponent').int()\n\t);\n});\n\nvar algorithm = {\n\talgorithm: [1, 2, 840, 113549, 1, 1, 1],\n\tparameters: [5, 0]\n};\n\nfunction rsaJwkToBuffer(jwk, opts) {\n\tif ('string' !== typeof jwk.e) {\n\t\tthrow new TypeError('Expected \"jwk.e\" to be a String');\n\t}\n\n\tif ('string' !== typeof jwk.n) {\n\t\tthrow new TypeError('Expected \"jwk.n\" to be a String');\n\t}\n\n\tif (opts.private) {\n\t\tif ('string' !== typeof jwk.d) {\n\t\t\tthrow new TypeError('Expected \"jwk.d\" to be a String');\n\t\t}\n\n\t\tif ('string' !== typeof jwk.p) {\n\t\t\tthrow new TypeError('Expected \"jwk.p\" to be a String');\n\t\t}\n\n\t\tif ('string' !== typeof jwk.q) {\n\t\t\tthrow new TypeError('Expected \"jwk.q\" to be a String');\n\t\t}\n\n\t\tif ('string' !== typeof jwk.dp) {\n\t\t\tthrow new TypeError('Expected \"jwk.dp\" to be a String');\n\t\t}\n\n\t\tif ('string' !== typeof jwk.dq) {\n\t\t\tthrow new TypeError('Expected \"jwk.dq\" to be a String');\n\t\t}\n\n\t\tif ('string' !== typeof jwk.qi) {\n\t\t\tthrow new TypeError('Expected \"jwk.qi\" to be a String');\n\t\t}\n\t}\n\n\tvar pem;\n\tif (opts.private) {\n\t\tpem = PrivateKeyInfo.encode({\n\t\t\tversion: 0,\n\t\t\tprivateKeyAlgorithm: algorithm,\n\t\t\tprivateKey: RSAPrivateKey.encode({\n\t\t\t\tversion: 0,\n\t\t\t\tmodulus: b64ToBn(jwk.n, false),\n\t\t\t\tpublicExponent: b64ToBn(jwk.e, false),\n\t\t\t\tprivateExponent: b64ToBn(jwk.d, true),\n\t\t\t\tprime1: b64ToBn(jwk.p, true),\n\t\t\t\tprime2: b64ToBn(jwk.q, true),\n\t\t\t\texponent1: b64ToBn(jwk.dp, true),\n\t\t\t\texponent2: b64ToBn(jwk.dq, true),\n\t\t\t\tcoefficient: b64ToBn(jwk.qi, true)\n\t\t\t}, 'der')\n\t\t}, 'pem', {\n\t\t\tlabel: 'PRIVATE KEY'\n\t\t});\n\t} else {\n\t\tpem = PublicKeyInfo.encode({\n\t\t\talgorithm: algorithm,\n\t\t\tPublicKey: {\n\t\t\t\tunused: 0,\n\t\t\t\tdata: RSAPublicKey.encode({\n\t\t\t\t\tmodulus: b64ToBn(jwk.n, false),\n\t\t\t\t\tpublicExponent: b64ToBn(jwk.e, false)\n\t\t\t\t}, 'der')\n\t\t\t}\n\t\t}, 'pem', {\n\t\t\tlabel: 'PUBLIC KEY'\n\t\t});\n\t}\n\n\t// This is in an if incase asn1.js adds a trailing \\n\n\t// istanbul ignore else\n\tif ('\\n' !== pem.slice(-1)) {\n\t\tpem += '\\n';\n\t}\n\n\treturn pem;\n}\n\nmodule.exports = rsaJwkToBuffer;\n",
    "'use strict';\n\nvar ec = require('./ec'),\n\trsa = require('./rsa');\n\n/**\n *\n * @param {{kty:'EC', crv:string, d:string, x?:string, y?:string} | {kty:'EC', crv:string, x:string, y:string} | {kty:'RSA', e:string, n:string, d?:string, p?:string, q?:string, dp?:string, dq?:string, qi?:string}} jwk\n * @param {{private:boolean}=} opts\n * @returns {string}\n */\nfunction jwkToBuffer(jwk, opts) {\n\tif ('object' !== typeof jwk || null === jwk) {\n\t\tthrow new TypeError('Expected \"jwk\" to be an Object');\n\t}\n\n\tvar kty = jwk.kty;\n\tif ('string' !== typeof kty) {\n\t\tthrow new TypeError('Expected \"jwk.kty\" to be a String');\n\t}\n\n\topts = opts || {};\n\topts.private = opts.private === true;\n\n\tswitch (kty) {\n\t\tcase 'EC': {\n\t\t\treturn ec(jwk, opts);\n\t\t}\n\t\tcase 'RSA': {\n\t\t\treturn rsa(jwk, opts);\n\t\t}\n\t\tdefault: {\n\t\t\tthrow new Error('Unsupported key type \"' + kty + '\"');\n\t\t}\n\t}\n}\n\nmodule.exports = jwkToBuffer;\n",
    "//#region src/esi/options.ts\nconst CLIENT_ID = process.env.EVE_CLIENT_ID || \"\";\nconst CLIENT_SECRET = process.env.EVE_CLIENT_SECRET || \"\";\nconst CALLBACK_URL = process.env.EVE_CALLBACK_URL || \"\";\nconst USER_AGENT = process.env.ESI_USER_AGENT || \"\";\nconst options = {\n\tclient_id: CLIENT_ID,\n\tclient_secret: CLIENT_SECRET,\n\tcallback_url: CALLBACK_URL,\n\tuser_agent: USER_AGENT\n};\n\n//#endregion\nexport { options };",
    "//#region rolldown:runtime\nvar __defProp = Object.defineProperty;\nvar __export = (target, all) => {\n\tfor (var name in all) __defProp(target, name, {\n\t\tget: all[name],\n\t\tenumerable: true\n\t});\n};\n\n//#endregion\nexport { __export };",
    "export class InvalidTokenError extends Error {\n}\nInvalidTokenError.prototype.name = \"InvalidTokenError\";\nfunction b64DecodeUnicode(str) {\n    return decodeURIComponent(atob(str).replace(/(.)/g, (m, p) => {\n        let code = p.charCodeAt(0).toString(16).toUpperCase();\n        if (code.length < 2) {\n            code = \"0\" + code;\n        }\n        return \"%\" + code;\n    }));\n}\nfunction base64UrlDecode(str) {\n    let output = str.replace(/-/g, \"+\").replace(/_/g, \"/\");\n    switch (output.length % 4) {\n        case 0:\n            break;\n        case 2:\n            output += \"==\";\n            break;\n        case 3:\n            output += \"=\";\n            break;\n        default:\n            throw new Error(\"base64 string is not of the correct length\");\n    }\n    try {\n        return b64DecodeUnicode(output);\n    }\n    catch (err) {\n        return atob(output);\n    }\n}\nexport function jwtDecode(token, options) {\n    if (typeof token !== \"string\") {\n        throw new InvalidTokenError(\"Invalid token specified: must be a string\");\n    }\n    options || (options = {});\n    const pos = options.header === true ? 0 : 1;\n    const part = token.split(\".\")[pos];\n    if (typeof part !== \"string\") {\n        throw new InvalidTokenError(`Invalid token specified: missing part #${pos + 1}`);\n    }\n    let decoded;\n    try {\n        decoded = base64UrlDecode(part);\n    }\n    catch (e) {\n        throw new InvalidTokenError(`Invalid token specified: invalid base64 for part #${pos + 1} (${e.message})`);\n    }\n    try {\n        return JSON.parse(decoded);\n    }\n    catch (e) {\n        throw new InvalidTokenError(`Invalid token specified: invalid json for part #${pos + 1} (${e.message})`);\n    }\n}\n",
    "export function encodeBase32UpperCase(bytes) {\n    return encodeBase32_internal(bytes, base32UpperCaseAlphabet, EncodingPadding.Include);\n}\nexport function encodeBase32UpperCaseNoPadding(bytes) {\n    return encodeBase32_internal(bytes, base32UpperCaseAlphabet, EncodingPadding.None);\n}\nexport function encodeBase32LowerCase(bytes) {\n    return encodeBase32_internal(bytes, base32LowerCaseAlphabet, EncodingPadding.Include);\n}\nexport function encodeBase32LowerCaseNoPadding(bytes) {\n    return encodeBase32_internal(bytes, base32LowerCaseAlphabet, EncodingPadding.None);\n}\n/** Replaced: Use encodeBase32UpperCase() instead. */\nexport function encodeBase32(bytes) {\n    return encodeBase32UpperCase(bytes);\n}\n/** Replaced: Use encodeBase32UpperCaseNoPadding() instead. */\nexport function encodeBase32NoPadding(bytes) {\n    return encodeBase32UpperCaseNoPadding(bytes);\n}\nfunction encodeBase32_internal(bytes, alphabet, padding) {\n    let result = \"\";\n    for (let i = 0; i < bytes.byteLength; i += 5) {\n        let buffer = 0n;\n        let bufferBitSize = 0;\n        for (let j = 0; j < 5 && i + j < bytes.byteLength; j++) {\n            buffer = (buffer << 8n) | BigInt(bytes[i + j]);\n            bufferBitSize += 8;\n        }\n        if (bufferBitSize % 5 !== 0) {\n            buffer = buffer << BigInt(5 - (bufferBitSize % 5));\n            bufferBitSize += 5 - (bufferBitSize % 5);\n        }\n        for (let j = 0; j < 8; j++) {\n            if (bufferBitSize >= 5) {\n                result += alphabet[Number((buffer >> BigInt(bufferBitSize - 5)) & 0x1fn)];\n                bufferBitSize -= 5;\n            }\n            else if (bufferBitSize > 0) {\n                result += alphabet[Number((buffer << BigInt(6 - bufferBitSize)) & 0x3fn)];\n                bufferBitSize = 0;\n            }\n            else if (padding === EncodingPadding.Include) {\n                result += \"=\";\n            }\n        }\n    }\n    return result;\n}\nexport function decodeBase32(encoded) {\n    return decodeBase32_internal(encoded, base32DecodeMap, DecodingPadding.Required);\n}\nexport function decodeBase32IgnorePadding(encoded) {\n    return decodeBase32_internal(encoded, base32DecodeMap, DecodingPadding.Ignore);\n}\nfunction decodeBase32_internal(encoded, decodeMap, padding) {\n    const result = new Uint8Array(Math.ceil(encoded.length / 8) * 5);\n    let totalBytes = 0;\n    for (let i = 0; i < encoded.length; i += 8) {\n        let chunk = 0n;\n        let bitsRead = 0;\n        for (let j = 0; j < 8; j++) {\n            if (padding === DecodingPadding.Required) {\n                if (encoded[i + j] === \"=\") {\n                    continue;\n                }\n                if (i + j >= encoded.length) {\n                    throw new Error(\"Invalid padding\");\n                }\n            }\n            if (padding === DecodingPadding.Ignore) {\n                if (i + j >= encoded.length || encoded[i + j] === \"=\") {\n                    continue;\n                }\n            }\n            if (j > 0 && encoded[i + j - 1] === \"=\") {\n                throw new Error(\"Invalid padding\");\n            }\n            if (!(encoded[i + j] in decodeMap)) {\n                throw new Error(\"Invalid character\");\n            }\n            chunk |= BigInt(decodeMap[encoded[i + j]]) << BigInt((7 - j) * 5);\n            bitsRead += 5;\n        }\n        if (bitsRead < 40) {\n            let unused;\n            if (bitsRead === 10) {\n                unused = chunk & 0xffffffffn;\n            }\n            else if (bitsRead === 20) {\n                unused = chunk & 0xffffffn;\n            }\n            else if (bitsRead === 25) {\n                unused = chunk & 0xffffn;\n            }\n            else if (bitsRead === 35) {\n                unused = chunk & 0xffn;\n            }\n            else {\n                throw new Error(\"Invalid padding\");\n            }\n            if (unused !== 0n) {\n                throw new Error(\"Invalid padding\");\n            }\n        }\n        const byteLength = Math.floor(bitsRead / 8);\n        for (let i = 0; i < byteLength; i++) {\n            result[totalBytes] = Number((chunk >> BigInt(32 - i * 8)) & 0xffn);\n            totalBytes++;\n        }\n    }\n    return result.slice(0, totalBytes);\n}\nconst base32UpperCaseAlphabet = \"ABCDEFGHIJKLMNOPQRSTUVWXYZ234567\";\nconst base32LowerCaseAlphabet = \"abcdefghijklmnopqrstuvwxyz234567\";\nconst base32DecodeMap = {\n    A: 0,\n    B: 1,\n    C: 2,\n    D: 3,\n    E: 4,\n    F: 5,\n    G: 6,\n    H: 7,\n    I: 8,\n    J: 9,\n    K: 10,\n    L: 11,\n    M: 12,\n    N: 13,\n    O: 14,\n    P: 15,\n    Q: 16,\n    R: 17,\n    S: 18,\n    T: 19,\n    U: 20,\n    V: 21,\n    W: 22,\n    X: 23,\n    Y: 24,\n    Z: 25,\n    a: 0,\n    b: 1,\n    c: 2,\n    d: 3,\n    e: 4,\n    f: 5,\n    g: 6,\n    h: 7,\n    i: 8,\n    j: 9,\n    k: 10,\n    l: 11,\n    m: 12,\n    n: 13,\n    o: 14,\n    p: 15,\n    q: 16,\n    r: 17,\n    s: 18,\n    t: 19,\n    u: 20,\n    v: 21,\n    w: 22,\n    x: 23,\n    y: 24,\n    z: 25,\n    \"2\": 26,\n    \"3\": 27,\n    \"4\": 28,\n    \"5\": 29,\n    \"6\": 30,\n    \"7\": 31\n};\nvar EncodingPadding;\n(function (EncodingPadding) {\n    EncodingPadding[EncodingPadding[\"Include\"] = 0] = \"Include\";\n    EncodingPadding[EncodingPadding[\"None\"] = 1] = \"None\";\n})(EncodingPadding || (EncodingPadding = {}));\nvar DecodingPadding;\n(function (DecodingPadding) {\n    DecodingPadding[DecodingPadding[\"Required\"] = 0] = \"Required\";\n    DecodingPadding[DecodingPadding[\"Ignore\"] = 1] = \"Ignore\";\n})(DecodingPadding || (DecodingPadding = {}));\n",
    "export function encodeBase64(bytes) {\n    return encodeBase64_internal(bytes, base64Alphabet, EncodingPadding.Include);\n}\nexport function encodeBase64NoPadding(bytes) {\n    return encodeBase64_internal(bytes, base64Alphabet, EncodingPadding.None);\n}\nexport function encodeBase64url(bytes) {\n    return encodeBase64_internal(bytes, base64urlAlphabet, EncodingPadding.Include);\n}\nexport function encodeBase64urlNoPadding(bytes) {\n    return encodeBase64_internal(bytes, base64urlAlphabet, EncodingPadding.None);\n}\nfunction encodeBase64_internal(bytes, alphabet, padding) {\n    let result = \"\";\n    for (let i = 0; i < bytes.byteLength; i += 3) {\n        let buffer = 0;\n        let bufferBitSize = 0;\n        for (let j = 0; j < 3 && i + j < bytes.byteLength; j++) {\n            buffer = (buffer << 8) | bytes[i + j];\n            bufferBitSize += 8;\n        }\n        for (let j = 0; j < 4; j++) {\n            if (bufferBitSize >= 6) {\n                result += alphabet[(buffer >> (bufferBitSize - 6)) & 0x3f];\n                bufferBitSize -= 6;\n            }\n            else if (bufferBitSize > 0) {\n                result += alphabet[(buffer << (6 - bufferBitSize)) & 0x3f];\n                bufferBitSize = 0;\n            }\n            else if (padding === EncodingPadding.Include) {\n                result += \"=\";\n            }\n        }\n    }\n    return result;\n}\nconst base64Alphabet = \"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/\";\nconst base64urlAlphabet = \"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789-_\";\nexport function decodeBase64(encoded) {\n    return decodeBase64_internal(encoded, base64DecodeMap, DecodingPadding.Required);\n}\nexport function decodeBase64IgnorePadding(encoded) {\n    return decodeBase64_internal(encoded, base64DecodeMap, DecodingPadding.Ignore);\n}\nexport function decodeBase64url(encoded) {\n    return decodeBase64_internal(encoded, base64urlDecodeMap, DecodingPadding.Required);\n}\nexport function decodeBase64urlIgnorePadding(encoded) {\n    return decodeBase64_internal(encoded, base64urlDecodeMap, DecodingPadding.Ignore);\n}\nfunction decodeBase64_internal(encoded, decodeMap, padding) {\n    const result = new Uint8Array(Math.ceil(encoded.length / 4) * 3);\n    let totalBytes = 0;\n    for (let i = 0; i < encoded.length; i += 4) {\n        let chunk = 0;\n        let bitsRead = 0;\n        for (let j = 0; j < 4; j++) {\n            if (padding === DecodingPadding.Required && encoded[i + j] === \"=\") {\n                continue;\n            }\n            if (padding === DecodingPadding.Ignore &&\n                (i + j >= encoded.length || encoded[i + j] === \"=\")) {\n                continue;\n            }\n            if (j > 0 && encoded[i + j - 1] === \"=\") {\n                throw new Error(\"Invalid padding\");\n            }\n            if (!(encoded[i + j] in decodeMap)) {\n                throw new Error(\"Invalid character\");\n            }\n            chunk |= decodeMap[encoded[i + j]] << ((3 - j) * 6);\n            bitsRead += 6;\n        }\n        if (bitsRead < 24) {\n            let unused;\n            if (bitsRead === 12) {\n                unused = chunk & 0xffff;\n            }\n            else if (bitsRead === 18) {\n                unused = chunk & 0xff;\n            }\n            else {\n                throw new Error(\"Invalid padding\");\n            }\n            if (unused !== 0) {\n                throw new Error(\"Invalid padding\");\n            }\n        }\n        const byteLength = Math.floor(bitsRead / 8);\n        for (let i = 0; i < byteLength; i++) {\n            result[totalBytes] = (chunk >> (16 - i * 8)) & 0xff;\n            totalBytes++;\n        }\n    }\n    return result.slice(0, totalBytes);\n}\nvar EncodingPadding;\n(function (EncodingPadding) {\n    EncodingPadding[EncodingPadding[\"Include\"] = 0] = \"Include\";\n    EncodingPadding[EncodingPadding[\"None\"] = 1] = \"None\";\n})(EncodingPadding || (EncodingPadding = {}));\nvar DecodingPadding;\n(function (DecodingPadding) {\n    DecodingPadding[DecodingPadding[\"Required\"] = 0] = \"Required\";\n    DecodingPadding[DecodingPadding[\"Ignore\"] = 1] = \"Ignore\";\n})(DecodingPadding || (DecodingPadding = {}));\nconst base64DecodeMap = {\n    \"0\": 52,\n    \"1\": 53,\n    \"2\": 54,\n    \"3\": 55,\n    \"4\": 56,\n    \"5\": 57,\n    \"6\": 58,\n    \"7\": 59,\n    \"8\": 60,\n    \"9\": 61,\n    A: 0,\n    B: 1,\n    C: 2,\n    D: 3,\n    E: 4,\n    F: 5,\n    G: 6,\n    H: 7,\n    I: 8,\n    J: 9,\n    K: 10,\n    L: 11,\n    M: 12,\n    N: 13,\n    O: 14,\n    P: 15,\n    Q: 16,\n    R: 17,\n    S: 18,\n    T: 19,\n    U: 20,\n    V: 21,\n    W: 22,\n    X: 23,\n    Y: 24,\n    Z: 25,\n    a: 26,\n    b: 27,\n    c: 28,\n    d: 29,\n    e: 30,\n    f: 31,\n    g: 32,\n    h: 33,\n    i: 34,\n    j: 35,\n    k: 36,\n    l: 37,\n    m: 38,\n    n: 39,\n    o: 40,\n    p: 41,\n    q: 42,\n    r: 43,\n    s: 44,\n    t: 45,\n    u: 46,\n    v: 47,\n    w: 48,\n    x: 49,\n    y: 50,\n    z: 51,\n    \"+\": 62,\n    \"/\": 63\n};\nconst base64urlDecodeMap = {\n    \"0\": 52,\n    \"1\": 53,\n    \"2\": 54,\n    \"3\": 55,\n    \"4\": 56,\n    \"5\": 57,\n    \"6\": 58,\n    \"7\": 59,\n    \"8\": 60,\n    \"9\": 61,\n    A: 0,\n    B: 1,\n    C: 2,\n    D: 3,\n    E: 4,\n    F: 5,\n    G: 6,\n    H: 7,\n    I: 8,\n    J: 9,\n    K: 10,\n    L: 11,\n    M: 12,\n    N: 13,\n    O: 14,\n    P: 15,\n    Q: 16,\n    R: 17,\n    S: 18,\n    T: 19,\n    U: 20,\n    V: 21,\n    W: 22,\n    X: 23,\n    Y: 24,\n    Z: 25,\n    a: 26,\n    b: 27,\n    c: 28,\n    d: 29,\n    e: 30,\n    f: 31,\n    g: 32,\n    h: 33,\n    i: 34,\n    j: 35,\n    k: 36,\n    l: 37,\n    m: 38,\n    n: 39,\n    o: 40,\n    p: 41,\n    q: 42,\n    r: 43,\n    s: 44,\n    t: 45,\n    u: 46,\n    v: 47,\n    w: 48,\n    x: 49,\n    y: 50,\n    z: 51,\n    \"-\": 62,\n    _: 63\n};\n",
    "import { __export } from \"../_virtual/rolldown_runtime.js\";\nimport { options } from \"./options.js\";\nimport { jwtDecode } from \"jwt-decode\";\nimport { encodeBase64urlNoPadding } from \"@oslojs/encoding\";\nimport jwt from \"jsonwebtoken\";\nimport jwkToPem from \"jwk-to-pem\";\n\n//#region src/esi/auth.ts\nvar auth_exports = {};\n__export(auth_exports, {\n\tcharacterIdFromToken: () => characterIdFromToken,\n\tcreateAuthorizationURL: () => createAuthorizationURL,\n\trefresh: () => refresh,\n\tvalidateAuthorizationCode: () => validateAuthorizationCode,\n\tvalidateToken: () => validateToken\n});\nfunction generateState() {\n\tconst randomValues = new Uint8Array(32);\n\tcrypto.getRandomValues(randomValues);\n\treturn encodeBase64urlNoPadding(randomValues);\n}\nasync function createAuthorizationURL(scopes = \"publicData\") {\n\tconst state = generateState();\n\tconst url = new URL(\"https://login.eveonline.com/v2/oauth/authorize/\");\n\turl.searchParams.set(\"response_type\", \"code\");\n\turl.searchParams.set(\"redirect_uri\", options.callback_url);\n\turl.searchParams.set(\"client_id\", options.client_id);\n\turl.searchParams.set(\"state\", state);\n\turl.searchParams.set(\"scope\", Array.isArray(scopes) ? scopes.join(\" \") : scopes);\n\treturn {\n\t\turl,\n\t\tstate\n\t};\n}\nasync function validateAuthorizationCode(code) {\n\ttry {\n\t\tconst response = await fetch(\"https://login.eveonline.com/v2/oauth/token\", {\n\t\t\tmethod: \"POST\",\n\t\t\theaders: {\n\t\t\t\t\"Content-Type\": \"application/x-www-form-urlencoded\",\n\t\t\t\tAuthorization: `Basic ${Buffer.from(`${options.client_id}:${options.client_secret}`).toString(\"base64\")}`\n\t\t\t},\n\t\t\tbody: new URLSearchParams({\n\t\t\t\tgrant_type: \"authorization_code\",\n\t\t\t\tcode\n\t\t\t})\n\t\t});\n\t\treturn await response.json();\n\t} catch (error) {\n\t\tconsole.error(`failed to validate EVE authorization code`, error);\n\t\tthrow `${error}`;\n\t}\n}\nlet eveAuthPublicKey;\nasync function validateToken(token) {\n\tif (!eveAuthPublicKey) try {\n\t\tconst eveJWKS = await (await fetch(\"https://login.eveonline.com/oauth/jwks\")).json();\n\t\teveAuthPublicKey = jwkToPem(eveJWKS.keys[0]);\n\t} catch (err) {\n\t\tconsole.error(`failed to get EVE Auth public keys`, err);\n\t}\n\ttry {\n\t\tconst decoded = jwt.verify(token, eveAuthPublicKey);\n\t\treturn decoded;\n\t} catch (err) {\n\t\tconsole.error(`failed to validate EVE token`, err);\n\t\treturn null;\n\t}\n}\nasync function refresh({ refresh_token }, scopes) {\n\tconst params = {\n\t\tgrant_type: \"refresh_token\",\n\t\trefresh_token,\n\t\tscope: \"\"\n\t};\n\tif (scopes) params[\"scope\"] = Array.isArray(scopes) ? scopes.join(\" \") : scopes;\n\tconst response = await fetch(\"https://login.eveonline.com/v2/oauth/token\", {\n\t\tmethod: \"POST\",\n\t\theaders: {\n\t\t\t\"Content-Type\": \"application/x-www-form-urlencoded\",\n\t\t\tAuthorization: `Basic ${Buffer.from(`${options.client_id}:${options.client_secret}`).toString(\"base64\")}`\n\t\t},\n\t\tbody: new URLSearchParams(params)\n\t});\n\treturn await response.json();\n}\nfunction characterIdFromToken(token) {\n\tconst payload = jwtDecode(token);\n\treturn parseInt(payload.sub.split(\":\")[2]);\n}\n\n//#endregion\nexport { auth_exports, characterIdFromToken, createAuthorizationURL, refresh, validateAuthorizationCode, validateToken };",
    "import { jwtDecode } from \"jwt-decode\";\n\n//#region src/esi/scopes.ts\nconst EVE_JWKS_URL = \"https://login.eveonline.com/oauth/jwks\";\nconst EVE_ISSUER = \"login.eveonline.com\";\nconst EVE_AUDIENCE = \"eveonline\";\nconst ESI_LATEST_URL = \"https://esi.evetech.net/latest\";\nconst DATA_SOURCE = \"tranquility\";\nfunction joinScopes(...scopes) {\n\treturn scopes.join(\" \");\n}\nlet SCOPES = /* @__PURE__ */ function(SCOPES$1) {\n\tSCOPES$1[\"PUBLIC_DATA\"] = \"publicData\";\n\tSCOPES$1[\"CALENDAR_RESPOND_CALENDAR_EVENTS\"] = \"esi-calendar.respond_calendar_events.v1\";\n\tSCOPES$1[\"CALENDAR_READ_CALENDAR_EVENTS\"] = \"esi-calendar.read_calendar_events.v1\";\n\tSCOPES$1[\"LOCATION_READ_LOCATION\"] = \"esi-location.read_location.v1\";\n\tSCOPES$1[\"LOCATION_READ_SHIP_TYPE\"] = \"esi-location.read_ship_type.v1\";\n\tSCOPES$1[\"MAIL_ORGANIZE_MAIL\"] = \"esi-mail.organize_mail.v1\";\n\tSCOPES$1[\"MAIL_READ_MAIL\"] = \"esi-mail.read_mail.v1\";\n\tSCOPES$1[\"MAIL_SEND_MAIL\"] = \"esi-mail.send_mail.v1\";\n\tSCOPES$1[\"SKILLS_READ_SKILLS\"] = \"esi-skills.read_skills.v1\";\n\tSCOPES$1[\"SKILLS_READ_SKILLQUEUE\"] = \"esi-skills.read_skillqueue.v1\";\n\tSCOPES$1[\"WALLET_READ_CHARACTER_WALLET\"] = \"esi-wallet.read_character_wallet.v1\";\n\tSCOPES$1[\"WALLET_READ_CORPORATION_WALLET\"] = \"esi-wallet.read_corporation_wallet.v1\";\n\tSCOPES$1[\"SEARCH_SEARCH_STRUCTURES\"] = \"esi-search.search_structures.v1\";\n\tSCOPES$1[\"CLONES_READ_CLONES\"] = \"esi-clones.read_clones.v1\";\n\tSCOPES$1[\"CHARACTERS_READ_CONTACTS\"] = \"esi-characters.read_contacts.v1\";\n\tSCOPES$1[\"UNIVERSE_READ_STRUCTURES\"] = \"esi-universe.read_structures.v1\";\n\tSCOPES$1[\"KILLMAILS_READ_KILLMAILS\"] = \"esi-killmails.read_killmails.v1\";\n\tSCOPES$1[\"CORPORATIONS_READ_CORPORATION_MEMBERSHIP\"] = \"esi-corporations.read_corporation_membership.v1\";\n\tSCOPES$1[\"ASSETS_READ_ASSETS\"] = \"esi-assets.read_assets.v1\";\n\tSCOPES$1[\"PLANETS_MANAGE_PLANETS\"] = \"esi-planets.manage_planets.v1\";\n\tSCOPES$1[\"FLEETS_READ_FLEET\"] = \"esi-fleets.read_fleet.v1\";\n\tSCOPES$1[\"FLEETS_WRITE_FLEET\"] = \"esi-fleets.write_fleet.v1\";\n\tSCOPES$1[\"UI_OPEN_WINDOW\"] = \"esi-ui.open_window.v1\";\n\tSCOPES$1[\"UI_WRITE_WAYPOINT\"] = \"esi-ui.write_waypoint.v1\";\n\tSCOPES$1[\"CHARACTERS_WRITE_CONTACTS\"] = \"esi-characters.write_contacts.v1\";\n\tSCOPES$1[\"FITTINGS_READ_FITTINGS\"] = \"esi-fittings.read_fittings.v1\";\n\tSCOPES$1[\"FITTINGS_WRITE_FITTINGS\"] = \"esi-fittings.write_fittings.v1\";\n\tSCOPES$1[\"MARKETS_STRUCTURE_MARKETS\"] = \"esi-markets.structure_markets.v1\";\n\tSCOPES$1[\"CORPORATIONS_READ_STRUCTURES\"] = \"esi-corporations.read_structures.v1\";\n\tSCOPES$1[\"CHARACTERS_READ_LOYALTY\"] = \"esi-characters.read_loyalty.v1\";\n\tSCOPES$1[\"CHARACTERS_READ_OPPORTUNITIES\"] = \"esi-characters.read_opportunities.v1\";\n\tSCOPES$1[\"CHARACTERS_READ_CHAT_CHANNELS\"] = \"esi-characters.read_chat_channels.v1\";\n\tSCOPES$1[\"CHARACTERS_READ_MEDALS\"] = \"esi-characters.read_medals.v1\";\n\tSCOPES$1[\"CHARACTERS_READ_STANDINGS\"] = \"esi-characters.read_standings.v1\";\n\tSCOPES$1[\"CHARACTERS_READ_AGENTS_RESEARCH\"] = \"esi-characters.read_agents_research.v1\";\n\tSCOPES$1[\"INDUSTRY_READ_CHARACTER_JOBS\"] = \"esi-industry.read_character_jobs.v1\";\n\tSCOPES$1[\"MARKETS_READ_CHARACTER_ORDERS\"] = \"esi-markets.read_character_orders.v1\";\n\tSCOPES$1[\"CHARACTERS_READ_BLUEPRINTS\"] = \"esi-characters.read_blueprints.v1\";\n\tSCOPES$1[\"CHARACTERS_READ_CORPORATION_ROLES\"] = \"esi-characters.read_corporation_roles.v1\";\n\tSCOPES$1[\"LOCATION_READ_ONLINE\"] = \"esi-location.read_online.v1\";\n\tSCOPES$1[\"CONTRACTS_READ_CHARACTER_CONTRACTS\"] = \"esi-contracts.read_character_contracts.v1\";\n\tSCOPES$1[\"CLONES_READ_IMPLANTS\"] = \"esi-clones.read_implants.v1\";\n\tSCOPES$1[\"CHARACTERS_READ_FATIGUE\"] = \"esi-characters.read_fatigue.v1\";\n\tSCOPES$1[\"KILLMAILS_READ_CORPORATION_KILLMAILS\"] = \"esi-killmails.read_corporation_killmails.v1\";\n\tSCOPES$1[\"CORPORATIONS_TRACK_MEMBERS\"] = \"esi-corporations.track_members.v1\";\n\tSCOPES$1[\"WALLET_READ_CORPORATION_WALLETS\"] = \"esi-wallet.read_corporation_wallets.v1\";\n\tSCOPES$1[\"CHARACTERS_READ_NOTIFICATIONS\"] = \"esi-characters.read_notifications.v1\";\n\tSCOPES$1[\"CORPORATIONS_READ_DIVISIONS\"] = \"esi-corporations.read_divisions.v1\";\n\tSCOPES$1[\"CORPORATIONS_READ_CONTACTS\"] = \"esi-corporations.read_contacts.v1\";\n\tSCOPES$1[\"ASSETS_READ_CORPORATION_ASSETS\"] = \"esi-assets.read_corporation_assets.v1\";\n\tSCOPES$1[\"CORPORATIONS_READ_TITLES\"] = \"esi-corporations.read_titles.v1\";\n\tSCOPES$1[\"CORPORATIONS_READ_BLUEPRINTS\"] = \"esi-corporations.read_blueprints.v1\";\n\tSCOPES$1[\"CONTRACTS_READ_CORPORATION_CONTRACTS\"] = \"esi-contracts.read_corporation_contracts.v1\";\n\tSCOPES$1[\"CORPORATIONS_READ_STANDINGS\"] = \"esi-corporations.read_standings.v1\";\n\tSCOPES$1[\"CORPORATIONS_READ_STARBASES\"] = \"esi-corporations.read_starbases.v1\";\n\tSCOPES$1[\"INDUSTRY_READ_CORPORATION_JOBS\"] = \"esi-industry.read_corporation_jobs.v1\";\n\tSCOPES$1[\"MARKETS_READ_CORPORATION_ORDERS\"] = \"esi-markets.read_corporation_orders.v1\";\n\tSCOPES$1[\"CORPORATIONS_READ_CONTAINER_LOGS\"] = \"esi-corporations.read_container_logs.v1\";\n\tSCOPES$1[\"INDUSTRY_READ_CHARACTER_MINING\"] = \"esi-industry.read_character_mining.v1\";\n\tSCOPES$1[\"INDUSTRY_READ_CORPORATION_MINING\"] = \"esi-industry.read_corporation_mining.v1\";\n\tSCOPES$1[\"PLANETS_READ_CUSTOMS_OFFICES\"] = \"esi-planets.read_customs_offices.v1\";\n\tSCOPES$1[\"CORPORATIONS_READ_FACILITIES\"] = \"esi-corporations.read_facilities.v1\";\n\tSCOPES$1[\"CORPORATIONS_READ_MEDALS\"] = \"esi-corporations.read_medals.v1\";\n\tSCOPES$1[\"CHARACTERS_READ_TITLES\"] = \"esi-characters.read_titles.v1\";\n\tSCOPES$1[\"ALLIANCES_READ_CONTACTS\"] = \"esi-alliances.read_contacts.v1\";\n\tSCOPES$1[\"CHARACTERS_READ_FW_STATS\"] = \"esi-characters.read_fw_stats.v1\";\n\tSCOPES$1[\"CORPORATIONS_READ_FW_STATS\"] = \"esi-corporations.read_fw_stats.v1\";\n\treturn SCOPES$1;\n}({});\nfunction tokenHasScopes(access_token, ...scopes) {\n\tlet tokenScopes = getScopesFromToken(access_token);\n\treturn scopes.every((scope) => tokenScopes.includes(scope));\n}\nfunction getScopesFromToken(access_token) {\n\tconst decoded = jwtDecode(access_token);\n\treturn typeof decoded.scp === \"string\" ? [decoded.scp] : decoded.scp;\n}\n\n//#endregion\nexport { DATA_SOURCE, ESI_LATEST_URL, EVE_AUDIENCE, EVE_ISSUER, EVE_JWKS_URL, SCOPES, getScopesFromToken, joinScopes, tokenHasScopes };",
    "const entityKind = Symbol.for(\"drizzle:entityKind\");\nconst hasOwnEntityKind = Symbol.for(\"drizzle:hasOwnEntityKind\");\nfunction is(value, type) {\n  if (!value || typeof value !== \"object\") {\n    return false;\n  }\n  if (value instanceof type) {\n    return true;\n  }\n  if (!Object.prototype.hasOwnProperty.call(type, entityKind)) {\n    throw new Error(\n      `Class \"${type.name ?? \"<unknown>\"}\" doesn't look like a Drizzle entity. If this is incorrect and the class is provided by Drizzle, please report this as a bug.`\n    );\n  }\n  let cls = Object.getPrototypeOf(value).constructor;\n  if (cls) {\n    while (cls) {\n      if (entityKind in cls && cls[entityKind] === type[entityKind]) {\n        return true;\n      }\n      cls = Object.getPrototypeOf(cls);\n    }\n  }\n  return false;\n}\nexport {\n  entityKind,\n  hasOwnEntityKind,\n  is\n};\n//# sourceMappingURL=entity.js.map",
    "import { entityKind } from \"./entity.js\";\nclass Column {\n  constructor(table, config) {\n    this.table = table;\n    this.config = config;\n    this.name = config.name;\n    this.keyAsName = config.keyAsName;\n    this.notNull = config.notNull;\n    this.default = config.default;\n    this.defaultFn = config.defaultFn;\n    this.onUpdateFn = config.onUpdateFn;\n    this.hasDefault = config.hasDefault;\n    this.primary = config.primaryKey;\n    this.isUnique = config.isUnique;\n    this.uniqueName = config.uniqueName;\n    this.uniqueType = config.uniqueType;\n    this.dataType = config.dataType;\n    this.columnType = config.columnType;\n    this.generated = config.generated;\n    this.generatedIdentity = config.generatedIdentity;\n  }\n  static [entityKind] = \"Column\";\n  name;\n  keyAsName;\n  primary;\n  notNull;\n  default;\n  defaultFn;\n  onUpdateFn;\n  hasDefault;\n  isUnique;\n  uniqueName;\n  uniqueType;\n  dataType;\n  columnType;\n  enumValues = void 0;\n  generated = void 0;\n  generatedIdentity = void 0;\n  config;\n  mapFromDriverValue(value) {\n    return value;\n  }\n  mapToDriverValue(value) {\n    return value;\n  }\n  // ** @internal */\n  shouldDisableInsert() {\n    return this.config.generated !== void 0 && this.config.generated.type !== \"byDefault\";\n  }\n}\nexport {\n  Column\n};\n//# sourceMappingURL=column.js.map",
    "import { entityKind } from \"./entity.js\";\nclass ColumnBuilder {\n  static [entityKind] = \"ColumnBuilder\";\n  config;\n  constructor(name, dataType, columnType) {\n    this.config = {\n      name,\n      keyAsName: name === \"\",\n      notNull: false,\n      default: void 0,\n      hasDefault: false,\n      primaryKey: false,\n      isUnique: false,\n      uniqueName: void 0,\n      uniqueType: void 0,\n      dataType,\n      columnType,\n      generated: void 0\n    };\n  }\n  /**\n   * Changes the data type of the column. Commonly used with `json` columns. Also, useful for branded types.\n   *\n   * @example\n   * ```ts\n   * const users = pgTable('users', {\n   * \tid: integer('id').$type<UserId>().primaryKey(),\n   * \tdetails: json('details').$type<UserDetails>().notNull(),\n   * });\n   * ```\n   */\n  $type() {\n    return this;\n  }\n  /**\n   * Adds a `not null` clause to the column definition.\n   *\n   * Affects the `select` model of the table - columns *without* `not null` will be nullable on select.\n   */\n  notNull() {\n    this.config.notNull = true;\n    return this;\n  }\n  /**\n   * Adds a `default <value>` clause to the column definition.\n   *\n   * Affects the `insert` model of the table - columns *with* `default` are optional on insert.\n   *\n   * If you need to set a dynamic default value, use {@link $defaultFn} instead.\n   */\n  default(value) {\n    this.config.default = value;\n    this.config.hasDefault = true;\n    return this;\n  }\n  /**\n   * Adds a dynamic default value to the column.\n   * The function will be called when the row is inserted, and the returned value will be used as the column value.\n   *\n   * **Note:** This value does not affect the `drizzle-kit` behavior, it is only used at runtime in `drizzle-orm`.\n   */\n  $defaultFn(fn) {\n    this.config.defaultFn = fn;\n    this.config.hasDefault = true;\n    return this;\n  }\n  /**\n   * Alias for {@link $defaultFn}.\n   */\n  $default = this.$defaultFn;\n  /**\n   * Adds a dynamic update value to the column.\n   * The function will be called when the row is updated, and the returned value will be used as the column value if none is provided.\n   * If no `default` (or `$defaultFn`) value is provided, the function will be called when the row is inserted as well, and the returned value will be used as the column value.\n   *\n   * **Note:** This value does not affect the `drizzle-kit` behavior, it is only used at runtime in `drizzle-orm`.\n   */\n  $onUpdateFn(fn) {\n    this.config.onUpdateFn = fn;\n    this.config.hasDefault = true;\n    return this;\n  }\n  /**\n   * Alias for {@link $onUpdateFn}.\n   */\n  $onUpdate = this.$onUpdateFn;\n  /**\n   * Adds a `primary key` clause to the column definition. This implicitly makes the column `not null`.\n   *\n   * In SQLite, `integer primary key` implicitly makes the column auto-incrementing.\n   */\n  primaryKey() {\n    this.config.primaryKey = true;\n    this.config.notNull = true;\n    return this;\n  }\n  /** @internal Sets the name of the column to the key within the table definition if a name was not given. */\n  setName(name) {\n    if (this.config.name !== \"\") return;\n    this.config.name = name;\n  }\n}\nexport {\n  ColumnBuilder\n};\n//# sourceMappingURL=column-builder.js.map",
    "const TableName = Symbol.for(\"drizzle:Name\");\nexport {\n  TableName\n};\n//# sourceMappingURL=table.utils.js.map",
    "function iife(fn, ...args) {\n  return fn(...args);\n}\nexport {\n  iife\n};\n//# sourceMappingURL=tracing-utils.js.map",
    "import { entityKind } from \"../entity.js\";\nimport { TableName } from \"../table.utils.js\";\nfunction unique(name) {\n  return new UniqueOnConstraintBuilder(name);\n}\nfunction uniqueKeyName(table, columns) {\n  return `${table[TableName]}_${columns.join(\"_\")}_unique`;\n}\nclass UniqueConstraintBuilder {\n  constructor(columns, name) {\n    this.name = name;\n    this.columns = columns;\n  }\n  static [entityKind] = \"PgUniqueConstraintBuilder\";\n  /** @internal */\n  columns;\n  /** @internal */\n  nullsNotDistinctConfig = false;\n  nullsNotDistinct() {\n    this.nullsNotDistinctConfig = true;\n    return this;\n  }\n  /** @internal */\n  build(table) {\n    return new UniqueConstraint(table, this.columns, this.nullsNotDistinctConfig, this.name);\n  }\n}\nclass UniqueOnConstraintBuilder {\n  static [entityKind] = \"PgUniqueOnConstraintBuilder\";\n  /** @internal */\n  name;\n  constructor(name) {\n    this.name = name;\n  }\n  on(...columns) {\n    return new UniqueConstraintBuilder(columns, this.name);\n  }\n}\nclass UniqueConstraint {\n  constructor(table, columns, nullsNotDistinct, name) {\n    this.table = table;\n    this.columns = columns;\n    this.name = name ?? uniqueKeyName(this.table, this.columns.map((column) => column.name));\n    this.nullsNotDistinct = nullsNotDistinct;\n  }\n  static [entityKind] = \"PgUniqueConstraint\";\n  columns;\n  name;\n  nullsNotDistinct = false;\n  getName() {\n    return this.name;\n  }\n}\nexport {\n  UniqueConstraint,\n  UniqueConstraintBuilder,\n  UniqueOnConstraintBuilder,\n  unique,\n  uniqueKeyName\n};\n//# sourceMappingURL=unique-constraint.js.map",
    "import { ColumnBuilder } from \"../../column-builder.js\";\nimport { Column } from \"../../column.js\";\nimport { entityKind, is } from \"../../entity.js\";\nimport { ForeignKeyBuilder } from \"../foreign-keys.js\";\nimport { iife } from \"../../tracing-utils.js\";\nimport { uniqueKeyName } from \"../unique-constraint.js\";\nimport { makePgArray, parsePgArray } from \"../utils/array.js\";\nclass PgColumnBuilder extends ColumnBuilder {\n  foreignKeyConfigs = [];\n  static [entityKind] = \"PgColumnBuilder\";\n  array(size) {\n    return new PgArrayBuilder(this.config.name, this, size);\n  }\n  references(ref, actions = {}) {\n    this.foreignKeyConfigs.push({ ref, actions });\n    return this;\n  }\n  unique(name, config) {\n    this.config.isUnique = true;\n    this.config.uniqueName = name;\n    this.config.uniqueType = config?.nulls;\n    return this;\n  }\n  generatedAlwaysAs(as) {\n    this.config.generated = {\n      as,\n      type: \"always\",\n      mode: \"stored\"\n    };\n    return this;\n  }\n  /** @internal */\n  buildForeignKeys(column, table) {\n    return this.foreignKeyConfigs.map(({ ref, actions }) => {\n      return iife(\n        (ref2, actions2) => {\n          const builder = new ForeignKeyBuilder(() => {\n            const foreignColumn = ref2();\n            return { columns: [column], foreignColumns: [foreignColumn] };\n          });\n          if (actions2.onUpdate) {\n            builder.onUpdate(actions2.onUpdate);\n          }\n          if (actions2.onDelete) {\n            builder.onDelete(actions2.onDelete);\n          }\n          return builder.build(table);\n        },\n        ref,\n        actions\n      );\n    });\n  }\n  /** @internal */\n  buildExtraConfigColumn(table) {\n    return new ExtraConfigColumn(table, this.config);\n  }\n}\nclass PgColumn extends Column {\n  constructor(table, config) {\n    if (!config.uniqueName) {\n      config.uniqueName = uniqueKeyName(table, [config.name]);\n    }\n    super(table, config);\n    this.table = table;\n  }\n  static [entityKind] = \"PgColumn\";\n}\nclass ExtraConfigColumn extends PgColumn {\n  static [entityKind] = \"ExtraConfigColumn\";\n  getSQLType() {\n    return this.getSQLType();\n  }\n  indexConfig = {\n    order: this.config.order ?? \"asc\",\n    nulls: this.config.nulls ?? \"last\",\n    opClass: this.config.opClass\n  };\n  defaultConfig = {\n    order: \"asc\",\n    nulls: \"last\",\n    opClass: void 0\n  };\n  asc() {\n    this.indexConfig.order = \"asc\";\n    return this;\n  }\n  desc() {\n    this.indexConfig.order = \"desc\";\n    return this;\n  }\n  nullsFirst() {\n    this.indexConfig.nulls = \"first\";\n    return this;\n  }\n  nullsLast() {\n    this.indexConfig.nulls = \"last\";\n    return this;\n  }\n  /**\n   * ### PostgreSQL documentation quote\n   *\n   * > An operator class with optional parameters can be specified for each column of an index.\n   * The operator class identifies the operators to be used by the index for that column.\n   * For example, a B-tree index on four-byte integers would use the int4_ops class;\n   * this operator class includes comparison functions for four-byte integers.\n   * In practice the default operator class for the column's data type is usually sufficient.\n   * The main point of having operator classes is that for some data types, there could be more than one meaningful ordering.\n   * For example, we might want to sort a complex-number data type either by absolute value or by real part.\n   * We could do this by defining two operator classes for the data type and then selecting the proper class when creating an index.\n   * More information about operator classes check:\n   *\n   * ### Useful links\n   * https://www.postgresql.org/docs/current/sql-createindex.html\n   *\n   * https://www.postgresql.org/docs/current/indexes-opclass.html\n   *\n   * https://www.postgresql.org/docs/current/xindex.html\n   *\n   * ### Additional types\n   * If you have the `pg_vector` extension installed in your database, you can use the\n   * `vector_l2_ops`, `vector_ip_ops`, `vector_cosine_ops`, `vector_l1_ops`, `bit_hamming_ops`, `bit_jaccard_ops`, `halfvec_l2_ops`, `sparsevec_l2_ops` options, which are predefined types.\n   *\n   * **You can always specify any string you want in the operator class, in case Drizzle doesn't have it natively in its types**\n   *\n   * @param opClass\n   * @returns\n   */\n  op(opClass) {\n    this.indexConfig.opClass = opClass;\n    return this;\n  }\n}\nclass IndexedColumn {\n  static [entityKind] = \"IndexedColumn\";\n  constructor(name, keyAsName, type, indexConfig) {\n    this.name = name;\n    this.keyAsName = keyAsName;\n    this.type = type;\n    this.indexConfig = indexConfig;\n  }\n  name;\n  keyAsName;\n  type;\n  indexConfig;\n}\nclass PgArrayBuilder extends PgColumnBuilder {\n  static [entityKind] = \"PgArrayBuilder\";\n  constructor(name, baseBuilder, size) {\n    super(name, \"array\", \"PgArray\");\n    this.config.baseBuilder = baseBuilder;\n    this.config.size = size;\n  }\n  /** @internal */\n  build(table) {\n    const baseColumn = this.config.baseBuilder.build(table);\n    return new PgArray(\n      table,\n      this.config,\n      baseColumn\n    );\n  }\n}\nclass PgArray extends PgColumn {\n  constructor(table, config, baseColumn, range) {\n    super(table, config);\n    this.baseColumn = baseColumn;\n    this.range = range;\n    this.size = config.size;\n  }\n  size;\n  static [entityKind] = \"PgArray\";\n  getSQLType() {\n    return `${this.baseColumn.getSQLType()}[${typeof this.size === \"number\" ? this.size : \"\"}]`;\n  }\n  mapFromDriverValue(value) {\n    if (typeof value === \"string\") {\n      value = parsePgArray(value);\n    }\n    return value.map((v) => this.baseColumn.mapFromDriverValue(v));\n  }\n  mapToDriverValue(value, isNestedArray = false) {\n    const a = value.map(\n      (v) => v === null ? null : is(this.baseColumn, PgArray) ? this.baseColumn.mapToDriverValue(v, true) : this.baseColumn.mapToDriverValue(v)\n    );\n    if (isNestedArray) return a;\n    return makePgArray(a);\n  }\n}\nexport {\n  ExtraConfigColumn,\n  IndexedColumn,\n  PgArray,\n  PgArrayBuilder,\n  PgColumn,\n  PgColumnBuilder\n};\n//# sourceMappingURL=common.js.map",
    "import { entityKind } from \"../../entity.js\";\nimport { PgColumn, PgColumnBuilder } from \"./common.js\";\nclass PgEnumObjectColumnBuilder extends PgColumnBuilder {\n  static [entityKind] = \"PgEnumObjectColumnBuilder\";\n  constructor(name, enumInstance) {\n    super(name, \"string\", \"PgEnumObjectColumn\");\n    this.config.enum = enumInstance;\n  }\n  /** @internal */\n  build(table) {\n    return new PgEnumObjectColumn(\n      table,\n      this.config\n    );\n  }\n}\nclass PgEnumObjectColumn extends PgColumn {\n  static [entityKind] = \"PgEnumObjectColumn\";\n  enum;\n  enumValues = this.config.enum.enumValues;\n  constructor(table, config) {\n    super(table, config);\n    this.enum = config.enum;\n  }\n  getSQLType() {\n    return this.enum.enumName;\n  }\n}\nconst isPgEnumSym = Symbol.for(\"drizzle:isPgEnum\");\nfunction isPgEnum(obj) {\n  return !!obj && typeof obj === \"function\" && isPgEnumSym in obj && obj[isPgEnumSym] === true;\n}\nclass PgEnumColumnBuilder extends PgColumnBuilder {\n  static [entityKind] = \"PgEnumColumnBuilder\";\n  constructor(name, enumInstance) {\n    super(name, \"string\", \"PgEnumColumn\");\n    this.config.enum = enumInstance;\n  }\n  /** @internal */\n  build(table) {\n    return new PgEnumColumn(\n      table,\n      this.config\n    );\n  }\n}\nclass PgEnumColumn extends PgColumn {\n  static [entityKind] = \"PgEnumColumn\";\n  enum = this.config.enum;\n  enumValues = this.config.enum.enumValues;\n  constructor(table, config) {\n    super(table, config);\n    this.enum = config.enum;\n  }\n  getSQLType() {\n    return this.enum.enumName;\n  }\n}\nfunction pgEnum(enumName, input) {\n  return Array.isArray(input) ? pgEnumWithSchema(enumName, [...input], void 0) : pgEnumObjectWithSchema(enumName, input, void 0);\n}\nfunction pgEnumWithSchema(enumName, values, schema) {\n  const enumInstance = Object.assign(\n    (name) => new PgEnumColumnBuilder(name ?? \"\", enumInstance),\n    {\n      enumName,\n      enumValues: values,\n      schema,\n      [isPgEnumSym]: true\n    }\n  );\n  return enumInstance;\n}\nfunction pgEnumObjectWithSchema(enumName, values, schema) {\n  const enumInstance = Object.assign(\n    (name) => new PgEnumObjectColumnBuilder(name ?? \"\", enumInstance),\n    {\n      enumName,\n      enumValues: Object.values(values),\n      schema,\n      [isPgEnumSym]: true\n    }\n  );\n  return enumInstance;\n}\nexport {\n  PgEnumColumn,\n  PgEnumColumnBuilder,\n  PgEnumObjectColumn,\n  PgEnumObjectColumnBuilder,\n  isPgEnum,\n  pgEnum,\n  pgEnumObjectWithSchema,\n  pgEnumWithSchema\n};\n//# sourceMappingURL=enum.js.map",
    "import { entityKind } from \"./entity.js\";\nclass Subquery {\n  static [entityKind] = \"Subquery\";\n  constructor(sql, fields, alias, isWith = false, usedTables = []) {\n    this._ = {\n      brand: \"Subquery\",\n      sql,\n      selectedFields: fields,\n      alias,\n      isWith,\n      usedTables\n    };\n  }\n  // getSQL(): SQL<unknown> {\n  // \treturn new SQL([this]);\n  // }\n}\nclass WithSubquery extends Subquery {\n  static [entityKind] = \"WithSubquery\";\n}\nexport {\n  Subquery,\n  WithSubquery\n};\n//# sourceMappingURL=subquery.js.map",
    "// package.json\nvar version = \"0.44.5\";\n\n// src/version.ts\nvar compatibilityVersion = 10;\nexport {\n  compatibilityVersion,\n  version as npmVersion\n};\n",
    "import { iife } from \"./tracing-utils.js\";\nimport { npmVersion } from \"./version.js\";\nlet otel;\nlet rawTracer;\nconst tracer = {\n  startActiveSpan(name, fn) {\n    if (!otel) {\n      return fn();\n    }\n    if (!rawTracer) {\n      rawTracer = otel.trace.getTracer(\"drizzle-orm\", npmVersion);\n    }\n    return iife(\n      (otel2, rawTracer2) => rawTracer2.startActiveSpan(\n        name,\n        (span) => {\n          try {\n            return fn(span);\n          } catch (e) {\n            span.setStatus({\n              code: otel2.SpanStatusCode.ERROR,\n              message: e instanceof Error ? e.message : \"Unknown error\"\n              // eslint-disable-line no-instanceof/no-instanceof\n            });\n            throw e;\n          } finally {\n            span.end();\n          }\n        }\n      ),\n      otel,\n      rawTracer\n    );\n  }\n};\nexport {\n  tracer\n};\n//# sourceMappingURL=tracing.js.map",
    "const ViewBaseConfig = Symbol.for(\"drizzle:ViewBaseConfig\");\nexport {\n  ViewBaseConfig\n};\n//# sourceMappingURL=view-common.js.map",
    "import { entityKind } from \"./entity.js\";\nimport { TableName } from \"./table.utils.js\";\nconst Schema = Symbol.for(\"drizzle:Schema\");\nconst Columns = Symbol.for(\"drizzle:Columns\");\nconst ExtraConfigColumns = Symbol.for(\"drizzle:ExtraConfigColumns\");\nconst OriginalName = Symbol.for(\"drizzle:OriginalName\");\nconst BaseName = Symbol.for(\"drizzle:BaseName\");\nconst IsAlias = Symbol.for(\"drizzle:IsAlias\");\nconst ExtraConfigBuilder = Symbol.for(\"drizzle:ExtraConfigBuilder\");\nconst IsDrizzleTable = Symbol.for(\"drizzle:IsDrizzleTable\");\nclass Table {\n  static [entityKind] = \"Table\";\n  /** @internal */\n  static Symbol = {\n    Name: TableName,\n    Schema,\n    OriginalName,\n    Columns,\n    ExtraConfigColumns,\n    BaseName,\n    IsAlias,\n    ExtraConfigBuilder\n  };\n  /**\n   * @internal\n   * Can be changed if the table is aliased.\n   */\n  [TableName];\n  /**\n   * @internal\n   * Used to store the original name of the table, before any aliasing.\n   */\n  [OriginalName];\n  /** @internal */\n  [Schema];\n  /** @internal */\n  [Columns];\n  /** @internal */\n  [ExtraConfigColumns];\n  /**\n   *  @internal\n   * Used to store the table name before the transformation via the `tableCreator` functions.\n   */\n  [BaseName];\n  /** @internal */\n  [IsAlias] = false;\n  /** @internal */\n  [IsDrizzleTable] = true;\n  /** @internal */\n  [ExtraConfigBuilder] = void 0;\n  constructor(name, schema, baseName) {\n    this[TableName] = this[OriginalName] = name;\n    this[Schema] = schema;\n    this[BaseName] = baseName;\n  }\n}\nfunction isTable(table) {\n  return typeof table === \"object\" && table !== null && IsDrizzleTable in table;\n}\nfunction getTableName(table) {\n  return table[TableName];\n}\nfunction getTableUniqueName(table) {\n  return `${table[Schema] ?? \"public\"}.${table[TableName]}`;\n}\nexport {\n  BaseName,\n  Columns,\n  ExtraConfigBuilder,\n  ExtraConfigColumns,\n  IsAlias,\n  OriginalName,\n  Schema,\n  Table,\n  getTableName,\n  getTableUniqueName,\n  isTable\n};\n//# sourceMappingURL=table.js.map",
    "import { entityKind, is } from \"../entity.js\";\nimport { isPgEnum } from \"../pg-core/columns/enum.js\";\nimport { Subquery } from \"../subquery.js\";\nimport { tracer } from \"../tracing.js\";\nimport { ViewBaseConfig } from \"../view-common.js\";\nimport { Column } from \"../column.js\";\nimport { IsAlias, Table } from \"../table.js\";\nclass FakePrimitiveParam {\n  static [entityKind] = \"FakePrimitiveParam\";\n}\nfunction isSQLWrapper(value) {\n  return value !== null && value !== void 0 && typeof value.getSQL === \"function\";\n}\nfunction mergeQueries(queries) {\n  const result = { sql: \"\", params: [] };\n  for (const query of queries) {\n    result.sql += query.sql;\n    result.params.push(...query.params);\n    if (query.typings?.length) {\n      if (!result.typings) {\n        result.typings = [];\n      }\n      result.typings.push(...query.typings);\n    }\n  }\n  return result;\n}\nclass StringChunk {\n  static [entityKind] = \"StringChunk\";\n  value;\n  constructor(value) {\n    this.value = Array.isArray(value) ? value : [value];\n  }\n  getSQL() {\n    return new SQL([this]);\n  }\n}\nclass SQL {\n  constructor(queryChunks) {\n    this.queryChunks = queryChunks;\n    for (const chunk of queryChunks) {\n      if (is(chunk, Table)) {\n        const schemaName = chunk[Table.Symbol.Schema];\n        this.usedTables.push(\n          schemaName === void 0 ? chunk[Table.Symbol.Name] : schemaName + \".\" + chunk[Table.Symbol.Name]\n        );\n      }\n    }\n  }\n  static [entityKind] = \"SQL\";\n  /** @internal */\n  decoder = noopDecoder;\n  shouldInlineParams = false;\n  /** @internal */\n  usedTables = [];\n  append(query) {\n    this.queryChunks.push(...query.queryChunks);\n    return this;\n  }\n  toQuery(config) {\n    return tracer.startActiveSpan(\"drizzle.buildSQL\", (span) => {\n      const query = this.buildQueryFromSourceParams(this.queryChunks, config);\n      span?.setAttributes({\n        \"drizzle.query.text\": query.sql,\n        \"drizzle.query.params\": JSON.stringify(query.params)\n      });\n      return query;\n    });\n  }\n  buildQueryFromSourceParams(chunks, _config) {\n    const config = Object.assign({}, _config, {\n      inlineParams: _config.inlineParams || this.shouldInlineParams,\n      paramStartIndex: _config.paramStartIndex || { value: 0 }\n    });\n    const {\n      casing,\n      escapeName,\n      escapeParam,\n      prepareTyping,\n      inlineParams,\n      paramStartIndex\n    } = config;\n    return mergeQueries(chunks.map((chunk) => {\n      if (is(chunk, StringChunk)) {\n        return { sql: chunk.value.join(\"\"), params: [] };\n      }\n      if (is(chunk, Name)) {\n        return { sql: escapeName(chunk.value), params: [] };\n      }\n      if (chunk === void 0) {\n        return { sql: \"\", params: [] };\n      }\n      if (Array.isArray(chunk)) {\n        const result = [new StringChunk(\"(\")];\n        for (const [i, p] of chunk.entries()) {\n          result.push(p);\n          if (i < chunk.length - 1) {\n            result.push(new StringChunk(\", \"));\n          }\n        }\n        result.push(new StringChunk(\")\"));\n        return this.buildQueryFromSourceParams(result, config);\n      }\n      if (is(chunk, SQL)) {\n        return this.buildQueryFromSourceParams(chunk.queryChunks, {\n          ...config,\n          inlineParams: inlineParams || chunk.shouldInlineParams\n        });\n      }\n      if (is(chunk, Table)) {\n        const schemaName = chunk[Table.Symbol.Schema];\n        const tableName = chunk[Table.Symbol.Name];\n        return {\n          sql: schemaName === void 0 || chunk[IsAlias] ? escapeName(tableName) : escapeName(schemaName) + \".\" + escapeName(tableName),\n          params: []\n        };\n      }\n      if (is(chunk, Column)) {\n        const columnName = casing.getColumnCasing(chunk);\n        if (_config.invokeSource === \"indexes\") {\n          return { sql: escapeName(columnName), params: [] };\n        }\n        const schemaName = chunk.table[Table.Symbol.Schema];\n        return {\n          sql: chunk.table[IsAlias] || schemaName === void 0 ? escapeName(chunk.table[Table.Symbol.Name]) + \".\" + escapeName(columnName) : escapeName(schemaName) + \".\" + escapeName(chunk.table[Table.Symbol.Name]) + \".\" + escapeName(columnName),\n          params: []\n        };\n      }\n      if (is(chunk, View)) {\n        const schemaName = chunk[ViewBaseConfig].schema;\n        const viewName = chunk[ViewBaseConfig].name;\n        return {\n          sql: schemaName === void 0 || chunk[ViewBaseConfig].isAlias ? escapeName(viewName) : escapeName(schemaName) + \".\" + escapeName(viewName),\n          params: []\n        };\n      }\n      if (is(chunk, Param)) {\n        if (is(chunk.value, Placeholder)) {\n          return { sql: escapeParam(paramStartIndex.value++, chunk), params: [chunk], typings: [\"none\"] };\n        }\n        const mappedValue = chunk.value === null ? null : chunk.encoder.mapToDriverValue(chunk.value);\n        if (is(mappedValue, SQL)) {\n          return this.buildQueryFromSourceParams([mappedValue], config);\n        }\n        if (inlineParams) {\n          return { sql: this.mapInlineParam(mappedValue, config), params: [] };\n        }\n        let typings = [\"none\"];\n        if (prepareTyping) {\n          typings = [prepareTyping(chunk.encoder)];\n        }\n        return { sql: escapeParam(paramStartIndex.value++, mappedValue), params: [mappedValue], typings };\n      }\n      if (is(chunk, Placeholder)) {\n        return { sql: escapeParam(paramStartIndex.value++, chunk), params: [chunk], typings: [\"none\"] };\n      }\n      if (is(chunk, SQL.Aliased) && chunk.fieldAlias !== void 0) {\n        return { sql: escapeName(chunk.fieldAlias), params: [] };\n      }\n      if (is(chunk, Subquery)) {\n        if (chunk._.isWith) {\n          return { sql: escapeName(chunk._.alias), params: [] };\n        }\n        return this.buildQueryFromSourceParams([\n          new StringChunk(\"(\"),\n          chunk._.sql,\n          new StringChunk(\") \"),\n          new Name(chunk._.alias)\n        ], config);\n      }\n      if (isPgEnum(chunk)) {\n        if (chunk.schema) {\n          return { sql: escapeName(chunk.schema) + \".\" + escapeName(chunk.enumName), params: [] };\n        }\n        return { sql: escapeName(chunk.enumName), params: [] };\n      }\n      if (isSQLWrapper(chunk)) {\n        if (chunk.shouldOmitSQLParens?.()) {\n          return this.buildQueryFromSourceParams([chunk.getSQL()], config);\n        }\n        return this.buildQueryFromSourceParams([\n          new StringChunk(\"(\"),\n          chunk.getSQL(),\n          new StringChunk(\")\")\n        ], config);\n      }\n      if (inlineParams) {\n        return { sql: this.mapInlineParam(chunk, config), params: [] };\n      }\n      return { sql: escapeParam(paramStartIndex.value++, chunk), params: [chunk], typings: [\"none\"] };\n    }));\n  }\n  mapInlineParam(chunk, { escapeString }) {\n    if (chunk === null) {\n      return \"null\";\n    }\n    if (typeof chunk === \"number\" || typeof chunk === \"boolean\") {\n      return chunk.toString();\n    }\n    if (typeof chunk === \"string\") {\n      return escapeString(chunk);\n    }\n    if (typeof chunk === \"object\") {\n      const mappedValueAsString = chunk.toString();\n      if (mappedValueAsString === \"[object Object]\") {\n        return escapeString(JSON.stringify(chunk));\n      }\n      return escapeString(mappedValueAsString);\n    }\n    throw new Error(\"Unexpected param value: \" + chunk);\n  }\n  getSQL() {\n    return this;\n  }\n  as(alias) {\n    if (alias === void 0) {\n      return this;\n    }\n    return new SQL.Aliased(this, alias);\n  }\n  mapWith(decoder) {\n    this.decoder = typeof decoder === \"function\" ? { mapFromDriverValue: decoder } : decoder;\n    return this;\n  }\n  inlineParams() {\n    this.shouldInlineParams = true;\n    return this;\n  }\n  /**\n   * This method is used to conditionally include a part of the query.\n   *\n   * @param condition - Condition to check\n   * @returns itself if the condition is `true`, otherwise `undefined`\n   */\n  if(condition) {\n    return condition ? this : void 0;\n  }\n}\nclass Name {\n  constructor(value) {\n    this.value = value;\n  }\n  static [entityKind] = \"Name\";\n  brand;\n  getSQL() {\n    return new SQL([this]);\n  }\n}\nfunction name(value) {\n  return new Name(value);\n}\nfunction isDriverValueEncoder(value) {\n  return typeof value === \"object\" && value !== null && \"mapToDriverValue\" in value && typeof value.mapToDriverValue === \"function\";\n}\nconst noopDecoder = {\n  mapFromDriverValue: (value) => value\n};\nconst noopEncoder = {\n  mapToDriverValue: (value) => value\n};\nconst noopMapper = {\n  ...noopDecoder,\n  ...noopEncoder\n};\nclass Param {\n  /**\n   * @param value - Parameter value\n   * @param encoder - Encoder to convert the value to a driver parameter\n   */\n  constructor(value, encoder = noopEncoder) {\n    this.value = value;\n    this.encoder = encoder;\n  }\n  static [entityKind] = \"Param\";\n  brand;\n  getSQL() {\n    return new SQL([this]);\n  }\n}\nfunction param(value, encoder) {\n  return new Param(value, encoder);\n}\nfunction sql(strings, ...params) {\n  const queryChunks = [];\n  if (params.length > 0 || strings.length > 0 && strings[0] !== \"\") {\n    queryChunks.push(new StringChunk(strings[0]));\n  }\n  for (const [paramIndex, param2] of params.entries()) {\n    queryChunks.push(param2, new StringChunk(strings[paramIndex + 1]));\n  }\n  return new SQL(queryChunks);\n}\n((sql2) => {\n  function empty() {\n    return new SQL([]);\n  }\n  sql2.empty = empty;\n  function fromList(list) {\n    return new SQL(list);\n  }\n  sql2.fromList = fromList;\n  function raw(str) {\n    return new SQL([new StringChunk(str)]);\n  }\n  sql2.raw = raw;\n  function join(chunks, separator) {\n    const result = [];\n    for (const [i, chunk] of chunks.entries()) {\n      if (i > 0 && separator !== void 0) {\n        result.push(separator);\n      }\n      result.push(chunk);\n    }\n    return new SQL(result);\n  }\n  sql2.join = join;\n  function identifier(value) {\n    return new Name(value);\n  }\n  sql2.identifier = identifier;\n  function placeholder2(name2) {\n    return new Placeholder(name2);\n  }\n  sql2.placeholder = placeholder2;\n  function param2(value, encoder) {\n    return new Param(value, encoder);\n  }\n  sql2.param = param2;\n})(sql || (sql = {}));\n((SQL2) => {\n  class Aliased {\n    constructor(sql2, fieldAlias) {\n      this.sql = sql2;\n      this.fieldAlias = fieldAlias;\n    }\n    static [entityKind] = \"SQL.Aliased\";\n    /** @internal */\n    isSelectionField = false;\n    getSQL() {\n      return this.sql;\n    }\n    /** @internal */\n    clone() {\n      return new Aliased(this.sql, this.fieldAlias);\n    }\n  }\n  SQL2.Aliased = Aliased;\n})(SQL || (SQL = {}));\nclass Placeholder {\n  constructor(name2) {\n    this.name = name2;\n  }\n  static [entityKind] = \"Placeholder\";\n  getSQL() {\n    return new SQL([this]);\n  }\n}\nfunction placeholder(name2) {\n  return new Placeholder(name2);\n}\nfunction fillPlaceholders(params, values) {\n  return params.map((p) => {\n    if (is(p, Placeholder)) {\n      if (!(p.name in values)) {\n        throw new Error(`No value for placeholder \"${p.name}\" was provided`);\n      }\n      return values[p.name];\n    }\n    if (is(p, Param) && is(p.value, Placeholder)) {\n      if (!(p.value.name in values)) {\n        throw new Error(`No value for placeholder \"${p.value.name}\" was provided`);\n      }\n      return p.encoder.mapToDriverValue(values[p.value.name]);\n    }\n    return p;\n  });\n}\nconst IsDrizzleView = Symbol.for(\"drizzle:IsDrizzleView\");\nclass View {\n  static [entityKind] = \"View\";\n  /** @internal */\n  [ViewBaseConfig];\n  /** @internal */\n  [IsDrizzleView] = true;\n  constructor({ name: name2, schema, selectedFields, query }) {\n    this[ViewBaseConfig] = {\n      name: name2,\n      originalName: name2,\n      schema,\n      selectedFields,\n      query,\n      isExisting: !query,\n      isAlias: false\n    };\n  }\n  getSQL() {\n    return new SQL([this]);\n  }\n}\nfunction isView(view) {\n  return typeof view === \"object\" && view !== null && IsDrizzleView in view;\n}\nfunction getViewName(view) {\n  return view[ViewBaseConfig].name;\n}\nColumn.prototype.getSQL = function() {\n  return new SQL([this]);\n};\nTable.prototype.getSQL = function() {\n  return new SQL([this]);\n};\nSubquery.prototype.getSQL = function() {\n  return new SQL([this]);\n};\nexport {\n  FakePrimitiveParam,\n  Name,\n  Param,\n  Placeholder,\n  SQL,\n  StringChunk,\n  View,\n  fillPlaceholders,\n  getViewName,\n  isDriverValueEncoder,\n  isSQLWrapper,\n  isView,\n  name,\n  noopDecoder,\n  noopEncoder,\n  noopMapper,\n  param,\n  placeholder,\n  sql\n};\n//# sourceMappingURL=sql.js.map",
    "import { Column } from \"./column.js\";\nimport { entityKind, is } from \"./entity.js\";\nimport { SQL, sql } from \"./sql/sql.js\";\nimport { Table } from \"./table.js\";\nimport { ViewBaseConfig } from \"./view-common.js\";\nclass ColumnAliasProxyHandler {\n  constructor(table) {\n    this.table = table;\n  }\n  static [entityKind] = \"ColumnAliasProxyHandler\";\n  get(columnObj, prop) {\n    if (prop === \"table\") {\n      return this.table;\n    }\n    return columnObj[prop];\n  }\n}\nclass TableAliasProxyHandler {\n  constructor(alias, replaceOriginalName) {\n    this.alias = alias;\n    this.replaceOriginalName = replaceOriginalName;\n  }\n  static [entityKind] = \"TableAliasProxyHandler\";\n  get(target, prop) {\n    if (prop === Table.Symbol.IsAlias) {\n      return true;\n    }\n    if (prop === Table.Symbol.Name) {\n      return this.alias;\n    }\n    if (this.replaceOriginalName && prop === Table.Symbol.OriginalName) {\n      return this.alias;\n    }\n    if (prop === ViewBaseConfig) {\n      return {\n        ...target[ViewBaseConfig],\n        name: this.alias,\n        isAlias: true\n      };\n    }\n    if (prop === Table.Symbol.Columns) {\n      const columns = target[Table.Symbol.Columns];\n      if (!columns) {\n        return columns;\n      }\n      const proxiedColumns = {};\n      Object.keys(columns).map((key) => {\n        proxiedColumns[key] = new Proxy(\n          columns[key],\n          new ColumnAliasProxyHandler(new Proxy(target, this))\n        );\n      });\n      return proxiedColumns;\n    }\n    const value = target[prop];\n    if (is(value, Column)) {\n      return new Proxy(value, new ColumnAliasProxyHandler(new Proxy(target, this)));\n    }\n    return value;\n  }\n}\nclass RelationTableAliasProxyHandler {\n  constructor(alias) {\n    this.alias = alias;\n  }\n  static [entityKind] = \"RelationTableAliasProxyHandler\";\n  get(target, prop) {\n    if (prop === \"sourceTable\") {\n      return aliasedTable(target.sourceTable, this.alias);\n    }\n    return target[prop];\n  }\n}\nfunction aliasedTable(table, tableAlias) {\n  return new Proxy(table, new TableAliasProxyHandler(tableAlias, false));\n}\nfunction aliasedRelation(relation, tableAlias) {\n  return new Proxy(relation, new RelationTableAliasProxyHandler(tableAlias));\n}\nfunction aliasedTableColumn(column, tableAlias) {\n  return new Proxy(\n    column,\n    new ColumnAliasProxyHandler(new Proxy(column.table, new TableAliasProxyHandler(tableAlias, false)))\n  );\n}\nfunction mapColumnsInAliasedSQLToAlias(query, alias) {\n  return new SQL.Aliased(mapColumnsInSQLToAlias(query.sql, alias), query.fieldAlias);\n}\nfunction mapColumnsInSQLToAlias(query, alias) {\n  return sql.join(query.queryChunks.map((c) => {\n    if (is(c, Column)) {\n      return aliasedTableColumn(c, alias);\n    }\n    if (is(c, SQL)) {\n      return mapColumnsInSQLToAlias(c, alias);\n    }\n    if (is(c, SQL.Aliased)) {\n      return mapColumnsInAliasedSQLToAlias(c, alias);\n    }\n    return c;\n  }));\n}\nexport {\n  ColumnAliasProxyHandler,\n  RelationTableAliasProxyHandler,\n  TableAliasProxyHandler,\n  aliasedRelation,\n  aliasedTable,\n  aliasedTableColumn,\n  mapColumnsInAliasedSQLToAlias,\n  mapColumnsInSQLToAlias\n};\n//# sourceMappingURL=alias.js.map",
    "import { Column } from \"./column.js\";\nimport { is } from \"./entity.js\";\nimport { Param, SQL, View } from \"./sql/sql.js\";\nimport { Subquery } from \"./subquery.js\";\nimport { getTableName, Table } from \"./table.js\";\nimport { ViewBaseConfig } from \"./view-common.js\";\nfunction mapResultRow(columns, row, joinsNotNullableMap) {\n  const nullifyMap = {};\n  const result = columns.reduce(\n    (result2, { path, field }, columnIndex) => {\n      let decoder;\n      if (is(field, Column)) {\n        decoder = field;\n      } else if (is(field, SQL)) {\n        decoder = field.decoder;\n      } else {\n        decoder = field.sql.decoder;\n      }\n      let node = result2;\n      for (const [pathChunkIndex, pathChunk] of path.entries()) {\n        if (pathChunkIndex < path.length - 1) {\n          if (!(pathChunk in node)) {\n            node[pathChunk] = {};\n          }\n          node = node[pathChunk];\n        } else {\n          const rawValue = row[columnIndex];\n          const value = node[pathChunk] = rawValue === null ? null : decoder.mapFromDriverValue(rawValue);\n          if (joinsNotNullableMap && is(field, Column) && path.length === 2) {\n            const objectName = path[0];\n            if (!(objectName in nullifyMap)) {\n              nullifyMap[objectName] = value === null ? getTableName(field.table) : false;\n            } else if (typeof nullifyMap[objectName] === \"string\" && nullifyMap[objectName] !== getTableName(field.table)) {\n              nullifyMap[objectName] = false;\n            }\n          }\n        }\n      }\n      return result2;\n    },\n    {}\n  );\n  if (joinsNotNullableMap && Object.keys(nullifyMap).length > 0) {\n    for (const [objectName, tableName] of Object.entries(nullifyMap)) {\n      if (typeof tableName === \"string\" && !joinsNotNullableMap[tableName]) {\n        result[objectName] = null;\n      }\n    }\n  }\n  return result;\n}\nfunction orderSelectedFields(fields, pathPrefix) {\n  return Object.entries(fields).reduce((result, [name, field]) => {\n    if (typeof name !== \"string\") {\n      return result;\n    }\n    const newPath = pathPrefix ? [...pathPrefix, name] : [name];\n    if (is(field, Column) || is(field, SQL) || is(field, SQL.Aliased)) {\n      result.push({ path: newPath, field });\n    } else if (is(field, Table)) {\n      result.push(...orderSelectedFields(field[Table.Symbol.Columns], newPath));\n    } else {\n      result.push(...orderSelectedFields(field, newPath));\n    }\n    return result;\n  }, []);\n}\nfunction haveSameKeys(left, right) {\n  const leftKeys = Object.keys(left);\n  const rightKeys = Object.keys(right);\n  if (leftKeys.length !== rightKeys.length) {\n    return false;\n  }\n  for (const [index, key] of leftKeys.entries()) {\n    if (key !== rightKeys[index]) {\n      return false;\n    }\n  }\n  return true;\n}\nfunction mapUpdateSet(table, values) {\n  const entries = Object.entries(values).filter(([, value]) => value !== void 0).map(([key, value]) => {\n    if (is(value, SQL) || is(value, Column)) {\n      return [key, value];\n    } else {\n      return [key, new Param(value, table[Table.Symbol.Columns][key])];\n    }\n  });\n  if (entries.length === 0) {\n    throw new Error(\"No values to set\");\n  }\n  return Object.fromEntries(entries);\n}\nfunction applyMixins(baseClass, extendedClasses) {\n  for (const extendedClass of extendedClasses) {\n    for (const name of Object.getOwnPropertyNames(extendedClass.prototype)) {\n      if (name === \"constructor\") continue;\n      Object.defineProperty(\n        baseClass.prototype,\n        name,\n        Object.getOwnPropertyDescriptor(extendedClass.prototype, name) || /* @__PURE__ */ Object.create(null)\n      );\n    }\n  }\n}\nfunction getTableColumns(table) {\n  return table[Table.Symbol.Columns];\n}\nfunction getViewSelectedFields(view) {\n  return view[ViewBaseConfig].selectedFields;\n}\nfunction getTableLikeName(table) {\n  return is(table, Subquery) ? table._.alias : is(table, View) ? table[ViewBaseConfig].name : is(table, SQL) ? void 0 : table[Table.Symbol.IsAlias] ? table[Table.Symbol.Name] : table[Table.Symbol.BaseName];\n}\nfunction getColumnNameAndConfig(a, b) {\n  return {\n    name: typeof a === \"string\" && a.length > 0 ? a : \"\",\n    config: typeof a === \"object\" ? a : b\n  };\n}\nconst _ = {};\nconst __ = {};\nfunction isConfig(data) {\n  if (typeof data !== \"object\" || data === null) return false;\n  if (data.constructor.name !== \"Object\") return false;\n  if (\"logger\" in data) {\n    const type = typeof data[\"logger\"];\n    if (type !== \"boolean\" && (type !== \"object\" || typeof data[\"logger\"][\"logQuery\"] !== \"function\") && type !== \"undefined\") return false;\n    return true;\n  }\n  if (\"schema\" in data) {\n    const type = typeof data[\"schema\"];\n    if (type !== \"object\" && type !== \"undefined\") return false;\n    return true;\n  }\n  if (\"casing\" in data) {\n    const type = typeof data[\"casing\"];\n    if (type !== \"string\" && type !== \"undefined\") return false;\n    return true;\n  }\n  if (\"mode\" in data) {\n    if (data[\"mode\"] !== \"default\" || data[\"mode\"] !== \"planetscale\" || data[\"mode\"] !== void 0) return false;\n    return true;\n  }\n  if (\"connection\" in data) {\n    const type = typeof data[\"connection\"];\n    if (type !== \"string\" && type !== \"object\" && type !== \"undefined\") return false;\n    return true;\n  }\n  if (\"client\" in data) {\n    const type = typeof data[\"client\"];\n    if (type !== \"object\" && type !== \"function\" && type !== \"undefined\") return false;\n    return true;\n  }\n  if (Object.keys(data).length === 0) return true;\n  return false;\n}\nconst textDecoder = typeof TextDecoder === \"undefined\" ? null : new TextDecoder();\nexport {\n  applyMixins,\n  getColumnNameAndConfig,\n  getTableColumns,\n  getTableLikeName,\n  getViewSelectedFields,\n  haveSameKeys,\n  isConfig,\n  mapResultRow,\n  mapUpdateSet,\n  orderSelectedFields,\n  textDecoder\n};\n//# sourceMappingURL=utils.js.map",
    "import { entityKind } from \"../entity.js\";\nimport { TableName } from \"../table.utils.js\";\nclass ForeignKeyBuilder {\n  static [entityKind] = \"SQLiteForeignKeyBuilder\";\n  /** @internal */\n  reference;\n  /** @internal */\n  _onUpdate;\n  /** @internal */\n  _onDelete;\n  constructor(config, actions) {\n    this.reference = () => {\n      const { name, columns, foreignColumns } = config();\n      return { name, columns, foreignTable: foreignColumns[0].table, foreignColumns };\n    };\n    if (actions) {\n      this._onUpdate = actions.onUpdate;\n      this._onDelete = actions.onDelete;\n    }\n  }\n  onUpdate(action) {\n    this._onUpdate = action;\n    return this;\n  }\n  onDelete(action) {\n    this._onDelete = action;\n    return this;\n  }\n  /** @internal */\n  build(table) {\n    return new ForeignKey(table, this);\n  }\n}\nclass ForeignKey {\n  constructor(table, builder) {\n    this.table = table;\n    this.reference = builder.reference;\n    this.onUpdate = builder._onUpdate;\n    this.onDelete = builder._onDelete;\n  }\n  static [entityKind] = \"SQLiteForeignKey\";\n  reference;\n  onUpdate;\n  onDelete;\n  getName() {\n    const { name, columns, foreignColumns } = this.reference();\n    const columnNames = columns.map((column) => column.name);\n    const foreignColumnNames = foreignColumns.map((column) => column.name);\n    const chunks = [\n      this.table[TableName],\n      ...columnNames,\n      foreignColumns[0].table[TableName],\n      ...foreignColumnNames\n    ];\n    return name ?? `${chunks.join(\"_\")}_fk`;\n  }\n}\nfunction foreignKey(config) {\n  function mappedConfig() {\n    if (typeof config === \"function\") {\n      const { name, columns, foreignColumns } = config();\n      return {\n        name,\n        columns,\n        foreignColumns\n      };\n    }\n    return config;\n  }\n  return new ForeignKeyBuilder(mappedConfig);\n}\nexport {\n  ForeignKey,\n  ForeignKeyBuilder,\n  foreignKey\n};\n//# sourceMappingURL=foreign-keys.js.map",
    "import { entityKind } from \"../entity.js\";\nimport { TableName } from \"../table.utils.js\";\nfunction uniqueKeyName(table, columns) {\n  return `${table[TableName]}_${columns.join(\"_\")}_unique`;\n}\nfunction unique(name) {\n  return new UniqueOnConstraintBuilder(name);\n}\nclass UniqueConstraintBuilder {\n  constructor(columns, name) {\n    this.name = name;\n    this.columns = columns;\n  }\n  static [entityKind] = \"SQLiteUniqueConstraintBuilder\";\n  /** @internal */\n  columns;\n  /** @internal */\n  build(table) {\n    return new UniqueConstraint(table, this.columns, this.name);\n  }\n}\nclass UniqueOnConstraintBuilder {\n  static [entityKind] = \"SQLiteUniqueOnConstraintBuilder\";\n  /** @internal */\n  name;\n  constructor(name) {\n    this.name = name;\n  }\n  on(...columns) {\n    return new UniqueConstraintBuilder(columns, this.name);\n  }\n}\nclass UniqueConstraint {\n  constructor(table, columns, name) {\n    this.table = table;\n    this.columns = columns;\n    this.name = name ?? uniqueKeyName(this.table, this.columns.map((column) => column.name));\n  }\n  static [entityKind] = \"SQLiteUniqueConstraint\";\n  columns;\n  name;\n  getName() {\n    return this.name;\n  }\n}\nexport {\n  UniqueConstraint,\n  UniqueConstraintBuilder,\n  UniqueOnConstraintBuilder,\n  unique,\n  uniqueKeyName\n};\n//# sourceMappingURL=unique-constraint.js.map",
    "import { ColumnBuilder } from \"../../column-builder.js\";\nimport { Column } from \"../../column.js\";\nimport { entityKind } from \"../../entity.js\";\nimport { ForeignKeyBuilder } from \"../foreign-keys.js\";\nimport { uniqueKeyName } from \"../unique-constraint.js\";\nclass SQLiteColumnBuilder extends ColumnBuilder {\n  static [entityKind] = \"SQLiteColumnBuilder\";\n  foreignKeyConfigs = [];\n  references(ref, actions = {}) {\n    this.foreignKeyConfigs.push({ ref, actions });\n    return this;\n  }\n  unique(name) {\n    this.config.isUnique = true;\n    this.config.uniqueName = name;\n    return this;\n  }\n  generatedAlwaysAs(as, config) {\n    this.config.generated = {\n      as,\n      type: \"always\",\n      mode: config?.mode ?? \"virtual\"\n    };\n    return this;\n  }\n  /** @internal */\n  buildForeignKeys(column, table) {\n    return this.foreignKeyConfigs.map(({ ref, actions }) => {\n      return ((ref2, actions2) => {\n        const builder = new ForeignKeyBuilder(() => {\n          const foreignColumn = ref2();\n          return { columns: [column], foreignColumns: [foreignColumn] };\n        });\n        if (actions2.onUpdate) {\n          builder.onUpdate(actions2.onUpdate);\n        }\n        if (actions2.onDelete) {\n          builder.onDelete(actions2.onDelete);\n        }\n        return builder.build(table);\n      })(ref, actions);\n    });\n  }\n}\nclass SQLiteColumn extends Column {\n  constructor(table, config) {\n    if (!config.uniqueName) {\n      config.uniqueName = uniqueKeyName(table, [config.name]);\n    }\n    super(table, config);\n    this.table = table;\n  }\n  static [entityKind] = \"SQLiteColumn\";\n}\nexport {\n  SQLiteColumn,\n  SQLiteColumnBuilder\n};\n//# sourceMappingURL=common.js.map",
    "import { entityKind } from \"../../entity.js\";\nimport { getColumnNameAndConfig, textDecoder } from \"../../utils.js\";\nimport { SQLiteColumn, SQLiteColumnBuilder } from \"./common.js\";\nclass SQLiteBigIntBuilder extends SQLiteColumnBuilder {\n  static [entityKind] = \"SQLiteBigIntBuilder\";\n  constructor(name) {\n    super(name, \"bigint\", \"SQLiteBigInt\");\n  }\n  /** @internal */\n  build(table) {\n    return new SQLiteBigInt(table, this.config);\n  }\n}\nclass SQLiteBigInt extends SQLiteColumn {\n  static [entityKind] = \"SQLiteBigInt\";\n  getSQLType() {\n    return \"blob\";\n  }\n  mapFromDriverValue(value) {\n    if (typeof Buffer !== \"undefined\" && Buffer.from) {\n      const buf = Buffer.isBuffer(value) ? value : value instanceof ArrayBuffer ? Buffer.from(value) : value.buffer ? Buffer.from(value.buffer, value.byteOffset, value.byteLength) : Buffer.from(value);\n      return BigInt(buf.toString(\"utf8\"));\n    }\n    return BigInt(textDecoder.decode(value));\n  }\n  mapToDriverValue(value) {\n    return Buffer.from(value.toString());\n  }\n}\nclass SQLiteBlobJsonBuilder extends SQLiteColumnBuilder {\n  static [entityKind] = \"SQLiteBlobJsonBuilder\";\n  constructor(name) {\n    super(name, \"json\", \"SQLiteBlobJson\");\n  }\n  /** @internal */\n  build(table) {\n    return new SQLiteBlobJson(\n      table,\n      this.config\n    );\n  }\n}\nclass SQLiteBlobJson extends SQLiteColumn {\n  static [entityKind] = \"SQLiteBlobJson\";\n  getSQLType() {\n    return \"blob\";\n  }\n  mapFromDriverValue(value) {\n    if (typeof Buffer !== \"undefined\" && Buffer.from) {\n      const buf = Buffer.isBuffer(value) ? value : value instanceof ArrayBuffer ? Buffer.from(value) : value.buffer ? Buffer.from(value.buffer, value.byteOffset, value.byteLength) : Buffer.from(value);\n      return JSON.parse(buf.toString(\"utf8\"));\n    }\n    return JSON.parse(textDecoder.decode(value));\n  }\n  mapToDriverValue(value) {\n    return Buffer.from(JSON.stringify(value));\n  }\n}\nclass SQLiteBlobBufferBuilder extends SQLiteColumnBuilder {\n  static [entityKind] = \"SQLiteBlobBufferBuilder\";\n  constructor(name) {\n    super(name, \"buffer\", \"SQLiteBlobBuffer\");\n  }\n  /** @internal */\n  build(table) {\n    return new SQLiteBlobBuffer(table, this.config);\n  }\n}\nclass SQLiteBlobBuffer extends SQLiteColumn {\n  static [entityKind] = \"SQLiteBlobBuffer\";\n  mapFromDriverValue(value) {\n    if (Buffer.isBuffer(value)) {\n      return value;\n    }\n    return Buffer.from(value);\n  }\n  getSQLType() {\n    return \"blob\";\n  }\n}\nfunction blob(a, b) {\n  const { name, config } = getColumnNameAndConfig(a, b);\n  if (config?.mode === \"json\") {\n    return new SQLiteBlobJsonBuilder(name);\n  }\n  if (config?.mode === \"bigint\") {\n    return new SQLiteBigIntBuilder(name);\n  }\n  return new SQLiteBlobBufferBuilder(name);\n}\nexport {\n  SQLiteBigInt,\n  SQLiteBigIntBuilder,\n  SQLiteBlobBuffer,\n  SQLiteBlobBufferBuilder,\n  SQLiteBlobJson,\n  SQLiteBlobJsonBuilder,\n  blob\n};\n//# sourceMappingURL=blob.js.map",
    "import { entityKind } from \"../../entity.js\";\nimport { getColumnNameAndConfig } from \"../../utils.js\";\nimport { SQLiteColumn, SQLiteColumnBuilder } from \"./common.js\";\nclass SQLiteCustomColumnBuilder extends SQLiteColumnBuilder {\n  static [entityKind] = \"SQLiteCustomColumnBuilder\";\n  constructor(name, fieldConfig, customTypeParams) {\n    super(name, \"custom\", \"SQLiteCustomColumn\");\n    this.config.fieldConfig = fieldConfig;\n    this.config.customTypeParams = customTypeParams;\n  }\n  /** @internal */\n  build(table) {\n    return new SQLiteCustomColumn(\n      table,\n      this.config\n    );\n  }\n}\nclass SQLiteCustomColumn extends SQLiteColumn {\n  static [entityKind] = \"SQLiteCustomColumn\";\n  sqlName;\n  mapTo;\n  mapFrom;\n  constructor(table, config) {\n    super(table, config);\n    this.sqlName = config.customTypeParams.dataType(config.fieldConfig);\n    this.mapTo = config.customTypeParams.toDriver;\n    this.mapFrom = config.customTypeParams.fromDriver;\n  }\n  getSQLType() {\n    return this.sqlName;\n  }\n  mapFromDriverValue(value) {\n    return typeof this.mapFrom === \"function\" ? this.mapFrom(value) : value;\n  }\n  mapToDriverValue(value) {\n    return typeof this.mapTo === \"function\" ? this.mapTo(value) : value;\n  }\n}\nfunction customType(customTypeParams) {\n  return (a, b) => {\n    const { name, config } = getColumnNameAndConfig(a, b);\n    return new SQLiteCustomColumnBuilder(\n      name,\n      config,\n      customTypeParams\n    );\n  };\n}\nexport {\n  SQLiteCustomColumn,\n  SQLiteCustomColumnBuilder,\n  customType\n};\n//# sourceMappingURL=custom.js.map",
    "import { entityKind } from \"../../entity.js\";\nimport { sql } from \"../../sql/sql.js\";\nimport { getColumnNameAndConfig } from \"../../utils.js\";\nimport { SQLiteColumn, SQLiteColumnBuilder } from \"./common.js\";\nclass SQLiteBaseIntegerBuilder extends SQLiteColumnBuilder {\n  static [entityKind] = \"SQLiteBaseIntegerBuilder\";\n  constructor(name, dataType, columnType) {\n    super(name, dataType, columnType);\n    this.config.autoIncrement = false;\n  }\n  primaryKey(config) {\n    if (config?.autoIncrement) {\n      this.config.autoIncrement = true;\n    }\n    this.config.hasDefault = true;\n    return super.primaryKey();\n  }\n}\nclass SQLiteBaseInteger extends SQLiteColumn {\n  static [entityKind] = \"SQLiteBaseInteger\";\n  autoIncrement = this.config.autoIncrement;\n  getSQLType() {\n    return \"integer\";\n  }\n}\nclass SQLiteIntegerBuilder extends SQLiteBaseIntegerBuilder {\n  static [entityKind] = \"SQLiteIntegerBuilder\";\n  constructor(name) {\n    super(name, \"number\", \"SQLiteInteger\");\n  }\n  build(table) {\n    return new SQLiteInteger(\n      table,\n      this.config\n    );\n  }\n}\nclass SQLiteInteger extends SQLiteBaseInteger {\n  static [entityKind] = \"SQLiteInteger\";\n}\nclass SQLiteTimestampBuilder extends SQLiteBaseIntegerBuilder {\n  static [entityKind] = \"SQLiteTimestampBuilder\";\n  constructor(name, mode) {\n    super(name, \"date\", \"SQLiteTimestamp\");\n    this.config.mode = mode;\n  }\n  /**\n   * @deprecated Use `default()` with your own expression instead.\n   *\n   * Adds `DEFAULT (cast((julianday('now') - 2440587.5)*86400000 as integer))` to the column, which is the current epoch timestamp in milliseconds.\n   */\n  defaultNow() {\n    return this.default(sql`(cast((julianday('now') - 2440587.5)*86400000 as integer))`);\n  }\n  build(table) {\n    return new SQLiteTimestamp(\n      table,\n      this.config\n    );\n  }\n}\nclass SQLiteTimestamp extends SQLiteBaseInteger {\n  static [entityKind] = \"SQLiteTimestamp\";\n  mode = this.config.mode;\n  mapFromDriverValue(value) {\n    if (this.config.mode === \"timestamp\") {\n      return new Date(value * 1e3);\n    }\n    return new Date(value);\n  }\n  mapToDriverValue(value) {\n    const unix = value.getTime();\n    if (this.config.mode === \"timestamp\") {\n      return Math.floor(unix / 1e3);\n    }\n    return unix;\n  }\n}\nclass SQLiteBooleanBuilder extends SQLiteBaseIntegerBuilder {\n  static [entityKind] = \"SQLiteBooleanBuilder\";\n  constructor(name, mode) {\n    super(name, \"boolean\", \"SQLiteBoolean\");\n    this.config.mode = mode;\n  }\n  build(table) {\n    return new SQLiteBoolean(\n      table,\n      this.config\n    );\n  }\n}\nclass SQLiteBoolean extends SQLiteBaseInteger {\n  static [entityKind] = \"SQLiteBoolean\";\n  mode = this.config.mode;\n  mapFromDriverValue(value) {\n    return Number(value) === 1;\n  }\n  mapToDriverValue(value) {\n    return value ? 1 : 0;\n  }\n}\nfunction integer(a, b) {\n  const { name, config } = getColumnNameAndConfig(a, b);\n  if (config?.mode === \"timestamp\" || config?.mode === \"timestamp_ms\") {\n    return new SQLiteTimestampBuilder(name, config.mode);\n  }\n  if (config?.mode === \"boolean\") {\n    return new SQLiteBooleanBuilder(name, config.mode);\n  }\n  return new SQLiteIntegerBuilder(name);\n}\nconst int = integer;\nexport {\n  SQLiteBaseInteger,\n  SQLiteBaseIntegerBuilder,\n  SQLiteBoolean,\n  SQLiteBooleanBuilder,\n  SQLiteInteger,\n  SQLiteIntegerBuilder,\n  SQLiteTimestamp,\n  SQLiteTimestampBuilder,\n  int,\n  integer\n};\n//# sourceMappingURL=integer.js.map",
    "import { entityKind } from \"../../entity.js\";\nimport { getColumnNameAndConfig } from \"../../utils.js\";\nimport { SQLiteColumn, SQLiteColumnBuilder } from \"./common.js\";\nclass SQLiteNumericBuilder extends SQLiteColumnBuilder {\n  static [entityKind] = \"SQLiteNumericBuilder\";\n  constructor(name) {\n    super(name, \"string\", \"SQLiteNumeric\");\n  }\n  /** @internal */\n  build(table) {\n    return new SQLiteNumeric(\n      table,\n      this.config\n    );\n  }\n}\nclass SQLiteNumeric extends SQLiteColumn {\n  static [entityKind] = \"SQLiteNumeric\";\n  mapFromDriverValue(value) {\n    if (typeof value === \"string\") return value;\n    return String(value);\n  }\n  getSQLType() {\n    return \"numeric\";\n  }\n}\nclass SQLiteNumericNumberBuilder extends SQLiteColumnBuilder {\n  static [entityKind] = \"SQLiteNumericNumberBuilder\";\n  constructor(name) {\n    super(name, \"number\", \"SQLiteNumericNumber\");\n  }\n  /** @internal */\n  build(table) {\n    return new SQLiteNumericNumber(\n      table,\n      this.config\n    );\n  }\n}\nclass SQLiteNumericNumber extends SQLiteColumn {\n  static [entityKind] = \"SQLiteNumericNumber\";\n  mapFromDriverValue(value) {\n    if (typeof value === \"number\") return value;\n    return Number(value);\n  }\n  mapToDriverValue = String;\n  getSQLType() {\n    return \"numeric\";\n  }\n}\nclass SQLiteNumericBigIntBuilder extends SQLiteColumnBuilder {\n  static [entityKind] = \"SQLiteNumericBigIntBuilder\";\n  constructor(name) {\n    super(name, \"bigint\", \"SQLiteNumericBigInt\");\n  }\n  /** @internal */\n  build(table) {\n    return new SQLiteNumericBigInt(\n      table,\n      this.config\n    );\n  }\n}\nclass SQLiteNumericBigInt extends SQLiteColumn {\n  static [entityKind] = \"SQLiteNumericBigInt\";\n  mapFromDriverValue = BigInt;\n  mapToDriverValue = String;\n  getSQLType() {\n    return \"numeric\";\n  }\n}\nfunction numeric(a, b) {\n  const { name, config } = getColumnNameAndConfig(a, b);\n  const mode = config?.mode;\n  return mode === \"number\" ? new SQLiteNumericNumberBuilder(name) : mode === \"bigint\" ? new SQLiteNumericBigIntBuilder(name) : new SQLiteNumericBuilder(name);\n}\nexport {\n  SQLiteNumeric,\n  SQLiteNumericBigInt,\n  SQLiteNumericBigIntBuilder,\n  SQLiteNumericBuilder,\n  SQLiteNumericNumber,\n  SQLiteNumericNumberBuilder,\n  numeric\n};\n//# sourceMappingURL=numeric.js.map",
    "import { entityKind } from \"../../entity.js\";\nimport { SQLiteColumn, SQLiteColumnBuilder } from \"./common.js\";\nclass SQLiteRealBuilder extends SQLiteColumnBuilder {\n  static [entityKind] = \"SQLiteRealBuilder\";\n  constructor(name) {\n    super(name, \"number\", \"SQLiteReal\");\n  }\n  /** @internal */\n  build(table) {\n    return new SQLiteReal(table, this.config);\n  }\n}\nclass SQLiteReal extends SQLiteColumn {\n  static [entityKind] = \"SQLiteReal\";\n  getSQLType() {\n    return \"real\";\n  }\n}\nfunction real(name) {\n  return new SQLiteRealBuilder(name ?? \"\");\n}\nexport {\n  SQLiteReal,\n  SQLiteRealBuilder,\n  real\n};\n//# sourceMappingURL=real.js.map",
    "import { entityKind } from \"../../entity.js\";\nimport { getColumnNameAndConfig } from \"../../utils.js\";\nimport { SQLiteColumn, SQLiteColumnBuilder } from \"./common.js\";\nclass SQLiteTextBuilder extends SQLiteColumnBuilder {\n  static [entityKind] = \"SQLiteTextBuilder\";\n  constructor(name, config) {\n    super(name, \"string\", \"SQLiteText\");\n    this.config.enumValues = config.enum;\n    this.config.length = config.length;\n  }\n  /** @internal */\n  build(table) {\n    return new SQLiteText(\n      table,\n      this.config\n    );\n  }\n}\nclass SQLiteText extends SQLiteColumn {\n  static [entityKind] = \"SQLiteText\";\n  enumValues = this.config.enumValues;\n  length = this.config.length;\n  constructor(table, config) {\n    super(table, config);\n  }\n  getSQLType() {\n    return `text${this.config.length ? `(${this.config.length})` : \"\"}`;\n  }\n}\nclass SQLiteTextJsonBuilder extends SQLiteColumnBuilder {\n  static [entityKind] = \"SQLiteTextJsonBuilder\";\n  constructor(name) {\n    super(name, \"json\", \"SQLiteTextJson\");\n  }\n  /** @internal */\n  build(table) {\n    return new SQLiteTextJson(\n      table,\n      this.config\n    );\n  }\n}\nclass SQLiteTextJson extends SQLiteColumn {\n  static [entityKind] = \"SQLiteTextJson\";\n  getSQLType() {\n    return \"text\";\n  }\n  mapFromDriverValue(value) {\n    return JSON.parse(value);\n  }\n  mapToDriverValue(value) {\n    return JSON.stringify(value);\n  }\n}\nfunction text(a, b = {}) {\n  const { name, config } = getColumnNameAndConfig(a, b);\n  if (config.mode === \"json\") {\n    return new SQLiteTextJsonBuilder(name);\n  }\n  return new SQLiteTextBuilder(name, config);\n}\nexport {\n  SQLiteText,\n  SQLiteTextBuilder,\n  SQLiteTextJson,\n  SQLiteTextJsonBuilder,\n  text\n};\n//# sourceMappingURL=text.js.map",
    "import { ColumnAliasProxyHandler, TableAliasProxyHandler } from \"./alias.js\";\nimport { Column } from \"./column.js\";\nimport { entityKind, is } from \"./entity.js\";\nimport { SQL, View } from \"./sql/sql.js\";\nimport { Subquery } from \"./subquery.js\";\nimport { ViewBaseConfig } from \"./view-common.js\";\nclass SelectionProxyHandler {\n  static [entityKind] = \"SelectionProxyHandler\";\n  config;\n  constructor(config) {\n    this.config = { ...config };\n  }\n  get(subquery, prop) {\n    if (prop === \"_\") {\n      return {\n        ...subquery[\"_\"],\n        selectedFields: new Proxy(\n          subquery._.selectedFields,\n          this\n        )\n      };\n    }\n    if (prop === ViewBaseConfig) {\n      return {\n        ...subquery[ViewBaseConfig],\n        selectedFields: new Proxy(\n          subquery[ViewBaseConfig].selectedFields,\n          this\n        )\n      };\n    }\n    if (typeof prop === \"symbol\") {\n      return subquery[prop];\n    }\n    const columns = is(subquery, Subquery) ? subquery._.selectedFields : is(subquery, View) ? subquery[ViewBaseConfig].selectedFields : subquery;\n    const value = columns[prop];\n    if (is(value, SQL.Aliased)) {\n      if (this.config.sqlAliasedBehavior === \"sql\" && !value.isSelectionField) {\n        return value.sql;\n      }\n      const newValue = value.clone();\n      newValue.isSelectionField = true;\n      return newValue;\n    }\n    if (is(value, SQL)) {\n      if (this.config.sqlBehavior === \"sql\") {\n        return value;\n      }\n      throw new Error(\n        `You tried to reference \"${prop}\" field from a subquery, which is a raw SQL field, but it doesn't have an alias declared. Please add an alias to the field using \".as('alias')\" method.`\n      );\n    }\n    if (is(value, Column)) {\n      if (this.config.alias) {\n        return new Proxy(\n          value,\n          new ColumnAliasProxyHandler(\n            new Proxy(\n              value.table,\n              new TableAliasProxyHandler(this.config.alias, this.config.replaceOriginalName ?? false)\n            )\n          )\n        );\n      }\n      return value;\n    }\n    if (typeof value !== \"object\" || value === null) {\n      return value;\n    }\n    return new Proxy(value, new SelectionProxyHandler(this.config));\n  }\n}\nexport {\n  SelectionProxyHandler\n};\n//# sourceMappingURL=selection-proxy.js.map",
    "import { entityKind } from \"./entity.js\";\nclass QueryPromise {\n  static [entityKind] = \"QueryPromise\";\n  [Symbol.toStringTag] = \"QueryPromise\";\n  catch(onRejected) {\n    return this.then(void 0, onRejected);\n  }\n  finally(onFinally) {\n    return this.then(\n      (value) => {\n        onFinally?.();\n        return value;\n      },\n      (reason) => {\n        onFinally?.();\n        throw reason;\n      }\n    );\n  }\n  then(onFulfilled, onRejected) {\n    return this.execute().then(onFulfilled, onRejected);\n  }\n}\nexport {\n  QueryPromise\n};\n//# sourceMappingURL=query-promise.js.map",
    "import { blob } from \"./blob.js\";\nimport { customType } from \"./custom.js\";\nimport { integer } from \"./integer.js\";\nimport { numeric } from \"./numeric.js\";\nimport { real } from \"./real.js\";\nimport { text } from \"./text.js\";\nfunction getSQLiteColumnBuilders() {\n  return {\n    blob,\n    customType,\n    integer,\n    numeric,\n    real,\n    text\n  };\n}\nexport {\n  getSQLiteColumnBuilders\n};\n//# sourceMappingURL=all.js.map",
    "import { entityKind } from \"../entity.js\";\nimport { Table } from \"../table.js\";\nimport { getSQLiteColumnBuilders } from \"./columns/all.js\";\nconst InlineForeignKeys = Symbol.for(\"drizzle:SQLiteInlineForeignKeys\");\nclass SQLiteTable extends Table {\n  static [entityKind] = \"SQLiteTable\";\n  /** @internal */\n  static Symbol = Object.assign({}, Table.Symbol, {\n    InlineForeignKeys\n  });\n  /** @internal */\n  [Table.Symbol.Columns];\n  /** @internal */\n  [InlineForeignKeys] = [];\n  /** @internal */\n  [Table.Symbol.ExtraConfigBuilder] = void 0;\n}\nfunction sqliteTableBase(name, columns, extraConfig, schema, baseName = name) {\n  const rawTable = new SQLiteTable(name, schema, baseName);\n  const parsedColumns = typeof columns === \"function\" ? columns(getSQLiteColumnBuilders()) : columns;\n  const builtColumns = Object.fromEntries(\n    Object.entries(parsedColumns).map(([name2, colBuilderBase]) => {\n      const colBuilder = colBuilderBase;\n      colBuilder.setName(name2);\n      const column = colBuilder.build(rawTable);\n      rawTable[InlineForeignKeys].push(...colBuilder.buildForeignKeys(column, rawTable));\n      return [name2, column];\n    })\n  );\n  const table = Object.assign(rawTable, builtColumns);\n  table[Table.Symbol.Columns] = builtColumns;\n  table[Table.Symbol.ExtraConfigColumns] = builtColumns;\n  if (extraConfig) {\n    table[SQLiteTable.Symbol.ExtraConfigBuilder] = extraConfig;\n  }\n  return table;\n}\nconst sqliteTable = (name, columns, extraConfig) => {\n  return sqliteTableBase(name, columns, extraConfig);\n};\nfunction sqliteTableCreator(customizeTableName) {\n  return (name, columns, extraConfig) => {\n    return sqliteTableBase(customizeTableName(name), columns, extraConfig, void 0, name);\n  };\n}\nexport {\n  InlineForeignKeys,\n  SQLiteTable,\n  sqliteTable,\n  sqliteTableCreator\n};\n//# sourceMappingURL=table.js.map",
    "import { entityKind } from \"../entity.js\";\nclass IndexBuilderOn {\n  constructor(name, unique) {\n    this.name = name;\n    this.unique = unique;\n  }\n  static [entityKind] = \"SQLiteIndexBuilderOn\";\n  on(...columns) {\n    return new IndexBuilder(this.name, columns, this.unique);\n  }\n}\nclass IndexBuilder {\n  static [entityKind] = \"SQLiteIndexBuilder\";\n  /** @internal */\n  config;\n  constructor(name, columns, unique) {\n    this.config = {\n      name,\n      columns,\n      unique,\n      where: void 0\n    };\n  }\n  /**\n   * Condition for partial index.\n   */\n  where(condition) {\n    this.config.where = condition;\n    return this;\n  }\n  /** @internal */\n  build(table) {\n    return new Index(this.config, table);\n  }\n}\nclass Index {\n  static [entityKind] = \"SQLiteIndex\";\n  config;\n  constructor(config, table) {\n    this.config = { ...config, table };\n  }\n}\nfunction index(name) {\n  return new IndexBuilderOn(name, false);\n}\nfunction uniqueIndex(name) {\n  return new IndexBuilderOn(name, true);\n}\nexport {\n  Index,\n  IndexBuilder,\n  IndexBuilderOn,\n  index,\n  uniqueIndex\n};\n//# sourceMappingURL=indexes.js.map",
    "import { is } from \"../entity.js\";\nimport { SQL } from \"../sql/sql.js\";\nimport { Subquery } from \"../subquery.js\";\nimport { Table } from \"../table.js\";\nimport { ViewBaseConfig } from \"../view-common.js\";\nimport { CheckBuilder } from \"./checks.js\";\nimport { ForeignKeyBuilder } from \"./foreign-keys.js\";\nimport { IndexBuilder } from \"./indexes.js\";\nimport { PrimaryKeyBuilder } from \"./primary-keys.js\";\nimport { SQLiteTable } from \"./table.js\";\nimport { UniqueConstraintBuilder } from \"./unique-constraint.js\";\nfunction getTableConfig(table) {\n  const columns = Object.values(table[SQLiteTable.Symbol.Columns]);\n  const indexes = [];\n  const checks = [];\n  const primaryKeys = [];\n  const uniqueConstraints = [];\n  const foreignKeys = Object.values(table[SQLiteTable.Symbol.InlineForeignKeys]);\n  const name = table[Table.Symbol.Name];\n  const extraConfigBuilder = table[SQLiteTable.Symbol.ExtraConfigBuilder];\n  if (extraConfigBuilder !== void 0) {\n    const extraConfig = extraConfigBuilder(table[SQLiteTable.Symbol.Columns]);\n    const extraValues = Array.isArray(extraConfig) ? extraConfig.flat(1) : Object.values(extraConfig);\n    for (const builder of Object.values(extraValues)) {\n      if (is(builder, IndexBuilder)) {\n        indexes.push(builder.build(table));\n      } else if (is(builder, CheckBuilder)) {\n        checks.push(builder.build(table));\n      } else if (is(builder, UniqueConstraintBuilder)) {\n        uniqueConstraints.push(builder.build(table));\n      } else if (is(builder, PrimaryKeyBuilder)) {\n        primaryKeys.push(builder.build(table));\n      } else if (is(builder, ForeignKeyBuilder)) {\n        foreignKeys.push(builder.build(table));\n      }\n    }\n  }\n  return {\n    columns,\n    indexes,\n    foreignKeys,\n    checks,\n    primaryKeys,\n    uniqueConstraints,\n    name\n  };\n}\nfunction extractUsedTable(table) {\n  if (is(table, SQLiteTable)) {\n    return [`${table[Table.Symbol.BaseName]}`];\n  }\n  if (is(table, Subquery)) {\n    return table._.usedTables ?? [];\n  }\n  if (is(table, SQL)) {\n    return table.usedTables ?? [];\n  }\n  return [];\n}\nfunction getViewConfig(view) {\n  return {\n    ...view[ViewBaseConfig]\n    // ...view[SQLiteViewConfig],\n  };\n}\nexport {\n  extractUsedTable,\n  getTableConfig,\n  getViewConfig\n};\n//# sourceMappingURL=utils.js.map",
    "import { entityKind } from \"../../entity.js\";\nimport { QueryPromise } from \"../../query-promise.js\";\nimport { SelectionProxyHandler } from \"../../selection-proxy.js\";\nimport { SQLiteTable } from \"../table.js\";\nimport { Table } from \"../../table.js\";\nimport { orderSelectedFields } from \"../../utils.js\";\nimport { extractUsedTable } from \"../utils.js\";\nclass SQLiteDeleteBase extends QueryPromise {\n  constructor(table, session, dialect, withList) {\n    super();\n    this.table = table;\n    this.session = session;\n    this.dialect = dialect;\n    this.config = { table, withList };\n  }\n  static [entityKind] = \"SQLiteDelete\";\n  /** @internal */\n  config;\n  /**\n   * Adds a `where` clause to the query.\n   *\n   * Calling this method will delete only those rows that fulfill a specified condition.\n   *\n   * See docs: {@link https://orm.drizzle.team/docs/delete}\n   *\n   * @param where the `where` clause.\n   *\n   * @example\n   * You can use conditional operators and `sql function` to filter the rows to be deleted.\n   *\n   * ```ts\n   * // Delete all cars with green color\n   * db.delete(cars).where(eq(cars.color, 'green'));\n   * // or\n   * db.delete(cars).where(sql`${cars.color} = 'green'`)\n   * ```\n   *\n   * You can logically combine conditional operators with `and()` and `or()` operators:\n   *\n   * ```ts\n   * // Delete all BMW cars with a green color\n   * db.delete(cars).where(and(eq(cars.color, 'green'), eq(cars.brand, 'BMW')));\n   *\n   * // Delete all cars with the green or blue color\n   * db.delete(cars).where(or(eq(cars.color, 'green'), eq(cars.color, 'blue')));\n   * ```\n   */\n  where(where) {\n    this.config.where = where;\n    return this;\n  }\n  orderBy(...columns) {\n    if (typeof columns[0] === \"function\") {\n      const orderBy = columns[0](\n        new Proxy(\n          this.config.table[Table.Symbol.Columns],\n          new SelectionProxyHandler({ sqlAliasedBehavior: \"alias\", sqlBehavior: \"sql\" })\n        )\n      );\n      const orderByArray = Array.isArray(orderBy) ? orderBy : [orderBy];\n      this.config.orderBy = orderByArray;\n    } else {\n      const orderByArray = columns;\n      this.config.orderBy = orderByArray;\n    }\n    return this;\n  }\n  limit(limit) {\n    this.config.limit = limit;\n    return this;\n  }\n  returning(fields = this.table[SQLiteTable.Symbol.Columns]) {\n    this.config.returning = orderSelectedFields(fields);\n    return this;\n  }\n  /** @internal */\n  getSQL() {\n    return this.dialect.buildDeleteQuery(this.config);\n  }\n  toSQL() {\n    const { typings: _typings, ...rest } = this.dialect.sqlToQuery(this.getSQL());\n    return rest;\n  }\n  /** @internal */\n  _prepare(isOneTimeQuery = true) {\n    return this.session[isOneTimeQuery ? \"prepareOneTimeQuery\" : \"prepareQuery\"](\n      this.dialect.sqlToQuery(this.getSQL()),\n      this.config.returning,\n      this.config.returning ? \"all\" : \"run\",\n      true,\n      void 0,\n      {\n        type: \"delete\",\n        tables: extractUsedTable(this.config.table)\n      }\n    );\n  }\n  prepare() {\n    return this._prepare(false);\n  }\n  run = (placeholderValues) => {\n    return this._prepare().run(placeholderValues);\n  };\n  all = (placeholderValues) => {\n    return this._prepare().all(placeholderValues);\n  };\n  get = (placeholderValues) => {\n    return this._prepare().get(placeholderValues);\n  };\n  values = (placeholderValues) => {\n    return this._prepare().values(placeholderValues);\n  };\n  async execute(placeholderValues) {\n    return this._prepare().execute(placeholderValues);\n  }\n  $dynamic() {\n    return this;\n  }\n}\nexport {\n  SQLiteDeleteBase\n};\n//# sourceMappingURL=delete.js.map",
    "import { entityKind } from \"./entity.js\";\nimport { Table } from \"./table.js\";\nfunction toSnakeCase(input) {\n  const words = input.replace(/['\\u2019]/g, \"\").match(/[\\da-z]+|[A-Z]+(?![a-z])|[A-Z][\\da-z]+/g) ?? [];\n  return words.map((word) => word.toLowerCase()).join(\"_\");\n}\nfunction toCamelCase(input) {\n  const words = input.replace(/['\\u2019]/g, \"\").match(/[\\da-z]+|[A-Z]+(?![a-z])|[A-Z][\\da-z]+/g) ?? [];\n  return words.reduce((acc, word, i) => {\n    const formattedWord = i === 0 ? word.toLowerCase() : `${word[0].toUpperCase()}${word.slice(1)}`;\n    return acc + formattedWord;\n  }, \"\");\n}\nfunction noopCase(input) {\n  return input;\n}\nclass CasingCache {\n  static [entityKind] = \"CasingCache\";\n  /** @internal */\n  cache = {};\n  cachedTables = {};\n  convert;\n  constructor(casing) {\n    this.convert = casing === \"snake_case\" ? toSnakeCase : casing === \"camelCase\" ? toCamelCase : noopCase;\n  }\n  getColumnCasing(column) {\n    if (!column.keyAsName) return column.name;\n    const schema = column.table[Table.Symbol.Schema] ?? \"public\";\n    const tableName = column.table[Table.Symbol.OriginalName];\n    const key = `${schema}.${tableName}.${column.name}`;\n    if (!this.cache[key]) {\n      this.cacheTable(column.table);\n    }\n    return this.cache[key];\n  }\n  cacheTable(table) {\n    const schema = table[Table.Symbol.Schema] ?? \"public\";\n    const tableName = table[Table.Symbol.OriginalName];\n    const tableKey = `${schema}.${tableName}`;\n    if (!this.cachedTables[tableKey]) {\n      for (const column of Object.values(table[Table.Symbol.Columns])) {\n        const columnKey = `${tableKey}.${column.name}`;\n        this.cache[columnKey] = this.convert(column.name);\n      }\n      this.cachedTables[tableKey] = true;\n    }\n  }\n  clearCache() {\n    this.cache = {};\n    this.cachedTables = {};\n  }\n}\nexport {\n  CasingCache,\n  toCamelCase,\n  toSnakeCase\n};\n//# sourceMappingURL=casing.js.map",
    "import { entityKind } from \"./entity.js\";\nclass DrizzleError extends Error {\n  static [entityKind] = \"DrizzleError\";\n  constructor({ message, cause }) {\n    super(message);\n    this.name = \"DrizzleError\";\n    this.cause = cause;\n  }\n}\nclass DrizzleQueryError extends Error {\n  constructor(query, params, cause) {\n    super(`Failed query: ${query}\nparams: ${params}`);\n    this.query = query;\n    this.params = params;\n    this.cause = cause;\n    Error.captureStackTrace(this, DrizzleQueryError);\n    if (cause) this.cause = cause;\n  }\n}\nclass TransactionRollbackError extends DrizzleError {\n  static [entityKind] = \"TransactionRollbackError\";\n  constructor() {\n    super({ message: \"Rollback\" });\n  }\n}\nexport {\n  DrizzleError,\n  DrizzleQueryError,\n  TransactionRollbackError\n};\n//# sourceMappingURL=errors.js.map",
    "import { entityKind } from \"../entity.js\";\nimport { Table } from \"../table.js\";\nimport { getPgColumnBuilders } from \"./columns/all.js\";\nconst InlineForeignKeys = Symbol.for(\"drizzle:PgInlineForeignKeys\");\nconst EnableRLS = Symbol.for(\"drizzle:EnableRLS\");\nclass PgTable extends Table {\n  static [entityKind] = \"PgTable\";\n  /** @internal */\n  static Symbol = Object.assign({}, Table.Symbol, {\n    InlineForeignKeys,\n    EnableRLS\n  });\n  /**@internal */\n  [InlineForeignKeys] = [];\n  /** @internal */\n  [EnableRLS] = false;\n  /** @internal */\n  [Table.Symbol.ExtraConfigBuilder] = void 0;\n  /** @internal */\n  [Table.Symbol.ExtraConfigColumns] = {};\n}\nfunction pgTableWithSchema(name, columns, extraConfig, schema, baseName = name) {\n  const rawTable = new PgTable(name, schema, baseName);\n  const parsedColumns = typeof columns === \"function\" ? columns(getPgColumnBuilders()) : columns;\n  const builtColumns = Object.fromEntries(\n    Object.entries(parsedColumns).map(([name2, colBuilderBase]) => {\n      const colBuilder = colBuilderBase;\n      colBuilder.setName(name2);\n      const column = colBuilder.build(rawTable);\n      rawTable[InlineForeignKeys].push(...colBuilder.buildForeignKeys(column, rawTable));\n      return [name2, column];\n    })\n  );\n  const builtColumnsForExtraConfig = Object.fromEntries(\n    Object.entries(parsedColumns).map(([name2, colBuilderBase]) => {\n      const colBuilder = colBuilderBase;\n      colBuilder.setName(name2);\n      const column = colBuilder.buildExtraConfigColumn(rawTable);\n      return [name2, column];\n    })\n  );\n  const table = Object.assign(rawTable, builtColumns);\n  table[Table.Symbol.Columns] = builtColumns;\n  table[Table.Symbol.ExtraConfigColumns] = builtColumnsForExtraConfig;\n  if (extraConfig) {\n    table[PgTable.Symbol.ExtraConfigBuilder] = extraConfig;\n  }\n  return Object.assign(table, {\n    enableRLS: () => {\n      table[PgTable.Symbol.EnableRLS] = true;\n      return table;\n    }\n  });\n}\nconst pgTable = (name, columns, extraConfig) => {\n  return pgTableWithSchema(name, columns, extraConfig, void 0);\n};\nfunction pgTableCreator(customizeTableName) {\n  return (name, columns, extraConfig) => {\n    return pgTableWithSchema(customizeTableName(name), columns, extraConfig, void 0, name);\n  };\n}\nexport {\n  EnableRLS,\n  InlineForeignKeys,\n  PgTable,\n  pgTable,\n  pgTableCreator,\n  pgTableWithSchema\n};\n//# sourceMappingURL=table.js.map",
    "import { entityKind } from \"../entity.js\";\nimport { PgTable } from \"./table.js\";\nfunction primaryKey(...config) {\n  if (config[0].columns) {\n    return new PrimaryKeyBuilder(config[0].columns, config[0].name);\n  }\n  return new PrimaryKeyBuilder(config);\n}\nclass PrimaryKeyBuilder {\n  static [entityKind] = \"PgPrimaryKeyBuilder\";\n  /** @internal */\n  columns;\n  /** @internal */\n  name;\n  constructor(columns, name) {\n    this.columns = columns;\n    this.name = name;\n  }\n  /** @internal */\n  build(table) {\n    return new PrimaryKey(table, this.columns, this.name);\n  }\n}\nclass PrimaryKey {\n  constructor(table, columns, name) {\n    this.table = table;\n    this.columns = columns;\n    this.name = name;\n  }\n  static [entityKind] = \"PgPrimaryKey\";\n  columns;\n  name;\n  getName() {\n    return this.name ?? `${this.table[PgTable.Symbol.Name]}_${this.columns.map((column) => column.name).join(\"_\")}_pk`;\n  }\n}\nexport {\n  PrimaryKey,\n  PrimaryKeyBuilder,\n  primaryKey\n};\n//# sourceMappingURL=primary-keys.js.map",
    "import { Column } from \"../../column.js\";\nimport { is } from \"../../entity.js\";\nimport { Table } from \"../../table.js\";\nimport {\n  isDriverValueEncoder,\n  isSQLWrapper,\n  Param,\n  Placeholder,\n  SQL,\n  sql,\n  StringChunk,\n  View\n} from \"../sql.js\";\nfunction bindIfParam(value, column) {\n  if (isDriverValueEncoder(column) && !isSQLWrapper(value) && !is(value, Param) && !is(value, Placeholder) && !is(value, Column) && !is(value, Table) && !is(value, View)) {\n    return new Param(value, column);\n  }\n  return value;\n}\nconst eq = (left, right) => {\n  return sql`${left} = ${bindIfParam(right, left)}`;\n};\nconst ne = (left, right) => {\n  return sql`${left} <> ${bindIfParam(right, left)}`;\n};\nfunction and(...unfilteredConditions) {\n  const conditions = unfilteredConditions.filter(\n    (c) => c !== void 0\n  );\n  if (conditions.length === 0) {\n    return void 0;\n  }\n  if (conditions.length === 1) {\n    return new SQL(conditions);\n  }\n  return new SQL([\n    new StringChunk(\"(\"),\n    sql.join(conditions, new StringChunk(\" and \")),\n    new StringChunk(\")\")\n  ]);\n}\nfunction or(...unfilteredConditions) {\n  const conditions = unfilteredConditions.filter(\n    (c) => c !== void 0\n  );\n  if (conditions.length === 0) {\n    return void 0;\n  }\n  if (conditions.length === 1) {\n    return new SQL(conditions);\n  }\n  return new SQL([\n    new StringChunk(\"(\"),\n    sql.join(conditions, new StringChunk(\" or \")),\n    new StringChunk(\")\")\n  ]);\n}\nfunction not(condition) {\n  return sql`not ${condition}`;\n}\nconst gt = (left, right) => {\n  return sql`${left} > ${bindIfParam(right, left)}`;\n};\nconst gte = (left, right) => {\n  return sql`${left} >= ${bindIfParam(right, left)}`;\n};\nconst lt = (left, right) => {\n  return sql`${left} < ${bindIfParam(right, left)}`;\n};\nconst lte = (left, right) => {\n  return sql`${left} <= ${bindIfParam(right, left)}`;\n};\nfunction inArray(column, values) {\n  if (Array.isArray(values)) {\n    if (values.length === 0) {\n      return sql`false`;\n    }\n    return sql`${column} in ${values.map((v) => bindIfParam(v, column))}`;\n  }\n  return sql`${column} in ${bindIfParam(values, column)}`;\n}\nfunction notInArray(column, values) {\n  if (Array.isArray(values)) {\n    if (values.length === 0) {\n      return sql`true`;\n    }\n    return sql`${column} not in ${values.map((v) => bindIfParam(v, column))}`;\n  }\n  return sql`${column} not in ${bindIfParam(values, column)}`;\n}\nfunction isNull(value) {\n  return sql`${value} is null`;\n}\nfunction isNotNull(value) {\n  return sql`${value} is not null`;\n}\nfunction exists(subquery) {\n  return sql`exists ${subquery}`;\n}\nfunction notExists(subquery) {\n  return sql`not exists ${subquery}`;\n}\nfunction between(column, min, max) {\n  return sql`${column} between ${bindIfParam(min, column)} and ${bindIfParam(\n    max,\n    column\n  )}`;\n}\nfunction notBetween(column, min, max) {\n  return sql`${column} not between ${bindIfParam(\n    min,\n    column\n  )} and ${bindIfParam(max, column)}`;\n}\nfunction like(column, value) {\n  return sql`${column} like ${value}`;\n}\nfunction notLike(column, value) {\n  return sql`${column} not like ${value}`;\n}\nfunction ilike(column, value) {\n  return sql`${column} ilike ${value}`;\n}\nfunction notIlike(column, value) {\n  return sql`${column} not ilike ${value}`;\n}\nfunction arrayContains(column, values) {\n  if (Array.isArray(values)) {\n    if (values.length === 0) {\n      throw new Error(\"arrayContains requires at least one value\");\n    }\n    const array = sql`${bindIfParam(values, column)}`;\n    return sql`${column} @> ${array}`;\n  }\n  return sql`${column} @> ${bindIfParam(values, column)}`;\n}\nfunction arrayContained(column, values) {\n  if (Array.isArray(values)) {\n    if (values.length === 0) {\n      throw new Error(\"arrayContained requires at least one value\");\n    }\n    const array = sql`${bindIfParam(values, column)}`;\n    return sql`${column} <@ ${array}`;\n  }\n  return sql`${column} <@ ${bindIfParam(values, column)}`;\n}\nfunction arrayOverlaps(column, values) {\n  if (Array.isArray(values)) {\n    if (values.length === 0) {\n      throw new Error(\"arrayOverlaps requires at least one value\");\n    }\n    const array = sql`${bindIfParam(values, column)}`;\n    return sql`${column} && ${array}`;\n  }\n  return sql`${column} && ${bindIfParam(values, column)}`;\n}\nexport {\n  and,\n  arrayContained,\n  arrayContains,\n  arrayOverlaps,\n  between,\n  bindIfParam,\n  eq,\n  exists,\n  gt,\n  gte,\n  ilike,\n  inArray,\n  isNotNull,\n  isNull,\n  like,\n  lt,\n  lte,\n  ne,\n  not,\n  notBetween,\n  notExists,\n  notIlike,\n  notInArray,\n  notLike,\n  or\n};\n//# sourceMappingURL=conditions.js.map",
    "import { sql } from \"../sql.js\";\nfunction asc(column) {\n  return sql`${column} asc`;\n}\nfunction desc(column) {\n  return sql`${column} desc`;\n}\nexport {\n  asc,\n  desc\n};\n//# sourceMappingURL=select.js.map",
    "import { getTableUniqueName, Table } from \"./table.js\";\nimport { Column } from \"./column.js\";\nimport { entityKind, is } from \"./entity.js\";\nimport { PrimaryKeyBuilder } from \"./pg-core/primary-keys.js\";\nimport {\n  and,\n  asc,\n  between,\n  desc,\n  eq,\n  exists,\n  gt,\n  gte,\n  ilike,\n  inArray,\n  isNotNull,\n  isNull,\n  like,\n  lt,\n  lte,\n  ne,\n  not,\n  notBetween,\n  notExists,\n  notIlike,\n  notInArray,\n  notLike,\n  or\n} from \"./sql/expressions/index.js\";\nimport { SQL, sql } from \"./sql/sql.js\";\nclass Relation {\n  constructor(sourceTable, referencedTable, relationName) {\n    this.sourceTable = sourceTable;\n    this.referencedTable = referencedTable;\n    this.relationName = relationName;\n    this.referencedTableName = referencedTable[Table.Symbol.Name];\n  }\n  static [entityKind] = \"Relation\";\n  referencedTableName;\n  fieldName;\n}\nclass Relations {\n  constructor(table, config) {\n    this.table = table;\n    this.config = config;\n  }\n  static [entityKind] = \"Relations\";\n}\nclass One extends Relation {\n  constructor(sourceTable, referencedTable, config, isNullable) {\n    super(sourceTable, referencedTable, config?.relationName);\n    this.config = config;\n    this.isNullable = isNullable;\n  }\n  static [entityKind] = \"One\";\n  withFieldName(fieldName) {\n    const relation = new One(\n      this.sourceTable,\n      this.referencedTable,\n      this.config,\n      this.isNullable\n    );\n    relation.fieldName = fieldName;\n    return relation;\n  }\n}\nclass Many extends Relation {\n  constructor(sourceTable, referencedTable, config) {\n    super(sourceTable, referencedTable, config?.relationName);\n    this.config = config;\n  }\n  static [entityKind] = \"Many\";\n  withFieldName(fieldName) {\n    const relation = new Many(\n      this.sourceTable,\n      this.referencedTable,\n      this.config\n    );\n    relation.fieldName = fieldName;\n    return relation;\n  }\n}\nfunction getOperators() {\n  return {\n    and,\n    between,\n    eq,\n    exists,\n    gt,\n    gte,\n    ilike,\n    inArray,\n    isNull,\n    isNotNull,\n    like,\n    lt,\n    lte,\n    ne,\n    not,\n    notBetween,\n    notExists,\n    notLike,\n    notIlike,\n    notInArray,\n    or,\n    sql\n  };\n}\nfunction getOrderByOperators() {\n  return {\n    sql,\n    asc,\n    desc\n  };\n}\nfunction extractTablesRelationalConfig(schema, configHelpers) {\n  if (Object.keys(schema).length === 1 && \"default\" in schema && !is(schema[\"default\"], Table)) {\n    schema = schema[\"default\"];\n  }\n  const tableNamesMap = {};\n  const relationsBuffer = {};\n  const tablesConfig = {};\n  for (const [key, value] of Object.entries(schema)) {\n    if (is(value, Table)) {\n      const dbName = getTableUniqueName(value);\n      const bufferedRelations = relationsBuffer[dbName];\n      tableNamesMap[dbName] = key;\n      tablesConfig[key] = {\n        tsName: key,\n        dbName: value[Table.Symbol.Name],\n        schema: value[Table.Symbol.Schema],\n        columns: value[Table.Symbol.Columns],\n        relations: bufferedRelations?.relations ?? {},\n        primaryKey: bufferedRelations?.primaryKey ?? []\n      };\n      for (const column of Object.values(\n        value[Table.Symbol.Columns]\n      )) {\n        if (column.primary) {\n          tablesConfig[key].primaryKey.push(column);\n        }\n      }\n      const extraConfig = value[Table.Symbol.ExtraConfigBuilder]?.(value[Table.Symbol.ExtraConfigColumns]);\n      if (extraConfig) {\n        for (const configEntry of Object.values(extraConfig)) {\n          if (is(configEntry, PrimaryKeyBuilder)) {\n            tablesConfig[key].primaryKey.push(...configEntry.columns);\n          }\n        }\n      }\n    } else if (is(value, Relations)) {\n      const dbName = getTableUniqueName(value.table);\n      const tableName = tableNamesMap[dbName];\n      const relations2 = value.config(\n        configHelpers(value.table)\n      );\n      let primaryKey;\n      for (const [relationName, relation] of Object.entries(relations2)) {\n        if (tableName) {\n          const tableConfig = tablesConfig[tableName];\n          tableConfig.relations[relationName] = relation;\n          if (primaryKey) {\n            tableConfig.primaryKey.push(...primaryKey);\n          }\n        } else {\n          if (!(dbName in relationsBuffer)) {\n            relationsBuffer[dbName] = {\n              relations: {},\n              primaryKey\n            };\n          }\n          relationsBuffer[dbName].relations[relationName] = relation;\n        }\n      }\n    }\n  }\n  return { tables: tablesConfig, tableNamesMap };\n}\nfunction relations(table, relations2) {\n  return new Relations(\n    table,\n    (helpers) => Object.fromEntries(\n      Object.entries(relations2(helpers)).map(([key, value]) => [\n        key,\n        value.withFieldName(key)\n      ])\n    )\n  );\n}\nfunction createOne(sourceTable) {\n  return function one(table, config) {\n    return new One(\n      sourceTable,\n      table,\n      config,\n      config?.fields.reduce((res, f) => res && f.notNull, true) ?? false\n    );\n  };\n}\nfunction createMany(sourceTable) {\n  return function many(referencedTable, config) {\n    return new Many(sourceTable, referencedTable, config);\n  };\n}\nfunction normalizeRelation(schema, tableNamesMap, relation) {\n  if (is(relation, One) && relation.config) {\n    return {\n      fields: relation.config.fields,\n      references: relation.config.references\n    };\n  }\n  const referencedTableTsName = tableNamesMap[getTableUniqueName(relation.referencedTable)];\n  if (!referencedTableTsName) {\n    throw new Error(\n      `Table \"${relation.referencedTable[Table.Symbol.Name]}\" not found in schema`\n    );\n  }\n  const referencedTableConfig = schema[referencedTableTsName];\n  if (!referencedTableConfig) {\n    throw new Error(`Table \"${referencedTableTsName}\" not found in schema`);\n  }\n  const sourceTable = relation.sourceTable;\n  const sourceTableTsName = tableNamesMap[getTableUniqueName(sourceTable)];\n  if (!sourceTableTsName) {\n    throw new Error(\n      `Table \"${sourceTable[Table.Symbol.Name]}\" not found in schema`\n    );\n  }\n  const reverseRelations = [];\n  for (const referencedTableRelation of Object.values(\n    referencedTableConfig.relations\n  )) {\n    if (relation.relationName && relation !== referencedTableRelation && referencedTableRelation.relationName === relation.relationName || !relation.relationName && referencedTableRelation.referencedTable === relation.sourceTable) {\n      reverseRelations.push(referencedTableRelation);\n    }\n  }\n  if (reverseRelations.length > 1) {\n    throw relation.relationName ? new Error(\n      `There are multiple relations with name \"${relation.relationName}\" in table \"${referencedTableTsName}\"`\n    ) : new Error(\n      `There are multiple relations between \"${referencedTableTsName}\" and \"${relation.sourceTable[Table.Symbol.Name]}\". Please specify relation name`\n    );\n  }\n  if (reverseRelations[0] && is(reverseRelations[0], One) && reverseRelations[0].config) {\n    return {\n      fields: reverseRelations[0].config.references,\n      references: reverseRelations[0].config.fields\n    };\n  }\n  throw new Error(\n    `There is not enough information to infer relation \"${sourceTableTsName}.${relation.fieldName}\"`\n  );\n}\nfunction createTableRelationsHelpers(sourceTable) {\n  return {\n    one: createOne(sourceTable),\n    many: createMany(sourceTable)\n  };\n}\nfunction mapRelationalRow(tablesConfig, tableConfig, row, buildQueryResultSelection, mapColumnValue = (value) => value) {\n  const result = {};\n  for (const [\n    selectionItemIndex,\n    selectionItem\n  ] of buildQueryResultSelection.entries()) {\n    if (selectionItem.isJson) {\n      const relation = tableConfig.relations[selectionItem.tsKey];\n      const rawSubRows = row[selectionItemIndex];\n      const subRows = typeof rawSubRows === \"string\" ? JSON.parse(rawSubRows) : rawSubRows;\n      result[selectionItem.tsKey] = is(relation, One) ? subRows && mapRelationalRow(\n        tablesConfig,\n        tablesConfig[selectionItem.relationTableTsKey],\n        subRows,\n        selectionItem.selection,\n        mapColumnValue\n      ) : subRows.map(\n        (subRow) => mapRelationalRow(\n          tablesConfig,\n          tablesConfig[selectionItem.relationTableTsKey],\n          subRow,\n          selectionItem.selection,\n          mapColumnValue\n        )\n      );\n    } else {\n      const value = mapColumnValue(row[selectionItemIndex]);\n      const field = selectionItem.field;\n      let decoder;\n      if (is(field, Column)) {\n        decoder = field;\n      } else if (is(field, SQL)) {\n        decoder = field.decoder;\n      } else {\n        decoder = field.sql.decoder;\n      }\n      result[selectionItem.tsKey] = value === null ? null : decoder.mapFromDriverValue(value);\n    }\n  }\n  return result;\n}\nexport {\n  Many,\n  One,\n  Relation,\n  Relations,\n  createMany,\n  createOne,\n  createTableRelationsHelpers,\n  extractTablesRelationalConfig,\n  getOperators,\n  getOrderByOperators,\n  mapRelationalRow,\n  normalizeRelation,\n  relations\n};\n//# sourceMappingURL=relations.js.map",
    "import { entityKind } from \"../entity.js\";\nimport { View } from \"../sql/sql.js\";\nclass SQLiteViewBase extends View {\n  static [entityKind] = \"SQLiteViewBase\";\n}\nexport {\n  SQLiteViewBase\n};\n//# sourceMappingURL=view-base.js.map",
    "import { aliasedTable, aliasedTableColumn, mapColumnsInAliasedSQLToAlias, mapColumnsInSQLToAlias } from \"../alias.js\";\nimport { CasingCache } from \"../casing.js\";\nimport { Column } from \"../column.js\";\nimport { entityKind, is } from \"../entity.js\";\nimport { DrizzleError } from \"../errors.js\";\nimport {\n  getOperators,\n  getOrderByOperators,\n  Many,\n  normalizeRelation,\n  One\n} from \"../relations.js\";\nimport { and, eq } from \"../sql/index.js\";\nimport { Param, SQL, sql } from \"../sql/sql.js\";\nimport { SQLiteColumn } from \"./columns/index.js\";\nimport { SQLiteTable } from \"./table.js\";\nimport { Subquery } from \"../subquery.js\";\nimport { getTableName, getTableUniqueName, Table } from \"../table.js\";\nimport { orderSelectedFields } from \"../utils.js\";\nimport { ViewBaseConfig } from \"../view-common.js\";\nimport { SQLiteViewBase } from \"./view-base.js\";\nclass SQLiteDialect {\n  static [entityKind] = \"SQLiteDialect\";\n  /** @internal */\n  casing;\n  constructor(config) {\n    this.casing = new CasingCache(config?.casing);\n  }\n  escapeName(name) {\n    return `\"${name}\"`;\n  }\n  escapeParam(_num) {\n    return \"?\";\n  }\n  escapeString(str) {\n    return `'${str.replace(/'/g, \"''\")}'`;\n  }\n  buildWithCTE(queries) {\n    if (!queries?.length) return void 0;\n    const withSqlChunks = [sql`with `];\n    for (const [i, w] of queries.entries()) {\n      withSqlChunks.push(sql`${sql.identifier(w._.alias)} as (${w._.sql})`);\n      if (i < queries.length - 1) {\n        withSqlChunks.push(sql`, `);\n      }\n    }\n    withSqlChunks.push(sql` `);\n    return sql.join(withSqlChunks);\n  }\n  buildDeleteQuery({ table, where, returning, withList, limit, orderBy }) {\n    const withSql = this.buildWithCTE(withList);\n    const returningSql = returning ? sql` returning ${this.buildSelection(returning, { isSingleTable: true })}` : void 0;\n    const whereSql = where ? sql` where ${where}` : void 0;\n    const orderBySql = this.buildOrderBy(orderBy);\n    const limitSql = this.buildLimit(limit);\n    return sql`${withSql}delete from ${table}${whereSql}${returningSql}${orderBySql}${limitSql}`;\n  }\n  buildUpdateSet(table, set) {\n    const tableColumns = table[Table.Symbol.Columns];\n    const columnNames = Object.keys(tableColumns).filter(\n      (colName) => set[colName] !== void 0 || tableColumns[colName]?.onUpdateFn !== void 0\n    );\n    const setSize = columnNames.length;\n    return sql.join(columnNames.flatMap((colName, i) => {\n      const col = tableColumns[colName];\n      const value = set[colName] ?? sql.param(col.onUpdateFn(), col);\n      const res = sql`${sql.identifier(this.casing.getColumnCasing(col))} = ${value}`;\n      if (i < setSize - 1) {\n        return [res, sql.raw(\", \")];\n      }\n      return [res];\n    }));\n  }\n  buildUpdateQuery({ table, set, where, returning, withList, joins, from, limit, orderBy }) {\n    const withSql = this.buildWithCTE(withList);\n    const setSql = this.buildUpdateSet(table, set);\n    const fromSql = from && sql.join([sql.raw(\" from \"), this.buildFromTable(from)]);\n    const joinsSql = this.buildJoins(joins);\n    const returningSql = returning ? sql` returning ${this.buildSelection(returning, { isSingleTable: true })}` : void 0;\n    const whereSql = where ? sql` where ${where}` : void 0;\n    const orderBySql = this.buildOrderBy(orderBy);\n    const limitSql = this.buildLimit(limit);\n    return sql`${withSql}update ${table} set ${setSql}${fromSql}${joinsSql}${whereSql}${returningSql}${orderBySql}${limitSql}`;\n  }\n  /**\n   * Builds selection SQL with provided fields/expressions\n   *\n   * Examples:\n   *\n   * `select <selection> from`\n   *\n   * `insert ... returning <selection>`\n   *\n   * If `isSingleTable` is true, then columns won't be prefixed with table name\n   */\n  buildSelection(fields, { isSingleTable = false } = {}) {\n    const columnsLen = fields.length;\n    const chunks = fields.flatMap(({ field }, i) => {\n      const chunk = [];\n      if (is(field, SQL.Aliased) && field.isSelectionField) {\n        chunk.push(sql.identifier(field.fieldAlias));\n      } else if (is(field, SQL.Aliased) || is(field, SQL)) {\n        const query = is(field, SQL.Aliased) ? field.sql : field;\n        if (isSingleTable) {\n          chunk.push(\n            new SQL(\n              query.queryChunks.map((c) => {\n                if (is(c, Column)) {\n                  return sql.identifier(this.casing.getColumnCasing(c));\n                }\n                return c;\n              })\n            )\n          );\n        } else {\n          chunk.push(query);\n        }\n        if (is(field, SQL.Aliased)) {\n          chunk.push(sql` as ${sql.identifier(field.fieldAlias)}`);\n        }\n      } else if (is(field, Column)) {\n        const tableName = field.table[Table.Symbol.Name];\n        if (field.columnType === \"SQLiteNumericBigInt\") {\n          if (isSingleTable) {\n            chunk.push(sql`cast(${sql.identifier(this.casing.getColumnCasing(field))} as text)`);\n          } else {\n            chunk.push(\n              sql`cast(${sql.identifier(tableName)}.${sql.identifier(this.casing.getColumnCasing(field))} as text)`\n            );\n          }\n        } else {\n          if (isSingleTable) {\n            chunk.push(sql.identifier(this.casing.getColumnCasing(field)));\n          } else {\n            chunk.push(sql`${sql.identifier(tableName)}.${sql.identifier(this.casing.getColumnCasing(field))}`);\n          }\n        }\n      }\n      if (i < columnsLen - 1) {\n        chunk.push(sql`, `);\n      }\n      return chunk;\n    });\n    return sql.join(chunks);\n  }\n  buildJoins(joins) {\n    if (!joins || joins.length === 0) {\n      return void 0;\n    }\n    const joinsArray = [];\n    if (joins) {\n      for (const [index, joinMeta] of joins.entries()) {\n        if (index === 0) {\n          joinsArray.push(sql` `);\n        }\n        const table = joinMeta.table;\n        const onSql = joinMeta.on ? sql` on ${joinMeta.on}` : void 0;\n        if (is(table, SQLiteTable)) {\n          const tableName = table[SQLiteTable.Symbol.Name];\n          const tableSchema = table[SQLiteTable.Symbol.Schema];\n          const origTableName = table[SQLiteTable.Symbol.OriginalName];\n          const alias = tableName === origTableName ? void 0 : joinMeta.alias;\n          joinsArray.push(\n            sql`${sql.raw(joinMeta.joinType)} join ${tableSchema ? sql`${sql.identifier(tableSchema)}.` : void 0}${sql.identifier(origTableName)}${alias && sql` ${sql.identifier(alias)}`}${onSql}`\n          );\n        } else {\n          joinsArray.push(\n            sql`${sql.raw(joinMeta.joinType)} join ${table}${onSql}`\n          );\n        }\n        if (index < joins.length - 1) {\n          joinsArray.push(sql` `);\n        }\n      }\n    }\n    return sql.join(joinsArray);\n  }\n  buildLimit(limit) {\n    return typeof limit === \"object\" || typeof limit === \"number\" && limit >= 0 ? sql` limit ${limit}` : void 0;\n  }\n  buildOrderBy(orderBy) {\n    const orderByList = [];\n    if (orderBy) {\n      for (const [index, orderByValue] of orderBy.entries()) {\n        orderByList.push(orderByValue);\n        if (index < orderBy.length - 1) {\n          orderByList.push(sql`, `);\n        }\n      }\n    }\n    return orderByList.length > 0 ? sql` order by ${sql.join(orderByList)}` : void 0;\n  }\n  buildFromTable(table) {\n    if (is(table, Table) && table[Table.Symbol.IsAlias]) {\n      return sql`${sql`${sql.identifier(table[Table.Symbol.Schema] ?? \"\")}.`.if(table[Table.Symbol.Schema])}${sql.identifier(table[Table.Symbol.OriginalName])} ${sql.identifier(table[Table.Symbol.Name])}`;\n    }\n    return table;\n  }\n  buildSelectQuery({\n    withList,\n    fields,\n    fieldsFlat,\n    where,\n    having,\n    table,\n    joins,\n    orderBy,\n    groupBy,\n    limit,\n    offset,\n    distinct,\n    setOperators\n  }) {\n    const fieldsList = fieldsFlat ?? orderSelectedFields(fields);\n    for (const f of fieldsList) {\n      if (is(f.field, Column) && getTableName(f.field.table) !== (is(table, Subquery) ? table._.alias : is(table, SQLiteViewBase) ? table[ViewBaseConfig].name : is(table, SQL) ? void 0 : getTableName(table)) && !((table2) => joins?.some(\n        ({ alias }) => alias === (table2[Table.Symbol.IsAlias] ? getTableName(table2) : table2[Table.Symbol.BaseName])\n      ))(f.field.table)) {\n        const tableName = getTableName(f.field.table);\n        throw new Error(\n          `Your \"${f.path.join(\"->\")}\" field references a column \"${tableName}\".\"${f.field.name}\", but the table \"${tableName}\" is not part of the query! Did you forget to join it?`\n        );\n      }\n    }\n    const isSingleTable = !joins || joins.length === 0;\n    const withSql = this.buildWithCTE(withList);\n    const distinctSql = distinct ? sql` distinct` : void 0;\n    const selection = this.buildSelection(fieldsList, { isSingleTable });\n    const tableSql = this.buildFromTable(table);\n    const joinsSql = this.buildJoins(joins);\n    const whereSql = where ? sql` where ${where}` : void 0;\n    const havingSql = having ? sql` having ${having}` : void 0;\n    const groupByList = [];\n    if (groupBy) {\n      for (const [index, groupByValue] of groupBy.entries()) {\n        groupByList.push(groupByValue);\n        if (index < groupBy.length - 1) {\n          groupByList.push(sql`, `);\n        }\n      }\n    }\n    const groupBySql = groupByList.length > 0 ? sql` group by ${sql.join(groupByList)}` : void 0;\n    const orderBySql = this.buildOrderBy(orderBy);\n    const limitSql = this.buildLimit(limit);\n    const offsetSql = offset ? sql` offset ${offset}` : void 0;\n    const finalQuery = sql`${withSql}select${distinctSql} ${selection} from ${tableSql}${joinsSql}${whereSql}${groupBySql}${havingSql}${orderBySql}${limitSql}${offsetSql}`;\n    if (setOperators.length > 0) {\n      return this.buildSetOperations(finalQuery, setOperators);\n    }\n    return finalQuery;\n  }\n  buildSetOperations(leftSelect, setOperators) {\n    const [setOperator, ...rest] = setOperators;\n    if (!setOperator) {\n      throw new Error(\"Cannot pass undefined values to any set operator\");\n    }\n    if (rest.length === 0) {\n      return this.buildSetOperationQuery({ leftSelect, setOperator });\n    }\n    return this.buildSetOperations(\n      this.buildSetOperationQuery({ leftSelect, setOperator }),\n      rest\n    );\n  }\n  buildSetOperationQuery({\n    leftSelect,\n    setOperator: { type, isAll, rightSelect, limit, orderBy, offset }\n  }) {\n    const leftChunk = sql`${leftSelect.getSQL()} `;\n    const rightChunk = sql`${rightSelect.getSQL()}`;\n    let orderBySql;\n    if (orderBy && orderBy.length > 0) {\n      const orderByValues = [];\n      for (const singleOrderBy of orderBy) {\n        if (is(singleOrderBy, SQLiteColumn)) {\n          orderByValues.push(sql.identifier(singleOrderBy.name));\n        } else if (is(singleOrderBy, SQL)) {\n          for (let i = 0; i < singleOrderBy.queryChunks.length; i++) {\n            const chunk = singleOrderBy.queryChunks[i];\n            if (is(chunk, SQLiteColumn)) {\n              singleOrderBy.queryChunks[i] = sql.identifier(this.casing.getColumnCasing(chunk));\n            }\n          }\n          orderByValues.push(sql`${singleOrderBy}`);\n        } else {\n          orderByValues.push(sql`${singleOrderBy}`);\n        }\n      }\n      orderBySql = sql` order by ${sql.join(orderByValues, sql`, `)}`;\n    }\n    const limitSql = typeof limit === \"object\" || typeof limit === \"number\" && limit >= 0 ? sql` limit ${limit}` : void 0;\n    const operatorChunk = sql.raw(`${type} ${isAll ? \"all \" : \"\"}`);\n    const offsetSql = offset ? sql` offset ${offset}` : void 0;\n    return sql`${leftChunk}${operatorChunk}${rightChunk}${orderBySql}${limitSql}${offsetSql}`;\n  }\n  buildInsertQuery({ table, values: valuesOrSelect, onConflict, returning, withList, select }) {\n    const valuesSqlList = [];\n    const columns = table[Table.Symbol.Columns];\n    const colEntries = Object.entries(columns).filter(\n      ([_, col]) => !col.shouldDisableInsert()\n    );\n    const insertOrder = colEntries.map(([, column]) => sql.identifier(this.casing.getColumnCasing(column)));\n    if (select) {\n      const select2 = valuesOrSelect;\n      if (is(select2, SQL)) {\n        valuesSqlList.push(select2);\n      } else {\n        valuesSqlList.push(select2.getSQL());\n      }\n    } else {\n      const values = valuesOrSelect;\n      valuesSqlList.push(sql.raw(\"values \"));\n      for (const [valueIndex, value] of values.entries()) {\n        const valueList = [];\n        for (const [fieldName, col] of colEntries) {\n          const colValue = value[fieldName];\n          if (colValue === void 0 || is(colValue, Param) && colValue.value === void 0) {\n            let defaultValue;\n            if (col.default !== null && col.default !== void 0) {\n              defaultValue = is(col.default, SQL) ? col.default : sql.param(col.default, col);\n            } else if (col.defaultFn !== void 0) {\n              const defaultFnResult = col.defaultFn();\n              defaultValue = is(defaultFnResult, SQL) ? defaultFnResult : sql.param(defaultFnResult, col);\n            } else if (!col.default && col.onUpdateFn !== void 0) {\n              const onUpdateFnResult = col.onUpdateFn();\n              defaultValue = is(onUpdateFnResult, SQL) ? onUpdateFnResult : sql.param(onUpdateFnResult, col);\n            } else {\n              defaultValue = sql`null`;\n            }\n            valueList.push(defaultValue);\n          } else {\n            valueList.push(colValue);\n          }\n        }\n        valuesSqlList.push(valueList);\n        if (valueIndex < values.length - 1) {\n          valuesSqlList.push(sql`, `);\n        }\n      }\n    }\n    const withSql = this.buildWithCTE(withList);\n    const valuesSql = sql.join(valuesSqlList);\n    const returningSql = returning ? sql` returning ${this.buildSelection(returning, { isSingleTable: true })}` : void 0;\n    const onConflictSql = onConflict?.length ? sql.join(onConflict) : void 0;\n    return sql`${withSql}insert into ${table} ${insertOrder} ${valuesSql}${onConflictSql}${returningSql}`;\n  }\n  sqlToQuery(sql2, invokeSource) {\n    return sql2.toQuery({\n      casing: this.casing,\n      escapeName: this.escapeName,\n      escapeParam: this.escapeParam,\n      escapeString: this.escapeString,\n      invokeSource\n    });\n  }\n  buildRelationalQuery({\n    fullSchema,\n    schema,\n    tableNamesMap,\n    table,\n    tableConfig,\n    queryConfig: config,\n    tableAlias,\n    nestedQueryRelation,\n    joinOn\n  }) {\n    let selection = [];\n    let limit, offset, orderBy = [], where;\n    const joins = [];\n    if (config === true) {\n      const selectionEntries = Object.entries(tableConfig.columns);\n      selection = selectionEntries.map(([key, value]) => ({\n        dbKey: value.name,\n        tsKey: key,\n        field: aliasedTableColumn(value, tableAlias),\n        relationTableTsKey: void 0,\n        isJson: false,\n        selection: []\n      }));\n    } else {\n      const aliasedColumns = Object.fromEntries(\n        Object.entries(tableConfig.columns).map(([key, value]) => [key, aliasedTableColumn(value, tableAlias)])\n      );\n      if (config.where) {\n        const whereSql = typeof config.where === \"function\" ? config.where(aliasedColumns, getOperators()) : config.where;\n        where = whereSql && mapColumnsInSQLToAlias(whereSql, tableAlias);\n      }\n      const fieldsSelection = [];\n      let selectedColumns = [];\n      if (config.columns) {\n        let isIncludeMode = false;\n        for (const [field, value] of Object.entries(config.columns)) {\n          if (value === void 0) {\n            continue;\n          }\n          if (field in tableConfig.columns) {\n            if (!isIncludeMode && value === true) {\n              isIncludeMode = true;\n            }\n            selectedColumns.push(field);\n          }\n        }\n        if (selectedColumns.length > 0) {\n          selectedColumns = isIncludeMode ? selectedColumns.filter((c) => config.columns?.[c] === true) : Object.keys(tableConfig.columns).filter((key) => !selectedColumns.includes(key));\n        }\n      } else {\n        selectedColumns = Object.keys(tableConfig.columns);\n      }\n      for (const field of selectedColumns) {\n        const column = tableConfig.columns[field];\n        fieldsSelection.push({ tsKey: field, value: column });\n      }\n      let selectedRelations = [];\n      if (config.with) {\n        selectedRelations = Object.entries(config.with).filter((entry) => !!entry[1]).map(([tsKey, queryConfig]) => ({ tsKey, queryConfig, relation: tableConfig.relations[tsKey] }));\n      }\n      let extras;\n      if (config.extras) {\n        extras = typeof config.extras === \"function\" ? config.extras(aliasedColumns, { sql }) : config.extras;\n        for (const [tsKey, value] of Object.entries(extras)) {\n          fieldsSelection.push({\n            tsKey,\n            value: mapColumnsInAliasedSQLToAlias(value, tableAlias)\n          });\n        }\n      }\n      for (const { tsKey, value } of fieldsSelection) {\n        selection.push({\n          dbKey: is(value, SQL.Aliased) ? value.fieldAlias : tableConfig.columns[tsKey].name,\n          tsKey,\n          field: is(value, Column) ? aliasedTableColumn(value, tableAlias) : value,\n          relationTableTsKey: void 0,\n          isJson: false,\n          selection: []\n        });\n      }\n      let orderByOrig = typeof config.orderBy === \"function\" ? config.orderBy(aliasedColumns, getOrderByOperators()) : config.orderBy ?? [];\n      if (!Array.isArray(orderByOrig)) {\n        orderByOrig = [orderByOrig];\n      }\n      orderBy = orderByOrig.map((orderByValue) => {\n        if (is(orderByValue, Column)) {\n          return aliasedTableColumn(orderByValue, tableAlias);\n        }\n        return mapColumnsInSQLToAlias(orderByValue, tableAlias);\n      });\n      limit = config.limit;\n      offset = config.offset;\n      for (const {\n        tsKey: selectedRelationTsKey,\n        queryConfig: selectedRelationConfigValue,\n        relation\n      } of selectedRelations) {\n        const normalizedRelation = normalizeRelation(schema, tableNamesMap, relation);\n        const relationTableName = getTableUniqueName(relation.referencedTable);\n        const relationTableTsName = tableNamesMap[relationTableName];\n        const relationTableAlias = `${tableAlias}_${selectedRelationTsKey}`;\n        const joinOn2 = and(\n          ...normalizedRelation.fields.map(\n            (field2, i) => eq(\n              aliasedTableColumn(normalizedRelation.references[i], relationTableAlias),\n              aliasedTableColumn(field2, tableAlias)\n            )\n          )\n        );\n        const builtRelation = this.buildRelationalQuery({\n          fullSchema,\n          schema,\n          tableNamesMap,\n          table: fullSchema[relationTableTsName],\n          tableConfig: schema[relationTableTsName],\n          queryConfig: is(relation, One) ? selectedRelationConfigValue === true ? { limit: 1 } : { ...selectedRelationConfigValue, limit: 1 } : selectedRelationConfigValue,\n          tableAlias: relationTableAlias,\n          joinOn: joinOn2,\n          nestedQueryRelation: relation\n        });\n        const field = sql`(${builtRelation.sql})`.as(selectedRelationTsKey);\n        selection.push({\n          dbKey: selectedRelationTsKey,\n          tsKey: selectedRelationTsKey,\n          field,\n          relationTableTsKey: relationTableTsName,\n          isJson: true,\n          selection: builtRelation.selection\n        });\n      }\n    }\n    if (selection.length === 0) {\n      throw new DrizzleError({\n        message: `No fields selected for table \"${tableConfig.tsName}\" (\"${tableAlias}\"). You need to have at least one item in \"columns\", \"with\" or \"extras\". If you need to select all columns, omit the \"columns\" key or set it to undefined.`\n      });\n    }\n    let result;\n    where = and(joinOn, where);\n    if (nestedQueryRelation) {\n      let field = sql`json_array(${sql.join(\n        selection.map(\n          ({ field: field2 }) => is(field2, SQLiteColumn) ? sql.identifier(this.casing.getColumnCasing(field2)) : is(field2, SQL.Aliased) ? field2.sql : field2\n        ),\n        sql`, `\n      )})`;\n      if (is(nestedQueryRelation, Many)) {\n        field = sql`coalesce(json_group_array(${field}), json_array())`;\n      }\n      const nestedSelection = [{\n        dbKey: \"data\",\n        tsKey: \"data\",\n        field: field.as(\"data\"),\n        isJson: true,\n        relationTableTsKey: tableConfig.tsName,\n        selection\n      }];\n      const needsSubquery = limit !== void 0 || offset !== void 0 || orderBy.length > 0;\n      if (needsSubquery) {\n        result = this.buildSelectQuery({\n          table: aliasedTable(table, tableAlias),\n          fields: {},\n          fieldsFlat: [\n            {\n              path: [],\n              field: sql.raw(\"*\")\n            }\n          ],\n          where,\n          limit,\n          offset,\n          orderBy,\n          setOperators: []\n        });\n        where = void 0;\n        limit = void 0;\n        offset = void 0;\n        orderBy = void 0;\n      } else {\n        result = aliasedTable(table, tableAlias);\n      }\n      result = this.buildSelectQuery({\n        table: is(result, SQLiteTable) ? result : new Subquery(result, {}, tableAlias),\n        fields: {},\n        fieldsFlat: nestedSelection.map(({ field: field2 }) => ({\n          path: [],\n          field: is(field2, Column) ? aliasedTableColumn(field2, tableAlias) : field2\n        })),\n        joins,\n        where,\n        limit,\n        offset,\n        orderBy,\n        setOperators: []\n      });\n    } else {\n      result = this.buildSelectQuery({\n        table: aliasedTable(table, tableAlias),\n        fields: {},\n        fieldsFlat: selection.map(({ field }) => ({\n          path: [],\n          field: is(field, Column) ? aliasedTableColumn(field, tableAlias) : field\n        })),\n        joins,\n        where,\n        limit,\n        offset,\n        orderBy,\n        setOperators: []\n      });\n    }\n    return {\n      tableTsKey: tableConfig.tsName,\n      sql: result,\n      selection\n    };\n  }\n}\nclass SQLiteSyncDialect extends SQLiteDialect {\n  static [entityKind] = \"SQLiteSyncDialect\";\n  migrate(migrations, session, config) {\n    const migrationsTable = config === void 0 ? \"__drizzle_migrations\" : typeof config === \"string\" ? \"__drizzle_migrations\" : config.migrationsTable ?? \"__drizzle_migrations\";\n    const migrationTableCreate = sql`\n\t\t\tCREATE TABLE IF NOT EXISTS ${sql.identifier(migrationsTable)} (\n\t\t\t\tid SERIAL PRIMARY KEY,\n\t\t\t\thash text NOT NULL,\n\t\t\t\tcreated_at numeric\n\t\t\t)\n\t\t`;\n    session.run(migrationTableCreate);\n    const dbMigrations = session.values(\n      sql`SELECT id, hash, created_at FROM ${sql.identifier(migrationsTable)} ORDER BY created_at DESC LIMIT 1`\n    );\n    const lastDbMigration = dbMigrations[0] ?? void 0;\n    session.run(sql`BEGIN`);\n    try {\n      for (const migration of migrations) {\n        if (!lastDbMigration || Number(lastDbMigration[2]) < migration.folderMillis) {\n          for (const stmt of migration.sql) {\n            session.run(sql.raw(stmt));\n          }\n          session.run(\n            sql`INSERT INTO ${sql.identifier(migrationsTable)} (\"hash\", \"created_at\") VALUES(${migration.hash}, ${migration.folderMillis})`\n          );\n        }\n      }\n      session.run(sql`COMMIT`);\n    } catch (e) {\n      session.run(sql`ROLLBACK`);\n      throw e;\n    }\n  }\n}\nclass SQLiteAsyncDialect extends SQLiteDialect {\n  static [entityKind] = \"SQLiteAsyncDialect\";\n  async migrate(migrations, session, config) {\n    const migrationsTable = config === void 0 ? \"__drizzle_migrations\" : typeof config === \"string\" ? \"__drizzle_migrations\" : config.migrationsTable ?? \"__drizzle_migrations\";\n    const migrationTableCreate = sql`\n\t\t\tCREATE TABLE IF NOT EXISTS ${sql.identifier(migrationsTable)} (\n\t\t\t\tid SERIAL PRIMARY KEY,\n\t\t\t\thash text NOT NULL,\n\t\t\t\tcreated_at numeric\n\t\t\t)\n\t\t`;\n    await session.run(migrationTableCreate);\n    const dbMigrations = await session.values(\n      sql`SELECT id, hash, created_at FROM ${sql.identifier(migrationsTable)} ORDER BY created_at DESC LIMIT 1`\n    );\n    const lastDbMigration = dbMigrations[0] ?? void 0;\n    await session.transaction(async (tx) => {\n      for (const migration of migrations) {\n        if (!lastDbMigration || Number(lastDbMigration[2]) < migration.folderMillis) {\n          for (const stmt of migration.sql) {\n            await tx.run(sql.raw(stmt));\n          }\n          await tx.run(\n            sql`INSERT INTO ${sql.identifier(migrationsTable)} (\"hash\", \"created_at\") VALUES(${migration.hash}, ${migration.folderMillis})`\n          );\n        }\n      }\n    });\n  }\n}\nexport {\n  SQLiteAsyncDialect,\n  SQLiteDialect,\n  SQLiteSyncDialect\n};\n//# sourceMappingURL=dialect.js.map",
    "import { entityKind } from \"../entity.js\";\nclass TypedQueryBuilder {\n  static [entityKind] = \"TypedQueryBuilder\";\n  /** @internal */\n  getSelectedFields() {\n    return this._.selectedFields;\n  }\n}\nexport {\n  TypedQueryBuilder\n};\n//# sourceMappingURL=query-builder.js.map",
    "import { entityKind, is } from \"../../entity.js\";\nimport { TypedQueryBuilder } from \"../../query-builders/query-builder.js\";\nimport { QueryPromise } from \"../../query-promise.js\";\nimport { SelectionProxyHandler } from \"../../selection-proxy.js\";\nimport { SQL, View } from \"../../sql/sql.js\";\nimport { Subquery } from \"../../subquery.js\";\nimport { Table } from \"../../table.js\";\nimport {\n  applyMixins,\n  getTableColumns,\n  getTableLikeName,\n  haveSameKeys,\n  orderSelectedFields\n} from \"../../utils.js\";\nimport { ViewBaseConfig } from \"../../view-common.js\";\nimport { extractUsedTable } from \"../utils.js\";\nimport { SQLiteViewBase } from \"../view-base.js\";\nclass SQLiteSelectBuilder {\n  static [entityKind] = \"SQLiteSelectBuilder\";\n  fields;\n  session;\n  dialect;\n  withList;\n  distinct;\n  constructor(config) {\n    this.fields = config.fields;\n    this.session = config.session;\n    this.dialect = config.dialect;\n    this.withList = config.withList;\n    this.distinct = config.distinct;\n  }\n  from(source) {\n    const isPartialSelect = !!this.fields;\n    let fields;\n    if (this.fields) {\n      fields = this.fields;\n    } else if (is(source, Subquery)) {\n      fields = Object.fromEntries(\n        Object.keys(source._.selectedFields).map((key) => [key, source[key]])\n      );\n    } else if (is(source, SQLiteViewBase)) {\n      fields = source[ViewBaseConfig].selectedFields;\n    } else if (is(source, SQL)) {\n      fields = {};\n    } else {\n      fields = getTableColumns(source);\n    }\n    return new SQLiteSelectBase({\n      table: source,\n      fields,\n      isPartialSelect,\n      session: this.session,\n      dialect: this.dialect,\n      withList: this.withList,\n      distinct: this.distinct\n    });\n  }\n}\nclass SQLiteSelectQueryBuilderBase extends TypedQueryBuilder {\n  static [entityKind] = \"SQLiteSelectQueryBuilder\";\n  _;\n  /** @internal */\n  config;\n  joinsNotNullableMap;\n  tableName;\n  isPartialSelect;\n  session;\n  dialect;\n  cacheConfig = void 0;\n  usedTables = /* @__PURE__ */ new Set();\n  constructor({ table, fields, isPartialSelect, session, dialect, withList, distinct }) {\n    super();\n    this.config = {\n      withList,\n      table,\n      fields: { ...fields },\n      distinct,\n      setOperators: []\n    };\n    this.isPartialSelect = isPartialSelect;\n    this.session = session;\n    this.dialect = dialect;\n    this._ = {\n      selectedFields: fields,\n      config: this.config\n    };\n    this.tableName = getTableLikeName(table);\n    this.joinsNotNullableMap = typeof this.tableName === \"string\" ? { [this.tableName]: true } : {};\n    for (const item of extractUsedTable(table)) this.usedTables.add(item);\n  }\n  /** @internal */\n  getUsedTables() {\n    return [...this.usedTables];\n  }\n  createJoin(joinType) {\n    return (table, on) => {\n      const baseTableName = this.tableName;\n      const tableName = getTableLikeName(table);\n      for (const item of extractUsedTable(table)) this.usedTables.add(item);\n      if (typeof tableName === \"string\" && this.config.joins?.some((join) => join.alias === tableName)) {\n        throw new Error(`Alias \"${tableName}\" is already used in this query`);\n      }\n      if (!this.isPartialSelect) {\n        if (Object.keys(this.joinsNotNullableMap).length === 1 && typeof baseTableName === \"string\") {\n          this.config.fields = {\n            [baseTableName]: this.config.fields\n          };\n        }\n        if (typeof tableName === \"string\" && !is(table, SQL)) {\n          const selection = is(table, Subquery) ? table._.selectedFields : is(table, View) ? table[ViewBaseConfig].selectedFields : table[Table.Symbol.Columns];\n          this.config.fields[tableName] = selection;\n        }\n      }\n      if (typeof on === \"function\") {\n        on = on(\n          new Proxy(\n            this.config.fields,\n            new SelectionProxyHandler({ sqlAliasedBehavior: \"sql\", sqlBehavior: \"sql\" })\n          )\n        );\n      }\n      if (!this.config.joins) {\n        this.config.joins = [];\n      }\n      this.config.joins.push({ on, table, joinType, alias: tableName });\n      if (typeof tableName === \"string\") {\n        switch (joinType) {\n          case \"left\": {\n            this.joinsNotNullableMap[tableName] = false;\n            break;\n          }\n          case \"right\": {\n            this.joinsNotNullableMap = Object.fromEntries(\n              Object.entries(this.joinsNotNullableMap).map(([key]) => [key, false])\n            );\n            this.joinsNotNullableMap[tableName] = true;\n            break;\n          }\n          case \"cross\":\n          case \"inner\": {\n            this.joinsNotNullableMap[tableName] = true;\n            break;\n          }\n          case \"full\": {\n            this.joinsNotNullableMap = Object.fromEntries(\n              Object.entries(this.joinsNotNullableMap).map(([key]) => [key, false])\n            );\n            this.joinsNotNullableMap[tableName] = false;\n            break;\n          }\n        }\n      }\n      return this;\n    };\n  }\n  /**\n   * Executes a `left join` operation by adding another table to the current query.\n   *\n   * Calling this method associates each row of the table with the corresponding row from the joined table, if a match is found. If no matching row exists, it sets all columns of the joined table to null.\n   *\n   * See docs: {@link https://orm.drizzle.team/docs/joins#left-join}\n   *\n   * @param table the table to join.\n   * @param on the `on` clause.\n   *\n   * @example\n   *\n   * ```ts\n   * // Select all users and their pets\n   * const usersWithPets: { user: User; pets: Pet | null; }[] = await db.select()\n   *   .from(users)\n   *   .leftJoin(pets, eq(users.id, pets.ownerId))\n   *\n   * // Select userId and petId\n   * const usersIdsAndPetIds: { userId: number; petId: number | null; }[] = await db.select({\n   *   userId: users.id,\n   *   petId: pets.id,\n   * })\n   *   .from(users)\n   *   .leftJoin(pets, eq(users.id, pets.ownerId))\n   * ```\n   */\n  leftJoin = this.createJoin(\"left\");\n  /**\n   * Executes a `right join` operation by adding another table to the current query.\n   *\n   * Calling this method associates each row of the joined table with the corresponding row from the main table, if a match is found. If no matching row exists, it sets all columns of the main table to null.\n   *\n   * See docs: {@link https://orm.drizzle.team/docs/joins#right-join}\n   *\n   * @param table the table to join.\n   * @param on the `on` clause.\n   *\n   * @example\n   *\n   * ```ts\n   * // Select all users and their pets\n   * const usersWithPets: { user: User | null; pets: Pet; }[] = await db.select()\n   *   .from(users)\n   *   .rightJoin(pets, eq(users.id, pets.ownerId))\n   *\n   * // Select userId and petId\n   * const usersIdsAndPetIds: { userId: number | null; petId: number; }[] = await db.select({\n   *   userId: users.id,\n   *   petId: pets.id,\n   * })\n   *   .from(users)\n   *   .rightJoin(pets, eq(users.id, pets.ownerId))\n   * ```\n   */\n  rightJoin = this.createJoin(\"right\");\n  /**\n   * Executes an `inner join` operation, creating a new table by combining rows from two tables that have matching values.\n   *\n   * Calling this method retrieves rows that have corresponding entries in both joined tables. Rows without matching entries in either table are excluded, resulting in a table that includes only matching pairs.\n   *\n   * See docs: {@link https://orm.drizzle.team/docs/joins#inner-join}\n   *\n   * @param table the table to join.\n   * @param on the `on` clause.\n   *\n   * @example\n   *\n   * ```ts\n   * // Select all users and their pets\n   * const usersWithPets: { user: User; pets: Pet; }[] = await db.select()\n   *   .from(users)\n   *   .innerJoin(pets, eq(users.id, pets.ownerId))\n   *\n   * // Select userId and petId\n   * const usersIdsAndPetIds: { userId: number; petId: number; }[] = await db.select({\n   *   userId: users.id,\n   *   petId: pets.id,\n   * })\n   *   .from(users)\n   *   .innerJoin(pets, eq(users.id, pets.ownerId))\n   * ```\n   */\n  innerJoin = this.createJoin(\"inner\");\n  /**\n   * Executes a `full join` operation by combining rows from two tables into a new table.\n   *\n   * Calling this method retrieves all rows from both main and joined tables, merging rows with matching values and filling in `null` for non-matching columns.\n   *\n   * See docs: {@link https://orm.drizzle.team/docs/joins#full-join}\n   *\n   * @param table the table to join.\n   * @param on the `on` clause.\n   *\n   * @example\n   *\n   * ```ts\n   * // Select all users and their pets\n   * const usersWithPets: { user: User | null; pets: Pet | null; }[] = await db.select()\n   *   .from(users)\n   *   .fullJoin(pets, eq(users.id, pets.ownerId))\n   *\n   * // Select userId and petId\n   * const usersIdsAndPetIds: { userId: number | null; petId: number | null; }[] = await db.select({\n   *   userId: users.id,\n   *   petId: pets.id,\n   * })\n   *   .from(users)\n   *   .fullJoin(pets, eq(users.id, pets.ownerId))\n   * ```\n   */\n  fullJoin = this.createJoin(\"full\");\n  /**\n   * Executes a `cross join` operation by combining rows from two tables into a new table.\n   *\n   * Calling this method retrieves all rows from both main and joined tables, merging all rows from each table.\n   *\n   * See docs: {@link https://orm.drizzle.team/docs/joins#cross-join}\n   *\n   * @param table the table to join.\n   *\n   * @example\n   *\n   * ```ts\n   * // Select all users, each user with every pet\n   * const usersWithPets: { user: User; pets: Pet; }[] = await db.select()\n   *   .from(users)\n   *   .crossJoin(pets)\n   *\n   * // Select userId and petId\n   * const usersIdsAndPetIds: { userId: number; petId: number; }[] = await db.select({\n   *   userId: users.id,\n   *   petId: pets.id,\n   * })\n   *   .from(users)\n   *   .crossJoin(pets)\n   * ```\n   */\n  crossJoin = this.createJoin(\"cross\");\n  createSetOperator(type, isAll) {\n    return (rightSelection) => {\n      const rightSelect = typeof rightSelection === \"function\" ? rightSelection(getSQLiteSetOperators()) : rightSelection;\n      if (!haveSameKeys(this.getSelectedFields(), rightSelect.getSelectedFields())) {\n        throw new Error(\n          \"Set operator error (union / intersect / except): selected fields are not the same or are in a different order\"\n        );\n      }\n      this.config.setOperators.push({ type, isAll, rightSelect });\n      return this;\n    };\n  }\n  /**\n   * Adds `union` set operator to the query.\n   *\n   * Calling this method will combine the result sets of the `select` statements and remove any duplicate rows that appear across them.\n   *\n   * See docs: {@link https://orm.drizzle.team/docs/set-operations#union}\n   *\n   * @example\n   *\n   * ```ts\n   * // Select all unique names from customers and users tables\n   * await db.select({ name: users.name })\n   *   .from(users)\n   *   .union(\n   *     db.select({ name: customers.name }).from(customers)\n   *   );\n   * // or\n   * import { union } from 'drizzle-orm/sqlite-core'\n   *\n   * await union(\n   *   db.select({ name: users.name }).from(users),\n   *   db.select({ name: customers.name }).from(customers)\n   * );\n   * ```\n   */\n  union = this.createSetOperator(\"union\", false);\n  /**\n   * Adds `union all` set operator to the query.\n   *\n   * Calling this method will combine the result-set of the `select` statements and keep all duplicate rows that appear across them.\n   *\n   * See docs: {@link https://orm.drizzle.team/docs/set-operations#union-all}\n   *\n   * @example\n   *\n   * ```ts\n   * // Select all transaction ids from both online and in-store sales\n   * await db.select({ transaction: onlineSales.transactionId })\n   *   .from(onlineSales)\n   *   .unionAll(\n   *     db.select({ transaction: inStoreSales.transactionId }).from(inStoreSales)\n   *   );\n   * // or\n   * import { unionAll } from 'drizzle-orm/sqlite-core'\n   *\n   * await unionAll(\n   *   db.select({ transaction: onlineSales.transactionId }).from(onlineSales),\n   *   db.select({ transaction: inStoreSales.transactionId }).from(inStoreSales)\n   * );\n   * ```\n   */\n  unionAll = this.createSetOperator(\"union\", true);\n  /**\n   * Adds `intersect` set operator to the query.\n   *\n   * Calling this method will retain only the rows that are present in both result sets and eliminate duplicates.\n   *\n   * See docs: {@link https://orm.drizzle.team/docs/set-operations#intersect}\n   *\n   * @example\n   *\n   * ```ts\n   * // Select course names that are offered in both departments A and B\n   * await db.select({ courseName: depA.courseName })\n   *   .from(depA)\n   *   .intersect(\n   *     db.select({ courseName: depB.courseName }).from(depB)\n   *   );\n   * // or\n   * import { intersect } from 'drizzle-orm/sqlite-core'\n   *\n   * await intersect(\n   *   db.select({ courseName: depA.courseName }).from(depA),\n   *   db.select({ courseName: depB.courseName }).from(depB)\n   * );\n   * ```\n   */\n  intersect = this.createSetOperator(\"intersect\", false);\n  /**\n   * Adds `except` set operator to the query.\n   *\n   * Calling this method will retrieve all unique rows from the left query, except for the rows that are present in the result set of the right query.\n   *\n   * See docs: {@link https://orm.drizzle.team/docs/set-operations#except}\n   *\n   * @example\n   *\n   * ```ts\n   * // Select all courses offered in department A but not in department B\n   * await db.select({ courseName: depA.courseName })\n   *   .from(depA)\n   *   .except(\n   *     db.select({ courseName: depB.courseName }).from(depB)\n   *   );\n   * // or\n   * import { except } from 'drizzle-orm/sqlite-core'\n   *\n   * await except(\n   *   db.select({ courseName: depA.courseName }).from(depA),\n   *   db.select({ courseName: depB.courseName }).from(depB)\n   * );\n   * ```\n   */\n  except = this.createSetOperator(\"except\", false);\n  /** @internal */\n  addSetOperators(setOperators) {\n    this.config.setOperators.push(...setOperators);\n    return this;\n  }\n  /**\n   * Adds a `where` clause to the query.\n   *\n   * Calling this method will select only those rows that fulfill a specified condition.\n   *\n   * See docs: {@link https://orm.drizzle.team/docs/select#filtering}\n   *\n   * @param where the `where` clause.\n   *\n   * @example\n   * You can use conditional operators and `sql function` to filter the rows to be selected.\n   *\n   * ```ts\n   * // Select all cars with green color\n   * await db.select().from(cars).where(eq(cars.color, 'green'));\n   * // or\n   * await db.select().from(cars).where(sql`${cars.color} = 'green'`)\n   * ```\n   *\n   * You can logically combine conditional operators with `and()` and `or()` operators:\n   *\n   * ```ts\n   * // Select all BMW cars with a green color\n   * await db.select().from(cars).where(and(eq(cars.color, 'green'), eq(cars.brand, 'BMW')));\n   *\n   * // Select all cars with the green or blue color\n   * await db.select().from(cars).where(or(eq(cars.color, 'green'), eq(cars.color, 'blue')));\n   * ```\n   */\n  where(where) {\n    if (typeof where === \"function\") {\n      where = where(\n        new Proxy(\n          this.config.fields,\n          new SelectionProxyHandler({ sqlAliasedBehavior: \"sql\", sqlBehavior: \"sql\" })\n        )\n      );\n    }\n    this.config.where = where;\n    return this;\n  }\n  /**\n   * Adds a `having` clause to the query.\n   *\n   * Calling this method will select only those rows that fulfill a specified condition. It is typically used with aggregate functions to filter the aggregated data based on a specified condition.\n   *\n   * See docs: {@link https://orm.drizzle.team/docs/select#aggregations}\n   *\n   * @param having the `having` clause.\n   *\n   * @example\n   *\n   * ```ts\n   * // Select all brands with more than one car\n   * await db.select({\n   * \tbrand: cars.brand,\n   * \tcount: sql<number>`cast(count(${cars.id}) as int)`,\n   * })\n   *   .from(cars)\n   *   .groupBy(cars.brand)\n   *   .having(({ count }) => gt(count, 1));\n   * ```\n   */\n  having(having) {\n    if (typeof having === \"function\") {\n      having = having(\n        new Proxy(\n          this.config.fields,\n          new SelectionProxyHandler({ sqlAliasedBehavior: \"sql\", sqlBehavior: \"sql\" })\n        )\n      );\n    }\n    this.config.having = having;\n    return this;\n  }\n  groupBy(...columns) {\n    if (typeof columns[0] === \"function\") {\n      const groupBy = columns[0](\n        new Proxy(\n          this.config.fields,\n          new SelectionProxyHandler({ sqlAliasedBehavior: \"alias\", sqlBehavior: \"sql\" })\n        )\n      );\n      this.config.groupBy = Array.isArray(groupBy) ? groupBy : [groupBy];\n    } else {\n      this.config.groupBy = columns;\n    }\n    return this;\n  }\n  orderBy(...columns) {\n    if (typeof columns[0] === \"function\") {\n      const orderBy = columns[0](\n        new Proxy(\n          this.config.fields,\n          new SelectionProxyHandler({ sqlAliasedBehavior: \"alias\", sqlBehavior: \"sql\" })\n        )\n      );\n      const orderByArray = Array.isArray(orderBy) ? orderBy : [orderBy];\n      if (this.config.setOperators.length > 0) {\n        this.config.setOperators.at(-1).orderBy = orderByArray;\n      } else {\n        this.config.orderBy = orderByArray;\n      }\n    } else {\n      const orderByArray = columns;\n      if (this.config.setOperators.length > 0) {\n        this.config.setOperators.at(-1).orderBy = orderByArray;\n      } else {\n        this.config.orderBy = orderByArray;\n      }\n    }\n    return this;\n  }\n  /**\n   * Adds a `limit` clause to the query.\n   *\n   * Calling this method will set the maximum number of rows that will be returned by this query.\n   *\n   * See docs: {@link https://orm.drizzle.team/docs/select#limit--offset}\n   *\n   * @param limit the `limit` clause.\n   *\n   * @example\n   *\n   * ```ts\n   * // Get the first 10 people from this query.\n   * await db.select().from(people).limit(10);\n   * ```\n   */\n  limit(limit) {\n    if (this.config.setOperators.length > 0) {\n      this.config.setOperators.at(-1).limit = limit;\n    } else {\n      this.config.limit = limit;\n    }\n    return this;\n  }\n  /**\n   * Adds an `offset` clause to the query.\n   *\n   * Calling this method will skip a number of rows when returning results from this query.\n   *\n   * See docs: {@link https://orm.drizzle.team/docs/select#limit--offset}\n   *\n   * @param offset the `offset` clause.\n   *\n   * @example\n   *\n   * ```ts\n   * // Get the 10th-20th people from this query.\n   * await db.select().from(people).offset(10).limit(10);\n   * ```\n   */\n  offset(offset) {\n    if (this.config.setOperators.length > 0) {\n      this.config.setOperators.at(-1).offset = offset;\n    } else {\n      this.config.offset = offset;\n    }\n    return this;\n  }\n  /** @internal */\n  getSQL() {\n    return this.dialect.buildSelectQuery(this.config);\n  }\n  toSQL() {\n    const { typings: _typings, ...rest } = this.dialect.sqlToQuery(this.getSQL());\n    return rest;\n  }\n  as(alias) {\n    const usedTables = [];\n    usedTables.push(...extractUsedTable(this.config.table));\n    if (this.config.joins) {\n      for (const it of this.config.joins) usedTables.push(...extractUsedTable(it.table));\n    }\n    return new Proxy(\n      new Subquery(this.getSQL(), this.config.fields, alias, false, [...new Set(usedTables)]),\n      new SelectionProxyHandler({ alias, sqlAliasedBehavior: \"alias\", sqlBehavior: \"error\" })\n    );\n  }\n  /** @internal */\n  getSelectedFields() {\n    return new Proxy(\n      this.config.fields,\n      new SelectionProxyHandler({ alias: this.tableName, sqlAliasedBehavior: \"alias\", sqlBehavior: \"error\" })\n    );\n  }\n  $dynamic() {\n    return this;\n  }\n}\nclass SQLiteSelectBase extends SQLiteSelectQueryBuilderBase {\n  static [entityKind] = \"SQLiteSelect\";\n  /** @internal */\n  _prepare(isOneTimeQuery = true) {\n    if (!this.session) {\n      throw new Error(\"Cannot execute a query on a query builder. Please use a database instance instead.\");\n    }\n    const fieldsList = orderSelectedFields(this.config.fields);\n    const query = this.session[isOneTimeQuery ? \"prepareOneTimeQuery\" : \"prepareQuery\"](\n      this.dialect.sqlToQuery(this.getSQL()),\n      fieldsList,\n      \"all\",\n      true,\n      void 0,\n      {\n        type: \"select\",\n        tables: [...this.usedTables]\n      },\n      this.cacheConfig\n    );\n    query.joinsNotNullableMap = this.joinsNotNullableMap;\n    return query;\n  }\n  $withCache(config) {\n    this.cacheConfig = config === void 0 ? { config: {}, enable: true, autoInvalidate: true } : config === false ? { enable: false } : { enable: true, autoInvalidate: true, ...config };\n    return this;\n  }\n  prepare() {\n    return this._prepare(false);\n  }\n  run = (placeholderValues) => {\n    return this._prepare().run(placeholderValues);\n  };\n  all = (placeholderValues) => {\n    return this._prepare().all(placeholderValues);\n  };\n  get = (placeholderValues) => {\n    return this._prepare().get(placeholderValues);\n  };\n  values = (placeholderValues) => {\n    return this._prepare().values(placeholderValues);\n  };\n  async execute() {\n    return this.all();\n  }\n}\napplyMixins(SQLiteSelectBase, [QueryPromise]);\nfunction createSetOperator(type, isAll) {\n  return (leftSelect, rightSelect, ...restSelects) => {\n    const setOperators = [rightSelect, ...restSelects].map((select) => ({\n      type,\n      isAll,\n      rightSelect: select\n    }));\n    for (const setOperator of setOperators) {\n      if (!haveSameKeys(leftSelect.getSelectedFields(), setOperator.rightSelect.getSelectedFields())) {\n        throw new Error(\n          \"Set operator error (union / intersect / except): selected fields are not the same or are in a different order\"\n        );\n      }\n    }\n    return leftSelect.addSetOperators(setOperators);\n  };\n}\nconst getSQLiteSetOperators = () => ({\n  union,\n  unionAll,\n  intersect,\n  except\n});\nconst union = createSetOperator(\"union\", false);\nconst unionAll = createSetOperator(\"union\", true);\nconst intersect = createSetOperator(\"intersect\", false);\nconst except = createSetOperator(\"except\", false);\nexport {\n  SQLiteSelectBase,\n  SQLiteSelectBuilder,\n  SQLiteSelectQueryBuilderBase,\n  except,\n  intersect,\n  union,\n  unionAll\n};\n//# sourceMappingURL=select.js.map",
    "import { entityKind, is } from \"../../entity.js\";\nimport { SelectionProxyHandler } from \"../../selection-proxy.js\";\nimport { SQLiteDialect, SQLiteSyncDialect } from \"../dialect.js\";\nimport { WithSubquery } from \"../../subquery.js\";\nimport { SQLiteSelectBuilder } from \"./select.js\";\nclass QueryBuilder {\n  static [entityKind] = \"SQLiteQueryBuilder\";\n  dialect;\n  dialectConfig;\n  constructor(dialect) {\n    this.dialect = is(dialect, SQLiteDialect) ? dialect : void 0;\n    this.dialectConfig = is(dialect, SQLiteDialect) ? void 0 : dialect;\n  }\n  $with = (alias, selection) => {\n    const queryBuilder = this;\n    const as = (qb) => {\n      if (typeof qb === \"function\") {\n        qb = qb(queryBuilder);\n      }\n      return new Proxy(\n        new WithSubquery(\n          qb.getSQL(),\n          selection ?? (\"getSelectedFields\" in qb ? qb.getSelectedFields() ?? {} : {}),\n          alias,\n          true\n        ),\n        new SelectionProxyHandler({ alias, sqlAliasedBehavior: \"alias\", sqlBehavior: \"error\" })\n      );\n    };\n    return { as };\n  };\n  with(...queries) {\n    const self = this;\n    function select(fields) {\n      return new SQLiteSelectBuilder({\n        fields: fields ?? void 0,\n        session: void 0,\n        dialect: self.getDialect(),\n        withList: queries\n      });\n    }\n    function selectDistinct(fields) {\n      return new SQLiteSelectBuilder({\n        fields: fields ?? void 0,\n        session: void 0,\n        dialect: self.getDialect(),\n        withList: queries,\n        distinct: true\n      });\n    }\n    return { select, selectDistinct };\n  }\n  select(fields) {\n    return new SQLiteSelectBuilder({ fields: fields ?? void 0, session: void 0, dialect: this.getDialect() });\n  }\n  selectDistinct(fields) {\n    return new SQLiteSelectBuilder({\n      fields: fields ?? void 0,\n      session: void 0,\n      dialect: this.getDialect(),\n      distinct: true\n    });\n  }\n  // Lazy load dialect to avoid circular dependency\n  getDialect() {\n    if (!this.dialect) {\n      this.dialect = new SQLiteSyncDialect(this.dialectConfig);\n    }\n    return this.dialect;\n  }\n}\nexport {\n  QueryBuilder\n};\n//# sourceMappingURL=query-builder.js.map",
    "import { entityKind, is } from \"../../entity.js\";\nimport { QueryPromise } from \"../../query-promise.js\";\nimport { Param, SQL, sql } from \"../../sql/sql.js\";\nimport { SQLiteTable } from \"../table.js\";\nimport { Columns, Table } from \"../../table.js\";\nimport { haveSameKeys, mapUpdateSet, orderSelectedFields } from \"../../utils.js\";\nimport { extractUsedTable } from \"../utils.js\";\nimport { QueryBuilder } from \"./query-builder.js\";\nclass SQLiteInsertBuilder {\n  constructor(table, session, dialect, withList) {\n    this.table = table;\n    this.session = session;\n    this.dialect = dialect;\n    this.withList = withList;\n  }\n  static [entityKind] = \"SQLiteInsertBuilder\";\n  values(values) {\n    values = Array.isArray(values) ? values : [values];\n    if (values.length === 0) {\n      throw new Error(\"values() must be called with at least one value\");\n    }\n    const mappedValues = values.map((entry) => {\n      const result = {};\n      const cols = this.table[Table.Symbol.Columns];\n      for (const colKey of Object.keys(entry)) {\n        const colValue = entry[colKey];\n        result[colKey] = is(colValue, SQL) ? colValue : new Param(colValue, cols[colKey]);\n      }\n      return result;\n    });\n    return new SQLiteInsertBase(this.table, mappedValues, this.session, this.dialect, this.withList);\n  }\n  select(selectQuery) {\n    const select = typeof selectQuery === \"function\" ? selectQuery(new QueryBuilder()) : selectQuery;\n    if (!is(select, SQL) && !haveSameKeys(this.table[Columns], select._.selectedFields)) {\n      throw new Error(\n        \"Insert select error: selected fields are not the same or are in a different order compared to the table definition\"\n      );\n    }\n    return new SQLiteInsertBase(this.table, select, this.session, this.dialect, this.withList, true);\n  }\n}\nclass SQLiteInsertBase extends QueryPromise {\n  constructor(table, values, session, dialect, withList, select) {\n    super();\n    this.session = session;\n    this.dialect = dialect;\n    this.config = { table, values, withList, select };\n  }\n  static [entityKind] = \"SQLiteInsert\";\n  /** @internal */\n  config;\n  returning(fields = this.config.table[SQLiteTable.Symbol.Columns]) {\n    this.config.returning = orderSelectedFields(fields);\n    return this;\n  }\n  /**\n   * Adds an `on conflict do nothing` clause to the query.\n   *\n   * Calling this method simply avoids inserting a row as its alternative action.\n   *\n   * See docs: {@link https://orm.drizzle.team/docs/insert#on-conflict-do-nothing}\n   *\n   * @param config The `target` and `where` clauses.\n   *\n   * @example\n   * ```ts\n   * // Insert one row and cancel the insert if there's a conflict\n   * await db.insert(cars)\n   *   .values({ id: 1, brand: 'BMW' })\n   *   .onConflictDoNothing();\n   *\n   * // Explicitly specify conflict target\n   * await db.insert(cars)\n   *   .values({ id: 1, brand: 'BMW' })\n   *   .onConflictDoNothing({ target: cars.id });\n   * ```\n   */\n  onConflictDoNothing(config = {}) {\n    if (!this.config.onConflict) this.config.onConflict = [];\n    if (config.target === void 0) {\n      this.config.onConflict.push(sql` on conflict do nothing`);\n    } else {\n      const targetSql = Array.isArray(config.target) ? sql`${config.target}` : sql`${[config.target]}`;\n      const whereSql = config.where ? sql` where ${config.where}` : sql``;\n      this.config.onConflict.push(sql` on conflict ${targetSql} do nothing${whereSql}`);\n    }\n    return this;\n  }\n  /**\n   * Adds an `on conflict do update` clause to the query.\n   *\n   * Calling this method will update the existing row that conflicts with the row proposed for insertion as its alternative action.\n   *\n   * See docs: {@link https://orm.drizzle.team/docs/insert#upserts-and-conflicts}\n   *\n   * @param config The `target`, `set` and `where` clauses.\n   *\n   * @example\n   * ```ts\n   * // Update the row if there's a conflict\n   * await db.insert(cars)\n   *   .values({ id: 1, brand: 'BMW' })\n   *   .onConflictDoUpdate({\n   *     target: cars.id,\n   *     set: { brand: 'Porsche' }\n   *   });\n   *\n   * // Upsert with 'where' clause\n   * await db.insert(cars)\n   *   .values({ id: 1, brand: 'BMW' })\n   *   .onConflictDoUpdate({\n   *     target: cars.id,\n   *     set: { brand: 'newBMW' },\n   *     where: sql`${cars.createdAt} > '2023-01-01'::date`,\n   *   });\n   * ```\n   */\n  onConflictDoUpdate(config) {\n    if (config.where && (config.targetWhere || config.setWhere)) {\n      throw new Error(\n        'You cannot use both \"where\" and \"targetWhere\"/\"setWhere\" at the same time - \"where\" is deprecated, use \"targetWhere\" or \"setWhere\" instead.'\n      );\n    }\n    if (!this.config.onConflict) this.config.onConflict = [];\n    const whereSql = config.where ? sql` where ${config.where}` : void 0;\n    const targetWhereSql = config.targetWhere ? sql` where ${config.targetWhere}` : void 0;\n    const setWhereSql = config.setWhere ? sql` where ${config.setWhere}` : void 0;\n    const targetSql = Array.isArray(config.target) ? sql`${config.target}` : sql`${[config.target]}`;\n    const setSql = this.dialect.buildUpdateSet(this.config.table, mapUpdateSet(this.config.table, config.set));\n    this.config.onConflict.push(\n      sql` on conflict ${targetSql}${targetWhereSql} do update set ${setSql}${whereSql}${setWhereSql}`\n    );\n    return this;\n  }\n  /** @internal */\n  getSQL() {\n    return this.dialect.buildInsertQuery(this.config);\n  }\n  toSQL() {\n    const { typings: _typings, ...rest } = this.dialect.sqlToQuery(this.getSQL());\n    return rest;\n  }\n  /** @internal */\n  _prepare(isOneTimeQuery = true) {\n    return this.session[isOneTimeQuery ? \"prepareOneTimeQuery\" : \"prepareQuery\"](\n      this.dialect.sqlToQuery(this.getSQL()),\n      this.config.returning,\n      this.config.returning ? \"all\" : \"run\",\n      true,\n      void 0,\n      {\n        type: \"insert\",\n        tables: extractUsedTable(this.config.table)\n      }\n    );\n  }\n  prepare() {\n    return this._prepare(false);\n  }\n  run = (placeholderValues) => {\n    return this._prepare().run(placeholderValues);\n  };\n  all = (placeholderValues) => {\n    return this._prepare().all(placeholderValues);\n  };\n  get = (placeholderValues) => {\n    return this._prepare().get(placeholderValues);\n  };\n  values = (placeholderValues) => {\n    return this._prepare().values(placeholderValues);\n  };\n  async execute() {\n    return this.config.returning ? this.all() : this.run();\n  }\n  $dynamic() {\n    return this;\n  }\n}\nexport {\n  SQLiteInsertBase,\n  SQLiteInsertBuilder\n};\n//# sourceMappingURL=insert.js.map",
    "import { entityKind, is } from \"../../entity.js\";\nimport { QueryPromise } from \"../../query-promise.js\";\nimport { SelectionProxyHandler } from \"../../selection-proxy.js\";\nimport { SQLiteTable } from \"../table.js\";\nimport { Subquery } from \"../../subquery.js\";\nimport { Table } from \"../../table.js\";\nimport {\n  getTableLikeName,\n  mapUpdateSet,\n  orderSelectedFields\n} from \"../../utils.js\";\nimport { ViewBaseConfig } from \"../../view-common.js\";\nimport { extractUsedTable } from \"../utils.js\";\nimport { SQLiteViewBase } from \"../view-base.js\";\nclass SQLiteUpdateBuilder {\n  constructor(table, session, dialect, withList) {\n    this.table = table;\n    this.session = session;\n    this.dialect = dialect;\n    this.withList = withList;\n  }\n  static [entityKind] = \"SQLiteUpdateBuilder\";\n  set(values) {\n    return new SQLiteUpdateBase(\n      this.table,\n      mapUpdateSet(this.table, values),\n      this.session,\n      this.dialect,\n      this.withList\n    );\n  }\n}\nclass SQLiteUpdateBase extends QueryPromise {\n  constructor(table, set, session, dialect, withList) {\n    super();\n    this.session = session;\n    this.dialect = dialect;\n    this.config = { set, table, withList, joins: [] };\n  }\n  static [entityKind] = \"SQLiteUpdate\";\n  /** @internal */\n  config;\n  from(source) {\n    this.config.from = source;\n    return this;\n  }\n  createJoin(joinType) {\n    return (table, on) => {\n      const tableName = getTableLikeName(table);\n      if (typeof tableName === \"string\" && this.config.joins.some((join) => join.alias === tableName)) {\n        throw new Error(`Alias \"${tableName}\" is already used in this query`);\n      }\n      if (typeof on === \"function\") {\n        const from = this.config.from ? is(table, SQLiteTable) ? table[Table.Symbol.Columns] : is(table, Subquery) ? table._.selectedFields : is(table, SQLiteViewBase) ? table[ViewBaseConfig].selectedFields : void 0 : void 0;\n        on = on(\n          new Proxy(\n            this.config.table[Table.Symbol.Columns],\n            new SelectionProxyHandler({ sqlAliasedBehavior: \"sql\", sqlBehavior: \"sql\" })\n          ),\n          from && new Proxy(\n            from,\n            new SelectionProxyHandler({ sqlAliasedBehavior: \"sql\", sqlBehavior: \"sql\" })\n          )\n        );\n      }\n      this.config.joins.push({ on, table, joinType, alias: tableName });\n      return this;\n    };\n  }\n  leftJoin = this.createJoin(\"left\");\n  rightJoin = this.createJoin(\"right\");\n  innerJoin = this.createJoin(\"inner\");\n  fullJoin = this.createJoin(\"full\");\n  /**\n   * Adds a 'where' clause to the query.\n   *\n   * Calling this method will update only those rows that fulfill a specified condition.\n   *\n   * See docs: {@link https://orm.drizzle.team/docs/update}\n   *\n   * @param where the 'where' clause.\n   *\n   * @example\n   * You can use conditional operators and `sql function` to filter the rows to be updated.\n   *\n   * ```ts\n   * // Update all cars with green color\n   * db.update(cars).set({ color: 'red' })\n   *   .where(eq(cars.color, 'green'));\n   * // or\n   * db.update(cars).set({ color: 'red' })\n   *   .where(sql`${cars.color} = 'green'`)\n   * ```\n   *\n   * You can logically combine conditional operators with `and()` and `or()` operators:\n   *\n   * ```ts\n   * // Update all BMW cars with a green color\n   * db.update(cars).set({ color: 'red' })\n   *   .where(and(eq(cars.color, 'green'), eq(cars.brand, 'BMW')));\n   *\n   * // Update all cars with the green or blue color\n   * db.update(cars).set({ color: 'red' })\n   *   .where(or(eq(cars.color, 'green'), eq(cars.color, 'blue')));\n   * ```\n   */\n  where(where) {\n    this.config.where = where;\n    return this;\n  }\n  orderBy(...columns) {\n    if (typeof columns[0] === \"function\") {\n      const orderBy = columns[0](\n        new Proxy(\n          this.config.table[Table.Symbol.Columns],\n          new SelectionProxyHandler({ sqlAliasedBehavior: \"alias\", sqlBehavior: \"sql\" })\n        )\n      );\n      const orderByArray = Array.isArray(orderBy) ? orderBy : [orderBy];\n      this.config.orderBy = orderByArray;\n    } else {\n      const orderByArray = columns;\n      this.config.orderBy = orderByArray;\n    }\n    return this;\n  }\n  limit(limit) {\n    this.config.limit = limit;\n    return this;\n  }\n  returning(fields = this.config.table[SQLiteTable.Symbol.Columns]) {\n    this.config.returning = orderSelectedFields(fields);\n    return this;\n  }\n  /** @internal */\n  getSQL() {\n    return this.dialect.buildUpdateQuery(this.config);\n  }\n  toSQL() {\n    const { typings: _typings, ...rest } = this.dialect.sqlToQuery(this.getSQL());\n    return rest;\n  }\n  /** @internal */\n  _prepare(isOneTimeQuery = true) {\n    return this.session[isOneTimeQuery ? \"prepareOneTimeQuery\" : \"prepareQuery\"](\n      this.dialect.sqlToQuery(this.getSQL()),\n      this.config.returning,\n      this.config.returning ? \"all\" : \"run\",\n      true,\n      void 0,\n      {\n        type: \"insert\",\n        tables: extractUsedTable(this.config.table)\n      }\n    );\n  }\n  prepare() {\n    return this._prepare(false);\n  }\n  run = (placeholderValues) => {\n    return this._prepare().run(placeholderValues);\n  };\n  all = (placeholderValues) => {\n    return this._prepare().all(placeholderValues);\n  };\n  get = (placeholderValues) => {\n    return this._prepare().get(placeholderValues);\n  };\n  values = (placeholderValues) => {\n    return this._prepare().values(placeholderValues);\n  };\n  async execute() {\n    return this.config.returning ? this.all() : this.run();\n  }\n  $dynamic() {\n    return this;\n  }\n}\nexport {\n  SQLiteUpdateBase,\n  SQLiteUpdateBuilder\n};\n//# sourceMappingURL=update.js.map",
    "import { entityKind } from \"../../entity.js\";\nimport { SQL, sql } from \"../../sql/sql.js\";\nclass SQLiteCountBuilder extends SQL {\n  constructor(params) {\n    super(SQLiteCountBuilder.buildEmbeddedCount(params.source, params.filters).queryChunks);\n    this.params = params;\n    this.session = params.session;\n    this.sql = SQLiteCountBuilder.buildCount(\n      params.source,\n      params.filters\n    );\n  }\n  sql;\n  static [entityKind] = \"SQLiteCountBuilderAsync\";\n  [Symbol.toStringTag] = \"SQLiteCountBuilderAsync\";\n  session;\n  static buildEmbeddedCount(source, filters) {\n    return sql`(select count(*) from ${source}${sql.raw(\" where \").if(filters)}${filters})`;\n  }\n  static buildCount(source, filters) {\n    return sql`select count(*) from ${source}${sql.raw(\" where \").if(filters)}${filters}`;\n  }\n  then(onfulfilled, onrejected) {\n    return Promise.resolve(this.session.count(this.sql)).then(\n      onfulfilled,\n      onrejected\n    );\n  }\n  catch(onRejected) {\n    return this.then(void 0, onRejected);\n  }\n  finally(onFinally) {\n    return this.then(\n      (value) => {\n        onFinally?.();\n        return value;\n      },\n      (reason) => {\n        onFinally?.();\n        throw reason;\n      }\n    );\n  }\n}\nexport {\n  SQLiteCountBuilder\n};\n//# sourceMappingURL=count.js.map",
    "import { entityKind } from \"../../entity.js\";\nimport { QueryPromise } from \"../../query-promise.js\";\nimport {\n  mapRelationalRow\n} from \"../../relations.js\";\nclass RelationalQueryBuilder {\n  constructor(mode, fullSchema, schema, tableNamesMap, table, tableConfig, dialect, session) {\n    this.mode = mode;\n    this.fullSchema = fullSchema;\n    this.schema = schema;\n    this.tableNamesMap = tableNamesMap;\n    this.table = table;\n    this.tableConfig = tableConfig;\n    this.dialect = dialect;\n    this.session = session;\n  }\n  static [entityKind] = \"SQLiteAsyncRelationalQueryBuilder\";\n  findMany(config) {\n    return this.mode === \"sync\" ? new SQLiteSyncRelationalQuery(\n      this.fullSchema,\n      this.schema,\n      this.tableNamesMap,\n      this.table,\n      this.tableConfig,\n      this.dialect,\n      this.session,\n      config ? config : {},\n      \"many\"\n    ) : new SQLiteRelationalQuery(\n      this.fullSchema,\n      this.schema,\n      this.tableNamesMap,\n      this.table,\n      this.tableConfig,\n      this.dialect,\n      this.session,\n      config ? config : {},\n      \"many\"\n    );\n  }\n  findFirst(config) {\n    return this.mode === \"sync\" ? new SQLiteSyncRelationalQuery(\n      this.fullSchema,\n      this.schema,\n      this.tableNamesMap,\n      this.table,\n      this.tableConfig,\n      this.dialect,\n      this.session,\n      config ? { ...config, limit: 1 } : { limit: 1 },\n      \"first\"\n    ) : new SQLiteRelationalQuery(\n      this.fullSchema,\n      this.schema,\n      this.tableNamesMap,\n      this.table,\n      this.tableConfig,\n      this.dialect,\n      this.session,\n      config ? { ...config, limit: 1 } : { limit: 1 },\n      \"first\"\n    );\n  }\n}\nclass SQLiteRelationalQuery extends QueryPromise {\n  constructor(fullSchema, schema, tableNamesMap, table, tableConfig, dialect, session, config, mode) {\n    super();\n    this.fullSchema = fullSchema;\n    this.schema = schema;\n    this.tableNamesMap = tableNamesMap;\n    this.table = table;\n    this.tableConfig = tableConfig;\n    this.dialect = dialect;\n    this.session = session;\n    this.config = config;\n    this.mode = mode;\n  }\n  static [entityKind] = \"SQLiteAsyncRelationalQuery\";\n  /** @internal */\n  mode;\n  /** @internal */\n  getSQL() {\n    return this.dialect.buildRelationalQuery({\n      fullSchema: this.fullSchema,\n      schema: this.schema,\n      tableNamesMap: this.tableNamesMap,\n      table: this.table,\n      tableConfig: this.tableConfig,\n      queryConfig: this.config,\n      tableAlias: this.tableConfig.tsName\n    }).sql;\n  }\n  /** @internal */\n  _prepare(isOneTimeQuery = false) {\n    const { query, builtQuery } = this._toSQL();\n    return this.session[isOneTimeQuery ? \"prepareOneTimeQuery\" : \"prepareQuery\"](\n      builtQuery,\n      void 0,\n      this.mode === \"first\" ? \"get\" : \"all\",\n      true,\n      (rawRows, mapColumnValue) => {\n        const rows = rawRows.map(\n          (row) => mapRelationalRow(this.schema, this.tableConfig, row, query.selection, mapColumnValue)\n        );\n        if (this.mode === \"first\") {\n          return rows[0];\n        }\n        return rows;\n      }\n    );\n  }\n  prepare() {\n    return this._prepare(false);\n  }\n  _toSQL() {\n    const query = this.dialect.buildRelationalQuery({\n      fullSchema: this.fullSchema,\n      schema: this.schema,\n      tableNamesMap: this.tableNamesMap,\n      table: this.table,\n      tableConfig: this.tableConfig,\n      queryConfig: this.config,\n      tableAlias: this.tableConfig.tsName\n    });\n    const builtQuery = this.dialect.sqlToQuery(query.sql);\n    return { query, builtQuery };\n  }\n  toSQL() {\n    return this._toSQL().builtQuery;\n  }\n  /** @internal */\n  executeRaw() {\n    if (this.mode === \"first\") {\n      return this._prepare(false).get();\n    }\n    return this._prepare(false).all();\n  }\n  async execute() {\n    return this.executeRaw();\n  }\n}\nclass SQLiteSyncRelationalQuery extends SQLiteRelationalQuery {\n  static [entityKind] = \"SQLiteSyncRelationalQuery\";\n  sync() {\n    return this.executeRaw();\n  }\n}\nexport {\n  RelationalQueryBuilder,\n  SQLiteRelationalQuery,\n  SQLiteSyncRelationalQuery\n};\n//# sourceMappingURL=query.js.map",
    "import { entityKind } from \"../../entity.js\";\nimport { QueryPromise } from \"../../query-promise.js\";\nclass SQLiteRaw extends QueryPromise {\n  constructor(execute, getSQL, action, dialect, mapBatchResult) {\n    super();\n    this.execute = execute;\n    this.getSQL = getSQL;\n    this.dialect = dialect;\n    this.mapBatchResult = mapBatchResult;\n    this.config = { action };\n  }\n  static [entityKind] = \"SQLiteRaw\";\n  /** @internal */\n  config;\n  getQuery() {\n    return { ...this.dialect.sqlToQuery(this.getSQL()), method: this.config.action };\n  }\n  mapResult(result, isFromBatch) {\n    return isFromBatch ? this.mapBatchResult(result) : result;\n  }\n  _prepare() {\n    return this;\n  }\n  /** @internal */\n  isResponseInArrayMode() {\n    return false;\n  }\n}\nexport {\n  SQLiteRaw\n};\n//# sourceMappingURL=raw.js.map",
    "import { entityKind } from \"../entity.js\";\nimport { SelectionProxyHandler } from \"../selection-proxy.js\";\nimport { sql } from \"../sql/sql.js\";\nimport {\n  QueryBuilder,\n  SQLiteDeleteBase,\n  SQLiteInsertBuilder,\n  SQLiteSelectBuilder,\n  SQLiteUpdateBuilder\n} from \"./query-builders/index.js\";\nimport { WithSubquery } from \"../subquery.js\";\nimport { SQLiteCountBuilder } from \"./query-builders/count.js\";\nimport { RelationalQueryBuilder } from \"./query-builders/query.js\";\nimport { SQLiteRaw } from \"./query-builders/raw.js\";\nclass BaseSQLiteDatabase {\n  constructor(resultKind, dialect, session, schema) {\n    this.resultKind = resultKind;\n    this.dialect = dialect;\n    this.session = session;\n    this._ = schema ? {\n      schema: schema.schema,\n      fullSchema: schema.fullSchema,\n      tableNamesMap: schema.tableNamesMap\n    } : {\n      schema: void 0,\n      fullSchema: {},\n      tableNamesMap: {}\n    };\n    this.query = {};\n    const query = this.query;\n    if (this._.schema) {\n      for (const [tableName, columns] of Object.entries(this._.schema)) {\n        query[tableName] = new RelationalQueryBuilder(\n          resultKind,\n          schema.fullSchema,\n          this._.schema,\n          this._.tableNamesMap,\n          schema.fullSchema[tableName],\n          columns,\n          dialect,\n          session\n        );\n      }\n    }\n    this.$cache = { invalidate: async (_params) => {\n    } };\n  }\n  static [entityKind] = \"BaseSQLiteDatabase\";\n  query;\n  /**\n   * Creates a subquery that defines a temporary named result set as a CTE.\n   *\n   * It is useful for breaking down complex queries into simpler parts and for reusing the result set in subsequent parts of the query.\n   *\n   * See docs: {@link https://orm.drizzle.team/docs/select#with-clause}\n   *\n   * @param alias The alias for the subquery.\n   *\n   * Failure to provide an alias will result in a DrizzleTypeError, preventing the subquery from being referenced in other queries.\n   *\n   * @example\n   *\n   * ```ts\n   * // Create a subquery with alias 'sq' and use it in the select query\n   * const sq = db.$with('sq').as(db.select().from(users).where(eq(users.id, 42)));\n   *\n   * const result = await db.with(sq).select().from(sq);\n   * ```\n   *\n   * To select arbitrary SQL values as fields in a CTE and reference them in other CTEs or in the main query, you need to add aliases to them:\n   *\n   * ```ts\n   * // Select an arbitrary SQL value as a field in a CTE and reference it in the main query\n   * const sq = db.$with('sq').as(db.select({\n   *   name: sql<string>`upper(${users.name})`.as('name'),\n   * })\n   * .from(users));\n   *\n   * const result = await db.with(sq).select({ name: sq.name }).from(sq);\n   * ```\n   */\n  $with = (alias, selection) => {\n    const self = this;\n    const as = (qb) => {\n      if (typeof qb === \"function\") {\n        qb = qb(new QueryBuilder(self.dialect));\n      }\n      return new Proxy(\n        new WithSubquery(\n          qb.getSQL(),\n          selection ?? (\"getSelectedFields\" in qb ? qb.getSelectedFields() ?? {} : {}),\n          alias,\n          true\n        ),\n        new SelectionProxyHandler({ alias, sqlAliasedBehavior: \"alias\", sqlBehavior: \"error\" })\n      );\n    };\n    return { as };\n  };\n  $count(source, filters) {\n    return new SQLiteCountBuilder({ source, filters, session: this.session });\n  }\n  /**\n   * Incorporates a previously defined CTE (using `$with`) into the main query.\n   *\n   * This method allows the main query to reference a temporary named result set.\n   *\n   * See docs: {@link https://orm.drizzle.team/docs/select#with-clause}\n   *\n   * @param queries The CTEs to incorporate into the main query.\n   *\n   * @example\n   *\n   * ```ts\n   * // Define a subquery 'sq' as a CTE using $with\n   * const sq = db.$with('sq').as(db.select().from(users).where(eq(users.id, 42)));\n   *\n   * // Incorporate the CTE 'sq' into the main query and select from it\n   * const result = await db.with(sq).select().from(sq);\n   * ```\n   */\n  with(...queries) {\n    const self = this;\n    function select(fields) {\n      return new SQLiteSelectBuilder({\n        fields: fields ?? void 0,\n        session: self.session,\n        dialect: self.dialect,\n        withList: queries\n      });\n    }\n    function selectDistinct(fields) {\n      return new SQLiteSelectBuilder({\n        fields: fields ?? void 0,\n        session: self.session,\n        dialect: self.dialect,\n        withList: queries,\n        distinct: true\n      });\n    }\n    function update(table) {\n      return new SQLiteUpdateBuilder(table, self.session, self.dialect, queries);\n    }\n    function insert(into) {\n      return new SQLiteInsertBuilder(into, self.session, self.dialect, queries);\n    }\n    function delete_(from) {\n      return new SQLiteDeleteBase(from, self.session, self.dialect, queries);\n    }\n    return { select, selectDistinct, update, insert, delete: delete_ };\n  }\n  select(fields) {\n    return new SQLiteSelectBuilder({ fields: fields ?? void 0, session: this.session, dialect: this.dialect });\n  }\n  selectDistinct(fields) {\n    return new SQLiteSelectBuilder({\n      fields: fields ?? void 0,\n      session: this.session,\n      dialect: this.dialect,\n      distinct: true\n    });\n  }\n  /**\n   * Creates an update query.\n   *\n   * Calling this method without `.where()` clause will update all rows in a table. The `.where()` clause specifies which rows should be updated.\n   *\n   * Use `.set()` method to specify which values to update.\n   *\n   * See docs: {@link https://orm.drizzle.team/docs/update}\n   *\n   * @param table The table to update.\n   *\n   * @example\n   *\n   * ```ts\n   * // Update all rows in the 'cars' table\n   * await db.update(cars).set({ color: 'red' });\n   *\n   * // Update rows with filters and conditions\n   * await db.update(cars).set({ color: 'red' }).where(eq(cars.brand, 'BMW'));\n   *\n   * // Update with returning clause\n   * const updatedCar: Car[] = await db.update(cars)\n   *   .set({ color: 'red' })\n   *   .where(eq(cars.id, 1))\n   *   .returning();\n   * ```\n   */\n  update(table) {\n    return new SQLiteUpdateBuilder(table, this.session, this.dialect);\n  }\n  $cache;\n  /**\n   * Creates an insert query.\n   *\n   * Calling this method will create new rows in a table. Use `.values()` method to specify which values to insert.\n   *\n   * See docs: {@link https://orm.drizzle.team/docs/insert}\n   *\n   * @param table The table to insert into.\n   *\n   * @example\n   *\n   * ```ts\n   * // Insert one row\n   * await db.insert(cars).values({ brand: 'BMW' });\n   *\n   * // Insert multiple rows\n   * await db.insert(cars).values([{ brand: 'BMW' }, { brand: 'Porsche' }]);\n   *\n   * // Insert with returning clause\n   * const insertedCar: Car[] = await db.insert(cars)\n   *   .values({ brand: 'BMW' })\n   *   .returning();\n   * ```\n   */\n  insert(into) {\n    return new SQLiteInsertBuilder(into, this.session, this.dialect);\n  }\n  /**\n   * Creates a delete query.\n   *\n   * Calling this method without `.where()` clause will delete all rows in a table. The `.where()` clause specifies which rows should be deleted.\n   *\n   * See docs: {@link https://orm.drizzle.team/docs/delete}\n   *\n   * @param table The table to delete from.\n   *\n   * @example\n   *\n   * ```ts\n   * // Delete all rows in the 'cars' table\n   * await db.delete(cars);\n   *\n   * // Delete rows with filters and conditions\n   * await db.delete(cars).where(eq(cars.color, 'green'));\n   *\n   * // Delete with returning clause\n   * const deletedCar: Car[] = await db.delete(cars)\n   *   .where(eq(cars.id, 1))\n   *   .returning();\n   * ```\n   */\n  delete(from) {\n    return new SQLiteDeleteBase(from, this.session, this.dialect);\n  }\n  run(query) {\n    const sequel = typeof query === \"string\" ? sql.raw(query) : query.getSQL();\n    if (this.resultKind === \"async\") {\n      return new SQLiteRaw(\n        async () => this.session.run(sequel),\n        () => sequel,\n        \"run\",\n        this.dialect,\n        this.session.extractRawRunValueFromBatchResult.bind(this.session)\n      );\n    }\n    return this.session.run(sequel);\n  }\n  all(query) {\n    const sequel = typeof query === \"string\" ? sql.raw(query) : query.getSQL();\n    if (this.resultKind === \"async\") {\n      return new SQLiteRaw(\n        async () => this.session.all(sequel),\n        () => sequel,\n        \"all\",\n        this.dialect,\n        this.session.extractRawAllValueFromBatchResult.bind(this.session)\n      );\n    }\n    return this.session.all(sequel);\n  }\n  get(query) {\n    const sequel = typeof query === \"string\" ? sql.raw(query) : query.getSQL();\n    if (this.resultKind === \"async\") {\n      return new SQLiteRaw(\n        async () => this.session.get(sequel),\n        () => sequel,\n        \"get\",\n        this.dialect,\n        this.session.extractRawGetValueFromBatchResult.bind(this.session)\n      );\n    }\n    return this.session.get(sequel);\n  }\n  values(query) {\n    const sequel = typeof query === \"string\" ? sql.raw(query) : query.getSQL();\n    if (this.resultKind === \"async\") {\n      return new SQLiteRaw(\n        async () => this.session.values(sequel),\n        () => sequel,\n        \"values\",\n        this.dialect,\n        this.session.extractRawValuesValueFromBatchResult.bind(this.session)\n      );\n    }\n    return this.session.values(sequel);\n  }\n  transaction(transaction, config) {\n    return this.session.transaction(transaction, config);\n  }\n}\nconst withReplicas = (primary, replicas, getReplica = () => replicas[Math.floor(Math.random() * replicas.length)]) => {\n  const select = (...args) => getReplica(replicas).select(...args);\n  const selectDistinct = (...args) => getReplica(replicas).selectDistinct(...args);\n  const $count = (...args) => getReplica(replicas).$count(...args);\n  const $with = (...args) => getReplica(replicas).with(...args);\n  const update = (...args) => primary.update(...args);\n  const insert = (...args) => primary.insert(...args);\n  const $delete = (...args) => primary.delete(...args);\n  const run = (...args) => primary.run(...args);\n  const all = (...args) => primary.all(...args);\n  const get = (...args) => primary.get(...args);\n  const values = (...args) => primary.values(...args);\n  const transaction = (...args) => primary.transaction(...args);\n  return {\n    ...primary,\n    update,\n    insert,\n    delete: $delete,\n    run,\n    all,\n    get,\n    values,\n    transaction,\n    $primary: primary,\n    select,\n    selectDistinct,\n    $count,\n    with: $with,\n    get query() {\n      return getReplica(replicas).query;\n    }\n  };\n};\nexport {\n  BaseSQLiteDatabase,\n  withReplicas\n};\n//# sourceMappingURL=db.js.map",
    "import { entityKind } from \"../../entity.js\";\nclass Cache {\n  static [entityKind] = \"Cache\";\n}\nclass NoopCache extends Cache {\n  strategy() {\n    return \"all\";\n  }\n  static [entityKind] = \"NoopCache\";\n  async get(_key) {\n    return void 0;\n  }\n  async put(_hashedQuery, _response, _tables, _config) {\n  }\n  async onMutate(_params) {\n  }\n}\nasync function hashQuery(sql, params) {\n  const dataToHash = `${sql}-${JSON.stringify(params)}`;\n  const encoder = new TextEncoder();\n  const data = encoder.encode(dataToHash);\n  const hashBuffer = await crypto.subtle.digest(\"SHA-256\", data);\n  const hashArray = [...new Uint8Array(hashBuffer)];\n  const hashHex = hashArray.map((b) => b.toString(16).padStart(2, \"0\")).join(\"\");\n  return hashHex;\n}\nexport {\n  Cache,\n  NoopCache,\n  hashQuery\n};\n//# sourceMappingURL=cache.js.map",
    "import { hashQuery, NoopCache } from \"../cache/core/cache.js\";\nimport { entityKind, is } from \"../entity.js\";\nimport { DrizzleError, DrizzleQueryError, TransactionRollbackError } from \"../errors.js\";\nimport { QueryPromise } from \"../query-promise.js\";\nimport { BaseSQLiteDatabase } from \"./db.js\";\nclass ExecuteResultSync extends QueryPromise {\n  constructor(resultCb) {\n    super();\n    this.resultCb = resultCb;\n  }\n  static [entityKind] = \"ExecuteResultSync\";\n  async execute() {\n    return this.resultCb();\n  }\n  sync() {\n    return this.resultCb();\n  }\n}\nclass SQLitePreparedQuery {\n  constructor(mode, executeMethod, query, cache, queryMetadata, cacheConfig) {\n    this.mode = mode;\n    this.executeMethod = executeMethod;\n    this.query = query;\n    this.cache = cache;\n    this.queryMetadata = queryMetadata;\n    this.cacheConfig = cacheConfig;\n    if (cache && cache.strategy() === \"all\" && cacheConfig === void 0) {\n      this.cacheConfig = { enable: true, autoInvalidate: true };\n    }\n    if (!this.cacheConfig?.enable) {\n      this.cacheConfig = void 0;\n    }\n  }\n  static [entityKind] = \"PreparedQuery\";\n  /** @internal */\n  joinsNotNullableMap;\n  /** @internal */\n  async queryWithCache(queryString, params, query) {\n    if (this.cache === void 0 || is(this.cache, NoopCache) || this.queryMetadata === void 0) {\n      try {\n        return await query();\n      } catch (e) {\n        throw new DrizzleQueryError(queryString, params, e);\n      }\n    }\n    if (this.cacheConfig && !this.cacheConfig.enable) {\n      try {\n        return await query();\n      } catch (e) {\n        throw new DrizzleQueryError(queryString, params, e);\n      }\n    }\n    if ((this.queryMetadata.type === \"insert\" || this.queryMetadata.type === \"update\" || this.queryMetadata.type === \"delete\") && this.queryMetadata.tables.length > 0) {\n      try {\n        const [res] = await Promise.all([\n          query(),\n          this.cache.onMutate({ tables: this.queryMetadata.tables })\n        ]);\n        return res;\n      } catch (e) {\n        throw new DrizzleQueryError(queryString, params, e);\n      }\n    }\n    if (!this.cacheConfig) {\n      try {\n        return await query();\n      } catch (e) {\n        throw new DrizzleQueryError(queryString, params, e);\n      }\n    }\n    if (this.queryMetadata.type === \"select\") {\n      const fromCache = await this.cache.get(\n        this.cacheConfig.tag ?? (await hashQuery(queryString, params)),\n        this.queryMetadata.tables,\n        this.cacheConfig.tag !== void 0,\n        this.cacheConfig.autoInvalidate\n      );\n      if (fromCache === void 0) {\n        let result;\n        try {\n          result = await query();\n        } catch (e) {\n          throw new DrizzleQueryError(queryString, params, e);\n        }\n        await this.cache.put(\n          this.cacheConfig.tag ?? (await hashQuery(queryString, params)),\n          result,\n          // make sure we send tables that were used in a query only if user wants to invalidate it on each write\n          this.cacheConfig.autoInvalidate ? this.queryMetadata.tables : [],\n          this.cacheConfig.tag !== void 0,\n          this.cacheConfig.config\n        );\n        return result;\n      }\n      return fromCache;\n    }\n    try {\n      return await query();\n    } catch (e) {\n      throw new DrizzleQueryError(queryString, params, e);\n    }\n  }\n  getQuery() {\n    return this.query;\n  }\n  mapRunResult(result, _isFromBatch) {\n    return result;\n  }\n  mapAllResult(_result, _isFromBatch) {\n    throw new Error(\"Not implemented\");\n  }\n  mapGetResult(_result, _isFromBatch) {\n    throw new Error(\"Not implemented\");\n  }\n  execute(placeholderValues) {\n    if (this.mode === \"async\") {\n      return this[this.executeMethod](placeholderValues);\n    }\n    return new ExecuteResultSync(() => this[this.executeMethod](placeholderValues));\n  }\n  mapResult(response, isFromBatch) {\n    switch (this.executeMethod) {\n      case \"run\": {\n        return this.mapRunResult(response, isFromBatch);\n      }\n      case \"all\": {\n        return this.mapAllResult(response, isFromBatch);\n      }\n      case \"get\": {\n        return this.mapGetResult(response, isFromBatch);\n      }\n    }\n  }\n}\nclass SQLiteSession {\n  constructor(dialect) {\n    this.dialect = dialect;\n  }\n  static [entityKind] = \"SQLiteSession\";\n  prepareOneTimeQuery(query, fields, executeMethod, isResponseInArrayMode, customResultMapper, queryMetadata, cacheConfig) {\n    return this.prepareQuery(\n      query,\n      fields,\n      executeMethod,\n      isResponseInArrayMode,\n      customResultMapper,\n      queryMetadata,\n      cacheConfig\n    );\n  }\n  run(query) {\n    const staticQuery = this.dialect.sqlToQuery(query);\n    try {\n      return this.prepareOneTimeQuery(staticQuery, void 0, \"run\", false).run();\n    } catch (err) {\n      throw new DrizzleError({ cause: err, message: `Failed to run the query '${staticQuery.sql}'` });\n    }\n  }\n  /** @internal */\n  extractRawRunValueFromBatchResult(result) {\n    return result;\n  }\n  all(query) {\n    return this.prepareOneTimeQuery(this.dialect.sqlToQuery(query), void 0, \"run\", false).all();\n  }\n  /** @internal */\n  extractRawAllValueFromBatchResult(_result) {\n    throw new Error(\"Not implemented\");\n  }\n  get(query) {\n    return this.prepareOneTimeQuery(this.dialect.sqlToQuery(query), void 0, \"run\", false).get();\n  }\n  /** @internal */\n  extractRawGetValueFromBatchResult(_result) {\n    throw new Error(\"Not implemented\");\n  }\n  values(query) {\n    return this.prepareOneTimeQuery(this.dialect.sqlToQuery(query), void 0, \"run\", false).values();\n  }\n  async count(sql) {\n    const result = await this.values(sql);\n    return result[0][0];\n  }\n  /** @internal */\n  extractRawValuesValueFromBatchResult(_result) {\n    throw new Error(\"Not implemented\");\n  }\n}\nclass SQLiteTransaction extends BaseSQLiteDatabase {\n  constructor(resultType, dialect, session, schema, nestedIndex = 0) {\n    super(resultType, dialect, session, schema);\n    this.schema = schema;\n    this.nestedIndex = nestedIndex;\n  }\n  static [entityKind] = \"SQLiteTransaction\";\n  rollback() {\n    throw new TransactionRollbackError();\n  }\n}\nexport {\n  ExecuteResultSync,\n  SQLitePreparedQuery,\n  SQLiteSession,\n  SQLiteTransaction\n};\n//# sourceMappingURL=session.js.map",
    "import { entityKind } from \"./entity.js\";\nclass ConsoleLogWriter {\n  static [entityKind] = \"ConsoleLogWriter\";\n  write(message) {\n    console.log(message);\n  }\n}\nclass DefaultLogger {\n  static [entityKind] = \"DefaultLogger\";\n  writer;\n  constructor(config) {\n    this.writer = config?.writer ?? new ConsoleLogWriter();\n  }\n  logQuery(query, params) {\n    const stringifiedParams = params.map((p) => {\n      try {\n        return JSON.stringify(p);\n      } catch {\n        return String(p);\n      }\n    });\n    const paramsStr = stringifiedParams.length ? ` -- params: [${stringifiedParams.join(\", \")}]` : \"\";\n    this.writer.write(`Query: ${query}${paramsStr}`);\n  }\n}\nclass NoopLogger {\n  static [entityKind] = \"NoopLogger\";\n  logQuery() {\n  }\n}\nexport {\n  ConsoleLogWriter,\n  DefaultLogger,\n  NoopLogger\n};\n//# sourceMappingURL=logger.js.map",
    "import { __export } from \"../_virtual/rolldown_runtime.js\";\nimport { index, integer, real, sqliteTable, text } from \"drizzle-orm/sqlite-core\";\nimport { relations } from \"drizzle-orm\";\n\n//#region src/db/schema.ts\nvar schema_exports = {};\n__export(schema_exports, {\n\tcharacters: () => characters,\n\tcharactersRelations: () => charactersRelations,\n\tminingFleetParticipants: () => miningFleetParticipants,\n\tminingFleetParticipantsRelations: () => miningFleetParticipantsRelations,\n\tminingFleets: () => miningFleets,\n\tminingFleetsRelations: () => miningFleetsRelations,\n\tresumeCommands: () => resumeCommands,\n\tshared: () => shared,\n\tusers: () => users,\n\tusersRelations: () => usersRelations\n});\nconst shared = {\n\tcreatedAt: integer(\"created_at\").notNull(),\n\tupdatedAt: integer(\"updated_at\")\n};\nconst users = sqliteTable(\"users\", {\n\tid: integer().primaryKey().unique().notNull(),\n\tdiscordID: text(\"discord_id\").unique().notNull(),\n\tmainCharacter: integer(\"main_character\"),\n\t...shared\n}, (table) => [index(\"idx_discord_id\").on(table.discordID), index(\"idx_main_character\").on(table.mainCharacter)]);\nconst usersRelations = relations(users, ({ one, many }) => ({\n\tcharacters: many(characters),\n\tmain: one(characters, {\n\t\tfields: [users.mainCharacter],\n\t\treferences: [characters.id]\n\t})\n}));\nconst characters = sqliteTable(\"characters\", {\n\tid: integer(\"id\").primaryKey({ autoIncrement: true }),\n\teveID: integer(\"eve_id\").notNull(),\n\tuserID: integer(\"user_id\").notNull(),\n\tname: text().notNull(),\n\taccessToken: text(\"access_token\").notNull(),\n\texpiresAt: integer(\"expires_at\").notNull(),\n\trefreshToken: text(\"refresh_token\").notNull(),\n\t...shared\n}, (table) => [index(\"idx_user_id\").on(table.userID), index(\"idx_eve_id\").on(table.eveID)]);\nconst charactersRelations = relations(characters, ({ one }) => ({ user: one(users, {\n\tfields: [characters.userID],\n\treferences: [users.id]\n}) }));\nconst resumeCommands = sqliteTable(\"resumecommands\", {\n\tid: text().primaryKey(),\n\tcommand: text().notNull(),\n\tparams: text().notNull(),\n\tcontext: text().notNull(),\n\t...shared\n});\nconst miningFleets = sqliteTable(\"mining_fleets\", {\n\tid: integer(\"id\").primaryKey({ autoIncrement: true }),\n\tname: text(\"name\").notNull(),\n\tdescription: text(\"description\"),\n\tcreatorDiscordId: text(\"creator_discord_id\").notNull(),\n\tstartTime: integer(\"start_time\").notNull(),\n\tendTime: integer(\"end_time\"),\n\tstatus: text(\"status\", { enum: [\n\t\t\"configuring\",\n\t\t\"active\",\n\t\t\"ended\",\n\t\t\"generating_report\",\n\t\t\"completed\",\n\t\t\"failed\"\n\t] }).notNull().default(\"configuring\"),\n\ttaxRate: real(\"tax_rate\").notNull().default(0),\n\tpublicMessageId: text(\"public_message_id\").unique(),\n\tpublicChannelId: text(\"public_channel_id\"),\n\treportData: text(\"report_data\"),\n\tcreatorEphemeralMessageId: text(\"creator_ephemeral_message_id\"),\n\t...shared\n}, (table) => [\n\tindex(\"idx_fleet_creator_discord_id\").on(table.creatorDiscordId),\n\tindex(\"idx_fleet_status\").on(table.status),\n\tindex(\"idx_fleet_public_message_id\").on(table.publicMessageId)\n]);\nconst miningFleetParticipants = sqliteTable(\"mining_fleet_participants\", {\n\tid: integer(\"id\").primaryKey({ autoIncrement: true }),\n\tfleetId: integer(\"fleet_id\").notNull().references(() => miningFleets.id, { onDelete: \"cascade\" }),\n\tcharacterId: integer(\"character_id\").notNull().references(() => characters.id, { onDelete: \"cascade\" }),\n\tdiscordId: text(\"discord_id\").notNull(),\n\trole: text(\"role\", { enum: [\n\t\t\"miner\",\n\t\t\"security\",\n\t\t\"hauler\"\n\t] }).notNull(),\n\tjoinTime: integer(\"join_time\").notNull(),\n\t...shared\n}, (table) => [\n\tindex(\"idx_participant_fleet_id\").on(table.fleetId),\n\tindex(\"idx_participant_character_id\").on(table.characterId),\n\tindex(\"idx_participant_discord_id\").on(table.discordId)\n]);\nconst miningFleetsRelations = relations(miningFleets, ({ many }) => ({ participants: many(miningFleetParticipants) }));\nconst miningFleetParticipantsRelations = relations(miningFleetParticipants, ({ one }) => ({\n\tfleet: one(miningFleets, {\n\t\tfields: [miningFleetParticipants.fleetId],\n\t\treferences: [miningFleets.id]\n\t}),\n\tcharacter: one(characters, {\n\t\tfields: [miningFleetParticipants.characterId],\n\t\treferences: [characters.id]\n\t})\n}));\n\n//#endregion\nexport { characters, miningFleetParticipants, miningFleets, resumeCommands, schema_exports, users };",
    "import { characters, users } from \"../schema.js\";\nimport { CharacterHelper } from \"./character.model.js\";\nimport { db } from \"../index.js\";\nimport { eq, sql } from \"drizzle-orm\";\n\n//#region src/db/models/user.model.ts\nvar UserHelper = class {\n\tstatic find(id) {\n\t\tconst result = db.select({\n\t\t\tid: users.id,\n\t\t\tdiscordID: users.discordID,\n\t\t\tcreatedAt: users.createdAt,\n\t\t\tupdatedAt: users.updatedAt,\n\t\t\tmainCharacterID: users.mainCharacter,\n\t\t\tcharacterIDsString: sql`json_group_array(characters.id)`\n\t\t}).from(users).where(eq(users.id, id)).leftJoin(characters, eq(users.id, characters.userID)).get();\n\t\treturn this.createFromQuery(result);\n\t}\n\tstatic findByDiscordId(id) {\n\t\tconst result = db.select({\n\t\t\tid: users.id,\n\t\t\tdiscordID: users.discordID,\n\t\t\tcreatedAt: users.createdAt,\n\t\t\tupdatedAt: users.updatedAt,\n\t\t\tmainCharacterID: users.mainCharacter,\n\t\t\tcharacterIDsString: sql`json_group_array(characters.id)`\n\t\t}).from(users).where(eq(users.discordID, id)).leftJoin(characters, eq(users.id, characters.userID)).get();\n\t\treturn this.createFromQuery(result);\n\t}\n\tstatic findAll() {\n\t\tconst result = db.select({\n\t\t\tid: users.id,\n\t\t\tdiscordID: users.discordID,\n\t\t\tcreatedAt: users.createdAt,\n\t\t\tupdatedAt: users.updatedAt,\n\t\t\tmainCharacterID: users.mainCharacter,\n\t\t\tcharacterIDsString: sql`json_group_array(characters.id)`\n\t\t}).from(users).leftJoin(characters, eq(users.id, characters.userID)).all();\n\t\treturn this.createFromQuery(result);\n\t}\n\tstatic findByCharacterId(id) {\n\t\tconst result = db.select({\n\t\t\tid: users.id,\n\t\t\tdiscordID: users.discordID,\n\t\t\tcreatedAt: users.createdAt,\n\t\t\tupdatedAt: users.updatedAt,\n\t\t\tmainCharacterID: users.mainCharacter,\n\t\t\tcharacterIDsString: sql`json_group_array(characters.id)`\n\t\t}).from(users).leftJoin(characters, eq(users.id, characters.userID)).where(eq(characters.id, id)).all();\n\t\treturn this.createFromQuery(result);\n\t}\n\tstatic findByCharacterName(name) {\n\t\tconst result = db.select({\n\t\t\tid: users.id,\n\t\t\tdiscordID: users.discordID,\n\t\t\tcreatedAt: users.createdAt,\n\t\t\tupdatedAt: users.updatedAt,\n\t\t\tmainCharacterID: users.mainCharacter,\n\t\t\tcharacterIDsString: sql`json_group_array(characters.id)`\n\t\t}).from(users).leftJoin(characters, eq(users.id, characters.userID)).where(eq(characters.name, name)).all();\n\t\treturn this.createFromQuery(result);\n\t}\n\tstatic createFromQuery(query) {\n\t\tif (!query) return [];\n\t\tif (Array.isArray(query)) return query.map((user) => {\n\t\t\treturn {\n\t\t\t\tid: user.id,\n\t\t\t\tdiscordID: user.discordID,\n\t\t\t\tcreatedAt: new Date(user.createdAt),\n\t\t\t\tupdatedAt: new Date(user.updatedAt),\n\t\t\t\tcharacterIDs: user.characterIDsString ? JSON.parse(user.characterIDsString ?? \"[]\").map((s) => Number(s)).sort() : [],\n\t\t\t\tmainCharacterID: user.mainCharacterID\n\t\t\t};\n\t\t});\n\t\telse return {\n\t\t\tid: query.id,\n\t\t\tdiscordID: query.discordID,\n\t\t\tcreatedAt: new Date(query.createdAt),\n\t\t\tupdatedAt: new Date(query.updatedAt),\n\t\t\tcharacterIDs: query.characterIDsString ? JSON.parse(query.characterIDsString ?? \"[]\").map((s) => Number(s)).sort() : [],\n\t\t\tmainCharacterID: query.mainCharacterID\n\t\t};\n\t}\n\tstatic create(discordID) {\n\t\tthis.save({\n\t\t\tdiscordID,\n\t\t\tcreatedAt: /* @__PURE__ */ new Date(),\n\t\t\tupdatedAt: /* @__PURE__ */ new Date()\n\t\t});\n\t\treturn this.findByDiscordId(discordID);\n\t}\n\tstatic save(user) {\n\t\tdb.insert(users).values({\n\t\t\tid: user.id,\n\t\t\tdiscordID: user.discordID,\n\t\t\tmainCharacter: user.mainCharacterID,\n\t\t\tcreatedAt: user.createdAt.getTime(),\n\t\t\tupdatedAt: user.updatedAt.getTime()\n\t\t}).onConflictDoUpdate({\n\t\t\ttarget: users.id,\n\t\t\tset: {\n\t\t\t\tdiscordID: user.discordID,\n\t\t\t\tmainCharacter: user.mainCharacterID,\n\t\t\t\tupdatedAt: user.updatedAt.getTime()\n\t\t\t}\n\t\t}).run();\n\t\treturn user;\n\t}\n\tstatic delete(user) {\n\t\tdb.delete(users).where(eq(users.id, user.id)).run();\n\t}\n\tstatic getCharacter(user, index) {\n\t\tif (!user.characterIDs) return void 0;\n\t\tif (index >= user.characterIDs.length) return void 0;\n\t\treturn CharacterHelper.find(user.characterIDs[index]);\n\t}\n};\n\n//#endregion\nexport { UserHelper };",
    "import { resumeCommands } from \"../schema.js\";\nimport { db } from \"../index.js\";\nimport { eq } from \"drizzle-orm\";\n\n//#region src/db/models/resume-command.model.ts\nvar ResumeCommand = class ResumeCommand {\n\tid;\n\tcommand;\n\tparams;\n\tcontext;\n\tcreated = /* @__PURE__ */ new Date();\n\tconstructor() {\n\t\tthis.created = /* @__PURE__ */ new Date();\n\t}\n\tstatic find(messageId) {\n\t\tconst result = db.select().from(resumeCommands).where(eq(resumeCommands.id, messageId)).get();\n\t\treturn this.createFromQuery(result);\n\t}\n\tstatic create(messageId, command, params = {}, context = {}) {\n\t\tconst resume = new ResumeCommand();\n\t\tresume.id = messageId;\n\t\tresume.command = command;\n\t\tresume.params = JSON.stringify(params);\n\t\tresume.context = JSON.stringify(context);\n\t\treturn resume;\n\t}\n\tstatic createFromQuery(query) {\n\t\tif (!query) return null;\n\t\tconst resume = new ResumeCommand();\n\t\tresume.id = query.id;\n\t\tresume.command = query.command;\n\t\tresume.params = query.params;\n\t\tresume.context = query.context;\n\t\tresume.created = query.created;\n\t\treturn resume;\n\t}\n\tsave() {\n\t\tdb.insert(resumeCommands).values({\n\t\t\tid: this.id,\n\t\t\tcommand: this.command,\n\t\t\tparams: this.params,\n\t\t\tcontext: this.context,\n\t\t\tcreatedAt: this.created.getTime()\n\t\t}).onConflictDoUpdate({\n\t\t\ttarget: resumeCommands.id,\n\t\t\tset: {\n\t\t\t\tcommand: this.command,\n\t\t\t\tparams: this.params,\n\t\t\t\tcontext: this.context\n\t\t\t}\n\t\t}).run();\n\t\treturn this;\n\t}\n\tdelete() {\n\t\tdb.delete(resumeCommands).where(eq(resumeCommands.id, this.id)).run();\n\t}\n\tstatic delete(messageId) {\n\t\tdb.delete(resumeCommands).where(eq(resumeCommands.id, messageId)).run();\n\t}\n};\n\n//#endregion\nexport { ResumeCommand };",
    "import { __export } from \"../../_virtual/rolldown_runtime.js\";\nimport { CharacterHelper } from \"./character.model.js\";\nimport { UserHelper } from \"./user.model.js\";\nimport { ResumeCommand } from \"./resume-command.model.js\";\n\n//#region src/db/models/index.ts\nvar models_exports = {};\n__export(models_exports, {\n\tCharacterHelper: () => CharacterHelper,\n\tResumeCommand: () => ResumeCommand,\n\tUserHelper: () => UserHelper\n});\n\n//#endregion\nexport { models_exports };",
    "import { Database } from \"bun:sqlite\";\nimport { entityKind } from \"../entity.js\";\nimport { DefaultLogger } from \"../logger.js\";\nimport {\n  createTableRelationsHelpers,\n  extractTablesRelationalConfig\n} from \"../relations.js\";\nimport { BaseSQLiteDatabase } from \"../sqlite-core/db.js\";\nimport { SQLiteSyncDialect } from \"../sqlite-core/dialect.js\";\nimport { isConfig } from \"../utils.js\";\nimport { SQLiteBunSession } from \"./session.js\";\nclass BunSQLiteDatabase extends BaseSQLiteDatabase {\n  static [entityKind] = \"BunSQLiteDatabase\";\n}\nfunction construct(client, config = {}) {\n  const dialect = new SQLiteSyncDialect({ casing: config.casing });\n  let logger;\n  if (config.logger === true) {\n    logger = new DefaultLogger();\n  } else if (config.logger !== false) {\n    logger = config.logger;\n  }\n  let schema;\n  if (config.schema) {\n    const tablesConfig = extractTablesRelationalConfig(\n      config.schema,\n      createTableRelationsHelpers\n    );\n    schema = {\n      fullSchema: config.schema,\n      schema: tablesConfig.tables,\n      tableNamesMap: tablesConfig.tableNamesMap\n    };\n  }\n  const session = new SQLiteBunSession(client, dialect, schema, { logger });\n  const db = new BunSQLiteDatabase(\"sync\", dialect, session, schema);\n  db.$client = client;\n  return db;\n}\nfunction drizzle(...params) {\n  if (params[0] === void 0 || typeof params[0] === \"string\") {\n    const instance = params[0] === void 0 ? new Database() : new Database(params[0]);\n    return construct(instance, params[1]);\n  }\n  if (isConfig(params[0])) {\n    const { connection, client, ...drizzleConfig } = params[0];\n    if (client) return construct(client, drizzleConfig);\n    if (typeof connection === \"object\") {\n      const { source, ...opts } = connection;\n      const options = Object.values(opts).filter((v) => v !== void 0).length ? opts : void 0;\n      const instance2 = new Database(source, options);\n      return construct(instance2, drizzleConfig);\n    }\n    const instance = new Database(connection);\n    return construct(instance, drizzleConfig);\n  }\n  return construct(params[0], params[1]);\n}\n((drizzle2) => {\n  function mock(config) {\n    return construct({}, config);\n  }\n  drizzle2.mock = mock;\n})(drizzle || (drizzle = {}));\nexport {\n  BunSQLiteDatabase,\n  drizzle\n};\n//# sourceMappingURL=driver.js.map",
    "import { entityKind } from \"../entity.js\";\nimport { NoopLogger } from \"../logger.js\";\nimport { fillPlaceholders, sql } from \"../sql/sql.js\";\nimport { SQLiteTransaction } from \"../sqlite-core/index.js\";\nimport { SQLitePreparedQuery as PreparedQueryBase, SQLiteSession } from \"../sqlite-core/session.js\";\nimport { mapResultRow } from \"../utils.js\";\nclass SQLiteBunSession extends SQLiteSession {\n  constructor(client, dialect, schema, options = {}) {\n    super(dialect);\n    this.client = client;\n    this.schema = schema;\n    this.logger = options.logger ?? new NoopLogger();\n  }\n  static [entityKind] = \"SQLiteBunSession\";\n  logger;\n  exec(query) {\n    this.client.exec(query);\n  }\n  prepareQuery(query, fields, executeMethod, isResponseInArrayMode, customResultMapper) {\n    const stmt = this.client.prepare(query.sql);\n    return new PreparedQuery(\n      stmt,\n      query,\n      this.logger,\n      fields,\n      executeMethod,\n      isResponseInArrayMode,\n      customResultMapper\n    );\n  }\n  transaction(transaction, config = {}) {\n    const tx = new SQLiteBunTransaction(\"sync\", this.dialect, this, this.schema);\n    let result;\n    const nativeTx = this.client.transaction(() => {\n      result = transaction(tx);\n    });\n    nativeTx[config.behavior ?? \"deferred\"]();\n    return result;\n  }\n}\nclass SQLiteBunTransaction extends SQLiteTransaction {\n  static [entityKind] = \"SQLiteBunTransaction\";\n  transaction(transaction) {\n    const savepointName = `sp${this.nestedIndex}`;\n    const tx = new SQLiteBunTransaction(\"sync\", this.dialect, this.session, this.schema, this.nestedIndex + 1);\n    this.session.run(sql.raw(`savepoint ${savepointName}`));\n    try {\n      const result = transaction(tx);\n      this.session.run(sql.raw(`release savepoint ${savepointName}`));\n      return result;\n    } catch (err) {\n      this.session.run(sql.raw(`rollback to savepoint ${savepointName}`));\n      throw err;\n    }\n  }\n}\nclass PreparedQuery extends PreparedQueryBase {\n  constructor(stmt, query, logger, fields, executeMethod, _isResponseInArrayMode, customResultMapper) {\n    super(\"sync\", executeMethod, query);\n    this.stmt = stmt;\n    this.logger = logger;\n    this.fields = fields;\n    this._isResponseInArrayMode = _isResponseInArrayMode;\n    this.customResultMapper = customResultMapper;\n  }\n  static [entityKind] = \"SQLiteBunPreparedQuery\";\n  run(placeholderValues) {\n    const params = fillPlaceholders(this.query.params, placeholderValues ?? {});\n    this.logger.logQuery(this.query.sql, params);\n    return this.stmt.run(...params);\n  }\n  all(placeholderValues) {\n    const { fields, query, logger, joinsNotNullableMap, stmt, customResultMapper } = this;\n    if (!fields && !customResultMapper) {\n      const params = fillPlaceholders(query.params, placeholderValues ?? {});\n      logger.logQuery(query.sql, params);\n      return stmt.all(...params);\n    }\n    const rows = this.values(placeholderValues);\n    if (customResultMapper) {\n      return customResultMapper(rows);\n    }\n    return rows.map((row) => mapResultRow(fields, row, joinsNotNullableMap));\n  }\n  get(placeholderValues) {\n    const params = fillPlaceholders(this.query.params, placeholderValues ?? {});\n    this.logger.logQuery(this.query.sql, params);\n    const row = this.stmt.values(...params)[0];\n    if (!row) {\n      return void 0;\n    }\n    const { fields, joinsNotNullableMap, customResultMapper } = this;\n    if (!fields && !customResultMapper) {\n      return row;\n    }\n    if (customResultMapper) {\n      return customResultMapper([row]);\n    }\n    return mapResultRow(fields, row, joinsNotNullableMap);\n  }\n  values(placeholderValues) {\n    const params = fillPlaceholders(this.query.params, placeholderValues ?? {});\n    this.logger.logQuery(this.query.sql, params);\n    return this.stmt.values(...params);\n  }\n  /** @internal */\n  isResponseInArrayMode() {\n    return this._isResponseInArrayMode;\n  }\n}\nexport {\n  PreparedQuery,\n  SQLiteBunSession,\n  SQLiteBunTransaction\n};\n//# sourceMappingURL=session.js.map",
    "import { characters, miningFleetParticipants, miningFleets, resumeCommands, schema_exports, users } from \"./schema.js\";\nimport { CharacterHelper } from \"./models/character.model.js\";\nimport { UserHelper } from \"./models/user.model.js\";\nimport { ResumeCommand } from \"./models/resume-command.model.js\";\nimport { models_exports } from \"./models/index.js\";\nimport { drizzle } from \"drizzle-orm/bun-sqlite\";\nimport { Database } from \"bun:sqlite\";\nimport { join } from \"node:path\";\n\n//#region src/db/index.ts\nconst DB_PATH = process.env.AUTH_DB_PATH || join(process.cwd(), \"../../db/kitten.db\");\nconsole.log(\"Using DB_PATH:\", DB_PATH);\nconst sqlite = new Database(DB_PATH);\nconst db = drizzle(sqlite, { schema: {\n\tusers,\n\tcharacters,\n\tresumeCommands,\n\tminingFleets,\n\tminingFleetParticipants\n} });\n\n//#endregion\nexport { CharacterHelper, DB_PATH, ResumeCommand, UserHelper, db, models_exports as models, schema_exports as schema };",
    "import { characters } from \"../schema.js\";\nimport { refresh, validateToken } from \"../../esi/auth.js\";\nimport { db } from \"../index.js\";\nimport { and, eq } from \"drizzle-orm\";\nimport { jwtDecode } from \"jwt-decode\";\n\n//#region src/db/models/character.model.ts\nvar CharacterHelper = class CharacterHelper {\n\tstatic hasValidToken(character) {\n\t\treturn /* @__PURE__ */ new Date() < character.expiresAt;\n\t}\n\tstatic getScopes(character) {\n\t\tconst decoded = jwtDecode(character.accessToken);\n\t\treturn typeof decoded.scp === \"string\" ? [decoded.scp] : decoded.scp;\n\t}\n\tstatic hasOnlyPublicScope(character) {\n\t\treturn this.getScopes(character).length === 1 && this.hasScope(character, \"publicData\");\n\t}\n\tstatic getTokens(character) {\n\t\treturn {\n\t\t\taccess_token: character.accessToken,\n\t\t\trefresh_token: character.refreshToken,\n\t\t\texpires_in: (character.expiresAt.getTime() - Date.now()) / 1e3\n\t\t};\n\t}\n\tstatic hasScope(character, scope) {\n\t\treturn this.getScopes(character).includes(scope);\n\t}\n\tstatic hasAllScopes(character, scopes) {\n\t\tconst has = this.getScopes(character);\n\t\treturn scopes.every((scope) => has.includes(scope));\n\t}\n\tstatic find(id) {\n\t\tconst result = db.select().from(characters).where(eq(characters.id, id)).limit(1).get();\n\t\tconst c = this.createCharacters(result);\n\t\treturn c ? c[0] : void 0;\n\t}\n\tstatic findByUser(user) {\n\t\tconst result = db.select().from(characters).where(eq(characters.userID, user.id)).all();\n\t\treturn this.createCharacters(result);\n\t}\n\tstatic findByUserAndEveID(userID, eveID) {\n\t\tconst result = db.select().from(characters).where(and(eq(characters.userID, userID), eq(characters.eveID, eveID))).limit(1).get();\n\t\tconst c = this.createCharacters(result);\n\t\treturn c ? c[0] : void 0;\n\t}\n\tstatic findByName(userID, name) {\n\t\tconst result = db.select().from(characters).where(and(eq(characters.name, name), eq(characters.userID, userID))).limit(1).get();\n\t\tconst c = this.createCharacters(result);\n\t\treturn c ? c[0] : void 0;\n\t}\n\tstatic findAll() {\n\t\tconst result = db.select().from(characters).all();\n\t\treturn this.createCharacters(result);\n\t}\n\tstatic create(eveID, name, user, tokens) {\n\t\treturn this.save({\n\t\t\teveID,\n\t\t\tuserID: user.id,\n\t\t\taccessToken: tokens.access_token,\n\t\t\texpiresAt: /* @__PURE__ */ new Date(tokens.expires_in * 1e3),\n\t\t\trefreshToken: tokens.refresh_token,\n\t\t\tname,\n\t\t\tcreatedAt: /* @__PURE__ */ new Date()\n\t\t});\n\t}\n\tstatic createCharacters(query) {\n\t\tif (!query) return [];\n\t\tif (Array.isArray(query)) return query.map((character) => {\n\t\t\treturn {\n\t\t\t\tid: character.id,\n\t\t\t\teveID: character.eveID,\n\t\t\t\tuserID: character.userID,\n\t\t\t\taccessToken: character.accessToken,\n\t\t\t\texpiresAt: new Date(character.expiresAt),\n\t\t\t\trefreshToken: character.refreshToken,\n\t\t\t\tname: character.name,\n\t\t\t\tcreatedAt: new Date(character.createdAt),\n\t\t\t\tupdatedAt: new Date(character.updatedAt)\n\t\t\t};\n\t\t});\n\t\telse return [{\n\t\t\tid: query.id,\n\t\t\teveID: query.eveID,\n\t\t\tuserID: query.userID,\n\t\t\taccessToken: query.accessToken,\n\t\t\texpiresAt: new Date(query.expiresAt),\n\t\t\trefreshToken: query.refreshToken,\n\t\t\tname: query.name,\n\t\t\tcreatedAt: new Date(query.createdAt),\n\t\t\tupdatedAt: new Date(query.updatedAt)\n\t\t}];\n\t}\n\tstatic save(character) {\n\t\tdb.insert(characters).values({\n\t\t\tid: character.id,\n\t\t\teveID: character.eveID,\n\t\t\tuserID: character.userID,\n\t\t\tname: character.name,\n\t\t\taccessToken: character.accessToken,\n\t\t\texpiresAt: character.expiresAt.getTime(),\n\t\t\trefreshToken: character.refreshToken,\n\t\t\tcreatedAt: Date.now(),\n\t\t\tupdatedAt: Date.now()\n\t\t}).onConflictDoUpdate({\n\t\t\ttarget: characters.id,\n\t\t\tset: {\n\t\t\t\teveID: character.eveID,\n\t\t\t\tuserID: character.userID,\n\t\t\t\tname: character.name,\n\t\t\t\taccessToken: character.accessToken,\n\t\t\t\texpiresAt: character.expiresAt.getTime(),\n\t\t\t\trefreshToken: character.refreshToken,\n\t\t\t\tupdatedAt: Date.now()\n\t\t\t}\n\t\t}).run();\n\t\treturn CharacterHelper.findByUserAndEveID(character.userID, character.eveID);\n\t}\n\tstatic delete(character) {\n\t\tdb.delete(characters).where(eq(characters.id, character.id)).run();\n\t}\n\tstatic async refreshTokens(character, scopes) {\n\t\tconst tokens = await refresh({ refresh_token: character.refreshToken }, scopes);\n\t\tconst decoded = await validateToken(tokens.access_token);\n\t\tif (!decoded) {\n\t\t\tconsole.error(`Failed to validate token for character ${character.eveID}`);\n\t\t\treturn character;\n\t\t}\n\t\tcharacter.accessToken = tokens.access_token;\n\t\tcharacter.expiresAt = new Date(Date.now() + tokens.expires_in * 1e3);\n\t\tcharacter.refreshToken = tokens.refresh_token;\n\t\tthis.save(character);\n\t\treturn character;\n\t}\n};\n\n//#endregion\nexport { CharacterHelper };",
    "import { options } from \"./options.js\";\nimport { CharacterHelper } from \"../db/models/character.model.js\";\nimport \"../db/models/index.js\";\nimport { ESI_LATEST_URL } from \"./scopes.js\";\n\n//#region src/esi/fetch.ts\nconst cache = /* @__PURE__ */ new Map();\nfunction cleanCache() {\n\tconst now = Date.now();\n\tfor (const [key, value] of cache) if (value.expires < now) cache.delete(key);\n}\nsetInterval(cleanCache, 1e3 * 60 * 15);\nconst defaultCacheDuration = 1e3 * 60 * 30;\nasync function esiFetch(path, character, { method = \"GET\", body, noCache = false, cacheDuration = defaultCacheDuration } = {}) {\n\ttry {\n\t\tconst headers = {\n\t\t\t\"User-Agent\": options.user_agent,\n\t\t\t\"Accept\": \"application/json\"\n\t\t};\n\t\tif (character) {\n\t\t\tif (!CharacterHelper.hasValidToken(character)) {\n\t\t\t\tawait CharacterHelper.refreshTokens(character);\n\t\t\t\tif (!CharacterHelper.hasValidToken(character)) throw new Error(`Failed to refresh token for character: ${character.eveID}`);\n\t\t\t}\n\t\t\theaders[\"Authorization\"] = `Bearer ${character.accessToken}`;\n\t\t}\n\t\tconst init = {\n\t\t\theaders,\n\t\t\tmethod: method || \"GET\",\n\t\t\tbody: body || void 0\n\t\t};\n\t\tconst url = new URL(`${ESI_LATEST_URL}${path.startsWith(\"/\") ? path : \"/\" + path}`);\n\t\turl.searchParams.set(\"datasource\", \"tranquility\");\n\t\tif (!noCache && init.method === \"GET\") {\n\t\t\tconst cached = cache.get(url.href);\n\t\t\tif (cached && cached?.expires > Date.now()) return cached.data;\n\t\t}\n\t\tconst res = await fetch(url, init);\n\t\tconst data = await res.json();\n\t\tif (!res.ok) {\n\t\t\tconsole.error(`ESI request failure at ${path} | ${res.status}:${res.statusText} => ${JSON.stringify(data)}`);\n\t\t\treturn null;\n\t\t}\n\t\tif (init.method === \"GET\") cache.set(url.href, {\n\t\t\texpires: Math.max(res.headers.get(\"expires\") && new Date(Number(res.headers.get(\"expires\") || \"\")).getTime() || 0, Date.now() + cacheDuration),\n\t\t\tdata\n\t\t});\n\t\treturn data;\n\t} catch (err) {\n\t\tconsole.error(`ESI request failure at ${path} | ${JSON.stringify(err)}`, err);\n\t\treturn null;\n\t}\n}\n\n//#endregion\nexport { esiFetch };",
    "import { __export } from \"../_virtual/rolldown_runtime.js\";\nimport { CharacterHelper } from \"../db/models/character.model.js\";\nimport \"../db/index.js\";\nimport \"./scopes.js\";\nimport { esiFetch } from \"./fetch.js\";\n\n//#region src/esi/character.ts\nvar character_exports = {};\n__export(character_exports, {\n\tgetCharacterAffiliations: () => getCharacterAffiliations,\n\tgetCharacterAgentResearch: () => getCharacterAgentResearch,\n\tgetCharacterAssetLocations: () => getCharacterAssetLocations,\n\tgetCharacterAssetNames: () => getCharacterAssetNames,\n\tgetCharacterAssets: () => getCharacterAssets,\n\tgetCharacterBlueprints: () => getCharacterBlueprints,\n\tgetCharacterClones: () => getCharacterClones,\n\tgetCharacterContactNotifications: () => getCharacterContactNotifications,\n\tgetCharacterCorporationHistory: () => getCharacterCorporationHistory,\n\tgetCharacterCurrentShip: () => getCharacterCurrentShip,\n\tgetCharacterImplants: () => getCharacterImplants,\n\tgetCharacterJumpFatigue: () => getCharacterJumpFatigue,\n\tgetCharacterLocation: () => getCharacterLocation,\n\tgetCharacterMedals: () => getCharacterMedals,\n\tgetCharacterNotifications: () => getCharacterNotifications,\n\tgetCharacterOnline: () => getCharacterOnline,\n\tgetCharacterPortraits: () => getCharacterPortraits,\n\tgetCharacterPublicData: () => getCharacterPublicData,\n\tgetCharacterRoles: () => getCharacterRoles,\n\tgetCharacterStandings: () => getCharacterStandings,\n\tgetCharacterTitles: () => getCharacterTitles,\n\tgetCharacterWallet: () => getCharacterWallet,\n\tgetCharacterWalletJournal: () => getCharacterWalletJournal,\n\tgetCharacterWalletTransactions: () => getCharacterWalletTransactions,\n\tgetPortraitURL: () => getPortraitURL\n});\nfunction getCharacterPublicData(id) {\n\treturn esiFetch(`/characters/${id}/`);\n}\nfunction getCharacterAffiliations(ids) {\n\treturn esiFetch(`/characters/affiliation/`, void 0, {\n\t\tmethod: \"POST\",\n\t\tbody: JSON.stringify(ids)\n\t})[0];\n}\nfunction getCharacterPortraits(id) {\n\treturn esiFetch(`/characters/${id}/portrait/`);\n}\nfunction getCharacterCorporationHistory(id) {\n\treturn esiFetch(`/characters/${id}/corporationhistory/`);\n}\nfunction getPortraitURL(id) {\n\treturn `https://images.evetech.net/characters/${id}/portrait`;\n}\nfunction getCharacterRoles(character) {\n\tif (!CharacterHelper.hasScope(character, \"esi-characters.read_corporation_roles.v1\")) return null;\n\treturn esiFetch(`/characters/${character.eveID}/roles/`, character);\n}\nfunction getCharacterTitles(character) {\n\tif (!CharacterHelper.hasScope(character, \"esi-characters.read_titles.v1\")) return null;\n\treturn esiFetch(`/characters/${character.eveID}/titles/`, character);\n}\nfunction getCharacterStandings(character) {\n\tif (!CharacterHelper.hasScope(character, \"esi-characters.read_standings.v1\")) return null;\n\treturn esiFetch(`/characters/${character.eveID}/standings/`, character);\n}\nfunction getCharacterNotifications(character) {\n\tif (!CharacterHelper.hasScope(character, \"esi-characters.read_notifications.v1\")) return null;\n\treturn esiFetch(`/characters/${character.eveID}/notifications/`, character);\n}\nfunction getCharacterContactNotifications(character) {\n\tif (!CharacterHelper.hasScope(character, \"esi-characters.read_notifications.v1\")) return null;\n\treturn esiFetch(`/characters/${character.eveID}/notifications/contacts`, character);\n}\nfunction getCharacterMedals(character) {\n\tif (!CharacterHelper.hasScope(character, \"esi-characters.read_medals.v1\")) return null;\n\treturn esiFetch(`/characters/${character.eveID}/medals/`, character);\n}\nfunction getCharacterJumpFatigue(character) {\n\tif (!CharacterHelper.hasScope(character, \"esi-characters.read_fatigue.v1\")) return null;\n\treturn esiFetch(`/characters/${character.eveID}/fatigue/`, character);\n}\nfunction getCharacterBlueprints(character) {\n\tif (!CharacterHelper.hasScope(character, \"esi-characters.read_blueprints.v1\")) return null;\n\treturn esiFetch(`/characters/${character.eveID}/blueprints/`, character);\n}\nfunction getCharacterAgentResearch(character) {\n\tif (!CharacterHelper.hasScope(character, \"esi-characters.read_agents_research.v1\")) return null;\n\treturn esiFetch(`/characters/${character.eveID}/agents_research/`, character);\n}\nfunction getCharacterClones(character) {\n\tif (!CharacterHelper.hasScope(character, \"esi-clones.read_clones.v1\")) return null;\n\treturn esiFetch(`/characters/${character.eveID}/clones/`, character);\n}\nfunction getCharacterImplants(character) {\n\tif (!CharacterHelper.hasScope(character, \"esi-clones.read_implants.v1\")) return null;\n\treturn esiFetch(`/characters/${character.eveID}/implants/`, character);\n}\nfunction getCharacterAssets(character) {\n\tif (!CharacterHelper.hasScope(character, \"esi-assets.read_assets.v1\")) return null;\n\treturn esiFetch(`/characters/${character.eveID}/assets/`, character);\n}\nfunction getCharacterAssetLocations(character, ids) {\n\tif (!CharacterHelper.hasScope(character, \"esi-assets.read_assets.v1\")) return null;\n\treturn esiFetch(`/characters/${character.eveID}/assets/locations/`, character, {\n\t\tmethod: \"POST\",\n\t\tbody: JSON.stringify(ids)\n\t});\n}\nfunction getCharacterAssetNames(character, ids) {\n\tif (!CharacterHelper.hasScope(character, \"esi-assets.read_assets.v1\")) return null;\n\treturn esiFetch(`/characters/${character.eveID}/assets/names/`, character, {\n\t\tmethod: \"POST\",\n\t\tbody: JSON.stringify(ids)\n\t});\n}\nfunction getCharacterWallet(character) {\n\tif (!CharacterHelper.hasScope(character, \"esi-wallet.read_character_wallet.v1\")) return null;\n\treturn esiFetch(`/characters/${character.eveID}/wallet/`, character);\n}\nfunction getCharacterWalletTransactions(character, fromId) {\n\tif (!CharacterHelper.hasScope(character, \"esi-wallet.read_character_wallet.v1\")) return null;\n\treturn esiFetch(`/characters/${character.eveID}/wallet/transactions/`, character, {\n\t\tmethod: \"POST\",\n\t\tbody: JSON.stringify(fromId)\n\t});\n}\nfunction getCharacterWalletJournal(character, page = 1) {\n\tif (!CharacterHelper.hasScope(character, \"esi-wallet.read_character_wallet.v1\")) return null;\n\treturn esiFetch(`/characters/${character.eveID}/wallet/journal/?page=${page}`, character);\n}\nfunction getCharacterLocation(character) {\n\tif (!CharacterHelper.hasScope(character, \"esi-location.read_location.v1\")) return null;\n\treturn esiFetch(`/characters/${character.eveID}/location/`, character);\n}\nfunction getCharacterOnline(character) {\n\tif (!CharacterHelper.hasScope(character, \"esi-location.read_online.v1\")) return null;\n\treturn esiFetch(`/characters/${character.eveID}/online/`, character);\n}\nfunction getCharacterCurrentShip(character) {\n\tif (!CharacterHelper.hasScope(character, \"esi-location.read_ship_type.v1\")) return null;\n\treturn esiFetch(`/characters/${character.eveID}/ship/`, character);\n}\n\n//#endregion\nexport { character_exports, getCharacterAffiliations, getCharacterAgentResearch, getCharacterAssetLocations, getCharacterAssetNames, getCharacterAssets, getCharacterBlueprints, getCharacterClones, getCharacterContactNotifications, getCharacterCorporationHistory, getCharacterCurrentShip, getCharacterImplants, getCharacterJumpFatigue, getCharacterLocation, getCharacterMedals, getCharacterNotifications, getCharacterOnline, getCharacterPortraits, getCharacterPublicData, getCharacterRoles, getCharacterStandings, getCharacterTitles, getCharacterWallet, getCharacterWalletJournal, getCharacterWalletTransactions, getPortraitURL };",
    "import { __export } from \"../_virtual/rolldown_runtime.js\";\nimport { CharacterHelper } from \"../db/models/character.model.js\";\nimport \"../db/index.js\";\nimport { esiFetch } from \"./fetch.js\";\n\n//#region src/esi/corporation.ts\nvar corporation_exports = {};\n__export(corporation_exports, {\n\tgetCorporationAllianceHistory: () => getCorporationAllianceHistory,\n\tgetCorporationAssetLocations: () => getCorporationAssetLocations,\n\tgetCorporationAssetNames: () => getCorporationAssetNames,\n\tgetCorporationAssets: () => getCorporationAssets,\n\tgetCorporationData: () => getCorporationData,\n\tgetCorporationIcons: () => getCorporationIcons\n});\nasync function getCorporationData(id) {\n\treturn await esiFetch(`/corporations/${id}/`);\n}\nasync function getCorporationAllianceHistory(id) {\n\treturn await esiFetch(`/corporations/${id}/alliancehistory/`);\n}\nasync function getCorporationIcons(id) {\n\treturn await esiFetch(`/corporations/${id}/icons/`);\n}\nasync function getCorporationAssets(id, character) {\n\tif (!CharacterHelper.hasScope(character, \"esi-assets.read_corporation_assets.v1\")) return null;\n\treturn await esiFetch(`/corporations/${id}/assets/`, character);\n}\nasync function getCorporationAssetLocations(id, character, ids) {\n\tif (!CharacterHelper.hasScope(character, \"esi-assets.read_corporation_assets.v1\")) return null;\n\treturn await esiFetch(`/corporations/${id}/assets/locations/`, character, {\n\t\tmethod: \"POST\",\n\t\tbody: JSON.stringify(ids)\n\t});\n}\nasync function getCorporationAssetNames(id, character, ids) {\n\tif (!CharacterHelper.hasScope(character, \"esi-assets.read_corporation_assets.v1\")) return null;\n\treturn await esiFetch(`/corporations/${id}/assets/names/`, character, {\n\t\tmethod: \"POST\",\n\t\tbody: JSON.stringify(ids)\n\t});\n}\n\n//#endregion\nexport { corporation_exports };",
    "import { __export } from \"../_virtual/rolldown_runtime.js\";\nimport { esiFetch } from \"./fetch.js\";\n\n//#region src/esi/alliance.ts\nvar alliance_exports = {};\n__export(alliance_exports, {\n\tgetAllianceCorporations: () => getAllianceCorporations,\n\tgetAllianceData: () => getAllianceData,\n\tgetAllianceIcons: () => getAllianceIcons\n});\nasync function getAllianceData(id) {\n\treturn await esiFetch(`/alliances/${id}/`);\n}\nasync function getAllianceCorporations(id) {\n\treturn await esiFetch(`/alliances/${id}/corporations/`);\n}\nasync function getAllianceIcons(id) {\n\treturn await esiFetch(`/alliances/${id}/icons/`);\n}\n\n//#endregion\nexport { alliance_exports, getAllianceCorporations, getAllianceData, getAllianceIcons };",
    "import { CharacterHelper } from \"../db/models/character.model.js\";\nimport \"../db/models/index.js\";\nimport { esiFetch } from \"./fetch.js\";\n\n//#region src/esi/skills.ts\nfunction getCharacterAttributes(character) {\n\tif (!CharacterHelper.hasScope(character, \"esi-skills.read_skills.v1\")) return null;\n\treturn esiFetch(`/characters/${character.eveID}/attributes`, character);\n}\nfunction getCharacterSkillQueue(character) {\n\tif (!CharacterHelper.hasScope(character, \"esi-skills.read_skillqueue.v1\")) return null;\n\treturn esiFetch(`/characters/${character.eveID}/skillqueue`, character);\n}\nfunction getCharacterSkills(character) {\n\tif (!CharacterHelper.hasScope(character, \"esi-skills.read_skills.v1\")) return null;\n\treturn esiFetch(`/characters/${character.eveID}/skills`, character);\n}\nfunction calculateTrainingPercentage(queuedSkill) {\n\tconst trainingStartPosition = (queuedSkill.training_start_sp - queuedSkill.level_start_sp) / queuedSkill.level_end_sp;\n\tconst timePosition = ((/* @__PURE__ */ new Date()).getTime() - new Date(queuedSkill.start_date).getTime()) / (new Date(queuedSkill.finish_date).getTime() - new Date(queuedSkill.start_date).getTime());\n\treturn trainingStartPosition + (1 - trainingStartPosition) * timePosition;\n}\n\n//#endregion\nexport { calculateTrainingPercentage, getCharacterAttributes, getCharacterSkillQueue, getCharacterSkills };",
    "\nexport function getCookies(headers: Headers) {\n  if (!headers) return {};\n  const cookieHeader = headers.get(\"Cookie\");\n  const cookies: Record<string, string> = {};\n\n  if (cookieHeader === null) return {};\n\n  for (const kv of cookieHeader.split(\";\")) {\n    const [cookieKey, ...cookieVal] = kv.split(\"=\");\n    const key = cookieKey.trim();\n    cookies[key] = cookieVal.join(\"=\");\n  }\n\n  return cookies;\n}\n\nexport function setCookie(response: Response, key: string, value: string, maxAge?: number) {\n  response.headers.append('Set-Cookie', `${key}=${value}${maxAge ? '; Path=/; Max-Age=' + maxAge : ''}`);\n}\n\nexport function removeCookie(response: Response, key: string) {\n  response.headers.append('Set-Cookie', `${key}=\"\"; Path=/; Max-Age=-1;`);\n}",
    "const hexAlphabet = \"0123456789abcdef\";\nconst hexDecodeMap = new Map([\n    [\"0\", 0],\n    [\"1\", 1],\n    [\"2\", 2],\n    [\"3\", 3],\n    [\"4\", 4],\n    [\"5\", 5],\n    [\"6\", 6],\n    [\"7\", 7],\n    [\"8\", 8],\n    [\"9\", 9],\n    [\"A\", 10],\n    [\"B\", 11],\n    [\"C\", 12],\n    [\"D\", 13],\n    [\"E\", 14],\n    [\"F\", 15],\n    [\"a\", 10],\n    [\"b\", 11],\n    [\"c\", 12],\n    [\"d\", 13],\n    [\"e\", 14],\n    [\"f\", 15]\n]);\nexport function encodeHex(data) {\n    const bytes = new Uint8Array(data);\n    let result = \"\";\n    for (let i = 0; i < bytes.length; i++) {\n        const key1 = bytes[i] >> 4;\n        result += hexAlphabet[key1];\n        const key2 = bytes[i] & 0x0f;\n        result += hexAlphabet[key2];\n    }\n    return result;\n}\nexport function decodeHex(data) {\n    const chunkCount = Math.ceil(data.length / 2);\n    const result = new Uint8Array(chunkCount);\n    for (let i = 0; i < chunkCount; i++) {\n        let buffer = 0;\n        const encoded1 = data[i * 2];\n        const value1 = hexDecodeMap.get(encoded1) ?? null;\n        if (value1 === null) {\n            throw new Error(`Invalid character: ${encoded1}`);\n        }\n        buffer += value1 << 4;\n        const encoded2 = data[i * 2 + 1];\n        if (encoded2 === undefined) {\n            throw new Error(\"Invalid data\");\n        }\n        const value2 = hexDecodeMap.get(encoded2) ?? null;\n        if (value2 === null) {\n            throw new Error(`Invalid character: ${encoded1}`);\n        }\n        buffer += value2;\n        result[i] = buffer;\n    }\n    return result;\n}\n",
    "export class Base32Encoding {\n    alphabet;\n    padding;\n    decodeMap = new Map();\n    constructor(alphabet, options) {\n        if (alphabet.length !== 32) {\n            throw new Error(\"Invalid alphabet\");\n        }\n        this.alphabet = alphabet;\n        this.padding = options?.padding ?? \"=\";\n        if (this.alphabet.includes(this.padding) || this.padding.length !== 1) {\n            throw new Error(\"Invalid padding\");\n        }\n        for (let i = 0; i < alphabet.length; i++) {\n            this.decodeMap.set(alphabet[i], i);\n        }\n    }\n    encode(data, options) {\n        let result = \"\";\n        let buffer = 0;\n        let shift = 0;\n        for (let i = 0; i < data.length; i++) {\n            buffer = (buffer << 8) | data[i];\n            shift += 8;\n            while (shift >= 5) {\n                shift -= 5;\n                result += this.alphabet[(buffer >> shift) & 0x1f];\n            }\n        }\n        if (shift > 0) {\n            result += this.alphabet[(buffer << (5 - shift)) & 0x1f];\n        }\n        const includePadding = options?.includePadding ?? true;\n        if (includePadding) {\n            const padCount = (8 - (result.length % 8)) % 8;\n            for (let i = 0; i < padCount; i++) {\n                result += \"=\";\n            }\n        }\n        return result;\n    }\n    decode(data, options) {\n        const strict = options?.strict ?? true;\n        const chunkCount = Math.ceil(data.length / 8);\n        const result = [];\n        for (let i = 0; i < chunkCount; i++) {\n            let padCount = 0;\n            const chunks = [];\n            for (let j = 0; j < 8; j++) {\n                const encoded = data[i * 8 + j];\n                if (encoded === \"=\") {\n                    if (i + 1 !== chunkCount) {\n                        throw new Error(`Invalid character: ${encoded}`);\n                    }\n                    padCount += 1;\n                    continue;\n                }\n                if (encoded === undefined) {\n                    if (strict) {\n                        throw new Error(\"Invalid data\");\n                    }\n                    padCount += 1;\n                    continue;\n                }\n                const value = this.decodeMap.get(encoded) ?? null;\n                if (value === null) {\n                    throw new Error(`Invalid character: ${encoded}`);\n                }\n                chunks.push(value);\n            }\n            if (padCount === 8 || padCount === 7 || padCount === 5 || padCount === 2) {\n                throw new Error(\"Invalid padding\");\n            }\n            const byte1 = (chunks[0] << 3) + (chunks[1] >> 2);\n            result.push(byte1);\n            if (padCount < 6) {\n                const byte2 = ((chunks[1] & 0x03) << 6) + (chunks[2] << 1) + (chunks[3] >> 4);\n                result.push(byte2);\n            }\n            if (padCount < 4) {\n                const byte3 = ((chunks[3] & 0xff) << 4) + (chunks[4] >> 1);\n                result.push(byte3);\n            }\n            if (padCount < 3) {\n                const byte4 = ((chunks[4] & 0x01) << 7) + (chunks[5] << 2) + (chunks[6] >> 3);\n                result.push(byte4);\n            }\n            if (padCount < 1) {\n                const byte5 = ((chunks[6] & 0x07) << 5) + chunks[7];\n                result.push(byte5);\n            }\n        }\n        return Uint8Array.from(result);\n    }\n}\nexport const base32 = new Base32Encoding(\"ABCDEFGHIJKLMNOPQRSTUVWXYZ234567\");\nexport const base32hex = new Base32Encoding(\"0123456789ABCDEFGHIJKLMNOPQRSTUV\");\n/** @deprecated Use `base32.encode()` instead */\nexport function encodeBase32(data, options) {\n    return base32.encode(new Uint8Array(data), {\n        includePadding: options?.padding ?? true\n    });\n}\n/** @deprecated Use `base32.decode()` instead */\nexport function decodeBase32(data) {\n    return base32.decode(data, {\n        strict: false\n    });\n}\n",
    "export class Base64Encoding {\n    alphabet;\n    padding;\n    decodeMap = new Map();\n    constructor(alphabet, options) {\n        if (alphabet.length !== 64) {\n            throw new Error(\"Invalid alphabet\");\n        }\n        this.alphabet = alphabet;\n        this.padding = options?.padding ?? \"=\";\n        if (this.alphabet.includes(this.padding) || this.padding.length !== 1) {\n            throw new Error(\"Invalid padding\");\n        }\n        for (let i = 0; i < alphabet.length; i++) {\n            this.decodeMap.set(alphabet[i], i);\n        }\n    }\n    encode(data, options) {\n        let result = \"\";\n        let buffer = 0;\n        let shift = 0;\n        for (let i = 0; i < data.length; i++) {\n            buffer = (buffer << 8) | data[i];\n            shift += 8;\n            while (shift >= 6) {\n                shift += -6;\n                result += this.alphabet[(buffer >> shift) & 0x3f];\n            }\n        }\n        if (shift > 0) {\n            result += this.alphabet[(buffer << (6 - shift)) & 0x3f];\n        }\n        const includePadding = options?.includePadding ?? true;\n        if (includePadding) {\n            const padCount = (4 - (result.length % 4)) % 4;\n            for (let i = 0; i < padCount; i++) {\n                result += \"=\";\n            }\n        }\n        return result;\n    }\n    decode(data, options) {\n        const strict = options?.strict ?? true;\n        const chunkCount = Math.ceil(data.length / 4);\n        const result = [];\n        for (let i = 0; i < chunkCount; i++) {\n            let padCount = 0;\n            let buffer = 0;\n            for (let j = 0; j < 4; j++) {\n                const encoded = data[i * 4 + j];\n                if (encoded === \"=\") {\n                    if (i + 1 !== chunkCount) {\n                        throw new Error(`Invalid character: ${encoded}`);\n                    }\n                    padCount += 1;\n                    continue;\n                }\n                if (encoded === undefined) {\n                    if (strict) {\n                        throw new Error(\"Invalid data\");\n                    }\n                    padCount += 1;\n                    continue;\n                }\n                const value = this.decodeMap.get(encoded) ?? null;\n                if (value === null) {\n                    throw new Error(`Invalid character: ${encoded}`);\n                }\n                buffer += value << (6 * (3 - j));\n            }\n            result.push((buffer >> 16) & 0xff);\n            if (padCount < 2) {\n                result.push((buffer >> 8) & 0xff);\n            }\n            if (padCount < 1) {\n                result.push(buffer & 0xff);\n            }\n        }\n        return Uint8Array.from(result);\n    }\n}\nexport const base64 = new Base64Encoding(\"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/\");\nexport const base64url = new Base64Encoding(\"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789-_\");\n/** @deprecated Use `base64.encode()` instead */\nexport function encodeBase64(data, options) {\n    return base64.encode(new Uint8Array(data), {\n        includePadding: options?.padding ?? true\n    });\n}\n/** @deprecated Use `base64.decode()` instead */\nexport function decodeBase64(data) {\n    return base64.decode(data, {\n        strict: false\n    });\n}\n/** @deprecated Use `base64url.encode()` instead */\nexport function encodeBase64url(data) {\n    return base64.encode(new Uint8Array(data), {\n        includePadding: false\n    });\n}\n/** @deprecated Use `base64url.decode()` instead */\nexport function decodeBase64url(data) {\n    return base64url.decode(data, {\n        strict: false\n    });\n}\n",
    "import { sha256 } from \"../crypto/index.js\";\nimport { base64, base64url } from \"../encoding/index.js\";\nexport class OAuth2Client {\n    clientId;\n    authorizeEndpoint;\n    tokenEndpoint;\n    redirectURI;\n    constructor(clientId, authorizeEndpoint, tokenEndpoint, options) {\n        this.clientId = clientId;\n        this.authorizeEndpoint = authorizeEndpoint;\n        this.tokenEndpoint = tokenEndpoint;\n        this.redirectURI = options?.redirectURI ?? null;\n    }\n    async createAuthorizationURL(options) {\n        const scopes = Array.from(new Set(options?.scopes ?? [])); // remove duplicates\n        const authorizationUrl = new URL(this.authorizeEndpoint);\n        authorizationUrl.searchParams.set(\"response_type\", \"code\");\n        authorizationUrl.searchParams.set(\"client_id\", this.clientId);\n        if (options?.state !== undefined) {\n            authorizationUrl.searchParams.set(\"state\", options.state);\n        }\n        if (scopes.length > 0) {\n            authorizationUrl.searchParams.set(\"scope\", scopes.join(\" \"));\n        }\n        if (this.redirectURI !== null) {\n            authorizationUrl.searchParams.set(\"redirect_uri\", this.redirectURI);\n        }\n        if (options?.codeVerifier !== undefined) {\n            const codeChallengeMethod = options?.codeChallengeMethod ?? \"S256\";\n            if (codeChallengeMethod === \"S256\") {\n                const codeChallengeBuffer = await sha256(new TextEncoder().encode(options.codeVerifier));\n                const codeChallenge = base64url.encode(new Uint8Array(codeChallengeBuffer), {\n                    includePadding: false\n                });\n                authorizationUrl.searchParams.set(\"code_challenge\", codeChallenge);\n                authorizationUrl.searchParams.set(\"code_challenge_method\", \"S256\");\n            }\n            else if (codeChallengeMethod === \"plain\") {\n                authorizationUrl.searchParams.set(\"code_challenge\", options.codeVerifier);\n                authorizationUrl.searchParams.set(\"code_challenge_method\", \"plain\");\n            }\n            else {\n                throw new TypeError(`Invalid value for 'codeChallengeMethod': ${codeChallengeMethod}`);\n            }\n        }\n        return authorizationUrl;\n    }\n    async validateAuthorizationCode(authorizationCode, options) {\n        const body = new URLSearchParams();\n        body.set(\"code\", authorizationCode);\n        body.set(\"client_id\", this.clientId);\n        body.set(\"grant_type\", \"authorization_code\");\n        if (this.redirectURI !== null) {\n            body.set(\"redirect_uri\", this.redirectURI);\n        }\n        if (options?.codeVerifier !== undefined) {\n            body.set(\"code_verifier\", options.codeVerifier);\n        }\n        return await this.sendTokenRequest(body, options);\n    }\n    async refreshAccessToken(refreshToken, options) {\n        const body = new URLSearchParams();\n        body.set(\"refresh_token\", refreshToken);\n        body.set(\"client_id\", this.clientId);\n        body.set(\"grant_type\", \"refresh_token\");\n        const scopes = Array.from(new Set(options?.scopes ?? [])); // remove duplicates\n        if (scopes.length > 0) {\n            body.set(\"scope\", scopes.join(\" \"));\n        }\n        return await this.sendTokenRequest(body, options);\n    }\n    async sendTokenRequest(body, options) {\n        const headers = new Headers();\n        headers.set(\"Content-Type\", \"application/x-www-form-urlencoded\");\n        headers.set(\"Accept\", \"application/json\");\n        headers.set(\"User-Agent\", \"oslo\");\n        if (options?.credentials !== undefined) {\n            const authenticateWith = options?.authenticateWith ?? \"http_basic_auth\";\n            if (authenticateWith === \"http_basic_auth\") {\n                const encodedCredentials = base64.encode(new TextEncoder().encode(`${this.clientId}:${options.credentials}`));\n                headers.set(\"Authorization\", `Basic ${encodedCredentials}`);\n            }\n            else if (authenticateWith === \"request_body\") {\n                body.set(\"client_secret\", options.credentials);\n            }\n            else {\n                throw new TypeError(`Invalid value for 'authenticateWith': ${authenticateWith}`);\n            }\n        }\n        const request = new Request(this.tokenEndpoint, {\n            method: \"POST\",\n            headers,\n            body\n        });\n        const response = await fetch(request);\n        const result = await response.json();\n        // providers are allowed to return non-400 status code for errors\n        if (!(\"access_token\" in result) && \"error\" in result) {\n            throw new OAuth2RequestError(request, result);\n        }\n        else if (!response.ok) {\n            throw new OAuth2RequestError(request, {});\n        }\n        return result;\n    }\n}\nexport function generateCodeVerifier() {\n    const randomValues = new Uint8Array(32);\n    crypto.getRandomValues(randomValues);\n    return base64url.encode(randomValues, {\n        includePadding: false\n    });\n}\nexport function generateState() {\n    const randomValues = new Uint8Array(32);\n    crypto.getRandomValues(randomValues);\n    return base64url.encode(randomValues, {\n        includePadding: false\n    });\n}\nexport class OAuth2RequestError extends Error {\n    request;\n    description;\n    constructor(request, body) {\n        super(body.error ?? \"\");\n        this.request = request;\n        this.description = body.error_description ?? null;\n    }\n}\n",
    "import type { RequestContext } from 'brisa';\nimport {\n  createAuthorizationURL as eveAuthURL,\n  validateAuthorizationCode,\n  validateToken,\n  type EveTokens,\n} from '@star-kitten/eve/esi';\nimport { getCookies, removeCookie, setCookie } from '@/utils/cookies';\nimport { OAuth2RequestError } from 'oslo/oauth2';\nimport { options } from '@star-kitten/eve/esi';\n\nexport type EVEAuth = {\n  validateToken: typeof validateToken;\n  validateAuthorizationCode: (code: string) => Promise<EveTokens>;\n  validate: (response: Response) => Promise<EveTokens>;\n  redirect: (scopes?: string) => Promise<Response>;\n}\n\nexport default async function middleware(req: RequestContext) {\n\n  req.store.set('options', options);\n\n  const redirect = async (scopes?: string): Promise<Response> => {\n    const { url, state } = await eveAuthURL(scopes);\n    const response = new Response('', { status: 302 });\n    setCookie(response, 'state', state, 60 * 10 /* 10 min */);\n    response.headers.set('location', url.href);\n    return response;\n  }\n\n  const eveauth: EVEAuth = {\n    validateAuthorizationCode: (code: string) => {\n      try {\n        return validateAuthorizationCode(code);\n      } catch (error) {\n        throw new OAuth2RequestError(req, {\n          error: `Failed to authenticate with EVE Online ${error}`,\n        });\n      }\n    },\n    validateToken,\n\n    validate: async (response: Response) => {\n      const query = new URL(req.url).searchParams;\n      const code = query.get('code');\n      if (!code) {\n        throw Error(`code missing from query parameters, there may be an error with the OAuth provider`);\n      }\n\n      const cookies = getCookies(req.headers);\n\n      if (cookies['state'] !== query.get('state')) throw Error('invalid state');\n      removeCookie(response, 'state');\n\n      try {\n        const tokens = await validateAuthorizationCode(code);\n        const decoded = await validateToken(tokens.access_token);\n        if (!decoded) throw 'Invalid Token';\n        return tokens;\n      } catch (error) {\n        throw new OAuth2RequestError(req, {\n          error: `Failed to authenticate with EVE Online ${error}`,\n        });\n      }\n    },\n\n    redirect,\n  }\n\n  req.store.set('eveauth', eveauth);\n\n  // -----------------------------------------\n\n  // Route Authorization\n\n}"
  ],
  "mappings": "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AAAA,IAAG;AAAA,IAAI;AAAA,IAAI;AAAA,IAAI;AAAA,IAAG;AAAA,IAAI;AAAA,IAAG;AAAA,IAAG;AAAA,IAAI;AAAA,IAAG;AAAA,IACrD;AAAA,IAAI;AAAA,IAAI;AAAA,IAAI;AAAA,IAAI;AAAA,IAAI;AAAA,IAAI;AAAA,IAAG;AAAA,IAAG;AAAA,IAAG;AAAA,IAAI;AAAA,IAAG;AAAA,IAAG;AAAA,IAAG;AAAA,IAAG;AAAA,IAAG;AAAA,IACpD;AAAA,IAAG;AAAA,IAAI;AAAA,IAAG;AAAA,IAAI;AAAA,IAAG;AAAA,IAAG;AAAA,IAAI;AAAA,IAAI;AAAA,IAAG;AAAA,IAAI;AAAA,IAAI;AAAA,IAAI;AAAA,IAAI;AAAA,IAAG;AAAA,IAAG;AAAA,EACvD;AAAA,EAEA,IAAI,KAAK;AAAA,IACP;AAAA,IAAG;AAAA,IAAG;AAAA,IAAG;AAAA,IAAI;AAAA,IAAI;AAAA,IAAI;AAAA,IAAI;AAAA,IAAG;AAAA,IAAG;AAAA,IAAG;AAAA,IAAG;AAAA,IAAI;AAAA,IAAI;AAAA,IAAI;AAAA,IAAI;AAAA,IACrD;AAAA,IAAG;AAAA,IAAI;AAAA,IAAI;AAAA,IAAG;AAAA,IAAI;AAAA,IAAG;AAAA,IAAG;AAAA,IAAI;AAAA,IAAG;AAAA,IAAG;AAAA,IAAI;AAAA,IAAG;AAAA,IAAG;AAAA,IAAI;AAAA,IAAI;AAAA,IACpD;AAAA,IAAG;AAAA,IAAG;AAAA,IAAI;AAAA,IAAI;AAAA,IAAG;AAAA,IAAG;AAAA,IAAG;AAAA,IAAI;AAAA,IAAI;AAAA,IAAI;AAAA,IAAG;AAAA,IAAI;AAAA,IAAI;AAAA,IAAI;AAAA,IAAG;AAAA,IACrD;AAAA,IAAI;AAAA,IAAG;AAAA,IAAG;AAAA,IAAI;AAAA,IAAI;AAAA,IAAI;AAAA,IAAG;AAAA,IAAI;AAAA,IAAG;AAAA,IAAG;AAAA,IAAI;AAAA,IAAG;AAAA,IAAI;AAAA,IAAG;AAAA,IAAI;AAAA,IACrD;AAAA,IAAG;AAAA,IAAG;AAAA,IAAI;AAAA,IAAG;AAAA,IAAI;AAAA,IAAG;AAAA,IAAI;AAAA,IAAG;AAAA,IAAG;AAA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CE;AAAA,UACA;AAAA,QACF;AAAA,QACA;AAAA,UACE;AAAA,UACA;AAAA,QACF;AAAA,QACA;AAAA,UACE;AAAA,UACA;AAAA,QACF;AAAA,QACA;AAAA,UACE;AAAA,UACA;AAAA,QACF;AAAA,QACA;AAAA,UACE;AAAA,UACA;AAAA,QACF;AAAA,QACA;AAAA,UACE;AAAA,UACA;AAAA,QACF;AAAA,QACA;AAAA,UACE;AAAA,UACA;AAAA,QACF;AAAA,QACA;AAAA,UACE;AAAA,UACA;AAAA,QACF;AAAA,QACA;AAAA,UACE;AAAA,UACA;AAAA,QACF;AAAA,QACA;AAAA,UACE;AAAA,UACA;AAAA,QACF;AAAA,QACA;AAAA,UACE;AAAA,UACA;AAAA,QACF;AAAA,QACA;AAAA,UACE;AAAA,UACA;AAAA,QACF;AAAA,QACA;AAAA,UACE;AAAA,UACA;AAAA,QACF;AAAA,QACA;AAAA,UACE;AAAA,UACA;AAAA,QACF;AAAA,QACA;AAAA,UACE;AAAA,UACA;AAAA,QACF;AAAA,QACA;AAAA,UACE;AAAA,UACA;AAAA,QACF;AAAA,QACA;AAAA,UACE;AAAA,UACA;AAAA,QACF;AAAA,QACA;AAAA,UACE;AAAA,UACA;AAAA,QACF;AAAA,QACA;AAAA,UACE;AAAA,UACA;AAAA,QACF;AAAA,QACA;AAAA,UACE;AAAA,UACA;AAAA,QACF;AAAA,QACA;AAAA,UACE;AAAA,UACA;AAAA,QACF;AAAA,QACA;AAAA,UACE;AAAA,UACA;AAAA,QACF;AAAA,QACA;AAAA,UACE;AAAA,UACA;AAAA,QACF;AAAA,QACA;AAAA,UACE;AAAA,UACA;AAAA,QACF;AAAA,QACA;AAAA,UACE;AAAA,UACA;AAAA,QACF;AAAA,QACA;AAAA,UACE;AAAA,UACA;AAAA,QACF;AAAA,QACA;AAAA,UACE;AAAA,UACA;AAAA,QACF;AAAA,QACA;AAAA,UACE;AAAA,UACA;AAAA,QACF;AAAA,QACA;AAAA,UACE;AAAA,UACA;AAAA,QACF;AAAA,QACA;AAAA,UACE;AAAA,UACA;AAAA,QACF;AAAA,QACA;AAAA,UACE;AAAA,UACA;AAAA,QACF;AAAA,QACA;AAAA,UACE;AAAA,UACA;AAAA,QACF;AAAA,QACA;AAAA,UACE;AAAA,UACA;AAAA,QACF;AAAA,QACA;AAAA,UACE;AAAA,UACA;AAAA,QACF;AAAA,QACA;AAAA,UACE;AAAA,UACA;AAAA,QACF;AAAA,QACA;AAAA,UACE;AAAA,UACA;AAAA,QACF;AAAA,QACA;AAAA,UACE;AAAA,UACA;AAAA,QACF;AAAA,QACA;AAAA,UACE;AAAA,UACA;AAAA,QACF;AAAA,QACA;AAAA,UACE;AAAA,UACA;AAAA,QACF;AAAA,QACA;AAAA,UACE;AAAA,UACA;AAAA,QACF;AAAA,QACA;AAAA,UACE;AAAA,UACA;AAAA,QACF;AAAA,QACA;AAAA,UACE;AAAA,UACA;AAAA,QACF;AAAA,MACF;AAAA,IACF;AAAA,IACA,KAAK;AAAA,MACH,KAAK;AAAA,MACL,QAAQ;AAAA,QACN;AAAA,UACE;AAAA,UACA;AAAA,QACF;AAAA,QACA;AAAA,UACE;AAAA,UACA;AAAA,QACF;AAAA,QACA;AAAA,UACE;AAAA,UACA;AAAA,QACF;AAAA,QACA;AAAA,UACE;AAAA,UACA;AAAA,QACF;AAAA,QACA;AAAA,UACE;AAAA,UACA;AAAA,QACF;AAAA,QACA;AAAA,UACE;AAAA,UACA;AAAA,QACF;AAAA,QACA;AAAA,UACE;AAAA,UACA;AAAA,QACF;AAAA,QACA;AAAA,UACE;AAAA,UACA;AAAA,QACF;AAAA,QACA;AAAA,UACE;AAAA,UACA;AAAA,QACF;AAAA,QACA;AAAA,UACE;AAAA,UACA;AAAA,QACF;AAAA,QACA;AAAA,UACE;AAAA,UACA;AAAA,QACF;AAAA,QACA;AAAA,UACE;AAAA,UACA;AAAA,QACF;AAAA,QACA;AAAA,UACE;AAAA,UACA;AAAA,QACF;AAAA,QACA;AAAA,UACE;AAAA,UACA;AAAA,QACF;AAAA,QACA;AAAA,UACE;AAAA,UACA;AAAA,QACF;AAAA,QACA;AAAA,UACE;AAAA,UACA;AAAA,QACF;AAAA,QACA;AAAA,UACE;AAAA,UACA;AAAA,QACF;AAAA,QACA;AAAA,UACE;AAAA,UACA;AAAA,QACF;AAAA,QACA;AAAA,UACE;AAAA,UACA;AAAA,QACF;AAAA,QACA;AAAA,UACE;AAAA,UACA;AAAA,QACF;AAAA,QACA;AAAA,UACE;AAAA,UACA;AAAA,QACF;AAAA,QACA;AAAA,UACE;AAAA,UACA;AAAA,QACF;AAAA,QACA;AAAA,UACE;AAAA,UACA;AAAA,QACF;AAAA,QACA;AAAA,UACE;AAAA,UACA;AAAA,QACF;AAAA,QACA;AAAA,UACE;AAAA,UACA;AAAA,QACF;AAAA,QACA;AAAA,UACE;AAAA,UACA;AAAA,QACF;AAAA,QACA;AAAA,UACE;AAAA,UACA;AAAA,QACF;AAAA,QACA;AAAA,UACE;AAAA,UACA;AAAA,QACF;AAAA,QACA;AAAA,UACE;AAAA,UACA;AAAA,QACF;AAAA,QACA;AAAA,UACE;AAAA,UACA;AAAA,QACF;AAAA,QACA;AAAA,UACE;AAAA,UACA;AAAA,QACF;AAAA,QACA;AAAA,UACE;AAAA,UACA;AAAA,QACF;AAAA,QACA;AAAA,UACE;AAAA,UACA;AAAA,QACF;AAAA,QACA;AAAA,UACE;AAAA,UACA;AAAA,QACF;AAAA,QACA;AAAA,UACE;AAAA,UACA;AAAA,QACF;AAAA,QACA;AAAA,UACE;AAAA,UACA;AAAA,QACF;AAAA,QACA;AAAA,UACE;AAAA,UACA;AAAA,QACF;AAAA,QACA;AAAA,UACE;AAAA,UACA;AAAA,QACF;AAAA,QACA;AAAA,UACE;AAAA,UACA;AAAA,QACF;AAAA,QACA;AAAA,UACE;AAAA,UACA;AAAA,QACF;AAAA,QACA;AAAA,UACE;AAAA,UACA;AAAA,QACF;AAAA,QACA;AAAA,UACE;AAAA,UACA;AAAA,QACF;AAAA,QACA;AAAA,UACE;AAAA,UACA;AAAA,QACF;AAAA,QACA;AAAA,UACE;AAAA,UACA;AAAA,QACF;AAAA,QACA;AAAA,UACE;AAAA,UACA;AAAA,QACF;AAAA,QACA;AAAA,UACE;AAAA,UACA;AAAA,QACF;AAAA,QACA;AAAA,UACE;AAAA,UACA;AAAA,QACF;AAAA,QACA;AAAA,UACE;AAAA,UACA;AAAA,QACF;AAAA,QACA;AAAA,UACE;AAAA,UACA;AAAA,QACF;AAAA,QACA;AAAA,UACE;AAAA,UACA;AAAA,QACF;AAAA,QACA;AAAA,UACE;AAAA,UACA;AAAA,QACF;AAAA,QACA;AAAA,UACE;AAAA,UACA;AAAA,QACF;AAAA,QACA;AAAA,UACE;AAAA,UACA;AAAA,QACF;AAAA,QACA;AAAA,UACE;AAAA,UACA;AAAA,QACF;AAAA,QACA;AAAA,UACE;AAAA,UACA;AAAA,QACF;AAAA,QACA;AAAA,UACE;AAAA,UACA;AAAA,QACF;AAAA,QACA;AAAA,UACE;AAAA,UACA;AAAA,QACF;AAAA,QACA;AAAA,UACE;AAAA,UACA;AAAA,QACF;AAAA,QACA;AAAA,UACE;AAAA,UACA;AAAA,QACF;AAAA,QACA;AAAA,UACE;AAAA,UACA;AAAA,QACF;AAAA,QACA;AAAA,UACE;AAAA,UACA;AAAA,QACF;AAAA,QACA;AAAA,UACE;AAAA,UACA;AAAA,QACF;AAAA,QACA;AAAA,UACE;AAAA,UACA;AAAA,QACF;AAAA,QACA;AAAA,UACE;AAAA,UACA;AAAA,QACF;AAAA,QACA;AAAA,UACE;AAAA,UACA;AAAA,QACF;AAAA,QACA;AAAA,UACE;AAAA,UACA;AAAA,QACF;AAAA,QACA;AAAA,UACE;AAAA,UACA;AAAA,QACF;AAAA,QACA;AAAA,UACE;AAAA,UACA;AAAA,QACF;AAAA,QACA;AAAA,UACE;AAAA,UACA;AAAA,QACF;AAAA,QACA;AAAA,UACE;AAAA,UACA;AAAA,QACF;AAAA,QACA;AAAA,UACE;AAAA,UACA;AAAA,QACF;AAAA,QACA;AAAA,UACE;AAAA,UACA;AAAA,QACF;AAAA,QACA;AAAA,UACE;AAAA,UACA;AAAA,QACF;AAAA,QACA;AAAA,UACE;AAAA,UACA;AAAA,QACF;AAAA,QACA;AAAA,UACE;AAAA,UACA;AAAA,QACF;AAAA,QACA;AAAA,UACE;AAAA,UACA;AAAA,QACF;AAAA,QACA;AAAA,UACE;AAAA,UACA;AAAA,QACF;AAAA,QACA;AAAA,UACE;AAAA,UACA;AAAA,QACF;AAAA,QACA;AAAA,UACE;AAAA,UACA;AAAA,QACF;AAAA,QACA;AAAA,UACE;AAAA,UACA;AAAA,QACF;AAAA,QACA;AAAA,UACE;AAAA,UACA;AAAA,QACF;AAAA,QACA;AAAA,UACE;AAAA,UACA;AAAA,QACF;AAAA,QACA;AAAA,UACE;AAAA,UACA;AAAA,QACF;AAAA,QACA;AAAA,UACE;AAAA,UACA;AAAA,QACF;AAAA,QACA;AAAA,UACE;AAAA,UACA;AAAA,QACF;AAAA,QACA;AAAA,UACE;AAAA,UACA;AAAA,QACF;AAAA,QACA;AAAA,UACE;AAAA,UACA;AAAA,QACF;AAAA,QACA;AAAA,UACE;AAAA,UACA;AAAA,QACF;AAAA,QACA;AAAA,UACE;AAAA,UACA;AAAA,QACF;AAAA,QACA;AAAA,UACE;AAAA,UACA;AAAA,QACF;AAAA,QACA;AAAA,UACE;AAAA,UACA;AAAA,QACF;AAAA,QACA;AAAA,UACE;AAAA,UACA;AAAA,QACF;AAAA,QACA;AAAA,UACE;AAAA,UACA;AAAA,QACF;AAAA,QACA;AAAA,UACE;AAAA,UACA;AAAA,QACF;AAAA,QACA;AAAA,UACE;AAAA,UACA;AAAA,QACF;AAAA,QACA;AAAA,UACE;AAAA,UACA;AAAA,QACF;AAAA,QACA;AAAA,UACE;AAAA,UACA;AAAA,QACF;AAAA,QACA;AAAA,UACE;AAAA,UACA;AAAA,QACF;AAAA,QACA;AAAA,UACE;AAAA,UACA;AAAA,QACF;AAAA,QACA;AAAA,UACE;AAAA,UACA;AAAA,QACF;AAAA,QACA;AAAA,UACE;AAAA,UACA;AAAA,QACF;AAAA,QACA;AAAA,UACE;AAAA,UACA;AAAA,QACF;AAAA,QACA;AAAA,UACE;AAAA,UACA;AAAA,QACF;AAAA,QACA;AAAA,UACE;AAAA,UACA;AAAA,QACF;AAAA,QACA;AAAA,UACE;AAAA,UACA;AAAA,QACF;AAAA,QACA;AAAA,UACE;AAAA,UACA;AAAA,QACF;AAAA,QACA;AAAA,UACE;AAAA,UACA;AA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",
  "debugId": "F43A0BF57718A84E64756E2164756E21",
  "names": []
}