@libp2p/webtransport 4.1.2-a8ec2bcb7 → 4.1.3-944935f8d
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 +2 -2
- package/package.json +9 -9
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 _f=Object.create;var An=Object.defineProperty;var Nf=Object.getOwnPropertyDescriptor;var Tf=Object.getOwnPropertyNames;var Rf=Object.getPrototypeOf,Lf=Object.prototype.hasOwnProperty;var $a=(r,t)=>()=>(t||r((t={exports:{}}).exports,t),t.exports),mt=(r,t)=>{for(var e in t)An(r,e,{get:t[e],enumerable:!0})},qa=(r,t,e,n)=>{if(t&&typeof t=="object"||typeof t=="function")for(let s of Tf(t))!Lf.call(r,s)&&s!==e&&An(r,s,{get:()=>t[s],enumerable:!(n=Nf(t,s))||n.enumerable});return r};var Ga=(r,t,e)=>(e=r!=null?_f(Rf(r)):{},qa(t||!r||!r.__esModule?An(e,"default",{value:r,enumerable:!0}):e,r)),Cf=r=>qa(An({},"__esModule",{value:!0}),r);var Zc=$a(Ar=>{"use strict";var lp="[object ArrayBuffer]",ve=class r{static isArrayBuffer(t){return Object.prototype.toString.call(t)===lp}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}},gi="string",up=/^[0-9a-f]+$/i,fp=/^(?:[A-Za-z0-9+/]{4})*(?:[A-Za-z0-9+/]{2}==|[A-Za-z0-9+/]{3}=)?$/,hp=/^[a-zA-Z0-9-_]+$/,qn=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=ve.toUint8Array(t),n="";for(let o=0;o<e.length;o++)n+=String.fromCharCode(e[o]);return decodeURIComponent(escape(n))}},qt=class{static toString(t,e=!1){let n=ve.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}},Gn=class r{static isHex(t){return typeof t===gi&&up.test(t)}static isBase64(t){return typeof t===gi&&fp.test(t)}static isBase64Url(t){return typeof t===gi&&hp.test(t)}static ToString(t,e="utf8"){let n=ve.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 qt.toString(n,!0);case"utf16":case"utf16be":return qt.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 qt.fromString(t,!0);case"utf16":case"utf16be":return qt.fromString(t);default:throw new Error(`Unknown type of encoding '${e}'`)}}static ToBase64(t){let e=ve.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 qn.fromString(t);case"utf16":case"utf16be":return qt.fromString(t);case"utf16le":case"usc2":return qt.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 qn.toString(t);case"utf16":case"utf16be":return qt.toString(t);case"utf16le":case"usc2":return qt.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=ve.toUint8Array(t),n="";for(let s=0;s<e.length;s++)n+=String.fromCharCode(e[s]);return n}static ToHex(t){let e=ve.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 qt.toString(t,e)}static FromUtf16String(t,e=!1){return qt.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,"")||""}};Gn.DEFAULT_UTF8_ENCODING="utf8";function dp(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 pp(...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 gp(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=ve;Ar.Convert=Gn;Ar.assign=dp;Ar.combine=pp;Ar.isEqual=gp});var uu=$a((Nb,lu)=>{"use strict";function cu(r,t){for(let e in t)Object.defineProperty(r,e,{value:t[e],enumerable:!0,configurable:!0});return r}function Zp(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 cu(r,e)}catch{e.message=r.message,e.stack=r.stack;let s=function(){};return s.prototype=Object.create(Object.getPrototypeOf(r)),cu(new s,e)}}lu.exports=Zp});var Q0={};mt(Q0,{webTransport:()=>J0});var co=Symbol.for("@libp2p/peer-id");var za=Symbol.for("@libp2p/transport");var ja;(function(r){r[r.FATAL_ALL=0]="FATAL_ALL",r[r.NO_FATAL=1]="NO_FATAL"})(ja||(ja={}));var Sn=class r extends Error{code;type;constructor(t="The operation was aborted"){super(t),this.name="AbortError",this.code=r.code,this.type=r.type}static code="ABORT_ERR";static type="aborted"},M=class extends Error{code;props;constructor(t,e,n){super(t),this.code=e,this.name=n?.name??"CodeError",this.props=n??{}}};var kn=Symbol.for("@libp2p/service-capabilities"),sg=Symbol.for("@libp2p/service-dependencies");var di={};mt(di,{Ed25519PrivateKey:()=>rr,Ed25519PublicKey:()=>en,generateKeyPair:()=>ip,generateKeyPairFromSeed:()=>Yc,unmarshalEd25519PrivateKey:()=>sp,unmarshalEd25519PublicKey:()=>op});var po={};mt(po,{base58btc:()=>ut,base58flickr:()=>Of});var _g=new Uint8Array(0);function Wa(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 de(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 Ya(r){return new TextEncoder().encode(r)}function Za(r){return new TextDecoder().decode(r)}function Uf(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(p){if(p instanceof Uint8Array||(ArrayBuffer.isView(p)?p=new Uint8Array(p.buffer,p.byteOffset,p.byteLength):Array.isArray(p)&&(p=Uint8Array.from(p))),!(p instanceof Uint8Array))throw new TypeError("Expected Uint8Array");if(p.length===0)return"";for(var h=0,d=0,b=0,v=p.length;b!==v&&p[b]===0;)b++,h++;for(var w=(v-b)*u+1>>>0,A=new Uint8Array(w);b!==v;){for(var B=p[b],S=0,N=w-1;(B!==0||S<d)&&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");d=S,b++}for(var _=w-d;_!==w&&A[_]===0;)_++;for(var V=c.repeat(h);_<w;++_)V+=r.charAt(A[_]);return V}function g(p){if(typeof p!="string")throw new TypeError("Expected String");if(p.length===0)return new Uint8Array;var h=0;if(p[h]!==" "){for(var d=0,b=0;p[h]===c;)d++,h++;for(var v=(p.length-h)*l+1>>>0,w=new Uint8Array(v);p[h];){var A=e[p.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(p[h]!==" "){for(var N=v-b;N!==v&&w[N]===0;)N++;for(var _=new Uint8Array(d+(v-N)),V=d;N!==v;)_[V++]=w[N++];return _}}}function m(p){var h=g(p);if(h)return h;throw new Error(`Non-${t} character`)}return{encode:f,decodeUnsafe:g,decode:m}}var Pf=Uf,Df=Pf,Ja=Df;var lo=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")}},uo=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 Qa(this,t)}},fo=class{decoders;constructor(t){this.decoders=t}or(t){return Qa(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 Qa(r,t){return new fo({...r.decoders??{[r.prefix]:r},...t.decoders??{[t.prefix]:t}})}var ho=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 lo(t,e,n),this.decoder=new uo(t,e,s)}encode(t){return this.encoder.encode(t)}decode(t){return this.decoder.decode(t)}};function ur({name:r,prefix:t,encode:e,decode:n}){return new ho(r,t,e,n)}function Te({name:r,prefix:t,alphabet:e}){let{encode:n,decode:s}=Ja(e,r);return ur({prefix:t,name:r,encode:n,decode:o=>de(s(o))})}function Vf(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 Hf(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 lt({name:r,prefix:t,bitsPerChar:e,alphabet:n}){return ur({prefix:t,name:r,encode(s){return Hf(s,n,e)},decode(s){return Vf(s,n,e,r)}})}var ut=Te({name:"base58btc",prefix:"z",alphabet:"123456789ABCDEFGHJKLMNPQRSTUVWXYZabcdefghijkmnopqrstuvwxyz"}),Of=Te({name:"base58flickr",prefix:"Z",alphabet:"123456789abcdefghijkmnopqrstuvwxyzABCDEFGHJKLMNPQRSTUVWXYZ"});var yo={};mt(yo,{identity:()=>pe});var ne={};mt(ne,{Digest:()=>je,create:()=>zt,decode:()=>Re,equals:()=>mo});var Mf=rc,tc=128,Kf=127,Ff=~Kf,$f=Math.pow(2,31);function rc(r,t,e){t=t||[],e=e||0;for(var n=e;r>=$f;)t[e++]=r&255|tc,r/=128;for(;r&Ff;)t[e++]=r&255|tc,r>>>=7;return t[e]=r|0,rc.bytes=e-n+1,t}var qf=go,Gf=128,ec=127;function go(r,n){var e=0,n=n||0,s=0,o=n,i,a=r.length;do{if(o>=a)throw go.bytes=0,new RangeError("Could not decode varint");i=r[o++],e+=s<28?(i&ec)<<s:(i&ec)*Math.pow(2,s),s+=7}while(i>=Gf);return go.bytes=o-n,e}var jf=Math.pow(2,7),zf=Math.pow(2,14),Wf=Math.pow(2,21),Yf=Math.pow(2,28),Zf=Math.pow(2,35),Xf=Math.pow(2,42),Jf=Math.pow(2,49),Qf=Math.pow(2,56),th=Math.pow(2,63),eh=function(r){return r<jf?1:r<zf?2:r<Wf?3:r<Yf?4:r<Zf?5:r<Xf?6:r<Jf?7:r<Qf?8:r<th?9:10},rh={encode:Mf,decode:qf,encodingLength:eh},nh=rh,$r=nh;function qr(r,t=0){return[$r.decode(r,t),$r.decode.bytes]}function fr(r,t,e=0){return $r.encode(r,t,e),t}function hr(r){return $r.encodingLength(r)}function zt(r,t){let e=t.byteLength,n=hr(r),s=n+hr(e),o=new Uint8Array(s+e);return fr(r,o,0),fr(e,o,n),o.set(t,s),new je(r,e,t,o)}function Re(r){let t=de(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 je(e,s,i,t)}function mo(r,t){if(r===t)return!0;{let e=t;return r.code===e.code&&r.size===e.size&&e.bytes instanceof Uint8Array&&Wa(r.bytes,e.bytes)}}var je=class{code;size;digest;bytes;constructor(t,e,n,s){this.code=t,this.size=e,this.digest=n,this.bytes=s}};var nc=0,sh="identity",sc=de;function oh(r){return zt(nc,sc(r))}var pe={code:nc,name:sh,encode:sc,digest:oh};var xo={};mt(xo,{sha256:()=>St,sha512:()=>ih});function bo({name:r,code:t,encode:e}){return new wo(r,t,e)}var wo=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?zt(this.code,e):e.then(n=>zt(this.code,n))}else throw Error("Unknown type, must be binary type")}};function ic(r){return async t=>new Uint8Array(await crypto.subtle.digest(r,t))}var St=bo({name:"sha2-256",code:18,encode:ic("SHA-256")}),ih=bo({name:"sha2-512",code:19,encode:ic("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 yt(r=0){return new Uint8Array(r)}function wt(r=0){return new Uint8Array(r)}function Et(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 Eo={};mt(Eo,{base10:()=>ch});var ch=Te({prefix:"9",name:"base10",alphabet:"0123456789"});var vo={};mt(vo,{base16:()=>lh,base16upper:()=>uh});var lh=lt({prefix:"f",name:"base16",alphabet:"0123456789abcdef",bitsPerChar:4}),uh=lt({prefix:"F",name:"base16upper",alphabet:"0123456789ABCDEF",bitsPerChar:4});var Bo={};mt(Bo,{base2:()=>fh});var fh=lt({prefix:"0",name:"base2",alphabet:"01",bitsPerChar:1});var Ao={};mt(Ao,{base256emoji:()=>mh});var ac=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}"),hh=ac.reduce((r,t,e)=>(r[e]=t,r),[]),dh=ac.reduce((r,t,e)=>(r[t.codePointAt(0)]=e,r),[]);function ph(r){return r.reduce((t,e)=>(t+=hh[e],t),"")}function gh(r){let t=[];for(let e of r){let n=dh[e.codePointAt(0)];if(n===void 0)throw new Error(`Non-base256emoji character: ${e}`);t.push(n)}return new Uint8Array(t)}var mh=ur({prefix:"\u{1F680}",name:"base256emoji",encode:ph,decode:gh});var So={};mt(So,{base32:()=>ge,base32hex:()=>xh,base32hexpad:()=>vh,base32hexpadupper:()=>Bh,base32hexupper:()=>Eh,base32pad:()=>wh,base32padupper:()=>bh,base32upper:()=>yh,base32z:()=>Ah});var ge=lt({prefix:"b",name:"base32",alphabet:"abcdefghijklmnopqrstuvwxyz234567",bitsPerChar:5}),yh=lt({prefix:"B",name:"base32upper",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZ234567",bitsPerChar:5}),wh=lt({prefix:"c",name:"base32pad",alphabet:"abcdefghijklmnopqrstuvwxyz234567=",bitsPerChar:5}),bh=lt({prefix:"C",name:"base32padupper",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZ234567=",bitsPerChar:5}),xh=lt({prefix:"v",name:"base32hex",alphabet:"0123456789abcdefghijklmnopqrstuv",bitsPerChar:5}),Eh=lt({prefix:"V",name:"base32hexupper",alphabet:"0123456789ABCDEFGHIJKLMNOPQRSTUV",bitsPerChar:5}),vh=lt({prefix:"t",name:"base32hexpad",alphabet:"0123456789abcdefghijklmnopqrstuv=",bitsPerChar:5}),Bh=lt({prefix:"T",name:"base32hexpadupper",alphabet:"0123456789ABCDEFGHIJKLMNOPQRSTUV=",bitsPerChar:5}),Ah=lt({prefix:"h",name:"base32z",alphabet:"ybndrfg8ejkmcpqxot1uwisza345h769",bitsPerChar:5});var ko={};mt(ko,{base36:()=>Sh,base36upper:()=>kh});var Sh=Te({prefix:"k",name:"base36",alphabet:"0123456789abcdefghijklmnopqrstuvwxyz"}),kh=Te({prefix:"K",name:"base36upper",alphabet:"0123456789ABCDEFGHIJKLMNOPQRSTUVWXYZ"});var No={};mt(No,{base64:()=>Io,base64pad:()=>Ih,base64url:()=>_o,base64urlpad:()=>_h});var Io=lt({prefix:"m",name:"base64",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/",bitsPerChar:6}),Ih=lt({prefix:"M",name:"base64pad",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/=",bitsPerChar:6}),_o=lt({prefix:"u",name:"base64url",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789-_",bitsPerChar:6}),_h=lt({prefix:"U",name:"base64urlpad",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789-_=",bitsPerChar:6});var To={};mt(To,{base8:()=>Nh});var Nh=lt({prefix:"7",name:"base8",alphabet:"01234567",bitsPerChar:3});var Ro={};mt(Ro,{identity:()=>Th});var Th=ur({prefix:"\0",name:"identity",encode:r=>Za(r),decode:r=>Ya(r)});var em=new TextEncoder,rm=new TextDecoder;function cc(r,t){let{bytes:e,version:n}=r;switch(n){case 0:return Uh(e,Lo(r),t??ut.encoder);default:return Ph(e,Lo(r),t??ge.encoder)}}var lc=new WeakMap;function Lo(r){let t=lc.get(r);if(t==null){let e=new Map;return lc.set(r,e),e}return t}var Kt=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!==Dh)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=zt(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&&mo(t.multihash,n.multihash)}toString(t){return cc(this,t)}toJSON(){return{"/":cc(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??uc(n,s,o.bytes))}else if(e[Vh]===!0){let{version:n,multihash:s,code:o}=e,i=Re(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=uc(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=de(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 je(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]=Ch(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 Lo(o).set(n,t),o}};function Ch(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 ge.prefix:{let e=t??ge;return[ge.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 Uh(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 Ph(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,Dh=18;function uc(r,t,e){let n=hr(r),s=n+hr(t),o=new Uint8Array(s+e.byteLength);return fr(r,o,0),fr(t,o,n),o.set(e,s),o}var Vh=Symbol.for("@ipld/js-cid/CID");var se={...Ro,...Bo,...To,...Eo,...vo,...So,...ko,...po,...No,...Ao},wm={...xo,...yo};function hc(r,t,e,n){return{name:r,prefix:t,encoder:{name:r,prefix:t,encode:e},decoder:{decode:n}}}var fc=hc("utf8","u",r=>"u"+new TextDecoder("utf8").decode(r),r=>new TextEncoder().encode(r.substring(1))),Co=hc("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}),Hh={utf8:fc,"utf-8":fc,hex:se.base16,latin1:Co,ascii:Co,binary:Co,...se},_n=Hh;function Z(r,t="utf8"){let e=_n[t];if(e==null)throw new Error(`Unsupported encoding "${t}"`);return e.decoder.decode(`${e.prefix}${r}`)}function Ft(r){return r==null?!1:typeof r.then=="function"&&typeof r.catch=="function"&&typeof r.finally=="function"}function Le(r){if(!Number.isSafeInteger(r)||r<0)throw new Error(`positive integer expected, not ${r}`)}function Oh(r){return r instanceof Uint8Array||r!=null&&typeof r=="object"&&r.constructor.name==="Uint8Array"}function dr(r,...t){if(!Oh(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 ze(r){if(typeof r!="function"||typeof r.create!="function")throw new Error("Hash should be wrapped by utils.wrapConstructor");Le(r.outputLen),Le(r.blockLen)}function pr(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 dc(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 Nn=typeof globalThis=="object"&&"crypto"in globalThis?globalThis.crypto:void 0;var mr=r=>new DataView(r.buffer,r.byteOffset,r.byteLength),Wt=(r,t)=>r<<32-t|r>>>t;var Lm=new Uint8Array(new Uint32Array([287454020]).buffer)[0]===68;var Mh=async()=>{};async function pc(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 Mh(),n+=o)}}function gc(r){if(typeof r!="string")throw new Error(`utf8ToBytes expected string, got ${typeof r}`);return new Uint8Array(new TextEncoder().encode(r))}function Yt(r){return typeof r=="string"&&(r=gc(r)),dr(r),r}function Uo(...r){let t=0;for(let n=0;n<r.length;n++){let s=r[n];dr(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 gr=class{clone(){return this._cloneInto()}},Kh={}.toString;function mc(r,t){if(t!==void 0&&Kh.call(t)!=="[object Object]")throw new Error("Options should be object or undefined");return Object.assign(r,t)}function Tn(r){let t=n=>r().update(Yt(n)).digest(),e=r();return t.outputLen=e.outputLen,t.blockLen=e.blockLen,t.create=()=>r(),t}function We(r=32){if(Nn&&typeof Nn.getRandomValues=="function")return Nn.getRandomValues(new Uint8Array(r));throw new Error("crypto.getRandomValues must be defined")}function Fh(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 yc=(r,t,e)=>r&t^~r&e,wc=(r,t,e)=>r&t^r&e^t&e,yr=class extends gr{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=mr(this.buffer)}update(t){pr(this);let{view:e,buffer:n,blockLen:s}=this;t=Yt(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=mr(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){pr(this),dc(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;Fh(n,s-8,BigInt(this.length*8),o),this.process(n,0);let a=mr(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 Rn=BigInt(4294967295),Po=BigInt(32);function bc(r,t=!1){return t?{h:Number(r&Rn),l:Number(r>>Po&Rn)}:{h:Number(r>>Po&Rn)|0,l:Number(r&Rn)|0}}function $h(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}=bc(r[s],t);[e[s],n[s]]=[o,i]}return[e,n]}var qh=(r,t)=>BigInt(r>>>0)<<Po|BigInt(t>>>0),Gh=(r,t,e)=>r>>>e,jh=(r,t,e)=>r<<32-e|t>>>e,zh=(r,t,e)=>r>>>e|t<<32-e,Wh=(r,t,e)=>r<<32-e|t>>>e,Yh=(r,t,e)=>r<<64-e|t>>>e-32,Zh=(r,t,e)=>r>>>e-32|t<<64-e,Xh=(r,t)=>t,Jh=(r,t)=>r,Qh=(r,t,e)=>r<<e|t>>>32-e,td=(r,t,e)=>t<<e|r>>>32-e,ed=(r,t,e)=>t<<e-32|r>>>64-e,rd=(r,t,e)=>r<<e-32|t>>>64-e;function nd(r,t,e,n){let s=(t>>>0)+(n>>>0);return{h:r+e+(s/2**32|0)|0,l:s|0}}var sd=(r,t,e)=>(r>>>0)+(t>>>0)+(e>>>0),od=(r,t,e,n)=>t+e+n+(r/2**32|0)|0,id=(r,t,e,n)=>(r>>>0)+(t>>>0)+(e>>>0)+(n>>>0),ad=(r,t,e,n,s)=>t+e+n+s+(r/2**32|0)|0,cd=(r,t,e,n,s)=>(r>>>0)+(t>>>0)+(e>>>0)+(n>>>0)+(s>>>0),ld=(r,t,e,n,s,o)=>t+e+n+s+o+(r/2**32|0)|0;var ud={fromBig:bc,split:$h,toBig:qh,shrSH:Gh,shrSL:jh,rotrSH:zh,rotrSL:Wh,rotrBH:Yh,rotrBL:Zh,rotr32H:Xh,rotr32L:Jh,rotlSH:Qh,rotlSL:td,rotlBH:ed,rotlBL:rd,add:nd,add3L:sd,add3H:od,add4L:id,add4H:ad,add5H:ld,add5L:cd},z=ud;var[fd,hd]=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))),Ce=new Uint32Array(80),Ue=new Uint32Array(80),Do=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:p,Hh:h,Hl:d}=this;return[t,e,n,s,o,i,a,c,l,u,f,g,m,p,h,d]}set(t,e,n,s,o,i,a,c,l,u,f,g,m,p,h,d){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=p|0,this.Hh=h|0,this.Hl=d|0}process(t,e){for(let w=0;w<16;w++,e+=4)Ce[w]=t.getUint32(e),Ue[w]=t.getUint32(e+=4);for(let w=16;w<80;w++){let A=Ce[w-15]|0,B=Ue[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),_=Ce[w-2]|0,V=Ue[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),O=z.add4L(N,R,Ue[w-7],Ue[w-16]),H=z.add4H(O,S,P,Ce[w-7],Ce[w-16]);Ce[w]=H|0,Ue[w]=O|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:p,Gh:h,Gl:d,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&p^~g&d,_=z.add5L(v,B,N,hd[w],Ue[w]),V=z.add5H(_,b,A,S,fd[w],Ce[w]),P=_|0,R=z.rotrSH(n,s,28)^z.rotrBH(n,s,34)^z.rotrBH(n,s,39),O=z.rotrSL(n,s,28)^z.rotrBL(n,s,34)^z.rotrBL(n,s,39),H=n&o^n&a^o&a,W=s&i^s&c^i&c;b=h|0,v=d|0,h=m|0,d=p|0,m=f|0,p=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,O,W);n=z.add3H(x,V,R,H),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:p}=z.add(this.Fh|0,this.Fl|0,m|0,p|0),{h,l:d}=z.add(this.Gh|0,this.Gl|0,h|0,d|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,p,h,d,b,v)}roundClean(){Ce.fill(0),Ue.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 jr=Tn(()=>new Do);var Cn={};mt(Cn,{abytes:()=>wr,bitGet:()=>bd,bitLen:()=>wd,bitMask:()=>zr,bitSet:()=>xd,bytesToHex:()=>ye,bytesToNumberBE:()=>we,bytesToNumberLE:()=>Zt,concatBytes:()=>xe,createHmacDrbg:()=>Oo,ensureBytes:()=>st,equalBytes:()=>md,hexToBytes:()=>Ye,hexToNumber:()=>Ho,isBytes:()=>Pe,numberToBytesBE:()=>De,numberToBytesLE:()=>be,numberToHexUnpadded:()=>Bc,numberToVarBytesBE:()=>gd,utf8ToBytes:()=>yd,validateObject:()=>$t});var vc=BigInt(0),Ln=BigInt(1),dd=BigInt(2);function Pe(r){return r instanceof Uint8Array||r!=null&&typeof r=="object"&&r.constructor.name==="Uint8Array"}function wr(r){if(!Pe(r))throw new Error("Uint8Array expected")}var pd=Array.from({length:256},(r,t)=>t.toString(16).padStart(2,"0"));function ye(r){wr(r);let t="";for(let e=0;e<r.length;e++)t+=pd[r[e]];return t}function Bc(r){let t=r.toString(16);return t.length&1?`0${t}`:t}function Ho(r){if(typeof r!="string")throw new Error("hex string expected, got "+typeof r);return BigInt(r===""?"0":`0x${r}`)}var me={_0:48,_9:57,_A:65,_F:70,_a:97,_f:102};function xc(r){if(r>=me._0&&r<=me._9)return r-me._0;if(r>=me._A&&r<=me._F)return r-(me._A-10);if(r>=me._a&&r<=me._f)return r-(me._a-10)}function Ye(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=xc(r.charCodeAt(o)),a=xc(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 we(r){return Ho(ye(r))}function Zt(r){return wr(r),Ho(ye(Uint8Array.from(r).reverse()))}function De(r,t){return Ye(r.toString(16).padStart(t*2,"0"))}function be(r,t){return De(r,t).reverse()}function gd(r){return Ye(Bc(r))}function st(r,t,e){let n;if(typeof t=="string")try{n=Ye(t)}catch(o){throw new Error(`${r} must be valid hex string, got "${t}". Cause: ${o}`)}else if(Pe(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 xe(...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 md(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 yd(r){if(typeof r!="string")throw new Error(`utf8ToBytes expected string, got ${typeof r}`);return new Uint8Array(new TextEncoder().encode(r))}function wd(r){let t;for(t=0;r>vc;r>>=Ln,t+=1);return t}function bd(r,t){return r>>BigInt(t)&Ln}function xd(r,t,e){return r|(e?Ln:vc)<<BigInt(t)}var zr=r=>(dd<<BigInt(r-1))-Ln,Vo=r=>new Uint8Array(r),Ec=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=Vo(r),s=Vo(r),o=0,i=()=>{n.fill(1),s.fill(0),o=0},a=(...f)=>e(s,n,...f),c=(f=Vo())=>{s=a(Ec([0]),f),n=a(),f.length!==0&&(s=a(Ec([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 xe(...g)};return(f,g)=>{i(),c(f);let m;for(;!(m=g(l()));)c();return i(),m}}var Ed={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"||Pe(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 $t(r,t,e={}){let n=(s,o,i)=>{let a=Ed[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),Ze=BigInt(2),vd=BigInt(3),Mo=BigInt(4),Ac=BigInt(5),Sc=BigInt(8),Bd=BigInt(9),Ad=BigInt(16);function X(r,t){let e=r%t;return e>=bt?e:t+e}function Ko(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 Un(r,t){if(r===bt||t<=bt)throw new Error(`invert: expected positive integers, got n=${r} mod=${t}`);let e=X(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 X(s,t)}function Sd(r){let t=(r-it)/Ze,e,n,s;for(e=r-it,n=0;e%Ze===bt;e/=Ze,n++);for(s=Ze;s<r&&Ko(s,t,r)!==r-it;s++);if(n===1){let i=(r+it)/Mo;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)/Ze;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 p=a.pow(u,it<<BigInt(l-m-1));u=a.sqr(p),f=a.mul(f,p),g=a.mul(g,u),l=m}return f}}function kd(r){if(r%Mo===vd){let t=(r+it)/Mo;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%Sc===Ac){let t=(r-Ac)/Sc;return function(n,s){let o=n.mul(s,Ze),i=n.pow(o,t),a=n.mul(s,i),c=n.mul(n.mul(a,Ze),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%Ad,Sd(r)}var kc=(r,t)=>(X(r,t)&it)===it,Id=["create","isValid","is0","neg","inv","sqrt","sqr","eql","add","sub","mul","pow","div","addN","subN","mulN","sqrN"];function Fo(r){let t={ORDER:"bigint",MASK:"bigint",BYTES:"isSafeInteger",BITS:"isSafeInteger"},e=Id.reduce((n,s)=>(n[s]="function",n),t);return $t(r,e)}function _d(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 Nd(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 $o(r,t){let e=t!==void 0?t:r.toString(2).length,n=Math.ceil(e/8);return{nBitLength:e,nByteLength:n}}function Pn(r,t,e=!1,n={}){if(r<=bt)throw new Error(`Expected Field ORDER > 0, got ${r}`);let{nBitLength:s,nByteLength:o}=$o(r,t);if(o>2048)throw new Error("Field lengths over 2048 bytes are not supported");let i=kd(r),a=Object.freeze({ORDER:r,BITS:s,BYTES:o,MASK:zr(s),ZERO:bt,ONE:it,create:c=>X(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=>X(-c,r),eql:(c,l)=>c===l,sqr:c=>X(c*c,r),add:(c,l)=>X(c+l,r),sub:(c,l)=>X(c-l,r),mul:(c,l)=>X(c*l,r),pow:(c,l)=>_d(a,c,l),div:(c,l)=>X(c*Un(l,r),r),sqrN:c=>c*c,addN:(c,l)=>c+l,subN:(c,l)=>c-l,mulN:(c,l)=>c*l,inv:c=>Un(c,r),sqrt:n.sqrt||(c=>i(a,c)),invertBatch:c=>Nd(a,c),cmov:(c,l,u)=>u?l:c,toBytes:c=>e?be(c,o):De(c,o),fromBytes:c=>{if(c.length!==o)throw new Error(`Fp.fromBytes: expected ${o}, got ${c.length}`);return e?Zt(c):we(c)}});return Object.freeze(a)}function Ic(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 qo(r){let t=Ic(r);return t+Math.ceil(t/2)}function _c(r,t,e=!1){let n=r.length,s=Ic(t),o=qo(t);if(n<16||n<o||n>1024)throw new Error(`expected ${o}-1024 bytes of input, got ${n}`);let i=e?we(r):Zt(r),a=X(i,t-it)+it;return e?be(a,s):De(a,s)}var Rd=BigInt(0),Go=BigInt(1);function Dn(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>Rd;)o&Go&&(i=i.add(a)),a=a.double(),o>>=Go;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 p=0;p<a;p++){let h=p*c,d=Number(i&f);i>>=m,d>c&&(d-=g,i+=Go);let b=h,v=h+Math.abs(d)-1,w=p%2!==0,A=d<0;d===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 Wr(r){return Fo(r.Fp),$t(r,{n:"bigint",h:"bigint",Gx:"field",Gy:"field"},{nBitLength:"isSafeInteger",nByteLength:"isSafeInteger"}),Object.freeze({...$o(r.n,r.nBitLength),...r,p:r.Fp.ORDER})}var Xt=BigInt(0),Ot=BigInt(1),Vn=BigInt(2),Ld=BigInt(8),Cd={zip215:!0};function Ud(r){let t=Wr(r);return $t(r,{hash:"function",a:"bigint",d:"bigint",randomBytes:"function"},{adjustScalarBytes:"function",domain:"function",uvRatio:"function",mapToCurve:"function"}),Object.freeze({...t})}function Nc(r){let t=Ud(r),{Fp:e,n,prehash:s,hash:o,randomBytes:i,nByteLength:a,h:c}=t,l=Vn<<BigInt(a*8)-Ot,u=e.create,f=t.uvRatio||((E,y)=>{try{return{isValid:!0,value:e.sqrt(E*e.inv(y))}}catch{return{isValid:!1,value:Xt}}}),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}),p=E=>typeof E=="bigint"&&Xt<E,h=(E,y)=>p(E)&&p(y)&&E<y,d=E=>E===Xt||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===Xt?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,!d(y))throw new Error("x required");if(!d(k))throw new Error("y required");if(!d(T))throw new Error("z required");if(!d(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(!d(k)||!d(T))throw new Error("invalid affine point");return new B(k,T,Ot,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:K,et:F}=this,j=u(T*T),q=u(L*L),G=u(K*K),nt=u(G*G),et=u(j*y),Bt=u(G*u(et+q)),At=u(nt+u(k*u(j*q)));if(Bt!==At)throw new Error("bad point: equation left != right (1)");let gt=u(T*L),Nt=u(K*F);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:K,ey:F,ez:j}=y,q=u(k*j),G=u(K*L),nt=u(T*j),et=u(F*L);return q===G&&nt===et}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,K=u(k*k),F=u(T*T),j=u(Vn*u(L*L)),q=u(y*K),G=k+T,nt=u(u(G*G)-K-F),et=q+F,Bt=et-j,At=q-F,gt=u(nt*Bt),Nt=u(et*At),he=u(nt*At),Ge=u(Bt*et);return new B(gt,Nt,Ge,he)}add(y){A(y);let{a:k,d:T}=t,{ex:L,ey:K,ez:F,et:j}=this,{ex:q,ey:G,ez:nt,et}=y;if(k===BigInt(-1)){let Da=u((K-L)*(G+q)),Va=u((K+L)*(G-q)),ao=u(Va-Da);if(ao===Xt)return this.double();let Ha=u(F*Vn*et),Oa=u(j*Vn*nt),Ma=Oa+Ha,Ka=Va+Da,Fa=Oa-Ha,Af=u(Ma*ao),Sf=u(Ka*Fa),kf=u(Ma*Fa),If=u(ao*Ka);return new B(Af,Sf,If,kf)}let Bt=u(L*q),At=u(K*G),gt=u(j*T*et),Nt=u(F*nt),he=u((L+K)*(q+G)-Bt-At),Ge=Nt-gt,Fr=Nt+gt,Pa=u(At-k*Bt),xf=u(he*Ge),Ef=u(Fr*Pa),vf=u(he*Pa),Bf=u(Ge*Fr);return new B(xf,Ef,Bf,vf)}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===Xt?N:this.equals(N)||k===Ot?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,K=this.is0();y==null&&(y=K?Ld:e.inv(L));let F=u(k*y),j=u(T*y),q=u(L*y);if(K)return{x:Xt,y:Ot};if(q!==Ot)throw new Error("invZ was invalid");return{x:F,y:j}}clearCofactor(){let{h:y}=t;return y===Ot?this:this.multiplyUnsafe(y)}static fromHex(y,k=!1){let{d:T,a:L}=t,K=e.BYTES;y=st("pointHex",y,K);let F=y.slice(),j=y[K-1];F[K-1]=j&-129;let q=Zt(F);q===Xt||(k?b(q,l):b(q,e.ORDER));let G=u(q*q),nt=u(G-Ot),et=u(T*G-L),{isValid:Bt,value:At}=f(nt,et);if(!Bt)throw new Error("Point.fromHex: invalid y coordinate");let gt=(At&Ot)===Ot,Nt=(j&128)!==0;if(!k&&At===Xt&&Nt)throw new Error("Point.fromHex: x=0 and x_0=1");return Nt!==gt&&(At=u(-At)),B.fromAffine({x:At,y:q})}static fromPrivateKey(y){return R(y).point}toRawBytes(){let{x:y,y:k}=this.toAffine(),T=be(k,e.BYTES);return T[T.length-1]|=y&Ot?128:0,T}toHex(){return ye(this.toRawBytes())}}B.BASE=new B(t.Gx,t.Gy,Ot,u(t.Gx*t.Gy)),B.ZERO=new B(Xt,Ot,Ot,Xt);let{BASE:S,ZERO:N}=B,_=Dn(B,a*8);function V(E){return X(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),K=P(T),F=S.multiply(K),j=F.toRawBytes();return{head:T,prefix:L,scalar:K,point:F,pointBytes:j}}function O(E){return R(E).pointBytes}function H(E=new Uint8Array,...y){let k=xe(...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:K}=R(y),F=H(k.context,T,E),j=S.multiply(F).toRawBytes(),q=H(k.context,j,K,E),G=V(F+q*L);v(G);let nt=xe(j,be(G,e.BYTES));return st("result",nt,a*2)}let x=Cd;function I(E,y,k,T=x){let{context:L,zip215:K}=T,F=e.BYTES;E=st("signature",E,2*F),y=st("message",y),s&&(y=s(y));let j=Zt(E.slice(F,2*F)),q,G,nt;try{q=B.fromHex(k,K),G=B.fromHex(E.slice(0,F),K),nt=S.multiplyUnsafe(j)}catch{return!1}if(!K&&q.isSmallOrder())return!1;let et=H(L,G.toRawBytes(),q.toRawBytes(),y);return G.add(q.multiplyUnsafe(et)).subtract(nt).clearCofactor().equals(B.ZERO)}return S._setWindowSize(8),{CURVE:t,getPublicKey:O,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 Yr=BigInt(0),jo=BigInt(1);function Pd(r){return $t(r,{a:"bigint"},{montgomeryBits:"isSafeInteger",nByteLength:"isSafeInteger",adjustScalarBytes:"function",domain:"function",powPminus2:"function",Gu:"bigint"}),Object.freeze({...r})}function Tc(r){let t=Pd(r),{P:e}=t,n=w=>X(w,e),s=t.montgomeryBits,o=Math.ceil(s/8),i=t.nByteLength,a=t.adjustScalarBytes||(w=>w),c=t.powPminus2||(w=>Ko(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"&&Yr<=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,_=jo,V=Yr,P=B,R=jo,O=Yr,H;for(let x=BigInt(s-1);x>=Yr;x--){let I=S>>x&jo;O^=I,H=l(O,_,P),_=H[0],P=H[1],H=l(O,V,R),V=H[0],R=H[1],O=I;let C=_+V,E=n(C*C),y=_-V,k=n(y*y),T=E-k,L=P+R,K=P-R,F=n(K*C),j=n(L*y),q=F+j,G=F-j;P=n(q*q),R=n(N*n(G*G)),_=n(E*k),V=n(T*(E+n(f*T)))}H=l(O,_,P),_=H[0],P=H[1],H=l(O,V,R),V=H[0],R=H[1];let W=c(V);return n(_*W)}function m(w){return be(n(w),o)}function p(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 d(w,A){let B=p(A),S=h(w),N=g(B,S);if(N===Yr)throw new Error("Invalid private or public key received");return m(N)}let b=m(t.Gu);function v(w){return d(w,b)}return{scalarMult:d,scalarMultBase:v,getSharedSecret:(w,A)=>d(w,A),getPublicKey:w=>v(w),utils:{randomPrivateKey:()=>t.randomBytes(t.nByteLength)},GuBytes:b}}var Zr=BigInt("57896044618658097711785492504343953926634992332820282019728792003956564819949"),Rc=BigInt("19681161376707505956807079304988542015446066515923890162744021073123829784752"),oy=BigInt(0),Dd=BigInt(1),Lc=BigInt(2),Vd=BigInt(3),Hd=BigInt(5),Od=BigInt(8);function Cc(r){let t=BigInt(10),e=BigInt(20),n=BigInt(40),s=BigInt(80),o=Zr,a=r*r%o*r%o,c=ot(a,Lc,o)*a%o,l=ot(c,Dd,o)*r%o,u=ot(l,Hd,o)*l%o,f=ot(u,t,o)*u%o,g=ot(f,e,o)*f%o,m=ot(g,n,o)*g%o,p=ot(m,s,o)*m%o,h=ot(p,s,o)*m%o,d=ot(h,t,o)*u%o;return{pow_p_5_8:ot(d,Lc,o)*r%o,b2:a}}function Uc(r){return r[0]&=248,r[31]&=127,r[31]|=64,r}function Md(r,t){let e=Zr,n=X(t*t*t,e),s=X(n*n*t,e),o=Cc(r*s).pow_p_5_8,i=X(r*n*o,e),a=X(t*i*i,e),c=i,l=X(i*Rc,e),u=a===r,f=a===X(-r,e),g=a===X(-r*Rc,e);return u&&(i=c),(f||g)&&(i=l),kc(i,e)&&(i=X(-i,e)),{isValid:u||f,value:i}}var Kd=Pn(Zr,void 0,!0),Fd={a:BigInt(-1),d:BigInt("37095705934669439343138083508754565189542113879843219016388785533085940283555"),Fp:Kd,n:BigInt("7237005577332262213973186563042994240857116359379907606001950938285454250989"),h:Od,Gx:BigInt("15112221349535400772501151409588531511454012693041857206046113283949847762202"),Gy:BigInt("46316835694926478169428394003475163141307993866256225615783033603165251855960"),hash:jr,randomBytes:We,adjustScalarBytes:Uc,uvRatio:Md},br=Nc(Fd);var Xr=Tc({P:Zr,a:BigInt(486662),montgomeryBits:255,nByteLength:32,Gu:BigInt(9),powPminus2:r=>{let t=Zr,{pow_p_5_8:e,b2:n}=Cc(r);return X(ot(e,Vd,t)*n,t)},adjustScalarBytes:Uc,randomBytes:We});var xr=32,Ee=64,Hn=32;function Pc(){let r=br.utils.randomPrivateKey(),t=br.getPublicKey(r);return{privateKey:Oc(r,t),publicKey:t}}function Dc(r){if(r.length!==Hn)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:Oc(t,e),publicKey:e}}function Vc(r,t){let e=r.subarray(0,Hn);return br.sign(t instanceof Uint8Array?t:t.subarray(),e)}function Hc(r,t,e){return br.verify(t,e instanceof Uint8Array?e:e.subarray(),r)}function Oc(r,t){let e=new Uint8Array(Ee);for(let n=0;n<Hn;n++)e[n]=r[n],e[Hn+n]=t[n];return e}var Ut={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 zo={alg:"A128GCM",ext:!0,k:"scm9jmO_4BJAgdwWGVulLg",key_ops:["encrypt","decrypt"],kty:"oct"};function Mc(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=Ut.get();e*=8;async function c(f,g){let m=a.getRandomValues(new Uint8Array(o)),p=a.getRandomValues(new Uint8Array(n)),h={name:t,iv:p};typeof g=="string"&&(g=Z(g));let d;if(g.length===0){d=await a.subtle.importKey("jwk",zo,{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"]);d=await a.subtle.deriveKey(v,w,{name:t,length:e},!0,["encrypt"])}catch{d=await a.subtle.importKey("jwk",zo,{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"]);d=await a.subtle.deriveKey(v,w,{name:t,length:e},!0,["encrypt"])}let b=await a.subtle.encrypt(h,d,f);return Et([m,h.iv,new Uint8Array(b)])}async function l(f,g){let m=f.subarray(0,o),p=f.subarray(o,o+n),h=f.subarray(o+n),d={name:t,iv:p};typeof g=="string"&&(g=Z(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",zo,{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(d,b,h);return new Uint8Array(v)}return{encrypt:c,decrypt:l}}async function Er(r,t){let n=await Mc().encrypt(r,t);return Io.encode(n)}var Gd=Math.pow(2,7),jd=Math.pow(2,14),zd=Math.pow(2,21),Wo=Math.pow(2,28),Yo=Math.pow(2,35),Zo=Math.pow(2,42),Xo=Math.pow(2,49),Q=128,Tt=127;function dt(r){if(r<Gd)return 1;if(r<jd)return 2;if(r<zd)return 3;if(r<Wo)return 4;if(r<Yo)return 5;if(r<Zo)return 6;if(r<Xo)return 7;if(Number.MAX_SAFE_INTEGER!=null&&r>Number.MAX_SAFE_INTEGER)throw new RangeError("Could not encode varint");return 8}function Jo(r,t,e=0){switch(dt(r)){case 8:t[e++]=r&255|Q,r/=128;case 7:t[e++]=r&255|Q,r/=128;case 6:t[e++]=r&255|Q,r/=128;case 5:t[e++]=r&255|Q,r/=128;case 4:t[e++]=r&255|Q,r>>>=7;case 3:t[e++]=r&255|Q,r>>>=7;case 2:t[e++]=r&255|Q,r>>>=7;case 1:{t[e++]=r&255,r>>>=7;break}default:throw new Error("unreachable")}return t}function Wd(r,t,e=0){switch(dt(r)){case 8:t.set(e++,r&255|Q),r/=128;case 7:t.set(e++,r&255|Q),r/=128;case 6:t.set(e++,r&255|Q),r/=128;case 5:t.set(e++,r&255|Q),r/=128;case 4:t.set(e++,r&255|Q),r>>>=7;case 3:t.set(e++,r&255|Q),r>>>=7;case 2:t.set(e++,r&255|Q),r>>>=7;case 1:{t.set(e++,r&255),r>>>=7;break}default:throw new Error("unreachable")}return t}function Qo(r,t){let e=r[t],n=0;if(n+=e&Tt,e<Q||(e=r[t+1],n+=(e&Tt)<<7,e<Q)||(e=r[t+2],n+=(e&Tt)<<14,e<Q)||(e=r[t+3],n+=(e&Tt)<<21,e<Q)||(e=r[t+4],n+=(e&Tt)*Wo,e<Q)||(e=r[t+5],n+=(e&Tt)*Yo,e<Q)||(e=r[t+6],n+=(e&Tt)*Zo,e<Q)||(e=r[t+7],n+=(e&Tt)*Xo,e<Q))return n;throw new RangeError("Could not decode varint")}function Yd(r,t){let e=r.get(t),n=0;if(n+=e&Tt,e<Q||(e=r.get(t+1),n+=(e&Tt)<<7,e<Q)||(e=r.get(t+2),n+=(e&Tt)<<14,e<Q)||(e=r.get(t+3),n+=(e&Tt)<<21,e<Q)||(e=r.get(t+4),n+=(e&Tt)*Wo,e<Q)||(e=r.get(t+5),n+=(e&Tt)*Yo,e<Q)||(e=r.get(t+6),n+=(e&Tt)*Zo,e<Q)||(e=r.get(t+7),n+=(e&Tt)*Xo,e<Q))return n;throw new RangeError("Could not decode varint")}function oe(r,t,e=0){return t==null&&(t=wt(dt(r))),t instanceof Uint8Array?Jo(r,t,e):Wd(r,t,e)}function Jt(r,t=0){return r instanceof Uint8Array?Qo(r,t):Yd(r,t)}var ti=new Float32Array([-0]),Ve=new Uint8Array(ti.buffer);function Kc(r,t,e){ti[0]=r,t[e]=Ve[0],t[e+1]=Ve[1],t[e+2]=Ve[2],t[e+3]=Ve[3]}function Fc(r,t){return Ve[0]=r[t],Ve[1]=r[t+1],Ve[2]=r[t+2],Ve[3]=r[t+3],ti[0]}var ei=new Float64Array([-0]),Rt=new Uint8Array(ei.buffer);function $c(r,t,e){ei[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 qc(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],ei[0]}var Zd=BigInt(Number.MAX_SAFE_INTEGER),Xd=BigInt(Number.MIN_SAFE_INTEGER),Mt=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 Xe;if(t<Zd&&t>Xd)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>Gc&&(s=0n,++n>Gc&&(n=0n))),new r(Number(s),Number(n))}static fromNumber(t){if(t===0)return Xe;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):Xe}},Xe=new Mt(0,0);Xe.toBigInt=function(){return 0n};Xe.zzEncode=Xe.zzDecode=function(){return this};Xe.length=function(){return 1};var Gc=4294967296n;function jc(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 zc(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 ri(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 Qt(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 ni=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,Qt(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 Qt(this,4);return On(this.buf,this.pos+=4)}sfixed32(){if(this.pos+4>this.len)throw Qt(this,4);return On(this.buf,this.pos+=4)|0}float(){if(this.pos+4>this.len)throw Qt(this,4);let t=Fc(this.buf,this.pos);return this.pos+=4,t}double(){if(this.pos+8>this.len)throw Qt(this,4);let t=qc(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 Qt(this,t);return this.pos+=t,e===n?new Uint8Array(0):this.buf.subarray(e,n)}string(){let t=this.bytes();return zc(t,0,t.length)}skip(t){if(typeof t=="number"){if(this.pos+t>this.len)throw Qt(this,t);this.pos+=t}else do if(this.pos>=this.len)throw Qt(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 Mt(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 Qt(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 Qt(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 Qt(this,8);let t=On(this.buf,this.pos+=4),e=On(this.buf,this.pos+=4);return new Mt(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=Qo(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 si(r){return new ni(r instanceof Uint8Array?r:r.subarray())}function Je(r,t,e){let n=si(r);return t.decode(n,void 0,e)}function oi(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 Qe=class{fn;len;next;val;constructor(t,e,n){this.fn=t,this.len=e,this.next=void 0,this.val=n}};function ii(){}var ci=class{head;tail;len;next;constructor(t){this.head=t.head,this.tail=t.tail,this.len=t.len,this.next=t.states}},Jd=oi();function Qd(r){return globalThis.Buffer!=null?wt(r):Jd(r)}var tn=class{len;head;tail;states;constructor(){this.len=0,this.head=new Qe(ii,0,0),this.tail=this.head,this.states=null}_push(t,e,n){return this.tail=this.tail.next=new Qe(t,e,n),this.len+=e,this}uint32(t){return this.len+=(this.tail=this.tail.next=new li((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(Mn,10,Mt.fromNumber(t)):this.uint32(t)}sint32(t){return this.uint32((t<<1^t>>31)>>>0)}uint64(t){let e=Mt.fromBigInt(t);return this._push(Mn,e.length(),e)}uint64Number(t){return this._push(Jo,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=Mt.fromBigInt(t).zzEncode();return this._push(Mn,e.length(),e)}sint64Number(t){let e=Mt.fromNumber(t).zzEncode();return this._push(Mn,e.length(),e)}sint64String(t){return this.sint64(BigInt(t))}bool(t){return this._push(ai,1,t?1:0)}fixed32(t){return this._push(Qr,4,t>>>0)}sfixed32(t){return this.fixed32(t)}fixed64(t){let e=Mt.fromBigInt(t);return this._push(Qr,4,e.lo)._push(Qr,4,e.hi)}fixed64Number(t){let e=Mt.fromNumber(t);return this._push(Qr,4,e.lo)._push(Qr,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(Kc,4,t)}double(t){return this._push($c,8,t)}bytes(t){let e=t.length>>>0;return e===0?this._push(ai,1,0):this.uint32(e)._push(ep,e,t)}string(t){let e=jc(t);return e!==0?this.uint32(e)._push(ri,e,t):this._push(ai,1,0)}fork(){return this.states=new ci(this),this.head=this.tail=new Qe(ii,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 Qe(ii,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=Qd(this.len),n=0;for(;t!=null;)t.fn(t.val,e,n),n+=t.len,t=t.next;return e}};function ai(r,t,e){t[e]=r&255}function tp(r,t,e){for(;r>127;)t[e++]=r&127|128,r>>>=7;t[e]=r}var li=class extends Qe{next;constructor(t,e){super(tp,t,e),this.next=void 0}};function Mn(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 Qr(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 ep(r,t,e){t.set(r,e)}globalThis.Buffer!=null&&(tn.prototype.bytes=function(r){let t=r.length>>>0;return this.uint32(t),t>0&&this._push(rp,t,r),this},tn.prototype.string=function(r){let t=globalThis.Buffer.byteLength(r);return this.uint32(t),t>0&&this._push(np,t,r),this});function rp(r,t,e){t.set(r,e)}function np(r,t,e){r.length<40?ri(r,t,e):t.utf8Write!=null?t.utf8Write(r,e):t.set(Z(r),e)}function ui(){return new tn}function tr(r,t){let e=ui();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 Kn(r,t,e,n){return{name:r,type:t,encode:e,decode:n}}function fi(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 Kn("enum",vr.VARINT,e,n)}function er(r,t){return Kn("message",vr.LENGTH_DELIMITED,r,t)}var at;(function(r){r.RSA="RSA",r.Ed25519="Ed25519",r.Secp256k1="Secp256k1"})(at||(at={}));var hi;(function(r){r[r.RSA=0]="RSA",r[r.Ed25519=1]="Ed25519",r[r.Secp256k1=2]="Secp256k1"})(hi||(hi={}));(function(r){r.codec=()=>fi(hi)})(at||(at={}));var ie;(function(r){let t;r.codec=()=>(t==null&&(t=er((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=>tr(e,r.codec()),r.decode=e=>Je(e,r.codec())})(ie||(ie={}));var ae;(function(r){let t;r.codec=()=>(t==null&&(t=er((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=>tr(e,r.codec()),r.decode=e=>Je(e,r.codec())})(ae||(ae={}));var en=class{_key;constructor(t){this._key=Br(t,xr)}verify(t,e){return Hc(this._key,e,t)}marshal(){return this._key}get bytes(){return ie.encode({Type:at.Ed25519,Data:this.marshal()}).subarray()}equals(t){return ft(this.bytes,t.bytes)}hash(){let t=St.digest(this.bytes);return Ft(t)?t.then(({bytes:e})=>e):t.bytes}},rr=class{_key;_publicKey;constructor(t,e){this._key=Br(t,Ee),this._publicKey=Br(e,xr)}sign(t){return Vc(this._key,t)}get public(){return new en(this._publicKey)}marshal(){return this._key}get bytes(){return ae.encode({Type:at.Ed25519,Data:this.marshal()}).subarray()}equals(t){return ft(this.bytes,t.bytes)}async hash(){let t=St.digest(this.bytes),e;return Ft(t)?{bytes:e}=await t:e=t.bytes,e}async id(){let t=pe.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 M(`export format '${e}' is not supported`,"ERR_INVALID_EXPORT_FORMAT")}};function sp(r){if(r.length>Ee){r=Br(r,Ee+xr);let n=r.subarray(0,Ee),s=r.subarray(Ee,r.length);return new rr(n,s)}r=Br(r,Ee);let t=r.subarray(0,Ee),e=r.subarray(xr);return new rr(t,e)}function op(r){return r=Br(r,xr),new en(r)}async function ip(){let{privateKey:r,publicKey:t}=Pc();return new rr(r,t)}async function Yc(r){let{privateKey:t,publicKey:e}=Dc(r);return new rr(t,e)}function Br(r,t){if(r=Uint8Array.from(r??[]),r.length!==t)throw new M(`Key must be a Uint8Array of length ${t}, got ${r.length}`,"ERR_INVALID_KEY_TYPE");return r}function $(r,t="utf8"){let e=_n[t];if(e==null)throw new Error(`Unsupported encoding "${t}"`);return e.encoder.encode(r).substring(1)}var Bi={};mt(Bi,{MAX_RSA_KEY_SIZE:()=>dn,RsaPrivateKey:()=>_r,RsaPublicKey:()=>hn,fromJwk:()=>Cp,generateKeyPair:()=>Up,unmarshalRsaPrivateKey:()=>Ei,unmarshalRsaPublicKey:()=>Lp});function nr(r){if(isNaN(r)||r<=0)throw new M("random bytes length must be a Number bigger than 0","ERR_INVALID_LENGTH");return We(r)}var Fe={};mt(Fe,{exportToPem:()=>Ip,importFromPem:()=>_p,jwkToPkcs1:()=>Bp,jwkToPkix:()=>Sp,pkcs1ToJwk:()=>vp,pkixToJwk:()=>Ap});var $n=class extends gr{constructor(t,e){super(),this.finished=!1,this.destroyed=!1,ze(t);let n=Yt(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 pr(this),this.iHash.update(t),this}digestInto(t){pr(this),dr(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()}},He=(r,t,e)=>new $n(r,t).update(e).digest();He.create=(r,t)=>new $n(r,t);function ap(r,t,e,n){ze(r);let s=mc({dkLen:32,asyncTick:10},n),{c:o,dkLen:i,asyncTick:a}=s;if(Le(o),Le(i),Le(a),o<1)throw new Error("PBKDF2: iterations (c) should be >= 1");let c=Yt(t),l=Yt(e),u=new Uint8Array(i),f=He.create(r,c),g=f._cloneInto().update(l);return{c:o,dkLen:i,asyncTick:a,DK:u,PRF:f,PRFSalt:g}}function cp(r,t,e,n,s){return r.destroy(),t.destroy(),n&&n.destroy(),s.fill(0),e}async function pi(r,t,e,n){let{c:s,dkLen:o,asyncTick:i,DK:a,PRF:c,PRFSalt:l}=ap(r,t,e,n),u,f=new Uint8Array(4),g=mr(f),m=new Uint8Array(c.outputLen);for(let p=1,h=0;h<o;p++,h+=c.outputLen){let d=a.subarray(h,h+c.outputLen);g.setInt32(0,p,!1),(u=l._cloneInto(u)).update(f).digestInto(m),d.set(m.subarray(0,d.length)),await pc(s-1,i,()=>{c._cloneInto(u).update(m).digestInto(m);for(let b=0;b<d.length;b++)d[b]^=m[b]})}return cp(c,l,a,u,m)}var Y=Ga(Zc());function sr(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 jn(...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=sr(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,sr(o,8)-n}function Xc(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 Vt(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 dw=Math.log(2);function zn(){if(typeof BigInt>"u")throw new Error("BigInt is not defined. Your environment doesn't implement BigInt.")}function yi(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 ke(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 nn=class{constructor(){this.items=[]}write(t){this.items.push(t)}final(){return yi(this.items)}},rn=[new Uint8Array([1])],Qc="0123456789";var kr="",ee=new ArrayBuffer(0),wi=new Uint8Array(0),sn="EndOfContent",el="OCTET STRING",rl="BIT STRING";function Ie(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):wi}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(!ke(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",ee)}toJSON(){return{...super.toJSON(),isHexOnly:this.isHexOnly,valueHex:Y.Convert.ToHex(this.valueHexView)}}},t.NAME="hexBlock",t}var Be=class{constructor({blockLength:t=0,error:e=kr,warnings:n=[],valueBeforeDecode:s=wi}={}){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)}}};Be.NAME="baseBlock";var Lt=class extends Be{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 Wn=class extends Ie(Be){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):wi,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",ee}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(!ke(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=sr(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}}};Wn.NAME="identificationBlock";var Yn=class extends Be{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(!ke(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=sr(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",ee;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}}};Yn.NAME="lengthBlock";var U={},kt=class extends Be{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 Wn(s),this.lenBlock=new Yn(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 nn;e||nl(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?ee: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)}};kt.NAME="BaseBlock";function nl(r){if(r instanceof U.Constructed)for(let t of r.valueBlock.value)nl(t)&&(r.lenBlock.isIndefiniteForm=!0);return!!r.lenBlock.isIndefiniteForm}var Zn=class extends kt{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}'`}};Zn.NAME="BaseStringBlock";var Xn=class extends Ie(Lt){constructor({isHexOnly:t=!0,...e}={}){super(e),this.isHexOnly=t}};Xn.NAME="PrimitiveValueBlock";var sl,Jn=class extends kt{constructor(t={}){super(t,Xn),this.idBlock.isConstructed=!1}};sl=Jn;U.Primitive=sl;Jn.NAME="PRIMITIVE";function yp(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 Rs(r,t=0,e=r.length){let n=t,s=new kt({},Lt),o=new Be;if(!ke(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=kt;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=yp(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 kt({},Lt);return t.error="Input buffer has zero length",{offset:-1,result:t}}return Rs(Y.BufferSourceConverter.toUint8Array(r).slice(),0,r.byteLength)}function wp(r,t){return r?1:t}var ce=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(!ke(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(;wp(this.isIndefiniteForm,n)>0;){let i=Rs(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===sn)break}return this.isIndefiniteForm&&(this.value[this.value.length-1].constructor.NAME===sn?this.value.pop():this.warnings.push("No EndOfContent block encoded")),o}toBER(t,e){let n=e||new nn;for(let s=0;s<this.value.length;s++)this.value[s].toBER(t,n);return e?ee:n.final()}toJSON(){let t={...super.toJSON(),isIndefiniteForm:this.isIndefiniteForm,value:[]};for(let e of this.value)t.value.push(e.toJSON());return t}};ce.NAME="ConstructedValueBlock";var ol,Me=class extends kt{constructor(t={}){super(t,ce),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 _f=Object.create;var An=Object.defineProperty;var Nf=Object.getOwnPropertyDescriptor;var Tf=Object.getOwnPropertyNames;var Rf=Object.getPrototypeOf,Lf=Object.prototype.hasOwnProperty;var $a=(r,t)=>()=>(t||r((t={exports:{}}).exports,t),t.exports),mt=(r,t)=>{for(var e in t)An(r,e,{get:t[e],enumerable:!0})},qa=(r,t,e,n)=>{if(t&&typeof t=="object"||typeof t=="function")for(let s of Tf(t))!Lf.call(r,s)&&s!==e&&An(r,s,{get:()=>t[s],enumerable:!(n=Nf(t,s))||n.enumerable});return r};var Ga=(r,t,e)=>(e=r!=null?_f(Rf(r)):{},qa(t||!r||!r.__esModule?An(e,"default",{value:r,enumerable:!0}):e,r)),Cf=r=>qa(An({},"__esModule",{value:!0}),r);var Zc=$a(Ar=>{"use strict";var lp="[object ArrayBuffer]",ve=class r{static isArrayBuffer(t){return Object.prototype.toString.call(t)===lp}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}},gi="string",up=/^[0-9a-f]+$/i,fp=/^(?:[A-Za-z0-9+/]{4})*(?:[A-Za-z0-9+/]{2}==|[A-Za-z0-9+/]{3}=)?$/,hp=/^[a-zA-Z0-9-_]+$/,qn=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=ve.toUint8Array(t),n="";for(let o=0;o<e.length;o++)n+=String.fromCharCode(e[o]);return decodeURIComponent(escape(n))}},qt=class{static toString(t,e=!1){let n=ve.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}},Gn=class r{static isHex(t){return typeof t===gi&&up.test(t)}static isBase64(t){return typeof t===gi&&fp.test(t)}static isBase64Url(t){return typeof t===gi&&hp.test(t)}static ToString(t,e="utf8"){let n=ve.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 qt.toString(n,!0);case"utf16":case"utf16be":return qt.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 qt.fromString(t,!0);case"utf16":case"utf16be":return qt.fromString(t);default:throw new Error(`Unknown type of encoding '${e}'`)}}static ToBase64(t){let e=ve.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 qn.fromString(t);case"utf16":case"utf16be":return qt.fromString(t);case"utf16le":case"usc2":return qt.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 qn.toString(t);case"utf16":case"utf16be":return qt.toString(t);case"utf16le":case"usc2":return qt.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=ve.toUint8Array(t),n="";for(let s=0;s<e.length;s++)n+=String.fromCharCode(e[s]);return n}static ToHex(t){let e=ve.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 qt.toString(t,e)}static FromUtf16String(t,e=!1){return qt.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,"")||""}};Gn.DEFAULT_UTF8_ENCODING="utf8";function dp(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 pp(...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 gp(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=ve;Ar.Convert=Gn;Ar.assign=dp;Ar.combine=pp;Ar.isEqual=gp});var uu=$a((Nb,lu)=>{"use strict";function cu(r,t){for(let e in t)Object.defineProperty(r,e,{value:t[e],enumerable:!0,configurable:!0});return r}function Zp(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 cu(r,e)}catch{e.message=r.message,e.stack=r.stack;let s=function(){};return s.prototype=Object.create(Object.getPrototypeOf(r)),cu(new s,e)}}lu.exports=Zp});var Q0={};mt(Q0,{webTransport:()=>J0});var co=Symbol.for("@libp2p/peer-id");var za=Symbol.for("@libp2p/transport");var ja;(function(r){r[r.FATAL_ALL=0]="FATAL_ALL",r[r.NO_FATAL=1]="NO_FATAL"})(ja||(ja={}));var Sn=class r extends Error{code;type;constructor(t="The operation was aborted"){super(t),this.name="AbortError",this.code=r.code,this.type=r.type}static code="ABORT_ERR";static type="aborted"},M=class extends Error{code;props;constructor(t,e,n){super(t),this.code=e,this.name=n?.name??"CodeError",this.props=n??{}}};var kn=Symbol.for("@libp2p/service-capabilities"),sg=Symbol.for("@libp2p/service-dependencies");var di={};mt(di,{Ed25519PrivateKey:()=>rr,Ed25519PublicKey:()=>en,generateKeyPair:()=>ip,generateKeyPairFromSeed:()=>Yc,unmarshalEd25519PrivateKey:()=>sp,unmarshalEd25519PublicKey:()=>op});var po={};mt(po,{base58btc:()=>ut,base58flickr:()=>Of});var _g=new Uint8Array(0);function Wa(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 de(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 Ya(r){return new TextEncoder().encode(r)}function Za(r){return new TextDecoder().decode(r)}function Uf(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(p){if(p instanceof Uint8Array||(ArrayBuffer.isView(p)?p=new Uint8Array(p.buffer,p.byteOffset,p.byteLength):Array.isArray(p)&&(p=Uint8Array.from(p))),!(p instanceof Uint8Array))throw new TypeError("Expected Uint8Array");if(p.length===0)return"";for(var h=0,d=0,b=0,v=p.length;b!==v&&p[b]===0;)b++,h++;for(var w=(v-b)*u+1>>>0,A=new Uint8Array(w);b!==v;){for(var B=p[b],S=0,N=w-1;(B!==0||S<d)&&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");d=S,b++}for(var _=w-d;_!==w&&A[_]===0;)_++;for(var V=c.repeat(h);_<w;++_)V+=r.charAt(A[_]);return V}function g(p){if(typeof p!="string")throw new TypeError("Expected String");if(p.length===0)return new Uint8Array;var h=0;if(p[h]!==" "){for(var d=0,b=0;p[h]===c;)d++,h++;for(var v=(p.length-h)*l+1>>>0,w=new Uint8Array(v);p[h];){var A=e[p.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(p[h]!==" "){for(var N=v-b;N!==v&&w[N]===0;)N++;for(var _=new Uint8Array(d+(v-N)),V=d;N!==v;)_[V++]=w[N++];return _}}}function m(p){var h=g(p);if(h)return h;throw new Error(`Non-${t} character`)}return{encode:f,decodeUnsafe:g,decode:m}}var Pf=Uf,Df=Pf,Ja=Df;var lo=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")}},uo=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 Qa(this,t)}},fo=class{decoders;constructor(t){this.decoders=t}or(t){return Qa(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 Qa(r,t){return new fo({...r.decoders??{[r.prefix]:r},...t.decoders??{[t.prefix]:t}})}var ho=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 lo(t,e,n),this.decoder=new uo(t,e,s)}encode(t){return this.encoder.encode(t)}decode(t){return this.decoder.decode(t)}};function ur({name:r,prefix:t,encode:e,decode:n}){return new ho(r,t,e,n)}function Te({name:r,prefix:t,alphabet:e}){let{encode:n,decode:s}=Ja(e,r);return ur({prefix:t,name:r,encode:n,decode:o=>de(s(o))})}function Vf(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 Hf(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 lt({name:r,prefix:t,bitsPerChar:e,alphabet:n}){return ur({prefix:t,name:r,encode(s){return Hf(s,n,e)},decode(s){return Vf(s,n,e,r)}})}var ut=Te({name:"base58btc",prefix:"z",alphabet:"123456789ABCDEFGHJKLMNPQRSTUVWXYZabcdefghijkmnopqrstuvwxyz"}),Of=Te({name:"base58flickr",prefix:"Z",alphabet:"123456789abcdefghijkmnopqrstuvwxyzABCDEFGHJKLMNPQRSTUVWXYZ"});var yo={};mt(yo,{identity:()=>pe});var ne={};mt(ne,{Digest:()=>je,create:()=>zt,decode:()=>Re,equals:()=>mo});var Mf=rc,tc=128,Kf=127,Ff=~Kf,$f=Math.pow(2,31);function rc(r,t,e){t=t||[],e=e||0;for(var n=e;r>=$f;)t[e++]=r&255|tc,r/=128;for(;r&Ff;)t[e++]=r&255|tc,r>>>=7;return t[e]=r|0,rc.bytes=e-n+1,t}var qf=go,Gf=128,ec=127;function go(r,n){var e=0,n=n||0,s=0,o=n,i,a=r.length;do{if(o>=a)throw go.bytes=0,new RangeError("Could not decode varint");i=r[o++],e+=s<28?(i&ec)<<s:(i&ec)*Math.pow(2,s),s+=7}while(i>=Gf);return go.bytes=o-n,e}var jf=Math.pow(2,7),zf=Math.pow(2,14),Wf=Math.pow(2,21),Yf=Math.pow(2,28),Zf=Math.pow(2,35),Xf=Math.pow(2,42),Jf=Math.pow(2,49),Qf=Math.pow(2,56),th=Math.pow(2,63),eh=function(r){return r<jf?1:r<zf?2:r<Wf?3:r<Yf?4:r<Zf?5:r<Xf?6:r<Jf?7:r<Qf?8:r<th?9:10},rh={encode:Mf,decode:qf,encodingLength:eh},nh=rh,$r=nh;function qr(r,t=0){return[$r.decode(r,t),$r.decode.bytes]}function fr(r,t,e=0){return $r.encode(r,t,e),t}function hr(r){return $r.encodingLength(r)}function zt(r,t){let e=t.byteLength,n=hr(r),s=n+hr(e),o=new Uint8Array(s+e);return fr(r,o,0),fr(e,o,n),o.set(t,s),new je(r,e,t,o)}function Re(r){let t=de(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 je(e,s,i,t)}function mo(r,t){if(r===t)return!0;{let e=t;return r.code===e.code&&r.size===e.size&&e.bytes instanceof Uint8Array&&Wa(r.bytes,e.bytes)}}var je=class{code;size;digest;bytes;constructor(t,e,n,s){this.code=t,this.size=e,this.digest=n,this.bytes=s}};var nc=0,sh="identity",sc=de;function oh(r){return zt(nc,sc(r))}var pe={code:nc,name:sh,encode:sc,digest:oh};var xo={};mt(xo,{sha256:()=>St,sha512:()=>ih});function bo({name:r,code:t,encode:e}){return new wo(r,t,e)}var wo=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?zt(this.code,e):e.then(n=>zt(this.code,n))}else throw Error("Unknown type, must be binary type")}};function ic(r){return async t=>new Uint8Array(await crypto.subtle.digest(r,t))}var St=bo({name:"sha2-256",code:18,encode:ic("SHA-256")}),ih=bo({name:"sha2-512",code:19,encode:ic("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 yt(r=0){return new Uint8Array(r)}function wt(r=0){return new Uint8Array(r)}function Et(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 Eo={};mt(Eo,{base10:()=>ch});var ch=Te({prefix:"9",name:"base10",alphabet:"0123456789"});var vo={};mt(vo,{base16:()=>lh,base16upper:()=>uh});var lh=lt({prefix:"f",name:"base16",alphabet:"0123456789abcdef",bitsPerChar:4}),uh=lt({prefix:"F",name:"base16upper",alphabet:"0123456789ABCDEF",bitsPerChar:4});var Bo={};mt(Bo,{base2:()=>fh});var fh=lt({prefix:"0",name:"base2",alphabet:"01",bitsPerChar:1});var Ao={};mt(Ao,{base256emoji:()=>mh});var ac=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}"),hh=ac.reduce((r,t,e)=>(r[e]=t,r),[]),dh=ac.reduce((r,t,e)=>(r[t.codePointAt(0)]=e,r),[]);function ph(r){return r.reduce((t,e)=>(t+=hh[e],t),"")}function gh(r){let t=[];for(let e of r){let n=dh[e.codePointAt(0)];if(n===void 0)throw new Error(`Non-base256emoji character: ${e}`);t.push(n)}return new Uint8Array(t)}var mh=ur({prefix:"\u{1F680}",name:"base256emoji",encode:ph,decode:gh});var So={};mt(So,{base32:()=>ge,base32hex:()=>xh,base32hexpad:()=>vh,base32hexpadupper:()=>Bh,base32hexupper:()=>Eh,base32pad:()=>wh,base32padupper:()=>bh,base32upper:()=>yh,base32z:()=>Ah});var ge=lt({prefix:"b",name:"base32",alphabet:"abcdefghijklmnopqrstuvwxyz234567",bitsPerChar:5}),yh=lt({prefix:"B",name:"base32upper",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZ234567",bitsPerChar:5}),wh=lt({prefix:"c",name:"base32pad",alphabet:"abcdefghijklmnopqrstuvwxyz234567=",bitsPerChar:5}),bh=lt({prefix:"C",name:"base32padupper",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZ234567=",bitsPerChar:5}),xh=lt({prefix:"v",name:"base32hex",alphabet:"0123456789abcdefghijklmnopqrstuv",bitsPerChar:5}),Eh=lt({prefix:"V",name:"base32hexupper",alphabet:"0123456789ABCDEFGHIJKLMNOPQRSTUV",bitsPerChar:5}),vh=lt({prefix:"t",name:"base32hexpad",alphabet:"0123456789abcdefghijklmnopqrstuv=",bitsPerChar:5}),Bh=lt({prefix:"T",name:"base32hexpadupper",alphabet:"0123456789ABCDEFGHIJKLMNOPQRSTUV=",bitsPerChar:5}),Ah=lt({prefix:"h",name:"base32z",alphabet:"ybndrfg8ejkmcpqxot1uwisza345h769",bitsPerChar:5});var ko={};mt(ko,{base36:()=>Sh,base36upper:()=>kh});var Sh=Te({prefix:"k",name:"base36",alphabet:"0123456789abcdefghijklmnopqrstuvwxyz"}),kh=Te({prefix:"K",name:"base36upper",alphabet:"0123456789ABCDEFGHIJKLMNOPQRSTUVWXYZ"});var No={};mt(No,{base64:()=>Io,base64pad:()=>Ih,base64url:()=>_o,base64urlpad:()=>_h});var Io=lt({prefix:"m",name:"base64",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/",bitsPerChar:6}),Ih=lt({prefix:"M",name:"base64pad",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/=",bitsPerChar:6}),_o=lt({prefix:"u",name:"base64url",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789-_",bitsPerChar:6}),_h=lt({prefix:"U",name:"base64urlpad",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789-_=",bitsPerChar:6});var To={};mt(To,{base8:()=>Nh});var Nh=lt({prefix:"7",name:"base8",alphabet:"01234567",bitsPerChar:3});var Ro={};mt(Ro,{identity:()=>Th});var Th=ur({prefix:"\0",name:"identity",encode:r=>Za(r),decode:r=>Ya(r)});var em=new TextEncoder,rm=new TextDecoder;function cc(r,t){let{bytes:e,version:n}=r;switch(n){case 0:return Uh(e,Lo(r),t??ut.encoder);default:return Ph(e,Lo(r),t??ge.encoder)}}var lc=new WeakMap;function Lo(r){let t=lc.get(r);if(t==null){let e=new Map;return lc.set(r,e),e}return t}var Kt=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!==Dh)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=zt(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&&mo(t.multihash,n.multihash)}toString(t){return cc(this,t)}toJSON(){return{"/":cc(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??uc(n,s,o.bytes))}else if(e[Vh]===!0){let{version:n,multihash:s,code:o}=e,i=Re(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=uc(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=de(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 je(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]=Ch(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 Lo(o).set(n,t),o}};function Ch(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 ge.prefix:{let e=t??ge;return[ge.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 Uh(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 Ph(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,Dh=18;function uc(r,t,e){let n=hr(r),s=n+hr(t),o=new Uint8Array(s+e.byteLength);return fr(r,o,0),fr(t,o,n),o.set(e,s),o}var Vh=Symbol.for("@ipld/js-cid/CID");var se={...Ro,...Bo,...To,...Eo,...vo,...So,...ko,...po,...No,...Ao},wm={...xo,...yo};function hc(r,t,e,n){return{name:r,prefix:t,encoder:{name:r,prefix:t,encode:e},decoder:{decode:n}}}var fc=hc("utf8","u",r=>"u"+new TextDecoder("utf8").decode(r),r=>new TextEncoder().encode(r.substring(1))),Co=hc("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}),Hh={utf8:fc,"utf-8":fc,hex:se.base16,latin1:Co,ascii:Co,binary:Co,...se},_n=Hh;function Z(r,t="utf8"){let e=_n[t];if(e==null)throw new Error(`Unsupported encoding "${t}"`);return e.decoder.decode(`${e.prefix}${r}`)}function Ft(r){return r==null?!1:typeof r.then=="function"&&typeof r.catch=="function"&&typeof r.finally=="function"}function Le(r){if(!Number.isSafeInteger(r)||r<0)throw new Error(`positive integer expected, not ${r}`)}function Oh(r){return r instanceof Uint8Array||r!=null&&typeof r=="object"&&r.constructor.name==="Uint8Array"}function dr(r,...t){if(!Oh(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 ze(r){if(typeof r!="function"||typeof r.create!="function")throw new Error("Hash should be wrapped by utils.wrapConstructor");Le(r.outputLen),Le(r.blockLen)}function pr(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 dc(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 Nn=typeof globalThis=="object"&&"crypto"in globalThis?globalThis.crypto:void 0;var mr=r=>new DataView(r.buffer,r.byteOffset,r.byteLength),Wt=(r,t)=>r<<32-t|r>>>t;var Lm=new Uint8Array(new Uint32Array([287454020]).buffer)[0]===68;var Mh=async()=>{};async function pc(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 Mh(),n+=o)}}function gc(r){if(typeof r!="string")throw new Error(`utf8ToBytes expected string, got ${typeof r}`);return new Uint8Array(new TextEncoder().encode(r))}function Yt(r){return typeof r=="string"&&(r=gc(r)),dr(r),r}function Uo(...r){let t=0;for(let n=0;n<r.length;n++){let s=r[n];dr(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 gr=class{clone(){return this._cloneInto()}},Kh={}.toString;function mc(r,t){if(t!==void 0&&Kh.call(t)!=="[object Object]")throw new Error("Options should be object or undefined");return Object.assign(r,t)}function Tn(r){let t=n=>r().update(Yt(n)).digest(),e=r();return t.outputLen=e.outputLen,t.blockLen=e.blockLen,t.create=()=>r(),t}function We(r=32){if(Nn&&typeof Nn.getRandomValues=="function")return Nn.getRandomValues(new Uint8Array(r));throw new Error("crypto.getRandomValues must be defined")}function Fh(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 yc=(r,t,e)=>r&t^~r&e,wc=(r,t,e)=>r&t^r&e^t&e,yr=class extends gr{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=mr(this.buffer)}update(t){pr(this);let{view:e,buffer:n,blockLen:s}=this;t=Yt(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=mr(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){pr(this),dc(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;Fh(n,s-8,BigInt(this.length*8),o),this.process(n,0);let a=mr(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 Rn=BigInt(4294967295),Po=BigInt(32);function bc(r,t=!1){return t?{h:Number(r&Rn),l:Number(r>>Po&Rn)}:{h:Number(r>>Po&Rn)|0,l:Number(r&Rn)|0}}function $h(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}=bc(r[s],t);[e[s],n[s]]=[o,i]}return[e,n]}var qh=(r,t)=>BigInt(r>>>0)<<Po|BigInt(t>>>0),Gh=(r,t,e)=>r>>>e,jh=(r,t,e)=>r<<32-e|t>>>e,zh=(r,t,e)=>r>>>e|t<<32-e,Wh=(r,t,e)=>r<<32-e|t>>>e,Yh=(r,t,e)=>r<<64-e|t>>>e-32,Zh=(r,t,e)=>r>>>e-32|t<<64-e,Xh=(r,t)=>t,Jh=(r,t)=>r,Qh=(r,t,e)=>r<<e|t>>>32-e,td=(r,t,e)=>t<<e|r>>>32-e,ed=(r,t,e)=>t<<e-32|r>>>64-e,rd=(r,t,e)=>r<<e-32|t>>>64-e;function nd(r,t,e,n){let s=(t>>>0)+(n>>>0);return{h:r+e+(s/2**32|0)|0,l:s|0}}var sd=(r,t,e)=>(r>>>0)+(t>>>0)+(e>>>0),od=(r,t,e,n)=>t+e+n+(r/2**32|0)|0,id=(r,t,e,n)=>(r>>>0)+(t>>>0)+(e>>>0)+(n>>>0),ad=(r,t,e,n,s)=>t+e+n+s+(r/2**32|0)|0,cd=(r,t,e,n,s)=>(r>>>0)+(t>>>0)+(e>>>0)+(n>>>0)+(s>>>0),ld=(r,t,e,n,s,o)=>t+e+n+s+o+(r/2**32|0)|0;var ud={fromBig:bc,split:$h,toBig:qh,shrSH:Gh,shrSL:jh,rotrSH:zh,rotrSL:Wh,rotrBH:Yh,rotrBL:Zh,rotr32H:Xh,rotr32L:Jh,rotlSH:Qh,rotlSL:td,rotlBH:ed,rotlBL:rd,add:nd,add3L:sd,add3H:od,add4L:id,add4H:ad,add5H:ld,add5L:cd},z=ud;var[fd,hd]=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))),Ce=new Uint32Array(80),Ue=new Uint32Array(80),Do=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:p,Hh:h,Hl:d}=this;return[t,e,n,s,o,i,a,c,l,u,f,g,m,p,h,d]}set(t,e,n,s,o,i,a,c,l,u,f,g,m,p,h,d){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=p|0,this.Hh=h|0,this.Hl=d|0}process(t,e){for(let w=0;w<16;w++,e+=4)Ce[w]=t.getUint32(e),Ue[w]=t.getUint32(e+=4);for(let w=16;w<80;w++){let A=Ce[w-15]|0,B=Ue[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),_=Ce[w-2]|0,V=Ue[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),O=z.add4L(N,R,Ue[w-7],Ue[w-16]),H=z.add4H(O,S,P,Ce[w-7],Ce[w-16]);Ce[w]=H|0,Ue[w]=O|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:p,Gh:h,Gl:d,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&p^~g&d,_=z.add5L(v,B,N,hd[w],Ue[w]),V=z.add5H(_,b,A,S,fd[w],Ce[w]),P=_|0,R=z.rotrSH(n,s,28)^z.rotrBH(n,s,34)^z.rotrBH(n,s,39),O=z.rotrSL(n,s,28)^z.rotrBL(n,s,34)^z.rotrBL(n,s,39),H=n&o^n&a^o&a,W=s&i^s&c^i&c;b=h|0,v=d|0,h=m|0,d=p|0,m=f|0,p=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,O,W);n=z.add3H(x,V,R,H),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:p}=z.add(this.Fh|0,this.Fl|0,m|0,p|0),{h,l:d}=z.add(this.Gh|0,this.Gl|0,h|0,d|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,p,h,d,b,v)}roundClean(){Ce.fill(0),Ue.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 jr=Tn(()=>new Do);var Cn={};mt(Cn,{abytes:()=>wr,bitGet:()=>bd,bitLen:()=>wd,bitMask:()=>zr,bitSet:()=>xd,bytesToHex:()=>ye,bytesToNumberBE:()=>we,bytesToNumberLE:()=>Zt,concatBytes:()=>xe,createHmacDrbg:()=>Oo,ensureBytes:()=>st,equalBytes:()=>md,hexToBytes:()=>Ye,hexToNumber:()=>Ho,isBytes:()=>Pe,numberToBytesBE:()=>De,numberToBytesLE:()=>be,numberToHexUnpadded:()=>Bc,numberToVarBytesBE:()=>gd,utf8ToBytes:()=>yd,validateObject:()=>$t});var vc=BigInt(0),Ln=BigInt(1),dd=BigInt(2);function Pe(r){return r instanceof Uint8Array||r!=null&&typeof r=="object"&&r.constructor.name==="Uint8Array"}function wr(r){if(!Pe(r))throw new Error("Uint8Array expected")}var pd=Array.from({length:256},(r,t)=>t.toString(16).padStart(2,"0"));function ye(r){wr(r);let t="";for(let e=0;e<r.length;e++)t+=pd[r[e]];return t}function Bc(r){let t=r.toString(16);return t.length&1?`0${t}`:t}function Ho(r){if(typeof r!="string")throw new Error("hex string expected, got "+typeof r);return BigInt(r===""?"0":`0x${r}`)}var me={_0:48,_9:57,_A:65,_F:70,_a:97,_f:102};function xc(r){if(r>=me._0&&r<=me._9)return r-me._0;if(r>=me._A&&r<=me._F)return r-(me._A-10);if(r>=me._a&&r<=me._f)return r-(me._a-10)}function Ye(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=xc(r.charCodeAt(o)),a=xc(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 we(r){return Ho(ye(r))}function Zt(r){return wr(r),Ho(ye(Uint8Array.from(r).reverse()))}function De(r,t){return Ye(r.toString(16).padStart(t*2,"0"))}function be(r,t){return De(r,t).reverse()}function gd(r){return Ye(Bc(r))}function st(r,t,e){let n;if(typeof t=="string")try{n=Ye(t)}catch(o){throw new Error(`${r} must be valid hex string, got "${t}". Cause: ${o}`)}else if(Pe(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 xe(...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 md(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 yd(r){if(typeof r!="string")throw new Error(`utf8ToBytes expected string, got ${typeof r}`);return new Uint8Array(new TextEncoder().encode(r))}function wd(r){let t;for(t=0;r>vc;r>>=Ln,t+=1);return t}function bd(r,t){return r>>BigInt(t)&Ln}function xd(r,t,e){return r|(e?Ln:vc)<<BigInt(t)}var zr=r=>(dd<<BigInt(r-1))-Ln,Vo=r=>new Uint8Array(r),Ec=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=Vo(r),s=Vo(r),o=0,i=()=>{n.fill(1),s.fill(0),o=0},a=(...f)=>e(s,n,...f),c=(f=Vo())=>{s=a(Ec([0]),f),n=a(),f.length!==0&&(s=a(Ec([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 xe(...g)};return(f,g)=>{i(),c(f);let m;for(;!(m=g(l()));)c();return i(),m}}var Ed={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"||Pe(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 $t(r,t,e={}){let n=(s,o,i)=>{let a=Ed[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),Ze=BigInt(2),vd=BigInt(3),Mo=BigInt(4),Ac=BigInt(5),Sc=BigInt(8),Bd=BigInt(9),Ad=BigInt(16);function X(r,t){let e=r%t;return e>=bt?e:t+e}function Ko(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 Un(r,t){if(r===bt||t<=bt)throw new Error(`invert: expected positive integers, got n=${r} mod=${t}`);let e=X(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 X(s,t)}function Sd(r){let t=(r-it)/Ze,e,n,s;for(e=r-it,n=0;e%Ze===bt;e/=Ze,n++);for(s=Ze;s<r&&Ko(s,t,r)!==r-it;s++);if(n===1){let i=(r+it)/Mo;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)/Ze;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 p=a.pow(u,it<<BigInt(l-m-1));u=a.sqr(p),f=a.mul(f,p),g=a.mul(g,u),l=m}return f}}function kd(r){if(r%Mo===vd){let t=(r+it)/Mo;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%Sc===Ac){let t=(r-Ac)/Sc;return function(n,s){let o=n.mul(s,Ze),i=n.pow(o,t),a=n.mul(s,i),c=n.mul(n.mul(a,Ze),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%Ad,Sd(r)}var kc=(r,t)=>(X(r,t)&it)===it,Id=["create","isValid","is0","neg","inv","sqrt","sqr","eql","add","sub","mul","pow","div","addN","subN","mulN","sqrN"];function Fo(r){let t={ORDER:"bigint",MASK:"bigint",BYTES:"isSafeInteger",BITS:"isSafeInteger"},e=Id.reduce((n,s)=>(n[s]="function",n),t);return $t(r,e)}function _d(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 Nd(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 $o(r,t){let e=t!==void 0?t:r.toString(2).length,n=Math.ceil(e/8);return{nBitLength:e,nByteLength:n}}function Pn(r,t,e=!1,n={}){if(r<=bt)throw new Error(`Expected Field ORDER > 0, got ${r}`);let{nBitLength:s,nByteLength:o}=$o(r,t);if(o>2048)throw new Error("Field lengths over 2048 bytes are not supported");let i=kd(r),a=Object.freeze({ORDER:r,BITS:s,BYTES:o,MASK:zr(s),ZERO:bt,ONE:it,create:c=>X(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=>X(-c,r),eql:(c,l)=>c===l,sqr:c=>X(c*c,r),add:(c,l)=>X(c+l,r),sub:(c,l)=>X(c-l,r),mul:(c,l)=>X(c*l,r),pow:(c,l)=>_d(a,c,l),div:(c,l)=>X(c*Un(l,r),r),sqrN:c=>c*c,addN:(c,l)=>c+l,subN:(c,l)=>c-l,mulN:(c,l)=>c*l,inv:c=>Un(c,r),sqrt:n.sqrt||(c=>i(a,c)),invertBatch:c=>Nd(a,c),cmov:(c,l,u)=>u?l:c,toBytes:c=>e?be(c,o):De(c,o),fromBytes:c=>{if(c.length!==o)throw new Error(`Fp.fromBytes: expected ${o}, got ${c.length}`);return e?Zt(c):we(c)}});return Object.freeze(a)}function Ic(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 qo(r){let t=Ic(r);return t+Math.ceil(t/2)}function _c(r,t,e=!1){let n=r.length,s=Ic(t),o=qo(t);if(n<16||n<o||n>1024)throw new Error(`expected ${o}-1024 bytes of input, got ${n}`);let i=e?we(r):Zt(r),a=X(i,t-it)+it;return e?be(a,s):De(a,s)}var Rd=BigInt(0),Go=BigInt(1);function Dn(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>Rd;)o&Go&&(i=i.add(a)),a=a.double(),o>>=Go;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 p=0;p<a;p++){let h=p*c,d=Number(i&f);i>>=m,d>c&&(d-=g,i+=Go);let b=h,v=h+Math.abs(d)-1,w=p%2!==0,A=d<0;d===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 Wr(r){return Fo(r.Fp),$t(r,{n:"bigint",h:"bigint",Gx:"field",Gy:"field"},{nBitLength:"isSafeInteger",nByteLength:"isSafeInteger"}),Object.freeze({...$o(r.n,r.nBitLength),...r,p:r.Fp.ORDER})}var Xt=BigInt(0),Ot=BigInt(1),Vn=BigInt(2),Ld=BigInt(8),Cd={zip215:!0};function Ud(r){let t=Wr(r);return $t(r,{hash:"function",a:"bigint",d:"bigint",randomBytes:"function"},{adjustScalarBytes:"function",domain:"function",uvRatio:"function",mapToCurve:"function"}),Object.freeze({...t})}function Nc(r){let t=Ud(r),{Fp:e,n,prehash:s,hash:o,randomBytes:i,nByteLength:a,h:c}=t,l=Vn<<BigInt(a*8)-Ot,u=e.create,f=t.uvRatio||((E,y)=>{try{return{isValid:!0,value:e.sqrt(E*e.inv(y))}}catch{return{isValid:!1,value:Xt}}}),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}),p=E=>typeof E=="bigint"&&Xt<E,h=(E,y)=>p(E)&&p(y)&&E<y,d=E=>E===Xt||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===Xt?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,!d(y))throw new Error("x required");if(!d(k))throw new Error("y required");if(!d(T))throw new Error("z required");if(!d(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(!d(k)||!d(T))throw new Error("invalid affine point");return new B(k,T,Ot,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:K,et:F}=this,j=u(T*T),q=u(L*L),G=u(K*K),nt=u(G*G),et=u(j*y),Bt=u(G*u(et+q)),At=u(nt+u(k*u(j*q)));if(Bt!==At)throw new Error("bad point: equation left != right (1)");let gt=u(T*L),Nt=u(K*F);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:K,ey:F,ez:j}=y,q=u(k*j),G=u(K*L),nt=u(T*j),et=u(F*L);return q===G&&nt===et}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,K=u(k*k),F=u(T*T),j=u(Vn*u(L*L)),q=u(y*K),G=k+T,nt=u(u(G*G)-K-F),et=q+F,Bt=et-j,At=q-F,gt=u(nt*Bt),Nt=u(et*At),he=u(nt*At),Ge=u(Bt*et);return new B(gt,Nt,Ge,he)}add(y){A(y);let{a:k,d:T}=t,{ex:L,ey:K,ez:F,et:j}=this,{ex:q,ey:G,ez:nt,et}=y;if(k===BigInt(-1)){let Da=u((K-L)*(G+q)),Va=u((K+L)*(G-q)),ao=u(Va-Da);if(ao===Xt)return this.double();let Ha=u(F*Vn*et),Oa=u(j*Vn*nt),Ma=Oa+Ha,Ka=Va+Da,Fa=Oa-Ha,Af=u(Ma*ao),Sf=u(Ka*Fa),kf=u(Ma*Fa),If=u(ao*Ka);return new B(Af,Sf,If,kf)}let Bt=u(L*q),At=u(K*G),gt=u(j*T*et),Nt=u(F*nt),he=u((L+K)*(q+G)-Bt-At),Ge=Nt-gt,Fr=Nt+gt,Pa=u(At-k*Bt),xf=u(he*Ge),Ef=u(Fr*Pa),vf=u(he*Pa),Bf=u(Ge*Fr);return new B(xf,Ef,Bf,vf)}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===Xt?N:this.equals(N)||k===Ot?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,K=this.is0();y==null&&(y=K?Ld:e.inv(L));let F=u(k*y),j=u(T*y),q=u(L*y);if(K)return{x:Xt,y:Ot};if(q!==Ot)throw new Error("invZ was invalid");return{x:F,y:j}}clearCofactor(){let{h:y}=t;return y===Ot?this:this.multiplyUnsafe(y)}static fromHex(y,k=!1){let{d:T,a:L}=t,K=e.BYTES;y=st("pointHex",y,K);let F=y.slice(),j=y[K-1];F[K-1]=j&-129;let q=Zt(F);q===Xt||(k?b(q,l):b(q,e.ORDER));let G=u(q*q),nt=u(G-Ot),et=u(T*G-L),{isValid:Bt,value:At}=f(nt,et);if(!Bt)throw new Error("Point.fromHex: invalid y coordinate");let gt=(At&Ot)===Ot,Nt=(j&128)!==0;if(!k&&At===Xt&&Nt)throw new Error("Point.fromHex: x=0 and x_0=1");return Nt!==gt&&(At=u(-At)),B.fromAffine({x:At,y:q})}static fromPrivateKey(y){return R(y).point}toRawBytes(){let{x:y,y:k}=this.toAffine(),T=be(k,e.BYTES);return T[T.length-1]|=y&Ot?128:0,T}toHex(){return ye(this.toRawBytes())}}B.BASE=new B(t.Gx,t.Gy,Ot,u(t.Gx*t.Gy)),B.ZERO=new B(Xt,Ot,Ot,Xt);let{BASE:S,ZERO:N}=B,_=Dn(B,a*8);function V(E){return X(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),K=P(T),F=S.multiply(K),j=F.toRawBytes();return{head:T,prefix:L,scalar:K,point:F,pointBytes:j}}function O(E){return R(E).pointBytes}function H(E=new Uint8Array,...y){let k=xe(...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:K}=R(y),F=H(k.context,T,E),j=S.multiply(F).toRawBytes(),q=H(k.context,j,K,E),G=V(F+q*L);v(G);let nt=xe(j,be(G,e.BYTES));return st("result",nt,a*2)}let x=Cd;function I(E,y,k,T=x){let{context:L,zip215:K}=T,F=e.BYTES;E=st("signature",E,2*F),y=st("message",y),s&&(y=s(y));let j=Zt(E.slice(F,2*F)),q,G,nt;try{q=B.fromHex(k,K),G=B.fromHex(E.slice(0,F),K),nt=S.multiplyUnsafe(j)}catch{return!1}if(!K&&q.isSmallOrder())return!1;let et=H(L,G.toRawBytes(),q.toRawBytes(),y);return G.add(q.multiplyUnsafe(et)).subtract(nt).clearCofactor().equals(B.ZERO)}return S._setWindowSize(8),{CURVE:t,getPublicKey:O,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 Yr=BigInt(0),jo=BigInt(1);function Pd(r){return $t(r,{a:"bigint"},{montgomeryBits:"isSafeInteger",nByteLength:"isSafeInteger",adjustScalarBytes:"function",domain:"function",powPminus2:"function",Gu:"bigint"}),Object.freeze({...r})}function Tc(r){let t=Pd(r),{P:e}=t,n=w=>X(w,e),s=t.montgomeryBits,o=Math.ceil(s/8),i=t.nByteLength,a=t.adjustScalarBytes||(w=>w),c=t.powPminus2||(w=>Ko(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"&&Yr<=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,_=jo,V=Yr,P=B,R=jo,O=Yr,H;for(let x=BigInt(s-1);x>=Yr;x--){let I=S>>x&jo;O^=I,H=l(O,_,P),_=H[0],P=H[1],H=l(O,V,R),V=H[0],R=H[1],O=I;let C=_+V,E=n(C*C),y=_-V,k=n(y*y),T=E-k,L=P+R,K=P-R,F=n(K*C),j=n(L*y),q=F+j,G=F-j;P=n(q*q),R=n(N*n(G*G)),_=n(E*k),V=n(T*(E+n(f*T)))}H=l(O,_,P),_=H[0],P=H[1],H=l(O,V,R),V=H[0],R=H[1];let W=c(V);return n(_*W)}function m(w){return be(n(w),o)}function p(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 d(w,A){let B=p(A),S=h(w),N=g(B,S);if(N===Yr)throw new Error("Invalid private or public key received");return m(N)}let b=m(t.Gu);function v(w){return d(w,b)}return{scalarMult:d,scalarMultBase:v,getSharedSecret:(w,A)=>d(w,A),getPublicKey:w=>v(w),utils:{randomPrivateKey:()=>t.randomBytes(t.nByteLength)},GuBytes:b}}var Zr=BigInt("57896044618658097711785492504343953926634992332820282019728792003956564819949"),Rc=BigInt("19681161376707505956807079304988542015446066515923890162744021073123829784752"),oy=BigInt(0),Dd=BigInt(1),Lc=BigInt(2),Vd=BigInt(3),Hd=BigInt(5),Od=BigInt(8);function Cc(r){let t=BigInt(10),e=BigInt(20),n=BigInt(40),s=BigInt(80),o=Zr,a=r*r%o*r%o,c=ot(a,Lc,o)*a%o,l=ot(c,Dd,o)*r%o,u=ot(l,Hd,o)*l%o,f=ot(u,t,o)*u%o,g=ot(f,e,o)*f%o,m=ot(g,n,o)*g%o,p=ot(m,s,o)*m%o,h=ot(p,s,o)*m%o,d=ot(h,t,o)*u%o;return{pow_p_5_8:ot(d,Lc,o)*r%o,b2:a}}function Uc(r){return r[0]&=248,r[31]&=127,r[31]|=64,r}function Md(r,t){let e=Zr,n=X(t*t*t,e),s=X(n*n*t,e),o=Cc(r*s).pow_p_5_8,i=X(r*n*o,e),a=X(t*i*i,e),c=i,l=X(i*Rc,e),u=a===r,f=a===X(-r,e),g=a===X(-r*Rc,e);return u&&(i=c),(f||g)&&(i=l),kc(i,e)&&(i=X(-i,e)),{isValid:u||f,value:i}}var Kd=Pn(Zr,void 0,!0),Fd={a:BigInt(-1),d:BigInt("37095705934669439343138083508754565189542113879843219016388785533085940283555"),Fp:Kd,n:BigInt("7237005577332262213973186563042994240857116359379907606001950938285454250989"),h:Od,Gx:BigInt("15112221349535400772501151409588531511454012693041857206046113283949847762202"),Gy:BigInt("46316835694926478169428394003475163141307993866256225615783033603165251855960"),hash:jr,randomBytes:We,adjustScalarBytes:Uc,uvRatio:Md},br=Nc(Fd);var Xr=Tc({P:Zr,a:BigInt(486662),montgomeryBits:255,nByteLength:32,Gu:BigInt(9),powPminus2:r=>{let t=Zr,{pow_p_5_8:e,b2:n}=Cc(r);return X(ot(e,Vd,t)*n,t)},adjustScalarBytes:Uc,randomBytes:We});var xr=32,Ee=64,Hn=32;function Pc(){let r=br.utils.randomPrivateKey(),t=br.getPublicKey(r);return{privateKey:Oc(r,t),publicKey:t}}function Dc(r){if(r.length!==Hn)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:Oc(t,e),publicKey:e}}function Vc(r,t){let e=r.subarray(0,Hn);return br.sign(t instanceof Uint8Array?t:t.subarray(),e)}function Hc(r,t,e){return br.verify(t,e instanceof Uint8Array?e:e.subarray(),r)}function Oc(r,t){let e=new Uint8Array(Ee);for(let n=0;n<Hn;n++)e[n]=r[n],e[Hn+n]=t[n];return e}var Ut={get(r=globalThis){let t=r.crypto;if(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 zo={alg:"A128GCM",ext:!0,k:"scm9jmO_4BJAgdwWGVulLg",key_ops:["encrypt","decrypt"],kty:"oct"};function Mc(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=Ut.get();e*=8;async function c(f,g){let m=a.getRandomValues(new Uint8Array(o)),p=a.getRandomValues(new Uint8Array(n)),h={name:t,iv:p};typeof g=="string"&&(g=Z(g));let d;if(g.length===0){d=await a.subtle.importKey("jwk",zo,{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"]);d=await a.subtle.deriveKey(v,w,{name:t,length:e},!0,["encrypt"])}catch{d=await a.subtle.importKey("jwk",zo,{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"]);d=await a.subtle.deriveKey(v,w,{name:t,length:e},!0,["encrypt"])}let b=await a.subtle.encrypt(h,d,f);return Et([m,h.iv,new Uint8Array(b)])}async function l(f,g){let m=f.subarray(0,o),p=f.subarray(o,o+n),h=f.subarray(o+n),d={name:t,iv:p};typeof g=="string"&&(g=Z(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",zo,{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(d,b,h);return new Uint8Array(v)}return{encrypt:c,decrypt:l}}async function Er(r,t){let n=await Mc().encrypt(r,t);return Io.encode(n)}var Gd=Math.pow(2,7),jd=Math.pow(2,14),zd=Math.pow(2,21),Wo=Math.pow(2,28),Yo=Math.pow(2,35),Zo=Math.pow(2,42),Xo=Math.pow(2,49),Q=128,Tt=127;function dt(r){if(r<Gd)return 1;if(r<jd)return 2;if(r<zd)return 3;if(r<Wo)return 4;if(r<Yo)return 5;if(r<Zo)return 6;if(r<Xo)return 7;if(Number.MAX_SAFE_INTEGER!=null&&r>Number.MAX_SAFE_INTEGER)throw new RangeError("Could not encode varint");return 8}function Jo(r,t,e=0){switch(dt(r)){case 8:t[e++]=r&255|Q,r/=128;case 7:t[e++]=r&255|Q,r/=128;case 6:t[e++]=r&255|Q,r/=128;case 5:t[e++]=r&255|Q,r/=128;case 4:t[e++]=r&255|Q,r>>>=7;case 3:t[e++]=r&255|Q,r>>>=7;case 2:t[e++]=r&255|Q,r>>>=7;case 1:{t[e++]=r&255,r>>>=7;break}default:throw new Error("unreachable")}return t}function Wd(r,t,e=0){switch(dt(r)){case 8:t.set(e++,r&255|Q),r/=128;case 7:t.set(e++,r&255|Q),r/=128;case 6:t.set(e++,r&255|Q),r/=128;case 5:t.set(e++,r&255|Q),r/=128;case 4:t.set(e++,r&255|Q),r>>>=7;case 3:t.set(e++,r&255|Q),r>>>=7;case 2:t.set(e++,r&255|Q),r>>>=7;case 1:{t.set(e++,r&255),r>>>=7;break}default:throw new Error("unreachable")}return t}function Qo(r,t){let e=r[t],n=0;if(n+=e&Tt,e<Q||(e=r[t+1],n+=(e&Tt)<<7,e<Q)||(e=r[t+2],n+=(e&Tt)<<14,e<Q)||(e=r[t+3],n+=(e&Tt)<<21,e<Q)||(e=r[t+4],n+=(e&Tt)*Wo,e<Q)||(e=r[t+5],n+=(e&Tt)*Yo,e<Q)||(e=r[t+6],n+=(e&Tt)*Zo,e<Q)||(e=r[t+7],n+=(e&Tt)*Xo,e<Q))return n;throw new RangeError("Could not decode varint")}function Yd(r,t){let e=r.get(t),n=0;if(n+=e&Tt,e<Q||(e=r.get(t+1),n+=(e&Tt)<<7,e<Q)||(e=r.get(t+2),n+=(e&Tt)<<14,e<Q)||(e=r.get(t+3),n+=(e&Tt)<<21,e<Q)||(e=r.get(t+4),n+=(e&Tt)*Wo,e<Q)||(e=r.get(t+5),n+=(e&Tt)*Yo,e<Q)||(e=r.get(t+6),n+=(e&Tt)*Zo,e<Q)||(e=r.get(t+7),n+=(e&Tt)*Xo,e<Q))return n;throw new RangeError("Could not decode varint")}function oe(r,t,e=0){return t==null&&(t=wt(dt(r))),t instanceof Uint8Array?Jo(r,t,e):Wd(r,t,e)}function Jt(r,t=0){return r instanceof Uint8Array?Qo(r,t):Yd(r,t)}var ti=new Float32Array([-0]),Ve=new Uint8Array(ti.buffer);function Kc(r,t,e){ti[0]=r,t[e]=Ve[0],t[e+1]=Ve[1],t[e+2]=Ve[2],t[e+3]=Ve[3]}function Fc(r,t){return Ve[0]=r[t],Ve[1]=r[t+1],Ve[2]=r[t+2],Ve[3]=r[t+3],ti[0]}var ei=new Float64Array([-0]),Rt=new Uint8Array(ei.buffer);function $c(r,t,e){ei[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 qc(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],ei[0]}var Zd=BigInt(Number.MAX_SAFE_INTEGER),Xd=BigInt(Number.MIN_SAFE_INTEGER),Mt=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 Xe;if(t<Zd&&t>Xd)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>Gc&&(s=0n,++n>Gc&&(n=0n))),new r(Number(s),Number(n))}static fromNumber(t){if(t===0)return Xe;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):Xe}},Xe=new Mt(0,0);Xe.toBigInt=function(){return 0n};Xe.zzEncode=Xe.zzDecode=function(){return this};Xe.length=function(){return 1};var Gc=4294967296n;function jc(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 zc(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 ri(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 Qt(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 ni=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,Qt(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 Qt(this,4);return On(this.buf,this.pos+=4)}sfixed32(){if(this.pos+4>this.len)throw Qt(this,4);return On(this.buf,this.pos+=4)|0}float(){if(this.pos+4>this.len)throw Qt(this,4);let t=Fc(this.buf,this.pos);return this.pos+=4,t}double(){if(this.pos+8>this.len)throw Qt(this,4);let t=qc(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 Qt(this,t);return this.pos+=t,e===n?new Uint8Array(0):this.buf.subarray(e,n)}string(){let t=this.bytes();return zc(t,0,t.length)}skip(t){if(typeof t=="number"){if(this.pos+t>this.len)throw Qt(this,t);this.pos+=t}else do if(this.pos>=this.len)throw Qt(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 Mt(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 Qt(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 Qt(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 Qt(this,8);let t=On(this.buf,this.pos+=4),e=On(this.buf,this.pos+=4);return new Mt(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=Qo(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 si(r){return new ni(r instanceof Uint8Array?r:r.subarray())}function Je(r,t,e){let n=si(r);return t.decode(n,void 0,e)}function oi(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 Qe=class{fn;len;next;val;constructor(t,e,n){this.fn=t,this.len=e,this.next=void 0,this.val=n}};function ii(){}var ci=class{head;tail;len;next;constructor(t){this.head=t.head,this.tail=t.tail,this.len=t.len,this.next=t.states}},Jd=oi();function Qd(r){return globalThis.Buffer!=null?wt(r):Jd(r)}var tn=class{len;head;tail;states;constructor(){this.len=0,this.head=new Qe(ii,0,0),this.tail=this.head,this.states=null}_push(t,e,n){return this.tail=this.tail.next=new Qe(t,e,n),this.len+=e,this}uint32(t){return this.len+=(this.tail=this.tail.next=new li((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(Mn,10,Mt.fromNumber(t)):this.uint32(t)}sint32(t){return this.uint32((t<<1^t>>31)>>>0)}uint64(t){let e=Mt.fromBigInt(t);return this._push(Mn,e.length(),e)}uint64Number(t){return this._push(Jo,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=Mt.fromBigInt(t).zzEncode();return this._push(Mn,e.length(),e)}sint64Number(t){let e=Mt.fromNumber(t).zzEncode();return this._push(Mn,e.length(),e)}sint64String(t){return this.sint64(BigInt(t))}bool(t){return this._push(ai,1,t?1:0)}fixed32(t){return this._push(Qr,4,t>>>0)}sfixed32(t){return this.fixed32(t)}fixed64(t){let e=Mt.fromBigInt(t);return this._push(Qr,4,e.lo)._push(Qr,4,e.hi)}fixed64Number(t){let e=Mt.fromNumber(t);return this._push(Qr,4,e.lo)._push(Qr,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(Kc,4,t)}double(t){return this._push($c,8,t)}bytes(t){let e=t.length>>>0;return e===0?this._push(ai,1,0):this.uint32(e)._push(ep,e,t)}string(t){let e=jc(t);return e!==0?this.uint32(e)._push(ri,e,t):this._push(ai,1,0)}fork(){return this.states=new ci(this),this.head=this.tail=new Qe(ii,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 Qe(ii,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=Qd(this.len),n=0;for(;t!=null;)t.fn(t.val,e,n),n+=t.len,t=t.next;return e}};function ai(r,t,e){t[e]=r&255}function tp(r,t,e){for(;r>127;)t[e++]=r&127|128,r>>>=7;t[e]=r}var li=class extends Qe{next;constructor(t,e){super(tp,t,e),this.next=void 0}};function Mn(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 Qr(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 ep(r,t,e){t.set(r,e)}globalThis.Buffer!=null&&(tn.prototype.bytes=function(r){let t=r.length>>>0;return this.uint32(t),t>0&&this._push(rp,t,r),this},tn.prototype.string=function(r){let t=globalThis.Buffer.byteLength(r);return this.uint32(t),t>0&&this._push(np,t,r),this});function rp(r,t,e){t.set(r,e)}function np(r,t,e){r.length<40?ri(r,t,e):t.utf8Write!=null?t.utf8Write(r,e):t.set(Z(r),e)}function ui(){return new tn}function tr(r,t){let e=ui();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 Kn(r,t,e,n){return{name:r,type:t,encode:e,decode:n}}function fi(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 Kn("enum",vr.VARINT,e,n)}function er(r,t){return Kn("message",vr.LENGTH_DELIMITED,r,t)}var at;(function(r){r.RSA="RSA",r.Ed25519="Ed25519",r.Secp256k1="Secp256k1"})(at||(at={}));var hi;(function(r){r[r.RSA=0]="RSA",r[r.Ed25519=1]="Ed25519",r[r.Secp256k1=2]="Secp256k1"})(hi||(hi={}));(function(r){r.codec=()=>fi(hi)})(at||(at={}));var ie;(function(r){let t;r.codec=()=>(t==null&&(t=er((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=>tr(e,r.codec()),r.decode=e=>Je(e,r.codec())})(ie||(ie={}));var ae;(function(r){let t;r.codec=()=>(t==null&&(t=er((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=>tr(e,r.codec()),r.decode=e=>Je(e,r.codec())})(ae||(ae={}));var en=class{_key;constructor(t){this._key=Br(t,xr)}verify(t,e){return Hc(this._key,e,t)}marshal(){return this._key}get bytes(){return ie.encode({Type:at.Ed25519,Data:this.marshal()}).subarray()}equals(t){return ft(this.bytes,t.bytes)}hash(){let t=St.digest(this.bytes);return Ft(t)?t.then(({bytes:e})=>e):t.bytes}},rr=class{_key;_publicKey;constructor(t,e){this._key=Br(t,Ee),this._publicKey=Br(e,xr)}sign(t){return Vc(this._key,t)}get public(){return new en(this._publicKey)}marshal(){return this._key}get bytes(){return ae.encode({Type:at.Ed25519,Data:this.marshal()}).subarray()}equals(t){return ft(this.bytes,t.bytes)}async hash(){let t=St.digest(this.bytes),e;return Ft(t)?{bytes:e}=await t:e=t.bytes,e}async id(){let t=pe.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 M(`export format '${e}' is not supported`,"ERR_INVALID_EXPORT_FORMAT")}};function sp(r){if(r.length>Ee){r=Br(r,Ee+xr);let n=r.subarray(0,Ee),s=r.subarray(Ee,r.length);return new rr(n,s)}r=Br(r,Ee);let t=r.subarray(0,Ee),e=r.subarray(xr);return new rr(t,e)}function op(r){return r=Br(r,xr),new en(r)}async function ip(){let{privateKey:r,publicKey:t}=Pc();return new rr(r,t)}async function Yc(r){let{privateKey:t,publicKey:e}=Dc(r);return new rr(t,e)}function Br(r,t){if(r=Uint8Array.from(r??[]),r.length!==t)throw new M(`Key must be a Uint8Array of length ${t}, got ${r.length}`,"ERR_INVALID_KEY_TYPE");return r}function $(r,t="utf8"){let e=_n[t];if(e==null)throw new Error(`Unsupported encoding "${t}"`);return e.encoder.encode(r).substring(1)}var Bi={};mt(Bi,{MAX_RSA_KEY_SIZE:()=>dn,RsaPrivateKey:()=>_r,RsaPublicKey:()=>hn,fromJwk:()=>Cp,generateKeyPair:()=>Up,unmarshalRsaPrivateKey:()=>Ei,unmarshalRsaPublicKey:()=>Lp});function nr(r){if(isNaN(r)||r<=0)throw new M("random bytes length must be a Number bigger than 0","ERR_INVALID_LENGTH");return We(r)}var Fe={};mt(Fe,{exportToPem:()=>Ip,importFromPem:()=>_p,jwkToPkcs1:()=>Bp,jwkToPkix:()=>Sp,pkcs1ToJwk:()=>vp,pkixToJwk:()=>Ap});var $n=class extends gr{constructor(t,e){super(),this.finished=!1,this.destroyed=!1,ze(t);let n=Yt(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 pr(this),this.iHash.update(t),this}digestInto(t){pr(this),dr(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()}},He=(r,t,e)=>new $n(r,t).update(e).digest();He.create=(r,t)=>new $n(r,t);function ap(r,t,e,n){ze(r);let s=mc({dkLen:32,asyncTick:10},n),{c:o,dkLen:i,asyncTick:a}=s;if(Le(o),Le(i),Le(a),o<1)throw new Error("PBKDF2: iterations (c) should be >= 1");let c=Yt(t),l=Yt(e),u=new Uint8Array(i),f=He.create(r,c),g=f._cloneInto().update(l);return{c:o,dkLen:i,asyncTick:a,DK:u,PRF:f,PRFSalt:g}}function cp(r,t,e,n,s){return r.destroy(),t.destroy(),n&&n.destroy(),s.fill(0),e}async function pi(r,t,e,n){let{c:s,dkLen:o,asyncTick:i,DK:a,PRF:c,PRFSalt:l}=ap(r,t,e,n),u,f=new Uint8Array(4),g=mr(f),m=new Uint8Array(c.outputLen);for(let p=1,h=0;h<o;p++,h+=c.outputLen){let d=a.subarray(h,h+c.outputLen);g.setInt32(0,p,!1),(u=l._cloneInto(u)).update(f).digestInto(m),d.set(m.subarray(0,d.length)),await pc(s-1,i,()=>{c._cloneInto(u).update(m).digestInto(m);for(let b=0;b<d.length;b++)d[b]^=m[b]})}return cp(c,l,a,u,m)}var Y=Ga(Zc());function sr(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 jn(...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=sr(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,sr(o,8)-n}function Xc(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 Vt(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 dw=Math.log(2);function zn(){if(typeof BigInt>"u")throw new Error("BigInt is not defined. Your environment doesn't implement BigInt.")}function yi(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 ke(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 nn=class{constructor(){this.items=[]}write(t){this.items.push(t)}final(){return yi(this.items)}},rn=[new Uint8Array([1])],Qc="0123456789";var kr="",ee=new ArrayBuffer(0),wi=new Uint8Array(0),sn="EndOfContent",el="OCTET STRING",rl="BIT STRING";function Ie(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):wi}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(!ke(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",ee)}toJSON(){return{...super.toJSON(),isHexOnly:this.isHexOnly,valueHex:Y.Convert.ToHex(this.valueHexView)}}},t.NAME="hexBlock",t}var Be=class{constructor({blockLength:t=0,error:e=kr,warnings:n=[],valueBeforeDecode:s=wi}={}){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)}}};Be.NAME="baseBlock";var Lt=class extends Be{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 Wn=class extends Ie(Be){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):wi,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",ee}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(!ke(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=sr(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}}};Wn.NAME="identificationBlock";var Yn=class extends Be{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(!ke(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=sr(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",ee;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}}};Yn.NAME="lengthBlock";var U={},kt=class extends Be{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 Wn(s),this.lenBlock=new Yn(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 nn;e||nl(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?ee: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)}};kt.NAME="BaseBlock";function nl(r){if(r instanceof U.Constructed)for(let t of r.valueBlock.value)nl(t)&&(r.lenBlock.isIndefiniteForm=!0);return!!r.lenBlock.isIndefiniteForm}var Zn=class extends kt{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}'`}};Zn.NAME="BaseStringBlock";var Xn=class extends Ie(Lt){constructor({isHexOnly:t=!0,...e}={}){super(e),this.isHexOnly=t}};Xn.NAME="PrimitiveValueBlock";var sl,Jn=class extends kt{constructor(t={}){super(t,Xn),this.idBlock.isConstructed=!1}};sl=Jn;U.Primitive=sl;Jn.NAME="PRIMITIVE";function yp(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 Rs(r,t=0,e=r.length){let n=t,s=new kt({},Lt),o=new Be;if(!ke(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=kt;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=yp(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 kt({},Lt);return t.error="Input buffer has zero length",{offset:-1,result:t}}return Rs(Y.BufferSourceConverter.toUint8Array(r).slice(),0,r.byteLength)}function wp(r,t){return r?1:t}var ce=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(!ke(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(;wp(this.isIndefiniteForm,n)>0;){let i=Rs(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===sn)break}return this.isIndefiniteForm&&(this.value[this.value.length-1].constructor.NAME===sn?this.value.pop():this.warnings.push("No EndOfContent block encoded")),o}toBER(t,e){let n=e||new nn;for(let s=0;s<this.value.length;s++)this.value[s].toBER(t,n);return e?ee:n.final()}toJSON(){let t={...super.toJSON(),isIndefiniteForm:this.isIndefiniteForm,value:[]};for(let e of this.value)t.value.push(e.toJSON());return t}};ce.NAME="ConstructedValueBlock";var ol,Me=class extends kt{constructor(t={}){super(t,ce),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
6
|
`)}`:`${e} :`}};ol=Me;U.Constructed=ol;Me.NAME="CONSTRUCTED";var Qn=class extends Lt{fromBER(t,e,n){return e}toBER(t){return ee}};Qn.override="EndOfContentValueBlock";var il,ts=class extends kt{constructor(t={}){super(t,Qn),this.idBlock.tagClass=1,this.idBlock.tagNumber=0}};il=ts;U.EndOfContent=il;ts.NAME=sn;var al,Ke=class extends kt{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}`}};al=Ke;U.Null=al;Ke.NAME="NULL";var es=class extends Ie(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 ke(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}}};es.NAME="BooleanValueBlock";var cl,rs=class extends kt{constructor(t={}){super(t,es),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}`}};cl=rs;U.Boolean=cl;rs.NAME="BOOLEAN";var ns=class extends Ie(ce){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=ce.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===sn){if(this.isIndefiniteForm)break;return this.error="EndOfContent is unexpected, OCTET STRING may consists of OCTET STRINGs only",-1}if(i!==el)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?ce.prototype.toBER.call(this,t,e):t?new ArrayBuffer(this.valueHexView.byteLength):this.valueHexView.slice().buffer}toJSON(){return{...super.toJSON(),isConstructed:this.isConstructed}}};ns.NAME="OctetStringValueBlock";var ll,Ae=class r extends kt{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=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=Rs(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?Me.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)}};ll=Ae;U.OctetString=ll;Ae.NAME=el;var ss=class extends Ie(ce){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=ce.prototype.fromBER.call(this,t,e,n),s===-1)return s;for(let a of this.value){let c=a.constructor.NAME;if(c===sn){if(this.isIndefiniteForm)break;return this.error="EndOfContent is unexpected, BIT STRING may consists of BIT STRINGs only",-1}if(c!==rl)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(!ke(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=Rs(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 ce.prototype.toBER.call(this,t,e);if(t)return new ArrayBuffer(this.valueHexView.byteLength+1);if(!this.valueHexView.byteLength)return ee;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}}};ss.NAME="BitStringValueBlock";var ul,Sr=class extends kt{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},ss),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 Me.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)}`}}};ul=Sr;U.BitString=ul;Sr.NAME=rl;var fl;function bp(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=jn(new Uint8Array([l%10]),o);break;default:o[i-f]=l%10}}return e[0]>0&&(o=jn(e,o)),o}function tl(r){if(r>=rn.length)for(let t=rn.length;t<=r;t++){let e=new Uint8Array([0]),n=rn[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=jn(e,n)),rn.push(n)}return rn[r]}function xp(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 on=class extends Ie(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(Xc(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=xp(tl(n),e),i="-";break;default:e=bp(e,tl(n))}n++,s>>=1}}for(let c=0;c<e.length;c++)e[c]&&(a=!0),a&&(i+=Qc.charAt(e[c]));return a===!1&&(i+=Qc.charAt(0)),i}};fl=on;on.NAME="IntegerValueBlock";Object.defineProperty(fl.prototype,"valueHex",{set:function(r){this.valueHexView=new Uint8Array(r),this.setValueHex()},get:function(){return this.valueHexView.slice().buffer}});var hl,pt=class r extends kt{constructor(t={}){super(t,on),this.idBlock.tagClass=1,this.idBlock.tagNumber=2}toBigInt(){return zn(),BigInt(this.valueBlock.toString())}static fromBigInt(t){zn();let e=BigInt(t),n=new nn,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()}`}};hl=pt;U.Integer=hl;pt.NAME="INTEGER";var dl,os=class extends pt{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=10}};dl=os;U.Enumerated=dl;os.NAME="ENUMERATED";var an=class extends Ie(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(!ke(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=sr(this.valueHexView,7):(this.isHexOnly=!0,this.warnings.push("Too big SID for decoding, hex only")),e+this.blockLength)}set valueBigInt(t){zn();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",ee;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}}};an.NAME="sidBlock";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.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,ee;e.push(s)}return yi(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 an;if(s>Number.MAX_SAFE_INTEGER){zn();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}};is.NAME="ObjectIdentifierValueBlock";var pl,te=class extends kt{constructor(t={}){super(t,is),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()}}};pl=te;U.ObjectIdentifier=pl;te.NAME="OBJECT IDENTIFIER";var cn=class extends Ie(Be){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(!ke(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=sr(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",ee;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}}};cn.NAME="relativeSidBlock";var as=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 cn;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,ee;n.push(o)}return yi(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 cn;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}};as.NAME="RelativeObjectIdentifierValueBlock";var gl,cs=class extends kt{constructor(t={}){super(t,as),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()}}};gl=cs;U.RelativeObjectIdentifier=gl;cs.NAME="RelativeObjectIdentifier";var ml,vt=class extends Me{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=16}};ml=vt;U.Sequence=ml;vt.NAME="SEQUENCE";var yl,ls=class extends Me{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=17}};yl=ls;U.Set=yl;ls.NAME="SET";var us=class extends Ie(Lt){constructor({...t}={}){super(t),this.isHexOnly=!0,this.value=kr}toJSON(){return{...super.toJSON(),value:this.value}}};us.NAME="StringValueBlock";var fs=class extends us{};fs.NAME="SimpleStringValueBlock";var Pt=class extends Zn{constructor({...t}={}){super(t,fs)}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}};Pt.NAME="SIMPLE STRING";var hs=class extends Pt{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}};hs.NAME="Utf8StringValueBlock";var wl,Se=class extends hs{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=12}};wl=Se;U.Utf8String=wl;Se.NAME="UTF8String";var ds=class extends Pt{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))}};ds.NAME="BmpStringValueBlock";var bl,ps=class extends ds{constructor({...t}={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=30}};bl=ps;U.BmpString=bl;ps.NAME="BMPString";var gs=class extends Pt{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}};gs.NAME="UniversalStringValueBlock";var xl,ms=class extends gs{constructor({...t}={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=28}};xl=ms;U.UniversalString=xl;ms.NAME="UniversalString";var El,ys=class extends Pt{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=18}};El=ys;U.NumericString=El;ys.NAME="NumericString";var vl,ws=class extends Pt{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=19}};vl=ws;U.PrintableString=vl;ws.NAME="PrintableString";var Bl,bs=class extends Pt{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=20}};Bl=bs;U.TeletexString=Bl;bs.NAME="TeletexString";var Al,xs=class extends Pt{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=21}};Al=xs;U.VideotexString=Al;xs.NAME="VideotexString";var Sl,Es=class extends Pt{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=22}};Sl=Es;U.IA5String=Sl;Es.NAME="IA5String";var kl,vs=class extends Pt{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=25}};kl=vs;U.GraphicString=kl;vs.NAME="GraphicString";var Il,ln=class extends Pt{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=26}};Il=ln;U.VisibleString=Il;ln.NAME="VisibleString";var _l,Bs=class extends Pt{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=27}};_l=Bs;U.GeneralString=_l;Bs.NAME="GeneralString";var Nl,As=class extends Pt{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=29}};Nl=As;U.CharacterString=Nl;As.NAME="CharacterString";var Tl,un=class extends ln{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]=Vt(this.year<2e3?this.year-1900:this.year-2e3,2),e[1]=Vt(this.month,2),e[2]=Vt(this.day,2),e[3]=Vt(this.hour,2),e[4]=Vt(this.minute,2),e[5]=Vt(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}}};Tl=un;U.UTCTime=Tl;un.NAME="UTCTime";var Rl,Ss=class extends un{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 p=parseInt(m.substring(0,2),10);if(isNaN(p.valueOf()))throw new Error("Wrong input string for conversion");if(a=f*p,m.length===4){if(p=parseInt(m.substring(2,4),10),isNaN(p.valueOf()))throw new Error("Wrong input string for conversion");c=f*p}}}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(Vt(this.year,4)),e.push(Vt(this.month,2)),e.push(Vt(this.day,2)),e.push(Vt(this.hour,2)),e.push(Vt(this.minute,2)),e.push(Vt(this.second,2)),this.millisecond!==0&&(e.push("."),e.push(Vt(this.millisecond,3))),e.push("Z"),e.join("")}return super.toString(t)}toJSON(){return{...super.toJSON(),millisecond:this.millisecond}}};Rl=Ss;U.GeneralizedTime=Rl;Ss.NAME="GeneralizedTime";var Ll,ks=class extends Se{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=31}};Ll=ks;U.DATE=Ll;ks.NAME="DATE";var Cl,Is=class extends Se{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=32}};Cl=Is;U.TimeOfDay=Cl;Is.NAME="TimeOfDay";var Ul,_s=class extends Se{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=33}};Ul=_s;U.DateTime=Ul;_s.NAME="DateTime";var Pl,Ns=class extends Se{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=34}};Pl=Ns;U.Duration=Pl;Ns.NAME="Duration";var Dl,Ts=class extends Se{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=14}};Dl=Ts;U.TIME=Dl;Ts.NAME="TIME";function vp(r){let{result:t}=Ir(r),e=t.valueBlock.value;return{n:$(le(e[1].toBigInt()),"base64url"),e:$(le(e[2].toBigInt()),"base64url"),d:$(le(e[3].toBigInt()),"base64url"),p:$(le(e[4].toBigInt()),"base64url"),q:$(le(e[5].toBigInt()),"base64url"),dp:$(le(e[6].toBigInt()),"base64url"),dq:$(le(e[7].toBigInt()),"base64url"),qi:$(le(e[8].toBigInt()),"base64url"),kty:"RSA",alg:"RS256"}}function Bp(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 M("JWK was missing components","ERR_INVALID_PARAMETERS");let e=new vt({value:[new pt({value:0}),pt.fromBigInt(ue(Z(r.n,"base64url"))),pt.fromBigInt(ue(Z(r.e,"base64url"))),pt.fromBigInt(ue(Z(r.d,"base64url"))),pt.fromBigInt(ue(Z(r.p,"base64url"))),pt.fromBigInt(ue(Z(r.q,"base64url"))),pt.fromBigInt(ue(Z(r.dp,"base64url"))),pt.fromBigInt(ue(Z(r.dq,"base64url"))),pt.fromBigInt(ue(Z(r.qi,"base64url")))]}).toBER();return new Uint8Array(e,0,e.byteLength)}function Ap(r){let{result:t}=Ir(r),e=t.valueBlock.value[1].valueBlock.value[0].valueBlock.value;return{kty:"RSA",n:$(le(e[0].toBigInt()),"base64url"),e:$(le(e[1].toBigInt()),"base64url")}}function Sp(r){if(r.n==null||r.e==null)throw new M("JWK was missing components","ERR_INVALID_PARAMETERS");let e=new vt({value:[new vt({value:[new te({value:"1.2.840.113549.1.1.1"}),new Ke]}),new Sr({valueHex:new vt({value:[pt.fromBigInt(ue(Z(r.n,"base64url"))),pt.fromBigInt(ue(Z(r.e,"base64url")))]}).toBER()})]}).toBER();return new Uint8Array(e,0,e.byteLength)}function le(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 ue(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 kp=16,bi=32,xi=1e4;async function Ip(r,t){let e=Ut.get(),s=new vt({value:[new pt({value:0}),new vt({value:[new te({value:"1.2.840.113549.1.1.1"}),new Ke]}),new Ae({valueHex:r.marshal()})]}).toBER(),o=new Uint8Array(s,0,s.byteLength),i=nr(kp),a=await pi(jr,t,i,{c:xi,dkLen:bi}),c=nr(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 vt({value:[new Ae({valueHex:i}),new pt({value:xi}),new pt({value:bi}),new vt({value:[new te({value:"1.2.840.113549.2.11"}),new Ke]})]}),g=new vt({value:[new te({value:"1.2.840.113549.1.5.13"}),new vt({value:[new vt({value:[new te({value:"1.2.840.113549.1.5.12"}),f]}),new vt({value:[new te({value:"2.16.840.1.101.3.4.1.42"}),new Ae({valueHex:c})]})]})]}),p=new vt({value:[g,new Ae({valueHex:u})]}).toBER(),h=new Uint8Array(p,0,p.byteLength);return["-----BEGIN ENCRYPTED PRIVATE KEY-----",...$(h,"base64pad").split(/(.{64})/).filter(Boolean),"-----END ENCRYPTED PRIVATE KEY-----"].join(`
|
|
7
|
-
`)}async function _p(r,t){let e=Ut.get(),n;if(r.includes("-----BEGIN ENCRYPTED PRIVATE KEY-----")){let s=Z(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}=Np(o),f=await pi(jr,t,a,{c,dkLen:l}),g=await e.subtle.importKey("raw",f,"AES-CBC",!1,["decrypt"]),m=fn(await e.subtle.decrypt({name:"AES-CBC",iv:i},g,u)),{result:p}=Ir(m);n=Vl(p)}else if(r.includes("-----BEGIN PRIVATE KEY-----")){let s=Z(r.replace("-----BEGIN PRIVATE KEY-----","").replace("-----END PRIVATE KEY-----","").replace(/\n/g,"").trim(),"base64pad"),{result:o}=Ir(s);n=Vl(o)}else throw new M("Could not parse private key from PEM data","ERR_INVALID_PARAMETERS");return Ei(n)}function Np(r){let t=r.valueBlock.value[0];if(t.valueBlock.value[0].toString()!=="OBJECT IDENTIFIER : 1.2.840.113549.1.5.13")throw new M("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 M("Only pkcs5PBKDF2 key derivation functions are supported","ERR_INVALID_PARAMS");let o=n.valueBlock.value[1],i=fn(o.valueBlock.value[0].getValue()),a=xi,c=bi;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 M("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 M("Only AES-CBC encryption schemes are supported","ERR_INVALID_PARAMS")}}}}let f=fn(l.valueBlock.value[1].getValue());return{cipherText:fn(r.valueBlock.value[1].getValue()),salt:i,iterations:a,keySize:c,iv:f}}function Vl(r){return fn(r.valueBlock.value[2].getValue())}function fn(r){return new Uint8Array(r,0,r.byteLength)}async function Hl(r){let t=await Ut.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 Kl(t);return{privateKey:e[0],publicKey:e[1]}}async function vi(r){let e=[await Ut.get().subtle.importKey("jwk",r,{name:"RSASSA-PKCS1-v1_5",hash:{name:"SHA-256"}},!0,["sign"]),await Tp(r)],n=await Kl({privateKey:e[0],publicKey:e[1]});return{privateKey:n[0],publicKey:n[1]}}async function Ol(r,t){let e=await Ut.get().subtle.importKey("jwk",r,{name:"RSASSA-PKCS1-v1_5",hash:{name:"SHA-256"}},!1,["sign"]),n=await Ut.get().subtle.sign({name:"RSASSA-PKCS1-v1_5"},e,t instanceof Uint8Array?t:t.subarray());return new Uint8Array(n,0,n.byteLength)}async function Ml(r,t,e){let n=await Ut.get().subtle.importKey("jwk",r,{name:"RSASSA-PKCS1-v1_5",hash:{name:"SHA-256"}},!1,["verify"]);return Ut.get().subtle.verify({name:"RSASSA-PKCS1-v1_5"},n,t,e instanceof Uint8Array?e:e.subarray())}async function Kl(r){if(r.privateKey==null||r.publicKey==null)throw new M("Private and public key are required","ERR_INVALID_PARAMETERS");return Promise.all([Ut.get().subtle.exportKey("jwk",r.privateKey),Ut.get().subtle.exportKey("jwk",r.publicKey)])}async function Tp(r){return Ut.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 Ls(r){if(r.kty!=="RSA")throw new M("invalid key type","ERR_INVALID_KEY_TYPE");if(r.n==null)throw new M("invalid key modulus","ERR_INVALID_KEY_MODULUS");return Z(r.n,"base64url").length*8}var dn=8192,hn=class{_key;constructor(t){this._key=t}verify(t,e){return Ml(this._key,e,t)}marshal(){return Fe.jwkToPkix(this._key)}get bytes(){return ie.encode({Type:at.RSA,Data:this.marshal()}).subarray()}equals(t){return ft(this.bytes,t.bytes)}hash(){let t=St.digest(this.bytes);return Ft(t)?t.then(({bytes:e})=>e):t.bytes}},_r=class{_key;_publicKey;constructor(t,e){this._key=t,this._publicKey=e}genSecret(){return nr(16)}sign(t){return Ol(this._key,t)}get public(){if(this._publicKey==null)throw new M("public key not provided","ERR_PUBKEY_NOT_PROVIDED");return new hn(this._publicKey)}marshal(){return Fe.jwkToPkcs1(this._key)}get bytes(){return ae.encode({Type:at.RSA,Data:this.marshal()}).subarray()}equals(t){return ft(this.bytes,t.bytes)}hash(){let t=St.digest(this.bytes);return Ft(t)?t.then(({bytes:e})=>e):t.bytes}async id(){let t=await this.public.hash();return $(t,"base58btc")}async export(t,e="pkcs-8"){if(e==="pkcs-8")return Fe.exportToPem(this,t);if(e==="libp2p-key")return Er(this.bytes,t);throw new M(`export format '${e}' is not supported`,"ERR_INVALID_EXPORT_FORMAT")}};async function Ei(r){let t=Fe.pkcs1ToJwk(r);if(Ls(t)>dn)throw new M("key size is too large","ERR_KEY_SIZE_TOO_LARGE");let e=await vi(t);return new _r(e.privateKey,e.publicKey)}function Lp(r){let t=Fe.pkixToJwk(r);if(Ls(t)>dn)throw new M("key size is too large","ERR_KEY_SIZE_TOO_LARGE");return new hn(t)}async function Cp(r){if(Ls(r)>dn)throw new M("key size is too large","ERR_KEY_SIZE_TOO_LARGE");let t=await vi(r);return new _r(t.privateKey,t.publicKey)}async function Up(r){if(r>dn)throw new M("key size is too large","ERR_KEY_SIZE_TOO_LARGE");let t=await Hl(r);return new _r(t.privateKey,t.publicKey)}var _i={};mt(_i,{Secp256k1PrivateKey:()=>gn,Secp256k1PublicKey:()=>pn,generateKeyPair:()=>zp,unmarshalSecp256k1PrivateKey:()=>Gp,unmarshalSecp256k1PublicKey:()=>jp});var Pp=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]),$e=new Uint32Array([1779033703,3144134277,1013904242,2773480762,1359893119,2600822924,528734635,1541459225]),qe=new Uint32Array(64),Ai=class extends yr{constructor(){super(64,32,8,!1),this.A=$e[0]|0,this.B=$e[1]|0,this.C=$e[2]|0,this.D=$e[3]|0,this.E=$e[4]|0,this.F=$e[5]|0,this.G=$e[6]|0,this.H=$e[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)qe[f]=t.getUint32(e,!1);for(let f=16;f<64;f++){let g=qe[f-15],m=qe[f-2],p=Wt(g,7)^Wt(g,18)^g>>>3,h=Wt(m,17)^Wt(m,19)^m>>>10;qe[f]=h+qe[f-7]+p+qe[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=Wt(a,6)^Wt(a,11)^Wt(a,25),m=u+g+yc(a,c,l)+Pp[f]+qe[f]|0,h=(Wt(n,2)^Wt(n,13)^Wt(n,22))+wc(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(){qe.fill(0)}destroy(){this.set(0,0,0,0,0,0,0,0),this.buffer.fill(0)}};var Nr=Tn(()=>new Ai);function Dp(r){let t=Wr(r);$t(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:Vp,hexToBytes:Hp}=Cn,or={Err:class extends Error{constructor(t=""){super(t)}},_parseInt(r){let{Err:t}=or;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:Vp(n),l:r.subarray(e+2)}},toSig(r){let{Err:t}=or,e=typeof r=="string"?Hp(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}=or._parseInt(e.subarray(2)),{d:i,l:a}=or._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}`}},_e=BigInt(0),Gt=BigInt(1),Ow=BigInt(2),Fl=BigInt(3),Mw=BigInt(4);function Op(r){let t=Dp(r),{Fp:e}=t,n=t.toBytes||((p,h,d)=>{let b=h.toAffine();return xe(Uint8Array.from([4]),e.toBytes(b.x),e.toBytes(b.y))}),s=t.fromBytes||(p=>{let h=p.subarray(1),d=e.fromBytes(h.subarray(0,e.BYTES)),b=e.fromBytes(h.subarray(e.BYTES,2*e.BYTES));return{x:d,y:b}});function o(p){let{a:h,b:d}=t,b=e.sqr(p),v=e.mul(b,p);return e.add(e.add(v,e.mul(p,h)),d)}if(!e.eql(e.sqr(t.Gy),o(t.Gx)))throw new Error("bad generator point: equation left != right");function i(p){return typeof p=="bigint"&&_e<p&&p<t.n}function a(p){if(!i(p))throw new Error("Expected valid bigint: 0 < bigint < curve.n")}function c(p){let{allowedPrivateKeyLengths:h,nByteLength:d,wrapPrivateKey:b,n:v}=t;if(h&&typeof p!="bigint"){if(Pe(p)&&(p=ye(p)),typeof p!="string"||!h.includes(p.length))throw new Error("Invalid key");p=p.padStart(d*2,"0")}let w;try{w=typeof p=="bigint"?p:we(st("private key",p,d))}catch{throw new Error(`private key must be ${d} bytes, hex or bigint, not ${typeof p}`)}return b&&(w=X(w,v)),a(w),w}let l=new Map;function u(p){if(!(p instanceof f))throw new Error("ProjectivePoint expected")}class f{constructor(h,d,b){if(this.px=h,this.py=d,this.pz=b,h==null||!e.isValid(h))throw new Error("x required");if(d==null||!e.isValid(d))throw new Error("y required");if(b==null||!e.isValid(b))throw new Error("z required")}static fromAffine(h){let{x:d,y:b}=h||{};if(!h||!e.isValid(d)||!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(d)&&v(b)?f.ZERO:new f(d,b,e.ONE)}get x(){return this.toAffine().x}get y(){return this.toAffine().y}static normalizeZ(h){let d=e.invertBatch(h.map(b=>b.pz));return h.map((b,v)=>b.toAffine(d[v])).map(f.fromAffine)}static fromHex(h){let d=f.fromAffine(s(st("pointHex",h)));return d.assertValidity(),d}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:d}=this.toAffine();if(!e.isValid(h)||!e.isValid(d))throw new Error("bad point: x or y not FE");let b=e.sqr(d),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:d,py:b,pz:v}=this,{px:w,py:A,pz:B}=h,S=e.eql(e.mul(d,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:d}=t,b=e.mul(d,Fl),{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:d,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,Fl),R=e.mul(d,w),O=e.mul(b,A),H=e.mul(v,B),W=e.add(d,b),x=e.add(w,A);W=e.mul(W,x),x=e.add(R,O),W=e.sub(W,x),x=e.add(d,v);let I=e.add(w,B);return x=e.mul(x,I),I=e.add(R,H),x=e.sub(x,I),I=e.add(b,v),S=e.add(A,B),I=e.mul(I,S),S=e.add(O,H),I=e.sub(I,S),_=e.mul(V,x),S=e.mul(P,H),_=e.add(S,_),S=e.sub(O,_),_=e.add(O,_),N=e.mul(S,_),O=e.add(R,R),O=e.add(O,R),H=e.mul(V,H),x=e.mul(P,x),O=e.add(O,H),H=e.sub(R,H),H=e.mul(V,H),x=e.add(x,H),R=e.mul(O,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,O),_=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,d=>{let b=e.invertBatch(d.map(v=>v.pz));return d.map((v,w)=>v.toAffine(b[w])).map(f.fromAffine)})}multiplyUnsafe(h){let d=f.ZERO;if(h===_e)return d;if(a(h),h===Gt)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=d,N=d,_=this;for(;w>_e||B>_e;)w&Gt&&(S=S.add(_)),B&Gt&&(N=N.add(_)),_=_.double(),w>>=Gt,B>>=Gt;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 d=h,b,v,{endo:w}=t;if(w){let{k1neg:A,k1:B,k2neg:S,k2:N}=w.splitScalar(d),{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(d);b=A,v=B}return f.normalizeZ([b,v])[0]}multiplyAndAddUnsafe(h,d,b){let v=f.BASE,w=(B,S)=>S===_e||S===Gt||!B.equals(v)?B.multiplyUnsafe(S):B.multiply(S),A=w(this,d).add(w(h,b));return A.is0()?void 0:A}toAffine(h){let{px:d,py:b,pz:v}=this,w=this.is0();h==null&&(h=w?e.ONE:e.inv(v));let A=e.mul(d,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:d}=t;if(h===Gt)return!0;if(d)return d(f,this);throw new Error("isTorsionFree() has not been declared for the elliptic curve")}clearCofactor(){let{h,clearCofactor:d}=t;return h===Gt?this:d?d(f,this):this.multiplyUnsafe(t.h)}toRawBytes(h=!0){return this.assertValidity(),n(f,this,h)}toHex(h=!0){return ye(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=Dn(f,t.endo?Math.ceil(g/2):g);return{CURVE:t,ProjectivePoint:f,normPrivateKeyToScalar:c,weierstrassEquation:o,isWithinCurveOrder:i}}function Mp(r){let t=Wr(r);return $t(t,{hash:"hash",hmac:"function",randomBytes:"function"},{bits2int:"function",bits2int_modN:"function",lowS:"boolean"}),Object.freeze({lowS:!0,...t})}function $l(r){let t=Mp(r),{Fp:e,n}=t,s=e.BYTES+1,o=2*e.BYTES+1;function i(x){return _e<x&&x<e.ORDER}function a(x){return X(x,n)}function c(x){return Un(x,n)}let{ProjectivePoint:l,normPrivateKeyToScalar:u,weierstrassEquation:f,isWithinCurveOrder:g}=Op({...t,toBytes(x,I,C){let E=I.toAffine(),y=e.toBytes(E.x),k=xe;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=we(E);if(!i(y))throw new Error("Point is not on curve");let k=f(y),T;try{T=e.sqrt(k)}catch(F){let j=F instanceof Error?": "+F.message:"";throw new Error("Point is not on curve"+j)}let L=(T&Gt)===Gt;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=>ye(De(x,t.nByteLength));function p(x){let I=n>>Gt;return x>I}function h(x){return p(x)?a(-x):x}let d=(x,I,C)=>we(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(d(I,0,C),d(I,C,2*C))}static fromDER(I){let{r:C,s:E}=or.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",K=l.fromHex(L+m(T)),F=c(T),j=a(-k*F),q=a(E*F),G=l.BASE.multiplyAndAddUnsafe(K,j,q);if(!G)throw new Error("point at infinify");return G.assertValidity(),G}hasHighS(){return p(this.s)}normalizeS(){return this.hasHighS()?new b(this.r,a(-this.s),this.recovery):this}toDERRawBytes(){return Ye(this.toDERHex())}toDERHex(){return or.hexFromSig({r:this.r,s:this.s})}toCompactRawBytes(){return Ye(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=qo(t.n);return _c(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=Pe(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=we(x),C=x.length*8-t.nBitLength;return C>0?I>>BigInt(C):I},N=t.bits2int_modN||function(x){return a(S(x))},_=zr(t.nBitLength);function V(x){if(typeof x!="bigint")throw new Error("bigint expected");if(!(_e<=x&&x<_))throw new Error(`bigint expected < 2^${t.nBitLength}`);return De(x,t.nByteLength)}function P(x,I,C=R){if(["recovered","canonical"].some(et=>et 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 K=N(x),F=u(I),j=[V(F),V(K)];if(L!=null&&L!==!1){let et=L===!0?y(e.BYTES):L;j.push(st("extraEntropy",et))}let q=xe(...j),G=K;function nt(et){let Bt=S(et);if(!g(Bt))return;let At=c(Bt),gt=l.BASE.multiply(Bt).toAffine(),Nt=a(gt.x);if(Nt===_e)return;let he=a(At*a(G+Nt*F));if(he===_e)return;let Ge=(gt.x===Nt?0:2)|Number(gt.y&Gt),Fr=he;return k&&p(he)&&(Fr=h(he),Ge^=1),new b(Nt,Fr,Ge)}return{seed:q,k2sig:nt}}let R={lowS:t.lowS,prehash:!1},O={lowS:t.lowS,prehash:!1};function H(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=O){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,K;try{if(typeof y=="string"||Pe(y))try{L=b.fromDER(y)}catch(gt){if(!(gt instanceof or.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");K=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:F,s:j}=L,q=N(I),G=c(j),nt=a(q*G),et=a(F*G),Bt=l.BASE.multiplyAndAddUnsafe(K,nt,et)?.toAffine();return Bt?a(Bt.x)===F:!1}return{CURVE:t,getPublicKey:w,getSharedSecret:B,sign:H,verify:W,ProjectivePoint:l,Signature:b,utils:v}}function Kp(r){return{hash:r,hmac:(t,...e)=>He(r,t,Uo(...e)),randomBytes:We}}function ql(r,t){let e=n=>$l({...r,...Kp(n)});return Object.freeze({...e(t),create:e})}var zl=BigInt("0xfffffffffffffffffffffffffffffffffffffffffffffffffffffffefffffc2f"),Gl=BigInt("0xfffffffffffffffffffffffffffffffebaaedce6af48a03bbfd25e8cd0364141"),Fp=BigInt(1),Si=BigInt(2),jl=(r,t)=>(r+t/Si)/t;function $p(r){let t=zl,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,Si,t)*l%t,p=ot(m,s,t)*m%t,h=ot(p,o,t)*p%t,d=ot(h,a,t)*h%t,b=ot(d,c,t)*d%t,v=ot(b,a,t)*h%t,w=ot(v,e,t)*u%t,A=ot(w,i,t)*p%t,B=ot(A,n,t)*l%t,S=ot(B,Si,t);if(!ki.eql(ki.sqr(S),r))throw new Error("Cannot find square root");return S}var ki=Pn(zl,void 0,void 0,{sqrt:$p}),re=ql({a:BigInt(0),b:BigInt(7),Fp:ki,n:Gl,Gx:BigInt("55066263022277343669578718895168534326250603453777594175500187360389116729240"),Gy:BigInt("32670510020758816978083085130507043184471273380659243275938904335757337482424"),h:BigInt(1),lowS:!0,endo:{beta:BigInt("0x7ae96a2b657c07106e64479eac3434e99cf0497512f58995c1396c28719501ee"),splitScalar:r=>{let t=Gl,e=BigInt("0x3086d221a7d46bcde86c90e49284eb15"),n=-Fp*BigInt("0xe4437ed6010e88286f547fa90abfe4c3"),s=BigInt("0x114ca50f7a8e2f3f657c1108d9d44cfd8"),o=e,i=BigInt("0x100000000000000000000000000000000"),a=jl(o*r,t),c=jl(-n*r,t),l=X(r-a*e-c*s,t),u=X(-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),Yw=BigInt(0);var Zw=re.ProjectivePoint;function Wl(){return re.utils.randomPrivateKey()}function Yl(r,t){let e=St.digest(t instanceof Uint8Array?t:t.subarray());if(Ft(e))return e.then(({digest:n})=>re.sign(n,r).toDERRawBytes()).catch(n=>{throw new M(String(n),"ERR_INVALID_INPUT")});try{return re.sign(e.digest,r).toDERRawBytes()}catch(n){throw new M(String(n),"ERR_INVALID_INPUT")}}function Zl(r,t,e){let n=St.digest(e instanceof Uint8Array?e:e.subarray());if(Ft(n))return n.then(({digest:s})=>re.verify(t,s,r)).catch(s=>{throw new M(String(s),"ERR_INVALID_INPUT")});try{return re.verify(t,n.digest,r)}catch(s){throw new M(String(s),"ERR_INVALID_INPUT")}}function Xl(r){return re.ProjectivePoint.fromHex(r).toRawBytes(!0)}function Jl(r){try{re.getPublicKey(r,!0)}catch(t){throw new M(String(t),"ERR_INVALID_PRIVATE_KEY")}}function Ii(r){try{re.ProjectivePoint.fromHex(r)}catch(t){throw new M(String(t),"ERR_INVALID_PUBLIC_KEY")}}function Ql(r){try{return re.getPublicKey(r,!0)}catch(t){throw new M(String(t),"ERR_INVALID_PRIVATE_KEY")}}var pn=class{_key;constructor(t){Ii(t),this._key=t}verify(t,e){return Zl(this._key,e,t)}marshal(){return Xl(this._key)}get bytes(){return ie.encode({Type:at.Secp256k1,Data:this.marshal()}).subarray()}equals(t){return ft(this.bytes,t.bytes)}async hash(){let t=St.digest(this.bytes),e;return Ft(t)?{bytes:e}=await t:e=t.bytes,e}},gn=class{_key;_publicKey;constructor(t,e){this._key=t,this._publicKey=e??Ql(t),Jl(this._key),Ii(this._publicKey)}sign(t){return Yl(this._key,t)}get public(){return new pn(this._publicKey)}marshal(){return this._key}get bytes(){return ae.encode({Type:at.Secp256k1,Data:this.marshal()}).subarray()}equals(t){return ft(this.bytes,t.bytes)}hash(){let t=St.digest(this.bytes);return Ft(t)?t.then(({bytes:e})=>e):t.bytes}async id(){let t=await this.public.hash();return $(t,"base58btc")}async export(t,e="libp2p-key"){if(e==="libp2p-key")return Er(this.bytes,t);throw new M(`export format '${e}' is not supported`,"ERR_INVALID_EXPORT_FORMAT")}};function Gp(r){return new gn(r)}function jp(r){return new pn(r)}async function zp(){let r=Wl();return new gn(r)}var ir={rsa:Bi,ed25519:di,secp256k1:_i};function tu(r){let t=Object.keys(ir).join(" / ");return new M(`invalid or unsupported key type ${r}. Must be ${t}`,"ERR_UNSUPPORTED_KEY_TYPE")}function eu(r){let t=ie.decode(r),e=t.Data??new Uint8Array;switch(t.Type){case at.RSA:return ir.rsa.unmarshalRsaPublicKey(e);case at.Ed25519:return ir.ed25519.unmarshalEd25519PublicKey(e);case at.Secp256k1:return ir.secp256k1.unmarshalSecp256k1PublicKey(e);default:throw tu(t.Type??"unknown")}}async function Ni(r){let t=ae.decode(r),e=t.Data??new Uint8Array;switch(t.Type){case at.RSA:return ir.rsa.unmarshalRsaPrivateKey(e);case at.Ed25519:return ir.ed25519.unmarshalEd25519PrivateKey(e);case at.Secp256k1:return ir.secp256k1.unmarshalSecp256k1PrivateKey(e);default:throw tu(t.Type??"RSA")}}var nu=Symbol.for("nodejs.util.inspect.custom"),ru=Object.values(se).map(r=>r.decoder).reduce((r,t)=>r.or(t),se.identity.decoder),su=114,Li=36,Ci=37,mn=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()})`}[co]=!0;toString(){return this.string==null&&(this.string=ut.encode(this.multihash.bytes).slice(1)),this.string}toCID(){return Kt.createV1(su,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 Ui(t).equals(this);if(t?.multihash?.bytes!=null)return ft(this.multihash.bytes,t.multihash.bytes);throw new Error("not valid Id")}[nu](){return`PeerId(${this.toString()})`}},Tr=class extends mn{type="RSA";publicKey;constructor(t){super({...t,type:"RSA"}),this.publicKey=t.publicKey}},Rr=class extends mn{type="Ed25519";publicKey;constructor(t){super({...t,type:"Ed25519"}),this.publicKey=t.multihash.digest}},Lr=class extends mn{type="secp256k1";publicKey;constructor(t){super({...t,type:"secp256k1"}),this.publicKey=t.multihash.digest}},Ti=2336,Ri=class{type="url";multihash;privateKey;publicKey;url;constructor(t){this.url=t.toString(),this.multihash=pe.digest(Z(this.url))}[nu](){return`PeerId(${this.url})`}[co]=!0;toString(){return this.toCID().toString()}toCID(){return Kt.createV1(Ti,this.multihash)}toBytes(){return this.toCID().bytes}equals(t){return t==null?!1:(t instanceof Uint8Array&&(t=$(t)),t.toString()===this.toString())}};function Ui(r,t){if(t=t??ru,r.charAt(0)==="1"||r.charAt(0)==="Q"){let e=Re(ut.decode(`z${r}`));return r.startsWith("12D")?new Rr({multihash:e}):r.startsWith("16U")?new Lr({multihash:e}):new Tr({multihash:e})}return Wp(ru.decode(r))}function Wp(r){try{let t=Re(r);if(t.code===pe.code){if(t.digest.length===Li)return new Rr({multihash:t});if(t.digest.length===Ci)return new Lr({multihash:t})}if(t.code===St.code)return new Tr({multihash:t})}catch{return Yp(Kt.decode(r))}throw new Error("Supplied PeerID CID is invalid")}function Yp(r){if(r==null||r.multihash==null||r.version==null||r.version===1&&r.code!==su&&r.code!==Ti)throw new Error("Supplied PeerID CID is invalid");if(r.code===Ti){let e=$(r.multihash.digest);return new Ri(new URL(e))}let t=r.multihash;if(t.code===St.code)return new Tr({multihash:r.multihash});if(t.code===pe.code){if(t.digest.length===Li)return new Rr({multihash:r.multihash});if(t.digest.length===Ci)return new Lr({multihash:r.multihash})}throw new Error("Supplied PeerID CID is invalid")}async function Pi(r,t){return r.length===Li?new Rr({multihash:zt(pe.code,r),privateKey:t}):r.length===Ci?new Lr({multihash:zt(pe.code,r),privateKey:t}):new Tr({multihash:await St.digest(r),publicKey:r,privateKey:t})}var iu=Symbol.for("@achingbrain/uint8arraylist");function ou(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 Cs(r){return!!r?.[iu]}var ct=class r{bufs;length;[iu]=!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(Cs(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(Cs(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=ou(this.bufs,t);return e.buf[e.index]}set(t,e){let n=ou(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(Cs(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 Et(n,s)}subarray(t,e){let{bufs:n,length:s}=this._subList(t,e);return n.length===1?n[0]:Et(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(!Cs(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=yt(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=yt(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=yt(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=yt(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=yt(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=yt(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=yt(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=yt(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 Us(r){return r[Symbol.asyncIterator]!=null}var Ps=r=>{let t=dt(r),e=wt(t);return oe(r,e),Ps.bytes=t,e};Ps.bytes=0;function au(r,t){t=t??{};let e=t.lengthEncoder??Ps;function*n(s){let o=e(s.byteLength);o instanceof Uint8Array?yield o:yield*o,s instanceof Uint8Array?yield s:yield*s}return Us(r)?async function*(){for await(let s of r)yield*n(s)}():function*(){for(let s of r)yield*n(s)}()}au.single=(r,t)=>{t=t??{};let e=t.lengthEncoder??Ps;return new ct(e(r.byteLength),r)};var Cr=Ga(uu(),1);var Xp=8,Jp=1024*1024*4,ar;(function(r){r[r.LENGTH=0]="LENGTH",r[r.DATA=1]="DATA"})(ar||(ar={}));var Di=r=>{let t=Jt(r);return Di.bytes=dt(t),t};Di.bytes=0;function yn(r,t){let e=new ct,n=ar.LENGTH,s=-1,o=t?.lengthDecoder??Di,i=t?.maxLengthLength??Xp,a=t?.maxDataLength??Jp;function*c(){for(;e.byteLength>0;){if(n===ar.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=ar.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===ar.DATA){if(e.byteLength<s)break;let l=e.sublist(0,s);e.consume(s),t?.onData!=null&&t.onData(l),yield l,n=ar.LENGTH}}}return Us(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 Ct(){let r={};return r.promise=new Promise((t,e)=>{r.resolve=t,r.reject=e}),r}var Ds=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 Dt(r,t,e){if(t==null)return r;if(t.aborted)return Promise.reject(new Ds(e?.errorMessage,e?.errorCode));let n,s=new Ds(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 Vi=class{readNext;haveNext;ended;nextResult;constructor(){this.ended=!1,this.readNext=Ct(),this.haveNext=Ct()}[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=Ct(),t}async throw(t){return this.ended=!0,t!=null&&(this.haveNext.promise.catch(()=>{}),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");for(;this.nextResult!=null;)await this.readNext.promise;t!=null?this.nextResult={done:!1,value:t}:(this.ended=!0,this.nextResult={done:!0,value:void 0}),this.haveNext.resolve(),this.haveNext=Ct(),await Dt(this.readNext.promise,e?.signal,e)}};function fu(){return new Vi}var Vs=class extends Error{code;constructor(t,e){super(t),this.code=e}},Hi=class extends Vs{type;constructor(t){super(t,"ABORT_ERR"),this.type="aborted"}};function hu(r,t){let e=fu();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 ct;return{read:async(i,a)=>{a?.signal?.throwIfAborted();let c,l=new Promise((u,f)=>{c=()=>{f(new Hi("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 ct:g}for(;s.byteLength<i;){let{value:f,done:g}=await Promise.race([n.next(),l]);if(g===!0)throw new Vs("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 Hs=class extends Error{code;constructor(t,e){super(t),this.code=e}};function Oi(r,t={}){let e=hu(r,t);t.maxDataLength!=null&&t.maxLengthLength==null&&(t.maxLengthLength=dt(t.maxDataLength));let n=t?.lengthDecoder??Jt,s=t?.lengthEncoder??oe;return{read:async i=>{let a=-1,c=new ct;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 Hs("message length length too long","ERR_MSG_LENGTH_TOO_LONG");if(a>-1)break}if(t?.maxDataLength!=null&&a>t.maxDataLength)throw new Hs("message length too long","ERR_MSG_DATA_TOO_LONG");return e.read(a,i)},write:async(i,a)=>{await e.write(new ct(s(i.byteLength),i),a)},writeV:async(i,a)=>{let c=new ct(...i.flatMap(l=>[s(l.byteLength),l]));await e.write(c,a)},unwrap:()=>e.unwrap()}}function Mi(){let r=Ct(),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 du(){let r=Mi(),t=Mi();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 Ki=class extends Error{type;code;constructor(t,e){super(t??"The operation was aborted"),this.type="aborted",this.code=e??"ABORT_ERR"}};function Pr(r={}){return Qp(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 Qp(r,t){t=t??{};let e=t.onEnd,n=new Ur,s,o,i,a=Ct(),c=async()=>{try{return n.isEmpty()?i?{done:!0}:await new Promise((d,b)=>{o=v=>{o=null,n.push(v);try{d(r(n))}catch(w){b(w)}return s}}):r(n)}finally{n.isEmpty()&&queueMicrotask(()=>{a.resolve(),a=Ct()})}},l=d=>o!=null?o(d):(n.push(d),s),u=d=>(n=new Ur,o!=null?o({error:d}):(n.push({error:d}),s)),f=d=>{if(i)return s;if(t?.objectMode!==!0&&d?.byteLength==null)throw new Error("objectMode was not true but tried to push non-Uint8Array value");return l({done:!1,value:d})},g=d=>i?s:(i=!0,d!=null?u(d):l({done:!0})),m=()=>(n=new Ur,g(),{done:!0}),p=d=>(g(d),{done:!0});if(s={[Symbol.asyncIterator](){return this},next:c,return:m,throw:p,push:f,end:g,get readableLength(){return n.size},onEmpty:async d=>{let b=d?.signal;if(b?.throwIfAborted(),n.isEmpty())return;let v,w;b!=null&&(v=new Promise((A,B)=>{w=()=>{B(new Ki)},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(d){return h.throw(d),e!=null&&(e(d),e=void 0),{done:!0}},return(){return h.return(),e!=null&&(e(),e=void 0),{done:!0}},push:f,end(d){return h.end(d),e!=null&&(e(d),e=void 0),s},get readableLength(){return h.readableLength},onEmpty:d=>h.onEmpty(d)},s}function t0(r){return r[Symbol.asyncIterator]!=null}function e0(...r){let t=[];for(let e of r)t0(e)||t.push(e);return t.length===r.length?function*(){for(let e of t)yield*e}():async function*(){let e=Pr({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 pu=e0;function gu(r,...t){if(r==null)throw new Error("Empty pipeline");if(Fi(r)){let n=r;r=()=>n.source}else if(yu(r)||mu(r)){let n=r;r=()=>n}let e=[r,...t];if(e.length>1&&Fi(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++)Fi(e[n])&&(e[n]=n0(e[n]));return r0(...e)}var r0=(...r)=>{let t;for(;r.length>0;)t=r.shift()(t);return t},mu=r=>r?.[Symbol.asyncIterator]!=null,yu=r=>r?.[Symbol.iterator]!=null,Fi=r=>r==null?!1:r.sink!=null&&r.source!=null,n0=r=>t=>{let e=r.sink(t);if(e?.then!=null){let n=Pr({objectMode:!0});e.then(()=>{n.end()},i=>{n.end(i)});let s,o=r.source;if(mu(o))s=async function*(){yield*o,n.end()};else if(yu(o))s=function*(){yield*o,n.end()};else throw new Error("Unknown duplex source type - must be Iterable or AsyncIterable");return pu(n,s())}return r.source};var Dr=!!globalThis.process?.env?.DUMP_SESSION_KEYS;function Ms(r){if(!Number.isSafeInteger(r)||r<0)throw new Error(`positive integer expected, not ${r}`)}function $i(r){if(typeof r!="boolean")throw new Error(`boolean expected, not ${r}`)}function qi(r){return r instanceof Uint8Array||r!=null&&typeof r=="object"&&r.constructor.name==="Uint8Array"}function Ht(r,...t){if(!qi(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 wu(r,t){Ht(r);let e=t.outputLen;if(r.length<e)throw new Error(`digestInto() expects output buffer of length at least ${e}`)}var Ne=r=>new Uint32Array(r.buffer,r.byteOffset,Math.floor(r.byteLength/4)),bu=r=>new DataView(r.buffer,r.byteOffset,r.byteLength),s0=new Uint8Array(new Uint32Array([287454020]).buffer)[0]===68;if(!s0)throw new Error("Non little-endian hardware is not supported");function o0(r){if(typeof r!="string")throw new Error(`string expected, got ${typeof r}`);return new Uint8Array(new TextEncoder().encode(r))}function Ks(r){if(typeof r=="string")r=o0(r);else if(qi(r))r=r.slice();else throw new Error(`Uint8Array expected, got ${typeof r}`);return r}function xu(r,t){if(t==null||typeof t!="object")throw new Error("options must be defined");return Object.assign(r,t)}function Eu(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 ji=(r,t)=>(Object.assign(t,r),t);function zi(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 It=(r,t)=>r[t++]&255|(r[t++]&255)<<8,Wi=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),Ht(t,32);let e=It(t,0),n=It(t,2),s=It(t,4),o=It(t,6),i=It(t,8),a=It(t,10),c=It(t,12),l=It(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]=It(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],p=i[7],h=i[8],d=i[9],b=It(t,e+0),v=It(t,e+2),w=It(t,e+4),A=It(t,e+6),B=It(t,e+8),S=It(t,e+10),N=It(t,e+12),_=It(t,e+14),V=o[0]+(b&8191),P=o[1]+((b>>>13|v<<3)&8191),R=o[2]+((v>>>10|w<<6)&8191),O=o[3]+((w>>>7|A<<9)&8191),H=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*d)+R*(5*h)+O*(5*p)+H*(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*d)+O*(5*h)+H*(5*p);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+O*(5*d)+H*(5*h);y=L>>>13,L&=8191,L+=W*(5*p)+x*(5*m)+I*(5*g)+C*(5*f)+E*(5*u),y+=L>>>13,L&=8191;let K=y+V*u+P*l+R*c+O*a+H*(5*d);y=K>>>13,K&=8191,K+=W*(5*h)+x*(5*p)+I*(5*m)+C*(5*g)+E*(5*f),y+=K>>>13,K&=8191;let F=y+V*f+P*u+R*l+O*c+H*a;y=F>>>13,F&=8191,F+=W*(5*d)+x*(5*h)+I*(5*p)+C*(5*m)+E*(5*g),y+=F>>>13,F&=8191;let j=y+V*g+P*f+R*u+O*l+H*c;y=j>>>13,j&=8191,j+=W*a+x*(5*d)+I*(5*h)+C*(5*p)+E*(5*m),y+=j>>>13,j&=8191;let q=y+V*m+P*g+R*f+O*u+H*l;y=q>>>13,q&=8191,q+=W*c+x*a+I*(5*d)+C*(5*h)+E*(5*p),y+=q>>>13,q&=8191;let G=y+V*p+P*m+R*g+O*f+H*u;y=G>>>13,G&=8191,G+=W*l+x*c+I*a+C*(5*d)+E*(5*h),y+=G>>>13,G&=8191;let nt=y+V*h+P*p+R*m+O*g+H*f;y=nt>>>13,nt&=8191,nt+=W*u+x*l+I*c+C*a+E*(5*d),y+=nt>>>13,nt&=8191;let et=y+V*d+P*h+R*p+O*m+H*g;y=et>>>13,et&=8191,et+=W*f+x*u+I*l+C*c+E*a,y+=et>>>13,et&=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]=K,o[4]=F,o[5]=j,o[6]=q,o[7]=G,o[8]=nt,o[9]=et}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),wu(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 i0(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 vu=i0(r=>new Wi(r));var Au=r=>Uint8Array.from(r.split("").map(t=>t.charCodeAt(0))),a0=Au("expand 16-byte k"),c0=Au("expand 32-byte k"),l0=Ne(a0),Su=Ne(c0),gx=Su.slice();function D(r,t){return r<<t|r>>>32-t}function Yi(r){return r.byteOffset%4===0}var Fs=64,u0=16,ku=2**32-1,Bu=new Uint32Array;function f0(r,t,e,n,s,o,i,a){let c=s.length,l=new Uint8Array(Fs),u=Ne(l),f=Yi(s)&&Yi(o),g=f?Ne(s):Bu,m=f?Ne(o):Bu;for(let p=0;p<c;i++){if(r(t,e,n,u,i,a),i>=ku)throw new Error("arx: counter overflow");let h=Math.min(Fs,c-p);if(f&&h===Fs){let d=p/4;if(p%4!==0)throw new Error("arx: invalid block position");for(let b=0,v;b<u0;b++)v=d+b,m[v]=g[v]^u[b];p+=Fs;continue}for(let d=0,b;d<h;d++)b=p+d,o[b]=s[b]^l[d];p+=h}}function Zi(r,t){let{allowShortKeys:e,extendNonceFn:n,counterLength:s,counterRight:o,rounds:i}=xu({allowShortKeys:!1,counterLength:8,counterRight:!1,rounds:20},t);if(typeof r!="function")throw new Error("core must be a function");return Ms(s),Ms(i),$i(o),$i(e),(a,c,l,u,f=0)=>{Ht(a),Ht(c),Ht(l);let g=l.length;if(u||(u=new Uint8Array(g)),Ht(u),Ms(f),f<0||f>=ku)throw new Error("arx: counter overflow");if(u.length<g)throw new Error(`arx: output (${u.length}) is shorter than data (${g})`);let m=[],p=a.length,h,d;if(p===32)h=a.slice(),m.push(h),d=Su;else if(p===16&&e)h=new Uint8Array(32),h.set(a),h.set(a,16),d=l0,m.push(h);else throw new Error(`arx: invalid 32-byte key, got length=${p}`);Yi(c)||(c=c.slice(),m.push(c));let b=Ne(h);if(n){if(c.length!==24)throw new Error("arx: extended nonce must be 24 bytes");n(d,b,Ne(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=Ne(c);for(f0(r,d,b,w,l,u,f,i);m.length>0;)m.pop().fill(0);return u}}function Nu(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],p=t[4],h=t[5],d=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,O=g,H=m,W=p,x=h,I=d,C=b,E=v,y=w,k=A,T=B;for(let K=0;K<o;K+=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),_=_+O|0,k=D(k^_,16),I=I+k|0,O=D(O^I,12),_=_+O|0,k=D(k^_,8),I=I+k|0,O=D(O^I,7),V=V+H|0,T=D(T^V,16),C=C+T|0,H=D(H^C,12),V=V+H|0,T=D(T^V,8),C=C+T|0,H=D(H^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+O|0,E=D(E^N,16),C=C+E|0,O=D(O^C,12),N=N+O|0,E=D(E^N,8),C=C+E|0,O=D(O^C,7),_=_+H|0,y=D(y^_,16),W=W+y|0,H=D(H^W,12),_=_+H|0,y=D(y^_,8),W=W+y|0,H=D(H^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+O|0,n[L++]=m+H|0,n[L++]=p+W|0,n[L++]=h+x|0,n[L++]=d+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 h0(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],p=t[6],h=t[7],d=e[0],b=e[1],v=e[2],w=e[3];for(let B=0;B<20;B+=2)s=s+c|0,d=D(d^s,16),g=g+d|0,c=D(c^g,12),s=s+c|0,d=D(d^s,8),g=g+d|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),p=p+v|0,u=D(u^p,12),i=i+u|0,v=D(v^i,8),p=p+v|0,u=D(u^p,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),p=p+w|0,l=D(l^p,12),s=s+l|0,w=D(w^s,8),p=p+w|0,l=D(l^p,7),o=o+u|0,d=D(d^o,16),h=h+d|0,u=D(u^h,12),o=o+u|0,d=D(d^o,8),h=h+d|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++]=d,n[A++]=b,n[A++]=v,n[A++]=w}var d0=Zi(Nu,{counterRight:!1,counterLength:4,allowShortKeys:!1}),p0=Zi(Nu,{counterRight:!1,counterLength:8,extendNonceFn:h0,allowShortKeys:!1});var g0=new Uint8Array(16),Iu=(r,t)=>{r.update(t);let e=t.length%16;e&&r.update(g0.subarray(e))},m0=new Uint8Array(32);function _u(r,t,e,n,s){let o=r(t,e,m0),i=vu.create(o);s&&Iu(i,s),Iu(i,n);let a=new Uint8Array(16),c=bu(a);zi(c,0,BigInt(s?s.length:0),!0),zi(c,8,BigInt(n.length),!0),i.update(a);let l=i.digest();return o.fill(0),l}var Tu=r=>(t,e,n)=>(Ht(t,32),Ht(e),{encrypt:(o,i)=>{let a=o.length,c=a+16;i?Ht(i,c):i=new Uint8Array(c),r(t,e,o,i,1);let l=_u(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?Ht(i,c):i=new Uint8Array(c);let l=o.subarray(0,-16),u=o.subarray(-16),f=_u(r,t,e,l,n);if(!Eu(u,f))throw new Error("invalid tag");return r(t,e,l,i,1),i}}),Xi=ji({blockSize:64,nonceLength:12,tagLength:16},Tu(d0)),Ex=ji({blockSize:64,nonceLength:24,tagLength:16},Tu(p0));function Lu(r,t,e){return ze(r),e===void 0&&(e=new Uint8Array(r.outputLen)),He(r,Yt(e),Yt(t))}var Ji=new Uint8Array([0]),Ru=new Uint8Array;function Cu(r,t,e,n=32){if(ze(r),Le(n),n>255*r.outputLen)throw new Error("Length should be <= 255*HashLen");let s=Math.ceil(n/r.outputLen);e===void 0&&(e=Ru);let o=new Uint8Array(s*r.outputLen),i=He.create(r,t),a=i._cloneInto(),c=new Uint8Array(i.outputLen);for(let l=0;l<s;l++)Ji[0]=l+1,a.update(l===0?Ru:c).update(e).update(Ji).digestInto(c),o.set(c,r.outputLen*l),i._cloneInto(a);return i.destroy(),a.destroy(),c.fill(0),Ji.fill(0),o.slice(0,n)}var Qi={hashSHA256(r){return Nr(r.subarray())},getHKDF(r,t){let e=Lu(Nr,t,r),s=Cu(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=Xr.utils.randomPrivateKey();return{publicKey:Xr.getPublicKey(r),privateKey:r}},generateX25519KeyPairFromSeed(r){return{publicKey:Xr.getPublicKey(r),privateKey:r}},generateX25519SharedKey(r,t){return Xr.getSharedSecret(r.subarray(),t.subarray())},chaCha20Poly1305Encrypt(r,t,e,n){return Xi(n,t,e).encrypt(r.subarray())},chaCha20Poly1305Decrypt(r,t,e,n,s){return Xi(n,t,e).decrypt(r.subarray(),s)}};var Uu=Qi;function Pu(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 wn=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)};wn.bytes=2;function Du(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 ta(r,t){!t.enabled||!Dr||(r?(t(`LOCAL_STATIC_PUBLIC_KEY ${$(r.publicKey,"hex")}`),t(`LOCAL_STATIC_PRIVATE_KEY ${$(r.privateKey,"hex")}`)):t("Missing local static keys."))}function ea(r,t){!t.enabled||!Dr||(r?(t(`LOCAL_PUBLIC_EPHEMERAL_KEY ${$(r.publicKey,"hex")}`),t(`LOCAL_PRIVATE_EPHEMERAL_KEY ${$(r.privateKey,"hex")}`)):t("Missing local ephemeral keys."))}function Vu(r,t){!t.enabled||!Dr||t(r?`REMOTE_STATIC_PUBLIC_KEY ${$(r.subarray(),"hex")}`:"Missing remote static public key.")}function ra(r,t){!t.enabled||!Dr||t(r?`REMOTE_EPHEMERAL_PUBLIC_KEY ${$(r.subarray(),"hex")}`:"Missing remote ephemeral keys.")}function na(r,t,e){!e.enabled||!Dr||(e(`CIPHER_STATE_1 ${r.n.getUint64()} ${r.k&&$(r.k,"hex")}`),e(`CIPHER_STATE_2 ${t.n.getUint64()} ${t.k&&$(t.k,"hex")}`))}var $s=class r extends Error{code;constructor(t="Unexpected Peer"){super(t),this.code=r.code}static code="ERR_UNEXPECTED_PEER"},Hr=class r extends Error{code;constructor(t="Invalid crypto exchange"){super(t),this.code=r.code}static code="ERR_INVALID_CRYPTO_EXCHANGE"};var y0=0,w0=4294967295,b0="Cipherstate has reached maximum n, a new handshake must be performed",qs=class{n;bytes;view;constructor(t=y0){this.n=t,this.bytes=yt(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>w0)throw new Error(b0)}};var cr=yt(0),Or=class{k;n;crypto;constructor(t,e=void 0,n=0){this.crypto=t,this.k=e,this.n=new qs(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}},sa=class{cs;ck;h;crypto;constructor(t,e){this.crypto=t;let n=Z(e,"utf-8");this.h=x0(t,n),this.ck=this.h,this.cs=new Or(t)}mixKey(t){let[e,n]=this.crypto.hkdf(this.ck,t);this.ck=e,this.cs=new Or(this.crypto,n)}mixHash(t){this.h=this.crypto.hash(new ct(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 Or(this.crypto,t),new Or(this.crypto,e)]}},oa=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 sa(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()}},bn=class extends oa{writeMessageA(t){return new ct(this.writeE(),this.ss.encryptAndHash(t))}writeMessageB(t){let e=this.writeE();this.writeEE();let n=this.writeS();return this.writeES(),new ct(e,n,this.ss.encryptAndHash(t))}writeMessageC(t){let e=this.writeS();return this.writeSE(),new ct(e,this.ss.encryptAndHash(t))}readMessageA(t){try{return this.readE(t),this.ss.decryptAndHash(t.sublist(32))}catch(e){throw new Hr(`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 Hr(`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 Hr(`handshake stage 2 validation fail: ${e.message}`)}}};function x0(r,t){if(t.length<=32){let e=yt(32);return e.set(t),e}else return r.hash(t)}var Gs;(function(r){let t;r.codec=()=>(t==null&&(t=er((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=>tr(e,r.codec()),r.decode=e=>Je(e,r.codec())})(Gs||(Gs={}));var xn;(function(r){let t;r.codec=()=>(t==null&&(t=er((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),Gs.codec().encode(e.extensions,n)),s.lengthDelimited!==!1&&n.ldelim()},(e,n)=>{let s={identityKey:yt(0),identitySig:yt(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=Gs.codec().decode(e,e.uint32());break}default:{e.skipType(i&7);break}}}return s})),t),r.encode=e=>tr(e,r.codec()),r.decode=e=>Je(e,r.codec())})(xn||(xn={}));async function ia(r,t,e){let n=await r.sign(Hu(t));return xn.encode({identityKey:r.public.bytes,identitySig:n,extensions:e})}async function aa(r,t,e){try{let n=xn.decode(r);if(e){let i=e.subarray();if(!ft(i,n.identityKey))throw new Error(`Payload identity key ${$(n.identityKey,"hex")} does not match expected remote identity key ${$(i,"hex")}`)}if(!t)throw new Error("Remote static does not exist");let s=Hu(t);if(!await eu(n.identityKey).verify(s,n.identitySig))throw new Error("Invalid payload signature");return n}catch(n){throw new $s(n.message)}}function Hu(r){let t=Z("noise-libp2p-static-key:");return r instanceof Uint8Array?Et([t,r],t.length+r.length):(r.prepend(t),r)}async function Ou(r){let{log:t,connection:e,crypto:n,privateKey:s,prologue:o,s:i,remoteIdentityKey:a,extensions:c}=r,l=await ia(s,i.publicKey,c),u=new bn({crypto:n,protocolName:"Noise_XX_25519_ChaChaPoly_SHA256",initiator:!0,prologue:o,s:i});ta(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."),ea(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."),ra(u.re,t),Vu(u.rs,t),t.trace("Initiator going to check remote's signature...");let g=await aa(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,p]=u.ss.split();return na(m,p,t),{payload:g,encrypt:h=>m.encryptWithAd(cr,h),decrypt:(h,d)=>p.decryptWithAd(cr,h,d)}}async function Mu(r){let{log:t,connection:e,crypto:n,privateKey:s,prologue:o,s:i,remoteIdentityKey:a,extensions:c}=r,l=await ia(s,i.publicKey,c),u=new bn({crypto:n,protocolName:"Noise_XX_25519_ChaChaPoly_SHA256",initiator:!1,prologue:o,s:i});ta(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."),ra(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."),ea(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 aa(f,u.rs,a),[m,p]=u.ss.split();return na(m,p,t),{payload:g,encrypt:h=>p.encryptWithAd(cr,h),decrypt:(h,d)=>m.decryptWithAd(cr,h,d)}}var Fu=16;function $u(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 ct(Vr(i.byteLength),i)}}}function qu(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-Fu<s)throw new Error("Invalid chunk");let i=n.sublist(s,o),a=n.subarray(s,o-Fu);try{let c=r.decrypt(i,a);t?.decryptedPackets.increment(),yield c}catch(c){throw t?.decryptErrors.increment(),c}}}}var js=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??Uu;this.crypto=Pu(c),this.extensions=s,this.metrics=a?Du(a):void 0,n?this.staticKey=c.generateX25519KeyPairFromSeed(n):this.staticKey=c.generateX25519KeyPair(),this.prologue=i??yt(0)}[Symbol.toStringTag]="@chainsafe/libp2p-noise";[kn]=["@libp2p/connection-encryption","@chainsafe/libp2p-noise"];async secureOutbound(t,e,n){let s=Oi(e,{lengthEncoder:Vr,lengthDecoder:wn,maxDataLength:65535});if(!t.privateKey)throw new M("local peerId does not contain private key","ERR_NO_PRIVATE_KEY");let o=await Ni(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 Pi(a.payload.identityKey)}}async secureInbound(t,e,n){let s=Oi(e,{lengthEncoder:Vr,lengthDecoder:wn,maxDataLength:65535});if(!t.privateKey)throw new M("local peerId does not contain private key","ERR_NO_PRIVATE_KEY");let o=await Ni(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 Pi(a.payload.identityKey)}}async performHandshakeInitiator(t,e,n){let s;try{s=await Ou({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 Mu({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]=du(),o=t.unwrap();return await gu(n,$u(e,this.metrics),o,i=>yn(i,{lengthDecoder:wn}),qu(e,this.metrics),n),s}};function Gu(r={}){return t=>new js(t,r)}var zs=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 ju=45,E0=15,Mr=new zs;function ca(r){if(!(r.length>E0))return Mr.new(r).parseWith(()=>Mr.readIPv4Addr())}function la(r){if(r.includes("%")&&(r=r.split("%")[0]),!(r.length>ju))return Mr.new(r).parseWith(()=>Mr.readIPv6Addr())}function Ws(r){if(r.includes("%")&&(r=r.split("%")[0]),!(r.length>ju))return Mr.new(r).parseWith(()=>Mr.readIPAddr())}function Ys(r){return!!ca(r)}function Zs(r){return!!la(r)}function Xs(r){return!!Ws(r)}var o2=parseInt("0xFFFF",16),i2=new Uint8Array([0,0,0,0,0,0,0,0,0,0,255,255]);var Yu=Ys,k0=Zs,ua=function(r){let t=0;if(r=r.toString().trim(),Yu(r)){let e=new Uint8Array(t+4);return r.split(/\./g).forEach(n=>{e[t++]=parseInt(n,10)&255}),e}if(k0(r)){let e=r.split(":",8),n;for(n=0;n<e.length;n++){let o=Yu(e[n]),i;o&&(i=ua(e[n]),e[n]=$(i.slice(0,2),"base16")),i!=null&&++n<8&&e.splice(n,0,$(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")},Zu=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={},fa={},_0=[[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"],[481,-1,"http-path"],[777,-1,"memory"]];_0.forEach(r=>{let t=N0(...r);fa[t.code]=t,Kr[t.name]=t});function N0(r,t,e,n,s){return{code:r,size:t,name:e,resolvable:!!n,path:!!s}}function tt(r){if(typeof r=="number"){if(fa[r]!=null)return fa[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 K2=tt("ip4"),F2=tt("ip6"),$2=tt("ipcidr");function ga(r,t){switch(tt(r).code){case 4:case 41:return R0(t);case 42:return pa(t);case 6:case 273:case 33:case 132:return Qu(t).toString();case 53:case 54:case 55:case 56:case 400:case 449:case 777:return pa(t);case 421:return P0(t);case 444:return Ju(t);case 445:return Ju(t);case 466:return U0(t);case 481:return globalThis.encodeURIComponent(pa(t));default:return $(t,"base16")}}function ma(r,t){switch(tt(r).code){case 4:return Xu(t);case 41:return Xu(t);case 42:return da(t);case 6:case 273:case 33:case 132:return ya(parseInt(t,10));case 53:case 54:case 55:case 56:case 400:case 449:case 777:return da(t);case 421:return L0(t);case 444:return D0(t);case 445:return V0(t);case 466:return C0(t);case 481:return da(globalThis.decodeURIComponent(t));default:return Z(t,"base16")}}var ha=Object.values(se).map(r=>r.decoder),T0=function(){let r=ha[0].or(ha[1]);return ha.slice(2).forEach(t=>r=r.or(t)),r}();function Xu(r){if(!Xs(r))throw new Error("invalid ip address");return ua(r)}function R0(r){let t=Zu(r,0,r.length);if(t==null)throw new Error("ipBuff is required");if(!Xs(t))throw new Error("invalid ip address");return t}function ya(r){let t=new ArrayBuffer(2);return new DataView(t).setUint16(0,r),new Uint8Array(t)}function Qu(r){return new DataView(r.buffer).getUint16(r.byteOffset)}function da(r){let t=Z(r),e=Uint8Array.from(oe(t.length));return Et([e,t],e.length+t.length)}function pa(r){let t=Jt(r);if(r=r.slice(dt(t)),r.length!==t)throw new Error("inconsistent lengths");return $(r)}function L0(r){let t;r[0]==="Q"||r[0]==="1"?t=Re(ut.decode(`z${r}`)).bytes:t=Kt.parse(r).multihash.bytes;let e=Uint8Array.from(oe(t.length));return Et([e,t],e.length+t.length)}function C0(r){let t=T0.decode(r),e=Uint8Array.from(oe(t.length));return Et([e,t],e.length+t.length)}function U0(r){let t=Jt(r),e=r.slice(dt(t));if(e.length!==t)throw new Error("inconsistent lengths");return"u"+$(e,"base64url")}function P0(r){let t=Jt(r),e=r.slice(dt(t));if(e.length!==t)throw new Error("inconsistent lengths");return $(e,"base58btc")}function D0(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=ge.decode("b"+t[0]),n=parseInt(t[1],10);if(n<1||n>65536)throw new Error("Port number is not in range(1, 65536)");let s=ya(n);return Et([e,s],e.length+s.length)}function V0(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=ge.decode(`b${t[0]}`),n=parseInt(t[1],10);if(n<1||n>65536)throw new Error("Port number is not in range(1, 65536)");let s=ya(n);return Et([e,s],e.length+s.length)}function Ju(r){let t=r.slice(0,r.length-2),e=r.slice(r.length-2),n=$(t,"base32"),s=Qu(e);return`${n}:${s}`}function tf(r){r=wa(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=tt(i);if(a.size===0){t.push([a.code]),e.push([a.code]);continue}if(o++,o>=s.length)throw rf("invalid address: "+r);if(a.path===!0){n=wa(s.slice(o).join("/")),t.push([a.code,ma(a.code,n)]),e.push([a.code,n]);break}let c=ma(a.code,s[o]);t.push([a.code,c]),e.push([a.code,ga(a.code,c)])}return{string:ef(e),bytes:xa(t),tuples:t,stringTuples:e,path:n}}function ba(r){let t=[],e=[],n=null,s=0;for(;s<r.length;){let o=Jt(r,s),i=dt(o),a=tt(o),c=H0(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 rf("Invalid address Uint8Array: "+$(r,"base16"));t.push([o,l]);let u=ga(o,l);if(e.push([o,u]),a.path===!0){n=u;break}}return{bytes:Uint8Array.from(r),string:ef(e),tuples:t,stringTuples:e,path:n}}function ef(r){let t=[];return r.map(e=>{let n=tt(e[0]);return t.push(n.name),e.length>1&&e[1]!=null&&t.push(e[1]),null}),wa(t.join("/"))}function xa(r){return Et(r.map(t=>{let e=tt(t[0]),n=Uint8Array.from(oe(e.code));return t.length>1&&t[1]!=null&&(n=Et([n,t[1]])),n}))}function H0(r,t){if(r.size>0)return r.size/8;if(r.size===0)return 0;{let e=Jt(t instanceof Uint8Array?t:Uint8Array.from(t));return e+dt(e)}}function wa(r){return"/"+r.trim().split("/").filter(t=>t).join("/")}function rf(r){return new Error("Error parsing address: "+r)}var O0=Symbol.for("nodejs.util.inspect.custom"),Ea=Symbol.for("@multiformats/js-multiaddr/multiaddr"),M0=[tt("dns").code,tt("dns4").code,tt("dns6").code,tt("dnsaddr").code],Js=class r{bytes;#e;#t;#r;#n;[Ea]=!0;constructor(t){t==null&&(t="");let e;if(t instanceof Uint8Array)e=ba(t);else if(typeof t=="string"){if(t.length>0&&t.charAt(0)!=="/")throw new Error(`multiaddr "${t}" must start with a "/"`);e=tf(t)}else if(sf(t))e=ba(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=tt("tcp"),a=tt("udp"),c=tt("ip4"),l=tt("ip6"),u=tt("dns6"),f=tt("ip6zone");for(let[m,p]of this.stringTuples())m===f.code&&(o=`%${p??""}`),M0.includes(m)&&(e=i.name,s=443,n=`${p??""}${o}`,t=m===u.code?6:4),(m===i.code||m===a.code)&&(e=tt(m).name,s=parseInt(p??"")),(m===c.code||m===l.code)&&(e=tt(m).name,n=`${p??""}${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({},tt(t)))}protoCodes(){return this.#t.map(([t])=>t)}protoNames(){return this.#t.map(([t])=>tt(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(xa(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"?$(ut.decode(`z${n}`),"base58btc"):$(Kt.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=nf.get(e.name);if(n==null)throw new M(`no available resolver for ${e.name}`,"ERR_NO_AVAILABLE_RESOLVER");return(await n(this,t)).map(o=>va(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)}[O0](){return`Multiaddr(${this.#e})`}};var nf=new Map;function sf(r){return!!r?.[Ea]}function va(r){return new Js(r)}var K0=r=>r.toString().split("/").slice(1),vn=r=>({match:t=>t.length<1?!1:r(t[0])?t.slice(1):!1,pattern:"fn"}),J=r=>({match:t=>vn(e=>e===r).match(t),pattern:r}),eo=()=>({match:r=>vn(t=>typeof t=="string").match(r),pattern:"{string}"}),ro=()=>({match:r=>vn(t=>!isNaN(parseInt(t))).match(r),pattern:"{number}"}),_t=()=>({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}"}),Qs=()=>({match:r=>{if(r.length<2||r[0]!=="certhash")return!1;try{_o.decode(r[1])}catch{return!1}return r.slice(2)},pattern:"/certhash/{certhash}"}),xt=r=>({match:t=>{let e=r.match(t);return e===!1?t:e},pattern:`optional(${r.pattern})`}),jt=(...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=K0(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 Aa=rt(J("dns4"),eo()),Sa=rt(J("dns6"),eo()),ka=rt(J("dnsaddr"),eo()),of=rt(J("dns"),eo()),wE=ht(Aa),bE=ht(Sa),xE=ht(ka),EE=ht(jt(of,ka,Aa,Sa)),af=rt(J("ip4"),vn(Ys)),cf=rt(J("ip6"),vn(Zs)),lf=jt(af,cf),fe=jt(lf,of,Aa,Sa,ka),vE=ht(fe),BE=ht(af),AE=ht(cf),SE=ht(lf),Ia=rt(fe,J("tcp"),ro()),Bn=rt(fe,J("udp"),ro()),kE=ht(Ia),IE=ht(Bn),_a=rt(Bn,J("quic")),no=rt(Bn,J("quic-v1")),F0=jt(_a,no),_E=ht(_a),NE=ht(no),Ba=jt(fe,Ia,Bn,_a,no),uf=jt(rt(Ba,J("ws"),xt(_t()))),TE=ht(uf),ff=jt(rt(Ba,J("wss"),xt(_t())),rt(Ba,J("tls"),J("ws"),xt(_t()))),RE=ht(ff),hf=rt(Bn,J("webrtc-direct"),xt(Qs()),xt(Qs()),xt(_t())),LE=ht(hf),df=rt(no,J("webtransport"),xt(Qs()),xt(Qs()),xt(_t())),so=ht(df),to=jt(uf,ff,rt(Ia,xt(_t())),rt(F0,xt(_t())),rt(fe,xt(_t())),hf,df,_t()),CE=ht(to),$0=rt(to,J("p2p-circuit"),_t()),UE=ht($0),q0=jt(rt(to,J("p2p-circuit"),J("webrtc"),xt(_t())),rt(to,J("webrtc"),xt(_t())),J("webrtc")),PE=ht(q0),G0=jt(rt(fe,J("tcp"),ro(),J("http"),xt(_t())),rt(fe,J("http"),xt(_t()))),DE=ht(G0),j0=jt(rt(fe,J("tcp"),jt(rt(J("443"),J("http")),rt(ro(),J("https"))),xt(_t())),rt(fe,J("tls"),J("http"),xt(_t())),rt(fe,J("https"),xt(_t()))),VE=ht(j0);var lr=class extends Event{type;detail;constructor(t,e){super(t),this.type=t,this.detail=e}};function Na(r){throw new Error("Not implemented")}function pf(r){if(r!=null){if(typeof r[Symbol.iterator]=="function")return r[Symbol.iterator]();if(typeof r[Symbol.asyncIterator]=="function")return r[Symbol.asyncIterator]();if(typeof r.next=="function")return r}throw new Error("argument is not an iterator or iterable")}function gf(r){return r==null?!1:typeof r.then=="function"&&typeof r.catch=="function"&&typeof r.finally=="function"}function mf(r,t){let e=pf(r).return?.();gf(e)&&e.catch(n=>{t.error("could not cause iterator to return",n)})}var z0="ERR_STREAM_RESET",W0="ERR_SINK_INVALID_STATE",Y0=5e3;function Ta(r){return r==null?!1:typeof r.then=="function"&&typeof r.catch=="function"&&typeof r.finally=="function"}var oo=class{id;direction;timeline;protocol;metadata;source;status;readStatus;writeStatus;log;sinkController;sinkEnd;closed;endErr;streamSource;onEnd;onCloseRead;onCloseWrite;onReset;onAbort;sendCloseWriteTimeout;sendingData;constructor(t){this.sinkController=new AbortController,this.sinkEnd=Ct(),this.closed=Ct(),this.log=t.log,this.status="open",this.readStatus="ready",this.writeStatus="ready",this.id=t.id,this.metadata=t.metadata??{},this.direction=t.direction,this.timeline={open:Date.now()},this.sendCloseWriteTimeout=t.sendCloseWriteTimeout??Y0,this.onEnd=t.onEnd,this.onCloseRead=t?.onCloseRead,this.onCloseWrite=t?.onCloseWrite,this.onReset=t?.onReset,this.onAbort=t?.onAbort,this.source=this.streamSource=Pr({onEnd:e=>{e!=null?this.log.trace("source ended with error",e):this.log.trace("source ended"),this.onSourceEnd(e)}}),this.sink=this.sink.bind(this)}async sink(t){if(this.writeStatus!=="ready")throw new M(`writable end state is "${this.writeStatus}" not "ready"`,W0);try{this.writeStatus="writing";let e={signal:this.sinkController.signal};if(this.direction==="outbound"){let s=this.sendNewStream(e);Ta(s)&&await s}let n=()=>{mf(t,this.log)};try{this.sinkController.signal.addEventListener("abort",n),this.log.trace("sink reading from source");for await(let s of t){s=s instanceof Uint8Array?new ct(s):s;let o=this.sendData(s,e);Ta(o)&&(this.sendingData=Ct(),await o,this.sendingData.resolve(),this.sendingData=void 0)}}finally{this.sinkController.signal.removeEventListener("abort",n)}this.log.trace('sink finished reading from source, write status is "%s"',this.writeStatus),this.writeStatus==="writing"&&(this.writeStatus="closing",this.log.trace("send close write to remote"),await this.sendCloseWrite({signal:AbortSignal.timeout(this.sendCloseWriteTimeout)}),this.writeStatus="closed"),this.onSinkEnd()}catch(e){throw this.log.trace("sink ended with error, calling abort with error",e),this.abort(e),e}finally{this.log.trace("resolve sink end"),this.sinkEnd.resolve()}}onSourceEnd(t){this.timeline.closeRead==null&&(this.timeline.closeRead=Date.now(),this.readStatus="closed",t!=null&&this.endErr==null&&(this.endErr=t),this.onCloseRead?.(),this.timeline.closeWrite!=null?(this.log.trace("source and sink ended"),this.timeline.close=Date.now(),this.status!=="aborted"&&this.status!=="reset"&&(this.status="closed"),this.onEnd!=null&&this.onEnd(this.endErr),this.closed.resolve()):this.log.trace("source ended, waiting for sink to end"))}onSinkEnd(t){this.timeline.closeWrite==null&&(this.timeline.closeWrite=Date.now(),this.writeStatus="closed",t!=null&&this.endErr==null&&(this.endErr=t),this.onCloseWrite?.(),this.timeline.closeRead!=null?(this.log.trace("sink and source ended"),this.timeline.close=Date.now(),this.status!=="aborted"&&this.status!=="reset"&&(this.status="closed"),this.onEnd!=null&&this.onEnd(this.endErr),this.closed.resolve()):this.log.trace("sink ended, waiting for source to end"))}async close(t){this.log.trace("closing gracefully"),this.status="closing",await Dt(Promise.all([this.closeWrite(t),this.closeRead(t),this.closed.promise]),t?.signal),this.status="closed",this.log.trace("closed gracefully")}async closeRead(t={}){if(this.readStatus==="closing"||this.readStatus==="closed")return;this.log.trace('closing readable end of stream with starting read status "%s"',this.readStatus);let e=this.readStatus;this.readStatus="closing",this.status!=="reset"&&this.status!=="aborted"&&this.timeline.closeRead==null&&(this.log.trace("send close read to remote"),await this.sendCloseRead(t)),e==="ready"&&(this.log.trace("ending internal source queue with %d queued bytes",this.streamSource.readableLength),this.streamSource.end()),this.log.trace("closed readable end of stream")}async closeWrite(t={}){this.writeStatus==="closing"||this.writeStatus==="closed"||(this.log.trace('closing writable end of stream with starting write status "%s"',this.writeStatus),this.writeStatus==="ready"&&(this.log.trace("sink was never sunk, sink an empty array"),await Dt(this.sink([]),t.signal)),this.writeStatus==="writing"&&(this.sendingData!=null&&await Dt(this.sendingData.promise,t.signal),this.log.trace("aborting source passed to .sink"),this.sinkController.abort(),await Dt(this.sinkEnd.promise,t.signal)),this.writeStatus="closed",this.log.trace("closed writable end of stream"))}abort(t){if(this.status==="closed"||this.status==="aborted"||this.status==="reset")return;this.log("abort with error",t),this.log("try to send reset to remote");let e=this.sendReset();Ta(e)&&e.catch(n=>{this.log.error("error sending reset message",n)}),this.status="aborted",this.timeline.abort=Date.now(),this._closeSinkAndSource(t),this.onAbort?.(t)}reset(){if(this.status==="closed"||this.status==="aborted"||this.status==="reset")return;let t=new M("stream reset",z0);this.status="reset",this.timeline.reset=Date.now(),this._closeSinkAndSource(t),this.onReset?.()}_closeSinkAndSource(t){this._closeSink(t),this._closeSource(t)}_closeSink(t){this.writeStatus==="writing"&&(this.log.trace("end sink source"),this.sinkController.abort()),this.onSinkEnd(t)}_closeSource(t){this.readStatus!=="closing"&&this.readStatus!=="closed"&&(this.log.trace("ending source with %d bytes to be read by consumer",this.streamSource.readableLength),this.readStatus="closing",this.streamSource.end(t))}remoteCloseWrite(){if(this.readStatus==="closing"||this.readStatus==="closed"){this.log("received remote close write but local source is already closed");return}this.log.trace("remote close write"),this._closeSource()}remoteCloseRead(){if(this.writeStatus==="closing"||this.writeStatus==="closed"){this.log("received remote close read but local sink is already closed");return}this.log.trace("remote close read"),this._closeSink()}destroy(){if(this.status==="closed"||this.status==="aborted"||this.status==="reset"){this.log("received destroy but we are already closed");return}this.log.trace("stream destroyed"),this._closeSinkAndSource()}sourcePush(t){this.streamSource.push(t)}sourceReadableLength(){return this.streamSource.readableLength}};var Ra=class extends oo{writer;reader;constructor(t){super(t),this.writer=t.bidiStream.writable.getWriter(),this.reader=t.bidiStream.readable.getReader(),Promise.resolve().then(async()=>{for(;;){let e=await this.reader.read();if(e.done){t.log("remote closed write");return}e.value!=null&&this.sourcePush(new ct(e.value))}}).catch(e=>{t.log.error("error reading from stream",e),this.abort(e)}).finally(()=>{this.remoteCloseWrite()}),this.writer.closed.then(()=>{t.log("writer closed")}).catch(e=>{t.log("writer close promise rejected",e)}).finally(()=>{this.remoteCloseRead()})}sendNewStream(t){}async sendData(t,e){for await(let n of t)this.log("sendData waiting for writer to be ready"),await Dt(this.writer.ready,e?.signal),this.writer.write(n).catch(s=>{this.log.error("error sending stream data",s)})}async sendReset(t){this.log("sendReset aborting writer"),await Dt(this.writer.abort(),t?.signal),this.log("sendReset aborted writer")}async sendCloseWrite(t){this.log("sendCloseWrite closing writer"),await Dt(this.writer.close(),t?.signal),this.log("sendCloseWrite closed writer")}async sendCloseRead(t){this.log("sendCloseRead cancelling reader"),await Dt(this.reader.cancel(),t?.signal),this.log("sendCloseRead cancelled reader")}};async function La(r,t,e,n,s,o){let i=o.forComponent(`libp2p:webtransport:stream:${e}:${t}`),a=new Ra({bidiStream:r,id:t,direction:e,log:i,onEnd:()=>{let c=n.findIndex(l=>l===a);c!==-1&&n.splice(c,1),s?.(a)}});return a}function io(){return{source:{[Symbol.asyncIterator](){return{async next(){return new Promise(()=>{})}}}},sink:async r=>new Promise(()=>{})}}function yf(r,t,e,n){let s=0,o=e.forComponent("libp2p:webtransport:muxer");return{protocol:"webtransport",createStreamMuxer:i=>{typeof i=="function"&&(i={onIncomingStream:i});let a=[];Promise.resolve().then(async()=>{for(;;){let{done:l,value:u}=await t.read();if(l)break;if(a.length>=n.maxInboundStreams)o(`too many inbound streams open - ${a.length}/${n.maxInboundStreams}, closing new incoming stream`),u.writable.close().catch(f=>{o.error(`failed to close inbound stream that crossed our maxInboundStream limit: ${f.message}`)}),u.readable.cancel().catch(f=>{o.error(`failed to close inbound stream that crossed our maxInboundStream limit: ${f.message}`)});else{let f=await La(u,String(s++),"inbound",a,i?.onStreamEnd,e);a.push(f),i?.onIncomingStream?.(f)}}}).catch(l=>{o.error("could not create a new stream",l)});let c={protocol:"webtransport",streams:a,newStream:async l=>{o("new outgoing stream",l);let u=await r.createBidirectionalStream(),f=await La(u,String(s++),i?.direction??"outbound",a,i?.onStreamEnd,e);return a.push(f),f},close:async()=>{o("closing webtransport muxer gracefully");try{r.close()}catch(l){c.abort(l)}},abort:l=>{o("closing webtransport muxer with err:",l);try{r.close()}catch(u){o.error("webtransport session threw error during close",u)}},...io()};return c}}}function wf(r,t){return t.filter(n=>!!r.find(s=>ft(n,s))).length===t.length}var Z0=Object.values(se).map(r=>r.decoder).reduce((r,t)=>r.or(t));function X0(r){return ne.decode(Z0.decode(r))}function Ca(r){if(!so.matches(r))throw new M("Invalid multiaddr, was not a WebTransport address","ERR_INVALID_MULTIADDR");let t=r.stringTuples(),e=t.filter(([i,a])=>i===tt("certhash").code).map(([i,a])=>X0(a??"")),n=t.filter(([i,a])=>i===tt("p2p").code).map(([i,a])=>Ui(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 bf=globalThis.WebTransport;var Ua=class{log;components;config;metrics;constructor(t,e={}){this.log=t.logger.forComponent("libp2p:webtransport"),this.components=t,this.config={...e,maxInboundStreams:e.maxInboundStreams??1e3,certificates:e.certificates??[]},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";[za]=!0;[kn]=["@libp2p/transport"];async dial(t,e){if(e?.signal?.aborted===!0)throw new Sn;this.log("dialing %s",t);let n=this.components.peerId;if(n===void 0)throw new M("Need a local peerid","ERR_INVALID_PARAMETERS");e=e??{};let{url:s,certhashes:o,remotePeer:i}=Ca(t),a,c,l=()=>{},u=!1,f=!1,g=!1;try{this.metrics?.dialerEvents.increment({pending:!0});let m=new bf(`${s}/.well-known/libp2p-webtransport?type=noise`,{serverCertificateHashes:o.map(p=>({algorithm:"sha-256",value:p.digest}))});if(l=p=>{if(!u)try{this.metrics?.dialerEvents.increment({[p]:!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}),this.log("wait for session to be ready"),e.onProgress?.(new lr("webtransport:wait-for-session")),await Promise.race([m.closed,m.ready]),this.log("session became ready"),f=!0,this.metrics?.dialerEvents.increment({ready:!0}),m.closed.catch(p=>{this.log.error("error on remote wt session close",p)}).finally(()=>{l("remote_close")}),g=await Dt(this.authenticateWebTransport({wt:m,localPeer:n,remotePeer:i,certhashes:o,...e}),e.signal),!g)throw new M("Failed to authenticate webtransport","ERR_AUTHENTICATION_FAILED");return this.metrics?.dialerEvents.increment({open:!0}),c={close:async()=>{this.log("closing webtransport"),l("close")},abort:p=>{this.log("aborting webtransport due to passed err",p),l("abort")},remoteAddr:t,timeline:{open:Date.now()},log:this.components.logger.forComponent("libp2p:webtransport:maconn"),...io()},await e.upgrader.upgradeOutbound(c,{skipEncryption:!0,muxerFactory:yf(m,m.incomingBidirectionalStreams.getReader(),this.components.logger,this.config),skipProtection:!0,onProgress:e.onProgress})}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({wt:t,localPeer:e,remotePeer:n,certhashes:s,onProgress:o,signal:i}){i?.throwIfAborted(),o?.(new lr("webtransport:open-authentication-stream"));let a=await t.createBidirectionalStream(),c=a.writable.getWriter(),l=a.readable.getReader(),u={source:async function*(){for(;;){let m=await l.read();if(m.value!=null&&(yield m.value),m.done)break}}(),sink:async m=>{for await(let p of m){await Dt(c.ready,i);let h=p instanceof Uint8Array?p:p.subarray();c.write(h).catch(d=>{this.log.error("could not write chunk during authentication of WebTransport stream",d)})}}},f=Gu()(this.components);o?.(new lr("webtransport:secure-outbound-connection"));let{remoteExtensions:g}=await f.secureOutbound(e,u,n);if(o?.(new lr("webtransport:close-authentication-stream")),c.close().catch(m=>{this.log.error(`Failed to close authentication stream writer: ${m.message}`)}),l.cancel().catch(m=>{this.log.error(`Failed to close authentication stream reader: ${m.message}`)}),!wf(g?.webtransportCerthashes??[],s.map(m=>m.bytes)))throw new Error("Our certhashes are not a subset of the remote's reported certhashes");return!0}createListener(t){return Na(this.components,{...t,certificates:this.config.certificates,maxInboundStreams:this.config.maxInboundStreams})}listenFilter(){return[]}dialFilter(t){return globalThis.WebTransport==null?[]:t.filter(e=>{if(!so.exactMatch(e))return!1;let{url:n,certhashes:s}=Ca(e);return n!=null&&s.length>0})}};function J0(r={}){return t=>new Ua(t,r)}return Cf(Q0);})();
|
|
7
|
+
`)}async function _p(r,t){let e=Ut.get(),n;if(r.includes("-----BEGIN ENCRYPTED PRIVATE KEY-----")){let s=Z(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}=Np(o),f=await pi(jr,t,a,{c,dkLen:l}),g=await e.subtle.importKey("raw",f,"AES-CBC",!1,["decrypt"]),m=fn(await e.subtle.decrypt({name:"AES-CBC",iv:i},g,u)),{result:p}=Ir(m);n=Vl(p)}else if(r.includes("-----BEGIN PRIVATE KEY-----")){let s=Z(r.replace("-----BEGIN PRIVATE KEY-----","").replace("-----END PRIVATE KEY-----","").replace(/\n/g,"").trim(),"base64pad"),{result:o}=Ir(s);n=Vl(o)}else throw new M("Could not parse private key from PEM data","ERR_INVALID_PARAMETERS");return Ei(n)}function Np(r){let t=r.valueBlock.value[0];if(t.valueBlock.value[0].toString()!=="OBJECT IDENTIFIER : 1.2.840.113549.1.5.13")throw new M("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 M("Only pkcs5PBKDF2 key derivation functions are supported","ERR_INVALID_PARAMS");let o=n.valueBlock.value[1],i=fn(o.valueBlock.value[0].getValue()),a=xi,c=bi;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 M("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 M("Only AES-CBC encryption schemes are supported","ERR_INVALID_PARAMS")}}}}let f=fn(l.valueBlock.value[1].getValue());return{cipherText:fn(r.valueBlock.value[1].getValue()),salt:i,iterations:a,keySize:c,iv:f}}function Vl(r){return fn(r.valueBlock.value[2].getValue())}function fn(r){return new Uint8Array(r,0,r.byteLength)}async function Hl(r){let t=await Ut.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 Kl(t);return{privateKey:e[0],publicKey:e[1]}}async function vi(r){let e=[await Ut.get().subtle.importKey("jwk",r,{name:"RSASSA-PKCS1-v1_5",hash:{name:"SHA-256"}},!0,["sign"]),await Tp(r)],n=await Kl({privateKey:e[0],publicKey:e[1]});return{privateKey:n[0],publicKey:n[1]}}async function Ol(r,t){let e=await Ut.get().subtle.importKey("jwk",r,{name:"RSASSA-PKCS1-v1_5",hash:{name:"SHA-256"}},!1,["sign"]),n=await Ut.get().subtle.sign({name:"RSASSA-PKCS1-v1_5"},e,t instanceof Uint8Array?t:t.subarray());return new Uint8Array(n,0,n.byteLength)}async function Ml(r,t,e){let n=await Ut.get().subtle.importKey("jwk",r,{name:"RSASSA-PKCS1-v1_5",hash:{name:"SHA-256"}},!1,["verify"]);return Ut.get().subtle.verify({name:"RSASSA-PKCS1-v1_5"},n,t,e instanceof Uint8Array?e:e.subarray())}async function Kl(r){if(r.privateKey==null||r.publicKey==null)throw new M("Private and public key are required","ERR_INVALID_PARAMETERS");return Promise.all([Ut.get().subtle.exportKey("jwk",r.privateKey),Ut.get().subtle.exportKey("jwk",r.publicKey)])}async function Tp(r){return Ut.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 Ls(r){if(r.kty!=="RSA")throw new M("invalid key type","ERR_INVALID_KEY_TYPE");if(r.n==null)throw new M("invalid key modulus","ERR_INVALID_KEY_MODULUS");return Z(r.n,"base64url").length*8}var dn=8192,hn=class{_key;constructor(t){this._key=t}verify(t,e){return Ml(this._key,e,t)}marshal(){return Fe.jwkToPkix(this._key)}get bytes(){return ie.encode({Type:at.RSA,Data:this.marshal()}).subarray()}equals(t){return ft(this.bytes,t.bytes)}hash(){let t=St.digest(this.bytes);return Ft(t)?t.then(({bytes:e})=>e):t.bytes}},_r=class{_key;_publicKey;constructor(t,e){this._key=t,this._publicKey=e}genSecret(){return nr(16)}sign(t){return Ol(this._key,t)}get public(){if(this._publicKey==null)throw new M("public key not provided","ERR_PUBKEY_NOT_PROVIDED");return new hn(this._publicKey)}marshal(){return Fe.jwkToPkcs1(this._key)}get bytes(){return ae.encode({Type:at.RSA,Data:this.marshal()}).subarray()}equals(t){return ft(this.bytes,t.bytes)}hash(){let t=St.digest(this.bytes);return Ft(t)?t.then(({bytes:e})=>e):t.bytes}async id(){let t=await this.public.hash();return $(t,"base58btc")}async export(t,e="pkcs-8"){if(e==="pkcs-8")return Fe.exportToPem(this,t);if(e==="libp2p-key")return Er(this.bytes,t);throw new M(`export format '${e}' is not supported`,"ERR_INVALID_EXPORT_FORMAT")}};async function Ei(r){let t=Fe.pkcs1ToJwk(r);if(Ls(t)>dn)throw new M("key size is too large","ERR_KEY_SIZE_TOO_LARGE");let e=await vi(t);return new _r(e.privateKey,e.publicKey)}function Lp(r){let t=Fe.pkixToJwk(r);if(Ls(t)>dn)throw new M("key size is too large","ERR_KEY_SIZE_TOO_LARGE");return new hn(t)}async function Cp(r){if(Ls(r)>dn)throw new M("key size is too large","ERR_KEY_SIZE_TOO_LARGE");let t=await vi(r);return new _r(t.privateKey,t.publicKey)}async function Up(r){if(r>dn)throw new M("key size is too large","ERR_KEY_SIZE_TOO_LARGE");let t=await Hl(r);return new _r(t.privateKey,t.publicKey)}var _i={};mt(_i,{Secp256k1PrivateKey:()=>gn,Secp256k1PublicKey:()=>pn,generateKeyPair:()=>zp,unmarshalSecp256k1PrivateKey:()=>Gp,unmarshalSecp256k1PublicKey:()=>jp});var Pp=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]),$e=new Uint32Array([1779033703,3144134277,1013904242,2773480762,1359893119,2600822924,528734635,1541459225]),qe=new Uint32Array(64),Ai=class extends yr{constructor(){super(64,32,8,!1),this.A=$e[0]|0,this.B=$e[1]|0,this.C=$e[2]|0,this.D=$e[3]|0,this.E=$e[4]|0,this.F=$e[5]|0,this.G=$e[6]|0,this.H=$e[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)qe[f]=t.getUint32(e,!1);for(let f=16;f<64;f++){let g=qe[f-15],m=qe[f-2],p=Wt(g,7)^Wt(g,18)^g>>>3,h=Wt(m,17)^Wt(m,19)^m>>>10;qe[f]=h+qe[f-7]+p+qe[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=Wt(a,6)^Wt(a,11)^Wt(a,25),m=u+g+yc(a,c,l)+Pp[f]+qe[f]|0,h=(Wt(n,2)^Wt(n,13)^Wt(n,22))+wc(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(){qe.fill(0)}destroy(){this.set(0,0,0,0,0,0,0,0),this.buffer.fill(0)}};var Nr=Tn(()=>new Ai);function Dp(r){let t=Wr(r);$t(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:Vp,hexToBytes:Hp}=Cn,or={Err:class extends Error{constructor(t=""){super(t)}},_parseInt(r){let{Err:t}=or;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:Vp(n),l:r.subarray(e+2)}},toSig(r){let{Err:t}=or,e=typeof r=="string"?Hp(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}=or._parseInt(e.subarray(2)),{d:i,l:a}=or._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}`}},_e=BigInt(0),Gt=BigInt(1),Ow=BigInt(2),Fl=BigInt(3),Mw=BigInt(4);function Op(r){let t=Dp(r),{Fp:e}=t,n=t.toBytes||((p,h,d)=>{let b=h.toAffine();return xe(Uint8Array.from([4]),e.toBytes(b.x),e.toBytes(b.y))}),s=t.fromBytes||(p=>{let h=p.subarray(1),d=e.fromBytes(h.subarray(0,e.BYTES)),b=e.fromBytes(h.subarray(e.BYTES,2*e.BYTES));return{x:d,y:b}});function o(p){let{a:h,b:d}=t,b=e.sqr(p),v=e.mul(b,p);return e.add(e.add(v,e.mul(p,h)),d)}if(!e.eql(e.sqr(t.Gy),o(t.Gx)))throw new Error("bad generator point: equation left != right");function i(p){return typeof p=="bigint"&&_e<p&&p<t.n}function a(p){if(!i(p))throw new Error("Expected valid bigint: 0 < bigint < curve.n")}function c(p){let{allowedPrivateKeyLengths:h,nByteLength:d,wrapPrivateKey:b,n:v}=t;if(h&&typeof p!="bigint"){if(Pe(p)&&(p=ye(p)),typeof p!="string"||!h.includes(p.length))throw new Error("Invalid key");p=p.padStart(d*2,"0")}let w;try{w=typeof p=="bigint"?p:we(st("private key",p,d))}catch{throw new Error(`private key must be ${d} bytes, hex or bigint, not ${typeof p}`)}return b&&(w=X(w,v)),a(w),w}let l=new Map;function u(p){if(!(p instanceof f))throw new Error("ProjectivePoint expected")}class f{constructor(h,d,b){if(this.px=h,this.py=d,this.pz=b,h==null||!e.isValid(h))throw new Error("x required");if(d==null||!e.isValid(d))throw new Error("y required");if(b==null||!e.isValid(b))throw new Error("z required")}static fromAffine(h){let{x:d,y:b}=h||{};if(!h||!e.isValid(d)||!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(d)&&v(b)?f.ZERO:new f(d,b,e.ONE)}get x(){return this.toAffine().x}get y(){return this.toAffine().y}static normalizeZ(h){let d=e.invertBatch(h.map(b=>b.pz));return h.map((b,v)=>b.toAffine(d[v])).map(f.fromAffine)}static fromHex(h){let d=f.fromAffine(s(st("pointHex",h)));return d.assertValidity(),d}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:d}=this.toAffine();if(!e.isValid(h)||!e.isValid(d))throw new Error("bad point: x or y not FE");let b=e.sqr(d),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:d,py:b,pz:v}=this,{px:w,py:A,pz:B}=h,S=e.eql(e.mul(d,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:d}=t,b=e.mul(d,Fl),{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:d,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,Fl),R=e.mul(d,w),O=e.mul(b,A),H=e.mul(v,B),W=e.add(d,b),x=e.add(w,A);W=e.mul(W,x),x=e.add(R,O),W=e.sub(W,x),x=e.add(d,v);let I=e.add(w,B);return x=e.mul(x,I),I=e.add(R,H),x=e.sub(x,I),I=e.add(b,v),S=e.add(A,B),I=e.mul(I,S),S=e.add(O,H),I=e.sub(I,S),_=e.mul(V,x),S=e.mul(P,H),_=e.add(S,_),S=e.sub(O,_),_=e.add(O,_),N=e.mul(S,_),O=e.add(R,R),O=e.add(O,R),H=e.mul(V,H),x=e.mul(P,x),O=e.add(O,H),H=e.sub(R,H),H=e.mul(V,H),x=e.add(x,H),R=e.mul(O,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,O),_=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,d=>{let b=e.invertBatch(d.map(v=>v.pz));return d.map((v,w)=>v.toAffine(b[w])).map(f.fromAffine)})}multiplyUnsafe(h){let d=f.ZERO;if(h===_e)return d;if(a(h),h===Gt)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=d,N=d,_=this;for(;w>_e||B>_e;)w&Gt&&(S=S.add(_)),B&Gt&&(N=N.add(_)),_=_.double(),w>>=Gt,B>>=Gt;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 d=h,b,v,{endo:w}=t;if(w){let{k1neg:A,k1:B,k2neg:S,k2:N}=w.splitScalar(d),{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(d);b=A,v=B}return f.normalizeZ([b,v])[0]}multiplyAndAddUnsafe(h,d,b){let v=f.BASE,w=(B,S)=>S===_e||S===Gt||!B.equals(v)?B.multiplyUnsafe(S):B.multiply(S),A=w(this,d).add(w(h,b));return A.is0()?void 0:A}toAffine(h){let{px:d,py:b,pz:v}=this,w=this.is0();h==null&&(h=w?e.ONE:e.inv(v));let A=e.mul(d,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:d}=t;if(h===Gt)return!0;if(d)return d(f,this);throw new Error("isTorsionFree() has not been declared for the elliptic curve")}clearCofactor(){let{h,clearCofactor:d}=t;return h===Gt?this:d?d(f,this):this.multiplyUnsafe(t.h)}toRawBytes(h=!0){return this.assertValidity(),n(f,this,h)}toHex(h=!0){return ye(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=Dn(f,t.endo?Math.ceil(g/2):g);return{CURVE:t,ProjectivePoint:f,normPrivateKeyToScalar:c,weierstrassEquation:o,isWithinCurveOrder:i}}function Mp(r){let t=Wr(r);return $t(t,{hash:"hash",hmac:"function",randomBytes:"function"},{bits2int:"function",bits2int_modN:"function",lowS:"boolean"}),Object.freeze({lowS:!0,...t})}function $l(r){let t=Mp(r),{Fp:e,n}=t,s=e.BYTES+1,o=2*e.BYTES+1;function i(x){return _e<x&&x<e.ORDER}function a(x){return X(x,n)}function c(x){return Un(x,n)}let{ProjectivePoint:l,normPrivateKeyToScalar:u,weierstrassEquation:f,isWithinCurveOrder:g}=Op({...t,toBytes(x,I,C){let E=I.toAffine(),y=e.toBytes(E.x),k=xe;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=we(E);if(!i(y))throw new Error("Point is not on curve");let k=f(y),T;try{T=e.sqrt(k)}catch(F){let j=F instanceof Error?": "+F.message:"";throw new Error("Point is not on curve"+j)}let L=(T&Gt)===Gt;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=>ye(De(x,t.nByteLength));function p(x){let I=n>>Gt;return x>I}function h(x){return p(x)?a(-x):x}let d=(x,I,C)=>we(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(d(I,0,C),d(I,C,2*C))}static fromDER(I){let{r:C,s:E}=or.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",K=l.fromHex(L+m(T)),F=c(T),j=a(-k*F),q=a(E*F),G=l.BASE.multiplyAndAddUnsafe(K,j,q);if(!G)throw new Error("point at infinify");return G.assertValidity(),G}hasHighS(){return p(this.s)}normalizeS(){return this.hasHighS()?new b(this.r,a(-this.s),this.recovery):this}toDERRawBytes(){return Ye(this.toDERHex())}toDERHex(){return or.hexFromSig({r:this.r,s:this.s})}toCompactRawBytes(){return Ye(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=qo(t.n);return _c(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=Pe(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=we(x),C=x.length*8-t.nBitLength;return C>0?I>>BigInt(C):I},N=t.bits2int_modN||function(x){return a(S(x))},_=zr(t.nBitLength);function V(x){if(typeof x!="bigint")throw new Error("bigint expected");if(!(_e<=x&&x<_))throw new Error(`bigint expected < 2^${t.nBitLength}`);return De(x,t.nByteLength)}function P(x,I,C=R){if(["recovered","canonical"].some(et=>et 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 K=N(x),F=u(I),j=[V(F),V(K)];if(L!=null&&L!==!1){let et=L===!0?y(e.BYTES):L;j.push(st("extraEntropy",et))}let q=xe(...j),G=K;function nt(et){let Bt=S(et);if(!g(Bt))return;let At=c(Bt),gt=l.BASE.multiply(Bt).toAffine(),Nt=a(gt.x);if(Nt===_e)return;let he=a(At*a(G+Nt*F));if(he===_e)return;let Ge=(gt.x===Nt?0:2)|Number(gt.y&Gt),Fr=he;return k&&p(he)&&(Fr=h(he),Ge^=1),new b(Nt,Fr,Ge)}return{seed:q,k2sig:nt}}let R={lowS:t.lowS,prehash:!1},O={lowS:t.lowS,prehash:!1};function H(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=O){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,K;try{if(typeof y=="string"||Pe(y))try{L=b.fromDER(y)}catch(gt){if(!(gt instanceof or.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");K=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:F,s:j}=L,q=N(I),G=c(j),nt=a(q*G),et=a(F*G),Bt=l.BASE.multiplyAndAddUnsafe(K,nt,et)?.toAffine();return Bt?a(Bt.x)===F:!1}return{CURVE:t,getPublicKey:w,getSharedSecret:B,sign:H,verify:W,ProjectivePoint:l,Signature:b,utils:v}}function Kp(r){return{hash:r,hmac:(t,...e)=>He(r,t,Uo(...e)),randomBytes:We}}function ql(r,t){let e=n=>$l({...r,...Kp(n)});return Object.freeze({...e(t),create:e})}var zl=BigInt("0xfffffffffffffffffffffffffffffffffffffffffffffffffffffffefffffc2f"),Gl=BigInt("0xfffffffffffffffffffffffffffffffebaaedce6af48a03bbfd25e8cd0364141"),Fp=BigInt(1),Si=BigInt(2),jl=(r,t)=>(r+t/Si)/t;function $p(r){let t=zl,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,Si,t)*l%t,p=ot(m,s,t)*m%t,h=ot(p,o,t)*p%t,d=ot(h,a,t)*h%t,b=ot(d,c,t)*d%t,v=ot(b,a,t)*h%t,w=ot(v,e,t)*u%t,A=ot(w,i,t)*p%t,B=ot(A,n,t)*l%t,S=ot(B,Si,t);if(!ki.eql(ki.sqr(S),r))throw new Error("Cannot find square root");return S}var ki=Pn(zl,void 0,void 0,{sqrt:$p}),re=ql({a:BigInt(0),b:BigInt(7),Fp:ki,n:Gl,Gx:BigInt("55066263022277343669578718895168534326250603453777594175500187360389116729240"),Gy:BigInt("32670510020758816978083085130507043184471273380659243275938904335757337482424"),h:BigInt(1),lowS:!0,endo:{beta:BigInt("0x7ae96a2b657c07106e64479eac3434e99cf0497512f58995c1396c28719501ee"),splitScalar:r=>{let t=Gl,e=BigInt("0x3086d221a7d46bcde86c90e49284eb15"),n=-Fp*BigInt("0xe4437ed6010e88286f547fa90abfe4c3"),s=BigInt("0x114ca50f7a8e2f3f657c1108d9d44cfd8"),o=e,i=BigInt("0x100000000000000000000000000000000"),a=jl(o*r,t),c=jl(-n*r,t),l=X(r-a*e-c*s,t),u=X(-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),Yw=BigInt(0);var Zw=re.ProjectivePoint;function Wl(){return re.utils.randomPrivateKey()}function Yl(r,t){let e=St.digest(t instanceof Uint8Array?t:t.subarray());if(Ft(e))return e.then(({digest:n})=>re.sign(n,r).toDERRawBytes()).catch(n=>{throw new M(String(n),"ERR_INVALID_INPUT")});try{return re.sign(e.digest,r).toDERRawBytes()}catch(n){throw new M(String(n),"ERR_INVALID_INPUT")}}function Zl(r,t,e){let n=St.digest(e instanceof Uint8Array?e:e.subarray());if(Ft(n))return n.then(({digest:s})=>re.verify(t,s,r)).catch(s=>{throw new M(String(s),"ERR_INVALID_INPUT")});try{return re.verify(t,n.digest,r)}catch(s){throw new M(String(s),"ERR_INVALID_INPUT")}}function Xl(r){return re.ProjectivePoint.fromHex(r).toRawBytes(!0)}function Jl(r){try{re.getPublicKey(r,!0)}catch(t){throw new M(String(t),"ERR_INVALID_PRIVATE_KEY")}}function Ii(r){try{re.ProjectivePoint.fromHex(r)}catch(t){throw new M(String(t),"ERR_INVALID_PUBLIC_KEY")}}function Ql(r){try{return re.getPublicKey(r,!0)}catch(t){throw new M(String(t),"ERR_INVALID_PRIVATE_KEY")}}var pn=class{_key;constructor(t){Ii(t),this._key=t}verify(t,e){return Zl(this._key,e,t)}marshal(){return Xl(this._key)}get bytes(){return ie.encode({Type:at.Secp256k1,Data:this.marshal()}).subarray()}equals(t){return ft(this.bytes,t.bytes)}async hash(){let t=St.digest(this.bytes),e;return Ft(t)?{bytes:e}=await t:e=t.bytes,e}},gn=class{_key;_publicKey;constructor(t,e){this._key=t,this._publicKey=e??Ql(t),Jl(this._key),Ii(this._publicKey)}sign(t){return Yl(this._key,t)}get public(){return new pn(this._publicKey)}marshal(){return this._key}get bytes(){return ae.encode({Type:at.Secp256k1,Data:this.marshal()}).subarray()}equals(t){return ft(this.bytes,t.bytes)}hash(){let t=St.digest(this.bytes);return Ft(t)?t.then(({bytes:e})=>e):t.bytes}async id(){let t=await this.public.hash();return $(t,"base58btc")}async export(t,e="libp2p-key"){if(e==="libp2p-key")return Er(this.bytes,t);throw new M(`export format '${e}' is not supported`,"ERR_INVALID_EXPORT_FORMAT")}};function Gp(r){return new gn(r)}function jp(r){return new pn(r)}async function zp(){let r=Wl();return new gn(r)}var ir={rsa:Bi,ed25519:di,secp256k1:_i};function tu(r){let t=Object.keys(ir).join(" / ");return new M(`invalid or unsupported key type ${r}. Must be ${t}`,"ERR_UNSUPPORTED_KEY_TYPE")}function eu(r){let t=ie.decode(r),e=t.Data??new Uint8Array;switch(t.Type){case at.RSA:return ir.rsa.unmarshalRsaPublicKey(e);case at.Ed25519:return ir.ed25519.unmarshalEd25519PublicKey(e);case at.Secp256k1:return ir.secp256k1.unmarshalSecp256k1PublicKey(e);default:throw tu(t.Type??"unknown")}}async function Ni(r){let t=ae.decode(r),e=t.Data??new Uint8Array;switch(t.Type){case at.RSA:return ir.rsa.unmarshalRsaPrivateKey(e);case at.Ed25519:return ir.ed25519.unmarshalEd25519PrivateKey(e);case at.Secp256k1:return ir.secp256k1.unmarshalSecp256k1PrivateKey(e);default:throw tu(t.Type??"RSA")}}var nu=Symbol.for("nodejs.util.inspect.custom"),ru=Object.values(se).map(r=>r.decoder).reduce((r,t)=>r.or(t),se.identity.decoder),su=114,Li=36,Ci=37,mn=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()})`}[co]=!0;toString(){return this.string==null&&(this.string=ut.encode(this.multihash.bytes).slice(1)),this.string}toCID(){return Kt.createV1(su,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 Ui(t).equals(this);if(t?.multihash?.bytes!=null)return ft(this.multihash.bytes,t.multihash.bytes);throw new Error("not valid Id")}[nu](){return`PeerId(${this.toString()})`}},Tr=class extends mn{type="RSA";publicKey;constructor(t){super({...t,type:"RSA"}),this.publicKey=t.publicKey}},Rr=class extends mn{type="Ed25519";publicKey;constructor(t){super({...t,type:"Ed25519"}),this.publicKey=t.multihash.digest}},Lr=class extends mn{type="secp256k1";publicKey;constructor(t){super({...t,type:"secp256k1"}),this.publicKey=t.multihash.digest}},Ti=2336,Ri=class{type="url";multihash;privateKey;publicKey;url;constructor(t){this.url=t.toString(),this.multihash=pe.digest(Z(this.url))}[nu](){return`PeerId(${this.url})`}[co]=!0;toString(){return this.toCID().toString()}toCID(){return Kt.createV1(Ti,this.multihash)}toBytes(){return this.toCID().bytes}equals(t){return t==null?!1:(t instanceof Uint8Array&&(t=$(t)),t.toString()===this.toString())}};function Ui(r,t){if(t=t??ru,r.charAt(0)==="1"||r.charAt(0)==="Q"){let e=Re(ut.decode(`z${r}`));return r.startsWith("12D")?new Rr({multihash:e}):r.startsWith("16U")?new Lr({multihash:e}):new Tr({multihash:e})}return Wp(ru.decode(r))}function Wp(r){try{let t=Re(r);if(t.code===pe.code){if(t.digest.length===Li)return new Rr({multihash:t});if(t.digest.length===Ci)return new Lr({multihash:t})}if(t.code===St.code)return new Tr({multihash:t})}catch{return Yp(Kt.decode(r))}throw new Error("Supplied PeerID CID is invalid")}function Yp(r){if(r?.multihash==null||r.version==null||r.version===1&&r.code!==su&&r.code!==Ti)throw new Error("Supplied PeerID CID is invalid");if(r.code===Ti){let e=$(r.multihash.digest);return new Ri(new URL(e))}let t=r.multihash;if(t.code===St.code)return new Tr({multihash:r.multihash});if(t.code===pe.code){if(t.digest.length===Li)return new Rr({multihash:r.multihash});if(t.digest.length===Ci)return new Lr({multihash:r.multihash})}throw new Error("Supplied PeerID CID is invalid")}async function Pi(r,t){return r.length===Li?new Rr({multihash:zt(pe.code,r),privateKey:t}):r.length===Ci?new Lr({multihash:zt(pe.code,r),privateKey:t}):new Tr({multihash:await St.digest(r),publicKey:r,privateKey:t})}var iu=Symbol.for("@achingbrain/uint8arraylist");function ou(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 Cs(r){return!!r?.[iu]}var ct=class r{bufs;length;[iu]=!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(Cs(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(Cs(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=ou(this.bufs,t);return e.buf[e.index]}set(t,e){let n=ou(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(Cs(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 Et(n,s)}subarray(t,e){let{bufs:n,length:s}=this._subList(t,e);return n.length===1?n[0]:Et(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(!Cs(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=yt(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=yt(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=yt(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=yt(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=yt(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=yt(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=yt(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=yt(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 Us(r){return r[Symbol.asyncIterator]!=null}var Ps=r=>{let t=dt(r),e=wt(t);return oe(r,e),Ps.bytes=t,e};Ps.bytes=0;function au(r,t){t=t??{};let e=t.lengthEncoder??Ps;function*n(s){let o=e(s.byteLength);o instanceof Uint8Array?yield o:yield*o,s instanceof Uint8Array?yield s:yield*s}return Us(r)?async function*(){for await(let s of r)yield*n(s)}():function*(){for(let s of r)yield*n(s)}()}au.single=(r,t)=>{t=t??{};let e=t.lengthEncoder??Ps;return new ct(e(r.byteLength),r)};var Cr=Ga(uu(),1);var Xp=8,Jp=1024*1024*4,ar;(function(r){r[r.LENGTH=0]="LENGTH",r[r.DATA=1]="DATA"})(ar||(ar={}));var Di=r=>{let t=Jt(r);return Di.bytes=dt(t),t};Di.bytes=0;function yn(r,t){let e=new ct,n=ar.LENGTH,s=-1,o=t?.lengthDecoder??Di,i=t?.maxLengthLength??Xp,a=t?.maxDataLength??Jp;function*c(){for(;e.byteLength>0;){if(n===ar.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=ar.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===ar.DATA){if(e.byteLength<s)break;let l=e.sublist(0,s);e.consume(s),t?.onData!=null&&t.onData(l),yield l,n=ar.LENGTH}}}return Us(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 Ct(){let r={};return r.promise=new Promise((t,e)=>{r.resolve=t,r.reject=e}),r}var Ds=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 Dt(r,t,e){if(t==null)return r;if(t.aborted)return Promise.reject(new Ds(e?.errorMessage,e?.errorCode));let n,s=new Ds(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 Vi=class{readNext;haveNext;ended;nextResult;constructor(){this.ended=!1,this.readNext=Ct(),this.haveNext=Ct()}[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=Ct(),t}async throw(t){return this.ended=!0,t!=null&&(this.haveNext.promise.catch(()=>{}),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");for(;this.nextResult!=null;)await this.readNext.promise;t!=null?this.nextResult={done:!1,value:t}:(this.ended=!0,this.nextResult={done:!0,value:void 0}),this.haveNext.resolve(),this.haveNext=Ct(),await Dt(this.readNext.promise,e?.signal,e)}};function fu(){return new Vi}var Vs=class extends Error{code;constructor(t,e){super(t),this.code=e}},Hi=class extends Vs{type;constructor(t){super(t,"ABORT_ERR"),this.type="aborted"}};function hu(r,t){let e=fu();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 ct;return{read:async(i,a)=>{a?.signal?.throwIfAborted();let c,l=new Promise((u,f)=>{c=()=>{f(new Hi("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 ct:g}for(;s.byteLength<i;){let{value:f,done:g}=await Promise.race([n.next(),l]);if(g===!0)throw new Vs("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 Hs=class extends Error{code;constructor(t,e){super(t),this.code=e}};function Oi(r,t={}){let e=hu(r,t);t.maxDataLength!=null&&t.maxLengthLength==null&&(t.maxLengthLength=dt(t.maxDataLength));let n=t?.lengthDecoder??Jt,s=t?.lengthEncoder??oe;return{read:async i=>{let a=-1,c=new ct;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 Hs("message length length too long","ERR_MSG_LENGTH_TOO_LONG");if(a>-1)break}if(t?.maxDataLength!=null&&a>t.maxDataLength)throw new Hs("message length too long","ERR_MSG_DATA_TOO_LONG");return e.read(a,i)},write:async(i,a)=>{await e.write(new ct(s(i.byteLength),i),a)},writeV:async(i,a)=>{let c=new ct(...i.flatMap(l=>[s(l.byteLength),l]));await e.write(c,a)},unwrap:()=>e.unwrap()}}function Mi(){let r=Ct(),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 du(){let r=Mi(),t=Mi();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 Ki=class extends Error{type;code;constructor(t,e){super(t??"The operation was aborted"),this.type="aborted",this.code=e??"ABORT_ERR"}};function Pr(r={}){return Qp(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 Qp(r,t){t=t??{};let e=t.onEnd,n=new Ur,s,o,i,a=Ct(),c=async()=>{try{return n.isEmpty()?i?{done:!0}:await new Promise((d,b)=>{o=v=>{o=null,n.push(v);try{d(r(n))}catch(w){b(w)}return s}}):r(n)}finally{n.isEmpty()&&queueMicrotask(()=>{a.resolve(),a=Ct()})}},l=d=>o!=null?o(d):(n.push(d),s),u=d=>(n=new Ur,o!=null?o({error:d}):(n.push({error:d}),s)),f=d=>{if(i)return s;if(t?.objectMode!==!0&&d?.byteLength==null)throw new Error("objectMode was not true but tried to push non-Uint8Array value");return l({done:!1,value:d})},g=d=>i?s:(i=!0,d!=null?u(d):l({done:!0})),m=()=>(n=new Ur,g(),{done:!0}),p=d=>(g(d),{done:!0});if(s={[Symbol.asyncIterator](){return this},next:c,return:m,throw:p,push:f,end:g,get readableLength(){return n.size},onEmpty:async d=>{let b=d?.signal;if(b?.throwIfAborted(),n.isEmpty())return;let v,w;b!=null&&(v=new Promise((A,B)=>{w=()=>{B(new Ki)},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(d){return h.throw(d),e!=null&&(e(d),e=void 0),{done:!0}},return(){return h.return(),e!=null&&(e(),e=void 0),{done:!0}},push:f,end(d){return h.end(d),e!=null&&(e(d),e=void 0),s},get readableLength(){return h.readableLength},onEmpty:d=>h.onEmpty(d)},s}function t0(r){return r[Symbol.asyncIterator]!=null}function e0(...r){let t=[];for(let e of r)t0(e)||t.push(e);return t.length===r.length?function*(){for(let e of t)yield*e}():async function*(){let e=Pr({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 pu=e0;function gu(r,...t){if(r==null)throw new Error("Empty pipeline");if(Fi(r)){let n=r;r=()=>n.source}else if(yu(r)||mu(r)){let n=r;r=()=>n}let e=[r,...t];if(e.length>1&&Fi(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++)Fi(e[n])&&(e[n]=n0(e[n]));return r0(...e)}var r0=(...r)=>{let t;for(;r.length>0;)t=r.shift()(t);return t},mu=r=>r?.[Symbol.asyncIterator]!=null,yu=r=>r?.[Symbol.iterator]!=null,Fi=r=>r==null?!1:r.sink!=null&&r.source!=null,n0=r=>t=>{let e=r.sink(t);if(e?.then!=null){let n=Pr({objectMode:!0});e.then(()=>{n.end()},i=>{n.end(i)});let s,o=r.source;if(mu(o))s=async function*(){yield*o,n.end()};else if(yu(o))s=function*(){yield*o,n.end()};else throw new Error("Unknown duplex source type - must be Iterable or AsyncIterable");return pu(n,s())}return r.source};var Dr=!!globalThis.process?.env?.DUMP_SESSION_KEYS;function Ms(r){if(!Number.isSafeInteger(r)||r<0)throw new Error(`positive integer expected, not ${r}`)}function $i(r){if(typeof r!="boolean")throw new Error(`boolean expected, not ${r}`)}function qi(r){return r instanceof Uint8Array||r!=null&&typeof r=="object"&&r.constructor.name==="Uint8Array"}function Ht(r,...t){if(!qi(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 wu(r,t){Ht(r);let e=t.outputLen;if(r.length<e)throw new Error(`digestInto() expects output buffer of length at least ${e}`)}var Ne=r=>new Uint32Array(r.buffer,r.byteOffset,Math.floor(r.byteLength/4)),bu=r=>new DataView(r.buffer,r.byteOffset,r.byteLength),s0=new Uint8Array(new Uint32Array([287454020]).buffer)[0]===68;if(!s0)throw new Error("Non little-endian hardware is not supported");function o0(r){if(typeof r!="string")throw new Error(`string expected, got ${typeof r}`);return new Uint8Array(new TextEncoder().encode(r))}function Ks(r){if(typeof r=="string")r=o0(r);else if(qi(r))r=r.slice();else throw new Error(`Uint8Array expected, got ${typeof r}`);return r}function xu(r,t){if(t==null||typeof t!="object")throw new Error("options must be defined");return Object.assign(r,t)}function Eu(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 ji=(r,t)=>(Object.assign(t,r),t);function zi(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 It=(r,t)=>r[t++]&255|(r[t++]&255)<<8,Wi=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),Ht(t,32);let e=It(t,0),n=It(t,2),s=It(t,4),o=It(t,6),i=It(t,8),a=It(t,10),c=It(t,12),l=It(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]=It(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],p=i[7],h=i[8],d=i[9],b=It(t,e+0),v=It(t,e+2),w=It(t,e+4),A=It(t,e+6),B=It(t,e+8),S=It(t,e+10),N=It(t,e+12),_=It(t,e+14),V=o[0]+(b&8191),P=o[1]+((b>>>13|v<<3)&8191),R=o[2]+((v>>>10|w<<6)&8191),O=o[3]+((w>>>7|A<<9)&8191),H=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*d)+R*(5*h)+O*(5*p)+H*(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*d)+O*(5*h)+H*(5*p);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+O*(5*d)+H*(5*h);y=L>>>13,L&=8191,L+=W*(5*p)+x*(5*m)+I*(5*g)+C*(5*f)+E*(5*u),y+=L>>>13,L&=8191;let K=y+V*u+P*l+R*c+O*a+H*(5*d);y=K>>>13,K&=8191,K+=W*(5*h)+x*(5*p)+I*(5*m)+C*(5*g)+E*(5*f),y+=K>>>13,K&=8191;let F=y+V*f+P*u+R*l+O*c+H*a;y=F>>>13,F&=8191,F+=W*(5*d)+x*(5*h)+I*(5*p)+C*(5*m)+E*(5*g),y+=F>>>13,F&=8191;let j=y+V*g+P*f+R*u+O*l+H*c;y=j>>>13,j&=8191,j+=W*a+x*(5*d)+I*(5*h)+C*(5*p)+E*(5*m),y+=j>>>13,j&=8191;let q=y+V*m+P*g+R*f+O*u+H*l;y=q>>>13,q&=8191,q+=W*c+x*a+I*(5*d)+C*(5*h)+E*(5*p),y+=q>>>13,q&=8191;let G=y+V*p+P*m+R*g+O*f+H*u;y=G>>>13,G&=8191,G+=W*l+x*c+I*a+C*(5*d)+E*(5*h),y+=G>>>13,G&=8191;let nt=y+V*h+P*p+R*m+O*g+H*f;y=nt>>>13,nt&=8191,nt+=W*u+x*l+I*c+C*a+E*(5*d),y+=nt>>>13,nt&=8191;let et=y+V*d+P*h+R*p+O*m+H*g;y=et>>>13,et&=8191,et+=W*f+x*u+I*l+C*c+E*a,y+=et>>>13,et&=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]=K,o[4]=F,o[5]=j,o[6]=q,o[7]=G,o[8]=nt,o[9]=et}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),wu(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 i0(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 vu=i0(r=>new Wi(r));var Au=r=>Uint8Array.from(r.split("").map(t=>t.charCodeAt(0))),a0=Au("expand 16-byte k"),c0=Au("expand 32-byte k"),l0=Ne(a0),Su=Ne(c0),gx=Su.slice();function D(r,t){return r<<t|r>>>32-t}function Yi(r){return r.byteOffset%4===0}var Fs=64,u0=16,ku=2**32-1,Bu=new Uint32Array;function f0(r,t,e,n,s,o,i,a){let c=s.length,l=new Uint8Array(Fs),u=Ne(l),f=Yi(s)&&Yi(o),g=f?Ne(s):Bu,m=f?Ne(o):Bu;for(let p=0;p<c;i++){if(r(t,e,n,u,i,a),i>=ku)throw new Error("arx: counter overflow");let h=Math.min(Fs,c-p);if(f&&h===Fs){let d=p/4;if(p%4!==0)throw new Error("arx: invalid block position");for(let b=0,v;b<u0;b++)v=d+b,m[v]=g[v]^u[b];p+=Fs;continue}for(let d=0,b;d<h;d++)b=p+d,o[b]=s[b]^l[d];p+=h}}function Zi(r,t){let{allowShortKeys:e,extendNonceFn:n,counterLength:s,counterRight:o,rounds:i}=xu({allowShortKeys:!1,counterLength:8,counterRight:!1,rounds:20},t);if(typeof r!="function")throw new Error("core must be a function");return Ms(s),Ms(i),$i(o),$i(e),(a,c,l,u,f=0)=>{Ht(a),Ht(c),Ht(l);let g=l.length;if(u||(u=new Uint8Array(g)),Ht(u),Ms(f),f<0||f>=ku)throw new Error("arx: counter overflow");if(u.length<g)throw new Error(`arx: output (${u.length}) is shorter than data (${g})`);let m=[],p=a.length,h,d;if(p===32)h=a.slice(),m.push(h),d=Su;else if(p===16&&e)h=new Uint8Array(32),h.set(a),h.set(a,16),d=l0,m.push(h);else throw new Error(`arx: invalid 32-byte key, got length=${p}`);Yi(c)||(c=c.slice(),m.push(c));let b=Ne(h);if(n){if(c.length!==24)throw new Error("arx: extended nonce must be 24 bytes");n(d,b,Ne(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=Ne(c);for(f0(r,d,b,w,l,u,f,i);m.length>0;)m.pop().fill(0);return u}}function Nu(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],p=t[4],h=t[5],d=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,O=g,H=m,W=p,x=h,I=d,C=b,E=v,y=w,k=A,T=B;for(let K=0;K<o;K+=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),_=_+O|0,k=D(k^_,16),I=I+k|0,O=D(O^I,12),_=_+O|0,k=D(k^_,8),I=I+k|0,O=D(O^I,7),V=V+H|0,T=D(T^V,16),C=C+T|0,H=D(H^C,12),V=V+H|0,T=D(T^V,8),C=C+T|0,H=D(H^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+O|0,E=D(E^N,16),C=C+E|0,O=D(O^C,12),N=N+O|0,E=D(E^N,8),C=C+E|0,O=D(O^C,7),_=_+H|0,y=D(y^_,16),W=W+y|0,H=D(H^W,12),_=_+H|0,y=D(y^_,8),W=W+y|0,H=D(H^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+O|0,n[L++]=m+H|0,n[L++]=p+W|0,n[L++]=h+x|0,n[L++]=d+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 h0(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],p=t[6],h=t[7],d=e[0],b=e[1],v=e[2],w=e[3];for(let B=0;B<20;B+=2)s=s+c|0,d=D(d^s,16),g=g+d|0,c=D(c^g,12),s=s+c|0,d=D(d^s,8),g=g+d|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),p=p+v|0,u=D(u^p,12),i=i+u|0,v=D(v^i,8),p=p+v|0,u=D(u^p,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),p=p+w|0,l=D(l^p,12),s=s+l|0,w=D(w^s,8),p=p+w|0,l=D(l^p,7),o=o+u|0,d=D(d^o,16),h=h+d|0,u=D(u^h,12),o=o+u|0,d=D(d^o,8),h=h+d|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++]=d,n[A++]=b,n[A++]=v,n[A++]=w}var d0=Zi(Nu,{counterRight:!1,counterLength:4,allowShortKeys:!1}),p0=Zi(Nu,{counterRight:!1,counterLength:8,extendNonceFn:h0,allowShortKeys:!1});var g0=new Uint8Array(16),Iu=(r,t)=>{r.update(t);let e=t.length%16;e&&r.update(g0.subarray(e))},m0=new Uint8Array(32);function _u(r,t,e,n,s){let o=r(t,e,m0),i=vu.create(o);s&&Iu(i,s),Iu(i,n);let a=new Uint8Array(16),c=bu(a);zi(c,0,BigInt(s?s.length:0),!0),zi(c,8,BigInt(n.length),!0),i.update(a);let l=i.digest();return o.fill(0),l}var Tu=r=>(t,e,n)=>(Ht(t,32),Ht(e),{encrypt:(o,i)=>{let a=o.length,c=a+16;i?Ht(i,c):i=new Uint8Array(c),r(t,e,o,i,1);let l=_u(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?Ht(i,c):i=new Uint8Array(c);let l=o.subarray(0,-16),u=o.subarray(-16),f=_u(r,t,e,l,n);if(!Eu(u,f))throw new Error("invalid tag");return r(t,e,l,i,1),i}}),Xi=ji({blockSize:64,nonceLength:12,tagLength:16},Tu(d0)),Ex=ji({blockSize:64,nonceLength:24,tagLength:16},Tu(p0));function Lu(r,t,e){return ze(r),e===void 0&&(e=new Uint8Array(r.outputLen)),He(r,Yt(e),Yt(t))}var Ji=new Uint8Array([0]),Ru=new Uint8Array;function Cu(r,t,e,n=32){if(ze(r),Le(n),n>255*r.outputLen)throw new Error("Length should be <= 255*HashLen");let s=Math.ceil(n/r.outputLen);e===void 0&&(e=Ru);let o=new Uint8Array(s*r.outputLen),i=He.create(r,t),a=i._cloneInto(),c=new Uint8Array(i.outputLen);for(let l=0;l<s;l++)Ji[0]=l+1,a.update(l===0?Ru:c).update(e).update(Ji).digestInto(c),o.set(c,r.outputLen*l),i._cloneInto(a);return i.destroy(),a.destroy(),c.fill(0),Ji.fill(0),o.slice(0,n)}var Qi={hashSHA256(r){return Nr(r.subarray())},getHKDF(r,t){let e=Lu(Nr,t,r),s=Cu(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=Xr.utils.randomPrivateKey();return{publicKey:Xr.getPublicKey(r),privateKey:r}},generateX25519KeyPairFromSeed(r){return{publicKey:Xr.getPublicKey(r),privateKey:r}},generateX25519SharedKey(r,t){return Xr.getSharedSecret(r.subarray(),t.subarray())},chaCha20Poly1305Encrypt(r,t,e,n){return Xi(n,t,e).encrypt(r.subarray())},chaCha20Poly1305Decrypt(r,t,e,n,s){return Xi(n,t,e).decrypt(r.subarray(),s)}};var Uu=Qi;function Pu(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 wn=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)};wn.bytes=2;function Du(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 ta(r,t){!t.enabled||!Dr||(r?(t(`LOCAL_STATIC_PUBLIC_KEY ${$(r.publicKey,"hex")}`),t(`LOCAL_STATIC_PRIVATE_KEY ${$(r.privateKey,"hex")}`)):t("Missing local static keys."))}function ea(r,t){!t.enabled||!Dr||(r?(t(`LOCAL_PUBLIC_EPHEMERAL_KEY ${$(r.publicKey,"hex")}`),t(`LOCAL_PRIVATE_EPHEMERAL_KEY ${$(r.privateKey,"hex")}`)):t("Missing local ephemeral keys."))}function Vu(r,t){!t.enabled||!Dr||t(r?`REMOTE_STATIC_PUBLIC_KEY ${$(r.subarray(),"hex")}`:"Missing remote static public key.")}function ra(r,t){!t.enabled||!Dr||t(r?`REMOTE_EPHEMERAL_PUBLIC_KEY ${$(r.subarray(),"hex")}`:"Missing remote ephemeral keys.")}function na(r,t,e){!e.enabled||!Dr||(e(`CIPHER_STATE_1 ${r.n.getUint64()} ${r.k&&$(r.k,"hex")}`),e(`CIPHER_STATE_2 ${t.n.getUint64()} ${t.k&&$(t.k,"hex")}`))}var $s=class r extends Error{code;constructor(t="Unexpected Peer"){super(t),this.code=r.code}static code="ERR_UNEXPECTED_PEER"},Hr=class r extends Error{code;constructor(t="Invalid crypto exchange"){super(t),this.code=r.code}static code="ERR_INVALID_CRYPTO_EXCHANGE"};var y0=0,w0=4294967295,b0="Cipherstate has reached maximum n, a new handshake must be performed",qs=class{n;bytes;view;constructor(t=y0){this.n=t,this.bytes=yt(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>w0)throw new Error(b0)}};var cr=yt(0),Or=class{k;n;crypto;constructor(t,e=void 0,n=0){this.crypto=t,this.k=e,this.n=new qs(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}},sa=class{cs;ck;h;crypto;constructor(t,e){this.crypto=t;let n=Z(e,"utf-8");this.h=x0(t,n),this.ck=this.h,this.cs=new Or(t)}mixKey(t){let[e,n]=this.crypto.hkdf(this.ck,t);this.ck=e,this.cs=new Or(this.crypto,n)}mixHash(t){this.h=this.crypto.hash(new ct(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 Or(this.crypto,t),new Or(this.crypto,e)]}},oa=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 sa(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()}},bn=class extends oa{writeMessageA(t){return new ct(this.writeE(),this.ss.encryptAndHash(t))}writeMessageB(t){let e=this.writeE();this.writeEE();let n=this.writeS();return this.writeES(),new ct(e,n,this.ss.encryptAndHash(t))}writeMessageC(t){let e=this.writeS();return this.writeSE(),new ct(e,this.ss.encryptAndHash(t))}readMessageA(t){try{return this.readE(t),this.ss.decryptAndHash(t.sublist(32))}catch(e){throw new Hr(`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 Hr(`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 Hr(`handshake stage 2 validation fail: ${e.message}`)}}};function x0(r,t){if(t.length<=32){let e=yt(32);return e.set(t),e}else return r.hash(t)}var Gs;(function(r){let t;r.codec=()=>(t==null&&(t=er((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=>tr(e,r.codec()),r.decode=e=>Je(e,r.codec())})(Gs||(Gs={}));var xn;(function(r){let t;r.codec=()=>(t==null&&(t=er((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),Gs.codec().encode(e.extensions,n)),s.lengthDelimited!==!1&&n.ldelim()},(e,n)=>{let s={identityKey:yt(0),identitySig:yt(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=Gs.codec().decode(e,e.uint32());break}default:{e.skipType(i&7);break}}}return s})),t),r.encode=e=>tr(e,r.codec()),r.decode=e=>Je(e,r.codec())})(xn||(xn={}));async function ia(r,t,e){let n=await r.sign(Hu(t));return xn.encode({identityKey:r.public.bytes,identitySig:n,extensions:e})}async function aa(r,t,e){try{let n=xn.decode(r);if(e){let i=e.subarray();if(!ft(i,n.identityKey))throw new Error(`Payload identity key ${$(n.identityKey,"hex")} does not match expected remote identity key ${$(i,"hex")}`)}if(!t)throw new Error("Remote static does not exist");let s=Hu(t);if(!await eu(n.identityKey).verify(s,n.identitySig))throw new Error("Invalid payload signature");return n}catch(n){throw new $s(n.message)}}function Hu(r){let t=Z("noise-libp2p-static-key:");return r instanceof Uint8Array?Et([t,r],t.length+r.length):(r.prepend(t),r)}async function Ou(r){let{log:t,connection:e,crypto:n,privateKey:s,prologue:o,s:i,remoteIdentityKey:a,extensions:c}=r,l=await ia(s,i.publicKey,c),u=new bn({crypto:n,protocolName:"Noise_XX_25519_ChaChaPoly_SHA256",initiator:!0,prologue:o,s:i});ta(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."),ea(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."),ra(u.re,t),Vu(u.rs,t),t.trace("Initiator going to check remote's signature...");let g=await aa(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,p]=u.ss.split();return na(m,p,t),{payload:g,encrypt:h=>m.encryptWithAd(cr,h),decrypt:(h,d)=>p.decryptWithAd(cr,h,d)}}async function Mu(r){let{log:t,connection:e,crypto:n,privateKey:s,prologue:o,s:i,remoteIdentityKey:a,extensions:c}=r,l=await ia(s,i.publicKey,c),u=new bn({crypto:n,protocolName:"Noise_XX_25519_ChaChaPoly_SHA256",initiator:!1,prologue:o,s:i});ta(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."),ra(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."),ea(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 aa(f,u.rs,a),[m,p]=u.ss.split();return na(m,p,t),{payload:g,encrypt:h=>p.encryptWithAd(cr,h),decrypt:(h,d)=>m.decryptWithAd(cr,h,d)}}var Fu=16;function $u(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 ct(Vr(i.byteLength),i)}}}function qu(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-Fu<s)throw new Error("Invalid chunk");let i=n.sublist(s,o),a=n.subarray(s,o-Fu);try{let c=r.decrypt(i,a);t?.decryptedPackets.increment(),yield c}catch(c){throw t?.decryptErrors.increment(),c}}}}var js=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??Uu;this.crypto=Pu(c),this.extensions=s,this.metrics=a?Du(a):void 0,n?this.staticKey=c.generateX25519KeyPairFromSeed(n):this.staticKey=c.generateX25519KeyPair(),this.prologue=i??yt(0)}[Symbol.toStringTag]="@chainsafe/libp2p-noise";[kn]=["@libp2p/connection-encryption","@chainsafe/libp2p-noise"];async secureOutbound(t,e,n){let s=Oi(e,{lengthEncoder:Vr,lengthDecoder:wn,maxDataLength:65535});if(!t.privateKey)throw new M("local peerId does not contain private key","ERR_NO_PRIVATE_KEY");let o=await Ni(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 Pi(a.payload.identityKey)}}async secureInbound(t,e,n){let s=Oi(e,{lengthEncoder:Vr,lengthDecoder:wn,maxDataLength:65535});if(!t.privateKey)throw new M("local peerId does not contain private key","ERR_NO_PRIVATE_KEY");let o=await Ni(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 Pi(a.payload.identityKey)}}async performHandshakeInitiator(t,e,n){let s;try{s=await Ou({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 Mu({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]=du(),o=t.unwrap();return await gu(n,$u(e,this.metrics),o,i=>yn(i,{lengthDecoder:wn}),qu(e,this.metrics),n),s}};function Gu(r={}){return t=>new js(t,r)}var zs=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 ju=45,E0=15,Mr=new zs;function ca(r){if(!(r.length>E0))return Mr.new(r).parseWith(()=>Mr.readIPv4Addr())}function la(r){if(r.includes("%")&&(r=r.split("%")[0]),!(r.length>ju))return Mr.new(r).parseWith(()=>Mr.readIPv6Addr())}function Ws(r){if(r.includes("%")&&(r=r.split("%")[0]),!(r.length>ju))return Mr.new(r).parseWith(()=>Mr.readIPAddr())}function Ys(r){return!!ca(r)}function Zs(r){return!!la(r)}function Xs(r){return!!Ws(r)}var o2=parseInt("0xFFFF",16),i2=new Uint8Array([0,0,0,0,0,0,0,0,0,0,255,255]);var Yu=Ys,k0=Zs,ua=function(r){let t=0;if(r=r.toString().trim(),Yu(r)){let e=new Uint8Array(t+4);return r.split(/\./g).forEach(n=>{e[t++]=parseInt(n,10)&255}),e}if(k0(r)){let e=r.split(":",8),n;for(n=0;n<e.length;n++){let o=Yu(e[n]),i;o&&(i=ua(e[n]),e[n]=$(i.slice(0,2),"base16")),i!=null&&++n<8&&e.splice(n,0,$(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")},Zu=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={},fa={},_0=[[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"],[481,-1,"http-path"],[777,-1,"memory"]];_0.forEach(r=>{let t=N0(...r);fa[t.code]=t,Kr[t.name]=t});function N0(r,t,e,n,s){return{code:r,size:t,name:e,resolvable:!!n,path:!!s}}function tt(r){if(typeof r=="number"){if(fa[r]!=null)return fa[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 K2=tt("ip4"),F2=tt("ip6"),$2=tt("ipcidr");function ga(r,t){switch(tt(r).code){case 4:case 41:return R0(t);case 42:return pa(t);case 6:case 273:case 33:case 132:return Qu(t).toString();case 53:case 54:case 55:case 56:case 400:case 449:case 777:return pa(t);case 421:return P0(t);case 444:return Ju(t);case 445:return Ju(t);case 466:return U0(t);case 481:return globalThis.encodeURIComponent(pa(t));default:return $(t,"base16")}}function ma(r,t){switch(tt(r).code){case 4:return Xu(t);case 41:return Xu(t);case 42:return da(t);case 6:case 273:case 33:case 132:return ya(parseInt(t,10));case 53:case 54:case 55:case 56:case 400:case 449:case 777:return da(t);case 421:return L0(t);case 444:return D0(t);case 445:return V0(t);case 466:return C0(t);case 481:return da(globalThis.decodeURIComponent(t));default:return Z(t,"base16")}}var ha=Object.values(se).map(r=>r.decoder),T0=function(){let r=ha[0].or(ha[1]);return ha.slice(2).forEach(t=>r=r.or(t)),r}();function Xu(r){if(!Xs(r))throw new Error("invalid ip address");return ua(r)}function R0(r){let t=Zu(r,0,r.length);if(t==null)throw new Error("ipBuff is required");if(!Xs(t))throw new Error("invalid ip address");return t}function ya(r){let t=new ArrayBuffer(2);return new DataView(t).setUint16(0,r),new Uint8Array(t)}function Qu(r){return new DataView(r.buffer).getUint16(r.byteOffset)}function da(r){let t=Z(r),e=Uint8Array.from(oe(t.length));return Et([e,t],e.length+t.length)}function pa(r){let t=Jt(r);if(r=r.slice(dt(t)),r.length!==t)throw new Error("inconsistent lengths");return $(r)}function L0(r){let t;r[0]==="Q"||r[0]==="1"?t=Re(ut.decode(`z${r}`)).bytes:t=Kt.parse(r).multihash.bytes;let e=Uint8Array.from(oe(t.length));return Et([e,t],e.length+t.length)}function C0(r){let t=T0.decode(r),e=Uint8Array.from(oe(t.length));return Et([e,t],e.length+t.length)}function U0(r){let t=Jt(r),e=r.slice(dt(t));if(e.length!==t)throw new Error("inconsistent lengths");return"u"+$(e,"base64url")}function P0(r){let t=Jt(r),e=r.slice(dt(t));if(e.length!==t)throw new Error("inconsistent lengths");return $(e,"base58btc")}function D0(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=ge.decode("b"+t[0]),n=parseInt(t[1],10);if(n<1||n>65536)throw new Error("Port number is not in range(1, 65536)");let s=ya(n);return Et([e,s],e.length+s.length)}function V0(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=ge.decode(`b${t[0]}`),n=parseInt(t[1],10);if(n<1||n>65536)throw new Error("Port number is not in range(1, 65536)");let s=ya(n);return Et([e,s],e.length+s.length)}function Ju(r){let t=r.slice(0,r.length-2),e=r.slice(r.length-2),n=$(t,"base32"),s=Qu(e);return`${n}:${s}`}function tf(r){r=wa(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=tt(i);if(a.size===0){t.push([a.code]),e.push([a.code]);continue}if(o++,o>=s.length)throw rf("invalid address: "+r);if(a.path===!0){n=wa(s.slice(o).join("/")),t.push([a.code,ma(a.code,n)]),e.push([a.code,n]);break}let c=ma(a.code,s[o]);t.push([a.code,c]),e.push([a.code,ga(a.code,c)])}return{string:ef(e),bytes:xa(t),tuples:t,stringTuples:e,path:n}}function ba(r){let t=[],e=[],n=null,s=0;for(;s<r.length;){let o=Jt(r,s),i=dt(o),a=tt(o),c=H0(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 rf("Invalid address Uint8Array: "+$(r,"base16"));t.push([o,l]);let u=ga(o,l);if(e.push([o,u]),a.path===!0){n=u;break}}return{bytes:Uint8Array.from(r),string:ef(e),tuples:t,stringTuples:e,path:n}}function ef(r){let t=[];return r.map(e=>{let n=tt(e[0]);return t.push(n.name),e.length>1&&e[1]!=null&&t.push(e[1]),null}),wa(t.join("/"))}function xa(r){return Et(r.map(t=>{let e=tt(t[0]),n=Uint8Array.from(oe(e.code));return t.length>1&&t[1]!=null&&(n=Et([n,t[1]])),n}))}function H0(r,t){if(r.size>0)return r.size/8;if(r.size===0)return 0;{let e=Jt(t instanceof Uint8Array?t:Uint8Array.from(t));return e+dt(e)}}function wa(r){return"/"+r.trim().split("/").filter(t=>t).join("/")}function rf(r){return new Error("Error parsing address: "+r)}var O0=Symbol.for("nodejs.util.inspect.custom"),Ea=Symbol.for("@multiformats/js-multiaddr/multiaddr"),M0=[tt("dns").code,tt("dns4").code,tt("dns6").code,tt("dnsaddr").code],Js=class r{bytes;#e;#t;#r;#n;[Ea]=!0;constructor(t){t==null&&(t="");let e;if(t instanceof Uint8Array)e=ba(t);else if(typeof t=="string"){if(t.length>0&&t.charAt(0)!=="/")throw new Error(`multiaddr "${t}" must start with a "/"`);e=tf(t)}else if(sf(t))e=ba(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=tt("tcp"),a=tt("udp"),c=tt("ip4"),l=tt("ip6"),u=tt("dns6"),f=tt("ip6zone");for(let[m,p]of this.stringTuples())m===f.code&&(o=`%${p??""}`),M0.includes(m)&&(e=i.name,s=443,n=`${p??""}${o}`,t=m===u.code?6:4),(m===i.code||m===a.code)&&(e=tt(m).name,s=parseInt(p??"")),(m===c.code||m===l.code)&&(e=tt(m).name,n=`${p??""}${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({},tt(t)))}protoCodes(){return this.#t.map(([t])=>t)}protoNames(){return this.#t.map(([t])=>tt(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(xa(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"?$(ut.decode(`z${n}`),"base58btc"):$(Kt.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=nf.get(e.name);if(n==null)throw new M(`no available resolver for ${e.name}`,"ERR_NO_AVAILABLE_RESOLVER");return(await n(this,t)).map(o=>va(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)}[O0](){return`Multiaddr(${this.#e})`}};var nf=new Map;function sf(r){return!!r?.[Ea]}function va(r){return new Js(r)}var K0=r=>r.toString().split("/").slice(1),vn=r=>({match:t=>t.length<1?!1:r(t[0])?t.slice(1):!1,pattern:"fn"}),J=r=>({match:t=>vn(e=>e===r).match(t),pattern:r}),eo=()=>({match:r=>vn(t=>typeof t=="string").match(r),pattern:"{string}"}),ro=()=>({match:r=>vn(t=>!isNaN(parseInt(t))).match(r),pattern:"{number}"}),_t=()=>({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}"}),Qs=()=>({match:r=>{if(r.length<2||r[0]!=="certhash")return!1;try{_o.decode(r[1])}catch{return!1}return r.slice(2)},pattern:"/certhash/{certhash}"}),xt=r=>({match:t=>{let e=r.match(t);return e===!1?t:e},pattern:`optional(${r.pattern})`}),jt=(...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=K0(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 Aa=rt(J("dns4"),eo()),Sa=rt(J("dns6"),eo()),ka=rt(J("dnsaddr"),eo()),of=rt(J("dns"),eo()),wE=ht(Aa),bE=ht(Sa),xE=ht(ka),EE=ht(jt(of,ka,Aa,Sa)),af=rt(J("ip4"),vn(Ys)),cf=rt(J("ip6"),vn(Zs)),lf=jt(af,cf),fe=jt(lf,of,Aa,Sa,ka),vE=ht(fe),BE=ht(af),AE=ht(cf),SE=ht(lf),Ia=rt(fe,J("tcp"),ro()),Bn=rt(fe,J("udp"),ro()),kE=ht(Ia),IE=ht(Bn),_a=rt(Bn,J("quic")),no=rt(Bn,J("quic-v1")),F0=jt(_a,no),_E=ht(_a),NE=ht(no),Ba=jt(fe,Ia,Bn,_a,no),uf=jt(rt(Ba,J("ws"),xt(_t()))),TE=ht(uf),ff=jt(rt(Ba,J("wss"),xt(_t())),rt(Ba,J("tls"),J("ws"),xt(_t()))),RE=ht(ff),hf=rt(Bn,J("webrtc-direct"),xt(Qs()),xt(Qs()),xt(_t())),LE=ht(hf),df=rt(no,J("webtransport"),xt(Qs()),xt(Qs()),xt(_t())),so=ht(df),to=jt(uf,ff,rt(Ia,xt(_t())),rt(F0,xt(_t())),rt(fe,xt(_t())),hf,df,_t()),CE=ht(to),$0=rt(to,J("p2p-circuit"),_t()),UE=ht($0),q0=jt(rt(to,J("p2p-circuit"),J("webrtc"),xt(_t())),rt(to,J("webrtc"),xt(_t())),J("webrtc")),PE=ht(q0),G0=jt(rt(fe,J("tcp"),ro(),J("http"),xt(_t())),rt(fe,J("http"),xt(_t()))),DE=ht(G0),j0=jt(rt(fe,J("tcp"),jt(rt(J("443"),J("http")),rt(ro(),J("https"))),xt(_t())),rt(fe,J("tls"),J("http"),xt(_t())),rt(fe,J("https"),xt(_t()))),VE=ht(j0);var lr=class extends Event{type;detail;constructor(t,e){super(t),this.type=t,this.detail=e}};function Na(r){throw new Error("Not implemented")}function pf(r){if(r!=null){if(typeof r[Symbol.iterator]=="function")return r[Symbol.iterator]();if(typeof r[Symbol.asyncIterator]=="function")return r[Symbol.asyncIterator]();if(typeof r.next=="function")return r}throw new Error("argument is not an iterator or iterable")}function gf(r){return r==null?!1:typeof r.then=="function"&&typeof r.catch=="function"&&typeof r.finally=="function"}function mf(r,t){let e=pf(r).return?.();gf(e)&&e.catch(n=>{t.error("could not cause iterator to return",n)})}var z0="ERR_STREAM_RESET",W0="ERR_SINK_INVALID_STATE",Y0=5e3;function Ta(r){return r==null?!1:typeof r.then=="function"&&typeof r.catch=="function"&&typeof r.finally=="function"}var oo=class{id;direction;timeline;protocol;metadata;source;status;readStatus;writeStatus;log;sinkController;sinkEnd;closed;endErr;streamSource;onEnd;onCloseRead;onCloseWrite;onReset;onAbort;sendCloseWriteTimeout;sendingData;constructor(t){this.sinkController=new AbortController,this.sinkEnd=Ct(),this.closed=Ct(),this.log=t.log,this.status="open",this.readStatus="ready",this.writeStatus="ready",this.id=t.id,this.metadata=t.metadata??{},this.direction=t.direction,this.timeline={open:Date.now()},this.sendCloseWriteTimeout=t.sendCloseWriteTimeout??Y0,this.onEnd=t.onEnd,this.onCloseRead=t?.onCloseRead,this.onCloseWrite=t?.onCloseWrite,this.onReset=t?.onReset,this.onAbort=t?.onAbort,this.source=this.streamSource=Pr({onEnd:e=>{e!=null?this.log.trace("source ended with error",e):this.log.trace("source ended"),this.onSourceEnd(e)}}),this.sink=this.sink.bind(this)}async sink(t){if(this.writeStatus!=="ready")throw new M(`writable end state is "${this.writeStatus}" not "ready"`,W0);try{this.writeStatus="writing";let e={signal:this.sinkController.signal};if(this.direction==="outbound"){let s=this.sendNewStream(e);Ta(s)&&await s}let n=()=>{mf(t,this.log)};try{this.sinkController.signal.addEventListener("abort",n),this.log.trace("sink reading from source");for await(let s of t){s=s instanceof Uint8Array?new ct(s):s;let o=this.sendData(s,e);Ta(o)&&(this.sendingData=Ct(),await o,this.sendingData.resolve(),this.sendingData=void 0)}}finally{this.sinkController.signal.removeEventListener("abort",n)}this.log.trace('sink finished reading from source, write status is "%s"',this.writeStatus),this.writeStatus==="writing"&&(this.writeStatus="closing",this.log.trace("send close write to remote"),await this.sendCloseWrite({signal:AbortSignal.timeout(this.sendCloseWriteTimeout)}),this.writeStatus="closed"),this.onSinkEnd()}catch(e){throw this.log.trace("sink ended with error, calling abort with error",e),this.abort(e),e}finally{this.log.trace("resolve sink end"),this.sinkEnd.resolve()}}onSourceEnd(t){this.timeline.closeRead==null&&(this.timeline.closeRead=Date.now(),this.readStatus="closed",t!=null&&this.endErr==null&&(this.endErr=t),this.onCloseRead?.(),this.timeline.closeWrite!=null?(this.log.trace("source and sink ended"),this.timeline.close=Date.now(),this.status!=="aborted"&&this.status!=="reset"&&(this.status="closed"),this.onEnd!=null&&this.onEnd(this.endErr),this.closed.resolve()):this.log.trace("source ended, waiting for sink to end"))}onSinkEnd(t){this.timeline.closeWrite==null&&(this.timeline.closeWrite=Date.now(),this.writeStatus="closed",t!=null&&this.endErr==null&&(this.endErr=t),this.onCloseWrite?.(),this.timeline.closeRead!=null?(this.log.trace("sink and source ended"),this.timeline.close=Date.now(),this.status!=="aborted"&&this.status!=="reset"&&(this.status="closed"),this.onEnd!=null&&this.onEnd(this.endErr),this.closed.resolve()):this.log.trace("sink ended, waiting for source to end"))}async close(t){this.log.trace("closing gracefully"),this.status="closing",await Dt(Promise.all([this.closeWrite(t),this.closeRead(t),this.closed.promise]),t?.signal),this.status="closed",this.log.trace("closed gracefully")}async closeRead(t={}){if(this.readStatus==="closing"||this.readStatus==="closed")return;this.log.trace('closing readable end of stream with starting read status "%s"',this.readStatus);let e=this.readStatus;this.readStatus="closing",this.status!=="reset"&&this.status!=="aborted"&&this.timeline.closeRead==null&&(this.log.trace("send close read to remote"),await this.sendCloseRead(t)),e==="ready"&&(this.log.trace("ending internal source queue with %d queued bytes",this.streamSource.readableLength),this.streamSource.end()),this.log.trace("closed readable end of stream")}async closeWrite(t={}){this.writeStatus==="closing"||this.writeStatus==="closed"||(this.log.trace('closing writable end of stream with starting write status "%s"',this.writeStatus),this.writeStatus==="ready"&&(this.log.trace("sink was never sunk, sink an empty array"),await Dt(this.sink([]),t.signal)),this.writeStatus==="writing"&&(this.sendingData!=null&&await Dt(this.sendingData.promise,t.signal),this.log.trace("aborting source passed to .sink"),this.sinkController.abort(),await Dt(this.sinkEnd.promise,t.signal)),this.writeStatus="closed",this.log.trace("closed writable end of stream"))}abort(t){if(this.status==="closed"||this.status==="aborted"||this.status==="reset")return;this.log("abort with error",t),this.log("try to send reset to remote");let e=this.sendReset();Ta(e)&&e.catch(n=>{this.log.error("error sending reset message",n)}),this.status="aborted",this.timeline.abort=Date.now(),this._closeSinkAndSource(t),this.onAbort?.(t)}reset(){if(this.status==="closed"||this.status==="aborted"||this.status==="reset")return;let t=new M("stream reset",z0);this.status="reset",this.timeline.reset=Date.now(),this._closeSinkAndSource(t),this.onReset?.()}_closeSinkAndSource(t){this._closeSink(t),this._closeSource(t)}_closeSink(t){this.writeStatus==="writing"&&(this.log.trace("end sink source"),this.sinkController.abort()),this.onSinkEnd(t)}_closeSource(t){this.readStatus!=="closing"&&this.readStatus!=="closed"&&(this.log.trace("ending source with %d bytes to be read by consumer",this.streamSource.readableLength),this.readStatus="closing",this.streamSource.end(t))}remoteCloseWrite(){if(this.readStatus==="closing"||this.readStatus==="closed"){this.log("received remote close write but local source is already closed");return}this.log.trace("remote close write"),this._closeSource()}remoteCloseRead(){if(this.writeStatus==="closing"||this.writeStatus==="closed"){this.log("received remote close read but local sink is already closed");return}this.log.trace("remote close read"),this._closeSink()}destroy(){if(this.status==="closed"||this.status==="aborted"||this.status==="reset"){this.log("received destroy but we are already closed");return}this.log.trace("stream destroyed"),this._closeSinkAndSource()}sourcePush(t){this.streamSource.push(t)}sourceReadableLength(){return this.streamSource.readableLength}};var Ra=class extends oo{writer;reader;constructor(t){super(t),this.writer=t.bidiStream.writable.getWriter(),this.reader=t.bidiStream.readable.getReader(),Promise.resolve().then(async()=>{for(;;){let e=await this.reader.read();if(e.done){t.log("remote closed write");return}e.value!=null&&this.sourcePush(new ct(e.value))}}).catch(e=>{t.log.error("error reading from stream",e),this.abort(e)}).finally(()=>{this.remoteCloseWrite()}),this.writer.closed.then(()=>{t.log("writer closed")}).catch(e=>{t.log("writer close promise rejected",e)}).finally(()=>{this.remoteCloseRead()})}sendNewStream(t){}async sendData(t,e){for await(let n of t)this.log("sendData waiting for writer to be ready"),await Dt(this.writer.ready,e?.signal),this.writer.write(n).catch(s=>{this.log.error("error sending stream data",s)})}async sendReset(t){this.log("sendReset aborting writer"),await Dt(this.writer.abort(),t?.signal),this.log("sendReset aborted writer")}async sendCloseWrite(t){this.log("sendCloseWrite closing writer"),await Dt(this.writer.close(),t?.signal),this.log("sendCloseWrite closed writer")}async sendCloseRead(t){this.log("sendCloseRead cancelling reader"),await Dt(this.reader.cancel(),t?.signal),this.log("sendCloseRead cancelled reader")}};async function La(r,t,e,n,s,o){let i=o.forComponent(`libp2p:webtransport:stream:${e}:${t}`),a=new Ra({bidiStream:r,id:t,direction:e,log:i,onEnd:()=>{let c=n.findIndex(l=>l===a);c!==-1&&n.splice(c,1),s?.(a)}});return a}function io(){return{source:{[Symbol.asyncIterator](){return{async next(){return new Promise(()=>{})}}}},sink:async r=>new Promise(()=>{})}}function yf(r,t,e,n){let s=0,o=e.forComponent("libp2p:webtransport:muxer");return{protocol:"webtransport",createStreamMuxer:i=>{typeof i=="function"&&(i={onIncomingStream:i});let a=[];Promise.resolve().then(async()=>{for(;;){let{done:l,value:u}=await t.read();if(l)break;if(a.length>=n.maxInboundStreams)o(`too many inbound streams open - ${a.length}/${n.maxInboundStreams}, closing new incoming stream`),u.writable.close().catch(f=>{o.error(`failed to close inbound stream that crossed our maxInboundStream limit: ${f.message}`)}),u.readable.cancel().catch(f=>{o.error(`failed to close inbound stream that crossed our maxInboundStream limit: ${f.message}`)});else{let f=await La(u,String(s++),"inbound",a,i?.onStreamEnd,e);a.push(f),i?.onIncomingStream?.(f)}}}).catch(l=>{o.error("could not create a new stream",l)});let c={protocol:"webtransport",streams:a,newStream:async l=>{o("new outgoing stream",l);let u=await r.createBidirectionalStream(),f=await La(u,String(s++),i?.direction??"outbound",a,i?.onStreamEnd,e);return a.push(f),f},close:async()=>{o("closing webtransport muxer gracefully");try{r.close()}catch(l){c.abort(l)}},abort:l=>{o("closing webtransport muxer with err:",l);try{r.close()}catch(u){o.error("webtransport session threw error during close",u)}},...io()};return c}}}function wf(r,t){return t.filter(n=>!!r.find(s=>ft(n,s))).length===t.length}var Z0=Object.values(se).map(r=>r.decoder).reduce((r,t)=>r.or(t));function X0(r){return ne.decode(Z0.decode(r))}function Ca(r){if(!so.matches(r))throw new M("Invalid multiaddr, was not a WebTransport address","ERR_INVALID_MULTIADDR");let t=r.stringTuples(),e=t.filter(([i,a])=>i===tt("certhash").code).map(([i,a])=>X0(a??"")),n=t.filter(([i,a])=>i===tt("p2p").code).map(([i,a])=>Ui(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 bf=globalThis.WebTransport;var Ua=class{log;components;config;metrics;constructor(t,e={}){this.log=t.logger.forComponent("libp2p:webtransport"),this.components=t,this.config={...e,maxInboundStreams:e.maxInboundStreams??1e3,certificates:e.certificates??[]},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";[za]=!0;[kn]=["@libp2p/transport"];async dial(t,e){if(e?.signal?.aborted===!0)throw new Sn;this.log("dialing %s",t);let n=this.components.peerId;if(n===void 0)throw new M("Need a local peerid","ERR_INVALID_PARAMETERS");e=e??{};let{url:s,certhashes:o,remotePeer:i}=Ca(t),a,c,l=()=>{},u=!1,f=!1,g=!1;try{this.metrics?.dialerEvents.increment({pending:!0});let m=new bf(`${s}/.well-known/libp2p-webtransport?type=noise`,{serverCertificateHashes:o.map(p=>({algorithm:"sha-256",value:p.digest}))});if(l=p=>{if(!u)try{this.metrics?.dialerEvents.increment({[p]:!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}),this.log("wait for session to be ready"),e.onProgress?.(new lr("webtransport:wait-for-session")),await Promise.race([m.closed,m.ready]),this.log("session became ready"),f=!0,this.metrics?.dialerEvents.increment({ready:!0}),m.closed.catch(p=>{this.log.error("error on remote wt session close",p)}).finally(()=>{l("remote_close")}),g=await Dt(this.authenticateWebTransport({wt:m,localPeer:n,remotePeer:i,certhashes:o,...e}),e.signal),!g)throw new M("Failed to authenticate webtransport","ERR_AUTHENTICATION_FAILED");return this.metrics?.dialerEvents.increment({open:!0}),c={close:async()=>{this.log("closing webtransport"),l("close")},abort:p=>{this.log("aborting webtransport due to passed err",p),l("abort")},remoteAddr:t,timeline:{open:Date.now()},log:this.components.logger.forComponent("libp2p:webtransport:maconn"),...io()},await e.upgrader.upgradeOutbound(c,{skipEncryption:!0,muxerFactory:yf(m,m.incomingBidirectionalStreams.getReader(),this.components.logger,this.config),skipProtection:!0,onProgress:e.onProgress})}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({wt:t,localPeer:e,remotePeer:n,certhashes:s,onProgress:o,signal:i}){i?.throwIfAborted(),o?.(new lr("webtransport:open-authentication-stream"));let a=await t.createBidirectionalStream(),c=a.writable.getWriter(),l=a.readable.getReader(),u={source:async function*(){for(;;){let m=await l.read();if(m.value!=null&&(yield m.value),m.done)break}}(),sink:async m=>{for await(let p of m){await Dt(c.ready,i);let h=p instanceof Uint8Array?p:p.subarray();c.write(h).catch(d=>{this.log.error("could not write chunk during authentication of WebTransport stream",d)})}}},f=Gu()(this.components);o?.(new lr("webtransport:secure-outbound-connection"));let{remoteExtensions:g}=await f.secureOutbound(e,u,n);if(o?.(new lr("webtransport:close-authentication-stream")),c.close().catch(m=>{this.log.error(`Failed to close authentication stream writer: ${m.message}`)}),l.cancel().catch(m=>{this.log.error(`Failed to close authentication stream reader: ${m.message}`)}),!wf(g?.webtransportCerthashes??[],s.map(m=>m.bytes)))throw new Error("Our certhashes are not a subset of the remote's reported certhashes");return!0}createListener(t){return Na(this.components,{...t,certificates:this.config.certificates,maxInboundStreams:this.config.maxInboundStreams})}listenFilter(){return[]}dialFilter(t){return globalThis.WebTransport==null?[]:t.filter(e=>{if(!so.exactMatch(e))return!1;let{url:n,certhashes:s}=Ca(e);return n!=null&&s.length>0})}};function J0(r={}){return t=>new Ua(t,r)}return Cf(Q0);})();
|
|
8
8
|
//! TODO unclear how to add backpressure here?
|
|
9
9
|
/*! Bundled license information:
|
|
10
10
|
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@libp2p/webtransport",
|
|
3
|
-
"version": "4.1.
|
|
3
|
+
"version": "4.1.3-944935f8d",
|
|
4
4
|
"description": "JavaScript implementation of the WebTransport module that libp2p uses and that implements the interface-transport spec",
|
|
5
5
|
"license": "Apache-2.0 OR MIT",
|
|
6
6
|
"homepage": "https://github.com/libp2p/js-libp2p/tree/main/packages/transport-webtransport#readme",
|
|
@@ -51,9 +51,9 @@
|
|
|
51
51
|
},
|
|
52
52
|
"dependencies": {
|
|
53
53
|
"@chainsafe/libp2p-noise": "^15.0.0",
|
|
54
|
-
"@libp2p/interface": "1.6.
|
|
55
|
-
"@libp2p/peer-id": "4.2.
|
|
56
|
-
"@libp2p/utils": "5.4.
|
|
54
|
+
"@libp2p/interface": "1.6.2-944935f8d",
|
|
55
|
+
"@libp2p/peer-id": "4.2.2-944935f8d",
|
|
56
|
+
"@libp2p/utils": "5.4.7-944935f8d",
|
|
57
57
|
"@multiformats/multiaddr": "^12.2.3",
|
|
58
58
|
"@multiformats/multiaddr-matcher": "^1.2.1",
|
|
59
59
|
"it-stream-types": "^2.0.1",
|
|
@@ -65,16 +65,16 @@
|
|
|
65
65
|
},
|
|
66
66
|
"devDependencies": {
|
|
67
67
|
"@libp2p/daemon-client": "^8.0.5",
|
|
68
|
-
"@libp2p/logger": "4.0.
|
|
69
|
-
"@libp2p/peer-id-factory": "4.2.
|
|
70
|
-
"@libp2p/ping": "1.1.
|
|
68
|
+
"@libp2p/logger": "4.0.18-944935f8d",
|
|
69
|
+
"@libp2p/peer-id-factory": "4.2.2-944935f8d",
|
|
70
|
+
"@libp2p/ping": "1.1.3-944935f8d",
|
|
71
71
|
"@noble/hashes": "^1.4.0",
|
|
72
|
-
"aegir": "^
|
|
72
|
+
"aegir": "^44.0.1",
|
|
73
73
|
"execa": "^9.1.0",
|
|
74
74
|
"go-libp2p": "^1.2.0",
|
|
75
75
|
"it-map": "^3.1.0",
|
|
76
76
|
"it-to-buffer": "^4.0.7",
|
|
77
|
-
"libp2p": "1.8.
|
|
77
|
+
"libp2p": "1.8.2-944935f8d",
|
|
78
78
|
"p-defer": "^4.0.1",
|
|
79
79
|
"p-wait-for": "^5.0.2"
|
|
80
80
|
},
|