@libp2p/circuit-relay-v2 1.0.4 → 1.0.5-887c6ffe1

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.
package/dist/index.min.js CHANGED
@@ -12,7 +12,7 @@
12
12
  `,r};yc.decode=function(e){for(var t=[],r=/\s*-----BEGIN ([A-Z0-9- ]+)-----\r?\n?([\x21-\x7e\s]+?(?:\r?\n\r?\n))?([:A-Za-z0-9+\/=\s]+?)-----END \1-----/g,n=/([\x21-\x7e]+):\s*([\x21-\x7e\s^:]+)/,i=/\r?\n/,s;s=r.exec(e),!!s;){var o=s[1];o==="NEW CERTIFICATE REQUEST"&&(o="CERTIFICATE REQUEST");var a={type:o,procType:null,contentDomain:null,dekInfo:null,headers:[],body:wi.util.decode64(s[3])};if(t.push(a),!!s[2]){for(var c=s[2].split(i),u=0;s&&u<c.length;){for(var f=c[u].replace(/\s+$/,""),l=u+1;l<c.length;++l){var h=c[l];if(!/\s/.test(h[0]))break;f+=h,u=l}if(s=f.match(n),s){for(var y={name:s[1],values:[]},d=s[2].split(","),p=0;p<d.length;++p)y.values.push(Ad(d[p]));if(a.procType)if(!a.contentDomain&&y.name==="Content-Domain")a.contentDomain=d[0]||"";else if(!a.dekInfo&&y.name==="DEK-Info"){if(y.values.length===0)throw new Error('Invalid PEM formatted message. The "DEK-Info" header must have at least one subfield.');a.dekInfo={algorithm:d[0],parameters:d[1]||null}}else a.headers.push(y);else{if(y.name!=="Proc-Type")throw new Error('Invalid PEM formatted message. The first encapsulated header must be "Proc-Type".');if(y.values.length!==2)throw new Error('Invalid PEM formatted message. The "Proc-Type" header must have two subfields.');a.procType={version:d[0],type:d[1]}}}++u}if(a.procType==="ENCRYPTED"&&!a.dekInfo)throw new Error('Invalid PEM formatted message. The "DEK-Info" header must be present if "Proc-Type" is "ENCRYPTED".')}}if(t.length===0)throw new Error("Invalid PEM formatted message.");return t};function Ei(e){for(var t=e.name+": ",r=[],n=function(c,u){return" "+u},i=0;i<e.values.length;++i)r.push(e.values[i].replace(/^(\S+\r\n)/,n));t+=r.join(",")+`\r
13
13
  `;for(var s=0,o=-1,i=0;i<t.length;++i,++s)if(s>65&&o!==-1){var a=t[o];a===","?(++o,t=t.substr(0,o)+`\r
14
14
  `+t.substr(o)):t=t.substr(0,o)+`\r
15
- `+a+t.substr(o+1),s=i-o-1,o=-1,++i}else(t[i]===" "||t[i]===" "||t[i]===",")&&(o=i);return t}function Ad(e){return e.replace(/^\s+/,"")}});var Sc=ot((x2,wc)=>{var ke=ht();Lr();Dt();var vc=wc.exports=ke.sha256=ke.sha256||{};ke.md.sha256=ke.md.algorithms.sha256=vc;vc.create=function(){bc||Td();var e=null,t=ke.util.createBuffer(),r=new Array(64),n={algorithm:"sha256",blockLength:64,digestLength:32,messageLength:0,fullMessageLength:null,messageLengthSize:8};return n.start=function(){n.messageLength=0,n.fullMessageLength=n.messageLength64=[];for(var i=n.messageLengthSize/4,s=0;s<i;++s)n.fullMessageLength.push(0);return t=ke.util.createBuffer(),e={h0:1779033703,h1:3144134277,h2:1013904242,h3:2773480762,h4:1359893119,h5:2600822924,h6:528734635,h7:1541459225},n},n.start(),n.update=function(i,s){s==="utf8"&&(i=ke.util.encodeUtf8(i));var o=i.length;n.messageLength+=o,o=[o/4294967296>>>0,o>>>0];for(var a=n.fullMessageLength.length-1;a>=0;--a)n.fullMessageLength[a]+=o[1],o[1]=o[0]+(n.fullMessageLength[a]/4294967296>>>0),n.fullMessageLength[a]=n.fullMessageLength[a]>>>0,o[0]=o[1]/4294967296>>>0;return t.putBytes(i),xc(e,r,t),(t.read>2048||t.length()===0)&&t.compact(),n},n.digest=function(){var i=ke.util.createBuffer();i.putBytes(t.bytes());var s=n.fullMessageLength[n.fullMessageLength.length-1]+n.messageLengthSize,o=s&n.blockLength-1;i.putBytes(mo.substr(0,n.blockLength-o));for(var a,c,u=n.fullMessageLength[0]*8,f=0;f<n.fullMessageLength.length-1;++f)a=n.fullMessageLength[f+1]*8,c=a/4294967296>>>0,u+=c,i.putInt32(u>>>0),u=a>>>0;i.putInt32(u);var l={h0:e.h0,h1:e.h1,h2:e.h2,h3:e.h3,h4:e.h4,h5:e.h5,h6:e.h6,h7:e.h7};xc(l,r,i);var h=ke.util.createBuffer();return h.putInt32(l.h0),h.putInt32(l.h1),h.putInt32(l.h2),h.putInt32(l.h3),h.putInt32(l.h4),h.putInt32(l.h5),h.putInt32(l.h6),h.putInt32(l.h7),h},n};var mo=null,bc=!1,Ec=null;function Td(){mo="\x80",mo+=ke.util.fillString("\0",64),Ec=[1116352408,1899447441,3049323471,3921009573,961987163,1508970993,2453635748,2870763221,3624381080,310598401,607225278,1426881987,1925078388,2162078206,2614888103,3248222580,3835390401,4022224774,264347078,604807628,770255983,1249150122,1555081692,1996064986,2554220882,2821834349,2952996808,3210313671,3336571891,3584528711,113926993,338241895,666307205,773529912,1294757372,1396182291,1695183700,1986661051,2177026350,2456956037,2730485921,2820302411,3259730800,3345764771,3516065817,3600352804,4094571909,275423344,430227734,506948616,659060556,883997877,958139571,1322822218,1537002063,1747873779,1955562222,2024104815,2227730452,2361852424,2428436474,2756734187,3204031479,3329325298],bc=!0}function xc(e,t,r){for(var n,i,s,o,a,c,u,f,l,h,y,d,p,m,x,E=r.length();E>=64;){for(u=0;u<16;++u)t[u]=r.getInt32();for(;u<64;++u)n=t[u-2],n=(n>>>17|n<<15)^(n>>>19|n<<13)^n>>>10,i=t[u-15],i=(i>>>7|i<<25)^(i>>>18|i<<14)^i>>>3,t[u]=n+t[u-7]+i+t[u-16]|0;for(f=e.h0,l=e.h1,h=e.h2,y=e.h3,d=e.h4,p=e.h5,m=e.h6,x=e.h7,u=0;u<64;++u)o=(d>>>6|d<<26)^(d>>>11|d<<21)^(d>>>25|d<<7),a=m^d&(p^m),s=(f>>>2|f<<30)^(f>>>13|f<<19)^(f>>>22|f<<10),c=f&l|h&(f^l),n=x+o+a+Ec[u]+t[u],i=s+c,x=m,m=p,p=d,d=y+n>>>0,y=h,h=l,l=f,f=n+i>>>0;e.h0=e.h0+f|0,e.h1=e.h1+l|0,e.h2=e.h2+h|0,e.h3=e.h3+y|0,e.h4=e.h4+d|0,e.h5=e.h5+p|0,e.h6=e.h6+m|0,e.h7=e.h7+x|0,E-=64}}});var Tc=ot((v2,Ac)=>{var Ue=ht();Dt();var Si=null;Ue.util.isNodejs&&!Ue.options.usePureJavaScript&&!process.versions["node-webkit"]&&(Si=bi());var Bd=Ac.exports=Ue.prng=Ue.prng||{};Bd.create=function(e){for(var t={plugin:e,key:null,seed:null,time:null,reseeds:0,generated:0,keyBytes:""},r=e.md,n=new Array(32),i=0;i<32;++i)n[i]=r.create();t.pools=n,t.pool=0,t.generate=function(u,f){if(!f)return t.generateSync(u);var l=t.plugin.cipher,h=t.plugin.increment,y=t.plugin.formatKey,d=t.plugin.formatSeed,p=Ue.util.createBuffer();t.key=null,m();function m(x){if(x)return f(x);if(p.length()>=u)return f(null,p.getBytes(u));if(t.generated>1048575&&(t.key=null),t.key===null)return Ue.util.nextTick(function(){s(m)});var E=l(t.key,t.seed);t.generated+=E.length,p.putBytes(E),t.key=y(l(t.key,h(t.seed))),t.seed=d(l(t.key,t.seed)),Ue.util.setImmediate(m)}},t.generateSync=function(u){var f=t.plugin.cipher,l=t.plugin.increment,h=t.plugin.formatKey,y=t.plugin.formatSeed;t.key=null;for(var d=Ue.util.createBuffer();d.length()<u;){t.generated>1048575&&(t.key=null),t.key===null&&o();var p=f(t.key,t.seed);t.generated+=p.length,d.putBytes(p),t.key=h(f(t.key,l(t.seed))),t.seed=y(f(t.key,t.seed))}return d.getBytes(u)};function s(u){if(t.pools[0].messageLength>=32)return a(),u();var f=32-t.pools[0].messageLength<<5;t.seedFile(f,function(l,h){if(l)return u(l);t.collect(h),a(),u()})}function o(){if(t.pools[0].messageLength>=32)return a();var u=32-t.pools[0].messageLength<<5;t.collect(t.seedFileSync(u)),a()}function a(){t.reseeds=t.reseeds===4294967295?0:t.reseeds+1;var u=t.plugin.md.create();u.update(t.keyBytes);for(var f=1,l=0;l<32;++l)t.reseeds%f===0&&(u.update(t.pools[l].digest().getBytes()),t.pools[l].start()),f=f<<1;t.keyBytes=u.digest().getBytes(),u.start(),u.update(t.keyBytes);var h=u.digest().getBytes();t.key=t.plugin.formatKey(t.keyBytes),t.seed=t.plugin.formatSeed(h),t.generated=0}function c(u){var f=null,l=Ue.util.globalScope,h=l.crypto||l.msCrypto;h&&h.getRandomValues&&(f=function(w){return h.getRandomValues(w)});var y=Ue.util.createBuffer();if(f)for(;y.length()<u;){var d=Math.max(1,Math.min(u-y.length(),65536)/4),p=new Uint32Array(Math.floor(d));try{f(p);for(var m=0;m<p.length;++m)y.putInt32(p[m])}catch(w){if(!(typeof QuotaExceededError<"u"&&w instanceof QuotaExceededError))throw w}}if(y.length()<u)for(var x,E,b,R=Math.floor(Math.random()*65536);y.length()<u;){E=16807*(R&65535),x=16807*(R>>16),E+=(x&32767)<<16,E+=x>>15,E=(E&2147483647)+(E>>31),R=E&4294967295;for(var m=0;m<3;++m)b=R>>>(m<<3),b^=Math.floor(Math.random()*256),y.putByte(b&255)}return y.getBytes(u)}return Si?(t.seedFile=function(u,f){Si.randomBytes(u,function(l,h){if(l)return f(l);f(null,h.toString())})},t.seedFileSync=function(u){return Si.randomBytes(u).toString()}):(t.seedFile=function(u,f){try{f(null,c(u))}catch(l){f(l)}},t.seedFileSync=c),t.collect=function(u){for(var f=u.length,l=0;l<f;++l)t.pools[t.pool].update(u.substr(l,1)),t.pool=t.pool===31?0:t.pool+1},t.collectInt=function(u,f){for(var l="",h=0;h<f;h+=8)l+=String.fromCharCode(u>>h&255);t.collect(l)},t.registerWorker=function(u){if(u===self)t.seedFile=function(l,h){function y(d){var p=d.data;p.forge&&p.forge.prng&&(self.removeEventListener("message",y),h(p.forge.prng.err,p.forge.prng.bytes))}self.addEventListener("message",y),self.postMessage({forge:{prng:{needed:l}}})};else{var f=function(l){var h=l.data;h.forge&&h.forge.prng&&t.seedFile(h.forge.prng.needed,function(y,d){u.postMessage({forge:{prng:{err:y,bytes:d}}})})};u.addEventListener("message",f)}},t}});var On=ot((b2,go)=>{var qt=ht();yo();Sc();Tc();Dt();(function(){if(qt.random&&qt.random.getBytes){go.exports=qt.random;return}(function(e){var t={},r=new Array(4),n=qt.util.createBuffer();t.formatKey=function(l){var h=qt.util.createBuffer(l);return l=new Array(4),l[0]=h.getInt32(),l[1]=h.getInt32(),l[2]=h.getInt32(),l[3]=h.getInt32(),qt.aes._expandKey(l,!1)},t.formatSeed=function(l){var h=qt.util.createBuffer(l);return l=new Array(4),l[0]=h.getInt32(),l[1]=h.getInt32(),l[2]=h.getInt32(),l[3]=h.getInt32(),l},t.cipher=function(l,h){return qt.aes._updateBlock(l,h,r,!1),n.putInt32(r[0]),n.putInt32(r[1]),n.putInt32(r[2]),n.putInt32(r[3]),n.getBytes()},t.increment=function(l){return++l[3],l},t.md=qt.md.sha256;function i(){var l=qt.prng.create(t);return l.getBytes=function(h,y){return l.generate(h,y)},l.getBytesSync=function(h){return l.generate(h)},l}var s=i(),o=null,a=qt.util.globalScope,c=a.crypto||a.msCrypto;if(c&&c.getRandomValues&&(o=function(l){return c.getRandomValues(l)}),qt.options.usePureJavaScript||!qt.util.isNodejs&&!o){if(typeof window>"u"||window.document,s.collectInt(+new Date,32),typeof navigator<"u"){var u="";for(var f in navigator)try{typeof navigator[f]=="string"&&(u+=navigator[f])}catch{}s.collect(u),u=null}e&&(e().mousemove(function(l){s.collectInt(l.clientX,16),s.collectInt(l.clientY,16)}),e().keypress(function(l){s.collectInt(l.charCode,8)}))}if(!qt.random)qt.random=s;else for(var f in s)qt.random[f]=s[f];qt.random.createInstance=i,go.exports=qt.random})(typeof jQuery<"u"?jQuery:null)})()});var _c=ot((E2,Cc)=>{var oe=ht();Dt();var xo=[217,120,249,196,25,221,181,237,40,233,253,121,74,160,216,157,198,126,55,131,43,118,83,142,98,76,100,136,68,139,251,162,23,154,89,245,135,179,79,19,97,69,109,141,9,129,125,50,189,143,64,235,134,183,123,11,240,149,33,34,92,107,78,130,84,214,101,147,206,96,178,28,115,86,192,20,167,140,241,220,18,117,202,31,59,190,228,209,66,61,212,48,163,60,182,38,111,191,14,218,70,105,7,87,39,242,29,155,188,148,67,3,248,17,199,246,144,239,62,231,6,195,213,47,200,102,30,215,8,232,234,222,128,82,238,247,132,170,114,172,53,77,106,42,150,26,210,113,90,21,73,116,75,159,208,94,4,24,164,236,194,224,65,110,15,81,203,204,36,145,175,80,161,244,112,57,153,124,58,133,35,184,180,122,252,2,54,91,37,85,151,49,45,93,250,152,227,138,146,174,5,223,41,16,103,108,186,201,211,0,230,207,225,158,168,44,99,22,1,63,88,226,137,169,13,56,52,27,171,51,255,176,187,72,12,95,185,177,205,46,197,243,219,71,229,165,156,119,10,166,32,104,254,127,193,173],Bc=[1,2,3,5],Id=function(e,t){return e<<t&65535|(e&65535)>>16-t},Cd=function(e,t){return(e&65535)>>t|e<<16-t&65535};Cc.exports=oe.rc2=oe.rc2||{};oe.rc2.expandKey=function(e,t){typeof e=="string"&&(e=oe.util.createBuffer(e)),t=t||128;var r=e,n=e.length(),i=t,s=Math.ceil(i/8),o=255>>(i&7),a;for(a=n;a<128;a++)r.putByte(xo[r.at(a-1)+r.at(a-n)&255]);for(r.setAt(128-s,xo[r.at(128-s)&o]),a=127-s;a>=0;a--)r.setAt(a,xo[r.at(a+1)^r.at(a+s)]);return r};var Ic=function(e,t,r){var n=!1,i=null,s=null,o=null,a,c,u,f,l=[];for(e=oe.rc2.expandKey(e,t),u=0;u<64;u++)l.push(e.getInt16Le());r?(a=function(d){for(u=0;u<4;u++)d[u]+=l[f]+(d[(u+3)%4]&d[(u+2)%4])+(~d[(u+3)%4]&d[(u+1)%4]),d[u]=Id(d[u],Bc[u]),f++},c=function(d){for(u=0;u<4;u++)d[u]+=l[d[(u+3)%4]&63]}):(a=function(d){for(u=3;u>=0;u--)d[u]=Cd(d[u],Bc[u]),d[u]-=l[f]+(d[(u+3)%4]&d[(u+2)%4])+(~d[(u+3)%4]&d[(u+1)%4]),f--},c=function(d){for(u=3;u>=0;u--)d[u]-=l[d[(u+3)%4]&63]});var h=function(d){var p=[];for(u=0;u<4;u++){var m=i.getInt16Le();o!==null&&(r?m^=o.getInt16Le():o.putInt16Le(m)),p.push(m&65535)}f=r?0:63;for(var x=0;x<d.length;x++)for(var E=0;E<d[x][0];E++)d[x][1](p);for(u=0;u<4;u++)o!==null&&(r?o.putInt16Le(p[u]):p[u]^=o.getInt16Le()),s.putInt16Le(p[u])},y=null;return y={start:function(d,p){d&&typeof d=="string"&&(d=oe.util.createBuffer(d)),n=!1,i=oe.util.createBuffer(),s=p||new oe.util.createBuffer,o=d,y.output=s},update:function(d){for(n||i.putBuffer(d);i.length()>=8;)h([[5,a],[1,c],[6,a],[1,c],[5,a]])},finish:function(d){var p=!0;if(r)if(d)p=d(8,i,!r);else{var m=i.length()===8?8:8-i.length();i.fillWithByte(m,m)}if(p&&(n=!0,y.update()),!r&&(p=i.length()===0,p))if(d)p=d(8,s,!r);else{var x=s.length(),E=s.at(x-1);E>x?p=!1:s.truncate(E)}return p}},y};oe.rc2.startEncrypting=function(e,t,r){var n=oe.rc2.createEncryptionCipher(e,128);return n.start(t,r),n};oe.rc2.createEncryptionCipher=function(e,t){return Ic(e,t,!0)};oe.rc2.startDecrypting=function(e,t,r){var n=oe.rc2.createDecryptionCipher(e,128);return n.start(t,r),n};oe.rc2.createDecryptionCipher=function(e,t){return Ic(e,t,!1)}});var Bi=ot((w2,Oc)=>{var vo=ht();Oc.exports=vo.jsbn=vo.jsbn||{};var $e,_d=0xdeadbeefcafe,Rc=(_d&16777215)==15715070;function B(e,t,r){this.data=[],e!=null&&(typeof e=="number"?this.fromNumber(e,t,r):t==null&&typeof e!="string"?this.fromString(e,256):this.fromString(e,t))}vo.jsbn.BigInteger=B;function it(){return new B(null)}function Rd(e,t,r,n,i,s){for(;--s>=0;){var o=t*this.data[e++]+r.data[n]+i;i=Math.floor(o/67108864),r.data[n++]=o&67108863}return i}function Ld(e,t,r,n,i,s){for(var o=t&32767,a=t>>15;--s>=0;){var c=this.data[e]&32767,u=this.data[e++]>>15,f=a*c+u*o;c=o*c+((f&32767)<<15)+r.data[n]+(i&1073741823),i=(c>>>30)+(f>>>15)+a*u+(i>>>30),r.data[n++]=c&1073741823}return i}function Lc(e,t,r,n,i,s){for(var o=t&16383,a=t>>14;--s>=0;){var c=this.data[e]&16383,u=this.data[e++]>>14,f=a*c+u*o;c=o*c+((f&16383)<<14)+r.data[n]+i,i=(c>>28)+(f>>14)+a*u,r.data[n++]=c&268435455}return i}typeof navigator>"u"?(B.prototype.am=Lc,$e=28):Rc&&navigator.appName=="Microsoft Internet Explorer"?(B.prototype.am=Ld,$e=30):Rc&&navigator.appName!="Netscape"?(B.prototype.am=Rd,$e=26):(B.prototype.am=Lc,$e=28);B.prototype.DB=$e;B.prototype.DM=(1<<$e)-1;B.prototype.DV=1<<$e;var bo=52;B.prototype.FV=Math.pow(2,bo);B.prototype.F1=bo-$e;B.prototype.F2=2*$e-bo;var Dd="0123456789abcdefghijklmnopqrstuvwxyz",Ai=new Array,un,ge;un=48;for(ge=0;ge<=9;++ge)Ai[un++]=ge;un=97;for(ge=10;ge<36;++ge)Ai[un++]=ge;un=65;for(ge=10;ge<36;++ge)Ai[un++]=ge;function Dc(e){return Dd.charAt(e)}function Nc(e,t){var r=Ai[e.charCodeAt(t)];return r??-1}function Nd(e){for(var t=this.t-1;t>=0;--t)e.data[t]=this.data[t];e.t=this.t,e.s=this.s}function Pd(e){this.t=1,this.s=e<0?-1:0,e>0?this.data[0]=e:e<-1?this.data[0]=e+this.DV:this.t=0}function hr(e){var t=it();return t.fromInt(e),t}function kd(e,t){var r;if(t==16)r=4;else if(t==8)r=3;else if(t==256)r=8;else if(t==2)r=1;else if(t==32)r=5;else if(t==4)r=2;else{this.fromRadix(e,t);return}this.t=0,this.s=0;for(var n=e.length,i=!1,s=0;--n>=0;){var o=r==8?e[n]&255:Nc(e,n);if(o<0){e.charAt(n)=="-"&&(i=!0);continue}i=!1,s==0?this.data[this.t++]=o:s+r>this.DB?(this.data[this.t-1]|=(o&(1<<this.DB-s)-1)<<s,this.data[this.t++]=o>>this.DB-s):this.data[this.t-1]|=o<<s,s+=r,s>=this.DB&&(s-=this.DB)}r==8&&e[0]&128&&(this.s=-1,s>0&&(this.data[this.t-1]|=(1<<this.DB-s)-1<<s)),this.clamp(),i&&B.ZERO.subTo(this,this)}function Ud(){for(var e=this.s&this.DM;this.t>0&&this.data[this.t-1]==e;)--this.t}function Od(e){if(this.s<0)return"-"+this.negate().toString(e);var t;if(e==16)t=4;else if(e==8)t=3;else if(e==2)t=1;else if(e==32)t=5;else if(e==4)t=2;else return this.toRadix(e);var r=(1<<t)-1,n,i=!1,s="",o=this.t,a=this.DB-o*this.DB%t;if(o-- >0)for(a<this.DB&&(n=this.data[o]>>a)>0&&(i=!0,s=Dc(n));o>=0;)a<t?(n=(this.data[o]&(1<<a)-1)<<t-a,n|=this.data[--o]>>(a+=this.DB-t)):(n=this.data[o]>>(a-=t)&r,a<=0&&(a+=this.DB,--o)),n>0&&(i=!0),i&&(s+=Dc(n));return i?s:"0"}function Md(){var e=it();return B.ZERO.subTo(this,e),e}function Kd(){return this.s<0?this.negate():this}function Fd(e){var t=this.s-e.s;if(t!=0)return t;var r=this.t;if(t=r-e.t,t!=0)return this.s<0?-t:t;for(;--r>=0;)if((t=this.data[r]-e.data[r])!=0)return t;return 0}function Ti(e){var t=1,r;return(r=e>>>16)!=0&&(e=r,t+=16),(r=e>>8)!=0&&(e=r,t+=8),(r=e>>4)!=0&&(e=r,t+=4),(r=e>>2)!=0&&(e=r,t+=2),(r=e>>1)!=0&&(e=r,t+=1),t}function Vd(){return this.t<=0?0:this.DB*(this.t-1)+Ti(this.data[this.t-1]^this.s&this.DM)}function qd(e,t){var r;for(r=this.t-1;r>=0;--r)t.data[r+e]=this.data[r];for(r=e-1;r>=0;--r)t.data[r]=0;t.t=this.t+e,t.s=this.s}function Hd(e,t){for(var r=e;r<this.t;++r)t.data[r-e]=this.data[r];t.t=Math.max(this.t-e,0),t.s=this.s}function zd(e,t){var r=e%this.DB,n=this.DB-r,i=(1<<n)-1,s=Math.floor(e/this.DB),o=this.s<<r&this.DM,a;for(a=this.t-1;a>=0;--a)t.data[a+s+1]=this.data[a]>>n|o,o=(this.data[a]&i)<<r;for(a=s-1;a>=0;--a)t.data[a]=0;t.data[s]=o,t.t=this.t+s+1,t.s=this.s,t.clamp()}function Gd(e,t){t.s=this.s;var r=Math.floor(e/this.DB);if(r>=this.t){t.t=0;return}var n=e%this.DB,i=this.DB-n,s=(1<<n)-1;t.data[0]=this.data[r]>>n;for(var o=r+1;o<this.t;++o)t.data[o-r-1]|=(this.data[o]&s)<<i,t.data[o-r]=this.data[o]>>n;n>0&&(t.data[this.t-r-1]|=(this.s&s)<<i),t.t=this.t-r,t.clamp()}function Wd(e,t){for(var r=0,n=0,i=Math.min(e.t,this.t);r<i;)n+=this.data[r]-e.data[r],t.data[r++]=n&this.DM,n>>=this.DB;if(e.t<this.t){for(n-=e.s;r<this.t;)n+=this.data[r],t.data[r++]=n&this.DM,n>>=this.DB;n+=this.s}else{for(n+=this.s;r<e.t;)n-=e.data[r],t.data[r++]=n&this.DM,n>>=this.DB;n-=e.s}t.s=n<0?-1:0,n<-1?t.data[r++]=this.DV+n:n>0&&(t.data[r++]=n),t.t=r,t.clamp()}function Yd(e,t){var r=this.abs(),n=e.abs(),i=r.t;for(t.t=i+n.t;--i>=0;)t.data[i]=0;for(i=0;i<n.t;++i)t.data[i+r.t]=r.am(0,n.data[i],t,i,0,r.t);t.s=0,t.clamp(),this.s!=e.s&&B.ZERO.subTo(t,t)}function $d(e){for(var t=this.abs(),r=e.t=2*t.t;--r>=0;)e.data[r]=0;for(r=0;r<t.t-1;++r){var n=t.am(r,t.data[r],e,2*r,0,1);(e.data[r+t.t]+=t.am(r+1,2*t.data[r],e,2*r+1,n,t.t-r-1))>=t.DV&&(e.data[r+t.t]-=t.DV,e.data[r+t.t+1]=1)}e.t>0&&(e.data[e.t-1]+=t.am(r,t.data[r],e,2*r,0,1)),e.s=0,e.clamp()}function Qd(e,t,r){var n=e.abs();if(!(n.t<=0)){var i=this.abs();if(i.t<n.t){t?.fromInt(0),r!=null&&this.copyTo(r);return}r==null&&(r=it());var s=it(),o=this.s,a=e.s,c=this.DB-Ti(n.data[n.t-1]);c>0?(n.lShiftTo(c,s),i.lShiftTo(c,r)):(n.copyTo(s),i.copyTo(r));var u=s.t,f=s.data[u-1];if(f!=0){var l=f*(1<<this.F1)+(u>1?s.data[u-2]>>this.F2:0),h=this.FV/l,y=(1<<this.F1)/l,d=1<<this.F2,p=r.t,m=p-u,x=t??it();for(s.dlShiftTo(m,x),r.compareTo(x)>=0&&(r.data[r.t++]=1,r.subTo(x,r)),B.ONE.dlShiftTo(u,x),x.subTo(s,s);s.t<u;)s.data[s.t++]=0;for(;--m>=0;){var E=r.data[--p]==f?this.DM:Math.floor(r.data[p]*h+(r.data[p-1]+d)*y);if((r.data[p]+=s.am(0,E,r,m,0,u))<E)for(s.dlShiftTo(m,x),r.subTo(x,r);r.data[p]<--E;)r.subTo(x,r)}t!=null&&(r.drShiftTo(u,t),o!=a&&B.ZERO.subTo(t,t)),r.t=u,r.clamp(),c>0&&r.rShiftTo(c,r),o<0&&B.ZERO.subTo(r,r)}}}function Zd(e){var t=it();return this.abs().divRemTo(e,null,t),this.s<0&&t.compareTo(B.ZERO)>0&&e.subTo(t,t),t}function Dr(e){this.m=e}function Xd(e){return e.s<0||e.compareTo(this.m)>=0?e.mod(this.m):e}function Jd(e){return e}function jd(e){e.divRemTo(this.m,null,e)}function tp(e,t,r){e.multiplyTo(t,r),this.reduce(r)}function ep(e,t){e.squareTo(t),this.reduce(t)}Dr.prototype.convert=Xd;Dr.prototype.revert=Jd;Dr.prototype.reduce=jd;Dr.prototype.mulTo=tp;Dr.prototype.sqrTo=ep;function rp(){if(this.t<1)return 0;var e=this.data[0];if(!(e&1))return 0;var t=e&3;return t=t*(2-(e&15)*t)&15,t=t*(2-(e&255)*t)&255,t=t*(2-((e&65535)*t&65535))&65535,t=t*(2-e*t%this.DV)%this.DV,t>0?this.DV-t:-t}function Nr(e){this.m=e,this.mp=e.invDigit(),this.mpl=this.mp&32767,this.mph=this.mp>>15,this.um=(1<<e.DB-15)-1,this.mt2=2*e.t}function np(e){var t=it();return e.abs().dlShiftTo(this.m.t,t),t.divRemTo(this.m,null,t),e.s<0&&t.compareTo(B.ZERO)>0&&this.m.subTo(t,t),t}function ip(e){var t=it();return e.copyTo(t),this.reduce(t),t}function sp(e){for(;e.t<=this.mt2;)e.data[e.t++]=0;for(var t=0;t<this.m.t;++t){var r=e.data[t]&32767,n=r*this.mpl+((r*this.mph+(e.data[t]>>15)*this.mpl&this.um)<<15)&e.DM;for(r=t+this.m.t,e.data[r]+=this.m.am(0,n,e,t,0,this.m.t);e.data[r]>=e.DV;)e.data[r]-=e.DV,e.data[++r]++}e.clamp(),e.drShiftTo(this.m.t,e),e.compareTo(this.m)>=0&&e.subTo(this.m,e)}function op(e,t){e.squareTo(t),this.reduce(t)}function ap(e,t,r){e.multiplyTo(t,r),this.reduce(r)}Nr.prototype.convert=np;Nr.prototype.revert=ip;Nr.prototype.reduce=sp;Nr.prototype.mulTo=ap;Nr.prototype.sqrTo=op;function cp(){return(this.t>0?this.data[0]&1:this.s)==0}function up(e,t){if(e>4294967295||e<1)return B.ONE;var r=it(),n=it(),i=t.convert(this),s=Ti(e)-1;for(i.copyTo(r);--s>=0;)if(t.sqrTo(r,n),(e&1<<s)>0)t.mulTo(n,i,r);else{var o=r;r=n,n=o}return t.revert(r)}function fp(e,t){var r;return e<256||t.isEven()?r=new Dr(t):r=new Nr(t),this.exp(e,r)}B.prototype.copyTo=Nd;B.prototype.fromInt=Pd;B.prototype.fromString=kd;B.prototype.clamp=Ud;B.prototype.dlShiftTo=qd;B.prototype.drShiftTo=Hd;B.prototype.lShiftTo=zd;B.prototype.rShiftTo=Gd;B.prototype.subTo=Wd;B.prototype.multiplyTo=Yd;B.prototype.squareTo=$d;B.prototype.divRemTo=Qd;B.prototype.invDigit=rp;B.prototype.isEven=cp;B.prototype.exp=up;B.prototype.toString=Od;B.prototype.negate=Md;B.prototype.abs=Kd;B.prototype.compareTo=Fd;B.prototype.bitLength=Vd;B.prototype.mod=Zd;B.prototype.modPowInt=fp;B.ZERO=hr(0);B.ONE=hr(1);function lp(){var e=it();return this.copyTo(e),e}function hp(){if(this.s<0){if(this.t==1)return this.data[0]-this.DV;if(this.t==0)return-1}else{if(this.t==1)return this.data[0];if(this.t==0)return 0}return(this.data[1]&(1<<32-this.DB)-1)<<this.DB|this.data[0]}function dp(){return this.t==0?this.s:this.data[0]<<24>>24}function pp(){return this.t==0?this.s:this.data[0]<<16>>16}function yp(e){return Math.floor(Math.LN2*this.DB/Math.log(e))}function mp(){return this.s<0?-1:this.t<=0||this.t==1&&this.data[0]<=0?0:1}function gp(e){if(e==null&&(e=10),this.signum()==0||e<2||e>36)return"0";var t=this.chunkSize(e),r=Math.pow(e,t),n=hr(r),i=it(),s=it(),o="";for(this.divRemTo(n,i,s);i.signum()>0;)o=(r+s.intValue()).toString(e).substr(1)+o,i.divRemTo(n,i,s);return s.intValue().toString(e)+o}function xp(e,t){this.fromInt(0),t==null&&(t=10);for(var r=this.chunkSize(t),n=Math.pow(t,r),i=!1,s=0,o=0,a=0;a<e.length;++a){var c=Nc(e,a);if(c<0){e.charAt(a)=="-"&&this.signum()==0&&(i=!0);continue}o=t*o+c,++s>=r&&(this.dMultiply(n),this.dAddOffset(o,0),s=0,o=0)}s>0&&(this.dMultiply(Math.pow(t,s)),this.dAddOffset(o,0)),i&&B.ZERO.subTo(this,this)}function vp(e,t,r){if(typeof t=="number")if(e<2)this.fromInt(1);else for(this.fromNumber(e,r),this.testBit(e-1)||this.bitwiseTo(B.ONE.shiftLeft(e-1),Eo,this),this.isEven()&&this.dAddOffset(1,0);!this.isProbablePrime(t);)this.dAddOffset(2,0),this.bitLength()>e&&this.subTo(B.ONE.shiftLeft(e-1),this);else{var n=new Array,i=e&7;n.length=(e>>3)+1,t.nextBytes(n),i>0?n[0]&=(1<<i)-1:n[0]=0,this.fromString(n,256)}}function bp(){var e=this.t,t=new Array;t[0]=this.s;var r=this.DB-e*this.DB%8,n,i=0;if(e-- >0)for(r<this.DB&&(n=this.data[e]>>r)!=(this.s&this.DM)>>r&&(t[i++]=n|this.s<<this.DB-r);e>=0;)r<8?(n=(this.data[e]&(1<<r)-1)<<8-r,n|=this.data[--e]>>(r+=this.DB-8)):(n=this.data[e]>>(r-=8)&255,r<=0&&(r+=this.DB,--e)),n&128&&(n|=-256),i==0&&(this.s&128)!=(n&128)&&++i,(i>0||n!=this.s)&&(t[i++]=n);return t}function Ep(e){return this.compareTo(e)==0}function wp(e){return this.compareTo(e)<0?this:e}function Sp(e){return this.compareTo(e)>0?this:e}function Ap(e,t,r){var n,i,s=Math.min(e.t,this.t);for(n=0;n<s;++n)r.data[n]=t(this.data[n],e.data[n]);if(e.t<this.t){for(i=e.s&this.DM,n=s;n<this.t;++n)r.data[n]=t(this.data[n],i);r.t=this.t}else{for(i=this.s&this.DM,n=s;n<e.t;++n)r.data[n]=t(i,e.data[n]);r.t=e.t}r.s=t(this.s,e.s),r.clamp()}function Tp(e,t){return e&t}function Bp(e){var t=it();return this.bitwiseTo(e,Tp,t),t}function Eo(e,t){return e|t}function Ip(e){var t=it();return this.bitwiseTo(e,Eo,t),t}function Pc(e,t){return e^t}function Cp(e){var t=it();return this.bitwiseTo(e,Pc,t),t}function kc(e,t){return e&~t}function _p(e){var t=it();return this.bitwiseTo(e,kc,t),t}function Rp(){for(var e=it(),t=0;t<this.t;++t)e.data[t]=this.DM&~this.data[t];return e.t=this.t,e.s=~this.s,e}function Lp(e){var t=it();return e<0?this.rShiftTo(-e,t):this.lShiftTo(e,t),t}function Dp(e){var t=it();return e<0?this.lShiftTo(-e,t):this.rShiftTo(e,t),t}function Np(e){if(e==0)return-1;var t=0;return e&65535||(e>>=16,t+=16),e&255||(e>>=8,t+=8),e&15||(e>>=4,t+=4),e&3||(e>>=2,t+=2),e&1||++t,t}function Pp(){for(var e=0;e<this.t;++e)if(this.data[e]!=0)return e*this.DB+Np(this.data[e]);return this.s<0?this.t*this.DB:-1}function kp(e){for(var t=0;e!=0;)e&=e-1,++t;return t}function Up(){for(var e=0,t=this.s&this.DM,r=0;r<this.t;++r)e+=kp(this.data[r]^t);return e}function Op(e){var t=Math.floor(e/this.DB);return t>=this.t?this.s!=0:(this.data[t]&1<<e%this.DB)!=0}function Mp(e,t){var r=B.ONE.shiftLeft(e);return this.bitwiseTo(r,t,r),r}function Kp(e){return this.changeBit(e,Eo)}function Fp(e){return this.changeBit(e,kc)}function Vp(e){return this.changeBit(e,Pc)}function qp(e,t){for(var r=0,n=0,i=Math.min(e.t,this.t);r<i;)n+=this.data[r]+e.data[r],t.data[r++]=n&this.DM,n>>=this.DB;if(e.t<this.t){for(n+=e.s;r<this.t;)n+=this.data[r],t.data[r++]=n&this.DM,n>>=this.DB;n+=this.s}else{for(n+=this.s;r<e.t;)n+=e.data[r],t.data[r++]=n&this.DM,n>>=this.DB;n+=e.s}t.s=n<0?-1:0,n>0?t.data[r++]=n:n<-1&&(t.data[r++]=this.DV+n),t.t=r,t.clamp()}function Hp(e){var t=it();return this.addTo(e,t),t}function zp(e){var t=it();return this.subTo(e,t),t}function Gp(e){var t=it();return this.multiplyTo(e,t),t}function Wp(e){var t=it();return this.divRemTo(e,t,null),t}function Yp(e){var t=it();return this.divRemTo(e,null,t),t}function $p(e){var t=it(),r=it();return this.divRemTo(e,t,r),new Array(t,r)}function Qp(e){this.data[this.t]=this.am(0,e-1,this,0,0,this.t),++this.t,this.clamp()}function Zp(e,t){if(e!=0){for(;this.t<=t;)this.data[this.t++]=0;for(this.data[t]+=e;this.data[t]>=this.DV;)this.data[t]-=this.DV,++t>=this.t&&(this.data[this.t++]=0),++this.data[t]}}function Mn(){}function Uc(e){return e}function Xp(e,t,r){e.multiplyTo(t,r)}function Jp(e,t){e.squareTo(t)}Mn.prototype.convert=Uc;Mn.prototype.revert=Uc;Mn.prototype.mulTo=Xp;Mn.prototype.sqrTo=Jp;function jp(e){return this.exp(e,new Mn)}function ty(e,t,r){var n=Math.min(this.t+e.t,t);for(r.s=0,r.t=n;n>0;)r.data[--n]=0;var i;for(i=r.t-this.t;n<i;++n)r.data[n+this.t]=this.am(0,e.data[n],r,n,0,this.t);for(i=Math.min(e.t,t);n<i;++n)this.am(0,e.data[n],r,n,0,t-n);r.clamp()}function ey(e,t,r){--t;var n=r.t=this.t+e.t-t;for(r.s=0;--n>=0;)r.data[n]=0;for(n=Math.max(t-this.t,0);n<e.t;++n)r.data[this.t+n-t]=this.am(t-n,e.data[n],r,0,0,this.t+n-t);r.clamp(),r.drShiftTo(1,r)}function fn(e){this.r2=it(),this.q3=it(),B.ONE.dlShiftTo(2*e.t,this.r2),this.mu=this.r2.divide(e),this.m=e}function ry(e){if(e.s<0||e.t>2*this.m.t)return e.mod(this.m);if(e.compareTo(this.m)<0)return e;var t=it();return e.copyTo(t),this.reduce(t),t}function ny(e){return e}function iy(e){for(e.drShiftTo(this.m.t-1,this.r2),e.t>this.m.t+1&&(e.t=this.m.t+1,e.clamp()),this.mu.multiplyUpperTo(this.r2,this.m.t+1,this.q3),this.m.multiplyLowerTo(this.q3,this.m.t+1,this.r2);e.compareTo(this.r2)<0;)e.dAddOffset(1,this.m.t+1);for(e.subTo(this.r2,e);e.compareTo(this.m)>=0;)e.subTo(this.m,e)}function sy(e,t){e.squareTo(t),this.reduce(t)}function oy(e,t,r){e.multiplyTo(t,r),this.reduce(r)}fn.prototype.convert=ry;fn.prototype.revert=ny;fn.prototype.reduce=iy;fn.prototype.mulTo=oy;fn.prototype.sqrTo=sy;function ay(e,t){var r=e.bitLength(),n,i=hr(1),s;if(r<=0)return i;r<18?n=1:r<48?n=3:r<144?n=4:r<768?n=5:n=6,r<8?s=new Dr(t):t.isEven()?s=new fn(t):s=new Nr(t);var o=new Array,a=3,c=n-1,u=(1<<n)-1;if(o[1]=s.convert(this),n>1){var f=it();for(s.sqrTo(o[1],f);a<=u;)o[a]=it(),s.mulTo(f,o[a-2],o[a]),a+=2}var l=e.t-1,h,y=!0,d=it(),p;for(r=Ti(e.data[l])-1;l>=0;){for(r>=c?h=e.data[l]>>r-c&u:(h=(e.data[l]&(1<<r+1)-1)<<c-r,l>0&&(h|=e.data[l-1]>>this.DB+r-c)),a=n;!(h&1);)h>>=1,--a;if((r-=a)<0&&(r+=this.DB,--l),y)o[h].copyTo(i),y=!1;else{for(;a>1;)s.sqrTo(i,d),s.sqrTo(d,i),a-=2;a>0?s.sqrTo(i,d):(p=i,i=d,d=p),s.mulTo(d,o[h],i)}for(;l>=0&&!(e.data[l]&1<<r);)s.sqrTo(i,d),p=i,i=d,d=p,--r<0&&(r=this.DB-1,--l)}return s.revert(i)}function cy(e){var t=this.s<0?this.negate():this.clone(),r=e.s<0?e.negate():e.clone();if(t.compareTo(r)<0){var n=t;t=r,r=n}var i=t.getLowestSetBit(),s=r.getLowestSetBit();if(s<0)return t;for(i<s&&(s=i),s>0&&(t.rShiftTo(s,t),r.rShiftTo(s,r));t.signum()>0;)(i=t.getLowestSetBit())>0&&t.rShiftTo(i,t),(i=r.getLowestSetBit())>0&&r.rShiftTo(i,r),t.compareTo(r)>=0?(t.subTo(r,t),t.rShiftTo(1,t)):(r.subTo(t,r),r.rShiftTo(1,r));return s>0&&r.lShiftTo(s,r),r}function uy(e){if(e<=0)return 0;var t=this.DV%e,r=this.s<0?e-1:0;if(this.t>0)if(t==0)r=this.data[0]%e;else for(var n=this.t-1;n>=0;--n)r=(t*r+this.data[n])%e;return r}function fy(e){var t=e.isEven();if(this.isEven()&&t||e.signum()==0)return B.ZERO;for(var r=e.clone(),n=this.clone(),i=hr(1),s=hr(0),o=hr(0),a=hr(1);r.signum()!=0;){for(;r.isEven();)r.rShiftTo(1,r),t?((!i.isEven()||!s.isEven())&&(i.addTo(this,i),s.subTo(e,s)),i.rShiftTo(1,i)):s.isEven()||s.subTo(e,s),s.rShiftTo(1,s);for(;n.isEven();)n.rShiftTo(1,n),t?((!o.isEven()||!a.isEven())&&(o.addTo(this,o),a.subTo(e,a)),o.rShiftTo(1,o)):a.isEven()||a.subTo(e,a),a.rShiftTo(1,a);r.compareTo(n)>=0?(r.subTo(n,r),t&&i.subTo(o,i),s.subTo(a,s)):(n.subTo(r,n),t&&o.subTo(i,o),a.subTo(s,a))}if(n.compareTo(B.ONE)!=0)return B.ZERO;if(a.compareTo(e)>=0)return a.subtract(e);if(a.signum()<0)a.addTo(e,a);else return a;return a.signum()<0?a.add(e):a}var Te=[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],ly=(1<<26)/Te[Te.length-1];function hy(e){var t,r=this.abs();if(r.t==1&&r.data[0]<=Te[Te.length-1]){for(t=0;t<Te.length;++t)if(r.data[0]==Te[t])return!0;return!1}if(r.isEven())return!1;for(t=1;t<Te.length;){for(var n=Te[t],i=t+1;i<Te.length&&n<ly;)n*=Te[i++];for(n=r.modInt(n);t<i;)if(n%Te[t++]==0)return!1}return r.millerRabin(e)}function dy(e){var t=this.subtract(B.ONE),r=t.getLowestSetBit();if(r<=0)return!1;for(var n=t.shiftRight(r),i=py(),s,o=0;o<e;++o){do s=new B(this.bitLength(),i);while(s.compareTo(B.ONE)<=0||s.compareTo(t)>=0);var a=s.modPow(n,this);if(a.compareTo(B.ONE)!=0&&a.compareTo(t)!=0){for(var c=1;c++<r&&a.compareTo(t)!=0;)if(a=a.modPowInt(2,this),a.compareTo(B.ONE)==0)return!1;if(a.compareTo(t)!=0)return!1}}return!0}function py(){return{nextBytes:function(e){for(var t=0;t<e.length;++t)e[t]=Math.floor(Math.random()*256)}}}B.prototype.chunkSize=yp;B.prototype.toRadix=gp;B.prototype.fromRadix=xp;B.prototype.fromNumber=vp;B.prototype.bitwiseTo=Ap;B.prototype.changeBit=Mp;B.prototype.addTo=qp;B.prototype.dMultiply=Qp;B.prototype.dAddOffset=Zp;B.prototype.multiplyLowerTo=ty;B.prototype.multiplyUpperTo=ey;B.prototype.modInt=uy;B.prototype.millerRabin=dy;B.prototype.clone=lp;B.prototype.intValue=hp;B.prototype.byteValue=dp;B.prototype.shortValue=pp;B.prototype.signum=mp;B.prototype.toByteArray=bp;B.prototype.equals=Ep;B.prototype.min=wp;B.prototype.max=Sp;B.prototype.and=Bp;B.prototype.or=Ip;B.prototype.xor=Cp;B.prototype.andNot=_p;B.prototype.not=Rp;B.prototype.shiftLeft=Lp;B.prototype.shiftRight=Dp;B.prototype.getLowestSetBit=Pp;B.prototype.bitCount=Up;B.prototype.testBit=Op;B.prototype.setBit=Kp;B.prototype.clearBit=Fp;B.prototype.flipBit=Vp;B.prototype.add=Hp;B.prototype.subtract=zp;B.prototype.multiply=Gp;B.prototype.divide=Wp;B.prototype.remainder=Yp;B.prototype.divideAndRemainder=$p;B.prototype.modPow=ay;B.prototype.modInverse=fy;B.prototype.pow=jp;B.prototype.gcd=cy;B.prototype.isProbablePrime=hy});var qc=ot((S2,Vc)=>{var Oe=ht();Lr();Dt();var Kc=Vc.exports=Oe.sha1=Oe.sha1||{};Oe.md.sha1=Oe.md.algorithms.sha1=Kc;Kc.create=function(){Fc||yy();var e=null,t=Oe.util.createBuffer(),r=new Array(80),n={algorithm:"sha1",blockLength:64,digestLength:20,messageLength:0,fullMessageLength:null,messageLengthSize:8};return n.start=function(){n.messageLength=0,n.fullMessageLength=n.messageLength64=[];for(var i=n.messageLengthSize/4,s=0;s<i;++s)n.fullMessageLength.push(0);return t=Oe.util.createBuffer(),e={h0:1732584193,h1:4023233417,h2:2562383102,h3:271733878,h4:3285377520},n},n.start(),n.update=function(i,s){s==="utf8"&&(i=Oe.util.encodeUtf8(i));var o=i.length;n.messageLength+=o,o=[o/4294967296>>>0,o>>>0];for(var a=n.fullMessageLength.length-1;a>=0;--a)n.fullMessageLength[a]+=o[1],o[1]=o[0]+(n.fullMessageLength[a]/4294967296>>>0),n.fullMessageLength[a]=n.fullMessageLength[a]>>>0,o[0]=o[1]/4294967296>>>0;return t.putBytes(i),Mc(e,r,t),(t.read>2048||t.length()===0)&&t.compact(),n},n.digest=function(){var i=Oe.util.createBuffer();i.putBytes(t.bytes());var s=n.fullMessageLength[n.fullMessageLength.length-1]+n.messageLengthSize,o=s&n.blockLength-1;i.putBytes(wo.substr(0,n.blockLength-o));for(var a,c,u=n.fullMessageLength[0]*8,f=0;f<n.fullMessageLength.length-1;++f)a=n.fullMessageLength[f+1]*8,c=a/4294967296>>>0,u+=c,i.putInt32(u>>>0),u=a>>>0;i.putInt32(u);var l={h0:e.h0,h1:e.h1,h2:e.h2,h3:e.h3,h4:e.h4};Mc(l,r,i);var h=Oe.util.createBuffer();return h.putInt32(l.h0),h.putInt32(l.h1),h.putInt32(l.h2),h.putInt32(l.h3),h.putInt32(l.h4),h},n};var wo=null,Fc=!1;function yy(){wo="\x80",wo+=Oe.util.fillString("\0",64),Fc=!0}function Mc(e,t,r){for(var n,i,s,o,a,c,u,f,l=r.length();l>=64;){for(i=e.h0,s=e.h1,o=e.h2,a=e.h3,c=e.h4,f=0;f<16;++f)n=r.getInt32(),t[f]=n,u=a^s&(o^a),n=(i<<5|i>>>27)+u+c+1518500249+n,c=a,a=o,o=(s<<30|s>>>2)>>>0,s=i,i=n;for(;f<20;++f)n=t[f-3]^t[f-8]^t[f-14]^t[f-16],n=n<<1|n>>>31,t[f]=n,u=a^s&(o^a),n=(i<<5|i>>>27)+u+c+1518500249+n,c=a,a=o,o=(s<<30|s>>>2)>>>0,s=i,i=n;for(;f<32;++f)n=t[f-3]^t[f-8]^t[f-14]^t[f-16],n=n<<1|n>>>31,t[f]=n,u=s^o^a,n=(i<<5|i>>>27)+u+c+1859775393+n,c=a,a=o,o=(s<<30|s>>>2)>>>0,s=i,i=n;for(;f<40;++f)n=t[f-6]^t[f-16]^t[f-28]^t[f-32],n=n<<2|n>>>30,t[f]=n,u=s^o^a,n=(i<<5|i>>>27)+u+c+1859775393+n,c=a,a=o,o=(s<<30|s>>>2)>>>0,s=i,i=n;for(;f<60;++f)n=t[f-6]^t[f-16]^t[f-28]^t[f-32],n=n<<2|n>>>30,t[f]=n,u=s&o|a&(s^o),n=(i<<5|i>>>27)+u+c+2400959708+n,c=a,a=o,o=(s<<30|s>>>2)>>>0,s=i,i=n;for(;f<80;++f)n=t[f-6]^t[f-16]^t[f-28]^t[f-32],n=n<<2|n>>>30,t[f]=n,u=s^o^a,n=(i<<5|i>>>27)+u+c+3395469782+n,c=a,a=o,o=(s<<30|s>>>2)>>>0,s=i,i=n;e.h0=e.h0+i|0,e.h1=e.h1+s|0,e.h2=e.h2+o|0,e.h3=e.h3+a|0,e.h4=e.h4+c|0,l-=64}}});var Gc=ot((A2,zc)=>{var Me=ht();Dt();On();qc();var Hc=zc.exports=Me.pkcs1=Me.pkcs1||{};Hc.encode_rsa_oaep=function(e,t,r){var n,i,s,o;typeof r=="string"?(n=r,i=arguments[3]||void 0,s=arguments[4]||void 0):r&&(n=r.label||void 0,i=r.seed||void 0,s=r.md||void 0,r.mgf1&&r.mgf1.md&&(o=r.mgf1.md)),s?s.start():s=Me.md.sha1.create(),o||(o=s);var a=Math.ceil(e.n.bitLength()/8),c=a-2*s.digestLength-2;if(t.length>c){var u=new Error("RSAES-OAEP input message length is too long.");throw u.length=t.length,u.maxLength=c,u}n||(n=""),s.update(n,"raw");for(var f=s.digest(),l="",h=c-t.length,y=0;y<h;y++)l+="\0";var d=f.getBytes()+l+""+t;if(!i)i=Me.random.getBytes(s.digestLength);else if(i.length!==s.digestLength){var u=new Error("Invalid RSAES-OAEP seed. The seed length must match the digest length.");throw u.seedLength=i.length,u.digestLength=s.digestLength,u}var p=Ii(i,a-s.digestLength-1,o),m=Me.util.xorBytes(d,p,d.length),x=Ii(m,s.digestLength,o),E=Me.util.xorBytes(i,x,i.length);return"\0"+E+m};Hc.decode_rsa_oaep=function(e,t,r){var n,i,s;typeof r=="string"?(n=r,i=arguments[3]||void 0):r&&(n=r.label||void 0,i=r.md||void 0,r.mgf1&&r.mgf1.md&&(s=r.mgf1.md));var o=Math.ceil(e.n.bitLength()/8);if(t.length!==o){var m=new Error("RSAES-OAEP encoded message length is invalid.");throw m.length=t.length,m.expectedLength=o,m}if(i===void 0?i=Me.md.sha1.create():i.start(),s||(s=i),o<2*i.digestLength+2)throw new Error("RSAES-OAEP key is too short for the hash function.");n||(n=""),i.update(n,"raw");for(var a=i.digest().getBytes(),c=t.charAt(0),u=t.substring(1,i.digestLength+1),f=t.substring(1+i.digestLength),l=Ii(f,i.digestLength,s),h=Me.util.xorBytes(u,l,u.length),y=Ii(h,o-i.digestLength-1,s),d=Me.util.xorBytes(f,y,f.length),p=d.substring(0,i.digestLength),m=c!=="\0",x=0;x<i.digestLength;++x)m|=a.charAt(x)!==p.charAt(x);for(var E=1,b=i.digestLength,R=i.digestLength;R<d.length;R++){var w=d.charCodeAt(R),S=w&1^1,L=E?65534:0;m|=w&L,E=E&S,b+=E}if(m||d.charCodeAt(b)!==1)throw new Error("Invalid RSAES-OAEP padding.");return d.substring(b+1)};function Ii(e,t,r){r||(r=Me.md.sha1.create());for(var n="",i=Math.ceil(t/r.digestLength),s=0;s<i;++s){var o=String.fromCharCode(s>>24&255,s>>16&255,s>>8&255,s&255);r.start(),r.update(e+o),n+=r.digest().getBytes()}return n.substring(0,t)}});var Wc=ot((T2,So)=>{var dr=ht();Dt();Bi();On();(function(){if(dr.prime){So.exports=dr.prime;return}var e=So.exports=dr.prime=dr.prime||{},t=dr.jsbn.BigInteger,r=[6,4,2,4,2,4,6,2],n=new t(null);n.fromInt(30);var i=function(l,h){return l|h};e.generateProbablePrime=function(l,h,y){typeof h=="function"&&(y=h,h={}),h=h||{};var d=h.algorithm||"PRIMEINC";typeof d=="string"&&(d={name:d}),d.options=d.options||{};var p=h.prng||dr.random,m={nextBytes:function(x){for(var E=p.getBytesSync(x.length),b=0;b<x.length;++b)x[b]=E.charCodeAt(b)}};if(d.name==="PRIMEINC")return s(l,m,d.options,y);throw new Error("Invalid prime generation algorithm: "+d.name)};function s(l,h,y,d){return"workers"in y?c(l,h,y,d):o(l,h,y,d)}function o(l,h,y,d){var p=u(l,h),m=0,x=f(p.bitLength());"millerRabinTests"in y&&(x=y.millerRabinTests);var E=10;"maxBlockTime"in y&&(E=y.maxBlockTime),a(p,l,h,m,x,E,d)}function a(l,h,y,d,p,m,x){var E=+new Date;do{if(l.bitLength()>h&&(l=u(h,y)),l.isProbablePrime(p))return x(null,l);l.dAddOffset(r[d++%8],0)}while(m<0||+new Date-E<m);dr.util.setImmediate(function(){a(l,h,y,d,p,m,x)})}function c(l,h,y,d){if(typeof Worker>"u")return o(l,h,y,d);var p=u(l,h),m=y.workers,x=y.workLoad||100,E=x*30/8,b=y.workerScript||"forge/prime.worker.js";if(m===-1)return dr.util.estimateCores(function(w,S){w&&(S=2),m=S-1,R()});R();function R(){m=Math.max(1,m);for(var w=[],S=0;S<m;++S)w[S]=new Worker(b);for(var L=m,S=0;S<m;++S)w[S].addEventListener("message",Y);var D=!1;function Y(W){if(!D){--L;var q=W.data;if(q.found){for(var j=0;j<w.length;++j)w[j].terminate();return D=!0,d(null,new t(q.prime,16))}p.bitLength()>l&&(p=u(l,h));var lt=p.toString(16);W.target.postMessage({hex:lt,workLoad:x}),p.dAddOffset(E,0)}}}}function u(l,h){var y=new t(l,h),d=l-1;return y.testBit(d)||y.bitwiseTo(t.ONE.shiftLeft(d),i,y),y.dAddOffset(31-y.mod(n).byteValue(),0),y}function f(l){return l<=100?27:l<=150?18:l<=200?15:l<=250?12:l<=300?9:l<=350?8:l<=400?7:l<=500?6:l<=600?5:l<=800?4:l<=1250?3:2}})()});var _i=ot((B2,jc)=>{var V=ht();Un();Bi();di();Gc();Wc();On();Dt();typeof nt>"u"&&(nt=V.jsbn.BigInteger);var nt,Ao=V.util.isNodejs?bi():null,v=V.asn1,xe=V.util;V.pki=V.pki||{};jc.exports=V.pki.rsa=V.rsa=V.rsa||{};var $=V.pki,my=[6,4,2,4,2,4,6,2],gy={name:"PrivateKeyInfo",tagClass:v.Class.UNIVERSAL,type:v.Type.SEQUENCE,constructed:!0,value:[{name:"PrivateKeyInfo.version",tagClass:v.Class.UNIVERSAL,type:v.Type.INTEGER,constructed:!1,capture:"privateKeyVersion"},{name:"PrivateKeyInfo.privateKeyAlgorithm",tagClass:v.Class.UNIVERSAL,type:v.Type.SEQUENCE,constructed:!0,value:[{name:"AlgorithmIdentifier.algorithm",tagClass:v.Class.UNIVERSAL,type:v.Type.OID,constructed:!1,capture:"privateKeyOid"}]},{name:"PrivateKeyInfo",tagClass:v.Class.UNIVERSAL,type:v.Type.OCTETSTRING,constructed:!1,capture:"privateKey"}]},xy={name:"RSAPrivateKey",tagClass:v.Class.UNIVERSAL,type:v.Type.SEQUENCE,constructed:!0,value:[{name:"RSAPrivateKey.version",tagClass:v.Class.UNIVERSAL,type:v.Type.INTEGER,constructed:!1,capture:"privateKeyVersion"},{name:"RSAPrivateKey.modulus",tagClass:v.Class.UNIVERSAL,type:v.Type.INTEGER,constructed:!1,capture:"privateKeyModulus"},{name:"RSAPrivateKey.publicExponent",tagClass:v.Class.UNIVERSAL,type:v.Type.INTEGER,constructed:!1,capture:"privateKeyPublicExponent"},{name:"RSAPrivateKey.privateExponent",tagClass:v.Class.UNIVERSAL,type:v.Type.INTEGER,constructed:!1,capture:"privateKeyPrivateExponent"},{name:"RSAPrivateKey.prime1",tagClass:v.Class.UNIVERSAL,type:v.Type.INTEGER,constructed:!1,capture:"privateKeyPrime1"},{name:"RSAPrivateKey.prime2",tagClass:v.Class.UNIVERSAL,type:v.Type.INTEGER,constructed:!1,capture:"privateKeyPrime2"},{name:"RSAPrivateKey.exponent1",tagClass:v.Class.UNIVERSAL,type:v.Type.INTEGER,constructed:!1,capture:"privateKeyExponent1"},{name:"RSAPrivateKey.exponent2",tagClass:v.Class.UNIVERSAL,type:v.Type.INTEGER,constructed:!1,capture:"privateKeyExponent2"},{name:"RSAPrivateKey.coefficient",tagClass:v.Class.UNIVERSAL,type:v.Type.INTEGER,constructed:!1,capture:"privateKeyCoefficient"}]},vy={name:"RSAPublicKey",tagClass:v.Class.UNIVERSAL,type:v.Type.SEQUENCE,constructed:!0,value:[{name:"RSAPublicKey.modulus",tagClass:v.Class.UNIVERSAL,type:v.Type.INTEGER,constructed:!1,capture:"publicKeyModulus"},{name:"RSAPublicKey.exponent",tagClass:v.Class.UNIVERSAL,type:v.Type.INTEGER,constructed:!1,capture:"publicKeyExponent"}]},by=V.pki.rsa.publicKeyValidator={name:"SubjectPublicKeyInfo",tagClass:v.Class.UNIVERSAL,type:v.Type.SEQUENCE,constructed:!0,captureAsn1:"subjectPublicKeyInfo",value:[{name:"SubjectPublicKeyInfo.AlgorithmIdentifier",tagClass:v.Class.UNIVERSAL,type:v.Type.SEQUENCE,constructed:!0,value:[{name:"AlgorithmIdentifier.algorithm",tagClass:v.Class.UNIVERSAL,type:v.Type.OID,constructed:!1,capture:"publicKeyOid"}]},{name:"SubjectPublicKeyInfo.subjectPublicKey",tagClass:v.Class.UNIVERSAL,type:v.Type.BITSTRING,constructed:!1,value:[{name:"SubjectPublicKeyInfo.subjectPublicKey.RSAPublicKey",tagClass:v.Class.UNIVERSAL,type:v.Type.SEQUENCE,constructed:!0,optional:!0,captureAsn1:"rsaPublicKey"}]}]},Ey={name:"DigestInfo",tagClass:v.Class.UNIVERSAL,type:v.Type.SEQUENCE,constructed:!0,value:[{name:"DigestInfo.DigestAlgorithm",tagClass:v.Class.UNIVERSAL,type:v.Type.SEQUENCE,constructed:!0,value:[{name:"DigestInfo.DigestAlgorithm.algorithmIdentifier",tagClass:v.Class.UNIVERSAL,type:v.Type.OID,constructed:!1,capture:"algorithmIdentifier"},{name:"DigestInfo.DigestAlgorithm.parameters",tagClass:v.Class.UNIVERSAL,type:v.Type.NULL,capture:"parameters",optional:!0,constructed:!1}]},{name:"DigestInfo.digest",tagClass:v.Class.UNIVERSAL,type:v.Type.OCTETSTRING,constructed:!1,capture:"digest"}]},wy=function(e){var t;if(e.algorithm in $.oids)t=$.oids[e.algorithm];else{var r=new Error("Unknown message digest algorithm.");throw r.algorithm=e.algorithm,r}var n=v.oidToDer(t).getBytes(),i=v.create(v.Class.UNIVERSAL,v.Type.SEQUENCE,!0,[]),s=v.create(v.Class.UNIVERSAL,v.Type.SEQUENCE,!0,[]);s.value.push(v.create(v.Class.UNIVERSAL,v.Type.OID,!1,n)),s.value.push(v.create(v.Class.UNIVERSAL,v.Type.NULL,!1,""));var o=v.create(v.Class.UNIVERSAL,v.Type.OCTETSTRING,!1,e.digest().getBytes());return i.value.push(s),i.value.push(o),v.toDer(i).getBytes()},Xc=function(e,t,r){if(r)return e.modPow(t.e,t.n);if(!t.p||!t.q)return e.modPow(t.d,t.n);t.dP||(t.dP=t.d.mod(t.p.subtract(nt.ONE))),t.dQ||(t.dQ=t.d.mod(t.q.subtract(nt.ONE))),t.qInv||(t.qInv=t.q.modInverse(t.p));var n;do n=new nt(V.util.bytesToHex(V.random.getBytes(t.n.bitLength()/8)),16);while(n.compareTo(t.n)>=0||!n.gcd(t.n).equals(nt.ONE));e=e.multiply(n.modPow(t.e,t.n)).mod(t.n);for(var i=e.mod(t.p).modPow(t.dP,t.p),s=e.mod(t.q).modPow(t.dQ,t.q);i.compareTo(s)<0;)i=i.add(t.p);var o=i.subtract(s).multiply(t.qInv).mod(t.p).multiply(t.q).add(s);return o=o.multiply(n.modInverse(t.n)).mod(t.n),o};$.rsa.encrypt=function(e,t,r){var n=r,i,s=Math.ceil(t.n.bitLength()/8);r!==!1&&r!==!0?(n=r===2,i=Jc(e,t,r)):(i=V.util.createBuffer(),i.putBytes(e));for(var o=new nt(i.toHex(),16),a=Xc(o,t,n),c=a.toString(16),u=V.util.createBuffer(),f=s-Math.ceil(c.length/2);f>0;)u.putByte(0),--f;return u.putBytes(V.util.hexToBytes(c)),u.getBytes()};$.rsa.decrypt=function(e,t,r,n){var i=Math.ceil(t.n.bitLength()/8);if(e.length!==i){var s=new Error("Encrypted message length is invalid.");throw s.length=e.length,s.expected=i,s}var o=new nt(V.util.createBuffer(e).toHex(),16);if(o.compareTo(t.n)>=0)throw new Error("Encrypted message is invalid.");for(var a=Xc(o,t,r),c=a.toString(16),u=V.util.createBuffer(),f=i-Math.ceil(c.length/2);f>0;)u.putByte(0),--f;return u.putBytes(V.util.hexToBytes(c)),n!==!1?Ci(u.getBytes(),t,r):u.getBytes()};$.rsa.createKeyPairGenerationState=function(e,t,r){typeof e=="string"&&(e=parseInt(e,10)),e=e||2048,r=r||{};var n=r.prng||V.random,i={nextBytes:function(a){for(var c=n.getBytesSync(a.length),u=0;u<a.length;++u)a[u]=c.charCodeAt(u)}},s=r.algorithm||"PRIMEINC",o;if(s==="PRIMEINC")o={algorithm:s,state:0,bits:e,rng:i,eInt:t||65537,e:new nt(null),p:null,q:null,qBits:e>>1,pBits:e-(e>>1),pqState:0,num:null,keys:null},o.e.fromInt(o.eInt);else throw new Error("Invalid key generation algorithm: "+s);return o};$.rsa.stepKeyPairGenerationState=function(e,t){"algorithm"in e||(e.algorithm="PRIMEINC");var r=new nt(null);r.fromInt(30);for(var n=0,i=function(l,h){return l|h},s=+new Date,o,a=0;e.keys===null&&(t<=0||a<t);){if(e.state===0){var c=e.p===null?e.pBits:e.qBits,u=c-1;e.pqState===0?(e.num=new nt(c,e.rng),e.num.testBit(u)||e.num.bitwiseTo(nt.ONE.shiftLeft(u),i,e.num),e.num.dAddOffset(31-e.num.mod(r).byteValue(),0),n=0,++e.pqState):e.pqState===1?e.num.bitLength()>c?e.pqState=0:e.num.isProbablePrime(Ay(e.num.bitLength()))?++e.pqState:e.num.dAddOffset(my[n++%8],0):e.pqState===2?e.pqState=e.num.subtract(nt.ONE).gcd(e.e).compareTo(nt.ONE)===0?3:0:e.pqState===3&&(e.pqState=0,e.p===null?e.p=e.num:e.q=e.num,e.p!==null&&e.q!==null&&++e.state,e.num=null)}else if(e.state===1)e.p.compareTo(e.q)<0&&(e.num=e.p,e.p=e.q,e.q=e.num),++e.state;else if(e.state===2)e.p1=e.p.subtract(nt.ONE),e.q1=e.q.subtract(nt.ONE),e.phi=e.p1.multiply(e.q1),++e.state;else if(e.state===3)e.phi.gcd(e.e).compareTo(nt.ONE)===0?++e.state:(e.p=null,e.q=null,e.state=0);else if(e.state===4)e.n=e.p.multiply(e.q),e.n.bitLength()===e.bits?++e.state:(e.q=null,e.state=0);else if(e.state===5){var f=e.e.modInverse(e.phi);e.keys={privateKey:$.rsa.setPrivateKey(e.n,e.e,f,e.p,e.q,f.mod(e.p1),f.mod(e.q1),e.q.modInverse(e.p)),publicKey:$.rsa.setPublicKey(e.n,e.e)}}o=+new Date,a+=o-s,s=o}return e.keys!==null};$.rsa.generateKeyPair=function(e,t,r,n){if(arguments.length===1?typeof e=="object"?(r=e,e=void 0):typeof e=="function"&&(n=e,e=void 0):arguments.length===2?typeof e=="number"?typeof t=="function"?(n=t,t=void 0):typeof t!="number"&&(r=t,t=void 0):(r=e,n=t,e=void 0,t=void 0):arguments.length===3&&(typeof t=="number"?typeof r=="function"&&(n=r,r=void 0):(n=r,r=t,t=void 0)),r=r||{},e===void 0&&(e=r.bits||2048),t===void 0&&(t=r.e||65537),!V.options.usePureJavaScript&&!r.prng&&e>=256&&e<=16384&&(t===65537||t===3)){if(n){if(Yc("generateKeyPair"))return Ao.generateKeyPair("rsa",{modulusLength:e,publicExponent:t,publicKeyEncoding:{type:"spki",format:"pem"},privateKeyEncoding:{type:"pkcs8",format:"pem"}},function(a,c,u){if(a)return n(a);n(null,{privateKey:$.privateKeyFromPem(u),publicKey:$.publicKeyFromPem(c)})});if($c("generateKey")&&$c("exportKey"))return xe.globalScope.crypto.subtle.generateKey({name:"RSASSA-PKCS1-v1_5",modulusLength:e,publicExponent:Zc(t),hash:{name:"SHA-256"}},!0,["sign","verify"]).then(function(a){return xe.globalScope.crypto.subtle.exportKey("pkcs8",a.privateKey)}).then(void 0,function(a){n(a)}).then(function(a){if(a){var c=$.privateKeyFromAsn1(v.fromDer(V.util.createBuffer(a)));n(null,{privateKey:c,publicKey:$.setRsaPublicKey(c.n,c.e)})}});if(Qc("generateKey")&&Qc("exportKey")){var i=xe.globalScope.msCrypto.subtle.generateKey({name:"RSASSA-PKCS1-v1_5",modulusLength:e,publicExponent:Zc(t),hash:{name:"SHA-256"}},!0,["sign","verify"]);i.oncomplete=function(a){var c=a.target.result,u=xe.globalScope.msCrypto.subtle.exportKey("pkcs8",c.privateKey);u.oncomplete=function(f){var l=f.target.result,h=$.privateKeyFromAsn1(v.fromDer(V.util.createBuffer(l)));n(null,{privateKey:h,publicKey:$.setRsaPublicKey(h.n,h.e)})},u.onerror=function(f){n(f)}},i.onerror=function(a){n(a)};return}}else if(Yc("generateKeyPairSync")){var s=Ao.generateKeyPairSync("rsa",{modulusLength:e,publicExponent:t,publicKeyEncoding:{type:"spki",format:"pem"},privateKeyEncoding:{type:"pkcs8",format:"pem"}});return{privateKey:$.privateKeyFromPem(s.privateKey),publicKey:$.publicKeyFromPem(s.publicKey)}}}var o=$.rsa.createKeyPairGenerationState(e,t,r);if(!n)return $.rsa.stepKeyPairGenerationState(o,0),o.keys;Sy(o,r,n)};$.setRsaPublicKey=$.rsa.setPublicKey=function(e,t){var r={n:e,e:t};return r.encrypt=function(n,i,s){if(typeof i=="string"?i=i.toUpperCase():i===void 0&&(i="RSAES-PKCS1-V1_5"),i==="RSAES-PKCS1-V1_5")i={encode:function(a,c,u){return Jc(a,c,2).getBytes()}};else if(i==="RSA-OAEP"||i==="RSAES-OAEP")i={encode:function(a,c){return V.pkcs1.encode_rsa_oaep(c,a,s)}};else if(["RAW","NONE","NULL",null].indexOf(i)!==-1)i={encode:function(a){return a}};else if(typeof i=="string")throw new Error('Unsupported encryption scheme: "'+i+'".');var o=i.encode(n,r,!0);return $.rsa.encrypt(o,r,!0)},r.verify=function(n,i,s,o){typeof s=="string"?s=s.toUpperCase():s===void 0&&(s="RSASSA-PKCS1-V1_5"),o===void 0&&(o={_parseAllDigestBytes:!0}),"_parseAllDigestBytes"in o||(o._parseAllDigestBytes=!0),s==="RSASSA-PKCS1-V1_5"?s={verify:function(c,u){u=Ci(u,r,!0);var f=v.fromDer(u,{parseAllBytes:o._parseAllDigestBytes}),l={},h=[];if(!v.validate(f,Ey,l,h)){var y=new Error("ASN.1 object does not contain a valid RSASSA-PKCS1-v1_5 DigestInfo value.");throw y.errors=h,y}var d=v.derToOid(l.algorithmIdentifier);if(!(d===V.oids.md2||d===V.oids.md5||d===V.oids.sha1||d===V.oids.sha224||d===V.oids.sha256||d===V.oids.sha384||d===V.oids.sha512||d===V.oids["sha512-224"]||d===V.oids["sha512-256"])){var y=new Error("Unknown RSASSA-PKCS1-v1_5 DigestAlgorithm identifier.");throw y.oid=d,y}if((d===V.oids.md2||d===V.oids.md5)&&!("parameters"in l))throw new Error("ASN.1 object does not contain a valid RSASSA-PKCS1-v1_5 DigestInfo value. Missing algorithm identifer NULL parameters.");return c===l.digest}}:(s==="NONE"||s==="NULL"||s===null)&&(s={verify:function(c,u){return u=Ci(u,r,!0),c===u}});var a=$.rsa.decrypt(i,r,!0,!1);return s.verify(n,a,r.n.bitLength())},r};$.setRsaPrivateKey=$.rsa.setPrivateKey=function(e,t,r,n,i,s,o,a){var c={n:e,e:t,d:r,p:n,q:i,dP:s,dQ:o,qInv:a};return c.decrypt=function(u,f,l){typeof f=="string"?f=f.toUpperCase():f===void 0&&(f="RSAES-PKCS1-V1_5");var h=$.rsa.decrypt(u,c,!1,!1);if(f==="RSAES-PKCS1-V1_5")f={decode:Ci};else if(f==="RSA-OAEP"||f==="RSAES-OAEP")f={decode:function(y,d){return V.pkcs1.decode_rsa_oaep(d,y,l)}};else if(["RAW","NONE","NULL",null].indexOf(f)!==-1)f={decode:function(y){return y}};else throw new Error('Unsupported encryption scheme: "'+f+'".');return f.decode(h,c,!1)},c.sign=function(u,f){var l=!1;typeof f=="string"&&(f=f.toUpperCase()),f===void 0||f==="RSASSA-PKCS1-V1_5"?(f={encode:wy},l=1):(f==="NONE"||f==="NULL"||f===null)&&(f={encode:function(){return u}},l=1);var h=f.encode(u,c.n.bitLength());return $.rsa.encrypt(h,c,l)},c};$.wrapRsaPrivateKey=function(e){return v.create(v.Class.UNIVERSAL,v.Type.SEQUENCE,!0,[v.create(v.Class.UNIVERSAL,v.Type.INTEGER,!1,v.integerToDer(0).getBytes()),v.create(v.Class.UNIVERSAL,v.Type.SEQUENCE,!0,[v.create(v.Class.UNIVERSAL,v.Type.OID,!1,v.oidToDer($.oids.rsaEncryption).getBytes()),v.create(v.Class.UNIVERSAL,v.Type.NULL,!1,"")]),v.create(v.Class.UNIVERSAL,v.Type.OCTETSTRING,!1,v.toDer(e).getBytes())])};$.privateKeyFromAsn1=function(e){var t={},r=[];if(v.validate(e,gy,t,r)&&(e=v.fromDer(V.util.createBuffer(t.privateKey))),t={},r=[],!v.validate(e,xy,t,r)){var n=new Error("Cannot read private key. ASN.1 object does not contain an RSAPrivateKey.");throw n.errors=r,n}var i,s,o,a,c,u,f,l;return i=V.util.createBuffer(t.privateKeyModulus).toHex(),s=V.util.createBuffer(t.privateKeyPublicExponent).toHex(),o=V.util.createBuffer(t.privateKeyPrivateExponent).toHex(),a=V.util.createBuffer(t.privateKeyPrime1).toHex(),c=V.util.createBuffer(t.privateKeyPrime2).toHex(),u=V.util.createBuffer(t.privateKeyExponent1).toHex(),f=V.util.createBuffer(t.privateKeyExponent2).toHex(),l=V.util.createBuffer(t.privateKeyCoefficient).toHex(),$.setRsaPrivateKey(new nt(i,16),new nt(s,16),new nt(o,16),new nt(a,16),new nt(c,16),new nt(u,16),new nt(f,16),new nt(l,16))};$.privateKeyToAsn1=$.privateKeyToRSAPrivateKey=function(e){return v.create(v.Class.UNIVERSAL,v.Type.SEQUENCE,!0,[v.create(v.Class.UNIVERSAL,v.Type.INTEGER,!1,v.integerToDer(0).getBytes()),v.create(v.Class.UNIVERSAL,v.Type.INTEGER,!1,Ke(e.n)),v.create(v.Class.UNIVERSAL,v.Type.INTEGER,!1,Ke(e.e)),v.create(v.Class.UNIVERSAL,v.Type.INTEGER,!1,Ke(e.d)),v.create(v.Class.UNIVERSAL,v.Type.INTEGER,!1,Ke(e.p)),v.create(v.Class.UNIVERSAL,v.Type.INTEGER,!1,Ke(e.q)),v.create(v.Class.UNIVERSAL,v.Type.INTEGER,!1,Ke(e.dP)),v.create(v.Class.UNIVERSAL,v.Type.INTEGER,!1,Ke(e.dQ)),v.create(v.Class.UNIVERSAL,v.Type.INTEGER,!1,Ke(e.qInv))])};$.publicKeyFromAsn1=function(e){var t={},r=[];if(v.validate(e,by,t,r)){var n=v.derToOid(t.publicKeyOid);if(n!==$.oids.rsaEncryption){var i=new Error("Cannot read public key. Unknown OID.");throw i.oid=n,i}e=t.rsaPublicKey}if(r=[],!v.validate(e,vy,t,r)){var i=new Error("Cannot read public key. ASN.1 object does not contain an RSAPublicKey.");throw i.errors=r,i}var s=V.util.createBuffer(t.publicKeyModulus).toHex(),o=V.util.createBuffer(t.publicKeyExponent).toHex();return $.setRsaPublicKey(new nt(s,16),new nt(o,16))};$.publicKeyToAsn1=$.publicKeyToSubjectPublicKeyInfo=function(e){return v.create(v.Class.UNIVERSAL,v.Type.SEQUENCE,!0,[v.create(v.Class.UNIVERSAL,v.Type.SEQUENCE,!0,[v.create(v.Class.UNIVERSAL,v.Type.OID,!1,v.oidToDer($.oids.rsaEncryption).getBytes()),v.create(v.Class.UNIVERSAL,v.Type.NULL,!1,"")]),v.create(v.Class.UNIVERSAL,v.Type.BITSTRING,!1,[$.publicKeyToRSAPublicKey(e)])])};$.publicKeyToRSAPublicKey=function(e){return v.create(v.Class.UNIVERSAL,v.Type.SEQUENCE,!0,[v.create(v.Class.UNIVERSAL,v.Type.INTEGER,!1,Ke(e.n)),v.create(v.Class.UNIVERSAL,v.Type.INTEGER,!1,Ke(e.e))])};function Jc(e,t,r){var n=V.util.createBuffer(),i=Math.ceil(t.n.bitLength()/8);if(e.length>i-11){var s=new Error("Message is too long for PKCS#1 v1.5 padding.");throw s.length=e.length,s.max=i-11,s}n.putByte(0),n.putByte(r);var o=i-3-e.length,a;if(r===0||r===1){a=r===0?0:255;for(var c=0;c<o;++c)n.putByte(a)}else for(;o>0;){for(var u=0,f=V.random.getBytes(o),c=0;c<o;++c)a=f.charCodeAt(c),a===0?++u:n.putByte(a);o=u}return n.putByte(0),n.putBytes(e),n}function Ci(e,t,r,n){var i=Math.ceil(t.n.bitLength()/8),s=V.util.createBuffer(e),o=s.getByte(),a=s.getByte();if(o!==0||r&&a!==0&&a!==1||!r&&a!=2||r&&a===0&&typeof n>"u")throw new Error("Encryption block is invalid.");var c=0;if(a===0){c=i-3-n;for(var u=0;u<c;++u)if(s.getByte()!==0)throw new Error("Encryption block is invalid.")}else if(a===1)for(c=0;s.length()>1;){if(s.getByte()!==255){--s.read;break}++c}else if(a===2)for(c=0;s.length()>1;){if(s.getByte()===0){--s.read;break}++c}var f=s.getByte();if(f!==0||c!==i-3-s.length())throw new Error("Encryption block is invalid.");return s.getBytes()}function Sy(e,t,r){typeof t=="function"&&(r=t,t={}),t=t||{};var n={algorithm:{name:t.algorithm||"PRIMEINC",options:{workers:t.workers||2,workLoad:t.workLoad||100,workerScript:t.workerScript}}};"prng"in t&&(n.prng=t.prng),i();function i(){s(e.pBits,function(a,c){if(a)return r(a);if(e.p=c,e.q!==null)return o(a,e.q);s(e.qBits,o)})}function s(a,c){V.prime.generateProbablePrime(a,n,c)}function o(a,c){if(a)return r(a);if(e.q=c,e.p.compareTo(e.q)<0){var u=e.p;e.p=e.q,e.q=u}if(e.p.subtract(nt.ONE).gcd(e.e).compareTo(nt.ONE)!==0){e.p=null,i();return}if(e.q.subtract(nt.ONE).gcd(e.e).compareTo(nt.ONE)!==0){e.q=null,s(e.qBits,o);return}if(e.p1=e.p.subtract(nt.ONE),e.q1=e.q.subtract(nt.ONE),e.phi=e.p1.multiply(e.q1),e.phi.gcd(e.e).compareTo(nt.ONE)!==0){e.p=e.q=null,i();return}if(e.n=e.p.multiply(e.q),e.n.bitLength()!==e.bits){e.q=null,s(e.qBits,o);return}var f=e.e.modInverse(e.phi);e.keys={privateKey:$.rsa.setPrivateKey(e.n,e.e,f,e.p,e.q,f.mod(e.p1),f.mod(e.q1),e.q.modInverse(e.p)),publicKey:$.rsa.setPublicKey(e.n,e.e)},r(null,e.keys)}}function Ke(e){var t=e.toString(16);t[0]>="8"&&(t="00"+t);var r=V.util.hexToBytes(t);return r.length>1&&(r.charCodeAt(0)===0&&!(r.charCodeAt(1)&128)||r.charCodeAt(0)===255&&(r.charCodeAt(1)&128)===128)?r.substr(1):r}function Ay(e){return e<=100?27:e<=150?18:e<=200?15:e<=250?12:e<=300?9:e<=350?8:e<=400?7:e<=500?6:e<=600?5:e<=800?4:e<=1250?3:2}function Yc(e){return V.util.isNodejs&&typeof Ao[e]=="function"}function $c(e){return typeof xe.globalScope<"u"&&typeof xe.globalScope.crypto=="object"&&typeof xe.globalScope.crypto.subtle=="object"&&typeof xe.globalScope.crypto.subtle[e]=="function"}function Qc(e){return typeof xe.globalScope<"u"&&typeof xe.globalScope.msCrypto=="object"&&typeof xe.globalScope.msCrypto.subtle=="object"&&typeof xe.globalScope.msCrypto.subtle[e]=="function"}function Zc(e){for(var t=V.util.hexToBytes(e.toString(16)),r=new Uint8Array(t.length),n=0;n<t.length;++n)r[n]=t.charCodeAt(n);return r}});var su=ot((I2,iu)=>{var O=ht();yo();Un();uc();Lr();di();pc();gc();On();_c();_i();Dt();typeof tu>"u"&&(tu=O.jsbn.BigInteger);var tu,A=O.asn1,Q=O.pki=O.pki||{};iu.exports=Q.pbe=O.pbe=O.pbe||{};var Pr=Q.oids,Ty={name:"EncryptedPrivateKeyInfo",tagClass:A.Class.UNIVERSAL,type:A.Type.SEQUENCE,constructed:!0,value:[{name:"EncryptedPrivateKeyInfo.encryptionAlgorithm",tagClass:A.Class.UNIVERSAL,type:A.Type.SEQUENCE,constructed:!0,value:[{name:"AlgorithmIdentifier.algorithm",tagClass:A.Class.UNIVERSAL,type:A.Type.OID,constructed:!1,capture:"encryptionOid"},{name:"AlgorithmIdentifier.parameters",tagClass:A.Class.UNIVERSAL,type:A.Type.SEQUENCE,constructed:!0,captureAsn1:"encryptionParams"}]},{name:"EncryptedPrivateKeyInfo.encryptedData",tagClass:A.Class.UNIVERSAL,type:A.Type.OCTETSTRING,constructed:!1,capture:"encryptedData"}]},By={name:"PBES2Algorithms",tagClass:A.Class.UNIVERSAL,type:A.Type.SEQUENCE,constructed:!0,value:[{name:"PBES2Algorithms.keyDerivationFunc",tagClass:A.Class.UNIVERSAL,type:A.Type.SEQUENCE,constructed:!0,value:[{name:"PBES2Algorithms.keyDerivationFunc.oid",tagClass:A.Class.UNIVERSAL,type:A.Type.OID,constructed:!1,capture:"kdfOid"},{name:"PBES2Algorithms.params",tagClass:A.Class.UNIVERSAL,type:A.Type.SEQUENCE,constructed:!0,value:[{name:"PBES2Algorithms.params.salt",tagClass:A.Class.UNIVERSAL,type:A.Type.OCTETSTRING,constructed:!1,capture:"kdfSalt"},{name:"PBES2Algorithms.params.iterationCount",tagClass:A.Class.UNIVERSAL,type:A.Type.INTEGER,constructed:!1,capture:"kdfIterationCount"},{name:"PBES2Algorithms.params.keyLength",tagClass:A.Class.UNIVERSAL,type:A.Type.INTEGER,constructed:!1,optional:!0,capture:"keyLength"},{name:"PBES2Algorithms.params.prf",tagClass:A.Class.UNIVERSAL,type:A.Type.SEQUENCE,constructed:!0,optional:!0,value:[{name:"PBES2Algorithms.params.prf.algorithm",tagClass:A.Class.UNIVERSAL,type:A.Type.OID,constructed:!1,capture:"prfOid"}]}]}]},{name:"PBES2Algorithms.encryptionScheme",tagClass:A.Class.UNIVERSAL,type:A.Type.SEQUENCE,constructed:!0,value:[{name:"PBES2Algorithms.encryptionScheme.oid",tagClass:A.Class.UNIVERSAL,type:A.Type.OID,constructed:!1,capture:"encOid"},{name:"PBES2Algorithms.encryptionScheme.iv",tagClass:A.Class.UNIVERSAL,type:A.Type.OCTETSTRING,constructed:!1,capture:"encIv"}]}]},Iy={name:"pkcs-12PbeParams",tagClass:A.Class.UNIVERSAL,type:A.Type.SEQUENCE,constructed:!0,value:[{name:"pkcs-12PbeParams.salt",tagClass:A.Class.UNIVERSAL,type:A.Type.OCTETSTRING,constructed:!1,capture:"salt"},{name:"pkcs-12PbeParams.iterations",tagClass:A.Class.UNIVERSAL,type:A.Type.INTEGER,constructed:!1,capture:"iterations"}]};Q.encryptPrivateKeyInfo=function(e,t,r){r=r||{},r.saltSize=r.saltSize||8,r.count=r.count||2048,r.algorithm=r.algorithm||"aes128",r.prfAlgorithm=r.prfAlgorithm||"sha1";var n=O.random.getBytesSync(r.saltSize),i=r.count,s=A.integerToDer(i),o,a,c;if(r.algorithm.indexOf("aes")===0||r.algorithm==="des"){var u,f,l;switch(r.algorithm){case"aes128":o=16,u=16,f=Pr["aes128-CBC"],l=O.aes.createEncryptionCipher;break;case"aes192":o=24,u=16,f=Pr["aes192-CBC"],l=O.aes.createEncryptionCipher;break;case"aes256":o=32,u=16,f=Pr["aes256-CBC"],l=O.aes.createEncryptionCipher;break;case"des":o=8,u=8,f=Pr.desCBC,l=O.des.createEncryptionCipher;break;default:var h=new Error("Cannot encrypt private key. Unknown encryption algorithm.");throw h.algorithm=r.algorithm,h}var y="hmacWith"+r.prfAlgorithm.toUpperCase(),d=nu(y),p=O.pkcs5.pbkdf2(t,n,i,o,d),m=O.random.getBytesSync(u),x=l(p);x.start(m),x.update(A.toDer(e)),x.finish(),c=x.output.getBytes();var E=Cy(n,s,o,y);a=A.create(A.Class.UNIVERSAL,A.Type.SEQUENCE,!0,[A.create(A.Class.UNIVERSAL,A.Type.OID,!1,A.oidToDer(Pr.pkcs5PBES2).getBytes()),A.create(A.Class.UNIVERSAL,A.Type.SEQUENCE,!0,[A.create(A.Class.UNIVERSAL,A.Type.SEQUENCE,!0,[A.create(A.Class.UNIVERSAL,A.Type.OID,!1,A.oidToDer(Pr.pkcs5PBKDF2).getBytes()),E]),A.create(A.Class.UNIVERSAL,A.Type.SEQUENCE,!0,[A.create(A.Class.UNIVERSAL,A.Type.OID,!1,A.oidToDer(f).getBytes()),A.create(A.Class.UNIVERSAL,A.Type.OCTETSTRING,!1,m)])])])}else if(r.algorithm==="3des"){o=24;var b=new O.util.ByteBuffer(n),p=Q.pbe.generatePkcs12Key(t,b,1,i,o),m=Q.pbe.generatePkcs12Key(t,b,2,i,o),x=O.des.createEncryptionCipher(p);x.start(m),x.update(A.toDer(e)),x.finish(),c=x.output.getBytes(),a=A.create(A.Class.UNIVERSAL,A.Type.SEQUENCE,!0,[A.create(A.Class.UNIVERSAL,A.Type.OID,!1,A.oidToDer(Pr["pbeWithSHAAnd3-KeyTripleDES-CBC"]).getBytes()),A.create(A.Class.UNIVERSAL,A.Type.SEQUENCE,!0,[A.create(A.Class.UNIVERSAL,A.Type.OCTETSTRING,!1,n),A.create(A.Class.UNIVERSAL,A.Type.INTEGER,!1,s.getBytes())])])}else{var h=new Error("Cannot encrypt private key. Unknown encryption algorithm.");throw h.algorithm=r.algorithm,h}var R=A.create(A.Class.UNIVERSAL,A.Type.SEQUENCE,!0,[a,A.create(A.Class.UNIVERSAL,A.Type.OCTETSTRING,!1,c)]);return R};Q.decryptPrivateKeyInfo=function(e,t){var r=null,n={},i=[];if(!A.validate(e,Ty,n,i)){var s=new Error("Cannot read encrypted private key. ASN.1 object is not a supported EncryptedPrivateKeyInfo.");throw s.errors=i,s}var o=A.derToOid(n.encryptionOid),a=Q.pbe.getCipher(o,n.encryptionParams,t),c=O.util.createBuffer(n.encryptedData);return a.update(c),a.finish()&&(r=A.fromDer(a.output)),r};Q.encryptedPrivateKeyToPem=function(e,t){var r={type:"ENCRYPTED PRIVATE KEY",body:A.toDer(e).getBytes()};return O.pem.encode(r,{maxline:t})};Q.encryptedPrivateKeyFromPem=function(e){var t=O.pem.decode(e)[0];if(t.type!=="ENCRYPTED PRIVATE KEY"){var r=new Error('Could not convert encrypted private key from PEM; PEM header type is "ENCRYPTED PRIVATE KEY".');throw r.headerType=t.type,r}if(t.procType&&t.procType.type==="ENCRYPTED")throw new Error("Could not convert encrypted private key from PEM; PEM is encrypted.");return A.fromDer(t.body)};Q.encryptRsaPrivateKey=function(e,t,r){if(r=r||{},!r.legacy){var n=Q.wrapRsaPrivateKey(Q.privateKeyToAsn1(e));return n=Q.encryptPrivateKeyInfo(n,t,r),Q.encryptedPrivateKeyToPem(n)}var i,s,o,a;switch(r.algorithm){case"aes128":i="AES-128-CBC",o=16,s=O.random.getBytesSync(16),a=O.aes.createEncryptionCipher;break;case"aes192":i="AES-192-CBC",o=24,s=O.random.getBytesSync(16),a=O.aes.createEncryptionCipher;break;case"aes256":i="AES-256-CBC",o=32,s=O.random.getBytesSync(16),a=O.aes.createEncryptionCipher;break;case"3des":i="DES-EDE3-CBC",o=24,s=O.random.getBytesSync(8),a=O.des.createEncryptionCipher;break;case"des":i="DES-CBC",o=8,s=O.random.getBytesSync(8),a=O.des.createEncryptionCipher;break;default:var c=new Error('Could not encrypt RSA private key; unsupported encryption algorithm "'+r.algorithm+'".');throw c.algorithm=r.algorithm,c}var u=O.pbe.opensslDeriveBytes(t,s.substr(0,8),o),f=a(u);f.start(s),f.update(A.toDer(Q.privateKeyToAsn1(e))),f.finish();var l={type:"RSA PRIVATE KEY",procType:{version:"4",type:"ENCRYPTED"},dekInfo:{algorithm:i,parameters:O.util.bytesToHex(s).toUpperCase()},body:f.output.getBytes()};return O.pem.encode(l)};Q.decryptRsaPrivateKey=function(e,t){var r=null,n=O.pem.decode(e)[0];if(n.type!=="ENCRYPTED PRIVATE KEY"&&n.type!=="PRIVATE KEY"&&n.type!=="RSA PRIVATE KEY"){var i=new Error('Could not convert private key from PEM; PEM header type is not "ENCRYPTED PRIVATE KEY", "PRIVATE KEY", or "RSA PRIVATE KEY".');throw i.headerType=i,i}if(n.procType&&n.procType.type==="ENCRYPTED"){var s,o;switch(n.dekInfo.algorithm){case"DES-CBC":s=8,o=O.des.createDecryptionCipher;break;case"DES-EDE3-CBC":s=24,o=O.des.createDecryptionCipher;break;case"AES-128-CBC":s=16,o=O.aes.createDecryptionCipher;break;case"AES-192-CBC":s=24,o=O.aes.createDecryptionCipher;break;case"AES-256-CBC":s=32,o=O.aes.createDecryptionCipher;break;case"RC2-40-CBC":s=5,o=function(l){return O.rc2.createDecryptionCipher(l,40)};break;case"RC2-64-CBC":s=8,o=function(l){return O.rc2.createDecryptionCipher(l,64)};break;case"RC2-128-CBC":s=16,o=function(l){return O.rc2.createDecryptionCipher(l,128)};break;default:var i=new Error('Could not decrypt private key; unsupported encryption algorithm "'+n.dekInfo.algorithm+'".');throw i.algorithm=n.dekInfo.algorithm,i}var a=O.util.hexToBytes(n.dekInfo.parameters),c=O.pbe.opensslDeriveBytes(t,a.substr(0,8),s),u=o(c);if(u.start(a),u.update(O.util.createBuffer(n.body)),u.finish())r=u.output.getBytes();else return r}else r=n.body;return n.type==="ENCRYPTED PRIVATE KEY"?r=Q.decryptPrivateKeyInfo(A.fromDer(r),t):r=A.fromDer(r),r!==null&&(r=Q.privateKeyFromAsn1(r)),r};Q.pbe.generatePkcs12Key=function(e,t,r,n,i,s){var o,a;if(typeof s>"u"||s===null){if(!("sha1"in O.md))throw new Error('"sha1" hash algorithm unavailable.');s=O.md.sha1.create()}var c=s.digestLength,u=s.blockLength,f=new O.util.ByteBuffer,l=new O.util.ByteBuffer;if(e!=null){for(a=0;a<e.length;a++)l.putInt16(e.charCodeAt(a));l.putInt16(0)}var h=l.length(),y=t.length(),d=new O.util.ByteBuffer;d.fillWithByte(r,u);var p=u*Math.ceil(y/u),m=new O.util.ByteBuffer;for(a=0;a<p;a++)m.putByte(t.at(a%y));var x=u*Math.ceil(h/u),E=new O.util.ByteBuffer;for(a=0;a<x;a++)E.putByte(l.at(a%h));var b=m;b.putBuffer(E);for(var R=Math.ceil(i/c),w=1;w<=R;w++){var S=new O.util.ByteBuffer;S.putBytes(d.bytes()),S.putBytes(b.bytes());for(var L=0;L<n;L++)s.start(),s.update(S.getBytes()),S=s.digest();var D=new O.util.ByteBuffer;for(a=0;a<u;a++)D.putByte(S.at(a%c));var Y=Math.ceil(y/u)+Math.ceil(h/u),W=new O.util.ByteBuffer;for(o=0;o<Y;o++){var q=new O.util.ByteBuffer(b.getBytes(u)),j=511;for(a=D.length()-1;a>=0;a--)j=j>>8,j+=D.at(a)+q.at(a),q.setAt(a,j&255);W.putBuffer(q)}b=W,f.putBuffer(S)}return f.truncate(f.length()-i),f};Q.pbe.getCipher=function(e,t,r){switch(e){case Q.oids.pkcs5PBES2:return Q.pbe.getCipherForPBES2(e,t,r);case Q.oids["pbeWithSHAAnd3-KeyTripleDES-CBC"]:case Q.oids["pbewithSHAAnd40BitRC2-CBC"]:return Q.pbe.getCipherForPKCS12PBE(e,t,r);default:var n=new Error("Cannot read encrypted PBE data block. Unsupported OID.");throw n.oid=e,n.supportedOids=["pkcs5PBES2","pbeWithSHAAnd3-KeyTripleDES-CBC","pbewithSHAAnd40BitRC2-CBC"],n}};Q.pbe.getCipherForPBES2=function(e,t,r){var n={},i=[];if(!A.validate(t,By,n,i)){var s=new Error("Cannot read password-based-encryption algorithm parameters. ASN.1 object is not a supported EncryptedPrivateKeyInfo.");throw s.errors=i,s}if(e=A.derToOid(n.kdfOid),e!==Q.oids.pkcs5PBKDF2){var s=new Error("Cannot read encrypted private key. Unsupported key derivation function OID.");throw s.oid=e,s.supportedOids=["pkcs5PBKDF2"],s}if(e=A.derToOid(n.encOid),e!==Q.oids["aes128-CBC"]&&e!==Q.oids["aes192-CBC"]&&e!==Q.oids["aes256-CBC"]&&e!==Q.oids["des-EDE3-CBC"]&&e!==Q.oids.desCBC){var s=new Error("Cannot read encrypted private key. Unsupported encryption scheme OID.");throw s.oid=e,s.supportedOids=["aes128-CBC","aes192-CBC","aes256-CBC","des-EDE3-CBC","desCBC"],s}var o=n.kdfSalt,a=O.util.createBuffer(n.kdfIterationCount);a=a.getInt(a.length()<<3);var c,u;switch(Q.oids[e]){case"aes128-CBC":c=16,u=O.aes.createDecryptionCipher;break;case"aes192-CBC":c=24,u=O.aes.createDecryptionCipher;break;case"aes256-CBC":c=32,u=O.aes.createDecryptionCipher;break;case"des-EDE3-CBC":c=24,u=O.des.createDecryptionCipher;break;case"desCBC":c=8,u=O.des.createDecryptionCipher;break}var f=ru(n.prfOid),l=O.pkcs5.pbkdf2(r,o,a,c,f),h=n.encIv,y=u(l);return y.start(h),y};Q.pbe.getCipherForPKCS12PBE=function(e,t,r){var n={},i=[];if(!A.validate(t,Iy,n,i)){var s=new Error("Cannot read password-based-encryption algorithm parameters. ASN.1 object is not a supported EncryptedPrivateKeyInfo.");throw s.errors=i,s}var o=O.util.createBuffer(n.salt),a=O.util.createBuffer(n.iterations);a=a.getInt(a.length()<<3);var c,u,f;switch(e){case Q.oids["pbeWithSHAAnd3-KeyTripleDES-CBC"]:c=24,u=8,f=O.des.startDecrypting;break;case Q.oids["pbewithSHAAnd40BitRC2-CBC"]:c=5,u=8,f=function(p,m){var x=O.rc2.createDecryptionCipher(p,40);return x.start(m,null),x};break;default:var s=new Error("Cannot read PKCS #12 PBE data block. Unsupported OID.");throw s.oid=e,s}var l=ru(n.prfOid),h=Q.pbe.generatePkcs12Key(r,o,1,a,c,l);l.start();var y=Q.pbe.generatePkcs12Key(r,o,2,a,u,l);return f(h,y)};Q.pbe.opensslDeriveBytes=function(e,t,r,n){if(typeof n>"u"||n===null){if(!("md5"in O.md))throw new Error('"md5" hash algorithm unavailable.');n=O.md.md5.create()}t===null&&(t="");for(var i=[eu(n,e+t)],s=16,o=1;s<r;++o,s+=16)i.push(eu(n,i[o-1]+e+t));return i.join("").substr(0,r)};function eu(e,t){return e.start().update(t).digest().getBytes()}function ru(e){var t;if(!e)t="hmacWithSHA1";else if(t=Q.oids[A.derToOid(e)],!t){var r=new Error("Unsupported PRF OID.");throw r.oid=e,r.supported=["hmacWithSHA1","hmacWithSHA224","hmacWithSHA256","hmacWithSHA384","hmacWithSHA512"],r}return nu(t)}function nu(e){var t=O.md;switch(e){case"hmacWithSHA224":t=O.md.sha512;case"hmacWithSHA1":case"hmacWithSHA256":case"hmacWithSHA384":case"hmacWithSHA512":e=e.substr(8).toLowerCase();break;default:var r=new Error("Unsupported PRF algorithm.");throw r.algorithm=e,r.supported=["hmacWithSHA1","hmacWithSHA224","hmacWithSHA256","hmacWithSHA384","hmacWithSHA512"],r}if(!t||!(e in t))throw new Error("Unknown hash algorithm: "+e);return t[e].create()}function Cy(e,t,r,n){var i=A.create(A.Class.UNIVERSAL,A.Type.SEQUENCE,!0,[A.create(A.Class.UNIVERSAL,A.Type.OCTETSTRING,!1,e),A.create(A.Class.UNIVERSAL,A.Type.INTEGER,!1,t.getBytes())]);return n!=="hmacWithSHA1"&&i.value.push(A.create(A.Class.UNIVERSAL,A.Type.INTEGER,!1,O.util.hexToBytes(r.toString(16))),A.create(A.Class.UNIVERSAL,A.Type.SEQUENCE,!0,[A.create(A.Class.UNIVERSAL,A.Type.OID,!1,A.oidToDer(Q.oids[n]).getBytes()),A.create(A.Class.UNIVERSAL,A.Type.NULL,!1,"")])),i}});var Yu=ot((Gb,Wu)=>{var xt=ht();Lr();Dt();var Wn=Wu.exports=xt.sha512=xt.sha512||{};xt.md.sha512=xt.md.algorithms.sha512=Wn;var zu=xt.sha384=xt.sha512.sha384=xt.sha512.sha384||{};zu.create=function(){return Wn.create("SHA-384")};xt.md.sha384=xt.md.algorithms.sha384=zu;xt.sha512.sha256=xt.sha512.sha256||{create:function(){return Wn.create("SHA-512/256")}};xt.md["sha512/256"]=xt.md.algorithms["sha512/256"]=xt.sha512.sha256;xt.sha512.sha224=xt.sha512.sha224||{create:function(){return Wn.create("SHA-512/224")}};xt.md["sha512/224"]=xt.md.algorithms["sha512/224"]=xt.sha512.sha224;Wn.create=function(e){if(Gu||$m(),typeof e>"u"&&(e="SHA-512"),!(e in qr))throw new Error("Invalid SHA-512 algorithm: "+e);for(var t=qr[e],r=null,n=xt.util.createBuffer(),i=new Array(80),s=0;s<80;++s)i[s]=new Array(2);var o=64;switch(e){case"SHA-384":o=48;break;case"SHA-512/256":o=32;break;case"SHA-512/224":o=28;break}var a={algorithm:e.replace("-","").toLowerCase(),blockLength:128,digestLength:o,messageLength:0,fullMessageLength:null,messageLengthSize:16};return a.start=function(){a.messageLength=0,a.fullMessageLength=a.messageLength128=[];for(var c=a.messageLengthSize/4,u=0;u<c;++u)a.fullMessageLength.push(0);n=xt.util.createBuffer(),r=new Array(t.length);for(var u=0;u<t.length;++u)r[u]=t[u].slice(0);return a},a.start(),a.update=function(c,u){u==="utf8"&&(c=xt.util.encodeUtf8(c));var f=c.length;a.messageLength+=f,f=[f/4294967296>>>0,f>>>0];for(var l=a.fullMessageLength.length-1;l>=0;--l)a.fullMessageLength[l]+=f[1],f[1]=f[0]+(a.fullMessageLength[l]/4294967296>>>0),a.fullMessageLength[l]=a.fullMessageLength[l]>>>0,f[0]=f[1]/4294967296>>>0;return n.putBytes(c),Hu(r,i,n),(n.read>2048||n.length()===0)&&n.compact(),a},a.digest=function(){var c=xt.util.createBuffer();c.putBytes(n.bytes());var u=a.fullMessageLength[a.fullMessageLength.length-1]+a.messageLengthSize,f=u&a.blockLength-1;c.putBytes(na.substr(0,a.blockLength-f));for(var l,h,y=a.fullMessageLength[0]*8,d=0;d<a.fullMessageLength.length-1;++d)l=a.fullMessageLength[d+1]*8,h=l/4294967296>>>0,y+=h,c.putInt32(y>>>0),y=l>>>0;c.putInt32(y);for(var p=new Array(r.length),d=0;d<r.length;++d)p[d]=r[d].slice(0);Hu(p,i,c);var m=xt.util.createBuffer(),x;e==="SHA-512"?x=p.length:e==="SHA-384"?x=p.length-2:x=p.length-4;for(var d=0;d<x;++d)m.putInt32(p[d][0]),(d!==x-1||e!=="SHA-512/224")&&m.putInt32(p[d][1]);return m},a};var na=null,Gu=!1,ia=null,qr=null;function $m(){na="\x80",na+=xt.util.fillString("\0",128),ia=[[1116352408,3609767458],[1899447441,602891725],[3049323471,3964484399],[3921009573,2173295548],[961987163,4081628472],[1508970993,3053834265],[2453635748,2937671579],[2870763221,3664609560],[3624381080,2734883394],[310598401,1164996542],[607225278,1323610764],[1426881987,3590304994],[1925078388,4068182383],[2162078206,991336113],[2614888103,633803317],[3248222580,3479774868],[3835390401,2666613458],[4022224774,944711139],[264347078,2341262773],[604807628,2007800933],[770255983,1495990901],[1249150122,1856431235],[1555081692,3175218132],[1996064986,2198950837],[2554220882,3999719339],[2821834349,766784016],[2952996808,2566594879],[3210313671,3203337956],[3336571891,1034457026],[3584528711,2466948901],[113926993,3758326383],[338241895,168717936],[666307205,1188179964],[773529912,1546045734],[1294757372,1522805485],[1396182291,2643833823],[1695183700,2343527390],[1986661051,1014477480],[2177026350,1206759142],[2456956037,344077627],[2730485921,1290863460],[2820302411,3158454273],[3259730800,3505952657],[3345764771,106217008],[3516065817,3606008344],[3600352804,1432725776],[4094571909,1467031594],[275423344,851169720],[430227734,3100823752],[506948616,1363258195],[659060556,3750685593],[883997877,3785050280],[958139571,3318307427],[1322822218,3812723403],[1537002063,2003034995],[1747873779,3602036899],[1955562222,1575990012],[2024104815,1125592928],[2227730452,2716904306],[2361852424,442776044],[2428436474,593698344],[2756734187,3733110249],[3204031479,2999351573],[3329325298,3815920427],[3391569614,3928383900],[3515267271,566280711],[3940187606,3454069534],[4118630271,4000239992],[116418474,1914138554],[174292421,2731055270],[289380356,3203993006],[460393269,320620315],[685471733,587496836],[852142971,1086792851],[1017036298,365543100],[1126000580,2618297676],[1288033470,3409855158],[1501505948,4234509866],[1607167915,987167468],[1816402316,1246189591]],qr={},qr["SHA-512"]=[[1779033703,4089235720],[3144134277,2227873595],[1013904242,4271175723],[2773480762,1595750129],[1359893119,2917565137],[2600822924,725511199],[528734635,4215389547],[1541459225,327033209]],qr["SHA-384"]=[[3418070365,3238371032],[1654270250,914150663],[2438529370,812702999],[355462360,4144912697],[1731405415,4290775857],[2394180231,1750603025],[3675008525,1694076839],[1203062813,3204075428]],qr["SHA-512/256"]=[[573645204,4230739756],[2673172387,3360449730],[596883563,1867755857],[2520282905,1497426621],[2519219938,2827943907],[3193839141,1401305490],[721525244,746961066],[246885852,2177182882]],qr["SHA-512/224"]=[[2352822216,424955298],[1944164710,2312950998],[502970286,855612546],[1738396948,1479516111],[258812777,2077511080],[2011393907,79989058],[1067287976,1780299464],[286451373,2446758561]],Gu=!0}function Hu(e,t,r){for(var n,i,s,o,a,c,u,f,l,h,y,d,p,m,x,E,b,R,w,S,L,D,Y,W,q,j,lt,Ht,I,P,_,N,T,M,F,G=r.length();G>=128;){for(I=0;I<16;++I)t[I][0]=r.getInt32()>>>0,t[I][1]=r.getInt32()>>>0;for(;I<80;++I)N=t[I-2],P=N[0],_=N[1],n=((P>>>19|_<<13)^(_>>>29|P<<3)^P>>>6)>>>0,i=((P<<13|_>>>19)^(_<<3|P>>>29)^(P<<26|_>>>6))>>>0,M=t[I-15],P=M[0],_=M[1],s=((P>>>1|_<<31)^(P>>>8|_<<24)^P>>>7)>>>0,o=((P<<31|_>>>1)^(P<<24|_>>>8)^(P<<25|_>>>7))>>>0,T=t[I-7],F=t[I-16],_=i+T[1]+o+F[1],t[I][0]=n+T[0]+s+F[0]+(_/4294967296>>>0)>>>0,t[I][1]=_>>>0;for(p=e[0][0],m=e[0][1],x=e[1][0],E=e[1][1],b=e[2][0],R=e[2][1],w=e[3][0],S=e[3][1],L=e[4][0],D=e[4][1],Y=e[5][0],W=e[5][1],q=e[6][0],j=e[6][1],lt=e[7][0],Ht=e[7][1],I=0;I<80;++I)u=((L>>>14|D<<18)^(L>>>18|D<<14)^(D>>>9|L<<23))>>>0,f=((L<<18|D>>>14)^(L<<14|D>>>18)^(D<<23|L>>>9))>>>0,l=(q^L&(Y^q))>>>0,h=(j^D&(W^j))>>>0,a=((p>>>28|m<<4)^(m>>>2|p<<30)^(m>>>7|p<<25))>>>0,c=((p<<4|m>>>28)^(m<<30|p>>>2)^(m<<25|p>>>7))>>>0,y=(p&x|b&(p^x))>>>0,d=(m&E|R&(m^E))>>>0,_=Ht+f+h+ia[I][1]+t[I][1],n=lt+u+l+ia[I][0]+t[I][0]+(_/4294967296>>>0)>>>0,i=_>>>0,_=c+d,s=a+y+(_/4294967296>>>0)>>>0,o=_>>>0,lt=q,Ht=j,q=Y,j=W,Y=L,W=D,_=S+i,L=w+n+(_/4294967296>>>0)>>>0,D=_>>>0,w=b,S=R,b=x,R=E,x=p,E=m,_=i+o,p=n+s+(_/4294967296>>>0)>>>0,m=_>>>0;_=e[0][1]+m,e[0][0]=e[0][0]+p+(_/4294967296>>>0)>>>0,e[0][1]=_>>>0,_=e[1][1]+E,e[1][0]=e[1][0]+x+(_/4294967296>>>0)>>>0,e[1][1]=_>>>0,_=e[2][1]+R,e[2][0]=e[2][0]+b+(_/4294967296>>>0)>>>0,e[2][1]=_>>>0,_=e[3][1]+S,e[3][0]=e[3][0]+w+(_/4294967296>>>0)>>>0,e[3][1]=_>>>0,_=e[4][1]+D,e[4][0]=e[4][0]+L+(_/4294967296>>>0)>>>0,e[4][1]=_>>>0,_=e[5][1]+W,e[5][0]=e[5][0]+Y+(_/4294967296>>>0)>>>0,e[5][1]=_>>>0,_=e[6][1]+j,e[6][0]=e[6][0]+q+(_/4294967296>>>0)>>>0,e[6][1]=_>>>0,_=e[7][1]+Ht,e[7][0]=e[7][0]+lt+(_/4294967296>>>0)>>>0,e[7][1]=_>>>0,G-=128}}});var Yf=ot((v4,Wf)=>{"use strict";function Gf(e,t){for(let r in t)Object.defineProperty(e,r,{value:t[r],enumerable:!0,configurable:!0});return e}function Qg(e,t,r){if(!e||typeof e=="string")throw new TypeError("Please pass an Error to err-code");r||(r={}),typeof t=="object"&&(r=t,t=""),t&&(r.code=t);try{return Gf(e,r)}catch{r.message=e.message,r.stack=e.stack;let i=function(){};return i.prototype=Object.create(Object.getPrototypeOf(e)),Gf(new i,r)}}Wf.exports=Qg});var al=ot((F4,ol)=>{function Se(e,t){typeof t=="boolean"&&(t={forever:t}),this._originalTimeouts=JSON.parse(JSON.stringify(e)),this._timeouts=e,this._options=t||{},this._maxRetryTime=t&&t.maxRetryTime||1/0,this._fn=null,this._errors=[],this._attempts=1,this._operationTimeout=null,this._operationTimeoutCb=null,this._timeout=null,this._operationStart=null,this._timer=null,this._options.forever&&(this._cachedTimeouts=this._timeouts.slice(0))}ol.exports=Se;Se.prototype.reset=function(){this._attempts=1,this._timeouts=this._originalTimeouts.slice(0)};Se.prototype.stop=function(){this._timeout&&clearTimeout(this._timeout),this._timer&&clearTimeout(this._timer),this._timeouts=[],this._cachedTimeouts=null};Se.prototype.retry=function(e){if(this._timeout&&clearTimeout(this._timeout),!e)return!1;var t=new Date().getTime();if(e&&t-this._operationStart>=this._maxRetryTime)return this._errors.push(e),this._errors.unshift(new Error("RetryOperation timeout occurred")),!1;this._errors.push(e);var r=this._timeouts.shift();if(r===void 0)if(this._cachedTimeouts)this._errors.splice(0,this._errors.length-1),r=this._cachedTimeouts.slice(-1);else return!1;var n=this;return this._timer=setTimeout(function(){n._attempts++,n._operationTimeoutCb&&(n._timeout=setTimeout(function(){n._operationTimeoutCb(n._attempts)},n._operationTimeout),n._options.unref&&n._timeout.unref()),n._fn(n._attempts)},r),this._options.unref&&this._timer.unref(),!0};Se.prototype.attempt=function(e,t){this._fn=e,t&&(t.timeout&&(this._operationTimeout=t.timeout),t.cb&&(this._operationTimeoutCb=t.cb));var r=this;this._operationTimeoutCb&&(this._timeout=setTimeout(function(){r._operationTimeoutCb()},r._operationTimeout)),this._operationStart=new Date().getTime(),this._fn(this._attempts)};Se.prototype.try=function(e){console.log("Using RetryOperation.try() is deprecated"),this.attempt(e)};Se.prototype.start=function(e){console.log("Using RetryOperation.start() is deprecated"),this.attempt(e)};Se.prototype.start=Se.prototype.try;Se.prototype.errors=function(){return this._errors};Se.prototype.attempts=function(){return this._attempts};Se.prototype.mainError=function(){if(this._errors.length===0)return null;for(var e={},t=null,r=0,n=0;n<this._errors.length;n++){var i=this._errors[n],s=i.message,o=(e[s]||0)+1;e[s]=o,o>=r&&(t=i,r=o)}return t}});var cl=ot($r=>{var jg=al();$r.operation=function(e){var t=$r.timeouts(e);return new jg(t,{forever:e&&(e.forever||e.retries===1/0),unref:e&&e.unref,maxRetryTime:e&&e.maxRetryTime})};$r.timeouts=function(e){if(e instanceof Array)return[].concat(e);var t={retries:10,factor:2,minTimeout:1*1e3,maxTimeout:1/0,randomize:!1};for(var r in e)t[r]=e[r];if(t.minTimeout>t.maxTimeout)throw new Error("minTimeout is greater than maxTimeout");for(var n=[],i=0;i<t.retries;i++)n.push(this.createTimeout(i,t));return e&&e.forever&&!n.length&&n.push(this.createTimeout(i,t)),n.sort(function(s,o){return s-o}),n};$r.createTimeout=function(e,t){var r=t.randomize?Math.random()+1:1,n=Math.round(r*Math.max(t.minTimeout,1)*Math.pow(t.factor,e));return n=Math.min(n,t.maxTimeout),n};$r.wrap=function(e,t,r){if(t instanceof Array&&(r=t,t=null),!r){r=[];for(var n in e)typeof e[n]=="function"&&r.push(n)}for(var i=0;i<r.length;i++){var s=r[i],o=e[s];e[s]=function(c){var u=$r.operation(t),f=Array.prototype.slice.call(arguments,1),l=f.pop();f.push(function(h){u.retry(h)||(h&&(arguments[0]=u.mainError()),l.apply(this,arguments))}),u.attempt(function(){c.apply(e,f)})}.bind(e,o),e[s].options=t}}});var fl=ot((q4,ul)=>{ul.exports=cl()});var ml=ot((P8,Ga)=>{"use strict";var c1=Object.prototype.hasOwnProperty,se="~";function ri(){}Object.create&&(ri.prototype=Object.create(null),new ri().__proto__||(se=!1));function u1(e,t,r){this.fn=e,this.context=t,this.once=r||!1}function yl(e,t,r,n,i){if(typeof r!="function")throw new TypeError("The listener must be a function");var s=new u1(r,n||e,i),o=se?se+t:t;return e._events[o]?e._events[o].fn?e._events[o]=[e._events[o],s]:e._events[o].push(s):(e._events[o]=s,e._eventsCount++),e}function ms(e,t){--e._eventsCount===0?e._events=new ri:delete e._events[t]}function re(){this._events=new ri,this._eventsCount=0}re.prototype.eventNames=function(){var t=[],r,n;if(this._eventsCount===0)return t;for(n in r=this._events)c1.call(r,n)&&t.push(se?n.slice(1):n);return Object.getOwnPropertySymbols?t.concat(Object.getOwnPropertySymbols(r)):t};re.prototype.listeners=function(t){var r=se?se+t:t,n=this._events[r];if(!n)return[];if(n.fn)return[n.fn];for(var i=0,s=n.length,o=new Array(s);i<s;i++)o[i]=n[i].fn;return o};re.prototype.listenerCount=function(t){var r=se?se+t:t,n=this._events[r];return n?n.fn?1:n.length:0};re.prototype.emit=function(t,r,n,i,s,o){var a=se?se+t:t;if(!this._events[a])return!1;var c=this._events[a],u=arguments.length,f,l;if(c.fn){switch(c.once&&this.removeListener(t,c.fn,void 0,!0),u){case 1:return c.fn.call(c.context),!0;case 2:return c.fn.call(c.context,r),!0;case 3:return c.fn.call(c.context,r,n),!0;case 4:return c.fn.call(c.context,r,n,i),!0;case 5:return c.fn.call(c.context,r,n,i,s),!0;case 6:return c.fn.call(c.context,r,n,i,s,o),!0}for(l=1,f=new Array(u-1);l<u;l++)f[l-1]=arguments[l];c.fn.apply(c.context,f)}else{var h=c.length,y;for(l=0;l<h;l++)switch(c[l].once&&this.removeListener(t,c[l].fn,void 0,!0),u){case 1:c[l].fn.call(c[l].context);break;case 2:c[l].fn.call(c[l].context,r);break;case 3:c[l].fn.call(c[l].context,r,n);break;case 4:c[l].fn.call(c[l].context,r,n,i);break;default:if(!f)for(y=1,f=new Array(u-1);y<u;y++)f[y-1]=arguments[y];c[l].fn.apply(c[l].context,f)}}return!0};re.prototype.on=function(t,r,n){return yl(this,t,r,n,!1)};re.prototype.once=function(t,r,n){return yl(this,t,r,n,!0)};re.prototype.removeListener=function(t,r,n,i){var s=se?se+t:t;if(!this._events[s])return this;if(!r)return ms(this,s),this;var o=this._events[s];if(o.fn)o.fn===r&&(!i||o.once)&&(!n||o.context===n)&&ms(this,s);else{for(var a=0,c=[],u=o.length;a<u;a++)(o[a].fn!==r||i&&!o[a].once||n&&o[a].context!==n)&&c.push(o[a]);c.length?this._events[s]=c.length===1?c[0]:c:ms(this,s)}return this};re.prototype.removeAllListeners=function(t){var r;return t?(r=se?se+t:t,this._events[r]&&ms(this,r)):(this._events=new ri,this._eventsCount=0),this};re.prototype.off=re.prototype.removeListener;re.prototype.addListener=re.prototype.on;re.prefixed=se;re.EventEmitter=re;typeof Ga<"u"&&(Ga.exports=re)});var S1={};Kt(S1,{RELAY_V2_HOP_CODEC:()=>we,RELAY_V2_STOP_CODEC:()=>Yr,circuitRelayServer:()=>pl,circuitRelayTransport:()=>Ol});var T1=Symbol.for("@libp2p/connection");var I1=Symbol.for("@libp2p/content-routing");var R1=Symbol.for("@libp2p/peer-discovery");var g0=Symbol.for("@libp2p/peer-id");var N1=Symbol.for("@libp2p/peer-routing");var x0;(function(e){e.Accept="accept",e.Ignore="ignore",e.Reject="reject"})(x0||(x0={}));var b0=Symbol.for("@libp2p/transport");var v0;(function(e){e[e.FATAL_ALL=0]="FATAL_ALL",e[e.NO_FATAL=1]="NO_FATAL"})(v0||(v0={}));var H=class extends Error{code;props;constructor(t,r,n){super(t),this.code=r,this.name=n?.name??"CodeError",this.props=n??{}}};var E0="ERR_INVALID_PARAMETERS";var me=class extends EventTarget{#t=new Map;listenerCount(t){let r=this.#t.get(t);return r==null?0:r.length}addEventListener(t,r,n){super.addEventListener(t,r,n);let i=this.#t.get(t);i==null&&(i=[],this.#t.set(t,i)),i.push({callback:r,once:(n!==!0&&n!==!1&&n?.once)??!1})}removeEventListener(t,r,n){super.removeEventListener(t.toString(),r??null,n);let i=this.#t.get(t);i!=null&&(i=i.filter(({callback:s})=>s!==r),this.#t.set(t,i))}dispatchEvent(t){let r=super.dispatchEvent(t),n=this.#t.get(t.type);return n==null||(n=n.filter(({once:i})=>!i),this.#t.set(t.type,n)),r}safeDispatchEvent(t,r){return this.dispatchEvent(new Jl(t,r))}},Ns=class extends Event{detail;constructor(t,r){super(t,r),this.detail=r?.detail}},Jl=globalThis.CustomEvent??Ns,w0=(e,...t)=>{try{[...t]}catch{}};var Ms={};Kt(Ms,{base58btc:()=>kt,base58flickr:()=>ih});function jl(e,t){if(e.length>=255)throw new TypeError("Alphabet too long");for(var r=new Uint8Array(256),n=0;n<r.length;n++)r[n]=255;for(var i=0;i<e.length;i++){var s=e.charAt(i),o=s.charCodeAt(0);if(r[o]!==255)throw new TypeError(s+" is ambiguous");r[o]=i}var a=e.length,c=e.charAt(0),u=Math.log(a)/Math.log(256),f=Math.log(256)/Math.log(a);function l(d){if(d instanceof Uint8Array||(ArrayBuffer.isView(d)?d=new Uint8Array(d.buffer,d.byteOffset,d.byteLength):Array.isArray(d)&&(d=Uint8Array.from(d))),!(d instanceof Uint8Array))throw new TypeError("Expected Uint8Array");if(d.length===0)return"";for(var p=0,m=0,x=0,E=d.length;x!==E&&d[x]===0;)x++,p++;for(var b=(E-x)*f+1>>>0,R=new Uint8Array(b);x!==E;){for(var w=d[x],S=0,L=b-1;(w!==0||S<m)&&L!==-1;L--,S++)w+=256*R[L]>>>0,R[L]=w%a>>>0,w=w/a>>>0;if(w!==0)throw new Error("Non-zero carry");m=S,x++}for(var D=b-m;D!==b&&R[D]===0;)D++;for(var Y=c.repeat(p);D<b;++D)Y+=e.charAt(R[D]);return Y}function h(d){if(typeof d!="string")throw new TypeError("Expected String");if(d.length===0)return new Uint8Array;var p=0;if(d[p]!==" "){for(var m=0,x=0;d[p]===c;)m++,p++;for(var E=(d.length-p)*u+1>>>0,b=new Uint8Array(E);d[p];){var R=r[d.charCodeAt(p)];if(R===255)return;for(var w=0,S=E-1;(R!==0||w<x)&&S!==-1;S--,w++)R+=a*b[S]>>>0,b[S]=R%256>>>0,R=R/256>>>0;if(R!==0)throw new Error("Non-zero carry");x=w,p++}if(d[p]!==" "){for(var L=E-x;L!==E&&b[L]===0;)L++;for(var D=new Uint8Array(m+(E-L)),Y=m;L!==E;)D[Y++]=b[L++];return D}}}function y(d){var p=h(d);if(p)return p;throw new Error(`Non-${t} character`)}return{encode:l,decodeUnsafe:h,decode:y}}var th=jl,eh=th,S0=eh;var dx=new Uint8Array(0);var A0=(e,t)=>{if(e===t)return!0;if(e.byteLength!==t.byteLength)return!1;for(let r=0;r<e.byteLength;r++)if(e[r]!==t[r])return!1;return!0},ze=e=>{if(e instanceof Uint8Array&&e.constructor.name==="Uint8Array")return e;if(e instanceof ArrayBuffer)return new Uint8Array(e);if(ArrayBuffer.isView(e))return new Uint8Array(e.buffer,e.byteOffset,e.byteLength);throw new Error("Unknown type, must be binary type")};var T0=e=>new TextEncoder().encode(e),B0=e=>new TextDecoder().decode(e);var Ps=class{constructor(t,r,n){this.name=t,this.prefix=r,this.baseEncode=n}encode(t){if(t instanceof Uint8Array)return`${this.prefix}${this.baseEncode(t)}`;throw Error("Unknown type, must be binary type")}},ks=class{constructor(t,r,n){if(this.name=t,this.prefix=r,r.codePointAt(0)===void 0)throw new Error("Invalid prefix character");this.prefixCodePoint=r.codePointAt(0),this.baseDecode=n}decode(t){if(typeof t=="string"){if(t.codePointAt(0)!==this.prefixCodePoint)throw Error(`Unable to decode multibase string ${JSON.stringify(t)}, ${this.name} decoder only supports inputs prefixed with ${this.prefix}`);return this.baseDecode(t.slice(this.prefix.length))}else throw Error("Can only multibase decode strings")}or(t){return C0(this,t)}},Us=class{constructor(t){this.decoders=t}or(t){return C0(this,t)}decode(t){let r=t[0],n=this.decoders[r];if(n)return n.decode(t);throw RangeError(`Unable to decode multibase string ${JSON.stringify(t)}, only inputs prefixed with ${Object.keys(this.decoders)} are supported`)}},C0=(e,t)=>new Us({...e.decoders||{[e.prefix]:e},...t.decoders||{[t.prefix]:t}}),Os=class{constructor(t,r,n,i){this.name=t,this.prefix=r,this.baseEncode=n,this.baseDecode=i,this.encoder=new Ps(t,r,n),this.decoder=new ks(t,r,i)}encode(t){return this.encoder.encode(t)}decode(t){return this.decoder.decode(t)}},Jr=({name:e,prefix:t,encode:r,decode:n})=>new Os(e,t,r,n),ar=({prefix:e,name:t,alphabet:r})=>{let{encode:n,decode:i}=S0(r,t);return Jr({prefix:e,name:t,encode:n,decode:s=>ze(i(s))})},rh=(e,t,r,n)=>{let i={};for(let f=0;f<t.length;++f)i[t[f]]=f;let s=e.length;for(;e[s-1]==="=";)--s;let o=new Uint8Array(s*r/8|0),a=0,c=0,u=0;for(let f=0;f<s;++f){let l=i[e[f]];if(l===void 0)throw new SyntaxError(`Non-${n} character`);c=c<<r|l,a+=r,a>=8&&(a-=8,o[u++]=255&c>>a)}if(a>=r||255&c<<8-a)throw new SyntaxError("Unexpected end of data");return o},nh=(e,t,r)=>{let n=t[t.length-1]==="=",i=(1<<r)-1,s="",o=0,a=0;for(let c=0;c<e.length;++c)for(a=a<<8|e[c],o+=8;o>r;)o-=r,s+=t[i&a>>o];if(o&&(s+=t[i&a<<r-o]),n)for(;s.length*r&7;)s+="=";return s},Bt=({name:e,prefix:t,bitsPerChar:r,alphabet:n})=>Jr({prefix:t,name:e,encode(i){return nh(i,n,r)},decode(i){return rh(i,n,r,e)}});var kt=ar({name:"base58btc",prefix:"z",alphabet:"123456789ABCDEFGHJKLMNPQRSTUVWXYZabcdefghijkmnopqrstuvwxyz"}),ih=ar({name:"base58flickr",prefix:"Z",alphabet:"123456789abcdefghijkmnopqrstuvwxyzABCDEFGHJKLMNPQRSTUVWXYZ"});var Ks={};Kt(Ks,{base10:()=>sh});var sh=ar({prefix:"9",name:"base10",alphabet:"0123456789"});var Fs={};Kt(Fs,{base16:()=>oh,base16upper:()=>ah});var oh=Bt({prefix:"f",name:"base16",alphabet:"0123456789abcdef",bitsPerChar:4}),ah=Bt({prefix:"F",name:"base16upper",alphabet:"0123456789ABCDEF",bitsPerChar:4});var Vs={};Kt(Vs,{base2:()=>ch});var ch=Bt({prefix:"0",name:"base2",alphabet:"01",bitsPerChar:1});var qs={};Kt(qs,{base256emoji:()=>dh});var _0=Array.from("\u{1F680}\u{1FA90}\u2604\u{1F6F0}\u{1F30C}\u{1F311}\u{1F312}\u{1F313}\u{1F314}\u{1F315}\u{1F316}\u{1F317}\u{1F318}\u{1F30D}\u{1F30F}\u{1F30E}\u{1F409}\u2600\u{1F4BB}\u{1F5A5}\u{1F4BE}\u{1F4BF}\u{1F602}\u2764\u{1F60D}\u{1F923}\u{1F60A}\u{1F64F}\u{1F495}\u{1F62D}\u{1F618}\u{1F44D}\u{1F605}\u{1F44F}\u{1F601}\u{1F525}\u{1F970}\u{1F494}\u{1F496}\u{1F499}\u{1F622}\u{1F914}\u{1F606}\u{1F644}\u{1F4AA}\u{1F609}\u263A\u{1F44C}\u{1F917}\u{1F49C}\u{1F614}\u{1F60E}\u{1F607}\u{1F339}\u{1F926}\u{1F389}\u{1F49E}\u270C\u2728\u{1F937}\u{1F631}\u{1F60C}\u{1F338}\u{1F64C}\u{1F60B}\u{1F497}\u{1F49A}\u{1F60F}\u{1F49B}\u{1F642}\u{1F493}\u{1F929}\u{1F604}\u{1F600}\u{1F5A4}\u{1F603}\u{1F4AF}\u{1F648}\u{1F447}\u{1F3B6}\u{1F612}\u{1F92D}\u2763\u{1F61C}\u{1F48B}\u{1F440}\u{1F62A}\u{1F611}\u{1F4A5}\u{1F64B}\u{1F61E}\u{1F629}\u{1F621}\u{1F92A}\u{1F44A}\u{1F973}\u{1F625}\u{1F924}\u{1F449}\u{1F483}\u{1F633}\u270B\u{1F61A}\u{1F61D}\u{1F634}\u{1F31F}\u{1F62C}\u{1F643}\u{1F340}\u{1F337}\u{1F63B}\u{1F613}\u2B50\u2705\u{1F97A}\u{1F308}\u{1F608}\u{1F918}\u{1F4A6}\u2714\u{1F623}\u{1F3C3}\u{1F490}\u2639\u{1F38A}\u{1F498}\u{1F620}\u261D\u{1F615}\u{1F33A}\u{1F382}\u{1F33B}\u{1F610}\u{1F595}\u{1F49D}\u{1F64A}\u{1F639}\u{1F5E3}\u{1F4AB}\u{1F480}\u{1F451}\u{1F3B5}\u{1F91E}\u{1F61B}\u{1F534}\u{1F624}\u{1F33C}\u{1F62B}\u26BD\u{1F919}\u2615\u{1F3C6}\u{1F92B}\u{1F448}\u{1F62E}\u{1F646}\u{1F37B}\u{1F343}\u{1F436}\u{1F481}\u{1F632}\u{1F33F}\u{1F9E1}\u{1F381}\u26A1\u{1F31E}\u{1F388}\u274C\u270A\u{1F44B}\u{1F630}\u{1F928}\u{1F636}\u{1F91D}\u{1F6B6}\u{1F4B0}\u{1F353}\u{1F4A2}\u{1F91F}\u{1F641}\u{1F6A8}\u{1F4A8}\u{1F92C}\u2708\u{1F380}\u{1F37A}\u{1F913}\u{1F619}\u{1F49F}\u{1F331}\u{1F616}\u{1F476}\u{1F974}\u25B6\u27A1\u2753\u{1F48E}\u{1F4B8}\u2B07\u{1F628}\u{1F31A}\u{1F98B}\u{1F637}\u{1F57A}\u26A0\u{1F645}\u{1F61F}\u{1F635}\u{1F44E}\u{1F932}\u{1F920}\u{1F927}\u{1F4CC}\u{1F535}\u{1F485}\u{1F9D0}\u{1F43E}\u{1F352}\u{1F617}\u{1F911}\u{1F30A}\u{1F92F}\u{1F437}\u260E\u{1F4A7}\u{1F62F}\u{1F486}\u{1F446}\u{1F3A4}\u{1F647}\u{1F351}\u2744\u{1F334}\u{1F4A3}\u{1F438}\u{1F48C}\u{1F4CD}\u{1F940}\u{1F922}\u{1F445}\u{1F4A1}\u{1F4A9}\u{1F450}\u{1F4F8}\u{1F47B}\u{1F910}\u{1F92E}\u{1F3BC}\u{1F975}\u{1F6A9}\u{1F34E}\u{1F34A}\u{1F47C}\u{1F48D}\u{1F4E3}\u{1F942}"),uh=_0.reduce((e,t,r)=>(e[r]=t,e),[]),fh=_0.reduce((e,t,r)=>(e[t.codePointAt(0)]=r,e),[]);function lh(e){return e.reduce((t,r)=>(t+=uh[r],t),"")}function hh(e){let t=[];for(let r of e){let n=fh[r.codePointAt(0)];if(n===void 0)throw new Error(`Non-base256emoji character: ${r}`);t.push(n)}return new Uint8Array(t)}var dh=Jr({prefix:"\u{1F680}",name:"base256emoji",encode:lh,decode:hh});var Hs={};Kt(Hs,{base32:()=>Ge,base32hex:()=>gh,base32hexpad:()=>vh,base32hexpadupper:()=>bh,base32hexupper:()=>xh,base32pad:()=>yh,base32padupper:()=>mh,base32upper:()=>ph,base32z:()=>Eh});var Ge=Bt({prefix:"b",name:"base32",alphabet:"abcdefghijklmnopqrstuvwxyz234567",bitsPerChar:5}),ph=Bt({prefix:"B",name:"base32upper",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZ234567",bitsPerChar:5}),yh=Bt({prefix:"c",name:"base32pad",alphabet:"abcdefghijklmnopqrstuvwxyz234567=",bitsPerChar:5}),mh=Bt({prefix:"C",name:"base32padupper",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZ234567=",bitsPerChar:5}),gh=Bt({prefix:"v",name:"base32hex",alphabet:"0123456789abcdefghijklmnopqrstuv",bitsPerChar:5}),xh=Bt({prefix:"V",name:"base32hexupper",alphabet:"0123456789ABCDEFGHIJKLMNOPQRSTUV",bitsPerChar:5}),vh=Bt({prefix:"t",name:"base32hexpad",alphabet:"0123456789abcdefghijklmnopqrstuv=",bitsPerChar:5}),bh=Bt({prefix:"T",name:"base32hexpadupper",alphabet:"0123456789ABCDEFGHIJKLMNOPQRSTUV=",bitsPerChar:5}),Eh=Bt({prefix:"h",name:"base32z",alphabet:"ybndrfg8ejkmcpqxot1uwisza345h769",bitsPerChar:5});var zs={};Kt(zs,{base36:()=>wh,base36upper:()=>Sh});var wh=ar({prefix:"k",name:"base36",alphabet:"0123456789abcdefghijklmnopqrstuvwxyz"}),Sh=ar({prefix:"K",name:"base36upper",alphabet:"0123456789ABCDEFGHIJKLMNOPQRSTUVWXYZ"});var Gs={};Kt(Gs,{base64:()=>fi,base64pad:()=>Ah,base64url:()=>Th,base64urlpad:()=>Bh});var fi=Bt({prefix:"m",name:"base64",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/",bitsPerChar:6}),Ah=Bt({prefix:"M",name:"base64pad",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/=",bitsPerChar:6}),Th=Bt({prefix:"u",name:"base64url",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789-_",bitsPerChar:6}),Bh=Bt({prefix:"U",name:"base64urlpad",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789-_=",bitsPerChar:6});var Ws={};Kt(Ws,{base8:()=>Ih});var Ih=Bt({prefix:"7",name:"base8",alphabet:"01234567",bitsPerChar:3});var Ys={};Kt(Ys,{identity:()=>Ch});var Ch=Jr({prefix:"\0",name:"identity",encode:e=>B0(e),decode:e=>T0(e)});var Cx=new TextEncoder,_x=new TextDecoder;var Qs={};Kt(Qs,{identity:()=>cr});var Lh=D0,R0=128,Dh=127,Nh=~Dh,Ph=Math.pow(2,31);function D0(e,t,r){t=t||[],r=r||0;for(var n=r;e>=Ph;)t[r++]=e&255|R0,e/=128;for(;e&Nh;)t[r++]=e&255|R0,e>>>=7;return t[r]=e|0,D0.bytes=r-n+1,t}var kh=$s,Uh=128,L0=127;function $s(e,n){var r=0,n=n||0,i=0,s=n,o,a=e.length;do{if(s>=a)throw $s.bytes=0,new RangeError("Could not decode varint");o=e[s++],r+=i<28?(o&L0)<<i:(o&L0)*Math.pow(2,i),i+=7}while(o>=Uh);return $s.bytes=s-n,r}var Oh=Math.pow(2,7),Mh=Math.pow(2,14),Kh=Math.pow(2,21),Fh=Math.pow(2,28),Vh=Math.pow(2,35),qh=Math.pow(2,42),Hh=Math.pow(2,49),zh=Math.pow(2,56),Gh=Math.pow(2,63),Wh=function(e){return e<Oh?1:e<Mh?2:e<Kh?3:e<Fh?4:e<Vh?5:e<qh?6:e<Hh?7:e<zh?8:e<Gh?9:10},Yh={encode:Lh,decode:kh,encodingLength:Wh},$h=Yh,_n=$h;var Rn=(e,t=0)=>[_n.decode(e,t),_n.decode.bytes],jr=(e,t,r=0)=>(_n.encode(e,t,r),t),tn=e=>_n.encodingLength(e);var Ne=(e,t)=>{let r=t.byteLength,n=tn(e),i=n+tn(r),s=new Uint8Array(i+r);return jr(e,s,0),jr(r,s,n),s.set(t,i),new en(e,r,t,s)},Cr=e=>{let t=ze(e),[r,n]=Rn(t),[i,s]=Rn(t.subarray(n)),o=t.subarray(n+s);if(o.byteLength!==i)throw new Error("Incorrect length");return new en(r,i,o,t)},N0=(e,t)=>{if(e===t)return!0;{let r=t;return e.code===r.code&&e.size===r.size&&r.bytes instanceof Uint8Array&&A0(e.bytes,r.bytes)}},en=class{constructor(t,r,n,i){this.code=t,this.size=r,this.digest=n,this.bytes=i}};var P0=0,Qh="identity",k0=ze,Zh=e=>Ne(P0,k0(e)),cr={code:P0,name:Qh,encode:k0,digest:Zh};var Js={};Kt(Js,{sha256:()=>Ut,sha512:()=>Xh});var Xs=({name:e,code:t,encode:r})=>new Zs(e,t,r),Zs=class{constructor(t,r,n){this.name=t,this.code=r,this.encode=n}digest(t){if(t instanceof Uint8Array){let r=this.encode(t);return r instanceof Uint8Array?Ne(this.code,r):r.then(n=>Ne(this.code,n))}else throw Error("Unknown type, must be binary type")}};var O0=e=>async t=>new Uint8Array(await crypto.subtle.digest(e,t)),Ut=Xs({name:"sha2-256",code:18,encode:O0("SHA-256")}),Xh=Xs({name:"sha2-512",code:19,encode:O0("SHA-512")});var M0=(e,t)=>{let{bytes:r,version:n}=e;switch(n){case 0:return jh(r,js(e),t||kt.encoder);default:return td(r,js(e),t||Ge.encoder)}};var K0=new WeakMap,js=e=>{let t=K0.get(e);if(t==null){let r=new Map;return K0.set(e,r),r}return t},fe=class e{constructor(t,r,n,i){this.code=r,this.version=t,this.multihash=n,this.bytes=i,this["/"]=i}get asCID(){return this}get byteOffset(){return this.bytes.byteOffset}get byteLength(){return this.bytes.byteLength}toV0(){switch(this.version){case 0:return this;case 1:{let{code:t,multihash:r}=this;if(t!==Ln)throw new Error("Cannot convert a non dag-pb CID to CIDv0");if(r.code!==ed)throw new Error("Cannot convert non sha2-256 multihash CID to CIDv0");return e.createV0(r)}default:throw Error(`Can not convert CID version ${this.version} to version 0. This is a bug please report`)}}toV1(){switch(this.version){case 0:{let{code:t,digest:r}=this.multihash,n=Ne(t,r);return e.createV1(this.code,n)}case 1:return this;default:throw Error(`Can not convert CID version ${this.version} to version 1. This is a bug please report`)}}equals(t){return e.equals(this,t)}static equals(t,r){let n=r;return n&&t.code===n.code&&t.version===n.version&&N0(t.multihash,n.multihash)}toString(t){return M0(this,t)}toJSON(){return{"/":M0(this)}}link(){return this}get[Symbol.toStringTag](){return"CID"}[Symbol.for("nodejs.util.inspect.custom")](){return`CID(${this.toString()})`}static asCID(t){if(t==null)return null;let r=t;if(r instanceof e)return r;if(r["/"]!=null&&r["/"]===r.bytes||r.asCID===r){let{version:n,code:i,multihash:s,bytes:o}=r;return new e(n,i,s,o||F0(n,i,s.bytes))}else if(r[rd]===!0){let{version:n,multihash:i,code:s}=r,o=Cr(i);return e.create(n,s,o)}else return null}static create(t,r,n){if(typeof r!="number")throw new Error("String codecs are no longer supported");if(!(n.bytes instanceof Uint8Array))throw new Error("Invalid digest");switch(t){case 0:{if(r!==Ln)throw new Error(`Version 0 CID must use dag-pb (code: ${Ln}) block encoding`);return new e(t,r,n,n.bytes)}case 1:{let i=F0(t,r,n.bytes);return new e(t,r,n,i)}default:throw new Error("Invalid version")}}static createV0(t){return e.create(0,Ln,t)}static createV1(t,r){return e.create(1,t,r)}static decode(t){let[r,n]=e.decodeFirst(t);if(n.length)throw new Error("Incorrect length");return r}static decodeFirst(t){let r=e.inspectBytes(t),n=r.size-r.multihashSize,i=ze(t.subarray(n,n+r.multihashSize));if(i.byteLength!==r.multihashSize)throw new Error("Incorrect length");let s=i.subarray(r.multihashSize-r.digestSize),o=new en(r.multihashCode,r.digestSize,s,i);return[r.version===0?e.createV0(o):e.createV1(r.codec,o),t.subarray(r.size)]}static inspectBytes(t){let r=0,n=()=>{let[l,h]=Rn(t.subarray(r));return r+=h,l},i=n(),s=Ln;if(i===18?(i=0,r=0):s=n(),i!==0&&i!==1)throw new RangeError(`Invalid CID version ${i}`);let o=r,a=n(),c=n(),u=r+c,f=u-o;return{version:i,codec:s,multihashCode:a,digestSize:c,multihashSize:f,size:u}}static parse(t,r){let[n,i]=Jh(t,r),s=e.decode(i);if(s.version===0&&t[0]!=="Q")throw Error("Version 0 CID string must not include multibase prefix");return js(s).set(n,t),s}},Jh=(e,t)=>{switch(e[0]){case"Q":{let r=t||kt;return[kt.prefix,r.decode(`${kt.prefix}${e}`)]}case kt.prefix:{let r=t||kt;return[kt.prefix,r.decode(e)]}case Ge.prefix:{let r=t||Ge;return[Ge.prefix,r.decode(e)]}default:{if(t==null)throw Error("To parse non base32 or base58btc encoded CID multibase decoder must be provided");return[e[0],t.decode(e)]}}},jh=(e,t,r)=>{let{prefix:n}=r;if(n!==kt.prefix)throw Error(`Cannot string encode V0 in ${r.name} encoding`);let i=t.get(n);if(i==null){let s=r.encode(e).slice(1);return t.set(n,s),s}else return i},td=(e,t,r)=>{let{prefix:n}=r,i=t.get(n);if(i==null){let s=r.encode(e);return t.set(n,s),s}else return i},Ln=112,ed=18,F0=(e,t,r)=>{let n=tn(e),i=n+tn(t),s=new Uint8Array(i+r.byteLength);return jr(e,s,0),jr(t,s,n),s.set(r,i),s},rd=Symbol.for("@ipld/js-cid/CID");var ur={...Ys,...Vs,...Ws,...Ks,...Fs,...Hs,...zs,...Ms,...Gs,...qs},Gx={...Js,...Qs};function Ct(e,t){if(e===t)return!0;if(e.byteLength!==t.byteLength)return!1;for(let r=0;r<e.byteLength;r++)if(e[r]!==t[r])return!1;return!0}var nd=Symbol.for("nodejs.util.inspect.custom"),V0=Object.values(ur).map(e=>e.decoder).reduce((e,t)=>e.or(t),ur.identity.decoder),q0=114,to=36,eo=37,Dn=class{type;multihash;privateKey;publicKey;string;constructor(t){this.type=t.type,this.multihash=t.multihash,this.privateKey=t.privateKey,Object.defineProperty(this,"string",{enumerable:!1,writable:!0})}get[Symbol.toStringTag](){return`PeerId(${this.toString()})`}[g0]=!0;toString(){return this.string==null&&(this.string=kt.encode(this.multihash.bytes).slice(1)),this.string}toCID(){return fe.createV1(q0,this.multihash)}toBytes(){return this.multihash.bytes}toJSON(){return this.toString()}equals(t){if(t instanceof Uint8Array)return Ct(this.multihash.bytes,t);if(typeof t=="string")return St(t).equals(this);if(t?.multihash?.bytes!=null)return Ct(this.multihash.bytes,t.multihash.bytes);throw new Error("not valid Id")}[nd](){return`PeerId(${this.toString()})`}},rn=class extends Dn{type="RSA";publicKey;constructor(t){super({...t,type:"RSA"}),this.publicKey=t.publicKey}},nn=class extends Dn{type="Ed25519";publicKey;constructor(t){super({...t,type:"Ed25519"}),this.publicKey=t.multihash.digest}},sn=class extends Dn{type="secp256k1";publicKey;constructor(t){super({...t,type:"secp256k1"}),this.publicKey=t.multihash.digest}};function St(e,t){if(t=t??V0,e.charAt(0)==="1"||e.charAt(0)==="Q"){let r=Cr(kt.decode(`z${e}`));return e.startsWith("12D")?new nn({multihash:r}):e.startsWith("16U")?new sn({multihash:r}):new rn({multihash:r})}return on(V0.decode(e))}function on(e){try{let t=Cr(e);if(t.code===cr.code){if(t.digest.length===to)return new nn({multihash:t});if(t.digest.length===eo)return new sn({multihash:t})}if(t.code===Ut.code)return new rn({multihash:t})}catch{return id(fe.decode(e))}throw new Error("Supplied PeerID CID is invalid")}function id(e){if(e==null||e.multihash==null||e.version==null||e.version===1&&e.code!==q0)throw new Error("Supplied PeerID CID is invalid");let t=e.multihash;if(t.code===Ut.code)return new rn({multihash:e.multihash});if(t.code===cr.code){if(t.digest.length===to)return new nn({multihash:e.multihash});if(t.digest.length===eo)return new sn({multihash:e.multihash})}throw new Error("Supplied PeerID CID is invalid")}async function H0(e,t){return e.length===to?new nn({multihash:Ne(cr.code,e),privateKey:t}):e.length===eo?new sn({multihash:Ne(cr.code,e),privateKey:t}):new rn({multihash:await Ut.digest(e),publicKey:e,privateKey:t})}var JE=Yt(Un(),1),jE=Yt(su(),1);var bg=Yt(ht(),1);function pr(e){return globalThis.Buffer!=null?new Uint8Array(e.buffer,e.byteOffset,e.byteLength):e}function Qe(e=0){return globalThis.Buffer?.alloc!=null?pr(globalThis.Buffer.alloc(e)):new Uint8Array(e)}function $t(e=0){return globalThis.Buffer?.allocUnsafe!=null?pr(globalThis.Buffer.allocUnsafe(e)):new Uint8Array(e)}function au(e,t,r,n){return{name:e,prefix:t,encoder:{name:e,prefix:t,encode:r},decoder:{decode:n}}}var ou=au("utf8","u",e=>"u"+new TextDecoder("utf8").decode(e),e=>new TextEncoder().encode(e.substring(1))),To=au("ascii","a",e=>{let t="a";for(let r=0;r<e.length;r++)t+=String.fromCharCode(e[r]);return t},e=>{e=e.substring(1);let t=$t(e.length);for(let r=0;r<e.length;r++)t[r]=e.charCodeAt(r);return t}),_y={utf8:ou,"utf-8":ou,hex:ur.base16,latin1:To,ascii:To,binary:To,...ur},Ri=_y;function Nt(e,t="utf8"){let r=Ri[t];if(r==null)throw new Error(`Unsupported encoding "${t}"`);return(t==="utf8"||t==="utf-8")&&globalThis.Buffer!=null&&globalThis.Buffer.from!=null?pr(globalThis.Buffer.from(e,"utf-8")):r.decoder.decode(`${r.prefix}${e}`)}var ra={};Kt(ra,{Ed25519PrivateKey:()=>Vr,Ed25519PublicKey:()=>Gn,generateKeyPair:()=>zm,generateKeyPairFromSeed:()=>qu,unmarshalEd25519PrivateKey:()=>qm,unmarshalEd25519PublicKey:()=>Hm});var q2=Yt(Dt(),1),H2=Yt(Bi(),1),cu=Yt(ht(),1);function Ot(e,t){if(globalThis.Buffer!=null)return pr(globalThis.Buffer.concat(e,t));t==null&&(t=e.reduce((i,s)=>i+s.length,0));let r=$t(t),n=0;for(let i of e)r.set(i,n),n+=i.length;return pr(r)}function pt(e,t="utf8"){let r=Ri[t];if(r==null)throw new Error(`Unsupported encoding "${t}"`);return(t==="utf8"||t==="utf-8")&&globalThis.Buffer!=null&&globalThis.Buffer.from!=null?globalThis.Buffer.from(e.buffer,e.byteOffset,e.byteLength).toString("utf8"):r.encoder.encode(e).substring(1)}function Be(e,t){let r=Uint8Array.from(e.abs().toByteArray());if(r=r[0]===0?r.subarray(1):r,t!=null){if(r.length>t)throw new Error("byte array longer than desired length");r=Ot([new Uint8Array(t-r.length),r])}return pt(r,"base64url")}function le(e){let t=uu(e);return new cu.default.jsbn.BigInteger(pt(t,"base16"),16)}function uu(e,t){let r=Nt(e,"base64urlpad");if(t!=null){if(r.length>t)throw new Error("byte array longer than desired length");r=Ot([new Uint8Array(t-r.length),r])}return r}function ve(e){return e==null?!1:typeof e.then=="function"&&typeof e.catch=="function"&&typeof e.finally=="function"}function fu(e){if(!Number.isSafeInteger(e)||e<0)throw new Error(`Wrong positive integer: ${e}`)}function Bo(e,...t){if(!(e instanceof Uint8Array))throw new Error("Expected Uint8Array");if(t.length>0&&!t.includes(e.length))throw new Error(`Expected Uint8Array of length ${t}, not of length=${e.length}`)}function lu(e){if(typeof e!="function"||typeof e.create!="function")throw new Error("Hash should be wrapped by utils.wrapConstructor");fu(e.outputLen),fu(e.blockLen)}function ln(e,t=!0){if(e.destroyed)throw new Error("Hash instance has been destroyed");if(t&&e.finished)throw new Error("Hash#digest() has already been called")}function hu(e,t){Bo(e);let r=t.outputLen;if(e.length<r)throw new Error(`digestInto() expects output buffer of length at least ${r}`)}var Li=typeof globalThis=="object"&&"crypto"in globalThis?globalThis.crypto:void 0;var du=e=>e instanceof Uint8Array;var Di=e=>new DataView(e.buffer,e.byteOffset,e.byteLength),Ie=(e,t)=>e<<32-t|e>>>t,Ry=new Uint8Array(new Uint32Array([287454020]).buffer)[0]===68;if(!Ry)throw new Error("Non little-endian hardware is not supported");function Io(e){if(typeof e!="string")throw new Error(`utf8ToBytes expected string, got ${typeof e}`);return new Uint8Array(new TextEncoder().encode(e))}function Kn(e){if(typeof e=="string"&&(e=Io(e)),!du(e))throw new Error(`expected Uint8Array, got ${typeof e}`);return e}function Ni(...e){let t=new Uint8Array(e.reduce((n,i)=>n+i.length,0)),r=0;return e.forEach(n=>{if(!du(n))throw new Error("Uint8Array expected");t.set(n,r),r+=n.length}),t}var hn=class{clone(){return this._cloneInto()}},X2={}.toString;function Pi(e){let t=n=>e().update(Kn(n)).digest(),r=e();return t.outputLen=r.outputLen,t.blockLen=r.blockLen,t.create=()=>e(),t}function dn(e=32){if(Li&&typeof Li.getRandomValues=="function")return Li.getRandomValues(new Uint8Array(e));throw new Error("crypto.getRandomValues must be defined")}function Ly(e,t,r,n){if(typeof e.setBigUint64=="function")return e.setBigUint64(t,r,n);let i=BigInt(32),s=BigInt(4294967295),o=Number(r>>i&s),a=Number(r&s),c=n?4:0,u=n?0:4;e.setUint32(t+c,o,n),e.setUint32(t+u,a,n)}var pn=class extends hn{constructor(t,r,n,i){super(),this.blockLen=t,this.outputLen=r,this.padOffset=n,this.isLE=i,this.finished=!1,this.length=0,this.pos=0,this.destroyed=!1,this.buffer=new Uint8Array(t),this.view=Di(this.buffer)}update(t){ln(this);let{view:r,buffer:n,blockLen:i}=this;t=Kn(t);let s=t.length;for(let o=0;o<s;){let a=Math.min(i-this.pos,s-o);if(a===i){let c=Di(t);for(;i<=s-o;o+=i)this.process(c,o);continue}n.set(t.subarray(o,o+a),this.pos),this.pos+=a,o+=a,this.pos===i&&(this.process(r,0),this.pos=0)}return this.length+=t.length,this.roundClean(),this}digestInto(t){ln(this),hu(t,this),this.finished=!0;let{buffer:r,view:n,blockLen:i,isLE:s}=this,{pos:o}=this;r[o++]=128,this.buffer.subarray(o).fill(0),this.padOffset>i-o&&(this.process(n,0),o=0);for(let l=o;l<i;l++)r[l]=0;Ly(n,i-8,BigInt(this.length*8),s),this.process(n,0);let a=Di(t),c=this.outputLen;if(c%4)throw new Error("_sha2: outputLen should be aligned to 32bit");let u=c/4,f=this.get();if(u>f.length)throw new Error("_sha2: outputLen bigger than state");for(let l=0;l<u;l++)a.setUint32(4*l,f[l],s)}digest(){let{buffer:t,outputLen:r}=this;this.digestInto(t);let n=t.slice(0,r);return this.destroy(),n}_cloneInto(t){t||(t=new this.constructor),t.set(...this.get());let{blockLen:r,buffer:n,length:i,finished:s,destroyed:o,pos:a}=this;return t.length=i,t.pos=a,t.finished=s,t.destroyed=o,i%r&&t.buffer.set(n),t}};var ki=BigInt(4294967295),Co=BigInt(32);function pu(e,t=!1){return t?{h:Number(e&ki),l:Number(e>>Co&ki)}:{h:Number(e>>Co&ki)|0,l:Number(e&ki)|0}}function Dy(e,t=!1){let r=new Uint32Array(e.length),n=new Uint32Array(e.length);for(let i=0;i<e.length;i++){let{h:s,l:o}=pu(e[i],t);[r[i],n[i]]=[s,o]}return[r,n]}var Ny=(e,t)=>BigInt(e>>>0)<<Co|BigInt(t>>>0),Py=(e,t,r)=>e>>>r,ky=(e,t,r)=>e<<32-r|t>>>r,Uy=(e,t,r)=>e>>>r|t<<32-r,Oy=(e,t,r)=>e<<32-r|t>>>r,My=(e,t,r)=>e<<64-r|t>>>r-32,Ky=(e,t,r)=>e>>>r-32|t<<64-r,Fy=(e,t)=>t,Vy=(e,t)=>e,qy=(e,t,r)=>e<<r|t>>>32-r,Hy=(e,t,r)=>t<<r|e>>>32-r,zy=(e,t,r)=>t<<r-32|e>>>64-r,Gy=(e,t,r)=>e<<r-32|t>>>64-r;function Wy(e,t,r,n){let i=(t>>>0)+(n>>>0);return{h:e+r+(i/2**32|0)|0,l:i|0}}var Yy=(e,t,r)=>(e>>>0)+(t>>>0)+(r>>>0),$y=(e,t,r,n)=>t+r+n+(e/2**32|0)|0,Qy=(e,t,r,n)=>(e>>>0)+(t>>>0)+(r>>>0)+(n>>>0),Zy=(e,t,r,n,i)=>t+r+n+i+(e/2**32|0)|0,Xy=(e,t,r,n,i)=>(e>>>0)+(t>>>0)+(r>>>0)+(n>>>0)+(i>>>0),Jy=(e,t,r,n,i,s)=>t+r+n+i+s+(e/2**32|0)|0;var jy={fromBig:pu,split:Dy,toBig:Ny,shrSH:Py,shrSL:ky,rotrSH:Uy,rotrSL:Oy,rotrBH:My,rotrBL:Ky,rotr32H:Fy,rotr32L:Vy,rotlSH:qy,rotlSL:Hy,rotlBH:zy,rotlBL:Gy,add:Wy,add3L:Yy,add3H:$y,add4L:Qy,add4H:Zy,add5H:Jy,add5L:Xy},Z=jy;var[tm,em]=Z.split(["0x428a2f98d728ae22","0x7137449123ef65cd","0xb5c0fbcfec4d3b2f","0xe9b5dba58189dbbc","0x3956c25bf348b538","0x59f111f1b605d019","0x923f82a4af194f9b","0xab1c5ed5da6d8118","0xd807aa98a3030242","0x12835b0145706fbe","0x243185be4ee4b28c","0x550c7dc3d5ffb4e2","0x72be5d74f27b896f","0x80deb1fe3b1696b1","0x9bdc06a725c71235","0xc19bf174cf692694","0xe49b69c19ef14ad2","0xefbe4786384f25e3","0x0fc19dc68b8cd5b5","0x240ca1cc77ac9c65","0x2de92c6f592b0275","0x4a7484aa6ea6e483","0x5cb0a9dcbd41fbd4","0x76f988da831153b5","0x983e5152ee66dfab","0xa831c66d2db43210","0xb00327c898fb213f","0xbf597fc7beef0ee4","0xc6e00bf33da88fc2","0xd5a79147930aa725","0x06ca6351e003826f","0x142929670a0e6e70","0x27b70a8546d22ffc","0x2e1b21385c26c926","0x4d2c6dfc5ac42aed","0x53380d139d95b3df","0x650a73548baf63de","0x766a0abb3c77b2a8","0x81c2c92e47edaee6","0x92722c851482353b","0xa2bfe8a14cf10364","0xa81a664bbc423001","0xc24b8b70d0f89791","0xc76c51a30654be30","0xd192e819d6ef5218","0xd69906245565a910","0xf40e35855771202a","0x106aa07032bbd1b8","0x19a4c116b8d2d0c8","0x1e376c085141ab53","0x2748774cdf8eeb99","0x34b0bcb5e19b48a8","0x391c0cb3c5c95a63","0x4ed8aa4ae3418acb","0x5b9cca4f7763e373","0x682e6ff3d6b2b8a3","0x748f82ee5defb2fc","0x78a5636f43172f60","0x84c87814a1f0ab72","0x8cc702081a6439ec","0x90befffa23631e28","0xa4506cebde82bde9","0xbef9a3f7b2c67915","0xc67178f2e372532b","0xca273eceea26619c","0xd186b8c721c0c207","0xeada7dd6cde0eb1e","0xf57d4f7fee6ed178","0x06f067aa72176fba","0x0a637dc5a2c898a6","0x113f9804bef90dae","0x1b710b35131c471b","0x28db77f523047d84","0x32caab7b40c72493","0x3c9ebe0a15c9bebc","0x431d67c49c100d4c","0x4cc5d4becb3e42b6","0x597f299cfc657e2a","0x5fcb6fab3ad6faec","0x6c44198c4a475817"].map(e=>BigInt(e))),yr=new Uint32Array(80),mr=new Uint32Array(80),_o=class extends pn{constructor(){super(128,64,16,!1),this.Ah=1779033703,this.Al=-205731576,this.Bh=-1150833019,this.Bl=-2067093701,this.Ch=1013904242,this.Cl=-23791573,this.Dh=-1521486534,this.Dl=1595750129,this.Eh=1359893119,this.El=-1377402159,this.Fh=-1694144372,this.Fl=725511199,this.Gh=528734635,this.Gl=-79577749,this.Hh=1541459225,this.Hl=327033209}get(){let{Ah:t,Al:r,Bh:n,Bl:i,Ch:s,Cl:o,Dh:a,Dl:c,Eh:u,El:f,Fh:l,Fl:h,Gh:y,Gl:d,Hh:p,Hl:m}=this;return[t,r,n,i,s,o,a,c,u,f,l,h,y,d,p,m]}set(t,r,n,i,s,o,a,c,u,f,l,h,y,d,p,m){this.Ah=t|0,this.Al=r|0,this.Bh=n|0,this.Bl=i|0,this.Ch=s|0,this.Cl=o|0,this.Dh=a|0,this.Dl=c|0,this.Eh=u|0,this.El=f|0,this.Fh=l|0,this.Fl=h|0,this.Gh=y|0,this.Gl=d|0,this.Hh=p|0,this.Hl=m|0}process(t,r){for(let b=0;b<16;b++,r+=4)yr[b]=t.getUint32(r),mr[b]=t.getUint32(r+=4);for(let b=16;b<80;b++){let R=yr[b-15]|0,w=mr[b-15]|0,S=Z.rotrSH(R,w,1)^Z.rotrSH(R,w,8)^Z.shrSH(R,w,7),L=Z.rotrSL(R,w,1)^Z.rotrSL(R,w,8)^Z.shrSL(R,w,7),D=yr[b-2]|0,Y=mr[b-2]|0,W=Z.rotrSH(D,Y,19)^Z.rotrBH(D,Y,61)^Z.shrSH(D,Y,6),q=Z.rotrSL(D,Y,19)^Z.rotrBL(D,Y,61)^Z.shrSL(D,Y,6),j=Z.add4L(L,q,mr[b-7],mr[b-16]),lt=Z.add4H(j,S,W,yr[b-7],yr[b-16]);yr[b]=lt|0,mr[b]=j|0}let{Ah:n,Al:i,Bh:s,Bl:o,Ch:a,Cl:c,Dh:u,Dl:f,Eh:l,El:h,Fh:y,Fl:d,Gh:p,Gl:m,Hh:x,Hl:E}=this;for(let b=0;b<80;b++){let R=Z.rotrSH(l,h,14)^Z.rotrSH(l,h,18)^Z.rotrBH(l,h,41),w=Z.rotrSL(l,h,14)^Z.rotrSL(l,h,18)^Z.rotrBL(l,h,41),S=l&y^~l&p,L=h&d^~h&m,D=Z.add5L(E,w,L,em[b],mr[b]),Y=Z.add5H(D,x,R,S,tm[b],yr[b]),W=D|0,q=Z.rotrSH(n,i,28)^Z.rotrBH(n,i,34)^Z.rotrBH(n,i,39),j=Z.rotrSL(n,i,28)^Z.rotrBL(n,i,34)^Z.rotrBL(n,i,39),lt=n&s^n&a^s&a,Ht=i&o^i&c^o&c;x=p|0,E=m|0,p=y|0,m=d|0,y=l|0,d=h|0,{h:l,l:h}=Z.add(u|0,f|0,Y|0,W|0),u=a|0,f=c|0,a=s|0,c=o|0,s=n|0,o=i|0;let I=Z.add3L(W,j,Ht);n=Z.add3H(I,Y,q,lt),i=I|0}({h:n,l:i}=Z.add(this.Ah|0,this.Al|0,n|0,i|0)),{h:s,l:o}=Z.add(this.Bh|0,this.Bl|0,s|0,o|0),{h:a,l:c}=Z.add(this.Ch|0,this.Cl|0,a|0,c|0),{h:u,l:f}=Z.add(this.Dh|0,this.Dl|0,u|0,f|0),{h:l,l:h}=Z.add(this.Eh|0,this.El|0,l|0,h|0),{h:y,l:d}=Z.add(this.Fh|0,this.Fl|0,y|0,d|0),{h:p,l:m}=Z.add(this.Gh|0,this.Gl|0,p|0,m|0),{h:x,l:E}=Z.add(this.Hh|0,this.Hl|0,x|0,E|0),this.set(n,i,s,o,a,c,u,f,l,h,y,d,p,m,x,E)}roundClean(){yr.fill(0),mr.fill(0)}destroy(){this.buffer.fill(0),this.set(0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0)}};var Ro=Pi(()=>new _o);var Mi={};Kt(Mi,{bitGet:()=>cm,bitLen:()=>am,bitMask:()=>Fn,bitSet:()=>um,bytesToHex:()=>Ze,bytesToNumberBE:()=>Xe,bytesToNumberLE:()=>gr,concatBytes:()=>Je,createHmacDrbg:()=>No,ensureBytes:()=>It,equalBytes:()=>sm,hexToBytes:()=>kr,hexToNumber:()=>Do,numberToBytesBE:()=>xr,numberToBytesLE:()=>Ur,numberToHexUnpadded:()=>gu,numberToVarBytesBE:()=>im,utf8ToBytes:()=>om,validateObject:()=>Fe});var mu=BigInt(0),Ui=BigInt(1),rm=BigInt(2),Oi=e=>e instanceof Uint8Array,nm=Array.from({length:256},(e,t)=>t.toString(16).padStart(2,"0"));function Ze(e){if(!Oi(e))throw new Error("Uint8Array expected");let t="";for(let r=0;r<e.length;r++)t+=nm[e[r]];return t}function gu(e){let t=e.toString(16);return t.length&1?`0${t}`:t}function Do(e){if(typeof e!="string")throw new Error("hex string expected, got "+typeof e);return BigInt(e===""?"0":`0x${e}`)}function kr(e){if(typeof e!="string")throw new Error("hex string expected, got "+typeof e);let t=e.length;if(t%2)throw new Error("padded hex string expected, got unpadded hex of length "+t);let r=new Uint8Array(t/2);for(let n=0;n<r.length;n++){let i=n*2,s=e.slice(i,i+2),o=Number.parseInt(s,16);if(Number.isNaN(o)||o<0)throw new Error("Invalid byte sequence");r[n]=o}return r}function Xe(e){return Do(Ze(e))}function gr(e){if(!Oi(e))throw new Error("Uint8Array expected");return Do(Ze(Uint8Array.from(e).reverse()))}function xr(e,t){return kr(e.toString(16).padStart(t*2,"0"))}function Ur(e,t){return xr(e,t).reverse()}function im(e){return kr(gu(e))}function It(e,t,r){let n;if(typeof t=="string")try{n=kr(t)}catch(s){throw new Error(`${e} must be valid hex string, got "${t}". Cause: ${s}`)}else if(Oi(t))n=Uint8Array.from(t);else throw new Error(`${e} must be hex string or Uint8Array`);let i=n.length;if(typeof r=="number"&&i!==r)throw new Error(`${e} expected ${r} bytes, got ${i}`);return n}function Je(...e){let t=new Uint8Array(e.reduce((n,i)=>n+i.length,0)),r=0;return e.forEach(n=>{if(!Oi(n))throw new Error("Uint8Array expected");t.set(n,r),r+=n.length}),t}function sm(e,t){if(e.length!==t.length)return!1;for(let r=0;r<e.length;r++)if(e[r]!==t[r])return!1;return!0}function om(e){if(typeof e!="string")throw new Error(`utf8ToBytes expected string, got ${typeof e}`);return new Uint8Array(new TextEncoder().encode(e))}function am(e){let t;for(t=0;e>mu;e>>=Ui,t+=1);return t}function cm(e,t){return e>>BigInt(t)&Ui}var um=(e,t,r)=>e|(r?Ui:mu)<<BigInt(t),Fn=e=>(rm<<BigInt(e-1))-Ui,Lo=e=>new Uint8Array(e),yu=e=>Uint8Array.from(e);function No(e,t,r){if(typeof e!="number"||e<2)throw new Error("hashLen must be a number");if(typeof t!="number"||t<2)throw new Error("qByteLen must be a number");if(typeof r!="function")throw new Error("hmacFn must be a function");let n=Lo(e),i=Lo(e),s=0,o=()=>{n.fill(1),i.fill(0),s=0},a=(...l)=>r(i,n,...l),c=(l=Lo())=>{i=a(yu([0]),l),n=a(),l.length!==0&&(i=a(yu([1]),l),n=a())},u=()=>{if(s++>=1e3)throw new Error("drbg: tried 1000 values");let l=0,h=[];for(;l<t;){n=a();let y=n.slice();h.push(y),l+=n.length}return Je(...h)};return(l,h)=>{o(),c(l);let y;for(;!(y=h(u()));)c();return o(),y}}var fm={bigint:e=>typeof e=="bigint",function:e=>typeof e=="function",boolean:e=>typeof e=="boolean",string:e=>typeof e=="string",stringOrUint8Array:e=>typeof e=="string"||e instanceof Uint8Array,isSafeInteger:e=>Number.isSafeInteger(e),array:e=>Array.isArray(e),field:(e,t)=>t.Fp.isValid(e),hash:e=>typeof e=="function"&&Number.isSafeInteger(e.outputLen)};function Fe(e,t,r={}){let n=(i,s,o)=>{let a=fm[s];if(typeof a!="function")throw new Error(`Invalid validator "${s}", expected function`);let c=e[i];if(!(o&&c===void 0)&&!a(c,e))throw new Error(`Invalid param ${String(i)}=${c} (${typeof c}), expected ${s}`)};for(let[i,s]of Object.entries(t))n(i,s,!1);for(let[i,s]of Object.entries(r))n(i,s,!0);return e}var Mt=BigInt(0),bt=BigInt(1),Or=BigInt(2),lm=BigInt(3),Po=BigInt(4),xu=BigInt(5),vu=BigInt(8),hm=BigInt(9),dm=BigInt(16);function dt(e,t){let r=e%t;return r>=Mt?r:t+r}function pm(e,t,r){if(r<=Mt||t<Mt)throw new Error("Expected power/modulo > 0");if(r===bt)return Mt;let n=bt;for(;t>Mt;)t&bt&&(n=n*e%r),e=e*e%r,t>>=bt;return n}function Et(e,t,r){let n=e;for(;t-- >Mt;)n*=n,n%=r;return n}function Ki(e,t){if(e===Mt||t<=Mt)throw new Error(`invert: expected positive integers, got n=${e} mod=${t}`);let r=dt(e,t),n=t,i=Mt,s=bt,o=bt,a=Mt;for(;r!==Mt;){let u=n/r,f=n%r,l=i-o*u,h=s-a*u;n=r,r=f,i=o,s=a,o=l,a=h}if(n!==bt)throw new Error("invert: does not exist");return dt(i,t)}function ym(e){let t=(e-bt)/Or,r,n,i;for(r=e-bt,n=0;r%Or===Mt;r/=Or,n++);for(i=Or;i<e&&pm(i,t,e)!==e-bt;i++);if(n===1){let o=(e+bt)/Po;return function(c,u){let f=c.pow(u,o);if(!c.eql(c.sqr(f),u))throw new Error("Cannot find square root");return f}}let s=(r+bt)/Or;return function(a,c){if(a.pow(c,t)===a.neg(a.ONE))throw new Error("Cannot find square root");let u=n,f=a.pow(a.mul(a.ONE,i),r),l=a.pow(c,s),h=a.pow(c,r);for(;!a.eql(h,a.ONE);){if(a.eql(h,a.ZERO))return a.ZERO;let y=1;for(let p=a.sqr(h);y<u&&!a.eql(p,a.ONE);y++)p=a.sqr(p);let d=a.pow(f,bt<<BigInt(u-y-1));f=a.sqr(d),l=a.mul(l,d),h=a.mul(h,f),u=y}return l}}function mm(e){if(e%Po===lm){let t=(e+bt)/Po;return function(n,i){let s=n.pow(i,t);if(!n.eql(n.sqr(s),i))throw new Error("Cannot find square root");return s}}if(e%vu===xu){let t=(e-xu)/vu;return function(n,i){let s=n.mul(i,Or),o=n.pow(s,t),a=n.mul(i,o),c=n.mul(n.mul(a,Or),o),u=n.mul(a,n.sub(c,n.ONE));if(!n.eql(n.sqr(u),i))throw new Error("Cannot find square root");return u}}return e%dm,ym(e)}var bu=(e,t)=>(dt(e,t)&bt)===bt,gm=["create","isValid","is0","neg","inv","sqrt","sqr","eql","add","sub","mul","pow","div","addN","subN","mulN","sqrN"];function ko(e){let t={ORDER:"bigint",MASK:"bigint",BYTES:"isSafeInteger",BITS:"isSafeInteger"},r=gm.reduce((n,i)=>(n[i]="function",n),t);return Fe(e,r)}function xm(e,t,r){if(r<Mt)throw new Error("Expected power > 0");if(r===Mt)return e.ONE;if(r===bt)return t;let n=e.ONE,i=t;for(;r>Mt;)r&bt&&(n=e.mul(n,i)),i=e.sqr(i),r>>=bt;return n}function vm(e,t){let r=new Array(t.length),n=t.reduce((s,o,a)=>e.is0(o)?s:(r[a]=s,e.mul(s,o)),e.ONE),i=e.inv(n);return t.reduceRight((s,o,a)=>e.is0(o)?s:(r[a]=e.mul(s,r[a]),e.mul(s,o)),i),r}function Uo(e,t){let r=t!==void 0?t:e.toString(2).length,n=Math.ceil(r/8);return{nBitLength:r,nByteLength:n}}function Fi(e,t,r=!1,n={}){if(e<=Mt)throw new Error(`Expected Field ORDER > 0, got ${e}`);let{nBitLength:i,nByteLength:s}=Uo(e,t);if(s>2048)throw new Error("Field lengths over 2048 bytes are not supported");let o=mm(e),a=Object.freeze({ORDER:e,BITS:i,BYTES:s,MASK:Fn(i),ZERO:Mt,ONE:bt,create:c=>dt(c,e),isValid:c=>{if(typeof c!="bigint")throw new Error(`Invalid field element: expected bigint, got ${typeof c}`);return Mt<=c&&c<e},is0:c=>c===Mt,isOdd:c=>(c&bt)===bt,neg:c=>dt(-c,e),eql:(c,u)=>c===u,sqr:c=>dt(c*c,e),add:(c,u)=>dt(c+u,e),sub:(c,u)=>dt(c-u,e),mul:(c,u)=>dt(c*u,e),pow:(c,u)=>xm(a,c,u),div:(c,u)=>dt(c*Ki(u,e),e),sqrN:c=>c*c,addN:(c,u)=>c+u,subN:(c,u)=>c-u,mulN:(c,u)=>c*u,inv:c=>Ki(c,e),sqrt:n.sqrt||(c=>o(a,c)),invertBatch:c=>vm(a,c),cmov:(c,u,f)=>f?u:c,toBytes:c=>r?Ur(c,s):xr(c,s),fromBytes:c=>{if(c.length!==s)throw new Error(`Fp.fromBytes: expected ${s}, got ${c.length}`);return r?gr(c):Xe(c)}});return Object.freeze(a)}function Eu(e,t){if(!e.isOdd)throw new Error("Field doesn't have isOdd");let r=e.sqrt(t);return e.isOdd(r)?e.neg(r):r}function wu(e){if(typeof e!="bigint")throw new Error("field order must be bigint");let t=e.toString(2).length;return Math.ceil(t/8)}function Oo(e){let t=wu(e);return t+Math.ceil(t/2)}function Su(e,t,r=!1){let n=e.length,i=wu(t),s=Oo(t);if(n<16||n<s||n>1024)throw new Error(`expected ${s}-1024 bytes of input, got ${n}`);let o=r?Xe(e):gr(e),a=dt(o,t-bt)+bt;return r?Ur(a,i):xr(a,i)}var Em=BigInt(0),Mo=BigInt(1);function Vi(e,t){let r=(i,s)=>{let o=s.negate();return i?o:s},n=i=>{let s=Math.ceil(t/i)+1,o=2**(i-1);return{windows:s,windowSize:o}};return{constTimeNegate:r,unsafeLadder(i,s){let o=e.ZERO,a=i;for(;s>Em;)s&Mo&&(o=o.add(a)),a=a.double(),s>>=Mo;return o},precomputeWindow(i,s){let{windows:o,windowSize:a}=n(s),c=[],u=i,f=u;for(let l=0;l<o;l++){f=u,c.push(f);for(let h=1;h<a;h++)f=f.add(u),c.push(f);u=f.double()}return c},wNAF(i,s,o){let{windows:a,windowSize:c}=n(i),u=e.ZERO,f=e.BASE,l=BigInt(2**i-1),h=2**i,y=BigInt(i);for(let d=0;d<a;d++){let p=d*c,m=Number(o&l);o>>=y,m>c&&(m-=h,o+=Mo);let x=p,E=p+Math.abs(m)-1,b=d%2!==0,R=m<0;m===0?f=f.add(r(b,s[x])):u=u.add(r(R,s[E]))}return{p:u,f}},wNAFCached(i,s,o,a){let c=i._WINDOW_SIZE||1,u=s.get(i);return u||(u=this.precomputeWindow(i,c),c!==1&&s.set(i,a(u))),this.wNAF(c,u,o)}}}function Vn(e){return ko(e.Fp),Fe(e,{n:"bigint",h:"bigint",Gx:"field",Gy:"field"},{nBitLength:"isSafeInteger",nByteLength:"isSafeInteger"}),Object.freeze({...Uo(e.n,e.nBitLength),...e,p:e.Fp.ORDER})}var Ce=BigInt(0),he=BigInt(1),qi=BigInt(2),wm=BigInt(8),Sm={zip215:!0};function Am(e){let t=Vn(e);return Fe(e,{hash:"function",a:"bigint",d:"bigint",randomBytes:"function"},{adjustScalarBytes:"function",domain:"function",uvRatio:"function",mapToCurve:"function"}),Object.freeze({...t})}function Hi(e){let t=Am(e),{Fp:r,n,prehash:i,hash:s,randomBytes:o,nByteLength:a,h:c}=t,u=qi<<BigInt(a*8)-he,f=r.create,l=t.uvRatio||((N,T)=>{try{return{isValid:!0,value:r.sqrt(N*r.inv(T))}}catch{return{isValid:!1,value:Ce}}}),h=t.adjustScalarBytes||(N=>N),y=t.domain||((N,T,M)=>{if(T.length||M)throw new Error("Contexts/pre-hash are not supported");return N}),d=N=>typeof N=="bigint"&&Ce<N,p=(N,T)=>d(N)&&d(T)&&N<T,m=N=>N===Ce||p(N,u);function x(N,T){if(p(N,T))return N;throw new Error(`Expected valid scalar < ${T}, got ${typeof N} ${N}`)}function E(N){return N===Ce?N:x(N,n)}let b=new Map;function R(N){if(!(N instanceof w))throw new Error("ExtendedPoint expected")}class w{constructor(T,M,F,G){if(this.ex=T,this.ey=M,this.ez=F,this.et=G,!m(T))throw new Error("x required");if(!m(M))throw new Error("y required");if(!m(F))throw new Error("z required");if(!m(G))throw new Error("t required")}get x(){return this.toAffine().x}get y(){return this.toAffine().y}static fromAffine(T){if(T instanceof w)throw new Error("extended point not allowed");let{x:M,y:F}=T||{};if(!m(M)||!m(F))throw new Error("invalid affine point");return new w(M,F,he,f(M*F))}static normalizeZ(T){let M=r.invertBatch(T.map(F=>F.ez));return T.map((F,G)=>F.toAffine(M[G])).map(w.fromAffine)}_setWindowSize(T){this._WINDOW_SIZE=T,b.delete(this)}assertValidity(){let{a:T,d:M}=t;if(this.is0())throw new Error("bad point: ZERO");let{ex:F,ey:G,ez:X,et}=this,ut=f(F*F),rt=f(G*G),st=f(X*X),Lt=f(st*st),Tt=f(ut*T),zt=f(st*f(Tt+rt)),Gt=f(Lt+f(M*f(ut*rt)));if(zt!==Gt)throw new Error("bad point: equation left != right (1)");let Pt=f(F*G),Wt=f(X*et);if(Pt!==Wt)throw new Error("bad point: equation left != right (2)")}equals(T){R(T);let{ex:M,ey:F,ez:G}=this,{ex:X,ey:et,ez:ut}=T,rt=f(M*ut),st=f(X*G),Lt=f(F*ut),Tt=f(et*G);return rt===st&&Lt===Tt}is0(){return this.equals(w.ZERO)}negate(){return new w(f(-this.ex),this.ey,this.ez,f(-this.et))}double(){let{a:T}=t,{ex:M,ey:F,ez:G}=this,X=f(M*M),et=f(F*F),ut=f(qi*f(G*G)),rt=f(T*X),st=M+F,Lt=f(f(st*st)-X-et),Tt=rt+et,zt=Tt-ut,Gt=rt-et,Pt=f(Lt*zt),Wt=f(Tt*Gt),He=f(Lt*Gt),Ir=f(zt*Tt);return new w(Pt,Wt,Ir,He)}add(T){R(T);let{a:M,d:F}=t,{ex:G,ey:X,ez:et,et:ut}=this,{ex:rt,ey:st,ez:Lt,et:Tt}=T;if(M===BigInt(-1)){let u0=f((X-G)*(st+rt)),f0=f((X+G)*(st-rt)),Ds=f(f0-u0);if(Ds===Ce)return this.double();let l0=f(et*qi*Tt),h0=f(ut*qi*Lt),d0=h0+l0,p0=f0+u0,y0=h0-l0,ql=f(d0*Ds),Hl=f(p0*y0),zl=f(d0*y0),Gl=f(Ds*p0);return new w(ql,Hl,Gl,zl)}let zt=f(G*rt),Gt=f(X*st),Pt=f(ut*F*Tt),Wt=f(et*Lt),He=f((G+X)*(rt+st)-zt-Gt),Ir=Wt-Pt,Cn=Wt+Pt,c0=f(Gt-M*zt),Ml=f(He*Ir),Kl=f(Cn*c0),Fl=f(He*c0),Vl=f(Ir*Cn);return new w(Ml,Kl,Vl,Fl)}subtract(T){return this.add(T.negate())}wNAF(T){return D.wNAFCached(this,b,T,w.normalizeZ)}multiply(T){let{p:M,f:F}=this.wNAF(x(T,n));return w.normalizeZ([M,F])[0]}multiplyUnsafe(T){let M=E(T);return M===Ce?L:this.equals(L)||M===he?this:this.equals(S)?this.wNAF(M).p:D.unsafeLadder(this,M)}isSmallOrder(){return this.multiplyUnsafe(c).is0()}isTorsionFree(){return D.unsafeLadder(this,n).is0()}toAffine(T){let{ex:M,ey:F,ez:G}=this,X=this.is0();T==null&&(T=X?wm:r.inv(G));let et=f(M*T),ut=f(F*T),rt=f(G*T);if(X)return{x:Ce,y:he};if(rt!==he)throw new Error("invZ was invalid");return{x:et,y:ut}}clearCofactor(){let{h:T}=t;return T===he?this:this.multiplyUnsafe(T)}static fromHex(T,M=!1){let{d:F,a:G}=t,X=r.BYTES;T=It("pointHex",T,X);let et=T.slice(),ut=T[X-1];et[X-1]=ut&-129;let rt=gr(et);rt===Ce||(M?x(rt,u):x(rt,r.ORDER));let st=f(rt*rt),Lt=f(st-he),Tt=f(F*st-G),{isValid:zt,value:Gt}=l(Lt,Tt);if(!zt)throw new Error("Point.fromHex: invalid y coordinate");let Pt=(Gt&he)===he,Wt=(ut&128)!==0;if(!M&&Gt===Ce&&Wt)throw new Error("Point.fromHex: x=0 and x_0=1");return Wt!==Pt&&(Gt=f(-Gt)),w.fromAffine({x:Gt,y:rt})}static fromPrivateKey(T){return q(T).point}toRawBytes(){let{x:T,y:M}=this.toAffine(),F=Ur(M,r.BYTES);return F[F.length-1]|=T&he?128:0,F}toHex(){return Ze(this.toRawBytes())}}w.BASE=new w(t.Gx,t.Gy,he,f(t.Gx*t.Gy)),w.ZERO=new w(Ce,he,he,Ce);let{BASE:S,ZERO:L}=w,D=Vi(w,a*8);function Y(N){return dt(N,n)}function W(N){return Y(gr(N))}function q(N){let T=a;N=It("private key",N,T);let M=It("hashed private key",s(N),2*T),F=h(M.slice(0,T)),G=M.slice(T,2*T),X=W(F),et=S.multiply(X),ut=et.toRawBytes();return{head:F,prefix:G,scalar:X,point:et,pointBytes:ut}}function j(N){return q(N).pointBytes}function lt(N=new Uint8Array,...T){let M=Je(...T);return W(s(y(M,It("context",N),!!i)))}function Ht(N,T,M={}){N=It("message",N),i&&(N=i(N));let{prefix:F,scalar:G,pointBytes:X}=q(T),et=lt(M.context,F,N),ut=S.multiply(et).toRawBytes(),rt=lt(M.context,ut,X,N),st=Y(et+rt*G);E(st);let Lt=Je(ut,Ur(st,r.BYTES));return It("result",Lt,a*2)}let I=Sm;function P(N,T,M,F=I){let{context:G,zip215:X}=F,et=r.BYTES;N=It("signature",N,2*et),T=It("message",T),i&&(T=i(T));let ut=gr(N.slice(et,2*et)),rt,st,Lt;try{rt=w.fromHex(M,X),st=w.fromHex(N.slice(0,et),X),Lt=S.multiplyUnsafe(ut)}catch{return!1}if(!X&&rt.isSmallOrder())return!1;let Tt=lt(G,st.toRawBytes(),rt.toRawBytes(),T);return st.add(rt.multiplyUnsafe(Tt)).subtract(Lt).clearCofactor().equals(w.ZERO)}return S._setWindowSize(8),{CURVE:t,getPublicKey:j,sign:Ht,verify:P,ExtendedPoint:w,utils:{getExtendedPublicKey:q,randomPrivateKey:()=>o(r.BYTES),precompute(N=8,T=w.BASE){return T._setWindowSize(N),T.multiply(BigInt(3)),T}}}}var Fo=BigInt("57896044618658097711785492504343953926634992332820282019728792003956564819949"),Au=BigInt("19681161376707505956807079304988542015446066515923890162744021073123829784752"),vv=BigInt(0),Tm=BigInt(1),Ko=BigInt(2),Bm=BigInt(5),Tu=BigInt(10),Im=BigInt(20),Cm=BigInt(40),Bu=BigInt(80);function _m(e){let t=Fo,n=e*e%t*e%t,i=Et(n,Ko,t)*n%t,s=Et(i,Tm,t)*e%t,o=Et(s,Bm,t)*s%t,a=Et(o,Tu,t)*o%t,c=Et(a,Im,t)*a%t,u=Et(c,Cm,t)*c%t,f=Et(u,Bu,t)*u%t,l=Et(f,Bu,t)*u%t,h=Et(l,Tu,t)*o%t;return{pow_p_5_8:Et(h,Ko,t)*e%t,b2:n}}function Rm(e){return e[0]&=248,e[31]&=127,e[31]|=64,e}function Lm(e,t){let r=Fo,n=dt(t*t*t,r),i=dt(n*n*t,r),s=_m(e*i).pow_p_5_8,o=dt(e*n*s,r),a=dt(t*o*o,r),c=o,u=dt(o*Au,r),f=a===e,l=a===dt(-e,r),h=a===dt(-e*Au,r);return f&&(o=c),(l||h)&&(o=u),bu(o,r)&&(o=dt(-o,r)),{isValid:f||l,value:o}}var je=Fi(Fo,void 0,!0),Vo={a:BigInt(-1),d:BigInt("37095705934669439343138083508754565189542113879843219016388785533085940283555"),Fp:je,n:BigInt("7237005577332262213973186563042994240857116359379907606001950938285454250989"),h:BigInt(8),Gx:BigInt("15112221349535400772501151409588531511454012693041857206046113283949847762202"),Gy:BigInt("46316835694926478169428394003475163141307993866256225615783033603165251855960"),hash:Ro,randomBytes:dn,adjustScalarBytes:Rm,uvRatio:Lm},yn=Hi(Vo);function Iu(e,t,r){if(t.length>255)throw new Error("Context is too big");return Ni(Io("SigEd25519 no Ed25519 collisions"),new Uint8Array([r?1:0,t.length]),t,e)}var bv=Hi({...Vo,domain:Iu}),Ev=Hi({...Vo,domain:Iu,prehash:Ro});var Dm=(je.ORDER+BigInt(3))/BigInt(8),wv=je.pow(Ko,Dm),Sv=je.sqrt(je.neg(je.ONE)),Av=(je.ORDER-BigInt(5))/BigInt(8),Tv=BigInt(486662);var Bv=Eu(je,je.neg(BigInt(486664)));var Iv=BigInt("25063068953384623474111414158702152701244531502492656460079210482610430750235"),Cv=BigInt("54469307008909316920995813868745141605393597292927456921205312896311721017578"),_v=BigInt("1159843021668779879193775521855586647937357759715417654439879720876111806838"),Rv=BigInt("40440834346308536858101042469323190826248399146238708352240133220865137265952");var Lv=BigInt("0x7fffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffff");var mn=32,tr=64,zi=32;function Cu(){let e=yn.utils.randomPrivateKey(),t=yn.getPublicKey(e);return{privateKey:Du(e,t),publicKey:t}}function _u(e){if(e.length!==zi)throw new TypeError('"seed" must be 32 bytes in length.');if(!(e instanceof Uint8Array))throw new TypeError('"seed" must be a node.js Buffer, or Uint8Array.');let t=e,r=yn.getPublicKey(t);return{privateKey:Du(t,r),publicKey:r}}function Ru(e,t){let r=e.subarray(0,zi);return yn.sign(t instanceof Uint8Array?t:t.subarray(),r)}function Lu(e,t,r){return yn.verify(t,r instanceof Uint8Array?r:r.subarray(),e)}function Du(e,t){let r=new Uint8Array(tr);for(let n=0;n<zi;n++)r[n]=e[n],r[zi+n]=t[n];return r}var ae={get(e=globalThis){let t=e.crypto;if(t==null||t.subtle==null)throw Object.assign(new Error("Missing Web Crypto API. The most likely cause of this error is that this page is being accessed from an insecure context (i.e. not HTTPS). For more information and possible resolutions see https://github.com/libp2p/js-libp2p/blob/main/packages/crypto/README.md#web-crypto-api"),{code:"ERR_MISSING_WEB_CRYPTO"});return t}};var qo={alg:"A128GCM",ext:!0,k:"scm9jmO_4BJAgdwWGVulLg",key_ops:["encrypt","decrypt"],kty:"oct"};function Ho(e){let t=e?.algorithm??"AES-GCM",r=e?.keyLength??16,n=e?.nonceLength??12,i=e?.digest??"SHA-256",s=e?.saltLength??16,o=e?.iterations??32767,a=ae.get();r*=8;async function c(l,h){let y=a.getRandomValues(new Uint8Array(s)),d=a.getRandomValues(new Uint8Array(n)),p={name:t,iv:d};typeof h=="string"&&(h=Nt(h));let m;if(h.length===0){m=await a.subtle.importKey("jwk",qo,{name:"AES-GCM"},!0,["encrypt"]);try{let E={name:"PBKDF2",salt:y,iterations:o,hash:{name:i}},b=await a.subtle.importKey("raw",h,{name:"PBKDF2"},!1,["deriveKey"]);m=await a.subtle.deriveKey(E,b,{name:t,length:r},!0,["encrypt"])}catch{m=await a.subtle.importKey("jwk",qo,{name:"AES-GCM"},!0,["encrypt"])}}else{let E={name:"PBKDF2",salt:y,iterations:o,hash:{name:i}},b=await a.subtle.importKey("raw",h,{name:"PBKDF2"},!1,["deriveKey"]);m=await a.subtle.deriveKey(E,b,{name:t,length:r},!0,["encrypt"])}let x=await a.subtle.encrypt(p,m,l);return Ot([y,p.iv,new Uint8Array(x)])}async function u(l,h){let y=l.subarray(0,s),d=l.subarray(s,s+n),p=l.subarray(s+n),m={name:t,iv:d};typeof h=="string"&&(h=Nt(h));let x;if(h.length===0)try{let b={name:"PBKDF2",salt:y,iterations:o,hash:{name:i}},R=await a.subtle.importKey("raw",h,{name:"PBKDF2"},!1,["deriveKey"]);x=await a.subtle.deriveKey(b,R,{name:t,length:r},!0,["decrypt"])}catch{x=await a.subtle.importKey("jwk",qo,{name:"AES-GCM"},!0,["decrypt"])}else{let b={name:"PBKDF2",salt:y,iterations:o,hash:{name:i}},R=await a.subtle.importKey("raw",h,{name:"PBKDF2"},!1,["deriveKey"]);x=await a.subtle.deriveKey(b,R,{name:t,length:r},!0,["decrypt"])}let E=await a.subtle.decrypt(m,x,p);return new Uint8Array(E)}return{encrypt:c,decrypt:u}}async function gn(e,t){let n=await Ho().encrypt(e,t);return fi.encode(n)}var zo=new Float32Array([-0]),vr=new Uint8Array(zo.buffer);function Pu(e,t,r){zo[0]=e,t[r]=vr[0],t[r+1]=vr[1],t[r+2]=vr[2],t[r+3]=vr[3]}function ku(e,t){return vr[0]=e[t],vr[1]=e[t+1],vr[2]=e[t+2],vr[3]=e[t+3],zo[0]}var Go=new Float64Array([-0]),Qt=new Uint8Array(Go.buffer);function Uu(e,t,r){Go[0]=e,t[r]=Qt[0],t[r+1]=Qt[1],t[r+2]=Qt[2],t[r+3]=Qt[3],t[r+4]=Qt[4],t[r+5]=Qt[5],t[r+6]=Qt[6],t[r+7]=Qt[7]}function Ou(e,t){return Qt[0]=e[t],Qt[1]=e[t+1],Qt[2]=e[t+2],Qt[3]=e[t+3],Qt[4]=e[t+4],Qt[5]=e[t+5],Qt[6]=e[t+6],Qt[7]=e[t+7],Go[0]}var Pm=BigInt(Number.MAX_SAFE_INTEGER),km=BigInt(Number.MIN_SAFE_INTEGER),ce=class e{lo;hi;constructor(t,r){this.lo=t|0,this.hi=r|0}toNumber(t=!1){if(!t&&this.hi>>>31>0){let r=~this.lo+1>>>0,n=~this.hi>>>0;return r===0&&(n=n+1>>>0),-(r+n*4294967296)}return this.lo+this.hi*4294967296}toBigInt(t=!1){if(t)return BigInt(this.lo>>>0)+(BigInt(this.hi>>>0)<<32n);if(this.hi>>>31){let r=~this.lo+1>>>0,n=~this.hi>>>0;return r===0&&(n=n+1>>>0),-(BigInt(r)+(BigInt(n)<<32n))}return BigInt(this.lo>>>0)+(BigInt(this.hi>>>0)<<32n)}toString(t=!1){return this.toBigInt(t).toString()}zzEncode(){let t=this.hi>>31;return this.hi=((this.hi<<1|this.lo>>>31)^t)>>>0,this.lo=(this.lo<<1^t)>>>0,this}zzDecode(){let t=-(this.lo&1);return this.lo=((this.lo>>>1|this.hi<<31)^t)>>>0,this.hi=(this.hi>>>1^t)>>>0,this}length(){let t=this.lo,r=(this.lo>>>28|this.hi<<4)>>>0,n=this.hi>>>24;return n===0?r===0?t<16384?t<128?1:2:t<2097152?3:4:r<16384?r<128?5:6:r<2097152?7:8:n<128?9:10}static fromBigInt(t){if(t===0n)return Mr;if(t<Pm&&t>km)return this.fromNumber(Number(t));let r=t<0n;r&&(t=-t);let n=t>>32n,i=t-(n<<32n);return r&&(n=~n|0n,i=~i|0n,++i>Mu&&(i=0n,++n>Mu&&(n=0n))),new e(Number(i),Number(n))}static fromNumber(t){if(t===0)return Mr;let r=t<0;r&&(t=-t);let n=t>>>0,i=(t-n)/4294967296>>>0;return r&&(i=~i>>>0,n=~n>>>0,++n>4294967295&&(n=0,++i>4294967295&&(i=0))),new e(n,i)}static from(t){return typeof t=="number"?e.fromNumber(t):typeof t=="bigint"?e.fromBigInt(t):typeof t=="string"?e.fromBigInt(BigInt(t)):t.low!=null||t.high!=null?new e(t.low>>>0,t.high>>>0):Mr}},Mr=new ce(0,0);Mr.toBigInt=function(){return 0n};Mr.zzEncode=Mr.zzDecode=function(){return this};Mr.length=function(){return 1};var Mu=4294967296n;function Ku(e){let t=0,r=0;for(let n=0;n<e.length;++n)r=e.charCodeAt(n),r<128?t+=1:r<2048?t+=2:(r&64512)===55296&&(e.charCodeAt(n+1)&64512)===56320?(++n,t+=4):t+=3;return t}function Fu(e,t,r){if(r-t<1)return"";let i,s=[],o=0,a;for(;t<r;)a=e[t++],a<128?s[o++]=a:a>191&&a<224?s[o++]=(a&31)<<6|e[t++]&63:a>239&&a<365?(a=((a&7)<<18|(e[t++]&63)<<12|(e[t++]&63)<<6|e[t++]&63)-65536,s[o++]=55296+(a>>10),s[o++]=56320+(a&1023)):s[o++]=(a&15)<<12|(e[t++]&63)<<6|e[t++]&63,o>8191&&((i??(i=[])).push(String.fromCharCode.apply(String,s)),o=0);return i!=null?(o>0&&i.push(String.fromCharCode.apply(String,s.slice(0,o))),i.join("")):String.fromCharCode.apply(String,s.slice(0,o))}function Wo(e,t,r){let n=r,i,s;for(let o=0;o<e.length;++o)i=e.charCodeAt(o),i<128?t[r++]=i:i<2048?(t[r++]=i>>6|192,t[r++]=i&63|128):(i&64512)===55296&&((s=e.charCodeAt(o+1))&64512)===56320?(i=65536+((i&1023)<<10)+(s&1023),++o,t[r++]=i>>18|240,t[r++]=i>>12&63|128,t[r++]=i>>6&63|128,t[r++]=i&63|128):(t[r++]=i>>12|224,t[r++]=i>>6&63|128,t[r++]=i&63|128);return r-n}function _e(e,t){return RangeError(`index out of range: ${e.pos} + ${t??1} > ${e.len}`)}function Gi(e,t){return(e[t-4]|e[t-3]<<8|e[t-2]<<16|e[t-1]<<24)>>>0}var Yo=class{buf;pos;len;_slice=Uint8Array.prototype.subarray;constructor(t){this.buf=t,this.pos=0,this.len=t.length}uint32(){let t=4294967295;if(t=(this.buf[this.pos]&127)>>>0,this.buf[this.pos++]<128||(t=(t|(this.buf[this.pos]&127)<<7)>>>0,this.buf[this.pos++]<128)||(t=(t|(this.buf[this.pos]&127)<<14)>>>0,this.buf[this.pos++]<128)||(t=(t|(this.buf[this.pos]&127)<<21)>>>0,this.buf[this.pos++]<128)||(t=(t|(this.buf[this.pos]&15)<<28)>>>0,this.buf[this.pos++]<128))return t;if((this.pos+=5)>this.len)throw this.pos=this.len,_e(this,10);return t}int32(){return this.uint32()|0}sint32(){let t=this.uint32();return t>>>1^-(t&1)|0}bool(){return this.uint32()!==0}fixed32(){if(this.pos+4>this.len)throw _e(this,4);return Gi(this.buf,this.pos+=4)}sfixed32(){if(this.pos+4>this.len)throw _e(this,4);return Gi(this.buf,this.pos+=4)|0}float(){if(this.pos+4>this.len)throw _e(this,4);let t=ku(this.buf,this.pos);return this.pos+=4,t}double(){if(this.pos+8>this.len)throw _e(this,4);let t=Ou(this.buf,this.pos);return this.pos+=8,t}bytes(){let t=this.uint32(),r=this.pos,n=this.pos+t;if(n>this.len)throw _e(this,t);return this.pos+=t,r===n?new Uint8Array(0):this.buf.subarray(r,n)}string(){let t=this.bytes();return Fu(t,0,t.length)}skip(t){if(typeof t=="number"){if(this.pos+t>this.len)throw _e(this,t);this.pos+=t}else do if(this.pos>=this.len)throw _e(this);while(this.buf[this.pos++]&128);return this}skipType(t){switch(t){case 0:this.skip();break;case 1:this.skip(8);break;case 2:this.skip(this.uint32());break;case 3:for(;(t=this.uint32()&7)!==4;)this.skipType(t);break;case 5:this.skip(4);break;default:throw Error(`invalid wire type ${t} at offset ${this.pos}`)}return this}readLongVarint(){let t=new ce(0,0),r=0;if(this.len-this.pos>4){for(;r<4;++r)if(t.lo=(t.lo|(this.buf[this.pos]&127)<<r*7)>>>0,this.buf[this.pos++]<128)return t;if(t.lo=(t.lo|(this.buf[this.pos]&127)<<28)>>>0,t.hi=(t.hi|(this.buf[this.pos]&127)>>4)>>>0,this.buf[this.pos++]<128)return t;r=0}else{for(;r<3;++r){if(this.pos>=this.len)throw _e(this);if(t.lo=(t.lo|(this.buf[this.pos]&127)<<r*7)>>>0,this.buf[this.pos++]<128)return t}return t.lo=(t.lo|(this.buf[this.pos++]&127)<<r*7)>>>0,t}if(this.len-this.pos>4){for(;r<5;++r)if(t.hi=(t.hi|(this.buf[this.pos]&127)<<r*7+3)>>>0,this.buf[this.pos++]<128)return t}else for(;r<5;++r){if(this.pos>=this.len)throw _e(this);if(t.hi=(t.hi|(this.buf[this.pos]&127)<<r*7+3)>>>0,this.buf[this.pos++]<128)return t}throw Error("invalid varint encoding")}readFixed64(){if(this.pos+8>this.len)throw _e(this,8);let t=Gi(this.buf,this.pos+=4),r=Gi(this.buf,this.pos+=4);return new ce(t,r)}int64(){return this.readLongVarint().toBigInt()}int64Number(){return this.readLongVarint().toNumber()}int64String(){return this.readLongVarint().toString()}uint64(){return this.readLongVarint().toBigInt(!0)}uint64Number(){return this.readLongVarint().toNumber(!0)}uint64String(){return this.readLongVarint().toString(!0)}sint64(){return this.readLongVarint().zzDecode().toBigInt()}sint64Number(){return this.readLongVarint().zzDecode().toNumber()}sint64String(){return this.readLongVarint().zzDecode().toString()}fixed64(){return this.readFixed64().toBigInt()}fixed64Number(){return this.readFixed64().toNumber()}fixed64String(){return this.readFixed64().toString()}sfixed64(){return this.readFixed64().toBigInt()}sfixed64Number(){return this.readFixed64().toNumber()}sfixed64String(){return this.readFixed64().toString()}};function $o(e){return new Yo(e instanceof Uint8Array?e:e.subarray())}function Zt(e,t){let r=$o(e);return t.decode(r)}function Qo(e){let t=e??8192,r=t>>>1,n,i=t;return function(o){if(o<1||o>r)return $t(o);i+o>t&&(n=$t(t),i=0);let a=n.subarray(i,i+=o);return i&7&&(i=(i|7)+1),a}}var Kr=class{fn;len;next;val;constructor(t,r,n){this.fn=t,this.len=r,this.next=void 0,this.val=n}};function Zo(){}var Jo=class{head;tail;len;next;constructor(t){this.head=t.head,this.tail=t.tail,this.len=t.len,this.next=t.states}},Um=Qo();function Om(e){return globalThis.Buffer!=null?$t(e):Um(e)}var zn=class{len;head;tail;states;constructor(){this.len=0,this.head=new Kr(Zo,0,0),this.tail=this.head,this.states=null}_push(t,r,n){return this.tail=this.tail.next=new Kr(t,r,n),this.len+=r,this}uint32(t){return this.len+=(this.tail=this.tail.next=new jo((t=t>>>0)<128?1:t<16384?2:t<2097152?3:t<268435456?4:5,t)).len,this}int32(t){return t<0?this._push(qn,10,ce.fromNumber(t)):this.uint32(t)}sint32(t){return this.uint32((t<<1^t>>31)>>>0)}uint64(t){let r=ce.fromBigInt(t);return this._push(qn,r.length(),r)}uint64Number(t){let r=ce.fromNumber(t);return this._push(qn,r.length(),r)}uint64String(t){return this.uint64(BigInt(t))}int64(t){return this.uint64(t)}int64Number(t){return this.uint64Number(t)}int64String(t){return this.uint64String(t)}sint64(t){let r=ce.fromBigInt(t).zzEncode();return this._push(qn,r.length(),r)}sint64Number(t){let r=ce.fromNumber(t).zzEncode();return this._push(qn,r.length(),r)}sint64String(t){return this.sint64(BigInt(t))}bool(t){return this._push(Xo,1,t?1:0)}fixed32(t){return this._push(Hn,4,t>>>0)}sfixed32(t){return this.fixed32(t)}fixed64(t){let r=ce.fromBigInt(t);return this._push(Hn,4,r.lo)._push(Hn,4,r.hi)}fixed64Number(t){let r=ce.fromNumber(t);return this._push(Hn,4,r.lo)._push(Hn,4,r.hi)}fixed64String(t){return this.fixed64(BigInt(t))}sfixed64(t){return this.fixed64(t)}sfixed64Number(t){return this.fixed64Number(t)}sfixed64String(t){return this.fixed64String(t)}float(t){return this._push(Pu,4,t)}double(t){return this._push(Uu,8,t)}bytes(t){let r=t.length>>>0;return r===0?this._push(Xo,1,0):this.uint32(r)._push(Km,r,t)}string(t){let r=Ku(t);return r!==0?this.uint32(r)._push(Wo,r,t):this._push(Xo,1,0)}fork(){return this.states=new Jo(this),this.head=this.tail=new Kr(Zo,0,0),this.len=0,this}reset(){return this.states!=null?(this.head=this.states.head,this.tail=this.states.tail,this.len=this.states.len,this.states=this.states.next):(this.head=this.tail=new Kr(Zo,0,0),this.len=0),this}ldelim(){let t=this.head,r=this.tail,n=this.len;return this.reset().uint32(n),n!==0&&(this.tail.next=t.next,this.tail=r,this.len+=n),this}finish(){let t=this.head.next,r=Om(this.len),n=0;for(;t!=null;)t.fn(t.val,r,n),n+=t.len,t=t.next;return r}};function Xo(e,t,r){t[r]=e&255}function Mm(e,t,r){for(;e>127;)t[r++]=e&127|128,e>>>=7;t[r]=e}var jo=class extends Kr{next;constructor(t,r){super(Mm,t,r),this.next=void 0}};function qn(e,t,r){for(;e.hi!==0;)t[r++]=e.lo&127|128,e.lo=(e.lo>>>7|e.hi<<25)>>>0,e.hi>>>=7;for(;e.lo>127;)t[r++]=e.lo&127|128,e.lo=e.lo>>>7;t[r++]=e.lo}function Hn(e,t,r){t[r]=e&255,t[r+1]=e>>>8&255,t[r+2]=e>>>16&255,t[r+3]=e>>>24}function Km(e,t,r){t.set(e,r)}globalThis.Buffer!=null&&(zn.prototype.bytes=function(e){let t=e.length>>>0;return this.uint32(t),t>0&&this._push(Fm,t,e),this},zn.prototype.string=function(e){let t=globalThis.Buffer.byteLength(e);return this.uint32(t),t>0&&this._push(Vm,t,e),this});function Fm(e,t,r){t.set(e,r)}function Vm(e,t,r){e.length<40?Wo(e,t,r):t.utf8Write!=null?t.utf8Write(e,r):t.set(Nt(e),r)}function ta(){return new zn}function Xt(e,t){let r=ta();return t.encode(e,r,{lengthDelimited:!1}),r.finish()}var xn;(function(e){e[e.VARINT=0]="VARINT",e[e.BIT64=1]="BIT64",e[e.LENGTH_DELIMITED=2]="LENGTH_DELIMITED",e[e.START_GROUP=3]="START_GROUP",e[e.END_GROUP=4]="END_GROUP",e[e.BIT32=5]="BIT32"})(xn||(xn={}));function Wi(e,t,r,n){return{name:e,type:t,encode:r,decode:n}}function Fr(e){function t(i){if(e[i.toString()]==null)throw new Error("Invalid enum value");return e[i]}let r=function(s,o){let a=t(s);o.int32(a)},n=function(s){let o=s.int32();return t(o)};return Wi("enum",xn.VARINT,r,n)}function Jt(e,t){return Wi("message",xn.LENGTH_DELIMITED,e,t)}var wt;(function(e){e.RSA="RSA",e.Ed25519="Ed25519",e.Secp256k1="Secp256k1"})(wt||(wt={}));var ea;(function(e){e[e.RSA=0]="RSA",e[e.Ed25519=1]="Ed25519",e[e.Secp256k1=2]="Secp256k1"})(ea||(ea={}));(function(e){e.codec=()=>Fr(ea)})(wt||(wt={}));var Ve;(function(e){let t;e.codec=()=>(t==null&&(t=Jt((r,n,i={})=>{i.lengthDelimited!==!1&&n.fork(),r.Type!=null&&(n.uint32(8),wt.codec().encode(r.Type,n)),r.Data!=null&&(n.uint32(18),n.bytes(r.Data)),i.lengthDelimited!==!1&&n.ldelim()},(r,n)=>{let i={},s=n==null?r.len:r.pos+n;for(;r.pos<s;){let o=r.uint32();switch(o>>>3){case 1:i.Type=wt.codec().decode(r);break;case 2:i.Data=r.bytes();break;default:r.skipType(o&7);break}}return i})),t),e.encode=r=>Xt(r,e.codec()),e.decode=r=>Zt(r,e.codec())})(Ve||(Ve={}));var qe;(function(e){let t;e.codec=()=>(t==null&&(t=Jt((r,n,i={})=>{i.lengthDelimited!==!1&&n.fork(),r.Type!=null&&(n.uint32(8),wt.codec().encode(r.Type,n)),r.Data!=null&&(n.uint32(18),n.bytes(r.Data)),i.lengthDelimited!==!1&&n.ldelim()},(r,n)=>{let i={},s=n==null?r.len:r.pos+n;for(;r.pos<s;){let o=r.uint32();switch(o>>>3){case 1:i.Type=wt.codec().decode(r);break;case 2:i.Data=r.bytes();break;default:r.skipType(o&7);break}}return i})),t),e.encode=r=>Xt(r,e.codec()),e.decode=r=>Zt(r,e.codec())})(qe||(qe={}));var Gn=class{_key;constructor(t){this._key=vn(t,mn)}verify(t,r){return Lu(this._key,r,t)}marshal(){return this._key}get bytes(){return Ve.encode({Type:wt.Ed25519,Data:this.marshal()}).subarray()}equals(t){return Ct(this.bytes,t.bytes)}hash(){let t=Ut.digest(this.bytes);return ve(t)?t.then(({bytes:r})=>r):t.bytes}},Vr=class{_key;_publicKey;constructor(t,r){this._key=vn(t,tr),this._publicKey=vn(r,mn)}sign(t){return Ru(this._key,t)}get public(){return new Gn(this._publicKey)}marshal(){return this._key}get bytes(){return qe.encode({Type:wt.Ed25519,Data:this.marshal()}).subarray()}equals(t){return Ct(this.bytes,t.bytes)}async hash(){let t=Ut.digest(this.bytes),r;return ve(t)?{bytes:r}=await t:r=t.bytes,r}async id(){let t=cr.digest(this.public.bytes);return kt.encode(t.bytes).substring(1)}async export(t,r="libp2p-key"){if(r==="libp2p-key")return gn(this.bytes,t);throw new H(`export format '${r}' is not supported`,"ERR_INVALID_EXPORT_FORMAT")}};function qm(e){if(e.length>tr){e=vn(e,tr+mn);let n=e.subarray(0,tr),i=e.subarray(tr,e.length);return new Vr(n,i)}e=vn(e,tr);let t=e.subarray(0,tr),r=e.subarray(mn);return new Vr(t,r)}function Hm(e){return e=vn(e,mn),new Gn(e)}async function zm(){let{privateKey:e,publicKey:t}=Cu();return new Vr(e,t)}async function qu(e){let{privateKey:t,publicKey:r}=_u(e);return new Vr(t,r)}function vn(e,t){if(e=Uint8Array.from(e??[]),e.length!==t)throw new H(`Key must be a Uint8Array of length ${t}, got ${e.length}`,"ERR_INVALID_KEY_TYPE");return e}var Gm={"P-256":256,"P-384":384,"P-521":521},Wm=Object.keys(Gm),_b=Wm.join(" / ");var aa={};Kt(aa,{MAX_KEY_SIZE:()=>Qn,RsaPrivateKey:()=>bn,RsaPublicKey:()=>$n,fromJwk:()=>ng,generateKeyPair:()=>ig,unmarshalRsaPrivateKey:()=>eg,unmarshalRsaPublicKey:()=>rg});var Yn=Yt(ht(),1);var dE=Yt(Yu(),1);function $i(e){if(isNaN(e)||e<=0)throw new H("random bytes length must be a Number bigger than 0","ERR_INVALID_LENGTH");return dn(e)}var Qb=Yt(_i(),1),sa=Yt(ht(),1);function $u(e,t){return t.map(r=>le(e[r]))}function Qu(e){return sa.default.pki.setRsaPrivateKey(...$u(e,["n","e","d","p","q","dp","dq","qi"]))}function Zu(e){return sa.default.pki.setRsaPublicKey(...$u(e,["n","e"]))}var Hr={};Kt(Hr,{jwkToPkcs1:()=>Zm,jwkToPkix:()=>Jm,pkcs1ToJwk:()=>Qm,pkixToJwk:()=>Xm});var Jb=Yt(Un(),1),jb=Yt(_i(),1);var er=Yt(ht(),1);function Qm(e){let t=er.default.asn1.fromDer(pt(e,"ascii")),r=er.default.pki.privateKeyFromAsn1(t);return{kty:"RSA",n:Be(r.n),e:Be(r.e),d:Be(r.d),p:Be(r.p),q:Be(r.q),dp:Be(r.dP),dq:Be(r.dQ),qi:Be(r.qInv),alg:"RS256"}}function Zm(e){if(e.n==null||e.e==null||e.d==null||e.p==null||e.q==null||e.dp==null||e.dq==null||e.qi==null)throw new H("JWK was missing components","ERR_INVALID_PARAMETERS");let t=er.default.pki.privateKeyToAsn1({n:le(e.n),e:le(e.e),d:le(e.d),p:le(e.p),q:le(e.q),dP:le(e.dp),dQ:le(e.dq),qInv:le(e.qi)});return Nt(er.default.asn1.toDer(t).getBytes(),"ascii")}function Xm(e){let t=er.default.asn1.fromDer(pt(e,"ascii")),r=er.default.pki.publicKeyFromAsn1(t);return{kty:"RSA",n:Be(r.n),e:Be(r.e)}}function Jm(e){if(e.n==null||e.e==null)throw new H("JWK was missing components","ERR_INVALID_PARAMETERS");let t=er.default.pki.publicKeyToAsn1({n:le(e.n),e:le(e.e)});return Nt(er.default.asn1.toDer(t).getBytes(),"ascii")}async function Xu(e){let t=await ae.get().subtle.generateKey({name:"RSASSA-PKCS1-v1_5",modulusLength:e,publicExponent:new Uint8Array([1,0,1]),hash:{name:"SHA-256"}},!0,["sign","verify"]),r=await tf(t);return{privateKey:r[0],publicKey:r[1]}}async function oa(e){let r=[await ae.get().subtle.importKey("jwk",e,{name:"RSASSA-PKCS1-v1_5",hash:{name:"SHA-256"}},!0,["sign"]),await jm(e)],n=await tf({privateKey:r[0],publicKey:r[1]});return{privateKey:n[0],publicKey:n[1]}}async function Ju(e,t){let r=await ae.get().subtle.importKey("jwk",e,{name:"RSASSA-PKCS1-v1_5",hash:{name:"SHA-256"}},!1,["sign"]),n=await ae.get().subtle.sign({name:"RSASSA-PKCS1-v1_5"},r,t instanceof Uint8Array?t:t.subarray());return new Uint8Array(n,0,n.byteLength)}async function ju(e,t,r){let n=await ae.get().subtle.importKey("jwk",e,{name:"RSASSA-PKCS1-v1_5",hash:{name:"SHA-256"}},!1,["verify"]);return ae.get().subtle.verify({name:"RSASSA-PKCS1-v1_5"},n,t,r instanceof Uint8Array?r:r.subarray())}async function tf(e){if(e.privateKey==null||e.publicKey==null)throw new H("Private and public key are required","ERR_INVALID_PARAMETERS");return Promise.all([ae.get().subtle.exportKey("jwk",e.privateKey),ae.get().subtle.exportKey("jwk",e.publicKey)])}async function jm(e){return ae.get().subtle.importKey("jwk",{kty:e.kty,n:e.n,e:e.e},{name:"RSASSA-PKCS1-v1_5",hash:{name:"SHA-256"}},!0,["verify"])}function ef(e,t,r,n){let i=t?Zu(e):Qu(e),s=pt(r instanceof Uint8Array?r:r.subarray(),"ascii"),o=n(s,i);return Nt(o,"ascii")}function rf(e,t){return ef(e,!0,t,(r,n)=>n.encrypt(r))}function nf(e,t){return ef(e,!1,t,(r,n)=>n.decrypt(r))}function Qi(e){if(e.kty!=="RSA")throw new H("invalid key type","ERR_INVALID_KEY_TYPE");if(e.n==null)throw new H("invalid key modulus","ERR_INVALID_KEY_MODULUS");return Nt(e.n,"base64url").length*8}var Qn=8192,$n=class{_key;constructor(t){this._key=t}verify(t,r){return ju(this._key,r,t)}marshal(){return Hr.jwkToPkix(this._key)}get bytes(){return Ve.encode({Type:wt.RSA,Data:this.marshal()}).subarray()}encrypt(t){return rf(this._key,t)}equals(t){return Ct(this.bytes,t.bytes)}hash(){let t=Ut.digest(this.bytes);return ve(t)?t.then(({bytes:r})=>r):t.bytes}},bn=class{_key;_publicKey;constructor(t,r){this._key=t,this._publicKey=r}genSecret(){return $i(16)}sign(t){return Ju(this._key,t)}get public(){if(this._publicKey==null)throw new H("public key not provided","ERR_PUBKEY_NOT_PROVIDED");return new $n(this._publicKey)}decrypt(t){return nf(this._key,t)}marshal(){return Hr.jwkToPkcs1(this._key)}get bytes(){return qe.encode({Type:wt.RSA,Data:this.marshal()}).subarray()}equals(t){return Ct(this.bytes,t.bytes)}hash(){let t=Ut.digest(this.bytes);return ve(t)?t.then(({bytes:r})=>r):t.bytes}async id(){let t=await this.public.hash();return pt(t,"base58btc")}async export(t,r="pkcs-8"){if(r==="pkcs-8"){let n=new Yn.default.util.ByteBuffer(this.marshal()),i=Yn.default.asn1.fromDer(n),s=Yn.default.pki.privateKeyFromAsn1(i),o={algorithm:"aes256",count:1e4,saltSize:128/8,prfAlgorithm:"sha512"};return Yn.default.pki.encryptRsaPrivateKey(s,t,o)}else{if(r==="libp2p-key")return gn(this.bytes,t);throw new H(`export format '${r}' is not supported`,"ERR_INVALID_EXPORT_FORMAT")}}};async function eg(e){let t=Hr.pkcs1ToJwk(e);if(Qi(t)>Qn)throw new H("key size is too large","ERR_KEY_SIZE_TOO_LARGE");let r=await oa(t);return new bn(r.privateKey,r.publicKey)}function rg(e){let t=Hr.pkixToJwk(e);if(Qi(t)>Qn)throw new H("key size is too large","ERR_KEY_SIZE_TOO_LARGE");return new $n(t)}async function ng(e){if(Qi(e)>Qn)throw new H("key size is too large","ERR_KEY_SIZE_TOO_LARGE");let t=await oa(e);return new bn(t.privateKey,t.publicKey)}async function ig(e){if(e>Qn)throw new H("key size is too large","ERR_KEY_SIZE_TOO_LARGE");let t=await Xu(e);return new bn(t.privateKey,t.publicKey)}var da={};Kt(da,{Secp256k1PrivateKey:()=>Xn,Secp256k1PublicKey:()=>Zn,generateKeyPair:()=>vg,unmarshalSecp256k1PrivateKey:()=>gg,unmarshalSecp256k1PublicKey:()=>xg});var sg=(e,t,r)=>e&t^~e&r,og=(e,t,r)=>e&t^e&r^t&r,ag=new Uint32Array([1116352408,1899447441,3049323471,3921009573,961987163,1508970993,2453635748,2870763221,3624381080,310598401,607225278,1426881987,1925078388,2162078206,2614888103,3248222580,3835390401,4022224774,264347078,604807628,770255983,1249150122,1555081692,1996064986,2554220882,2821834349,2952996808,3210313671,3336571891,3584528711,113926993,338241895,666307205,773529912,1294757372,1396182291,1695183700,1986661051,2177026350,2456956037,2730485921,2820302411,3259730800,3345764771,3516065817,3600352804,4094571909,275423344,430227734,506948616,659060556,883997877,958139571,1322822218,1537002063,1747873779,1955562222,2024104815,2227730452,2361852424,2428436474,2756734187,3204031479,3329325298]),br=new Uint32Array([1779033703,3144134277,1013904242,2773480762,1359893119,2600822924,528734635,1541459225]),Er=new Uint32Array(64),ca=class extends pn{constructor(){super(64,32,8,!1),this.A=br[0]|0,this.B=br[1]|0,this.C=br[2]|0,this.D=br[3]|0,this.E=br[4]|0,this.F=br[5]|0,this.G=br[6]|0,this.H=br[7]|0}get(){let{A:t,B:r,C:n,D:i,E:s,F:o,G:a,H:c}=this;return[t,r,n,i,s,o,a,c]}set(t,r,n,i,s,o,a,c){this.A=t|0,this.B=r|0,this.C=n|0,this.D=i|0,this.E=s|0,this.F=o|0,this.G=a|0,this.H=c|0}process(t,r){for(let l=0;l<16;l++,r+=4)Er[l]=t.getUint32(r,!1);for(let l=16;l<64;l++){let h=Er[l-15],y=Er[l-2],d=Ie(h,7)^Ie(h,18)^h>>>3,p=Ie(y,17)^Ie(y,19)^y>>>10;Er[l]=p+Er[l-7]+d+Er[l-16]|0}let{A:n,B:i,C:s,D:o,E:a,F:c,G:u,H:f}=this;for(let l=0;l<64;l++){let h=Ie(a,6)^Ie(a,11)^Ie(a,25),y=f+h+sg(a,c,u)+ag[l]+Er[l]|0,p=(Ie(n,2)^Ie(n,13)^Ie(n,22))+og(n,i,s)|0;f=u,u=c,c=a,a=o+y|0,o=s,s=i,i=n,n=y+p|0}n=n+this.A|0,i=i+this.B|0,s=s+this.C|0,o=o+this.D|0,a=a+this.E|0,c=c+this.F|0,u=u+this.G|0,f=f+this.H|0,this.set(n,i,s,o,a,c,u,f)}roundClean(){Er.fill(0)}destroy(){this.set(0,0,0,0,0,0,0,0),this.buffer.fill(0)}};var sf=Pi(()=>new ca);function cg(e){let t=Vn(e);Fe(t,{a:"field",b:"field"},{allowedPrivateKeyLengths:"array",wrapPrivateKey:"boolean",isTorsionFree:"function",clearCofactor:"function",allowInfinityPoint:"boolean",fromBytes:"function",toBytes:"function"});let{endo:r,Fp:n,a:i}=t;if(r){if(!n.eql(i,n.ZERO))throw new Error("Endomorphism can only be defined for Koblitz curves that have a=0");if(typeof r!="object"||typeof r.beta!="bigint"||typeof r.splitScalar!="function")throw new Error("Expected endomorphism with beta: bigint and splitScalar: function")}return Object.freeze({...t})}var{bytesToNumberBE:ug,hexToBytes:fg}=Mi,zr={Err:class extends Error{constructor(t=""){super(t)}},_parseInt(e){let{Err:t}=zr;if(e.length<2||e[0]!==2)throw new t("Invalid signature integer tag");let r=e[1],n=e.subarray(2,r+2);if(!r||n.length!==r)throw new t("Invalid signature integer: wrong length");if(n[0]&128)throw new t("Invalid signature integer: negative");if(n[0]===0&&!(n[1]&128))throw new t("Invalid signature integer: unnecessary leading zero");return{d:ug(n),l:e.subarray(r+2)}},toSig(e){let{Err:t}=zr,r=typeof e=="string"?fg(e):e;if(!(r instanceof Uint8Array))throw new Error("ui8a expected");let n=r.length;if(n<2||r[0]!=48)throw new t("Invalid signature tag");if(r[1]!==n-2)throw new t("Invalid signature: incorrect length");let{d:i,l:s}=zr._parseInt(r.subarray(2)),{d:o,l:a}=zr._parseInt(s);if(a.length)throw new t("Invalid signature: left bytes after parsing");return{r:i,s:o}},hexFromSig(e){let t=u=>Number.parseInt(u[0],16)&8?"00"+u:u,r=u=>{let f=u.toString(16);return f.length&1?`0${f}`:f},n=t(r(e.s)),i=t(r(e.r)),s=n.length/2,o=i.length/2,a=r(s),c=r(o);return`30${r(o+s+4)}02${c}${i}02${a}${n}`}},rr=BigInt(0),be=BigInt(1),SE=BigInt(2),of=BigInt(3),AE=BigInt(4);function lg(e){let t=cg(e),{Fp:r}=t,n=t.toBytes||((d,p,m)=>{let x=p.toAffine();return Je(Uint8Array.from([4]),r.toBytes(x.x),r.toBytes(x.y))}),i=t.fromBytes||(d=>{let p=d.subarray(1),m=r.fromBytes(p.subarray(0,r.BYTES)),x=r.fromBytes(p.subarray(r.BYTES,2*r.BYTES));return{x:m,y:x}});function s(d){let{a:p,b:m}=t,x=r.sqr(d),E=r.mul(x,d);return r.add(r.add(E,r.mul(d,p)),m)}if(!r.eql(r.sqr(t.Gy),s(t.Gx)))throw new Error("bad generator point: equation left != right");function o(d){return typeof d=="bigint"&&rr<d&&d<t.n}function a(d){if(!o(d))throw new Error("Expected valid bigint: 0 < bigint < curve.n")}function c(d){let{allowedPrivateKeyLengths:p,nByteLength:m,wrapPrivateKey:x,n:E}=t;if(p&&typeof d!="bigint"){if(d instanceof Uint8Array&&(d=Ze(d)),typeof d!="string"||!p.includes(d.length))throw new Error("Invalid key");d=d.padStart(m*2,"0")}let b;try{b=typeof d=="bigint"?d:Xe(It("private key",d,m))}catch{throw new Error(`private key must be ${m} bytes, hex or bigint, not ${typeof d}`)}return x&&(b=dt(b,E)),a(b),b}let u=new Map;function f(d){if(!(d instanceof l))throw new Error("ProjectivePoint expected")}class l{constructor(p,m,x){if(this.px=p,this.py=m,this.pz=x,p==null||!r.isValid(p))throw new Error("x required");if(m==null||!r.isValid(m))throw new Error("y required");if(x==null||!r.isValid(x))throw new Error("z required")}static fromAffine(p){let{x:m,y:x}=p||{};if(!p||!r.isValid(m)||!r.isValid(x))throw new Error("invalid affine point");if(p instanceof l)throw new Error("projective point not allowed");let E=b=>r.eql(b,r.ZERO);return E(m)&&E(x)?l.ZERO:new l(m,x,r.ONE)}get x(){return this.toAffine().x}get y(){return this.toAffine().y}static normalizeZ(p){let m=r.invertBatch(p.map(x=>x.pz));return p.map((x,E)=>x.toAffine(m[E])).map(l.fromAffine)}static fromHex(p){let m=l.fromAffine(i(It("pointHex",p)));return m.assertValidity(),m}static fromPrivateKey(p){return l.BASE.multiply(c(p))}_setWindowSize(p){this._WINDOW_SIZE=p,u.delete(this)}assertValidity(){if(this.is0()){if(t.allowInfinityPoint&&!r.is0(this.py))return;throw new Error("bad point: ZERO")}let{x:p,y:m}=this.toAffine();if(!r.isValid(p)||!r.isValid(m))throw new Error("bad point: x or y not FE");let x=r.sqr(m),E=s(p);if(!r.eql(x,E))throw new Error("bad point: equation left != right");if(!this.isTorsionFree())throw new Error("bad point: not in prime-order subgroup")}hasEvenY(){let{y:p}=this.toAffine();if(r.isOdd)return!r.isOdd(p);throw new Error("Field doesn't support isOdd")}equals(p){f(p);let{px:m,py:x,pz:E}=this,{px:b,py:R,pz:w}=p,S=r.eql(r.mul(m,w),r.mul(b,E)),L=r.eql(r.mul(x,w),r.mul(R,E));return S&&L}negate(){return new l(this.px,r.neg(this.py),this.pz)}double(){let{a:p,b:m}=t,x=r.mul(m,of),{px:E,py:b,pz:R}=this,w=r.ZERO,S=r.ZERO,L=r.ZERO,D=r.mul(E,E),Y=r.mul(b,b),W=r.mul(R,R),q=r.mul(E,b);return q=r.add(q,q),L=r.mul(E,R),L=r.add(L,L),w=r.mul(p,L),S=r.mul(x,W),S=r.add(w,S),w=r.sub(Y,S),S=r.add(Y,S),S=r.mul(w,S),w=r.mul(q,w),L=r.mul(x,L),W=r.mul(p,W),q=r.sub(D,W),q=r.mul(p,q),q=r.add(q,L),L=r.add(D,D),D=r.add(L,D),D=r.add(D,W),D=r.mul(D,q),S=r.add(S,D),W=r.mul(b,R),W=r.add(W,W),D=r.mul(W,q),w=r.sub(w,D),L=r.mul(W,Y),L=r.add(L,L),L=r.add(L,L),new l(w,S,L)}add(p){f(p);let{px:m,py:x,pz:E}=this,{px:b,py:R,pz:w}=p,S=r.ZERO,L=r.ZERO,D=r.ZERO,Y=t.a,W=r.mul(t.b,of),q=r.mul(m,b),j=r.mul(x,R),lt=r.mul(E,w),Ht=r.add(m,x),I=r.add(b,R);Ht=r.mul(Ht,I),I=r.add(q,j),Ht=r.sub(Ht,I),I=r.add(m,E);let P=r.add(b,w);return I=r.mul(I,P),P=r.add(q,lt),I=r.sub(I,P),P=r.add(x,E),S=r.add(R,w),P=r.mul(P,S),S=r.add(j,lt),P=r.sub(P,S),D=r.mul(Y,I),S=r.mul(W,lt),D=r.add(S,D),S=r.sub(j,D),D=r.add(j,D),L=r.mul(S,D),j=r.add(q,q),j=r.add(j,q),lt=r.mul(Y,lt),I=r.mul(W,I),j=r.add(j,lt),lt=r.sub(q,lt),lt=r.mul(Y,lt),I=r.add(I,lt),q=r.mul(j,I),L=r.add(L,q),q=r.mul(P,I),S=r.mul(Ht,S),S=r.sub(S,q),q=r.mul(Ht,j),D=r.mul(P,D),D=r.add(D,q),new l(S,L,D)}subtract(p){return this.add(p.negate())}is0(){return this.equals(l.ZERO)}wNAF(p){return y.wNAFCached(this,u,p,m=>{let x=r.invertBatch(m.map(E=>E.pz));return m.map((E,b)=>E.toAffine(x[b])).map(l.fromAffine)})}multiplyUnsafe(p){let m=l.ZERO;if(p===rr)return m;if(a(p),p===be)return this;let{endo:x}=t;if(!x)return y.unsafeLadder(this,p);let{k1neg:E,k1:b,k2neg:R,k2:w}=x.splitScalar(p),S=m,L=m,D=this;for(;b>rr||w>rr;)b&be&&(S=S.add(D)),w&be&&(L=L.add(D)),D=D.double(),b>>=be,w>>=be;return E&&(S=S.negate()),R&&(L=L.negate()),L=new l(r.mul(L.px,x.beta),L.py,L.pz),S.add(L)}multiply(p){a(p);let m=p,x,E,{endo:b}=t;if(b){let{k1neg:R,k1:w,k2neg:S,k2:L}=b.splitScalar(m),{p:D,f:Y}=this.wNAF(w),{p:W,f:q}=this.wNAF(L);D=y.constTimeNegate(R,D),W=y.constTimeNegate(S,W),W=new l(r.mul(W.px,b.beta),W.py,W.pz),x=D.add(W),E=Y.add(q)}else{let{p:R,f:w}=this.wNAF(m);x=R,E=w}return l.normalizeZ([x,E])[0]}multiplyAndAddUnsafe(p,m,x){let E=l.BASE,b=(w,S)=>S===rr||S===be||!w.equals(E)?w.multiplyUnsafe(S):w.multiply(S),R=b(this,m).add(b(p,x));return R.is0()?void 0:R}toAffine(p){let{px:m,py:x,pz:E}=this,b=this.is0();p==null&&(p=b?r.ONE:r.inv(E));let R=r.mul(m,p),w=r.mul(x,p),S=r.mul(E,p);if(b)return{x:r.ZERO,y:r.ZERO};if(!r.eql(S,r.ONE))throw new Error("invZ was invalid");return{x:R,y:w}}isTorsionFree(){let{h:p,isTorsionFree:m}=t;if(p===be)return!0;if(m)return m(l,this);throw new Error("isTorsionFree() has not been declared for the elliptic curve")}clearCofactor(){let{h:p,clearCofactor:m}=t;return p===be?this:m?m(l,this):this.multiplyUnsafe(t.h)}toRawBytes(p=!0){return this.assertValidity(),n(l,this,p)}toHex(p=!0){return Ze(this.toRawBytes(p))}}l.BASE=new l(t.Gx,t.Gy,r.ONE),l.ZERO=new l(r.ZERO,r.ONE,r.ZERO);let h=t.nBitLength,y=Vi(l,t.endo?Math.ceil(h/2):h);return{CURVE:t,ProjectivePoint:l,normPrivateKeyToScalar:c,weierstrassEquation:s,isWithinCurveOrder:o}}function hg(e){let t=Vn(e);return Fe(t,{hash:"hash",hmac:"function",randomBytes:"function"},{bits2int:"function",bits2int_modN:"function",lowS:"boolean"}),Object.freeze({lowS:!0,...t})}function af(e){let t=hg(e),{Fp:r,n}=t,i=r.BYTES+1,s=2*r.BYTES+1;function o(I){return rr<I&&I<r.ORDER}function a(I){return dt(I,n)}function c(I){return Ki(I,n)}let{ProjectivePoint:u,normPrivateKeyToScalar:f,weierstrassEquation:l,isWithinCurveOrder:h}=lg({...t,toBytes(I,P,_){let N=P.toAffine(),T=r.toBytes(N.x),M=Je;return _?M(Uint8Array.from([P.hasEvenY()?2:3]),T):M(Uint8Array.from([4]),T,r.toBytes(N.y))},fromBytes(I){let P=I.length,_=I[0],N=I.subarray(1);if(P===i&&(_===2||_===3)){let T=Xe(N);if(!o(T))throw new Error("Point is not on curve");let M=l(T),F=r.sqrt(M),G=(F&be)===be;return(_&1)===1!==G&&(F=r.neg(F)),{x:T,y:F}}else if(P===s&&_===4){let T=r.fromBytes(N.subarray(0,r.BYTES)),M=r.fromBytes(N.subarray(r.BYTES,2*r.BYTES));return{x:T,y:M}}else throw new Error(`Point of length ${P} was invalid. Expected ${i} compressed bytes or ${s} uncompressed bytes`)}}),y=I=>Ze(xr(I,t.nByteLength));function d(I){let P=n>>be;return I>P}function p(I){return d(I)?a(-I):I}let m=(I,P,_)=>Xe(I.slice(P,_));class x{constructor(P,_,N){this.r=P,this.s=_,this.recovery=N,this.assertValidity()}static fromCompact(P){let _=t.nByteLength;return P=It("compactSignature",P,_*2),new x(m(P,0,_),m(P,_,2*_))}static fromDER(P){let{r:_,s:N}=zr.toSig(It("DER",P));return new x(_,N)}assertValidity(){if(!h(this.r))throw new Error("r must be 0 < r < CURVE.n");if(!h(this.s))throw new Error("s must be 0 < s < CURVE.n")}addRecoveryBit(P){return new x(this.r,this.s,P)}recoverPublicKey(P){let{r:_,s:N,recovery:T}=this,M=L(It("msgHash",P));if(T==null||![0,1,2,3].includes(T))throw new Error("recovery id invalid");let F=T===2||T===3?_+t.n:_;if(F>=r.ORDER)throw new Error("recovery id 2 or 3 invalid");let G=T&1?"03":"02",X=u.fromHex(G+y(F)),et=c(F),ut=a(-M*et),rt=a(N*et),st=u.BASE.multiplyAndAddUnsafe(X,ut,rt);if(!st)throw new Error("point at infinify");return st.assertValidity(),st}hasHighS(){return d(this.s)}normalizeS(){return this.hasHighS()?new x(this.r,a(-this.s),this.recovery):this}toDERRawBytes(){return kr(this.toDERHex())}toDERHex(){return zr.hexFromSig({r:this.r,s:this.s})}toCompactRawBytes(){return kr(this.toCompactHex())}toCompactHex(){return y(this.r)+y(this.s)}}let E={isValidPrivateKey(I){try{return f(I),!0}catch{return!1}},normPrivateKeyToScalar:f,randomPrivateKey:()=>{let I=Oo(t.n);return Su(t.randomBytes(I),t.n)},precompute(I=8,P=u.BASE){return P._setWindowSize(I),P.multiply(BigInt(3)),P}};function b(I,P=!0){return u.fromPrivateKey(I).toRawBytes(P)}function R(I){let P=I instanceof Uint8Array,_=typeof I=="string",N=(P||_)&&I.length;return P?N===i||N===s:_?N===2*i||N===2*s:I instanceof u}function w(I,P,_=!0){if(R(I))throw new Error("first arg must be private key");if(!R(P))throw new Error("second arg must be public key");return u.fromHex(P).multiply(f(I)).toRawBytes(_)}let S=t.bits2int||function(I){let P=Xe(I),_=I.length*8-t.nBitLength;return _>0?P>>BigInt(_):P},L=t.bits2int_modN||function(I){return a(S(I))},D=Fn(t.nBitLength);function Y(I){if(typeof I!="bigint")throw new Error("bigint expected");if(!(rr<=I&&I<D))throw new Error(`bigint expected < 2^${t.nBitLength}`);return xr(I,t.nByteLength)}function W(I,P,_=q){if(["recovered","canonical"].some(Tt=>Tt in _))throw new Error("sign() legacy options not supported");let{hash:N,randomBytes:T}=t,{lowS:M,prehash:F,extraEntropy:G}=_;M==null&&(M=!0),I=It("msgHash",I),F&&(I=It("prehashed msgHash",N(I)));let X=L(I),et=f(P),ut=[Y(et),Y(X)];if(G!=null){let Tt=G===!0?T(r.BYTES):G;ut.push(It("extraEntropy",Tt))}let rt=Je(...ut),st=X;function Lt(Tt){let zt=S(Tt);if(!h(zt))return;let Gt=c(zt),Pt=u.BASE.multiply(zt).toAffine(),Wt=a(Pt.x);if(Wt===rr)return;let He=a(Gt*a(st+Wt*et));if(He===rr)return;let Ir=(Pt.x===Wt?0:2)|Number(Pt.y&be),Cn=He;return M&&d(He)&&(Cn=p(He),Ir^=1),new x(Wt,Cn,Ir)}return{seed:rt,k2sig:Lt}}let q={lowS:t.lowS,prehash:!1},j={lowS:t.lowS,prehash:!1};function lt(I,P,_=q){let{seed:N,k2sig:T}=W(I,P,_),M=t;return No(M.hash.outputLen,M.nByteLength,M.hmac)(N,T)}u.BASE._setWindowSize(8);function Ht(I,P,_,N=j){let T=I;if(P=It("msgHash",P),_=It("publicKey",_),"strict"in N)throw new Error("options.strict was renamed to lowS");let{lowS:M,prehash:F}=N,G,X;try{if(typeof T=="string"||T instanceof Uint8Array)try{G=x.fromDER(T)}catch(Pt){if(!(Pt instanceof zr.Err))throw Pt;G=x.fromCompact(T)}else if(typeof T=="object"&&typeof T.r=="bigint"&&typeof T.s=="bigint"){let{r:Pt,s:Wt}=T;G=new x(Pt,Wt)}else throw new Error("PARSE");X=u.fromHex(_)}catch(Pt){if(Pt.message==="PARSE")throw new Error("signature must be Signature instance, Uint8Array or hex string");return!1}if(M&&G.hasHighS())return!1;F&&(P=t.hash(P));let{r:et,s:ut}=G,rt=L(P),st=c(ut),Lt=a(rt*st),Tt=a(et*st),zt=u.BASE.multiplyAndAddUnsafe(X,Lt,Tt)?.toAffine();return zt?a(zt.x)===et:!1}return{CURVE:t,getPublicKey:b,getSharedSecret:w,sign:lt,verify:Ht,ProjectivePoint:u,Signature:x,utils:E}}var Zi=class extends hn{constructor(t,r){super(),this.finished=!1,this.destroyed=!1,lu(t);let n=Kn(r);if(this.iHash=t.create(),typeof this.iHash.update!="function")throw new Error("Expected instance of class which extends utils.Hash");this.blockLen=this.iHash.blockLen,this.outputLen=this.iHash.outputLen;let i=this.blockLen,s=new Uint8Array(i);s.set(n.length>i?t.create().update(n).digest():n);for(let o=0;o<s.length;o++)s[o]^=54;this.iHash.update(s),this.oHash=t.create();for(let o=0;o<s.length;o++)s[o]^=106;this.oHash.update(s),s.fill(0)}update(t){return ln(this),this.iHash.update(t),this}digestInto(t){ln(this),Bo(t,this.outputLen),this.finished=!0,this.iHash.digestInto(t),this.oHash.update(t),this.oHash.digestInto(t),this.destroy()}digest(){let t=new Uint8Array(this.oHash.outputLen);return this.digestInto(t),t}_cloneInto(t){t||(t=Object.create(Object.getPrototypeOf(this),{}));let{oHash:r,iHash:n,finished:i,destroyed:s,blockLen:o,outputLen:a}=this;return t=t,t.finished=i,t.destroyed=s,t.blockLen=o,t.outputLen=a,t.oHash=r._cloneInto(t.oHash),t.iHash=n._cloneInto(t.iHash),t}destroy(){this.destroyed=!0,this.oHash.destroy(),this.iHash.destroy()}},ua=(e,t,r)=>new Zi(e,t).update(r).digest();ua.create=(e,t)=>new Zi(e,t);function dg(e){return{hash:e,hmac:(t,...r)=>ua(e,t,Ni(...r)),randomBytes:dn}}function cf(e,t){let r=n=>af({...e,...dg(n)});return Object.freeze({...r(t),create:r})}var lf=BigInt("0xfffffffffffffffffffffffffffffffffffffffffffffffffffffffefffffc2f"),uf=BigInt("0xfffffffffffffffffffffffffffffffebaaedce6af48a03bbfd25e8cd0364141"),pg=BigInt(1),fa=BigInt(2),ff=(e,t)=>(e+t/fa)/t;function yg(e){let t=lf,r=BigInt(3),n=BigInt(6),i=BigInt(11),s=BigInt(22),o=BigInt(23),a=BigInt(44),c=BigInt(88),u=e*e*e%t,f=u*u*e%t,l=Et(f,r,t)*f%t,h=Et(l,r,t)*f%t,y=Et(h,fa,t)*u%t,d=Et(y,i,t)*y%t,p=Et(d,s,t)*d%t,m=Et(p,a,t)*p%t,x=Et(m,c,t)*m%t,E=Et(x,a,t)*p%t,b=Et(E,r,t)*f%t,R=Et(b,o,t)*d%t,w=Et(R,n,t)*u%t,S=Et(w,fa,t);if(!la.eql(la.sqr(S),e))throw new Error("Cannot find square root");return S}var la=Fi(lf,void 0,void 0,{sqrt:yg}),Re=cf({a:BigInt(0),b:BigInt(7),Fp:la,n:uf,Gx:BigInt("55066263022277343669578718895168534326250603453777594175500187360389116729240"),Gy:BigInt("32670510020758816978083085130507043184471273380659243275938904335757337482424"),h:BigInt(1),lowS:!0,endo:{beta:BigInt("0x7ae96a2b657c07106e64479eac3434e99cf0497512f58995c1396c28719501ee"),splitScalar:e=>{let t=uf,r=BigInt("0x3086d221a7d46bcde86c90e49284eb15"),n=-pg*BigInt("0xe4437ed6010e88286f547fa90abfe4c3"),i=BigInt("0x114ca50f7a8e2f3f657c1108d9d44cfd8"),s=r,o=BigInt("0x100000000000000000000000000000000"),a=ff(s*e,t),c=ff(-n*e,t),u=dt(e-a*r-c*i,t),f=dt(-a*n-c*s,t),l=u>o,h=f>o;if(l&&(u=t-u),h&&(f=t-f),u>o||f>o)throw new Error("splitScalar: Endomorphism failed, k="+e);return{k1neg:l,k1:u,k2neg:h,k2:f}}}},sf),UE=BigInt(0);var OE=Re.ProjectivePoint;function hf(){return Re.utils.randomPrivateKey()}function df(e,t){let r=Ut.digest(t instanceof Uint8Array?t:t.subarray());if(ve(r))return r.then(({digest:n})=>Re.sign(n,e).toDERRawBytes()).catch(n=>{throw new H(String(n),"ERR_INVALID_INPUT")});try{return Re.sign(r.digest,e).toDERRawBytes()}catch(n){throw new H(String(n),"ERR_INVALID_INPUT")}}function pf(e,t,r){let n=Ut.digest(r instanceof Uint8Array?r:r.subarray());if(ve(n))return n.then(({digest:i})=>Re.verify(t,i,e)).catch(i=>{throw new H(String(i),"ERR_INVALID_INPUT")});try{return Re.verify(t,n.digest,e)}catch(i){throw new H(String(i),"ERR_INVALID_INPUT")}}function yf(e){return Re.ProjectivePoint.fromHex(e).toRawBytes(!0)}function mf(e){try{Re.getPublicKey(e,!0)}catch(t){throw new H(String(t),"ERR_INVALID_PRIVATE_KEY")}}function ha(e){try{Re.ProjectivePoint.fromHex(e)}catch(t){throw new H(String(t),"ERR_INVALID_PUBLIC_KEY")}}function gf(e){try{return Re.getPublicKey(e,!0)}catch(t){throw new H(String(t),"ERR_INVALID_PRIVATE_KEY")}}var Zn=class{_key;constructor(t){ha(t),this._key=t}verify(t,r){return pf(this._key,r,t)}marshal(){return yf(this._key)}get bytes(){return Ve.encode({Type:wt.Secp256k1,Data:this.marshal()}).subarray()}equals(t){return Ct(this.bytes,t.bytes)}async hash(){let t=Ut.digest(this.bytes),r;return ve(t)?{bytes:r}=await t:r=t.bytes,r}},Xn=class{_key;_publicKey;constructor(t,r){this._key=t,this._publicKey=r??gf(t),mf(this._key),ha(this._publicKey)}sign(t){return df(this._key,t)}get public(){return new Zn(this._publicKey)}marshal(){return this._key}get bytes(){return qe.encode({Type:wt.Secp256k1,Data:this.marshal()}).subarray()}equals(t){return Ct(this.bytes,t.bytes)}hash(){let t=Ut.digest(this.bytes);return ve(t)?t.then(({bytes:r})=>r):t.bytes}async id(){let t=await this.public.hash();return pt(t,"base58btc")}async export(t,r="libp2p-key"){if(r==="libp2p-key")return gn(this.bytes,t);throw new H(`export format '${r}' is not supported`,"ERR_INVALID_EXPORT_FORMAT")}};function gg(e){return new Xn(e)}function xg(e){return new Zn(e)}async function vg(){let e=hf();return new Xn(e)}var Gr={rsa:aa,ed25519:ra,secp256k1:da};function xf(e){let t=Object.keys(Gr).join(" / ");return new H(`invalid or unsupported key type ${e}. Must be ${t}`,"ERR_UNSUPPORTED_KEY_TYPE")}function vf(e){let t=Ve.decode(e),r=t.Data??new Uint8Array;switch(t.Type){case wt.RSA:return Gr.rsa.unmarshalRsaPublicKey(r);case wt.Ed25519:return Gr.ed25519.unmarshalEd25519PublicKey(r);case wt.Secp256k1:return Gr.secp256k1.unmarshalSecp256k1PublicKey(r);default:throw xf(t.Type??"unknown")}}async function bf(e){let t=qe.decode(e),r=t.Data??new Uint8Array;switch(t.Type){case wt.RSA:return Gr.rsa.unmarshalRsaPrivateKey(r);case wt.Ed25519:return Gr.ed25519.unmarshalEd25519PrivateKey(r);case wt.Secp256k1:return Gr.secp256k1.unmarshalSecp256k1PrivateKey(r);default:throw xf(t.Type??"RSA")}}var Eg=Math.pow(2,7),wg=Math.pow(2,14),Sg=Math.pow(2,21),pa=Math.pow(2,28),ya=Math.pow(2,35),ma=Math.pow(2,42),ga=Math.pow(2,49),ct=128,jt=127;function te(e){if(e<Eg)return 1;if(e<wg)return 2;if(e<Sg)return 3;if(e<pa)return 4;if(e<ya)return 5;if(e<ma)return 6;if(e<ga)return 7;if(Number.MAX_SAFE_INTEGER!=null&&e>Number.MAX_SAFE_INTEGER)throw new RangeError("Could not encode varint");return 8}function Ag(e,t,r=0){switch(te(e)){case 8:t[r++]=e&255|ct,e/=128;case 7:t[r++]=e&255|ct,e/=128;case 6:t[r++]=e&255|ct,e/=128;case 5:t[r++]=e&255|ct,e/=128;case 4:t[r++]=e&255|ct,e>>>=7;case 3:t[r++]=e&255|ct,e>>>=7;case 2:t[r++]=e&255|ct,e>>>=7;case 1:{t[r++]=e&255,e>>>=7;break}default:throw new Error("unreachable")}return t}function Tg(e,t,r=0){switch(te(e)){case 8:t.set(r++,e&255|ct),e/=128;case 7:t.set(r++,e&255|ct),e/=128;case 6:t.set(r++,e&255|ct),e/=128;case 5:t.set(r++,e&255|ct),e/=128;case 4:t.set(r++,e&255|ct),e>>>=7;case 3:t.set(r++,e&255|ct),e>>>=7;case 2:t.set(r++,e&255|ct),e>>>=7;case 1:{t.set(r++,e&255),e>>>=7;break}default:throw new Error("unreachable")}return t}function Bg(e,t){let r=e[t],n=0;if(n+=r&jt,r<ct||(r=e[t+1],n+=(r&jt)<<7,r<ct)||(r=e[t+2],n+=(r&jt)<<14,r<ct)||(r=e[t+3],n+=(r&jt)<<21,r<ct)||(r=e[t+4],n+=(r&jt)*pa,r<ct)||(r=e[t+5],n+=(r&jt)*ya,r<ct)||(r=e[t+6],n+=(r&jt)*ma,r<ct)||(r=e[t+7],n+=(r&jt)*ga,r<ct))return n;throw new RangeError("Could not decode varint")}function Ig(e,t){let r=e.get(t),n=0;if(n+=r&jt,r<ct||(r=e.get(t+1),n+=(r&jt)<<7,r<ct)||(r=e.get(t+2),n+=(r&jt)<<14,r<ct)||(r=e.get(t+3),n+=(r&jt)<<21,r<ct)||(r=e.get(t+4),n+=(r&jt)*pa,r<ct)||(r=e.get(t+5),n+=(r&jt)*ya,r<ct)||(r=e.get(t+6),n+=(r&jt)*ma,r<ct)||(r=e.get(t+7),n+=(r&jt)*ga,r<ct))return n;throw new RangeError("Could not decode varint")}function Ee(e,t,r=0){return t==null&&(t=$t(te(e))),t instanceof Uint8Array?Ag(e,t,r):Tg(e,t,r)}function Le(e,t=0){return e instanceof Uint8Array?Bg(e,t):Ig(e,t)}var wf=Symbol.for("@achingbrain/uint8arraylist");function Ef(e,t){if(t==null||t<0)throw new RangeError("index is out of bounds");let r=0;for(let n of e){let i=r+n.byteLength;if(t<i)return{buf:n,index:t-r};r=i}throw new RangeError("index is out of bounds")}function Xi(e){return!!e?.[wf]}var ue=class e{bufs;length;[wf]=!0;constructor(...t){this.bufs=[],this.length=0,t.length>0&&this.appendAll(t)}*[Symbol.iterator](){yield*this.bufs}get byteLength(){return this.length}append(...t){this.appendAll(t)}appendAll(t){let r=0;for(let n of t)if(n instanceof Uint8Array)r+=n.byteLength,this.bufs.push(n);else if(Xi(n))r+=n.byteLength,this.bufs.push(...n.bufs);else throw new Error("Could not append value, must be an Uint8Array or a Uint8ArrayList");this.length+=r}prepend(...t){this.prependAll(t)}prependAll(t){let r=0;for(let n of t.reverse())if(n instanceof Uint8Array)r+=n.byteLength,this.bufs.unshift(n);else if(Xi(n))r+=n.byteLength,this.bufs.unshift(...n.bufs);else throw new Error("Could not prepend value, must be an Uint8Array or a Uint8ArrayList");this.length+=r}get(t){let r=Ef(this.bufs,t);return r.buf[r.index]}set(t,r){let n=Ef(this.bufs,t);n.buf[n.index]=r}write(t,r=0){if(t instanceof Uint8Array)for(let n=0;n<t.length;n++)this.set(r+n,t[n]);else if(Xi(t))for(let n=0;n<t.length;n++)this.set(r+n,t.get(n));else throw new Error("Could not write value, must be an Uint8Array or a Uint8ArrayList")}consume(t){if(t=Math.trunc(t),!(Number.isNaN(t)||t<=0)){if(t===this.byteLength){this.bufs=[],this.length=0;return}for(;this.bufs.length>0;)if(t>=this.bufs[0].byteLength)t-=this.bufs[0].byteLength,this.length-=this.bufs[0].byteLength,this.bufs.shift();else{this.bufs[0]=this.bufs[0].subarray(t),this.length-=t;break}}}slice(t,r){let{bufs:n,length:i}=this._subList(t,r);return Ot(n,i)}subarray(t,r){let{bufs:n,length:i}=this._subList(t,r);return n.length===1?n[0]:Ot(n,i)}sublist(t,r){let{bufs:n,length:i}=this._subList(t,r),s=new e;return s.length=i,s.bufs=[...n],s}_subList(t,r){if(t=t??0,r=r??this.length,t<0&&(t=this.length+t),r<0&&(r=this.length+r),t<0||r>this.length)throw new RangeError("index is out of bounds");if(t===r)return{bufs:[],length:0};if(t===0&&r===this.length)return{bufs:this.bufs,length:this.length};let n=[],i=0;for(let s=0;s<this.bufs.length;s++){let o=this.bufs[s],a=i,c=a+o.byteLength;if(i=c,t>=c)continue;let u=t>=a&&t<c,f=r>a&&r<=c;if(u&&f){if(t===a&&r===c){n.push(o);break}let l=t-a;n.push(o.subarray(l,l+(r-t)));break}if(u){if(t===0){n.push(o);continue}n.push(o.subarray(t-a));continue}if(f){if(r===c){n.push(o);break}n.push(o.subarray(0,r-a));break}n.push(o)}return{bufs:n,length:r-t}}indexOf(t,r=0){if(!Xi(t)&&!(t instanceof Uint8Array))throw new TypeError('The "value" argument must be a Uint8ArrayList or Uint8Array');let n=t instanceof Uint8Array?t:t.subarray();if(r=Number(r??0),isNaN(r)&&(r=0),r<0&&(r=this.length+r),r<0&&(r=0),t.length===0)return r>this.length?this.length:r;let i=n.byteLength;if(i===0)throw new TypeError("search must be at least 1 byte long");let s=256,o=new Int32Array(s);for(let l=0;l<s;l++)o[l]=-1;for(let l=0;l<i;l++)o[n[l]]=l;let a=o,c=this.byteLength-n.byteLength,u=n.byteLength-1,f;for(let l=r;l<=c;l+=f){f=0;for(let h=u;h>=0;h--){let y=this.get(l+h);if(n[h]!==y){f=Math.max(1,h-a[y]);break}}if(f===0)return l}return-1}getInt8(t){let r=this.subarray(t,t+1);return new DataView(r.buffer,r.byteOffset,r.byteLength).getInt8(0)}setInt8(t,r){let n=$t(1);new DataView(n.buffer,n.byteOffset,n.byteLength).setInt8(0,r),this.write(n,t)}getInt16(t,r){let n=this.subarray(t,t+2);return new DataView(n.buffer,n.byteOffset,n.byteLength).getInt16(0,r)}setInt16(t,r,n){let i=Qe(2);new DataView(i.buffer,i.byteOffset,i.byteLength).setInt16(0,r,n),this.write(i,t)}getInt32(t,r){let n=this.subarray(t,t+4);return new DataView(n.buffer,n.byteOffset,n.byteLength).getInt32(0,r)}setInt32(t,r,n){let i=Qe(4);new DataView(i.buffer,i.byteOffset,i.byteLength).setInt32(0,r,n),this.write(i,t)}getBigInt64(t,r){let n=this.subarray(t,t+8);return new DataView(n.buffer,n.byteOffset,n.byteLength).getBigInt64(0,r)}setBigInt64(t,r,n){let i=Qe(8);new DataView(i.buffer,i.byteOffset,i.byteLength).setBigInt64(0,r,n),this.write(i,t)}getUint8(t){let r=this.subarray(t,t+1);return new DataView(r.buffer,r.byteOffset,r.byteLength).getUint8(0)}setUint8(t,r){let n=$t(1);new DataView(n.buffer,n.byteOffset,n.byteLength).setUint8(0,r),this.write(n,t)}getUint16(t,r){let n=this.subarray(t,t+2);return new DataView(n.buffer,n.byteOffset,n.byteLength).getUint16(0,r)}setUint16(t,r,n){let i=Qe(2);new DataView(i.buffer,i.byteOffset,i.byteLength).setUint16(0,r,n),this.write(i,t)}getUint32(t,r){let n=this.subarray(t,t+4);return new DataView(n.buffer,n.byteOffset,n.byteLength).getUint32(0,r)}setUint32(t,r,n){let i=Qe(4);new DataView(i.buffer,i.byteOffset,i.byteLength).setUint32(0,r,n),this.write(i,t)}getBigUint64(t,r){let n=this.subarray(t,t+8);return new DataView(n.buffer,n.byteOffset,n.byteLength).getBigUint64(0,r)}setBigUint64(t,r,n){let i=Qe(8);new DataView(i.buffer,i.byteOffset,i.byteLength).setBigUint64(0,r,n),this.write(i,t)}getFloat32(t,r){let n=this.subarray(t,t+4);return new DataView(n.buffer,n.byteOffset,n.byteLength).getFloat32(0,r)}setFloat32(t,r,n){let i=Qe(4);new DataView(i.buffer,i.byteOffset,i.byteLength).setFloat32(0,r,n),this.write(i,t)}getFloat64(t,r){let n=this.subarray(t,t+8);return new DataView(n.buffer,n.byteOffset,n.byteLength).getFloat64(0,r)}setFloat64(t,r,n){let i=Qe(8);new DataView(i.buffer,i.byteOffset,i.byteLength).setFloat64(0,r,n),this.write(i,t)}equals(t){if(t==null||!(t instanceof e)||t.bufs.length!==this.bufs.length)return!1;for(let r=0;r<this.bufs.length;r++)if(!Ct(this.bufs[r],t.bufs[r]))return!1;return!0}static fromUint8Arrays(t,r){let n=new e;return n.bufs=t,r==null&&(r=t.reduce((i,s)=>i+s.byteLength,0)),n.length=r,n}};var Sf={ERR_SIGNATURE_NOT_VALID:"ERR_SIGNATURE_NOT_VALID"};var Jn;(function(e){let t;e.codec=()=>(t==null&&(t=Jt((r,n,i={})=>{i.lengthDelimited!==!1&&n.fork(),r.publicKey!=null&&r.publicKey.byteLength>0&&(n.uint32(10),n.bytes(r.publicKey)),r.payloadType!=null&&r.payloadType.byteLength>0&&(n.uint32(18),n.bytes(r.payloadType)),r.payload!=null&&r.payload.byteLength>0&&(n.uint32(26),n.bytes(r.payload)),r.signature!=null&&r.signature.byteLength>0&&(n.uint32(42),n.bytes(r.signature)),i.lengthDelimited!==!1&&n.ldelim()},(r,n)=>{let i={publicKey:new Uint8Array(0),payloadType:new Uint8Array(0),payload:new Uint8Array(0),signature:new Uint8Array(0)},s=n==null?r.len:r.pos+n;for(;r.pos<s;){let o=r.uint32();switch(o>>>3){case 1:i.publicKey=r.bytes();break;case 2:i.payloadType=r.bytes();break;case 3:i.payload=r.bytes();break;case 5:i.signature=r.bytes();break;default:r.skipType(o&7);break}}return i})),t),e.encode=r=>Xt(r,e.codec()),e.decode=r=>Zt(r,e.codec())})(Jn||(Jn={}));var jn=class e{static createFromProtobuf=async t=>{let r=Jn.decode(t),n=await H0(r.publicKey);return new e({peerId:n,payloadType:r.payloadType,payload:r.payload,signature:r.signature})};static seal=async(t,r)=>{if(r.privateKey==null)throw new Error("Missing private key");let n=t.domain,i=t.codec,s=t.marshal(),o=Af(n,i,s),c=await(await bf(r.privateKey)).sign(o.subarray());return new e({peerId:r,payloadType:i,payload:s,signature:c})};static openAndCertify=async(t,r)=>{let n=await e.createFromProtobuf(t);if(!await n.validate(r))throw new H("envelope signature is not valid for the given domain",Sf.ERR_SIGNATURE_NOT_VALID);return n};peerId;payloadType;payload;signature;marshaled;constructor(t){let{peerId:r,payloadType:n,payload:i,signature:s}=t;this.peerId=r,this.payloadType=n,this.payload=i,this.signature=s}marshal(){if(this.peerId.publicKey==null)throw new Error("Missing public key");return this.marshaled==null&&(this.marshaled=Jn.encode({publicKey:this.peerId.publicKey,payloadType:this.payloadType,payload:this.payload.subarray(),signature:this.signature})),this.marshaled}equals(t){return Ct(this.marshal(),t.marshal())}async validate(t){let r=Af(t,this.payloadType,this.payload);if(this.peerId.publicKey==null)throw new Error("Missing public key");return vf(this.peerId.publicKey).verify(r.subarray(),this.signature)}},Af=(e,t,r)=>{let n=Nt(e),i=Ee(n.byteLength),s=Ee(t.length),o=Ee(r.length);return new ue(i,n,s,t,o,r)};var Ji=class{index=0;input="";new(t){return this.index=0,this.input=t,this}readAtomically(t){let r=this.index,n=t();return n===void 0&&(this.index=r),n}parseWith(t){let r=t();if(this.index===this.input.length)return r}peekChar(){if(!(this.index>=this.input.length))return this.input[this.index]}readChar(){if(!(this.index>=this.input.length))return this.input[this.index++]}readGivenChar(t){return this.readAtomically(()=>{let r=this.readChar();if(r===t)return r})}readSeparator(t,r,n){return this.readAtomically(()=>{if(!(r>0&&this.readGivenChar(t)===void 0))return n()})}readNumber(t,r,n,i){return this.readAtomically(()=>{let s=0,o=0,a=this.peekChar();if(a===void 0)return;let c=a==="0",u=2**(8*i)-1;for(;;){let f=this.readAtomically(()=>{let l=this.readChar();if(l===void 0)return;let h=Number.parseInt(l,t);if(!Number.isNaN(h))return h});if(f===void 0)break;if(s*=t,s+=f,s>u||(o+=1,r!==void 0&&o>r))return}if(o!==0)return!n&&c&&o>1?void 0:s})}readIPv4Addr(){return this.readAtomically(()=>{let t=new Uint8Array(4);for(let r=0;r<t.length;r++){let n=this.readSeparator(".",r,()=>this.readNumber(10,3,!1,1));if(n===void 0)return;t[r]=n}return t})}readIPv6Addr(){let t=r=>{for(let n=0;n<r.length/2;n++){let i=n*2;if(n<r.length-3){let o=this.readSeparator(":",n,()=>this.readIPv4Addr());if(o!==void 0)return r[i]=o[0],r[i+1]=o[1],r[i+2]=o[2],r[i+3]=o[3],[i+4,!0]}let s=this.readSeparator(":",n,()=>this.readNumber(16,4,!0,2));if(s===void 0)return[i,!1];r[i]=s>>8,r[i+1]=s&255}return[r.length,!1]};return this.readAtomically(()=>{let r=new Uint8Array(16),[n,i]=t(r);if(n===16)return r;if(i||this.readGivenChar(":")===void 0||this.readGivenChar(":")===void 0)return;let s=new Uint8Array(14),o=16-(n+2),[a]=t(s.subarray(0,o));return r.set(s.subarray(0,a),16-a),r})}readIPAddr(){return this.readIPv4Addr()??this.readIPv6Addr()}};var Tf=45,Cg=15,wn=new Ji;function xa(e){if(!(e.length>Cg))return wn.new(e).parseWith(()=>wn.readIPv4Addr())}function va(e){if(e.includes("%")&&(e=e.split("%")[0]),!(e.length>Tf))return wn.new(e).parseWith(()=>wn.readIPv6Addr())}function ji(e){if(e.includes("%")&&(e=e.split("%")[0]),!(e.length>Tf))return wn.new(e).parseWith(()=>wn.readIPAddr())}var Nw=parseInt("0xFFFF",16),Pw=new Uint8Array([0,0,0,0,0,0,0,0,0,0,255,255]);function Cf(e){return!!xa(e)}function _f(e){return!!va(e)}function ts(e){return!!ji(e)}var Rf=Cf,Ng=_f,ba=function(e){let t=0;if(e=e.toString().trim(),Rf(e)){let r=new Uint8Array(t+4);return e.split(/\./g).forEach(n=>{r[t++]=parseInt(n,10)&255}),r}if(Ng(e)){let r=e.split(":",8),n;for(n=0;n<r.length;n++){let s=Rf(r[n]),o;s&&(o=ba(r[n]),r[n]=pt(o.slice(0,2),"base16")),o!=null&&++n<8&&r.splice(n,0,pt(o.slice(2,4),"base16"))}if(r[0]==="")for(;r.length<8;)r.unshift("0");else if(r[r.length-1]==="")for(;r.length<8;)r.push("0");else if(r.length<8){for(n=0;n<r.length&&r[n]!=="";n++);let s=[n,1];for(n=9-r.length;n>0;n--)s.push("0");r.splice.apply(r,s)}let i=new Uint8Array(t+16);for(n=0;n<r.length;n++){let s=parseInt(r[n],16);i[t++]=s>>8&255,i[t++]=s&255}return i}throw new Error("invalid ip address")},Lf=function(e,t=0,r){t=~~t,r=r??e.length-t;let n=new DataView(e.buffer);if(r===4){let i=[];for(let s=0;s<r;s++)i.push(e[t+s]);return i.join(".")}if(r===16){let i=[];for(let s=0;s<r;s+=2)i.push(n.getUint16(t+s).toString(16));return i.join(":").replace(/(^|:)0(:0)*:0(:|$)/,"$1::$3").replace(/:{3,4}/,"::")}return""};var Sn={},Ea={},kg=[[4,32,"ip4"],[6,16,"tcp"],[33,16,"dccp"],[41,128,"ip6"],[42,-1,"ip6zone"],[43,8,"ipcidr"],[53,-1,"dns",!0],[54,-1,"dns4",!0],[55,-1,"dns6",!0],[56,-1,"dnsaddr",!0],[132,16,"sctp"],[273,16,"udp"],[275,0,"p2p-webrtc-star"],[276,0,"p2p-webrtc-direct"],[277,0,"p2p-stardust"],[280,0,"webrtc-direct"],[281,0,"webrtc"],[290,0,"p2p-circuit"],[301,0,"udt"],[302,0,"utp"],[400,-1,"unix",!1,!0],[421,-1,"ipfs"],[421,-1,"p2p"],[443,0,"https"],[444,96,"onion"],[445,296,"onion3"],[446,-1,"garlic64"],[448,0,"tls"],[449,-1,"sni"],[460,0,"quic"],[461,0,"quic-v1"],[465,0,"webtransport"],[466,-1,"certhash"],[477,0,"ws"],[478,0,"wss"],[479,0,"p2p-websocket-star"],[480,0,"http"],[777,-1,"memory"]];kg.forEach(e=>{let t=Ug(...e);Ea[t.code]=t,Sn[t.name]=t});function Ug(e,t,r,n,i){return{code:e,size:t,name:r,resolvable:!!n,path:!!i}}function yt(e){if(typeof e=="number"){if(Ea[e]!=null)return Ea[e];throw new Error(`no protocol with code: ${e}`)}else if(typeof e=="string"){if(Sn[e]!=null)return Sn[e];throw new Error(`no protocol with name: ${e}`)}throw new Error(`invalid protocol id type: ${typeof e}`)}var gS=yt("ip4"),xS=yt("ip6"),vS=yt("ipcidr");function Sa(e,t){switch(yt(e).code){case 4:case 41:return Mg(t);case 42:return Pf(t);case 6:case 273:case 33:case 132:return Uf(t).toString();case 53:case 54:case 55:case 56:case 400:case 449:case 777:return Pf(t);case 421:return qg(t);case 444:return kf(t);case 445:return kf(t);case 466:return Vg(t);default:return pt(t,"base16")}}function Aa(e,t){switch(yt(e).code){case 4:return Df(t);case 41:return Df(t);case 42:return Nf(t);case 6:case 273:case 33:case 132:return Ta(parseInt(t,10));case 53:case 54:case 55:case 56:case 400:case 449:case 777:return Nf(t);case 421:return Kg(t);case 444:return Hg(t);case 445:return zg(t);case 466:return Fg(t);default:return Nt(t,"base16")}}var wa=Object.values(ur).map(e=>e.decoder),Og=function(){let e=wa[0].or(wa[1]);return wa.slice(2).forEach(t=>e=e.or(t)),e}();function Df(e){if(!ts(e))throw new Error("invalid ip address");return ba(e)}function Mg(e){let t=Lf(e,0,e.length);if(t==null)throw new Error("ipBuff is required");if(!ts(t))throw new Error("invalid ip address");return t}function Ta(e){let t=new ArrayBuffer(2);return new DataView(t).setUint16(0,e),new Uint8Array(t)}function Uf(e){return new DataView(e.buffer).getUint16(e.byteOffset)}function Nf(e){let t=Nt(e),r=Uint8Array.from(Ee(t.length));return Ot([r,t],r.length+t.length)}function Pf(e){let t=Le(e);if(e=e.slice(te(t)),e.length!==t)throw new Error("inconsistent lengths");return pt(e)}function Kg(e){let t;e[0]==="Q"||e[0]==="1"?t=Cr(kt.decode(`z${e}`)).bytes:t=fe.parse(e).multihash.bytes;let r=Uint8Array.from(Ee(t.length));return Ot([r,t],r.length+t.length)}function Fg(e){let t=Og.decode(e),r=Uint8Array.from(Ee(t.length));return Ot([r,t],r.length+t.length)}function Vg(e){let t=Le(e),r=e.slice(te(t));if(r.length!==t)throw new Error("inconsistent lengths");return"u"+pt(r,"base64url")}function qg(e){let t=Le(e),r=e.slice(te(t));if(r.length!==t)throw new Error("inconsistent lengths");return pt(r,"base58btc")}function Hg(e){let t=e.split(":");if(t.length!==2)throw new Error(`failed to parse onion addr: ["'${t.join('", "')}'"]' does not contain a port number`);if(t[0].length!==16)throw new Error(`failed to parse onion addr: ${t[0]} not a Tor onion address.`);let r=Ge.decode("b"+t[0]),n=parseInt(t[1],10);if(n<1||n>65536)throw new Error("Port number is not in range(1, 65536)");let i=Ta(n);return Ot([r,i],r.length+i.length)}function zg(e){let t=e.split(":");if(t.length!==2)throw new Error(`failed to parse onion addr: ["'${t.join('", "')}'"]' does not contain a port number`);if(t[0].length!==56)throw new Error(`failed to parse onion addr: ${t[0]} not a Tor onion3 address.`);let r=Ge.decode(`b${t[0]}`),n=parseInt(t[1],10);if(n<1||n>65536)throw new Error("Port number is not in range(1, 65536)");let i=Ta(n);return Ot([r,i],r.length+i.length)}function kf(e){let t=e.slice(0,e.length-2),r=e.slice(e.length-2),n=pt(t,"base32"),i=Uf(r);return`${n}:${i}`}function Of(e){e=Ba(e);let t=[],r=[],n=null,i=e.split("/").slice(1);if(i.length===1&&i[0]==="")return{bytes:new Uint8Array,string:"/",tuples:[],stringTuples:[],path:null};for(let s=0;s<i.length;s++){let o=i[s],a=yt(o);if(a.size===0){t.push([a.code]),r.push([a.code]);continue}if(s++,s>=i.length)throw Kf("invalid address: "+e);if(a.path===!0){n=Ba(i.slice(s).join("/")),t.push([a.code,Aa(a.code,n)]),r.push([a.code,n]);break}let c=Aa(a.code,i[s]);t.push([a.code,c]),r.push([a.code,Sa(a.code,c)])}return{string:Mf(r),bytes:Ca(t),tuples:t,stringTuples:r,path:n}}function Ia(e){let t=[],r=[],n=null,i=0;for(;i<e.length;){let s=Le(e,i),o=te(s),a=yt(s),c=Gg(a,e.slice(i+o));if(c===0){t.push([s]),r.push([s]),i+=o;continue}let u=e.slice(i+o,i+o+c);if(i+=c+o,i>e.length)throw Kf("Invalid address Uint8Array: "+pt(e,"base16"));t.push([s,u]);let f=Sa(s,u);if(r.push([s,f]),a.path===!0){n=f;break}}return{bytes:Uint8Array.from(e),string:Mf(r),tuples:t,stringTuples:r,path:n}}function Mf(e){let t=[];return e.map(r=>{let n=yt(r[0]);return t.push(n.name),r.length>1&&r[1]!=null&&t.push(r[1]),null}),Ba(t.join("/"))}function Ca(e){return Ot(e.map(t=>{let r=yt(t[0]),n=Uint8Array.from(Ee(r.code));return t.length>1&&t[1]!=null&&(n=Ot([n,t[1]])),n}))}function Gg(e,t){if(e.size>0)return e.size/8;if(e.size===0)return 0;{let r=Le(t instanceof Uint8Array?t:Uint8Array.from(t));return r+te(r)}}function Ba(e){return"/"+e.trim().split("/").filter(t=>t).join("/")}function Kf(e){return new Error("Error parsing address: "+e)}var Wg=Symbol.for("nodejs.util.inspect.custom"),_a=Symbol.for("@multiformats/js-multiaddr/multiaddr"),Yg=[yt("dns").code,yt("dns4").code,yt("dns6").code,yt("dnsaddr").code],es=class e{bytes;#t;#e;#r;#n;[_a]=!0;constructor(t){t==null&&(t="");let r;if(t instanceof Uint8Array)r=Ia(t);else if(typeof t=="string"){if(t.length>0&&t.charAt(0)!=="/")throw new Error(`multiaddr "${t}" must start with a "/"`);r=Of(t)}else if(Vf(t))r=Ia(t.bytes);else throw new Error("addr must be a string, Buffer, or another Multiaddr");this.bytes=r.bytes,this.#t=r.string,this.#e=r.tuples,this.#r=r.stringTuples,this.#n=r.path}toString(){return this.#t}toJSON(){return this.toString()}toOptions(){let t,r,n,i,s="",o=yt("tcp"),a=yt("udp"),c=yt("ip4"),u=yt("ip6"),f=yt("dns6"),l=yt("ip6zone");for(let[y,d]of this.stringTuples())y===l.code&&(s=`%${d??""}`),Yg.includes(y)&&(r=o.name,i=443,n=`${d??""}${s}`,t=y===f.code?6:4),(y===o.code||y===a.code)&&(r=yt(y).name,i=parseInt(d??"")),(y===c.code||y===u.code)&&(r=yt(y).name,n=`${d??""}${s}`,t=y===u.code?6:4);if(t==null||r==null||n==null||i==null)throw new Error('multiaddr must have a valid format: "/{ip4, ip6, dns4, dns6, dnsaddr}/{address}/{tcp, udp}/{port}".');return{family:t,host:n,transport:r,port:i}}protos(){return this.#e.map(([t])=>Object.assign({},yt(t)))}protoCodes(){return this.#e.map(([t])=>t)}protoNames(){return this.#e.map(([t])=>yt(t).name)}tuples(){return this.#e}stringTuples(){return this.#r}encapsulate(t){return t=new e(t),new e(this.toString()+t.toString())}decapsulate(t){let r=t.toString(),n=this.toString(),i=n.lastIndexOf(r);if(i<0)throw new Error(`Address ${this.toString()} does not contain subaddress: ${t.toString()}`);return new e(n.slice(0,i))}decapsulateCode(t){let r=this.tuples();for(let n=r.length-1;n>=0;n--)if(r[n][0]===t)return new e(Ca(r.slice(0,n)));return this}getPeerId(){try{let t=[];this.stringTuples().forEach(([n,i])=>{n===Sn.p2p.code&&t.push([n,i]),n===Sn["p2p-circuit"].code&&(t=[])});let r=t.pop();if(r?.[1]!=null){let n=r[1];return n[0]==="Q"||n[0]==="1"?pt(kt.decode(`z${n}`),"base58btc"):pt(fe.parse(n).multihash.bytes,"base58btc")}return null}catch{return null}}getPath(){return this.#n}equals(t){return Ct(this.bytes,t.bytes)}async resolve(t){let r=this.protos().find(s=>s.resolvable);if(r==null)return[this];let n=Ff.get(r.name);if(n==null)throw new H(`no available resolver for ${r.name}`,"ERR_NO_AVAILABLE_RESOLVER");return(await n(this,t)).map(s=>new e(s))}nodeAddress(){let t=this.toOptions();if(t.transport!=="tcp"&&t.transport!=="udp")throw new Error(`multiaddr must have a valid format - no protocol with name: "${t.transport}". Must have a valid transport protocol: "{tcp, udp}"`);return{family:t.family,address:t.host,port:t.port}}isThinWaistAddress(t){let r=(t??this).protos();return!(r.length!==2||r[0].code!==4&&r[0].code!==41||r[1].code!==6&&r[1].code!==273)}[Wg](){return`Multiaddr(${this.#t})`}};var Ff=new Map;function Vf(e){return!!e?.[_a]}function ee(e){return new es(e)}var $g=Uint8Array.from([3,1]);var Ra;(function(e){let t;(function(n){let i;n.codec=()=>(i==null&&(i=Jt((s,o,a={})=>{a.lengthDelimited!==!1&&o.fork(),s.multiaddr!=null&&s.multiaddr.byteLength>0&&(o.uint32(10),o.bytes(s.multiaddr)),a.lengthDelimited!==!1&&o.ldelim()},(s,o)=>{let a={multiaddr:new Uint8Array(0)},c=o==null?s.len:s.pos+o;for(;s.pos<c;){let u=s.uint32();switch(u>>>3){case 1:a.multiaddr=s.bytes();break;default:s.skipType(u&7);break}}return a})),i),n.encode=s=>Xt(s,n.codec()),n.decode=s=>Zt(s,n.codec())})(t=e.AddressInfo||(e.AddressInfo={}));let r;e.codec=()=>(r==null&&(r=Jt((n,i,s={})=>{if(s.lengthDelimited!==!1&&i.fork(),n.peerId!=null&&n.peerId.byteLength>0&&(i.uint32(10),i.bytes(n.peerId)),n.seq!=null&&n.seq!==0n&&(i.uint32(16),i.uint64(n.seq)),n.addresses!=null)for(let o of n.addresses)i.uint32(26),e.AddressInfo.codec().encode(o,i);s.lengthDelimited!==!1&&i.ldelim()},(n,i)=>{let s={peerId:new Uint8Array(0),seq:0n,addresses:[]},o=i==null?n.len:n.pos+i;for(;n.pos<o;){let a=n.uint32();switch(a>>>3){case 1:s.peerId=n.bytes();break;case 2:s.seq=n.uint64();break;case 3:s.addresses.push(e.AddressInfo.codec().decode(n,n.uint32()));break;default:n.skipType(a&7);break}}return s})),r),e.encode=n=>Xt(n,e.codec()),e.decode=n=>Zt(n,e.codec())})(Ra||(Ra={}));function wr(){let e={};return e.promise=new Promise((t,r)=>{e.resolve=t,e.reject=r}),e}var rs=class extends Error{type;code;constructor(t,r){super(t??"The operation was aborted"),this.type="aborted",this.name="AbortError",this.code=r??"ABORT_ERR"}};async function qf(e,t,r){if(t==null)return e;if(t.aborted)return Promise.reject(new rs(r?.errorMessage,r?.errorCode));let n,i=new rs(r?.errorMessage,r?.errorCode);try{return await Promise.race([e,new Promise((s,o)=>{n=()=>{o(i)},t.addEventListener("abort",n)})])}finally{n!=null&&t.removeEventListener("abort",n)}}var La=class{needNext;haveNext;ended;nextResult;constructor(){this.ended=!1,this.needNext=wr(),this.needNext.resolve(),this.haveNext=wr()}[Symbol.asyncIterator](){return this}async next(){if(this.nextResult==null&&await this.haveNext.promise,this.nextResult==null)throw new Error("Have next but next was undefined");let t=this.nextResult;return this.nextResult=void 0,this.needNext.resolve(),this.needNext=wr(),t}async throw(t){return this.ended=!0,t!=null&&this.haveNext.reject(t),{done:!0,value:void 0}}async return(){let t={done:!0,value:void 0};return await this._push(void 0),t}async push(t,r){await this._push(t,r)}async end(t,r){t!=null?await this.throw(t):await this._push(void 0,r)}async _push(t,r){if(t!=null&&this.ended)throw new Error("Cannot push value onto an ended pushable");this.nextResult!=null&&await this.needNext.promise,t!=null?this.nextResult={done:!1,value:t}:(this.ended=!0,this.nextResult={done:!0,value:void 0}),this.haveNext.resolve(),this.haveNext=wr(),await qf(this.needNext.promise,r?.signal,r)}};function Hf(){return new La}var ns=class extends Error{code;constructor(t,r){super(t),this.code=r}},Da=class extends ns{type;constructor(t){super(t,"ABORT_ERR"),this.type="aborted"}};function zf(e,t){let r=Hf();e.sink(r).catch(async o=>{await r.end(o)}),e.sink=async o=>{for await(let a of o)await r.push(a);await r.end()};let n=e.source;e.source[Symbol.iterator]!=null?n=e.source[Symbol.iterator]():e.source[Symbol.asyncIterator]!=null&&(n=e.source[Symbol.asyncIterator]());let i=new ue;return{read:async(o,a)=>{a?.signal?.throwIfAborted();let c,u=new Promise((f,l)=>{c=()=>{l(new Da("Read aborted"))},a?.signal?.addEventListener("abort",c)});try{if(o==null){let{done:l,value:h}=await Promise.race([n.next(),u]);return l===!0?new ue:h}for(;i.byteLength<o;){let{value:l,done:h}=await Promise.race([n.next(),u]);if(h===!0)throw new ns("unexpected end of input","ERR_UNEXPECTED_EOF");i.append(l)}let f=i.sublist(0,o);return i.consume(o),f}finally{c!=null&&a?.signal?.removeEventListener("abort",c)}},write:async(o,a)=>{a?.signal?.throwIfAborted(),o instanceof Uint8Array?await r.push(o,a):await r.push(o.subarray(),a)},unwrap:()=>{if(i.byteLength>0){let o=e.source;e.source=async function*(){t?.yieldBytes===!1?yield i:yield*i,yield*o}()}return e}}}function is(e){return e[Symbol.asyncIterator]!=null}var ss=e=>{let t=te(e),r=$t(t);return Ee(e,r),ss.bytes=t,r};ss.bytes=0;function ti(e,t){t=t??{};let r=t.lengthEncoder??ss;function*n(i){let s=r(i.byteLength);s instanceof Uint8Array?yield s:yield*s,i instanceof Uint8Array?yield i:yield*i}return is(e)?async function*(){for await(let i of e)yield*n(i)}():function*(){for(let i of e)yield*n(i)}()}ti.single=(e,t)=>{t=t??{};let r=t.lengthEncoder??ss;return new ue(r(e.byteLength),e)};var An=Yt(Yf(),1);var Zg=8,Xg=1024*1024*4,Wr;(function(e){e[e.LENGTH=0]="LENGTH",e[e.DATA=1]="DATA"})(Wr||(Wr={}));var Pa=e=>{let t=Le(e);return Pa.bytes=te(t),t};Pa.bytes=0;function Na(e,t){let r=new ue,n=Wr.LENGTH,i=-1,s=t?.lengthDecoder??Pa,o=t?.maxLengthLength??Zg,a=t?.maxDataLength??Xg;function*c(){for(;r.byteLength>0;){if(n===Wr.LENGTH)try{if(i=s(r),i<0)throw(0,An.default)(new Error("invalid message length"),"ERR_INVALID_MSG_LENGTH");if(i>a)throw(0,An.default)(new Error("message length too long"),"ERR_MSG_DATA_TOO_LONG");let u=s.bytes;r.consume(u),t?.onLength!=null&&t.onLength(i),n=Wr.DATA}catch(u){if(u instanceof RangeError){if(r.byteLength>o)throw(0,An.default)(new Error("message length length too long"),"ERR_MSG_LENGTH_TOO_LONG");break}throw u}if(n===Wr.DATA){if(r.byteLength<i)break;let u=r.sublist(0,i);r.consume(i),t?.onData!=null&&t.onData(u),yield u,n=Wr.LENGTH}}}return is(e)?async function*(){for await(let u of e)r.append(u),yield*c();if(r.byteLength>0)throw(0,An.default)(new Error("unexpected end of input"),"ERR_UNEXPECTED_EOF")}():function*(){for(let u of e)r.append(u),yield*c();if(r.byteLength>0)throw(0,An.default)(new Error("unexpected end of input"),"ERR_UNEXPECTED_EOF")}()}Na.fromReader=(e,t)=>{let r=1,n=async function*(){for(;;)try{let{done:s,value:o}=await e.next(r);if(s===!0)return;o!=null&&(yield o)}catch(s){if(s.code==="ERR_UNDER_READ")return{done:!0,value:null};throw s}finally{r=1}}();return Na(n,{...t??{},onLength:s=>{r=s}})};var os=class extends Error{code;constructor(t,r){super(t),this.code=r}},$f=e=>Le(e);$f.bytes=0;function Qf(e,t={}){let r=zf(e,t);return t.maxDataLength!=null&&t.maxLengthLength==null&&(t.maxLengthLength=te(t.maxDataLength)),{read:async i=>{let s=-1,o=new ue,a=t?.lengthDecoder??$f;for(;;){o.append(await r.read(1,i));try{s=a(o)}catch(c){if(c instanceof RangeError)continue;throw c}if(t?.maxLengthLength!=null&&o.byteLength>t.maxLengthLength)throw new os("message length length too long","ERR_MSG_LENGTH_TOO_LONG");if(s>-1)break}if(t?.maxDataLength!=null&&s>t.maxDataLength)throw new os("message length too long","ERR_MSG_DATA_TOO_LONG");return r.read(s,i)},write:async(i,s)=>{await r.write(ti.single(i,t),s)},writeV:async(i,s)=>{let o=new ue(...i.map(a=>ti.single(a,t)));await r.write(o,s)},unwrap:()=>r.unwrap()}}function Sr(e,t){let r=Qf(e,t),n={read:async(i,s)=>{let o=await r.read(s);return i.decode(o)},write:async(i,s,o)=>{await r.write(s.encode(i),o)},writeV:async(i,s,o)=>{await r.writeV(i.map(a=>s.encode(a)),o)},pb:i=>({read:async s=>n.read(i,s),write:async(s,o)=>n.write(s,i,o),writeV:async(s,o)=>n.writeV(s,i,o),unwrap:()=>n}),unwrap:()=>r.unwrap()};return n}var as="/libp2p/relay";var Zf="circuit-relay-source",Xf="circuit-relay-relay";var Jf=BigInt(131072),we="/libp2p/circuit/relay/0.2.0/hop",Yr="/libp2p/circuit/relay/0.2.0/stop",jf=30*1e3,tl=30*1e3,ei=300,el="ERR_NO_ROUTERS_AVAILABLE",ka="ERR_RELAYED_DIAL",rl="ERR_HOP_REQUEST_FAILED",cs="ERR_TRANSFER_LIMIT_EXCEEDED";var ft;(function(e){let t;(function(i){i.RESERVE="RESERVE",i.CONNECT="CONNECT",i.STATUS="STATUS"})(t=e.Type||(e.Type={}));let r;(function(i){i[i.RESERVE=0]="RESERVE",i[i.CONNECT=1]="CONNECT",i[i.STATUS=2]="STATUS"})(r||(r={})),function(i){i.codec=()=>Fr(r)}(t=e.Type||(e.Type={}));let n;e.codec=()=>(n==null&&(n=Jt((i,s,o={})=>{o.lengthDelimited!==!1&&s.fork(),i.type!=null&&(s.uint32(8),e.Type.codec().encode(i.type,s)),i.peer!=null&&(s.uint32(18),Tn.codec().encode(i.peer,s)),i.reservation!=null&&(s.uint32(26),us.codec().encode(i.reservation,s)),i.limit!=null&&(s.uint32(34),Bn.codec().encode(i.limit,s)),i.status!=null&&(s.uint32(40),tt.codec().encode(i.status,s)),o.lengthDelimited!==!1&&s.ldelim()},(i,s)=>{let o={},a=s==null?i.len:i.pos+s;for(;i.pos<a;){let c=i.uint32();switch(c>>>3){case 1:o.type=e.Type.codec().decode(i);break;case 2:o.peer=Tn.codec().decode(i,i.uint32());break;case 3:o.reservation=us.codec().decode(i,i.uint32());break;case 4:o.limit=Bn.codec().decode(i,i.uint32());break;case 5:o.status=tt.codec().decode(i);break;default:i.skipType(c&7);break}}return o})),n),e.encode=i=>Xt(i,e.codec()),e.decode=i=>Zt(i,e.codec())})(ft||(ft={}));var de;(function(e){let t;(function(i){i.CONNECT="CONNECT",i.STATUS="STATUS"})(t=e.Type||(e.Type={}));let r;(function(i){i[i.CONNECT=0]="CONNECT",i[i.STATUS=1]="STATUS"})(r||(r={})),function(i){i.codec=()=>Fr(r)}(t=e.Type||(e.Type={}));let n;e.codec=()=>(n==null&&(n=Jt((i,s,o={})=>{o.lengthDelimited!==!1&&s.fork(),i.type!=null&&(s.uint32(8),e.Type.codec().encode(i.type,s)),i.peer!=null&&(s.uint32(18),Tn.codec().encode(i.peer,s)),i.limit!=null&&(s.uint32(26),Bn.codec().encode(i.limit,s)),i.status!=null&&(s.uint32(32),tt.codec().encode(i.status,s)),o.lengthDelimited!==!1&&s.ldelim()},(i,s)=>{let o={},a=s==null?i.len:i.pos+s;for(;i.pos<a;){let c=i.uint32();switch(c>>>3){case 1:o.type=e.Type.codec().decode(i);break;case 2:o.peer=Tn.codec().decode(i,i.uint32());break;case 3:o.limit=Bn.codec().decode(i,i.uint32());break;case 4:o.status=tt.codec().decode(i);break;default:i.skipType(c&7);break}}return o})),n),e.encode=i=>Xt(i,e.codec()),e.decode=i=>Zt(i,e.codec())})(de||(de={}));var Tn;(function(e){let t;e.codec=()=>(t==null&&(t=Jt((r,n,i={})=>{if(i.lengthDelimited!==!1&&n.fork(),r.id!=null&&r.id.byteLength>0&&(n.uint32(10),n.bytes(r.id)),r.addrs!=null)for(let s of r.addrs)n.uint32(18),n.bytes(s);i.lengthDelimited!==!1&&n.ldelim()},(r,n)=>{let i={id:new Uint8Array(0),addrs:[]},s=n==null?r.len:r.pos+n;for(;r.pos<s;){let o=r.uint32();switch(o>>>3){case 1:i.id=r.bytes();break;case 2:i.addrs.push(r.bytes());break;default:r.skipType(o&7);break}}return i})),t),e.encode=r=>Xt(r,e.codec()),e.decode=r=>Zt(r,e.codec())})(Tn||(Tn={}));var us;(function(e){let t;e.codec=()=>(t==null&&(t=Jt((r,n,i={})=>{if(i.lengthDelimited!==!1&&n.fork(),r.expire!=null&&r.expire!==0n&&(n.uint32(8),n.uint64(r.expire)),r.addrs!=null)for(let s of r.addrs)n.uint32(18),n.bytes(s);r.voucher!=null&&(n.uint32(26),n.bytes(r.voucher)),i.lengthDelimited!==!1&&n.ldelim()},(r,n)=>{let i={expire:0n,addrs:[]},s=n==null?r.len:r.pos+n;for(;r.pos<s;){let o=r.uint32();switch(o>>>3){case 1:i.expire=r.uint64();break;case 2:i.addrs.push(r.bytes());break;case 3:i.voucher=r.bytes();break;default:r.skipType(o&7);break}}return i})),t),e.encode=r=>Xt(r,e.codec()),e.decode=r=>Zt(r,e.codec())})(us||(us={}));var Bn;(function(e){let t;e.codec=()=>(t==null&&(t=Jt((r,n,i={})=>{i.lengthDelimited!==!1&&n.fork(),r.duration!=null&&(n.uint32(8),n.uint32(r.duration)),r.data!=null&&(n.uint32(16),n.uint64(r.data)),i.lengthDelimited!==!1&&n.ldelim()},(r,n)=>{let i={},s=n==null?r.len:r.pos+n;for(;r.pos<s;){let o=r.uint32();switch(o>>>3){case 1:i.duration=r.uint32();break;case 2:i.data=r.uint64();break;default:r.skipType(o&7);break}}return i})),t),e.encode=r=>Xt(r,e.codec()),e.decode=r=>Zt(r,e.codec())})(Bn||(Bn={}));var tt;(function(e){e.UNUSED="UNUSED",e.OK="OK",e.RESERVATION_REFUSED="RESERVATION_REFUSED",e.RESOURCE_LIMIT_EXCEEDED="RESOURCE_LIMIT_EXCEEDED",e.PERMISSION_DENIED="PERMISSION_DENIED",e.CONNECTION_FAILED="CONNECTION_FAILED",e.NO_RESERVATION="NO_RESERVATION",e.MALFORMED_MESSAGE="MALFORMED_MESSAGE",e.UNEXPECTED_MESSAGE="UNEXPECTED_MESSAGE"})(tt||(tt={}));var Ua;(function(e){e[e.UNUSED=0]="UNUSED",e[e.OK=100]="OK",e[e.RESERVATION_REFUSED=200]="RESERVATION_REFUSED",e[e.RESOURCE_LIMIT_EXCEEDED=201]="RESOURCE_LIMIT_EXCEEDED",e[e.PERMISSION_DENIED=202]="PERMISSION_DENIED",e[e.CONNECTION_FAILED=203]="CONNECTION_FAILED",e[e.NO_RESERVATION=204]="NO_RESERVATION",e[e.MALFORMED_MESSAGE=400]="MALFORMED_MESSAGE",e[e.UNEXPECTED_MESSAGE=401]="UNEXPECTED_MESSAGE"})(Ua||(Ua={}));(function(e){e.codec=()=>Fr(Ua)})(tt||(tt={}));var fs;(function(e){let t;e.codec=()=>(t==null&&(t=Jt((r,n,i={})=>{i.lengthDelimited!==!1&&n.fork(),r.relay!=null&&r.relay.byteLength>0&&(n.uint32(10),n.bytes(r.relay)),r.peer!=null&&r.peer.byteLength>0&&(n.uint32(18),n.bytes(r.peer)),r.expiration!=null&&r.expiration!==0n&&(n.uint32(24),n.uint64(r.expiration)),i.lengthDelimited!==!1&&n.ldelim()},(r,n)=>{let i={relay:new Uint8Array(0),peer:new Uint8Array(0),expiration:0n},s=n==null?r.len:r.pos+n;for(;r.pos<s;){let o=r.uint32();switch(o>>>3){case 1:i.relay=r.bytes();break;case 2:i.peer=r.bytes();break;case 3:i.expiration=r.uint64();break;default:r.skipType(o&7);break}}return i})),t),e.encode=r=>Xt(r,e.codec()),e.decode=r=>Zt(r,e.codec())})(fs||(fs={}));function nl(e){let t=new globalThis.AbortController;function r(){t.abort();for(let s of e)s?.removeEventListener!=null&&s.removeEventListener("abort",r)}for(let s of e){if(s?.aborted===!0){r();break}s?.addEventListener!=null&&s.addEventListener("abort",r)}function n(){for(let s of e)s?.removeEventListener!=null&&s.removeEventListener("abort",r)}let i=t.signal;return i.clear=n,i}async function*il(e,t,r){let n=t.remaining;for await(let i of e){let s=BigInt(i.byteLength);if(t.remaining-s<0){let o=Number(t.remaining);t.remaining=0n;try{o!==0&&(yield i.subarray(0,o))}catch(a){r.log.error(a)}throw new H(`data limit of ${n} bytes exceeded`,cs)}t.remaining-=s,yield i}}function sl(e,t,r,n,i){function s(l){e.abort(l),t.abort(l)}let o=[r];n?.duration!=null&&o.push(AbortSignal.timeout(n.duration));let a=nl(o),c=!1,u=!1,f;n?.data!=null&&(f={remaining:n.data}),queueMicrotask(()=>{let l=()=>{t.abort(new H(`duration limit of ${n?.duration} ms exceeded`,cs))};a.addEventListener("abort",l,{once:!0}),t.sink(f==null?e.source:il(e.source,f,i)).catch(h=>{i.log.error("error while relaying streams src -> dst",h),s(h)}).finally(()=>{c=!0,u&&(a.removeEventListener("abort",l),a.clear())})}),queueMicrotask(()=>{let l=()=>{e.abort(new H(`duration limit of ${n?.duration} ms exceeded`,cs))};a.addEventListener("abort",l,{once:!0}),e.sink(f==null?t.source:il(t.source,f,i)).catch(h=>{i.log.error("error while relaying streams dst -> src",h),s(h)}).finally(()=>{u=!0,c&&(a.removeEventListener("abort",l),a.clear())})})}async function ls(e){let t=new TextEncoder().encode(e),r=await Ut.digest(t);return fe.createV0(r)}function Oa(e){let t=e*BigInt(1e3),r=new Date().getTime();return Number(t-BigInt(r))}var hl=Yt(fl(),1);var t1=Object.prototype.toString,e1=e=>t1.call(e)==="[object Error]",r1=new Set(["Failed to fetch","NetworkError when attempting to fetch resource.","The Internet connection appears to be offline.","Load failed","Network request failed","fetch failed"]);function Ma(e){return e&&e1(e)&&e.name==="TypeError"&&typeof e.message=="string"?e.message==="Load failed"?e.stack===void 0:r1.has(e.message):!1}var Ka=class extends Error{constructor(t){super(),t instanceof Error?(this.originalError=t,{message:t}=t):(this.originalError=new Error(t),this.originalError.stack=this.stack),this.name="AbortError",this.message=t}},ll=(e,t,r)=>{let n=r.retries-(t-1);return e.attemptNumber=t,e.retriesLeft=n,e};async function Fa(e,t){return new Promise((r,n)=>{t={onFailedAttempt(){},retries:10,...t};let i=hl.default.operation(t),s=()=>{i.stop(),n(t.signal?.reason)};t.signal&&!t.signal.aborted&&t.signal.addEventListener("abort",s,{once:!0});let o=()=>{t.signal?.removeEventListener("abort",s),i.stop()};i.attempt(async a=>{try{let c=await e(a);o(),r(c)}catch(c){try{if(!(c instanceof Error))throw new TypeError(`Non-error was thrown: "${c}". You should only throw errors.`);if(c instanceof Ka)throw c.originalError;if(c instanceof TypeError&&!Ma(c))throw c;if(await t.onFailedAttempt(ll(c,a,t)),!i.retry(c))throw i.mainError()}catch(u){ll(u,a,t),o(),n(u)}}})})}var hs=class extends me{contentRouting;timeout;started;bootDelay;log;constructor(t,r){super(),this.log=t.logger.forComponent("libp2p:circuit-relay:advert-service"),this.contentRouting=t.contentRouting,this.bootDelay=r?.bootDelay??tl,this.started=!1}isStarted(){return this.started}start(){this.started||(this.timeout=setTimeout(()=>{this._advertiseService().catch(t=>{this.log.error("could not advertise service",t)})},this.bootDelay),this.started=!0)}stop(){try{clearTimeout(this.timeout)}catch{}this.started=!1}async _advertiseService(){await Fa(async()=>{try{let t=await ls(as);await this.contentRouting.provide(t),this.safeDispatchEvent("advert:success",{detail:void 0})}catch(t){if(this.safeDispatchEvent("advert:error",{detail:t}),t.code===el){this.log.error("a content router, such as a DHT, must be provided in order to advertise the relay service",t),this.stop();return}throw this.log.error("could not advertise service",t),t}})}};function nr(e,t){let r={[Symbol.iterator]:()=>r,next:()=>{let n=e.next(),i=n.value;return n.done===!0||i==null?{done:!0,value:void 0}:{done:!1,value:t(i)}}};return r}var ir=class{map;constructor(t){if(this.map=new Map,t!=null)for(let[r,n]of t.entries())this.map.set(r.toString(),n)}[Symbol.iterator](){return this.entries()}clear(){this.map.clear()}delete(t){this.map.delete(t.toString())}entries(){return nr(this.map.entries(),t=>[St(t[0]),t[1]])}forEach(t){this.map.forEach((r,n)=>{t(r,St(n),this)})}get(t){return this.map.get(t.toString())}has(t){return this.map.has(t.toString())}set(t,r){this.map.set(t.toString(),r)}keys(){return nr(this.map.keys(),t=>St(t))}values(){return this.map.values()}get size(){return this.map.size}};var Va=class e{set;constructor(t){if(this.set=new Set,t!=null)for(let r of t)this.set.add(r.toString())}get size(){return this.set.size}[Symbol.iterator](){return this.values()}add(t){this.set.add(t.toString())}clear(){this.set.clear()}delete(t){this.set.delete(t.toString())}entries(){return nr(this.set.entries(),t=>{let r=St(t[0]);return[r,r]})}forEach(t){this.set.forEach(r=>{let n=St(r);t(n,n,this)})}has(t){return this.set.has(t.toString())}values(){return nr(this.set.values(),t=>St(t))}intersection(t){let r=new e;for(let n of t)this.has(n)&&r.add(n);return r}difference(t){let r=new e;for(let n of this)t.has(n)||r.add(n);return r}union(t){let r=new e;for(let n of t)r.add(n);for(let n of this)r.add(n);return r}};var qa=class e{list;constructor(t){if(this.list=[],t!=null)for(let r of t)this.list.push(r.toString())}[Symbol.iterator](){return nr(this.list.entries(),t=>St(t[1]))}concat(t){let r=new e(this);for(let n of t)r.push(n);return r}entries(){return nr(this.list.entries(),t=>[t[0],St(t[1])])}every(t){return this.list.every((r,n)=>t(St(r),n,this))}filter(t){let r=new e;return this.list.forEach((n,i)=>{let s=St(n);t(s,i,this)&&r.push(s)}),r}find(t){let r=this.list.find((n,i)=>t(St(n),i,this));if(r!=null)return St(r)}findIndex(t){return this.list.findIndex((r,n)=>t(St(r),n,this))}forEach(t){this.list.forEach((r,n)=>{t(St(r),n,this)})}includes(t){return this.list.includes(t.toString())}indexOf(t){return this.list.indexOf(t.toString())}pop(){let t=this.list.pop();if(t!=null)return St(t)}push(...t){for(let r of t)this.list.push(r.toString())}shift(){let t=this.list.shift();if(t!=null)return St(t)}unshift(...t){let r=this.list.length;for(let n=t.length-1;n>-1;n--)r=this.list.unshift(t[n].toString());return r}get length(){return this.list.length}};var ds=class{reservations=new ir;_started=!1;interval;maxReservations;reservationClearInterval;applyDefaultLimit;reservationTtl;defaultDurationLimit;defaultDataLimit;constructor(t={}){this.maxReservations=t.maxReservations??15,this.reservationClearInterval=t.reservationClearInterval??3e5,this.applyDefaultLimit=t.applyDefaultLimit!==!1,this.reservationTtl=t.reservationTtl??72e5,this.defaultDurationLimit=t.defaultDurationLimit??12e4,this.defaultDataLimit=t.defaultDataLimit??Jf}isStarted(){return this._started}start(){this._started||(this._started=!0,this.interval=setInterval(()=>{let t=new Date().getTime();this.reservations.forEach((r,n)=>{r.expire.getTime()<t&&this.reservations.delete(n)})},this.reservationClearInterval))}stop(){clearInterval(this.interval)}reserve(t,r,n){if(this.reservations.size>=this.maxReservations&&!this.reservations.has(t))return{status:tt.RESERVATION_REFUSED};let i=new Date(Date.now()+this.reservationTtl),s;return this.applyDefaultLimit&&(s=n??{data:this.defaultDataLimit,duration:this.defaultDurationLimit}),this.reservations.set(t,{addr:r,expire:i,limit:s}),{status:tt.OK,expire:Math.round(i.getTime()/1e3)}}removeReservation(t){this.reservations.delete(t)}hasReservation(t){return this.reservations.has(t)}get(t){return this.reservations.get(t)}};var ps=class e{domain="libp2p-relay-rsvp";codec=new Uint8Array([3,2]);relay;peer;expiration;constructor({relay:t,peer:r,expiration:n}){this.relay=t,this.peer=r,this.expiration=n}marshal(){return fs.encode({relay:this.relay.toBytes(),peer:this.peer.toBytes(),expiration:BigInt(this.expiration)})}equals(t){return!(!(t instanceof e)||!this.peer.equals(t.peer)||!this.relay.equals(t.relay)||this.expiration!==t.expiration)}};var dl=e=>e.protoCodes().includes(290),a1={maxOutboundStopStreams:ei},Ha=class extends me{registrar;peerStore;addressManager;peerId;connectionManager;connectionGater;reservationStore;advertService;started;hopTimeout;shutdownController;maxInboundHopStreams;maxOutboundHopStreams;maxOutboundStopStreams;log;constructor(t,r={}){super(),this.log=t.logger.forComponent("libp2p:circuit-relay:server"),this.registrar=t.registrar,this.peerStore=t.peerStore,this.addressManager=t.addressManager,this.peerId=t.peerId,this.connectionManager=t.connectionManager,this.connectionGater=t.connectionGater,this.started=!1,this.hopTimeout=r?.hopTimeout??jf,this.shutdownController=new AbortController,this.maxInboundHopStreams=r.maxInboundHopStreams,this.maxOutboundHopStreams=r.maxOutboundHopStreams,this.maxOutboundStopStreams=r.maxOutboundStopStreams??a1.maxOutboundStopStreams,w0(1/0,this.shutdownController.signal),r.advertise!=null&&r.advertise!==!1&&(this.advertService=new hs(t,r.advertise===!0?void 0:r.advertise),this.advertService.addEventListener("advert:success",()=>{this.safeDispatchEvent("relay:advert:success",{})}),this.advertService.addEventListener("advert:error",n=>{this.safeDispatchEvent("relay:advert:error",{detail:n.detail})})),this.reservationStore=new ds(r.reservations)}isStarted(){return this.started}async start(){this.started||(this.advertService?.start(),await this.registrar.handle(we,t=>{this.onHop(t).catch(r=>{this.log.error(r)})},{maxInboundStreams:this.maxInboundHopStreams,maxOutboundStreams:this.maxOutboundHopStreams,runOnTransientConnection:!0}),this.reservationStore.start(),this.started=!0)}async stop(){this.advertService?.stop(),this.reservationStore.stop(),this.shutdownController.abort(),await this.registrar.unhandle(we),this.started=!1}async onHop({connection:t,stream:r}){this.log("received circuit v2 hop protocol stream from %p",t.remotePeer);let n=wr(),i=setTimeout(()=>{n.reject("timed out")},this.hopTimeout),s=Sr(r);try{let o=await Promise.race([s.pb(ft).read(),n.promise]);if(o?.type==null)throw new Error("request was invalid, could not read from stream");this.log("received",o.type),await Promise.race([this.handleHopProtocol({connection:t,stream:s,request:o}),n.promise])}catch(o){this.log.error("error while handling hop",o),await s.pb(ft).write({type:ft.Type.STATUS,status:tt.MALFORMED_MESSAGE}),r.abort(o)}finally{clearTimeout(i)}}async handleHopProtocol({stream:t,request:r,connection:n}){switch(this.log("received hop message"),r.type){case ft.Type.RESERVE:await this.handleReserve({stream:t,request:r,connection:n});break;case ft.Type.CONNECT:await this.handleConnect({stream:t,request:r,connection:n});break;default:this.log.error("invalid hop request type %s via peer %p",r.type,n.remotePeer),await t.pb(ft).write({type:ft.Type.STATUS,status:tt.UNEXPECTED_MESSAGE})}}async handleReserve({stream:t,request:r,connection:n}){let i=t.pb(ft);if(this.log("hop reserve request from %p",n.remotePeer),dl(n.remoteAddr)){this.log.error("relay reservation over circuit connection denied for peer: %p",n.remotePeer),await i.write({type:ft.Type.STATUS,status:tt.PERMISSION_DENIED});return}if(await this.connectionGater.denyInboundRelayReservation?.(n.remotePeer)===!0){this.log.error("reservation for %p denied by connection gater",n.remotePeer),await i.write({type:ft.Type.STATUS,status:tt.PERMISSION_DENIED});return}let s=this.reservationStore.reserve(n.remotePeer,n.remoteAddr);if(s.status!==tt.OK){await i.write({type:ft.Type.STATUS,status:s.status});return}try{if(s.expire!=null){let o=s.expire*1e3-Date.now();await this.peerStore.merge(n.remotePeer,{tags:{[Zf]:{value:1,ttl:o}}})}await i.write({type:ft.Type.STATUS,status:tt.OK,reservation:await this.makeReservation(n.remotePeer,BigInt(s.expire??0)),limit:this.reservationStore.get(n.remotePeer)?.limit}),this.log("sent confirmation response to %s",n.remotePeer)}catch(o){this.log.error("failed to send confirmation response to %p",n.remotePeer,o),this.reservationStore.removeReservation(n.remotePeer)}}async makeReservation(t,r){let n=[];for(let s of this.addressManager.getAddresses())s.toString().includes("/p2p-circuit")||n.push(s.bytes);let i=await jn.seal(new ps({peer:t,relay:this.peerId,expiration:Number(r)}),this.peerId);return{addrs:n,expire:r,voucher:i.marshal()}}async handleConnect({stream:t,request:r,connection:n}){let i=t.pb(ft);if(dl(n.remoteAddr)){this.log.error("relay reservation over circuit connection denied for peer: %p",n.remotePeer),await i.write({type:ft.Type.STATUS,status:tt.PERMISSION_DENIED});return}this.log("hop connect request from %p",n.remotePeer);let s;try{if(r.peer==null)throw this.log.error("no peer info in hop connect request"),new Error("no peer info in request");r.peer.addrs.forEach(ee),s=on(r.peer.id)}catch(l){this.log.error("invalid hop connect request via peer %p %s",n.remotePeer,l),await i.write({type:ft.Type.STATUS,status:tt.MALFORMED_MESSAGE});return}if(!this.reservationStore.hasReservation(s)){this.log.error("hop connect denied for destination peer %p not having a reservation for %p with status %s",s,n.remotePeer,tt.NO_RESERVATION),await i.write({type:ft.Type.STATUS,status:tt.NO_RESERVATION});return}if(await this.connectionGater.denyOutboundRelayedConnection?.(n.remotePeer,s)===!0){this.log.error("hop connect for %p to %p denied by connection gater",n.remotePeer,s),await i.write({type:ft.Type.STATUS,status:tt.PERMISSION_DENIED});return}let o=this.connectionManager.getConnections(s);if(o.length===0){this.log("hop connect denied for destination peer %p not having a connection for %p as there is no destination connection",s,n.remotePeer),await i.write({type:ft.Type.STATUS,status:tt.NO_RESERVATION});return}let a=o[0],c=await this.stopHop({connection:a,request:{type:de.Type.CONNECT,peer:{id:n.remotePeer.toBytes(),addrs:[]}}});if(c==null){this.log.error("failed to open stream to destination peer %p",a?.remotePeer),await i.write({type:ft.Type.STATUS,status:tt.CONNECTION_FAILED});return}await i.write({type:ft.Type.STATUS,status:tt.OK});let u=t.unwrap();this.log("connection from %p to %p established - merging streams",n.remotePeer,s);let f=this.reservationStore.get(s)?.limit;sl(u,c,this.shutdownController.signal,f,{log:this.log})}async stopHop({connection:t,request:r}){this.log("starting circuit relay v2 stop request to %s",t.remotePeer);let n=await t.newStream([Yr],{maxOutboundStreams:this.maxOutboundStopStreams,runOnTransientConnection:!0}),i=Sr(n),s=i.pb(de);await s.write(r);let o;try{o=await s.read()}catch{this.log.error("error parsing stop message response from %p",t.remotePeer)}if(o==null){this.log.error("could not read response from %p",t.remotePeer),await n.close();return}if(o.status===tt.OK)return this.log("stop request to %p was successful",t.remotePeer),i.unwrap();this.log("stop request failed with code %d",o.status),await n.close()}get reservations(){return this.reservationStore.reservations}};function pl(e={}){return t=>new Ha(t,e)}var ys=class extends me{peerId;peerStore;contentRouting;registrar;started;topologyId;log;constructor(t){super(),this.log=t.logger.forComponent("libp2p:circuit-relay:discover-relays"),this.started=!1,this.peerId=t.peerId,this.peerStore=t.peerStore,this.contentRouting=t.contentRouting,this.registrar=t.registrar}isStarted(){return this.started}async start(){this.topologyId=await this.registrar.register(we,{notifyOnTransient:!0,onConnect:t=>{this.safeDispatchEvent("relay:discover",{detail:t})}}),this.discover().catch(t=>{this.log.error("error listening on relays",t)}),this.started=!0}stop(){this.topologyId!=null&&this.registrar.unregister(this.topologyId),this.started=!1}async discover(){this.log("searching peer store for relays");let t=await this.peerStore.all({filters:[r=>r.protocols.includes(we)],orders:[()=>Math.random()<.5?1:-1]});for(let r of t)this.log("found relay peer %p in content peer store",r.id),this.safeDispatchEvent("relay:discover",{detail:r.id});this.log("found %d relay peers in peer store",t.length);try{this.log("searching content routing for relays");let r=await ls(as),n=0;for await(let i of this.contentRouting.findProviders(r))if(i.multiaddrs.length>0&&!i.id.equals(this.peerId)){let s=i.id;n++,await this.peerStore.merge(s,{multiaddrs:i.multiaddrs}),this.log("found relay peer %p in content routing",s),this.safeDispatchEvent("relay:discover",{detail:s})}this.log("found %d relay peers in content routing",n)}catch(r){this.log.error("failed when finding relays on the network",r)}}};var Wa=Yt(ml(),1);var ni=class extends Error{constructor(t){super(t),this.name="TimeoutError"}},Ya=class extends Error{constructor(t){super(),this.name="AbortError",this.message=t}},gl=e=>globalThis.DOMException===void 0?new Ya(e):new DOMException(e),xl=e=>{let t=e.reason===void 0?gl("This operation was aborted."):e.reason;return t instanceof Error?t:gl(t)};function $a(e,t,r,n){let i,s=new Promise((o,a)=>{if(typeof t!="number"||Math.sign(t)!==1)throw new TypeError(`Expected \`milliseconds\` to be a positive number, got \`${t}\``);if(t===Number.POSITIVE_INFINITY){o(e);return}if(n={customTimers:{setTimeout,clearTimeout},...n},n.signal){let{signal:c}=n;c.aborted&&a(xl(c)),c.addEventListener("abort",()=>{a(xl(c))})}i=n.customTimers.setTimeout.call(void 0,()=>{if(typeof r=="function"){try{o(r())}catch(f){a(f)}return}let c=typeof r=="string"?r:`Promise timed out after ${t} milliseconds`,u=r instanceof Error?r:new ni(c);typeof e.cancel=="function"&&e.cancel(),a(u)},t),(async()=>{try{o(await e)}catch(c){a(c)}finally{n.customTimers.clearTimeout.call(void 0,i)}})()});return s.clear=()=>{clearTimeout(i),i=void 0},s}function Qa(e,t,r){let n=0,i=e.length;for(;i>0;){let s=Math.trunc(i/2),o=n+s;r(e[o],t)<=0?(n=++o,i-=s+1):i=s}return n}var Qr=function(e,t,r,n){if(r==="a"&&!n)throw new TypeError("Private accessor was defined without a getter");if(typeof t=="function"?e!==t||!n:!t.has(e))throw new TypeError("Cannot read private member from an object whose class did not declare it");return r==="m"?n:r==="a"?n.call(e):n?n.value:t.get(e)},sr,Za=class{constructor(){sr.set(this,[])}enqueue(t,r){r={priority:0,...r};let n={priority:r.priority,run:t};if(this.size&&Qr(this,sr,"f")[this.size-1].priority>=r.priority){Qr(this,sr,"f").push(n);return}let i=Qa(Qr(this,sr,"f"),n,(s,o)=>o.priority-s.priority);Qr(this,sr,"f").splice(i,0,n)}dequeue(){let t=Qr(this,sr,"f").shift();return t?.run}filter(t){return Qr(this,sr,"f").filter(r=>r.priority===t.priority).map(r=>r.run)}get size(){return Qr(this,sr,"f").length}};sr=new WeakMap;var vl=Za;var At=function(e,t,r,n,i){if(n==="m")throw new TypeError("Private method is not writable");if(n==="a"&&!i)throw new TypeError("Private accessor was defined without a setter");if(typeof t=="function"?e!==t||!i:!t.has(e))throw new TypeError("Cannot write private member to an object whose class did not declare it");return n==="a"?i.call(e,r):i?i.value=r:t.set(e,r),r},K=function(e,t,r,n){if(r==="a"&&!n)throw new TypeError("Private accessor was defined without a getter");if(typeof t=="function"?e!==t||!n:!t.has(e))throw new TypeError("Cannot read private member from an object whose class did not declare it");return r==="m"?n:r==="a"?n.call(e):n?n.value:t.get(e)},_t,si,oi,Tr,ws,ai,gs,De,ii,pe,xs,ye,ci,Ar,vs,bl,El,Al,wl,Sl,bs,Xa,Ja,Ss,Tl,Es,As=class extends Error{},ja=class extends Wa.default{constructor(t){var r,n,i,s;if(super(),_t.add(this),si.set(this,void 0),oi.set(this,void 0),Tr.set(this,0),ws.set(this,void 0),ai.set(this,void 0),gs.set(this,0),De.set(this,void 0),ii.set(this,void 0),pe.set(this,void 0),xs.set(this,void 0),ye.set(this,0),ci.set(this,void 0),Ar.set(this,void 0),vs.set(this,void 0),Object.defineProperty(this,"timeout",{enumerable:!0,configurable:!0,writable:!0,value:void 0}),t={carryoverConcurrencyCount:!1,intervalCap:Number.POSITIVE_INFINITY,interval:0,concurrency:Number.POSITIVE_INFINITY,autoStart:!0,queueClass:vl,...t},!(typeof t.intervalCap=="number"&&t.intervalCap>=1))throw new TypeError(`Expected \`intervalCap\` to be a number from 1 and up, got \`${(n=(r=t.intervalCap)===null||r===void 0?void 0:r.toString())!==null&&n!==void 0?n:""}\` (${typeof t.intervalCap})`);if(t.interval===void 0||!(Number.isFinite(t.interval)&&t.interval>=0))throw new TypeError(`Expected \`interval\` to be a finite number >= 0, got \`${(s=(i=t.interval)===null||i===void 0?void 0:i.toString())!==null&&s!==void 0?s:""}\` (${typeof t.interval})`);At(this,si,t.carryoverConcurrencyCount,"f"),At(this,oi,t.intervalCap===Number.POSITIVE_INFINITY||t.interval===0,"f"),At(this,ws,t.intervalCap,"f"),At(this,ai,t.interval,"f"),At(this,pe,new t.queueClass,"f"),At(this,xs,t.queueClass,"f"),this.concurrency=t.concurrency,this.timeout=t.timeout,At(this,vs,t.throwOnTimeout===!0,"f"),At(this,Ar,t.autoStart===!1,"f")}get concurrency(){return K(this,ci,"f")}set concurrency(t){if(!(typeof t=="number"&&t>=1))throw new TypeError(`Expected \`concurrency\` to be a number from 1 and up, got \`${t}\` (${typeof t})`);At(this,ci,t,"f"),K(this,_t,"m",Ss).call(this)}async add(t,r={}){return r={timeout:this.timeout,throwOnTimeout:K(this,vs,"f"),...r},new Promise((n,i)=>{K(this,pe,"f").enqueue(async()=>{var s,o,a;At(this,ye,(o=K(this,ye,"f"),o++,o),"f"),At(this,Tr,(a=K(this,Tr,"f"),a++,a),"f");try{if(!((s=r.signal)===null||s===void 0)&&s.aborted)throw new As("The task was aborted.");let c=t({signal:r.signal});r.timeout&&(c=$a(Promise.resolve(c),r.timeout)),r.signal&&(c=Promise.race([c,K(this,_t,"m",Tl).call(this,r.signal)]));let u=await c;n(u),this.emit("completed",u)}catch(c){if(c instanceof ni&&!r.throwOnTimeout){n();return}i(c),this.emit("error",c)}finally{K(this,_t,"m",Al).call(this)}},r),this.emit("add"),K(this,_t,"m",bs).call(this)})}async addAll(t,r){return Promise.all(t.map(async n=>this.add(n,r)))}start(){return K(this,Ar,"f")?(At(this,Ar,!1,"f"),K(this,_t,"m",Ss).call(this),this):this}pause(){At(this,Ar,!0,"f")}clear(){At(this,pe,new(K(this,xs,"f")),"f")}async onEmpty(){K(this,pe,"f").size!==0&&await K(this,_t,"m",Es).call(this,"empty")}async onSizeLessThan(t){K(this,pe,"f").size<t||await K(this,_t,"m",Es).call(this,"next",()=>K(this,pe,"f").size<t)}async onIdle(){K(this,ye,"f")===0&&K(this,pe,"f").size===0||await K(this,_t,"m",Es).call(this,"idle")}get size(){return K(this,pe,"f").size}sizeBy(t){return K(this,pe,"f").filter(t).length}get pending(){return K(this,ye,"f")}get isPaused(){return K(this,Ar,"f")}};si=new WeakMap,oi=new WeakMap,Tr=new WeakMap,ws=new WeakMap,ai=new WeakMap,gs=new WeakMap,De=new WeakMap,ii=new WeakMap,pe=new WeakMap,xs=new WeakMap,ye=new WeakMap,ci=new WeakMap,Ar=new WeakMap,vs=new WeakMap,_t=new WeakSet,bl=function(){return K(this,oi,"f")||K(this,Tr,"f")<K(this,ws,"f")},El=function(){return K(this,ye,"f")<K(this,ci,"f")},Al=function(){var t;At(this,ye,(t=K(this,ye,"f"),t--,t),"f"),K(this,_t,"m",bs).call(this),this.emit("next")},wl=function(){K(this,_t,"m",Ja).call(this),K(this,_t,"m",Xa).call(this),At(this,ii,void 0,"f")},Sl=function(){let t=Date.now();if(K(this,De,"f")===void 0){let r=K(this,gs,"f")-t;if(r<0)At(this,Tr,K(this,si,"f")?K(this,ye,"f"):0,"f");else return K(this,ii,"f")===void 0&&At(this,ii,setTimeout(()=>{K(this,_t,"m",wl).call(this)},r),"f"),!0}return!1},bs=function(){if(K(this,pe,"f").size===0)return K(this,De,"f")&&clearInterval(K(this,De,"f")),At(this,De,void 0,"f"),this.emit("empty"),K(this,ye,"f")===0&&this.emit("idle"),!1;if(!K(this,Ar,"f")){let t=!K(this,_t,"a",Sl);if(K(this,_t,"a",bl)&&K(this,_t,"a",El)){let r=K(this,pe,"f").dequeue();return r?(this.emit("active"),r(),t&&K(this,_t,"m",Xa).call(this),!0):!1}}return!1},Xa=function(){K(this,oi,"f")||K(this,De,"f")!==void 0||(At(this,De,setInterval(()=>{K(this,_t,"m",Ja).call(this)},K(this,ai,"f")),"f"),At(this,gs,Date.now()+K(this,ai,"f"),"f"))},Ja=function(){K(this,Tr,"f")===0&&K(this,ye,"f")===0&&K(this,De,"f")&&(clearInterval(K(this,De,"f")),At(this,De,void 0,"f")),At(this,Tr,K(this,si,"f")?K(this,ye,"f"):0,"f"),K(this,_t,"m",Ss).call(this)},Ss=function(){for(;K(this,_t,"m",bs).call(this););},Tl=async function(t){return new Promise((r,n)=>{t.addEventListener("abort",()=>{n(new As("The task was aborted."))},{once:!0})})},Es=async function(t,r){return new Promise(n=>{let i=()=>{r&&!r()||(this.off(t,i),n())};this.on(t,i)})};var Bl=ja;function f1(e,t,r){let n=0,i=e.length;for(;i>0;){let s=Math.trunc(i/2),o=n+s;r(e[o],t)<=0?(n=++o,i-=s+1):i=s}return n}var t0=class{#t=[];enqueue(t,r){let n=r?.peerId,i=r?.priority??0;if(n==null)throw new H("missing peer id",E0);let s={priority:i,peerId:n,run:t};if(this.size>0&&this.#t[this.size-1].priority>=i){this.#t.push(s);return}let o=f1(this.#t,s,(a,c)=>c.priority-a.priority);this.#t.splice(o,0,s)}dequeue(){return this.#t.shift()?.run}filter(t){if(t.peerId!=null){let r=t.peerId;return this.#t.filter(n=>r.equals(n.peerId)).map(n=>n.run)}return this.#t.filter(r=>r.priority===t.priority).map(r=>r.run)}get size(){return this.#t.length}},Ts=class extends Bl{constructor(t={}){super({...t,queueClass:t0})}hasJob(t){return this.sizeBy({peerId:t})>0}};var h1=60*1e3*10,d1=60*1e3*5,p1=30*1e3,Bs=class extends me{peerId;connectionManager;transportManager;peerStore;events;reserveQueue;reservations;maxDiscoveredRelays;maxReservationQueueLength;reservationCompletionTimeout;started;log;constructor(t,r){super(),this.log=t.logger.forComponent("libp2p:circuit-relay:transport:reservation-store"),this.peerId=t.peerId,this.connectionManager=t.connectionManager,this.transportManager=t.transportManager,this.peerStore=t.peerStore,this.events=t.events,this.reservations=new ir,this.maxDiscoveredRelays=r?.discoverRelays??0,this.maxReservationQueueLength=r?.maxReservationQueueLength??100,this.reservationCompletionTimeout=r?.reservationCompletionTimeout??1e4,this.started=!1,this.reserveQueue=new Ts({concurrency:r?.reservationConcurrency??1}),this.events.addEventListener("peer:disconnect",n=>{this.#e(n.detail)})}isStarted(){return this.started}async start(){this.started=!0}async stop(){this.reserveQueue.clear(),this.reservations.forEach(({timeout:t})=>{clearTimeout(t)}),this.reservations.clear(),this.started=!1}async addRelay(t,r){if(this.peerId.equals(t)){this.log("not trying to use self as relay");return}if(this.reserveQueue.size>this.maxReservationQueueLength){this.log("not adding relay as the queue is full");return}if(this.reserveQueue.hasJob(t)){this.log("relay peer is already in the reservation queue");return}this.log("add relay %p",t),await this.reserveQueue.add(async()=>{try{let n=this.reservations.get(t);if(n!=null){if(Oa(n.reservation.expire)>h1){this.log("already have reservation on relay peer %p and it expires in more than 10 minutes",t);return}clearTimeout(n.timeout),this.reservations.delete(t)}if(r==="discovered"&&[...this.reservations.values()].reduce((f,l)=>(l.type==="discovered"&&f++,f),0)>=this.maxDiscoveredRelays){this.log("already have enough discovered relays");return}let i=AbortSignal.timeout(this.reservationCompletionTimeout),s=await this.connectionManager.openConnection(t,{signal:i});if(s.remoteAddr.protoNames().includes("p2p-circuit")){this.log("not creating reservation over relayed connection");return}let o=await this.#t(s,{signal:i});this.log("created reservation on relay peer %p",t);let a=Oa(o.expire),c=Math.min(Math.max(a-d1,p1),Math.pow(2,31)-1),u=setTimeout(()=>{this.addRelay(t,r).catch(f=>{this.log.error("could not refresh reservation to relay %p",t,f)})},c);this.reservations.set(t,{timeout:u,reservation:o,type:r}),await this.peerStore.merge(t,{tags:{[Xf]:{value:1,ttl:a}}}),await this.transportManager.listen([ee(`/p2p/${t.toString()}/p2p-circuit`)])}catch(n){this.log.error("could not reserve slot on %p",t,n);let i=this.reservations.get(t);i!=null&&clearTimeout(i.timeout),this.reservations.delete(t)}},{peerId:t})}hasReservation(t){return this.reservations.has(t)}getReservation(t){return this.reservations.get(t)?.reservation}async#t(t,r){r.signal?.throwIfAborted(),this.log("requesting reservation from %p",t.remotePeer);let n=await t.newStream(we,r),s=Sr(n).pb(ft);await s.write({type:ft.Type.RESERVE},r);let o;try{o=await s.read(r)}catch(c){throw this.log.error("error parsing reserve message response from %p because",t.remotePeer,c),n.abort(c),c}finally{await n.close()}if(o.status===tt.OK&&o.reservation!=null){let c=!1,u=t.remoteAddr.bytes;for(let f of o.reservation.addrs)if(Ct(u,f)){c=!0;break}return c||o.reservation.addrs.push(u),o.reservation}let a=`reservation failed with status ${o.status??"undefined"}`;throw this.log.error(a),new Error(a)}#e(t){let r=this.reservations.get(t);r!=null&&(this.log("connection to relay %p closed, removing reservation from local store",t),clearTimeout(r.timeout),this.reservations.delete(t),this.safeDispatchEvent("relay:removed",{detail:t}),this.reservations.size<this.maxDiscoveredRelays&&(this.log("not enough relays %d/%d",this.reservations.size,this.maxDiscoveredRelays),this.safeDispatchEvent("relay:not-enough-relays",{})))}};function e0(e){let{stream:t,remoteAddr:r,logger:n}=e,i=n.forComponent("libp2p:stream:converter"),s=!1,o=!1,a=t.close.bind(t);t.close=async h=>{await a(h),l(!0)};let c=t.abort.bind(t);t.abort=h=>{c(h),l(!0)};let u=t.sink.bind(t);t.sink=async h=>{try{await u(h)}catch(y){y.type!=="aborted"&&i(y)}finally{o=!0,l()}};let f={log:i,sink:t.sink,source:async function*(){try{for await(let h of t.source)h instanceof Uint8Array?yield h:yield*h}finally{s=!0,l()}}(),remoteAddr:r,timeline:{open:Date.now(),close:void 0},close:t.close,abort:t.abort};function l(h){h===!0&&(s=!0,o=!0),s&&o&&f.timeline.close==null&&(f.timeline.close=Date.now())}return f}var y1=U("dns4"),m1=U("dns6"),g1=U("dnsaddr"),Zr=Rt(U("dns"),g1,y1,m1),_s=Rt(U("ip4"),U("ip6")),In=Rt(z(_s,U("tcp")),z(Zr,U("tcp"))),Rs=z(_s,U("udp")),x1=z(Rs,U("utp")),v1=z(Rs,U("quic")),b1=z(Rs,U("quic-v1")),r0=Rt(z(In,U("ws")),z(Zr,U("ws"))),Is=Rt(z(r0,U("p2p")),r0),n0=Rt(z(In,U("wss")),z(Zr,U("wss")),z(In,U("tls"),U("ws")),z(Zr,U("tls"),U("ws"))),Cs=Rt(z(n0,U("p2p")),n0),i0=Rt(z(In,U("http")),z(_s,U("http")),z(Zr,U("http"))),s0=Rt(z(In,U("https")),z(_s,U("https")),z(Zr,U("https"))),Il=z(Rs,U("webrtc-direct"),U("certhash")),Rl=Rt(z(Il,U("p2p")),Il),Cl=z(b1,U("webtransport"),U("certhash"),U("certhash")),Ll=Rt(z(Cl,U("p2p")),Cl),Dl=Rt(z(Is,U("p2p-webrtc-star"),U("p2p")),z(Cs,U("p2p-webrtc-star"),U("p2p")),z(Is,U("p2p-webrtc-star")),z(Cs,U("p2p-webrtc-star"))),s3=Rt(z(Is,U("p2p-websocket-star"),U("p2p")),z(Cs,U("p2p-websocket-star"),U("p2p")),z(Is,U("p2p-websocket-star")),z(Cs,U("p2p-websocket-star"))),Nl=Rt(z(i0,U("p2p-webrtc-direct"),U("p2p")),z(s0,U("p2p-webrtc-direct"),U("p2p")),z(i0,U("p2p-webrtc-direct")),z(s0,U("p2p-webrtc-direct"))),Xr=Rt(r0,n0,i0,s0,Dl,Nl,In,x1,v1,Zr,Rl,Ll),o3=Rt(z(Xr,U("p2p-stardust"),U("p2p")),z(Xr,U("p2p-stardust"))),Br=Rt(z(Xr,U("p2p")),Dl,Nl,Rl,Ll,U("p2p")),_l=Rt(z(Br,U("p2p-circuit"),Br),z(Br,U("p2p-circuit")),z(U("p2p-circuit"),Br),z(Xr,U("p2p-circuit")),z(U("p2p-circuit"),Xr),U("p2p-circuit")),Pl=()=>Rt(z(_l,Pl),_l),or=Pl(),a3=Rt(z(or,Br,or),z(Br,or),z(or,Br),or,Br);var c3=Rt(z(or,U("webrtc"),U("p2p")),z(or,U("webrtc")),z(Xr,U("webrtc"),U("p2p")),z(Xr,U("webrtc")),U("webrtc"));function kl(e){function t(r){let n;try{n=ee(r)}catch{return!1}let i=e(n.protoNames());return i===null?!1:i===!0||i===!1?i:i.length===0}return t}function z(...e){function t(r){if(r.length<e.length)return null;let n=r;return e.some(i=>(n=typeof i=="function"?i().partialMatch(r):i.partialMatch(r),Array.isArray(n)&&(r=n),n===null)),n}return{toString:function(){return"{ "+e.join(" ")+" }"},input:e,matches:kl(t),partialMatch:t}}function Rt(...e){function t(n){let i=null;return e.some(s=>{let o=typeof s=="function"?s().partialMatch(n):s.partialMatch(n);return o!=null?(i=o,!0):!1}),i}return{toString:function(){return"{ "+e.join(" ")+" }"},input:e,matches:kl(t),partialMatch:t}}function U(e){let t=e;function r(i){let s;try{s=ee(i)}catch{return!1}let o=s.protoNames();return o.length===1&&o[0]===t}function n(i){return i.length===0?null:i[0]===t?i.slice(1):null}return{toString:function(){return t},matches:r,partialMatch:n}}var o0=class extends me{connectionManager;relayStore;listeningAddrs;log;constructor(t){super(),this.log=t.logger.forComponent("libp2p:circuit-relay:transport:listener"),this.connectionManager=t.connectionManager,this.relayStore=t.relayStore,this.listeningAddrs=new ir,this.relayStore.addEventListener("relay:removed",this._onRemoveRelayPeer)}_onRemoveRelayPeer=t=>{this.#t(t.detail)};async listen(t){this.log("listen on %a",t);let r=t.decapsulate("/p2p-circuit"),n=await this.connectionManager.openConnection(r);if(!this.relayStore.hasReservation(n.remotePeer)){this.log("making reservation on peer %p",n.remotePeer),await this.relayStore.addRelay(n.remotePeer,"configured");return}let i=this.relayStore.getReservation(n.remotePeer);if(i==null)throw new H("Did not have reservation after making reservation","ERR_NO_RESERVATION");if(this.listeningAddrs.has(n.remotePeer)){this.log("already listening on relay %p",n.remotePeer);return}this.listeningAddrs.set(n.remotePeer,i.addrs.map(s=>ee(s).encapsulate("/p2p-circuit"))),this.safeDispatchEvent("listening",{})}getAddrs(){return[...this.listeningAddrs.values()].flat()}async close(){}#t(t){let r=this.listeningAddrs.has(t);this.log("relay peer removed %p - had reservation",t,r),this.listeningAddrs.delete(t),r&&(this.log.trace("removing relay event listener for peer %p",t),this.relayStore.removeEventListener("relay:removed",this._onRemoveRelayPeer),this.safeDispatchEvent("close",{}))}};function Ul(e){return new o0(e)}var w1=e=>{if(e.peer==null)return!1;try{e.peer.addrs.forEach(ee)}catch{return!1}return!0},a0={maxInboundStopStreams:ei,maxOutboundStopStreams:ei,stopTimeout:3e4},Ls=class{discovery;registrar;peerStore;connectionManager;transportManager;peerId;upgrader;addressManager;connectionGater;reservationStore;logger;maxInboundStopStreams;maxOutboundStopStreams;stopTimeout;started;log;constructor(t,r){this.log=t.logger.forComponent("libp2p:circuit-relay:transport"),this.registrar=t.registrar,this.peerStore=t.peerStore,this.connectionManager=t.connectionManager,this.transportManager=t.transportManager,this.logger=t.logger,this.peerId=t.peerId,this.upgrader=t.upgrader,this.addressManager=t.addressManager,this.connectionGater=t.connectionGater,this.maxInboundStopStreams=r.maxInboundStopStreams??a0.maxInboundStopStreams,this.maxOutboundStopStreams=r.maxOutboundStopStreams??a0.maxOutboundStopStreams,this.stopTimeout=r.stopTimeout??a0.stopTimeout,r.discoverRelays!=null&&r.discoverRelays>0&&(this.discovery=new ys(t),this.discovery.addEventListener("relay:discover",n=>{this.reservationStore.addRelay(n.detail,"discovered").catch(i=>{this.log.error("could not add discovered relay %p",n.detail,i)})})),this.reservationStore=new Bs(t,r),this.reservationStore.addEventListener("relay:not-enough-relays",()=>{this.discovery?.discover().catch(n=>{this.log.error("could not discover relays",n)})}),this.started=!1}isStarted(){return this.started}async start(){await this.reservationStore.start(),await this.discovery?.start(),await this.registrar.handle(Yr,t=>{this.onStop(t).catch(r=>{this.log.error("error while handling STOP protocol",r),t.stream.abort(r)})},{maxInboundStreams:this.maxInboundStopStreams,maxOutboundStreams:this.maxOutboundStopStreams,runOnTransientConnection:!0}),this.started=!0}async stop(){this.discovery?.stop(),await this.reservationStore.stop(),await this.registrar.unhandle(Yr),this.started=!1}[b0]=!0;[Symbol.toStringTag]="libp2p/circuit-relay-v2";async dial(t,r={}){if(t.protoCodes().filter(d=>d===290).length!==1){let d="Invalid circuit relay address";throw this.log.error(d,t),new H(d,ka)}let n=t.toString().split("/p2p-circuit"),i=ee(n[0]),s=ee(n[n.length-1]),o=i.getPeerId(),a=s.getPeerId();if(o==null||a==null){let d=`Circuit relay dial to ${t.toString()} failed as address did not have peer ids`;throw this.log.error(d),new H(d,ka)}let c=St(o),u=St(a),f=!1,h=this.connectionManager.getConnections(c)[0];h==null&&(await this.peerStore.merge(c,{multiaddrs:[i]}),h=await this.connectionManager.openConnection(c,r),f=!0);let y;try{return y=await h.newStream(we),await this.connectV2({stream:y,connection:h,destinationPeer:u,destinationAddr:s,relayAddr:i,ma:t,disconnectOnFailure:f})}catch(d){throw this.log.error("circuit relay dial to destination %p via relay %p failed",u,c,d),y?.abort(d),f&&await h.close(),d}}async connectV2({stream:t,connection:r,destinationPeer:n,destinationAddr:i,relayAddr:s,ma:o,disconnectOnFailure:a}){try{let c=Sr(t),u=c.pb(ft);await u.write({type:ft.Type.CONNECT,peer:{id:n.toBytes(),addrs:[ee(i).bytes]}});let f=await u.read();if(f.status!==tt.OK)throw new H(`failed to connect via relay with status ${f?.status?.toString()??"undefined"}`,rl);let l=e0({stream:c.unwrap(),remoteAddr:o,localAddr:s.encapsulate(`/p2p-circuit/p2p/${this.peerId.toString()}`),logger:this.logger});return this.log("new outbound transient connection %a",l.remoteAddr),await this.upgrader.upgradeOutbound(l,{transient:!0})}catch(c){throw this.log.error(`Circuit relay dial to destination ${n.toString()} via relay ${r.remotePeer.toString()} failed`,c),a&&await r.close(),c}}createListener(t){return Ul({connectionManager:this.connectionManager,relayStore:this.reservationStore,logger:this.logger})}filter(t){return t=Array.isArray(t)?t:[t],t.filter(r=>or.matches(r))}async onStop({connection:t,stream:r}){if(!this.reservationStore.hasReservation(t.remotePeer))try{this.log("dialed via relay we did not have a reservation on, start listening on that relay address"),await this.transportManager.listen([t.remoteAddr.encapsulate("/p2p-circuit")])}catch(f){this.log.error("failed to listen on a relay peer we were dialed via but did not have a reservation on",f)}let n=AbortSignal.timeout(this.stopTimeout),i=Sr(r).pb(de),s=await i.read({signal:n});if(this.log("new circuit relay v2 stop stream from %p with type %s",t.remotePeer,s.type),s?.type===void 0){this.log.error("type was missing from circuit v2 stop protocol request from %s",t.remotePeer),await i.write({type:de.Type.STATUS,status:tt.MALFORMED_MESSAGE},{signal:n}),await r.close();return}if(s.type!==de.Type.CONNECT){this.log.error("invalid stop connect request via peer %p",t.remotePeer),await i.write({type:de.Type.STATUS,status:tt.UNEXPECTED_MESSAGE},{signal:n}),await r.close();return}if(!w1(s)){this.log.error("invalid stop connect request via peer %p",t.remotePeer),await i.write({type:de.Type.STATUS,status:tt.MALFORMED_MESSAGE},{signal:n}),await r.close();return}let o=on(s.peer.id);if(await this.connectionGater.denyInboundRelayedConnection?.(t.remotePeer,o)===!0){this.log.error("connection gater denied inbound relayed connection from %p",t.remotePeer),await i.write({type:de.Type.STATUS,status:tt.PERMISSION_DENIED},{signal:n}),await r.close();return}this.log.trace("sending success response to %p",t.remotePeer),await i.write({type:de.Type.STATUS,status:tt.OK},{signal:n});let a=t.remoteAddr.encapsulate(`/p2p-circuit/p2p/${o.toString()}`),c=this.addressManager.getAddresses()[0],u=e0({stream:i.unwrap().unwrap(),remoteAddr:a,localAddr:c,logger:this.logger});this.log("new inbound transient connection %a",u.remoteAddr),await this.upgrader.upgradeInbound(u,{transient:!0}),this.log("%s connection %a upgraded","inbound",u.remoteAddr)}};function Ol(e={}){return t=>new Ls(t,e)}return Xl(S1);})();
15
+ `+a+t.substr(o+1),s=i-o-1,o=-1,++i}else(t[i]===" "||t[i]===" "||t[i]===",")&&(o=i);return t}function Ad(e){return e.replace(/^\s+/,"")}});var Sc=ot((x2,wc)=>{var ke=ht();Lr();Dt();var vc=wc.exports=ke.sha256=ke.sha256||{};ke.md.sha256=ke.md.algorithms.sha256=vc;vc.create=function(){bc||Td();var e=null,t=ke.util.createBuffer(),r=new Array(64),n={algorithm:"sha256",blockLength:64,digestLength:32,messageLength:0,fullMessageLength:null,messageLengthSize:8};return n.start=function(){n.messageLength=0,n.fullMessageLength=n.messageLength64=[];for(var i=n.messageLengthSize/4,s=0;s<i;++s)n.fullMessageLength.push(0);return t=ke.util.createBuffer(),e={h0:1779033703,h1:3144134277,h2:1013904242,h3:2773480762,h4:1359893119,h5:2600822924,h6:528734635,h7:1541459225},n},n.start(),n.update=function(i,s){s==="utf8"&&(i=ke.util.encodeUtf8(i));var o=i.length;n.messageLength+=o,o=[o/4294967296>>>0,o>>>0];for(var a=n.fullMessageLength.length-1;a>=0;--a)n.fullMessageLength[a]+=o[1],o[1]=o[0]+(n.fullMessageLength[a]/4294967296>>>0),n.fullMessageLength[a]=n.fullMessageLength[a]>>>0,o[0]=o[1]/4294967296>>>0;return t.putBytes(i),xc(e,r,t),(t.read>2048||t.length()===0)&&t.compact(),n},n.digest=function(){var i=ke.util.createBuffer();i.putBytes(t.bytes());var s=n.fullMessageLength[n.fullMessageLength.length-1]+n.messageLengthSize,o=s&n.blockLength-1;i.putBytes(mo.substr(0,n.blockLength-o));for(var a,c,u=n.fullMessageLength[0]*8,f=0;f<n.fullMessageLength.length-1;++f)a=n.fullMessageLength[f+1]*8,c=a/4294967296>>>0,u+=c,i.putInt32(u>>>0),u=a>>>0;i.putInt32(u);var l={h0:e.h0,h1:e.h1,h2:e.h2,h3:e.h3,h4:e.h4,h5:e.h5,h6:e.h6,h7:e.h7};xc(l,r,i);var h=ke.util.createBuffer();return h.putInt32(l.h0),h.putInt32(l.h1),h.putInt32(l.h2),h.putInt32(l.h3),h.putInt32(l.h4),h.putInt32(l.h5),h.putInt32(l.h6),h.putInt32(l.h7),h},n};var mo=null,bc=!1,Ec=null;function Td(){mo="\x80",mo+=ke.util.fillString("\0",64),Ec=[1116352408,1899447441,3049323471,3921009573,961987163,1508970993,2453635748,2870763221,3624381080,310598401,607225278,1426881987,1925078388,2162078206,2614888103,3248222580,3835390401,4022224774,264347078,604807628,770255983,1249150122,1555081692,1996064986,2554220882,2821834349,2952996808,3210313671,3336571891,3584528711,113926993,338241895,666307205,773529912,1294757372,1396182291,1695183700,1986661051,2177026350,2456956037,2730485921,2820302411,3259730800,3345764771,3516065817,3600352804,4094571909,275423344,430227734,506948616,659060556,883997877,958139571,1322822218,1537002063,1747873779,1955562222,2024104815,2227730452,2361852424,2428436474,2756734187,3204031479,3329325298],bc=!0}function xc(e,t,r){for(var n,i,s,o,a,c,u,f,l,h,y,d,p,m,x,E=r.length();E>=64;){for(u=0;u<16;++u)t[u]=r.getInt32();for(;u<64;++u)n=t[u-2],n=(n>>>17|n<<15)^(n>>>19|n<<13)^n>>>10,i=t[u-15],i=(i>>>7|i<<25)^(i>>>18|i<<14)^i>>>3,t[u]=n+t[u-7]+i+t[u-16]|0;for(f=e.h0,l=e.h1,h=e.h2,y=e.h3,d=e.h4,p=e.h5,m=e.h6,x=e.h7,u=0;u<64;++u)o=(d>>>6|d<<26)^(d>>>11|d<<21)^(d>>>25|d<<7),a=m^d&(p^m),s=(f>>>2|f<<30)^(f>>>13|f<<19)^(f>>>22|f<<10),c=f&l|h&(f^l),n=x+o+a+Ec[u]+t[u],i=s+c,x=m,m=p,p=d,d=y+n>>>0,y=h,h=l,l=f,f=n+i>>>0;e.h0=e.h0+f|0,e.h1=e.h1+l|0,e.h2=e.h2+h|0,e.h3=e.h3+y|0,e.h4=e.h4+d|0,e.h5=e.h5+p|0,e.h6=e.h6+m|0,e.h7=e.h7+x|0,E-=64}}});var Tc=ot((v2,Ac)=>{var Ue=ht();Dt();var Si=null;Ue.util.isNodejs&&!Ue.options.usePureJavaScript&&!process.versions["node-webkit"]&&(Si=bi());var Bd=Ac.exports=Ue.prng=Ue.prng||{};Bd.create=function(e){for(var t={plugin:e,key:null,seed:null,time:null,reseeds:0,generated:0,keyBytes:""},r=e.md,n=new Array(32),i=0;i<32;++i)n[i]=r.create();t.pools=n,t.pool=0,t.generate=function(u,f){if(!f)return t.generateSync(u);var l=t.plugin.cipher,h=t.plugin.increment,y=t.plugin.formatKey,d=t.plugin.formatSeed,p=Ue.util.createBuffer();t.key=null,m();function m(x){if(x)return f(x);if(p.length()>=u)return f(null,p.getBytes(u));if(t.generated>1048575&&(t.key=null),t.key===null)return Ue.util.nextTick(function(){s(m)});var E=l(t.key,t.seed);t.generated+=E.length,p.putBytes(E),t.key=y(l(t.key,h(t.seed))),t.seed=d(l(t.key,t.seed)),Ue.util.setImmediate(m)}},t.generateSync=function(u){var f=t.plugin.cipher,l=t.plugin.increment,h=t.plugin.formatKey,y=t.plugin.formatSeed;t.key=null;for(var d=Ue.util.createBuffer();d.length()<u;){t.generated>1048575&&(t.key=null),t.key===null&&o();var p=f(t.key,t.seed);t.generated+=p.length,d.putBytes(p),t.key=h(f(t.key,l(t.seed))),t.seed=y(f(t.key,t.seed))}return d.getBytes(u)};function s(u){if(t.pools[0].messageLength>=32)return a(),u();var f=32-t.pools[0].messageLength<<5;t.seedFile(f,function(l,h){if(l)return u(l);t.collect(h),a(),u()})}function o(){if(t.pools[0].messageLength>=32)return a();var u=32-t.pools[0].messageLength<<5;t.collect(t.seedFileSync(u)),a()}function a(){t.reseeds=t.reseeds===4294967295?0:t.reseeds+1;var u=t.plugin.md.create();u.update(t.keyBytes);for(var f=1,l=0;l<32;++l)t.reseeds%f===0&&(u.update(t.pools[l].digest().getBytes()),t.pools[l].start()),f=f<<1;t.keyBytes=u.digest().getBytes(),u.start(),u.update(t.keyBytes);var h=u.digest().getBytes();t.key=t.plugin.formatKey(t.keyBytes),t.seed=t.plugin.formatSeed(h),t.generated=0}function c(u){var f=null,l=Ue.util.globalScope,h=l.crypto||l.msCrypto;h&&h.getRandomValues&&(f=function(w){return h.getRandomValues(w)});var y=Ue.util.createBuffer();if(f)for(;y.length()<u;){var d=Math.max(1,Math.min(u-y.length(),65536)/4),p=new Uint32Array(Math.floor(d));try{f(p);for(var m=0;m<p.length;++m)y.putInt32(p[m])}catch(w){if(!(typeof QuotaExceededError<"u"&&w instanceof QuotaExceededError))throw w}}if(y.length()<u)for(var x,E,b,R=Math.floor(Math.random()*65536);y.length()<u;){E=16807*(R&65535),x=16807*(R>>16),E+=(x&32767)<<16,E+=x>>15,E=(E&2147483647)+(E>>31),R=E&4294967295;for(var m=0;m<3;++m)b=R>>>(m<<3),b^=Math.floor(Math.random()*256),y.putByte(b&255)}return y.getBytes(u)}return Si?(t.seedFile=function(u,f){Si.randomBytes(u,function(l,h){if(l)return f(l);f(null,h.toString())})},t.seedFileSync=function(u){return Si.randomBytes(u).toString()}):(t.seedFile=function(u,f){try{f(null,c(u))}catch(l){f(l)}},t.seedFileSync=c),t.collect=function(u){for(var f=u.length,l=0;l<f;++l)t.pools[t.pool].update(u.substr(l,1)),t.pool=t.pool===31?0:t.pool+1},t.collectInt=function(u,f){for(var l="",h=0;h<f;h+=8)l+=String.fromCharCode(u>>h&255);t.collect(l)},t.registerWorker=function(u){if(u===self)t.seedFile=function(l,h){function y(d){var p=d.data;p.forge&&p.forge.prng&&(self.removeEventListener("message",y),h(p.forge.prng.err,p.forge.prng.bytes))}self.addEventListener("message",y),self.postMessage({forge:{prng:{needed:l}}})};else{var f=function(l){var h=l.data;h.forge&&h.forge.prng&&t.seedFile(h.forge.prng.needed,function(y,d){u.postMessage({forge:{prng:{err:y,bytes:d}}})})};u.addEventListener("message",f)}},t}});var On=ot((b2,go)=>{var qt=ht();yo();Sc();Tc();Dt();(function(){if(qt.random&&qt.random.getBytes){go.exports=qt.random;return}(function(e){var t={},r=new Array(4),n=qt.util.createBuffer();t.formatKey=function(l){var h=qt.util.createBuffer(l);return l=new Array(4),l[0]=h.getInt32(),l[1]=h.getInt32(),l[2]=h.getInt32(),l[3]=h.getInt32(),qt.aes._expandKey(l,!1)},t.formatSeed=function(l){var h=qt.util.createBuffer(l);return l=new Array(4),l[0]=h.getInt32(),l[1]=h.getInt32(),l[2]=h.getInt32(),l[3]=h.getInt32(),l},t.cipher=function(l,h){return qt.aes._updateBlock(l,h,r,!1),n.putInt32(r[0]),n.putInt32(r[1]),n.putInt32(r[2]),n.putInt32(r[3]),n.getBytes()},t.increment=function(l){return++l[3],l},t.md=qt.md.sha256;function i(){var l=qt.prng.create(t);return l.getBytes=function(h,y){return l.generate(h,y)},l.getBytesSync=function(h){return l.generate(h)},l}var s=i(),o=null,a=qt.util.globalScope,c=a.crypto||a.msCrypto;if(c&&c.getRandomValues&&(o=function(l){return c.getRandomValues(l)}),qt.options.usePureJavaScript||!qt.util.isNodejs&&!o){if(typeof window>"u"||window.document,s.collectInt(+new Date,32),typeof navigator<"u"){var u="";for(var f in navigator)try{typeof navigator[f]=="string"&&(u+=navigator[f])}catch{}s.collect(u),u=null}e&&(e().mousemove(function(l){s.collectInt(l.clientX,16),s.collectInt(l.clientY,16)}),e().keypress(function(l){s.collectInt(l.charCode,8)}))}if(!qt.random)qt.random=s;else for(var f in s)qt.random[f]=s[f];qt.random.createInstance=i,go.exports=qt.random})(typeof jQuery<"u"?jQuery:null)})()});var _c=ot((E2,Cc)=>{var oe=ht();Dt();var xo=[217,120,249,196,25,221,181,237,40,233,253,121,74,160,216,157,198,126,55,131,43,118,83,142,98,76,100,136,68,139,251,162,23,154,89,245,135,179,79,19,97,69,109,141,9,129,125,50,189,143,64,235,134,183,123,11,240,149,33,34,92,107,78,130,84,214,101,147,206,96,178,28,115,86,192,20,167,140,241,220,18,117,202,31,59,190,228,209,66,61,212,48,163,60,182,38,111,191,14,218,70,105,7,87,39,242,29,155,188,148,67,3,248,17,199,246,144,239,62,231,6,195,213,47,200,102,30,215,8,232,234,222,128,82,238,247,132,170,114,172,53,77,106,42,150,26,210,113,90,21,73,116,75,159,208,94,4,24,164,236,194,224,65,110,15,81,203,204,36,145,175,80,161,244,112,57,153,124,58,133,35,184,180,122,252,2,54,91,37,85,151,49,45,93,250,152,227,138,146,174,5,223,41,16,103,108,186,201,211,0,230,207,225,158,168,44,99,22,1,63,88,226,137,169,13,56,52,27,171,51,255,176,187,72,12,95,185,177,205,46,197,243,219,71,229,165,156,119,10,166,32,104,254,127,193,173],Bc=[1,2,3,5],Id=function(e,t){return e<<t&65535|(e&65535)>>16-t},Cd=function(e,t){return(e&65535)>>t|e<<16-t&65535};Cc.exports=oe.rc2=oe.rc2||{};oe.rc2.expandKey=function(e,t){typeof e=="string"&&(e=oe.util.createBuffer(e)),t=t||128;var r=e,n=e.length(),i=t,s=Math.ceil(i/8),o=255>>(i&7),a;for(a=n;a<128;a++)r.putByte(xo[r.at(a-1)+r.at(a-n)&255]);for(r.setAt(128-s,xo[r.at(128-s)&o]),a=127-s;a>=0;a--)r.setAt(a,xo[r.at(a+1)^r.at(a+s)]);return r};var Ic=function(e,t,r){var n=!1,i=null,s=null,o=null,a,c,u,f,l=[];for(e=oe.rc2.expandKey(e,t),u=0;u<64;u++)l.push(e.getInt16Le());r?(a=function(d){for(u=0;u<4;u++)d[u]+=l[f]+(d[(u+3)%4]&d[(u+2)%4])+(~d[(u+3)%4]&d[(u+1)%4]),d[u]=Id(d[u],Bc[u]),f++},c=function(d){for(u=0;u<4;u++)d[u]+=l[d[(u+3)%4]&63]}):(a=function(d){for(u=3;u>=0;u--)d[u]=Cd(d[u],Bc[u]),d[u]-=l[f]+(d[(u+3)%4]&d[(u+2)%4])+(~d[(u+3)%4]&d[(u+1)%4]),f--},c=function(d){for(u=3;u>=0;u--)d[u]-=l[d[(u+3)%4]&63]});var h=function(d){var p=[];for(u=0;u<4;u++){var m=i.getInt16Le();o!==null&&(r?m^=o.getInt16Le():o.putInt16Le(m)),p.push(m&65535)}f=r?0:63;for(var x=0;x<d.length;x++)for(var E=0;E<d[x][0];E++)d[x][1](p);for(u=0;u<4;u++)o!==null&&(r?o.putInt16Le(p[u]):p[u]^=o.getInt16Le()),s.putInt16Le(p[u])},y=null;return y={start:function(d,p){d&&typeof d=="string"&&(d=oe.util.createBuffer(d)),n=!1,i=oe.util.createBuffer(),s=p||new oe.util.createBuffer,o=d,y.output=s},update:function(d){for(n||i.putBuffer(d);i.length()>=8;)h([[5,a],[1,c],[6,a],[1,c],[5,a]])},finish:function(d){var p=!0;if(r)if(d)p=d(8,i,!r);else{var m=i.length()===8?8:8-i.length();i.fillWithByte(m,m)}if(p&&(n=!0,y.update()),!r&&(p=i.length()===0,p))if(d)p=d(8,s,!r);else{var x=s.length(),E=s.at(x-1);E>x?p=!1:s.truncate(E)}return p}},y};oe.rc2.startEncrypting=function(e,t,r){var n=oe.rc2.createEncryptionCipher(e,128);return n.start(t,r),n};oe.rc2.createEncryptionCipher=function(e,t){return Ic(e,t,!0)};oe.rc2.startDecrypting=function(e,t,r){var n=oe.rc2.createDecryptionCipher(e,128);return n.start(t,r),n};oe.rc2.createDecryptionCipher=function(e,t){return Ic(e,t,!1)}});var Bi=ot((w2,Oc)=>{var vo=ht();Oc.exports=vo.jsbn=vo.jsbn||{};var $e,_d=0xdeadbeefcafe,Rc=(_d&16777215)==15715070;function B(e,t,r){this.data=[],e!=null&&(typeof e=="number"?this.fromNumber(e,t,r):t==null&&typeof e!="string"?this.fromString(e,256):this.fromString(e,t))}vo.jsbn.BigInteger=B;function it(){return new B(null)}function Rd(e,t,r,n,i,s){for(;--s>=0;){var o=t*this.data[e++]+r.data[n]+i;i=Math.floor(o/67108864),r.data[n++]=o&67108863}return i}function Ld(e,t,r,n,i,s){for(var o=t&32767,a=t>>15;--s>=0;){var c=this.data[e]&32767,u=this.data[e++]>>15,f=a*c+u*o;c=o*c+((f&32767)<<15)+r.data[n]+(i&1073741823),i=(c>>>30)+(f>>>15)+a*u+(i>>>30),r.data[n++]=c&1073741823}return i}function Lc(e,t,r,n,i,s){for(var o=t&16383,a=t>>14;--s>=0;){var c=this.data[e]&16383,u=this.data[e++]>>14,f=a*c+u*o;c=o*c+((f&16383)<<14)+r.data[n]+i,i=(c>>28)+(f>>14)+a*u,r.data[n++]=c&268435455}return i}typeof navigator>"u"?(B.prototype.am=Lc,$e=28):Rc&&navigator.appName=="Microsoft Internet Explorer"?(B.prototype.am=Ld,$e=30):Rc&&navigator.appName!="Netscape"?(B.prototype.am=Rd,$e=26):(B.prototype.am=Lc,$e=28);B.prototype.DB=$e;B.prototype.DM=(1<<$e)-1;B.prototype.DV=1<<$e;var bo=52;B.prototype.FV=Math.pow(2,bo);B.prototype.F1=bo-$e;B.prototype.F2=2*$e-bo;var Dd="0123456789abcdefghijklmnopqrstuvwxyz",Ai=new Array,un,ge;un=48;for(ge=0;ge<=9;++ge)Ai[un++]=ge;un=97;for(ge=10;ge<36;++ge)Ai[un++]=ge;un=65;for(ge=10;ge<36;++ge)Ai[un++]=ge;function Dc(e){return Dd.charAt(e)}function Nc(e,t){var r=Ai[e.charCodeAt(t)];return r??-1}function Nd(e){for(var t=this.t-1;t>=0;--t)e.data[t]=this.data[t];e.t=this.t,e.s=this.s}function Pd(e){this.t=1,this.s=e<0?-1:0,e>0?this.data[0]=e:e<-1?this.data[0]=e+this.DV:this.t=0}function hr(e){var t=it();return t.fromInt(e),t}function kd(e,t){var r;if(t==16)r=4;else if(t==8)r=3;else if(t==256)r=8;else if(t==2)r=1;else if(t==32)r=5;else if(t==4)r=2;else{this.fromRadix(e,t);return}this.t=0,this.s=0;for(var n=e.length,i=!1,s=0;--n>=0;){var o=r==8?e[n]&255:Nc(e,n);if(o<0){e.charAt(n)=="-"&&(i=!0);continue}i=!1,s==0?this.data[this.t++]=o:s+r>this.DB?(this.data[this.t-1]|=(o&(1<<this.DB-s)-1)<<s,this.data[this.t++]=o>>this.DB-s):this.data[this.t-1]|=o<<s,s+=r,s>=this.DB&&(s-=this.DB)}r==8&&e[0]&128&&(this.s=-1,s>0&&(this.data[this.t-1]|=(1<<this.DB-s)-1<<s)),this.clamp(),i&&B.ZERO.subTo(this,this)}function Ud(){for(var e=this.s&this.DM;this.t>0&&this.data[this.t-1]==e;)--this.t}function Od(e){if(this.s<0)return"-"+this.negate().toString(e);var t;if(e==16)t=4;else if(e==8)t=3;else if(e==2)t=1;else if(e==32)t=5;else if(e==4)t=2;else return this.toRadix(e);var r=(1<<t)-1,n,i=!1,s="",o=this.t,a=this.DB-o*this.DB%t;if(o-- >0)for(a<this.DB&&(n=this.data[o]>>a)>0&&(i=!0,s=Dc(n));o>=0;)a<t?(n=(this.data[o]&(1<<a)-1)<<t-a,n|=this.data[--o]>>(a+=this.DB-t)):(n=this.data[o]>>(a-=t)&r,a<=0&&(a+=this.DB,--o)),n>0&&(i=!0),i&&(s+=Dc(n));return i?s:"0"}function Md(){var e=it();return B.ZERO.subTo(this,e),e}function Kd(){return this.s<0?this.negate():this}function Fd(e){var t=this.s-e.s;if(t!=0)return t;var r=this.t;if(t=r-e.t,t!=0)return this.s<0?-t:t;for(;--r>=0;)if((t=this.data[r]-e.data[r])!=0)return t;return 0}function Ti(e){var t=1,r;return(r=e>>>16)!=0&&(e=r,t+=16),(r=e>>8)!=0&&(e=r,t+=8),(r=e>>4)!=0&&(e=r,t+=4),(r=e>>2)!=0&&(e=r,t+=2),(r=e>>1)!=0&&(e=r,t+=1),t}function Vd(){return this.t<=0?0:this.DB*(this.t-1)+Ti(this.data[this.t-1]^this.s&this.DM)}function qd(e,t){var r;for(r=this.t-1;r>=0;--r)t.data[r+e]=this.data[r];for(r=e-1;r>=0;--r)t.data[r]=0;t.t=this.t+e,t.s=this.s}function Hd(e,t){for(var r=e;r<this.t;++r)t.data[r-e]=this.data[r];t.t=Math.max(this.t-e,0),t.s=this.s}function zd(e,t){var r=e%this.DB,n=this.DB-r,i=(1<<n)-1,s=Math.floor(e/this.DB),o=this.s<<r&this.DM,a;for(a=this.t-1;a>=0;--a)t.data[a+s+1]=this.data[a]>>n|o,o=(this.data[a]&i)<<r;for(a=s-1;a>=0;--a)t.data[a]=0;t.data[s]=o,t.t=this.t+s+1,t.s=this.s,t.clamp()}function Gd(e,t){t.s=this.s;var r=Math.floor(e/this.DB);if(r>=this.t){t.t=0;return}var n=e%this.DB,i=this.DB-n,s=(1<<n)-1;t.data[0]=this.data[r]>>n;for(var o=r+1;o<this.t;++o)t.data[o-r-1]|=(this.data[o]&s)<<i,t.data[o-r]=this.data[o]>>n;n>0&&(t.data[this.t-r-1]|=(this.s&s)<<i),t.t=this.t-r,t.clamp()}function Wd(e,t){for(var r=0,n=0,i=Math.min(e.t,this.t);r<i;)n+=this.data[r]-e.data[r],t.data[r++]=n&this.DM,n>>=this.DB;if(e.t<this.t){for(n-=e.s;r<this.t;)n+=this.data[r],t.data[r++]=n&this.DM,n>>=this.DB;n+=this.s}else{for(n+=this.s;r<e.t;)n-=e.data[r],t.data[r++]=n&this.DM,n>>=this.DB;n-=e.s}t.s=n<0?-1:0,n<-1?t.data[r++]=this.DV+n:n>0&&(t.data[r++]=n),t.t=r,t.clamp()}function Yd(e,t){var r=this.abs(),n=e.abs(),i=r.t;for(t.t=i+n.t;--i>=0;)t.data[i]=0;for(i=0;i<n.t;++i)t.data[i+r.t]=r.am(0,n.data[i],t,i,0,r.t);t.s=0,t.clamp(),this.s!=e.s&&B.ZERO.subTo(t,t)}function $d(e){for(var t=this.abs(),r=e.t=2*t.t;--r>=0;)e.data[r]=0;for(r=0;r<t.t-1;++r){var n=t.am(r,t.data[r],e,2*r,0,1);(e.data[r+t.t]+=t.am(r+1,2*t.data[r],e,2*r+1,n,t.t-r-1))>=t.DV&&(e.data[r+t.t]-=t.DV,e.data[r+t.t+1]=1)}e.t>0&&(e.data[e.t-1]+=t.am(r,t.data[r],e,2*r,0,1)),e.s=0,e.clamp()}function Qd(e,t,r){var n=e.abs();if(!(n.t<=0)){var i=this.abs();if(i.t<n.t){t?.fromInt(0),r!=null&&this.copyTo(r);return}r==null&&(r=it());var s=it(),o=this.s,a=e.s,c=this.DB-Ti(n.data[n.t-1]);c>0?(n.lShiftTo(c,s),i.lShiftTo(c,r)):(n.copyTo(s),i.copyTo(r));var u=s.t,f=s.data[u-1];if(f!=0){var l=f*(1<<this.F1)+(u>1?s.data[u-2]>>this.F2:0),h=this.FV/l,y=(1<<this.F1)/l,d=1<<this.F2,p=r.t,m=p-u,x=t??it();for(s.dlShiftTo(m,x),r.compareTo(x)>=0&&(r.data[r.t++]=1,r.subTo(x,r)),B.ONE.dlShiftTo(u,x),x.subTo(s,s);s.t<u;)s.data[s.t++]=0;for(;--m>=0;){var E=r.data[--p]==f?this.DM:Math.floor(r.data[p]*h+(r.data[p-1]+d)*y);if((r.data[p]+=s.am(0,E,r,m,0,u))<E)for(s.dlShiftTo(m,x),r.subTo(x,r);r.data[p]<--E;)r.subTo(x,r)}t!=null&&(r.drShiftTo(u,t),o!=a&&B.ZERO.subTo(t,t)),r.t=u,r.clamp(),c>0&&r.rShiftTo(c,r),o<0&&B.ZERO.subTo(r,r)}}}function Zd(e){var t=it();return this.abs().divRemTo(e,null,t),this.s<0&&t.compareTo(B.ZERO)>0&&e.subTo(t,t),t}function Dr(e){this.m=e}function Xd(e){return e.s<0||e.compareTo(this.m)>=0?e.mod(this.m):e}function Jd(e){return e}function jd(e){e.divRemTo(this.m,null,e)}function tp(e,t,r){e.multiplyTo(t,r),this.reduce(r)}function ep(e,t){e.squareTo(t),this.reduce(t)}Dr.prototype.convert=Xd;Dr.prototype.revert=Jd;Dr.prototype.reduce=jd;Dr.prototype.mulTo=tp;Dr.prototype.sqrTo=ep;function rp(){if(this.t<1)return 0;var e=this.data[0];if(!(e&1))return 0;var t=e&3;return t=t*(2-(e&15)*t)&15,t=t*(2-(e&255)*t)&255,t=t*(2-((e&65535)*t&65535))&65535,t=t*(2-e*t%this.DV)%this.DV,t>0?this.DV-t:-t}function Nr(e){this.m=e,this.mp=e.invDigit(),this.mpl=this.mp&32767,this.mph=this.mp>>15,this.um=(1<<e.DB-15)-1,this.mt2=2*e.t}function np(e){var t=it();return e.abs().dlShiftTo(this.m.t,t),t.divRemTo(this.m,null,t),e.s<0&&t.compareTo(B.ZERO)>0&&this.m.subTo(t,t),t}function ip(e){var t=it();return e.copyTo(t),this.reduce(t),t}function sp(e){for(;e.t<=this.mt2;)e.data[e.t++]=0;for(var t=0;t<this.m.t;++t){var r=e.data[t]&32767,n=r*this.mpl+((r*this.mph+(e.data[t]>>15)*this.mpl&this.um)<<15)&e.DM;for(r=t+this.m.t,e.data[r]+=this.m.am(0,n,e,t,0,this.m.t);e.data[r]>=e.DV;)e.data[r]-=e.DV,e.data[++r]++}e.clamp(),e.drShiftTo(this.m.t,e),e.compareTo(this.m)>=0&&e.subTo(this.m,e)}function op(e,t){e.squareTo(t),this.reduce(t)}function ap(e,t,r){e.multiplyTo(t,r),this.reduce(r)}Nr.prototype.convert=np;Nr.prototype.revert=ip;Nr.prototype.reduce=sp;Nr.prototype.mulTo=ap;Nr.prototype.sqrTo=op;function cp(){return(this.t>0?this.data[0]&1:this.s)==0}function up(e,t){if(e>4294967295||e<1)return B.ONE;var r=it(),n=it(),i=t.convert(this),s=Ti(e)-1;for(i.copyTo(r);--s>=0;)if(t.sqrTo(r,n),(e&1<<s)>0)t.mulTo(n,i,r);else{var o=r;r=n,n=o}return t.revert(r)}function fp(e,t){var r;return e<256||t.isEven()?r=new Dr(t):r=new Nr(t),this.exp(e,r)}B.prototype.copyTo=Nd;B.prototype.fromInt=Pd;B.prototype.fromString=kd;B.prototype.clamp=Ud;B.prototype.dlShiftTo=qd;B.prototype.drShiftTo=Hd;B.prototype.lShiftTo=zd;B.prototype.rShiftTo=Gd;B.prototype.subTo=Wd;B.prototype.multiplyTo=Yd;B.prototype.squareTo=$d;B.prototype.divRemTo=Qd;B.prototype.invDigit=rp;B.prototype.isEven=cp;B.prototype.exp=up;B.prototype.toString=Od;B.prototype.negate=Md;B.prototype.abs=Kd;B.prototype.compareTo=Fd;B.prototype.bitLength=Vd;B.prototype.mod=Zd;B.prototype.modPowInt=fp;B.ZERO=hr(0);B.ONE=hr(1);function lp(){var e=it();return this.copyTo(e),e}function hp(){if(this.s<0){if(this.t==1)return this.data[0]-this.DV;if(this.t==0)return-1}else{if(this.t==1)return this.data[0];if(this.t==0)return 0}return(this.data[1]&(1<<32-this.DB)-1)<<this.DB|this.data[0]}function dp(){return this.t==0?this.s:this.data[0]<<24>>24}function pp(){return this.t==0?this.s:this.data[0]<<16>>16}function yp(e){return Math.floor(Math.LN2*this.DB/Math.log(e))}function mp(){return this.s<0?-1:this.t<=0||this.t==1&&this.data[0]<=0?0:1}function gp(e){if(e==null&&(e=10),this.signum()==0||e<2||e>36)return"0";var t=this.chunkSize(e),r=Math.pow(e,t),n=hr(r),i=it(),s=it(),o="";for(this.divRemTo(n,i,s);i.signum()>0;)o=(r+s.intValue()).toString(e).substr(1)+o,i.divRemTo(n,i,s);return s.intValue().toString(e)+o}function xp(e,t){this.fromInt(0),t==null&&(t=10);for(var r=this.chunkSize(t),n=Math.pow(t,r),i=!1,s=0,o=0,a=0;a<e.length;++a){var c=Nc(e,a);if(c<0){e.charAt(a)=="-"&&this.signum()==0&&(i=!0);continue}o=t*o+c,++s>=r&&(this.dMultiply(n),this.dAddOffset(o,0),s=0,o=0)}s>0&&(this.dMultiply(Math.pow(t,s)),this.dAddOffset(o,0)),i&&B.ZERO.subTo(this,this)}function vp(e,t,r){if(typeof t=="number")if(e<2)this.fromInt(1);else for(this.fromNumber(e,r),this.testBit(e-1)||this.bitwiseTo(B.ONE.shiftLeft(e-1),Eo,this),this.isEven()&&this.dAddOffset(1,0);!this.isProbablePrime(t);)this.dAddOffset(2,0),this.bitLength()>e&&this.subTo(B.ONE.shiftLeft(e-1),this);else{var n=new Array,i=e&7;n.length=(e>>3)+1,t.nextBytes(n),i>0?n[0]&=(1<<i)-1:n[0]=0,this.fromString(n,256)}}function bp(){var e=this.t,t=new Array;t[0]=this.s;var r=this.DB-e*this.DB%8,n,i=0;if(e-- >0)for(r<this.DB&&(n=this.data[e]>>r)!=(this.s&this.DM)>>r&&(t[i++]=n|this.s<<this.DB-r);e>=0;)r<8?(n=(this.data[e]&(1<<r)-1)<<8-r,n|=this.data[--e]>>(r+=this.DB-8)):(n=this.data[e]>>(r-=8)&255,r<=0&&(r+=this.DB,--e)),n&128&&(n|=-256),i==0&&(this.s&128)!=(n&128)&&++i,(i>0||n!=this.s)&&(t[i++]=n);return t}function Ep(e){return this.compareTo(e)==0}function wp(e){return this.compareTo(e)<0?this:e}function Sp(e){return this.compareTo(e)>0?this:e}function Ap(e,t,r){var n,i,s=Math.min(e.t,this.t);for(n=0;n<s;++n)r.data[n]=t(this.data[n],e.data[n]);if(e.t<this.t){for(i=e.s&this.DM,n=s;n<this.t;++n)r.data[n]=t(this.data[n],i);r.t=this.t}else{for(i=this.s&this.DM,n=s;n<e.t;++n)r.data[n]=t(i,e.data[n]);r.t=e.t}r.s=t(this.s,e.s),r.clamp()}function Tp(e,t){return e&t}function Bp(e){var t=it();return this.bitwiseTo(e,Tp,t),t}function Eo(e,t){return e|t}function Ip(e){var t=it();return this.bitwiseTo(e,Eo,t),t}function Pc(e,t){return e^t}function Cp(e){var t=it();return this.bitwiseTo(e,Pc,t),t}function kc(e,t){return e&~t}function _p(e){var t=it();return this.bitwiseTo(e,kc,t),t}function Rp(){for(var e=it(),t=0;t<this.t;++t)e.data[t]=this.DM&~this.data[t];return e.t=this.t,e.s=~this.s,e}function Lp(e){var t=it();return e<0?this.rShiftTo(-e,t):this.lShiftTo(e,t),t}function Dp(e){var t=it();return e<0?this.lShiftTo(-e,t):this.rShiftTo(e,t),t}function Np(e){if(e==0)return-1;var t=0;return e&65535||(e>>=16,t+=16),e&255||(e>>=8,t+=8),e&15||(e>>=4,t+=4),e&3||(e>>=2,t+=2),e&1||++t,t}function Pp(){for(var e=0;e<this.t;++e)if(this.data[e]!=0)return e*this.DB+Np(this.data[e]);return this.s<0?this.t*this.DB:-1}function kp(e){for(var t=0;e!=0;)e&=e-1,++t;return t}function Up(){for(var e=0,t=this.s&this.DM,r=0;r<this.t;++r)e+=kp(this.data[r]^t);return e}function Op(e){var t=Math.floor(e/this.DB);return t>=this.t?this.s!=0:(this.data[t]&1<<e%this.DB)!=0}function Mp(e,t){var r=B.ONE.shiftLeft(e);return this.bitwiseTo(r,t,r),r}function Kp(e){return this.changeBit(e,Eo)}function Fp(e){return this.changeBit(e,kc)}function Vp(e){return this.changeBit(e,Pc)}function qp(e,t){for(var r=0,n=0,i=Math.min(e.t,this.t);r<i;)n+=this.data[r]+e.data[r],t.data[r++]=n&this.DM,n>>=this.DB;if(e.t<this.t){for(n+=e.s;r<this.t;)n+=this.data[r],t.data[r++]=n&this.DM,n>>=this.DB;n+=this.s}else{for(n+=this.s;r<e.t;)n+=e.data[r],t.data[r++]=n&this.DM,n>>=this.DB;n+=e.s}t.s=n<0?-1:0,n>0?t.data[r++]=n:n<-1&&(t.data[r++]=this.DV+n),t.t=r,t.clamp()}function Hp(e){var t=it();return this.addTo(e,t),t}function zp(e){var t=it();return this.subTo(e,t),t}function Gp(e){var t=it();return this.multiplyTo(e,t),t}function Wp(e){var t=it();return this.divRemTo(e,t,null),t}function Yp(e){var t=it();return this.divRemTo(e,null,t),t}function $p(e){var t=it(),r=it();return this.divRemTo(e,t,r),new Array(t,r)}function Qp(e){this.data[this.t]=this.am(0,e-1,this,0,0,this.t),++this.t,this.clamp()}function Zp(e,t){if(e!=0){for(;this.t<=t;)this.data[this.t++]=0;for(this.data[t]+=e;this.data[t]>=this.DV;)this.data[t]-=this.DV,++t>=this.t&&(this.data[this.t++]=0),++this.data[t]}}function Mn(){}function Uc(e){return e}function Xp(e,t,r){e.multiplyTo(t,r)}function Jp(e,t){e.squareTo(t)}Mn.prototype.convert=Uc;Mn.prototype.revert=Uc;Mn.prototype.mulTo=Xp;Mn.prototype.sqrTo=Jp;function jp(e){return this.exp(e,new Mn)}function ty(e,t,r){var n=Math.min(this.t+e.t,t);for(r.s=0,r.t=n;n>0;)r.data[--n]=0;var i;for(i=r.t-this.t;n<i;++n)r.data[n+this.t]=this.am(0,e.data[n],r,n,0,this.t);for(i=Math.min(e.t,t);n<i;++n)this.am(0,e.data[n],r,n,0,t-n);r.clamp()}function ey(e,t,r){--t;var n=r.t=this.t+e.t-t;for(r.s=0;--n>=0;)r.data[n]=0;for(n=Math.max(t-this.t,0);n<e.t;++n)r.data[this.t+n-t]=this.am(t-n,e.data[n],r,0,0,this.t+n-t);r.clamp(),r.drShiftTo(1,r)}function fn(e){this.r2=it(),this.q3=it(),B.ONE.dlShiftTo(2*e.t,this.r2),this.mu=this.r2.divide(e),this.m=e}function ry(e){if(e.s<0||e.t>2*this.m.t)return e.mod(this.m);if(e.compareTo(this.m)<0)return e;var t=it();return e.copyTo(t),this.reduce(t),t}function ny(e){return e}function iy(e){for(e.drShiftTo(this.m.t-1,this.r2),e.t>this.m.t+1&&(e.t=this.m.t+1,e.clamp()),this.mu.multiplyUpperTo(this.r2,this.m.t+1,this.q3),this.m.multiplyLowerTo(this.q3,this.m.t+1,this.r2);e.compareTo(this.r2)<0;)e.dAddOffset(1,this.m.t+1);for(e.subTo(this.r2,e);e.compareTo(this.m)>=0;)e.subTo(this.m,e)}function sy(e,t){e.squareTo(t),this.reduce(t)}function oy(e,t,r){e.multiplyTo(t,r),this.reduce(r)}fn.prototype.convert=ry;fn.prototype.revert=ny;fn.prototype.reduce=iy;fn.prototype.mulTo=oy;fn.prototype.sqrTo=sy;function ay(e,t){var r=e.bitLength(),n,i=hr(1),s;if(r<=0)return i;r<18?n=1:r<48?n=3:r<144?n=4:r<768?n=5:n=6,r<8?s=new Dr(t):t.isEven()?s=new fn(t):s=new Nr(t);var o=new Array,a=3,c=n-1,u=(1<<n)-1;if(o[1]=s.convert(this),n>1){var f=it();for(s.sqrTo(o[1],f);a<=u;)o[a]=it(),s.mulTo(f,o[a-2],o[a]),a+=2}var l=e.t-1,h,y=!0,d=it(),p;for(r=Ti(e.data[l])-1;l>=0;){for(r>=c?h=e.data[l]>>r-c&u:(h=(e.data[l]&(1<<r+1)-1)<<c-r,l>0&&(h|=e.data[l-1]>>this.DB+r-c)),a=n;!(h&1);)h>>=1,--a;if((r-=a)<0&&(r+=this.DB,--l),y)o[h].copyTo(i),y=!1;else{for(;a>1;)s.sqrTo(i,d),s.sqrTo(d,i),a-=2;a>0?s.sqrTo(i,d):(p=i,i=d,d=p),s.mulTo(d,o[h],i)}for(;l>=0&&!(e.data[l]&1<<r);)s.sqrTo(i,d),p=i,i=d,d=p,--r<0&&(r=this.DB-1,--l)}return s.revert(i)}function cy(e){var t=this.s<0?this.negate():this.clone(),r=e.s<0?e.negate():e.clone();if(t.compareTo(r)<0){var n=t;t=r,r=n}var i=t.getLowestSetBit(),s=r.getLowestSetBit();if(s<0)return t;for(i<s&&(s=i),s>0&&(t.rShiftTo(s,t),r.rShiftTo(s,r));t.signum()>0;)(i=t.getLowestSetBit())>0&&t.rShiftTo(i,t),(i=r.getLowestSetBit())>0&&r.rShiftTo(i,r),t.compareTo(r)>=0?(t.subTo(r,t),t.rShiftTo(1,t)):(r.subTo(t,r),r.rShiftTo(1,r));return s>0&&r.lShiftTo(s,r),r}function uy(e){if(e<=0)return 0;var t=this.DV%e,r=this.s<0?e-1:0;if(this.t>0)if(t==0)r=this.data[0]%e;else for(var n=this.t-1;n>=0;--n)r=(t*r+this.data[n])%e;return r}function fy(e){var t=e.isEven();if(this.isEven()&&t||e.signum()==0)return B.ZERO;for(var r=e.clone(),n=this.clone(),i=hr(1),s=hr(0),o=hr(0),a=hr(1);r.signum()!=0;){for(;r.isEven();)r.rShiftTo(1,r),t?((!i.isEven()||!s.isEven())&&(i.addTo(this,i),s.subTo(e,s)),i.rShiftTo(1,i)):s.isEven()||s.subTo(e,s),s.rShiftTo(1,s);for(;n.isEven();)n.rShiftTo(1,n),t?((!o.isEven()||!a.isEven())&&(o.addTo(this,o),a.subTo(e,a)),o.rShiftTo(1,o)):a.isEven()||a.subTo(e,a),a.rShiftTo(1,a);r.compareTo(n)>=0?(r.subTo(n,r),t&&i.subTo(o,i),s.subTo(a,s)):(n.subTo(r,n),t&&o.subTo(i,o),a.subTo(s,a))}if(n.compareTo(B.ONE)!=0)return B.ZERO;if(a.compareTo(e)>=0)return a.subtract(e);if(a.signum()<0)a.addTo(e,a);else return a;return a.signum()<0?a.add(e):a}var Te=[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],ly=(1<<26)/Te[Te.length-1];function hy(e){var t,r=this.abs();if(r.t==1&&r.data[0]<=Te[Te.length-1]){for(t=0;t<Te.length;++t)if(r.data[0]==Te[t])return!0;return!1}if(r.isEven())return!1;for(t=1;t<Te.length;){for(var n=Te[t],i=t+1;i<Te.length&&n<ly;)n*=Te[i++];for(n=r.modInt(n);t<i;)if(n%Te[t++]==0)return!1}return r.millerRabin(e)}function dy(e){var t=this.subtract(B.ONE),r=t.getLowestSetBit();if(r<=0)return!1;for(var n=t.shiftRight(r),i=py(),s,o=0;o<e;++o){do s=new B(this.bitLength(),i);while(s.compareTo(B.ONE)<=0||s.compareTo(t)>=0);var a=s.modPow(n,this);if(a.compareTo(B.ONE)!=0&&a.compareTo(t)!=0){for(var c=1;c++<r&&a.compareTo(t)!=0;)if(a=a.modPowInt(2,this),a.compareTo(B.ONE)==0)return!1;if(a.compareTo(t)!=0)return!1}}return!0}function py(){return{nextBytes:function(e){for(var t=0;t<e.length;++t)e[t]=Math.floor(Math.random()*256)}}}B.prototype.chunkSize=yp;B.prototype.toRadix=gp;B.prototype.fromRadix=xp;B.prototype.fromNumber=vp;B.prototype.bitwiseTo=Ap;B.prototype.changeBit=Mp;B.prototype.addTo=qp;B.prototype.dMultiply=Qp;B.prototype.dAddOffset=Zp;B.prototype.multiplyLowerTo=ty;B.prototype.multiplyUpperTo=ey;B.prototype.modInt=uy;B.prototype.millerRabin=dy;B.prototype.clone=lp;B.prototype.intValue=hp;B.prototype.byteValue=dp;B.prototype.shortValue=pp;B.prototype.signum=mp;B.prototype.toByteArray=bp;B.prototype.equals=Ep;B.prototype.min=wp;B.prototype.max=Sp;B.prototype.and=Bp;B.prototype.or=Ip;B.prototype.xor=Cp;B.prototype.andNot=_p;B.prototype.not=Rp;B.prototype.shiftLeft=Lp;B.prototype.shiftRight=Dp;B.prototype.getLowestSetBit=Pp;B.prototype.bitCount=Up;B.prototype.testBit=Op;B.prototype.setBit=Kp;B.prototype.clearBit=Fp;B.prototype.flipBit=Vp;B.prototype.add=Hp;B.prototype.subtract=zp;B.prototype.multiply=Gp;B.prototype.divide=Wp;B.prototype.remainder=Yp;B.prototype.divideAndRemainder=$p;B.prototype.modPow=ay;B.prototype.modInverse=fy;B.prototype.pow=jp;B.prototype.gcd=cy;B.prototype.isProbablePrime=hy});var qc=ot((S2,Vc)=>{var Oe=ht();Lr();Dt();var Kc=Vc.exports=Oe.sha1=Oe.sha1||{};Oe.md.sha1=Oe.md.algorithms.sha1=Kc;Kc.create=function(){Fc||yy();var e=null,t=Oe.util.createBuffer(),r=new Array(80),n={algorithm:"sha1",blockLength:64,digestLength:20,messageLength:0,fullMessageLength:null,messageLengthSize:8};return n.start=function(){n.messageLength=0,n.fullMessageLength=n.messageLength64=[];for(var i=n.messageLengthSize/4,s=0;s<i;++s)n.fullMessageLength.push(0);return t=Oe.util.createBuffer(),e={h0:1732584193,h1:4023233417,h2:2562383102,h3:271733878,h4:3285377520},n},n.start(),n.update=function(i,s){s==="utf8"&&(i=Oe.util.encodeUtf8(i));var o=i.length;n.messageLength+=o,o=[o/4294967296>>>0,o>>>0];for(var a=n.fullMessageLength.length-1;a>=0;--a)n.fullMessageLength[a]+=o[1],o[1]=o[0]+(n.fullMessageLength[a]/4294967296>>>0),n.fullMessageLength[a]=n.fullMessageLength[a]>>>0,o[0]=o[1]/4294967296>>>0;return t.putBytes(i),Mc(e,r,t),(t.read>2048||t.length()===0)&&t.compact(),n},n.digest=function(){var i=Oe.util.createBuffer();i.putBytes(t.bytes());var s=n.fullMessageLength[n.fullMessageLength.length-1]+n.messageLengthSize,o=s&n.blockLength-1;i.putBytes(wo.substr(0,n.blockLength-o));for(var a,c,u=n.fullMessageLength[0]*8,f=0;f<n.fullMessageLength.length-1;++f)a=n.fullMessageLength[f+1]*8,c=a/4294967296>>>0,u+=c,i.putInt32(u>>>0),u=a>>>0;i.putInt32(u);var l={h0:e.h0,h1:e.h1,h2:e.h2,h3:e.h3,h4:e.h4};Mc(l,r,i);var h=Oe.util.createBuffer();return h.putInt32(l.h0),h.putInt32(l.h1),h.putInt32(l.h2),h.putInt32(l.h3),h.putInt32(l.h4),h},n};var wo=null,Fc=!1;function yy(){wo="\x80",wo+=Oe.util.fillString("\0",64),Fc=!0}function Mc(e,t,r){for(var n,i,s,o,a,c,u,f,l=r.length();l>=64;){for(i=e.h0,s=e.h1,o=e.h2,a=e.h3,c=e.h4,f=0;f<16;++f)n=r.getInt32(),t[f]=n,u=a^s&(o^a),n=(i<<5|i>>>27)+u+c+1518500249+n,c=a,a=o,o=(s<<30|s>>>2)>>>0,s=i,i=n;for(;f<20;++f)n=t[f-3]^t[f-8]^t[f-14]^t[f-16],n=n<<1|n>>>31,t[f]=n,u=a^s&(o^a),n=(i<<5|i>>>27)+u+c+1518500249+n,c=a,a=o,o=(s<<30|s>>>2)>>>0,s=i,i=n;for(;f<32;++f)n=t[f-3]^t[f-8]^t[f-14]^t[f-16],n=n<<1|n>>>31,t[f]=n,u=s^o^a,n=(i<<5|i>>>27)+u+c+1859775393+n,c=a,a=o,o=(s<<30|s>>>2)>>>0,s=i,i=n;for(;f<40;++f)n=t[f-6]^t[f-16]^t[f-28]^t[f-32],n=n<<2|n>>>30,t[f]=n,u=s^o^a,n=(i<<5|i>>>27)+u+c+1859775393+n,c=a,a=o,o=(s<<30|s>>>2)>>>0,s=i,i=n;for(;f<60;++f)n=t[f-6]^t[f-16]^t[f-28]^t[f-32],n=n<<2|n>>>30,t[f]=n,u=s&o|a&(s^o),n=(i<<5|i>>>27)+u+c+2400959708+n,c=a,a=o,o=(s<<30|s>>>2)>>>0,s=i,i=n;for(;f<80;++f)n=t[f-6]^t[f-16]^t[f-28]^t[f-32],n=n<<2|n>>>30,t[f]=n,u=s^o^a,n=(i<<5|i>>>27)+u+c+3395469782+n,c=a,a=o,o=(s<<30|s>>>2)>>>0,s=i,i=n;e.h0=e.h0+i|0,e.h1=e.h1+s|0,e.h2=e.h2+o|0,e.h3=e.h3+a|0,e.h4=e.h4+c|0,l-=64}}});var Gc=ot((A2,zc)=>{var Me=ht();Dt();On();qc();var Hc=zc.exports=Me.pkcs1=Me.pkcs1||{};Hc.encode_rsa_oaep=function(e,t,r){var n,i,s,o;typeof r=="string"?(n=r,i=arguments[3]||void 0,s=arguments[4]||void 0):r&&(n=r.label||void 0,i=r.seed||void 0,s=r.md||void 0,r.mgf1&&r.mgf1.md&&(o=r.mgf1.md)),s?s.start():s=Me.md.sha1.create(),o||(o=s);var a=Math.ceil(e.n.bitLength()/8),c=a-2*s.digestLength-2;if(t.length>c){var u=new Error("RSAES-OAEP input message length is too long.");throw u.length=t.length,u.maxLength=c,u}n||(n=""),s.update(n,"raw");for(var f=s.digest(),l="",h=c-t.length,y=0;y<h;y++)l+="\0";var d=f.getBytes()+l+""+t;if(!i)i=Me.random.getBytes(s.digestLength);else if(i.length!==s.digestLength){var u=new Error("Invalid RSAES-OAEP seed. The seed length must match the digest length.");throw u.seedLength=i.length,u.digestLength=s.digestLength,u}var p=Ii(i,a-s.digestLength-1,o),m=Me.util.xorBytes(d,p,d.length),x=Ii(m,s.digestLength,o),E=Me.util.xorBytes(i,x,i.length);return"\0"+E+m};Hc.decode_rsa_oaep=function(e,t,r){var n,i,s;typeof r=="string"?(n=r,i=arguments[3]||void 0):r&&(n=r.label||void 0,i=r.md||void 0,r.mgf1&&r.mgf1.md&&(s=r.mgf1.md));var o=Math.ceil(e.n.bitLength()/8);if(t.length!==o){var m=new Error("RSAES-OAEP encoded message length is invalid.");throw m.length=t.length,m.expectedLength=o,m}if(i===void 0?i=Me.md.sha1.create():i.start(),s||(s=i),o<2*i.digestLength+2)throw new Error("RSAES-OAEP key is too short for the hash function.");n||(n=""),i.update(n,"raw");for(var a=i.digest().getBytes(),c=t.charAt(0),u=t.substring(1,i.digestLength+1),f=t.substring(1+i.digestLength),l=Ii(f,i.digestLength,s),h=Me.util.xorBytes(u,l,u.length),y=Ii(h,o-i.digestLength-1,s),d=Me.util.xorBytes(f,y,f.length),p=d.substring(0,i.digestLength),m=c!=="\0",x=0;x<i.digestLength;++x)m|=a.charAt(x)!==p.charAt(x);for(var E=1,b=i.digestLength,R=i.digestLength;R<d.length;R++){var w=d.charCodeAt(R),S=w&1^1,L=E?65534:0;m|=w&L,E=E&S,b+=E}if(m||d.charCodeAt(b)!==1)throw new Error("Invalid RSAES-OAEP padding.");return d.substring(b+1)};function Ii(e,t,r){r||(r=Me.md.sha1.create());for(var n="",i=Math.ceil(t/r.digestLength),s=0;s<i;++s){var o=String.fromCharCode(s>>24&255,s>>16&255,s>>8&255,s&255);r.start(),r.update(e+o),n+=r.digest().getBytes()}return n.substring(0,t)}});var Wc=ot((T2,So)=>{var dr=ht();Dt();Bi();On();(function(){if(dr.prime){So.exports=dr.prime;return}var e=So.exports=dr.prime=dr.prime||{},t=dr.jsbn.BigInteger,r=[6,4,2,4,2,4,6,2],n=new t(null);n.fromInt(30);var i=function(l,h){return l|h};e.generateProbablePrime=function(l,h,y){typeof h=="function"&&(y=h,h={}),h=h||{};var d=h.algorithm||"PRIMEINC";typeof d=="string"&&(d={name:d}),d.options=d.options||{};var p=h.prng||dr.random,m={nextBytes:function(x){for(var E=p.getBytesSync(x.length),b=0;b<x.length;++b)x[b]=E.charCodeAt(b)}};if(d.name==="PRIMEINC")return s(l,m,d.options,y);throw new Error("Invalid prime generation algorithm: "+d.name)};function s(l,h,y,d){return"workers"in y?c(l,h,y,d):o(l,h,y,d)}function o(l,h,y,d){var p=u(l,h),m=0,x=f(p.bitLength());"millerRabinTests"in y&&(x=y.millerRabinTests);var E=10;"maxBlockTime"in y&&(E=y.maxBlockTime),a(p,l,h,m,x,E,d)}function a(l,h,y,d,p,m,x){var E=+new Date;do{if(l.bitLength()>h&&(l=u(h,y)),l.isProbablePrime(p))return x(null,l);l.dAddOffset(r[d++%8],0)}while(m<0||+new Date-E<m);dr.util.setImmediate(function(){a(l,h,y,d,p,m,x)})}function c(l,h,y,d){if(typeof Worker>"u")return o(l,h,y,d);var p=u(l,h),m=y.workers,x=y.workLoad||100,E=x*30/8,b=y.workerScript||"forge/prime.worker.js";if(m===-1)return dr.util.estimateCores(function(w,S){w&&(S=2),m=S-1,R()});R();function R(){m=Math.max(1,m);for(var w=[],S=0;S<m;++S)w[S]=new Worker(b);for(var L=m,S=0;S<m;++S)w[S].addEventListener("message",Y);var D=!1;function Y(W){if(!D){--L;var q=W.data;if(q.found){for(var j=0;j<w.length;++j)w[j].terminate();return D=!0,d(null,new t(q.prime,16))}p.bitLength()>l&&(p=u(l,h));var lt=p.toString(16);W.target.postMessage({hex:lt,workLoad:x}),p.dAddOffset(E,0)}}}}function u(l,h){var y=new t(l,h),d=l-1;return y.testBit(d)||y.bitwiseTo(t.ONE.shiftLeft(d),i,y),y.dAddOffset(31-y.mod(n).byteValue(),0),y}function f(l){return l<=100?27:l<=150?18:l<=200?15:l<=250?12:l<=300?9:l<=350?8:l<=400?7:l<=500?6:l<=600?5:l<=800?4:l<=1250?3:2}})()});var _i=ot((B2,jc)=>{var V=ht();Un();Bi();di();Gc();Wc();On();Dt();typeof nt>"u"&&(nt=V.jsbn.BigInteger);var nt,Ao=V.util.isNodejs?bi():null,v=V.asn1,xe=V.util;V.pki=V.pki||{};jc.exports=V.pki.rsa=V.rsa=V.rsa||{};var $=V.pki,my=[6,4,2,4,2,4,6,2],gy={name:"PrivateKeyInfo",tagClass:v.Class.UNIVERSAL,type:v.Type.SEQUENCE,constructed:!0,value:[{name:"PrivateKeyInfo.version",tagClass:v.Class.UNIVERSAL,type:v.Type.INTEGER,constructed:!1,capture:"privateKeyVersion"},{name:"PrivateKeyInfo.privateKeyAlgorithm",tagClass:v.Class.UNIVERSAL,type:v.Type.SEQUENCE,constructed:!0,value:[{name:"AlgorithmIdentifier.algorithm",tagClass:v.Class.UNIVERSAL,type:v.Type.OID,constructed:!1,capture:"privateKeyOid"}]},{name:"PrivateKeyInfo",tagClass:v.Class.UNIVERSAL,type:v.Type.OCTETSTRING,constructed:!1,capture:"privateKey"}]},xy={name:"RSAPrivateKey",tagClass:v.Class.UNIVERSAL,type:v.Type.SEQUENCE,constructed:!0,value:[{name:"RSAPrivateKey.version",tagClass:v.Class.UNIVERSAL,type:v.Type.INTEGER,constructed:!1,capture:"privateKeyVersion"},{name:"RSAPrivateKey.modulus",tagClass:v.Class.UNIVERSAL,type:v.Type.INTEGER,constructed:!1,capture:"privateKeyModulus"},{name:"RSAPrivateKey.publicExponent",tagClass:v.Class.UNIVERSAL,type:v.Type.INTEGER,constructed:!1,capture:"privateKeyPublicExponent"},{name:"RSAPrivateKey.privateExponent",tagClass:v.Class.UNIVERSAL,type:v.Type.INTEGER,constructed:!1,capture:"privateKeyPrivateExponent"},{name:"RSAPrivateKey.prime1",tagClass:v.Class.UNIVERSAL,type:v.Type.INTEGER,constructed:!1,capture:"privateKeyPrime1"},{name:"RSAPrivateKey.prime2",tagClass:v.Class.UNIVERSAL,type:v.Type.INTEGER,constructed:!1,capture:"privateKeyPrime2"},{name:"RSAPrivateKey.exponent1",tagClass:v.Class.UNIVERSAL,type:v.Type.INTEGER,constructed:!1,capture:"privateKeyExponent1"},{name:"RSAPrivateKey.exponent2",tagClass:v.Class.UNIVERSAL,type:v.Type.INTEGER,constructed:!1,capture:"privateKeyExponent2"},{name:"RSAPrivateKey.coefficient",tagClass:v.Class.UNIVERSAL,type:v.Type.INTEGER,constructed:!1,capture:"privateKeyCoefficient"}]},vy={name:"RSAPublicKey",tagClass:v.Class.UNIVERSAL,type:v.Type.SEQUENCE,constructed:!0,value:[{name:"RSAPublicKey.modulus",tagClass:v.Class.UNIVERSAL,type:v.Type.INTEGER,constructed:!1,capture:"publicKeyModulus"},{name:"RSAPublicKey.exponent",tagClass:v.Class.UNIVERSAL,type:v.Type.INTEGER,constructed:!1,capture:"publicKeyExponent"}]},by=V.pki.rsa.publicKeyValidator={name:"SubjectPublicKeyInfo",tagClass:v.Class.UNIVERSAL,type:v.Type.SEQUENCE,constructed:!0,captureAsn1:"subjectPublicKeyInfo",value:[{name:"SubjectPublicKeyInfo.AlgorithmIdentifier",tagClass:v.Class.UNIVERSAL,type:v.Type.SEQUENCE,constructed:!0,value:[{name:"AlgorithmIdentifier.algorithm",tagClass:v.Class.UNIVERSAL,type:v.Type.OID,constructed:!1,capture:"publicKeyOid"}]},{name:"SubjectPublicKeyInfo.subjectPublicKey",tagClass:v.Class.UNIVERSAL,type:v.Type.BITSTRING,constructed:!1,value:[{name:"SubjectPublicKeyInfo.subjectPublicKey.RSAPublicKey",tagClass:v.Class.UNIVERSAL,type:v.Type.SEQUENCE,constructed:!0,optional:!0,captureAsn1:"rsaPublicKey"}]}]},Ey={name:"DigestInfo",tagClass:v.Class.UNIVERSAL,type:v.Type.SEQUENCE,constructed:!0,value:[{name:"DigestInfo.DigestAlgorithm",tagClass:v.Class.UNIVERSAL,type:v.Type.SEQUENCE,constructed:!0,value:[{name:"DigestInfo.DigestAlgorithm.algorithmIdentifier",tagClass:v.Class.UNIVERSAL,type:v.Type.OID,constructed:!1,capture:"algorithmIdentifier"},{name:"DigestInfo.DigestAlgorithm.parameters",tagClass:v.Class.UNIVERSAL,type:v.Type.NULL,capture:"parameters",optional:!0,constructed:!1}]},{name:"DigestInfo.digest",tagClass:v.Class.UNIVERSAL,type:v.Type.OCTETSTRING,constructed:!1,capture:"digest"}]},wy=function(e){var t;if(e.algorithm in $.oids)t=$.oids[e.algorithm];else{var r=new Error("Unknown message digest algorithm.");throw r.algorithm=e.algorithm,r}var n=v.oidToDer(t).getBytes(),i=v.create(v.Class.UNIVERSAL,v.Type.SEQUENCE,!0,[]),s=v.create(v.Class.UNIVERSAL,v.Type.SEQUENCE,!0,[]);s.value.push(v.create(v.Class.UNIVERSAL,v.Type.OID,!1,n)),s.value.push(v.create(v.Class.UNIVERSAL,v.Type.NULL,!1,""));var o=v.create(v.Class.UNIVERSAL,v.Type.OCTETSTRING,!1,e.digest().getBytes());return i.value.push(s),i.value.push(o),v.toDer(i).getBytes()},Xc=function(e,t,r){if(r)return e.modPow(t.e,t.n);if(!t.p||!t.q)return e.modPow(t.d,t.n);t.dP||(t.dP=t.d.mod(t.p.subtract(nt.ONE))),t.dQ||(t.dQ=t.d.mod(t.q.subtract(nt.ONE))),t.qInv||(t.qInv=t.q.modInverse(t.p));var n;do n=new nt(V.util.bytesToHex(V.random.getBytes(t.n.bitLength()/8)),16);while(n.compareTo(t.n)>=0||!n.gcd(t.n).equals(nt.ONE));e=e.multiply(n.modPow(t.e,t.n)).mod(t.n);for(var i=e.mod(t.p).modPow(t.dP,t.p),s=e.mod(t.q).modPow(t.dQ,t.q);i.compareTo(s)<0;)i=i.add(t.p);var o=i.subtract(s).multiply(t.qInv).mod(t.p).multiply(t.q).add(s);return o=o.multiply(n.modInverse(t.n)).mod(t.n),o};$.rsa.encrypt=function(e,t,r){var n=r,i,s=Math.ceil(t.n.bitLength()/8);r!==!1&&r!==!0?(n=r===2,i=Jc(e,t,r)):(i=V.util.createBuffer(),i.putBytes(e));for(var o=new nt(i.toHex(),16),a=Xc(o,t,n),c=a.toString(16),u=V.util.createBuffer(),f=s-Math.ceil(c.length/2);f>0;)u.putByte(0),--f;return u.putBytes(V.util.hexToBytes(c)),u.getBytes()};$.rsa.decrypt=function(e,t,r,n){var i=Math.ceil(t.n.bitLength()/8);if(e.length!==i){var s=new Error("Encrypted message length is invalid.");throw s.length=e.length,s.expected=i,s}var o=new nt(V.util.createBuffer(e).toHex(),16);if(o.compareTo(t.n)>=0)throw new Error("Encrypted message is invalid.");for(var a=Xc(o,t,r),c=a.toString(16),u=V.util.createBuffer(),f=i-Math.ceil(c.length/2);f>0;)u.putByte(0),--f;return u.putBytes(V.util.hexToBytes(c)),n!==!1?Ci(u.getBytes(),t,r):u.getBytes()};$.rsa.createKeyPairGenerationState=function(e,t,r){typeof e=="string"&&(e=parseInt(e,10)),e=e||2048,r=r||{};var n=r.prng||V.random,i={nextBytes:function(a){for(var c=n.getBytesSync(a.length),u=0;u<a.length;++u)a[u]=c.charCodeAt(u)}},s=r.algorithm||"PRIMEINC",o;if(s==="PRIMEINC")o={algorithm:s,state:0,bits:e,rng:i,eInt:t||65537,e:new nt(null),p:null,q:null,qBits:e>>1,pBits:e-(e>>1),pqState:0,num:null,keys:null},o.e.fromInt(o.eInt);else throw new Error("Invalid key generation algorithm: "+s);return o};$.rsa.stepKeyPairGenerationState=function(e,t){"algorithm"in e||(e.algorithm="PRIMEINC");var r=new nt(null);r.fromInt(30);for(var n=0,i=function(l,h){return l|h},s=+new Date,o,a=0;e.keys===null&&(t<=0||a<t);){if(e.state===0){var c=e.p===null?e.pBits:e.qBits,u=c-1;e.pqState===0?(e.num=new nt(c,e.rng),e.num.testBit(u)||e.num.bitwiseTo(nt.ONE.shiftLeft(u),i,e.num),e.num.dAddOffset(31-e.num.mod(r).byteValue(),0),n=0,++e.pqState):e.pqState===1?e.num.bitLength()>c?e.pqState=0:e.num.isProbablePrime(Ay(e.num.bitLength()))?++e.pqState:e.num.dAddOffset(my[n++%8],0):e.pqState===2?e.pqState=e.num.subtract(nt.ONE).gcd(e.e).compareTo(nt.ONE)===0?3:0:e.pqState===3&&(e.pqState=0,e.p===null?e.p=e.num:e.q=e.num,e.p!==null&&e.q!==null&&++e.state,e.num=null)}else if(e.state===1)e.p.compareTo(e.q)<0&&(e.num=e.p,e.p=e.q,e.q=e.num),++e.state;else if(e.state===2)e.p1=e.p.subtract(nt.ONE),e.q1=e.q.subtract(nt.ONE),e.phi=e.p1.multiply(e.q1),++e.state;else if(e.state===3)e.phi.gcd(e.e).compareTo(nt.ONE)===0?++e.state:(e.p=null,e.q=null,e.state=0);else if(e.state===4)e.n=e.p.multiply(e.q),e.n.bitLength()===e.bits?++e.state:(e.q=null,e.state=0);else if(e.state===5){var f=e.e.modInverse(e.phi);e.keys={privateKey:$.rsa.setPrivateKey(e.n,e.e,f,e.p,e.q,f.mod(e.p1),f.mod(e.q1),e.q.modInverse(e.p)),publicKey:$.rsa.setPublicKey(e.n,e.e)}}o=+new Date,a+=o-s,s=o}return e.keys!==null};$.rsa.generateKeyPair=function(e,t,r,n){if(arguments.length===1?typeof e=="object"?(r=e,e=void 0):typeof e=="function"&&(n=e,e=void 0):arguments.length===2?typeof e=="number"?typeof t=="function"?(n=t,t=void 0):typeof t!="number"&&(r=t,t=void 0):(r=e,n=t,e=void 0,t=void 0):arguments.length===3&&(typeof t=="number"?typeof r=="function"&&(n=r,r=void 0):(n=r,r=t,t=void 0)),r=r||{},e===void 0&&(e=r.bits||2048),t===void 0&&(t=r.e||65537),!V.options.usePureJavaScript&&!r.prng&&e>=256&&e<=16384&&(t===65537||t===3)){if(n){if(Yc("generateKeyPair"))return Ao.generateKeyPair("rsa",{modulusLength:e,publicExponent:t,publicKeyEncoding:{type:"spki",format:"pem"},privateKeyEncoding:{type:"pkcs8",format:"pem"}},function(a,c,u){if(a)return n(a);n(null,{privateKey:$.privateKeyFromPem(u),publicKey:$.publicKeyFromPem(c)})});if($c("generateKey")&&$c("exportKey"))return xe.globalScope.crypto.subtle.generateKey({name:"RSASSA-PKCS1-v1_5",modulusLength:e,publicExponent:Zc(t),hash:{name:"SHA-256"}},!0,["sign","verify"]).then(function(a){return xe.globalScope.crypto.subtle.exportKey("pkcs8",a.privateKey)}).then(void 0,function(a){n(a)}).then(function(a){if(a){var c=$.privateKeyFromAsn1(v.fromDer(V.util.createBuffer(a)));n(null,{privateKey:c,publicKey:$.setRsaPublicKey(c.n,c.e)})}});if(Qc("generateKey")&&Qc("exportKey")){var i=xe.globalScope.msCrypto.subtle.generateKey({name:"RSASSA-PKCS1-v1_5",modulusLength:e,publicExponent:Zc(t),hash:{name:"SHA-256"}},!0,["sign","verify"]);i.oncomplete=function(a){var c=a.target.result,u=xe.globalScope.msCrypto.subtle.exportKey("pkcs8",c.privateKey);u.oncomplete=function(f){var l=f.target.result,h=$.privateKeyFromAsn1(v.fromDer(V.util.createBuffer(l)));n(null,{privateKey:h,publicKey:$.setRsaPublicKey(h.n,h.e)})},u.onerror=function(f){n(f)}},i.onerror=function(a){n(a)};return}}else if(Yc("generateKeyPairSync")){var s=Ao.generateKeyPairSync("rsa",{modulusLength:e,publicExponent:t,publicKeyEncoding:{type:"spki",format:"pem"},privateKeyEncoding:{type:"pkcs8",format:"pem"}});return{privateKey:$.privateKeyFromPem(s.privateKey),publicKey:$.publicKeyFromPem(s.publicKey)}}}var o=$.rsa.createKeyPairGenerationState(e,t,r);if(!n)return $.rsa.stepKeyPairGenerationState(o,0),o.keys;Sy(o,r,n)};$.setRsaPublicKey=$.rsa.setPublicKey=function(e,t){var r={n:e,e:t};return r.encrypt=function(n,i,s){if(typeof i=="string"?i=i.toUpperCase():i===void 0&&(i="RSAES-PKCS1-V1_5"),i==="RSAES-PKCS1-V1_5")i={encode:function(a,c,u){return Jc(a,c,2).getBytes()}};else if(i==="RSA-OAEP"||i==="RSAES-OAEP")i={encode:function(a,c){return V.pkcs1.encode_rsa_oaep(c,a,s)}};else if(["RAW","NONE","NULL",null].indexOf(i)!==-1)i={encode:function(a){return a}};else if(typeof i=="string")throw new Error('Unsupported encryption scheme: "'+i+'".');var o=i.encode(n,r,!0);return $.rsa.encrypt(o,r,!0)},r.verify=function(n,i,s,o){typeof s=="string"?s=s.toUpperCase():s===void 0&&(s="RSASSA-PKCS1-V1_5"),o===void 0&&(o={_parseAllDigestBytes:!0}),"_parseAllDigestBytes"in o||(o._parseAllDigestBytes=!0),s==="RSASSA-PKCS1-V1_5"?s={verify:function(c,u){u=Ci(u,r,!0);var f=v.fromDer(u,{parseAllBytes:o._parseAllDigestBytes}),l={},h=[];if(!v.validate(f,Ey,l,h)){var y=new Error("ASN.1 object does not contain a valid RSASSA-PKCS1-v1_5 DigestInfo value.");throw y.errors=h,y}var d=v.derToOid(l.algorithmIdentifier);if(!(d===V.oids.md2||d===V.oids.md5||d===V.oids.sha1||d===V.oids.sha224||d===V.oids.sha256||d===V.oids.sha384||d===V.oids.sha512||d===V.oids["sha512-224"]||d===V.oids["sha512-256"])){var y=new Error("Unknown RSASSA-PKCS1-v1_5 DigestAlgorithm identifier.");throw y.oid=d,y}if((d===V.oids.md2||d===V.oids.md5)&&!("parameters"in l))throw new Error("ASN.1 object does not contain a valid RSASSA-PKCS1-v1_5 DigestInfo value. Missing algorithm identifer NULL parameters.");return c===l.digest}}:(s==="NONE"||s==="NULL"||s===null)&&(s={verify:function(c,u){return u=Ci(u,r,!0),c===u}});var a=$.rsa.decrypt(i,r,!0,!1);return s.verify(n,a,r.n.bitLength())},r};$.setRsaPrivateKey=$.rsa.setPrivateKey=function(e,t,r,n,i,s,o,a){var c={n:e,e:t,d:r,p:n,q:i,dP:s,dQ:o,qInv:a};return c.decrypt=function(u,f,l){typeof f=="string"?f=f.toUpperCase():f===void 0&&(f="RSAES-PKCS1-V1_5");var h=$.rsa.decrypt(u,c,!1,!1);if(f==="RSAES-PKCS1-V1_5")f={decode:Ci};else if(f==="RSA-OAEP"||f==="RSAES-OAEP")f={decode:function(y,d){return V.pkcs1.decode_rsa_oaep(d,y,l)}};else if(["RAW","NONE","NULL",null].indexOf(f)!==-1)f={decode:function(y){return y}};else throw new Error('Unsupported encryption scheme: "'+f+'".');return f.decode(h,c,!1)},c.sign=function(u,f){var l=!1;typeof f=="string"&&(f=f.toUpperCase()),f===void 0||f==="RSASSA-PKCS1-V1_5"?(f={encode:wy},l=1):(f==="NONE"||f==="NULL"||f===null)&&(f={encode:function(){return u}},l=1);var h=f.encode(u,c.n.bitLength());return $.rsa.encrypt(h,c,l)},c};$.wrapRsaPrivateKey=function(e){return v.create(v.Class.UNIVERSAL,v.Type.SEQUENCE,!0,[v.create(v.Class.UNIVERSAL,v.Type.INTEGER,!1,v.integerToDer(0).getBytes()),v.create(v.Class.UNIVERSAL,v.Type.SEQUENCE,!0,[v.create(v.Class.UNIVERSAL,v.Type.OID,!1,v.oidToDer($.oids.rsaEncryption).getBytes()),v.create(v.Class.UNIVERSAL,v.Type.NULL,!1,"")]),v.create(v.Class.UNIVERSAL,v.Type.OCTETSTRING,!1,v.toDer(e).getBytes())])};$.privateKeyFromAsn1=function(e){var t={},r=[];if(v.validate(e,gy,t,r)&&(e=v.fromDer(V.util.createBuffer(t.privateKey))),t={},r=[],!v.validate(e,xy,t,r)){var n=new Error("Cannot read private key. ASN.1 object does not contain an RSAPrivateKey.");throw n.errors=r,n}var i,s,o,a,c,u,f,l;return i=V.util.createBuffer(t.privateKeyModulus).toHex(),s=V.util.createBuffer(t.privateKeyPublicExponent).toHex(),o=V.util.createBuffer(t.privateKeyPrivateExponent).toHex(),a=V.util.createBuffer(t.privateKeyPrime1).toHex(),c=V.util.createBuffer(t.privateKeyPrime2).toHex(),u=V.util.createBuffer(t.privateKeyExponent1).toHex(),f=V.util.createBuffer(t.privateKeyExponent2).toHex(),l=V.util.createBuffer(t.privateKeyCoefficient).toHex(),$.setRsaPrivateKey(new nt(i,16),new nt(s,16),new nt(o,16),new nt(a,16),new nt(c,16),new nt(u,16),new nt(f,16),new nt(l,16))};$.privateKeyToAsn1=$.privateKeyToRSAPrivateKey=function(e){return v.create(v.Class.UNIVERSAL,v.Type.SEQUENCE,!0,[v.create(v.Class.UNIVERSAL,v.Type.INTEGER,!1,v.integerToDer(0).getBytes()),v.create(v.Class.UNIVERSAL,v.Type.INTEGER,!1,Ke(e.n)),v.create(v.Class.UNIVERSAL,v.Type.INTEGER,!1,Ke(e.e)),v.create(v.Class.UNIVERSAL,v.Type.INTEGER,!1,Ke(e.d)),v.create(v.Class.UNIVERSAL,v.Type.INTEGER,!1,Ke(e.p)),v.create(v.Class.UNIVERSAL,v.Type.INTEGER,!1,Ke(e.q)),v.create(v.Class.UNIVERSAL,v.Type.INTEGER,!1,Ke(e.dP)),v.create(v.Class.UNIVERSAL,v.Type.INTEGER,!1,Ke(e.dQ)),v.create(v.Class.UNIVERSAL,v.Type.INTEGER,!1,Ke(e.qInv))])};$.publicKeyFromAsn1=function(e){var t={},r=[];if(v.validate(e,by,t,r)){var n=v.derToOid(t.publicKeyOid);if(n!==$.oids.rsaEncryption){var i=new Error("Cannot read public key. Unknown OID.");throw i.oid=n,i}e=t.rsaPublicKey}if(r=[],!v.validate(e,vy,t,r)){var i=new Error("Cannot read public key. ASN.1 object does not contain an RSAPublicKey.");throw i.errors=r,i}var s=V.util.createBuffer(t.publicKeyModulus).toHex(),o=V.util.createBuffer(t.publicKeyExponent).toHex();return $.setRsaPublicKey(new nt(s,16),new nt(o,16))};$.publicKeyToAsn1=$.publicKeyToSubjectPublicKeyInfo=function(e){return v.create(v.Class.UNIVERSAL,v.Type.SEQUENCE,!0,[v.create(v.Class.UNIVERSAL,v.Type.SEQUENCE,!0,[v.create(v.Class.UNIVERSAL,v.Type.OID,!1,v.oidToDer($.oids.rsaEncryption).getBytes()),v.create(v.Class.UNIVERSAL,v.Type.NULL,!1,"")]),v.create(v.Class.UNIVERSAL,v.Type.BITSTRING,!1,[$.publicKeyToRSAPublicKey(e)])])};$.publicKeyToRSAPublicKey=function(e){return v.create(v.Class.UNIVERSAL,v.Type.SEQUENCE,!0,[v.create(v.Class.UNIVERSAL,v.Type.INTEGER,!1,Ke(e.n)),v.create(v.Class.UNIVERSAL,v.Type.INTEGER,!1,Ke(e.e))])};function Jc(e,t,r){var n=V.util.createBuffer(),i=Math.ceil(t.n.bitLength()/8);if(e.length>i-11){var s=new Error("Message is too long for PKCS#1 v1.5 padding.");throw s.length=e.length,s.max=i-11,s}n.putByte(0),n.putByte(r);var o=i-3-e.length,a;if(r===0||r===1){a=r===0?0:255;for(var c=0;c<o;++c)n.putByte(a)}else for(;o>0;){for(var u=0,f=V.random.getBytes(o),c=0;c<o;++c)a=f.charCodeAt(c),a===0?++u:n.putByte(a);o=u}return n.putByte(0),n.putBytes(e),n}function Ci(e,t,r,n){var i=Math.ceil(t.n.bitLength()/8),s=V.util.createBuffer(e),o=s.getByte(),a=s.getByte();if(o!==0||r&&a!==0&&a!==1||!r&&a!=2||r&&a===0&&typeof n>"u")throw new Error("Encryption block is invalid.");var c=0;if(a===0){c=i-3-n;for(var u=0;u<c;++u)if(s.getByte()!==0)throw new Error("Encryption block is invalid.")}else if(a===1)for(c=0;s.length()>1;){if(s.getByte()!==255){--s.read;break}++c}else if(a===2)for(c=0;s.length()>1;){if(s.getByte()===0){--s.read;break}++c}var f=s.getByte();if(f!==0||c!==i-3-s.length())throw new Error("Encryption block is invalid.");return s.getBytes()}function Sy(e,t,r){typeof t=="function"&&(r=t,t={}),t=t||{};var n={algorithm:{name:t.algorithm||"PRIMEINC",options:{workers:t.workers||2,workLoad:t.workLoad||100,workerScript:t.workerScript}}};"prng"in t&&(n.prng=t.prng),i();function i(){s(e.pBits,function(a,c){if(a)return r(a);if(e.p=c,e.q!==null)return o(a,e.q);s(e.qBits,o)})}function s(a,c){V.prime.generateProbablePrime(a,n,c)}function o(a,c){if(a)return r(a);if(e.q=c,e.p.compareTo(e.q)<0){var u=e.p;e.p=e.q,e.q=u}if(e.p.subtract(nt.ONE).gcd(e.e).compareTo(nt.ONE)!==0){e.p=null,i();return}if(e.q.subtract(nt.ONE).gcd(e.e).compareTo(nt.ONE)!==0){e.q=null,s(e.qBits,o);return}if(e.p1=e.p.subtract(nt.ONE),e.q1=e.q.subtract(nt.ONE),e.phi=e.p1.multiply(e.q1),e.phi.gcd(e.e).compareTo(nt.ONE)!==0){e.p=e.q=null,i();return}if(e.n=e.p.multiply(e.q),e.n.bitLength()!==e.bits){e.q=null,s(e.qBits,o);return}var f=e.e.modInverse(e.phi);e.keys={privateKey:$.rsa.setPrivateKey(e.n,e.e,f,e.p,e.q,f.mod(e.p1),f.mod(e.q1),e.q.modInverse(e.p)),publicKey:$.rsa.setPublicKey(e.n,e.e)},r(null,e.keys)}}function Ke(e){var t=e.toString(16);t[0]>="8"&&(t="00"+t);var r=V.util.hexToBytes(t);return r.length>1&&(r.charCodeAt(0)===0&&!(r.charCodeAt(1)&128)||r.charCodeAt(0)===255&&(r.charCodeAt(1)&128)===128)?r.substr(1):r}function Ay(e){return e<=100?27:e<=150?18:e<=200?15:e<=250?12:e<=300?9:e<=350?8:e<=400?7:e<=500?6:e<=600?5:e<=800?4:e<=1250?3:2}function Yc(e){return V.util.isNodejs&&typeof Ao[e]=="function"}function $c(e){return typeof xe.globalScope<"u"&&typeof xe.globalScope.crypto=="object"&&typeof xe.globalScope.crypto.subtle=="object"&&typeof xe.globalScope.crypto.subtle[e]=="function"}function Qc(e){return typeof xe.globalScope<"u"&&typeof xe.globalScope.msCrypto=="object"&&typeof xe.globalScope.msCrypto.subtle=="object"&&typeof xe.globalScope.msCrypto.subtle[e]=="function"}function Zc(e){for(var t=V.util.hexToBytes(e.toString(16)),r=new Uint8Array(t.length),n=0;n<t.length;++n)r[n]=t.charCodeAt(n);return r}});var su=ot((I2,iu)=>{var O=ht();yo();Un();uc();Lr();di();pc();gc();On();_c();_i();Dt();typeof tu>"u"&&(tu=O.jsbn.BigInteger);var tu,A=O.asn1,Q=O.pki=O.pki||{};iu.exports=Q.pbe=O.pbe=O.pbe||{};var Pr=Q.oids,Ty={name:"EncryptedPrivateKeyInfo",tagClass:A.Class.UNIVERSAL,type:A.Type.SEQUENCE,constructed:!0,value:[{name:"EncryptedPrivateKeyInfo.encryptionAlgorithm",tagClass:A.Class.UNIVERSAL,type:A.Type.SEQUENCE,constructed:!0,value:[{name:"AlgorithmIdentifier.algorithm",tagClass:A.Class.UNIVERSAL,type:A.Type.OID,constructed:!1,capture:"encryptionOid"},{name:"AlgorithmIdentifier.parameters",tagClass:A.Class.UNIVERSAL,type:A.Type.SEQUENCE,constructed:!0,captureAsn1:"encryptionParams"}]},{name:"EncryptedPrivateKeyInfo.encryptedData",tagClass:A.Class.UNIVERSAL,type:A.Type.OCTETSTRING,constructed:!1,capture:"encryptedData"}]},By={name:"PBES2Algorithms",tagClass:A.Class.UNIVERSAL,type:A.Type.SEQUENCE,constructed:!0,value:[{name:"PBES2Algorithms.keyDerivationFunc",tagClass:A.Class.UNIVERSAL,type:A.Type.SEQUENCE,constructed:!0,value:[{name:"PBES2Algorithms.keyDerivationFunc.oid",tagClass:A.Class.UNIVERSAL,type:A.Type.OID,constructed:!1,capture:"kdfOid"},{name:"PBES2Algorithms.params",tagClass:A.Class.UNIVERSAL,type:A.Type.SEQUENCE,constructed:!0,value:[{name:"PBES2Algorithms.params.salt",tagClass:A.Class.UNIVERSAL,type:A.Type.OCTETSTRING,constructed:!1,capture:"kdfSalt"},{name:"PBES2Algorithms.params.iterationCount",tagClass:A.Class.UNIVERSAL,type:A.Type.INTEGER,constructed:!1,capture:"kdfIterationCount"},{name:"PBES2Algorithms.params.keyLength",tagClass:A.Class.UNIVERSAL,type:A.Type.INTEGER,constructed:!1,optional:!0,capture:"keyLength"},{name:"PBES2Algorithms.params.prf",tagClass:A.Class.UNIVERSAL,type:A.Type.SEQUENCE,constructed:!0,optional:!0,value:[{name:"PBES2Algorithms.params.prf.algorithm",tagClass:A.Class.UNIVERSAL,type:A.Type.OID,constructed:!1,capture:"prfOid"}]}]}]},{name:"PBES2Algorithms.encryptionScheme",tagClass:A.Class.UNIVERSAL,type:A.Type.SEQUENCE,constructed:!0,value:[{name:"PBES2Algorithms.encryptionScheme.oid",tagClass:A.Class.UNIVERSAL,type:A.Type.OID,constructed:!1,capture:"encOid"},{name:"PBES2Algorithms.encryptionScheme.iv",tagClass:A.Class.UNIVERSAL,type:A.Type.OCTETSTRING,constructed:!1,capture:"encIv"}]}]},Iy={name:"pkcs-12PbeParams",tagClass:A.Class.UNIVERSAL,type:A.Type.SEQUENCE,constructed:!0,value:[{name:"pkcs-12PbeParams.salt",tagClass:A.Class.UNIVERSAL,type:A.Type.OCTETSTRING,constructed:!1,capture:"salt"},{name:"pkcs-12PbeParams.iterations",tagClass:A.Class.UNIVERSAL,type:A.Type.INTEGER,constructed:!1,capture:"iterations"}]};Q.encryptPrivateKeyInfo=function(e,t,r){r=r||{},r.saltSize=r.saltSize||8,r.count=r.count||2048,r.algorithm=r.algorithm||"aes128",r.prfAlgorithm=r.prfAlgorithm||"sha1";var n=O.random.getBytesSync(r.saltSize),i=r.count,s=A.integerToDer(i),o,a,c;if(r.algorithm.indexOf("aes")===0||r.algorithm==="des"){var u,f,l;switch(r.algorithm){case"aes128":o=16,u=16,f=Pr["aes128-CBC"],l=O.aes.createEncryptionCipher;break;case"aes192":o=24,u=16,f=Pr["aes192-CBC"],l=O.aes.createEncryptionCipher;break;case"aes256":o=32,u=16,f=Pr["aes256-CBC"],l=O.aes.createEncryptionCipher;break;case"des":o=8,u=8,f=Pr.desCBC,l=O.des.createEncryptionCipher;break;default:var h=new Error("Cannot encrypt private key. Unknown encryption algorithm.");throw h.algorithm=r.algorithm,h}var y="hmacWith"+r.prfAlgorithm.toUpperCase(),d=nu(y),p=O.pkcs5.pbkdf2(t,n,i,o,d),m=O.random.getBytesSync(u),x=l(p);x.start(m),x.update(A.toDer(e)),x.finish(),c=x.output.getBytes();var E=Cy(n,s,o,y);a=A.create(A.Class.UNIVERSAL,A.Type.SEQUENCE,!0,[A.create(A.Class.UNIVERSAL,A.Type.OID,!1,A.oidToDer(Pr.pkcs5PBES2).getBytes()),A.create(A.Class.UNIVERSAL,A.Type.SEQUENCE,!0,[A.create(A.Class.UNIVERSAL,A.Type.SEQUENCE,!0,[A.create(A.Class.UNIVERSAL,A.Type.OID,!1,A.oidToDer(Pr.pkcs5PBKDF2).getBytes()),E]),A.create(A.Class.UNIVERSAL,A.Type.SEQUENCE,!0,[A.create(A.Class.UNIVERSAL,A.Type.OID,!1,A.oidToDer(f).getBytes()),A.create(A.Class.UNIVERSAL,A.Type.OCTETSTRING,!1,m)])])])}else if(r.algorithm==="3des"){o=24;var b=new O.util.ByteBuffer(n),p=Q.pbe.generatePkcs12Key(t,b,1,i,o),m=Q.pbe.generatePkcs12Key(t,b,2,i,o),x=O.des.createEncryptionCipher(p);x.start(m),x.update(A.toDer(e)),x.finish(),c=x.output.getBytes(),a=A.create(A.Class.UNIVERSAL,A.Type.SEQUENCE,!0,[A.create(A.Class.UNIVERSAL,A.Type.OID,!1,A.oidToDer(Pr["pbeWithSHAAnd3-KeyTripleDES-CBC"]).getBytes()),A.create(A.Class.UNIVERSAL,A.Type.SEQUENCE,!0,[A.create(A.Class.UNIVERSAL,A.Type.OCTETSTRING,!1,n),A.create(A.Class.UNIVERSAL,A.Type.INTEGER,!1,s.getBytes())])])}else{var h=new Error("Cannot encrypt private key. Unknown encryption algorithm.");throw h.algorithm=r.algorithm,h}var R=A.create(A.Class.UNIVERSAL,A.Type.SEQUENCE,!0,[a,A.create(A.Class.UNIVERSAL,A.Type.OCTETSTRING,!1,c)]);return R};Q.decryptPrivateKeyInfo=function(e,t){var r=null,n={},i=[];if(!A.validate(e,Ty,n,i)){var s=new Error("Cannot read encrypted private key. ASN.1 object is not a supported EncryptedPrivateKeyInfo.");throw s.errors=i,s}var o=A.derToOid(n.encryptionOid),a=Q.pbe.getCipher(o,n.encryptionParams,t),c=O.util.createBuffer(n.encryptedData);return a.update(c),a.finish()&&(r=A.fromDer(a.output)),r};Q.encryptedPrivateKeyToPem=function(e,t){var r={type:"ENCRYPTED PRIVATE KEY",body:A.toDer(e).getBytes()};return O.pem.encode(r,{maxline:t})};Q.encryptedPrivateKeyFromPem=function(e){var t=O.pem.decode(e)[0];if(t.type!=="ENCRYPTED PRIVATE KEY"){var r=new Error('Could not convert encrypted private key from PEM; PEM header type is "ENCRYPTED PRIVATE KEY".');throw r.headerType=t.type,r}if(t.procType&&t.procType.type==="ENCRYPTED")throw new Error("Could not convert encrypted private key from PEM; PEM is encrypted.");return A.fromDer(t.body)};Q.encryptRsaPrivateKey=function(e,t,r){if(r=r||{},!r.legacy){var n=Q.wrapRsaPrivateKey(Q.privateKeyToAsn1(e));return n=Q.encryptPrivateKeyInfo(n,t,r),Q.encryptedPrivateKeyToPem(n)}var i,s,o,a;switch(r.algorithm){case"aes128":i="AES-128-CBC",o=16,s=O.random.getBytesSync(16),a=O.aes.createEncryptionCipher;break;case"aes192":i="AES-192-CBC",o=24,s=O.random.getBytesSync(16),a=O.aes.createEncryptionCipher;break;case"aes256":i="AES-256-CBC",o=32,s=O.random.getBytesSync(16),a=O.aes.createEncryptionCipher;break;case"3des":i="DES-EDE3-CBC",o=24,s=O.random.getBytesSync(8),a=O.des.createEncryptionCipher;break;case"des":i="DES-CBC",o=8,s=O.random.getBytesSync(8),a=O.des.createEncryptionCipher;break;default:var c=new Error('Could not encrypt RSA private key; unsupported encryption algorithm "'+r.algorithm+'".');throw c.algorithm=r.algorithm,c}var u=O.pbe.opensslDeriveBytes(t,s.substr(0,8),o),f=a(u);f.start(s),f.update(A.toDer(Q.privateKeyToAsn1(e))),f.finish();var l={type:"RSA PRIVATE KEY",procType:{version:"4",type:"ENCRYPTED"},dekInfo:{algorithm:i,parameters:O.util.bytesToHex(s).toUpperCase()},body:f.output.getBytes()};return O.pem.encode(l)};Q.decryptRsaPrivateKey=function(e,t){var r=null,n=O.pem.decode(e)[0];if(n.type!=="ENCRYPTED PRIVATE KEY"&&n.type!=="PRIVATE KEY"&&n.type!=="RSA PRIVATE KEY"){var i=new Error('Could not convert private key from PEM; PEM header type is not "ENCRYPTED PRIVATE KEY", "PRIVATE KEY", or "RSA PRIVATE KEY".');throw i.headerType=i,i}if(n.procType&&n.procType.type==="ENCRYPTED"){var s,o;switch(n.dekInfo.algorithm){case"DES-CBC":s=8,o=O.des.createDecryptionCipher;break;case"DES-EDE3-CBC":s=24,o=O.des.createDecryptionCipher;break;case"AES-128-CBC":s=16,o=O.aes.createDecryptionCipher;break;case"AES-192-CBC":s=24,o=O.aes.createDecryptionCipher;break;case"AES-256-CBC":s=32,o=O.aes.createDecryptionCipher;break;case"RC2-40-CBC":s=5,o=function(l){return O.rc2.createDecryptionCipher(l,40)};break;case"RC2-64-CBC":s=8,o=function(l){return O.rc2.createDecryptionCipher(l,64)};break;case"RC2-128-CBC":s=16,o=function(l){return O.rc2.createDecryptionCipher(l,128)};break;default:var i=new Error('Could not decrypt private key; unsupported encryption algorithm "'+n.dekInfo.algorithm+'".');throw i.algorithm=n.dekInfo.algorithm,i}var a=O.util.hexToBytes(n.dekInfo.parameters),c=O.pbe.opensslDeriveBytes(t,a.substr(0,8),s),u=o(c);if(u.start(a),u.update(O.util.createBuffer(n.body)),u.finish())r=u.output.getBytes();else return r}else r=n.body;return n.type==="ENCRYPTED PRIVATE KEY"?r=Q.decryptPrivateKeyInfo(A.fromDer(r),t):r=A.fromDer(r),r!==null&&(r=Q.privateKeyFromAsn1(r)),r};Q.pbe.generatePkcs12Key=function(e,t,r,n,i,s){var o,a;if(typeof s>"u"||s===null){if(!("sha1"in O.md))throw new Error('"sha1" hash algorithm unavailable.');s=O.md.sha1.create()}var c=s.digestLength,u=s.blockLength,f=new O.util.ByteBuffer,l=new O.util.ByteBuffer;if(e!=null){for(a=0;a<e.length;a++)l.putInt16(e.charCodeAt(a));l.putInt16(0)}var h=l.length(),y=t.length(),d=new O.util.ByteBuffer;d.fillWithByte(r,u);var p=u*Math.ceil(y/u),m=new O.util.ByteBuffer;for(a=0;a<p;a++)m.putByte(t.at(a%y));var x=u*Math.ceil(h/u),E=new O.util.ByteBuffer;for(a=0;a<x;a++)E.putByte(l.at(a%h));var b=m;b.putBuffer(E);for(var R=Math.ceil(i/c),w=1;w<=R;w++){var S=new O.util.ByteBuffer;S.putBytes(d.bytes()),S.putBytes(b.bytes());for(var L=0;L<n;L++)s.start(),s.update(S.getBytes()),S=s.digest();var D=new O.util.ByteBuffer;for(a=0;a<u;a++)D.putByte(S.at(a%c));var Y=Math.ceil(y/u)+Math.ceil(h/u),W=new O.util.ByteBuffer;for(o=0;o<Y;o++){var q=new O.util.ByteBuffer(b.getBytes(u)),j=511;for(a=D.length()-1;a>=0;a--)j=j>>8,j+=D.at(a)+q.at(a),q.setAt(a,j&255);W.putBuffer(q)}b=W,f.putBuffer(S)}return f.truncate(f.length()-i),f};Q.pbe.getCipher=function(e,t,r){switch(e){case Q.oids.pkcs5PBES2:return Q.pbe.getCipherForPBES2(e,t,r);case Q.oids["pbeWithSHAAnd3-KeyTripleDES-CBC"]:case Q.oids["pbewithSHAAnd40BitRC2-CBC"]:return Q.pbe.getCipherForPKCS12PBE(e,t,r);default:var n=new Error("Cannot read encrypted PBE data block. Unsupported OID.");throw n.oid=e,n.supportedOids=["pkcs5PBES2","pbeWithSHAAnd3-KeyTripleDES-CBC","pbewithSHAAnd40BitRC2-CBC"],n}};Q.pbe.getCipherForPBES2=function(e,t,r){var n={},i=[];if(!A.validate(t,By,n,i)){var s=new Error("Cannot read password-based-encryption algorithm parameters. ASN.1 object is not a supported EncryptedPrivateKeyInfo.");throw s.errors=i,s}if(e=A.derToOid(n.kdfOid),e!==Q.oids.pkcs5PBKDF2){var s=new Error("Cannot read encrypted private key. Unsupported key derivation function OID.");throw s.oid=e,s.supportedOids=["pkcs5PBKDF2"],s}if(e=A.derToOid(n.encOid),e!==Q.oids["aes128-CBC"]&&e!==Q.oids["aes192-CBC"]&&e!==Q.oids["aes256-CBC"]&&e!==Q.oids["des-EDE3-CBC"]&&e!==Q.oids.desCBC){var s=new Error("Cannot read encrypted private key. Unsupported encryption scheme OID.");throw s.oid=e,s.supportedOids=["aes128-CBC","aes192-CBC","aes256-CBC","des-EDE3-CBC","desCBC"],s}var o=n.kdfSalt,a=O.util.createBuffer(n.kdfIterationCount);a=a.getInt(a.length()<<3);var c,u;switch(Q.oids[e]){case"aes128-CBC":c=16,u=O.aes.createDecryptionCipher;break;case"aes192-CBC":c=24,u=O.aes.createDecryptionCipher;break;case"aes256-CBC":c=32,u=O.aes.createDecryptionCipher;break;case"des-EDE3-CBC":c=24,u=O.des.createDecryptionCipher;break;case"desCBC":c=8,u=O.des.createDecryptionCipher;break}var f=ru(n.prfOid),l=O.pkcs5.pbkdf2(r,o,a,c,f),h=n.encIv,y=u(l);return y.start(h),y};Q.pbe.getCipherForPKCS12PBE=function(e,t,r){var n={},i=[];if(!A.validate(t,Iy,n,i)){var s=new Error("Cannot read password-based-encryption algorithm parameters. ASN.1 object is not a supported EncryptedPrivateKeyInfo.");throw s.errors=i,s}var o=O.util.createBuffer(n.salt),a=O.util.createBuffer(n.iterations);a=a.getInt(a.length()<<3);var c,u,f;switch(e){case Q.oids["pbeWithSHAAnd3-KeyTripleDES-CBC"]:c=24,u=8,f=O.des.startDecrypting;break;case Q.oids["pbewithSHAAnd40BitRC2-CBC"]:c=5,u=8,f=function(p,m){var x=O.rc2.createDecryptionCipher(p,40);return x.start(m,null),x};break;default:var s=new Error("Cannot read PKCS #12 PBE data block. Unsupported OID.");throw s.oid=e,s}var l=ru(n.prfOid),h=Q.pbe.generatePkcs12Key(r,o,1,a,c,l);l.start();var y=Q.pbe.generatePkcs12Key(r,o,2,a,u,l);return f(h,y)};Q.pbe.opensslDeriveBytes=function(e,t,r,n){if(typeof n>"u"||n===null){if(!("md5"in O.md))throw new Error('"md5" hash algorithm unavailable.');n=O.md.md5.create()}t===null&&(t="");for(var i=[eu(n,e+t)],s=16,o=1;s<r;++o,s+=16)i.push(eu(n,i[o-1]+e+t));return i.join("").substr(0,r)};function eu(e,t){return e.start().update(t).digest().getBytes()}function ru(e){var t;if(!e)t="hmacWithSHA1";else if(t=Q.oids[A.derToOid(e)],!t){var r=new Error("Unsupported PRF OID.");throw r.oid=e,r.supported=["hmacWithSHA1","hmacWithSHA224","hmacWithSHA256","hmacWithSHA384","hmacWithSHA512"],r}return nu(t)}function nu(e){var t=O.md;switch(e){case"hmacWithSHA224":t=O.md.sha512;case"hmacWithSHA1":case"hmacWithSHA256":case"hmacWithSHA384":case"hmacWithSHA512":e=e.substr(8).toLowerCase();break;default:var r=new Error("Unsupported PRF algorithm.");throw r.algorithm=e,r.supported=["hmacWithSHA1","hmacWithSHA224","hmacWithSHA256","hmacWithSHA384","hmacWithSHA512"],r}if(!t||!(e in t))throw new Error("Unknown hash algorithm: "+e);return t[e].create()}function Cy(e,t,r,n){var i=A.create(A.Class.UNIVERSAL,A.Type.SEQUENCE,!0,[A.create(A.Class.UNIVERSAL,A.Type.OCTETSTRING,!1,e),A.create(A.Class.UNIVERSAL,A.Type.INTEGER,!1,t.getBytes())]);return n!=="hmacWithSHA1"&&i.value.push(A.create(A.Class.UNIVERSAL,A.Type.INTEGER,!1,O.util.hexToBytes(r.toString(16))),A.create(A.Class.UNIVERSAL,A.Type.SEQUENCE,!0,[A.create(A.Class.UNIVERSAL,A.Type.OID,!1,A.oidToDer(Q.oids[n]).getBytes()),A.create(A.Class.UNIVERSAL,A.Type.NULL,!1,"")])),i}});var Yu=ot((Gb,Wu)=>{var xt=ht();Lr();Dt();var Wn=Wu.exports=xt.sha512=xt.sha512||{};xt.md.sha512=xt.md.algorithms.sha512=Wn;var zu=xt.sha384=xt.sha512.sha384=xt.sha512.sha384||{};zu.create=function(){return Wn.create("SHA-384")};xt.md.sha384=xt.md.algorithms.sha384=zu;xt.sha512.sha256=xt.sha512.sha256||{create:function(){return Wn.create("SHA-512/256")}};xt.md["sha512/256"]=xt.md.algorithms["sha512/256"]=xt.sha512.sha256;xt.sha512.sha224=xt.sha512.sha224||{create:function(){return Wn.create("SHA-512/224")}};xt.md["sha512/224"]=xt.md.algorithms["sha512/224"]=xt.sha512.sha224;Wn.create=function(e){if(Gu||$m(),typeof e>"u"&&(e="SHA-512"),!(e in qr))throw new Error("Invalid SHA-512 algorithm: "+e);for(var t=qr[e],r=null,n=xt.util.createBuffer(),i=new Array(80),s=0;s<80;++s)i[s]=new Array(2);var o=64;switch(e){case"SHA-384":o=48;break;case"SHA-512/256":o=32;break;case"SHA-512/224":o=28;break}var a={algorithm:e.replace("-","").toLowerCase(),blockLength:128,digestLength:o,messageLength:0,fullMessageLength:null,messageLengthSize:16};return a.start=function(){a.messageLength=0,a.fullMessageLength=a.messageLength128=[];for(var c=a.messageLengthSize/4,u=0;u<c;++u)a.fullMessageLength.push(0);n=xt.util.createBuffer(),r=new Array(t.length);for(var u=0;u<t.length;++u)r[u]=t[u].slice(0);return a},a.start(),a.update=function(c,u){u==="utf8"&&(c=xt.util.encodeUtf8(c));var f=c.length;a.messageLength+=f,f=[f/4294967296>>>0,f>>>0];for(var l=a.fullMessageLength.length-1;l>=0;--l)a.fullMessageLength[l]+=f[1],f[1]=f[0]+(a.fullMessageLength[l]/4294967296>>>0),a.fullMessageLength[l]=a.fullMessageLength[l]>>>0,f[0]=f[1]/4294967296>>>0;return n.putBytes(c),Hu(r,i,n),(n.read>2048||n.length()===0)&&n.compact(),a},a.digest=function(){var c=xt.util.createBuffer();c.putBytes(n.bytes());var u=a.fullMessageLength[a.fullMessageLength.length-1]+a.messageLengthSize,f=u&a.blockLength-1;c.putBytes(na.substr(0,a.blockLength-f));for(var l,h,y=a.fullMessageLength[0]*8,d=0;d<a.fullMessageLength.length-1;++d)l=a.fullMessageLength[d+1]*8,h=l/4294967296>>>0,y+=h,c.putInt32(y>>>0),y=l>>>0;c.putInt32(y);for(var p=new Array(r.length),d=0;d<r.length;++d)p[d]=r[d].slice(0);Hu(p,i,c);var m=xt.util.createBuffer(),x;e==="SHA-512"?x=p.length:e==="SHA-384"?x=p.length-2:x=p.length-4;for(var d=0;d<x;++d)m.putInt32(p[d][0]),(d!==x-1||e!=="SHA-512/224")&&m.putInt32(p[d][1]);return m},a};var na=null,Gu=!1,ia=null,qr=null;function $m(){na="\x80",na+=xt.util.fillString("\0",128),ia=[[1116352408,3609767458],[1899447441,602891725],[3049323471,3964484399],[3921009573,2173295548],[961987163,4081628472],[1508970993,3053834265],[2453635748,2937671579],[2870763221,3664609560],[3624381080,2734883394],[310598401,1164996542],[607225278,1323610764],[1426881987,3590304994],[1925078388,4068182383],[2162078206,991336113],[2614888103,633803317],[3248222580,3479774868],[3835390401,2666613458],[4022224774,944711139],[264347078,2341262773],[604807628,2007800933],[770255983,1495990901],[1249150122,1856431235],[1555081692,3175218132],[1996064986,2198950837],[2554220882,3999719339],[2821834349,766784016],[2952996808,2566594879],[3210313671,3203337956],[3336571891,1034457026],[3584528711,2466948901],[113926993,3758326383],[338241895,168717936],[666307205,1188179964],[773529912,1546045734],[1294757372,1522805485],[1396182291,2643833823],[1695183700,2343527390],[1986661051,1014477480],[2177026350,1206759142],[2456956037,344077627],[2730485921,1290863460],[2820302411,3158454273],[3259730800,3505952657],[3345764771,106217008],[3516065817,3606008344],[3600352804,1432725776],[4094571909,1467031594],[275423344,851169720],[430227734,3100823752],[506948616,1363258195],[659060556,3750685593],[883997877,3785050280],[958139571,3318307427],[1322822218,3812723403],[1537002063,2003034995],[1747873779,3602036899],[1955562222,1575990012],[2024104815,1125592928],[2227730452,2716904306],[2361852424,442776044],[2428436474,593698344],[2756734187,3733110249],[3204031479,2999351573],[3329325298,3815920427],[3391569614,3928383900],[3515267271,566280711],[3940187606,3454069534],[4118630271,4000239992],[116418474,1914138554],[174292421,2731055270],[289380356,3203993006],[460393269,320620315],[685471733,587496836],[852142971,1086792851],[1017036298,365543100],[1126000580,2618297676],[1288033470,3409855158],[1501505948,4234509866],[1607167915,987167468],[1816402316,1246189591]],qr={},qr["SHA-512"]=[[1779033703,4089235720],[3144134277,2227873595],[1013904242,4271175723],[2773480762,1595750129],[1359893119,2917565137],[2600822924,725511199],[528734635,4215389547],[1541459225,327033209]],qr["SHA-384"]=[[3418070365,3238371032],[1654270250,914150663],[2438529370,812702999],[355462360,4144912697],[1731405415,4290775857],[2394180231,1750603025],[3675008525,1694076839],[1203062813,3204075428]],qr["SHA-512/256"]=[[573645204,4230739756],[2673172387,3360449730],[596883563,1867755857],[2520282905,1497426621],[2519219938,2827943907],[3193839141,1401305490],[721525244,746961066],[246885852,2177182882]],qr["SHA-512/224"]=[[2352822216,424955298],[1944164710,2312950998],[502970286,855612546],[1738396948,1479516111],[258812777,2077511080],[2011393907,79989058],[1067287976,1780299464],[286451373,2446758561]],Gu=!0}function Hu(e,t,r){for(var n,i,s,o,a,c,u,f,l,h,y,d,p,m,x,E,b,R,w,S,L,D,Y,W,q,j,lt,Ht,I,P,_,N,T,M,F,G=r.length();G>=128;){for(I=0;I<16;++I)t[I][0]=r.getInt32()>>>0,t[I][1]=r.getInt32()>>>0;for(;I<80;++I)N=t[I-2],P=N[0],_=N[1],n=((P>>>19|_<<13)^(_>>>29|P<<3)^P>>>6)>>>0,i=((P<<13|_>>>19)^(_<<3|P>>>29)^(P<<26|_>>>6))>>>0,M=t[I-15],P=M[0],_=M[1],s=((P>>>1|_<<31)^(P>>>8|_<<24)^P>>>7)>>>0,o=((P<<31|_>>>1)^(P<<24|_>>>8)^(P<<25|_>>>7))>>>0,T=t[I-7],F=t[I-16],_=i+T[1]+o+F[1],t[I][0]=n+T[0]+s+F[0]+(_/4294967296>>>0)>>>0,t[I][1]=_>>>0;for(p=e[0][0],m=e[0][1],x=e[1][0],E=e[1][1],b=e[2][0],R=e[2][1],w=e[3][0],S=e[3][1],L=e[4][0],D=e[4][1],Y=e[5][0],W=e[5][1],q=e[6][0],j=e[6][1],lt=e[7][0],Ht=e[7][1],I=0;I<80;++I)u=((L>>>14|D<<18)^(L>>>18|D<<14)^(D>>>9|L<<23))>>>0,f=((L<<18|D>>>14)^(L<<14|D>>>18)^(D<<23|L>>>9))>>>0,l=(q^L&(Y^q))>>>0,h=(j^D&(W^j))>>>0,a=((p>>>28|m<<4)^(m>>>2|p<<30)^(m>>>7|p<<25))>>>0,c=((p<<4|m>>>28)^(m<<30|p>>>2)^(m<<25|p>>>7))>>>0,y=(p&x|b&(p^x))>>>0,d=(m&E|R&(m^E))>>>0,_=Ht+f+h+ia[I][1]+t[I][1],n=lt+u+l+ia[I][0]+t[I][0]+(_/4294967296>>>0)>>>0,i=_>>>0,_=c+d,s=a+y+(_/4294967296>>>0)>>>0,o=_>>>0,lt=q,Ht=j,q=Y,j=W,Y=L,W=D,_=S+i,L=w+n+(_/4294967296>>>0)>>>0,D=_>>>0,w=b,S=R,b=x,R=E,x=p,E=m,_=i+o,p=n+s+(_/4294967296>>>0)>>>0,m=_>>>0;_=e[0][1]+m,e[0][0]=e[0][0]+p+(_/4294967296>>>0)>>>0,e[0][1]=_>>>0,_=e[1][1]+E,e[1][0]=e[1][0]+x+(_/4294967296>>>0)>>>0,e[1][1]=_>>>0,_=e[2][1]+R,e[2][0]=e[2][0]+b+(_/4294967296>>>0)>>>0,e[2][1]=_>>>0,_=e[3][1]+S,e[3][0]=e[3][0]+w+(_/4294967296>>>0)>>>0,e[3][1]=_>>>0,_=e[4][1]+D,e[4][0]=e[4][0]+L+(_/4294967296>>>0)>>>0,e[4][1]=_>>>0,_=e[5][1]+W,e[5][0]=e[5][0]+Y+(_/4294967296>>>0)>>>0,e[5][1]=_>>>0,_=e[6][1]+j,e[6][0]=e[6][0]+q+(_/4294967296>>>0)>>>0,e[6][1]=_>>>0,_=e[7][1]+Ht,e[7][0]=e[7][0]+lt+(_/4294967296>>>0)>>>0,e[7][1]=_>>>0,G-=128}}});var Yf=ot((v4,Wf)=>{"use strict";function Gf(e,t){for(let r in t)Object.defineProperty(e,r,{value:t[r],enumerable:!0,configurable:!0});return e}function Qg(e,t,r){if(!e||typeof e=="string")throw new TypeError("Please pass an Error to err-code");r||(r={}),typeof t=="object"&&(r=t,t=""),t&&(r.code=t);try{return Gf(e,r)}catch{r.message=e.message,r.stack=e.stack;let i=function(){};return i.prototype=Object.create(Object.getPrototypeOf(e)),Gf(new i,r)}}Wf.exports=Qg});var al=ot((F4,ol)=>{function Se(e,t){typeof t=="boolean"&&(t={forever:t}),this._originalTimeouts=JSON.parse(JSON.stringify(e)),this._timeouts=e,this._options=t||{},this._maxRetryTime=t&&t.maxRetryTime||1/0,this._fn=null,this._errors=[],this._attempts=1,this._operationTimeout=null,this._operationTimeoutCb=null,this._timeout=null,this._operationStart=null,this._timer=null,this._options.forever&&(this._cachedTimeouts=this._timeouts.slice(0))}ol.exports=Se;Se.prototype.reset=function(){this._attempts=1,this._timeouts=this._originalTimeouts.slice(0)};Se.prototype.stop=function(){this._timeout&&clearTimeout(this._timeout),this._timer&&clearTimeout(this._timer),this._timeouts=[],this._cachedTimeouts=null};Se.prototype.retry=function(e){if(this._timeout&&clearTimeout(this._timeout),!e)return!1;var t=new Date().getTime();if(e&&t-this._operationStart>=this._maxRetryTime)return this._errors.push(e),this._errors.unshift(new Error("RetryOperation timeout occurred")),!1;this._errors.push(e);var r=this._timeouts.shift();if(r===void 0)if(this._cachedTimeouts)this._errors.splice(0,this._errors.length-1),r=this._cachedTimeouts.slice(-1);else return!1;var n=this;return this._timer=setTimeout(function(){n._attempts++,n._operationTimeoutCb&&(n._timeout=setTimeout(function(){n._operationTimeoutCb(n._attempts)},n._operationTimeout),n._options.unref&&n._timeout.unref()),n._fn(n._attempts)},r),this._options.unref&&this._timer.unref(),!0};Se.prototype.attempt=function(e,t){this._fn=e,t&&(t.timeout&&(this._operationTimeout=t.timeout),t.cb&&(this._operationTimeoutCb=t.cb));var r=this;this._operationTimeoutCb&&(this._timeout=setTimeout(function(){r._operationTimeoutCb()},r._operationTimeout)),this._operationStart=new Date().getTime(),this._fn(this._attempts)};Se.prototype.try=function(e){console.log("Using RetryOperation.try() is deprecated"),this.attempt(e)};Se.prototype.start=function(e){console.log("Using RetryOperation.start() is deprecated"),this.attempt(e)};Se.prototype.start=Se.prototype.try;Se.prototype.errors=function(){return this._errors};Se.prototype.attempts=function(){return this._attempts};Se.prototype.mainError=function(){if(this._errors.length===0)return null;for(var e={},t=null,r=0,n=0;n<this._errors.length;n++){var i=this._errors[n],s=i.message,o=(e[s]||0)+1;e[s]=o,o>=r&&(t=i,r=o)}return t}});var cl=ot($r=>{var jg=al();$r.operation=function(e){var t=$r.timeouts(e);return new jg(t,{forever:e&&(e.forever||e.retries===1/0),unref:e&&e.unref,maxRetryTime:e&&e.maxRetryTime})};$r.timeouts=function(e){if(e instanceof Array)return[].concat(e);var t={retries:10,factor:2,minTimeout:1*1e3,maxTimeout:1/0,randomize:!1};for(var r in e)t[r]=e[r];if(t.minTimeout>t.maxTimeout)throw new Error("minTimeout is greater than maxTimeout");for(var n=[],i=0;i<t.retries;i++)n.push(this.createTimeout(i,t));return e&&e.forever&&!n.length&&n.push(this.createTimeout(i,t)),n.sort(function(s,o){return s-o}),n};$r.createTimeout=function(e,t){var r=t.randomize?Math.random()+1:1,n=Math.round(r*Math.max(t.minTimeout,1)*Math.pow(t.factor,e));return n=Math.min(n,t.maxTimeout),n};$r.wrap=function(e,t,r){if(t instanceof Array&&(r=t,t=null),!r){r=[];for(var n in e)typeof e[n]=="function"&&r.push(n)}for(var i=0;i<r.length;i++){var s=r[i],o=e[s];e[s]=function(c){var u=$r.operation(t),f=Array.prototype.slice.call(arguments,1),l=f.pop();f.push(function(h){u.retry(h)||(h&&(arguments[0]=u.mainError()),l.apply(this,arguments))}),u.attempt(function(){c.apply(e,f)})}.bind(e,o),e[s].options=t}}});var fl=ot((q4,ul)=>{ul.exports=cl()});var ml=ot((P8,Ga)=>{"use strict";var c1=Object.prototype.hasOwnProperty,se="~";function ri(){}Object.create&&(ri.prototype=Object.create(null),new ri().__proto__||(se=!1));function u1(e,t,r){this.fn=e,this.context=t,this.once=r||!1}function yl(e,t,r,n,i){if(typeof r!="function")throw new TypeError("The listener must be a function");var s=new u1(r,n||e,i),o=se?se+t:t;return e._events[o]?e._events[o].fn?e._events[o]=[e._events[o],s]:e._events[o].push(s):(e._events[o]=s,e._eventsCount++),e}function ms(e,t){--e._eventsCount===0?e._events=new ri:delete e._events[t]}function re(){this._events=new ri,this._eventsCount=0}re.prototype.eventNames=function(){var t=[],r,n;if(this._eventsCount===0)return t;for(n in r=this._events)c1.call(r,n)&&t.push(se?n.slice(1):n);return Object.getOwnPropertySymbols?t.concat(Object.getOwnPropertySymbols(r)):t};re.prototype.listeners=function(t){var r=se?se+t:t,n=this._events[r];if(!n)return[];if(n.fn)return[n.fn];for(var i=0,s=n.length,o=new Array(s);i<s;i++)o[i]=n[i].fn;return o};re.prototype.listenerCount=function(t){var r=se?se+t:t,n=this._events[r];return n?n.fn?1:n.length:0};re.prototype.emit=function(t,r,n,i,s,o){var a=se?se+t:t;if(!this._events[a])return!1;var c=this._events[a],u=arguments.length,f,l;if(c.fn){switch(c.once&&this.removeListener(t,c.fn,void 0,!0),u){case 1:return c.fn.call(c.context),!0;case 2:return c.fn.call(c.context,r),!0;case 3:return c.fn.call(c.context,r,n),!0;case 4:return c.fn.call(c.context,r,n,i),!0;case 5:return c.fn.call(c.context,r,n,i,s),!0;case 6:return c.fn.call(c.context,r,n,i,s,o),!0}for(l=1,f=new Array(u-1);l<u;l++)f[l-1]=arguments[l];c.fn.apply(c.context,f)}else{var h=c.length,y;for(l=0;l<h;l++)switch(c[l].once&&this.removeListener(t,c[l].fn,void 0,!0),u){case 1:c[l].fn.call(c[l].context);break;case 2:c[l].fn.call(c[l].context,r);break;case 3:c[l].fn.call(c[l].context,r,n);break;case 4:c[l].fn.call(c[l].context,r,n,i);break;default:if(!f)for(y=1,f=new Array(u-1);y<u;y++)f[y-1]=arguments[y];c[l].fn.apply(c[l].context,f)}}return!0};re.prototype.on=function(t,r,n){return yl(this,t,r,n,!1)};re.prototype.once=function(t,r,n){return yl(this,t,r,n,!0)};re.prototype.removeListener=function(t,r,n,i){var s=se?se+t:t;if(!this._events[s])return this;if(!r)return ms(this,s),this;var o=this._events[s];if(o.fn)o.fn===r&&(!i||o.once)&&(!n||o.context===n)&&ms(this,s);else{for(var a=0,c=[],u=o.length;a<u;a++)(o[a].fn!==r||i&&!o[a].once||n&&o[a].context!==n)&&c.push(o[a]);c.length?this._events[s]=c.length===1?c[0]:c:ms(this,s)}return this};re.prototype.removeAllListeners=function(t){var r;return t?(r=se?se+t:t,this._events[r]&&ms(this,r)):(this._events=new ri,this._eventsCount=0),this};re.prototype.off=re.prototype.removeListener;re.prototype.addListener=re.prototype.on;re.prefixed=se;re.EventEmitter=re;typeof Ga<"u"&&(Ga.exports=re)});var S1={};Kt(S1,{RELAY_V2_HOP_CODEC:()=>we,RELAY_V2_STOP_CODEC:()=>Yr,circuitRelayServer:()=>pl,circuitRelayTransport:()=>Ol});var T1=Symbol.for("@libp2p/connection");var I1=Symbol.for("@libp2p/content-routing");var R1=Symbol.for("@libp2p/peer-discovery");var g0=Symbol.for("@libp2p/peer-id");var N1=Symbol.for("@libp2p/peer-routing");var x0;(function(e){e.Accept="accept",e.Ignore="ignore",e.Reject="reject"})(x0||(x0={}));var b0=Symbol.for("@libp2p/transport");var v0;(function(e){e[e.FATAL_ALL=0]="FATAL_ALL",e[e.NO_FATAL=1]="NO_FATAL"})(v0||(v0={}));var H=class extends Error{code;props;constructor(t,r,n){super(t),this.code=r,this.name=n?.name??"CodeError",this.props=n??{}}};var E0="ERR_INVALID_PARAMETERS";var me=class extends EventTarget{#t=new Map;listenerCount(t){let r=this.#t.get(t);return r==null?0:r.length}addEventListener(t,r,n){super.addEventListener(t,r,n);let i=this.#t.get(t);i==null&&(i=[],this.#t.set(t,i)),i.push({callback:r,once:(n!==!0&&n!==!1&&n?.once)??!1})}removeEventListener(t,r,n){super.removeEventListener(t.toString(),r??null,n);let i=this.#t.get(t);i!=null&&(i=i.filter(({callback:s})=>s!==r),this.#t.set(t,i))}dispatchEvent(t){let r=super.dispatchEvent(t),n=this.#t.get(t.type);return n==null||(n=n.filter(({once:i})=>!i),this.#t.set(t.type,n)),r}safeDispatchEvent(t,r){return this.dispatchEvent(new Jl(t,r))}},Ns=class extends Event{detail;constructor(t,r){super(t,r),this.detail=r?.detail}},Jl=globalThis.CustomEvent??Ns,w0=(e,...t)=>{try{[...t]}catch{}};var Ms={};Kt(Ms,{base58btc:()=>kt,base58flickr:()=>ih});function jl(e,t){if(e.length>=255)throw new TypeError("Alphabet too long");for(var r=new Uint8Array(256),n=0;n<r.length;n++)r[n]=255;for(var i=0;i<e.length;i++){var s=e.charAt(i),o=s.charCodeAt(0);if(r[o]!==255)throw new TypeError(s+" is ambiguous");r[o]=i}var a=e.length,c=e.charAt(0),u=Math.log(a)/Math.log(256),f=Math.log(256)/Math.log(a);function l(d){if(d instanceof Uint8Array||(ArrayBuffer.isView(d)?d=new Uint8Array(d.buffer,d.byteOffset,d.byteLength):Array.isArray(d)&&(d=Uint8Array.from(d))),!(d instanceof Uint8Array))throw new TypeError("Expected Uint8Array");if(d.length===0)return"";for(var p=0,m=0,x=0,E=d.length;x!==E&&d[x]===0;)x++,p++;for(var b=(E-x)*f+1>>>0,R=new Uint8Array(b);x!==E;){for(var w=d[x],S=0,L=b-1;(w!==0||S<m)&&L!==-1;L--,S++)w+=256*R[L]>>>0,R[L]=w%a>>>0,w=w/a>>>0;if(w!==0)throw new Error("Non-zero carry");m=S,x++}for(var D=b-m;D!==b&&R[D]===0;)D++;for(var Y=c.repeat(p);D<b;++D)Y+=e.charAt(R[D]);return Y}function h(d){if(typeof d!="string")throw new TypeError("Expected String");if(d.length===0)return new Uint8Array;var p=0;if(d[p]!==" "){for(var m=0,x=0;d[p]===c;)m++,p++;for(var E=(d.length-p)*u+1>>>0,b=new Uint8Array(E);d[p];){var R=r[d.charCodeAt(p)];if(R===255)return;for(var w=0,S=E-1;(R!==0||w<x)&&S!==-1;S--,w++)R+=a*b[S]>>>0,b[S]=R%256>>>0,R=R/256>>>0;if(R!==0)throw new Error("Non-zero carry");x=w,p++}if(d[p]!==" "){for(var L=E-x;L!==E&&b[L]===0;)L++;for(var D=new Uint8Array(m+(E-L)),Y=m;L!==E;)D[Y++]=b[L++];return D}}}function y(d){var p=h(d);if(p)return p;throw new Error(`Non-${t} character`)}return{encode:l,decodeUnsafe:h,decode:y}}var th=jl,eh=th,S0=eh;var dx=new Uint8Array(0);var A0=(e,t)=>{if(e===t)return!0;if(e.byteLength!==t.byteLength)return!1;for(let r=0;r<e.byteLength;r++)if(e[r]!==t[r])return!1;return!0},ze=e=>{if(e instanceof Uint8Array&&e.constructor.name==="Uint8Array")return e;if(e instanceof ArrayBuffer)return new Uint8Array(e);if(ArrayBuffer.isView(e))return new Uint8Array(e.buffer,e.byteOffset,e.byteLength);throw new Error("Unknown type, must be binary type")};var T0=e=>new TextEncoder().encode(e),B0=e=>new TextDecoder().decode(e);var Ps=class{constructor(t,r,n){this.name=t,this.prefix=r,this.baseEncode=n}encode(t){if(t instanceof Uint8Array)return`${this.prefix}${this.baseEncode(t)}`;throw Error("Unknown type, must be binary type")}},ks=class{constructor(t,r,n){if(this.name=t,this.prefix=r,r.codePointAt(0)===void 0)throw new Error("Invalid prefix character");this.prefixCodePoint=r.codePointAt(0),this.baseDecode=n}decode(t){if(typeof t=="string"){if(t.codePointAt(0)!==this.prefixCodePoint)throw Error(`Unable to decode multibase string ${JSON.stringify(t)}, ${this.name} decoder only supports inputs prefixed with ${this.prefix}`);return this.baseDecode(t.slice(this.prefix.length))}else throw Error("Can only multibase decode strings")}or(t){return C0(this,t)}},Us=class{constructor(t){this.decoders=t}or(t){return C0(this,t)}decode(t){let r=t[0],n=this.decoders[r];if(n)return n.decode(t);throw RangeError(`Unable to decode multibase string ${JSON.stringify(t)}, only inputs prefixed with ${Object.keys(this.decoders)} are supported`)}},C0=(e,t)=>new Us({...e.decoders||{[e.prefix]:e},...t.decoders||{[t.prefix]:t}}),Os=class{constructor(t,r,n,i){this.name=t,this.prefix=r,this.baseEncode=n,this.baseDecode=i,this.encoder=new Ps(t,r,n),this.decoder=new ks(t,r,i)}encode(t){return this.encoder.encode(t)}decode(t){return this.decoder.decode(t)}},Jr=({name:e,prefix:t,encode:r,decode:n})=>new Os(e,t,r,n),ar=({prefix:e,name:t,alphabet:r})=>{let{encode:n,decode:i}=S0(r,t);return Jr({prefix:e,name:t,encode:n,decode:s=>ze(i(s))})},rh=(e,t,r,n)=>{let i={};for(let f=0;f<t.length;++f)i[t[f]]=f;let s=e.length;for(;e[s-1]==="=";)--s;let o=new Uint8Array(s*r/8|0),a=0,c=0,u=0;for(let f=0;f<s;++f){let l=i[e[f]];if(l===void 0)throw new SyntaxError(`Non-${n} character`);c=c<<r|l,a+=r,a>=8&&(a-=8,o[u++]=255&c>>a)}if(a>=r||255&c<<8-a)throw new SyntaxError("Unexpected end of data");return o},nh=(e,t,r)=>{let n=t[t.length-1]==="=",i=(1<<r)-1,s="",o=0,a=0;for(let c=0;c<e.length;++c)for(a=a<<8|e[c],o+=8;o>r;)o-=r,s+=t[i&a>>o];if(o&&(s+=t[i&a<<r-o]),n)for(;s.length*r&7;)s+="=";return s},Bt=({name:e,prefix:t,bitsPerChar:r,alphabet:n})=>Jr({prefix:t,name:e,encode(i){return nh(i,n,r)},decode(i){return rh(i,n,r,e)}});var kt=ar({name:"base58btc",prefix:"z",alphabet:"123456789ABCDEFGHJKLMNPQRSTUVWXYZabcdefghijkmnopqrstuvwxyz"}),ih=ar({name:"base58flickr",prefix:"Z",alphabet:"123456789abcdefghijkmnopqrstuvwxyzABCDEFGHJKLMNPQRSTUVWXYZ"});var Ks={};Kt(Ks,{base10:()=>sh});var sh=ar({prefix:"9",name:"base10",alphabet:"0123456789"});var Fs={};Kt(Fs,{base16:()=>oh,base16upper:()=>ah});var oh=Bt({prefix:"f",name:"base16",alphabet:"0123456789abcdef",bitsPerChar:4}),ah=Bt({prefix:"F",name:"base16upper",alphabet:"0123456789ABCDEF",bitsPerChar:4});var Vs={};Kt(Vs,{base2:()=>ch});var ch=Bt({prefix:"0",name:"base2",alphabet:"01",bitsPerChar:1});var qs={};Kt(qs,{base256emoji:()=>dh});var _0=Array.from("\u{1F680}\u{1FA90}\u2604\u{1F6F0}\u{1F30C}\u{1F311}\u{1F312}\u{1F313}\u{1F314}\u{1F315}\u{1F316}\u{1F317}\u{1F318}\u{1F30D}\u{1F30F}\u{1F30E}\u{1F409}\u2600\u{1F4BB}\u{1F5A5}\u{1F4BE}\u{1F4BF}\u{1F602}\u2764\u{1F60D}\u{1F923}\u{1F60A}\u{1F64F}\u{1F495}\u{1F62D}\u{1F618}\u{1F44D}\u{1F605}\u{1F44F}\u{1F601}\u{1F525}\u{1F970}\u{1F494}\u{1F496}\u{1F499}\u{1F622}\u{1F914}\u{1F606}\u{1F644}\u{1F4AA}\u{1F609}\u263A\u{1F44C}\u{1F917}\u{1F49C}\u{1F614}\u{1F60E}\u{1F607}\u{1F339}\u{1F926}\u{1F389}\u{1F49E}\u270C\u2728\u{1F937}\u{1F631}\u{1F60C}\u{1F338}\u{1F64C}\u{1F60B}\u{1F497}\u{1F49A}\u{1F60F}\u{1F49B}\u{1F642}\u{1F493}\u{1F929}\u{1F604}\u{1F600}\u{1F5A4}\u{1F603}\u{1F4AF}\u{1F648}\u{1F447}\u{1F3B6}\u{1F612}\u{1F92D}\u2763\u{1F61C}\u{1F48B}\u{1F440}\u{1F62A}\u{1F611}\u{1F4A5}\u{1F64B}\u{1F61E}\u{1F629}\u{1F621}\u{1F92A}\u{1F44A}\u{1F973}\u{1F625}\u{1F924}\u{1F449}\u{1F483}\u{1F633}\u270B\u{1F61A}\u{1F61D}\u{1F634}\u{1F31F}\u{1F62C}\u{1F643}\u{1F340}\u{1F337}\u{1F63B}\u{1F613}\u2B50\u2705\u{1F97A}\u{1F308}\u{1F608}\u{1F918}\u{1F4A6}\u2714\u{1F623}\u{1F3C3}\u{1F490}\u2639\u{1F38A}\u{1F498}\u{1F620}\u261D\u{1F615}\u{1F33A}\u{1F382}\u{1F33B}\u{1F610}\u{1F595}\u{1F49D}\u{1F64A}\u{1F639}\u{1F5E3}\u{1F4AB}\u{1F480}\u{1F451}\u{1F3B5}\u{1F91E}\u{1F61B}\u{1F534}\u{1F624}\u{1F33C}\u{1F62B}\u26BD\u{1F919}\u2615\u{1F3C6}\u{1F92B}\u{1F448}\u{1F62E}\u{1F646}\u{1F37B}\u{1F343}\u{1F436}\u{1F481}\u{1F632}\u{1F33F}\u{1F9E1}\u{1F381}\u26A1\u{1F31E}\u{1F388}\u274C\u270A\u{1F44B}\u{1F630}\u{1F928}\u{1F636}\u{1F91D}\u{1F6B6}\u{1F4B0}\u{1F353}\u{1F4A2}\u{1F91F}\u{1F641}\u{1F6A8}\u{1F4A8}\u{1F92C}\u2708\u{1F380}\u{1F37A}\u{1F913}\u{1F619}\u{1F49F}\u{1F331}\u{1F616}\u{1F476}\u{1F974}\u25B6\u27A1\u2753\u{1F48E}\u{1F4B8}\u2B07\u{1F628}\u{1F31A}\u{1F98B}\u{1F637}\u{1F57A}\u26A0\u{1F645}\u{1F61F}\u{1F635}\u{1F44E}\u{1F932}\u{1F920}\u{1F927}\u{1F4CC}\u{1F535}\u{1F485}\u{1F9D0}\u{1F43E}\u{1F352}\u{1F617}\u{1F911}\u{1F30A}\u{1F92F}\u{1F437}\u260E\u{1F4A7}\u{1F62F}\u{1F486}\u{1F446}\u{1F3A4}\u{1F647}\u{1F351}\u2744\u{1F334}\u{1F4A3}\u{1F438}\u{1F48C}\u{1F4CD}\u{1F940}\u{1F922}\u{1F445}\u{1F4A1}\u{1F4A9}\u{1F450}\u{1F4F8}\u{1F47B}\u{1F910}\u{1F92E}\u{1F3BC}\u{1F975}\u{1F6A9}\u{1F34E}\u{1F34A}\u{1F47C}\u{1F48D}\u{1F4E3}\u{1F942}"),uh=_0.reduce((e,t,r)=>(e[r]=t,e),[]),fh=_0.reduce((e,t,r)=>(e[t.codePointAt(0)]=r,e),[]);function lh(e){return e.reduce((t,r)=>(t+=uh[r],t),"")}function hh(e){let t=[];for(let r of e){let n=fh[r.codePointAt(0)];if(n===void 0)throw new Error(`Non-base256emoji character: ${r}`);t.push(n)}return new Uint8Array(t)}var dh=Jr({prefix:"\u{1F680}",name:"base256emoji",encode:lh,decode:hh});var Hs={};Kt(Hs,{base32:()=>Ge,base32hex:()=>gh,base32hexpad:()=>vh,base32hexpadupper:()=>bh,base32hexupper:()=>xh,base32pad:()=>yh,base32padupper:()=>mh,base32upper:()=>ph,base32z:()=>Eh});var Ge=Bt({prefix:"b",name:"base32",alphabet:"abcdefghijklmnopqrstuvwxyz234567",bitsPerChar:5}),ph=Bt({prefix:"B",name:"base32upper",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZ234567",bitsPerChar:5}),yh=Bt({prefix:"c",name:"base32pad",alphabet:"abcdefghijklmnopqrstuvwxyz234567=",bitsPerChar:5}),mh=Bt({prefix:"C",name:"base32padupper",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZ234567=",bitsPerChar:5}),gh=Bt({prefix:"v",name:"base32hex",alphabet:"0123456789abcdefghijklmnopqrstuv",bitsPerChar:5}),xh=Bt({prefix:"V",name:"base32hexupper",alphabet:"0123456789ABCDEFGHIJKLMNOPQRSTUV",bitsPerChar:5}),vh=Bt({prefix:"t",name:"base32hexpad",alphabet:"0123456789abcdefghijklmnopqrstuv=",bitsPerChar:5}),bh=Bt({prefix:"T",name:"base32hexpadupper",alphabet:"0123456789ABCDEFGHIJKLMNOPQRSTUV=",bitsPerChar:5}),Eh=Bt({prefix:"h",name:"base32z",alphabet:"ybndrfg8ejkmcpqxot1uwisza345h769",bitsPerChar:5});var zs={};Kt(zs,{base36:()=>wh,base36upper:()=>Sh});var wh=ar({prefix:"k",name:"base36",alphabet:"0123456789abcdefghijklmnopqrstuvwxyz"}),Sh=ar({prefix:"K",name:"base36upper",alphabet:"0123456789ABCDEFGHIJKLMNOPQRSTUVWXYZ"});var Gs={};Kt(Gs,{base64:()=>fi,base64pad:()=>Ah,base64url:()=>Th,base64urlpad:()=>Bh});var fi=Bt({prefix:"m",name:"base64",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/",bitsPerChar:6}),Ah=Bt({prefix:"M",name:"base64pad",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/=",bitsPerChar:6}),Th=Bt({prefix:"u",name:"base64url",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789-_",bitsPerChar:6}),Bh=Bt({prefix:"U",name:"base64urlpad",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789-_=",bitsPerChar:6});var Ws={};Kt(Ws,{base8:()=>Ih});var Ih=Bt({prefix:"7",name:"base8",alphabet:"01234567",bitsPerChar:3});var Ys={};Kt(Ys,{identity:()=>Ch});var Ch=Jr({prefix:"\0",name:"identity",encode:e=>B0(e),decode:e=>T0(e)});var Cx=new TextEncoder,_x=new TextDecoder;var Qs={};Kt(Qs,{identity:()=>cr});var Lh=D0,R0=128,Dh=127,Nh=~Dh,Ph=Math.pow(2,31);function D0(e,t,r){t=t||[],r=r||0;for(var n=r;e>=Ph;)t[r++]=e&255|R0,e/=128;for(;e&Nh;)t[r++]=e&255|R0,e>>>=7;return t[r]=e|0,D0.bytes=r-n+1,t}var kh=$s,Uh=128,L0=127;function $s(e,n){var r=0,n=n||0,i=0,s=n,o,a=e.length;do{if(s>=a)throw $s.bytes=0,new RangeError("Could not decode varint");o=e[s++],r+=i<28?(o&L0)<<i:(o&L0)*Math.pow(2,i),i+=7}while(o>=Uh);return $s.bytes=s-n,r}var Oh=Math.pow(2,7),Mh=Math.pow(2,14),Kh=Math.pow(2,21),Fh=Math.pow(2,28),Vh=Math.pow(2,35),qh=Math.pow(2,42),Hh=Math.pow(2,49),zh=Math.pow(2,56),Gh=Math.pow(2,63),Wh=function(e){return e<Oh?1:e<Mh?2:e<Kh?3:e<Fh?4:e<Vh?5:e<qh?6:e<Hh?7:e<zh?8:e<Gh?9:10},Yh={encode:Lh,decode:kh,encodingLength:Wh},$h=Yh,_n=$h;var Rn=(e,t=0)=>[_n.decode(e,t),_n.decode.bytes],jr=(e,t,r=0)=>(_n.encode(e,t,r),t),tn=e=>_n.encodingLength(e);var Ne=(e,t)=>{let r=t.byteLength,n=tn(e),i=n+tn(r),s=new Uint8Array(i+r);return jr(e,s,0),jr(r,s,n),s.set(t,i),new en(e,r,t,s)},Cr=e=>{let t=ze(e),[r,n]=Rn(t),[i,s]=Rn(t.subarray(n)),o=t.subarray(n+s);if(o.byteLength!==i)throw new Error("Incorrect length");return new en(r,i,o,t)},N0=(e,t)=>{if(e===t)return!0;{let r=t;return e.code===r.code&&e.size===r.size&&r.bytes instanceof Uint8Array&&A0(e.bytes,r.bytes)}},en=class{constructor(t,r,n,i){this.code=t,this.size=r,this.digest=n,this.bytes=i}};var P0=0,Qh="identity",k0=ze,Zh=e=>Ne(P0,k0(e)),cr={code:P0,name:Qh,encode:k0,digest:Zh};var Js={};Kt(Js,{sha256:()=>Ut,sha512:()=>Xh});var Xs=({name:e,code:t,encode:r})=>new Zs(e,t,r),Zs=class{constructor(t,r,n){this.name=t,this.code=r,this.encode=n}digest(t){if(t instanceof Uint8Array){let r=this.encode(t);return r instanceof Uint8Array?Ne(this.code,r):r.then(n=>Ne(this.code,n))}else throw Error("Unknown type, must be binary type")}};var O0=e=>async t=>new Uint8Array(await crypto.subtle.digest(e,t)),Ut=Xs({name:"sha2-256",code:18,encode:O0("SHA-256")}),Xh=Xs({name:"sha2-512",code:19,encode:O0("SHA-512")});var M0=(e,t)=>{let{bytes:r,version:n}=e;switch(n){case 0:return jh(r,js(e),t||kt.encoder);default:return td(r,js(e),t||Ge.encoder)}};var K0=new WeakMap,js=e=>{let t=K0.get(e);if(t==null){let r=new Map;return K0.set(e,r),r}return t},fe=class e{constructor(t,r,n,i){this.code=r,this.version=t,this.multihash=n,this.bytes=i,this["/"]=i}get asCID(){return this}get byteOffset(){return this.bytes.byteOffset}get byteLength(){return this.bytes.byteLength}toV0(){switch(this.version){case 0:return this;case 1:{let{code:t,multihash:r}=this;if(t!==Ln)throw new Error("Cannot convert a non dag-pb CID to CIDv0");if(r.code!==ed)throw new Error("Cannot convert non sha2-256 multihash CID to CIDv0");return e.createV0(r)}default:throw Error(`Can not convert CID version ${this.version} to version 0. This is a bug please report`)}}toV1(){switch(this.version){case 0:{let{code:t,digest:r}=this.multihash,n=Ne(t,r);return e.createV1(this.code,n)}case 1:return this;default:throw Error(`Can not convert CID version ${this.version} to version 1. This is a bug please report`)}}equals(t){return e.equals(this,t)}static equals(t,r){let n=r;return n&&t.code===n.code&&t.version===n.version&&N0(t.multihash,n.multihash)}toString(t){return M0(this,t)}toJSON(){return{"/":M0(this)}}link(){return this}get[Symbol.toStringTag](){return"CID"}[Symbol.for("nodejs.util.inspect.custom")](){return`CID(${this.toString()})`}static asCID(t){if(t==null)return null;let r=t;if(r instanceof e)return r;if(r["/"]!=null&&r["/"]===r.bytes||r.asCID===r){let{version:n,code:i,multihash:s,bytes:o}=r;return new e(n,i,s,o||F0(n,i,s.bytes))}else if(r[rd]===!0){let{version:n,multihash:i,code:s}=r,o=Cr(i);return e.create(n,s,o)}else return null}static create(t,r,n){if(typeof r!="number")throw new Error("String codecs are no longer supported");if(!(n.bytes instanceof Uint8Array))throw new Error("Invalid digest");switch(t){case 0:{if(r!==Ln)throw new Error(`Version 0 CID must use dag-pb (code: ${Ln}) block encoding`);return new e(t,r,n,n.bytes)}case 1:{let i=F0(t,r,n.bytes);return new e(t,r,n,i)}default:throw new Error("Invalid version")}}static createV0(t){return e.create(0,Ln,t)}static createV1(t,r){return e.create(1,t,r)}static decode(t){let[r,n]=e.decodeFirst(t);if(n.length)throw new Error("Incorrect length");return r}static decodeFirst(t){let r=e.inspectBytes(t),n=r.size-r.multihashSize,i=ze(t.subarray(n,n+r.multihashSize));if(i.byteLength!==r.multihashSize)throw new Error("Incorrect length");let s=i.subarray(r.multihashSize-r.digestSize),o=new en(r.multihashCode,r.digestSize,s,i);return[r.version===0?e.createV0(o):e.createV1(r.codec,o),t.subarray(r.size)]}static inspectBytes(t){let r=0,n=()=>{let[l,h]=Rn(t.subarray(r));return r+=h,l},i=n(),s=Ln;if(i===18?(i=0,r=0):s=n(),i!==0&&i!==1)throw new RangeError(`Invalid CID version ${i}`);let o=r,a=n(),c=n(),u=r+c,f=u-o;return{version:i,codec:s,multihashCode:a,digestSize:c,multihashSize:f,size:u}}static parse(t,r){let[n,i]=Jh(t,r),s=e.decode(i);if(s.version===0&&t[0]!=="Q")throw Error("Version 0 CID string must not include multibase prefix");return js(s).set(n,t),s}},Jh=(e,t)=>{switch(e[0]){case"Q":{let r=t||kt;return[kt.prefix,r.decode(`${kt.prefix}${e}`)]}case kt.prefix:{let r=t||kt;return[kt.prefix,r.decode(e)]}case Ge.prefix:{let r=t||Ge;return[Ge.prefix,r.decode(e)]}default:{if(t==null)throw Error("To parse non base32 or base58btc encoded CID multibase decoder must be provided");return[e[0],t.decode(e)]}}},jh=(e,t,r)=>{let{prefix:n}=r;if(n!==kt.prefix)throw Error(`Cannot string encode V0 in ${r.name} encoding`);let i=t.get(n);if(i==null){let s=r.encode(e).slice(1);return t.set(n,s),s}else return i},td=(e,t,r)=>{let{prefix:n}=r,i=t.get(n);if(i==null){let s=r.encode(e);return t.set(n,s),s}else return i},Ln=112,ed=18,F0=(e,t,r)=>{let n=tn(e),i=n+tn(t),s=new Uint8Array(i+r.byteLength);return jr(e,s,0),jr(t,s,n),s.set(r,i),s},rd=Symbol.for("@ipld/js-cid/CID");var ur={...Ys,...Vs,...Ws,...Ks,...Fs,...Hs,...zs,...Ms,...Gs,...qs},Gx={...Js,...Qs};function Ct(e,t){if(e===t)return!0;if(e.byteLength!==t.byteLength)return!1;for(let r=0;r<e.byteLength;r++)if(e[r]!==t[r])return!1;return!0}var nd=Symbol.for("nodejs.util.inspect.custom"),V0=Object.values(ur).map(e=>e.decoder).reduce((e,t)=>e.or(t),ur.identity.decoder),q0=114,to=36,eo=37,Dn=class{type;multihash;privateKey;publicKey;string;constructor(t){this.type=t.type,this.multihash=t.multihash,this.privateKey=t.privateKey,Object.defineProperty(this,"string",{enumerable:!1,writable:!0})}get[Symbol.toStringTag](){return`PeerId(${this.toString()})`}[g0]=!0;toString(){return this.string==null&&(this.string=kt.encode(this.multihash.bytes).slice(1)),this.string}toCID(){return fe.createV1(q0,this.multihash)}toBytes(){return this.multihash.bytes}toJSON(){return this.toString()}equals(t){if(t instanceof Uint8Array)return Ct(this.multihash.bytes,t);if(typeof t=="string")return St(t).equals(this);if(t?.multihash?.bytes!=null)return Ct(this.multihash.bytes,t.multihash.bytes);throw new Error("not valid Id")}[nd](){return`PeerId(${this.toString()})`}},rn=class extends Dn{type="RSA";publicKey;constructor(t){super({...t,type:"RSA"}),this.publicKey=t.publicKey}},nn=class extends Dn{type="Ed25519";publicKey;constructor(t){super({...t,type:"Ed25519"}),this.publicKey=t.multihash.digest}},sn=class extends Dn{type="secp256k1";publicKey;constructor(t){super({...t,type:"secp256k1"}),this.publicKey=t.multihash.digest}};function St(e,t){if(t=t??V0,e.charAt(0)==="1"||e.charAt(0)==="Q"){let r=Cr(kt.decode(`z${e}`));return e.startsWith("12D")?new nn({multihash:r}):e.startsWith("16U")?new sn({multihash:r}):new rn({multihash:r})}return on(V0.decode(e))}function on(e){try{let t=Cr(e);if(t.code===cr.code){if(t.digest.length===to)return new nn({multihash:t});if(t.digest.length===eo)return new sn({multihash:t})}if(t.code===Ut.code)return new rn({multihash:t})}catch{return id(fe.decode(e))}throw new Error("Supplied PeerID CID is invalid")}function id(e){if(e==null||e.multihash==null||e.version==null||e.version===1&&e.code!==q0)throw new Error("Supplied PeerID CID is invalid");let t=e.multihash;if(t.code===Ut.code)return new rn({multihash:e.multihash});if(t.code===cr.code){if(t.digest.length===to)return new nn({multihash:e.multihash});if(t.digest.length===eo)return new sn({multihash:e.multihash})}throw new Error("Supplied PeerID CID is invalid")}async function H0(e,t){return e.length===to?new nn({multihash:Ne(cr.code,e),privateKey:t}):e.length===eo?new sn({multihash:Ne(cr.code,e),privateKey:t}):new rn({multihash:await Ut.digest(e),publicKey:e,privateKey:t})}var JE=Yt(Un(),1),jE=Yt(su(),1);var bg=Yt(ht(),1);function pr(e){return globalThis.Buffer!=null?new Uint8Array(e.buffer,e.byteOffset,e.byteLength):e}function Qe(e=0){return globalThis.Buffer?.alloc!=null?pr(globalThis.Buffer.alloc(e)):new Uint8Array(e)}function $t(e=0){return globalThis.Buffer?.allocUnsafe!=null?pr(globalThis.Buffer.allocUnsafe(e)):new Uint8Array(e)}function au(e,t,r,n){return{name:e,prefix:t,encoder:{name:e,prefix:t,encode:r},decoder:{decode:n}}}var ou=au("utf8","u",e=>"u"+new TextDecoder("utf8").decode(e),e=>new TextEncoder().encode(e.substring(1))),To=au("ascii","a",e=>{let t="a";for(let r=0;r<e.length;r++)t+=String.fromCharCode(e[r]);return t},e=>{e=e.substring(1);let t=$t(e.length);for(let r=0;r<e.length;r++)t[r]=e.charCodeAt(r);return t}),_y={utf8:ou,"utf-8":ou,hex:ur.base16,latin1:To,ascii:To,binary:To,...ur},Ri=_y;function Nt(e,t="utf8"){let r=Ri[t];if(r==null)throw new Error(`Unsupported encoding "${t}"`);return(t==="utf8"||t==="utf-8")&&globalThis.Buffer!=null&&globalThis.Buffer.from!=null?pr(globalThis.Buffer.from(e,"utf-8")):r.decoder.decode(`${r.prefix}${e}`)}var ra={};Kt(ra,{Ed25519PrivateKey:()=>Vr,Ed25519PublicKey:()=>Gn,generateKeyPair:()=>zm,generateKeyPairFromSeed:()=>qu,unmarshalEd25519PrivateKey:()=>qm,unmarshalEd25519PublicKey:()=>Hm});var q2=Yt(Dt(),1),H2=Yt(Bi(),1),cu=Yt(ht(),1);function Ot(e,t){if(globalThis.Buffer!=null)return pr(globalThis.Buffer.concat(e,t));t==null&&(t=e.reduce((i,s)=>i+s.length,0));let r=$t(t),n=0;for(let i of e)r.set(i,n),n+=i.length;return pr(r)}function pt(e,t="utf8"){let r=Ri[t];if(r==null)throw new Error(`Unsupported encoding "${t}"`);return(t==="utf8"||t==="utf-8")&&globalThis.Buffer!=null&&globalThis.Buffer.from!=null?globalThis.Buffer.from(e.buffer,e.byteOffset,e.byteLength).toString("utf8"):r.encoder.encode(e).substring(1)}function Be(e,t){let r=Uint8Array.from(e.abs().toByteArray());if(r=r[0]===0?r.subarray(1):r,t!=null){if(r.length>t)throw new Error("byte array longer than desired length");r=Ot([new Uint8Array(t-r.length),r])}return pt(r,"base64url")}function le(e){let t=uu(e);return new cu.default.jsbn.BigInteger(pt(t,"base16"),16)}function uu(e,t){let r=Nt(e,"base64urlpad");if(t!=null){if(r.length>t)throw new Error("byte array longer than desired length");r=Ot([new Uint8Array(t-r.length),r])}return r}function ve(e){return e==null?!1:typeof e.then=="function"&&typeof e.catch=="function"&&typeof e.finally=="function"}function fu(e){if(!Number.isSafeInteger(e)||e<0)throw new Error(`Wrong positive integer: ${e}`)}function Bo(e,...t){if(!(e instanceof Uint8Array))throw new Error("Expected Uint8Array");if(t.length>0&&!t.includes(e.length))throw new Error(`Expected Uint8Array of length ${t}, not of length=${e.length}`)}function lu(e){if(typeof e!="function"||typeof e.create!="function")throw new Error("Hash should be wrapped by utils.wrapConstructor");fu(e.outputLen),fu(e.blockLen)}function ln(e,t=!0){if(e.destroyed)throw new Error("Hash instance has been destroyed");if(t&&e.finished)throw new Error("Hash#digest() has already been called")}function hu(e,t){Bo(e);let r=t.outputLen;if(e.length<r)throw new Error(`digestInto() expects output buffer of length at least ${r}`)}var Li=typeof globalThis=="object"&&"crypto"in globalThis?globalThis.crypto:void 0;var du=e=>e instanceof Uint8Array;var Di=e=>new DataView(e.buffer,e.byteOffset,e.byteLength),Ie=(e,t)=>e<<32-t|e>>>t,Ry=new Uint8Array(new Uint32Array([287454020]).buffer)[0]===68;if(!Ry)throw new Error("Non little-endian hardware is not supported");function Io(e){if(typeof e!="string")throw new Error(`utf8ToBytes expected string, got ${typeof e}`);return new Uint8Array(new TextEncoder().encode(e))}function Kn(e){if(typeof e=="string"&&(e=Io(e)),!du(e))throw new Error(`expected Uint8Array, got ${typeof e}`);return e}function Ni(...e){let t=new Uint8Array(e.reduce((n,i)=>n+i.length,0)),r=0;return e.forEach(n=>{if(!du(n))throw new Error("Uint8Array expected");t.set(n,r),r+=n.length}),t}var hn=class{clone(){return this._cloneInto()}},X2={}.toString;function Pi(e){let t=n=>e().update(Kn(n)).digest(),r=e();return t.outputLen=r.outputLen,t.blockLen=r.blockLen,t.create=()=>e(),t}function dn(e=32){if(Li&&typeof Li.getRandomValues=="function")return Li.getRandomValues(new Uint8Array(e));throw new Error("crypto.getRandomValues must be defined")}function Ly(e,t,r,n){if(typeof e.setBigUint64=="function")return e.setBigUint64(t,r,n);let i=BigInt(32),s=BigInt(4294967295),o=Number(r>>i&s),a=Number(r&s),c=n?4:0,u=n?0:4;e.setUint32(t+c,o,n),e.setUint32(t+u,a,n)}var pn=class extends hn{constructor(t,r,n,i){super(),this.blockLen=t,this.outputLen=r,this.padOffset=n,this.isLE=i,this.finished=!1,this.length=0,this.pos=0,this.destroyed=!1,this.buffer=new Uint8Array(t),this.view=Di(this.buffer)}update(t){ln(this);let{view:r,buffer:n,blockLen:i}=this;t=Kn(t);let s=t.length;for(let o=0;o<s;){let a=Math.min(i-this.pos,s-o);if(a===i){let c=Di(t);for(;i<=s-o;o+=i)this.process(c,o);continue}n.set(t.subarray(o,o+a),this.pos),this.pos+=a,o+=a,this.pos===i&&(this.process(r,0),this.pos=0)}return this.length+=t.length,this.roundClean(),this}digestInto(t){ln(this),hu(t,this),this.finished=!0;let{buffer:r,view:n,blockLen:i,isLE:s}=this,{pos:o}=this;r[o++]=128,this.buffer.subarray(o).fill(0),this.padOffset>i-o&&(this.process(n,0),o=0);for(let l=o;l<i;l++)r[l]=0;Ly(n,i-8,BigInt(this.length*8),s),this.process(n,0);let a=Di(t),c=this.outputLen;if(c%4)throw new Error("_sha2: outputLen should be aligned to 32bit");let u=c/4,f=this.get();if(u>f.length)throw new Error("_sha2: outputLen bigger than state");for(let l=0;l<u;l++)a.setUint32(4*l,f[l],s)}digest(){let{buffer:t,outputLen:r}=this;this.digestInto(t);let n=t.slice(0,r);return this.destroy(),n}_cloneInto(t){t||(t=new this.constructor),t.set(...this.get());let{blockLen:r,buffer:n,length:i,finished:s,destroyed:o,pos:a}=this;return t.length=i,t.pos=a,t.finished=s,t.destroyed=o,i%r&&t.buffer.set(n),t}};var ki=BigInt(4294967295),Co=BigInt(32);function pu(e,t=!1){return t?{h:Number(e&ki),l:Number(e>>Co&ki)}:{h:Number(e>>Co&ki)|0,l:Number(e&ki)|0}}function Dy(e,t=!1){let r=new Uint32Array(e.length),n=new Uint32Array(e.length);for(let i=0;i<e.length;i++){let{h:s,l:o}=pu(e[i],t);[r[i],n[i]]=[s,o]}return[r,n]}var Ny=(e,t)=>BigInt(e>>>0)<<Co|BigInt(t>>>0),Py=(e,t,r)=>e>>>r,ky=(e,t,r)=>e<<32-r|t>>>r,Uy=(e,t,r)=>e>>>r|t<<32-r,Oy=(e,t,r)=>e<<32-r|t>>>r,My=(e,t,r)=>e<<64-r|t>>>r-32,Ky=(e,t,r)=>e>>>r-32|t<<64-r,Fy=(e,t)=>t,Vy=(e,t)=>e,qy=(e,t,r)=>e<<r|t>>>32-r,Hy=(e,t,r)=>t<<r|e>>>32-r,zy=(e,t,r)=>t<<r-32|e>>>64-r,Gy=(e,t,r)=>e<<r-32|t>>>64-r;function Wy(e,t,r,n){let i=(t>>>0)+(n>>>0);return{h:e+r+(i/2**32|0)|0,l:i|0}}var Yy=(e,t,r)=>(e>>>0)+(t>>>0)+(r>>>0),$y=(e,t,r,n)=>t+r+n+(e/2**32|0)|0,Qy=(e,t,r,n)=>(e>>>0)+(t>>>0)+(r>>>0)+(n>>>0),Zy=(e,t,r,n,i)=>t+r+n+i+(e/2**32|0)|0,Xy=(e,t,r,n,i)=>(e>>>0)+(t>>>0)+(r>>>0)+(n>>>0)+(i>>>0),Jy=(e,t,r,n,i,s)=>t+r+n+i+s+(e/2**32|0)|0;var jy={fromBig:pu,split:Dy,toBig:Ny,shrSH:Py,shrSL:ky,rotrSH:Uy,rotrSL:Oy,rotrBH:My,rotrBL:Ky,rotr32H:Fy,rotr32L:Vy,rotlSH:qy,rotlSL:Hy,rotlBH:zy,rotlBL:Gy,add:Wy,add3L:Yy,add3H:$y,add4L:Qy,add4H:Zy,add5H:Jy,add5L:Xy},Z=jy;var[tm,em]=Z.split(["0x428a2f98d728ae22","0x7137449123ef65cd","0xb5c0fbcfec4d3b2f","0xe9b5dba58189dbbc","0x3956c25bf348b538","0x59f111f1b605d019","0x923f82a4af194f9b","0xab1c5ed5da6d8118","0xd807aa98a3030242","0x12835b0145706fbe","0x243185be4ee4b28c","0x550c7dc3d5ffb4e2","0x72be5d74f27b896f","0x80deb1fe3b1696b1","0x9bdc06a725c71235","0xc19bf174cf692694","0xe49b69c19ef14ad2","0xefbe4786384f25e3","0x0fc19dc68b8cd5b5","0x240ca1cc77ac9c65","0x2de92c6f592b0275","0x4a7484aa6ea6e483","0x5cb0a9dcbd41fbd4","0x76f988da831153b5","0x983e5152ee66dfab","0xa831c66d2db43210","0xb00327c898fb213f","0xbf597fc7beef0ee4","0xc6e00bf33da88fc2","0xd5a79147930aa725","0x06ca6351e003826f","0x142929670a0e6e70","0x27b70a8546d22ffc","0x2e1b21385c26c926","0x4d2c6dfc5ac42aed","0x53380d139d95b3df","0x650a73548baf63de","0x766a0abb3c77b2a8","0x81c2c92e47edaee6","0x92722c851482353b","0xa2bfe8a14cf10364","0xa81a664bbc423001","0xc24b8b70d0f89791","0xc76c51a30654be30","0xd192e819d6ef5218","0xd69906245565a910","0xf40e35855771202a","0x106aa07032bbd1b8","0x19a4c116b8d2d0c8","0x1e376c085141ab53","0x2748774cdf8eeb99","0x34b0bcb5e19b48a8","0x391c0cb3c5c95a63","0x4ed8aa4ae3418acb","0x5b9cca4f7763e373","0x682e6ff3d6b2b8a3","0x748f82ee5defb2fc","0x78a5636f43172f60","0x84c87814a1f0ab72","0x8cc702081a6439ec","0x90befffa23631e28","0xa4506cebde82bde9","0xbef9a3f7b2c67915","0xc67178f2e372532b","0xca273eceea26619c","0xd186b8c721c0c207","0xeada7dd6cde0eb1e","0xf57d4f7fee6ed178","0x06f067aa72176fba","0x0a637dc5a2c898a6","0x113f9804bef90dae","0x1b710b35131c471b","0x28db77f523047d84","0x32caab7b40c72493","0x3c9ebe0a15c9bebc","0x431d67c49c100d4c","0x4cc5d4becb3e42b6","0x597f299cfc657e2a","0x5fcb6fab3ad6faec","0x6c44198c4a475817"].map(e=>BigInt(e))),yr=new Uint32Array(80),mr=new Uint32Array(80),_o=class extends pn{constructor(){super(128,64,16,!1),this.Ah=1779033703,this.Al=-205731576,this.Bh=-1150833019,this.Bl=-2067093701,this.Ch=1013904242,this.Cl=-23791573,this.Dh=-1521486534,this.Dl=1595750129,this.Eh=1359893119,this.El=-1377402159,this.Fh=-1694144372,this.Fl=725511199,this.Gh=528734635,this.Gl=-79577749,this.Hh=1541459225,this.Hl=327033209}get(){let{Ah:t,Al:r,Bh:n,Bl:i,Ch:s,Cl:o,Dh:a,Dl:c,Eh:u,El:f,Fh:l,Fl:h,Gh:y,Gl:d,Hh:p,Hl:m}=this;return[t,r,n,i,s,o,a,c,u,f,l,h,y,d,p,m]}set(t,r,n,i,s,o,a,c,u,f,l,h,y,d,p,m){this.Ah=t|0,this.Al=r|0,this.Bh=n|0,this.Bl=i|0,this.Ch=s|0,this.Cl=o|0,this.Dh=a|0,this.Dl=c|0,this.Eh=u|0,this.El=f|0,this.Fh=l|0,this.Fl=h|0,this.Gh=y|0,this.Gl=d|0,this.Hh=p|0,this.Hl=m|0}process(t,r){for(let b=0;b<16;b++,r+=4)yr[b]=t.getUint32(r),mr[b]=t.getUint32(r+=4);for(let b=16;b<80;b++){let R=yr[b-15]|0,w=mr[b-15]|0,S=Z.rotrSH(R,w,1)^Z.rotrSH(R,w,8)^Z.shrSH(R,w,7),L=Z.rotrSL(R,w,1)^Z.rotrSL(R,w,8)^Z.shrSL(R,w,7),D=yr[b-2]|0,Y=mr[b-2]|0,W=Z.rotrSH(D,Y,19)^Z.rotrBH(D,Y,61)^Z.shrSH(D,Y,6),q=Z.rotrSL(D,Y,19)^Z.rotrBL(D,Y,61)^Z.shrSL(D,Y,6),j=Z.add4L(L,q,mr[b-7],mr[b-16]),lt=Z.add4H(j,S,W,yr[b-7],yr[b-16]);yr[b]=lt|0,mr[b]=j|0}let{Ah:n,Al:i,Bh:s,Bl:o,Ch:a,Cl:c,Dh:u,Dl:f,Eh:l,El:h,Fh:y,Fl:d,Gh:p,Gl:m,Hh:x,Hl:E}=this;for(let b=0;b<80;b++){let R=Z.rotrSH(l,h,14)^Z.rotrSH(l,h,18)^Z.rotrBH(l,h,41),w=Z.rotrSL(l,h,14)^Z.rotrSL(l,h,18)^Z.rotrBL(l,h,41),S=l&y^~l&p,L=h&d^~h&m,D=Z.add5L(E,w,L,em[b],mr[b]),Y=Z.add5H(D,x,R,S,tm[b],yr[b]),W=D|0,q=Z.rotrSH(n,i,28)^Z.rotrBH(n,i,34)^Z.rotrBH(n,i,39),j=Z.rotrSL(n,i,28)^Z.rotrBL(n,i,34)^Z.rotrBL(n,i,39),lt=n&s^n&a^s&a,Ht=i&o^i&c^o&c;x=p|0,E=m|0,p=y|0,m=d|0,y=l|0,d=h|0,{h:l,l:h}=Z.add(u|0,f|0,Y|0,W|0),u=a|0,f=c|0,a=s|0,c=o|0,s=n|0,o=i|0;let I=Z.add3L(W,j,Ht);n=Z.add3H(I,Y,q,lt),i=I|0}({h:n,l:i}=Z.add(this.Ah|0,this.Al|0,n|0,i|0)),{h:s,l:o}=Z.add(this.Bh|0,this.Bl|0,s|0,o|0),{h:a,l:c}=Z.add(this.Ch|0,this.Cl|0,a|0,c|0),{h:u,l:f}=Z.add(this.Dh|0,this.Dl|0,u|0,f|0),{h:l,l:h}=Z.add(this.Eh|0,this.El|0,l|0,h|0),{h:y,l:d}=Z.add(this.Fh|0,this.Fl|0,y|0,d|0),{h:p,l:m}=Z.add(this.Gh|0,this.Gl|0,p|0,m|0),{h:x,l:E}=Z.add(this.Hh|0,this.Hl|0,x|0,E|0),this.set(n,i,s,o,a,c,u,f,l,h,y,d,p,m,x,E)}roundClean(){yr.fill(0),mr.fill(0)}destroy(){this.buffer.fill(0),this.set(0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0)}};var Ro=Pi(()=>new _o);var Mi={};Kt(Mi,{bitGet:()=>cm,bitLen:()=>am,bitMask:()=>Fn,bitSet:()=>um,bytesToHex:()=>Ze,bytesToNumberBE:()=>Xe,bytesToNumberLE:()=>gr,concatBytes:()=>Je,createHmacDrbg:()=>No,ensureBytes:()=>It,equalBytes:()=>sm,hexToBytes:()=>kr,hexToNumber:()=>Do,numberToBytesBE:()=>xr,numberToBytesLE:()=>Ur,numberToHexUnpadded:()=>gu,numberToVarBytesBE:()=>im,utf8ToBytes:()=>om,validateObject:()=>Fe});var mu=BigInt(0),Ui=BigInt(1),rm=BigInt(2),Oi=e=>e instanceof Uint8Array,nm=Array.from({length:256},(e,t)=>t.toString(16).padStart(2,"0"));function Ze(e){if(!Oi(e))throw new Error("Uint8Array expected");let t="";for(let r=0;r<e.length;r++)t+=nm[e[r]];return t}function gu(e){let t=e.toString(16);return t.length&1?`0${t}`:t}function Do(e){if(typeof e!="string")throw new Error("hex string expected, got "+typeof e);return BigInt(e===""?"0":`0x${e}`)}function kr(e){if(typeof e!="string")throw new Error("hex string expected, got "+typeof e);let t=e.length;if(t%2)throw new Error("padded hex string expected, got unpadded hex of length "+t);let r=new Uint8Array(t/2);for(let n=0;n<r.length;n++){let i=n*2,s=e.slice(i,i+2),o=Number.parseInt(s,16);if(Number.isNaN(o)||o<0)throw new Error("Invalid byte sequence");r[n]=o}return r}function Xe(e){return Do(Ze(e))}function gr(e){if(!Oi(e))throw new Error("Uint8Array expected");return Do(Ze(Uint8Array.from(e).reverse()))}function xr(e,t){return kr(e.toString(16).padStart(t*2,"0"))}function Ur(e,t){return xr(e,t).reverse()}function im(e){return kr(gu(e))}function It(e,t,r){let n;if(typeof t=="string")try{n=kr(t)}catch(s){throw new Error(`${e} must be valid hex string, got "${t}". Cause: ${s}`)}else if(Oi(t))n=Uint8Array.from(t);else throw new Error(`${e} must be hex string or Uint8Array`);let i=n.length;if(typeof r=="number"&&i!==r)throw new Error(`${e} expected ${r} bytes, got ${i}`);return n}function Je(...e){let t=new Uint8Array(e.reduce((n,i)=>n+i.length,0)),r=0;return e.forEach(n=>{if(!Oi(n))throw new Error("Uint8Array expected");t.set(n,r),r+=n.length}),t}function sm(e,t){if(e.length!==t.length)return!1;for(let r=0;r<e.length;r++)if(e[r]!==t[r])return!1;return!0}function om(e){if(typeof e!="string")throw new Error(`utf8ToBytes expected string, got ${typeof e}`);return new Uint8Array(new TextEncoder().encode(e))}function am(e){let t;for(t=0;e>mu;e>>=Ui,t+=1);return t}function cm(e,t){return e>>BigInt(t)&Ui}var um=(e,t,r)=>e|(r?Ui:mu)<<BigInt(t),Fn=e=>(rm<<BigInt(e-1))-Ui,Lo=e=>new Uint8Array(e),yu=e=>Uint8Array.from(e);function No(e,t,r){if(typeof e!="number"||e<2)throw new Error("hashLen must be a number");if(typeof t!="number"||t<2)throw new Error("qByteLen must be a number");if(typeof r!="function")throw new Error("hmacFn must be a function");let n=Lo(e),i=Lo(e),s=0,o=()=>{n.fill(1),i.fill(0),s=0},a=(...l)=>r(i,n,...l),c=(l=Lo())=>{i=a(yu([0]),l),n=a(),l.length!==0&&(i=a(yu([1]),l),n=a())},u=()=>{if(s++>=1e3)throw new Error("drbg: tried 1000 values");let l=0,h=[];for(;l<t;){n=a();let y=n.slice();h.push(y),l+=n.length}return Je(...h)};return(l,h)=>{o(),c(l);let y;for(;!(y=h(u()));)c();return o(),y}}var fm={bigint:e=>typeof e=="bigint",function:e=>typeof e=="function",boolean:e=>typeof e=="boolean",string:e=>typeof e=="string",stringOrUint8Array:e=>typeof e=="string"||e instanceof Uint8Array,isSafeInteger:e=>Number.isSafeInteger(e),array:e=>Array.isArray(e),field:(e,t)=>t.Fp.isValid(e),hash:e=>typeof e=="function"&&Number.isSafeInteger(e.outputLen)};function Fe(e,t,r={}){let n=(i,s,o)=>{let a=fm[s];if(typeof a!="function")throw new Error(`Invalid validator "${s}", expected function`);let c=e[i];if(!(o&&c===void 0)&&!a(c,e))throw new Error(`Invalid param ${String(i)}=${c} (${typeof c}), expected ${s}`)};for(let[i,s]of Object.entries(t))n(i,s,!1);for(let[i,s]of Object.entries(r))n(i,s,!0);return e}var Mt=BigInt(0),bt=BigInt(1),Or=BigInt(2),lm=BigInt(3),Po=BigInt(4),xu=BigInt(5),vu=BigInt(8),hm=BigInt(9),dm=BigInt(16);function dt(e,t){let r=e%t;return r>=Mt?r:t+r}function pm(e,t,r){if(r<=Mt||t<Mt)throw new Error("Expected power/modulo > 0");if(r===bt)return Mt;let n=bt;for(;t>Mt;)t&bt&&(n=n*e%r),e=e*e%r,t>>=bt;return n}function Et(e,t,r){let n=e;for(;t-- >Mt;)n*=n,n%=r;return n}function Ki(e,t){if(e===Mt||t<=Mt)throw new Error(`invert: expected positive integers, got n=${e} mod=${t}`);let r=dt(e,t),n=t,i=Mt,s=bt,o=bt,a=Mt;for(;r!==Mt;){let u=n/r,f=n%r,l=i-o*u,h=s-a*u;n=r,r=f,i=o,s=a,o=l,a=h}if(n!==bt)throw new Error("invert: does not exist");return dt(i,t)}function ym(e){let t=(e-bt)/Or,r,n,i;for(r=e-bt,n=0;r%Or===Mt;r/=Or,n++);for(i=Or;i<e&&pm(i,t,e)!==e-bt;i++);if(n===1){let o=(e+bt)/Po;return function(c,u){let f=c.pow(u,o);if(!c.eql(c.sqr(f),u))throw new Error("Cannot find square root");return f}}let s=(r+bt)/Or;return function(a,c){if(a.pow(c,t)===a.neg(a.ONE))throw new Error("Cannot find square root");let u=n,f=a.pow(a.mul(a.ONE,i),r),l=a.pow(c,s),h=a.pow(c,r);for(;!a.eql(h,a.ONE);){if(a.eql(h,a.ZERO))return a.ZERO;let y=1;for(let p=a.sqr(h);y<u&&!a.eql(p,a.ONE);y++)p=a.sqr(p);let d=a.pow(f,bt<<BigInt(u-y-1));f=a.sqr(d),l=a.mul(l,d),h=a.mul(h,f),u=y}return l}}function mm(e){if(e%Po===lm){let t=(e+bt)/Po;return function(n,i){let s=n.pow(i,t);if(!n.eql(n.sqr(s),i))throw new Error("Cannot find square root");return s}}if(e%vu===xu){let t=(e-xu)/vu;return function(n,i){let s=n.mul(i,Or),o=n.pow(s,t),a=n.mul(i,o),c=n.mul(n.mul(a,Or),o),u=n.mul(a,n.sub(c,n.ONE));if(!n.eql(n.sqr(u),i))throw new Error("Cannot find square root");return u}}return e%dm,ym(e)}var bu=(e,t)=>(dt(e,t)&bt)===bt,gm=["create","isValid","is0","neg","inv","sqrt","sqr","eql","add","sub","mul","pow","div","addN","subN","mulN","sqrN"];function ko(e){let t={ORDER:"bigint",MASK:"bigint",BYTES:"isSafeInteger",BITS:"isSafeInteger"},r=gm.reduce((n,i)=>(n[i]="function",n),t);return Fe(e,r)}function xm(e,t,r){if(r<Mt)throw new Error("Expected power > 0");if(r===Mt)return e.ONE;if(r===bt)return t;let n=e.ONE,i=t;for(;r>Mt;)r&bt&&(n=e.mul(n,i)),i=e.sqr(i),r>>=bt;return n}function vm(e,t){let r=new Array(t.length),n=t.reduce((s,o,a)=>e.is0(o)?s:(r[a]=s,e.mul(s,o)),e.ONE),i=e.inv(n);return t.reduceRight((s,o,a)=>e.is0(o)?s:(r[a]=e.mul(s,r[a]),e.mul(s,o)),i),r}function Uo(e,t){let r=t!==void 0?t:e.toString(2).length,n=Math.ceil(r/8);return{nBitLength:r,nByteLength:n}}function Fi(e,t,r=!1,n={}){if(e<=Mt)throw new Error(`Expected Field ORDER > 0, got ${e}`);let{nBitLength:i,nByteLength:s}=Uo(e,t);if(s>2048)throw new Error("Field lengths over 2048 bytes are not supported");let o=mm(e),a=Object.freeze({ORDER:e,BITS:i,BYTES:s,MASK:Fn(i),ZERO:Mt,ONE:bt,create:c=>dt(c,e),isValid:c=>{if(typeof c!="bigint")throw new Error(`Invalid field element: expected bigint, got ${typeof c}`);return Mt<=c&&c<e},is0:c=>c===Mt,isOdd:c=>(c&bt)===bt,neg:c=>dt(-c,e),eql:(c,u)=>c===u,sqr:c=>dt(c*c,e),add:(c,u)=>dt(c+u,e),sub:(c,u)=>dt(c-u,e),mul:(c,u)=>dt(c*u,e),pow:(c,u)=>xm(a,c,u),div:(c,u)=>dt(c*Ki(u,e),e),sqrN:c=>c*c,addN:(c,u)=>c+u,subN:(c,u)=>c-u,mulN:(c,u)=>c*u,inv:c=>Ki(c,e),sqrt:n.sqrt||(c=>o(a,c)),invertBatch:c=>vm(a,c),cmov:(c,u,f)=>f?u:c,toBytes:c=>r?Ur(c,s):xr(c,s),fromBytes:c=>{if(c.length!==s)throw new Error(`Fp.fromBytes: expected ${s}, got ${c.length}`);return r?gr(c):Xe(c)}});return Object.freeze(a)}function Eu(e,t){if(!e.isOdd)throw new Error("Field doesn't have isOdd");let r=e.sqrt(t);return e.isOdd(r)?e.neg(r):r}function wu(e){if(typeof e!="bigint")throw new Error("field order must be bigint");let t=e.toString(2).length;return Math.ceil(t/8)}function Oo(e){let t=wu(e);return t+Math.ceil(t/2)}function Su(e,t,r=!1){let n=e.length,i=wu(t),s=Oo(t);if(n<16||n<s||n>1024)throw new Error(`expected ${s}-1024 bytes of input, got ${n}`);let o=r?Xe(e):gr(e),a=dt(o,t-bt)+bt;return r?Ur(a,i):xr(a,i)}var Em=BigInt(0),Mo=BigInt(1);function Vi(e,t){let r=(i,s)=>{let o=s.negate();return i?o:s},n=i=>{let s=Math.ceil(t/i)+1,o=2**(i-1);return{windows:s,windowSize:o}};return{constTimeNegate:r,unsafeLadder(i,s){let o=e.ZERO,a=i;for(;s>Em;)s&Mo&&(o=o.add(a)),a=a.double(),s>>=Mo;return o},precomputeWindow(i,s){let{windows:o,windowSize:a}=n(s),c=[],u=i,f=u;for(let l=0;l<o;l++){f=u,c.push(f);for(let h=1;h<a;h++)f=f.add(u),c.push(f);u=f.double()}return c},wNAF(i,s,o){let{windows:a,windowSize:c}=n(i),u=e.ZERO,f=e.BASE,l=BigInt(2**i-1),h=2**i,y=BigInt(i);for(let d=0;d<a;d++){let p=d*c,m=Number(o&l);o>>=y,m>c&&(m-=h,o+=Mo);let x=p,E=p+Math.abs(m)-1,b=d%2!==0,R=m<0;m===0?f=f.add(r(b,s[x])):u=u.add(r(R,s[E]))}return{p:u,f}},wNAFCached(i,s,o,a){let c=i._WINDOW_SIZE||1,u=s.get(i);return u||(u=this.precomputeWindow(i,c),c!==1&&s.set(i,a(u))),this.wNAF(c,u,o)}}}function Vn(e){return ko(e.Fp),Fe(e,{n:"bigint",h:"bigint",Gx:"field",Gy:"field"},{nBitLength:"isSafeInteger",nByteLength:"isSafeInteger"}),Object.freeze({...Uo(e.n,e.nBitLength),...e,p:e.Fp.ORDER})}var Ce=BigInt(0),he=BigInt(1),qi=BigInt(2),wm=BigInt(8),Sm={zip215:!0};function Am(e){let t=Vn(e);return Fe(e,{hash:"function",a:"bigint",d:"bigint",randomBytes:"function"},{adjustScalarBytes:"function",domain:"function",uvRatio:"function",mapToCurve:"function"}),Object.freeze({...t})}function Hi(e){let t=Am(e),{Fp:r,n,prehash:i,hash:s,randomBytes:o,nByteLength:a,h:c}=t,u=qi<<BigInt(a*8)-he,f=r.create,l=t.uvRatio||((N,T)=>{try{return{isValid:!0,value:r.sqrt(N*r.inv(T))}}catch{return{isValid:!1,value:Ce}}}),h=t.adjustScalarBytes||(N=>N),y=t.domain||((N,T,M)=>{if(T.length||M)throw new Error("Contexts/pre-hash are not supported");return N}),d=N=>typeof N=="bigint"&&Ce<N,p=(N,T)=>d(N)&&d(T)&&N<T,m=N=>N===Ce||p(N,u);function x(N,T){if(p(N,T))return N;throw new Error(`Expected valid scalar < ${T}, got ${typeof N} ${N}`)}function E(N){return N===Ce?N:x(N,n)}let b=new Map;function R(N){if(!(N instanceof w))throw new Error("ExtendedPoint expected")}class w{constructor(T,M,F,G){if(this.ex=T,this.ey=M,this.ez=F,this.et=G,!m(T))throw new Error("x required");if(!m(M))throw new Error("y required");if(!m(F))throw new Error("z required");if(!m(G))throw new Error("t required")}get x(){return this.toAffine().x}get y(){return this.toAffine().y}static fromAffine(T){if(T instanceof w)throw new Error("extended point not allowed");let{x:M,y:F}=T||{};if(!m(M)||!m(F))throw new Error("invalid affine point");return new w(M,F,he,f(M*F))}static normalizeZ(T){let M=r.invertBatch(T.map(F=>F.ez));return T.map((F,G)=>F.toAffine(M[G])).map(w.fromAffine)}_setWindowSize(T){this._WINDOW_SIZE=T,b.delete(this)}assertValidity(){let{a:T,d:M}=t;if(this.is0())throw new Error("bad point: ZERO");let{ex:F,ey:G,ez:X,et}=this,ut=f(F*F),rt=f(G*G),st=f(X*X),Lt=f(st*st),Tt=f(ut*T),zt=f(st*f(Tt+rt)),Gt=f(Lt+f(M*f(ut*rt)));if(zt!==Gt)throw new Error("bad point: equation left != right (1)");let Pt=f(F*G),Wt=f(X*et);if(Pt!==Wt)throw new Error("bad point: equation left != right (2)")}equals(T){R(T);let{ex:M,ey:F,ez:G}=this,{ex:X,ey:et,ez:ut}=T,rt=f(M*ut),st=f(X*G),Lt=f(F*ut),Tt=f(et*G);return rt===st&&Lt===Tt}is0(){return this.equals(w.ZERO)}negate(){return new w(f(-this.ex),this.ey,this.ez,f(-this.et))}double(){let{a:T}=t,{ex:M,ey:F,ez:G}=this,X=f(M*M),et=f(F*F),ut=f(qi*f(G*G)),rt=f(T*X),st=M+F,Lt=f(f(st*st)-X-et),Tt=rt+et,zt=Tt-ut,Gt=rt-et,Pt=f(Lt*zt),Wt=f(Tt*Gt),He=f(Lt*Gt),Ir=f(zt*Tt);return new w(Pt,Wt,Ir,He)}add(T){R(T);let{a:M,d:F}=t,{ex:G,ey:X,ez:et,et:ut}=this,{ex:rt,ey:st,ez:Lt,et:Tt}=T;if(M===BigInt(-1)){let u0=f((X-G)*(st+rt)),f0=f((X+G)*(st-rt)),Ds=f(f0-u0);if(Ds===Ce)return this.double();let l0=f(et*qi*Tt),h0=f(ut*qi*Lt),d0=h0+l0,p0=f0+u0,y0=h0-l0,ql=f(d0*Ds),Hl=f(p0*y0),zl=f(d0*y0),Gl=f(Ds*p0);return new w(ql,Hl,Gl,zl)}let zt=f(G*rt),Gt=f(X*st),Pt=f(ut*F*Tt),Wt=f(et*Lt),He=f((G+X)*(rt+st)-zt-Gt),Ir=Wt-Pt,Cn=Wt+Pt,c0=f(Gt-M*zt),Ml=f(He*Ir),Kl=f(Cn*c0),Fl=f(He*c0),Vl=f(Ir*Cn);return new w(Ml,Kl,Vl,Fl)}subtract(T){return this.add(T.negate())}wNAF(T){return D.wNAFCached(this,b,T,w.normalizeZ)}multiply(T){let{p:M,f:F}=this.wNAF(x(T,n));return w.normalizeZ([M,F])[0]}multiplyUnsafe(T){let M=E(T);return M===Ce?L:this.equals(L)||M===he?this:this.equals(S)?this.wNAF(M).p:D.unsafeLadder(this,M)}isSmallOrder(){return this.multiplyUnsafe(c).is0()}isTorsionFree(){return D.unsafeLadder(this,n).is0()}toAffine(T){let{ex:M,ey:F,ez:G}=this,X=this.is0();T==null&&(T=X?wm:r.inv(G));let et=f(M*T),ut=f(F*T),rt=f(G*T);if(X)return{x:Ce,y:he};if(rt!==he)throw new Error("invZ was invalid");return{x:et,y:ut}}clearCofactor(){let{h:T}=t;return T===he?this:this.multiplyUnsafe(T)}static fromHex(T,M=!1){let{d:F,a:G}=t,X=r.BYTES;T=It("pointHex",T,X);let et=T.slice(),ut=T[X-1];et[X-1]=ut&-129;let rt=gr(et);rt===Ce||(M?x(rt,u):x(rt,r.ORDER));let st=f(rt*rt),Lt=f(st-he),Tt=f(F*st-G),{isValid:zt,value:Gt}=l(Lt,Tt);if(!zt)throw new Error("Point.fromHex: invalid y coordinate");let Pt=(Gt&he)===he,Wt=(ut&128)!==0;if(!M&&Gt===Ce&&Wt)throw new Error("Point.fromHex: x=0 and x_0=1");return Wt!==Pt&&(Gt=f(-Gt)),w.fromAffine({x:Gt,y:rt})}static fromPrivateKey(T){return q(T).point}toRawBytes(){let{x:T,y:M}=this.toAffine(),F=Ur(M,r.BYTES);return F[F.length-1]|=T&he?128:0,F}toHex(){return Ze(this.toRawBytes())}}w.BASE=new w(t.Gx,t.Gy,he,f(t.Gx*t.Gy)),w.ZERO=new w(Ce,he,he,Ce);let{BASE:S,ZERO:L}=w,D=Vi(w,a*8);function Y(N){return dt(N,n)}function W(N){return Y(gr(N))}function q(N){let T=a;N=It("private key",N,T);let M=It("hashed private key",s(N),2*T),F=h(M.slice(0,T)),G=M.slice(T,2*T),X=W(F),et=S.multiply(X),ut=et.toRawBytes();return{head:F,prefix:G,scalar:X,point:et,pointBytes:ut}}function j(N){return q(N).pointBytes}function lt(N=new Uint8Array,...T){let M=Je(...T);return W(s(y(M,It("context",N),!!i)))}function Ht(N,T,M={}){N=It("message",N),i&&(N=i(N));let{prefix:F,scalar:G,pointBytes:X}=q(T),et=lt(M.context,F,N),ut=S.multiply(et).toRawBytes(),rt=lt(M.context,ut,X,N),st=Y(et+rt*G);E(st);let Lt=Je(ut,Ur(st,r.BYTES));return It("result",Lt,a*2)}let I=Sm;function P(N,T,M,F=I){let{context:G,zip215:X}=F,et=r.BYTES;N=It("signature",N,2*et),T=It("message",T),i&&(T=i(T));let ut=gr(N.slice(et,2*et)),rt,st,Lt;try{rt=w.fromHex(M,X),st=w.fromHex(N.slice(0,et),X),Lt=S.multiplyUnsafe(ut)}catch{return!1}if(!X&&rt.isSmallOrder())return!1;let Tt=lt(G,st.toRawBytes(),rt.toRawBytes(),T);return st.add(rt.multiplyUnsafe(Tt)).subtract(Lt).clearCofactor().equals(w.ZERO)}return S._setWindowSize(8),{CURVE:t,getPublicKey:j,sign:Ht,verify:P,ExtendedPoint:w,utils:{getExtendedPublicKey:q,randomPrivateKey:()=>o(r.BYTES),precompute(N=8,T=w.BASE){return T._setWindowSize(N),T.multiply(BigInt(3)),T}}}}var Fo=BigInt("57896044618658097711785492504343953926634992332820282019728792003956564819949"),Au=BigInt("19681161376707505956807079304988542015446066515923890162744021073123829784752"),vv=BigInt(0),Tm=BigInt(1),Ko=BigInt(2),Bm=BigInt(5),Tu=BigInt(10),Im=BigInt(20),Cm=BigInt(40),Bu=BigInt(80);function _m(e){let t=Fo,n=e*e%t*e%t,i=Et(n,Ko,t)*n%t,s=Et(i,Tm,t)*e%t,o=Et(s,Bm,t)*s%t,a=Et(o,Tu,t)*o%t,c=Et(a,Im,t)*a%t,u=Et(c,Cm,t)*c%t,f=Et(u,Bu,t)*u%t,l=Et(f,Bu,t)*u%t,h=Et(l,Tu,t)*o%t;return{pow_p_5_8:Et(h,Ko,t)*e%t,b2:n}}function Rm(e){return e[0]&=248,e[31]&=127,e[31]|=64,e}function Lm(e,t){let r=Fo,n=dt(t*t*t,r),i=dt(n*n*t,r),s=_m(e*i).pow_p_5_8,o=dt(e*n*s,r),a=dt(t*o*o,r),c=o,u=dt(o*Au,r),f=a===e,l=a===dt(-e,r),h=a===dt(-e*Au,r);return f&&(o=c),(l||h)&&(o=u),bu(o,r)&&(o=dt(-o,r)),{isValid:f||l,value:o}}var je=Fi(Fo,void 0,!0),Vo={a:BigInt(-1),d:BigInt("37095705934669439343138083508754565189542113879843219016388785533085940283555"),Fp:je,n:BigInt("7237005577332262213973186563042994240857116359379907606001950938285454250989"),h:BigInt(8),Gx:BigInt("15112221349535400772501151409588531511454012693041857206046113283949847762202"),Gy:BigInt("46316835694926478169428394003475163141307993866256225615783033603165251855960"),hash:Ro,randomBytes:dn,adjustScalarBytes:Rm,uvRatio:Lm},yn=Hi(Vo);function Iu(e,t,r){if(t.length>255)throw new Error("Context is too big");return Ni(Io("SigEd25519 no Ed25519 collisions"),new Uint8Array([r?1:0,t.length]),t,e)}var bv=Hi({...Vo,domain:Iu}),Ev=Hi({...Vo,domain:Iu,prehash:Ro});var Dm=(je.ORDER+BigInt(3))/BigInt(8),wv=je.pow(Ko,Dm),Sv=je.sqrt(je.neg(je.ONE)),Av=(je.ORDER-BigInt(5))/BigInt(8),Tv=BigInt(486662);var Bv=Eu(je,je.neg(BigInt(486664)));var Iv=BigInt("25063068953384623474111414158702152701244531502492656460079210482610430750235"),Cv=BigInt("54469307008909316920995813868745141605393597292927456921205312896311721017578"),_v=BigInt("1159843021668779879193775521855586647937357759715417654439879720876111806838"),Rv=BigInt("40440834346308536858101042469323190826248399146238708352240133220865137265952");var Lv=BigInt("0x7fffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffff");var mn=32,tr=64,zi=32;function Cu(){let e=yn.utils.randomPrivateKey(),t=yn.getPublicKey(e);return{privateKey:Du(e,t),publicKey:t}}function _u(e){if(e.length!==zi)throw new TypeError('"seed" must be 32 bytes in length.');if(!(e instanceof Uint8Array))throw new TypeError('"seed" must be a node.js Buffer, or Uint8Array.');let t=e,r=yn.getPublicKey(t);return{privateKey:Du(t,r),publicKey:r}}function Ru(e,t){let r=e.subarray(0,zi);return yn.sign(t instanceof Uint8Array?t:t.subarray(),r)}function Lu(e,t,r){return yn.verify(t,r instanceof Uint8Array?r:r.subarray(),e)}function Du(e,t){let r=new Uint8Array(tr);for(let n=0;n<zi;n++)r[n]=e[n],r[zi+n]=t[n];return r}var ae={get(e=globalThis){let t=e.crypto;if(t==null||t.subtle==null)throw Object.assign(new Error("Missing Web Crypto API. The most likely cause of this error is that this page is being accessed from an insecure context (i.e. not HTTPS). For more information and possible resolutions see https://github.com/libp2p/js-libp2p/blob/main/packages/crypto/README.md#web-crypto-api"),{code:"ERR_MISSING_WEB_CRYPTO"});return t}};var qo={alg:"A128GCM",ext:!0,k:"scm9jmO_4BJAgdwWGVulLg",key_ops:["encrypt","decrypt"],kty:"oct"};function Ho(e){let t=e?.algorithm??"AES-GCM",r=e?.keyLength??16,n=e?.nonceLength??12,i=e?.digest??"SHA-256",s=e?.saltLength??16,o=e?.iterations??32767,a=ae.get();r*=8;async function c(l,h){let y=a.getRandomValues(new Uint8Array(s)),d=a.getRandomValues(new Uint8Array(n)),p={name:t,iv:d};typeof h=="string"&&(h=Nt(h));let m;if(h.length===0){m=await a.subtle.importKey("jwk",qo,{name:"AES-GCM"},!0,["encrypt"]);try{let E={name:"PBKDF2",salt:y,iterations:o,hash:{name:i}},b=await a.subtle.importKey("raw",h,{name:"PBKDF2"},!1,["deriveKey"]);m=await a.subtle.deriveKey(E,b,{name:t,length:r},!0,["encrypt"])}catch{m=await a.subtle.importKey("jwk",qo,{name:"AES-GCM"},!0,["encrypt"])}}else{let E={name:"PBKDF2",salt:y,iterations:o,hash:{name:i}},b=await a.subtle.importKey("raw",h,{name:"PBKDF2"},!1,["deriveKey"]);m=await a.subtle.deriveKey(E,b,{name:t,length:r},!0,["encrypt"])}let x=await a.subtle.encrypt(p,m,l);return Ot([y,p.iv,new Uint8Array(x)])}async function u(l,h){let y=l.subarray(0,s),d=l.subarray(s,s+n),p=l.subarray(s+n),m={name:t,iv:d};typeof h=="string"&&(h=Nt(h));let x;if(h.length===0)try{let b={name:"PBKDF2",salt:y,iterations:o,hash:{name:i}},R=await a.subtle.importKey("raw",h,{name:"PBKDF2"},!1,["deriveKey"]);x=await a.subtle.deriveKey(b,R,{name:t,length:r},!0,["decrypt"])}catch{x=await a.subtle.importKey("jwk",qo,{name:"AES-GCM"},!0,["decrypt"])}else{let b={name:"PBKDF2",salt:y,iterations:o,hash:{name:i}},R=await a.subtle.importKey("raw",h,{name:"PBKDF2"},!1,["deriveKey"]);x=await a.subtle.deriveKey(b,R,{name:t,length:r},!0,["decrypt"])}let E=await a.subtle.decrypt(m,x,p);return new Uint8Array(E)}return{encrypt:c,decrypt:u}}async function gn(e,t){let n=await Ho().encrypt(e,t);return fi.encode(n)}var zo=new Float32Array([-0]),vr=new Uint8Array(zo.buffer);function Pu(e,t,r){zo[0]=e,t[r]=vr[0],t[r+1]=vr[1],t[r+2]=vr[2],t[r+3]=vr[3]}function ku(e,t){return vr[0]=e[t],vr[1]=e[t+1],vr[2]=e[t+2],vr[3]=e[t+3],zo[0]}var Go=new Float64Array([-0]),Qt=new Uint8Array(Go.buffer);function Uu(e,t,r){Go[0]=e,t[r]=Qt[0],t[r+1]=Qt[1],t[r+2]=Qt[2],t[r+3]=Qt[3],t[r+4]=Qt[4],t[r+5]=Qt[5],t[r+6]=Qt[6],t[r+7]=Qt[7]}function Ou(e,t){return Qt[0]=e[t],Qt[1]=e[t+1],Qt[2]=e[t+2],Qt[3]=e[t+3],Qt[4]=e[t+4],Qt[5]=e[t+5],Qt[6]=e[t+6],Qt[7]=e[t+7],Go[0]}var Pm=BigInt(Number.MAX_SAFE_INTEGER),km=BigInt(Number.MIN_SAFE_INTEGER),ce=class e{lo;hi;constructor(t,r){this.lo=t|0,this.hi=r|0}toNumber(t=!1){if(!t&&this.hi>>>31>0){let r=~this.lo+1>>>0,n=~this.hi>>>0;return r===0&&(n=n+1>>>0),-(r+n*4294967296)}return this.lo+this.hi*4294967296}toBigInt(t=!1){if(t)return BigInt(this.lo>>>0)+(BigInt(this.hi>>>0)<<32n);if(this.hi>>>31){let r=~this.lo+1>>>0,n=~this.hi>>>0;return r===0&&(n=n+1>>>0),-(BigInt(r)+(BigInt(n)<<32n))}return BigInt(this.lo>>>0)+(BigInt(this.hi>>>0)<<32n)}toString(t=!1){return this.toBigInt(t).toString()}zzEncode(){let t=this.hi>>31;return this.hi=((this.hi<<1|this.lo>>>31)^t)>>>0,this.lo=(this.lo<<1^t)>>>0,this}zzDecode(){let t=-(this.lo&1);return this.lo=((this.lo>>>1|this.hi<<31)^t)>>>0,this.hi=(this.hi>>>1^t)>>>0,this}length(){let t=this.lo,r=(this.lo>>>28|this.hi<<4)>>>0,n=this.hi>>>24;return n===0?r===0?t<16384?t<128?1:2:t<2097152?3:4:r<16384?r<128?5:6:r<2097152?7:8:n<128?9:10}static fromBigInt(t){if(t===0n)return Mr;if(t<Pm&&t>km)return this.fromNumber(Number(t));let r=t<0n;r&&(t=-t);let n=t>>32n,i=t-(n<<32n);return r&&(n=~n|0n,i=~i|0n,++i>Mu&&(i=0n,++n>Mu&&(n=0n))),new e(Number(i),Number(n))}static fromNumber(t){if(t===0)return Mr;let r=t<0;r&&(t=-t);let n=t>>>0,i=(t-n)/4294967296>>>0;return r&&(i=~i>>>0,n=~n>>>0,++n>4294967295&&(n=0,++i>4294967295&&(i=0))),new e(n,i)}static from(t){return typeof t=="number"?e.fromNumber(t):typeof t=="bigint"?e.fromBigInt(t):typeof t=="string"?e.fromBigInt(BigInt(t)):t.low!=null||t.high!=null?new e(t.low>>>0,t.high>>>0):Mr}},Mr=new ce(0,0);Mr.toBigInt=function(){return 0n};Mr.zzEncode=Mr.zzDecode=function(){return this};Mr.length=function(){return 1};var Mu=4294967296n;function Ku(e){let t=0,r=0;for(let n=0;n<e.length;++n)r=e.charCodeAt(n),r<128?t+=1:r<2048?t+=2:(r&64512)===55296&&(e.charCodeAt(n+1)&64512)===56320?(++n,t+=4):t+=3;return t}function Fu(e,t,r){if(r-t<1)return"";let i,s=[],o=0,a;for(;t<r;)a=e[t++],a<128?s[o++]=a:a>191&&a<224?s[o++]=(a&31)<<6|e[t++]&63:a>239&&a<365?(a=((a&7)<<18|(e[t++]&63)<<12|(e[t++]&63)<<6|e[t++]&63)-65536,s[o++]=55296+(a>>10),s[o++]=56320+(a&1023)):s[o++]=(a&15)<<12|(e[t++]&63)<<6|e[t++]&63,o>8191&&((i??(i=[])).push(String.fromCharCode.apply(String,s)),o=0);return i!=null?(o>0&&i.push(String.fromCharCode.apply(String,s.slice(0,o))),i.join("")):String.fromCharCode.apply(String,s.slice(0,o))}function Wo(e,t,r){let n=r,i,s;for(let o=0;o<e.length;++o)i=e.charCodeAt(o),i<128?t[r++]=i:i<2048?(t[r++]=i>>6|192,t[r++]=i&63|128):(i&64512)===55296&&((s=e.charCodeAt(o+1))&64512)===56320?(i=65536+((i&1023)<<10)+(s&1023),++o,t[r++]=i>>18|240,t[r++]=i>>12&63|128,t[r++]=i>>6&63|128,t[r++]=i&63|128):(t[r++]=i>>12|224,t[r++]=i>>6&63|128,t[r++]=i&63|128);return r-n}function _e(e,t){return RangeError(`index out of range: ${e.pos} + ${t??1} > ${e.len}`)}function Gi(e,t){return(e[t-4]|e[t-3]<<8|e[t-2]<<16|e[t-1]<<24)>>>0}var Yo=class{buf;pos;len;_slice=Uint8Array.prototype.subarray;constructor(t){this.buf=t,this.pos=0,this.len=t.length}uint32(){let t=4294967295;if(t=(this.buf[this.pos]&127)>>>0,this.buf[this.pos++]<128||(t=(t|(this.buf[this.pos]&127)<<7)>>>0,this.buf[this.pos++]<128)||(t=(t|(this.buf[this.pos]&127)<<14)>>>0,this.buf[this.pos++]<128)||(t=(t|(this.buf[this.pos]&127)<<21)>>>0,this.buf[this.pos++]<128)||(t=(t|(this.buf[this.pos]&15)<<28)>>>0,this.buf[this.pos++]<128))return t;if((this.pos+=5)>this.len)throw this.pos=this.len,_e(this,10);return t}int32(){return this.uint32()|0}sint32(){let t=this.uint32();return t>>>1^-(t&1)|0}bool(){return this.uint32()!==0}fixed32(){if(this.pos+4>this.len)throw _e(this,4);return Gi(this.buf,this.pos+=4)}sfixed32(){if(this.pos+4>this.len)throw _e(this,4);return Gi(this.buf,this.pos+=4)|0}float(){if(this.pos+4>this.len)throw _e(this,4);let t=ku(this.buf,this.pos);return this.pos+=4,t}double(){if(this.pos+8>this.len)throw _e(this,4);let t=Ou(this.buf,this.pos);return this.pos+=8,t}bytes(){let t=this.uint32(),r=this.pos,n=this.pos+t;if(n>this.len)throw _e(this,t);return this.pos+=t,r===n?new Uint8Array(0):this.buf.subarray(r,n)}string(){let t=this.bytes();return Fu(t,0,t.length)}skip(t){if(typeof t=="number"){if(this.pos+t>this.len)throw _e(this,t);this.pos+=t}else do if(this.pos>=this.len)throw _e(this);while(this.buf[this.pos++]&128);return this}skipType(t){switch(t){case 0:this.skip();break;case 1:this.skip(8);break;case 2:this.skip(this.uint32());break;case 3:for(;(t=this.uint32()&7)!==4;)this.skipType(t);break;case 5:this.skip(4);break;default:throw Error(`invalid wire type ${t} at offset ${this.pos}`)}return this}readLongVarint(){let t=new ce(0,0),r=0;if(this.len-this.pos>4){for(;r<4;++r)if(t.lo=(t.lo|(this.buf[this.pos]&127)<<r*7)>>>0,this.buf[this.pos++]<128)return t;if(t.lo=(t.lo|(this.buf[this.pos]&127)<<28)>>>0,t.hi=(t.hi|(this.buf[this.pos]&127)>>4)>>>0,this.buf[this.pos++]<128)return t;r=0}else{for(;r<3;++r){if(this.pos>=this.len)throw _e(this);if(t.lo=(t.lo|(this.buf[this.pos]&127)<<r*7)>>>0,this.buf[this.pos++]<128)return t}return t.lo=(t.lo|(this.buf[this.pos++]&127)<<r*7)>>>0,t}if(this.len-this.pos>4){for(;r<5;++r)if(t.hi=(t.hi|(this.buf[this.pos]&127)<<r*7+3)>>>0,this.buf[this.pos++]<128)return t}else for(;r<5;++r){if(this.pos>=this.len)throw _e(this);if(t.hi=(t.hi|(this.buf[this.pos]&127)<<r*7+3)>>>0,this.buf[this.pos++]<128)return t}throw Error("invalid varint encoding")}readFixed64(){if(this.pos+8>this.len)throw _e(this,8);let t=Gi(this.buf,this.pos+=4),r=Gi(this.buf,this.pos+=4);return new ce(t,r)}int64(){return this.readLongVarint().toBigInt()}int64Number(){return this.readLongVarint().toNumber()}int64String(){return this.readLongVarint().toString()}uint64(){return this.readLongVarint().toBigInt(!0)}uint64Number(){return this.readLongVarint().toNumber(!0)}uint64String(){return this.readLongVarint().toString(!0)}sint64(){return this.readLongVarint().zzDecode().toBigInt()}sint64Number(){return this.readLongVarint().zzDecode().toNumber()}sint64String(){return this.readLongVarint().zzDecode().toString()}fixed64(){return this.readFixed64().toBigInt()}fixed64Number(){return this.readFixed64().toNumber()}fixed64String(){return this.readFixed64().toString()}sfixed64(){return this.readFixed64().toBigInt()}sfixed64Number(){return this.readFixed64().toNumber()}sfixed64String(){return this.readFixed64().toString()}};function $o(e){return new Yo(e instanceof Uint8Array?e:e.subarray())}function Zt(e,t){let r=$o(e);return t.decode(r)}function Qo(e){let t=e??8192,r=t>>>1,n,i=t;return function(o){if(o<1||o>r)return $t(o);i+o>t&&(n=$t(t),i=0);let a=n.subarray(i,i+=o);return i&7&&(i=(i|7)+1),a}}var Kr=class{fn;len;next;val;constructor(t,r,n){this.fn=t,this.len=r,this.next=void 0,this.val=n}};function Zo(){}var Jo=class{head;tail;len;next;constructor(t){this.head=t.head,this.tail=t.tail,this.len=t.len,this.next=t.states}},Um=Qo();function Om(e){return globalThis.Buffer!=null?$t(e):Um(e)}var zn=class{len;head;tail;states;constructor(){this.len=0,this.head=new Kr(Zo,0,0),this.tail=this.head,this.states=null}_push(t,r,n){return this.tail=this.tail.next=new Kr(t,r,n),this.len+=r,this}uint32(t){return this.len+=(this.tail=this.tail.next=new jo((t=t>>>0)<128?1:t<16384?2:t<2097152?3:t<268435456?4:5,t)).len,this}int32(t){return t<0?this._push(qn,10,ce.fromNumber(t)):this.uint32(t)}sint32(t){return this.uint32((t<<1^t>>31)>>>0)}uint64(t){let r=ce.fromBigInt(t);return this._push(qn,r.length(),r)}uint64Number(t){let r=ce.fromNumber(t);return this._push(qn,r.length(),r)}uint64String(t){return this.uint64(BigInt(t))}int64(t){return this.uint64(t)}int64Number(t){return this.uint64Number(t)}int64String(t){return this.uint64String(t)}sint64(t){let r=ce.fromBigInt(t).zzEncode();return this._push(qn,r.length(),r)}sint64Number(t){let r=ce.fromNumber(t).zzEncode();return this._push(qn,r.length(),r)}sint64String(t){return this.sint64(BigInt(t))}bool(t){return this._push(Xo,1,t?1:0)}fixed32(t){return this._push(Hn,4,t>>>0)}sfixed32(t){return this.fixed32(t)}fixed64(t){let r=ce.fromBigInt(t);return this._push(Hn,4,r.lo)._push(Hn,4,r.hi)}fixed64Number(t){let r=ce.fromNumber(t);return this._push(Hn,4,r.lo)._push(Hn,4,r.hi)}fixed64String(t){return this.fixed64(BigInt(t))}sfixed64(t){return this.fixed64(t)}sfixed64Number(t){return this.fixed64Number(t)}sfixed64String(t){return this.fixed64String(t)}float(t){return this._push(Pu,4,t)}double(t){return this._push(Uu,8,t)}bytes(t){let r=t.length>>>0;return r===0?this._push(Xo,1,0):this.uint32(r)._push(Km,r,t)}string(t){let r=Ku(t);return r!==0?this.uint32(r)._push(Wo,r,t):this._push(Xo,1,0)}fork(){return this.states=new Jo(this),this.head=this.tail=new Kr(Zo,0,0),this.len=0,this}reset(){return this.states!=null?(this.head=this.states.head,this.tail=this.states.tail,this.len=this.states.len,this.states=this.states.next):(this.head=this.tail=new Kr(Zo,0,0),this.len=0),this}ldelim(){let t=this.head,r=this.tail,n=this.len;return this.reset().uint32(n),n!==0&&(this.tail.next=t.next,this.tail=r,this.len+=n),this}finish(){let t=this.head.next,r=Om(this.len),n=0;for(;t!=null;)t.fn(t.val,r,n),n+=t.len,t=t.next;return r}};function Xo(e,t,r){t[r]=e&255}function Mm(e,t,r){for(;e>127;)t[r++]=e&127|128,e>>>=7;t[r]=e}var jo=class extends Kr{next;constructor(t,r){super(Mm,t,r),this.next=void 0}};function qn(e,t,r){for(;e.hi!==0;)t[r++]=e.lo&127|128,e.lo=(e.lo>>>7|e.hi<<25)>>>0,e.hi>>>=7;for(;e.lo>127;)t[r++]=e.lo&127|128,e.lo=e.lo>>>7;t[r++]=e.lo}function Hn(e,t,r){t[r]=e&255,t[r+1]=e>>>8&255,t[r+2]=e>>>16&255,t[r+3]=e>>>24}function Km(e,t,r){t.set(e,r)}globalThis.Buffer!=null&&(zn.prototype.bytes=function(e){let t=e.length>>>0;return this.uint32(t),t>0&&this._push(Fm,t,e),this},zn.prototype.string=function(e){let t=globalThis.Buffer.byteLength(e);return this.uint32(t),t>0&&this._push(Vm,t,e),this});function Fm(e,t,r){t.set(e,r)}function Vm(e,t,r){e.length<40?Wo(e,t,r):t.utf8Write!=null?t.utf8Write(e,r):t.set(Nt(e),r)}function ta(){return new zn}function Xt(e,t){let r=ta();return t.encode(e,r,{lengthDelimited:!1}),r.finish()}var xn;(function(e){e[e.VARINT=0]="VARINT",e[e.BIT64=1]="BIT64",e[e.LENGTH_DELIMITED=2]="LENGTH_DELIMITED",e[e.START_GROUP=3]="START_GROUP",e[e.END_GROUP=4]="END_GROUP",e[e.BIT32=5]="BIT32"})(xn||(xn={}));function Wi(e,t,r,n){return{name:e,type:t,encode:r,decode:n}}function Fr(e){function t(i){if(e[i.toString()]==null)throw new Error("Invalid enum value");return e[i]}let r=function(s,o){let a=t(s);o.int32(a)},n=function(s){let o=s.int32();return t(o)};return Wi("enum",xn.VARINT,r,n)}function Jt(e,t){return Wi("message",xn.LENGTH_DELIMITED,e,t)}var wt;(function(e){e.RSA="RSA",e.Ed25519="Ed25519",e.Secp256k1="Secp256k1"})(wt||(wt={}));var ea;(function(e){e[e.RSA=0]="RSA",e[e.Ed25519=1]="Ed25519",e[e.Secp256k1=2]="Secp256k1"})(ea||(ea={}));(function(e){e.codec=()=>Fr(ea)})(wt||(wt={}));var Ve;(function(e){let t;e.codec=()=>(t==null&&(t=Jt((r,n,i={})=>{i.lengthDelimited!==!1&&n.fork(),r.Type!=null&&(n.uint32(8),wt.codec().encode(r.Type,n)),r.Data!=null&&(n.uint32(18),n.bytes(r.Data)),i.lengthDelimited!==!1&&n.ldelim()},(r,n)=>{let i={},s=n==null?r.len:r.pos+n;for(;r.pos<s;){let o=r.uint32();switch(o>>>3){case 1:i.Type=wt.codec().decode(r);break;case 2:i.Data=r.bytes();break;default:r.skipType(o&7);break}}return i})),t),e.encode=r=>Xt(r,e.codec()),e.decode=r=>Zt(r,e.codec())})(Ve||(Ve={}));var qe;(function(e){let t;e.codec=()=>(t==null&&(t=Jt((r,n,i={})=>{i.lengthDelimited!==!1&&n.fork(),r.Type!=null&&(n.uint32(8),wt.codec().encode(r.Type,n)),r.Data!=null&&(n.uint32(18),n.bytes(r.Data)),i.lengthDelimited!==!1&&n.ldelim()},(r,n)=>{let i={},s=n==null?r.len:r.pos+n;for(;r.pos<s;){let o=r.uint32();switch(o>>>3){case 1:i.Type=wt.codec().decode(r);break;case 2:i.Data=r.bytes();break;default:r.skipType(o&7);break}}return i})),t),e.encode=r=>Xt(r,e.codec()),e.decode=r=>Zt(r,e.codec())})(qe||(qe={}));var Gn=class{_key;constructor(t){this._key=vn(t,mn)}verify(t,r){return Lu(this._key,r,t)}marshal(){return this._key}get bytes(){return Ve.encode({Type:wt.Ed25519,Data:this.marshal()}).subarray()}equals(t){return Ct(this.bytes,t.bytes)}hash(){let t=Ut.digest(this.bytes);return ve(t)?t.then(({bytes:r})=>r):t.bytes}},Vr=class{_key;_publicKey;constructor(t,r){this._key=vn(t,tr),this._publicKey=vn(r,mn)}sign(t){return Ru(this._key,t)}get public(){return new Gn(this._publicKey)}marshal(){return this._key}get bytes(){return qe.encode({Type:wt.Ed25519,Data:this.marshal()}).subarray()}equals(t){return Ct(this.bytes,t.bytes)}async hash(){let t=Ut.digest(this.bytes),r;return ve(t)?{bytes:r}=await t:r=t.bytes,r}async id(){let t=cr.digest(this.public.bytes);return kt.encode(t.bytes).substring(1)}async export(t,r="libp2p-key"){if(r==="libp2p-key")return gn(this.bytes,t);throw new H(`export format '${r}' is not supported`,"ERR_INVALID_EXPORT_FORMAT")}};function qm(e){if(e.length>tr){e=vn(e,tr+mn);let n=e.subarray(0,tr),i=e.subarray(tr,e.length);return new Vr(n,i)}e=vn(e,tr);let t=e.subarray(0,tr),r=e.subarray(mn);return new Vr(t,r)}function Hm(e){return e=vn(e,mn),new Gn(e)}async function zm(){let{privateKey:e,publicKey:t}=Cu();return new Vr(e,t)}async function qu(e){let{privateKey:t,publicKey:r}=_u(e);return new Vr(t,r)}function vn(e,t){if(e=Uint8Array.from(e??[]),e.length!==t)throw new H(`Key must be a Uint8Array of length ${t}, got ${e.length}`,"ERR_INVALID_KEY_TYPE");return e}var Gm={"P-256":256,"P-384":384,"P-521":521},Wm=Object.keys(Gm),_b=Wm.join(" / ");var aa={};Kt(aa,{MAX_KEY_SIZE:()=>Qn,RsaPrivateKey:()=>bn,RsaPublicKey:()=>$n,fromJwk:()=>ng,generateKeyPair:()=>ig,unmarshalRsaPrivateKey:()=>eg,unmarshalRsaPublicKey:()=>rg});var Yn=Yt(ht(),1);var dE=Yt(Yu(),1);function $i(e){if(isNaN(e)||e<=0)throw new H("random bytes length must be a Number bigger than 0","ERR_INVALID_LENGTH");return dn(e)}var Qb=Yt(_i(),1),sa=Yt(ht(),1);function $u(e,t){return t.map(r=>le(e[r]))}function Qu(e){return sa.default.pki.setRsaPrivateKey(...$u(e,["n","e","d","p","q","dp","dq","qi"]))}function Zu(e){return sa.default.pki.setRsaPublicKey(...$u(e,["n","e"]))}var Hr={};Kt(Hr,{jwkToPkcs1:()=>Zm,jwkToPkix:()=>Jm,pkcs1ToJwk:()=>Qm,pkixToJwk:()=>Xm});var Jb=Yt(Un(),1),jb=Yt(_i(),1);var er=Yt(ht(),1);function Qm(e){let t=er.default.asn1.fromDer(pt(e,"ascii")),r=er.default.pki.privateKeyFromAsn1(t);return{kty:"RSA",n:Be(r.n),e:Be(r.e),d:Be(r.d),p:Be(r.p),q:Be(r.q),dp:Be(r.dP),dq:Be(r.dQ),qi:Be(r.qInv),alg:"RS256"}}function Zm(e){if(e.n==null||e.e==null||e.d==null||e.p==null||e.q==null||e.dp==null||e.dq==null||e.qi==null)throw new H("JWK was missing components","ERR_INVALID_PARAMETERS");let t=er.default.pki.privateKeyToAsn1({n:le(e.n),e:le(e.e),d:le(e.d),p:le(e.p),q:le(e.q),dP:le(e.dp),dQ:le(e.dq),qInv:le(e.qi)});return Nt(er.default.asn1.toDer(t).getBytes(),"ascii")}function Xm(e){let t=er.default.asn1.fromDer(pt(e,"ascii")),r=er.default.pki.publicKeyFromAsn1(t);return{kty:"RSA",n:Be(r.n),e:Be(r.e)}}function Jm(e){if(e.n==null||e.e==null)throw new H("JWK was missing components","ERR_INVALID_PARAMETERS");let t=er.default.pki.publicKeyToAsn1({n:le(e.n),e:le(e.e)});return Nt(er.default.asn1.toDer(t).getBytes(),"ascii")}async function Xu(e){let t=await ae.get().subtle.generateKey({name:"RSASSA-PKCS1-v1_5",modulusLength:e,publicExponent:new Uint8Array([1,0,1]),hash:{name:"SHA-256"}},!0,["sign","verify"]),r=await tf(t);return{privateKey:r[0],publicKey:r[1]}}async function oa(e){let r=[await ae.get().subtle.importKey("jwk",e,{name:"RSASSA-PKCS1-v1_5",hash:{name:"SHA-256"}},!0,["sign"]),await jm(e)],n=await tf({privateKey:r[0],publicKey:r[1]});return{privateKey:n[0],publicKey:n[1]}}async function Ju(e,t){let r=await ae.get().subtle.importKey("jwk",e,{name:"RSASSA-PKCS1-v1_5",hash:{name:"SHA-256"}},!1,["sign"]),n=await ae.get().subtle.sign({name:"RSASSA-PKCS1-v1_5"},r,t instanceof Uint8Array?t:t.subarray());return new Uint8Array(n,0,n.byteLength)}async function ju(e,t,r){let n=await ae.get().subtle.importKey("jwk",e,{name:"RSASSA-PKCS1-v1_5",hash:{name:"SHA-256"}},!1,["verify"]);return ae.get().subtle.verify({name:"RSASSA-PKCS1-v1_5"},n,t,r instanceof Uint8Array?r:r.subarray())}async function tf(e){if(e.privateKey==null||e.publicKey==null)throw new H("Private and public key are required","ERR_INVALID_PARAMETERS");return Promise.all([ae.get().subtle.exportKey("jwk",e.privateKey),ae.get().subtle.exportKey("jwk",e.publicKey)])}async function jm(e){return ae.get().subtle.importKey("jwk",{kty:e.kty,n:e.n,e:e.e},{name:"RSASSA-PKCS1-v1_5",hash:{name:"SHA-256"}},!0,["verify"])}function ef(e,t,r,n){let i=t?Zu(e):Qu(e),s=pt(r instanceof Uint8Array?r:r.subarray(),"ascii"),o=n(s,i);return Nt(o,"ascii")}function rf(e,t){return ef(e,!0,t,(r,n)=>n.encrypt(r))}function nf(e,t){return ef(e,!1,t,(r,n)=>n.decrypt(r))}function Qi(e){if(e.kty!=="RSA")throw new H("invalid key type","ERR_INVALID_KEY_TYPE");if(e.n==null)throw new H("invalid key modulus","ERR_INVALID_KEY_MODULUS");return Nt(e.n,"base64url").length*8}var Qn=8192,$n=class{_key;constructor(t){this._key=t}verify(t,r){return ju(this._key,r,t)}marshal(){return Hr.jwkToPkix(this._key)}get bytes(){return Ve.encode({Type:wt.RSA,Data:this.marshal()}).subarray()}encrypt(t){return rf(this._key,t)}equals(t){return Ct(this.bytes,t.bytes)}hash(){let t=Ut.digest(this.bytes);return ve(t)?t.then(({bytes:r})=>r):t.bytes}},bn=class{_key;_publicKey;constructor(t,r){this._key=t,this._publicKey=r}genSecret(){return $i(16)}sign(t){return Ju(this._key,t)}get public(){if(this._publicKey==null)throw new H("public key not provided","ERR_PUBKEY_NOT_PROVIDED");return new $n(this._publicKey)}decrypt(t){return nf(this._key,t)}marshal(){return Hr.jwkToPkcs1(this._key)}get bytes(){return qe.encode({Type:wt.RSA,Data:this.marshal()}).subarray()}equals(t){return Ct(this.bytes,t.bytes)}hash(){let t=Ut.digest(this.bytes);return ve(t)?t.then(({bytes:r})=>r):t.bytes}async id(){let t=await this.public.hash();return pt(t,"base58btc")}async export(t,r="pkcs-8"){if(r==="pkcs-8"){let n=new Yn.default.util.ByteBuffer(this.marshal()),i=Yn.default.asn1.fromDer(n),s=Yn.default.pki.privateKeyFromAsn1(i),o={algorithm:"aes256",count:1e4,saltSize:128/8,prfAlgorithm:"sha512"};return Yn.default.pki.encryptRsaPrivateKey(s,t,o)}else{if(r==="libp2p-key")return gn(this.bytes,t);throw new H(`export format '${r}' is not supported`,"ERR_INVALID_EXPORT_FORMAT")}}};async function eg(e){let t=Hr.pkcs1ToJwk(e);if(Qi(t)>Qn)throw new H("key size is too large","ERR_KEY_SIZE_TOO_LARGE");let r=await oa(t);return new bn(r.privateKey,r.publicKey)}function rg(e){let t=Hr.pkixToJwk(e);if(Qi(t)>Qn)throw new H("key size is too large","ERR_KEY_SIZE_TOO_LARGE");return new $n(t)}async function ng(e){if(Qi(e)>Qn)throw new H("key size is too large","ERR_KEY_SIZE_TOO_LARGE");let t=await oa(e);return new bn(t.privateKey,t.publicKey)}async function ig(e){if(e>Qn)throw new H("key size is too large","ERR_KEY_SIZE_TOO_LARGE");let t=await Xu(e);return new bn(t.privateKey,t.publicKey)}var da={};Kt(da,{Secp256k1PrivateKey:()=>Xn,Secp256k1PublicKey:()=>Zn,generateKeyPair:()=>vg,unmarshalSecp256k1PrivateKey:()=>gg,unmarshalSecp256k1PublicKey:()=>xg});var sg=(e,t,r)=>e&t^~e&r,og=(e,t,r)=>e&t^e&r^t&r,ag=new Uint32Array([1116352408,1899447441,3049323471,3921009573,961987163,1508970993,2453635748,2870763221,3624381080,310598401,607225278,1426881987,1925078388,2162078206,2614888103,3248222580,3835390401,4022224774,264347078,604807628,770255983,1249150122,1555081692,1996064986,2554220882,2821834349,2952996808,3210313671,3336571891,3584528711,113926993,338241895,666307205,773529912,1294757372,1396182291,1695183700,1986661051,2177026350,2456956037,2730485921,2820302411,3259730800,3345764771,3516065817,3600352804,4094571909,275423344,430227734,506948616,659060556,883997877,958139571,1322822218,1537002063,1747873779,1955562222,2024104815,2227730452,2361852424,2428436474,2756734187,3204031479,3329325298]),br=new Uint32Array([1779033703,3144134277,1013904242,2773480762,1359893119,2600822924,528734635,1541459225]),Er=new Uint32Array(64),ca=class extends pn{constructor(){super(64,32,8,!1),this.A=br[0]|0,this.B=br[1]|0,this.C=br[2]|0,this.D=br[3]|0,this.E=br[4]|0,this.F=br[5]|0,this.G=br[6]|0,this.H=br[7]|0}get(){let{A:t,B:r,C:n,D:i,E:s,F:o,G:a,H:c}=this;return[t,r,n,i,s,o,a,c]}set(t,r,n,i,s,o,a,c){this.A=t|0,this.B=r|0,this.C=n|0,this.D=i|0,this.E=s|0,this.F=o|0,this.G=a|0,this.H=c|0}process(t,r){for(let l=0;l<16;l++,r+=4)Er[l]=t.getUint32(r,!1);for(let l=16;l<64;l++){let h=Er[l-15],y=Er[l-2],d=Ie(h,7)^Ie(h,18)^h>>>3,p=Ie(y,17)^Ie(y,19)^y>>>10;Er[l]=p+Er[l-7]+d+Er[l-16]|0}let{A:n,B:i,C:s,D:o,E:a,F:c,G:u,H:f}=this;for(let l=0;l<64;l++){let h=Ie(a,6)^Ie(a,11)^Ie(a,25),y=f+h+sg(a,c,u)+ag[l]+Er[l]|0,p=(Ie(n,2)^Ie(n,13)^Ie(n,22))+og(n,i,s)|0;f=u,u=c,c=a,a=o+y|0,o=s,s=i,i=n,n=y+p|0}n=n+this.A|0,i=i+this.B|0,s=s+this.C|0,o=o+this.D|0,a=a+this.E|0,c=c+this.F|0,u=u+this.G|0,f=f+this.H|0,this.set(n,i,s,o,a,c,u,f)}roundClean(){Er.fill(0)}destroy(){this.set(0,0,0,0,0,0,0,0),this.buffer.fill(0)}};var sf=Pi(()=>new ca);function cg(e){let t=Vn(e);Fe(t,{a:"field",b:"field"},{allowedPrivateKeyLengths:"array",wrapPrivateKey:"boolean",isTorsionFree:"function",clearCofactor:"function",allowInfinityPoint:"boolean",fromBytes:"function",toBytes:"function"});let{endo:r,Fp:n,a:i}=t;if(r){if(!n.eql(i,n.ZERO))throw new Error("Endomorphism can only be defined for Koblitz curves that have a=0");if(typeof r!="object"||typeof r.beta!="bigint"||typeof r.splitScalar!="function")throw new Error("Expected endomorphism with beta: bigint and splitScalar: function")}return Object.freeze({...t})}var{bytesToNumberBE:ug,hexToBytes:fg}=Mi,zr={Err:class extends Error{constructor(t=""){super(t)}},_parseInt(e){let{Err:t}=zr;if(e.length<2||e[0]!==2)throw new t("Invalid signature integer tag");let r=e[1],n=e.subarray(2,r+2);if(!r||n.length!==r)throw new t("Invalid signature integer: wrong length");if(n[0]&128)throw new t("Invalid signature integer: negative");if(n[0]===0&&!(n[1]&128))throw new t("Invalid signature integer: unnecessary leading zero");return{d:ug(n),l:e.subarray(r+2)}},toSig(e){let{Err:t}=zr,r=typeof e=="string"?fg(e):e;if(!(r instanceof Uint8Array))throw new Error("ui8a expected");let n=r.length;if(n<2||r[0]!=48)throw new t("Invalid signature tag");if(r[1]!==n-2)throw new t("Invalid signature: incorrect length");let{d:i,l:s}=zr._parseInt(r.subarray(2)),{d:o,l:a}=zr._parseInt(s);if(a.length)throw new t("Invalid signature: left bytes after parsing");return{r:i,s:o}},hexFromSig(e){let t=u=>Number.parseInt(u[0],16)&8?"00"+u:u,r=u=>{let f=u.toString(16);return f.length&1?`0${f}`:f},n=t(r(e.s)),i=t(r(e.r)),s=n.length/2,o=i.length/2,a=r(s),c=r(o);return`30${r(o+s+4)}02${c}${i}02${a}${n}`}},rr=BigInt(0),be=BigInt(1),SE=BigInt(2),of=BigInt(3),AE=BigInt(4);function lg(e){let t=cg(e),{Fp:r}=t,n=t.toBytes||((d,p,m)=>{let x=p.toAffine();return Je(Uint8Array.from([4]),r.toBytes(x.x),r.toBytes(x.y))}),i=t.fromBytes||(d=>{let p=d.subarray(1),m=r.fromBytes(p.subarray(0,r.BYTES)),x=r.fromBytes(p.subarray(r.BYTES,2*r.BYTES));return{x:m,y:x}});function s(d){let{a:p,b:m}=t,x=r.sqr(d),E=r.mul(x,d);return r.add(r.add(E,r.mul(d,p)),m)}if(!r.eql(r.sqr(t.Gy),s(t.Gx)))throw new Error("bad generator point: equation left != right");function o(d){return typeof d=="bigint"&&rr<d&&d<t.n}function a(d){if(!o(d))throw new Error("Expected valid bigint: 0 < bigint < curve.n")}function c(d){let{allowedPrivateKeyLengths:p,nByteLength:m,wrapPrivateKey:x,n:E}=t;if(p&&typeof d!="bigint"){if(d instanceof Uint8Array&&(d=Ze(d)),typeof d!="string"||!p.includes(d.length))throw new Error("Invalid key");d=d.padStart(m*2,"0")}let b;try{b=typeof d=="bigint"?d:Xe(It("private key",d,m))}catch{throw new Error(`private key must be ${m} bytes, hex or bigint, not ${typeof d}`)}return x&&(b=dt(b,E)),a(b),b}let u=new Map;function f(d){if(!(d instanceof l))throw new Error("ProjectivePoint expected")}class l{constructor(p,m,x){if(this.px=p,this.py=m,this.pz=x,p==null||!r.isValid(p))throw new Error("x required");if(m==null||!r.isValid(m))throw new Error("y required");if(x==null||!r.isValid(x))throw new Error("z required")}static fromAffine(p){let{x:m,y:x}=p||{};if(!p||!r.isValid(m)||!r.isValid(x))throw new Error("invalid affine point");if(p instanceof l)throw new Error("projective point not allowed");let E=b=>r.eql(b,r.ZERO);return E(m)&&E(x)?l.ZERO:new l(m,x,r.ONE)}get x(){return this.toAffine().x}get y(){return this.toAffine().y}static normalizeZ(p){let m=r.invertBatch(p.map(x=>x.pz));return p.map((x,E)=>x.toAffine(m[E])).map(l.fromAffine)}static fromHex(p){let m=l.fromAffine(i(It("pointHex",p)));return m.assertValidity(),m}static fromPrivateKey(p){return l.BASE.multiply(c(p))}_setWindowSize(p){this._WINDOW_SIZE=p,u.delete(this)}assertValidity(){if(this.is0()){if(t.allowInfinityPoint&&!r.is0(this.py))return;throw new Error("bad point: ZERO")}let{x:p,y:m}=this.toAffine();if(!r.isValid(p)||!r.isValid(m))throw new Error("bad point: x or y not FE");let x=r.sqr(m),E=s(p);if(!r.eql(x,E))throw new Error("bad point: equation left != right");if(!this.isTorsionFree())throw new Error("bad point: not in prime-order subgroup")}hasEvenY(){let{y:p}=this.toAffine();if(r.isOdd)return!r.isOdd(p);throw new Error("Field doesn't support isOdd")}equals(p){f(p);let{px:m,py:x,pz:E}=this,{px:b,py:R,pz:w}=p,S=r.eql(r.mul(m,w),r.mul(b,E)),L=r.eql(r.mul(x,w),r.mul(R,E));return S&&L}negate(){return new l(this.px,r.neg(this.py),this.pz)}double(){let{a:p,b:m}=t,x=r.mul(m,of),{px:E,py:b,pz:R}=this,w=r.ZERO,S=r.ZERO,L=r.ZERO,D=r.mul(E,E),Y=r.mul(b,b),W=r.mul(R,R),q=r.mul(E,b);return q=r.add(q,q),L=r.mul(E,R),L=r.add(L,L),w=r.mul(p,L),S=r.mul(x,W),S=r.add(w,S),w=r.sub(Y,S),S=r.add(Y,S),S=r.mul(w,S),w=r.mul(q,w),L=r.mul(x,L),W=r.mul(p,W),q=r.sub(D,W),q=r.mul(p,q),q=r.add(q,L),L=r.add(D,D),D=r.add(L,D),D=r.add(D,W),D=r.mul(D,q),S=r.add(S,D),W=r.mul(b,R),W=r.add(W,W),D=r.mul(W,q),w=r.sub(w,D),L=r.mul(W,Y),L=r.add(L,L),L=r.add(L,L),new l(w,S,L)}add(p){f(p);let{px:m,py:x,pz:E}=this,{px:b,py:R,pz:w}=p,S=r.ZERO,L=r.ZERO,D=r.ZERO,Y=t.a,W=r.mul(t.b,of),q=r.mul(m,b),j=r.mul(x,R),lt=r.mul(E,w),Ht=r.add(m,x),I=r.add(b,R);Ht=r.mul(Ht,I),I=r.add(q,j),Ht=r.sub(Ht,I),I=r.add(m,E);let P=r.add(b,w);return I=r.mul(I,P),P=r.add(q,lt),I=r.sub(I,P),P=r.add(x,E),S=r.add(R,w),P=r.mul(P,S),S=r.add(j,lt),P=r.sub(P,S),D=r.mul(Y,I),S=r.mul(W,lt),D=r.add(S,D),S=r.sub(j,D),D=r.add(j,D),L=r.mul(S,D),j=r.add(q,q),j=r.add(j,q),lt=r.mul(Y,lt),I=r.mul(W,I),j=r.add(j,lt),lt=r.sub(q,lt),lt=r.mul(Y,lt),I=r.add(I,lt),q=r.mul(j,I),L=r.add(L,q),q=r.mul(P,I),S=r.mul(Ht,S),S=r.sub(S,q),q=r.mul(Ht,j),D=r.mul(P,D),D=r.add(D,q),new l(S,L,D)}subtract(p){return this.add(p.negate())}is0(){return this.equals(l.ZERO)}wNAF(p){return y.wNAFCached(this,u,p,m=>{let x=r.invertBatch(m.map(E=>E.pz));return m.map((E,b)=>E.toAffine(x[b])).map(l.fromAffine)})}multiplyUnsafe(p){let m=l.ZERO;if(p===rr)return m;if(a(p),p===be)return this;let{endo:x}=t;if(!x)return y.unsafeLadder(this,p);let{k1neg:E,k1:b,k2neg:R,k2:w}=x.splitScalar(p),S=m,L=m,D=this;for(;b>rr||w>rr;)b&be&&(S=S.add(D)),w&be&&(L=L.add(D)),D=D.double(),b>>=be,w>>=be;return E&&(S=S.negate()),R&&(L=L.negate()),L=new l(r.mul(L.px,x.beta),L.py,L.pz),S.add(L)}multiply(p){a(p);let m=p,x,E,{endo:b}=t;if(b){let{k1neg:R,k1:w,k2neg:S,k2:L}=b.splitScalar(m),{p:D,f:Y}=this.wNAF(w),{p:W,f:q}=this.wNAF(L);D=y.constTimeNegate(R,D),W=y.constTimeNegate(S,W),W=new l(r.mul(W.px,b.beta),W.py,W.pz),x=D.add(W),E=Y.add(q)}else{let{p:R,f:w}=this.wNAF(m);x=R,E=w}return l.normalizeZ([x,E])[0]}multiplyAndAddUnsafe(p,m,x){let E=l.BASE,b=(w,S)=>S===rr||S===be||!w.equals(E)?w.multiplyUnsafe(S):w.multiply(S),R=b(this,m).add(b(p,x));return R.is0()?void 0:R}toAffine(p){let{px:m,py:x,pz:E}=this,b=this.is0();p==null&&(p=b?r.ONE:r.inv(E));let R=r.mul(m,p),w=r.mul(x,p),S=r.mul(E,p);if(b)return{x:r.ZERO,y:r.ZERO};if(!r.eql(S,r.ONE))throw new Error("invZ was invalid");return{x:R,y:w}}isTorsionFree(){let{h:p,isTorsionFree:m}=t;if(p===be)return!0;if(m)return m(l,this);throw new Error("isTorsionFree() has not been declared for the elliptic curve")}clearCofactor(){let{h:p,clearCofactor:m}=t;return p===be?this:m?m(l,this):this.multiplyUnsafe(t.h)}toRawBytes(p=!0){return this.assertValidity(),n(l,this,p)}toHex(p=!0){return Ze(this.toRawBytes(p))}}l.BASE=new l(t.Gx,t.Gy,r.ONE),l.ZERO=new l(r.ZERO,r.ONE,r.ZERO);let h=t.nBitLength,y=Vi(l,t.endo?Math.ceil(h/2):h);return{CURVE:t,ProjectivePoint:l,normPrivateKeyToScalar:c,weierstrassEquation:s,isWithinCurveOrder:o}}function hg(e){let t=Vn(e);return Fe(t,{hash:"hash",hmac:"function",randomBytes:"function"},{bits2int:"function",bits2int_modN:"function",lowS:"boolean"}),Object.freeze({lowS:!0,...t})}function af(e){let t=hg(e),{Fp:r,n}=t,i=r.BYTES+1,s=2*r.BYTES+1;function o(I){return rr<I&&I<r.ORDER}function a(I){return dt(I,n)}function c(I){return Ki(I,n)}let{ProjectivePoint:u,normPrivateKeyToScalar:f,weierstrassEquation:l,isWithinCurveOrder:h}=lg({...t,toBytes(I,P,_){let N=P.toAffine(),T=r.toBytes(N.x),M=Je;return _?M(Uint8Array.from([P.hasEvenY()?2:3]),T):M(Uint8Array.from([4]),T,r.toBytes(N.y))},fromBytes(I){let P=I.length,_=I[0],N=I.subarray(1);if(P===i&&(_===2||_===3)){let T=Xe(N);if(!o(T))throw new Error("Point is not on curve");let M=l(T),F=r.sqrt(M),G=(F&be)===be;return(_&1)===1!==G&&(F=r.neg(F)),{x:T,y:F}}else if(P===s&&_===4){let T=r.fromBytes(N.subarray(0,r.BYTES)),M=r.fromBytes(N.subarray(r.BYTES,2*r.BYTES));return{x:T,y:M}}else throw new Error(`Point of length ${P} was invalid. Expected ${i} compressed bytes or ${s} uncompressed bytes`)}}),y=I=>Ze(xr(I,t.nByteLength));function d(I){let P=n>>be;return I>P}function p(I){return d(I)?a(-I):I}let m=(I,P,_)=>Xe(I.slice(P,_));class x{constructor(P,_,N){this.r=P,this.s=_,this.recovery=N,this.assertValidity()}static fromCompact(P){let _=t.nByteLength;return P=It("compactSignature",P,_*2),new x(m(P,0,_),m(P,_,2*_))}static fromDER(P){let{r:_,s:N}=zr.toSig(It("DER",P));return new x(_,N)}assertValidity(){if(!h(this.r))throw new Error("r must be 0 < r < CURVE.n");if(!h(this.s))throw new Error("s must be 0 < s < CURVE.n")}addRecoveryBit(P){return new x(this.r,this.s,P)}recoverPublicKey(P){let{r:_,s:N,recovery:T}=this,M=L(It("msgHash",P));if(T==null||![0,1,2,3].includes(T))throw new Error("recovery id invalid");let F=T===2||T===3?_+t.n:_;if(F>=r.ORDER)throw new Error("recovery id 2 or 3 invalid");let G=T&1?"03":"02",X=u.fromHex(G+y(F)),et=c(F),ut=a(-M*et),rt=a(N*et),st=u.BASE.multiplyAndAddUnsafe(X,ut,rt);if(!st)throw new Error("point at infinify");return st.assertValidity(),st}hasHighS(){return d(this.s)}normalizeS(){return this.hasHighS()?new x(this.r,a(-this.s),this.recovery):this}toDERRawBytes(){return kr(this.toDERHex())}toDERHex(){return zr.hexFromSig({r:this.r,s:this.s})}toCompactRawBytes(){return kr(this.toCompactHex())}toCompactHex(){return y(this.r)+y(this.s)}}let E={isValidPrivateKey(I){try{return f(I),!0}catch{return!1}},normPrivateKeyToScalar:f,randomPrivateKey:()=>{let I=Oo(t.n);return Su(t.randomBytes(I),t.n)},precompute(I=8,P=u.BASE){return P._setWindowSize(I),P.multiply(BigInt(3)),P}};function b(I,P=!0){return u.fromPrivateKey(I).toRawBytes(P)}function R(I){let P=I instanceof Uint8Array,_=typeof I=="string",N=(P||_)&&I.length;return P?N===i||N===s:_?N===2*i||N===2*s:I instanceof u}function w(I,P,_=!0){if(R(I))throw new Error("first arg must be private key");if(!R(P))throw new Error("second arg must be public key");return u.fromHex(P).multiply(f(I)).toRawBytes(_)}let S=t.bits2int||function(I){let P=Xe(I),_=I.length*8-t.nBitLength;return _>0?P>>BigInt(_):P},L=t.bits2int_modN||function(I){return a(S(I))},D=Fn(t.nBitLength);function Y(I){if(typeof I!="bigint")throw new Error("bigint expected");if(!(rr<=I&&I<D))throw new Error(`bigint expected < 2^${t.nBitLength}`);return xr(I,t.nByteLength)}function W(I,P,_=q){if(["recovered","canonical"].some(Tt=>Tt in _))throw new Error("sign() legacy options not supported");let{hash:N,randomBytes:T}=t,{lowS:M,prehash:F,extraEntropy:G}=_;M==null&&(M=!0),I=It("msgHash",I),F&&(I=It("prehashed msgHash",N(I)));let X=L(I),et=f(P),ut=[Y(et),Y(X)];if(G!=null){let Tt=G===!0?T(r.BYTES):G;ut.push(It("extraEntropy",Tt))}let rt=Je(...ut),st=X;function Lt(Tt){let zt=S(Tt);if(!h(zt))return;let Gt=c(zt),Pt=u.BASE.multiply(zt).toAffine(),Wt=a(Pt.x);if(Wt===rr)return;let He=a(Gt*a(st+Wt*et));if(He===rr)return;let Ir=(Pt.x===Wt?0:2)|Number(Pt.y&be),Cn=He;return M&&d(He)&&(Cn=p(He),Ir^=1),new x(Wt,Cn,Ir)}return{seed:rt,k2sig:Lt}}let q={lowS:t.lowS,prehash:!1},j={lowS:t.lowS,prehash:!1};function lt(I,P,_=q){let{seed:N,k2sig:T}=W(I,P,_),M=t;return No(M.hash.outputLen,M.nByteLength,M.hmac)(N,T)}u.BASE._setWindowSize(8);function Ht(I,P,_,N=j){let T=I;if(P=It("msgHash",P),_=It("publicKey",_),"strict"in N)throw new Error("options.strict was renamed to lowS");let{lowS:M,prehash:F}=N,G,X;try{if(typeof T=="string"||T instanceof Uint8Array)try{G=x.fromDER(T)}catch(Pt){if(!(Pt instanceof zr.Err))throw Pt;G=x.fromCompact(T)}else if(typeof T=="object"&&typeof T.r=="bigint"&&typeof T.s=="bigint"){let{r:Pt,s:Wt}=T;G=new x(Pt,Wt)}else throw new Error("PARSE");X=u.fromHex(_)}catch(Pt){if(Pt.message==="PARSE")throw new Error("signature must be Signature instance, Uint8Array or hex string");return!1}if(M&&G.hasHighS())return!1;F&&(P=t.hash(P));let{r:et,s:ut}=G,rt=L(P),st=c(ut),Lt=a(rt*st),Tt=a(et*st),zt=u.BASE.multiplyAndAddUnsafe(X,Lt,Tt)?.toAffine();return zt?a(zt.x)===et:!1}return{CURVE:t,getPublicKey:b,getSharedSecret:w,sign:lt,verify:Ht,ProjectivePoint:u,Signature:x,utils:E}}var Zi=class extends hn{constructor(t,r){super(),this.finished=!1,this.destroyed=!1,lu(t);let n=Kn(r);if(this.iHash=t.create(),typeof this.iHash.update!="function")throw new Error("Expected instance of class which extends utils.Hash");this.blockLen=this.iHash.blockLen,this.outputLen=this.iHash.outputLen;let i=this.blockLen,s=new Uint8Array(i);s.set(n.length>i?t.create().update(n).digest():n);for(let o=0;o<s.length;o++)s[o]^=54;this.iHash.update(s),this.oHash=t.create();for(let o=0;o<s.length;o++)s[o]^=106;this.oHash.update(s),s.fill(0)}update(t){return ln(this),this.iHash.update(t),this}digestInto(t){ln(this),Bo(t,this.outputLen),this.finished=!0,this.iHash.digestInto(t),this.oHash.update(t),this.oHash.digestInto(t),this.destroy()}digest(){let t=new Uint8Array(this.oHash.outputLen);return this.digestInto(t),t}_cloneInto(t){t||(t=Object.create(Object.getPrototypeOf(this),{}));let{oHash:r,iHash:n,finished:i,destroyed:s,blockLen:o,outputLen:a}=this;return t=t,t.finished=i,t.destroyed=s,t.blockLen=o,t.outputLen=a,t.oHash=r._cloneInto(t.oHash),t.iHash=n._cloneInto(t.iHash),t}destroy(){this.destroyed=!0,this.oHash.destroy(),this.iHash.destroy()}},ua=(e,t,r)=>new Zi(e,t).update(r).digest();ua.create=(e,t)=>new Zi(e,t);function dg(e){return{hash:e,hmac:(t,...r)=>ua(e,t,Ni(...r)),randomBytes:dn}}function cf(e,t){let r=n=>af({...e,...dg(n)});return Object.freeze({...r(t),create:r})}var lf=BigInt("0xfffffffffffffffffffffffffffffffffffffffffffffffffffffffefffffc2f"),uf=BigInt("0xfffffffffffffffffffffffffffffffebaaedce6af48a03bbfd25e8cd0364141"),pg=BigInt(1),fa=BigInt(2),ff=(e,t)=>(e+t/fa)/t;function yg(e){let t=lf,r=BigInt(3),n=BigInt(6),i=BigInt(11),s=BigInt(22),o=BigInt(23),a=BigInt(44),c=BigInt(88),u=e*e*e%t,f=u*u*e%t,l=Et(f,r,t)*f%t,h=Et(l,r,t)*f%t,y=Et(h,fa,t)*u%t,d=Et(y,i,t)*y%t,p=Et(d,s,t)*d%t,m=Et(p,a,t)*p%t,x=Et(m,c,t)*m%t,E=Et(x,a,t)*p%t,b=Et(E,r,t)*f%t,R=Et(b,o,t)*d%t,w=Et(R,n,t)*u%t,S=Et(w,fa,t);if(!la.eql(la.sqr(S),e))throw new Error("Cannot find square root");return S}var la=Fi(lf,void 0,void 0,{sqrt:yg}),Re=cf({a:BigInt(0),b:BigInt(7),Fp:la,n:uf,Gx:BigInt("55066263022277343669578718895168534326250603453777594175500187360389116729240"),Gy:BigInt("32670510020758816978083085130507043184471273380659243275938904335757337482424"),h:BigInt(1),lowS:!0,endo:{beta:BigInt("0x7ae96a2b657c07106e64479eac3434e99cf0497512f58995c1396c28719501ee"),splitScalar:e=>{let t=uf,r=BigInt("0x3086d221a7d46bcde86c90e49284eb15"),n=-pg*BigInt("0xe4437ed6010e88286f547fa90abfe4c3"),i=BigInt("0x114ca50f7a8e2f3f657c1108d9d44cfd8"),s=r,o=BigInt("0x100000000000000000000000000000000"),a=ff(s*e,t),c=ff(-n*e,t),u=dt(e-a*r-c*i,t),f=dt(-a*n-c*s,t),l=u>o,h=f>o;if(l&&(u=t-u),h&&(f=t-f),u>o||f>o)throw new Error("splitScalar: Endomorphism failed, k="+e);return{k1neg:l,k1:u,k2neg:h,k2:f}}}},sf),UE=BigInt(0);var OE=Re.ProjectivePoint;function hf(){return Re.utils.randomPrivateKey()}function df(e,t){let r=Ut.digest(t instanceof Uint8Array?t:t.subarray());if(ve(r))return r.then(({digest:n})=>Re.sign(n,e).toDERRawBytes()).catch(n=>{throw new H(String(n),"ERR_INVALID_INPUT")});try{return Re.sign(r.digest,e).toDERRawBytes()}catch(n){throw new H(String(n),"ERR_INVALID_INPUT")}}function pf(e,t,r){let n=Ut.digest(r instanceof Uint8Array?r:r.subarray());if(ve(n))return n.then(({digest:i})=>Re.verify(t,i,e)).catch(i=>{throw new H(String(i),"ERR_INVALID_INPUT")});try{return Re.verify(t,n.digest,e)}catch(i){throw new H(String(i),"ERR_INVALID_INPUT")}}function yf(e){return Re.ProjectivePoint.fromHex(e).toRawBytes(!0)}function mf(e){try{Re.getPublicKey(e,!0)}catch(t){throw new H(String(t),"ERR_INVALID_PRIVATE_KEY")}}function ha(e){try{Re.ProjectivePoint.fromHex(e)}catch(t){throw new H(String(t),"ERR_INVALID_PUBLIC_KEY")}}function gf(e){try{return Re.getPublicKey(e,!0)}catch(t){throw new H(String(t),"ERR_INVALID_PRIVATE_KEY")}}var Zn=class{_key;constructor(t){ha(t),this._key=t}verify(t,r){return pf(this._key,r,t)}marshal(){return yf(this._key)}get bytes(){return Ve.encode({Type:wt.Secp256k1,Data:this.marshal()}).subarray()}equals(t){return Ct(this.bytes,t.bytes)}async hash(){let t=Ut.digest(this.bytes),r;return ve(t)?{bytes:r}=await t:r=t.bytes,r}},Xn=class{_key;_publicKey;constructor(t,r){this._key=t,this._publicKey=r??gf(t),mf(this._key),ha(this._publicKey)}sign(t){return df(this._key,t)}get public(){return new Zn(this._publicKey)}marshal(){return this._key}get bytes(){return qe.encode({Type:wt.Secp256k1,Data:this.marshal()}).subarray()}equals(t){return Ct(this.bytes,t.bytes)}hash(){let t=Ut.digest(this.bytes);return ve(t)?t.then(({bytes:r})=>r):t.bytes}async id(){let t=await this.public.hash();return pt(t,"base58btc")}async export(t,r="libp2p-key"){if(r==="libp2p-key")return gn(this.bytes,t);throw new H(`export format '${r}' is not supported`,"ERR_INVALID_EXPORT_FORMAT")}};function gg(e){return new Xn(e)}function xg(e){return new Zn(e)}async function vg(){let e=hf();return new Xn(e)}var Gr={rsa:aa,ed25519:ra,secp256k1:da};function xf(e){let t=Object.keys(Gr).join(" / ");return new H(`invalid or unsupported key type ${e}. Must be ${t}`,"ERR_UNSUPPORTED_KEY_TYPE")}function vf(e){let t=Ve.decode(e),r=t.Data??new Uint8Array;switch(t.Type){case wt.RSA:return Gr.rsa.unmarshalRsaPublicKey(r);case wt.Ed25519:return Gr.ed25519.unmarshalEd25519PublicKey(r);case wt.Secp256k1:return Gr.secp256k1.unmarshalSecp256k1PublicKey(r);default:throw xf(t.Type??"unknown")}}async function bf(e){let t=qe.decode(e),r=t.Data??new Uint8Array;switch(t.Type){case wt.RSA:return Gr.rsa.unmarshalRsaPrivateKey(r);case wt.Ed25519:return Gr.ed25519.unmarshalEd25519PrivateKey(r);case wt.Secp256k1:return Gr.secp256k1.unmarshalSecp256k1PrivateKey(r);default:throw xf(t.Type??"RSA")}}var Eg=Math.pow(2,7),wg=Math.pow(2,14),Sg=Math.pow(2,21),pa=Math.pow(2,28),ya=Math.pow(2,35),ma=Math.pow(2,42),ga=Math.pow(2,49),ct=128,jt=127;function te(e){if(e<Eg)return 1;if(e<wg)return 2;if(e<Sg)return 3;if(e<pa)return 4;if(e<ya)return 5;if(e<ma)return 6;if(e<ga)return 7;if(Number.MAX_SAFE_INTEGER!=null&&e>Number.MAX_SAFE_INTEGER)throw new RangeError("Could not encode varint");return 8}function Ag(e,t,r=0){switch(te(e)){case 8:t[r++]=e&255|ct,e/=128;case 7:t[r++]=e&255|ct,e/=128;case 6:t[r++]=e&255|ct,e/=128;case 5:t[r++]=e&255|ct,e/=128;case 4:t[r++]=e&255|ct,e>>>=7;case 3:t[r++]=e&255|ct,e>>>=7;case 2:t[r++]=e&255|ct,e>>>=7;case 1:{t[r++]=e&255,e>>>=7;break}default:throw new Error("unreachable")}return t}function Tg(e,t,r=0){switch(te(e)){case 8:t.set(r++,e&255|ct),e/=128;case 7:t.set(r++,e&255|ct),e/=128;case 6:t.set(r++,e&255|ct),e/=128;case 5:t.set(r++,e&255|ct),e/=128;case 4:t.set(r++,e&255|ct),e>>>=7;case 3:t.set(r++,e&255|ct),e>>>=7;case 2:t.set(r++,e&255|ct),e>>>=7;case 1:{t.set(r++,e&255),e>>>=7;break}default:throw new Error("unreachable")}return t}function Bg(e,t){let r=e[t],n=0;if(n+=r&jt,r<ct||(r=e[t+1],n+=(r&jt)<<7,r<ct)||(r=e[t+2],n+=(r&jt)<<14,r<ct)||(r=e[t+3],n+=(r&jt)<<21,r<ct)||(r=e[t+4],n+=(r&jt)*pa,r<ct)||(r=e[t+5],n+=(r&jt)*ya,r<ct)||(r=e[t+6],n+=(r&jt)*ma,r<ct)||(r=e[t+7],n+=(r&jt)*ga,r<ct))return n;throw new RangeError("Could not decode varint")}function Ig(e,t){let r=e.get(t),n=0;if(n+=r&jt,r<ct||(r=e.get(t+1),n+=(r&jt)<<7,r<ct)||(r=e.get(t+2),n+=(r&jt)<<14,r<ct)||(r=e.get(t+3),n+=(r&jt)<<21,r<ct)||(r=e.get(t+4),n+=(r&jt)*pa,r<ct)||(r=e.get(t+5),n+=(r&jt)*ya,r<ct)||(r=e.get(t+6),n+=(r&jt)*ma,r<ct)||(r=e.get(t+7),n+=(r&jt)*ga,r<ct))return n;throw new RangeError("Could not decode varint")}function Ee(e,t,r=0){return t==null&&(t=$t(te(e))),t instanceof Uint8Array?Ag(e,t,r):Tg(e,t,r)}function Le(e,t=0){return e instanceof Uint8Array?Bg(e,t):Ig(e,t)}var wf=Symbol.for("@achingbrain/uint8arraylist");function Ef(e,t){if(t==null||t<0)throw new RangeError("index is out of bounds");let r=0;for(let n of e){let i=r+n.byteLength;if(t<i)return{buf:n,index:t-r};r=i}throw new RangeError("index is out of bounds")}function Xi(e){return!!e?.[wf]}var ue=class e{bufs;length;[wf]=!0;constructor(...t){this.bufs=[],this.length=0,t.length>0&&this.appendAll(t)}*[Symbol.iterator](){yield*this.bufs}get byteLength(){return this.length}append(...t){this.appendAll(t)}appendAll(t){let r=0;for(let n of t)if(n instanceof Uint8Array)r+=n.byteLength,this.bufs.push(n);else if(Xi(n))r+=n.byteLength,this.bufs.push(...n.bufs);else throw new Error("Could not append value, must be an Uint8Array or a Uint8ArrayList");this.length+=r}prepend(...t){this.prependAll(t)}prependAll(t){let r=0;for(let n of t.reverse())if(n instanceof Uint8Array)r+=n.byteLength,this.bufs.unshift(n);else if(Xi(n))r+=n.byteLength,this.bufs.unshift(...n.bufs);else throw new Error("Could not prepend value, must be an Uint8Array or a Uint8ArrayList");this.length+=r}get(t){let r=Ef(this.bufs,t);return r.buf[r.index]}set(t,r){let n=Ef(this.bufs,t);n.buf[n.index]=r}write(t,r=0){if(t instanceof Uint8Array)for(let n=0;n<t.length;n++)this.set(r+n,t[n]);else if(Xi(t))for(let n=0;n<t.length;n++)this.set(r+n,t.get(n));else throw new Error("Could not write value, must be an Uint8Array or a Uint8ArrayList")}consume(t){if(t=Math.trunc(t),!(Number.isNaN(t)||t<=0)){if(t===this.byteLength){this.bufs=[],this.length=0;return}for(;this.bufs.length>0;)if(t>=this.bufs[0].byteLength)t-=this.bufs[0].byteLength,this.length-=this.bufs[0].byteLength,this.bufs.shift();else{this.bufs[0]=this.bufs[0].subarray(t),this.length-=t;break}}}slice(t,r){let{bufs:n,length:i}=this._subList(t,r);return Ot(n,i)}subarray(t,r){let{bufs:n,length:i}=this._subList(t,r);return n.length===1?n[0]:Ot(n,i)}sublist(t,r){let{bufs:n,length:i}=this._subList(t,r),s=new e;return s.length=i,s.bufs=[...n],s}_subList(t,r){if(t=t??0,r=r??this.length,t<0&&(t=this.length+t),r<0&&(r=this.length+r),t<0||r>this.length)throw new RangeError("index is out of bounds");if(t===r)return{bufs:[],length:0};if(t===0&&r===this.length)return{bufs:this.bufs,length:this.length};let n=[],i=0;for(let s=0;s<this.bufs.length;s++){let o=this.bufs[s],a=i,c=a+o.byteLength;if(i=c,t>=c)continue;let u=t>=a&&t<c,f=r>a&&r<=c;if(u&&f){if(t===a&&r===c){n.push(o);break}let l=t-a;n.push(o.subarray(l,l+(r-t)));break}if(u){if(t===0){n.push(o);continue}n.push(o.subarray(t-a));continue}if(f){if(r===c){n.push(o);break}n.push(o.subarray(0,r-a));break}n.push(o)}return{bufs:n,length:r-t}}indexOf(t,r=0){if(!Xi(t)&&!(t instanceof Uint8Array))throw new TypeError('The "value" argument must be a Uint8ArrayList or Uint8Array');let n=t instanceof Uint8Array?t:t.subarray();if(r=Number(r??0),isNaN(r)&&(r=0),r<0&&(r=this.length+r),r<0&&(r=0),t.length===0)return r>this.length?this.length:r;let i=n.byteLength;if(i===0)throw new TypeError("search must be at least 1 byte long");let s=256,o=new Int32Array(s);for(let l=0;l<s;l++)o[l]=-1;for(let l=0;l<i;l++)o[n[l]]=l;let a=o,c=this.byteLength-n.byteLength,u=n.byteLength-1,f;for(let l=r;l<=c;l+=f){f=0;for(let h=u;h>=0;h--){let y=this.get(l+h);if(n[h]!==y){f=Math.max(1,h-a[y]);break}}if(f===0)return l}return-1}getInt8(t){let r=this.subarray(t,t+1);return new DataView(r.buffer,r.byteOffset,r.byteLength).getInt8(0)}setInt8(t,r){let n=$t(1);new DataView(n.buffer,n.byteOffset,n.byteLength).setInt8(0,r),this.write(n,t)}getInt16(t,r){let n=this.subarray(t,t+2);return new DataView(n.buffer,n.byteOffset,n.byteLength).getInt16(0,r)}setInt16(t,r,n){let i=Qe(2);new DataView(i.buffer,i.byteOffset,i.byteLength).setInt16(0,r,n),this.write(i,t)}getInt32(t,r){let n=this.subarray(t,t+4);return new DataView(n.buffer,n.byteOffset,n.byteLength).getInt32(0,r)}setInt32(t,r,n){let i=Qe(4);new DataView(i.buffer,i.byteOffset,i.byteLength).setInt32(0,r,n),this.write(i,t)}getBigInt64(t,r){let n=this.subarray(t,t+8);return new DataView(n.buffer,n.byteOffset,n.byteLength).getBigInt64(0,r)}setBigInt64(t,r,n){let i=Qe(8);new DataView(i.buffer,i.byteOffset,i.byteLength).setBigInt64(0,r,n),this.write(i,t)}getUint8(t){let r=this.subarray(t,t+1);return new DataView(r.buffer,r.byteOffset,r.byteLength).getUint8(0)}setUint8(t,r){let n=$t(1);new DataView(n.buffer,n.byteOffset,n.byteLength).setUint8(0,r),this.write(n,t)}getUint16(t,r){let n=this.subarray(t,t+2);return new DataView(n.buffer,n.byteOffset,n.byteLength).getUint16(0,r)}setUint16(t,r,n){let i=Qe(2);new DataView(i.buffer,i.byteOffset,i.byteLength).setUint16(0,r,n),this.write(i,t)}getUint32(t,r){let n=this.subarray(t,t+4);return new DataView(n.buffer,n.byteOffset,n.byteLength).getUint32(0,r)}setUint32(t,r,n){let i=Qe(4);new DataView(i.buffer,i.byteOffset,i.byteLength).setUint32(0,r,n),this.write(i,t)}getBigUint64(t,r){let n=this.subarray(t,t+8);return new DataView(n.buffer,n.byteOffset,n.byteLength).getBigUint64(0,r)}setBigUint64(t,r,n){let i=Qe(8);new DataView(i.buffer,i.byteOffset,i.byteLength).setBigUint64(0,r,n),this.write(i,t)}getFloat32(t,r){let n=this.subarray(t,t+4);return new DataView(n.buffer,n.byteOffset,n.byteLength).getFloat32(0,r)}setFloat32(t,r,n){let i=Qe(4);new DataView(i.buffer,i.byteOffset,i.byteLength).setFloat32(0,r,n),this.write(i,t)}getFloat64(t,r){let n=this.subarray(t,t+8);return new DataView(n.buffer,n.byteOffset,n.byteLength).getFloat64(0,r)}setFloat64(t,r,n){let i=Qe(8);new DataView(i.buffer,i.byteOffset,i.byteLength).setFloat64(0,r,n),this.write(i,t)}equals(t){if(t==null||!(t instanceof e)||t.bufs.length!==this.bufs.length)return!1;for(let r=0;r<this.bufs.length;r++)if(!Ct(this.bufs[r],t.bufs[r]))return!1;return!0}static fromUint8Arrays(t,r){let n=new e;return n.bufs=t,r==null&&(r=t.reduce((i,s)=>i+s.byteLength,0)),n.length=r,n}};var Sf={ERR_SIGNATURE_NOT_VALID:"ERR_SIGNATURE_NOT_VALID"};var Jn;(function(e){let t;e.codec=()=>(t==null&&(t=Jt((r,n,i={})=>{i.lengthDelimited!==!1&&n.fork(),r.publicKey!=null&&r.publicKey.byteLength>0&&(n.uint32(10),n.bytes(r.publicKey)),r.payloadType!=null&&r.payloadType.byteLength>0&&(n.uint32(18),n.bytes(r.payloadType)),r.payload!=null&&r.payload.byteLength>0&&(n.uint32(26),n.bytes(r.payload)),r.signature!=null&&r.signature.byteLength>0&&(n.uint32(42),n.bytes(r.signature)),i.lengthDelimited!==!1&&n.ldelim()},(r,n)=>{let i={publicKey:new Uint8Array(0),payloadType:new Uint8Array(0),payload:new Uint8Array(0),signature:new Uint8Array(0)},s=n==null?r.len:r.pos+n;for(;r.pos<s;){let o=r.uint32();switch(o>>>3){case 1:i.publicKey=r.bytes();break;case 2:i.payloadType=r.bytes();break;case 3:i.payload=r.bytes();break;case 5:i.signature=r.bytes();break;default:r.skipType(o&7);break}}return i})),t),e.encode=r=>Xt(r,e.codec()),e.decode=r=>Zt(r,e.codec())})(Jn||(Jn={}));var jn=class e{static createFromProtobuf=async t=>{let r=Jn.decode(t),n=await H0(r.publicKey);return new e({peerId:n,payloadType:r.payloadType,payload:r.payload,signature:r.signature})};static seal=async(t,r)=>{if(r.privateKey==null)throw new Error("Missing private key");let n=t.domain,i=t.codec,s=t.marshal(),o=Af(n,i,s),c=await(await bf(r.privateKey)).sign(o.subarray());return new e({peerId:r,payloadType:i,payload:s,signature:c})};static openAndCertify=async(t,r)=>{let n=await e.createFromProtobuf(t);if(!await n.validate(r))throw new H("envelope signature is not valid for the given domain",Sf.ERR_SIGNATURE_NOT_VALID);return n};peerId;payloadType;payload;signature;marshaled;constructor(t){let{peerId:r,payloadType:n,payload:i,signature:s}=t;this.peerId=r,this.payloadType=n,this.payload=i,this.signature=s}marshal(){if(this.peerId.publicKey==null)throw new Error("Missing public key");return this.marshaled==null&&(this.marshaled=Jn.encode({publicKey:this.peerId.publicKey,payloadType:this.payloadType,payload:this.payload.subarray(),signature:this.signature})),this.marshaled}equals(t){return Ct(this.marshal(),t.marshal())}async validate(t){let r=Af(t,this.payloadType,this.payload);if(this.peerId.publicKey==null)throw new Error("Missing public key");return vf(this.peerId.publicKey).verify(r.subarray(),this.signature)}},Af=(e,t,r)=>{let n=Nt(e),i=Ee(n.byteLength),s=Ee(t.length),o=Ee(r.length);return new ue(i,n,s,t,o,r)};var Ji=class{index=0;input="";new(t){return this.index=0,this.input=t,this}readAtomically(t){let r=this.index,n=t();return n===void 0&&(this.index=r),n}parseWith(t){let r=t();if(this.index===this.input.length)return r}peekChar(){if(!(this.index>=this.input.length))return this.input[this.index]}readChar(){if(!(this.index>=this.input.length))return this.input[this.index++]}readGivenChar(t){return this.readAtomically(()=>{let r=this.readChar();if(r===t)return r})}readSeparator(t,r,n){return this.readAtomically(()=>{if(!(r>0&&this.readGivenChar(t)===void 0))return n()})}readNumber(t,r,n,i){return this.readAtomically(()=>{let s=0,o=0,a=this.peekChar();if(a===void 0)return;let c=a==="0",u=2**(8*i)-1;for(;;){let f=this.readAtomically(()=>{let l=this.readChar();if(l===void 0)return;let h=Number.parseInt(l,t);if(!Number.isNaN(h))return h});if(f===void 0)break;if(s*=t,s+=f,s>u||(o+=1,r!==void 0&&o>r))return}if(o!==0)return!n&&c&&o>1?void 0:s})}readIPv4Addr(){return this.readAtomically(()=>{let t=new Uint8Array(4);for(let r=0;r<t.length;r++){let n=this.readSeparator(".",r,()=>this.readNumber(10,3,!1,1));if(n===void 0)return;t[r]=n}return t})}readIPv6Addr(){let t=r=>{for(let n=0;n<r.length/2;n++){let i=n*2;if(n<r.length-3){let o=this.readSeparator(":",n,()=>this.readIPv4Addr());if(o!==void 0)return r[i]=o[0],r[i+1]=o[1],r[i+2]=o[2],r[i+3]=o[3],[i+4,!0]}let s=this.readSeparator(":",n,()=>this.readNumber(16,4,!0,2));if(s===void 0)return[i,!1];r[i]=s>>8,r[i+1]=s&255}return[r.length,!1]};return this.readAtomically(()=>{let r=new Uint8Array(16),[n,i]=t(r);if(n===16)return r;if(i||this.readGivenChar(":")===void 0||this.readGivenChar(":")===void 0)return;let s=new Uint8Array(14),o=16-(n+2),[a]=t(s.subarray(0,o));return r.set(s.subarray(0,a),16-a),r})}readIPAddr(){return this.readIPv4Addr()??this.readIPv6Addr()}};var Tf=45,Cg=15,wn=new Ji;function xa(e){if(!(e.length>Cg))return wn.new(e).parseWith(()=>wn.readIPv4Addr())}function va(e){if(e.includes("%")&&(e=e.split("%")[0]),!(e.length>Tf))return wn.new(e).parseWith(()=>wn.readIPv6Addr())}function ji(e){if(e.includes("%")&&(e=e.split("%")[0]),!(e.length>Tf))return wn.new(e).parseWith(()=>wn.readIPAddr())}var Nw=parseInt("0xFFFF",16),Pw=new Uint8Array([0,0,0,0,0,0,0,0,0,0,255,255]);function Cf(e){return!!xa(e)}function _f(e){return!!va(e)}function ts(e){return!!ji(e)}var Rf=Cf,Ng=_f,ba=function(e){let t=0;if(e=e.toString().trim(),Rf(e)){let r=new Uint8Array(t+4);return e.split(/\./g).forEach(n=>{r[t++]=parseInt(n,10)&255}),r}if(Ng(e)){let r=e.split(":",8),n;for(n=0;n<r.length;n++){let s=Rf(r[n]),o;s&&(o=ba(r[n]),r[n]=pt(o.slice(0,2),"base16")),o!=null&&++n<8&&r.splice(n,0,pt(o.slice(2,4),"base16"))}if(r[0]==="")for(;r.length<8;)r.unshift("0");else if(r[r.length-1]==="")for(;r.length<8;)r.push("0");else if(r.length<8){for(n=0;n<r.length&&r[n]!=="";n++);let s=[n,1];for(n=9-r.length;n>0;n--)s.push("0");r.splice.apply(r,s)}let i=new Uint8Array(t+16);for(n=0;n<r.length;n++){let s=parseInt(r[n],16);i[t++]=s>>8&255,i[t++]=s&255}return i}throw new Error("invalid ip address")},Lf=function(e,t=0,r){t=~~t,r=r??e.length-t;let n=new DataView(e.buffer);if(r===4){let i=[];for(let s=0;s<r;s++)i.push(e[t+s]);return i.join(".")}if(r===16){let i=[];for(let s=0;s<r;s+=2)i.push(n.getUint16(t+s).toString(16));return i.join(":").replace(/(^|:)0(:0)*:0(:|$)/,"$1::$3").replace(/:{3,4}/,"::")}return""};var Sn={},Ea={},kg=[[4,32,"ip4"],[6,16,"tcp"],[33,16,"dccp"],[41,128,"ip6"],[42,-1,"ip6zone"],[43,8,"ipcidr"],[53,-1,"dns",!0],[54,-1,"dns4",!0],[55,-1,"dns6",!0],[56,-1,"dnsaddr",!0],[132,16,"sctp"],[273,16,"udp"],[275,0,"p2p-webrtc-star"],[276,0,"p2p-webrtc-direct"],[277,0,"p2p-stardust"],[280,0,"webrtc-direct"],[281,0,"webrtc"],[290,0,"p2p-circuit"],[301,0,"udt"],[302,0,"utp"],[400,-1,"unix",!1,!0],[421,-1,"ipfs"],[421,-1,"p2p"],[443,0,"https"],[444,96,"onion"],[445,296,"onion3"],[446,-1,"garlic64"],[448,0,"tls"],[449,-1,"sni"],[460,0,"quic"],[461,0,"quic-v1"],[465,0,"webtransport"],[466,-1,"certhash"],[477,0,"ws"],[478,0,"wss"],[479,0,"p2p-websocket-star"],[480,0,"http"],[777,-1,"memory"]];kg.forEach(e=>{let t=Ug(...e);Ea[t.code]=t,Sn[t.name]=t});function Ug(e,t,r,n,i){return{code:e,size:t,name:r,resolvable:!!n,path:!!i}}function yt(e){if(typeof e=="number"){if(Ea[e]!=null)return Ea[e];throw new Error(`no protocol with code: ${e}`)}else if(typeof e=="string"){if(Sn[e]!=null)return Sn[e];throw new Error(`no protocol with name: ${e}`)}throw new Error(`invalid protocol id type: ${typeof e}`)}var gS=yt("ip4"),xS=yt("ip6"),vS=yt("ipcidr");function Sa(e,t){switch(yt(e).code){case 4:case 41:return Mg(t);case 42:return Pf(t);case 6:case 273:case 33:case 132:return Uf(t).toString();case 53:case 54:case 55:case 56:case 400:case 449:case 777:return Pf(t);case 421:return qg(t);case 444:return kf(t);case 445:return kf(t);case 466:return Vg(t);default:return pt(t,"base16")}}function Aa(e,t){switch(yt(e).code){case 4:return Df(t);case 41:return Df(t);case 42:return Nf(t);case 6:case 273:case 33:case 132:return Ta(parseInt(t,10));case 53:case 54:case 55:case 56:case 400:case 449:case 777:return Nf(t);case 421:return Kg(t);case 444:return Hg(t);case 445:return zg(t);case 466:return Fg(t);default:return Nt(t,"base16")}}var wa=Object.values(ur).map(e=>e.decoder),Og=function(){let e=wa[0].or(wa[1]);return wa.slice(2).forEach(t=>e=e.or(t)),e}();function Df(e){if(!ts(e))throw new Error("invalid ip address");return ba(e)}function Mg(e){let t=Lf(e,0,e.length);if(t==null)throw new Error("ipBuff is required");if(!ts(t))throw new Error("invalid ip address");return t}function Ta(e){let t=new ArrayBuffer(2);return new DataView(t).setUint16(0,e),new Uint8Array(t)}function Uf(e){return new DataView(e.buffer).getUint16(e.byteOffset)}function Nf(e){let t=Nt(e),r=Uint8Array.from(Ee(t.length));return Ot([r,t],r.length+t.length)}function Pf(e){let t=Le(e);if(e=e.slice(te(t)),e.length!==t)throw new Error("inconsistent lengths");return pt(e)}function Kg(e){let t;e[0]==="Q"||e[0]==="1"?t=Cr(kt.decode(`z${e}`)).bytes:t=fe.parse(e).multihash.bytes;let r=Uint8Array.from(Ee(t.length));return Ot([r,t],r.length+t.length)}function Fg(e){let t=Og.decode(e),r=Uint8Array.from(Ee(t.length));return Ot([r,t],r.length+t.length)}function Vg(e){let t=Le(e),r=e.slice(te(t));if(r.length!==t)throw new Error("inconsistent lengths");return"u"+pt(r,"base64url")}function qg(e){let t=Le(e),r=e.slice(te(t));if(r.length!==t)throw new Error("inconsistent lengths");return pt(r,"base58btc")}function Hg(e){let t=e.split(":");if(t.length!==2)throw new Error(`failed to parse onion addr: ["'${t.join('", "')}'"]' does not contain a port number`);if(t[0].length!==16)throw new Error(`failed to parse onion addr: ${t[0]} not a Tor onion address.`);let r=Ge.decode("b"+t[0]),n=parseInt(t[1],10);if(n<1||n>65536)throw new Error("Port number is not in range(1, 65536)");let i=Ta(n);return Ot([r,i],r.length+i.length)}function zg(e){let t=e.split(":");if(t.length!==2)throw new Error(`failed to parse onion addr: ["'${t.join('", "')}'"]' does not contain a port number`);if(t[0].length!==56)throw new Error(`failed to parse onion addr: ${t[0]} not a Tor onion3 address.`);let r=Ge.decode(`b${t[0]}`),n=parseInt(t[1],10);if(n<1||n>65536)throw new Error("Port number is not in range(1, 65536)");let i=Ta(n);return Ot([r,i],r.length+i.length)}function kf(e){let t=e.slice(0,e.length-2),r=e.slice(e.length-2),n=pt(t,"base32"),i=Uf(r);return`${n}:${i}`}function Of(e){e=Ba(e);let t=[],r=[],n=null,i=e.split("/").slice(1);if(i.length===1&&i[0]==="")return{bytes:new Uint8Array,string:"/",tuples:[],stringTuples:[],path:null};for(let s=0;s<i.length;s++){let o=i[s],a=yt(o);if(a.size===0){t.push([a.code]),r.push([a.code]);continue}if(s++,s>=i.length)throw Kf("invalid address: "+e);if(a.path===!0){n=Ba(i.slice(s).join("/")),t.push([a.code,Aa(a.code,n)]),r.push([a.code,n]);break}let c=Aa(a.code,i[s]);t.push([a.code,c]),r.push([a.code,Sa(a.code,c)])}return{string:Mf(r),bytes:Ca(t),tuples:t,stringTuples:r,path:n}}function Ia(e){let t=[],r=[],n=null,i=0;for(;i<e.length;){let s=Le(e,i),o=te(s),a=yt(s),c=Gg(a,e.slice(i+o));if(c===0){t.push([s]),r.push([s]),i+=o;continue}let u=e.slice(i+o,i+o+c);if(i+=c+o,i>e.length)throw Kf("Invalid address Uint8Array: "+pt(e,"base16"));t.push([s,u]);let f=Sa(s,u);if(r.push([s,f]),a.path===!0){n=f;break}}return{bytes:Uint8Array.from(e),string:Mf(r),tuples:t,stringTuples:r,path:n}}function Mf(e){let t=[];return e.map(r=>{let n=yt(r[0]);return t.push(n.name),r.length>1&&r[1]!=null&&t.push(r[1]),null}),Ba(t.join("/"))}function Ca(e){return Ot(e.map(t=>{let r=yt(t[0]),n=Uint8Array.from(Ee(r.code));return t.length>1&&t[1]!=null&&(n=Ot([n,t[1]])),n}))}function Gg(e,t){if(e.size>0)return e.size/8;if(e.size===0)return 0;{let r=Le(t instanceof Uint8Array?t:Uint8Array.from(t));return r+te(r)}}function Ba(e){return"/"+e.trim().split("/").filter(t=>t).join("/")}function Kf(e){return new Error("Error parsing address: "+e)}var Wg=Symbol.for("nodejs.util.inspect.custom"),_a=Symbol.for("@multiformats/js-multiaddr/multiaddr"),Yg=[yt("dns").code,yt("dns4").code,yt("dns6").code,yt("dnsaddr").code],es=class e{bytes;#t;#e;#r;#n;[_a]=!0;constructor(t){t==null&&(t="");let r;if(t instanceof Uint8Array)r=Ia(t);else if(typeof t=="string"){if(t.length>0&&t.charAt(0)!=="/")throw new Error(`multiaddr "${t}" must start with a "/"`);r=Of(t)}else if(Vf(t))r=Ia(t.bytes);else throw new Error("addr must be a string, Buffer, or another Multiaddr");this.bytes=r.bytes,this.#t=r.string,this.#e=r.tuples,this.#r=r.stringTuples,this.#n=r.path}toString(){return this.#t}toJSON(){return this.toString()}toOptions(){let t,r,n,i,s="",o=yt("tcp"),a=yt("udp"),c=yt("ip4"),u=yt("ip6"),f=yt("dns6"),l=yt("ip6zone");for(let[y,d]of this.stringTuples())y===l.code&&(s=`%${d??""}`),Yg.includes(y)&&(r=o.name,i=443,n=`${d??""}${s}`,t=y===f.code?6:4),(y===o.code||y===a.code)&&(r=yt(y).name,i=parseInt(d??"")),(y===c.code||y===u.code)&&(r=yt(y).name,n=`${d??""}${s}`,t=y===u.code?6:4);if(t==null||r==null||n==null||i==null)throw new Error('multiaddr must have a valid format: "/{ip4, ip6, dns4, dns6, dnsaddr}/{address}/{tcp, udp}/{port}".');return{family:t,host:n,transport:r,port:i}}protos(){return this.#e.map(([t])=>Object.assign({},yt(t)))}protoCodes(){return this.#e.map(([t])=>t)}protoNames(){return this.#e.map(([t])=>yt(t).name)}tuples(){return this.#e}stringTuples(){return this.#r}encapsulate(t){return t=new e(t),new e(this.toString()+t.toString())}decapsulate(t){let r=t.toString(),n=this.toString(),i=n.lastIndexOf(r);if(i<0)throw new Error(`Address ${this.toString()} does not contain subaddress: ${t.toString()}`);return new e(n.slice(0,i))}decapsulateCode(t){let r=this.tuples();for(let n=r.length-1;n>=0;n--)if(r[n][0]===t)return new e(Ca(r.slice(0,n)));return this}getPeerId(){try{let t=[];this.stringTuples().forEach(([n,i])=>{n===Sn.p2p.code&&t.push([n,i]),n===Sn["p2p-circuit"].code&&(t=[])});let r=t.pop();if(r?.[1]!=null){let n=r[1];return n[0]==="Q"||n[0]==="1"?pt(kt.decode(`z${n}`),"base58btc"):pt(fe.parse(n).multihash.bytes,"base58btc")}return null}catch{return null}}getPath(){return this.#n}equals(t){return Ct(this.bytes,t.bytes)}async resolve(t){let r=this.protos().find(s=>s.resolvable);if(r==null)return[this];let n=Ff.get(r.name);if(n==null)throw new H(`no available resolver for ${r.name}`,"ERR_NO_AVAILABLE_RESOLVER");return(await n(this,t)).map(s=>new e(s))}nodeAddress(){let t=this.toOptions();if(t.transport!=="tcp"&&t.transport!=="udp")throw new Error(`multiaddr must have a valid format - no protocol with name: "${t.transport}". Must have a valid transport protocol: "{tcp, udp}"`);return{family:t.family,address:t.host,port:t.port}}isThinWaistAddress(t){let r=(t??this).protos();return!(r.length!==2||r[0].code!==4&&r[0].code!==41||r[1].code!==6&&r[1].code!==273)}[Wg](){return`Multiaddr(${this.#t})`}};var Ff=new Map;function Vf(e){return!!e?.[_a]}function ee(e){return new es(e)}var $g=Uint8Array.from([3,1]);var Ra;(function(e){let t;(function(n){let i;n.codec=()=>(i==null&&(i=Jt((s,o,a={})=>{a.lengthDelimited!==!1&&o.fork(),s.multiaddr!=null&&s.multiaddr.byteLength>0&&(o.uint32(10),o.bytes(s.multiaddr)),a.lengthDelimited!==!1&&o.ldelim()},(s,o)=>{let a={multiaddr:new Uint8Array(0)},c=o==null?s.len:s.pos+o;for(;s.pos<c;){let u=s.uint32();switch(u>>>3){case 1:a.multiaddr=s.bytes();break;default:s.skipType(u&7);break}}return a})),i),n.encode=s=>Xt(s,n.codec()),n.decode=s=>Zt(s,n.codec())})(t=e.AddressInfo||(e.AddressInfo={}));let r;e.codec=()=>(r==null&&(r=Jt((n,i,s={})=>{if(s.lengthDelimited!==!1&&i.fork(),n.peerId!=null&&n.peerId.byteLength>0&&(i.uint32(10),i.bytes(n.peerId)),n.seq!=null&&n.seq!==0n&&(i.uint32(16),i.uint64(n.seq)),n.addresses!=null)for(let o of n.addresses)i.uint32(26),e.AddressInfo.codec().encode(o,i);s.lengthDelimited!==!1&&i.ldelim()},(n,i)=>{let s={peerId:new Uint8Array(0),seq:0n,addresses:[]},o=i==null?n.len:n.pos+i;for(;n.pos<o;){let a=n.uint32();switch(a>>>3){case 1:s.peerId=n.bytes();break;case 2:s.seq=n.uint64();break;case 3:s.addresses.push(e.AddressInfo.codec().decode(n,n.uint32()));break;default:n.skipType(a&7);break}}return s})),r),e.encode=n=>Xt(n,e.codec()),e.decode=n=>Zt(n,e.codec())})(Ra||(Ra={}));function wr(){let e={};return e.promise=new Promise((t,r)=>{e.resolve=t,e.reject=r}),e}var rs=class extends Error{type;code;constructor(t,r){super(t??"The operation was aborted"),this.type="aborted",this.name="AbortError",this.code=r??"ABORT_ERR"}};async function qf(e,t,r){if(t==null)return e;if(t.aborted)return Promise.reject(new rs(r?.errorMessage,r?.errorCode));let n,i=new rs(r?.errorMessage,r?.errorCode);try{return await Promise.race([e,new Promise((s,o)=>{n=()=>{o(i)},t.addEventListener("abort",n)})])}finally{n!=null&&t.removeEventListener("abort",n)}}var La=class{needNext;haveNext;ended;nextResult;constructor(){this.ended=!1,this.needNext=wr(),this.haveNext=wr()}[Symbol.asyncIterator](){return this}async next(){if(this.nextResult==null&&await this.haveNext.promise,this.nextResult==null)throw new Error("Have next but next was undefined");let t=this.nextResult;return this.nextResult=void 0,this.needNext.resolve(),this.needNext=wr(),t}async throw(t){return this.ended=!0,t!=null&&this.haveNext.reject(t),{done:!0,value:void 0}}async return(){let t={done:!0,value:void 0};return await this._push(void 0),t}async push(t,r){await this._push(t,r)}async end(t,r){t!=null?await this.throw(t):await this._push(void 0,r)}async _push(t,r){if(t!=null&&this.ended)throw new Error("Cannot push value onto an ended pushable");this.nextResult!=null&&await this.needNext.promise,t!=null?this.nextResult={done:!1,value:t}:(this.ended=!0,this.nextResult={done:!0,value:void 0}),this.haveNext.resolve(),this.haveNext=wr(),await qf(this.needNext.promise,r?.signal,r)}};function Hf(){return new La}var ns=class extends Error{code;constructor(t,r){super(t),this.code=r}},Da=class extends ns{type;constructor(t){super(t,"ABORT_ERR"),this.type="aborted"}};function zf(e,t){let r=Hf();e.sink(r).catch(async o=>{await r.end(o)}),e.sink=async o=>{for await(let a of o)await r.push(a);await r.end()};let n=e.source;e.source[Symbol.iterator]!=null?n=e.source[Symbol.iterator]():e.source[Symbol.asyncIterator]!=null&&(n=e.source[Symbol.asyncIterator]());let i=new ue;return{read:async(o,a)=>{a?.signal?.throwIfAborted();let c,u=new Promise((f,l)=>{c=()=>{l(new Da("Read aborted"))},a?.signal?.addEventListener("abort",c)});try{if(o==null){let{done:l,value:h}=await Promise.race([n.next(),u]);return l===!0?new ue:h}for(;i.byteLength<o;){let{value:l,done:h}=await Promise.race([n.next(),u]);if(h===!0)throw new ns("unexpected end of input","ERR_UNEXPECTED_EOF");i.append(l)}let f=i.sublist(0,o);return i.consume(o),f}finally{c!=null&&a?.signal?.removeEventListener("abort",c)}},write:async(o,a)=>{a?.signal?.throwIfAborted(),o instanceof Uint8Array?await r.push(o,a):await r.push(o.subarray(),a)},unwrap:()=>{if(i.byteLength>0){let o=e.source;e.source=async function*(){t?.yieldBytes===!1?yield i:yield*i,yield*o}()}return e}}}function is(e){return e[Symbol.asyncIterator]!=null}var ss=e=>{let t=te(e),r=$t(t);return Ee(e,r),ss.bytes=t,r};ss.bytes=0;function ti(e,t){t=t??{};let r=t.lengthEncoder??ss;function*n(i){let s=r(i.byteLength);s instanceof Uint8Array?yield s:yield*s,i instanceof Uint8Array?yield i:yield*i}return is(e)?async function*(){for await(let i of e)yield*n(i)}():function*(){for(let i of e)yield*n(i)}()}ti.single=(e,t)=>{t=t??{};let r=t.lengthEncoder??ss;return new ue(r(e.byteLength),e)};var An=Yt(Yf(),1);var Zg=8,Xg=1024*1024*4,Wr;(function(e){e[e.LENGTH=0]="LENGTH",e[e.DATA=1]="DATA"})(Wr||(Wr={}));var Pa=e=>{let t=Le(e);return Pa.bytes=te(t),t};Pa.bytes=0;function Na(e,t){let r=new ue,n=Wr.LENGTH,i=-1,s=t?.lengthDecoder??Pa,o=t?.maxLengthLength??Zg,a=t?.maxDataLength??Xg;function*c(){for(;r.byteLength>0;){if(n===Wr.LENGTH)try{if(i=s(r),i<0)throw(0,An.default)(new Error("invalid message length"),"ERR_INVALID_MSG_LENGTH");if(i>a)throw(0,An.default)(new Error("message length too long"),"ERR_MSG_DATA_TOO_LONG");let u=s.bytes;r.consume(u),t?.onLength!=null&&t.onLength(i),n=Wr.DATA}catch(u){if(u instanceof RangeError){if(r.byteLength>o)throw(0,An.default)(new Error("message length length too long"),"ERR_MSG_LENGTH_TOO_LONG");break}throw u}if(n===Wr.DATA){if(r.byteLength<i)break;let u=r.sublist(0,i);r.consume(i),t?.onData!=null&&t.onData(u),yield u,n=Wr.LENGTH}}}return is(e)?async function*(){for await(let u of e)r.append(u),yield*c();if(r.byteLength>0)throw(0,An.default)(new Error("unexpected end of input"),"ERR_UNEXPECTED_EOF")}():function*(){for(let u of e)r.append(u),yield*c();if(r.byteLength>0)throw(0,An.default)(new Error("unexpected end of input"),"ERR_UNEXPECTED_EOF")}()}Na.fromReader=(e,t)=>{let r=1,n=async function*(){for(;;)try{let{done:s,value:o}=await e.next(r);if(s===!0)return;o!=null&&(yield o)}catch(s){if(s.code==="ERR_UNDER_READ")return{done:!0,value:null};throw s}finally{r=1}}();return Na(n,{...t??{},onLength:s=>{r=s}})};var os=class extends Error{code;constructor(t,r){super(t),this.code=r}},$f=e=>Le(e);$f.bytes=0;function Qf(e,t={}){let r=zf(e,t);return t.maxDataLength!=null&&t.maxLengthLength==null&&(t.maxLengthLength=te(t.maxDataLength)),{read:async i=>{let s=-1,o=new ue,a=t?.lengthDecoder??$f;for(;;){o.append(await r.read(1,i));try{s=a(o)}catch(c){if(c instanceof RangeError)continue;throw c}if(t?.maxLengthLength!=null&&o.byteLength>t.maxLengthLength)throw new os("message length length too long","ERR_MSG_LENGTH_TOO_LONG");if(s>-1)break}if(t?.maxDataLength!=null&&s>t.maxDataLength)throw new os("message length too long","ERR_MSG_DATA_TOO_LONG");return r.read(s,i)},write:async(i,s)=>{await r.write(ti.single(i,t),s)},writeV:async(i,s)=>{let o=new ue(...i.map(a=>ti.single(a,t)));await r.write(o,s)},unwrap:()=>r.unwrap()}}function Sr(e,t){let r=Qf(e,t),n={read:async(i,s)=>{let o=await r.read(s);return i.decode(o)},write:async(i,s,o)=>{await r.write(s.encode(i),o)},writeV:async(i,s,o)=>{await r.writeV(i.map(a=>s.encode(a)),o)},pb:i=>({read:async s=>n.read(i,s),write:async(s,o)=>n.write(s,i,o),writeV:async(s,o)=>n.writeV(s,i,o),unwrap:()=>n}),unwrap:()=>r.unwrap()};return n}var as="/libp2p/relay";var Zf="circuit-relay-source",Xf="circuit-relay-relay";var Jf=BigInt(131072),we="/libp2p/circuit/relay/0.2.0/hop",Yr="/libp2p/circuit/relay/0.2.0/stop",jf=30*1e3,tl=30*1e3,ei=300,el="ERR_NO_ROUTERS_AVAILABLE",ka="ERR_RELAYED_DIAL",rl="ERR_HOP_REQUEST_FAILED",cs="ERR_TRANSFER_LIMIT_EXCEEDED";var ft;(function(e){let t;(function(i){i.RESERVE="RESERVE",i.CONNECT="CONNECT",i.STATUS="STATUS"})(t=e.Type||(e.Type={}));let r;(function(i){i[i.RESERVE=0]="RESERVE",i[i.CONNECT=1]="CONNECT",i[i.STATUS=2]="STATUS"})(r||(r={})),function(i){i.codec=()=>Fr(r)}(t=e.Type||(e.Type={}));let n;e.codec=()=>(n==null&&(n=Jt((i,s,o={})=>{o.lengthDelimited!==!1&&s.fork(),i.type!=null&&(s.uint32(8),e.Type.codec().encode(i.type,s)),i.peer!=null&&(s.uint32(18),Tn.codec().encode(i.peer,s)),i.reservation!=null&&(s.uint32(26),us.codec().encode(i.reservation,s)),i.limit!=null&&(s.uint32(34),Bn.codec().encode(i.limit,s)),i.status!=null&&(s.uint32(40),tt.codec().encode(i.status,s)),o.lengthDelimited!==!1&&s.ldelim()},(i,s)=>{let o={},a=s==null?i.len:i.pos+s;for(;i.pos<a;){let c=i.uint32();switch(c>>>3){case 1:o.type=e.Type.codec().decode(i);break;case 2:o.peer=Tn.codec().decode(i,i.uint32());break;case 3:o.reservation=us.codec().decode(i,i.uint32());break;case 4:o.limit=Bn.codec().decode(i,i.uint32());break;case 5:o.status=tt.codec().decode(i);break;default:i.skipType(c&7);break}}return o})),n),e.encode=i=>Xt(i,e.codec()),e.decode=i=>Zt(i,e.codec())})(ft||(ft={}));var de;(function(e){let t;(function(i){i.CONNECT="CONNECT",i.STATUS="STATUS"})(t=e.Type||(e.Type={}));let r;(function(i){i[i.CONNECT=0]="CONNECT",i[i.STATUS=1]="STATUS"})(r||(r={})),function(i){i.codec=()=>Fr(r)}(t=e.Type||(e.Type={}));let n;e.codec=()=>(n==null&&(n=Jt((i,s,o={})=>{o.lengthDelimited!==!1&&s.fork(),i.type!=null&&(s.uint32(8),e.Type.codec().encode(i.type,s)),i.peer!=null&&(s.uint32(18),Tn.codec().encode(i.peer,s)),i.limit!=null&&(s.uint32(26),Bn.codec().encode(i.limit,s)),i.status!=null&&(s.uint32(32),tt.codec().encode(i.status,s)),o.lengthDelimited!==!1&&s.ldelim()},(i,s)=>{let o={},a=s==null?i.len:i.pos+s;for(;i.pos<a;){let c=i.uint32();switch(c>>>3){case 1:o.type=e.Type.codec().decode(i);break;case 2:o.peer=Tn.codec().decode(i,i.uint32());break;case 3:o.limit=Bn.codec().decode(i,i.uint32());break;case 4:o.status=tt.codec().decode(i);break;default:i.skipType(c&7);break}}return o})),n),e.encode=i=>Xt(i,e.codec()),e.decode=i=>Zt(i,e.codec())})(de||(de={}));var Tn;(function(e){let t;e.codec=()=>(t==null&&(t=Jt((r,n,i={})=>{if(i.lengthDelimited!==!1&&n.fork(),r.id!=null&&r.id.byteLength>0&&(n.uint32(10),n.bytes(r.id)),r.addrs!=null)for(let s of r.addrs)n.uint32(18),n.bytes(s);i.lengthDelimited!==!1&&n.ldelim()},(r,n)=>{let i={id:new Uint8Array(0),addrs:[]},s=n==null?r.len:r.pos+n;for(;r.pos<s;){let o=r.uint32();switch(o>>>3){case 1:i.id=r.bytes();break;case 2:i.addrs.push(r.bytes());break;default:r.skipType(o&7);break}}return i})),t),e.encode=r=>Xt(r,e.codec()),e.decode=r=>Zt(r,e.codec())})(Tn||(Tn={}));var us;(function(e){let t;e.codec=()=>(t==null&&(t=Jt((r,n,i={})=>{if(i.lengthDelimited!==!1&&n.fork(),r.expire!=null&&r.expire!==0n&&(n.uint32(8),n.uint64(r.expire)),r.addrs!=null)for(let s of r.addrs)n.uint32(18),n.bytes(s);r.voucher!=null&&(n.uint32(26),n.bytes(r.voucher)),i.lengthDelimited!==!1&&n.ldelim()},(r,n)=>{let i={expire:0n,addrs:[]},s=n==null?r.len:r.pos+n;for(;r.pos<s;){let o=r.uint32();switch(o>>>3){case 1:i.expire=r.uint64();break;case 2:i.addrs.push(r.bytes());break;case 3:i.voucher=r.bytes();break;default:r.skipType(o&7);break}}return i})),t),e.encode=r=>Xt(r,e.codec()),e.decode=r=>Zt(r,e.codec())})(us||(us={}));var Bn;(function(e){let t;e.codec=()=>(t==null&&(t=Jt((r,n,i={})=>{i.lengthDelimited!==!1&&n.fork(),r.duration!=null&&(n.uint32(8),n.uint32(r.duration)),r.data!=null&&(n.uint32(16),n.uint64(r.data)),i.lengthDelimited!==!1&&n.ldelim()},(r,n)=>{let i={},s=n==null?r.len:r.pos+n;for(;r.pos<s;){let o=r.uint32();switch(o>>>3){case 1:i.duration=r.uint32();break;case 2:i.data=r.uint64();break;default:r.skipType(o&7);break}}return i})),t),e.encode=r=>Xt(r,e.codec()),e.decode=r=>Zt(r,e.codec())})(Bn||(Bn={}));var tt;(function(e){e.UNUSED="UNUSED",e.OK="OK",e.RESERVATION_REFUSED="RESERVATION_REFUSED",e.RESOURCE_LIMIT_EXCEEDED="RESOURCE_LIMIT_EXCEEDED",e.PERMISSION_DENIED="PERMISSION_DENIED",e.CONNECTION_FAILED="CONNECTION_FAILED",e.NO_RESERVATION="NO_RESERVATION",e.MALFORMED_MESSAGE="MALFORMED_MESSAGE",e.UNEXPECTED_MESSAGE="UNEXPECTED_MESSAGE"})(tt||(tt={}));var Ua;(function(e){e[e.UNUSED=0]="UNUSED",e[e.OK=100]="OK",e[e.RESERVATION_REFUSED=200]="RESERVATION_REFUSED",e[e.RESOURCE_LIMIT_EXCEEDED=201]="RESOURCE_LIMIT_EXCEEDED",e[e.PERMISSION_DENIED=202]="PERMISSION_DENIED",e[e.CONNECTION_FAILED=203]="CONNECTION_FAILED",e[e.NO_RESERVATION=204]="NO_RESERVATION",e[e.MALFORMED_MESSAGE=400]="MALFORMED_MESSAGE",e[e.UNEXPECTED_MESSAGE=401]="UNEXPECTED_MESSAGE"})(Ua||(Ua={}));(function(e){e.codec=()=>Fr(Ua)})(tt||(tt={}));var fs;(function(e){let t;e.codec=()=>(t==null&&(t=Jt((r,n,i={})=>{i.lengthDelimited!==!1&&n.fork(),r.relay!=null&&r.relay.byteLength>0&&(n.uint32(10),n.bytes(r.relay)),r.peer!=null&&r.peer.byteLength>0&&(n.uint32(18),n.bytes(r.peer)),r.expiration!=null&&r.expiration!==0n&&(n.uint32(24),n.uint64(r.expiration)),i.lengthDelimited!==!1&&n.ldelim()},(r,n)=>{let i={relay:new Uint8Array(0),peer:new Uint8Array(0),expiration:0n},s=n==null?r.len:r.pos+n;for(;r.pos<s;){let o=r.uint32();switch(o>>>3){case 1:i.relay=r.bytes();break;case 2:i.peer=r.bytes();break;case 3:i.expiration=r.uint64();break;default:r.skipType(o&7);break}}return i})),t),e.encode=r=>Xt(r,e.codec()),e.decode=r=>Zt(r,e.codec())})(fs||(fs={}));function nl(e){let t=new globalThis.AbortController;function r(){t.abort();for(let s of e)s?.removeEventListener!=null&&s.removeEventListener("abort",r)}for(let s of e){if(s?.aborted===!0){r();break}s?.addEventListener!=null&&s.addEventListener("abort",r)}function n(){for(let s of e)s?.removeEventListener!=null&&s.removeEventListener("abort",r)}let i=t.signal;return i.clear=n,i}async function*il(e,t,r){let n=t.remaining;for await(let i of e){let s=BigInt(i.byteLength);if(t.remaining-s<0){let o=Number(t.remaining);t.remaining=0n;try{o!==0&&(yield i.subarray(0,o))}catch(a){r.log.error(a)}throw new H(`data limit of ${n} bytes exceeded`,cs)}t.remaining-=s,yield i}}function sl(e,t,r,n,i){function s(l){e.abort(l),t.abort(l)}let o=[r];n?.duration!=null&&o.push(AbortSignal.timeout(n.duration));let a=nl(o),c=!1,u=!1,f;n?.data!=null&&(f={remaining:n.data}),queueMicrotask(()=>{let l=()=>{t.abort(new H(`duration limit of ${n?.duration} ms exceeded`,cs))};a.addEventListener("abort",l,{once:!0}),t.sink(f==null?e.source:il(e.source,f,i)).catch(h=>{i.log.error("error while relaying streams src -> dst",h),s(h)}).finally(()=>{c=!0,u&&(a.removeEventListener("abort",l),a.clear())})}),queueMicrotask(()=>{let l=()=>{e.abort(new H(`duration limit of ${n?.duration} ms exceeded`,cs))};a.addEventListener("abort",l,{once:!0}),e.sink(f==null?t.source:il(t.source,f,i)).catch(h=>{i.log.error("error while relaying streams dst -> src",h),s(h)}).finally(()=>{u=!0,c&&(a.removeEventListener("abort",l),a.clear())})})}async function ls(e){let t=new TextEncoder().encode(e),r=await Ut.digest(t);return fe.createV0(r)}function Oa(e){let t=e*BigInt(1e3),r=new Date().getTime();return Number(t-BigInt(r))}var hl=Yt(fl(),1);var t1=Object.prototype.toString,e1=e=>t1.call(e)==="[object Error]",r1=new Set(["Failed to fetch","NetworkError when attempting to fetch resource.","The Internet connection appears to be offline.","Load failed","Network request failed","fetch failed"]);function Ma(e){return e&&e1(e)&&e.name==="TypeError"&&typeof e.message=="string"?e.message==="Load failed"?e.stack===void 0:r1.has(e.message):!1}var Ka=class extends Error{constructor(t){super(),t instanceof Error?(this.originalError=t,{message:t}=t):(this.originalError=new Error(t),this.originalError.stack=this.stack),this.name="AbortError",this.message=t}},ll=(e,t,r)=>{let n=r.retries-(t-1);return e.attemptNumber=t,e.retriesLeft=n,e};async function Fa(e,t){return new Promise((r,n)=>{t={onFailedAttempt(){},retries:10,...t};let i=hl.default.operation(t),s=()=>{i.stop(),n(t.signal?.reason)};t.signal&&!t.signal.aborted&&t.signal.addEventListener("abort",s,{once:!0});let o=()=>{t.signal?.removeEventListener("abort",s),i.stop()};i.attempt(async a=>{try{let c=await e(a);o(),r(c)}catch(c){try{if(!(c instanceof Error))throw new TypeError(`Non-error was thrown: "${c}". You should only throw errors.`);if(c instanceof Ka)throw c.originalError;if(c instanceof TypeError&&!Ma(c))throw c;if(await t.onFailedAttempt(ll(c,a,t)),!i.retry(c))throw i.mainError()}catch(u){ll(u,a,t),o(),n(u)}}})})}var hs=class extends me{contentRouting;timeout;started;bootDelay;log;constructor(t,r){super(),this.log=t.logger.forComponent("libp2p:circuit-relay:advert-service"),this.contentRouting=t.contentRouting,this.bootDelay=r?.bootDelay??tl,this.started=!1}isStarted(){return this.started}start(){this.started||(this.timeout=setTimeout(()=>{this._advertiseService().catch(t=>{this.log.error("could not advertise service",t)})},this.bootDelay),this.started=!0)}stop(){try{clearTimeout(this.timeout)}catch{}this.started=!1}async _advertiseService(){await Fa(async()=>{try{let t=await ls(as);await this.contentRouting.provide(t),this.safeDispatchEvent("advert:success",{detail:void 0})}catch(t){if(this.safeDispatchEvent("advert:error",{detail:t}),t.code===el){this.log.error("a content router, such as a DHT, must be provided in order to advertise the relay service",t),this.stop();return}throw this.log.error("could not advertise service",t),t}})}};function nr(e,t){let r={[Symbol.iterator]:()=>r,next:()=>{let n=e.next(),i=n.value;return n.done===!0||i==null?{done:!0,value:void 0}:{done:!1,value:t(i)}}};return r}var ir=class{map;constructor(t){if(this.map=new Map,t!=null)for(let[r,n]of t.entries())this.map.set(r.toString(),n)}[Symbol.iterator](){return this.entries()}clear(){this.map.clear()}delete(t){this.map.delete(t.toString())}entries(){return nr(this.map.entries(),t=>[St(t[0]),t[1]])}forEach(t){this.map.forEach((r,n)=>{t(r,St(n),this)})}get(t){return this.map.get(t.toString())}has(t){return this.map.has(t.toString())}set(t,r){this.map.set(t.toString(),r)}keys(){return nr(this.map.keys(),t=>St(t))}values(){return this.map.values()}get size(){return this.map.size}};var Va=class e{set;constructor(t){if(this.set=new Set,t!=null)for(let r of t)this.set.add(r.toString())}get size(){return this.set.size}[Symbol.iterator](){return this.values()}add(t){this.set.add(t.toString())}clear(){this.set.clear()}delete(t){this.set.delete(t.toString())}entries(){return nr(this.set.entries(),t=>{let r=St(t[0]);return[r,r]})}forEach(t){this.set.forEach(r=>{let n=St(r);t(n,n,this)})}has(t){return this.set.has(t.toString())}values(){return nr(this.set.values(),t=>St(t))}intersection(t){let r=new e;for(let n of t)this.has(n)&&r.add(n);return r}difference(t){let r=new e;for(let n of this)t.has(n)||r.add(n);return r}union(t){let r=new e;for(let n of t)r.add(n);for(let n of this)r.add(n);return r}};var qa=class e{list;constructor(t){if(this.list=[],t!=null)for(let r of t)this.list.push(r.toString())}[Symbol.iterator](){return nr(this.list.entries(),t=>St(t[1]))}concat(t){let r=new e(this);for(let n of t)r.push(n);return r}entries(){return nr(this.list.entries(),t=>[t[0],St(t[1])])}every(t){return this.list.every((r,n)=>t(St(r),n,this))}filter(t){let r=new e;return this.list.forEach((n,i)=>{let s=St(n);t(s,i,this)&&r.push(s)}),r}find(t){let r=this.list.find((n,i)=>t(St(n),i,this));if(r!=null)return St(r)}findIndex(t){return this.list.findIndex((r,n)=>t(St(r),n,this))}forEach(t){this.list.forEach((r,n)=>{t(St(r),n,this)})}includes(t){return this.list.includes(t.toString())}indexOf(t){return this.list.indexOf(t.toString())}pop(){let t=this.list.pop();if(t!=null)return St(t)}push(...t){for(let r of t)this.list.push(r.toString())}shift(){let t=this.list.shift();if(t!=null)return St(t)}unshift(...t){let r=this.list.length;for(let n=t.length-1;n>-1;n--)r=this.list.unshift(t[n].toString());return r}get length(){return this.list.length}};var ds=class{reservations=new ir;_started=!1;interval;maxReservations;reservationClearInterval;applyDefaultLimit;reservationTtl;defaultDurationLimit;defaultDataLimit;constructor(t={}){this.maxReservations=t.maxReservations??15,this.reservationClearInterval=t.reservationClearInterval??3e5,this.applyDefaultLimit=t.applyDefaultLimit!==!1,this.reservationTtl=t.reservationTtl??72e5,this.defaultDurationLimit=t.defaultDurationLimit??12e4,this.defaultDataLimit=t.defaultDataLimit??Jf}isStarted(){return this._started}start(){this._started||(this._started=!0,this.interval=setInterval(()=>{let t=new Date().getTime();this.reservations.forEach((r,n)=>{r.expire.getTime()<t&&this.reservations.delete(n)})},this.reservationClearInterval))}stop(){clearInterval(this.interval)}reserve(t,r,n){if(this.reservations.size>=this.maxReservations&&!this.reservations.has(t))return{status:tt.RESERVATION_REFUSED};let i=new Date(Date.now()+this.reservationTtl),s;return this.applyDefaultLimit&&(s=n??{data:this.defaultDataLimit,duration:this.defaultDurationLimit}),this.reservations.set(t,{addr:r,expire:i,limit:s}),{status:tt.OK,expire:Math.round(i.getTime()/1e3)}}removeReservation(t){this.reservations.delete(t)}hasReservation(t){return this.reservations.has(t)}get(t){return this.reservations.get(t)}};var ps=class e{domain="libp2p-relay-rsvp";codec=new Uint8Array([3,2]);relay;peer;expiration;constructor({relay:t,peer:r,expiration:n}){this.relay=t,this.peer=r,this.expiration=n}marshal(){return fs.encode({relay:this.relay.toBytes(),peer:this.peer.toBytes(),expiration:BigInt(this.expiration)})}equals(t){return!(!(t instanceof e)||!this.peer.equals(t.peer)||!this.relay.equals(t.relay)||this.expiration!==t.expiration)}};var dl=e=>e.protoCodes().includes(290),a1={maxOutboundStopStreams:ei},Ha=class extends me{registrar;peerStore;addressManager;peerId;connectionManager;connectionGater;reservationStore;advertService;started;hopTimeout;shutdownController;maxInboundHopStreams;maxOutboundHopStreams;maxOutboundStopStreams;log;constructor(t,r={}){super(),this.log=t.logger.forComponent("libp2p:circuit-relay:server"),this.registrar=t.registrar,this.peerStore=t.peerStore,this.addressManager=t.addressManager,this.peerId=t.peerId,this.connectionManager=t.connectionManager,this.connectionGater=t.connectionGater,this.started=!1,this.hopTimeout=r?.hopTimeout??jf,this.shutdownController=new AbortController,this.maxInboundHopStreams=r.maxInboundHopStreams,this.maxOutboundHopStreams=r.maxOutboundHopStreams,this.maxOutboundStopStreams=r.maxOutboundStopStreams??a1.maxOutboundStopStreams,w0(1/0,this.shutdownController.signal),r.advertise!=null&&r.advertise!==!1&&(this.advertService=new hs(t,r.advertise===!0?void 0:r.advertise),this.advertService.addEventListener("advert:success",()=>{this.safeDispatchEvent("relay:advert:success",{})}),this.advertService.addEventListener("advert:error",n=>{this.safeDispatchEvent("relay:advert:error",{detail:n.detail})})),this.reservationStore=new ds(r.reservations)}isStarted(){return this.started}async start(){this.started||(this.advertService?.start(),await this.registrar.handle(we,t=>{this.onHop(t).catch(r=>{this.log.error(r)})},{maxInboundStreams:this.maxInboundHopStreams,maxOutboundStreams:this.maxOutboundHopStreams,runOnTransientConnection:!0}),this.reservationStore.start(),this.started=!0)}async stop(){this.advertService?.stop(),this.reservationStore.stop(),this.shutdownController.abort(),await this.registrar.unhandle(we),this.started=!1}async onHop({connection:t,stream:r}){this.log("received circuit v2 hop protocol stream from %p",t.remotePeer);let n=wr(),i=setTimeout(()=>{n.reject("timed out")},this.hopTimeout),s=Sr(r);try{let o=await Promise.race([s.pb(ft).read(),n.promise]);if(o?.type==null)throw new Error("request was invalid, could not read from stream");this.log("received",o.type),await Promise.race([this.handleHopProtocol({connection:t,stream:s,request:o}),n.promise])}catch(o){this.log.error("error while handling hop",o),await s.pb(ft).write({type:ft.Type.STATUS,status:tt.MALFORMED_MESSAGE}),r.abort(o)}finally{clearTimeout(i)}}async handleHopProtocol({stream:t,request:r,connection:n}){switch(this.log("received hop message"),r.type){case ft.Type.RESERVE:await this.handleReserve({stream:t,request:r,connection:n});break;case ft.Type.CONNECT:await this.handleConnect({stream:t,request:r,connection:n});break;default:this.log.error("invalid hop request type %s via peer %p",r.type,n.remotePeer),await t.pb(ft).write({type:ft.Type.STATUS,status:tt.UNEXPECTED_MESSAGE})}}async handleReserve({stream:t,request:r,connection:n}){let i=t.pb(ft);if(this.log("hop reserve request from %p",n.remotePeer),dl(n.remoteAddr)){this.log.error("relay reservation over circuit connection denied for peer: %p",n.remotePeer),await i.write({type:ft.Type.STATUS,status:tt.PERMISSION_DENIED});return}if(await this.connectionGater.denyInboundRelayReservation?.(n.remotePeer)===!0){this.log.error("reservation for %p denied by connection gater",n.remotePeer),await i.write({type:ft.Type.STATUS,status:tt.PERMISSION_DENIED});return}let s=this.reservationStore.reserve(n.remotePeer,n.remoteAddr);if(s.status!==tt.OK){await i.write({type:ft.Type.STATUS,status:s.status});return}try{if(s.expire!=null){let o=s.expire*1e3-Date.now();await this.peerStore.merge(n.remotePeer,{tags:{[Zf]:{value:1,ttl:o}}})}await i.write({type:ft.Type.STATUS,status:tt.OK,reservation:await this.makeReservation(n.remotePeer,BigInt(s.expire??0)),limit:this.reservationStore.get(n.remotePeer)?.limit}),this.log("sent confirmation response to %s",n.remotePeer)}catch(o){this.log.error("failed to send confirmation response to %p",n.remotePeer,o),this.reservationStore.removeReservation(n.remotePeer)}}async makeReservation(t,r){let n=[];for(let s of this.addressManager.getAddresses())s.toString().includes("/p2p-circuit")||n.push(s.bytes);let i=await jn.seal(new ps({peer:t,relay:this.peerId,expiration:Number(r)}),this.peerId);return{addrs:n,expire:r,voucher:i.marshal()}}async handleConnect({stream:t,request:r,connection:n}){let i=t.pb(ft);if(dl(n.remoteAddr)){this.log.error("relay reservation over circuit connection denied for peer: %p",n.remotePeer),await i.write({type:ft.Type.STATUS,status:tt.PERMISSION_DENIED});return}this.log("hop connect request from %p",n.remotePeer);let s;try{if(r.peer==null)throw this.log.error("no peer info in hop connect request"),new Error("no peer info in request");r.peer.addrs.forEach(ee),s=on(r.peer.id)}catch(l){this.log.error("invalid hop connect request via peer %p %s",n.remotePeer,l),await i.write({type:ft.Type.STATUS,status:tt.MALFORMED_MESSAGE});return}if(!this.reservationStore.hasReservation(s)){this.log.error("hop connect denied for destination peer %p not having a reservation for %p with status %s",s,n.remotePeer,tt.NO_RESERVATION),await i.write({type:ft.Type.STATUS,status:tt.NO_RESERVATION});return}if(await this.connectionGater.denyOutboundRelayedConnection?.(n.remotePeer,s)===!0){this.log.error("hop connect for %p to %p denied by connection gater",n.remotePeer,s),await i.write({type:ft.Type.STATUS,status:tt.PERMISSION_DENIED});return}let o=this.connectionManager.getConnections(s);if(o.length===0){this.log("hop connect denied for destination peer %p not having a connection for %p as there is no destination connection",s,n.remotePeer),await i.write({type:ft.Type.STATUS,status:tt.NO_RESERVATION});return}let a=o[0],c=await this.stopHop({connection:a,request:{type:de.Type.CONNECT,peer:{id:n.remotePeer.toBytes(),addrs:[]}}});if(c==null){this.log.error("failed to open stream to destination peer %p",a?.remotePeer),await i.write({type:ft.Type.STATUS,status:tt.CONNECTION_FAILED});return}await i.write({type:ft.Type.STATUS,status:tt.OK});let u=t.unwrap();this.log("connection from %p to %p established - merging streams",n.remotePeer,s);let f=this.reservationStore.get(s)?.limit;sl(u,c,this.shutdownController.signal,f,{log:this.log})}async stopHop({connection:t,request:r}){this.log("starting circuit relay v2 stop request to %s",t.remotePeer);let n=await t.newStream([Yr],{maxOutboundStreams:this.maxOutboundStopStreams,runOnTransientConnection:!0}),i=Sr(n),s=i.pb(de);await s.write(r);let o;try{o=await s.read()}catch{this.log.error("error parsing stop message response from %p",t.remotePeer)}if(o==null){this.log.error("could not read response from %p",t.remotePeer),await n.close();return}if(o.status===tt.OK)return this.log("stop request to %p was successful",t.remotePeer),i.unwrap();this.log("stop request failed with code %d",o.status),await n.close()}get reservations(){return this.reservationStore.reservations}};function pl(e={}){return t=>new Ha(t,e)}var ys=class extends me{peerId;peerStore;contentRouting;registrar;started;topologyId;log;constructor(t){super(),this.log=t.logger.forComponent("libp2p:circuit-relay:discover-relays"),this.started=!1,this.peerId=t.peerId,this.peerStore=t.peerStore,this.contentRouting=t.contentRouting,this.registrar=t.registrar}isStarted(){return this.started}async start(){this.topologyId=await this.registrar.register(we,{notifyOnTransient:!0,onConnect:t=>{this.safeDispatchEvent("relay:discover",{detail:t})}}),this.discover().catch(t=>{this.log.error("error listening on relays",t)}),this.started=!0}stop(){this.topologyId!=null&&this.registrar.unregister(this.topologyId),this.started=!1}async discover(){this.log("searching peer store for relays");let t=await this.peerStore.all({filters:[r=>r.protocols.includes(we)],orders:[()=>Math.random()<.5?1:-1]});for(let r of t)this.log("found relay peer %p in content peer store",r.id),this.safeDispatchEvent("relay:discover",{detail:r.id});this.log("found %d relay peers in peer store",t.length);try{this.log("searching content routing for relays");let r=await ls(as),n=0;for await(let i of this.contentRouting.findProviders(r))if(i.multiaddrs.length>0&&!i.id.equals(this.peerId)){let s=i.id;n++,await this.peerStore.merge(s,{multiaddrs:i.multiaddrs}),this.log("found relay peer %p in content routing",s),this.safeDispatchEvent("relay:discover",{detail:s})}this.log("found %d relay peers in content routing",n)}catch(r){this.log.error("failed when finding relays on the network",r)}}};var Wa=Yt(ml(),1);var ni=class extends Error{constructor(t){super(t),this.name="TimeoutError"}},Ya=class extends Error{constructor(t){super(),this.name="AbortError",this.message=t}},gl=e=>globalThis.DOMException===void 0?new Ya(e):new DOMException(e),xl=e=>{let t=e.reason===void 0?gl("This operation was aborted."):e.reason;return t instanceof Error?t:gl(t)};function $a(e,t,r,n){let i,s=new Promise((o,a)=>{if(typeof t!="number"||Math.sign(t)!==1)throw new TypeError(`Expected \`milliseconds\` to be a positive number, got \`${t}\``);if(t===Number.POSITIVE_INFINITY){o(e);return}if(n={customTimers:{setTimeout,clearTimeout},...n},n.signal){let{signal:c}=n;c.aborted&&a(xl(c)),c.addEventListener("abort",()=>{a(xl(c))})}i=n.customTimers.setTimeout.call(void 0,()=>{if(typeof r=="function"){try{o(r())}catch(f){a(f)}return}let c=typeof r=="string"?r:`Promise timed out after ${t} milliseconds`,u=r instanceof Error?r:new ni(c);typeof e.cancel=="function"&&e.cancel(),a(u)},t),(async()=>{try{o(await e)}catch(c){a(c)}finally{n.customTimers.clearTimeout.call(void 0,i)}})()});return s.clear=()=>{clearTimeout(i),i=void 0},s}function Qa(e,t,r){let n=0,i=e.length;for(;i>0;){let s=Math.trunc(i/2),o=n+s;r(e[o],t)<=0?(n=++o,i-=s+1):i=s}return n}var Qr=function(e,t,r,n){if(r==="a"&&!n)throw new TypeError("Private accessor was defined without a getter");if(typeof t=="function"?e!==t||!n:!t.has(e))throw new TypeError("Cannot read private member from an object whose class did not declare it");return r==="m"?n:r==="a"?n.call(e):n?n.value:t.get(e)},sr,Za=class{constructor(){sr.set(this,[])}enqueue(t,r){r={priority:0,...r};let n={priority:r.priority,run:t};if(this.size&&Qr(this,sr,"f")[this.size-1].priority>=r.priority){Qr(this,sr,"f").push(n);return}let i=Qa(Qr(this,sr,"f"),n,(s,o)=>o.priority-s.priority);Qr(this,sr,"f").splice(i,0,n)}dequeue(){let t=Qr(this,sr,"f").shift();return t?.run}filter(t){return Qr(this,sr,"f").filter(r=>r.priority===t.priority).map(r=>r.run)}get size(){return Qr(this,sr,"f").length}};sr=new WeakMap;var vl=Za;var At=function(e,t,r,n,i){if(n==="m")throw new TypeError("Private method is not writable");if(n==="a"&&!i)throw new TypeError("Private accessor was defined without a setter");if(typeof t=="function"?e!==t||!i:!t.has(e))throw new TypeError("Cannot write private member to an object whose class did not declare it");return n==="a"?i.call(e,r):i?i.value=r:t.set(e,r),r},K=function(e,t,r,n){if(r==="a"&&!n)throw new TypeError("Private accessor was defined without a getter");if(typeof t=="function"?e!==t||!n:!t.has(e))throw new TypeError("Cannot read private member from an object whose class did not declare it");return r==="m"?n:r==="a"?n.call(e):n?n.value:t.get(e)},_t,si,oi,Tr,ws,ai,gs,De,ii,pe,xs,ye,ci,Ar,vs,bl,El,Al,wl,Sl,bs,Xa,Ja,Ss,Tl,Es,As=class extends Error{},ja=class extends Wa.default{constructor(t){var r,n,i,s;if(super(),_t.add(this),si.set(this,void 0),oi.set(this,void 0),Tr.set(this,0),ws.set(this,void 0),ai.set(this,void 0),gs.set(this,0),De.set(this,void 0),ii.set(this,void 0),pe.set(this,void 0),xs.set(this,void 0),ye.set(this,0),ci.set(this,void 0),Ar.set(this,void 0),vs.set(this,void 0),Object.defineProperty(this,"timeout",{enumerable:!0,configurable:!0,writable:!0,value:void 0}),t={carryoverConcurrencyCount:!1,intervalCap:Number.POSITIVE_INFINITY,interval:0,concurrency:Number.POSITIVE_INFINITY,autoStart:!0,queueClass:vl,...t},!(typeof t.intervalCap=="number"&&t.intervalCap>=1))throw new TypeError(`Expected \`intervalCap\` to be a number from 1 and up, got \`${(n=(r=t.intervalCap)===null||r===void 0?void 0:r.toString())!==null&&n!==void 0?n:""}\` (${typeof t.intervalCap})`);if(t.interval===void 0||!(Number.isFinite(t.interval)&&t.interval>=0))throw new TypeError(`Expected \`interval\` to be a finite number >= 0, got \`${(s=(i=t.interval)===null||i===void 0?void 0:i.toString())!==null&&s!==void 0?s:""}\` (${typeof t.interval})`);At(this,si,t.carryoverConcurrencyCount,"f"),At(this,oi,t.intervalCap===Number.POSITIVE_INFINITY||t.interval===0,"f"),At(this,ws,t.intervalCap,"f"),At(this,ai,t.interval,"f"),At(this,pe,new t.queueClass,"f"),At(this,xs,t.queueClass,"f"),this.concurrency=t.concurrency,this.timeout=t.timeout,At(this,vs,t.throwOnTimeout===!0,"f"),At(this,Ar,t.autoStart===!1,"f")}get concurrency(){return K(this,ci,"f")}set concurrency(t){if(!(typeof t=="number"&&t>=1))throw new TypeError(`Expected \`concurrency\` to be a number from 1 and up, got \`${t}\` (${typeof t})`);At(this,ci,t,"f"),K(this,_t,"m",Ss).call(this)}async add(t,r={}){return r={timeout:this.timeout,throwOnTimeout:K(this,vs,"f"),...r},new Promise((n,i)=>{K(this,pe,"f").enqueue(async()=>{var s,o,a;At(this,ye,(o=K(this,ye,"f"),o++,o),"f"),At(this,Tr,(a=K(this,Tr,"f"),a++,a),"f");try{if(!((s=r.signal)===null||s===void 0)&&s.aborted)throw new As("The task was aborted.");let c=t({signal:r.signal});r.timeout&&(c=$a(Promise.resolve(c),r.timeout)),r.signal&&(c=Promise.race([c,K(this,_t,"m",Tl).call(this,r.signal)]));let u=await c;n(u),this.emit("completed",u)}catch(c){if(c instanceof ni&&!r.throwOnTimeout){n();return}i(c),this.emit("error",c)}finally{K(this,_t,"m",Al).call(this)}},r),this.emit("add"),K(this,_t,"m",bs).call(this)})}async addAll(t,r){return Promise.all(t.map(async n=>this.add(n,r)))}start(){return K(this,Ar,"f")?(At(this,Ar,!1,"f"),K(this,_t,"m",Ss).call(this),this):this}pause(){At(this,Ar,!0,"f")}clear(){At(this,pe,new(K(this,xs,"f")),"f")}async onEmpty(){K(this,pe,"f").size!==0&&await K(this,_t,"m",Es).call(this,"empty")}async onSizeLessThan(t){K(this,pe,"f").size<t||await K(this,_t,"m",Es).call(this,"next",()=>K(this,pe,"f").size<t)}async onIdle(){K(this,ye,"f")===0&&K(this,pe,"f").size===0||await K(this,_t,"m",Es).call(this,"idle")}get size(){return K(this,pe,"f").size}sizeBy(t){return K(this,pe,"f").filter(t).length}get pending(){return K(this,ye,"f")}get isPaused(){return K(this,Ar,"f")}};si=new WeakMap,oi=new WeakMap,Tr=new WeakMap,ws=new WeakMap,ai=new WeakMap,gs=new WeakMap,De=new WeakMap,ii=new WeakMap,pe=new WeakMap,xs=new WeakMap,ye=new WeakMap,ci=new WeakMap,Ar=new WeakMap,vs=new WeakMap,_t=new WeakSet,bl=function(){return K(this,oi,"f")||K(this,Tr,"f")<K(this,ws,"f")},El=function(){return K(this,ye,"f")<K(this,ci,"f")},Al=function(){var t;At(this,ye,(t=K(this,ye,"f"),t--,t),"f"),K(this,_t,"m",bs).call(this),this.emit("next")},wl=function(){K(this,_t,"m",Ja).call(this),K(this,_t,"m",Xa).call(this),At(this,ii,void 0,"f")},Sl=function(){let t=Date.now();if(K(this,De,"f")===void 0){let r=K(this,gs,"f")-t;if(r<0)At(this,Tr,K(this,si,"f")?K(this,ye,"f"):0,"f");else return K(this,ii,"f")===void 0&&At(this,ii,setTimeout(()=>{K(this,_t,"m",wl).call(this)},r),"f"),!0}return!1},bs=function(){if(K(this,pe,"f").size===0)return K(this,De,"f")&&clearInterval(K(this,De,"f")),At(this,De,void 0,"f"),this.emit("empty"),K(this,ye,"f")===0&&this.emit("idle"),!1;if(!K(this,Ar,"f")){let t=!K(this,_t,"a",Sl);if(K(this,_t,"a",bl)&&K(this,_t,"a",El)){let r=K(this,pe,"f").dequeue();return r?(this.emit("active"),r(),t&&K(this,_t,"m",Xa).call(this),!0):!1}}return!1},Xa=function(){K(this,oi,"f")||K(this,De,"f")!==void 0||(At(this,De,setInterval(()=>{K(this,_t,"m",Ja).call(this)},K(this,ai,"f")),"f"),At(this,gs,Date.now()+K(this,ai,"f"),"f"))},Ja=function(){K(this,Tr,"f")===0&&K(this,ye,"f")===0&&K(this,De,"f")&&(clearInterval(K(this,De,"f")),At(this,De,void 0,"f")),At(this,Tr,K(this,si,"f")?K(this,ye,"f"):0,"f"),K(this,_t,"m",Ss).call(this)},Ss=function(){for(;K(this,_t,"m",bs).call(this););},Tl=async function(t){return new Promise((r,n)=>{t.addEventListener("abort",()=>{n(new As("The task was aborted."))},{once:!0})})},Es=async function(t,r){return new Promise(n=>{let i=()=>{r&&!r()||(this.off(t,i),n())};this.on(t,i)})};var Bl=ja;function f1(e,t,r){let n=0,i=e.length;for(;i>0;){let s=Math.trunc(i/2),o=n+s;r(e[o],t)<=0?(n=++o,i-=s+1):i=s}return n}var t0=class{#t=[];enqueue(t,r){let n=r?.peerId,i=r?.priority??0;if(n==null)throw new H("missing peer id",E0);let s={priority:i,peerId:n,run:t};if(this.size>0&&this.#t[this.size-1].priority>=i){this.#t.push(s);return}let o=f1(this.#t,s,(a,c)=>c.priority-a.priority);this.#t.splice(o,0,s)}dequeue(){return this.#t.shift()?.run}filter(t){if(t.peerId!=null){let r=t.peerId;return this.#t.filter(n=>r.equals(n.peerId)).map(n=>n.run)}return this.#t.filter(r=>r.priority===t.priority).map(r=>r.run)}get size(){return this.#t.length}},Ts=class extends Bl{constructor(t={}){super({...t,queueClass:t0})}hasJob(t){return this.sizeBy({peerId:t})>0}};var h1=60*1e3*10,d1=60*1e3*5,p1=30*1e3,Bs=class extends me{peerId;connectionManager;transportManager;peerStore;events;reserveQueue;reservations;maxDiscoveredRelays;maxReservationQueueLength;reservationCompletionTimeout;started;log;constructor(t,r){super(),this.log=t.logger.forComponent("libp2p:circuit-relay:transport:reservation-store"),this.peerId=t.peerId,this.connectionManager=t.connectionManager,this.transportManager=t.transportManager,this.peerStore=t.peerStore,this.events=t.events,this.reservations=new ir,this.maxDiscoveredRelays=r?.discoverRelays??0,this.maxReservationQueueLength=r?.maxReservationQueueLength??100,this.reservationCompletionTimeout=r?.reservationCompletionTimeout??1e4,this.started=!1,this.reserveQueue=new Ts({concurrency:r?.reservationConcurrency??1}),this.events.addEventListener("peer:disconnect",n=>{this.#e(n.detail)})}isStarted(){return this.started}async start(){this.started=!0}async stop(){this.reserveQueue.clear(),this.reservations.forEach(({timeout:t})=>{clearTimeout(t)}),this.reservations.clear(),this.started=!1}async addRelay(t,r){if(this.peerId.equals(t)){this.log("not trying to use self as relay");return}if(this.reserveQueue.size>this.maxReservationQueueLength){this.log("not adding relay as the queue is full");return}if(this.reserveQueue.hasJob(t)){this.log("relay peer is already in the reservation queue");return}this.log("add relay %p",t),await this.reserveQueue.add(async()=>{try{let n=this.reservations.get(t);if(n!=null){if(Oa(n.reservation.expire)>h1){this.log("already have reservation on relay peer %p and it expires in more than 10 minutes",t);return}clearTimeout(n.timeout),this.reservations.delete(t)}if(r==="discovered"&&[...this.reservations.values()].reduce((f,l)=>(l.type==="discovered"&&f++,f),0)>=this.maxDiscoveredRelays){this.log("already have enough discovered relays");return}let i=AbortSignal.timeout(this.reservationCompletionTimeout),s=await this.connectionManager.openConnection(t,{signal:i});if(s.remoteAddr.protoNames().includes("p2p-circuit")){this.log("not creating reservation over relayed connection");return}let o=await this.#t(s,{signal:i});this.log("created reservation on relay peer %p",t);let a=Oa(o.expire),c=Math.min(Math.max(a-d1,p1),Math.pow(2,31)-1),u=setTimeout(()=>{this.addRelay(t,r).catch(f=>{this.log.error("could not refresh reservation to relay %p",t,f)})},c);this.reservations.set(t,{timeout:u,reservation:o,type:r}),await this.peerStore.merge(t,{tags:{[Xf]:{value:1,ttl:a}}}),await this.transportManager.listen([ee(`/p2p/${t.toString()}/p2p-circuit`)])}catch(n){this.log.error("could not reserve slot on %p",t,n);let i=this.reservations.get(t);i!=null&&clearTimeout(i.timeout),this.reservations.delete(t)}},{peerId:t})}hasReservation(t){return this.reservations.has(t)}getReservation(t){return this.reservations.get(t)?.reservation}async#t(t,r){r.signal?.throwIfAborted(),this.log("requesting reservation from %p",t.remotePeer);let n=await t.newStream(we,r),s=Sr(n).pb(ft);await s.write({type:ft.Type.RESERVE},r);let o;try{o=await s.read(r)}catch(c){throw this.log.error("error parsing reserve message response from %p because",t.remotePeer,c),n.abort(c),c}finally{await n.close()}if(o.status===tt.OK&&o.reservation!=null){let c=!1,u=t.remoteAddr.bytes;for(let f of o.reservation.addrs)if(Ct(u,f)){c=!0;break}return c||o.reservation.addrs.push(u),o.reservation}let a=`reservation failed with status ${o.status??"undefined"}`;throw this.log.error(a),new Error(a)}#e(t){let r=this.reservations.get(t);r!=null&&(this.log("connection to relay %p closed, removing reservation from local store",t),clearTimeout(r.timeout),this.reservations.delete(t),this.safeDispatchEvent("relay:removed",{detail:t}),this.reservations.size<this.maxDiscoveredRelays&&(this.log("not enough relays %d/%d",this.reservations.size,this.maxDiscoveredRelays),this.safeDispatchEvent("relay:not-enough-relays",{})))}};function e0(e){let{stream:t,remoteAddr:r,logger:n}=e,i=n.forComponent("libp2p:stream:converter"),s=!1,o=!1,a=t.close.bind(t);t.close=async h=>{await a(h),l(!0)};let c=t.abort.bind(t);t.abort=h=>{c(h),l(!0)};let u=t.sink.bind(t);t.sink=async h=>{try{await u(h)}catch(y){y.type!=="aborted"&&i(y)}finally{o=!0,l()}};let f={log:i,sink:t.sink,source:async function*(){try{for await(let h of t.source)h instanceof Uint8Array?yield h:yield*h}finally{s=!0,l()}}(),remoteAddr:r,timeline:{open:Date.now(),close:void 0},close:t.close,abort:t.abort};function l(h){h===!0&&(s=!0,o=!0),s&&o&&f.timeline.close==null&&(f.timeline.close=Date.now())}return f}var y1=U("dns4"),m1=U("dns6"),g1=U("dnsaddr"),Zr=Rt(U("dns"),g1,y1,m1),_s=Rt(U("ip4"),U("ip6")),In=Rt(z(_s,U("tcp")),z(Zr,U("tcp"))),Rs=z(_s,U("udp")),x1=z(Rs,U("utp")),v1=z(Rs,U("quic")),b1=z(Rs,U("quic-v1")),r0=Rt(z(In,U("ws")),z(Zr,U("ws"))),Is=Rt(z(r0,U("p2p")),r0),n0=Rt(z(In,U("wss")),z(Zr,U("wss")),z(In,U("tls"),U("ws")),z(Zr,U("tls"),U("ws"))),Cs=Rt(z(n0,U("p2p")),n0),i0=Rt(z(In,U("http")),z(_s,U("http")),z(Zr,U("http"))),s0=Rt(z(In,U("https")),z(_s,U("https")),z(Zr,U("https"))),Il=z(Rs,U("webrtc-direct"),U("certhash")),Rl=Rt(z(Il,U("p2p")),Il),Cl=z(b1,U("webtransport"),U("certhash"),U("certhash")),Ll=Rt(z(Cl,U("p2p")),Cl),Dl=Rt(z(Is,U("p2p-webrtc-star"),U("p2p")),z(Cs,U("p2p-webrtc-star"),U("p2p")),z(Is,U("p2p-webrtc-star")),z(Cs,U("p2p-webrtc-star"))),s3=Rt(z(Is,U("p2p-websocket-star"),U("p2p")),z(Cs,U("p2p-websocket-star"),U("p2p")),z(Is,U("p2p-websocket-star")),z(Cs,U("p2p-websocket-star"))),Nl=Rt(z(i0,U("p2p-webrtc-direct"),U("p2p")),z(s0,U("p2p-webrtc-direct"),U("p2p")),z(i0,U("p2p-webrtc-direct")),z(s0,U("p2p-webrtc-direct"))),Xr=Rt(r0,n0,i0,s0,Dl,Nl,In,x1,v1,Zr,Rl,Ll),o3=Rt(z(Xr,U("p2p-stardust"),U("p2p")),z(Xr,U("p2p-stardust"))),Br=Rt(z(Xr,U("p2p")),Dl,Nl,Rl,Ll,U("p2p")),_l=Rt(z(Br,U("p2p-circuit"),Br),z(Br,U("p2p-circuit")),z(U("p2p-circuit"),Br),z(Xr,U("p2p-circuit")),z(U("p2p-circuit"),Xr),U("p2p-circuit")),Pl=()=>Rt(z(_l,Pl),_l),or=Pl(),a3=Rt(z(or,Br,or),z(Br,or),z(or,Br),or,Br);var c3=Rt(z(or,U("webrtc"),U("p2p")),z(or,U("webrtc")),z(Xr,U("webrtc"),U("p2p")),z(Xr,U("webrtc")),U("webrtc"));function kl(e){function t(r){let n;try{n=ee(r)}catch{return!1}let i=e(n.protoNames());return i===null?!1:i===!0||i===!1?i:i.length===0}return t}function z(...e){function t(r){if(r.length<e.length)return null;let n=r;return e.some(i=>(n=typeof i=="function"?i().partialMatch(r):i.partialMatch(r),Array.isArray(n)&&(r=n),n===null)),n}return{toString:function(){return"{ "+e.join(" ")+" }"},input:e,matches:kl(t),partialMatch:t}}function Rt(...e){function t(n){let i=null;return e.some(s=>{let o=typeof s=="function"?s().partialMatch(n):s.partialMatch(n);return o!=null?(i=o,!0):!1}),i}return{toString:function(){return"{ "+e.join(" ")+" }"},input:e,matches:kl(t),partialMatch:t}}function U(e){let t=e;function r(i){let s;try{s=ee(i)}catch{return!1}let o=s.protoNames();return o.length===1&&o[0]===t}function n(i){return i.length===0?null:i[0]===t?i.slice(1):null}return{toString:function(){return t},matches:r,partialMatch:n}}var o0=class extends me{connectionManager;relayStore;listeningAddrs;log;constructor(t){super(),this.log=t.logger.forComponent("libp2p:circuit-relay:transport:listener"),this.connectionManager=t.connectionManager,this.relayStore=t.relayStore,this.listeningAddrs=new ir,this.relayStore.addEventListener("relay:removed",this._onRemoveRelayPeer)}_onRemoveRelayPeer=t=>{this.#t(t.detail)};async listen(t){this.log("listen on %a",t);let r=t.decapsulate("/p2p-circuit"),n=await this.connectionManager.openConnection(r);if(!this.relayStore.hasReservation(n.remotePeer)){this.log("making reservation on peer %p",n.remotePeer),await this.relayStore.addRelay(n.remotePeer,"configured");return}let i=this.relayStore.getReservation(n.remotePeer);if(i==null)throw new H("Did not have reservation after making reservation","ERR_NO_RESERVATION");if(this.listeningAddrs.has(n.remotePeer)){this.log("already listening on relay %p",n.remotePeer);return}this.listeningAddrs.set(n.remotePeer,i.addrs.map(s=>ee(s).encapsulate("/p2p-circuit"))),this.safeDispatchEvent("listening",{})}getAddrs(){return[...this.listeningAddrs.values()].flat()}async close(){}#t(t){let r=this.listeningAddrs.has(t);this.log("relay peer removed %p - had reservation",t,r),this.listeningAddrs.delete(t),r&&(this.log.trace("removing relay event listener for peer %p",t),this.relayStore.removeEventListener("relay:removed",this._onRemoveRelayPeer),this.safeDispatchEvent("close",{}))}};function Ul(e){return new o0(e)}var w1=e=>{if(e.peer==null)return!1;try{e.peer.addrs.forEach(ee)}catch{return!1}return!0},a0={maxInboundStopStreams:ei,maxOutboundStopStreams:ei,stopTimeout:3e4},Ls=class{discovery;registrar;peerStore;connectionManager;transportManager;peerId;upgrader;addressManager;connectionGater;reservationStore;logger;maxInboundStopStreams;maxOutboundStopStreams;stopTimeout;started;log;constructor(t,r){this.log=t.logger.forComponent("libp2p:circuit-relay:transport"),this.registrar=t.registrar,this.peerStore=t.peerStore,this.connectionManager=t.connectionManager,this.transportManager=t.transportManager,this.logger=t.logger,this.peerId=t.peerId,this.upgrader=t.upgrader,this.addressManager=t.addressManager,this.connectionGater=t.connectionGater,this.maxInboundStopStreams=r.maxInboundStopStreams??a0.maxInboundStopStreams,this.maxOutboundStopStreams=r.maxOutboundStopStreams??a0.maxOutboundStopStreams,this.stopTimeout=r.stopTimeout??a0.stopTimeout,r.discoverRelays!=null&&r.discoverRelays>0&&(this.discovery=new ys(t),this.discovery.addEventListener("relay:discover",n=>{this.reservationStore.addRelay(n.detail,"discovered").catch(i=>{this.log.error("could not add discovered relay %p",n.detail,i)})})),this.reservationStore=new Bs(t,r),this.reservationStore.addEventListener("relay:not-enough-relays",()=>{this.discovery?.discover().catch(n=>{this.log.error("could not discover relays",n)})}),this.started=!1}isStarted(){return this.started}async start(){await this.reservationStore.start(),await this.discovery?.start(),await this.registrar.handle(Yr,t=>{this.onStop(t).catch(r=>{this.log.error("error while handling STOP protocol",r),t.stream.abort(r)})},{maxInboundStreams:this.maxInboundStopStreams,maxOutboundStreams:this.maxOutboundStopStreams,runOnTransientConnection:!0}),this.started=!0}async stop(){this.discovery?.stop(),await this.reservationStore.stop(),await this.registrar.unhandle(Yr),this.started=!1}[b0]=!0;[Symbol.toStringTag]="libp2p/circuit-relay-v2";async dial(t,r={}){if(t.protoCodes().filter(d=>d===290).length!==1){let d="Invalid circuit relay address";throw this.log.error(d,t),new H(d,ka)}let n=t.toString().split("/p2p-circuit"),i=ee(n[0]),s=ee(n[n.length-1]),o=i.getPeerId(),a=s.getPeerId();if(o==null||a==null){let d=`Circuit relay dial to ${t.toString()} failed as address did not have peer ids`;throw this.log.error(d),new H(d,ka)}let c=St(o),u=St(a),f=!1,h=this.connectionManager.getConnections(c)[0];h==null&&(await this.peerStore.merge(c,{multiaddrs:[i]}),h=await this.connectionManager.openConnection(c,r),f=!0);let y;try{return y=await h.newStream(we),await this.connectV2({stream:y,connection:h,destinationPeer:u,destinationAddr:s,relayAddr:i,ma:t,disconnectOnFailure:f})}catch(d){throw this.log.error("circuit relay dial to destination %p via relay %p failed",u,c,d),y?.abort(d),f&&await h.close(),d}}async connectV2({stream:t,connection:r,destinationPeer:n,destinationAddr:i,relayAddr:s,ma:o,disconnectOnFailure:a}){try{let c=Sr(t),u=c.pb(ft);await u.write({type:ft.Type.CONNECT,peer:{id:n.toBytes(),addrs:[ee(i).bytes]}});let f=await u.read();if(f.status!==tt.OK)throw new H(`failed to connect via relay with status ${f?.status?.toString()??"undefined"}`,rl);let l=e0({stream:c.unwrap(),remoteAddr:o,localAddr:s.encapsulate(`/p2p-circuit/p2p/${this.peerId.toString()}`),logger:this.logger});return this.log("new outbound transient connection %a",l.remoteAddr),await this.upgrader.upgradeOutbound(l,{transient:!0})}catch(c){throw this.log.error(`Circuit relay dial to destination ${n.toString()} via relay ${r.remotePeer.toString()} failed`,c),a&&await r.close(),c}}createListener(t){return Ul({connectionManager:this.connectionManager,relayStore:this.reservationStore,logger:this.logger})}filter(t){return t=Array.isArray(t)?t:[t],t.filter(r=>or.matches(r))}async onStop({connection:t,stream:r}){if(!this.reservationStore.hasReservation(t.remotePeer))try{this.log("dialed via relay we did not have a reservation on, start listening on that relay address"),await this.transportManager.listen([t.remoteAddr.encapsulate("/p2p-circuit")])}catch(f){this.log.error("failed to listen on a relay peer we were dialed via but did not have a reservation on",f)}let n=AbortSignal.timeout(this.stopTimeout),i=Sr(r).pb(de),s=await i.read({signal:n});if(this.log("new circuit relay v2 stop stream from %p with type %s",t.remotePeer,s.type),s?.type===void 0){this.log.error("type was missing from circuit v2 stop protocol request from %s",t.remotePeer),await i.write({type:de.Type.STATUS,status:tt.MALFORMED_MESSAGE},{signal:n}),await r.close();return}if(s.type!==de.Type.CONNECT){this.log.error("invalid stop connect request via peer %p",t.remotePeer),await i.write({type:de.Type.STATUS,status:tt.UNEXPECTED_MESSAGE},{signal:n}),await r.close();return}if(!w1(s)){this.log.error("invalid stop connect request via peer %p",t.remotePeer),await i.write({type:de.Type.STATUS,status:tt.MALFORMED_MESSAGE},{signal:n}),await r.close();return}let o=on(s.peer.id);if(await this.connectionGater.denyInboundRelayedConnection?.(t.remotePeer,o)===!0){this.log.error("connection gater denied inbound relayed connection from %p",t.remotePeer),await i.write({type:de.Type.STATUS,status:tt.PERMISSION_DENIED},{signal:n}),await r.close();return}this.log.trace("sending success response to %p",t.remotePeer),await i.write({type:de.Type.STATUS,status:tt.OK},{signal:n});let a=t.remoteAddr.encapsulate(`/p2p-circuit/p2p/${o.toString()}`),c=this.addressManager.getAddresses()[0],u=e0({stream:i.unwrap().unwrap(),remoteAddr:a,localAddr:c,logger:this.logger});this.log("new inbound transient connection %a",u.remoteAddr),await this.upgrader.upgradeInbound(u,{transient:!0}),this.log("%s connection %a upgraded","inbound",u.remoteAddr)}};function Ol(e={}){return t=>new Ls(t,e)}return Xl(S1);})();
16
16
  /*! Bundled license information:
17
17
 
18
18
  @noble/hashes/esm/utils.js: