@libp2p/webtransport 4.0.28-90cfd25e2 → 4.0.28-c82432312

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
@@ -1,10 +1,10 @@
1
1
  (function (root, factory) {(typeof module === 'object' && module.exports) ? module.exports = factory() : root.Libp2PWebtransport = factory()}(typeof self !== 'undefined' ? self : this, function () {
2
- "use strict";var Libp2PWebtransport=(()=>{var bf=Object.create;var Bn=Object.defineProperty;var xf=Object.getOwnPropertyDescriptor;var Ef=Object.getOwnPropertyNames;var vf=Object.getPrototypeOf,Bf=Object.prototype.hasOwnProperty;var Pa=(r,t)=>()=>(t||r((t={exports:{}}).exports,t),t.exports),yt=(r,t)=>{for(var e in t)Bn(r,e,{get:t[e],enumerable:!0})},Da=(r,t,e,n)=>{if(t&&typeof t=="object"||typeof t=="function")for(let s of Ef(t))!Bf.call(r,s)&&s!==e&&Bn(r,s,{get:()=>t[s],enumerable:!(n=xf(t,s))||n.enumerable});return r};var Va=(r,t,e)=>(e=r!=null?bf(vf(r)):{},Da(t||!r||!r.__esModule?Bn(e,"default",{value:r,enumerable:!0}):e,r)),Af=r=>Da(Bn({},"__esModule",{value:!0}),r);var qc=Pa(Ar=>{"use strict";var Qd="[object ArrayBuffer]",xe=class r{static isArrayBuffer(t){return Object.prototype.toString.call(t)===Qd}static toArrayBuffer(t){return this.isArrayBuffer(t)?t:t.byteLength===t.buffer.byteLength||t.byteOffset===0&&t.byteLength===t.buffer.byteLength?t.buffer:this.toUint8Array(t.buffer).slice(t.byteOffset,t.byteOffset+t.byteLength).buffer}static toUint8Array(t){return this.toView(t,Uint8Array)}static toView(t,e){if(t.constructor===e)return t;if(this.isArrayBuffer(t))return new e(t);if(this.isArrayBufferView(t))return new e(t.buffer,t.byteOffset,t.byteLength);throw new TypeError("The provided value is not of type '(ArrayBuffer or ArrayBufferView)'")}static isBufferSource(t){return this.isArrayBufferView(t)||this.isArrayBuffer(t)}static isArrayBufferView(t){return ArrayBuffer.isView(t)||t&&this.isArrayBuffer(t.buffer)}static isEqual(t,e){let n=r.toUint8Array(t),s=r.toUint8Array(e);if(n.length!==s.byteLength)return!1;for(let o=0;o<n.length;o++)if(n[o]!==s[o])return!1;return!0}static concat(...t){let e;Array.isArray(t[0])&&!(t[1]instanceof Function)||Array.isArray(t[0])&&t[1]instanceof Function?e=t[0]:t[t.length-1]instanceof Function?e=t.slice(0,t.length-1):e=t;let n=0;for(let i of e)n+=i.byteLength;let s=new Uint8Array(n),o=0;for(let i of e){let a=this.toUint8Array(i);s.set(a,o),o+=a.length}return t[t.length-1]instanceof Function?this.toView(s,t[t.length-1]):s.buffer}},yi="string",t0=/^[0-9a-f]+$/i,e0=/^(?:[A-Za-z0-9+/]{4})*(?:[A-Za-z0-9+/]{2}==|[A-Za-z0-9+/]{3}=)?$/,r0=/^[a-zA-Z0-9-_]+$/,$n=class{static fromString(t){let e=unescape(encodeURIComponent(t)),n=new Uint8Array(e.length);for(let s=0;s<e.length;s++)n[s]=e.charCodeAt(s);return n.buffer}static toString(t){let e=xe.toUint8Array(t),n="";for(let o=0;o<e.length;o++)n+=String.fromCharCode(e[o]);return decodeURIComponent(escape(n))}},Kt=class{static toString(t,e=!1){let n=xe.toArrayBuffer(t),s=new DataView(n),o="";for(let i=0;i<n.byteLength;i+=2){let a=s.getUint16(i,e);o+=String.fromCharCode(a)}return o}static fromString(t,e=!1){let n=new ArrayBuffer(t.length*2),s=new DataView(n);for(let o=0;o<t.length;o++)s.setUint16(o*2,t.charCodeAt(o),e);return n}},qn=class r{static isHex(t){return typeof t===yi&&t0.test(t)}static isBase64(t){return typeof t===yi&&e0.test(t)}static isBase64Url(t){return typeof t===yi&&r0.test(t)}static ToString(t,e="utf8"){let n=xe.toUint8Array(t);switch(e.toLowerCase()){case"utf8":return this.ToUtf8String(n);case"binary":return this.ToBinary(n);case"hex":return this.ToHex(n);case"base64":return this.ToBase64(n);case"base64url":return this.ToBase64Url(n);case"utf16le":return Kt.toString(n,!0);case"utf16":case"utf16be":return Kt.toString(n);default:throw new Error(`Unknown type of encoding '${e}'`)}}static FromString(t,e="utf8"){if(!t)return new ArrayBuffer(0);switch(e.toLowerCase()){case"utf8":return this.FromUtf8String(t);case"binary":return this.FromBinary(t);case"hex":return this.FromHex(t);case"base64":return this.FromBase64(t);case"base64url":return this.FromBase64Url(t);case"utf16le":return Kt.fromString(t,!0);case"utf16":case"utf16be":return Kt.fromString(t);default:throw new Error(`Unknown type of encoding '${e}'`)}}static ToBase64(t){let e=xe.toUint8Array(t);if(typeof btoa<"u"){let n=this.ToString(e,"binary");return btoa(n)}else return Buffer.from(e).toString("base64")}static FromBase64(t){let e=this.formatString(t);if(!e)return new ArrayBuffer(0);if(!r.isBase64(e))throw new TypeError("Argument 'base64Text' is not Base64 encoded");return typeof atob<"u"?this.FromBinary(atob(e)):new Uint8Array(Buffer.from(e,"base64")).buffer}static FromBase64Url(t){let e=this.formatString(t);if(!e)return new ArrayBuffer(0);if(!r.isBase64Url(e))throw new TypeError("Argument 'base64url' is not Base64Url encoded");return this.FromBase64(this.Base64Padding(e.replace(/\-/g,"+").replace(/\_/g,"/")))}static ToBase64Url(t){return this.ToBase64(t).replace(/\+/g,"-").replace(/\//g,"_").replace(/\=/g,"")}static FromUtf8String(t,e=r.DEFAULT_UTF8_ENCODING){switch(e){case"ascii":return this.FromBinary(t);case"utf8":return $n.fromString(t);case"utf16":case"utf16be":return Kt.fromString(t);case"utf16le":case"usc2":return Kt.fromString(t,!0);default:throw new Error(`Unknown type of encoding '${e}'`)}}static ToUtf8String(t,e=r.DEFAULT_UTF8_ENCODING){switch(e){case"ascii":return this.ToBinary(t);case"utf8":return $n.toString(t);case"utf16":case"utf16be":return Kt.toString(t);case"utf16le":case"usc2":return Kt.toString(t,!0);default:throw new Error(`Unknown type of encoding '${e}'`)}}static FromBinary(t){let e=t.length,n=new Uint8Array(e);for(let s=0;s<e;s++)n[s]=t.charCodeAt(s);return n.buffer}static ToBinary(t){let e=xe.toUint8Array(t),n="";for(let s=0;s<e.length;s++)n+=String.fromCharCode(e[s]);return n}static ToHex(t){let e=xe.toUint8Array(t),n="",s=e.length;for(let o=0;o<s;o++){let i=e[o];i<16&&(n+="0"),n+=i.toString(16)}return n}static FromHex(t){let e=this.formatString(t);if(!e)return new ArrayBuffer(0);if(!r.isHex(e))throw new TypeError("Argument 'hexString' is not HEX encoded");e.length%2&&(e=`0${e}`);let n=new Uint8Array(e.length/2);for(let s=0;s<e.length;s=s+2){let o=e.slice(s,s+2);n[s/2]=parseInt(o,16)}return n.buffer}static ToUtf16String(t,e=!1){return Kt.toString(t,e)}static FromUtf16String(t,e=!1){return Kt.fromString(t,e)}static Base64Padding(t){let e=4-t.length%4;if(e<4)for(let n=0;n<e;n++)t+="=";return t}static formatString(t){return t?.replace(/[\n\r\t ]/g,"")||""}};qn.DEFAULT_UTF8_ENCODING="utf8";function n0(r,...t){let e=arguments[0];for(let n=1;n<arguments.length;n++){let s=arguments[n];for(let o in s)e[o]=s[o]}return e}function s0(...r){let t=r.map(s=>s.byteLength).reduce((s,o)=>s+o),e=new Uint8Array(t),n=0;return r.map(s=>new Uint8Array(s)).forEach(s=>{for(let o of s)e[n++]=o}),e.buffer}function o0(r,t){if(!(r&&t)||r.byteLength!==t.byteLength)return!1;let e=new Uint8Array(r),n=new Uint8Array(t);for(let s=0;s<r.byteLength;s++)if(e[s]!==n[s])return!1;return!0}Ar.BufferSourceConverter=xe;Ar.Convert=qn;Ar.assign=n0;Ar.combine=s0;Ar.isEqual=o0});var nu=Pa((ob,ru)=>{"use strict";function eu(r,t){for(let e in t)Object.defineProperty(r,e,{value:t[e],enumerable:!0,configurable:!0});return r}function K0(r,t,e){if(!r||typeof r=="string")throw new TypeError("Please pass an Error to err-code");e||(e={}),typeof t=="object"&&(e=t,t=""),t&&(e.code=t);try{return eu(r,e)}catch{e.message=r.message,e.stack=r.stack;let s=function(){};return s.prototype=Object.create(Object.getPrototypeOf(r)),eu(new s,e)}}ru.exports=K0});var qp={};yt(qp,{webTransport:()=>$p});var Oa=Symbol.for("@libp2p/peer-id");var Ma=Symbol.for("@libp2p/transport");var Ha;(function(r){r[r.FATAL_ALL=0]="FATAL_ALL",r[r.NO_FATAL=1]="NO_FATAL"})(Ha||(Ha={}));var F=class extends Error{code;props;constructor(t,e,n){super(t),this.code=e,this.name=n?.name??"CodeError",this.props=n??{}}};var pi={};yt(pi,{Ed25519PrivateKey:()=>er,Ed25519PublicKey:()=>tn,generateKeyPair:()=>Zd,generateKeyPairFromSeed:()=>$c,unmarshalEd25519PrivateKey:()=>Wd,unmarshalEd25519PublicKey:()=>Yd});var ho={};yt(ho,{base58btc:()=>ut,base58flickr:()=>Tf});var Yp=new Uint8Array(0);function Ka(r,t){if(r===t)return!0;if(r.byteLength!==t.byteLength)return!1;for(let e=0;e<r.byteLength;e++)if(r[e]!==t[e])return!1;return!0}function fe(r){if(r instanceof Uint8Array&&r.constructor.name==="Uint8Array")return r;if(r instanceof ArrayBuffer)return new Uint8Array(r);if(ArrayBuffer.isView(r))return new Uint8Array(r.buffer,r.byteOffset,r.byteLength);throw new Error("Unknown type, must be binary type")}function Fa(r){return new TextEncoder().encode(r)}function $a(r){return new TextDecoder().decode(r)}function Sf(r,t){if(r.length>=255)throw new TypeError("Alphabet too long");for(var e=new Uint8Array(256),n=0;n<e.length;n++)e[n]=255;for(var s=0;s<r.length;s++){var o=r.charAt(s),i=o.charCodeAt(0);if(e[i]!==255)throw new TypeError(o+" is ambiguous");e[i]=s}var a=r.length,c=r.charAt(0),l=Math.log(a)/Math.log(256),u=Math.log(256)/Math.log(a);function f(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 h=0,p=0,b=0,v=d.length;b!==v&&d[b]===0;)b++,h++;for(var w=(v-b)*u+1>>>0,A=new Uint8Array(w);b!==v;){for(var B=d[b],S=0,N=w-1;(B!==0||S<p)&&N!==-1;N--,S++)B+=256*A[N]>>>0,A[N]=B%a>>>0,B=B/a>>>0;if(B!==0)throw new Error("Non-zero carry");p=S,b++}for(var _=w-p;_!==w&&A[_]===0;)_++;for(var V=c.repeat(h);_<w;++_)V+=r.charAt(A[_]);return V}function g(d){if(typeof d!="string")throw new TypeError("Expected String");if(d.length===0)return new Uint8Array;var h=0;if(d[h]!==" "){for(var p=0,b=0;d[h]===c;)p++,h++;for(var v=(d.length-h)*l+1>>>0,w=new Uint8Array(v);d[h];){var A=e[d.charCodeAt(h)];if(A===255)return;for(var B=0,S=v-1;(A!==0||B<b)&&S!==-1;S--,B++)A+=a*w[S]>>>0,w[S]=A%256>>>0,A=A/256>>>0;if(A!==0)throw new Error("Non-zero carry");b=B,h++}if(d[h]!==" "){for(var N=v-b;N!==v&&w[N]===0;)N++;for(var _=new Uint8Array(p+(v-N)),V=p;N!==v;)_[V++]=w[N++];return _}}}function m(d){var h=g(d);if(h)return h;throw new Error(`Non-${t} character`)}return{encode:f,decodeUnsafe:g,decode:m}}var kf=Sf,If=kf,Ga=If;var co=class{name;prefix;baseEncode;constructor(t,e,n){this.name=t,this.prefix=e,this.baseEncode=n}encode(t){if(t instanceof Uint8Array)return`${this.prefix}${this.baseEncode(t)}`;throw Error("Unknown type, must be binary type")}},lo=class{name;prefix;baseDecode;prefixCodePoint;constructor(t,e,n){if(this.name=t,this.prefix=e,e.codePointAt(0)===void 0)throw new Error("Invalid prefix character");this.prefixCodePoint=e.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 ja(this,t)}},uo=class{decoders;constructor(t){this.decoders=t}or(t){return ja(this,t)}decode(t){let e=t[0],n=this.decoders[e];if(n!=null)return n.decode(t);throw RangeError(`Unable to decode multibase string ${JSON.stringify(t)}, only inputs prefixed with ${Object.keys(this.decoders)} are supported`)}};function ja(r,t){return new uo({...r.decoders??{[r.prefix]:r},...t.decoders??{[t.prefix]:t}})}var fo=class{name;prefix;baseEncode;baseDecode;encoder;decoder;constructor(t,e,n,s){this.name=t,this.prefix=e,this.baseEncode=n,this.baseDecode=s,this.encoder=new co(t,e,n),this.decoder=new lo(t,e,s)}encode(t){return this.encoder.encode(t)}decode(t){return this.decoder.decode(t)}};function lr({name:r,prefix:t,encode:e,decode:n}){return new fo(r,t,e,n)}function _e({name:r,prefix:t,alphabet:e}){let{encode:n,decode:s}=Ga(e,r);return lr({prefix:t,name:r,encode:n,decode:o=>fe(s(o))})}function _f(r,t,e,n){let s={};for(let u=0;u<t.length;++u)s[t[u]]=u;let o=r.length;for(;r[o-1]==="=";)--o;let i=new Uint8Array(o*e/8|0),a=0,c=0,l=0;for(let u=0;u<o;++u){let f=s[r[u]];if(f===void 0)throw new SyntaxError(`Non-${n} character`);c=c<<e|f,a+=e,a>=8&&(a-=8,i[l++]=255&c>>a)}if(a>=e||255&c<<8-a)throw new SyntaxError("Unexpected end of data");return i}function Nf(r,t,e){let n=t[t.length-1]==="=",s=(1<<e)-1,o="",i=0,a=0;for(let c=0;c<r.length;++c)for(a=a<<8|r[c],i+=8;i>e;)i-=e,o+=t[s&a>>i];if(i!==0&&(o+=t[s&a<<e-i]),n)for(;o.length*e&7;)o+="=";return o}function ct({name:r,prefix:t,bitsPerChar:e,alphabet:n}){return lr({prefix:t,name:r,encode(s){return Nf(s,n,e)},decode(s){return _f(s,n,e,r)}})}var ut=_e({name:"base58btc",prefix:"z",alphabet:"123456789ABCDEFGHJKLMNPQRSTUVWXYZabcdefghijkmnopqrstuvwxyz"}),Tf=_e({name:"base58flickr",prefix:"Z",alphabet:"123456789abcdefghijkmnopqrstuvwxyzABCDEFGHJKLMNPQRSTUVWXYZ"});var yo={};yt(yo,{identity:()=>Te});var ee={};yt(ee,{Digest:()=>Ge,create:()=>$t,decode:()=>Ne,equals:()=>go});var Rf=Ya,za=128,Lf=127,Cf=~Lf,Uf=Math.pow(2,31);function Ya(r,t,e){t=t||[],e=e||0;for(var n=e;r>=Uf;)t[e++]=r&255|za,r/=128;for(;r&Cf;)t[e++]=r&255|za,r>>>=7;return t[e]=r|0,Ya.bytes=e-n+1,t}var Pf=po,Df=128,Wa=127;function po(r,n){var e=0,n=n||0,s=0,o=n,i,a=r.length;do{if(o>=a)throw po.bytes=0,new RangeError("Could not decode varint");i=r[o++],e+=s<28?(i&Wa)<<s:(i&Wa)*Math.pow(2,s),s+=7}while(i>=Df);return po.bytes=o-n,e}var Vf=Math.pow(2,7),Of=Math.pow(2,14),Hf=Math.pow(2,21),Mf=Math.pow(2,28),Kf=Math.pow(2,35),Ff=Math.pow(2,42),$f=Math.pow(2,49),qf=Math.pow(2,56),Gf=Math.pow(2,63),jf=function(r){return r<Vf?1:r<Of?2:r<Hf?3:r<Mf?4:r<Kf?5:r<Ff?6:r<$f?7:r<qf?8:r<Gf?9:10},zf={encode:Rf,decode:Pf,encodingLength:jf},Wf=zf,$r=Wf;function qr(r,t=0){return[$r.decode(r,t),$r.decode.bytes]}function ur(r,t,e=0){return $r.encode(r,t,e),t}function fr(r){return $r.encodingLength(r)}function $t(r,t){let e=t.byteLength,n=fr(r),s=n+fr(e),o=new Uint8Array(s+e);return ur(r,o,0),ur(e,o,n),o.set(t,s),new Ge(r,e,t,o)}function Ne(r){let t=fe(r),[e,n]=qr(t),[s,o]=qr(t.subarray(n)),i=t.subarray(n+o);if(i.byteLength!==s)throw new Error("Incorrect length");return new Ge(e,s,i,t)}function go(r,t){if(r===t)return!0;{let e=t;return r.code===e.code&&r.size===e.size&&e.bytes instanceof Uint8Array&&Ka(r.bytes,e.bytes)}}var Ge=class{code;size;digest;bytes;constructor(t,e,n,s){this.code=t,this.size=e,this.digest=n,this.bytes=s}};var Za=0,Yf="identity",Xa=fe;function Zf(r){return $t(Za,Xa(r))}var Te={code:Za,name:Yf,encode:Xa,digest:Zf};var bo={};yt(bo,{sha256:()=>At,sha512:()=>Xf});function wo({name:r,code:t,encode:e}){return new mo(r,t,e)}var mo=class{name;code;encode;constructor(t,e,n){this.name=t,this.code=e,this.encode=n}digest(t){if(t instanceof Uint8Array){let e=this.encode(t);return e instanceof Uint8Array?$t(this.code,e):e.then(n=>$t(this.code,n))}else throw Error("Unknown type, must be binary type")}};function Qa(r){return async t=>new Uint8Array(await crypto.subtle.digest(r,t))}var At=wo({name:"sha2-256",code:18,encode:Qa("SHA-256")}),Xf=wo({name:"sha2-512",code:19,encode:Qa("SHA-512")});function ft(r,t){if(r===t)return!0;if(r.byteLength!==t.byteLength)return!1;for(let e=0;e<r.byteLength;e++)if(r[e]!==t[e])return!1;return!0}function mt(r=0){return new Uint8Array(r)}function wt(r=0){return new Uint8Array(r)}function xt(r,t){t==null&&(t=r.reduce((s,o)=>s+o.length,0));let e=wt(t),n=0;for(let s of r)e.set(s,n),n+=s.length;return e}var xo={};yt(xo,{base10:()=>Qf});var Qf=_e({prefix:"9",name:"base10",alphabet:"0123456789"});var Eo={};yt(Eo,{base16:()=>th,base16upper:()=>eh});var th=ct({prefix:"f",name:"base16",alphabet:"0123456789abcdef",bitsPerChar:4}),eh=ct({prefix:"F",name:"base16upper",alphabet:"0123456789ABCDEF",bitsPerChar:4});var vo={};yt(vo,{base2:()=>rh});var rh=ct({prefix:"0",name:"base2",alphabet:"01",bitsPerChar:1});var Bo={};yt(Bo,{base256emoji:()=>ah});var tc=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}"),nh=tc.reduce((r,t,e)=>(r[e]=t,r),[]),sh=tc.reduce((r,t,e)=>(r[t.codePointAt(0)]=e,r),[]);function oh(r){return r.reduce((t,e)=>(t+=nh[e],t),"")}function ih(r){let t=[];for(let e of r){let n=sh[e.codePointAt(0)];if(n===void 0)throw new Error(`Non-base256emoji character: ${e}`);t.push(n)}return new Uint8Array(t)}var ah=lr({prefix:"\u{1F680}",name:"base256emoji",encode:oh,decode:ih});var Ao={};yt(Ao,{base32:()=>he,base32hex:()=>fh,base32hexpad:()=>dh,base32hexpadupper:()=>ph,base32hexupper:()=>hh,base32pad:()=>lh,base32padupper:()=>uh,base32upper:()=>ch,base32z:()=>gh});var he=ct({prefix:"b",name:"base32",alphabet:"abcdefghijklmnopqrstuvwxyz234567",bitsPerChar:5}),ch=ct({prefix:"B",name:"base32upper",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZ234567",bitsPerChar:5}),lh=ct({prefix:"c",name:"base32pad",alphabet:"abcdefghijklmnopqrstuvwxyz234567=",bitsPerChar:5}),uh=ct({prefix:"C",name:"base32padupper",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZ234567=",bitsPerChar:5}),fh=ct({prefix:"v",name:"base32hex",alphabet:"0123456789abcdefghijklmnopqrstuv",bitsPerChar:5}),hh=ct({prefix:"V",name:"base32hexupper",alphabet:"0123456789ABCDEFGHIJKLMNOPQRSTUV",bitsPerChar:5}),dh=ct({prefix:"t",name:"base32hexpad",alphabet:"0123456789abcdefghijklmnopqrstuv=",bitsPerChar:5}),ph=ct({prefix:"T",name:"base32hexpadupper",alphabet:"0123456789ABCDEFGHIJKLMNOPQRSTUV=",bitsPerChar:5}),gh=ct({prefix:"h",name:"base32z",alphabet:"ybndrfg8ejkmcpqxot1uwisza345h769",bitsPerChar:5});var So={};yt(So,{base36:()=>yh,base36upper:()=>mh});var yh=_e({prefix:"k",name:"base36",alphabet:"0123456789abcdefghijklmnopqrstuvwxyz"}),mh=_e({prefix:"K",name:"base36upper",alphabet:"0123456789ABCDEFGHIJKLMNOPQRSTUVWXYZ"});var _o={};yt(_o,{base64:()=>ko,base64pad:()=>wh,base64url:()=>Io,base64urlpad:()=>bh});var ko=ct({prefix:"m",name:"base64",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/",bitsPerChar:6}),wh=ct({prefix:"M",name:"base64pad",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/=",bitsPerChar:6}),Io=ct({prefix:"u",name:"base64url",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789-_",bitsPerChar:6}),bh=ct({prefix:"U",name:"base64urlpad",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789-_=",bitsPerChar:6});var No={};yt(No,{base8:()=>xh});var xh=ct({prefix:"7",name:"base8",alphabet:"01234567",bitsPerChar:3});var To={};yt(To,{identity:()=>Eh});var Eh=lr({prefix:"\0",name:"identity",encode:r=>$a(r),decode:r=>Fa(r)});var vg=new TextEncoder,Bg=new TextDecoder;function ec(r,t){let{bytes:e,version:n}=r;switch(n){case 0:return Sh(e,Ro(r),t??ut.encoder);default:return kh(e,Ro(r),t??he.encoder)}}var rc=new WeakMap;function Ro(r){let t=rc.get(r);if(t==null){let e=new Map;return rc.set(r,e),e}return t}var qt=class r{code;version;multihash;bytes;"/";constructor(t,e,n,s){this.code=e,this.version=t,this.multihash=n,this.bytes=s,this["/"]=s}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:e}=this;if(t!==Gr)throw new Error("Cannot convert a non dag-pb CID to CIDv0");if(e.code!==Ih)throw new Error("Cannot convert non sha2-256 multihash CID to CIDv0");return r.createV0(e)}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:e}=this.multihash,n=$t(t,e);return r.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 r.equals(this,t)}static equals(t,e){let n=e;return n!=null&&t.code===n.code&&t.version===n.version&&go(t.multihash,n.multihash)}toString(t){return ec(this,t)}toJSON(){return{"/":ec(this)}}link(){return this}[Symbol.toStringTag]="CID";[Symbol.for("nodejs.util.inspect.custom")](){return`CID(${this.toString()})`}static asCID(t){if(t==null)return null;let e=t;if(e instanceof r)return e;if(e["/"]!=null&&e["/"]===e.bytes||e.asCID===e){let{version:n,code:s,multihash:o,bytes:i}=e;return new r(n,s,o,i??nc(n,s,o.bytes))}else if(e[_h]===!0){let{version:n,multihash:s,code:o}=e,i=Ne(s);return r.create(n,o,i)}else return null}static create(t,e,n){if(typeof e!="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(e!==Gr)throw new Error(`Version 0 CID must use dag-pb (code: ${Gr}) block encoding`);return new r(t,e,n,n.bytes)}case 1:{let s=nc(t,e,n.bytes);return new r(t,e,n,s)}default:throw new Error("Invalid version")}}static createV0(t){return r.create(0,Gr,t)}static createV1(t,e){return r.create(1,t,e)}static decode(t){let[e,n]=r.decodeFirst(t);if(n.length!==0)throw new Error("Incorrect length");return e}static decodeFirst(t){let e=r.inspectBytes(t),n=e.size-e.multihashSize,s=fe(t.subarray(n,n+e.multihashSize));if(s.byteLength!==e.multihashSize)throw new Error("Incorrect length");let o=s.subarray(e.multihashSize-e.digestSize),i=new Ge(e.multihashCode,e.digestSize,o,s);return[e.version===0?r.createV0(i):r.createV1(e.codec,i),t.subarray(e.size)]}static inspectBytes(t){let e=0,n=()=>{let[f,g]=qr(t.subarray(e));return e+=g,f},s=n(),o=Gr;if(s===18?(s=0,e=0):o=n(),s!==0&&s!==1)throw new RangeError(`Invalid CID version ${s}`);let i=e,a=n(),c=n(),l=e+c,u=l-i;return{version:s,codec:o,multihashCode:a,digestSize:c,multihashSize:u,size:l}}static parse(t,e){let[n,s]=Ah(t,e),o=r.decode(s);if(o.version===0&&t[0]!=="Q")throw Error("Version 0 CID string must not include multibase prefix");return Ro(o).set(n,t),o}};function Ah(r,t){switch(r[0]){case"Q":{let e=t??ut;return[ut.prefix,e.decode(`${ut.prefix}${r}`)]}case ut.prefix:{let e=t??ut;return[ut.prefix,e.decode(r)]}case he.prefix:{let e=t??he;return[he.prefix,e.decode(r)]}default:{if(t==null)throw Error("To parse non base32 or base58btc encoded CID multibase decoder must be provided");return[r[0],t.decode(r)]}}}function Sh(r,t,e){let{prefix:n}=e;if(n!==ut.prefix)throw Error(`Cannot string encode V0 in ${e.name} encoding`);let s=t.get(n);if(s==null){let o=e.encode(r).slice(1);return t.set(n,o),o}else return s}function kh(r,t,e){let{prefix:n}=e,s=t.get(n);if(s==null){let o=e.encode(r);return t.set(n,o),o}else return s}var Gr=112,Ih=18;function nc(r,t,e){let n=fr(r),s=n+fr(t),o=new Uint8Array(s+e.byteLength);return ur(r,o,0),ur(t,o,n),o.set(e,s),o}var _h=Symbol.for("@ipld/js-cid/CID");var re={...To,...vo,...No,...xo,...Eo,...Ao,...So,...ho,..._o,...Bo},Hg={...bo,...yo};function oc(r,t,e,n){return{name:r,prefix:t,encoder:{name:r,prefix:t,encode:e},decoder:{decode:n}}}var sc=oc("utf8","u",r=>"u"+new TextDecoder("utf8").decode(r),r=>new TextEncoder().encode(r.substring(1))),Lo=oc("ascii","a",r=>{let t="a";for(let e=0;e<r.length;e++)t+=String.fromCharCode(r[e]);return t},r=>{r=r.substring(1);let t=wt(r.length);for(let e=0;e<r.length;e++)t[e]=r.charCodeAt(e);return t}),Nh={utf8:sc,"utf-8":sc,hex:re.base16,latin1:Lo,ascii:Lo,binary:Lo,...re},Sn=Nh;function et(r,t="utf8"){let e=Sn[t];if(e==null)throw new Error(`Unsupported encoding "${t}"`);return e.decoder.decode(`${e.prefix}${r}`)}function Ht(r){return r==null?!1:typeof r.then=="function"&&typeof r.catch=="function"&&typeof r.finally=="function"}function Re(r){if(!Number.isSafeInteger(r)||r<0)throw new Error(`positive integer expected, not ${r}`)}function Th(r){return r instanceof Uint8Array||r!=null&&typeof r=="object"&&r.constructor.name==="Uint8Array"}function hr(r,...t){if(!Th(r))throw new Error("Uint8Array expected");if(t.length>0&&!t.includes(r.length))throw new Error(`Uint8Array expected of length ${t}, not of length=${r.length}`)}function je(r){if(typeof r!="function"||typeof r.create!="function")throw new Error("Hash should be wrapped by utils.wrapConstructor");Re(r.outputLen),Re(r.blockLen)}function dr(r,t=!0){if(r.destroyed)throw new Error("Hash instance has been destroyed");if(t&&r.finished)throw new Error("Hash#digest() has already been called")}function ic(r,t){hr(r);let e=t.outputLen;if(r.length<e)throw new Error(`digestInto() expects output buffer of length at least ${e}`)}var kn=typeof globalThis=="object"&&"crypto"in globalThis?globalThis.crypto:void 0;var gr=r=>new DataView(r.buffer,r.byteOffset,r.byteLength),Gt=(r,t)=>r<<32-t|r>>>t;var Qg=new Uint8Array(new Uint32Array([287454020]).buffer)[0]===68;var Rh=async()=>{};async function ac(r,t,e){let n=Date.now();for(let s=0;s<r;s++){e(s);let o=Date.now()-n;o>=0&&o<t||(await Rh(),n+=o)}}function Co(r){if(typeof r!="string")throw new Error(`utf8ToBytes expected string, got ${typeof r}`);return new Uint8Array(new TextEncoder().encode(r))}function jt(r){return typeof r=="string"&&(r=Co(r)),hr(r),r}function In(...r){let t=0;for(let n=0;n<r.length;n++){let s=r[n];hr(s),t+=s.length}let e=new Uint8Array(t);for(let n=0,s=0;n<r.length;n++){let o=r[n];e.set(o,s),s+=o.length}return e}var pr=class{clone(){return this._cloneInto()}},Lh={}.toString;function cc(r,t){if(t!==void 0&&Lh.call(t)!=="[object Object]")throw new Error("Options should be object or undefined");return Object.assign(r,t)}function _n(r){let t=n=>r().update(jt(n)).digest(),e=r();return t.outputLen=e.outputLen,t.blockLen=e.blockLen,t.create=()=>r(),t}function ze(r=32){if(kn&&typeof kn.getRandomValues=="function")return kn.getRandomValues(new Uint8Array(r));throw new Error("crypto.getRandomValues must be defined")}function Ch(r,t,e,n){if(typeof r.setBigUint64=="function")return r.setBigUint64(t,e,n);let s=BigInt(32),o=BigInt(4294967295),i=Number(e>>s&o),a=Number(e&o),c=n?4:0,l=n?0:4;r.setUint32(t+c,i,n),r.setUint32(t+l,a,n)}var lc=(r,t,e)=>r&t^~r&e,uc=(r,t,e)=>r&t^r&e^t&e,yr=class extends pr{constructor(t,e,n,s){super(),this.blockLen=t,this.outputLen=e,this.padOffset=n,this.isLE=s,this.finished=!1,this.length=0,this.pos=0,this.destroyed=!1,this.buffer=new Uint8Array(t),this.view=gr(this.buffer)}update(t){dr(this);let{view:e,buffer:n,blockLen:s}=this;t=jt(t);let o=t.length;for(let i=0;i<o;){let a=Math.min(s-this.pos,o-i);if(a===s){let c=gr(t);for(;s<=o-i;i+=s)this.process(c,i);continue}n.set(t.subarray(i,i+a),this.pos),this.pos+=a,i+=a,this.pos===s&&(this.process(e,0),this.pos=0)}return this.length+=t.length,this.roundClean(),this}digestInto(t){dr(this),ic(t,this),this.finished=!0;let{buffer:e,view:n,blockLen:s,isLE:o}=this,{pos:i}=this;e[i++]=128,this.buffer.subarray(i).fill(0),this.padOffset>s-i&&(this.process(n,0),i=0);for(let f=i;f<s;f++)e[f]=0;Ch(n,s-8,BigInt(this.length*8),o),this.process(n,0);let a=gr(t),c=this.outputLen;if(c%4)throw new Error("_sha2: outputLen should be aligned to 32bit");let l=c/4,u=this.get();if(l>u.length)throw new Error("_sha2: outputLen bigger than state");for(let f=0;f<l;f++)a.setUint32(4*f,u[f],o)}digest(){let{buffer:t,outputLen:e}=this;this.digestInto(t);let n=t.slice(0,e);return this.destroy(),n}_cloneInto(t){t||(t=new this.constructor),t.set(...this.get());let{blockLen:e,buffer:n,length:s,finished:o,destroyed:i,pos:a}=this;return t.length=s,t.pos=a,t.finished=o,t.destroyed=i,s%e&&t.buffer.set(n),t}};var Nn=BigInt(4294967295),Uo=BigInt(32);function fc(r,t=!1){return t?{h:Number(r&Nn),l:Number(r>>Uo&Nn)}:{h:Number(r>>Uo&Nn)|0,l:Number(r&Nn)|0}}function Uh(r,t=!1){let e=new Uint32Array(r.length),n=new Uint32Array(r.length);for(let s=0;s<r.length;s++){let{h:o,l:i}=fc(r[s],t);[e[s],n[s]]=[o,i]}return[e,n]}var Ph=(r,t)=>BigInt(r>>>0)<<Uo|BigInt(t>>>0),Dh=(r,t,e)=>r>>>e,Vh=(r,t,e)=>r<<32-e|t>>>e,Oh=(r,t,e)=>r>>>e|t<<32-e,Hh=(r,t,e)=>r<<32-e|t>>>e,Mh=(r,t,e)=>r<<64-e|t>>>e-32,Kh=(r,t,e)=>r>>>e-32|t<<64-e,Fh=(r,t)=>t,$h=(r,t)=>r,qh=(r,t,e)=>r<<e|t>>>32-e,Gh=(r,t,e)=>t<<e|r>>>32-e,jh=(r,t,e)=>t<<e-32|r>>>64-e,zh=(r,t,e)=>r<<e-32|t>>>64-e;function Wh(r,t,e,n){let s=(t>>>0)+(n>>>0);return{h:r+e+(s/2**32|0)|0,l:s|0}}var Yh=(r,t,e)=>(r>>>0)+(t>>>0)+(e>>>0),Zh=(r,t,e,n)=>t+e+n+(r/2**32|0)|0,Xh=(r,t,e,n)=>(r>>>0)+(t>>>0)+(e>>>0)+(n>>>0),Jh=(r,t,e,n,s)=>t+e+n+s+(r/2**32|0)|0,Qh=(r,t,e,n,s)=>(r>>>0)+(t>>>0)+(e>>>0)+(n>>>0)+(s>>>0),td=(r,t,e,n,s,o)=>t+e+n+s+o+(r/2**32|0)|0;var ed={fromBig:fc,split:Uh,toBig:Ph,shrSH:Dh,shrSL:Vh,rotrSH:Oh,rotrSL:Hh,rotrBH:Mh,rotrBL:Kh,rotr32H:Fh,rotr32L:$h,rotlSH:qh,rotlSL:Gh,rotlBH:jh,rotlBL:zh,add:Wh,add3L:Yh,add3H:Zh,add4L:Xh,add4H:Jh,add5H:td,add5L:Qh},z=ed;var[rd,nd]=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(r=>BigInt(r))),Le=new Uint32Array(80),Ce=new Uint32Array(80),Po=class extends yr{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:e,Bh:n,Bl:s,Ch:o,Cl:i,Dh:a,Dl:c,Eh:l,El:u,Fh:f,Fl:g,Gh:m,Gl:d,Hh:h,Hl:p}=this;return[t,e,n,s,o,i,a,c,l,u,f,g,m,d,h,p]}set(t,e,n,s,o,i,a,c,l,u,f,g,m,d,h,p){this.Ah=t|0,this.Al=e|0,this.Bh=n|0,this.Bl=s|0,this.Ch=o|0,this.Cl=i|0,this.Dh=a|0,this.Dl=c|0,this.Eh=l|0,this.El=u|0,this.Fh=f|0,this.Fl=g|0,this.Gh=m|0,this.Gl=d|0,this.Hh=h|0,this.Hl=p|0}process(t,e){for(let w=0;w<16;w++,e+=4)Le[w]=t.getUint32(e),Ce[w]=t.getUint32(e+=4);for(let w=16;w<80;w++){let A=Le[w-15]|0,B=Ce[w-15]|0,S=z.rotrSH(A,B,1)^z.rotrSH(A,B,8)^z.shrSH(A,B,7),N=z.rotrSL(A,B,1)^z.rotrSL(A,B,8)^z.shrSL(A,B,7),_=Le[w-2]|0,V=Ce[w-2]|0,P=z.rotrSH(_,V,19)^z.rotrBH(_,V,61)^z.shrSH(_,V,6),R=z.rotrSL(_,V,19)^z.rotrBL(_,V,61)^z.shrSL(_,V,6),H=z.add4L(N,R,Ce[w-7],Ce[w-16]),O=z.add4H(H,S,P,Le[w-7],Le[w-16]);Le[w]=O|0,Ce[w]=H|0}let{Ah:n,Al:s,Bh:o,Bl:i,Ch:a,Cl:c,Dh:l,Dl:u,Eh:f,El:g,Fh:m,Fl:d,Gh:h,Gl:p,Hh:b,Hl:v}=this;for(let w=0;w<80;w++){let A=z.rotrSH(f,g,14)^z.rotrSH(f,g,18)^z.rotrBH(f,g,41),B=z.rotrSL(f,g,14)^z.rotrSL(f,g,18)^z.rotrBL(f,g,41),S=f&m^~f&h,N=g&d^~g&p,_=z.add5L(v,B,N,nd[w],Ce[w]),V=z.add5H(_,b,A,S,rd[w],Le[w]),P=_|0,R=z.rotrSH(n,s,28)^z.rotrBH(n,s,34)^z.rotrBH(n,s,39),H=z.rotrSL(n,s,28)^z.rotrBL(n,s,34)^z.rotrBL(n,s,39),O=n&o^n&a^o&a,W=s&i^s&c^i&c;b=h|0,v=p|0,h=m|0,p=d|0,m=f|0,d=g|0,{h:f,l:g}=z.add(l|0,u|0,V|0,P|0),l=a|0,u=c|0,a=o|0,c=i|0,o=n|0,i=s|0;let x=z.add3L(P,H,W);n=z.add3H(x,V,R,O),s=x|0}({h:n,l:s}=z.add(this.Ah|0,this.Al|0,n|0,s|0)),{h:o,l:i}=z.add(this.Bh|0,this.Bl|0,o|0,i|0),{h:a,l:c}=z.add(this.Ch|0,this.Cl|0,a|0,c|0),{h:l,l:u}=z.add(this.Dh|0,this.Dl|0,l|0,u|0),{h:f,l:g}=z.add(this.Eh|0,this.El|0,f|0,g|0),{h:m,l:d}=z.add(this.Fh|0,this.Fl|0,m|0,d|0),{h,l:p}=z.add(this.Gh|0,this.Gl|0,h|0,p|0),{h:b,l:v}=z.add(this.Hh|0,this.Hl|0,b|0,v|0),this.set(n,s,o,i,a,c,l,u,f,g,m,d,h,p,b,v)}roundClean(){Le.fill(0),Ce.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 mr=_n(()=>new Po);var Rn={};yt(Rn,{abytes:()=>wr,bitGet:()=>ud,bitLen:()=>ld,bitMask:()=>jr,bitSet:()=>fd,bytesToHex:()=>pe,bytesToNumberBE:()=>ge,bytesToNumberLE:()=>zt,concatBytes:()=>me,createHmacDrbg:()=>Oo,ensureBytes:()=>st,equalBytes:()=>ad,hexToBytes:()=>We,hexToNumber:()=>Vo,isBytes:()=>Ue,numberToBytesBE:()=>Pe,numberToBytesLE:()=>ye,numberToHexUnpadded:()=>gc,numberToVarBytesBE:()=>id,utf8ToBytes:()=>cd,validateObject:()=>Mt});var pc=BigInt(0),Tn=BigInt(1),sd=BigInt(2);function Ue(r){return r instanceof Uint8Array||r!=null&&typeof r=="object"&&r.constructor.name==="Uint8Array"}function wr(r){if(!Ue(r))throw new Error("Uint8Array expected")}var od=Array.from({length:256},(r,t)=>t.toString(16).padStart(2,"0"));function pe(r){wr(r);let t="";for(let e=0;e<r.length;e++)t+=od[r[e]];return t}function gc(r){let t=r.toString(16);return t.length&1?`0${t}`:t}function Vo(r){if(typeof r!="string")throw new Error("hex string expected, got "+typeof r);return BigInt(r===""?"0":`0x${r}`)}var de={_0:48,_9:57,_A:65,_F:70,_a:97,_f:102};function hc(r){if(r>=de._0&&r<=de._9)return r-de._0;if(r>=de._A&&r<=de._F)return r-(de._A-10);if(r>=de._a&&r<=de._f)return r-(de._a-10)}function We(r){if(typeof r!="string")throw new Error("hex string expected, got "+typeof r);let t=r.length,e=t/2;if(t%2)throw new Error("padded hex string expected, got unpadded hex of length "+t);let n=new Uint8Array(e);for(let s=0,o=0;s<e;s++,o+=2){let i=hc(r.charCodeAt(o)),a=hc(r.charCodeAt(o+1));if(i===void 0||a===void 0){let c=r[o]+r[o+1];throw new Error('hex string expected, got non-hex character "'+c+'" at index '+o)}n[s]=i*16+a}return n}function ge(r){return Vo(pe(r))}function zt(r){return wr(r),Vo(pe(Uint8Array.from(r).reverse()))}function Pe(r,t){return We(r.toString(16).padStart(t*2,"0"))}function ye(r,t){return Pe(r,t).reverse()}function id(r){return We(gc(r))}function st(r,t,e){let n;if(typeof t=="string")try{n=We(t)}catch(o){throw new Error(`${r} must be valid hex string, got "${t}". Cause: ${o}`)}else if(Ue(t))n=Uint8Array.from(t);else throw new Error(`${r} must be hex string or Uint8Array`);let s=n.length;if(typeof e=="number"&&s!==e)throw new Error(`${r} expected ${e} bytes, got ${s}`);return n}function me(...r){let t=0;for(let n=0;n<r.length;n++){let s=r[n];wr(s),t+=s.length}let e=new Uint8Array(t);for(let n=0,s=0;n<r.length;n++){let o=r[n];e.set(o,s),s+=o.length}return e}function ad(r,t){if(r.length!==t.length)return!1;let e=0;for(let n=0;n<r.length;n++)e|=r[n]^t[n];return e===0}function cd(r){if(typeof r!="string")throw new Error(`utf8ToBytes expected string, got ${typeof r}`);return new Uint8Array(new TextEncoder().encode(r))}function ld(r){let t;for(t=0;r>pc;r>>=Tn,t+=1);return t}function ud(r,t){return r>>BigInt(t)&Tn}function fd(r,t,e){return r|(e?Tn:pc)<<BigInt(t)}var jr=r=>(sd<<BigInt(r-1))-Tn,Do=r=>new Uint8Array(r),dc=r=>Uint8Array.from(r);function Oo(r,t,e){if(typeof r!="number"||r<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 e!="function")throw new Error("hmacFn must be a function");let n=Do(r),s=Do(r),o=0,i=()=>{n.fill(1),s.fill(0),o=0},a=(...f)=>e(s,n,...f),c=(f=Do())=>{s=a(dc([0]),f),n=a(),f.length!==0&&(s=a(dc([1]),f),n=a())},l=()=>{if(o++>=1e3)throw new Error("drbg: tried 1000 values");let f=0,g=[];for(;f<t;){n=a();let m=n.slice();g.push(m),f+=n.length}return me(...g)};return(f,g)=>{i(),c(f);let m;for(;!(m=g(l()));)c();return i(),m}}var hd={bigint:r=>typeof r=="bigint",function:r=>typeof r=="function",boolean:r=>typeof r=="boolean",string:r=>typeof r=="string",stringOrUint8Array:r=>typeof r=="string"||Ue(r),isSafeInteger:r=>Number.isSafeInteger(r),array:r=>Array.isArray(r),field:(r,t)=>t.Fp.isValid(r),hash:r=>typeof r=="function"&&Number.isSafeInteger(r.outputLen)};function Mt(r,t,e={}){let n=(s,o,i)=>{let a=hd[o];if(typeof a!="function")throw new Error(`Invalid validator "${o}", expected function`);let c=r[s];if(!(i&&c===void 0)&&!a(c,r))throw new Error(`Invalid param ${String(s)}=${c} (${typeof c}), expected ${o}`)};for(let[s,o]of Object.entries(t))n(s,o,!1);for(let[s,o]of Object.entries(e))n(s,o,!0);return r}var bt=BigInt(0),it=BigInt(1),Ye=BigInt(2),dd=BigInt(3),Ho=BigInt(4),yc=BigInt(5),mc=BigInt(8),pd=BigInt(9),gd=BigInt(16);function Z(r,t){let e=r%t;return e>=bt?e:t+e}function Mo(r,t,e){if(e<=bt||t<bt)throw new Error("Expected power/modulo > 0");if(e===it)return bt;let n=it;for(;t>bt;)t&it&&(n=n*r%e),r=r*r%e,t>>=it;return n}function ot(r,t,e){let n=r;for(;t-- >bt;)n*=n,n%=e;return n}function Ln(r,t){if(r===bt||t<=bt)throw new Error(`invert: expected positive integers, got n=${r} mod=${t}`);let e=Z(r,t),n=t,s=bt,o=it,i=it,a=bt;for(;e!==bt;){let l=n/e,u=n%e,f=s-i*l,g=o-a*l;n=e,e=u,s=i,o=a,i=f,a=g}if(n!==it)throw new Error("invert: does not exist");return Z(s,t)}function yd(r){let t=(r-it)/Ye,e,n,s;for(e=r-it,n=0;e%Ye===bt;e/=Ye,n++);for(s=Ye;s<r&&Mo(s,t,r)!==r-it;s++);if(n===1){let i=(r+it)/Ho;return function(c,l){let u=c.pow(l,i);if(!c.eql(c.sqr(u),l))throw new Error("Cannot find square root");return u}}let o=(e+it)/Ye;return function(a,c){if(a.pow(c,t)===a.neg(a.ONE))throw new Error("Cannot find square root");let l=n,u=a.pow(a.mul(a.ONE,s),e),f=a.pow(c,o),g=a.pow(c,e);for(;!a.eql(g,a.ONE);){if(a.eql(g,a.ZERO))return a.ZERO;let m=1;for(let h=a.sqr(g);m<l&&!a.eql(h,a.ONE);m++)h=a.sqr(h);let d=a.pow(u,it<<BigInt(l-m-1));u=a.sqr(d),f=a.mul(f,d),g=a.mul(g,u),l=m}return f}}function md(r){if(r%Ho===dd){let t=(r+it)/Ho;return function(n,s){let o=n.pow(s,t);if(!n.eql(n.sqr(o),s))throw new Error("Cannot find square root");return o}}if(r%mc===yc){let t=(r-yc)/mc;return function(n,s){let o=n.mul(s,Ye),i=n.pow(o,t),a=n.mul(s,i),c=n.mul(n.mul(a,Ye),i),l=n.mul(a,n.sub(c,n.ONE));if(!n.eql(n.sqr(l),s))throw new Error("Cannot find square root");return l}}return r%gd,yd(r)}var wc=(r,t)=>(Z(r,t)&it)===it,wd=["create","isValid","is0","neg","inv","sqrt","sqr","eql","add","sub","mul","pow","div","addN","subN","mulN","sqrN"];function Ko(r){let t={ORDER:"bigint",MASK:"bigint",BYTES:"isSafeInteger",BITS:"isSafeInteger"},e=wd.reduce((n,s)=>(n[s]="function",n),t);return Mt(r,e)}function bd(r,t,e){if(e<bt)throw new Error("Expected power > 0");if(e===bt)return r.ONE;if(e===it)return t;let n=r.ONE,s=t;for(;e>bt;)e&it&&(n=r.mul(n,s)),s=r.sqr(s),e>>=it;return n}function xd(r,t){let e=new Array(t.length),n=t.reduce((o,i,a)=>r.is0(i)?o:(e[a]=o,r.mul(o,i)),r.ONE),s=r.inv(n);return t.reduceRight((o,i,a)=>r.is0(i)?o:(e[a]=r.mul(o,e[a]),r.mul(o,i)),s),e}function Fo(r,t){let e=t!==void 0?t:r.toString(2).length,n=Math.ceil(e/8);return{nBitLength:e,nByteLength:n}}function Cn(r,t,e=!1,n={}){if(r<=bt)throw new Error(`Expected Field ORDER > 0, got ${r}`);let{nBitLength:s,nByteLength:o}=Fo(r,t);if(o>2048)throw new Error("Field lengths over 2048 bytes are not supported");let i=md(r),a=Object.freeze({ORDER:r,BITS:s,BYTES:o,MASK:jr(s),ZERO:bt,ONE:it,create:c=>Z(c,r),isValid:c=>{if(typeof c!="bigint")throw new Error(`Invalid field element: expected bigint, got ${typeof c}`);return bt<=c&&c<r},is0:c=>c===bt,isOdd:c=>(c&it)===it,neg:c=>Z(-c,r),eql:(c,l)=>c===l,sqr:c=>Z(c*c,r),add:(c,l)=>Z(c+l,r),sub:(c,l)=>Z(c-l,r),mul:(c,l)=>Z(c*l,r),pow:(c,l)=>bd(a,c,l),div:(c,l)=>Z(c*Ln(l,r),r),sqrN:c=>c*c,addN:(c,l)=>c+l,subN:(c,l)=>c-l,mulN:(c,l)=>c*l,inv:c=>Ln(c,r),sqrt:n.sqrt||(c=>i(a,c)),invertBatch:c=>xd(a,c),cmov:(c,l,u)=>u?l:c,toBytes:c=>e?ye(c,o):Pe(c,o),fromBytes:c=>{if(c.length!==o)throw new Error(`Fp.fromBytes: expected ${o}, got ${c.length}`);return e?zt(c):ge(c)}});return Object.freeze(a)}function bc(r,t){if(!r.isOdd)throw new Error("Field doesn't have isOdd");let e=r.sqrt(t);return r.isOdd(e)?r.neg(e):e}function xc(r){if(typeof r!="bigint")throw new Error("field order must be bigint");let t=r.toString(2).length;return Math.ceil(t/8)}function $o(r){let t=xc(r);return t+Math.ceil(t/2)}function Ec(r,t,e=!1){let n=r.length,s=xc(t),o=$o(t);if(n<16||n<o||n>1024)throw new Error(`expected ${o}-1024 bytes of input, got ${n}`);let i=e?ge(r):zt(r),a=Z(i,t-it)+it;return e?ye(a,s):Pe(a,s)}var vd=BigInt(0),qo=BigInt(1);function Un(r,t){let e=(s,o)=>{let i=o.negate();return s?i:o},n=s=>{let o=Math.ceil(t/s)+1,i=2**(s-1);return{windows:o,windowSize:i}};return{constTimeNegate:e,unsafeLadder(s,o){let i=r.ZERO,a=s;for(;o>vd;)o&qo&&(i=i.add(a)),a=a.double(),o>>=qo;return i},precomputeWindow(s,o){let{windows:i,windowSize:a}=n(o),c=[],l=s,u=l;for(let f=0;f<i;f++){u=l,c.push(u);for(let g=1;g<a;g++)u=u.add(l),c.push(u);l=u.double()}return c},wNAF(s,o,i){let{windows:a,windowSize:c}=n(s),l=r.ZERO,u=r.BASE,f=BigInt(2**s-1),g=2**s,m=BigInt(s);for(let d=0;d<a;d++){let h=d*c,p=Number(i&f);i>>=m,p>c&&(p-=g,i+=qo);let b=h,v=h+Math.abs(p)-1,w=d%2!==0,A=p<0;p===0?u=u.add(e(w,o[b])):l=l.add(e(A,o[v]))}return{p:l,f:u}},wNAFCached(s,o,i,a){let c=s._WINDOW_SIZE||1,l=o.get(s);return l||(l=this.precomputeWindow(s,c),c!==1&&o.set(s,a(l))),this.wNAF(c,l,i)}}}function zr(r){return Ko(r.Fp),Mt(r,{n:"bigint",h:"bigint",Gx:"field",Gy:"field"},{nBitLength:"isSafeInteger",nByteLength:"isSafeInteger"}),Object.freeze({...Fo(r.n,r.nBitLength),...r,p:r.Fp.ORDER})}var Wt=BigInt(0),Dt=BigInt(1),Pn=BigInt(2),Bd=BigInt(8),Ad={zip215:!0};function Sd(r){let t=zr(r);return Mt(r,{hash:"function",a:"bigint",d:"bigint",randomBytes:"function"},{adjustScalarBytes:"function",domain:"function",uvRatio:"function",mapToCurve:"function"}),Object.freeze({...t})}function Dn(r){let t=Sd(r),{Fp:e,n,prehash:s,hash:o,randomBytes:i,nByteLength:a,h:c}=t,l=Pn<<BigInt(a*8)-Dt,u=e.create,f=t.uvRatio||((E,y)=>{try{return{isValid:!0,value:e.sqrt(E*e.inv(y))}}catch{return{isValid:!1,value:Wt}}}),g=t.adjustScalarBytes||(E=>E),m=t.domain||((E,y,k)=>{if(y.length||k)throw new Error("Contexts/pre-hash are not supported");return E}),d=E=>typeof E=="bigint"&&Wt<E,h=(E,y)=>d(E)&&d(y)&&E<y,p=E=>E===Wt||h(E,l);function b(E,y){if(h(E,y))return E;throw new Error(`Expected valid scalar < ${y}, got ${typeof E} ${E}`)}function v(E){return E===Wt?E:b(E,n)}let w=new Map;function A(E){if(!(E instanceof B))throw new Error("ExtendedPoint expected")}class B{constructor(y,k,T,L){if(this.ex=y,this.ey=k,this.ez=T,this.et=L,!p(y))throw new Error("x required");if(!p(k))throw new Error("y required");if(!p(T))throw new Error("z required");if(!p(L))throw new Error("t required")}get x(){return this.toAffine().x}get y(){return this.toAffine().y}static fromAffine(y){if(y instanceof B)throw new Error("extended point not allowed");let{x:k,y:T}=y||{};if(!p(k)||!p(T))throw new Error("invalid affine point");return new B(k,T,Dt,u(k*T))}static normalizeZ(y){let k=e.invertBatch(y.map(T=>T.ez));return y.map((T,L)=>T.toAffine(k[L])).map(B.fromAffine)}_setWindowSize(y){this._WINDOW_SIZE=y,w.delete(this)}assertValidity(){let{a:y,d:k}=t;if(this.is0())throw new Error("bad point: ZERO");let{ex:T,ey:L,ez:M,et:K}=this,j=u(T*T),$=u(L*L),G=u(M*M),nt=u(G*G),tt=u(j*y),vt=u(G*u(tt+$)),Bt=u(nt+u(k*u(j*$)));if(vt!==Bt)throw new Error("bad point: equation left != right (1)");let gt=u(T*L),_t=u(M*K);if(gt!==_t)throw new Error("bad point: equation left != right (2)")}equals(y){A(y);let{ex:k,ey:T,ez:L}=this,{ex:M,ey:K,ez:j}=y,$=u(k*j),G=u(M*L),nt=u(T*j),tt=u(K*L);return $===G&&nt===tt}is0(){return this.equals(B.ZERO)}negate(){return new B(u(-this.ex),this.ey,this.ez,u(-this.et))}double(){let{a:y}=t,{ex:k,ey:T,ez:L}=this,M=u(k*k),K=u(T*T),j=u(Pn*u(L*L)),$=u(y*M),G=k+T,nt=u(u(G*G)-M-K),tt=$+K,vt=tt-j,Bt=$-K,gt=u(nt*vt),_t=u(tt*Bt),ue=u(nt*Bt),qe=u(vt*tt);return new B(gt,_t,qe,ue)}add(y){A(y);let{a:k,d:T}=t,{ex:L,ey:M,ez:K,et:j}=this,{ex:$,ey:G,ez:nt,et:tt}=y;if(k===BigInt(-1)){let _a=u((M-L)*(G+$)),Na=u((M+L)*(G-$)),ao=u(Na-_a);if(ao===Wt)return this.double();let Ta=u(K*Pn*tt),Ra=u(j*Pn*nt),La=Ra+Ta,Ca=Na+_a,Ua=Ra-Ta,gf=u(La*ao),yf=u(Ca*Ua),mf=u(La*Ua),wf=u(ao*Ca);return new B(gf,yf,wf,mf)}let vt=u(L*$),Bt=u(M*G),gt=u(j*T*tt),_t=u(K*nt),ue=u((L+M)*($+G)-vt-Bt),qe=_t-gt,Fr=_t+gt,Ia=u(Bt-k*vt),ff=u(ue*qe),hf=u(Fr*Ia),df=u(ue*Ia),pf=u(qe*Fr);return new B(ff,hf,pf,df)}subtract(y){return this.add(y.negate())}wNAF(y){return _.wNAFCached(this,w,y,B.normalizeZ)}multiply(y){let{p:k,f:T}=this.wNAF(b(y,n));return B.normalizeZ([k,T])[0]}multiplyUnsafe(y){let k=v(y);return k===Wt?N:this.equals(N)||k===Dt?this:this.equals(S)?this.wNAF(k).p:_.unsafeLadder(this,k)}isSmallOrder(){return this.multiplyUnsafe(c).is0()}isTorsionFree(){return _.unsafeLadder(this,n).is0()}toAffine(y){let{ex:k,ey:T,ez:L}=this,M=this.is0();y==null&&(y=M?Bd:e.inv(L));let K=u(k*y),j=u(T*y),$=u(L*y);if(M)return{x:Wt,y:Dt};if($!==Dt)throw new Error("invZ was invalid");return{x:K,y:j}}clearCofactor(){let{h:y}=t;return y===Dt?this:this.multiplyUnsafe(y)}static fromHex(y,k=!1){let{d:T,a:L}=t,M=e.BYTES;y=st("pointHex",y,M);let K=y.slice(),j=y[M-1];K[M-1]=j&-129;let $=zt(K);$===Wt||(k?b($,l):b($,e.ORDER));let G=u($*$),nt=u(G-Dt),tt=u(T*G-L),{isValid:vt,value:Bt}=f(nt,tt);if(!vt)throw new Error("Point.fromHex: invalid y coordinate");let gt=(Bt&Dt)===Dt,_t=(j&128)!==0;if(!k&&Bt===Wt&&_t)throw new Error("Point.fromHex: x=0 and x_0=1");return _t!==gt&&(Bt=u(-Bt)),B.fromAffine({x:Bt,y:$})}static fromPrivateKey(y){return R(y).point}toRawBytes(){let{x:y,y:k}=this.toAffine(),T=ye(k,e.BYTES);return T[T.length-1]|=y&Dt?128:0,T}toHex(){return pe(this.toRawBytes())}}B.BASE=new B(t.Gx,t.Gy,Dt,u(t.Gx*t.Gy)),B.ZERO=new B(Wt,Dt,Dt,Wt);let{BASE:S,ZERO:N}=B,_=Un(B,a*8);function V(E){return Z(E,n)}function P(E){return V(zt(E))}function R(E){let y=a;E=st("private key",E,y);let k=st("hashed private key",o(E),2*y),T=g(k.slice(0,y)),L=k.slice(y,2*y),M=P(T),K=S.multiply(M),j=K.toRawBytes();return{head:T,prefix:L,scalar:M,point:K,pointBytes:j}}function H(E){return R(E).pointBytes}function O(E=new Uint8Array,...y){let k=me(...y);return P(o(m(k,st("context",E),!!s)))}function W(E,y,k={}){E=st("message",E),s&&(E=s(E));let{prefix:T,scalar:L,pointBytes:M}=R(y),K=O(k.context,T,E),j=S.multiply(K).toRawBytes(),$=O(k.context,j,M,E),G=V(K+$*L);v(G);let nt=me(j,ye(G,e.BYTES));return st("result",nt,a*2)}let x=Ad;function I(E,y,k,T=x){let{context:L,zip215:M}=T,K=e.BYTES;E=st("signature",E,2*K),y=st("message",y),s&&(y=s(y));let j=zt(E.slice(K,2*K)),$,G,nt;try{$=B.fromHex(k,M),G=B.fromHex(E.slice(0,K),M),nt=S.multiplyUnsafe(j)}catch{return!1}if(!M&&$.isSmallOrder())return!1;let tt=O(L,G.toRawBytes(),$.toRawBytes(),y);return G.add($.multiplyUnsafe(tt)).subtract(nt).clearCofactor().equals(B.ZERO)}return S._setWindowSize(8),{CURVE:t,getPublicKey:H,sign:W,verify:I,ExtendedPoint:B,utils:{getExtendedPublicKey:R,randomPrivateKey:()=>i(e.BYTES),precompute(E=8,y=B.BASE){return y._setWindowSize(E),y.multiply(BigInt(3)),y}}}}var Wr=BigInt(0),Go=BigInt(1);function kd(r){return Mt(r,{a:"bigint"},{montgomeryBits:"isSafeInteger",nByteLength:"isSafeInteger",adjustScalarBytes:"function",domain:"function",powPminus2:"function",Gu:"bigint"}),Object.freeze({...r})}function vc(r){let t=kd(r),{P:e}=t,n=w=>Z(w,e),s=t.montgomeryBits,o=Math.ceil(s/8),i=t.nByteLength,a=t.adjustScalarBytes||(w=>w),c=t.powPminus2||(w=>Mo(w,e-BigInt(2),e));function l(w,A,B){let S=n(w*(A-B));return A=n(A-S),B=n(B+S),[A,B]}function u(w){if(typeof w=="bigint"&&Wr<=w&&w<e)return w;throw new Error("Expected valid scalar 0 < scalar < CURVE.P")}let f=(t.a-BigInt(2))/BigInt(4);function g(w,A){let B=u(w),S=u(A),N=B,_=Go,V=Wr,P=B,R=Go,H=Wr,O;for(let x=BigInt(s-1);x>=Wr;x--){let I=S>>x&Go;H^=I,O=l(H,_,P),_=O[0],P=O[1],O=l(H,V,R),V=O[0],R=O[1],H=I;let C=_+V,E=n(C*C),y=_-V,k=n(y*y),T=E-k,L=P+R,M=P-R,K=n(M*C),j=n(L*y),$=K+j,G=K-j;P=n($*$),R=n(N*n(G*G)),_=n(E*k),V=n(T*(E+n(f*T)))}O=l(H,_,P),_=O[0],P=O[1],O=l(H,V,R),V=O[0],R=O[1];let W=c(V);return n(_*W)}function m(w){return ye(n(w),o)}function d(w){let A=st("u coordinate",w,o);return i===32&&(A[31]&=127),zt(A)}function h(w){let A=st("scalar",w),B=A.length;if(B!==o&&B!==i)throw new Error(`Expected ${o} or ${i} bytes, got ${B}`);return zt(a(A))}function p(w,A){let B=d(A),S=h(w),N=g(B,S);if(N===Wr)throw new Error("Invalid private or public key received");return m(N)}let b=m(t.Gu);function v(w){return p(w,b)}return{scalarMult:p,scalarMultBase:v,getSharedSecret:(w,A)=>p(w,A),getPublicKey:w=>v(w),utils:{randomPrivateKey:()=>t.randomBytes(t.nByteLength)},GuBytes:b}}var Yr=BigInt("57896044618658097711785492504343953926634992332820282019728792003956564819949"),Bc=BigInt("19681161376707505956807079304988542015446066515923890162744021073123829784752"),Sy=BigInt(0),Id=BigInt(1),jo=BigInt(2),_d=BigInt(5),Ac=BigInt(10),Nd=BigInt(20),Td=BigInt(40),Sc=BigInt(80);function kc(r){let t=Yr,n=r*r%t*r%t,s=ot(n,jo,t)*n%t,o=ot(s,Id,t)*r%t,i=ot(o,_d,t)*o%t,a=ot(i,Ac,t)*i%t,c=ot(a,Nd,t)*a%t,l=ot(c,Td,t)*c%t,u=ot(l,Sc,t)*l%t,f=ot(u,Sc,t)*l%t,g=ot(f,Ac,t)*i%t;return{pow_p_5_8:ot(g,jo,t)*r%t,b2:n}}function Ic(r){return r[0]&=248,r[31]&=127,r[31]|=64,r}function Rd(r,t){let e=Yr,n=Z(t*t*t,e),s=Z(n*n*t,e),o=kc(r*s).pow_p_5_8,i=Z(r*n*o,e),a=Z(t*i*i,e),c=i,l=Z(i*Bc,e),u=a===r,f=a===Z(-r,e),g=a===Z(-r*Bc,e);return u&&(i=c),(f||g)&&(i=l),wc(i,e)&&(i=Z(-i,e)),{isValid:u||f,value:i}}var we=Cn(Yr,void 0,!0),zo={a:BigInt(-1),d:BigInt("37095705934669439343138083508754565189542113879843219016388785533085940283555"),Fp:we,n:BigInt("7237005577332262213973186563042994240857116359379907606001950938285454250989"),h:BigInt(8),Gx:BigInt("15112221349535400772501151409588531511454012693041857206046113283949847762202"),Gy:BigInt("46316835694926478169428394003475163141307993866256225615783033603165251855960"),hash:mr,randomBytes:ze,adjustScalarBytes:Ic,uvRatio:Rd},br=Dn(zo);function _c(r,t,e){if(t.length>255)throw new Error("Context is too big");return In(Co("SigEd25519 no Ed25519 collisions"),new Uint8Array([e?1:0,t.length]),t,r)}var ky=Dn({...zo,domain:_c}),Iy=Dn({...zo,domain:_c,prehash:mr}),Zr=vc({P:Yr,a:BigInt(486662),montgomeryBits:255,nByteLength:32,Gu:BigInt(9),powPminus2:r=>{let t=Yr,{pow_p_5_8:e,b2:n}=kc(r);return Z(ot(e,BigInt(3),t)*n,t)},adjustScalarBytes:Ic,randomBytes:ze});var Ld=(we.ORDER+BigInt(3))/BigInt(8),_y=we.pow(jo,Ld),Ny=we.sqrt(we.neg(we.ONE)),Ty=(we.ORDER-BigInt(5))/BigInt(8),Ry=BigInt(486662);var Ly=bc(we,we.neg(BigInt(486664)));var Cy=BigInt("25063068953384623474111414158702152701244531502492656460079210482610430750235"),Uy=BigInt("54469307008909316920995813868745141605393597292927456921205312896311721017578"),Py=BigInt("1159843021668779879193775521855586647937357759715417654439879720876111806838"),Dy=BigInt("40440834346308536858101042469323190826248399146238708352240133220865137265952");var Vy=BigInt("0x7fffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffff");var xr=32,be=64,Vn=32;function Nc(){let r=br.utils.randomPrivateKey(),t=br.getPublicKey(r);return{privateKey:Cc(r,t),publicKey:t}}function Tc(r){if(r.length!==Vn)throw new TypeError('"seed" must be 32 bytes in length.');if(!(r instanceof Uint8Array))throw new TypeError('"seed" must be a node.js Buffer, or Uint8Array.');let t=r,e=br.getPublicKey(t);return{privateKey:Cc(t,e),publicKey:e}}function Rc(r,t){let e=r.subarray(0,Vn);return br.sign(t instanceof Uint8Array?t:t.subarray(),e)}function Lc(r,t,e){return br.verify(t,e instanceof Uint8Array?e:e.subarray(),r)}function Cc(r,t){let e=new Uint8Array(be);for(let n=0;n<Vn;n++)e[n]=r[n],e[Vn+n]=t[n];return e}var Lt={get(r=globalThis){let t=r.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 Wo={alg:"A128GCM",ext:!0,k:"scm9jmO_4BJAgdwWGVulLg",key_ops:["encrypt","decrypt"],kty:"oct"};function Uc(r){let t=r?.algorithm??"AES-GCM",e=r?.keyLength??16,n=r?.nonceLength??12,s=r?.digest??"SHA-256",o=r?.saltLength??16,i=r?.iterations??32767,a=Lt.get();e*=8;async function c(f,g){let m=a.getRandomValues(new Uint8Array(o)),d=a.getRandomValues(new Uint8Array(n)),h={name:t,iv:d};typeof g=="string"&&(g=et(g));let p;if(g.length===0){p=await a.subtle.importKey("jwk",Wo,{name:"AES-GCM"},!0,["encrypt"]);try{let v={name:"PBKDF2",salt:m,iterations:i,hash:{name:s}},w=await a.subtle.importKey("raw",g,{name:"PBKDF2"},!1,["deriveKey"]);p=await a.subtle.deriveKey(v,w,{name:t,length:e},!0,["encrypt"])}catch{p=await a.subtle.importKey("jwk",Wo,{name:"AES-GCM"},!0,["encrypt"])}}else{let v={name:"PBKDF2",salt:m,iterations:i,hash:{name:s}},w=await a.subtle.importKey("raw",g,{name:"PBKDF2"},!1,["deriveKey"]);p=await a.subtle.deriveKey(v,w,{name:t,length:e},!0,["encrypt"])}let b=await a.subtle.encrypt(h,p,f);return xt([m,h.iv,new Uint8Array(b)])}async function l(f,g){let m=f.subarray(0,o),d=f.subarray(o,o+n),h=f.subarray(o+n),p={name:t,iv:d};typeof g=="string"&&(g=et(g));let b;if(g.length===0)try{let w={name:"PBKDF2",salt:m,iterations:i,hash:{name:s}},A=await a.subtle.importKey("raw",g,{name:"PBKDF2"},!1,["deriveKey"]);b=await a.subtle.deriveKey(w,A,{name:t,length:e},!0,["decrypt"])}catch{b=await a.subtle.importKey("jwk",Wo,{name:"AES-GCM"},!0,["decrypt"])}else{let w={name:"PBKDF2",salt:m,iterations:i,hash:{name:s}},A=await a.subtle.importKey("raw",g,{name:"PBKDF2"},!1,["deriveKey"]);b=await a.subtle.deriveKey(w,A,{name:t,length:e},!0,["decrypt"])}let v=await a.subtle.decrypt(p,b,h);return new Uint8Array(v)}return{encrypt:c,decrypt:l}}async function Er(r,t){let n=await Uc().encrypt(r,t);return ko.encode(n)}var Pd=Math.pow(2,7),Dd=Math.pow(2,14),Vd=Math.pow(2,21),Yo=Math.pow(2,28),Zo=Math.pow(2,35),Xo=Math.pow(2,42),Jo=Math.pow(2,49),J=128,Nt=127;function dt(r){if(r<Pd)return 1;if(r<Dd)return 2;if(r<Vd)return 3;if(r<Yo)return 4;if(r<Zo)return 5;if(r<Xo)return 6;if(r<Jo)return 7;if(Number.MAX_SAFE_INTEGER!=null&&r>Number.MAX_SAFE_INTEGER)throw new RangeError("Could not encode varint");return 8}function Qo(r,t,e=0){switch(dt(r)){case 8:t[e++]=r&255|J,r/=128;case 7:t[e++]=r&255|J,r/=128;case 6:t[e++]=r&255|J,r/=128;case 5:t[e++]=r&255|J,r/=128;case 4:t[e++]=r&255|J,r>>>=7;case 3:t[e++]=r&255|J,r>>>=7;case 2:t[e++]=r&255|J,r>>>=7;case 1:{t[e++]=r&255,r>>>=7;break}default:throw new Error("unreachable")}return t}function Od(r,t,e=0){switch(dt(r)){case 8:t.set(e++,r&255|J),r/=128;case 7:t.set(e++,r&255|J),r/=128;case 6:t.set(e++,r&255|J),r/=128;case 5:t.set(e++,r&255|J),r/=128;case 4:t.set(e++,r&255|J),r>>>=7;case 3:t.set(e++,r&255|J),r>>>=7;case 2:t.set(e++,r&255|J),r>>>=7;case 1:{t.set(e++,r&255),r>>>=7;break}default:throw new Error("unreachable")}return t}function ti(r,t){let e=r[t],n=0;if(n+=e&Nt,e<J||(e=r[t+1],n+=(e&Nt)<<7,e<J)||(e=r[t+2],n+=(e&Nt)<<14,e<J)||(e=r[t+3],n+=(e&Nt)<<21,e<J)||(e=r[t+4],n+=(e&Nt)*Yo,e<J)||(e=r[t+5],n+=(e&Nt)*Zo,e<J)||(e=r[t+6],n+=(e&Nt)*Xo,e<J)||(e=r[t+7],n+=(e&Nt)*Jo,e<J))return n;throw new RangeError("Could not decode varint")}function Hd(r,t){let e=r.get(t),n=0;if(n+=e&Nt,e<J||(e=r.get(t+1),n+=(e&Nt)<<7,e<J)||(e=r.get(t+2),n+=(e&Nt)<<14,e<J)||(e=r.get(t+3),n+=(e&Nt)<<21,e<J)||(e=r.get(t+4),n+=(e&Nt)*Yo,e<J)||(e=r.get(t+5),n+=(e&Nt)*Zo,e<J)||(e=r.get(t+6),n+=(e&Nt)*Xo,e<J)||(e=r.get(t+7),n+=(e&Nt)*Jo,e<J))return n;throw new RangeError("Could not decode varint")}function ne(r,t,e=0){return t==null&&(t=wt(dt(r))),t instanceof Uint8Array?Qo(r,t,e):Od(r,t,e)}function Yt(r,t=0){return r instanceof Uint8Array?ti(r,t):Hd(r,t)}var ei=new Float32Array([-0]),De=new Uint8Array(ei.buffer);function Pc(r,t,e){ei[0]=r,t[e]=De[0],t[e+1]=De[1],t[e+2]=De[2],t[e+3]=De[3]}function Dc(r,t){return De[0]=r[t],De[1]=r[t+1],De[2]=r[t+2],De[3]=r[t+3],ei[0]}var ri=new Float64Array([-0]),Tt=new Uint8Array(ri.buffer);function Vc(r,t,e){ri[0]=r,t[e]=Tt[0],t[e+1]=Tt[1],t[e+2]=Tt[2],t[e+3]=Tt[3],t[e+4]=Tt[4],t[e+5]=Tt[5],t[e+6]=Tt[6],t[e+7]=Tt[7]}function Oc(r,t){return Tt[0]=r[t],Tt[1]=r[t+1],Tt[2]=r[t+2],Tt[3]=r[t+3],Tt[4]=r[t+4],Tt[5]=r[t+5],Tt[6]=r[t+6],Tt[7]=r[t+7],ri[0]}var Md=BigInt(Number.MAX_SAFE_INTEGER),Kd=BigInt(Number.MIN_SAFE_INTEGER),Vt=class r{lo;hi;constructor(t,e){this.lo=t|0,this.hi=e|0}toNumber(t=!1){if(!t&&this.hi>>>31>0){let e=~this.lo+1>>>0,n=~this.hi>>>0;return e===0&&(n=n+1>>>0),-(e+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 e=~this.lo+1>>>0,n=~this.hi>>>0;return e===0&&(n=n+1>>>0),-(BigInt(e)+(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,e=(this.lo>>>28|this.hi<<4)>>>0,n=this.hi>>>24;return n===0?e===0?t<16384?t<128?1:2:t<2097152?3:4:e<16384?e<128?5:6:e<2097152?7:8:n<128?9:10}static fromBigInt(t){if(t===0n)return Ze;if(t<Md&&t>Kd)return this.fromNumber(Number(t));let e=t<0n;e&&(t=-t);let n=t>>32n,s=t-(n<<32n);return e&&(n=~n|0n,s=~s|0n,++s>Hc&&(s=0n,++n>Hc&&(n=0n))),new r(Number(s),Number(n))}static fromNumber(t){if(t===0)return Ze;let e=t<0;e&&(t=-t);let n=t>>>0,s=(t-n)/4294967296>>>0;return e&&(s=~s>>>0,n=~n>>>0,++n>4294967295&&(n=0,++s>4294967295&&(s=0))),new r(n,s)}static from(t){return typeof t=="number"?r.fromNumber(t):typeof t=="bigint"?r.fromBigInt(t):typeof t=="string"?r.fromBigInt(BigInt(t)):t.low!=null||t.high!=null?new r(t.low>>>0,t.high>>>0):Ze}},Ze=new Vt(0,0);Ze.toBigInt=function(){return 0n};Ze.zzEncode=Ze.zzDecode=function(){return this};Ze.length=function(){return 1};var Hc=4294967296n;function Mc(r){let t=0,e=0;for(let n=0;n<r.length;++n)e=r.charCodeAt(n),e<128?t+=1:e<2048?t+=2:(e&64512)===55296&&(r.charCodeAt(n+1)&64512)===56320?(++n,t+=4):t+=3;return t}function Kc(r,t,e){if(e-t<1)return"";let s,o=[],i=0,a;for(;t<e;)a=r[t++],a<128?o[i++]=a:a>191&&a<224?o[i++]=(a&31)<<6|r[t++]&63:a>239&&a<365?(a=((a&7)<<18|(r[t++]&63)<<12|(r[t++]&63)<<6|r[t++]&63)-65536,o[i++]=55296+(a>>10),o[i++]=56320+(a&1023)):o[i++]=(a&15)<<12|(r[t++]&63)<<6|r[t++]&63,i>8191&&((s??(s=[])).push(String.fromCharCode.apply(String,o)),i=0);return s!=null?(i>0&&s.push(String.fromCharCode.apply(String,o.slice(0,i))),s.join("")):String.fromCharCode.apply(String,o.slice(0,i))}function ni(r,t,e){let n=e,s,o;for(let i=0;i<r.length;++i)s=r.charCodeAt(i),s<128?t[e++]=s:s<2048?(t[e++]=s>>6|192,t[e++]=s&63|128):(s&64512)===55296&&((o=r.charCodeAt(i+1))&64512)===56320?(s=65536+((s&1023)<<10)+(o&1023),++i,t[e++]=s>>18|240,t[e++]=s>>12&63|128,t[e++]=s>>6&63|128,t[e++]=s&63|128):(t[e++]=s>>12|224,t[e++]=s>>6&63|128,t[e++]=s&63|128);return e-n}function Zt(r,t){return RangeError(`index out of range: ${r.pos} + ${t??1} > ${r.len}`)}function On(r,t){return(r[t-4]|r[t-3]<<8|r[t-2]<<16|r[t-1]<<24)>>>0}var si=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,Zt(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 Zt(this,4);return On(this.buf,this.pos+=4)}sfixed32(){if(this.pos+4>this.len)throw Zt(this,4);return On(this.buf,this.pos+=4)|0}float(){if(this.pos+4>this.len)throw Zt(this,4);let t=Dc(this.buf,this.pos);return this.pos+=4,t}double(){if(this.pos+8>this.len)throw Zt(this,4);let t=Oc(this.buf,this.pos);return this.pos+=8,t}bytes(){let t=this.uint32(),e=this.pos,n=this.pos+t;if(n>this.len)throw Zt(this,t);return this.pos+=t,e===n?new Uint8Array(0):this.buf.subarray(e,n)}string(){let t=this.bytes();return Kc(t,0,t.length)}skip(t){if(typeof t=="number"){if(this.pos+t>this.len)throw Zt(this,t);this.pos+=t}else do if(this.pos>=this.len)throw Zt(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 Vt(0,0),e=0;if(this.len-this.pos>4){for(;e<4;++e)if(t.lo=(t.lo|(this.buf[this.pos]&127)<<e*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;e=0}else{for(;e<3;++e){if(this.pos>=this.len)throw Zt(this);if(t.lo=(t.lo|(this.buf[this.pos]&127)<<e*7)>>>0,this.buf[this.pos++]<128)return t}return t.lo=(t.lo|(this.buf[this.pos++]&127)<<e*7)>>>0,t}if(this.len-this.pos>4){for(;e<5;++e)if(t.hi=(t.hi|(this.buf[this.pos]&127)<<e*7+3)>>>0,this.buf[this.pos++]<128)return t}else for(;e<5;++e){if(this.pos>=this.len)throw Zt(this);if(t.hi=(t.hi|(this.buf[this.pos]&127)<<e*7+3)>>>0,this.buf[this.pos++]<128)return t}throw Error("invalid varint encoding")}readFixed64(){if(this.pos+8>this.len)throw Zt(this,8);let t=On(this.buf,this.pos+=4),e=On(this.buf,this.pos+=4);return new Vt(t,e)}int64(){return this.readLongVarint().toBigInt()}int64Number(){return this.readLongVarint().toNumber()}int64String(){return this.readLongVarint().toString()}uint64(){return this.readLongVarint().toBigInt(!0)}uint64Number(){let t=ti(this.buf,this.pos);return this.pos+=dt(t),t}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 oi(r){return new si(r instanceof Uint8Array?r:r.subarray())}function Xe(r,t,e){let n=oi(r);return t.decode(n,void 0,e)}function ii(r){let t=r??8192,e=t>>>1,n,s=t;return function(i){if(i<1||i>e)return wt(i);s+i>t&&(n=wt(t),s=0);let a=n.subarray(s,s+=i);return s&7&&(s=(s|7)+1),a}}var Je=class{fn;len;next;val;constructor(t,e,n){this.fn=t,this.len=e,this.next=void 0,this.val=n}};function ai(){}var li=class{head;tail;len;next;constructor(t){this.head=t.head,this.tail=t.tail,this.len=t.len,this.next=t.states}},Fd=ii();function $d(r){return globalThis.Buffer!=null?wt(r):Fd(r)}var Qr=class{len;head;tail;states;constructor(){this.len=0,this.head=new Je(ai,0,0),this.tail=this.head,this.states=null}_push(t,e,n){return this.tail=this.tail.next=new Je(t,e,n),this.len+=e,this}uint32(t){return this.len+=(this.tail=this.tail.next=new ui((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(Hn,10,Vt.fromNumber(t)):this.uint32(t)}sint32(t){return this.uint32((t<<1^t>>31)>>>0)}uint64(t){let e=Vt.fromBigInt(t);return this._push(Hn,e.length(),e)}uint64Number(t){return this._push(Qo,dt(t),t)}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 e=Vt.fromBigInt(t).zzEncode();return this._push(Hn,e.length(),e)}sint64Number(t){let e=Vt.fromNumber(t).zzEncode();return this._push(Hn,e.length(),e)}sint64String(t){return this.sint64(BigInt(t))}bool(t){return this._push(ci,1,t?1:0)}fixed32(t){return this._push(Jr,4,t>>>0)}sfixed32(t){return this.fixed32(t)}fixed64(t){let e=Vt.fromBigInt(t);return this._push(Jr,4,e.lo)._push(Jr,4,e.hi)}fixed64Number(t){let e=Vt.fromNumber(t);return this._push(Jr,4,e.lo)._push(Jr,4,e.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(Pc,4,t)}double(t){return this._push(Vc,8,t)}bytes(t){let e=t.length>>>0;return e===0?this._push(ci,1,0):this.uint32(e)._push(Gd,e,t)}string(t){let e=Mc(t);return e!==0?this.uint32(e)._push(ni,e,t):this._push(ci,1,0)}fork(){return this.states=new li(this),this.head=this.tail=new Je(ai,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 Je(ai,0,0),this.len=0),this}ldelim(){let t=this.head,e=this.tail,n=this.len;return this.reset().uint32(n),n!==0&&(this.tail.next=t.next,this.tail=e,this.len+=n),this}finish(){let t=this.head.next,e=$d(this.len),n=0;for(;t!=null;)t.fn(t.val,e,n),n+=t.len,t=t.next;return e}};function ci(r,t,e){t[e]=r&255}function qd(r,t,e){for(;r>127;)t[e++]=r&127|128,r>>>=7;t[e]=r}var ui=class extends Je{next;constructor(t,e){super(qd,t,e),this.next=void 0}};function Hn(r,t,e){for(;r.hi!==0;)t[e++]=r.lo&127|128,r.lo=(r.lo>>>7|r.hi<<25)>>>0,r.hi>>>=7;for(;r.lo>127;)t[e++]=r.lo&127|128,r.lo=r.lo>>>7;t[e++]=r.lo}function Jr(r,t,e){t[e]=r&255,t[e+1]=r>>>8&255,t[e+2]=r>>>16&255,t[e+3]=r>>>24}function Gd(r,t,e){t.set(r,e)}globalThis.Buffer!=null&&(Qr.prototype.bytes=function(r){let t=r.length>>>0;return this.uint32(t),t>0&&this._push(jd,t,r),this},Qr.prototype.string=function(r){let t=globalThis.Buffer.byteLength(r);return this.uint32(t),t>0&&this._push(zd,t,r),this});function jd(r,t,e){t.set(r,e)}function zd(r,t,e){r.length<40?ni(r,t,e):t.utf8Write!=null?t.utf8Write(r,e):t.set(et(r),e)}function fi(){return new Qr}function Qe(r,t){let e=fi();return t.encode(r,e,{lengthDelimited:!1}),e.finish()}var vr;(function(r){r[r.VARINT=0]="VARINT",r[r.BIT64=1]="BIT64",r[r.LENGTH_DELIMITED=2]="LENGTH_DELIMITED",r[r.START_GROUP=3]="START_GROUP",r[r.END_GROUP=4]="END_GROUP",r[r.BIT32=5]="BIT32"})(vr||(vr={}));function Mn(r,t,e,n){return{name:r,type:t,encode:e,decode:n}}function hi(r){function t(s){if(r[s.toString()]==null)throw new Error("Invalid enum value");return r[s]}let e=function(o,i){let a=t(o);i.int32(a)},n=function(o){let i=o.int32();return t(i)};return Mn("enum",vr.VARINT,e,n)}function tr(r,t){return Mn("message",vr.LENGTH_DELIMITED,r,t)}var at;(function(r){r.RSA="RSA",r.Ed25519="Ed25519",r.Secp256k1="Secp256k1"})(at||(at={}));var di;(function(r){r[r.RSA=0]="RSA",r[r.Ed25519=1]="Ed25519",r[r.Secp256k1=2]="Secp256k1"})(di||(di={}));(function(r){r.codec=()=>hi(di)})(at||(at={}));var se;(function(r){let t;r.codec=()=>(t==null&&(t=tr((e,n,s={})=>{s.lengthDelimited!==!1&&n.fork(),e.Type!=null&&(n.uint32(8),at.codec().encode(e.Type,n)),e.Data!=null&&(n.uint32(18),n.bytes(e.Data)),s.lengthDelimited!==!1&&n.ldelim()},(e,n)=>{let s={},o=n==null?e.len:e.pos+n;for(;e.pos<o;){let i=e.uint32();switch(i>>>3){case 1:s.Type=at.codec().decode(e);break;case 2:s.Data=e.bytes();break;default:e.skipType(i&7);break}}return s})),t),r.encode=e=>Qe(e,r.codec()),r.decode=e=>Xe(e,r.codec())})(se||(se={}));var oe;(function(r){let t;r.codec=()=>(t==null&&(t=tr((e,n,s={})=>{s.lengthDelimited!==!1&&n.fork(),e.Type!=null&&(n.uint32(8),at.codec().encode(e.Type,n)),e.Data!=null&&(n.uint32(18),n.bytes(e.Data)),s.lengthDelimited!==!1&&n.ldelim()},(e,n)=>{let s={},o=n==null?e.len:e.pos+n;for(;e.pos<o;){let i=e.uint32();switch(i>>>3){case 1:s.Type=at.codec().decode(e);break;case 2:s.Data=e.bytes();break;default:e.skipType(i&7);break}}return s})),t),r.encode=e=>Qe(e,r.codec()),r.decode=e=>Xe(e,r.codec())})(oe||(oe={}));var tn=class{_key;constructor(t){this._key=Br(t,xr)}verify(t,e){return Lc(this._key,e,t)}marshal(){return this._key}get bytes(){return se.encode({Type:at.Ed25519,Data:this.marshal()}).subarray()}equals(t){return ft(this.bytes,t.bytes)}hash(){let t=At.digest(this.bytes);return Ht(t)?t.then(({bytes:e})=>e):t.bytes}},er=class{_key;_publicKey;constructor(t,e){this._key=Br(t,be),this._publicKey=Br(e,xr)}sign(t){return Rc(this._key,t)}get public(){return new tn(this._publicKey)}marshal(){return this._key}get bytes(){return oe.encode({Type:at.Ed25519,Data:this.marshal()}).subarray()}equals(t){return ft(this.bytes,t.bytes)}async hash(){let t=At.digest(this.bytes),e;return Ht(t)?{bytes:e}=await t:e=t.bytes,e}async id(){let t=Te.digest(this.public.bytes);return ut.encode(t.bytes).substring(1)}async export(t,e="libp2p-key"){if(e==="libp2p-key")return Er(this.bytes,t);throw new F(`export format '${e}' is not supported`,"ERR_INVALID_EXPORT_FORMAT")}};function Wd(r){if(r.length>be){r=Br(r,be+xr);let n=r.subarray(0,be),s=r.subarray(be,r.length);return new er(n,s)}r=Br(r,be);let t=r.subarray(0,be),e=r.subarray(xr);return new er(t,e)}function Yd(r){return r=Br(r,xr),new tn(r)}async function Zd(){let{privateKey:r,publicKey:t}=Nc();return new er(r,t)}async function $c(r){let{privateKey:t,publicKey:e}=Tc(r);return new er(t,e)}function Br(r,t){if(r=Uint8Array.from(r??[]),r.length!==t)throw new F(`Key must be a Uint8Array of length ${t}, got ${r.length}`,"ERR_INVALID_KEY_TYPE");return r}function q(r,t="utf8"){let e=Sn[t];if(e==null)throw new Error(`Unsupported encoding "${t}"`);return e.encoder.encode(r).substring(1)}var Ai={};yt(Ai,{MAX_RSA_KEY_SIZE:()=>hn,RsaPrivateKey:()=>_r,RsaPublicKey:()=>fn,fromJwk:()=>B0,generateKeyPair:()=>A0,unmarshalRsaPrivateKey:()=>vi,unmarshalRsaPublicKey:()=>v0});function rr(r){if(isNaN(r)||r<=0)throw new F("random bytes length must be a Number bigger than 0","ERR_INVALID_LENGTH");return ze(r)}var Ke={};yt(Ke,{exportToPem:()=>m0,importFromPem:()=>w0,jwkToPkcs1:()=>d0,jwkToPkix:()=>g0,pkcs1ToJwk:()=>h0,pkixToJwk:()=>p0});var Fn=class extends pr{constructor(t,e){super(),this.finished=!1,this.destroyed=!1,je(t);let n=jt(e);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 s=this.blockLen,o=new Uint8Array(s);o.set(n.length>s?t.create().update(n).digest():n);for(let i=0;i<o.length;i++)o[i]^=54;this.iHash.update(o),this.oHash=t.create();for(let i=0;i<o.length;i++)o[i]^=106;this.oHash.update(o),o.fill(0)}update(t){return dr(this),this.iHash.update(t),this}digestInto(t){dr(this),hr(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:e,iHash:n,finished:s,destroyed:o,blockLen:i,outputLen:a}=this;return t=t,t.finished=s,t.destroyed=o,t.blockLen=i,t.outputLen=a,t.oHash=e._cloneInto(t.oHash),t.iHash=n._cloneInto(t.iHash),t}destroy(){this.destroyed=!0,this.oHash.destroy(),this.iHash.destroy()}},Ve=(r,t,e)=>new Fn(r,t).update(e).digest();Ve.create=(r,t)=>new Fn(r,t);function Xd(r,t,e,n){je(r);let s=cc({dkLen:32,asyncTick:10},n),{c:o,dkLen:i,asyncTick:a}=s;if(Re(o),Re(i),Re(a),o<1)throw new Error("PBKDF2: iterations (c) should be >= 1");let c=jt(t),l=jt(e),u=new Uint8Array(i),f=Ve.create(r,c),g=f._cloneInto().update(l);return{c:o,dkLen:i,asyncTick:a,DK:u,PRF:f,PRFSalt:g}}function Jd(r,t,e,n,s){return r.destroy(),t.destroy(),n&&n.destroy(),s.fill(0),e}async function gi(r,t,e,n){let{c:s,dkLen:o,asyncTick:i,DK:a,PRF:c,PRFSalt:l}=Xd(r,t,e,n),u,f=new Uint8Array(4),g=gr(f),m=new Uint8Array(c.outputLen);for(let d=1,h=0;h<o;d++,h+=c.outputLen){let p=a.subarray(h,h+c.outputLen);g.setInt32(0,d,!1),(u=l._cloneInto(u)).update(f).digestInto(m),p.set(m.subarray(0,p.length)),await ac(s-1,i,()=>{c._cloneInto(u).update(m).digestInto(m);for(let b=0;b<p.length;b++)p[b]^=m[b]})}return Jd(c,l,a,u,m)}var Y=Va(qc());function nr(r,t){let e=0;if(r.length===1)return r[0];for(let n=r.length-1;n>=0;n--)e+=r[r.length-1-n]*Math.pow(2,t*n);return e}function Oe(r,t,e=-1){let n=e,s=r,o=0,i=Math.pow(2,t);for(let a=1;a<8;a++){if(r<i){let c;if(n<0)c=new ArrayBuffer(a),o=a;else{if(n<a)return new ArrayBuffer(0);c=new ArrayBuffer(n),o=n}let l=new Uint8Array(c);for(let u=a-1;u>=0;u--){let f=Math.pow(2,u*t);l[o-u-1]=Math.floor(s/f),s-=l[o-u-1]*f}return c}i*=Math.pow(2,t)}return new ArrayBuffer(0)}function Gn(...r){let t=0,e=0;for(let o of r)t+=o.length;let n=new ArrayBuffer(t),s=new Uint8Array(n);for(let o of r)s.set(o,e),e+=o.length;return s}function mi(){let r=new Uint8Array(this.valueHex);if(this.valueHex.byteLength>=2){let a=r[0]===255&&r[1]&128,c=r[0]===0&&(r[1]&128)===0;(a||c)&&this.warnings.push("Needlessly long format")}let t=new ArrayBuffer(this.valueHex.byteLength),e=new Uint8Array(t);for(let a=0;a<this.valueHex.byteLength;a++)e[a]=0;e[0]=r[0]&128;let n=nr(e,8),s=new ArrayBuffer(this.valueHex.byteLength),o=new Uint8Array(s);for(let a=0;a<this.valueHex.byteLength;a++)o[a]=r[a];return o[0]&=127,nr(o,8)-n}function Gc(r){let t=r<0?r*-1:r,e=128;for(let n=1;n<8;n++){if(t<=e){if(r<0){let i=e-t,a=Oe(i,8,n),c=new Uint8Array(a);return c[0]|=128,a}let s=Oe(t,8,n),o=new Uint8Array(s);if(o[0]&128){let i=s.slice(0),a=new Uint8Array(i);s=new ArrayBuffer(s.byteLength+1),o=new Uint8Array(s);for(let c=0;c<i.byteLength;c++)o[c+1]=a[c];o[0]=0}return s}e*=Math.pow(2,8)}return new ArrayBuffer(0)}function jc(r,t){if(r.byteLength!==t.byteLength)return!1;let e=new Uint8Array(r),n=new Uint8Array(t);for(let s=0;s<e.length;s++)if(e[s]!==n[s])return!1;return!0}function Pt(r,t){let e=r.toString(10);if(t<e.length)return"";let n=t-e.length,s=new Array(n);for(let i=0;i<n;i++)s[i]="0";return s.join("").concat(e)}var Gm=Math.log(2);function jn(){if(typeof BigInt>"u")throw new Error("BigInt is not defined. Your environment doesn't implement BigInt.")}function wi(r){let t=0,e=0;for(let s=0;s<r.length;s++){let o=r[s];t+=o.byteLength}let n=new Uint8Array(t);for(let s=0;s<r.length;s++){let o=r[s];n.set(new Uint8Array(o),e),e+=o.byteLength}return n.buffer}function Ae(r,t,e,n){return t instanceof Uint8Array?t.byteLength?e<0?(r.error="Wrong parameter: inputOffset less than zero",!1):n<0?(r.error="Wrong parameter: inputLength less than zero",!1):t.byteLength-e-n<0?(r.error="End of input reached before message was fully decoded (inconsistent offset and length values)",!1):!0:(r.error="Wrong parameter: inputBuffer has zero length",!1):(r.error="Wrong parameter: inputBuffer must be 'Uint8Array'",!1)}var rn=class{constructor(){this.items=[]}write(t){this.items.push(t)}final(){return wi(this.items)}},en=[new Uint8Array([1])],zc="0123456789";var kr="",Jt=new ArrayBuffer(0),bi=new Uint8Array(0),nn="EndOfContent",Yc="OCTET STRING",Zc="BIT STRING";function Se(r){var t;return t=class extends r{constructor(...n){var s;super(...n);let o=n[0]||{};this.isHexOnly=(s=o.isHexOnly)!==null&&s!==void 0?s:!1,this.valueHexView=o.valueHex?Y.BufferSourceConverter.toUint8Array(o.valueHex):bi}get valueHex(){return this.valueHexView.slice().buffer}set valueHex(n){this.valueHexView=new Uint8Array(n)}fromBER(n,s,o){let i=n instanceof ArrayBuffer?new Uint8Array(n):n;if(!Ae(this,i,s,o))return-1;let a=s+o;return this.valueHexView=i.subarray(s,a),this.valueHexView.length?(this.blockLength=o,a):(this.warnings.push("Zero buffer length"),s)}toBER(n=!1){return this.isHexOnly?n?new ArrayBuffer(this.valueHexView.byteLength):this.valueHexView.byteLength===this.valueHexView.buffer.byteLength?this.valueHexView.buffer:this.valueHexView.slice().buffer:(this.error="Flag 'isHexOnly' is not set, abort",Jt)}toJSON(){return{...super.toJSON(),isHexOnly:this.isHexOnly,valueHex:Y.Convert.ToHex(this.valueHexView)}}},t.NAME="hexBlock",t}var Ee=class{constructor({blockLength:t=0,error:e=kr,warnings:n=[],valueBeforeDecode:s=bi}={}){this.blockLength=t,this.error=e,this.warnings=n,this.valueBeforeDecodeView=Y.BufferSourceConverter.toUint8Array(s)}static blockName(){return this.NAME}get valueBeforeDecode(){return this.valueBeforeDecodeView.slice().buffer}set valueBeforeDecode(t){this.valueBeforeDecodeView=new Uint8Array(t)}toJSON(){return{blockName:this.constructor.NAME,blockLength:this.blockLength,error:this.error,warnings:this.warnings,valueBeforeDecode:Y.Convert.ToHex(this.valueBeforeDecodeView)}}};Ee.NAME="baseBlock";var Rt=class extends Ee{fromBER(t,e,n){throw TypeError("User need to make a specific function in a class which extends 'ValueBlock'")}toBER(t,e){throw TypeError("User need to make a specific function in a class which extends 'ValueBlock'")}};Rt.NAME="valueBlock";var zn=class extends Se(Ee){constructor({idBlock:t={}}={}){var e,n,s,o;super(),t?(this.isHexOnly=(e=t.isHexOnly)!==null&&e!==void 0?e:!1,this.valueHexView=t.valueHex?Y.BufferSourceConverter.toUint8Array(t.valueHex):bi,this.tagClass=(n=t.tagClass)!==null&&n!==void 0?n:-1,this.tagNumber=(s=t.tagNumber)!==null&&s!==void 0?s:-1,this.isConstructed=(o=t.isConstructed)!==null&&o!==void 0?o:!1):(this.tagClass=-1,this.tagNumber=-1,this.isConstructed=!1)}toBER(t=!1){let e=0;switch(this.tagClass){case 1:e|=0;break;case 2:e|=64;break;case 3:e|=128;break;case 4:e|=192;break;default:return this.error="Unknown tag class",Jt}if(this.isConstructed&&(e|=32),this.tagNumber<31&&!this.isHexOnly){let s=new Uint8Array(1);if(!t){let o=this.tagNumber;o&=31,e|=o,s[0]=e}return s.buffer}if(!this.isHexOnly){let s=Oe(this.tagNumber,7),o=new Uint8Array(s),i=s.byteLength,a=new Uint8Array(i+1);if(a[0]=e|31,!t){for(let c=0;c<i-1;c++)a[c+1]=o[c]|128;a[i]=o[i-1]}return a.buffer}let n=new Uint8Array(this.valueHexView.byteLength+1);if(n[0]=e|31,!t){let s=this.valueHexView;for(let o=0;o<s.length-1;o++)n[o+1]=s[o]|128;n[this.valueHexView.byteLength]=s[s.length-1]}return n.buffer}fromBER(t,e,n){let s=Y.BufferSourceConverter.toUint8Array(t);if(!Ae(this,s,e,n))return-1;let o=s.subarray(e,e+n);if(o.length===0)return this.error="Zero buffer length",-1;switch(o[0]&192){case 0:this.tagClass=1;break;case 64:this.tagClass=2;break;case 128:this.tagClass=3;break;case 192:this.tagClass=4;break;default:return this.error="Unknown tag class",-1}this.isConstructed=(o[0]&32)===32,this.isHexOnly=!1;let a=o[0]&31;if(a!==31)this.tagNumber=a,this.blockLength=1;else{let c=1,l=this.valueHexView=new Uint8Array(255),u=255;for(;o[c]&128;){if(l[c-1]=o[c]&127,c++,c>=o.length)return this.error="End of input reached before message was fully decoded",-1;if(c===u){u+=255;let g=new Uint8Array(u);for(let m=0;m<l.length;m++)g[m]=l[m];l=this.valueHexView=new Uint8Array(u)}}this.blockLength=c+1,l[c-1]=o[c]&127;let f=new Uint8Array(c);for(let g=0;g<c;g++)f[g]=l[g];l=this.valueHexView=new Uint8Array(c),l.set(f),this.blockLength<=9?this.tagNumber=nr(l,7):(this.isHexOnly=!0,this.warnings.push("Tag too long, represented as hex-coded"))}if(this.tagClass===1&&this.isConstructed)switch(this.tagNumber){case 1:case 2:case 5:case 6:case 9:case 13:case 14:case 23:case 24:case 31:case 32:case 33:case 34:return this.error="Constructed encoding used for primitive type",-1}return e+this.blockLength}toJSON(){return{...super.toJSON(),tagClass:this.tagClass,tagNumber:this.tagNumber,isConstructed:this.isConstructed}}};zn.NAME="identificationBlock";var Wn=class extends Ee{constructor({lenBlock:t={}}={}){var e,n,s;super(),this.isIndefiniteForm=(e=t.isIndefiniteForm)!==null&&e!==void 0?e:!1,this.longFormUsed=(n=t.longFormUsed)!==null&&n!==void 0?n:!1,this.length=(s=t.length)!==null&&s!==void 0?s:0}fromBER(t,e,n){let s=Y.BufferSourceConverter.toUint8Array(t);if(!Ae(this,s,e,n))return-1;let o=s.subarray(e,e+n);if(o.length===0)return this.error="Zero buffer length",-1;if(o[0]===255)return this.error="Length block 0xFF is reserved by standard",-1;if(this.isIndefiniteForm=o[0]===128,this.isIndefiniteForm)return this.blockLength=1,e+this.blockLength;if(this.longFormUsed=!!(o[0]&128),this.longFormUsed===!1)return this.length=o[0],this.blockLength=1,e+this.blockLength;let i=o[0]&127;if(i>8)return this.error="Too big integer",-1;if(i+1>o.length)return this.error="End of input reached before message was fully decoded",-1;let a=e+1,c=s.subarray(a,a+i);return c[i-1]===0&&this.warnings.push("Needlessly long encoded length"),this.length=nr(c,8),this.longFormUsed&&this.length<=127&&this.warnings.push("Unnecessary usage of long length form"),this.blockLength=i+1,e+this.blockLength}toBER(t=!1){let e,n;if(this.length>127&&(this.longFormUsed=!0),this.isIndefiniteForm)return e=new ArrayBuffer(1),t===!1&&(n=new Uint8Array(e),n[0]=128),e;if(this.longFormUsed){let s=Oe(this.length,8);if(s.byteLength>127)return this.error="Too big length",Jt;if(e=new ArrayBuffer(s.byteLength+1),t)return e;let o=new Uint8Array(s);n=new Uint8Array(e),n[0]=s.byteLength|128;for(let i=0;i<s.byteLength;i++)n[i+1]=o[i];return e}return e=new ArrayBuffer(1),t===!1&&(n=new Uint8Array(e),n[0]=this.length),e}toJSON(){return{...super.toJSON(),isIndefiniteForm:this.isIndefiniteForm,longFormUsed:this.longFormUsed,length:this.length}}};Wn.NAME="lengthBlock";var U={},St=class extends Ee{constructor({name:t=kr,optional:e=!1,primitiveSchema:n,...s}={},o){super(s),this.name=t,this.optional=e,n&&(this.primitiveSchema=n),this.idBlock=new zn(s),this.lenBlock=new Wn(s),this.valueBlock=o?new o(s):new Rt(s)}fromBER(t,e,n){let s=this.valueBlock.fromBER(t,e,this.lenBlock.isIndefiniteForm?n:this.lenBlock.length);return s===-1?(this.error=this.valueBlock.error,s):(this.idBlock.error.length||(this.blockLength+=this.idBlock.blockLength),this.lenBlock.error.length||(this.blockLength+=this.lenBlock.blockLength),this.valueBlock.error.length||(this.blockLength+=this.valueBlock.blockLength),s)}toBER(t,e){let n=e||new rn;e||Xc(this);let s=this.idBlock.toBER(t);if(n.write(s),this.lenBlock.isIndefiniteForm)n.write(new Uint8Array([128]).buffer),this.valueBlock.toBER(t,n),n.write(new ArrayBuffer(2));else{let o=this.valueBlock.toBER(t);this.lenBlock.length=o.byteLength;let i=this.lenBlock.toBER(t);n.write(i),n.write(o)}return e?Jt:n.final()}toJSON(){let t={...super.toJSON(),idBlock:this.idBlock.toJSON(),lenBlock:this.lenBlock.toJSON(),valueBlock:this.valueBlock.toJSON(),name:this.name,optional:this.optional};return this.primitiveSchema&&(t.primitiveSchema=this.primitiveSchema.toJSON()),t}toString(t="ascii"){return t==="ascii"?this.onAsciiEncoding():Y.Convert.ToHex(this.toBER())}onAsciiEncoding(){return`${this.constructor.NAME} : ${Y.Convert.ToHex(this.valueBlock.valueBeforeDecodeView)}`}isEqual(t){if(this===t)return!0;if(!(t instanceof this.constructor))return!1;let e=this.toBER(),n=t.toBER();return jc(e,n)}};St.NAME="BaseBlock";function Xc(r){if(r instanceof U.Constructed)for(let t of r.valueBlock.value)Xc(t)&&(r.lenBlock.isIndefiniteForm=!0);return!!r.lenBlock.isIndefiniteForm}var Yn=class extends St{constructor({value:t=kr,...e}={},n){super(e,n),t&&this.fromString(t)}getValue(){return this.valueBlock.value}setValue(t){this.valueBlock.value=t}fromBER(t,e,n){let s=this.valueBlock.fromBER(t,e,this.lenBlock.isIndefiniteForm?n:this.lenBlock.length);return s===-1?(this.error=this.valueBlock.error,s):(this.fromBuffer(this.valueBlock.valueHexView),this.idBlock.error.length||(this.blockLength+=this.idBlock.blockLength),this.lenBlock.error.length||(this.blockLength+=this.lenBlock.blockLength),this.valueBlock.error.length||(this.blockLength+=this.valueBlock.blockLength),s)}onAsciiEncoding(){return`${this.constructor.NAME} : '${this.valueBlock.value}'`}};Yn.NAME="BaseStringBlock";var Zn=class extends Se(Rt){constructor({isHexOnly:t=!0,...e}={}){super(e),this.isHexOnly=t}};Zn.NAME="PrimitiveValueBlock";var Jc,Xn=class extends St{constructor(t={}){super(t,Zn),this.idBlock.isConstructed=!1}};Jc=Xn;U.Primitive=Jc;Xn.NAME="PRIMITIVE";function a0(r,t){if(r instanceof t)return r;let e=new t;return e.idBlock=r.idBlock,e.lenBlock=r.lenBlock,e.warnings=r.warnings,e.valueBeforeDecodeView=r.valueBeforeDecodeView,e}function Ts(r,t=0,e=r.length){let n=t,s=new St({},Rt),o=new Ee;if(!Ae(o,r,t,e))return s.error=o.error,{offset:-1,result:s};if(!r.subarray(t,t+e).length)return s.error="Zero buffer length",{offset:-1,result:s};let a=s.idBlock.fromBER(r,t,e);if(s.idBlock.warnings.length&&s.warnings.concat(s.idBlock.warnings),a===-1)return s.error=s.idBlock.error,{offset:-1,result:s};if(t=a,e-=s.idBlock.blockLength,a=s.lenBlock.fromBER(r,t,e),s.lenBlock.warnings.length&&s.warnings.concat(s.lenBlock.warnings),a===-1)return s.error=s.lenBlock.error,{offset:-1,result:s};if(t=a,e-=s.lenBlock.blockLength,!s.idBlock.isConstructed&&s.lenBlock.isIndefiniteForm)return s.error="Indefinite length form used for primitive encoding form",{offset:-1,result:s};let c=St;switch(s.idBlock.tagClass){case 1:if(s.idBlock.tagNumber>=37&&s.idBlock.isHexOnly===!1)return s.error="UNIVERSAL 37 and upper tags are reserved by ASN.1 standard",{offset:-1,result:s};switch(s.idBlock.tagNumber){case 0:if(s.idBlock.isConstructed&&s.lenBlock.length>0)return s.error="Type [UNIVERSAL 0] is reserved",{offset:-1,result:s};c=U.EndOfContent;break;case 1:c=U.Boolean;break;case 2:c=U.Integer;break;case 3:c=U.BitString;break;case 4:c=U.OctetString;break;case 5:c=U.Null;break;case 6:c=U.ObjectIdentifier;break;case 10:c=U.Enumerated;break;case 12:c=U.Utf8String;break;case 13:c=U.RelativeObjectIdentifier;break;case 14:c=U.TIME;break;case 15:return s.error="[UNIVERSAL 15] is reserved by ASN.1 standard",{offset:-1,result:s};case 16:c=U.Sequence;break;case 17:c=U.Set;break;case 18:c=U.NumericString;break;case 19:c=U.PrintableString;break;case 20:c=U.TeletexString;break;case 21:c=U.VideotexString;break;case 22:c=U.IA5String;break;case 23:c=U.UTCTime;break;case 24:c=U.GeneralizedTime;break;case 25:c=U.GraphicString;break;case 26:c=U.VisibleString;break;case 27:c=U.GeneralString;break;case 28:c=U.UniversalString;break;case 29:c=U.CharacterString;break;case 30:c=U.BmpString;break;case 31:c=U.DATE;break;case 32:c=U.TimeOfDay;break;case 33:c=U.DateTime;break;case 34:c=U.Duration;break;default:{let l=s.idBlock.isConstructed?new U.Constructed:new U.Primitive;l.idBlock=s.idBlock,l.lenBlock=s.lenBlock,l.warnings=s.warnings,s=l}}break;case 2:case 3:case 4:default:c=s.idBlock.isConstructed?U.Constructed:U.Primitive}return s=a0(s,c),a=s.fromBER(r,t,s.lenBlock.isIndefiniteForm?e:s.lenBlock.length),s.valueBeforeDecodeView=r.subarray(n,n+s.blockLength),{offset:a,result:s}}function Ir(r){if(!r.byteLength){let t=new St({},Rt);return t.error="Input buffer has zero length",{offset:-1,result:t}}return Ts(Y.BufferSourceConverter.toUint8Array(r).slice(),0,r.byteLength)}function c0(r,t){return r?1:t}var ie=class extends Rt{constructor({value:t=[],isIndefiniteForm:e=!1,...n}={}){super(n),this.value=t,this.isIndefiniteForm=e}fromBER(t,e,n){let s=Y.BufferSourceConverter.toUint8Array(t);if(!Ae(this,s,e,n))return-1;if(this.valueBeforeDecodeView=s.subarray(e,e+n),this.valueBeforeDecodeView.length===0)return this.warnings.push("Zero buffer length"),e;let o=e;for(;c0(this.isIndefiniteForm,n)>0;){let i=Ts(s,o,n);if(i.offset===-1)return this.error=i.result.error,this.warnings.concat(i.result.warnings),-1;if(o=i.offset,this.blockLength+=i.result.blockLength,n-=i.result.blockLength,this.value.push(i.result),this.isIndefiniteForm&&i.result.constructor.NAME===nn)break}return this.isIndefiniteForm&&(this.value[this.value.length-1].constructor.NAME===nn?this.value.pop():this.warnings.push("No EndOfContent block encoded")),o}toBER(t,e){let n=e||new rn;for(let s=0;s<this.value.length;s++)this.value[s].toBER(t,n);return e?Jt:n.final()}toJSON(){let t={...super.toJSON(),isIndefiniteForm:this.isIndefiniteForm,value:[]};for(let e of this.value)t.value.push(e.toJSON());return t}};ie.NAME="ConstructedValueBlock";var Qc,He=class extends St{constructor(t={}){super(t,ie),this.idBlock.isConstructed=!0}fromBER(t,e,n){this.valueBlock.isIndefiniteForm=this.lenBlock.isIndefiniteForm;let s=this.valueBlock.fromBER(t,e,this.lenBlock.isIndefiniteForm?n:this.lenBlock.length);return s===-1?(this.error=this.valueBlock.error,s):(this.idBlock.error.length||(this.blockLength+=this.idBlock.blockLength),this.lenBlock.error.length||(this.blockLength+=this.lenBlock.blockLength),this.valueBlock.error.length||(this.blockLength+=this.valueBlock.blockLength),s)}onAsciiEncoding(){let t=[];for(let n of this.valueBlock.value)t.push(n.toString("ascii").split(`
2
+ "use strict";var Libp2PWebtransport=(()=>{var bf=Object.create;var Bn=Object.defineProperty;var xf=Object.getOwnPropertyDescriptor;var Ef=Object.getOwnPropertyNames;var vf=Object.getPrototypeOf,Bf=Object.prototype.hasOwnProperty;var Da=(r,t)=>()=>(t||r((t={exports:{}}).exports,t),t.exports),yt=(r,t)=>{for(var e in t)Bn(r,e,{get:t[e],enumerable:!0})},Va=(r,t,e,n)=>{if(t&&typeof t=="object"||typeof t=="function")for(let s of Ef(t))!Bf.call(r,s)&&s!==e&&Bn(r,s,{get:()=>t[s],enumerable:!(n=xf(t,s))||n.enumerable});return r};var Oa=(r,t,e)=>(e=r!=null?bf(vf(r)):{},Va(t||!r||!r.__esModule?Bn(e,"default",{value:r,enumerable:!0}):e,r)),Af=r=>Va(Bn({},"__esModule",{value:!0}),r);var Gc=Da(Ar=>{"use strict";var Qd="[object ArrayBuffer]",xe=class r{static isArrayBuffer(t){return Object.prototype.toString.call(t)===Qd}static toArrayBuffer(t){return this.isArrayBuffer(t)?t:t.byteLength===t.buffer.byteLength||t.byteOffset===0&&t.byteLength===t.buffer.byteLength?t.buffer:this.toUint8Array(t.buffer).slice(t.byteOffset,t.byteOffset+t.byteLength).buffer}static toUint8Array(t){return this.toView(t,Uint8Array)}static toView(t,e){if(t.constructor===e)return t;if(this.isArrayBuffer(t))return new e(t);if(this.isArrayBufferView(t))return new e(t.buffer,t.byteOffset,t.byteLength);throw new TypeError("The provided value is not of type '(ArrayBuffer or ArrayBufferView)'")}static isBufferSource(t){return this.isArrayBufferView(t)||this.isArrayBuffer(t)}static isArrayBufferView(t){return ArrayBuffer.isView(t)||t&&this.isArrayBuffer(t.buffer)}static isEqual(t,e){let n=r.toUint8Array(t),s=r.toUint8Array(e);if(n.length!==s.byteLength)return!1;for(let o=0;o<n.length;o++)if(n[o]!==s[o])return!1;return!0}static concat(...t){let e;Array.isArray(t[0])&&!(t[1]instanceof Function)||Array.isArray(t[0])&&t[1]instanceof Function?e=t[0]:t[t.length-1]instanceof Function?e=t.slice(0,t.length-1):e=t;let n=0;for(let i of e)n+=i.byteLength;let s=new Uint8Array(n),o=0;for(let i of e){let a=this.toUint8Array(i);s.set(a,o),o+=a.length}return t[t.length-1]instanceof Function?this.toView(s,t[t.length-1]):s.buffer}},yi="string",t0=/^[0-9a-f]+$/i,e0=/^(?:[A-Za-z0-9+/]{4})*(?:[A-Za-z0-9+/]{2}==|[A-Za-z0-9+/]{3}=)?$/,r0=/^[a-zA-Z0-9-_]+$/,$n=class{static fromString(t){let e=unescape(encodeURIComponent(t)),n=new Uint8Array(e.length);for(let s=0;s<e.length;s++)n[s]=e.charCodeAt(s);return n.buffer}static toString(t){let e=xe.toUint8Array(t),n="";for(let o=0;o<e.length;o++)n+=String.fromCharCode(e[o]);return decodeURIComponent(escape(n))}},Kt=class{static toString(t,e=!1){let n=xe.toArrayBuffer(t),s=new DataView(n),o="";for(let i=0;i<n.byteLength;i+=2){let a=s.getUint16(i,e);o+=String.fromCharCode(a)}return o}static fromString(t,e=!1){let n=new ArrayBuffer(t.length*2),s=new DataView(n);for(let o=0;o<t.length;o++)s.setUint16(o*2,t.charCodeAt(o),e);return n}},qn=class r{static isHex(t){return typeof t===yi&&t0.test(t)}static isBase64(t){return typeof t===yi&&e0.test(t)}static isBase64Url(t){return typeof t===yi&&r0.test(t)}static ToString(t,e="utf8"){let n=xe.toUint8Array(t);switch(e.toLowerCase()){case"utf8":return this.ToUtf8String(n);case"binary":return this.ToBinary(n);case"hex":return this.ToHex(n);case"base64":return this.ToBase64(n);case"base64url":return this.ToBase64Url(n);case"utf16le":return Kt.toString(n,!0);case"utf16":case"utf16be":return Kt.toString(n);default:throw new Error(`Unknown type of encoding '${e}'`)}}static FromString(t,e="utf8"){if(!t)return new ArrayBuffer(0);switch(e.toLowerCase()){case"utf8":return this.FromUtf8String(t);case"binary":return this.FromBinary(t);case"hex":return this.FromHex(t);case"base64":return this.FromBase64(t);case"base64url":return this.FromBase64Url(t);case"utf16le":return Kt.fromString(t,!0);case"utf16":case"utf16be":return Kt.fromString(t);default:throw new Error(`Unknown type of encoding '${e}'`)}}static ToBase64(t){let e=xe.toUint8Array(t);if(typeof btoa<"u"){let n=this.ToString(e,"binary");return btoa(n)}else return Buffer.from(e).toString("base64")}static FromBase64(t){let e=this.formatString(t);if(!e)return new ArrayBuffer(0);if(!r.isBase64(e))throw new TypeError("Argument 'base64Text' is not Base64 encoded");return typeof atob<"u"?this.FromBinary(atob(e)):new Uint8Array(Buffer.from(e,"base64")).buffer}static FromBase64Url(t){let e=this.formatString(t);if(!e)return new ArrayBuffer(0);if(!r.isBase64Url(e))throw new TypeError("Argument 'base64url' is not Base64Url encoded");return this.FromBase64(this.Base64Padding(e.replace(/\-/g,"+").replace(/\_/g,"/")))}static ToBase64Url(t){return this.ToBase64(t).replace(/\+/g,"-").replace(/\//g,"_").replace(/\=/g,"")}static FromUtf8String(t,e=r.DEFAULT_UTF8_ENCODING){switch(e){case"ascii":return this.FromBinary(t);case"utf8":return $n.fromString(t);case"utf16":case"utf16be":return Kt.fromString(t);case"utf16le":case"usc2":return Kt.fromString(t,!0);default:throw new Error(`Unknown type of encoding '${e}'`)}}static ToUtf8String(t,e=r.DEFAULT_UTF8_ENCODING){switch(e){case"ascii":return this.ToBinary(t);case"utf8":return $n.toString(t);case"utf16":case"utf16be":return Kt.toString(t);case"utf16le":case"usc2":return Kt.toString(t,!0);default:throw new Error(`Unknown type of encoding '${e}'`)}}static FromBinary(t){let e=t.length,n=new Uint8Array(e);for(let s=0;s<e;s++)n[s]=t.charCodeAt(s);return n.buffer}static ToBinary(t){let e=xe.toUint8Array(t),n="";for(let s=0;s<e.length;s++)n+=String.fromCharCode(e[s]);return n}static ToHex(t){let e=xe.toUint8Array(t),n="",s=e.length;for(let o=0;o<s;o++){let i=e[o];i<16&&(n+="0"),n+=i.toString(16)}return n}static FromHex(t){let e=this.formatString(t);if(!e)return new ArrayBuffer(0);if(!r.isHex(e))throw new TypeError("Argument 'hexString' is not HEX encoded");e.length%2&&(e=`0${e}`);let n=new Uint8Array(e.length/2);for(let s=0;s<e.length;s=s+2){let o=e.slice(s,s+2);n[s/2]=parseInt(o,16)}return n.buffer}static ToUtf16String(t,e=!1){return Kt.toString(t,e)}static FromUtf16String(t,e=!1){return Kt.fromString(t,e)}static Base64Padding(t){let e=4-t.length%4;if(e<4)for(let n=0;n<e;n++)t+="=";return t}static formatString(t){return t?.replace(/[\n\r\t ]/g,"")||""}};qn.DEFAULT_UTF8_ENCODING="utf8";function n0(r,...t){let e=arguments[0];for(let n=1;n<arguments.length;n++){let s=arguments[n];for(let o in s)e[o]=s[o]}return e}function s0(...r){let t=r.map(s=>s.byteLength).reduce((s,o)=>s+o),e=new Uint8Array(t),n=0;return r.map(s=>new Uint8Array(s)).forEach(s=>{for(let o of s)e[n++]=o}),e.buffer}function o0(r,t){if(!(r&&t)||r.byteLength!==t.byteLength)return!1;let e=new Uint8Array(r),n=new Uint8Array(t);for(let s=0;s<r.byteLength;s++)if(e[s]!==n[s])return!1;return!0}Ar.BufferSourceConverter=xe;Ar.Convert=qn;Ar.assign=n0;Ar.combine=s0;Ar.isEqual=o0});var su=Da((ob,nu)=>{"use strict";function ru(r,t){for(let e in t)Object.defineProperty(r,e,{value:t[e],enumerable:!0,configurable:!0});return r}function K0(r,t,e){if(!r||typeof r=="string")throw new TypeError("Please pass an Error to err-code");e||(e={}),typeof t=="object"&&(e=t,t=""),t&&(e.code=t);try{return ru(r,e)}catch{e.message=r.message,e.stack=r.stack;let s=function(){};return s.prototype=Object.create(Object.getPrototypeOf(r)),ru(new s,e)}}nu.exports=K0});var qp={};yt(qp,{webTransport:()=>$p});var Ha=Symbol.for("@libp2p/peer-id");var Ka=Symbol.for("@libp2p/transport");var Ma;(function(r){r[r.FATAL_ALL=0]="FATAL_ALL",r[r.NO_FATAL=1]="NO_FATAL"})(Ma||(Ma={}));var F=class extends Error{code;props;constructor(t,e,n){super(t),this.code=e,this.name=n?.name??"CodeError",this.props=n??{}}};var pi={};yt(pi,{Ed25519PrivateKey:()=>er,Ed25519PublicKey:()=>tn,generateKeyPair:()=>Zd,generateKeyPairFromSeed:()=>qc,unmarshalEd25519PrivateKey:()=>Wd,unmarshalEd25519PublicKey:()=>Yd});var ho={};yt(ho,{base58btc:()=>ut,base58flickr:()=>Tf});var Yp=new Uint8Array(0);function Fa(r,t){if(r===t)return!0;if(r.byteLength!==t.byteLength)return!1;for(let e=0;e<r.byteLength;e++)if(r[e]!==t[e])return!1;return!0}function fe(r){if(r instanceof Uint8Array&&r.constructor.name==="Uint8Array")return r;if(r instanceof ArrayBuffer)return new Uint8Array(r);if(ArrayBuffer.isView(r))return new Uint8Array(r.buffer,r.byteOffset,r.byteLength);throw new Error("Unknown type, must be binary type")}function $a(r){return new TextEncoder().encode(r)}function qa(r){return new TextDecoder().decode(r)}function Sf(r,t){if(r.length>=255)throw new TypeError("Alphabet too long");for(var e=new Uint8Array(256),n=0;n<e.length;n++)e[n]=255;for(var s=0;s<r.length;s++){var o=r.charAt(s),i=o.charCodeAt(0);if(e[i]!==255)throw new TypeError(o+" is ambiguous");e[i]=s}var a=r.length,c=r.charAt(0),l=Math.log(a)/Math.log(256),u=Math.log(256)/Math.log(a);function f(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 h=0,p=0,b=0,v=d.length;b!==v&&d[b]===0;)b++,h++;for(var w=(v-b)*u+1>>>0,A=new Uint8Array(w);b!==v;){for(var B=d[b],S=0,N=w-1;(B!==0||S<p)&&N!==-1;N--,S++)B+=256*A[N]>>>0,A[N]=B%a>>>0,B=B/a>>>0;if(B!==0)throw new Error("Non-zero carry");p=S,b++}for(var _=w-p;_!==w&&A[_]===0;)_++;for(var V=c.repeat(h);_<w;++_)V+=r.charAt(A[_]);return V}function g(d){if(typeof d!="string")throw new TypeError("Expected String");if(d.length===0)return new Uint8Array;var h=0;if(d[h]!==" "){for(var p=0,b=0;d[h]===c;)p++,h++;for(var v=(d.length-h)*l+1>>>0,w=new Uint8Array(v);d[h];){var A=e[d.charCodeAt(h)];if(A===255)return;for(var B=0,S=v-1;(A!==0||B<b)&&S!==-1;S--,B++)A+=a*w[S]>>>0,w[S]=A%256>>>0,A=A/256>>>0;if(A!==0)throw new Error("Non-zero carry");b=B,h++}if(d[h]!==" "){for(var N=v-b;N!==v&&w[N]===0;)N++;for(var _=new Uint8Array(p+(v-N)),V=p;N!==v;)_[V++]=w[N++];return _}}}function m(d){var h=g(d);if(h)return h;throw new Error(`Non-${t} character`)}return{encode:f,decodeUnsafe:g,decode:m}}var kf=Sf,If=kf,ja=If;var co=class{name;prefix;baseEncode;constructor(t,e,n){this.name=t,this.prefix=e,this.baseEncode=n}encode(t){if(t instanceof Uint8Array)return`${this.prefix}${this.baseEncode(t)}`;throw Error("Unknown type, must be binary type")}},lo=class{name;prefix;baseDecode;prefixCodePoint;constructor(t,e,n){if(this.name=t,this.prefix=e,e.codePointAt(0)===void 0)throw new Error("Invalid prefix character");this.prefixCodePoint=e.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 za(this,t)}},uo=class{decoders;constructor(t){this.decoders=t}or(t){return za(this,t)}decode(t){let e=t[0],n=this.decoders[e];if(n!=null)return n.decode(t);throw RangeError(`Unable to decode multibase string ${JSON.stringify(t)}, only inputs prefixed with ${Object.keys(this.decoders)} are supported`)}};function za(r,t){return new uo({...r.decoders??{[r.prefix]:r},...t.decoders??{[t.prefix]:t}})}var fo=class{name;prefix;baseEncode;baseDecode;encoder;decoder;constructor(t,e,n,s){this.name=t,this.prefix=e,this.baseEncode=n,this.baseDecode=s,this.encoder=new co(t,e,n),this.decoder=new lo(t,e,s)}encode(t){return this.encoder.encode(t)}decode(t){return this.decoder.decode(t)}};function lr({name:r,prefix:t,encode:e,decode:n}){return new fo(r,t,e,n)}function _e({name:r,prefix:t,alphabet:e}){let{encode:n,decode:s}=ja(e,r);return lr({prefix:t,name:r,encode:n,decode:o=>fe(s(o))})}function _f(r,t,e,n){let s={};for(let u=0;u<t.length;++u)s[t[u]]=u;let o=r.length;for(;r[o-1]==="=";)--o;let i=new Uint8Array(o*e/8|0),a=0,c=0,l=0;for(let u=0;u<o;++u){let f=s[r[u]];if(f===void 0)throw new SyntaxError(`Non-${n} character`);c=c<<e|f,a+=e,a>=8&&(a-=8,i[l++]=255&c>>a)}if(a>=e||255&c<<8-a)throw new SyntaxError("Unexpected end of data");return i}function Nf(r,t,e){let n=t[t.length-1]==="=",s=(1<<e)-1,o="",i=0,a=0;for(let c=0;c<r.length;++c)for(a=a<<8|r[c],i+=8;i>e;)i-=e,o+=t[s&a>>i];if(i!==0&&(o+=t[s&a<<e-i]),n)for(;o.length*e&7;)o+="=";return o}function ct({name:r,prefix:t,bitsPerChar:e,alphabet:n}){return lr({prefix:t,name:r,encode(s){return Nf(s,n,e)},decode(s){return _f(s,n,e,r)}})}var ut=_e({name:"base58btc",prefix:"z",alphabet:"123456789ABCDEFGHJKLMNPQRSTUVWXYZabcdefghijkmnopqrstuvwxyz"}),Tf=_e({name:"base58flickr",prefix:"Z",alphabet:"123456789abcdefghijkmnopqrstuvwxyzABCDEFGHJKLMNPQRSTUVWXYZ"});var yo={};yt(yo,{identity:()=>Te});var ee={};yt(ee,{Digest:()=>Ge,create:()=>$t,decode:()=>Ne,equals:()=>go});var Rf=Za,Wa=128,Lf=127,Cf=~Lf,Uf=Math.pow(2,31);function Za(r,t,e){t=t||[],e=e||0;for(var n=e;r>=Uf;)t[e++]=r&255|Wa,r/=128;for(;r&Cf;)t[e++]=r&255|Wa,r>>>=7;return t[e]=r|0,Za.bytes=e-n+1,t}var Pf=po,Df=128,Ya=127;function po(r,n){var e=0,n=n||0,s=0,o=n,i,a=r.length;do{if(o>=a)throw po.bytes=0,new RangeError("Could not decode varint");i=r[o++],e+=s<28?(i&Ya)<<s:(i&Ya)*Math.pow(2,s),s+=7}while(i>=Df);return po.bytes=o-n,e}var Vf=Math.pow(2,7),Of=Math.pow(2,14),Hf=Math.pow(2,21),Mf=Math.pow(2,28),Kf=Math.pow(2,35),Ff=Math.pow(2,42),$f=Math.pow(2,49),qf=Math.pow(2,56),Gf=Math.pow(2,63),jf=function(r){return r<Vf?1:r<Of?2:r<Hf?3:r<Mf?4:r<Kf?5:r<Ff?6:r<$f?7:r<qf?8:r<Gf?9:10},zf={encode:Rf,decode:Pf,encodingLength:jf},Wf=zf,$r=Wf;function qr(r,t=0){return[$r.decode(r,t),$r.decode.bytes]}function ur(r,t,e=0){return $r.encode(r,t,e),t}function fr(r){return $r.encodingLength(r)}function $t(r,t){let e=t.byteLength,n=fr(r),s=n+fr(e),o=new Uint8Array(s+e);return ur(r,o,0),ur(e,o,n),o.set(t,s),new Ge(r,e,t,o)}function Ne(r){let t=fe(r),[e,n]=qr(t),[s,o]=qr(t.subarray(n)),i=t.subarray(n+o);if(i.byteLength!==s)throw new Error("Incorrect length");return new Ge(e,s,i,t)}function go(r,t){if(r===t)return!0;{let e=t;return r.code===e.code&&r.size===e.size&&e.bytes instanceof Uint8Array&&Fa(r.bytes,e.bytes)}}var Ge=class{code;size;digest;bytes;constructor(t,e,n,s){this.code=t,this.size=e,this.digest=n,this.bytes=s}};var Xa=0,Yf="identity",Ja=fe;function Zf(r){return $t(Xa,Ja(r))}var Te={code:Xa,name:Yf,encode:Ja,digest:Zf};var bo={};yt(bo,{sha256:()=>At,sha512:()=>Xf});function wo({name:r,code:t,encode:e}){return new mo(r,t,e)}var mo=class{name;code;encode;constructor(t,e,n){this.name=t,this.code=e,this.encode=n}digest(t){if(t instanceof Uint8Array){let e=this.encode(t);return e instanceof Uint8Array?$t(this.code,e):e.then(n=>$t(this.code,n))}else throw Error("Unknown type, must be binary type")}};function tc(r){return async t=>new Uint8Array(await crypto.subtle.digest(r,t))}var At=wo({name:"sha2-256",code:18,encode:tc("SHA-256")}),Xf=wo({name:"sha2-512",code:19,encode:tc("SHA-512")});function ft(r,t){if(r===t)return!0;if(r.byteLength!==t.byteLength)return!1;for(let e=0;e<r.byteLength;e++)if(r[e]!==t[e])return!1;return!0}function mt(r=0){return new Uint8Array(r)}function wt(r=0){return new Uint8Array(r)}function xt(r,t){t==null&&(t=r.reduce((s,o)=>s+o.length,0));let e=wt(t),n=0;for(let s of r)e.set(s,n),n+=s.length;return e}var xo={};yt(xo,{base10:()=>Qf});var Qf=_e({prefix:"9",name:"base10",alphabet:"0123456789"});var Eo={};yt(Eo,{base16:()=>th,base16upper:()=>eh});var th=ct({prefix:"f",name:"base16",alphabet:"0123456789abcdef",bitsPerChar:4}),eh=ct({prefix:"F",name:"base16upper",alphabet:"0123456789ABCDEF",bitsPerChar:4});var vo={};yt(vo,{base2:()=>rh});var rh=ct({prefix:"0",name:"base2",alphabet:"01",bitsPerChar:1});var Bo={};yt(Bo,{base256emoji:()=>ah});var ec=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}"),nh=ec.reduce((r,t,e)=>(r[e]=t,r),[]),sh=ec.reduce((r,t,e)=>(r[t.codePointAt(0)]=e,r),[]);function oh(r){return r.reduce((t,e)=>(t+=nh[e],t),"")}function ih(r){let t=[];for(let e of r){let n=sh[e.codePointAt(0)];if(n===void 0)throw new Error(`Non-base256emoji character: ${e}`);t.push(n)}return new Uint8Array(t)}var ah=lr({prefix:"\u{1F680}",name:"base256emoji",encode:oh,decode:ih});var Ao={};yt(Ao,{base32:()=>he,base32hex:()=>fh,base32hexpad:()=>dh,base32hexpadupper:()=>ph,base32hexupper:()=>hh,base32pad:()=>lh,base32padupper:()=>uh,base32upper:()=>ch,base32z:()=>gh});var he=ct({prefix:"b",name:"base32",alphabet:"abcdefghijklmnopqrstuvwxyz234567",bitsPerChar:5}),ch=ct({prefix:"B",name:"base32upper",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZ234567",bitsPerChar:5}),lh=ct({prefix:"c",name:"base32pad",alphabet:"abcdefghijklmnopqrstuvwxyz234567=",bitsPerChar:5}),uh=ct({prefix:"C",name:"base32padupper",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZ234567=",bitsPerChar:5}),fh=ct({prefix:"v",name:"base32hex",alphabet:"0123456789abcdefghijklmnopqrstuv",bitsPerChar:5}),hh=ct({prefix:"V",name:"base32hexupper",alphabet:"0123456789ABCDEFGHIJKLMNOPQRSTUV",bitsPerChar:5}),dh=ct({prefix:"t",name:"base32hexpad",alphabet:"0123456789abcdefghijklmnopqrstuv=",bitsPerChar:5}),ph=ct({prefix:"T",name:"base32hexpadupper",alphabet:"0123456789ABCDEFGHIJKLMNOPQRSTUV=",bitsPerChar:5}),gh=ct({prefix:"h",name:"base32z",alphabet:"ybndrfg8ejkmcpqxot1uwisza345h769",bitsPerChar:5});var So={};yt(So,{base36:()=>yh,base36upper:()=>mh});var yh=_e({prefix:"k",name:"base36",alphabet:"0123456789abcdefghijklmnopqrstuvwxyz"}),mh=_e({prefix:"K",name:"base36upper",alphabet:"0123456789ABCDEFGHIJKLMNOPQRSTUVWXYZ"});var _o={};yt(_o,{base64:()=>ko,base64pad:()=>wh,base64url:()=>Io,base64urlpad:()=>bh});var ko=ct({prefix:"m",name:"base64",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/",bitsPerChar:6}),wh=ct({prefix:"M",name:"base64pad",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/=",bitsPerChar:6}),Io=ct({prefix:"u",name:"base64url",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789-_",bitsPerChar:6}),bh=ct({prefix:"U",name:"base64urlpad",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789-_=",bitsPerChar:6});var No={};yt(No,{base8:()=>xh});var xh=ct({prefix:"7",name:"base8",alphabet:"01234567",bitsPerChar:3});var To={};yt(To,{identity:()=>Eh});var Eh=lr({prefix:"\0",name:"identity",encode:r=>qa(r),decode:r=>$a(r)});var vg=new TextEncoder,Bg=new TextDecoder;function rc(r,t){let{bytes:e,version:n}=r;switch(n){case 0:return Sh(e,Ro(r),t??ut.encoder);default:return kh(e,Ro(r),t??he.encoder)}}var nc=new WeakMap;function Ro(r){let t=nc.get(r);if(t==null){let e=new Map;return nc.set(r,e),e}return t}var qt=class r{code;version;multihash;bytes;"/";constructor(t,e,n,s){this.code=e,this.version=t,this.multihash=n,this.bytes=s,this["/"]=s}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:e}=this;if(t!==Gr)throw new Error("Cannot convert a non dag-pb CID to CIDv0");if(e.code!==Ih)throw new Error("Cannot convert non sha2-256 multihash CID to CIDv0");return r.createV0(e)}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:e}=this.multihash,n=$t(t,e);return r.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 r.equals(this,t)}static equals(t,e){let n=e;return n!=null&&t.code===n.code&&t.version===n.version&&go(t.multihash,n.multihash)}toString(t){return rc(this,t)}toJSON(){return{"/":rc(this)}}link(){return this}[Symbol.toStringTag]="CID";[Symbol.for("nodejs.util.inspect.custom")](){return`CID(${this.toString()})`}static asCID(t){if(t==null)return null;let e=t;if(e instanceof r)return e;if(e["/"]!=null&&e["/"]===e.bytes||e.asCID===e){let{version:n,code:s,multihash:o,bytes:i}=e;return new r(n,s,o,i??sc(n,s,o.bytes))}else if(e[_h]===!0){let{version:n,multihash:s,code:o}=e,i=Ne(s);return r.create(n,o,i)}else return null}static create(t,e,n){if(typeof e!="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(e!==Gr)throw new Error(`Version 0 CID must use dag-pb (code: ${Gr}) block encoding`);return new r(t,e,n,n.bytes)}case 1:{let s=sc(t,e,n.bytes);return new r(t,e,n,s)}default:throw new Error("Invalid version")}}static createV0(t){return r.create(0,Gr,t)}static createV1(t,e){return r.create(1,t,e)}static decode(t){let[e,n]=r.decodeFirst(t);if(n.length!==0)throw new Error("Incorrect length");return e}static decodeFirst(t){let e=r.inspectBytes(t),n=e.size-e.multihashSize,s=fe(t.subarray(n,n+e.multihashSize));if(s.byteLength!==e.multihashSize)throw new Error("Incorrect length");let o=s.subarray(e.multihashSize-e.digestSize),i=new Ge(e.multihashCode,e.digestSize,o,s);return[e.version===0?r.createV0(i):r.createV1(e.codec,i),t.subarray(e.size)]}static inspectBytes(t){let e=0,n=()=>{let[f,g]=qr(t.subarray(e));return e+=g,f},s=n(),o=Gr;if(s===18?(s=0,e=0):o=n(),s!==0&&s!==1)throw new RangeError(`Invalid CID version ${s}`);let i=e,a=n(),c=n(),l=e+c,u=l-i;return{version:s,codec:o,multihashCode:a,digestSize:c,multihashSize:u,size:l}}static parse(t,e){let[n,s]=Ah(t,e),o=r.decode(s);if(o.version===0&&t[0]!=="Q")throw Error("Version 0 CID string must not include multibase prefix");return Ro(o).set(n,t),o}};function Ah(r,t){switch(r[0]){case"Q":{let e=t??ut;return[ut.prefix,e.decode(`${ut.prefix}${r}`)]}case ut.prefix:{let e=t??ut;return[ut.prefix,e.decode(r)]}case he.prefix:{let e=t??he;return[he.prefix,e.decode(r)]}default:{if(t==null)throw Error("To parse non base32 or base58btc encoded CID multibase decoder must be provided");return[r[0],t.decode(r)]}}}function Sh(r,t,e){let{prefix:n}=e;if(n!==ut.prefix)throw Error(`Cannot string encode V0 in ${e.name} encoding`);let s=t.get(n);if(s==null){let o=e.encode(r).slice(1);return t.set(n,o),o}else return s}function kh(r,t,e){let{prefix:n}=e,s=t.get(n);if(s==null){let o=e.encode(r);return t.set(n,o),o}else return s}var Gr=112,Ih=18;function sc(r,t,e){let n=fr(r),s=n+fr(t),o=new Uint8Array(s+e.byteLength);return ur(r,o,0),ur(t,o,n),o.set(e,s),o}var _h=Symbol.for("@ipld/js-cid/CID");var re={...To,...vo,...No,...xo,...Eo,...Ao,...So,...ho,..._o,...Bo},Hg={...bo,...yo};function ic(r,t,e,n){return{name:r,prefix:t,encoder:{name:r,prefix:t,encode:e},decoder:{decode:n}}}var oc=ic("utf8","u",r=>"u"+new TextDecoder("utf8").decode(r),r=>new TextEncoder().encode(r.substring(1))),Lo=ic("ascii","a",r=>{let t="a";for(let e=0;e<r.length;e++)t+=String.fromCharCode(r[e]);return t},r=>{r=r.substring(1);let t=wt(r.length);for(let e=0;e<r.length;e++)t[e]=r.charCodeAt(e);return t}),Nh={utf8:oc,"utf-8":oc,hex:re.base16,latin1:Lo,ascii:Lo,binary:Lo,...re},Sn=Nh;function et(r,t="utf8"){let e=Sn[t];if(e==null)throw new Error(`Unsupported encoding "${t}"`);return e.decoder.decode(`${e.prefix}${r}`)}function Ht(r){return r==null?!1:typeof r.then=="function"&&typeof r.catch=="function"&&typeof r.finally=="function"}function Re(r){if(!Number.isSafeInteger(r)||r<0)throw new Error(`positive integer expected, not ${r}`)}function Th(r){return r instanceof Uint8Array||r!=null&&typeof r=="object"&&r.constructor.name==="Uint8Array"}function hr(r,...t){if(!Th(r))throw new Error("Uint8Array expected");if(t.length>0&&!t.includes(r.length))throw new Error(`Uint8Array expected of length ${t}, not of length=${r.length}`)}function je(r){if(typeof r!="function"||typeof r.create!="function")throw new Error("Hash should be wrapped by utils.wrapConstructor");Re(r.outputLen),Re(r.blockLen)}function dr(r,t=!0){if(r.destroyed)throw new Error("Hash instance has been destroyed");if(t&&r.finished)throw new Error("Hash#digest() has already been called")}function ac(r,t){hr(r);let e=t.outputLen;if(r.length<e)throw new Error(`digestInto() expects output buffer of length at least ${e}`)}var kn=typeof globalThis=="object"&&"crypto"in globalThis?globalThis.crypto:void 0;var gr=r=>new DataView(r.buffer,r.byteOffset,r.byteLength),Gt=(r,t)=>r<<32-t|r>>>t;var Qg=new Uint8Array(new Uint32Array([287454020]).buffer)[0]===68;var Rh=async()=>{};async function cc(r,t,e){let n=Date.now();for(let s=0;s<r;s++){e(s);let o=Date.now()-n;o>=0&&o<t||(await Rh(),n+=o)}}function Co(r){if(typeof r!="string")throw new Error(`utf8ToBytes expected string, got ${typeof r}`);return new Uint8Array(new TextEncoder().encode(r))}function jt(r){return typeof r=="string"&&(r=Co(r)),hr(r),r}function In(...r){let t=0;for(let n=0;n<r.length;n++){let s=r[n];hr(s),t+=s.length}let e=new Uint8Array(t);for(let n=0,s=0;n<r.length;n++){let o=r[n];e.set(o,s),s+=o.length}return e}var pr=class{clone(){return this._cloneInto()}},Lh={}.toString;function lc(r,t){if(t!==void 0&&Lh.call(t)!=="[object Object]")throw new Error("Options should be object or undefined");return Object.assign(r,t)}function _n(r){let t=n=>r().update(jt(n)).digest(),e=r();return t.outputLen=e.outputLen,t.blockLen=e.blockLen,t.create=()=>r(),t}function ze(r=32){if(kn&&typeof kn.getRandomValues=="function")return kn.getRandomValues(new Uint8Array(r));throw new Error("crypto.getRandomValues must be defined")}function Ch(r,t,e,n){if(typeof r.setBigUint64=="function")return r.setBigUint64(t,e,n);let s=BigInt(32),o=BigInt(4294967295),i=Number(e>>s&o),a=Number(e&o),c=n?4:0,l=n?0:4;r.setUint32(t+c,i,n),r.setUint32(t+l,a,n)}var uc=(r,t,e)=>r&t^~r&e,fc=(r,t,e)=>r&t^r&e^t&e,yr=class extends pr{constructor(t,e,n,s){super(),this.blockLen=t,this.outputLen=e,this.padOffset=n,this.isLE=s,this.finished=!1,this.length=0,this.pos=0,this.destroyed=!1,this.buffer=new Uint8Array(t),this.view=gr(this.buffer)}update(t){dr(this);let{view:e,buffer:n,blockLen:s}=this;t=jt(t);let o=t.length;for(let i=0;i<o;){let a=Math.min(s-this.pos,o-i);if(a===s){let c=gr(t);for(;s<=o-i;i+=s)this.process(c,i);continue}n.set(t.subarray(i,i+a),this.pos),this.pos+=a,i+=a,this.pos===s&&(this.process(e,0),this.pos=0)}return this.length+=t.length,this.roundClean(),this}digestInto(t){dr(this),ac(t,this),this.finished=!0;let{buffer:e,view:n,blockLen:s,isLE:o}=this,{pos:i}=this;e[i++]=128,this.buffer.subarray(i).fill(0),this.padOffset>s-i&&(this.process(n,0),i=0);for(let f=i;f<s;f++)e[f]=0;Ch(n,s-8,BigInt(this.length*8),o),this.process(n,0);let a=gr(t),c=this.outputLen;if(c%4)throw new Error("_sha2: outputLen should be aligned to 32bit");let l=c/4,u=this.get();if(l>u.length)throw new Error("_sha2: outputLen bigger than state");for(let f=0;f<l;f++)a.setUint32(4*f,u[f],o)}digest(){let{buffer:t,outputLen:e}=this;this.digestInto(t);let n=t.slice(0,e);return this.destroy(),n}_cloneInto(t){t||(t=new this.constructor),t.set(...this.get());let{blockLen:e,buffer:n,length:s,finished:o,destroyed:i,pos:a}=this;return t.length=s,t.pos=a,t.finished=o,t.destroyed=i,s%e&&t.buffer.set(n),t}};var Nn=BigInt(4294967295),Uo=BigInt(32);function hc(r,t=!1){return t?{h:Number(r&Nn),l:Number(r>>Uo&Nn)}:{h:Number(r>>Uo&Nn)|0,l:Number(r&Nn)|0}}function Uh(r,t=!1){let e=new Uint32Array(r.length),n=new Uint32Array(r.length);for(let s=0;s<r.length;s++){let{h:o,l:i}=hc(r[s],t);[e[s],n[s]]=[o,i]}return[e,n]}var Ph=(r,t)=>BigInt(r>>>0)<<Uo|BigInt(t>>>0),Dh=(r,t,e)=>r>>>e,Vh=(r,t,e)=>r<<32-e|t>>>e,Oh=(r,t,e)=>r>>>e|t<<32-e,Hh=(r,t,e)=>r<<32-e|t>>>e,Mh=(r,t,e)=>r<<64-e|t>>>e-32,Kh=(r,t,e)=>r>>>e-32|t<<64-e,Fh=(r,t)=>t,$h=(r,t)=>r,qh=(r,t,e)=>r<<e|t>>>32-e,Gh=(r,t,e)=>t<<e|r>>>32-e,jh=(r,t,e)=>t<<e-32|r>>>64-e,zh=(r,t,e)=>r<<e-32|t>>>64-e;function Wh(r,t,e,n){let s=(t>>>0)+(n>>>0);return{h:r+e+(s/2**32|0)|0,l:s|0}}var Yh=(r,t,e)=>(r>>>0)+(t>>>0)+(e>>>0),Zh=(r,t,e,n)=>t+e+n+(r/2**32|0)|0,Xh=(r,t,e,n)=>(r>>>0)+(t>>>0)+(e>>>0)+(n>>>0),Jh=(r,t,e,n,s)=>t+e+n+s+(r/2**32|0)|0,Qh=(r,t,e,n,s)=>(r>>>0)+(t>>>0)+(e>>>0)+(n>>>0)+(s>>>0),td=(r,t,e,n,s,o)=>t+e+n+s+o+(r/2**32|0)|0;var ed={fromBig:hc,split:Uh,toBig:Ph,shrSH:Dh,shrSL:Vh,rotrSH:Oh,rotrSL:Hh,rotrBH:Mh,rotrBL:Kh,rotr32H:Fh,rotr32L:$h,rotlSH:qh,rotlSL:Gh,rotlBH:jh,rotlBL:zh,add:Wh,add3L:Yh,add3H:Zh,add4L:Xh,add4H:Jh,add5H:td,add5L:Qh},z=ed;var[rd,nd]=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(r=>BigInt(r))),Le=new Uint32Array(80),Ce=new Uint32Array(80),Po=class extends yr{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:e,Bh:n,Bl:s,Ch:o,Cl:i,Dh:a,Dl:c,Eh:l,El:u,Fh:f,Fl:g,Gh:m,Gl:d,Hh:h,Hl:p}=this;return[t,e,n,s,o,i,a,c,l,u,f,g,m,d,h,p]}set(t,e,n,s,o,i,a,c,l,u,f,g,m,d,h,p){this.Ah=t|0,this.Al=e|0,this.Bh=n|0,this.Bl=s|0,this.Ch=o|0,this.Cl=i|0,this.Dh=a|0,this.Dl=c|0,this.Eh=l|0,this.El=u|0,this.Fh=f|0,this.Fl=g|0,this.Gh=m|0,this.Gl=d|0,this.Hh=h|0,this.Hl=p|0}process(t,e){for(let w=0;w<16;w++,e+=4)Le[w]=t.getUint32(e),Ce[w]=t.getUint32(e+=4);for(let w=16;w<80;w++){let A=Le[w-15]|0,B=Ce[w-15]|0,S=z.rotrSH(A,B,1)^z.rotrSH(A,B,8)^z.shrSH(A,B,7),N=z.rotrSL(A,B,1)^z.rotrSL(A,B,8)^z.shrSL(A,B,7),_=Le[w-2]|0,V=Ce[w-2]|0,P=z.rotrSH(_,V,19)^z.rotrBH(_,V,61)^z.shrSH(_,V,6),R=z.rotrSL(_,V,19)^z.rotrBL(_,V,61)^z.shrSL(_,V,6),H=z.add4L(N,R,Ce[w-7],Ce[w-16]),O=z.add4H(H,S,P,Le[w-7],Le[w-16]);Le[w]=O|0,Ce[w]=H|0}let{Ah:n,Al:s,Bh:o,Bl:i,Ch:a,Cl:c,Dh:l,Dl:u,Eh:f,El:g,Fh:m,Fl:d,Gh:h,Gl:p,Hh:b,Hl:v}=this;for(let w=0;w<80;w++){let A=z.rotrSH(f,g,14)^z.rotrSH(f,g,18)^z.rotrBH(f,g,41),B=z.rotrSL(f,g,14)^z.rotrSL(f,g,18)^z.rotrBL(f,g,41),S=f&m^~f&h,N=g&d^~g&p,_=z.add5L(v,B,N,nd[w],Ce[w]),V=z.add5H(_,b,A,S,rd[w],Le[w]),P=_|0,R=z.rotrSH(n,s,28)^z.rotrBH(n,s,34)^z.rotrBH(n,s,39),H=z.rotrSL(n,s,28)^z.rotrBL(n,s,34)^z.rotrBL(n,s,39),O=n&o^n&a^o&a,W=s&i^s&c^i&c;b=h|0,v=p|0,h=m|0,p=d|0,m=f|0,d=g|0,{h:f,l:g}=z.add(l|0,u|0,V|0,P|0),l=a|0,u=c|0,a=o|0,c=i|0,o=n|0,i=s|0;let x=z.add3L(P,H,W);n=z.add3H(x,V,R,O),s=x|0}({h:n,l:s}=z.add(this.Ah|0,this.Al|0,n|0,s|0)),{h:o,l:i}=z.add(this.Bh|0,this.Bl|0,o|0,i|0),{h:a,l:c}=z.add(this.Ch|0,this.Cl|0,a|0,c|0),{h:l,l:u}=z.add(this.Dh|0,this.Dl|0,l|0,u|0),{h:f,l:g}=z.add(this.Eh|0,this.El|0,f|0,g|0),{h:m,l:d}=z.add(this.Fh|0,this.Fl|0,m|0,d|0),{h,l:p}=z.add(this.Gh|0,this.Gl|0,h|0,p|0),{h:b,l:v}=z.add(this.Hh|0,this.Hl|0,b|0,v|0),this.set(n,s,o,i,a,c,l,u,f,g,m,d,h,p,b,v)}roundClean(){Le.fill(0),Ce.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 mr=_n(()=>new Po);var Rn={};yt(Rn,{abytes:()=>wr,bitGet:()=>ud,bitLen:()=>ld,bitMask:()=>jr,bitSet:()=>fd,bytesToHex:()=>pe,bytesToNumberBE:()=>ge,bytesToNumberLE:()=>zt,concatBytes:()=>me,createHmacDrbg:()=>Oo,ensureBytes:()=>st,equalBytes:()=>ad,hexToBytes:()=>We,hexToNumber:()=>Vo,isBytes:()=>Ue,numberToBytesBE:()=>Pe,numberToBytesLE:()=>ye,numberToHexUnpadded:()=>yc,numberToVarBytesBE:()=>id,utf8ToBytes:()=>cd,validateObject:()=>Mt});var gc=BigInt(0),Tn=BigInt(1),sd=BigInt(2);function Ue(r){return r instanceof Uint8Array||r!=null&&typeof r=="object"&&r.constructor.name==="Uint8Array"}function wr(r){if(!Ue(r))throw new Error("Uint8Array expected")}var od=Array.from({length:256},(r,t)=>t.toString(16).padStart(2,"0"));function pe(r){wr(r);let t="";for(let e=0;e<r.length;e++)t+=od[r[e]];return t}function yc(r){let t=r.toString(16);return t.length&1?`0${t}`:t}function Vo(r){if(typeof r!="string")throw new Error("hex string expected, got "+typeof r);return BigInt(r===""?"0":`0x${r}`)}var de={_0:48,_9:57,_A:65,_F:70,_a:97,_f:102};function dc(r){if(r>=de._0&&r<=de._9)return r-de._0;if(r>=de._A&&r<=de._F)return r-(de._A-10);if(r>=de._a&&r<=de._f)return r-(de._a-10)}function We(r){if(typeof r!="string")throw new Error("hex string expected, got "+typeof r);let t=r.length,e=t/2;if(t%2)throw new Error("padded hex string expected, got unpadded hex of length "+t);let n=new Uint8Array(e);for(let s=0,o=0;s<e;s++,o+=2){let i=dc(r.charCodeAt(o)),a=dc(r.charCodeAt(o+1));if(i===void 0||a===void 0){let c=r[o]+r[o+1];throw new Error('hex string expected, got non-hex character "'+c+'" at index '+o)}n[s]=i*16+a}return n}function ge(r){return Vo(pe(r))}function zt(r){return wr(r),Vo(pe(Uint8Array.from(r).reverse()))}function Pe(r,t){return We(r.toString(16).padStart(t*2,"0"))}function ye(r,t){return Pe(r,t).reverse()}function id(r){return We(yc(r))}function st(r,t,e){let n;if(typeof t=="string")try{n=We(t)}catch(o){throw new Error(`${r} must be valid hex string, got "${t}". Cause: ${o}`)}else if(Ue(t))n=Uint8Array.from(t);else throw new Error(`${r} must be hex string or Uint8Array`);let s=n.length;if(typeof e=="number"&&s!==e)throw new Error(`${r} expected ${e} bytes, got ${s}`);return n}function me(...r){let t=0;for(let n=0;n<r.length;n++){let s=r[n];wr(s),t+=s.length}let e=new Uint8Array(t);for(let n=0,s=0;n<r.length;n++){let o=r[n];e.set(o,s),s+=o.length}return e}function ad(r,t){if(r.length!==t.length)return!1;let e=0;for(let n=0;n<r.length;n++)e|=r[n]^t[n];return e===0}function cd(r){if(typeof r!="string")throw new Error(`utf8ToBytes expected string, got ${typeof r}`);return new Uint8Array(new TextEncoder().encode(r))}function ld(r){let t;for(t=0;r>gc;r>>=Tn,t+=1);return t}function ud(r,t){return r>>BigInt(t)&Tn}function fd(r,t,e){return r|(e?Tn:gc)<<BigInt(t)}var jr=r=>(sd<<BigInt(r-1))-Tn,Do=r=>new Uint8Array(r),pc=r=>Uint8Array.from(r);function Oo(r,t,e){if(typeof r!="number"||r<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 e!="function")throw new Error("hmacFn must be a function");let n=Do(r),s=Do(r),o=0,i=()=>{n.fill(1),s.fill(0),o=0},a=(...f)=>e(s,n,...f),c=(f=Do())=>{s=a(pc([0]),f),n=a(),f.length!==0&&(s=a(pc([1]),f),n=a())},l=()=>{if(o++>=1e3)throw new Error("drbg: tried 1000 values");let f=0,g=[];for(;f<t;){n=a();let m=n.slice();g.push(m),f+=n.length}return me(...g)};return(f,g)=>{i(),c(f);let m;for(;!(m=g(l()));)c();return i(),m}}var hd={bigint:r=>typeof r=="bigint",function:r=>typeof r=="function",boolean:r=>typeof r=="boolean",string:r=>typeof r=="string",stringOrUint8Array:r=>typeof r=="string"||Ue(r),isSafeInteger:r=>Number.isSafeInteger(r),array:r=>Array.isArray(r),field:(r,t)=>t.Fp.isValid(r),hash:r=>typeof r=="function"&&Number.isSafeInteger(r.outputLen)};function Mt(r,t,e={}){let n=(s,o,i)=>{let a=hd[o];if(typeof a!="function")throw new Error(`Invalid validator "${o}", expected function`);let c=r[s];if(!(i&&c===void 0)&&!a(c,r))throw new Error(`Invalid param ${String(s)}=${c} (${typeof c}), expected ${o}`)};for(let[s,o]of Object.entries(t))n(s,o,!1);for(let[s,o]of Object.entries(e))n(s,o,!0);return r}var bt=BigInt(0),it=BigInt(1),Ye=BigInt(2),dd=BigInt(3),Ho=BigInt(4),mc=BigInt(5),wc=BigInt(8),pd=BigInt(9),gd=BigInt(16);function Z(r,t){let e=r%t;return e>=bt?e:t+e}function Mo(r,t,e){if(e<=bt||t<bt)throw new Error("Expected power/modulo > 0");if(e===it)return bt;let n=it;for(;t>bt;)t&it&&(n=n*r%e),r=r*r%e,t>>=it;return n}function ot(r,t,e){let n=r;for(;t-- >bt;)n*=n,n%=e;return n}function Ln(r,t){if(r===bt||t<=bt)throw new Error(`invert: expected positive integers, got n=${r} mod=${t}`);let e=Z(r,t),n=t,s=bt,o=it,i=it,a=bt;for(;e!==bt;){let l=n/e,u=n%e,f=s-i*l,g=o-a*l;n=e,e=u,s=i,o=a,i=f,a=g}if(n!==it)throw new Error("invert: does not exist");return Z(s,t)}function yd(r){let t=(r-it)/Ye,e,n,s;for(e=r-it,n=0;e%Ye===bt;e/=Ye,n++);for(s=Ye;s<r&&Mo(s,t,r)!==r-it;s++);if(n===1){let i=(r+it)/Ho;return function(c,l){let u=c.pow(l,i);if(!c.eql(c.sqr(u),l))throw new Error("Cannot find square root");return u}}let o=(e+it)/Ye;return function(a,c){if(a.pow(c,t)===a.neg(a.ONE))throw new Error("Cannot find square root");let l=n,u=a.pow(a.mul(a.ONE,s),e),f=a.pow(c,o),g=a.pow(c,e);for(;!a.eql(g,a.ONE);){if(a.eql(g,a.ZERO))return a.ZERO;let m=1;for(let h=a.sqr(g);m<l&&!a.eql(h,a.ONE);m++)h=a.sqr(h);let d=a.pow(u,it<<BigInt(l-m-1));u=a.sqr(d),f=a.mul(f,d),g=a.mul(g,u),l=m}return f}}function md(r){if(r%Ho===dd){let t=(r+it)/Ho;return function(n,s){let o=n.pow(s,t);if(!n.eql(n.sqr(o),s))throw new Error("Cannot find square root");return o}}if(r%wc===mc){let t=(r-mc)/wc;return function(n,s){let o=n.mul(s,Ye),i=n.pow(o,t),a=n.mul(s,i),c=n.mul(n.mul(a,Ye),i),l=n.mul(a,n.sub(c,n.ONE));if(!n.eql(n.sqr(l),s))throw new Error("Cannot find square root");return l}}return r%gd,yd(r)}var bc=(r,t)=>(Z(r,t)&it)===it,wd=["create","isValid","is0","neg","inv","sqrt","sqr","eql","add","sub","mul","pow","div","addN","subN","mulN","sqrN"];function Ko(r){let t={ORDER:"bigint",MASK:"bigint",BYTES:"isSafeInteger",BITS:"isSafeInteger"},e=wd.reduce((n,s)=>(n[s]="function",n),t);return Mt(r,e)}function bd(r,t,e){if(e<bt)throw new Error("Expected power > 0");if(e===bt)return r.ONE;if(e===it)return t;let n=r.ONE,s=t;for(;e>bt;)e&it&&(n=r.mul(n,s)),s=r.sqr(s),e>>=it;return n}function xd(r,t){let e=new Array(t.length),n=t.reduce((o,i,a)=>r.is0(i)?o:(e[a]=o,r.mul(o,i)),r.ONE),s=r.inv(n);return t.reduceRight((o,i,a)=>r.is0(i)?o:(e[a]=r.mul(o,e[a]),r.mul(o,i)),s),e}function Fo(r,t){let e=t!==void 0?t:r.toString(2).length,n=Math.ceil(e/8);return{nBitLength:e,nByteLength:n}}function Cn(r,t,e=!1,n={}){if(r<=bt)throw new Error(`Expected Field ORDER > 0, got ${r}`);let{nBitLength:s,nByteLength:o}=Fo(r,t);if(o>2048)throw new Error("Field lengths over 2048 bytes are not supported");let i=md(r),a=Object.freeze({ORDER:r,BITS:s,BYTES:o,MASK:jr(s),ZERO:bt,ONE:it,create:c=>Z(c,r),isValid:c=>{if(typeof c!="bigint")throw new Error(`Invalid field element: expected bigint, got ${typeof c}`);return bt<=c&&c<r},is0:c=>c===bt,isOdd:c=>(c&it)===it,neg:c=>Z(-c,r),eql:(c,l)=>c===l,sqr:c=>Z(c*c,r),add:(c,l)=>Z(c+l,r),sub:(c,l)=>Z(c-l,r),mul:(c,l)=>Z(c*l,r),pow:(c,l)=>bd(a,c,l),div:(c,l)=>Z(c*Ln(l,r),r),sqrN:c=>c*c,addN:(c,l)=>c+l,subN:(c,l)=>c-l,mulN:(c,l)=>c*l,inv:c=>Ln(c,r),sqrt:n.sqrt||(c=>i(a,c)),invertBatch:c=>xd(a,c),cmov:(c,l,u)=>u?l:c,toBytes:c=>e?ye(c,o):Pe(c,o),fromBytes:c=>{if(c.length!==o)throw new Error(`Fp.fromBytes: expected ${o}, got ${c.length}`);return e?zt(c):ge(c)}});return Object.freeze(a)}function xc(r,t){if(!r.isOdd)throw new Error("Field doesn't have isOdd");let e=r.sqrt(t);return r.isOdd(e)?r.neg(e):e}function Ec(r){if(typeof r!="bigint")throw new Error("field order must be bigint");let t=r.toString(2).length;return Math.ceil(t/8)}function $o(r){let t=Ec(r);return t+Math.ceil(t/2)}function vc(r,t,e=!1){let n=r.length,s=Ec(t),o=$o(t);if(n<16||n<o||n>1024)throw new Error(`expected ${o}-1024 bytes of input, got ${n}`);let i=e?ge(r):zt(r),a=Z(i,t-it)+it;return e?ye(a,s):Pe(a,s)}var vd=BigInt(0),qo=BigInt(1);function Un(r,t){let e=(s,o)=>{let i=o.negate();return s?i:o},n=s=>{let o=Math.ceil(t/s)+1,i=2**(s-1);return{windows:o,windowSize:i}};return{constTimeNegate:e,unsafeLadder(s,o){let i=r.ZERO,a=s;for(;o>vd;)o&qo&&(i=i.add(a)),a=a.double(),o>>=qo;return i},precomputeWindow(s,o){let{windows:i,windowSize:a}=n(o),c=[],l=s,u=l;for(let f=0;f<i;f++){u=l,c.push(u);for(let g=1;g<a;g++)u=u.add(l),c.push(u);l=u.double()}return c},wNAF(s,o,i){let{windows:a,windowSize:c}=n(s),l=r.ZERO,u=r.BASE,f=BigInt(2**s-1),g=2**s,m=BigInt(s);for(let d=0;d<a;d++){let h=d*c,p=Number(i&f);i>>=m,p>c&&(p-=g,i+=qo);let b=h,v=h+Math.abs(p)-1,w=d%2!==0,A=p<0;p===0?u=u.add(e(w,o[b])):l=l.add(e(A,o[v]))}return{p:l,f:u}},wNAFCached(s,o,i,a){let c=s._WINDOW_SIZE||1,l=o.get(s);return l||(l=this.precomputeWindow(s,c),c!==1&&o.set(s,a(l))),this.wNAF(c,l,i)}}}function zr(r){return Ko(r.Fp),Mt(r,{n:"bigint",h:"bigint",Gx:"field",Gy:"field"},{nBitLength:"isSafeInteger",nByteLength:"isSafeInteger"}),Object.freeze({...Fo(r.n,r.nBitLength),...r,p:r.Fp.ORDER})}var Wt=BigInt(0),Dt=BigInt(1),Pn=BigInt(2),Bd=BigInt(8),Ad={zip215:!0};function Sd(r){let t=zr(r);return Mt(r,{hash:"function",a:"bigint",d:"bigint",randomBytes:"function"},{adjustScalarBytes:"function",domain:"function",uvRatio:"function",mapToCurve:"function"}),Object.freeze({...t})}function Dn(r){let t=Sd(r),{Fp:e,n,prehash:s,hash:o,randomBytes:i,nByteLength:a,h:c}=t,l=Pn<<BigInt(a*8)-Dt,u=e.create,f=t.uvRatio||((E,y)=>{try{return{isValid:!0,value:e.sqrt(E*e.inv(y))}}catch{return{isValid:!1,value:Wt}}}),g=t.adjustScalarBytes||(E=>E),m=t.domain||((E,y,k)=>{if(y.length||k)throw new Error("Contexts/pre-hash are not supported");return E}),d=E=>typeof E=="bigint"&&Wt<E,h=(E,y)=>d(E)&&d(y)&&E<y,p=E=>E===Wt||h(E,l);function b(E,y){if(h(E,y))return E;throw new Error(`Expected valid scalar < ${y}, got ${typeof E} ${E}`)}function v(E){return E===Wt?E:b(E,n)}let w=new Map;function A(E){if(!(E instanceof B))throw new Error("ExtendedPoint expected")}class B{constructor(y,k,T,L){if(this.ex=y,this.ey=k,this.ez=T,this.et=L,!p(y))throw new Error("x required");if(!p(k))throw new Error("y required");if(!p(T))throw new Error("z required");if(!p(L))throw new Error("t required")}get x(){return this.toAffine().x}get y(){return this.toAffine().y}static fromAffine(y){if(y instanceof B)throw new Error("extended point not allowed");let{x:k,y:T}=y||{};if(!p(k)||!p(T))throw new Error("invalid affine point");return new B(k,T,Dt,u(k*T))}static normalizeZ(y){let k=e.invertBatch(y.map(T=>T.ez));return y.map((T,L)=>T.toAffine(k[L])).map(B.fromAffine)}_setWindowSize(y){this._WINDOW_SIZE=y,w.delete(this)}assertValidity(){let{a:y,d:k}=t;if(this.is0())throw new Error("bad point: ZERO");let{ex:T,ey:L,ez:M,et:K}=this,j=u(T*T),$=u(L*L),G=u(M*M),nt=u(G*G),tt=u(j*y),vt=u(G*u(tt+$)),Bt=u(nt+u(k*u(j*$)));if(vt!==Bt)throw new Error("bad point: equation left != right (1)");let gt=u(T*L),Nt=u(M*K);if(gt!==Nt)throw new Error("bad point: equation left != right (2)")}equals(y){A(y);let{ex:k,ey:T,ez:L}=this,{ex:M,ey:K,ez:j}=y,$=u(k*j),G=u(M*L),nt=u(T*j),tt=u(K*L);return $===G&&nt===tt}is0(){return this.equals(B.ZERO)}negate(){return new B(u(-this.ex),this.ey,this.ez,u(-this.et))}double(){let{a:y}=t,{ex:k,ey:T,ez:L}=this,M=u(k*k),K=u(T*T),j=u(Pn*u(L*L)),$=u(y*M),G=k+T,nt=u(u(G*G)-M-K),tt=$+K,vt=tt-j,Bt=$-K,gt=u(nt*vt),Nt=u(tt*Bt),ue=u(nt*Bt),qe=u(vt*tt);return new B(gt,Nt,qe,ue)}add(y){A(y);let{a:k,d:T}=t,{ex:L,ey:M,ez:K,et:j}=this,{ex:$,ey:G,ez:nt,et:tt}=y;if(k===BigInt(-1)){let Na=u((M-L)*(G+$)),Ta=u((M+L)*(G-$)),ao=u(Ta-Na);if(ao===Wt)return this.double();let Ra=u(K*Pn*tt),La=u(j*Pn*nt),Ca=La+Ra,Ua=Ta+Na,Pa=La-Ra,gf=u(Ca*ao),yf=u(Ua*Pa),mf=u(Ca*Pa),wf=u(ao*Ua);return new B(gf,yf,wf,mf)}let vt=u(L*$),Bt=u(M*G),gt=u(j*T*tt),Nt=u(K*nt),ue=u((L+M)*($+G)-vt-Bt),qe=Nt-gt,Fr=Nt+gt,_a=u(Bt-k*vt),ff=u(ue*qe),hf=u(Fr*_a),df=u(ue*_a),pf=u(qe*Fr);return new B(ff,hf,pf,df)}subtract(y){return this.add(y.negate())}wNAF(y){return _.wNAFCached(this,w,y,B.normalizeZ)}multiply(y){let{p:k,f:T}=this.wNAF(b(y,n));return B.normalizeZ([k,T])[0]}multiplyUnsafe(y){let k=v(y);return k===Wt?N:this.equals(N)||k===Dt?this:this.equals(S)?this.wNAF(k).p:_.unsafeLadder(this,k)}isSmallOrder(){return this.multiplyUnsafe(c).is0()}isTorsionFree(){return _.unsafeLadder(this,n).is0()}toAffine(y){let{ex:k,ey:T,ez:L}=this,M=this.is0();y==null&&(y=M?Bd:e.inv(L));let K=u(k*y),j=u(T*y),$=u(L*y);if(M)return{x:Wt,y:Dt};if($!==Dt)throw new Error("invZ was invalid");return{x:K,y:j}}clearCofactor(){let{h:y}=t;return y===Dt?this:this.multiplyUnsafe(y)}static fromHex(y,k=!1){let{d:T,a:L}=t,M=e.BYTES;y=st("pointHex",y,M);let K=y.slice(),j=y[M-1];K[M-1]=j&-129;let $=zt(K);$===Wt||(k?b($,l):b($,e.ORDER));let G=u($*$),nt=u(G-Dt),tt=u(T*G-L),{isValid:vt,value:Bt}=f(nt,tt);if(!vt)throw new Error("Point.fromHex: invalid y coordinate");let gt=(Bt&Dt)===Dt,Nt=(j&128)!==0;if(!k&&Bt===Wt&&Nt)throw new Error("Point.fromHex: x=0 and x_0=1");return Nt!==gt&&(Bt=u(-Bt)),B.fromAffine({x:Bt,y:$})}static fromPrivateKey(y){return R(y).point}toRawBytes(){let{x:y,y:k}=this.toAffine(),T=ye(k,e.BYTES);return T[T.length-1]|=y&Dt?128:0,T}toHex(){return pe(this.toRawBytes())}}B.BASE=new B(t.Gx,t.Gy,Dt,u(t.Gx*t.Gy)),B.ZERO=new B(Wt,Dt,Dt,Wt);let{BASE:S,ZERO:N}=B,_=Un(B,a*8);function V(E){return Z(E,n)}function P(E){return V(zt(E))}function R(E){let y=a;E=st("private key",E,y);let k=st("hashed private key",o(E),2*y),T=g(k.slice(0,y)),L=k.slice(y,2*y),M=P(T),K=S.multiply(M),j=K.toRawBytes();return{head:T,prefix:L,scalar:M,point:K,pointBytes:j}}function H(E){return R(E).pointBytes}function O(E=new Uint8Array,...y){let k=me(...y);return P(o(m(k,st("context",E),!!s)))}function W(E,y,k={}){E=st("message",E),s&&(E=s(E));let{prefix:T,scalar:L,pointBytes:M}=R(y),K=O(k.context,T,E),j=S.multiply(K).toRawBytes(),$=O(k.context,j,M,E),G=V(K+$*L);v(G);let nt=me(j,ye(G,e.BYTES));return st("result",nt,a*2)}let x=Ad;function I(E,y,k,T=x){let{context:L,zip215:M}=T,K=e.BYTES;E=st("signature",E,2*K),y=st("message",y),s&&(y=s(y));let j=zt(E.slice(K,2*K)),$,G,nt;try{$=B.fromHex(k,M),G=B.fromHex(E.slice(0,K),M),nt=S.multiplyUnsafe(j)}catch{return!1}if(!M&&$.isSmallOrder())return!1;let tt=O(L,G.toRawBytes(),$.toRawBytes(),y);return G.add($.multiplyUnsafe(tt)).subtract(nt).clearCofactor().equals(B.ZERO)}return S._setWindowSize(8),{CURVE:t,getPublicKey:H,sign:W,verify:I,ExtendedPoint:B,utils:{getExtendedPublicKey:R,randomPrivateKey:()=>i(e.BYTES),precompute(E=8,y=B.BASE){return y._setWindowSize(E),y.multiply(BigInt(3)),y}}}}var Wr=BigInt(0),Go=BigInt(1);function kd(r){return Mt(r,{a:"bigint"},{montgomeryBits:"isSafeInteger",nByteLength:"isSafeInteger",adjustScalarBytes:"function",domain:"function",powPminus2:"function",Gu:"bigint"}),Object.freeze({...r})}function Bc(r){let t=kd(r),{P:e}=t,n=w=>Z(w,e),s=t.montgomeryBits,o=Math.ceil(s/8),i=t.nByteLength,a=t.adjustScalarBytes||(w=>w),c=t.powPminus2||(w=>Mo(w,e-BigInt(2),e));function l(w,A,B){let S=n(w*(A-B));return A=n(A-S),B=n(B+S),[A,B]}function u(w){if(typeof w=="bigint"&&Wr<=w&&w<e)return w;throw new Error("Expected valid scalar 0 < scalar < CURVE.P")}let f=(t.a-BigInt(2))/BigInt(4);function g(w,A){let B=u(w),S=u(A),N=B,_=Go,V=Wr,P=B,R=Go,H=Wr,O;for(let x=BigInt(s-1);x>=Wr;x--){let I=S>>x&Go;H^=I,O=l(H,_,P),_=O[0],P=O[1],O=l(H,V,R),V=O[0],R=O[1],H=I;let C=_+V,E=n(C*C),y=_-V,k=n(y*y),T=E-k,L=P+R,M=P-R,K=n(M*C),j=n(L*y),$=K+j,G=K-j;P=n($*$),R=n(N*n(G*G)),_=n(E*k),V=n(T*(E+n(f*T)))}O=l(H,_,P),_=O[0],P=O[1],O=l(H,V,R),V=O[0],R=O[1];let W=c(V);return n(_*W)}function m(w){return ye(n(w),o)}function d(w){let A=st("u coordinate",w,o);return i===32&&(A[31]&=127),zt(A)}function h(w){let A=st("scalar",w),B=A.length;if(B!==o&&B!==i)throw new Error(`Expected ${o} or ${i} bytes, got ${B}`);return zt(a(A))}function p(w,A){let B=d(A),S=h(w),N=g(B,S);if(N===Wr)throw new Error("Invalid private or public key received");return m(N)}let b=m(t.Gu);function v(w){return p(w,b)}return{scalarMult:p,scalarMultBase:v,getSharedSecret:(w,A)=>p(w,A),getPublicKey:w=>v(w),utils:{randomPrivateKey:()=>t.randomBytes(t.nByteLength)},GuBytes:b}}var Yr=BigInt("57896044618658097711785492504343953926634992332820282019728792003956564819949"),Ac=BigInt("19681161376707505956807079304988542015446066515923890162744021073123829784752"),Sy=BigInt(0),Id=BigInt(1),jo=BigInt(2),_d=BigInt(5),Sc=BigInt(10),Nd=BigInt(20),Td=BigInt(40),kc=BigInt(80);function Ic(r){let t=Yr,n=r*r%t*r%t,s=ot(n,jo,t)*n%t,o=ot(s,Id,t)*r%t,i=ot(o,_d,t)*o%t,a=ot(i,Sc,t)*i%t,c=ot(a,Nd,t)*a%t,l=ot(c,Td,t)*c%t,u=ot(l,kc,t)*l%t,f=ot(u,kc,t)*l%t,g=ot(f,Sc,t)*i%t;return{pow_p_5_8:ot(g,jo,t)*r%t,b2:n}}function _c(r){return r[0]&=248,r[31]&=127,r[31]|=64,r}function Rd(r,t){let e=Yr,n=Z(t*t*t,e),s=Z(n*n*t,e),o=Ic(r*s).pow_p_5_8,i=Z(r*n*o,e),a=Z(t*i*i,e),c=i,l=Z(i*Ac,e),u=a===r,f=a===Z(-r,e),g=a===Z(-r*Ac,e);return u&&(i=c),(f||g)&&(i=l),bc(i,e)&&(i=Z(-i,e)),{isValid:u||f,value:i}}var we=Cn(Yr,void 0,!0),zo={a:BigInt(-1),d:BigInt("37095705934669439343138083508754565189542113879843219016388785533085940283555"),Fp:we,n:BigInt("7237005577332262213973186563042994240857116359379907606001950938285454250989"),h:BigInt(8),Gx:BigInt("15112221349535400772501151409588531511454012693041857206046113283949847762202"),Gy:BigInt("46316835694926478169428394003475163141307993866256225615783033603165251855960"),hash:mr,randomBytes:ze,adjustScalarBytes:_c,uvRatio:Rd},br=Dn(zo);function Nc(r,t,e){if(t.length>255)throw new Error("Context is too big");return In(Co("SigEd25519 no Ed25519 collisions"),new Uint8Array([e?1:0,t.length]),t,r)}var ky=Dn({...zo,domain:Nc}),Iy=Dn({...zo,domain:Nc,prehash:mr}),Zr=Bc({P:Yr,a:BigInt(486662),montgomeryBits:255,nByteLength:32,Gu:BigInt(9),powPminus2:r=>{let t=Yr,{pow_p_5_8:e,b2:n}=Ic(r);return Z(ot(e,BigInt(3),t)*n,t)},adjustScalarBytes:_c,randomBytes:ze});var Ld=(we.ORDER+BigInt(3))/BigInt(8),_y=we.pow(jo,Ld),Ny=we.sqrt(we.neg(we.ONE)),Ty=(we.ORDER-BigInt(5))/BigInt(8),Ry=BigInt(486662);var Ly=xc(we,we.neg(BigInt(486664)));var Cy=BigInt("25063068953384623474111414158702152701244531502492656460079210482610430750235"),Uy=BigInt("54469307008909316920995813868745141605393597292927456921205312896311721017578"),Py=BigInt("1159843021668779879193775521855586647937357759715417654439879720876111806838"),Dy=BigInt("40440834346308536858101042469323190826248399146238708352240133220865137265952");var Vy=BigInt("0x7fffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffff");var xr=32,be=64,Vn=32;function Tc(){let r=br.utils.randomPrivateKey(),t=br.getPublicKey(r);return{privateKey:Uc(r,t),publicKey:t}}function Rc(r){if(r.length!==Vn)throw new TypeError('"seed" must be 32 bytes in length.');if(!(r instanceof Uint8Array))throw new TypeError('"seed" must be a node.js Buffer, or Uint8Array.');let t=r,e=br.getPublicKey(t);return{privateKey:Uc(t,e),publicKey:e}}function Lc(r,t){let e=r.subarray(0,Vn);return br.sign(t instanceof Uint8Array?t:t.subarray(),e)}function Cc(r,t,e){return br.verify(t,e instanceof Uint8Array?e:e.subarray(),r)}function Uc(r,t){let e=new Uint8Array(be);for(let n=0;n<Vn;n++)e[n]=r[n],e[Vn+n]=t[n];return e}var Ct={get(r=globalThis){let t=r.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 Wo={alg:"A128GCM",ext:!0,k:"scm9jmO_4BJAgdwWGVulLg",key_ops:["encrypt","decrypt"],kty:"oct"};function Pc(r){let t=r?.algorithm??"AES-GCM",e=r?.keyLength??16,n=r?.nonceLength??12,s=r?.digest??"SHA-256",o=r?.saltLength??16,i=r?.iterations??32767,a=Ct.get();e*=8;async function c(f,g){let m=a.getRandomValues(new Uint8Array(o)),d=a.getRandomValues(new Uint8Array(n)),h={name:t,iv:d};typeof g=="string"&&(g=et(g));let p;if(g.length===0){p=await a.subtle.importKey("jwk",Wo,{name:"AES-GCM"},!0,["encrypt"]);try{let v={name:"PBKDF2",salt:m,iterations:i,hash:{name:s}},w=await a.subtle.importKey("raw",g,{name:"PBKDF2"},!1,["deriveKey"]);p=await a.subtle.deriveKey(v,w,{name:t,length:e},!0,["encrypt"])}catch{p=await a.subtle.importKey("jwk",Wo,{name:"AES-GCM"},!0,["encrypt"])}}else{let v={name:"PBKDF2",salt:m,iterations:i,hash:{name:s}},w=await a.subtle.importKey("raw",g,{name:"PBKDF2"},!1,["deriveKey"]);p=await a.subtle.deriveKey(v,w,{name:t,length:e},!0,["encrypt"])}let b=await a.subtle.encrypt(h,p,f);return xt([m,h.iv,new Uint8Array(b)])}async function l(f,g){let m=f.subarray(0,o),d=f.subarray(o,o+n),h=f.subarray(o+n),p={name:t,iv:d};typeof g=="string"&&(g=et(g));let b;if(g.length===0)try{let w={name:"PBKDF2",salt:m,iterations:i,hash:{name:s}},A=await a.subtle.importKey("raw",g,{name:"PBKDF2"},!1,["deriveKey"]);b=await a.subtle.deriveKey(w,A,{name:t,length:e},!0,["decrypt"])}catch{b=await a.subtle.importKey("jwk",Wo,{name:"AES-GCM"},!0,["decrypt"])}else{let w={name:"PBKDF2",salt:m,iterations:i,hash:{name:s}},A=await a.subtle.importKey("raw",g,{name:"PBKDF2"},!1,["deriveKey"]);b=await a.subtle.deriveKey(w,A,{name:t,length:e},!0,["decrypt"])}let v=await a.subtle.decrypt(p,b,h);return new Uint8Array(v)}return{encrypt:c,decrypt:l}}async function Er(r,t){let n=await Pc().encrypt(r,t);return ko.encode(n)}var Pd=Math.pow(2,7),Dd=Math.pow(2,14),Vd=Math.pow(2,21),Yo=Math.pow(2,28),Zo=Math.pow(2,35),Xo=Math.pow(2,42),Jo=Math.pow(2,49),J=128,Tt=127;function dt(r){if(r<Pd)return 1;if(r<Dd)return 2;if(r<Vd)return 3;if(r<Yo)return 4;if(r<Zo)return 5;if(r<Xo)return 6;if(r<Jo)return 7;if(Number.MAX_SAFE_INTEGER!=null&&r>Number.MAX_SAFE_INTEGER)throw new RangeError("Could not encode varint");return 8}function Qo(r,t,e=0){switch(dt(r)){case 8:t[e++]=r&255|J,r/=128;case 7:t[e++]=r&255|J,r/=128;case 6:t[e++]=r&255|J,r/=128;case 5:t[e++]=r&255|J,r/=128;case 4:t[e++]=r&255|J,r>>>=7;case 3:t[e++]=r&255|J,r>>>=7;case 2:t[e++]=r&255|J,r>>>=7;case 1:{t[e++]=r&255,r>>>=7;break}default:throw new Error("unreachable")}return t}function Od(r,t,e=0){switch(dt(r)){case 8:t.set(e++,r&255|J),r/=128;case 7:t.set(e++,r&255|J),r/=128;case 6:t.set(e++,r&255|J),r/=128;case 5:t.set(e++,r&255|J),r/=128;case 4:t.set(e++,r&255|J),r>>>=7;case 3:t.set(e++,r&255|J),r>>>=7;case 2:t.set(e++,r&255|J),r>>>=7;case 1:{t.set(e++,r&255),r>>>=7;break}default:throw new Error("unreachable")}return t}function ti(r,t){let e=r[t],n=0;if(n+=e&Tt,e<J||(e=r[t+1],n+=(e&Tt)<<7,e<J)||(e=r[t+2],n+=(e&Tt)<<14,e<J)||(e=r[t+3],n+=(e&Tt)<<21,e<J)||(e=r[t+4],n+=(e&Tt)*Yo,e<J)||(e=r[t+5],n+=(e&Tt)*Zo,e<J)||(e=r[t+6],n+=(e&Tt)*Xo,e<J)||(e=r[t+7],n+=(e&Tt)*Jo,e<J))return n;throw new RangeError("Could not decode varint")}function Hd(r,t){let e=r.get(t),n=0;if(n+=e&Tt,e<J||(e=r.get(t+1),n+=(e&Tt)<<7,e<J)||(e=r.get(t+2),n+=(e&Tt)<<14,e<J)||(e=r.get(t+3),n+=(e&Tt)<<21,e<J)||(e=r.get(t+4),n+=(e&Tt)*Yo,e<J)||(e=r.get(t+5),n+=(e&Tt)*Zo,e<J)||(e=r.get(t+6),n+=(e&Tt)*Xo,e<J)||(e=r.get(t+7),n+=(e&Tt)*Jo,e<J))return n;throw new RangeError("Could not decode varint")}function ne(r,t,e=0){return t==null&&(t=wt(dt(r))),t instanceof Uint8Array?Qo(r,t,e):Od(r,t,e)}function Yt(r,t=0){return r instanceof Uint8Array?ti(r,t):Hd(r,t)}var ei=new Float32Array([-0]),De=new Uint8Array(ei.buffer);function Dc(r,t,e){ei[0]=r,t[e]=De[0],t[e+1]=De[1],t[e+2]=De[2],t[e+3]=De[3]}function Vc(r,t){return De[0]=r[t],De[1]=r[t+1],De[2]=r[t+2],De[3]=r[t+3],ei[0]}var ri=new Float64Array([-0]),Rt=new Uint8Array(ri.buffer);function Oc(r,t,e){ri[0]=r,t[e]=Rt[0],t[e+1]=Rt[1],t[e+2]=Rt[2],t[e+3]=Rt[3],t[e+4]=Rt[4],t[e+5]=Rt[5],t[e+6]=Rt[6],t[e+7]=Rt[7]}function Hc(r,t){return Rt[0]=r[t],Rt[1]=r[t+1],Rt[2]=r[t+2],Rt[3]=r[t+3],Rt[4]=r[t+4],Rt[5]=r[t+5],Rt[6]=r[t+6],Rt[7]=r[t+7],ri[0]}var Md=BigInt(Number.MAX_SAFE_INTEGER),Kd=BigInt(Number.MIN_SAFE_INTEGER),Vt=class r{lo;hi;constructor(t,e){this.lo=t|0,this.hi=e|0}toNumber(t=!1){if(!t&&this.hi>>>31>0){let e=~this.lo+1>>>0,n=~this.hi>>>0;return e===0&&(n=n+1>>>0),-(e+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 e=~this.lo+1>>>0,n=~this.hi>>>0;return e===0&&(n=n+1>>>0),-(BigInt(e)+(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,e=(this.lo>>>28|this.hi<<4)>>>0,n=this.hi>>>24;return n===0?e===0?t<16384?t<128?1:2:t<2097152?3:4:e<16384?e<128?5:6:e<2097152?7:8:n<128?9:10}static fromBigInt(t){if(t===0n)return Ze;if(t<Md&&t>Kd)return this.fromNumber(Number(t));let e=t<0n;e&&(t=-t);let n=t>>32n,s=t-(n<<32n);return e&&(n=~n|0n,s=~s|0n,++s>Mc&&(s=0n,++n>Mc&&(n=0n))),new r(Number(s),Number(n))}static fromNumber(t){if(t===0)return Ze;let e=t<0;e&&(t=-t);let n=t>>>0,s=(t-n)/4294967296>>>0;return e&&(s=~s>>>0,n=~n>>>0,++n>4294967295&&(n=0,++s>4294967295&&(s=0))),new r(n,s)}static from(t){return typeof t=="number"?r.fromNumber(t):typeof t=="bigint"?r.fromBigInt(t):typeof t=="string"?r.fromBigInt(BigInt(t)):t.low!=null||t.high!=null?new r(t.low>>>0,t.high>>>0):Ze}},Ze=new Vt(0,0);Ze.toBigInt=function(){return 0n};Ze.zzEncode=Ze.zzDecode=function(){return this};Ze.length=function(){return 1};var Mc=4294967296n;function Kc(r){let t=0,e=0;for(let n=0;n<r.length;++n)e=r.charCodeAt(n),e<128?t+=1:e<2048?t+=2:(e&64512)===55296&&(r.charCodeAt(n+1)&64512)===56320?(++n,t+=4):t+=3;return t}function Fc(r,t,e){if(e-t<1)return"";let s,o=[],i=0,a;for(;t<e;)a=r[t++],a<128?o[i++]=a:a>191&&a<224?o[i++]=(a&31)<<6|r[t++]&63:a>239&&a<365?(a=((a&7)<<18|(r[t++]&63)<<12|(r[t++]&63)<<6|r[t++]&63)-65536,o[i++]=55296+(a>>10),o[i++]=56320+(a&1023)):o[i++]=(a&15)<<12|(r[t++]&63)<<6|r[t++]&63,i>8191&&((s??(s=[])).push(String.fromCharCode.apply(String,o)),i=0);return s!=null?(i>0&&s.push(String.fromCharCode.apply(String,o.slice(0,i))),s.join("")):String.fromCharCode.apply(String,o.slice(0,i))}function ni(r,t,e){let n=e,s,o;for(let i=0;i<r.length;++i)s=r.charCodeAt(i),s<128?t[e++]=s:s<2048?(t[e++]=s>>6|192,t[e++]=s&63|128):(s&64512)===55296&&((o=r.charCodeAt(i+1))&64512)===56320?(s=65536+((s&1023)<<10)+(o&1023),++i,t[e++]=s>>18|240,t[e++]=s>>12&63|128,t[e++]=s>>6&63|128,t[e++]=s&63|128):(t[e++]=s>>12|224,t[e++]=s>>6&63|128,t[e++]=s&63|128);return e-n}function Zt(r,t){return RangeError(`index out of range: ${r.pos} + ${t??1} > ${r.len}`)}function On(r,t){return(r[t-4]|r[t-3]<<8|r[t-2]<<16|r[t-1]<<24)>>>0}var si=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,Zt(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 Zt(this,4);return On(this.buf,this.pos+=4)}sfixed32(){if(this.pos+4>this.len)throw Zt(this,4);return On(this.buf,this.pos+=4)|0}float(){if(this.pos+4>this.len)throw Zt(this,4);let t=Vc(this.buf,this.pos);return this.pos+=4,t}double(){if(this.pos+8>this.len)throw Zt(this,4);let t=Hc(this.buf,this.pos);return this.pos+=8,t}bytes(){let t=this.uint32(),e=this.pos,n=this.pos+t;if(n>this.len)throw Zt(this,t);return this.pos+=t,e===n?new Uint8Array(0):this.buf.subarray(e,n)}string(){let t=this.bytes();return Fc(t,0,t.length)}skip(t){if(typeof t=="number"){if(this.pos+t>this.len)throw Zt(this,t);this.pos+=t}else do if(this.pos>=this.len)throw Zt(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 Vt(0,0),e=0;if(this.len-this.pos>4){for(;e<4;++e)if(t.lo=(t.lo|(this.buf[this.pos]&127)<<e*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;e=0}else{for(;e<3;++e){if(this.pos>=this.len)throw Zt(this);if(t.lo=(t.lo|(this.buf[this.pos]&127)<<e*7)>>>0,this.buf[this.pos++]<128)return t}return t.lo=(t.lo|(this.buf[this.pos++]&127)<<e*7)>>>0,t}if(this.len-this.pos>4){for(;e<5;++e)if(t.hi=(t.hi|(this.buf[this.pos]&127)<<e*7+3)>>>0,this.buf[this.pos++]<128)return t}else for(;e<5;++e){if(this.pos>=this.len)throw Zt(this);if(t.hi=(t.hi|(this.buf[this.pos]&127)<<e*7+3)>>>0,this.buf[this.pos++]<128)return t}throw Error("invalid varint encoding")}readFixed64(){if(this.pos+8>this.len)throw Zt(this,8);let t=On(this.buf,this.pos+=4),e=On(this.buf,this.pos+=4);return new Vt(t,e)}int64(){return this.readLongVarint().toBigInt()}int64Number(){return this.readLongVarint().toNumber()}int64String(){return this.readLongVarint().toString()}uint64(){return this.readLongVarint().toBigInt(!0)}uint64Number(){let t=ti(this.buf,this.pos);return this.pos+=dt(t),t}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 oi(r){return new si(r instanceof Uint8Array?r:r.subarray())}function Xe(r,t,e){let n=oi(r);return t.decode(n,void 0,e)}function ii(r){let t=r??8192,e=t>>>1,n,s=t;return function(i){if(i<1||i>e)return wt(i);s+i>t&&(n=wt(t),s=0);let a=n.subarray(s,s+=i);return s&7&&(s=(s|7)+1),a}}var Je=class{fn;len;next;val;constructor(t,e,n){this.fn=t,this.len=e,this.next=void 0,this.val=n}};function ai(){}var li=class{head;tail;len;next;constructor(t){this.head=t.head,this.tail=t.tail,this.len=t.len,this.next=t.states}},Fd=ii();function $d(r){return globalThis.Buffer!=null?wt(r):Fd(r)}var Qr=class{len;head;tail;states;constructor(){this.len=0,this.head=new Je(ai,0,0),this.tail=this.head,this.states=null}_push(t,e,n){return this.tail=this.tail.next=new Je(t,e,n),this.len+=e,this}uint32(t){return this.len+=(this.tail=this.tail.next=new ui((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(Hn,10,Vt.fromNumber(t)):this.uint32(t)}sint32(t){return this.uint32((t<<1^t>>31)>>>0)}uint64(t){let e=Vt.fromBigInt(t);return this._push(Hn,e.length(),e)}uint64Number(t){return this._push(Qo,dt(t),t)}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 e=Vt.fromBigInt(t).zzEncode();return this._push(Hn,e.length(),e)}sint64Number(t){let e=Vt.fromNumber(t).zzEncode();return this._push(Hn,e.length(),e)}sint64String(t){return this.sint64(BigInt(t))}bool(t){return this._push(ci,1,t?1:0)}fixed32(t){return this._push(Jr,4,t>>>0)}sfixed32(t){return this.fixed32(t)}fixed64(t){let e=Vt.fromBigInt(t);return this._push(Jr,4,e.lo)._push(Jr,4,e.hi)}fixed64Number(t){let e=Vt.fromNumber(t);return this._push(Jr,4,e.lo)._push(Jr,4,e.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(Dc,4,t)}double(t){return this._push(Oc,8,t)}bytes(t){let e=t.length>>>0;return e===0?this._push(ci,1,0):this.uint32(e)._push(Gd,e,t)}string(t){let e=Kc(t);return e!==0?this.uint32(e)._push(ni,e,t):this._push(ci,1,0)}fork(){return this.states=new li(this),this.head=this.tail=new Je(ai,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 Je(ai,0,0),this.len=0),this}ldelim(){let t=this.head,e=this.tail,n=this.len;return this.reset().uint32(n),n!==0&&(this.tail.next=t.next,this.tail=e,this.len+=n),this}finish(){let t=this.head.next,e=$d(this.len),n=0;for(;t!=null;)t.fn(t.val,e,n),n+=t.len,t=t.next;return e}};function ci(r,t,e){t[e]=r&255}function qd(r,t,e){for(;r>127;)t[e++]=r&127|128,r>>>=7;t[e]=r}var ui=class extends Je{next;constructor(t,e){super(qd,t,e),this.next=void 0}};function Hn(r,t,e){for(;r.hi!==0;)t[e++]=r.lo&127|128,r.lo=(r.lo>>>7|r.hi<<25)>>>0,r.hi>>>=7;for(;r.lo>127;)t[e++]=r.lo&127|128,r.lo=r.lo>>>7;t[e++]=r.lo}function Jr(r,t,e){t[e]=r&255,t[e+1]=r>>>8&255,t[e+2]=r>>>16&255,t[e+3]=r>>>24}function Gd(r,t,e){t.set(r,e)}globalThis.Buffer!=null&&(Qr.prototype.bytes=function(r){let t=r.length>>>0;return this.uint32(t),t>0&&this._push(jd,t,r),this},Qr.prototype.string=function(r){let t=globalThis.Buffer.byteLength(r);return this.uint32(t),t>0&&this._push(zd,t,r),this});function jd(r,t,e){t.set(r,e)}function zd(r,t,e){r.length<40?ni(r,t,e):t.utf8Write!=null?t.utf8Write(r,e):t.set(et(r),e)}function fi(){return new Qr}function Qe(r,t){let e=fi();return t.encode(r,e,{lengthDelimited:!1}),e.finish()}var vr;(function(r){r[r.VARINT=0]="VARINT",r[r.BIT64=1]="BIT64",r[r.LENGTH_DELIMITED=2]="LENGTH_DELIMITED",r[r.START_GROUP=3]="START_GROUP",r[r.END_GROUP=4]="END_GROUP",r[r.BIT32=5]="BIT32"})(vr||(vr={}));function Mn(r,t,e,n){return{name:r,type:t,encode:e,decode:n}}function hi(r){function t(s){if(r[s.toString()]==null)throw new Error("Invalid enum value");return r[s]}let e=function(o,i){let a=t(o);i.int32(a)},n=function(o){let i=o.int32();return t(i)};return Mn("enum",vr.VARINT,e,n)}function tr(r,t){return Mn("message",vr.LENGTH_DELIMITED,r,t)}var at;(function(r){r.RSA="RSA",r.Ed25519="Ed25519",r.Secp256k1="Secp256k1"})(at||(at={}));var di;(function(r){r[r.RSA=0]="RSA",r[r.Ed25519=1]="Ed25519",r[r.Secp256k1=2]="Secp256k1"})(di||(di={}));(function(r){r.codec=()=>hi(di)})(at||(at={}));var se;(function(r){let t;r.codec=()=>(t==null&&(t=tr((e,n,s={})=>{s.lengthDelimited!==!1&&n.fork(),e.Type!=null&&(n.uint32(8),at.codec().encode(e.Type,n)),e.Data!=null&&(n.uint32(18),n.bytes(e.Data)),s.lengthDelimited!==!1&&n.ldelim()},(e,n)=>{let s={},o=n==null?e.len:e.pos+n;for(;e.pos<o;){let i=e.uint32();switch(i>>>3){case 1:s.Type=at.codec().decode(e);break;case 2:s.Data=e.bytes();break;default:e.skipType(i&7);break}}return s})),t),r.encode=e=>Qe(e,r.codec()),r.decode=e=>Xe(e,r.codec())})(se||(se={}));var oe;(function(r){let t;r.codec=()=>(t==null&&(t=tr((e,n,s={})=>{s.lengthDelimited!==!1&&n.fork(),e.Type!=null&&(n.uint32(8),at.codec().encode(e.Type,n)),e.Data!=null&&(n.uint32(18),n.bytes(e.Data)),s.lengthDelimited!==!1&&n.ldelim()},(e,n)=>{let s={},o=n==null?e.len:e.pos+n;for(;e.pos<o;){let i=e.uint32();switch(i>>>3){case 1:s.Type=at.codec().decode(e);break;case 2:s.Data=e.bytes();break;default:e.skipType(i&7);break}}return s})),t),r.encode=e=>Qe(e,r.codec()),r.decode=e=>Xe(e,r.codec())})(oe||(oe={}));var tn=class{_key;constructor(t){this._key=Br(t,xr)}verify(t,e){return Cc(this._key,e,t)}marshal(){return this._key}get bytes(){return se.encode({Type:at.Ed25519,Data:this.marshal()}).subarray()}equals(t){return ft(this.bytes,t.bytes)}hash(){let t=At.digest(this.bytes);return Ht(t)?t.then(({bytes:e})=>e):t.bytes}},er=class{_key;_publicKey;constructor(t,e){this._key=Br(t,be),this._publicKey=Br(e,xr)}sign(t){return Lc(this._key,t)}get public(){return new tn(this._publicKey)}marshal(){return this._key}get bytes(){return oe.encode({Type:at.Ed25519,Data:this.marshal()}).subarray()}equals(t){return ft(this.bytes,t.bytes)}async hash(){let t=At.digest(this.bytes),e;return Ht(t)?{bytes:e}=await t:e=t.bytes,e}async id(){let t=Te.digest(this.public.bytes);return ut.encode(t.bytes).substring(1)}async export(t,e="libp2p-key"){if(e==="libp2p-key")return Er(this.bytes,t);throw new F(`export format '${e}' is not supported`,"ERR_INVALID_EXPORT_FORMAT")}};function Wd(r){if(r.length>be){r=Br(r,be+xr);let n=r.subarray(0,be),s=r.subarray(be,r.length);return new er(n,s)}r=Br(r,be);let t=r.subarray(0,be),e=r.subarray(xr);return new er(t,e)}function Yd(r){return r=Br(r,xr),new tn(r)}async function Zd(){let{privateKey:r,publicKey:t}=Tc();return new er(r,t)}async function qc(r){let{privateKey:t,publicKey:e}=Rc(r);return new er(t,e)}function Br(r,t){if(r=Uint8Array.from(r??[]),r.length!==t)throw new F(`Key must be a Uint8Array of length ${t}, got ${r.length}`,"ERR_INVALID_KEY_TYPE");return r}function q(r,t="utf8"){let e=Sn[t];if(e==null)throw new Error(`Unsupported encoding "${t}"`);return e.encoder.encode(r).substring(1)}var Ai={};yt(Ai,{MAX_RSA_KEY_SIZE:()=>hn,RsaPrivateKey:()=>_r,RsaPublicKey:()=>fn,fromJwk:()=>B0,generateKeyPair:()=>A0,unmarshalRsaPrivateKey:()=>vi,unmarshalRsaPublicKey:()=>v0});function rr(r){if(isNaN(r)||r<=0)throw new F("random bytes length must be a Number bigger than 0","ERR_INVALID_LENGTH");return ze(r)}var Ke={};yt(Ke,{exportToPem:()=>m0,importFromPem:()=>w0,jwkToPkcs1:()=>d0,jwkToPkix:()=>g0,pkcs1ToJwk:()=>h0,pkixToJwk:()=>p0});var Fn=class extends pr{constructor(t,e){super(),this.finished=!1,this.destroyed=!1,je(t);let n=jt(e);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 s=this.blockLen,o=new Uint8Array(s);o.set(n.length>s?t.create().update(n).digest():n);for(let i=0;i<o.length;i++)o[i]^=54;this.iHash.update(o),this.oHash=t.create();for(let i=0;i<o.length;i++)o[i]^=106;this.oHash.update(o),o.fill(0)}update(t){return dr(this),this.iHash.update(t),this}digestInto(t){dr(this),hr(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:e,iHash:n,finished:s,destroyed:o,blockLen:i,outputLen:a}=this;return t=t,t.finished=s,t.destroyed=o,t.blockLen=i,t.outputLen=a,t.oHash=e._cloneInto(t.oHash),t.iHash=n._cloneInto(t.iHash),t}destroy(){this.destroyed=!0,this.oHash.destroy(),this.iHash.destroy()}},Ve=(r,t,e)=>new Fn(r,t).update(e).digest();Ve.create=(r,t)=>new Fn(r,t);function Xd(r,t,e,n){je(r);let s=lc({dkLen:32,asyncTick:10},n),{c:o,dkLen:i,asyncTick:a}=s;if(Re(o),Re(i),Re(a),o<1)throw new Error("PBKDF2: iterations (c) should be >= 1");let c=jt(t),l=jt(e),u=new Uint8Array(i),f=Ve.create(r,c),g=f._cloneInto().update(l);return{c:o,dkLen:i,asyncTick:a,DK:u,PRF:f,PRFSalt:g}}function Jd(r,t,e,n,s){return r.destroy(),t.destroy(),n&&n.destroy(),s.fill(0),e}async function gi(r,t,e,n){let{c:s,dkLen:o,asyncTick:i,DK:a,PRF:c,PRFSalt:l}=Xd(r,t,e,n),u,f=new Uint8Array(4),g=gr(f),m=new Uint8Array(c.outputLen);for(let d=1,h=0;h<o;d++,h+=c.outputLen){let p=a.subarray(h,h+c.outputLen);g.setInt32(0,d,!1),(u=l._cloneInto(u)).update(f).digestInto(m),p.set(m.subarray(0,p.length)),await cc(s-1,i,()=>{c._cloneInto(u).update(m).digestInto(m);for(let b=0;b<p.length;b++)p[b]^=m[b]})}return Jd(c,l,a,u,m)}var Y=Oa(Gc());function nr(r,t){let e=0;if(r.length===1)return r[0];for(let n=r.length-1;n>=0;n--)e+=r[r.length-1-n]*Math.pow(2,t*n);return e}function Oe(r,t,e=-1){let n=e,s=r,o=0,i=Math.pow(2,t);for(let a=1;a<8;a++){if(r<i){let c;if(n<0)c=new ArrayBuffer(a),o=a;else{if(n<a)return new ArrayBuffer(0);c=new ArrayBuffer(n),o=n}let l=new Uint8Array(c);for(let u=a-1;u>=0;u--){let f=Math.pow(2,u*t);l[o-u-1]=Math.floor(s/f),s-=l[o-u-1]*f}return c}i*=Math.pow(2,t)}return new ArrayBuffer(0)}function Gn(...r){let t=0,e=0;for(let o of r)t+=o.length;let n=new ArrayBuffer(t),s=new Uint8Array(n);for(let o of r)s.set(o,e),e+=o.length;return s}function mi(){let r=new Uint8Array(this.valueHex);if(this.valueHex.byteLength>=2){let a=r[0]===255&&r[1]&128,c=r[0]===0&&(r[1]&128)===0;(a||c)&&this.warnings.push("Needlessly long format")}let t=new ArrayBuffer(this.valueHex.byteLength),e=new Uint8Array(t);for(let a=0;a<this.valueHex.byteLength;a++)e[a]=0;e[0]=r[0]&128;let n=nr(e,8),s=new ArrayBuffer(this.valueHex.byteLength),o=new Uint8Array(s);for(let a=0;a<this.valueHex.byteLength;a++)o[a]=r[a];return o[0]&=127,nr(o,8)-n}function jc(r){let t=r<0?r*-1:r,e=128;for(let n=1;n<8;n++){if(t<=e){if(r<0){let i=e-t,a=Oe(i,8,n),c=new Uint8Array(a);return c[0]|=128,a}let s=Oe(t,8,n),o=new Uint8Array(s);if(o[0]&128){let i=s.slice(0),a=new Uint8Array(i);s=new ArrayBuffer(s.byteLength+1),o=new Uint8Array(s);for(let c=0;c<i.byteLength;c++)o[c+1]=a[c];o[0]=0}return s}e*=Math.pow(2,8)}return new ArrayBuffer(0)}function zc(r,t){if(r.byteLength!==t.byteLength)return!1;let e=new Uint8Array(r),n=new Uint8Array(t);for(let s=0;s<e.length;s++)if(e[s]!==n[s])return!1;return!0}function Pt(r,t){let e=r.toString(10);if(t<e.length)return"";let n=t-e.length,s=new Array(n);for(let i=0;i<n;i++)s[i]="0";return s.join("").concat(e)}var Gm=Math.log(2);function jn(){if(typeof BigInt>"u")throw new Error("BigInt is not defined. Your environment doesn't implement BigInt.")}function wi(r){let t=0,e=0;for(let s=0;s<r.length;s++){let o=r[s];t+=o.byteLength}let n=new Uint8Array(t);for(let s=0;s<r.length;s++){let o=r[s];n.set(new Uint8Array(o),e),e+=o.byteLength}return n.buffer}function Ae(r,t,e,n){return t instanceof Uint8Array?t.byteLength?e<0?(r.error="Wrong parameter: inputOffset less than zero",!1):n<0?(r.error="Wrong parameter: inputLength less than zero",!1):t.byteLength-e-n<0?(r.error="End of input reached before message was fully decoded (inconsistent offset and length values)",!1):!0:(r.error="Wrong parameter: inputBuffer has zero length",!1):(r.error="Wrong parameter: inputBuffer must be 'Uint8Array'",!1)}var rn=class{constructor(){this.items=[]}write(t){this.items.push(t)}final(){return wi(this.items)}},en=[new Uint8Array([1])],Wc="0123456789";var kr="",Jt=new ArrayBuffer(0),bi=new Uint8Array(0),nn="EndOfContent",Zc="OCTET STRING",Xc="BIT STRING";function Se(r){var t;return t=class extends r{constructor(...n){var s;super(...n);let o=n[0]||{};this.isHexOnly=(s=o.isHexOnly)!==null&&s!==void 0?s:!1,this.valueHexView=o.valueHex?Y.BufferSourceConverter.toUint8Array(o.valueHex):bi}get valueHex(){return this.valueHexView.slice().buffer}set valueHex(n){this.valueHexView=new Uint8Array(n)}fromBER(n,s,o){let i=n instanceof ArrayBuffer?new Uint8Array(n):n;if(!Ae(this,i,s,o))return-1;let a=s+o;return this.valueHexView=i.subarray(s,a),this.valueHexView.length?(this.blockLength=o,a):(this.warnings.push("Zero buffer length"),s)}toBER(n=!1){return this.isHexOnly?n?new ArrayBuffer(this.valueHexView.byteLength):this.valueHexView.byteLength===this.valueHexView.buffer.byteLength?this.valueHexView.buffer:this.valueHexView.slice().buffer:(this.error="Flag 'isHexOnly' is not set, abort",Jt)}toJSON(){return{...super.toJSON(),isHexOnly:this.isHexOnly,valueHex:Y.Convert.ToHex(this.valueHexView)}}},t.NAME="hexBlock",t}var Ee=class{constructor({blockLength:t=0,error:e=kr,warnings:n=[],valueBeforeDecode:s=bi}={}){this.blockLength=t,this.error=e,this.warnings=n,this.valueBeforeDecodeView=Y.BufferSourceConverter.toUint8Array(s)}static blockName(){return this.NAME}get valueBeforeDecode(){return this.valueBeforeDecodeView.slice().buffer}set valueBeforeDecode(t){this.valueBeforeDecodeView=new Uint8Array(t)}toJSON(){return{blockName:this.constructor.NAME,blockLength:this.blockLength,error:this.error,warnings:this.warnings,valueBeforeDecode:Y.Convert.ToHex(this.valueBeforeDecodeView)}}};Ee.NAME="baseBlock";var Lt=class extends Ee{fromBER(t,e,n){throw TypeError("User need to make a specific function in a class which extends 'ValueBlock'")}toBER(t,e){throw TypeError("User need to make a specific function in a class which extends 'ValueBlock'")}};Lt.NAME="valueBlock";var zn=class extends Se(Ee){constructor({idBlock:t={}}={}){var e,n,s,o;super(),t?(this.isHexOnly=(e=t.isHexOnly)!==null&&e!==void 0?e:!1,this.valueHexView=t.valueHex?Y.BufferSourceConverter.toUint8Array(t.valueHex):bi,this.tagClass=(n=t.tagClass)!==null&&n!==void 0?n:-1,this.tagNumber=(s=t.tagNumber)!==null&&s!==void 0?s:-1,this.isConstructed=(o=t.isConstructed)!==null&&o!==void 0?o:!1):(this.tagClass=-1,this.tagNumber=-1,this.isConstructed=!1)}toBER(t=!1){let e=0;switch(this.tagClass){case 1:e|=0;break;case 2:e|=64;break;case 3:e|=128;break;case 4:e|=192;break;default:return this.error="Unknown tag class",Jt}if(this.isConstructed&&(e|=32),this.tagNumber<31&&!this.isHexOnly){let s=new Uint8Array(1);if(!t){let o=this.tagNumber;o&=31,e|=o,s[0]=e}return s.buffer}if(!this.isHexOnly){let s=Oe(this.tagNumber,7),o=new Uint8Array(s),i=s.byteLength,a=new Uint8Array(i+1);if(a[0]=e|31,!t){for(let c=0;c<i-1;c++)a[c+1]=o[c]|128;a[i]=o[i-1]}return a.buffer}let n=new Uint8Array(this.valueHexView.byteLength+1);if(n[0]=e|31,!t){let s=this.valueHexView;for(let o=0;o<s.length-1;o++)n[o+1]=s[o]|128;n[this.valueHexView.byteLength]=s[s.length-1]}return n.buffer}fromBER(t,e,n){let s=Y.BufferSourceConverter.toUint8Array(t);if(!Ae(this,s,e,n))return-1;let o=s.subarray(e,e+n);if(o.length===0)return this.error="Zero buffer length",-1;switch(o[0]&192){case 0:this.tagClass=1;break;case 64:this.tagClass=2;break;case 128:this.tagClass=3;break;case 192:this.tagClass=4;break;default:return this.error="Unknown tag class",-1}this.isConstructed=(o[0]&32)===32,this.isHexOnly=!1;let a=o[0]&31;if(a!==31)this.tagNumber=a,this.blockLength=1;else{let c=1,l=this.valueHexView=new Uint8Array(255),u=255;for(;o[c]&128;){if(l[c-1]=o[c]&127,c++,c>=o.length)return this.error="End of input reached before message was fully decoded",-1;if(c===u){u+=255;let g=new Uint8Array(u);for(let m=0;m<l.length;m++)g[m]=l[m];l=this.valueHexView=new Uint8Array(u)}}this.blockLength=c+1,l[c-1]=o[c]&127;let f=new Uint8Array(c);for(let g=0;g<c;g++)f[g]=l[g];l=this.valueHexView=new Uint8Array(c),l.set(f),this.blockLength<=9?this.tagNumber=nr(l,7):(this.isHexOnly=!0,this.warnings.push("Tag too long, represented as hex-coded"))}if(this.tagClass===1&&this.isConstructed)switch(this.tagNumber){case 1:case 2:case 5:case 6:case 9:case 13:case 14:case 23:case 24:case 31:case 32:case 33:case 34:return this.error="Constructed encoding used for primitive type",-1}return e+this.blockLength}toJSON(){return{...super.toJSON(),tagClass:this.tagClass,tagNumber:this.tagNumber,isConstructed:this.isConstructed}}};zn.NAME="identificationBlock";var Wn=class extends Ee{constructor({lenBlock:t={}}={}){var e,n,s;super(),this.isIndefiniteForm=(e=t.isIndefiniteForm)!==null&&e!==void 0?e:!1,this.longFormUsed=(n=t.longFormUsed)!==null&&n!==void 0?n:!1,this.length=(s=t.length)!==null&&s!==void 0?s:0}fromBER(t,e,n){let s=Y.BufferSourceConverter.toUint8Array(t);if(!Ae(this,s,e,n))return-1;let o=s.subarray(e,e+n);if(o.length===0)return this.error="Zero buffer length",-1;if(o[0]===255)return this.error="Length block 0xFF is reserved by standard",-1;if(this.isIndefiniteForm=o[0]===128,this.isIndefiniteForm)return this.blockLength=1,e+this.blockLength;if(this.longFormUsed=!!(o[0]&128),this.longFormUsed===!1)return this.length=o[0],this.blockLength=1,e+this.blockLength;let i=o[0]&127;if(i>8)return this.error="Too big integer",-1;if(i+1>o.length)return this.error="End of input reached before message was fully decoded",-1;let a=e+1,c=s.subarray(a,a+i);return c[i-1]===0&&this.warnings.push("Needlessly long encoded length"),this.length=nr(c,8),this.longFormUsed&&this.length<=127&&this.warnings.push("Unnecessary usage of long length form"),this.blockLength=i+1,e+this.blockLength}toBER(t=!1){let e,n;if(this.length>127&&(this.longFormUsed=!0),this.isIndefiniteForm)return e=new ArrayBuffer(1),t===!1&&(n=new Uint8Array(e),n[0]=128),e;if(this.longFormUsed){let s=Oe(this.length,8);if(s.byteLength>127)return this.error="Too big length",Jt;if(e=new ArrayBuffer(s.byteLength+1),t)return e;let o=new Uint8Array(s);n=new Uint8Array(e),n[0]=s.byteLength|128;for(let i=0;i<s.byteLength;i++)n[i+1]=o[i];return e}return e=new ArrayBuffer(1),t===!1&&(n=new Uint8Array(e),n[0]=this.length),e}toJSON(){return{...super.toJSON(),isIndefiniteForm:this.isIndefiniteForm,longFormUsed:this.longFormUsed,length:this.length}}};Wn.NAME="lengthBlock";var U={},St=class extends Ee{constructor({name:t=kr,optional:e=!1,primitiveSchema:n,...s}={},o){super(s),this.name=t,this.optional=e,n&&(this.primitiveSchema=n),this.idBlock=new zn(s),this.lenBlock=new Wn(s),this.valueBlock=o?new o(s):new Lt(s)}fromBER(t,e,n){let s=this.valueBlock.fromBER(t,e,this.lenBlock.isIndefiniteForm?n:this.lenBlock.length);return s===-1?(this.error=this.valueBlock.error,s):(this.idBlock.error.length||(this.blockLength+=this.idBlock.blockLength),this.lenBlock.error.length||(this.blockLength+=this.lenBlock.blockLength),this.valueBlock.error.length||(this.blockLength+=this.valueBlock.blockLength),s)}toBER(t,e){let n=e||new rn;e||Jc(this);let s=this.idBlock.toBER(t);if(n.write(s),this.lenBlock.isIndefiniteForm)n.write(new Uint8Array([128]).buffer),this.valueBlock.toBER(t,n),n.write(new ArrayBuffer(2));else{let o=this.valueBlock.toBER(t);this.lenBlock.length=o.byteLength;let i=this.lenBlock.toBER(t);n.write(i),n.write(o)}return e?Jt:n.final()}toJSON(){let t={...super.toJSON(),idBlock:this.idBlock.toJSON(),lenBlock:this.lenBlock.toJSON(),valueBlock:this.valueBlock.toJSON(),name:this.name,optional:this.optional};return this.primitiveSchema&&(t.primitiveSchema=this.primitiveSchema.toJSON()),t}toString(t="ascii"){return t==="ascii"?this.onAsciiEncoding():Y.Convert.ToHex(this.toBER())}onAsciiEncoding(){return`${this.constructor.NAME} : ${Y.Convert.ToHex(this.valueBlock.valueBeforeDecodeView)}`}isEqual(t){if(this===t)return!0;if(!(t instanceof this.constructor))return!1;let e=this.toBER(),n=t.toBER();return zc(e,n)}};St.NAME="BaseBlock";function Jc(r){if(r instanceof U.Constructed)for(let t of r.valueBlock.value)Jc(t)&&(r.lenBlock.isIndefiniteForm=!0);return!!r.lenBlock.isIndefiniteForm}var Yn=class extends St{constructor({value:t=kr,...e}={},n){super(e,n),t&&this.fromString(t)}getValue(){return this.valueBlock.value}setValue(t){this.valueBlock.value=t}fromBER(t,e,n){let s=this.valueBlock.fromBER(t,e,this.lenBlock.isIndefiniteForm?n:this.lenBlock.length);return s===-1?(this.error=this.valueBlock.error,s):(this.fromBuffer(this.valueBlock.valueHexView),this.idBlock.error.length||(this.blockLength+=this.idBlock.blockLength),this.lenBlock.error.length||(this.blockLength+=this.lenBlock.blockLength),this.valueBlock.error.length||(this.blockLength+=this.valueBlock.blockLength),s)}onAsciiEncoding(){return`${this.constructor.NAME} : '${this.valueBlock.value}'`}};Yn.NAME="BaseStringBlock";var Zn=class extends Se(Lt){constructor({isHexOnly:t=!0,...e}={}){super(e),this.isHexOnly=t}};Zn.NAME="PrimitiveValueBlock";var Qc,Xn=class extends St{constructor(t={}){super(t,Zn),this.idBlock.isConstructed=!1}};Qc=Xn;U.Primitive=Qc;Xn.NAME="PRIMITIVE";function a0(r,t){if(r instanceof t)return r;let e=new t;return e.idBlock=r.idBlock,e.lenBlock=r.lenBlock,e.warnings=r.warnings,e.valueBeforeDecodeView=r.valueBeforeDecodeView,e}function Ts(r,t=0,e=r.length){let n=t,s=new St({},Lt),o=new Ee;if(!Ae(o,r,t,e))return s.error=o.error,{offset:-1,result:s};if(!r.subarray(t,t+e).length)return s.error="Zero buffer length",{offset:-1,result:s};let a=s.idBlock.fromBER(r,t,e);if(s.idBlock.warnings.length&&s.warnings.concat(s.idBlock.warnings),a===-1)return s.error=s.idBlock.error,{offset:-1,result:s};if(t=a,e-=s.idBlock.blockLength,a=s.lenBlock.fromBER(r,t,e),s.lenBlock.warnings.length&&s.warnings.concat(s.lenBlock.warnings),a===-1)return s.error=s.lenBlock.error,{offset:-1,result:s};if(t=a,e-=s.lenBlock.blockLength,!s.idBlock.isConstructed&&s.lenBlock.isIndefiniteForm)return s.error="Indefinite length form used for primitive encoding form",{offset:-1,result:s};let c=St;switch(s.idBlock.tagClass){case 1:if(s.idBlock.tagNumber>=37&&s.idBlock.isHexOnly===!1)return s.error="UNIVERSAL 37 and upper tags are reserved by ASN.1 standard",{offset:-1,result:s};switch(s.idBlock.tagNumber){case 0:if(s.idBlock.isConstructed&&s.lenBlock.length>0)return s.error="Type [UNIVERSAL 0] is reserved",{offset:-1,result:s};c=U.EndOfContent;break;case 1:c=U.Boolean;break;case 2:c=U.Integer;break;case 3:c=U.BitString;break;case 4:c=U.OctetString;break;case 5:c=U.Null;break;case 6:c=U.ObjectIdentifier;break;case 10:c=U.Enumerated;break;case 12:c=U.Utf8String;break;case 13:c=U.RelativeObjectIdentifier;break;case 14:c=U.TIME;break;case 15:return s.error="[UNIVERSAL 15] is reserved by ASN.1 standard",{offset:-1,result:s};case 16:c=U.Sequence;break;case 17:c=U.Set;break;case 18:c=U.NumericString;break;case 19:c=U.PrintableString;break;case 20:c=U.TeletexString;break;case 21:c=U.VideotexString;break;case 22:c=U.IA5String;break;case 23:c=U.UTCTime;break;case 24:c=U.GeneralizedTime;break;case 25:c=U.GraphicString;break;case 26:c=U.VisibleString;break;case 27:c=U.GeneralString;break;case 28:c=U.UniversalString;break;case 29:c=U.CharacterString;break;case 30:c=U.BmpString;break;case 31:c=U.DATE;break;case 32:c=U.TimeOfDay;break;case 33:c=U.DateTime;break;case 34:c=U.Duration;break;default:{let l=s.idBlock.isConstructed?new U.Constructed:new U.Primitive;l.idBlock=s.idBlock,l.lenBlock=s.lenBlock,l.warnings=s.warnings,s=l}}break;case 2:case 3:case 4:default:c=s.idBlock.isConstructed?U.Constructed:U.Primitive}return s=a0(s,c),a=s.fromBER(r,t,s.lenBlock.isIndefiniteForm?e:s.lenBlock.length),s.valueBeforeDecodeView=r.subarray(n,n+s.blockLength),{offset:a,result:s}}function Ir(r){if(!r.byteLength){let t=new St({},Lt);return t.error="Input buffer has zero length",{offset:-1,result:t}}return Ts(Y.BufferSourceConverter.toUint8Array(r).slice(),0,r.byteLength)}function c0(r,t){return r?1:t}var ie=class extends Lt{constructor({value:t=[],isIndefiniteForm:e=!1,...n}={}){super(n),this.value=t,this.isIndefiniteForm=e}fromBER(t,e,n){let s=Y.BufferSourceConverter.toUint8Array(t);if(!Ae(this,s,e,n))return-1;if(this.valueBeforeDecodeView=s.subarray(e,e+n),this.valueBeforeDecodeView.length===0)return this.warnings.push("Zero buffer length"),e;let o=e;for(;c0(this.isIndefiniteForm,n)>0;){let i=Ts(s,o,n);if(i.offset===-1)return this.error=i.result.error,this.warnings.concat(i.result.warnings),-1;if(o=i.offset,this.blockLength+=i.result.blockLength,n-=i.result.blockLength,this.value.push(i.result),this.isIndefiniteForm&&i.result.constructor.NAME===nn)break}return this.isIndefiniteForm&&(this.value[this.value.length-1].constructor.NAME===nn?this.value.pop():this.warnings.push("No EndOfContent block encoded")),o}toBER(t,e){let n=e||new rn;for(let s=0;s<this.value.length;s++)this.value[s].toBER(t,n);return e?Jt:n.final()}toJSON(){let t={...super.toJSON(),isIndefiniteForm:this.isIndefiniteForm,value:[]};for(let e of this.value)t.value.push(e.toJSON());return t}};ie.NAME="ConstructedValueBlock";var tl,He=class extends St{constructor(t={}){super(t,ie),this.idBlock.isConstructed=!0}fromBER(t,e,n){this.valueBlock.isIndefiniteForm=this.lenBlock.isIndefiniteForm;let s=this.valueBlock.fromBER(t,e,this.lenBlock.isIndefiniteForm?n:this.lenBlock.length);return s===-1?(this.error=this.valueBlock.error,s):(this.idBlock.error.length||(this.blockLength+=this.idBlock.blockLength),this.lenBlock.error.length||(this.blockLength+=this.lenBlock.blockLength),this.valueBlock.error.length||(this.blockLength+=this.valueBlock.blockLength),s)}onAsciiEncoding(){let t=[];for(let n of this.valueBlock.value)t.push(n.toString("ascii").split(`
3
3
  `).map(s=>` ${s}`).join(`
4
4
  `));let e=this.idBlock.tagClass===3?`[${this.idBlock.tagNumber}]`:this.constructor.NAME;return t.length?`${e} :
5
5
  ${t.join(`
6
- `)}`:`${e} :`}};Qc=He;U.Constructed=Qc;He.NAME="CONSTRUCTED";var Jn=class extends Rt{fromBER(t,e,n){return e}toBER(t){return Jt}};Jn.override="EndOfContentValueBlock";var tl,Qn=class extends St{constructor(t={}){super(t,Jn),this.idBlock.tagClass=1,this.idBlock.tagNumber=0}};tl=Qn;U.EndOfContent=tl;Qn.NAME=nn;var el,Me=class extends St{constructor(t={}){super(t,Rt),this.idBlock.tagClass=1,this.idBlock.tagNumber=5}fromBER(t,e,n){return this.lenBlock.length>0&&this.warnings.push("Non-zero length of value block for Null type"),this.idBlock.error.length||(this.blockLength+=this.idBlock.blockLength),this.lenBlock.error.length||(this.blockLength+=this.lenBlock.blockLength),this.blockLength+=n,e+n>t.byteLength?(this.error="End of input reached before message was fully decoded (inconsistent offset and length values)",-1):e+n}toBER(t,e){let n=new ArrayBuffer(2);if(!t){let s=new Uint8Array(n);s[0]=5,s[1]=0}return e&&e.write(n),n}onAsciiEncoding(){return`${this.constructor.NAME}`}};el=Me;U.Null=el;Me.NAME="NULL";var ts=class extends Se(Rt){constructor({value:t,...e}={}){super(e),e.valueHex?this.valueHexView=Y.BufferSourceConverter.toUint8Array(e.valueHex):this.valueHexView=new Uint8Array(1),t&&(this.value=t)}get value(){for(let t of this.valueHexView)if(t>0)return!0;return!1}set value(t){this.valueHexView[0]=t?255:0}fromBER(t,e,n){let s=Y.BufferSourceConverter.toUint8Array(t);return Ae(this,s,e,n)?(this.valueHexView=s.subarray(e,e+n),n>1&&this.warnings.push("Boolean value encoded in more then 1 octet"),this.isHexOnly=!0,mi.call(this),this.blockLength=n,e+n):-1}toBER(){return this.valueHexView.slice()}toJSON(){return{...super.toJSON(),value:this.value}}};ts.NAME="BooleanValueBlock";var rl,es=class extends St{constructor(t={}){super(t,ts),this.idBlock.tagClass=1,this.idBlock.tagNumber=1}getValue(){return this.valueBlock.value}setValue(t){this.valueBlock.value=t}onAsciiEncoding(){return`${this.constructor.NAME} : ${this.getValue}`}};rl=es;U.Boolean=rl;es.NAME="BOOLEAN";var rs=class extends Se(ie){constructor({isConstructed:t=!1,...e}={}){super(e),this.isConstructed=t}fromBER(t,e,n){let s=0;if(this.isConstructed){if(this.isHexOnly=!1,s=ie.prototype.fromBER.call(this,t,e,n),s===-1)return s;for(let o=0;o<this.value.length;o++){let i=this.value[o].constructor.NAME;if(i===nn){if(this.isIndefiniteForm)break;return this.error="EndOfContent is unexpected, OCTET STRING may consists of OCTET STRINGs only",-1}if(i!==Yc)return this.error="OCTET STRING may consists of OCTET STRINGs only",-1}}else this.isHexOnly=!0,s=super.fromBER(t,e,n),this.blockLength=n;return s}toBER(t,e){return this.isConstructed?ie.prototype.toBER.call(this,t,e):t?new ArrayBuffer(this.valueHexView.byteLength):this.valueHexView.slice().buffer}toJSON(){return{...super.toJSON(),isConstructed:this.isConstructed}}};rs.NAME="OctetStringValueBlock";var nl,ve=class r extends St{constructor({idBlock:t={},lenBlock:e={},...n}={}){var s,o;(s=n.isConstructed)!==null&&s!==void 0||(n.isConstructed=!!(!((o=n.value)===null||o===void 0)&&o.length)),super({idBlock:{isConstructed:n.isConstructed,...t},lenBlock:{...e,isIndefiniteForm:!!n.isIndefiniteForm},...n},rs),this.idBlock.tagClass=1,this.idBlock.tagNumber=4}fromBER(t,e,n){if(this.valueBlock.isConstructed=this.idBlock.isConstructed,this.valueBlock.isIndefiniteForm=this.lenBlock.isIndefiniteForm,n===0)return this.idBlock.error.length===0&&(this.blockLength+=this.idBlock.blockLength),this.lenBlock.error.length===0&&(this.blockLength+=this.lenBlock.blockLength),e;if(!this.valueBlock.isConstructed){let o=(t instanceof ArrayBuffer?new Uint8Array(t):t).subarray(e,e+n);try{if(o.byteLength){let i=Ts(o,0,o.byteLength);i.offset!==-1&&i.offset===n&&(this.valueBlock.value=[i.result])}}catch{}}return super.fromBER(t,e,n)}onAsciiEncoding(){return this.valueBlock.isConstructed||this.valueBlock.value&&this.valueBlock.value.length?He.prototype.onAsciiEncoding.call(this):`${this.constructor.NAME} : ${Y.Convert.ToHex(this.valueBlock.valueHexView)}`}getValue(){if(!this.idBlock.isConstructed)return this.valueBlock.valueHexView.slice().buffer;let t=[];for(let e of this.valueBlock.value)e instanceof r&&t.push(e.valueBlock.valueHexView);return Y.BufferSourceConverter.concat(t)}};nl=ve;U.OctetString=nl;ve.NAME=Yc;var ns=class extends Se(ie){constructor({unusedBits:t=0,isConstructed:e=!1,...n}={}){super(n),this.unusedBits=t,this.isConstructed=e,this.blockLength=this.valueHexView.byteLength}fromBER(t,e,n){if(!n)return e;let s=-1;if(this.isConstructed){if(s=ie.prototype.fromBER.call(this,t,e,n),s===-1)return s;for(let a of this.value){let c=a.constructor.NAME;if(c===nn){if(this.isIndefiniteForm)break;return this.error="EndOfContent is unexpected, BIT STRING may consists of BIT STRINGs only",-1}if(c!==Zc)return this.error="BIT STRING may consists of BIT STRINGs only",-1;let l=a.valueBlock;if(this.unusedBits>0&&l.unusedBits>0)return this.error='Using of "unused bits" inside constructive BIT STRING allowed for least one only',-1;this.unusedBits=l.unusedBits}return s}let o=Y.BufferSourceConverter.toUint8Array(t);if(!Ae(this,o,e,n))return-1;let i=o.subarray(e,e+n);if(this.unusedBits=i[0],this.unusedBits>7)return this.error="Unused bits for BitString must be in range 0-7",-1;if(!this.unusedBits){let a=i.subarray(1);try{if(a.byteLength){let c=Ts(a,0,a.byteLength);c.offset!==-1&&c.offset===n-1&&(this.value=[c.result])}}catch{}}return this.valueHexView=i.subarray(1),this.blockLength=i.length,e+n}toBER(t,e){if(this.isConstructed)return ie.prototype.toBER.call(this,t,e);if(t)return new ArrayBuffer(this.valueHexView.byteLength+1);if(!this.valueHexView.byteLength)return Jt;let n=new Uint8Array(this.valueHexView.length+1);return n[0]=this.unusedBits,n.set(this.valueHexView,1),n.buffer}toJSON(){return{...super.toJSON(),unusedBits:this.unusedBits,isConstructed:this.isConstructed}}};ns.NAME="BitStringValueBlock";var sl,Sr=class extends St{constructor({idBlock:t={},lenBlock:e={},...n}={}){var s,o;(s=n.isConstructed)!==null&&s!==void 0||(n.isConstructed=!!(!((o=n.value)===null||o===void 0)&&o.length)),super({idBlock:{isConstructed:n.isConstructed,...t},lenBlock:{...e,isIndefiniteForm:!!n.isIndefiniteForm},...n},ns),this.idBlock.tagClass=1,this.idBlock.tagNumber=3}fromBER(t,e,n){return this.valueBlock.isConstructed=this.idBlock.isConstructed,this.valueBlock.isIndefiniteForm=this.lenBlock.isIndefiniteForm,super.fromBER(t,e,n)}onAsciiEncoding(){if(this.valueBlock.isConstructed||this.valueBlock.value&&this.valueBlock.value.length)return He.prototype.onAsciiEncoding.call(this);{let t=[],e=this.valueBlock.valueHexView;for(let s of e)t.push(s.toString(2).padStart(8,"0"));let n=t.join("");return`${this.constructor.NAME} : ${n.substring(0,n.length-this.valueBlock.unusedBits)}`}}};sl=Sr;U.BitString=sl;Sr.NAME=Zc;var ol;function l0(r,t){let e=new Uint8Array([0]),n=new Uint8Array(r),s=new Uint8Array(t),o=n.slice(0),i=o.length-1,a=s.slice(0),c=a.length-1,l=0,u=c<i?i:c,f=0;for(let g=u;g>=0;g--,f++){switch(!0){case f<a.length:l=o[i-f]+a[c-f]+e[0];break;default:l=o[i-f]+e[0]}switch(e[0]=l/10,!0){case f>=o.length:o=Gn(new Uint8Array([l%10]),o);break;default:o[i-f]=l%10}}return e[0]>0&&(o=Gn(e,o)),o}function Wc(r){if(r>=en.length)for(let t=en.length;t<=r;t++){let e=new Uint8Array([0]),n=en[t-1].slice(0);for(let s=n.length-1;s>=0;s--){let o=new Uint8Array([(n[s]<<1)+e[0]]);e[0]=o[0]/10,n[s]=o[0]%10}e[0]>0&&(n=Gn(e,n)),en.push(n)}return en[r]}function u0(r,t){let e=0,n=new Uint8Array(r),s=new Uint8Array(t),o=n.slice(0),i=o.length-1,a=s.slice(0),c=a.length-1,l,u=0;for(let f=c;f>=0;f--,u++)switch(l=o[i-u]-a[c-u]-e,!0){case l<0:e=1,o[i-u]=l+10;break;default:e=0,o[i-u]=l}if(e>0)for(let f=i-c+1;f>=0;f--,u++)if(l=o[i-u]-e,l<0)e=1,o[i-u]=l+10;else{e=0,o[i-u]=l;break}return o.slice()}var sn=class extends Se(Rt){constructor({value:t,...e}={}){super(e),this._valueDec=0,e.valueHex&&this.setValueHex(),t!==void 0&&(this.valueDec=t)}setValueHex(){this.valueHexView.length>=4?(this.warnings.push("Too big Integer for decoding, hex only"),this.isHexOnly=!0,this._valueDec=0):(this.isHexOnly=!1,this.valueHexView.length>0&&(this._valueDec=mi.call(this)))}set valueDec(t){this._valueDec=t,this.isHexOnly=!1,this.valueHexView=new Uint8Array(Gc(t))}get valueDec(){return this._valueDec}fromDER(t,e,n,s=0){let o=this.fromBER(t,e,n);if(o===-1)return o;let i=this.valueHexView;return i[0]===0&&i[1]&128?this.valueHexView=i.subarray(1):s!==0&&i.length<s&&(s-i.length>1&&(s=i.length+1),this.valueHexView=i.subarray(s-i.length)),o}toDER(t=!1){let e=this.valueHexView;switch(!0){case(e[0]&128)!==0:{let n=new Uint8Array(this.valueHexView.length+1);n[0]=0,n.set(e,1),this.valueHexView=n}break;case(e[0]===0&&(e[1]&128)===0):this.valueHexView=this.valueHexView.subarray(1);break}return this.toBER(t)}fromBER(t,e,n){let s=super.fromBER(t,e,n);return s===-1||this.setValueHex(),s}toBER(t){return t?new ArrayBuffer(this.valueHexView.length):this.valueHexView.slice().buffer}toJSON(){return{...super.toJSON(),valueDec:this.valueDec}}toString(){let t=this.valueHexView.length*8-1,e=new Uint8Array(this.valueHexView.length*8/3),n=0,s,o=this.valueHexView,i="",a=!1;for(let c=o.byteLength-1;c>=0;c--){s=o[c];for(let l=0;l<8;l++){if((s&1)===1)switch(n){case t:e=u0(Wc(n),e),i="-";break;default:e=l0(e,Wc(n))}n++,s>>=1}}for(let c=0;c<e.length;c++)e[c]&&(a=!0),a&&(i+=zc.charAt(e[c]));return a===!1&&(i+=zc.charAt(0)),i}};ol=sn;sn.NAME="IntegerValueBlock";Object.defineProperty(ol.prototype,"valueHex",{set:function(r){this.valueHexView=new Uint8Array(r),this.setValueHex()},get:function(){return this.valueHexView.slice().buffer}});var il,pt=class r extends St{constructor(t={}){super(t,sn),this.idBlock.tagClass=1,this.idBlock.tagNumber=2}toBigInt(){return jn(),BigInt(this.valueBlock.toString())}static fromBigInt(t){jn();let e=BigInt(t),n=new rn,s=e.toString(16).replace(/^-/,""),o=new Uint8Array(Y.Convert.FromHex(s));if(e<0){let a=new Uint8Array(o.length+(o[0]&128?1:0));a[0]|=128;let l=BigInt(`0x${Y.Convert.ToHex(a)}`)+e,u=Y.BufferSourceConverter.toUint8Array(Y.Convert.FromHex(l.toString(16)));u[0]|=128,n.write(u)}else o[0]&128&&n.write(new Uint8Array([0])),n.write(o);return new r({valueHex:n.final()})}convertToDER(){let t=new r({valueHex:this.valueBlock.valueHexView});return t.valueBlock.toDER(),t}convertFromDER(){return new r({valueHex:this.valueBlock.valueHexView[0]===0?this.valueBlock.valueHexView.subarray(1):this.valueBlock.valueHexView})}onAsciiEncoding(){return`${this.constructor.NAME} : ${this.valueBlock.toString()}`}};il=pt;U.Integer=il;pt.NAME="INTEGER";var al,ss=class extends pt{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=10}};al=ss;U.Enumerated=al;ss.NAME="ENUMERATED";var on=class extends Se(Rt){constructor({valueDec:t=-1,isFirstSid:e=!1,...n}={}){super(n),this.valueDec=t,this.isFirstSid=e}fromBER(t,e,n){if(!n)return e;let s=Y.BufferSourceConverter.toUint8Array(t);if(!Ae(this,s,e,n))return-1;let o=s.subarray(e,e+n);this.valueHexView=new Uint8Array(n);for(let a=0;a<n&&(this.valueHexView[a]=o[a]&127,this.blockLength++,!!(o[a]&128));a++);let i=new Uint8Array(this.blockLength);for(let a=0;a<this.blockLength;a++)i[a]=this.valueHexView[a];return this.valueHexView=i,o[this.blockLength-1]&128?(this.error="End of input reached before message was fully decoded",-1):(this.valueHexView[0]===0&&this.warnings.push("Needlessly long format of SID encoding"),this.blockLength<=8?this.valueDec=nr(this.valueHexView,7):(this.isHexOnly=!0,this.warnings.push("Too big SID for decoding, hex only")),e+this.blockLength)}set valueBigInt(t){jn();let e=BigInt(t).toString(2);for(;e.length%7;)e="0"+e;let n=new Uint8Array(e.length/7);for(let s=0;s<n.length;s++)n[s]=parseInt(e.slice(s*7,s*7+7),2)+(s+1<n.length?128:0);this.fromBER(n.buffer,0,n.length)}toBER(t){if(this.isHexOnly){if(t)return new ArrayBuffer(this.valueHexView.byteLength);let s=this.valueHexView,o=new Uint8Array(this.blockLength);for(let i=0;i<this.blockLength-1;i++)o[i]=s[i]|128;return o[this.blockLength-1]=s[this.blockLength-1],o.buffer}let e=Oe(this.valueDec,7);if(e.byteLength===0)return this.error="Error during encoding SID value",Jt;let n=new Uint8Array(e.byteLength);if(!t){let s=new Uint8Array(e),o=e.byteLength-1;for(let i=0;i<o;i++)n[i]=s[i]|128;n[o]=s[o]}return n}toString(){let t="";if(this.isHexOnly)t=Y.Convert.ToHex(this.valueHexView);else if(this.isFirstSid){let e=this.valueDec;this.valueDec<=39?t="0.":this.valueDec<=79?(t="1.",e-=40):(t="2.",e-=80),t+=e.toString()}else t=this.valueDec.toString();return t}toJSON(){return{...super.toJSON(),valueDec:this.valueDec,isFirstSid:this.isFirstSid}}};on.NAME="sidBlock";var os=class extends Rt{constructor({value:t=kr,...e}={}){super(e),this.value=[],t&&this.fromString(t)}fromBER(t,e,n){let s=e;for(;n>0;){let o=new on;if(s=o.fromBER(t,s,n),s===-1)return this.blockLength=0,this.error=o.error,s;this.value.length===0&&(o.isFirstSid=!0),this.blockLength+=o.blockLength,n-=o.blockLength,this.value.push(o)}return s}toBER(t){let e=[];for(let n=0;n<this.value.length;n++){let s=this.value[n].toBER(t);if(s.byteLength===0)return this.error=this.value[n].error,Jt;e.push(s)}return wi(e)}fromString(t){this.value=[];let e=0,n=0,s="",o=!1;do if(n=t.indexOf(".",e),n===-1?s=t.substring(e):s=t.substring(e,n),e=n+1,o){let i=this.value[0],a=0;switch(i.valueDec){case 0:break;case 1:a=40;break;case 2:a=80;break;default:this.value=[];return}let c=parseInt(s,10);if(isNaN(c))return;i.valueDec=c+a,o=!1}else{let i=new on;if(s>Number.MAX_SAFE_INTEGER){jn();let a=BigInt(s);i.valueBigInt=a}else if(i.valueDec=parseInt(s,10),isNaN(i.valueDec))return;this.value.length||(i.isFirstSid=!0,o=!0),this.value.push(i)}while(n!==-1)}toString(){let t="",e=!1;for(let n=0;n<this.value.length;n++){e=this.value[n].isHexOnly;let s=this.value[n].toString();n!==0&&(t=`${t}.`),e?(s=`{${s}}`,this.value[n].isFirstSid?t=`2.{${s} - 80}`:t+=s):t+=s}return t}toJSON(){let t={...super.toJSON(),value:this.toString(),sidArray:[]};for(let e=0;e<this.value.length;e++)t.sidArray.push(this.value[e].toJSON());return t}};os.NAME="ObjectIdentifierValueBlock";var cl,Xt=class extends St{constructor(t={}){super(t,os),this.idBlock.tagClass=1,this.idBlock.tagNumber=6}getValue(){return this.valueBlock.toString()}setValue(t){this.valueBlock.fromString(t)}onAsciiEncoding(){return`${this.constructor.NAME} : ${this.valueBlock.toString()||"empty"}`}toJSON(){return{...super.toJSON(),value:this.getValue()}}};cl=Xt;U.ObjectIdentifier=cl;Xt.NAME="OBJECT IDENTIFIER";var an=class extends Se(Ee){constructor({valueDec:t=0,...e}={}){super(e),this.valueDec=t}fromBER(t,e,n){if(n===0)return e;let s=Y.BufferSourceConverter.toUint8Array(t);if(!Ae(this,s,e,n))return-1;let o=s.subarray(e,e+n);this.valueHexView=new Uint8Array(n);for(let a=0;a<n&&(this.valueHexView[a]=o[a]&127,this.blockLength++,!!(o[a]&128));a++);let i=new Uint8Array(this.blockLength);for(let a=0;a<this.blockLength;a++)i[a]=this.valueHexView[a];return this.valueHexView=i,o[this.blockLength-1]&128?(this.error="End of input reached before message was fully decoded",-1):(this.valueHexView[0]===0&&this.warnings.push("Needlessly long format of SID encoding"),this.blockLength<=8?this.valueDec=nr(this.valueHexView,7):(this.isHexOnly=!0,this.warnings.push("Too big SID for decoding, hex only")),e+this.blockLength)}toBER(t){if(this.isHexOnly){if(t)return new ArrayBuffer(this.valueHexView.byteLength);let s=this.valueHexView,o=new Uint8Array(this.blockLength);for(let i=0;i<this.blockLength-1;i++)o[i]=s[i]|128;return o[this.blockLength-1]=s[this.blockLength-1],o.buffer}let e=Oe(this.valueDec,7);if(e.byteLength===0)return this.error="Error during encoding SID value",Jt;let n=new Uint8Array(e.byteLength);if(!t){let s=new Uint8Array(e),o=e.byteLength-1;for(let i=0;i<o;i++)n[i]=s[i]|128;n[o]=s[o]}return n.buffer}toString(){let t="";return this.isHexOnly?t=Y.Convert.ToHex(this.valueHexView):t=this.valueDec.toString(),t}toJSON(){return{...super.toJSON(),valueDec:this.valueDec}}};an.NAME="relativeSidBlock";var is=class extends Rt{constructor({value:t=kr,...e}={}){super(e),this.value=[],t&&this.fromString(t)}fromBER(t,e,n){let s=e;for(;n>0;){let o=new an;if(s=o.fromBER(t,s,n),s===-1)return this.blockLength=0,this.error=o.error,s;this.blockLength+=o.blockLength,n-=o.blockLength,this.value.push(o)}return s}toBER(t,e){let n=[];for(let s=0;s<this.value.length;s++){let o=this.value[s].toBER(t);if(o.byteLength===0)return this.error=this.value[s].error,Jt;n.push(o)}return wi(n)}fromString(t){this.value=[];let e=0,n=0,s="";do{n=t.indexOf(".",e),n===-1?s=t.substring(e):s=t.substring(e,n),e=n+1;let o=new an;if(o.valueDec=parseInt(s,10),isNaN(o.valueDec))return!0;this.value.push(o)}while(n!==-1);return!0}toString(){let t="",e=!1;for(let n=0;n<this.value.length;n++){e=this.value[n].isHexOnly;let s=this.value[n].toString();n!==0&&(t=`${t}.`),e&&(s=`{${s}}`),t+=s}return t}toJSON(){let t={...super.toJSON(),value:this.toString(),sidArray:[]};for(let e=0;e<this.value.length;e++)t.sidArray.push(this.value[e].toJSON());return t}};is.NAME="RelativeObjectIdentifierValueBlock";var ll,as=class extends St{constructor(t={}){super(t,is),this.idBlock.tagClass=1,this.idBlock.tagNumber=13}getValue(){return this.valueBlock.toString()}setValue(t){this.valueBlock.fromString(t)}onAsciiEncoding(){return`${this.constructor.NAME} : ${this.valueBlock.toString()||"empty"}`}toJSON(){return{...super.toJSON(),value:this.getValue()}}};ll=as;U.RelativeObjectIdentifier=ll;as.NAME="RelativeObjectIdentifier";var ul,Et=class extends He{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=16}};ul=Et;U.Sequence=ul;Et.NAME="SEQUENCE";var fl,cs=class extends He{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=17}};fl=cs;U.Set=fl;cs.NAME="SET";var ls=class extends Se(Rt){constructor({...t}={}){super(t),this.isHexOnly=!0,this.value=kr}toJSON(){return{...super.toJSON(),value:this.value}}};ls.NAME="StringValueBlock";var us=class extends ls{};us.NAME="SimpleStringValueBlock";var Ct=class extends Yn{constructor({...t}={}){super(t,us)}fromBuffer(t){this.valueBlock.value=String.fromCharCode.apply(null,Y.BufferSourceConverter.toUint8Array(t))}fromString(t){let e=t.length,n=this.valueBlock.valueHexView=new Uint8Array(e);for(let s=0;s<e;s++)n[s]=t.charCodeAt(s);this.valueBlock.value=t}};Ct.NAME="SIMPLE STRING";var fs=class extends Ct{fromBuffer(t){this.valueBlock.valueHexView=Y.BufferSourceConverter.toUint8Array(t);try{this.valueBlock.value=Y.Convert.ToUtf8String(t)}catch(e){this.warnings.push(`Error during "decodeURIComponent": ${e}, using raw string`),this.valueBlock.value=Y.Convert.ToBinary(t)}}fromString(t){this.valueBlock.valueHexView=new Uint8Array(Y.Convert.FromUtf8String(t)),this.valueBlock.value=t}};fs.NAME="Utf8StringValueBlock";var hl,Be=class extends fs{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=12}};hl=Be;U.Utf8String=hl;Be.NAME="UTF8String";var hs=class extends Ct{fromBuffer(t){this.valueBlock.value=Y.Convert.ToUtf16String(t),this.valueBlock.valueHexView=Y.BufferSourceConverter.toUint8Array(t)}fromString(t){this.valueBlock.value=t,this.valueBlock.valueHexView=new Uint8Array(Y.Convert.FromUtf16String(t))}};hs.NAME="BmpStringValueBlock";var dl,ds=class extends hs{constructor({...t}={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=30}};dl=ds;U.BmpString=dl;ds.NAME="BMPString";var ps=class extends Ct{fromBuffer(t){let e=ArrayBuffer.isView(t)?t.slice().buffer:t.slice(0),n=new Uint8Array(e);for(let s=0;s<n.length;s+=4)n[s]=n[s+3],n[s+1]=n[s+2],n[s+2]=0,n[s+3]=0;this.valueBlock.value=String.fromCharCode.apply(null,new Uint32Array(e))}fromString(t){let e=t.length,n=this.valueBlock.valueHexView=new Uint8Array(e*4);for(let s=0;s<e;s++){let o=Oe(t.charCodeAt(s),8),i=new Uint8Array(o);if(i.length>4)continue;let a=4-i.length;for(let c=i.length-1;c>=0;c--)n[s*4+c+a]=i[c]}this.valueBlock.value=t}};ps.NAME="UniversalStringValueBlock";var pl,gs=class extends ps{constructor({...t}={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=28}};pl=gs;U.UniversalString=pl;gs.NAME="UniversalString";var gl,ys=class extends Ct{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=18}};gl=ys;U.NumericString=gl;ys.NAME="NumericString";var yl,ms=class extends Ct{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=19}};yl=ms;U.PrintableString=yl;ms.NAME="PrintableString";var ml,ws=class extends Ct{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=20}};ml=ws;U.TeletexString=ml;ws.NAME="TeletexString";var wl,bs=class extends Ct{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=21}};wl=bs;U.VideotexString=wl;bs.NAME="VideotexString";var bl,xs=class extends Ct{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=22}};bl=xs;U.IA5String=bl;xs.NAME="IA5String";var xl,Es=class extends Ct{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=25}};xl=Es;U.GraphicString=xl;Es.NAME="GraphicString";var El,cn=class extends Ct{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=26}};El=cn;U.VisibleString=El;cn.NAME="VisibleString";var vl,vs=class extends Ct{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=27}};vl=vs;U.GeneralString=vl;vs.NAME="GeneralString";var Bl,Bs=class extends Ct{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=29}};Bl=Bs;U.CharacterString=Bl;Bs.NAME="CharacterString";var Al,ln=class extends cn{constructor({value:t,valueDate:e,...n}={}){if(super(n),this.year=0,this.month=0,this.day=0,this.hour=0,this.minute=0,this.second=0,t){this.fromString(t),this.valueBlock.valueHexView=new Uint8Array(t.length);for(let s=0;s<t.length;s++)this.valueBlock.valueHexView[s]=t.charCodeAt(s)}e&&(this.fromDate(e),this.valueBlock.valueHexView=new Uint8Array(this.toBuffer())),this.idBlock.tagClass=1,this.idBlock.tagNumber=23}fromBuffer(t){this.fromString(String.fromCharCode.apply(null,Y.BufferSourceConverter.toUint8Array(t)))}toBuffer(){let t=this.toString(),e=new ArrayBuffer(t.length),n=new Uint8Array(e);for(let s=0;s<t.length;s++)n[s]=t.charCodeAt(s);return e}fromDate(t){this.year=t.getUTCFullYear(),this.month=t.getUTCMonth()+1,this.day=t.getUTCDate(),this.hour=t.getUTCHours(),this.minute=t.getUTCMinutes(),this.second=t.getUTCSeconds()}toDate(){return new Date(Date.UTC(this.year,this.month-1,this.day,this.hour,this.minute,this.second))}fromString(t){let n=/(\d{2})(\d{2})(\d{2})(\d{2})(\d{2})(\d{2})Z/ig.exec(t);if(n===null){this.error="Wrong input string for conversion";return}let s=parseInt(n[1],10);s>=50?this.year=1900+s:this.year=2e3+s,this.month=parseInt(n[2],10),this.day=parseInt(n[3],10),this.hour=parseInt(n[4],10),this.minute=parseInt(n[5],10),this.second=parseInt(n[6],10)}toString(t="iso"){if(t==="iso"){let e=new Array(7);return e[0]=Pt(this.year<2e3?this.year-1900:this.year-2e3,2),e[1]=Pt(this.month,2),e[2]=Pt(this.day,2),e[3]=Pt(this.hour,2),e[4]=Pt(this.minute,2),e[5]=Pt(this.second,2),e[6]="Z",e.join("")}return super.toString(t)}onAsciiEncoding(){return`${this.constructor.NAME} : ${this.toDate().toISOString()}`}toJSON(){return{...super.toJSON(),year:this.year,month:this.month,day:this.day,hour:this.hour,minute:this.minute,second:this.second}}};Al=ln;U.UTCTime=Al;ln.NAME="UTCTime";var Sl,As=class extends ln{constructor(t={}){var e;super(t),(e=this.millisecond)!==null&&e!==void 0||(this.millisecond=0),this.idBlock.tagClass=1,this.idBlock.tagNumber=24}fromDate(t){super.fromDate(t),this.millisecond=t.getUTCMilliseconds()}toDate(){return new Date(Date.UTC(this.year,this.month-1,this.day,this.hour,this.minute,this.second,this.millisecond))}fromString(t){let e=!1,n="",s="",o=0,i,a=0,c=0;if(t[t.length-1]==="Z")n=t.substring(0,t.length-1),e=!0;else{let f=new Number(t[t.length-1]);if(isNaN(f.valueOf()))throw new Error("Wrong input string for conversion");n=t}if(e){if(n.indexOf("+")!==-1)throw new Error("Wrong input string for conversion");if(n.indexOf("-")!==-1)throw new Error("Wrong input string for conversion")}else{let f=1,g=n.indexOf("+"),m="";if(g===-1&&(g=n.indexOf("-"),f=-1),g!==-1){if(m=n.substring(g+1),n=n.substring(0,g),m.length!==2&&m.length!==4)throw new Error("Wrong input string for conversion");let d=parseInt(m.substring(0,2),10);if(isNaN(d.valueOf()))throw new Error("Wrong input string for conversion");if(a=f*d,m.length===4){if(d=parseInt(m.substring(2,4),10),isNaN(d.valueOf()))throw new Error("Wrong input string for conversion");c=f*d}}}let l=n.indexOf(".");if(l===-1&&(l=n.indexOf(",")),l!==-1){let f=new Number(`0${n.substring(l)}`);if(isNaN(f.valueOf()))throw new Error("Wrong input string for conversion");o=f.valueOf(),s=n.substring(0,l)}else s=n;switch(!0){case s.length===8:if(i=/(\d{4})(\d{2})(\d{2})/ig,l!==-1)throw new Error("Wrong input string for conversion");break;case s.length===10:if(i=/(\d{4})(\d{2})(\d{2})(\d{2})/ig,l!==-1){let f=60*o;this.minute=Math.floor(f),f=60*(f-this.minute),this.second=Math.floor(f),f=1e3*(f-this.second),this.millisecond=Math.floor(f)}break;case s.length===12:if(i=/(\d{4})(\d{2})(\d{2})(\d{2})(\d{2})/ig,l!==-1){let f=60*o;this.second=Math.floor(f),f=1e3*(f-this.second),this.millisecond=Math.floor(f)}break;case s.length===14:if(i=/(\d{4})(\d{2})(\d{2})(\d{2})(\d{2})(\d{2})/ig,l!==-1){let f=1e3*o;this.millisecond=Math.floor(f)}break;default:throw new Error("Wrong input string for conversion")}let u=i.exec(s);if(u===null)throw new Error("Wrong input string for conversion");for(let f=1;f<u.length;f++)switch(f){case 1:this.year=parseInt(u[f],10);break;case 2:this.month=parseInt(u[f],10);break;case 3:this.day=parseInt(u[f],10);break;case 4:this.hour=parseInt(u[f],10)+a;break;case 5:this.minute=parseInt(u[f],10)+c;break;case 6:this.second=parseInt(u[f],10);break;default:throw new Error("Wrong input string for conversion")}if(e===!1){let f=new Date(this.year,this.month,this.day,this.hour,this.minute,this.second,this.millisecond);this.year=f.getUTCFullYear(),this.month=f.getUTCMonth(),this.day=f.getUTCDay(),this.hour=f.getUTCHours(),this.minute=f.getUTCMinutes(),this.second=f.getUTCSeconds(),this.millisecond=f.getUTCMilliseconds()}}toString(t="iso"){if(t==="iso"){let e=[];return e.push(Pt(this.year,4)),e.push(Pt(this.month,2)),e.push(Pt(this.day,2)),e.push(Pt(this.hour,2)),e.push(Pt(this.minute,2)),e.push(Pt(this.second,2)),this.millisecond!==0&&(e.push("."),e.push(Pt(this.millisecond,3))),e.push("Z"),e.join("")}return super.toString(t)}toJSON(){return{...super.toJSON(),millisecond:this.millisecond}}};Sl=As;U.GeneralizedTime=Sl;As.NAME="GeneralizedTime";var kl,Ss=class extends Be{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=31}};kl=Ss;U.DATE=kl;Ss.NAME="DATE";var Il,ks=class extends Be{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=32}};Il=ks;U.TimeOfDay=Il;ks.NAME="TimeOfDay";var _l,Is=class extends Be{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=33}};_l=Is;U.DateTime=_l;Is.NAME="DateTime";var Nl,_s=class extends Be{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=34}};Nl=_s;U.Duration=Nl;_s.NAME="Duration";var Tl,Ns=class extends Be{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=14}};Tl=Ns;U.TIME=Tl;Ns.NAME="TIME";function h0(r){let{result:t}=Ir(r),e=t.valueBlock.value;return{n:q(ae(e[1].toBigInt()),"base64url"),e:q(ae(e[2].toBigInt()),"base64url"),d:q(ae(e[3].toBigInt()),"base64url"),p:q(ae(e[4].toBigInt()),"base64url"),q:q(ae(e[5].toBigInt()),"base64url"),dp:q(ae(e[6].toBigInt()),"base64url"),dq:q(ae(e[7].toBigInt()),"base64url"),qi:q(ae(e[8].toBigInt()),"base64url"),kty:"RSA",alg:"RS256"}}function d0(r){if(r.n==null||r.e==null||r.d==null||r.p==null||r.q==null||r.dp==null||r.dq==null||r.qi==null)throw new F("JWK was missing components","ERR_INVALID_PARAMETERS");let e=new Et({value:[new pt({value:0}),pt.fromBigInt(ce(et(r.n,"base64url"))),pt.fromBigInt(ce(et(r.e,"base64url"))),pt.fromBigInt(ce(et(r.d,"base64url"))),pt.fromBigInt(ce(et(r.p,"base64url"))),pt.fromBigInt(ce(et(r.q,"base64url"))),pt.fromBigInt(ce(et(r.dp,"base64url"))),pt.fromBigInt(ce(et(r.dq,"base64url"))),pt.fromBigInt(ce(et(r.qi,"base64url")))]}).toBER();return new Uint8Array(e,0,e.byteLength)}function p0(r){let{result:t}=Ir(r),e=t.valueBlock.value[1].valueBlock.value[0].valueBlock.value;return{kty:"RSA",n:q(ae(e[0].toBigInt()),"base64url"),e:q(ae(e[1].toBigInt()),"base64url")}}function g0(r){if(r.n==null||r.e==null)throw new F("JWK was missing components","ERR_INVALID_PARAMETERS");let e=new Et({value:[new Et({value:[new Xt({value:"1.2.840.113549.1.1.1"}),new Me]}),new Sr({valueHex:new Et({value:[pt.fromBigInt(ce(et(r.n,"base64url"))),pt.fromBigInt(ce(et(r.e,"base64url")))]}).toBER()})]}).toBER();return new Uint8Array(e,0,e.byteLength)}function ae(r){let t=r.toString(16);t.length%2>0&&(t=`0${t}`);let e=t.length/2,n=new Uint8Array(e),s=0,o=0;for(;s<e;)n[s]=parseInt(t.slice(o,o+2),16),s+=1,o+=2;return n}function ce(r){let t=[];return r.forEach(function(e){let n=e.toString(16);n.length%2>0&&(n=`0${n}`),t.push(n)}),BigInt("0x"+t.join(""))}var y0=16,xi=32,Ei=1e4;async function m0(r,t){let e=Lt.get(),s=new Et({value:[new pt({value:0}),new Et({value:[new Xt({value:"1.2.840.113549.1.1.1"}),new Me]}),new ve({valueHex:r.marshal()})]}).toBER(),o=new Uint8Array(s,0,s.byteLength),i=rr(y0),a=await gi(mr,t,i,{c:Ei,dkLen:xi}),c=rr(16),l=await e.subtle.importKey("raw",a,"AES-CBC",!1,["encrypt"]),u=await e.subtle.encrypt({name:"AES-CBC",iv:c},l,o),f=new Et({value:[new ve({valueHex:i}),new pt({value:Ei}),new pt({value:xi}),new Et({value:[new Xt({value:"1.2.840.113549.2.11"}),new Me]})]}),g=new Et({value:[new Xt({value:"1.2.840.113549.1.5.13"}),new Et({value:[new Et({value:[new Xt({value:"1.2.840.113549.1.5.12"}),f]}),new Et({value:[new Xt({value:"2.16.840.1.101.3.4.1.42"}),new ve({valueHex:c})]})]})]}),d=new Et({value:[g,new ve({valueHex:u})]}).toBER(),h=new Uint8Array(d,0,d.byteLength);return["-----BEGIN ENCRYPTED PRIVATE KEY-----",...q(h,"base64pad").split(/(.{64})/).filter(Boolean),"-----END ENCRYPTED PRIVATE KEY-----"].join(`
7
- `)}async function w0(r,t){let e=Lt.get(),n;if(r.includes("-----BEGIN ENCRYPTED PRIVATE KEY-----")){let s=et(r.replace("-----BEGIN ENCRYPTED PRIVATE KEY-----","").replace("-----END ENCRYPTED PRIVATE KEY-----","").replace(/\n/g,"").trim(),"base64pad"),{result:o}=Ir(s),{iv:i,salt:a,iterations:c,keySize:l,cipherText:u}=b0(o),f=await gi(mr,t,a,{c,dkLen:l}),g=await e.subtle.importKey("raw",f,"AES-CBC",!1,["decrypt"]),m=un(await e.subtle.decrypt({name:"AES-CBC",iv:i},g,u)),{result:d}=Ir(m);n=Rl(d)}else if(r.includes("-----BEGIN PRIVATE KEY-----")){let s=et(r.replace("-----BEGIN PRIVATE KEY-----","").replace("-----END PRIVATE KEY-----","").replace(/\n/g,"").trim(),"base64pad"),{result:o}=Ir(s);n=Rl(o)}else throw new F("Could not parse private key from PEM data","ERR_INVALID_PARAMETERS");return vi(n)}function b0(r){let t=r.valueBlock.value[0];if(t.valueBlock.value[0].toString()!=="OBJECT IDENTIFIER : 1.2.840.113549.1.5.13")throw new F("Only pkcs5PBES2 encrypted private keys are supported","ERR_INVALID_PARAMS");let n=t.valueBlock.value[1].valueBlock.value[0];if(n.valueBlock.value[0].toString()!=="OBJECT IDENTIFIER : 1.2.840.113549.1.5.12")throw new F("Only pkcs5PBKDF2 key derivation functions are supported","ERR_INVALID_PARAMS");let o=n.valueBlock.value[1],i=un(o.valueBlock.value[0].getValue()),a=Ei,c=xi;if(o.valueBlock.value.length===3)a=Number(o.valueBlock.value[1].toBigInt()),c=Number(o.valueBlock.value[2].toBigInt());else if(o.valueBlock.value.length===2)throw new F("Could not derive key size and iterations from PEM file - please use @libp2p/rsa to re-import your key","ERR_INVALID_PARAMS");let l=t.valueBlock.value[1].valueBlock.value[1],u=l.valueBlock.value[0].toString();if(u!=="OBJECT IDENTIFIER : 1.2.840.113549.3.7"){if(u!=="OBJECT IDENTIFIER : 1.3.14.3.2.7"){if(u!=="OBJECT IDENTIFIER : 2.16.840.1.101.3.4.1.2"){if(u!=="OBJECT IDENTIFIER : 2.16.840.1.101.3.4.1.22"){if(u!=="OBJECT IDENTIFIER : 2.16.840.1.101.3.4.1.42")throw new F("Only AES-CBC encryption schemes are supported","ERR_INVALID_PARAMS")}}}}let f=un(l.valueBlock.value[1].getValue());return{cipherText:un(r.valueBlock.value[1].getValue()),salt:i,iterations:a,keySize:c,iv:f}}function Rl(r){return un(r.valueBlock.value[2].getValue())}function un(r){return new Uint8Array(r,0,r.byteLength)}async function Ll(r){let t=await Lt.get().subtle.generateKey({name:"RSASSA-PKCS1-v1_5",modulusLength:r,publicExponent:new Uint8Array([1,0,1]),hash:{name:"SHA-256"}},!0,["sign","verify"]),e=await Pl(t);return{privateKey:e[0],publicKey:e[1]}}async function Bi(r){let e=[await Lt.get().subtle.importKey("jwk",r,{name:"RSASSA-PKCS1-v1_5",hash:{name:"SHA-256"}},!0,["sign"]),await x0(r)],n=await Pl({privateKey:e[0],publicKey:e[1]});return{privateKey:n[0],publicKey:n[1]}}async function Cl(r,t){let e=await Lt.get().subtle.importKey("jwk",r,{name:"RSASSA-PKCS1-v1_5",hash:{name:"SHA-256"}},!1,["sign"]),n=await Lt.get().subtle.sign({name:"RSASSA-PKCS1-v1_5"},e,t instanceof Uint8Array?t:t.subarray());return new Uint8Array(n,0,n.byteLength)}async function Ul(r,t,e){let n=await Lt.get().subtle.importKey("jwk",r,{name:"RSASSA-PKCS1-v1_5",hash:{name:"SHA-256"}},!1,["verify"]);return Lt.get().subtle.verify({name:"RSASSA-PKCS1-v1_5"},n,t,e instanceof Uint8Array?e:e.subarray())}async function Pl(r){if(r.privateKey==null||r.publicKey==null)throw new F("Private and public key are required","ERR_INVALID_PARAMETERS");return Promise.all([Lt.get().subtle.exportKey("jwk",r.privateKey),Lt.get().subtle.exportKey("jwk",r.publicKey)])}async function x0(r){return Lt.get().subtle.importKey("jwk",{kty:r.kty,n:r.n,e:r.e},{name:"RSASSA-PKCS1-v1_5",hash:{name:"SHA-256"}},!0,["verify"])}function Rs(r){if(r.kty!=="RSA")throw new F("invalid key type","ERR_INVALID_KEY_TYPE");if(r.n==null)throw new F("invalid key modulus","ERR_INVALID_KEY_MODULUS");return et(r.n,"base64url").length*8}var hn=8192,fn=class{_key;constructor(t){this._key=t}verify(t,e){return Ul(this._key,e,t)}marshal(){return Ke.jwkToPkix(this._key)}get bytes(){return se.encode({Type:at.RSA,Data:this.marshal()}).subarray()}equals(t){return ft(this.bytes,t.bytes)}hash(){let t=At.digest(this.bytes);return Ht(t)?t.then(({bytes:e})=>e):t.bytes}},_r=class{_key;_publicKey;constructor(t,e){this._key=t,this._publicKey=e}genSecret(){return rr(16)}sign(t){return Cl(this._key,t)}get public(){if(this._publicKey==null)throw new F("public key not provided","ERR_PUBKEY_NOT_PROVIDED");return new fn(this._publicKey)}marshal(){return Ke.jwkToPkcs1(this._key)}get bytes(){return oe.encode({Type:at.RSA,Data:this.marshal()}).subarray()}equals(t){return ft(this.bytes,t.bytes)}hash(){let t=At.digest(this.bytes);return Ht(t)?t.then(({bytes:e})=>e):t.bytes}async id(){let t=await this.public.hash();return q(t,"base58btc")}async export(t,e="pkcs-8"){if(e==="pkcs-8")return Ke.exportToPem(this,t);if(e==="libp2p-key")return Er(this.bytes,t);throw new F(`export format '${e}' is not supported`,"ERR_INVALID_EXPORT_FORMAT")}};async function vi(r){let t=Ke.pkcs1ToJwk(r);if(Rs(t)>hn)throw new F("key size is too large","ERR_KEY_SIZE_TOO_LARGE");let e=await Bi(t);return new _r(e.privateKey,e.publicKey)}function v0(r){let t=Ke.pkixToJwk(r);if(Rs(t)>hn)throw new F("key size is too large","ERR_KEY_SIZE_TOO_LARGE");return new fn(t)}async function B0(r){if(Rs(r)>hn)throw new F("key size is too large","ERR_KEY_SIZE_TOO_LARGE");let t=await Bi(r);return new _r(t.privateKey,t.publicKey)}async function A0(r){if(r>hn)throw new F("key size is too large","ERR_KEY_SIZE_TOO_LARGE");let t=await Ll(r);return new _r(t.privateKey,t.publicKey)}var Ni={};yt(Ni,{Secp256k1PrivateKey:()=>pn,Secp256k1PublicKey:()=>dn,generateKeyPair:()=>V0,unmarshalSecp256k1PrivateKey:()=>P0,unmarshalSecp256k1PublicKey:()=>D0});var S0=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]),Fe=new Uint32Array([1779033703,3144134277,1013904242,2773480762,1359893119,2600822924,528734635,1541459225]),$e=new Uint32Array(64),Si=class extends yr{constructor(){super(64,32,8,!1),this.A=Fe[0]|0,this.B=Fe[1]|0,this.C=Fe[2]|0,this.D=Fe[3]|0,this.E=Fe[4]|0,this.F=Fe[5]|0,this.G=Fe[6]|0,this.H=Fe[7]|0}get(){let{A:t,B:e,C:n,D:s,E:o,F:i,G:a,H:c}=this;return[t,e,n,s,o,i,a,c]}set(t,e,n,s,o,i,a,c){this.A=t|0,this.B=e|0,this.C=n|0,this.D=s|0,this.E=o|0,this.F=i|0,this.G=a|0,this.H=c|0}process(t,e){for(let f=0;f<16;f++,e+=4)$e[f]=t.getUint32(e,!1);for(let f=16;f<64;f++){let g=$e[f-15],m=$e[f-2],d=Gt(g,7)^Gt(g,18)^g>>>3,h=Gt(m,17)^Gt(m,19)^m>>>10;$e[f]=h+$e[f-7]+d+$e[f-16]|0}let{A:n,B:s,C:o,D:i,E:a,F:c,G:l,H:u}=this;for(let f=0;f<64;f++){let g=Gt(a,6)^Gt(a,11)^Gt(a,25),m=u+g+lc(a,c,l)+S0[f]+$e[f]|0,h=(Gt(n,2)^Gt(n,13)^Gt(n,22))+uc(n,s,o)|0;u=l,l=c,c=a,a=i+m|0,i=o,o=s,s=n,n=m+h|0}n=n+this.A|0,s=s+this.B|0,o=o+this.C|0,i=i+this.D|0,a=a+this.E|0,c=c+this.F|0,l=l+this.G|0,u=u+this.H|0,this.set(n,s,o,i,a,c,l,u)}roundClean(){$e.fill(0)}destroy(){this.set(0,0,0,0,0,0,0,0),this.buffer.fill(0)}};var Nr=_n(()=>new Si);function k0(r){let t=zr(r);Mt(t,{a:"field",b:"field"},{allowedPrivateKeyLengths:"array",wrapPrivateKey:"boolean",isTorsionFree:"function",clearCofactor:"function",allowInfinityPoint:"boolean",fromBytes:"function",toBytes:"function"});let{endo:e,Fp:n,a:s}=t;if(e){if(!n.eql(s,n.ZERO))throw new Error("Endomorphism can only be defined for Koblitz curves that have a=0");if(typeof e!="object"||typeof e.beta!="bigint"||typeof e.splitScalar!="function")throw new Error("Expected endomorphism with beta: bigint and splitScalar: function")}return Object.freeze({...t})}var{bytesToNumberBE:I0,hexToBytes:_0}=Rn,sr={Err:class extends Error{constructor(t=""){super(t)}},_parseInt(r){let{Err:t}=sr;if(r.length<2||r[0]!==2)throw new t("Invalid signature integer tag");let e=r[1],n=r.subarray(2,e+2);if(!e||n.length!==e)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:I0(n),l:r.subarray(e+2)}},toSig(r){let{Err:t}=sr,e=typeof r=="string"?_0(r):r;wr(e);let n=e.length;if(n<2||e[0]!=48)throw new t("Invalid signature tag");if(e[1]!==n-2)throw new t("Invalid signature: incorrect length");let{d:s,l:o}=sr._parseInt(e.subarray(2)),{d:i,l:a}=sr._parseInt(o);if(a.length)throw new t("Invalid signature: left bytes after parsing");return{r:s,s:i}},hexFromSig(r){let t=l=>Number.parseInt(l[0],16)&8?"00"+l:l,e=l=>{let u=l.toString(16);return u.length&1?`0${u}`:u},n=t(e(r.s)),s=t(e(r.r)),o=n.length/2,i=s.length/2,a=e(o),c=e(i);return`30${e(i+o+4)}02${c}${s}02${a}${n}`}},ke=BigInt(0),Ft=BigInt(1),mw=BigInt(2),Dl=BigInt(3),ww=BigInt(4);function N0(r){let t=k0(r),{Fp:e}=t,n=t.toBytes||((d,h,p)=>{let b=h.toAffine();return me(Uint8Array.from([4]),e.toBytes(b.x),e.toBytes(b.y))}),s=t.fromBytes||(d=>{let h=d.subarray(1),p=e.fromBytes(h.subarray(0,e.BYTES)),b=e.fromBytes(h.subarray(e.BYTES,2*e.BYTES));return{x:p,y:b}});function o(d){let{a:h,b:p}=t,b=e.sqr(d),v=e.mul(b,d);return e.add(e.add(v,e.mul(d,h)),p)}if(!e.eql(e.sqr(t.Gy),o(t.Gx)))throw new Error("bad generator point: equation left != right");function i(d){return typeof d=="bigint"&&ke<d&&d<t.n}function a(d){if(!i(d))throw new Error("Expected valid bigint: 0 < bigint < curve.n")}function c(d){let{allowedPrivateKeyLengths:h,nByteLength:p,wrapPrivateKey:b,n:v}=t;if(h&&typeof d!="bigint"){if(Ue(d)&&(d=pe(d)),typeof d!="string"||!h.includes(d.length))throw new Error("Invalid key");d=d.padStart(p*2,"0")}let w;try{w=typeof d=="bigint"?d:ge(st("private key",d,p))}catch{throw new Error(`private key must be ${p} bytes, hex or bigint, not ${typeof d}`)}return b&&(w=Z(w,v)),a(w),w}let l=new Map;function u(d){if(!(d instanceof f))throw new Error("ProjectivePoint expected")}class f{constructor(h,p,b){if(this.px=h,this.py=p,this.pz=b,h==null||!e.isValid(h))throw new Error("x required");if(p==null||!e.isValid(p))throw new Error("y required");if(b==null||!e.isValid(b))throw new Error("z required")}static fromAffine(h){let{x:p,y:b}=h||{};if(!h||!e.isValid(p)||!e.isValid(b))throw new Error("invalid affine point");if(h instanceof f)throw new Error("projective point not allowed");let v=w=>e.eql(w,e.ZERO);return v(p)&&v(b)?f.ZERO:new f(p,b,e.ONE)}get x(){return this.toAffine().x}get y(){return this.toAffine().y}static normalizeZ(h){let p=e.invertBatch(h.map(b=>b.pz));return h.map((b,v)=>b.toAffine(p[v])).map(f.fromAffine)}static fromHex(h){let p=f.fromAffine(s(st("pointHex",h)));return p.assertValidity(),p}static fromPrivateKey(h){return f.BASE.multiply(c(h))}_setWindowSize(h){this._WINDOW_SIZE=h,l.delete(this)}assertValidity(){if(this.is0()){if(t.allowInfinityPoint&&!e.is0(this.py))return;throw new Error("bad point: ZERO")}let{x:h,y:p}=this.toAffine();if(!e.isValid(h)||!e.isValid(p))throw new Error("bad point: x or y not FE");let b=e.sqr(p),v=o(h);if(!e.eql(b,v))throw new Error("bad point: equation left != right");if(!this.isTorsionFree())throw new Error("bad point: not in prime-order subgroup")}hasEvenY(){let{y:h}=this.toAffine();if(e.isOdd)return!e.isOdd(h);throw new Error("Field doesn't support isOdd")}equals(h){u(h);let{px:p,py:b,pz:v}=this,{px:w,py:A,pz:B}=h,S=e.eql(e.mul(p,B),e.mul(w,v)),N=e.eql(e.mul(b,B),e.mul(A,v));return S&&N}negate(){return new f(this.px,e.neg(this.py),this.pz)}double(){let{a:h,b:p}=t,b=e.mul(p,Dl),{px:v,py:w,pz:A}=this,B=e.ZERO,S=e.ZERO,N=e.ZERO,_=e.mul(v,v),V=e.mul(w,w),P=e.mul(A,A),R=e.mul(v,w);return R=e.add(R,R),N=e.mul(v,A),N=e.add(N,N),B=e.mul(h,N),S=e.mul(b,P),S=e.add(B,S),B=e.sub(V,S),S=e.add(V,S),S=e.mul(B,S),B=e.mul(R,B),N=e.mul(b,N),P=e.mul(h,P),R=e.sub(_,P),R=e.mul(h,R),R=e.add(R,N),N=e.add(_,_),_=e.add(N,_),_=e.add(_,P),_=e.mul(_,R),S=e.add(S,_),P=e.mul(w,A),P=e.add(P,P),_=e.mul(P,R),B=e.sub(B,_),N=e.mul(P,V),N=e.add(N,N),N=e.add(N,N),new f(B,S,N)}add(h){u(h);let{px:p,py:b,pz:v}=this,{px:w,py:A,pz:B}=h,S=e.ZERO,N=e.ZERO,_=e.ZERO,V=t.a,P=e.mul(t.b,Dl),R=e.mul(p,w),H=e.mul(b,A),O=e.mul(v,B),W=e.add(p,b),x=e.add(w,A);W=e.mul(W,x),x=e.add(R,H),W=e.sub(W,x),x=e.add(p,v);let I=e.add(w,B);return x=e.mul(x,I),I=e.add(R,O),x=e.sub(x,I),I=e.add(b,v),S=e.add(A,B),I=e.mul(I,S),S=e.add(H,O),I=e.sub(I,S),_=e.mul(V,x),S=e.mul(P,O),_=e.add(S,_),S=e.sub(H,_),_=e.add(H,_),N=e.mul(S,_),H=e.add(R,R),H=e.add(H,R),O=e.mul(V,O),x=e.mul(P,x),H=e.add(H,O),O=e.sub(R,O),O=e.mul(V,O),x=e.add(x,O),R=e.mul(H,x),N=e.add(N,R),R=e.mul(I,x),S=e.mul(W,S),S=e.sub(S,R),R=e.mul(W,H),_=e.mul(I,_),_=e.add(_,R),new f(S,N,_)}subtract(h){return this.add(h.negate())}is0(){return this.equals(f.ZERO)}wNAF(h){return m.wNAFCached(this,l,h,p=>{let b=e.invertBatch(p.map(v=>v.pz));return p.map((v,w)=>v.toAffine(b[w])).map(f.fromAffine)})}multiplyUnsafe(h){let p=f.ZERO;if(h===ke)return p;if(a(h),h===Ft)return this;let{endo:b}=t;if(!b)return m.unsafeLadder(this,h);let{k1neg:v,k1:w,k2neg:A,k2:B}=b.splitScalar(h),S=p,N=p,_=this;for(;w>ke||B>ke;)w&Ft&&(S=S.add(_)),B&Ft&&(N=N.add(_)),_=_.double(),w>>=Ft,B>>=Ft;return v&&(S=S.negate()),A&&(N=N.negate()),N=new f(e.mul(N.px,b.beta),N.py,N.pz),S.add(N)}multiply(h){a(h);let p=h,b,v,{endo:w}=t;if(w){let{k1neg:A,k1:B,k2neg:S,k2:N}=w.splitScalar(p),{p:_,f:V}=this.wNAF(B),{p:P,f:R}=this.wNAF(N);_=m.constTimeNegate(A,_),P=m.constTimeNegate(S,P),P=new f(e.mul(P.px,w.beta),P.py,P.pz),b=_.add(P),v=V.add(R)}else{let{p:A,f:B}=this.wNAF(p);b=A,v=B}return f.normalizeZ([b,v])[0]}multiplyAndAddUnsafe(h,p,b){let v=f.BASE,w=(B,S)=>S===ke||S===Ft||!B.equals(v)?B.multiplyUnsafe(S):B.multiply(S),A=w(this,p).add(w(h,b));return A.is0()?void 0:A}toAffine(h){let{px:p,py:b,pz:v}=this,w=this.is0();h==null&&(h=w?e.ONE:e.inv(v));let A=e.mul(p,h),B=e.mul(b,h),S=e.mul(v,h);if(w)return{x:e.ZERO,y:e.ZERO};if(!e.eql(S,e.ONE))throw new Error("invZ was invalid");return{x:A,y:B}}isTorsionFree(){let{h,isTorsionFree:p}=t;if(h===Ft)return!0;if(p)return p(f,this);throw new Error("isTorsionFree() has not been declared for the elliptic curve")}clearCofactor(){let{h,clearCofactor:p}=t;return h===Ft?this:p?p(f,this):this.multiplyUnsafe(t.h)}toRawBytes(h=!0){return this.assertValidity(),n(f,this,h)}toHex(h=!0){return pe(this.toRawBytes(h))}}f.BASE=new f(t.Gx,t.Gy,e.ONE),f.ZERO=new f(e.ZERO,e.ONE,e.ZERO);let g=t.nBitLength,m=Un(f,t.endo?Math.ceil(g/2):g);return{CURVE:t,ProjectivePoint:f,normPrivateKeyToScalar:c,weierstrassEquation:o,isWithinCurveOrder:i}}function T0(r){let t=zr(r);return Mt(t,{hash:"hash",hmac:"function",randomBytes:"function"},{bits2int:"function",bits2int_modN:"function",lowS:"boolean"}),Object.freeze({lowS:!0,...t})}function Vl(r){let t=T0(r),{Fp:e,n}=t,s=e.BYTES+1,o=2*e.BYTES+1;function i(x){return ke<x&&x<e.ORDER}function a(x){return Z(x,n)}function c(x){return Ln(x,n)}let{ProjectivePoint:l,normPrivateKeyToScalar:u,weierstrassEquation:f,isWithinCurveOrder:g}=N0({...t,toBytes(x,I,C){let E=I.toAffine(),y=e.toBytes(E.x),k=me;return C?k(Uint8Array.from([I.hasEvenY()?2:3]),y):k(Uint8Array.from([4]),y,e.toBytes(E.y))},fromBytes(x){let I=x.length,C=x[0],E=x.subarray(1);if(I===s&&(C===2||C===3)){let y=ge(E);if(!i(y))throw new Error("Point is not on curve");let k=f(y),T;try{T=e.sqrt(k)}catch(K){let j=K instanceof Error?": "+K.message:"";throw new Error("Point is not on curve"+j)}let L=(T&Ft)===Ft;return(C&1)===1!==L&&(T=e.neg(T)),{x:y,y:T}}else if(I===o&&C===4){let y=e.fromBytes(E.subarray(0,e.BYTES)),k=e.fromBytes(E.subarray(e.BYTES,2*e.BYTES));return{x:y,y:k}}else throw new Error(`Point of length ${I} was invalid. Expected ${s} compressed bytes or ${o} uncompressed bytes`)}}),m=x=>pe(Pe(x,t.nByteLength));function d(x){let I=n>>Ft;return x>I}function h(x){return d(x)?a(-x):x}let p=(x,I,C)=>ge(x.slice(I,C));class b{constructor(I,C,E){this.r=I,this.s=C,this.recovery=E,this.assertValidity()}static fromCompact(I){let C=t.nByteLength;return I=st("compactSignature",I,C*2),new b(p(I,0,C),p(I,C,2*C))}static fromDER(I){let{r:C,s:E}=sr.toSig(st("DER",I));return new b(C,E)}assertValidity(){if(!g(this.r))throw new Error("r must be 0 < r < CURVE.n");if(!g(this.s))throw new Error("s must be 0 < s < CURVE.n")}addRecoveryBit(I){return new b(this.r,this.s,I)}recoverPublicKey(I){let{r:C,s:E,recovery:y}=this,k=N(st("msgHash",I));if(y==null||![0,1,2,3].includes(y))throw new Error("recovery id invalid");let T=y===2||y===3?C+t.n:C;if(T>=e.ORDER)throw new Error("recovery id 2 or 3 invalid");let L=y&1?"03":"02",M=l.fromHex(L+m(T)),K=c(T),j=a(-k*K),$=a(E*K),G=l.BASE.multiplyAndAddUnsafe(M,j,$);if(!G)throw new Error("point at infinify");return G.assertValidity(),G}hasHighS(){return d(this.s)}normalizeS(){return this.hasHighS()?new b(this.r,a(-this.s),this.recovery):this}toDERRawBytes(){return We(this.toDERHex())}toDERHex(){return sr.hexFromSig({r:this.r,s:this.s})}toCompactRawBytes(){return We(this.toCompactHex())}toCompactHex(){return m(this.r)+m(this.s)}}let v={isValidPrivateKey(x){try{return u(x),!0}catch{return!1}},normPrivateKeyToScalar:u,randomPrivateKey:()=>{let x=$o(t.n);return Ec(t.randomBytes(x),t.n)},precompute(x=8,I=l.BASE){return I._setWindowSize(x),I.multiply(BigInt(3)),I}};function w(x,I=!0){return l.fromPrivateKey(x).toRawBytes(I)}function A(x){let I=Ue(x),C=typeof x=="string",E=(I||C)&&x.length;return I?E===s||E===o:C?E===2*s||E===2*o:x instanceof l}function B(x,I,C=!0){if(A(x))throw new Error("first arg must be private key");if(!A(I))throw new Error("second arg must be public key");return l.fromHex(I).multiply(u(x)).toRawBytes(C)}let S=t.bits2int||function(x){let I=ge(x),C=x.length*8-t.nBitLength;return C>0?I>>BigInt(C):I},N=t.bits2int_modN||function(x){return a(S(x))},_=jr(t.nBitLength);function V(x){if(typeof x!="bigint")throw new Error("bigint expected");if(!(ke<=x&&x<_))throw new Error(`bigint expected < 2^${t.nBitLength}`);return Pe(x,t.nByteLength)}function P(x,I,C=R){if(["recovered","canonical"].some(tt=>tt in C))throw new Error("sign() legacy options not supported");let{hash:E,randomBytes:y}=t,{lowS:k,prehash:T,extraEntropy:L}=C;k==null&&(k=!0),x=st("msgHash",x),T&&(x=st("prehashed msgHash",E(x)));let M=N(x),K=u(I),j=[V(K),V(M)];if(L!=null&&L!==!1){let tt=L===!0?y(e.BYTES):L;j.push(st("extraEntropy",tt))}let $=me(...j),G=M;function nt(tt){let vt=S(tt);if(!g(vt))return;let Bt=c(vt),gt=l.BASE.multiply(vt).toAffine(),_t=a(gt.x);if(_t===ke)return;let ue=a(Bt*a(G+_t*K));if(ue===ke)return;let qe=(gt.x===_t?0:2)|Number(gt.y&Ft),Fr=ue;return k&&d(ue)&&(Fr=h(ue),qe^=1),new b(_t,Fr,qe)}return{seed:$,k2sig:nt}}let R={lowS:t.lowS,prehash:!1},H={lowS:t.lowS,prehash:!1};function O(x,I,C=R){let{seed:E,k2sig:y}=P(x,I,C),k=t;return Oo(k.hash.outputLen,k.nByteLength,k.hmac)(E,y)}l.BASE._setWindowSize(8);function W(x,I,C,E=H){let y=x;if(I=st("msgHash",I),C=st("publicKey",C),"strict"in E)throw new Error("options.strict was renamed to lowS");let{lowS:k,prehash:T}=E,L,M;try{if(typeof y=="string"||Ue(y))try{L=b.fromDER(y)}catch(gt){if(!(gt instanceof sr.Err))throw gt;L=b.fromCompact(y)}else if(typeof y=="object"&&typeof y.r=="bigint"&&typeof y.s=="bigint"){let{r:gt,s:_t}=y;L=new b(gt,_t)}else throw new Error("PARSE");M=l.fromHex(C)}catch(gt){if(gt.message==="PARSE")throw new Error("signature must be Signature instance, Uint8Array or hex string");return!1}if(k&&L.hasHighS())return!1;T&&(I=t.hash(I));let{r:K,s:j}=L,$=N(I),G=c(j),nt=a($*G),tt=a(K*G),vt=l.BASE.multiplyAndAddUnsafe(M,nt,tt)?.toAffine();return vt?a(vt.x)===K:!1}return{CURVE:t,getPublicKey:w,getSharedSecret:B,sign:O,verify:W,ProjectivePoint:l,Signature:b,utils:v}}function R0(r){return{hash:r,hmac:(t,...e)=>Ve(r,t,In(...e)),randomBytes:ze}}function Ol(r,t){let e=n=>Vl({...r,...R0(n)});return Object.freeze({...e(t),create:e})}var Kl=BigInt("0xfffffffffffffffffffffffffffffffffffffffffffffffffffffffefffffc2f"),Hl=BigInt("0xfffffffffffffffffffffffffffffffebaaedce6af48a03bbfd25e8cd0364141"),L0=BigInt(1),ki=BigInt(2),Ml=(r,t)=>(r+t/ki)/t;function C0(r){let t=Kl,e=BigInt(3),n=BigInt(6),s=BigInt(11),o=BigInt(22),i=BigInt(23),a=BigInt(44),c=BigInt(88),l=r*r*r%t,u=l*l*r%t,f=ot(u,e,t)*u%t,g=ot(f,e,t)*u%t,m=ot(g,ki,t)*l%t,d=ot(m,s,t)*m%t,h=ot(d,o,t)*d%t,p=ot(h,a,t)*h%t,b=ot(p,c,t)*p%t,v=ot(b,a,t)*h%t,w=ot(v,e,t)*u%t,A=ot(w,i,t)*d%t,B=ot(A,n,t)*l%t,S=ot(B,ki,t);if(!Ii.eql(Ii.sqr(S),r))throw new Error("Cannot find square root");return S}var Ii=Cn(Kl,void 0,void 0,{sqrt:C0}),Qt=Ol({a:BigInt(0),b:BigInt(7),Fp:Ii,n:Hl,Gx:BigInt("55066263022277343669578718895168534326250603453777594175500187360389116729240"),Gy:BigInt("32670510020758816978083085130507043184471273380659243275938904335757337482424"),h:BigInt(1),lowS:!0,endo:{beta:BigInt("0x7ae96a2b657c07106e64479eac3434e99cf0497512f58995c1396c28719501ee"),splitScalar:r=>{let t=Hl,e=BigInt("0x3086d221a7d46bcde86c90e49284eb15"),n=-L0*BigInt("0xe4437ed6010e88286f547fa90abfe4c3"),s=BigInt("0x114ca50f7a8e2f3f657c1108d9d44cfd8"),o=e,i=BigInt("0x100000000000000000000000000000000"),a=Ml(o*r,t),c=Ml(-n*r,t),l=Z(r-a*e-c*s,t),u=Z(-a*n-c*o,t),f=l>i,g=u>i;if(f&&(l=t-l),g&&(u=t-u),l>i||u>i)throw new Error("splitScalar: Endomorphism failed, k="+r);return{k1neg:f,k1:l,k2neg:g,k2:u}}}},Nr),Iw=BigInt(0);var _w=Qt.ProjectivePoint;function Fl(){return Qt.utils.randomPrivateKey()}function $l(r,t){let e=At.digest(t instanceof Uint8Array?t:t.subarray());if(Ht(e))return e.then(({digest:n})=>Qt.sign(n,r).toDERRawBytes()).catch(n=>{throw new F(String(n),"ERR_INVALID_INPUT")});try{return Qt.sign(e.digest,r).toDERRawBytes()}catch(n){throw new F(String(n),"ERR_INVALID_INPUT")}}function ql(r,t,e){let n=At.digest(e instanceof Uint8Array?e:e.subarray());if(Ht(n))return n.then(({digest:s})=>Qt.verify(t,s,r)).catch(s=>{throw new F(String(s),"ERR_INVALID_INPUT")});try{return Qt.verify(t,n.digest,r)}catch(s){throw new F(String(s),"ERR_INVALID_INPUT")}}function Gl(r){return Qt.ProjectivePoint.fromHex(r).toRawBytes(!0)}function jl(r){try{Qt.getPublicKey(r,!0)}catch(t){throw new F(String(t),"ERR_INVALID_PRIVATE_KEY")}}function _i(r){try{Qt.ProjectivePoint.fromHex(r)}catch(t){throw new F(String(t),"ERR_INVALID_PUBLIC_KEY")}}function zl(r){try{return Qt.getPublicKey(r,!0)}catch(t){throw new F(String(t),"ERR_INVALID_PRIVATE_KEY")}}var dn=class{_key;constructor(t){_i(t),this._key=t}verify(t,e){return ql(this._key,e,t)}marshal(){return Gl(this._key)}get bytes(){return se.encode({Type:at.Secp256k1,Data:this.marshal()}).subarray()}equals(t){return ft(this.bytes,t.bytes)}async hash(){let t=At.digest(this.bytes),e;return Ht(t)?{bytes:e}=await t:e=t.bytes,e}},pn=class{_key;_publicKey;constructor(t,e){this._key=t,this._publicKey=e??zl(t),jl(this._key),_i(this._publicKey)}sign(t){return $l(this._key,t)}get public(){return new dn(this._publicKey)}marshal(){return this._key}get bytes(){return oe.encode({Type:at.Secp256k1,Data:this.marshal()}).subarray()}equals(t){return ft(this.bytes,t.bytes)}hash(){let t=At.digest(this.bytes);return Ht(t)?t.then(({bytes:e})=>e):t.bytes}async id(){let t=await this.public.hash();return q(t,"base58btc")}async export(t,e="libp2p-key"){if(e==="libp2p-key")return Er(this.bytes,t);throw new F(`export format '${e}' is not supported`,"ERR_INVALID_EXPORT_FORMAT")}};function P0(r){return new pn(r)}function D0(r){return new dn(r)}async function V0(){let r=Fl();return new pn(r)}var or={rsa:Ai,ed25519:pi,secp256k1:Ni};function Wl(r){let t=Object.keys(or).join(" / ");return new F(`invalid or unsupported key type ${r}. Must be ${t}`,"ERR_UNSUPPORTED_KEY_TYPE")}function Yl(r){let t=se.decode(r),e=t.Data??new Uint8Array;switch(t.Type){case at.RSA:return or.rsa.unmarshalRsaPublicKey(e);case at.Ed25519:return or.ed25519.unmarshalEd25519PublicKey(e);case at.Secp256k1:return or.secp256k1.unmarshalSecp256k1PublicKey(e);default:throw Wl(t.Type??"unknown")}}async function Ti(r){let t=oe.decode(r),e=t.Data??new Uint8Array;switch(t.Type){case at.RSA:return or.rsa.unmarshalRsaPrivateKey(e);case at.Ed25519:return or.ed25519.unmarshalEd25519PrivateKey(e);case at.Secp256k1:return or.secp256k1.unmarshalSecp256k1PrivateKey(e);default:throw Wl(t.Type??"RSA")}}var O0=Symbol.for("nodejs.util.inspect.custom"),Zl=Object.values(re).map(r=>r.decoder).reduce((r,t)=>r.or(t),re.identity.decoder),Xl=114,Ri=36,Li=37,gn=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()})`}[Oa]=!0;toString(){return this.string==null&&(this.string=ut.encode(this.multihash.bytes).slice(1)),this.string}toCID(){return qt.createV1(Xl,this.multihash)}toBytes(){return this.multihash.bytes}toJSON(){return this.toString()}equals(t){if(t==null)return!1;if(t instanceof Uint8Array)return ft(this.multihash.bytes,t);if(typeof t=="string")return Ci(t).equals(this);if(t?.multihash?.bytes!=null)return ft(this.multihash.bytes,t.multihash.bytes);throw new Error("not valid Id")}[O0](){return`PeerId(${this.toString()})`}},Tr=class extends gn{type="RSA";publicKey;constructor(t){super({...t,type:"RSA"}),this.publicKey=t.publicKey}},Rr=class extends gn{type="Ed25519";publicKey;constructor(t){super({...t,type:"Ed25519"}),this.publicKey=t.multihash.digest}},Lr=class extends gn{type="secp256k1";publicKey;constructor(t){super({...t,type:"secp256k1"}),this.publicKey=t.multihash.digest}};function Ci(r,t){if(t=t??Zl,r.charAt(0)==="1"||r.charAt(0)==="Q"){let e=Ne(ut.decode(`z${r}`));return r.startsWith("12D")?new Rr({multihash:e}):r.startsWith("16U")?new Lr({multihash:e}):new Tr({multihash:e})}return H0(Zl.decode(r))}function H0(r){try{let t=Ne(r);if(t.code===Te.code){if(t.digest.length===Ri)return new Rr({multihash:t});if(t.digest.length===Li)return new Lr({multihash:t})}if(t.code===At.code)return new Tr({multihash:t})}catch{return M0(qt.decode(r))}throw new Error("Supplied PeerID CID is invalid")}function M0(r){if(r==null||r.multihash==null||r.version==null||r.version===1&&r.code!==Xl)throw new Error("Supplied PeerID CID is invalid");let t=r.multihash;if(t.code===At.code)return new Tr({multihash:r.multihash});if(t.code===Te.code){if(t.digest.length===Ri)return new Rr({multihash:r.multihash});if(t.digest.length===Li)return new Lr({multihash:r.multihash})}throw new Error("Supplied PeerID CID is invalid")}async function Ui(r,t){return r.length===Ri?new Rr({multihash:$t(Te.code,r),privateKey:t}):r.length===Li?new Lr({multihash:$t(Te.code,r),privateKey:t}):new Tr({multihash:await At.digest(r),publicKey:r,privateKey:t})}var Ql=Symbol.for("@achingbrain/uint8arraylist");function Jl(r,t){if(t==null||t<0)throw new RangeError("index is out of bounds");let e=0;for(let n of r){let s=e+n.byteLength;if(t<s)return{buf:n,index:t-e};e=s}throw new RangeError("index is out of bounds")}function Ls(r){return!!r?.[Ql]}var lt=class r{bufs;length;[Ql]=!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 e=0;for(let n of t)if(n instanceof Uint8Array)e+=n.byteLength,this.bufs.push(n);else if(Ls(n))e+=n.byteLength,this.bufs.push(...n.bufs);else throw new Error("Could not append value, must be an Uint8Array or a Uint8ArrayList");this.length+=e}prepend(...t){this.prependAll(t)}prependAll(t){let e=0;for(let n of t.reverse())if(n instanceof Uint8Array)e+=n.byteLength,this.bufs.unshift(n);else if(Ls(n))e+=n.byteLength,this.bufs.unshift(...n.bufs);else throw new Error("Could not prepend value, must be an Uint8Array or a Uint8ArrayList");this.length+=e}get(t){let e=Jl(this.bufs,t);return e.buf[e.index]}set(t,e){let n=Jl(this.bufs,t);n.buf[n.index]=e}write(t,e=0){if(t instanceof Uint8Array)for(let n=0;n<t.length;n++)this.set(e+n,t[n]);else if(Ls(t))for(let n=0;n<t.length;n++)this.set(e+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,e){let{bufs:n,length:s}=this._subList(t,e);return xt(n,s)}subarray(t,e){let{bufs:n,length:s}=this._subList(t,e);return n.length===1?n[0]:xt(n,s)}sublist(t,e){let{bufs:n,length:s}=this._subList(t,e),o=new r;return o.length=s,o.bufs=[...n],o}_subList(t,e){if(t=t??0,e=e??this.length,t<0&&(t=this.length+t),e<0&&(e=this.length+e),t<0||e>this.length)throw new RangeError("index is out of bounds");if(t===e)return{bufs:[],length:0};if(t===0&&e===this.length)return{bufs:this.bufs,length:this.length};let n=[],s=0;for(let o=0;o<this.bufs.length;o++){let i=this.bufs[o],a=s,c=a+i.byteLength;if(s=c,t>=c)continue;let l=t>=a&&t<c,u=e>a&&e<=c;if(l&&u){if(t===a&&e===c){n.push(i);break}let f=t-a;n.push(i.subarray(f,f+(e-t)));break}if(l){if(t===0){n.push(i);continue}n.push(i.subarray(t-a));continue}if(u){if(e===c){n.push(i);break}n.push(i.subarray(0,e-a));break}n.push(i)}return{bufs:n,length:e-t}}indexOf(t,e=0){if(!Ls(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(e=Number(e??0),isNaN(e)&&(e=0),e<0&&(e=this.length+e),e<0&&(e=0),t.length===0)return e>this.length?this.length:e;let s=n.byteLength;if(s===0)throw new TypeError("search must be at least 1 byte long");let o=256,i=new Int32Array(o);for(let f=0;f<o;f++)i[f]=-1;for(let f=0;f<s;f++)i[n[f]]=f;let a=i,c=this.byteLength-n.byteLength,l=n.byteLength-1,u;for(let f=e;f<=c;f+=u){u=0;for(let g=l;g>=0;g--){let m=this.get(f+g);if(n[g]!==m){u=Math.max(1,g-a[m]);break}}if(u===0)return f}return-1}getInt8(t){let e=this.subarray(t,t+1);return new DataView(e.buffer,e.byteOffset,e.byteLength).getInt8(0)}setInt8(t,e){let n=wt(1);new DataView(n.buffer,n.byteOffset,n.byteLength).setInt8(0,e),this.write(n,t)}getInt16(t,e){let n=this.subarray(t,t+2);return new DataView(n.buffer,n.byteOffset,n.byteLength).getInt16(0,e)}setInt16(t,e,n){let s=mt(2);new DataView(s.buffer,s.byteOffset,s.byteLength).setInt16(0,e,n),this.write(s,t)}getInt32(t,e){let n=this.subarray(t,t+4);return new DataView(n.buffer,n.byteOffset,n.byteLength).getInt32(0,e)}setInt32(t,e,n){let s=mt(4);new DataView(s.buffer,s.byteOffset,s.byteLength).setInt32(0,e,n),this.write(s,t)}getBigInt64(t,e){let n=this.subarray(t,t+8);return new DataView(n.buffer,n.byteOffset,n.byteLength).getBigInt64(0,e)}setBigInt64(t,e,n){let s=mt(8);new DataView(s.buffer,s.byteOffset,s.byteLength).setBigInt64(0,e,n),this.write(s,t)}getUint8(t){let e=this.subarray(t,t+1);return new DataView(e.buffer,e.byteOffset,e.byteLength).getUint8(0)}setUint8(t,e){let n=wt(1);new DataView(n.buffer,n.byteOffset,n.byteLength).setUint8(0,e),this.write(n,t)}getUint16(t,e){let n=this.subarray(t,t+2);return new DataView(n.buffer,n.byteOffset,n.byteLength).getUint16(0,e)}setUint16(t,e,n){let s=mt(2);new DataView(s.buffer,s.byteOffset,s.byteLength).setUint16(0,e,n),this.write(s,t)}getUint32(t,e){let n=this.subarray(t,t+4);return new DataView(n.buffer,n.byteOffset,n.byteLength).getUint32(0,e)}setUint32(t,e,n){let s=mt(4);new DataView(s.buffer,s.byteOffset,s.byteLength).setUint32(0,e,n),this.write(s,t)}getBigUint64(t,e){let n=this.subarray(t,t+8);return new DataView(n.buffer,n.byteOffset,n.byteLength).getBigUint64(0,e)}setBigUint64(t,e,n){let s=mt(8);new DataView(s.buffer,s.byteOffset,s.byteLength).setBigUint64(0,e,n),this.write(s,t)}getFloat32(t,e){let n=this.subarray(t,t+4);return new DataView(n.buffer,n.byteOffset,n.byteLength).getFloat32(0,e)}setFloat32(t,e,n){let s=mt(4);new DataView(s.buffer,s.byteOffset,s.byteLength).setFloat32(0,e,n),this.write(s,t)}getFloat64(t,e){let n=this.subarray(t,t+8);return new DataView(n.buffer,n.byteOffset,n.byteLength).getFloat64(0,e)}setFloat64(t,e,n){let s=mt(8);new DataView(s.buffer,s.byteOffset,s.byteLength).setFloat64(0,e,n),this.write(s,t)}equals(t){if(t==null||!(t instanceof r)||t.bufs.length!==this.bufs.length)return!1;for(let e=0;e<this.bufs.length;e++)if(!ft(this.bufs[e],t.bufs[e]))return!1;return!0}static fromUint8Arrays(t,e){let n=new r;return n.bufs=t,e==null&&(e=t.reduce((s,o)=>s+o.byteLength,0)),n.length=e,n}};function Cs(r){return r[Symbol.asyncIterator]!=null}var Us=r=>{let t=dt(r),e=wt(t);return ne(r,e),Us.bytes=t,e};Us.bytes=0;function tu(r,t){t=t??{};let e=t.lengthEncoder??Us;function*n(s){let o=e(s.byteLength);o instanceof Uint8Array?yield o:yield*o,s instanceof Uint8Array?yield s:yield*s}return Cs(r)?async function*(){for await(let s of r)yield*n(s)}():function*(){for(let s of r)yield*n(s)}()}tu.single=(r,t)=>{t=t??{};let e=t.lengthEncoder??Us;return new lt(e(r.byteLength),r)};var Cr=Va(nu(),1);var F0=8,$0=1024*1024*4,ir;(function(r){r[r.LENGTH=0]="LENGTH",r[r.DATA=1]="DATA"})(ir||(ir={}));var Pi=r=>{let t=Yt(r);return Pi.bytes=dt(t),t};Pi.bytes=0;function yn(r,t){let e=new lt,n=ir.LENGTH,s=-1,o=t?.lengthDecoder??Pi,i=t?.maxLengthLength??F0,a=t?.maxDataLength??$0;function*c(){for(;e.byteLength>0;){if(n===ir.LENGTH)try{if(s=o(e),s<0)throw(0,Cr.default)(new Error("invalid message length"),"ERR_INVALID_MSG_LENGTH");if(s>a)throw(0,Cr.default)(new Error("message length too long"),"ERR_MSG_DATA_TOO_LONG");let l=o.bytes;e.consume(l),t?.onLength!=null&&t.onLength(s),n=ir.DATA}catch(l){if(l instanceof RangeError){if(e.byteLength>i)throw(0,Cr.default)(new Error("message length length too long"),"ERR_MSG_LENGTH_TOO_LONG");break}throw l}if(n===ir.DATA){if(e.byteLength<s)break;let l=e.sublist(0,s);e.consume(s),t?.onData!=null&&t.onData(l),yield l,n=ir.LENGTH}}}return Cs(r)?async function*(){for await(let l of r)e.append(l),yield*c();if(e.byteLength>0)throw(0,Cr.default)(new Error("unexpected end of input"),"ERR_UNEXPECTED_EOF")}():function*(){for(let l of r)e.append(l),yield*c();if(e.byteLength>0)throw(0,Cr.default)(new Error("unexpected end of input"),"ERR_UNEXPECTED_EOF")}()}yn.fromReader=(r,t)=>{let e=1,n=async function*(){for(;;)try{let{done:o,value:i}=await r.next(e);if(o===!0)return;i!=null&&(yield i)}catch(o){if(o.code==="ERR_UNDER_READ")return{done:!0,value:null};throw o}finally{e=1}}();return yn(n,{...t??{},onLength:o=>{e=o}})};function te(){let r={};return r.promise=new Promise((t,e)=>{r.resolve=t,r.reject=e}),r}var Ps=class extends Error{type;code;constructor(t,e){super(t??"The operation was aborted"),this.type="aborted",this.name="AbortError",this.code=e??"ABORT_ERR"}};async function su(r,t,e){if(t==null)return r;if(t.aborted)return Promise.reject(new Ps(e?.errorMessage,e?.errorCode));let n,s=new Ps(e?.errorMessage,e?.errorCode);try{return await Promise.race([r,new Promise((o,i)=>{n=()=>{i(s)},t.addEventListener("abort",n)})])}finally{n!=null&&t.removeEventListener("abort",n)}}var Di=class{readNext;haveNext;ended;nextResult;constructor(){this.ended=!1,this.readNext=te(),this.haveNext=te()}[Symbol.asyncIterator](){return this}async next(){if(this.nextResult==null&&await this.haveNext.promise,this.nextResult==null)throw new Error("HaveNext promise resolved but nextResult was undefined");let t=this.nextResult;return this.nextResult=void 0,this.readNext.resolve(),this.readNext=te(),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,e){await this._push(t,e)}async end(t,e){t!=null?await this.throw(t):await this._push(void 0,e)}async _push(t,e){if(t!=null&&this.ended)throw new Error("Cannot push value onto an ended pushable");if(this.nextResult!=null&&(await this.readNext.promise,this.nextResult!=null))throw new Error("NeedNext promise resolved but nextResult was not consumed");t!=null?this.nextResult={done:!1,value:t}:(this.ended=!0,this.nextResult={done:!0,value:void 0}),this.haveNext.resolve(),this.haveNext=te(),await su(this.readNext.promise,e?.signal,e)}};function ou(){return new Di}var Ds=class extends Error{code;constructor(t,e){super(t),this.code=e}},Vi=class extends Ds{type;constructor(t){super(t,"ABORT_ERR"),this.type="aborted"}};function iu(r,t){let e=ou();r.sink(e).catch(async i=>{await e.end(i)}),r.sink=async i=>{for await(let a of i)await e.push(a);await e.end()};let n=r.source;r.source[Symbol.iterator]!=null?n=r.source[Symbol.iterator]():r.source[Symbol.asyncIterator]!=null&&(n=r.source[Symbol.asyncIterator]());let s=new lt;return{read:async(i,a)=>{a?.signal?.throwIfAborted();let c,l=new Promise((u,f)=>{c=()=>{f(new Vi("Read aborted"))},a?.signal?.addEventListener("abort",c)});try{if(i==null){let{done:f,value:g}=await Promise.race([n.next(),l]);return f===!0?new lt:g}for(;s.byteLength<i;){let{value:f,done:g}=await Promise.race([n.next(),l]);if(g===!0)throw new Ds("unexpected end of input","ERR_UNEXPECTED_EOF");s.append(f)}let u=s.sublist(0,i);return s.consume(i),u}finally{c!=null&&a?.signal?.removeEventListener("abort",c)}},write:async(i,a)=>{a?.signal?.throwIfAborted(),i instanceof Uint8Array?await e.push(i,a):await e.push(i.subarray(),a)},unwrap:()=>{if(s.byteLength>0){let i=r.source;r.source=async function*(){t?.yieldBytes===!1?yield s:yield*s,yield*i}()}return r}}}var Vs=class extends Error{code;constructor(t,e){super(t),this.code=e}};function Oi(r,t={}){let e=iu(r,t);t.maxDataLength!=null&&t.maxLengthLength==null&&(t.maxLengthLength=dt(t.maxDataLength));let n=t?.lengthDecoder??Yt,s=t?.lengthEncoder??ne;return{read:async i=>{let a=-1,c=new lt;for(;;){c.append(await e.read(1,i));try{a=n(c)}catch(l){if(l instanceof RangeError)continue;throw l}if(t?.maxLengthLength!=null&&c.byteLength>t.maxLengthLength)throw new Vs("message length length too long","ERR_MSG_LENGTH_TOO_LONG");if(a>-1)break}if(t?.maxDataLength!=null&&a>t.maxDataLength)throw new Vs("message length too long","ERR_MSG_DATA_TOO_LONG");return e.read(a,i)},write:async(i,a)=>{await e.write(new lt(s(i.byteLength),i),a)},writeV:async(i,a)=>{let c=new lt(...i.flatMap(l=>[s(l.byteLength),l]));await e.write(c,a)},unwrap:()=>e.unwrap()}}function Hi(){let r=te(),t=!1;return{sink:async e=>{if(t)throw new Error("already piped");t=!0,r.resolve(e)},source:async function*(){yield*await r.promise}()}}function au(){let r=Hi(),t=Hi();return[{source:r.source,sink:t.sink},{source:t.source,sink:r.sink}]}var Os=class{buffer;mask;top;btm;next;constructor(t){if(!(t>0)||t-1&t)throw new Error("Max size for a FixedFIFO should be a power of two");this.buffer=new Array(t),this.mask=t-1,this.top=0,this.btm=0,this.next=null}push(t){return this.buffer[this.top]!==void 0?!1:(this.buffer[this.top]=t,this.top=this.top+1&this.mask,!0)}shift(){let t=this.buffer[this.btm];if(t!==void 0)return this.buffer[this.btm]=void 0,this.btm=this.btm+1&this.mask,t}isEmpty(){return this.buffer[this.btm]===void 0}},Ur=class{size;hwm;head;tail;constructor(t={}){this.hwm=t.splitLimit??16,this.head=new Os(this.hwm),this.tail=this.head,this.size=0}calculateSize(t){return t?.byteLength!=null?t.byteLength:1}push(t){if(t?.value!=null&&(this.size+=this.calculateSize(t.value)),!this.head.push(t)){let e=this.head;this.head=e.next=new Os(2*this.head.buffer.length),this.head.push(t)}}shift(){let t=this.tail.shift();if(t===void 0&&this.tail.next!=null){let e=this.tail.next;this.tail.next=null,this.tail=e,t=this.tail.shift()}return t?.value!=null&&(this.size-=this.calculateSize(t.value)),t}isEmpty(){return this.head.isEmpty()}};var Mi=class extends Error{type;code;constructor(t,e){super(t??"The operation was aborted"),this.type="aborted",this.code=e??"ABORT_ERR"}};function Hs(r={}){return q0(e=>{let n=e.shift();if(n==null)return{done:!0};if(n.error!=null)throw n.error;return{done:n.done===!0,value:n.value}},r)}function q0(r,t){t=t??{};let e=t.onEnd,n=new Ur,s,o,i,a=te(),c=async()=>{try{return n.isEmpty()?i?{done:!0}:await new Promise((p,b)=>{o=v=>{o=null,n.push(v);try{p(r(n))}catch(w){b(w)}return s}}):r(n)}finally{n.isEmpty()&&queueMicrotask(()=>{a.resolve(),a=te()})}},l=p=>o!=null?o(p):(n.push(p),s),u=p=>(n=new Ur,o!=null?o({error:p}):(n.push({error:p}),s)),f=p=>{if(i)return s;if(t?.objectMode!==!0&&p?.byteLength==null)throw new Error("objectMode was not true but tried to push non-Uint8Array value");return l({done:!1,value:p})},g=p=>i?s:(i=!0,p!=null?u(p):l({done:!0})),m=()=>(n=new Ur,g(),{done:!0}),d=p=>(g(p),{done:!0});if(s={[Symbol.asyncIterator](){return this},next:c,return:m,throw:d,push:f,end:g,get readableLength(){return n.size},onEmpty:async p=>{let b=p?.signal;if(b?.throwIfAborted(),n.isEmpty())return;let v,w;b!=null&&(v=new Promise((A,B)=>{w=()=>{B(new Mi)},b.addEventListener("abort",w)}));try{await Promise.race([a.promise,v])}finally{w!=null&&b!=null&&b?.removeEventListener("abort",w)}}},e==null)return s;let h=s;return s={[Symbol.asyncIterator](){return this},next(){return h.next()},throw(p){return h.throw(p),e!=null&&(e(p),e=void 0),{done:!0}},return(){return h.return(),e!=null&&(e(),e=void 0),{done:!0}},push:f,end(p){return h.end(p),e!=null&&(e(p),e=void 0),s},get readableLength(){return h.readableLength},onEmpty:p=>h.onEmpty(p)},s}function G0(r){return r[Symbol.asyncIterator]!=null}function j0(...r){let t=[];for(let e of r)G0(e)||t.push(e);return t.length===r.length?function*(){for(let e of t)yield*e}():async function*(){let e=Hs({objectMode:!0});Promise.resolve().then(async()=>{try{await Promise.all(r.map(async n=>{for await(let s of n)e.push(s)})),e.end()}catch(n){e.end(n)}}),yield*e}()}var cu=j0;function lu(r,...t){if(r==null)throw new Error("Empty pipeline");if(Ki(r)){let n=r;r=()=>n.source}else if(fu(r)||uu(r)){let n=r;r=()=>n}let e=[r,...t];if(e.length>1&&Ki(e[e.length-1])&&(e[e.length-1]=e[e.length-1].sink),e.length>2)for(let n=1;n<e.length-1;n++)Ki(e[n])&&(e[n]=W0(e[n]));return z0(...e)}var z0=(...r)=>{let t;for(;r.length>0;)t=r.shift()(t);return t},uu=r=>r?.[Symbol.asyncIterator]!=null,fu=r=>r?.[Symbol.iterator]!=null,Ki=r=>r==null?!1:r.sink!=null&&r.source!=null,W0=r=>t=>{let e=r.sink(t);if(e?.then!=null){let n=Hs({objectMode:!0});e.then(()=>{n.end()},i=>{n.end(i)});let s,o=r.source;if(uu(o))s=async function*(){yield*o,n.end()};else if(fu(o))s=function*(){yield*o,n.end()};else throw new Error("Unknown duplex source type - must be Iterable or AsyncIterable");return cu(n,s())}return r.source};var Pr=!!globalThis.process?.env?.DUMP_SESSION_KEYS;var Ie=r=>new Uint32Array(r.buffer,r.byteOffset,Math.floor(r.byteLength/4));function hu(r){return r instanceof Uint8Array||r!=null&&typeof r=="object"&&r.constructor.name==="Uint8Array"}var du=r=>new DataView(r.buffer,r.byteOffset,r.byteLength),Y0=new Uint8Array(new Uint32Array([287454020]).buffer)[0]===68;if(!Y0)throw new Error("Non little-endian hardware is not supported");function Ms(r){if(typeof r!="string")throw new Error(`utf8ToBytes expected string, got ${typeof r}`);return new Uint8Array(new TextEncoder().encode(r))}function Ks(r){if(typeof r=="string")r=Ms(r);else if(hu(r))r=r.slice();else throw new Error(`expected Uint8Array, got ${typeof r}`);return r}var Z0=r=>Object.prototype.toString.call(r)==="[object Object]"&&r.constructor===Object;function pu(r,t){if(t!==void 0&&(typeof t!="object"||!Z0(t)))throw new Error("options must be object or undefined");return Object.assign(r,t)}function ar(r,t){if(!hu(r))throw new Error("Uint8Array expected");if(typeof t=="number"&&r.length!==t)throw new Error(`Uint8Array length ${t} expected`)}function gu(r,t){if(r.length!==t.length)return!1;let e=0;for(let n=0;n<r.length;n++)e|=r[n]^t[n];return e===0}var Fi=(r,t)=>(Object.assign(t,r),t);function $i(r,t,e,n){if(typeof r.setBigUint64=="function")return r.setBigUint64(t,e,n);let s=BigInt(32),o=BigInt(4294967295),i=Number(e>>s&o),a=Number(e&o),c=n?4:0,l=n?0:4;r.setUint32(t+c,i,n),r.setUint32(t+l,a,n)}function Fs(r){if(!Number.isSafeInteger(r)||r<0)throw new Error(`wrong positive integer: ${r}`)}function qi(r){if(typeof r!="boolean")throw new Error(`boolean expected, not ${r}`)}function X0(r){return r!=null&&typeof r=="object"&&(r instanceof Uint8Array||r.constructor.name==="Uint8Array")}function Dr(r,...t){if(!X0(r))throw new Error("Uint8Array expected");if(t.length>0&&!t.includes(r.length))throw new Error(`Uint8Array expected of length ${t}, not of length=${r.length}`)}function Gi(r,t=!0){if(r.destroyed)throw new Error("Hash instance has been destroyed");if(t&&r.finished)throw new Error("Hash#digest() has already been called")}function yu(r,t){Dr(r);let e=t.outputLen;if(r.length<e)throw new Error(`digestInto() expects output buffer of length at least ${e}`)}var kt=(r,t)=>r[t++]&255|(r[t++]&255)<<8,ji=class{constructor(t){this.blockLen=16,this.outputLen=16,this.buffer=new Uint8Array(16),this.r=new Uint16Array(10),this.h=new Uint16Array(10),this.pad=new Uint16Array(8),this.pos=0,this.finished=!1,t=Ks(t),ar(t,32);let e=kt(t,0),n=kt(t,2),s=kt(t,4),o=kt(t,6),i=kt(t,8),a=kt(t,10),c=kt(t,12),l=kt(t,14);this.r[0]=e&8191,this.r[1]=(e>>>13|n<<3)&8191,this.r[2]=(n>>>10|s<<6)&7939,this.r[3]=(s>>>7|o<<9)&8191,this.r[4]=(o>>>4|i<<12)&255,this.r[5]=i>>>1&8190,this.r[6]=(i>>>14|a<<2)&8191,this.r[7]=(a>>>11|c<<5)&8065,this.r[8]=(c>>>8|l<<8)&8191,this.r[9]=l>>>5&127;for(let u=0;u<8;u++)this.pad[u]=kt(t,16+2*u)}process(t,e,n=!1){let s=n?0:2048,{h:o,r:i}=this,a=i[0],c=i[1],l=i[2],u=i[3],f=i[4],g=i[5],m=i[6],d=i[7],h=i[8],p=i[9],b=kt(t,e+0),v=kt(t,e+2),w=kt(t,e+4),A=kt(t,e+6),B=kt(t,e+8),S=kt(t,e+10),N=kt(t,e+12),_=kt(t,e+14),V=o[0]+(b&8191),P=o[1]+((b>>>13|v<<3)&8191),R=o[2]+((v>>>10|w<<6)&8191),H=o[3]+((w>>>7|A<<9)&8191),O=o[4]+((A>>>4|B<<12)&8191),W=o[5]+(B>>>1&8191),x=o[6]+((B>>>14|S<<2)&8191),I=o[7]+((S>>>11|N<<5)&8191),C=o[8]+((N>>>8|_<<8)&8191),E=o[9]+(_>>>5|s),y=0,k=y+V*a+P*(5*p)+R*(5*h)+H*(5*d)+O*(5*m);y=k>>>13,k&=8191,k+=W*(5*g)+x*(5*f)+I*(5*u)+C*(5*l)+E*(5*c),y+=k>>>13,k&=8191;let T=y+V*c+P*a+R*(5*p)+H*(5*h)+O*(5*d);y=T>>>13,T&=8191,T+=W*(5*m)+x*(5*g)+I*(5*f)+C*(5*u)+E*(5*l),y+=T>>>13,T&=8191;let L=y+V*l+P*c+R*a+H*(5*p)+O*(5*h);y=L>>>13,L&=8191,L+=W*(5*d)+x*(5*m)+I*(5*g)+C*(5*f)+E*(5*u),y+=L>>>13,L&=8191;let M=y+V*u+P*l+R*c+H*a+O*(5*p);y=M>>>13,M&=8191,M+=W*(5*h)+x*(5*d)+I*(5*m)+C*(5*g)+E*(5*f),y+=M>>>13,M&=8191;let K=y+V*f+P*u+R*l+H*c+O*a;y=K>>>13,K&=8191,K+=W*(5*p)+x*(5*h)+I*(5*d)+C*(5*m)+E*(5*g),y+=K>>>13,K&=8191;let j=y+V*g+P*f+R*u+H*l+O*c;y=j>>>13,j&=8191,j+=W*a+x*(5*p)+I*(5*h)+C*(5*d)+E*(5*m),y+=j>>>13,j&=8191;let $=y+V*m+P*g+R*f+H*u+O*l;y=$>>>13,$&=8191,$+=W*c+x*a+I*(5*p)+C*(5*h)+E*(5*d),y+=$>>>13,$&=8191;let G=y+V*d+P*m+R*g+H*f+O*u;y=G>>>13,G&=8191,G+=W*l+x*c+I*a+C*(5*p)+E*(5*h),y+=G>>>13,G&=8191;let nt=y+V*h+P*d+R*m+H*g+O*f;y=nt>>>13,nt&=8191,nt+=W*u+x*l+I*c+C*a+E*(5*p),y+=nt>>>13,nt&=8191;let tt=y+V*p+P*h+R*d+H*m+O*g;y=tt>>>13,tt&=8191,tt+=W*f+x*u+I*l+C*c+E*a,y+=tt>>>13,tt&=8191,y=(y<<2)+y|0,y=y+k|0,k=y&8191,y=y>>>13,T+=y,o[0]=k,o[1]=T,o[2]=L,o[3]=M,o[4]=K,o[5]=j,o[6]=$,o[7]=G,o[8]=nt,o[9]=tt}finalize(){let{h:t,pad:e}=this,n=new Uint16Array(10),s=t[1]>>>13;t[1]&=8191;for(let a=2;a<10;a++)t[a]+=s,s=t[a]>>>13,t[a]&=8191;t[0]+=s*5,s=t[0]>>>13,t[0]&=8191,t[1]+=s,s=t[1]>>>13,t[1]&=8191,t[2]+=s,n[0]=t[0]+5,s=n[0]>>>13,n[0]&=8191;for(let a=1;a<10;a++)n[a]=t[a]+s,s=n[a]>>>13,n[a]&=8191;n[9]-=8192;let o=(s^1)-1;for(let a=0;a<10;a++)n[a]&=o;o=~o;for(let a=0;a<10;a++)t[a]=t[a]&o|n[a];t[0]=(t[0]|t[1]<<13)&65535,t[1]=(t[1]>>>3|t[2]<<10)&65535,t[2]=(t[2]>>>6|t[3]<<7)&65535,t[3]=(t[3]>>>9|t[4]<<4)&65535,t[4]=(t[4]>>>12|t[5]<<1|t[6]<<14)&65535,t[5]=(t[6]>>>2|t[7]<<11)&65535,t[6]=(t[7]>>>5|t[8]<<8)&65535,t[7]=(t[8]>>>8|t[9]<<5)&65535;let i=t[0]+e[0];t[0]=i&65535;for(let a=1;a<8;a++)i=(t[a]+e[a]|0)+(i>>>16)|0,t[a]=i&65535}update(t){Gi(this);let{buffer:e,blockLen:n}=this;t=Ks(t);let s=t.length;for(let o=0;o<s;){let i=Math.min(n-this.pos,s-o);if(i===n){for(;n<=s-o;o+=n)this.process(t,o);continue}e.set(t.subarray(o,o+i),this.pos),this.pos+=i,o+=i,this.pos===n&&(this.process(e,0,!1),this.pos=0)}return this}destroy(){this.h.fill(0),this.r.fill(0),this.buffer.fill(0),this.pad.fill(0)}digestInto(t){Gi(this),yu(t,this),this.finished=!0;let{buffer:e,h:n}=this,{pos:s}=this;if(s){for(e[s++]=1;s<16;s++)e[s]=0;this.process(e,0,!0)}this.finalize();let o=0;for(let i=0;i<8;i++)t[o++]=n[i]>>>0,t[o++]=n[i]>>>8;return t}digest(){let{buffer:t,outputLen:e}=this;this.digestInto(t);let n=t.slice(0,e);return this.destroy(),n}};function J0(r){let t=(n,s)=>r(s).update(Ks(n)).digest(),e=r(new Uint8Array(32));return t.outputLen=e.outputLen,t.blockLen=e.blockLen,t.create=n=>r(n),t}var mu=J0(r=>new ji(r));var Q0=Ms("expand 16-byte k"),tp=Ms("expand 32-byte k"),ep=Ie(Q0),rp=Ie(tp);function D(r,t){return r<<t|r>>>32-t}function zi(r){return r.byteOffset%4===0}var $s=64,np=16,bu=2**32-1,wu=new Uint32Array;function sp(r,t,e,n,s,o,i,a){let c=s.length,l=new Uint8Array($s),u=Ie(l),f=zi(s)&&zi(o),g=f?Ie(s):wu,m=f?Ie(o):wu;for(let d=0;d<c;i++){if(r(t,e,n,u,i,a),i>=bu)throw new Error("arx: counter overflow");let h=Math.min($s,c-d);if(f&&h===$s){let p=d/4;if(d%4!==0)throw new Error("arx: invalid block position");for(let b=0,v;b<np;b++)v=p+b,m[v]=g[v]^u[b];d+=$s;continue}for(let p=0,b;p<h;p++)b=d+p,o[b]=s[b]^l[p];d+=h}}function Wi(r,t){let{allowShortKeys:e,extendNonceFn:n,counterLength:s,counterRight:o,rounds:i}=pu({allowShortKeys:!1,counterLength:8,counterRight:!1,rounds:20},t);if(typeof r!="function")throw new Error("core must be a function");return Fs(s),Fs(i),qi(o),qi(e),(a,c,l,u,f=0)=>{Dr(a),Dr(c),Dr(l);let g=l.length;if(u||(u=new Uint8Array(g)),Dr(u),Fs(f),f<0||f>=bu)throw new Error("arx: counter overflow");if(u.length<g)throw new Error(`arx: output (${u.length}) is shorter than data (${g})`);let m=[],d=a.length,h,p;if(d===32)h=a.slice(),m.push(h),p=rp;else if(d===16&&e)h=new Uint8Array(32),h.set(a),h.set(a,16),p=ep,m.push(h);else throw new Error(`arx: invalid 32-byte key, got length=${d}`);zi(c)||(c=c.slice(),m.push(c));let b=Ie(h);if(n){if(c.length!==24)throw new Error("arx: extended nonce must be 24 bytes");n(p,b,Ie(c.subarray(0,16)),b),c=c.subarray(16)}let v=16-s;if(v!==c.length)throw new Error(`arx: nonce must be ${v} or 16 bytes`);if(v!==12){let A=new Uint8Array(12);A.set(c,o?0:12-c.length),c=A,m.push(c)}let w=Ie(c);for(sp(r,p,b,w,l,u,f,i);m.length>0;)m.pop().fill(0);return u}}function vu(r,t,e,n,s,o=20){let i=r[0],a=r[1],c=r[2],l=r[3],u=t[0],f=t[1],g=t[2],m=t[3],d=t[4],h=t[5],p=t[6],b=t[7],v=s,w=e[0],A=e[1],B=e[2],S=i,N=a,_=c,V=l,P=u,R=f,H=g,O=m,W=d,x=h,I=p,C=b,E=v,y=w,k=A,T=B;for(let M=0;M<o;M+=2)S=S+P|0,E=D(E^S,16),W=W+E|0,P=D(P^W,12),S=S+P|0,E=D(E^S,8),W=W+E|0,P=D(P^W,7),N=N+R|0,y=D(y^N,16),x=x+y|0,R=D(R^x,12),N=N+R|0,y=D(y^N,8),x=x+y|0,R=D(R^x,7),_=_+H|0,k=D(k^_,16),I=I+k|0,H=D(H^I,12),_=_+H|0,k=D(k^_,8),I=I+k|0,H=D(H^I,7),V=V+O|0,T=D(T^V,16),C=C+T|0,O=D(O^C,12),V=V+O|0,T=D(T^V,8),C=C+T|0,O=D(O^C,7),S=S+R|0,T=D(T^S,16),I=I+T|0,R=D(R^I,12),S=S+R|0,T=D(T^S,8),I=I+T|0,R=D(R^I,7),N=N+H|0,E=D(E^N,16),C=C+E|0,H=D(H^C,12),N=N+H|0,E=D(E^N,8),C=C+E|0,H=D(H^C,7),_=_+O|0,y=D(y^_,16),W=W+y|0,O=D(O^W,12),_=_+O|0,y=D(y^_,8),W=W+y|0,O=D(O^W,7),V=V+P|0,k=D(k^V,16),x=x+k|0,P=D(P^x,12),V=V+P|0,k=D(k^V,8),x=x+k|0,P=D(P^x,7);let L=0;n[L++]=i+S|0,n[L++]=a+N|0,n[L++]=c+_|0,n[L++]=l+V|0,n[L++]=u+P|0,n[L++]=f+R|0,n[L++]=g+H|0,n[L++]=m+O|0,n[L++]=d+W|0,n[L++]=h+x|0,n[L++]=p+I|0,n[L++]=b+C|0,n[L++]=v+E|0,n[L++]=w+y|0,n[L++]=A+k|0,n[L++]=B+T|0}function op(r,t,e,n){let s=r[0],o=r[1],i=r[2],a=r[3],c=t[0],l=t[1],u=t[2],f=t[3],g=t[4],m=t[5],d=t[6],h=t[7],p=e[0],b=e[1],v=e[2],w=e[3];for(let B=0;B<20;B+=2)s=s+c|0,p=D(p^s,16),g=g+p|0,c=D(c^g,12),s=s+c|0,p=D(p^s,8),g=g+p|0,c=D(c^g,7),o=o+l|0,b=D(b^o,16),m=m+b|0,l=D(l^m,12),o=o+l|0,b=D(b^o,8),m=m+b|0,l=D(l^m,7),i=i+u|0,v=D(v^i,16),d=d+v|0,u=D(u^d,12),i=i+u|0,v=D(v^i,8),d=d+v|0,u=D(u^d,7),a=a+f|0,w=D(w^a,16),h=h+w|0,f=D(f^h,12),a=a+f|0,w=D(w^a,8),h=h+w|0,f=D(f^h,7),s=s+l|0,w=D(w^s,16),d=d+w|0,l=D(l^d,12),s=s+l|0,w=D(w^s,8),d=d+w|0,l=D(l^d,7),o=o+u|0,p=D(p^o,16),h=h+p|0,u=D(u^h,12),o=o+u|0,p=D(p^o,8),h=h+p|0,u=D(u^h,7),i=i+f|0,b=D(b^i,16),g=g+b|0,f=D(f^g,12),i=i+f|0,b=D(b^i,8),g=g+b|0,f=D(f^g,7),a=a+c|0,v=D(v^a,16),m=m+v|0,c=D(c^m,12),a=a+c|0,v=D(v^a,8),m=m+v|0,c=D(c^m,7);let A=0;n[A++]=s,n[A++]=o,n[A++]=i,n[A++]=a,n[A++]=p,n[A++]=b,n[A++]=v,n[A++]=w}var ip=Wi(vu,{counterRight:!1,counterLength:4,allowShortKeys:!1}),ap=Wi(vu,{counterRight:!1,counterLength:8,extendNonceFn:op,allowShortKeys:!1});var cp=new Uint8Array(16),xu=(r,t)=>{r.update(t);let e=t.length%16;e&&r.update(cp.subarray(e))},lp=new Uint8Array(32);function Eu(r,t,e,n,s){let o=r(t,e,lp),i=mu.create(o);s&&xu(i,s),xu(i,n);let a=new Uint8Array(16),c=du(a);$i(c,0,BigInt(s?s.length:0),!0),$i(c,8,BigInt(n.length),!0),i.update(a);let l=i.digest();return o.fill(0),l}var Bu=r=>(t,e,n)=>(ar(t,32),ar(e),{encrypt:(o,i)=>{let a=o.length,c=a+16;i?ar(i,c):i=new Uint8Array(c),r(t,e,o,i,1);let l=Eu(r,t,e,i.subarray(0,-16),n);return i.set(l,a),i},decrypt:(o,i)=>{let a=o.length,c=a-16;if(a<16)throw new Error("encrypted data must be at least 16 bytes");i?ar(i,c):i=new Uint8Array(c);let l=o.subarray(0,-16),u=o.subarray(-16),f=Eu(r,t,e,l,n);if(!gu(u,f))throw new Error("invalid tag");return r(t,e,l,i,1),i}}),Yi=Fi({blockSize:64,nonceLength:12,tagLength:16},Bu(ip)),Yb=Fi({blockSize:64,nonceLength:24,tagLength:16},Bu(ap));function Su(r,t,e){return je(r),e===void 0&&(e=new Uint8Array(r.outputLen)),Ve(r,jt(e),jt(t))}var Zi=new Uint8Array([0]),Au=new Uint8Array;function ku(r,t,e,n=32){if(je(r),Re(n),n>255*r.outputLen)throw new Error("Length should be <= 255*HashLen");let s=Math.ceil(n/r.outputLen);e===void 0&&(e=Au);let o=new Uint8Array(s*r.outputLen),i=Ve.create(r,t),a=i._cloneInto(),c=new Uint8Array(i.outputLen);for(let l=0;l<s;l++)Zi[0]=l+1,a.update(l===0?Au:c).update(e).update(Zi).digestInto(c),o.set(c,r.outputLen*l),i._cloneInto(a);return i.destroy(),a.destroy(),c.fill(0),Zi.fill(0),o.slice(0,n)}var Xi={hashSHA256(r){return Nr(r.subarray())},getHKDF(r,t){let e=Su(Nr,t,r),s=ku(Nr,e,void 0,96),o=s.subarray(0,32),i=s.subarray(32,64),a=s.subarray(64,96);return[o,i,a]},generateX25519KeyPair(){let r=Zr.utils.randomPrivateKey();return{publicKey:Zr.getPublicKey(r),privateKey:r}},generateX25519KeyPairFromSeed(r){return{publicKey:Zr.getPublicKey(r),privateKey:r}},generateX25519SharedKey(r,t){return Zr.getSharedSecret(r.subarray(),t.subarray())},chaCha20Poly1305Encrypt(r,t,e,n){return Yi(n,t,e).encrypt(r.subarray())},chaCha20Poly1305Decrypt(r,t,e,n,s){return Yi(n,t,e).decrypt(r.subarray(),s)}};var Iu=Xi;function _u(r){return{generateKeypair:r.generateX25519KeyPair,dh:(t,e)=>r.generateX25519SharedKey(t.privateKey,e).subarray(0,32),encrypt:r.chaCha20Poly1305Encrypt,decrypt:r.chaCha20Poly1305Decrypt,hash:r.hashSHA256,hkdf:r.getHKDF}}var Vr=r=>{let t=wt(2);return t[0]=r>>8,t[1]=r,t};Vr.bytes=2;var mn=r=>{if(r.length<2)throw RangeError("Could not decode int16BE");if(r instanceof Uint8Array){let t=0;return t+=r[0]<<8,t+=r[1],t}return r.getUint16(0)};mn.bytes=2;function Nu(r){return{xxHandshakeSuccesses:r.registerCounter("libp2p_noise_xxhandshake_successes_total",{help:"Total count of noise xxHandshakes successes_"}),xxHandshakeErrors:r.registerCounter("libp2p_noise_xxhandshake_error_total",{help:"Total count of noise xxHandshakes errors"}),encryptedPackets:r.registerCounter("libp2p_noise_encrypted_packets_total",{help:"Total count of noise encrypted packets successfully"}),decryptedPackets:r.registerCounter("libp2p_noise_decrypted_packets_total",{help:"Total count of noise decrypted packets"}),decryptErrors:r.registerCounter("libp2p_noise_decrypt_errors_total",{help:"Total count of noise decrypt errors"})}}function Ji(r,t){!t.enabled||!Pr||(r?(t(`LOCAL_STATIC_PUBLIC_KEY ${q(r.publicKey,"hex")}`),t(`LOCAL_STATIC_PRIVATE_KEY ${q(r.privateKey,"hex")}`)):t("Missing local static keys."))}function Qi(r,t){!t.enabled||!Pr||(r?(t(`LOCAL_PUBLIC_EPHEMERAL_KEY ${q(r.publicKey,"hex")}`),t(`LOCAL_PRIVATE_EPHEMERAL_KEY ${q(r.privateKey,"hex")}`)):t("Missing local ephemeral keys."))}function Tu(r,t){!t.enabled||!Pr||t(r?`REMOTE_STATIC_PUBLIC_KEY ${q(r.subarray(),"hex")}`:"Missing remote static public key.")}function ta(r,t){!t.enabled||!Pr||t(r?`REMOTE_EPHEMERAL_PUBLIC_KEY ${q(r.subarray(),"hex")}`:"Missing remote ephemeral keys.")}function ea(r,t,e){!e.enabled||!Pr||(e(`CIPHER_STATE_1 ${r.n.getUint64()} ${r.k&&q(r.k,"hex")}`),e(`CIPHER_STATE_2 ${t.n.getUint64()} ${t.k&&q(t.k,"hex")}`))}var qs=class r extends Error{code;constructor(t="Unexpected Peer"){super(t),this.code=r.code}static code="ERR_UNEXPECTED_PEER"},Or=class r extends Error{code;constructor(t="Invalid crypto exchange"){super(t),this.code=r.code}static code="ERR_INVALID_CRYPTO_EXCHANGE"};var up=0,fp=4294967295,hp="Cipherstate has reached maximum n, a new handshake must be performed",Gs=class{n;bytes;view;constructor(t=up){this.n=t,this.bytes=mt(12),this.view=new DataView(this.bytes.buffer,this.bytes.byteOffset,this.bytes.byteLength),this.view.setUint32(4,t,!0)}increment(){this.n++,this.view.setUint32(4,this.n,!0)}getBytes(){return this.bytes}getUint64(){return this.n}assertValue(){if(this.n>fp)throw new Error(hp)}};var cr=mt(0),Hr=class{k;n;crypto;constructor(t,e=void 0,n=0){this.crypto=t,this.k=e,this.n=new Gs(n)}hasKey(){return!!this.k}encryptWithAd(t,e){if(!this.hasKey())return e;this.n.assertValue();let n=this.crypto.encrypt(e,this.n.getBytes(),t,this.k);return this.n.increment(),n}decryptWithAd(t,e,n){if(!this.hasKey())return e;this.n.assertValue();let s=this.crypto.decrypt(e,this.n.getBytes(),t,this.k,n);return this.n.increment(),s}},ra=class{cs;ck;h;crypto;constructor(t,e){this.crypto=t;let n=et(e,"utf-8");this.h=dp(t,n),this.ck=this.h,this.cs=new Hr(t)}mixKey(t){let[e,n]=this.crypto.hkdf(this.ck,t);this.ck=e,this.cs=new Hr(this.crypto,n)}mixHash(t){this.h=this.crypto.hash(new lt(this.h,t))}encryptAndHash(t){let e=this.cs.encryptWithAd(this.h,t);return this.mixHash(e),e}decryptAndHash(t){let e=this.cs.decryptWithAd(this.h,t);return this.mixHash(t),e}split(){let[t,e]=this.crypto.hkdf(this.ck,cr);return[new Hr(this.crypto,t),new Hr(this.crypto,e)]}},na=class{ss;s;e;rs;re;initiator;crypto;constructor(t){let{crypto:e,protocolName:n,prologue:s,initiator:o,s:i,e:a,rs:c,re:l}=t;this.crypto=e,this.ss=new ra(e,n),this.ss.mixHash(s),this.initiator=o,this.s=i,this.e=a,this.rs=c,this.re=l}writeE(){if(this.e)throw new Error("ephemeral keypair is already set");let t=this.crypto.generateKeypair();return this.ss.mixHash(t.publicKey),this.e=t,t.publicKey}writeS(){if(!this.s)throw new Error("static keypair is not set");return this.ss.encryptAndHash(this.s.publicKey)}writeEE(){if(!this.e)throw new Error("ephemeral keypair is not set");if(!this.re)throw new Error("remote ephemeral public key is not set");this.ss.mixKey(this.crypto.dh(this.e,this.re))}writeES(){if(this.initiator){if(!this.e)throw new Error("ephemeral keypair is not set");if(!this.rs)throw new Error("remote static public key is not set");this.ss.mixKey(this.crypto.dh(this.e,this.rs))}else{if(!this.s)throw new Error("static keypair is not set");if(!this.re)throw new Error("remote ephemeral public key is not set");this.ss.mixKey(this.crypto.dh(this.s,this.re))}}writeSE(){if(this.initiator){if(!this.s)throw new Error("static keypair is not set");if(!this.re)throw new Error("remote ephemeral public key is not set");this.ss.mixKey(this.crypto.dh(this.s,this.re))}else{if(!this.e)throw new Error("ephemeral keypair is not set");if(!this.rs)throw new Error("remote static public key is not set");this.ss.mixKey(this.crypto.dh(this.e,this.rs))}}readE(t,e=0){if(this.re)throw new Error("remote ephemeral public key is already set");if(t.byteLength<e+32)throw new Error("message is not long enough");this.re=t.sublist(e,e+32),this.ss.mixHash(this.re)}readS(t,e=0){if(this.rs)throw new Error("remote static public key is already set");let n=32+(this.ss.cs.hasKey()?16:0);if(t.byteLength<e+n)throw new Error("message is not long enough");let s=t.sublist(e,e+n);return this.rs=this.ss.decryptAndHash(s),n}readEE(){this.writeEE()}readES(){this.writeES()}readSE(){this.writeSE()}},wn=class extends na{writeMessageA(t){return new lt(this.writeE(),this.ss.encryptAndHash(t))}writeMessageB(t){let e=this.writeE();this.writeEE();let n=this.writeS();return this.writeES(),new lt(e,n,this.ss.encryptAndHash(t))}writeMessageC(t){let e=this.writeS();return this.writeSE(),new lt(e,this.ss.encryptAndHash(t))}readMessageA(t){try{return this.readE(t),this.ss.decryptAndHash(t.sublist(32))}catch(e){throw new Or(`handshake stage 0 validation fail: ${e.message}`)}}readMessageB(t){try{this.readE(t),this.readEE();let e=this.readS(t,32);return this.readES(),this.ss.decryptAndHash(t.sublist(32+e))}catch(e){throw new Or(`handshake stage 1 validation fail: ${e.message}`)}}readMessageC(t){try{let e=this.readS(t);return this.readSE(),this.ss.decryptAndHash(t.sublist(e))}catch(e){throw new Or(`handshake stage 2 validation fail: ${e.message}`)}}};function dp(r,t){if(t.length<=32){let e=mt(32);return e.set(t),e}else return r.hash(t)}var js;(function(r){let t;r.codec=()=>(t==null&&(t=tr((e,n,s={})=>{if(s.lengthDelimited!==!1&&n.fork(),e.webtransportCerthashes!=null)for(let o of e.webtransportCerthashes)n.uint32(10),n.bytes(o);s.lengthDelimited!==!1&&n.ldelim()},(e,n)=>{let s={webtransportCerthashes:[]},o=n==null?e.len:e.pos+n;for(;e.pos<o;){let i=e.uint32();switch(i>>>3){case 1:{s.webtransportCerthashes.push(e.bytes());break}default:{e.skipType(i&7);break}}}return s})),t),r.encode=e=>Qe(e,r.codec()),r.decode=e=>Xe(e,r.codec())})(js||(js={}));var bn;(function(r){let t;r.codec=()=>(t==null&&(t=tr((e,n,s={})=>{s.lengthDelimited!==!1&&n.fork(),e.identityKey!=null&&e.identityKey.byteLength>0&&(n.uint32(10),n.bytes(e.identityKey)),e.identitySig!=null&&e.identitySig.byteLength>0&&(n.uint32(18),n.bytes(e.identitySig)),e.extensions!=null&&(n.uint32(34),js.codec().encode(e.extensions,n)),s.lengthDelimited!==!1&&n.ldelim()},(e,n)=>{let s={identityKey:mt(0),identitySig:mt(0)},o=n==null?e.len:e.pos+n;for(;e.pos<o;){let i=e.uint32();switch(i>>>3){case 1:{s.identityKey=e.bytes();break}case 2:{s.identitySig=e.bytes();break}case 4:{s.extensions=js.codec().decode(e,e.uint32());break}default:{e.skipType(i&7);break}}}return s})),t),r.encode=e=>Qe(e,r.codec()),r.decode=e=>Xe(e,r.codec())})(bn||(bn={}));async function sa(r,t,e){let n=await r.sign(Ru(t));return bn.encode({identityKey:r.public.bytes,identitySig:n,extensions:e})}async function oa(r,t,e){try{let n=bn.decode(r);if(e){let i=e.subarray();if(!ft(i,n.identityKey))throw new Error(`Payload identity key ${q(n.identityKey,"hex")} does not match expected remote identity key ${q(i,"hex")}`)}if(!t)throw new Error("Remote static does not exist");let s=Ru(t);if(!await Yl(n.identityKey).verify(s,n.identitySig))throw new Error("Invalid payload signature");return n}catch(n){throw new qs(n.message)}}function Ru(r){let t=et("noise-libp2p-static-key:");return r instanceof Uint8Array?xt([t,r],t.length+r.length):(r.prepend(t),r)}async function Lu(r){let{log:t,connection:e,crypto:n,privateKey:s,prologue:o,s:i,remoteIdentityKey:a,extensions:c}=r,l=await sa(s,i.publicKey,c),u=new wn({crypto:n,protocolName:"Noise_XX_25519_ChaChaPoly_SHA256",initiator:!0,prologue:o,s:i});Ji(u.s,t),t.trace("Stage 0 - Initiator starting to send first message."),await e.write(u.writeMessageA(cr)),t.trace("Stage 0 - Initiator finished sending first message."),Qi(u.e,t),t.trace("Stage 1 - Initiator waiting to receive first message from responder...");let f=u.readMessageB(await e.read());t.trace("Stage 1 - Initiator received the message."),ta(u.re,t),Tu(u.rs,t),t.trace("Initiator going to check remote's signature...");let g=await oa(f,u.rs,a);t.trace("All good with the signature!"),t.trace("Stage 2 - Initiator sending third handshake message."),await e.write(u.writeMessageC(l)),t.trace("Stage 2 - Initiator sent message with signed payload.");let[m,d]=u.ss.split();return ea(m,d,t),{payload:g,encrypt:h=>m.encryptWithAd(cr,h),decrypt:(h,p)=>d.decryptWithAd(cr,h,p)}}async function Cu(r){let{log:t,connection:e,crypto:n,privateKey:s,prologue:o,s:i,remoteIdentityKey:a,extensions:c}=r,l=await sa(s,i.publicKey,c),u=new wn({crypto:n,protocolName:"Noise_XX_25519_ChaChaPoly_SHA256",initiator:!1,prologue:o,s:i});Ji(u.s,t),t.trace("Stage 0 - Responder waiting to receive first message."),u.readMessageA(await e.read()),t.trace("Stage 0 - Responder received first message."),ta(u.re,t),t.trace("Stage 1 - Responder sending out first message with signed payload and static key."),await e.write(u.writeMessageB(l)),t.trace("Stage 1 - Responder sent the second handshake message with signed payload."),Qi(u.e,t),t.trace("Stage 2 - Responder waiting for third handshake message...");let f=u.readMessageC(await e.read());t.trace("Stage 2 - Responder received the message, finished handshake.");let g=await oa(f,u.rs,a),[m,d]=u.ss.split();return ea(m,d,t),{payload:g,encrypt:h=>d.encryptWithAd(cr,h),decrypt:(h,p)=>m.decryptWithAd(cr,h,p)}}var Pu=16;function Du(r,t){return async function*(e){for await(let n of e)for(let s=0;s<n.length;s+=65519){let o=s+65519;o>n.length&&(o=n.length);let i;n instanceof Uint8Array?i=r.encrypt(n.subarray(s,o)):i=r.encrypt(n.sublist(s,o)),t?.encryptedPackets.increment(),yield new lt(Vr(i.byteLength),i)}}}function Vu(r,t){return async function*(e){for await(let n of e)for(let s=0;s<n.length;s+=65535){let o=s+65535;if(o>n.length&&(o=n.length),o-Pu<s)throw new Error("Invalid chunk");let i=n.sublist(s,o),a=n.subarray(s,o-Pu);try{let c=r.decrypt(i,a);t?.decryptedPackets.increment(),yield c}catch(c){throw t?.decryptErrors.increment(),c}}}}var zs=class{protocol="/noise";crypto;prologue;staticKey;extensions;metrics;components;constructor(t,e={}){let{staticNoiseKey:n,extensions:s,crypto:o,prologueBytes:i}=e,{metrics:a}=t;this.components=t;let c=o??Iu;this.crypto=_u(c),this.extensions=s,this.metrics=a?Nu(a):void 0,n?this.staticKey=c.generateX25519KeyPairFromSeed(n):this.staticKey=c.generateX25519KeyPair(),this.prologue=i??mt(0)}async secureOutbound(t,e,n){let s=Oi(e,{lengthEncoder:Vr,lengthDecoder:mn,maxDataLength:65535});if(!t.privateKey)throw new F("local peerId does not contain private key","ERR_NO_PRIVATE_KEY");let o=await Ti(t.privateKey),i=n?.publicKey,a=await this.performHandshakeInitiator(s,o,i),c=await this.createSecureConnection(s,a);return e.source=c.source,e.sink=c.sink,{conn:e,remoteExtensions:a.payload.extensions,remotePeer:await Ui(a.payload.identityKey)}}async secureInbound(t,e,n){let s=Oi(e,{lengthEncoder:Vr,lengthDecoder:mn,maxDataLength:65535});if(!t.privateKey)throw new F("local peerId does not contain private key","ERR_NO_PRIVATE_KEY");let o=await Ti(t.privateKey),i=n?.publicKey,a=await this.performHandshakeResponder(s,o,i),c=await this.createSecureConnection(s,a);return e.source=c.source,e.sink=c.sink,{conn:e,remoteExtensions:a.payload.extensions,remotePeer:await Ui(a.payload.identityKey)}}async performHandshakeInitiator(t,e,n){let s;try{s=await Lu({connection:t,privateKey:e,remoteIdentityKey:n,log:this.components.logger.forComponent("libp2p:noise:xxhandshake"),crypto:this.crypto,prologue:this.prologue,s:this.staticKey,extensions:this.extensions}),this.metrics?.xxHandshakeSuccesses.increment()}catch(o){throw this.metrics?.xxHandshakeErrors.increment(),o}return s}async performHandshakeResponder(t,e,n){let s;try{s=await Cu({connection:t,privateKey:e,remoteIdentityKey:n,log:this.components.logger.forComponent("libp2p:noise:xxhandshake"),crypto:this.crypto,prologue:this.prologue,s:this.staticKey,extensions:this.extensions}),this.metrics?.xxHandshakeSuccesses.increment()}catch(o){throw this.metrics?.xxHandshakeErrors.increment(),o}return s}async createSecureConnection(t,e){let[n,s]=au(),o=t.unwrap();return await lu(n,Du(e,this.metrics),o,i=>yn(i,{lengthDecoder:mn}),Vu(e,this.metrics),n),s}};function Ou(r={}){return t=>new zs(t,r)}var Ws=class{index=0;input="";new(t){return this.index=0,this.input=t,this}readAtomically(t){let e=this.index,n=t();return n===void 0&&(this.index=e),n}parseWith(t){let e=t();if(this.index===this.input.length)return e}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 e=this.readChar();if(e===t)return e})}readSeparator(t,e,n){return this.readAtomically(()=>{if(!(e>0&&this.readGivenChar(t)===void 0))return n()})}readNumber(t,e,n,s){return this.readAtomically(()=>{let o=0,i=0,a=this.peekChar();if(a===void 0)return;let c=a==="0",l=2**(8*s)-1;for(;;){let u=this.readAtomically(()=>{let f=this.readChar();if(f===void 0)return;let g=Number.parseInt(f,t);if(!Number.isNaN(g))return g});if(u===void 0)break;if(o*=t,o+=u,o>l||(i+=1,e!==void 0&&i>e))return}if(i!==0)return!n&&c&&i>1?void 0:o})}readIPv4Addr(){return this.readAtomically(()=>{let t=new Uint8Array(4);for(let e=0;e<t.length;e++){let n=this.readSeparator(".",e,()=>this.readNumber(10,3,!1,1));if(n===void 0)return;t[e]=n}return t})}readIPv6Addr(){let t=e=>{for(let n=0;n<e.length/2;n++){let s=n*2;if(n<e.length-3){let i=this.readSeparator(":",n,()=>this.readIPv4Addr());if(i!==void 0)return e[s]=i[0],e[s+1]=i[1],e[s+2]=i[2],e[s+3]=i[3],[s+4,!0]}let o=this.readSeparator(":",n,()=>this.readNumber(16,4,!0,2));if(o===void 0)return[s,!1];e[s]=o>>8,e[s+1]=o&255}return[e.length,!1]};return this.readAtomically(()=>{let e=new Uint8Array(16),[n,s]=t(e);if(n===16)return e;if(s||this.readGivenChar(":")===void 0||this.readGivenChar(":")===void 0)return;let o=new Uint8Array(14),i=16-(n+2),[a]=t(o.subarray(0,i));return e.set(o.subarray(0,a),16-a),e})}readIPAddr(){return this.readIPv4Addr()??this.readIPv6Addr()}};var Hu=45,pp=15,Mr=new Ws;function ia(r){if(!(r.length>pp))return Mr.new(r).parseWith(()=>Mr.readIPv4Addr())}function aa(r){if(r.includes("%")&&(r=r.split("%")[0]),!(r.length>Hu))return Mr.new(r).parseWith(()=>Mr.readIPv6Addr())}function Ys(r){if(r.includes("%")&&(r=r.split("%")[0]),!(r.length>Hu))return Mr.new(r).parseWith(()=>Mr.readIPAddr())}var Rx=parseInt("0xFFFF",16),Lx=new Uint8Array([0,0,0,0,0,0,0,0,0,0,255,255]);function Zs(r){return!!ia(r)}function Xs(r){return!!aa(r)}function Js(r){return!!Ys(r)}var Fu=Zs,bp=Xs,ca=function(r){let t=0;if(r=r.toString().trim(),Fu(r)){let e=new Uint8Array(t+4);return r.split(/\./g).forEach(n=>{e[t++]=parseInt(n,10)&255}),e}if(bp(r)){let e=r.split(":",8),n;for(n=0;n<e.length;n++){let o=Fu(e[n]),i;o&&(i=ca(e[n]),e[n]=q(i.slice(0,2),"base16")),i!=null&&++n<8&&e.splice(n,0,q(i.slice(2,4),"base16"))}if(e[0]==="")for(;e.length<8;)e.unshift("0");else if(e[e.length-1]==="")for(;e.length<8;)e.push("0");else if(e.length<8){for(n=0;n<e.length&&e[n]!=="";n++);let o=[n,1];for(n=9-e.length;n>0;n--)o.push("0");e.splice.apply(e,o)}let s=new Uint8Array(t+16);for(n=0;n<e.length;n++){let o=parseInt(e[n],16);s[t++]=o>>8&255,s[t++]=o&255}return s}throw new Error("invalid ip address")},$u=function(r,t=0,e){t=~~t,e=e??r.length-t;let n=new DataView(r.buffer);if(e===4){let s=[];for(let o=0;o<e;o++)s.push(r[t+o]);return s.join(".")}if(e===16){let s=[];for(let o=0;o<e;o+=2)s.push(n.getUint16(t+o).toString(16));return s.join(":").replace(/(^|:)0(:0)*:0(:|$)/,"$1::$3").replace(/:{3,4}/,"::")}return""};var Kr={},la={},Ep=[[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"]];Ep.forEach(r=>{let t=vp(...r);la[t.code]=t,Kr[t.name]=t});function vp(r,t,e,n,s){return{code:r,size:t,name:e,resolvable:!!n,path:!!s}}function Q(r){if(typeof r=="number"){if(la[r]!=null)return la[r];throw new Error(`no protocol with code: ${r}`)}else if(typeof r=="string"){if(Kr[r]!=null)return Kr[r];throw new Error(`no protocol with name: ${r}`)}throw new Error(`invalid protocol id type: ${typeof r}`)}var g2=Q("ip4"),y2=Q("ip6"),m2=Q("ipcidr");function fa(r,t){switch(Q(r).code){case 4:case 41:return Ap(t);case 42:return ju(t);case 6:case 273:case 33:case 132:return Wu(t).toString();case 53:case 54:case 55:case 56:case 400:case 449:case 777:return ju(t);case 421:return _p(t);case 444:return zu(t);case 445:return zu(t);case 466:return Ip(t);default:return q(t,"base16")}}function ha(r,t){switch(Q(r).code){case 4:return qu(t);case 41:return qu(t);case 42:return Gu(t);case 6:case 273:case 33:case 132:return da(parseInt(t,10));case 53:case 54:case 55:case 56:case 400:case 449:case 777:return Gu(t);case 421:return Sp(t);case 444:return Np(t);case 445:return Tp(t);case 466:return kp(t);default:return et(t,"base16")}}var ua=Object.values(re).map(r=>r.decoder),Bp=function(){let r=ua[0].or(ua[1]);return ua.slice(2).forEach(t=>r=r.or(t)),r}();function qu(r){if(!Js(r))throw new Error("invalid ip address");return ca(r)}function Ap(r){let t=$u(r,0,r.length);if(t==null)throw new Error("ipBuff is required");if(!Js(t))throw new Error("invalid ip address");return t}function da(r){let t=new ArrayBuffer(2);return new DataView(t).setUint16(0,r),new Uint8Array(t)}function Wu(r){return new DataView(r.buffer).getUint16(r.byteOffset)}function Gu(r){let t=et(r),e=Uint8Array.from(ne(t.length));return xt([e,t],e.length+t.length)}function ju(r){let t=Yt(r);if(r=r.slice(dt(t)),r.length!==t)throw new Error("inconsistent lengths");return q(r)}function Sp(r){let t;r[0]==="Q"||r[0]==="1"?t=Ne(ut.decode(`z${r}`)).bytes:t=qt.parse(r).multihash.bytes;let e=Uint8Array.from(ne(t.length));return xt([e,t],e.length+t.length)}function kp(r){let t=Bp.decode(r),e=Uint8Array.from(ne(t.length));return xt([e,t],e.length+t.length)}function Ip(r){let t=Yt(r),e=r.slice(dt(t));if(e.length!==t)throw new Error("inconsistent lengths");return"u"+q(e,"base64url")}function _p(r){let t=Yt(r),e=r.slice(dt(t));if(e.length!==t)throw new Error("inconsistent lengths");return q(e,"base58btc")}function Np(r){let t=r.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 e=he.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 s=da(n);return xt([e,s],e.length+s.length)}function Tp(r){let t=r.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 e=he.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 s=da(n);return xt([e,s],e.length+s.length)}function zu(r){let t=r.slice(0,r.length-2),e=r.slice(r.length-2),n=q(t,"base32"),s=Wu(e);return`${n}:${s}`}function Yu(r){r=pa(r);let t=[],e=[],n=null,s=r.split("/").slice(1);if(s.length===1&&s[0]==="")return{bytes:new Uint8Array,string:"/",tuples:[],stringTuples:[],path:null};for(let o=0;o<s.length;o++){let i=s[o],a=Q(i);if(a.size===0){t.push([a.code]),e.push([a.code]);continue}if(o++,o>=s.length)throw Xu("invalid address: "+r);if(a.path===!0){n=pa(s.slice(o).join("/")),t.push([a.code,ha(a.code,n)]),e.push([a.code,n]);break}let c=ha(a.code,s[o]);t.push([a.code,c]),e.push([a.code,fa(a.code,c)])}return{string:Zu(e),bytes:ya(t),tuples:t,stringTuples:e,path:n}}function ga(r){let t=[],e=[],n=null,s=0;for(;s<r.length;){let o=Yt(r,s),i=dt(o),a=Q(o),c=Rp(a,r.slice(s+i));if(c===0){t.push([o]),e.push([o]),s+=i;continue}let l=r.slice(s+i,s+i+c);if(s+=c+i,s>r.length)throw Xu("Invalid address Uint8Array: "+q(r,"base16"));t.push([o,l]);let u=fa(o,l);if(e.push([o,u]),a.path===!0){n=u;break}}return{bytes:Uint8Array.from(r),string:Zu(e),tuples:t,stringTuples:e,path:n}}function Zu(r){let t=[];return r.map(e=>{let n=Q(e[0]);return t.push(n.name),e.length>1&&e[1]!=null&&t.push(e[1]),null}),pa(t.join("/"))}function ya(r){return xt(r.map(t=>{let e=Q(t[0]),n=Uint8Array.from(ne(e.code));return t.length>1&&t[1]!=null&&(n=xt([n,t[1]])),n}))}function Rp(r,t){if(r.size>0)return r.size/8;if(r.size===0)return 0;{let e=Yt(t instanceof Uint8Array?t:Uint8Array.from(t));return e+dt(e)}}function pa(r){return"/"+r.trim().split("/").filter(t=>t).join("/")}function Xu(r){return new Error("Error parsing address: "+r)}var Lp=Symbol.for("nodejs.util.inspect.custom"),ma=Symbol.for("@multiformats/js-multiaddr/multiaddr"),Cp=[Q("dns").code,Q("dns4").code,Q("dns6").code,Q("dnsaddr").code],Qs=class r{bytes;#e;#t;#r;#n;[ma]=!0;constructor(t){t==null&&(t="");let e;if(t instanceof Uint8Array)e=ga(t);else if(typeof t=="string"){if(t.length>0&&t.charAt(0)!=="/")throw new Error(`multiaddr "${t}" must start with a "/"`);e=Yu(t)}else if(Qu(t))e=ga(t.bytes);else throw new Error("addr must be a string, Buffer, or another Multiaddr");this.bytes=e.bytes,this.#e=e.string,this.#t=e.tuples,this.#r=e.stringTuples,this.#n=e.path}toString(){return this.#e}toJSON(){return this.toString()}toOptions(){let t,e,n,s,o="",i=Q("tcp"),a=Q("udp"),c=Q("ip4"),l=Q("ip6"),u=Q("dns6"),f=Q("ip6zone");for(let[m,d]of this.stringTuples())m===f.code&&(o=`%${d??""}`),Cp.includes(m)&&(e=i.name,s=443,n=`${d??""}${o}`,t=m===u.code?6:4),(m===i.code||m===a.code)&&(e=Q(m).name,s=parseInt(d??"")),(m===c.code||m===l.code)&&(e=Q(m).name,n=`${d??""}${o}`,t=m===l.code?6:4);if(t==null||e==null||n==null||s==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:e,port:s}}protos(){return this.#t.map(([t])=>Object.assign({},Q(t)))}protoCodes(){return this.#t.map(([t])=>t)}protoNames(){return this.#t.map(([t])=>Q(t).name)}tuples(){return this.#t}stringTuples(){return this.#r}encapsulate(t){return t=new r(t),new r(this.toString()+t.toString())}decapsulate(t){let e=t.toString(),n=this.toString(),s=n.lastIndexOf(e);if(s<0)throw new Error(`Address ${this.toString()} does not contain subaddress: ${t.toString()}`);return new r(n.slice(0,s))}decapsulateCode(t){let e=this.tuples();for(let n=e.length-1;n>=0;n--)if(e[n][0]===t)return new r(ya(e.slice(0,n)));return this}getPeerId(){try{let t=[];this.stringTuples().forEach(([n,s])=>{n===Kr.p2p.code&&t.push([n,s]),n===Kr["p2p-circuit"].code&&(t=[])});let e=t.pop();if(e?.[1]!=null){let n=e[1];return n[0]==="Q"||n[0]==="1"?q(ut.decode(`z${n}`),"base58btc"):q(qt.parse(n).multihash.bytes,"base58btc")}return null}catch{return null}}getPath(){return this.#n}equals(t){return ft(this.bytes,t.bytes)}async resolve(t){let e=this.protos().find(o=>o.resolvable);if(e==null)return[this];let n=Ju.get(e.name);if(n==null)throw new F(`no available resolver for ${e.name}`,"ERR_NO_AVAILABLE_RESOLVER");return(await n(this,t)).map(o=>wa(o))}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 e=(t??this).protos();return!(e.length!==2||e[0].code!==4&&e[0].code!==41||e[1].code!==6&&e[1].code!==273)}[Lp](){return`Multiaddr(${this.#e})`}};var Ju=new Map;function Qu(r){return!!r?.[ma]}function wa(r){return new Qs(r)}var Up=r=>r.toString().split("/").slice(1),En=r=>({match:t=>t.length<1?!1:r(t[0])?t.slice(1):!1,pattern:"fn"}),X=r=>({match:t=>En(e=>e===r).match(t),pattern:r}),ro=()=>({match:r=>En(t=>typeof t=="string").match(r),pattern:"{string}"}),no=()=>({match:r=>En(t=>!isNaN(parseInt(t))).match(r),pattern:"{number}"}),It=()=>({match:r=>{if(r.length<2||r[0]!=="p2p"&&r[0]!=="ipfs")return!1;if(r[1].startsWith("Q")||r[1].startsWith("1"))try{ut.decode(`z${r[1]}`)}catch{return!1}else return!1;return r.slice(2)},pattern:"/p2p/{peerid}"}),to=()=>({match:r=>{if(r.length<2||r[0]!=="certhash")return!1;try{Io.decode(r[1])}catch{return!1}return r.slice(2)},pattern:"/certhash/{certhash}"}),Ut=r=>({match:t=>{let e=r.match(t);return e===!1?t:e},pattern:`optional(${r.pattern})`}),Ot=(...r)=>({match:t=>{let e;for(let n of r){let s=n.match(t);s!==!1&&(e==null||s.length<e.length)&&(e=s)}return e??!1},pattern:`or(${r.map(t=>t.pattern).join(", ")})`}),rt=(...r)=>({match:t=>{for(let e of r){let n=e.match(t);if(n===!1)return!1;t=n}return t},pattern:`and(${r.map(t=>t.pattern).join(", ")})`});function ht(...r){function t(s){let o=Up(s);for(let i of r){let a=i.match(o);if(a===!1)return!1;o=a}return o}function e(s){return t(s)!==!1}function n(s){let o=t(s);return o===!1?!1:o.length===0}return{matches:e,exactMatch:n}}var xa=rt(X("dns4"),ro()),Ea=rt(X("dns6"),ro()),va=rt(X("dnsaddr"),ro()),tf=rt(X("dns"),ro()),j2=ht(xa),z2=ht(Ea),W2=ht(va),Y2=ht(Ot(tf,va,xa,Ea)),ef=rt(X("ip4"),En(Zs)),rf=rt(X("ip6"),En(Xs)),nf=Ot(ef,rf),le=Ot(nf,tf,xa,Ea,va),Z2=ht(le),X2=ht(ef),J2=ht(rf),Q2=ht(nf),so=rt(le,X("tcp"),no()),vn=rt(le,X("udp"),no()),Pp=Ot(so,vn),tE=ht(so),eE=ht(vn),Ba=rt(vn,X("quic")),oo=rt(vn,X("quic-v1")),Dp=Ot(Ba,oo),rE=ht(Ba),nE=ht(oo),ba=Ot(le,so,vn,Ba,oo),sf=Ot(rt(ba,X("ws"),Ut(It()))),sE=ht(sf),of=Ot(rt(ba,X("wss"),Ut(It())),rt(ba,X("tls"),X("ws"),Ut(It()))),oE=ht(of),af=rt(Pp,X("webrtc-direct"),to(),Ut(to()),Ut(It())),iE=ht(af),cf=rt(oo,X("webtransport"),to(),to(),Ut(It())),io=ht(cf),eo=Ot(sf,of,rt(so,Ut(It())),rt(Dp,Ut(It())),rt(le,Ut(It())),af,cf,It()),aE=ht(eo),Vp=rt(eo,X("p2p-circuit"),It()),cE=ht(Vp),Op=Ot(rt(eo,X("p2p-circuit"),X("webrtc"),It()),rt(eo,X("webrtc"),Ut(It())),X("webrtc")),lE=ht(Op),Hp=Ot(rt(le,X("tcp"),no(),X("http"),Ut(It())),rt(le,X("http"),Ut(It()))),uE=ht(Hp),Mp=Ot(rt(le,X("tcp"),Ot(rt(X("443"),X("http")),rt(no(),X("https"))),Ut(It())),rt(le,X("tls"),X("http"),Ut(It())),rt(le,X("https"),Ut(It()))),fE=ht(Mp);async function Aa(r,t,e,n,s,o){let i=o.forComponent(`libp2p:webtransport:stream:${e}:${t}`),a=r.writable.getWriter(),c=r.readable.getReader();await a.ready;function l(){let d=n.findIndex(h=>h===m);d!==-1&&(n.splice(d,1),m.timeline.close=Date.now(),s?.(m))}let u=!1,f=!1;(async function(){let d=await a.closed.catch(h=>h);if(d!=null){let h=d.message;h.includes("aborted by the remote server")||h.includes("STOP_SENDING")||i.error(`WebTransport writer closed unexpectedly: streamId=${t} err=${d.message}`)}u=!0,u&&f&&l()})().catch(()=>{i.error("WebTransport failed to cleanup closed stream")}),async function(){let d=await c.closed.catch(h=>h);d!=null&&i.error(`WebTransport reader closed unexpectedly: streamId=${t} err=${d.message}`),f=!0,u&&f&&l()}().catch(()=>{i.error("WebTransport failed to cleanup closed stream")});let g=!1,m={id:t,status:"open",writeStatus:"ready",readStatus:"ready",abort(d){u||(a.abort(d).catch(h=>{i.error("could not abort stream",h)}),u=!0),f=!0,this.status="aborted",this.writeStatus="closed",this.readStatus="closed",this.timeline.reset=this.timeline.close=this.timeline.closeRead=this.timeline.closeWrite=Date.now(),l()},async close(d){this.status="closing",await Promise.all([m.closeRead(d),m.closeWrite(d)]),l(),this.status="closed",this.timeline.close=Date.now()},async closeRead(d){if(!f){this.readStatus="closing";try{await c.cancel()}catch(h){h.toString().includes("RESET_STREAM")===!0&&(u=!0)}this.timeline.closeRead=Date.now(),this.readStatus="closed",f=!0}u&&l()},async closeWrite(d){if(!u){u=!0,this.writeStatus="closing";try{await a.close()}catch(h){h.toString().includes("RESET_STREAM")===!0&&(f=!0)}this.timeline.closeWrite=Date.now(),this.writeStatus="closed"}f&&l()},direction:e,timeline:{open:Date.now()},metadata:{},source:async function*(){for(;;){let d=await c.read();if(d.done){f=!0,u&&l();return}yield new lt(d.value)}}(),sink:async function(d){if(g)throw new Error("sink already called on stream");g=!0;try{this.writeStatus="writing";for await(let h of d)if(h instanceof Uint8Array)await a.write(h);else for(let p of h)await a.write(p);this.writeStatus="done"}finally{this.timeline.closeWrite=Date.now(),this.writeStatus="closed",await m.closeWrite()}},log:i};return m}function Sa(){return{source:{[Symbol.asyncIterator](){return{async next(){return new Promise(()=>{})}}}},sink:async r=>new Promise(()=>{})}}function lf(r,t){return t.filter(n=>!!r.find(s=>ft(n,s))).length===t.length}var Kp=Object.values(re).map(r=>r.decoder).reduce((r,t)=>r.or(t));function Fp(r){return ee.decode(Kp.decode(r))}function uf(r){if(!io.matches(r))throw new F("Invalid multiaddr, was not a WebTransport address","ERR_INVALID_MULTIADDR");let t=r.stringTuples(),e=t.filter(([i,a])=>i===Q("certhash").code).map(([i,a])=>Fp(a??"")),n=t.filter(([i,a])=>i===Q("p2p").code).map(([i,a])=>Ci(a??""))[0],s=r.toOptions(),o=s.host;return s.family===6&&o?.includes(":")&&(o=`[${o}]`),{url:`https://${o}:${s.port}`,certhashes:e,remotePeer:n}}var ka=class{log;components;config;metrics;constructor(t,e={}){this.log=t.logger.forComponent("libp2p:webtransport"),this.components=t,this.config={maxInboundStreams:e.maxInboundStreams??1e3},t.metrics!=null&&(this.metrics={dialerEvents:t.metrics.registerCounterGroup("libp2p_webtransport_dialer_events_total",{label:"event",help:"Total count of WebTransport dialer events by type"})})}[Symbol.toStringTag]="@libp2p/webtransport";[Ma]=!0;async dial(t,e){e?.signal?.throwIfAborted(),this.log("dialing %s",t);let n=this.components.peerId;if(n===void 0)throw new Error("Need a local peerid");e=e??{};let{url:s,certhashes:o,remotePeer:i}=uf(t);if(i==null)throw new Error("Need a target peerid");if(o.length===0)throw new Error("Expected multiaddr to contain certhashes");let a,c,l=()=>{},u=!1,f=!1,g=!1;try{this.metrics?.dialerEvents.increment({pending:!0});let m=new WebTransport(`${s}/.well-known/libp2p-webtransport?type=noise`,{serverCertificateHashes:o.map(d=>({algorithm:"sha-256",value:d.digest}))});if(l=d=>{if(!u)try{this.metrics?.dialerEvents.increment({[d]:!0}),m.close()}catch(h){this.log.error("error closing wt session",h)}finally{c!=null&&(c.timeline.close=Date.now()),u=!0}},a=()=>{l(f?"noise_timeout":"ready_timeout")},e.signal?.addEventListener("abort",a,{once:!0}),await Promise.race([m.closed,m.ready]),f=!0,this.metrics?.dialerEvents.increment({ready:!0}),m.closed.catch(d=>{this.log.error("error on remote wt session close",d)}).finally(()=>{l("remote_close")}),!await this.authenticateWebTransport(m,n,i,o))throw new Error("Failed to authenticate webtransport");return this.metrics?.dialerEvents.increment({open:!0}),c={close:async()=>{this.log("Closing webtransport"),l("close")},abort:d=>{this.log("aborting webtransport due to passed err",d),l("abort")},remoteAddr:t,timeline:{open:Date.now()},log:this.components.logger.forComponent("libp2p:webtransport:maconn"),...Sa()},g=!0,await e.upgrader.upgradeOutbound(c,{skipEncryption:!0,muxerFactory:this.webtransportMuxer(m),skipProtection:!0})}catch(m){throw this.log.error("caught wt session err",m),l(g?"upgrade_error":f?"noise_error":"ready_error"),m}finally{a!=null&&e.signal?.removeEventListener("abort",a)}}async authenticateWebTransport(t,e,n,s){let o=await t.createBidirectionalStream(),i=o.writable.getWriter(),a=o.readable.getReader();await i.ready;let c={source:async function*(){for(;;){let f=await a.read();if(f.value!=null&&(yield f.value),f.done)break}}(),sink:async function(f){for await(let g of f)g instanceof Uint8Array?await i.write(g):await i.write(g.subarray())}},l=Ou()(this.components),{remoteExtensions:u}=await l.secureOutbound(e,c,n);if(i.close().catch(f=>{this.log.error(`Failed to close authentication stream writer: ${f.message}`)}),a.cancel().catch(f=>{this.log.error(`Failed to close authentication stream reader: ${f.message}`)}),!lf(u?.webtransportCerthashes??[],s.map(f=>f.bytes)))throw new Error("Our certhashes are not a subset of the remote's reported certhashes");return!0}webtransportMuxer(t){let e=0,n=this.config,s=this;return{protocol:"webtransport",createStreamMuxer:o=>{typeof o=="function"&&(o={onIncomingStream:o});let i=[];return async function(){let c=t.incomingBidirectionalStreams.getReader();for(;;){let{done:l,value:u}=await c.read();if(l)break;if(i.length>=n.maxInboundStreams)u.writable.close().catch(f=>{s.log.error(`Failed to close inbound stream that crossed our maxInboundStream limit: ${f.message}`)}),u.readable.cancel().catch(f=>{s.log.error(`Failed to close inbound stream that crossed our maxInboundStream limit: ${f.message}`)});else{let f=await Aa(u,String(e++),"inbound",i,o?.onStreamEnd,s.components.logger);i.push(f),o?.onIncomingStream?.(f)}}}().catch(()=>{this.log.error("WebTransport failed to receive incoming stream")}),{protocol:"webtransport",streams:i,newStream:async c=>{let l=await t.createBidirectionalStream(),u=await Aa(l,String(e++),o?.direction??"outbound",i,o?.onStreamEnd,s.components.logger);return i.push(u),u},close:async c=>{this.log("Closing webtransport muxer"),await Promise.all(i.map(async l=>l.close(c)))},abort:c=>{this.log("Aborting webtransport muxer with err:",c);for(let l of i)l.abort(c)},...Sa()}}}}createListener(t){throw new Error("Webtransport servers are not supported in Node or the browser")}filter(t){return t.filter(io.exactMatch)}};function $p(r={}){return t=>new ka(t,r)}return Af(qp);})();
6
+ `)}`:`${e} :`}};tl=He;U.Constructed=tl;He.NAME="CONSTRUCTED";var Jn=class extends Lt{fromBER(t,e,n){return e}toBER(t){return Jt}};Jn.override="EndOfContentValueBlock";var el,Qn=class extends St{constructor(t={}){super(t,Jn),this.idBlock.tagClass=1,this.idBlock.tagNumber=0}};el=Qn;U.EndOfContent=el;Qn.NAME=nn;var rl,Me=class extends St{constructor(t={}){super(t,Lt),this.idBlock.tagClass=1,this.idBlock.tagNumber=5}fromBER(t,e,n){return this.lenBlock.length>0&&this.warnings.push("Non-zero length of value block for Null type"),this.idBlock.error.length||(this.blockLength+=this.idBlock.blockLength),this.lenBlock.error.length||(this.blockLength+=this.lenBlock.blockLength),this.blockLength+=n,e+n>t.byteLength?(this.error="End of input reached before message was fully decoded (inconsistent offset and length values)",-1):e+n}toBER(t,e){let n=new ArrayBuffer(2);if(!t){let s=new Uint8Array(n);s[0]=5,s[1]=0}return e&&e.write(n),n}onAsciiEncoding(){return`${this.constructor.NAME}`}};rl=Me;U.Null=rl;Me.NAME="NULL";var ts=class extends Se(Lt){constructor({value:t,...e}={}){super(e),e.valueHex?this.valueHexView=Y.BufferSourceConverter.toUint8Array(e.valueHex):this.valueHexView=new Uint8Array(1),t&&(this.value=t)}get value(){for(let t of this.valueHexView)if(t>0)return!0;return!1}set value(t){this.valueHexView[0]=t?255:0}fromBER(t,e,n){let s=Y.BufferSourceConverter.toUint8Array(t);return Ae(this,s,e,n)?(this.valueHexView=s.subarray(e,e+n),n>1&&this.warnings.push("Boolean value encoded in more then 1 octet"),this.isHexOnly=!0,mi.call(this),this.blockLength=n,e+n):-1}toBER(){return this.valueHexView.slice()}toJSON(){return{...super.toJSON(),value:this.value}}};ts.NAME="BooleanValueBlock";var nl,es=class extends St{constructor(t={}){super(t,ts),this.idBlock.tagClass=1,this.idBlock.tagNumber=1}getValue(){return this.valueBlock.value}setValue(t){this.valueBlock.value=t}onAsciiEncoding(){return`${this.constructor.NAME} : ${this.getValue}`}};nl=es;U.Boolean=nl;es.NAME="BOOLEAN";var rs=class extends Se(ie){constructor({isConstructed:t=!1,...e}={}){super(e),this.isConstructed=t}fromBER(t,e,n){let s=0;if(this.isConstructed){if(this.isHexOnly=!1,s=ie.prototype.fromBER.call(this,t,e,n),s===-1)return s;for(let o=0;o<this.value.length;o++){let i=this.value[o].constructor.NAME;if(i===nn){if(this.isIndefiniteForm)break;return this.error="EndOfContent is unexpected, OCTET STRING may consists of OCTET STRINGs only",-1}if(i!==Zc)return this.error="OCTET STRING may consists of OCTET STRINGs only",-1}}else this.isHexOnly=!0,s=super.fromBER(t,e,n),this.blockLength=n;return s}toBER(t,e){return this.isConstructed?ie.prototype.toBER.call(this,t,e):t?new ArrayBuffer(this.valueHexView.byteLength):this.valueHexView.slice().buffer}toJSON(){return{...super.toJSON(),isConstructed:this.isConstructed}}};rs.NAME="OctetStringValueBlock";var sl,ve=class r extends St{constructor({idBlock:t={},lenBlock:e={},...n}={}){var s,o;(s=n.isConstructed)!==null&&s!==void 0||(n.isConstructed=!!(!((o=n.value)===null||o===void 0)&&o.length)),super({idBlock:{isConstructed:n.isConstructed,...t},lenBlock:{...e,isIndefiniteForm:!!n.isIndefiniteForm},...n},rs),this.idBlock.tagClass=1,this.idBlock.tagNumber=4}fromBER(t,e,n){if(this.valueBlock.isConstructed=this.idBlock.isConstructed,this.valueBlock.isIndefiniteForm=this.lenBlock.isIndefiniteForm,n===0)return this.idBlock.error.length===0&&(this.blockLength+=this.idBlock.blockLength),this.lenBlock.error.length===0&&(this.blockLength+=this.lenBlock.blockLength),e;if(!this.valueBlock.isConstructed){let o=(t instanceof ArrayBuffer?new Uint8Array(t):t).subarray(e,e+n);try{if(o.byteLength){let i=Ts(o,0,o.byteLength);i.offset!==-1&&i.offset===n&&(this.valueBlock.value=[i.result])}}catch{}}return super.fromBER(t,e,n)}onAsciiEncoding(){return this.valueBlock.isConstructed||this.valueBlock.value&&this.valueBlock.value.length?He.prototype.onAsciiEncoding.call(this):`${this.constructor.NAME} : ${Y.Convert.ToHex(this.valueBlock.valueHexView)}`}getValue(){if(!this.idBlock.isConstructed)return this.valueBlock.valueHexView.slice().buffer;let t=[];for(let e of this.valueBlock.value)e instanceof r&&t.push(e.valueBlock.valueHexView);return Y.BufferSourceConverter.concat(t)}};sl=ve;U.OctetString=sl;ve.NAME=Zc;var ns=class extends Se(ie){constructor({unusedBits:t=0,isConstructed:e=!1,...n}={}){super(n),this.unusedBits=t,this.isConstructed=e,this.blockLength=this.valueHexView.byteLength}fromBER(t,e,n){if(!n)return e;let s=-1;if(this.isConstructed){if(s=ie.prototype.fromBER.call(this,t,e,n),s===-1)return s;for(let a of this.value){let c=a.constructor.NAME;if(c===nn){if(this.isIndefiniteForm)break;return this.error="EndOfContent is unexpected, BIT STRING may consists of BIT STRINGs only",-1}if(c!==Xc)return this.error="BIT STRING may consists of BIT STRINGs only",-1;let l=a.valueBlock;if(this.unusedBits>0&&l.unusedBits>0)return this.error='Using of "unused bits" inside constructive BIT STRING allowed for least one only',-1;this.unusedBits=l.unusedBits}return s}let o=Y.BufferSourceConverter.toUint8Array(t);if(!Ae(this,o,e,n))return-1;let i=o.subarray(e,e+n);if(this.unusedBits=i[0],this.unusedBits>7)return this.error="Unused bits for BitString must be in range 0-7",-1;if(!this.unusedBits){let a=i.subarray(1);try{if(a.byteLength){let c=Ts(a,0,a.byteLength);c.offset!==-1&&c.offset===n-1&&(this.value=[c.result])}}catch{}}return this.valueHexView=i.subarray(1),this.blockLength=i.length,e+n}toBER(t,e){if(this.isConstructed)return ie.prototype.toBER.call(this,t,e);if(t)return new ArrayBuffer(this.valueHexView.byteLength+1);if(!this.valueHexView.byteLength)return Jt;let n=new Uint8Array(this.valueHexView.length+1);return n[0]=this.unusedBits,n.set(this.valueHexView,1),n.buffer}toJSON(){return{...super.toJSON(),unusedBits:this.unusedBits,isConstructed:this.isConstructed}}};ns.NAME="BitStringValueBlock";var ol,Sr=class extends St{constructor({idBlock:t={},lenBlock:e={},...n}={}){var s,o;(s=n.isConstructed)!==null&&s!==void 0||(n.isConstructed=!!(!((o=n.value)===null||o===void 0)&&o.length)),super({idBlock:{isConstructed:n.isConstructed,...t},lenBlock:{...e,isIndefiniteForm:!!n.isIndefiniteForm},...n},ns),this.idBlock.tagClass=1,this.idBlock.tagNumber=3}fromBER(t,e,n){return this.valueBlock.isConstructed=this.idBlock.isConstructed,this.valueBlock.isIndefiniteForm=this.lenBlock.isIndefiniteForm,super.fromBER(t,e,n)}onAsciiEncoding(){if(this.valueBlock.isConstructed||this.valueBlock.value&&this.valueBlock.value.length)return He.prototype.onAsciiEncoding.call(this);{let t=[],e=this.valueBlock.valueHexView;for(let s of e)t.push(s.toString(2).padStart(8,"0"));let n=t.join("");return`${this.constructor.NAME} : ${n.substring(0,n.length-this.valueBlock.unusedBits)}`}}};ol=Sr;U.BitString=ol;Sr.NAME=Xc;var il;function l0(r,t){let e=new Uint8Array([0]),n=new Uint8Array(r),s=new Uint8Array(t),o=n.slice(0),i=o.length-1,a=s.slice(0),c=a.length-1,l=0,u=c<i?i:c,f=0;for(let g=u;g>=0;g--,f++){switch(!0){case f<a.length:l=o[i-f]+a[c-f]+e[0];break;default:l=o[i-f]+e[0]}switch(e[0]=l/10,!0){case f>=o.length:o=Gn(new Uint8Array([l%10]),o);break;default:o[i-f]=l%10}}return e[0]>0&&(o=Gn(e,o)),o}function Yc(r){if(r>=en.length)for(let t=en.length;t<=r;t++){let e=new Uint8Array([0]),n=en[t-1].slice(0);for(let s=n.length-1;s>=0;s--){let o=new Uint8Array([(n[s]<<1)+e[0]]);e[0]=o[0]/10,n[s]=o[0]%10}e[0]>0&&(n=Gn(e,n)),en.push(n)}return en[r]}function u0(r,t){let e=0,n=new Uint8Array(r),s=new Uint8Array(t),o=n.slice(0),i=o.length-1,a=s.slice(0),c=a.length-1,l,u=0;for(let f=c;f>=0;f--,u++)switch(l=o[i-u]-a[c-u]-e,!0){case l<0:e=1,o[i-u]=l+10;break;default:e=0,o[i-u]=l}if(e>0)for(let f=i-c+1;f>=0;f--,u++)if(l=o[i-u]-e,l<0)e=1,o[i-u]=l+10;else{e=0,o[i-u]=l;break}return o.slice()}var sn=class extends Se(Lt){constructor({value:t,...e}={}){super(e),this._valueDec=0,e.valueHex&&this.setValueHex(),t!==void 0&&(this.valueDec=t)}setValueHex(){this.valueHexView.length>=4?(this.warnings.push("Too big Integer for decoding, hex only"),this.isHexOnly=!0,this._valueDec=0):(this.isHexOnly=!1,this.valueHexView.length>0&&(this._valueDec=mi.call(this)))}set valueDec(t){this._valueDec=t,this.isHexOnly=!1,this.valueHexView=new Uint8Array(jc(t))}get valueDec(){return this._valueDec}fromDER(t,e,n,s=0){let o=this.fromBER(t,e,n);if(o===-1)return o;let i=this.valueHexView;return i[0]===0&&i[1]&128?this.valueHexView=i.subarray(1):s!==0&&i.length<s&&(s-i.length>1&&(s=i.length+1),this.valueHexView=i.subarray(s-i.length)),o}toDER(t=!1){let e=this.valueHexView;switch(!0){case(e[0]&128)!==0:{let n=new Uint8Array(this.valueHexView.length+1);n[0]=0,n.set(e,1),this.valueHexView=n}break;case(e[0]===0&&(e[1]&128)===0):this.valueHexView=this.valueHexView.subarray(1);break}return this.toBER(t)}fromBER(t,e,n){let s=super.fromBER(t,e,n);return s===-1||this.setValueHex(),s}toBER(t){return t?new ArrayBuffer(this.valueHexView.length):this.valueHexView.slice().buffer}toJSON(){return{...super.toJSON(),valueDec:this.valueDec}}toString(){let t=this.valueHexView.length*8-1,e=new Uint8Array(this.valueHexView.length*8/3),n=0,s,o=this.valueHexView,i="",a=!1;for(let c=o.byteLength-1;c>=0;c--){s=o[c];for(let l=0;l<8;l++){if((s&1)===1)switch(n){case t:e=u0(Yc(n),e),i="-";break;default:e=l0(e,Yc(n))}n++,s>>=1}}for(let c=0;c<e.length;c++)e[c]&&(a=!0),a&&(i+=Wc.charAt(e[c]));return a===!1&&(i+=Wc.charAt(0)),i}};il=sn;sn.NAME="IntegerValueBlock";Object.defineProperty(il.prototype,"valueHex",{set:function(r){this.valueHexView=new Uint8Array(r),this.setValueHex()},get:function(){return this.valueHexView.slice().buffer}});var al,pt=class r extends St{constructor(t={}){super(t,sn),this.idBlock.tagClass=1,this.idBlock.tagNumber=2}toBigInt(){return jn(),BigInt(this.valueBlock.toString())}static fromBigInt(t){jn();let e=BigInt(t),n=new rn,s=e.toString(16).replace(/^-/,""),o=new Uint8Array(Y.Convert.FromHex(s));if(e<0){let a=new Uint8Array(o.length+(o[0]&128?1:0));a[0]|=128;let l=BigInt(`0x${Y.Convert.ToHex(a)}`)+e,u=Y.BufferSourceConverter.toUint8Array(Y.Convert.FromHex(l.toString(16)));u[0]|=128,n.write(u)}else o[0]&128&&n.write(new Uint8Array([0])),n.write(o);return new r({valueHex:n.final()})}convertToDER(){let t=new r({valueHex:this.valueBlock.valueHexView});return t.valueBlock.toDER(),t}convertFromDER(){return new r({valueHex:this.valueBlock.valueHexView[0]===0?this.valueBlock.valueHexView.subarray(1):this.valueBlock.valueHexView})}onAsciiEncoding(){return`${this.constructor.NAME} : ${this.valueBlock.toString()}`}};al=pt;U.Integer=al;pt.NAME="INTEGER";var cl,ss=class extends pt{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=10}};cl=ss;U.Enumerated=cl;ss.NAME="ENUMERATED";var on=class extends Se(Lt){constructor({valueDec:t=-1,isFirstSid:e=!1,...n}={}){super(n),this.valueDec=t,this.isFirstSid=e}fromBER(t,e,n){if(!n)return e;let s=Y.BufferSourceConverter.toUint8Array(t);if(!Ae(this,s,e,n))return-1;let o=s.subarray(e,e+n);this.valueHexView=new Uint8Array(n);for(let a=0;a<n&&(this.valueHexView[a]=o[a]&127,this.blockLength++,!!(o[a]&128));a++);let i=new Uint8Array(this.blockLength);for(let a=0;a<this.blockLength;a++)i[a]=this.valueHexView[a];return this.valueHexView=i,o[this.blockLength-1]&128?(this.error="End of input reached before message was fully decoded",-1):(this.valueHexView[0]===0&&this.warnings.push("Needlessly long format of SID encoding"),this.blockLength<=8?this.valueDec=nr(this.valueHexView,7):(this.isHexOnly=!0,this.warnings.push("Too big SID for decoding, hex only")),e+this.blockLength)}set valueBigInt(t){jn();let e=BigInt(t).toString(2);for(;e.length%7;)e="0"+e;let n=new Uint8Array(e.length/7);for(let s=0;s<n.length;s++)n[s]=parseInt(e.slice(s*7,s*7+7),2)+(s+1<n.length?128:0);this.fromBER(n.buffer,0,n.length)}toBER(t){if(this.isHexOnly){if(t)return new ArrayBuffer(this.valueHexView.byteLength);let s=this.valueHexView,o=new Uint8Array(this.blockLength);for(let i=0;i<this.blockLength-1;i++)o[i]=s[i]|128;return o[this.blockLength-1]=s[this.blockLength-1],o.buffer}let e=Oe(this.valueDec,7);if(e.byteLength===0)return this.error="Error during encoding SID value",Jt;let n=new Uint8Array(e.byteLength);if(!t){let s=new Uint8Array(e),o=e.byteLength-1;for(let i=0;i<o;i++)n[i]=s[i]|128;n[o]=s[o]}return n}toString(){let t="";if(this.isHexOnly)t=Y.Convert.ToHex(this.valueHexView);else if(this.isFirstSid){let e=this.valueDec;this.valueDec<=39?t="0.":this.valueDec<=79?(t="1.",e-=40):(t="2.",e-=80),t+=e.toString()}else t=this.valueDec.toString();return t}toJSON(){return{...super.toJSON(),valueDec:this.valueDec,isFirstSid:this.isFirstSid}}};on.NAME="sidBlock";var os=class extends Lt{constructor({value:t=kr,...e}={}){super(e),this.value=[],t&&this.fromString(t)}fromBER(t,e,n){let s=e;for(;n>0;){let o=new on;if(s=o.fromBER(t,s,n),s===-1)return this.blockLength=0,this.error=o.error,s;this.value.length===0&&(o.isFirstSid=!0),this.blockLength+=o.blockLength,n-=o.blockLength,this.value.push(o)}return s}toBER(t){let e=[];for(let n=0;n<this.value.length;n++){let s=this.value[n].toBER(t);if(s.byteLength===0)return this.error=this.value[n].error,Jt;e.push(s)}return wi(e)}fromString(t){this.value=[];let e=0,n=0,s="",o=!1;do if(n=t.indexOf(".",e),n===-1?s=t.substring(e):s=t.substring(e,n),e=n+1,o){let i=this.value[0],a=0;switch(i.valueDec){case 0:break;case 1:a=40;break;case 2:a=80;break;default:this.value=[];return}let c=parseInt(s,10);if(isNaN(c))return;i.valueDec=c+a,o=!1}else{let i=new on;if(s>Number.MAX_SAFE_INTEGER){jn();let a=BigInt(s);i.valueBigInt=a}else if(i.valueDec=parseInt(s,10),isNaN(i.valueDec))return;this.value.length||(i.isFirstSid=!0,o=!0),this.value.push(i)}while(n!==-1)}toString(){let t="",e=!1;for(let n=0;n<this.value.length;n++){e=this.value[n].isHexOnly;let s=this.value[n].toString();n!==0&&(t=`${t}.`),e?(s=`{${s}}`,this.value[n].isFirstSid?t=`2.{${s} - 80}`:t+=s):t+=s}return t}toJSON(){let t={...super.toJSON(),value:this.toString(),sidArray:[]};for(let e=0;e<this.value.length;e++)t.sidArray.push(this.value[e].toJSON());return t}};os.NAME="ObjectIdentifierValueBlock";var ll,Xt=class extends St{constructor(t={}){super(t,os),this.idBlock.tagClass=1,this.idBlock.tagNumber=6}getValue(){return this.valueBlock.toString()}setValue(t){this.valueBlock.fromString(t)}onAsciiEncoding(){return`${this.constructor.NAME} : ${this.valueBlock.toString()||"empty"}`}toJSON(){return{...super.toJSON(),value:this.getValue()}}};ll=Xt;U.ObjectIdentifier=ll;Xt.NAME="OBJECT IDENTIFIER";var an=class extends Se(Ee){constructor({valueDec:t=0,...e}={}){super(e),this.valueDec=t}fromBER(t,e,n){if(n===0)return e;let s=Y.BufferSourceConverter.toUint8Array(t);if(!Ae(this,s,e,n))return-1;let o=s.subarray(e,e+n);this.valueHexView=new Uint8Array(n);for(let a=0;a<n&&(this.valueHexView[a]=o[a]&127,this.blockLength++,!!(o[a]&128));a++);let i=new Uint8Array(this.blockLength);for(let a=0;a<this.blockLength;a++)i[a]=this.valueHexView[a];return this.valueHexView=i,o[this.blockLength-1]&128?(this.error="End of input reached before message was fully decoded",-1):(this.valueHexView[0]===0&&this.warnings.push("Needlessly long format of SID encoding"),this.blockLength<=8?this.valueDec=nr(this.valueHexView,7):(this.isHexOnly=!0,this.warnings.push("Too big SID for decoding, hex only")),e+this.blockLength)}toBER(t){if(this.isHexOnly){if(t)return new ArrayBuffer(this.valueHexView.byteLength);let s=this.valueHexView,o=new Uint8Array(this.blockLength);for(let i=0;i<this.blockLength-1;i++)o[i]=s[i]|128;return o[this.blockLength-1]=s[this.blockLength-1],o.buffer}let e=Oe(this.valueDec,7);if(e.byteLength===0)return this.error="Error during encoding SID value",Jt;let n=new Uint8Array(e.byteLength);if(!t){let s=new Uint8Array(e),o=e.byteLength-1;for(let i=0;i<o;i++)n[i]=s[i]|128;n[o]=s[o]}return n.buffer}toString(){let t="";return this.isHexOnly?t=Y.Convert.ToHex(this.valueHexView):t=this.valueDec.toString(),t}toJSON(){return{...super.toJSON(),valueDec:this.valueDec}}};an.NAME="relativeSidBlock";var is=class extends Lt{constructor({value:t=kr,...e}={}){super(e),this.value=[],t&&this.fromString(t)}fromBER(t,e,n){let s=e;for(;n>0;){let o=new an;if(s=o.fromBER(t,s,n),s===-1)return this.blockLength=0,this.error=o.error,s;this.blockLength+=o.blockLength,n-=o.blockLength,this.value.push(o)}return s}toBER(t,e){let n=[];for(let s=0;s<this.value.length;s++){let o=this.value[s].toBER(t);if(o.byteLength===0)return this.error=this.value[s].error,Jt;n.push(o)}return wi(n)}fromString(t){this.value=[];let e=0,n=0,s="";do{n=t.indexOf(".",e),n===-1?s=t.substring(e):s=t.substring(e,n),e=n+1;let o=new an;if(o.valueDec=parseInt(s,10),isNaN(o.valueDec))return!0;this.value.push(o)}while(n!==-1);return!0}toString(){let t="",e=!1;for(let n=0;n<this.value.length;n++){e=this.value[n].isHexOnly;let s=this.value[n].toString();n!==0&&(t=`${t}.`),e&&(s=`{${s}}`),t+=s}return t}toJSON(){let t={...super.toJSON(),value:this.toString(),sidArray:[]};for(let e=0;e<this.value.length;e++)t.sidArray.push(this.value[e].toJSON());return t}};is.NAME="RelativeObjectIdentifierValueBlock";var ul,as=class extends St{constructor(t={}){super(t,is),this.idBlock.tagClass=1,this.idBlock.tagNumber=13}getValue(){return this.valueBlock.toString()}setValue(t){this.valueBlock.fromString(t)}onAsciiEncoding(){return`${this.constructor.NAME} : ${this.valueBlock.toString()||"empty"}`}toJSON(){return{...super.toJSON(),value:this.getValue()}}};ul=as;U.RelativeObjectIdentifier=ul;as.NAME="RelativeObjectIdentifier";var fl,Et=class extends He{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=16}};fl=Et;U.Sequence=fl;Et.NAME="SEQUENCE";var hl,cs=class extends He{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=17}};hl=cs;U.Set=hl;cs.NAME="SET";var ls=class extends Se(Lt){constructor({...t}={}){super(t),this.isHexOnly=!0,this.value=kr}toJSON(){return{...super.toJSON(),value:this.value}}};ls.NAME="StringValueBlock";var us=class extends ls{};us.NAME="SimpleStringValueBlock";var Ut=class extends Yn{constructor({...t}={}){super(t,us)}fromBuffer(t){this.valueBlock.value=String.fromCharCode.apply(null,Y.BufferSourceConverter.toUint8Array(t))}fromString(t){let e=t.length,n=this.valueBlock.valueHexView=new Uint8Array(e);for(let s=0;s<e;s++)n[s]=t.charCodeAt(s);this.valueBlock.value=t}};Ut.NAME="SIMPLE STRING";var fs=class extends Ut{fromBuffer(t){this.valueBlock.valueHexView=Y.BufferSourceConverter.toUint8Array(t);try{this.valueBlock.value=Y.Convert.ToUtf8String(t)}catch(e){this.warnings.push(`Error during "decodeURIComponent": ${e}, using raw string`),this.valueBlock.value=Y.Convert.ToBinary(t)}}fromString(t){this.valueBlock.valueHexView=new Uint8Array(Y.Convert.FromUtf8String(t)),this.valueBlock.value=t}};fs.NAME="Utf8StringValueBlock";var dl,Be=class extends fs{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=12}};dl=Be;U.Utf8String=dl;Be.NAME="UTF8String";var hs=class extends Ut{fromBuffer(t){this.valueBlock.value=Y.Convert.ToUtf16String(t),this.valueBlock.valueHexView=Y.BufferSourceConverter.toUint8Array(t)}fromString(t){this.valueBlock.value=t,this.valueBlock.valueHexView=new Uint8Array(Y.Convert.FromUtf16String(t))}};hs.NAME="BmpStringValueBlock";var pl,ds=class extends hs{constructor({...t}={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=30}};pl=ds;U.BmpString=pl;ds.NAME="BMPString";var ps=class extends Ut{fromBuffer(t){let e=ArrayBuffer.isView(t)?t.slice().buffer:t.slice(0),n=new Uint8Array(e);for(let s=0;s<n.length;s+=4)n[s]=n[s+3],n[s+1]=n[s+2],n[s+2]=0,n[s+3]=0;this.valueBlock.value=String.fromCharCode.apply(null,new Uint32Array(e))}fromString(t){let e=t.length,n=this.valueBlock.valueHexView=new Uint8Array(e*4);for(let s=0;s<e;s++){let o=Oe(t.charCodeAt(s),8),i=new Uint8Array(o);if(i.length>4)continue;let a=4-i.length;for(let c=i.length-1;c>=0;c--)n[s*4+c+a]=i[c]}this.valueBlock.value=t}};ps.NAME="UniversalStringValueBlock";var gl,gs=class extends ps{constructor({...t}={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=28}};gl=gs;U.UniversalString=gl;gs.NAME="UniversalString";var yl,ys=class extends Ut{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=18}};yl=ys;U.NumericString=yl;ys.NAME="NumericString";var ml,ms=class extends Ut{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=19}};ml=ms;U.PrintableString=ml;ms.NAME="PrintableString";var wl,ws=class extends Ut{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=20}};wl=ws;U.TeletexString=wl;ws.NAME="TeletexString";var bl,bs=class extends Ut{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=21}};bl=bs;U.VideotexString=bl;bs.NAME="VideotexString";var xl,xs=class extends Ut{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=22}};xl=xs;U.IA5String=xl;xs.NAME="IA5String";var El,Es=class extends Ut{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=25}};El=Es;U.GraphicString=El;Es.NAME="GraphicString";var vl,cn=class extends Ut{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=26}};vl=cn;U.VisibleString=vl;cn.NAME="VisibleString";var Bl,vs=class extends Ut{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=27}};Bl=vs;U.GeneralString=Bl;vs.NAME="GeneralString";var Al,Bs=class extends Ut{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=29}};Al=Bs;U.CharacterString=Al;Bs.NAME="CharacterString";var Sl,ln=class extends cn{constructor({value:t,valueDate:e,...n}={}){if(super(n),this.year=0,this.month=0,this.day=0,this.hour=0,this.minute=0,this.second=0,t){this.fromString(t),this.valueBlock.valueHexView=new Uint8Array(t.length);for(let s=0;s<t.length;s++)this.valueBlock.valueHexView[s]=t.charCodeAt(s)}e&&(this.fromDate(e),this.valueBlock.valueHexView=new Uint8Array(this.toBuffer())),this.idBlock.tagClass=1,this.idBlock.tagNumber=23}fromBuffer(t){this.fromString(String.fromCharCode.apply(null,Y.BufferSourceConverter.toUint8Array(t)))}toBuffer(){let t=this.toString(),e=new ArrayBuffer(t.length),n=new Uint8Array(e);for(let s=0;s<t.length;s++)n[s]=t.charCodeAt(s);return e}fromDate(t){this.year=t.getUTCFullYear(),this.month=t.getUTCMonth()+1,this.day=t.getUTCDate(),this.hour=t.getUTCHours(),this.minute=t.getUTCMinutes(),this.second=t.getUTCSeconds()}toDate(){return new Date(Date.UTC(this.year,this.month-1,this.day,this.hour,this.minute,this.second))}fromString(t){let n=/(\d{2})(\d{2})(\d{2})(\d{2})(\d{2})(\d{2})Z/ig.exec(t);if(n===null){this.error="Wrong input string for conversion";return}let s=parseInt(n[1],10);s>=50?this.year=1900+s:this.year=2e3+s,this.month=parseInt(n[2],10),this.day=parseInt(n[3],10),this.hour=parseInt(n[4],10),this.minute=parseInt(n[5],10),this.second=parseInt(n[6],10)}toString(t="iso"){if(t==="iso"){let e=new Array(7);return e[0]=Pt(this.year<2e3?this.year-1900:this.year-2e3,2),e[1]=Pt(this.month,2),e[2]=Pt(this.day,2),e[3]=Pt(this.hour,2),e[4]=Pt(this.minute,2),e[5]=Pt(this.second,2),e[6]="Z",e.join("")}return super.toString(t)}onAsciiEncoding(){return`${this.constructor.NAME} : ${this.toDate().toISOString()}`}toJSON(){return{...super.toJSON(),year:this.year,month:this.month,day:this.day,hour:this.hour,minute:this.minute,second:this.second}}};Sl=ln;U.UTCTime=Sl;ln.NAME="UTCTime";var kl,As=class extends ln{constructor(t={}){var e;super(t),(e=this.millisecond)!==null&&e!==void 0||(this.millisecond=0),this.idBlock.tagClass=1,this.idBlock.tagNumber=24}fromDate(t){super.fromDate(t),this.millisecond=t.getUTCMilliseconds()}toDate(){return new Date(Date.UTC(this.year,this.month-1,this.day,this.hour,this.minute,this.second,this.millisecond))}fromString(t){let e=!1,n="",s="",o=0,i,a=0,c=0;if(t[t.length-1]==="Z")n=t.substring(0,t.length-1),e=!0;else{let f=new Number(t[t.length-1]);if(isNaN(f.valueOf()))throw new Error("Wrong input string for conversion");n=t}if(e){if(n.indexOf("+")!==-1)throw new Error("Wrong input string for conversion");if(n.indexOf("-")!==-1)throw new Error("Wrong input string for conversion")}else{let f=1,g=n.indexOf("+"),m="";if(g===-1&&(g=n.indexOf("-"),f=-1),g!==-1){if(m=n.substring(g+1),n=n.substring(0,g),m.length!==2&&m.length!==4)throw new Error("Wrong input string for conversion");let d=parseInt(m.substring(0,2),10);if(isNaN(d.valueOf()))throw new Error("Wrong input string for conversion");if(a=f*d,m.length===4){if(d=parseInt(m.substring(2,4),10),isNaN(d.valueOf()))throw new Error("Wrong input string for conversion");c=f*d}}}let l=n.indexOf(".");if(l===-1&&(l=n.indexOf(",")),l!==-1){let f=new Number(`0${n.substring(l)}`);if(isNaN(f.valueOf()))throw new Error("Wrong input string for conversion");o=f.valueOf(),s=n.substring(0,l)}else s=n;switch(!0){case s.length===8:if(i=/(\d{4})(\d{2})(\d{2})/ig,l!==-1)throw new Error("Wrong input string for conversion");break;case s.length===10:if(i=/(\d{4})(\d{2})(\d{2})(\d{2})/ig,l!==-1){let f=60*o;this.minute=Math.floor(f),f=60*(f-this.minute),this.second=Math.floor(f),f=1e3*(f-this.second),this.millisecond=Math.floor(f)}break;case s.length===12:if(i=/(\d{4})(\d{2})(\d{2})(\d{2})(\d{2})/ig,l!==-1){let f=60*o;this.second=Math.floor(f),f=1e3*(f-this.second),this.millisecond=Math.floor(f)}break;case s.length===14:if(i=/(\d{4})(\d{2})(\d{2})(\d{2})(\d{2})(\d{2})/ig,l!==-1){let f=1e3*o;this.millisecond=Math.floor(f)}break;default:throw new Error("Wrong input string for conversion")}let u=i.exec(s);if(u===null)throw new Error("Wrong input string for conversion");for(let f=1;f<u.length;f++)switch(f){case 1:this.year=parseInt(u[f],10);break;case 2:this.month=parseInt(u[f],10);break;case 3:this.day=parseInt(u[f],10);break;case 4:this.hour=parseInt(u[f],10)+a;break;case 5:this.minute=parseInt(u[f],10)+c;break;case 6:this.second=parseInt(u[f],10);break;default:throw new Error("Wrong input string for conversion")}if(e===!1){let f=new Date(this.year,this.month,this.day,this.hour,this.minute,this.second,this.millisecond);this.year=f.getUTCFullYear(),this.month=f.getUTCMonth(),this.day=f.getUTCDay(),this.hour=f.getUTCHours(),this.minute=f.getUTCMinutes(),this.second=f.getUTCSeconds(),this.millisecond=f.getUTCMilliseconds()}}toString(t="iso"){if(t==="iso"){let e=[];return e.push(Pt(this.year,4)),e.push(Pt(this.month,2)),e.push(Pt(this.day,2)),e.push(Pt(this.hour,2)),e.push(Pt(this.minute,2)),e.push(Pt(this.second,2)),this.millisecond!==0&&(e.push("."),e.push(Pt(this.millisecond,3))),e.push("Z"),e.join("")}return super.toString(t)}toJSON(){return{...super.toJSON(),millisecond:this.millisecond}}};kl=As;U.GeneralizedTime=kl;As.NAME="GeneralizedTime";var Il,Ss=class extends Be{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=31}};Il=Ss;U.DATE=Il;Ss.NAME="DATE";var _l,ks=class extends Be{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=32}};_l=ks;U.TimeOfDay=_l;ks.NAME="TimeOfDay";var Nl,Is=class extends Be{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=33}};Nl=Is;U.DateTime=Nl;Is.NAME="DateTime";var Tl,_s=class extends Be{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=34}};Tl=_s;U.Duration=Tl;_s.NAME="Duration";var Rl,Ns=class extends Be{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=14}};Rl=Ns;U.TIME=Rl;Ns.NAME="TIME";function h0(r){let{result:t}=Ir(r),e=t.valueBlock.value;return{n:q(ae(e[1].toBigInt()),"base64url"),e:q(ae(e[2].toBigInt()),"base64url"),d:q(ae(e[3].toBigInt()),"base64url"),p:q(ae(e[4].toBigInt()),"base64url"),q:q(ae(e[5].toBigInt()),"base64url"),dp:q(ae(e[6].toBigInt()),"base64url"),dq:q(ae(e[7].toBigInt()),"base64url"),qi:q(ae(e[8].toBigInt()),"base64url"),kty:"RSA",alg:"RS256"}}function d0(r){if(r.n==null||r.e==null||r.d==null||r.p==null||r.q==null||r.dp==null||r.dq==null||r.qi==null)throw new F("JWK was missing components","ERR_INVALID_PARAMETERS");let e=new Et({value:[new pt({value:0}),pt.fromBigInt(ce(et(r.n,"base64url"))),pt.fromBigInt(ce(et(r.e,"base64url"))),pt.fromBigInt(ce(et(r.d,"base64url"))),pt.fromBigInt(ce(et(r.p,"base64url"))),pt.fromBigInt(ce(et(r.q,"base64url"))),pt.fromBigInt(ce(et(r.dp,"base64url"))),pt.fromBigInt(ce(et(r.dq,"base64url"))),pt.fromBigInt(ce(et(r.qi,"base64url")))]}).toBER();return new Uint8Array(e,0,e.byteLength)}function p0(r){let{result:t}=Ir(r),e=t.valueBlock.value[1].valueBlock.value[0].valueBlock.value;return{kty:"RSA",n:q(ae(e[0].toBigInt()),"base64url"),e:q(ae(e[1].toBigInt()),"base64url")}}function g0(r){if(r.n==null||r.e==null)throw new F("JWK was missing components","ERR_INVALID_PARAMETERS");let e=new Et({value:[new Et({value:[new Xt({value:"1.2.840.113549.1.1.1"}),new Me]}),new Sr({valueHex:new Et({value:[pt.fromBigInt(ce(et(r.n,"base64url"))),pt.fromBigInt(ce(et(r.e,"base64url")))]}).toBER()})]}).toBER();return new Uint8Array(e,0,e.byteLength)}function ae(r){let t=r.toString(16);t.length%2>0&&(t=`0${t}`);let e=t.length/2,n=new Uint8Array(e),s=0,o=0;for(;s<e;)n[s]=parseInt(t.slice(o,o+2),16),s+=1,o+=2;return n}function ce(r){let t=[];return r.forEach(function(e){let n=e.toString(16);n.length%2>0&&(n=`0${n}`),t.push(n)}),BigInt("0x"+t.join(""))}var y0=16,xi=32,Ei=1e4;async function m0(r,t){let e=Ct.get(),s=new Et({value:[new pt({value:0}),new Et({value:[new Xt({value:"1.2.840.113549.1.1.1"}),new Me]}),new ve({valueHex:r.marshal()})]}).toBER(),o=new Uint8Array(s,0,s.byteLength),i=rr(y0),a=await gi(mr,t,i,{c:Ei,dkLen:xi}),c=rr(16),l=await e.subtle.importKey("raw",a,"AES-CBC",!1,["encrypt"]),u=await e.subtle.encrypt({name:"AES-CBC",iv:c},l,o),f=new Et({value:[new ve({valueHex:i}),new pt({value:Ei}),new pt({value:xi}),new Et({value:[new Xt({value:"1.2.840.113549.2.11"}),new Me]})]}),g=new Et({value:[new Xt({value:"1.2.840.113549.1.5.13"}),new Et({value:[new Et({value:[new Xt({value:"1.2.840.113549.1.5.12"}),f]}),new Et({value:[new Xt({value:"2.16.840.1.101.3.4.1.42"}),new ve({valueHex:c})]})]})]}),d=new Et({value:[g,new ve({valueHex:u})]}).toBER(),h=new Uint8Array(d,0,d.byteLength);return["-----BEGIN ENCRYPTED PRIVATE KEY-----",...q(h,"base64pad").split(/(.{64})/).filter(Boolean),"-----END ENCRYPTED PRIVATE KEY-----"].join(`
7
+ `)}async function w0(r,t){let e=Ct.get(),n;if(r.includes("-----BEGIN ENCRYPTED PRIVATE KEY-----")){let s=et(r.replace("-----BEGIN ENCRYPTED PRIVATE KEY-----","").replace("-----END ENCRYPTED PRIVATE KEY-----","").replace(/\n/g,"").trim(),"base64pad"),{result:o}=Ir(s),{iv:i,salt:a,iterations:c,keySize:l,cipherText:u}=b0(o),f=await gi(mr,t,a,{c,dkLen:l}),g=await e.subtle.importKey("raw",f,"AES-CBC",!1,["decrypt"]),m=un(await e.subtle.decrypt({name:"AES-CBC",iv:i},g,u)),{result:d}=Ir(m);n=Ll(d)}else if(r.includes("-----BEGIN PRIVATE KEY-----")){let s=et(r.replace("-----BEGIN PRIVATE KEY-----","").replace("-----END PRIVATE KEY-----","").replace(/\n/g,"").trim(),"base64pad"),{result:o}=Ir(s);n=Ll(o)}else throw new F("Could not parse private key from PEM data","ERR_INVALID_PARAMETERS");return vi(n)}function b0(r){let t=r.valueBlock.value[0];if(t.valueBlock.value[0].toString()!=="OBJECT IDENTIFIER : 1.2.840.113549.1.5.13")throw new F("Only pkcs5PBES2 encrypted private keys are supported","ERR_INVALID_PARAMS");let n=t.valueBlock.value[1].valueBlock.value[0];if(n.valueBlock.value[0].toString()!=="OBJECT IDENTIFIER : 1.2.840.113549.1.5.12")throw new F("Only pkcs5PBKDF2 key derivation functions are supported","ERR_INVALID_PARAMS");let o=n.valueBlock.value[1],i=un(o.valueBlock.value[0].getValue()),a=Ei,c=xi;if(o.valueBlock.value.length===3)a=Number(o.valueBlock.value[1].toBigInt()),c=Number(o.valueBlock.value[2].toBigInt());else if(o.valueBlock.value.length===2)throw new F("Could not derive key size and iterations from PEM file - please use @libp2p/rsa to re-import your key","ERR_INVALID_PARAMS");let l=t.valueBlock.value[1].valueBlock.value[1],u=l.valueBlock.value[0].toString();if(u!=="OBJECT IDENTIFIER : 1.2.840.113549.3.7"){if(u!=="OBJECT IDENTIFIER : 1.3.14.3.2.7"){if(u!=="OBJECT IDENTIFIER : 2.16.840.1.101.3.4.1.2"){if(u!=="OBJECT IDENTIFIER : 2.16.840.1.101.3.4.1.22"){if(u!=="OBJECT IDENTIFIER : 2.16.840.1.101.3.4.1.42")throw new F("Only AES-CBC encryption schemes are supported","ERR_INVALID_PARAMS")}}}}let f=un(l.valueBlock.value[1].getValue());return{cipherText:un(r.valueBlock.value[1].getValue()),salt:i,iterations:a,keySize:c,iv:f}}function Ll(r){return un(r.valueBlock.value[2].getValue())}function un(r){return new Uint8Array(r,0,r.byteLength)}async function Cl(r){let t=await Ct.get().subtle.generateKey({name:"RSASSA-PKCS1-v1_5",modulusLength:r,publicExponent:new Uint8Array([1,0,1]),hash:{name:"SHA-256"}},!0,["sign","verify"]),e=await Dl(t);return{privateKey:e[0],publicKey:e[1]}}async function Bi(r){let e=[await Ct.get().subtle.importKey("jwk",r,{name:"RSASSA-PKCS1-v1_5",hash:{name:"SHA-256"}},!0,["sign"]),await x0(r)],n=await Dl({privateKey:e[0],publicKey:e[1]});return{privateKey:n[0],publicKey:n[1]}}async function Ul(r,t){let e=await Ct.get().subtle.importKey("jwk",r,{name:"RSASSA-PKCS1-v1_5",hash:{name:"SHA-256"}},!1,["sign"]),n=await Ct.get().subtle.sign({name:"RSASSA-PKCS1-v1_5"},e,t instanceof Uint8Array?t:t.subarray());return new Uint8Array(n,0,n.byteLength)}async function Pl(r,t,e){let n=await Ct.get().subtle.importKey("jwk",r,{name:"RSASSA-PKCS1-v1_5",hash:{name:"SHA-256"}},!1,["verify"]);return Ct.get().subtle.verify({name:"RSASSA-PKCS1-v1_5"},n,t,e instanceof Uint8Array?e:e.subarray())}async function Dl(r){if(r.privateKey==null||r.publicKey==null)throw new F("Private and public key are required","ERR_INVALID_PARAMETERS");return Promise.all([Ct.get().subtle.exportKey("jwk",r.privateKey),Ct.get().subtle.exportKey("jwk",r.publicKey)])}async function x0(r){return Ct.get().subtle.importKey("jwk",{kty:r.kty,n:r.n,e:r.e},{name:"RSASSA-PKCS1-v1_5",hash:{name:"SHA-256"}},!0,["verify"])}function Rs(r){if(r.kty!=="RSA")throw new F("invalid key type","ERR_INVALID_KEY_TYPE");if(r.n==null)throw new F("invalid key modulus","ERR_INVALID_KEY_MODULUS");return et(r.n,"base64url").length*8}var hn=8192,fn=class{_key;constructor(t){this._key=t}verify(t,e){return Pl(this._key,e,t)}marshal(){return Ke.jwkToPkix(this._key)}get bytes(){return se.encode({Type:at.RSA,Data:this.marshal()}).subarray()}equals(t){return ft(this.bytes,t.bytes)}hash(){let t=At.digest(this.bytes);return Ht(t)?t.then(({bytes:e})=>e):t.bytes}},_r=class{_key;_publicKey;constructor(t,e){this._key=t,this._publicKey=e}genSecret(){return rr(16)}sign(t){return Ul(this._key,t)}get public(){if(this._publicKey==null)throw new F("public key not provided","ERR_PUBKEY_NOT_PROVIDED");return new fn(this._publicKey)}marshal(){return Ke.jwkToPkcs1(this._key)}get bytes(){return oe.encode({Type:at.RSA,Data:this.marshal()}).subarray()}equals(t){return ft(this.bytes,t.bytes)}hash(){let t=At.digest(this.bytes);return Ht(t)?t.then(({bytes:e})=>e):t.bytes}async id(){let t=await this.public.hash();return q(t,"base58btc")}async export(t,e="pkcs-8"){if(e==="pkcs-8")return Ke.exportToPem(this,t);if(e==="libp2p-key")return Er(this.bytes,t);throw new F(`export format '${e}' is not supported`,"ERR_INVALID_EXPORT_FORMAT")}};async function vi(r){let t=Ke.pkcs1ToJwk(r);if(Rs(t)>hn)throw new F("key size is too large","ERR_KEY_SIZE_TOO_LARGE");let e=await Bi(t);return new _r(e.privateKey,e.publicKey)}function v0(r){let t=Ke.pkixToJwk(r);if(Rs(t)>hn)throw new F("key size is too large","ERR_KEY_SIZE_TOO_LARGE");return new fn(t)}async function B0(r){if(Rs(r)>hn)throw new F("key size is too large","ERR_KEY_SIZE_TOO_LARGE");let t=await Bi(r);return new _r(t.privateKey,t.publicKey)}async function A0(r){if(r>hn)throw new F("key size is too large","ERR_KEY_SIZE_TOO_LARGE");let t=await Cl(r);return new _r(t.privateKey,t.publicKey)}var Ni={};yt(Ni,{Secp256k1PrivateKey:()=>pn,Secp256k1PublicKey:()=>dn,generateKeyPair:()=>V0,unmarshalSecp256k1PrivateKey:()=>P0,unmarshalSecp256k1PublicKey:()=>D0});var S0=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]),Fe=new Uint32Array([1779033703,3144134277,1013904242,2773480762,1359893119,2600822924,528734635,1541459225]),$e=new Uint32Array(64),Si=class extends yr{constructor(){super(64,32,8,!1),this.A=Fe[0]|0,this.B=Fe[1]|0,this.C=Fe[2]|0,this.D=Fe[3]|0,this.E=Fe[4]|0,this.F=Fe[5]|0,this.G=Fe[6]|0,this.H=Fe[7]|0}get(){let{A:t,B:e,C:n,D:s,E:o,F:i,G:a,H:c}=this;return[t,e,n,s,o,i,a,c]}set(t,e,n,s,o,i,a,c){this.A=t|0,this.B=e|0,this.C=n|0,this.D=s|0,this.E=o|0,this.F=i|0,this.G=a|0,this.H=c|0}process(t,e){for(let f=0;f<16;f++,e+=4)$e[f]=t.getUint32(e,!1);for(let f=16;f<64;f++){let g=$e[f-15],m=$e[f-2],d=Gt(g,7)^Gt(g,18)^g>>>3,h=Gt(m,17)^Gt(m,19)^m>>>10;$e[f]=h+$e[f-7]+d+$e[f-16]|0}let{A:n,B:s,C:o,D:i,E:a,F:c,G:l,H:u}=this;for(let f=0;f<64;f++){let g=Gt(a,6)^Gt(a,11)^Gt(a,25),m=u+g+uc(a,c,l)+S0[f]+$e[f]|0,h=(Gt(n,2)^Gt(n,13)^Gt(n,22))+fc(n,s,o)|0;u=l,l=c,c=a,a=i+m|0,i=o,o=s,s=n,n=m+h|0}n=n+this.A|0,s=s+this.B|0,o=o+this.C|0,i=i+this.D|0,a=a+this.E|0,c=c+this.F|0,l=l+this.G|0,u=u+this.H|0,this.set(n,s,o,i,a,c,l,u)}roundClean(){$e.fill(0)}destroy(){this.set(0,0,0,0,0,0,0,0),this.buffer.fill(0)}};var Nr=_n(()=>new Si);function k0(r){let t=zr(r);Mt(t,{a:"field",b:"field"},{allowedPrivateKeyLengths:"array",wrapPrivateKey:"boolean",isTorsionFree:"function",clearCofactor:"function",allowInfinityPoint:"boolean",fromBytes:"function",toBytes:"function"});let{endo:e,Fp:n,a:s}=t;if(e){if(!n.eql(s,n.ZERO))throw new Error("Endomorphism can only be defined for Koblitz curves that have a=0");if(typeof e!="object"||typeof e.beta!="bigint"||typeof e.splitScalar!="function")throw new Error("Expected endomorphism with beta: bigint and splitScalar: function")}return Object.freeze({...t})}var{bytesToNumberBE:I0,hexToBytes:_0}=Rn,sr={Err:class extends Error{constructor(t=""){super(t)}},_parseInt(r){let{Err:t}=sr;if(r.length<2||r[0]!==2)throw new t("Invalid signature integer tag");let e=r[1],n=r.subarray(2,e+2);if(!e||n.length!==e)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:I0(n),l:r.subarray(e+2)}},toSig(r){let{Err:t}=sr,e=typeof r=="string"?_0(r):r;wr(e);let n=e.length;if(n<2||e[0]!=48)throw new t("Invalid signature tag");if(e[1]!==n-2)throw new t("Invalid signature: incorrect length");let{d:s,l:o}=sr._parseInt(e.subarray(2)),{d:i,l:a}=sr._parseInt(o);if(a.length)throw new t("Invalid signature: left bytes after parsing");return{r:s,s:i}},hexFromSig(r){let t=l=>Number.parseInt(l[0],16)&8?"00"+l:l,e=l=>{let u=l.toString(16);return u.length&1?`0${u}`:u},n=t(e(r.s)),s=t(e(r.r)),o=n.length/2,i=s.length/2,a=e(o),c=e(i);return`30${e(i+o+4)}02${c}${s}02${a}${n}`}},ke=BigInt(0),Ft=BigInt(1),mw=BigInt(2),Vl=BigInt(3),ww=BigInt(4);function N0(r){let t=k0(r),{Fp:e}=t,n=t.toBytes||((d,h,p)=>{let b=h.toAffine();return me(Uint8Array.from([4]),e.toBytes(b.x),e.toBytes(b.y))}),s=t.fromBytes||(d=>{let h=d.subarray(1),p=e.fromBytes(h.subarray(0,e.BYTES)),b=e.fromBytes(h.subarray(e.BYTES,2*e.BYTES));return{x:p,y:b}});function o(d){let{a:h,b:p}=t,b=e.sqr(d),v=e.mul(b,d);return e.add(e.add(v,e.mul(d,h)),p)}if(!e.eql(e.sqr(t.Gy),o(t.Gx)))throw new Error("bad generator point: equation left != right");function i(d){return typeof d=="bigint"&&ke<d&&d<t.n}function a(d){if(!i(d))throw new Error("Expected valid bigint: 0 < bigint < curve.n")}function c(d){let{allowedPrivateKeyLengths:h,nByteLength:p,wrapPrivateKey:b,n:v}=t;if(h&&typeof d!="bigint"){if(Ue(d)&&(d=pe(d)),typeof d!="string"||!h.includes(d.length))throw new Error("Invalid key");d=d.padStart(p*2,"0")}let w;try{w=typeof d=="bigint"?d:ge(st("private key",d,p))}catch{throw new Error(`private key must be ${p} bytes, hex or bigint, not ${typeof d}`)}return b&&(w=Z(w,v)),a(w),w}let l=new Map;function u(d){if(!(d instanceof f))throw new Error("ProjectivePoint expected")}class f{constructor(h,p,b){if(this.px=h,this.py=p,this.pz=b,h==null||!e.isValid(h))throw new Error("x required");if(p==null||!e.isValid(p))throw new Error("y required");if(b==null||!e.isValid(b))throw new Error("z required")}static fromAffine(h){let{x:p,y:b}=h||{};if(!h||!e.isValid(p)||!e.isValid(b))throw new Error("invalid affine point");if(h instanceof f)throw new Error("projective point not allowed");let v=w=>e.eql(w,e.ZERO);return v(p)&&v(b)?f.ZERO:new f(p,b,e.ONE)}get x(){return this.toAffine().x}get y(){return this.toAffine().y}static normalizeZ(h){let p=e.invertBatch(h.map(b=>b.pz));return h.map((b,v)=>b.toAffine(p[v])).map(f.fromAffine)}static fromHex(h){let p=f.fromAffine(s(st("pointHex",h)));return p.assertValidity(),p}static fromPrivateKey(h){return f.BASE.multiply(c(h))}_setWindowSize(h){this._WINDOW_SIZE=h,l.delete(this)}assertValidity(){if(this.is0()){if(t.allowInfinityPoint&&!e.is0(this.py))return;throw new Error("bad point: ZERO")}let{x:h,y:p}=this.toAffine();if(!e.isValid(h)||!e.isValid(p))throw new Error("bad point: x or y not FE");let b=e.sqr(p),v=o(h);if(!e.eql(b,v))throw new Error("bad point: equation left != right");if(!this.isTorsionFree())throw new Error("bad point: not in prime-order subgroup")}hasEvenY(){let{y:h}=this.toAffine();if(e.isOdd)return!e.isOdd(h);throw new Error("Field doesn't support isOdd")}equals(h){u(h);let{px:p,py:b,pz:v}=this,{px:w,py:A,pz:B}=h,S=e.eql(e.mul(p,B),e.mul(w,v)),N=e.eql(e.mul(b,B),e.mul(A,v));return S&&N}negate(){return new f(this.px,e.neg(this.py),this.pz)}double(){let{a:h,b:p}=t,b=e.mul(p,Vl),{px:v,py:w,pz:A}=this,B=e.ZERO,S=e.ZERO,N=e.ZERO,_=e.mul(v,v),V=e.mul(w,w),P=e.mul(A,A),R=e.mul(v,w);return R=e.add(R,R),N=e.mul(v,A),N=e.add(N,N),B=e.mul(h,N),S=e.mul(b,P),S=e.add(B,S),B=e.sub(V,S),S=e.add(V,S),S=e.mul(B,S),B=e.mul(R,B),N=e.mul(b,N),P=e.mul(h,P),R=e.sub(_,P),R=e.mul(h,R),R=e.add(R,N),N=e.add(_,_),_=e.add(N,_),_=e.add(_,P),_=e.mul(_,R),S=e.add(S,_),P=e.mul(w,A),P=e.add(P,P),_=e.mul(P,R),B=e.sub(B,_),N=e.mul(P,V),N=e.add(N,N),N=e.add(N,N),new f(B,S,N)}add(h){u(h);let{px:p,py:b,pz:v}=this,{px:w,py:A,pz:B}=h,S=e.ZERO,N=e.ZERO,_=e.ZERO,V=t.a,P=e.mul(t.b,Vl),R=e.mul(p,w),H=e.mul(b,A),O=e.mul(v,B),W=e.add(p,b),x=e.add(w,A);W=e.mul(W,x),x=e.add(R,H),W=e.sub(W,x),x=e.add(p,v);let I=e.add(w,B);return x=e.mul(x,I),I=e.add(R,O),x=e.sub(x,I),I=e.add(b,v),S=e.add(A,B),I=e.mul(I,S),S=e.add(H,O),I=e.sub(I,S),_=e.mul(V,x),S=e.mul(P,O),_=e.add(S,_),S=e.sub(H,_),_=e.add(H,_),N=e.mul(S,_),H=e.add(R,R),H=e.add(H,R),O=e.mul(V,O),x=e.mul(P,x),H=e.add(H,O),O=e.sub(R,O),O=e.mul(V,O),x=e.add(x,O),R=e.mul(H,x),N=e.add(N,R),R=e.mul(I,x),S=e.mul(W,S),S=e.sub(S,R),R=e.mul(W,H),_=e.mul(I,_),_=e.add(_,R),new f(S,N,_)}subtract(h){return this.add(h.negate())}is0(){return this.equals(f.ZERO)}wNAF(h){return m.wNAFCached(this,l,h,p=>{let b=e.invertBatch(p.map(v=>v.pz));return p.map((v,w)=>v.toAffine(b[w])).map(f.fromAffine)})}multiplyUnsafe(h){let p=f.ZERO;if(h===ke)return p;if(a(h),h===Ft)return this;let{endo:b}=t;if(!b)return m.unsafeLadder(this,h);let{k1neg:v,k1:w,k2neg:A,k2:B}=b.splitScalar(h),S=p,N=p,_=this;for(;w>ke||B>ke;)w&Ft&&(S=S.add(_)),B&Ft&&(N=N.add(_)),_=_.double(),w>>=Ft,B>>=Ft;return v&&(S=S.negate()),A&&(N=N.negate()),N=new f(e.mul(N.px,b.beta),N.py,N.pz),S.add(N)}multiply(h){a(h);let p=h,b,v,{endo:w}=t;if(w){let{k1neg:A,k1:B,k2neg:S,k2:N}=w.splitScalar(p),{p:_,f:V}=this.wNAF(B),{p:P,f:R}=this.wNAF(N);_=m.constTimeNegate(A,_),P=m.constTimeNegate(S,P),P=new f(e.mul(P.px,w.beta),P.py,P.pz),b=_.add(P),v=V.add(R)}else{let{p:A,f:B}=this.wNAF(p);b=A,v=B}return f.normalizeZ([b,v])[0]}multiplyAndAddUnsafe(h,p,b){let v=f.BASE,w=(B,S)=>S===ke||S===Ft||!B.equals(v)?B.multiplyUnsafe(S):B.multiply(S),A=w(this,p).add(w(h,b));return A.is0()?void 0:A}toAffine(h){let{px:p,py:b,pz:v}=this,w=this.is0();h==null&&(h=w?e.ONE:e.inv(v));let A=e.mul(p,h),B=e.mul(b,h),S=e.mul(v,h);if(w)return{x:e.ZERO,y:e.ZERO};if(!e.eql(S,e.ONE))throw new Error("invZ was invalid");return{x:A,y:B}}isTorsionFree(){let{h,isTorsionFree:p}=t;if(h===Ft)return!0;if(p)return p(f,this);throw new Error("isTorsionFree() has not been declared for the elliptic curve")}clearCofactor(){let{h,clearCofactor:p}=t;return h===Ft?this:p?p(f,this):this.multiplyUnsafe(t.h)}toRawBytes(h=!0){return this.assertValidity(),n(f,this,h)}toHex(h=!0){return pe(this.toRawBytes(h))}}f.BASE=new f(t.Gx,t.Gy,e.ONE),f.ZERO=new f(e.ZERO,e.ONE,e.ZERO);let g=t.nBitLength,m=Un(f,t.endo?Math.ceil(g/2):g);return{CURVE:t,ProjectivePoint:f,normPrivateKeyToScalar:c,weierstrassEquation:o,isWithinCurveOrder:i}}function T0(r){let t=zr(r);return Mt(t,{hash:"hash",hmac:"function",randomBytes:"function"},{bits2int:"function",bits2int_modN:"function",lowS:"boolean"}),Object.freeze({lowS:!0,...t})}function Ol(r){let t=T0(r),{Fp:e,n}=t,s=e.BYTES+1,o=2*e.BYTES+1;function i(x){return ke<x&&x<e.ORDER}function a(x){return Z(x,n)}function c(x){return Ln(x,n)}let{ProjectivePoint:l,normPrivateKeyToScalar:u,weierstrassEquation:f,isWithinCurveOrder:g}=N0({...t,toBytes(x,I,C){let E=I.toAffine(),y=e.toBytes(E.x),k=me;return C?k(Uint8Array.from([I.hasEvenY()?2:3]),y):k(Uint8Array.from([4]),y,e.toBytes(E.y))},fromBytes(x){let I=x.length,C=x[0],E=x.subarray(1);if(I===s&&(C===2||C===3)){let y=ge(E);if(!i(y))throw new Error("Point is not on curve");let k=f(y),T;try{T=e.sqrt(k)}catch(K){let j=K instanceof Error?": "+K.message:"";throw new Error("Point is not on curve"+j)}let L=(T&Ft)===Ft;return(C&1)===1!==L&&(T=e.neg(T)),{x:y,y:T}}else if(I===o&&C===4){let y=e.fromBytes(E.subarray(0,e.BYTES)),k=e.fromBytes(E.subarray(e.BYTES,2*e.BYTES));return{x:y,y:k}}else throw new Error(`Point of length ${I} was invalid. Expected ${s} compressed bytes or ${o} uncompressed bytes`)}}),m=x=>pe(Pe(x,t.nByteLength));function d(x){let I=n>>Ft;return x>I}function h(x){return d(x)?a(-x):x}let p=(x,I,C)=>ge(x.slice(I,C));class b{constructor(I,C,E){this.r=I,this.s=C,this.recovery=E,this.assertValidity()}static fromCompact(I){let C=t.nByteLength;return I=st("compactSignature",I,C*2),new b(p(I,0,C),p(I,C,2*C))}static fromDER(I){let{r:C,s:E}=sr.toSig(st("DER",I));return new b(C,E)}assertValidity(){if(!g(this.r))throw new Error("r must be 0 < r < CURVE.n");if(!g(this.s))throw new Error("s must be 0 < s < CURVE.n")}addRecoveryBit(I){return new b(this.r,this.s,I)}recoverPublicKey(I){let{r:C,s:E,recovery:y}=this,k=N(st("msgHash",I));if(y==null||![0,1,2,3].includes(y))throw new Error("recovery id invalid");let T=y===2||y===3?C+t.n:C;if(T>=e.ORDER)throw new Error("recovery id 2 or 3 invalid");let L=y&1?"03":"02",M=l.fromHex(L+m(T)),K=c(T),j=a(-k*K),$=a(E*K),G=l.BASE.multiplyAndAddUnsafe(M,j,$);if(!G)throw new Error("point at infinify");return G.assertValidity(),G}hasHighS(){return d(this.s)}normalizeS(){return this.hasHighS()?new b(this.r,a(-this.s),this.recovery):this}toDERRawBytes(){return We(this.toDERHex())}toDERHex(){return sr.hexFromSig({r:this.r,s:this.s})}toCompactRawBytes(){return We(this.toCompactHex())}toCompactHex(){return m(this.r)+m(this.s)}}let v={isValidPrivateKey(x){try{return u(x),!0}catch{return!1}},normPrivateKeyToScalar:u,randomPrivateKey:()=>{let x=$o(t.n);return vc(t.randomBytes(x),t.n)},precompute(x=8,I=l.BASE){return I._setWindowSize(x),I.multiply(BigInt(3)),I}};function w(x,I=!0){return l.fromPrivateKey(x).toRawBytes(I)}function A(x){let I=Ue(x),C=typeof x=="string",E=(I||C)&&x.length;return I?E===s||E===o:C?E===2*s||E===2*o:x instanceof l}function B(x,I,C=!0){if(A(x))throw new Error("first arg must be private key");if(!A(I))throw new Error("second arg must be public key");return l.fromHex(I).multiply(u(x)).toRawBytes(C)}let S=t.bits2int||function(x){let I=ge(x),C=x.length*8-t.nBitLength;return C>0?I>>BigInt(C):I},N=t.bits2int_modN||function(x){return a(S(x))},_=jr(t.nBitLength);function V(x){if(typeof x!="bigint")throw new Error("bigint expected");if(!(ke<=x&&x<_))throw new Error(`bigint expected < 2^${t.nBitLength}`);return Pe(x,t.nByteLength)}function P(x,I,C=R){if(["recovered","canonical"].some(tt=>tt in C))throw new Error("sign() legacy options not supported");let{hash:E,randomBytes:y}=t,{lowS:k,prehash:T,extraEntropy:L}=C;k==null&&(k=!0),x=st("msgHash",x),T&&(x=st("prehashed msgHash",E(x)));let M=N(x),K=u(I),j=[V(K),V(M)];if(L!=null&&L!==!1){let tt=L===!0?y(e.BYTES):L;j.push(st("extraEntropy",tt))}let $=me(...j),G=M;function nt(tt){let vt=S(tt);if(!g(vt))return;let Bt=c(vt),gt=l.BASE.multiply(vt).toAffine(),Nt=a(gt.x);if(Nt===ke)return;let ue=a(Bt*a(G+Nt*K));if(ue===ke)return;let qe=(gt.x===Nt?0:2)|Number(gt.y&Ft),Fr=ue;return k&&d(ue)&&(Fr=h(ue),qe^=1),new b(Nt,Fr,qe)}return{seed:$,k2sig:nt}}let R={lowS:t.lowS,prehash:!1},H={lowS:t.lowS,prehash:!1};function O(x,I,C=R){let{seed:E,k2sig:y}=P(x,I,C),k=t;return Oo(k.hash.outputLen,k.nByteLength,k.hmac)(E,y)}l.BASE._setWindowSize(8);function W(x,I,C,E=H){let y=x;if(I=st("msgHash",I),C=st("publicKey",C),"strict"in E)throw new Error("options.strict was renamed to lowS");let{lowS:k,prehash:T}=E,L,M;try{if(typeof y=="string"||Ue(y))try{L=b.fromDER(y)}catch(gt){if(!(gt instanceof sr.Err))throw gt;L=b.fromCompact(y)}else if(typeof y=="object"&&typeof y.r=="bigint"&&typeof y.s=="bigint"){let{r:gt,s:Nt}=y;L=new b(gt,Nt)}else throw new Error("PARSE");M=l.fromHex(C)}catch(gt){if(gt.message==="PARSE")throw new Error("signature must be Signature instance, Uint8Array or hex string");return!1}if(k&&L.hasHighS())return!1;T&&(I=t.hash(I));let{r:K,s:j}=L,$=N(I),G=c(j),nt=a($*G),tt=a(K*G),vt=l.BASE.multiplyAndAddUnsafe(M,nt,tt)?.toAffine();return vt?a(vt.x)===K:!1}return{CURVE:t,getPublicKey:w,getSharedSecret:B,sign:O,verify:W,ProjectivePoint:l,Signature:b,utils:v}}function R0(r){return{hash:r,hmac:(t,...e)=>Ve(r,t,In(...e)),randomBytes:ze}}function Hl(r,t){let e=n=>Ol({...r,...R0(n)});return Object.freeze({...e(t),create:e})}var Fl=BigInt("0xfffffffffffffffffffffffffffffffffffffffffffffffffffffffefffffc2f"),Ml=BigInt("0xfffffffffffffffffffffffffffffffebaaedce6af48a03bbfd25e8cd0364141"),L0=BigInt(1),ki=BigInt(2),Kl=(r,t)=>(r+t/ki)/t;function C0(r){let t=Fl,e=BigInt(3),n=BigInt(6),s=BigInt(11),o=BigInt(22),i=BigInt(23),a=BigInt(44),c=BigInt(88),l=r*r*r%t,u=l*l*r%t,f=ot(u,e,t)*u%t,g=ot(f,e,t)*u%t,m=ot(g,ki,t)*l%t,d=ot(m,s,t)*m%t,h=ot(d,o,t)*d%t,p=ot(h,a,t)*h%t,b=ot(p,c,t)*p%t,v=ot(b,a,t)*h%t,w=ot(v,e,t)*u%t,A=ot(w,i,t)*d%t,B=ot(A,n,t)*l%t,S=ot(B,ki,t);if(!Ii.eql(Ii.sqr(S),r))throw new Error("Cannot find square root");return S}var Ii=Cn(Fl,void 0,void 0,{sqrt:C0}),Qt=Hl({a:BigInt(0),b:BigInt(7),Fp:Ii,n:Ml,Gx:BigInt("55066263022277343669578718895168534326250603453777594175500187360389116729240"),Gy:BigInt("32670510020758816978083085130507043184471273380659243275938904335757337482424"),h:BigInt(1),lowS:!0,endo:{beta:BigInt("0x7ae96a2b657c07106e64479eac3434e99cf0497512f58995c1396c28719501ee"),splitScalar:r=>{let t=Ml,e=BigInt("0x3086d221a7d46bcde86c90e49284eb15"),n=-L0*BigInt("0xe4437ed6010e88286f547fa90abfe4c3"),s=BigInt("0x114ca50f7a8e2f3f657c1108d9d44cfd8"),o=e,i=BigInt("0x100000000000000000000000000000000"),a=Kl(o*r,t),c=Kl(-n*r,t),l=Z(r-a*e-c*s,t),u=Z(-a*n-c*o,t),f=l>i,g=u>i;if(f&&(l=t-l),g&&(u=t-u),l>i||u>i)throw new Error("splitScalar: Endomorphism failed, k="+r);return{k1neg:f,k1:l,k2neg:g,k2:u}}}},Nr),Iw=BigInt(0);var _w=Qt.ProjectivePoint;function $l(){return Qt.utils.randomPrivateKey()}function ql(r,t){let e=At.digest(t instanceof Uint8Array?t:t.subarray());if(Ht(e))return e.then(({digest:n})=>Qt.sign(n,r).toDERRawBytes()).catch(n=>{throw new F(String(n),"ERR_INVALID_INPUT")});try{return Qt.sign(e.digest,r).toDERRawBytes()}catch(n){throw new F(String(n),"ERR_INVALID_INPUT")}}function Gl(r,t,e){let n=At.digest(e instanceof Uint8Array?e:e.subarray());if(Ht(n))return n.then(({digest:s})=>Qt.verify(t,s,r)).catch(s=>{throw new F(String(s),"ERR_INVALID_INPUT")});try{return Qt.verify(t,n.digest,r)}catch(s){throw new F(String(s),"ERR_INVALID_INPUT")}}function jl(r){return Qt.ProjectivePoint.fromHex(r).toRawBytes(!0)}function zl(r){try{Qt.getPublicKey(r,!0)}catch(t){throw new F(String(t),"ERR_INVALID_PRIVATE_KEY")}}function _i(r){try{Qt.ProjectivePoint.fromHex(r)}catch(t){throw new F(String(t),"ERR_INVALID_PUBLIC_KEY")}}function Wl(r){try{return Qt.getPublicKey(r,!0)}catch(t){throw new F(String(t),"ERR_INVALID_PRIVATE_KEY")}}var dn=class{_key;constructor(t){_i(t),this._key=t}verify(t,e){return Gl(this._key,e,t)}marshal(){return jl(this._key)}get bytes(){return se.encode({Type:at.Secp256k1,Data:this.marshal()}).subarray()}equals(t){return ft(this.bytes,t.bytes)}async hash(){let t=At.digest(this.bytes),e;return Ht(t)?{bytes:e}=await t:e=t.bytes,e}},pn=class{_key;_publicKey;constructor(t,e){this._key=t,this._publicKey=e??Wl(t),zl(this._key),_i(this._publicKey)}sign(t){return ql(this._key,t)}get public(){return new dn(this._publicKey)}marshal(){return this._key}get bytes(){return oe.encode({Type:at.Secp256k1,Data:this.marshal()}).subarray()}equals(t){return ft(this.bytes,t.bytes)}hash(){let t=At.digest(this.bytes);return Ht(t)?t.then(({bytes:e})=>e):t.bytes}async id(){let t=await this.public.hash();return q(t,"base58btc")}async export(t,e="libp2p-key"){if(e==="libp2p-key")return Er(this.bytes,t);throw new F(`export format '${e}' is not supported`,"ERR_INVALID_EXPORT_FORMAT")}};function P0(r){return new pn(r)}function D0(r){return new dn(r)}async function V0(){let r=$l();return new pn(r)}var or={rsa:Ai,ed25519:pi,secp256k1:Ni};function Yl(r){let t=Object.keys(or).join(" / ");return new F(`invalid or unsupported key type ${r}. Must be ${t}`,"ERR_UNSUPPORTED_KEY_TYPE")}function Zl(r){let t=se.decode(r),e=t.Data??new Uint8Array;switch(t.Type){case at.RSA:return or.rsa.unmarshalRsaPublicKey(e);case at.Ed25519:return or.ed25519.unmarshalEd25519PublicKey(e);case at.Secp256k1:return or.secp256k1.unmarshalSecp256k1PublicKey(e);default:throw Yl(t.Type??"unknown")}}async function Ti(r){let t=oe.decode(r),e=t.Data??new Uint8Array;switch(t.Type){case at.RSA:return or.rsa.unmarshalRsaPrivateKey(e);case at.Ed25519:return or.ed25519.unmarshalEd25519PrivateKey(e);case at.Secp256k1:return or.secp256k1.unmarshalSecp256k1PrivateKey(e);default:throw Yl(t.Type??"RSA")}}var O0=Symbol.for("nodejs.util.inspect.custom"),Xl=Object.values(re).map(r=>r.decoder).reduce((r,t)=>r.or(t),re.identity.decoder),Jl=114,Ri=36,Li=37,gn=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()})`}[Ha]=!0;toString(){return this.string==null&&(this.string=ut.encode(this.multihash.bytes).slice(1)),this.string}toCID(){return qt.createV1(Jl,this.multihash)}toBytes(){return this.multihash.bytes}toJSON(){return this.toString()}equals(t){if(t==null)return!1;if(t instanceof Uint8Array)return ft(this.multihash.bytes,t);if(typeof t=="string")return Ci(t).equals(this);if(t?.multihash?.bytes!=null)return ft(this.multihash.bytes,t.multihash.bytes);throw new Error("not valid Id")}[O0](){return`PeerId(${this.toString()})`}},Tr=class extends gn{type="RSA";publicKey;constructor(t){super({...t,type:"RSA"}),this.publicKey=t.publicKey}},Rr=class extends gn{type="Ed25519";publicKey;constructor(t){super({...t,type:"Ed25519"}),this.publicKey=t.multihash.digest}},Lr=class extends gn{type="secp256k1";publicKey;constructor(t){super({...t,type:"secp256k1"}),this.publicKey=t.multihash.digest}};function Ci(r,t){if(t=t??Xl,r.charAt(0)==="1"||r.charAt(0)==="Q"){let e=Ne(ut.decode(`z${r}`));return r.startsWith("12D")?new Rr({multihash:e}):r.startsWith("16U")?new Lr({multihash:e}):new Tr({multihash:e})}return H0(Xl.decode(r))}function H0(r){try{let t=Ne(r);if(t.code===Te.code){if(t.digest.length===Ri)return new Rr({multihash:t});if(t.digest.length===Li)return new Lr({multihash:t})}if(t.code===At.code)return new Tr({multihash:t})}catch{return M0(qt.decode(r))}throw new Error("Supplied PeerID CID is invalid")}function M0(r){if(r==null||r.multihash==null||r.version==null||r.version===1&&r.code!==Jl)throw new Error("Supplied PeerID CID is invalid");let t=r.multihash;if(t.code===At.code)return new Tr({multihash:r.multihash});if(t.code===Te.code){if(t.digest.length===Ri)return new Rr({multihash:r.multihash});if(t.digest.length===Li)return new Lr({multihash:r.multihash})}throw new Error("Supplied PeerID CID is invalid")}async function Ui(r,t){return r.length===Ri?new Rr({multihash:$t(Te.code,r),privateKey:t}):r.length===Li?new Lr({multihash:$t(Te.code,r),privateKey:t}):new Tr({multihash:await At.digest(r),publicKey:r,privateKey:t})}var tu=Symbol.for("@achingbrain/uint8arraylist");function Ql(r,t){if(t==null||t<0)throw new RangeError("index is out of bounds");let e=0;for(let n of r){let s=e+n.byteLength;if(t<s)return{buf:n,index:t-e};e=s}throw new RangeError("index is out of bounds")}function Ls(r){return!!r?.[tu]}var lt=class r{bufs;length;[tu]=!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 e=0;for(let n of t)if(n instanceof Uint8Array)e+=n.byteLength,this.bufs.push(n);else if(Ls(n))e+=n.byteLength,this.bufs.push(...n.bufs);else throw new Error("Could not append value, must be an Uint8Array or a Uint8ArrayList");this.length+=e}prepend(...t){this.prependAll(t)}prependAll(t){let e=0;for(let n of t.reverse())if(n instanceof Uint8Array)e+=n.byteLength,this.bufs.unshift(n);else if(Ls(n))e+=n.byteLength,this.bufs.unshift(...n.bufs);else throw new Error("Could not prepend value, must be an Uint8Array or a Uint8ArrayList");this.length+=e}get(t){let e=Ql(this.bufs,t);return e.buf[e.index]}set(t,e){let n=Ql(this.bufs,t);n.buf[n.index]=e}write(t,e=0){if(t instanceof Uint8Array)for(let n=0;n<t.length;n++)this.set(e+n,t[n]);else if(Ls(t))for(let n=0;n<t.length;n++)this.set(e+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,e){let{bufs:n,length:s}=this._subList(t,e);return xt(n,s)}subarray(t,e){let{bufs:n,length:s}=this._subList(t,e);return n.length===1?n[0]:xt(n,s)}sublist(t,e){let{bufs:n,length:s}=this._subList(t,e),o=new r;return o.length=s,o.bufs=[...n],o}_subList(t,e){if(t=t??0,e=e??this.length,t<0&&(t=this.length+t),e<0&&(e=this.length+e),t<0||e>this.length)throw new RangeError("index is out of bounds");if(t===e)return{bufs:[],length:0};if(t===0&&e===this.length)return{bufs:this.bufs,length:this.length};let n=[],s=0;for(let o=0;o<this.bufs.length;o++){let i=this.bufs[o],a=s,c=a+i.byteLength;if(s=c,t>=c)continue;let l=t>=a&&t<c,u=e>a&&e<=c;if(l&&u){if(t===a&&e===c){n.push(i);break}let f=t-a;n.push(i.subarray(f,f+(e-t)));break}if(l){if(t===0){n.push(i);continue}n.push(i.subarray(t-a));continue}if(u){if(e===c){n.push(i);break}n.push(i.subarray(0,e-a));break}n.push(i)}return{bufs:n,length:e-t}}indexOf(t,e=0){if(!Ls(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(e=Number(e??0),isNaN(e)&&(e=0),e<0&&(e=this.length+e),e<0&&(e=0),t.length===0)return e>this.length?this.length:e;let s=n.byteLength;if(s===0)throw new TypeError("search must be at least 1 byte long");let o=256,i=new Int32Array(o);for(let f=0;f<o;f++)i[f]=-1;for(let f=0;f<s;f++)i[n[f]]=f;let a=i,c=this.byteLength-n.byteLength,l=n.byteLength-1,u;for(let f=e;f<=c;f+=u){u=0;for(let g=l;g>=0;g--){let m=this.get(f+g);if(n[g]!==m){u=Math.max(1,g-a[m]);break}}if(u===0)return f}return-1}getInt8(t){let e=this.subarray(t,t+1);return new DataView(e.buffer,e.byteOffset,e.byteLength).getInt8(0)}setInt8(t,e){let n=wt(1);new DataView(n.buffer,n.byteOffset,n.byteLength).setInt8(0,e),this.write(n,t)}getInt16(t,e){let n=this.subarray(t,t+2);return new DataView(n.buffer,n.byteOffset,n.byteLength).getInt16(0,e)}setInt16(t,e,n){let s=mt(2);new DataView(s.buffer,s.byteOffset,s.byteLength).setInt16(0,e,n),this.write(s,t)}getInt32(t,e){let n=this.subarray(t,t+4);return new DataView(n.buffer,n.byteOffset,n.byteLength).getInt32(0,e)}setInt32(t,e,n){let s=mt(4);new DataView(s.buffer,s.byteOffset,s.byteLength).setInt32(0,e,n),this.write(s,t)}getBigInt64(t,e){let n=this.subarray(t,t+8);return new DataView(n.buffer,n.byteOffset,n.byteLength).getBigInt64(0,e)}setBigInt64(t,e,n){let s=mt(8);new DataView(s.buffer,s.byteOffset,s.byteLength).setBigInt64(0,e,n),this.write(s,t)}getUint8(t){let e=this.subarray(t,t+1);return new DataView(e.buffer,e.byteOffset,e.byteLength).getUint8(0)}setUint8(t,e){let n=wt(1);new DataView(n.buffer,n.byteOffset,n.byteLength).setUint8(0,e),this.write(n,t)}getUint16(t,e){let n=this.subarray(t,t+2);return new DataView(n.buffer,n.byteOffset,n.byteLength).getUint16(0,e)}setUint16(t,e,n){let s=mt(2);new DataView(s.buffer,s.byteOffset,s.byteLength).setUint16(0,e,n),this.write(s,t)}getUint32(t,e){let n=this.subarray(t,t+4);return new DataView(n.buffer,n.byteOffset,n.byteLength).getUint32(0,e)}setUint32(t,e,n){let s=mt(4);new DataView(s.buffer,s.byteOffset,s.byteLength).setUint32(0,e,n),this.write(s,t)}getBigUint64(t,e){let n=this.subarray(t,t+8);return new DataView(n.buffer,n.byteOffset,n.byteLength).getBigUint64(0,e)}setBigUint64(t,e,n){let s=mt(8);new DataView(s.buffer,s.byteOffset,s.byteLength).setBigUint64(0,e,n),this.write(s,t)}getFloat32(t,e){let n=this.subarray(t,t+4);return new DataView(n.buffer,n.byteOffset,n.byteLength).getFloat32(0,e)}setFloat32(t,e,n){let s=mt(4);new DataView(s.buffer,s.byteOffset,s.byteLength).setFloat32(0,e,n),this.write(s,t)}getFloat64(t,e){let n=this.subarray(t,t+8);return new DataView(n.buffer,n.byteOffset,n.byteLength).getFloat64(0,e)}setFloat64(t,e,n){let s=mt(8);new DataView(s.buffer,s.byteOffset,s.byteLength).setFloat64(0,e,n),this.write(s,t)}equals(t){if(t==null||!(t instanceof r)||t.bufs.length!==this.bufs.length)return!1;for(let e=0;e<this.bufs.length;e++)if(!ft(this.bufs[e],t.bufs[e]))return!1;return!0}static fromUint8Arrays(t,e){let n=new r;return n.bufs=t,e==null&&(e=t.reduce((s,o)=>s+o.byteLength,0)),n.length=e,n}};function Cs(r){return r[Symbol.asyncIterator]!=null}var Us=r=>{let t=dt(r),e=wt(t);return ne(r,e),Us.bytes=t,e};Us.bytes=0;function eu(r,t){t=t??{};let e=t.lengthEncoder??Us;function*n(s){let o=e(s.byteLength);o instanceof Uint8Array?yield o:yield*o,s instanceof Uint8Array?yield s:yield*s}return Cs(r)?async function*(){for await(let s of r)yield*n(s)}():function*(){for(let s of r)yield*n(s)}()}eu.single=(r,t)=>{t=t??{};let e=t.lengthEncoder??Us;return new lt(e(r.byteLength),r)};var Cr=Oa(su(),1);var F0=8,$0=1024*1024*4,ir;(function(r){r[r.LENGTH=0]="LENGTH",r[r.DATA=1]="DATA"})(ir||(ir={}));var Pi=r=>{let t=Yt(r);return Pi.bytes=dt(t),t};Pi.bytes=0;function yn(r,t){let e=new lt,n=ir.LENGTH,s=-1,o=t?.lengthDecoder??Pi,i=t?.maxLengthLength??F0,a=t?.maxDataLength??$0;function*c(){for(;e.byteLength>0;){if(n===ir.LENGTH)try{if(s=o(e),s<0)throw(0,Cr.default)(new Error("invalid message length"),"ERR_INVALID_MSG_LENGTH");if(s>a)throw(0,Cr.default)(new Error("message length too long"),"ERR_MSG_DATA_TOO_LONG");let l=o.bytes;e.consume(l),t?.onLength!=null&&t.onLength(s),n=ir.DATA}catch(l){if(l instanceof RangeError){if(e.byteLength>i)throw(0,Cr.default)(new Error("message length length too long"),"ERR_MSG_LENGTH_TOO_LONG");break}throw l}if(n===ir.DATA){if(e.byteLength<s)break;let l=e.sublist(0,s);e.consume(s),t?.onData!=null&&t.onData(l),yield l,n=ir.LENGTH}}}return Cs(r)?async function*(){for await(let l of r)e.append(l),yield*c();if(e.byteLength>0)throw(0,Cr.default)(new Error("unexpected end of input"),"ERR_UNEXPECTED_EOF")}():function*(){for(let l of r)e.append(l),yield*c();if(e.byteLength>0)throw(0,Cr.default)(new Error("unexpected end of input"),"ERR_UNEXPECTED_EOF")}()}yn.fromReader=(r,t)=>{let e=1,n=async function*(){for(;;)try{let{done:o,value:i}=await r.next(e);if(o===!0)return;i!=null&&(yield i)}catch(o){if(o.code==="ERR_UNDER_READ")return{done:!0,value:null};throw o}finally{e=1}}();return yn(n,{...t??{},onLength:o=>{e=o}})};function te(){let r={};return r.promise=new Promise((t,e)=>{r.resolve=t,r.reject=e}),r}var Ps=class extends Error{type;code;constructor(t,e){super(t??"The operation was aborted"),this.type="aborted",this.name="AbortError",this.code=e??"ABORT_ERR"}};async function ou(r,t,e){if(t==null)return r;if(t.aborted)return Promise.reject(new Ps(e?.errorMessage,e?.errorCode));let n,s=new Ps(e?.errorMessage,e?.errorCode);try{return await Promise.race([r,new Promise((o,i)=>{n=()=>{i(s)},t.addEventListener("abort",n)})])}finally{n!=null&&t.removeEventListener("abort",n)}}var Di=class{readNext;haveNext;ended;nextResult;constructor(){this.ended=!1,this.readNext=te(),this.haveNext=te()}[Symbol.asyncIterator](){return this}async next(){if(this.nextResult==null&&await this.haveNext.promise,this.nextResult==null)throw new Error("HaveNext promise resolved but nextResult was undefined");let t=this.nextResult;return this.nextResult=void 0,this.readNext.resolve(),this.readNext=te(),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,e){await this._push(t,e)}async end(t,e){t!=null?await this.throw(t):await this._push(void 0,e)}async _push(t,e){if(t!=null&&this.ended)throw new Error("Cannot push value onto an ended pushable");if(this.nextResult!=null&&(await this.readNext.promise,this.nextResult!=null))throw new Error("NeedNext promise resolved but nextResult was not consumed");t!=null?this.nextResult={done:!1,value:t}:(this.ended=!0,this.nextResult={done:!0,value:void 0}),this.haveNext.resolve(),this.haveNext=te(),await ou(this.readNext.promise,e?.signal,e)}};function iu(){return new Di}var Ds=class extends Error{code;constructor(t,e){super(t),this.code=e}},Vi=class extends Ds{type;constructor(t){super(t,"ABORT_ERR"),this.type="aborted"}};function au(r,t){let e=iu();r.sink(e).catch(async i=>{await e.end(i)}),r.sink=async i=>{for await(let a of i)await e.push(a);await e.end()};let n=r.source;r.source[Symbol.iterator]!=null?n=r.source[Symbol.iterator]():r.source[Symbol.asyncIterator]!=null&&(n=r.source[Symbol.asyncIterator]());let s=new lt;return{read:async(i,a)=>{a?.signal?.throwIfAborted();let c,l=new Promise((u,f)=>{c=()=>{f(new Vi("Read aborted"))},a?.signal?.addEventListener("abort",c)});try{if(i==null){let{done:f,value:g}=await Promise.race([n.next(),l]);return f===!0?new lt:g}for(;s.byteLength<i;){let{value:f,done:g}=await Promise.race([n.next(),l]);if(g===!0)throw new Ds("unexpected end of input","ERR_UNEXPECTED_EOF");s.append(f)}let u=s.sublist(0,i);return s.consume(i),u}finally{c!=null&&a?.signal?.removeEventListener("abort",c)}},write:async(i,a)=>{a?.signal?.throwIfAborted(),i instanceof Uint8Array?await e.push(i,a):await e.push(i.subarray(),a)},unwrap:()=>{if(s.byteLength>0){let i=r.source;r.source=async function*(){t?.yieldBytes===!1?yield s:yield*s,yield*i}()}return r}}}var Vs=class extends Error{code;constructor(t,e){super(t),this.code=e}};function Oi(r,t={}){let e=au(r,t);t.maxDataLength!=null&&t.maxLengthLength==null&&(t.maxLengthLength=dt(t.maxDataLength));let n=t?.lengthDecoder??Yt,s=t?.lengthEncoder??ne;return{read:async i=>{let a=-1,c=new lt;for(;;){c.append(await e.read(1,i));try{a=n(c)}catch(l){if(l instanceof RangeError)continue;throw l}if(t?.maxLengthLength!=null&&c.byteLength>t.maxLengthLength)throw new Vs("message length length too long","ERR_MSG_LENGTH_TOO_LONG");if(a>-1)break}if(t?.maxDataLength!=null&&a>t.maxDataLength)throw new Vs("message length too long","ERR_MSG_DATA_TOO_LONG");return e.read(a,i)},write:async(i,a)=>{await e.write(new lt(s(i.byteLength),i),a)},writeV:async(i,a)=>{let c=new lt(...i.flatMap(l=>[s(l.byteLength),l]));await e.write(c,a)},unwrap:()=>e.unwrap()}}function Hi(){let r=te(),t=!1;return{sink:async e=>{if(t)throw new Error("already piped");t=!0,r.resolve(e)},source:async function*(){yield*await r.promise}()}}function cu(){let r=Hi(),t=Hi();return[{source:r.source,sink:t.sink},{source:t.source,sink:r.sink}]}var Os=class{buffer;mask;top;btm;next;constructor(t){if(!(t>0)||t-1&t)throw new Error("Max size for a FixedFIFO should be a power of two");this.buffer=new Array(t),this.mask=t-1,this.top=0,this.btm=0,this.next=null}push(t){return this.buffer[this.top]!==void 0?!1:(this.buffer[this.top]=t,this.top=this.top+1&this.mask,!0)}shift(){let t=this.buffer[this.btm];if(t!==void 0)return this.buffer[this.btm]=void 0,this.btm=this.btm+1&this.mask,t}isEmpty(){return this.buffer[this.btm]===void 0}},Ur=class{size;hwm;head;tail;constructor(t={}){this.hwm=t.splitLimit??16,this.head=new Os(this.hwm),this.tail=this.head,this.size=0}calculateSize(t){return t?.byteLength!=null?t.byteLength:1}push(t){if(t?.value!=null&&(this.size+=this.calculateSize(t.value)),!this.head.push(t)){let e=this.head;this.head=e.next=new Os(2*this.head.buffer.length),this.head.push(t)}}shift(){let t=this.tail.shift();if(t===void 0&&this.tail.next!=null){let e=this.tail.next;this.tail.next=null,this.tail=e,t=this.tail.shift()}return t?.value!=null&&(this.size-=this.calculateSize(t.value)),t}isEmpty(){return this.head.isEmpty()}};var Mi=class extends Error{type;code;constructor(t,e){super(t??"The operation was aborted"),this.type="aborted",this.code=e??"ABORT_ERR"}};function Hs(r={}){return q0(e=>{let n=e.shift();if(n==null)return{done:!0};if(n.error!=null)throw n.error;return{done:n.done===!0,value:n.value}},r)}function q0(r,t){t=t??{};let e=t.onEnd,n=new Ur,s,o,i,a=te(),c=async()=>{try{return n.isEmpty()?i?{done:!0}:await new Promise((p,b)=>{o=v=>{o=null,n.push(v);try{p(r(n))}catch(w){b(w)}return s}}):r(n)}finally{n.isEmpty()&&queueMicrotask(()=>{a.resolve(),a=te()})}},l=p=>o!=null?o(p):(n.push(p),s),u=p=>(n=new Ur,o!=null?o({error:p}):(n.push({error:p}),s)),f=p=>{if(i)return s;if(t?.objectMode!==!0&&p?.byteLength==null)throw new Error("objectMode was not true but tried to push non-Uint8Array value");return l({done:!1,value:p})},g=p=>i?s:(i=!0,p!=null?u(p):l({done:!0})),m=()=>(n=new Ur,g(),{done:!0}),d=p=>(g(p),{done:!0});if(s={[Symbol.asyncIterator](){return this},next:c,return:m,throw:d,push:f,end:g,get readableLength(){return n.size},onEmpty:async p=>{let b=p?.signal;if(b?.throwIfAborted(),n.isEmpty())return;let v,w;b!=null&&(v=new Promise((A,B)=>{w=()=>{B(new Mi)},b.addEventListener("abort",w)}));try{await Promise.race([a.promise,v])}finally{w!=null&&b!=null&&b?.removeEventListener("abort",w)}}},e==null)return s;let h=s;return s={[Symbol.asyncIterator](){return this},next(){return h.next()},throw(p){return h.throw(p),e!=null&&(e(p),e=void 0),{done:!0}},return(){return h.return(),e!=null&&(e(),e=void 0),{done:!0}},push:f,end(p){return h.end(p),e!=null&&(e(p),e=void 0),s},get readableLength(){return h.readableLength},onEmpty:p=>h.onEmpty(p)},s}function G0(r){return r[Symbol.asyncIterator]!=null}function j0(...r){let t=[];for(let e of r)G0(e)||t.push(e);return t.length===r.length?function*(){for(let e of t)yield*e}():async function*(){let e=Hs({objectMode:!0});Promise.resolve().then(async()=>{try{await Promise.all(r.map(async n=>{for await(let s of n)e.push(s)})),e.end()}catch(n){e.end(n)}}),yield*e}()}var lu=j0;function uu(r,...t){if(r==null)throw new Error("Empty pipeline");if(Ki(r)){let n=r;r=()=>n.source}else if(hu(r)||fu(r)){let n=r;r=()=>n}let e=[r,...t];if(e.length>1&&Ki(e[e.length-1])&&(e[e.length-1]=e[e.length-1].sink),e.length>2)for(let n=1;n<e.length-1;n++)Ki(e[n])&&(e[n]=W0(e[n]));return z0(...e)}var z0=(...r)=>{let t;for(;r.length>0;)t=r.shift()(t);return t},fu=r=>r?.[Symbol.asyncIterator]!=null,hu=r=>r?.[Symbol.iterator]!=null,Ki=r=>r==null?!1:r.sink!=null&&r.source!=null,W0=r=>t=>{let e=r.sink(t);if(e?.then!=null){let n=Hs({objectMode:!0});e.then(()=>{n.end()},i=>{n.end(i)});let s,o=r.source;if(fu(o))s=async function*(){yield*o,n.end()};else if(hu(o))s=function*(){yield*o,n.end()};else throw new Error("Unknown duplex source type - must be Iterable or AsyncIterable");return lu(n,s())}return r.source};var Pr=!!globalThis.process?.env?.DUMP_SESSION_KEYS;var Ie=r=>new Uint32Array(r.buffer,r.byteOffset,Math.floor(r.byteLength/4));function du(r){return r instanceof Uint8Array||r!=null&&typeof r=="object"&&r.constructor.name==="Uint8Array"}var pu=r=>new DataView(r.buffer,r.byteOffset,r.byteLength),Y0=new Uint8Array(new Uint32Array([287454020]).buffer)[0]===68;if(!Y0)throw new Error("Non little-endian hardware is not supported");function Ms(r){if(typeof r!="string")throw new Error(`utf8ToBytes expected string, got ${typeof r}`);return new Uint8Array(new TextEncoder().encode(r))}function Ks(r){if(typeof r=="string")r=Ms(r);else if(du(r))r=r.slice();else throw new Error(`expected Uint8Array, got ${typeof r}`);return r}var Z0=r=>Object.prototype.toString.call(r)==="[object Object]"&&r.constructor===Object;function gu(r,t){if(t!==void 0&&(typeof t!="object"||!Z0(t)))throw new Error("options must be object or undefined");return Object.assign(r,t)}function ar(r,t){if(!du(r))throw new Error("Uint8Array expected");if(typeof t=="number"&&r.length!==t)throw new Error(`Uint8Array length ${t} expected`)}function yu(r,t){if(r.length!==t.length)return!1;let e=0;for(let n=0;n<r.length;n++)e|=r[n]^t[n];return e===0}var Fi=(r,t)=>(Object.assign(t,r),t);function $i(r,t,e,n){if(typeof r.setBigUint64=="function")return r.setBigUint64(t,e,n);let s=BigInt(32),o=BigInt(4294967295),i=Number(e>>s&o),a=Number(e&o),c=n?4:0,l=n?0:4;r.setUint32(t+c,i,n),r.setUint32(t+l,a,n)}function Fs(r){if(!Number.isSafeInteger(r)||r<0)throw new Error(`wrong positive integer: ${r}`)}function qi(r){if(typeof r!="boolean")throw new Error(`boolean expected, not ${r}`)}function X0(r){return r!=null&&typeof r=="object"&&(r instanceof Uint8Array||r.constructor.name==="Uint8Array")}function Dr(r,...t){if(!X0(r))throw new Error("Uint8Array expected");if(t.length>0&&!t.includes(r.length))throw new Error(`Uint8Array expected of length ${t}, not of length=${r.length}`)}function Gi(r,t=!0){if(r.destroyed)throw new Error("Hash instance has been destroyed");if(t&&r.finished)throw new Error("Hash#digest() has already been called")}function mu(r,t){Dr(r);let e=t.outputLen;if(r.length<e)throw new Error(`digestInto() expects output buffer of length at least ${e}`)}var kt=(r,t)=>r[t++]&255|(r[t++]&255)<<8,ji=class{constructor(t){this.blockLen=16,this.outputLen=16,this.buffer=new Uint8Array(16),this.r=new Uint16Array(10),this.h=new Uint16Array(10),this.pad=new Uint16Array(8),this.pos=0,this.finished=!1,t=Ks(t),ar(t,32);let e=kt(t,0),n=kt(t,2),s=kt(t,4),o=kt(t,6),i=kt(t,8),a=kt(t,10),c=kt(t,12),l=kt(t,14);this.r[0]=e&8191,this.r[1]=(e>>>13|n<<3)&8191,this.r[2]=(n>>>10|s<<6)&7939,this.r[3]=(s>>>7|o<<9)&8191,this.r[4]=(o>>>4|i<<12)&255,this.r[5]=i>>>1&8190,this.r[6]=(i>>>14|a<<2)&8191,this.r[7]=(a>>>11|c<<5)&8065,this.r[8]=(c>>>8|l<<8)&8191,this.r[9]=l>>>5&127;for(let u=0;u<8;u++)this.pad[u]=kt(t,16+2*u)}process(t,e,n=!1){let s=n?0:2048,{h:o,r:i}=this,a=i[0],c=i[1],l=i[2],u=i[3],f=i[4],g=i[5],m=i[6],d=i[7],h=i[8],p=i[9],b=kt(t,e+0),v=kt(t,e+2),w=kt(t,e+4),A=kt(t,e+6),B=kt(t,e+8),S=kt(t,e+10),N=kt(t,e+12),_=kt(t,e+14),V=o[0]+(b&8191),P=o[1]+((b>>>13|v<<3)&8191),R=o[2]+((v>>>10|w<<6)&8191),H=o[3]+((w>>>7|A<<9)&8191),O=o[4]+((A>>>4|B<<12)&8191),W=o[5]+(B>>>1&8191),x=o[6]+((B>>>14|S<<2)&8191),I=o[7]+((S>>>11|N<<5)&8191),C=o[8]+((N>>>8|_<<8)&8191),E=o[9]+(_>>>5|s),y=0,k=y+V*a+P*(5*p)+R*(5*h)+H*(5*d)+O*(5*m);y=k>>>13,k&=8191,k+=W*(5*g)+x*(5*f)+I*(5*u)+C*(5*l)+E*(5*c),y+=k>>>13,k&=8191;let T=y+V*c+P*a+R*(5*p)+H*(5*h)+O*(5*d);y=T>>>13,T&=8191,T+=W*(5*m)+x*(5*g)+I*(5*f)+C*(5*u)+E*(5*l),y+=T>>>13,T&=8191;let L=y+V*l+P*c+R*a+H*(5*p)+O*(5*h);y=L>>>13,L&=8191,L+=W*(5*d)+x*(5*m)+I*(5*g)+C*(5*f)+E*(5*u),y+=L>>>13,L&=8191;let M=y+V*u+P*l+R*c+H*a+O*(5*p);y=M>>>13,M&=8191,M+=W*(5*h)+x*(5*d)+I*(5*m)+C*(5*g)+E*(5*f),y+=M>>>13,M&=8191;let K=y+V*f+P*u+R*l+H*c+O*a;y=K>>>13,K&=8191,K+=W*(5*p)+x*(5*h)+I*(5*d)+C*(5*m)+E*(5*g),y+=K>>>13,K&=8191;let j=y+V*g+P*f+R*u+H*l+O*c;y=j>>>13,j&=8191,j+=W*a+x*(5*p)+I*(5*h)+C*(5*d)+E*(5*m),y+=j>>>13,j&=8191;let $=y+V*m+P*g+R*f+H*u+O*l;y=$>>>13,$&=8191,$+=W*c+x*a+I*(5*p)+C*(5*h)+E*(5*d),y+=$>>>13,$&=8191;let G=y+V*d+P*m+R*g+H*f+O*u;y=G>>>13,G&=8191,G+=W*l+x*c+I*a+C*(5*p)+E*(5*h),y+=G>>>13,G&=8191;let nt=y+V*h+P*d+R*m+H*g+O*f;y=nt>>>13,nt&=8191,nt+=W*u+x*l+I*c+C*a+E*(5*p),y+=nt>>>13,nt&=8191;let tt=y+V*p+P*h+R*d+H*m+O*g;y=tt>>>13,tt&=8191,tt+=W*f+x*u+I*l+C*c+E*a,y+=tt>>>13,tt&=8191,y=(y<<2)+y|0,y=y+k|0,k=y&8191,y=y>>>13,T+=y,o[0]=k,o[1]=T,o[2]=L,o[3]=M,o[4]=K,o[5]=j,o[6]=$,o[7]=G,o[8]=nt,o[9]=tt}finalize(){let{h:t,pad:e}=this,n=new Uint16Array(10),s=t[1]>>>13;t[1]&=8191;for(let a=2;a<10;a++)t[a]+=s,s=t[a]>>>13,t[a]&=8191;t[0]+=s*5,s=t[0]>>>13,t[0]&=8191,t[1]+=s,s=t[1]>>>13,t[1]&=8191,t[2]+=s,n[0]=t[0]+5,s=n[0]>>>13,n[0]&=8191;for(let a=1;a<10;a++)n[a]=t[a]+s,s=n[a]>>>13,n[a]&=8191;n[9]-=8192;let o=(s^1)-1;for(let a=0;a<10;a++)n[a]&=o;o=~o;for(let a=0;a<10;a++)t[a]=t[a]&o|n[a];t[0]=(t[0]|t[1]<<13)&65535,t[1]=(t[1]>>>3|t[2]<<10)&65535,t[2]=(t[2]>>>6|t[3]<<7)&65535,t[3]=(t[3]>>>9|t[4]<<4)&65535,t[4]=(t[4]>>>12|t[5]<<1|t[6]<<14)&65535,t[5]=(t[6]>>>2|t[7]<<11)&65535,t[6]=(t[7]>>>5|t[8]<<8)&65535,t[7]=(t[8]>>>8|t[9]<<5)&65535;let i=t[0]+e[0];t[0]=i&65535;for(let a=1;a<8;a++)i=(t[a]+e[a]|0)+(i>>>16)|0,t[a]=i&65535}update(t){Gi(this);let{buffer:e,blockLen:n}=this;t=Ks(t);let s=t.length;for(let o=0;o<s;){let i=Math.min(n-this.pos,s-o);if(i===n){for(;n<=s-o;o+=n)this.process(t,o);continue}e.set(t.subarray(o,o+i),this.pos),this.pos+=i,o+=i,this.pos===n&&(this.process(e,0,!1),this.pos=0)}return this}destroy(){this.h.fill(0),this.r.fill(0),this.buffer.fill(0),this.pad.fill(0)}digestInto(t){Gi(this),mu(t,this),this.finished=!0;let{buffer:e,h:n}=this,{pos:s}=this;if(s){for(e[s++]=1;s<16;s++)e[s]=0;this.process(e,0,!0)}this.finalize();let o=0;for(let i=0;i<8;i++)t[o++]=n[i]>>>0,t[o++]=n[i]>>>8;return t}digest(){let{buffer:t,outputLen:e}=this;this.digestInto(t);let n=t.slice(0,e);return this.destroy(),n}};function J0(r){let t=(n,s)=>r(s).update(Ks(n)).digest(),e=r(new Uint8Array(32));return t.outputLen=e.outputLen,t.blockLen=e.blockLen,t.create=n=>r(n),t}var wu=J0(r=>new ji(r));var Q0=Ms("expand 16-byte k"),tp=Ms("expand 32-byte k"),ep=Ie(Q0),rp=Ie(tp);function D(r,t){return r<<t|r>>>32-t}function zi(r){return r.byteOffset%4===0}var $s=64,np=16,xu=2**32-1,bu=new Uint32Array;function sp(r,t,e,n,s,o,i,a){let c=s.length,l=new Uint8Array($s),u=Ie(l),f=zi(s)&&zi(o),g=f?Ie(s):bu,m=f?Ie(o):bu;for(let d=0;d<c;i++){if(r(t,e,n,u,i,a),i>=xu)throw new Error("arx: counter overflow");let h=Math.min($s,c-d);if(f&&h===$s){let p=d/4;if(d%4!==0)throw new Error("arx: invalid block position");for(let b=0,v;b<np;b++)v=p+b,m[v]=g[v]^u[b];d+=$s;continue}for(let p=0,b;p<h;p++)b=d+p,o[b]=s[b]^l[p];d+=h}}function Wi(r,t){let{allowShortKeys:e,extendNonceFn:n,counterLength:s,counterRight:o,rounds:i}=gu({allowShortKeys:!1,counterLength:8,counterRight:!1,rounds:20},t);if(typeof r!="function")throw new Error("core must be a function");return Fs(s),Fs(i),qi(o),qi(e),(a,c,l,u,f=0)=>{Dr(a),Dr(c),Dr(l);let g=l.length;if(u||(u=new Uint8Array(g)),Dr(u),Fs(f),f<0||f>=xu)throw new Error("arx: counter overflow");if(u.length<g)throw new Error(`arx: output (${u.length}) is shorter than data (${g})`);let m=[],d=a.length,h,p;if(d===32)h=a.slice(),m.push(h),p=rp;else if(d===16&&e)h=new Uint8Array(32),h.set(a),h.set(a,16),p=ep,m.push(h);else throw new Error(`arx: invalid 32-byte key, got length=${d}`);zi(c)||(c=c.slice(),m.push(c));let b=Ie(h);if(n){if(c.length!==24)throw new Error("arx: extended nonce must be 24 bytes");n(p,b,Ie(c.subarray(0,16)),b),c=c.subarray(16)}let v=16-s;if(v!==c.length)throw new Error(`arx: nonce must be ${v} or 16 bytes`);if(v!==12){let A=new Uint8Array(12);A.set(c,o?0:12-c.length),c=A,m.push(c)}let w=Ie(c);for(sp(r,p,b,w,l,u,f,i);m.length>0;)m.pop().fill(0);return u}}function Bu(r,t,e,n,s,o=20){let i=r[0],a=r[1],c=r[2],l=r[3],u=t[0],f=t[1],g=t[2],m=t[3],d=t[4],h=t[5],p=t[6],b=t[7],v=s,w=e[0],A=e[1],B=e[2],S=i,N=a,_=c,V=l,P=u,R=f,H=g,O=m,W=d,x=h,I=p,C=b,E=v,y=w,k=A,T=B;for(let M=0;M<o;M+=2)S=S+P|0,E=D(E^S,16),W=W+E|0,P=D(P^W,12),S=S+P|0,E=D(E^S,8),W=W+E|0,P=D(P^W,7),N=N+R|0,y=D(y^N,16),x=x+y|0,R=D(R^x,12),N=N+R|0,y=D(y^N,8),x=x+y|0,R=D(R^x,7),_=_+H|0,k=D(k^_,16),I=I+k|0,H=D(H^I,12),_=_+H|0,k=D(k^_,8),I=I+k|0,H=D(H^I,7),V=V+O|0,T=D(T^V,16),C=C+T|0,O=D(O^C,12),V=V+O|0,T=D(T^V,8),C=C+T|0,O=D(O^C,7),S=S+R|0,T=D(T^S,16),I=I+T|0,R=D(R^I,12),S=S+R|0,T=D(T^S,8),I=I+T|0,R=D(R^I,7),N=N+H|0,E=D(E^N,16),C=C+E|0,H=D(H^C,12),N=N+H|0,E=D(E^N,8),C=C+E|0,H=D(H^C,7),_=_+O|0,y=D(y^_,16),W=W+y|0,O=D(O^W,12),_=_+O|0,y=D(y^_,8),W=W+y|0,O=D(O^W,7),V=V+P|0,k=D(k^V,16),x=x+k|0,P=D(P^x,12),V=V+P|0,k=D(k^V,8),x=x+k|0,P=D(P^x,7);let L=0;n[L++]=i+S|0,n[L++]=a+N|0,n[L++]=c+_|0,n[L++]=l+V|0,n[L++]=u+P|0,n[L++]=f+R|0,n[L++]=g+H|0,n[L++]=m+O|0,n[L++]=d+W|0,n[L++]=h+x|0,n[L++]=p+I|0,n[L++]=b+C|0,n[L++]=v+E|0,n[L++]=w+y|0,n[L++]=A+k|0,n[L++]=B+T|0}function op(r,t,e,n){let s=r[0],o=r[1],i=r[2],a=r[3],c=t[0],l=t[1],u=t[2],f=t[3],g=t[4],m=t[5],d=t[6],h=t[7],p=e[0],b=e[1],v=e[2],w=e[3];for(let B=0;B<20;B+=2)s=s+c|0,p=D(p^s,16),g=g+p|0,c=D(c^g,12),s=s+c|0,p=D(p^s,8),g=g+p|0,c=D(c^g,7),o=o+l|0,b=D(b^o,16),m=m+b|0,l=D(l^m,12),o=o+l|0,b=D(b^o,8),m=m+b|0,l=D(l^m,7),i=i+u|0,v=D(v^i,16),d=d+v|0,u=D(u^d,12),i=i+u|0,v=D(v^i,8),d=d+v|0,u=D(u^d,7),a=a+f|0,w=D(w^a,16),h=h+w|0,f=D(f^h,12),a=a+f|0,w=D(w^a,8),h=h+w|0,f=D(f^h,7),s=s+l|0,w=D(w^s,16),d=d+w|0,l=D(l^d,12),s=s+l|0,w=D(w^s,8),d=d+w|0,l=D(l^d,7),o=o+u|0,p=D(p^o,16),h=h+p|0,u=D(u^h,12),o=o+u|0,p=D(p^o,8),h=h+p|0,u=D(u^h,7),i=i+f|0,b=D(b^i,16),g=g+b|0,f=D(f^g,12),i=i+f|0,b=D(b^i,8),g=g+b|0,f=D(f^g,7),a=a+c|0,v=D(v^a,16),m=m+v|0,c=D(c^m,12),a=a+c|0,v=D(v^a,8),m=m+v|0,c=D(c^m,7);let A=0;n[A++]=s,n[A++]=o,n[A++]=i,n[A++]=a,n[A++]=p,n[A++]=b,n[A++]=v,n[A++]=w}var ip=Wi(Bu,{counterRight:!1,counterLength:4,allowShortKeys:!1}),ap=Wi(Bu,{counterRight:!1,counterLength:8,extendNonceFn:op,allowShortKeys:!1});var cp=new Uint8Array(16),Eu=(r,t)=>{r.update(t);let e=t.length%16;e&&r.update(cp.subarray(e))},lp=new Uint8Array(32);function vu(r,t,e,n,s){let o=r(t,e,lp),i=wu.create(o);s&&Eu(i,s),Eu(i,n);let a=new Uint8Array(16),c=pu(a);$i(c,0,BigInt(s?s.length:0),!0),$i(c,8,BigInt(n.length),!0),i.update(a);let l=i.digest();return o.fill(0),l}var Au=r=>(t,e,n)=>(ar(t,32),ar(e),{encrypt:(o,i)=>{let a=o.length,c=a+16;i?ar(i,c):i=new Uint8Array(c),r(t,e,o,i,1);let l=vu(r,t,e,i.subarray(0,-16),n);return i.set(l,a),i},decrypt:(o,i)=>{let a=o.length,c=a-16;if(a<16)throw new Error("encrypted data must be at least 16 bytes");i?ar(i,c):i=new Uint8Array(c);let l=o.subarray(0,-16),u=o.subarray(-16),f=vu(r,t,e,l,n);if(!yu(u,f))throw new Error("invalid tag");return r(t,e,l,i,1),i}}),Yi=Fi({blockSize:64,nonceLength:12,tagLength:16},Au(ip)),Yb=Fi({blockSize:64,nonceLength:24,tagLength:16},Au(ap));function ku(r,t,e){return je(r),e===void 0&&(e=new Uint8Array(r.outputLen)),Ve(r,jt(e),jt(t))}var Zi=new Uint8Array([0]),Su=new Uint8Array;function Iu(r,t,e,n=32){if(je(r),Re(n),n>255*r.outputLen)throw new Error("Length should be <= 255*HashLen");let s=Math.ceil(n/r.outputLen);e===void 0&&(e=Su);let o=new Uint8Array(s*r.outputLen),i=Ve.create(r,t),a=i._cloneInto(),c=new Uint8Array(i.outputLen);for(let l=0;l<s;l++)Zi[0]=l+1,a.update(l===0?Su:c).update(e).update(Zi).digestInto(c),o.set(c,r.outputLen*l),i._cloneInto(a);return i.destroy(),a.destroy(),c.fill(0),Zi.fill(0),o.slice(0,n)}var Xi={hashSHA256(r){return Nr(r.subarray())},getHKDF(r,t){let e=ku(Nr,t,r),s=Iu(Nr,e,void 0,96),o=s.subarray(0,32),i=s.subarray(32,64),a=s.subarray(64,96);return[o,i,a]},generateX25519KeyPair(){let r=Zr.utils.randomPrivateKey();return{publicKey:Zr.getPublicKey(r),privateKey:r}},generateX25519KeyPairFromSeed(r){return{publicKey:Zr.getPublicKey(r),privateKey:r}},generateX25519SharedKey(r,t){return Zr.getSharedSecret(r.subarray(),t.subarray())},chaCha20Poly1305Encrypt(r,t,e,n){return Yi(n,t,e).encrypt(r.subarray())},chaCha20Poly1305Decrypt(r,t,e,n,s){return Yi(n,t,e).decrypt(r.subarray(),s)}};var _u=Xi;function Nu(r){return{generateKeypair:r.generateX25519KeyPair,dh:(t,e)=>r.generateX25519SharedKey(t.privateKey,e).subarray(0,32),encrypt:r.chaCha20Poly1305Encrypt,decrypt:r.chaCha20Poly1305Decrypt,hash:r.hashSHA256,hkdf:r.getHKDF}}var Vr=r=>{let t=wt(2);return t[0]=r>>8,t[1]=r,t};Vr.bytes=2;var mn=r=>{if(r.length<2)throw RangeError("Could not decode int16BE");if(r instanceof Uint8Array){let t=0;return t+=r[0]<<8,t+=r[1],t}return r.getUint16(0)};mn.bytes=2;function Tu(r){return{xxHandshakeSuccesses:r.registerCounter("libp2p_noise_xxhandshake_successes_total",{help:"Total count of noise xxHandshakes successes_"}),xxHandshakeErrors:r.registerCounter("libp2p_noise_xxhandshake_error_total",{help:"Total count of noise xxHandshakes errors"}),encryptedPackets:r.registerCounter("libp2p_noise_encrypted_packets_total",{help:"Total count of noise encrypted packets successfully"}),decryptedPackets:r.registerCounter("libp2p_noise_decrypted_packets_total",{help:"Total count of noise decrypted packets"}),decryptErrors:r.registerCounter("libp2p_noise_decrypt_errors_total",{help:"Total count of noise decrypt errors"})}}function Ji(r,t){!t.enabled||!Pr||(r?(t(`LOCAL_STATIC_PUBLIC_KEY ${q(r.publicKey,"hex")}`),t(`LOCAL_STATIC_PRIVATE_KEY ${q(r.privateKey,"hex")}`)):t("Missing local static keys."))}function Qi(r,t){!t.enabled||!Pr||(r?(t(`LOCAL_PUBLIC_EPHEMERAL_KEY ${q(r.publicKey,"hex")}`),t(`LOCAL_PRIVATE_EPHEMERAL_KEY ${q(r.privateKey,"hex")}`)):t("Missing local ephemeral keys."))}function Ru(r,t){!t.enabled||!Pr||t(r?`REMOTE_STATIC_PUBLIC_KEY ${q(r.subarray(),"hex")}`:"Missing remote static public key.")}function ta(r,t){!t.enabled||!Pr||t(r?`REMOTE_EPHEMERAL_PUBLIC_KEY ${q(r.subarray(),"hex")}`:"Missing remote ephemeral keys.")}function ea(r,t,e){!e.enabled||!Pr||(e(`CIPHER_STATE_1 ${r.n.getUint64()} ${r.k&&q(r.k,"hex")}`),e(`CIPHER_STATE_2 ${t.n.getUint64()} ${t.k&&q(t.k,"hex")}`))}var qs=class r extends Error{code;constructor(t="Unexpected Peer"){super(t),this.code=r.code}static code="ERR_UNEXPECTED_PEER"},Or=class r extends Error{code;constructor(t="Invalid crypto exchange"){super(t),this.code=r.code}static code="ERR_INVALID_CRYPTO_EXCHANGE"};var up=0,fp=4294967295,hp="Cipherstate has reached maximum n, a new handshake must be performed",Gs=class{n;bytes;view;constructor(t=up){this.n=t,this.bytes=mt(12),this.view=new DataView(this.bytes.buffer,this.bytes.byteOffset,this.bytes.byteLength),this.view.setUint32(4,t,!0)}increment(){this.n++,this.view.setUint32(4,this.n,!0)}getBytes(){return this.bytes}getUint64(){return this.n}assertValue(){if(this.n>fp)throw new Error(hp)}};var cr=mt(0),Hr=class{k;n;crypto;constructor(t,e=void 0,n=0){this.crypto=t,this.k=e,this.n=new Gs(n)}hasKey(){return!!this.k}encryptWithAd(t,e){if(!this.hasKey())return e;this.n.assertValue();let n=this.crypto.encrypt(e,this.n.getBytes(),t,this.k);return this.n.increment(),n}decryptWithAd(t,e,n){if(!this.hasKey())return e;this.n.assertValue();let s=this.crypto.decrypt(e,this.n.getBytes(),t,this.k,n);return this.n.increment(),s}},ra=class{cs;ck;h;crypto;constructor(t,e){this.crypto=t;let n=et(e,"utf-8");this.h=dp(t,n),this.ck=this.h,this.cs=new Hr(t)}mixKey(t){let[e,n]=this.crypto.hkdf(this.ck,t);this.ck=e,this.cs=new Hr(this.crypto,n)}mixHash(t){this.h=this.crypto.hash(new lt(this.h,t))}encryptAndHash(t){let e=this.cs.encryptWithAd(this.h,t);return this.mixHash(e),e}decryptAndHash(t){let e=this.cs.decryptWithAd(this.h,t);return this.mixHash(t),e}split(){let[t,e]=this.crypto.hkdf(this.ck,cr);return[new Hr(this.crypto,t),new Hr(this.crypto,e)]}},na=class{ss;s;e;rs;re;initiator;crypto;constructor(t){let{crypto:e,protocolName:n,prologue:s,initiator:o,s:i,e:a,rs:c,re:l}=t;this.crypto=e,this.ss=new ra(e,n),this.ss.mixHash(s),this.initiator=o,this.s=i,this.e=a,this.rs=c,this.re=l}writeE(){if(this.e)throw new Error("ephemeral keypair is already set");let t=this.crypto.generateKeypair();return this.ss.mixHash(t.publicKey),this.e=t,t.publicKey}writeS(){if(!this.s)throw new Error("static keypair is not set");return this.ss.encryptAndHash(this.s.publicKey)}writeEE(){if(!this.e)throw new Error("ephemeral keypair is not set");if(!this.re)throw new Error("remote ephemeral public key is not set");this.ss.mixKey(this.crypto.dh(this.e,this.re))}writeES(){if(this.initiator){if(!this.e)throw new Error("ephemeral keypair is not set");if(!this.rs)throw new Error("remote static public key is not set");this.ss.mixKey(this.crypto.dh(this.e,this.rs))}else{if(!this.s)throw new Error("static keypair is not set");if(!this.re)throw new Error("remote ephemeral public key is not set");this.ss.mixKey(this.crypto.dh(this.s,this.re))}}writeSE(){if(this.initiator){if(!this.s)throw new Error("static keypair is not set");if(!this.re)throw new Error("remote ephemeral public key is not set");this.ss.mixKey(this.crypto.dh(this.s,this.re))}else{if(!this.e)throw new Error("ephemeral keypair is not set");if(!this.rs)throw new Error("remote static public key is not set");this.ss.mixKey(this.crypto.dh(this.e,this.rs))}}readE(t,e=0){if(this.re)throw new Error("remote ephemeral public key is already set");if(t.byteLength<e+32)throw new Error("message is not long enough");this.re=t.sublist(e,e+32),this.ss.mixHash(this.re)}readS(t,e=0){if(this.rs)throw new Error("remote static public key is already set");let n=32+(this.ss.cs.hasKey()?16:0);if(t.byteLength<e+n)throw new Error("message is not long enough");let s=t.sublist(e,e+n);return this.rs=this.ss.decryptAndHash(s),n}readEE(){this.writeEE()}readES(){this.writeES()}readSE(){this.writeSE()}},wn=class extends na{writeMessageA(t){return new lt(this.writeE(),this.ss.encryptAndHash(t))}writeMessageB(t){let e=this.writeE();this.writeEE();let n=this.writeS();return this.writeES(),new lt(e,n,this.ss.encryptAndHash(t))}writeMessageC(t){let e=this.writeS();return this.writeSE(),new lt(e,this.ss.encryptAndHash(t))}readMessageA(t){try{return this.readE(t),this.ss.decryptAndHash(t.sublist(32))}catch(e){throw new Or(`handshake stage 0 validation fail: ${e.message}`)}}readMessageB(t){try{this.readE(t),this.readEE();let e=this.readS(t,32);return this.readES(),this.ss.decryptAndHash(t.sublist(32+e))}catch(e){throw new Or(`handshake stage 1 validation fail: ${e.message}`)}}readMessageC(t){try{let e=this.readS(t);return this.readSE(),this.ss.decryptAndHash(t.sublist(e))}catch(e){throw new Or(`handshake stage 2 validation fail: ${e.message}`)}}};function dp(r,t){if(t.length<=32){let e=mt(32);return e.set(t),e}else return r.hash(t)}var js;(function(r){let t;r.codec=()=>(t==null&&(t=tr((e,n,s={})=>{if(s.lengthDelimited!==!1&&n.fork(),e.webtransportCerthashes!=null)for(let o of e.webtransportCerthashes)n.uint32(10),n.bytes(o);s.lengthDelimited!==!1&&n.ldelim()},(e,n)=>{let s={webtransportCerthashes:[]},o=n==null?e.len:e.pos+n;for(;e.pos<o;){let i=e.uint32();switch(i>>>3){case 1:{s.webtransportCerthashes.push(e.bytes());break}default:{e.skipType(i&7);break}}}return s})),t),r.encode=e=>Qe(e,r.codec()),r.decode=e=>Xe(e,r.codec())})(js||(js={}));var bn;(function(r){let t;r.codec=()=>(t==null&&(t=tr((e,n,s={})=>{s.lengthDelimited!==!1&&n.fork(),e.identityKey!=null&&e.identityKey.byteLength>0&&(n.uint32(10),n.bytes(e.identityKey)),e.identitySig!=null&&e.identitySig.byteLength>0&&(n.uint32(18),n.bytes(e.identitySig)),e.extensions!=null&&(n.uint32(34),js.codec().encode(e.extensions,n)),s.lengthDelimited!==!1&&n.ldelim()},(e,n)=>{let s={identityKey:mt(0),identitySig:mt(0)},o=n==null?e.len:e.pos+n;for(;e.pos<o;){let i=e.uint32();switch(i>>>3){case 1:{s.identityKey=e.bytes();break}case 2:{s.identitySig=e.bytes();break}case 4:{s.extensions=js.codec().decode(e,e.uint32());break}default:{e.skipType(i&7);break}}}return s})),t),r.encode=e=>Qe(e,r.codec()),r.decode=e=>Xe(e,r.codec())})(bn||(bn={}));async function sa(r,t,e){let n=await r.sign(Lu(t));return bn.encode({identityKey:r.public.bytes,identitySig:n,extensions:e})}async function oa(r,t,e){try{let n=bn.decode(r);if(e){let i=e.subarray();if(!ft(i,n.identityKey))throw new Error(`Payload identity key ${q(n.identityKey,"hex")} does not match expected remote identity key ${q(i,"hex")}`)}if(!t)throw new Error("Remote static does not exist");let s=Lu(t);if(!await Zl(n.identityKey).verify(s,n.identitySig))throw new Error("Invalid payload signature");return n}catch(n){throw new qs(n.message)}}function Lu(r){let t=et("noise-libp2p-static-key:");return r instanceof Uint8Array?xt([t,r],t.length+r.length):(r.prepend(t),r)}async function Cu(r){let{log:t,connection:e,crypto:n,privateKey:s,prologue:o,s:i,remoteIdentityKey:a,extensions:c}=r,l=await sa(s,i.publicKey,c),u=new wn({crypto:n,protocolName:"Noise_XX_25519_ChaChaPoly_SHA256",initiator:!0,prologue:o,s:i});Ji(u.s,t),t.trace("Stage 0 - Initiator starting to send first message."),await e.write(u.writeMessageA(cr)),t.trace("Stage 0 - Initiator finished sending first message."),Qi(u.e,t),t.trace("Stage 1 - Initiator waiting to receive first message from responder...");let f=u.readMessageB(await e.read());t.trace("Stage 1 - Initiator received the message."),ta(u.re,t),Ru(u.rs,t),t.trace("Initiator going to check remote's signature...");let g=await oa(f,u.rs,a);t.trace("All good with the signature!"),t.trace("Stage 2 - Initiator sending third handshake message."),await e.write(u.writeMessageC(l)),t.trace("Stage 2 - Initiator sent message with signed payload.");let[m,d]=u.ss.split();return ea(m,d,t),{payload:g,encrypt:h=>m.encryptWithAd(cr,h),decrypt:(h,p)=>d.decryptWithAd(cr,h,p)}}async function Uu(r){let{log:t,connection:e,crypto:n,privateKey:s,prologue:o,s:i,remoteIdentityKey:a,extensions:c}=r,l=await sa(s,i.publicKey,c),u=new wn({crypto:n,protocolName:"Noise_XX_25519_ChaChaPoly_SHA256",initiator:!1,prologue:o,s:i});Ji(u.s,t),t.trace("Stage 0 - Responder waiting to receive first message."),u.readMessageA(await e.read()),t.trace("Stage 0 - Responder received first message."),ta(u.re,t),t.trace("Stage 1 - Responder sending out first message with signed payload and static key."),await e.write(u.writeMessageB(l)),t.trace("Stage 1 - Responder sent the second handshake message with signed payload."),Qi(u.e,t),t.trace("Stage 2 - Responder waiting for third handshake message...");let f=u.readMessageC(await e.read());t.trace("Stage 2 - Responder received the message, finished handshake.");let g=await oa(f,u.rs,a),[m,d]=u.ss.split();return ea(m,d,t),{payload:g,encrypt:h=>d.encryptWithAd(cr,h),decrypt:(h,p)=>m.decryptWithAd(cr,h,p)}}var Du=16;function Vu(r,t){return async function*(e){for await(let n of e)for(let s=0;s<n.length;s+=65519){let o=s+65519;o>n.length&&(o=n.length);let i;n instanceof Uint8Array?i=r.encrypt(n.subarray(s,o)):i=r.encrypt(n.sublist(s,o)),t?.encryptedPackets.increment(),yield new lt(Vr(i.byteLength),i)}}}function Ou(r,t){return async function*(e){for await(let n of e)for(let s=0;s<n.length;s+=65535){let o=s+65535;if(o>n.length&&(o=n.length),o-Du<s)throw new Error("Invalid chunk");let i=n.sublist(s,o),a=n.subarray(s,o-Du);try{let c=r.decrypt(i,a);t?.decryptedPackets.increment(),yield c}catch(c){throw t?.decryptErrors.increment(),c}}}}var zs=class{protocol="/noise";crypto;prologue;staticKey;extensions;metrics;components;constructor(t,e={}){let{staticNoiseKey:n,extensions:s,crypto:o,prologueBytes:i}=e,{metrics:a}=t;this.components=t;let c=o??_u;this.crypto=Nu(c),this.extensions=s,this.metrics=a?Tu(a):void 0,n?this.staticKey=c.generateX25519KeyPairFromSeed(n):this.staticKey=c.generateX25519KeyPair(),this.prologue=i??mt(0)}async secureOutbound(t,e,n){let s=Oi(e,{lengthEncoder:Vr,lengthDecoder:mn,maxDataLength:65535});if(!t.privateKey)throw new F("local peerId does not contain private key","ERR_NO_PRIVATE_KEY");let o=await Ti(t.privateKey),i=n?.publicKey,a=await this.performHandshakeInitiator(s,o,i),c=await this.createSecureConnection(s,a);return e.source=c.source,e.sink=c.sink,{conn:e,remoteExtensions:a.payload.extensions,remotePeer:await Ui(a.payload.identityKey)}}async secureInbound(t,e,n){let s=Oi(e,{lengthEncoder:Vr,lengthDecoder:mn,maxDataLength:65535});if(!t.privateKey)throw new F("local peerId does not contain private key","ERR_NO_PRIVATE_KEY");let o=await Ti(t.privateKey),i=n?.publicKey,a=await this.performHandshakeResponder(s,o,i),c=await this.createSecureConnection(s,a);return e.source=c.source,e.sink=c.sink,{conn:e,remoteExtensions:a.payload.extensions,remotePeer:await Ui(a.payload.identityKey)}}async performHandshakeInitiator(t,e,n){let s;try{s=await Cu({connection:t,privateKey:e,remoteIdentityKey:n,log:this.components.logger.forComponent("libp2p:noise:xxhandshake"),crypto:this.crypto,prologue:this.prologue,s:this.staticKey,extensions:this.extensions}),this.metrics?.xxHandshakeSuccesses.increment()}catch(o){throw this.metrics?.xxHandshakeErrors.increment(),o}return s}async performHandshakeResponder(t,e,n){let s;try{s=await Uu({connection:t,privateKey:e,remoteIdentityKey:n,log:this.components.logger.forComponent("libp2p:noise:xxhandshake"),crypto:this.crypto,prologue:this.prologue,s:this.staticKey,extensions:this.extensions}),this.metrics?.xxHandshakeSuccesses.increment()}catch(o){throw this.metrics?.xxHandshakeErrors.increment(),o}return s}async createSecureConnection(t,e){let[n,s]=cu(),o=t.unwrap();return await uu(n,Vu(e,this.metrics),o,i=>yn(i,{lengthDecoder:mn}),Ou(e,this.metrics),n),s}};function Hu(r={}){return t=>new zs(t,r)}var Ws=class{index=0;input="";new(t){return this.index=0,this.input=t,this}readAtomically(t){let e=this.index,n=t();return n===void 0&&(this.index=e),n}parseWith(t){let e=t();if(this.index===this.input.length)return e}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 e=this.readChar();if(e===t)return e})}readSeparator(t,e,n){return this.readAtomically(()=>{if(!(e>0&&this.readGivenChar(t)===void 0))return n()})}readNumber(t,e,n,s){return this.readAtomically(()=>{let o=0,i=0,a=this.peekChar();if(a===void 0)return;let c=a==="0",l=2**(8*s)-1;for(;;){let u=this.readAtomically(()=>{let f=this.readChar();if(f===void 0)return;let g=Number.parseInt(f,t);if(!Number.isNaN(g))return g});if(u===void 0)break;if(o*=t,o+=u,o>l||(i+=1,e!==void 0&&i>e))return}if(i!==0)return!n&&c&&i>1?void 0:o})}readIPv4Addr(){return this.readAtomically(()=>{let t=new Uint8Array(4);for(let e=0;e<t.length;e++){let n=this.readSeparator(".",e,()=>this.readNumber(10,3,!1,1));if(n===void 0)return;t[e]=n}return t})}readIPv6Addr(){let t=e=>{for(let n=0;n<e.length/2;n++){let s=n*2;if(n<e.length-3){let i=this.readSeparator(":",n,()=>this.readIPv4Addr());if(i!==void 0)return e[s]=i[0],e[s+1]=i[1],e[s+2]=i[2],e[s+3]=i[3],[s+4,!0]}let o=this.readSeparator(":",n,()=>this.readNumber(16,4,!0,2));if(o===void 0)return[s,!1];e[s]=o>>8,e[s+1]=o&255}return[e.length,!1]};return this.readAtomically(()=>{let e=new Uint8Array(16),[n,s]=t(e);if(n===16)return e;if(s||this.readGivenChar(":")===void 0||this.readGivenChar(":")===void 0)return;let o=new Uint8Array(14),i=16-(n+2),[a]=t(o.subarray(0,i));return e.set(o.subarray(0,a),16-a),e})}readIPAddr(){return this.readIPv4Addr()??this.readIPv6Addr()}};var Mu=45,pp=15,Mr=new Ws;function ia(r){if(!(r.length>pp))return Mr.new(r).parseWith(()=>Mr.readIPv4Addr())}function aa(r){if(r.includes("%")&&(r=r.split("%")[0]),!(r.length>Mu))return Mr.new(r).parseWith(()=>Mr.readIPv6Addr())}function Ys(r){if(r.includes("%")&&(r=r.split("%")[0]),!(r.length>Mu))return Mr.new(r).parseWith(()=>Mr.readIPAddr())}var Rx=parseInt("0xFFFF",16),Lx=new Uint8Array([0,0,0,0,0,0,0,0,0,0,255,255]);function Zs(r){return!!ia(r)}function Xs(r){return!!aa(r)}function Js(r){return!!Ys(r)}var $u=Zs,bp=Xs,ca=function(r){let t=0;if(r=r.toString().trim(),$u(r)){let e=new Uint8Array(t+4);return r.split(/\./g).forEach(n=>{e[t++]=parseInt(n,10)&255}),e}if(bp(r)){let e=r.split(":",8),n;for(n=0;n<e.length;n++){let o=$u(e[n]),i;o&&(i=ca(e[n]),e[n]=q(i.slice(0,2),"base16")),i!=null&&++n<8&&e.splice(n,0,q(i.slice(2,4),"base16"))}if(e[0]==="")for(;e.length<8;)e.unshift("0");else if(e[e.length-1]==="")for(;e.length<8;)e.push("0");else if(e.length<8){for(n=0;n<e.length&&e[n]!=="";n++);let o=[n,1];for(n=9-e.length;n>0;n--)o.push("0");e.splice.apply(e,o)}let s=new Uint8Array(t+16);for(n=0;n<e.length;n++){let o=parseInt(e[n],16);s[t++]=o>>8&255,s[t++]=o&255}return s}throw new Error("invalid ip address")},qu=function(r,t=0,e){t=~~t,e=e??r.length-t;let n=new DataView(r.buffer);if(e===4){let s=[];for(let o=0;o<e;o++)s.push(r[t+o]);return s.join(".")}if(e===16){let s=[];for(let o=0;o<e;o+=2)s.push(n.getUint16(t+o).toString(16));return s.join(":").replace(/(^|:)0(:0)*:0(:|$)/,"$1::$3").replace(/:{3,4}/,"::")}return""};var Kr={},la={},Ep=[[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"]];Ep.forEach(r=>{let t=vp(...r);la[t.code]=t,Kr[t.name]=t});function vp(r,t,e,n,s){return{code:r,size:t,name:e,resolvable:!!n,path:!!s}}function Q(r){if(typeof r=="number"){if(la[r]!=null)return la[r];throw new Error(`no protocol with code: ${r}`)}else if(typeof r=="string"){if(Kr[r]!=null)return Kr[r];throw new Error(`no protocol with name: ${r}`)}throw new Error(`invalid protocol id type: ${typeof r}`)}var g2=Q("ip4"),y2=Q("ip6"),m2=Q("ipcidr");function fa(r,t){switch(Q(r).code){case 4:case 41:return Ap(t);case 42:return zu(t);case 6:case 273:case 33:case 132:return Yu(t).toString();case 53:case 54:case 55:case 56:case 400:case 449:case 777:return zu(t);case 421:return _p(t);case 444:return Wu(t);case 445:return Wu(t);case 466:return Ip(t);default:return q(t,"base16")}}function ha(r,t){switch(Q(r).code){case 4:return Gu(t);case 41:return Gu(t);case 42:return ju(t);case 6:case 273:case 33:case 132:return da(parseInt(t,10));case 53:case 54:case 55:case 56:case 400:case 449:case 777:return ju(t);case 421:return Sp(t);case 444:return Np(t);case 445:return Tp(t);case 466:return kp(t);default:return et(t,"base16")}}var ua=Object.values(re).map(r=>r.decoder),Bp=function(){let r=ua[0].or(ua[1]);return ua.slice(2).forEach(t=>r=r.or(t)),r}();function Gu(r){if(!Js(r))throw new Error("invalid ip address");return ca(r)}function Ap(r){let t=qu(r,0,r.length);if(t==null)throw new Error("ipBuff is required");if(!Js(t))throw new Error("invalid ip address");return t}function da(r){let t=new ArrayBuffer(2);return new DataView(t).setUint16(0,r),new Uint8Array(t)}function Yu(r){return new DataView(r.buffer).getUint16(r.byteOffset)}function ju(r){let t=et(r),e=Uint8Array.from(ne(t.length));return xt([e,t],e.length+t.length)}function zu(r){let t=Yt(r);if(r=r.slice(dt(t)),r.length!==t)throw new Error("inconsistent lengths");return q(r)}function Sp(r){let t;r[0]==="Q"||r[0]==="1"?t=Ne(ut.decode(`z${r}`)).bytes:t=qt.parse(r).multihash.bytes;let e=Uint8Array.from(ne(t.length));return xt([e,t],e.length+t.length)}function kp(r){let t=Bp.decode(r),e=Uint8Array.from(ne(t.length));return xt([e,t],e.length+t.length)}function Ip(r){let t=Yt(r),e=r.slice(dt(t));if(e.length!==t)throw new Error("inconsistent lengths");return"u"+q(e,"base64url")}function _p(r){let t=Yt(r),e=r.slice(dt(t));if(e.length!==t)throw new Error("inconsistent lengths");return q(e,"base58btc")}function Np(r){let t=r.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 e=he.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 s=da(n);return xt([e,s],e.length+s.length)}function Tp(r){let t=r.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 e=he.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 s=da(n);return xt([e,s],e.length+s.length)}function Wu(r){let t=r.slice(0,r.length-2),e=r.slice(r.length-2),n=q(t,"base32"),s=Yu(e);return`${n}:${s}`}function Zu(r){r=pa(r);let t=[],e=[],n=null,s=r.split("/").slice(1);if(s.length===1&&s[0]==="")return{bytes:new Uint8Array,string:"/",tuples:[],stringTuples:[],path:null};for(let o=0;o<s.length;o++){let i=s[o],a=Q(i);if(a.size===0){t.push([a.code]),e.push([a.code]);continue}if(o++,o>=s.length)throw Ju("invalid address: "+r);if(a.path===!0){n=pa(s.slice(o).join("/")),t.push([a.code,ha(a.code,n)]),e.push([a.code,n]);break}let c=ha(a.code,s[o]);t.push([a.code,c]),e.push([a.code,fa(a.code,c)])}return{string:Xu(e),bytes:ya(t),tuples:t,stringTuples:e,path:n}}function ga(r){let t=[],e=[],n=null,s=0;for(;s<r.length;){let o=Yt(r,s),i=dt(o),a=Q(o),c=Rp(a,r.slice(s+i));if(c===0){t.push([o]),e.push([o]),s+=i;continue}let l=r.slice(s+i,s+i+c);if(s+=c+i,s>r.length)throw Ju("Invalid address Uint8Array: "+q(r,"base16"));t.push([o,l]);let u=fa(o,l);if(e.push([o,u]),a.path===!0){n=u;break}}return{bytes:Uint8Array.from(r),string:Xu(e),tuples:t,stringTuples:e,path:n}}function Xu(r){let t=[];return r.map(e=>{let n=Q(e[0]);return t.push(n.name),e.length>1&&e[1]!=null&&t.push(e[1]),null}),pa(t.join("/"))}function ya(r){return xt(r.map(t=>{let e=Q(t[0]),n=Uint8Array.from(ne(e.code));return t.length>1&&t[1]!=null&&(n=xt([n,t[1]])),n}))}function Rp(r,t){if(r.size>0)return r.size/8;if(r.size===0)return 0;{let e=Yt(t instanceof Uint8Array?t:Uint8Array.from(t));return e+dt(e)}}function pa(r){return"/"+r.trim().split("/").filter(t=>t).join("/")}function Ju(r){return new Error("Error parsing address: "+r)}var Lp=Symbol.for("nodejs.util.inspect.custom"),ma=Symbol.for("@multiformats/js-multiaddr/multiaddr"),Cp=[Q("dns").code,Q("dns4").code,Q("dns6").code,Q("dnsaddr").code],Qs=class r{bytes;#e;#t;#r;#n;[ma]=!0;constructor(t){t==null&&(t="");let e;if(t instanceof Uint8Array)e=ga(t);else if(typeof t=="string"){if(t.length>0&&t.charAt(0)!=="/")throw new Error(`multiaddr "${t}" must start with a "/"`);e=Zu(t)}else if(tf(t))e=ga(t.bytes);else throw new Error("addr must be a string, Buffer, or another Multiaddr");this.bytes=e.bytes,this.#e=e.string,this.#t=e.tuples,this.#r=e.stringTuples,this.#n=e.path}toString(){return this.#e}toJSON(){return this.toString()}toOptions(){let t,e,n,s,o="",i=Q("tcp"),a=Q("udp"),c=Q("ip4"),l=Q("ip6"),u=Q("dns6"),f=Q("ip6zone");for(let[m,d]of this.stringTuples())m===f.code&&(o=`%${d??""}`),Cp.includes(m)&&(e=i.name,s=443,n=`${d??""}${o}`,t=m===u.code?6:4),(m===i.code||m===a.code)&&(e=Q(m).name,s=parseInt(d??"")),(m===c.code||m===l.code)&&(e=Q(m).name,n=`${d??""}${o}`,t=m===l.code?6:4);if(t==null||e==null||n==null||s==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:e,port:s}}protos(){return this.#t.map(([t])=>Object.assign({},Q(t)))}protoCodes(){return this.#t.map(([t])=>t)}protoNames(){return this.#t.map(([t])=>Q(t).name)}tuples(){return this.#t}stringTuples(){return this.#r}encapsulate(t){return t=new r(t),new r(this.toString()+t.toString())}decapsulate(t){let e=t.toString(),n=this.toString(),s=n.lastIndexOf(e);if(s<0)throw new Error(`Address ${this.toString()} does not contain subaddress: ${t.toString()}`);return new r(n.slice(0,s))}decapsulateCode(t){let e=this.tuples();for(let n=e.length-1;n>=0;n--)if(e[n][0]===t)return new r(ya(e.slice(0,n)));return this}getPeerId(){try{let t=[];this.stringTuples().forEach(([n,s])=>{n===Kr.p2p.code&&t.push([n,s]),n===Kr["p2p-circuit"].code&&(t=[])});let e=t.pop();if(e?.[1]!=null){let n=e[1];return n[0]==="Q"||n[0]==="1"?q(ut.decode(`z${n}`),"base58btc"):q(qt.parse(n).multihash.bytes,"base58btc")}return null}catch{return null}}getPath(){return this.#n}equals(t){return ft(this.bytes,t.bytes)}async resolve(t){let e=this.protos().find(o=>o.resolvable);if(e==null)return[this];let n=Qu.get(e.name);if(n==null)throw new F(`no available resolver for ${e.name}`,"ERR_NO_AVAILABLE_RESOLVER");return(await n(this,t)).map(o=>wa(o))}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 e=(t??this).protos();return!(e.length!==2||e[0].code!==4&&e[0].code!==41||e[1].code!==6&&e[1].code!==273)}[Lp](){return`Multiaddr(${this.#e})`}};var Qu=new Map;function tf(r){return!!r?.[ma]}function wa(r){return new Qs(r)}var Up=r=>r.toString().split("/").slice(1),En=r=>({match:t=>t.length<1?!1:r(t[0])?t.slice(1):!1,pattern:"fn"}),X=r=>({match:t=>En(e=>e===r).match(t),pattern:r}),ro=()=>({match:r=>En(t=>typeof t=="string").match(r),pattern:"{string}"}),no=()=>({match:r=>En(t=>!isNaN(parseInt(t))).match(r),pattern:"{number}"}),It=()=>({match:r=>{if(r.length<2||r[0]!=="p2p"&&r[0]!=="ipfs")return!1;if(r[1].startsWith("Q")||r[1].startsWith("1"))try{ut.decode(`z${r[1]}`)}catch{return!1}else return!1;return r.slice(2)},pattern:"/p2p/{peerid}"}),to=()=>({match:r=>{if(r.length<2||r[0]!=="certhash")return!1;try{Io.decode(r[1])}catch{return!1}return r.slice(2)},pattern:"/certhash/{certhash}"}),_t=r=>({match:t=>{let e=r.match(t);return e===!1?t:e},pattern:`optional(${r.pattern})`}),Ot=(...r)=>({match:t=>{let e;for(let n of r){let s=n.match(t);s!==!1&&(e==null||s.length<e.length)&&(e=s)}return e??!1},pattern:`or(${r.map(t=>t.pattern).join(", ")})`}),rt=(...r)=>({match:t=>{for(let e of r){let n=e.match(t);if(n===!1)return!1;t=n}return t},pattern:`and(${r.map(t=>t.pattern).join(", ")})`});function ht(...r){function t(s){let o=Up(s);for(let i of r){let a=i.match(o);if(a===!1)return!1;o=a}return o}function e(s){return t(s)!==!1}function n(s){let o=t(s);return o===!1?!1:o.length===0}return{matches:e,exactMatch:n}}var xa=rt(X("dns4"),ro()),Ea=rt(X("dns6"),ro()),va=rt(X("dnsaddr"),ro()),ef=rt(X("dns"),ro()),j2=ht(xa),z2=ht(Ea),W2=ht(va),Y2=ht(Ot(ef,va,xa,Ea)),rf=rt(X("ip4"),En(Zs)),nf=rt(X("ip6"),En(Xs)),sf=Ot(rf,nf),le=Ot(sf,ef,xa,Ea,va),Z2=ht(le),X2=ht(rf),J2=ht(nf),Q2=ht(sf),so=rt(le,X("tcp"),no()),vn=rt(le,X("udp"),no()),Pp=Ot(so,vn),tE=ht(so),eE=ht(vn),Ba=rt(vn,X("quic")),oo=rt(vn,X("quic-v1")),Dp=Ot(Ba,oo),rE=ht(Ba),nE=ht(oo),ba=Ot(le,so,vn,Ba,oo),of=Ot(rt(ba,X("ws"),_t(It()))),sE=ht(of),af=Ot(rt(ba,X("wss"),_t(It())),rt(ba,X("tls"),X("ws"),_t(It()))),oE=ht(af),cf=rt(Pp,X("webrtc-direct"),to(),_t(to()),_t(It())),iE=ht(cf),lf=rt(oo,X("webtransport"),_t(to()),_t(to()),_t(It())),io=ht(lf),eo=Ot(of,af,rt(so,_t(It())),rt(Dp,_t(It())),rt(le,_t(It())),cf,lf,It()),aE=ht(eo),Vp=rt(eo,X("p2p-circuit"),It()),cE=ht(Vp),Op=Ot(rt(eo,X("p2p-circuit"),X("webrtc"),It()),rt(eo,X("webrtc"),_t(It())),X("webrtc")),lE=ht(Op),Hp=Ot(rt(le,X("tcp"),no(),X("http"),_t(It())),rt(le,X("http"),_t(It()))),uE=ht(Hp),Mp=Ot(rt(le,X("tcp"),Ot(rt(X("443"),X("http")),rt(no(),X("https"))),_t(It())),rt(le,X("tls"),X("http"),_t(It())),rt(le,X("https"),_t(It()))),fE=ht(Mp);async function Aa(r,t,e,n,s,o){let i=o.forComponent(`libp2p:webtransport:stream:${e}:${t}`),a=r.writable.getWriter(),c=r.readable.getReader();await a.ready;function l(){let d=n.findIndex(h=>h===m);d!==-1&&(n.splice(d,1),m.timeline.close=Date.now(),s?.(m))}let u=!1,f=!1;(async function(){let d=await a.closed.catch(h=>h);if(d!=null){let h=d.message;h.includes("aborted by the remote server")||h.includes("STOP_SENDING")||i.error(`WebTransport writer closed unexpectedly: streamId=${t} err=${d.message}`)}u=!0,u&&f&&l()})().catch(()=>{i.error("WebTransport failed to cleanup closed stream")}),async function(){let d=await c.closed.catch(h=>h);d!=null&&i.error(`WebTransport reader closed unexpectedly: streamId=${t} err=${d.message}`),f=!0,u&&f&&l()}().catch(()=>{i.error("WebTransport failed to cleanup closed stream")});let g=!1,m={id:t,status:"open",writeStatus:"ready",readStatus:"ready",abort(d){u||(a.abort(d).catch(h=>{i.error("could not abort stream",h)}),u=!0),f=!0,this.status="aborted",this.writeStatus="closed",this.readStatus="closed",this.timeline.reset=this.timeline.close=this.timeline.closeRead=this.timeline.closeWrite=Date.now(),l()},async close(d){this.status="closing",await Promise.all([m.closeRead(d),m.closeWrite(d)]),l(),this.status="closed",this.timeline.close=Date.now()},async closeRead(d){if(!f){this.readStatus="closing";try{await c.cancel()}catch(h){h.toString().includes("RESET_STREAM")===!0&&(u=!0)}this.timeline.closeRead=Date.now(),this.readStatus="closed",f=!0}u&&l()},async closeWrite(d){if(!u){u=!0,this.writeStatus="closing";try{await a.close()}catch(h){h.toString().includes("RESET_STREAM")===!0&&(f=!0)}this.timeline.closeWrite=Date.now(),this.writeStatus="closed"}f&&l()},direction:e,timeline:{open:Date.now()},metadata:{},source:async function*(){for(;;){let d=await c.read();if(d.done){f=!0,u&&l();return}yield new lt(d.value)}}(),sink:async function(d){if(g)throw new Error("sink already called on stream");g=!0;try{this.writeStatus="writing";for await(let h of d)if(h instanceof Uint8Array)await a.write(h);else for(let p of h)await a.write(p);this.writeStatus="done"}finally{this.timeline.closeWrite=Date.now(),this.writeStatus="closed",await m.closeWrite()}},log:i};return m}function Sa(){return{source:{[Symbol.asyncIterator](){return{async next(){return new Promise(()=>{})}}}},sink:async r=>new Promise(()=>{})}}function uf(r,t){return t.filter(n=>!!r.find(s=>ft(n,s))).length===t.length}var Kp=Object.values(re).map(r=>r.decoder).reduce((r,t)=>r.or(t));function Fp(r){return ee.decode(Kp.decode(r))}function ka(r){if(!io.matches(r))throw new F("Invalid multiaddr, was not a WebTransport address","ERR_INVALID_MULTIADDR");let t=r.stringTuples(),e=t.filter(([i,a])=>i===Q("certhash").code).map(([i,a])=>Fp(a??"")),n=t.filter(([i,a])=>i===Q("p2p").code).map(([i,a])=>Ci(a??""))[0],s=r.toOptions(),o=s.host;return s.family===6&&o?.includes(":")&&(o=`[${o}]`),{url:`https://${o}:${s.port}`,certhashes:e,remotePeer:n}}var Ia=class{log;components;config;metrics;constructor(t,e={}){this.log=t.logger.forComponent("libp2p:webtransport"),this.components=t,this.config={maxInboundStreams:e.maxInboundStreams??1e3},t.metrics!=null&&(this.metrics={dialerEvents:t.metrics.registerCounterGroup("libp2p_webtransport_dialer_events_total",{label:"event",help:"Total count of WebTransport dialer events by type"})})}[Symbol.toStringTag]="@libp2p/webtransport";[Ka]=!0;async dial(t,e){e?.signal?.throwIfAborted(),this.log("dialing %s",t);let n=this.components.peerId;if(n===void 0)throw new Error("Need a local peerid");e=e??{};let{url:s,certhashes:o,remotePeer:i}=ka(t);if(i==null)throw new Error("Need a target peerid");if(o.length===0)throw new Error("Expected multiaddr to contain certhashes");let a,c,l=()=>{},u=!1,f=!1,g=!1;try{this.metrics?.dialerEvents.increment({pending:!0});let m=new WebTransport(`${s}/.well-known/libp2p-webtransport?type=noise`,{serverCertificateHashes:o.map(d=>({algorithm:"sha-256",value:d.digest}))});if(l=d=>{if(!u)try{this.metrics?.dialerEvents.increment({[d]:!0}),m.close()}catch(h){this.log.error("error closing wt session",h)}finally{c!=null&&(c.timeline.close=Date.now()),u=!0}},a=()=>{l(f?"noise_timeout":"ready_timeout")},e.signal?.addEventListener("abort",a,{once:!0}),await Promise.race([m.closed,m.ready]),f=!0,this.metrics?.dialerEvents.increment({ready:!0}),m.closed.catch(d=>{this.log.error("error on remote wt session close",d)}).finally(()=>{l("remote_close")}),!await this.authenticateWebTransport(m,n,i,o))throw new Error("Failed to authenticate webtransport");return this.metrics?.dialerEvents.increment({open:!0}),c={close:async()=>{this.log("Closing webtransport"),l("close")},abort:d=>{this.log("aborting webtransport due to passed err",d),l("abort")},remoteAddr:t,timeline:{open:Date.now()},log:this.components.logger.forComponent("libp2p:webtransport:maconn"),...Sa()},g=!0,await e.upgrader.upgradeOutbound(c,{skipEncryption:!0,muxerFactory:this.webtransportMuxer(m),skipProtection:!0})}catch(m){throw this.log.error("caught wt session err",m),l(g?"upgrade_error":f?"noise_error":"ready_error"),m}finally{a!=null&&e.signal?.removeEventListener("abort",a)}}async authenticateWebTransport(t,e,n,s){let o=await t.createBidirectionalStream(),i=o.writable.getWriter(),a=o.readable.getReader();await i.ready;let c={source:async function*(){for(;;){let f=await a.read();if(f.value!=null&&(yield f.value),f.done)break}}(),sink:async function(f){for await(let g of f)g instanceof Uint8Array?await i.write(g):await i.write(g.subarray())}},l=Hu()(this.components),{remoteExtensions:u}=await l.secureOutbound(e,c,n);if(i.close().catch(f=>{this.log.error(`Failed to close authentication stream writer: ${f.message}`)}),a.cancel().catch(f=>{this.log.error(`Failed to close authentication stream reader: ${f.message}`)}),!uf(u?.webtransportCerthashes??[],s.map(f=>f.bytes)))throw new Error("Our certhashes are not a subset of the remote's reported certhashes");return!0}webtransportMuxer(t){let e=0,n=this.config,s=this;return{protocol:"webtransport",createStreamMuxer:o=>{typeof o=="function"&&(o={onIncomingStream:o});let i=[];return async function(){let c=t.incomingBidirectionalStreams.getReader();for(;;){let{done:l,value:u}=await c.read();if(l)break;if(i.length>=n.maxInboundStreams)u.writable.close().catch(f=>{s.log.error(`Failed to close inbound stream that crossed our maxInboundStream limit: ${f.message}`)}),u.readable.cancel().catch(f=>{s.log.error(`Failed to close inbound stream that crossed our maxInboundStream limit: ${f.message}`)});else{let f=await Aa(u,String(e++),"inbound",i,o?.onStreamEnd,s.components.logger);i.push(f),o?.onIncomingStream?.(f)}}}().catch(()=>{this.log.error("WebTransport failed to receive incoming stream")}),{protocol:"webtransport",streams:i,newStream:async c=>{let l=await t.createBidirectionalStream(),u=await Aa(l,String(e++),o?.direction??"outbound",i,o?.onStreamEnd,s.components.logger);return i.push(u),u},close:async c=>{this.log("Closing webtransport muxer"),await Promise.all(i.map(async l=>l.close(c)))},abort:c=>{this.log("Aborting webtransport muxer with err:",c);for(let l of i)l.abort(c)},...Sa()}}}}createListener(t){throw new Error("Webtransport servers are not supported in Node or the browser")}listenFilter(){return[]}dialFilter(t){return t.filter(e=>{if(!io.exactMatch(e))return!1;let{url:n,certhashes:s,remotePeer:o}=ka(e);return n!=null&&o!=null&&s.length>0})}};function $p(r={}){return t=>new Ia(t,r)}return Af(qp);})();
8
8
  //! TODO unclear how to add backpressure here?
9
9
  /*! Bundled license information:
10
10