28 lines
88 KiB
JavaScript
28 lines
88 KiB
JavaScript
var Ye="0123456789abcdefghijklmnopqrstuvwxyz";function B(n){return Ye.charAt(n)}function Je(n,t){return n&t}function it(n,t){return n|t}function Gt(n,t){return n^t}function zt(n,t){return n&~t}function Xe(n){if(n==0)return-1;var t=0;return n&65535||(n>>=16,t+=16),n&255||(n>>=8,t+=8),n&15||(n>>=4,t+=4),n&3||(n>>=2,t+=2),n&1||++t,t}function Qe(n){for(var t=0;n!=0;)n&=n-1,++t;return t}var J="ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/",Le="=";function dt(n){var t,e,r="";for(t=0;t+3<=n.length;t+=3)e=parseInt(n.substring(t,t+3),16),r+=J.charAt(e>>6)+J.charAt(e&63);for(t+1==n.length?(e=parseInt(n.substring(t,t+1),16),r+=J.charAt(e<<2)):t+2==n.length&&(e=parseInt(n.substring(t,t+2),16),r+=J.charAt(e>>2)+J.charAt((e&3)<<4));(r.length&3)>0;)r+=Le;return r}function Zt(n){var t="",e,r=0,s=0;for(e=0;e<n.length&&n.charAt(e)!=Le;++e){var i=J.indexOf(n.charAt(e));i<0||(r==0?(t+=B(i>>2),s=i&3,r=1):r==1?(t+=B(s<<2|i>>4),s=i&15,r=2):r==2?(t+=B(s),t+=B(i>>2),s=i&3,r=3):(t+=B(s<<2|i>>4),t+=B(i&15),r=0))}return r==1&&(t+=B(s<<2)),t}var G,We={decode:function(n){var t;if(G===void 0){var e="0123456789ABCDEF",r=` \f
|
||
\r \u2028\u2029`;for(G={},t=0;t<16;++t)G[e.charAt(t)]=t;for(e=e.toLowerCase(),t=10;t<16;++t)G[e.charAt(t)]=t;for(t=0;t<r.length;++t)G[r.charAt(t)]=-1}var s=[],i=0,o=0;for(t=0;t<n.length;++t){var a=n.charAt(t);if(a=="=")break;if(a=G[a],a!=-1){if(a===void 0)throw new Error("Illegal character at offset "+t);i|=a,++o>=2?(s[s.length]=i,i=0,o=0):i<<=4}}if(o)throw new Error("Hex encoding incomplete: 4 bits missing");return s}},H,jt={decode:function(n){var t;if(H===void 0){var e="ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/",r=`= \f
|
||
\r \u2028\u2029`;for(H=Object.create(null),t=0;t<64;++t)H[e.charAt(t)]=t;for(H["-"]=62,H._=63,t=0;t<r.length;++t)H[r.charAt(t)]=-1}var s=[],i=0,o=0;for(t=0;t<n.length;++t){var a=n.charAt(t);if(a=="=")break;if(a=H[a],a!=-1){if(a===void 0)throw new Error("Illegal character at offset "+t);i|=a,++o>=4?(s[s.length]=i>>16,s[s.length]=i>>8&255,s[s.length]=i&255,i=0,o=0):i<<=6}}switch(o){case 1:throw new Error("Base64 encoding incomplete: at least 2 bits missing");case 2:s[s.length]=i>>10;break;case 3:s[s.length]=i>>16,s[s.length]=i>>8&255;break}return s},re:/-----BEGIN [^-]+-----([A-Za-z0-9+\/=\s]+)-----END [^-]+-----|begin-base64[^\n]+\n([A-Za-z0-9+\/=\s]+)====/,unarmor:function(n){var t=jt.re.exec(n);if(t)if(t[1])n=t[1];else if(t[2])n=t[2];else throw new Error("RegExp out of sync");return jt.decode(n)}},z=1e13,nt=function(){function n(t){this.buf=[+t||0]}return n.prototype.mulAdd=function(t,e){var r=this.buf,s=r.length,i,o;for(i=0;i<s;++i)o=r[i]*t+e,o<z?e=0:(e=0|o/z,o-=e*z),r[i]=o;e>0&&(r[i]=e)},n.prototype.sub=function(t){var e=this.buf,r=e.length,s,i;for(s=0;s<r;++s)i=e[s]-t,i<0?(i+=z,t=1):t=0,e[s]=i;for(;e[e.length-1]===0;)e.pop()},n.prototype.toString=function(t){if((t||10)!=10)throw new Error("only base 10 is supported");for(var e=this.buf,r=e[e.length-1].toString(),s=e.length-2;s>=0;--s)r+=(z+e[s]).toString().substring(1);return r},n.prototype.valueOf=function(){for(var t=this.buf,e=0,r=t.length-1;r>=0;--r)e=e*z+t[r];return e},n.prototype.simplify=function(){var t=this.buf;return t.length==1?t[0]:this},n}(),Ne="…",tn=/^(\d\d)(0[1-9]|1[0-2])(0[1-9]|[12]\d|3[01])([01]\d|2[0-3])(?:([0-5]\d)(?:([0-5]\d)(?:[.,](\d{1,3}))?)?)?(Z|[-+](?:[0]\d|1[0-2])([0-5]\d)?)?$/,en=/^(\d\d\d\d)(0[1-9]|1[0-2])(0[1-9]|[12]\d|3[01])([01]\d|2[0-3])(?:([0-5]\d)(?:([0-5]\d)(?:[.,](\d{1,3}))?)?)?(Z|[-+](?:[0]\d|1[0-2])([0-5]\d)?)?$/;function X(n,t){return n.length>t&&(n=n.substring(0,t)+Ne),n}var Tt=function(){function n(t,e){this.hexDigits="0123456789ABCDEF",t instanceof n?(this.enc=t.enc,this.pos=t.pos):(this.enc=t,this.pos=e)}return n.prototype.get=function(t){if(t===void 0&&(t=this.pos++),t>=this.enc.length)throw new Error("Requesting byte offset ".concat(t," on a stream of length ").concat(this.enc.length));return typeof this.enc=="string"?this.enc.charCodeAt(t):this.enc[t]},n.prototype.hexByte=function(t){return this.hexDigits.charAt(t>>4&15)+this.hexDigits.charAt(t&15)},n.prototype.hexDump=function(t,e,r){for(var s="",i=t;i<e;++i)if(s+=this.hexByte(this.get(i)),r!==!0)switch(i&15){case 7:s+=" ";break;case 15:s+=`
|
||
`;break;default:s+=" "}return s},n.prototype.isASCII=function(t,e){for(var r=t;r<e;++r){var s=this.get(r);if(s<32||s>176)return!1}return!0},n.prototype.parseStringISO=function(t,e){for(var r="",s=t;s<e;++s)r+=String.fromCharCode(this.get(s));return r},n.prototype.parseStringUTF=function(t,e){for(var r="",s=t;s<e;){var i=this.get(s++);i<128?r+=String.fromCharCode(i):i>191&&i<224?r+=String.fromCharCode((i&31)<<6|this.get(s++)&63):r+=String.fromCharCode((i&15)<<12|(this.get(s++)&63)<<6|this.get(s++)&63)}return r},n.prototype.parseStringBMP=function(t,e){for(var r="",s,i,o=t;o<e;)s=this.get(o++),i=this.get(o++),r+=String.fromCharCode(s<<8|i);return r},n.prototype.parseTime=function(t,e,r){var s=this.parseStringISO(t,e),i=(r?tn:en).exec(s);return i?(r&&(i[1]=+i[1],i[1]+=+i[1]<70?2e3:1900),s=i[1]+"-"+i[2]+"-"+i[3]+" "+i[4],i[5]&&(s+=":"+i[5],i[6]&&(s+=":"+i[6],i[7]&&(s+="."+i[7]))),i[8]&&(s+=" UTC",i[8]!="Z"&&(s+=i[8],i[9]&&(s+=":"+i[9]))),s):"Unrecognized time: "+s},n.prototype.parseInteger=function(t,e){for(var r=this.get(t),s=r>127,i=s?255:0,o,a="";r==i&&++t<e;)r=this.get(t);if(o=e-t,o===0)return s?-1:0;if(o>4){for(a=r,o<<=3;!((+a^i)&128);)a=+a<<1,--o;a="("+o+` bit)
|
||
`}s&&(r=r-256);for(var u=new nt(r),c=t+1;c<e;++c)u.mulAdd(256,this.get(c));return a+u.toString()},n.prototype.parseBitString=function(t,e,r){for(var s=this.get(t),i=(e-t-1<<3)-s,o="("+i+` bit)
|
||
`,a="",u=t+1;u<e;++u){for(var c=this.get(u),h=u==e-1?s:0,d=7;d>=h;--d)a+=c>>d&1?"1":"0";if(a.length>r)return o+X(a,r)}return o+a},n.prototype.parseOctetString=function(t,e,r){if(this.isASCII(t,e))return X(this.parseStringISO(t,e),r);var s=e-t,i="("+s+` byte)
|
||
`;r/=2,s>r&&(e=t+r);for(var o=t;o<e;++o)i+=this.hexByte(this.get(o));return s>r&&(i+=Ne),i},n.prototype.parseOID=function(t,e,r){for(var s="",i=new nt,o=0,a=t;a<e;++a){var u=this.get(a);if(i.mulAdd(128,u&127),o+=7,!(u&128)){if(s==="")if(i=i.simplify(),i instanceof nt)i.sub(80),s="2."+i.toString();else{var c=i<80?i<40?0:1:2;s=c+"."+(i-c*40)}else s+="."+i.toString();if(s.length>r)return X(s,r);i=new nt,o=0}}return o>0&&(s+=".incomplete"),s},n}(),nn=function(){function n(t,e,r,s,i){if(!(s instanceof Yt))throw new Error("Invalid tag value.");this.stream=t,this.header=e,this.length=r,this.tag=s,this.sub=i}return n.prototype.typeName=function(){switch(this.tag.tagClass){case 0:switch(this.tag.tagNumber){case 0:return"EOC";case 1:return"BOOLEAN";case 2:return"INTEGER";case 3:return"BIT_STRING";case 4:return"OCTET_STRING";case 5:return"NULL";case 6:return"OBJECT_IDENTIFIER";case 7:return"ObjectDescriptor";case 8:return"EXTERNAL";case 9:return"REAL";case 10:return"ENUMERATED";case 11:return"EMBEDDED_PDV";case 12:return"UTF8String";case 16:return"SEQUENCE";case 17:return"SET";case 18:return"NumericString";case 19:return"PrintableString";case 20:return"TeletexString";case 21:return"VideotexString";case 22:return"IA5String";case 23:return"UTCTime";case 24:return"GeneralizedTime";case 25:return"GraphicString";case 26:return"VisibleString";case 27:return"GeneralString";case 28:return"UniversalString";case 30:return"BMPString"}return"Universal_"+this.tag.tagNumber.toString();case 1:return"Application_"+this.tag.tagNumber.toString();case 2:return"["+this.tag.tagNumber.toString()+"]";case 3:return"Private_"+this.tag.tagNumber.toString()}},n.prototype.content=function(t){if(this.tag===void 0)return null;t===void 0&&(t=1/0);var e=this.posContent(),r=Math.abs(this.length);if(!this.tag.isUniversal())return this.sub!==null?"("+this.sub.length+" elem)":this.stream.parseOctetString(e,e+r,t);switch(this.tag.tagNumber){case 1:return this.stream.get(e)===0?"false":"true";case 2:return this.stream.parseInteger(e,e+r);case 3:return this.sub?"("+this.sub.length+" elem)":this.stream.parseBitString(e,e+r,t);case 4:return this.sub?"("+this.sub.length+" elem)":this.stream.parseOctetString(e,e+r,t);case 6:return this.stream.parseOID(e,e+r,t);case 16:case 17:return this.sub!==null?"("+this.sub.length+" elem)":"(no elem)";case 12:return X(this.stream.parseStringUTF(e,e+r),t);case 18:case 19:case 20:case 21:case 22:case 26:return X(this.stream.parseStringISO(e,e+r),t);case 30:return X(this.stream.parseStringBMP(e,e+r),t);case 23:case 24:return this.stream.parseTime(e,e+r,this.tag.tagNumber==23)}return null},n.prototype.toString=function(){return this.typeName()+"@"+this.stream.pos+"[header:"+this.header+",length:"+this.length+",sub:"+(this.sub===null?"null":this.sub.length)+"]"},n.prototype.toPrettyString=function(t){t===void 0&&(t="");var e=t+this.typeName()+" @"+this.stream.pos;if(this.length>=0&&(e+="+"),e+=this.length,this.tag.tagConstructed?e+=" (constructed)":this.tag.isUniversal()&&(this.tag.tagNumber==3||this.tag.tagNumber==4)&&this.sub!==null&&(e+=" (encapsulates)"),e+=`
|
||
`,this.sub!==null){t+=" ";for(var r=0,s=this.sub.length;r<s;++r)e+=this.sub[r].toPrettyString(t)}return e},n.prototype.posStart=function(){return this.stream.pos},n.prototype.posContent=function(){return this.stream.pos+this.header},n.prototype.posEnd=function(){return this.stream.pos+this.header+Math.abs(this.length)},n.prototype.toHexString=function(){return this.stream.hexDump(this.posStart(),this.posEnd(),!0)},n.decodeLength=function(t){var e=t.get(),r=e&127;if(r==e)return r;if(r>6)throw new Error("Length over 48 bits not supported at position "+(t.pos-1));if(r===0)return null;e=0;for(var s=0;s<r;++s)e=e*256+t.get();return e},n.prototype.getHexStringValue=function(){var t=this.toHexString(),e=this.header*2,r=this.length*2;return t.substr(e,r)},n.decode=function(t){var e;t instanceof Tt?e=t:e=new Tt(t,0);var r=new Tt(e),s=new Yt(e),i=n.decodeLength(e),o=e.pos,a=o-r.pos,u=null,c=function(){var d=[];if(i!==null){for(var l=o+i;e.pos<l;)d[d.length]=n.decode(e);if(e.pos!=l)throw new Error("Content size is not correct for container starting at offset "+o)}else try{for(;;){var g=n.decode(e);if(g.tag.isEOC())break;d[d.length]=g}i=o-e.pos}catch(_){throw new Error("Exception while decoding undefined length content: "+_)}return d};if(s.tagConstructed)u=c();else if(s.isUniversal()&&(s.tagNumber==3||s.tagNumber==4))try{if(s.tagNumber==3&&e.get()!=0)throw new Error("BIT STRINGs with unused bits cannot encapsulate.");u=c();for(var h=0;h<u.length;++h)if(u[h].tag.isEOC())throw new Error("EOC is not supposed to be actual content.")}catch{u=null}if(u===null){if(i===null)throw new Error("We can't skip over an invalid tag with undefined length at offset "+o);e.pos=o+Math.abs(i)}return new n(r,a,i,s,u)},n}(),Yt=function(){function n(t){var e=t.get();if(this.tagClass=e>>6,this.tagConstructed=(e&32)!==0,this.tagNumber=e&31,this.tagNumber==31){var r=new nt;do e=t.get(),r.mulAdd(128,e&127);while(e&128);this.tagNumber=r.simplify()}}return n.prototype.isUniversal=function(){return this.tagClass===0},n.prototype.isEOC=function(){return this.tagClass===0&&this.tagNumber===0},n}(),q,rn=0xdeadbeefcafe,Jt=(rn&16777215)==15715070,P=[2,3,5,7,11,13,17,19,23,29,31,37,41,43,47,53,59,61,67,71,73,79,83,89,97,101,103,107,109,113,127,131,137,139,149,151,157,163,167,173,179,181,191,193,197,199,211,223,227,229,233,239,241,251,257,263,269,271,277,281,283,293,307,311,313,317,331,337,347,349,353,359,367,373,379,383,389,397,401,409,419,421,431,433,439,443,449,457,461,463,467,479,487,491,499,503,509,521,523,541,547,557,563,569,571,577,587,593,599,601,607,613,617,619,631,641,643,647,653,659,661,673,677,683,691,701,709,719,727,733,739,743,751,757,761,769,773,787,797,809,811,821,823,827,829,839,853,857,859,863,877,881,883,887,907,911,919,929,937,941,947,953,967,971,977,983,991,997],sn=(1<<26)/P[P.length-1],m=function(){function n(t,e,r){t!=null&&(typeof t=="number"?this.fromNumber(t,e,r):e==null&&typeof t!="string"?this.fromString(t,256):this.fromString(t,e))}return n.prototype.toString=function(t){if(this.s<0)return"-"+this.negate().toString(t);var e;if(t==16)e=4;else if(t==8)e=3;else if(t==2)e=1;else if(t==32)e=5;else if(t==4)e=2;else return this.toRadix(t);var r=(1<<e)-1,s,i=!1,o="",a=this.t,u=this.DB-a*this.DB%e;if(a-- >0)for(u<this.DB&&(s=this[a]>>u)>0&&(i=!0,o=B(s));a>=0;)u<e?(s=(this[a]&(1<<u)-1)<<e-u,s|=this[--a]>>(u+=this.DB-e)):(s=this[a]>>(u-=e)&r,u<=0&&(u+=this.DB,--a)),s>0&&(i=!0),i&&(o+=B(s));return i?o:"0"},n.prototype.negate=function(){var t=v();return n.ZERO.subTo(this,t),t},n.prototype.abs=function(){return this.s<0?this.negate():this},n.prototype.compareTo=function(t){var e=this.s-t.s;if(e!=0)return e;var r=this.t;if(e=r-t.t,e!=0)return this.s<0?-e:e;for(;--r>=0;)if((e=this[r]-t[r])!=0)return e;return 0},n.prototype.bitLength=function(){return this.t<=0?0:this.DB*(this.t-1)+ot(this[this.t-1]^this.s&this.DM)},n.prototype.mod=function(t){var e=v();return this.abs().divRemTo(t,null,e),this.s<0&&e.compareTo(n.ZERO)>0&&t.subTo(e,e),e},n.prototype.modPowInt=function(t,e){var r;return t<256||e.isEven()?r=new Xt(e):r=new Qt(e),this.exp(t,r)},n.prototype.clone=function(){var t=v();return this.copyTo(t),t},n.prototype.intValue=function(){if(this.s<0){if(this.t==1)return this[0]-this.DV;if(this.t==0)return-1}else{if(this.t==1)return this[0];if(this.t==0)return 0}return(this[1]&(1<<32-this.DB)-1)<<this.DB|this[0]},n.prototype.byteValue=function(){return this.t==0?this.s:this[0]<<24>>24},n.prototype.shortValue=function(){return this.t==0?this.s:this[0]<<16>>16},n.prototype.signum=function(){return this.s<0?-1:this.t<=0||this.t==1&&this[0]<=0?0:1},n.prototype.toByteArray=function(){var t=this.t,e=[];e[0]=this.s;var r=this.DB-t*this.DB%8,s,i=0;if(t-- >0)for(r<this.DB&&(s=this[t]>>r)!=(this.s&this.DM)>>r&&(e[i++]=s|this.s<<this.DB-r);t>=0;)r<8?(s=(this[t]&(1<<r)-1)<<8-r,s|=this[--t]>>(r+=this.DB-8)):(s=this[t]>>(r-=8)&255,r<=0&&(r+=this.DB,--t)),s&128&&(s|=-256),i==0&&(this.s&128)!=(s&128)&&++i,(i>0||s!=this.s)&&(e[i++]=s);return e},n.prototype.equals=function(t){return this.compareTo(t)==0},n.prototype.min=function(t){return this.compareTo(t)<0?this:t},n.prototype.max=function(t){return this.compareTo(t)>0?this:t},n.prototype.and=function(t){var e=v();return this.bitwiseTo(t,Je,e),e},n.prototype.or=function(t){var e=v();return this.bitwiseTo(t,it,e),e},n.prototype.xor=function(t){var e=v();return this.bitwiseTo(t,Gt,e),e},n.prototype.andNot=function(t){var e=v();return this.bitwiseTo(t,zt,e),e},n.prototype.not=function(){for(var t=v(),e=0;e<this.t;++e)t[e]=this.DM&~this[e];return t.t=this.t,t.s=~this.s,t},n.prototype.shiftLeft=function(t){var e=v();return t<0?this.rShiftTo(-t,e):this.lShiftTo(t,e),e},n.prototype.shiftRight=function(t){var e=v();return t<0?this.lShiftTo(-t,e):this.rShiftTo(t,e),e},n.prototype.getLowestSetBit=function(){for(var t=0;t<this.t;++t)if(this[t]!=0)return t*this.DB+Xe(this[t]);return this.s<0?this.t*this.DB:-1},n.prototype.bitCount=function(){for(var t=0,e=this.s&this.DM,r=0;r<this.t;++r)t+=Qe(this[r]^e);return t},n.prototype.testBit=function(t){var e=Math.floor(t/this.DB);return e>=this.t?this.s!=0:(this[e]&1<<t%this.DB)!=0},n.prototype.setBit=function(t){return this.changeBit(t,it)},n.prototype.clearBit=function(t){return this.changeBit(t,zt)},n.prototype.flipBit=function(t){return this.changeBit(t,Gt)},n.prototype.add=function(t){var e=v();return this.addTo(t,e),e},n.prototype.subtract=function(t){var e=v();return this.subTo(t,e),e},n.prototype.multiply=function(t){var e=v();return this.multiplyTo(t,e),e},n.prototype.divide=function(t){var e=v();return this.divRemTo(t,e,null),e},n.prototype.remainder=function(t){var e=v();return this.divRemTo(t,null,e),e},n.prototype.divideAndRemainder=function(t){var e=v(),r=v();return this.divRemTo(t,e,r),[e,r]},n.prototype.modPow=function(t,e){var r=t.bitLength(),s,i=k(1),o;if(r<=0)return i;r<18?s=1:r<48?s=3:r<144?s=4:r<768?s=5:s=6,r<8?o=new Xt(e):e.isEven()?o=new an(e):o=new Qt(e);var a=[],u=3,c=s-1,h=(1<<s)-1;if(a[1]=o.convert(this),s>1){var d=v();for(o.sqrTo(a[1],d);u<=h;)a[u]=v(),o.mulTo(d,a[u-2],a[u]),u+=2}var l=t.t-1,g,_=!0,S=v(),E;for(r=ot(t[l])-1;l>=0;){for(r>=c?g=t[l]>>r-c&h:(g=(t[l]&(1<<r+1)-1)<<c-r,l>0&&(g|=t[l-1]>>this.DB+r-c)),u=s;!(g&1);)g>>=1,--u;if((r-=u)<0&&(r+=this.DB,--l),_)a[g].copyTo(i),_=!1;else{for(;u>1;)o.sqrTo(i,S),o.sqrTo(S,i),u-=2;u>0?o.sqrTo(i,S):(E=i,i=S,S=E),o.mulTo(S,a[g],i)}for(;l>=0&&!(t[l]&1<<r);)o.sqrTo(i,S),E=i,i=S,S=E,--r<0&&(r=this.DB-1,--l)}return o.revert(i)},n.prototype.modInverse=function(t){var e=t.isEven();if(this.isEven()&&e||t.signum()==0)return n.ZERO;for(var r=t.clone(),s=this.clone(),i=k(1),o=k(0),a=k(0),u=k(1);r.signum()!=0;){for(;r.isEven();)r.rShiftTo(1,r),e?((!i.isEven()||!o.isEven())&&(i.addTo(this,i),o.subTo(t,o)),i.rShiftTo(1,i)):o.isEven()||o.subTo(t,o),o.rShiftTo(1,o);for(;s.isEven();)s.rShiftTo(1,s),e?((!a.isEven()||!u.isEven())&&(a.addTo(this,a),u.subTo(t,u)),a.rShiftTo(1,a)):u.isEven()||u.subTo(t,u),u.rShiftTo(1,u);r.compareTo(s)>=0?(r.subTo(s,r),e&&i.subTo(a,i),o.subTo(u,o)):(s.subTo(r,s),e&&a.subTo(i,a),u.subTo(o,u))}if(s.compareTo(n.ONE)!=0)return n.ZERO;if(u.compareTo(t)>=0)return u.subtract(t);if(u.signum()<0)u.addTo(t,u);else return u;return u.signum()<0?u.add(t):u},n.prototype.pow=function(t){return this.exp(t,new on)},n.prototype.gcd=function(t){var e=this.s<0?this.negate():this.clone(),r=t.s<0?t.negate():t.clone();if(e.compareTo(r)<0){var s=e;e=r,r=s}var i=e.getLowestSetBit(),o=r.getLowestSetBit();if(o<0)return e;for(i<o&&(o=i),o>0&&(e.rShiftTo(o,e),r.rShiftTo(o,r));e.signum()>0;)(i=e.getLowestSetBit())>0&&e.rShiftTo(i,e),(i=r.getLowestSetBit())>0&&r.rShiftTo(i,r),e.compareTo(r)>=0?(e.subTo(r,e),e.rShiftTo(1,e)):(r.subTo(e,r),r.rShiftTo(1,r));return o>0&&r.lShiftTo(o,r),r},n.prototype.isProbablePrime=function(t){var e,r=this.abs();if(r.t==1&&r[0]<=P[P.length-1]){for(e=0;e<P.length;++e)if(r[0]==P[e])return!0;return!1}if(r.isEven())return!1;for(e=1;e<P.length;){for(var s=P[e],i=e+1;i<P.length&&s<sn;)s*=P[i++];for(s=r.modInt(s);e<i;)if(s%P[e++]==0)return!1}return r.millerRabin(t)},n.prototype.copyTo=function(t){for(var e=this.t-1;e>=0;--e)t[e]=this[e];t.t=this.t,t.s=this.s},n.prototype.fromInt=function(t){this.t=1,this.s=t<0?-1:0,t>0?this[0]=t:t<-1?this[0]=t+this.DV:this.t=0},n.prototype.fromString=function(t,e){var r;if(e==16)r=4;else if(e==8)r=3;else if(e==256)r=8;else if(e==2)r=1;else if(e==32)r=5;else if(e==4)r=2;else{this.fromRadix(t,e);return}this.t=0,this.s=0;for(var s=t.length,i=!1,o=0;--s>=0;){var a=r==8?+t[s]&255:te(t,s);if(a<0){t.charAt(s)=="-"&&(i=!0);continue}i=!1,o==0?this[this.t++]=a:o+r>this.DB?(this[this.t-1]|=(a&(1<<this.DB-o)-1)<<o,this[this.t++]=a>>this.DB-o):this[this.t-1]|=a<<o,o+=r,o>=this.DB&&(o-=this.DB)}r==8&&+t[0]&128&&(this.s=-1,o>0&&(this[this.t-1]|=(1<<this.DB-o)-1<<o)),this.clamp(),i&&n.ZERO.subTo(this,this)},n.prototype.clamp=function(){for(var t=this.s&this.DM;this.t>0&&this[this.t-1]==t;)--this.t},n.prototype.dlShiftTo=function(t,e){var r;for(r=this.t-1;r>=0;--r)e[r+t]=this[r];for(r=t-1;r>=0;--r)e[r]=0;e.t=this.t+t,e.s=this.s},n.prototype.drShiftTo=function(t,e){for(var r=t;r<this.t;++r)e[r-t]=this[r];e.t=Math.max(this.t-t,0),e.s=this.s},n.prototype.lShiftTo=function(t,e){for(var r=t%this.DB,s=this.DB-r,i=(1<<s)-1,o=Math.floor(t/this.DB),a=this.s<<r&this.DM,u=this.t-1;u>=0;--u)e[u+o+1]=this[u]>>s|a,a=(this[u]&i)<<r;for(var u=o-1;u>=0;--u)e[u]=0;e[o]=a,e.t=this.t+o+1,e.s=this.s,e.clamp()},n.prototype.rShiftTo=function(t,e){e.s=this.s;var r=Math.floor(t/this.DB);if(r>=this.t){e.t=0;return}var s=t%this.DB,i=this.DB-s,o=(1<<s)-1;e[0]=this[r]>>s;for(var a=r+1;a<this.t;++a)e[a-r-1]|=(this[a]&o)<<i,e[a-r]=this[a]>>s;s>0&&(e[this.t-r-1]|=(this.s&o)<<i),e.t=this.t-r,e.clamp()},n.prototype.subTo=function(t,e){for(var r=0,s=0,i=Math.min(t.t,this.t);r<i;)s+=this[r]-t[r],e[r++]=s&this.DM,s>>=this.DB;if(t.t<this.t){for(s-=t.s;r<this.t;)s+=this[r],e[r++]=s&this.DM,s>>=this.DB;s+=this.s}else{for(s+=this.s;r<t.t;)s-=t[r],e[r++]=s&this.DM,s>>=this.DB;s-=t.s}e.s=s<0?-1:0,s<-1?e[r++]=this.DV+s:s>0&&(e[r++]=s),e.t=r,e.clamp()},n.prototype.multiplyTo=function(t,e){var r=this.abs(),s=t.abs(),i=r.t;for(e.t=i+s.t;--i>=0;)e[i]=0;for(i=0;i<s.t;++i)e[i+r.t]=r.am(0,s[i],e,i,0,r.t);e.s=0,e.clamp(),this.s!=t.s&&n.ZERO.subTo(e,e)},n.prototype.squareTo=function(t){for(var e=this.abs(),r=t.t=2*e.t;--r>=0;)t[r]=0;for(r=0;r<e.t-1;++r){var s=e.am(r,e[r],t,2*r,0,1);(t[r+e.t]+=e.am(r+1,2*e[r],t,2*r+1,s,e.t-r-1))>=e.DV&&(t[r+e.t]-=e.DV,t[r+e.t+1]=1)}t.t>0&&(t[t.t-1]+=e.am(r,e[r],t,2*r,0,1)),t.s=0,t.clamp()},n.prototype.divRemTo=function(t,e,r){var s=t.abs();if(!(s.t<=0)){var i=this.abs();if(i.t<s.t){e!=null&&e.fromInt(0),r!=null&&this.copyTo(r);return}r==null&&(r=v());var o=v(),a=this.s,u=t.s,c=this.DB-ot(s[s.t-1]);c>0?(s.lShiftTo(c,o),i.lShiftTo(c,r)):(s.copyTo(o),i.copyTo(r));var h=o.t,d=o[h-1];if(d!=0){var l=d*(1<<this.F1)+(h>1?o[h-2]>>this.F2:0),g=this.FV/l,_=(1<<this.F1)/l,S=1<<this.F2,E=r.t,V=E-h,p=e??v();for(o.dlShiftTo(V,p),r.compareTo(p)>=0&&(r[r.t++]=1,r.subTo(p,r)),n.ONE.dlShiftTo(h,p),p.subTo(o,o);o.t<h;)o[o.t++]=0;for(;--V>=0;){var U=r[--E]==d?this.DM:Math.floor(r[E]*g+(r[E-1]+S)*_);if((r[E]+=o.am(0,U,r,V,0,h))<U)for(o.dlShiftTo(V,p),r.subTo(p,r);r[E]<--U;)r.subTo(p,r)}e!=null&&(r.drShiftTo(h,e),a!=u&&n.ZERO.subTo(e,e)),r.t=h,r.clamp(),c>0&&r.rShiftTo(c,r),a<0&&n.ZERO.subTo(r,r)}}},n.prototype.invDigit=function(){if(this.t<1)return 0;var t=this[0];if(!(t&1))return 0;var e=t&3;return e=e*(2-(t&15)*e)&15,e=e*(2-(t&255)*e)&255,e=e*(2-((t&65535)*e&65535))&65535,e=e*(2-t*e%this.DV)%this.DV,e>0?this.DV-e:-e},n.prototype.isEven=function(){return(this.t>0?this[0]&1:this.s)==0},n.prototype.exp=function(t,e){if(t>4294967295||t<1)return n.ONE;var r=v(),s=v(),i=e.convert(this),o=ot(t)-1;for(i.copyTo(r);--o>=0;)if(e.sqrTo(r,s),(t&1<<o)>0)e.mulTo(s,i,r);else{var a=r;r=s,s=a}return e.revert(r)},n.prototype.chunkSize=function(t){return Math.floor(Math.LN2*this.DB/Math.log(t))},n.prototype.toRadix=function(t){if(t==null&&(t=10),this.signum()==0||t<2||t>36)return"0";var e=this.chunkSize(t),r=Math.pow(t,e),s=k(r),i=v(),o=v(),a="";for(this.divRemTo(s,i,o);i.signum()>0;)a=(r+o.intValue()).toString(t).substr(1)+a,i.divRemTo(s,i,o);return o.intValue().toString(t)+a},n.prototype.fromRadix=function(t,e){this.fromInt(0),e==null&&(e=10);for(var r=this.chunkSize(e),s=Math.pow(e,r),i=!1,o=0,a=0,u=0;u<t.length;++u){var c=te(t,u);if(c<0){t.charAt(u)=="-"&&this.signum()==0&&(i=!0);continue}a=e*a+c,++o>=r&&(this.dMultiply(s),this.dAddOffset(a,0),o=0,a=0)}o>0&&(this.dMultiply(Math.pow(e,o)),this.dAddOffset(a,0)),i&&n.ZERO.subTo(this,this)},n.prototype.fromNumber=function(t,e,r){if(typeof e=="number")if(t<2)this.fromInt(1);else for(this.fromNumber(t,r),this.testBit(t-1)||this.bitwiseTo(n.ONE.shiftLeft(t-1),it,this),this.isEven()&&this.dAddOffset(1,0);!this.isProbablePrime(e);)this.dAddOffset(2,0),this.bitLength()>t&&this.subTo(n.ONE.shiftLeft(t-1),this);else{var s=[],i=t&7;s.length=(t>>3)+1,e.nextBytes(s),i>0?s[0]&=(1<<i)-1:s[0]=0,this.fromString(s,256)}},n.prototype.bitwiseTo=function(t,e,r){var s,i,o=Math.min(t.t,this.t);for(s=0;s<o;++s)r[s]=e(this[s],t[s]);if(t.t<this.t){for(i=t.s&this.DM,s=o;s<this.t;++s)r[s]=e(this[s],i);r.t=this.t}else{for(i=this.s&this.DM,s=o;s<t.t;++s)r[s]=e(i,t[s]);r.t=t.t}r.s=e(this.s,t.s),r.clamp()},n.prototype.changeBit=function(t,e){var r=n.ONE.shiftLeft(t);return this.bitwiseTo(r,e,r),r},n.prototype.addTo=function(t,e){for(var r=0,s=0,i=Math.min(t.t,this.t);r<i;)s+=this[r]+t[r],e[r++]=s&this.DM,s>>=this.DB;if(t.t<this.t){for(s+=t.s;r<this.t;)s+=this[r],e[r++]=s&this.DM,s>>=this.DB;s+=this.s}else{for(s+=this.s;r<t.t;)s+=t[r],e[r++]=s&this.DM,s>>=this.DB;s+=t.s}e.s=s<0?-1:0,s>0?e[r++]=s:s<-1&&(e[r++]=this.DV+s),e.t=r,e.clamp()},n.prototype.dMultiply=function(t){this[this.t]=this.am(0,t-1,this,0,0,this.t),++this.t,this.clamp()},n.prototype.dAddOffset=function(t,e){if(t!=0){for(;this.t<=e;)this[this.t++]=0;for(this[e]+=t;this[e]>=this.DV;)this[e]-=this.DV,++e>=this.t&&(this[this.t++]=0),++this[e]}},n.prototype.multiplyLowerTo=function(t,e,r){var s=Math.min(this.t+t.t,e);for(r.s=0,r.t=s;s>0;)r[--s]=0;for(var i=r.t-this.t;s<i;++s)r[s+this.t]=this.am(0,t[s],r,s,0,this.t);for(var i=Math.min(t.t,e);s<i;++s)this.am(0,t[s],r,s,0,e-s);r.clamp()},n.prototype.multiplyUpperTo=function(t,e,r){--e;var s=r.t=this.t+t.t-e;for(r.s=0;--s>=0;)r[s]=0;for(s=Math.max(e-this.t,0);s<t.t;++s)r[this.t+s-e]=this.am(e-s,t[s],r,0,0,this.t+s-e);r.clamp(),r.drShiftTo(1,r)},n.prototype.modInt=function(t){if(t<=0)return 0;var e=this.DV%t,r=this.s<0?t-1:0;if(this.t>0)if(e==0)r=this[0]%t;else for(var s=this.t-1;s>=0;--s)r=(e*r+this[s])%t;return r},n.prototype.millerRabin=function(t){var e=this.subtract(n.ONE),r=e.getLowestSetBit();if(r<=0)return!1;var s=e.shiftRight(r);t=t+1>>1,t>P.length&&(t=P.length);for(var i=v(),o=0;o<t;++o){i.fromInt(P[Math.floor(Math.random()*P.length)]);var a=i.modPow(s,this);if(a.compareTo(n.ONE)!=0&&a.compareTo(e)!=0){for(var u=1;u++<r&&a.compareTo(e)!=0;)if(a=a.modPowInt(2,this),a.compareTo(n.ONE)==0)return!1;if(a.compareTo(e)!=0)return!1}}return!0},n.prototype.square=function(){var t=v();return this.squareTo(t),t},n.prototype.gcda=function(t,e){var r=this.s<0?this.negate():this.clone(),s=t.s<0?t.negate():t.clone();if(r.compareTo(s)<0){var i=r;r=s,s=i}var o=r.getLowestSetBit(),a=s.getLowestSetBit();if(a<0){e(r);return}o<a&&(a=o),a>0&&(r.rShiftTo(a,r),s.rShiftTo(a,s));var u=function(){(o=r.getLowestSetBit())>0&&r.rShiftTo(o,r),(o=s.getLowestSetBit())>0&&s.rShiftTo(o,s),r.compareTo(s)>=0?(r.subTo(s,r),r.rShiftTo(1,r)):(s.subTo(r,s),s.rShiftTo(1,s)),r.signum()>0?setTimeout(u,0):(a>0&&s.lShiftTo(a,s),setTimeout(function(){e(s)},0))};setTimeout(u,10)},n.prototype.fromNumberAsync=function(t,e,r,s){if(typeof e=="number")if(t<2)this.fromInt(1);else{this.fromNumber(t,r),this.testBit(t-1)||this.bitwiseTo(n.ONE.shiftLeft(t-1),it,this),this.isEven()&&this.dAddOffset(1,0);var i=this,o=function(){i.dAddOffset(2,0),i.bitLength()>t&&i.subTo(n.ONE.shiftLeft(t-1),i),i.isProbablePrime(e)?setTimeout(function(){s()},0):setTimeout(o,0)};setTimeout(o,0)}else{var a=[],u=t&7;a.length=(t>>3)+1,e.nextBytes(a),u>0?a[0]&=(1<<u)-1:a[0]=0,this.fromString(a,256)}},n}(),on=function(){function n(){}return n.prototype.convert=function(t){return t},n.prototype.revert=function(t){return t},n.prototype.mulTo=function(t,e,r){t.multiplyTo(e,r)},n.prototype.sqrTo=function(t,e){t.squareTo(e)},n}(),Xt=function(){function n(t){this.m=t}return n.prototype.convert=function(t){return t.s<0||t.compareTo(this.m)>=0?t.mod(this.m):t},n.prototype.revert=function(t){return t},n.prototype.reduce=function(t){t.divRemTo(this.m,null,t)},n.prototype.mulTo=function(t,e,r){t.multiplyTo(e,r),this.reduce(r)},n.prototype.sqrTo=function(t,e){t.squareTo(e),this.reduce(e)},n}(),Qt=function(){function n(t){this.m=t,this.mp=t.invDigit(),this.mpl=this.mp&32767,this.mph=this.mp>>15,this.um=(1<<t.DB-15)-1,this.mt2=2*t.t}return n.prototype.convert=function(t){var e=v();return t.abs().dlShiftTo(this.m.t,e),e.divRemTo(this.m,null,e),t.s<0&&e.compareTo(m.ZERO)>0&&this.m.subTo(e,e),e},n.prototype.revert=function(t){var e=v();return t.copyTo(e),this.reduce(e),e},n.prototype.reduce=function(t){for(;t.t<=this.mt2;)t[t.t++]=0;for(var e=0;e<this.m.t;++e){var r=t[e]&32767,s=r*this.mpl+((r*this.mph+(t[e]>>15)*this.mpl&this.um)<<15)&t.DM;for(r=e+this.m.t,t[r]+=this.m.am(0,s,t,e,0,this.m.t);t[r]>=t.DV;)t[r]-=t.DV,t[++r]++}t.clamp(),t.drShiftTo(this.m.t,t),t.compareTo(this.m)>=0&&t.subTo(this.m,t)},n.prototype.mulTo=function(t,e,r){t.multiplyTo(e,r),this.reduce(r)},n.prototype.sqrTo=function(t,e){t.squareTo(e),this.reduce(e)},n}(),an=function(){function n(t){this.m=t,this.r2=v(),this.q3=v(),m.ONE.dlShiftTo(2*t.t,this.r2),this.mu=this.r2.divide(t)}return n.prototype.convert=function(t){if(t.s<0||t.t>2*this.m.t)return t.mod(this.m);if(t.compareTo(this.m)<0)return t;var e=v();return t.copyTo(e),this.reduce(e),e},n.prototype.revert=function(t){return t},n.prototype.reduce=function(t){for(t.drShiftTo(this.m.t-1,this.r2),t.t>this.m.t+1&&(t.t=this.m.t+1,t.clamp()),this.mu.multiplyUpperTo(this.r2,this.m.t+1,this.q3),this.m.multiplyLowerTo(this.q3,this.m.t+1,this.r2);t.compareTo(this.r2)<0;)t.dAddOffset(1,this.m.t+1);for(t.subTo(this.r2,t);t.compareTo(this.m)>=0;)t.subTo(this.m,t)},n.prototype.mulTo=function(t,e,r){t.multiplyTo(e,r),this.reduce(r)},n.prototype.sqrTo=function(t,e){t.squareTo(e),this.reduce(e)},n}();function v(){return new m(null)}function w(n,t){return new m(n,t)}var Wt=typeof navigator<"u";Wt&&Jt&&navigator.appName=="Microsoft Internet Explorer"?(m.prototype.am=function(n,t,e,r,s,i){for(var o=t&32767,a=t>>15;--i>=0;){var u=this[n]&32767,c=this[n++]>>15,h=a*u+c*o;u=o*u+((h&32767)<<15)+e[r]+(s&1073741823),s=(u>>>30)+(h>>>15)+a*c+(s>>>30),e[r++]=u&1073741823}return s},q=30):Wt&&Jt&&navigator.appName!="Netscape"?(m.prototype.am=function(n,t,e,r,s,i){for(;--i>=0;){var o=t*this[n++]+e[r]+s;s=Math.floor(o/67108864),e[r++]=o&67108863}return s},q=26):(m.prototype.am=function(n,t,e,r,s,i){for(var o=t&16383,a=t>>14;--i>=0;){var u=this[n]&16383,c=this[n++]>>14,h=a*u+c*o;u=o*u+((h&16383)<<14)+e[r]+s,s=(u>>28)+(h>>14)+a*c,e[r++]=u&268435455}return s},q=28);m.prototype.DB=q;m.prototype.DM=(1<<q)-1;m.prototype.DV=1<<q;var qt=52;m.prototype.FV=Math.pow(2,qt);m.prototype.F1=qt-q;m.prototype.F2=2*q-qt;var mt=[],Q,I;Q="0".charCodeAt(0);for(I=0;I<=9;++I)mt[Q++]=I;Q="a".charCodeAt(0);for(I=10;I<36;++I)mt[Q++]=I;Q="A".charCodeAt(0);for(I=10;I<36;++I)mt[Q++]=I;function te(n,t){var e=mt[n.charCodeAt(t)];return e??-1}function k(n){var t=v();return t.fromInt(n),t}function ot(n){var t=1,e;return(e=n>>>16)!=0&&(n=e,t+=16),(e=n>>8)!=0&&(n=e,t+=8),(e=n>>4)!=0&&(n=e,t+=4),(e=n>>2)!=0&&(n=e,t+=2),(e=n>>1)!=0&&(n=e,t+=1),t}m.ZERO=k(0);m.ONE=k(1);var un=function(){function n(){this.i=0,this.j=0,this.S=[]}return n.prototype.init=function(t){var e,r,s;for(e=0;e<256;++e)this.S[e]=e;for(r=0,e=0;e<256;++e)r=r+this.S[e]+t[e%t.length]&255,s=this.S[e],this.S[e]=this.S[r],this.S[r]=s;this.i=0,this.j=0},n.prototype.next=function(){var t;return this.i=this.i+1&255,this.j=this.j+this.S[this.i]&255,t=this.S[this.i],this.S[this.i]=this.S[this.j],this.S[this.j]=t,this.S[t+this.S[this.i]&255]},n}();function hn(){return new un}var Ve=256,at,M=null,L;if(M==null){M=[],L=0;var ut=void 0;if(typeof window<"u"&&window.crypto&&window.crypto.getRandomValues){var wt=new Uint32Array(256);for(window.crypto.getRandomValues(wt),ut=0;ut<wt.length;++ut)M[L++]=wt[ut]&255}var ht=0,ct=function(n){if(ht=ht||0,ht>=256||L>=Ve){window.removeEventListener?window.removeEventListener("mousemove",ct,!1):window.detachEvent&&window.detachEvent("onmousemove",ct);return}try{var t=n.x+n.y;M[L++]=t&255,ht+=1}catch{}};typeof window<"u"&&(window.addEventListener?window.addEventListener("mousemove",ct,!1):window.attachEvent&&window.attachEvent("onmousemove",ct))}function cn(){if(at==null){for(at=hn();L<Ve;){var n=Math.floor(65536*Math.random());M[L++]=n&255}for(at.init(M),L=0;L<M.length;++L)M[L]=0;L=0}return at.next()}var kt=function(){function n(){}return n.prototype.nextBytes=function(t){for(var e=0;e<t.length;++e)t[e]=cn()},n}();function fn(n,t){if(t<n.length+22)return console.error("Message too long for RSA"),null;for(var e=t-n.length-6,r="",s=0;s<e;s+=2)r+="ff";var i="0001"+r+"00"+n;return w(i,16)}function pn(n,t){if(t<n.length+11)return console.error("Message too long for RSA"),null;for(var e=[],r=n.length-1;r>=0&&t>0;){var s=n.charCodeAt(r--);s<128?e[--t]=s:s>127&&s<2048?(e[--t]=s&63|128,e[--t]=s>>6|192):(e[--t]=s&63|128,e[--t]=s>>6&63|128,e[--t]=s>>12|224)}e[--t]=0;for(var i=new kt,o=[];t>2;){for(o[0]=0;o[0]==0;)i.nextBytes(o);e[--t]=o[0]}return e[--t]=2,e[--t]=0,new m(e)}var ln=function(){function n(){this.n=null,this.e=0,this.d=null,this.p=null,this.q=null,this.dmp1=null,this.dmq1=null,this.coeff=null}return n.prototype.doPublic=function(t){return t.modPowInt(this.e,this.n)},n.prototype.doPrivate=function(t){if(this.p==null||this.q==null)return t.modPow(this.d,this.n);for(var e=t.mod(this.p).modPow(this.dmp1,this.p),r=t.mod(this.q).modPow(this.dmq1,this.q);e.compareTo(r)<0;)e=e.add(this.p);return e.subtract(r).multiply(this.coeff).mod(this.p).multiply(this.q).add(r)},n.prototype.setPublic=function(t,e){t!=null&&e!=null&&t.length>0&&e.length>0?(this.n=w(t,16),this.e=parseInt(e,16)):console.error("Invalid RSA public key")},n.prototype.encrypt=function(t){var e=this.n.bitLength()+7>>3,r=pn(t,e);if(r==null)return null;var s=this.doPublic(r);if(s==null)return null;for(var i=s.toString(16),o=i.length,a=0;a<e*2-o;a++)i="0"+i;return i},n.prototype.setPrivate=function(t,e,r){t!=null&&e!=null&&t.length>0&&e.length>0?(this.n=w(t,16),this.e=parseInt(e,16),this.d=w(r,16)):console.error("Invalid RSA private key")},n.prototype.setPrivateEx=function(t,e,r,s,i,o,a,u){t!=null&&e!=null&&t.length>0&&e.length>0?(this.n=w(t,16),this.e=parseInt(e,16),this.d=w(r,16),this.p=w(s,16),this.q=w(i,16),this.dmp1=w(o,16),this.dmq1=w(a,16),this.coeff=w(u,16)):console.error("Invalid RSA private key")},n.prototype.generate=function(t,e){var r=new kt,s=t>>1;this.e=parseInt(e,16);for(var i=new m(e,16);;){for(;this.p=new m(t-s,1,r),!(this.p.subtract(m.ONE).gcd(i).compareTo(m.ONE)==0&&this.p.isProbablePrime(10)););for(;this.q=new m(s,1,r),!(this.q.subtract(m.ONE).gcd(i).compareTo(m.ONE)==0&&this.q.isProbablePrime(10)););if(this.p.compareTo(this.q)<=0){var o=this.p;this.p=this.q,this.q=o}var a=this.p.subtract(m.ONE),u=this.q.subtract(m.ONE),c=a.multiply(u);if(c.gcd(i).compareTo(m.ONE)==0){this.n=this.p.multiply(this.q),this.d=i.modInverse(c),this.dmp1=this.d.mod(a),this.dmq1=this.d.mod(u),this.coeff=this.q.modInverse(this.p);break}}},n.prototype.decrypt=function(t){var e=w(t,16),r=this.doPrivate(e);return r==null?null:gn(r,this.n.bitLength()+7>>3)},n.prototype.generateAsync=function(t,e,r){var s=new kt,i=t>>1;this.e=parseInt(e,16);var o=new m(e,16),a=this,u=function(){var c=function(){if(a.p.compareTo(a.q)<=0){var l=a.p;a.p=a.q,a.q=l}var g=a.p.subtract(m.ONE),_=a.q.subtract(m.ONE),S=g.multiply(_);S.gcd(o).compareTo(m.ONE)==0?(a.n=a.p.multiply(a.q),a.d=o.modInverse(S),a.dmp1=a.d.mod(g),a.dmq1=a.d.mod(_),a.coeff=a.q.modInverse(a.p),setTimeout(function(){r()},0)):setTimeout(u,0)},h=function(){a.q=v(),a.q.fromNumberAsync(i,1,s,function(){a.q.subtract(m.ONE).gcda(o,function(l){l.compareTo(m.ONE)==0&&a.q.isProbablePrime(10)?setTimeout(c,0):setTimeout(h,0)})})},d=function(){a.p=v(),a.p.fromNumberAsync(t-i,1,s,function(){a.p.subtract(m.ONE).gcda(o,function(l){l.compareTo(m.ONE)==0&&a.p.isProbablePrime(10)?setTimeout(h,0):setTimeout(d,0)})})};setTimeout(d,0)};setTimeout(u,0)},n.prototype.sign=function(t,e,r){var s=dn(r),i=s+e(t).toString(),o=fn(i,this.n.bitLength()/4);if(o==null)return null;var a=this.doPrivate(o);if(a==null)return null;var u=a.toString(16);return u.length&1?"0"+u:u},n.prototype.verify=function(t,e,r){var s=w(e,16),i=this.doPublic(s);if(i==null)return null;var o=i.toString(16).replace(/^1f+00/,""),a=mn(o);return a==r(t).toString()},n}();function gn(n,t){for(var e=n.toByteArray(),r=0;r<e.length&&e[r]==0;)++r;if(e.length-r!=t-1||e[r]!=2)return null;for(++r;e[r]!=0;)if(++r>=e.length)return null;for(var s="";++r<e.length;){var i=e[r]&255;i<128?s+=String.fromCharCode(i):i>191&&i<224?(s+=String.fromCharCode((i&31)<<6|e[r+1]&63),++r):(s+=String.fromCharCode((i&15)<<12|(e[r+1]&63)<<6|e[r+2]&63),r+=2)}return s}var pt={md2:"3020300c06082a864886f70d020205000410",md5:"3020300c06082a864886f70d020505000410",sha1:"3021300906052b0e03021a05000414",sha224:"302d300d06096086480165030402040500041c",sha256:"3031300d060960864801650304020105000420",sha384:"3041300d060960864801650304020205000430",sha512:"3051300d060960864801650304020305000440",ripemd160:"3021300906052b2403020105000414"};function dn(n){return pt[n]||""}function mn(n){for(var t in pt)if(pt.hasOwnProperty(t)){var e=pt[t],r=e.length;if(n.substr(0,r)==e)return n.substr(r)}return n}/*!
|
||
Copyright (c) 2011, Yahoo! Inc. All rights reserved.
|
||
Code licensed under the BSD License:
|
||
http://developer.yahoo.com/yui/license.html
|
||
version: 2.9.0
|
||
*/var b={};b.lang={extend:function(n,t,e){if(!t||!n)throw new Error("YAHOO.lang.extend failed, please check that all dependencies are included.");var r=function(){};if(r.prototype=t.prototype,n.prototype=new r,n.prototype.constructor=n,n.superclass=t.prototype,t.prototype.constructor==Object.prototype.constructor&&(t.prototype.constructor=t),e){var s;for(s in e)n.prototype[s]=e[s];var i=function(){},o=["toString","valueOf"];try{/MSIE/.test(navigator.userAgent)&&(i=function(a,u){for(s=0;s<o.length;s=s+1){var c=o[s],h=u[c];typeof h=="function"&&h!=Object.prototype[c]&&(a[c]=h)}})}catch{}i(n.prototype,e)}}};/**
|
||
* @fileOverview
|
||
* @name asn1-1.0.js
|
||
* @author Kenji Urushima kenji.urushima@gmail.com
|
||
* @version asn1 1.0.13 (2017-Jun-02)
|
||
* @since jsrsasign 2.1
|
||
* @license <a href="https://kjur.github.io/jsrsasign/license/">MIT License</a>
|
||
*/var f={};(typeof f.asn1>"u"||!f.asn1)&&(f.asn1={});f.asn1.ASN1Util=new function(){this.integerToByteHex=function(n){var t=n.toString(16);return t.length%2==1&&(t="0"+t),t},this.bigIntToMinTwosComplementsHex=function(n){var t=n.toString(16);if(t.substr(0,1)!="-")t.length%2==1?t="0"+t:t.match(/^[0-7]/)||(t="00"+t);else{var e=t.substr(1),r=e.length;r%2==1?r+=1:t.match(/^[0-7]/)||(r+=2);for(var s="",i=0;i<r;i++)s+="f";var o=new m(s,16),a=o.xor(n).add(m.ONE);t=a.toString(16).replace(/^-/,"")}return t},this.getPEMStringFromHex=function(n,t){return hextopem(n,t)},this.newObject=function(n){var t=f,e=t.asn1,r=e.DERBoolean,s=e.DERInteger,i=e.DERBitString,o=e.DEROctetString,a=e.DERNull,u=e.DERObjectIdentifier,c=e.DEREnumerated,h=e.DERUTF8String,d=e.DERNumericString,l=e.DERPrintableString,g=e.DERTeletexString,_=e.DERIA5String,S=e.DERUTCTime,E=e.DERGeneralizedTime,V=e.DERSequence,p=e.DERSet,U=e.DERTaggedObject,$=e.ASN1Util.newObject,W=Object.keys(n);if(W.length!=1)throw"key of param shall be only one.";var y=W[0];if(":bool:int:bitstr:octstr:null:oid:enum:utf8str:numstr:prnstr:telstr:ia5str:utctime:gentime:seq:set:tag:".indexOf(":"+y+":")==-1)throw"undefined key: "+y;if(y=="bool")return new r(n[y]);if(y=="int")return new s(n[y]);if(y=="bitstr")return new i(n[y]);if(y=="octstr")return new o(n[y]);if(y=="null")return new a(n[y]);if(y=="oid")return new u(n[y]);if(y=="enum")return new c(n[y]);if(y=="utf8str")return new h(n[y]);if(y=="numstr")return new d(n[y]);if(y=="prnstr")return new l(n[y]);if(y=="telstr")return new g(n[y]);if(y=="ia5str")return new _(n[y]);if(y=="utctime")return new S(n[y]);if(y=="gentime")return new E(n[y]);if(y=="seq"){for(var j=n[y],O=[],A=0;A<j.length;A++){var tt=$(j[A]);O.push(tt)}return new V({array:O})}if(y=="set"){for(var j=n[y],O=[],A=0;A<j.length;A++){var tt=$(j[A]);O.push(tt)}return new p({array:O})}if(y=="tag"){var x=n[y];if(Object.prototype.toString.call(x)==="[object Array]"&&x.length==3){var Ze=$(x[2]);return new U({tag:x[0],explicit:x[1],obj:Ze})}else{var st={};if(x.explicit!==void 0&&(st.explicit=x.explicit),x.tag!==void 0&&(st.tag=x.tag),x.obj===void 0)throw"obj shall be specified for 'tag'.";return st.obj=$(x.obj),new U(st)}}},this.jsonToASN1HEX=function(n){var t=this.newObject(n);return t.getEncodedHex()}};f.asn1.ASN1Util.oidHexToInt=function(n){for(var s="",t=parseInt(n.substr(0,2),16),e=Math.floor(t/40),r=t%40,s=e+"."+r,i="",o=2;o<n.length;o+=2){var a=parseInt(n.substr(o,2),16),u=("00000000"+a.toString(2)).slice(-8);if(i=i+u.substr(1,7),u.substr(0,1)=="0"){var c=new m(i,2);s=s+"."+c.toString(10),i=""}}return s};f.asn1.ASN1Util.oidIntToHex=function(n){var t=function(a){var u=a.toString(16);return u.length==1&&(u="0"+u),u},e=function(a){var u="",c=new m(a,10),h=c.toString(2),d=7-h.length%7;d==7&&(d=0);for(var l="",g=0;g<d;g++)l+="0";h=l+h;for(var g=0;g<h.length-1;g+=7){var _=h.substr(g,7);g!=h.length-7&&(_="1"+_),u+=t(parseInt(_,2))}return u};if(!n.match(/^[0-9.]+$/))throw"malformed oid string: "+n;var r="",s=n.split("."),i=parseInt(s[0])*40+parseInt(s[1]);r+=t(i),s.splice(0,2);for(var o=0;o<s.length;o++)r+=e(s[o]);return r};f.asn1.ASN1Object=function(){var n="";this.getLengthHexFromValue=function(){if(typeof this.hV>"u"||this.hV==null)throw"this.hV is null or undefined.";if(this.hV.length%2==1)throw"value hex must be even length: n="+n.length+",v="+this.hV;var t=this.hV.length/2,e=t.toString(16);if(e.length%2==1&&(e="0"+e),t<128)return e;var r=e.length/2;if(r>15)throw"ASN.1 length too long to represent by 8x: n = "+t.toString(16);var s=128+r;return s.toString(16)+e},this.getEncodedHex=function(){return(this.hTLV==null||this.isModified)&&(this.hV=this.getFreshValueHex(),this.hL=this.getLengthHexFromValue(),this.hTLV=this.hT+this.hL+this.hV,this.isModified=!1),this.hTLV},this.getValueHex=function(){return this.getEncodedHex(),this.hV},this.getFreshValueHex=function(){return""}};f.asn1.DERAbstractString=function(n){f.asn1.DERAbstractString.superclass.constructor.call(this),this.getString=function(){return this.s},this.setString=function(t){this.hTLV=null,this.isModified=!0,this.s=t,this.hV=stohex(this.s)},this.setStringHex=function(t){this.hTLV=null,this.isModified=!0,this.s=null,this.hV=t},this.getFreshValueHex=function(){return this.hV},typeof n<"u"&&(typeof n=="string"?this.setString(n):typeof n.str<"u"?this.setString(n.str):typeof n.hex<"u"&&this.setStringHex(n.hex))};b.lang.extend(f.asn1.DERAbstractString,f.asn1.ASN1Object);f.asn1.DERAbstractTime=function(n){f.asn1.DERAbstractTime.superclass.constructor.call(this),this.localDateToUTC=function(t){utc=t.getTime()+t.getTimezoneOffset()*6e4;var e=new Date(utc);return e},this.formatDate=function(t,e,r){var s=this.zeroPadding,i=this.localDateToUTC(t),o=String(i.getFullYear());e=="utc"&&(o=o.substr(2,2));var a=s(String(i.getMonth()+1),2),u=s(String(i.getDate()),2),c=s(String(i.getHours()),2),h=s(String(i.getMinutes()),2),d=s(String(i.getSeconds()),2),l=o+a+u+c+h+d;if(r===!0){var g=i.getMilliseconds();if(g!=0){var _=s(String(g),3);_=_.replace(/[0]+$/,""),l=l+"."+_}}return l+"Z"},this.zeroPadding=function(t,e){return t.length>=e?t:new Array(e-t.length+1).join("0")+t},this.getString=function(){return this.s},this.setString=function(t){this.hTLV=null,this.isModified=!0,this.s=t,this.hV=stohex(t)},this.setByDateValue=function(t,e,r,s,i,o){var a=new Date(Date.UTC(t,e-1,r,s,i,o,0));this.setByDate(a)},this.getFreshValueHex=function(){return this.hV}};b.lang.extend(f.asn1.DERAbstractTime,f.asn1.ASN1Object);f.asn1.DERAbstractStructured=function(n){f.asn1.DERAbstractString.superclass.constructor.call(this),this.setByASN1ObjectArray=function(t){this.hTLV=null,this.isModified=!0,this.asn1Array=t},this.appendASN1Object=function(t){this.hTLV=null,this.isModified=!0,this.asn1Array.push(t)},this.asn1Array=new Array,typeof n<"u"&&typeof n.array<"u"&&(this.asn1Array=n.array)};b.lang.extend(f.asn1.DERAbstractStructured,f.asn1.ASN1Object);f.asn1.DERBoolean=function(){f.asn1.DERBoolean.superclass.constructor.call(this),this.hT="01",this.hTLV="0101ff"};b.lang.extend(f.asn1.DERBoolean,f.asn1.ASN1Object);f.asn1.DERInteger=function(n){f.asn1.DERInteger.superclass.constructor.call(this),this.hT="02",this.setByBigInteger=function(t){this.hTLV=null,this.isModified=!0,this.hV=f.asn1.ASN1Util.bigIntToMinTwosComplementsHex(t)},this.setByInteger=function(t){var e=new m(String(t),10);this.setByBigInteger(e)},this.setValueHex=function(t){this.hV=t},this.getFreshValueHex=function(){return this.hV},typeof n<"u"&&(typeof n.bigint<"u"?this.setByBigInteger(n.bigint):typeof n.int<"u"?this.setByInteger(n.int):typeof n=="number"?this.setByInteger(n):typeof n.hex<"u"&&this.setValueHex(n.hex))};b.lang.extend(f.asn1.DERInteger,f.asn1.ASN1Object);f.asn1.DERBitString=function(n){if(n!==void 0&&typeof n.obj<"u"){var t=f.asn1.ASN1Util.newObject(n.obj);n.hex="00"+t.getEncodedHex()}f.asn1.DERBitString.superclass.constructor.call(this),this.hT="03",this.setHexValueIncludingUnusedBits=function(e){this.hTLV=null,this.isModified=!0,this.hV=e},this.setUnusedBitsAndHexValue=function(e,r){if(e<0||7<e)throw"unused bits shall be from 0 to 7: u = "+e;var s="0"+e;this.hTLV=null,this.isModified=!0,this.hV=s+r},this.setByBinaryString=function(e){e=e.replace(/0+$/,"");var r=8-e.length%8;r==8&&(r=0);for(var s=0;s<=r;s++)e+="0";for(var i="",s=0;s<e.length-1;s+=8){var o=e.substr(s,8),a=parseInt(o,2).toString(16);a.length==1&&(a="0"+a),i+=a}this.hTLV=null,this.isModified=!0,this.hV="0"+r+i},this.setByBooleanArray=function(e){for(var r="",s=0;s<e.length;s++)e[s]==!0?r+="1":r+="0";this.setByBinaryString(r)},this.newFalseArray=function(e){for(var r=new Array(e),s=0;s<e;s++)r[s]=!1;return r},this.getFreshValueHex=function(){return this.hV},typeof n<"u"&&(typeof n=="string"&&n.toLowerCase().match(/^[0-9a-f]+$/)?this.setHexValueIncludingUnusedBits(n):typeof n.hex<"u"?this.setHexValueIncludingUnusedBits(n.hex):typeof n.bin<"u"?this.setByBinaryString(n.bin):typeof n.array<"u"&&this.setByBooleanArray(n.array))};b.lang.extend(f.asn1.DERBitString,f.asn1.ASN1Object);f.asn1.DEROctetString=function(n){if(n!==void 0&&typeof n.obj<"u"){var t=f.asn1.ASN1Util.newObject(n.obj);n.hex=t.getEncodedHex()}f.asn1.DEROctetString.superclass.constructor.call(this,n),this.hT="04"};b.lang.extend(f.asn1.DEROctetString,f.asn1.DERAbstractString);f.asn1.DERNull=function(){f.asn1.DERNull.superclass.constructor.call(this),this.hT="05",this.hTLV="0500"};b.lang.extend(f.asn1.DERNull,f.asn1.ASN1Object);f.asn1.DERObjectIdentifier=function(n){var t=function(r){var s=r.toString(16);return s.length==1&&(s="0"+s),s},e=function(r){var s="",i=new m(r,10),o=i.toString(2),a=7-o.length%7;a==7&&(a=0);for(var u="",c=0;c<a;c++)u+="0";o=u+o;for(var c=0;c<o.length-1;c+=7){var h=o.substr(c,7);c!=o.length-7&&(h="1"+h),s+=t(parseInt(h,2))}return s};f.asn1.DERObjectIdentifier.superclass.constructor.call(this),this.hT="06",this.setValueHex=function(r){this.hTLV=null,this.isModified=!0,this.s=null,this.hV=r},this.setValueOidString=function(r){if(!r.match(/^[0-9.]+$/))throw"malformed oid string: "+r;var s="",i=r.split("."),o=parseInt(i[0])*40+parseInt(i[1]);s+=t(o),i.splice(0,2);for(var a=0;a<i.length;a++)s+=e(i[a]);this.hTLV=null,this.isModified=!0,this.s=null,this.hV=s},this.setValueName=function(r){var s=f.asn1.x509.OID.name2oid(r);if(s!=="")this.setValueOidString(s);else throw"DERObjectIdentifier oidName undefined: "+r},this.getFreshValueHex=function(){return this.hV},n!==void 0&&(typeof n=="string"?n.match(/^[0-2].[0-9.]+$/)?this.setValueOidString(n):this.setValueName(n):n.oid!==void 0?this.setValueOidString(n.oid):n.hex!==void 0?this.setValueHex(n.hex):n.name!==void 0&&this.setValueName(n.name))};b.lang.extend(f.asn1.DERObjectIdentifier,f.asn1.ASN1Object);f.asn1.DEREnumerated=function(n){f.asn1.DEREnumerated.superclass.constructor.call(this),this.hT="0a",this.setByBigInteger=function(t){this.hTLV=null,this.isModified=!0,this.hV=f.asn1.ASN1Util.bigIntToMinTwosComplementsHex(t)},this.setByInteger=function(t){var e=new m(String(t),10);this.setByBigInteger(e)},this.setValueHex=function(t){this.hV=t},this.getFreshValueHex=function(){return this.hV},typeof n<"u"&&(typeof n.int<"u"?this.setByInteger(n.int):typeof n=="number"?this.setByInteger(n):typeof n.hex<"u"&&this.setValueHex(n.hex))};b.lang.extend(f.asn1.DEREnumerated,f.asn1.ASN1Object);f.asn1.DERUTF8String=function(n){f.asn1.DERUTF8String.superclass.constructor.call(this,n),this.hT="0c"};b.lang.extend(f.asn1.DERUTF8String,f.asn1.DERAbstractString);f.asn1.DERNumericString=function(n){f.asn1.DERNumericString.superclass.constructor.call(this,n),this.hT="12"};b.lang.extend(f.asn1.DERNumericString,f.asn1.DERAbstractString);f.asn1.DERPrintableString=function(n){f.asn1.DERPrintableString.superclass.constructor.call(this,n),this.hT="13"};b.lang.extend(f.asn1.DERPrintableString,f.asn1.DERAbstractString);f.asn1.DERTeletexString=function(n){f.asn1.DERTeletexString.superclass.constructor.call(this,n),this.hT="14"};b.lang.extend(f.asn1.DERTeletexString,f.asn1.DERAbstractString);f.asn1.DERIA5String=function(n){f.asn1.DERIA5String.superclass.constructor.call(this,n),this.hT="16"};b.lang.extend(f.asn1.DERIA5String,f.asn1.DERAbstractString);f.asn1.DERUTCTime=function(n){f.asn1.DERUTCTime.superclass.constructor.call(this,n),this.hT="17",this.setByDate=function(t){this.hTLV=null,this.isModified=!0,this.date=t,this.s=this.formatDate(this.date,"utc"),this.hV=stohex(this.s)},this.getFreshValueHex=function(){return typeof this.date>"u"&&typeof this.s>"u"&&(this.date=new Date,this.s=this.formatDate(this.date,"utc"),this.hV=stohex(this.s)),this.hV},n!==void 0&&(n.str!==void 0?this.setString(n.str):typeof n=="string"&&n.match(/^[0-9]{12}Z$/)?this.setString(n):n.hex!==void 0?this.setStringHex(n.hex):n.date!==void 0&&this.setByDate(n.date))};b.lang.extend(f.asn1.DERUTCTime,f.asn1.DERAbstractTime);f.asn1.DERGeneralizedTime=function(n){f.asn1.DERGeneralizedTime.superclass.constructor.call(this,n),this.hT="18",this.withMillis=!1,this.setByDate=function(t){this.hTLV=null,this.isModified=!0,this.date=t,this.s=this.formatDate(this.date,"gen",this.withMillis),this.hV=stohex(this.s)},this.getFreshValueHex=function(){return this.date===void 0&&this.s===void 0&&(this.date=new Date,this.s=this.formatDate(this.date,"gen",this.withMillis),this.hV=stohex(this.s)),this.hV},n!==void 0&&(n.str!==void 0?this.setString(n.str):typeof n=="string"&&n.match(/^[0-9]{14}Z$/)?this.setString(n):n.hex!==void 0?this.setStringHex(n.hex):n.date!==void 0&&this.setByDate(n.date),n.millis===!0&&(this.withMillis=!0))};b.lang.extend(f.asn1.DERGeneralizedTime,f.asn1.DERAbstractTime);f.asn1.DERSequence=function(n){f.asn1.DERSequence.superclass.constructor.call(this,n),this.hT="30",this.getFreshValueHex=function(){for(var t="",e=0;e<this.asn1Array.length;e++){var r=this.asn1Array[e];t+=r.getEncodedHex()}return this.hV=t,this.hV}};b.lang.extend(f.asn1.DERSequence,f.asn1.DERAbstractStructured);f.asn1.DERSet=function(n){f.asn1.DERSet.superclass.constructor.call(this,n),this.hT="31",this.sortFlag=!0,this.getFreshValueHex=function(){for(var t=new Array,e=0;e<this.asn1Array.length;e++){var r=this.asn1Array[e];t.push(r.getEncodedHex())}return this.sortFlag==!0&&t.sort(),this.hV=t.join(""),this.hV},typeof n<"u"&&typeof n.sortflag<"u"&&n.sortflag==!1&&(this.sortFlag=!1)};b.lang.extend(f.asn1.DERSet,f.asn1.DERAbstractStructured);f.asn1.DERTaggedObject=function(n){f.asn1.DERTaggedObject.superclass.constructor.call(this),this.hT="a0",this.hV="",this.isExplicit=!0,this.asn1Object=null,this.setASN1Object=function(t,e,r){this.hT=e,this.isExplicit=t,this.asn1Object=r,this.isExplicit?(this.hV=this.asn1Object.getEncodedHex(),this.hTLV=null,this.isModified=!0):(this.hV=null,this.hTLV=r.getEncodedHex(),this.hTLV=this.hTLV.replace(/^../,e),this.isModified=!1)},this.getFreshValueHex=function(){return this.hV},typeof n<"u"&&(typeof n.tag<"u"&&(this.hT=n.tag),typeof n.explicit<"u"&&(this.isExplicit=n.explicit),typeof n.obj<"u"&&(this.asn1Object=n.obj,this.setASN1Object(this.isExplicit,this.hT,this.asn1Object)))};b.lang.extend(f.asn1.DERTaggedObject,f.asn1.ASN1Object);var yn=globalThis&&globalThis.__extends||function(){var n=function(t,e){return n=Object.setPrototypeOf||{__proto__:[]}instanceof Array&&function(r,s){r.__proto__=s}||function(r,s){for(var i in s)Object.prototype.hasOwnProperty.call(s,i)&&(r[i]=s[i])},n(t,e)};return function(t,e){if(typeof e!="function"&&e!==null)throw new TypeError("Class extends value "+String(e)+" is not a constructor or null");n(t,e);function r(){this.constructor=t}t.prototype=e===null?Object.create(e):(r.prototype=e.prototype,new r)}}(),ee=function(n){yn(t,n);function t(e){var r=n.call(this)||this;return e&&(typeof e=="string"?r.parseKey(e):(t.hasPrivateKeyProperty(e)||t.hasPublicKeyProperty(e))&&r.parsePropertiesFrom(e)),r}return t.prototype.parseKey=function(e){try{var r=0,s=0,i=/^\s*(?:[0-9A-Fa-f][0-9A-Fa-f]\s*)+$/,o=i.test(e)?We.decode(e):jt.unarmor(e),a=nn.decode(o);if(a.sub.length===3&&(a=a.sub[2].sub[0]),a.sub.length===9){r=a.sub[1].getHexStringValue(),this.n=w(r,16),s=a.sub[2].getHexStringValue(),this.e=parseInt(s,16);var u=a.sub[3].getHexStringValue();this.d=w(u,16);var c=a.sub[4].getHexStringValue();this.p=w(c,16);var h=a.sub[5].getHexStringValue();this.q=w(h,16);var d=a.sub[6].getHexStringValue();this.dmp1=w(d,16);var l=a.sub[7].getHexStringValue();this.dmq1=w(l,16);var g=a.sub[8].getHexStringValue();this.coeff=w(g,16)}else if(a.sub.length===2)if(a.sub[0].sub){var _=a.sub[1],S=_.sub[0];r=S.sub[0].getHexStringValue(),this.n=w(r,16),s=S.sub[1].getHexStringValue(),this.e=parseInt(s,16)}else r=a.sub[0].getHexStringValue(),this.n=w(r,16),s=a.sub[1].getHexStringValue(),this.e=parseInt(s,16);else return!1;return!0}catch{return!1}},t.prototype.getPrivateBaseKey=function(){var e={array:[new f.asn1.DERInteger({int:0}),new f.asn1.DERInteger({bigint:this.n}),new f.asn1.DERInteger({int:this.e}),new f.asn1.DERInteger({bigint:this.d}),new f.asn1.DERInteger({bigint:this.p}),new f.asn1.DERInteger({bigint:this.q}),new f.asn1.DERInteger({bigint:this.dmp1}),new f.asn1.DERInteger({bigint:this.dmq1}),new f.asn1.DERInteger({bigint:this.coeff})]},r=new f.asn1.DERSequence(e);return r.getEncodedHex()},t.prototype.getPrivateBaseKeyB64=function(){return dt(this.getPrivateBaseKey())},t.prototype.getPublicBaseKey=function(){var e=new f.asn1.DERSequence({array:[new f.asn1.DERObjectIdentifier({oid:"1.2.840.113549.1.1.1"}),new f.asn1.DERNull]}),r=new f.asn1.DERSequence({array:[new f.asn1.DERInteger({bigint:this.n}),new f.asn1.DERInteger({int:this.e})]}),s=new f.asn1.DERBitString({hex:"00"+r.getEncodedHex()}),i=new f.asn1.DERSequence({array:[e,s]});return i.getEncodedHex()},t.prototype.getPublicBaseKeyB64=function(){return dt(this.getPublicBaseKey())},t.wordwrap=function(e,r){if(r=r||64,!e)return e;var s="(.{1,"+r+`})( +|$
|
||
?)|(.{1,`+r+"})";return e.match(RegExp(s,"g")).join(`
|
||
`)},t.prototype.getPrivateKey=function(){var e=`-----BEGIN RSA PRIVATE KEY-----
|
||
`;return e+=t.wordwrap(this.getPrivateBaseKeyB64())+`
|
||
`,e+="-----END RSA PRIVATE KEY-----",e},t.prototype.getPublicKey=function(){var e=`-----BEGIN PUBLIC KEY-----
|
||
`;return e+=t.wordwrap(this.getPublicBaseKeyB64())+`
|
||
`,e+="-----END PUBLIC KEY-----",e},t.hasPublicKeyProperty=function(e){return e=e||{},e.hasOwnProperty("n")&&e.hasOwnProperty("e")},t.hasPrivateKeyProperty=function(e){return e=e||{},e.hasOwnProperty("n")&&e.hasOwnProperty("e")&&e.hasOwnProperty("d")&&e.hasOwnProperty("p")&&e.hasOwnProperty("q")&&e.hasOwnProperty("dmp1")&&e.hasOwnProperty("dmq1")&&e.hasOwnProperty("coeff")},t.prototype.parsePropertiesFrom=function(e){this.n=e.n,this.e=e.e,e.hasOwnProperty("d")&&(this.d=e.d,this.p=e.p,this.q=e.q,this.dmp1=e.dmp1,this.dmq1=e.dmq1,this.coeff=e.coeff)},t}(ln),bt,vn=typeof process<"u"?(bt=process.env)===null||bt===void 0?void 0:bt.npm_package_version:void 0,_n=function(){function n(t){t===void 0&&(t={}),t=t||{},this.default_key_size=t.default_key_size?parseInt(t.default_key_size,10):1024,this.default_public_exponent=t.default_public_exponent||"010001",this.log=t.log||!1,this.key=null}return n.prototype.setKey=function(t){this.log&&this.key&&console.warn("A key was already set, overriding existing."),this.key=new ee(t)},n.prototype.setPrivateKey=function(t){this.setKey(t)},n.prototype.setPublicKey=function(t){this.setKey(t)},n.prototype.decrypt=function(t){try{return this.getKey().decrypt(Zt(t))}catch{return!1}},n.prototype.encrypt=function(t){try{return dt(this.getKey().encrypt(t))}catch{return!1}},n.prototype.sign=function(t,e,r){try{return dt(this.getKey().sign(t,e,r))}catch{return!1}},n.prototype.verify=function(t,e,r){try{return this.getKey().verify(t,Zt(e),r)}catch{return!1}},n.prototype.getKey=function(t){if(!this.key){if(this.key=new ee,t&&{}.toString.call(t)==="[object Function]"){this.key.generateAsync(this.default_key_size,this.default_public_exponent,t);return}this.key.generate(this.default_key_size,this.default_public_exponent)}return this.key},n.prototype.getPrivateKey=function(){return this.getKey().getPrivateKey()},n.prototype.getPrivateKeyB64=function(){return this.getKey().getPrivateBaseKeyB64()},n.prototype.getPublicKey=function(){return this.getKey().getPublicKey()},n.prototype.getPublicKeyB64=function(){return this.getKey().getPublicBaseKeyB64()},n.version=vn,n}();function Sn(n){return n&&n.__esModule&&Object.prototype.hasOwnProperty.call(n,"default")?n.default:n}var Ht={exports:{}},Be=function(n,t){return function(){for(var e=new Array(arguments.length),r=0;r<e.length;r++)e[r]=arguments[r];return n.apply(t,e)}},Tn=Be,F=Object.prototype.toString;function Kt(n){return F.call(n)==="[object Array]"}function Ct(n){return typeof n>"u"}function wn(n){return n!==null&&!Ct(n)&&n.constructor!==null&&!Ct(n.constructor)&&typeof n.constructor.isBuffer=="function"&&n.constructor.isBuffer(n)}function bn(n){return F.call(n)==="[object ArrayBuffer]"}function En(n){return typeof FormData<"u"&&n instanceof FormData}function On(n){var t;return typeof ArrayBuffer<"u"&&ArrayBuffer.isView?t=ArrayBuffer.isView(n):t=n&&n.buffer&&n.buffer instanceof ArrayBuffer,t}function An(n){return typeof n=="string"}function xn(n){return typeof n=="number"}function Ue(n){return n!==null&&typeof n=="object"}function lt(n){if(F.call(n)!=="[object Object]")return!1;var t=Object.getPrototypeOf(n);return t===null||t===Object.prototype}function Pn(n){return F.call(n)==="[object Date]"}function Dn(n){return F.call(n)==="[object File]"}function Rn(n){return F.call(n)==="[object Blob]"}function je(n){return F.call(n)==="[object Function]"}function In(n){return Ue(n)&&je(n.pipe)}function Ln(n){return typeof URLSearchParams<"u"&&n instanceof URLSearchParams}function Nn(n){return n.trim?n.trim():n.replace(/^\s+|\s+$/g,"")}function Vn(){return typeof navigator<"u"&&(navigator.product==="ReactNative"||navigator.product==="NativeScript"||navigator.product==="NS")?!1:typeof window<"u"&&typeof document<"u"}function Ft(n,t){if(!(n===null||typeof n>"u"))if(typeof n!="object"&&(n=[n]),Kt(n))for(var e=0,r=n.length;e<r;e++)t.call(null,n[e],e,n);else for(var s in n)Object.prototype.hasOwnProperty.call(n,s)&&t.call(null,n[s],s,n)}function Mt(){var n={};function t(s,i){lt(n[i])&<(s)?n[i]=Mt(n[i],s):lt(s)?n[i]=Mt({},s):Kt(s)?n[i]=s.slice():n[i]=s}for(var e=0,r=arguments.length;e<r;e++)Ft(arguments[e],t);return n}function Bn(n,t,e){return Ft(t,function(r,s){e&&typeof r=="function"?n[s]=Tn(r,e):n[s]=r}),n}function Un(n){return n.charCodeAt(0)===65279&&(n=n.slice(1)),n}var R={isArray:Kt,isArrayBuffer:bn,isBuffer:wn,isFormData:En,isArrayBufferView:On,isString:An,isNumber:xn,isObject:Ue,isPlainObject:lt,isUndefined:Ct,isDate:Pn,isFile:Dn,isBlob:Rn,isFunction:je,isStream:In,isURLSearchParams:Ln,isStandardBrowserEnv:Vn,forEach:Ft,merge:Mt,extend:Bn,trim:Nn,stripBOM:Un},Z=R;function ne(n){return encodeURIComponent(n).replace(/%3A/gi,":").replace(/%24/g,"$").replace(/%2C/gi,",").replace(/%20/g,"+").replace(/%5B/gi,"[").replace(/%5D/gi,"]")}var ke=function(n,t,e){if(!t)return n;var r;if(e)r=e(t);else if(Z.isURLSearchParams(t))r=t.toString();else{var s=[];Z.forEach(t,function(o,a){o===null||typeof o>"u"||(Z.isArray(o)?a=a+"[]":o=[o],Z.forEach(o,function(u){Z.isDate(u)?u=u.toISOString():Z.isObject(u)&&(u=JSON.stringify(u)),s.push(ne(a)+"="+ne(u))}))}),r=s.join("&")}if(r){var i=n.indexOf("#");i!==-1&&(n=n.slice(0,i)),n+=(n.indexOf("?")===-1?"?":"&")+r}return n},jn=R;function yt(){this.handlers=[]}yt.prototype.use=function(n,t,e){return this.handlers.push({fulfilled:n,rejected:t,synchronous:e?e.synchronous:!1,runWhen:e?e.runWhen:null}),this.handlers.length-1};yt.prototype.eject=function(n){this.handlers[n]&&(this.handlers[n]=null)};yt.prototype.forEach=function(n){jn.forEach(this.handlers,function(t){t!==null&&n(t)})};var kn=yt,Cn=R,Mn=function(n,t){Cn.forEach(n,function(e,r){r!==t&&r.toUpperCase()===t.toUpperCase()&&(n[t]=e,delete n[r])})},Ce=function(n,t,e,r,s){return n.config=t,e&&(n.code=e),n.request=r,n.response=s,n.isAxiosError=!0,n.toJSON=function(){return{message:this.message,name:this.name,description:this.description,number:this.number,fileName:this.fileName,lineNumber:this.lineNumber,columnNumber:this.columnNumber,stack:this.stack,config:this.config,code:this.code,status:this.response&&this.response.status?this.response.status:null}},n},Et,re;function Me(){if(re)return Et;re=1;var n=Ce;return Et=function(t,e,r,s,i){var o=new Error(t);return n(o,e,r,s,i)},Et}var Ot,se;function qn(){if(se)return Ot;se=1;var n=Me();return Ot=function(t,e,r){var s=r.config.validateStatus;!r.status||!s||s(r.status)?t(r):e(n("Request failed with status code "+r.status,r.config,null,r.request,r))},Ot}var At,ie;function Hn(){if(ie)return At;ie=1;var n=R;return At=n.isStandardBrowserEnv()?function(){return{write:function(t,e,r,s,i,o){var a=[];a.push(t+"="+encodeURIComponent(e)),n.isNumber(r)&&a.push("expires="+new Date(r).toGMTString()),n.isString(s)&&a.push("path="+s),n.isString(i)&&a.push("domain="+i),o===!0&&a.push("secure"),document.cookie=a.join("; ")},read:function(t){var e=document.cookie.match(new RegExp("(^|;\\s*)("+t+")=([^;]*)"));return e?decodeURIComponent(e[3]):null},remove:function(t){this.write(t,"",Date.now()-864e5)}}}():function(){return{write:function(){},read:function(){return null},remove:function(){}}}(),At}var oe,ae;function Kn(){return ae||(ae=1,oe=function(n){return/^([a-z][a-z\d\+\-\.]*:)?\/\//i.test(n)}),oe}var ue,he;function Fn(){return he||(he=1,ue=function(n,t){return t?n.replace(/\/+$/,"")+"/"+t.replace(/^\/+/,""):n}),ue}var xt,ce;function $n(){if(ce)return xt;ce=1;var n=Kn(),t=Fn();return xt=function(e,r){return e&&!n(r)?t(e,r):r},xt}var Pt,fe;function Gn(){if(fe)return Pt;fe=1;var n=R,t=["age","authorization","content-length","content-type","etag","expires","from","host","if-modified-since","if-unmodified-since","last-modified","location","max-forwards","proxy-authorization","referer","retry-after","user-agent"];return Pt=function(e){var r={},s,i,o;return e&&n.forEach(e.split(`
|
||
`),function(a){if(o=a.indexOf(":"),s=n.trim(a.substr(0,o)).toLowerCase(),i=n.trim(a.substr(o+1)),s){if(r[s]&&t.indexOf(s)>=0)return;s==="set-cookie"?r[s]=(r[s]?r[s]:[]).concat([i]):r[s]=r[s]?r[s]+", "+i:i}}),r},Pt}var Dt,pe;function zn(){if(pe)return Dt;pe=1;var n=R;return Dt=n.isStandardBrowserEnv()?function(){var t=/(msie|trident)/i.test(navigator.userAgent),e=document.createElement("a"),r;function s(i){var o=i;return t&&(e.setAttribute("href",o),o=e.href),e.setAttribute("href",o),{href:e.href,protocol:e.protocol?e.protocol.replace(/:$/,""):"",host:e.host,search:e.search?e.search.replace(/^\?/,""):"",hash:e.hash?e.hash.replace(/^#/,""):"",hostname:e.hostname,port:e.port,pathname:e.pathname.charAt(0)==="/"?e.pathname:"/"+e.pathname}}return r=s(window.location.href),function(i){var o=n.isString(i)?s(i):i;return o.protocol===r.protocol&&o.host===r.host}}():function(){return function(){return!0}}(),Dt}var Rt,le;function vt(){if(le)return Rt;le=1;function n(t){this.message=t}return n.prototype.toString=function(){return"Cancel"+(this.message?": "+this.message:"")},n.prototype.__CANCEL__=!0,Rt=n,Rt}var It,ge;function Zn(){if(ge)return It;ge=1;var n=R,t=qn(),e=Hn(),r=ke,s=$n(),i=Gn(),o=zn(),a=Me(),u=_t(),c=vt();return It=function(h){return new Promise(function(d,l){var g=h.data,_=h.headers,S=h.responseType,E;function V(){h.cancelToken&&h.cancelToken.unsubscribe(E),h.signal&&h.signal.removeEventListener("abort",E)}n.isFormData(g)&&delete _["Content-Type"];var p=new XMLHttpRequest;if(h.auth){var U=h.auth.username||"",$=h.auth.password?unescape(encodeURIComponent(h.auth.password)):"";_.Authorization="Basic "+btoa(U+":"+$)}var W=s(h.baseURL,h.url);p.open(h.method.toUpperCase(),r(W,h.params,h.paramsSerializer),!0),p.timeout=h.timeout;function y(){if(p){var O="getAllResponseHeaders"in p?i(p.getAllResponseHeaders()):null,A=!S||S==="text"||S==="json"?p.responseText:p.response,tt={data:A,status:p.status,statusText:p.statusText,headers:O,config:h,request:p};t(function(x){d(x),V()},function(x){l(x),V()},tt),p=null}}if("onloadend"in p?p.onloadend=y:p.onreadystatechange=function(){!p||p.readyState!==4||p.status===0&&!(p.responseURL&&p.responseURL.indexOf("file:")===0)||setTimeout(y)},p.onabort=function(){p&&(l(a("Request aborted",h,"ECONNABORTED",p)),p=null)},p.onerror=function(){l(a("Network Error",h,null,p)),p=null},p.ontimeout=function(){var O=h.timeout?"timeout of "+h.timeout+"ms exceeded":"timeout exceeded",A=h.transitional||u.transitional;h.timeoutErrorMessage&&(O=h.timeoutErrorMessage),l(a(O,h,A.clarifyTimeoutError?"ETIMEDOUT":"ECONNABORTED",p)),p=null},n.isStandardBrowserEnv()){var j=(h.withCredentials||o(W))&&h.xsrfCookieName?e.read(h.xsrfCookieName):void 0;j&&(_[h.xsrfHeaderName]=j)}"setRequestHeader"in p&&n.forEach(_,function(O,A){typeof g>"u"&&A.toLowerCase()==="content-type"?delete _[A]:p.setRequestHeader(A,O)}),n.isUndefined(h.withCredentials)||(p.withCredentials=!!h.withCredentials),S&&S!=="json"&&(p.responseType=h.responseType),typeof h.onDownloadProgress=="function"&&p.addEventListener("progress",h.onDownloadProgress),typeof h.onUploadProgress=="function"&&p.upload&&p.upload.addEventListener("progress",h.onUploadProgress),(h.cancelToken||h.signal)&&(E=function(O){p&&(l(!O||O&&O.type?new c("canceled"):O),p.abort(),p=null)},h.cancelToken&&h.cancelToken.subscribe(E),h.signal&&(h.signal.aborted?E():h.signal.addEventListener("abort",E))),g||(g=null),p.send(g)})},It}var Lt,de;function _t(){if(de)return Lt;de=1;var n=R,t=Mn,e=Ce,r={"Content-Type":"application/x-www-form-urlencoded"};function s(u,c){!n.isUndefined(u)&&n.isUndefined(u["Content-Type"])&&(u["Content-Type"]=c)}function i(){var u;return(typeof XMLHttpRequest<"u"||typeof process<"u"&&Object.prototype.toString.call(process)==="[object process]")&&(u=Zn()),u}function o(u,c,h){if(n.isString(u))try{return(c||JSON.parse)(u),n.trim(u)}catch(d){if(d.name!=="SyntaxError")throw d}return(h||JSON.stringify)(u)}var a={transitional:{silentJSONParsing:!0,forcedJSONParsing:!0,clarifyTimeoutError:!1},adapter:i(),transformRequest:[function(u,c){return t(c,"Accept"),t(c,"Content-Type"),n.isFormData(u)||n.isArrayBuffer(u)||n.isBuffer(u)||n.isStream(u)||n.isFile(u)||n.isBlob(u)?u:n.isArrayBufferView(u)?u.buffer:n.isURLSearchParams(u)?(s(c,"application/x-www-form-urlencoded;charset=utf-8"),u.toString()):n.isObject(u)||c&&c["Content-Type"]==="application/json"?(s(c,"application/json"),o(u)):u}],transformResponse:[function(u){var c=this.transitional||a.transitional,h=c&&c.silentJSONParsing,d=c&&c.forcedJSONParsing,l=!h&&this.responseType==="json";if(l||d&&n.isString(u)&&u.length)try{return JSON.parse(u)}catch(g){if(l)throw g.name==="SyntaxError"?e(g,this,"E_JSON_PARSE"):g}return u}],timeout:0,xsrfCookieName:"XSRF-TOKEN",xsrfHeaderName:"X-XSRF-TOKEN",maxContentLength:-1,maxBodyLength:-1,validateStatus:function(u){return u>=200&&u<300},headers:{common:{Accept:"application/json, text/plain, */*"}}};return n.forEach(["delete","get","head"],function(u){a.headers[u]={}}),n.forEach(["post","put","patch"],function(u){a.headers[u]=n.merge(r)}),Lt=a,Lt}var Yn=R,Jn=_t(),Xn=function(n,t,e){var r=this||Jn;return Yn.forEach(e,function(s){n=s.call(r,n,t)}),n},me,ye;function qe(){return ye||(ye=1,me=function(n){return!!(n&&n.__CANCEL__)}),me}var ve=R,Nt=Xn,Qn=qe(),Wn=_t(),tr=vt();function Vt(n){if(n.cancelToken&&n.cancelToken.throwIfRequested(),n.signal&&n.signal.aborted)throw new tr("canceled")}var er=function(n){Vt(n),n.headers=n.headers||{},n.data=Nt.call(n,n.data,n.headers,n.transformRequest),n.headers=ve.merge(n.headers.common||{},n.headers[n.method]||{},n.headers),ve.forEach(["delete","get","head","post","put","patch","common"],function(e){delete n.headers[e]});var t=n.adapter||Wn.adapter;return t(n).then(function(e){return Vt(n),e.data=Nt.call(n,e.data,e.headers,n.transformResponse),e},function(e){return Qn(e)||(Vt(n),e&&e.response&&(e.response.data=Nt.call(n,e.response.data,e.response.headers,n.transformResponse))),Promise.reject(e)})},D=R,He=function(n,t){t=t||{};var e={};function r(c,h){return D.isPlainObject(c)&&D.isPlainObject(h)?D.merge(c,h):D.isPlainObject(h)?D.merge({},h):D.isArray(h)?h.slice():h}function s(c){if(D.isUndefined(t[c])){if(!D.isUndefined(n[c]))return r(void 0,n[c])}else return r(n[c],t[c])}function i(c){if(!D.isUndefined(t[c]))return r(void 0,t[c])}function o(c){if(D.isUndefined(t[c])){if(!D.isUndefined(n[c]))return r(void 0,n[c])}else return r(void 0,t[c])}function a(c){if(c in t)return r(n[c],t[c]);if(c in n)return r(void 0,n[c])}var u={url:i,method:i,data:i,baseURL:o,transformRequest:o,transformResponse:o,paramsSerializer:o,timeout:o,timeoutMessage:o,withCredentials:o,adapter:o,responseType:o,xsrfCookieName:o,xsrfHeaderName:o,onUploadProgress:o,onDownloadProgress:o,decompress:o,maxContentLength:o,maxBodyLength:o,transport:o,httpAgent:o,httpsAgent:o,cancelToken:o,socketPath:o,responseEncoding:o,validateStatus:a};return D.forEach(Object.keys(n).concat(Object.keys(t)),function(c){var h=u[c]||s,d=h(c);D.isUndefined(d)&&h!==a||(e[c]=d)}),e},_e,Se;function Ke(){return Se||(Se=1,_e={version:"0.24.0"}),_e}var nr=Ke().version,$t={};["object","boolean","number","function","string","symbol"].forEach(function(n,t){$t[n]=function(e){return typeof e===n||"a"+(t<1?"n ":" ")+n}});var Te={};$t.transitional=function(n,t,e){function r(s,i){return"[Axios v"+nr+"] Transitional option '"+s+"'"+i+(e?". "+e:"")}return function(s,i,o){if(n===!1)throw new Error(r(i," has been removed"+(t?" in "+t:"")));return t&&!Te[i]&&(Te[i]=!0,console.warn(r(i," has been deprecated since v"+t+" and will be removed in the near future"))),n?n(s,i,o):!0}};function rr(n,t,e){if(typeof n!="object")throw new TypeError("options must be an object");for(var r=Object.keys(n),s=r.length;s-- >0;){var i=r[s],o=t[i];if(o){var a=n[i],u=a===void 0||o(a,i,n);if(u!==!0)throw new TypeError("option "+i+" must be "+u);continue}if(e!==!0)throw Error("Unknown option "+i)}}var sr={assertOptions:rr,validators:$t},Fe=R,ir=ke,we=kn,be=er,St=He,$e=sr,Y=$e.validators;function rt(n){this.defaults=n,this.interceptors={request:new we,response:new we}}rt.prototype.request=function(n){typeof n=="string"?(n=arguments[1]||{},n.url=arguments[0]):n=n||{},n=St(this.defaults,n),n.method?n.method=n.method.toLowerCase():this.defaults.method?n.method=this.defaults.method.toLowerCase():n.method="get";var t=n.transitional;t!==void 0&&$e.assertOptions(t,{silentJSONParsing:Y.transitional(Y.boolean),forcedJSONParsing:Y.transitional(Y.boolean),clarifyTimeoutError:Y.transitional(Y.boolean)},!1);var e=[],r=!0;this.interceptors.request.forEach(function(h){typeof h.runWhen=="function"&&h.runWhen(n)===!1||(r=r&&h.synchronous,e.unshift(h.fulfilled,h.rejected))});var s=[];this.interceptors.response.forEach(function(h){s.push(h.fulfilled,h.rejected)});var i;if(!r){var o=[be,void 0];for(Array.prototype.unshift.apply(o,e),o=o.concat(s),i=Promise.resolve(n);o.length;)i=i.then(o.shift(),o.shift());return i}for(var a=n;e.length;){var u=e.shift(),c=e.shift();try{a=u(a)}catch(h){c(h);break}}try{i=be(a)}catch(h){return Promise.reject(h)}for(;s.length;)i=i.then(s.shift(),s.shift());return i};rt.prototype.getUri=function(n){return n=St(this.defaults,n),ir(n.url,n.params,n.paramsSerializer).replace(/^\?/,"")};Fe.forEach(["delete","get","head","options"],function(n){rt.prototype[n]=function(t,e){return this.request(St(e||{},{method:n,url:t,data:(e||{}).data}))}});Fe.forEach(["post","put","patch"],function(n){rt.prototype[n]=function(t,e,r){return this.request(St(r||{},{method:n,url:t,data:e}))}});var or=rt,Bt,Ee;function ar(){if(Ee)return Bt;Ee=1;var n=vt();function t(e){if(typeof e!="function")throw new TypeError("executor must be a function.");var r;this.promise=new Promise(function(i){r=i});var s=this;this.promise.then(function(i){if(s._listeners){var o,a=s._listeners.length;for(o=0;o<a;o++)s._listeners[o](i);s._listeners=null}}),this.promise.then=function(i){var o,a=new Promise(function(u){s.subscribe(u),o=u}).then(i);return a.cancel=function(){s.unsubscribe(o)},a},e(function(i){s.reason||(s.reason=new n(i),r(s.reason))})}return t.prototype.throwIfRequested=function(){if(this.reason)throw this.reason},t.prototype.subscribe=function(e){if(this.reason){e(this.reason);return}this._listeners?this._listeners.push(e):this._listeners=[e]},t.prototype.unsubscribe=function(e){if(this._listeners){var r=this._listeners.indexOf(e);r!==-1&&this._listeners.splice(r,1)}},t.source=function(){var e,r=new t(function(s){e=s});return{token:r,cancel:e}},Bt=t,Bt}var Oe,Ae;function ur(){return Ae||(Ae=1,Oe=function(n){return function(t){return n.apply(null,t)}}),Oe}var xe,Pe;function hr(){return Pe||(Pe=1,xe=function(n){return typeof n=="object"&&n.isAxiosError===!0}),xe}var De=R,cr=Be,gt=or,fr=He,pr=_t();function Ge(n){var t=new gt(n),e=cr(gt.prototype.request,t);return De.extend(e,gt.prototype,t),De.extend(e,t),e.create=function(r){return Ge(fr(n,r))},e}var N=Ge(pr);N.Axios=gt;N.Cancel=vt();N.CancelToken=ar();N.isCancel=qe();N.VERSION=Ke().version;N.all=function(n){return Promise.all(n)};N.spread=ur();N.isAxiosError=hr();Ht.exports=N;Ht.exports.default=N;var lr=Ht.exports,gr=lr;const ze=Sn(gr),et=sessionStorage,T={type:function(n){if(!n)return et;if(n&&n==="st")return sessionStorage;if(n&&n==="lt")return localStorage},isAvailable:function(n){var t;try{t=window[n];var e="__storage_test__";return t.setItem(e,e),t.removeItem(e),!0}catch(r){return r instanceof DOMException&&(r.code===22||r.code===1014||r.name==="QuotaExceededError"||r.name==="NS_ERROR_DOM_QUOTA_REACHED")&&t&&t.length!==0}},setStringItem:function(n,t){return typeof t=="string"||typeof t=="number"?(et.setItem(n,t),!0):(console.log(`setStringItem - ${n}-不是String类型-${typeof t}`),!1)},getStringItem:function(n){const t=et.getItem(n);return!t||t=="undefined"?(console.log(`getStringItem - 没有${n}这个缓存`),!1):t},setObjectItem:function(n,t){return typeof t!="object"?!1:(et.setItem(n,JSON.stringify(t)),!0)},getObjectItem:function(n,t=""){const e=et.getItem(n);if(!e)return!1;if(e=="undefined")return console.log(`${e} 没有被正确赋值`),!1;const r=JSON.parse(e);return t?Object.keys(r).indexOf(t)>-1?r[t]:(console.log(`没有对应的key值-${n}##sso`),!1):r}};ze.defaults.withCredentials=!0;const C=ze.create({baseURL:T.getObjectItem("sso","VUE_APP_SSO_DOMAINURL"),withCredentials:!!T.getObjectItem("sso","VUE_APP_AXIOS_CREDENTIALS"),timeout:3e3});C.interceptors.request.use(n=>{n.headers["Content-Type"]="application/x-www-form-urlencoded;charset=UTF-8",n.cType&&(n.headers.userLoginName=n.data.userLoginName);const t=T.getObjectItem(T.getObjectItem("sso","VUE_APP_SSO_SITETOKEN_KEY"),"access_token");return t&&n.params&&(n.params.access_token=t),n},n=>(console.error(n),Promise.reject(n)));C.interceptors.response.use(n=>{let t;if(n.data)return t=n.data,t;{t=n;const{status:e}=t;if(e==200)return t;switch(e){case 302:console.log("API返回-302重定向",t),window.location=t;break;case 400:T.type.clear(),console.error("API返回-400错误");break;case 401:T.type.clear(),console.error("API返回-401错误");break;default:T.type.clear(),console.error("API返回-未定义错误");break}return Promise.reject(t)}},n=>Promise.reject(n));var Re=function(){var n=function(){};return n.prototype.IEVersion=function(){var t=navigator.userAgent,e=t.indexOf("compatible")>-1&&t.indexOf("MSIE")>-1,r=t.indexOf("Edge")>-1&&!e,s=t.indexOf("Trident")>-1&&t.indexOf("rv:11.0")>-1;if(e){var i=new RegExp("MSIE (\\d+\\.\\d+);");i.test(t);var o=parseFloat(RegExp.$1);return o==7?7:o==8?8:o==9?9:o==10?10:6}else return r?"edge":s?11:-1},n.prototype.generateRandomString=function(){var t=new Uint32Array(28);return window.crypto.getRandomValues(t),Array.from(t,e=>("0"+e.toString(16)).substring(-2)).join("")},n.prototype.uuid=()=>"xxxxxxxx-xxxx-4xxx-yxxx-xxxxxxxxxxxx".replace(/[xy]/g,function(t){var e=Math.random()*16|0,r=t=="x"?e:e&3|8;return r.toString(16)}),n.prototype.parseQueryString=function(t){if(t=="")return!1;var e=t.split("&").map(s=>s.split("=")),r={};return e.forEach(s=>r[s[0]]=s[1]),r},new n}(),ft="ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/=";function dr(n){var t=new Array;if(n==null||n=="")return t;t.push(255),t.push(254);for(var e=0;e<n.length;e++){var r=n.charCodeAt(e).toString(16);r.length==1?e="000"+r:r.length==2?r="00"+r:r.length==3&&(r="0"+r);var s=parseInt(r.substring(2),16),i=parseInt(r.substring(0,2),16);t.push(s),t.push(i)}return t}function Ie(n){if(n==null||n=="")return"";n=dr(n);var t="",e,r,s="",i,o,a,u="",c=0;do e=n[c++],r=n[c++],s=n[c++],i=e>>2,o=(e&3)<<4|r>>4,a=(r&15)<<2|s>>6,u=s&63,isNaN(r)?a=u=64:isNaN(s)&&(u=64),t=t+ft.charAt(i)+ft.charAt(o)+ft.charAt(a)+ft.charAt(u),e=r=s="",i=o=a=u="";while(c<n.length);return t}function Ut(n,t){const e=new URL(n,window.location.href),r={};for(const[s,i]of e.searchParams)s!==t&&(r[s]=i);return e.search=new URLSearchParams(r).toString(),e.href}const K=function(){const{log:n,error:t,warn:e}=console;var r=function(){};return r.instant=null,r.prototype.initParams=function(s,i){if(!i||!i.env||!i.env.sso)return t("没有传入sso配置信息"),!1;if(this.ssoInfo=i.env.sso,!this.ssoInfo.hasOwnProperty("VUE_APP_SSO_DOMAINURL"))return t("入口函数(比如main.js)没有获取到env.sso['VUE_APP_SSO_DOMAINURL']参数"),window.alert("重构后,原传入参数【VUE_APP_SSO】更名为【VUE_APP_SSO_DOMAINURL】,请检查!"),!1;if(this.vue_app_sso_domainUrl=this.ssoInfo.VUE_APP_SSO_DOMAINURL,!this.ssoInfo.hasOwnProperty("VUE_APP_SSO_CONTEXT"))return t("入口函数(比如main.js)没有获取到env.sso['VUE_APP_SSO_CONTEXT']参数"),!1;if(this.vue_app_sso_context=this.ssoInfo.VUE_APP_SSO_CONTEXT,!this.ssoInfo.hasOwnProperty("VUE_APP_SSO_AUTHORIZE_URL"))return t("入口函数(比如main.js)没有获取到env.sso['VUE_APP_SSO_AUTHORIZE_URL']参数"),!1;if(this.vue_app_sso_authorize_url=this.ssoInfo.VUE_APP_SSO_AUTHORIZE_URL,!this.ssoInfo.hasOwnProperty("VUE_APP_SSO_LOGOUT_URL"))return t("入口函数(比如main.js)没有获取到env.sso['VUE_APP_SSO_LOGOUT_URL']参数"),window.alert("重构后,原传入参数【VUE_APP_Y9_LOGOUT_URL】更名为【VUE_APP_SSO_LOGOUT_URL】,请检查!"),!1;if(this.vue_app_sso_logout_url=this.ssoInfo.VUE_APP_SSO_LOGOUT_URL,!this.ssoInfo.hasOwnProperty("VUE_APP_SSO_CLIENT_ID"))return t("入口函数(比如main.js)没有获取到env.sso['VUE_APP_SSO_CLIENT_ID']参数"),!1;if(this.vue_app_sso_client_id=this.ssoInfo.VUE_APP_SSO_CLIENT_ID,!this.ssoInfo.hasOwnProperty("VUE_APP_SSO_SECRET"))return t("入口函数(比如main.js)没有获取到env.sso['VUE_APP_SSO_SECRET']参数"),!1;if(this.vue_app_sso_secret=this.ssoInfo.VUE_APP_SSO_SECRET,!this.ssoInfo.hasOwnProperty("VUE_APP_SSO_GRANT_TYPE"))return t("入口函数(比如main.js)没有获取到env.sso['VUE_APP_SSO_GRANT_TYPE']参数"),window.alert("重构后,原传入参数【VUE_APP_GRANT_TYPE】更名为【VUE_APP_SSO_GRANT_TYPE】,请检查!"),!1;if(this.vue_app_sso_grant_type=this.ssoInfo.VUE_APP_SSO_GRANT_TYPE,!this.ssoInfo.hasOwnProperty("VUE_APP_SSO_SITETOKEN_KEY"))return t("入口函数(比如main.js)没有获取到env.sso['VUE_APP_SSO_SITETOKEN_KEY']参数"),window.alert("重构后,原传入参数【VUE_APP_SITETOKEN】更名为【VUE_APP_SSO_SITETOKEN_KEY】,请检查!"),!1;if(this.vue_app_sso_siteTokenKey=this.ssoInfo.VUE_APP_SSO_SITETOKEN_KEY,this.ssoInfo.hasOwnProperty("VUE_APP_APPFEATURES")){if(this.appFeatures=this.ssoInfo.VUE_APP_APPFEATURES,!this.ssoInfo.hasOwnProperty("VUE_APP_LOGIN_PAGE_URL"))return t("特定的登录页面检测, 必须传入sso.env.VUE_APP_LOGIN_PAGE_URL参数"),!1;this.appLoginPageUrl=this.ssoInfo.VUE_APP_LOGIN_PAGE_URL}i.env.hasOwnProperty("logInfo")?(i.env.logInfo.hasOwnProperty("showLog")?this.showLog=!0:this.showLog=!1,i.env.logInfo.hasOwnProperty("sso_refresh_Timer_t")?this.sso_refresh_Timer_t=i.env.logInfo.sso_refresh_Timer_t:this.sso_refresh_Timer_t=18e5):(this.showLog=!1,this.sso_refresh_Timer_t=18e5),this.sso_Timer=null,this.showLog&&(n("Y9SSO对象:"+this),n(`VUE_APP_SSO_DOMAINURL=${this.vue_app_sso_domainUrl}`),n(`VUE_APP_SSO_CONTEXT=${this.vue_app_sso_context}`),n(`VUE_APP_SSO_AUTHORIZE_URL=${this.vue_app_sso_authorize_url}`),n(`VUE_APP_SSO_LOGOUT_URL=${this.vue_app_sso_logout_url}`),n(`VUE_APP_SSO_CLIENT_ID=${this.vue_app_sso_client_id}`),n(`VUE_APP_SSO_SECRET=${this.vue_app_sso_secret}`),n(`VUE_APP_SSO_GRANT_TYPE=${this.vue_app_sso_grant_type}`),n(`VUE_APP_SSO_SITETOKEN_KEY=${this.vue_app_sso_siteTokenKey}`))},r.prototype.ssoTimerRun=async function(){r.instant.sso_Timer?clearInterval(r.instant.sso_Timer):r.instant.sso_Timer=setInterval(async()=>{await r.instant.ssoTimer_refreshToken()},r.instant.sso_refresh_Timer_t)},r.prototype.checkLogin=async function(s=""){let i=Re.parseQueryString(window.location.search.substring(1));const o=T.getObjectItem("query")||{},a=i?Object.assign(o,i):o;T.setObjectItem("query",a);let u=window.location.origin+window.location.pathname;if(!i&&r.instant.appLoginPageUrl&&(s?(r.instant.showLog&&n("使用了独立的单点登陆页面【项目最好别走这个if,多项目集成时容易出问题】"),r.instant.navToLogin(s)):(r.instant.showLog&&n("使用了独立的单点登陆页面"),window.location=r.instant.appLoginPageUrl)),!i&&!r.instant.appLoginPageUrl&&(r.instant.showLog&&n("单点登录服务器上的登陆页面"),r.instant.navToLogin(u)),i&&i.code){const c={grant_type:r.instant.vue_app_sso_grant_type,client_id:r.instant.vue_app_sso_client_id,client_secret:r.instant.vue_app_sso_secret,code:i.code,redirect_uri:u};r.instant.showLog&&n("登录跳转链接中包含code时获取access_token");const h=await r.instant.ssoGetAccessTokenApi({params:c}).then(g=>g).catch(g=>{t("登录跳转链接中包含code时,获取access_token的过程中catch到错误:"+g)});r.instant.showLog&&n(`获取access_token成功,在sessionStorage中查看${r.instant.vue_app_sso_siteTokenKey}`);let d=Date.parse(new Date).toString().slice(0,10);r.instant.showLog&&n(`检查ssoGetAccessTokenApi返回的数据类型${typeof h},数据是${JSON.stringify(h)}`),typeof h!="object"&&(window.location=window.location.href),h.expires_in=h.expires_in-1800,h.count_expires_in=parseInt(d)+parseInt(h.expires_in),T.setObjectItem(r.instant.vue_app_sso_siteTokenKey,h)&&await r.instant.ssoGetUserInfoApi(),r.instant.showLog&&n("删除回调url中的code");let l=window.location.origin+window.location.pathname;history.replaceState({},"",l)}i&&i.ticket&&(u=window.location.href,r.instant.showLog&&n("切换账号"),r.instant.navToLogin(u)),i&&i.itemId&&(u=window.location.href,r.instant.showLog&&n("q.itemId"),r.instant.navToLogin(u)),i&&(r.instant.showLog&&n(`处理任意其它未知参数的情况,q=${JSON.stringify(i)}`),window.location=window.location.origin+window.location.pathname)},r.prototype.navToLogin=function(s){const i=`${r.instant.vue_app_sso_authorize_url}?response_type=code&client_id=${r.instant.vue_app_sso_client_id}&client_secret=${r.instant.vue_app_sso_secret}&state=${Re.generateRandomString()}&scope=all&redirect_uri=${s}`;if(r.instant.showLog&&n(`单点登录 - 传入插件的授权码url=【${r.instant.vue_app_sso_authorize_url}】`),r.instant.showLog&&n(`单点登录 - 拼接授权码的完整url=【${i}】`),r.instant.showLog&&n(`单点登录 - 授权成功后,将要跳转的url=【${s}】`),r.instant.vue_app_sso_authorize_url)window.location=i;else{r.instant.showLog&&n("【重构后测试此if问题是否还存在】");let o=i.split("=");window.location=o[o.length-1]}},r.prototype.ssoLogin=async function(s,i,o,a){const u=await r.instant.getRandom(),c=new _n;c.setPublicKey(u);let h=c.encrypt(Ie(i));const d={tenantShortName:o||"risesoft",username:Ie(s),password:h,pwdEcodeType:u},l=await r.instant.checkSsoLoginInfoApi({params:d}).catch(g=>{t("获取用户输入的用户名和密码开始单点登录的过程中,【checkSsoLoginInfoApi执行catch到错误】 e="+g)});return l.success?(console.log(l),r.instant.showLog&&n(`登陆前的认证成功 ${l}`),d.loginName="loginName",d.noLoginScreen=!0,d.service=a,await r.instant.ssoLoginApi(d).then(async g=>{if(g.success){const _=`${r.instant.vue_app_sso_authorize_url}?response_type=code&client_id=${r.instant.vue_app_sso_client_id}&client_secret=${r.instant.vue_app_sso_secret}&redirect_uri=${a}`;r.instant.showLog&&n("登陆成功"),r.instant.showLog&&n(`拼接获取授权码的完整URL=${_}`),window.location=_}else return r.instant.showLog&&t("登陆失败,请检查用户名和密码,resultInfo="+l),!1}).catch(g=>{t("获取用户输入的用户名和密码开始单点登录的过程中,【ssoLoginApi执行catch到错误】 e="+g)})):(window.alert(l.msg),!1)},r.prototype.getSessionCache=async function(){let s=Date.parse(new Date).toString().slice(0,10),i=T.getObjectItem(r.instant.vue_app_sso_siteTokenKey),o;if(i&&i.refresh_token){o=T.getObjectItem(r.instant.vue_app_sso_siteTokenKey,"count_expires_in");let a=s-o;return a>0&&a<1800&&await r.instant.refreshToken().catch(u=>{t("获取当前会话登陆信息 - 执行refreshToken函数catch错误:"+u)}),!0}else return!1},r.prototype.checkToken=async function(){return await r.instant.getSessionCache()?(T.getStringItem("userName")||await r.instant.ssoGetUserInfoApi(),!0):!1},r.prototype.ssoTimer_refreshToken=async function(){r.instant.showLog&&n("========================================================"),r.instant.showLog&&n(`【${new Date}】sso - 自动执行了定时器`),r.instant.showLog&&n("更新前"),r.instant.showLog&&n(`${r.instant.vue_app_sso_siteTokenKey} = `,T.getObjectItem(r.instant.vue_app_sso_siteTokenKey)),r.instant.showLog&&n("--------------------------------------------------------"),Date.parse(new Date).toString().slice(0,10);let s=T.getObjectItem(r.instant.vue_app_sso_siteTokenKey);s&&s.refresh_token&&(T.getObjectItem(r.instant.vue_app_sso_siteTokenKey,"count_expires_in"),T.getObjectItem(r.instant.vue_app_sso_siteTokenKey,"refresh_token"),await r.instant.refreshToken().catch(i=>n(i.message))),r.instant.showLog&&n("更新后"),r.instant.showLog&&n(`${r.instant.vue_app_sso_siteTokenKey} = `,T.getObjectItem(r.instant.vue_app_sso_siteTokenKey)),r.instant.showLog&&n("========================================================")},r.prototype.refreshToken=async function(){const s=Date.parse(new Date).toString().slice(0,10),i={grant_type:"refresh_token",client_id:r.instant.vue_app_sso_client_id,client_secret:r.instant.vue_app_sso_secret,refresh_token:T.getObjectItem(r.instant.vue_app_sso_siteTokenKey,"refresh_token"),redirect_uri:window.location.href},o=await r.instant.ssoGetAccessTokenApi({params:i}).then(a=>a).catch(a=>{t("更新token的过程中catch到错误:"+a)});return o&&o.expires_in&&(o.expires_in=o.expires_in-1800,o.count_expires_in=parseInt(s)+parseInt(o.expires_in)),T.setObjectItem(r.instant.vue_app_sso_siteTokenKey,o)?!0:(r.instant.showLog&&n("没有成功缓存"),!1)},r.prototype.getLoginNameAndTenants=async function(s){return r.instant.showLog&&n("单点登录 - 【sso-检索用户和租户信息API】得到的参数:",s),await C({url:`${r.instant.vue_app_sso_context}/api/loginNameAndTenants`,method:"post",cType:!1,test:!0,params:s})},r.prototype.getRandom=async function(){let s=await C({url:`${r.instant.vue_app_sso_context}/api/getRandom`,method:"get",cType:!1,test:!0,params:{_:Date.now()}});if(s.success)return s.data;t("获取公钥失败,"+s.msg)},r.prototype.checkSsoLoginInfoApi=async function(s){return r.instant.showLog&&n("单点登录 - 【sso-1-登录前的认证API】得到的参数:",s.params),await C({url:`${r.instant.vue_app_sso_context}/api/checkSsoLoginInfo`,method:"post",cType:!1,test:!0,params:s.params})},r.prototype.ssoLoginApi=async function(s){return r.instant.showLog&&n("单点登录 - 【sso-2-登录API】得到的参数:",s),await C({url:`${r.instant.vue_app_sso_context}/api/logon`,method:"post",cType:!1,test:!0,params:s})},r.prototype.ssoGetAccessTokenApi=async function(s){r.instant.showLog&&n("单点登录 - 【sso-3-获取和更新token API】得到的参数:",s.params);let i=Ut(s.params.redirect_uri,"code"),o=Ut(i,"state"),a=Ut(o,"response");r.instant.showLog&&n("redirect_uri 这个参数中不能有 code state response 这几个参数的处理结果",a);let u=new URLSearchParams;return u.append("grant_type",s.params.grant_type),u.append("client_id",s.params.client_id),u.append("client_secret",s.params.client_secret),s.params.grant_type==="refresh_token"?u.append("refresh_token",s.params.refresh_token):u.append("code",s.params.code),u.append("redirect_uri",a),await C({url:`${r.instant.vue_app_sso_context}/oauth2.0/accessToken`,method:"post",cType:!1,params:u})},r.prototype.ssoGetUserInfoApi=async function(){let s=T.getObjectItem(r.instant.vue_app_sso_siteTokenKey,"access_token");if(!s)return t("单点登录 - 【sso-4-获取用户的信息 API】没有获取到access_token参数"),!1;r.instant.showLog&&n("单点登录 - 【sso-4-获取用户的信息 API】access_token = ",s);let i=await C({url:`${r.instant.vue_app_sso_context}/oauth2.0/profile`,method:"get",cType:!1,params:{access_token:s}});return T.setObjectItem("ssoUserInfo",i),T.setStringItem("userName",i.name),i},r.prototype.ssoLogout=async function(s){r.instant.showLog&&n(`登出,传入的obj = ${JSON.stringify(s)}`);let i=`${r.instant.vue_app_sso_domainUrl}/sso/logout?service=${window.location.origin}/`;s.logoutUrl?(i=s.logoutUrl,r.instant.showLog&&n(`执行了【传入的】登出URL=${s.logoutUrl}`)):r.instant.showLog&&n(`执行了【默认的】登出URL=${i}`),s.__y9delete__&&(await s.__y9delete__(),r.instant.showLog&&n("执行了自定义的删除函数(事件)obj.__y9delete__"));let o=sessionStorage.getItem("sso");sessionStorage.clear(),r.instant.showLog&&n("登出时执行了【缓存清除语句】==> sessionStorage.clear()"),sessionStorage.setItem("sso",o),r.instant.showLog&&n("如果没有关闭会话页面,这里恢复了要传入sso插件的参数"),window.location=i},r.instant||(r.instant=new r),r.instant}();function mr(n,t){T.setObjectItem("sso",t.env.sso),K.initParams(n,t),K.ssoTimerRun(),n.$y9_SSO={checkLogin:K.checkLogin,checkToken:K.checkToken,ssoLogout:K.ssoLogout,ssoLogin:K.ssoLogin,getLoginNameAndTenants:K.getLoginNameAndTenants}}export{mr as y};
|