!function e(t,r,n){function i(o,a){if(!r[o]){if(!t[o]){var c="function"==typeof require&&require;if(!a&&c)return c(o,!0);if(s)return s(o,!0);var f=new Error("Cannot find module '"+o+"'");throw f.code="MODULE_NOT_FOUND",f}var h=r[o]={exports:{}};t[o][0].call(h.exports,function(e){var r=t[o][1][e];return i(r?r:e)},h,h.exports,e,t,r,n)}return r[o].exports}for(var s="function"==typeof require&&require,o=0;oe)throw new Error("Maximum number of retry must be greater than 0. Actual: "+e);this.maxNumberOfRetry_=e},n.prototype.backoff=function(e){if(-1!==this.timeoutID_)throw new Error("Backoff in progress.");this.backoffNumber_===this.maxNumberOfRetry_?(this.emit("fail",e),this.reset()):(this.backoffDelay_=this.backoffStrategy_.next(),this.timeoutID_=setTimeout(this.handlers.backoff,this.backoffDelay_),this.emit("backoff",this.backoffNumber_,this.backoffDelay_,e))},n.prototype.onBackoff_=function(){this.timeoutID_=-1,this.emit("ready",this.backoffNumber_,this.backoffDelay_),this.backoffNumber_++},n.prototype.reset=function(){this.backoffNumber_=0,this.backoffStrategy_.reset(),clearTimeout(this.timeoutID_),this.timeoutID_=-1},t.exports=n},{events:260,util:281}],3:[function(e,t,r){function n(e){return"function"==typeof e}function i(e,t,r){if(s.EventEmitter.call(this),!n(e))throw new Error("fn should be a function.Actual: "+typeof e);if(!n(r))throw new Error("callback should be a function.Actual: "+typeof e);this.function_=e,this.arguments_=t,this.callback_=r,this.results_=[],this.backoff_=null,this.strategy_=null,this.failAfter_=-1,this.state_=i.State_.PENDING}var s=e("events"),o=e("util"),a=e("./backoff"),c=e("./strategy/fibonacci");o.inherits(i,s.EventEmitter),i.State_={PENDING:0,RUNNING:1,COMPLETED:2,ABORTED:3},i.prototype.isPending=function(){return this.state_==i.State_.PENDING},i.prototype.isRunning=function(){return this.state_==i.State_.RUNNING},i.prototype.isCompleted=function(){return this.state_==i.State_.COMPLETED},i.prototype.isAborted=function(){return this.state_==i.State_.ABORTED},i.prototype.setStrategy=function(e){if(!this.isPending())throw new Error("FunctionCall in progress.");return this.strategy_=e,this},i.prototype.getResults=function(){return this.results_.concat()},i.prototype.failAfter=function(e){if(!this.isPending())throw new Error("FunctionCall in progress.");return this.failAfter_=e,this},i.prototype.abort=function(){if(this.isCompleted())throw new Error("FunctionCall already completed.");this.isRunning()&&this.backoff_.reset(),this.state_=i.State_.ABORTED},i.prototype.start=function(e){if(this.isAborted())throw new Error("FunctionCall aborted.");if(!this.isPending())throw new Error("FunctionCall already started.");var t=this.strategy_||new c;this.backoff_=e?e(t):new a(t),this.backoff_.on("ready",this.doCall_.bind(this)),this.backoff_.on("fail",this.doCallback_.bind(this)),this.backoff_.on("backoff",this.handleBackoff_.bind(this)),this.failAfter_>0&&this.backoff_.failAfter(this.failAfter_),this.state_=i.State_.RUNNING,this.doCall_()},i.prototype.doCall_=function(){var e=["call"].concat(this.arguments_);s.EventEmitter.prototype.emit.apply(this,e);var t=this.handleFunctionCallback_.bind(this);this.function_.apply(null,this.arguments_.concat(t))},i.prototype.doCallback_=function(){var e=this.results_[this.results_.length-1];this.callback_.apply(null,e)},i.prototype.handleFunctionCallback_=function(){if(!this.isAborted()){var e=Array.prototype.slice.call(arguments);this.results_.push(e),s.EventEmitter.prototype.emit.apply(this,["callback"].concat(e)),e[0]?this.backoff_.backoff(e[0]):(this.state_=i.State_.COMPLETED,this.doCallback_())}},i.prototype.handleBackoff_=function(e,t,r){this.emit("backoff",e,t,r)},t.exports=i},{"./backoff":2,"./strategy/fibonacci":5,events:260,util:281}],4:[function(e,t,r){function n(e){s.call(this,e),this.backoffDelay_=0,this.nextBackoffDelay_=this.getInitialDelay()}var i=e("util"),s=e("./strategy");i.inherits(n,s),n.prototype.next_=function(){return this.backoffDelay_=Math.min(this.nextBackoffDelay_,this.getMaxDelay()),this.nextBackoffDelay_=2*this.backoffDelay_,this.backoffDelay_},n.prototype.reset_=function(){this.backoffDelay_=0,this.nextBackoffDelay_=this.getInitialDelay()},t.exports=n},{"./strategy":6,util:281}],5:[function(e,t,r){function n(e){s.call(this,e),this.backoffDelay_=0,this.nextBackoffDelay_=this.getInitialDelay()}var i=e("util"),s=e("./strategy");i.inherits(n,s),n.prototype.next_=function(){var e=Math.min(this.nextBackoffDelay_,this.getMaxDelay());return this.nextBackoffDelay_+=this.backoffDelay_,this.backoffDelay_=e,e},n.prototype.reset_=function(){this.nextBackoffDelay_=this.getInitialDelay(),this.backoffDelay_=0},t.exports=n},{"./strategy":6,util:281}],6:[function(e,t,r){function n(e){return void 0!==e&&null!==e}function i(e){if(e=e||{},n(e.initialDelay)&&e.initialDelay<1)throw new Error("The initial timeout must be greater than 0.");if(n(e.maxDelay)&&e.maxDelay<1)throw new Error("The maximal timeout must be greater than 0.");if(this.initialDelay_=e.initialDelay||100,this.maxDelay_=e.maxDelay||1e4,this.maxDelay_<=this.initialDelay_)throw new Error("The maximal backoff delay must be greater than the initial backoff delay.");if(n(e.randomisationFactor)&&(e.randomisationFactor<0||e.randomisationFactor>1))throw new Error("The randomisation factor must be between 0 and 1.");this.randomisationFactor_=e.randomisationFactor||0}e("events"),e("util");i.prototype.getMaxDelay=function(){return this.maxDelay_},i.prototype.getInitialDelay=function(){return this.initialDelay_},i.prototype.next=function(){var e=this.next_(),t=1+Math.random()*this.randomisationFactor_,r=Math.round(e*t);return r},i.prototype.next_=function(){throw new Error("BackoffStrategy.next_() unimplemented.")},i.prototype.reset=function(){this.reset_()},i.prototype.reset_=function(){throw new Error("BackoffStrategy.reset_() unimplemented.")},t.exports=i},{events:260,util:281}],7:[function(e,t,r){!function(e,n){"function"==typeof define&&define.amd?define([],n):"object"==typeof r?t.exports=n():e.returnExports=n()}(this,function(){function e(i,s){if("function"!=typeof s)throw new Error("Bad callback given: "+s);if(!i)throw new Error("No options given");var a=i.onResponse;if(i="string"==typeof i?{uri:i}:JSON.parse(JSON.stringify(i)),i.onResponse=a,i.verbose&&(e.log=n()),i.url&&(i.uri=i.url,delete i.url),!i.uri&&""!==i.uri)throw new Error("options.uri is a required argument");if("string"!=typeof i.uri)throw new Error("options.uri must be a string");for(var c=["proxy","_redirectsFollowed","maxRedirects","followRedirect"],f=0;f>18&63,s=c>>12&63,o=c>>6&63,a=63&c,p[u++]=f.charAt(i)+f.charAt(s)+f.charAt(o)+f.charAt(a);while(h299)&&r.error){e=new Error("CouchDB error: "+(r.error.reason||r.error.error));for(var i in r)e[i]=r[i];return n(e,t,r)}return n(e,t,r)}"string"==typeof t&&(t={uri:t}),t.json=!0,t.body&&(t.json=t.body),delete t.body,n=n||r;var s=e(t,i);return s},e})},{}],8:[function(e,t,r){function n(){return"WebkitAppearance"in document.documentElement.style||window.console&&(console.firebug||console.exception&&console.table)||navigator.userAgent.toLowerCase().match(/firefox\/(\d+)/)&&parseInt(RegExp.$1,10)>=31}function i(){var e=arguments,t=this.useColors;if(e[0]=(t?"%c":"")+this.namespace+(t?" %c":" ")+e[0]+(t?"%c ":" ")+"+"+r.humanize(this.diff),!t)return e;var n="color: "+this.color;e=[e[0],n,"color: inherit"].concat(Array.prototype.slice.call(e,1));var i=0,s=0;return e[0].replace(/%[a-z%]/g,function(e){"%%"!==e&&(i++,"%c"===e&&(s=i))}),e.splice(s,0,n),e}function s(){return"object"==typeof console&&console.log&&Function.prototype.apply.call(console.log,console,arguments)}function o(e){try{null==e?r.storage.removeItem("debug"):r.storage.debug=e}catch(t){}}function a(){var e;try{e=r.storage.debug}catch(t){}return e}function c(){try{return window.localStorage}catch(e){}}r=t.exports=e("./debug"),r.log=s,r.formatArgs=i,r.save=o,r.load=a,r.useColors=n,r.storage="undefined"!=typeof chrome&&"undefined"!=typeof chrome.storage?chrome.storage.local:c(),r.colors=["lightseagreen","forestgreen","goldenrod","dodgerblue","darkorchid","crimson"],r.formatters.j=function(e){return JSON.stringify(e)},r.enable(a())},{"./debug":9}],9:[function(e,t,r){function n(){return r.colors[h++%r.colors.length]}function i(e){function t(){}function i(){var e=i,t=+new Date,s=t-(f||t);e.diff=s,e.prev=f,e.curr=t,f=t,null==e.useColors&&(e.useColors=r.useColors()),null==e.color&&e.useColors&&(e.color=n());var o=Array.prototype.slice.call(arguments);o[0]=r.coerce(o[0]),"string"!=typeof o[0]&&(o=["%o"].concat(o));var a=0;o[0]=o[0].replace(/%([a-z%])/g,function(t,n){if("%%"===t)return t;a++;var i=r.formatters[n];if("function"==typeof i){var s=o[a];t=i.call(e,s),o.splice(a,1),a--}return t}),"function"==typeof r.formatArgs&&(o=r.formatArgs.apply(e,o));var c=i.log||r.log||console.log.bind(console);c.apply(e,o)}t.enabled=!1,i.enabled=!0;var s=r.enabled(e)?i:t;return s.namespace=e,s}function s(e){r.save(e);for(var t=(e||"").split(/[\s,]+/),n=t.length,i=0;n>i;i++)t[i]&&(e=t[i].replace(/\*/g,".*?"),"-"===e[0]?r.skips.push(new RegExp("^"+e.substr(1)+"$")):r.names.push(new RegExp("^"+e+"$")))}function o(){r.enable("")}function a(e){var t,n;for(t=0,n=r.skips.length;n>t;t++)if(r.skips[t].test(e))return!1;for(t=0,n=r.names.length;n>t;t++)if(r.names[t].test(e))return!0;return!1}function c(e){return e instanceof Error?e.stack||e.message:e}r=t.exports=i,r.coerce=c,r.disable=o,r.enable=s,r.enabled=a,r.humanize=e("ms"),r.names=[],r.skips=[],r.formatters={};var f,h=0},{ms:28}],10:[function(e,t,r){"function"==typeof Object.create?t.exports=function(e,t){e.super_=t,e.prototype=Object.create(t.prototype,{constructor:{value:e,enumerable:!1,writable:!0,configurable:!0}})}:t.exports=function(e,t){e.super_=t;var r=function(){};r.prototype=t.prototype,e.prototype=new r,e.prototype.constructor=e}},{}],11:[function(e,t,r){function n(e,t){return null==t?e:i(t,s(t),e)}var i=e("lodash._basecopy"),s=e("lodash.keys");t.exports=n},{"lodash._basecopy":12,"lodash.keys":20}],12:[function(e,t,r){function n(e,t,r){r||(r={});for(var n=-1,i=t.length;++n2?r[o-2]:void 0,c=o>2?r[2]:void 0,f=o>1?r[o-1]:void 0;for("function"==typeof a?(a=i(a,f,5),o-=2):(a="function"==typeof f?f:void 0,o-=a?1:0),c&&s(r[0],r[1],c)&&(a=3>o?void 0:a,o=1);++n-1&&e%1==0&&t>e}function o(e,t,r){if(!c(r))return!1;var n=typeof t;if("number"==n?i(r)&&s(t,r.length):"string"==n&&t in r){var o=r[t];return e===e?e===o:o!==o}return!1}function a(e){return"number"==typeof e&&e>-1&&e%1==0&&h>=e}function c(e){var t=typeof e;return!!e&&("object"==t||"function"==t)}var f=/^\d+$/,h=9007199254740991,u=n("length");t.exports=o},{}],17:[function(e,t,r){function n(e,t,r){for(var n=-1,i=o(t),s=i.length;++n-1&&e%1==0&&u>=e}function a(e){return n(e)&&s(e)&&f.call(e,"callee")&&!h.call(e,"callee")}var c=Object.prototype,f=c.hasOwnProperty,h=c.propertyIsEnumerable,u=9007199254740991,d=i("length");t.exports=a},{}],19:[function(e,t,r){function n(e){return!!e&&"object"==typeof e}function i(e,t){var r=null==e?void 0:e[t];return c(r)?r:void 0}function s(e){return"number"==typeof e&&e>-1&&e%1==0&&m>=e}function o(e){return a(e)&&b.call(e)==h}function a(e){var t=typeof e;return!!e&&("object"==t||"function"==t)}function c(e){return null==e?!1:o(e)?y.test(p.call(e)):n(e)&&u.test(e)}var f="[object Array]",h="[object Function]",u=/^\[object .+?Constructor\]$/,d=Object.prototype,p=Function.prototype.toString,l=d.hasOwnProperty,b=d.toString,y=RegExp("^"+p.call(l).replace(/[\\^$.*+?()[\]{}|]/g,"\\$&").replace(/hasOwnProperty|(function).*?(?=\\\()| for .+?(?=\\\])/g,"$1.*?")+"$"),g=i(Array,"isArray"),m=9007199254740991,v=g||function(e){return n(e)&&s(e.length)&&b.call(e)==f};t.exports=v},{}],20:[function(e,t,r){function n(e){return function(t){return null==t?void 0:t[e]}}function i(e){return null!=e&&o(m(e))}function s(e,t){return e="number"==typeof e||p.test(e)?+e:-1,t=null==t?g:t,e>-1&&e%1==0&&t>e}function o(e){return"number"==typeof e&&e>-1&&e%1==0&&g>=e}function a(e){for(var t=f(e),r=t.length,n=r&&e.length,i=!!n&&o(n)&&(d(e)||u(e)),a=-1,c=[];++a0;++n/g,">").replace(/"/g,""").replace(/"/g,"'")}function s(e){return e.replace(/\&/g,"&").replace(//g,">")}n.prototype.is=function(e,t){return this.getName()===e&&(!t||this.getNS()===t)},n.prototype.getName=function(){return this.name.indexOf(":")>=0?this.name.substr(this.name.indexOf(":")+1):this.name},n.prototype.getNS=function(){if(this.name.indexOf(":")>=0){var e=this.name.substr(0,this.name.indexOf(":"));return this.findNS(e)}return this.findNS()},n.prototype.findNS=function(e){if(e){var t="xmlns:"+e;if(this.attrs[t])return this.attrs[t];if(this.parent)return this.parent.findNS(e)}else{if(this.attrs.xmlns)return this.attrs.xmlns;if(this.parent)return this.parent.findNS()}},n.prototype.getXmlns=function(){var e={};this.parent&&(e=this.parent.getXmlns());for(var t in this.attrs){var r=t.match("xmlns:?(.*)");this.attrs.hasOwnProperty(t)&&r&&(e[this.attrs[t]]=r[1])}return e},n.prototype.setAttrs=function(e){this.attrs={},Object.keys(e||{}).forEach(function(t){this.attrs[t]=e[t]},this)},n.prototype.getAttr=function(e,t){if(!t)return this.attrs[e];var r=this.getXmlns();return r[t]?this.attrs[[r[t],e].join(":")]:null},n.prototype.getChild=function(e,t){return this.getChildren(e,t)[0]},n.prototype.getChildren=function(e,t){for(var r=[],n=0;n");for(var t=0;t")},n.prototype.write=function(e){e("<"),e(this.name);for(var t in this.attrs){var r=this.attrs[t];(r||""===r||0===r)&&(e(" "),e(t),e('="'),"string"!=typeof r&&(r=r.toString(10)),e(i(r)),e('"'))}0===this.children.length?e("/>"):this._addChildren(e)},r.Element=n,r.escapeXml=i},{}],24:[function(e,t,r){"use strict";var n=e("./parse");n.availableSaxParsers.push(n.bestSaxParser=e("./sax/sax_ltx")),t.exports=e("./index")},{"./index":25,"./parse":26,"./sax/sax_ltx":27}],25:[function(e,t,r){"use strict";var n=e("./parse");r.Element=e("./dom-element"),r.escapeXml=e("./element").escapeXml,r.parse=n.parse,r.Parser=n.Parser,r.availableSaxParsers=n.availableSaxParsers,r.bestSaxParser=n.bestSaxParser},{"./dom-element":22,"./element":23,"./parse":26}],26:[function(e,t,r){"use strict";var n=e("events"),i=e("util"),s=e("./dom-element");r.availableSaxParsers=[],r.bestSaxParser=null;var o=["./sax/sax_expat.js","./sax/sax_ltx.js","./sax/sax_saxjs.js"];o.forEach(function(t){var n;try{n=e(t)}catch(i){}n&&(r.availableSaxParsers.push(n),r.bestSaxParser||(r.bestSaxParser=n))}),r.Parser=function(e){n.EventEmitter.call(this);var t=this,i=e||r.bestSaxParser;if(!i)throw new Error("No SAX parser available");this.parser=new i;var o;this.parser.addListener("startElement",function(e,t){var r=new s(e,t);o=o?o.cnode(r):r}),this.parser.addListener("endElement",function(e){o&&e===o.name&&(o.parent?o=o.parent:t.tree||(t.tree=o,o=void 0))}),this.parser.addListener("text",function(e){o&&o.t(e)}),this.parser.addListener("error",function(e){t.error=e,t.emit("error",e)})},i.inherits(r.Parser,n.EventEmitter),r.Parser.prototype.write=function(e){this.parser.write(e)},r.Parser.prototype.end=function(e){this.parser.end(e),this.error||(this.tree?this.emit("tree",this.tree):this.emit("error",new Error("Incomplete document")))},r.parse=function(e,t){var n=new r.Parser(t),i=null,s=null;if(n.on("tree",function(e){i=e}),n.on("error",function(e){s=e}),n.write(e),n.end(),s)throw s;return i}},{"./dom-element":22,events:260,util:281}],27:[function(e,t,r){"use strict";function n(e){return e.replace(/\&(amp|#38);/g,"&").replace(/\&(lt|#60);/g,"<").replace(/\&(gt|#62);/g,">").replace(/\&(quot|#34);/g,'"').replace(/\&(apos|#39);/g,"'").replace(/\&(nbsp|#160);/g,"\n")}var i=e("util"),s=e("events"),o=0,a=1,c=2,f=3,h=4,u=5,d=6,p=7,l=t.exports=function(){s.EventEmitter.call(this);var e,t,r,i,l,b,y,g=o,m=0;this._handleTagOpening=function(e,t,r){e?this.emit("endElement",t):(this.emit("startElement",t,r),l&&this.emit("endElement",t))},this.write=function(s){function v(){if("number"==typeof m){var e=s.slice(m,_);return m=void 0,e}}"string"!=typeof s&&(s=s.toString());var _=0;for(e&&(s=e+s,_+=e.length,e=null);_=w||47===w||62===w)&&(t=v(),_--,g=f);break;case a:62===w&&(g=o);break;case f:62===w?(this._handleTagOpening(i,t,r),t=void 0,r=void 0,i=void 0,l=void 0,g=o,m=_+1):47===w?l=!0:w>32&&(m=_,g=h);break;case h:(32>=w||61===w)&&(y=v(),_--,g=u);break;case u:61===w&&(g=d);break;case d:(34===w||39===w)&&(b=w,g=p,m=_+1);break;case p:if(w===b){var E=n(v());r[y]=E,y=void 0,g=f}}}"number"==typeof m&&m<=s.length&&(e=s.slice(m),m=0)}};i.inherits(l,s.EventEmitter),l.prototype.end=function(e){e&&this.write(e),this.write=function(){}}},{events:260,util:281}],28:[function(e,t,r){function n(e){if(e=""+e,!(e.length>1e4)){var t=/^((?:\d+)?\.?\d+) *(milliseconds?|msecs?|ms|seconds?|secs?|s|minutes?|mins?|m|hours?|hrs?|h|days?|d|years?|yrs?|y)?$/i.exec(e);if(t){var r=parseFloat(t[1]),n=(t[2]||"ms").toLowerCase();switch(n){case"years":case"year":case"yrs":case"yr":case"y":return r*u;case"days":case"day":case"d":return r*h;case"hours":case"hour":case"hrs":case"hr":case"h":return r*f;case"minutes":case"minute":case"mins":case"min":case"m":return r*c;case"seconds":case"second":case"secs":case"sec":case"s":return r*a;case"milliseconds":case"millisecond":case"msecs":case"msec":case"ms":return r}}}}function i(e){return e>=h?Math.round(e/h)+"d":e>=f?Math.round(e/f)+"h":e>=c?Math.round(e/c)+"m":e>=a?Math.round(e/a)+"s":e+"ms"}function s(e){return o(e,h,"day")||o(e,f,"hour")||o(e,c,"minute")||o(e,a,"second")||e+" ms"}function o(e,t,r){return t>e?void 0:1.5*t>e?Math.floor(e/t)+" "+r:Math.ceil(e/t)+" "+r+"s"}var a=1e3,c=60*a,f=60*c,h=24*f,u=365.25*h;t.exports=function(e,t){return t=t||{},"string"==typeof e?n(e):t["long"]?s(e):i(e)}},{}],29:[function(e,t,r){"use strict";var n=e("./lib/Client"),i=e("./lib/sasl"),s=e("node-xmpp-core");t.exports=n,t.exports.Client=n,t.exports.SASL=i,t.exports.Iq=s.IQ,s.exportCoreUtils(t.exports)},{"./lib/Client":30,"./lib/sasl":38,"node-xmpp-core":41}],30:[function(e,t,r){(function(r){"use strict";function n(e){this.options={},e&&(this.options=e),this.availableSaslMechanisms=[y,g,b,l,p], this.options.autostart!==!1&&this.connect()}var i,s,o,a=e("./session"),c=e("node-xmpp-core"),f=c.JID,h=c.Stanza,u=c.inherits,d=e("./sasl"),p=e("./authentication/anonymous"),l=e("./authentication/plain"),b=e("./authentication/digestmd5"),y=e("./authentication/xoauth2"),g=e("./authentication/external"),m=e("child_process").exec,v=e("debug")("xmpp:client"),_="jabber:client",w="jabber:iq:register",S="urn:ietf:params:xml:ns:xmpp-sasl",E="urn:ietf:params:xml:ns:xmpp-bind",k="urn:ietf:params:xml:ns:xmpp-session",x=0,A=1,B=2,I=3,C=4,j=5,R="sess",M="bind";if("undefined"==typeof P)var P=null,O=null;"function"==typeof P?i=function(e){return O(e)}:(o=e("buffer").Buffer,i=function(e){return new o(e,"base64").toString("utf8")}),"function"==typeof O?s=function(e){return P(e)}:(o=e("buffer").Buffer,s=function(e){return new o(e,"utf8").toString("base64")}),u(n,a),n.NS_CLIENT=_,n.prototype.connect=function(){return this.options.bosh&&this.options.bosh.prebind?this._connectViaBosh():void this._useStandardConnect()},n.prototype._useStandardConnect=function(){this.options.xmlns=_,delete this.did_bind,delete this.did_session,this.state=x,this.on("end",function(){this.state=x,delete this.did_bind,delete this.did_session}),a.call(this,this.options),this.options.jid=this.jid,this.connection.on("disconnect",function(e){this.state=x,this.connection.reconnect||(e&&this.emit("error",e),this.emit("offline")),delete this.did_bind,delete this.did_session}.bind(this)),this.options.preferred?this.preferredSaslMechanism=this.options.preferred:this.preferredSaslMechanism="DIGEST-MD5";var e=d.detectMechanisms(this.options,this.availableSaslMechanisms);this.availableSaslMechanisms=e},n.prototype._connectViaBosh=function(){v("load bosh prebind");var e=this.options.bosh.prebind;delete this.options.bosh.prebind;var t="node "+r+"/prebind.js ";delete this.options.bosh.prebind,t+=encodeURI(JSON.stringify(this.options)),m(t,function(t,r,n){if(t)e(t,null);else{var i=r.match(/rid:+[ 0-9]*/i),s=r.match(/sid:+[ a-z+'"-_A-Z+0-9]*/i);if(!i||!s)return e(n);if(i=i[0].split(":")[1].trim(),s=s[0].split(":")[1].replace("'","").replace("'","").trim(),i&&s)return e(null,{rid:i,sid:s});e(n)}})},n.prototype.onStanza=function(e){return"stream:error"===e.name?this._handleStreamError(e):this.state!==j&&e.is("features")?(this.streamFeatures=e,this.useFeatures()):void this._handleStanza(e)},n.prototype._handleStanza=function(e){switch(this.state){case j:this.emit("stanza",e);break;case x:this.emit("stanza:preauth",e);break;case A:this._handleAuthState(e);break;case I:e.is("iq")&&e.attrs.id===M&&this._handleBindState(e);break;case C:e.is("iq")===!0&&e.attrs.id===R&&this._handleSessionState(e)}},n.prototype._handleStreamError=function(e){this.reconnect||this.emit("error",e)},n.prototype._handleSessionState=function(e){"result"===e.attrs.type?(this.state=B,this.did_session=!0,this.useFeatures()):this.emit("error","Cannot bind resource")},n.prototype._handleBindState=function(e){if("result"===e.attrs.type){this.state=B,this.did_bind=!0;var t=e.getChild("bind",E);t&&t.getChild("jid")&&(this.jid=new f(t.getChild("jid").getText())),this.useFeatures()}else this.emit("error","Cannot bind resource")},n.prototype._handleAuthState=function(e){if(e.is("challenge",S)){var t=i(e.getText()),r=s(this.mech.challenge(t)),n=new h.Element("response",{xmlns:S}).t(r);this.send(n)}else e.is("success",S)?(this.mech=null,this.state=B,this.emit("auth")):this.emit("error","XMPP authentication failure")},n.prototype._handlePreAuthState=function(){this.state=A;var e=this.streamFeatures.getChild("mechanisms",S).getChildren("mechanism",S).map(function(e){return e.getText()});if(this.mech=d.selectMechanism(e,this.preferredSaslMechanism,this.availableSaslMechanisms),this.mech){this.mech.authzid=this.jid.bare().toString(),this.mech.authcid=this.jid.local,this.mech.password=this.password,this.mech.api_key=this.api_key,this.mech.access_token=this.access_token,this.mech.oauth2_token=this.oauth2_token,this.mech.oauth2_auth=this.oauth2_auth,this.mech.realm=this.jid.domain,this.actAs&&(this.mech.actAs=this.actAs.user),this.mech.digest_uri="xmpp/"+this.jid.domain;var t=s(this.mech.auth()),r=this.mech.authAttrs();r.xmlns=S,r.mechanism=this.mech.name,this.send(new h.Element("auth",r).t(t))}else this.emit("error",new Error("No usable SASL mechanism"))},n.prototype.useFeatures=function(){if(this.state===x&&this.register)delete this.register,this.doRegister();else if(this.state===x&&this.streamFeatures.getChild("mechanisms",S))this._handlePreAuthState();else if(this.state===B&&!this.did_bind&&this.streamFeatures.getChild("bind",E)){this.state=I;var e=new h.Element("iq",{type:"set",id:M}).c("bind",{xmlns:E});this.jid.resource&&e.c("resource").t(this.jid.resource),this.send(e)}else if(this.state===B&&!this.did_session&&this.streamFeatures.getChild("session",k)){this.state=C;var t=new h.Element("iq",{type:"set",to:this.jid.domain,id:R}).c("session",{xmlns:k});this.send(t)}else this.state===B&&(this.state=j,this.emit("online",{jid:this.jid}))},n.prototype.doRegister=function(){var e="register"+Math.ceil(99999*Math.random()),t=new h.Element("iq",{type:"set",id:e,to:this.jid.domain}).c("query",{xmlns:w}).c("username").t(this.jid.local).up().c("password").t(this.password);this.send(t);var r=this,n=function(t){t.is("iq")&&t.attrs.id===e&&(r.removeListener("stanza",n),"result"===t.attrs.type?r.useFeatures():r.emit("error",new Error("Registration error")))};this.on("stanza:preauth",n)},n.prototype.getSaslMechanisms=function(){return this.availableSaslMechanisms},n.prototype.clearSaslMechanism=function(){this.availableSaslMechanisms=[]},n.prototype.registerSaslMechanism=function(e){-1===this.availableSaslMechanisms.indexOf(e)&&this.availableSaslMechanisms.push(e)},n.prototype.unregisterSaslMechanism=function(e){var t=this.availableSaslMechanisms.indexOf(e);t>=0&&(this.availableSaslMechanisms=this.availableSaslMechanisms.splice(t,1))},t.exports=n}).call(this,"/node_modules/node-xmpp-client/lib")},{"./authentication/anonymous":31,"./authentication/digestmd5":32,"./authentication/external":33,"./authentication/plain":35,"./authentication/xoauth2":36,"./sasl":38,"./session":39,buffer:64,child_process:61,debug:8,"node-xmpp-core":41}],31:[function(e,t,r){"use strict";function n(){}var i=e("./mechanism"),s=e("node-xmpp-core").inherits;s(n,i),n.prototype.name="ANONYMOUS",n.prototype.auth=function(){return this.authzid},n.prototype.match=function(){return!0},t.exports=n},{"./mechanism":34,"node-xmpp-core":41}],32:[function(e,t,r){"use strict";function n(e,t){var r=u.createHash("md5");return r.update(e),r.digest(t||"binary")}function i(e){return n(e,"hex")}function s(e){for(var t={};e;){var r;(r=/^(.+?)=(.*?[^\\]),\s*(.*)/.exec(e))?(t[r[1]]=r[2].replace(/\"/g,""),e=r[3]):(r=/^(.+?)=(.+?),\s*(.*)/.exec(e))?(t[r[1]]=r[2],e=r[3]):(r=/^(.+?)="(.*?[^\\])"$/.exec(e))?(t[r[1]]=r[2],e=r[3]):(r=/^(.+?)=(.+?)$/.exec(e))?(t[r[1]]=r[2],e=r[3]):e=null}return t}function o(e){var t="";for(var r in e){var n=e[r];n&&(t+=","+r+'="'+n+'"')}return t.substr(1)}function a(e,t,r){for(;e.lengtht;t++)e+=String.fromCharCode(48+Math.ceil(10*Math.random()));return e}function f(){this.nonce_count=0,this.cnonce=c(),this.authcid=null,this.actAs=null,this.realm=null,this.password=null}var h=e("node-xmpp-core").inherits,u=e("crypto"),d=e("./mechanism");h(f,d),f.prototype.name="DIGEST-MD5",f.prototype.auth=function(){return""},f.prototype.getNC=function(){return a(this.nonce_count.toString(),8,"0")},f.prototype.responseValue=function(e){var t=s(e);t.realm&&(this.realm=t.realm);var r;if(t.nonce&&t.qop){this.nonce_count++;var o=n(this.authcid+":"+this.realm+":"+this.password)+":"+t.nonce+":"+this.cnonce;this.actAs&&(o+=":"+this.actAs);var a="AUTHENTICATE:"+this.digest_uri;("auth-int"===t.qop||"auth-conf"===t.qop)&&(a+=":00000000000000000000000000000000"),r=i(i(o)+":"+t.nonce+":"+this.getNC()+":"+this.cnonce+":"+t.qop+":"+i(a))}return r},f.prototype.challenge=function(e){var t=s(e);t.realm&&(this.realm=t.realm);var r;if(t.nonce&&t.qop){var n=this.responseValue(e);r={username:this.authcid,realm:this.realm,nonce:t.nonce,cnonce:this.cnonce,nc:this.getNC(),qop:t.qop,"digest-uri":this.digest_uri,response:n,charset:"utf-8"},this.actAs&&(r.authzid=this.actAs)}else if(t.rspauth)return"";return o(r)},f.prototype.serverChallenge=function(){var e={};return e.realm="",this.nonce=e.nonce=c(),e.qop="auth",this.charset=e.charset="utf-8",e.algorithm="md5-sess",o(e)},f.prototype.response=function(e){var t=s(e);return this.authcid=t.username,t.nonce!==this.nonce?!1:t.cnonce?(this.cnonce=t.cnonce,this.charset!==t.charset?!1:(this.response=t.response,!0)):!1},f.prototype.match=function(e){return e.password?!0:!1},t.exports=f},{"./mechanism":34,crypto:68,"node-xmpp-core":41}],33:[function(e,t,r){"use strict";function n(){}var i=e("node-xmpp-core").inherits,s=e("./mechanism");i(n,s),n.prototype.name="EXTERNAL",n.prototype.auth=function(){return this.authzid},n.prototype.match=function(e){return e.credentials?!0:!1},t.exports=n},{"./mechanism":34,"node-xmpp-core":41}],34:[function(e,t,r){"use strict";function n(){}var i=e("node-xmpp-core").inherits,s=e("events").EventEmitter;i(n,s),n.prototype.authAttrs=function(){return{}},t.exports=n},{events:260,"node-xmpp-core":41}],35:[function(e,t,r){"use strict";function n(){}var i=e("node-xmpp-core").inherits,s=e("./mechanism");i(n,s),n.prototype.name="PLAIN",n.prototype.auth=function(){return this.authzid+"\x00"+this.authcid+"\x00"+this.password},n.prototype.match=function(e){return e.password?!0:!1},t.exports=n},{"./mechanism":34,"node-xmpp-core":41}],36:[function(e,t,r){"use strict";function n(){this.oauth2_auth=null,this.authzid=null}var i=e("node-xmpp-core").inherits,s=e("./mechanism");i(n,s),n.prototype.name="X-OAUTH2",n.prototype.NS_GOOGLE_AUTH="http://www.google.com/talk/protocol/auth",n.prototype.auth=function(){return"\x00"+this.authzid+"\x00"+this.oauth2_token},n.prototype.authAttrs=function(){return{"auth:service":"oauth2","xmlns:auth":this.oauth2_auth}},n.prototype.match=function(e){return e.oauth2_auth===n.prototype.NS_GOOGLE_AUTH},t.exports=n},{"./mechanism":34,"node-xmpp-core":41}],37:[function(e,t,r){(function(r){"use strict";function n(e){var t=this;if(i.call(this),this.boshURL=e.bosh.url,this.jid=e.jid,this.wait=e.bosh.wait||60,this.xmlnsAttrs={xmlns:"http://jabber.org/protocol/httpbind","xmlns:xmpp":"urn:xmpp:xbosh","xmlns:stream":"http://etherx.jabber.org/streams"},e.xmlns)for(var n in e.xmlns)n?this.xmlnsAttrs["xmlns:"+n]=e.xmlns[n]:this.xmlnsAttrs.xmlns=e.xmlns[n];this.currentRequests=0,this.queue=[],this.rid=Math.ceil(9999999999*Math.random()),this.request({to:this.jid.domain,ver:"1.6",wait:this.wait,hold:"1",content:this.contentType,"xmpp:version":"1.0"},[],function(e,n){e?t.emit("error",e):n&&n.attrs&&(t.sid=n.attrs.sid,t.maxRequests=parseInt(n.attrs.requests,10)||2,t.sid&&t.maxRequests>0?(t.emit("connect"),t.processResponse(n),r.nextTick(t.mayRequest.bind(t))):t.emit("error","Invalid parameters"))})}var i=e("events").EventEmitter,s=e("node-xmpp-core"),o=s.inherits,a=s.ltx,c=e("request"),f=e("debug")("xmpp:client:bosh");o(n,i),n.prototype.contentType="text/xml; charset=utf-8",n.prototype.send=function(e){this.queue.push(e.root()),r.nextTick(this.mayRequest.bind(this))},n.prototype.startStream=function(){var e=this;this.rid++,this.request({to:this.jid.domain,"xmpp:restart":"true"},[],function(t,n){t?(e.emit("error",t),e.emit("disconnect"),e.emit("end"),delete e.sid,e.emit("close")):(e.streamOpened=!0,n&&e.processResponse(n),r.nextTick(e.mayRequest.bind(e)))})},n.prototype.processResponse=function(e){if(f("process bosh server response "+e.toString()),e&&e.children)for(var t=0;t0&&this.currentRequests=400)return r(new Error("HTTP status "+o.statusCode));var f;try{f=a.parse(c)}catch(h){return r(h)}f&&"terminate"===f.attrs.type&&f.attrs.condition?r(new Error(f.attrs.condition)):f?r(null,f):r(new Error("no "))}),this.currentRequests++},t.exports=n}).call(this,e("_process"))},{_process:264,debug:8,events:260,"node-xmpp-core":41,request:7}],38:[function(e,t,r){"use strict";function n(e,t,r){var n,i=[],s={};return Array.isArray(r)&&(i=i.concat(r)),i.forEach(function(e){s[e.prototype.name]=e}),s[t]&&e.indexOf(t)>=0&&(n=s[t]),i.forEach(function(t){!n&&e.indexOf(t.prototype.name)>=0&&(n=t)}),n?new n:null}function i(e,t){var r=t||[],n=[];return r.forEach(function(t){var r=t.prototype.match;r(e)&&n.push(t)}),n}var s=e("./authentication/mechanism");r.selectMechanism=n,r.detectMechanisms=i,r.AbstractMechanism=s},{"./authentication/mechanism":34}],39:[function(e,t,r){(function(r){"use strict";function n(e){s.call(this),this.setOptions(e),e.websocket&&e.websocket.url?(p("start websocket connection"),this._setupWebsocketConnection(e)):e.bosh&&e.bosh.url?(p("start bosh connection"),this._setupBoshConnection(e)):(p("start socket connection"),this._setupSocketConnection(e))}var i=e("tls"),s=e("events").EventEmitter,o=e("node-xmpp-core"),a=o.inherits,c=o.Connection,f=o.JID,h=o.SRV,u=e("./bosh"),d=e("./websockets"),p=e("debug")("xmpp:client:session");a(n,s),n.prototype._setupSocketConnection=function(e){var t={xmlns:{"":e.xmlns},streamAttrs:{version:"1.0",to:this.jid.domain},serialized:e.serialized};for(var r in e)r in t||(t[r]=e[r]);if(this.connection=new c(t),this._addConnectionListeners(),e.host)this._socketConnectionToHost(e);else{if(!h)throw new Error("Cannot load SRV");this._performSrvLookup(e)}},n.prototype._socketConnectionToHost=function(e){var t=this;e.legacySSL?(this.connection.allowTLS=!1,this.connection.connect({socket:function(){return i.connect(e.port||5223,e.host,e.credentials||{},function(){this.socket.authorized?t.emit("connect",this.socket):t.emit("error","unauthorized")}.bind(this))}})):(e.credentials&&(this.connection.credentials=i.createSecureContext(e.credentials)),e.disallowTLS&&(this.connection.allowTLS=!1),this.connection.listen({socket:function(){r.nextTick(function(){this.socket.connect(e.port||5222,e.host)}.bind(this));var t=e.socket;return e.socket=null,t}}))},n.prototype._performSrvLookup=function(e){if(e.legacySSL)throw new Error("LegacySSL mode does not support DNS lookups");e.credentials&&(this.connection.credentials=i.createSecureContext(e.credentials)),e.disallowTLS&&(this.connection.allowTLS=!1),this.connection.listen({socket:h.connect({socket:e.socket,services:["_xmpp-client._tcp"],domain:this.jid.domain,defaultPort:5222})})},n.prototype._setupBoshConnection=function(e){this.connection=new u({jid:this.jid,bosh:e.bosh}),this._addConnectionListeners(),this.connection.on("connected",function(){this.connection.startStream&&this.connection.startStream()}.bind(this))},n.prototype._setupWebsocketConnection=function(e){this.connection=new d({jid:this.jid,websocket:e.websocket}),this._addConnectionListeners(),this.connection.on("connected",function(){this.connection.startStream&&this.connection.startStream()}.bind(this))},n.prototype.setOptions=function(e){this.jid="string"==typeof e.jid?new f(e.jid):e.jid,this.password=e.password,this.preferredSaslMechanism=e.preferredSaslMechanism,this.api_key=e.api_key,this.access_token=e.access_token,this.oauth2_token=e.oauth2_token,this.oauth2_auth=e.oauth2_auth,this.register=e.register,"string"==typeof e.actAs?this.actAs=new f(e.actAs):this.actAs=e.actAs},n.prototype._addConnectionListeners=function(e){e=e||this.connection,e.on("stanza",this.onStanza.bind(this)),e.on("drain",this.emit.bind(this,"drain")),e.on("end",this.emit.bind(this,"end")),e.on("close",this.emit.bind(this,"close")),e.on("error",this.emit.bind(this,"error")),e.on("connect",this.emit.bind(this,"connect")),e.on("reconnect",this.emit.bind(this,"reconnect")),e.on("disconnect",this.emit.bind(this,"disconnect")),e.startStream&&(e.on("connect",function(){e.startStream()}),this.on("auth",function(){e.startStream()}))},n.prototype.pause=function(){this.connection&&this.connection.pause&&this.connection.pause()},n.prototype.resume=function(){this.connection&&this.connection.resume&&this.connection.resume()},n.prototype.send=function(e){return this.connection?this.connection.send(e):!1},n.prototype.end=function(){this.connection&&this.connection.end()},n.prototype.onStanza=function(){},t.exports=n}).call(this,e("_process"))},{"./bosh":37,"./websockets":40,_process:264,debug:8,events:260,"node-xmpp-core":41,tls:61}],40:[function(e,t,r){"use strict";function n(e){i.call(this),this.url=e.websocket.url,this.jid=e.jid,this.xmlns={},this.websocket=new h(this.url,["xmpp"]),this.websocket.onopen=this.onopen.bind(this),this.websocket.onmessage=this.onmessage.bind(this),this.websocket.onclose=this.onclose.bind(this),this.websocket.onerror=this.onerror.bind(this)}var i=e("events").EventEmitter,s=e("node-xmpp-core"),o=s.Element,a=s.StreamParser,c=s.Connection,f=s.inherits,h=e("faye-websocket")&&e("faye-websocket").Client?e("faye-websocket").Client:window.WebSocket,u=e("debug")("xmpp:client:websockets");f(n,i),n.prototype.maxStanzaSize=65535,n.prototype.xmppVersion="1.0",n.prototype.onopen=function(){this.startParser(),this.emit("connected")},n.prototype.startParser=function(){var e=this;this.parser=new a.StreamParser(this.maxStanzaSize),this.parser.on("start",function(t){e.streamAttrs=t,e.streamNsAttrs={};for(var r in t)("xmlns"===r||"xmlns:"===r.substr(0,6))&&(e.streamNsAttrs[r]=t[r]);e.emit("streamStart",t)}),this.parser.on("stanza",function(t){e.onStanza(t)}),this.parser.on("error",this.onerror.bind(this)),this.parser.on("end",function(){e.stopParser(),e.end()})},n.prototype.stopParser=function(){this.parser&&delete this.parser},n.prototype.onmessage=function(e){u("ws msg <--",e.data),e&&e.data&&this.parser&&this.parser.write(e.data)},n.prototype.onStanza=function(e){e.is("error",c.NS_STREAM)?this.emit("error",e):this.emit("stanza",e)},n.prototype.startStream=function(){var e={};for(var t in this.xmlns)this.xmlns.hasOwnProperty(t)&&(t?e["xmlns:"+t]=this.xmlns[t]:e.xmlns=this.xmlns[t]);this.xmppVersion&&(e.version=this.xmppVersion),this.streamTo&&(e.to=this.streamTo),this.streamId&&(e.id=this.streamId),this.jid&&(e.to=this.jid.domain),e.xmlns="jabber:client",e["xmlns:stream"]=c.NS_STREAM;var r=new o("stream:stream",e);r.t(" ");var n=r.toString();this.send(n.substr(0,n.indexOf(" "))),this.streamOpened=!0},n.prototype.send=function(e){e.root&&(e=e.root()),e=e.toString(),u("ws send -->",e),this.websocket.send(e)},n.prototype.onclose=function(){this.emit("disconnect"),this.emit("close")},n.prototype.end=function(){this.send(""),this.emit("disconnect"),this.emit("end"),this.websocket&&this.websocket.close()},n.prototype.onerror=function(e){this.emit("error",e)},t.exports=n},{debug:8,events:260,"faye-websocket":63,"node-xmpp-core":41}],41:[function(e,t,r){"use strict";var n=e("./lib/Stanza"),i=e("./lib/IQ"),s=e("./lib/Presence"),o=e("./lib/Message"),a=e("./lib/Connection"),c=e("./lib/StreamParser"),f=e("node-xmpp-jid").JID,h=e("ltx"),u=e("inherits");n.Iq=i,n.Presence=s,n.Message=o,n.Element=h.Element,n.Stanza=n,r.SRV=e("./lib/SRV"),r.exportCoreUtils=function(e){e.Connection=a,e.StreamParser=c,e.Stanza=n,e.createStanza=n.createStanza,e.IQ=i,e.Presence=s,e.Message=o,e.ltx=h,e.Element=h.Element,e.createElement=h.createElement,e.escapeXML=h.escapeXML,e.escapeXMLText=h.escapeXMLText,e.Parser=h.Parser,e.parse=h.parse,e.JID=f,e.inherits=u},r.exportCoreUtils(r)},{"./lib/Connection":42,"./lib/IQ":43,"./lib/Message":44,"./lib/Presence":45,"./lib/SRV":46,"./lib/Stanza":47,"./lib/StreamParser":48,inherits:10,ltx:49,"node-xmpp-jid":55}],42:[function(e,t,r){"use strict";function n(e,t){var r=l({},t);return r.initialDelay=t&&(t.initialReconnectDelay||t.reconnectDelay)||m,r.maxDelay=t&&t.maxReconnectDelay||v,r.immediate=t&&t.socket&&"function"!=typeof t.socket,r.type=t&&t.delayType,r.emitter=e,r}function i(e){a.call(this),this.streamAttrs=e&&e.streamAttrs||{},this.xmlns=e&&e.xmlns||{},this.xmlns.stream=y,this.streamOpen=e&&e.streamOpen||_,this.streamClose=e&&e.streamClose||w,this.rejectUnauthorized=!(!e||!e.rejectUnauthorized),this.serialized=!(!e||!e.serialized),this.requestCert=!(!e||!e.requestCert),this.servername=e&&e.servername,this._setupSocket(n(this,e)),this.once("reconnect",function(){this.reconnect=e&&e.reconnect})}function s(e){return e.children?e.children.reduce(function(e,t){return e+s(t)},""):e}var o=e("net"),a=e("events").EventEmitter,c=e("inherits"),f=e("ltx"),h=e("reconnect-core"),u=e("./StreamParser"),d=e("tls-connect"),p=e("debug")("xmpp:connection"),l=e("lodash.assign"),b="urn:ietf:params:xml:ns:xmpp-tls",y="http://etherx.jabber.org/streams",g="urn:ietf:params:xml:ns:xmpp-streams",m=1e3,v=3e4,_="stream:stream",w="";c(i,a),i.prototype.NS_XMPP_TLS=b,i.NS_STREAM=y,i.prototype.NS_XMPP_STREAMS=g,i.prototype.allowTLS=!0,i.prototype._setupSocket=function(e){p("setup socket");var t={},r=h(function(e){var n=this.socket;return"on"===e.preserve?(e.preserve=t,t=e):e=t=e.preserve?e.preserve:e||t,"function"==typeof e.socket?(p("use lazy socket"),this.socket=e.socket.call(this)):(p("use standard socket"),this.socket=e.socket,e.socket=null,this.socket&&this.once("connect",function(){r.options.immediate=!1})),this.socket=this.socket||new o.Socket,n!==this.socket&&this.setupStream(),this.socket}.bind(this));r(r.options=e);var n=this.end;this.end=this.disconnect=function(){this.closeStream(),n()},this.on("connection",function(){this.parser||this.startParser()}),this.on("end",function(){t={}})},i.prototype.setupStream=function(){p("setup stream"),this.socket.on("end",this.onEnd.bind(this)),this.socket.on("data",this.onData.bind(this)),this.socket.on("close",this.onClose.bind(this)),this.socket.on("data",this.emit.bind(this,"data")),this.socket.on("drain",this.emit.bind(this,"drain")),this.socket.on("error",function(){}),this.socket.serializeStanza||(this.serialized?this.socket.serializeStanza=function(e,t){e.write(function(e){t(e)})}:this.socket.serializeStanza=function(e,t){t(e.toString())})},i.prototype.pause=function(){this.socket.pause&&this.socket.pause()},i.prototype.resume=function(){this.socket.resume&&this.socket.resume()},i.prototype.send=function(e){if(this.socket&&this.streamOpened){if(!this.socket.writable)return void this.socket.end();p("send: "+e.toString());var t=!0;if(e.root){var r=this.rmXmlns(e.root());this.socket.serializeStanza(r,function(e){t=this.write(e)}.bind(this.socket))}else t=this.socket.write(e);return t}},i.prototype.startParser=function(){var e=this;this.parser=new u.StreamParser(this.maxStanzaSize),this.parser.on("streamStart",function(t){e.streamNsAttrs={};for(var r in t)("xmlns"===r||"xmlns:"===r.substr(0,6))&&(e.streamNsAttrs[r]=t[r]);e.emit("streamStart",t)}),this.parser.on("stanza",function(t){e.onStanza(e.addStreamNs(t))}),this.parser.on("error",function(t){e.error(t.condition||"internal-server-error",t.message)}),this.parser.once("end",function(){e.stopParser(),e.reconnect?e.once("reconnect",e.startParser.bind(e)):e.end()})},i.prototype.stopParser=function(){if(this.parser){var e=this.parser;this.parser=null,e.end()}},i.prototype.openStream=function(){var e={};for(var t in this.xmlns)this.xmlns.hasOwnProperty(t)&&(t?e["xmlns:"+t]=this.xmlns[t]:e.xmlns=this.xmlns[t]);for(t in this.streamAttrs)this.streamAttrs.hasOwnProperty(t)&&(e[t]=this.streamAttrs[t]);this.streamTo&&(e.to=this.streamTo);var r,n=new f.Element(this.streamOpen,e);if("stream:stream"===n.name){n.t(" ");var i=n.toString();r=i.substr(0,i.indexOf(" "))}else r=n.toString();this.streamOpened=!0,this.send(r)},i.prototype.startStream=i.prototype.openStream,i.prototype.closeStream=function(){this.send(this.streamClose),this.streamOpened=!1},i.prototype.endStream=i.prototype.closeStream,i.prototype.onData=function(e){p("receive: "+e.toString("utf8")),this.parser&&this.parser.write(e)},i.prototype.setSecure=function(e,t){this.socket.removeAllListeners("data"),this.socket.removeAllListeners("drain"),this.socket.removeAllListeners("close"),this.socket.clearTimer&&this.socket.clearTimer();var r=d({socket:this.socket,rejectUnauthorized:this.rejectUnauthorized,credentials:e||this.credentials,requestCert:this.requestCert,isServer:!!t},function(){this.isSecure=!0,this.once("disconnect",function(){this.isSecure=!1}),r.emit("connect",r)}.bind(this));r.on("clientError",this.emit.bind(this,"error")),this.reconnect||(this.reconnect=!0,this.once("reconnect",function(){this.reconnect=!1})),this.stopParser(),this.listen({socket:r,preserve:"on"})},i.prototype.onStanza=function(e){if(e.is("error",y)){var t=new Error(""+s(e));t.stanza=e,this.socket.emit("error",t)}else e.is("features",this.NS_STREAM)&&this.allowTLS&&!this.isSecure&&e.getChild("starttls",this.NS_XMPP_TLS)?this.send(new f.Element("starttls",{xmlns:this.NS_XMPP_TLS})):this.allowTLS&&e.is("proceed",this.NS_XMPP_TLS)?this.setSecure():this.emit("stanza",e)},i.prototype.addStreamNs=function(e){for(var t in this.streamNsAttrs)e.attrs[t]||"xmlns"===t&&this.streamNsAttrs[t]===this.xmlns[""]||(e.attrs[t]=this.streamNsAttrs[t]);return e},i.prototype.rmXmlns=function(e){for(var t in this.xmlns){var r=t?"xmlns:"+t:"xmlns";e.attrs[r]===this.xmlns[t]&&(e.attrs[r]=null)}return e},i.prototype.onEnd=function(){this.closeStream(),this.reconnect||this.emit("end")},i.prototype.onClose=function(){this.reconnect||this.emit("close")},i.prototype.error=function(e,t){if(this.emit("error",new Error(t)),this.socket&&this.socket.writable){this.streamOpened||this.openStream();var r=new f.Element("stream:error");r.c(e,{xmlns:g}),t&&r.c("text",{xmlns:g,"xml:lang":"en"}).t(t),this.send(r),this.end()}},t.exports=i},{"./StreamParser":48,debug:8,events:260,inherits:10,"lodash.assign":17,ltx:49,net:61,"reconnect-core":58,"tls-connect":59}],43:[function(e,t,r){"use strict";function n(e){i.call(this,"iq",e)}var i=e("./Stanza"),s=e("inherits");s(n,i),t.exports=n},{"./Stanza":47,inherits:10}],44:[function(e,t,r){"use strict";function n(e){i.call(this,"message",e)}var i=e("./Stanza"),s=e("inherits");s(n,i),t.exports=n},{"./Stanza":47,inherits:10}],45:[function(e,t,r){"use strict";function n(e){i.call(this,"presence",e)}var i=e("./Stanza"),s=e("inherits");s(n,i),t.exports=n},{"./Stanza":47,inherits:10}],46:[function(e,t,r){"use strict";function n(e,t){return e=parseInt(e,10),t=parseInt(t,10),t>e?-1:e>t?1:0}function i(e){var t={};e.forEach(function(e){t.hasOwnProperty(e.priority)||(t[e.priority]=[]),t[e.priority].push(e)});var r=[];return Object.keys(t).sort(n).forEach(function(e){var n=t[e],i=0;n.forEach(function(e){i+=e.weight});var s=Math.floor(Math.random()*i);i=0;var o=n[0];n.forEach(function(e){i+=e.weight,i>s&&(o=e)}),o&&r.push(o)}),r}function s(e,t){c.resolveSrv(e,function(e,r){if(e)t(e);else{var n,s=0,a=[],c=function(e,r){n=n||e,a=a.concat(r),s--,1>s&&t(a?null:n,a)},f=i(r);s=f.length,f.forEach(function(e){o(e.name,function(t,r){r&&(r=r.map(function(t){return{name:t,port:e.port}})),c(t,r)})})}})}function o(e,t){var r,n=[],i=function(e,i){r=r||e,i&&n.push(i),t(n.length>0?null:r,n)};c.lookup(e,i)}function a(e,t){function r(){e.removeListener("connect",r),e.removeListener("disconnect",n)}function n(){var n=t.shift();n?e.socket.connect(n.port,n.name):r()}return e.on("connect",r),e.on("disconnect",n),n()}var c=e("dns");r.connect=function(e){function t(n){var i=this;!i.socket&&e.socket?("function"==typeof e.socket?i.socket=e.socket.call(this):i.socket=e.socket,e.socket=null):n||(i.socket=null);var c=r.shift();return c?s(c+"."+e.domain,function(e,r){!e&&r?a(i,r):t.call(i,"retry")}):o(e.domain,function(t,n){n&&n.length>0?(n=n.map(function(t){return{name:t,port:e.defaultPort}}),a(i,n)):i.reconnect?(r=e.services.slice(),i.socket=null):(t=t||new Error("No addresses resolved for "+e.domain),i.emit("error",t))}),i.socket}var r=e.services.slice();return t}},{dns:61}],47:[function(e,t,r){"use strict";function n(e,t){s.call(this,e,t)}var i=e("inherits"),s=e("ltx/lib/Element"),o=e("node-xmpp-jid").JID;i(n,s),n.prototype.clone=function(){var e=new n(this.name,{});for(var t in this.attrs)this.attrs.hasOwnProperty(t)&&(e.attrs[t]=this.attrs[t]);for(var r=0;r"); if(t>=0&&r>=0&&r+2>t){var n=e.substring(t,r+2);e=e.replace(n,"")}}return e},n.prototype.write=function(e){if(this.parser){if(e=e.toString("utf8"),e=this.checkXMLHeader(e),this.bytesParsedOnStanzaBegin&&this.maxStanzaSize&&this.bytesParsed>this.bytesParsedOnStanzaBegin+this.maxStanzaSize)return void this.error("policy-violation","Maximum stanza size exceeded");this.bytesParsed+=e.length,this.parser.write(e)}},n.prototype.end=function(e){e&&this.write(e),delete this.parser,this.emit("end")},n.prototype.error=function(e,t){var r=new Error(t);r.condition=e,this.emit("error",r)},n.StreamParser=n,t.exports=n},{"./Stanza":47,events:260,inherits:10,"ltx/lib/Element":50,"ltx/lib/parsers/ltx":54}],49:[function(e,t,r){"use strict";var n=e("./lib/parse"),i=e("./lib/Parser"),s=e("./lib/escape"),o=e("./lib/Element");r.Element=o,r.equals=o.equals,r.createElement=o.createElement,r.escapeXML=s.escapeXML,r.escapeXMLText=s.escapeXMLText,r.Parser=i,r.parse=n},{"./lib/Element":50,"./lib/Parser":51,"./lib/escape":52,"./lib/parse":53}],50:[function(e,t,r){"use strict";function n(e,t){this.name=e,this.parent=null,this.children=[],this.setAttrs(t)}var i=e("./escape"),s=i.escapeXML,o=i.escapeXMLText;n.prototype.is=function(e,t){return this.getName()===e&&(!t||this.getNS()===t)},n.prototype.getName=function(){return this.name.indexOf(":")>=0?this.name.substr(this.name.indexOf(":")+1):this.name},n.prototype.getNS=function(){if(this.name.indexOf(":")>=0){var e=this.name.substr(0,this.name.indexOf(":"));return this.findNS(e)}return this.findNS()},n.prototype.findNS=function(e){if(e){var t="xmlns:"+e;if(this.attrs[t])return this.attrs[t];if(this.parent)return this.parent.findNS(e)}else{if(this.attrs.xmlns)return this.attrs.xmlns;if(this.parent)return this.parent.findNS()}},n.prototype.getXmlns=function(){var e={};this.parent&&(e=this.parent.getXmlns());for(var t in this.attrs){var r=t.match("xmlns:?(.*)");this.attrs.hasOwnProperty(t)&&r&&(e[this.attrs[t]]=r[1])}return e},n.prototype.setAttrs=function(e){this.attrs={},"string"==typeof e?this.attrs.xmlns=e:e&&Object.keys(e).forEach(function(t){this.attrs[t]=e[t]},this)},n.prototype.getAttr=function(e,t){if(!t)return this.attrs[e];var r=this.getXmlns();return r[t]?this.attrs[[r[t],e].join(":")]:null},n.prototype.getChild=function(e,t){return this.getChildren(e,t)[0]},n.prototype.getChildren=function(e,t){for(var r=[],n=0;n");for(var t=0;t")},n.prototype.write=function(e){e("<"),e(this.name);for(var t in this.attrs){var r=this.attrs[t];null!=r&&(e(" "),e(t),e('="'),"string"!=typeof r&&(r=r.toString()),e(s(r)),e('"'))}0===this.children.length?e("/>"):this._addChildren(e)},n.prototype.nameEquals=function(e){return this.name===e.name},n.prototype.attrsEquals=function(e){var t=this.attrs,r=Object.keys(t),n=r.length;if(n!==Object.keys(e.attrs).length)return!1;for(var i=0,s=n;s>i;i++){var o=r[i],a=t[o];if(null==a||null==e.attrs[o]){if(a!==e.attrs[o])return!1}else if(a.toString()!==e.attrs[o].toString())return!1}return!0},n.prototype.childrenEquals=function(e){var t=this.children,r=t.length;if(r!==e.children.length)return!1;for(var n=0,i=r;i>n;n++){var s=t[n];if("string"==typeof s){if(s!==e.children[n])return!1}else if(!s.equals(e.children[n]))return!1}return!0},n.prototype.equals=function(e){return this.nameEquals(e)&&this.attrsEquals(e)&&this.childrenEquals(e)?!0:!1},n.createElement=function(e,t){var r=new n(e,t),i=Array.prototype.slice.call(arguments,2);return i.forEach(function(e){r.cnode(e)}),r},n.nameEqual=function(e,t){return e.nameEquals(t)},n.attrsEqual=function(e,t){return e.attrsEquals(t)},n.childrenEqual=function(e,t){return e.childrenEquals(t)},n.equal=function(e,t){return e.equals(t)},t.exports=n},{"./escape":52}],51:[function(e,t,r){"use strict";var n=e("events").EventEmitter,i=e("inherits"),s=e("./Element"),o=e("./parsers/ltx"),a=function(e){n.call(this);var t=this.Parser=e&&e.Parser||o,r=this.Element=e&&e.Element||s;this.parser=new t;var i,a=this;this.parser.on("startElement",function(e,t){var n=new r(e,t);i=i?i.cnode(n):n}),this.parser.on("endElement",function(e){i&&e===i.name&&(i.parent?i=i.parent:a.tree||(a.tree=i,i=void 0))}),this.parser.on("text",function(e){i&&i.t(e)}),this.parser.on("error",function(e){a.error=e,a.emit("error",e)})};i(a,n),a.prototype.write=function(e){this.parser.write(e)},a.prototype.end=function(e){this.parser.end(e),this.error||(this.tree?this.emit("tree",this.tree):this.emit("error",new Error("Incomplete document")))},t.exports=a},{"./Element":50,"./parsers/ltx":54,events:260,inherits:10}],52:[function(e,t,r){"use strict";r.escapeXML=function(e){return e.replace(/\&/g,"&").replace(//g,">").replace(/"/g,""").replace(/"/g,"'")},r.escapeXMLText=function(e){return e.replace(/\&/g,"&").replace(//g,">")}},{}],53:[function(e,t,r){"use strict";var n=e("./Parser");t.exports=function(e,t){var r=new n(t),i=null,s=null;if(r.on("tree",function(e){i=e}),r.on("error",function(e){s=e}),r.write(e),r.end(),s)throw s;return i}},{"./Parser":51}],54:[function(e,t,r){"use strict";function n(e){return e.replace(/\&(amp|#38);/g,"&").replace(/\&(lt|#60);/g,"<").replace(/\&(gt|#62);/g,">").replace(/\&(quot|#34);/g,'"').replace(/\&(apos|#39);/g,"'").replace(/\&(nbsp|#160);/g,"\n")}var i=e("inherits"),s=e("events").EventEmitter,o=0,a=1,c=2,f=3,h=4,u=5,d=6,p=7,l=t.exports=function(){s.call(this);var e,t,r,i,l,b,y,g=o,m=0;this._handleTagOpening=function(e,t,r){e?this.emit("endElement",t):(this.emit("startElement",t,r),l&&this.emit("endElement",t))},this.write=function(s){function v(){if("number"==typeof m){var e=s.slice(m,_);return m=void 0,e}}"string"!=typeof s&&(s=s.toString());var _=0;for(e&&(s=e+s,_+=e.length,e=null);_=w||47===w||62===w)&&(t=v(),_--,g=f);break;case a:62===w&&(g=o);break;case f:62===w?(this._handleTagOpening(i,t,r),t=void 0,r=void 0,i=void 0,l=void 0,g=o,m=_+1):47===w?l=!0:w>32&&(m=_,g=h);break;case h:(32>=w||61===w)&&(y=v(),_--,g=u);break;case u:61===w&&(g=d);break;case d:(34===w||39===w)&&(b=w,g=p,m=_+1);break;case p:if(w===b){var E=n(v());r[y]=E,y=void 0,g=f}}}"number"==typeof m&&m<=s.length&&(e=s.slice(m),m=0)}};i(l,s),l.prototype.end=function(e){e&&this.write(e),this.write=function(){}}},{events:260,inherits:10}],55:[function(e,t,r){"use strict";var n=e("./lib/JID");t.exports=n,t.exports.JID=n,t.exports.equal=function(e,t){return e.equals(t)}},{"./lib/JID":56}],56:[function(e,t,r){"use strict";function n(e,t,r){if(this._local=null,this.user=null,this._domain=null,this._resource=null,!e||t||r){if(!t)throw new Error("Argument error");this.setLocal(e),this.setDomain(t),this.setResource(r)}else this.parseJID(e)}var i=e("./escaping");n.prototype.parseJID=function(e){var t=e.indexOf("/");-1!==t&&(this.setResource(e.substr(t+1)),e=e.substr(0,t));var r=e.indexOf("@");-1!==r&&(this.setLocal(e.substr(0,r)),e=e.substr(r+1)),this.setDomain(e)},n.prototype.toString=function(e){var t=this._domain;return this._local&&(t=this.getLocal(e)+"@"+t),this._resource&&(t=t+"/"+this._resource),t},n.prototype.toJSON=function(e){return{local:this.getLocal(e),domain:this.getDomain(),resource:this.getResource()}},n.prototype.bare=function(){return this._resource?new n(this._local,this._domain,null):this},n.prototype.equals=function(e){return this._local===e._local&&this._domain===e._domain&&this._resource===e._resource},n.prototype.setLocal=function(e,t){return t=t||i.detect(e),t&&(e=i.escape(e)),this._local=e&&e.toLowerCase(),this.user=this._local,this},n.prototype.setUser=function(){console.log("JID.setUser: Use JID.setLocal instead"),this.setLocal.apply(this,arguments)},n.prototype.getUser=function(){return console.log("JID.getUser: Use JID.getLocal instead"),this.getLocal.apply(this,arguments)},n.prototype.getLocal=function(e){e=e||!1;var t=null;return t=e?i.unescape(this._local):this._local},Object.defineProperty(n.prototype,"local",{get:n.prototype.getLocal,set:n.prototype.setLocal}),n.prototype.setDomain=function(e){return this._domain=e.toLowerCase(),this},n.prototype.getDomain=function(){return this._domain},Object.defineProperty(n.prototype,"domain",{get:n.prototype.getDomain,set:n.prototype.setDomain}),n.prototype.setResource=function(e){return this._resource=e,this},n.prototype.getResource=function(){return this._resource},Object.defineProperty(n.prototype,"resource",{get:n.prototype.getResource,set:n.prototype.setResource}),n.prototype.detectEscape=i.detectEscape,n.prototype.escapeLocal=i.escape,n.prototype.unescapeLocal=i.unescape,t.exports=n},{"./escaping":57}],57:[function(e,t,r){"use strict";t.exports.detect=function(e){if(!e)return!1;var t=e.replace(/\\20/g,"").replace(/\\22/g,"").replace(/\\26/g,"").replace(/\\27/g,"").replace(/\\2f/g,"").replace(/\\3a/g,"").replace(/\\3c/g,"").replace(/\\3e/g,"").replace(/\\40/g,"").replace(/\\5c/g,""),r=t.search(/\\| |\"|\&|\'|\/|:|<|>|@/g);return-1===r?!1:!0},t.exports.escape=function(e){return null===e?null:e.replace(/^\s+|\s+$/g,"").replace(/\\/g,"\\5c").replace(/ /g,"\\20").replace(/\"/g,"\\22").replace(/\&/g,"\\26").replace(/\'/g,"\\27").replace(/\//g,"\\2f").replace(/:/g,"\\3a").replace(//g,"\\3e").replace(/@/g,"\\40").replace(/\3a/g,"c3a")},t.exports.unescape=function(e){return null===e?null:e.replace(/\\20/g," ").replace(/\\22/g,'"').replace(/\\26/g,"&").replace(/\\27/g,"'").replace(/\\2f/g,"/").replace(/\\3a/g,":").replace(/\\3c/g,"<").replace(/\\3e/g,">").replace(/\\40/g,"@").replace(/\\5c/g,"\\")}},{}],58:[function(e,t,r){var n=e("events").EventEmitter,i=e("backoff"),s=function(){};t.exports=function(e){return function(t,r){function o(n,i){function o(e){h=s,p.removeListener("connect",d),p.removeListener("error",u),p.removeListener("close",u),p.removeListener("end",u),"Request"==p.constructor.name&&p.on("error",s)}function u(e){if(a.connected=!1,o(e),a.emit("disconnect",e),a.reconnect)try{c.backoff()}catch(t){}}function d(){c.reset(),a.connected=!0,r&&p.removeListener("connect",r),a.emit("connect",p)}if(a.reconnect){h(),a.emit("reconnect",n,i);var p=e.apply(null,f);p!==a._connection&&a.emit("connection",p),a._connection=p,h=o,p.on("error",u).on("close",u).on("end",u),t.immediate||"Request"==p.constructor.name?(a.connected=!0,a.emit("connect",p),p.once("data",function(){c.reset()})):p.on("connect",d)}}r="function"==typeof t?t:r,t="object"==typeof t?t:{initialDelay:1e3,maxDelay:3e4},r||(r=t.onConnect);var a=t.emitter||new n;a.connected=!1,a.reconnect=!0,r&&a.on("connect",r);var c=(i[t.type]||i.fibonacci)(t);c.on("backoff",function(e,t){a.emit("backoff",e,t)});var f,h=s;return c.on("ready",o),a.connect=a.listen=function(){return this.reconnect=!0,c.reset(),f=[].slice.call(arguments),o(0,0),a},a.end=a.disconnect=function(){return a.reconnect=!1,a._connection&&a._connection.end(),a.emit("disconnect"),a},a}}},{backoff:1,events:260}],59:[function(e,t,r){(function(r){"use strict";function n(e){var t={};"object"==typeof e[0]?t=e[0]:isPipeName(e[0])?t.path=e[0]:(t.port=e[0],"string"==typeof e[1]&&(t.host=e[1]));var r=e[e.length-1];return"function"==typeof r?[t,r]:[t]}function i(e,t){function r(e,t){if(/\.$/.test(e)||(e+="."),!t&&/\*/.test(e)||/[\.\*].*\*/.test(e)||/\*/.test(e)&&!/\*.*\..+\..+/.test(e))return/$./;var r=e.replace(/\*([a-z0-9\\-_\.])|[\.,\-\\\^\$+?*\[\]\(\):!\|{}]/g,function(e,t){return t?"[a-z0-9\\-_]*"+("-"===t?"\\-":t):"\\"+e});return new RegExp("^"+r+"$","i")}var n=[],i=[],s=[],o=!0,a=!1;if(t.subjectaltname&&t.subjectaltname.split(/, /g).forEach(function(e){if(/^DNS:/.test(e))n.push(e.slice(4));else if(/^IP Address:/.test(e))s.push(e.slice(11));else if(/^URI:/.test(e)){var t=url.parse(e.slice(4));t&&i.push(t.hostname)}}),f.isIP(e))a=s.some(function(t){return t===e});else{if(/\.$/.test(e)||(e+="."),n=n.map(function(e){return r(e,!0)}),i=i.map(function(e){return r(e,!1)}),n=n.concat(i),n.length>0&&(o=!1),o){var c=t.subject.CN;if(u.isArray(c))for(var h=0,d=c.length;d>h;++h)n.push(r(c[h],!0));else n.push(r(c,!0))}a=n.some(function(t){return t.test(e)})}return a}function s(e){var t=n(e),r=t[0],i=t[1];return"object"==typeof e[1]?r=u._extend(r,e[1]):"object"==typeof e[2]&&(r=u._extend(r,e[2])),i?[r,i]:[r]}function o(e,t,r,n){d(t.socket);var i=h.createSecurePair(n,!!t.isServer,!!t.requestCert,!!t.rejectUnauthorized,{NPNProtocols:r.NPNProtocols,servername:e});return c(i,t.socket),i.cleartext._controlReleased=!0,i.on("error",function(e){i.cleartext.emit("error",e)}),i}function a(){function e(){function e(){if(!y._hadError){y._hadError=!0;var e=new Error("socket hang up");e.code="ECONNRESET",y.destroy(),y.emit("error",e)}}g||y._releaseControl(),n.session&&y.setSession(n.session),g||(n.servername&&y.setServername(n.servername),n.isServer||y._start()),y.on("secure",function(){var t=y._ssl||y.ssl,r=t.verifyError();if(!r){var s=m.getPeerCertificate(),o=i(f,s);o||(r=new Error("Hostname/IP doesn't match certificate's altnames"))}if(r){if(m.authorized=!1,m.authorizationError=r.message,n.rejectUnauthorized)return m.emit("error",r),void m.destroy();m.emit("secureConnect")}else m.authorized=!0,m.emit("secureConnect");m.removeListener("end",e)}),m.once("end",e)}var t=s(arguments),n=t[0],a=t[1],c={rejectUnauthorized:"0"!==r.env.NODE_TLS_REJECT_UNAUTHORIZED,requestCert:!0,isServer:!1};n=u._extend(c,n||{});var f=n.servername||n.host||n.socket&&n.socket._host||"127.0.0.1",l={},b=n.credentials||p.createCredentials(n);h.convertNPNProtocols&&h.convertNPNProtocols(n.NPNProtocols,l);var y,g,m;if("undefined"==typeof h.TLSSocket?(g=!0,y=o(f,n,l,b),m=y.cleartext):(g=!1,y=new h.TLSSocket(n.socket,{credentials:b,isServer:!!n.isServer,requestCert:!!n.requestCert,rejectUnauthorized:!!n.rejectUnauthorized,NPNProtocols:l.NPNProtocols}),m=y),y._handle&&!y._connecting?e():(!g&&n.socket&&n.socket.once("connect",function(){d(n.socket._handle),y._handle=n.socket._handle,y._handle.owner=y,y.emit("connect")}),y.once("connect",e)),a&&m.once("secureConnect",a),!n.socket){d(!g);var v;v=n.path&&!n.port?{path:n.path}:{port:n.port,host:n.host,localAddress:n.localAddress},y.connect(v)}return m}function c(e,t){function n(e){o._controlReleased&&o.emit("error",e)}function i(){t.removeListener("error",n),t.removeListener("timeout",s)}function s(){o.emit("timeout")}e.encrypted.pipe(t),t.pipe(e.encrypted),e.encrypted.on("close",function(){r.nextTick(function(){e.encrypted.unpipe&&e.encrypted.unpipe(t),t.destroySoon()})}),e.fd=t.fd,e._handle=t._handle;var o=e.cleartext;return o.socket=t,o.encrypted=e.encrypted,o.authorized=!1,t.on("drain",function(){e.encrypted._pending&&e.encrypted._writePending&&e.encrypted._writePending(),e.cleartext._pending&&e.cleartext._writePending&&e.cleartext._writePending(),e.encrypted.read&&e.encrypted.read(0),e.cleartext.read&&e.cleartext.read(0)}),t.on("error",n),t.on("close",i),t.on("timeout",s),o}t.exports=a,a.connect=a;var f=e("net"),h=e("tls"),u=e("util"),d=e("assert"),p=e("crypto")}).call(this,e("_process"))},{_process:264,assert:62,crypto:68,net:61,tls:61,util:281}],60:[function(e,t,r){"use strict";function n(e,t){if(!(e instanceof t))throw new TypeError("Cannot call a class as a function")}function i(e,t){if(!e)throw new ReferenceError("this hasn't been initialised - super() hasn't been called");return!t||"object"!=typeof t&&"function"!=typeof t?e:t}function s(e,t){if("function"!=typeof t&&null!==t)throw new TypeError("Super expression must either be null or a function, not "+typeof t);e.prototype=Object.create(t&&t.prototype,{constructor:{value:e,enumerable:!1,writable:!0,configurable:!0}}),t&&(Object.setPrototypeOf?Object.setPrototypeOf(e,t):e.__proto__=t)}function o(e){function t(e){return e.split("/")[1]}var r=function(e){function r(e,s){if(n(this,r),void 0===s)throw new Error("Options must not be undefined!");if(null==s.room)throw new Error("You must define a room name!");s.defaultRoomComponent=s.defaultRoomComponent||"@conference.yatta.ninja",s.role="slave";var o=i(this,Object.getPrototypeOf(r).call(this,e,s));o.creds=s.credentials||{jid:"@yatta.ninja",preferred:"ANONYMOUS"},o.room=s.room,-1===o.room.indexOf("@")&&(o.room+=s.defaultRoomComponent),null!=s.host?(o.creds.host=s.host,o.creds.port=s.port):o.creds.websocket=s.websocket||{url:"wss:yatta.ninja:5281/xmpp-websocket"};var a=new c.Client(o.creds);o.xmpp=a;var h=o;return a.on("online",function(){h.setUserId(h.xmpp.jid.resource),h.room_jid=h.room+"/"+h.xmpp.jid.resource;var e=new f.Element("presence",{to:h.room_jid}).c("x",{}).up().c("role",{xmlns:"http://y.ninja/role"}).t(s.role);h.xmpp.send(e)}),a.on("error",function(e){throw new Error("XMPP error",e)}),a.on("stanza",function(e){if("error"===e.getAttr("type"))return void console.error(e.toString());var r=t(e.getAttr("from"));if(e.is("presence"))if(r===h.userId);else if("unavailable"===e.getAttr("type"))h.userLeft(r);else{var n=e.getChild("role","http://y.ninja/role").getText();h.userJoined(r,n)}else{if(r===h.userId)return!0;var i=JSON.parse(e.attrs.value);h.debug&&console.log("RECEIVED: ",i),h.receiveMessage(r,i)}}),o}return s(r,e),a(r,[{key:"disconnect",value:function(){throw new Error("XMPPConnector.disconnect is not supported!")}},{key:"reconnect",value:function(){throw new Error("XMPPConnector.reconnect is not supported!")}},{key:"send",value:function(e,t,r){var n=new f.Element("message",{to:""===e?this.room:this.room+"/"+e,type:r||"message"});n.setAttribute("value",JSON.stringify(t)),this.debug&&console.log("SENDING: ",t),this.xmpp.send(n.root())}},{key:"broadcast",value:function(e){this.send("",e,"groupchat")}},{key:"isDisconnected",value:function(){return!1}}]),r}(e.AbstractConnector);e.extend("xmpp",r)}var a=function(){function e(e,t){for(var r=0;r=0;s--)if(o[s]!=a[s])return!1;for(s=o.length-1;s>=0;s--)if(i=o[s],!c(e[i],t[i]))return!1;return!0}function u(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&&u(i,r)&&o(i,r,"Got unwanted exception"+n),e&&i&&r&&!u(i,r)||!e&&i)throw i}var p=e("util/"),l=Array.prototype.slice,b=Object.prototype.hasOwnProperty,y=t.exports=a;y.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 c=n.indexOf("\n",a+1);n=n.substring(c+1)}this.stack=n}}},p.inherits(y.AssertionError,Error),y.fail=o,y.ok=a,y.equal=function(e,t,r){e!=t&&o(e,t,r,"==",y.equal)},y.notEqual=function(e,t,r){e==t&&o(e,t,r,"!=",y.notEqual)},y.deepEqual=function(e,t,r){c(e,t)||o(e,t,r,"deepEqual",y.deepEqual)},y.notDeepEqual=function(e,t,r){c(e,t)&&o(e,t,r,"notDeepEqual",y.notDeepEqual)},y.strictEqual=function(e,t,r){e!==t&&o(e,t,r,"===",y.strictEqual)},y.notStrictEqual=function(e,t,r){e===t&&o(e,t,r,"!==",y.notStrictEqual)},y["throws"]=function(e,t,r){d.apply(this,[!0].concat(l.call(arguments)))},y.doesNotThrow=function(e,t){d.apply(this,[!1].concat(l.call(arguments)))},y.ifError=function(e){if(e)throw e};var g=Object.keys||function(e){var t=[];for(var r in e)b.call(e,r)&&t.push(r);return t}},{"util/":281}],63:[function(e,t,r){arguments[4][61][0].apply(r,arguments)},{dup:61}],64:[function(e,t,r){(function(t){function n(){function e(){}try{var t=new Uint8Array(1);return t.foo=function(){return 42},t.constructor=e,42===t.foo()&&t.constructor===e&&"function"==typeof t.subarray&&0===t.subarray(1,1).byteLength}catch(r){return!1}}function i(){return s.TYPED_ARRAY_SUPPORT?2147483647:1073741823}function s(e){return this instanceof s?(this.length=0,this.parent=void 0,"number"==typeof e?o(this,e):"string"==typeof e?a(this,e,arguments.length>1?arguments[1]:"utf8"):c(this,e)):arguments.length>1?new s(e,arguments[1]):new s(e)}function o(e,t){if(e=b(e,0>t?0:0|y(t)),!s.TYPED_ARRAY_SUPPORT)for(var r=0;t>r;r++)e[r]=0;return e}function a(e,t,r){("string"!=typeof r||""===r)&&(r="utf8");var n=0|m(t,r);return e=b(e,n),e.write(t,r),e}function c(e,t){if(s.isBuffer(t))return f(e,t);if(G(t))return h(e,t);if(null==t)throw new TypeError("must start with number, buffer, array or string");if("undefined"!=typeof ArrayBuffer){if(t.buffer instanceof ArrayBuffer)return u(e,t);if(t instanceof ArrayBuffer)return d(e,t)}return t.length?p(e,t):l(e,t)}function f(e,t){var r=0|y(t.length);return e=b(e,r),t.copy(e,0,0,r),e}function h(e,t){var r=0|y(t.length);e=b(e,r);for(var n=0;r>n;n+=1)e[n]=255&t[n];return e}function u(e,t){var r=0|y(t.length);e=b(e,r);for(var n=0;r>n;n+=1)e[n]=255&t[n];return e}function d(e,t){return s.TYPED_ARRAY_SUPPORT?(t.byteLength,e=s._augment(new Uint8Array(t))):e=u(e,new Uint8Array(t)),e}function p(e,t){var r=0|y(t.length);e=b(e,r);for(var n=0;r>n;n+=1)e[n]=255&t[n];return e}function l(e,t){var r,n=0;"Buffer"===t.type&&G(t.data)&&(r=t.data,n=0|y(r.length)),e=b(e,n);for(var i=0;n>i;i+=1)e[i]=255&r[i];return e}function b(e,t){s.TYPED_ARRAY_SUPPORT?(e=s._augment(new Uint8Array(t)),e.__proto__=s.prototype):(e.length=t,e._isBuffer=!0);var r=0!==t&&t<=s.poolSize>>>1;return r&&(e.parent=$),e}function y(e){if(e>=i())throw new RangeError("Attempt to allocate Buffer larger than maximum size: 0x"+i().toString(16)+" bytes");return 0|e}function g(e,t){if(!(this instanceof g))return new g(e,t);var r=new s(e,t);return delete r.parent,r}function m(e,t){"string"!=typeof e&&(e=""+e);var r=e.length;if(0===r)return 0;for(var n=!1;;)switch(t){case"ascii":case"binary":case"raw":case"raws":return r;case"utf8":case"utf-8":return F(e).length;case"ucs2":case"ucs-2":case"utf16le":case"utf-16le":return 2*r;case"hex":return r>>>1;case"base64":return Y(e).length;default:if(n)return F(e).length;t=(""+t).toLowerCase(),n=!0}}function v(e,t,r){var n=!1;if(t=0|t,r=void 0===r||r===1/0?this.length:0|r,e||(e="utf8"),0>t&&(t=0),r>this.length&&(r=this.length),t>=r)return"";for(;;)switch(e){case"hex":return R(this,t,r);case"utf8":case"utf-8":return B(this,t,r);case"ascii":return C(this,t,r);case"binary":return j(this,t,r);case"base64":return A(this,t,r);case"ucs2":case"ucs-2":case"utf16le":case"utf-16le":return M(this,t,r);default:if(n)throw new TypeError("Unknown encoding: "+e);e=(e+"").toLowerCase(),n=!0}}function _(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 w(e,t,r,n){return H(F(t,e.length-r),e,r,n)}function S(e,t,r,n){return H(K(t),e,r,n)}function E(e,t,r,n){return S(e,t,r,n)}function k(e,t,r,n){return H(Y(t),e,r,n)}function x(e,t,r,n){return H(V(t,e.length-r),e,r,n)}function A(e,t,r){return 0===t&&r===e.length?J.fromByteArray(e):J.fromByteArray(e.slice(t,r))}function B(e,t,r){r=Math.min(e.length,r);for(var n=[],i=t;r>i;){var s=e[i],o=null,a=s>239?4:s>223?3:s>191?2:1;if(r>=i+a){var c,f,h,u;switch(a){case 1:128>s&&(o=s);break;case 2:c=e[i+1],128===(192&c)&&(u=(31&s)<<6|63&c,u>127&&(o=u));break;case 3:c=e[i+1],f=e[i+2],128===(192&c)&&128===(192&f)&&(u=(15&s)<<12|(63&c)<<6|63&f,u>2047&&(55296>u||u>57343)&&(o=u));break;case 4:c=e[i+1],f=e[i+2],h=e[i+3],128===(192&c)&&128===(192&f)&&128===(192&h)&&(u=(15&s)<<18|(63&c)<<12|(63&f)<<6|63&h,u>65535&&1114112>u&&(o=u))}}null===o?(o=65533,a=1):o>65535&&(o-=65536,n.push(o>>>10&1023|55296),o=56320|1023&o),n.push(o),i+=a}return I(n)}function I(e){var t=e.length;if(Z>=t)return String.fromCharCode.apply(String,e);for(var r="",n=0;t>n;)r+=String.fromCharCode.apply(String,e.slice(n,n+=Z));return r}function C(e,t,r){var n="";r=Math.min(e.length,r);for(var i=t;r>i;i++)n+=String.fromCharCode(127&e[i]);return n}function j(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 R(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+=X(e[s]);return i}function M(e,t,r){for(var n=e.slice(t,r),i="",s=0;se)throw new RangeError("offset is not uint");if(e+t>r)throw new RangeError("Trying to access beyond buffer length")}function O(e,t,r,n,i,o){if(!s.isBuffer(e))throw new TypeError("buffer must be a Buffer instance");if(t>i||o>t)throw new RangeError("value is out of bounds");if(r+n>e.length)throw new RangeError("index out of range")}function T(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 D(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 L(e,t,r,n,i,s){if(t>i||s>t)throw new RangeError("value is out of bounds");if(r+n>e.length)throw new RangeError("index out of range");if(0>r)throw new RangeError("index out of range")}function N(e,t,r,n,i){return i||L(e,t,r,4,3.4028234663852886e38,-3.4028234663852886e38),W.write(e,t,r,n,23,4),r+4}function z(e,t,r,n,i){return i||L(e,t,r,8,1.7976931348623157e308,-1.7976931348623157e308),W.write(e,t,r,n,52,8),r+8}function U(e){if(e=q(e).replace(ee,""),e.length<2)return"";for(;e.length%4!==0;)e+="=";return e}function q(e){return e.trim?e.trim():e.replace(/^\s+|\s+$/g,"")}function X(e){return 16>e?"0"+e.toString(16):e.toString(16)}function F(e,t){t=t||1/0;for(var r,n=e.length,i=null,s=[],o=0;n>o;o++){if(r=e.charCodeAt(o),r>55295&&57344>r){if(!i){if(r>56319){(t-=3)>-1&&s.push(239,191,189);continue}if(o+1===n){(t-=3)>-1&&s.push(239,191,189);continue}i=r;continue}if(56320>r){(t-=3)>-1&&s.push(239,191,189),i=r;continue}r=i-55296<<10|r-56320|65536}else i&&(t-=3)>-1&&s.push(239,191,189);if(i=null,128>r){if((t-=1)<0)break;s.push(r)}else if(2048>r){if((t-=2)<0)break;s.push(r>>6|192,63&r|128)}else if(65536>r){if((t-=3)<0)break;s.push(r>>12|224,r>>6&63|128,63&r|128)}else{if(!(1114112>r))throw new Error("Invalid code point");if((t-=4)<0)break;s.push(r>>18|240,r>>12&63|128,r>>6&63|128,63&r|128)}}return s}function K(e){for(var t=[],r=0;r>8,i=r%256,s.push(i),s.push(n);return s}function Y(e){return J.toByteArray(U(e))}function H(e,t,r,n){for(var i=0;n>i&&!(i+r>=t.length||i>=e.length);i++)t[i+r]=e[i];return i}var J=e("base64-js"),W=e("ieee754"),G=e("is-array");r.Buffer=s,r.SlowBuffer=g,r.INSPECT_MAX_BYTES=50,s.poolSize=8192;var $={};s.TYPED_ARRAY_SUPPORT=void 0!==t.TYPED_ARRAY_SUPPORT?t.TYPED_ARRAY_SUPPORT:n(),s.TYPED_ARRAY_SUPPORT&&(s.prototype.__proto__=Uint8Array.prototype,s.__proto__=Uint8Array),s.isBuffer=function(e){return!(null==e||!e._isBuffer)},s.compare=function(e,t){if(!s.isBuffer(e)||!s.isBuffer(t))throw new TypeError("Arguments must be Buffers");if(e===t)return 0;for(var r=e.length,n=t.length,i=0,o=Math.min(r,n);o>i&&e[i]===t[i];)++i;return i!==o&&(r=e[i],n=t[i]),n>r?-1:r>n?1:0},s.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}},s.concat=function(e,t){if(!G(e))throw new TypeError("list argument must be an Array of Buffers.");if(0===e.length)return new s(0);var r;if(void 0===t)for(t=0,r=0;r0&&(e=this.toString("hex",0,t).match(/.{2}/g).join(" "),this.length>t&&(e+=" ... ")),""},s.prototype.compare=function(e){if(!s.isBuffer(e))throw new TypeError("Argument must be a Buffer");return this===e?0:s.compare(this,e)},s.prototype.indexOf=function(e,t){function r(e,t,r){for(var n=-1,i=0;r+i2147483647?t=2147483647:-2147483648>t&&(t=-2147483648),t>>=0,0===this.length)return-1;if(t>=this.length)return-1;if(0>t&&(t=Math.max(this.length+t,0)),"string"==typeof e)return 0===e.length?-1:String.prototype.indexOf.call(this,e,t);if(s.isBuffer(e))return r(this,e,t);if("number"==typeof e)return s.TYPED_ARRAY_SUPPORT&&"function"===Uint8Array.prototype.indexOf?Uint8Array.prototype.indexOf.call(this,e,t):r(this,[e],t);throw new TypeError("val must be string, number or Buffer")},s.prototype.get=function(e){return console.log(".get() is deprecated. Access using array indexes instead."),this.readUInt8(e)},s.prototype.set=function(e,t){return console.log(".set() is deprecated. Access using array indexes instead."),this.writeUInt8(e,t)},s.prototype.write=function(e,t,r,n){if(void 0===t)n="utf8",r=this.length,t=0;else if(void 0===r&&"string"==typeof t)n=t,r=this.length,t=0;else if(isFinite(t))t=0|t,isFinite(r)?(r=0|r,void 0===n&&(n="utf8")):(n=r,r=void 0);else{var i=n;n=t,t=0|r,r=i}var s=this.length-t;if((void 0===r||r>s)&&(r=s),e.length>0&&(0>r||0>t)||t>this.length)throw new RangeError("attempt to write outside buffer bounds");n||(n="utf8");for(var o=!1;;)switch(n){case"hex":return _(this,e,t,r);case"utf8":case"utf-8":return w(this,e,t,r);case"ascii":return S(this,e,t,r);case"binary":return E(this,e,t,r);case"base64":return k(this,e,t,r);case"ucs2":case"ucs-2":case"utf16le":case"utf-16le":return x(this,e,t,r);default:if(o)throw new TypeError("Unknown encoding: "+n);n=(""+n).toLowerCase(),o=!0}},s.prototype.toJSON=function(){return{type:"Buffer",data:Array.prototype.slice.call(this._arr||this,0)}};var Z=4096;s.prototype.slice=function(e,t){var r=this.length;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);var n;if(s.TYPED_ARRAY_SUPPORT)n=s._augment(this.subarray(e,t));else{var i=t-e;n=new s(i,void 0);for(var o=0;i>o;o++)n[o]=this[o+e]}return n.length&&(n.parent=this.parent||this),n},s.prototype.readUIntLE=function(e,t,r){e=0|e,t=0|t,r||P(e,t,this.length);for(var n=this[e],i=1,s=0;++s0&&(i*=256);)n+=this[e+--t]*i;return n},s.prototype.readUInt8=function(e,t){return t||P(e,1,this.length),this[e]},s.prototype.readUInt16LE=function(e,t){return t||P(e,2,this.length),this[e]|this[e+1]<<8},s.prototype.readUInt16BE=function(e,t){return t||P(e,2,this.length),this[e]<<8|this[e+1]},s.prototype.readUInt32LE=function(e,t){return t||P(e,4,this.length),(this[e]|this[e+1]<<8|this[e+2]<<16)+16777216*this[e+3]},s.prototype.readUInt32BE=function(e,t){return t||P(e,4,this.length),16777216*this[e]+(this[e+1]<<16|this[e+2]<<8|this[e+3])},s.prototype.readIntLE=function(e,t,r){e=0|e,t=0|t,r||P(e,t,this.length);for(var n=this[e],i=1,s=0;++s=i&&(n-=Math.pow(2,8*t)),n},s.prototype.readIntBE=function(e,t,r){e=0|e,t=0|t,r||P(e,t,this.length);for(var n=t,i=1,s=this[e+--n];n>0&&(i*=256);)s+=this[e+--n]*i;return i*=128,s>=i&&(s-=Math.pow(2,8*t)),s},s.prototype.readInt8=function(e,t){return t||P(e,1,this.length),128&this[e]?-1*(255-this[e]+1):this[e]},s.prototype.readInt16LE=function(e,t){t||P(e,2,this.length);var r=this[e]|this[e+1]<<8;return 32768&r?4294901760|r:r},s.prototype.readInt16BE=function(e,t){t||P(e,2,this.length);var r=this[e+1]|this[e]<<8;return 32768&r?4294901760|r:r},s.prototype.readInt32LE=function(e,t){return t||P(e,4,this.length),this[e]|this[e+1]<<8|this[e+2]<<16|this[e+3]<<24},s.prototype.readInt32BE=function(e,t){return t||P(e,4,this.length),this[e]<<24|this[e+1]<<16|this[e+2]<<8|this[e+3]},s.prototype.readFloatLE=function(e,t){return t||P(e,4,this.length),W.read(this,e,!0,23,4)},s.prototype.readFloatBE=function(e,t){return t||P(e,4,this.length),W.read(this,e,!1,23,4)},s.prototype.readDoubleLE=function(e,t){return t||P(e,8,this.length),W.read(this,e,!0,52,8)},s.prototype.readDoubleBE=function(e,t){return t||P(e,8,this.length),W.read(this,e,!1,52,8)},s.prototype.writeUIntLE=function(e,t,r,n){e=+e,t=0|t,r=0|r,n||O(this,e,t,r,Math.pow(2,8*r),0);var i=1,s=0;for(this[t]=255&e;++s=0&&(s*=256);)this[t+i]=e/s&255;return t+r},s.prototype.writeUInt8=function(e,t,r){return e=+e,t=0|t,r||O(this,e,t,1,255,0),s.TYPED_ARRAY_SUPPORT||(e=Math.floor(e)),this[t]=255&e,t+1},s.prototype.writeUInt16LE=function(e,t,r){return e=+e,t=0|t,r||O(this,e,t,2,65535,0),s.TYPED_ARRAY_SUPPORT?(this[t]=255&e,this[t+1]=e>>>8):T(this,e,t,!0),t+2},s.prototype.writeUInt16BE=function(e,t,r){return e=+e,t=0|t,r||O(this,e,t,2,65535,0),s.TYPED_ARRAY_SUPPORT?(this[t]=e>>>8,this[t+1]=255&e):T(this,e,t,!1),t+2},s.prototype.writeUInt32LE=function(e,t,r){return e=+e,t=0|t,r||O(this,e,t,4,4294967295,0),s.TYPED_ARRAY_SUPPORT?(this[t+3]=e>>>24,this[t+2]=e>>>16,this[t+1]=e>>>8,this[t]=255&e):D(this,e,t,!0),t+4},s.prototype.writeUInt32BE=function(e,t,r){return e=+e,t=0|t,r||O(this,e,t,4,4294967295,0),s.TYPED_ARRAY_SUPPORT?(this[t]=e>>>24,this[t+1]=e>>>16,this[t+2]=e>>>8,this[t+3]=255&e):D(this,e,t,!1),t+4},s.prototype.writeIntLE=function(e,t,r,n){if(e=+e,t=0|t,!n){var i=Math.pow(2,8*r-1);O(this,e,t,r,i-1,-i)}var s=0,o=1,a=0>e?1:0;for(this[t]=255&e;++s>0)-a&255;return t+r},s.prototype.writeIntBE=function(e,t,r,n){if(e=+e,t=0|t,!n){var i=Math.pow(2,8*r-1);O(this,e,t,r,i-1,-i)}var s=r-1,o=1,a=0>e?1:0;for(this[t+s]=255&e;--s>=0&&(o*=256);)this[t+s]=(e/o>>0)-a&255;return t+r},s.prototype.writeInt8=function(e,t,r){return e=+e,t=0|t,r||O(this,e,t,1,127,-128),s.TYPED_ARRAY_SUPPORT||(e=Math.floor(e)),0>e&&(e=255+e+1),this[t]=255&e,t+1},s.prototype.writeInt16LE=function(e,t,r){return e=+e,t=0|t,r||O(this,e,t,2,32767,-32768),s.TYPED_ARRAY_SUPPORT?(this[t]=255&e,this[t+1]=e>>>8):T(this,e,t,!0),t+2},s.prototype.writeInt16BE=function(e,t,r){return e=+e,t=0|t,r||O(this,e,t,2,32767,-32768),s.TYPED_ARRAY_SUPPORT?(this[t]=e>>>8,this[t+1]=255&e):T(this,e,t,!1),t+2},s.prototype.writeInt32LE=function(e,t,r){return e=+e,t=0|t,r||O(this,e,t,4,2147483647,-2147483648),s.TYPED_ARRAY_SUPPORT?(this[t]=255&e,this[t+1]=e>>>8,this[t+2]=e>>>16,this[t+3]=e>>>24):D(this,e,t,!0),t+4},s.prototype.writeInt32BE=function(e,t,r){return e=+e,t=0|t,r||O(this,e,t,4,2147483647,-2147483648),0>e&&(e=4294967295+e+1),s.TYPED_ARRAY_SUPPORT?(this[t]=e>>>24,this[t+1]=e>>>16,this[t+2]=e>>>8,this[t+3]=255&e):D(this,e,t,!1),t+4},s.prototype.writeFloatLE=function(e,t,r){return N(this,e,t,!0,r)},s.prototype.writeFloatBE=function(e,t,r){return N(this,e,t,!1,r)},s.prototype.writeDoubleLE=function(e,t,r){return z(this,e,t,!0,r)},s.prototype.writeDoubleBE=function(e,t,r){return z(this,e,t,!1,r)},s.prototype.copy=function(e,t,r,n){if(r||(r=0),n||0===n||(n=this.length),t>=e.length&&(t=e.length),t||(t=0),n>0&&r>n&&(n=r),n===r)return 0;if(0===e.length||0===this.length)return 0;if(0>t)throw new RangeError("targetStart out of bounds");if(0>r||r>=this.length)throw new RangeError("sourceStart out of bounds");if(0>n)throw new RangeError("sourceEnd out of bounds");n>this.length&&(n=this.length),e.length-tr&&n>t)for(i=o-1;i>=0;i--)e[i+t]=this[i+r];else if(1e3>o||!s.TYPED_ARRAY_SUPPORT)for(i=0;o>i;i++)e[i+t]=this[i+r];else e._set(this.subarray(r,r+o),t);return o},s.prototype.fill=function(e,t,r){if(e||(e=0),t||(t=0),r||(r=this.length),t>r)throw new RangeError("end < start");if(r!==t&&0!==this.length){if(0>t||t>=this.length)throw new RangeError("start out of bounds");if(0>r||r>this.length)throw new RangeError("end out of bounds");var n;if("number"==typeof e)for(n=t;r>n;n++)this[n]=e;else{var i=F(e.toString()),s=i.length;for(n=t;r>n;n++)this[n]=i[n%s]}return this}},s.prototype.toArrayBuffer=function(){if("undefined"!=typeof Uint8Array){if(s.TYPED_ARRAY_SUPPORT)return new s(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 Q=s.prototype;s._augment=function(e){return e.constructor=s,e._isBuffer=!0,e._set=e.set,e.get=Q.get,e.set=Q.set,e.write=Q.write,e.toString=Q.toString,e.toLocaleString=Q.toString,e.toJSON=Q.toJSON,e.equals=Q.equals,e.compare=Q.compare,e.indexOf=Q.indexOf,e.copy=Q.copy,e.slice=Q.slice,e.readUIntLE=Q.readUIntLE,e.readUIntBE=Q.readUIntBE,e.readUInt8=Q.readUInt8,e.readUInt16LE=Q.readUInt16LE,e.readUInt16BE=Q.readUInt16BE,e.readUInt32LE=Q.readUInt32LE,e.readUInt32BE=Q.readUInt32BE,e.readIntLE=Q.readIntLE,e.readIntBE=Q.readIntBE,e.readInt8=Q.readInt8,e.readInt16LE=Q.readInt16LE,e.readInt16BE=Q.readInt16BE,e.readInt32LE=Q.readInt32LE,e.readInt32BE=Q.readInt32BE,e.readFloatLE=Q.readFloatLE,e.readFloatBE=Q.readFloatBE,e.readDoubleLE=Q.readDoubleLE,e.readDoubleBE=Q.readDoubleBE,e.writeUInt8=Q.writeUInt8,e.writeUIntLE=Q.writeUIntLE,e.writeUIntBE=Q.writeUIntBE,e.writeUInt16LE=Q.writeUInt16LE,e.writeUInt16BE=Q.writeUInt16BE,e.writeUInt32LE=Q.writeUInt32LE,e.writeUInt32BE=Q.writeUInt32BE,e.writeIntLE=Q.writeIntLE,e.writeIntBE=Q.writeIntBE,e.writeInt8=Q.writeInt8,e.writeInt16LE=Q.writeInt16LE,e.writeInt16BE=Q.writeInt16BE,e.writeInt32LE=Q.writeInt32LE,e.writeInt32BE=Q.writeInt32BE,e.writeFloatLE=Q.writeFloatLE,e.writeFloatBE=Q.writeFloatBE,e.writeDoubleLE=Q.writeDoubleLE,e.writeDoubleBE=Q.writeDoubleBE,e.fill=Q.fill,e.inspect=Q.inspect,e.toArrayBuffer=Q.toArrayBuffer,e};var ee=/[^+\/0-9A-Za-z-_]/g}).call(this,"undefined"!=typeof global?global:"undefined"!=typeof self?self:"undefined"!=typeof window?window:{})},{"base64-js":65,ieee754:66,"is-array":67}],65:[function(e,t,r){var n="ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/";!function(e){"use strict";function t(e){var t=e.charCodeAt(0);return t===o||t===u?62:t===a||t===d?63:c>t?-1:c+10>t?t-c+26+26:h+26>t?t-h:f+26>t?t-f+26:void 0}function r(e){function r(e){f[u++]=e}var n,i,o,a,c,f;if(e.length%4>0)throw new Error("Invalid string. Length must be a multiple of 4");var h=e.length;c="="===e.charAt(h-2)?2:"="===e.charAt(h-1)?1:0,f=new s(3*e.length/4-c),o=c>0?e.length-4:e.length;var u=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===c?(a=t(e.charAt(n))<<2|t(e.charAt(n+1))>>4,r(255&a)):1===c&&(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)),f}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,c="";for(i=0,o=e.length-a;o>i;i+=3)s=(e[i]<<16)+(e[i+1]<<8)+e[i+2],c+=r(s);switch(a){case 1:s=e[e.length-1],c+=t(s>>2),c+=t(s<<4&63),c+="==";break;case 2:s=(e[e.length-2]<<8)+e[e.length-1],c+=t(s>>10),c+=t(s>>4&63),c+=t(s<<2&63),c+="="}return c}var s="undefined"!=typeof Uint8Array?Uint8Array:Array,o="+".charCodeAt(0),a="/".charCodeAt(0),c="0".charCodeAt(0),f="a".charCodeAt(0),h="A".charCodeAt(0),u="-".charCodeAt(0),d="_".charCodeAt(0);e.toByteArray=r,e.fromByteArray=i}("undefined"==typeof r?this.base64js={}:r)},{}],66:[function(e,t,r){r.read=function(e,t,r,n,i){var s,o,a=8*i-n-1,c=(1<>1,h=-7,u=r?i-1:0,d=r?-1:1,p=e[t+u];for(u+=d,s=p&(1<<-h)-1,p>>=-h,h+=a;h>0;s=256*s+e[t+u],u+=d,h-=8);for(o=s&(1<<-h)-1,s>>=-h,h+=n;h>0;o=256*o+e[t+u],u+=d,h-=8);if(0===s)s=1-f;else{if(s===c)return o?NaN:(p?-1:1)*(1/0);o+=Math.pow(2,n),s-=f}return(p?-1:1)*o*Math.pow(2,s-n)},r.write=function(e,t,r,n,i,s){var o,a,c,f=8*s-i-1,h=(1<>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=h):(o=Math.floor(Math.log(t)/Math.LN2),t*(c=Math.pow(2,-o))<1&&(o--,c*=2),t+=o+u>=1?d/c:d*Math.pow(2,1-u),t*c>=2&&(o++,c/=2),o+u>=h?(a=0,o=h):o+u>=1?(a=(t*c-1)*Math.pow(2,i),o+=u):(a=t*Math.pow(2,u-1)*Math.pow(2,i),o=0));i>=8;e[r+p]=255&a,p+=l,a/=256,i-=8);for(o=o<0;e[r+p]=255&o,p+=l,o/=256,f-=8);e[r+p-l]|=128*b}},{}],67:[function(e,t,r){var n=Array.isArray,i=Object.prototype.toString;t.exports=n||function(e){return!!e&&"[object Array]"==i.call(e)}},{}],68:[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-cipher");["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 c=e("public-encrypt");["publicEncrypt","privateEncrypt","publicDecrypt","privateDecrypt"].forEach(function(e){r[e]=c[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-cipher":69,"browserify-sign":99,"browserify-sign/algos":98,"create-ecdh":166,"create-hash":192,"create-hmac":205,"diffie-hellman":206,pbkdf2:213,"public-encrypt":214,randombytes:259}],69:[function(e,t,r){function n(e,t){var r,n;if(e=e.toLowerCase(),d[e])r=d[e].key,n=d[e].iv;else{if(!u[e])throw new TypeError("invalid suite type");r=8*u[e].key,n=u[e].iv}var i=c(t,!1,r,n);return s(e,i.key,i.iv)}function i(e,t){var r,n;if(e=e.toLowerCase(),d[e])r=d[e].key,n=d[e].iv;else{if(!u[e])throw new TypeError("invalid suite type");r=8*u[e].key,n=u[e].iv}var i=c(t,!1,r,n);return o(e,i.key,i.iv)}function s(e,t,r){if(e=e.toLowerCase(),d[e])return f.createCipheriv(e,t,r);if(u[e])return new h({key:t,iv:r,mode:e});throw new TypeError("invalid suite type")}function o(e,t,r){if(e=e.toLowerCase(),d[e])return f.createDecipheriv(e,t,r);if(u[e])return new h({key:t,iv:r,mode:e,decrypt:!0});throw new TypeError("invalid suite type")}function a(){return Object.keys(u).concat(f.getCiphers())}var c=e("evp_bytestokey"),f=e("browserify-aes/browser"),h=e("browserify-des"),u=e("browserify-des/modes"),d=e("browserify-aes/modes");r.createCipher=r.Cipher=n,r.createCipheriv=r.Cipheriv=s,r.createDecipher=r.Decipher=i,r.createDecipheriv=r.Decipheriv=o,r.listCiphers=r.getCiphers=a},{"browserify-aes/browser":72,"browserify-aes/modes":76,"browserify-des":87,"browserify-des/modes":88,evp_bytestokey:97}],70:[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;te;t=++e)128>t?r.push(t<<1):r.push(t<<1^283);return r}(),i=0,c=0,t=f=0;256>f;t=++f)r=c^c<<1^c<<2^c<<3^c<<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=c=1:(i=s^e[e[e[a^s]]],c^=e[e[c]]);return!0};var c=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=c.SBOX[s>>>24]<<24|c.SBOX[s>>>16&255]<<16|c.SBOX[s>>>8&255]<<8|c.SBOX[255&s],s^=c.RCON[n/t|0]<<24):t>6&&n%t===4?s=c.SBOX[s>>>24]<<24|c.SBOX[s>>>16&255]<<16|c.SBOX[s>>>8&255]<<8|c.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:c.INV_SUB_MIX[0][c.SBOX[s>>>24]]^c.INV_SUB_MIX[1][c.SBOX[s>>>16&255]]^c.INV_SUB_MIX[2][c.SBOX[s>>>8&255]]^c.INV_SUB_MIX[3][c.SBOX[255&s]];return!0},o.prototype.encryptBlock=function(t){t=s(new e(t));var r=this._doCryptBlock(t,this._keySchedule,c.SUB_MIX,c.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,c.INV_SUB_MIX,c.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,c,f,h,u,d,p;o=e[0]^r[0],a=e[1]^r[1],c=e[2]^r[2],f=e[3]^r[3],s=4;for(var l=1;l>>24]^n[1][a>>>16&255]^n[2][c>>>8&255]^n[3][255&f]^r[s++],u=n[0][a>>>24]^n[1][c>>>16&255]^n[2][f>>>8&255]^n[3][255&o]^r[s++],d=n[0][c>>>24]^n[1][f>>>16&255]^n[2][o>>>8&255]^n[3][255&a]^r[s++],p=n[0][f>>>24]^n[1][o>>>16&255]^n[2][a>>>8&255]^n[3][255&c]^r[s++],o=h,a=u,c=d,f=p;return h=(i[o>>>24]<<24|i[a>>>16&255]<<16|i[c>>>8&255]<<8|i[255&f])^r[s++],u=(i[a>>>24]<<24|i[c>>>16&255]<<16|i[f>>>8&255]<<8|i[255&o])^r[s++],d=(i[c>>>24]<<24|i[f>>>16&255]<<16|i[o>>>8&255]<<8|i[255&a])^r[s++],p=(i[f>>>24]<<24|i[o>>>16&255]<<16|i[a>>>8&255]<<8|i[255&c])^r[s++],[t(h),t(u),t(d),t(p)]},r.AES=o}).call(this,e("buffer").Buffer)},{buffer:64}],71:[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 f=new r(4);f.fill(0),this._ghash=new c(this._cipher.encryptBlock(f)),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;++it&&(t=new r(t),t.fill(0),this._ghash.update(t))}this._called=!0;var n=this._mode.encrypt(this,e);return this._decrypt?this._ghash.update(e):this._ghash.update(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=f(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":70,"./ghash":75,buffer:64,"buffer-xor":84,"cipher-base":85,inherits:261}],72:[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":73,"./encrypter":74,"./modes":76}],73:[function(e,t,r){(function(t){function n(e,r,s){return this instanceof n?(f.call(this),this._cache=new i,this._last=void 0,this._cipher=new c.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;++r16)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)},{"./aes":70,"./authCipher":71,"./modes":76,"./modes/cbc":77,"./modes/cfb":78,"./modes/cfb1":79,"./modes/cfb8":80,"./modes/ctr":81,"./modes/ecb":82,"./modes/ofb":83,"./streamCipher":86,buffer:64,"cipher-base":85,evp_bytestokey:97,inherits:261}],74:[function(e,t,r){(function(t){function n(e,r,s){return this instanceof n?(c.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=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(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=h[e.toLowerCase()];if(!r)throw new TypeError("invalid suite type");var n=u(t,!1,r.key,r.iv);return s(e,n.key,n.iv)}var a=e("./aes"),c=e("cipher-base"),f=e("inherits"),h=e("./modes"),u=e("evp_bytestokey"),d=e("./streamCipher"),p=e("./authCipher");f(n,c),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;++nc||0>e?(r=Math.abs(e)%c,0>e?c-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;++t0;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 c=Math.pow(2,32)}).call(this,e("buffer").Buffer)},{buffer:64}],76:[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"}},{}],77:[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":84}],78:[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:64,"buffer-xor":84}],79:[function(e,t,r){(function(e){function t(e,t,r){for(var i,s,o,a=-1,c=8,f=0;++a>a%8,e._prev=n(e._prev,r?s:o);return f}function n(t,r){var n=t.length,i=-1,s=new e(t.length);for(t=e.concat([t,new e([r])]);++i>7;return s}r.encrypt=function(r,n,i){for(var s=n.length,o=new e(s),a=-1;++as;++s)i[s]=t[s]^r[s];return i}}).call(this,e("buffer").Buffer)},{buffer:64}],85:[function(e,t,r){(function(r){function n(e){i.call(this),this.hashMode="string"==typeof e,this.hashMode?this[e]=this._finalOrDigest:this["final"]=this._finalOrDigest,this._decoder=null,this._encoding=null}var i=e("stream").Transform,s=e("inherits"),o=e("string_decoder").StringDecoder;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 this.hashMode?this:(n&&(i=this._toString(i,n)),i)},n.prototype.setAutoPadding=function(){},n.prototype.getAuthTag=function(){throw new Error("trying to get auth tag in unsupported state")},n.prototype.setAuthTag=function(){throw new Error("trying to set auth tag in unsupported state")},n.prototype.setAAD=function(){throw new Error("trying to set aad in unsupported state")},n.prototype._transform=function(e,t,r){var n;try{this.hashMode?this._update(e):this.push(this._update(e))}catch(i){n=i}finally{r(n)}},n.prototype._flush=function(e){var t;try{this.push(this._final())}catch(r){t=r}finally{e(t)}},n.prototype._finalOrDigest=function(e){var t=this._final()||new r("");return e&&(t=this._toString(t,e,!0)),t},n.prototype._toString=function(e,t,r){if(this._decoder||(this._decoder=new o(t),this._encoding=t),this._encoding!==t)throw new Error("can't switch encodings");var n=this._decoder.write(e);return r&&(n+=this._decoder.end()),n}}).call(this,e("buffer").Buffer)},{buffer:64,inherits:261,stream:278,string_decoder:279}],86:[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("cipher-base"),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":70,buffer:64,"cipher-base":85,inherits:261}],87:[function(e,t,r){(function(r){function n(e){i.call(this);var t,n=e.mode.toLowerCase(),s=a[n];t=e.decrypt?"decrypt":"encrypt";var o=e.key;("des-ede"===n||"des-ede-cbc"===n)&&(o=r.concat([o,o.slice(0,8)]));var c=e.iv;this._des=s.create({key:o,iv:c,type:t})}var i=e("cipher-base"),s=e("des.js"),o=e("inherits"),a={"des-ede3-cbc":s.CBC.instantiate(s.EDE),"des-ede3":s.EDE,"des-ede-cbc":s.CBC.instantiate(s.EDE),"des-ede":s.EDE,"des-cbc":s.CBC.instantiate(s.DES),"des-ecb":s.DES};a.des=a["des-cbc"],a.des3=a["des-ede3-cbc"],t.exports=n,o(n,i),n.prototype._update=function(e){return new r(this._des.update(e))},n.prototype._final=function(){return new r(this._des["final"]())}}).call(this,e("buffer").Buffer)},{buffer:64,"cipher-base":89,"des.js":90,inherits:261}],88:[function(e,t,r){r["des-ecb"]={key:8,iv:0},r["des-cbc"]=r.des={key:8,iv:8},r["des-ede3-cbc"]=r.des3={key:24,iv:8},r["des-ede3"]={key:24,iv:0},r["des-ede-cbc"]={key:16,iv:8},r["des-ede"]={key:16,iv:0}},{}],89:[function(e,t,r){(function(r){function n(e){i.call(this),this.hashMode="string"==typeof e,this.hashMode?this[e]=this._finalOrDigest:this["final"]=this._finalOrDigest,this._decoder=null,this._encoding=null}var i=e("stream").Transform,s=e("inherits"),o=e("string_decoder").StringDecoder;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 this.hashMode?this:(n&&(i=this._toString(i,n)),i)},n.prototype.setAutoPadding=function(){},n.prototype.getAuthTag=function(){throw new Error("trying to get auth tag in unsupported state")},n.prototype.setAuthTag=function(){throw new Error("trying to set auth tag in unsupported state")},n.prototype.setAAD=function(){throw new Error("trying to set aad in unsupported state")},n.prototype._transform=function(e,t,r){var n;try{this.hashMode?this._update(e):this.push(this._update(e))}catch(i){n=i}finally{r(n)}},n.prototype._flush=function(e){var t;try{this.push(this._final())}catch(r){t=r}finally{e(t)}},n.prototype._finalOrDigest=function(e){var t=this._final()||new r("");return e&&(t=this._toString(t,e,!0)),t},n.prototype._toString=function(e,t,r){if(this._decoder||(this._decoder=new o(t),this._encoding=t),this._encoding!==t)throw new Error("can't switch encodings");var n=this._decoder.write(e);return r&&(n+=this._decoder.end()),n}}).call(this,e("buffer").Buffer)},{buffer:64,inherits:261,stream:278,string_decoder:279}],90:[function(e,t,r){"use strict";r.utils=e("./des/utils"),r.Cipher=e("./des/cipher"),r.DES=e("./des/des"),r.CBC=e("./des/cbc"),r.EDE=e("./des/ede")},{"./des/cbc":91,"./des/cipher":92,"./des/des":93,"./des/ede":94,"./des/utils":95}],91:[function(e,t,r){"use strict";function n(e){s.equal(e.length,8,"Invalid IV length"),this.iv=new Array(8);for(var t=0;tn;n++)this.buffer[this.bufferOff+n]=e[t+n];return this.bufferOff+=r,r},n.prototype._flushBuffer=function(e,t){return this._update(this.buffer,0,e,t),this.bufferOff=0,this.blockSize},n.prototype._updateEncrypt=function(e){var t=0,r=0,n=(this.bufferOff+e.length)/this.blockSize|0,i=new Array(n*this.blockSize);0!==this.bufferOff&&(t+=this._buffer(e,t),this.bufferOff===this.buffer.length&&(r+=this._flushBuffer(i,r)));for(var s=e.length-(e.length-t)%this.blockSize;s>t;t+=this.blockSize)this._update(e,t,i,r),r+=this.blockSize;for(;t0;n--)t+=this._buffer(e,t),r+=this._flushBuffer(i,r);return t+=this._buffer(e,t),i},n.prototype["final"]=function(e){var t;e&&(t=this.update(e));var r;return r="encrypt"===this.type?this._finalEncrypt():this._finalDecrypt(),t?t.concat(r):r},n.prototype._pad=function(e,t){if(0===t)return!1;for(;t>>1];r=c.r28shl(r,o),n=c.r28shl(n,o),c.pc2(r,n,e.keys,i)}},i.prototype._update=function(e,t,r,n){var i=this._desState,s=c.readUInt32BE(e,t),o=c.readUInt32BE(e,t+4);c.ip(s,o,i.tmp,0),s=i.tmp[0],o=i.tmp[1],"encrypt"===this.type?this._encrypt(i,s,o,i.tmp,0):this._decrypt(i,s,o,i.tmp,0),s=i.tmp[0],o=i.tmp[1],c.writeUInt32BE(r,s,n),c.writeUInt32BE(r,o,n+4)},i.prototype._pad=function(e,t){for(var r=e.length-t,n=t;n>>0,s=p}c.rip(o,s,n,i)},i.prototype._decrypt=function(e,t,r,n,i){for(var s=r,o=t,a=e.keys.length-2;a>=0;a-=2){var f=e.keys[a],h=e.keys[a+1];c.expand(s,e.tmp,0),f^=e.tmp[0],h^=e.tmp[1];var u=c.substitute(f,h),d=c.permute(u),p=s;s=(o^d)>>>0,o=p}c.rip(s,o,n,i)}},{"../des":90,inherits:261,"minimalistic-assert":96}],94:[function(e,t,r){"use strict";function n(e,t){s.equal(t.length,24,"Invalid key length");var r=t.slice(0,8),n=t.slice(8,16),i=t.slice(16,24);"encrypt"===e?this.ciphers=[f.create({type:"encrypt",key:r}),f.create({type:"decrypt",key:n}),f.create({type:"encrypt",key:i})]:this.ciphers=[f.create({type:"decrypt",key:i}),f.create({type:"encrypt",key:n}),f.create({type:"decrypt",key:r})]}function i(e){c.call(this,e);var t=new n(this.type,this.options.key);this._edeState=t}var s=e("minimalistic-assert"),o=e("inherits"),a=e("../des"),c=a.Cipher,f=a.DES;o(i,c),t.exports=i,i.create=function(e){return new i(e)},i.prototype._update=function(e,t,r,n){var i=this._edeState;i.ciphers[0]._update(e,t,r,n),i.ciphers[1]._update(r,n,r,n),i.ciphers[2]._update(r,n,r,n)},i.prototype._pad=f.prototype._pad,i.prototype._unpad=f.prototype._unpad},{"../des":90,inherits:261,"minimalistic-assert":96}],95:[function(e,t,r){"use strict";r.readUInt32BE=function(e,t){var r=e[0+t]<<24|e[1+t]<<16|e[2+t]<<8|e[3+t];return r>>>0},r.writeUInt32BE=function(e,t,r){e[0+r]=t>>>24,e[1+r]=t>>>16&255,e[2+r]=t>>>8&255,e[3+r]=255&t},r.ip=function(e,t,r,n){for(var i=0,s=0,o=6;o>=0;o-=2){for(var a=0;24>=a;a+=8)i<<=1,i|=t>>>a+o&1;for(var a=0;24>=a;a+=8)i<<=1,i|=e>>>a+o&1}for(var o=6;o>=0;o-=2){for(var a=1;25>=a;a+=8)s<<=1,s|=t>>>a+o&1;for(var a=1;25>=a;a+=8)s<<=1,s|=e>>>a+o&1}r[n+0]=i>>>0,r[n+1]=s>>>0},r.rip=function(e,t,r,n){for(var i=0,s=0,o=0;4>o;o++)for(var a=24;a>=0;a-=8)i<<=1,i|=t>>>a+o&1,i<<=1,i|=e>>>a+o&1;for(var o=4;8>o;o++)for(var a=24;a>=0;a-=8)s<<=1,s|=t>>>a+o&1,s<<=1,s|=e>>>a+o&1;r[n+0]=i>>>0,r[n+1]=s>>>0},r.pc1=function(e,t,r,n){for(var i=0,s=0,o=7;o>=5;o--){for(var a=0;24>=a;a+=8)i<<=1,i|=t>>a+o&1;for(var a=0;24>=a;a+=8)i<<=1,i|=e>>a+o&1}for(var a=0;24>=a;a+=8)i<<=1,i|=t>>a+o&1;for(var o=1;3>=o;o++){for(var a=0;24>=a;a+=8)s<<=1,s|=t>>a+o&1;for(var a=0;24>=a;a+=8)s<<=1,s|=e>>a+o&1}for(var a=0;24>=a;a+=8)s<<=1,s|=e>>a+o&1;r[n+0]=i>>>0,r[n+1]=s>>>0},r.r28shl=function(e,t){return e<>>28-t};var n=[14,11,17,4,27,23,25,0,13,22,7,18,5,9,16,24,2,20,12,21,1,8,15,26,15,4,25,19,9,1,26,16,5,11,23,8,12,7,17,0,22,3,10,14,6,20,27,24];r.pc2=function(e,t,r,i){for(var s=0,o=0,a=n.length>>>1,c=0;a>c;c++)s<<=1,s|=e>>>n[c]&1;for(var c=a;c>>n[c]&1;r[i+0]=s>>>0,r[i+1]=o>>>0},r.expand=function(e,t,r){var n=0,i=0;n=(1&e)<<5|e>>>27;for(var s=23;s>=15;s-=4)n<<=6,n|=e>>>s&63;for(var s=11;s>=3;s-=4)i|=e>>>s&63,i<<=6;i|=(31&e)<<1|e>>>31,t[r+0]=n>>>0,t[r+1]=i>>>0};var i=[14,0,4,15,13,7,1,4,2,14,15,2,11,13,8,1,3,10,10,6,6,12,12,11,5,9,9,5,0,3,7,8,4,15,1,12,14,8,8,2,13,4,6,9,2,1,11,7,15,5,12,11,9,3,7,14,3,10,10,0,5,6,0,13,15,3,1,13,8,4,14,7,6,15,11,2,3,8,4,14,9,12,7,0,2,1,13,10,12,6,0,9,5,11,10,5,0,13,14,8,7,10,11,1,10,3,4,15,13,4,1,2,5,11,8,6,12,7,6,12,9,0,3,5,2,14,15,9,10,13,0,7,9,0,14,9,6,3,3,4,15,6,5,10,1,2,13,8,12,5,7,14,11,12,4,11,2,15,8,1,13,1,6,10,4,13,9,0,8,6,15,9,3,8,0,7,11,4,1,15,2,14,12,3,5,11,10,5,14,2,7,12,7,13,13,8,14,11,3,5,0,6,6,15,9,0,10,3,1,4,2,7,8,2,5,12,11,1,12,10,4,14,15,9,10,3,6,15,9,0,0,6,12,10,11,1,7,13,13,8,15,9,1,4,3,5,14,11,5,12,2,7,8,2,4,14,2,14,12,11,4,2,1,12,7,4,10,7,11,13,6,1,8,5,5,0,3,15,15,10,13,3,0,9,14,8,9,6,4,11,2,8,1,12,11,7,10,1,13,14,7,2,8,13,15,6,9,15,12,0,5,9,6,10,3,4,0,5,14,3,12,10,1,15,10,4,15,2,9,7,2,12,6,9,8,5,0,6,13,1,3,13,4,14,14,0,7,11,5,3,11,8,9,4,14,3,15,2,5,12,2,9,8,5,12,15,3,10,7,11,0,14,4,1,10,7,1,6,13,0,11,8,6,13,4,13,11,0,2,11,14,7,15,4,0,9,8,1,13,10,3,14,12,3,9,5,7,12,5,2,10,15,6,8,1,6,1,6,4,11,11,13,13,8,12,1,3,4,7,10,14,7,10,9,15,5,6,0,8,15,0,14,5,2,9,3,2,12,13,1,2,15,8,13,4,8,6,10,15,3,11,7,1,4,10,12,9,5,3,6,14,11,5,0,0,14,12,9,7,2,7,2,11,1,4,14,1,7,9,4,12,10,14,8,2,13,0,15,6,12,10,9,13,0,15,3,3,5,5,6,8,11];r.substitute=function(e,t){for(var r=0,n=0;4>n;n++){var s=e>>>18-6*n&63,o=i[64*n+s];r<<=4,r|=o}for(var n=0;4>n;n++){var s=t>>>18-6*n&63,o=i[256+64*n+s];r<<=4,r|=o}return r>>>0};var s=[16,25,12,11,3,20,4,15,31,17,9,6,27,14,1,22,30,24,8,18,0,5,29,23,13,19,2,26,10,21,28,7];r.permute=function(e){for(var t=0,r=0;r>>s[r]&1;return t>>>0},r.padSplit=function(e,t,r){for(var n=e.toString(2);n.lengths;s+=r)i.push(n.slice(s,s+r));return i.join(" ")}},{}],96:[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)}},{}],97:[function(e,t,r){(function(r){function n(e,t,n,s){r.isBuffer(e)||(e=new r(e,"binary")),t&&!r.isBuffer(t)&&(t=new r(t,"binary")),n/=8,s=s||0;for(var o,a,c=0,f=0,h=new r(n),u=new r(s),d=0,p=[];;){if(d++>0&&p.push(o),p.push(e),t&&p.push(t),o=i(r.concat(p)),p=[],a=0,n>0)for(;;){if(0===n)break;if(a===o.length)break;h[c++]=o[a],n--,a++}if(s>0&&a!==o.length)for(;;){if(0===s)break;if(a===o.length)break;u[f++]=o[a],s--,a++}if(0===n&&0===s)break}for(a=0;as;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){for(var t=new Array(e.bitLength()),r=0;r>>i}return t}function c(e,t,r){r.negative=t.negative^e.negative;var n=e.length+t.length|0;r.length=n,n=n-1|0;var i=0|e.words[0],s=0|t.words[0],o=i*s,a=67108863&o,c=o/67108864|0;r.words[0]=a;for(var f=1;n>f;f++){for(var h=c>>>26,u=67108863&c,d=Math.min(f,t.length-1),p=Math.max(0,f-e.length+1);d>=p;p++){var l=f-p|0,i=0|e.words[l],s=0|t.words[p],o=i*s,a=67108863&o;h=h+(o/67108864|0)|0,a=a+u|0,u=67108863&a,h=h+(a>>>26)|0}r.words[f]=0|u,c=0|h}return 0!==c?r.words[f]=0|c:r.length--,r.strip()}function f(e,t,r){r.negative=t.negative^e.negative,r.length=e.length+t.length;for(var n=0,i=0,s=0;s=f;f++){var h=s-f,u=0|e.words[h],d=0|t.words[f],p=u*d,l=67108863&p;o=o+(p/67108864|0)|0,l=l+a|0,a=67108863&l,o=o+(l>>>26)|0,i+=o>>>26,o&=67108863}r.words[s]=a,n=o,o=i}return 0!==n?r.words[s]=n:r.length--,r.strip()}function h(e,t){this.name=e,this.p=new i(t,16),this.n=this.p.bitLength(),this.k=new i(1).iushln(this.n).isub(this.p),this.tmp=this._tmp()}function u(){h.call(this,"k256","ffffffff ffffffff ffffffff ffffffff ffffffff ffffffff fffffffe fffffc2f")}function d(){h.call(this,"p224","ffffffff ffffffff ffffffff ffffffff 00000000 00000000 00000001")}function p(){h.call(this,"p192","ffffffff ffffffff ffffffff fffffffe ffffffff ffffffff")}function l(){h.call(this,"25519","7fffffffffffffff ffffffffffffffff ffffffffffffffff ffffffffffffffed")}function b(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 y(e){b.call(this,e),this.shift=this.m.bitLength(),this.shift%26!==0&&(this.shift+=26-this.shift%26),this.r=new i(1).iushln(this.shift),this.r2=this.imod(this.r.sqr()),this.rinv=this.r._invmp(this.m),this.minv=this.rinv.mul(this.r).isubn(1).div(this.m),this.minv=this.minv.umod(this.r),this.minv=this.r.sub(this.minv)}"object"==typeof e?e.exports=i:t.BN=i,i.BN=i,i.wordSize=26,i.max=function(e,t){return e.cmp(t)>0?e:t},i.min=function(e,t){return e.cmp(t)<0?e:t},i.prototype._init=function(e,t,n){if("number"==typeof e)return this._initNumber(e,t,n);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.negative=1),this.strip(),"le"===n&&this._initArray(this.toArray(),t,n)},i.prototype._initNumber=function(e,t,n){0>e&&(this.negative=1,e=-e),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),"le"===n&&this._initArray(this.toArray(),t,n)},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=0;i-=3){var a=e[i]|e[i-1]<<8|e[i-2]<<16;this.words[o]|=a<>>26-s&67108863,s+=24,s>=26&&(s-=26,o++)}else if("le"===n)for(var i=0,o=0;i>>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=t;r-=6){var o=s(e,r,r+6);this.words[i]|=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<>>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,c=Math.min(s,s-a)+r,f=0,h=r;c>h;h+=n)f=o(e,h,h+n,t),this.imuln(i),this.words[0]+f<67108864?this.words[0]+=f:this._iaddn(f);if(0!==a){for(var u=1,f=o(e,h,e.length,t),h=0;a>h;h++)u*=t;this.imuln(u),this.words[0]+f<67108864?this.words[0]+=f:this._iaddn(f)}},i.prototype.copy=function(e){e.words=new Array(this.length);for(var t=0;t1&&0===this.words[this.length-1];)this.length--;return this._normSign()},i.prototype._normSign=function(){return 1===this.length&&0===this.words[0]&&(this.negative=0),this},i.prototype.inspect=function(){return(this.red?""};var g=["","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"],m=[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],v=[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){e=e||10;var t=0|t||1;if(16===e||"hex"===e){for(var n="",i=0,s=0,o=0;o>>24-i&16777215,n=0!==s||o!==this.length-1?g[6-c.length]+c+n:c+n,i+=2,i>=26&&(i-=26,o--)}for(0!==s&&(n=s.toString(16)+n);n.length%t!==0;)n="0"+n;return 0!==this.negative&&(n="-"+n),n}if(e===(0|e)&&e>=2&&36>=e){var f=m[e],h=v[e],n="",u=this.clone();for(u.negative=0;0!==u.cmpn(0);){var d=u.modn(h).toString(e);u=u.idivn(h),n=0!==u.cmpn(0)?g[f-d.length]+d+n:d+n}for(0===this.cmpn(0)&&(n="0"+n);n.length%t!==0;)n="0"+n;return 0!==this.negative&&(n="-"+n),n}r(!1,"Base should be between 2 and 36")},i.prototype.toJSON=function(){return this.toString(16)},i.prototype.toArray=function(e,t){this.strip();var n="le"===e,i=new Array(this.byteLength());i[0]=0;var s=this.clone();if(n)for(var o=0;0!==s.cmpn(0);o++){var a=s.andln(255);s.iushrn(8),i[o]=a}else for(var o=0;0!==s.cmpn(0);o++){var a=s.andln(255);s.iushrn(8),i[i.length-o-1]=a}if(t)for(r(i.length<=t,"byte array longer than desired length");i.length=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;te.length?this.clone().ior(e):e.clone().ior(this)},i.prototype.uor=function(e){return this.length>e.length?this.clone().iuor(e):e.clone().iuor(this)},i.prototype.iuand=function(e){var t;t=this.length>e.length?e:this;for(var r=0;re.length?this.clone().iand(e):e.clone().iand(this)},i.prototype.uand=function(e){return this.length>e.length?this.clone().iuand(e):e.clone().iuand(this)},i.prototype.iuxor=function(e){var t,r;this.length>e.length?(t=this,r=e):(t=e,r=this);for(var n=0;ne.length?this.clone().ixor(e):e.clone().ixor(this)},i.prototype.uxor=function(e){return this.length>e.length?this.clone().iuxor(e):e.clone().iuxor(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 t?this.words[n]=this.words[n]|1<e.length?(r=this,n=e):(r=e,n=this);for(var i=0,s=0;s>>26}for(;0!==i&&s>>26}if(this.length=r.length,0!==i)this.words[this.length]=i,this.length++;else if(r!==this)for(;se.length?this.clone().iadd(e):e.clone().iadd(this)},i.prototype.isub=function(e){if(0!==e.negative){e.negative=0;var t=this.iadd(e);return e.negative=1,t._normSign()}if(0!==this.negative)return this.negative=0,this.iadd(e),this.negative=1,this._normSign();var r=this.cmp(e);if(0===r)return this.negative=0,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>26,this.words[o]=67108863&t}for(;0!==s&&o>26,this.words[o]=67108863&t}if(0===s&&o=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 c=n-a,f=0|this.words[c],h=0|e.words[a],u=f*h,d=67108863&u;i+=u/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,c=1;c>>26}return this.strip()},i.prototype.imuln=function(e){r("number"==typeof e);for(var t=0,n=0;n>=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.muln=function(e){return this.clone().imuln(e)},i.prototype.sqr=function(){return this.mul(this)},i.prototype.isqr=function(){return this.mul(this)},i.prototype.pow=function(e){var t=a(e);if(0===t.length)return new i(1);for(var r=this,n=0;n=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>>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.ishln=function(e){return r(0===this.negative),this.iushln(e)},i.prototype.iushrn=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<f;f++)c.words[f]=this.words[f];c.length=o}if(0===o);else if(this.length>o){this.length-=o;for(var f=0;f=0&&(0!==h||f>=i);f--){var u=0|this.words[f];this.words[f]=h<<26-s|u>>>s,h=u&a}return c&&0!==h&&(c.words[c.length++]=h),0===this.length&&(this.words[0]=0,this.length=1),this.strip(),this},i.prototype.ishrn=function(e,t,n){return r(0===this.negative),this.iushrn(e,t,n)},i.prototype.shln=function(e){return this.clone().ishln(e)},i.prototype.ushln=function(e){return this.clone().iushln(e)},i.prototype.shrn=function(e){return this.clone().ishrn(e)},i.prototype.ushrn=function(e){return this.clone().iushrn(e)},i.prototype.testn=function(e){r("number"==typeof e&&e>=0);var t=e%26,n=(e-t)/26,i=1<=0);var t=e%26,n=(e-t)/26;if(r(0===this.negative,"imaskn works only with positive numbers"),0!==t&&n++,this.length=Math.min(n,this.length),0!==t){var i=67108863^67108863>>>t<e?this.isubn(-e):0!==this.negative?1===this.length&&(0|this.words[0])=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(0!==this.negative)return this.negative=0,this.iaddn(e),this.negative=1,this;this.words[0]-=e;for(var t=0;t>26)-(f/67108864|0),this.words[i+n]=67108863&c}for(;i>26,this.words[i+n]=67108863&c}if(0===a)return this.strip();r(-1===a),a=0;for(var i=0;i>26,this.words[i]=67108863&c}return this.negative=1,this.strip()},i.prototype._wordDiv=function(e,t){var r=this.length-e.length,n=this.clone(),s=e,o=0|s.words[s.length-1],a=this._countBits(o);r=26-a,0!==r&&(s=s.ushln(r),n.iushln(r),o=0|s.words[s.length-1]);var c,f=n.length-s.length;if("mod"!==t){c=new i(null),c.length=f+1,c.words=new Array(c.length);for(var h=0;h=0;d--){var p=67108864*(0|n.words[s.length+d])+(0|n.words[s.length+d-1]);for(p=Math.min(p/o|0,67108863),n._ishlnsubmul(s,p,d);0!==n.negative;)p--,n.negative=0,n._ishlnsubmul(s,1,d),0!==n.cmpn(0)&&(n.negative^=1);c&&(c.words[d]=p)}return c&&c.strip(),n.strip(),"div"!==t&&0!==r&&n.iushrn(r),{div:c?c:null,mod:n}},i.prototype.divmod=function(e,t,n){if(r(0!==e.cmpn(0)),0!==this.negative&&0===e.negative){var s,o,a=this.neg().divmod(e,t);return"mod"!==t&&(s=a.div.neg()),"div"!==t&&(o=a.mod.neg(),n&&o.neg&&(o=o.add(e))),{div:s,mod:o}}if(0===this.negative&&0!==e.negative){var s,a=this.divmod(e.neg(),t);return"mod"!==t&&(s=a.div.neg()),{div:s,mod:a.mod}}if(0!==(this.negative&e.negative)){var o,a=this.neg().divmod(e.neg(),t);return"div"!==t&&(o=a.mod.neg(),n&&o.neg&&(o=o.isub(e))),{div:a.div,mod:o}}return 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",!1).div},i.prototype.mod=function(e){return this.divmod(e,"mod",!1).mod},i.prototype.umod=function(e){return this.divmod(e,"mod",!0).mod},i.prototype.divRound=function(e){var t=this.divmod(e);if(0===t.mod.cmpn(0))return t.div;var r=0!==t.div.negative?t.mod.isub(e):t.mod,n=e.ushrn(1),i=e.andln(1),s=r.cmp(n);return 0>s||1===i&&0===s?t.div:0!==t.div.negative?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+(0|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=(0|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(0===e.negative),r(0!==e.cmpn(0));var t=this,n=e.clone();t=0!==t.negative?t.umod(e):t.clone();for(var s=new i(1),o=new i(0),a=new i(0),c=new i(1),f=0;t.isEven()&&n.isEven();)t.iushrn(1),n.iushrn(1),++f;for(var h=n.clone(),u=t.clone();0!==t.cmpn(0);){for(;t.isEven();)t.iushrn(1),s.isEven()&&o.isEven()?(s.iushrn(1),o.iushrn(1)):(s.iadd(h).iushrn(1),o.isub(u).iushrn(1));for(;n.isEven();)n.iushrn(1),a.isEven()&&c.isEven()?(a.iushrn(1),c.iushrn(1)):(a.iadd(h).iushrn(1),c.isub(u).iushrn(1));t.cmp(n)>=0?(t.isub(n),s.isub(a),o.isub(c)):(n.isub(t),a.isub(s),c.isub(o))}return{a:a,b:c,gcd:n.iushln(f)}},i.prototype._invmp=function(e){r(0===e.negative),r(0!==e.cmpn(0));var t=this,n=e.clone();t=0!==t.negative?t.umod(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.iushrn(1),s.isEven()?s.iushrn(1):s.iadd(a).iushrn(1);for(;n.isEven();)n.iushrn(1),o.isEven()?o.iushrn(1):o.iadd(a).iushrn(1);t.cmp(n)>=0?(t.isub(n),s.isub(o)):(n.isub(t),o.isub(s))}var c;return c=0===t.cmpn(1)?s:o,c.cmpn(0)<0&&c.iadd(e),c},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.negative=0,r.negative=0;for(var n=0;t.isEven()&&r.isEven();n++)t.iushrn(1),r.iushrn(1);for(;;){for(;t.isEven();)t.iushrn(1);for(;r.isEven();)r.iushrn(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.iushln(n)},i.prototype.invm=function(e){return this.egcd(e).a.umod(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<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>>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),0!==this.negative&&!t)return-1;if(0===this.negative&&t)return 1;e&=67108863,this.strip();var r;if(this.length>1)r=1;else{var n=0|this.words[0];r=n===e?0:e>n?-1:1}return 0!==this.negative&&(r=-r),r},i.prototype.cmp=function(e){if(0!==this.negative&&0===e.negative)return-1;if(0===this.negative&&0!==e.negative)return 1;var t=this.ucmp(e);return 0!==this.negative?-t:t},i.prototype.ucmp=function(e){if(this.length>e.length)return 1;if(this.length=0;r--){var n=0|this.words[r],i=0|e.words[r];if(n!==i){i>n?t=-1:n>i&&(t=1);break}}return t},i.red=function(e){return new b(e)},i.prototype.toRed=function(e){return r(!this.red,"Already a number in reduction context"),r(0===this.negative,"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.ushl(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 _={k256:null,p224:null,p192:null,p25519:null};h.prototype._tmp=function(){var e=new i(null);return e.words=new Array(Math.ceil(this.n/13)),e},h.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=t0?r.isub(this.p):r.strip(),r},h.prototype.split=function(e,t){e.iushrn(this.n,0,t)},h.prototype.imulK=function(e){return e.imul(this.k)},n(u,h),u.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>>22,s=o}e.words[i-10]=s>>>22,e.length-=9},u.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>>=26,e.words[r]=i,t=n}return 0!==t&&(e.words[e.length++]=t),e},i._prime=function w(e){if(_[e])return _[e];var w;if("k256"===e)w=new u;else if("p224"===e)w=new d;else if("p192"===e)w=new p;else{if("p25519"!==e)throw new Error("Unknown prime "+e);w=new l}return _[e]=w,w},b.prototype._verify1=function(e){r(0===e.negative,"red works only with positives"),r(e.red,"red works only with red numbers")},b.prototype._verify2=function(e,t){r(0===(e.negative|t.negative),"red works only with positives"),r(e.red&&e.red===t.red,"red works only with red numbers")},b.prototype.imod=function(e){return this.prime?this.prime.ireduce(e)._forceRed(this):e.umod(this.m)._forceRed(this)},b.prototype.neg=function(e){var t=e.clone();return t.negative^=1,t.iadd(this.m)._forceRed(this)},b.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)},b.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},b.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)},b.prototype.isub=function(e,t){this._verify2(e,t);var r=e.isub(t);return r.cmpn(0)<0&&r.iadd(this.m),r},b.prototype.shl=function(e,t){return this._verify1(e),this.imod(e.ushln(t))},b.prototype.imul=function(e,t){return this._verify2(e,t),this.imod(e.imul(t))},b.prototype.mul=function(e,t){return this._verify2(e,t),this.imod(e.mul(t))},b.prototype.isqr=function(e){return this.imul(e,e)},b.prototype.sqr=function(e){return this.mul(e,e)},b.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)).iushrn(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.iushrn(1);r(0!==o.cmpn(0));var c=new i(1).toRed(this),f=c.redNeg(),h=this.m.subn(1).iushrn(1),u=this.m.bitLength();for(u=new i(2*u*u).toRed(this);0!==this.pow(u,h).cmp(f);)u.redIAdd(f);for(var d=this.pow(u,o),s=this.pow(e,o.addn(1).iushrn(1)),p=this.pow(e,o),l=a;0!==p.cmp(c);){for(var b=p,y=0;0!==b.cmp(c);y++)b=b.redSqr();r(l>y);var g=this.pow(d,new i(1).iushln(l-y-1));s=s.redMul(g),d=g.redSqr(),p=p.redMul(d),l=y}return s},b.prototype.invm=function(e){var t=e._invmp(this.m);return 0!==t.negative?(t.negative=0,this.imod(t).redNeg()):this.imod(t)},b.prototype.pow=function(e,t){if(0===t.cmpn(0))return new i(1);if(0===t.cmpn(1))return e.clone();var r=4,n=new Array(1<=0;s--){for(var h=t.words[s],u=f-1;u>=0;u--){var d=h>>u&1;o!==n[0]&&(o=this.sqr(o)),0!==d||0!==a?(a<<=1,a|=d,c++,(c===r||0===s&&0===u)&&(o=this.mul(o,n[a]),c=0,a=0)):c=0}f=26}return o},b.prototype.convertTo=function(e){var t=e.umod(this.m);return t===e?t.clone():t},b.prototype.convertFrom=function(e){var t=e.clone();return t.red=null,t},i.mont=function(e){return new y(e)},n(y,b),y.prototype.convertTo=function(e){return this.imod(e.ushln(this.shift))},y.prototype.convertFrom=function(e){var t=this.imod(e.mul(this.rinv));return t.red=null,t},y.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).iushrn(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)},y.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).iushrn(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)},y.prototype.invm=function(e){var t=this.imod(e._invmp(this.m).mul(this.r2));return t._forceRed(this)}}("undefined"==typeof t||t,this)},{}],102:[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).umod(t.modulus)),c=a.toRed(o.mont(t.prime1)),f=a.toRed(o.mont(t.prime2)),h=t.coefficient,u=t.prime1,d=t.prime2,p=c.redPow(t.exponent1),l=f.redPow(t.exponent2);p=p.fromRed(),l=l.fromRed();var b=p.isub(l).imul(h).umod(u);return b.imul(d),l.iadd(b),new r(l.imul(i.unblinder).umod(t.modulus).toArray(!1,s))}function s(e){for(var t=e.modulus.byteLength(),r=new o(a(t));r.cmp(e.modulus)>=0||!r.umod(e.prime1)||!r.umod(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":101,buffer:64,randombytes:259}],103:[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"),n.eddsa=e("./elliptic/eddsa")},{"../package.json":126,"./elliptic/curve":106,"./elliptic/curves":109,"./elliptic/ec":110,"./elliptic/eddsa":113,"./elliptic/hmac-drbg":116,"./elliptic/utils":118,brorand:119}],104:[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,c=a.getNAF,f=a.getJSF,h=a.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){h(e.precomputed);var r=e._getDoubles(),n=c(t,1),i=(1<=o;t--)a=(a<<1)+n[t];s.push(a)}for(var f=this.jpoint(null,null,null),u=this.jpoint(null,null,null),d=i;d>0;d--){for(var o=0;o=0;a--){for(var t=0;a>=0&&0===s[a];a--)t++;if(a>=0&&t++,o=o.dblp(t),0>a)break;var f=s[a];h(0!==f),o="affine"===e.type?f>0?o.mixedAdd(i[f-1>>1]):o.mixedAdd(i[-f-1>>1].neg()):f>0?o.add(i[f-1>>1]):o.add(i[-f-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,a=0,h=0;n>h;h++){var u=t[h],d=u._getNAFPoints(e);i[h]=d.wnd,s[h]=d.points}for(var h=n-1;h>=1;h-=2){var p=h-1,l=h;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 y=[-3,-1,-5,-7,0,7,5,1,3],g=f(r[p],r[l]);a=Math.max(g[0].length,a),o[p]=new Array(a),o[l]=new Array(a);for(var m=0;a>m;m++){var v=0|g[0][m],_=0|g[1][m];o[p][m]=y[3*(v+1)+(_+1)],o[l][m]=0,s[p]=b}}else o[p]=c(r[p],i[p]),o[l]=c(r[l],i[l]),a=Math.max(o[p].length,a),a=Math.max(o[l].length,a)}for(var w=this.jpoint(null,null,null),S=this._wnafT4,h=a;h>=0;h--){for(var E=0;h>=0;){for(var k=!0,m=0;n>m;m++)S[m]=0|o[m][h],0!==S[m]&&(k=!1);if(!k)break;E++,h--}if(h>=0&&E++,w=w.dblp(E),0>h)break;for(var m=0;n>m;m++){var u,x=S[m];0!==x&&(x>0?u=s[m][x-1>>1]:0>x&&(u=s[m][-x-1>>1].neg()),w="affine"===u.type?w.mixedAdd(u):w.add(u))}}for(var h=0;n>h;h++)s[h]=null;return w.toP()},n.BasePoint=i,i.prototype.eq=function(){throw new Error("Not implemented")},i.prototype.validate=function(){return this.curve.validate(this)},n.prototype.decodePoint=function(e,t){e=a.toArray(e,t);var r=this.p.byteLength();if(4===e[0]&&e.length-1===2*r)return this.point(e.slice(1,1+r),e.slice(1+r,1+2*r));if((2===e[0]||3===e[0])&&e.length-1===r)return this.pointFromX(e.slice(1,1+r),3===e[0]);throw new Error("Unknown point format")},i.prototype.encodeCompressed=function(e){return this.encode(e,!0)},i.prototype._encode=function(e){var t=this.curve.p.byteLength(),r=this.getX().toArray("be",t);return e?[this.getY().isEven()?2:3].concat(r):[4].concat(r,this.getY().toArray("be",t))},i.prototype.encode=function(e,t){return a.encode(this._encode(t),e)},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._hasDoubles=function(e){if(!this.precomputed)return!1;var t=this.precomputed.doubles;return t?t.points.length>=Math.ceil((e.bitLength()+1)/t.step):!1},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<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":103,"bn.js":101}],105:[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,f.call(this,"edwards",e),this.a=new a(e.a,16).umod(this.red.m),this.a=this.a.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),h(!this.twisted||0===this.c.fromRed().cmpn(1)),this.oneC=1===(0|e.c)}function i(e,t,r,n,i){f.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"),c=e("inherits"),f=s.base,h=o.utils.assert;c(n,f),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){e=new a(e,16),e.red||(e=e.toRed(this.red));var r=e.redSqr(),n=this.c2.redSub(this.a.redMul(r)),i=this.one.redSub(this.c2.redMul(this.d).redMul(r)),s=n.redMul(i.redInvm()).redSqrt(),o=s.fromRed().isOdd();return(t&&!o||!t&&o)&&(s=s.redNeg()),this.point(e,s)},n.prototype.pointFromY=function(e,t){e=new a(e,16),e.red||(e=e.toRed(this.red));var r=e.redSqr(),n=r.redSub(this.one),i=r.redMul(this.d).redAdd(this.one),s=n.redMul(i.redInvm());if(0===s.cmp(this.zero)){if(t)throw new Error("invalid point");return this.point(this.zero,e)}var o=s.redSqrt();if(0!==o.redSqr().redSub(s).cmp(this.zero))throw new Error("invalid point");return o.isOdd()!==t&&(o=o.redNeg()),this.point(o,e)},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)},c(i,f.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()?"":""},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),c=i.redMul(o),f=s.redMul(a),h=i.redMul(a),u=o.redMul(s);return this.curve.point(c,f,u,h)},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 c=this.z.redSqr(),f=a.redSub(c).redISub(c);e=n.redSub(i).redISub(s).redMul(f),t=a.redMul(o.redSub(s)),r=a.redMul(f)}}else{var o=i.redAdd(s),c=this.curve._mulC(this.c.redMul(this.z)).redSqr(),f=o.redSub(c).redSub(c);e=this.curve._mulC(n.redISub(o)).redMul(f),t=this.curve._mulC(o).redMul(i.redISub(s)),r=o.redMul(f)}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),c=r.redAdd(t),f=s.redMul(o),h=a.redMul(c),u=s.redMul(c),d=o.redMul(a);return this.curve.point(f,h,d,u)},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),c=i.redSub(a),f=i.redAdd(a),h=this.x.redAdd(this.y).redMul(e.x.redAdd(e.y)).redISub(s).redISub(o),u=n.redMul(c).redMul(h);return this.curve.twisted?(t=n.redMul(f).redMul(o.redSub(this.curve._mulA(s))),r=c.redMul(f)):(t=n.redMul(f).redMul(o.redSub(s)),r=this.curve._mulC(c).redMul(f)),this.curve.point(u,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._hasDoubles(e)?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.eq=function(e){return this===e||0===this.getX().cmp(e.getX())&&0===this.getY().cmp(e.getY())},i.prototype.toP=i.prototype.normalize,i.prototype.mixedAdd=i.prototype.add},{"../../elliptic":103,"../curve":106,"bn.js":101,inherits:261}],106:[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":104,"./edwards":105,"./mont":107,"./short":108}],107:[function(e,t,r){"use strict";function n(e){c.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){c.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"),c=s.base,f=e("../../elliptic"),h=f.utils;a(n,c),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,c.BasePoint),n.prototype.decodePoint=function(e,t){return this.point(h.toArray(e,t),1)},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.prototype._encode=function(){return this.getX().toArray("be",this.curve.p.byteLength())},i.fromJSON=function(e,t){return new i(e,t[0],t[1]||e.one)},i.prototype.inspect=function(){return this.isInfinity()?"":""},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),c=t.z.redMul(o.redAdd(a).redSqr()),f=t.x.redMul(o.redISub(a).redSqr());return this.curve.point(c,f)},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.iushrn(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.eq=function(e){return 0===this.getX().cmp(e.getX())},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()}},{"../../elliptic":103,"../curve":106,"bn.js":101,inherits:261}],108:[function(e,t,r){"use strict";function n(e){h.call(this,"short",e),this.a=new c(e.a,16).toRed(this.red),this.b=new c(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){h.BasePoint.call(this,e,"affine"),null===t&&null===r?(this.x=null,this.y=null,this.inf=!0):(this.x=new c(t,16),this.y=new c(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){h.BasePoint.call(this,e,"jacobian"),null===t&&null===r&&null===n?(this.x=this.curve.one,this.y=this.curve.one,this.z=new c(0)):(this.x=new c(t,16),this.y=new c(r,16),this.z=new c(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"),c=e("bn.js"),f=e("inherits"),h=o.base,u=a.utils.assert;f(n,h),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 c(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 c(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],u(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 c(e.a,16),b:new c(e.b,16)}}):this._getEndoBasis(r),{beta:t,lambda:r,basis:s}}},n.prototype._getEndoRoots=function(e){var t=e===this.p?this.red:c.mont(e),r=new c(2).toRed(t).redInvm(),n=r.redNeg(),i=new c(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,f,h,u=this.n.ushrn(Math.floor(this.n.bitLength()/2)),d=e,p=this.n.clone(),l=new c(1),b=new c(0),y=new c(0),g=new c(1),m=0;0!==d.cmpn(0);){var v=p.div(d);f=p.sub(v.mul(d)),h=y.sub(v.mul(l));var _=g.sub(v.mul(b));if(!n&&f.cmp(u)<0)t=a.neg(),r=l,n=f.neg(),i=h;else if(n&&2===++m)break;a=f,p=d,d=f,y=l,l=h,g=b,b=_}s=f.neg(),o=h;var w=n.sqr().add(i.sqr()),S=s.sqr().add(o.sqr());return S.cmp(w)>=0&&(s=t,o=r),n.negative&&(n=n.neg(),i=i.neg()),s.negative&&(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),c=i.mul(r.b),f=s.mul(n.b),h=e.sub(o).sub(a),u=c.add(f).neg();return{k1:h,k2:u}},n.prototype.pointFromX=function(e,t){e=new c(e,16),e.red||(e=e.toRed(this.red));var r=e.redSqr().redMul(e).redIAdd(e.redMul(this.a)).redIAdd(this.b),n=r.redSqrt(),i=n.fromRed().isOdd();return(t&&!i||!t&&i)&&(n=n.redNeg()),this.point(e,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;if;f++)r[f]=null,n[f]=null;return c},f(i,h.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()?"":""},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 c(e,16),this._hasDoubles(e)?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},f(s,h.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),c=s.redSub(o);if(0===a.cmpn(0))return 0!==c.cmpn(0)?this.curve.jpoint(null,null,null):this.dbl();var f=a.redSqr(),h=f.redMul(a),u=n.redMul(f),d=c.redSqr().redIAdd(h).redISub(u).redISub(u),p=c.redMul(u.redISub(d)).redISub(s.redMul(h)),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 c=o.redSqr(),f=c.redMul(o),h=r.redMul(c),u=a.redSqr().redIAdd(f).redISub(h).redISub(h),d=a.redMul(h.redISub(u)).redISub(i.redMul(f)),p=this.z.redMul(o);return this.curve.jpoint(u,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,c=a.redSqr().redSqr(),f=o.redAdd(o),r=0;e>r;r++){var h=s.redSqr(),u=f.redSqr(),d=u.redSqr(),p=h.redAdd(h).redIAdd(h).redIAdd(n.redMul(c)),l=s.redMul(u),b=p.redSqr().redISub(l.redAdd(l)),y=l.redISub(b),g=p.redMul(y);g=g.redIAdd(g).redISub(d);var m=f.redMul(a);e>r+1&&(c=c.redMul(d)),s=b,a=m,f=g}return this.curve.jpoint(s,f.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),c=a.redSqr().redISub(o).redISub(o),f=s.redIAdd(s);f=f.redIAdd(f),f=f.redIAdd(f),e=c,t=a.redMul(o.redISub(c)).redISub(f),r=this.y.redAdd(this.y)}else{var h=this.x.redSqr(),u=this.y.redSqr(),d=u.redSqr(),p=this.x.redAdd(u).redSqr().redISub(h).redISub(d);p=p.redIAdd(p);var l=h.redAdd(h).redIAdd(h),b=l.redSqr(),y=d.redIAdd(d);y=y.redIAdd(y),y=y.redIAdd(y),e=b.redISub(p).redISub(p),t=l.redMul(p.redISub(e)).redISub(y),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),c=a.redSqr().redISub(o).redISub(o);e=c;var f=s.redIAdd(s);f=f.redIAdd(f),f=f.redIAdd(f),t=a.redMul(o.redISub(c)).redISub(f),r=this.y.redAdd(this.y)}else{var h=this.z.redSqr(),u=this.y.redSqr(),d=this.x.redMul(u),p=this.x.redSub(h).redMul(this.x.redAdd(h));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(u).redISub(h);var y=u.redSqr();y=y.redIAdd(y),y=y.redIAdd(y),y=y.redIAdd(y),t=p.redMul(l.redISub(e)).redISub(y)}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)),c=t.redAdd(t);c=c.redIAdd(c);var f=c.redMul(o),h=a.redSqr().redISub(f.redAdd(f)),u=f.redISub(h),d=o.redSqr();d=d.redIAdd(d),d=d.redIAdd(d),d=d.redIAdd(d);var p=a.redMul(u).redISub(d),l=r.redAdd(r).redMul(n);return this.curve.jpoint(h,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(),c=n.redIAdd(n);c=c.redIAdd(c),c=c.redIAdd(c),c=c.redIAdd(c);var f=i.redIAdd(o).redSqr().redISub(s).redISub(a).redISub(c),h=t.redMul(f);h=h.redIAdd(h),h=h.redIAdd(h);var u=this.x.redMul(a).redISub(h);u=u.redIAdd(u),u=u.redIAdd(u);var d=this.y.redMul(f.redMul(c.redISub(f)).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(u,d,p)},s.prototype.mul=function(e,t){return e=new c(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()?"":""},s.prototype.isInfinity=function(){return 0===this.z.cmpn(0)}},{"../../elliptic":103,"../curve":106,"bn.js":101,inherits:261}],109:[function(e,t,r){"use strict";function n(e){"short"===e.type?this.curve=new a.curve["short"](e):"edwards"===e.type?this.curve=new a.curve.edwards(e):this.curve=new a.curve.mont(e),this.g=this.curve.g,this.n=this.curve.n,this.hash=e.hash,c(this.g.validate(),"Invalid curve"),c(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"),c=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("p384",{type:"short",prime:null,p:"ffffffff ffffffff ffffffff ffffffff ffffffff ffffffff ffffffff fffffffe ffffffff 00000000 00000000 ffffffff",a:"ffffffff ffffffff ffffffff ffffffff ffffffff ffffffff ffffffff fffffffe ffffffff 00000000 00000000 fffffffc",b:"b3312fa7 e23ee7e4 988e056b e3f82d19 181d9c6e fe814112 0314088f 5013875a c656398d 8a2ed19d 2a85c8ed d3ec2aef",n:"ffffffff ffffffff ffffffff ffffffff ffffffff ffffffff c7634d81 f4372ddf 581a0db2 48b0a77a ecec196a ccc52973",hash:o.sha384,gRed:!1,g:["aa87ca22 be8b0537 8eb1c71e f320ad74 6e1d3b62 8ba79b98 59f741e0 82542a38 5502f25d bf55296c 3a545e38 72760ab7","3617de4a 96262c6f 5d9e98bf 9292dc29 f8f41dbd 289a147c e9da3113 b5f0b8c0 0a60b1ce 1d7e819d 7a431d7c 90ea0e5f"]}),i("p521",{type:"short",prime:null,p:"000001ff ffffffff ffffffff ffffffff ffffffff ffffffff ffffffff ffffffff ffffffff ffffffff ffffffff ffffffff ffffffff ffffffff ffffffff ffffffff ffffffff",a:"000001ff ffffffff ffffffff ffffffff ffffffff ffffffff ffffffff ffffffff ffffffff ffffffff ffffffff ffffffff ffffffff ffffffff ffffffff ffffffff fffffffc",b:"00000051 953eb961 8e1c9a1f 929a21a0 b68540ee a2da725b 99b315f3 b8b48991 8ef109e1 56193951 ec7e937b 1652c0bd 3bb1bf07 3573df88 3d2c34f1 ef451fd4 6b503f00",n:"000001ff ffffffff ffffffff ffffffff ffffffff ffffffff ffffffff ffffffff fffffffa 51868783 bf2f966b 7fcc0148 f709a5d0 3bb5c9b8 899c47ae bb6fb71e 91386409",hash:o.sha512,gRed:!1,g:["000000c6 858e06b7 0404e9cd 9e3ecb66 2395b442 9c648139 053fb521 f828af60 6b4d3dba a14b5e77 efe75928 fe1dc127 a2ffa8de 3348b3c1 856a429b f97e7e31 c2e5bd66","00000118 39296a78 9a3bc004 5c8a5fb4 2c7d1bd9 98f54449 579b4468 17afbd17 273e662c 97ee7299 5ef42640 c550b901 3fad0761 353c7086 a272c240 88be9476 9fd16650"]}),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 f;try{f=e("./precomputed/secp256k1")}catch(h){f=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",f]})},{"../elliptic":103,"./precomputed/secp256k1":117,"hash.js":120}],110:[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.ushrn(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,c=e("./key"),f=e("./signature");t.exports=n,n.prototype.keyPair=function(e){return new c(this,e)},n.prototype.keyFromPrivate=function(e,t){return c.fromPrivate(this,e,t)},n.prototype.keyFromPublic=function(e,t){return c.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.ushrn(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(),c=a.length;o>c;c++)a.unshift(0);for(var h=e.toArray(),c=h.length;o>c;c++)h.unshift(0);for(var u=new s.hmacDRBG({hash:this.hash,entropy:a,nonce:h}),d=this.n.sub(new i(1));;){var p=new i(u.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(),y=b.umod(this.n);if(0!==y.cmpn(0)){var g=p.invm(this.n).mul(y.mul(t.getPrivate()).iadd(e));if(g=g.umod(this.n),0!==g.cmpn(0)){var m=(l.getY().isOdd()?1:0)|(0!==b.cmp(y)?2:0);return n.canonical&&g.cmp(this.nh)>0&&(g=this.n.sub(g),m^=1),new f({r:y,s:g,recoveryParam:m})}}}}}},n.prototype.verify=function(e,t,r,n){e=this._truncateToN(new i(e,16)),r=this.keyFromPublic(r,n),t=new f(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),c=a.mul(e).umod(this.n),h=a.mul(s).umod(this.n),u=this.g.mulAdd(c,r.getPublic(),h);return u.isInfinity()?!1:0===u.getX().umod(this.n).cmp(s)},n.prototype.recoverPubKey=function(e,t,r,n){a((3&r)===r,"The recovery param is more than two bits"),t=new f(t,n);var s=this.n,o=new i(e),c=t.r,h=t.s,u=1&r,d=r>>1;if(c.cmp(this.curve.p.umod(this.curve.n))>=0&&d)throw new Error("Unable to find sencond key candinate");c=d?this.curve.pointFromX(c.add(this.curve.n),u):this.curve.pointFromX(c,u);var p=s.sub(o),l=t.r.invm(s);return c.mul(h).add(this.g.mul(p)).mul(l)},n.prototype.getKeyRecoveryParam=function(e,t,r,n){if(t=new f(t,n),null!==t.recoveryParam)return t.recoveryParam;for(var i=0;4>i;i++){var s=this.recoverPubKey(e,t,i);if(s.eq(r))return i}throw new Error("Unable to find valid recovery factor")}},{"../../elliptic":103,"./key":111,"./signature":112,"bn.js":101}],111:[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");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){return"string"==typeof e&&(t=e,e=null),this.pub||(this.pub=this.ec.g.mul(this.priv)),t?this.pub.encode(t,e):this.pub},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.umod(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)):void(this.pub=this.ec.curve.decodePoint(e,t))},n.prototype.derive=function(e){return e.mul(this.priv).getX()},n.prototype.sign=function(e,t,r){return this.ec.sign(e,this,t,r)},n.prototype.verify=function(e,t){return this.ec.verify(e,t,this)},n.prototype.inspect=function(){return""}},{"bn.js":101}],112:[function(e,t,r){"use strict";function n(e,t){return e instanceof n?e:void(this._importDER(e,t)||(u(e.r&&e.s,"Signature without r or s"),this.r=new c(e.r,16),this.s=new c(e.s,16),null!==e.recoveryParam?this.recoveryParam=e.recoveryParam:this.recoveryParam=null))}function i(){this.place=0}function s(e,t){var r=e[t.place++];if(!(128&r))return r;for(var n=15&r,i=0,s=0,o=t.place;n>s;s++,o++)i<<=8,i|=e[o];return t.place=o,i}function o(e){for(var t=0,r=e.length-1;!e[t]&&!(128&e[t+1])&&r>t;)t++;return 0===t?e:e.slice(t)}function a(e,t){if(128>t)return void e.push(t);var r=1+(Math.log(t)/Math.LN2>>>3);for(e.push(128|r);--r;)e.push(t>>>(r<<3)&255);e.push(t)}var c=e("bn.js"),f=e("../../elliptic"),h=f.utils,u=h.assert;t.exports=n,n.prototype._importDER=function(e,t){e=h.toArray(e,t);var r=new i;if(48!==e[r.place++])return!1;var n=s(e,r);if(n+r.place!==e.length)return!1;if(2!==e[r.place++])return!1;var o=s(e,r),a=e.slice(r.place,o+r.place);if(r.place+=o,2!==e[r.place++])return!1;var f=s(e,r);if(e.length!==f+r.place)return!1;var u=e.slice(r.place,f+r.place);return 0===a[0]&&128&a[1]&&(a=a.slice(1)),0===u[0]&&128&u[1]&&(u=u.slice(1)),this.r=new c(a),this.s=new c(u),this.recoveryParam=null,!0},n.prototype.toDER=function(e){var t=this.r.toArray(),r=this.s.toArray();for(128&t[0]&&(t=[0].concat(t)),128&r[0]&&(r=[0].concat(r)),t=o(t),r=o(r);!(r[0]||128&r[1]);)r=r.slice(1);var n=[2];a(n,t.length),n=n.concat(t),n.push(2),a(n,r.length);var i=n.concat(r),s=[48];return a(s,i.length),s=s.concat(i),h.encode(s,e)}},{"../../elliptic":103,"bn.js":101}],113:[function(e,t,r){"use strict";function n(e){if(a("ed25519"===e,"only tested with ed25519 so far"),!(this instanceof n))return new n(e);var e=s.curves[e].curve;this.curve=e,this.g=e.g,this.g.precompute(e.n.bitLength()+1),this.pointClass=e.point().constructor,this.encodingLength=Math.ceil(e.n.bitLength()/8),this.hash=i.sha512}var i=e("hash.js"),s=e("../../elliptic"),o=s.utils,a=o.assert,c=o.parseBytes,f=e("./key"),h=e("./signature");t.exports=n,n.prototype.sign=function(e,t){e=c(e);var r=this.keyFromSecret(t),n=this.hashInt(r.messagePrefix(),e),i=this.g.mul(n),s=this.encodePoint(i),o=this.hashInt(s,r.pubBytes(),e).mul(r.priv()),a=n.add(o).umod(this.curve.n);return this.makeSignature({R:i,S:a,Rencoded:s})},n.prototype.verify=function(e,t,r){e=c(e),t=this.makeSignature(t);var n=this.keyFromPublic(r),i=this.hashInt(t.Rencoded(),n.pubBytes(),e),s=this.g.mul(t.S()),o=t.R().add(n.pub().mul(i));return o.eq(s)},n.prototype.hashInt=function(){for(var e=this.hash(),t=0;t=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.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>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=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,c=1;a>c;c++)r.push(0);i.iushrn(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 c=e.andln(7)+n&7;a=3!==c&&5!==c||2!==o?s:-s}r[0].push(a);var f;if(0===(1&o))f=0;else{var c=t.andln(7)+i&7;f=3!==c&&5!==c||2!==s?o:-o}r[1].push(f),2*n===a+1&&(n=1-n),2*i===f+1&&(i=1-i),e.iushrn(1),t.iushrn(1)}return r}function c(e,t){var r=t.name,n="_"+r;e.prototype[r]=function(){return void 0!==this[n]?this[n]:this[n]=t.call(this)}}function f(e){return"string"==typeof e?u.toArray(e,"hex"):e}function h(e){return new d(e,"hex","le")}var u=r,d=e("bn.js");u.assert=function(e,t){if(!e)throw new Error(t||"Assertion failed")},u.toArray=n,u.zero2=i,u.toHex=s,u.encode=function(e,t){return"hex"===t?s(e):e},u.getNAF=o,u.getJSF=a,u.cachedProperty=c,u.parseBytes=f,u.intFromLE=h},{"bn.js":101}],119:[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)window.crypto&&window.crypto.getRandomValues?n.prototype._rand=function(e){var t=new Uint8Array(e);return window.crypto.getRandomValues(t),t}:window.msCrypto&&window.msCrypto.getRandomValues?n.prototype._rand=function(e){var t=new Uint8Array(e);return window.msCrypto.getRandomValues(t),t}:n.prototype._rand=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=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;ni;i++)n[i]=0;if(e<<=3,"big"===this.endian){for(var s=8;s>>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;sthis.blockSize&&(e=(new this.Hash).update(e).digest()),o(e.length<=this.blockSize);for(var t=e.length;t=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"),c=a.utils,f=c.rotl32,h=c.sum32,u=c.sum32_3,d=c.sum32_4,p=a.common.BlockHash;c.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],c=this.h[3],p=this.h[4],m=r,v=n,_=a,w=c,S=p,E=0;80>E;E++){var k=h(f(d(r,i(E,n,a,c),e[l[E]+t],s(E)),y[E]),p);r=p,p=c,c=f(a,10),a=n,n=k,k=h(f(d(m,i(79-E,v,_,w),e[b[E]+t],o(E)),g[E]),S),m=S,S=w,w=f(_,10),_=v,v=k}k=u(this.h[1],a,w),this.h[1]=u(this.h[2],c,S),this.h[2]=u(this.h[3],p,m),this.h[3]=u(this.h[4],r,v),this.h[4]=u(this.h[0],n,_),this.h[0]=k},n.prototype._digest=function(e){return"hex"===e?c.toHex32(this.h,"little"):c.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],y=[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],g=[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":120}],124:[function(e,t,r){function n(){return this instanceof n?(H.call(this),this.h=[1779033703,3144134277,1013904242,2773480762,1359893119,2600822924,528734635,1541459225],this.k=J,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?(H.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?(H.call(this),this.h=[1732584193,4023233417,2562383102,271733878,3285377520],void(this.W=new Array(80))):new a}function c(e,t,r){return e&t^~e&r}function f(e,t,r){return e&t^e&r^t&r}function h(e,t,r){return e^t^r}function u(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?c(t,r,n):1===e||3===e?h(t,r,n):2===e?f(t,r,n):void 0}function y(e,t,r,n,i,s){var o=e&r^~e&i;return 0>o&&(o+=4294967296),o}function g(e,t,r,n,i,s){var o=t&n^~t&s;return 0>o&&(o+=4294967296),o}function m(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=D(e,t,28),n=D(t,e,2),i=D(t,e,7),s=r^n^i;return 0>s&&(s+=4294967296),s}function w(e,t){var r=L(e,t,28),n=L(t,e,2),i=L(t,e,7),s=r^n^i;return 0>s&&(s+=4294967296),s}function S(e,t){var r=D(e,t,14),n=D(e,t,18),i=D(t,e,9),s=r^n^i;return 0>s&&(s+=4294967296),s}function E(e,t){var r=L(e,t,14),n=L(e,t,18),i=L(t,e,9),s=r^n^i;return 0>s&&(s+=4294967296),s}function k(e,t){var r=D(e,t,1),n=D(e,t,8),i=N(e,t,7),s=r^n^i;return 0>s&&(s+=4294967296),s}function x(e,t){var r=L(e,t,1),n=L(e,t,8),i=z(e,t,7),s=r^n^i;return 0>s&&(s+=4294967296),s}function A(e,t){var r=D(e,t,19),n=D(t,e,29),i=N(e,t,6),s=r^n^i;return 0>s&&(s+=4294967296),s}function B(e,t){var r=L(e,t,19),n=L(t,e,29),i=z(e,t,6),s=r^n^i;return 0>s&&(s+=4294967296),s}var I=e("../hash"),C=I.utils,j=C.assert,R=C.rotr32,M=C.rotl32,P=C.sum32,O=C.sum32_4,T=C.sum32_5,D=C.rotr64_hi,L=C.rotr64_lo,N=C.shr64_hi,z=C.shr64_lo,U=C.sum64,q=C.sum64_hi,X=C.sum64_lo,F=C.sum64_4_hi,K=C.sum64_4_lo,V=C.sum64_5_hi,Y=C.sum64_5_lo,H=I.common.BlockHash,J=[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],G=[1518500249,1859775393,2400959708,3395469782];C.inherits(n,H),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(;nn;n++)r[n]=e[t+n];for(;nn;n++)r[n]=e[t+n];for(;n>8,o=255&i;s?r.push(s,o):r.push(o)}else for(var n=0;n>>24|e>>>8&65280|e<<8&16711680|(255&e)<<24;return t>>>0}function o(e,t){for(var r="",n=0;n>>0}return s}function h(e,t){for(var r=new Array(4*e.length),n=0,i=0;n>>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 u(e,t){return e>>>t|e<<32-t}function d(e,t){return 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 y(e,t,r,n,i){return e+t+r+n+i>>>0}function g(e,t){if(!e)throw new Error(t||"Assertion failed")}function m(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 c=0,f=t;f=f+n>>>0,c+=t>f?1:0,f=f+s>>>0,c+=s>f?1:0,f=f+a>>>0,c+=a>f?1:0;var h=e+r+i+o+c;return h>>>0}function S(e,t,r,n,i,s,o,a){var c=t+n+s+a;return c>>>0}function E(e,t,r,n,i,s,o,a,c,f){var h=0,u=t;u=u+n>>>0,h+=t>u?1:0,u=u+s>>>0,h+=s>u?1:0,u=u+a>>>0,h+=a>u?1:0,u=u+f>>>0,h+=f>u?1:0;var d=e+r+i+o+c+h;return d>>>0}function k(e,t,r,n,i,s,o,a,c,f){var h=t+n+s+a+f;return h>>>0}function x(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 B(e,t,r){return e>>>r}function I(e,t,r){var n=e<<32-r|t>>>r;return n>>>0}var C=r,j=e("inherits");C.toArray=n,C.toHex=i,C.htonl=s,C.toHex32=o,C.zero2=a,C.zero8=c,C.join32=f,C.split32=h,C.rotr32=u,C.rotl32=d,C.sum32=p,C.sum32_3=l,C.sum32_4=b,C.sum32_5=y,C.assert=g,C.inherits=j,r.sum64=m,r.sum64_hi=v,r.sum64_lo=_,r.sum64_4_hi=w,r.sum64_4_lo=S,r.sum64_5_hi=E,r.sum64_5_lo=k,r.rotr64_hi=x,r.rotr64_lo=A,r.shr64_hi=B,r.shr64_lo=I},{inherits:261}],126:[function(e,t,r){t.exports={name:"elliptic",version:"6.0.1",description:"EC cryptography",main:"lib/elliptic.js",scripts:{test:"make lint && istanbul test _mocha --reporter=spec test/*-test.js",coveralls:"cat ./coverage/lcov.info | coveralls"},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",coveralls:"^2.11.3",istanbul:"^0.3.17",jscs:"^1.11.3",jshint:"^2.6.0",mocha:"^2.1.0","uglify-js":"^2.4.13"},dependencies:{"bn.js":"^4.0.0",brorand:"^1.0.1","hash.js":"^1.0.0",inherits:"^2.0.1"},gitHead:"a9eb628eec9a2f562e67947c5417e9b2435d0a2d",_id:"elliptic@6.0.1",_shasum:"91d573ecb2a3c274b8c07e0d1f35ff19f07e6978",_from:"elliptic@>=6.0.0 <7.0.0",_npmVersion:"3.3.6",_nodeVersion:"5.0.0",_npmUser:{name:"indutny",email:"fedor@indutny.com"},dist:{shasum:"91d573ecb2a3c274b8c07e0d1f35ff19f07e6978",tarball:"http://registry.npmjs.org/elliptic/-/elliptic-6.0.1.tgz"},maintainers:[{name:"indutny",email:"fedor@indutny.com"}],directories:{},_resolved:"https://registry.npmjs.org/elliptic/-/elliptic-6.0.1.tgz",readme:"ERROR: No README data found!"}},{}],127:[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"}},{}],128:[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())}),c=n.define("PrivateKeyInfo",function(){this.seq().obj(this.key("version")["int"](),this.key("algorithm").use(a),this.key("subjectPrivateKey").octstr())});r.PrivateKey=c;var f=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=f;var h=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=h,r.DSAparam=n.define("DSAparam",function(){this["int"]()});var u=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=u;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":131}],129:[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 c,f=e.toString(),h=f.match(n);if(h){var u="aes"+h[1],d=new r(h[2],"hex"),p=new r(h[3].replace(/\r?\n/g,""),"base64"),l=o(t,d.slice(0,8),parseInt(h[1],10)).key,b=[],y=a.createDecipheriv(u,l,d);b.push(y.update(p)),b.push(y["final"]()),c=r.concat(b)}else{var g=f.match(s);c=new r(g[2].replace(/\r?\n/g,""),"base64")}var m=f.match(i)[1]+" KEY";return{tag:m,data:c}}}).call(this,e("buffer").Buffer)},{"browserify-aes":148,buffer:64,evp_bytestokey:163}],130:[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,c=a(e,t),f=c.tag,h=c.data;switch(f){case"PUBLIC KEY":switch(o=s.PublicKey.decode(h,"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 "+f);case"ENCRYPTED PRIVATE KEY":h=s.EncryptedPrivateKey.decode(h,"der"),h=i(h,t);case"PRIVATE KEY":switch(o=s.PrivateKey.decode(h,"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 "+f);case"RSA PUBLIC KEY":return s.RSAPublicKey.decode(h,"der");case"RSA PRIVATE KEY":return s.RSAPrivateKey.decode(h,"der");case"DSA PRIVATE KEY":return{type:"dsa",params:s.DSAPrivateKey.decode(h,"der")};case"EC PRIVATE KEY":return h=s.ECPrivateKey.decode(h,"der"),{curve:h.parameters.value,privateKey:h.privateKey};default:throw new Error("unknown key type "+f)}}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,h=e.subjectPrivateKey,u=parseInt(s.split("-")[1],10)/8,d=f.pbkdf2Sync(t,n,i,u),p=c.createDecipheriv(s,d,a),l=[];return l.push(p.update(h)),l.push(p["final"]()),r.concat(l)}var s=e("./asn1"),o=e("./aesid.json"),a=e("./fixProc"),c=e("browserify-aes"),f=e("pbkdf2");t.exports=n,n.signature=s.signature}).call(this,e("buffer").Buffer)},{"./aesid.json":127,"./asn1":128,"./fixProc":129,"browserify-aes":148,buffer:64,pbkdf2:213}],131:[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":132,"./asn1/base":134,"./asn1/constants":138,"./asn1/decoders":140,"./asn1/encoders":143,"bn.js":101}],132:[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":131,inherits:261,vm:282}],133:[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":134,buffer:64,inherits:261}],134:[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":133,"./node":135,"./reporter":136}],135:[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","utf8str"],c=["key","obj","use","optional","explicit","implicit","def","choice","any"].concat(a),f=["_peekTag","_decodeTag","_use","_decodeStr","_decodeObjid","_decodeTime","_decodeNull","_decodeInt","_decodeBool","_decodeList","_encodeComposite","_encodeStr","_encodeObjid","_encodeTime","_encodeNull","_encodeInt","_encodeBool"];t.exports=n;var h=["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={};h.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;c.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}))},f.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 c;if(t.obj&&i&&(c=e.enterObject()),i){if(null!==t.explicit){var f=this._decodeTag(e,t.explicit);if(e.isError(f))return f;e=f}if(null===t.use&&null===t.choice){if(t.any)var o=e.save();var h=this._decodeTag(e,null!==t.implicit?t.implicit:t.tag,t.any);if(e.isError(h))return h;t.any?n=e.raw(o):e=h}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 u=t.children.some(function(t){t._decode(e)});if(u)return err}}return t.obj&&i&&(n=e.leaveObject(c)),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?this._decodeStr(t,e):"ia5str"===e||"utf8str"===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(c){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 c=this.clone();c._baseState.implicit=null,o=this._createEncoderBuffer(e.map(function(r){var n=this._baseState;return this._getUse(n.args[0],e)._encode(r,t)},c))}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 f=null!==n.implicit?n.implicit:n.tag,h=null===n.implicit?"universal":"context";null===f?null===n.use&&t.error("Tag could be ommited only for .use()"):null===n.use&&(s=this._encodeComposite(f,a,h,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("utf8str"===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":134,"minimalistic-assert":145}],136:[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:261}],137:[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":138}],138:[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":137}],139:[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){f.Node.call(this,"der",e)}function s(e,t){var r=e.readUInt8(t);if(e.isError(r))return r;var n=u.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=u.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"),c=e("../../asn1"),f=c.base,h=c.bignum,u=c.constants.der;t.exports=n,n.prototype.decode=function(e,t){return e instanceof f.DecoderBuffer||(e=new f.DecoderBuffer(e,t)),this.tree._decode(e,t)},a(i,f.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.save(),c=this._skipUntilEnd(e,'Failed to skip indefinite length body: "'+this.tag+'"');return e.isError(c)?c:(i=e.offset-a.offset,e.restore(a),e.skip(i,'Failed to match body of: "'+t+'"'))},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||"utf8str"===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 r?result=n:result=[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),c=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),c=0|r.slice(10,12);n=70>n?2e3+n:1900+n}return Date.UTC(n,i-1,s,o,a,c,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 h(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":131,inherits:261}],140:[function(e,t,r){var n=r;n.der=e("./der"),n.pem=e("./pem")},{"./der":139,"./pem":141}],141:[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,c=-1,f=0;fe?"0"+e:e}function o(e,t,r,n){var i;if("seqof"===e?e="seq":"setof"===e&&(e="set"),u.tagByName.hasOwnProperty(e))i=u.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|=u.tagClassByName[r||"universal"]<<6)}var a=e("inherits"),c=e("buffer").Buffer,f=e("../../asn1"),h=f.base,u=(f.bignum,f.constants.der);t.exports=n,n.prototype.encode=function(e,t){return this.tree._encode(e,t).join()},a(i,h.Node),i.prototype._encodeComposite=function(e,t,r,n){var i=o(e,t,r,this.reporter);if(n.length<128){var s=new c(2);return s[0]=i,s[1]=n.length,this._createEncoderBuffer([s,n])}for(var a=1,f=n.length;f>=256;f>>=8)a++;var s=new c(2+a);s[0]=i,s[1]=128|a;for(var f=1+a,h=n.length;h>0;f--,h>>=8)s[f]=255&h;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||"utf8str"===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=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=128;s>>=7)i++}for(var o=new c(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&&!c.isBuffer(e)){var r=e.toArray();!e.sign&&128&r[0]&&r.unshift(0),e=new c(r)}if(c.isBuffer(e)){var n=e.length;0===e.length&&n++;var i=new c(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 c(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;na||0>e?(r=Math.abs(e)%a,0>e?a-r:r):e}function n(e){for(var t=0;te;t=++e)128>t?r.push(t<<1):r.push(t<<1^283);return r}(),i=0,c=0,t=f=0;256>f;t=++f)r=c^c<<1^c<<2^c<<3^c<<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=c=1:(i=s^e[e[e[a^s]]],c^=e[e[c]]);return!0};var c=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=c.SBOX[s>>>24]<<24|c.SBOX[s>>>16&255]<<16|c.SBOX[s>>>8&255]<<8|c.SBOX[255&s],s^=c.RCON[n/t|0]<<24):t>6&&n%t===4?s=c.SBOX[s>>>24]<<24|c.SBOX[s>>>16&255]<<16|c.SBOX[s>>>8&255]<<8|c.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:c.INV_SUB_MIX[0][c.SBOX[s>>>24]]^c.INV_SUB_MIX[1][c.SBOX[s>>>16&255]]^c.INV_SUB_MIX[2][c.SBOX[s>>>8&255]]^c.INV_SUB_MIX[3][c.SBOX[255&s]];return!0},o.prototype.encryptBlock=function(t){t=s(new e(t));var r=this._doCryptBlock(t,this._keySchedule,c.SUB_MIX,c.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,c.INV_SUB_MIX,c.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,c,f,h,u,d,p;o=e[0]^r[0],a=e[1]^r[1],c=e[2]^r[2],f=e[3]^r[3],s=4;for(var l=1;l>>24]^n[1][a>>>16&255]^n[2][c>>>8&255]^n[3][255&f]^r[s++],u=n[0][a>>>24]^n[1][c>>>16&255]^n[2][f>>>8&255]^n[3][255&o]^r[s++],d=n[0][c>>>24]^n[1][f>>>16&255]^n[2][o>>>8&255]^n[3][255&a]^r[s++],p=n[0][f>>>24]^n[1][o>>>16&255]^n[2][a>>>8&255]^n[3][255&c]^r[s++],o=h,a=u,c=d,f=p;return h=(i[o>>>24]<<24|i[a>>>16&255]<<16|i[c>>>8&255]<<8|i[255&f])^r[s++],u=(i[a>>>24]<<24|i[c>>>16&255]<<16|i[f>>>8&255]<<8|i[255&o])^r[s++],d=(i[c>>>24]<<24|i[f>>>16&255]<<16|i[o>>>8&255]<<8|i[255&a])^r[s++],p=(i[f>>>24]<<24|i[o>>>16&255]<<16|i[a>>>8&255]<<8|i[255&c])^r[s++],[t(h),t(u),t(d),t(p)]},r.AES=o}).call(this,e("buffer").Buffer)},{buffer:64}],147:[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 f=new r(4);f.fill(0),this._ghash=new c(this._cipher.encryptBlock(f)),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;++it&&(t=new r(t),t.fill(0),this._ghash.update(t))}this._called=!0;var n=this._mode.encrypt(this,e);return this._decrypt?this._ghash.update(e):this._ghash.update(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=f(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":146,"./ghash":151,buffer:64,"buffer-xor":160,"cipher-base":161,inherits:261}],148:[function(e,t,r){arguments[4][72][0].apply(r,arguments)},{"./decrypter":149,"./encrypter":150,"./modes":152,dup:72}],149:[function(e,t,r){(function(t){function n(e,r,s){return this instanceof n?(f.call(this),this._cache=new i,this._last=void 0,this._cipher=new c.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;++r16)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)},{"./aes":146,"./authCipher":147,"./modes":152,"./modes/cbc":153,"./modes/cfb":154,"./modes/cfb1":155,"./modes/cfb8":156,"./modes/ctr":157,"./modes/ecb":158,"./modes/ofb":159,"./streamCipher":162,buffer:64,"cipher-base":161,evp_bytestokey:163,inherits:261}],150:[function(e,t,r){(function(t){function n(e,r,s){return this instanceof n?(c.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=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(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=h[e.toLowerCase()];if(!r)throw new TypeError("invalid suite type");var n=u(t,!1,r.key,r.iv);return s(e,n.key,n.iv)}var a=e("./aes"),c=e("cipher-base"),f=e("inherits"),h=e("./modes"),u=e("evp_bytestokey"),d=e("./streamCipher"),p=e("./authCipher");f(n,c),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;++nc||0>e?(r=Math.abs(e)%c,0>e?c-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;++t0;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 c=Math.pow(2,32)}).call(this,e("buffer").Buffer)},{buffer:64}],152:[function(e,t,r){arguments[4][76][0].apply(r,arguments)},{dup:76}],153:[function(e,t,r){arguments[4][77][0].apply(r,arguments)},{"buffer-xor":160,dup:77}],154:[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:64,"buffer-xor":160}],155:[function(e,t,r){(function(e){function t(e,t,r){for(var i,s,o,a=-1,c=8,f=0;++a>a%8,e._prev=n(e._prev,r?s:o);return f}function n(t,r){var n=t.length,i=-1,s=new e(t.length);for(t=e.concat([t,new e([r])]);++i>7;return s}r.encrypt=function(r,n,i){for(var s=n.length,o=new e(s),a=-1;++as;++s)i[s]=t[s]^r[s];return i}}).call(this,e("buffer").Buffer)},{buffer:64}],161:[function(e,t,r){(function(r){function n(e){i.call(this),this.hashMode="string"==typeof e,this.hashMode?this[e]=this._finalOrDigest:this["final"]=this._finalOrDigest,this._decoder=null,this._encoding=null}var i=e("stream").Transform,s=e("inherits"),o=e("string_decoder").StringDecoder;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 this.hashMode?this:(n&&(i=this._toString(i,n)),i)},n.prototype.setAutoPadding=function(){},n.prototype.getAuthTag=function(){throw new Error("trying to get auth tag in unsupported state")},n.prototype.setAuthTag=function(){throw new Error("trying to set auth tag in unsupported state")},n.prototype.setAAD=function(){throw new Error("trying to set aad in unsupported state")},n.prototype._transform=function(e,t,r){var n;try{this.hashMode?this._update(e):this.push(this._update(e))}catch(i){n=i}finally{r(n)}},n.prototype._flush=function(e){var t;try{this.push(this._final())}catch(r){t=r}finally{e(t)}},n.prototype._finalOrDigest=function(e){var t=this._final()||new r("");return e&&(t=this._toString(t,e,!0)),t},n.prototype._toString=function(e,t,r){if(this._decoder||(this._decoder=new o(t),this._encoding=t),this._encoding!==t)throw new Error("can't switch encodings");var n=this._decoder.write(e);return r&&(n+=this._decoder.end()),n}}).call(this,e("buffer").Buffer)},{buffer:64,inherits:261,stream:278,string_decoder:279}],162:[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("cipher-base"),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":146,buffer:64,"cipher-base":161,inherits:261}],163:[function(e,t,r){(function(r){function n(e,t,n,s){r.isBuffer(e)||(e=new r(e,"binary")),t&&!r.isBuffer(t)&&(t=new r(t,"binary")),n/=8,s=s||0;for(var o,a,c=0,f=0,h=new r(n),u=new r(s),d=0,p=[];;){if(d++>0&&p.push(o),p.push(e),t&&p.push(t),o=i(r.concat(p)),p=[],a=0,n>0)for(;;){if(0===n)break;if(a===o.length)break;h[c++]=o[a],n--,a++}if(s>0&&a!==o.length)for(;;){if(0===s)break;if(a===o.length)break;u[f++]=o[a],s--,a++}if(0===n&&0===s)break}for(a=0;a0&&r.ishrn(n),r}function f(e,t){e=c(e,t),e=e.mod(t);var n=new r(e.toArray());if(n.lengthd&&(b=1),c=Math.min(e.length,u.length),e.length!==u.length&&(b=1),p=-1;++p=t)throw new Error("invalid sig")}var a=e("./curves"),c=e("elliptic"),f=e("parse-asn1"),h=e("bn.js"),u=c.ec;t.exports=n}).call(this,e("buffer").Buffer)},{"./curves":100,"bn.js":101,buffer:64,elliptic:103,"parse-asn1":130}],166:[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>5]|=128<>>9<<4)+14]=t;for(var r=1732584193,n=-271733879,i=-1732584194,h=271733878,u=0;u>16)+(t>>16)+(r>>16);return n<<16|65535&r}function h(e,t){return e<>>32-t}var u=e("./helpers");t.exports=function(e){return u.hash(e,n,16)}},{"./helpers":193}],195:[function(e,t,r){(function(r){function n(e){i.call(this),this.hashMode="string"==typeof e,this.hashMode?this[e]=this._finalOrDigest:this["final"]=this._finalOrDigest,this._decoder=null,this._encoding=null}var i=e("stream").Transform,s=e("inherits"),o=e("string_decoder").StringDecoder;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 this.hashMode?this:(n&&(i=this._toString(i,n)),i)},n.prototype.setAutoPadding=function(){},n.prototype.getAuthTag=function(){throw new Error("trying to get auth tag in unsupported state")},n.prototype.setAuthTag=function(){throw new Error("trying to set auth tag in unsupported state")},n.prototype.setAAD=function(){throw new Error("trying to set aad in unsupported state")},n.prototype._transform=function(e,t,r){var n;try{this.hashMode?this._update(e):this.push(this._update(e))}catch(i){n=i}finally{r(n)}},n.prototype._flush=function(e){var t;try{this.push(this._final())}catch(r){t=r}finally{e(t)}},n.prototype._finalOrDigest=function(e){var t=this._final()||new r("");return e&&(t=this._toString(t,e,!0)),t},n.prototype._toString=function(e,t,r){if(this._decoder||(this._decoder=new o(t),this._encoding=t),this._encoding!==t)throw new Error("can't switch encodings");var n=this._decoder.write(e);return r&&(n+=this._decoder.end()),n}}).call(this,e("buffer").Buffer)},{buffer:64,inherits:261,stream:278,string_decoder:279}],196:[function(e,t,r){(function(e){function r(e){for(var t=[],r=0,n=0;r>>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,u=t[i];t[i]=16711935&(u<<8|u>>>24)|4278255360&(u<<24|u>>>8)}var m,v,_,w,S,E,k,x,A,B;E=m=e[0],k=v=e[1],x=_=e[2],A=w=e[3],B=S=e[4];var I;for(n=0;80>n;n+=1)I=m+t[r+d[n]]|0,I+=16>n?s(v,_,w)+y[0]:32>n?o(v,_,w)+y[1]:48>n?a(v,_,w)+y[2]:64>n?c(v,_,w)+y[3]:f(v,_,w)+y[4],I=0|I,I=h(I,l[n]),I=I+S|0,m=S,S=w,w=h(_,10),_=v,v=I,I=E+t[r+p[n]]|0,I+=16>n?f(k,x,A)+g[0]:32>n?c(k,x,A)+g[1]:48>n?a(k,x,A)+g[2]:64>n?o(k,x,A)+g[3]:s(k,x,A)+g[4], I=0|I,I=h(I,b[n]),I=I+B|0,E=B,B=A,A=h(x,10),x=k,k=I;I=e[1]+_+A|0,e[1]=e[2]+w+B|0,e[2]=e[3]+S+E|0,e[3]=e[4]+m+k|0,e[4]=e[0]+v+x|0,e[0]=I}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 c(e,t,r){return e&r|t&~r}function f(e,t,r){return e^(t|~r)}function h(e,t){return e<>>32-t}function u(t){var s=[1732584193,4023233417,2562383102,271733878,3285377520];"string"==typeof t&&(t=new e(t,"utf8"));var o=r(t),a=8*t.length,c=8*t.length;o[a>>>5]|=128<<24-a%32,o[(a+64>>>9<<4)+14]=16711935&(c<<8|c>>>24)|4278255360&(c<<24|c>>>8);for(var f=0;ff;f++){var h=s[f];s[f]=16711935&(h<<8|h>>>24)|4278255360&(h<<24|h>>>8)}var u=n(s);return new e(u)}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],y=[0,1518500249,1859775393,2400959708,2840853838],g=[1352829926,1548603684,1836072691,2053994217,0];t.exports=u}).call(this,e("buffer").Buffer)},{buffer:64}],197:[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),c=a-s,f=0;c>f;f++)o[i%this._blockSize+f]=t[f+s];i+=c,s+=c,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:64}],198:[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":199,"./sha1":200,"./sha224":201,"./sha256":202,"./sha384":203,"./sha512":204}],199:[function(e,t,r){(function(r){function n(){this.init(),this._w=a,o.call(this,64,56)}function i(e,t){return 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[u-3]^s[u-8]^s[u-14]^s[u-16]}function r(e,t){s[u]=e;var r=i(o,5)+t+h+e+n;h=f,f=c,c=i(a,30),a=o,o=r,u++}var n,s=this._w,o=this._a,a=this._b,c=this._c,f=this._d,h=this._e,u=0;for(n=1518500249;16>u;)r(e.readInt32BE(4*u),a&c|~a&f);for(;20>u;)r(t(),a&c|~a&f);for(n=1859775393;40>u;)r(t(),a^c^f);for(n=-1894007588;60>u;)r(t(),a&c|a&f|c&f);for(n=-899497514;80>u;)r(t(),a^c^f);this._a=o+this._a|0,this._b=a+this._b|0,this._c=c+this._c|0,this._d=f+this._d|0,this._e=h+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":197,buffer:64,inherits:261}],200:[function(e,t,r){(function(r){function n(){this.init(),this._w=a,o.call(this,64,56)}function i(e,t){return 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[u-3]^s[u-8]^s[u-14]^s[u-16],1)}function r(e,t){s[u]=e;var r=i(o,5)+t+h+e+n;h=f,f=c,c=i(a,30),a=o,o=r,u++}var n,s=this._w,o=this._a,a=this._b,c=this._c,f=this._d,h=this._e,u=0;for(n=1518500249;16>u;)r(e.readInt32BE(4*u),a&c|~a&f);for(;20>u;)r(t(),a&c|~a&f);for(n=1859775393;40>u;)r(t(),a^c^f);for(n=-1894007588;60>u;)r(t(),a&c|a&f|c&f);for(n=-899497514;80>u;)r(t(),a^c^f);this._a=o+this._a|0,this._b=a+this._b|0,this._c=c+this._c|0,this._d=f+this._d|0,this._e=h+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":197,buffer:64,inherits:261}],201:[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":197,"./sha256":202,buffer:64,inherits:261}],202:[function(e,t,r){(function(r){function n(){this.init(),this._w=p,u.call(this,64,56)}function i(e,t,r){return r^e&(t^r)}function s(e,t,r){return e&t|r&(e|t)}function o(e){return(e>>>2|e<<30)^(e>>>13|e<<19)^(e>>>22|e<<10)}function a(e){return(e>>>6|e<<26)^(e>>>11|e<<21)^(e>>>25|e<<7)}function c(e){return(e>>>7|e<<25)^(e>>>18|e<<14)^e>>>3}function f(e){return(e>>>17|e<<15)^(e>>>19|e<<13)^e>>>10}var h=e("inherits"),u=e("./hash"),d=[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],p=new Array(64);h(n,u),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 f(n[v-2])+n[v-7]+c(n[v-15])+n[v-16]}function r(e){n[v]=e;var t=m+a(b)+i(b,y,g)+d[v]+e,r=o(h)+s(h,u,p);m=g,g=y,y=b,b=l+t,l=p,p=u,u=h,h=t+r,v++}for(var n=this._w,h=0|this._a,u=0|this._b,p=0|this._c,l=0|this._d,b=0|this._e,y=0|this._f,g=0|this._g,m=0|this._h,v=0;16>v;)r(e.readInt32BE(4*v));for(;64>v;)r(t());this._a=h+this._a|0,this._b=u+this._b|0,this._c=p+this._c|0,this._d=l+this._d|0,this._e=b+this._e|0,this._f=y+this._f|0,this._g=g+this._g|0,this._h=m+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":197,buffer:64,inherits:261}],203:[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":197,"./sha512":204,buffer:64,inherits:261}],204:[function(e,t,r){(function(r){function n(){this.init(),this._w=b,p.call(this,128,112)}function i(e,t,r){return r^e&(t^r)}function s(e,t,r){return e&t|r&(e|t)}function o(e,t){return(e>>>28|t<<4)^(t>>>2|e<<30)^(t>>>7|e<<25)}function a(e,t){return(e>>>14|t<<18)^(e>>>18|t<<14)^(t>>>9|e<<23)}function c(e,t){return(e>>>1|t<<31)^(e>>>8|t<<24)^e>>>7}function f(e,t){return(e>>>1|t<<31)^(e>>>8|t<<24)^(e>>>7|t<<25)}function h(e,t){return(e>>>19|t<<13)^(t>>>29|e<<3)^e>>>6}function u(e,t){return(e>>>19|t<<13)^(t>>>29|e<<3)^(e>>>6|t<<26)}var d=e("inherits"),p=e("./hash"),l=[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],b=new Array(160);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._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=p[M-30],t=p[M-30+1],r=c(e,t),i=f(t,e);e=p[M-4],t=p[M-4+1];var s=h(e,t),o=u(t,e),a=p[M-14],l=p[M-14+1],b=p[M-32],y=p[M-32+1];d=i+l,n=r+a+(i>>>0>d>>>0?1:0),d+=o,n=n+s+(o>>>0>d>>>0?1:0),d+=y,n=n+b+(y>>>0>d>>>0?1:0)}function r(){p[M]=n,p[M+1]=d;var e=s(b,y,g),t=s(E,k,x),r=o(b,E),c=o(E,b),f=a(v,B),h=a(B,v),u=l[M],P=l[M+1],O=i(v,_,w),T=i(B,I,C),D=j+h,L=S+f+(j>>>0>D>>>0?1:0);D+=T,L=L+O+(T>>>0>D>>>0?1:0),D+=P,L=L+u+(P>>>0>D>>>0?1:0),D+=d,L=L+n+(d>>>0>D>>>0?1:0);var N=c+t,z=r+e+(c>>>0>N>>>0?1:0);S=w,j=C,w=_,C=I,_=v,I=B,B=A+D|0,v=m+L+(A>>>0>B>>>0?1:0)|0,m=g,A=x,g=y,x=k,y=b,k=E,E=D+N|0,b=L+z+(D>>>0>E>>>0?1:0)|0,R++,M+=2}for(var n,d,p=this._w,b=0|this._a,y=0|this._b,g=0|this._c,m=0|this._d,v=0|this._e,_=0|this._f,w=0|this._g,S=0|this._h,E=0|this._al,k=0|this._bl,x=0|this._cl,A=0|this._dl,B=0|this._el,I=0|this._fl,C=0|this._gl,j=0|this._hl,R=0,M=0;16>R;)n=e.readInt32BE(4*M),d=e.readInt32BE(4*M+4),r();for(;80>R;)t(),r();this._al=this._al+E|0,this._bl=this._bl+k|0,this._cl=this._cl+x|0,this._dl=this._dl+A|0,this._el=this._el+B|0,this._fl=this._fl+I|0,this._gl=this._gl+C|0,this._hl=this._hl+j|0,this._a=this._a+b+(this._al>>>0>>0?1:0)|0,this._b=this._b+y+(this._bl>>>0>>0?1:0)|0,this._c=this._c+g+(this._cl>>>0>>0?1:0)|0,this._d=this._d+m+(this._dl>>>0>>0?1:0)|0,this._e=this._e+v+(this._el>>>0>>0?1:0)|0,this._f=this._f+_+(this._fl>>>0>>0?1:0)|0,this._g=this._g+w+(this._gl>>>0>>0?1:0)|0,this._h=this._h+S+(this._hl>>>0>>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":197,buffer:64,inherits:261}],205:[function(e,t,r){(function(r){"use strict";function n(e,t){o.call(this),e=e.toLowerCase(),"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.lengthf;f++)s[f]=54^t[f],c[f]=92^t[f];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:64,"create-hash/browser":192,inherits:261,stream:278}],206:[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":207,"./lib/generatePrime":208,"./lib/primes":209,buffer:64}],207:[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 m)return m[n];var i=0;if(e.isEven()||!y.simpleSieve||!y.fermatTest(e)||!h.test(e))return i+=1,i+="02"===r||"05"===r?8:4,m[n]=i,i;h.test(e.shrn(1))||(i+=2);var s;switch(r){case"02":e.mod(u).cmp(d)&&(i+=8);break;case"05":s=e.mod(p),s.cmp(l)&&s.cmp(b)&&(i+=8);break;default:i+=4}return m[n]=i,i}function o(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,this._primeCode=void 0,r?(this.setPublicKey=n,this.setPrivateKey=i):this._primeCode=8}function a(e,t){var n=new r(e.toArray());return t?n.toString(t):n}var c=e("bn.js"),f=e("miller-rabin"),h=new f,u=new c(24),d=new c(11),p=new c(10),l=new c(3),b=new c(7),y=e("./generatePrime"),g=e("randombytes");t.exports=o;var m={};Object.defineProperty(o.prototype,"verifyError",{enumerable:!0,get:function(){return"number"!=typeof this._primeCode&&(this._primeCode=s(this.__prime,this.__gen)),this._primeCode}}),o.prototype.generateKeys=function(){return this._priv||(this._priv=new c(g(this._primeLen))),this._pub=this._gen.toRed(this._prime).redPow(this._priv).fromRed(),this.getPublicKey()},o.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.lengthn;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 v=t,t}function i(e){for(var t=n(),r=0;re)return new c(2===t||5===t?[140,123]:[140,39]);t=new c(t);for(var r,n;;){for(r=new c(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))for(;r.mod(b).cmp(y);)r.iadd(m)}else for(;r.mod(f).cmp(g);)r.iadd(m);if(n=r.shrn(1),i(n)&&i(r)&&s(n)&&s(r)&&u.test(n)&&u.test(r))return r}}var a=e("randombytes");t.exports=o,o.simpleSieve=i,o.fermatTest=s;var c=e("bn.js"),f=new c(24),h=e("miller-rabin"),u=new h,d=new c(1),p=new c(2),l=new c(5),b=(new c(16),new c(8),new c(10)),y=new c(3),g=(new c(7),new c(11)),m=new c(4),v=(new c(12),null)},{"bn.js":210,"miller-rabin":211,randombytes:259}],209:[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"}}},{}],210:[function(e,t,r){arguments[4][101][0].apply(r,arguments)},{dup:101}],211:[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),c=a.subn(1),f=0;!a.testn(f);f++);for(var h=e.shrn(f),u=a.toRed(s),d=!0;t>0;t--){var p=this._rand(c);r&&r(p);var l=p.toRed(s).redPow(h);if(0!==l.cmp(o)&&0!==l.cmp(u)){for(var b=1;f>b;b++){if(l=l.redSqr(),0===l.cmp(o))return!1;if(0===l.cmp(u))break}if(b===f)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),c=0;!o.testn(c);c++);for(var f=e.shrn(c),h=o.toRed(n);t>0;t--){var u=this._rand(a),d=e.gcd(u);if(0!==d.cmpn(1))return d;var p=u.toRed(n).redPow(f);if(0!==p.cmp(s)&&0!==p.cmp(h)){for(var l=1;c>l;l++){if(p=p.redSqr(),0===p.cmp(s))return p.fromRed().subn(1).gcd(e);if(0===p.cmp(h))break}if(l===c)return p=p.redSqr(),p.fromRed().subn(1).gcd(e)}}return!1}},{"bn.js":210,brorand:212}],212:[function(e,t,r){arguments[4][119][0].apply(r,arguments)},{dup:119}],213:[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 c,f=1,h=new t(i),u=new t(r.length+4);r.copy(u,0,0,r.length);for(var d,p,l=1;f>=l;l++){u.writeUInt32BE(l,r.length);var b=s(a,e).update(u).digest();c||(c=b.length,p=new t(c),f=Math.ceil(i/c),d=i-(f-1)*c),b.copy(p,0,0,c);for(var y=1;n>y;y++){b=s(a,e).update(b).digest();for(var g=0;c>g;g++)p[g]^=b[g]}var m=(l-1)*c,v=l===f?d:c;p.copy(h,m,0,v)}return h}var s=e("create-hmac"),o=Math.pow(2,30)-1;r.pbkdf2=n,r.pbkdf2Sync=i}).call(this,e("buffer").Buffer)},{buffer:64,"create-hmac":205}],214:[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":255,"./publicEncrypt":256}],215:[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=0||!r.umod(e.prime1)||!r.umod(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":216,buffer:64,randombytes:259}],218:[function(e,t,r){arguments[4][127][0].apply(r,arguments)},{dup:127}],219:[function(e,t,r){arguments[4][128][0].apply(r,arguments)},{"asn1.js":222,dup:128}],220:[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 c,f=e.toString(),h=f.match(n);if(h){var u="aes"+h[1],d=new r(h[2],"hex"),p=new r(h[3].replace(/\r?\n/g,""),"base64"),l=o(t,d.slice(0,8),parseInt(h[1],10)).key,b=[],y=a.createDecipheriv(u,l,d);b.push(y.update(p)),b.push(y["final"]()),c=r.concat(b)}else{var g=f.match(s);c=new r(g[2].replace(/\r?\n/g,""),"base64")}var m=f.match(i)[1]+" KEY";return{tag:m,data:c}}}).call(this,e("buffer").Buffer)},{"browserify-aes":239,buffer:64,evp_bytestokey:254}],221:[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,c=a(e,t),f=c.tag,h=c.data;switch(f){case"PUBLIC KEY":switch(o=s.PublicKey.decode(h,"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 "+f);case"ENCRYPTED PRIVATE KEY":h=s.EncryptedPrivateKey.decode(h,"der"),h=i(h,t);case"PRIVATE KEY":switch(o=s.PrivateKey.decode(h,"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 "+f);case"RSA PUBLIC KEY":return s.RSAPublicKey.decode(h,"der");case"RSA PRIVATE KEY":return s.RSAPrivateKey.decode(h,"der");case"DSA PRIVATE KEY":return{type:"dsa",params:s.DSAPrivateKey.decode(h,"der")};case"EC PRIVATE KEY":return h=s.ECPrivateKey.decode(h,"der"),{curve:h.parameters.value,privateKey:h.privateKey};default:throw new Error("unknown key type "+f)}}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,h=e.subjectPrivateKey,u=parseInt(s.split("-")[1],10)/8,d=f.pbkdf2Sync(t,n,i,u),p=c.createDecipheriv(s,d,a),l=[]; return l.push(p.update(h)),l.push(p["final"]()),r.concat(l)}var s=e("./asn1"),o=e("./aesid.json"),a=e("./fixProc"),c=e("browserify-aes"),f=e("pbkdf2");t.exports=n,n.signature=s.signature}).call(this,e("buffer").Buffer)},{"./aesid.json":218,"./asn1":219,"./fixProc":220,"browserify-aes":239,buffer:64,pbkdf2:213}],222:[function(e,t,r){arguments[4][131][0].apply(r,arguments)},{"./asn1/api":223,"./asn1/base":225,"./asn1/constants":229,"./asn1/decoders":231,"./asn1/encoders":234,"bn.js":216,dup:131}],223:[function(e,t,r){arguments[4][132][0].apply(r,arguments)},{"../asn1":222,dup:132,inherits:261,vm:282}],224:[function(e,t,r){arguments[4][133][0].apply(r,arguments)},{"../base":225,buffer:64,dup:133,inherits:261}],225:[function(e,t,r){arguments[4][134][0].apply(r,arguments)},{"./buffer":224,"./node":226,"./reporter":227,dup:134}],226:[function(e,t,r){arguments[4][135][0].apply(r,arguments)},{"../base":225,dup:135,"minimalistic-assert":236}],227:[function(e,t,r){arguments[4][136][0].apply(r,arguments)},{dup:136,inherits:261}],228:[function(e,t,r){arguments[4][137][0].apply(r,arguments)},{"../constants":229,dup:137}],229:[function(e,t,r){arguments[4][138][0].apply(r,arguments)},{"./der":228,dup:138}],230:[function(e,t,r){arguments[4][139][0].apply(r,arguments)},{"../../asn1":222,dup:139,inherits:261}],231:[function(e,t,r){arguments[4][140][0].apply(r,arguments)},{"./der":230,"./pem":232,dup:140}],232:[function(e,t,r){arguments[4][141][0].apply(r,arguments)},{"../../asn1":222,"./der":230,buffer:64,dup:141,inherits:261}],233:[function(e,t,r){arguments[4][142][0].apply(r,arguments)},{"../../asn1":222,buffer:64,dup:142,inherits:261}],234:[function(e,t,r){arguments[4][143][0].apply(r,arguments)},{"./der":233,"./pem":235,dup:143}],235:[function(e,t,r){arguments[4][144][0].apply(r,arguments)},{"../../asn1":222,"./der":233,buffer:64,dup:144,inherits:261}],236:[function(e,t,r){arguments[4][96][0].apply(r,arguments)},{dup:96}],237:[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;te;t=++e)128>t?r.push(t<<1):r.push(t<<1^283);return r}(),i=0,c=0,t=f=0;256>f;t=++f)r=c^c<<1^c<<2^c<<3^c<<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=c=1:(i=s^e[e[e[a^s]]],c^=e[e[c]]);return!0};var c=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=c.SBOX[s>>>24]<<24|c.SBOX[s>>>16&255]<<16|c.SBOX[s>>>8&255]<<8|c.SBOX[255&s],s^=c.RCON[n/t|0]<<24):t>6&&n%t===4?s=c.SBOX[s>>>24]<<24|c.SBOX[s>>>16&255]<<16|c.SBOX[s>>>8&255]<<8|c.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:c.INV_SUB_MIX[0][c.SBOX[s>>>24]]^c.INV_SUB_MIX[1][c.SBOX[s>>>16&255]]^c.INV_SUB_MIX[2][c.SBOX[s>>>8&255]]^c.INV_SUB_MIX[3][c.SBOX[255&s]];return!0},o.prototype.encryptBlock=function(t){t=s(new e(t));var r=this._doCryptBlock(t,this._keySchedule,c.SUB_MIX,c.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,c.INV_SUB_MIX,c.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,c,f,h,u,d,p;o=e[0]^r[0],a=e[1]^r[1],c=e[2]^r[2],f=e[3]^r[3],s=4;for(var l=1;l>>24]^n[1][a>>>16&255]^n[2][c>>>8&255]^n[3][255&f]^r[s++],u=n[0][a>>>24]^n[1][c>>>16&255]^n[2][f>>>8&255]^n[3][255&o]^r[s++],d=n[0][c>>>24]^n[1][f>>>16&255]^n[2][o>>>8&255]^n[3][255&a]^r[s++],p=n[0][f>>>24]^n[1][o>>>16&255]^n[2][a>>>8&255]^n[3][255&c]^r[s++],o=h,a=u,c=d,f=p;return h=(i[o>>>24]<<24|i[a>>>16&255]<<16|i[c>>>8&255]<<8|i[255&f])^r[s++],u=(i[a>>>24]<<24|i[c>>>16&255]<<16|i[f>>>8&255]<<8|i[255&o])^r[s++],d=(i[c>>>24]<<24|i[f>>>16&255]<<16|i[o>>>8&255]<<8|i[255&a])^r[s++],p=(i[f>>>24]<<24|i[o>>>16&255]<<16|i[a>>>8&255]<<8|i[255&c])^r[s++],[t(h),t(u),t(d),t(p)]},r.AES=o}).call(this,e("buffer").Buffer)},{buffer:64}],238:[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 f=new r(4);f.fill(0),this._ghash=new c(this._cipher.encryptBlock(f)),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;++it&&(t=new r(t),t.fill(0),this._ghash.update(t))}this._called=!0;var n=this._mode.encrypt(this,e);return this._decrypt?this._ghash.update(e):this._ghash.update(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=f(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":237,"./ghash":242,buffer:64,"buffer-xor":251,"cipher-base":252,inherits:261}],239:[function(e,t,r){arguments[4][72][0].apply(r,arguments)},{"./decrypter":240,"./encrypter":241,"./modes":243,dup:72}],240:[function(e,t,r){(function(t){function n(e,r,s){return this instanceof n?(f.call(this),this._cache=new i,this._last=void 0,this._cipher=new c.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;++r16)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)},{"./aes":237,"./authCipher":238,"./modes":243,"./modes/cbc":244,"./modes/cfb":245,"./modes/cfb1":246,"./modes/cfb8":247,"./modes/ctr":248,"./modes/ecb":249,"./modes/ofb":250,"./streamCipher":253,buffer:64,"cipher-base":252,evp_bytestokey:254,inherits:261}],241:[function(e,t,r){(function(t){function n(e,r,s){return this instanceof n?(c.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=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(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=h[e.toLowerCase()];if(!r)throw new TypeError("invalid suite type");var n=u(t,!1,r.key,r.iv);return s(e,n.key,n.iv)}var a=e("./aes"),c=e("cipher-base"),f=e("inherits"),h=e("./modes"),u=e("evp_bytestokey"),d=e("./streamCipher"),p=e("./authCipher");f(n,c),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;++nc||0>e?(r=Math.abs(e)%c,0>e?c-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;++t0;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 c=Math.pow(2,32)}).call(this,e("buffer").Buffer)},{buffer:64}],243:[function(e,t,r){arguments[4][76][0].apply(r,arguments)},{dup:76}],244:[function(e,t,r){arguments[4][77][0].apply(r,arguments)},{"buffer-xor":251,dup:77}],245:[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:64,"buffer-xor":251}],246:[function(e,t,r){(function(e){function t(e,t,r){for(var i,s,o,a=-1,c=8,f=0;++a>a%8,e._prev=n(e._prev,r?s:o);return f}function n(t,r){var n=t.length,i=-1,s=new e(t.length);for(t=e.concat([t,new e([r])]);++i>7;return s}r.encrypt=function(r,n,i){for(var s=n.length,o=new e(s),a=-1;++as;++s)i[s]=t[s]^r[s];return i}}).call(this,e("buffer").Buffer)},{buffer:64}],252:[function(e,t,r){(function(r){function n(e){i.call(this),this.hashMode="string"==typeof e,this.hashMode?this[e]=this._finalOrDigest:this["final"]=this._finalOrDigest,this._decoder=null,this._encoding=null}var i=e("stream").Transform,s=e("inherits"),o=e("string_decoder").StringDecoder;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 this.hashMode?this:(n&&(i=this._toString(i,n)),i)},n.prototype.setAutoPadding=function(){},n.prototype.getAuthTag=function(){throw new Error("trying to get auth tag in unsupported state")},n.prototype.setAuthTag=function(){throw new Error("trying to set auth tag in unsupported state")},n.prototype.setAAD=function(){throw new Error("trying to set aad in unsupported state")},n.prototype._transform=function(e,t,r){var n;try{this.hashMode?this._update(e):this.push(this._update(e))}catch(i){n=i}finally{r(n)}},n.prototype._flush=function(e){var t;try{this.push(this._final())}catch(r){t=r}finally{e(t)}},n.prototype._finalOrDigest=function(e){var t=this._final()||new r("");return e&&(t=this._toString(t,e,!0)),t},n.prototype._toString=function(e,t,r){if(this._decoder||(this._decoder=new o(t),this._encoding=t),this._encoding!==t)throw new Error("can't switch encodings");var n=this._decoder.write(e);return r&&(n+=this._decoder.end()),n}}).call(this,e("buffer").Buffer)},{buffer:64,inherits:261,stream:278,string_decoder:279}],253:[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("cipher-base"),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":237,buffer:64,"cipher-base":252,inherits:261}],254:[function(e,t,r){(function(r){function n(e,t,n,s){r.isBuffer(e)||(e=new r(e,"binary")),t&&!r.isBuffer(t)&&(t=new r(t,"binary")),n/=8,s=s||0;for(var o,a,c=0,f=0,h=new r(n),u=new r(s),d=0,p=[];;){if(d++>0&&p.push(o),p.push(e),t&&p.push(t),o=i(r.concat(p)),p=[],a=0,n>0)for(;;){if(0===n)break;if(a===o.length)break;h[c++]=o[a],n--,a++}if(s>0&&a!==o.length)for(;;){if(0===s)break;if(a===o.length)break;u[f++]=o[a],s--,a++}if(0===n&&0===s)break}for(a=0;a=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;++su||new f(t).cmp(c.modulus)>=0)throw new Error("decryption error");var p;p=s?d(new f(t),c):h(t,c);var l=new r(u-p.length);if(l.fill(0),p=r.concat([l,p],u),4===a)return n(c,p);if(1===a)return i(c,p,s);if(3===a)return p;throw new Error("unknown padding")}}).call(this,e("buffer").Buffer)},{"./mgf":215,"./withPublic":257,"./xor":258,"bn.js":216,"browserify-rsa":217,buffer:64,"create-hash":192,"parse-asn1":221}],256:[function(e,t,r){(function(r){function n(e,t){var n=e.modulus.byteLength(),i=t.length,s=c("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),y=h(r.concat([s,p,new r([1]),t],l),f(b,l)),g=h(b,f(y,o));return new u(r.concat([new r([0]),g,y],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 u(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),c=0;e>s;)c===o.length&&(o=a(2*e),c=0),n=o[c++],n&&(i[s++]=n);return i}var o=e("parse-asn1"),a=e("randombytes"),c=e("create-hash"),f=e("./mgf"),h=e("./xor"),u=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,c=o(e);if(4===s)a=n(c,t);else if(1===s)a=i(c,t,r);else{if(3!==s)throw new Error("unknown padding");if(a=new u(t),a.cmp(c.modulus)>=0)throw new Error("data too long for modulus")}return r?p(a,c):d(a,c)}}).call(this,e("buffer").Buffer)},{"./mgf":215,"./withPublic":257,"./xor":258,"bn.js":216,"browserify-rsa":217,buffer:64,"create-hash":192,"parse-asn1":221,randombytes:259}],257:[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":216,buffer:64}],258:[function(e,t,r){t.exports=function(e,t){for(var r=e.length,n=-1;++ne||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,c,f;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:s=Array.prototype.slice.call(arguments,1),r.apply(this,s)}else if(o(r))for(s=Array.prototype.slice.call(arguments,1),f=r.slice(),n=f.length,c=0;n>c;c++)f[c].apply(this,s);return!0},n.prototype.addListener=function(e,t){var r;if(!i(t))throw TypeError("listener must be a function");return 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&&(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())),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 if(r)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.prototype.listenerCount=function(e){if(this._events){var t=this._events[e];if(i(t))return 1;if(t)return t.length}return 0},n.listenerCount=function(e,t){return e.listenerCount(t)}},{}],261:[function(e,t,r){arguments[4][10][0].apply(r,arguments)},{dup:10}],262:[function(e,t,r){t.exports=function(e){return!(null==e||!(e._isBuffer||e.constructor&&"function"==typeof e.constructor.isBuffer&&e.constructor.isBuffer(e)))}},{}],263:[function(e,t,r){t.exports=Array.isArray||function(e){return"[object Array]"==Object.prototype.toString.call(e)}},{}],264:[function(e,t,r){function n(){h=!1,a.length?f=a.concat(f):u=-1,f.length&&i()}function i(){if(!h){var e=setTimeout(n);h=!0;for(var t=f.length;t;){for(a=f,f=[];++u1)for(var r=1;r0)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&&u(e)),p(e,t);else i||(t.reading=!1);return o(t)}function o(e){return!e.ended&&(e.needReadable||e.length=O?e=O:(e--,e|=e>>>1,e|=e>>>2,e|=e>>>4,e|=e>>>8,e|=e>>>16,e++),e}function c(e,t){return 0===t.length&&t.ended?0:t.objectMode?0===e?0:1:null===e||isNaN(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 f(e,t){var r=null;return B.isBuffer(t)||"string"==typeof t||null===t||void 0===t||e.objectMode||(r=new TypeError("Invalid non-string/buffer chunk")),r}function h(e,t){if(!t.ended){if(t.decoder){var r=t.decoder.end();r&&r.length&&(t.buffer.push(r),t.length+=t.objectMode?1:r.length)}t.ended=!0,u(e)}}function u(e){var t=e._readableState;t.needReadable=!1,t.emittedReadable||(R("emitReadable",t.flowing),t.emittedReadable=!0,t.sync?x(d,e):d(e))}function d(e){R("emit readable"),e.emit("readable"),v(e)}function p(e,t){t.readingMore||(t.readingMore=!0,x(l,e,t))}function l(e,t){for(var r=t.length;!t.reading&&!t.flowing&&!t.ended&&t.length=i)r=s?n.join(""):1===n.length?n[0]:B.concat(n,i),n.length=0;else if(ef&&e>c;f++){var a=n[0],u=Math.min(e-c,a.length);s?r+=a.slice(0,u):a.copy(r,c,0,u),u0)throw new Error("endReadable called on non-empty stream"); t.endEmitted||(t.ended=!0,x(S,t,e))}function S(e,t){e.endEmitted||0!==e.length||(e.endEmitted=!0,t.readable=!1,t.emit("end"))}function E(e,t){for(var r=0,n=e.length;n>r;r++)t(e[r],r)}function k(e,t){for(var r=0,n=e.length;n>r;r++)if(e[r]===t)return r;return-1}t.exports=i;var x=e("process-nextick-args"),A=e("isarray"),B=e("buffer").Buffer;i.ReadableState=n;var I,C=(e("events"),function(e,t){return e.listeners(t).length});!function(){try{I=e("stream")}catch(t){}finally{I||(I=e("events").EventEmitter)}}();var B=e("buffer").Buffer,j=e("core-util-is");j.inherits=e("inherits");var R,M=e("util");R=M&&M.debuglog?M.debuglog("stream"):function(){};var P;j.inherits(i,I),i.prototype.push=function(e,t){var r=this._readableState;return r.objectMode||"string"!=typeof e||(t=t||r.defaultEncoding,t!==r.encoding&&(e=new B(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.isPaused=function(){return this._readableState.flowing===!1},i.prototype.setEncoding=function(t){return P||(P=e("string_decoder/").StringDecoder),this._readableState.decoder=new P(t),this._readableState.encoding=t,this};var O=8388608;i.prototype.read=function(e){R("read",e);var t=this._readableState,r=e;if(("number"!=typeof e||e>0)&&(t.emittedReadable=!1),0===e&&t.needReadable&&(t.length>=t.highWaterMark||t.ended))return R("read: emitReadable",t.length,t.ended),0===t.length&&t.ended?w(this):u(this),null;if(e=c(e,t),0===e&&t.ended)return 0===t.length&&w(this),null;var n=t.needReadable;R("need readable",n),(0===t.length||t.length-e0?_(e,t):null,null===i&&(t.needReadable=!0,e=0),t.length-=e,0!==t.length||t.ended||(t.needReadable=!0),r!==e&&t.ended&&0===t.length&&w(this),null!==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){R("onunpipe"),e===u&&s()}function i(){R("onend"),e.end()}function s(){R("cleanup"),e.removeListener("close",c),e.removeListener("finish",f),e.removeListener("drain",y),e.removeListener("error",a),e.removeListener("unpipe",n),u.removeListener("end",i),u.removeListener("end",s),u.removeListener("data",o),g=!0,!d.awaitDrain||e._writableState&&!e._writableState.needDrain||y()}function o(t){R("ondata");var r=e.write(t);!1===r&&(1!==d.pipesCount||d.pipes[0]!==e||1!==u.listenerCount("data")||g||(R("false write response, pause",u._readableState.awaitDrain),u._readableState.awaitDrain++),u.pause())}function a(t){R("onerror",t),h(),e.removeListener("error",a),0===C(e,"error")&&e.emit("error",t)}function c(){e.removeListener("finish",f),h()}function f(){R("onfinish"),e.removeListener("close",c),h()}function h(){R("unpipe"),u.unpipe(e)}var u=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,R("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?x(l):u.once("end",l),e.on("unpipe",n);var y=b(u);e.on("drain",y);var g=!1;return u.on("data",o),e._events&&e._events.error?A(e._events.error)?e._events.error.unshift(a):e._events.error=[a,e._events.error]:e.on("error",a),e.once("close",c),e.once("finish",f),e.emit("pipe",u),d.flowing||(R("pipe resume"),u.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=k(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 r=I.prototype.on.call(this,e,t);if("data"===e&&!1!==this._readableState.flowing&&this.resume(),"readable"===e&&this.readable){var n=this._readableState;n.readableListening||(n.readableListening=!0,n.emittedReadable=!1,n.needReadable=!0,n.reading?n.length&&u(this,n):x(y,this))}return r},i.prototype.addListener=i.prototype.on,i.prototype.resume=function(){var e=this._readableState;return e.flowing||(R("resume"),e.flowing=!0,g(this,e)),this},i.prototype.pause=function(){return R("call pause flowing=%j",this._readableState.flowing),!1!==this._readableState.flowing&&(R("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(R("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(R("wrapped data"),t.decoder&&(i=t.decoder.write(i)),(!t.objectMode||null!==i&&void 0!==i)&&(t.objectMode||i&&i.length)){var s=n.push(i);s||(r=!0,e.pause())}});for(var i in e)void 0===this[i]&&"function"==typeof e[i]&&(this[i]=function(t){return function(){return e[t].apply(e,arguments)}}(i));var s=["error","close","destroy","pause","resume"];return E(s,function(t){e.on(t,n.emit.bind(n,t))}),n._read=function(t){R("wrapped _read",t),r&&(r=!1,e.resume())},n},i._fromList=_}).call(this,e("_process"))},{"./_stream_duplex":266,_process:264,buffer:64,"core-util-is":271,events:260,inherits:261,isarray:263,"process-nextick-args":272,"string_decoder/":279,util:63}],269:[function(e,t,r){"use strict";function n(e){this.afterTransform=function(t,r){return i(e,t,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,null!==r&&void 0!==r&&e.push(r),i&&i(t);var s=e._readableState;s.reading=!1,(s.needReadable||s.length-1))throw new TypeError("Unknown encoding: "+e);this._writableState.defaultEncoding=e},o.prototype._write=function(e,t,r){r(new Error("not implemented"))},o.prototype._writev=null,o.prototype.end=function(e,t,r){var n=this._writableState;"function"==typeof e?(r=e,e=null,t=null):"function"==typeof t&&(r=t,t=null),null!==e&&void 0!==e&&this.write(e,t),n.corked&&(n.corked=1,this.uncork()),n.ending||n.finished||w(this,n,r)}},{"./_stream_duplex":266,buffer:64,"core-util-is":271,events:260,inherits:261,"process-nextick-args":272,"util-deprecate":273}],271:[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 c(e){return"symbol"==typeof e}function f(e){return void 0===e}function h(e){return u(e)&&"[object RegExp]"===g(e)}function u(e){return"object"==typeof e&&null!==e}function d(e){return u(e)&&"[object Date]"===g(e)}function p(e){return u(e)&&("[object Error]"===g(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 y(t){return e.isBuffer(t)}function g(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=c,r.isUndefined=f,r.isRegExp=h,r.isObject=u,r.isDate=d,r.isError=p,r.isFunction=l,r.isPrimitive=b,r.isBuffer=y}).call(this,{isBuffer:e("../../../../insert-module-globals/node_modules/is-buffer/index.js")})},{"../../../../insert-module-globals/node_modules/is-buffer/index.js":262}],272:[function(e,t,r){(function(e){"use strict";function r(t){for(var r=new Array(arguments.length-1),n=0;n=this.charLength-this.charReceived?this.charLength-this.charReceived:e.length;if(e.copy(this.charBuffer,this.charReceived,0,r),this.charReceived+=r,this.charReceived=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},f.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},f.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:64}],280:[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}},{}],281:[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),c(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 c(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=c(e,i,n)),i}var s=f(e,t);if(s)return s;var o=Object.keys(t),b=a(o);if(e.showHidden&&(o=Object.getOwnPropertyNames(t)),x(t)&&(o.indexOf("message")>=0||o.indexOf("description")>=0))return h(t);if(0===o.length){if(A(t)){var y=t.name?": "+t.name:"";return e.stylize("[Function"+y+"]","special")}if(S(t))return e.stylize(RegExp.prototype.toString.call(t),"regexp");if(k(t))return e.stylize(Date.prototype.toString.call(t),"date");if(x(t))return h(t)}var g="",m=!1,_=["{","}"];if(l(t)&&(m=!0,_=["[","]"]),A(t)){var w=t.name?": "+t.name:"";g=" [Function"+w+"]"}if(S(t)&&(g=" "+RegExp.prototype.toString.call(t)),k(t)&&(g=" "+Date.prototype.toUTCString.call(t)),x(t)&&(g=" "+h(t)),0===o.length&&(!m||0==t.length))return _[0]+g+_[1];if(0>n)return S(t)?e.stylize(RegExp.prototype.toString.call(t),"regexp"):e.stylize("[Object]","special");e.seen.push(t);var E;return E=m?u(e,t,n,b,o):o.map(function(r){return d(e,t,n,b,r,m)}),e.seen.pop(),p(E,g,_)}function f(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 m(t)?e.stylize(""+t,"number"):b(t)?e.stylize(""+t,"boolean"):y(t)?e.stylize("null","null"):void 0}function h(e){return"["+Error.prototype.toString.call(e)+"]"}function u(e,t,r,n,i){for(var s=[],o=0,a=t.length;a>o;++o)R(t,String(o))?s.push(d(e,t,r,n,String(o),!0)):s.push("");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,f;if(f=Object.getOwnPropertyDescriptor(t,i)||{value:t[i]},f.get?a=f.set?e.stylize("[Getter/Setter]","special"):e.stylize("[Getter]","special"):f.set&&(a=e.stylize("[Setter]","special")),R(n,i)||(o="["+i+"]"),a||(e.seen.indexOf(f.value)<0?(a=y(r)?c(e,f.value,null):c(e,f.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 y(e){return null===e}function g(e){return null==e}function m(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 E(e)&&"[object RegExp]"===I(e)}function E(e){return"object"==typeof e&&null!==e}function k(e){return E(e)&&"[object Date]"===I(e)}function x(e){return E(e)&&("[object Error]"===I(e)||e instanceof Error)}function A(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 I(e){return Object.prototype.toString.call(e)}function C(e){return 10>e?"0"+e.toString(10):e.toString(10)}function j(){var e=new Date,t=[C(e.getHours()),C(e.getMinutes()),C(e.getSeconds())].join(":");return[e.getDate(),T[e.getMonth()],t].join(" ")}function R(e,t){return Object.prototype.hasOwnProperty.call(e,t)}var M=/%[sdj%]/g;r.format=function(e){if(!v(e)){for(var t=[],r=0;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+=y(a)||!E(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 P,O={};r.debuglog=function(e){if(w(P)&&(P=t.env.NODE_DEBUG||""),e=e.toUpperCase(),!O[e])if(new RegExp("\\b"+e+"\\b","i").test(P)){var n=t.pid;O[e]=function(){var t=r.format.apply(r,arguments);console.error("%s %d: %s",e,n,t)}}else O[e]=function(){};return O[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=y,r.isNullOrUndefined=g,r.isNumber=m,r.isString=v,r.isSymbol=_,r.isUndefined=w,r.isRegExp=S,r.isObject=E,r.isDate=k,r.isError=x,r.isFunction=A,r.isPrimitive=B,r.isBuffer=e("./support/isBuffer");var T=["Jan","Feb","Mar","Apr","May","Jun","Jul","Aug","Sep","Oct","Nov","Dec"];r.log=function(){console.log("%s - %s",j(),r.format.apply(r,arguments))},r.inherits=e("inherits"),r._extend=function(e,t){if(!t||!E(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":280,_process:264,inherits:261}],282:[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