{"version":3,"sources":["../node_modules/public-encrypt/node_modules/bn.js/lib/bn.js","../node_modules/public-encrypt/mgf.js","../node_modules/public-encrypt/xor.js","../node_modules/public-encrypt/withPublic.js","../node_modules/query-string/index.js","../node_modules/public-encrypt/browser.js","../node_modules/public-encrypt/publicEncrypt.js","../node_modules/public-encrypt/privateDecrypt.js"],"names":["module","exports","assert","val","msg","Error","inherits","ctor","superCtor","super_","TempCtor","prototype","constructor","BN","number","base","endian","isBN","this","negative","words","length","red","_init","Buffer","wordSize","window","require","e","parseHex4Bits","string","index","c","charCodeAt","parseHexByte","lowerBound","r","parseBase","str","start","end","mul","len","Math","min","i","num","Array","isArray","max","left","right","cmp","_initNumber","_initArray","toString","replace","_parseHex","_parseBase","toArray","ceil","j","w","off","strip","limbLen","limbPow","total","mod","word","imuln","_iaddn","pow","copy","dest","clone","_expand","size","_normSign","inspect","zeros","groupSizes","groupBases","smallMulTo","self","out","a","b","lo","carry","k","ncarry","rword","maxJ","padding","groupSize","groupBase","isZero","modn","idivn","toNumber","ret","toJSON","toBuffer","toArrayLike","ArrayType","byteLength","reqLength","littleEndian","res","q","andln","iushrn","clz32","_countBits","t","_zeroBits","bitLength","hi","zeroBits","toTwos","width","abs","inotn","iaddn","fromTwos","testn","notn","ineg","isNeg","neg","iuor","ior","or","uor","iuand","iand","and","uand","iuxor","ixor","xor","uxor","bytesNeeded","bitsLeft","setn","bit","wbit","iadd","isub","add","sub","comb10MulTo","mid","o","a0","al0","ah0","a1","al1","ah1","a2","al2","ah2","a3","al3","ah3","a4","al4","ah4","a5","al5","ah5","a6","al6","ah6","a7","al7","ah7","a8","al8","ah8","a9","al9","ah9","b0","bl0","bh0","b1","bl1","bh1","b2","bl2","bh2","b3","bl3","bh3","b4","bl4","bh4","b5","bl5","bh5","b6","bl6","bh6","b7","bl7","bh7","b8","bl8","bh8","b9","bl9","bh9","w0","imul","w1","w2","w3","w4","w5","w6","w7","w8","w9","w10","w11","w12","w13","w14","w15","w16","w17","w18","jumboMulTo","FFTM","mulp","x","y","mulTo","hncarry","bigMulTo","makeRBT","N","l","revBin","rb","permute","rbt","rws","iws","rtws","itws","transform","s","rtwdf","cos","PI","itwdf","sin","p","rtwdf_","itwdf_","re","ie","ro","io","rx","guessLen13b","n","m","odd","conjugate","normalize13b","ws","round","convert13b","stub","ph","_","rwst","iwst","nrws","nrwst","niwst","rmws","mulf","muln","sqr","isqr","toBitArray","iushln","bits","carryMask","newCarry","ishln","hint","extended","h","mask","maskedWords","ishrn","shln","ushln","shrn","ushrn","imaskn","maskn","isubn","addn","subn","iabs","_ishlnsubmul","shift","_wordDiv","mode","bhi","diff","qj","div","divmod","positive","divn","umod","divRound","dm","half","r2","acc","egcd","A","B","C","D","g","isEven","yp","xp","im","isOdd","jm","gcd","_invmp","x1","x2","delta","cmpn","invm","bincn","ucmp","gtn","gt","gten","gte","ltn","lt","lten","lte","eqn","eq","Red","toRed","ctx","convertTo","_forceRed","fromRed","convertFrom","forceRed","redAdd","redIAdd","redSub","redISub","redShl","shl","redMul","_verify2","redIMul","redSqr","_verify1","redISqr","redSqrt","sqrt","redInvm","redNeg","redPow","primes","k256","p224","p192","p25519","MPrime","name","tmp","_tmp","K256","call","P224","P192","P25519","prime","_prime","Mont","imod","rinv","minv","ireduce","rlen","split","imulK","undefined","_strip","input","output","outLen","prev","next","mod3","one","nOne","lpow","z","inv","wnd","current","currentLen","mont","u","createHash","i2ops","allocUnsafe","writeUInt32BE","seed","alloc","concat","update","digest","slice","paddedMsg","key","from","modulus","publicExponent","strictUriEncode","objectAssign","encode","value","opts","strict","encodeURIComponent","keysSorter","sort","Object","keys","Number","map","extract","parse","formatter","result","arrayFormat","accumulator","exec","parserForArrayFormat","create","trim","forEach","param","parts","join","decodeURIComponent","reduce","Boolean","stringify","obj","encoderForArrayFormat","val2","push","filter","publicEncrypt","privateDecrypt","privateEncrypt","buf","publicDecrypt","parseKeys","randomBytes","mgf","withPublic","crt","publicKey","reverse","mLen","iHash","hLen","hLen2","ps","dblen","maskedDb","maskedSeed","oaep","cache","cur","nonZero","pkcs1","privateKey","enc","zBuffer","db","dif","compare","p1","status"],"mappings":"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","file":"static/js/main~f9ca8911.43097e22.chunk.js","sourcesContent":["(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 ? '';\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 if (carry !== 0 || i !== this.length - 1) {\n out = zeros[6 - word.length] + word + out;\n } else {\n out = word + out;\n }\n off += 2;\n if (off >= 26) {\n off -= 26;\n i--;\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\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","var createHash = require('create-hash')\nvar Buffer = require('safe-buffer').Buffer\n\nmodule.exports = function (seed, len) {\n var t = Buffer.alloc(0)\n var i = 0\n var c\n while (t.length < len) {\n c = i2ops(i++)\n t = Buffer.concat([t, createHash('sha1').update(seed).update(c).digest()])\n }\n return t.slice(0, len)\n}\n\nfunction i2ops (c) {\n var out = Buffer.allocUnsafe(4)\n out.writeUInt32BE(c, 0)\n return out\n}\n","module.exports = function xor (a, b) {\n var len = a.length\n var i = -1\n while (++i < len) {\n a[i] ^= b[i]\n }\n return a\n}\n","var BN = require('bn.js')\nvar Buffer = require('safe-buffer').Buffer\n\nfunction withPublic (paddedMsg, key) {\n return Buffer.from(paddedMsg\n .toRed(BN.mont(key.modulus))\n .redPow(new BN(key.publicExponent))\n .fromRed()\n .toArray())\n}\n\nmodule.exports = withPublic\n","'use strict';\nvar strictUriEncode = require('strict-uri-encode');\nvar objectAssign = require('object-assign');\n\nfunction encoderForArrayFormat(opts) {\n\tswitch (opts.arrayFormat) {\n\t\tcase 'index':\n\t\t\treturn function (key, value, index) {\n\t\t\t\treturn value === null ? [\n\t\t\t\t\tencode(key, opts),\n\t\t\t\t\t'[',\n\t\t\t\t\tindex,\n\t\t\t\t\t']'\n\t\t\t\t].join('') : [\n\t\t\t\t\tencode(key, opts),\n\t\t\t\t\t'[',\n\t\t\t\t\tencode(index, opts),\n\t\t\t\t\t']=',\n\t\t\t\t\tencode(value, opts)\n\t\t\t\t].join('');\n\t\t\t};\n\n\t\tcase 'bracket':\n\t\t\treturn function (key, value) {\n\t\t\t\treturn value === null ? encode(key, opts) : [\n\t\t\t\t\tencode(key, opts),\n\t\t\t\t\t'[]=',\n\t\t\t\t\tencode(value, opts)\n\t\t\t\t].join('');\n\t\t\t};\n\n\t\tdefault:\n\t\t\treturn function (key, value) {\n\t\t\t\treturn value === null ? encode(key, opts) : [\n\t\t\t\t\tencode(key, opts),\n\t\t\t\t\t'=',\n\t\t\t\t\tencode(value, opts)\n\t\t\t\t].join('');\n\t\t\t};\n\t}\n}\n\nfunction parserForArrayFormat(opts) {\n\tvar result;\n\n\tswitch (opts.arrayFormat) {\n\t\tcase 'index':\n\t\t\treturn function (key, value, accumulator) {\n\t\t\t\tresult = /\\[(\\d*)\\]$/.exec(key);\n\n\t\t\t\tkey = key.replace(/\\[\\d*\\]$/, '');\n\n\t\t\t\tif (!result) {\n\t\t\t\t\taccumulator[key] = value;\n\t\t\t\t\treturn;\n\t\t\t\t}\n\n\t\t\t\tif (accumulator[key] === undefined) {\n\t\t\t\t\taccumulator[key] = {};\n\t\t\t\t}\n\n\t\t\t\taccumulator[key][result[1]] = value;\n\t\t\t};\n\n\t\tcase 'bracket':\n\t\t\treturn function (key, value, accumulator) {\n\t\t\t\tresult = /(\\[\\])$/.exec(key);\n\t\t\t\tkey = key.replace(/\\[\\]$/, '');\n\n\t\t\t\tif (!result) {\n\t\t\t\t\taccumulator[key] = value;\n\t\t\t\t\treturn;\n\t\t\t\t} else if (accumulator[key] === undefined) {\n\t\t\t\t\taccumulator[key] = [value];\n\t\t\t\t\treturn;\n\t\t\t\t}\n\n\t\t\t\taccumulator[key] = [].concat(accumulator[key], value);\n\t\t\t};\n\n\t\tdefault:\n\t\t\treturn function (key, value, accumulator) {\n\t\t\t\tif (accumulator[key] === undefined) {\n\t\t\t\t\taccumulator[key] = value;\n\t\t\t\t\treturn;\n\t\t\t\t}\n\n\t\t\t\taccumulator[key] = [].concat(accumulator[key], value);\n\t\t\t};\n\t}\n}\n\nfunction encode(value, opts) {\n\tif (opts.encode) {\n\t\treturn opts.strict ? strictUriEncode(value) : encodeURIComponent(value);\n\t}\n\n\treturn value;\n}\n\nfunction keysSorter(input) {\n\tif (Array.isArray(input)) {\n\t\treturn input.sort();\n\t} else if (typeof input === 'object') {\n\t\treturn keysSorter(Object.keys(input)).sort(function (a, b) {\n\t\t\treturn Number(a) - Number(b);\n\t\t}).map(function (key) {\n\t\t\treturn input[key];\n\t\t});\n\t}\n\n\treturn input;\n}\n\nexports.extract = function (str) {\n\treturn str.split('?')[1] || '';\n};\n\nexports.parse = function (str, opts) {\n\topts = objectAssign({arrayFormat: 'none'}, opts);\n\n\tvar formatter = parserForArrayFormat(opts);\n\n\t// Create an object with no prototype\n\t// https://github.com/sindresorhus/query-string/issues/47\n\tvar ret = Object.create(null);\n\n\tif (typeof str !== 'string') {\n\t\treturn ret;\n\t}\n\n\tstr = str.trim().replace(/^(\\?|#|&)/, '');\n\n\tif (!str) {\n\t\treturn ret;\n\t}\n\n\tstr.split('&').forEach(function (param) {\n\t\tvar parts = param.replace(/\\+/g, ' ').split('=');\n\t\t// Firefox (pre 40) decodes `%3D` to `=`\n\t\t// https://github.com/sindresorhus/query-string/pull/37\n\t\tvar key = parts.shift();\n\t\tvar val = parts.length > 0 ? parts.join('=') : undefined;\n\n\t\t// missing `=` should be `null`:\n\t\t// http://w3.org/TR/2012/WD-url-20120524/#collect-url-parameters\n\t\tval = val === undefined ? null : decodeURIComponent(val);\n\n\t\tformatter(decodeURIComponent(key), val, ret);\n\t});\n\n\treturn Object.keys(ret).sort().reduce(function (result, key) {\n\t\tvar val = ret[key];\n\t\tif (Boolean(val) && typeof val === 'object' && !Array.isArray(val)) {\n\t\t\t// Sort object keys, not values\n\t\t\tresult[key] = keysSorter(val);\n\t\t} else {\n\t\t\tresult[key] = val;\n\t\t}\n\n\t\treturn result;\n\t}, Object.create(null));\n};\n\nexports.stringify = function (obj, opts) {\n\tvar defaults = {\n\t\tencode: true,\n\t\tstrict: true,\n\t\tarrayFormat: 'none'\n\t};\n\n\topts = objectAssign(defaults, opts);\n\n\tvar formatter = encoderForArrayFormat(opts);\n\n\treturn obj ? Object.keys(obj).sort().map(function (key) {\n\t\tvar val = obj[key];\n\n\t\tif (val === undefined) {\n\t\t\treturn '';\n\t\t}\n\n\t\tif (val === null) {\n\t\t\treturn encode(key, opts);\n\t\t}\n\n\t\tif (Array.isArray(val)) {\n\t\t\tvar result = [];\n\n\t\t\tval.slice().forEach(function (val2) {\n\t\t\t\tif (val2 === undefined) {\n\t\t\t\t\treturn;\n\t\t\t\t}\n\n\t\t\t\tresult.push(formatter(key, val2, result.length));\n\t\t\t});\n\n\t\t\treturn result.join('&');\n\t\t}\n\n\t\treturn encode(key, opts) + '=' + encode(val, opts);\n\t}).filter(function (x) {\n\t\treturn x.length > 0;\n\t}).join('&') : '';\n};\n","exports.publicEncrypt = require('./publicEncrypt')\nexports.privateDecrypt = require('./privateDecrypt')\n\nexports.privateEncrypt = function privateEncrypt (key, buf) {\n return exports.publicEncrypt(key, buf, true)\n}\n\nexports.publicDecrypt = function publicDecrypt (key, buf) {\n return exports.privateDecrypt(key, buf, true)\n}\n","var parseKeys = require('parse-asn1')\nvar randomBytes = require('randombytes')\nvar createHash = require('create-hash')\nvar mgf = require('./mgf')\nvar xor = require('./xor')\nvar BN = require('bn.js')\nvar withPublic = require('./withPublic')\nvar crt = require('browserify-rsa')\nvar Buffer = require('safe-buffer').Buffer\n\nmodule.exports = function publicEncrypt (publicKey, msg, reverse) {\n var padding\n if (publicKey.padding) {\n padding = publicKey.padding\n } else if (reverse) {\n padding = 1\n } else {\n padding = 4\n }\n var key = parseKeys(publicKey)\n var paddedMsg\n if (padding === 4) {\n paddedMsg = oaep(key, msg)\n } else if (padding === 1) {\n paddedMsg = pkcs1(key, msg, reverse)\n } else if (padding === 3) {\n paddedMsg = new BN(msg)\n if (paddedMsg.cmp(key.modulus) >= 0) {\n throw new Error('data too long for modulus')\n }\n } else {\n throw new Error('unknown padding')\n }\n if (reverse) {\n return crt(paddedMsg, key)\n } else {\n return withPublic(paddedMsg, key)\n }\n}\n\nfunction oaep (key, msg) {\n var k = key.modulus.byteLength()\n var mLen = msg.length\n var iHash = createHash('sha1').update(Buffer.alloc(0)).digest()\n var hLen = iHash.length\n var hLen2 = 2 * hLen\n if (mLen > k - hLen2 - 2) {\n throw new Error('message too long')\n }\n var ps = Buffer.alloc(k - mLen - hLen2 - 2)\n var dblen = k - hLen - 1\n var seed = randomBytes(hLen)\n var maskedDb = xor(Buffer.concat([iHash, ps, Buffer.alloc(1, 1), msg], dblen), mgf(seed, dblen))\n var maskedSeed = xor(seed, mgf(maskedDb, hLen))\n return new BN(Buffer.concat([Buffer.alloc(1), maskedSeed, maskedDb], k))\n}\nfunction pkcs1 (key, msg, reverse) {\n var mLen = msg.length\n var k = key.modulus.byteLength()\n if (mLen > k - 11) {\n throw new Error('message too long')\n }\n var ps\n if (reverse) {\n ps = Buffer.alloc(k - mLen - 3, 0xff)\n } else {\n ps = nonZero(k - mLen - 3)\n }\n return new BN(Buffer.concat([Buffer.from([0, reverse ? 1 : 2]), ps, Buffer.alloc(1), msg], k))\n}\nfunction nonZero (len) {\n var out = Buffer.allocUnsafe(len)\n var i = 0\n var cache = randomBytes(len * 2)\n var cur = 0\n var num\n while (i < len) {\n if (cur === cache.length) {\n cache = randomBytes(len * 2)\n cur = 0\n }\n num = cache[cur++]\n if (num) {\n out[i++] = num\n }\n }\n return out\n}\n","var parseKeys = require('parse-asn1')\nvar mgf = require('./mgf')\nvar xor = require('./xor')\nvar BN = require('bn.js')\nvar crt = require('browserify-rsa')\nvar createHash = require('create-hash')\nvar withPublic = require('./withPublic')\nvar Buffer = require('safe-buffer').Buffer\n\nmodule.exports = function privateDecrypt (privateKey, enc, reverse) {\n var padding\n if (privateKey.padding) {\n padding = privateKey.padding\n } else if (reverse) {\n padding = 1\n } else {\n padding = 4\n }\n\n var key = parseKeys(privateKey)\n var k = key.modulus.byteLength()\n if (enc.length > k || new BN(enc).cmp(key.modulus) >= 0) {\n throw new Error('decryption error')\n }\n var msg\n if (reverse) {\n msg = withPublic(new BN(enc), key)\n } else {\n msg = crt(enc, key)\n }\n var zBuffer = Buffer.alloc(k - msg.length)\n msg = Buffer.concat([zBuffer, msg], k)\n if (padding === 4) {\n return oaep(key, msg)\n } else if (padding === 1) {\n return pkcs1(key, msg, reverse)\n } else if (padding === 3) {\n return msg\n } else {\n throw new Error('unknown padding')\n }\n}\n\nfunction oaep (key, msg) {\n var k = key.modulus.byteLength()\n var iHash = createHash('sha1').update(Buffer.alloc(0)).digest()\n var hLen = iHash.length\n if (msg[0] !== 0) {\n throw new Error('decryption error')\n }\n var maskedSeed = msg.slice(1, hLen + 1)\n var maskedDb = msg.slice(hLen + 1)\n var seed = xor(maskedSeed, mgf(maskedDb, hLen))\n var db = xor(maskedDb, mgf(seed, k - hLen - 1))\n if (compare(iHash, db.slice(0, hLen))) {\n throw new Error('decryption error')\n }\n var i = hLen\n while (db[i] === 0) {\n i++\n }\n if (db[i++] !== 1) {\n throw new Error('decryption error')\n }\n return db.slice(i)\n}\n\nfunction pkcs1 (key, msg, reverse) {\n var p1 = msg.slice(0, 2)\n var i = 2\n var status = 0\n while (msg[i++] !== 0) {\n if (i >= msg.length) {\n status++\n break\n }\n }\n var ps = msg.slice(2, i - 1)\n\n if ((p1.toString('hex') !== '0002' && !reverse) || (p1.toString('hex') !== '0001' && reverse)) {\n status++\n }\n if (ps.length < 8) {\n status++\n }\n if (status) {\n throw new Error('decryption error')\n }\n return msg.slice(i)\n}\nfunction compare (a, b) {\n a = Buffer.from(a)\n b = Buffer.from(b)\n var dif = 0\n var len = a.length\n if (a.length !== b.length) {\n dif++\n len = Math.min(a.length, b.length)\n }\n var i = -1\n while (++i < len) {\n dif += (a[i] ^ b[i])\n }\n return dif\n}\n"],"sourceRoot":""}