{"version":3,"sources":["webpack:///./node_modules/browserify-aes/modes/ecb.js","webpack:///./node_modules/browserify-aes/streamCipher.js","webpack:///./node_modules/browserify-des/modes.js","webpack:///./node_modules/browserify-des/index.js","webpack:///./node_modules/browserify-aes/modes/cfb.js","webpack:///./node_modules/browserify-aes/aes.js","webpack:///./node_modules/browserify-aes/ghash.js","webpack:///./node_modules/browserify-aes/decrypter.js","webpack:///./node_modules/browserify-aes/modes/ofb.js","webpack:///./node_modules/browserify-aes/modes/cfb1.js","webpack:///./node_modules/browserify-aes/modes/cfb8.js","webpack:///./node_modules/browserify-aes/modes/ctr.js","webpack:///./node_modules/browserify-aes/authCipher.js","webpack:///./node_modules/browserify-aes/encrypter.js","webpack:///./node_modules/browserify-cipher/browser.js","webpack:///./node_modules/browserify-rsa/node_modules/bn.js/lib/bn.js","webpack:///./node_modules/browserify-rsa/index.js","webpack:///./node_modules/browserify-aes/modes/index.js","webpack:///./node_modules/browserify-aes/incr32.js","webpack:///./node_modules/browserify-aes/modes/cbc.js","webpack:///./node_modules/browserify-aes/browser.js","webpack:///./node_modules/brorand/index.js"],"names":["exports","encrypt","self","block","_cipher","encryptBlock","decrypt","decryptBlock","aes","Buffer","Transform","inherits","StreamCipher","mode","key","iv","call","this","AES","_prev","from","_cache","allocUnsafe","_secCache","_decrypt","_mode","prototype","_update","chunk","_final","scrub","module","des","des3","CipherBase","modes","CBC","instantiate","EDE","DES","opts","type","modeName","toLowerCase","isBuffer","concat","slice","_des","create","data","update","final","xor","encryptStart","len","length","out","asUInt32Array","buf","Array","i","readUInt32BE","scrubVec","v","cryptBlock","M","keySchedule","SUB_MIX","SBOX","nRounds","t0","t1","t2","t3","SUB_MIX0","SUB_MIX1","SUB_MIX2","SUB_MIX3","s0","s1","s2","s3","ksRow","round","RCON","G","d","j","INV_SBOX","INV_SUB_MIX","x","xi","sx","x2","x4","x8","t","_key","_reset","blockSize","keySize","keyWords","ksRows","k","invKeySchedule","ik","ksR","tt","_nRounds","_keySchedule","_invKeySchedule","encryptBlockRaw","writeUInt32BE","m1","ZEROES","alloc","toArray","fromArray","GHASH","h","state","cache","ghash","_multiply","lsbVi","Vi","Zi","abl","bl","AuthCipher","MODES","ebtk","Decipher","Splitter","_last","_autopadding","unpad","last","padded","Error","createDecipheriv","suite","password","config","TypeError","createDecipher","keys","thing","add","get","push","flush","setAutoPadding","setTo","autoPadding","getBlock","pad","encryptByte","byteParam","bit","value","shiftIn","buffer","incr32","chunkNum","Math","ceil","start","offset","xorTest","a","b","min","calcIv","ck","_finID","toPad","ivBits","tail","writeUIntBE","_ghash","_alen","_len","_authTag","_called","rump","tag","getAuthTag","setAuthTag","setAAD","Cipher","PADDING","createCipheriv","createCipher","equals","padBuff","writeUInt8","aesModes","desModes","keyLen","ivLen","getCiphers","Object","Cipheriv","Decipheriv","listCiphers","assert","val","msg","ctor","superCtor","super_","TempCtor","constructor","BN","number","base","endian","isBN","negative","words","red","_init","wordSize","e","parseHex","str","end","r","c","charCodeAt","parseBase","mul","num","isArray","max","left","right","cmp","_initNumber","_initArray","toString","replace","_parseHex","_parseBase","strip","w","off","limbLen","limbPow","total","mod","word","imuln","_iaddn","pow","copy","dest","clone","_expand","size","_normSign","inspect","zeros","groupSizes","groupBases","toBitArray","bitLength","wbit","smallMulTo","lo","carry","ncarry","rword","maxJ","padding","groupSize","groupBase","isZero","modn","idivn","toNumber","ret","toJSON","toBuffer","toArrayLike","ArrayType","byteLength","reqLength","littleEndian","res","q","andln","iushrn","clz32","_countBits","_zeroBits","hi","zeroBits","toTwos","width","abs","inotn","iaddn","fromTwos","testn","notn","ineg","isNeg","neg","iuor","ior","or","uor","iuand","iand","and","uand","iuxor","ixor","uxor","bytesNeeded","bitsLeft","setn","iadd","isub","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","imul","w0","w1","w2","w3","w4","w5","w6","w7","w8","w9","w10","w11","w12","w13","w14","w15","w16","w17","w18","bigMulTo","hncarry","jumboMulTo","fftm","FFTM","mulp","y","mulTo","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","convert13b","stub","ph","_","rwst","iwst","nrws","nrwst","niwst","rmws","mulf","muln","sqr","isqr","iushln","bits","carryMask","newCarry","ishln","hint","extended","mask","maskedWords","ishrn","shln","ushln","shrn","ushrn","imaskn","maskn","isubn","addn","subn","iabs","_ishlnsubmul","shift","_wordDiv","bhi","bhiBits","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","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","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","windowSize","wnd","current","currentLen","mont","u","randomBytes","blind","priv","getr","blinder","bn","modulus","publicExponent","unblinder","crt","blinds","blinded","c1","prime1","c2","prime2","qinv","coefficient","exponent1","m2","exponent2","modeModules","ECB","CFB","CFB8","CFB1","OFB","CTR","GCM","item","readUInt8","ciphers","deciphers","Rand","rand","generate","_rand","getBytes","Uint8Array","getByte","crypto","getRandomValues","arr","msCrypto","window"],"mappings":"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","file":"js/chunk-vendors~5bb1f863.0858621e.js","sourcesContent":["exports.encrypt = function (self, block) {\n return self._cipher.encryptBlock(block)\n}\n\nexports.decrypt = function (self, block) {\n return self._cipher.decryptBlock(block)\n}\n","var aes = require('./aes')\nvar Buffer = require('safe-buffer').Buffer\nvar Transform = require('cipher-base')\nvar inherits = require('inherits')\n\nfunction StreamCipher (mode, key, iv, decrypt) {\n Transform.call(this)\n\n this._cipher = new aes.AES(key)\n this._prev = Buffer.from(iv)\n this._cache = Buffer.allocUnsafe(0)\n this._secCache = Buffer.allocUnsafe(0)\n this._decrypt = decrypt\n this._mode = mode\n}\n\ninherits(StreamCipher, Transform)\n\nStreamCipher.prototype._update = function (chunk) {\n return this._mode.encrypt(this, chunk, this._decrypt)\n}\n\nStreamCipher.prototype._final = function () {\n this._cipher.scrub()\n}\n\nmodule.exports = StreamCipher\n","exports['des-ecb'] = {\n key: 8,\n iv: 0\n}\nexports['des-cbc'] = exports.des = {\n key: 8,\n iv: 8\n}\nexports['des-ede3-cbc'] = exports.des3 = {\n key: 24,\n iv: 8\n}\nexports['des-ede3'] = {\n key: 24,\n iv: 0\n}\nexports['des-ede-cbc'] = {\n key: 16,\n iv: 8\n}\nexports['des-ede'] = {\n key: 16,\n iv: 0\n}\n","var CipherBase = require('cipher-base')\nvar des = require('des.js')\nvar inherits = require('inherits')\nvar Buffer = require('safe-buffer').Buffer\n\nvar modes = {\n 'des-ede3-cbc': des.CBC.instantiate(des.EDE),\n 'des-ede3': des.EDE,\n 'des-ede-cbc': des.CBC.instantiate(des.EDE),\n 'des-ede': des.EDE,\n 'des-cbc': des.CBC.instantiate(des.DES),\n 'des-ecb': des.DES\n}\nmodes.des = modes['des-cbc']\nmodes.des3 = modes['des-ede3-cbc']\nmodule.exports = DES\ninherits(DES, CipherBase)\nfunction DES (opts) {\n CipherBase.call(this)\n var modeName = opts.mode.toLowerCase()\n var mode = modes[modeName]\n var type\n if (opts.decrypt) {\n type = 'decrypt'\n } else {\n type = 'encrypt'\n }\n var key = opts.key\n if (!Buffer.isBuffer(key)) {\n key = Buffer.from(key)\n }\n if (modeName === 'des-ede' || modeName === 'des-ede-cbc') {\n key = Buffer.concat([key, key.slice(0, 8)])\n }\n var iv = opts.iv\n if (!Buffer.isBuffer(iv)) {\n iv = Buffer.from(iv)\n }\n this._des = mode.create({\n key: key,\n iv: iv,\n type: type\n })\n}\nDES.prototype._update = function (data) {\n return Buffer.from(this._des.update(data))\n}\nDES.prototype._final = function () {\n return Buffer.from(this._des.final())\n}\n","var Buffer = require('safe-buffer').Buffer\nvar xor = require('buffer-xor')\n\nfunction encryptStart (self, data, decrypt) {\n var len = data.length\n var out = xor(data, self._cache)\n self._cache = self._cache.slice(len)\n self._prev = Buffer.concat([self._prev, decrypt ? data : out])\n return out\n}\n\nexports.encrypt = function (self, data, decrypt) {\n var out = Buffer.allocUnsafe(0)\n var len\n\n while (data.length) {\n if (self._cache.length === 0) {\n self._cache = self._cipher.encryptBlock(self._prev)\n self._prev = Buffer.allocUnsafe(0)\n }\n\n if (self._cache.length <= data.length) {\n len = self._cache.length\n out = Buffer.concat([out, encryptStart(self, data.slice(0, len), decrypt)])\n data = data.slice(len)\n } else {\n out = Buffer.concat([out, encryptStart(self, data, decrypt)])\n break\n }\n }\n\n return out\n}\n","// based on the aes implimentation in triple sec\n// https://github.com/keybase/triplesec\n// which is in turn based on the one from crypto-js\n// https://code.google.com/p/crypto-js/\n\nvar Buffer = require('safe-buffer').Buffer\n\nfunction asUInt32Array (buf) {\n if (!Buffer.isBuffer(buf)) buf = Buffer.from(buf)\n\n var len = (buf.length / 4) | 0\n var out = new Array(len)\n\n for (var i = 0; i < len; i++) {\n out[i] = buf.readUInt32BE(i * 4)\n }\n\n return out\n}\n\nfunction scrubVec (v) {\n for (var i = 0; i < v.length; v++) {\n v[i] = 0\n }\n}\n\nfunction cryptBlock (M, keySchedule, SUB_MIX, SBOX, nRounds) {\n var SUB_MIX0 = SUB_MIX[0]\n var SUB_MIX1 = SUB_MIX[1]\n var SUB_MIX2 = SUB_MIX[2]\n var SUB_MIX3 = SUB_MIX[3]\n\n var s0 = M[0] ^ keySchedule[0]\n var s1 = M[1] ^ keySchedule[1]\n var s2 = M[2] ^ keySchedule[2]\n var s3 = M[3] ^ keySchedule[3]\n var t0, t1, t2, t3\n var ksRow = 4\n\n for (var round = 1; round < nRounds; round++) {\n t0 = SUB_MIX0[s0 >>> 24] ^ SUB_MIX1[(s1 >>> 16) & 0xff] ^ SUB_MIX2[(s2 >>> 8) & 0xff] ^ SUB_MIX3[s3 & 0xff] ^ keySchedule[ksRow++]\n t1 = SUB_MIX0[s1 >>> 24] ^ SUB_MIX1[(s2 >>> 16) & 0xff] ^ SUB_MIX2[(s3 >>> 8) & 0xff] ^ SUB_MIX3[s0 & 0xff] ^ keySchedule[ksRow++]\n t2 = SUB_MIX0[s2 >>> 24] ^ SUB_MIX1[(s3 >>> 16) & 0xff] ^ SUB_MIX2[(s0 >>> 8) & 0xff] ^ SUB_MIX3[s1 & 0xff] ^ keySchedule[ksRow++]\n t3 = SUB_MIX0[s3 >>> 24] ^ SUB_MIX1[(s0 >>> 16) & 0xff] ^ SUB_MIX2[(s1 >>> 8) & 0xff] ^ SUB_MIX3[s2 & 0xff] ^ keySchedule[ksRow++]\n s0 = t0\n s1 = t1\n s2 = t2\n s3 = t3\n }\n\n t0 = ((SBOX[s0 >>> 24] << 24) | (SBOX[(s1 >>> 16) & 0xff] << 16) | (SBOX[(s2 >>> 8) & 0xff] << 8) | SBOX[s3 & 0xff]) ^ keySchedule[ksRow++]\n t1 = ((SBOX[s1 >>> 24] << 24) | (SBOX[(s2 >>> 16) & 0xff] << 16) | (SBOX[(s3 >>> 8) & 0xff] << 8) | SBOX[s0 & 0xff]) ^ keySchedule[ksRow++]\n t2 = ((SBOX[s2 >>> 24] << 24) | (SBOX[(s3 >>> 16) & 0xff] << 16) | (SBOX[(s0 >>> 8) & 0xff] << 8) | SBOX[s1 & 0xff]) ^ keySchedule[ksRow++]\n t3 = ((SBOX[s3 >>> 24] << 24) | (SBOX[(s0 >>> 16) & 0xff] << 16) | (SBOX[(s1 >>> 8) & 0xff] << 8) | SBOX[s2 & 0xff]) ^ keySchedule[ksRow++]\n t0 = t0 >>> 0\n t1 = t1 >>> 0\n t2 = t2 >>> 0\n t3 = t3 >>> 0\n\n return [t0, t1, t2, t3]\n}\n\n// AES constants\nvar RCON = [0x00, 0x01, 0x02, 0x04, 0x08, 0x10, 0x20, 0x40, 0x80, 0x1b, 0x36]\nvar G = (function () {\n // Compute double table\n var d = new Array(256)\n for (var j = 0; j < 256; j++) {\n if (j < 128) {\n d[j] = j << 1\n } else {\n d[j] = (j << 1) ^ 0x11b\n }\n }\n\n var SBOX = []\n var INV_SBOX = []\n var SUB_MIX = [[], [], [], []]\n var INV_SUB_MIX = [[], [], [], []]\n\n // Walk GF(2^8)\n var x = 0\n var xi = 0\n for (var i = 0; i < 256; ++i) {\n // Compute sbox\n var sx = xi ^ (xi << 1) ^ (xi << 2) ^ (xi << 3) ^ (xi << 4)\n sx = (sx >>> 8) ^ (sx & 0xff) ^ 0x63\n SBOX[x] = sx\n INV_SBOX[sx] = x\n\n // Compute multiplication\n var x2 = d[x]\n var x4 = d[x2]\n var x8 = d[x4]\n\n // Compute sub bytes, mix columns tables\n var t = (d[sx] * 0x101) ^ (sx * 0x1010100)\n SUB_MIX[0][x] = (t << 24) | (t >>> 8)\n SUB_MIX[1][x] = (t << 16) | (t >>> 16)\n SUB_MIX[2][x] = (t << 8) | (t >>> 24)\n SUB_MIX[3][x] = t\n\n // Compute inv sub bytes, inv mix columns tables\n t = (x8 * 0x1010101) ^ (x4 * 0x10001) ^ (x2 * 0x101) ^ (x * 0x1010100)\n INV_SUB_MIX[0][sx] = (t << 24) | (t >>> 8)\n INV_SUB_MIX[1][sx] = (t << 16) | (t >>> 16)\n INV_SUB_MIX[2][sx] = (t << 8) | (t >>> 24)\n INV_SUB_MIX[3][sx] = t\n\n if (x === 0) {\n x = xi = 1\n } else {\n x = x2 ^ d[d[d[x8 ^ x2]]]\n xi ^= d[d[xi]]\n }\n }\n\n return {\n SBOX: SBOX,\n INV_SBOX: INV_SBOX,\n SUB_MIX: SUB_MIX,\n INV_SUB_MIX: INV_SUB_MIX\n }\n})()\n\nfunction AES (key) {\n this._key = asUInt32Array(key)\n this._reset()\n}\n\nAES.blockSize = 4 * 4\nAES.keySize = 256 / 8\nAES.prototype.blockSize = AES.blockSize\nAES.prototype.keySize = AES.keySize\nAES.prototype._reset = function () {\n var keyWords = this._key\n var keySize = keyWords.length\n var nRounds = keySize + 6\n var ksRows = (nRounds + 1) * 4\n\n var keySchedule = []\n for (var k = 0; k < keySize; k++) {\n keySchedule[k] = keyWords[k]\n }\n\n for (k = keySize; k < ksRows; k++) {\n var t = keySchedule[k - 1]\n\n if (k % keySize === 0) {\n t = (t << 8) | (t >>> 24)\n t =\n (G.SBOX[t >>> 24] << 24) |\n (G.SBOX[(t >>> 16) & 0xff] << 16) |\n (G.SBOX[(t >>> 8) & 0xff] << 8) |\n (G.SBOX[t & 0xff])\n\n t ^= RCON[(k / keySize) | 0] << 24\n } else if (keySize > 6 && k % keySize === 4) {\n t =\n (G.SBOX[t >>> 24] << 24) |\n (G.SBOX[(t >>> 16) & 0xff] << 16) |\n (G.SBOX[(t >>> 8) & 0xff] << 8) |\n (G.SBOX[t & 0xff])\n }\n\n keySchedule[k] = keySchedule[k - keySize] ^ t\n }\n\n var invKeySchedule = []\n for (var ik = 0; ik < ksRows; ik++) {\n var ksR = ksRows - ik\n var tt = keySchedule[ksR - (ik % 4 ? 0 : 4)]\n\n if (ik < 4 || ksR <= 4) {\n invKeySchedule[ik] = tt\n } else {\n invKeySchedule[ik] =\n G.INV_SUB_MIX[0][G.SBOX[tt >>> 24]] ^\n G.INV_SUB_MIX[1][G.SBOX[(tt >>> 16) & 0xff]] ^\n G.INV_SUB_MIX[2][G.SBOX[(tt >>> 8) & 0xff]] ^\n G.INV_SUB_MIX[3][G.SBOX[tt & 0xff]]\n }\n }\n\n this._nRounds = nRounds\n this._keySchedule = keySchedule\n this._invKeySchedule = invKeySchedule\n}\n\nAES.prototype.encryptBlockRaw = function (M) {\n M = asUInt32Array(M)\n return cryptBlock(M, this._keySchedule, G.SUB_MIX, G.SBOX, this._nRounds)\n}\n\nAES.prototype.encryptBlock = function (M) {\n var out = this.encryptBlockRaw(M)\n var buf = Buffer.allocUnsafe(16)\n buf.writeUInt32BE(out[0], 0)\n buf.writeUInt32BE(out[1], 4)\n buf.writeUInt32BE(out[2], 8)\n buf.writeUInt32BE(out[3], 12)\n return buf\n}\n\nAES.prototype.decryptBlock = function (M) {\n M = asUInt32Array(M)\n\n // swap\n var m1 = M[1]\n M[1] = M[3]\n M[3] = m1\n\n var out = cryptBlock(M, this._invKeySchedule, G.INV_SUB_MIX, G.INV_SBOX, this._nRounds)\n var buf = Buffer.allocUnsafe(16)\n buf.writeUInt32BE(out[0], 0)\n buf.writeUInt32BE(out[3], 4)\n buf.writeUInt32BE(out[2], 8)\n buf.writeUInt32BE(out[1], 12)\n return buf\n}\n\nAES.prototype.scrub = function () {\n scrubVec(this._keySchedule)\n scrubVec(this._invKeySchedule)\n scrubVec(this._key)\n}\n\nmodule.exports.AES = AES\n","var Buffer = require('safe-buffer').Buffer\nvar ZEROES = Buffer.alloc(16, 0)\n\nfunction toArray (buf) {\n return [\n buf.readUInt32BE(0),\n buf.readUInt32BE(4),\n buf.readUInt32BE(8),\n buf.readUInt32BE(12)\n ]\n}\n\nfunction fromArray (out) {\n var buf = Buffer.allocUnsafe(16)\n buf.writeUInt32BE(out[0] >>> 0, 0)\n buf.writeUInt32BE(out[1] >>> 0, 4)\n buf.writeUInt32BE(out[2] >>> 0, 8)\n buf.writeUInt32BE(out[3] >>> 0, 12)\n return buf\n}\n\nfunction GHASH (key) {\n this.h = key\n this.state = Buffer.alloc(16, 0)\n this.cache = Buffer.allocUnsafe(0)\n}\n\n// from http://bitwiseshiftleft.github.io/sjcl/doc/symbols/src/core_gcm.js.html\n// by Juho Vähä-Herttua\nGHASH.prototype.ghash = function (block) {\n var i = -1\n while (++i < block.length) {\n this.state[i] ^= block[i]\n }\n this._multiply()\n}\n\nGHASH.prototype._multiply = function () {\n var Vi = toArray(this.h)\n var Zi = [0, 0, 0, 0]\n var j, xi, lsbVi\n var i = -1\n while (++i < 128) {\n xi = (this.state[~~(i / 8)] & (1 << (7 - (i % 8)))) !== 0\n if (xi) {\n // Z_i+1 = Z_i ^ V_i\n Zi[0] ^= Vi[0]\n Zi[1] ^= Vi[1]\n Zi[2] ^= Vi[2]\n Zi[3] ^= Vi[3]\n }\n\n // Store the value of LSB(V_i)\n lsbVi = (Vi[3] & 1) !== 0\n\n // V_i+1 = V_i >> 1\n for (j = 3; j > 0; j--) {\n Vi[j] = (Vi[j] >>> 1) | ((Vi[j - 1] & 1) << 31)\n }\n Vi[0] = Vi[0] >>> 1\n\n // If LSB(V_i) is 1, V_i+1 = (V_i >> 1) ^ R\n if (lsbVi) {\n Vi[0] = Vi[0] ^ (0xe1 << 24)\n }\n }\n this.state = fromArray(Zi)\n}\n\nGHASH.prototype.update = function (buf) {\n this.cache = Buffer.concat([this.cache, buf])\n var chunk\n while (this.cache.length >= 16) {\n chunk = this.cache.slice(0, 16)\n this.cache = this.cache.slice(16)\n this.ghash(chunk)\n }\n}\n\nGHASH.prototype.final = function (abl, bl) {\n if (this.cache.length) {\n this.ghash(Buffer.concat([this.cache, ZEROES], 16))\n }\n\n this.ghash(fromArray([0, abl, 0, bl]))\n return this.state\n}\n\nmodule.exports = GHASH\n","var AuthCipher = require('./authCipher')\nvar Buffer = require('safe-buffer').Buffer\nvar MODES = require('./modes')\nvar StreamCipher = require('./streamCipher')\nvar Transform = require('cipher-base')\nvar aes = require('./aes')\nvar ebtk = require('evp_bytestokey')\nvar inherits = require('inherits')\n\nfunction Decipher (mode, key, iv) {\n Transform.call(this)\n\n this._cache = new Splitter()\n this._last = void 0\n this._cipher = new aes.AES(key)\n this._prev = Buffer.from(iv)\n this._mode = mode\n this._autopadding = true\n}\n\ninherits(Decipher, Transform)\n\nDecipher.prototype._update = function (data) {\n this._cache.add(data)\n var chunk\n var thing\n var out = []\n while ((chunk = this._cache.get(this._autopadding))) {\n thing = this._mode.decrypt(this, chunk)\n out.push(thing)\n }\n return Buffer.concat(out)\n}\n\nDecipher.prototype._final = function () {\n var chunk = this._cache.flush()\n if (this._autopadding) {\n return unpad(this._mode.decrypt(this, chunk))\n } else if (chunk) {\n throw new Error('data not multiple of block length')\n }\n}\n\nDecipher.prototype.setAutoPadding = function (setTo) {\n this._autopadding = !!setTo\n return this\n}\n\nfunction Splitter () {\n this.cache = Buffer.allocUnsafe(0)\n}\n\nSplitter.prototype.add = function (data) {\n this.cache = Buffer.concat([this.cache, data])\n}\n\nSplitter.prototype.get = function (autoPadding) {\n var out\n if (autoPadding) {\n if (this.cache.length > 16) {\n out = this.cache.slice(0, 16)\n this.cache = this.cache.slice(16)\n return out\n }\n } else {\n if (this.cache.length >= 16) {\n out = this.cache.slice(0, 16)\n this.cache = this.cache.slice(16)\n return out\n }\n }\n\n return null\n}\n\nSplitter.prototype.flush = function () {\n if (this.cache.length) return this.cache\n}\n\nfunction unpad (last) {\n var padded = last[15]\n if (padded < 1 || padded > 16) {\n throw new Error('unable to decrypt data')\n }\n var i = -1\n while (++i < padded) {\n if (last[(i + (16 - padded))] !== padded) {\n throw new Error('unable to decrypt data')\n }\n }\n if (padded === 16) return\n\n return last.slice(0, 16 - padded)\n}\n\nfunction createDecipheriv (suite, password, iv) {\n var config = MODES[suite.toLowerCase()]\n if (!config) throw new TypeError('invalid suite type')\n\n if (typeof iv === 'string') iv = Buffer.from(iv)\n if (config.mode !== 'GCM' && iv.length !== config.iv) throw new TypeError('invalid iv length ' + iv.length)\n\n if (typeof password === 'string') password = Buffer.from(password)\n if (password.length !== config.key / 8) throw new TypeError('invalid key length ' + password.length)\n\n if (config.type === 'stream') {\n return new StreamCipher(config.module, password, iv, true)\n } else if (config.type === 'auth') {\n return new AuthCipher(config.module, password, iv, true)\n }\n\n return new Decipher(config.module, password, iv)\n}\n\nfunction createDecipher (suite, password) {\n var config = MODES[suite.toLowerCase()]\n if (!config) throw new TypeError('invalid suite type')\n\n var keys = ebtk(password, false, config.key, config.iv)\n return createDecipheriv(suite, keys.key, keys.iv)\n}\n\nexports.createDecipher = createDecipher\nexports.createDecipheriv = createDecipheriv\n","var xor = require('buffer-xor')\n\nfunction getBlock (self) {\n self._prev = self._cipher.encryptBlock(self._prev)\n return self._prev\n}\n\nexports.encrypt = function (self, chunk) {\n while (self._cache.length < chunk.length) {\n self._cache = Buffer.concat([self._cache, getBlock(self)])\n }\n\n var pad = self._cache.slice(0, chunk.length)\n self._cache = self._cache.slice(chunk.length)\n return xor(chunk, pad)\n}\n","var Buffer = require('safe-buffer').Buffer\n\nfunction encryptByte (self, byteParam, decrypt) {\n var pad\n var i = -1\n var len = 8\n var out = 0\n var bit, value\n while (++i < len) {\n pad = self._cipher.encryptBlock(self._prev)\n bit = (byteParam & (1 << (7 - i))) ? 0x80 : 0\n value = pad[0] ^ bit\n out += ((value & 0x80) >> (i % 8))\n self._prev = shiftIn(self._prev, decrypt ? bit : value)\n }\n return out\n}\n\nfunction shiftIn (buffer, value) {\n var len = buffer.length\n var i = -1\n var out = Buffer.allocUnsafe(buffer.length)\n buffer = Buffer.concat([buffer, Buffer.from([value])])\n\n while (++i < len) {\n out[i] = buffer[i] << 1 | buffer[i + 1] >> (7)\n }\n\n return out\n}\n\nexports.encrypt = function (self, chunk, decrypt) {\n var len = chunk.length\n var out = Buffer.allocUnsafe(len)\n var i = -1\n\n while (++i < len) {\n out[i] = encryptByte(self, chunk[i], decrypt)\n }\n\n return out\n}\n","var Buffer = require('safe-buffer').Buffer\n\nfunction encryptByte (self, byteParam, decrypt) {\n var pad = self._cipher.encryptBlock(self._prev)\n var out = pad[0] ^ byteParam\n\n self._prev = Buffer.concat([\n self._prev.slice(1),\n Buffer.from([decrypt ? byteParam : out])\n ])\n\n return out\n}\n\nexports.encrypt = function (self, chunk, decrypt) {\n var len = chunk.length\n var out = Buffer.allocUnsafe(len)\n var i = -1\n\n while (++i < len) {\n out[i] = encryptByte(self, chunk[i], decrypt)\n }\n\n return out\n}\n","var xor = require('buffer-xor')\nvar Buffer = require('safe-buffer').Buffer\nvar incr32 = require('../incr32')\n\nfunction getBlock (self) {\n var out = self._cipher.encryptBlockRaw(self._prev)\n incr32(self._prev)\n return out\n}\n\nvar blockSize = 16\nexports.encrypt = function (self, chunk) {\n var chunkNum = Math.ceil(chunk.length / blockSize)\n var start = self._cache.length\n self._cache = Buffer.concat([\n self._cache,\n Buffer.allocUnsafe(chunkNum * blockSize)\n ])\n for (var i = 0; i < chunkNum; i++) {\n var out = getBlock(self)\n var offset = start + i * blockSize\n self._cache.writeUInt32BE(out[0], offset + 0)\n self._cache.writeUInt32BE(out[1], offset + 4)\n self._cache.writeUInt32BE(out[2], offset + 8)\n self._cache.writeUInt32BE(out[3], offset + 12)\n }\n var pad = self._cache.slice(0, chunk.length)\n self._cache = self._cache.slice(chunk.length)\n return xor(chunk, pad)\n}\n","var aes = require('./aes')\nvar Buffer = require('safe-buffer').Buffer\nvar Transform = require('cipher-base')\nvar inherits = require('inherits')\nvar GHASH = require('./ghash')\nvar xor = require('buffer-xor')\nvar incr32 = require('./incr32')\n\nfunction xorTest (a, b) {\n var out = 0\n if (a.length !== b.length) out++\n\n var len = Math.min(a.length, b.length)\n for (var i = 0; i < len; ++i) {\n out += (a[i] ^ b[i])\n }\n\n return out\n}\n\nfunction calcIv (self, iv, ck) {\n if (iv.length === 12) {\n self._finID = Buffer.concat([iv, Buffer.from([0, 0, 0, 1])])\n return Buffer.concat([iv, Buffer.from([0, 0, 0, 2])])\n }\n var ghash = new GHASH(ck)\n var len = iv.length\n var toPad = len % 16\n ghash.update(iv)\n if (toPad) {\n toPad = 16 - toPad\n ghash.update(Buffer.alloc(toPad, 0))\n }\n ghash.update(Buffer.alloc(8, 0))\n var ivBits = len * 8\n var tail = Buffer.alloc(8)\n tail.writeUIntBE(ivBits, 0, 8)\n ghash.update(tail)\n self._finID = ghash.state\n var out = Buffer.from(self._finID)\n incr32(out)\n return out\n}\nfunction StreamCipher (mode, key, iv, decrypt) {\n Transform.call(this)\n\n var h = Buffer.alloc(4, 0)\n\n this._cipher = new aes.AES(key)\n var ck = this._cipher.encryptBlock(h)\n this._ghash = new GHASH(ck)\n iv = calcIv(this, iv, ck)\n\n this._prev = Buffer.from(iv)\n this._cache = Buffer.allocUnsafe(0)\n this._secCache = Buffer.allocUnsafe(0)\n this._decrypt = decrypt\n this._alen = 0\n this._len = 0\n this._mode = mode\n\n this._authTag = null\n this._called = false\n}\n\ninherits(StreamCipher, Transform)\n\nStreamCipher.prototype._update = function (chunk) {\n if (!this._called && this._alen) {\n var rump = 16 - (this._alen % 16)\n if (rump < 16) {\n rump = Buffer.alloc(rump, 0)\n this._ghash.update(rump)\n }\n }\n\n this._called = true\n var out = this._mode.encrypt(this, chunk)\n if (this._decrypt) {\n this._ghash.update(chunk)\n } else {\n this._ghash.update(out)\n }\n this._len += chunk.length\n return out\n}\n\nStreamCipher.prototype._final = function () {\n if (this._decrypt && !this._authTag) throw new Error('Unsupported state or unable to authenticate data')\n\n var tag = xor(this._ghash.final(this._alen * 8, this._len * 8), this._cipher.encryptBlock(this._finID))\n if (this._decrypt && xorTest(tag, this._authTag)) throw new Error('Unsupported state or unable to authenticate data')\n\n this._authTag = tag\n this._cipher.scrub()\n}\n\nStreamCipher.prototype.getAuthTag = function getAuthTag () {\n if (this._decrypt || !Buffer.isBuffer(this._authTag)) throw new Error('Attempting to get auth tag in unsupported state')\n\n return this._authTag\n}\n\nStreamCipher.prototype.setAuthTag = function setAuthTag (tag) {\n if (!this._decrypt) throw new Error('Attempting to set auth tag in unsupported state')\n\n this._authTag = tag\n}\n\nStreamCipher.prototype.setAAD = function setAAD (buf) {\n if (this._called) throw new Error('Attempting to set AAD in unsupported state')\n\n this._ghash.update(buf)\n this._alen += buf.length\n}\n\nmodule.exports = StreamCipher\n","var MODES = require('./modes')\nvar AuthCipher = require('./authCipher')\nvar Buffer = require('safe-buffer').Buffer\nvar StreamCipher = require('./streamCipher')\nvar Transform = require('cipher-base')\nvar aes = require('./aes')\nvar ebtk = require('evp_bytestokey')\nvar inherits = require('inherits')\n\nfunction Cipher (mode, key, iv) {\n Transform.call(this)\n\n this._cache = new Splitter()\n this._cipher = new aes.AES(key)\n this._prev = Buffer.from(iv)\n this._mode = mode\n this._autopadding = true\n}\n\ninherits(Cipher, Transform)\n\nCipher.prototype._update = function (data) {\n this._cache.add(data)\n var chunk\n var thing\n var out = []\n\n while ((chunk = this._cache.get())) {\n thing = this._mode.encrypt(this, chunk)\n out.push(thing)\n }\n\n return Buffer.concat(out)\n}\n\nvar PADDING = Buffer.alloc(16, 0x10)\n\nCipher.prototype._final = function () {\n var chunk = this._cache.flush()\n if (this._autopadding) {\n chunk = this._mode.encrypt(this, chunk)\n this._cipher.scrub()\n return chunk\n }\n\n if (!chunk.equals(PADDING)) {\n this._cipher.scrub()\n throw new Error('data not multiple of block length')\n }\n}\n\nCipher.prototype.setAutoPadding = function (setTo) {\n this._autopadding = !!setTo\n return this\n}\n\nfunction Splitter () {\n this.cache = Buffer.allocUnsafe(0)\n}\n\nSplitter.prototype.add = function (data) {\n this.cache = Buffer.concat([this.cache, data])\n}\n\nSplitter.prototype.get = function () {\n if (this.cache.length > 15) {\n var out = this.cache.slice(0, 16)\n this.cache = this.cache.slice(16)\n return out\n }\n return null\n}\n\nSplitter.prototype.flush = function () {\n var len = 16 - this.cache.length\n var padBuff = Buffer.allocUnsafe(len)\n\n var i = -1\n while (++i < len) {\n padBuff.writeUInt8(len, i)\n }\n\n return Buffer.concat([this.cache, padBuff])\n}\n\nfunction createCipheriv (suite, password, iv) {\n var config = MODES[suite.toLowerCase()]\n if (!config) throw new TypeError('invalid suite type')\n\n if (typeof password === 'string') password = Buffer.from(password)\n if (password.length !== config.key / 8) throw new TypeError('invalid key length ' + password.length)\n\n if (typeof iv === 'string') iv = Buffer.from(iv)\n if (config.mode !== 'GCM' && iv.length !== config.iv) throw new TypeError('invalid iv length ' + iv.length)\n\n if (config.type === 'stream') {\n return new StreamCipher(config.module, password, iv)\n } else if (config.type === 'auth') {\n return new AuthCipher(config.module, password, iv)\n }\n\n return new Cipher(config.module, password, iv)\n}\n\nfunction createCipher (suite, password) {\n var config = MODES[suite.toLowerCase()]\n if (!config) throw new TypeError('invalid suite type')\n\n var keys = ebtk(password, false, config.key, config.iv)\n return createCipheriv(suite, keys.key, keys.iv)\n}\n\nexports.createCipheriv = createCipheriv\nexports.createCipher = createCipher\n","var DES = require('browserify-des')\nvar aes = require('browserify-aes/browser')\nvar aesModes = require('browserify-aes/modes')\nvar desModes = require('browserify-des/modes')\nvar ebtk = require('evp_bytestokey')\n\nfunction createCipher (suite, password) {\n suite = suite.toLowerCase()\n\n var keyLen, ivLen\n if (aesModes[suite]) {\n keyLen = aesModes[suite].key\n ivLen = aesModes[suite].iv\n } else if (desModes[suite]) {\n keyLen = desModes[suite].key * 8\n ivLen = desModes[suite].iv\n } else {\n throw new TypeError('invalid suite type')\n }\n\n var keys = ebtk(password, false, keyLen, ivLen)\n return createCipheriv(suite, keys.key, keys.iv)\n}\n\nfunction createDecipher (suite, password) {\n suite = suite.toLowerCase()\n\n var keyLen, ivLen\n if (aesModes[suite]) {\n keyLen = aesModes[suite].key\n ivLen = aesModes[suite].iv\n } else if (desModes[suite]) {\n keyLen = desModes[suite].key * 8\n ivLen = desModes[suite].iv\n } else {\n throw new TypeError('invalid suite type')\n }\n\n var keys = ebtk(password, false, keyLen, ivLen)\n return createDecipheriv(suite, keys.key, keys.iv)\n}\n\nfunction createCipheriv (suite, key, iv) {\n suite = suite.toLowerCase()\n if (aesModes[suite]) return aes.createCipheriv(suite, key, iv)\n if (desModes[suite]) return new DES({ key: key, iv: iv, mode: suite })\n\n throw new TypeError('invalid suite type')\n}\n\nfunction createDecipheriv (suite, key, iv) {\n suite = suite.toLowerCase()\n if (aesModes[suite]) return aes.createDecipheriv(suite, key, iv)\n if (desModes[suite]) return new DES({ key: key, iv: iv, mode: suite, decrypt: true })\n\n throw new TypeError('invalid suite type')\n}\n\nfunction getCiphers () {\n return Object.keys(desModes).concat(aes.getCiphers())\n}\n\nexports.createCipher = exports.Cipher = createCipher\nexports.createCipheriv = exports.Cipheriv = createCipheriv\nexports.createDecipher = exports.Decipher = createDecipher\nexports.createDecipheriv = exports.Decipheriv = createDecipheriv\nexports.listCiphers = exports.getCiphers = getCiphers\n","(function (module, exports) {\n 'use strict';\n\n // Utils\n function assert (val, msg) {\n if (!val) throw new Error(msg || 'Assertion failed');\n }\n\n // Could use `inherits` module, but don't want to move from single file\n // architecture yet.\n function inherits (ctor, superCtor) {\n ctor.super_ = superCtor;\n var TempCtor = function () {};\n TempCtor.prototype = superCtor.prototype;\n ctor.prototype = new TempCtor();\n ctor.prototype.constructor = ctor;\n }\n\n // BN\n\n function BN (number, base, endian) {\n if (BN.isBN(number)) {\n return number;\n }\n\n this.negative = 0;\n this.words = null;\n this.length = 0;\n\n // Reduction context\n this.red = null;\n\n if (number !== null) {\n if (base === 'le' || base === 'be') {\n endian = base;\n base = 10;\n }\n\n this._init(number || 0, base || 10, endian || 'be');\n }\n }\n if (typeof module === 'object') {\n module.exports = BN;\n } else {\n exports.BN = BN;\n }\n\n BN.BN = BN;\n BN.wordSize = 26;\n\n var Buffer;\n try {\n Buffer = require('buffer').Buffer;\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 }\n\n if (base === 16) {\n this._parseHex(number, start);\n } else {\n this._parseBase(number, base, start);\n }\n\n if (number[0] === '-') {\n this.negative = 1;\n }\n\n this.strip();\n\n if (endian !== 'le') return;\n\n this._initArray(this.toArray(), base, endian);\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 parseHex (str, start, end) {\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 <<= 4;\n\n // 'a' - 'f'\n if (c >= 49 && c <= 54) {\n r |= c - 49 + 0xa;\n\n // 'A' - 'F'\n } else if (c >= 17 && c <= 22) {\n r |= c - 17 + 0xa;\n\n // '0' - '9'\n } else {\n r |= c & 0xf;\n }\n }\n return r;\n }\n\n BN.prototype._parseHex = function _parseHex (number, start) {\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 var j, w;\n // Scan 24-bit chunks and add them to the number\n var off = 0;\n for (i = number.length - 6, j = 0; i >= start; i -= 6) {\n w = parseHex(number, i, i + 6);\n this.words[j] |= (w << off) & 0x3ffffff;\n // NOTE: `0x3fffff` is intentional here, 26bits max shift + 24bit hex limb\n this.words[j + 1] |= w >>> (26 - off) & 0x3fffff;\n off += 24;\n if (off >= 26) {\n off -= 26;\n j++;\n }\n }\n if (i + 6 !== start) {\n w = parseHex(number, start, i + 6);\n this.words[j] |= (w << off) & 0x3ffffff;\n this.words[j + 1] |= w >>> (26 - off) & 0x3fffff;\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\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 bn = require('bn.js');\nvar randomBytes = require('randombytes');\nmodule.exports = crt;\nfunction blind(priv) {\n var r = getr(priv);\n var blinder = r.toRed(bn.mont(priv.modulus))\n .redPow(new bn(priv.publicExponent)).fromRed();\n return {\n blinder: blinder,\n unblinder:r.invm(priv.modulus)\n };\n}\nfunction crt(msg, priv) {\n var blinds = blind(priv);\n var len = priv.modulus.byteLength();\n var mod = bn.mont(priv.modulus);\n var blinded = new bn(msg).mul(blinds.blinder).umod(priv.modulus);\n var c1 = blinded.toRed(bn.mont(priv.prime1));\n var c2 = blinded.toRed(bn.mont(priv.prime2));\n var qinv = priv.coefficient;\n var p = priv.prime1;\n var q = priv.prime2;\n var m1 = c1.redPow(priv.exponent1);\n var m2 = c2.redPow(priv.exponent2);\n m1 = m1.fromRed();\n m2 = m2.fromRed();\n var h = m1.isub(m2).imul(qinv).umod(p);\n h.imul(q);\n m2.iadd(h);\n return new Buffer(m2.imul(blinds.unblinder).umod(priv.modulus).toArray(false, len));\n}\ncrt.getr = getr;\nfunction getr(priv) {\n var len = priv.modulus.byteLength();\n var r = new bn(randomBytes(len));\n while (r.cmp(priv.modulus) >= 0 || !r.umod(priv.prime1) || !r.umod(priv.prime2)) {\n r = new bn(randomBytes(len));\n }\n return r;\n}\n","var modeModules = {\n ECB: require('./ecb'),\n CBC: require('./cbc'),\n CFB: require('./cfb'),\n CFB8: require('./cfb8'),\n CFB1: require('./cfb1'),\n OFB: require('./ofb'),\n CTR: require('./ctr'),\n GCM: require('./ctr')\n}\n\nvar modes = require('./list.json')\n\nfor (var key in modes) {\n modes[key].module = modeModules[modes[key].mode]\n}\n\nmodule.exports = modes\n","function incr32 (iv) {\n var len = iv.length\n var item\n while (len--) {\n item = iv.readUInt8(len)\n if (item === 255) {\n iv.writeUInt8(0, len)\n } else {\n item++\n iv.writeUInt8(item, len)\n break\n }\n }\n}\nmodule.exports = incr32\n","var xor = require('buffer-xor')\n\nexports.encrypt = function (self, block) {\n var data = xor(block, self._prev)\n\n self._prev = self._cipher.encryptBlock(data)\n return self._prev\n}\n\nexports.decrypt = function (self, block) {\n var pad = self._prev\n\n self._prev = block\n var out = self._cipher.decryptBlock(block)\n\n return xor(out, pad)\n}\n","var ciphers = require('./encrypter')\nvar deciphers = require('./decrypter')\nvar modes = require('./modes/list.json')\n\nfunction getCiphers () {\n return Object.keys(modes)\n}\n\nexports.createCipher = exports.Cipher = ciphers.createCipher\nexports.createCipheriv = exports.Cipheriv = ciphers.createCipheriv\nexports.createDecipher = exports.Decipher = deciphers.createDecipher\nexports.createDecipheriv = exports.Decipheriv = deciphers.createDecipheriv\nexports.listCiphers = exports.getCiphers = getCiphers\n","var r;\n\nmodule.exports = function rand(len) {\n if (!r)\n r = new Rand(null);\n\n return r.generate(len);\n};\n\nfunction Rand(rand) {\n this.rand = rand;\n}\nmodule.exports.Rand = Rand;\n\nRand.prototype.generate = function generate(len) {\n return this._rand(len);\n};\n\n// Emulate crypto API using randy\nRand.prototype._rand = function _rand(n) {\n if (this.rand.getBytes)\n return this.rand.getBytes(n);\n\n var res = new Uint8Array(n);\n for (var i = 0; i < res.length; i++)\n res[i] = this.rand.getByte();\n return res;\n};\n\nif (typeof self === 'object') {\n if (self.crypto && self.crypto.getRandomValues) {\n // Modern browsers\n Rand.prototype._rand = function _rand(n) {\n var arr = new Uint8Array(n);\n self.crypto.getRandomValues(arr);\n return arr;\n };\n } else if (self.msCrypto && self.msCrypto.getRandomValues) {\n // IE\n Rand.prototype._rand = function _rand(n) {\n var arr = new Uint8Array(n);\n self.msCrypto.getRandomValues(arr);\n return arr;\n };\n\n // Safari's WebWorkers do not have `crypto`\n } else if (typeof window === 'object') {\n // Old junk\n Rand.prototype._rand = function() {\n throw new Error('Not implemented yet');\n };\n }\n} else {\n // Node.js or Web worker with no crypto support\n try {\n var crypto = require('crypto');\n if (typeof crypto.randomBytes !== 'function')\n throw new Error('Not supported');\n\n Rand.prototype._rand = function _rand(n) {\n return crypto.randomBytes(n);\n };\n } catch (e) {\n }\n}\n"],"sourceRoot":""}