@ray-js/wechat-rsa 0.0.1-beta-1 → 0.0.2-beta-2

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (4) hide show
  1. package/index.esm.js +1 -3704
  2. package/index.js +1 -0
  3. package/package.json +1 -1
  4. package/index..js +0 -3709
package/index.js ADDED
@@ -0,0 +1 @@
1
+ "use strict";Object.defineProperty(exports,"__esModule",{value:!0});function t(t){return"0123456789abcdefghijklmnopqrstuvwxyz".charAt(t)}function s(t,s){return t&s}function e(t,s){return t|s}function i(t,s){return t^s}function r(t,s){return t&~s}function n(t){if(0==t)return-1;let s=0;return 0==(65535&t)&&(t>>=16,s+=16),0==(255&t)&&(t>>=8,s+=8),0==(15&t)&&(t>>=4,s+=4),0==(3&t)&&(t>>=2,s+=2),0==(1&t)&&++s,s}function h(t){let s=0;for(;0!=t;)t&=t-1,++s;return s}const o="ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/";let u;const l={decode(t){let s;if(void 0===u){let t="0123456789ABCDEF";const e=" \f\n\r\t \u2028\u2029";for(u={},s=0;s<16;++s)u[t.charAt(s)]=s;for(t=t.toLowerCase(),s=10;s<16;++s)u[t.charAt(s)]=s;for(s=0;s<e.length;++s)u[e.charAt(s)]=-1}const e=[];let i=0,r=0;for(s=0;s<t.length;++s){let n=t.charAt(s);if("="==n)break;if(n=u[n],-1!=n){if(void 0===n)throw new Error("Illegal character at offset "+s);i|=n,++r>=2?(e[e.length]=i,i=0,r=0):i<<=4}}if(r)throw new Error("Hex encoding incomplete: 4 bits missing");return e}};let a;const c={decode(t){let s;if(void 0===a){const t="ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/",e="= \f\n\r\t \u2028\u2029";for(a=Object.create(null),s=0;s<64;++s)a[t.charAt(s)]=s;for(a["-"]=62,a._=63,s=0;s<e.length;++s)a[e.charAt(s)]=-1}const e=[];let i=0,r=0;for(s=0;s<t.length;++s){let n=t.charAt(s);if("="==n)break;if(n=a[n],-1!=n){if(void 0===n)throw new Error("Illegal character at offset "+s);i|=n,++r>=4?(e[e.length]=i>>16,e[e.length]=i>>8&255,e[e.length]=255&i,i=0,r=0):i<<=6}}switch(r){case 1:throw new Error("Base64 encoding incomplete: at least 2 bits missing");case 2:e[e.length]=i>>10;break;case 3:e[e.length]=i>>16,e[e.length]=i>>8&255}return e},re:/-----BEGIN [^-]+-----([A-Za-z0-9+\/=\s]+)-----END [^-]+-----|begin-base64[^\n]+\n([A-Za-z0-9+\/=\s]+)====/,unarmor(t){const s=c.re.exec(t);if(s)if(s[1])t=s[1];else{if(!s[2])throw new Error("RegExp out of sync");t=s[2]}return c.decode(t)}},f=1e13;class m{constructor(t){this.buf=[t?+t:0]}mulAdd(t,s){const e=this.buf,i=e.length;let r,n;for(r=0;r<i;++r)n=e[r]*t+s,n<f?s=0:n-=(s=0|n/f)*f,e[r]=n;s>0&&(e[r]=s)}sub(t){const s=this.buf,e=s.length;let i,r;for(i=0;i<e;++i)r=s[i]-t,r<0?(r+=f,t=1):t=0,s[i]=r;for(;0===s[s.length-1];)s.pop()}toString(t){if(10!=(t||10))throw new Error("only base 10 is supported");const s=this.buf;let e=s[s.length-1].toString();for(let t=s.length-2;t>=0;--t)e+=(f+s[t]).toString().substring(1);return e}valueOf(){const t=this.buf;let s=0;for(let e=t.length-1;e>=0;--e)s=s*f+t[e];return s}simplify(){const t=this.buf;return 1==t.length?t[0]:this}}const g=/^(\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)?)?$/,d=/^(\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 p(t,s){return t.length>s&&(t=t.substring(0,s)+"…"),t}class T{constructor(t,s){this.hexDigits="0123456789ABCDEF",t instanceof T?(this.enc=t.enc,this.pos=t.pos):(this.enc=t,this.pos=s||0)}get(t){if(void 0===t&&(t=this.pos++),t>=this.enc.length)throw new Error(`Requesting byte offset ${t} on a stream of length ${this.enc.length}`);return"string"==typeof this.enc?this.enc.charCodeAt(t):this.enc[t]}hexByte(t){return this.hexDigits.charAt(t>>4&15)+this.hexDigits.charAt(15&t)}hexDump(t,s,e){let i="";for(let r=t;r<s;++r)if(i+=this.hexByte(this.get(r)),!0!==e)switch(15&r){case 7:i+=" ";break;case 15:i+="\n";break;default:i+=" "}return i}isASCII(t,s){for(let e=t;e<s;++e){const t=this.get(e);if(t<32||t>176)return!1}return!0}parseStringISO(t,s){let e="";for(let i=t;i<s;++i)e+=String.fromCharCode(this.get(i));return e}parseStringUTF(t,s){let e="";for(let i=t;i<s;){const t=this.get(i++);e+=t<128?String.fromCharCode(t):t>191&&t<224?String.fromCharCode((31&t)<<6|63&this.get(i++)):String.fromCharCode((15&t)<<12|(63&this.get(i++))<<6|63&this.get(i++))}return e}parseStringBMP(t,s){let e,i,r="";for(let n=t;n<s;)e=this.get(n++),i=this.get(n++),r+=String.fromCharCode(e<<8|i);return r}parseTime(t,s,e){let i=this.parseStringISO(t,s);const r=(e?g:d).exec(i);return r?(e&&(r[1]=+r[1],r[1]+=+r[1]<70?2e3:1900),i=r[1]+"-"+r[2]+"-"+r[3]+" "+r[4],r[5]&&(i+=":"+r[5],r[6]&&(i+=":"+r[6],r[7]&&(i+="."+r[7]))),r[8]&&(i+=" UTC","Z"!=r[8]&&(i+=r[8],r[9]&&(i+=":"+r[9]))),i):"Unrecognized time: "+i}parseInteger(t,s){let e=this.get(t);const i=e>127,r=i?255:0;let n,h="";for(;e==r&&++t<s;)e=this.get(t);if(n=s-t,0===n)return i?-1:0;if(n>4){for(h=e,n<<=3;0==(128&(+h^r));)h=+h<<1,--n;h="("+n+" bit)\n"}i&&(e-=256);const o=new m(e);for(let e=t+1;e<s;++e)o.mulAdd(256,this.get(e));return h+o.toString()}parseBitString(t,s,e){const i=this.get(t),r="("+((s-t-1<<3)-i)+" bit)\n";let n="";for(let h=t+1;h<s;++h){const t=this.get(h),o=h==s-1?i:0;for(let s=7;s>=o;--s)n+=t>>s&1?"1":"0";if(n.length>e)return r+p(n,e)}return r+n}parseOctetString(t,s,e){if(this.isASCII(t,s))return p(this.parseStringISO(t,s),e);const i=s-t;let r="("+i+" byte)\n";i>(e/=2)&&(s=t+e);for(let e=t;e<s;++e)r+=this.hexByte(this.get(e));return i>e&&(r+="…"),r}parseOID(t,s,e){let i="",r=new m,n=0;for(let h=t;h<s;++h){const t=this.get(h);if(r.mulAdd(128,127&t),n+=7,!(128&t)){if(""===i)if(r=r.simplify(),r instanceof m)r.sub(80),i="2."+r.toString();else{const t=r<80?r<40?0:1:2;i=t+"."+(r-40*t)}else i+="."+r.toString();if(i.length>e)return p(i,e);r=new m,n=0}}return n>0&&(i+=".incomplete"),i}}class b{constructor(t,s,e,i,r){if(!(i instanceof S))throw new Error("Invalid tag value.");this.stream=t,this.header=s,this.length=e,this.tag=i,this.sub=r}typeName(){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();default:return}}content(t){if(void 0===this.tag)return null;void 0===t&&(t=1/0);const s=this.posContent(),e=Math.abs(this.length);if(!this.tag.isUniversal())return null!==this.sub?"("+this.sub.length+" elem)":this.stream.parseOctetString(s,s+e,t);switch(this.tag.tagNumber){case 1:return 0===this.stream.get(s)?"false":"true";case 2:return this.stream.parseInteger(s,s+e);case 3:return this.sub?"("+this.sub.length+" elem)":this.stream.parseBitString(s,s+e,t);case 4:return this.sub?"("+this.sub.length+" elem)":this.stream.parseOctetString(s,s+e,t);case 6:return this.stream.parseOID(s,s+e,t);case 16:case 17:return null!==this.sub?"("+this.sub.length+" elem)":"(no elem)";case 12:return p(this.stream.parseStringUTF(s,s+e),t);case 18:case 19:case 20:case 21:case 22:case 26:return p(this.stream.parseStringISO(s,s+e),t);case 30:return p(this.stream.parseStringBMP(s,s+e),t);case 23:case 24:return this.stream.parseTime(s,s+e,23==this.tag.tagNumber)}return null}toString(){return this.typeName()+"@"+this.stream.pos+"[header:"+this.header+",length:"+this.length+",sub:"+(null===this.sub?"null":this.sub.length)+"]"}toPrettyString(t){void 0===t&&(t="");let s=t+this.typeName()+" @"+this.stream.pos;if(this.length>=0&&(s+="+"),s+=this.length,this.tag.tagConstructed?s+=" (constructed)":!this.tag.isUniversal()||3!=this.tag.tagNumber&&4!=this.tag.tagNumber||null===this.sub||(s+=" (encapsulates)"),s+="\n",null!==this.sub){t+=" ";for(let e=0,i=this.sub.length;e<i;++e)s+=this.sub[e].toPrettyString(t)}return s}posStart(){return this.stream.pos}posContent(){return this.stream.pos+this.header}posEnd(){return this.stream.pos+this.header+Math.abs(this.length)}toHexString(){return this.stream.hexDump(this.posStart(),this.posEnd(),!0)}static decodeLength(t){let s=t.get();const e=127&s;if(e==s)return e;if(e>6)throw new Error("Length over 48 bits not supported at position "+(t.pos-1));if(0===e)return null;s=0;for(let i=0;i<e;++i)s=256*s+t.get();return s}getHexStringValue(){const t=this.toHexString(),s=2*this.header,e=2*this.length;return t.substr(s,e)}static decode(t){let s;s=t instanceof T?t:new T(t,0);const e=new T(s),i=new S(s);let r=b.decodeLength(s);const n=s.pos,h=n-e.pos;let o=null;const u=function(){const t=[];if(null!==r){const e=n+r;for(;s.pos<e;)t[t.length]=b.decode(s);if(s.pos!=e)throw new Error("Content size is not correct for container starting at offset "+n)}else try{for(;;){const e=b.decode(s);if(e.tag.isEOC())break;t[t.length]=e}r=n-s.pos}catch(t){throw new Error("Exception while decoding undefined length content: "+t)}return t};if(i.tagConstructed)o=u();else if(i.isUniversal()&&(3==i.tagNumber||4==i.tagNumber))try{if(3==i.tagNumber&&0!=s.get())throw new Error("BIT STRINGs with unused bits cannot encapsulate.");o=u();for(let t=0;t<o.length;++t)if(o[t].tag.isEOC())throw new Error("EOC is not supposed to be actual content.")}catch(t){o=null}if(null===r)throw new Error("We can't skip over an invalid tag with undefined length at offset "+n);if(null===o){if(null===r)throw new Error("We can't skip over an invalid tag with undefined length at offset "+n);s.pos=n+Math.abs(r)}return new b(e,h,r,i,o)}}class S{constructor(t){let s=t.get();if(this.tagClass=s>>6,this.tagConstructed=0!=(32&s),this.tagNumber=31&s,31==this.tagNumber){const e=new m;do{s=t.get(),e.mulAdd(128,127&s)}while(128&s);this.tagNumber=e.simplify()}}isUniversal(){return 0===this.tagClass}isEOC(){return 0===this.tagClass&&0===this.tagNumber}}let w;const E="undefined"!=typeof navigator,y=E&&"Microsoft Internet Explorer"===navigator.appName,D=E&&"Netscape"!==navigator.appName||"undefined"!=typeof wx;w=y?30:D?26:28;const B=[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],v=(1<<26)/B[B.length-1];class N{constructor(t,s,e){this.DB=w,this.DM=(1<<w)-1,this.DV=1<<w,this.FV=Math.pow(2,52),this.F1=52-w,this.F2=2*w-52,null!=t&&("number"==typeof t?void 0!==s&&this.fromNumber(t,s,e):null==s&&"string"!=typeof t?this.fromString(t,256):this.fromString(t,s))}toString(s){if(this.s<0)return"-"+this.negate().toString(s);let e;if(16==s)e=4;else if(8==s)e=3;else if(2==s)e=1;else if(32==s)e=5;else{if(4!=s)return this.toRadix(s);e=2}const i=(1<<e)-1;let r,n=!1,h="",o=this.t,u=this.DB-o*this.DB%e;if(o-- >0)for(u<this.DB&&(r=this[o]>>u)>0&&(n=!0,h=t(r));o>=0;)u<e?(r=(this[o]&(1<<u)-1)<<e-u,r|=this[--o]>>(u+=this.DB-e)):(r=this[o]>>(u-=e)&i,u<=0&&(u+=this.DB,--o)),r>0&&(n=!0),n&&(h+=t(r));return n?h:"0"}negate(){const t=M();return N.ZERO.subTo(this,t),t}abs(){return this.s<0?this.negate():this}compareTo(t){let s=this.s-t.s;if(0!=s)return s;let e=this.t;if(s=e-t.t,0!=s)return this.s<0?-s:s;for(;--e>=0;)if(0!=(s=this[e]-t[e]))return s;return 0}bitLength(){return this.t<=0?0:this.DB*(this.t-1)+k(this[this.t-1]^this.s&this.DM)}mod(t){const s=M();return this.abs().divRemTo(t,null,s),this.s<0&&s.compareTo(N.ZERO)>0&&t.subTo(s,s),s}modPowInt(t,s){let e;return e=t<256||s.isEven()?new A(s):new x(s),this.exp(t,e)}clone(){const t=M();return this.copyTo(t),t}intValue(){if(this.s<0){if(1==this.t)return this[0]-this.DV;if(0==this.t)return-1}else{if(1==this.t)return this[0];if(0==this.t)return 0}return(this[1]&(1<<32-this.DB)-1)<<this.DB|this[0]}byteValue(){return 0==this.t?this.s:this[0]<<24>>24}shortValue(){return 0==this.t?this.s:this[0]<<16>>16}signum(){return this.s<0?-1:this.t<=0||1==this.t&&this[0]<=0?0:1}toByteArray(){let t=this.t;const s=[];s[0]=this.s;let e,i=this.DB-t*this.DB%8,r=0;if(t-- >0)for(i<this.DB&&(e=this[t]>>i)!=(this.s&this.DM)>>i&&(s[r++]=e|this.s<<this.DB-i);t>=0;)i<8?(e=(this[t]&(1<<i)-1)<<8-i,e|=this[--t]>>(i+=this.DB-8)):(e=this[t]>>(i-=8)&255,i<=0&&(i+=this.DB,--t)),0!=(128&e)&&(e|=-256),0==r&&(128&this.s)!=(128&e)&&++r,(r>0||e!=this.s)&&(s[r++]=e);return s}equals(t){return 0==this.compareTo(t)}min(t){return this.compareTo(t)<0?this:t}max(t){return this.compareTo(t)>0?this:t}and(t){const e=M();return this.bitwiseTo(t,s,e),e}or(t){const s=M();return this.bitwiseTo(t,e,s),s}xor(t){const s=M();return this.bitwiseTo(t,i,s),s}andNot(t){const s=M();return this.bitwiseTo(t,r,s),s}not(){const t=M();for(let s=0;s<this.t;++s)t[s]=this.DM&~this[s];return t.t=this.t,t.s=~this.s,t}shiftLeft(t){const s=M();return t<0?this.rShiftTo(-t,s):this.lShiftTo(t,s),s}shiftRight(t){const s=M();return t<0?this.lShiftTo(-t,s):this.rShiftTo(t,s),s}getLowestSetBit(){for(let t=0;t<this.t;++t)if(0!=this[t])return t*this.DB+n(this[t]);return this.s<0?this.t*this.DB:-1}bitCount(){let t=0;const s=this.s&this.DM;for(let e=0;e<this.t;++e)t+=h(this[e]^s);return t}testBit(t){const s=Math.floor(t/this.DB);return s>=this.t?0!=this.s:0!=(this[s]&1<<t%this.DB)}setBit(t){return this.changeBit(t,e)}clearBit(t){return this.changeBit(t,r)}flipBit(t){return this.changeBit(t,i)}add(t){const s=M();return this.addTo(t,s),s}subtract(t){const s=M();return this.subTo(t,s),s}multiply(t){const s=M();return this.multiplyTo(t,s),s}divide(t){const s=M();return this.divRemTo(t,s,null),s}remainder(t){const s=M();return this.divRemTo(t,null,s),s}divideAndRemainder(t){const s=M(),e=M();return this.divRemTo(t,s,e),[s,e]}modPow(t,s){let e,i,r=t.bitLength(),n=L(1);if(r<=0)return n;e=r<18?1:r<48?3:r<144?4:r<768?5:6,i=r<8?new A(s):s.isEven()?new I(s):new x(s);const h=[];let o=3;const u=e-1,l=(1<<e)-1;if(h[1]=i.convert(this),e>1){const t=M();for(i.sqrTo(h[1],t);o<=l;)h[o]=M(),i.mulTo(t,h[o-2],h[o]),o+=2}let a,c,f=t.t-1,m=!0,g=M();for(r=k(t[f])-1;f>=0;){for(r>=u?a=t[f]>>r-u&l:(a=(t[f]&(1<<r+1)-1)<<u-r,f>0&&(a|=t[f-1]>>this.DB+r-u)),o=e;0==(1&a);)a>>=1,--o;if((r-=o)<0&&(r+=this.DB,--f),m)h[a].copyTo(n),m=!1;else{for(;o>1;)i.sqrTo(n,g),i.sqrTo(g,n),o-=2;o>0?i.sqrTo(n,g):(c=n,n=g,g=c),i.mulTo(g,h[a],n)}for(;f>=0&&0==(t[f]&1<<r);)i.sqrTo(n,g),c=n,n=g,g=c,--r<0&&(r=this.DB-1,--f)}return i.revert(n)}modInverse(t){const s=t.isEven();if(this.isEven()&&s||0==t.signum())return N.ZERO;const e=t.clone(),i=this.clone(),r=L(1),n=L(0),h=L(0),o=L(1);for(;0!=e.signum();){for(;e.isEven();)e.rShiftTo(1,e),s?(r.isEven()&&n.isEven()||(r.addTo(this,r),n.subTo(t,n)),r.rShiftTo(1,r)):n.isEven()||n.subTo(t,n),n.rShiftTo(1,n);for(;i.isEven();)i.rShiftTo(1,i),s?(h.isEven()&&o.isEven()||(h.addTo(this,h),o.subTo(t,o)),h.rShiftTo(1,h)):o.isEven()||o.subTo(t,o),o.rShiftTo(1,o);e.compareTo(i)>=0?(e.subTo(i,e),s&&r.subTo(h,r),n.subTo(o,n)):(i.subTo(e,i),s&&h.subTo(r,h),o.subTo(n,o))}return 0!=i.compareTo(N.ONE)?N.ZERO:o.compareTo(t)>=0?o.subtract(t):o.signum()<0?(o.addTo(t,o),o.signum()<0?o.add(t):o):o}pow(t){return this.exp(t,new O)}gcd(t){let s=this.s<0?this.negate():this.clone(),e=t.s<0?t.negate():t.clone();if(s.compareTo(e)<0){const t=s;s=e,e=t}let i=s.getLowestSetBit(),r=e.getLowestSetBit();if(r<0)return s;for(i<r&&(r=i),r>0&&(s.rShiftTo(r,s),e.rShiftTo(r,e));s.signum()>0;)(i=s.getLowestSetBit())>0&&s.rShiftTo(i,s),(i=e.getLowestSetBit())>0&&e.rShiftTo(i,e),s.compareTo(e)>=0?(s.subTo(e,s),s.rShiftTo(1,s)):(e.subTo(s,e),e.rShiftTo(1,e));return r>0&&e.lShiftTo(r,e),e}isProbablePrime(t){let s;const e=this.abs();if(1==e.t&&e[0]<=B[B.length-1]){for(s=0;s<B.length;++s)if(e[0]==B[s])return!0;return!1}if(e.isEven())return!1;for(s=1;s<B.length;){let t=B[s],i=s+1;for(;i<B.length&&t<v;)t*=B[i++];for(t=e.modInt(t);s<i;)if(t%B[s++]==0)return!1}return e.millerRabin(t)}copyTo(t){for(let s=this.t-1;s>=0;--s)t[s]=this[s];t.t=this.t,t.s=this.s}fromInt(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}fromString(t,s){let e;if(16==s)e=4;else if(8==s)e=3;else if(256==s)e=8;else if(2==s)e=1;else if(32==s)e=5;else{if(4!=s)return void this.fromRadix(t,s);e=2}this.t=0,this.s=0;let i=t.length,r=!1,n=0;for(;--i>=0;){const s=8==e?255&+t[i]:V(t,i);s<0?"-"==t.charAt(i)&&(r=!0):(r=!1,0==n?this[this.t++]=s:n+e>this.DB?(this[this.t-1]|=(s&(1<<this.DB-n)-1)<<n,this[this.t++]=s>>this.DB-n):this[this.t-1]|=s<<n,n+=e,n>=this.DB&&(n-=this.DB))}8==e&&0!=(128&+t[0])&&(this.s=-1,n>0&&(this[this.t-1]|=(1<<this.DB-n)-1<<n)),this.clamp(),r&&N.ZERO.subTo(this,this)}clamp(){const t=this.s&this.DM;for(;this.t>0&&this[this.t-1]==t;)--this.t}dlShiftTo(t,s){let e;for(e=this.t-1;e>=0;--e)s[e+t]=this[e];for(e=t-1;e>=0;--e)s[e]=0;s.t=this.t+t,s.s=this.s}drShiftTo(t,s){for(let e=t;e<this.t;++e)s[e-t]=this[e];s.t=Math.max(this.t-t,0),s.s=this.s}lShiftTo(t,s){const e=t%this.DB,i=this.DB-e,r=(1<<i)-1,n=Math.floor(t/this.DB);let h=this.s<<e&this.DM;for(let t=this.t-1;t>=0;--t)s[t+n+1]=this[t]>>i|h,h=(this[t]&r)<<e;for(let t=n-1;t>=0;--t)s[t]=0;s[n]=h,s.t=this.t+n+1,s.s=this.s,s.clamp()}rShiftTo(t,s){s.s=this.s;const e=Math.floor(t/this.DB);if(e>=this.t)return void(s.t=0);const i=t%this.DB,r=this.DB-i,n=(1<<i)-1;s[0]=this[e]>>i;for(let t=e+1;t<this.t;++t)s[t-e-1]|=(this[t]&n)<<r,s[t-e]=this[t]>>i;i>0&&(s[this.t-e-1]|=(this.s&n)<<r),s.t=this.t-e,s.clamp()}subTo(t,s){let e=0,i=0;const r=Math.min(t.t,this.t);for(;e<r;)i+=this[e]-t[e],s[e++]=i&this.DM,i>>=this.DB;if(t.t<this.t){for(i-=t.s;e<this.t;)i+=this[e],s[e++]=i&this.DM,i>>=this.DB;i+=this.s}else{for(i+=this.s;e<t.t;)i-=t[e],s[e++]=i&this.DM,i>>=this.DB;i-=t.s}s.s=i<0?-1:0,i<-1?s[e++]=this.DV+i:i>0&&(s[e++]=i),s.t=e,s.clamp()}multiplyTo(t,s){const e=this.abs(),i=t.abs();let r=e.t;for(s.t=r+i.t;--r>=0;)s[r]=0;for(r=0;r<i.t;++r)s[r+e.t]=e.am(0,i[r],s,r,0,e.t);s.s=0,s.clamp(),this.s!=t.s&&N.ZERO.subTo(s,s)}squareTo(t){const s=this.abs();let e=t.t=2*s.t;for(;--e>=0;)t[e]=0;for(e=0;e<s.t-1;++e){const i=s.am(e,s[e],t,2*e,0,1);(t[e+s.t]+=s.am(e+1,2*s[e],t,2*e+1,i,s.t-e-1))>=s.DV&&(t[e+s.t]-=s.DV,t[e+s.t+1]=1)}t.t>0&&(t[t.t-1]+=s.am(e,s[e],t,2*e,0,1)),t.s=0,t.clamp()}divRemTo(t,s,e){const i=t.abs();if(i.t<=0)return;const r=this.abs();if(r.t<i.t)return null!=s&&s.fromInt(0),void(null!=e&&this.copyTo(e));null==e&&(e=M());const n=M(),h=this.s,o=t.s,u=this.DB-k(i[i.t-1]);u>0?(i.lShiftTo(u,n),r.lShiftTo(u,e)):(i.copyTo(n),r.copyTo(e));const l=n.t,a=n[l-1];if(0==a)return;const c=a*(1<<this.F1)+(l>1?n[l-2]>>this.F2:0),f=this.FV/c,m=(1<<this.F1)/c,g=1<<this.F2;let d=e.t,p=d-l;const T=null==s?M():s;for(n.dlShiftTo(p,T),e.compareTo(T)>=0&&(e[e.t++]=1,e.subTo(T,e)),N.ONE.dlShiftTo(l,T),T.subTo(n,n);n.t<l;)n[n.t++]=0;for(;--p>=0;){let t=e[--d]==a?this.DM:Math.floor(e[d]*f+(e[d-1]+g)*m);if((e[d]+=n.am(0,t,e,p,0,l))<t)for(n.dlShiftTo(p,T),e.subTo(T,e);e[d]<--t;)e.subTo(T,e)}null!=s&&(e.drShiftTo(l,s),h!=o&&N.ZERO.subTo(s,s)),e.t=l,e.clamp(),u>0&&e.rShiftTo(u,e),h<0&&N.ZERO.subTo(e,e)}invDigit(){if(this.t<1)return 0;const t=this[0];if(0==(1&t))return 0;let s=3&t;return s=s*(2-(15&t)*s)&15,s=s*(2-(255&t)*s)&255,s=s*(2-((65535&t)*s&65535))&65535,s=s*(2-t*s%this.DV)%this.DV,s>0?this.DV-s:-s}isEven(){return 0==(this.t>0?1&this[0]:this.s)}exp(t,s){if(t>4294967295||t<1)return N.ONE;let e=M(),i=M();const r=s.convert(this);let n=k(t)-1;for(r.copyTo(e);--n>=0;)if(s.sqrTo(e,i),(t&1<<n)>0)s.mulTo(i,r,e);else{const t=e;e=i,i=t}return s.revert(e)}chunkSize(t){return Math.floor(Math.LN2*this.DB/Math.log(t))}toRadix(t){if(null==t&&(t=10),0==this.signum()||t<2||t>36)return"0";const s=this.chunkSize(t),e=Math.pow(t,s),i=L(e),r=M(),n=M();let h="";for(this.divRemTo(i,r,n);r.signum()>0;)h=(e+n.intValue()).toString(t).substr(1)+h,r.divRemTo(i,r,n);return n.intValue().toString(t)+h}fromRadix(t,s){this.fromInt(0),null==s&&(s=10);const e=this.chunkSize(s),i=Math.pow(s,e);let r=!1,n=0,h=0;for(let o=0;o<t.length;++o){const u=V(t,o);u<0?"-"==t.charAt(o)&&0==this.signum()&&(r=!0):(h=s*h+u,++n>=e&&(this.dMultiply(i),this.dAddOffset(h,0),n=0,h=0))}n>0&&(this.dMultiply(Math.pow(s,n)),this.dAddOffset(h,0)),r&&N.ZERO.subTo(this,this)}fromNumber(t,s,i){if("number"==typeof s)if(t<2)this.fromInt(1);else for(void 0!==i&&this.fromNumber(t,i),this.testBit(t-1)||this.bitwiseTo(N.ONE.shiftLeft(t-1),e,this),this.isEven()&&this.dAddOffset(1,0);!this.isProbablePrime(s);)this.dAddOffset(2,0),this.bitLength()>t&&this.subTo(N.ONE.shiftLeft(t-1),this);else{const e=[],i=7&t;e.length=1+(t>>3),s.nextBytes(e),i>0?e[0]&=(1<<i)-1:e[0]=0,this.fromString(e,256)}}bitwiseTo(t,s,e){let i,r;const n=Math.min(t.t,this.t);for(i=0;i<n;++i)e[i]=s(this[i],t[i]);if(t.t<this.t){for(r=t.s&this.DM,i=n;i<this.t;++i)e[i]=s(this[i],r);e.t=this.t}else{for(r=this.s&this.DM,i=n;i<t.t;++i)e[i]=s(r,t[i]);e.t=t.t}e.s=s(this.s,t.s),e.clamp()}changeBit(t,s){const e=N.ONE.shiftLeft(t);return this.bitwiseTo(e,s,e),e}addTo(t,s){let e=0,i=0;const r=Math.min(t.t,this.t);for(;e<r;)i+=this[e]+t[e],s[e++]=i&this.DM,i>>=this.DB;if(t.t<this.t){for(i+=t.s;e<this.t;)i+=this[e],s[e++]=i&this.DM,i>>=this.DB;i+=this.s}else{for(i+=this.s;e<t.t;)i+=t[e],s[e++]=i&this.DM,i>>=this.DB;i+=t.s}s.s=i<0?-1:0,i>0?s[e++]=i:i<-1&&(s[e++]=this.DV+i),s.t=e,s.clamp()}dMultiply(t){this[this.t]=this.am(0,t-1,this,0,0,this.t),++this.t,this.clamp()}dAddOffset(t,s){if(0!=t){for(;this.t<=s;)this[this.t++]=0;for(this[s]+=t;this[s]>=this.DV;)this[s]-=this.DV,++s>=this.t&&(this[this.t++]=0),++this[s]}}multiplyLowerTo(t,s,e){let i=Math.min(this.t+t.t,s);for(e.s=0,e.t=i;i>0;)e[--i]=0;for(const s=e.t-this.t;i<s;++i)e[i+this.t]=this.am(0,t[i],e,i,0,this.t);for(const r=Math.min(t.t,s);i<r;++i)this.am(0,t[i],e,i,0,s-i);e.clamp()}multiplyUpperTo(t,s,e){--s;let i=e.t=this.t+t.t-s;for(e.s=0;--i>=0;)e[i]=0;for(i=Math.max(s-this.t,0);i<t.t;++i)e[this.t+i-s]=this.am(s-i,t[i],e,0,0,this.t+i-s);e.clamp(),e.drShiftTo(1,e)}modInt(t){if(t<=0)return 0;const s=this.DV%t;let e=this.s<0?t-1:0;if(this.t>0)if(0==s)e=this[0]%t;else for(let i=this.t-1;i>=0;--i)e=(s*e+this[i])%t;return e}millerRabin(t){const s=this.subtract(N.ONE),e=s.getLowestSetBit();if(e<=0)return!1;const i=s.shiftRight(e);(t=t+1>>1)>B.length&&(t=B.length);const r=M();for(let n=0;n<t;++n){r.fromInt(B[Math.floor(Math.random()*B.length)]);let t=r.modPow(i,this);if(0!=t.compareTo(N.ONE)&&0!=t.compareTo(s)){let i=1;for(;i++<e&&0!=t.compareTo(s);)if(t=t.modPowInt(2,this),0==t.compareTo(N.ONE))return!1;if(0!=t.compareTo(s))return!1}}return!0}square(){const t=M();return this.squareTo(t),t}gcda(t,s){let e=this.s<0?this.negate():this.clone(),i=t.s<0?t.negate():t.clone();if(e.compareTo(i)<0){const t=e;e=i,i=t}let r=e.getLowestSetBit(),n=i.getLowestSetBit();if(n<0)return void s(e);r<n&&(n=r),n>0&&(e.rShiftTo(n,e),i.rShiftTo(n,i));setTimeout((function t(){(r=e.getLowestSetBit())>0&&e.rShiftTo(r,e),(r=i.getLowestSetBit())>0&&i.rShiftTo(r,i),e.compareTo(i)>=0?(e.subTo(i,e),e.rShiftTo(1,e)):(i.subTo(e,i),i.rShiftTo(1,i)),e.signum()>0?setTimeout(t,0):(n>0&&i.lShiftTo(n,i),setTimeout((function(){s(i)}),0))}),10)}fromNumberAsync(t,s,i,r){if("number"==typeof s)if(t<2)this.fromInt(1);else{this.fromNumber(t,i),this.testBit(t-1)||this.bitwiseTo(N.ONE.shiftLeft(t-1),e,this),this.isEven()&&this.dAddOffset(1,0);const n=()=>{this.dAddOffset(2,0),this.bitLength()>t&&this.subTo(N.ONE.shiftLeft(t-1),this),this.isProbablePrime(s)?setTimeout((function(){r()}),0):setTimeout(n,0)};setTimeout(n,0)}else{const e=[],i=7&t;e.length=1+(t>>3),s.nextBytes(e),i>0?e[0]&=(1<<i)-1:e[0]=0,this.fromString(e,256)}}am(t,s,e,i,r,n){if(y){const h=32767&s,o=s>>15;for(;--n>=0;){let s=32767&this[t];const n=this[t++]>>15,u=o*s+n*h;s=h*s+((32767&u)<<15)+e[i]+(1073741823&r),r=(s>>>30)+(u>>>15)+o*n+(r>>>30),e[i++]=1073741823&s}return r}if(D){for(;--n>=0;){const n=s*this[t++]+e[i]+r;r=Math.floor(n/67108864),e[i++]=67108863&n}return r}{const h=16383&s,o=s>>14;for(;--n>=0;){let s=16383&this[t];const n=this[t++]>>14,u=o*s+n*h;s=h*s+((16383&u)<<14)+e[i]+r,r=(s>>28)+(u>>14)+o*n,e[i++]=268435455&s}return r}}}class O{convert(t){return t}revert(t){return t}mulTo(t,s,e){t.multiplyTo(s,e)}sqrTo(t,s){t.squareTo(s)}}class A{constructor(t){this.m=t}convert(t){return t.s<0||t.compareTo(this.m)>=0?t.mod(this.m):t}revert(t){return t}reduce(t){t.divRemTo(this.m,null,t)}mulTo(t,s,e){t.multiplyTo(s,e),this.reduce(e)}sqrTo(t,s){t.squareTo(s),this.reduce(s)}}class x{constructor(t){this.m=t,this.mp=t.invDigit(),this.mpl=32767&this.mp,this.mph=this.mp>>15,this.um=(1<<t.DB-15)-1,this.mt2=2*t.t}convert(t){const s=M();return t.abs().dlShiftTo(this.m.t,s),s.divRemTo(this.m,null,s),t.s<0&&s.compareTo(N.ZERO)>0&&this.m.subTo(s,s),s}revert(t){const s=M();return t.copyTo(s),this.reduce(s),s}reduce(t){for(;t.t<=this.mt2;)t[t.t++]=0;for(let s=0;s<this.m.t;++s){let e=32767&t[s];const i=e*this.mpl+((e*this.mph+(t[s]>>15)*this.mpl&this.um)<<15)&t.DM;for(e=s+this.m.t,t[e]+=this.m.am(0,i,t,s,0,this.m.t);t[e]>=t.DV;)t[e]-=t.DV,t[++e]++}t.clamp(),t.drShiftTo(this.m.t,t),t.compareTo(this.m)>=0&&t.subTo(this.m,t)}mulTo(t,s,e){t.multiplyTo(s,e),this.reduce(e)}sqrTo(t,s){t.squareTo(s),this.reduce(s)}}class I{constructor(t){this.m=t,this.r2=M(),this.q3=M(),N.ONE.dlShiftTo(2*t.t,this.r2),this.mu=this.r2.divide(t)}convert(t){if(t.s<0||t.t>2*this.m.t)return t.mod(this.m);if(t.compareTo(this.m)<0)return t;{const s=M();return t.copyTo(s),this.reduce(s),s}}revert(t){return t}reduce(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)}mulTo(t,s,e){t.multiplyTo(s,e),this.reduce(e)}sqrTo(t,s){t.squareTo(s),this.reduce(s)}}function M(){return new N(null)}function q(t,s){return new N(t,s)}const C=[];let P,R;for(P="0".charCodeAt(0),R=0;R<=9;++R)C[P++]=R;for(P="a".charCodeAt(0),R=10;R<36;++R)C[P++]=R;for(P="A".charCodeAt(0),R=10;R<36;++R)C[P++]=R;function V(t,s){const e=C[t.charCodeAt(s)];return null==e?-1:e}function L(t){const s=M();return s.fromInt(t),s}function k(t){let s,e=1;return 0!=(s=t>>>16)&&(t=s,e+=16),0!=(s=t>>8)&&(t=s,e+=8),0!=(s=t>>4)&&(t=s,e+=4),0!=(s=t>>2)&&(t=s,e+=2),0!=(s=t>>1)&&(t=s,e+=1),e}N.ZERO=L(0),N.ONE=L(1);class _{constructor(){this.i=0,this.j=0,this.S=[]}init(t){let s,e,i;for(s=0;s<256;++s)this.S[s]=s;for(e=0,s=0;s<256;++s)e=e+this.S[s]+t[s%t.length]&255,i=this.S[s],this.S[s]=this.S[e],this.S[e]=i;this.i=0,this.j=0}next(){this.i=this.i+1&255,this.j=this.j+this.S[this.i]&255;const t=this.S[this.i];return this.S[this.i]=this.S[this.j],this.S[this.j]=t,this.S[t+this.S[this.i]&255]}}let F,U,Z=[];function z(){if(null==F){for(F=new _;U<256;){const t=Math.floor(65536*Math.random());Z[U++]=255&t}for(F.init(Z),U=0;U<Z.length;++U)Z[U]=0;U=0}return F.next()}null==Z&&(Z=[],U=0);class H{nextBytes(t){for(let s=0;s<t.length;++s)t[s]=z()}}class j{constructor(){this.e=0}doPublic(t){return this.n?t.modPowInt(this.e,this.n):null}setPublic(t,s){null!=t&&null!=s&&t.length>0&&s.length>0?(this.n=q(t,16),this.e=parseInt(s,16)):console.error("Invalid RSA public key")}encrypt(t){if(!this.n)return null;const s=this.n.bitLength()+7>>3,e=function(t,s){if(s<t.length+11)return console.error("Message too long for RSA"),null;const e=[];let i=t.length-1;for(;i>=0&&s>0;){const r=t.charCodeAt(i--);r<128?e[--s]=r:r>127&&r<2048?(e[--s]=63&r|128,e[--s]=r>>6|192):(e[--s]=63&r|128,e[--s]=r>>6&63|128,e[--s]=r>>12|224)}e[--s]=0;const r=new H,n=[];for(;s>2;){for(n[0]=0;0==n[0];)r.nextBytes(n);e[--s]=n[0]}return e[--s]=2,e[--s]=0,new N(e)}(t,s);if(null==e)return null;const i=this.doPublic(e);if(null==i)return null;let r=i.toString(16);const n=r.length;for(let t=0;t<2*s-n;t++)r="0"+r;return r}generate(t,s){const e=new H,i=t>>1;this.e=parseInt(s,16);const r=new N(s,16);for(;;){for(;this.p=new N(t-i,1,e),0!=this.p.subtract(N.ONE).gcd(r).compareTo(N.ONE)||!this.p.isProbablePrime(10););for(;this.q=new N(i,1,e),0!=this.q.subtract(N.ONE).gcd(r).compareTo(N.ONE)||!this.q.isProbablePrime(10););if(this.p.compareTo(this.q)<=0){const t=this.p;this.p=this.q,this.q=t}const s=this.p.subtract(N.ONE),n=this.q.subtract(N.ONE),h=s.multiply(n);if(0==h.gcd(r).compareTo(N.ONE)){this.n=this.p.multiply(this.q),this.d=r.modInverse(h),this.dmp1=this.d.mod(s),this.dmq1=this.d.mod(n),this.coeff=this.q.modInverse(this.p);break}}}generateAsync(t,s,e){const i=new H,r=t>>1;this.e=parseInt(s,16);const n=new N(s,16),h=()=>{const s=()=>{if(this.p.compareTo(this.q)<=0){const t=this.p;this.p=this.q,this.q=t}const t=this.p.subtract(N.ONE),s=this.q.subtract(N.ONE),i=t.multiply(s);0==i.gcd(n).compareTo(N.ONE)?(this.n=this.p.multiply(this.q),this.d=n.modInverse(i),this.dmp1=this.d.mod(t),this.dmq1=this.d.mod(s),this.coeff=this.q.modInverse(this.p),setTimeout((function(){e()}),0)):setTimeout(h,0)},o=()=>{this.q=M(),this.q.fromNumberAsync(r,1,i,(()=>{this.q.subtract(N.ONE).gcda(n,(t=>{0==t.compareTo(N.ONE)&&this.q.isProbablePrime(10)?setTimeout(s,0):setTimeout(o,0)}))}))},u=()=>{this.p=M(),this.p.fromNumberAsync(t-r,1,i,(()=>{this.p.subtract(N.ONE).gcda(n,(t=>{0==t.compareTo(N.ONE)&&this.p.isProbablePrime(10)?setTimeout(o,0):setTimeout(u,0)}))}))};setTimeout(u,0)};setTimeout(h,0)}}class K extends j{constructor(t){super(),t&&("string"==typeof t?this.parseKey(t):K.hasPublicKeyProperty(t)&&this.parsePropertiesFrom(t))}parseKey(t){try{let s=0,e=0;const i=/^\s*(?:[0-9A-Fa-f][0-9A-Fa-f]\s*)+$/.test(t)?l.decode(t):c.unarmor(t);let r=b.decode(i);if(r.sub&&3===r.sub.length&&r.sub[2].sub&&(r=r.sub[2].sub[0]),r.sub&&9===r.sub.length){s=r.sub[1].getHexStringValue(),this.n=q(s,16),e=r.sub[2].getHexStringValue(),this.e=parseInt(e,16);const t=r.sub[3].getHexStringValue();this.d=q(t,16);const i=r.sub[4].getHexStringValue();this.p=q(i,16);const n=r.sub[5].getHexStringValue();this.q=q(n,16);const h=r.sub[6].getHexStringValue();this.dmp1=q(h,16);const o=r.sub[7].getHexStringValue();this.dmq1=q(o,16);const u=r.sub[8].getHexStringValue();this.coeff=q(u,16)}else{if(!r.sub||2!==r.sub.length)return!1;{const t=r.sub[1];if(!t.sub)return!1;{const i=t.sub[0];if(!i.sub)return!1;s=i.sub[0].getHexStringValue(),this.n=q(s,16),e=i.sub[1].getHexStringValue(),this.e=parseInt(e,16)}}}return!0}catch(t){return!1}}static hasPublicKeyProperty(t){return(t=t||{}).hasOwnProperty("n")&&t.hasOwnProperty("e")}parsePropertiesFrom(t){this.n=t.n,this.e=t.e,t.hasOwnProperty("d")&&(this.d=t.d,this.p=t.p,this.q=t.q,this.dmp1=t.dmp1,this.dmq1=t.dmq1,this.coeff=t.coeff)}}class G{constructor(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}setKey(t){this.log&&this.key&&console.warn("A key was already set, overriding existing."),this.key=new K(t)}setPublicKey(t){this.setKey(t)}encrypt(t){try{const s=this.getKey().encrypt(t);if("string"==typeof s)return function(t){let s,e,i="";for(s=0;s+3<=t.length;s+=3)e=parseInt(t.substring(s,s+3),16),i+=o.charAt(e>>6)+o.charAt(63&e);for(s+1==t.length?(e=parseInt(t.substring(s,s+1),16),i+=o.charAt(e<<2)):s+2==t.length&&(e=parseInt(t.substring(s,s+2),16),i+=o.charAt(e>>2)+o.charAt((3&e)<<4));(3&i.length)>0;)i+="=";return i}(s)}catch(t){}return""}getKey(t){if(!this.key){if(this.key=new K,t&&"[object Function]"==={}.toString.call(t))return this.key.generateAsync(this.default_key_size,this.default_public_exponent,t),this.key;this.key.generate(this.default_key_size,this.default_public_exponent)}return this.key}}exports.JSEncrypt=G,exports.default=G;
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@ray-js/wechat-rsa",
3
- "version": "0.0.1-beta-1",
3
+ "version": "0.0.2-beta-2",
4
4
  "publishConfig": {
5
5
  "access": "public",
6
6
  "registry": "https://registry.npmjs.org"