flocore/bitcore.min.js
2015-07-22 10:39:24 -04:00

19 lines
456 KiB
JavaScript
Raw Blame History

This file contains invisible Unicode characters

This file contains invisible Unicode characters that are indistinguishable to humans but may be processed differently by a computer. If you think that this is intentional, you can safely ignore this warning. Use the Escape button to reveal them.

This file contains Unicode characters that might be confused with other characters. If you think that this is intentional, you can safely ignore this warning. Use the Escape button to reveal them.

require=function e(t,r,n){function i(o,a){if(!r[o]){if(!t[o]){var f="function"==typeof require&&require;if(!a&&f)return f(o,!0);if(s)return s(o,!0);var c=new Error("Cannot find module '"+o+"'");throw c.code="MODULE_NOT_FOUND",c}var u=r[o]={exports:{}};t[o][0].call(u.exports,function(e){var r=t[o][1][e];return i(r?r:e)},u,u.exports,e,t,r,n)}return r[o].exports}for(var s="function"==typeof require&&require,o=0;o<n.length;o++)i(n[o]);return i}({1:[function(e,t,r){(function(r){"use strict";function n(e,t,r){if(!(this instanceof n))return new n(e,t,r);if(i.isArray(e)&&i.isNumber(t))return n.createMultisig(e,t,r);if(e instanceof n)return e;if(s.checkArgument(e,"First argument is required, please include address data.","guide/address.html"),t&&!f.get(t))throw new TypeError('Second argument must be "livenet" or "testnet".');if(r&&r!==n.PayToPublicKeyHash&&r!==n.PayToScriptHash)throw new TypeError('Third argument must be "pubkeyhash" or "scripthash".');var o=this._classifyArguments(e,t,r);return o.network=o.network||f.get(t)||f.defaultNetwork,o.type=o.type||r||n.PayToPublicKeyHash,u.defineImmutable(this,{hashBuffer:o.hashBuffer,network:o.network,type:o.type}),this}var i=e("lodash"),s=e("./util/preconditions"),o=e("./errors"),a=e("./encoding/base58check"),f=e("./networks"),c=e("./crypto/hash"),u=e("./util/js"),h=e("./publickey");n.prototype._classifyArguments=function(e,t,s){if((e instanceof r||e instanceof Uint8Array)&&20===e.length)return n._transformHash(e);if((e instanceof r||e instanceof Uint8Array)&&21===e.length)return n._transformBuffer(e,t,s);if(e instanceof h)return n._transformPublicKey(e);if(e instanceof d)return n._transformScript(e,t);if("string"==typeof e)return n._transformString(e,t,s);if(i.isObject(e))return n._transformObject(e);throw new TypeError("First argument is an unrecognized data format.")},n.PayToPublicKeyHash="pubkeyhash",n.PayToScriptHash="scripthash",n._transformHash=function(e){var t={};if(!(e instanceof r||e instanceof Uint8Array))throw new TypeError("Address supplied is not a buffer.");if(20!==e.length)throw new TypeError("Address hashbuffers must be exactly 20 bytes.");return t.hashBuffer=e,t},n._transformObject=function(e){return s.checkArgument(e.hash||e.hashBuffer,"Must provide a `hash` or `hashBuffer` property"),s.checkArgument(e.type,"Must provide a `type` property"),{hashBuffer:e.hash?new r(e.hash,"hex"):e.hashBuffer,network:f.get(e.network)||f.defaultNetwork,type:e.type}},n._classifyFromVersion=function(e){var t={},r=f.get(e[0],"pubkeyhash"),i=f.get(e[0],"scripthash");return r?(t.network=r,t.type=n.PayToPublicKeyHash):i&&(t.network=i,t.type=n.PayToScriptHash),t},n._transformBuffer=function(e,t,i){var s={};if(!(e instanceof r||e instanceof Uint8Array))throw new TypeError("Address supplied is not a buffer.");if(21!==e.length)throw new TypeError("Address buffers must be exactly 21 bytes.");t=f.get(t);var o=n._classifyFromVersion(e);if(!o.network||t&&t!==o.network)throw new TypeError("Address has mismatched network type.");if(!o.type||i&&i!==o.type)throw new TypeError("Address has mismatched type.");return s.hashBuffer=e.slice(1),s.network=o.network,s.type=o.type,s},n._transformPublicKey=function(e){var t={};if(!(e instanceof h))throw new TypeError("Address must be an instance of PublicKey.");return t.hashBuffer=c.sha256ripemd160(e.toBuffer()),t.type=n.PayToPublicKeyHash,t},n._transformScript=function(e,t){s.checkArgument(e instanceof d,"script must be a Script instance");var r=e.getAddressInfo(t);if(!r)throw new o.Script.CantDeriveAddress(e);return r},n.createMultisig=function(e,t,r){return r=r||e[0].network||f.defaultNetwork,n.payingTo(d.buildMultisigOut(e,t),r)},n._transformString=function(e,t,r){if("string"!=typeof e)throw new TypeError("data parameter supplied is not a string.");e=e.trim();var i=a.decode(e),s=n._transformBuffer(i,t,r);return s},n.fromPublicKey=function(e,t){var r=n._transformPublicKey(e);return t=t||f.defaultNetwork,new n(r.hashBuffer,t,r.type)},n.fromPublicKeyHash=function(e,t){var r=n._transformHash(e);return new n(r.hashBuffer,t,n.PayToPublicKeyHash)},n.fromScriptHash=function(e,t){s.checkArgument(e,"hash parameter is required");var r=n._transformHash(e);return new n(r.hashBuffer,t,n.PayToScriptHash)},n.payingTo=function(e,t){return s.checkArgument(e,"script is required"),s.checkArgument(e instanceof d,"script must be instance of Script"),n.fromScriptHash(c.sha256ripemd160(e.toBuffer()),t)},n.fromScript=function(e,t){s.checkArgument(e instanceof d,"script must be a Script instance");var r=n._transformScript(e,t);return new n(r.hashBuffer,t,r.type)},n.fromBuffer=function(e,t,r){var i=n._transformBuffer(e,t,r);return new n(i.hashBuffer,i.network,i.type)},n.fromString=function(e,t,r){var i=n._transformString(e,t,r);return new n(i.hashBuffer,i.network,i.type)},n.fromJSON=function(e){u.isValidJSON(e)&&(e=JSON.parse(e)),s.checkState(u.isHexa(e.hash),'Unexpected hash property, "'+e.hash+'", expected to be hex.');var t=new r(e.hash,"hex");return new n(t,e.network,e.type)},n.getValidationError=function(e,t,r){var i;try{new n(e,t,r)}catch(s){i=s}return i},n.isValid=function(e,t,r){return!n.getValidationError(e,t,r)},n.prototype.isPayToPublicKeyHash=function(){return this.type===n.PayToPublicKeyHash},n.prototype.isPayToScriptHash=function(){return this.type===n.PayToScriptHash},n.prototype.toBuffer=function(){var e=new r([this.network[this.type]]),t=r.concat([e,this.hashBuffer]);return t},n.prototype.toObject=function(){return{hash:this.hashBuffer.toString("hex"),type:this.type,network:this.network.toString()}},n.prototype.toJSON=function(){return JSON.stringify(this.toObject())},n.prototype.toString=function(){return a.encode(this.toBuffer())},n.prototype.inspect=function(){return"<Address: "+this.toString()+", type: "+this.type+", network: "+this.network+">"},t.exports=n;var d=e("./script")}).call(this,e("buffer").Buffer)},{"./crypto/hash":8,"./encoding/base58check":13,"./errors":17,"./networks":22,"./publickey":25,"./script":26,"./util/js":42,"./util/preconditions":43,buffer:46,lodash:194}],2:[function(e,t,r){(function(r){"use strict";function n(e){return this instanceof n?(i.extend(this,n._from(e)),this):new n(e)}var i=e("lodash"),s=e("./blockheader"),o=e("../crypto/bn"),a=e("../util/buffer"),f=e("../encoding/bufferreader"),c=e("../encoding/bufferwriter"),u=e("../crypto/hash"),h=e("../util/js"),d=e("../transaction"),p=e("../util/preconditions");n.MAX_BLOCK_SIZE=1e6,n._from=function(e){var t={};if(a.isBuffer(e))t=n._fromBufferReader(f(e));else if(h.isValidJSON(e))t=n._fromJSON(e);else{if(!i.isObject(e))throw new TypeError("Unrecognized argument for Block");t=n._fromObject(e)}return t},n._fromJSON=function(e){return p.checkArgument(h.isValidJSON(e),"data must be valid JSON"),e=JSON.parse(e),n._fromObject(e)},n._fromObject=function(e){var t=[];e.transactions.forEach(function(e){t.push(e instanceof d?e:d().fromJSON(e))});var r={header:s.fromObject(e.header),transactions:t};return r},n.fromJSON=function(e){var t=n._fromJSON(e);return new n(t)},n.fromObject=function(e){var t=n._fromObject(e);return new n(t)},n._fromBufferReader=function(e){var t={};p.checkState(!e.finished(),"No block data received"),t.header=s.fromBufferReader(e);var r=e.readVarintNum();t.transactions=[];for(var n=0;r>n;n++)t.transactions.push(d().fromBufferReader(e));return t},n.fromBufferReader=function(e){p.checkArgument(e,"br is required");var t=n._fromBufferReader(e);return new n(t)},n.fromBuffer=function(e){return n.fromBufferReader(new f(e))},n.fromString=function(e){var t=new r(e,"hex");return n.fromBuffer(t)},n.fromRawBlock=function(e){a.isBuffer(e)||(e=new r(e,"binary"));var t=f(e);t.pos=n.Values.START_OF_BLOCK;var i=n._fromBufferReader(t);return new n(i)},n.prototype.toObject=function(){var e=[];return this.transactions.forEach(function(t){e.push(t.toObject())}),{header:this.header.toObject(),transactions:e}},n.prototype.toJSON=function(){return JSON.stringify(this.toObject())},n.prototype.toBuffer=function(){return this.toBufferWriter().concat()},n.prototype.toString=function(){return this.toBuffer().toString("hex")},n.prototype.toBufferWriter=function(e){e||(e=new c),e.write(this.header.toBuffer()),e.writeVarintNum(this.transactions.length);for(var t=0;t<this.transactions.length;t++)this.transactions[t].toBufferWriter(e);return e},n.prototype.getTransactionHashes=function(){var e=[];if(0===this.transactions.length)return[n.Values.NULL_HASH];for(var t=0;t<this.transactions.length;t++)e.push(this.transactions[t]._getHash());return e},n.prototype.getMerkleTree=function(){for(var e=this.getTransactionHashes(),t=0,n=this.transactions.length;n>1;n=Math.floor((n+1)/2)){for(var i=0;n>i;i+=2){var s=Math.min(i+1,n-1),o=r.concat([e[t+i],e[t+s]]);e.push(u.sha256sha256(o))}t+=n}return e},n.prototype.getMerkleRoot=function(){var e=this.getMerkleTree();return e[e.length-1]},n.prototype.validMerkleRoot=function(){var e=new o(this.header.merkleRoot.toString("hex"),"hex"),t=new o(this.getMerkleRoot().toString("hex"),"hex");return 0!==e.cmp(t)?!1:!0},n.prototype._getHash=function(){return this.header._getHash()};var l={configurable:!1,enumerable:!0,get:function(){return this._id||(this._id=this.header.id),this._id},set:i.noop};Object.defineProperty(n.prototype,"id",l),Object.defineProperty(n.prototype,"hash",l),n.prototype.inspect=function(){return"<Block "+this.id+">"},n.Values={START_OF_BLOCK:8,NULL_HASH:new r("0000000000000000000000000000000000000000000000000000000000000000","hex")},t.exports=n}).call(this,e("buffer").Buffer)},{"../crypto/bn":6,"../crypto/hash":8,"../encoding/bufferreader":14,"../encoding/bufferwriter":15,"../transaction":29,"../util/buffer":41,"../util/js":42,"../util/preconditions":43,"./blockheader":3,buffer:46,lodash:194}],3:[function(e,t,r){(function(r){"use strict";var n=e("lodash"),i=e("../crypto/bn"),s=e("../util/buffer"),o=e("../encoding/bufferreader"),a=e("../encoding/bufferwriter"),f=e("../crypto/hash"),c=e("../util/js"),u=e("../util/preconditions"),h=function p(e){return this instanceof p?(n.extend(this,p._from(e)),this):new p(e)};h._from=function(e){var t={};if(s.isBuffer(e))t=h._fromBufferReader(o(e));else if(c.isValidJSON(e))t=h._fromJSON(e);else{if(!n.isObject(e))throw new TypeError("Unrecognized argument for BlockHeader");t=h._fromObject(e)}return t},h._fromJSON=function(e){return u.checkArgument(c.isValidJSON(e),"data must be a valid JSON string"),e=JSON.parse(e),h._fromObject(e)},h._fromObject=function(e){u.checkArgument(e,"data is required");var t=e.prevHash,i=e.merkleRoot;n.isString(e.prevHash)&&(t=s.reverse(new r(e.prevHash,"hex"))),n.isString(e.merkleRoot)&&(i=s.reverse(new r(e.merkleRoot,"hex")));var o={version:e.version,prevHash:t,merkleRoot:i,time:e.time,timestamp:e.time,bits:e.bits,nonce:e.nonce};return o},h.fromJSON=function(e){var t=h._fromJSON(e);return new h(t)},h.fromObject=function(e){var t=h._fromObject(e);return new h(t)},h.fromRawBlock=function(e){s.isBuffer(e)||(e=new r(e,"binary"));var t=o(e);t.pos=h.Constants.START_OF_HEADER;var n=h._fromBufferReader(t);return new h(n)},h.fromBuffer=function(e){var t=h._fromBufferReader(o(e));return new h(t)},h.fromString=function(e){var t=new r(e,"hex");return h.fromBuffer(t)},h._fromBufferReader=function(e){var t={};return t.version=e.readUInt32LE(),t.prevHash=e.read(32),t.merkleRoot=e.read(32),t.time=e.readUInt32LE(),t.bits=e.readUInt32LE(),t.nonce=e.readUInt32LE(),t},h.fromBufferReader=function(e){var t=h._fromBufferReader(e);return new h(t)},h.prototype.toObject=function(){return{version:this.version,prevHash:s.reverse(this.prevHash).toString("hex"),merkleRoot:s.reverse(this.merkleRoot).toString("hex"),time:this.time,bits:this.bits,nonce:this.nonce}},h.prototype.toJSON=function(){return JSON.stringify(this.toObject())},h.prototype.toBuffer=function(){return this.toBufferWriter().concat()},h.prototype.toString=function(){return this.toBuffer().toString("hex")},h.prototype.toBufferWriter=function(e){return e||(e=new a),e.writeUInt32LE(this.version),e.write(this.prevHash),e.write(this.merkleRoot),e.writeUInt32LE(this.time),e.writeUInt32LE(this.bits),e.writeUInt32LE(this.nonce),e},h.prototype.getTargetDifficulty=function(e){for(var t=new i(16777215&this.bits),r=8*((this.bits>>>24)-3);r-->0;)t=t.mul(new i(2));return t},h.prototype._getHash=function(){var e=this.toBuffer();return f.sha256sha256(e)};var d={configurable:!1,enumerable:!0,get:function(){return this._id||(this._id=o(this._getHash()).readReverse().toString("hex")),this._id},set:n.noop};Object.defineProperty(h.prototype,"id",d),Object.defineProperty(h.prototype,"hash",d),h.prototype.validTimestamp=function(){var e=Math.round((new Date).getTime()/1e3);return this.time>e+h.Constants.MAX_TIME_OFFSET?!1:!0},h.prototype.validProofOfWork=function(){var e=new i(this.id,"hex"),t=this.getTargetDifficulty();return e.cmp(t)>0?!1:!0},h.prototype.inspect=function(){return"<BlockHeader "+this.id+">"},h.Constants={START_OF_HEADER:8,MAX_TIME_OFFSET:7200,LARGEST_HASH:new i("10000000000000000000000000000000000000000000000000000000000000000","hex")},t.exports=h}).call(this,e("buffer").Buffer)},{"../crypto/bn":6,"../crypto/hash":8,"../encoding/bufferreader":14,"../encoding/bufferwriter":15,"../util/buffer":41,"../util/js":42,"../util/preconditions":43,buffer:46,lodash:194}],4:[function(e,t,r){t.exports=e("./block"),t.exports.BlockHeader=e("./blockheader"),t.exports.MerkleBlock=e("./merkleblock")},{"./block":2,"./blockheader":3,"./merkleblock":5}],5:[function(e,t,r){(function(r){"use strict";function n(e){if(!(this instanceof n))return new n(e);var t={};if(o.isBuffer(e))t=n._fromBufferReader(a(e));else if(u.isValidJSON(e))t=n._fromJSON(e);else{if(!i.isObject(e))throw new TypeError("Unrecognized argument for MerkleBlock");var r;r=e.header instanceof s?e.header:s.fromJSON(JSON.stringify(e.header)),t={header:r,numTransactions:e.numTransactions,hashes:e.hashes,flags:e.flags}}return i.extend(this,t),this._flagBitsUsed=0,this._hashesUsed=0,this}var i=e("lodash"),s=e("./blockheader"),o=e("../util/buffer"),a=e("../encoding/bufferreader"),f=e("../encoding/bufferwriter"),c=e("../crypto/hash"),u=e("../util/js"),h=e("../transaction"),d=e("../util/preconditions");n.fromBuffer=function(e){return n.fromBufferReader(a(e))},n.fromBufferReader=function(e){return new n(n._fromBufferReader(e))},n.fromJSON=function(e){return new n(n._fromJSON(e))},n.prototype.toBuffer=function(){return this.toBufferWriter().concat()},n.prototype.toBufferWriter=function(e){e||(e=new f),e.write(this.header.toBuffer()),e.writeUInt32LE(this.numTransactions),e.writeVarintNum(this.hashes.length);for(var t=0;t<this.hashes.length;t++)e.write(new r(this.hashes[t],"hex"));for(e.writeVarintNum(this.flags.length),t=0;t<this.flags.length;t++)e.writeUInt8(this.flags[t]);return e},n.prototype.toObject=function(){return{header:this.header.toObject(),numTransactions:this.numTransactions,hashes:this.hashes,flags:this.flags}},n.prototype.toJSON=function(){return JSON.stringify(this.toObject())},n.prototype.validMerkleTree=function(){if(d.checkState(i.isArray(this.flags),"MerkleBlock flags is not an array"),d.checkState(i.isArray(this.hashes),"MerkleBlock hashes is not an array"),this.hashes.length>this.numTransactions)return!1;if(8*this.flags.length<this.hashes.length)return!1;var e=this._calcTreeHeight(),t={hashesUsed:0,flagBitsUsed:0},r=this._traverseMerkleTree(e,0,t);return t.hashesUsed!==this.hashes.length?!1:o.equals(r,this.header.merkleRoot)},n.prototype._traverseMerkleTree=function(e,t,n){if(n=n||{},n.txs=n.txs||[],n.flagBitsUsed=n.flagBitsUsed||0,n.hashesUsed=n.hashesUsed||0,n.flagBitsUsed>8*this.flags.length)return null;var i=this.flags[n.flagBitsUsed>>3]>>>(7&n.flagBitsUsed++)&1;if(0!==e&&i){var s=this._traverseMerkleTree(e-1,2*t,n),o=s;return 2*t+1<this._calcTreeWidth(e-1)&&(o=this._traverseMerkleTree(e-1,2*t+1,n)),c.sha256sha256(new r.concat([s,o]))}if(n.hashesUsed>=this.hashes.length)return null;var a=this.hashes[n.hashesUsed++];return 0===e&&i&&n.txs.push(a),new r(a,"hex")},n.prototype._calcTreeWidth=function(e){return this.numTransactions+(1<<e)-1>>e},n.prototype._calcTreeHeight=function(){for(var e=0;this._calcTreeWidth(e)>1;)e++;return e},n.prototype.hasTransaction=function(e){d.checkArgument(!i.isUndefined(e),"tx cannot be undefined"),d.checkArgument(e instanceof h||"string"==typeof e,'Invalid tx given, tx must be a "string" or "Transaction"');var t=e;e instanceof h&&(t=o.reverse(new r(e.id,"hex")).toString("hex"));var n=[],s=this._calcTreeHeight();return this._traverseMerkleTree(s,0,{txs:n}),-1!==n.indexOf(t)},n._fromBufferReader=function(e){d.checkState(!e.finished(),"No merkleblock data received");var t={};t.header=s.fromBufferReader(e),t.numTransactions=e.readUInt32LE();var r=e.readVarintNum();t.hashes=[];for(var n=0;r>n;n++)t.hashes.push(e.read(32).toString("hex"));var i=e.readVarintNum();for(t.flags=[],n=0;i>n;n++)t.flags.push(e.readUInt8());return t},n._fromJSON=function(e){u.isValidJSON(e)&&(e=JSON.parse(e));var t={header:s.fromObject(e.header),numTransactions:e.numTransactions,hashes:e.hashes,flags:e.flags};return t},t.exports=n}).call(this,e("buffer").Buffer)},{"../crypto/hash":8,"../encoding/bufferreader":14,"../encoding/bufferwriter":15,"../transaction":29,"../util/buffer":41,"../util/js":42,"../util/preconditions":43,"./blockheader":3,buffer:46,lodash:194}],6:[function(e,t,r){(function(r){"use strict";var n=e("bn.js"),i=e("../util/preconditions"),s=e("lodash"),o=function(e){for(var t=new r(e.length),n=0;n<e.length;n++)t[n]=e[e.length-1-n];return t};n.Zero=new n(0),n.One=new n(1),n.Minus1=new n(-1),n.fromNumber=function(e){return i.checkArgument(s.isNumber(e)),new n(e)},n.fromString=function(e,t){return i.checkArgument(s.isString(e)),new n(e,t)},n.fromBuffer=function(e,t){"undefined"!=typeof t&&"little"===t.endian&&(e=o(e));var r=e.toString("hex"),i=new n(r,16);return i},n.fromSM=function(e,t){var i;if(0===e.length)return n.fromBuffer(new r([0]));var s="big";return t&&(s=t.endian),"little"===s&&(e=o(e)),128&e[0]?(e[0]=127&e[0],i=n.fromBuffer(e),i.neg().copy(i)):i=n.fromBuffer(e),i},n.prototype.toNumber=function(){return parseInt(this.toString(10),10)},n.prototype.toBuffer=function(e){var t,i;if(e&&e.size){i=this.toString(16,2);var s=i.length/2;t=new r(i,"hex"),s===e.size?t=t:s>e.size?t=n.trim(t,s):s<e.size&&(t=n.pad(t,s,e.size))}else i=this.toString(16,2),t=new r(i,"hex");return"undefined"!=typeof e&&"little"===e.endian&&(t=o(t)),t},n.prototype.toSMBigEndian=function(){var e;return-1===this.cmp(n.Zero)?(e=this.neg().toBuffer(),128&e[0]?e=r.concat([new r([128]),e]):e[0]=128|e[0]):(e=this.toBuffer(),128&e[0]&&(e=r.concat([new r([0]),e]))),1===e.length&0===e[0]&&(e=new r([])),e},n.prototype.toSM=function(e){var t=e?e.endian:"big",r=this.toSMBigEndian();return"little"===t&&(r=o(r)),r},n.fromScriptNumBuffer=function(e,t,r){var s=r||4;if(i.checkArgument(e.length<=s,new Error("script number overflow")),t&&e.length>0&&0===(127&e[e.length-1])&&(e.length<=1||0===(128&e[e.length-2])))throw new Error("non-minimally encoded script number");return n.fromSM(e,{endian:"little"})},n.prototype.toScriptNumBuffer=function(){return this.toSM({endian:"little"})},n.prototype.gt=function(e){return this.cmp(e)>0},n.prototype.gte=function(e){return this.cmp(e)>=0},n.prototype.lt=function(e){return this.cmp(e)<0},n.trim=function(e,t){return e.slice(t-e.length,e.length)},n.pad=function(e,t,n){for(var i=new r(n),s=0;s<e.length;s++)i[i.length-1-s]=e[e.length-1-s];for(s=0;n-t>s;s++)i[s]=0;return i},t.exports=n}).call(this,e("buffer").Buffer)},{"../util/preconditions":43,"bn.js":170,buffer:46,lodash:194}],7:[function(e,t,r){(function(r){"use strict";var n=e("./bn"),i=e("./point"),s=e("./signature"),o=e("../publickey"),a=e("./random"),f=e("./hash"),c=e("../util/buffer"),u=e("lodash"),h=e("../util/preconditions"),d=function p(e){return this instanceof p?void(e&&this.set(e)):new p(e)};d.prototype.set=function(e){return this.hashbuf=e.hashbuf||this.hashbuf,this.endian=e.endian||this.endian,this.privkey=e.privkey||this.privkey,this.pubkey=e.pubkey||(this.privkey?this.privkey.publicKey:this.pubkey),this.sig=e.sig||this.sig,this.k=e.k||this.k,this.verified=e.verified||this.verified,this},d.prototype.privkey2pubkey=function(){this.pubkey=this.privkey.toPublicKey()},d.prototype.calci=function(){for(var e=0;4>e;e++){this.sig.i=e;var t;try{t=this.toPublicKey()}catch(r){console.error(r);continue}if(t.point.eq(this.pubkey.point))return this.sig.compressed=this.pubkey.compressed,this}throw this.sig.i=void 0,new Error("Unable to find valid recovery factor")},d.fromString=function(e){var t=JSON.parse(e);return new d(t)},d.prototype.randomK=function(){var e,t=i.getN();do e=n.fromBuffer(a.getRandomBuffer(32));while(!e.lt(t)||!e.gt(n.Zero));return this.k=e,this},d.prototype.deterministicK=function(e){u.isUndefined(e)&&(e=0);var t=new r(32);t.fill(1);var s=new r(32);s.fill(0);var o=this.privkey.bn.toBuffer({size:32});s=f.sha256hmac(r.concat([t,new r([0]),o,this.hashbuf]),s),t=f.sha256hmac(t,s),s=f.sha256hmac(r.concat([t,new r([1]),o,this.hashbuf]),s),t=f.sha256hmac(t,s),t=f.sha256hmac(t,s);for(var a=n.fromBuffer(t),c=i.getN(),h=0;e>h||!a.lt(c)||!a.gt(n.Zero);h++)s=f.sha256hmac(r.concat([t,new r([0])]),s),t=f.sha256hmac(t,s),t=f.sha256hmac(t,s),a=n.fromBuffer(t);return this.k=a,this},d.prototype.toPublicKey=function(){var e=this.sig.i;h.checkArgument(0===e||1===e||2===e||3===e,new Error("i must be equal to 0, 1, 2, or 3"));var t=n.fromBuffer(this.hashbuf),r=this.sig.r,s=this.sig.s,a=1&e,f=e>>1,c=i.getN(),u=i.getG(),d=f?r.add(c):r,p=i.fromX(a,d),l=p.mul(c);if(!l.isInfinity())throw new Error("nR is not a valid curve point");var b=t.neg().mod(c),g=r.invm(c),m=p.mul(s).add(u.mul(b)).mul(g),y=o.fromPoint(m,this.sig.compressed);return y},d.prototype.sigError=function(){if(!c.isBuffer(this.hashbuf)||32!==this.hashbuf.length)return"hashbuf must be a 32 byte buffer";var e=this.sig.r,t=this.sig.s;if(!(e.gt(n.Zero)&&e.lt(i.getN())&&t.gt(n.Zero)&&t.lt(i.getN())))return"r and s not in range";var r=n.fromBuffer(this.hashbuf,this.endian?{endian:this.endian}:void 0),s=i.getN(),o=t.invm(s),a=o.mul(r).mod(s),f=o.mul(e).mod(s),u=i.getG().mulAdd(a,this.pubkey.point,f);return u.isInfinity()?"p is infinity":0!==u.getX().mod(s).cmp(e)?"Invalid signature":!1},d.toLowS=function(e){return e.gt(n.fromBuffer(new r("7FFFFFFFFFFFFFFFFFFFFFFFFFFFFFFF5D576E7357A4501DDFE92F46681B20A0","hex")))&&(e=i.getN().sub(e)),e},d.prototype._findSignature=function(e,t){var r,s,o,a,f=i.getN(),c=i.getG(),u=0;do(!this.k||u>0)&&this.deterministicK(u),u++,r=this.k,s=c.mul(r),o=s.x.mod(f),a=r.invm(f).mul(t.add(e.mul(o))).mod(f);while(o.cmp(n.Zero)<=0||a.cmp(n.Zero)<=0);return a=d.toLowS(a),{s:a,r:o}},d.prototype.sign=function(){var e=this.hashbuf,t=this.privkey,r=t.bn;h.checkState(e&&t&&r,new Error("invalid parameters")),h.checkState(c.isBuffer(e)&&32===e.length,new Error("hashbuf must be a 32 byte buffer"));var i=n.fromBuffer(e,this.endian?{endian:this.endian}:void 0),o=this._findSignature(r,i);return o.compressed=this.pubkey.compressed,this.sig=new s(o),this},d.prototype.signRandomK=function(){return this.randomK(),this.sign()},d.prototype.toString=function(){var e={};return this.hashbuf&&(e.hashbuf=this.hashbuf.toString("hex")),this.privkey&&(e.privkey=this.privkey.toString()),this.pubkey&&(e.pubkey=this.pubkey.toString()),this.sig&&(e.sig=this.sig.toString()),this.k&&(e.k=this.k.toString()),JSON.stringify(e)},d.prototype.verify=function(){return this.verified=this.sigError()?!1:!0,this},d.sign=function(e,t,r){return d().set({hashbuf:e,endian:r,privkey:t}).sign().sig},d.verify=function(e,t,r,n){return d().set({hashbuf:e,endian:n,sig:t,pubkey:r}).verify().verified},t.exports=d}).call(this,e("buffer").Buffer)},{"../publickey":25,"../util/buffer":41,"../util/preconditions":43,"./bn":6,"./hash":8,"./point":9,"./random":10,"./signature":11,buffer:46,lodash:194}],8:[function(e,t,r){(function(r,n){"use strict";var i=e("hash.js"),s=e("sha512"),o=e("crypto"),a=e("../util/buffer"),f=e("../util/preconditions"),c=t.exports;c.sha1=function(e){return f.checkArgument(a.isBuffer(e)),o.createHash("sha1").update(e).digest()},c.sha1.blocksize=512,c.sha256=function(e){return f.checkArgument(a.isBuffer(e)),o.createHash("sha256").update(e).digest()},c.sha256.blocksize=512,c.sha256sha256=function(e){return f.checkArgument(a.isBuffer(e)),c.sha256(c.sha256(e))},c.ripemd160=function(e){return f.checkArgument(a.isBuffer(e)),o.createHash("ripemd160").update(e).digest()},r.window&&(c.ripemd160=function(e){f.checkArgument(a.isBuffer(e));var t=(new i.ripemd160).update(e).digest();return new n(t)}),c.sha256ripemd160=function(e){return f.checkArgument(a.isBuffer(e)),c.ripemd160(c.sha256(e))},c.sha512=function(e){f.checkArgument(a.isBuffer(e));var t=s(e);return new n(t)},c.sha512.blocksize=1024,c.hmac=function(e,t,r){f.checkArgument(a.isBuffer(t)),f.checkArgument(a.isBuffer(r)),f.checkArgument(e.blocksize);var i=e.blocksize/8;if(r.length>i)r=e(r);else if(i>r){var s=new n(i);s.fill(0),r.copy(s),r=s}var o=new n(i);o.fill(92);var c=new n(i);c.fill(54);for(var u=new n(i),h=new n(i),d=0;i>d;d++)u[d]=o[d]^r[d],h[d]=c[d]^r[d];return e(n.concat([u,e(n.concat([h,t]))]))},c.sha256hmac=function(e,t){return c.hmac(c.sha256,e,t)},c.sha512hmac=function(e,t){return c.hmac(c.sha512,e,t)}}).call(this,"undefined"!=typeof global?global:"undefined"!=typeof self?self:"undefined"!=typeof window?window:{},e("buffer").Buffer)},{"../util/buffer":41,"../util/preconditions":43,buffer:46,crypto:50,"hash.js":187,sha512:197}],9:[function(e,t,r){(function(r){"use strict";var n=e("./bn"),i=e("../util/buffer"),s=e("elliptic").curves.secp256k1,o=s.curve.point.bind(s.curve),a=s.curve.pointFromX.bind(s.curve),f=function(e,t,r){var n=o(e,t,r);return n.validate(),n};f.prototype=Object.getPrototypeOf(s.curve.point()),f.fromX=function(e,t){var r=a(e,t);return r.validate(),r},f.getG=function(){return s.curve.g},f.getN=function(){return new n(s.curve.n.toArray())},f.prototype._getX=f.prototype.getX,f.prototype.getX=function(){return new n(this._getX().toArray())},f.prototype._getY=f.prototype.getY,f.prototype.getY=function(){return new n(this._getY().toArray())},f.prototype.validate=function(){if(this.isInfinity())throw new Error("Point cannot be equal to Infinity");if(0===this.getX().cmp(n.Zero)||0===this.getY().cmp(n.Zero))throw new Error("Invalid x,y value for curve, cannot equal 0.");var e=a(this.getY().isOdd(),this.getX());if(0!==e.y.cmp(this.y))throw new Error("Invalid y value for curve.");var t=this.getX().gt(n.Minus1)&&this.getX().lt(f.getN()),r=this.getY().gt(n.Minus1)&&this.getY().lt(f.getN());if(!t||!r)throw new Error("Point does not lie on the curve");if(!this.mul(f.getN()).isInfinity())throw new Error("Point times N must be infinity");return this},f.pointToCompressed=function(e){var t,n=e.getX().toBuffer({size:32}),s=e.getY().toBuffer({size:32}),o=s[s.length-1]%2;return t=new r(o?[3]:[2]),i.concat([t,n])},t.exports=f}).call(this,e("buffer").Buffer)},{"../util/buffer":41,"./bn":6,buffer:46,elliptic:172}],10:[function(e,t,r){(function(r,n){"use strict";function i(){}i.getRandomBuffer=function(e){return r.browser?i.getRandomBufferBrowser(e):i.getRandomBufferNode(e)},i.getRandomBufferNode=function(t){var r=e("crypto");return r.randomBytes(t)},i.getRandomBufferBrowser=function(e){if(!window.crypto&&!window.msCrypto)throw new Error("window.crypto not available");if(window.crypto&&window.crypto.getRandomValues)var t=window.crypto;else{if(!window.msCrypto||!window.msCrypto.getRandomValues)throw new Error("window.crypto.getRandomValues not available");var t=window.msCrypto}var r=new Uint8Array(e);t.getRandomValues(r);var i=new n(r);return i},i.getPseudoRandomBuffer=function(e){for(var t,r=4294967296,i=new n(e),s=0;e>=s;s++){var o=Math.floor(s/4),a=s-4*o;0===a?(t=Math.random()*r,i[s]=255&t):i[s]=255&(t>>>=8)}return i},t.exports=i}).call(this,e("_process"),e("buffer").Buffer)},{_process:147,buffer:46,crypto:50}],11:[function(e,t,r){(function(r){"use strict";var n=e("./bn"),i=e("lodash"),s=e("../util/preconditions"),o=e("../util/buffer"),a=e("../util/js"),f=function c(e,t){if(!(this instanceof c))return new c(e,t);if(e instanceof n)this.set({r:e,s:t});else if(e){var r=e;this.set(r)}};f.prototype.set=function(e){return this.r=e.r||this.r||void 0,this.s=e.s||this.s||void 0,this.i="undefined"!=typeof e.i?e.i:this.i,this.compressed="undefined"!=typeof e.compressed?e.compressed:this.compressed,this.nhashtype=e.nhashtype||this.nhashtype||void 0,this},f.fromCompact=function(e){s.checkArgument(o.isBuffer(e),"Argument is expected to be a Buffer");var t=new f,r=!0,i=e.slice(0,1)[0]-27-4;0>i&&(r=!1,i+=4);var a=e.slice(1,33),c=e.slice(33,65);return s.checkArgument(0===i||1===i||2===i||3===i,new Error("i must be 0, 1, 2, or 3")),s.checkArgument(32===a.length,new Error("r must be 32 bytes")),s.checkArgument(32===c.length,new Error("s must be 32 bytes")),t.compressed=r,t.i=i,t.r=n.fromBuffer(a),t.s=n.fromBuffer(c),t},f.fromDER=f.fromBuffer=function(e,t){var r=f.parseDER(e,t),n=new f;return n.r=r.r,n.s=r.s,n},f.fromTxFormat=function(e){var t=e.readUInt8(e.length-1),r=e.slice(0,e.length-1),n=new f.fromDER(r,!1);return n.nhashtype=t,n},f.fromString=function(e){var t=new r(e,"hex");return f.fromDER(t)},f.parseDER=function(e,t){s.checkArgument(o.isBuffer(e),new Error("DER formatted signature should be a buffer")),i.isUndefined(t)&&(t=!0);var r=e[0];s.checkArgument(48===r,new Error("Header byte should be 0x30"));var a=e[1],f=e.slice(2).length;s.checkArgument(!t||a===f,new Error("Length byte should length of what follows")),a=f>a?a:f;var c=e[2];s.checkArgument(2===c,new Error("Integer byte for r should be 0x02"));var u=e[3],h=e.slice(4,4+u),d=n.fromBuffer(h),p=0===e[4]?!0:!1;s.checkArgument(u===h.length,new Error("Length of r incorrect"));var l=e[4+u+0];s.checkArgument(2===l,new Error("Integer byte for s should be 0x02"));var b=e[4+u+1],g=e.slice(4+u+2,4+u+2+b),m=n.fromBuffer(g),y=0===e[4+u+2+2]?!0:!1;s.checkArgument(b===g.length,new Error("Length of s incorrect"));var v=4+u+2+b;s.checkArgument(a===v-2,new Error("Length of signature incorrect"));var _={header:r,length:a,rheader:c,rlength:u,rneg:p,rbuf:h,r:d,sheader:l,slength:b,sneg:y,sbuf:g,s:m};return _},f.prototype.toCompact=function(e,t){if(e="number"==typeof e?e:this.i,t="boolean"==typeof t?t:this.compressed,0!==e&&1!==e&&2!==e&&3!==e)throw new Error("i must be equal to 0, 1, 2, or 3");var n=e+27+4;t===!1&&(n-=4);var i=new r([n]),s=this.r.toBuffer({size:32}),o=this.s.toBuffer({size:32});return r.concat([i,s,o])},f.prototype.toBuffer=f.prototype.toDER=function(){var e=this.r.toBuffer(),t=this.s.toBuffer(),n=128&e[0]?!0:!1,i=128&t[0]?!0:!1,s=n?r.concat([new r([0]),e]):e,o=i?r.concat([new r([0]),t]):t,a=s.length,f=o.length,c=2+a+2+f,u=2,h=2,d=48,p=r.concat([new r([d,c,u,a]),s,new r([h,f]),o]);return p},f.prototype.toString=function(){var e=this.toDER();return e.toString("hex")},f.isTxDER=function(e){if(e.length<9)return!1;if(e.length>73)return!1;if(48!==e[0])return!1;if(e[1]!==e.length-3)return!1;var t=e[3];if(5+t>=e.length)return!1;var r=e[5+t];if(t+r+7!==e.length)return!1;var n=e.slice(4);if(2!==e[2])return!1;if(0===t)return!1;if(128&n[0])return!1;if(t>1&&0===n[0]&&!(128&n[1]))return!1;var i=e.slice(6+t);return 2!==e[6+t-2]?!1:0===r?!1:128&i[0]?!1:r>1&&0===i[0]&&!(128&i[1])?!1:!0},f.prototype.hasLowS=function(){return this.s.lt(new n(1))||this.s.gt(new n("7FFFFFFFFFFFFFFFFFFFFFFFFFFFFFFF5D576E7357A4501DDFE92F46681B20A0"))?!1:!0},f.prototype.hasDefinedHashtype=function(){if(!a.isNaturalNumber(this.nhashtype))return!1;var e=this.nhashtype&~f.SIGHASH_ANYONECANPAY;return e<f.SIGHASH_ALL||e>f.SIGHASH_SINGLE?!1:!0},f.prototype.toTxFormat=function(){var e=this.toDER(),t=new r(1);return t.writeUInt8(this.nhashtype,0),r.concat([e,t])},f.SIGHASH_ALL=1,f.SIGHASH_NONE=2,f.SIGHASH_SINGLE=3,f.SIGHASH_ANYONECANPAY=128,t.exports=f}).call(this,e("buffer").Buffer)},{"../util/buffer":41,"../util/js":42,"../util/preconditions":43,"./bn":6,buffer:46,lodash:194}],12:[function(e,t,r){(function(r){"use strict";var n=e("lodash"),i=e("bs58"),s=e("buffer"),o="123456789ABCDEFGHJKLMNPQRSTUVWXYZabcdefghijkmnopqrstuvwxyz".split(""),a=function f(e){
if(!(this instanceof f))return new f(e);if(r.isBuffer(e)){var t=e;this.fromBuffer(t)}else if("string"==typeof e){var n=e;this.fromString(n)}else e&&this.set(e)};a.validCharacters=function(e){return s.Buffer.isBuffer(e)&&(e=e.toString()),n.all(n.map(e,function(e){return n.contains(o,e)}))},a.prototype.set=function(e){return this.buf=e.buf||this.buf||void 0,this},a.encode=function(e){if(!s.Buffer.isBuffer(e))throw new Error("Input should be a buffer");return i.encode(e)},a.decode=function(e){if("string"!=typeof e)throw new Error("Input should be a string");return new r(i.decode(e))},a.prototype.fromBuffer=function(e){return this.buf=e,this},a.prototype.fromString=function(e){var t=a.decode(e);return this.buf=t,this},a.prototype.toBuffer=function(){return this.buf},a.prototype.toString=function(){return a.encode(this.buf)},t.exports=a}).call(this,e("buffer").Buffer)},{bs58:171,buffer:46,lodash:194}],13:[function(e,t,r){(function(r){"use strict";var n=e("lodash"),i=e("./base58"),s=e("buffer"),o=e("../crypto/hash").sha256sha256,a=function f(e){if(!(this instanceof f))return new f(e);if(r.isBuffer(e)){var t=e;this.fromBuffer(t)}else if("string"==typeof e){var n=e;this.fromString(n)}else e&&this.set(e)};a.prototype.set=function(e){return this.buf=e.buf||this.buf||void 0,this},a.validChecksum=function(e,t){return n.isString(e)&&(e=new s.Buffer(i.decode(e))),n.isString(t)&&(t=new s.Buffer(i.decode(t))),t||(t=e.slice(-4),e=e.slice(0,-4)),a.checksum(e).toString("hex")===t.toString("hex")},a.decode=function(e){if("string"!=typeof e)throw new Error("Input must be a string");var t=new r(i.decode(e));if(t.length<4)throw new Error("Input string too short");var n=t.slice(0,-4),s=t.slice(-4),a=o(n),f=a.slice(0,4);if(s.toString("hex")!==f.toString("hex"))throw new Error("Checksum mismatch");return n},a.checksum=function(e){return o(e).slice(0,4)},a.encode=function(e){if(!r.isBuffer(e))throw new Error("Input must be a buffer");var t=new r(e.length+4),n=a.checksum(e);return e.copy(t),n.copy(t,e.length),i.encode(t)},a.prototype.fromBuffer=function(e){return this.buf=e,this},a.prototype.fromString=function(e){var t=a.decode(e);return this.buf=t,this},a.prototype.toBuffer=function(){return this.buf},a.prototype.toString=function(){return a.encode(this.buf)},t.exports=a}).call(this,e("buffer").Buffer)},{"../crypto/hash":8,"./base58":12,buffer:46,lodash:194}],14:[function(e,t,r){(function(r){"use strict";var n=e("lodash"),i=e("../util/preconditions"),s=e("../util/buffer"),o=e("../crypto/bn"),a=function f(e){if(!(this instanceof f))return new f(e);if(!n.isUndefined(e))if(r.isBuffer(e))this.set({buf:e});else if(n.isString(e))this.set({buf:new r(e,"hex")});else{if(!n.isObject(e))throw new TypeError("Unrecognized argument for BufferReader");var t=e;this.set(t)}};a.prototype.set=function(e){return this.buf=e.buf||this.buf||void 0,this.pos=e.pos||this.pos||0,this},a.prototype.eof=function(){return this.pos>=this.buf.length},a.prototype.finished=a.prototype.eof,a.prototype.read=function(e){i.checkArgument(!n.isUndefined(e),"Must specify a length");var t=this.buf.slice(this.pos,this.pos+e);return this.pos=this.pos+e,t},a.prototype.readAll=function(){var e=this.buf.slice(this.pos,this.buf.length);return this.pos=this.buf.length,e},a.prototype.readUInt8=function(){var e=this.buf.readUInt8(this.pos);return this.pos=this.pos+1,e},a.prototype.readUInt16BE=function(){var e=this.buf.readUInt16BE(this.pos);return this.pos=this.pos+2,e},a.prototype.readUInt16LE=function(){var e=this.buf.readUInt16LE(this.pos);return this.pos=this.pos+2,e},a.prototype.readUInt32BE=function(){var e=this.buf.readUInt32BE(this.pos);return this.pos=this.pos+4,e},a.prototype.readUInt32LE=function(){var e=this.buf.readUInt32LE(this.pos);return this.pos=this.pos+4,e},a.prototype.readUInt64BEBN=function(){var e=this.buf.slice(this.pos,this.pos+8),t=o.fromBuffer(e);return this.pos=this.pos+8,t},a.prototype.readUInt64LEBN=function(){var e,t=this.buf.readUInt32LE(this.pos),r=this.buf.readUInt32LE(this.pos+4),n=4294967296*r+t;if(9007199254740991>=n)e=new o(n);else{var i=Array.prototype.slice.call(this.buf,this.pos,this.pos+8);e=new o(i,10,"le")}return this.pos=this.pos+8,e},a.prototype.readVarintNum=function(){var e=this.readUInt8();switch(e){case 253:return this.readUInt16LE();case 254:return this.readUInt32LE();case 255:var t=this.readUInt64LEBN(),r=t.toNumber();if(r<=Math.pow(2,53))return r;throw new Error("number too large to retain precision - use readVarintBN");default:return e}},a.prototype.readVarLengthBuffer=function(){var e=this.readVarintNum(),t=this.read(e);return i.checkState(t.length===e,"Invalid length while reading varlength buffer. Expected to read: "+e+" and read "+t.length),t},a.prototype.readVarintBuf=function(){var e=this.buf.readUInt8(this.pos);switch(e){case 253:return this.read(3);case 254:return this.read(5);case 255:return this.read(9);default:return this.read(1)}},a.prototype.readVarintBN=function(){var e=this.readUInt8();switch(e){case 253:return new o(this.readUInt16LE());case 254:return new o(this.readUInt32LE());case 255:return this.readUInt64LEBN();default:return new o(e)}},a.prototype.reverse=function(){for(var e=new r(this.buf.length),t=0;t<e.length;t++)e[t]=this.buf[this.buf.length-1-t];return this.buf=e,this},a.prototype.readReverse=function(e){n.isUndefined(e)&&(e=this.buf.length);var t=this.buf.slice(this.pos,this.pos+e);return this.pos=this.pos+e,s.reverse(t)},t.exports=a}).call(this,e("buffer").Buffer)},{"../crypto/bn":6,"../util/buffer":41,"../util/preconditions":43,buffer:46,lodash:194}],15:[function(e,t,r){(function(r){"use strict";var n=e("../util/buffer"),i=e("assert"),s=function o(e){return this instanceof o?void(e?this.set(e):this.bufs=[]):new o(e)};s.prototype.set=function(e){return this.bufs=e.bufs||this.bufs||[],this},s.prototype.toBuffer=function(){return this.concat()},s.prototype.concat=function(){return r.concat(this.bufs)},s.prototype.write=function(e){return i(n.isBuffer(e)),this.bufs.push(e),this},s.prototype.writeReverse=function(e){return i(n.isBuffer(e)),this.bufs.push(n.reverse(e)),this},s.prototype.writeUInt8=function(e){var t=new r(1);return t.writeUInt8(e,0),this.write(t),this},s.prototype.writeUInt16BE=function(e){var t=new r(2);return t.writeUInt16BE(e,0),this.write(t),this},s.prototype.writeUInt16LE=function(e){var t=new r(2);return t.writeUInt16LE(e,0),this.write(t),this},s.prototype.writeUInt32BE=function(e){var t=new r(4);return t.writeUInt32BE(e,0),this.write(t),this},s.prototype.writeInt32LE=function(e){var t=new r(4);return t.writeInt32LE(e,0),this.write(t),this},s.prototype.writeUInt32LE=function(e){var t=new r(4);return t.writeUInt32LE(e,0),this.write(t),this},s.prototype.writeUInt64BEBN=function(e){var t=e.toBuffer({size:8});return this.write(t),this},s.prototype.writeUInt64LEBN=function(e){var t=e.toBuffer({size:8}),n=new r(Array.apply(new Array,t).reverse());return this.write(n),this},s.prototype.writeVarintNum=function(e){var t=s.varintBufNum(e);return this.write(t),this},s.prototype.writeVarintBN=function(e){var t=s.varintBufBN(e);return this.write(t),this},s.varintBufNum=function(e){var t=void 0;return 253>e?(t=new r(1),t.writeUInt8(e,0)):65536>e?(t=new r(3),t.writeUInt8(253,0),t.writeUInt16LE(e,1)):4294967296>e?(t=new r(5),t.writeUInt8(254,0),t.writeUInt32LE(e,1)):(t=new r(9),t.writeUInt8(255,0),t.writeInt32LE(-1&e,1),t.writeUInt32LE(Math.floor(e/4294967296),5)),t},s.varintBufBN=function(e){var t=void 0,n=e.toNumber();if(253>n)t=new r(1),t.writeUInt8(n,0);else if(65536>n)t=new r(3),t.writeUInt8(253,0),t.writeUInt16LE(n,1);else if(4294967296>n)t=new r(5),t.writeUInt8(254,0),t.writeUInt32LE(n,1);else{var i=new s;i.writeUInt8(255),i.writeUInt64LEBN(e);var t=i.concat()}return t},t.exports=s}).call(this,e("buffer").Buffer)},{"../util/buffer":41,assert:44,buffer:46}],16:[function(e,t,r){(function(r){"use strict";var n=e("./bufferwriter"),i=e("./bufferreader"),s=e("../crypto/bn"),o=function a(e){if(!(this instanceof a))return new a(e);if(r.isBuffer(e))this.buf=e;else if("number"==typeof e){var t=e;this.fromNumber(t)}else if(e instanceof s){var n=e;this.fromBN(n)}else if(e){var i=e;this.set(i)}};o.prototype.set=function(e){return this.buf=e.buf||this.buf,this},o.prototype.fromString=function(e){return this.set({buf:new r(e,"hex")}),this},o.prototype.toString=function(){return this.buf.toString("hex")},o.prototype.fromBuffer=function(e){return this.buf=e,this},o.prototype.fromBufferReader=function(e){return this.buf=e.readVarintBuf(),this},o.prototype.fromBN=function(e){return this.buf=n().writeVarintBN(e).concat(),this},o.prototype.fromNumber=function(e){return this.buf=n().writeVarintNum(e).concat(),this},o.prototype.toBuffer=function(){return this.buf},o.prototype.toBN=function(){return i(this.buf).readVarintBN()},o.prototype.toNumber=function(){return i(this.buf).readVarintNum()},t.exports=o}).call(this,e("buffer").Buffer)},{"../crypto/bn":6,"./bufferreader":14,"./bufferwriter":15,buffer:46}],17:[function(e,t,r){"use strict";function n(e,t){return e.replace("{0}",t[0]).replace("{1}",t[1]).replace("{2}",t[2])}var i=e("lodash"),s=function(e,t){var r=function(){if(i.isString(t.message))this.message=n(t.message,arguments);else{if(!i.isFunction(t.message))throw new Error("Invalid error definition for "+t.name);this.message=t.message.apply(null,arguments)}this.stack=this.message+"\n"+(new Error).stack};return r.prototype=Object.create(e.prototype),r.prototype.name=e.prototype.name+t.name,e[t.name]=r,t.errors&&o(r,t.errors),r},o=function(e,t){i.each(t,function(t){s(e,t)})},a=function(e,t){return o(e,t),e},f={};f.Error=function(){this.message="Internal error",this.stack=this.message+"\n"+(new Error).stack},f.Error.prototype=Object.create(Error.prototype),f.Error.prototype.name="bitcore.Error";var c=e("./spec");a(f.Error,c),t.exports=f.Error,t.exports.extend=function(e){return s(f.Error,e)}},{"./spec":18,lodash:194}],18:[function(e,t,r){"use strict";var n="http://bitcore.io/";t.exports=[{name:"InvalidB58Char",message:"Invalid Base58 character: {0} in {1}"},{name:"InvalidB58Checksum",message:"Invalid Base58 checksum for {0}"},{name:"InvalidNetwork",message:"Invalid version for network: got {0}"},{name:"InvalidState",message:"Invalid state: {0}"},{name:"NotImplemented",message:"Function {0} was not implemented yet"},{name:"InvalidNetworkArgument",message:'Invalid network: must be "livenet" or "testnet", got {0}'},{name:"InvalidArgument",message:function(){return"Invalid Argument"+(arguments[0]?": "+arguments[0]:"")+(arguments[1]?" Documentation: "+n+arguments[1]:"")}},{name:"AbstractMethodInvoked",message:"Abstract Method Invokation: {0}"},{name:"InvalidArgumentType",message:function(){return"Invalid Argument for "+arguments[2]+", expected "+arguments[1]+" but got "+typeof arguments[0]}},{name:"Unit",message:"Internal Error on Unit {0}",errors:[{name:"UnknownCode",message:"Unrecognized unit code: {0}"},{name:"InvalidRate",message:"Invalid exchange rate: {0}"}]},{name:"Transaction",message:"Internal Error on Transaction {0}",errors:[{name:"Input",message:"Internal Error on Input {0}",errors:[{name:"MissingScript",message:"Need a script to create an input"},{name:"UnsupportedScript",message:"Unsupported input script type: {0}"},{name:"MissingPreviousOutput",message:"No previous output information."}]},{name:"NeedMoreInfo",message:"{0}"},{name:"InvalidSorting",message:"The sorting function provided did not return the change output as one of the array elements"},{name:"InvalidOutputAmountSum",message:"{0}"},{name:"MissingSignatures",message:"Some inputs have not been fully signed"},{name:"InvalidIndex",message:"Invalid index: {0} is not between 0, {1}"},{name:"UnableToVerifySignature",message:"Unable to verify signature: {0}"},{name:"DustOutputs",message:"Dust amount detected in one output"},{name:"InvalidSatoshis",message:"Output satoshis are invalid"},{name:"FeeError",message:"Internal Error on Fee {0}",errors:[{name:"TooSmall",message:"Fee is too small: {0}"},{name:"TooLarge",message:"Fee is too large: {0}"},{name:"Different",message:"Unspent value is different from specified fee: {0}"}]},{name:"ChangeAddressMissing",message:"Change address is missing"},{name:"BlockHeightTooHigh",message:"Block Height can be at most 2^32 -1"},{name:"NLockTimeOutOfRange",message:"Block Height can only be between 0 and 499 999 999"},{name:"LockTimeTooEarly",message:"Lock Time can't be earlier than UNIX date 500 000 000"}]},{name:"Script",message:"Internal Error on Script {0}",errors:[{name:"UnrecognizedAddress",message:"Expected argument {0} to be an address"},{name:"CantDeriveAddress",message:"Can't derive address associated with script {0}, needs to be p2pkh in, p2pkh out, p2sh in, or p2sh out."},{name:"InvalidBuffer",message:"Invalid script buffer: can't parse valid script from given buffer {0}"}]},{name:"HDPrivateKey",message:"Internal Error on HDPrivateKey {0}",errors:[{name:"InvalidDerivationArgument",message:"Invalid derivation argument {0}, expected string, or number and boolean"},{name:"InvalidEntropyArgument",message:"Invalid entropy: must be an hexa string or binary buffer, got {0}",errors:[{name:"TooMuchEntropy",message:'Invalid entropy: more than 512 bits is non standard, got "{0}"'},{name:"NotEnoughEntropy",message:'Invalid entropy: at least 128 bits needed, got "{0}"'}]},{name:"InvalidLength",message:"Invalid length for xprivkey string in {0}"},{name:"InvalidPath",message:"Invalid derivation path: {0}"},{name:"UnrecognizedArgument",message:'Invalid argument: creating a HDPrivateKey requires a string, buffer, json or object, got "{0}"'}]},{name:"HDPublicKey",message:"Internal Error on HDPublicKey {0}",errors:[{name:"ArgumentIsPrivateExtended",message:"Argument is an extended private key: {0}"},{name:"InvalidDerivationArgument",message:"Invalid derivation argument: got {0}"},{name:"InvalidLength",message:'Invalid length for xpubkey: got "{0}"'},{name:"InvalidPath",message:'Invalid derivation path, it should look like: "m/1/100", got "{0}"'},{name:"MustSupplyArgument",message:"Must supply an argument to create a HDPublicKey"},{name:"UnrecognizedArgument",message:"Invalid argument for creation, must be string, json, buffer, or object"}]}]},{}],19:[function(e,t,r){"use strict";t.exports={_cache:{},_count:0,_eraseIndex:0,_usedList:{},_usedIndex:{},_CACHE_SIZE:5e3,get:function(e,t,r){r=!!r;var n=e+"/"+t+"/"+r;return this._cache[n]?(this._cacheHit(n),this._cache[n]):void 0},set:function(e,t,r,n){r=!!r;var i=e+"/"+t+"/"+r;this._cache[i]=n,this._cacheHit(i)},_cacheHit:function(e){this._usedIndex[e]&&delete this._usedList[this._usedIndex[e]],this._usedList[this._count]=e,this._usedIndex[e]=this._count,this._count++,this._cacheRemove()},_cacheRemove:function(){for(;this._eraseIndex<this._count-this._CACHE_SIZE;){if(this._usedList[this._eraseIndex]){var e=this._usedList[this._eraseIndex];delete this._usedIndex[e],delete this._cache[e]}delete this._usedList[this._eraseIndex],this._eraseIndex++}}}},{}],20:[function(e,t,r){(function(r){"use strict";function n(e){if(e instanceof n)return e;if(!(this instanceof n))return new n(e);if(!e)return this._generateRandomly();if(d.get(e))return this._generateRandomly(e);if(o.isString(e)||v.isBuffer(e))if(n.isValidSerialized(e))this._buildFromSerialized(e);else if(_.isValidJSON(e))this._buildFromJSON(e);else{if(!v.isBuffer(e)||!n.isValidSerialized(e.toString()))throw n.getSerializedError(e);this._buildFromSerialized(e.toString())}else{if(!o.isObject(e))throw new y.UnrecognizedArgument(e);this._buildFromObject(e)}}var i=e("assert"),s=e("buffer"),o=e("lodash"),a=e("./util/preconditions"),f=e("./crypto/bn"),c=e("./encoding/base58"),u=e("./encoding/base58check"),h=e("./crypto/hash"),d=e("./networks"),p=e("./hdkeycache"),l=e("./crypto/point"),b=e("./privatekey"),g=e("./crypto/random"),m=e("./errors"),y=m.HDPrivateKey,v=e("./util/buffer"),_=e("./util/js"),w=128,S=1/8,k=512;n.isValidPath=function(e,t){if(o.isString(e)){var r=n._getDerivationIndexes(e);return null!==r&&o.all(r,n.isValidPath)}return o.isNumber(e)?(e<n.Hardened&&t===!0&&(e+=n.Hardened),e>=0&&e<n.MaxIndex):!1},n._getDerivationIndexes=function(e){var t=e.split("/");if(o.contains(n.RootElementAlias,e))return[];if(!o.contains(n.RootElementAlias,t[0]))return null;var r=t.slice(1).map(function(e){var t="'"===e.slice(-1);if(t&&(e=e.slice(0,-1)),!e||"-"===e[0])return 0/0;var r=+e;return t&&(r+=n.Hardened),r});return o.any(r,isNaN)?null:r},n.prototype.derive=function(e,t){if(o.isNumber(e))return this._deriveWithNumber(e,t);if(o.isString(e))return this._deriveFromString(e);throw new y.InvalidDerivationArgument(e)},n.prototype._deriveWithNumber=function(e,t){if(!n.isValidPath(e,t))throw new y.InvalidPath(e);t=e>=n.Hardened?!0:t,e<n.Hardened&&t===!0&&(e+=n.Hardened);var r=p.get(this.xprivkey,e,t);if(r)return r;var i,o=v.integerAsBuffer(e);i=v.concat(t?[new s.Buffer([0]),this.privateKey.toBuffer(),o]:[this.publicKey.toBuffer(),o]);var a=h.sha512hmac(i,this._buffers.chainCode),c=f.fromBuffer(a.slice(0,32),{size:32}),u=a.slice(32,64),d=c.add(this.privateKey.toBigNumber()).mod(l.getN()).toBuffer({size:32}),b=new n({network:this.network,depth:this.depth+1,parentFingerPrint:this.fingerPrint,childIndex:e,chainCode:u,privateKey:d});return p.set(this.xprivkey,e,t,b),b},n.prototype._deriveFromString=function(e){if(!n.isValidPath(e))throw new y.InvalidPath(e);var t=n._getDerivationIndexes(e),r=t.reduce(function(e,t){return e._deriveWithNumber(t)},this);return r},n.isValidSerialized=function(e,t){return!n.getSerializedError(e,t)},n.getSerializedError=function(e,t){if(!o.isString(e)&&!v.isBuffer(e))return new y.UnrecognizedArgument("Expected string or buffer");if(!c.validCharacters(e))return new m.InvalidB58Char("(unknown)",e);try{e=u.decode(e)}catch(r){return new m.InvalidB58Checksum(e)}if(e.length!==n.DataLength)return new y.InvalidLength(e);if(!o.isUndefined(t)){var i=n._validateNetwork(e,t);if(i)return i}return null},n._validateNetwork=function(e,t){var r=d.get(t);if(!r)return new m.InvalidNetworkArgument(t);var n=e.slice(0,4);return v.integerFromBuffer(n)!==r.xprivkey?new m.InvalidNetwork(n):null},n.fromJSON=function(e){return a.checkArgument(_.isValidJSON(e),"No valid JSON string was provided"),new n(e)},n.fromString=function(e){return a.checkArgument(o.isString(e),"No valid string was provided"),new n(e)},n.fromObject=function(e){return a.checkArgument(o.isObject(e),"No valid argument was provided"),new n(e)},n.prototype._buildFromJSON=function(e){return this._buildFromObject(JSON.parse(e))},n.prototype._buildFromObject=function(e){var t={version:e.network?v.integerAsBuffer(d.get(e.network).xprivkey):e.version,depth:o.isNumber(e.depth)?v.integerAsSingleByteBuffer(e.depth):e.depth,parentFingerPrint:o.isNumber(e.parentFingerPrint)?v.integerAsBuffer(e.parentFingerPrint):e.parentFingerPrint,childIndex:o.isNumber(e.childIndex)?v.integerAsBuffer(e.childIndex):e.childIndex,chainCode:o.isString(e.chainCode)?v.hexToBuffer(e.chainCode):e.chainCode,privateKey:o.isString(e.privateKey)&&_.isHexa(e.privateKey)?v.hexToBuffer(e.privateKey):e.privateKey,checksum:e.checksum?e.checksum.length?e.checksum:v.integerAsBuffer(e.checksum):void 0};return this._buildFromBuffers(t)},n.prototype._buildFromSerialized=function(e){var t=u.decode(e),r={version:t.slice(n.VersionStart,n.VersionEnd),depth:t.slice(n.DepthStart,n.DepthEnd),parentFingerPrint:t.slice(n.ParentFingerPrintStart,n.ParentFingerPrintEnd),childIndex:t.slice(n.ChildIndexStart,n.ChildIndexEnd),chainCode:t.slice(n.ChainCodeStart,n.ChainCodeEnd),privateKey:t.slice(n.PrivateKeyStart,n.PrivateKeyEnd),checksum:t.slice(n.ChecksumStart,n.ChecksumEnd),xprivkey:e};return this._buildFromBuffers(r)},n.prototype._generateRandomly=function(e){return n.fromSeed(g.getRandomBuffer(64),e)},n.fromSeed=function(e,t){if(_.isHexaString(e)&&(e=v.hexToBuffer(e)),!r.isBuffer(e))throw new y.InvalidEntropyArgument(e);if(e.length<w*S)throw new y.InvalidEntropyArgument.NotEnoughEntropy(e);if(e.length>k*S)throw new y.InvalidEntropyArgument.TooMuchEntropy(e);var i=h.sha512hmac(e,new s.Buffer("Bitcoin seed"));return new n({network:d.get(t)||d.defaultNetwork,depth:0,parentFingerPrint:0,childIndex:0,privateKey:i.slice(0,32),chainCode:i.slice(32,64)})},n.prototype._calcHDPublicKey=function(){if(!this._hdPublicKey){var t=e("./hdpublickey");this._hdPublicKey=new t(this)}},n.prototype._buildFromBuffers=function(e){n._validateBufferArguments(e),_.defineImmutable(this,{_buffers:e});var t=[e.version,e.depth,e.parentFingerPrint,e.childIndex,e.chainCode,v.emptyBuffer(1),e.privateKey],i=s.Buffer.concat(t);if(e.checksum&&e.checksum.length){if(e.checksum.toString()!==u.checksum(i).toString())throw new m.InvalidB58Checksum(i)}else e.checksum=u.checksum(i);var o,a=d.get(v.integerFromBuffer(e.version));o=u.encode(s.Buffer.concat(t)),e.xprivkey=new r(o);var c=new b(f.fromBuffer(e.privateKey),a),p=c.toPublicKey(),l=n.ParentFingerPrintSize,g=h.sha256ripemd160(p.toBuffer()).slice(0,l);return _.defineImmutable(this,{xprivkey:o,network:a,depth:v.integerFromSingleByteBuffer(e.depth),privateKey:c,publicKey:p,fingerPrint:g}),this._hdPublicKey=null,Object.defineProperty(this,"hdPublicKey",{configurable:!1,enumerable:!0,get:function(){return this._calcHDPublicKey(),this._hdPublicKey}}),Object.defineProperty(this,"xpubkey",{configurable:!1,enumerable:!0,get:function(){return this._calcHDPublicKey(),this._hdPublicKey.xpubkey}}),this},n._validateBufferArguments=function(e){var t=function(t,r){var n=e[t];i(v.isBuffer(n),t+" argument is not a buffer"),i(n.length===r,t+" has not the expected size: found "+n.length+", expected "+r)};t("version",n.VersionSize),t("depth",n.DepthSize),t("parentFingerPrint",n.ParentFingerPrintSize),t("childIndex",n.ChildIndexSize),t("chainCode",n.ChainCodeSize),t("privateKey",n.PrivateKeySize),e.checksum&&e.checksum.length&&t("checksum",n.CheckSumSize)},n.prototype.toString=function(){return this.xprivkey},n.prototype.inspect=function(){return"<HDPrivateKey: "+this.xprivkey+">"},n.prototype.toObject=function(){return{network:d.get(v.integerFromBuffer(this._buffers.version),"xprivkey").name,depth:v.integerFromSingleByteBuffer(this._buffers.depth),fingerPrint:v.integerFromBuffer(this.fingerPrint),parentFingerPrint:v.integerFromBuffer(this._buffers.parentFingerPrint),childIndex:v.integerFromBuffer(this._buffers.childIndex),chainCode:v.bufferToHex(this._buffers.chainCode),privateKey:this.privateKey.toBuffer().toString("hex"),checksum:v.integerFromBuffer(this._buffers.checksum),xprivkey:this.xprivkey}},n.prototype.toJSON=function(){return JSON.stringify(this.toObject())},n.fromBuffer=function(e){return new n(e.toString())},n.prototype.toBuffer=function(){return v.copy(this._buffers.xprivkey)},n.DefaultDepth=0,n.DefaultFingerprint=0,n.DefaultChildIndex=0,n.Hardened=2147483648,n.MaxIndex=2*n.Hardened,n.RootElementAlias=["m","M","m'","M'"],n.VersionSize=4,n.DepthSize=1,n.ParentFingerPrintSize=4,n.ChildIndexSize=4,n.ChainCodeSize=32,n.PrivateKeySize=32,n.CheckSumSize=4,n.DataLength=78,n.SerializedByteSize=82,n.VersionStart=0,n.VersionEnd=n.VersionStart+n.VersionSize,n.DepthStart=n.VersionEnd,n.DepthEnd=n.DepthStart+n.DepthSize,n.ParentFingerPrintStart=n.DepthEnd,n.ParentFingerPrintEnd=n.ParentFingerPrintStart+n.ParentFingerPrintSize,n.ChildIndexStart=n.ParentFingerPrintEnd,n.ChildIndexEnd=n.ChildIndexStart+n.ChildIndexSize,n.ChainCodeStart=n.ChildIndexEnd,n.ChainCodeEnd=n.ChainCodeStart+n.ChainCodeSize,n.PrivateKeyStart=n.ChainCodeEnd+1,n.PrivateKeyEnd=n.PrivateKeyStart+n.PrivateKeySize,n.ChecksumStart=n.PrivateKeyEnd,n.ChecksumEnd=n.ChecksumStart+n.CheckSumSize,i(n.ChecksumEnd===n.SerializedByteSize),t.exports=n}).call(this,e("buffer").Buffer)},{"./crypto/bn":6,"./crypto/hash":8,"./crypto/point":9,"./crypto/random":10,"./encoding/base58":12,"./encoding/base58check":13,"./errors":17,"./hdkeycache":19,"./hdpublickey":21,"./networks":22,"./privatekey":24,"./util/buffer":41,"./util/js":42,"./util/preconditions":43,assert:44,buffer:46,lodash:194}],21:[function(e,t,r){(function(r){"use strict";function n(e){if(e instanceof n)return e;if(!(this instanceof n))return new n(e);if(e){if(i.isString(e)||_.isBuffer(e)){var t=n.getSerializedError(e);if(t){if(v.isValidJSON(e))return this._buildFromJSON(e);if(_.isBuffer(e)&&!n.getSerializedError(e.toString()))return this._buildFromSerialized(e.toString());if(t instanceof m.ArgumentIsPrivateExtended)return new u(e).hdPublicKey;throw t}return this._buildFromSerialized(e)}if(i.isObject(e))return e instanceof u?this._buildFromPrivate(e):this._buildFromObject(e);throw new m.UnrecognizedArgument(e)}throw new m.MustSupplyArgument}var i=e("lodash"),s=e("./util/preconditions"),o=e("./crypto/bn"),a=e("./encoding/base58"),f=e("./encoding/base58check"),c=e("./crypto/hash"),u=e("./hdprivatekey"),h=e("./hdkeycache"),d=e("./networks"),p=e("./crypto/point"),l=e("./publickey"),b=e("./errors"),g=b,m=b.HDPublicKey,y=e("assert"),v=e("./util/js"),_=e("./util/buffer");n.isValidPath=function(e){if(i.isString(e)){var t=u._getDerivationIndexes(e);return null!==t&&i.all(t,n.isValidPath)}return i.isNumber(e)?e>=0&&e<n.Hardened:!1},n.prototype.derive=function(e){if(i.isNumber(e))return this._deriveWithNumber(e);if(i.isString(e))return this._deriveFromString(e);throw new m.InvalidDerivationArgument(e)},n.prototype._deriveWithNumber=function(e){if(e>=n.Hardened)throw new m.InvalidIndexCantDeriveHardened;if(0>e)throw new m.InvalidPath(e);var t=h.get(this.xpubkey,e,!1);if(t)return t;var r=_.integerAsBuffer(e),i=_.concat([this.publicKey.toBuffer(),r]),s=c.sha512hmac(i,this._buffers.chainCode),a=o.fromBuffer(s.slice(0,32),{size:32}),f=s.slice(32,64),u=l.fromPoint(p.getG().mul(a).add(this.publicKey.point)),d=new n({network:this.network,depth:this.depth+1,parentFingerPrint:this.fingerPrint,childIndex:e,chainCode:f,publicKey:u});return h.set(this.xpubkey,e,!1,d),d},n.prototype._deriveFromString=function(e){if(i.contains(e,"'"))throw new m.InvalidIndexCantDeriveHardened;if(!n.isValidPath(e))throw new m.InvalidPath(e);var t=u._getDerivationIndexes(e),r=t.reduce(function(e,t){return e._deriveWithNumber(t)},this);return r},n.isValidSerialized=function(e,t){return i.isNull(n.getSerializedError(e,t))},n.getSerializedError=function(e,t){if(!i.isString(e)&&!_.isBuffer(e))return new m.UnrecognizedArgument("expected buffer or string");if(!a.validCharacters(e))return new g.InvalidB58Char("(unknown)",e);try{e=f.decode(e)}catch(r){return new g.InvalidB58Checksum(e)}if(e.length!==n.DataSize)return new g.InvalidLength(e);if(!i.isUndefined(t)){var s=n._validateNetwork(e,t);if(s)return s}var o=_.integerFromBuffer(e.slice(0,4));return o===d.livenet.xprivkey||o===d.testnet.xprivkey?new m.ArgumentIsPrivateExtended:null},n._validateNetwork=function(e,t){var r=d.get(t);if(!r)return new g.InvalidNetworkArgument(t);var i=e.slice(n.VersionStart,n.VersionEnd);return _.integerFromBuffer(i)!==r.xpubkey?new g.InvalidNetwork(i):null},n.prototype._buildFromJSON=function(e){return this._buildFromObject(JSON.parse(e))},n.prototype._buildFromPrivate=function(e){var t=i.clone(e._buffers),r=p.getG().mul(o.fromBuffer(t.privateKey));return t.publicKey=p.pointToCompressed(r),t.version=_.integerAsBuffer(d.get(_.integerFromBuffer(t.version)).xpubkey),t.privateKey=void 0,t.checksum=void 0,t.xprivkey=void 0,this._buildFromBuffers(t)},n.prototype._buildFromObject=function(e){var t={version:e.network?_.integerAsBuffer(d.get(e.network).xpubkey):e.version,depth:i.isNumber(e.depth)?_.integerAsSingleByteBuffer(e.depth):e.depth,parentFingerPrint:i.isNumber(e.parentFingerPrint)?_.integerAsBuffer(e.parentFingerPrint):e.parentFingerPrint,childIndex:i.isNumber(e.childIndex)?_.integerAsBuffer(e.childIndex):e.childIndex,chainCode:i.isString(e.chainCode)?_.hexToBuffer(e.chainCode):e.chainCode,publicKey:i.isString(e.publicKey)?_.hexToBuffer(e.publicKey):_.isBuffer(e.publicKey)?e.publicKey:e.publicKey.toBuffer(),checksum:i.isNumber(e.checksum)?_.integerAsBuffer(e.checksum):e.checksum};return this._buildFromBuffers(t)},n.prototype._buildFromSerialized=function(e){var t=f.decode(e),r={version:t.slice(n.VersionStart,n.VersionEnd),depth:t.slice(n.DepthStart,n.DepthEnd),parentFingerPrint:t.slice(n.ParentFingerPrintStart,n.ParentFingerPrintEnd),childIndex:t.slice(n.ChildIndexStart,n.ChildIndexEnd),chainCode:t.slice(n.ChainCodeStart,n.ChainCodeEnd),publicKey:t.slice(n.PublicKeyStart,n.PublicKeyEnd),checksum:t.slice(n.ChecksumStart,n.ChecksumEnd),xpubkey:e};return this._buildFromBuffers(r)},n.prototype._buildFromBuffers=function(e){n._validateBufferArguments(e),v.defineImmutable(this,{_buffers:e});var t=[e.version,e.depth,e.parentFingerPrint,e.childIndex,e.chainCode,e.publicKey],i=_.concat(t),s=f.checksum(i);if(e.checksum&&e.checksum.length){if(e.checksum.toString("hex")!==s.toString("hex"))throw new g.InvalidB58Checksum(i,s)}else e.checksum=s;var o,a=d.get(_.integerFromBuffer(e.version));o=f.encode(_.concat(t)),e.xpubkey=new r(o);var u=new l(e.publicKey,{network:a}),h=n.ParentFingerPrintSize,p=c.sha256ripemd160(u.toBuffer()).slice(0,h);return v.defineImmutable(this,{xpubkey:o,network:a,depth:_.integerFromSingleByteBuffer(e.depth),publicKey:u,fingerPrint:p}),this},n._validateBufferArguments=function(e){var t=function(t,r){var n=e[t];y(_.isBuffer(n),t+" argument is not a buffer, it's "+typeof n),y(n.length===r,t+" has not the expected size: found "+n.length+", expected "+r)};t("version",n.VersionSize),t("depth",n.DepthSize),t("parentFingerPrint",n.ParentFingerPrintSize),t("childIndex",n.ChildIndexSize),t("chainCode",n.ChainCodeSize),t("publicKey",n.PublicKeySize),e.checksum&&e.checksum.length&&t("checksum",n.CheckSumSize)},n.fromJSON=function(e){return s.checkArgument(v.isValidJSON(e),"No valid JSON string was provided"),new n(e)},n.fromObject=function(e){return s.checkArgument(i.isObject(e),"No valid argument was provided"),new n(e)},n.fromString=function(e){return s.checkArgument(i.isString(e),"No valid string was provided"),new n(e)},n.prototype.toString=function(){return this.xpubkey},n.prototype.inspect=function(){return"<HDPublicKey: "+this.xpubkey+">"},n.prototype.toObject=function(){return{network:d.get(_.integerFromBuffer(this._buffers.version)).name,depth:_.integerFromSingleByteBuffer(this._buffers.depth),fingerPrint:_.integerFromBuffer(this.fingerPrint),parentFingerPrint:_.integerFromBuffer(this._buffers.parentFingerPrint),childIndex:_.integerFromBuffer(this._buffers.childIndex),chainCode:_.bufferToHex(this._buffers.chainCode),publicKey:this.publicKey.toString(),checksum:_.integerFromBuffer(this._buffers.checksum),xpubkey:this.xpubkey}},n.prototype.toJSON=function(){return JSON.stringify(this.toObject())},n.fromBuffer=function(e){return new n(e)},n.prototype.toBuffer=function(){return _.copy(this._buffers.xpubkey)},n.Hardened=2147483648,n.RootElementAlias=["m","M"],n.VersionSize=4,n.DepthSize=1,n.ParentFingerPrintSize=4,n.ChildIndexSize=4,n.ChainCodeSize=32,n.PublicKeySize=33,n.CheckSumSize=4,n.DataSize=78,n.SerializedByteSize=82,n.VersionStart=0,n.VersionEnd=n.VersionStart+n.VersionSize,n.DepthStart=n.VersionEnd,n.DepthEnd=n.DepthStart+n.DepthSize,n.ParentFingerPrintStart=n.DepthEnd,n.ParentFingerPrintEnd=n.ParentFingerPrintStart+n.ParentFingerPrintSize,n.ChildIndexStart=n.ParentFingerPrintEnd,n.ChildIndexEnd=n.ChildIndexStart+n.ChildIndexSize,n.ChainCodeStart=n.ChildIndexEnd,n.ChainCodeEnd=n.ChainCodeStart+n.ChainCodeSize,n.PublicKeyStart=n.ChainCodeEnd,n.PublicKeyEnd=n.PublicKeyStart+n.PublicKeySize,n.ChecksumStart=n.PublicKeyEnd,n.ChecksumEnd=n.ChecksumStart+n.CheckSumSize,y(n.PublicKeyEnd===n.DataSize),y(n.ChecksumEnd===n.SerializedByteSize),t.exports=n}).call(this,e("buffer").Buffer)},{"./crypto/bn":6,"./crypto/hash":8,"./crypto/point":9,"./encoding/base58":12,"./encoding/base58check":13,"./errors":17,"./hdkeycache":19,"./hdprivatekey":20,"./networks":22,"./publickey":25,"./util/buffer":41,"./util/js":42,"./util/preconditions":43,assert:44,buffer:46,lodash:194}],22:[function(e,t,r){"use strict";function n(){}function i(e,t){if(~u.indexOf(e))return e;if(t){a.isArray(t)||(t=[t]);var r=function(t){
return u[n][t]===e};for(var n in u)if(a.any(t,r))return u[n];return void 0}return h[e]}function s(e){var t=new n;return c.defineImmutable(t,{name:e.name,alias:e.alias,pubkeyhash:e.pubkeyhash,privatekey:e.privatekey,scripthash:e.scripthash,xpubkey:e.xpubkey,xprivkey:e.xprivkey,networkMagic:f.integerAsBuffer(e.networkMagic),port:e.port,dnsSeeds:e.dnsSeeds}),a.each(t,function(e){a.isUndefined(e)||a.isObject(e)||(h[e]=t)}),u.push(t),t}function o(e){for(var t=0;t<u.length;t++)u[t]===e&&u.splice(t,1);for(var r in h)h[r]===e&&delete h[r]}var a=e("lodash"),f=e("./util/buffer"),c=e("./util/js"),u=[],h={};n.prototype.toString=function(){return this.name},s({name:"livenet",alias:"mainnet",pubkeyhash:0,privatekey:128,scripthash:5,xpubkey:76067358,xprivkey:76066276,networkMagic:4190024921,port:8333,dnsSeeds:["seed.bitcoin.sipa.be","dnsseed.bluematt.me","dnsseed.bitcoin.dashjr.org","seed.bitcoinstats.com","seed.bitnodes.io","bitseed.xf2.org"]}),s({name:"testnet",alias:"testnet",pubkeyhash:111,privatekey:239,scripthash:196,xpubkey:70617039,xprivkey:70615956,networkMagic:185665799,port:18333,dnsSeeds:["testnet-seed.bitcoin.petertodd.org","testnet-seed.bluematt.me","testnet-seed.alexykot.me","testnet-seed.bitcoin.schildbach.de"]});var d=i("livenet"),p=i("testnet");t.exports={add:s,remove:o,defaultNetwork:d,livenet:d,mainnet:d,testnet:p,get:i}},{"./util/buffer":41,"./util/js":42,lodash:194}],23:[function(e,t,r){(function(r){"use strict";function n(e){if(!(this instanceof n))return new n(e);var t;if(i.isNumber(e))t=e;else{if(!i.isString(e))throw new TypeError('Unrecognized num type: "'+typeof e+'" for Opcode');t=n.map[e]}return a.defineImmutable(this,{num:t}),this}var i=e("lodash"),s=e("./util/preconditions"),o=e("./util/buffer"),a=e("./util/js");n.fromBuffer=function(e){return s.checkArgument(o.isBuffer(e)),new n(Number("0x"+e.toString("hex")))},n.fromNumber=function(e){return s.checkArgument(i.isNumber(e)),new n(e)},n.fromString=function(e){s.checkArgument(i.isString(e));var t=n.map[e];if("undefined"==typeof t)throw new TypeError("Invalid opcodestr");return new n(t)},n.prototype.toHex=function(){return this.num.toString(16)},n.prototype.toBuffer=function(){return new r(this.toHex(),"hex")},n.prototype.toNumber=function(){return this.num},n.prototype.toString=function(){var e=n.reverseMap[this.num];if("undefined"==typeof e)throw new Error("Opcode does not have a string representation");return e},n.smallInt=function(e){return s.checkArgument(e>=0&&16>=e,"Invalid Argument: n must be between 0 and 16"),0===e?n("OP_0"):new n(n.map.OP_1+e-1)},n.map={OP_FALSE:0,OP_0:0,OP_PUSHDATA1:76,OP_PUSHDATA2:77,OP_PUSHDATA4:78,OP_1NEGATE:79,OP_RESERVED:80,OP_TRUE:81,OP_1:81,OP_2:82,OP_3:83,OP_4:84,OP_5:85,OP_6:86,OP_7:87,OP_8:88,OP_9:89,OP_10:90,OP_11:91,OP_12:92,OP_13:93,OP_14:94,OP_15:95,OP_16:96,OP_NOP:97,OP_VER:98,OP_IF:99,OP_NOTIF:100,OP_VERIF:101,OP_VERNOTIF:102,OP_ELSE:103,OP_ENDIF:104,OP_VERIFY:105,OP_RETURN:106,OP_TOALTSTACK:107,OP_FROMALTSTACK:108,OP_2DROP:109,OP_2DUP:110,OP_3DUP:111,OP_2OVER:112,OP_2ROT:113,OP_2SWAP:114,OP_IFDUP:115,OP_DEPTH:116,OP_DROP:117,OP_DUP:118,OP_NIP:119,OP_OVER:120,OP_PICK:121,OP_ROLL:122,OP_ROT:123,OP_SWAP:124,OP_TUCK:125,OP_CAT:126,OP_SUBSTR:127,OP_LEFT:128,OP_RIGHT:129,OP_SIZE:130,OP_INVERT:131,OP_AND:132,OP_OR:133,OP_XOR:134,OP_EQUAL:135,OP_EQUALVERIFY:136,OP_RESERVED1:137,OP_RESERVED2:138,OP_1ADD:139,OP_1SUB:140,OP_2MUL:141,OP_2DIV:142,OP_NEGATE:143,OP_ABS:144,OP_NOT:145,OP_0NOTEQUAL:146,OP_ADD:147,OP_SUB:148,OP_MUL:149,OP_DIV:150,OP_MOD:151,OP_LSHIFT:152,OP_RSHIFT:153,OP_BOOLAND:154,OP_BOOLOR:155,OP_NUMEQUAL:156,OP_NUMEQUALVERIFY:157,OP_NUMNOTEQUAL:158,OP_LESSTHAN:159,OP_GREATERTHAN:160,OP_LESSTHANOREQUAL:161,OP_GREATERTHANOREQUAL:162,OP_MIN:163,OP_MAX:164,OP_WITHIN:165,OP_RIPEMD160:166,OP_SHA1:167,OP_SHA256:168,OP_HASH160:169,OP_HASH256:170,OP_CODESEPARATOR:171,OP_CHECKSIG:172,OP_CHECKSIGVERIFY:173,OP_CHECKMULTISIG:174,OP_CHECKMULTISIGVERIFY:175,OP_CHECKLOCKTIMEVERIFY:177,OP_NOP1:176,OP_NOP2:177,OP_NOP3:178,OP_NOP4:179,OP_NOP5:180,OP_NOP6:181,OP_NOP7:182,OP_NOP8:183,OP_NOP9:184,OP_NOP10:185,OP_PUBKEYHASH:253,OP_PUBKEY:254,OP_INVALIDOPCODE:255},n.reverseMap=[];for(var f in n.map)n.reverseMap[n.map[f]]=f;i.extend(n,n.map),n.isSmallIntOp=function(e){return e instanceof n&&(e=e.toNumber()),e===n.map.OP_0||e>=n.map.OP_1&&e<=n.map.OP_16},n.prototype.inspect=function(){return"<Opcode: "+this.toString()+", hex: "+this.toHex()+", decimal: "+this.num+">"},t.exports=n}).call(this,e("buffer").Buffer)},{"./util/buffer":41,"./util/js":42,"./util/preconditions":43,buffer:46,lodash:194}],24:[function(e,t,r){(function(r){"use strict";var n=e("lodash"),i=e("./address"),s=e("./encoding/base58check"),o=e("./crypto/bn"),a=e("./util/js"),f=e("./networks"),c=e("./crypto/point"),u=e("./publickey"),h=e("./crypto/random"),d=function p(e,t){if(!(this instanceof p))return new p(e,t);if(e instanceof p)return e;var r=this._classifyArguments(e,t);if(!r.bn||0===r.bn.cmp(new o(0)))throw new TypeError("Number can not be equal to zero, undefined, null or false");if(!r.bn.lt(c.getN()))throw new TypeError("Number must be less than N");if("undefined"==typeof r.network)throw new TypeError('Must specify the network ("livenet" or "testnet")');return a.defineImmutable(this,{bn:r.bn,compressed:r.compressed,network:r.network}),Object.defineProperty(this,"publicKey",{configurable:!1,enumerable:!0,get:this.toPublicKey.bind(this)}),this};d.prototype._classifyArguments=function(e,t){var i={compressed:!0,network:t?f.get(t):f.defaultNetwork};if(n.isUndefined(e)||n.isNull(e))i.bn=d._getRandomBN();else if(e instanceof o)i.bn=e;else if(e instanceof r||e instanceof Uint8Array)i=d._transformBuffer(e,t);else if(d._isJSON(e))i=d._transformJSON(e);else if(!t&&f.get(e))i.bn=d._getRandomBN(),i.network=f.get(e);else{if("string"!=typeof e)throw new TypeError("First argument is an unrecognized data type.");a.isHexa(e)?i.bn=new o(new r(e,"hex")):i=d._transformWIF(e,t)}return i},d._getRandomBN=function(){var e,t;do{var r=h.getRandomBuffer(32);t=o.fromBuffer(r),e=t.lt(c.getN())}while(!e);return t},d._isJSON=function(e){return a.isValidJSON(e)||e.bn&&e.network},d._transformBuffer=function(e,t){var r={};if(32===e.length)return d._transformBNBuffer(e,t);if(r.network=f.get(e[0],"privatekey"),!r.network)throw new Error("Invalid network");if(t&&r.network!==f.get(t))throw new TypeError("Private key network mismatch");if(34===e.length&&1===e[33])r.compressed=!0;else{if(33!==e.length)throw new Error("Length of buffer must be 33 (uncompressed) or 34 (compressed)");r.compressed=!1}return r.bn=o.fromBuffer(e.slice(1,33)),r},d._transformBNBuffer=function(e,t){var r={};return r.network=f.get(t)||f.defaultNetwork,r.bn=o.fromBuffer(e),r.compressed=!1,r},d._transformWIF=function(e,t){return d._transformBuffer(s.decode(e),t)},d.fromJSON=function(e){if(!d._isJSON(e))throw new TypeError("Must be a valid JSON string or plain object");return new d(e)},d.fromBuffer=function(e,t){return new d(e,t)},d._transformJSON=function(e){a.isValidJSON(e)&&(e=JSON.parse(e));var t=new o(e.bn,"hex"),r=f.get(e.network);return{bn:t,network:r,compressed:e.compressed}},d.fromString=d.fromWIF=function(e){return new d(e)},d.fromRandom=function(e){var t=d._getRandomBN();return new d(t,e)},d.getValidationError=function(e,t){var r;try{new d(e,t)}catch(n){r=n}return r},d.isValid=function(e,t){return e?!d.getValidationError(e,t):!1},d.prototype.toString=function(){return this.toBuffer().toString("hex")},d.prototype.toWIF=function(){var e,t=this.network,n=this.compressed;return e=r.concat(n?[new r([t.privatekey]),this.bn.toBuffer({size:32}),new r([1])]:[new r([t.privatekey]),this.bn.toBuffer({size:32})]),s.encode(e)},d.prototype.toBigNumber=function(){return this.bn},d.prototype.toBuffer=function(){return this.bn.toBuffer()},d.prototype.toPublicKey=function(){return this._pubkey||(this._pubkey=u.fromPrivateKey(this)),this._pubkey},d.prototype.toAddress=function(e){var t=this.toPublicKey();return i.fromPublicKey(t,e||this.network)},d.prototype.toObject=function(){return{bn:this.bn.toString("hex"),compressed:this.compressed,network:this.network.toString()}},d.prototype.toJSON=function(){return JSON.stringify(this.toObject())},d.prototype.inspect=function(){var e=this.compressed?"":", uncompressed";return"<PrivateKey: "+this.toString()+", network: "+this.network+e+">"},t.exports=d}).call(this,e("buffer").Buffer)},{"./address":1,"./crypto/bn":6,"./crypto/point":9,"./crypto/random":10,"./encoding/base58check":13,"./networks":22,"./publickey":25,"./util/js":42,buffer:46,lodash:194}],25:[function(e,t,r){(function(r){"use strict";var n=e("./crypto/bn"),i=e("./crypto/point"),s=e("./crypto/hash"),o=e("./util/js"),a=e("./networks"),f=e("lodash"),c=e("./util/preconditions"),u=function h(e,t){if(!(this instanceof h))return new h(e,t);if(c.checkArgument(e,"First argument is required, please include public key data."),e instanceof h)return e;t=t||{};var r=this._classifyArgs(e,t);return r.point.validate(),o.defineImmutable(this,{point:r.point,compressed:r.compressed,network:r.network||a.defaultNetwork}),this};u.prototype._classifyArgs=function(e,t){var n={compressed:f.isUndefined(t.compressed)||t.compressed};if(e instanceof i)n.point=e;else if(u._isJSON(e))n=u._transformJSON(e);else if("string"==typeof e)n=u._transformDER(new r(e,"hex"));else if(u._isBuffer(e))n=u._transformDER(e);else{if(!u._isPrivateKey(e))throw new TypeError("First argument is an unrecognized data format.");n=u._transformPrivateKey(e)}return n.network||(n.network=f.isUndefined(t.network)?void 0:a.get(t.network)),n},u._isPrivateKey=function(t){var r=e("./privatekey");return t instanceof r},u._isBuffer=function(e){return e instanceof r||e instanceof Uint8Array},u._isJSON=function(e){return!!(o.isValidJSON(e)||e.x&&e.y)},u._transformPrivateKey=function(e){c.checkArgument(u._isPrivateKey(e),"Must be an instance of PrivateKey");var t={};return t.point=i.getG().mul(e.bn),t.compressed=e.compressed,t.network=e.network,t},u._transformDER=function(e,t){c.checkArgument(u._isBuffer(e),"Must be a hex buffer of DER encoded public key");var r={};t=f.isUndefined(t)?!0:t;var s,o,a,h;if(4!==e[0]&&(t||6!==e[0]&&7!==e[0]))if(3===e[0])a=e.slice(1),s=new n(a),r=u._transformX(!0,s),r.compressed=!0;else{if(2!==e[0])throw new TypeError("Invalid DER format public key");a=e.slice(1),s=new n(a),r=u._transformX(!1,s),r.compressed=!0}else{if(a=e.slice(1,33),h=e.slice(33,65),32!==a.length||32!==h.length||65!==e.length)throw new TypeError("Length of x and y must be 32 bytes");s=new n(a),o=new n(h),r.point=new i(s,o),r.compressed=!1}return r},u._transformX=function(e,t){c.checkArgument("boolean"==typeof e,"Must specify whether y is odd or not (true or false)");var r={};return r.point=i.fromX(e,t),r},u.fromJSON=function(e){return c.checkArgument(u._isJSON(e),"Must be a valid JSON string or plain object"),new u(e)},u._transformJSON=function(e){o.isValidJSON(e)&&(e=JSON.parse(e));var t=new n(e.x,"hex"),r=new n(e.y,"hex"),s=new i(t,r);return new u(s,{compressed:e.compressed})},u.fromPrivateKey=function(e){c.checkArgument(u._isPrivateKey(e),"Must be an instance of PrivateKey");var t=u._transformPrivateKey(e);return new u(t.point,{compressed:t.compressed,network:t.network})},u.fromDER=u.fromBuffer=function(e,t){c.checkArgument(u._isBuffer(e),"Must be a hex buffer of DER encoded public key");var r=u._transformDER(e,t);return new u(r.point,{compressed:r.compressed})},u.fromPoint=function(e,t){return c.checkArgument(e instanceof i,"First argument must be an instance of Point."),new u(e,{compressed:t})},u.fromString=function(e,t){var n=new r(e,t||"hex"),i=u._transformDER(n);return new u(i.point,{compressed:i.compressed})},u.fromX=function(e,t){var r=u._transformX(e,t);return new u(r.point,{compressed:r.compressed})},u.getValidationError=function(e){var t;try{new u(e)}catch(r){t=r}return t},u.isValid=function(e){return!u.getValidationError(e)},u.prototype.toObject=function(){return{x:this.point.getX().toString("hex",2),y:this.point.getY().toString("hex",2),compressed:this.compressed}},u.prototype.toJSON=function(){return JSON.stringify(this.toObject())},u.prototype.toBuffer=u.prototype.toDER=function(){var e,t=this.point.getX(),n=this.point.getY(),i=t.toBuffer({size:32}),s=n.toBuffer({size:32});if(this.compressed){var o=s[s.length-1]%2;return e=new r(o?[3]:[2]),r.concat([e,i])}return e=new r([4]),r.concat([e,i,s])},u.prototype._getID=function(){return s.sha256ripemd160(this.toBuffer())},u.prototype.toAddress=function(t){var r=e("./address");return r.fromPublicKey(this,t||this.network)},u.prototype.toString=function(){return this.toDER().toString("hex")},u.prototype.inspect=function(){return"<PublicKey: "+this.toString()+(this.compressed?"":", uncompressed")+">"},t.exports=u}).call(this,e("buffer").Buffer)},{"./address":1,"./crypto/bn":6,"./crypto/hash":8,"./crypto/point":9,"./networks":22,"./privatekey":24,"./util/js":42,"./util/preconditions":43,buffer:46,lodash:194}],26:[function(e,t,r){t.exports=e("./script"),t.exports.Interpreter=e("./interpreter")},{"./interpreter":27,"./script":28}],27:[function(e,t,r){(function(r){"use strict";var n=e("lodash"),i=e("./script"),s=e("../opcode"),o=e("../crypto/bn"),a=e("../crypto/hash"),f=e("../crypto/signature"),c=e("../publickey"),u=function h(e){return this instanceof h?void(e?(this.initialize(),this.set(e)):this.initialize()):new h(e)};u.prototype.verify=function(t,r,s,o,a){var f=e("../transaction");n.isUndefined(s)&&(s=new f),n.isUndefined(o)&&(o=0),n.isUndefined(a)&&(a=0),this.set({script:t,tx:s,nin:o,flags:a});var c;if(0!==(a&u.SCRIPT_VERIFY_SIGPUSHONLY)&&!t.isPushOnly())return this.errstr="SCRIPT_ERR_SIG_PUSHONLY",!1;if(!this.evaluate())return!1;a&u.SCRIPT_VERIFY_P2SH&&(c=this.stack.slice());var h=this.stack;if(this.initialize(),this.set({script:r,stack:h,tx:s,nin:o,flags:a}),!this.evaluate())return!1;if(0===this.stack.length)return this.errstr="SCRIPT_ERR_EVAL_FALSE_NO_RESULT",!1;var d=this.stack[this.stack.length-1];if(!u.castToBool(d))return this.errstr="SCRIPT_ERR_EVAL_FALSE_IN_STACK",!1;if(a&u.SCRIPT_VERIFY_P2SH&&r.isScriptHashOut()){if(!t.isPushOnly())return this.errstr="SCRIPT_ERR_SIG_PUSHONLY",!1;if(0===c.length)throw new Error("internal error - stack copy empty");var p=c[c.length-1],l=i.fromBuffer(p);return c.pop(),this.initialize(),this.set({script:l,stack:c,tx:s,nin:o,flags:a}),this.evaluate()?0===c.length?(this.errstr="SCRIPT_ERR_EVAL_FALSE_NO_P2SH_STACK",!1):u.castToBool(c[c.length-1])?!0:(this.errstr="SCRIPT_ERR_EVAL_FALSE_IN_P2SH_STACK",!1):!1}return!0},t.exports=u,u.prototype.initialize=function(e){this.stack=[],this.altstack=[],this.pc=0,this.pbegincodehash=0,this.nOpCount=0,this.vfExec=[],this.errstr="",this.flags=0},u.prototype.set=function(e){this.script=e.script||this.script,this.tx=e.tx||this.tx,this.nin="undefined"!=typeof e.nin?e.nin:this.nin,this.stack=e.stack||this.stack,this.altstack=e.altack||this.altstack,this.pc="undefined"!=typeof e.pc?e.pc:this.pc,this.pbegincodehash="undefined"!=typeof e.pbegincodehash?e.pbegincodehash:this.pbegincodehash,this.nOpCount="undefined"!=typeof e.nOpCount?e.nOpCount:this.nOpCount,this.vfExec=e.vfExec||this.vfExec,this.errstr=e.errstr||this.errstr,this.flags="undefined"!=typeof e.flags?e.flags:this.flags},u["true"]=new r([1]),u["false"]=new r([]),u.MAX_SCRIPT_ELEMENT_SIZE=520,u.LOCKTIME_THRESHOLD=5e8,u.LOCKTIME_THRESHOLD_BN=new o(u.LOCKTIME_THRESHOLD),u.SCRIPT_VERIFY_NONE=0,u.SCRIPT_VERIFY_P2SH=1,u.SCRIPT_VERIFY_STRICTENC=2,u.SCRIPT_VERIFY_DERSIG=4,u.SCRIPT_VERIFY_LOW_S=8,u.SCRIPT_VERIFY_NULLDUMMY=16,u.SCRIPT_VERIFY_SIGPUSHONLY=32,u.SCRIPT_VERIFY_MINIMALDATA=64,u.SCRIPT_VERIFY_DISCOURAGE_UPGRADABLE_NOPS=128,u.SCRIPT_VERIFY_CHECKLOCKTIMEVERIFY=512,u.castToBool=function(e){for(var t=0;t<e.length;t++)if(0!==e[t])return t===e.length-1&&128===e[t]?!1:!0;return!1},u.prototype.checkSignatureEncoding=function(e){var t;if(0!==(this.flags&(u.SCRIPT_VERIFY_DERSIG|u.SCRIPT_VERIFY_LOW_S|u.SCRIPT_VERIFY_STRICTENC))&&!f.isTxDER(e))return this.errstr="SCRIPT_ERR_SIG_DER_INVALID_FORMAT",!1;if(0!==(this.flags&u.SCRIPT_VERIFY_LOW_S)){if(t=f.fromTxFormat(e),!t.hasLowS())return this.errstr="SCRIPT_ERR_SIG_DER_HIGH_S",!1}else if(0!==(this.flags&u.SCRIPT_VERIFY_STRICTENC)&&(t=f.fromTxFormat(e),!t.hasDefinedHashtype()))return this.errstr="SCRIPT_ERR_SIG_HASHTYPE",!1;return!0},u.prototype.checkPubkeyEncoding=function(e){return 0===(this.flags&u.SCRIPT_VERIFY_STRICTENC)||c.isValid(e)?!0:(this.errstr="SCRIPT_ERR_PUBKEYTYPE",!1)},u.prototype.evaluate=function(){if(this.script.toBuffer().length>1e4)return this.errstr="SCRIPT_ERR_SCRIPT_SIZE",!1;try{for(;this.pc<this.script.chunks.length;){var e=this.step();if(!e)return!1}if(this.stack.length+this.altstack.length>1e3)return this.errstr="SCRIPT_ERR_STACK_SIZE",!1}catch(t){return this.errstr="SCRIPT_ERR_UNKNOWN_ERROR: "+t,!1}return this.vfExec.length>0?(this.errstr="SCRIPT_ERR_UNBALANCED_CONDITIONAL",!1):!0},u.prototype.checkLockTime=function(e){return this.tx.nLockTime<u.LOCKTIME_THRESHOLD&&e.lt(u.LOCKTIME_THRESHOLD_BN)||this.tx.nLockTime>=u.LOCKTIME_THRESHOLD&&e.gte(u.LOCKTIME_THRESHOLD_BN)?e.gt(new o(this.tx.nLockTime))?!1:this.tx.inputs[this.nin].isFinal()?!0:!1:!1},u.prototype.step=function(){var e,t,r,h,d,p,l,b,g,m,y,v,_,w,S,k,E,I=0!==(this.flags&u.SCRIPT_VERIFY_MINIMALDATA),A=-1===this.vfExec.indexOf(!1),O=this.script.chunks[this.pc];this.pc++;var P=O.opcodenum;if(n.isUndefined(P))return this.errstr="SCRIPT_ERR_UNDEFINED_OPCODE",!1;if(O.buf&&O.buf.length>u.MAX_SCRIPT_ELEMENT_SIZE)return this.errstr="SCRIPT_ERR_PUSH_SIZE",!1;if(P>s.OP_16&&++this.nOpCount>201)return this.errstr="SCRIPT_ERR_OP_COUNT",!1;if(P===s.OP_CAT||P===s.OP_SUBSTR||P===s.OP_LEFT||P===s.OP_RIGHT||P===s.OP_INVERT||P===s.OP_AND||P===s.OP_OR||P===s.OP_XOR||P===s.OP_2MUL||P===s.OP_2DIV||P===s.OP_MUL||P===s.OP_DIV||P===s.OP_MOD||P===s.OP_LSHIFT||P===s.OP_RSHIFT)return this.errstr="SCRIPT_ERR_DISABLED_OPCODE",!1;if(A&&P>=0&&P<=s.OP_PUSHDATA4){if(I&&!this.script.checkMinimalPush(this.pc-1))return this.errstr="SCRIPT_ERR_MINIMALDATA",!1;if(O.buf){if(O.len!==O.buf.length)throw new Error("Length of push value not equal to length of data");this.stack.push(O.buf)}else this.stack.push(u["false"])}else if(A||s.OP_IF<=P&&P<=s.OP_ENDIF)switch(P){case s.OP_1NEGATE:case s.OP_1:case s.OP_2:case s.OP_3:case s.OP_4:case s.OP_5:case s.OP_6:case s.OP_7:case s.OP_8:case s.OP_9:case s.OP_10:case s.OP_11:case s.OP_12:case s.OP_13:case s.OP_14:case s.OP_15:case s.OP_16:d=P-(s.OP_1-1),e=new o(d).toScriptNumBuffer(),this.stack.push(e);break;case s.OP_NOP:break;case s.OP_NOP2:case s.OP_CHECKLOCKTIMEVERIFY:if(!(this.flags&u.SCRIPT_VERIFY_CHECKLOCKTIMEVERIFY)){if(this.flags&u.SCRIPT_VERIFY_DISCOURAGE_UPGRADABLE_NOPS)return this.errstr="SCRIPT_ERR_DISCOURAGE_UPGRADABLE_NOPS",!1;break}if(this.stack.length<1)return this.errstr="SCRIPT_ERR_INVALID_STACK_OPERATION",!1;var B=o.fromScriptNumBuffer(this.stack[this.stack.length-1],I,5);if(B.lt(new o(0)))return this.errstr="SCRIPT_ERR_NEGATIVE_LOCKTIME",!1;if(!this.checkLockTime(B))return this.errstr="SCRIPT_ERR_UNSATISFIED_LOCKTIME",!1;break;case s.OP_NOP1:case s.OP_NOP3:case s.OP_NOP4:case s.OP_NOP5:case s.OP_NOP6:case s.OP_NOP7:case s.OP_NOP8:case s.OP_NOP9:case s.OP_NOP10:if(this.flags&u.SCRIPT_VERIFY_DISCOURAGE_UPGRADABLE_NOPS)return this.errstr="SCRIPT_ERR_DISCOURAGE_UPGRADABLE_NOPS",!1;break;case s.OP_IF:case s.OP_NOTIF:if(k=!1,A){if(this.stack.length<1)return this.errstr="SCRIPT_ERR_UNBALANCED_CONDITIONAL",!1;e=this.stack.pop(),k=u.castToBool(e),P===s.OP_NOTIF&&(k=!k)}this.vfExec.push(k);break;case s.OP_ELSE:if(0===this.vfExec.length)return this.errstr="SCRIPT_ERR_UNBALANCED_CONDITIONAL",!1;this.vfExec[this.vfExec.length-1]=!this.vfExec[this.vfExec.length-1];break;case s.OP_ENDIF:if(0===this.vfExec.length)return this.errstr="SCRIPT_ERR_UNBALANCED_CONDITIONAL",!1;this.vfExec.pop();break;case s.OP_VERIFY:if(this.stack.length<1)return this.errstr="SCRIPT_ERR_INVALID_STACK_OPERATION",!1;if(e=this.stack[this.stack.length-1],k=u.castToBool(e),!k)return this.errstr="SCRIPT_ERR_VERIFY",!1;this.stack.pop();break;case s.OP_RETURN:return this.errstr="SCRIPT_ERR_OP_RETURN",!1;case s.OP_TOALTSTACK:if(this.stack.length<1)return this.errstr="SCRIPT_ERR_INVALID_STACK_OPERATION",!1;this.altstack.push(this.stack.pop());break;case s.OP_FROMALTSTACK:if(this.altstack.length<1)return this.errstr="SCRIPT_ERR_INVALID_ALTSTACK_OPERATION",!1;this.stack.push(this.altstack.pop());break;case s.OP_2DROP:if(this.stack.length<2)return this.errstr="SCRIPT_ERR_INVALID_STACK_OPERATION",!1;this.stack.pop(),this.stack.pop();break;case s.OP_2DUP:if(this.stack.length<2)return this.errstr="SCRIPT_ERR_INVALID_STACK_OPERATION",!1;t=this.stack[this.stack.length-2],r=this.stack[this.stack.length-1],this.stack.push(t),this.stack.push(r);break;case s.OP_3DUP:if(this.stack.length<3)return this.errstr="SCRIPT_ERR_INVALID_STACK_OPERATION",!1;t=this.stack[this.stack.length-3],r=this.stack[this.stack.length-2];var x=this.stack[this.stack.length-1];this.stack.push(t),this.stack.push(r),this.stack.push(x);break;case s.OP_2OVER:if(this.stack.length<4)return this.errstr="SCRIPT_ERR_INVALID_STACK_OPERATION",!1;t=this.stack[this.stack.length-4],r=this.stack[this.stack.length-3],this.stack.push(t),this.stack.push(r);break;case s.OP_2ROT:if(this.stack.length<6)return this.errstr="SCRIPT_ERR_INVALID_STACK_OPERATION",!1;h=this.stack.splice(this.stack.length-6,2),this.stack.push(h[0]),this.stack.push(h[1]);break;case s.OP_2SWAP:if(this.stack.length<4)return this.errstr="SCRIPT_ERR_INVALID_STACK_OPERATION",!1;h=this.stack.splice(this.stack.length-4,2),this.stack.push(h[0]),this.stack.push(h[1]);break;case s.OP_IFDUP:if(this.stack.length<1)return this.errstr="SCRIPT_ERR_INVALID_STACK_OPERATION",!1;e=this.stack[this.stack.length-1],k=u.castToBool(e),k&&this.stack.push(e);break;case s.OP_DEPTH:e=new o(this.stack.length).toScriptNumBuffer(),this.stack.push(e);break;case s.OP_DROP:if(this.stack.length<1)return this.errstr="SCRIPT_ERR_INVALID_STACK_OPERATION",!1;this.stack.pop();break;case s.OP_DUP:if(this.stack.length<1)return this.errstr="SCRIPT_ERR_INVALID_STACK_OPERATION",!1;this.stack.push(this.stack[this.stack.length-1]);break;case s.OP_NIP:if(this.stack.length<2)return this.errstr="SCRIPT_ERR_INVALID_STACK_OPERATION",!1;this.stack.splice(this.stack.length-2,1);break;case s.OP_OVER:if(this.stack.length<2)return this.errstr="SCRIPT_ERR_INVALID_STACK_OPERATION",!1;this.stack.push(this.stack[this.stack.length-2]);break;case s.OP_PICK:case s.OP_ROLL:if(this.stack.length<2)return this.errstr="SCRIPT_ERR_INVALID_STACK_OPERATION",!1;if(e=this.stack[this.stack.length-1],b=o.fromScriptNumBuffer(e,I),d=b.toNumber(),this.stack.pop(),0>d||d>=this.stack.length)return this.errstr="SCRIPT_ERR_INVALID_STACK_OPERATION",!1;e=this.stack[this.stack.length-d-1],P===s.OP_ROLL&&this.stack.splice(this.stack.length-d-1,1),this.stack.push(e);break;case s.OP_ROT:if(this.stack.length<3)return this.errstr="SCRIPT_ERR_INVALID_STACK_OPERATION",!1;p=this.stack[this.stack.length-3],l=this.stack[this.stack.length-2];var R=this.stack[this.stack.length-1];this.stack[this.stack.length-3]=l,this.stack[this.stack.length-2]=R,this.stack[this.stack.length-1]=p;break;case s.OP_SWAP:if(this.stack.length<2)return this.errstr="SCRIPT_ERR_INVALID_STACK_OPERATION",!1;p=this.stack[this.stack.length-2],l=this.stack[this.stack.length-1],this.stack[this.stack.length-2]=l,this.stack[this.stack.length-1]=p;break;case s.OP_TUCK:if(this.stack.length<2)return this.errstr="SCRIPT_ERR_INVALID_STACK_OPERATION",!1;this.stack.splice(this.stack.length-2,0,this.stack[this.stack.length-1]);break;case s.OP_SIZE:if(this.stack.length<1)return this.errstr="SCRIPT_ERR_INVALID_STACK_OPERATION",!1;b=new o(this.stack[this.stack.length-1].length),this.stack.push(b.toScriptNumBuffer());break;case s.OP_EQUAL:case s.OP_EQUALVERIFY:if(this.stack.length<2)return this.errstr="SCRIPT_ERR_INVALID_STACK_OPERATION",!1;t=this.stack[this.stack.length-2],r=this.stack[this.stack.length-1];var T=t.toString("hex")===r.toString("hex");if(this.stack.pop(),this.stack.pop(),this.stack.push(T?u["true"]:u["false"]),P===s.OP_EQUALVERIFY){if(!T)return this.errstr="SCRIPT_ERR_EQUALVERIFY",!1;this.stack.pop()}break;case s.OP_1ADD:case s.OP_1SUB:case s.OP_NEGATE:case s.OP_ABS:case s.OP_NOT:case s.OP_0NOTEQUAL:if(this.stack.length<1)return this.errstr="SCRIPT_ERR_INVALID_STACK_OPERATION",!1;switch(e=this.stack[this.stack.length-1],b=o.fromScriptNumBuffer(e,I),P){case s.OP_1ADD:b=b.add(o.One);break;case s.OP_1SUB:b=b.sub(o.One);break;case s.OP_NEGATE:b=b.neg();break;case s.OP_ABS:b.cmp(o.Zero)<0&&(b=b.neg());break;case s.OP_NOT:b=new o((0===b.cmp(o.Zero))+0);break;case s.OP_0NOTEQUAL:b=new o((0!==b.cmp(o.Zero))+0)}this.stack.pop(),this.stack.push(b.toScriptNumBuffer());break;case s.OP_ADD:case s.OP_SUB:case s.OP_BOOLAND:case s.OP_BOOLOR:case s.OP_NUMEQUAL:case s.OP_NUMEQUALVERIFY:case s.OP_NUMNOTEQUAL:case s.OP_LESSTHAN:case s.OP_GREATERTHAN:case s.OP_LESSTHANOREQUAL:case s.OP_GREATERTHANOREQUAL:case s.OP_MIN:case s.OP_MAX:if(this.stack.length<2)return this.errstr="SCRIPT_ERR_INVALID_STACK_OPERATION",!1;switch(g=o.fromScriptNumBuffer(this.stack[this.stack.length-2],I),m=o.fromScriptNumBuffer(this.stack[this.stack.length-1],I),b=new o(0),P){case s.OP_ADD:b=g.add(m);break;case s.OP_SUB:b=g.sub(m);break;case s.OP_BOOLAND:b=new o((0!==g.cmp(o.Zero)&&0!==m.cmp(o.Zero))+0);break;case s.OP_BOOLOR:b=new o((0!==g.cmp(o.Zero)||0!==m.cmp(o.Zero))+0);break;case s.OP_NUMEQUAL:b=new o((0===g.cmp(m))+0);break;case s.OP_NUMEQUALVERIFY:b=new o((0===g.cmp(m))+0);break;case s.OP_NUMNOTEQUAL:b=new o((0!==g.cmp(m))+0);break;case s.OP_LESSTHAN:b=new o((g.cmp(m)<0)+0);break;case s.OP_GREATERTHAN:b=new o((g.cmp(m)>0)+0);break;case s.OP_LESSTHANOREQUAL:b=new o((g.cmp(m)<=0)+0);break;case s.OP_GREATERTHANOREQUAL:b=new o((g.cmp(m)>=0)+0);break;case s.OP_MIN:b=g.cmp(m)<0?g:m;break;case s.OP_MAX:b=g.cmp(m)>0?g:m}if(this.stack.pop(),this.stack.pop(),this.stack.push(b.toScriptNumBuffer()),P===s.OP_NUMEQUALVERIFY){if(!u.castToBool(this.stack[this.stack.length-1]))return this.errstr="SCRIPT_ERR_NUMEQUALVERIFY",!1;this.stack.pop()}break;case s.OP_WITHIN:if(this.stack.length<3)return this.errstr="SCRIPT_ERR_INVALID_STACK_OPERATION",!1;g=o.fromScriptNumBuffer(this.stack[this.stack.length-3],I),m=o.fromScriptNumBuffer(this.stack[this.stack.length-2],I);var N=o.fromScriptNumBuffer(this.stack[this.stack.length-1],I);k=m.cmp(g)<=0&&g.cmp(N)<0,this.stack.pop(),this.stack.pop(),this.stack.pop(),this.stack.push(k?u["true"]:u["false"]);break;case s.OP_RIPEMD160:case s.OP_SHA1:case s.OP_SHA256:case s.OP_HASH160:case s.OP_HASH256:if(this.stack.length<1)return this.errstr="SCRIPT_ERR_INVALID_STACK_OPERATION",!1;e=this.stack[this.stack.length-1];var C;P===s.OP_RIPEMD160?C=a.ripemd160(e):P===s.OP_SHA1?C=a.sha1(e):P===s.OP_SHA256?C=a.sha256(e):P===s.OP_HASH160?C=a.sha256ripemd160(e):P===s.OP_HASH256&&(C=a.sha256sha256(e)),this.stack.pop(),this.stack.push(C);break;case s.OP_CODESEPARATOR:this.pbegincodehash=this.pc;break;case s.OP_CHECKSIG:case s.OP_CHECKSIGVERIFY:if(this.stack.length<2)return this.errstr="SCRIPT_ERR_INVALID_STACK_OPERATION",!1;y=this.stack[this.stack.length-2],v=this.stack[this.stack.length-1],_=(new i).set({chunks:this.script.chunks.slice(this.pbegincodehash)});var j=(new i).add(y);if(_.findAndDelete(j),!this.checkSignatureEncoding(y)||!this.checkPubkeyEncoding(v))return!1;try{w=f.fromTxFormat(y),S=c.fromBuffer(v,!1),E=this.tx.verifySignature(w,S,this.nin,_)}catch(U){E=!1}if(this.stack.pop(),this.stack.pop(),this.stack.push(E?u["true"]:u["false"]),P===s.OP_CHECKSIGVERIFY){if(!E)return this.errstr="SCRIPT_ERR_CHECKSIGVERIFY",!1;this.stack.pop()}break;case s.OP_CHECKMULTISIG:case s.OP_CHECKMULTISIGVERIFY:var M=1;if(this.stack.length<M)return this.errstr="SCRIPT_ERR_INVALID_STACK_OPERATION",!1;var L=o.fromScriptNumBuffer(this.stack[this.stack.length-M],I).toNumber();if(0>L||L>20)return this.errstr="SCRIPT_ERR_PUBKEY_COUNT",!1;if(this.nOpCount+=L,this.nOpCount>201)return this.errstr="SCRIPT_ERR_OP_COUNT",!1;var D=++M;if(M+=L,this.stack.length<M)return this.errstr="SCRIPT_ERR_INVALID_STACK_OPERATION",!1;var H=o.fromScriptNumBuffer(this.stack[this.stack.length-M],I).toNumber();if(0>H||H>L)return this.errstr="SCRIPT_ERR_SIG_COUNT",!1;var F=++M;if(M+=H,this.stack.length<M)return this.errstr="SCRIPT_ERR_INVALID_STACK_OPERATION",!1;_=(new i).set({chunks:this.script.chunks.slice(this.pbegincodehash)});for(var K=0;H>K;K++)y=this.stack[this.stack.length-F-K],_.findAndDelete((new i).add(y));for(E=!0;E&&H>0;){if(y=this.stack[this.stack.length-F],v=this.stack[this.stack.length-D],!this.checkSignatureEncoding(y)||!this.checkPubkeyEncoding(v))return!1;var z;try{w=f.fromTxFormat(y),S=c.fromBuffer(v,!1),z=this.tx.verifySignature(w,S,this.nin,_)}catch(U){z=!1}z&&(F++,H--),D++,L--,H>L&&(E=!1)}for(;M-->1;)this.stack.pop();if(this.stack.length<1)return this.errstr="SCRIPT_ERR_INVALID_STACK_OPERATION",!1;if(this.flags&u.SCRIPT_VERIFY_NULLDUMMY&&this.stack[this.stack.length-1].length)return this.errstr="SCRIPT_ERR_SIG_NULLDUMMY",!1;if(this.stack.pop(),this.stack.push(E?u["true"]:u["false"]),P===s.OP_CHECKMULTISIGVERIFY){if(!E)return this.errstr="SCRIPT_ERR_CHECKMULTISIGVERIFY",!1;this.stack.pop()}break;default:return this.errstr="SCRIPT_ERR_BAD_OPCODE",!1}return!0}}).call(this,e("buffer").Buffer)},{"../crypto/bn":6,"../crypto/hash":8,"../crypto/signature":11,"../opcode":23,"../publickey":25,"../transaction":29,"./script":28,buffer:46,lodash:194}],28:[function(e,t,r){(function(r){"use strict";var n=e("../address"),i=e("../encoding/bufferreader"),s=e("../encoding/bufferwriter"),o=e("../crypto/hash"),a=e("../opcode"),f=e("../publickey"),c=e("../crypto/signature"),u=e("../networks"),h=e("../util/preconditions"),d=e("lodash"),p=e("../errors"),l=e("buffer"),b=e("../util/buffer"),g=e("../util/js"),m=function y(e){return this instanceof y?(this.chunks=[],b.isBuffer(e)?y.fromBuffer(e):e instanceof n?y.fromAddress(e):e instanceof y?y.fromBuffer(e.toBuffer()):"string"==typeof e?y.fromString(e):void("undefined"!=typeof e&&this.set(e))):new y(e)};m.prototype.set=function(e){return this.chunks=e.chunks||this.chunks,this},m.fromBuffer=function(e){var t=new m;t.chunks=[];for(var r=new i(e);!r.finished();)try{var n,s,o=r.readUInt8();o>0&&o<a.OP_PUSHDATA1?(n=o,t.chunks.push({buf:r.read(n),len:n,opcodenum:o})):o===a.OP_PUSHDATA1?(n=r.readUInt8(),s=r.read(n),t.chunks.push({buf:s,len:n,opcodenum:o})):o===a.OP_PUSHDATA2?(n=r.readUInt16LE(),s=r.read(n),t.chunks.push({buf:s,len:n,opcodenum:o})):o===a.OP_PUSHDATA4?(n=r.readUInt32LE(),s=r.read(n),t.chunks.push({buf:s,len:n,opcodenum:o})):t.chunks.push({opcodenum:o})}catch(f){if(f instanceof RangeError)throw new p.Script.InvalidBuffer(e.toString("hex"));throw f}return t},m.prototype.toBuffer=function(){for(var e=new s,t=0;t<this.chunks.length;t++){var r=this.chunks[t],n=r.opcodenum;e.writeUInt8(r.opcodenum),r.buf&&(n<a.OP_PUSHDATA1?e.write(r.buf):n===a.OP_PUSHDATA1?(e.writeUInt8(r.len),e.write(r.buf)):n===a.OP_PUSHDATA2?(e.writeUInt16LE(r.len),e.write(r.buf)):n===a.OP_PUSHDATA4&&(e.writeUInt32LE(r.len),e.write(r.buf)))}return e.concat()},m.fromString=function(e){if(g.isHexa(e)||0===e.length)return new m(new l.Buffer(e,"hex"));var t=new m;t.chunks=[];for(var n=e.split(" "),i=0;i<n.length;){var s=n[i],o=a(s),f=o.toNumber();if(d.isUndefined(f)){if(f=parseInt(s),!(f>0&&f<a.OP_PUSHDATA1))throw new Error("Invalid script: "+JSON.stringify(e));t.chunks.push({buf:new r(n[i+1].slice(2),"hex"),len:f,opcodenum:f}),i+=2}else if(f===a.OP_PUSHDATA1||f===a.OP_PUSHDATA2||f===a.OP_PUSHDATA4){if("0x"!==n[i+2].slice(0,2))throw new Error("Pushdata data must start with 0x");t.chunks.push({buf:new r(n[i+2].slice(2),"hex"),len:parseInt(n[i+1]),opcodenum:f}),i+=3}else t.chunks.push({opcodenum:f}),i+=1}return t},m.prototype._chunkToString=function(e){var t=e.opcodenum,r="";if(e.buf)(t===a.OP_PUSHDATA1||t===a.OP_PUSHDATA2||t===a.OP_PUSHDATA4)&&(r=r+" "+a(t).toString()),r=r+" "+e.len,e.len>0&&(r=r+" 0x"+e.buf.toString("hex"));else if("undefined"!=typeof a.reverseMap[t])r=r+" "+a(t).toString();
else{var n=t.toString(16);n.length%2!==0&&(n="0"+n),r=r+" 0x"+n}return r},m.prototype.toString=function(){for(var e="",t=0;t<this.chunks.length;t++){var r=this.chunks[t];e+=this._chunkToString(r)}return e.substr(1)},m.prototype.toHex=function(){return this.toBuffer().toString("hex")},m.prototype.inspect=function(){return"<Script: "+this.toString()+">"},m.prototype.isPublicKeyHashOut=function(){return!(5!==this.chunks.length||this.chunks[0].opcodenum!==a.OP_DUP||this.chunks[1].opcodenum!==a.OP_HASH160||!this.chunks[2].buf||20!==this.chunks[2].buf.length||this.chunks[3].opcodenum!==a.OP_EQUALVERIFY||this.chunks[4].opcodenum!==a.OP_CHECKSIG)},m.prototype.isPublicKeyHashIn=function(){if(2===this.chunks.length){var e=this.chunks[0].buf,t=this.chunks[1].buf;if(e&&e.length&&48===e[0]&&t&&t.length){var r=t[0];if((4===r||6===r||7===r)&&65===t.length)return!0;if((3===r||2===r)&&33===t.length)return!0}}return!1},m.prototype.getPublicKeyHash=function(){return h.checkState(this.isPublicKeyHashOut(),"Can't retrieve PublicKeyHash from a non-PKH output"),this.chunks[2].buf},m.prototype.isPublicKeyOut=function(){if(2===this.chunks.length&&this.chunks[0].buf&&this.chunks[0].buf.length&&this.chunks[1].opcodenum===a.OP_CHECKSIG){var e=this.chunks[0].buf,t=e[0],r=!1;if(4!==t&&6!==t&&7!==t||65!==e.length?3!==t&&2!==t||33!==e.length||(r=!0):r=!0,r)return f.isValid(e)}return!1},m.prototype.isPublicKeyIn=function(){return 1===this.chunks.length&&b.isBuffer(this.chunks[0].buf)&&71===this.chunks[0].buf.length},m.prototype.isScriptHashOut=function(){var e=this.toBuffer();return 23===e.length&&e[0]===a.OP_HASH160&&20===e[1]&&e[e.length-1]===a.OP_EQUAL},m.prototype.isScriptHashIn=function(){if(this.chunks.length<=1)return!1;var e=this.chunks[this.chunks.length-1],t=e.buf;if(!t)return!1;var r;try{r=m.fromBuffer(t)}catch(n){if(n instanceof p.Script.InvalidBuffer)return!1;throw n}var i=r.classify();return i!==m.types.UNKNOWN},m.prototype.isMultisigOut=function(){return this.chunks.length>3&&a.isSmallIntOp(this.chunks[0].opcodenum)&&this.chunks.slice(1,this.chunks.length-2).every(function(e){return e.buf&&b.isBuffer(e.buf)})&&a.isSmallIntOp(this.chunks[this.chunks.length-2].opcodenum)&&this.chunks[this.chunks.length-1].opcodenum===a.OP_CHECKMULTISIG},m.prototype.isMultisigIn=function(){return this.chunks.length>=2&&0===this.chunks[0].opcodenum&&this.chunks.slice(1,this.chunks.length).every(function(e){return e.buf&&b.isBuffer(e.buf)&&71===e.buf.length})},m.prototype.isDataOut=function(){return this.chunks.length>=1&&this.chunks[0].opcodenum===a.OP_RETURN&&(1===this.chunks.length||2===this.chunks.length&&this.chunks[1].buf&&this.chunks[1].buf.length<=m.OP_RETURN_STANDARD_SIZE&&this.chunks[1].length===this.chunks.len)},m.prototype.getData=function(){if(this.isDataOut()||this.isScriptHashOut())return new r(d.isUndefined(this.chunks[1])?0:this.chunks[1].buf);if(this.isPublicKeyHashOut())return new r(this.chunks[2].buf);throw new Error("Unrecognized script type to get data from")},m.prototype.isPushOnly=function(){return d.every(this.chunks,function(e){return e.opcodenum<=a.OP_16})},m.types={},m.types.UNKNOWN="Unknown",m.types.PUBKEY_OUT="Pay to public key",m.types.PUBKEY_IN="Spend from public key",m.types.PUBKEYHASH_OUT="Pay to public key hash",m.types.PUBKEYHASH_IN="Spend from public key hash",m.types.SCRIPTHASH_OUT="Pay to script hash",m.types.SCRIPTHASH_IN="Spend from script hash",m.types.MULTISIG_OUT="Pay to multisig",m.types.MULTISIG_IN="Spend from multisig",m.types.DATA_OUT="Data push",m.OP_RETURN_STANDARD_SIZE=80,m.identifiers={},m.identifiers.PUBKEY_OUT=m.prototype.isPublicKeyOut,m.identifiers.PUBKEY_IN=m.prototype.isPublicKeyIn,m.identifiers.PUBKEYHASH_OUT=m.prototype.isPublicKeyHashOut,m.identifiers.PUBKEYHASH_IN=m.prototype.isPublicKeyHashIn,m.identifiers.MULTISIG_OUT=m.prototype.isMultisigOut,m.identifiers.MULTISIG_IN=m.prototype.isMultisigIn,m.identifiers.SCRIPTHASH_OUT=m.prototype.isScriptHashOut,m.identifiers.SCRIPTHASH_IN=m.prototype.isScriptHashIn,m.identifiers.DATA_OUT=m.prototype.isDataOut,m.prototype.classify=function(){for(var e in m.identifiers)if(m.identifiers[e].bind(this)())return m.types[e];return m.types.UNKNOWN},m.prototype.isStandard=function(){return this.classify()!==m.types.UNKNOWN},m.prototype.prepend=function(e){return this._addByType(e,!0),this},m.prototype.equals=function(e){if(h.checkState(e instanceof m,"Must provide another script"),this.chunks.length!==e.chunks.length)return!1;var t;for(t=0;t<this.chunks.length;t++){if(b.isBuffer(this.chunks[t].buf)&&!b.isBuffer(e.chunks[t].buf))return!1;if(b.isBuffer(this.chunks[t].buf)&&!b.equals(this.chunks[t].buf,e.chunks[t].buf))return!1;if(this.chunks[t].opcodenum!==e.chunks[t].opcodenum)return!1}return!0},m.prototype.add=function(e){return this._addByType(e,!1),this},m.prototype._addByType=function(e,t){if("string"==typeof e)this._addOpcode(e,t);else if("number"==typeof e)this._addOpcode(e,t);else if(e instanceof a)this._addOpcode(e,t);else if(b.isBuffer(e))this._addBuffer(e,t);else if(e instanceof m)this.chunks=this.chunks.concat(e.chunks);else{if("object"!=typeof e)throw new Error("Invalid script chunk");this._insertAtPosition(e,t)}},m.prototype._insertAtPosition=function(e,t){t?this.chunks.unshift(e):this.chunks.push(e)},m.prototype._addOpcode=function(e,t){var r;return r="number"==typeof e?e:e instanceof a?e.toNumber():a(e).toNumber(),this._insertAtPosition({opcodenum:r},t),this},m.prototype._addBuffer=function(e,t){var r,n=e.length;if(n>=0&&n<a.OP_PUSHDATA1)r=n;else if(n<Math.pow(2,8))r=a.OP_PUSHDATA1;else if(n<Math.pow(2,16))r=a.OP_PUSHDATA2;else{if(!(n<Math.pow(2,32)))throw new Error("You can't push that much data");r=a.OP_PUSHDATA4}return this._insertAtPosition({buf:e,len:n,opcodenum:r},t),this},m.prototype.removeCodeseparators=function(){for(var e=[],t=0;t<this.chunks.length;t++)this.chunks[t].opcodenum!==a.OP_CODESEPARATOR&&e.push(this.chunks[t]);return this.chunks=e,this},m.buildMultisigOut=function(e,t,r){h.checkArgument(t<=e.length,"Number of required signatures must be less than or equal to the number of public keys"),r=r||{};var n=new m;n.add(a.smallInt(t)),e=d.map(e,f);var i=e;r.noSorting||(i=d.sortBy(e,function(e){return e.toString("hex")}));for(var s=0;s<i.length;s++){var o=i[s];n.add(o.toBuffer())}return n.add(a.smallInt(e.length)),n.add(a.OP_CHECKMULTISIG),n},m.buildP2SHMultisigIn=function(e,t,r,n){h.checkArgument(d.isArray(e)),h.checkArgument(d.isNumber(t)),h.checkArgument(d.isArray(r)),n=n||{};var i=new m;return i.add(a.OP_0),d.each(r,function(e){h.checkArgument(b.isBuffer(e),"Signatures must be an array of Buffers"),i.add(e)}),i.add((n.cachedMultisig||m.buildMultisigOut(e,t,n)).toBuffer()),i},m.buildPublicKeyHashOut=function(e){h.checkArgument(!d.isUndefined(e)),h.checkArgument(e instanceof f||e instanceof n||d.isString(e)),e instanceof f?e=e.toAddress():d.isString(e)&&(e=new n(e));var t=new m;return t.add(a.OP_DUP).add(a.OP_HASH160).add(e.hashBuffer).add(a.OP_EQUALVERIFY).add(a.OP_CHECKSIG),t._network=e.network,t},m.buildPublicKeyOut=function(e){h.checkArgument(e instanceof f);var t=new m;return t.add(e.toBuffer()).add(a.OP_CHECKSIG),t},m.buildDataOut=function(e){h.checkArgument(d.isUndefined(e)||d.isString(e)||b.isBuffer(e)),"string"==typeof e&&(e=new r(e));var t=new m;return t.add(a.OP_RETURN),d.isUndefined(e)||t.add(e),t},m.buildScriptHashOut=function(e){h.checkArgument(e instanceof m||e instanceof n&&e.isPayToScriptHash());var t=new m;return t.add(a.OP_HASH160).add(e instanceof n?e.hashBuffer:o.sha256ripemd160(e.toBuffer())).add(a.OP_EQUAL),t._network=e._network||e.network,t},m.buildPublicKeyHashIn=function(e,t,r){h.checkArgument(t instanceof c||b.isBuffer(t)),h.checkArgument(d.isUndefined(r)||d.isNumber(r)),t instanceof c&&(t=t.toBuffer());var n=(new m).add(b.concat([t,b.integerAsSingleByteBuffer(r||c.SIGHASH_ALL)])).add(new f(e).toBuffer());return n},m.empty=function(){return new m},m.prototype.toScriptHashOut=function(){return m.buildScriptHashOut(this)},m.fromAddress=function(e){if(e=n(e),e.isPayToScriptHash())return m.buildScriptHashOut(e);if(e.isPayToPublicKeyHash())return m.buildPublicKeyHashOut(e);throw new p.Script.UnrecognizedAddress(e)},m.prototype.getAddressInfo=function(e){if(this._isInput)return this._getInputAddressInfo();if(this._isOutput)return this._getOutputAddressInfo();var t=this._getOutputAddressInfo();return t?t:this._getInputAddressInfo()},m.prototype._getOutputAddressInfo=function(){var e={};if(this.isScriptHashOut())e.hashBuffer=this.getData(),e.type=n.PayToScriptHash;else{if(!this.isPublicKeyHashOut())return!1;e.hashBuffer=this.getData(),e.type=n.PayToPublicKeyHash}return e},m.prototype._getInputAddressInfo=function(){var e={};if(this.isPublicKeyHashIn())e.hashBuffer=o.sha256ripemd160(this.chunks[1].buf),e.type=n.PayToPublicKeyHash;else{if(!this.isScriptHashIn())return!1;e.hashBuffer=o.sha256ripemd160(this.chunks[this.chunks.length-1].buf),e.type=n.PayToScriptHash}return e},m.prototype.toAddress=function(e){var t=this.getAddressInfo();return t?(t.network=u.get(e)||this._network||u.defaultNetwork,new n(t)):!1},m.prototype.findAndDelete=function(e){for(var t=e.toBuffer(),r=t.toString("hex"),n=0;n<this.chunks.length;n++){var i=m({chunks:[this.chunks[n]]}),s=i.toBuffer(),o=s.toString("hex");r===o&&this.chunks.splice(n,1)}return this},m.prototype.checkMinimalPush=function(e){var t=this.chunks[e],r=t.buf,n=t.opcodenum;return r?0===r.length?n===a.OP_0:1===r.length&&r[0]>=1&&r[0]<=16?n===a.OP_1+(r[0]-1):1===r.length&&129===r[0]?n===a.OP_1NEGATE:r.length<=75?n===r.length:r.length<=255?n===a.OP_PUSHDATA1:r.length<=65535?n===a.OP_PUSHDATA2:!0:!0},m.prototype._decodeOP_N=function(e){if(e===a.OP_0)return 0;if(e>=a.OP_1&&e<=a.OP_16)return e-(a.OP_1-1);throw new Error("Invalid opcode: "+JSON.stringify(e))},m.prototype.getSignatureOperationsCount=function(e){e=d.isUndefined(e)?!0:e;var t=this,r=0,n=a.OP_INVALIDOPCODE;return d.each(t.chunks,function(i){var s=i.opcodenum;s==a.OP_CHECKSIG||s==a.OP_CHECKSIGVERIFY?r++:(s==a.OP_CHECKMULTISIG||s==a.OP_CHECKMULTISIGVERIFY)&&(r+=e&&n>=a.OP_1&&n<=a.OP_16?t._decodeOP_N(n):20),n=s}),r},t.exports=m}).call(this,e("buffer").Buffer)},{"../address":1,"../crypto/hash":8,"../crypto/signature":11,"../encoding/bufferreader":14,"../encoding/bufferwriter":15,"../errors":17,"../networks":22,"../opcode":23,"../publickey":25,"../util/buffer":41,"../util/js":42,"../util/preconditions":43,buffer:46,lodash:194}],29:[function(e,t,r){t.exports=e("./transaction"),t.exports.Input=e("./input"),t.exports.Output=e("./output"),t.exports.UnspentOutput=e("./unspentoutput"),t.exports.Signature=e("./signature")},{"./input":30,"./output":34,"./signature":36,"./transaction":37,"./unspentoutput":38}],30:[function(e,t,r){t.exports=e("./input"),t.exports.PublicKeyHash=e("./publickeyhash"),t.exports.MultiSigScriptHash=e("./multisigscripthash.js")},{"./input":31,"./multisigscripthash.js":32,"./publickeyhash":33}],31:[function(e,t,r){"use strict";function n(e){return this instanceof n?e?this._fromObject(e):void 0:new n(e)}var i=e("lodash"),s=e("../../util/preconditions"),o=e("../../errors"),a=e("../../encoding/bufferwriter"),f=e("buffer"),c=e("../../util/buffer"),u=e("../../util/js"),h=e("../../script"),d=e("../sighash"),p=e("../output"),l=4294967295;n.DEFAULT_SEQNUMBER=l,Object.defineProperty(n.prototype,"script",{configurable:!1,enumerable:!0,get:function(){return this.isNull()?null:(this._script||(this._script=new h(this._scriptBuffer),this._script._isInput=!0),this._script)}}),n.prototype._fromObject=function(e){if(i.isString(e.prevTxId)&&u.isHexa(e.prevTxId)&&(e.prevTxId=new f.Buffer(e.prevTxId,"hex")),this.output=e.output?e.output instanceof p?e.output:new p(e.output):void 0,this.prevTxId=e.prevTxId||e.txidbuf,this.outputIndex=i.isUndefined(e.outputIndex)?e.txoutnum:e.outputIndex,this.sequenceNumber=i.isUndefined(e.sequenceNumber)?i.isUndefined(e.seqnum)?l:e.seqnum:e.sequenceNumber,i.isUndefined(e.script)&&i.isUndefined(e.scriptBuffer))throw new o.Transaction.Input.MissingScript;return this.setScript(e.scriptBuffer||e.script),this},n.prototype.toObject=function(){var e={prevTxId:this.prevTxId.toString("hex"),outputIndex:this.outputIndex,sequenceNumber:this.sequenceNumber,script:this._scriptBuffer.toString("hex")};return this.script&&(e.scriptString=this.script.toString()),this.output&&(e.output=this.output.toObject()),e},n.fromObject=function(e){s.checkArgument(i.isObject(e));var t=new n;return t._fromObject(e)},n.prototype.toJSON=function(){return JSON.stringify(this.toObject())},n.fromJSON=function(e){return s.checkArgument(u.isValidJSON(e),"Invalid JSON provided to Input.fromJSON"),n.fromObject(JSON.parse(e))},n.fromBufferReader=function(e){var t=new n;return t.prevTxId=e.readReverse(32),t.outputIndex=e.readUInt32LE(),t._scriptBuffer=e.readVarLengthBuffer(),t.sequenceNumber=e.readUInt32LE(),t},n.prototype.toBufferWriter=function(e){e||(e=new a),e.writeReverse(this.prevTxId),e.writeUInt32LE(this.outputIndex);var t=this._scriptBuffer;return e.writeVarintNum(t.length),e.write(t),e.writeUInt32LE(this.sequenceNumber),e},n.prototype.setScript=function(e){if(this._script=null,e instanceof h)this._script=e,this._script._isInput=!0,this._scriptBuffer=e.toBuffer();else if(u.isHexa(e))this._scriptBuffer=new f.Buffer(e,"hex");else if(i.isString(e))this._script=new h(e),this._script._isInput=!0,this._scriptBuffer=this._script.toBuffer();else{if(!c.isBuffer(e))throw new TypeError("Invalid argument type: script");this._scriptBuffer=new f.Buffer(e)}return this},n.prototype.getSignatures=function(){throw new o.AbstractMethodInvoked("Trying to sign unsupported output type (only P2PKH and P2SH multisig inputs are supported) for input: "+this.toJSON())},n.prototype.isFullySigned=function(){throw new o.AbstractMethodInvoked("Input#isFullySigned")},n.prototype.isFinal=function(){return 4294967295!==this.sequenceNumber},n.prototype.addSignature=function(){throw new o.AbstractMethodInvoked("Input#addSignature")},n.prototype.clearSignatures=function(){throw new o.AbstractMethodInvoked("Input#clearSignatures")},n.prototype.isValidSignature=function(e,t){return t.signature.nhashtype=t.sigtype,d.verify(e,t.signature,t.publicKey,t.inputIndex,this.output.script)},n.prototype.isNull=function(){return"0000000000000000000000000000000000000000000000000000000000000000"===this.prevTxId.toString("hex")&&4294967295===this.outputIndex},n.prototype._estimateSize=function(){return this.toBufferWriter().toBuffer().length},t.exports=n},{"../../encoding/bufferwriter":15,"../../errors":17,"../../script":26,"../../util/buffer":41,"../../util/js":42,"../../util/preconditions":43,"../output":34,"../sighash":35,buffer:46,lodash:194}],32:[function(e,t,r){"use strict";function n(e,t,r,n){o.apply(this,arguments);var s=this;t=t||e.publicKeys,r=r||e.threshold,n=n||e.signatures,this.publicKeys=i.sortBy(t,function(e){return e.toString("hex")}),this.redeemScript=c.buildMultisigOut(this.publicKeys,r),f.checkState(c.buildScriptHashOut(this.redeemScript).equals(this.output.script),"Provided public keys don't hash to the provided output"),this.publicKeyIndex={},i.each(this.publicKeys,function(e,t){s.publicKeyIndex[e.toString()]=t}),this.threshold=r,this.signatures=n?this._deserializeSignatures(n):new Array(this.publicKeys.length)}var i=e("lodash"),s=e("inherits"),o=e("./input"),a=e("../output"),f=e("../../util/preconditions"),c=e("../../script"),u=e("../../crypto/signature"),h=e("../sighash"),d=(e("../../publickey"),e("../../util/buffer")),p=e("../signature");s(n,o),n.prototype.toObject=function(){var e=o.prototype.toObject.apply(this,arguments);return e.threshold=this.threshold,e.publicKeys=i.map(this.publicKeys,function(e){return e.toString()}),e.signatures=this._serializeSignatures(),e},n.prototype._deserializeSignatures=function(e){return i.map(e,function(e){return e?new p(e):void 0})},n.prototype._serializeSignatures=function(){return i.map(this.signatures,function(e){return e?e.toObject():void 0})},n.prototype.getSignatures=function(e,t,r,n){f.checkState(this.output instanceof a),n=n||u.SIGHASH_ALL;var s=this,o=[];return i.each(this.publicKeys,function(i){i.toString()===t.publicKey.toString()&&o.push(new p({publicKey:t.publicKey,prevTxId:s.prevTxId,outputIndex:s.outputIndex,inputIndex:r,signature:h.sign(e,t,n,r,s.redeemScript),sigtype:n}))}),o},n.prototype.addSignature=function(e,t){return f.checkState(!this.isFullySigned(),"All needed signatures have already been added"),f.checkArgument(!i.isUndefined(this.publicKeyIndex[t.publicKey.toString()]),"Signature has no matching public key"),f.checkState(this.isValidSignature(e,t)),this.signatures[this.publicKeyIndex[t.publicKey.toString()]]=t,this._updateScript(),this},n.prototype._updateScript=function(){return this.setScript(c.buildP2SHMultisigIn(this.publicKeys,this.threshold,this._createSignatures(),{cachedMultisig:this.redeemScript})),this},n.prototype._createSignatures=function(){return i.map(i.filter(this.signatures,function(e){return!i.isUndefined(e)}),function(e){return d.concat([e.signature.toDER(),d.integerAsSingleByteBuffer(e.sigtype)])})},n.prototype.clearSignatures=function(){this.signatures=new Array(this.publicKeys.length),this._updateScript()},n.prototype.isFullySigned=function(){return this.countSignatures()===this.threshold},n.prototype.countMissingSignatures=function(){return this.threshold-this.countSignatures()},n.prototype.countSignatures=function(){return i.reduce(this.signatures,function(e,t){return e+!!t},0)},n.prototype.publicKeysWithoutSignature=function(){var e=this;return i.filter(this.publicKeys,function(t){return!e.signatures[e.publicKeyIndex[t.toString()]]})},n.prototype.isValidSignature=function(e,t){return t.signature.nhashtype=t.sigtype,h.verify(e,t.signature,t.publicKey,t.inputIndex,this.redeemScript)},n.OPCODES_SIZE=7,n.SIGNATURE_SIZE=74,n.PUBKEY_SIZE=34,n.prototype._estimateSize=function(){return n.OPCODES_SIZE+this.threshold*n.SIGNATURE_SIZE+this.publicKeys.length*n.PUBKEY_SIZE},t.exports=n},{"../../crypto/signature":11,"../../publickey":25,"../../script":26,"../../util/buffer":41,"../../util/preconditions":43,"../output":34,"../sighash":35,"../signature":36,"./input":31,inherits:193,lodash:194}],33:[function(e,t,r){"use strict";function n(){f.apply(this,arguments)}var i=e("inherits"),s=e("../../util/preconditions"),o=e("../../util/buffer"),a=e("../../crypto/hash"),f=e("./input"),c=e("../output"),u=e("../sighash"),h=e("../../script"),d=e("../../crypto/signature"),p=e("../signature");i(n,f),n.prototype.getSignatures=function(e,t,r,n,i){return s.checkState(this.output instanceof c),i=i||a.sha256ripemd160(t.publicKey.toBuffer()),n=n||d.SIGHASH_ALL,o.equals(i,this.output.script.getPublicKeyHash())?[new p({publicKey:t.publicKey,prevTxId:this.prevTxId,outputIndex:this.outputIndex,inputIndex:r,signature:u.sign(e,t,n,r,this.output.script),sigtype:n})]:[]},n.prototype.addSignature=function(e,t){return s.checkState(this.isValidSignature(e,t),"Signature is invalid"),this.setScript(h.buildPublicKeyHashIn(t.publicKey,t.signature.toDER(),t.sigtype)),this},n.prototype.clearSignatures=function(){return this.setScript(h.empty()),this},n.prototype.isFullySigned=function(){return this.script.isPublicKeyHashIn()},n.SCRIPT_MAX_SIZE=107,n.prototype._estimateSize=function(){return n.SCRIPT_MAX_SIZE},t.exports=n},{"../../crypto/hash":8,"../../crypto/signature":11,"../../script":26,"../../util/buffer":41,"../../util/preconditions":43,"../output":34,"../sighash":35,"../signature":36,"./input":31,inherits:193}],34:[function(e,t,r){"use strict";function n(e){if(!(this instanceof n))return new n(e);if(!i.isObject(e)){if(f.isValidJSON(e))return n.fromJSON(e);throw new TypeError("Unrecognized argument for Output")}this.satoshis=e.satoshis,a.isBuffer(e.script)?this._scriptBuffer=e.script:(i.isString(e.script)&&f.isHexa(e.script)&&(e.script=new o.Buffer(e.script,"hex")),this.setScript(e.script))}var i=e("lodash"),s=e("../crypto/bn"),o=e("buffer"),a=e("../util/buffer"),f=e("../util/js"),c=e("../encoding/bufferwriter"),u=e("../script"),h=e("../util/preconditions"),d=e("../errors"),p=9007199254740991;Object.defineProperty(n.prototype,"script",{configurable:!1,enumerable:!0,get:function(){return this._script?this._script:(this.setScriptFromBuffer(this._scriptBuffer),this._script)}}),Object.defineProperty(n.prototype,"satoshis",{configurable:!1,enumerable:!0,get:function(){return this._satoshis},set:function(e){e instanceof s?(this._satoshisBN=e,this._satoshis=e.toNumber()):i.isString(e)?(this._satoshis=parseInt(e),this._satoshisBN=s.fromNumber(this._satoshis)):(h.checkArgument(f.isNaturalNumber(e),"Output satoshis is not a natural number"),this._satoshisBN=s.fromNumber(e),this._satoshis=e),h.checkState(f.isNaturalNumber(this._satoshis),"Output satoshis is not a natural number")}}),n.prototype.invalidSatoshis=function(){return this._satoshis>p?"transaction txout satoshis greater than max safe integer":this._satoshis!==this._satoshisBN.toNumber()?"transaction txout satoshis has corrupted value":this._satoshis<0?"transaction txout negative":!1},n.prototype.toObject=function(){var e={satoshis:this.satoshis};return e.script=this._scriptBuffer.toString("hex"),e},n.prototype.toJSON=function(){return JSON.stringify(this.toObject())},n.fromJSON=function(e){h.checkArgument(f.isValidJSON(e),"data must be valid JSON");var t=JSON.parse(e);return new n({satoshis:Number(t.satoshis),script:new u(t.script)})},n.prototype.setScriptFromBuffer=function(e){this._scriptBuffer=e;try{this._script=u.fromBuffer(this._scriptBuffer),this._script._isOutput=!0}catch(t){if(!(t instanceof d.Script.InvalidBuffer))throw t;this._script=null}},n.prototype.setScript=function(e){if(e instanceof u)this._scriptBuffer=e.toBuffer(),this._script=e,this._script._isOutput=!0;else if(i.isString(e))this._script=u.fromString(e),this._scriptBuffer=this._script.toBuffer(),this._script._isOutput=!0;else{if(!a.isBuffer(e))throw new TypeError("Invalid argument type: script");this.setScriptFromBuffer(e)}return this},n.prototype.inspect=function(){var e;return e=this.script?this.script.inspect():this._scriptBuffer.toString("hex"),"<Output ("+this.satoshis+" sats) "+e+">"},n.fromBufferReader=function(e){var t={};t.satoshis=e.readUInt64LEBN();var r=e.readVarintNum();return t.script=0!==r?e.read(r):new o.Buffer([]),new n(t)},n.prototype.toBufferWriter=function(e){e||(e=new c),e.writeUInt64LEBN(this._satoshisBN);var t=this._scriptBuffer;return e.writeVarintNum(t.length),e.write(t),e},t.exports=n},{"../crypto/bn":6,"../encoding/bufferwriter":15,"../errors":17,"../script":26,"../util/buffer":41,"../util/js":42,"../util/preconditions":43,buffer:46,lodash:194}],35:[function(e,t,r){(function(r){"use strict";function n(e,t,r,n,i){var s=y(e,r,n,i),o=p.sign(s,t,"little").set({nhashtype:r});return o}function i(e,t,r,n,i){l.checkArgument(!b.isUndefined(e)),l.checkArgument(!b.isUndefined(t)&&!b.isUndefined(t.nhashtype));var s=y(e,t.nhashtype,n,i);return p.verify(s,t,r,"little")}var s=e("buffer"),o=e("../crypto/signature"),a=e("../script"),f=e("./output"),c=e("../encoding/bufferreader"),u=e("../encoding/bufferwriter"),h=e("../crypto/bn"),d=e("../crypto/hash"),p=e("../crypto/ecdsa"),l=e("../util/preconditions"),b=e("lodash"),g="0000000000000000000000000000000000000000000000000000000000000001",m="ffffffffffffffff",y=function(t,n,i,p){var l,b=e("./transaction"),y=e("./input"),v=b.shallowCopy(t);for(p=new a(p),p.removeCodeseparators(),l=0;l<v.inputs.length;l++)v.inputs[l]=new y(v.inputs[l]).setScript(a.empty());if(v.inputs[i]=new y(v.inputs[i]).setScript(p),(31&n)===o.SIGHASH_NONE||(31&n)===o.SIGHASH_SINGLE)for(l=0;l<v.inputs.length;l++)l!==i&&(v.inputs[l].sequenceNumber=0);if((31&n)===o.SIGHASH_NONE)v.outputs=[];else if((31&n)===o.SIGHASH_SINGLE){if(i>=v.outputs.length)return new r(g,"hex");for(v.outputs.length=i+1,l=0;i>l;l++)v.outputs[l]=new f({satoshis:h.fromBuffer(new s.Buffer(m,"hex")),script:a.empty()})}n&o.SIGHASH_ANYONECANPAY&&(v.inputs=[v.inputs[i]]);var _=(new u).write(v.toBuffer()).writeInt32LE(n).toBuffer(),w=d.sha256sha256(_);return w=new c(w).readReverse()};t.exports={sighash:y,sign:n,verify:i}}).call(this,e("buffer").Buffer)},{"../crypto/bn":6,"../crypto/ecdsa":7,"../crypto/hash":8,"../crypto/signature":11,"../encoding/bufferreader":14,"../encoding/bufferwriter":15,"../script":26,"../util/preconditions":43,"./input":30,"./output":34,"./transaction":37,buffer:46,lodash:194}],36:[function(e,t,r){(function(r){"use strict";function n(e){if(!(this instanceof n))return new n(e);if(e instanceof n)return e;if(i.isString(e)&&f.isValidJSON(e))return n.fromJSON(e);if(i.isObject(e))return this._fromObject(e);throw new u.InvalidArgument("TransactionSignatures must be instantiated from an object")}var i=e("lodash"),s=e("../util/preconditions"),o=e("inherits"),a=e("../util/buffer"),f=e("../util/js"),c=e("../publickey"),u=e("../errors"),h=e("../crypto/signature");o(n,h),n.prototype._fromObject=function(e){return this._checkObjectArgs(e),this.publicKey=new c(e.publicKey),this.prevTxId=a.isBuffer(e.prevTxId)?e.prevTxId:new r(e.prevTxId,"hex"),this.outputIndex=e.outputIndex,this.inputIndex=e.inputIndex,this.signature=e.signature instanceof h?e.signature:a.isBuffer(e.signature)?h.fromBuffer(e.signature):h.fromString(e.signature),this.sigtype=e.sigtype,this},n.prototype._checkObjectArgs=function(e){s.checkArgument(c(e.publicKey),"publicKey"),s.checkArgument(!i.isUndefined(e.inputIndex),"inputIndex"),s.checkArgument(!i.isUndefined(e.outputIndex),"outputIndex"),s.checkState(i.isNumber(e.inputIndex),"inputIndex must be a number"),s.checkState(i.isNumber(e.outputIndex),"outputIndex must be a number"),s.checkArgument(e.signature,"signature"),s.checkArgument(e.prevTxId,"prevTxId"),s.checkState(e.signature instanceof h||a.isBuffer(e.signature)||f.isHexa(e.signature),"signature must be a buffer or hexa value"),s.checkState(a.isBuffer(e.prevTxId)||f.isHexa(e.prevTxId),"prevTxId must be a buffer or hexa value"),s.checkArgument(e.sigtype,"sigtype"),s.checkState(i.isNumber(e.sigtype),"sigtype must be a number")},n.prototype.toObject=function(){return{publicKey:this.publicKey.toString(),prevTxId:this.prevTxId.toString("hex"),outputIndex:this.outputIndex,inputIndex:this.inputIndex,signature:this.signature.toString(),sigtype:this.sigtype}},n.prototype.toJSON=function(){return JSON.stringify(this.toObject())},n.fromJSON=function(e){return new n(JSON.parse(e))},n.fromObject=function(e){return s.checkArgument(e),new n(e)},t.exports=n}).call(this,e("buffer").Buffer)},{"../crypto/signature":11,"../errors":17,"../publickey":25,"../util/buffer":41,"../util/js":42,"../util/preconditions":43,buffer:46,inherits:193,lodash:194}],37:[function(e,t,r){"use strict";function n(e){if(!(this instanceof n))return new n(e);if(this.inputs=[],this.outputs=[],this._inputAmount=void 0,this._outputAmount=void 0,e){if(e instanceof n)return n.shallowCopy(e);if(c.isHexa(e))this.fromString(e);else if(c.isValidJSON(e))this.fromJSON(e);else if(f.isBuffer(e))this.fromBuffer(e);else{if(!i.isObject(e))throw new a.InvalidArgument("Must provide an object or string to deserialize a transaction");this.fromObject(e)}}else this._newTransaction()}var i=e("lodash"),s=e("../util/preconditions"),o=e("buffer"),a=e("../errors"),f=e("../util/buffer"),c=e("../util/js"),u=e("../encoding/bufferreader"),h=e("../encoding/bufferwriter"),d=e("../crypto/hash"),p=e("../crypto/signature"),l=e("./sighash"),b=e("../address"),g=e("./unspentoutput"),m=e("./input"),y=m.PublicKeyHash,v=m.MultiSigScriptHash,_=e("./output"),w=e("../script"),S=e("../privatekey"),k=e("../crypto/bn"),E=1,I=0,A=1e6;n.DUST_AMOUNT=546,n.FEE_SECURITY_MARGIN=15,n.MAX_MONEY=21e14,n.NLOCKTIME_BLOCKHEIGHT_LIMIT=5e8,n.NLOCKTIME_MAX_VALUE=4294967295,n.FEE_PER_KB=1e4,n.CHANGE_OUTPUT_MAX_SIZE=62,n.MAXIMUM_EXTRA_SIZE=26,n.shallowCopy=function(e){var t=new n(e.toBuffer());return t};var O={configurable:!1,enumerable:!0,get:function(){return new u(this._getHash()).readReverse().toString("hex")}};Object.defineProperty(n.prototype,"hash",O),Object.defineProperty(n.prototype,"id",O);var P={configurable:!1,enumerable:!0,get:function(){return this._getInputAmount()}};Object.defineProperty(n.prototype,"inputAmount",P),P.get=function(){return this._getOutputAmount()},Object.defineProperty(n.prototype,"outputAmount",P),n.prototype._getHash=function(){return d.sha256sha256(this.toBuffer())},n.prototype.serialize=function(e){return!0===e||e&&e.disableAll?this.uncheckedSerialize():this.checkedSerialize(e)},n.prototype.uncheckedSerialize=n.prototype.toString=function(){return this.toBuffer().toString("hex")},n.prototype.checkedSerialize=function(e){var t=this.getSerializationError(e);if(t)throw t.message+=" Use Transaction#uncheckedSerialize if you want to skip security checks. See http://bitcore.io/guide/transaction.html#Serialization for more info.",t;return this.uncheckedSerialize()},n.prototype.invalidSatoshis=function(){for(var e=!1,t=0;t<this.outputs.length;t++)this.outputs[t].invalidSatoshis()&&(e=!0);return e},n.prototype.getSerializationError=function(e){if(e=e||{},this.invalidSatoshis())return new a.Transaction.InvalidSatoshis;var t,r=this._getUnspentValue();return 0>r?e.disableMoreOutputThanInput||(t=new a.Transaction.InvalidOutputAmountSum):t=this._hasFeeError(e,r),t||this._hasDustOutputs(e)||this._isMissingSignatures(e)},n.prototype._hasFeeError=function(e,t){if(!i.isUndefined(this._fee)&&this._fee!==t)return new a.Transaction.FeeError.Different("Unspent value is "+t+" but specified fee is "+this._fee);if(!e.disableLargeFees){var r=Math.floor(n.FEE_SECURITY_MARGIN*this._estimateFee());if(t>r)return this._missingChange()?new a.Transaction.ChangeAddressMissing("Fee is too large and no change address was provided"):new a.Transaction.FeeError.TooLarge("expected less than "+r+" but got "+t)}if(!e.disableSmallFees){var s=Math.ceil(this._estimateFee()/n.FEE_SECURITY_MARGIN);if(s>t)return new a.Transaction.FeeError.TooSmall("expected more than "+s+" but got "+t)}},n.prototype._missingChange=function(){return!this._changeScript},n.prototype._hasDustOutputs=function(e){if(!e.disableDustOutputs){var t,r;for(t in this.outputs)if(r=this.outputs[t],r.satoshis<n.DUST_AMOUNT&&!r.script.isDataOut())return new a.Transaction.DustOutputs}},n.prototype._isMissingSignatures=function(e){return e.disableIsFullySigned?void 0:this.isFullySigned()?void 0:new a.Transaction.MissingSignatures},n.prototype.inspect=function(){return"<Transaction: "+this.uncheckedSerialize()+">"},n.prototype.toBuffer=function(){var e=new h;return this.toBufferWriter(e).toBuffer()},n.prototype.toBufferWriter=function(e){return e.writeUInt32LE(this.version),e.writeVarintNum(this.inputs.length),i.each(this.inputs,function(t){t.toBufferWriter(e)}),e.writeVarintNum(this.outputs.length),i.each(this.outputs,function(t){t.toBufferWriter(e)}),e.writeUInt32LE(this.nLockTime),e},n.prototype.fromBuffer=function(e){var t=new u(e);return this.fromBufferReader(t)},n.prototype.fromBufferReader=function(e){s.checkArgument(!e.finished(),"No transaction data received");var t,r,n;for(this.version=e.readUInt32LE(),r=e.readVarintNum(),t=0;r>t;t++){var i=m.fromBufferReader(e);this.inputs.push(i)}for(n=e.readVarintNum(),t=0;n>t;t++)this.outputs.push(_.fromBufferReader(e));return this.nLockTime=e.readUInt32LE(),this},n.prototype.fromJSON=function(e){return c.isValidJSON(e)&&(e=JSON.parse(e)),this.fromObject(e)},n.prototype.toObject=function(){var e=[];this.inputs.forEach(function(t){e.push(t.toObject())});var t=[];this.outputs.forEach(function(e){t.push(e.toObject())});var r={version:this.version,inputs:e,outputs:t,nLockTime:this.nLockTime};return this._changeScript&&(r.changeScript=this._changeScript.toString()),i.isUndefined(this._changeIndex)||(r.changeIndex=this._changeIndex),i.isUndefined(this._fee)||(r.fee=this._fee),r},n.prototype.fromObject=function(e){var t=this;return e instanceof n&&(e=e.toObject()),i.each(e.inputs,function(e){if(!e.output||!e.output.script)return void t.uncheckedAddInput(new m(e));e.output.script=new w(e.output.script);var r;if(e.output.script.isPublicKeyHashOut())r=new m.PublicKeyHash(e);
else{if(!(e.output.script.isScriptHashOut()&&e.publicKeys&&e.threshold))throw new a.Transaction.Input.UnsupportedScript(e.output.script);r=new m.MultiSigScriptHash(e,e.publicKeys,e.threshold,e.signatures)}t.addInput(r)}),i.each(e.outputs,function(e){t.addOutput(new _(e))}),e.changeIndex&&(this._changeIndex=e.changeIndex),e.changeScript&&(this._changeScript=new w(e.changeScript)),e.fee&&this.fee(e.fee),this.nLockTime=e.nLockTime,this.version=e.version,this._checkConsistency(),this},n.prototype._checkConsistency=function(){i.isUndefined(this._changeIndex)||(s.checkState(this._changeScript),s.checkState(this.outputs[this._changeIndex]),s.checkState(this.outputs[this._changeIndex].script.toString()===this._changeScript.toString()))},n.prototype.lockUntilDate=function(e){if(s.checkArgument(e),i.isNumber(e)&&e<n.NLOCKTIME_BLOCKHEIGHT_LIMIT)throw new a.Transaction.LockTimeTooEarly;return i.isDate(e)&&(e=e.getTime()/1e3),this.nLockTime=e,this},n.prototype.lockUntilBlockHeight=function(e){if(s.checkArgument(i.isNumber(e)),e>=n.NLOCKTIME_BLOCKHEIGHT_LIMIT)throw new a.Transaction.BlockHeightTooHigh;if(0>e)throw new a.Transaction.NLockTimeOutOfRange;return this.nLockTime=e,this},n.prototype.getLockTime=function(){return this.nLockTime?this.nLockTime<n.NLOCKTIME_BLOCKHEIGHT_LIMIT?this.nLockTime:new Date(1e3*this.nLockTime):null},n.prototype.toJSON=function(){return JSON.stringify(this.toObject())},n.prototype.fromString=function(e){this.fromBuffer(new o.Buffer(e,"hex"))},n.prototype._newTransaction=function(){this.version=E,this.nLockTime=I},n.prototype.from=function(e,t,r){if(i.isArray(e)){var n=this;return i.each(e,function(e){n.from(e,t,r)}),this}var s=i.any(this.inputs,function(t){return t.prevTxId.toString("hex")===e.txId&&t.outputIndex===e.outputIndex});if(!s)return t&&r?this._fromMultisigUtxo(e,t,r):this._fromNonP2SH(e),this},n.prototype._fromNonP2SH=function(e){var t;e=new g(e),t=e.script.isPublicKeyHashOut()?y:m,this.addInput(new t({output:new _({script:e.script,satoshis:e.satoshis}),prevTxId:e.txId,outputIndex:e.outputIndex,script:w.empty()}))},n.prototype._fromMultisigUtxo=function(e,t,r){s.checkArgument(r<=t.length,"Number of required signatures must be greater than the number of public keys"),e=new g(e),this.addInput(new v({output:new _({script:e.script,satoshis:e.satoshis}),prevTxId:e.txId,outputIndex:e.outputIndex,script:w.empty()},t,r))},n.prototype.addInput=function(e,t,r){if(s.checkArgumentType(e,m,"input"),!e.output&&(i.isUndefined(t)||i.isUndefined(r)))throw new a.Transaction.NeedMoreInfo("Need information about the UTXO script and satoshis");return e.output||!t||i.isUndefined(r)||(t=t instanceof w?t:new w(t),s.checkArgumentType(r,"number","satoshis"),e.output=new _({script:t,satoshis:r})),this.uncheckedAddInput(e)},n.prototype.uncheckedAddInput=function(e){return s.checkArgumentType(e,m,"input"),this.inputs.push(e),this._inputAmount=void 0,this._updateChangeOutput(),this},n.prototype.hasAllUtxoInfo=function(){return i.all(this.inputs.map(function(e){return!!e.output}))},n.prototype.fee=function(e){return s.checkArgument(i.isNumber(e),"amount must be a number"),this._fee=e,this._updateChangeOutput(),this},n.prototype.feePerKb=function(e){return s.checkArgument(i.isNumber(e),"amount must be a number"),this._feePerKb=e,this._updateChangeOutput(),this},n.prototype.change=function(e){return s.checkArgument(e,"address is required"),this._changeScript=w.fromAddress(e),this._updateChangeOutput(),this},n.prototype.getChangeOutput=function(){return i.isUndefined(this._changeIndex)?null:this.outputs[this._changeIndex]},n.prototype.to=function(e,t){return s.checkArgument(c.isNaturalNumber(t),"Amount is expected to be a positive integer"),this.addOutput(new _({script:w(new b(e)),satoshis:t})),this},n.prototype.addData=function(e){return this.addOutput(new _({script:w.buildDataOut(e),satoshis:0})),this},n.prototype.addOutput=function(e){return s.checkArgumentType(e,_,"output"),this._addOutput(e),this._updateChangeOutput(),this},n.prototype.clearOutputs=function(){return this.outputs=[],this._clearSignatures(),this._outputAmount=void 0,this._changeIndex=void 0,this._updateChangeOutput(),this},n.prototype._addOutput=function(e){this.outputs.push(e),this._outputAmount=void 0},n.prototype._getOutputAmount=function(){if(i.isUndefined(this._outputAmount)){var e=this;this._outputAmount=0,i.each(this.outputs,function(t){e._outputAmount+=t.satoshis})}return this._outputAmount},n.prototype._getInputAmount=function(){if(i.isUndefined(this._inputAmount)){var e=this;this._inputAmount=0,i.each(this.inputs,function(t){if(i.isUndefined(t.output))throw new a.Transaction.Input.MissingPreviousOutput;e._inputAmount+=t.output.satoshis})}return this._inputAmount},n.prototype._updateChangeOutput=function(){if(this._changeScript){this._clearSignatures(),i.isUndefined(this._changeIndex)||this._removeOutput(this._changeIndex);var e=this._getUnspentValue(),t=this.getFee(),r=e-t;r>0?(this._changeIndex=this.outputs.length,this._addOutput(new _({script:this._changeScript,satoshis:r}))):this._changeIndex=void 0}},n.prototype.getFee=function(){return i.isUndefined(this._fee)?this._changeScript?this._estimateFee():this._getUnspentValue():this._fee},n.prototype._estimateFee=function(){var e=this._estimateSize(),t=this._getUnspentValue();return n._estimateFee(e,t,this._feePerKb)},n.prototype._getUnspentValue=function(){return this._getInputAmount()-this._getOutputAmount()},n.prototype._clearSignatures=function(){i.each(this.inputs,function(e){e.clearSignatures()})},n._estimateFee=function(e,t,r){var i=Math.ceil(e/1e3)*(r||n.FEE_PER_KB);return t>i&&(e+=n.CHANGE_OUTPUT_MAX_SIZE),Math.ceil(e/1e3)*(r||n.FEE_PER_KB)},n.prototype._estimateSize=function(){var e=n.MAXIMUM_EXTRA_SIZE;return i.each(this.inputs,function(t){e+=t._estimateSize()}),i.each(this.outputs,function(t){e+=t.script.toBuffer().length+9}),e},n.prototype._removeOutput=function(e){var t=this.outputs[e];this.outputs=i.without(this.outputs,t),this._outputAmount=void 0},n.prototype.removeOutput=function(e){this._removeOutput(e),this._updateChangeOutput()},n.prototype.shuffleOutputs=function(){return this.sortOutputs(i.shuffle)},n.prototype.sortOutputs=function(e){var t=e(this.outputs);return this._newOutputOrder(t)},n.prototype._newOutputOrder=function(e){var t=this.outputs.length!==e.length||0!==i.difference(this.outputs,e).length;if(t)throw new a.Transaction.InvalidSorting;if(!i.isUndefined(this._changeIndex)){var r=this.outputs[this._changeIndex];this._changeIndex=i.findIndex(e,r)}return this.outputs=e,this},n.prototype.removeInput=function(e,t){var r;if(r=!t&&i.isNumber(e)?e:i.findIndex(this.inputs,function(r){return r.prevTxId.toString("hex")===e&&r.outputIndex===t}),0>r||r>=this.inputs.length)throw new a.Transaction.InvalidIndex(r,this.inputs.length);var n=this.inputs[r];this.inputs=i.without(this.inputs,n),this._inputAmount=void 0,this._updateChangeOutput()},n.prototype.sign=function(e,t){s.checkState(this.hasAllUtxoInfo());var r=this;return i.isArray(e)?(i.each(e,function(e){r.sign(e,t)}),this):(i.each(this.getSignatures(e,t),function(e){r.applySignature(e)}),this)},n.prototype.getSignatures=function(e,t){e=new S(e),t=t||p.SIGHASH_ALL;var r=this,n=[],s=d.sha256ripemd160(e.publicKey.toBuffer());return i.each(this.inputs,function(o,a){i.each(o.getSignatures(r,e,a,t,s),function(e){n.push(e)})}),n},n.prototype.applySignature=function(e){return this.inputs[e.inputIndex].addSignature(this,e),this},n.prototype.isFullySigned=function(){return i.each(this.inputs,function(e){if(e.isFullySigned===m.prototype.isFullySigned)throw new a.Transaction.UnableToVerifySignature("Unrecognized script kind, or not enough information to execute script.This usually happens when creating a transaction from a serialized transaction")}),i.all(i.map(this.inputs,function(e){return e.isFullySigned()}))},n.prototype.isValidSignature=function(e){var t=this;if(this.inputs[e.inputIndex].isValidSignature===m.prototype.isValidSignature)throw new a.Transaction.UnableToVerifySignature("Unrecognized script kind, or not enough information to execute script.This usually happens when creating a transaction from a serialized transaction");return this.inputs[e.inputIndex].isValidSignature(t,e)},n.prototype.verifySignature=function(e,t,r,n){return l.verify(this,e,t,r,n)},n.prototype.verify=function(){if(0===this.inputs.length)return"transaction txins empty";if(0===this.outputs.length)return"transaction txouts empty";for(var e=new k(0),t=0;t<this.outputs.length;t++){var r=this.outputs[t];if(r.invalidSatoshis())return"transaction txout "+t+" satoshis is invalid";if(r._satoshisBN.gt(new k(n.MAX_MONEY,10)))return"transaction txout "+t+" greater than MAX_MONEY";if(e=e.add(r._satoshisBN),e.gt(new k(n.MAX_MONEY)))return"transaction txout "+t+" total output greater than MAX_MONEY"}if(this.toBuffer().length>A)return"transaction over the maximum block size";var s={};for(t=0;t<this.inputs.length;t++){var o=this.inputs[t],a=o.prevTxId+":"+o.outputIndex;if(!i.isUndefined(s[a]))return"transaction input "+t+" duplicate input";s[a]=!0}var f=this.isCoinbase();if(f){var c=this.inputs[0]._scriptBuffer;if(c.length<2||c.length>100)return"coinbase transaction script size invalid"}else for(t=0;t<this.inputs.length;t++)if(this.inputs[t].isNull())return"transaction input "+t+" has null input";return!0},n.prototype.isCoinbase=function(){return 1===this.inputs.length&&this.inputs[0].isNull()},t.exports=n},{"../address":1,"../crypto/bn":6,"../crypto/hash":8,"../crypto/signature":11,"../encoding/bufferreader":14,"../encoding/bufferwriter":15,"../errors":17,"../privatekey":24,"../script":26,"../util/buffer":41,"../util/js":42,"../util/preconditions":43,"./input":30,"./output":34,"./sighash":35,"./unspentoutput":38,buffer:46,lodash:194}],38:[function(e,t,r){"use strict";function n(e){if(!(this instanceof n))return new n(e);s.checkArgument(i.isObject(e),"Must provide an object from where to extract data");var t=e.address?new f(e.address):void 0,r=e.txid?e.txid:e.txId;if(!r||!o.isHexaString(r)||r.length>64)throw new Error("Invalid TXID in object",e);var u=i.isUndefined(e.vout)?e.outputIndex:e.vout;if(!i.isNumber(u))throw new Error("Invalid outputIndex, received "+u);s.checkArgument(!i.isUndefined(e.scriptPubKey)||!i.isUndefined(e.script),"Must provide the scriptPubKey for that output!");var h=new a(e.scriptPubKey||e.script);s.checkArgument(!i.isUndefined(e.amount)||!i.isUndefined(e.satoshis),"Must provide an amount for the output");var d=i.isUndefined(e.amount)?e.satoshis:new c.fromBTC(e.amount).toSatoshis();s.checkArgument(i.isNumber(d),"Amount must be a number"),o.defineImmutable(this,{address:t,txId:r,outputIndex:u,script:h,satoshis:d})}var i=e("lodash"),s=e("../util/preconditions"),o=e("../util/js"),a=e("../script"),f=e("../address"),c=e("../unit");n.prototype.inspect=function(){return"<UnspentOutput: "+this.txId+":"+this.outputIndex+", satoshis: "+this.satoshis+", address: "+this.address+">"},n.prototype.toString=function(){return this.txId+":"+this.outputIndex},n.fromJSON=n.fromObject=function(e){return o.isValidJSON(e)&&(e=JSON.parse(e)),new n(e)},n.prototype.toJSON=function(){return JSON.stringify(this.toObject())},n.prototype.toObject=function(){return{address:this.address?this.address.toString():void 0,txid:this.txId,vout:this.outputIndex,scriptPubKey:this.script.toBuffer().toString("hex"),amount:c.fromSatoshis(this.satoshis).toBTC()}},t.exports=n},{"../address":1,"../script":26,"../unit":39,"../util/js":42,"../util/preconditions":43,lodash:194}],39:[function(e,t,r){"use strict";function n(e,t){if(!(this instanceof n))return new n(e,t);if(i.isNumber(t)){if(0>=t)throw new s.Unit.InvalidRate(t);e/=t,t=n.BTC}this._value=this._from(e,t);var r=this,o=function(e){Object.defineProperty(r,e,{get:function(){return r.to(e)},enumerable:!0})};Object.keys(a).forEach(o)}var i=e("lodash"),s=e("./errors"),o=e("./util/js"),a={BTC:[1e8,8],mBTC:[1e5,5],uBTC:[100,2],bits:[100,2],satoshis:[1,0]};Object.keys(a).forEach(function(e){n[e]=e}),n.fromJSON=function(e){return o.isValidJSON(e)&&(e=JSON.parse(e)),new n(e.amount,e.code)},n.fromBTC=function(e){return new n(e,n.BTC)},n.fromMilis=function(e){return new n(e,n.mBTC)},n.fromMicros=n.fromBits=function(e){return new n(e,n.bits)},n.fromSatoshis=function(e){return new n(e,n.satoshis)},n.fromFiat=function(e,t){return new n(e,t)},n.prototype._from=function(e,t){if(!a[t])throw new s.Unit.UnknownCode(t);return parseInt((e*a[t][0]).toFixed())},n.prototype.to=function(e){if(i.isNumber(e)){if(0>=e)throw new s.Unit.InvalidRate(e);return parseFloat((this.BTC*e).toFixed(2))}if(!a[e])throw new s.Unit.UnknownCode(e);var t=this._value/a[e][0];return parseFloat(t.toFixed(a[e][1]))},n.prototype.toBTC=function(){return this.to(n.BTC)},n.prototype.toMilis=function(){return this.to(n.mBTC)},n.prototype.toMicros=n.prototype.toBits=function(){return this.to(n.bits)},n.prototype.toSatoshis=function(){return this.to(n.satoshis)},n.prototype.atRate=function(e){return this.to(e)},n.prototype.toString=function(){return this.satoshis+" satoshis"},n.prototype.toObject=function(){return{amount:this.BTC,code:n.BTC}},n.prototype.toJSON=function(){return JSON.stringify(this.toObject())},n.prototype.inspect=function(){return"<Unit: "+this.toString()+">"},t.exports=n},{"./errors":17,"./util/js":42,lodash:194}],40:[function(e,t,r){"use strict";var n=e("lodash"),i=e("url"),s=e("./address"),o=e("./unit"),a=e("./util/js"),f=function(e,t){if(!(this instanceof f))return new f(e,t);if(this.extras={},this.knownParams=t||[],this.address=this.network=this.amount=this.message=null,"string"==typeof e){var r=f.parse(e);r.amount&&(r.amount=this._parseAmount(r.amount)),this._fromObject(r)}else{if("object"!=typeof e)throw new TypeError("Unrecognized data format.");this._fromObject(e)}};f.fromString=function(e){if("string"!=typeof e)throw new TypeError("Expected a string");return new f(e)},f.fromJSON=function(e){return a.isValidJSON(e)&&(e=JSON.parse(e)),new f(e)},f.isValid=function(e,t){try{new f(e,t)}catch(r){return!1}return!0},f.parse=function(e){var t=i.parse(e,!0);if("bitcoin:"!==t.protocol)throw new TypeError("Invalid bitcoin URI");var r=/[^:]*:\/?\/?([^?]*)/.exec(e);return t.query.address=r&&r[1]||void 0,t.query},f.Members=["address","amount","message","label","r"],f.prototype._fromObject=function(e){if(!s.isValid(e.address))throw new TypeError("Invalid bitcoin address");this.address=new s(e.address),this.network=this.address.network,this.amount=e.amount;for(var t in e)if("address"!==t&&"amount"!==t){if(/^req-/.exec(t)&&-1===this.knownParams.indexOf(t))throw Error("Unknown required argument "+t);var r=f.Members.indexOf(t)>-1?this:this.extras;r[t]=e[t]}},f.prototype._parseAmount=function(e){if(e=Number(e),isNaN(e))throw new TypeError("Invalid amount");return o.fromBTC(e).toSatoshis()},f.prototype.toObject=function(){for(var e={},t=0;t<f.Members.length;t++){var r=f.Members[t];this.hasOwnProperty(r)&&"undefined"!=typeof this[r]&&(e[r]=this[r].toString())}return n.extend(e,this.extras),e},f.prototype.toJSON=function(){return JSON.stringify(this.toObject())},f.prototype.toString=function(){var e={};return this.amount&&(e.amount=o.fromSatoshis(this.amount).toBTC()),this.message&&(e.message=this.message),this.label&&(e.label=this.label),this.r&&(e.r=this.r),n.extend(e,this.extras),i.format({protocol:"bitcoin:",host:this.address,query:e})},f.prototype.inspect=function(){return"<URI: "+this.toString()+">"},t.exports=f},{"./address":1,"./unit":39,"./util/js":42,lodash:194,url:165}],41:[function(e,t,r){(function(r){"use strict";function n(e,t){if(e.length!==t.length)return!1;for(var r=e.length,n=0;r>n;n++)if(e[n]!==t[n])return!1;return!0}var i=e("buffer"),s=e("assert"),o=e("./js"),a=e("./preconditions");t.exports={fill:function(e,t){a.checkArgumentType(e,"Buffer","buffer"),a.checkArgumentType(t,"number","value");for(var r=e.length,n=0;r>n;n++)e[n]=t;return e},copy:function(e){var t=new r(e.length);return e.copy(t),t},isBuffer:function(e){return i.Buffer.isBuffer(e)||e instanceof Uint8Array},emptyBuffer:function(e){a.checkArgumentType(e,"number","bytes");for(var t=new i.Buffer(e),r=0;e>r;r++)t.write("\x00",r);return t},concat:i.Buffer.concat,equals:n,equal:n,integerAsSingleByteBuffer:function(e){return a.checkArgumentType(e,"number","integer"),new i.Buffer([255&e])},integerAsBuffer:function(e){a.checkArgumentType(e,"number","integer");var t=[];return t.push(e>>24&255),t.push(e>>16&255),t.push(e>>8&255),t.push(255&e),new r(t)},integerFromBuffer:function(e){return a.checkArgumentType(e,"Buffer","buffer"),e[0]<<24|e[1]<<16|e[2]<<8|e[3]},integerFromSingleByteBuffer:function(e){return a.checkArgumentType(e,"Buffer","buffer"),e[0]},bufferToHex:function(e){return a.checkArgumentType(e,"Buffer","buffer"),e.toString("hex")},reverse:function(e){for(var t=new i.Buffer(e.length),r=0;r<e.length;r++)t[r]=e[e.length-r-1];return t},hexToBuffer:function(e){return s(o.isHexa(e)),new i.Buffer(e,"hex")}},t.exports.NULL_HASH=t.exports.fill(new r(32),0),t.exports.EMPTY_BUFFER=new r(0)}).call(this,e("buffer").Buffer)},{"./js":42,"./preconditions":43,assert:44,buffer:46}],42:[function(e,t,r){"use strict";var n=e("lodash"),i=function(e){return n.isString(e)?/^[0-9a-fA-F]+$/.test(e):!1};t.exports={isValidJSON:function(e){var t;if(!n.isString(e))return!1;try{t=JSON.parse(e)}catch(r){return!1}return"object"==typeof t?!0:!1},isHexa:i,isHexaString:i,cloneArray:function(e){return[].concat(e)},defineImmutable:function(e,t){return Object.keys(t).forEach(function(r){Object.defineProperty(e,r,{configurable:!1,enumerable:!0,value:t[r]})}),e},isNaturalNumber:function(e){return"number"==typeof e&&isFinite(e)&&Math.floor(e)===e&&e>=0}}},{lodash:194}],43:[function(e,t,r){"use strict";var n=e("../errors"),i=e("lodash");t.exports={checkState:function(e,t){if(!e)throw new n.InvalidState(t)},checkArgument:function(e,t,r,i){if(!e)throw new n.InvalidArgument(t,r,i)},checkArgumentType:function(t,r,s){if(s=s||"(unknown name)",i.isString(r)){if("Buffer"===r){var o=e("./buffer");if(!o.isBuffer(t))throw new n.InvalidArgumentType(t,r,s)}else if(typeof t!==r)throw new n.InvalidArgumentType(t,r,s)}else if(!(t instanceof r))throw new n.InvalidArgumentType(t,r.name,s)}}},{"../errors":17,"./buffer":41,lodash:194}],44:[function(e,t,r){function n(e,t){return p.isUndefined(t)?""+t:!p.isNumber(t)||!isNaN(t)&&isFinite(t)?p.isFunction(t)||p.isRegExp(t)?t.toString():t:t.toString()}function i(e,t){return p.isString(e)?e.length<t?e:e.slice(0,t):e}function s(e){return i(JSON.stringify(e.actual,n),128)+" "+e.operator+" "+i(JSON.stringify(e.expected,n),128)}function o(e,t,r,n,i){throw new g.AssertionError({message:r,actual:e,expected:t,operator:n,stackStartFunction:i})}function a(e,t){e||o(e,!0,t,"==",g.ok)}function f(e,t){if(e===t)return!0;if(p.isBuffer(e)&&p.isBuffer(t)){if(e.length!=t.length)return!1;for(var r=0;r<e.length;r++)if(e[r]!==t[r])return!1;return!0}return p.isDate(e)&&p.isDate(t)?e.getTime()===t.getTime():p.isRegExp(e)&&p.isRegExp(t)?e.source===t.source&&e.global===t.global&&e.multiline===t.multiline&&e.lastIndex===t.lastIndex&&e.ignoreCase===t.ignoreCase:p.isObject(e)||p.isObject(t)?u(e,t):e==t}function c(e){return"[object Arguments]"==Object.prototype.toString.call(e)}function u(e,t){if(p.isNullOrUndefined(e)||p.isNullOrUndefined(t))return!1;if(e.prototype!==t.prototype)return!1;if(c(e))return c(t)?(e=l.call(e),t=l.call(t),f(e,t)):!1;try{var r,n,i=m(e),s=m(t)}catch(o){return!1}if(i.length!=s.length)return!1;for(i.sort(),s.sort(),n=i.length-1;n>=0;n--)if(i[n]!=s[n])return!1;for(n=i.length-1;n>=0;n--)if(r=i[n],!f(e[r],t[r]))return!1;return!0}function h(e,t){return e&&t?"[object RegExp]"==Object.prototype.toString.call(t)?t.test(e):e instanceof t?!0:t.call({},e)===!0?!0:!1:!1}function d(e,t,r,n){var i;p.isString(r)&&(n=r,r=null);try{t()}catch(s){i=s}if(n=(r&&r.name?" ("+r.name+").":".")+(n?" "+n:"."),e&&!i&&o(i,r,"Missing expected exception"+n),!e&&h(i,r)&&o(i,r,"Got unwanted exception"+n),e&&i&&r&&!h(i,r)||!e&&i)throw i}var p=e("util/"),l=Array.prototype.slice,b=Object.prototype.hasOwnProperty,g=t.exports=a;g.AssertionError=function(e){this.name="AssertionError",this.actual=e.actual,this.expected=e.expected,this.operator=e.operator,e.message?(this.message=e.message,this.generatedMessage=!1):(this.message=s(this),this.generatedMessage=!0);var t=e.stackStartFunction||o;if(Error.captureStackTrace)Error.captureStackTrace(this,t);else{var r=new Error;if(r.stack){var n=r.stack,i=t.name,a=n.indexOf("\n"+i);if(a>=0){var f=n.indexOf("\n",a+1);n=n.substring(f+1)}this.stack=n}}},p.inherits(g.AssertionError,Error),g.fail=o,g.ok=a,g.equal=function(e,t,r){e!=t&&o(e,t,r,"==",g.equal)},g.notEqual=function(e,t,r){e==t&&o(e,t,r,"!=",g.notEqual)},g.deepEqual=function(e,t,r){f(e,t)||o(e,t,r,"deepEqual",g.deepEqual)},g.notDeepEqual=function(e,t,r){f(e,t)&&o(e,t,r,"notDeepEqual",g.notDeepEqual)},g.strictEqual=function(e,t,r){e!==t&&o(e,t,r,"===",g.strictEqual)},g.notStrictEqual=function(e,t,r){e===t&&o(e,t,r,"!==",g.notStrictEqual)},g["throws"]=function(e,t,r){d.apply(this,[!0].concat(l.call(arguments)))},g.doesNotThrow=function(e,t){d.apply(this,[!1].concat(l.call(arguments)))},g.ifError=function(e){if(e)throw e};var m=Object.keys||function(e){var t=[];for(var r in e)b.call(e,r)&&t.push(r);return t}},{"util/":167}],45:[function(e,t,r){},{}],46:[function(e,t,r){function n(e,t,r){if(!(this instanceof n))return new n(e,t,r);var i,s=typeof e;if("number"===s)i=e>0?e>>>0:0;else if("string"===s)"base64"===t&&(e=k(e)),i=n.byteLength(e,t);else{if("object"!==s||null===e)throw new TypeError("must start with number, buffer, array or string");"Buffer"===e.type&&j(e.data)&&(e=e.data),i=+e.length>0?Math.floor(+e.length):0}if(this.length>U)throw new RangeError("Attempt to allocate Buffer larger than maximum size: 0x"+U.toString(16)+" bytes");var o;n.TYPED_ARRAY_SUPPORT?o=n._augment(new Uint8Array(i)):(o=this,o.length=i,o._isBuffer=!0);var a;if(n.TYPED_ARRAY_SUPPORT&&"number"==typeof e.byteLength)o._set(e);else if(I(e))if(n.isBuffer(e))for(a=0;i>a;a++)o[a]=e.readUInt8(a);else for(a=0;i>a;a++)o[a]=(e[a]%256+256)%256;else if("string"===s)o.write(e,0,t);else if("number"===s&&!n.TYPED_ARRAY_SUPPORT&&!r)for(a=0;i>a;a++)o[a]=0;return o}function i(e,t,r,n){r=Number(r)||0;var i=e.length-r;n?(n=Number(n),n>i&&(n=i)):n=i;var s=t.length;if(s%2!==0)throw new Error("Invalid hex string");n>s/2&&(n=s/2);for(var o=0;n>o;o++){var a=parseInt(t.substr(2*o,2),16);if(isNaN(a))throw new Error("Invalid hex string");e[r+o]=a}return o}function s(e,t,r,n){var i=R(O(t),e,r,n);return i}function o(e,t,r,n){var i=R(P(t),e,r,n);return i}function a(e,t,r,n){return o(e,t,r,n)}function f(e,t,r,n){var i=R(x(t),e,r,n);return i}function c(e,t,r,n){var i=R(B(t),e,r,n,2);return i}function u(e,t,r){return N.fromByteArray(0===t&&r===e.length?e:e.slice(t,r))}function h(e,t,r){var n="",i="";r=Math.min(e.length,r);for(var s=t;r>s;s++)e[s]<=127?(n+=T(i)+String.fromCharCode(e[s]),i=""):i+="%"+e[s].toString(16);return n+T(i)}function d(e,t,r){var n="";r=Math.min(e.length,r);for(var i=t;r>i;i++)n+=String.fromCharCode(e[i]);return n}function p(e,t,r){return d(e,t,r)}function l(e,t,r){var n=e.length;(!t||0>t)&&(t=0),(!r||0>r||r>n)&&(r=n);for(var i="",s=t;r>s;s++)i+=A(e[s]);return i}function b(e,t,r){for(var n=e.slice(t,r),i="",s=0;s<n.length;s+=2)i+=String.fromCharCode(n[s]+256*n[s+1]);return i}function g(e,t,r){if(e%1!==0||0>e)throw new RangeError("offset is not uint");if(e+t>r)throw new RangeError("Trying to access beyond buffer length")}function m(e,t,r,i,s,o){if(!n.isBuffer(e))throw new TypeError("buffer must be a Buffer instance");if(t>s||o>t)throw new TypeError("value is out of bounds");if(r+i>e.length)throw new TypeError("index out of range")}function y(e,t,r,n){0>t&&(t=65535+t+1);for(var i=0,s=Math.min(e.length-r,2);s>i;i++)e[r+i]=(t&255<<8*(n?i:1-i))>>>8*(n?i:1-i)}function v(e,t,r,n){0>t&&(t=4294967295+t+1);for(var i=0,s=Math.min(e.length-r,4);s>i;i++)e[r+i]=t>>>8*(n?i:3-i)&255}function _(e,t,r,n,i,s){if(t>i||s>t)throw new TypeError("value is out of bounds");if(r+n>e.length)throw new TypeError("index out of range")}function w(e,t,r,n,i){return i||_(e,t,r,4,3.4028234663852886e38,-3.4028234663852886e38),C.write(e,t,r,n,23,4),r+4}function S(e,t,r,n,i){return i||_(e,t,r,8,1.7976931348623157e308,-1.7976931348623157e308),C.write(e,t,r,n,52,8),r+8}function k(e){for(e=E(e).replace(L,"");e.length%4!==0;)e+="=";return e}function E(e){return e.trim?e.trim():e.replace(/^\s+|\s+$/g,"")}function I(e){return j(e)||n.isBuffer(e)||e&&"object"==typeof e&&"number"==typeof e.length}function A(e){return 16>e?"0"+e.toString(16):e.toString(16)}function O(e){for(var t=[],r=0;r<e.length;r++){var n=e.charCodeAt(r);if(127>=n)t.push(n);else{var i=r;n>=55296&&57343>=n&&r++;for(var s=encodeURIComponent(e.slice(i,r+1)).substr(1).split("%"),o=0;o<s.length;o++)t.push(parseInt(s[o],16))}}return t}function P(e){for(var t=[],r=0;r<e.length;r++)t.push(255&e.charCodeAt(r));return t}function B(e){for(var t,r,n,i=[],s=0;s<e.length;s++)t=e.charCodeAt(s),r=t>>8,n=t%256,i.push(n),i.push(r);return i}function x(e){return N.toByteArray(e)}function R(e,t,r,n,i){i&&(n-=n%i);for(var s=0;n>s&&!(s+r>=t.length||s>=e.length);s++)t[s+r]=e[s];return s}function T(e){try{return decodeURIComponent(e)}catch(t){return String.fromCharCode(65533)}}var N=e("base64-js"),C=e("ieee754"),j=e("is-array");r.Buffer=n,r.SlowBuffer=n,r.INSPECT_MAX_BYTES=50,n.poolSize=8192;var U=1073741823;n.TYPED_ARRAY_SUPPORT=function(){try{var e=new ArrayBuffer(0),t=new Uint8Array(e);return t.foo=function(){return 42},42===t.foo()&&"function"==typeof t.subarray&&0===new Uint8Array(1).subarray(1,1).byteLength}catch(r){return!1}}(),n.isBuffer=function(e){return!(null==e||!e._isBuffer)},n.compare=function(e,t){if(!n.isBuffer(e)||!n.isBuffer(t))throw new TypeError("Arguments must be Buffers");for(var r=e.length,i=t.length,s=0,o=Math.min(r,i);o>s&&e[s]===t[s];s++);return s!==o&&(r=e[s],i=t[s]),i>r?-1:r>i?1:0},n.isEncoding=function(e){switch(String(e).toLowerCase()){case"hex":case"utf8":case"utf-8":case"ascii":case"binary":case"base64":case"raw":case"ucs2":case"ucs-2":case"utf16le":case"utf-16le":return!0;default:return!1}},n.concat=function(e,t){if(!j(e))throw new TypeError("Usage: Buffer.concat(list[, length])");if(0===e.length)return new n(0);if(1===e.length)return e[0];var r;if(void 0===t)for(t=0,r=0;r<e.length;r++)t+=e[r].length;var i=new n(t),s=0;for(r=0;r<e.length;r++){var o=e[r];o.copy(i,s),s+=o.length}return i},n.byteLength=function(e,t){var r;switch(e+="",t||"utf8"){case"ascii":case"binary":case"raw":r=e.length;break;case"ucs2":case"ucs-2":case"utf16le":case"utf-16le":r=2*e.length;break;case"hex":r=e.length>>>1;break;case"utf8":case"utf-8":r=O(e).length;break;case"base64":r=x(e).length;break;default:r=e.length}return r},n.prototype.length=void 0,n.prototype.parent=void 0,n.prototype.toString=function(e,t,r){var n=!1;if(t>>>=0,r=void 0===r||r===1/0?this.length:r>>>0,e||(e="utf8"),0>t&&(t=0),r>this.length&&(r=this.length),t>=r)return"";for(;;)switch(e){case"hex":return l(this,t,r);case"utf8":case"utf-8":return h(this,t,r);case"ascii":return d(this,t,r);case"binary":return p(this,t,r);case"base64":return u(this,t,r);case"ucs2":case"ucs-2":case"utf16le":case"utf-16le":return b(this,t,r);default:if(n)throw new TypeError("Unknown encoding: "+e);e=(e+"").toLowerCase(),n=!0}},n.prototype.equals=function(e){if(!n.isBuffer(e))throw new TypeError("Argument must be a Buffer");return 0===n.compare(this,e)},n.prototype.inspect=function(){var e="",t=r.INSPECT_MAX_BYTES;return this.length>0&&(e=this.toString("hex",0,t).match(/.{2}/g).join(" "),this.length>t&&(e+=" ... ")),"<Buffer "+e+">"},n.prototype.compare=function(e){if(!n.isBuffer(e))throw new TypeError("Argument must be a Buffer");return n.compare(this,e)},n.prototype.get=function(e){return console.log(".get() is deprecated. Access using array indexes instead."),this.readUInt8(e)},n.prototype.set=function(e,t){return console.log(".set() is deprecated. Access using array indexes instead."),this.writeUInt8(e,t)},n.prototype.write=function(e,t,r,n){if(isFinite(t))isFinite(r)||(n=r,r=void 0);else{var u=n;n=t,t=r,r=u}t=Number(t)||0;var h=this.length-t;r?(r=Number(r),r>h&&(r=h)):r=h,n=String(n||"utf8").toLowerCase();var d;switch(n){case"hex":d=i(this,e,t,r);break;case"utf8":case"utf-8":d=s(this,e,t,r);break;case"ascii":d=o(this,e,t,r);break;case"binary":d=a(this,e,t,r);break;case"base64":d=f(this,e,t,r);break;case"ucs2":case"ucs-2":case"utf16le":case"utf-16le":d=c(this,e,t,r);break;default:throw new TypeError("Unknown encoding: "+n)}return d},n.prototype.toJSON=function(){return{type:"Buffer",data:Array.prototype.slice.call(this._arr||this,0)}},n.prototype.slice=function(e,t){var r=this.length;if(e=~~e,t=void 0===t?r:~~t,0>e?(e+=r,0>e&&(e=0)):e>r&&(e=r),0>t?(t+=r,0>t&&(t=0)):t>r&&(t=r),e>t&&(t=e),n.TYPED_ARRAY_SUPPORT)return n._augment(this.subarray(e,t));for(var i=t-e,s=new n(i,void 0,!0),o=0;i>o;o++)s[o]=this[o+e];return s},n.prototype.readUInt8=function(e,t){return t||g(e,1,this.length),this[e]},n.prototype.readUInt16LE=function(e,t){return t||g(e,2,this.length),this[e]|this[e+1]<<8},n.prototype.readUInt16BE=function(e,t){return t||g(e,2,this.length),this[e]<<8|this[e+1]},n.prototype.readUInt32LE=function(e,t){return t||g(e,4,this.length),(this[e]|this[e+1]<<8|this[e+2]<<16)+16777216*this[e+3]},n.prototype.readUInt32BE=function(e,t){return t||g(e,4,this.length),16777216*this[e]+(this[e+1]<<16|this[e+2]<<8|this[e+3])},n.prototype.readInt8=function(e,t){return t||g(e,1,this.length),128&this[e]?-1*(255-this[e]+1):this[e]},n.prototype.readInt16LE=function(e,t){t||g(e,2,this.length);var r=this[e]|this[e+1]<<8;return 32768&r?4294901760|r:r},n.prototype.readInt16BE=function(e,t){t||g(e,2,this.length);var r=this[e+1]|this[e]<<8;return 32768&r?4294901760|r:r},n.prototype.readInt32LE=function(e,t){return t||g(e,4,this.length),this[e]|this[e+1]<<8|this[e+2]<<16|this[e+3]<<24},n.prototype.readInt32BE=function(e,t){return t||g(e,4,this.length),this[e]<<24|this[e+1]<<16|this[e+2]<<8|this[e+3]},n.prototype.readFloatLE=function(e,t){return t||g(e,4,this.length),C.read(this,e,!0,23,4)},n.prototype.readFloatBE=function(e,t){return t||g(e,4,this.length),C.read(this,e,!1,23,4)},n.prototype.readDoubleLE=function(e,t){return t||g(e,8,this.length),C.read(this,e,!0,52,8)},n.prototype.readDoubleBE=function(e,t){return t||g(e,8,this.length),C.read(this,e,!1,52,8)},n.prototype.writeUInt8=function(e,t,r){return e=+e,t>>>=0,r||m(this,e,t,1,255,0),n.TYPED_ARRAY_SUPPORT||(e=Math.floor(e)),this[t]=e,t+1},n.prototype.writeUInt16LE=function(e,t,r){return e=+e,t>>>=0,r||m(this,e,t,2,65535,0),n.TYPED_ARRAY_SUPPORT?(this[t]=e,this[t+1]=e>>>8):y(this,e,t,!0),t+2},n.prototype.writeUInt16BE=function(e,t,r){return e=+e,t>>>=0,r||m(this,e,t,2,65535,0),n.TYPED_ARRAY_SUPPORT?(this[t]=e>>>8,this[t+1]=e):y(this,e,t,!1),t+2},n.prototype.writeUInt32LE=function(e,t,r){return e=+e,t>>>=0,r||m(this,e,t,4,4294967295,0),n.TYPED_ARRAY_SUPPORT?(this[t+3]=e>>>24,this[t+2]=e>>>16,this[t+1]=e>>>8,this[t]=e):v(this,e,t,!0),t+4},n.prototype.writeUInt32BE=function(e,t,r){return e=+e,t>>>=0,r||m(this,e,t,4,4294967295,0),n.TYPED_ARRAY_SUPPORT?(this[t]=e>>>24,this[t+1]=e>>>16,this[t+2]=e>>>8,this[t+3]=e):v(this,e,t,!1),t+4},n.prototype.writeInt8=function(e,t,r){return e=+e,t>>>=0,r||m(this,e,t,1,127,-128),n.TYPED_ARRAY_SUPPORT||(e=Math.floor(e)),0>e&&(e=255+e+1),this[t]=e,t+1},n.prototype.writeInt16LE=function(e,t,r){return e=+e,t>>>=0,r||m(this,e,t,2,32767,-32768),n.TYPED_ARRAY_SUPPORT?(this[t]=e,this[t+1]=e>>>8):y(this,e,t,!0),t+2},n.prototype.writeInt16BE=function(e,t,r){return e=+e,t>>>=0,r||m(this,e,t,2,32767,-32768),n.TYPED_ARRAY_SUPPORT?(this[t]=e>>>8,this[t+1]=e):y(this,e,t,!1),t+2},n.prototype.writeInt32LE=function(e,t,r){return e=+e,t>>>=0,r||m(this,e,t,4,2147483647,-2147483648),n.TYPED_ARRAY_SUPPORT?(this[t]=e,this[t+1]=e>>>8,this[t+2]=e>>>16,this[t+3]=e>>>24):v(this,e,t,!0),t+4},n.prototype.writeInt32BE=function(e,t,r){return e=+e,t>>>=0,r||m(this,e,t,4,2147483647,-2147483648),
0>e&&(e=4294967295+e+1),n.TYPED_ARRAY_SUPPORT?(this[t]=e>>>24,this[t+1]=e>>>16,this[t+2]=e>>>8,this[t+3]=e):v(this,e,t,!1),t+4},n.prototype.writeFloatLE=function(e,t,r){return w(this,e,t,!0,r)},n.prototype.writeFloatBE=function(e,t,r){return w(this,e,t,!1,r)},n.prototype.writeDoubleLE=function(e,t,r){return S(this,e,t,!0,r)},n.prototype.writeDoubleBE=function(e,t,r){return S(this,e,t,!1,r)},n.prototype.copy=function(e,t,r,i){var s=this;if(r||(r=0),i||0===i||(i=this.length),t||(t=0),i!==r&&0!==e.length&&0!==s.length){if(r>i)throw new TypeError("sourceEnd < sourceStart");if(0>t||t>=e.length)throw new TypeError("targetStart out of bounds");if(0>r||r>=s.length)throw new TypeError("sourceStart out of bounds");if(0>i||i>s.length)throw new TypeError("sourceEnd out of bounds");i>this.length&&(i=this.length),e.length-t<i-r&&(i=e.length-t+r);var o=i-r;if(1e3>o||!n.TYPED_ARRAY_SUPPORT)for(var a=0;o>a;a++)e[a+t]=this[a+r];else e._set(this.subarray(r,r+o),t)}},n.prototype.fill=function(e,t,r){if(e||(e=0),t||(t=0),r||(r=this.length),t>r)throw new TypeError("end < start");if(r!==t&&0!==this.length){if(0>t||t>=this.length)throw new TypeError("start out of bounds");if(0>r||r>this.length)throw new TypeError("end out of bounds");var n;if("number"==typeof e)for(n=t;r>n;n++)this[n]=e;else{var i=O(e.toString()),s=i.length;for(n=t;r>n;n++)this[n]=i[n%s]}return this}},n.prototype.toArrayBuffer=function(){if("undefined"!=typeof Uint8Array){if(n.TYPED_ARRAY_SUPPORT)return new n(this).buffer;for(var e=new Uint8Array(this.length),t=0,r=e.length;r>t;t+=1)e[t]=this[t];return e.buffer}throw new TypeError("Buffer.toArrayBuffer not supported in this browser")};var M=n.prototype;n._augment=function(e){return e.constructor=n,e._isBuffer=!0,e._get=e.get,e._set=e.set,e.get=M.get,e.set=M.set,e.write=M.write,e.toString=M.toString,e.toLocaleString=M.toString,e.toJSON=M.toJSON,e.equals=M.equals,e.compare=M.compare,e.copy=M.copy,e.slice=M.slice,e.readUInt8=M.readUInt8,e.readUInt16LE=M.readUInt16LE,e.readUInt16BE=M.readUInt16BE,e.readUInt32LE=M.readUInt32LE,e.readUInt32BE=M.readUInt32BE,e.readInt8=M.readInt8,e.readInt16LE=M.readInt16LE,e.readInt16BE=M.readInt16BE,e.readInt32LE=M.readInt32LE,e.readInt32BE=M.readInt32BE,e.readFloatLE=M.readFloatLE,e.readFloatBE=M.readFloatBE,e.readDoubleLE=M.readDoubleLE,e.readDoubleBE=M.readDoubleBE,e.writeUInt8=M.writeUInt8,e.writeUInt16LE=M.writeUInt16LE,e.writeUInt16BE=M.writeUInt16BE,e.writeUInt32LE=M.writeUInt32LE,e.writeUInt32BE=M.writeUInt32BE,e.writeInt8=M.writeInt8,e.writeInt16LE=M.writeInt16LE,e.writeInt16BE=M.writeInt16BE,e.writeInt32LE=M.writeInt32LE,e.writeInt32BE=M.writeInt32BE,e.writeFloatLE=M.writeFloatLE,e.writeFloatBE=M.writeFloatBE,e.writeDoubleLE=M.writeDoubleLE,e.writeDoubleBE=M.writeDoubleBE,e.fill=M.fill,e.inspect=M.inspect,e.toArrayBuffer=M.toArrayBuffer,e};var L=/[^+\/0-9A-z]/g},{"base64-js":47,ieee754:48,"is-array":49}],47:[function(e,t,r){var n="ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/";!function(e){"use strict";function t(e){var t=e.charCodeAt(0);return t===o?62:t===a?63:f>t?-1:f+10>t?t-f+26+26:u+26>t?t-u:c+26>t?t-c+26:void 0}function r(e){function r(e){c[h++]=e}var n,i,o,a,f,c;if(e.length%4>0)throw new Error("Invalid string. Length must be a multiple of 4");var u=e.length;f="="===e.charAt(u-2)?2:"="===e.charAt(u-1)?1:0,c=new s(3*e.length/4-f),o=f>0?e.length-4:e.length;var h=0;for(n=0,i=0;o>n;n+=4,i+=3)a=t(e.charAt(n))<<18|t(e.charAt(n+1))<<12|t(e.charAt(n+2))<<6|t(e.charAt(n+3)),r((16711680&a)>>16),r((65280&a)>>8),r(255&a);return 2===f?(a=t(e.charAt(n))<<2|t(e.charAt(n+1))>>4,r(255&a)):1===f&&(a=t(e.charAt(n))<<10|t(e.charAt(n+1))<<4|t(e.charAt(n+2))>>2,r(a>>8&255),r(255&a)),c}function i(e){function t(e){return n.charAt(e)}function r(e){return t(e>>18&63)+t(e>>12&63)+t(e>>6&63)+t(63&e)}var i,s,o,a=e.length%3,f="";for(i=0,o=e.length-a;o>i;i+=3)s=(e[i]<<16)+(e[i+1]<<8)+e[i+2],f+=r(s);switch(a){case 1:s=e[e.length-1],f+=t(s>>2),f+=t(s<<4&63),f+="==";break;case 2:s=(e[e.length-2]<<8)+e[e.length-1],f+=t(s>>10),f+=t(s>>4&63),f+=t(s<<2&63),f+="="}return f}var s="undefined"!=typeof Uint8Array?Uint8Array:Array,o="+".charCodeAt(0),a="/".charCodeAt(0),f="0".charCodeAt(0),c="a".charCodeAt(0),u="A".charCodeAt(0);e.toByteArray=r,e.fromByteArray=i}("undefined"==typeof r?this.base64js={}:r)},{}],48:[function(e,t,r){r.read=function(e,t,r,n,i){var s,o,a=8*i-n-1,f=(1<<a)-1,c=f>>1,u=-7,h=r?i-1:0,d=r?-1:1,p=e[t+h];for(h+=d,s=p&(1<<-u)-1,p>>=-u,u+=a;u>0;s=256*s+e[t+h],h+=d,u-=8);for(o=s&(1<<-u)-1,s>>=-u,u+=n;u>0;o=256*o+e[t+h],h+=d,u-=8);if(0===s)s=1-c;else{if(s===f)return o?0/0:(p?-1:1)*(1/0);o+=Math.pow(2,n),s-=c}return(p?-1:1)*o*Math.pow(2,s-n)},r.write=function(e,t,r,n,i,s){var o,a,f,c=8*s-i-1,u=(1<<c)-1,h=u>>1,d=23===i?Math.pow(2,-24)-Math.pow(2,-77):0,p=n?0:s-1,l=n?1:-1,b=0>t||0===t&&0>1/t?1:0;for(t=Math.abs(t),isNaN(t)||t===1/0?(a=isNaN(t)?1:0,o=u):(o=Math.floor(Math.log(t)/Math.LN2),t*(f=Math.pow(2,-o))<1&&(o--,f*=2),t+=o+h>=1?d/f:d*Math.pow(2,1-h),t*f>=2&&(o++,f/=2),o+h>=u?(a=0,o=u):o+h>=1?(a=(t*f-1)*Math.pow(2,i),o+=h):(a=t*Math.pow(2,h-1)*Math.pow(2,i),o=0));i>=8;e[r+p]=255&a,p+=l,a/=256,i-=8);for(o=o<<i|a,c+=i;c>0;e[r+p]=255&o,p+=l,o/=256,c-=8);e[r+p-l]|=128*b}},{}],49:[function(e,t,r){var n=Array.isArray,i=Object.prototype.toString;t.exports=n||function(e){return!!e&&"[object Array]"==i.call(e)}},{}],50:[function(e,t,r){"use strict";r.randomBytes=r.rng=r.pseudoRandomBytes=r.prng=e("randombytes"),r.createHash=r.Hash=e("create-hash"),r.createHmac=r.Hmac=e("create-hmac");var n=["sha1","sha224","sha256","sha384","sha512","md5","rmd160"].concat(Object.keys(e("browserify-sign/algos")));r.getHashes=function(){return n};var i=e("pbkdf2");r.pbkdf2=i.pbkdf2,r.pbkdf2Sync=i.pbkdf2Sync;var s=e("browserify-aes");["Cipher","createCipher","Cipheriv","createCipheriv","Decipher","createDecipher","Decipheriv","createDecipheriv","getCiphers","listCiphers"].forEach(function(e){r[e]=s[e]});var o=e("diffie-hellman");["DiffieHellmanGroup","createDiffieHellmanGroup","getDiffieHellman","createDiffieHellman","DiffieHellman"].forEach(function(e){r[e]=o[e]});var a=e("browserify-sign");["createSign","Sign","createVerify","Verify"].forEach(function(e){r[e]=a[e]}),r.createECDH=e("create-ecdh");var f=e("public-encrypt");["publicEncrypt","privateEncrypt","publicDecrypt","privateDecrypt"].forEach(function(e){r[e]=f[e]}),["createCredentials"].forEach(function(e){r[e]=function(){throw new Error(["sorry, "+e+" is not implemented yet","we accept pull requests","https://github.com/crypto-browserify/crypto-browserify"].join("\n"))}})},{"browserify-aes":54,"browserify-sign":70,"browserify-sign/algos":69,"create-ecdh":96,"create-hash":97,"create-hmac":109,"diffie-hellman":110,pbkdf2:116,"public-encrypt":117,randombytes:144}],51:[function(e,t,r){(function(r){function n(e,t,n){r.isBuffer(e)||(e=new r(e,"binary")),t/=8,n=n||0;for(var s,o,a=0,f=0,c=new r(t),u=new r(n),h=0,d=[];;){if(h++>0&&d.push(s),d.push(e),s=i(r.concat(d)),d=[],o=0,t>0)for(;;){if(0===t)break;if(o===s.length)break;c[a++]=s[o],t--,o++}if(n>0&&o!==s.length)for(;;){if(0===n)break;if(o===s.length)break;u[f++]=s[o],n--,o++}if(0===t&&0===n)break}for(o=0;o<s.length;o++)s[o]=0;return{key:c,iv:u}}var i=e("create-hash/md5");t.exports=n}).call(this,e("buffer").Buffer)},{buffer:46,"create-hash/md5":99}],52:[function(e,t,r){(function(e){function t(e){var t,r;return t=e>a||0>e?(r=Math.abs(e)%a,0>e?a-r:r):e}function n(e){for(var t=0;t<e.length;e++)e[t]=0;return!1}function i(){this.SBOX=[],this.INV_SBOX=[],this.SUB_MIX=[[],[],[],[]],this.INV_SUB_MIX=[[],[],[],[]],this.init(),this.RCON=[0,1,2,4,8,16,32,64,128,27,54]}function s(e){for(var t=e.length/4,r=new Array(t),n=-1;++n<t;)r[n]=e.readUInt32BE(4*n);return r}function o(e){this._key=s(e),this._doReset()}var a=Math.pow(2,32);i.prototype.init=function(){var e,t,r,n,i,s,o,a,f,c;for(e=function(){var e,r;for(r=[],t=e=0;256>e;t=++e)r.push(128>t?t<<1:t<<1^283);return r}(),i=0,f=0,t=c=0;256>c;t=++c)r=f^f<<1^f<<2^f<<3^f<<4,r=r>>>8^255&r^99,this.SBOX[i]=r,this.INV_SBOX[r]=i,s=e[i],o=e[s],a=e[o],n=257*e[r]^16843008*r,this.SUB_MIX[0][i]=n<<24|n>>>8,this.SUB_MIX[1][i]=n<<16|n>>>16,this.SUB_MIX[2][i]=n<<8|n>>>24,this.SUB_MIX[3][i]=n,n=16843009*a^65537*o^257*s^16843008*i,this.INV_SUB_MIX[0][r]=n<<24|n>>>8,this.INV_SUB_MIX[1][r]=n<<16|n>>>16,this.INV_SUB_MIX[2][r]=n<<8|n>>>24,this.INV_SUB_MIX[3][r]=n,0===i?i=f=1:(i=s^e[e[e[a^s]]],f^=e[e[f]]);return!0};var f=new i;o.blockSize=16,o.prototype.blockSize=o.blockSize,o.keySize=32,o.prototype.keySize=o.keySize,o.prototype._doReset=function(){var e,t,r,n,i,s;for(r=this._key,t=r.length,this._nRounds=t+6,i=4*(this._nRounds+1),this._keySchedule=[],n=0;i>n;n++)this._keySchedule[n]=t>n?r[n]:(s=this._keySchedule[n-1],n%t===0?(s=s<<8|s>>>24,s=f.SBOX[s>>>24]<<24|f.SBOX[s>>>16&255]<<16|f.SBOX[s>>>8&255]<<8|f.SBOX[255&s],s^=f.RCON[n/t|0]<<24):t>6&&n%t===4?s=f.SBOX[s>>>24]<<24|f.SBOX[s>>>16&255]<<16|f.SBOX[s>>>8&255]<<8|f.SBOX[255&s]:void 0,this._keySchedule[n-t]^s);for(this._invKeySchedule=[],e=0;i>e;e++)n=i-e,s=this._keySchedule[n-(e%4?0:4)],this._invKeySchedule[e]=4>e||4>=n?s:f.INV_SUB_MIX[0][f.SBOX[s>>>24]]^f.INV_SUB_MIX[1][f.SBOX[s>>>16&255]]^f.INV_SUB_MIX[2][f.SBOX[s>>>8&255]]^f.INV_SUB_MIX[3][f.SBOX[255&s]];return!0},o.prototype.encryptBlock=function(t){t=s(new e(t));var r=this._doCryptBlock(t,this._keySchedule,f.SUB_MIX,f.SBOX),n=new e(16);return n.writeUInt32BE(r[0],0),n.writeUInt32BE(r[1],4),n.writeUInt32BE(r[2],8),n.writeUInt32BE(r[3],12),n},o.prototype.decryptBlock=function(t){t=s(new e(t));var r=[t[3],t[1]];t[1]=r[0],t[3]=r[1];var n=this._doCryptBlock(t,this._invKeySchedule,f.INV_SUB_MIX,f.INV_SBOX),i=new e(16);return i.writeUInt32BE(n[0],0),i.writeUInt32BE(n[3],4),i.writeUInt32BE(n[2],8),i.writeUInt32BE(n[1],12),i},o.prototype.scrub=function(){n(this._keySchedule),n(this._invKeySchedule),n(this._key)},o.prototype._doCryptBlock=function(e,r,n,i){var s,o,a,f,c,u,h,d,p;o=e[0]^r[0],a=e[1]^r[1],f=e[2]^r[2],c=e[3]^r[3],s=4;for(var l=1;l<this._nRounds;l++)u=n[0][o>>>24]^n[1][a>>>16&255]^n[2][f>>>8&255]^n[3][255&c]^r[s++],h=n[0][a>>>24]^n[1][f>>>16&255]^n[2][c>>>8&255]^n[3][255&o]^r[s++],d=n[0][f>>>24]^n[1][c>>>16&255]^n[2][o>>>8&255]^n[3][255&a]^r[s++],p=n[0][c>>>24]^n[1][o>>>16&255]^n[2][a>>>8&255]^n[3][255&f]^r[s++],o=u,a=h,f=d,c=p;return u=(i[o>>>24]<<24|i[a>>>16&255]<<16|i[f>>>8&255]<<8|i[255&c])^r[s++],h=(i[a>>>24]<<24|i[f>>>16&255]<<16|i[c>>>8&255]<<8|i[255&o])^r[s++],d=(i[f>>>24]<<24|i[c>>>16&255]<<16|i[o>>>8&255]<<8|i[255&a])^r[s++],p=(i[c>>>24]<<24|i[o>>>16&255]<<16|i[a>>>8&255]<<8|i[255&f])^r[s++],[t(u),t(h),t(d),t(p)]},r.AES=o}).call(this,e("buffer").Buffer)},{buffer:46}],53:[function(e,t,r){(function(r){function n(e,t,i,a){if(!(this instanceof n))return new n(e,t,i);o.call(this),this._finID=r.concat([i,new r([0,0,0,1])]),i=r.concat([i,new r([0,0,0,2])]),this._cipher=new s.AES(t),this._prev=new r(i.length),this._cache=new r(""),this._secCache=new r(""),this._decrypt=a,this._alen=0,this._len=0,i.copy(this._prev),this._mode=e;var c=new r(4);c.fill(0),this._ghash=new f(this._cipher.encryptBlock(c)),this._authTag=null,this._called=!1}function i(e,t){var r=0;e.length!==t.length&&r++;for(var n=Math.min(e.length,t.length),i=-1;++i<n;)r+=e[i]^t[i];return r}var s=e("./aes"),o=e("./cipherBase"),a=e("inherits"),f=e("./ghash"),c=e("buffer-xor");a(n,o),t.exports=n,n.prototype._update=function(e){if(!this._called&&this._alen){var t=16-this._alen%16;16>t&&(t=new r(t),t.fill(0),this._ghash.update(t))}this._called=!0;var n=this._mode.encrypt(this,e);return this._ghash.update(this._decrypt?e:n),this._len+=e.length,n},n.prototype._final=function(){if(this._decrypt&&!this._authTag)throw new Error("Unsupported state or unable to authenticate data");var e=c(this._ghash["final"](8*this._alen,8*this._len),this._cipher.encryptBlock(this._finID));if(this._decrypt){if(i(e,this._authTag))throw new Error("Unsupported state or unable to authenticate data")}else this._authTag=e;this._cipher.scrub()},n.prototype.getAuthTag=function(){if(!this._decrypt&&r.isBuffer(this._authTag))return this._authTag;throw new Error("Attempting to get auth tag in unsupported state")},n.prototype.setAuthTag=function(e){if(!this._decrypt)throw new Error("Attempting to set auth tag in unsupported state");this._authTag=e},n.prototype.setAAD=function(e){if(this._called)throw new Error("Attempting to set AAD in unsupported state");this._ghash.update(e),this._alen+=e.length}}).call(this,e("buffer").Buffer)},{"./aes":52,"./cipherBase":55,"./ghash":58,buffer:46,"buffer-xor":67,inherits:193}],54:[function(e,t,r){function n(){return Object.keys(o)}var i=e("./encrypter");r.createCipher=r.Cipher=i.createCipher,r.createCipheriv=r.Cipheriv=i.createCipheriv;var s=e("./decrypter");r.createDecipher=r.Decipher=s.createDecipher,r.createDecipheriv=r.Decipheriv=s.createDecipheriv;var o=e("./modes");r.listCiphers=r.getCiphers=n},{"./decrypter":56,"./encrypter":57,"./modes":59}],55:[function(e,t,r){(function(r){function n(){i.call(this),this._base64Cache=new r("")}var i=e("stream").Transform,s=e("inherits");t.exports=n,s(n,i),n.prototype.update=function(e,t,n){"string"==typeof e&&(e=new r(e,t));var i=this._update(e);return n&&(i=this._toString(i,n)),i},n.prototype._transform=function(e,t,r){this.push(this._update(e)),r()},n.prototype._flush=function(e){try{this.push(this._final())}catch(t){return e(t)}e()},n.prototype["final"]=function(e){var t=this._final()||new r("");return e&&(t=this._toString(t,e,!0)),t},n.prototype._toString=function(e,t,n){if("base64"!==t)return e.toString(t);this._base64Cache=r.concat([this._base64Cache,e]);var i;if(n)return i=this._base64Cache,this._base64Cache=null,i.toString("base64");var s=this._base64Cache.length,o=s%3;if(!o)return i=this._base64Cache,this._base64Cache=new r(""),i.toString("base64");var a=s-o;return a?(i=this._base64Cache.slice(0,a),this._base64Cache=this._base64Cache.slice(-o),i.toString("base64")):""}}).call(this,e("buffer").Buffer)},{buffer:46,inherits:193,stream:163}],56:[function(e,t,r){(function(t){function n(e,r,s){return this instanceof n?(c.call(this),this._cache=new i,this._last=void 0,this._cipher=new f.AES(r),this._prev=new t(s.length),s.copy(this._prev),this._mode=e,void(this._autopadding=!0)):new n(e,r,s)}function i(){return this instanceof i?void(this.cache=new t("")):new i}function s(e){for(var t=e[15],r=-1;++r<t;)if(e[r+(16-t)]!==t)throw new Error("unable to decrypt data");return 16!==t?e.slice(0,16-t):void 0}function o(e,r,i){var s=h[e.toLowerCase()];if(!s)throw new TypeError("invalid suite type");if("string"==typeof i&&(i=new t(i)),"string"==typeof r&&(r=new t(r)),r.length!==s.key/8)throw new TypeError("invalid key length "+r.length);if(i.length!==s.iv)throw new TypeError("invalid iv length "+i.length);return"stream"===s.type?new d(b[s.mode],r,i,!0):"auth"===s.type?new p(b[s.mode],r,i,!0):new n(b[s.mode],r,i)}function a(e,t){var r=h[e.toLowerCase()];if(!r)throw new TypeError("invalid suite type");var n=l(t,r.key,r.iv);return o(e,n.key,n.iv)}var f=e("./aes"),c=e("./cipherBase"),u=e("inherits"),h=e("./modes"),d=e("./streamCipher"),p=e("./authCipher"),l=e("./EVP_BytesToKey");u(n,c),n.prototype._update=function(e){this._cache.add(e);for(var r,n,i=[];r=this._cache.get(this._autopadding);)n=this._mode.decrypt(this,r),i.push(n);return t.concat(i)},n.prototype._final=function(){var e=this._cache.flush();if(this._autopadding)return s(this._mode.decrypt(this,e));if(e)throw new Error("data not multiple of block length")},n.prototype.setAutoPadding=function(e){this._autopadding=!!e},i.prototype.add=function(e){this.cache=t.concat([this.cache,e])},i.prototype.get=function(e){var t;if(e){if(this.cache.length>16)return t=this.cache.slice(0,16),this.cache=this.cache.slice(16),t}else if(this.cache.length>=16)return t=this.cache.slice(0,16),this.cache=this.cache.slice(16),t;return null},i.prototype.flush=function(){return this.cache.length?this.cache:void 0};var b={ECB:e("./modes/ecb"),CBC:e("./modes/cbc"),CFB:e("./modes/cfb"),CFB8:e("./modes/cfb8"),CFB1:e("./modes/cfb1"),OFB:e("./modes/ofb"),CTR:e("./modes/ctr"),GCM:e("./modes/ctr")};r.createDecipher=a,r.createDecipheriv=o}).call(this,e("buffer").Buffer)},{"./EVP_BytesToKey":51,"./aes":52,"./authCipher":53,"./cipherBase":55,"./modes":59,"./modes/cbc":60,"./modes/cfb":61,"./modes/cfb1":62,"./modes/cfb8":63,"./modes/ctr":64,"./modes/ecb":65,"./modes/ofb":66,"./streamCipher":68,buffer:46,inherits:193}],57:[function(e,t,r){(function(t){function n(e,r,s){return this instanceof n?(f.call(this),this._cache=new i,this._cipher=new a.AES(r),this._prev=new t(s.length),s.copy(this._prev),this._mode=e,void(this._autopadding=!0)):new n(e,r,s)}function i(){return this instanceof i?void(this.cache=new t("")):new i}function s(e,r,i){var s=u[e.toLowerCase()];if(!s)throw new TypeError("invalid suite type");if("string"==typeof i&&(i=new t(i)),"string"==typeof r&&(r=new t(r)),r.length!==s.key/8)throw new TypeError("invalid key length "+r.length);if(i.length!==s.iv)throw new TypeError("invalid iv length "+i.length);return"stream"===s.type?new d(l[s.mode],r,i):"auth"===s.type?new p(l[s.mode],r,i):new n(l[s.mode],r,i)}function o(e,t){var r=u[e.toLowerCase()];if(!r)throw new TypeError("invalid suite type");var n=h(t,r.key,r.iv);return s(e,n.key,n.iv)}var a=e("./aes"),f=e("./cipherBase"),c=e("inherits"),u=e("./modes"),h=e("./EVP_BytesToKey"),d=e("./streamCipher"),p=e("./authCipher");c(n,f),n.prototype._update=function(e){this._cache.add(e);for(var r,n,i=[];r=this._cache.get();)n=this._mode.encrypt(this,r),i.push(n);return t.concat(i)},n.prototype._final=function(){var e=this._cache.flush();if(this._autopadding)return e=this._mode.encrypt(this,e),this._cipher.scrub(),e;if("10101010101010101010101010101010"!==e.toString("hex"))throw this._cipher.scrub(),new Error("data not multiple of block length")},n.prototype.setAutoPadding=function(e){this._autopadding=!!e},i.prototype.add=function(e){this.cache=t.concat([this.cache,e])},i.prototype.get=function(){if(this.cache.length>15){var e=this.cache.slice(0,16);return this.cache=this.cache.slice(16),e}return null},i.prototype.flush=function(){for(var e=16-this.cache.length,r=new t(e),n=-1;++n<e;)r.writeUInt8(e,n);var i=t.concat([this.cache,r]);return i};var l={ECB:e("./modes/ecb"),CBC:e("./modes/cbc"),CFB:e("./modes/cfb"),CFB8:e("./modes/cfb8"),CFB1:e("./modes/cfb1"),OFB:e("./modes/ofb"),CTR:e("./modes/ctr"),GCM:e("./modes/ctr")};r.createCipheriv=s,r.createCipher=o}).call(this,e("buffer").Buffer)},{"./EVP_BytesToKey":51,"./aes":52,"./authCipher":53,"./cipherBase":55,"./modes":59,"./modes/cbc":60,"./modes/cfb":61,"./modes/cfb1":62,"./modes/cfb8":63,"./modes/ctr":64,"./modes/ecb":65,"./modes/ofb":66,"./streamCipher":68,buffer:46,inherits:193}],58:[function(e,t,r){(function(e){function r(t){this.h=t,this.state=new e(16),this.state.fill(0),this.cache=new e("")}function n(e){return[e.readUInt32BE(0),e.readUInt32BE(4),e.readUInt32BE(8),e.readUInt32BE(12)]}function i(t){t=t.map(s);var r=new e(16);return r.writeUInt32BE(t[0],0),r.writeUInt32BE(t[1],4),r.writeUInt32BE(t[2],8),r.writeUInt32BE(t[3],12),r}function s(e){var t,r;return t=e>f||0>e?(r=Math.abs(e)%f,0>e?f-r:r):e}function o(e,t){return[e[0]^t[0],e[1]^t[1],e[2]^t[2],e[3]^t[3]]}var a=new e(16);a.fill(0),t.exports=r,r.prototype.ghash=function(e){for(var t=-1;++t<e.length;)this.state[t]^=e[t];this._multiply()},r.prototype._multiply=function(){for(var e,t,r,s=n(this.h),a=[0,0,0,0],f=-1;++f<128;){for(t=0!==(this.state[~~(f/8)]&1<<7-f%8),t&&(a=o(a,s)),r=0!==(1&s[3]),e=3;e>0;e--)s[e]=s[e]>>>1|(1&s[e-1])<<31;s[0]=s[0]>>>1,r&&(s[0]=s[0]^225<<24)}this.state=i(a)},r.prototype.update=function(t){this.cache=e.concat([this.cache,t]);for(var r;this.cache.length>=16;)r=this.cache.slice(0,16),this.cache=this.cache.slice(16),this.ghash(r)},r.prototype["final"]=function(t,r){return this.cache.length&&this.ghash(e.concat([this.cache,a],16)),this.ghash(i([0,t,0,r])),this.state};var f=Math.pow(2,32)}).call(this,e("buffer").Buffer)},{buffer:46}],59:[function(e,t,r){r["aes-128-ecb"]={cipher:"AES",key:128,iv:0,mode:"ECB",type:"block"},r["aes-192-ecb"]={cipher:"AES",key:192,iv:0,mode:"ECB",type:"block"},r["aes-256-ecb"]={cipher:"AES",key:256,iv:0,mode:"ECB",type:"block"},r["aes-128-cbc"]={cipher:"AES",key:128,iv:16,mode:"CBC",type:"block"},r["aes-192-cbc"]={cipher:"AES",key:192,iv:16,mode:"CBC",type:"block"},r["aes-256-cbc"]={cipher:"AES",key:256,iv:16,mode:"CBC",type:"block"},r.aes128=r["aes-128-cbc"],r.aes192=r["aes-192-cbc"],r.aes256=r["aes-256-cbc"],r["aes-128-cfb"]={cipher:"AES",key:128,iv:16,mode:"CFB",type:"stream"},r["aes-192-cfb"]={cipher:"AES",key:192,iv:16,mode:"CFB",type:"stream"},r["aes-256-cfb"]={cipher:"AES",key:256,iv:16,mode:"CFB",type:"stream"},r["aes-128-cfb8"]={cipher:"AES",key:128,iv:16,mode:"CFB8",type:"stream"},r["aes-192-cfb8"]={cipher:"AES",key:192,iv:16,mode:"CFB8",type:"stream"},r["aes-256-cfb8"]={cipher:"AES",key:256,iv:16,mode:"CFB8",type:"stream"},r["aes-128-cfb1"]={cipher:"AES",key:128,iv:16,mode:"CFB1",type:"stream"},r["aes-192-cfb1"]={cipher:"AES",key:192,iv:16,mode:"CFB1",type:"stream"},r["aes-256-cfb1"]={cipher:"AES",key:256,iv:16,mode:"CFB1",type:"stream"},r["aes-128-ofb"]={cipher:"AES",key:128,iv:16,mode:"OFB",type:"stream"},r["aes-192-ofb"]={cipher:"AES",key:192,iv:16,mode:"OFB",type:"stream"},r["aes-256-ofb"]={cipher:"AES",key:256,iv:16,mode:"OFB",type:"stream"},r["aes-128-ctr"]={cipher:"AES",key:128,iv:16,mode:"CTR",type:"stream"},r["aes-192-ctr"]={cipher:"AES",key:192,iv:16,mode:"CTR",type:"stream"},r["aes-256-ctr"]={cipher:"AES",key:256,iv:16,mode:"CTR",type:"stream"},r["aes-128-gcm"]={cipher:"AES",key:128,iv:12,mode:"GCM",type:"auth"},r["aes-192-gcm"]={cipher:"AES",key:192,iv:12,mode:"GCM",type:"auth"},r["aes-256-gcm"]={cipher:"AES",key:256,iv:12,mode:"GCM",type:"auth"}},{}],60:[function(e,t,r){var n=e("buffer-xor");r.encrypt=function(e,t){var r=n(t,e._prev);return e._prev=e._cipher.encryptBlock(r),e._prev},r.decrypt=function(e,t){var r=e._prev;e._prev=t;var i=e._cipher.decryptBlock(t);return n(i,r)}},{"buffer-xor":67}],61:[function(e,t,r){(function(t){function n(e,r,n){var s=r.length,o=i(r,e._cache);return e._cache=e._cache.slice(s),e._prev=t.concat([e._prev,n?r:o]),o}var i=e("buffer-xor");r.encrypt=function(e,r,i){for(var s,o=new t("");r.length;){if(0===e._cache.length&&(e._cache=e._cipher.encryptBlock(e._prev),e._prev=new t("")),!(e._cache.length<=r.length)){o=t.concat([o,n(e,r,i)]);break}s=e._cache.length,o=t.concat([o,n(e,r.slice(0,s),i)]),r=r.slice(s)}return o}}).call(this,e("buffer").Buffer)},{buffer:46,"buffer-xor":67}],62:[function(e,t,r){(function(e){function t(e,t,r){for(var i,s,o,a=-1,f=8,c=0;++a<f;)i=e._cipher.encryptBlock(e._prev),s=t&1<<7-a?128:0,o=i[0]^s,c+=(128&o)>>a%8,e._prev=n(e._prev,r?s:o);return c}function n(t,r){var n=t.length,i=-1,s=new e(t.length);for(t=e.concat([t,new e([r])]);++i<n;)s[i]=t[i]<<1|t[i+1]>>7;return s}r.encrypt=function(r,n,i){for(var s=n.length,o=new e(s),a=-1;++a<s;)o[a]=t(r,n[a],i);return o}}).call(this,e("buffer").Buffer)},{buffer:46}],63:[function(e,t,r){(function(e){function t(t,r,n){var i=t._cipher.encryptBlock(t._prev),s=i[0]^r;return t._prev=e.concat([t._prev.slice(1),new e([n?r:s])]),s}r.encrypt=function(r,n,i){for(var s=n.length,o=new e(s),a=-1;++a<s;)o[a]=t(r,n[a],i);return o}}).call(this,e("buffer").Buffer)},{buffer:46}],64:[function(e,t,r){(function(t){function n(e){for(var t,r=e.length;r--;){if(t=e.readUInt8(r),255!==t){t++,e.writeUInt8(t,r);break}e.writeUInt8(0,r)}}function i(e){var t=e._cipher.encryptBlock(e._prev);return n(e._prev),t}var s=e("buffer-xor");r.encrypt=function(e,r){for(;e._cache.length<r.length;)e._cache=t.concat([e._cache,i(e)]);var n=e._cache.slice(0,r.length);return e._cache=e._cache.slice(r.length),s(r,n)}}).call(this,e("buffer").Buffer)},{buffer:46,"buffer-xor":67}],65:[function(e,t,r){r.encrypt=function(e,t){return e._cipher.encryptBlock(t)},r.decrypt=function(e,t){return e._cipher.decryptBlock(t)}},{}],66:[function(e,t,r){(function(t){function n(e){return e._prev=e._cipher.encryptBlock(e._prev),e._prev}var i=e("buffer-xor");r.encrypt=function(e,r){for(;e._cache.length<r.length;)e._cache=t.concat([e._cache,n(e)]);var s=e._cache.slice(0,r.length);return e._cache=e._cache.slice(r.length),i(r,s)}}).call(this,e("buffer").Buffer)},{buffer:46,"buffer-xor":67}],67:[function(e,t,r){(function(e){t.exports=function(t,r){for(var n=Math.min(t.length,r.length),i=new e(n),s=0;n>s;++s)i[s]=t[s]^r[s];return i}}).call(this,e("buffer").Buffer)},{buffer:46}],68:[function(e,t,r){(function(r){function n(e,t,o,a){return this instanceof n?(s.call(this),this._cipher=new i.AES(t),this._prev=new r(o.length),this._cache=new r(""),this._secCache=new r(""),this._decrypt=a,o.copy(this._prev),void(this._mode=e)):new n(e,t,o)}var i=e("./aes"),s=e("./cipherBase"),o=e("inherits");o(n,s),t.exports=n,n.prototype._update=function(e){return this._mode.encrypt(this,e,this._decrypt)},n.prototype._final=function(){this._cipher.scrub()}}).call(this,e("buffer").Buffer)},{"./aes":52,"./cipherBase":55,buffer:46,inherits:193}],69:[function(e,t,r){(function(e){"use strict";r["RSA-SHA224"]=r.sha224WithRSAEncryption={sign:"rsa",hash:"sha224",id:new e("302d300d06096086480165030402040500041c","hex")},r["RSA-SHA256"]=r.sha256WithRSAEncryption={sign:"rsa",hash:"sha256",id:new e("3031300d060960864801650304020105000420","hex")},r["RSA-SHA384"]=r.sha384WithRSAEncryption={sign:"rsa",hash:"sha384",id:new e("3041300d060960864801650304020205000430","hex")},r["RSA-SHA512"]=r.sha512WithRSAEncryption={sign:"rsa",hash:"sha512",id:new e("3051300d060960864801650304020305000440","hex")},r["RSA-SHA1"]={sign:"rsa",hash:"sha1",id:new e("3021300906052b0e03021a05000414","hex")},r["ecdsa-with-SHA1"]={sign:"ecdsa",hash:"sha1",id:new e("","hex")},r.DSA=r["DSA-SHA1"]=r["DSA-SHA"]={sign:"dsa",hash:"sha1",id:new e("","hex")},r["DSA-SHA224"]=r["DSA-WITH-SHA224"]={sign:"dsa",hash:"sha224",id:new e("","hex")},r["DSA-SHA256"]=r["DSA-WITH-SHA256"]={sign:"dsa",hash:"sha256",id:new e("","hex")},r["DSA-SHA384"]=r["DSA-WITH-SHA384"]={sign:"dsa",hash:"sha384",id:new e("","hex")},r["DSA-SHA512"]=r["DSA-WITH-SHA512"]={sign:"dsa",hash:"sha512",id:new e("","hex")},r["DSA-RIPEMD160"]={sign:"dsa",hash:"rmd160",id:new e("","hex")},r["RSA-RIPEMD160"]=r.ripemd160WithRSA={sign:"rsa",hash:"rmd160",id:new e("3021300906052b2403020105000414","hex")},r["RSA-MD5"]=r.md5WithRSAEncryption={sign:"rsa",hash:"md5",id:new e("3020300c06082a864886f70d020505000410","hex")}}).call(this,e("buffer").Buffer)},{buffer:46}],70:[function(e,t,r){(function(t){"use strict";function n(e){return new s(e)}function i(e){return new o(e)}function s(e){c.Writable.call(this);var t=p[e];if(!t)throw new Error("Unknown message digest");this._hashType=t.hash,this._hash=d(t.hash),this._tag=t.id,this._signType=t.sign}function o(e){c.Writable.call(this);var t=p[e];if(!t)throw new Error("Unknown message digest");this._hash=d(t.hash),this._tag=t.id,this._signType=t.sign}var a=e("./sign"),f=e("./verify"),c=e("stream"),u=e("inherits"),h=e("./algos"),d=e("create-hash"),p={};Object.keys(h).forEach(function(e){p[e]=p[e.toLowerCase()]=h[e]}),r.createSign=r.Sign=n,r.createVerify=r.Verify=i,u(s,c.Writable),s.prototype._write=function(e,t,r){this._hash.update(e),r()},s.prototype.update=function(e,r){return"string"==typeof e&&(e=new t(e,r)),this._hash.update(e),this},s.prototype.sign=function(e,r){this.end();var n=this._hash.digest(),i=a(t.concat([this._tag,n]),e,this._hashType,this._signType);return r&&(i=i.toString(r)),i},u(o,c.Writable),o.prototype._write=function(e,t,r){this._hash.update(e),r()},o.prototype.update=function(e,r){return"string"==typeof e&&(e=new t(e,r)),this._hash.update(e),this},o.prototype.verify=function(e,r,n){this.end();var i=this._hash.digest();return"string"==typeof r&&(r=new t(r,n)),f(r,t.concat([this._tag,i]),e,this._signType)}}).call(this,e("buffer").Buffer)},{"./algos":69,"./sign":93,"./verify":94,buffer:46,"create-hash":97,inherits:193,stream:163}],71:[function(e,t,r){"use strict";r["1.3.132.0.10"]="secp256k1",r["1.3.132.0.33"]="p224",r["1.2.840.10045.3.1.1"]="p192",r["1.2.840.10045.3.1.7"]="p256"},{}],72:[function(e,t,r){(function(r){function n(e){var t=s(e),r=t.toRed(o.mont(e.modulus)).redPow(new o(e.publicExponent)).fromRed();return{blinder:r,unblinder:t.invm(e.modulus)}}function i(e,t){var i=n(t),s=t.modulus.byteLength(),a=(o.mont(t.modulus),new o(e).mul(i.blinder).mod(t.modulus)),f=a.toRed(o.mont(t.prime1)),c=a.toRed(o.mont(t.prime2)),u=t.coefficient,h=t.prime1,d=t.prime2,p=f.redPow(t.exponent1),l=c.redPow(t.exponent2);p=p.fromRed(),l=l.fromRed();var b=p.isub(l).imul(u).mod(h);b.imul(d),l.iadd(b);var g=new r(l.imul(i.unblinder).mod(t.modulus).toArray());if(g.length<s){var m=new r(s-g.length);m.fill(0),g=r.concat([m,g],s)}return g}function s(e){for(var t=e.modulus.byteLength(),r=new o(a(t));r.cmp(e.modulus)>=0||!r.mod(e.prime1)||!r.mod(e.prime2);)r=new o(a(t));return r}var o=e("bn.js"),a=e("randombytes");t.exports=i,i.getr=s}).call(this,e("buffer").Buffer)},{"bn.js":170,buffer:46,randombytes:144}],73:[function(e,t,r){(function(r){var n=e("create-hash");t.exports=function(e,t,i){i/=8;for(var s,o,a,f=0,c=new r(i),u=0;;){if(s=n("md5"),u++>0&&s.update(o),s.update(e),s.update(t),o=s.digest(),a=0,i>0)for(;;){if(0===i)break;if(a===o.length)break;c[f++]=o[a++],i--}if(0===i)break}for(a=0;a<o.length;a++)o[a]=0;return c}}).call(this,e("buffer").Buffer)},{buffer:46,"create-hash":97}],74:[function(e,t,r){t.exports={"2.16.840.1.101.3.4.1.1":"aes-128-ecb","2.16.840.1.101.3.4.1.2":"aes-128-cbc","2.16.840.1.101.3.4.1.3":"aes-128-ofb","2.16.840.1.101.3.4.1.4":"aes-128-cfb","2.16.840.1.101.3.4.1.21":"aes-192-ecb","2.16.840.1.101.3.4.1.22":"aes-192-cbc","2.16.840.1.101.3.4.1.23":"aes-192-ofb","2.16.840.1.101.3.4.1.24":"aes-192-cfb","2.16.840.1.101.3.4.1.41":"aes-256-ecb","2.16.840.1.101.3.4.1.42":"aes-256-cbc","2.16.840.1.101.3.4.1.43":"aes-256-ofb","2.16.840.1.101.3.4.1.44":"aes-256-cfb"}},{}],75:[function(e,t,r){var n=e("asn1.js"),i=n.define("RSAPrivateKey",function(){this.seq().obj(this.key("version")["int"](),this.key("modulus")["int"](),this.key("publicExponent")["int"](),this.key("privateExponent")["int"](),this.key("prime1")["int"](),this.key("prime2")["int"](),this.key("exponent1")["int"](),this.key("exponent2")["int"](),this.key("coefficient")["int"]())});r.RSAPrivateKey=i;var s=n.define("RSAPublicKey",function(){this.seq().obj(this.key("modulus")["int"](),this.key("publicExponent")["int"]())});r.RSAPublicKey=s;var o=n.define("SubjectPublicKeyInfo",function(){this.seq().obj(this.key("algorithm").use(a),this.key("subjectPublicKey").bitstr())});r.PublicKey=o;var a=n.define("AlgorithmIdentifier",function(){this.seq().obj(this.key("algorithm").objid(),this.key("none").null_().optional(),this.key("curve").objid().optional(),this.key("params").seq().obj(this.key("p")["int"](),this.key("q")["int"](),this.key("g")["int"]()).optional())}),f=n.define("PrivateKeyInfo",function(){this.seq().obj(this.key("version")["int"](),this.key("algorithm").use(a),this.key("subjectPrivateKey").octstr())});r.PrivateKey=f;var c=n.define("EncryptedPrivateKeyInfo",function(){this.seq().obj(this.key("algorithm").seq().obj(this.key("id").objid(),this.key("decrypt").seq().obj(this.key("kde").seq().obj(this.key("id").objid(),this.key("kdeparams").seq().obj(this.key("salt").octstr(),this.key("iters")["int"]())),this.key("cipher").seq().obj(this.key("algo").objid(),this.key("iv").octstr()))),this.key("subjectPrivateKey").octstr())});r.EncryptedPrivateKey=c;var u=n.define("DSAPrivateKey",function(){this.seq().obj(this.key("version")["int"](),this.key("p")["int"](),this.key("q")["int"](),this.key("g")["int"](),this.key("pub_key")["int"](),this.key("priv_key")["int"]())});r.DSAPrivateKey=u,r.DSAparam=n.define("DSAparam",function(){this["int"]()});var h=n.define("ECPrivateKey",function(){this.seq().obj(this.key("version")["int"](),this.key("privateKey").octstr(),this.key("parameters").optional().explicit(0).use(d),this.key("publicKey").optional().explicit(1).bitstr())});r.ECPrivateKey=h;var d=n.define("ECParameters",function(){this.choice({
namedCurve:this.objid()})});r.signature=n.define("signature",function(){this.seq().obj(this.key("r")["int"](),this.key("s")["int"]())})},{"asn1.js":78}],76:[function(e,t,r){(function(r){var n=/Proc-Type: 4,ENCRYPTED\r?\nDEK-Info: AES-((?:128)|(?:192)|(?:256))-CBC,([0-9A-H]+)\r?\n\r?\n([0-9A-z\n\r\+\/\=]+)\r?\n/m,i=/^-----BEGIN (.*) KEY-----\r?\n/m,s=/^-----BEGIN (.*) KEY-----\r?\n([0-9A-z\n\r\+\/\=]+)\r?\n-----END \1 KEY-----$/m,o=e("./EVP_BytesToKey"),a=e("browserify-aes");t.exports=function(e,t){var f,c=e.toString(),u=c.match(n);if(u){var h="aes"+u[1],d=new r(u[2],"hex"),p=new r(u[3].replace(/\r?\n/g,""),"base64"),l=o(t,d.slice(0,8),parseInt(u[1])),b=[],g=a.createDecipheriv(h,l,d);b.push(g.update(p)),b.push(g["final"]()),f=r.concat(b)}else{var m=c.match(s);f=new r(m[2].replace(/\r?\n/g,""),"base64")}var y=c.match(i)[1]+" KEY";return{tag:y,data:f}}}).call(this,e("buffer").Buffer)},{"./EVP_BytesToKey":73,"browserify-aes":54,buffer:46}],77:[function(e,t,r){(function(r){function n(e){var t;"object"!=typeof e||r.isBuffer(e)||(t=e.passphrase,e=e.key),"string"==typeof e&&(e=new r(e));var n,o,f=a(e,t),c=f.tag,u=f.data;switch(c){case"PUBLIC KEY":switch(o=s.PublicKey.decode(u,"der"),n=o.algorithm.algorithm.join(".")){case"1.2.840.113549.1.1.1":return s.RSAPublicKey.decode(o.subjectPublicKey.data,"der");case"1.2.840.10045.2.1":return o.subjectPrivateKey=o.subjectPublicKey,{type:"ec",data:o};case"1.2.840.10040.4.1":return o.algorithm.params.pub_key=s.DSAparam.decode(o.subjectPublicKey.data,"der"),{type:"dsa",data:o.algorithm.params};default:throw new Error("unknown key id "+n)}throw new Error("unknown key type "+c);case"ENCRYPTED PRIVATE KEY":u=s.EncryptedPrivateKey.decode(u,"der"),u=i(u,t);case"PRIVATE KEY":switch(o=s.PrivateKey.decode(u,"der"),n=o.algorithm.algorithm.join(".")){case"1.2.840.113549.1.1.1":return s.RSAPrivateKey.decode(o.subjectPrivateKey,"der");case"1.2.840.10045.2.1":return{curve:o.algorithm.curve,privateKey:s.ECPrivateKey.decode(o.subjectPrivateKey,"der").privateKey};case"1.2.840.10040.4.1":return o.algorithm.params.priv_key=s.DSAparam.decode(o.subjectPrivateKey,"der"),{type:"dsa",params:o.algorithm.params};default:throw new Error("unknown key id "+n)}throw new Error("unknown key type "+c);case"RSA PUBLIC KEY":return s.RSAPublicKey.decode(u,"der");case"RSA PRIVATE KEY":return s.RSAPrivateKey.decode(u,"der");case"DSA PRIVATE KEY":return{type:"dsa",params:s.DSAPrivateKey.decode(u,"der")};case"EC PRIVATE KEY":return u=s.ECPrivateKey.decode(u,"der"),{curve:u.parameters.value,privateKey:u.privateKey};default:throw new Error("unknown key type "+c)}}function i(e,t){var n=e.algorithm.decrypt.kde.kdeparams.salt,i=parseInt(e.algorithm.decrypt.kde.kdeparams.iters.toString(),10),s=o[e.algorithm.decrypt.cipher.algo.join(".")],a=e.algorithm.decrypt.cipher.iv,u=e.subjectPrivateKey,h=parseInt(s.split("-")[1],10)/8,d=c.pbkdf2Sync(t,n,i,h),p=f.createDecipheriv(s,d,a),l=[];return l.push(p.update(u)),l.push(p["final"]()),r.concat(l)}var s=e("./asn1"),o=e("./aesid.json"),a=e("./fixProc"),f=e("browserify-aes"),c=e("pbkdf2");t.exports=n,n.signature=s.signature}).call(this,e("buffer").Buffer)},{"./aesid.json":74,"./asn1":75,"./fixProc":76,"browserify-aes":54,buffer:46,pbkdf2:116}],78:[function(e,t,r){var n=r;n.bignum=e("bn.js"),n.define=e("./asn1/api").define,n.base=e("./asn1/base"),n.constants=e("./asn1/constants"),n.decoders=e("./asn1/decoders"),n.encoders=e("./asn1/encoders")},{"./asn1/api":79,"./asn1/base":81,"./asn1/constants":85,"./asn1/decoders":87,"./asn1/encoders":90,"bn.js":170}],79:[function(e,t,r){function n(e,t){this.name=e,this.body=t,this.decoders={},this.encoders={}}var i=e("../asn1"),s=e("inherits"),o=r;o.define=function(e,t){return new n(e,t)},n.prototype._createNamed=function(t){var r;try{r=e("vm").runInThisContext("(function "+this.name+"(entity) {\n this._initNamed(entity);\n})")}catch(n){r=function(e){this._initNamed(e)}}return s(r,t),r.prototype._initNamed=function(e){t.call(this,e)},new r(this)},n.prototype._getDecoder=function(e){return this.decoders.hasOwnProperty(e)||(this.decoders[e]=this._createNamed(i.decoders[e])),this.decoders[e]},n.prototype.decode=function(e,t,r){return this._getDecoder(t).decode(e,r)},n.prototype._getEncoder=function(e){return this.encoders.hasOwnProperty(e)||(this.encoders[e]=this._createNamed(i.encoders[e])),this.encoders[e]},n.prototype.encode=function(e,t,r){return this._getEncoder(t).encode(e,r)}},{"../asn1":78,inherits:193,vm:168}],80:[function(e,t,r){function n(e,t){return o.call(this,t),a.isBuffer(e)?(this.base=e,this.offset=0,void(this.length=e.length)):void this.error("Input not Buffer")}function i(e,t){if(Array.isArray(e))this.length=0,this.value=e.map(function(e){return e instanceof i||(e=new i(e,t)),this.length+=e.length,e},this);else if("number"==typeof e){if(!(e>=0&&255>=e))return t.error("non-byte EncoderBuffer value");this.value=e,this.length=1}else if("string"==typeof e)this.value=e,this.length=a.byteLength(e);else{if(!a.isBuffer(e))return t.error("Unsupported type: "+typeof e);this.value=e,this.length=e.length}}var s=e("inherits"),o=e("../base").Reporter,a=e("buffer").Buffer;s(n,o),r.DecoderBuffer=n,n.prototype.save=function(){return{offset:this.offset,reporter:o.prototype.save.call(this)}},n.prototype.restore=function(e){var t=new n(this.base);return t.offset=e.offset,t.length=this.offset,this.offset=e.offset,o.prototype.restore.call(this,e.reporter),t},n.prototype.isEmpty=function(){return this.offset===this.length},n.prototype.readUInt8=function(e){return this.offset+1<=this.length?this.base.readUInt8(this.offset++,!0):this.error(e||"DecoderBuffer overrun")},n.prototype.skip=function(e,t){if(!(this.offset+e<=this.length))return this.error(t||"DecoderBuffer overrun");var r=new n(this.base);return r._reporterState=this._reporterState,r.offset=this.offset,r.length=this.offset+e,this.offset+=e,r},n.prototype.raw=function(e){return this.base.slice(e?e.offset:this.offset,this.length)},r.EncoderBuffer=i,i.prototype.join=function(e,t){return e||(e=new a(this.length)),t||(t=0),0===this.length?e:(Array.isArray(this.value)?this.value.forEach(function(r){r.join(e,t),t+=r.length}):("number"==typeof this.value?e[t]=this.value:"string"==typeof this.value?e.write(this.value,t):a.isBuffer(this.value)&&this.value.copy(e,t),t+=this.length),e)}},{"../base":81,buffer:46,inherits:193}],81:[function(e,t,r){var n=r;n.Reporter=e("./reporter").Reporter,n.DecoderBuffer=e("./buffer").DecoderBuffer,n.EncoderBuffer=e("./buffer").EncoderBuffer,n.Node=e("./node")},{"./buffer":80,"./node":82,"./reporter":83}],82:[function(e,t,r){function n(e,t){var r={};this._baseState=r,r.enc=e,r.parent=t||null,r.children=null,r.tag=null,r.args=null,r.reverseArgs=null,r.choice=null,r.optional=!1,r.any=!1,r.obj=!1,r.use=null,r.useDecoder=null,r.key=null,r["default"]=null,r.explicit=null,r.implicit=null,r.parent||(r.children=[],this._wrap())}var i=e("../base").Reporter,s=e("../base").EncoderBuffer,o=e("minimalistic-assert"),a=["seq","seqof","set","setof","octstr","bitstr","objid","bool","gentime","utctime","null_","enum","int","ia5str"],f=["key","obj","use","optional","explicit","implicit","def","choice","any"].concat(a),c=["_peekTag","_decodeTag","_use","_decodeStr","_decodeObjid","_decodeTime","_decodeNull","_decodeInt","_decodeBool","_decodeList","_encodeComposite","_encodeStr","_encodeObjid","_encodeTime","_encodeNull","_encodeInt","_encodeBool"];t.exports=n;var u=["enc","parent","children","tag","args","reverseArgs","choice","optional","any","obj","use","alteredUse","key","default","explicit","implicit"];n.prototype.clone=function(){var e=this._baseState,t={};u.forEach(function(r){t[r]=e[r]});var r=new this.constructor(t.parent);return r._baseState=t,r},n.prototype._wrap=function(){var e=this._baseState;f.forEach(function(t){this[t]=function(){var r=new this.constructor(this);return e.children.push(r),r[t].apply(r,arguments)}},this)},n.prototype._init=function(e){var t=this._baseState;o(null===t.parent),e.call(this),t.children=t.children.filter(function(e){return e._baseState.parent===this},this),o.equal(t.children.length,1,"Root node can have only one child")},n.prototype._useArgs=function(e){var t=this._baseState,r=e.filter(function(e){return e instanceof this.constructor},this);e=e.filter(function(e){return!(e instanceof this.constructor)},this),0!==r.length&&(o(null===t.children),t.children=r,r.forEach(function(e){e._baseState.parent=this},this)),0!==e.length&&(o(null===t.args),t.args=e,t.reverseArgs=e.map(function(e){if("object"!=typeof e||e.constructor!==Object)return e;var t={};return Object.keys(e).forEach(function(r){r==(0|r)&&(r|=0);var n=e[r];t[n]=r}),t}))},c.forEach(function(e){n.prototype[e]=function(){var t=this._baseState;throw new Error(e+" not implemented for encoding: "+t.enc)}}),a.forEach(function(e){n.prototype[e]=function(){var t=this._baseState,r=Array.prototype.slice.call(arguments);return o(null===t.tag),t.tag=e,this._useArgs(r),this}}),n.prototype.use=function(e){var t=this._baseState;return o(null===t.use),t.use=e,this},n.prototype.optional=function(){var e=this._baseState;return e.optional=!0,this},n.prototype.def=function(e){var t=this._baseState;return o(null===t["default"]),t["default"]=e,t.optional=!0,this},n.prototype.explicit=function(e){var t=this._baseState;return o(null===t.explicit&&null===t.implicit),t.explicit=e,this},n.prototype.implicit=function(e){var t=this._baseState;return o(null===t.explicit&&null===t.implicit),t.implicit=e,this},n.prototype.obj=function(){var e=this._baseState,t=Array.prototype.slice.call(arguments);return e.obj=!0,0!==t.length&&this._useArgs(t),this},n.prototype.key=function(e){var t=this._baseState;return o(null===t.key),t.key=e,this},n.prototype.any=function(){var e=this._baseState;return e.any=!0,this},n.prototype.choice=function(e){var t=this._baseState;return o(null===t.choice),t.choice=e,this._useArgs(Object.keys(e).map(function(t){return e[t]})),this},n.prototype._decode=function(e){var t=this._baseState;if(null===t.parent)return e.wrapResult(t.children[0]._decode(e));var r,n=t["default"],i=!0;if(null!==t.key&&(r=e.enterKey(t.key)),t.optional){var s=null;if(null!==t.explicit?s=t.explicit:null!==t.implicit?s=t.implicit:null!==t.tag&&(s=t.tag),null!==s||t.any){if(i=this._peekTag(e,s,t.any),e.isError(i))return i}else{var o=e.save();try{null===t.choice?this._decodeGeneric(t.tag,e):this._decodeChoice(e),i=!0}catch(a){i=!1}e.restore(o)}}var f;if(t.obj&&i&&(f=e.enterObject()),i){if(null!==t.explicit){var c=this._decodeTag(e,t.explicit);if(e.isError(c))return c;e=c}if(null===t.use&&null===t.choice){if(t.any)var o=e.save();var u=this._decodeTag(e,null!==t.implicit?t.implicit:t.tag,t.any);if(e.isError(u))return u;t.any?n=e.raw(o):e=u}if(n=t.any?n:null===t.choice?this._decodeGeneric(t.tag,e):this._decodeChoice(e),e.isError(n))return n;if(!t.any&&null===t.choice&&null!==t.children){var h=t.children.some(function(t){t._decode(e)});if(h)return err}}return t.obj&&i&&(n=e.leaveObject(f)),null===t.key||null===n&&i!==!0||e.leaveKey(r,t.key,n),n},n.prototype._decodeGeneric=function(e,t){var r=this._baseState;return"seq"===e||"set"===e?null:"seqof"===e||"setof"===e?this._decodeList(t,e,r.args[0]):"octstr"===e||"bitstr"===e||"ia5str"===e?this._decodeStr(t,e):"objid"===e&&r.args?this._decodeObjid(t,r.args[0],r.args[1]):"objid"===e?this._decodeObjid(t,null,null):"gentime"===e||"utctime"===e?this._decodeTime(t,e):"null_"===e?this._decodeNull(t):"bool"===e?this._decodeBool(t):"int"===e||"enum"===e?this._decodeInt(t,r.args&&r.args[0]):null!==r.use?this._getUse(r.use,t._reporterState.obj)._decode(t):t.error("unknown tag: "+e)},n.prototype._getUse=function(e,t){var r=this._baseState;return r.useDecoder=this._use(e,t),o(null===r.useDecoder._baseState.parent),r.useDecoder=r.useDecoder._baseState.children[0],r.implicit!==r.useDecoder._baseState.implicit&&(r.useDecoder=r.useDecoder.clone(),r.useDecoder._baseState.implicit=r.implicit),r.useDecoder},n.prototype._decodeChoice=function(e){var t=this._baseState,r=null,n=!1;return Object.keys(t.choice).some(function(i){var s=e.save(),o=t.choice[i];try{var a=o._decode(e);if(e.isError(a))return!1;r={type:i,value:a},n=!0}catch(f){return e.restore(s),!1}return!0},this),n?r:e.error("Choice not matched")},n.prototype._createEncoderBuffer=function(e){return new s(e,this.reporter)},n.prototype._encode=function(e,t,r){var n=this._baseState;if(null===n["default"]||n["default"]!==e){var i=this._encodeValue(e,t,r);if(void 0!==i&&!this._skipDefault(i,t,r))return i}},n.prototype._encodeValue=function(e,t,r){var n=this._baseState;if(null===n.parent)return n.children[0]._encode(e,t||new i);var s=null;if(this.reporter=t,n.optional&&void 0===e){if(null===n["default"])return;e=n["default"]}var o=null,a=!1;if(n.any)s=this._createEncoderBuffer(e);else if(n.choice)s=this._encodeChoice(e,t);else if(n.children)o=n.children.map(function(r){if("null_"===r._baseState.tag)return r._encode(null,t,e);if(null===r._baseState.key)return t.error("Child should have a key");var n=t.enterKey(r._baseState.key);if("object"!=typeof e)return t.error("Child expected, but input is not object");var i=r._encode(e[r._baseState.key],t,e);return t.leaveKey(n),i},this).filter(function(e){return e}),o=this._createEncoderBuffer(o);else if("seqof"===n.tag||"setof"===n.tag){if(!n.args||1!==n.args.length)return t.error("Too many args for : "+n.tag);if(!Array.isArray(e))return t.error("seqof/setof, but data is not Array");var f=this.clone();f._baseState.implicit=null,o=this._createEncoderBuffer(e.map(function(r){var n=this._baseState;return this._getUse(n.args[0],e)._encode(r,t)},f))}else null!==n.use?s=this._getUse(n.use,r)._encode(e,t):(o=this._encodePrimitive(n.tag,e),a=!0);var s;if(!n.any&&null===n.choice){var c=null!==n.implicit?n.implicit:n.tag,u=null===n.implicit?"universal":"context";null===c?null===n.use&&t.error("Tag could be ommited only for .use()"):null===n.use&&(s=this._encodeComposite(c,a,u,o))}return null!==n.explicit&&(s=this._encodeComposite(n.explicit,!1,"context",s)),s},n.prototype._encodeChoice=function(e,t){var r=this._baseState,n=r.choice[e.type];return n||o(!1,e.type+" not found in "+JSON.stringify(Object.keys(r.choice))),n._encode(e.value,t)},n.prototype._encodePrimitive=function(e,t){var r=this._baseState;if("octstr"===e||"bitstr"===e||"ia5str"===e)return this._encodeStr(t,e);if("objid"===e&&r.args)return this._encodeObjid(t,r.reverseArgs[0],r.args[1]);if("objid"===e)return this._encodeObjid(t,null,null);if("gentime"===e||"utctime"===e)return this._encodeTime(t,e);if("null_"===e)return this._encodeNull();if("int"===e||"enum"===e)return this._encodeInt(t,r.args&&r.reverseArgs[0]);if("bool"===e)return this._encodeBool(t);throw new Error("Unsupported tag: "+e)}},{"../base":81,"minimalistic-assert":92}],83:[function(e,t,r){function n(e){this._reporterState={obj:null,path:[],options:e||{},errors:[]}}function i(e,t){this.path=e,this.rethrow(t)}var s=e("inherits");r.Reporter=n,n.prototype.isError=function(e){return e instanceof i},n.prototype.save=function(){var e=this._reporterState;return{obj:e.obj,pathLen:e.path.length}},n.prototype.restore=function(e){var t=this._reporterState;t.obj=e.obj,t.path=t.path.slice(0,e.pathLen)},n.prototype.enterKey=function(e){return this._reporterState.path.push(e)},n.prototype.leaveKey=function(e,t,r){var n=this._reporterState;n.path=n.path.slice(0,e-1),null!==n.obj&&(n.obj[t]=r)},n.prototype.enterObject=function(){var e=this._reporterState,t=e.obj;return e.obj={},t},n.prototype.leaveObject=function(e){var t=this._reporterState,r=t.obj;return t.obj=e,r},n.prototype.error=function(e){var t,r=this._reporterState,n=e instanceof i;if(t=n?e:new i(r.path.map(function(e){return"["+JSON.stringify(e)+"]"}).join(""),e.message||e,e.stack),!r.options.partial)throw t;return n||r.errors.push(t),t},n.prototype.wrapResult=function(e){var t=this._reporterState;return t.options.partial?{result:this.isError(e)?null:e,errors:t.errors}:e},s(i,Error),i.prototype.rethrow=function(e){return this.message=e+" at: "+(this.path||"(shallow)"),Error.captureStackTrace(this,i),this}},{inherits:193}],84:[function(e,t,r){var n=e("../constants");r.tagClass={0:"universal",1:"application",2:"context",3:"private"},r.tagClassByName=n._reverse(r.tagClass),r.tag={0:"end",1:"bool",2:"int",3:"bitstr",4:"octstr",5:"null_",6:"objid",7:"objDesc",8:"external",9:"real",10:"enum",11:"embed",12:"utf8str",13:"relativeOid",16:"seq",17:"set",18:"numstr",19:"printstr",20:"t61str",21:"videostr",22:"ia5str",23:"utctime",24:"gentime",25:"graphstr",26:"iso646str",27:"genstr",28:"unistr",29:"charstr",30:"bmpstr"},r.tagByName=n._reverse(r.tag)},{"../constants":85}],85:[function(e,t,r){var n=r;n._reverse=function(e){var t={};return Object.keys(e).forEach(function(r){(0|r)==r&&(r=0|r);var n=e[r];t[n]=r}),t},n.der=e("./der")},{"./der":84}],86:[function(e,t,r){function n(e){this.enc="der",this.name=e.name,this.entity=e,this.tree=new i,this.tree._init(e.body)}function i(e){c.Node.call(this,"der",e)}function s(e,t){var r=e.readUInt8(t);if(e.isError(r))return r;var n=h.tagClass[r>>6],i=0===(32&r);if(31===(31&r)){var s=r;for(r=0;128===(128&s);){if(s=e.readUInt8(t),e.isError(s))return s;r<<=7,r|=127&s}}else r&=31;var o=h.tag[r];return{cls:n,primitive:i,tag:r,tagStr:o}}function o(e,t,r){var n=e.readUInt8(r);if(e.isError(n))return n;if(!t&&128===n)return null;if(0===(128&n))return n;var i=127&n;if(i>=4)return e.error("length octect is too long");n=0;for(var s=0;i>s;s++){n<<=8;var o=e.readUInt8(r);if(e.isError(o))return o;n|=o}return n}var a=e("inherits"),f=e("../../asn1"),c=f.base,u=f.bignum,h=f.constants.der;t.exports=n,n.prototype.decode=function(e,t){return e instanceof c.DecoderBuffer||(e=new c.DecoderBuffer(e,t)),this.tree._decode(e,t)},a(i,c.Node),i.prototype._peekTag=function(e,t,r){if(e.isEmpty())return!1;var n=e.save(),i=s(e,'Failed to peek tag: "'+t+'"');return e.isError(i)?i:(e.restore(n),i.tag===t||i.tagStr===t||r)},i.prototype._decodeTag=function(e,t,r){var n=s(e,'Failed to decode tag of "'+t+'"');if(e.isError(n))return n;var i=o(e,n.primitive,'Failed to get length of "'+t+'"');if(e.isError(i))return i;if(!r&&n.tag!==t&&n.tagStr!==t&&n.tagStr+"of"!==t)return e.error('Failed to match tag: "'+t+'"');if(n.primitive||null!==i)return e.skip(i,'Failed to match body of: "'+t+'"');var a=e.start(),f=this._skipUntilEnd(e,'Failed to skip indefinite length body: "'+this.tag+'"');return e.isError(f)?f:e.cut(a)},i.prototype._skipUntilEnd=function(e,t){for(;;){var r=s(e,t);if(e.isError(r))return r;var n=o(e,r.primitive,t);if(e.isError(n))return n;var i;if(i=r.primitive||null!==n?e.skip(n):this._skipUntilEnd(e,t),e.isError(i))return i;if("end"===r.tagStr)break}},i.prototype._decodeList=function(e,t,r){for(var n=[];!e.isEmpty();){var i=this._peekTag(e,"end");if(e.isError(i))return i;var s=r.decode(e,"der");if(e.isError(s)&&i)break;n.push(s)}return n},i.prototype._decodeStr=function(e,t){if("octstr"===t)return e.raw();if("bitstr"===t){var r=e.readUInt8();return e.isError(r)?r:{unused:r,data:e.raw()}}return"ia5str"===t?e.raw().toString():this.error("Decoding of string type: "+t+" unsupported")},i.prototype._decodeObjid=function(e,t,r){for(var n=[],i=0;!e.isEmpty();){var s=e.readUInt8();i<<=7,i|=127&s,0===(128&s)&&(n.push(i),i=0)}128&s&&n.push(i);var o=n[0]/40|0,a=n[0]%40;return result=r?n:[o,a].concat(n.slice(1)),t&&(result=t[result.join(" ")]),result},i.prototype._decodeTime=function(e,t){var r=e.raw().toString();if("gentime"===t)var n=0|r.slice(0,4),i=0|r.slice(4,6),s=0|r.slice(6,8),o=0|r.slice(8,10),a=0|r.slice(10,12),f=0|r.slice(12,14);else{if("utctime"!==t)return this.error("Decoding "+t+" time is not supported yet");var n=0|r.slice(0,2),i=0|r.slice(2,4),s=0|r.slice(4,6),o=0|r.slice(6,8),a=0|r.slice(8,10),f=0|r.slice(10,12);n=70>n?2e3+n:1900+n}return Date.UTC(n,i-1,s,o,a,f,0)},i.prototype._decodeNull=function(e){return null},i.prototype._decodeBool=function(e){var t=e.readUInt8();return e.isError(t)?t:0!==t},i.prototype._decodeInt=function(e,t){var r=e.raw(),n=new u(r);return t&&(n=t[n.toString(10)]||n),n},i.prototype._use=function(e,t){return"function"==typeof e&&(e=e(t)),e._getDecoder("der").tree}},{"../../asn1":78,inherits:193}],87:[function(e,t,r){var n=r;n.der=e("./der"),n.pem=e("./pem")},{"./der":86,"./pem":88}],88:[function(e,t,r){function n(e){o.call(this,e),this.enc="pem"}var i=e("inherits"),s=e("buffer").Buffer,o=(e("../../asn1"),e("./der"));i(n,o),t.exports=n,n.prototype.decode=function(e,t){for(var r=e.toString().split(/[\r\n]+/g),n=t.label.toUpperCase(),i=/^-----(BEGIN|END) ([^-]+)-----$/,a=-1,f=-1,c=0;c<r.length;c++){var u=r[c].match(i);if(null!==u&&u[2]===n){if(-1!==a){if("END"!==u[1])break;f=c;break}if("BEGIN"!==u[1])break;a=c}}if(-1===a||-1===f)throw new Error("PEM section not found for: "+n);var h=r.slice(a+1,f).join("");h.replace(/[^a-z0-9\+\/=]+/gi,"");var d=new s(h,"base64");return o.prototype.decode.call(this,d,t)}},{"../../asn1":78,"./der":86,buffer:46,inherits:193}],89:[function(e,t,r){function n(e){this.enc="der",this.name=e.name,this.entity=e,this.tree=new i,this.tree._init(e.body)}function i(e){u.Node.call(this,"der",e)}function s(e){return 10>e?"0"+e:e}function o(e,t,r,n){var i;if("seqof"===e?e="seq":"setof"===e&&(e="set"),h.tagByName.hasOwnProperty(e))i=h.tagByName[e];else{if("number"!=typeof e||(0|e)!==e)return n.error("Unknown tag: "+e);i=e}return i>=31?n.error("Multi-octet tag encoding unsupported"):(t||(i|=32),i|=h.tagClassByName[r||"universal"]<<6)}var a=e("inherits"),f=e("buffer").Buffer,c=e("../../asn1"),u=c.base,h=(c.bignum,c.constants.der);t.exports=n,n.prototype.encode=function(e,t){return this.tree._encode(e,t).join()},a(i,u.Node),i.prototype._encodeComposite=function(e,t,r,n){var i=o(e,t,r,this.reporter);if(n.length<128){var s=new f(2);return s[0]=i,s[1]=n.length,this._createEncoderBuffer([s,n])}for(var a=1,c=n.length;c>=256;c>>=8)a++;var s=new f(2+a);s[0]=i,s[1]=128|a;for(var c=1+a,u=n.length;u>0;c--,u>>=8)s[c]=255&u;return this._createEncoderBuffer([s,n])},i.prototype._encodeStr=function(e,t){return"octstr"===t?this._createEncoderBuffer(e):"bitstr"===t?this._createEncoderBuffer([0|e.unused,e.data]):"ia5str"===t?this._createEncoderBuffer(e):this.reporter.error("Encoding of string type: "+t+" unsupported")},i.prototype._encodeObjid=function(e,t,r){if("string"==typeof e){if(!t)return this.reporter.error("string objid given, but no values map found");if(!t.hasOwnProperty(e))return this.reporter.error("objid not found in values map");e=t[e].split(/\s+/g);for(var n=0;n<e.length;n++)e[n]|=0}else Array.isArray(e)&&(e=e.slice());if(!Array.isArray(e))return this.reporter.error("objid() should be either array or string, got: "+JSON.stringify(e));if(!r){if(e[1]>=40)return this.reporter.error("Second objid identifier OOB");e.splice(0,2,40*e[0]+e[1])}for(var i=0,n=0;n<e.length;n++){var s=e[n];for(i++;s>=128;s>>=7)i++}for(var o=new f(i),a=o.length-1,n=e.length-1;n>=0;n--){var s=e[n];for(o[a--]=127&s;(s>>=7)>0;)o[a--]=128|127&s}return this._createEncoderBuffer(o)},i.prototype._encodeTime=function(e,t){var r,n=new Date(e);return"gentime"===t?r=[s(n.getFullYear()),s(n.getUTCMonth()+1),s(n.getUTCDate()),s(n.getUTCHours()),s(n.getUTCMinutes()),s(n.getUTCSeconds()),"Z"].join(""):"utctime"===t?r=[s(n.getFullYear()%100),s(n.getUTCMonth()+1),s(n.getUTCDate()),s(n.getUTCHours()),s(n.getUTCMinutes()),s(n.getUTCSeconds()),"Z"].join(""):this.reporter.error("Encoding "+t+" time is not supported yet"),this._encodeStr(r,"octstr")},i.prototype._encodeNull=function(){return this._createEncoderBuffer("")},i.prototype._encodeInt=function(e,t){if("string"==typeof e){if(!t)return this.reporter.error("String int or enum given, but no values map");if(!t.hasOwnProperty(e))return this.reporter.error("Values map doesn't contain: "+JSON.stringify(e));e=t[e]}if("number"!=typeof e&&!f.isBuffer(e)){var r=e.toArray();e.sign===!1&&128&r[0]&&r.unshift(0),e=new f(r)}if(f.isBuffer(e)){var n=e.length;0===e.length&&n++;var i=new f(n);return e.copy(i),0===e.length&&(i[0]=0),this._createEncoderBuffer(i)}if(128>e)return this._createEncoderBuffer(e);if(256>e)return this._createEncoderBuffer([0,e]);for(var n=1,s=e;s>=256;s>>=8)n++;for(var i=new Array(n),s=i.length-1;s>=0;s--)i[s]=255&e,e>>=8;return 128&i[0]&&i.unshift(0),this._createEncoderBuffer(new f(i))},i.prototype._encodeBool=function(e){return this._createEncoderBuffer(e?255:0)},i.prototype._use=function(e,t){return"function"==typeof e&&(e=e(t)),e._getEncoder("der").tree},i.prototype._skipDefault=function(e,t,r){var n,i=this._baseState;if(null===i["default"])return!1;var s=e.join();if(void 0===i.defaultBuffer&&(i.defaultBuffer=this._encodeValue(i["default"],t,r).join()),s.length!==i.defaultBuffer.length)return!1;for(n=0;n<s.length;n++)if(s[n]!==i.defaultBuffer[n])return!1;return!0}},{"../../asn1":78,buffer:46,inherits:193}],90:[function(e,t,r){var n=r;n.der=e("./der"),n.pem=e("./pem")},{"./der":89,"./pem":91}],91:[function(e,t,r){function n(e){s.call(this,e),this.enc="pem"}var i=e("inherits"),s=(e("buffer").Buffer,e("../../asn1"),e("./der"));i(n,s),t.exports=n,n.prototype.encode=function(e,t){for(var r=s.prototype.encode.call(this,e),n=r.toString("base64"),i=["-----BEGIN "+t.label+"-----"],o=0;o<n.length;o+=64)i.push(n.slice(o,o+64));return i.push("-----END "+t.label+"-----"),i.join("\n")}},{"../../asn1":78,"./der":89,buffer:46,inherits:193}],92:[function(e,t,r){function n(e,t){if(!e)throw new Error(t||"Assertion failed")}t.exports=n,n.equal=function(e,t,r){if(e!=t)throw new Error(r||"Assertion failed: "+e+" != "+t)}},{}],93:[function(e,t,r){(function(r){function n(e,t,r,n){var o=d(t);if(o.curve){if("ecdsa"!==n)throw new Error("wrong private key type");return i(e,o)}if("dsa"===o.type)return s(e,o,r);if("rsa"!==n)throw new Error("wrong private key type");for(var a=o.modulus.byteLength(),f=[0,1];e.length+f.length+1<a;)f.push(255);f.push(0);for(var c=-1;++c<e.length;)f.push(e[c]);var u=b(f,o);return u}function i(e,t){var n=m[t.curve.join(".")];if(!n)throw new Error("unknown curve "+t.curve.join("."));var i=new l.ec(n),s=i.genKeyPair();s._importPrivate(t.privateKey);var o=s.sign(e);return new r(o.toDER())}function s(e,t,r){for(var n,i=t.params.priv_key,s=t.params.p,c=t.params.q,d=(p.mont(c),t.params.g),l=new p(0),b=f(e,c).mod(c),g=!1,m=a(i,c,e,r);g===!1;)n=u(c,m,r),l=h(d,n,s,c),g=n.invm(c).imul(b.add(i.mul(l))).mod(c),g.cmpn(0)||(g=!1,l=new p(0));return o(l,g)}function o(e,t){e=e.toArray(),t=t.toArray(),128&e[0]&&(e=[0].concat(e)),128&t[0]&&(t=[0].concat(t));var n=e.length+t.length+4,i=[48,n,2,e.length];return i=i.concat(e,[2,t.length],t),new r(i)}function a(e,t,n,i){if(e=new r(e.toArray()),e.length<t.byteLength()){var s=new r(t.byteLength()-e.length);s.fill(0),e=r.concat([s,e])}var o=n.length,a=c(n,t),f=new r(o);f.fill(1);var u=new r(o);return u.fill(0),u=g(i,u).update(f).update(new r([0])).update(e).update(a).digest(),f=g(i,u).update(f).digest(),u=g(i,u).update(f).update(new r([1])).update(e).update(a).digest(),f=g(i,u).update(f).digest(),{k:u,v:f}}function f(e,t){var r=new p(e),n=(e.length<<3)-t.bitLength();return n>0&&r.ishrn(n),r}function c(e,t){e=f(e,t),e=e.mod(t);var n=new r(e.toArray());if(n.length<t.byteLength()){var i=new r(t.byteLength()-n.length);i.fill(0),n=r.concat([i,n])}return n}function u(e,t,n){for(var i,s;;){for(i=new r("");8*i.length<e.bitLength();)t.v=g(n,t.k).update(t.v).digest(),i=r.concat([i,t.v]);if(s=f(i,e),t.k=g(n,t.k).update(t.v).update(new r([0])).digest(),t.v=g(n,t.k).update(t.v).digest(),-1===s.cmp(e))return s}}function h(e,t,r,n){return e.toRed(p.mont(r)).redPow(t).fromRed().mod(n)}var d=e("parse-asn1"),p=e("bn.js"),l=e("elliptic"),b=e("browserify-rsa"),g=e("create-hmac"),m=e("./curves");t.exports=n,t.exports.getKey=a,t.exports.makeKey=u}).call(this,e("buffer").Buffer)},{"./curves":71,"bn.js":170,"browserify-rsa":72,buffer:46,"create-hmac":109,elliptic:172,"parse-asn1":77}],94:[function(e,t,r){(function(r){"use strict";function n(e,t,n,o){var f=a(n);if("ec"===f.type){if("ecdsa"!==o)throw new Error("wrong public key type");return i(e,t,f)}if("dsa"===f.type){if("dsa"!==o)throw new Error("wrong public key type");return s(e,t,f)}if("rsa"!==o)throw new Error("wrong public key type");for(var c=f.modulus.byteLength(),h=[1],d=0;t.length+h.length+2<c;)h.push(255),d++;h.push(0);for(var p=-1;++p<t.length;)h.push(t[p]);h=new r(h);var l=u.mont(f.modulus);e=new u(e).toRed(l),e=e.redPow(new u(f.publicExponent)),e=new r(e.fromRed().toArray());var b=0;for(8>d&&(b=1),c=Math.min(e.length,h.length),e.length!==h.length&&(b=1),p=-1;++p<c;)b|=e[p]^h[p];return 0===b}function i(e,t,r){var n=c[r.data.algorithm.curve.join(".")];if(!n)throw new Error("unknown curve "+r.data.algorithm.curve.join("."));var i=new f.ec(n),s=r.data.subjectPrivateKey.data;return i.verify(t,e,s)}function s(e,t,r){var n=r.data.p,i=r.data.q,s=r.data.g,f=r.data.pub_key,c=a.signature.decode(e,"der"),h=c.s,d=c.r;o(h,i),o(d,i);var p=(u.mont(i),u.mont(n)),l=h.invm(i),b=s.toRed(p).redPow(new u(t).mul(l).mod(i)).fromRed().mul(f.toRed(p).redPow(d.mul(l).mod(i)).fromRed()).mod(n).mod(i);return!b.cmp(d)}function o(e,t){if(e.cmpn(0)<=0)throw new Error("invalid sig");if(e.cmp(t)>=t)throw new Error("invalid sig")}var a=e("parse-asn1"),f=e("elliptic"),c=e("./curves"),u=e("bn.js");t.exports=n}).call(this,e("buffer").Buffer)},{"./curves":71,"bn.js":170,buffer:46,elliptic:172,"parse-asn1":77}],95:[function(e,t,r){(function(r){function n(e){this.curveType=a[e],this.curveType||(this.curveType={name:e}),this.curve=new s.ec(this.curveType.name),this.keys=void 0}function i(e,t,n){Array.isArray(e)||(e=e.toArray());var i=new r(e);if(n&&i.length<n){var s=new r(n-i.length);s.fill(0),i=r.concat([s,i])}return t?i.toString(t):i}var s=e("elliptic"),o=e("bn.js");t.exports=function(e){return new n(e)};var a={secp256k1:{name:"secp256k1",byteLength:32},secp224r1:{name:"p224",byteLength:28},prime256v1:{name:"p256",byteLength:32},prime192v1:{name:"p192",byteLength:24},ed25519:{name:"ed25519",byteLength:32}};a.p224=a.secp224r1,a.p256=a.secp256r1=a.prime256v1,a.p192=a.secp192r1=a.prime192v1,n.prototype.generateKeys=function(e,t){return this.keys=this.curve.genKeyPair(),this.getPublicKey(e,t)},n.prototype.computeSecret=function(e,t,n){t=t||"utf8",r.isBuffer(e)||(e=new r(e,t));var s=this.curve.keyFromPublic(e).getPublic(),o=s.mul(this.keys.getPrivate()).getX();return i(o,n,this.curveType.byteLength)},n.prototype.getPublicKey=function(e,t){var r=this.keys.getPublic("compressed"===t,!0);return"hybrid"===t&&(r[0]=r[r.length-1]%2?7:6),i(r,e)},n.prototype.getPrivateKey=function(e){return i(this.keys.getPrivate(),e)},n.prototype.setPublicKey=function(e,t){return t=t||"utf8",r.isBuffer(e)||(e=new r(e,t)),this.keys._importPublic(e),this},n.prototype.setPrivateKey=function(e,t){t=t||"utf8",r.isBuffer(e)||(e=new r(e,t));var n=new o(e);return n=n.toString(16),this.keys._importPrivate(n),this}}).call(this,e("buffer").Buffer)},{"bn.js":170,buffer:46,elliptic:172}],96:[function(e,t,r){var n=e("crypto").createECDH;t.exports=n||e("./browser")},{"./browser":95,crypto:50}],97:[function(e,t,r){(function(r){"use strict";function n(e){c.call(this),this._hash=e,this.buffers=[]}function i(e){c.call(this),this._hash=e}var s=e("inherits"),o=e("./md5"),a=e("ripemd160"),f=e("sha.js"),c=e("stream").Transform;s(n,c),n.prototype._transform=function(e,t,r){this.buffers.push(e),r()},n.prototype._flush=function(e){this.push(this.digest()),e()},n.prototype.update=function(e,t){return"string"==typeof e&&(e=new r(e,t)),this.buffers.push(e),this},n.prototype.digest=function(e){var t=r.concat(this.buffers),n=this._hash(t);return this.buffers=null,e?n.toString(e):n},s(i,c),i.prototype._transform=function(e,t,n){t&&(e=new r(e,t)),this._hash.update(e),n()},i.prototype._flush=function(e){this.push(this._hash.digest()),this._hash=null,e()},i.prototype.update=function(e,t){return"string"==typeof e&&(e=new r(e,t)),this._hash.update(e),this},i.prototype.digest=function(e){var t=this._hash.digest();return e?t.toString(e):t},t.exports=function(e){return"md5"===e?new n(o):"rmd160"===e?new n(a):new i(f(e))}}).call(this,e("buffer").Buffer);
},{"./md5":99,buffer:46,inherits:193,ripemd160:100,"sha.js":102,stream:163}],98:[function(e,t,r){(function(e){"use strict";function t(t,r){if(t.length%s!==0){var n=t.length+(s-t.length%s);t=e.concat([t,o],n)}for(var i=[],a=r?t.readInt32BE:t.readInt32LE,f=0;f<t.length;f+=s)i.push(a.call(t,f));return i}function n(t,r,n){for(var i=new e(r),s=n?i.writeInt32BE:i.writeInt32LE,o=0;o<t.length;o++)s.call(i,t[o],4*o,!0);return i}function i(r,i,s,o){e.isBuffer(r)||(r=new e(r));var f=i(t(r,o),r.length*a);return n(f,s,o)}var s=4,o=new e(s);o.fill(0);var a=8;r.hash=i}).call(this,e("buffer").Buffer)},{buffer:46}],99:[function(e,t,r){"use strict";function n(e,t){e[t>>5]|=128<<t%32,e[(t+64>>>9<<4)+14]=t;for(var r=1732584193,n=-271733879,i=-1732584194,u=271733878,h=0;h<e.length;h+=16){var d=r,p=n,l=i,b=u;r=s(r,n,i,u,e[h+0],7,-680876936),u=s(u,r,n,i,e[h+1],12,-389564586),i=s(i,u,r,n,e[h+2],17,606105819),n=s(n,i,u,r,e[h+3],22,-1044525330),r=s(r,n,i,u,e[h+4],7,-176418897),u=s(u,r,n,i,e[h+5],12,1200080426),i=s(i,u,r,n,e[h+6],17,-1473231341),n=s(n,i,u,r,e[h+7],22,-45705983),r=s(r,n,i,u,e[h+8],7,1770035416),u=s(u,r,n,i,e[h+9],12,-1958414417),i=s(i,u,r,n,e[h+10],17,-42063),n=s(n,i,u,r,e[h+11],22,-1990404162),r=s(r,n,i,u,e[h+12],7,1804603682),u=s(u,r,n,i,e[h+13],12,-40341101),i=s(i,u,r,n,e[h+14],17,-1502002290),n=s(n,i,u,r,e[h+15],22,1236535329),r=o(r,n,i,u,e[h+1],5,-165796510),u=o(u,r,n,i,e[h+6],9,-1069501632),i=o(i,u,r,n,e[h+11],14,643717713),n=o(n,i,u,r,e[h+0],20,-373897302),r=o(r,n,i,u,e[h+5],5,-701558691),u=o(u,r,n,i,e[h+10],9,38016083),i=o(i,u,r,n,e[h+15],14,-660478335),n=o(n,i,u,r,e[h+4],20,-405537848),r=o(r,n,i,u,e[h+9],5,568446438),u=o(u,r,n,i,e[h+14],9,-1019803690),i=o(i,u,r,n,e[h+3],14,-187363961),n=o(n,i,u,r,e[h+8],20,1163531501),r=o(r,n,i,u,e[h+13],5,-1444681467),u=o(u,r,n,i,e[h+2],9,-51403784),i=o(i,u,r,n,e[h+7],14,1735328473),n=o(n,i,u,r,e[h+12],20,-1926607734),r=a(r,n,i,u,e[h+5],4,-378558),u=a(u,r,n,i,e[h+8],11,-2022574463),i=a(i,u,r,n,e[h+11],16,1839030562),n=a(n,i,u,r,e[h+14],23,-35309556),r=a(r,n,i,u,e[h+1],4,-1530992060),u=a(u,r,n,i,e[h+4],11,1272893353),i=a(i,u,r,n,e[h+7],16,-155497632),n=a(n,i,u,r,e[h+10],23,-1094730640),r=a(r,n,i,u,e[h+13],4,681279174),u=a(u,r,n,i,e[h+0],11,-358537222),i=a(i,u,r,n,e[h+3],16,-722521979),n=a(n,i,u,r,e[h+6],23,76029189),r=a(r,n,i,u,e[h+9],4,-640364487),u=a(u,r,n,i,e[h+12],11,-421815835),i=a(i,u,r,n,e[h+15],16,530742520),n=a(n,i,u,r,e[h+2],23,-995338651),r=f(r,n,i,u,e[h+0],6,-198630844),u=f(u,r,n,i,e[h+7],10,1126891415),i=f(i,u,r,n,e[h+14],15,-1416354905),n=f(n,i,u,r,e[h+5],21,-57434055),r=f(r,n,i,u,e[h+12],6,1700485571),u=f(u,r,n,i,e[h+3],10,-1894986606),i=f(i,u,r,n,e[h+10],15,-1051523),n=f(n,i,u,r,e[h+1],21,-2054922799),r=f(r,n,i,u,e[h+8],6,1873313359),u=f(u,r,n,i,e[h+15],10,-30611744),i=f(i,u,r,n,e[h+6],15,-1560198380),n=f(n,i,u,r,e[h+13],21,1309151649),r=f(r,n,i,u,e[h+4],6,-145523070),u=f(u,r,n,i,e[h+11],10,-1120210379),i=f(i,u,r,n,e[h+2],15,718787259),n=f(n,i,u,r,e[h+9],21,-343485551),r=c(r,d),n=c(n,p),i=c(i,l),u=c(u,b)}return Array(r,n,i,u)}function i(e,t,r,n,i,s){return c(u(c(c(t,e),c(n,s)),i),r)}function s(e,t,r,n,s,o,a){return i(t&r|~t&n,e,t,s,o,a)}function o(e,t,r,n,s,o,a){return i(t&n|r&~n,e,t,s,o,a)}function a(e,t,r,n,s,o,a){return i(t^r^n,e,t,s,o,a)}function f(e,t,r,n,s,o,a){return i(r^(t|~n),e,t,s,o,a)}function c(e,t){var r=(65535&e)+(65535&t),n=(e>>16)+(t>>16)+(r>>16);return n<<16|65535&r}function u(e,t){return e<<t|e>>>32-t}var h=e("./helpers");t.exports=function(e){return h.hash(e,n,16)}},{"./helpers":98}],100:[function(e,t,r){(function(e){function r(e){for(var t=[],r=0,n=0;r<e.length;r++,n+=8)t[n>>>5]|=e[r]<<24-n%32;return t}function n(e){for(var t=[],r=0;r<32*e.length;r+=8)t.push(e[r>>>5]>>>24-r%32&255);return t}function i(e,t,r){for(var n=0;16>n;n++){var i=r+n,h=t[i];t[i]=16711935&(h<<8|h>>>24)|4278255360&(h<<24|h>>>8)}var y,v,_,w,S,k,E,I,A,O;k=y=e[0],E=v=e[1],I=_=e[2],A=w=e[3],O=S=e[4];var P;for(n=0;80>n;n+=1)P=y+t[r+d[n]]|0,P+=16>n?s(v,_,w)+g[0]:32>n?o(v,_,w)+g[1]:48>n?a(v,_,w)+g[2]:64>n?f(v,_,w)+g[3]:c(v,_,w)+g[4],P=0|P,P=u(P,l[n]),P=P+S|0,y=S,S=w,w=u(_,10),_=v,v=P,P=k+t[r+p[n]]|0,P+=16>n?c(E,I,A)+m[0]:32>n?f(E,I,A)+m[1]:48>n?a(E,I,A)+m[2]:64>n?o(E,I,A)+m[3]:s(E,I,A)+m[4],P=0|P,P=u(P,b[n]),P=P+O|0,k=O,O=A,A=u(I,10),I=E,E=P;P=e[1]+_+A|0,e[1]=e[2]+w+O|0,e[2]=e[3]+S+k|0,e[3]=e[4]+y+E|0,e[4]=e[0]+v+I|0,e[0]=P}function s(e,t,r){return e^t^r}function o(e,t,r){return e&t|~e&r}function a(e,t,r){return(e|~t)^r}function f(e,t,r){return e&r|t&~r}function c(e,t,r){return e^(t|~r)}function u(e,t){return e<<t|e>>>32-t}function h(t){var s=[1732584193,4023233417,2562383102,271733878,3285377520];"string"==typeof t&&(t=new e(t,"utf8"));var o=r(t),a=8*t.length,f=8*t.length;o[a>>>5]|=128<<24-a%32,o[(a+64>>>9<<4)+14]=16711935&(f<<8|f>>>24)|4278255360&(f<<24|f>>>8);for(var c=0;c<o.length;c+=16)i(s,o,c);for(c=0;5>c;c++){var u=s[c];s[c]=16711935&(u<<8|u>>>24)|4278255360&(u<<24|u>>>8)}var h=n(s);return new e(h)}var d=[0,1,2,3,4,5,6,7,8,9,10,11,12,13,14,15,7,4,13,1,10,6,15,3,12,0,9,5,2,14,11,8,3,10,14,4,9,15,8,1,2,7,0,6,13,11,5,12,1,9,11,10,0,8,12,4,13,3,7,15,14,5,6,2,4,0,5,9,7,12,2,10,14,1,3,8,11,6,15,13],p=[5,14,7,0,9,2,11,4,13,6,15,8,1,10,3,12,6,11,3,7,0,13,5,10,14,15,8,12,4,9,1,2,15,5,1,3,7,14,6,9,11,8,12,2,10,0,4,13,8,6,4,1,3,11,15,0,5,12,2,13,9,7,10,14,12,15,10,4,1,5,8,7,6,2,13,14,0,3,9,11],l=[11,14,15,12,5,8,7,9,11,13,14,15,6,7,9,8,7,6,8,13,11,9,7,15,7,12,15,9,11,7,13,12,11,13,6,7,14,9,13,15,14,8,13,6,5,12,7,5,11,12,14,15,14,15,9,8,9,14,5,6,8,6,5,12,9,15,5,11,6,8,13,12,5,12,13,14,11,8,5,6],b=[8,9,9,11,13,15,15,5,7,7,8,11,14,14,12,6,9,13,15,7,12,8,9,11,7,7,12,7,6,15,13,11,9,7,15,11,8,6,6,14,12,13,5,14,13,13,7,5,15,5,8,11,14,14,6,14,6,9,12,9,12,5,15,8,8,5,12,9,12,5,14,6,8,13,6,5,15,13,11,11],g=[0,1518500249,1859775393,2400959708,2840853838],m=[1352829926,1548603684,1836072691,2053994217,0];t.exports=h}).call(this,e("buffer").Buffer)},{buffer:46}],101:[function(e,t,r){(function(e){function r(t,r){this._block=new e(t),this._finalSize=r,this._blockSize=t,this._len=0,this._s=0}r.prototype.update=function(t,r){"string"==typeof t&&(r=r||"utf8",t=new e(t,r));for(var n=this._len+=t.length,i=this._s||0,s=0,o=this._block;n>i;){for(var a=Math.min(t.length,s+this._blockSize-i%this._blockSize),f=a-s,c=0;f>c;c++)o[i%this._blockSize+c]=t[c+s];i+=f,s+=f,i%this._blockSize===0&&this._update(o)}return this._s=i,this},r.prototype.digest=function(e){var t=8*this._len;this._block[this._len%this._blockSize]=128,this._block.fill(0,this._len%this._blockSize+1),t%(8*this._blockSize)>=8*this._finalSize&&(this._update(this._block),this._block.fill(0)),this._block.writeInt32BE(t,this._blockSize-4);var r=this._update(this._block)||this._hash();return e?r.toString(e):r},r.prototype._update=function(){throw new Error("_update must be implemented by subclass")},t.exports=r}).call(this,e("buffer").Buffer)},{buffer:46}],102:[function(e,t,r){var r=t.exports=function(e){e=e.toLowerCase();var t=r[e];if(!t)throw new Error(e+" is not supported (we accept pull requests)");return new t};r.sha=e("./sha"),r.sha1=e("./sha1"),r.sha224=e("./sha224"),r.sha256=e("./sha256"),r.sha384=e("./sha384"),r.sha512=e("./sha512")},{"./sha":103,"./sha1":104,"./sha224":105,"./sha256":106,"./sha384":107,"./sha512":108}],103:[function(e,t,r){(function(r){function n(){this.init(),this._w=a,o.call(this,64,56)}function i(e,t){return e<<t|e>>>32-t}var s=e("inherits"),o=e("./hash"),a=new Array(80);s(n,o),n.prototype.init=function(){return this._a=1732584193,this._b=-271733879,this._c=-1732584194,this._d=271733878,this._e=-1009589776,this},n.prototype._update=function(e){function t(){return s[h-3]^s[h-8]^s[h-14]^s[h-16]}function r(e,t){s[h]=e;var r=i(o,5)+t+u+e+n;u=c,c=f,f=i(a,30),a=o,o=r,h++}var n,s=this._w,o=this._a,a=this._b,f=this._c,c=this._d,u=this._e,h=0;for(n=1518500249;16>h;)r(e.readInt32BE(4*h),a&f|~a&c);for(;20>h;)r(t(),a&f|~a&c);for(n=1859775393;40>h;)r(t(),a^f^c);for(n=-1894007588;60>h;)r(t(),a&f|a&c|f&c);for(n=-899497514;80>h;)r(t(),a^f^c);this._a=o+this._a|0,this._b=a+this._b|0,this._c=f+this._c|0,this._d=c+this._d|0,this._e=u+this._e|0},n.prototype._hash=function(){var e=new r(20);return e.writeInt32BE(0|this._a,0),e.writeInt32BE(0|this._b,4),e.writeInt32BE(0|this._c,8),e.writeInt32BE(0|this._d,12),e.writeInt32BE(0|this._e,16),e},t.exports=n}).call(this,e("buffer").Buffer)},{"./hash":101,buffer:46,inherits:193}],104:[function(e,t,r){(function(r){function n(){this.init(),this._w=a,o.call(this,64,56)}function i(e,t){return e<<t|e>>>32-t}var s=e("inherits"),o=e("./hash"),a=new Array(80);s(n,o),n.prototype.init=function(){return this._a=1732584193,this._b=-271733879,this._c=-1732584194,this._d=271733878,this._e=-1009589776,this},n.prototype._update=function(e){function t(){return i(s[h-3]^s[h-8]^s[h-14]^s[h-16],1)}function r(e,t){s[h]=e;var r=i(o,5)+t+u+e+n;u=c,c=f,f=i(a,30),a=o,o=r,h++}var n,s=this._w,o=this._a,a=this._b,f=this._c,c=this._d,u=this._e,h=0;for(n=1518500249;16>h;)r(e.readInt32BE(4*h),a&f|~a&c);for(;20>h;)r(t(),a&f|~a&c);for(n=1859775393;40>h;)r(t(),a^f^c);for(n=-1894007588;60>h;)r(t(),a&f|a&c|f&c);for(n=-899497514;80>h;)r(t(),a^f^c);this._a=o+this._a|0,this._b=a+this._b|0,this._c=f+this._c|0,this._d=c+this._d|0,this._e=u+this._e|0},n.prototype._hash=function(){var e=new r(20);return e.writeInt32BE(0|this._a,0),e.writeInt32BE(0|this._b,4),e.writeInt32BE(0|this._c,8),e.writeInt32BE(0|this._d,12),e.writeInt32BE(0|this._e,16),e},t.exports=n}).call(this,e("buffer").Buffer)},{"./hash":101,buffer:46,inherits:193}],105:[function(e,t,r){(function(r){function n(){this.init(),this._w=a,o.call(this,64,56)}var i=e("inherits"),s=e("./sha256"),o=e("./hash"),a=new Array(64);i(n,s),n.prototype.init=function(){return this._a=-1056596264,this._b=914150663,this._c=812702999,this._d=-150054599,this._e=-4191439,this._f=1750603025,this._g=1694076839,this._h=-1090891868,this},n.prototype._hash=function(){var e=new r(28);return e.writeInt32BE(this._a,0),e.writeInt32BE(this._b,4),e.writeInt32BE(this._c,8),e.writeInt32BE(this._d,12),e.writeInt32BE(this._e,16),e.writeInt32BE(this._f,20),e.writeInt32BE(this._g,24),e},t.exports=n}).call(this,e("buffer").Buffer)},{"./hash":101,"./sha256":106,buffer:46,inherits:193}],106:[function(e,t,r){(function(r){function n(){this.init(),this._w=b,p.call(this,64,56)}function i(e,t){return e>>>t|e<<32-t}function s(e,t){return e>>>t}function o(e,t,r){return e&t^~e&r}function a(e,t,r){return e&t^e&r^t&r}function f(e){return i(e,2)^i(e,13)^i(e,22)}function c(e){return i(e,6)^i(e,11)^i(e,25)}function u(e){return i(e,7)^i(e,18)^s(e,3)}function h(e){return i(e,17)^i(e,19)^s(e,10)}var d=e("inherits"),p=e("./hash"),l=[1116352408,1899447441,3049323471,3921009573,961987163,1508970993,2453635748,2870763221,3624381080,310598401,607225278,1426881987,1925078388,2162078206,2614888103,3248222580,3835390401,4022224774,264347078,604807628,770255983,1249150122,1555081692,1996064986,2554220882,2821834349,2952996808,3210313671,3336571891,3584528711,113926993,338241895,666307205,773529912,1294757372,1396182291,1695183700,1986661051,2177026350,2456956037,2730485921,2820302411,3259730800,3345764771,3516065817,3600352804,4094571909,275423344,430227734,506948616,659060556,883997877,958139571,1322822218,1537002063,1747873779,1955562222,2024104815,2227730452,2361852424,2428436474,2756734187,3204031479,3329325298],b=new Array(64);d(n,p),n.prototype.init=function(){return this._a=1779033703,this._b=-1150833019,this._c=1013904242,this._d=-1521486534,this._e=1359893119,this._f=-1694144372,this._g=528734635,this._h=1541459225,this},n.prototype._update=function(e){function t(){return h(n[v-2])+n[v-7]+u(n[v-15])+n[v-16]}function r(e){n[v]=e;var t=y+c(b)+o(b,g,m)+l[v]+e,r=f(i)+a(i,s,d);y=m,m=g,g=b,b=p+t,p=d,d=s,s=i,i=t+r,v++}for(var n=this._w,i=0|this._a,s=0|this._b,d=0|this._c,p=0|this._d,b=0|this._e,g=0|this._f,m=0|this._g,y=0|this._h,v=0;16>v;)r(e.readInt32BE(4*v));for(;64>v;)r(t());this._a=i+this._a|0,this._b=s+this._b|0,this._c=d+this._c|0,this._d=p+this._d|0,this._e=b+this._e|0,this._f=g+this._f|0,this._g=m+this._g|0,this._h=y+this._h|0},n.prototype._hash=function(){var e=new r(32);return e.writeInt32BE(this._a,0),e.writeInt32BE(this._b,4),e.writeInt32BE(this._c,8),e.writeInt32BE(this._d,12),e.writeInt32BE(this._e,16),e.writeInt32BE(this._f,20),e.writeInt32BE(this._g,24),e.writeInt32BE(this._h,28),e},t.exports=n}).call(this,e("buffer").Buffer)},{"./hash":101,buffer:46,inherits:193}],107:[function(e,t,r){(function(r){function n(){this.init(),this._w=a,o.call(this,128,112)}var i=e("inherits"),s=e("./sha512"),o=e("./hash"),a=new Array(160);i(n,s),n.prototype.init=function(){return this._a=-876896931,this._b=1654270250,this._c=-1856437926,this._d=355462360,this._e=1731405415,this._f=-1900787065,this._g=-619958771,this._h=1203062813,this._al=-1056596264,this._bl=914150663,this._cl=812702999,this._dl=-150054599,this._el=-4191439,this._fl=1750603025,this._gl=1694076839,this._hl=-1090891868,this},n.prototype._hash=function(){function e(e,r,n){t.writeInt32BE(e,n),t.writeInt32BE(r,n+4)}var t=new r(48);return e(this._a,this._al,0),e(this._b,this._bl,8),e(this._c,this._cl,16),e(this._d,this._dl,24),e(this._e,this._el,32),e(this._f,this._fl,40),t},t.exports=n}).call(this,e("buffer").Buffer)},{"./hash":101,"./sha512":108,buffer:46,inherits:193}],108:[function(e,t,r){(function(r){function n(){this.init(),this._w=u,f.call(this,128,112)}function i(e,t,r){return e>>>r|t<<32-r}function s(e,t,r){return e&t^~e&r}function o(e,t,r){return e&t^e&r^t&r}var a=e("inherits"),f=e("./hash"),c=[1116352408,3609767458,1899447441,602891725,3049323471,3964484399,3921009573,2173295548,961987163,4081628472,1508970993,3053834265,2453635748,2937671579,2870763221,3664609560,3624381080,2734883394,310598401,1164996542,607225278,1323610764,1426881987,3590304994,1925078388,4068182383,2162078206,991336113,2614888103,633803317,3248222580,3479774868,3835390401,2666613458,4022224774,944711139,264347078,2341262773,604807628,2007800933,770255983,1495990901,1249150122,1856431235,1555081692,3175218132,1996064986,2198950837,2554220882,3999719339,2821834349,766784016,2952996808,2566594879,3210313671,3203337956,3336571891,1034457026,3584528711,2466948901,113926993,3758326383,338241895,168717936,666307205,1188179964,773529912,1546045734,1294757372,1522805485,1396182291,2643833823,1695183700,2343527390,1986661051,1014477480,2177026350,1206759142,2456956037,344077627,2730485921,1290863460,2820302411,3158454273,3259730800,3505952657,3345764771,106217008,3516065817,3606008344,3600352804,1432725776,4094571909,1467031594,275423344,851169720,430227734,3100823752,506948616,1363258195,659060556,3750685593,883997877,3785050280,958139571,3318307427,1322822218,3812723403,1537002063,2003034995,1747873779,3602036899,1955562222,1575990012,2024104815,1125592928,2227730452,2716904306,2361852424,442776044,2428436474,593698344,2756734187,3733110249,3204031479,2999351573,3329325298,3815920427,3391569614,3928383900,3515267271,566280711,3940187606,3454069534,4118630271,4000239992,116418474,1914138554,174292421,2731055270,289380356,3203993006,460393269,320620315,685471733,587496836,852142971,1086792851,1017036298,365543100,1126000580,2618297676,1288033470,3409855158,1501505948,4234509866,1607167915,987167468,1816402316,1246189591],u=new Array(160);a(n,f),n.prototype.init=function(){return this._a=1779033703,this._b=-1150833019,this._c=1013904242,this._d=-1521486534,this._e=1359893119,this._f=-1694144372,this._g=528734635,this._h=1541459225,this._al=-205731576,this._bl=-2067093701,this._cl=-23791573,this._dl=1595750129,this._el=-1377402159,this._fl=725511199,this._gl=-79577749,this._hl=327033209,this},n.prototype._update=function(e){function t(){var e=f[O-30],t=f[O-30+1],r=i(e,t,1)^i(e,t,8)^e>>>7,s=i(t,e,1)^i(t,e,8)^i(t,e,7);e=f[O-4],t=f[O-4+1];var o=i(e,t,19)^i(t,e,29)^e>>>6,c=i(t,e,19)^i(e,t,29)^i(t,e,6),u=f[O-14],h=f[O-14+1],d=f[O-32],p=f[O-32+1];a=s+h,n=r+u+(s>>>0>a>>>0?1:0),a+=c,n=n+o+(c>>>0>a>>>0?1:0),a+=p,n=n+d+(p>>>0>a>>>0?1:0)}function r(){f[O]=n,f[O+1]=a;var e=o(u,h,d),t=o(y,v,_),r=i(u,y,28)^i(y,u,2)^i(y,u,7),P=i(y,u,28)^i(u,y,2)^i(u,y,7),B=i(l,S,14)^i(l,S,18)^i(S,l,9),x=i(S,l,14)^i(S,l,18)^i(l,S,9),R=c[O],T=c[O+1],N=s(l,b,g),C=s(S,k,E),j=I+x,U=m+B+(I>>>0>j>>>0?1:0);j+=C,U=U+N+(C>>>0>j>>>0?1:0),j+=T,U=U+R+(T>>>0>j>>>0?1:0),j+=a,U=U+n+(a>>>0>j>>>0?1:0);var M=P+t,L=r+e+(P>>>0>M>>>0?1:0);m=g,I=E,g=b,E=k,b=l,k=S,S=w+j|0,l=p+U+(w>>>0>S>>>0?1:0)|0,p=d,w=_,d=h,_=v,h=u,v=y,y=j+M|0,u=U+L+(j>>>0>y>>>0?1:0)|0,A++,O+=2}for(var n,a,f=this._w,u=0|this._a,h=0|this._b,d=0|this._c,p=0|this._d,l=0|this._e,b=0|this._f,g=0|this._g,m=0|this._h,y=0|this._al,v=0|this._bl,_=0|this._cl,w=0|this._dl,S=0|this._el,k=0|this._fl,E=0|this._gl,I=0|this._hl,A=0,O=0;16>A;)n=e.readInt32BE(4*O),a=e.readInt32BE(4*O+4),r();for(;80>A;)t(),r();this._al=this._al+y|0,this._bl=this._bl+v|0,this._cl=this._cl+_|0,this._dl=this._dl+w|0,this._el=this._el+S|0,this._fl=this._fl+k|0,this._gl=this._gl+E|0,this._hl=this._hl+I|0,this._a=this._a+u+(this._al>>>0<y>>>0?1:0)|0,this._b=this._b+h+(this._bl>>>0<v>>>0?1:0)|0,this._c=this._c+d+(this._cl>>>0<_>>>0?1:0)|0,this._d=this._d+p+(this._dl>>>0<w>>>0?1:0)|0,this._e=this._e+l+(this._el>>>0<S>>>0?1:0)|0,this._f=this._f+b+(this._fl>>>0<k>>>0?1:0)|0,this._g=this._g+g+(this._gl>>>0<E>>>0?1:0)|0,this._h=this._h+m+(this._hl>>>0<I>>>0?1:0)|0},n.prototype._hash=function(){function e(e,r,n){t.writeInt32BE(e,n),t.writeInt32BE(r,n+4)}var t=new r(64);return e(this._a,this._al,0),e(this._b,this._bl,8),e(this._c,this._cl,16),e(this._d,this._dl,24),e(this._e,this._el,32),e(this._f,this._fl,40),e(this._g,this._gl,48),e(this._h,this._hl,56),t},t.exports=n}).call(this,e("buffer").Buffer)},{"./hash":101,buffer:46,inherits:193}],109:[function(e,t,r){(function(r){"use strict";function n(e,t){o.call(this),"string"==typeof t&&(t=new r(t));var n="sha512"===e||"sha384"===e?128:64;this._alg=e,this._key=t,t.length>n?t=i(e).update(t).digest():t.length<n&&(t=r.concat([t,a],n));for(var s=this._ipad=new r(n),f=this._opad=new r(n),c=0;n>c;c++)s[c]=54^t[c],f[c]=92^t[c];this._hash=i(e).update(s)}var i=e("create-hash/browser"),s=e("inherits"),o=e("stream").Transform,a=new r(128);a.fill(0),s(n,o),n.prototype.update=function(e,t){return this._hash.update(e,t),this},n.prototype._transform=function(e,t,r){this._hash.update(e),r()},n.prototype._flush=function(e){this.push(this.digest()),e()},n.prototype.digest=function(e){var t=this._hash.digest();return i(this._alg).update(this._opad).update(t).digest(e)},t.exports=function(e,t){return new n(e,t)}}).call(this,e("buffer").Buffer)},{buffer:46,"create-hash/browser":97,inherits:193,stream:163}],110:[function(e,t,r){(function(t){function n(e){var r=new t(o[e].prime,"hex"),n=new t(o[e].gen,"hex");return new a(r,n)}function i(e,r,n,i){return(t.isBuffer(r)||"string"==typeof r&&-1===["hex","binary","base64"].indexOf(r))&&(i=n,n=r,r=void 0),r=r||"binary",i=i||"binary",n=n||new t([2]),t.isBuffer(n)||(n=new t(n,i)),"number"==typeof e?new a(s(e,n),n,!0):(t.isBuffer(e)||(e=new t(e,r)),new a(e,n,!0))}var s=e("./lib/generatePrime"),o=e("./lib/primes"),a=e("./lib/dh");r.DiffieHellmanGroup=r.createDiffieHellmanGroup=r.getDiffieHellman=n,r.createDiffieHellman=r.DiffieHellman=i}).call(this,e("buffer").Buffer)},{"./lib/dh":111,"./lib/generatePrime":112,"./lib/primes":113,buffer:46}],111:[function(e,t,r){(function(r){function n(e,t){return t=t||"utf8",r.isBuffer(e)||(e=new r(e,t)),this._pub=new c(e),this}function i(e,t){return t=t||"utf8",r.isBuffer(e)||(e=new r(e,t)),this._priv=new c(e),this}function s(e,t){var r=t.toString("hex"),n=[r,e.toString(16)].join("_");if(n in v)return v[n];var i=0;if(e.isEven()||!m.simpleSieve||!m.fermatTest(e)||!h.test(e))return i+=1,i+="02"===r||"05"===r?8:4,v[n]=i,i;h.test(e.shrn(1))||(i+=2);var s;switch(r){case"02":e.mod(d).cmp(p)&&(i+=8);break;case"05":s=e.mod(l),s.cmp(b)&&s.cmp(g)&&(i+=8);break;default:i+=4}return v[n]=i,i}function o(e,t){try{Object.defineProperty(e,"verifyError",{enumerable:!0,value:t,writable:!1})}catch(r){e.verifyError=t}}function a(e,t,r){this.setGenerator(t),this.__prime=new c(e),this._prime=c.mont(this.__prime),this._primeLen=e.length,this._pub=void 0,this._priv=void 0,r?(this.setPublicKey=n,this.setPrivateKey=i,o(this,s(this.__prime,t))):o(this,8)}function f(e,t){var n=new r(e.toArray());return t?n.toString(t):n}var c=e("bn.js"),u=e("miller-rabin"),h=new u,d=new c(24),p=new c(11),l=new c(10),b=new c(3),g=new c(7),m=e("./generatePrime"),y=e("randombytes");t.exports=a;var v={};a.prototype.generateKeys=function(){return this._priv||(this._priv=new c(y(this._primeLen))),this._pub=this._gen.toRed(this._prime).redPow(this._priv).fromRed(),this.getPublicKey()},a.prototype.computeSecret=function(e){e=new c(e),e=e.toRed(this._prime);var t=e.redPow(this._priv).fromRed(),n=new r(t.toArray()),i=this.getPrime();if(n.length<i.length){var s=new r(i.length-n.length);s.fill(0),n=r.concat([s,n])}return n},a.prototype.getPublicKey=function(e){return f(this._pub,e)},a.prototype.getPrivateKey=function(e){return f(this._priv,e)},a.prototype.getPrime=function(e){return f(this.__prime,e)},a.prototype.getGenerator=function(e){return f(this._gen,e)},a.prototype.setGenerator=function(e,t){return t=t||"utf8",r.isBuffer(e)||(e=new r(e,t)),this._gen=new c(e),this}}).call(this,e("buffer").Buffer)},{"./generatePrime":112,"bn.js":170,buffer:46,"miller-rabin":114,randombytes:144}],112:[function(e,t,r){function n(){if(null!==S)return S;var e=1048576,t=[];t[0]=2;for(var r=1,n=3;e>n;n+=2){for(var i=Math.ceil(Math.sqrt(n)),s=0;r>s&&t[s]<=i&&n%t[s]!==0;s++);r!==s&&t[s]<=i||(t[r++]=n)}return S=t,t}function i(e){for(var t=n(),r=0;r<t.length;r++)if(0===e.modn(t[r]))return 0===e.cmpn(t[r])?!0:!1;return!0}function s(e){var t=f.mont(e);return 0===p.toRed(t).redPow(e.subn(1)).fromRed().cmpn(1)}function o(e,t){function r(e){n=-1;for(var r=new f(a(Math.ceil(e/8)));r.bitLength()>e;)r.ishrn(1);if(r.isEven()&&r.iadd(d),r.testn(1)||r.iadd(p),t.cmp(p))if(t.cmp(l))o={major:[_],minor:[p]};else{for(rem=r.mod(m);rem.cmp(y);)r.iadd(_),rem=r.mod(m);o={major:[_,b],minor:[p,g]}}else{for(;r.mod(c).cmp(v);)r.iadd(_);o={major:[c],minor:[w]}}return r}if(16>e)return new f(2===t||5===t?[140,123]:[140,39]);t=new f(t);for(var n,o,u=r(e),S=u.shrn(1);;){for(;u.bitLength()>e;)u=r(e),S=u.shrn(1);if(n++,i(S)&&i(u)&&s(S)&&s(u)&&h.test(S)&&h.test(u))return u;u.iadd(o.major[n%o.major.length]),S.iadd(o.minor[n%o.minor.length])}}var a=e("randombytes");t.exports=o,o.simpleSieve=i,o.fermatTest=s;var f=e("bn.js"),c=new f(24),u=e("miller-rabin"),h=new u,d=new f(1),p=new f(2),l=new f(5),b=new f(16),g=new f(8),m=new f(10),y=new f(3),v=(new f(7),new f(11)),_=new f(4),w=new f(12),S=null},{"bn.js":170,"miller-rabin":114,randombytes:144}],113:[function(e,t,r){t.exports={modp1:{gen:"02",prime:"ffffffffffffffffc90fdaa22168c234c4c6628b80dc1cd129024e088a67cc74020bbea63b139b22514a08798e3404ddef9519b3cd3a431b302b0a6df25f14374fe1356d6d51c245e485b576625e7ec6f44c42e9a63a3620ffffffffffffffff"},modp2:{gen:"02",prime:"ffffffffffffffffc90fdaa22168c234c4c6628b80dc1cd129024e088a67cc74020bbea63b139b22514a08798e3404ddef9519b3cd3a431b302b0a6df25f14374fe1356d6d51c245e485b576625e7ec6f44c42e9a637ed6b0bff5cb6f406b7edee386bfb5a899fa5ae9f24117c4b1fe649286651ece65381ffffffffffffffff"},modp5:{gen:"02",prime:"ffffffffffffffffc90fdaa22168c234c4c6628b80dc1cd129024e088a67cc74020bbea63b139b22514a08798e3404ddef9519b3cd3a431b302b0a6df25f14374fe1356d6d51c245e485b576625e7ec6f44c42e9a637ed6b0bff5cb6f406b7edee386bfb5a899fa5ae9f24117c4b1fe649286651ece45b3dc2007cb8a163bf0598da48361c55d39a69163fa8fd24cf5f83655d23dca3ad961c62f356208552bb9ed529077096966d670c354e4abc9804f1746c08ca237327ffffffffffffffff"},modp14:{gen:"02",prime:"ffffffffffffffffc90fdaa22168c234c4c6628b80dc1cd129024e088a67cc74020bbea63b139b22514a08798e3404ddef9519b3cd3a431b302b0a6df25f14374fe1356d6d51c245e485b576625e7ec6f44c42e9a637ed6b0bff5cb6f406b7edee386bfb5a899fa5ae9f24117c4b1fe649286651ece45b3dc2007cb8a163bf0598da48361c55d39a69163fa8fd24cf5f83655d23dca3ad961c62f356208552bb9ed529077096966d670c354e4abc9804f1746c08ca18217c32905e462e36ce3be39e772c180e86039b2783a2ec07a28fb5c55df06f4c52c9de2bcbf6955817183995497cea956ae515d2261898fa051015728e5a8aacaa68ffffffffffffffff"},modp15:{gen:"02",prime:"ffffffffffffffffc90fdaa22168c234c4c6628b80dc1cd129024e088a67cc74020bbea63b139b22514a08798e3404ddef9519b3cd3a431b302b0a6df25f14374fe1356d6d51c245e485b576625e7ec6f44c42e9a637ed6b0bff5cb6f406b7edee386bfb5a899fa5ae9f24117c4b1fe649286651ece45b3dc2007cb8a163bf0598da48361c55d39a69163fa8fd24cf5f83655d23dca3ad961c62f356208552bb9ed529077096966d670c354e4abc9804f1746c08ca18217c32905e462e36ce3be39e772c180e86039b2783a2ec07a28fb5c55df06f4c52c9de2bcbf6955817183995497cea956ae515d2261898fa051015728e5a8aaac42dad33170d04507a33a85521abdf1cba64ecfb850458dbef0a8aea71575d060c7db3970f85a6e1e4c7abf5ae8cdb0933d71e8c94e04a25619dcee3d2261ad2ee6bf12ffa06d98a0864d87602733ec86a64521f2b18177b200cbbe117577a615d6c770988c0bad946e208e24fa074e5ab3143db5bfce0fd108e4b82d120a93ad2caffffffffffffffff"},modp16:{gen:"02",prime:"ffffffffffffffffc90fdaa22168c234c4c6628b80dc1cd129024e088a67cc74020bbea63b139b22514a08798e3404ddef9519b3cd3a431b302b0a6df25f14374fe1356d6d51c245e485b576625e7ec6f44c42e9a637ed6b0bff5cb6f406b7edee386bfb5a899fa5ae9f24117c4b1fe649286651ece45b3dc2007cb8a163bf0598da48361c55d39a69163fa8fd24cf5f83655d23dca3ad961c62f356208552bb9ed529077096966d670c354e4abc9804f1746c08ca18217c32905e462e36ce3be39e772c180e86039b2783a2ec07a28fb5c55df06f4c52c9de2bcbf6955817183995497cea956ae515d2261898fa051015728e5a8aaac42dad33170d04507a33a85521abdf1cba64ecfb850458dbef0a8aea71575d060c7db3970f85a6e1e4c7abf5ae8cdb0933d71e8c94e04a25619dcee3d2261ad2ee6bf12ffa06d98a0864d87602733ec86a64521f2b18177b200cbbe117577a615d6c770988c0bad946e208e24fa074e5ab3143db5bfce0fd108e4b82d120a92108011a723c12a787e6d788719a10bdba5b2699c327186af4e23c1a946834b6150bda2583e9ca2ad44ce8dbbbc2db04de8ef92e8efc141fbecaa6287c59474e6bc05d99b2964fa090c3a2233ba186515be7ed1f612970cee2d7afb81bdd762170481cd0069127d5b05aa993b4ea988d8fddc186ffb7dc90a6c08f4df435c934063199ffffffffffffffff"},modp17:{gen:"02",prime:"ffffffffffffffffc90fdaa22168c234c4c6628b80dc1cd129024e088a67cc74020bbea63b139b22514a08798e3404ddef9519b3cd3a431b302b0a6df25f14374fe1356d6d51c245e485b576625e7ec6f44c42e9a637ed6b0bff5cb6f406b7edee386bfb5a899fa5ae9f24117c4b1fe649286651ece45b3dc2007cb8a163bf0598da48361c55d39a69163fa8fd24cf5f83655d23dca3ad961c62f356208552bb9ed529077096966d670c354e4abc9804f1746c08ca18217c32905e462e36ce3be39e772c180e86039b2783a2ec07a28fb5c55df06f4c52c9de2bcbf6955817183995497cea956ae515d2261898fa051015728e5a8aaac42dad33170d04507a33a85521abdf1cba64ecfb850458dbef0a8aea71575d060c7db3970f85a6e1e4c7abf5ae8cdb0933d71e8c94e04a25619dcee3d2261ad2ee6bf12ffa06d98a0864d87602733ec86a64521f2b18177b200cbbe117577a615d6c770988c0bad946e208e24fa074e5ab3143db5bfce0fd108e4b82d120a92108011a723c12a787e6d788719a10bdba5b2699c327186af4e23c1a946834b6150bda2583e9ca2ad44ce8dbbbc2db04de8ef92e8efc141fbecaa6287c59474e6bc05d99b2964fa090c3a2233ba186515be7ed1f612970cee2d7afb81bdd762170481cd0069127d5b05aa993b4ea988d8fddc186ffb7dc90a6c08f4df435c93402849236c3fab4d27c7026c1d4dcb2602646dec9751e763dba37bdf8ff9406ad9e530ee5db382f413001aeb06a53ed9027d831179727b0865a8918da3edbebcf9b14ed44ce6cbaced4bb1bdb7f1447e6cc254b332051512bd7af426fb8f401378cd2bf5983ca01c64b92ecf032ea15d1721d03f482d7ce6e74fef6d55e702f46980c82b5a84031900b1c9e59e7c97fbec7e8f323a97a7e36cc88be0f1d45b7ff585ac54bd407b22b4154aacc8f6d7ebf48e1d814cc5ed20f8037e0a79715eef29be32806a1d58bb7c5da76f550aa3d8a1fbff0eb19ccb1a313d55cda56c9ec2ef29632387fe8d76e3c0468043e8f663f4860ee12bf2d5b0b7474d6e694f91e6dcc4024ffffffffffffffff"},modp18:{gen:"02",prime:"ffffffffffffffffc90fdaa22168c234c4c6628b80dc1cd129024e088a67cc74020bbea63b139b22514a08798e3404ddef9519b3cd3a431b302b0a6df25f14374fe1356d6d51c245e485b576625e7ec6f44c42e9a637ed6b0bff5cb6f406b7edee386bfb5a899fa5ae9f24117c4b1fe649286651ece45b3dc2007cb8a163bf0598da48361c55d39a69163fa8fd24cf5f83655d23dca3ad961c62f356208552bb9ed529077096966d670c354e4abc9804f1746c08ca18217c32905e462e36ce3be39e772c180e86039b2783a2ec07a28fb5c55df06f4c52c9de2bcbf6955817183995497cea956ae515d2261898fa051015728e5a8aaac42dad33170d04507a33a85521abdf1cba64ecfb850458dbef0a8aea71575d060c7db3970f85a6e1e4c7abf5ae8cdb0933d71e8c94e04a25619dcee3d2261ad2ee6bf12ffa06d98a0864d87602733ec86a64521f2b18177b200cbbe117577a615d6c770988c0bad946e208e24fa074e5ab3143db5bfce0fd108e4b82d120a92108011a723c12a787e6d788719a10bdba5b2699c327186af4e23c1a946834b6150bda2583e9ca2ad44ce8dbbbc2db04de8ef92e8efc141fbecaa6287c59474e6bc05d99b2964fa090c3a2233ba186515be7ed1f612970cee2d7afb81bdd762170481cd0069127d5b05aa993b4ea988d8fddc186ffb7dc90a6c08f4df435c93402849236c3fab4d27c7026c1d4dcb2602646dec9751e763dba37bdf8ff9406ad9e530ee5db382f413001aeb06a53ed9027d831179727b0865a8918da3edbebcf9b14ed44ce6cbaced4bb1bdb7f1447e6cc254b332051512bd7af426fb8f401378cd2bf5983ca01c64b92ecf032ea15d1721d03f482d7ce6e74fef6d55e702f46980c82b5a84031900b1c9e59e7c97fbec7e8f323a97a7e36cc88be0f1d45b7ff585ac54bd407b22b4154aacc8f6d7ebf48e1d814cc5ed20f8037e0a79715eef29be32806a1d58bb7c5da76f550aa3d8a1fbff0eb19ccb1a313d55cda56c9ec2ef29632387fe8d76e3c0468043e8f663f4860ee12bf2d5b0b7474d6e694f91e6dbe115974a3926f12fee5e438777cb6a932df8cd8bec4d073b931ba3bc832b68d9dd300741fa7bf8afc47ed2576f6936ba424663aab639c5ae4f5683423b4742bf1c978238f16cbe39d652de3fdb8befc848ad922222e04a4037c0713eb57a81a23f0c73473fc646cea306b4bcbc8862f8385ddfa9d4b7fa2c087e879683303ed5bdd3a062b3cf5b3a278a66d2a13f83f44f82ddf310ee074ab6a364597e899a0255dc164f31cc50846851df9ab48195ded7ea1b1d510bd7ee74d73faf36bc31ecfa268359046f4eb879f924009438b481c6cd7889a002ed5ee382bc9190da6fc026e479558e4475677e9aa9e3050e2765694dfc81f56e880b96e7160c980dd98edd3dfffffffffffffffff"}}},{}],114:[function(e,t,r){function n(e){this.rand=e||new s.Rand}var i=e("bn.js"),s=e("brorand");t.exports=n,n.create=function(e){return new n(e)},n.prototype._rand=function(e){var t=e.bitLength(),r=this.rand.generate(Math.ceil(t/8));r[0]|=3;var n=7&t;return 0!==n&&(r[r.length-1]>>=7-n),new i(r)},n.prototype.test=function(e,t,r){var n=e.bitLength(),s=i.mont(e),o=new i(1).toRed(s);t||(t=Math.max(1,n/48|0));for(var a=e.subn(1),f=a.subn(1),c=0;!a.testn(c);c++);for(var u=e.shrn(c),h=a.toRed(s),d=!0;t>0;t--){var p=this._rand(f);r&&r(p);var l=p.toRed(s).redPow(u);if(0!==l.cmp(o)&&0!==l.cmp(h)){for(var b=1;c>b;b++){if(l=l.redSqr(),0===l.cmp(o))return!1;if(0===l.cmp(h))break}if(b===c)return!1}}return d},n.prototype.getDivisor=function(e,t){var r=e.bitLength(),n=i.mont(e),s=new i(1).toRed(n);t||(t=Math.max(1,r/48|0));for(var o=e.subn(1),a=o.subn(1),f=0;!o.testn(f);f++);for(var c=e.shrn(f),u=o.toRed(n);t>0;t--){var h=this._rand(a),d=e.gcd(h);if(0!==d.cmpn(1))return d;var p=h.toRed(n).redPow(c);if(0!==p.cmp(s)&&0!==p.cmp(u)){for(var l=1;f>l;l++){if(p=p.redSqr(),0===p.cmp(s))return p.fromRed().subn(1).gcd(e);if(0===p.cmp(u))break}if(l===f)return p=p.redSqr(),p.fromRed().subn(1).gcd(e)}}return!1}},{"bn.js":170,brorand:115}],115:[function(e,t,r){function n(e){this.rand=e}var i;if(t.exports=function(e){return i||(i=new n(null)),i.generate(e)},t.exports.Rand=n,n.prototype.generate=function(e){return this._rand(e)},"object"==typeof window)n.prototype._rand=window.crypto&&window.crypto.getRandomValues?function(e){var t=new Uint8Array(e);return window.crypto.getRandomValues(t),t}:window.msCrypto&&window.msCrypto.getRandomValues?function(e){var t=new Uint8Array(e);return window.msCrypto.getRandomValues(t),t}:function(){throw new Error("Not implemented yet")};else try{var s=e("crypto");n.prototype._rand=function(e){return s.randomBytes(e)}}catch(o){n.prototype._rand=function(e){for(var t=new Uint8Array(e),r=0;r<t.length;r++)t[r]=this.rand.getByte();return t}}},{}],116:[function(e,t,r){(function(t){function n(e,t,r,n,s,o){if("function"==typeof s&&(o=s,s=void 0),"function"!=typeof o)throw new Error("No callback provided to pbkdf2");var a=i(e,t,r,n,s);setTimeout(function(){o(void 0,a)})}function i(e,r,n,i,a){if("number"!=typeof n)throw new TypeError("Iterations not a number");if(0>n)throw new TypeError("Bad iterations");if("number"!=typeof i)throw new TypeError("Key length not a number");if(0>i||i>o)throw new TypeError("Bad key length");
a=a||"sha1",t.isBuffer(e)||(e=new t(e,"binary")),t.isBuffer(r)||(r=new t(r,"binary"));var f,c=1,u=new t(i),h=new t(r.length+4);r.copy(h,0,0,r.length);for(var d,p,l=1;c>=l;l++){h.writeUInt32BE(l,r.length);var b=s(a,e).update(h).digest();f||(f=b.length,p=new t(f),c=Math.ceil(i/f),d=i-(c-1)*f),b.copy(p,0,0,f);for(var g=1;n>g;g++){b=s(a,e).update(b).digest();for(var m=0;f>m;m++)p[m]^=b[m]}var y=(l-1)*f,v=l===c?d:f;p.copy(u,y,0,v)}return u}var s=e("create-hmac"),o=Math.pow(2,30)-1;r.pbkdf2=n,r.pbkdf2Sync=i}).call(this,e("buffer").Buffer)},{buffer:46,"create-hmac":109}],117:[function(e,t,r){r.publicEncrypt=e("./publicEncrypt"),r.privateDecrypt=e("./privateDecrypt"),r.privateEncrypt=function(e,t){return r.publicEncrypt(e,t,!0)},r.publicDecrypt=function(e,t){return r.privateDecrypt(e,t,!0)}},{"./privateDecrypt":140,"./publicEncrypt":141}],118:[function(e,t,r){(function(r){function n(e){var t=new r(4);return t.writeUInt32BE(e,0),t}var i=e("create-hash");t.exports=function(e,t){for(var s,o=new r(""),a=0;o.length<t;)s=n(a++),o=r.concat([o,i("sha1").update(e).update(s).digest()]);return o.slice(0,t)}}).call(this,e("buffer").Buffer)},{buffer:46,"create-hash":97}],119:[function(e,t,r){t.exports=e(72)},{"/home/braydon/bitcore/node_modules/bitcore-build/node_modules/browserify/node_modules/crypto-browserify/node_modules/browserify-sign/node_modules/browserify-rsa/index.js":72,"bn.js":170,buffer:46,randombytes:144}],120:[function(e,t,r){t.exports=e(73)},{"/home/braydon/bitcore/node_modules/bitcore-build/node_modules/browserify/node_modules/crypto-browserify/node_modules/browserify-sign/node_modules/parse-asn1/EVP_BytesToKey.js":73,buffer:46,"create-hash":97}],121:[function(e,t,r){t.exports=e(74)},{"/home/braydon/bitcore/node_modules/bitcore-build/node_modules/browserify/node_modules/crypto-browserify/node_modules/browserify-sign/node_modules/parse-asn1/aesid.json":74}],122:[function(e,t,r){t.exports=e(75)},{"/home/braydon/bitcore/node_modules/bitcore-build/node_modules/browserify/node_modules/crypto-browserify/node_modules/browserify-sign/node_modules/parse-asn1/asn1.js":75,"asn1.js":125}],123:[function(e,t,r){t.exports=e(76)},{"./EVP_BytesToKey":120,"/home/braydon/bitcore/node_modules/bitcore-build/node_modules/browserify/node_modules/crypto-browserify/node_modules/browserify-sign/node_modules/parse-asn1/fixProc.js":76,"browserify-aes":54,buffer:46}],124:[function(e,t,r){t.exports=e(77)},{"./aesid.json":121,"./asn1":122,"./fixProc":123,"/home/braydon/bitcore/node_modules/bitcore-build/node_modules/browserify/node_modules/crypto-browserify/node_modules/browserify-sign/node_modules/parse-asn1/index.js":77,"browserify-aes":54,buffer:46,pbkdf2:116}],125:[function(e,t,r){t.exports=e(78)},{"./asn1/api":126,"./asn1/base":128,"./asn1/constants":132,"./asn1/decoders":134,"./asn1/encoders":137,"/home/braydon/bitcore/node_modules/bitcore-build/node_modules/browserify/node_modules/crypto-browserify/node_modules/browserify-sign/node_modules/parse-asn1/node_modules/asn1.js/lib/asn1.js":78,"bn.js":170}],126:[function(e,t,r){t.exports=e(79)},{"../asn1":125,"/home/braydon/bitcore/node_modules/bitcore-build/node_modules/browserify/node_modules/crypto-browserify/node_modules/browserify-sign/node_modules/parse-asn1/node_modules/asn1.js/lib/asn1/api.js":79,inherits:193,vm:168}],127:[function(e,t,r){t.exports=e(80)},{"../base":128,"/home/braydon/bitcore/node_modules/bitcore-build/node_modules/browserify/node_modules/crypto-browserify/node_modules/browserify-sign/node_modules/parse-asn1/node_modules/asn1.js/lib/asn1/base/buffer.js":80,buffer:46,inherits:193}],128:[function(e,t,r){t.exports=e(81)},{"./buffer":127,"./node":129,"./reporter":130,"/home/braydon/bitcore/node_modules/bitcore-build/node_modules/browserify/node_modules/crypto-browserify/node_modules/browserify-sign/node_modules/parse-asn1/node_modules/asn1.js/lib/asn1/base/index.js":81}],129:[function(e,t,r){t.exports=e(82)},{"../base":128,"/home/braydon/bitcore/node_modules/bitcore-build/node_modules/browserify/node_modules/crypto-browserify/node_modules/browserify-sign/node_modules/parse-asn1/node_modules/asn1.js/lib/asn1/base/node.js":82,"minimalistic-assert":139}],130:[function(e,t,r){t.exports=e(83)},{"/home/braydon/bitcore/node_modules/bitcore-build/node_modules/browserify/node_modules/crypto-browserify/node_modules/browserify-sign/node_modules/parse-asn1/node_modules/asn1.js/lib/asn1/base/reporter.js":83,inherits:193}],131:[function(e,t,r){t.exports=e(84)},{"../constants":132,"/home/braydon/bitcore/node_modules/bitcore-build/node_modules/browserify/node_modules/crypto-browserify/node_modules/browserify-sign/node_modules/parse-asn1/node_modules/asn1.js/lib/asn1/constants/der.js":84}],132:[function(e,t,r){t.exports=e(85)},{"./der":131,"/home/braydon/bitcore/node_modules/bitcore-build/node_modules/browserify/node_modules/crypto-browserify/node_modules/browserify-sign/node_modules/parse-asn1/node_modules/asn1.js/lib/asn1/constants/index.js":85}],133:[function(e,t,r){t.exports=e(86)},{"../../asn1":125,"/home/braydon/bitcore/node_modules/bitcore-build/node_modules/browserify/node_modules/crypto-browserify/node_modules/browserify-sign/node_modules/parse-asn1/node_modules/asn1.js/lib/asn1/decoders/der.js":86,inherits:193}],134:[function(e,t,r){t.exports=e(87)},{"./der":133,"./pem":135,"/home/braydon/bitcore/node_modules/bitcore-build/node_modules/browserify/node_modules/crypto-browserify/node_modules/browserify-sign/node_modules/parse-asn1/node_modules/asn1.js/lib/asn1/decoders/index.js":87}],135:[function(e,t,r){t.exports=e(88)},{"../../asn1":125,"./der":133,"/home/braydon/bitcore/node_modules/bitcore-build/node_modules/browserify/node_modules/crypto-browserify/node_modules/browserify-sign/node_modules/parse-asn1/node_modules/asn1.js/lib/asn1/decoders/pem.js":88,buffer:46,inherits:193}],136:[function(e,t,r){t.exports=e(89)},{"../../asn1":125,"/home/braydon/bitcore/node_modules/bitcore-build/node_modules/browserify/node_modules/crypto-browserify/node_modules/browserify-sign/node_modules/parse-asn1/node_modules/asn1.js/lib/asn1/encoders/der.js":89,buffer:46,inherits:193}],137:[function(e,t,r){t.exports=e(90)},{"./der":136,"./pem":138,"/home/braydon/bitcore/node_modules/bitcore-build/node_modules/browserify/node_modules/crypto-browserify/node_modules/browserify-sign/node_modules/parse-asn1/node_modules/asn1.js/lib/asn1/encoders/index.js":90}],138:[function(e,t,r){t.exports=e(91)},{"../../asn1":125,"./der":136,"/home/braydon/bitcore/node_modules/bitcore-build/node_modules/browserify/node_modules/crypto-browserify/node_modules/browserify-sign/node_modules/parse-asn1/node_modules/asn1.js/lib/asn1/encoders/pem.js":91,buffer:46,inherits:193}],139:[function(e,t,r){t.exports=e(92)},{"/home/braydon/bitcore/node_modules/bitcore-build/node_modules/browserify/node_modules/crypto-browserify/node_modules/browserify-sign/node_modules/parse-asn1/node_modules/asn1.js/node_modules/minimalistic-assert/index.js":92}],140:[function(e,t,r){(function(r){function n(e,t){var n=(e.modulus,e.modulus.byteLength()),i=(t.length,h("sha1").update(new r("")).digest()),o=i.length;if(0!==t[0])throw new Error("decryption error");var c=t.slice(1,o+1),u=t.slice(o+1),d=f(c,a(u,o)),p=f(u,a(d,n-o-1));if(s(i,p.slice(0,o)))throw new Error("decryption error");for(var l=o;0===p[l];)l++;if(1!==p[l++])throw new Error("decryption error");return p.slice(l)}function i(e,t,r){for(var n=t.slice(0,2),i=2,s=0;0!==t[i++];)if(i>=t.length){s++;break}{var o=t.slice(2,i-1);t.slice(i-1,i)}if(("0002"!==n.toString("hex")&&!r||"0001"!==n.toString("hex")&&r)&&s++,o.length<8&&s++,s)throw new Error("decryption error");return t.slice(i)}function s(e,t){e=new r(e),t=new r(t);var n=0,i=e.length;e.length!==t.length&&(n++,i=Math.min(e.length,t.length));for(var s=-1;++s<i;)n+=e[s]^t[s];return n}var o=e("parse-asn1"),a=e("./mgf"),f=e("./xor"),c=e("bn.js"),u=e("browserify-rsa"),h=e("create-hash"),d=e("./withPublic");t.exports=function(e,t,s){var a;a=e.padding?e.padding:s?1:4;var f=o(e),h=f.modulus.byteLength();if(t.length>h||new c(t).cmp(f.modulus)>=0)throw new Error("decryption error");var p;p=s?d(new c(t),f):u(t,f);var l=new r(h-p.length);if(l.fill(0),p=r.concat([l,p],h),4===a)return n(f,p);if(1===a)return i(f,p,s);if(3===a)return p;throw new Error("unknown padding")}}).call(this,e("buffer").Buffer)},{"./mgf":118,"./withPublic":142,"./xor":143,"bn.js":170,"browserify-rsa":119,buffer:46,"create-hash":97,"parse-asn1":124}],141:[function(e,t,r){(function(r){function n(e,t){var n=e.modulus.byteLength(),i=t.length,s=f("sha1").update(new r("")).digest(),o=s.length,d=2*o;if(i>n-d-2)throw new Error("message too long");var p=new r(n-i-d-2);p.fill(0);var l=n-o-1,b=a(o),g=u(r.concat([s,p,new r([1]),t],l),c(b,l)),m=u(b,c(g,o));return new h(r.concat([new r([0]),m,g],n))}function i(e,t,n){var i=t.length,o=e.modulus.byteLength();if(i>o-11)throw new Error("message too long");var a;return n?(a=new r(o-i-3),a.fill(255)):a=s(o-i-3),new h(r.concat([new r([0,n?1:2]),a,new r([0]),t],o))}function s(e,t){for(var n,i=new r(e),s=0,o=a(2*e),f=0;e>s;)f===o.length&&(o=a(2*e),f=0),n=o[f++],n&&(i[s++]=n);return i}var o=e("parse-asn1"),a=e("randombytes"),f=e("create-hash"),c=e("./mgf"),u=e("./xor"),h=e("bn.js"),d=e("./withPublic"),p=e("browserify-rsa");t.exports=function(e,t,r){var s;s=e.padding?e.padding:r?1:4;var a,f=o(e);if(4===s)a=n(f,t);else if(1===s)a=i(f,t,r);else{if(3!==s)throw new Error("unknown padding");if(a=new h(t),a.cmp(f.modulus)>=0)throw new Error("data too long for modulus")}return r?p(a,f):d(a,f)}}).call(this,e("buffer").Buffer)},{"./mgf":118,"./withPublic":142,"./xor":143,"bn.js":170,"browserify-rsa":119,buffer:46,"create-hash":97,"parse-asn1":124,randombytes:144}],142:[function(e,t,r){(function(r){function n(e,t){return new r(e.toRed(i.mont(t.modulus)).redPow(new i(t.publicExponent)).fromRed().toArray())}var i=e("bn.js");t.exports=n}).call(this,e("buffer").Buffer)},{"bn.js":170,buffer:46}],143:[function(e,t,r){t.exports=function(e,t){for(var r=e.length,n=-1;++n<r;)e[n]^=t[n];return e}},{}],144:[function(e,t,r){(function(e,r,n){"use strict";function i(t,r){var i=new n(t);return o.getRandomValues(i),"function"==typeof r?e.nextTick(function(){r(null,i)}):i}function s(){throw new Error("secure random number generation not supported by this browser\nuse chrome, FireFox or Internet Explorer 11")}var o=r.crypto||r.msCrypto;t.exports=o&&o.getRandomValues?i:s}).call(this,e("_process"),"undefined"!=typeof global?global:"undefined"!=typeof self?self:"undefined"!=typeof window?window:{},e("buffer").Buffer)},{_process:147,buffer:46}],145:[function(e,t,r){function n(){this._events=this._events||{},this._maxListeners=this._maxListeners||void 0}function i(e){return"function"==typeof e}function s(e){return"number"==typeof e}function o(e){return"object"==typeof e&&null!==e}function a(e){return void 0===e}t.exports=n,n.EventEmitter=n,n.prototype._events=void 0,n.prototype._maxListeners=void 0,n.defaultMaxListeners=10,n.prototype.setMaxListeners=function(e){if(!s(e)||0>e||isNaN(e))throw TypeError("n must be a positive number");return this._maxListeners=e,this},n.prototype.emit=function(e){var t,r,n,s,f,c;if(this._events||(this._events={}),"error"===e&&(!this._events.error||o(this._events.error)&&!this._events.error.length)){if(t=arguments[1],t instanceof Error)throw t;throw TypeError('Uncaught, unspecified "error" event.')}if(r=this._events[e],a(r))return!1;if(i(r))switch(arguments.length){case 1:r.call(this);break;case 2:r.call(this,arguments[1]);break;case 3:r.call(this,arguments[1],arguments[2]);break;default:for(n=arguments.length,s=new Array(n-1),f=1;n>f;f++)s[f-1]=arguments[f];r.apply(this,s)}else if(o(r)){for(n=arguments.length,s=new Array(n-1),f=1;n>f;f++)s[f-1]=arguments[f];for(c=r.slice(),n=c.length,f=0;n>f;f++)c[f].apply(this,s)}return!0},n.prototype.addListener=function(e,t){var r;if(!i(t))throw TypeError("listener must be a function");if(this._events||(this._events={}),this._events.newListener&&this.emit("newListener",e,i(t.listener)?t.listener:t),this._events[e]?o(this._events[e])?this._events[e].push(t):this._events[e]=[this._events[e],t]:this._events[e]=t,o(this._events[e])&&!this._events[e].warned){var r;r=a(this._maxListeners)?n.defaultMaxListeners:this._maxListeners,r&&r>0&&this._events[e].length>r&&(this._events[e].warned=!0,console.error("(node) warning: possible EventEmitter memory leak detected. %d listeners added. Use emitter.setMaxListeners() to increase limit.",this._events[e].length),"function"==typeof console.trace&&console.trace())}return this},n.prototype.on=n.prototype.addListener,n.prototype.once=function(e,t){function r(){this.removeListener(e,r),n||(n=!0,t.apply(this,arguments))}if(!i(t))throw TypeError("listener must be a function");var n=!1;return r.listener=t,this.on(e,r),this},n.prototype.removeListener=function(e,t){var r,n,s,a;if(!i(t))throw TypeError("listener must be a function");if(!this._events||!this._events[e])return this;if(r=this._events[e],s=r.length,n=-1,r===t||i(r.listener)&&r.listener===t)delete this._events[e],this._events.removeListener&&this.emit("removeListener",e,t);else if(o(r)){for(a=s;a-->0;)if(r[a]===t||r[a].listener&&r[a].listener===t){n=a;break}if(0>n)return this;1===r.length?(r.length=0,delete this._events[e]):r.splice(n,1),this._events.removeListener&&this.emit("removeListener",e,t)}return this},n.prototype.removeAllListeners=function(e){var t,r;if(!this._events)return this;if(!this._events.removeListener)return 0===arguments.length?this._events={}:this._events[e]&&delete this._events[e],this;if(0===arguments.length){for(t in this._events)"removeListener"!==t&&this.removeAllListeners(t);return this.removeAllListeners("removeListener"),this._events={},this}if(r=this._events[e],i(r))this.removeListener(e,r);else for(;r.length;)this.removeListener(e,r[r.length-1]);return delete this._events[e],this},n.prototype.listeners=function(e){var t;return t=this._events&&this._events[e]?i(this._events[e])?[this._events[e]]:this._events[e].slice():[]},n.listenerCount=function(e,t){var r;return r=e._events&&e._events[t]?i(e._events[t])?1:e._events[t].length:0}},{}],146:[function(e,t,r){t.exports=Array.isArray||function(e){return"[object Array]"==Object.prototype.toString.call(e)}},{}],147:[function(e,t,r){function n(){}var i=t.exports={};i.nextTick=function(){var e="undefined"!=typeof window&&window.setImmediate,t="undefined"!=typeof window&&window.MutationObserver,r="undefined"!=typeof window&&window.postMessage&&window.addEventListener;if(e)return function(e){return window.setImmediate(e)};var n=[];if(t){var i=document.createElement("div"),s=new MutationObserver(function(){var e=n.slice();n.length=0,e.forEach(function(e){e()})});return s.observe(i,{attributes:!0}),function(e){n.length||i.setAttribute("yes","no"),n.push(e)}}return r?(window.addEventListener("message",function(e){var t=e.source;if((t===window||null===t)&&"process-tick"===e.data&&(e.stopPropagation(),n.length>0)){var r=n.shift();r()}},!0),function(e){n.push(e),window.postMessage("process-tick","*")}):function(e){setTimeout(e,0)}}(),i.title="browser",i.browser=!0,i.env={},i.argv=[],i.on=n,i.addListener=n,i.once=n,i.off=n,i.removeListener=n,i.removeAllListeners=n,i.emit=n,i.binding=function(e){throw new Error("process.binding is not supported")},i.cwd=function(){return"/"},i.chdir=function(e){throw new Error("process.chdir is not supported")}},{}],148:[function(e,t,r){(function(e){!function(n){function i(e){throw RangeError(N[e])}function s(e,t){for(var r=e.length;r--;)e[r]=t(e[r]);return e}function o(e,t){return s(e.split(T),t).join(".")}function a(e){for(var t,r,n=[],i=0,s=e.length;s>i;)t=e.charCodeAt(i++),t>=55296&&56319>=t&&s>i?(r=e.charCodeAt(i++),56320==(64512&r)?n.push(((1023&t)<<10)+(1023&r)+65536):(n.push(t),i--)):n.push(t);return n}function f(e){return s(e,function(e){var t="";return e>65535&&(e-=65536,t+=U(e>>>10&1023|55296),e=56320|1023&e),t+=U(e)}).join("")}function c(e){return 10>e-48?e-22:26>e-65?e-65:26>e-97?e-97:S}function u(e,t){return e+22+75*(26>e)-((0!=t)<<5)}function h(e,t,r){var n=0;for(e=r?j(e/A):e>>1,e+=j(e/t);e>C*E>>1;n+=S)e=j(e/C);return j(n+(C+1)*e/(e+I))}function d(e){var t,r,n,s,o,a,u,d,p,l,b=[],g=e.length,m=0,y=P,v=O;for(r=e.lastIndexOf(B),0>r&&(r=0),n=0;r>n;++n)e.charCodeAt(n)>=128&&i("not-basic"),b.push(e.charCodeAt(n));for(s=r>0?r+1:0;g>s;){for(o=m,a=1,u=S;s>=g&&i("invalid-input"),d=c(e.charCodeAt(s++)),(d>=S||d>j((w-m)/a))&&i("overflow"),m+=d*a,p=v>=u?k:u>=v+E?E:u-v,!(p>d);u+=S)l=S-p,a>j(w/l)&&i("overflow"),a*=l;t=b.length+1,v=h(m-o,t,0==o),j(m/t)>w-y&&i("overflow"),y+=j(m/t),m%=t,b.splice(m++,0,y)}return f(b)}function p(e){var t,r,n,s,o,f,c,d,p,l,b,g,m,y,v,_=[];for(e=a(e),g=e.length,t=P,r=0,o=O,f=0;g>f;++f)b=e[f],128>b&&_.push(U(b));for(n=s=_.length,s&&_.push(B);g>n;){for(c=w,f=0;g>f;++f)b=e[f],b>=t&&c>b&&(c=b);for(m=n+1,c-t>j((w-r)/m)&&i("overflow"),r+=(c-t)*m,t=c,f=0;g>f;++f)if(b=e[f],t>b&&++r>w&&i("overflow"),b==t){for(d=r,p=S;l=o>=p?k:p>=o+E?E:p-o,!(l>d);p+=S)v=d-l,y=S-l,_.push(U(u(l+v%y,0))),d=j(v/y);_.push(U(u(d,0))),o=h(r,m,n==s),r=0,++n}++r,++t}return _.join("")}function l(e){return o(e,function(e){return x.test(e)?d(e.slice(4).toLowerCase()):e})}function b(e){return o(e,function(e){return R.test(e)?"xn--"+p(e):e})}var g="object"==typeof r&&r,m="object"==typeof t&&t&&t.exports==g&&t,y="object"==typeof e&&e;(y.global===y||y.window===y)&&(n=y);var v,_,w=2147483647,S=36,k=1,E=26,I=38,A=700,O=72,P=128,B="-",x=/^xn--/,R=/[^ -~]/,T=/\x2E|\u3002|\uFF0E|\uFF61/g,N={overflow:"Overflow: input needs wider integers to process","not-basic":"Illegal input >= 0x80 (not a basic code point)","invalid-input":"Invalid input"},C=S-k,j=Math.floor,U=String.fromCharCode;if(v={version:"1.2.4",ucs2:{decode:a,encode:f},decode:d,encode:p,toASCII:b,toUnicode:l},"function"==typeof define&&"object"==typeof define.amd&&define.amd)define("punycode",function(){return v});else if(g&&!g.nodeType)if(m)m.exports=v;else for(_ in v)v.hasOwnProperty(_)&&(g[_]=v[_]);else n.punycode=v}(this)}).call(this,"undefined"!=typeof global?global:"undefined"!=typeof self?self:"undefined"!=typeof window?window:{})},{}],149:[function(e,t,r){"use strict";function n(e,t){return Object.prototype.hasOwnProperty.call(e,t)}t.exports=function(e,t,r,s){t=t||"&",r=r||"=";var o={};if("string"!=typeof e||0===e.length)return o;var a=/\+/g;e=e.split(t);var f=1e3;s&&"number"==typeof s.maxKeys&&(f=s.maxKeys);var c=e.length;f>0&&c>f&&(c=f);for(var u=0;c>u;++u){var h,d,p,l,b=e[u].replace(a,"%20"),g=b.indexOf(r);g>=0?(h=b.substr(0,g),d=b.substr(g+1)):(h=b,d=""),p=decodeURIComponent(h),l=decodeURIComponent(d),n(o,p)?i(o[p])?o[p].push(l):o[p]=[o[p],l]:o[p]=l}return o};var i=Array.isArray||function(e){return"[object Array]"===Object.prototype.toString.call(e)}},{}],150:[function(e,t,r){"use strict";function n(e,t){if(e.map)return e.map(t);for(var r=[],n=0;n<e.length;n++)r.push(t(e[n],n));return r}var i=function(e){switch(typeof e){case"string":return e;case"boolean":return e?"true":"false";case"number":return isFinite(e)?e:"";default:return""}};t.exports=function(e,t,r,a){return t=t||"&",r=r||"=",null===e&&(e=void 0),"object"==typeof e?n(o(e),function(o){var a=encodeURIComponent(i(o))+r;return s(e[o])?n(e[o],function(e){return a+encodeURIComponent(i(e))}).join(t):a+encodeURIComponent(i(e[o]))}).join(t):a?encodeURIComponent(i(a))+r+encodeURIComponent(i(e)):""};var s=Array.isArray||function(e){return"[object Array]"===Object.prototype.toString.call(e)},o=Object.keys||function(e){var t=[];for(var r in e)Object.prototype.hasOwnProperty.call(e,r)&&t.push(r);return t}},{}],151:[function(e,t,r){"use strict";r.decode=r.parse=e("./decode"),r.encode=r.stringify=e("./encode")},{"./decode":149,"./encode":150}],152:[function(e,t,r){t.exports=e("./lib/_stream_duplex.js")},{"./lib/_stream_duplex.js":153}],153:[function(e,t,r){(function(r){function n(e){return this instanceof n?(f.call(this,e),c.call(this,e),e&&e.readable===!1&&(this.readable=!1),e&&e.writable===!1&&(this.writable=!1),this.allowHalfOpen=!0,e&&e.allowHalfOpen===!1&&(this.allowHalfOpen=!1),void this.once("end",i)):new n(e)}function i(){this.allowHalfOpen||this._writableState.ended||r.nextTick(this.end.bind(this))}function s(e,t){for(var r=0,n=e.length;n>r;r++)t(e[r],r)}t.exports=n;var o=Object.keys||function(e){var t=[];for(var r in e)t.push(r);return t},a=e("core-util-is");a.inherits=e("inherits");var f=e("./_stream_readable"),c=e("./_stream_writable");a.inherits(n,f),s(o(c.prototype),function(e){n.prototype[e]||(n.prototype[e]=c.prototype[e])})}).call(this,e("_process"))},{"./_stream_readable":155,"./_stream_writable":157,_process:147,"core-util-is":158,inherits:193}],154:[function(e,t,r){function n(e){return this instanceof n?void i.call(this,e):new n(e)}t.exports=n;var i=e("./_stream_transform"),s=e("core-util-is");s.inherits=e("inherits"),s.inherits(n,i),n.prototype._transform=function(e,t,r){r(null,e)}},{"./_stream_transform":156,"core-util-is":158,inherits:193}],155:[function(e,t,r){(function(r){function n(t,r){var n=e("./_stream_duplex");t=t||{};var i=t.highWaterMark,s=t.objectMode?16:16384;this.highWaterMark=i||0===i?i:s,this.highWaterMark=~~this.highWaterMark,this.buffer=[],this.length=0,this.pipes=null,this.pipesCount=0,this.flowing=null,this.ended=!1,this.endEmitted=!1,this.reading=!1,this.sync=!0,this.needReadable=!1,this.emittedReadable=!1,this.readableListening=!1,this.objectMode=!!t.objectMode,r instanceof n&&(this.objectMode=this.objectMode||!!t.readableObjectMode),this.defaultEncoding=t.defaultEncoding||"utf8",this.ranOut=!1,this.awaitDrain=0,this.readingMore=!1,this.decoder=null,this.encoding=null,t.encoding&&(P||(P=e("string_decoder/").StringDecoder),this.decoder=new P(t.encoding),this.encoding=t.encoding)}function i(t){e("./_stream_duplex");return this instanceof i?(this._readableState=new n(t,this),this.readable=!0,void A.call(this)):new i(t)}function s(e,t,r,n,i){var s=c(t,r);if(s)e.emit("error",s);else if(O.isNullOrUndefined(r))t.reading=!1,t.ended||u(e,t);else if(t.objectMode||r&&r.length>0)if(t.ended&&!i){var a=new Error("stream.push() after EOF");e.emit("error",a)}else if(t.endEmitted&&i){var a=new Error("stream.unshift() after end event");e.emit("error",a)}else!t.decoder||i||n||(r=t.decoder.write(r)),i||(t.reading=!1),t.flowing&&0===t.length&&!t.sync?(e.emit("data",r),e.read(0)):(t.length+=t.objectMode?1:r.length,i?t.buffer.unshift(r):t.buffer.push(r),t.needReadable&&h(e)),p(e,t);else i||(t.reading=!1);return o(t)}function o(e){return!e.ended&&(e.needReadable||e.length<e.highWaterMark||0===e.length)}function a(e){if(e>=x)e=x;else{e--;for(var t=1;32>t;t<<=1)e|=e>>t;e++}return e}function f(e,t){return 0===t.length&&t.ended?0:t.objectMode?0===e?0:1:isNaN(e)||O.isNull(e)?t.flowing&&t.buffer.length?t.buffer[0].length:t.length:0>=e?0:(e>t.highWaterMark&&(t.highWaterMark=a(e)),e>t.length?t.ended?t.length:(t.needReadable=!0,0):e)}function c(e,t){var r=null;return O.isBuffer(t)||O.isString(t)||O.isNullOrUndefined(t)||e.objectMode||(r=new TypeError("Invalid non-string/buffer chunk")),r}function u(e,t){if(t.decoder&&!t.ended){var r=t.decoder.end();r&&r.length&&(t.buffer.push(r),t.length+=t.objectMode?1:r.length)}t.ended=!0,h(e)}function h(e){var t=e._readableState;t.needReadable=!1,t.emittedReadable||(B("emitReadable",t.flowing),t.emittedReadable=!0,t.sync?r.nextTick(function(){d(e)}):d(e))}function d(e){B("emit readable"),e.emit("readable"),y(e)}function p(e,t){t.readingMore||(t.readingMore=!0,r.nextTick(function(){l(e,t)}))}function l(e,t){for(var r=t.length;!t.reading&&!t.flowing&&!t.ended&&t.length<t.highWaterMark&&(B("maybeReadMore read 0"),e.read(0),r!==t.length);)r=t.length;t.readingMore=!1}function b(e){return function(){var t=e._readableState;B("pipeOnDrain",t.awaitDrain),t.awaitDrain&&t.awaitDrain--,0===t.awaitDrain&&I.listenerCount(e,"data")&&(t.flowing=!0,y(e))}}function g(e,t){t.resumeScheduled||(t.resumeScheduled=!0,r.nextTick(function(){m(e,t)}))}function m(e,t){t.resumeScheduled=!1,e.emit("resume"),y(e),t.flowing&&!t.reading&&e.read(0)}function y(e){var t=e._readableState;if(B("flow",t.flowing),t.flowing)do var r=e.read();while(null!==r&&t.flowing)}function v(e,t){var r,n=t.buffer,i=t.length,s=!!t.decoder,o=!!t.objectMode;if(0===n.length)return null;if(0===i)r=null;else if(o)r=n.shift();else if(!e||e>=i)r=s?n.join(""):E.concat(n,i),n.length=0;else if(e<n[0].length){var a=n[0];r=a.slice(0,e),n[0]=a.slice(e)}else if(e===n[0].length)r=n.shift();else{r=s?"":new E(e);for(var f=0,c=0,u=n.length;u>c&&e>f;c++){var a=n[0],h=Math.min(e-f,a.length);s?r+=a.slice(0,h):a.copy(r,f,0,h),h<a.length?n[0]=a.slice(h):n.shift(),f+=h}}return r}function _(e){var t=e._readableState;if(t.length>0)throw new Error("endReadable called on non-empty stream");t.endEmitted||(t.ended=!0,r.nextTick(function(){t.endEmitted||0!==t.length||(t.endEmitted=!0,e.readable=!1,e.emit("end"))}))}function w(e,t){for(var r=0,n=e.length;n>r;r++)t(e[r],r)}function S(e,t){for(var r=0,n=e.length;n>r;r++)if(e[r]===t)return r;return-1}t.exports=i;var k=e("isarray"),E=e("buffer").Buffer;i.ReadableState=n;var I=e("events").EventEmitter;I.listenerCount||(I.listenerCount=function(e,t){return e.listeners(t).length});var A=e("stream"),O=e("core-util-is");O.inherits=e("inherits");var P,B=e("util");B=B&&B.debuglog?B.debuglog("stream"):function(){},O.inherits(i,A),i.prototype.push=function(e,t){var r=this._readableState;return O.isString(e)&&!r.objectMode&&(t=t||r.defaultEncoding,t!==r.encoding&&(e=new E(e,t),t="")),s(this,r,e,t,!1)},i.prototype.unshift=function(e){var t=this._readableState;return s(this,t,e,"",!0)},i.prototype.setEncoding=function(t){return P||(P=e("string_decoder/").StringDecoder),this._readableState.decoder=new P(t),this._readableState.encoding=t,this};var x=8388608;i.prototype.read=function(e){B("read",e);var t=this._readableState,r=e;if((!O.isNumber(e)||e>0)&&(t.emittedReadable=!1),0===e&&t.needReadable&&(t.length>=t.highWaterMark||t.ended))return B("read: emitReadable",t.length,t.ended),0===t.length&&t.ended?_(this):h(this),null;if(e=f(e,t),0===e&&t.ended)return 0===t.length&&_(this),null;var n=t.needReadable;B("need readable",n),(0===t.length||t.length-e<t.highWaterMark)&&(n=!0,B("length less than watermark",n)),(t.ended||t.reading)&&(n=!1,B("reading or ended",n)),n&&(B("do read"),t.reading=!0,t.sync=!0,0===t.length&&(t.needReadable=!0),this._read(t.highWaterMark),t.sync=!1),n&&!t.reading&&(e=f(r,t));var i;return i=e>0?v(e,t):null,O.isNull(i)&&(t.needReadable=!0,e=0),t.length-=e,0!==t.length||t.ended||(t.needReadable=!0),r!==e&&t.ended&&0===t.length&&_(this),O.isNull(i)||this.emit("data",i),i},i.prototype._read=function(e){this.emit("error",new Error("not implemented"))},i.prototype.pipe=function(e,t){function n(e){B("onunpipe"),e===h&&s()}function i(){B("onend"),e.end()}function s(){B("cleanup"),e.removeListener("close",f),e.removeListener("finish",c),e.removeListener("drain",g),e.removeListener("error",a),e.removeListener("unpipe",n),h.removeListener("end",i),h.removeListener("end",s),h.removeListener("data",o),!d.awaitDrain||e._writableState&&!e._writableState.needDrain||g()}function o(t){B("ondata");var r=e.write(t);!1===r&&(B("false write response, pause",h._readableState.awaitDrain),h._readableState.awaitDrain++,h.pause())}function a(t){B("onerror",t),u(),e.removeListener("error",a),0===I.listenerCount(e,"error")&&e.emit("error",t)}function f(){e.removeListener("finish",c),u()}function c(){B("onfinish"),e.removeListener("close",f),u()}function u(){B("unpipe"),h.unpipe(e)}var h=this,d=this._readableState;switch(d.pipesCount){case 0:d.pipes=e;break;case 1:d.pipes=[d.pipes,e];break;default:d.pipes.push(e)}d.pipesCount+=1,B("pipe count=%d opts=%j",d.pipesCount,t);var p=(!t||t.end!==!1)&&e!==r.stdout&&e!==r.stderr,l=p?i:s;d.endEmitted?r.nextTick(l):h.once("end",l),e.on("unpipe",n);var g=b(h);return e.on("drain",g),h.on("data",o),e._events&&e._events.error?k(e._events.error)?e._events.error.unshift(a):e._events.error=[a,e._events.error]:e.on("error",a),e.once("close",f),e.once("finish",c),e.emit("pipe",h),d.flowing||(B("pipe resume"),h.resume()),e},i.prototype.unpipe=function(e){var t=this._readableState;if(0===t.pipesCount)return this;if(1===t.pipesCount)return e&&e!==t.pipes?this:(e||(e=t.pipes),t.pipes=null,t.pipesCount=0,t.flowing=!1,e&&e.emit("unpipe",this),this);if(!e){var r=t.pipes,n=t.pipesCount;t.pipes=null,t.pipesCount=0,t.flowing=!1;for(var i=0;n>i;i++)r[i].emit("unpipe",this);return this}var i=S(t.pipes,e);return-1===i?this:(t.pipes.splice(i,1),t.pipesCount-=1,1===t.pipesCount&&(t.pipes=t.pipes[0]),e.emit("unpipe",this),this)},i.prototype.on=function(e,t){var n=A.prototype.on.call(this,e,t);if("data"===e&&!1!==this._readableState.flowing&&this.resume(),"readable"===e&&this.readable){var i=this._readableState;if(!i.readableListening)if(i.readableListening=!0,i.emittedReadable=!1,i.needReadable=!0,i.reading)i.length&&h(this,i);else{var s=this;r.nextTick(function(){B("readable nexttick read 0"),s.read(0)})}}return n},i.prototype.addListener=i.prototype.on,i.prototype.resume=function(){var e=this._readableState;return e.flowing||(B("resume"),e.flowing=!0,e.reading||(B("resume read 0"),this.read(0)),g(this,e)),this},i.prototype.pause=function(){return B("call pause flowing=%j",this._readableState.flowing),!1!==this._readableState.flowing&&(B("pause"),this._readableState.flowing=!1,this.emit("pause")),this},i.prototype.wrap=function(e){var t=this._readableState,r=!1,n=this;e.on("end",function(){if(B("wrapped end"),t.decoder&&!t.ended){var e=t.decoder.end();e&&e.length&&n.push(e)}n.push(null)}),e.on("data",function(i){if(B("wrapped data"),t.decoder&&(i=t.decoder.write(i)),i&&(t.objectMode||i.length)){var s=n.push(i);s||(r=!0,e.pause())}});for(var i in e)O.isFunction(e[i])&&O.isUndefined(this[i])&&(this[i]=function(t){return function(){return e[t].apply(e,arguments)}}(i));var s=["error","close","destroy","pause","resume"];return w(s,function(t){e.on(t,n.emit.bind(n,t))}),n._read=function(t){B("wrapped _read",t),r&&(r=!1,e.resume())},n},i._fromList=v}).call(this,e("_process"))},{"./_stream_duplex":153,_process:147,buffer:46,"core-util-is":158,events:145,inherits:193,isarray:146,stream:163,"string_decoder/":164,util:45}],156:[function(e,t,r){function n(e,t){this.afterTransform=function(e,r){return i(t,e,r)},this.needTransform=!1,this.transforming=!1,this.writecb=null,this.writechunk=null}function i(e,t,r){var n=e._transformState;n.transforming=!1;var i=n.writecb;if(!i)return e.emit("error",new Error("no writecb in Transform class"));n.writechunk=null,n.writecb=null,f.isNullOrUndefined(r)||e.push(r),i&&i(t);var s=e._readableState;s.reading=!1,(s.needReadable||s.length<s.highWaterMark)&&e._read(s.highWaterMark)}function s(e){if(!(this instanceof s))return new s(e);a.call(this,e),this._transformState=new n(e,this);var t=this;this._readableState.needReadable=!0,this._readableState.sync=!1,this.once("prefinish",function(){f.isFunction(this._flush)?this._flush(function(e){o(t,e)}):o(t)})}function o(e,t){if(t)return e.emit("error",t);var r=e._writableState,n=e._transformState;if(r.length)throw new Error("calling transform done when ws.length != 0");if(n.transforming)throw new Error("calling transform done when still transforming");return e.push(null)}t.exports=s;var a=e("./_stream_duplex"),f=e("core-util-is");f.inherits=e("inherits"),f.inherits(s,a),s.prototype.push=function(e,t){return this._transformState.needTransform=!1,a.prototype.push.call(this,e,t)},s.prototype._transform=function(e,t,r){throw new Error("not implemented")},s.prototype._write=function(e,t,r){var n=this._transformState;if(n.writecb=r,n.writechunk=e,n.writeencoding=t,!n.transforming){var i=this._readableState;(n.needTransform||i.needReadable||i.length<i.highWaterMark)&&this._read(i.highWaterMark)}},s.prototype._read=function(e){var t=this._transformState;f.isNull(t.writechunk)||!t.writecb||t.transforming?t.needTransform=!0:(t.transforming=!0,this._transform(t.writechunk,t.writeencoding,t.afterTransform))}},{"./_stream_duplex":153,"core-util-is":158,inherits:193}],157:[function(e,t,r){
(function(r){function n(e,t,r){this.chunk=e,this.encoding=t,this.callback=r}function i(t,r){var n=e("./_stream_duplex");t=t||{};var i=t.highWaterMark,s=t.objectMode?16:16384;this.highWaterMark=i||0===i?i:s,this.objectMode=!!t.objectMode,r instanceof n&&(this.objectMode=this.objectMode||!!t.writableObjectMode),this.highWaterMark=~~this.highWaterMark,this.needDrain=!1,this.ending=!1,this.ended=!1,this.finished=!1;var o=t.decodeStrings===!1;this.decodeStrings=!o,this.defaultEncoding=t.defaultEncoding||"utf8",this.length=0,this.writing=!1,this.corked=0,this.sync=!0,this.bufferProcessing=!1,this.onwrite=function(e){p(r,e)},this.writecb=null,this.writelen=0,this.buffer=[],this.pendingcb=0,this.prefinished=!1,this.errorEmitted=!1}function s(t){var r=e("./_stream_duplex");return this instanceof s||this instanceof r?(this._writableState=new i(t,this),this.writable=!0,void k.call(this)):new s(t)}function o(e,t,n){var i=new Error("write after end");e.emit("error",i),r.nextTick(function(){n(i)})}function a(e,t,n,i){var s=!0;if(!(S.isBuffer(n)||S.isString(n)||S.isNullOrUndefined(n)||t.objectMode)){var o=new TypeError("Invalid non-string/buffer chunk");e.emit("error",o),r.nextTick(function(){i(o)}),s=!1}return s}function f(e,t,r){return!e.objectMode&&e.decodeStrings!==!1&&S.isString(t)&&(t=new w(t,r)),t}function c(e,t,r,i,s){r=f(t,r,i),S.isBuffer(r)&&(i="buffer");var o=t.objectMode?1:r.length;t.length+=o;var a=t.length<t.highWaterMark;return a||(t.needDrain=!0),t.writing||t.corked?t.buffer.push(new n(r,i,s)):u(e,t,!1,o,r,i,s),a}function u(e,t,r,n,i,s,o){t.writelen=n,t.writecb=o,t.writing=!0,t.sync=!0,r?e._writev(i,t.onwrite):e._write(i,s,t.onwrite),t.sync=!1}function h(e,t,n,i,s){n?r.nextTick(function(){t.pendingcb--,s(i)}):(t.pendingcb--,s(i)),e._writableState.errorEmitted=!0,e.emit("error",i)}function d(e){e.writing=!1,e.writecb=null,e.length-=e.writelen,e.writelen=0}function p(e,t){var n=e._writableState,i=n.sync,s=n.writecb;if(d(n),t)h(e,n,i,t,s);else{var o=m(e,n);o||n.corked||n.bufferProcessing||!n.buffer.length||g(e,n),i?r.nextTick(function(){l(e,n,o,s)}):l(e,n,o,s)}}function l(e,t,r,n){r||b(e,t),t.pendingcb--,n(),v(e,t)}function b(e,t){0===t.length&&t.needDrain&&(t.needDrain=!1,e.emit("drain"))}function g(e,t){if(t.bufferProcessing=!0,e._writev&&t.buffer.length>1){for(var r=[],n=0;n<t.buffer.length;n++)r.push(t.buffer[n].callback);t.pendingcb++,u(e,t,!0,t.length,t.buffer,"",function(e){for(var n=0;n<r.length;n++)t.pendingcb--,r[n](e)}),t.buffer=[]}else{for(var n=0;n<t.buffer.length;n++){var i=t.buffer[n],s=i.chunk,o=i.encoding,a=i.callback,f=t.objectMode?1:s.length;if(u(e,t,!1,f,s,o,a),t.writing){n++;break}}n<t.buffer.length?t.buffer=t.buffer.slice(n):t.buffer.length=0}t.bufferProcessing=!1}function m(e,t){return t.ending&&0===t.length&&!t.finished&&!t.writing}function y(e,t){t.prefinished||(t.prefinished=!0,e.emit("prefinish"))}function v(e,t){var r=m(e,t);return r&&(0===t.pendingcb?(y(e,t),t.finished=!0,e.emit("finish")):y(e,t)),r}function _(e,t,n){t.ending=!0,v(e,t),n&&(t.finished?r.nextTick(n):e.once("finish",n)),t.ended=!0}t.exports=s;var w=e("buffer").Buffer;s.WritableState=i;var S=e("core-util-is");S.inherits=e("inherits");var k=e("stream");S.inherits(s,k),s.prototype.pipe=function(){this.emit("error",new Error("Cannot pipe. Not readable."))},s.prototype.write=function(e,t,r){var n=this._writableState,i=!1;return S.isFunction(t)&&(r=t,t=null),S.isBuffer(e)?t="buffer":t||(t=n.defaultEncoding),S.isFunction(r)||(r=function(){}),n.ended?o(this,n,r):a(this,n,e,r)&&(n.pendingcb++,i=c(this,n,e,t,r)),i},s.prototype.cork=function(){var e=this._writableState;e.corked++},s.prototype.uncork=function(){var e=this._writableState;e.corked&&(e.corked--,e.writing||e.corked||e.finished||e.bufferProcessing||!e.buffer.length||g(this,e))},s.prototype._write=function(e,t,r){r(new Error("not implemented"))},s.prototype._writev=null,s.prototype.end=function(e,t,r){var n=this._writableState;S.isFunction(e)?(r=e,e=null,t=null):S.isFunction(t)&&(r=t,t=null),S.isNullOrUndefined(e)||this.write(e,t),n.corked&&(n.corked=1,this.uncork()),n.ending||n.finished||_(this,n,r)}}).call(this,e("_process"))},{"./_stream_duplex":153,_process:147,buffer:46,"core-util-is":158,inherits:193,stream:163}],158:[function(e,t,r){(function(e){function t(e){return Array.isArray(e)}function n(e){return"boolean"==typeof e}function i(e){return null===e}function s(e){return null==e}function o(e){return"number"==typeof e}function a(e){return"string"==typeof e}function f(e){return"symbol"==typeof e}function c(e){return void 0===e}function u(e){return h(e)&&"[object RegExp]"===m(e)}function h(e){return"object"==typeof e&&null!==e}function d(e){return h(e)&&"[object Date]"===m(e)}function p(e){return h(e)&&("[object Error]"===m(e)||e instanceof Error)}function l(e){return"function"==typeof e}function b(e){return null===e||"boolean"==typeof e||"number"==typeof e||"string"==typeof e||"symbol"==typeof e||"undefined"==typeof e}function g(t){return e.isBuffer(t)}function m(e){return Object.prototype.toString.call(e)}r.isArray=t,r.isBoolean=n,r.isNull=i,r.isNullOrUndefined=s,r.isNumber=o,r.isString=a,r.isSymbol=f,r.isUndefined=c,r.isRegExp=u,r.isObject=h,r.isDate=d,r.isError=p,r.isFunction=l,r.isPrimitive=b,r.isBuffer=g}).call(this,e("buffer").Buffer)},{buffer:46}],159:[function(e,t,r){t.exports=e("./lib/_stream_passthrough.js")},{"./lib/_stream_passthrough.js":154}],160:[function(e,t,r){r=t.exports=e("./lib/_stream_readable.js"),r.Stream=e("stream"),r.Readable=r,r.Writable=e("./lib/_stream_writable.js"),r.Duplex=e("./lib/_stream_duplex.js"),r.Transform=e("./lib/_stream_transform.js"),r.PassThrough=e("./lib/_stream_passthrough.js")},{"./lib/_stream_duplex.js":153,"./lib/_stream_passthrough.js":154,"./lib/_stream_readable.js":155,"./lib/_stream_transform.js":156,"./lib/_stream_writable.js":157,stream:163}],161:[function(e,t,r){t.exports=e("./lib/_stream_transform.js")},{"./lib/_stream_transform.js":156}],162:[function(e,t,r){t.exports=e("./lib/_stream_writable.js")},{"./lib/_stream_writable.js":157}],163:[function(e,t,r){function n(){i.call(this)}t.exports=n;var i=e("events").EventEmitter,s=e("inherits");s(n,i),n.Readable=e("readable-stream/readable.js"),n.Writable=e("readable-stream/writable.js"),n.Duplex=e("readable-stream/duplex.js"),n.Transform=e("readable-stream/transform.js"),n.PassThrough=e("readable-stream/passthrough.js"),n.Stream=n,n.prototype.pipe=function(e,t){function r(t){e.writable&&!1===e.write(t)&&c.pause&&c.pause()}function n(){c.readable&&c.resume&&c.resume()}function s(){u||(u=!0,e.end())}function o(){u||(u=!0,"function"==typeof e.destroy&&e.destroy())}function a(e){if(f(),0===i.listenerCount(this,"error"))throw e}function f(){c.removeListener("data",r),e.removeListener("drain",n),c.removeListener("end",s),c.removeListener("close",o),c.removeListener("error",a),e.removeListener("error",a),c.removeListener("end",f),c.removeListener("close",f),e.removeListener("close",f)}var c=this;c.on("data",r),e.on("drain",n),e._isStdio||t&&t.end===!1||(c.on("end",s),c.on("close",o));var u=!1;return c.on("error",a),e.on("error",a),c.on("end",f),c.on("close",f),e.on("close",f),e.emit("pipe",c),e}},{events:145,inherits:193,"readable-stream/duplex.js":152,"readable-stream/passthrough.js":159,"readable-stream/readable.js":160,"readable-stream/transform.js":161,"readable-stream/writable.js":162}],164:[function(e,t,r){function n(e){if(e&&!f(e))throw new Error("Unknown encoding: "+e)}function i(e){return e.toString(this.encoding)}function s(e){this.charReceived=e.length%2,this.charLength=this.charReceived?2:0}function o(e){this.charReceived=e.length%3,this.charLength=this.charReceived?3:0}var a=e("buffer").Buffer,f=a.isEncoding||function(e){switch(e&&e.toLowerCase()){case"hex":case"utf8":case"utf-8":case"ascii":case"binary":case"base64":case"ucs2":case"ucs-2":case"utf16le":case"utf-16le":case"raw":return!0;default:return!1}},c=r.StringDecoder=function(e){switch(this.encoding=(e||"utf8").toLowerCase().replace(/[-_]/,""),n(e),this.encoding){case"utf8":this.surrogateSize=3;break;case"ucs2":case"utf16le":this.surrogateSize=2,this.detectIncompleteChar=s;break;case"base64":this.surrogateSize=3,this.detectIncompleteChar=o;break;default:return void(this.write=i)}this.charBuffer=new a(6),this.charReceived=0,this.charLength=0};c.prototype.write=function(e){for(var t="";this.charLength;){var r=e.length>=this.charLength-this.charReceived?this.charLength-this.charReceived:e.length;if(e.copy(this.charBuffer,this.charReceived,0,r),this.charReceived+=r,this.charReceived<this.charLength)return"";e=e.slice(r,e.length),t=this.charBuffer.slice(0,this.charLength).toString(this.encoding);var n=t.charCodeAt(t.length-1);if(!(n>=55296&&56319>=n)){if(this.charReceived=this.charLength=0,0===e.length)return t;break}this.charLength+=this.surrogateSize,t=""}this.detectIncompleteChar(e);var i=e.length;this.charLength&&(e.copy(this.charBuffer,0,e.length-this.charReceived,i),i-=this.charReceived),t+=e.toString(this.encoding,0,i);var i=t.length-1,n=t.charCodeAt(i);if(n>=55296&&56319>=n){var s=this.surrogateSize;return this.charLength+=s,this.charReceived+=s,this.charBuffer.copy(this.charBuffer,s,0,s),e.copy(this.charBuffer,0,0,s),t.substring(0,i)}return t},c.prototype.detectIncompleteChar=function(e){for(var t=e.length>=3?3:e.length;t>0;t--){var r=e[e.length-t];if(1==t&&r>>5==6){this.charLength=2;break}if(2>=t&&r>>4==14){this.charLength=3;break}if(3>=t&&r>>3==30){this.charLength=4;break}}this.charReceived=t},c.prototype.end=function(e){var t="";if(e&&e.length&&(t=this.write(e)),this.charReceived){var r=this.charReceived,n=this.charBuffer,i=this.encoding;t+=n.slice(0,r).toString(i)}return t}},{buffer:46}],165:[function(e,t,r){function n(){this.protocol=null,this.slashes=null,this.auth=null,this.host=null,this.port=null,this.hostname=null,this.hash=null,this.search=null,this.query=null,this.pathname=null,this.path=null,this.href=null}function i(e,t,r){if(e&&c(e)&&e instanceof n)return e;var i=new n;return i.parse(e,t,r),i}function s(e){return f(e)&&(e=i(e)),e instanceof n?e.format():n.prototype.format.call(e)}function o(e,t){return i(e,!1,!0).resolve(t)}function a(e,t){return e?i(e,!1,!0).resolveObject(t):t}function f(e){return"string"==typeof e}function c(e){return"object"==typeof e&&null!==e}function u(e){return null===e}function h(e){return null==e}var d=e("punycode");r.parse=i,r.resolve=o,r.resolveObject=a,r.format=s,r.Url=n;var p=/^([a-z0-9.+-]+:)/i,l=/:[0-9]*$/,b=["<",">",'"',"`"," ","\r","\n"," "],g=["{","}","|","\\","^","`"].concat(b),m=["'"].concat(g),y=["%","/","?",";","#"].concat(m),v=["/","?","#"],_=255,w=/^[a-z0-9A-Z_-]{0,63}$/,S=/^([a-z0-9A-Z_-]{0,63})(.*)$/,k={javascript:!0,"javascript:":!0},E={javascript:!0,"javascript:":!0},I={http:!0,https:!0,ftp:!0,gopher:!0,file:!0,"http:":!0,"https:":!0,"ftp:":!0,"gopher:":!0,"file:":!0},A=e("querystring");n.prototype.parse=function(e,t,r){if(!f(e))throw new TypeError("Parameter 'url' must be a string, not "+typeof e);var n=e;n=n.trim();var i=p.exec(n);if(i){i=i[0];var s=i.toLowerCase();this.protocol=s,n=n.substr(i.length)}if(r||i||n.match(/^\/\/[^@\/]+@[^@\/]+/)){var o="//"===n.substr(0,2);!o||i&&E[i]||(n=n.substr(2),this.slashes=!0)}if(!E[i]&&(o||i&&!I[i])){for(var a=-1,c=0;c<v.length;c++){var u=n.indexOf(v[c]);-1!==u&&(-1===a||a>u)&&(a=u)}var h,l;l=-1===a?n.lastIndexOf("@"):n.lastIndexOf("@",a),-1!==l&&(h=n.slice(0,l),n=n.slice(l+1),this.auth=decodeURIComponent(h)),a=-1;for(var c=0;c<y.length;c++){var u=n.indexOf(y[c]);-1!==u&&(-1===a||a>u)&&(a=u)}-1===a&&(a=n.length),this.host=n.slice(0,a),n=n.slice(a),this.parseHost(),this.hostname=this.hostname||"";var b="["===this.hostname[0]&&"]"===this.hostname[this.hostname.length-1];if(!b)for(var g=this.hostname.split(/\./),c=0,O=g.length;O>c;c++){var P=g[c];if(P&&!P.match(w)){for(var B="",x=0,R=P.length;R>x;x++)B+=P.charCodeAt(x)>127?"x":P[x];if(!B.match(w)){var T=g.slice(0,c),N=g.slice(c+1),C=P.match(S);C&&(T.push(C[1]),N.unshift(C[2])),N.length&&(n="/"+N.join(".")+n),this.hostname=T.join(".");break}}}if(this.hostname=this.hostname.length>_?"":this.hostname.toLowerCase(),!b){for(var j=this.hostname.split("."),U=[],c=0;c<j.length;++c){var M=j[c];U.push(M.match(/[^A-Za-z0-9_-]/)?"xn--"+d.encode(M):M)}this.hostname=U.join(".")}var L=this.port?":"+this.port:"",D=this.hostname||"";this.host=D+L,this.href+=this.host,b&&(this.hostname=this.hostname.substr(1,this.hostname.length-2),"/"!==n[0]&&(n="/"+n))}if(!k[s])for(var c=0,O=m.length;O>c;c++){var H=m[c],F=encodeURIComponent(H);F===H&&(F=escape(H)),n=n.split(H).join(F)}var K=n.indexOf("#");-1!==K&&(this.hash=n.substr(K),n=n.slice(0,K));var z=n.indexOf("?");if(-1!==z?(this.search=n.substr(z),this.query=n.substr(z+1),t&&(this.query=A.parse(this.query)),n=n.slice(0,z)):t&&(this.search="",this.query={}),n&&(this.pathname=n),I[s]&&this.hostname&&!this.pathname&&(this.pathname="/"),this.pathname||this.search){var L=this.pathname||"",M=this.search||"";this.path=L+M}return this.href=this.format(),this},n.prototype.format=function(){var e=this.auth||"";e&&(e=encodeURIComponent(e),e=e.replace(/%3A/i,":"),e+="@");var t=this.protocol||"",r=this.pathname||"",n=this.hash||"",i=!1,s="";this.host?i=e+this.host:this.hostname&&(i=e+(-1===this.hostname.indexOf(":")?this.hostname:"["+this.hostname+"]"),this.port&&(i+=":"+this.port)),this.query&&c(this.query)&&Object.keys(this.query).length&&(s=A.stringify(this.query));var o=this.search||s&&"?"+s||"";return t&&":"!==t.substr(-1)&&(t+=":"),this.slashes||(!t||I[t])&&i!==!1?(i="//"+(i||""),r&&"/"!==r.charAt(0)&&(r="/"+r)):i||(i=""),n&&"#"!==n.charAt(0)&&(n="#"+n),o&&"?"!==o.charAt(0)&&(o="?"+o),r=r.replace(/[?#]/g,function(e){return encodeURIComponent(e)}),o=o.replace("#","%23"),t+i+r+o+n},n.prototype.resolve=function(e){return this.resolveObject(i(e,!1,!0)).format()},n.prototype.resolveObject=function(e){if(f(e)){var t=new n;t.parse(e,!1,!0),e=t}var r=new n;if(Object.keys(this).forEach(function(e){r[e]=this[e]},this),r.hash=e.hash,""===e.href)return r.href=r.format(),r;if(e.slashes&&!e.protocol)return Object.keys(e).forEach(function(t){"protocol"!==t&&(r[t]=e[t])}),I[r.protocol]&&r.hostname&&!r.pathname&&(r.path=r.pathname="/"),r.href=r.format(),r;if(e.protocol&&e.protocol!==r.protocol){if(!I[e.protocol])return Object.keys(e).forEach(function(t){r[t]=e[t]}),r.href=r.format(),r;if(r.protocol=e.protocol,e.host||E[e.protocol])r.pathname=e.pathname;else{for(var i=(e.pathname||"").split("/");i.length&&!(e.host=i.shift()););e.host||(e.host=""),e.hostname||(e.hostname=""),""!==i[0]&&i.unshift(""),i.length<2&&i.unshift(""),r.pathname=i.join("/")}if(r.search=e.search,r.query=e.query,r.host=e.host||"",r.auth=e.auth,r.hostname=e.hostname||e.host,r.port=e.port,r.pathname||r.search){var s=r.pathname||"",o=r.search||"";r.path=s+o}return r.slashes=r.slashes||e.slashes,r.href=r.format(),r}var a=r.pathname&&"/"===r.pathname.charAt(0),c=e.host||e.pathname&&"/"===e.pathname.charAt(0),d=c||a||r.host&&e.pathname,p=d,l=r.pathname&&r.pathname.split("/")||[],i=e.pathname&&e.pathname.split("/")||[],b=r.protocol&&!I[r.protocol];if(b&&(r.hostname="",r.port=null,r.host&&(""===l[0]?l[0]=r.host:l.unshift(r.host)),r.host="",e.protocol&&(e.hostname=null,e.port=null,e.host&&(""===i[0]?i[0]=e.host:i.unshift(e.host)),e.host=null),d=d&&(""===i[0]||""===l[0])),c)r.host=e.host||""===e.host?e.host:r.host,r.hostname=e.hostname||""===e.hostname?e.hostname:r.hostname,r.search=e.search,r.query=e.query,l=i;else if(i.length)l||(l=[]),l.pop(),l=l.concat(i),r.search=e.search,r.query=e.query;else if(!h(e.search)){if(b){r.hostname=r.host=l.shift();var g=r.host&&r.host.indexOf("@")>0?r.host.split("@"):!1;g&&(r.auth=g.shift(),r.host=r.hostname=g.shift())}return r.search=e.search,r.query=e.query,u(r.pathname)&&u(r.search)||(r.path=(r.pathname?r.pathname:"")+(r.search?r.search:"")),r.href=r.format(),r}if(!l.length)return r.pathname=null,r.path=r.search?"/"+r.search:null,r.href=r.format(),r;for(var m=l.slice(-1)[0],y=(r.host||e.host)&&("."===m||".."===m)||""===m,v=0,_=l.length;_>=0;_--)m=l[_],"."==m?l.splice(_,1):".."===m?(l.splice(_,1),v++):v&&(l.splice(_,1),v--);if(!d&&!p)for(;v--;v)l.unshift("..");!d||""===l[0]||l[0]&&"/"===l[0].charAt(0)||l.unshift(""),y&&"/"!==l.join("/").substr(-1)&&l.push("");var w=""===l[0]||l[0]&&"/"===l[0].charAt(0);if(b){r.hostname=r.host=w?"":l.length?l.shift():"";var g=r.host&&r.host.indexOf("@")>0?r.host.split("@"):!1;g&&(r.auth=g.shift(),r.host=r.hostname=g.shift())}return d=d||r.host&&l.length,d&&!w&&l.unshift(""),l.length?r.pathname=l.join("/"):(r.pathname=null,r.path=null),u(r.pathname)&&u(r.search)||(r.path=(r.pathname?r.pathname:"")+(r.search?r.search:"")),r.auth=e.auth||r.auth,r.slashes=r.slashes||e.slashes,r.href=r.format(),r},n.prototype.parseHost=function(){var e=this.host,t=l.exec(e);t&&(t=t[0],":"!==t&&(this.port=t.substr(1)),e=e.substr(0,e.length-t.length)),e&&(this.hostname=e)}},{punycode:148,querystring:151}],166:[function(e,t,r){t.exports=function(e){return e&&"object"==typeof e&&"function"==typeof e.copy&&"function"==typeof e.fill&&"function"==typeof e.readUInt8}},{}],167:[function(e,t,r){(function(t,n){function i(e,t){var n={seen:[],stylize:o};return arguments.length>=3&&(n.depth=arguments[2]),arguments.length>=4&&(n.colors=arguments[3]),b(t)?n.showHidden=t:t&&r._extend(n,t),w(n.showHidden)&&(n.showHidden=!1),w(n.depth)&&(n.depth=2),w(n.colors)&&(n.colors=!1),w(n.customInspect)&&(n.customInspect=!0),n.colors&&(n.stylize=s),f(n,e,n.depth)}function s(e,t){var r=i.styles[t];return r?"["+i.colors[r][0]+"m"+e+"["+i.colors[r][1]+"m":e}function o(e,t){return e}function a(e){var t={};return e.forEach(function(e,r){t[e]=!0}),t}function f(e,t,n){if(e.customInspect&&t&&A(t.inspect)&&t.inspect!==r.inspect&&(!t.constructor||t.constructor.prototype!==t)){var i=t.inspect(n,e);return v(i)||(i=f(e,i,n)),i}var s=c(e,t);if(s)return s;var o=Object.keys(t),b=a(o);if(e.showHidden&&(o=Object.getOwnPropertyNames(t)),I(t)&&(o.indexOf("message")>=0||o.indexOf("description")>=0))return u(t);if(0===o.length){if(A(t)){var g=t.name?": "+t.name:"";return e.stylize("[Function"+g+"]","special")}if(S(t))return e.stylize(RegExp.prototype.toString.call(t),"regexp");if(E(t))return e.stylize(Date.prototype.toString.call(t),"date");if(I(t))return u(t)}var m="",y=!1,_=["{","}"];if(l(t)&&(y=!0,_=["[","]"]),A(t)){var w=t.name?": "+t.name:"";m=" [Function"+w+"]"}if(S(t)&&(m=" "+RegExp.prototype.toString.call(t)),E(t)&&(m=" "+Date.prototype.toUTCString.call(t)),I(t)&&(m=" "+u(t)),0===o.length&&(!y||0==t.length))return _[0]+m+_[1];if(0>n)return S(t)?e.stylize(RegExp.prototype.toString.call(t),"regexp"):e.stylize("[Object]","special");e.seen.push(t);var k;return k=y?h(e,t,n,b,o):o.map(function(r){return d(e,t,n,b,r,y)}),e.seen.pop(),p(k,m,_)}function c(e,t){if(w(t))return e.stylize("undefined","undefined");if(v(t)){var r="'"+JSON.stringify(t).replace(/^"|"$/g,"").replace(/'/g,"\\'").replace(/\\"/g,'"')+"'";return e.stylize(r,"string")}return y(t)?e.stylize(""+t,"number"):b(t)?e.stylize(""+t,"boolean"):g(t)?e.stylize("null","null"):void 0}function u(e){return"["+Error.prototype.toString.call(e)+"]"}function h(e,t,r,n,i){for(var s=[],o=0,a=t.length;a>o;++o)s.push(R(t,String(o))?d(e,t,r,n,String(o),!0):"");return i.forEach(function(i){i.match(/^\d+$/)||s.push(d(e,t,r,n,i,!0))}),s}function d(e,t,r,n,i,s){var o,a,c;if(c=Object.getOwnPropertyDescriptor(t,i)||{value:t[i]},c.get?a=c.set?e.stylize("[Getter/Setter]","special"):e.stylize("[Getter]","special"):c.set&&(a=e.stylize("[Setter]","special")),R(n,i)||(o="["+i+"]"),a||(e.seen.indexOf(c.value)<0?(a=g(r)?f(e,c.value,null):f(e,c.value,r-1),a.indexOf("\n")>-1&&(a=s?a.split("\n").map(function(e){return" "+e}).join("\n").substr(2):"\n"+a.split("\n").map(function(e){return" "+e}).join("\n"))):a=e.stylize("[Circular]","special")),w(o)){if(s&&i.match(/^\d+$/))return a;o=JSON.stringify(""+i),o.match(/^"([a-zA-Z_][a-zA-Z_0-9]*)"$/)?(o=o.substr(1,o.length-2),o=e.stylize(o,"name")):(o=o.replace(/'/g,"\\'").replace(/\\"/g,'"').replace(/(^"|"$)/g,"'"),o=e.stylize(o,"string"))}return o+": "+a}function p(e,t,r){var n=0,i=e.reduce(function(e,t){return n++,t.indexOf("\n")>=0&&n++,e+t.replace(/\u001b\[\d\d?m/g,"").length+1},0);return i>60?r[0]+(""===t?"":t+"\n ")+" "+e.join(",\n ")+" "+r[1]:r[0]+t+" "+e.join(", ")+" "+r[1]}function l(e){return Array.isArray(e)}function b(e){return"boolean"==typeof e}function g(e){return null===e}function m(e){return null==e}function y(e){return"number"==typeof e}function v(e){return"string"==typeof e}function _(e){return"symbol"==typeof e}function w(e){return void 0===e}function S(e){return k(e)&&"[object RegExp]"===P(e)}function k(e){return"object"==typeof e&&null!==e}function E(e){return k(e)&&"[object Date]"===P(e)}function I(e){return k(e)&&("[object Error]"===P(e)||e instanceof Error)}function A(e){return"function"==typeof e}function O(e){return null===e||"boolean"==typeof e||"number"==typeof e||"string"==typeof e||"symbol"==typeof e||"undefined"==typeof e}function P(e){return Object.prototype.toString.call(e)}function B(e){return 10>e?"0"+e.toString(10):e.toString(10)}function x(){var e=new Date,t=[B(e.getHours()),B(e.getMinutes()),B(e.getSeconds())].join(":");return[e.getDate(),j[e.getMonth()],t].join(" ")}function R(e,t){return Object.prototype.hasOwnProperty.call(e,t)}var T=/%[sdj%]/g;r.format=function(e){if(!v(e)){for(var t=[],r=0;r<arguments.length;r++)t.push(i(arguments[r]));return t.join(" ")}for(var r=1,n=arguments,s=n.length,o=String(e).replace(T,function(e){if("%%"===e)return"%";if(r>=s)return e;switch(e){case"%s":return String(n[r++]);case"%d":return Number(n[r++]);case"%j":try{return JSON.stringify(n[r++])}catch(t){return"[Circular]"}default:return e}}),a=n[r];s>r;a=n[++r])o+=g(a)||!k(a)?" "+a:" "+i(a);return o},r.deprecate=function(e,i){function s(){if(!o){if(t.throwDeprecation)throw new Error(i);t.traceDeprecation?console.trace(i):console.error(i),o=!0}return e.apply(this,arguments)}if(w(n.process))return function(){return r.deprecate(e,i).apply(this,arguments)};if(t.noDeprecation===!0)return e;var o=!1;return s};var N,C={};r.debuglog=function(e){if(w(N)&&(N=t.env.NODE_DEBUG||""),e=e.toUpperCase(),!C[e])if(new RegExp("\\b"+e+"\\b","i").test(N)){var n=t.pid;C[e]=function(){var t=r.format.apply(r,arguments);console.error("%s %d: %s",e,n,t)}}else C[e]=function(){};return C[e]},r.inspect=i,i.colors={bold:[1,22],italic:[3,23],underline:[4,24],inverse:[7,27],white:[37,39],grey:[90,39],black:[30,39],blue:[34,39],cyan:[36,39],green:[32,39],magenta:[35,39],red:[31,39],yellow:[33,39]},i.styles={special:"cyan",number:"yellow","boolean":"yellow",undefined:"grey","null":"bold",string:"green",date:"magenta",regexp:"red"},r.isArray=l,r.isBoolean=b,r.isNull=g,r.isNullOrUndefined=m,r.isNumber=y,r.isString=v,r.isSymbol=_,r.isUndefined=w,r.isRegExp=S,r.isObject=k,r.isDate=E,r.isError=I,r.isFunction=A,r.isPrimitive=O,r.isBuffer=e("./support/isBuffer");var j=["Jan","Feb","Mar","Apr","May","Jun","Jul","Aug","Sep","Oct","Nov","Dec"];r.log=function(){console.log("%s - %s",x(),r.format.apply(r,arguments))},r.inherits=e("inherits"),r._extend=function(e,t){if(!t||!k(t))return e;for(var r=Object.keys(t),n=r.length;n--;)e[r[n]]=t[r[n]];return e}}).call(this,e("_process"),"undefined"!=typeof global?global:"undefined"!=typeof self?self:"undefined"!=typeof window?window:{})},{"./support/isBuffer":166,_process:147,inherits:193}],168:[function(require,module,exports){function Context(){}var indexOf=require("indexof"),Object_keys=function(e){if(Object.keys)return Object.keys(e);var t=[];for(var r in e)t.push(r);return t},forEach=function(e,t){if(e.forEach)return e.forEach(t);for(var r=0;r<e.length;r++)t(e[r],r,e)},defineProp=function(){try{return Object.defineProperty({},"_",{}),function(e,t,r){Object.defineProperty(e,t,{writable:!0,enumerable:!1,configurable:!0,value:r})}}catch(e){return function(e,t,r){e[t]=r}}}(),globals=["Array","Boolean","Date","Error","EvalError","Function","Infinity","JSON","Math","NaN","Number","Object","RangeError","ReferenceError","RegExp","String","SyntaxError","TypeError","URIError","decodeURI","decodeURIComponent","encodeURI","encodeURIComponent","escape","eval","isFinite","isNaN","parseFloat","parseInt","undefined","unescape"];Context.prototype={};var Script=exports.Script=function(e){return this instanceof Script?void(this.code=e):new Script(e)};Script.prototype.runInContext=function(e){if(!(e instanceof Context))throw new TypeError("needs a 'context' argument.");var t=document.createElement("iframe");t.style||(t.style={}),t.style.display="none",document.body.appendChild(t);var r=t.contentWindow,n=r.eval,i=r.execScript;!n&&i&&(i.call(r,"null"),n=r.eval),forEach(Object_keys(e),function(t){r[t]=e[t]}),forEach(globals,function(t){e[t]&&(r[t]=e[t])});var s=Object_keys(r),o=n.call(r,this.code);return forEach(Object_keys(r),function(t){(t in e||-1===indexOf(s,t))&&(e[t]=r[t])}),forEach(globals,function(t){t in e||defineProp(e,t,r[t])}),document.body.removeChild(t),o},Script.prototype.runInThisContext=function(){return eval(this.code)},Script.prototype.runInNewContext=function(e){var t=Script.createContext(e),r=this.runInContext(t);return forEach(Object_keys(t),function(r){e[r]=t[r]}),r},forEach(Object_keys(Script.prototype),function(e){exports[e]=Script[e]=function(t){var r=Script(t);return r[e].apply(r,[].slice.call(arguments,1))}}),exports.createScript=function(e){return exports.Script(e)},exports.createContext=Script.createContext=function(e){var t=new Context;return"object"==typeof e&&forEach(Object_keys(e),function(r){t[r]=e[r]}),t}},{indexof:169}],169:[function(e,t,r){var n=[].indexOf;t.exports=function(e,t){if(n)return e.indexOf(t);for(var r=0;r<e.length;++r)if(e[r]===t)return r;return-1}},{}],170:[function(e,t,r){!function(e,t){"use strict";function r(e,t){if(!e)throw new Error(t||"Assertion failed")}function n(e,t){e.super_=t;var r=function(){};r.prototype=t.prototype,e.prototype=new r,e.prototype.constructor=e}function i(e,t,r){return null!==e&&"object"==typeof e&&Array.isArray(e.words)?e:(this.sign=!1,this.words=null,this.length=0,this.red=null,("le"===t||"be"===t)&&(r=t,t=10),void(null!==e&&this._init(e||0,t||10,r||"be")))}function s(e,t,r){for(var n=0,i=Math.min(e.length,r),s=t;i>s;s++){var o=e.charCodeAt(s)-48;n<<=4,n|=o>=49&&54>=o?o-49+10:o>=17&&22>=o?o-17+10:15&o}return n}function o(e,t,r,n){for(var i=0,s=Math.min(e.length,r),o=t;s>o;o++){var a=e.charCodeAt(o)-48;i*=n,i+=a>=49?a-49+10:a>=17?a-17+10:a}return i}function a(e,t){this.name=e,this.p=new i(t,16),this.n=this.p.bitLength(),this.k=new i(1).ishln(this.n).isub(this.p),this.tmp=this._tmp()}function f(){a.call(this,"k256","ffffffff ffffffff ffffffff ffffffff ffffffff ffffffff fffffffe fffffc2f")}function c(){a.call(this,"p224","ffffffff ffffffff ffffffff ffffffff 00000000 00000000 00000001")}function u(){a.call(this,"p192","ffffffff ffffffff ffffffff fffffffe ffffffff ffffffff")}function h(){a.call(this,"25519","7fffffffffffffff ffffffffffffffff ffffffffffffffff ffffffffffffffed")}function d(e){if("string"==typeof e){var t=i._prime(e);this.m=t.p,this.prime=t}else this.m=e,this.prime=null}function p(e){d.call(this,e),this.shift=this.m.bitLength(),this.shift%26!==0&&(this.shift+=26-this.shift%26),this.r=new i(1).ishln(this.shift),this.r2=this.imod(this.r.sqr()),this.rinv=this.r._invmp(this.m),this.minv=this.rinv.mul(this.r).isubn(1).div(this.m),this.minv.sign=!0,this.minv=this.minv.mod(this.r)}"object"==typeof e?e.exports=i:t.BN=i,i.BN=i,i.wordSize=26,i.prototype._init=function(e,t,n){if("number"==typeof e)return 0>e&&(this.sign=!0,e=-e),void(67108864>e?(this.words=[67108863&e],this.length=1):4503599627370496>e?(this.words=[67108863&e,e/67108864&67108863],this.length=2):(r(9007199254740992>e),this.words=[67108863&e,e/67108864&67108863,1],this.length=3));if("object"==typeof e)return this._initArray(e,t,n);"hex"===t&&(t=16),r(t===(0|t)&&t>=2&&36>=t),e=e.toString().replace(/\s+/g,"");var i=0;"-"===e[0]&&i++,16===t?this._parseHex(e,i):this._parseBase(e,t,i),"-"===e[0]&&(this.sign=!0),this.strip()},i.prototype._initArray=function(e,t,n){if(r("number"==typeof e.length),e.length<=0)return this.words=[0],this.length=1,this;this.length=Math.ceil(e.length/3),this.words=new Array(this.length);for(var i=0;i<this.length;i++)this.words[i]=0;var s=0;if("be"===n)for(var i=e.length-1,o=0;i>=0;i-=3){var a=e[i]|e[i-1]<<8|e[i-2]<<16;this.words[o]|=a<<s&67108863,this.words[o+1]=a>>>26-s&67108863,s+=24,s>=26&&(s-=26,o++)}else if("le"===n)for(var i=0,o=0;i<e.length;i+=3){var a=e[i]|e[i+1]<<8|e[i+2]<<16;this.words[o]|=a<<s&67108863,this.words[o+1]=a>>>26-s&67108863,s+=24,s>=26&&(s-=26,o++)}return this.strip()},i.prototype._parseHex=function(e,t){this.length=Math.ceil((e.length-t)/6),this.words=new Array(this.length);for(var r=0;r<this.length;r++)this.words[r]=0;for(var n=0,r=e.length-6,i=0;r>=t;r-=6){var o=s(e,r,r+6);this.words[i]|=o<<n&67108863,this.words[i+1]|=o>>>26-n&4194303,n+=24,n>=26&&(n-=26,i++)}if(r+6!==t){var o=s(e,t,r+6);this.words[i]|=o<<n&67108863,this.words[i+1]|=o>>>26-n&4194303}this.strip()},i.prototype._parseBase=function(e,t,r){this.words=[0],this.length=1;for(var n=0,i=1;67108863>=i;i*=t)n++;n--,i=i/t|0;for(var s=e.length-r,a=s%n,f=Math.min(s,s-a)+r,c=0,u=r;f>u;u+=n)c=o(e,u,u+n,t),this.imuln(i),this.words[0]+c<67108864?this.words[0]+=c:this._iaddn(c);if(0!==a){for(var h=1,c=o(e,u,e.length,t),u=0;a>u;u++)h*=t;this.imuln(h),this.words[0]+c<67108864?this.words[0]+=c:this._iaddn(c)}},i.prototype.copy=function(e){e.words=new Array(this.length);for(var t=0;t<this.length;t++)e.words[t]=this.words[t];e.length=this.length,e.sign=this.sign,e.red=this.red},i.prototype.clone=function(){var e=new i(null);return this.copy(e),e},i.prototype.strip=function(){for(;this.length>1&&0===this.words[this.length-1];)this.length--;return this._normSign()},i.prototype._normSign=function(){return 1===this.length&&0===this.words[0]&&(this.sign=!1),this},i.prototype.inspect=function(){return(this.red?"<BN-R: ":"<BN: ")+this.toString(16)+">"};var l=["","0","00","000","0000","00000","000000","0000000","00000000","000000000","0000000000","00000000000","000000000000","0000000000000","00000000000000","000000000000000","0000000000000000","00000000000000000","000000000000000000","0000000000000000000","00000000000000000000","000000000000000000000","0000000000000000000000","00000000000000000000000","000000000000000000000000","0000000000000000000000000"],b=[0,0,25,16,12,11,10,9,8,8,7,7,7,7,6,6,6,6,6,6,6,5,5,5,5,5,5,5,5,5,5,5,5,5,5,5,5],g=[0,0,33554432,43046721,16777216,48828125,60466176,40353607,16777216,43046721,1e7,19487171,35831808,62748517,7529536,11390625,16777216,24137569,34012224,47045881,64e6,4084101,5153632,6436343,7962624,9765625,11881376,14348907,17210368,20511149,243e5,28629151,33554432,39135393,45435424,52521875,60466176];i.prototype.toString=function(e,t){if(e=e||10,16===e||"hex"===e){for(var n="",i=0,t=0|t||1,s=0,o=0;o<this.length;o++){var a=this.words[o],f=(16777215&(a<<i|s)).toString(16);s=a>>>24-i&16777215,n=0!==s||o!==this.length-1?l[6-f.length]+f+n:f+n,i+=2,i>=26&&(i-=26,o--)}for(0!==s&&(n=s.toString(16)+n);n.length%t!==0;)n="0"+n;return this.sign&&(n="-"+n),n}if(e===(0|e)&&e>=2&&36>=e){var c=b[e],u=g[e],n="",h=this.clone();for(h.sign=!1;0!==h.cmpn(0);){var d=h.modn(u).toString(e);h=h.idivn(u),n=0!==h.cmpn(0)?l[c-d.length]+d+n:d+n}return 0===this.cmpn(0)&&(n="0"+n),this.sign&&(n="-"+n),n}r(!1,"Base should be between 2 and 36")},i.prototype.toJSON=function(){return this.toString(16)},i.prototype.toArray=function(){this.strip();var e=new Array(this.byteLength());e[0]=0;for(var t=this.clone(),r=0;0!==t.cmpn(0);r++){var n=t.andln(255);t.ishrn(8),e[e.length-r-1]=n}return e},i.prototype._countBits=Math.clz32?function(e){return 32-Math.clz32(e)}:function(e){var t=e,r=0;return t>=4096&&(r+=13,t>>>=13),t>=64&&(r+=7,t>>>=7),t>=8&&(r+=4,t>>>=4),t>=2&&(r+=2,t>>>=2),r+t},i.prototype._zeroBits=function(e){if(0===e)return 26;var t=e,r=0;return 0===(8191&t)&&(r+=13,t>>>=13),0===(127&t)&&(r+=7,t>>>=7),0===(15&t)&&(r+=4,t>>>=4),0===(3&t)&&(r+=2,t>>>=2),0===(1&t)&&r++,
r},i.prototype.bitLength=function(){var e=0,t=this.words[this.length-1],e=this._countBits(t);return 26*(this.length-1)+e},i.prototype.zeroBits=function(){if(0===this.cmpn(0))return 0;for(var e=0,t=0;t<this.length;t++){var r=this._zeroBits(this.words[t]);if(e+=r,26!==r)break}return e},i.prototype.byteLength=function(){return Math.ceil(this.bitLength()/8)},i.prototype.neg=function(){if(0===this.cmpn(0))return this.clone();var e=this.clone();return e.sign=!this.sign,e},i.prototype.ior=function(e){for(this.sign=this.sign||e.sign;this.length<e.length;)this.words[this.length++]=0;for(var t=0;t<e.length;t++)this.words[t]=this.words[t]|e.words[t];return this.strip()},i.prototype.or=function(e){return this.length>e.length?this.clone().ior(e):e.clone().ior(this)},i.prototype.iand=function(e){this.sign=this.sign&&e.sign;var t;t=this.length>e.length?e:this;for(var r=0;r<t.length;r++)this.words[r]=this.words[r]&e.words[r];return this.length=t.length,this.strip()},i.prototype.and=function(e){return this.length>e.length?this.clone().iand(e):e.clone().iand(this)},i.prototype.ixor=function(e){this.sign=this.sign||e.sign;var t,r;this.length>e.length?(t=this,r=e):(t=e,r=this);for(var n=0;n<r.length;n++)this.words[n]=t.words[n]^r.words[n];if(this!==t)for(;n<t.length;n++)this.words[n]=t.words[n];return this.length=t.length,this.strip()},i.prototype.xor=function(e){return this.length>e.length?this.clone().ixor(e):e.clone().ixor(this)},i.prototype.setn=function(e,t){r("number"==typeof e&&e>=0);for(var n=e/26|0,i=e%26;this.length<=n;)this.words[this.length++]=0;return this.words[n]=t?this.words[n]|1<<i:this.words[n]&~(1<<i),this.strip()},i.prototype.iadd=function(e){if(this.sign&&!e.sign){this.sign=!1;var t=this.isub(e);return this.sign=!this.sign,this._normSign()}if(!this.sign&&e.sign){e.sign=!1;var t=this.isub(e);return e.sign=!0,t._normSign()}var r,n;this.length>e.length?(r=this,n=e):(r=e,n=this);for(var i=0,s=0;s<n.length;s++){var t=r.words[s]+n.words[s]+i;this.words[s]=67108863&t,i=t>>>26}for(;0!==i&&s<r.length;s++){var t=r.words[s]+i;this.words[s]=67108863&t,i=t>>>26}if(this.length=r.length,0!==i)this.words[this.length]=i,this.length++;else if(r!==this)for(;s<r.length;s++)this.words[s]=r.words[s];return this},i.prototype.add=function(e){if(e.sign&&!this.sign){e.sign=!1;var t=this.sub(e);return e.sign=!0,t}if(!e.sign&&this.sign){this.sign=!1;var t=e.sub(this);return this.sign=!0,t}return this.length>e.length?this.clone().iadd(e):e.clone().iadd(this)},i.prototype.isub=function(e){if(e.sign){e.sign=!1;var t=this.iadd(e);return e.sign=!0,t._normSign()}if(this.sign)return this.sign=!1,this.iadd(e),this.sign=!0,this._normSign();var r=this.cmp(e);if(0===r)return this.sign=!1,this.length=1,this.words[0]=0,this;var n,i;r>0?(n=this,i=e):(n=e,i=this);for(var s=0,o=0;o<i.length;o++){var t=n.words[o]-i.words[o]+s;s=t>>26,this.words[o]=67108863&t}for(;0!==s&&o<n.length;o++){var t=n.words[o]+s;s=t>>26,this.words[o]=67108863&t}if(0===s&&o<n.length&&n!==this)for(;o<n.length;o++)this.words[o]=n.words[o];return this.length=Math.max(this.length,o),n!==this&&(this.sign=!0),this.strip()},i.prototype.sub=function(e){return this.clone().isub(e)},i.prototype._smallMulTo=function(e,t){t.sign=e.sign!==this.sign,t.length=this.length+e.length;for(var r=0,n=0;n<t.length-1;n++){for(var i=r>>>26,s=67108863&r,o=Math.min(n,e.length-1),a=Math.max(0,n-this.length+1);o>=a;a++){var f=n-a,c=0|this.words[f],u=0|e.words[a],h=c*u,d=67108863&h;i=i+(h/67108864|0)|0,d=d+s|0,s=67108863&d,i=i+(d>>>26)|0}t.words[n]=s,r=i}return 0!==r?t.words[n]=r:t.length--,t.strip()},i.prototype._bigMulTo=function(e,t){t.sign=e.sign!==this.sign,t.length=this.length+e.length;for(var r=0,n=0,i=0;i<t.length-1;i++){var s=n;n=0;for(var o=67108863&r,a=Math.min(i,e.length-1),f=Math.max(0,i-this.length+1);a>=f;f++){var c=i-f,u=0|this.words[c],h=0|e.words[f],d=u*h,p=67108863&d;s=s+(d/67108864|0)|0,p=p+o|0,o=67108863&p,s=s+(p>>>26)|0,n+=s>>>26,s&=67108863}t.words[i]=o,r=s,s=n}return 0!==r?t.words[i]=r:t.length--,t.strip()},i.prototype.mulTo=function(e,t){var r;return r=this.length+e.length<63?this._smallMulTo(e,t):this._bigMulTo(e,t)},i.prototype.mul=function(e){var t=new i(null);return t.words=new Array(this.length+e.length),this.mulTo(e,t)},i.prototype.imul=function(e){if(0===this.cmpn(0)||0===e.cmpn(0))return this.words[0]=0,this.length=1,this;var t=this.length,r=e.length;this.sign=e.sign!==this.sign,this.length=this.length+e.length,this.words[this.length-1]=0;for(var n=this.length-2;n>=0;n--){for(var i=0,s=0,o=Math.min(n,r-1),a=Math.max(0,n-t+1);o>=a;a++){var f=n-a,c=this.words[f],u=e.words[a],h=c*u,d=67108863&h;i+=h/67108864|0,d+=s,s=67108863&d,i+=d>>>26}this.words[n]=s,this.words[n+1]+=i,i=0}for(var i=0,f=1;f<this.length;f++){var p=this.words[f]+i;this.words[f]=67108863&p,i=p>>>26}return this.strip()},i.prototype.imuln=function(e){r("number"==typeof e);for(var t=0,n=0;n<this.length;n++){var i=this.words[n]*e,s=(67108863&i)+(67108863&t);t>>=26,t+=i/67108864|0,t+=s>>>26,this.words[n]=67108863&s}return 0!==t&&(this.words[n]=t,this.length++),this},i.prototype.sqr=function(){return this.mul(this)},i.prototype.isqr=function(){return this.mul(this)},i.prototype.ishln=function(e){r("number"==typeof e&&e>=0);var t=e%26,n=(e-t)/26,i=67108863>>>26-t<<26-t;if(0!==t){for(var s=0,o=0;o<this.length;o++){var a=this.words[o]&i,f=this.words[o]-a<<t;this.words[o]=f|s,s=a>>>26-t}s&&(this.words[o]=s,this.length++)}if(0!==n){for(var o=this.length-1;o>=0;o--)this.words[o+n]=this.words[o];for(var o=0;n>o;o++)this.words[o]=0;this.length+=n}return this.strip()},i.prototype.ishrn=function(e,t,n){r("number"==typeof e&&e>=0);var i;i=t?(t-t%26)/26:0;var s=e%26,o=Math.min((e-s)/26,this.length),a=67108863^67108863>>>s<<s,f=n;if(i-=o,i=Math.max(0,i),f){for(var c=0;o>c;c++)f.words[c]=this.words[c];f.length=o}if(0===o);else if(this.length>o){this.length-=o;for(var c=0;c<this.length;c++)this.words[c]=this.words[c+o]}else this.words[0]=0,this.length=1;for(var u=0,c=this.length-1;c>=0&&(0!==u||c>=i);c--){var h=this.words[c];this.words[c]=u<<26-s|h>>>s,u=h&a}return f&&0!==u&&(f.words[f.length++]=u),0===this.length&&(this.words[0]=0,this.length=1),this.strip(),this},i.prototype.shln=function(e){return this.clone().ishln(e)},i.prototype.shrn=function(e){return this.clone().ishrn(e)},i.prototype.testn=function(e){r("number"==typeof e&&e>=0);var t=e%26,n=(e-t)/26,i=1<<t;if(this.length<=n)return!1;var s=this.words[n];return!!(s&i)},i.prototype.imaskn=function(e){r("number"==typeof e&&e>=0);var t=e%26,n=(e-t)/26;if(r(!this.sign,"imaskn works only with positive numbers"),0!==t&&n++,this.length=Math.min(n,this.length),0!==t){var i=67108863^67108863>>>t<<t;this.words[this.length-1]&=i}return this.strip()},i.prototype.maskn=function(e){return this.clone().imaskn(e)},i.prototype.iaddn=function(e){return r("number"==typeof e),0>e?this.isubn(-e):this.sign?1===this.length&&this.words[0]<e?(this.words[0]=e-this.words[0],this.sign=!1,this):(this.sign=!1,this.isubn(e),this.sign=!0,this):this._iaddn(e)},i.prototype._iaddn=function(e){this.words[0]+=e;for(var t=0;t<this.length&&this.words[t]>=67108864;t++)this.words[t]-=67108864,t===this.length-1?this.words[t+1]=1:this.words[t+1]++;return this.length=Math.max(this.length,t+1),this},i.prototype.isubn=function(e){if(r("number"==typeof e),0>e)return this.iaddn(-e);if(this.sign)return this.sign=!1,this.iaddn(e),this.sign=!0,this;this.words[0]-=e;for(var t=0;t<this.length&&this.words[t]<0;t++)this.words[t]+=67108864,this.words[t+1]-=1;return this.strip()},i.prototype.addn=function(e){return this.clone().iaddn(e)},i.prototype.subn=function(e){return this.clone().isubn(e)},i.prototype.iabs=function(){return this.sign=!1,this},i.prototype.abs=function(){return this.clone().iabs()},i.prototype._ishlnsubmul=function(e,t,n){var i,s=e.length+n;if(this.words.length<s){for(var o=new Array(s),i=0;i<this.length;i++)o[i]=this.words[i];this.words=o}else i=this.length;for(this.length=Math.max(this.length,s);i<this.length;i++)this.words[i]=0;for(var a=0,i=0;i<e.length;i++){var f=this.words[i+n]+a,c=e.words[i]*t;f-=67108863&c,a=(f>>26)-(c/67108864|0),this.words[i+n]=67108863&f}for(;i<this.length-n;i++){var f=this.words[i+n]+a;a=f>>26,this.words[i+n]=67108863&f}if(0===a)return this.strip();r(-1===a),a=0;for(var i=0;i<this.length;i++){var f=-this.words[i]+a;a=f>>26,this.words[i]=67108863&f}return this.sign=!0,this.strip()},i.prototype._wordDiv=function(e,t){var r=this.length-e.length,n=this.clone(),s=e,o=s.words[s.length-1],a=this._countBits(o);r=26-a,0!==r&&(s=s.shln(r),n.ishln(r),o=s.words[s.length-1]);var f,c=n.length-s.length;if("mod"!==t){f=new i(null),f.length=c+1,f.words=new Array(f.length);for(var u=0;u<f.length;u++)f.words[u]=0}var h=n.clone()._ishlnsubmul(s,1,c);h.sign||(n=h,f&&(f.words[c]=1));for(var d=c-1;d>=0;d--){var p=67108864*n.words[s.length+d]+n.words[s.length+d-1];for(p=Math.min(p/o|0,67108863),n._ishlnsubmul(s,p,d);n.sign;)p--,n.sign=!1,n._ishlnsubmul(s,1,d),0!==n.cmpn(0)&&(n.sign=!n.sign);f&&(f.words[d]=p)}return f&&f.strip(),n.strip(),"div"!==t&&0!==r&&n.ishrn(r),{div:f?f:null,mod:n}},i.prototype.divmod=function(e,t){if(r(0!==e.cmpn(0)),this.sign&&!e.sign){var n,s,o=this.neg().divmod(e,t);return"mod"!==t&&(n=o.div.neg()),"div"!==t&&(s=0===o.mod.cmpn(0)?o.mod:e.sub(o.mod)),{div:n,mod:s}}if(!this.sign&&e.sign){var n,o=this.divmod(e.neg(),t);return"mod"!==t&&(n=o.div.neg()),{div:n,mod:o.mod}}return this.sign&&e.sign?this.neg().divmod(e.neg(),t):e.length>this.length||this.cmp(e)<0?{div:new i(0),mod:this}:1===e.length?"div"===t?{div:this.divn(e.words[0]),mod:null}:"mod"===t?{div:null,mod:new i(this.modn(e.words[0]))}:{div:this.divn(e.words[0]),mod:new i(this.modn(e.words[0]))}:this._wordDiv(e,t)},i.prototype.div=function(e){return this.divmod(e,"div").div},i.prototype.mod=function(e){return this.divmod(e,"mod").mod},i.prototype.divRound=function(e){var t=this.divmod(e);if(0===t.mod.cmpn(0))return t.div;var r=t.div.sign?t.mod.isub(e):t.mod,n=e.shrn(1),i=e.andln(1),s=r.cmp(n);return 0>s||1===i&&0===s?t.div:t.div.sign?t.div.isubn(1):t.div.iaddn(1)},i.prototype.modn=function(e){r(67108863>=e);for(var t=(1<<26)%e,n=0,i=this.length-1;i>=0;i--)n=(t*n+this.words[i])%e;return n},i.prototype.idivn=function(e){r(67108863>=e);for(var t=0,n=this.length-1;n>=0;n--){var i=this.words[n]+67108864*t;this.words[n]=i/e|0,t=i%e}return this.strip()},i.prototype.divn=function(e){return this.clone().idivn(e)},i.prototype.egcd=function(e){r(!e.sign),r(0!==e.cmpn(0));var t=this,n=e.clone();t=t.sign?t.mod(e):t.clone();for(var s=new i(1),o=new i(0),a=new i(0),f=new i(1),c=0;t.isEven()&&n.isEven();)t.ishrn(1),n.ishrn(1),++c;for(var u=n.clone(),h=t.clone();0!==t.cmpn(0);){for(;t.isEven();)t.ishrn(1),s.isEven()&&o.isEven()?(s.ishrn(1),o.ishrn(1)):(s.iadd(u).ishrn(1),o.isub(h).ishrn(1));for(;n.isEven();)n.ishrn(1),a.isEven()&&f.isEven()?(a.ishrn(1),f.ishrn(1)):(a.iadd(u).ishrn(1),f.isub(h).ishrn(1));t.cmp(n)>=0?(t.isub(n),s.isub(a),o.isub(f)):(n.isub(t),a.isub(s),f.isub(o))}return{a:a,b:f,gcd:n.ishln(c)}},i.prototype._invmp=function(e){r(!e.sign),r(0!==e.cmpn(0));var t=this,n=e.clone();t=t.sign?t.mod(e):t.clone();for(var s=new i(1),o=new i(0),a=n.clone();t.cmpn(1)>0&&n.cmpn(1)>0;){for(;t.isEven();)t.ishrn(1),s.isEven()?s.ishrn(1):s.iadd(a).ishrn(1);for(;n.isEven();)n.ishrn(1),o.isEven()?o.ishrn(1):o.iadd(a).ishrn(1);t.cmp(n)>=0?(t.isub(n),s.isub(o)):(n.isub(t),o.isub(s))}return 0===t.cmpn(1)?s:o},i.prototype.gcd=function(e){if(0===this.cmpn(0))return e.clone();if(0===e.cmpn(0))return this.clone();var t=this.clone(),r=e.clone();t.sign=!1,r.sign=!1;for(var n=0;t.isEven()&&r.isEven();n++)t.ishrn(1),r.ishrn(1);for(;;){for(;t.isEven();)t.ishrn(1);for(;r.isEven();)r.ishrn(1);var i=t.cmp(r);if(0>i){var s=t;t=r,r=s}else if(0===i||0===r.cmpn(1))break;t.isub(r)}return r.ishln(n)},i.prototype.invm=function(e){return this.egcd(e).a.mod(e)},i.prototype.isEven=function(){return 0===(1&this.words[0])},i.prototype.isOdd=function(){return 1===(1&this.words[0])},i.prototype.andln=function(e){return this.words[0]&e},i.prototype.bincn=function(e){r("number"==typeof e);var t=e%26,n=(e-t)/26,i=1<<t;if(this.length<=n){for(var s=this.length;n+1>s;s++)this.words[s]=0;return this.words[n]|=i,this.length=n+1,this}for(var o=i,s=n;0!==o&&s<this.length;s++){var a=this.words[s];a+=o,o=a>>>26,a&=67108863,this.words[s]=a}return 0!==o&&(this.words[s]=o,this.length++),this},i.prototype.cmpn=function(e){var t=0>e;if(t&&(e=-e),this.sign&&!t)return-1;if(!this.sign&&t)return 1;e&=67108863,this.strip();var r;if(this.length>1)r=1;else{var n=this.words[0];r=n===e?0:e>n?-1:1}return this.sign&&(r=-r),r},i.prototype.cmp=function(e){if(this.sign&&!e.sign)return-1;if(!this.sign&&e.sign)return 1;var t=this.ucmp(e);return this.sign?-t:t},i.prototype.ucmp=function(e){if(this.length>e.length)return 1;if(this.length<e.length)return-1;for(var t=0,r=this.length-1;r>=0;r--){var n=this.words[r],i=e.words[r];if(n!==i){i>n?t=-1:n>i&&(t=1);break}}return t},i.red=function(e){return new d(e)},i.prototype.toRed=function(e){return r(!this.red,"Already a number in reduction context"),r(!this.sign,"red works only with positives"),e.convertTo(this)._forceRed(e)},i.prototype.fromRed=function(){return r(this.red,"fromRed works only with numbers in reduction context"),this.red.convertFrom(this)},i.prototype._forceRed=function(e){return this.red=e,this},i.prototype.forceRed=function(e){return r(!this.red,"Already a number in reduction context"),this._forceRed(e)},i.prototype.redAdd=function(e){return r(this.red,"redAdd works only with red numbers"),this.red.add(this,e)},i.prototype.redIAdd=function(e){return r(this.red,"redIAdd works only with red numbers"),this.red.iadd(this,e)},i.prototype.redSub=function(e){return r(this.red,"redSub works only with red numbers"),this.red.sub(this,e)},i.prototype.redISub=function(e){return r(this.red,"redISub works only with red numbers"),this.red.isub(this,e)},i.prototype.redShl=function(e){return r(this.red,"redShl works only with red numbers"),this.red.shl(this,e)},i.prototype.redMul=function(e){return r(this.red,"redMul works only with red numbers"),this.red._verify2(this,e),this.red.mul(this,e)},i.prototype.redIMul=function(e){return r(this.red,"redMul works only with red numbers"),this.red._verify2(this,e),this.red.imul(this,e)},i.prototype.redSqr=function(){return r(this.red,"redSqr works only with red numbers"),this.red._verify1(this),this.red.sqr(this)},i.prototype.redISqr=function(){return r(this.red,"redISqr works only with red numbers"),this.red._verify1(this),this.red.isqr(this)},i.prototype.redSqrt=function(){return r(this.red,"redSqrt works only with red numbers"),this.red._verify1(this),this.red.sqrt(this)},i.prototype.redInvm=function(){return r(this.red,"redInvm works only with red numbers"),this.red._verify1(this),this.red.invm(this)},i.prototype.redNeg=function(){return r(this.red,"redNeg works only with red numbers"),this.red._verify1(this),this.red.neg(this)},i.prototype.redPow=function(e){return r(this.red&&!e.red,"redPow(normalNum)"),this.red._verify1(this),this.red.pow(this,e)};var m={k256:null,p224:null,p192:null,p25519:null};a.prototype._tmp=function(){var e=new i(null);return e.words=new Array(Math.ceil(this.n/13)),e},a.prototype.ireduce=function(e){var t,r=e;do this.split(r,this.tmp),r=this.imulK(r),r=r.iadd(this.tmp),t=r.bitLength();while(t>this.n);var n=t<this.n?-1:r.ucmp(this.p);return 0===n?(r.words[0]=0,r.length=1):n>0?r.isub(this.p):r.strip(),r},a.prototype.split=function(e,t){e.ishrn(this.n,0,t)},a.prototype.imulK=function(e){return e.imul(this.k)},n(f,a),f.prototype.split=function(e,t){for(var r=4194303,n=Math.min(e.length,9),i=0;n>i;i++)t.words[i]=e.words[i];if(t.length=n,e.length<=9)return e.words[0]=0,void(e.length=1);var s=e.words[9];t.words[t.length++]=s&r;for(var i=10;i<e.length;i++){var o=e.words[i];e.words[i-10]=(o&r)<<4|s>>>22,s=o}e.words[i-10]=s>>>22,e.length-=9},f.prototype.imulK=function(e){e.words[e.length]=0,e.words[e.length+1]=0,e.length+=2;for(var t,r=0,n=0;n<e.length;n++){var i=e.words[n];t=64*i,r+=977*i,t+=r/67108864|0,r&=67108863,e.words[n]=r,r=t}return 0===e.words[e.length-1]&&(e.length--,0===e.words[e.length-1]&&e.length--),e},n(c,a),n(u,a),n(h,a),h.prototype.imulK=function(e){for(var t=0,r=0;r<e.length;r++){var n=19*e.words[r]+t,i=67108863&n;n>>>=26,e.words[r]=i,t=n}return 0!==t&&(e.words[e.length++]=t),e},i._prime=function y(e){if(m[e])return m[e];var y;if("k256"===e)y=new f;else if("p224"===e)y=new c;else if("p192"===e)y=new u;else{if("p25519"!==e)throw new Error("Unknown prime "+e);y=new h}return m[e]=y,y},d.prototype._verify1=function(e){r(!e.sign,"red works only with positives"),r(e.red,"red works only with red numbers")},d.prototype._verify2=function(e,t){r(!e.sign&&!t.sign,"red works only with positives"),r(e.red&&e.red===t.red,"red works only with red numbers")},d.prototype.imod=function(e){return this.prime?this.prime.ireduce(e)._forceRed(this):e.mod(this.m)._forceRed(this)},d.prototype.neg=function(e){var t=e.clone();return t.sign=!t.sign,t.iadd(this.m)._forceRed(this)},d.prototype.add=function(e,t){this._verify2(e,t);var r=e.add(t);return r.cmp(this.m)>=0&&r.isub(this.m),r._forceRed(this)},d.prototype.iadd=function(e,t){this._verify2(e,t);var r=e.iadd(t);return r.cmp(this.m)>=0&&r.isub(this.m),r},d.prototype.sub=function(e,t){this._verify2(e,t);var r=e.sub(t);return r.cmpn(0)<0&&r.iadd(this.m),r._forceRed(this)},d.prototype.isub=function(e,t){this._verify2(e,t);var r=e.isub(t);return r.cmpn(0)<0&&r.iadd(this.m),r},d.prototype.shl=function(e,t){return this._verify1(e),this.imod(e.shln(t))},d.prototype.imul=function(e,t){return this._verify2(e,t),this.imod(e.imul(t))},d.prototype.mul=function(e,t){return this._verify2(e,t),this.imod(e.mul(t))},d.prototype.isqr=function(e){return this.imul(e,e)},d.prototype.sqr=function(e){return this.mul(e,e)},d.prototype.sqrt=function(e){if(0===e.cmpn(0))return e.clone();var t=this.m.andln(3);if(r(t%2===1),3===t){var n=this.m.add(new i(1)).ishrn(2),s=this.pow(e,n);return s}for(var o=this.m.subn(1),a=0;0!==o.cmpn(0)&&0===o.andln(1);)a++,o.ishrn(1);r(0!==o.cmpn(0));var f=new i(1).toRed(this),c=f.redNeg(),u=this.m.subn(1).ishrn(1),h=this.m.bitLength();for(h=new i(2*h*h).toRed(this);0!==this.pow(h,u).cmp(c);)h.redIAdd(c);for(var d=this.pow(h,o),s=this.pow(e,o.addn(1).ishrn(1)),p=this.pow(e,o),l=a;0!==p.cmp(f);){for(var b=p,g=0;0!==b.cmp(f);g++)b=b.redSqr();r(l>g);var m=this.pow(d,new i(1).ishln(l-g-1));s=s.redMul(m),d=m.redSqr(),p=p.redMul(d),l=g}return s},d.prototype.invm=function(e){var t=e._invmp(this.m);return t.sign?(t.sign=!1,this.imod(t).redNeg()):this.imod(t)},d.prototype.pow=function(e,t){var r=[];if(0===t.cmpn(0))return new i(1);for(var n=t.clone();0!==n.cmpn(0);)r.push(n.andln(1)),n.ishrn(1);for(var s=e,o=0;o<r.length&&0===r[o];o++,s=this.sqr(s));if(++o<r.length)for(var n=this.sqr(s);o<r.length;o++,n=this.sqr(n))0!==r[o]&&(s=this.mul(s,n));return s},d.prototype.convertTo=function(e){return e.clone()},d.prototype.convertFrom=function(e){var t=e.clone();return t.red=null,t},i.mont=function(e){return new p(e)},n(p,d),p.prototype.convertTo=function(e){return this.imod(e.shln(this.shift))},p.prototype.convertFrom=function(e){var t=this.imod(e.mul(this.rinv));return t.red=null,t},p.prototype.imul=function(e,t){if(0===e.cmpn(0)||0===t.cmpn(0))return e.words[0]=0,e.length=1,e;var r=e.imul(t),n=r.maskn(this.shift).mul(this.minv).imaskn(this.shift).mul(this.m),i=r.isub(n).ishrn(this.shift),s=i;return i.cmp(this.m)>=0?s=i.isub(this.m):i.cmpn(0)<0&&(s=i.iadd(this.m)),s._forceRed(this)},p.prototype.mul=function(e,t){if(0===e.cmpn(0)||0===t.cmpn(0))return new i(0)._forceRed(this);var r=e.mul(t),n=r.maskn(this.shift).mul(this.minv).imaskn(this.shift).mul(this.m),s=r.isub(n).ishrn(this.shift),o=s;return s.cmp(this.m)>=0?o=s.isub(this.m):s.cmpn(0)<0&&(o=s.iadd(this.m)),o._forceRed(this)},p.prototype.invm=function(e){var t=this.imod(e._invmp(this.m).mul(this.r2));return t._forceRed(this)}}("undefined"==typeof t||t,this)},{}],171:[function(e,t,r){function n(e){if(0===e.length)return"";var t,r,n=[0];for(t=0;t<e.length;t++){for(r=0;r<n.length;r++)n[r]<<=8;n[0]+=e[t];var i=0;for(r=0;r<n.length;++r)n[r]+=i,i=n[r]/f|0,n[r]%=f;for(;i;)n.push(i%f),i=i/f|0}for(t=0;0===e[t]&&t<e.length-1;t++)n.push(0);return n.reverse().map(function(e){return s[e]}).join("")}function i(e){if(0===e.length)return[];var t,r,n=[0];for(t=0;t<e.length;t++){var i=e[t];if(!(i in o))throw new Error("Non-base58 character");for(r=0;r<n.length;r++)n[r]*=f;n[0]+=o[i];var s=0;for(r=0;r<n.length;++r)n[r]+=s,s=n[r]>>8,n[r]&=255;for(;s;)n.push(255&s),s>>=8}for(t=0;"1"===e[t]&&t<e.length-1;t++)n.push(0);return n.reverse()}for(var s="123456789ABCDEFGHJKLMNPQRSTUVWXYZabcdefghijkmnopqrstuvwxyz",o={},a=0;a<s.length;a++)o[s.charAt(a)]=a;var f=58;t.exports={encode:n,decode:i}},{}],172:[function(e,t,r){"use strict";var n=r;n.version=e("../package.json").version,n.utils=e("./elliptic/utils"),n.rand=e("brorand"),n.hmacDRBG=e("./elliptic/hmac-drbg"),n.curve=e("./elliptic/curve"),n.curves=e("./elliptic/curves"),n.ec=e("./elliptic/ec")},{"../package.json":186,"./elliptic/curve":175,"./elliptic/curves":178,"./elliptic/ec":179,"./elliptic/hmac-drbg":182,"./elliptic/utils":184,brorand:185}],173:[function(e,t,r){"use strict";function n(e,t){this.type=e,this.p=new s(t.p,16),this.red=t.prime?s.red(t.prime):s.mont(this.p),this.zero=new s(0).toRed(this.red),this.one=new s(1).toRed(this.red),this.two=new s(2).toRed(this.red),this.n=t.n&&new s(t.n,16),this.g=t.g&&this.pointFromJSON(t.g,t.gRed),this._wnafT1=new Array(4),this._wnafT2=new Array(4),this._wnafT3=new Array(4),this._wnafT4=new Array(4)}function i(e,t){this.curve=e,this.type=t,this.precomputed=null}var s=e("bn.js"),o=e("../../elliptic"),a=o.utils.getNAF,f=o.utils.getJSF,c=o.utils.assert;t.exports=n,n.prototype.point=function(){throw new Error("Not implemented")},n.prototype.validate=function(){throw new Error("Not implemented")},n.prototype._fixedNafMul=function(e,t){var r=e._getDoubles(),n=a(t,1),i=(1<<r.step+1)-(r.step%2===0?2:1);i/=3;for(var s=[],o=0;o<n.length;o+=r.step){for(var f=0,t=o+r.step-1;t>=o;t--)f=(f<<1)+n[t];s.push(f)}for(var c=this.jpoint(null,null,null),u=this.jpoint(null,null,null),h=i;h>0;h--){for(var o=0;o<s.length;o++){var f=s[o];f===h?u=u.mixedAdd(r.points[o]):f===-h&&(u=u.mixedAdd(r.points[o].neg()))}c=c.add(u)}return c.toP()},n.prototype._wnafMul=function(e,t){var r=4,n=e._getNAFPoints(r);r=n.wnd;for(var i=n.points,s=a(t,r),o=this.jpoint(null,null,null),f=s.length-1;f>=0;f--){for(var t=0;f>=0&&0===s[f];f--)t++;if(f>=0&&t++,o=o.dblp(t),0>f)break;var u=s[f];c(0!==u),o="affine"===e.type?o.mixedAdd(u>0?i[u-1>>1]:i[-u-1>>1].neg()):o.add(u>0?i[u-1>>1]:i[-u-1>>1].neg())}return"affine"===e.type?o.toP():o},n.prototype._wnafMulAdd=function(e,t,r,n){for(var i=this._wnafT1,s=this._wnafT2,o=this._wnafT3,c=0,u=0;n>u;u++){var h=t[u],d=h._getNAFPoints(e);i[u]=d.wnd,s[u]=d.points}for(var u=n-1;u>=1;u-=2){var p=u-1,l=u;if(1===i[p]&&1===i[l]){var b=[t[p],null,null,t[l]];0===t[p].y.cmp(t[l].y)?(b[1]=t[p].add(t[l]),b[2]=t[p].toJ().mixedAdd(t[l].neg())):0===t[p].y.cmp(t[l].y.redNeg())?(b[1]=t[p].toJ().mixedAdd(t[l]),b[2]=t[p].add(t[l].neg())):(b[1]=t[p].toJ().mixedAdd(t[l]),b[2]=t[p].toJ().mixedAdd(t[l].neg()));var g=[-3,-1,-5,-7,0,7,5,1,3],m=f(r[p],r[l]);c=Math.max(m[0].length,c),o[p]=new Array(c),o[l]=new Array(c);for(var y=0;c>y;y++){var v=0|m[0][y],_=0|m[1][y];o[p][y]=g[3*(v+1)+(_+1)],o[l][y]=0,s[p]=b}}else o[p]=a(r[p],i[p]),o[l]=a(r[l],i[l]),c=Math.max(o[p].length,c),c=Math.max(o[l].length,c)}for(var w=this.jpoint(null,null,null),S=this._wnafT4,u=c;u>=0;u--){for(var k=0;u>=0;){for(var E=!0,y=0;n>y;y++)S[y]=0|o[y][u],0!==S[y]&&(E=!1);if(!E)break;k++,u--}if(u>=0&&k++,w=w.dblp(k),0>u)break;for(var y=0;n>y;y++){var h,I=S[y];0!==I&&(I>0?h=s[y][I-1>>1]:0>I&&(h=s[y][-I-1>>1].neg()),w="affine"===h.type?w.mixedAdd(h):w.add(h))}}for(var u=0;n>u;u++)s[u]=null;return w.toP()},n.BasePoint=i,i.prototype.validate=function(){return this.curve.validate(this)},i.prototype.precompute=function(e){if(this.precomputed)return this;var t={doubles:null,naf:null,beta:null};return t.naf=this._getNAFPoints(8),t.doubles=this._getDoubles(4,e),t.beta=this._getBeta(),this.precomputed=t,this},i.prototype._getDoubles=function(e,t){if(this.precomputed&&this.precomputed.doubles)return this.precomputed.doubles;for(var r=[this],n=this,i=0;t>i;i+=e){for(var s=0;e>s;s++)n=n.dbl();r.push(n)}return{step:e,points:r}},i.prototype._getNAFPoints=function(e){if(this.precomputed&&this.precomputed.naf)return this.precomputed.naf;for(var t=[this],r=(1<<e)-1,n=1===r?null:this.dbl(),i=1;r>i;i++)t[i]=t[i-1].add(n);return{wnd:e,points:t}},i.prototype._getBeta=function(){return null},i.prototype.dblp=function(e){for(var t=this,r=0;e>r;r++)t=t.dbl();return t}},{"../../elliptic":172,"bn.js":170}],174:[function(e,t,r){"use strict";function n(e){this.twisted=1!==(0|e.a),this.mOneA=this.twisted&&-1===(0|e.a),this.extended=this.mOneA,c.call(this,"edwards",e),this.a=new a(e.a,16).mod(this.red.m).toRed(this.red),this.c=new a(e.c,16).toRed(this.red),this.c2=this.c.redSqr(),this.d=new a(e.d,16).toRed(this.red),this.dd=this.d.redAdd(this.d),u(!this.twisted||0===this.c.fromRed().cmpn(1)),this.oneC=1===(0|e.c)}function i(e,t,r,n,i){c.BasePoint.call(this,e,"projective"),null===t&&null===r&&null===n?(this.x=this.curve.zero,this.y=this.curve.one,this.z=this.curve.one,this.t=this.curve.zero,this.zOne=!0):(this.x=new a(t,16),this.y=new a(r,16),this.z=n?new a(n,16):this.curve.one,this.t=i&&new a(i,16),this.x.red||(this.x=this.x.toRed(this.curve.red)),this.y.red||(this.y=this.y.toRed(this.curve.red)),this.z.red||(this.z=this.z.toRed(this.curve.red)),this.t&&!this.t.red&&(this.t=this.t.toRed(this.curve.red)),this.zOne=this.z===this.curve.one,this.curve.extended&&!this.t&&(this.t=this.x.redMul(this.y),this.zOne||(this.t=this.t.redMul(this.z.redInvm()))))}var s=e("../curve"),o=e("../../elliptic"),a=e("bn.js"),f=e("inherits"),c=s.base,u=o.utils.assert;f(n,c),t.exports=n,n.prototype._mulA=function(e){return this.mOneA?e.redNeg():this.a.redMul(e)},n.prototype._mulC=function(e){return this.oneC?e:this.c.redMul(e)},n.prototype.jpoint=function(e,t,r,n){return this.point(e,t,r,n)},n.prototype.pointFromX=function(e,t){t=new a(t,16),t.red||(t=t.toRed(this.red));var r=t.redSqr(),n=this.c2.redSub(this.a.redMul(r)),i=this.one.redSub(this.c2.redMul(this.d).redMul(r)),o=n.redMul(i.redInvm()).redSqrt(),f=o.fromRed().isOdd();return(e&&!f||!e&&f)&&(o=o.redNeg()),this.point(t,o,s.one)},n.prototype.validate=function(e){if(e.isInfinity())return!0;e.normalize();var t=e.x.redSqr(),r=e.y.redSqr(),n=t.redMul(this.a).redAdd(r),i=this.c2.redMul(this.one.redAdd(this.d.redMul(t).redMul(r)));return 0===n.cmp(i)},f(i,c.BasePoint),n.prototype.pointFromJSON=function(e){return i.fromJSON(this,e)},n.prototype.point=function(e,t,r,n){return new i(this,e,t,r,n)},i.fromJSON=function(e,t){return new i(e,t[0],t[1],t[2])},i.prototype.inspect=function(){return this.isInfinity()?"<EC Point Infinity>":"<EC Point x: "+this.x.fromRed().toString(16,2)+" y: "+this.y.fromRed().toString(16,2)+" z: "+this.z.fromRed().toString(16,2)+">"},i.prototype.isInfinity=function(){return 0===this.x.cmpn(0)&&0===this.y.cmp(this.z)},i.prototype._extDbl=function(){var e=this.x.redSqr(),t=this.y.redSqr(),r=this.z.redSqr();r=r.redIAdd(r);var n=this.curve._mulA(e),i=this.x.redAdd(this.y).redSqr().redISub(e).redISub(t),s=n.redAdd(t),o=s.redSub(r),a=n.redSub(t),f=i.redMul(o),c=s.redMul(a),u=i.redMul(a),h=o.redMul(s);return this.curve.point(f,c,h,u)},i.prototype._projDbl=function(){var e,t,r,n=this.x.redAdd(this.y).redSqr(),i=this.x.redSqr(),s=this.y.redSqr();if(this.curve.twisted){var o=this.curve._mulA(i),a=o.redAdd(s);if(this.zOne)e=n.redSub(i).redSub(s).redMul(a.redSub(this.curve.two)),t=a.redMul(o.redSub(s)),r=a.redSqr().redSub(a).redSub(a);else{var f=this.z.redSqr(),c=a.redSub(f).redISub(f);e=n.redSub(i).redISub(s).redMul(c),t=a.redMul(o.redSub(s)),r=a.redMul(c)}}else{var o=i.redAdd(s),f=this.curve._mulC(this.c.redMul(this.z)).redSqr(),c=o.redSub(f).redSub(f);e=this.curve._mulC(n.redISub(o)).redMul(c),t=this.curve._mulC(o).redMul(i.redISub(s)),r=o.redMul(c)}return this.curve.point(e,t,r)},i.prototype.dbl=function(){return this.isInfinity()?this:this.curve.extended?this._extDbl():this._projDbl()},i.prototype._extAdd=function(e){var t=this.y.redSub(this.x).redMul(e.y.redSub(e.x)),r=this.y.redAdd(this.x).redMul(e.y.redAdd(e.x)),n=this.t.redMul(this.curve.dd).redMul(e.t),i=this.z.redMul(e.z.redAdd(e.z)),s=r.redSub(t),o=i.redSub(n),a=i.redAdd(n),f=r.redAdd(t),c=s.redMul(o),u=a.redMul(f),h=s.redMul(f),d=o.redMul(a);return this.curve.point(c,u,d,h)},i.prototype._projAdd=function(e){var t,r,n=this.z.redMul(e.z),i=n.redSqr(),s=this.x.redMul(e.x),o=this.y.redMul(e.y),a=this.curve.d.redMul(s).redMul(o),f=i.redSub(a),c=i.redAdd(a),u=this.x.redAdd(this.y).redMul(e.x.redAdd(e.y)).redISub(s).redISub(o),h=n.redMul(f).redMul(u);return this.curve.twisted?(t=n.redMul(c).redMul(o.redSub(this.curve._mulA(s))),r=f.redMul(c)):(t=n.redMul(c).redMul(o.redSub(s)),r=this.curve._mulC(f).redMul(c)),this.curve.point(h,t,r)},i.prototype.add=function(e){return this.isInfinity()?e:e.isInfinity()?this:this.curve.extended?this._extAdd(e):this._projAdd(e)},i.prototype.mul=function(e){return this.precomputed&&this.precomputed.doubles?this.curve._fixedNafMul(this,e):this.curve._wnafMul(this,e)},i.prototype.mulAdd=function(e,t,r){return this.curve._wnafMulAdd(1,[this,t],[e,r],2)},i.prototype.normalize=function(){if(this.zOne)return this;var e=this.z.redInvm();return this.x=this.x.redMul(e),this.y=this.y.redMul(e),this.t&&(this.t=this.t.redMul(e)),this.z=this.curve.one,this.zOne=!0,this},i.prototype.neg=function(){return this.curve.point(this.x.redNeg(),this.y,this.z,this.t&&this.t.redNeg())},i.prototype.getX=function(){return this.normalize(),this.x.fromRed()},i.prototype.getY=function(){return this.normalize(),this.y.fromRed()},i.prototype.toP=i.prototype.normalize,i.prototype.mixedAdd=i.prototype.add},{"../../elliptic":172,"../curve":175,"bn.js":170,inherits:193}],175:[function(e,t,r){"use strict";var n=r;n.base=e("./base"),n["short"]=e("./short"),n.mont=e("./mont"),n.edwards=e("./edwards")},{"./base":173,"./edwards":174,"./mont":176,"./short":177}],176:[function(e,t,r){"use strict";function n(e){f.call(this,"mont",e),this.a=new o(e.a,16).toRed(this.red),this.b=new o(e.b,16).toRed(this.red),this.i4=new o(4).toRed(this.red).redInvm(),this.two=new o(2).toRed(this.red),this.a24=this.i4.redMul(this.a.redAdd(this.two))}function i(e,t,r){f.BasePoint.call(this,e,"projective"),null===t&&null===r?(this.x=this.curve.one,this.z=this.curve.zero):(this.x=new o(t,16),this.z=new o(r,16),this.x.red||(this.x=this.x.toRed(this.curve.red)),this.z.red||(this.z=this.z.toRed(this.curve.red)))}var s=e("../curve"),o=e("bn.js"),a=e("inherits"),f=s.base;a(n,f),t.exports=n,n.prototype.validate=function(e){var t=e.normalize().x,r=t.redSqr(),n=r.redMul(t).redAdd(r.redMul(this.a)).redAdd(t),i=n.redSqrt();return 0===i.redSqr().cmp(n)},a(i,f.BasePoint),n.prototype.point=function(e,t){return new i(this,e,t)},n.prototype.pointFromJSON=function(e){return i.fromJSON(this,e)},i.prototype.precompute=function(){},i.fromJSON=function(e,t){return new i(e,t[0],t[1]||e.one)},i.prototype.inspect=function(){return this.isInfinity()?"<EC Point Infinity>":"<EC Point x: "+this.x.fromRed().toString(16,2)+" z: "+this.z.fromRed().toString(16,2)+">"},i.prototype.isInfinity=function(){return 0===this.z.cmpn(0)},i.prototype.dbl=function(){var e=this.x.redAdd(this.z),t=e.redSqr(),r=this.x.redSub(this.z),n=r.redSqr(),i=t.redSub(n),s=t.redMul(n),o=i.redMul(n.redAdd(this.curve.a24.redMul(i)));return this.curve.point(s,o)},i.prototype.add=function(){throw new Error("Not supported on Montgomery curve")},i.prototype.diffAdd=function(e,t){var r=this.x.redAdd(this.z),n=this.x.redSub(this.z),i=e.x.redAdd(e.z),s=e.x.redSub(e.z),o=s.redMul(r),a=i.redMul(n),f=t.z.redMul(o.redAdd(a).redSqr()),c=t.x.redMul(o.redISub(a).redSqr());return this.curve.point(f,c)},i.prototype.mul=function(e){for(var t=e.clone(),r=this,n=this.curve.point(null,null),i=this,s=[];0!==t.cmpn(0);t.ishrn(1))s.push(t.andln(1));
for(var o=s.length-1;o>=0;o--)0===s[o]?(r=r.diffAdd(n,i),n=n.dbl()):(n=r.diffAdd(n,i),r=r.dbl());return n},i.prototype.mulAdd=function(){throw new Error("Not supported on Montgomery curve")},i.prototype.normalize=function(){return this.x=this.x.redMul(this.z.redInvm()),this.z=this.curve.one,this},i.prototype.getX=function(){return this.normalize(),this.x.fromRed()}},{"../curve":175,"bn.js":170,inherits:193}],177:[function(e,t,r){"use strict";function n(e){u.call(this,"short",e),this.a=new f(e.a,16).toRed(this.red),this.b=new f(e.b,16).toRed(this.red),this.tinv=this.two.redInvm(),this.zeroA=0===this.a.fromRed().cmpn(0),this.threeA=0===this.a.fromRed().sub(this.p).cmpn(-3),this.endo=this._getEndomorphism(e),this._endoWnafT1=new Array(4),this._endoWnafT2=new Array(4)}function i(e,t,r,n){u.BasePoint.call(this,e,"affine"),null===t&&null===r?(this.x=null,this.y=null,this.inf=!0):(this.x=new f(t,16),this.y=new f(r,16),n&&(this.x.forceRed(this.curve.red),this.y.forceRed(this.curve.red)),this.x.red||(this.x=this.x.toRed(this.curve.red)),this.y.red||(this.y=this.y.toRed(this.curve.red)),this.inf=!1)}function s(e,t,r,n){u.BasePoint.call(this,e,"jacobian"),null===t&&null===r&&null===n?(this.x=this.curve.one,this.y=this.curve.one,this.z=new f(0)):(this.x=new f(t,16),this.y=new f(r,16),this.z=new f(n,16)),this.x.red||(this.x=this.x.toRed(this.curve.red)),this.y.red||(this.y=this.y.toRed(this.curve.red)),this.z.red||(this.z=this.z.toRed(this.curve.red)),this.zOne=this.z===this.curve.one}var o=e("../curve"),a=e("../../elliptic"),f=e("bn.js"),c=e("inherits"),u=o.base,h=a.utils.assert;c(n,u),t.exports=n,n.prototype._getEndomorphism=function(e){if(this.zeroA&&this.g&&this.n&&1===this.p.modn(3)){var t,r;if(e.beta)t=new f(e.beta,16).toRed(this.red);else{var n=this._getEndoRoots(this.p);t=n[0].cmp(n[1])<0?n[0]:n[1],t=t.toRed(this.red)}if(e.lambda)r=new f(e.lambda,16);else{var i=this._getEndoRoots(this.n);0===this.g.mul(i[0]).x.cmp(this.g.x.redMul(t))?r=i[0]:(r=i[1],h(0===this.g.mul(r).x.cmp(this.g.x.redMul(t))))}var s;return s=e.basis?e.basis.map(function(e){return{a:new f(e.a,16),b:new f(e.b,16)}}):this._getEndoBasis(r),{beta:t,lambda:r,basis:s}}},n.prototype._getEndoRoots=function(e){var t=e===this.p?this.red:f.mont(e),r=new f(2).toRed(t).redInvm(),n=r.redNeg(),i=new f(3).toRed(t).redNeg().redSqrt().redMul(r),s=n.redAdd(i).fromRed(),o=n.redSub(i).fromRed();return[s,o]},n.prototype._getEndoBasis=function(e){for(var t,r,n,i,s,o,a,c,u,h=this.n.shrn(Math.floor(this.n.bitLength()/2)),d=e,p=this.n.clone(),l=new f(1),b=new f(0),g=new f(0),m=new f(1),y=0;0!==d.cmpn(0);){var v=p.div(d);c=p.sub(v.mul(d)),u=g.sub(v.mul(l));var _=m.sub(v.mul(b));if(!n&&c.cmp(h)<0)t=a.neg(),r=l,n=c.neg(),i=u;else if(n&&2===++y)break;a=c,p=d,d=c,g=l,l=u,m=b,b=_}s=c.neg(),o=u;var w=n.sqr().add(i.sqr()),S=s.sqr().add(o.sqr());return S.cmp(w)>=0&&(s=t,o=r),n.sign&&(n=n.neg(),i=i.neg()),s.sign&&(s=s.neg(),o=o.neg()),[{a:n,b:i},{a:s,b:o}]},n.prototype._endoSplit=function(e){var t=this.endo.basis,r=t[0],n=t[1],i=n.b.mul(e).divRound(this.n),s=r.b.neg().mul(e).divRound(this.n),o=i.mul(r.a),a=s.mul(n.a),f=i.mul(r.b),c=s.mul(n.b),u=e.sub(o).sub(a),h=f.add(c).neg();return{k1:u,k2:h}},n.prototype.pointFromX=function(e,t){t=new f(t,16),t.red||(t=t.toRed(this.red));var r=t.redSqr().redMul(t).redIAdd(t.redMul(this.a)).redIAdd(this.b),n=r.redSqrt(),i=n.fromRed().isOdd();return(e&&!i||!e&&i)&&(n=n.redNeg()),this.point(t,n)},n.prototype.validate=function(e){if(e.inf)return!0;var t=e.x,r=e.y,n=this.a.redMul(t),i=t.redSqr().redMul(t).redIAdd(n).redIAdd(this.b);return 0===r.redSqr().redISub(i).cmpn(0)},n.prototype._endoWnafMulAdd=function(e,t){for(var r=this._endoWnafT1,n=this._endoWnafT2,i=0;i<e.length;i++){var s=this._endoSplit(t[i]),o=e[i],a=o._getBeta();s.k1.sign&&(s.k1.sign=!s.k1.sign,o=o.neg(!0)),s.k2.sign&&(s.k2.sign=!s.k2.sign,a=a.neg(!0)),r[2*i]=o,r[2*i+1]=a,n[2*i]=s.k1,n[2*i+1]=s.k2}for(var f=this._wnafMulAdd(1,r,n,2*i),c=0;2*i>c;c++)r[c]=null,n[c]=null;return f},c(i,u.BasePoint),n.prototype.point=function(e,t,r){return new i(this,e,t,r)},n.prototype.pointFromJSON=function(e,t){return i.fromJSON(this,e,t)},i.prototype._getBeta=function(){if(this.curve.endo){var e=this.precomputed;if(e&&e.beta)return e.beta;var t=this.curve.point(this.x.redMul(this.curve.endo.beta),this.y);if(e){var r=this.curve,n=function(e){return r.point(e.x.redMul(r.endo.beta),e.y)};e.beta=t,t.precomputed={beta:null,naf:e.naf&&{wnd:e.naf.wnd,points:e.naf.points.map(n)},doubles:e.doubles&&{step:e.doubles.step,points:e.doubles.points.map(n)}}}return t}},i.prototype.toJSON=function(){return this.precomputed?[this.x,this.y,this.precomputed&&{doubles:this.precomputed.doubles&&{step:this.precomputed.doubles.step,points:this.precomputed.doubles.points.slice(1)},naf:this.precomputed.naf&&{wnd:this.precomputed.naf.wnd,points:this.precomputed.naf.points.slice(1)}}]:[this.x,this.y]},i.fromJSON=function(e,t,r){function n(t){return e.point(t[0],t[1],r)}"string"==typeof t&&(t=JSON.parse(t));var i=e.point(t[0],t[1],r);if(!t[2])return i;var s=t[2];return i.precomputed={beta:null,doubles:s.doubles&&{step:s.doubles.step,points:[i].concat(s.doubles.points.map(n))},naf:s.naf&&{wnd:s.naf.wnd,points:[i].concat(s.naf.points.map(n))}},i},i.prototype.inspect=function(){return this.isInfinity()?"<EC Point Infinity>":"<EC Point x: "+this.x.fromRed().toString(16,2)+" y: "+this.y.fromRed().toString(16,2)+">"},i.prototype.isInfinity=function(){return this.inf},i.prototype.add=function(e){if(this.inf)return e;if(e.inf)return this;if(this.eq(e))return this.dbl();if(this.neg().eq(e))return this.curve.point(null,null);if(0===this.x.cmp(e.x))return this.curve.point(null,null);var t=this.y.redSub(e.y);0!==t.cmpn(0)&&(t=t.redMul(this.x.redSub(e.x).redInvm()));var r=t.redSqr().redISub(this.x).redISub(e.x),n=t.redMul(this.x.redSub(r)).redISub(this.y);return this.curve.point(r,n)},i.prototype.dbl=function(){if(this.inf)return this;var e=this.y.redAdd(this.y);if(0===e.cmpn(0))return this.curve.point(null,null);var t=this.curve.a,r=this.x.redSqr(),n=e.redInvm(),i=r.redAdd(r).redIAdd(r).redIAdd(t).redMul(n),s=i.redSqr().redISub(this.x.redAdd(this.x)),o=i.redMul(this.x.redSub(s)).redISub(this.y);return this.curve.point(s,o)},i.prototype.getX=function(){return this.x.fromRed()},i.prototype.getY=function(){return this.y.fromRed()},i.prototype.mul=function(e){return e=new f(e,16),this.precomputed&&this.precomputed.doubles?this.curve._fixedNafMul(this,e):this.curve.endo?this.curve._endoWnafMulAdd([this],[e]):this.curve._wnafMul(this,e)},i.prototype.mulAdd=function(e,t,r){var n=[this,t],i=[e,r];return this.curve.endo?this.curve._endoWnafMulAdd(n,i):this.curve._wnafMulAdd(1,n,i,2)},i.prototype.eq=function(e){return this===e||this.inf===e.inf&&(this.inf||0===this.x.cmp(e.x)&&0===this.y.cmp(e.y))},i.prototype.neg=function(e){if(this.inf)return this;var t=this.curve.point(this.x,this.y.redNeg());if(e&&this.precomputed){var r=this.precomputed,n=function(e){return e.neg()};t.precomputed={naf:r.naf&&{wnd:r.naf.wnd,points:r.naf.points.map(n)},doubles:r.doubles&&{step:r.doubles.step,points:r.doubles.points.map(n)}}}return t},i.prototype.toJ=function(){if(this.inf)return this.curve.jpoint(null,null,null);var e=this.curve.jpoint(this.x,this.y,this.curve.one);return e},c(s,u.BasePoint),n.prototype.jpoint=function(e,t,r){return new s(this,e,t,r)},s.prototype.toP=function(){if(this.isInfinity())return this.curve.point(null,null);var e=this.z.redInvm(),t=e.redSqr(),r=this.x.redMul(t),n=this.y.redMul(t).redMul(e);return this.curve.point(r,n)},s.prototype.neg=function(){return this.curve.jpoint(this.x,this.y.redNeg(),this.z)},s.prototype.add=function(e){if(this.isInfinity())return e;if(e.isInfinity())return this;var t=e.z.redSqr(),r=this.z.redSqr(),n=this.x.redMul(t),i=e.x.redMul(r),s=this.y.redMul(t.redMul(e.z)),o=e.y.redMul(r.redMul(this.z)),a=n.redSub(i),f=s.redSub(o);if(0===a.cmpn(0))return 0!==f.cmpn(0)?this.curve.jpoint(null,null,null):this.dbl();var c=a.redSqr(),u=c.redMul(a),h=n.redMul(c),d=f.redSqr().redIAdd(u).redISub(h).redISub(h),p=f.redMul(h.redISub(d)).redISub(s.redMul(u)),l=this.z.redMul(e.z).redMul(a);return this.curve.jpoint(d,p,l)},s.prototype.mixedAdd=function(e){if(this.isInfinity())return e.toJ();if(e.isInfinity())return this;var t=this.z.redSqr(),r=this.x,n=e.x.redMul(t),i=this.y,s=e.y.redMul(t).redMul(this.z),o=r.redSub(n),a=i.redSub(s);if(0===o.cmpn(0))return 0!==a.cmpn(0)?this.curve.jpoint(null,null,null):this.dbl();var f=o.redSqr(),c=f.redMul(o),u=r.redMul(f),h=a.redSqr().redIAdd(c).redISub(u).redISub(u),d=a.redMul(u.redISub(h)).redISub(i.redMul(c)),p=this.z.redMul(o);return this.curve.jpoint(h,d,p)},s.prototype.dblp=function(e){if(0===e)return this;if(this.isInfinity())return this;if(!e)return this.dbl();if(this.curve.zeroA||this.curve.threeA){for(var t=this,r=0;e>r;r++)t=t.dbl();return t}for(var n=this.curve.a,i=this.curve.tinv,s=this.x,o=this.y,a=this.z,f=a.redSqr().redSqr(),c=o.redAdd(o),r=0;e>r;r++){var u=s.redSqr(),h=c.redSqr(),d=h.redSqr(),p=u.redAdd(u).redIAdd(u).redIAdd(n.redMul(f)),l=s.redMul(h),b=p.redSqr().redISub(l.redAdd(l)),g=l.redISub(b),m=p.redMul(g);m=m.redIAdd(m).redISub(d);var y=c.redMul(a);e>r+1&&(f=f.redMul(d)),s=b,a=y,c=m}return this.curve.jpoint(s,c.redMul(i),a)},s.prototype.dbl=function(){return this.isInfinity()?this:this.curve.zeroA?this._zeroDbl():this.curve.threeA?this._threeDbl():this._dbl()},s.prototype._zeroDbl=function(){var e,t,r;if(this.zOne){var n=this.x.redSqr(),i=this.y.redSqr(),s=i.redSqr(),o=this.x.redAdd(i).redSqr().redISub(n).redISub(s);o=o.redIAdd(o);var a=n.redAdd(n).redIAdd(n),f=a.redSqr().redISub(o).redISub(o),c=s.redIAdd(s);c=c.redIAdd(c),c=c.redIAdd(c),e=f,t=a.redMul(o.redISub(f)).redISub(c),r=this.y.redAdd(this.y)}else{var u=this.x.redSqr(),h=this.y.redSqr(),d=h.redSqr(),p=this.x.redAdd(h).redSqr().redISub(u).redISub(d);p=p.redIAdd(p);var l=u.redAdd(u).redIAdd(u),b=l.redSqr(),g=d.redIAdd(d);g=g.redIAdd(g),g=g.redIAdd(g),e=b.redISub(p).redISub(p),t=l.redMul(p.redISub(e)).redISub(g),r=this.y.redMul(this.z),r=r.redIAdd(r)}return this.curve.jpoint(e,t,r)},s.prototype._threeDbl=function(){var e,t,r;if(this.zOne){var n=this.x.redSqr(),i=this.y.redSqr(),s=i.redSqr(),o=this.x.redAdd(i).redSqr().redISub(n).redISub(s);o=o.redIAdd(o);var a=n.redAdd(n).redIAdd(n).redIAdd(this.curve.a),f=a.redSqr().redISub(o).redISub(o);e=f;var c=s.redIAdd(s);c=c.redIAdd(c),c=c.redIAdd(c),t=a.redMul(o.redISub(f)).redISub(c),r=this.y.redAdd(this.y)}else{var u=this.z.redSqr(),h=this.y.redSqr(),d=this.x.redMul(h),p=this.x.redSub(u).redMul(this.x.redAdd(u));p=p.redAdd(p).redIAdd(p);var l=d.redIAdd(d);l=l.redIAdd(l);var b=l.redAdd(l);e=p.redSqr().redISub(b),r=this.y.redAdd(this.z).redSqr().redISub(h).redISub(u);var g=h.redSqr();g=g.redIAdd(g),g=g.redIAdd(g),g=g.redIAdd(g),t=p.redMul(l.redISub(e)).redISub(g)}return this.curve.jpoint(e,t,r)},s.prototype._dbl=function(){var e=this.curve.a,t=this.x,r=this.y,n=this.z,i=n.redSqr().redSqr(),s=t.redSqr(),o=r.redSqr(),a=s.redAdd(s).redIAdd(s).redIAdd(e.redMul(i)),f=t.redAdd(t);f=f.redIAdd(f);var c=f.redMul(o),u=a.redSqr().redISub(c.redAdd(c)),h=c.redISub(u),d=o.redSqr();d=d.redIAdd(d),d=d.redIAdd(d),d=d.redIAdd(d);var p=a.redMul(h).redISub(d),l=r.redAdd(r).redMul(n);return this.curve.jpoint(u,p,l)},s.prototype.trpl=function(){if(!this.curve.zeroA)return this.dbl().add(this);var e=this.x.redSqr(),t=this.y.redSqr(),r=this.z.redSqr(),n=t.redSqr(),i=e.redAdd(e).redIAdd(e),s=i.redSqr(),o=this.x.redAdd(t).redSqr().redISub(e).redISub(n);o=o.redIAdd(o),o=o.redAdd(o).redIAdd(o),o=o.redISub(s);var a=o.redSqr(),f=n.redIAdd(n);f=f.redIAdd(f),f=f.redIAdd(f),f=f.redIAdd(f);var c=i.redIAdd(o).redSqr().redISub(s).redISub(a).redISub(f),u=t.redMul(c);u=u.redIAdd(u),u=u.redIAdd(u);var h=this.x.redMul(a).redISub(u);h=h.redIAdd(h),h=h.redIAdd(h);var d=this.y.redMul(c.redMul(f.redISub(c)).redISub(o.redMul(a)));d=d.redIAdd(d),d=d.redIAdd(d),d=d.redIAdd(d);var p=this.z.redAdd(o).redSqr().redISub(r).redISub(a);return this.curve.jpoint(h,d,p)},s.prototype.mul=function(e,t){return e=new f(e,t),this.curve._wnafMul(this,e)},s.prototype.eq=function(e){if("affine"===e.type)return this.eq(e.toJ());if(this===e)return!0;var t=this.z.redSqr(),r=e.z.redSqr();if(0!==this.x.redMul(r).redISub(e.x.redMul(t)).cmpn(0))return!1;var n=t.redMul(this.z),i=r.redMul(e.z);return 0===this.y.redMul(i).redISub(e.y.redMul(n)).cmpn(0)},s.prototype.inspect=function(){return this.isInfinity()?"<EC JPoint Infinity>":"<EC JPoint x: "+this.x.toString(16,2)+" y: "+this.y.toString(16,2)+" z: "+this.z.toString(16,2)+">"},s.prototype.isInfinity=function(){return 0===this.z.cmpn(0)}},{"../../elliptic":172,"../curve":175,"bn.js":170,inherits:193}],178:[function(e,t,r){"use strict";function n(e){this.curve="short"===e.type?new a.curve["short"](e):"edwards"===e.type?new a.curve.edwards(e):new a.curve.mont(e),this.g=this.curve.g,this.n=this.curve.n,this.hash=e.hash,f(this.g.validate(),"Invalid curve"),f(this.g.mul(this.n).isInfinity(),"Invalid curve, G*N != O")}function i(e,t){Object.defineProperty(s,e,{configurable:!0,enumerable:!0,get:function(){var r=new n(t);return Object.defineProperty(s,e,{configurable:!0,enumerable:!0,value:r}),r}})}var s=r,o=e("hash.js"),a=e("../elliptic"),f=a.utils.assert;s.PresetCurve=n,i("p192",{type:"short",prime:"p192",p:"ffffffff ffffffff ffffffff fffffffe ffffffff ffffffff",a:"ffffffff ffffffff ffffffff fffffffe ffffffff fffffffc",b:"64210519 e59c80e7 0fa7e9ab 72243049 feb8deec c146b9b1",n:"ffffffff ffffffff ffffffff 99def836 146bc9b1 b4d22831",hash:o.sha256,gRed:!1,g:["188da80e b03090f6 7cbf20eb 43a18800 f4ff0afd 82ff1012","07192b95 ffc8da78 631011ed 6b24cdd5 73f977a1 1e794811"]}),i("p224",{type:"short",prime:"p224",p:"ffffffff ffffffff ffffffff ffffffff 00000000 00000000 00000001",a:"ffffffff ffffffff ffffffff fffffffe ffffffff ffffffff fffffffe",b:"b4050a85 0c04b3ab f5413256 5044b0b7 d7bfd8ba 270b3943 2355ffb4",n:"ffffffff ffffffff ffffffff ffff16a2 e0b8f03e 13dd2945 5c5c2a3d",hash:o.sha256,gRed:!1,g:["b70e0cbd 6bb4bf7f 321390b9 4a03c1d3 56c21122 343280d6 115c1d21","bd376388 b5f723fb 4c22dfe6 cd4375a0 5a074764 44d58199 85007e34"]}),i("p256",{type:"short",prime:null,p:"ffffffff 00000001 00000000 00000000 00000000 ffffffff ffffffff ffffffff",a:"ffffffff 00000001 00000000 00000000 00000000 ffffffff ffffffff fffffffc",b:"5ac635d8 aa3a93e7 b3ebbd55 769886bc 651d06b0 cc53b0f6 3bce3c3e 27d2604b",n:"ffffffff 00000000 ffffffff ffffffff bce6faad a7179e84 f3b9cac2 fc632551",hash:o.sha256,gRed:!1,g:["6b17d1f2 e12c4247 f8bce6e5 63a440f2 77037d81 2deb33a0 f4a13945 d898c296","4fe342e2 fe1a7f9b 8ee7eb4a 7c0f9e16 2bce3357 6b315ece cbb64068 37bf51f5"]}),i("curve25519",{type:"mont",prime:"p25519",p:"7fffffffffffffff ffffffffffffffff ffffffffffffffff ffffffffffffffed",a:"76d06",b:"0",n:"1000000000000000 0000000000000000 14def9dea2f79cd6 5812631a5cf5d3ed",hash:o.sha256,gRed:!1,g:["9"]}),i("ed25519",{type:"edwards",prime:"p25519",p:"7fffffffffffffff ffffffffffffffff ffffffffffffffff ffffffffffffffed",a:"-1",c:"1",d:"52036cee2b6ffe73 8cc740797779e898 00700a4d4141d8ab 75eb4dca135978a3",n:"1000000000000000 0000000000000000 14def9dea2f79cd6 5812631a5cf5d3ed",hash:o.sha256,gRed:!1,g:["216936d3cd6e53fec0a4e231fdd6dc5c692cc7609525a7b2c9562d608f25d51a","6666666666666666666666666666666666666666666666666666666666666658"]});var c;try{c=e("./precomputed/secp256k1")}catch(u){c=void 0}i("secp256k1",{type:"short",prime:"k256",p:"ffffffff ffffffff ffffffff ffffffff ffffffff ffffffff fffffffe fffffc2f",a:"0",b:"7",n:"ffffffff ffffffff ffffffff fffffffe baaedce6 af48a03b bfd25e8c d0364141",h:"1",hash:o.sha256,beta:"7ae96a2b657c07106e64479eac3434e99cf0497512f58995c1396c28719501ee",lambda:"5363ad4cc05c30e0a5261c028812645a122e22ea20816678df02967c1b23bd72",basis:[{a:"3086d221a7d46bcde86c90e49284eb15",b:"-e4437ed6010e88286f547fa90abfe4c3"},{a:"114ca50f7a8e2f3f657c1108d9d44cfd8",b:"3086d221a7d46bcde86c90e49284eb15"}],gRed:!1,g:["79be667ef9dcbbac55a06295ce870b07029bfcdb2dce28d959f2815b16f81798","483ada7726a3c4655da4fbfc0e1108a8fd17b448a68554199c47d08ffb10d4b8",c]})},{"../elliptic":172,"./precomputed/secp256k1":183,"hash.js":187}],179:[function(e,t,r){"use strict";function n(e){return this instanceof n?("string"==typeof e&&(a(s.curves.hasOwnProperty(e),"Unknown curve "+e),e=s.curves[e]),e instanceof s.curves.PresetCurve&&(e={curve:e}),this.curve=e.curve.curve,this.n=this.curve.n,this.nh=this.n.shrn(1),this.g=this.curve.g,this.g=e.curve.g,this.g.precompute(e.curve.n.bitLength()+1),void(this.hash=e.hash||e.curve.hash)):new n(e)}var i=e("bn.js"),s=e("../../elliptic"),o=s.utils,a=o.assert,f=e("./key"),c=e("./signature");t.exports=n,n.prototype.keyPair=function(e){return new f(this,e)},n.prototype.keyFromPrivate=function(e,t){return f.fromPrivate(this,e,t)},n.prototype.keyFromPublic=function(e,t){return f.fromPublic(this,e,t)},n.prototype.genKeyPair=function(e){e||(e={});for(var t=new s.hmacDRBG({hash:this.hash,pers:e.pers,entropy:e.entropy||s.rand(this.hash.hmacStrength),nonce:this.n.toArray()}),r=this.n.byteLength(),n=this.n.sub(new i(2));;){var o=new i(t.generate(r));if(!(o.cmp(n)>0))return o.iaddn(1),this.keyFromPrivate(o)}},n.prototype._truncateToN=function(e,t){var r=8*e.byteLength()-this.n.bitLength();return r>0&&(e=e.shrn(r)),!t&&e.cmp(this.n)>=0?e.sub(this.n):e},n.prototype.sign=function(e,t,r,n){"object"==typeof r&&(n=r,r=null),n||(n={}),t=this.keyFromPrivate(t,r),e=this._truncateToN(new i(e,16));for(var o=this.n.byteLength(),a=t.getPrivate().toArray(),f=a.length;21>f;f++)a.unshift(0);for(var u=e.toArray(),f=u.length;o>f;f++)u.unshift(0);for(var h=new s.hmacDRBG({hash:this.hash,entropy:a,nonce:u}),d=this.n.sub(new i(1));;){var p=new i(h.generate(this.n.byteLength()));if(p=this._truncateToN(p,!0),!(p.cmpn(1)<=0||p.cmp(d)>=0)){var l=this.g.mul(p);if(!l.isInfinity()){var b=l.getX().mod(this.n);if(0!==b.cmpn(0)){var g=p.invm(this.n).mul(b.mul(t.getPrivate()).iadd(e)).mod(this.n);if(0!==g.cmpn(0))return n.canonical&&g.cmp(this.nh)>0&&(g=this.n.sub(g)),new c({r:b,s:g})}}}}},n.prototype.verify=function(e,t,r,n){e=this._truncateToN(new i(e,16)),r=this.keyFromPublic(r,n),t=new c(t,"hex");var s=t.r,o=t.s;if(s.cmpn(1)<0||s.cmp(this.n)>=0)return!1;if(o.cmpn(1)<0||o.cmp(this.n)>=0)return!1;var a=o.invm(this.n),f=a.mul(e).mod(this.n),u=a.mul(s).mod(this.n),h=this.g.mulAdd(f,r.getPublic(),u);return h.isInfinity()?!1:0===h.getX().mod(this.n).cmp(s)}},{"../../elliptic":172,"./key":180,"./signature":181,"bn.js":170}],180:[function(e,t,r){"use strict";function n(e,t){this.ec=e,this.priv=null,this.pub=null,t.priv&&this._importPrivate(t.priv,t.privEnc),t.pub&&this._importPublic(t.pub,t.pubEnc)}var i=e("bn.js"),s=e("../../elliptic"),o=s.utils;t.exports=n,n.fromPublic=function(e,t,r){return t instanceof n?t:new n(e,{pub:t,pubEnc:r})},n.fromPrivate=function(e,t,r){return t instanceof n?t:new n(e,{priv:t,privEnc:r})},n.prototype.validate=function(){var e=this.getPublic();return e.isInfinity()?{result:!1,reason:"Invalid public key"}:e.validate()?e.mul(this.ec.curve.n).isInfinity()?{result:!0,reason:null}:{result:!1,reason:"Public key * N != O"}:{result:!1,reason:"Public key is not a point"}},n.prototype.getPublic=function(e,t){if(this.pub||(this.pub=this.ec.g.mul(this.priv)),"string"==typeof e&&(t=e,e=null),!t)return this.pub;for(var r=this.ec.curve.p.byteLength(),n=this.pub.getX().toArray(),i=n.length;r>i;i++)n.unshift(0);var s;if("mont"!==this.ec.curve.type)if(e)s=[this.pub.getY().isEven()?2:3].concat(n);else{for(var a=this.pub.getY().toArray(),i=a.length;r>i;i++)a.unshift(0);var s=[4].concat(n,a)}else s=n;return o.encode(s,t)},n.prototype.getPrivate=function(e){return"hex"===e?this.priv.toString(16,2):this.priv},n.prototype._importPrivate=function(e,t){this.priv=new i(e,t||16),this.priv=this.priv.mod(this.ec.curve.n)},n.prototype._importPublic=function(e,t){return e.x||e.y?void(this.pub=this.ec.curve.point(e.x,e.y)):(e=o.toArray(e,t),"mont"!==this.ec.curve.type?this._importPublicShort(e):this._importPublicMont(e))},n.prototype._importPublicShort=function(e){var t=this.ec.curve.p.byteLength();4===e[0]&&e.length-1===2*t?this.pub=this.ec.curve.point(e.slice(1,1+t),e.slice(1+t,1+2*t)):2!==e[0]&&3!==e[0]||e.length-1!==t||(this.pub=this.ec.curve.pointFromX(3===e[0],e.slice(1,1+t)))},n.prototype._importPublicMont=function(e){this.pub=this.ec.curve.point(e,1)},n.prototype.derive=function(e){return e.mul(this.priv).getX()},n.prototype.sign=function(e){return this.ec.sign(e,this)},n.prototype.verify=function(e,t){return this.ec.verify(e,t,this)},n.prototype.inspect=function(){return"<Key priv: "+(this.priv&&this.priv.toString(16,2))+" pub: "+(this.pub&&this.pub.inspect())+" >"}},{"../../elliptic":172,"bn.js":170}],181:[function(e,t,r){"use strict";function n(e,t){return e instanceof n?e:void(this._importDER(e,t)||(a(e.r&&e.s,"Signature without r or s"),this.r=new i(e.r,16),this.s=new i(e.s,16)))}var i=e("bn.js"),s=e("../../elliptic"),o=s.utils,a=o.assert;t.exports=n,n.prototype._importDER=function(e,t){if(e=o.toArray(e,t),e.length<6||48!==e[0]||2!==e[2])return!1;var r=e[1];if(1+r>e.length)return!1;var n=e[3];if(n>=128)return!1;if(4+n+2>=e.length)return!1;if(2!==e[4+n])return!1;var s=e[5+n];return s>=128?!1:4+n+2+s>e.length?!1:(this.r=new i(e.slice(4,4+n)),this.s=new i(e.slice(4+n+2,4+n+2+s)),!0)},n.prototype.toDER=function(e){var t=this.r.toArray(),r=this.s.toArray();128&t[0]&&(t=[0].concat(t)),128&r[0]&&(r=[0].concat(r));var n=t.length+r.length+4,i=[48,n,2,t.length];return i=i.concat(t,[2,r.length],r),o.encode(i,e)}},{"../../elliptic":172,"bn.js":170}],182:[function(e,t,r){"use strict";function n(e){if(!(this instanceof n))return new n(e);this.hash=e.hash,this.predResist=!!e.predResist,this.outLen=this.hash.outSize,this.minEntropy=e.minEntropy||this.hash.hmacStrength,this.reseed=null,this.reseedInterval=null,this.K=null,this.V=null;var t=o.toArray(e.entropy,e.entropyEnc),r=o.toArray(e.nonce,e.nonceEnc),i=o.toArray(e.pers,e.persEnc);a(t.length>=this.minEntropy/8,"Not enough entropy. Minimum is: "+this.minEntropy+" bits"),this._init(t,r,i)}var i=e("hash.js"),s=e("../elliptic"),o=s.utils,a=o.assert;t.exports=n,n.prototype._init=function(e,t,r){var n=e.concat(t).concat(r);this.K=new Array(this.outLen/8),this.V=new Array(this.outLen/8);for(var i=0;i<this.V.length;i++)this.K[i]=0,this.V[i]=1;this._update(n),this.reseed=1,this.reseedInterval=281474976710656},n.prototype._hmac=function(){return new i.hmac(this.hash,this.K)},n.prototype._update=function(e){var t=this._hmac().update(this.V).update([0]);e&&(t=t.update(e)),this.K=t.digest(),this.V=this._hmac().update(this.V).digest(),e&&(this.K=this._hmac().update(this.V).update([1]).update(e).digest(),this.V=this._hmac().update(this.V).digest())},n.prototype.reseed=function(e,t,r,n){"string"!=typeof t&&(n=r,r=t,t=null),e=o.toBuffer(e,t),r=o.toBuffer(r,n),a(e.length>=this.minEntropy/8,"Not enough entropy. Minimum is: "+this.minEntropy+" bits"),this._update(e.concat(r||[])),this.reseed=1},n.prototype.generate=function(e,t,r,n){if(this.reseed>this.reseedInterval)throw new Error("Reseed is required");"string"!=typeof t&&(n=r,r=t,t=null),r&&(r=o.toArray(r,n),this._update(r));for(var i=[];i.length<e;)this.V=this._hmac().update(this.V).digest(),i=i.concat(this.V);var s=i.slice(0,e);return this._update(r),this.reseed++,o.encode(s,t)}},{"../elliptic":172,"hash.js":187}],183:[function(e,t,r){t.exports={doubles:{step:4,points:[["e60fce93b59e9ec53011aabc21c23e97b2a31369b87a5ae9c44ee89e2a6dec0a","f7e3507399e595929db99f34f57937101296891e44d23f0be1f32cce69616821"],["8282263212c609d9ea2a6e3e172de238d8c39cabd5ac1ca10646e23fd5f51508","11f8a8098557dfe45e8256e830b60ace62d613ac2f7b17bed31b6eaff6e26caf"],["175e159f728b865a72f99cc6c6fc846de0b93833fd2222ed73fce5b551e5b739","d3506e0d9e3c79eba4ef97a51ff71f5eacb5955add24345c6efa6ffee9fed695"],["363d90d447b00c9c99ceac05b6262ee053441c7e55552ffe526bad8f83ff4640","4e273adfc732221953b445397f3363145b9a89008199ecb62003c7f3bee9de9"],["8b4b5f165df3c2be8c6244b5b745638843e4a781a15bcd1b69f79a55dffdf80c","4aad0a6f68d308b4b3fbd7813ab0da04f9e336546162ee56b3eff0c65fd4fd36"],["723cbaa6e5db996d6bf771c00bd548c7b700dbffa6c0e77bcb6115925232fcda","96e867b5595cc498a921137488824d6e2660a0653779494801dc069d9eb39f5f"],["eebfa4d493bebf98ba5feec812c2d3b50947961237a919839a533eca0e7dd7fa","5d9a8ca3970ef0f269ee7edaf178089d9ae4cdc3a711f712ddfd4fdae1de8999"],["100f44da696e71672791d0a09b7bde459f1215a29b3c03bfefd7835b39a48db0","cdd9e13192a00b772ec8f3300c090666b7ff4a18ff5195ac0fbd5cd62bc65a09"],["e1031be262c7ed1b1dc9227a4a04c017a77f8d4464f3b3852c8acde6e534fd2d","9d7061928940405e6bb6a4176597535af292dd419e1ced79a44f18f29456a00d"],["feea6cae46d55b530ac2839f143bd7ec5cf8b266a41d6af52d5e688d9094696d","e57c6b6c97dce1bab06e4e12bf3ecd5c981c8957cc41442d3155debf18090088"],["da67a91d91049cdcb367be4be6ffca3cfeed657d808583de33fa978bc1ec6cb1","9bacaa35481642bc41f463f7ec9780e5dec7adc508f740a17e9ea8e27a68be1d"],["53904faa0b334cdda6e000935ef22151ec08d0f7bb11069f57545ccc1a37b7c0","5bc087d0bc80106d88c9eccac20d3c1c13999981e14434699dcb096b022771c8"],["8e7bcd0bd35983a7719cca7764ca906779b53a043a9b8bcaeff959f43ad86047","10b7770b2a3da4b3940310420ca9514579e88e2e47fd68b3ea10047e8460372a"],["385eed34c1cdff21e6d0818689b81bde71a7f4f18397e6690a841e1599c43862","283bebc3e8ea23f56701de19e9ebf4576b304eec2086dc8cc0458fe5542e5453"],["6f9d9b803ecf191637c73a4413dfa180fddf84a5947fbc9c606ed86c3fac3a7","7c80c68e603059ba69b8e2a30e45c4d47ea4dd2f5c281002d86890603a842160"],["3322d401243c4e2582a2147c104d6ecbf774d163db0f5e5313b7e0e742d0e6bd","56e70797e9664ef5bfb019bc4ddaf9b72805f63ea2873af624f3a2e96c28b2a0"],["85672c7d2de0b7da2bd1770d89665868741b3f9af7643397721d74d28134ab83","7c481b9b5b43b2eb6374049bfa62c2e5e77f17fcc5298f44c8e3094f790313a6"],["948bf809b1988a46b06c9f1919413b10f9226c60f668832ffd959af60c82a0a","53a562856dcb6646dc6b74c5d1c3418c6d4dff08c97cd2bed4cb7f88d8c8e589"],["6260ce7f461801c34f067ce0f02873a8f1b0e44dfc69752accecd819f38fd8e8","bc2da82b6fa5b571a7f09049776a1ef7ecd292238051c198c1a84e95b2b4ae17"],["e5037de0afc1d8d43d8348414bbf4103043ec8f575bfdc432953cc8d2037fa2d","4571534baa94d3b5f9f98d09fb990bddbd5f5b03ec481f10e0e5dc841d755bda"],["e06372b0f4a207adf5ea905e8f1771b4e7e8dbd1c6a6c5b725866a0ae4fce725","7a908974bce18cfe12a27bb2ad5a488cd7484a7787104870b27034f94eee31dd"],["213c7a715cd5d45358d0bbf9dc0ce02204b10bdde2a3f58540ad6908d0559754","4b6dad0b5ae462507013ad06245ba190bb4850f5f36a7eeddff2c27534b458f2"],["4e7c272a7af4b34e8dbb9352a5419a87e2838c70adc62cddf0cc3a3b08fbd53c","17749c766c9d0b18e16fd09f6def681b530b9614bff7dd33e0b3941817dcaae6"],["fea74e3dbe778b1b10f238ad61686aa5c76e3db2be43057632427e2840fb27b6","6e0568db9b0b13297cf674deccb6af93126b596b973f7b77701d3db7f23cb96f"],["76e64113f677cf0e10a2570d599968d31544e179b760432952c02a4417bdde39","c90ddf8dee4e95cf577066d70681f0d35e2a33d2b56d2032b4b1752d1901ac01"],["c738c56b03b2abe1e8281baa743f8f9a8f7cc643df26cbee3ab150242bcbb891","893fb578951ad2537f718f2eacbfbbbb82314eef7880cfe917e735d9699a84c3"],["d895626548b65b81e264c7637c972877d1d72e5f3a925014372e9f6588f6c14b","febfaa38f2bc7eae728ec60818c340eb03428d632bb067e179363ed75d7d991f"],["b8da94032a957518eb0f6433571e8761ceffc73693e84edd49150a564f676e03","2804dfa44805a1e4d7c99cc9762808b092cc584d95ff3b511488e4e74efdf6e7"],["e80fea14441fb33a7d8adab9475d7fab2019effb5156a792f1a11778e3c0df5d","eed1de7f638e00771e89768ca3ca94472d155e80af322ea9fcb4291b6ac9ec78"],["a301697bdfcd704313ba48e51d567543f2a182031efd6915ddc07bbcc4e16070","7370f91cfb67e4f5081809fa25d40f9b1735dbf7c0a11a130c0d1a041e177ea1"],["90ad85b389d6b936463f9d0512678de208cc330b11307fffab7ac63e3fb04ed4","e507a3620a38261affdcbd9427222b839aefabe1582894d991d4d48cb6ef150"],["8f68b9d2f63b5f339239c1ad981f162ee88c5678723ea3351b7b444c9ec4c0da","662a9f2dba063986de1d90c2b6be215dbbea2cfe95510bfdf23cbf79501fff82"],["e4f3fb0176af85d65ff99ff9198c36091f48e86503681e3e6686fd5053231e11","1e63633ad0ef4f1c1661a6d0ea02b7286cc7e74ec951d1c9822c38576feb73bc"],["8c00fa9b18ebf331eb961537a45a4266c7034f2f0d4e1d0716fb6eae20eae29e","efa47267fea521a1a9dc343a3736c974c2fadafa81e36c54e7d2a4c66702414b"],["e7a26ce69dd4829f3e10cec0a9e98ed3143d084f308b92c0997fddfc60cb3e41","2a758e300fa7984b471b006a1aafbb18d0a6b2c0420e83e20e8a9421cf2cfd51"],["b6459e0ee3662ec8d23540c223bcbdc571cbcb967d79424f3cf29eb3de6b80ef","67c876d06f3e06de1dadf16e5661db3c4b3ae6d48e35b2ff30bf0b61a71ba45"],["d68a80c8280bb840793234aa118f06231d6f1fc67e73c5a5deda0f5b496943e8","db8ba9fff4b586d00c4b1f9177b0e28b5b0e7b8f7845295a294c84266b133120"],["324aed7df65c804252dc0270907a30b09612aeb973449cea4095980fc28d3d5d","648a365774b61f2ff130c0c35aec1f4f19213b0c7e332843967224af96ab7c84"],["4df9c14919cde61f6d51dfdbe5fee5dceec4143ba8d1ca888e8bd373fd054c96","35ec51092d8728050974c23a1d85d4b5d506cdc288490192ebac06cad10d5d"],["9c3919a84a474870faed8a9c1cc66021523489054d7f0308cbfc99c8ac1f98cd","ddb84f0f4a4ddd57584f044bf260e641905326f76c64c8e6be7e5e03d4fc599d"],["6057170b1dd12fdf8de05f281d8e06bb91e1493a8b91d4cc5a21382120a959e5","9a1af0b26a6a4807add9a2daf71df262465152bc3ee24c65e899be932385a2a8"],["a576df8e23a08411421439a4518da31880cef0fba7d4df12b1a6973eecb94266","40a6bf20e76640b2c92b97afe58cd82c432e10a7f514d9f3ee8be11ae1b28ec8"],["7778a78c28dec3e30a05fe9629de8c38bb30d1f5cf9a3a208f763889be58ad71","34626d9ab5a5b22ff7098e12f2ff580087b38411ff24ac563b513fc1fd9f43ac"],["928955ee637a84463729fd30e7afd2ed5f96274e5ad7e5cb09eda9c06d903ac","c25621003d3f42a827b78a13093a95eeac3d26efa8a8d83fc5180e935bcd091f"],["85d0fef3ec6db109399064f3a0e3b2855645b4a907ad354527aae75163d82751","1f03648413a38c0be29d496e582cf5663e8751e96877331582c237a24eb1f962"],["ff2b0dce97eece97c1c9b6041798b85dfdfb6d8882da20308f5404824526087e","493d13fef524ba188af4c4dc54d07936c7b7ed6fb90e2ceb2c951e01f0c29907"],["827fbbe4b1e880ea9ed2b2e6301b212b57f1ee148cd6dd28780e5e2cf856e241","c60f9c923c727b0b71bef2c67d1d12687ff7a63186903166d605b68baec293ec"],["eaa649f21f51bdbae7be4ae34ce6e5217a58fdce7f47f9aa7f3b58fa2120e2b3","be3279ed5bbbb03ac69a80f89879aa5a01a6b965f13f7e59d47a5305ba5ad93d"],["e4a42d43c5cf169d9391df6decf42ee541b6d8f0c9a137401e23632dda34d24f","4d9f92e716d1c73526fc99ccfb8ad34ce886eedfa8d8e4f13a7f7131deba9414"],["1ec80fef360cbdd954160fadab352b6b92b53576a88fea4947173b9d4300bf19","aeefe93756b5340d2f3a4958a7abbf5e0146e77f6295a07b671cdc1cc107cefd"],["146a778c04670c2f91b00af4680dfa8bce3490717d58ba889ddb5928366642be","b318e0ec3354028add669827f9d4b2870aaa971d2f7e5ed1d0b297483d83efd0"],["fa50c0f61d22e5f07e3acebb1aa07b128d0012209a28b9776d76a8793180eef9","6b84c6922397eba9b72cd2872281a68a5e683293a57a213b38cd8d7d3f4f2811"],["da1d61d0ca721a11b1a5bf6b7d88e8421a288ab5d5bba5220e53d32b5f067ec2","8157f55a7c99306c79c0766161c91e2966a73899d279b48a655fba0f1ad836f1"],["a8e282ff0c9706907215ff98e8fd416615311de0446f1e062a73b0610d064e13","7f97355b8db81c09abfb7f3c5b2515888b679a3e50dd6bd6cef7c73111f4cc0c"],["174a53b9c9a285872d39e56e6913cab15d59b1fa512508c022f382de8319497c","ccc9dc37abfc9c1657b4155f2c47f9e6646b3a1d8cb9854383da13ac079afa73"],["959396981943785c3d3e57edf5018cdbe039e730e4918b3d884fdff09475b7ba","2e7e552888c331dd8ba0386a4b9cd6849c653f64c8709385e9b8abf87524f2fd"],["d2a63a50ae401e56d645a1153b109a8fcca0a43d561fba2dbb51340c9d82b151","e82d86fb6443fcb7565aee58b2948220a70f750af484ca52d4142174dcf89405"],["64587e2335471eb890ee7896d7cfdc866bacbdbd3839317b3436f9b45617e073","d99fcdd5bf6902e2ae96dd6447c299a185b90a39133aeab358299e5e9faf6589"],["8481bde0e4e4d885b3a546d3e549de042f0aa6cea250e7fd358d6c86dd45e458","38ee7b8cba5404dd84a25bf39cecb2ca900a79c42b262e556d64b1b59779057e"],["13464a57a78102aa62b6979ae817f4637ffcfed3c4b1ce30bcd6303f6caf666b","69be159004614580ef7e433453ccb0ca48f300a81d0942e13f495a907f6ecc27"],["bc4a9df5b713fe2e9aef430bcc1dc97a0cd9ccede2f28588cada3a0d2d83f366","d3a81ca6e785c06383937adf4b798caa6e8a9fbfa547b16d758d666581f33c1"],["8c28a97bf8298bc0d23d8c749452a32e694b65e30a9472a3954ab30fe5324caa","40a30463a3305193378fedf31f7cc0eb7ae784f0451cb9459e71dc73cbef9482"],["8ea9666139527a8c1dd94ce4f071fd23c8b350c5a4bb33748c4ba111faccae0","620efabbc8ee2782e24e7c0cfb95c5d735b783be9cf0f8e955af34a30e62b945"],["dd3625faef5ba06074669716bbd3788d89bdde815959968092f76cc4eb9a9787","7a188fa3520e30d461da2501045731ca941461982883395937f68d00c644a573"],["f710d79d9eb962297e4f6232b40e8f7feb2bc63814614d692c12de752408221e","ea98e67232d3b3295d3b535532115ccac8612c721851617526ae47a9c77bfc82"]]
},naf:{wnd:7,points:[["f9308a019258c31049344f85f89d5229b531c845836f99b08601f113bce036f9","388f7b0f632de8140fe337e62a37f3566500a99934c2231b6cb9fd7584b8e672"],["2f8bde4d1a07209355b4a7250a5c5128e88b84bddc619ab7cba8d569b240efe4","d8ac222636e5e3d6d4dba9dda6c9c426f788271bab0d6840dca87d3aa6ac62d6"],["5cbdf0646e5db4eaa398f365f2ea7a0e3d419b7e0330e39ce92bddedcac4f9bc","6aebca40ba255960a3178d6d861a54dba813d0b813fde7b5a5082628087264da"],["acd484e2f0c7f65309ad178a9f559abde09796974c57e714c35f110dfc27ccbe","cc338921b0a7d9fd64380971763b61e9add888a4375f8e0f05cc262ac64f9c37"],["774ae7f858a9411e5ef4246b70c65aac5649980be5c17891bbec17895da008cb","d984a032eb6b5e190243dd56d7b7b365372db1e2dff9d6a8301d74c9c953c61b"],["f28773c2d975288bc7d1d205c3748651b075fbc6610e58cddeeddf8f19405aa8","ab0902e8d880a89758212eb65cdaf473a1a06da521fa91f29b5cb52db03ed81"],["d7924d4f7d43ea965a465ae3095ff41131e5946f3c85f79e44adbcf8e27e080e","581e2872a86c72a683842ec228cc6defea40af2bd896d3a5c504dc9ff6a26b58"],["defdea4cdb677750a420fee807eacf21eb9898ae79b9768766e4faa04a2d4a34","4211ab0694635168e997b0ead2a93daeced1f4a04a95c0f6cfb199f69e56eb77"],["2b4ea0a797a443d293ef5cff444f4979f06acfebd7e86d277475656138385b6c","85e89bc037945d93b343083b5a1c86131a01f60c50269763b570c854e5c09b7a"],["352bbf4a4cdd12564f93fa332ce333301d9ad40271f8107181340aef25be59d5","321eb4075348f534d59c18259dda3e1f4a1b3b2e71b1039c67bd3d8bcf81998c"],["2fa2104d6b38d11b0230010559879124e42ab8dfeff5ff29dc9cdadd4ecacc3f","2de1068295dd865b64569335bd5dd80181d70ecfc882648423ba76b532b7d67"],["9248279b09b4d68dab21a9b066edda83263c3d84e09572e269ca0cd7f5453714","73016f7bf234aade5d1aa71bdea2b1ff3fc0de2a887912ffe54a32ce97cb3402"],["daed4f2be3a8bf278e70132fb0beb7522f570e144bf615c07e996d443dee8729","a69dce4a7d6c98e8d4a1aca87ef8d7003f83c230f3afa726ab40e52290be1c55"],["c44d12c7065d812e8acf28d7cbb19f9011ecd9e9fdf281b0e6a3b5e87d22e7db","2119a460ce326cdc76c45926c982fdac0e106e861edf61c5a039063f0e0e6482"],["6a245bf6dc698504c89a20cfded60853152b695336c28063b61c65cbd269e6b4","e022cf42c2bd4a708b3f5126f16a24ad8b33ba48d0423b6efd5e6348100d8a82"],["1697ffa6fd9de627c077e3d2fe541084ce13300b0bec1146f95ae57f0d0bd6a5","b9c398f186806f5d27561506e4557433a2cf15009e498ae7adee9d63d01b2396"],["605bdb019981718b986d0f07e834cb0d9deb8360ffb7f61df982345ef27a7479","2972d2de4f8d20681a78d93ec96fe23c26bfae84fb14db43b01e1e9056b8c49"],["62d14dab4150bf497402fdc45a215e10dcb01c354959b10cfe31c7e9d87ff33d","80fc06bd8cc5b01098088a1950eed0db01aa132967ab472235f5642483b25eaf"],["80c60ad0040f27dade5b4b06c408e56b2c50e9f56b9b8b425e555c2f86308b6f","1c38303f1cc5c30f26e66bad7fe72f70a65eed4cbe7024eb1aa01f56430bd57a"],["7a9375ad6167ad54aa74c6348cc54d344cc5dc9487d847049d5eabb0fa03c8fb","d0e3fa9eca8726909559e0d79269046bdc59ea10c70ce2b02d499ec224dc7f7"],["d528ecd9b696b54c907a9ed045447a79bb408ec39b68df504bb51f459bc3ffc9","eecf41253136e5f99966f21881fd656ebc4345405c520dbc063465b521409933"],["49370a4b5f43412ea25f514e8ecdad05266115e4a7ecb1387231808f8b45963","758f3f41afd6ed428b3081b0512fd62a54c3f3afbb5b6764b653052a12949c9a"],["77f230936ee88cbbd73df930d64702ef881d811e0e1498e2f1c13eb1fc345d74","958ef42a7886b6400a08266e9ba1b37896c95330d97077cbbe8eb3c7671c60d6"],["f2dac991cc4ce4b9ea44887e5c7c0bce58c80074ab9d4dbaeb28531b7739f530","e0dedc9b3b2f8dad4da1f32dec2531df9eb5fbeb0598e4fd1a117dba703a3c37"],["463b3d9f662621fb1b4be8fbbe2520125a216cdfc9dae3debcba4850c690d45b","5ed430d78c296c3543114306dd8622d7c622e27c970a1de31cb377b01af7307e"],["f16f804244e46e2a09232d4aff3b59976b98fac14328a2d1a32496b49998f247","cedabd9b82203f7e13d206fcdf4e33d92a6c53c26e5cce26d6579962c4e31df6"],["caf754272dc84563b0352b7a14311af55d245315ace27c65369e15f7151d41d1","cb474660ef35f5f2a41b643fa5e460575f4fa9b7962232a5c32f908318a04476"],["2600ca4b282cb986f85d0f1709979d8b44a09c07cb86d7c124497bc86f082120","4119b88753c15bd6a693b03fcddbb45d5ac6be74ab5f0ef44b0be9475a7e4b40"],["7635ca72d7e8432c338ec53cd12220bc01c48685e24f7dc8c602a7746998e435","91b649609489d613d1d5e590f78e6d74ecfc061d57048bad9e76f302c5b9c61"],["754e3239f325570cdbbf4a87deee8a66b7f2b33479d468fbc1a50743bf56cc18","673fb86e5bda30fb3cd0ed304ea49a023ee33d0197a695d0c5d98093c536683"],["e3e6bd1071a1e96aff57859c82d570f0330800661d1c952f9fe2694691d9b9e8","59c9e0bba394e76f40c0aa58379a3cb6a5a2283993e90c4167002af4920e37f5"],["186b483d056a033826ae73d88f732985c4ccb1f32ba35f4b4cc47fdcf04aa6eb","3b952d32c67cf77e2e17446e204180ab21fb8090895138b4a4a797f86e80888b"],["df9d70a6b9876ce544c98561f4be4f725442e6d2b737d9c91a8321724ce0963f","55eb2dafd84d6ccd5f862b785dc39d4ab157222720ef9da217b8c45cf2ba2417"],["5edd5cc23c51e87a497ca815d5dce0f8ab52554f849ed8995de64c5f34ce7143","efae9c8dbc14130661e8cec030c89ad0c13c66c0d17a2905cdc706ab7399a868"],["290798c2b6476830da12fe02287e9e777aa3fba1c355b17a722d362f84614fba","e38da76dcd440621988d00bcf79af25d5b29c094db2a23146d003afd41943e7a"],["af3c423a95d9f5b3054754efa150ac39cd29552fe360257362dfdecef4053b45","f98a3fd831eb2b749a93b0e6f35cfb40c8cd5aa667a15581bc2feded498fd9c6"],["766dbb24d134e745cccaa28c99bf274906bb66b26dcf98df8d2fed50d884249a","744b1152eacbe5e38dcc887980da38b897584a65fa06cedd2c924f97cbac5996"],["59dbf46f8c94759ba21277c33784f41645f7b44f6c596a58ce92e666191abe3e","c534ad44175fbc300f4ea6ce648309a042ce739a7919798cd85e216c4a307f6e"],["f13ada95103c4537305e691e74e9a4a8dd647e711a95e73cb62dc6018cfd87b8","e13817b44ee14de663bf4bc808341f326949e21a6a75c2570778419bdaf5733d"],["7754b4fa0e8aced06d4167a2c59cca4cda1869c06ebadfb6488550015a88522c","30e93e864e669d82224b967c3020b8fa8d1e4e350b6cbcc537a48b57841163a2"],["948dcadf5990e048aa3874d46abef9d701858f95de8041d2a6828c99e2262519","e491a42537f6e597d5d28a3224b1bc25df9154efbd2ef1d2cbba2cae5347d57e"],["7962414450c76c1689c7b48f8202ec37fb224cf5ac0bfa1570328a8a3d7c77ab","100b610ec4ffb4760d5c1fc133ef6f6b12507a051f04ac5760afa5b29db83437"],["3514087834964b54b15b160644d915485a16977225b8847bb0dd085137ec47ca","ef0afbb2056205448e1652c48e8127fc6039e77c15c2378b7e7d15a0de293311"],["d3cc30ad6b483e4bc79ce2c9dd8bc54993e947eb8df787b442943d3f7b527eaf","8b378a22d827278d89c5e9be8f9508ae3c2ad46290358630afb34db04eede0a4"],["1624d84780732860ce1c78fcbfefe08b2b29823db913f6493975ba0ff4847610","68651cf9b6da903e0914448c6cd9d4ca896878f5282be4c8cc06e2a404078575"],["733ce80da955a8a26902c95633e62a985192474b5af207da6df7b4fd5fc61cd4","f5435a2bd2badf7d485a4d8b8db9fcce3e1ef8e0201e4578c54673bc1dc5ea1d"],["15d9441254945064cf1a1c33bbd3b49f8966c5092171e699ef258dfab81c045c","d56eb30b69463e7234f5137b73b84177434800bacebfc685fc37bbe9efe4070d"],["a1d0fcf2ec9de675b612136e5ce70d271c21417c9d2b8aaaac138599d0717940","edd77f50bcb5a3cab2e90737309667f2641462a54070f3d519212d39c197a629"],["e22fbe15c0af8ccc5780c0735f84dbe9a790badee8245c06c7ca37331cb36980","a855babad5cd60c88b430a69f53a1a7a38289154964799be43d06d77d31da06"],["311091dd9860e8e20ee13473c1155f5f69635e394704eaa74009452246cfa9b3","66db656f87d1f04fffd1f04788c06830871ec5a64feee685bd80f0b1286d8374"],["34c1fd04d301be89b31c0442d3e6ac24883928b45a9340781867d4232ec2dbdf","9414685e97b1b5954bd46f730174136d57f1ceeb487443dc5321857ba73abee"],["f219ea5d6b54701c1c14de5b557eb42a8d13f3abbcd08affcc2a5e6b049b8d63","4cb95957e83d40b0f73af4544cccf6b1f4b08d3c07b27fb8d8c2962a400766d1"],["d7b8740f74a8fbaab1f683db8f45de26543a5490bca627087236912469a0b448","fa77968128d9c92ee1010f337ad4717eff15db5ed3c049b3411e0315eaa4593b"],["32d31c222f8f6f0ef86f7c98d3a3335ead5bcd32abdd94289fe4d3091aa824bf","5f3032f5892156e39ccd3d7915b9e1da2e6dac9e6f26e961118d14b8462e1661"],["7461f371914ab32671045a155d9831ea8793d77cd59592c4340f86cbc18347b5","8ec0ba238b96bec0cbdddcae0aa442542eee1ff50c986ea6b39847b3cc092ff6"],["ee079adb1df1860074356a25aa38206a6d716b2c3e67453d287698bad7b2b2d6","8dc2412aafe3be5c4c5f37e0ecc5f9f6a446989af04c4e25ebaac479ec1c8c1e"],["16ec93e447ec83f0467b18302ee620f7e65de331874c9dc72bfd8616ba9da6b5","5e4631150e62fb40d0e8c2a7ca5804a39d58186a50e497139626778e25b0674d"],["eaa5f980c245f6f038978290afa70b6bd8855897f98b6aa485b96065d537bd99","f65f5d3e292c2e0819a528391c994624d784869d7e6ea67fb18041024edc07dc"],["78c9407544ac132692ee1910a02439958ae04877151342ea96c4b6b35a49f51","f3e0319169eb9b85d5404795539a5e68fa1fbd583c064d2462b675f194a3ddb4"],["494f4be219a1a77016dcd838431aea0001cdc8ae7a6fc688726578d9702857a5","42242a969283a5f339ba7f075e36ba2af925ce30d767ed6e55f4b031880d562c"],["a598a8030da6d86c6bc7f2f5144ea549d28211ea58faa70ebf4c1e665c1fe9b5","204b5d6f84822c307e4b4a7140737aec23fc63b65b35f86a10026dbd2d864e6b"],["c41916365abb2b5d09192f5f2dbeafec208f020f12570a184dbadc3e58595997","4f14351d0087efa49d245b328984989d5caf9450f34bfc0ed16e96b58fa9913"],["841d6063a586fa475a724604da03bc5b92a2e0d2e0a36acfe4c73a5514742881","73867f59c0659e81904f9a1c7543698e62562d6744c169ce7a36de01a8d6154"],["5e95bb399a6971d376026947f89bde2f282b33810928be4ded112ac4d70e20d5","39f23f366809085beebfc71181313775a99c9aed7d8ba38b161384c746012865"],["36e4641a53948fd476c39f8a99fd974e5ec07564b5315d8bf99471bca0ef2f66","d2424b1b1abe4eb8164227b085c9aa9456ea13493fd563e06fd51cf5694c78fc"],["336581ea7bfbbb290c191a2f507a41cf5643842170e914faeab27c2c579f726","ead12168595fe1be99252129b6e56b3391f7ab1410cd1e0ef3dcdcabd2fda224"],["8ab89816dadfd6b6a1f2634fcf00ec8403781025ed6890c4849742706bd43ede","6fdcef09f2f6d0a044e654aef624136f503d459c3e89845858a47a9129cdd24e"],["1e33f1a746c9c5778133344d9299fcaa20b0938e8acff2544bb40284b8c5fb94","60660257dd11b3aa9c8ed618d24edff2306d320f1d03010e33a7d2057f3b3b6"],["85b7c1dcb3cec1b7ee7f30ded79dd20a0ed1f4cc18cbcfcfa410361fd8f08f31","3d98a9cdd026dd43f39048f25a8847f4fcafad1895d7a633c6fed3c35e999511"],["29df9fbd8d9e46509275f4b125d6d45d7fbe9a3b878a7af872a2800661ac5f51","b4c4fe99c775a606e2d8862179139ffda61dc861c019e55cd2876eb2a27d84b"],["a0b1cae06b0a847a3fea6e671aaf8adfdfe58ca2f768105c8082b2e449fce252","ae434102edde0958ec4b19d917a6a28e6b72da1834aff0e650f049503a296cf2"],["4e8ceafb9b3e9a136dc7ff67e840295b499dfb3b2133e4ba113f2e4c0e121e5","cf2174118c8b6d7a4b48f6d534ce5c79422c086a63460502b827ce62a326683c"],["d24a44e047e19b6f5afb81c7ca2f69080a5076689a010919f42725c2b789a33b","6fb8d5591b466f8fc63db50f1c0f1c69013f996887b8244d2cdec417afea8fa3"],["ea01606a7a6c9cdd249fdfcfacb99584001edd28abbab77b5104e98e8e3b35d4","322af4908c7312b0cfbfe369f7a7b3cdb7d4494bc2823700cfd652188a3ea98d"],["af8addbf2b661c8a6c6328655eb96651252007d8c5ea31be4ad196de8ce2131f","6749e67c029b85f52a034eafd096836b2520818680e26ac8f3dfbcdb71749700"],["e3ae1974566ca06cc516d47e0fb165a674a3dabcfca15e722f0e3450f45889","2aeabe7e4531510116217f07bf4d07300de97e4874f81f533420a72eeb0bd6a4"],["591ee355313d99721cf6993ffed1e3e301993ff3ed258802075ea8ced397e246","b0ea558a113c30bea60fc4775460c7901ff0b053d25ca2bdeee98f1a4be5d196"],["11396d55fda54c49f19aa97318d8da61fa8584e47b084945077cf03255b52984","998c74a8cd45ac01289d5833a7beb4744ff536b01b257be4c5767bea93ea57a4"],["3c5d2a1ba39c5a1790000738c9e0c40b8dcdfd5468754b6405540157e017aa7a","b2284279995a34e2f9d4de7396fc18b80f9b8b9fdd270f6661f79ca4c81bd257"],["cc8704b8a60a0defa3a99a7299f2e9c3fbc395afb04ac078425ef8a1793cc030","bdd46039feed17881d1e0862db347f8cf395b74fc4bcdc4e940b74e3ac1f1b13"],["c533e4f7ea8555aacd9777ac5cad29b97dd4defccc53ee7ea204119b2889b197","6f0a256bc5efdf429a2fb6242f1a43a2d9b925bb4a4b3a26bb8e0f45eb596096"],["c14f8f2ccb27d6f109f6d08d03cc96a69ba8c34eec07bbcf566d48e33da6593","c359d6923bb398f7fd4473e16fe1c28475b740dd098075e6c0e8649113dc3a38"],["a6cbc3046bc6a450bac24789fa17115a4c9739ed75f8f21ce441f72e0b90e6ef","21ae7f4680e889bb130619e2c0f95a360ceb573c70603139862afd617fa9b9f"],["347d6d9a02c48927ebfb86c1359b1caf130a3c0267d11ce6344b39f99d43cc38","60ea7f61a353524d1c987f6ecec92f086d565ab687870cb12689ff1e31c74448"],["da6545d2181db8d983f7dcb375ef5866d47c67b1bf31c8cf855ef7437b72656a","49b96715ab6878a79e78f07ce5680c5d6673051b4935bd897fea824b77dc208a"],["c40747cc9d012cb1a13b8148309c6de7ec25d6945d657146b9d5994b8feb1111","5ca560753be2a12fc6de6caf2cb489565db936156b9514e1bb5e83037e0fa2d4"],["4e42c8ec82c99798ccf3a610be870e78338c7f713348bd34c8203ef4037f3502","7571d74ee5e0fb92a7a8b33a07783341a5492144cc54bcc40a94473693606437"],["3775ab7089bc6af823aba2e1af70b236d251cadb0c86743287522a1b3b0dedea","be52d107bcfa09d8bcb9736a828cfa7fac8db17bf7a76a2c42ad961409018cf7"],["cee31cbf7e34ec379d94fb814d3d775ad954595d1314ba8846959e3e82f74e26","8fd64a14c06b589c26b947ae2bcf6bfa0149ef0be14ed4d80f448a01c43b1c6d"],["b4f9eaea09b6917619f6ea6a4eb5464efddb58fd45b1ebefcdc1a01d08b47986","39e5c9925b5a54b07433a4f18c61726f8bb131c012ca542eb24a8ac07200682a"],["d4263dfc3d2df923a0179a48966d30ce84e2515afc3dccc1b77907792ebcc60e","62dfaf07a0f78feb30e30d6295853ce189e127760ad6cf7fae164e122a208d54"],["48457524820fa65a4f8d35eb6930857c0032acc0a4a2de422233eeda897612c4","25a748ab367979d98733c38a1fa1c2e7dc6cc07db2d60a9ae7a76aaa49bd0f77"],["dfeeef1881101f2cb11644f3a2afdfc2045e19919152923f367a1767c11cceda","ecfb7056cf1de042f9420bab396793c0c390bde74b4bbdff16a83ae09a9a7517"],["6d7ef6b17543f8373c573f44e1f389835d89bcbc6062ced36c82df83b8fae859","cd450ec335438986dfefa10c57fea9bcc521a0959b2d80bbf74b190dca712d10"],["e75605d59102a5a2684500d3b991f2e3f3c88b93225547035af25af66e04541f","f5c54754a8f71ee540b9b48728473e314f729ac5308b06938360990e2bfad125"],["eb98660f4c4dfaa06a2be453d5020bc99a0c2e60abe388457dd43fefb1ed620c","6cb9a8876d9cb8520609af3add26cd20a0a7cd8a9411131ce85f44100099223e"],["13e87b027d8514d35939f2e6892b19922154596941888336dc3563e3b8dba942","fef5a3c68059a6dec5d624114bf1e91aac2b9da568d6abeb2570d55646b8adf1"],["ee163026e9fd6fe017c38f06a5be6fc125424b371ce2708e7bf4491691e5764a","1acb250f255dd61c43d94ccc670d0f58f49ae3fa15b96623e5430da0ad6c62b2"],["b268f5ef9ad51e4d78de3a750c2dc89b1e626d43505867999932e5db33af3d80","5f310d4b3c99b9ebb19f77d41c1dee018cf0d34fd4191614003e945a1216e423"],["ff07f3118a9df035e9fad85eb6c7bfe42b02f01ca99ceea3bf7ffdba93c4750d","438136d603e858a3a5c440c38eccbaddc1d2942114e2eddd4740d098ced1f0d8"],["8d8b9855c7c052a34146fd20ffb658bea4b9f69e0d825ebec16e8c3ce2b526a1","cdb559eedc2d79f926baf44fb84ea4d44bcf50fee51d7ceb30e2e7f463036758"],["52db0b5384dfbf05bfa9d472d7ae26dfe4b851ceca91b1eba54263180da32b63","c3b997d050ee5d423ebaf66a6db9f57b3180c902875679de924b69d84a7b375"],["e62f9490d3d51da6395efd24e80919cc7d0f29c3f3fa48c6fff543becbd43352","6d89ad7ba4876b0b22c2ca280c682862f342c8591f1daf5170e07bfd9ccafa7d"],["7f30ea2476b399b4957509c88f77d0191afa2ff5cb7b14fd6d8e7d65aaab1193","ca5ef7d4b231c94c3b15389a5f6311e9daff7bb67b103e9880ef4bff637acaec"],["5098ff1e1d9f14fb46a210fada6c903fef0fb7b4a1dd1d9ac60a0361800b7a00","9731141d81fc8f8084d37c6e7542006b3ee1b40d60dfe5362a5b132fd17ddc0"],["32b78c7de9ee512a72895be6b9cbefa6e2f3c4ccce445c96b9f2c81e2778ad58","ee1849f513df71e32efc3896ee28260c73bb80547ae2275ba497237794c8753c"],["e2cb74fddc8e9fbcd076eef2a7c72b0ce37d50f08269dfc074b581550547a4f7","d3aa2ed71c9dd2247a62df062736eb0baddea9e36122d2be8641abcb005cc4a4"],["8438447566d4d7bedadc299496ab357426009a35f235cb141be0d99cd10ae3a8","c4e1020916980a4da5d01ac5e6ad330734ef0d7906631c4f2390426b2edd791f"],["4162d488b89402039b584c6fc6c308870587d9c46f660b878ab65c82c711d67e","67163e903236289f776f22c25fb8a3afc1732f2b84b4e95dbda47ae5a0852649"],["3fad3fa84caf0f34f0f89bfd2dcf54fc175d767aec3e50684f3ba4a4bf5f683d","cd1bc7cb6cc407bb2f0ca647c718a730cf71872e7d0d2a53fa20efcdfe61826"],["674f2600a3007a00568c1a7ce05d0816c1fb84bf1370798f1c69532faeb1a86b","299d21f9413f33b3edf43b257004580b70db57da0b182259e09eecc69e0d38a5"],["d32f4da54ade74abb81b815ad1fb3b263d82d6c692714bcff87d29bd5ee9f08f","f9429e738b8e53b968e99016c059707782e14f4535359d582fc416910b3eea87"],["30e4e670435385556e593657135845d36fbb6931f72b08cb1ed954f1e3ce3ff6","462f9bce619898638499350113bbc9b10a878d35da70740dc695a559eb88db7b"],["be2062003c51cc3004682904330e4dee7f3dcd10b01e580bf1971b04d4cad297","62188bc49d61e5428573d48a74e1c655b1c61090905682a0d5558ed72dccb9bc"],["93144423ace3451ed29e0fb9ac2af211cb6e84a601df5993c419859fff5df04a","7c10dfb164c3425f5c71a3f9d7992038f1065224f72bb9d1d902a6d13037b47c"],["b015f8044f5fcbdcf21ca26d6c34fb8197829205c7b7d2a7cb66418c157b112c","ab8c1e086d04e813744a655b2df8d5f83b3cdc6faa3088c1d3aea1454e3a1d5f"],["d5e9e1da649d97d89e4868117a465a3a4f8a18de57a140d36b3f2af341a21b52","4cb04437f391ed73111a13cc1d4dd0db1693465c2240480d8955e8592f27447a"],["d3ae41047dd7ca065dbf8ed77b992439983005cd72e16d6f996a5316d36966bb","bd1aeb21ad22ebb22a10f0303417c6d964f8cdd7df0aca614b10dc14d125ac46"],["463e2763d885f958fc66cdd22800f0a487197d0a82e377b49f80af87c897b065","bfefacdb0e5d0fd7df3a311a94de062b26b80c61fbc97508b79992671ef7ca7f"],["7985fdfd127c0567c6f53ec1bb63ec3158e597c40bfe747c83cddfc910641917","603c12daf3d9862ef2b25fe1de289aed24ed291e0ec6708703a5bd567f32ed03"],["74a1ad6b5f76e39db2dd249410eac7f99e74c59cb83d2d0ed5ff1543da7703e9","cc6157ef18c9c63cd6193d83631bbea0093e0968942e8c33d5737fd790e0db08"],["30682a50703375f602d416664ba19b7fc9bab42c72747463a71d0896b22f6da3","553e04f6b018b4fa6c8f39e7f311d3176290d0e0f19ca73f17714d9977a22ff8"],["9e2158f0d7c0d5f26c3791efefa79597654e7a2b2464f52b1ee6c1347769ef57","712fcdd1b9053f09003a3481fa7762e9ffd7c8ef35a38509e2fbf2629008373"],["176e26989a43c9cfeba4029c202538c28172e566e3c4fce7322857f3be327d66","ed8cc9d04b29eb877d270b4878dc43c19aefd31f4eee09ee7b47834c1fa4b1c3"],["75d46efea3771e6e68abb89a13ad747ecf1892393dfc4f1b7004788c50374da8","9852390a99507679fd0b86fd2b39a868d7efc22151346e1a3ca4726586a6bed8"],["809a20c67d64900ffb698c4c825f6d5f2310fb0451c869345b7319f645605721","9e994980d9917e22b76b061927fa04143d096ccc54963e6a5ebfa5f3f8e286c1"],["1b38903a43f7f114ed4500b4eac7083fdefece1cf29c63528d563446f972c180","4036edc931a60ae889353f77fd53de4a2708b26b6f5da72ad3394119daf408f9"]]}}},{}],184:[function(e,t,r){"use strict";function n(e,t){if(Array.isArray(e))return e.slice();if(!e)return[];var r=[];if("string"!=typeof e){for(var n=0;n<e.length;n++)r[n]=0|e[n];return r}if(t){if("hex"===t){e=e.replace(/[^a-z0-9]+/gi,""),e.length%2!==0&&(e="0"+e);for(var n=0;n<e.length;n+=2)r.push(parseInt(e[n]+e[n+1],16))}}else for(var n=0;n<e.length;n++){var i=e.charCodeAt(n),s=i>>8,o=255&i;s?r.push(s,o):r.push(o)}return r}function i(e){return 1===e.length?"0"+e:e}function s(e){for(var t="",r=0;r<e.length;r++)t+=i(e[r].toString(16));return t}function o(e,t){for(var r=[],n=1<<t+1,i=e.clone();i.cmpn(1)>=0;){var s;if(i.isOdd()){var o=i.andln(n-1);s=o>(n>>1)-1?(n>>1)-o:o,i.isubn(s)}else s=0;r.push(s);for(var a=0!==i.cmpn(0)&&0===i.andln(n-1)?t+1:1,f=1;a>f;f++)r.push(0);i.ishrn(a)}return r}function a(e,t){var r=[[],[]];e=e.clone(),t=t.clone();for(var n=0,i=0;e.cmpn(-n)>0||t.cmpn(-i)>0;){var s=e.andln(3)+n&3,o=t.andln(3)+i&3;3===s&&(s=-1),3===o&&(o=-1);var a;if(0===(1&s))a=0;else{var f=e.andln(7)+n&7;a=3!==f&&5!==f||2!==o?s:-s}r[0].push(a);var c;if(0===(1&o))c=0;else{var f=t.andln(7)+i&7;c=3!==f&&5!==f||2!==s?o:-o}r[1].push(c),2*n===a+1&&(n=1-n),2*i===c+1&&(i=1-i),e.ishrn(1),t.ishrn(1)}return r}var f=r;f.assert=function(e,t){if(!e)throw new Error(t||"Assertion failed")},f.toArray=n,f.zero2=i,f.toHex=s,f.encode=function(e,t){return"hex"===t?s(e):e},f.getNAF=o,f.getJSF=a},{}],185:[function(e,t,r){t.exports=e(115)},{"/home/braydon/bitcore/node_modules/bitcore-build/node_modules/browserify/node_modules/crypto-browserify/node_modules/diffie-hellman/node_modules/miller-rabin/node_modules/brorand/index.js":115}],186:[function(e,t,r){t.exports={name:"elliptic",version:"3.0.3",description:"EC cryptography",main:"lib/elliptic.js",scripts:{test:"make lint && mocha --reporter=spec test/*-test.js"},repository:{type:"git",url:"git+ssh://git@github.com/indutny/elliptic.git"},keywords:["EC","Elliptic","curve","Cryptography"],author:{name:"Fedor Indutny",email:"fedor@indutny.com"},license:"MIT",bugs:{url:"https://github.com/indutny/elliptic/issues"},homepage:"https://github.com/indutny/elliptic",devDependencies:{browserify:"^3.44.2",jscs:"^1.11.3",jshint:"^2.6.0",mocha:"^2.1.0","uglify-js":"^2.4.13"},dependencies:{"bn.js":"^2.0.0",brorand:"^1.0.1","hash.js":"^1.0.0",inherits:"^2.0.1"},readme:"# Elliptic [![Build Status](https://secure.travis-ci.org/indutny/elliptic.png)](http://travis-ci.org/indutny/elliptic)\n\nFast elliptic-curve cryptography in a plain javascript implementation.\n\nNOTE: Please take a look at http://safecurves.cr.yp.to/ before choosing a curve\nfor your cryptography operations.\n\n## Incentive\n\nECC is much slower than regular RSA cryptography, the JS implementations are\neven more slower.\n\n## Benchmarks\n\n```bash\n$ node benchmarks/index.js\nBenchmarking: sign\nelliptic#sign x 262 ops/sec ±0.51% (177 runs sampled)\neccjs#sign x 55.91 ops/sec ±0.90% (144 runs sampled)\n------------------------\nFastest is elliptic#sign\n========================\nBenchmarking: verify\nelliptic#verify x 113 ops/sec ±0.50% (166 runs sampled)\neccjs#verify x 48.56 ops/sec ±0.36% (125 runs sampled)\n------------------------\nFastest is elliptic#verify\n========================\nBenchmarking: gen\nelliptic#gen x 294 ops/sec ±0.43% (176 runs sampled)\neccjs#gen x 62.25 ops/sec ±0.63% (129 runs sampled)\n------------------------\nFastest is elliptic#gen\n========================\nBenchmarking: ecdh\nelliptic#ecdh x 136 ops/sec ±0.85% (156 runs sampled)\n------------------------\nFastest is elliptic#ecdh\n========================\n```\n\n## API\n\n### ECDSA\n\n```javascript\nvar EC = require('elliptic').ec;\n\n// Create and initialize EC context\n// (better do it once and reuse it)\nvar ec = new EC('secp256k1');\n\n// Generate keys\nvar key = ec.genKeyPair();\n\n// Sign message (must be an array, or it'll be treated as a hex sequence)\nvar msg = [ 0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 10 ];\nvar signature = key.sign(msg);\n\n// Export DER encoded signature in Array\nvar derSign = signature.toDER();\n\n// Verify signature\nconsole.log(key.verify(msg, derSign));\n```\n\n### ECDH\n\n```javascript\n// Generate keys\nvar key1 = ec.genKeyPair();\nvar key2 = ec.genKeyPair();\n\nvar shared1 = key1.derive(key2.getPublic());\nvar shared2 = key2.derive(key1.getPublic());\n\nconsole.log('Both shared secrets are BN instances');\nconsole.log(shared1.toString(16));\nconsole.log(shared2.toString(16));\n```\n\nNOTE: `.derive()` returns a [BN][1] instance.\n\n## Supported curves\n\nElliptic.js support following curve types:\n\n* Short Weierstrass\n* Montgomery\n* Edwards\n* Twisted Edwards\n\nFollowing curve 'presets' are embedded into the library:\n\n* `secp256k1`\n* `p192`\n* `p224`\n* `p256`\n* `curve25519`\n* `ed25519`\n\nNOTE: That `curve25519` could not be used for ECDSA, use `ed25519` instead.\n\n### Implementation details\n\nECDSA is using deterministic `k` value generation as per [RFC6979][0]. Most of\nthe curve operations are performed on non-affine coordinates (either projective\nor extended), various windowing techniques are used for different cases.\n\nAll operations are performed in reduction context using [bn.js][1], hashing is\nprovided by [hash.js][2]\n\n### Related projects\n\n* [eccrypto][3]: isomorphic implementation of ECDSA, ECDH and ECIES for both\n browserify and node (uses `elliptic` for browser and [secp256k1-node][4] for\n node)\n\n#### LICENSE\n\nThis software is licensed under the MIT License.\n\nCopyright Fedor Indutny, 2014.\n\nPermission is hereby granted, free of charge, to any person obtaining a\ncopy of this software and associated documentation files (the\n\"Software\"), to deal in the Software without restriction, including\nwithout limitation the rights to use, copy, modify, merge, publish,\ndistribute, sublicense, and/or sell copies of the Software, and to permit\npersons to whom the Software is furnished to do so, subject to the\nfollowing conditions:\n\nThe above copyright notice and this permission notice shall be included\nin all copies or substantial portions of the Software.\n\nTHE SOFTWARE IS PROVIDED \"AS IS\", WITHOUT WARRANTY OF ANY KIND, EXPRESS\nOR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF\nMERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN\nNO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM,\nDAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR\nOTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE\nUSE OR OTHER DEALINGS IN THE SOFTWARE.\n\n[0]: http://tools.ietf.org/html/rfc6979\n[1]: https://github.com/indutny/bn.js\n[2]: https://github.com/indutny/hash.js\n[3]: https://github.com/bitchan/eccrypto\n[4]: https://github.com/wanderer/secp256k1-node\n",readmeFilename:"README.md",_id:"elliptic@3.0.3",_shasum:"865c9b420bfbe55006b9f969f97a0d2c44966595",_resolved:"https://registry.npmjs.org/elliptic/-/elliptic-3.0.3.tgz",_from:"https://registry.npmjs.org/elliptic/-/elliptic-3.0.3.tgz"}},{}],187:[function(e,t,r){var n=r;n.utils=e("./hash/utils"),n.common=e("./hash/common"),n.sha=e("./hash/sha"),n.ripemd=e("./hash/ripemd"),n.hmac=e("./hash/hmac"),n.sha1=n.sha.sha1,n.sha256=n.sha.sha256,n.sha224=n.sha.sha224,n.sha384=n.sha.sha384,n.sha512=n.sha.sha512,n.ripemd160=n.ripemd.ripemd160},{"./hash/common":188,"./hash/hmac":189,"./hash/ripemd":190,"./hash/sha":191,"./hash/utils":192}],188:[function(e,t,r){function n(){this.pending=null,this.pendingTotal=0,this.blockSize=this.constructor.blockSize,this.outSize=this.constructor.outSize,this.hmacStrength=this.constructor.hmacStrength,this.padLength=this.constructor.padLength/8,this.endian="big",this._delta8=this.blockSize/8,this._delta32=this.blockSize/32}var i=e("../hash"),s=i.utils,o=s.assert;r.BlockHash=n,n.prototype.update=function(e,t){if(e=s.toArray(e,t),this.pending=this.pending?this.pending.concat(e):e,this.pendingTotal+=e.length,this.pending.length>=this._delta8){e=this.pending;var r=e.length%this._delta8;this.pending=e.slice(e.length-r,e.length),0===this.pending.length&&(this.pending=null),e=s.join32(e,0,e.length-r,this.endian);for(var n=0;n<e.length;n+=this._delta32)this._update(e,n,n+this._delta32)}return this},n.prototype.digest=function(e){return this.update(this._pad()),o(null===this.pending),this._digest(e)},n.prototype._pad=function(){var e=this.pendingTotal,t=this._delta8,r=t-(e+this.padLength)%t,n=new Array(r+this.padLength);n[0]=128;for(var i=1;r>i;i++)n[i]=0;if(e<<=3,"big"===this.endian){for(var s=8;s<this.padLength;s++)n[i++]=0;n[i++]=0,n[i++]=0,n[i++]=0,n[i++]=0,n[i++]=e>>>24&255,n[i++]=e>>>16&255,n[i++]=e>>>8&255,n[i++]=255&e}else{n[i++]=255&e,n[i++]=e>>>8&255,n[i++]=e>>>16&255,n[i++]=e>>>24&255,n[i++]=0,n[i++]=0,n[i++]=0,n[i++]=0;for(var s=8;s<this.padLength;s++)n[i++]=0}return n}},{"../hash":187}],189:[function(e,t,r){function n(e,t,r){return this instanceof n?(this.Hash=e,this.blockSize=e.blockSize/8,this.outSize=e.outSize/8,this.inner=null,this.outer=null,void this._init(s.toArray(t,r))):new n(e,t,r)}var i=e("../hash"),s=i.utils,o=s.assert;t.exports=n,n.prototype._init=function(e){e.length>this.blockSize&&(e=(new this.Hash).update(e).digest()),o(e.length<=this.blockSize);for(var t=e.length;t<this.blockSize;t++)e.push(0);for(var t=0;t<e.length;t++)e[t]^=54;this.inner=(new this.Hash).update(e);for(var t=0;t<e.length;t++)e[t]^=106;this.outer=(new this.Hash).update(e)},n.prototype.update=function(e,t){return this.inner.update(e,t),this},n.prototype.digest=function(e){return this.outer.update(this.inner.digest()),this.outer.digest(e)}},{"../hash":187}],190:[function(e,t,r){function n(){return this instanceof n?(p.call(this),this.h=[1732584193,4023233417,2562383102,271733878,3285377520],void(this.endian="little")):new n}function i(e,t,r,n){return 15>=e?t^r^n:31>=e?t&r|~t&n:47>=e?(t|~r)^n:63>=e?t&n|r&~n:t^(r|~n)}function s(e){return 15>=e?0:31>=e?1518500249:47>=e?1859775393:63>=e?2400959708:2840853838}function o(e){return 15>=e?1352829926:31>=e?1548603684:47>=e?1836072691:63>=e?2053994217:0}var a=e("../hash"),f=a.utils,c=f.rotl32,u=f.sum32,h=f.sum32_3,d=f.sum32_4,p=a.common.BlockHash;f.inherits(n,p),r.ripemd160=n,n.blockSize=512,n.outSize=160,n.hmacStrength=192,n.padLength=64,n.prototype._update=function(e,t){for(var r=this.h[0],n=this.h[1],a=this.h[2],f=this.h[3],p=this.h[4],y=r,v=n,_=a,w=f,S=p,k=0;80>k;k++){var E=u(c(d(r,i(k,n,a,f),e[l[k]+t],s(k)),g[k]),p);r=p,p=f,f=c(a,10),a=n,n=E,E=u(c(d(y,i(79-k,v,_,w),e[b[k]+t],o(k)),m[k]),S),y=S,S=w,w=c(_,10),_=v,v=E}E=h(this.h[1],a,w),this.h[1]=h(this.h[2],f,S),this.h[2]=h(this.h[3],p,y),this.h[3]=h(this.h[4],r,v),this.h[4]=h(this.h[0],n,_),this.h[0]=E},n.prototype._digest=function(e){return"hex"===e?f.toHex32(this.h,"little"):f.split32(this.h,"little")};var l=[0,1,2,3,4,5,6,7,8,9,10,11,12,13,14,15,7,4,13,1,10,6,15,3,12,0,9,5,2,14,11,8,3,10,14,4,9,15,8,1,2,7,0,6,13,11,5,12,1,9,11,10,0,8,12,4,13,3,7,15,14,5,6,2,4,0,5,9,7,12,2,10,14,1,3,8,11,6,15,13],b=[5,14,7,0,9,2,11,4,13,6,15,8,1,10,3,12,6,11,3,7,0,13,5,10,14,15,8,12,4,9,1,2,15,5,1,3,7,14,6,9,11,8,12,2,10,0,4,13,8,6,4,1,3,11,15,0,5,12,2,13,9,7,10,14,12,15,10,4,1,5,8,7,6,2,13,14,0,3,9,11],g=[11,14,15,12,5,8,7,9,11,13,14,15,6,7,9,8,7,6,8,13,11,9,7,15,7,12,15,9,11,7,13,12,11,13,6,7,14,9,13,15,14,8,13,6,5,12,7,5,11,12,14,15,14,15,9,8,9,14,5,6,8,6,5,12,9,15,5,11,6,8,13,12,5,12,13,14,11,8,5,6],m=[8,9,9,11,13,15,15,5,7,7,8,11,14,14,12,6,9,13,15,7,12,8,9,11,7,7,12,7,6,15,13,11,9,7,15,11,8,6,6,14,12,13,5,14,13,13,7,5,15,5,8,11,14,14,6,14,6,9,12,9,12,5,15,8,8,5,12,9,12,5,14,6,8,13,6,5,15,13,11,11]},{"../hash":187}],191:[function(e,t,r){function n(){return this instanceof n?(Y.call(this),this.h=[1779033703,3144134277,1013904242,2773480762,1359893119,2600822924,528734635,1541459225],this.k=G,void(this.W=new Array(64))):new n}function i(){return this instanceof i?(n.call(this),void(this.h=[3238371032,914150663,812702999,4144912697,4290775857,1750603025,1694076839,3204075428])):new i}function s(){return this instanceof s?(Y.call(this),this.h=[1779033703,4089235720,3144134277,2227873595,1013904242,4271175723,2773480762,1595750129,1359893119,2917565137,2600822924,725511199,528734635,4215389547,1541459225,327033209],this.k=W,void(this.W=new Array(160))):new s}function o(){return this instanceof o?(s.call(this),void(this.h=[3418070365,3238371032,1654270250,914150663,2438529370,812702999,355462360,4144912697,1731405415,4290775857,2394180231,1750603025,3675008525,1694076839,1203062813,3204075428])):new o}function a(){return this instanceof a?(Y.call(this),this.h=[1732584193,4023233417,2562383102,271733878,3285377520],void(this.W=new Array(80))):new a}function f(e,t,r){return e&t^~e&r}function c(e,t,r){return e&t^e&r^t&r}function u(e,t,r){return e^t^r}function h(e){return R(e,2)^R(e,13)^R(e,22)}function d(e){return R(e,6)^R(e,11)^R(e,25)}function p(e){return R(e,7)^R(e,18)^e>>>3}function l(e){return R(e,17)^R(e,19)^e>>>10}function b(e,t,r,n){return 0===e?f(t,r,n):1===e||3===e?u(t,r,n):2===e?c(t,r,n):void 0}function g(e,t,r,n,i,s){var o=e&r^~e&i;return 0>o&&(o+=4294967296),o}function m(e,t,r,n,i,s){var o=t&n^~t&s;return 0>o&&(o+=4294967296),o}function y(e,t,r,n,i,s){var o=e&r^e&i^r&i;return 0>o&&(o+=4294967296),o}function v(e,t,r,n,i,s){var o=t&n^t&s^n&s;return 0>o&&(o+=4294967296),o}function _(e,t){var r=U(e,t,28),n=U(t,e,2),i=U(t,e,7),s=r^n^i;return 0>s&&(s+=4294967296),s}function w(e,t){var r=M(e,t,28),n=M(t,e,2),i=M(t,e,7),s=r^n^i;return 0>s&&(s+=4294967296),s}function S(e,t){var r=U(e,t,14),n=U(e,t,18),i=U(t,e,9),s=r^n^i;return 0>s&&(s+=4294967296),s}function k(e,t){var r=M(e,t,14),n=M(e,t,18),i=M(t,e,9),s=r^n^i;return 0>s&&(s+=4294967296),s}function E(e,t){var r=U(e,t,1),n=U(e,t,8),i=L(e,t,7),s=r^n^i;return 0>s&&(s+=4294967296),s}function I(e,t){var r=M(e,t,1),n=M(e,t,8),i=D(e,t,7),s=r^n^i;return 0>s&&(s+=4294967296),s}function A(e,t){var r=U(e,t,19),n=U(t,e,29),i=L(e,t,6),s=r^n^i;return 0>s&&(s+=4294967296),s}function O(e,t){var r=M(e,t,19),n=M(t,e,29),i=D(e,t,6),s=r^n^i;return 0>s&&(s+=4294967296),s}var P=e("../hash"),B=P.utils,x=B.assert,R=B.rotr32,T=B.rotl32,N=B.sum32,C=B.sum32_4,j=B.sum32_5,U=B.rotr64_hi,M=B.rotr64_lo,L=B.shr64_hi,D=B.shr64_lo,H=B.sum64,F=B.sum64_hi,K=B.sum64_lo,z=B.sum64_4_hi,V=B.sum64_4_lo,q=B.sum64_5_hi,J=B.sum64_5_lo,Y=P.common.BlockHash,G=[1116352408,1899447441,3049323471,3921009573,961987163,1508970993,2453635748,2870763221,3624381080,310598401,607225278,1426881987,1925078388,2162078206,2614888103,3248222580,3835390401,4022224774,264347078,604807628,770255983,1249150122,1555081692,1996064986,2554220882,2821834349,2952996808,3210313671,3336571891,3584528711,113926993,338241895,666307205,773529912,1294757372,1396182291,1695183700,1986661051,2177026350,2456956037,2730485921,2820302411,3259730800,3345764771,3516065817,3600352804,4094571909,275423344,430227734,506948616,659060556,883997877,958139571,1322822218,1537002063,1747873779,1955562222,2024104815,2227730452,2361852424,2428436474,2756734187,3204031479,3329325298],W=[1116352408,3609767458,1899447441,602891725,3049323471,3964484399,3921009573,2173295548,961987163,4081628472,1508970993,3053834265,2453635748,2937671579,2870763221,3664609560,3624381080,2734883394,310598401,1164996542,607225278,1323610764,1426881987,3590304994,1925078388,4068182383,2162078206,991336113,2614888103,633803317,3248222580,3479774868,3835390401,2666613458,4022224774,944711139,264347078,2341262773,604807628,2007800933,770255983,1495990901,1249150122,1856431235,1555081692,3175218132,1996064986,2198950837,2554220882,3999719339,2821834349,766784016,2952996808,2566594879,3210313671,3203337956,3336571891,1034457026,3584528711,2466948901,113926993,3758326383,338241895,168717936,666307205,1188179964,773529912,1546045734,1294757372,1522805485,1396182291,2643833823,1695183700,2343527390,1986661051,1014477480,2177026350,1206759142,2456956037,344077627,2730485921,1290863460,2820302411,3158454273,3259730800,3505952657,3345764771,106217008,3516065817,3606008344,3600352804,1432725776,4094571909,1467031594,275423344,851169720,430227734,3100823752,506948616,1363258195,659060556,3750685593,883997877,3785050280,958139571,3318307427,1322822218,3812723403,1537002063,2003034995,1747873779,3602036899,1955562222,1575990012,2024104815,1125592928,2227730452,2716904306,2361852424,442776044,2428436474,593698344,2756734187,3733110249,3204031479,2999351573,3329325298,3815920427,3391569614,3928383900,3515267271,566280711,3940187606,3454069534,4118630271,4000239992,116418474,1914138554,174292421,2731055270,289380356,3203993006,460393269,320620315,685471733,587496836,852142971,1086792851,1017036298,365543100,1126000580,2618297676,1288033470,3409855158,1501505948,4234509866,1607167915,987167468,1816402316,1246189591],X=[1518500249,1859775393,2400959708,3395469782];
B.inherits(n,Y),r.sha256=n,n.blockSize=512,n.outSize=256,n.hmacStrength=192,n.padLength=64,n.prototype._update=function(e,t){for(var r=this.W,n=0;16>n;n++)r[n]=e[t+n];for(;n<r.length;n++)r[n]=C(l(r[n-2]),r[n-7],p(r[n-15]),r[n-16]);var i=this.h[0],s=this.h[1],o=this.h[2],a=this.h[3],u=this.h[4],b=this.h[5],g=this.h[6],m=this.h[7];x(this.k.length===r.length);for(var n=0;n<r.length;n++){var y=j(m,d(u),f(u,b,g),this.k[n],r[n]),v=N(h(i),c(i,s,o));m=g,g=b,b=u,u=N(a,y),a=o,o=s,s=i,i=N(y,v)}this.h[0]=N(this.h[0],i),this.h[1]=N(this.h[1],s),this.h[2]=N(this.h[2],o),this.h[3]=N(this.h[3],a),this.h[4]=N(this.h[4],u),this.h[5]=N(this.h[5],b),this.h[6]=N(this.h[6],g),this.h[7]=N(this.h[7],m)},n.prototype._digest=function(e){return"hex"===e?B.toHex32(this.h,"big"):B.split32(this.h,"big")},B.inherits(i,n),r.sha224=i,i.blockSize=512,i.outSize=224,i.hmacStrength=192,i.padLength=64,i.prototype._digest=function(e){return"hex"===e?B.toHex32(this.h.slice(0,7),"big"):B.split32(this.h.slice(0,7),"big")},B.inherits(s,Y),r.sha512=s,s.blockSize=1024,s.outSize=512,s.hmacStrength=192,s.padLength=128,s.prototype._prepareBlock=function(e,t){for(var r=this.W,n=0;32>n;n++)r[n]=e[t+n];for(;n<r.length;n+=2){var i=A(r[n-4],r[n-3]),s=O(r[n-4],r[n-3]),o=r[n-14],a=r[n-13],f=E(r[n-30],r[n-29]),c=I(r[n-30],r[n-29]),u=r[n-32],h=r[n-31];r[n]=z(i,s,o,a,f,c,u,h),r[n+1]=V(i,s,o,a,f,c,u,h)}},s.prototype._update=function(e,t){this._prepareBlock(e,t);var r=this.W,n=this.h[0],i=this.h[1],s=this.h[2],o=this.h[3],a=this.h[4],f=this.h[5],c=this.h[6],u=this.h[7],h=this.h[8],d=this.h[9],p=this.h[10],l=this.h[11],b=this.h[12],E=this.h[13],I=this.h[14],A=this.h[15];x(this.k.length===r.length);for(var O=0;O<r.length;O+=2){var P=I,B=A,R=S(h,d),T=k(h,d),N=g(h,d,p,l,b,E),C=m(h,d,p,l,b,E),j=this.k[O],U=this.k[O+1],M=r[O],L=r[O+1],D=q(P,B,R,T,N,C,j,U,M,L),z=J(P,B,R,T,N,C,j,U,M,L),P=_(n,i),B=w(n,i),R=y(n,i,s,o,a,f),T=v(n,i,s,o,a,f),V=F(P,B,R,T),Y=K(P,B,R,T);I=b,A=E,b=p,E=l,p=h,l=d,h=F(c,u,D,z),d=K(u,u,D,z),c=a,u=f,a=s,f=o,s=n,o=i,n=F(D,z,V,Y),i=K(D,z,V,Y)}H(this.h,0,n,i),H(this.h,2,s,o),H(this.h,4,a,f),H(this.h,6,c,u),H(this.h,8,h,d),H(this.h,10,p,l),H(this.h,12,b,E),H(this.h,14,I,A)},s.prototype._digest=function(e){return"hex"===e?B.toHex32(this.h,"big"):B.split32(this.h,"big")},B.inherits(o,s),r.sha384=o,o.blockSize=1024,o.outSize=384,o.hmacStrength=192,o.padLength=128,o.prototype._digest=function(e){return"hex"===e?B.toHex32(this.h.slice(0,12),"big"):B.split32(this.h.slice(0,12),"big")},B.inherits(a,Y),r.sha1=a,a.blockSize=512,a.outSize=160,a.hmacStrength=80,a.padLength=64,a.prototype._update=function(e,t){for(var r=this.W,n=0;16>n;n++)r[n]=e[t+n];for(;n<r.length;n++)r[n]=T(r[n-3]^r[n-8]^r[n-14]^r[n-16],1);for(var i=this.h[0],s=this.h[1],o=this.h[2],a=this.h[3],f=this.h[4],n=0;n<r.length;n++){var c=~~(n/20),u=j(T(i,5),b(c,s,o,a),f,r[n],X[c]);f=a,a=o,o=T(s,30),s=i,i=u}this.h[0]=N(this.h[0],i),this.h[1]=N(this.h[1],s),this.h[2]=N(this.h[2],o),this.h[3]=N(this.h[3],a),this.h[4]=N(this.h[4],f)},a.prototype._digest=function(e){return"hex"===e?B.toHex32(this.h,"big"):B.split32(this.h,"big")}},{"../hash":187}],192:[function(e,t,r){function n(e,t){if(Array.isArray(e))return e.slice();if(!e)return[];var r=[];if("string"==typeof e)if(t){if("hex"===t){e=e.replace(/[^a-z0-9]+/gi,""),e.length%2!==0&&(e="0"+e);for(var n=0;n<e.length;n+=2)r.push(parseInt(e[n]+e[n+1],16))}}else for(var n=0;n<e.length;n++){var i=e.charCodeAt(n),s=i>>8,o=255&i;s?r.push(s,o):r.push(o)}else for(var n=0;n<e.length;n++)r[n]=0|e[n];return r}function i(e){for(var t="",r=0;r<e.length;r++)t+=a(e[r].toString(16));return t}function s(e){var t=e>>>24|e>>>8&65280|e<<8&16711680|(255&e)<<24;return t>>>0}function o(e,t){for(var r="",n=0;n<e.length;n++){var i=e[n];"little"===t&&(i=s(i)),r+=f(i.toString(16))}return r}function a(e){return 1===e.length?"0"+e:e}function f(e){return 7===e.length?"0"+e:6===e.length?"00"+e:5===e.length?"000"+e:4===e.length?"0000"+e:3===e.length?"00000"+e:2===e.length?"000000"+e:1===e.length?"0000000"+e:e}function c(e,t,r,n){var i=r-t;m(i%4===0);for(var s=new Array(i/4),o=0,a=t;o<s.length;o++,a+=4){var f;f="big"===n?e[a]<<24|e[a+1]<<16|e[a+2]<<8|e[a+3]:e[a+3]<<24|e[a+2]<<16|e[a+1]<<8|e[a],s[o]=f>>>0}return s}function u(e,t){for(var r=new Array(4*e.length),n=0,i=0;n<e.length;n++,i+=4){var s=e[n];"big"===t?(r[i]=s>>>24,r[i+1]=s>>>16&255,r[i+2]=s>>>8&255,r[i+3]=255&s):(r[i+3]=s>>>24,r[i+2]=s>>>16&255,r[i+1]=s>>>8&255,r[i]=255&s)}return r}function h(e,t){return e>>>t|e<<32-t}function d(e,t){return e<<t|e>>>32-t}function p(e,t){return e+t>>>0}function l(e,t,r){return e+t+r>>>0}function b(e,t,r,n){return e+t+r+n>>>0}function g(e,t,r,n,i){return e+t+r+n+i>>>0}function m(e,t){if(!e)throw new Error(t||"Assertion failed")}function y(e,t,r,n){var i=e[t],s=e[t+1],o=n+s>>>0,a=(n>o?1:0)+r+i;e[t]=a>>>0,e[t+1]=o}function v(e,t,r,n){var i=t+n>>>0,s=(t>i?1:0)+e+r;return s>>>0}function _(e,t,r,n){var i=t+n;return i>>>0}function w(e,t,r,n,i,s,o,a){var f=0,c=t;c=c+n>>>0,f+=t>c?1:0,c=c+s>>>0,f+=s>c?1:0,c=c+a>>>0,f+=a>c?1:0;var u=e+r+i+o+f;return u>>>0}function S(e,t,r,n,i,s,o,a){var f=t+n+s+a;return f>>>0}function k(e,t,r,n,i,s,o,a,f,c){var u=0,h=t;h=h+n>>>0,u+=t>h?1:0,h=h+s>>>0,u+=s>h?1:0,h=h+a>>>0,u+=a>h?1:0,h=h+c>>>0,u+=c>h?1:0;var d=e+r+i+o+f+u;return d>>>0}function E(e,t,r,n,i,s,o,a,f,c){var u=t+n+s+a+c;return u>>>0}function I(e,t,r){var n=t<<32-r|e>>>r;return n>>>0}function A(e,t,r){var n=e<<32-r|t>>>r;return n>>>0}function O(e,t,r){return e>>>r}function P(e,t,r){var n=e<<32-r|t>>>r;return n>>>0}var B=r,x=e("inherits");B.toArray=n,B.toHex=i,B.htonl=s,B.toHex32=o,B.zero2=a,B.zero8=f,B.join32=c,B.split32=u,B.rotr32=h,B.rotl32=d,B.sum32=p,B.sum32_3=l,B.sum32_4=b,B.sum32_5=g,B.assert=m,B.inherits=x,r.sum64=y,r.sum64_hi=v,r.sum64_lo=_,r.sum64_4_hi=w,r.sum64_4_lo=S,r.sum64_5_hi=k,r.sum64_5_lo=E,r.rotr64_hi=I,r.rotr64_lo=A,r.shr64_hi=O,r.shr64_lo=P},{inherits:193}],193:[function(e,t,r){t.exports="function"==typeof Object.create?function(e,t){e.super_=t,e.prototype=Object.create(t.prototype,{constructor:{value:e,enumerable:!1,writable:!0,configurable:!0}})}:function(e,t){e.super_=t;var r=function(){};r.prototype=t.prototype,e.prototype=new r,e.prototype.constructor=e}},{}],194:[function(e,t,r){(function(e){(function(){function n(e,t,r){for(var n=(r||0)-1,i=e?e.length:0;++n<i;)if(e[n]===t)return n;return-1}function i(e,t){var r=typeof t;if(e=e.cache,"boolean"==r||null==t)return e[t]?0:-1;"number"!=r&&"string"!=r&&(r="object");var i="number"==r?t:_+t;return e=(e=e[r])&&e[i],"object"==r?e&&n(e,t)>-1?0:-1:e?0:-1}function s(e){var t=this.cache,r=typeof e;if("boolean"==r||null==e)t[e]=!0;else{"number"!=r&&"string"!=r&&(r="object");var n="number"==r?e:_+e,i=t[r]||(t[r]={});"object"==r?(i[n]||(i[n]=[])).push(e):i[n]=!0}}function o(e){return e.charCodeAt(0)}function a(e,t){for(var r=e.criteria,n=t.criteria,i=-1,s=r.length;++i<s;){var o=r[i],a=n[i];if(o!==a){if(o>a||"undefined"==typeof o)return 1;if(a>o||"undefined"==typeof a)return-1}}return e.index-t.index}function f(e){var t=-1,r=e.length,n=e[0],i=e[r/2|0],o=e[r-1];if(n&&"object"==typeof n&&i&&"object"==typeof i&&o&&"object"==typeof o)return!1;var a=h();a["false"]=a["null"]=a["true"]=a.undefined=!1;var f=h();for(f.array=e,f.cache=a,f.push=s;++t<r;)f.push(e[t]);return f}function c(e){return"\\"+X[e]}function u(){return m.pop()||[]}function h(){return y.pop()||{array:null,cache:null,criteria:null,"false":!1,index:0,"null":!1,number:null,object:null,push:null,string:null,"true":!1,undefined:!1,value:null}}function d(e){e.length=0,m.length<S&&m.push(e)}function p(e){var t=e.cache;t&&p(t),e.array=e.cache=e.criteria=e.object=e.number=e.string=e.value=null,y.length<S&&y.push(e)}function l(e,t,r){t||(t=0),"undefined"==typeof r&&(r=e?e.length:0);for(var n=-1,i=r-t||0,s=Array(0>i?0:i);++n<i;)s[n]=e[t+n];return s}function b(e){function t(e){return e&&"object"==typeof e&&!Zr(e)&&Nr.call(e,"__wrapped__")?e:new r(e)}function r(e,t){this.__chain__=!!t,this.__wrapped__=e}function s(e){function t(){if(n){var e=l(n);Cr.apply(e,arguments)}if(this instanceof t){var s=y(r.prototype),o=r.apply(s,e||arguments);return xe(o)?o:s}return r.apply(i,e||arguments)}var r=e[0],n=e[2],i=e[4];return Xr(t,e),t}function m(e,t,r,n,i){if(r){var s=r(e);if("undefined"!=typeof s)return s}var o=xe(e);if(!o)return e;var a=Ar.call(e);if(!J[a])return e;var f=Gr[a];switch(a){case D:case H:return new f(+e);case K:case q:return new f(e);case V:return s=f(e.source,P.exec(e)),s.lastIndex=e.lastIndex,s}var c=Zr(e);if(t){var h=!n;n||(n=u()),i||(i=u());for(var p=n.length;p--;)if(n[p]==e)return i[p];s=c?f(e.length):{}}else s=c?l(e):sn({},e);return c&&(Nr.call(e,"index")&&(s.index=e.index),Nr.call(e,"input")&&(s.input=e.input)),t?(n.push(e),i.push(s),(c?Xe:fn)(e,function(e,o){s[o]=m(e,t,r,n,i)}),h&&(d(n),d(i)),s):s}function y(e,t){return xe(e)?Dr(e):{}}function S(e,t,r){if("function"!=typeof e)return Zt;if("undefined"==typeof t||!("prototype"in e))return e;var n=e.__bindData__;if("undefined"==typeof n&&(Wr.funcNames&&(n=!e.name),n=n||!Wr.funcDecomp,!n)){var i=Rr.call(e);Wr.funcNames||(n=!B.test(i)),n||(n=N.test(i),Xr(e,n))}if(n===!1||n!==!0&&1&n[1])return e;switch(r){case 1:return function(r){return e.call(t,r)};case 2:return function(r,n){return e.call(t,r,n)};case 3:return function(r,n,i){return e.call(t,r,n,i)};case 4:return function(r,n,i,s){return e.call(t,r,n,i,s)}}return Ct(e,t)}function X(e){function t(){var e=f?o:this;if(i){var p=l(i);Cr.apply(p,arguments)}if((s||u)&&(p||(p=l(arguments)),s&&Cr.apply(p,s),u&&p.length<a))return n|=16,X([r,h?n:-4&n,p,null,o,a]);if(p||(p=arguments),c&&(r=e[d]),this instanceof t){e=y(r.prototype);var b=r.apply(e,p);return xe(b)?b:e}return r.apply(e,p)}var r=e[0],n=e[1],i=e[2],s=e[3],o=e[4],a=e[5],f=1&n,c=2&n,u=4&n,h=8&n,d=r;return Xr(t,e),t}function Q(e,t){var r=-1,s=fe(),o=e?e.length:0,a=o>=w&&s===n,c=[];if(a){var u=f(t);u?(s=i,t=u):a=!1}for(;++r<o;){var h=e[r];s(t,h)<0&&c.push(h)}return a&&p(t),c}function $(e,t,r,n){for(var i=(n||0)-1,s=e?e.length:0,o=[];++i<s;){var a=e[i];if(a&&"object"==typeof a&&"number"==typeof a.length&&(Zr(a)||de(a))){t||(a=$(a,t,r));var f=-1,c=a.length,u=o.length;for(o.length+=c;++f<c;)o[u++]=a[f]}else r||o.push(a)}return o}function ee(e,t,r,n,i,s){if(r){var o=r(e,t);if("undefined"!=typeof o)return!!o}if(e===t)return 0!==e||1/e==1/t;var a=typeof e,f=typeof t;if(!(e!==e||e&&W[a]||t&&W[f]))return!1;if(null==e||null==t)return e===t;var c=Ar.call(e),h=Ar.call(t);if(c==M&&(c=z),h==M&&(h=z),c!=h)return!1;switch(c){case D:case H:return+e==+t;case K:return e!=+e?t!=+t:0==e?1/e==1/t:e==+t;case V:case q:return e==wr(t)}var p=c==L;if(!p){var l=Nr.call(e,"__wrapped__"),b=Nr.call(t,"__wrapped__");if(l||b)return ee(l?e.__wrapped__:e,b?t.__wrapped__:t,r,n,i,s);if(c!=z)return!1;var g=e.constructor,m=t.constructor;if(g!=m&&!(Be(g)&&g instanceof g&&Be(m)&&m instanceof m)&&"constructor"in e&&"constructor"in t)return!1}var y=!i;i||(i=u()),s||(s=u());for(var v=i.length;v--;)if(i[v]==e)return s[v]==t;var _=0;if(o=!0,i.push(e),s.push(t),p){if(v=e.length,_=t.length,o=_==v,o||n)for(;_--;){var w=v,S=t[_];if(n)for(;w--&&!(o=ee(e[w],S,r,n,i,s)););else if(!(o=ee(e[_],S,r,n,i,s)))break}}else an(t,function(t,a,f){return Nr.call(f,a)?(_++,o=Nr.call(e,a)&&ee(e[a],t,r,n,i,s)):void 0}),o&&!n&&an(e,function(e,t,r){return Nr.call(r,t)?o=--_>-1:void 0});return i.pop(),s.pop(),y&&(d(i),d(s)),o}function te(e,t,r,n,i){(Zr(t)?Xe:fn)(t,function(t,s){var o,a,f=t,c=e[s];if(t&&((a=Zr(t))||cn(t))){for(var u=n.length;u--;)if(o=n[u]==t){c=i[u];break}if(!o){var h;r&&(f=r(c,t),(h="undefined"!=typeof f)&&(c=f)),h||(c=a?Zr(c)?c:[]:cn(c)?c:{}),n.push(t),i.push(c),h||te(c,t,r,n,i)}}else r&&(f=r(c,t),"undefined"==typeof f&&(f=t)),"undefined"!=typeof f&&(c=f);e[s]=c})}function ne(e,t){return e+xr(Yr()*(t-e+1))}function ie(e,t,r){var s=-1,o=fe(),a=e?e.length:0,c=[],h=!t&&a>=w&&o===n,l=r||h?u():c;if(h){var b=f(l);o=i,l=b}for(;++s<a;){var g=e[s],m=r?r(g,s,e):g;(t?!s||l[l.length-1]!==m:o(l,m)<0)&&((r||h)&&l.push(m),c.push(g))}return h?(d(l.array),p(l)):r&&d(l),c}function se(e){return function(r,n,i){var s={};n=t.createCallback(n,i,3);var o=-1,a=r?r.length:0;if("number"==typeof a)for(;++o<a;){var f=r[o];e(s,f,n(f,o,r),r)}else fn(r,function(t,r,i){e(s,t,n(t,r,i),i)});return s}}function oe(e,t,r,n,i,o){var a=1&t,f=2&t,c=4&t,u=16&t,h=32&t;if(!f&&!Be(e))throw new Sr;u&&!r.length&&(t&=-17,u=r=!1),h&&!n.length&&(t&=-33,h=n=!1);var d=e&&e.__bindData__;if(d&&d!==!0)return d=l(d),d[2]&&(d[2]=l(d[2])),d[3]&&(d[3]=l(d[3])),!a||1&d[1]||(d[4]=i),!a&&1&d[1]&&(t|=8),!c||4&d[1]||(d[5]=o),u&&Cr.apply(d[2]||(d[2]=[]),r),h&&Mr.apply(d[3]||(d[3]=[]),n),d[1]|=t,oe.apply(null,d);var p=1==t||17===t?s:X;return p([e,t,r,n,i,o])}function ae(e){return en[e]}function fe(){var e=(e=t.indexOf)===mt?n:e;return e}function ce(e){return"function"==typeof e&&Or.test(e)}function ue(e){var t,r;return e&&Ar.call(e)==z&&(t=e.constructor,!Be(t)||t instanceof t)?(an(e,function(e,t){r=t}),"undefined"==typeof r||Nr.call(e,r)):!1}function he(e){return tn[e]}function de(e){return e&&"object"==typeof e&&"number"==typeof e.length&&Ar.call(e)==M||!1}function pe(e,t,r,n){return"boolean"!=typeof t&&null!=t&&(n=r,r=t,t=!1),m(e,t,"function"==typeof r&&S(r,n,1))}function le(e,t,r){return m(e,!0,"function"==typeof t&&S(t,r,1))}function be(e,t){var r=y(e);return t?sn(r,t):r}function ge(e,r,n){var i;return r=t.createCallback(r,n,3),fn(e,function(e,t,n){return r(e,t,n)?(i=t,!1):void 0}),i}function me(e,r,n){var i;return r=t.createCallback(r,n,3),ve(e,function(e,t,n){return r(e,t,n)?(i=t,!1):void 0}),i}function ye(e,t,r){var n=[];an(e,function(e,t){n.push(t,e)});var i=n.length;for(t=S(t,r,3);i--&&t(n[i--],n[i],e)!==!1;);return e}function ve(e,t,r){var n=$r(e),i=n.length;for(t=S(t,r,3);i--;){var s=n[i];if(t(e[s],s,e)===!1)break}return e}function _e(e){var t=[];return an(e,function(e,r){Be(e)&&t.push(r)}),t.sort()}function we(e,t){return e?Nr.call(e,t):!1}function Se(e){for(var t=-1,r=$r(e),n=r.length,i={};++t<n;){var s=r[t];i[e[s]]=s}return i}function ke(e){return e===!0||e===!1||e&&"object"==typeof e&&Ar.call(e)==D||!1}function Ee(e){return e&&"object"==typeof e&&Ar.call(e)==H||!1}function Ie(e){return e&&1===e.nodeType||!1}function Ae(e){var t=!0;if(!e)return t;var r=Ar.call(e),n=e.length;return r==L||r==q||r==M||r==z&&"number"==typeof n&&Be(e.splice)?!n:(fn(e,function(){return t=!1}),t)}function Oe(e,t,r,n){return ee(e,t,"function"==typeof r&&S(r,n,2))}function Pe(e){return Fr(e)&&!Kr(parseFloat(e))}function Be(e){return"function"==typeof e}function xe(e){return!(!e||!W[typeof e])}function Re(e){return Ne(e)&&e!=+e}function Te(e){return null===e}function Ne(e){return"number"==typeof e||e&&"object"==typeof e&&Ar.call(e)==K||!1}function Ce(e){return e&&"object"==typeof e&&Ar.call(e)==V||!1}function je(e){return"string"==typeof e||e&&"object"==typeof e&&Ar.call(e)==q||!1}function Ue(e){return"undefined"==typeof e}function Me(e,r,n){var i={};return r=t.createCallback(r,n,3),fn(e,function(e,t,n){i[t]=r(e,t,n)}),i}function Le(e){var t=arguments,r=2;if(!xe(e))return e;if("number"!=typeof t[2]&&(r=t.length),r>3&&"function"==typeof t[r-2])var n=S(t[--r-1],t[r--],2);else r>2&&"function"==typeof t[r-1]&&(n=t[--r]);for(var i=l(arguments,1,r),s=-1,o=u(),a=u();++s<r;)te(e,i[s],n,o,a);return d(o),d(a),e}function De(e,r,n){var i={};if("function"!=typeof r){var s=[];an(e,function(e,t){s.push(t)}),s=Q(s,$(arguments,!0,!1,1));for(var o=-1,a=s.length;++o<a;){var f=s[o];i[f]=e[f]}}else r=t.createCallback(r,n,3),an(e,function(e,t,n){r(e,t,n)||(i[t]=e)});return i}function He(e){for(var t=-1,r=$r(e),n=r.length,i=pr(n);++t<n;){var s=r[t];i[t]=[s,e[s]]}return i}function Fe(e,r,n){var i={};if("function"!=typeof r)for(var s=-1,o=$(arguments,!0,!1,1),a=xe(e)?o.length:0;++s<a;){var f=o[s];f in e&&(i[f]=e[f])}else r=t.createCallback(r,n,3),an(e,function(e,t,n){r(e,t,n)&&(i[t]=e)});return i}function Ke(e,r,n,i){var s=Zr(e);if(null==n)if(s)n=[];else{var o=e&&e.constructor,a=o&&o.prototype;n=y(a)}return r&&(r=t.createCallback(r,i,4),(s?Xe:fn)(e,function(e,t,i){return r(n,e,t,i)})),n}function ze(e){for(var t=-1,r=$r(e),n=r.length,i=pr(n);++t<n;)i[t]=e[r[t]];return i}function Ve(e){for(var t=arguments,r=-1,n=$(t,!0,!1,1),i=t[2]&&t[2][t[1]]===e?1:n.length,s=pr(i);++r<i;)s[r]=e[n[r]];return s}function qe(e,t,r){var n=-1,i=fe(),s=e?e.length:0,o=!1;return r=(0>r?Vr(0,s+r):r)||0,Zr(e)?o=i(e,t,r)>-1:"number"==typeof s?o=(je(e)?e.indexOf(t,r):i(e,t,r))>-1:fn(e,function(e){return++n>=r?!(o=e===t):void 0}),o}function Je(e,r,n){var i=!0;r=t.createCallback(r,n,3);var s=-1,o=e?e.length:0;if("number"==typeof o)for(;++s<o&&(i=!!r(e[s],s,e)););else fn(e,function(e,t,n){return i=!!r(e,t,n)});return i}function Ye(e,r,n){var i=[];r=t.createCallback(r,n,3);var s=-1,o=e?e.length:0;if("number"==typeof o)for(;++s<o;){var a=e[s];r(a,s,e)&&i.push(a)}else fn(e,function(e,t,n){r(e,t,n)&&i.push(e)});return i}function Ge(e,r,n){r=t.createCallback(r,n,3);var i=-1,s=e?e.length:0;if("number"!=typeof s){var o;return fn(e,function(e,t,n){return r(e,t,n)?(o=e,!1):void 0}),o}for(;++i<s;){var a=e[i];if(r(a,i,e))return a}}function We(e,r,n){var i;return r=t.createCallback(r,n,3),Ze(e,function(e,t,n){return r(e,t,n)?(i=e,!1):void 0}),i}function Xe(e,t,r){var n=-1,i=e?e.length:0;if(t=t&&"undefined"==typeof r?t:S(t,r,3),"number"==typeof i)for(;++n<i&&t(e[n],n,e)!==!1;);else fn(e,t);return e}function Ze(e,t,r){var n=e?e.length:0;if(t=t&&"undefined"==typeof r?t:S(t,r,3),"number"==typeof n)for(;n--&&t(e[n],n,e)!==!1;);else{var i=$r(e);n=i.length,fn(e,function(e,r,s){return r=i?i[--n]:--n,t(s[r],r,s)})}return e}function Qe(e,t){var r=l(arguments,2),n=-1,i="function"==typeof t,s=e?e.length:0,o=pr("number"==typeof s?s:0);return Xe(e,function(e){o[++n]=(i?t:e[t]).apply(e,r)}),o}function $e(e,r,n){var i=-1,s=e?e.length:0;if(r=t.createCallback(r,n,3),"number"==typeof s)for(var o=pr(s);++i<s;)o[i]=r(e[i],i,e);else o=[],fn(e,function(e,t,n){o[++i]=r(e,t,n)});return o}function et(e,r,n){var i=-(1/0),s=i;if("function"!=typeof r&&n&&n[r]===e&&(r=null),null==r&&Zr(e))for(var a=-1,f=e.length;++a<f;){var c=e[a];c>s&&(s=c)}else r=null==r&&je(e)?o:t.createCallback(r,n,3),Xe(e,function(e,t,n){var o=r(e,t,n);o>i&&(i=o,s=e)});return s}function tt(e,r,n){var i=1/0,s=i;if("function"!=typeof r&&n&&n[r]===e&&(r=null),null==r&&Zr(e))for(var a=-1,f=e.length;++a<f;){var c=e[a];s>c&&(s=c)}else r=null==r&&je(e)?o:t.createCallback(r,n,3),Xe(e,function(e,t,n){var o=r(e,t,n);i>o&&(i=o,s=e)});return s}function rt(e,r,n,i){if(!e)return n;var s=arguments.length<3;r=t.createCallback(r,i,4);var o=-1,a=e.length;if("number"==typeof a)for(s&&(n=e[++o]);++o<a;)n=r(n,e[o],o,e);else fn(e,function(e,t,i){n=s?(s=!1,e):r(n,e,t,i)});return n}function nt(e,r,n,i){var s=arguments.length<3;return r=t.createCallback(r,i,4),Ze(e,function(e,t,i){n=s?(s=!1,e):r(n,e,t,i)}),n}function it(e,r,n){return r=t.createCallback(r,n,3),Ye(e,function(e,t,n){return!r(e,t,n)})}function st(e,t,r){if(e&&"number"!=typeof e.length&&(e=ze(e)),null==t||r)return e?e[ne(0,e.length-1)]:g;var n=ot(e);return n.length=qr(Vr(0,t),n.length),n}function ot(e){var t=-1,r=e?e.length:0,n=pr("number"==typeof r?r:0);return Xe(e,function(e){var r=ne(0,++t);n[t]=n[r],n[r]=e}),n}function at(e){var t=e?e.length:0;return"number"==typeof t?t:$r(e).length}function ft(e,r,n){var i;r=t.createCallback(r,n,3);var s=-1,o=e?e.length:0;if("number"==typeof o)for(;++s<o&&!(i=r(e[s],s,e)););else fn(e,function(e,t,n){return!(i=r(e,t,n))});return!!i}function ct(e,r,n){var i=-1,s=Zr(r),o=e?e.length:0,f=pr("number"==typeof o?o:0);for(s||(r=t.createCallback(r,n,3)),Xe(e,function(e,t,n){var o=f[++i]=h();s?o.criteria=$e(r,function(t){return e[t]}):(o.criteria=u())[0]=r(e,t,n),o.index=i,o.value=e}),o=f.length,f.sort(a);o--;){var c=f[o];f[o]=c.value,s||d(c.criteria),p(c)}return f}function ut(e){return e&&"number"==typeof e.length?l(e):ze(e)}function ht(e){for(var t=-1,r=e?e.length:0,n=[];++t<r;){var i=e[t];i&&n.push(i)}return n}function dt(e){return Q(e,$(arguments,!0,!0,1))}function pt(e,r,n){var i=-1,s=e?e.length:0;for(r=t.createCallback(r,n,3);++i<s;)if(r(e[i],i,e))return i;return-1}function lt(e,r,n){var i=e?e.length:0;for(r=t.createCallback(r,n,3);i--;)if(r(e[i],i,e))return i;return-1}function bt(e,r,n){var i=0,s=e?e.length:0;if("number"!=typeof r&&null!=r){var o=-1;for(r=t.createCallback(r,n,3);++o<s&&r(e[o],o,e);)i++}else if(i=r,null==i||n)return e?e[0]:g;return l(e,0,qr(Vr(0,i),s))}function gt(e,t,r,n){return"boolean"!=typeof t&&null!=t&&(n=r,r="function"!=typeof t&&n&&n[t]===e?null:t,t=!1),null!=r&&(e=$e(e,r,n)),$(e,t)}function mt(e,t,r){if("number"==typeof r){var i=e?e.length:0;r=0>r?Vr(0,i+r):r||0}else if(r){var s=At(e,t);return e[s]===t?s:-1}return n(e,t,r)}function yt(e,r,n){var i=0,s=e?e.length:0;if("number"!=typeof r&&null!=r){var o=s;for(r=t.createCallback(r,n,3);o--&&r(e[o],o,e);)i++}else i=null==r||n?1:r||i;return l(e,0,qr(Vr(0,s-i),s))}function vt(){for(var e=[],t=-1,r=arguments.length,s=u(),o=fe(),a=o===n,c=u();++t<r;){var h=arguments[t];(Zr(h)||de(h))&&(e.push(h),s.push(a&&h.length>=w&&f(t?e[t]:c)))}var l=e[0],b=-1,g=l?l.length:0,m=[];e:for(;++b<g;){var y=s[0];if(h=l[b],(y?i(y,h):o(c,h))<0){for(t=r,(y||c).push(h);--t;)if(y=s[t],(y?i(y,h):o(e[t],h))<0)continue e;m.push(h)}}for(;r--;)y=s[r],y&&p(y);return d(s),d(c),m}function _t(e,r,n){var i=0,s=e?e.length:0;if("number"!=typeof r&&null!=r){var o=s;for(r=t.createCallback(r,n,3);o--&&r(e[o],o,e);)i++}else if(i=r,null==i||n)return e?e[s-1]:g;return l(e,Vr(0,s-i))}function wt(e,t,r){var n=e?e.length:0;for("number"==typeof r&&(n=(0>r?Vr(0,n+r):qr(r,n-1))+1);n--;)if(e[n]===t)return n;return-1}function St(e){for(var t=arguments,r=0,n=t.length,i=e?e.length:0;++r<n;)for(var s=-1,o=t[r];++s<i;)e[s]===o&&(Ur.call(e,s--,1),i--);return e}function kt(e,t,r){e=+e||0,r="number"==typeof r?r:+r||1,null==t&&(t=e,e=0);for(var n=-1,i=Vr(0,Pr((t-e)/(r||1))),s=pr(i);++n<i;)s[n]=e,e+=r;return s}function Et(e,r,n){var i=-1,s=e?e.length:0,o=[];for(r=t.createCallback(r,n,3);++i<s;){var a=e[i];r(a,i,e)&&(o.push(a),Ur.call(e,i--,1),s--)}return o}function It(e,r,n){if("number"!=typeof r&&null!=r){var i=0,s=-1,o=e?e.length:0;for(r=t.createCallback(r,n,3);++s<o&&r(e[s],s,e);)i++}else i=null==r||n?1:Vr(0,r);return l(e,i)}function At(e,r,n,i){var s=0,o=e?e.length:s;for(n=n?t.createCallback(n,i,1):Zt,r=n(r);o>s;){var a=s+o>>>1;n(e[a])<r?s=a+1:o=a}return s}function Ot(){return ie($(arguments,!0,!0))}function Pt(e,r,n,i){return"boolean"!=typeof r&&null!=r&&(i=n,n="function"!=typeof r&&i&&i[r]===e?null:r,r=!1),null!=n&&(n=t.createCallback(n,i,3)),ie(e,r,n)}function Bt(e){return Q(e,l(arguments,1))}function xt(){for(var e=-1,t=arguments.length;++e<t;){var r=arguments[e];if(Zr(r)||de(r))var n=n?ie(Q(n,r).concat(Q(r,n))):r}return n||[]}function Rt(){for(var e=arguments.length>1?arguments:arguments[0],t=-1,r=e?et(pn(e,"length")):0,n=pr(0>r?0:r);++t<r;)n[t]=pn(e,t);return n}function Tt(e,t){var r=-1,n=e?e.length:0,i={};for(t||!n||Zr(e[0])||(t=[]);++r<n;){var s=e[r];t?i[s]=t[r]:s&&(i[s[0]]=s[1])}return i}function Nt(e,t){if(!Be(t))throw new Sr;return function(){return--e<1?t.apply(this,arguments):void 0}}function Ct(e,t){return arguments.length>2?oe(e,17,l(arguments,2),null,t):oe(e,1,null,null,t)}function jt(e){for(var t=arguments.length>1?$(arguments,!0,!1,1):_e(e),r=-1,n=t.length;++r<n;){var i=t[r];e[i]=oe(e[i],1,null,null,e)}return e}function Ut(e,t){return arguments.length>2?oe(t,19,l(arguments,2),null,e):oe(t,3,null,null,e)}function Mt(){for(var e=arguments,t=e.length;t--;)if(!Be(e[t]))throw new Sr;return function(){for(var t=arguments,r=e.length;r--;)t=[e[r].apply(this,t)];return t[0]}}function Lt(e,t){return t="number"==typeof t?t:+t||e.length,oe(e,4,null,null,null,t)}function Dt(e,t,r){var n,i,s,o,a,f,c,u=0,h=!1,d=!0;if(!Be(e))throw new Sr;if(t=Vr(0,t)||0,r===!0){var p=!0;d=!1}else xe(r)&&(p=r.leading,h="maxWait"in r&&(Vr(t,r.maxWait)||0),d="trailing"in r?r.trailing:d);var l=function(){var r=t-(bn()-o);if(0>=r){i&&Br(i);var h=c;i=f=c=g,h&&(u=bn(),s=e.apply(a,n),f||i||(n=a=null))}else f=jr(l,r)},b=function(){f&&Br(f),i=f=c=g,(d||h!==t)&&(u=bn(),s=e.apply(a,n),f||i||(n=a=null))};return function(){if(n=arguments,o=bn(),a=this,c=d&&(f||!p),h===!1)var r=p&&!f;else{i||p||(u=o);var g=h-(o-u),m=0>=g;m?(i&&(i=Br(i)),u=o,s=e.apply(a,n)):i||(i=jr(b,g))}return m&&f?f=Br(f):f||t===h||(f=jr(l,t)),r&&(m=!0,s=e.apply(a,n)),!m||f||i||(n=a=null),s}}function Ht(e){if(!Be(e))throw new Sr;var t=l(arguments,1);return jr(function(){e.apply(g,t)},1)}function Ft(e,t){if(!Be(e))throw new Sr;var r=l(arguments,2);return jr(function(){e.apply(g,r)},t)}function Kt(e,t){if(!Be(e))throw new Sr;var r=function(){var n=r.cache,i=t?t.apply(this,arguments):_+arguments[0];return Nr.call(n,i)?n[i]:n[i]=e.apply(this,arguments)};return r.cache={},r}function zt(e){var t,r;if(!Be(e))throw new Sr;return function(){return t?r:(t=!0,r=e.apply(this,arguments),e=null,r)}}function Vt(e){return oe(e,16,l(arguments,1))}function qt(e){return oe(e,32,null,l(arguments,1))}function Jt(e,t,r){var n=!0,i=!0;if(!Be(e))throw new Sr;return r===!1?n=!1:xe(r)&&(n="leading"in r?r.leading:n,i="trailing"in r?r.trailing:i),Y.leading=n,Y.maxWait=t,Y.trailing=i,Dt(e,t,Y)}function Yt(e,t){return oe(t,16,[e])}function Gt(e){return function(){return e}}function Wt(e,t,r){var n=typeof e;if(null==e||"function"==n)return S(e,t,r);if("object"!=n)return tr(e);var i=$r(e),s=i[0],o=e[s];return 1!=i.length||o!==o||xe(o)?function(t){for(var r=i.length,n=!1;r--&&(n=ee(t[i[r]],e[i[r]],null,!0)););return n}:function(e){var t=e[s];return o===t&&(0!==o||1/o==1/t)}}function Xt(e){return null==e?"":wr(e).replace(nn,ae)}function Zt(e){return e}function Qt(e,n,i){var s=!0,o=n&&_e(n);n&&(i||o.length)||(null==i&&(i=n),a=r,n=e,e=t,o=_e(n)),i===!1?s=!1:xe(i)&&"chain"in i&&(s=i.chain);var a=e,f=Be(a);Xe(o,function(t){var r=e[t]=n[t];f&&(a.prototype[t]=function(){var t=this.__chain__,n=this.__wrapped__,i=[n];Cr.apply(i,arguments);var o=r.apply(e,i);if(s||t){if(n===o&&xe(o))return this;o=new a(o),o.__chain__=t}return o})})}function $t(){return e._=Ir,this}function er(){}function tr(e){return function(t){return t[e]}}function rr(e,t,r){var n=null==e,i=null==t;if(null==r&&("boolean"==typeof e&&i?(r=e,e=1):i||"boolean"!=typeof t||(r=t,i=!0)),n&&i&&(t=1),e=+e||0,i?(t=e,e=0):t=+t||0,r||e%1||t%1){var s=Yr();return qr(e+s*(t-e+parseFloat("1e-"+((s+"").length-1))),t)}return ne(e,t)}function nr(e,t){if(e){var r=e[t];return Be(r)?e[t]():r}}function ir(e,r,n){var i=t.templateSettings;e=wr(e||""),n=on({},n,i);var s,o=on({},n.imports,i.imports),a=$r(o),f=ze(o),u=0,h=n.interpolate||T,d="__p += '",p=_r((n.escape||T).source+"|"+h.source+"|"+(h===x?O:T).source+"|"+(n.evaluate||T).source+"|$","g");e.replace(p,function(t,r,n,i,o,a){return n||(n=i),d+=e.slice(u,a).replace(C,c),r&&(d+="' +\n__e("+r+") +\n'"),o&&(s=!0,d+="';\n"+o+";\n__p += '"),n&&(d+="' +\n((__t = ("+n+")) == null ? '' : __t) +\n'"),u=a+t.length,t}),d+="';\n";var l=n.variable,b=l;b||(l="obj",d="with ("+l+") {\n"+d+"\n}\n"),d=(s?d.replace(E,""):d).replace(I,"$1").replace(A,"$1;"),d="function("+l+") {\n"+(b?"":l+" || ("+l+" = {});\n")+"var __t, __p = '', __e = _.escape"+(s?", __j = Array.prototype.join;\nfunction print() { __p += __j.call(arguments, '') }\n":";\n")+d+"return __p\n}";var m="\n/*\n//# sourceURL="+(n.sourceURL||"/lodash/template/source["+U++ +"]")+"\n*/";try{var y=gr(a,"return "+d+m).apply(g,f)}catch(v){throw v.source=d,v}return r?y(r):(y.source=d,y)}function sr(e,t,r){e=(e=+e)>-1?e:0;var n=-1,i=pr(e);for(t=S(t,r,1);++n<e;)i[n]=t(n);return i}function or(e){return null==e?"":wr(e).replace(rn,he)}function ar(e){var t=++v;return wr(null==e?"":e)+t}function fr(e){return e=new r(e),e.__chain__=!0,e}function cr(e,t){return t(e),e}function ur(){return this.__chain__=!0,this}function hr(){return wr(this.__wrapped__)}function dr(){return this.__wrapped__}e=e?re.defaults(Z.Object(),e,re.pick(Z,j)):Z;var pr=e.Array,lr=e.Boolean,br=e.Date,gr=e.Function,mr=e.Math,yr=e.Number,vr=e.Object,_r=e.RegExp,wr=e.String,Sr=e.TypeError,kr=[],Er=vr.prototype,Ir=e._,Ar=Er.toString,Or=_r("^"+wr(Ar).replace(/[.*+?^${}()|[\]\\]/g,"\\$&").replace(/toString| for [^\]]+/g,".*?")+"$"),Pr=mr.ceil,Br=e.clearTimeout,xr=mr.floor,Rr=gr.prototype.toString,Tr=ce(Tr=vr.getPrototypeOf)&&Tr,Nr=Er.hasOwnProperty,Cr=kr.push,jr=e.setTimeout,Ur=kr.splice,Mr=kr.unshift,Lr=function(){try{var e={},t=ce(t=vr.defineProperty)&&t,r=t(e,e,e)&&t}catch(n){}return r}(),Dr=ce(Dr=vr.create)&&Dr,Hr=ce(Hr=pr.isArray)&&Hr,Fr=e.isFinite,Kr=e.isNaN,zr=ce(zr=vr.keys)&&zr,Vr=mr.max,qr=mr.min,Jr=e.parseInt,Yr=mr.random,Gr={};Gr[L]=pr,Gr[D]=lr,Gr[H]=br,Gr[F]=gr,Gr[z]=vr,Gr[K]=yr,Gr[V]=_r,Gr[q]=wr,r.prototype=t.prototype;var Wr=t.support={};Wr.funcDecomp=!ce(e.WinRTError)&&N.test(b),Wr.funcNames="string"==typeof gr.name,t.templateSettings={escape:/<%-([\s\S]+?)%>/g,evaluate:/<%([\s\S]+?)%>/g,interpolate:x,variable:"",imports:{_:t}},Dr||(y=function(){function t(){}return function(r){if(xe(r)){t.prototype=r;var n=new t;t.prototype=null}return n||e.Object()}}());var Xr=Lr?function(e,t){G.value=t,Lr(e,"__bindData__",G)}:er,Zr=Hr||function(e){return e&&"object"==typeof e&&"number"==typeof e.length&&Ar.call(e)==L||!1},Qr=function(e){var t,r=e,n=[];if(!r)return n;if(!W[typeof e])return n;for(t in r)Nr.call(r,t)&&n.push(t);return n},$r=zr?function(e){return xe(e)?zr(e):[]}:Qr,en={"&":"&amp;","<":"&lt;",">":"&gt;",'"':"&quot;","'":"&#39;"},tn=Se(en),rn=_r("("+$r(tn).join("|")+")","g"),nn=_r("["+$r(en).join("")+"]","g"),sn=function(e,t,r){var n,i=e,s=i;if(!i)return s;var o=arguments,a=0,f="number"==typeof r?2:o.length;if(f>3&&"function"==typeof o[f-2])var c=S(o[--f-1],o[f--],2);else f>2&&"function"==typeof o[f-1]&&(c=o[--f]);for(;++a<f;)if(i=o[a],i&&W[typeof i])for(var u=-1,h=W[typeof i]&&$r(i),d=h?h.length:0;++u<d;)n=h[u],s[n]=c?c(s[n],i[n]):i[n];return s},on=function(e,t,r){var n,i=e,s=i;if(!i)return s;for(var o=arguments,a=0,f="number"==typeof r?2:o.length;++a<f;)if(i=o[a],i&&W[typeof i])for(var c=-1,u=W[typeof i]&&$r(i),h=u?u.length:0;++c<h;)n=u[c],"undefined"==typeof s[n]&&(s[n]=i[n]);return s},an=function(e,t,r){var n,i=e,s=i;if(!i)return s;if(!W[typeof i])return s;t=t&&"undefined"==typeof r?t:S(t,r,3);for(n in i)if(t(i[n],n,e)===!1)return s;return s},fn=function(e,t,r){var n,i=e,s=i;if(!i)return s;if(!W[typeof i])return s;t=t&&"undefined"==typeof r?t:S(t,r,3);for(var o=-1,a=W[typeof i]&&$r(i),f=a?a.length:0;++o<f;)if(n=a[o],t(i[n],n,e)===!1)return s;return s},cn=Tr?function(e){if(!e||Ar.call(e)!=z)return!1;var t=e.valueOf,r=ce(t)&&(r=Tr(t))&&Tr(r);return r?e==r||Tr(e)==r:ue(e)}:ue,un=se(function(e,t,r){Nr.call(e,r)?e[r]++:e[r]=1}),hn=se(function(e,t,r){(Nr.call(e,r)?e[r]:e[r]=[]).push(t)}),dn=se(function(e,t,r){e[r]=t}),pn=$e,ln=Ye,bn=ce(bn=br.now)&&bn||function(){return(new br).getTime()},gn=8==Jr(k+"08")?Jr:function(e,t){return Jr(je(e)?e.replace(R,""):e,t||0)};return t.after=Nt,t.assign=sn,t.at=Ve,t.bind=Ct,t.bindAll=jt,t.bindKey=Ut,t.chain=fr,t.compact=ht,t.compose=Mt,t.constant=Gt,t.countBy=un,t.create=be,t.createCallback=Wt,t.curry=Lt,t.debounce=Dt,t.defaults=on,t.defer=Ht,t.delay=Ft,t.difference=dt,t.filter=Ye,t.flatten=gt,t.forEach=Xe,t.forEachRight=Ze,t.forIn=an,t.forInRight=ye,t.forOwn=fn,t.forOwnRight=ve,t.functions=_e,t.groupBy=hn,t.indexBy=dn,t.initial=yt,t.intersection=vt,t.invert=Se,t.invoke=Qe,t.keys=$r,t.map=$e,t.mapValues=Me,t.max=et,t.memoize=Kt,t.merge=Le,t.min=tt,t.omit=De,t.once=zt,t.pairs=He,t.partial=Vt,t.partialRight=qt,t.pick=Fe,t.pluck=pn,t.property=tr,t.pull=St,t.range=kt,t.reject=it,t.remove=Et,t.rest=It,t.shuffle=ot,t.sortBy=ct,t.tap=cr,t.throttle=Jt,t.times=sr,t.toArray=ut,t.transform=Ke,t.union=Ot,t.uniq=Pt,t.values=ze,t.where=ln,t.without=Bt,t.wrap=Yt,t.xor=xt,t.zip=Rt,t.zipObject=Tt,t.collect=$e,t.drop=It,t.each=Xe,t.eachRight=Ze,t.extend=sn,t.methods=_e,t.object=Tt,t.select=Ye,t.tail=It,t.unique=Pt,t.unzip=Rt,Qt(t),t.clone=pe,t.cloneDeep=le,t.contains=qe,t.escape=Xt,t.every=Je,t.find=Ge,t.findIndex=pt,t.findKey=ge,t.findLast=We,t.findLastIndex=lt,t.findLastKey=me,t.has=we,t.identity=Zt,t.indexOf=mt,t.isArguments=de,t.isArray=Zr,t.isBoolean=ke,t.isDate=Ee,t.isElement=Ie,t.isEmpty=Ae,
t.isEqual=Oe,t.isFinite=Pe,t.isFunction=Be,t.isNaN=Re,t.isNull=Te,t.isNumber=Ne,t.isObject=xe,t.isPlainObject=cn,t.isRegExp=Ce,t.isString=je,t.isUndefined=Ue,t.lastIndexOf=wt,t.mixin=Qt,t.noConflict=$t,t.noop=er,t.now=bn,t.parseInt=gn,t.random=rr,t.reduce=rt,t.reduceRight=nt,t.result=nr,t.runInContext=b,t.size=at,t.some=ft,t.sortedIndex=At,t.template=ir,t.unescape=or,t.uniqueId=ar,t.all=Je,t.any=ft,t.detect=Ge,t.findWhere=Ge,t.foldl=rt,t.foldr=nt,t.include=qe,t.inject=rt,Qt(function(){var e={};return fn(t,function(r,n){t.prototype[n]||(e[n]=r)}),e}(),!1),t.first=bt,t.last=_t,t.sample=st,t.take=bt,t.head=bt,fn(t,function(e,n){var i="sample"!==n;t.prototype[n]||(t.prototype[n]=function(t,n){var s=this.__chain__,o=e(this.__wrapped__,t,n);return s||null!=t&&(!n||i&&"function"==typeof t)?new r(o,s):o})}),t.VERSION="2.4.1",t.prototype.chain=ur,t.prototype.toString=hr,t.prototype.value=dr,t.prototype.valueOf=dr,Xe(["join","pop","shift"],function(e){var n=kr[e];t.prototype[e]=function(){var e=this.__chain__,t=n.apply(this.__wrapped__,arguments);return e?new r(t,e):t}}),Xe(["push","reverse","sort","unshift"],function(e){var r=kr[e];t.prototype[e]=function(){return r.apply(this.__wrapped__,arguments),this}}),Xe(["concat","slice","splice"],function(e){var n=kr[e];t.prototype[e]=function(){return new r(n.apply(this.__wrapped__,arguments),this.__chain__)}}),t}var g,m=[],y=[],v=0,_=+new Date+"",w=75,S=40,k=" \f \ufeff\n\r\u2028\u2029  ",E=/\b__p \+= '';/g,I=/\b(__p \+=) '' \+/g,A=/(__e\(.*?\)|\b__t\)) \+\n'';/g,O=/\$\{([^\\}]*(?:\\.[^\\}]*)*)\}/g,P=/\w*$/,B=/^\s*function[ \n\r\t]+\w/,x=/<%=([\s\S]+?)%>/g,R=RegExp("^["+k+"]*0+(?=.$)"),T=/($^)/,N=/\bthis\b/,C=/['\n\r\t\u2028\u2029\\]/g,j=["Array","Boolean","Date","Function","Math","Number","Object","RegExp","String","_","attachEvent","clearTimeout","isFinite","isNaN","parseInt","setTimeout"],U=0,M="[object Arguments]",L="[object Array]",D="[object Boolean]",H="[object Date]",F="[object Function]",K="[object Number]",z="[object Object]",V="[object RegExp]",q="[object String]",J={};J[F]=!1,J[M]=J[L]=J[D]=J[H]=J[K]=J[z]=J[V]=J[q]=!0;var Y={leading:!1,maxWait:0,trailing:!1},G={configurable:!1,enumerable:!1,value:null,writable:!1},W={"boolean":!1,"function":!0,object:!0,number:!1,string:!1,undefined:!1},X={"\\":"\\","'":"'","\n":"n","\r":"r"," ":"t","\u2028":"u2028","\u2029":"u2029"},Z=W[typeof window]&&window||this,Q=W[typeof r]&&r&&!r.nodeType&&r,$=W[typeof t]&&t&&!t.nodeType&&t,ee=$&&$.exports===Q&&Q,te=W[typeof e]&&e;!te||te.global!==te&&te.window!==te||(Z=te);var re=b();"function"==typeof define&&"object"==typeof define.amd&&define.amd?(Z._=re,define(function(){return re})):Q&&$?ee?($.exports=re)._=re:Q._=re:Z._=re}).call(this)}).call(this,"undefined"!=typeof global?global:"undefined"!=typeof self?self:"undefined"!=typeof window?window:{})},{}],195:[function(e,t,r){(function(r){var n=e("./word-array"),i=function(){function e(){}return{extend:function(t){e.prototype=this;var r=new e;return t&&r.mixIn(t),r.hasOwnProperty("init")||(r.init=function(){r.$super.init.apply(this,arguments)}),r.init.prototype=r,r.$super=this,r},create:function(){var e=this.extend();return e.init.apply(e,arguments),e},init:function(){},mixIn:function(e){for(var t in e)e.hasOwnProperty(t)&&(this[t]=e[t]);e.hasOwnProperty("toString")&&(this.toString=e.toString)},clone:function(){return this.init.prototype.extend(this)}}}(),s=i.extend({reset:function(){this._data=new n,this._nDataBytes=0},_append:function(e){r.isBuffer(e)&&(e=n.fromBuffer(e)),this._data.concat(e),this._nDataBytes+=e.sigBytes},_process:function(e){var t=this._data,r=t.words,i=t.sigBytes,s=this.blockSize,o=4*s,a=i/o;a=e?Math.ceil(a):Math.max((0|a)-this._minBufferSize,0);var f=a*s,c=Math.min(4*f,i);if(f){for(var u=0;f>u;u+=s)this._doProcessBlock(r,u);var h=r.splice(0,f);t.sigBytes-=c}return new n(h,c)},clone:function(){var e=i.clone.call(this);return e._data=this._data.clone(),e},_minBufferSize:0}),o=s.extend({cfg:i.extend(),init:function(e){this.cfg=this.cfg.extend(e),this.reset()},reset:function(){s.reset.call(this),this._doReset()},update:function(e){return"string"==typeof e&&(e=n.fromBuffer(new r(e,"utf8"))),r.isBuffer(e)&&(e=n.fromBuffer(e)),this._append(e),this._process(),this},finalize:function(e){"string"==typeof e&&(e=n.fromBuffer(new r(e,"utf8"))),r.isBuffer(e)&&(e=n.fromBuffer(e)),e&&this._append(e);var t=this._doFinalize();return t.toBuffer()},blockSize:16,_createHelper:function(e){return function(t,r){return new e.init(r).finalize(t)}}});t.exports.Hasher=o}).call(this,e("buffer").Buffer)},{"./word-array":199,buffer:46}],196:[function(e,t,r){(function(r){function n(e){if(!(this instanceof n))return new n(e);var t=this._hasher=new i.init;"string"==typeof e&&(e=s.fromBuffer(new r(e,"utf8"))),r.isBuffer(e)&&(e=s.fromBuffer(e));var o=t.blockSize,a=4*o;e.sigBytes>a&&(e=t.finalize(e)),e.clamp();for(var f=this._oKey=e.clone(),c=this._iKey=e.clone(),u=f.words,h=c.words,d=0;o>d;d++)u[d]^=1549556828,h[d]^=909522486;f.sigBytes=c.sigBytes=a,this.reset()}var i=e("./sha512").sha512,s=e("./word-array");n.prototype.reset=function(){var e=this._hasher;e.reset(),e.update(this._iKey)},n.prototype.update=function(e){return"string"==typeof e&&(e=s.fromBuffer(new r(e,"utf8"))),r.isBuffer(e)&&(e=s.fromBuffer(e)),this._hasher.update(e),this},n.prototype.finalize=function(e){"string"==typeof e&&(e=s.fromBuffer(new r(e,"utf8"))),r.isBuffer(e)&&(e=s.fromBuffer(e));var t=this._hasher,n=t.finalize(e);t.reset();var i=t.finalize(this._oKey.clone().concat(n));return i},t.exports=n}).call(this,e("buffer").Buffer)},{"./sha512":198,"./word-array":199,buffer:46}],197:[function(e,t,r){t.exports=e("./sha512"),t.exports.hmac=e("./hmac")},{"./hmac":196,"./sha512":198}],198:[function(e,t,r){var n=e("./cryptojs").Hasher,i=e("./x64"),s=i.Word,o=i.WordArray,a=[s(1116352408,3609767458),s(1899447441,602891725),s(3049323471,3964484399),s(3921009573,2173295548),s(961987163,4081628472),s(1508970993,3053834265),s(2453635748,2937671579),s(2870763221,3664609560),s(3624381080,2734883394),s(310598401,1164996542),s(607225278,1323610764),s(1426881987,3590304994),s(1925078388,4068182383),s(2162078206,991336113),s(2614888103,633803317),s(3248222580,3479774868),s(3835390401,2666613458),s(4022224774,944711139),s(264347078,2341262773),s(604807628,2007800933),s(770255983,1495990901),s(1249150122,1856431235),s(1555081692,3175218132),s(1996064986,2198950837),s(2554220882,3999719339),s(2821834349,766784016),s(2952996808,2566594879),s(3210313671,3203337956),s(3336571891,1034457026),s(3584528711,2466948901),s(113926993,3758326383),s(338241895,168717936),s(666307205,1188179964),s(773529912,1546045734),s(1294757372,1522805485),s(1396182291,2643833823),s(1695183700,2343527390),s(1986661051,1014477480),s(2177026350,1206759142),s(2456956037,344077627),s(2730485921,1290863460),s(2820302411,3158454273),s(3259730800,3505952657),s(3345764771,106217008),s(3516065817,3606008344),s(3600352804,1432725776),s(4094571909,1467031594),s(275423344,851169720),s(430227734,3100823752),s(506948616,1363258195),s(659060556,3750685593),s(883997877,3785050280),s(958139571,3318307427),s(1322822218,3812723403),s(1537002063,2003034995),s(1747873779,3602036899),s(1955562222,1575990012),s(2024104815,1125592928),s(2227730452,2716904306),s(2361852424,442776044),s(2428436474,593698344),s(2756734187,3733110249),s(3204031479,2999351573),s(3329325298,3815920427),s(3391569614,3928383900),s(3515267271,566280711),s(3940187606,3454069534),s(4118630271,4000239992),s(116418474,1914138554),s(174292421,2731055270),s(289380356,3203993006),s(460393269,320620315),s(685471733,587496836),s(852142971,1086792851),s(1017036298,365543100),s(1126000580,2618297676),s(1288033470,3409855158),s(1501505948,4234509866),s(1607167915,987167468),s(1816402316,1246189591)],f=[];!function(){for(var e=0;80>e;e++)f[e]=s()}();var c=n.extend({_doReset:function(){this._hash=new o([s(1779033703,4089235720),s(3144134277,2227873595),s(1013904242,4271175723),s(2773480762,1595750129),s(1359893119,2917565137),s(2600822924,725511199),s(528734635,4215389547),s(1541459225,327033209)])},_doProcessBlock:function(e,t){for(var r=this._hash.words,n=r[0],i=r[1],s=r[2],o=r[3],c=r[4],u=r[5],h=r[6],d=r[7],p=n.high,l=n.low,b=i.high,g=i.low,m=s.high,y=s.low,v=o.high,_=o.low,w=c.high,S=c.low,k=u.high,E=u.low,I=h.high,A=h.low,O=d.high,P=d.low,B=p,x=l,R=b,T=g,N=m,C=y,j=v,U=_,M=w,L=S,D=k,H=E,F=I,K=A,z=O,V=P,q=0;80>q;q++){var J=f[q];if(16>q)var Y=J.high=0|e[t+2*q],G=J.low=0|e[t+2*q+1];else{var W=f[q-15],X=W.high,Z=W.low,Q=(X>>>1|Z<<31)^(X>>>8|Z<<24)^X>>>7,$=(Z>>>1|X<<31)^(Z>>>8|X<<24)^(Z>>>7|X<<25),ee=f[q-2],te=ee.high,re=ee.low,ne=(te>>>19|re<<13)^(te<<3|re>>>29)^te>>>6,ie=(re>>>19|te<<13)^(re<<3|te>>>29)^(re>>>6|te<<26),se=f[q-7],oe=se.high,ae=se.low,fe=f[q-16],ce=fe.high,ue=fe.low,G=$+ae,Y=Q+oe+($>>>0>G>>>0?1:0),G=G+ie,Y=Y+ne+(ie>>>0>G>>>0?1:0),G=G+ue,Y=Y+ce+(ue>>>0>G>>>0?1:0);J.high=Y,J.low=G}var he=M&D^~M&F,de=L&H^~L&K,pe=B&R^B&N^R&N,le=x&T^x&C^T&C,be=(B>>>28|x<<4)^(B<<30|x>>>2)^(B<<25|x>>>7),ge=(x>>>28|B<<4)^(x<<30|B>>>2)^(x<<25|B>>>7),me=(M>>>14|L<<18)^(M>>>18|L<<14)^(M<<23|L>>>9),ye=(L>>>14|M<<18)^(L>>>18|M<<14)^(L<<23|M>>>9),ve=a[q],_e=ve.high,we=ve.low,Se=V+ye,ke=z+me+(V>>>0>Se>>>0?1:0),Se=Se+de,ke=ke+he+(de>>>0>Se>>>0?1:0),Se=Se+we,ke=ke+_e+(we>>>0>Se>>>0?1:0),Se=Se+G,ke=ke+Y+(G>>>0>Se>>>0?1:0),Ee=ge+le,Ie=be+pe+(ge>>>0>Ee>>>0?1:0);z=F,V=K,F=D,K=H,D=M,H=L,L=U+Se|0,M=j+ke+(U>>>0>L>>>0?1:0)|0,j=N,U=C,N=R,C=T,R=B,T=x,x=Se+Ee|0,B=ke+Ie+(Se>>>0>x>>>0?1:0)|0}l=n.low=l+x,n.high=p+B+(x>>>0>l>>>0?1:0),g=i.low=g+T,i.high=b+R+(T>>>0>g>>>0?1:0),y=s.low=y+C,s.high=m+N+(C>>>0>y>>>0?1:0),_=o.low=_+U,o.high=v+j+(U>>>0>_>>>0?1:0),S=c.low=S+L,c.high=w+M+(L>>>0>S>>>0?1:0),E=u.low=E+H,u.high=k+D+(H>>>0>E>>>0?1:0),A=h.low=A+K,h.high=I+F+(K>>>0>A>>>0?1:0),P=d.low=P+V,d.high=O+z+(V>>>0>P>>>0?1:0)},_doFinalize:function(){var e=this._data,t=e.words,r=8*this._nDataBytes,n=8*e.sigBytes;t[n>>>5]|=128<<24-n%32,t[(n+128>>>10<<5)+30]=Math.floor(r/4294967296),t[(n+128>>>10<<5)+31]=r,e.sigBytes=4*t.length,this._process();var i=this._hash.toX32();return i},clone:function(){var e=n.clone.call(this);return e._hash=this._hash.clone(),e},blockSize:32});t.exports=n._createHelper(c),t.exports.sha512=c},{"./cryptojs":195,"./x64":200}],199:[function(e,t,r){(function(e,r){function n(e,t){this.words=e||[],this.sigBytes=void 0!=t?t:4*this.words.length}t.exports=n,n.prototype.concat=function(e){r.isBuffer(e)&&(e=n.fromBuffer(e));var t=this.words,i=e.words,s=this.sigBytes,o=e.sigBytes;if(this.clamp(),s%4)for(var a=0;o>a;a++){var f=i[a>>>2]>>>24-a%4*8&255;t[s+a>>>2]|=f<<24-(s+a)%4*8}else if(i.length>65535)for(var a=0;o>a;a+=4)t[s+a>>>2]=i[a>>>2];else t.push.apply(t,i);return this.sigBytes+=o,this},n.prototype.clamp=function(){var e=this.words,t=this.sigBytes;e[t>>>2]&=4294967295<<32-t%4*8,e.length=Math.ceil(t/4)},n.prototype.clone=function(){var e=new n(this.words.slice(0));return e},n.prototype.toBuffer=function(){for(var e=new r(4*this.words.length),t=0;t<this.words.length;++t){var n=this.words[t];e.writeUInt32BE(n,4*t,!0)}return e},n.fromBuffer=function(t){var r=t.length,i=r%4,s=[];if(e.browser){for(var o=0;r-i>o;o+=4){var a=t.readUInt32BE(o);s.push(a)}for(var f=0,c=r-i,u=0;i>u;u+=1)f|=t.readUInt8(c+u)<<8*(3-u);return i>0&&s.push(f),new n(s,t.length)}for(var o=0;r>o;o+=4){var a=t.readUInt32BE(o,!0);s.push(a)}return new n(s,t.length)}}).call(this,e("_process"),e("buffer").Buffer)},{_process:147,buffer:46}],200:[function(e,t,r){function n(e,t){return this instanceof n?(this.high=e,void(this.low=t)):new n(e,t)}function i(e){this.words=e||[]}var s=e("./word-array");i.prototype.toX32=function(){for(var e=this.words,t=e.length,r=[],n=0;t>n;n++){var i=e[n];r.push(i.high),r.push(i.low)}return new s(r,this.sigBytes)},t.exports.Word=n,t.exports.WordArray=i},{"./word-array":199}],201:[function(e,t,r){t.exports={name:"bitcore",version:"0.12.14",description:"A pure and powerful JavaScript Bitcoin library.",author:"BitPay <dev@bitpay.com>",main:"index.js",scripts:{lint:"gulp lint",test:"gulp test",coverage:"gulp coverage",build:"gulp"},contributors:[{name:"Daniel Cousens",email:"bitcoin@dcousens.com"},{name:"Esteban Ordano",email:"eordano@gmail.com"},{name:"Gordon Hall",email:"gordon@bitpay.com"},{name:"Jeff Garzik",email:"jgarzik@bitpay.com"},{name:"Kyle Drake",email:"kyle@kyledrake.net"},{name:"Manuel Araoz",email:"manuelaraoz@gmail.com"},{name:"Matias Alejo Garcia",email:"ematiu@gmail.com"},{name:"Ryan X. Charles",email:"ryanxcharles@gmail.com"},{name:"Stefan Thomas",email:"moon@justmoon.net"},{name:"Stephen Pair",email:"stephen@bitpay.com"},{name:"Wei Lu",email:"luwei.here@gmail.com"}],keywords:["bitcoin","transaction","address","p2p","ecies","cryptocurrency","blockchain","payment","bip21","bip32","bip37","bip70","multisig"],repository:{type:"git",url:"https://github.com/bitpay/bitcore.git"},browser:{request:"browser-request"},dependencies:{"bn.js":"=2.0.4",bs58:"=2.0.0",elliptic:"=3.0.3","hash.js":"=1.0.2",inherits:"=2.0.1",lodash:"=2.4.1",sha512:"=0.0.1"},devDependencies:{"bitcore-build":"bitpay/bitcore-build",brfs:"^1.2.0",chai:"^1.10.0",gulp:"^3.8.10",sinon:"^1.13.0"},license:"MIT"}},{}],bitcore:[function(e,t,r){(function(r,n){"use strict";var i=t.exports;i.version="v"+e("./package.json").version,i.versionGuard=function(e){if(void 0!==e){var t="More than one instance of bitcore found with versions: "+i.version+" and "+e+". Please make sure to require bitcore and check that submodules do not also include their own bitcore dependency.";throw new Error(t)}},i.versionGuard(r._bitcore),r._bitcore=i.version,i.crypto={},i.crypto.BN=e("./lib/crypto/bn"),i.crypto.ECDSA=e("./lib/crypto/ecdsa"),i.crypto.Hash=e("./lib/crypto/hash"),i.crypto.Random=e("./lib/crypto/random"),i.crypto.Point=e("./lib/crypto/point"),i.crypto.Signature=e("./lib/crypto/signature"),i.encoding={},i.encoding.Base58=e("./lib/encoding/base58"),i.encoding.Base58Check=e("./lib/encoding/base58check"),i.encoding.BufferReader=e("./lib/encoding/bufferreader"),i.encoding.BufferWriter=e("./lib/encoding/bufferwriter"),i.encoding.Varint=e("./lib/encoding/varint"),i.util={},i.util.buffer=e("./lib/util/buffer"),i.util.js=e("./lib/util/js"),i.util.preconditions=e("./lib/util/preconditions"),i.errors=e("./lib/errors"),i.Address=e("./lib/address"),i.Block=e("./lib/block"),i.MerkleBlock=e("./lib/block/merkleblock"),i.BlockHeader=e("./lib/block/blockheader"),i.HDPrivateKey=e("./lib/hdprivatekey.js"),i.HDPublicKey=e("./lib/hdpublickey.js"),i.Networks=e("./lib/networks"),i.Opcode=e("./lib/opcode"),i.PrivateKey=e("./lib/privatekey"),i.PublicKey=e("./lib/publickey"),i.Script=e("./lib/script"),i.Transaction=e("./lib/transaction"),i.URI=e("./lib/uri"),i.Unit=e("./lib/unit"),i.deps={},i.deps.bnjs=e("bn.js"),i.deps.bs58=e("bs58"),i.deps.Buffer=n,i.deps.elliptic=e("elliptic"),i.deps._=e("lodash"),i._HDKeyCache=e("./lib/hdkeycache"),i.Transaction.sighash=e("./lib/transaction/sighash")}).call(this,"undefined"!=typeof global?global:"undefined"!=typeof self?self:"undefined"!=typeof window?window:{},e("buffer").Buffer)},{"./lib/address":1,"./lib/block":4,"./lib/block/blockheader":3,"./lib/block/merkleblock":5,"./lib/crypto/bn":6,"./lib/crypto/ecdsa":7,"./lib/crypto/hash":8,"./lib/crypto/point":9,"./lib/crypto/random":10,"./lib/crypto/signature":11,"./lib/encoding/base58":12,"./lib/encoding/base58check":13,"./lib/encoding/bufferreader":14,"./lib/encoding/bufferwriter":15,"./lib/encoding/varint":16,"./lib/errors":17,"./lib/hdkeycache":19,"./lib/hdprivatekey.js":20,"./lib/hdpublickey.js":21,"./lib/networks":22,"./lib/opcode":23,"./lib/privatekey":24,"./lib/publickey":25,"./lib/script":26,"./lib/transaction":29,"./lib/transaction/sighash":35,"./lib/unit":39,"./lib/uri":40,"./lib/util/buffer":41,"./lib/util/js":42,"./lib/util/preconditions":43,"./package.json":201,"bn.js":170,bs58:171,buffer:46,elliptic:172,lodash:194}]},{},[]);