@libp2p/webtransport 4.1.8-1675adee2 → 4.1.8-737b3ea5b

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
package/dist/index.min.js CHANGED
@@ -1,10 +1,10 @@
1
1
  (function (root, factory) {(typeof module === 'object' && module.exports) ? module.exports = factory() : root.Libp2PWebtransport = factory()}(typeof self !== 'undefined' ? self : this, function () {
2
- "use strict";var Libp2PWebtransport=(()=>{var Vf=Object.create;var _n=Object.defineProperty;var Hf=Object.getOwnPropertyDescriptor;var Of=Object.getOwnPropertyNames;var Mf=Object.getPrototypeOf,Kf=Object.prototype.hasOwnProperty;var Ff=(r,t)=>()=>(t||r((t={exports:{}}).exports,t),t.exports),gt=(r,t)=>{for(var e in t)_n(r,e,{get:t[e],enumerable:!0})},rc=(r,t,e,n)=>{if(t&&typeof t=="object"||typeof t=="function")for(let s of Of(t))!Kf.call(r,s)&&s!==e&&_n(r,s,{get:()=>t[s],enumerable:!(n=Hf(t,s))||n.enumerable});return r};var $f=(r,t,e)=>(e=r!=null?Vf(Mf(r)):{},rc(t||!r||!r.__esModule?_n(e,"default",{value:r,enumerable:!0}):e,r)),qf=r=>rc(_n({},"__esModule",{value:!0}),r);var cl=Ff(Ir=>{"use strict";var Ep="[object ArrayBuffer]",ve=class r{static isArrayBuffer(t){return Object.prototype.toString.call(t)===Ep}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}},_i="string",vp=/^[0-9a-f]+$/i,Bp=/^(?:[A-Za-z0-9+/]{4})*(?:[A-Za-z0-9+/]{2}==|[A-Za-z0-9+/]{3}=)?$/,Ap=/^[a-zA-Z0-9-_]+$/,Yn=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))}},$t=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}},Zn=class r{static isHex(t){return typeof t===_i&&vp.test(t)}static isBase64(t){return typeof t===_i&&Bp.test(t)}static isBase64Url(t){return typeof t===_i&&Ap.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 $t.toString(n,!0);case"utf16":case"utf16be":return $t.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 $t.fromString(t,!0);case"utf16":case"utf16be":return $t.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 Yn.fromString(t);case"utf16":case"utf16be":return $t.fromString(t);case"utf16le":case"usc2":return $t.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 Yn.toString(t);case"utf16":case"utf16be":return $t.toString(t);case"utf16le":case"usc2":return $t.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 $t.toString(t,e)}static FromUtf16String(t,e=!1){return $t.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,"")||""}};Zn.DEFAULT_UTF8_ENCODING="utf8";function Sp(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 kp(...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 Ip(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}Ir.BufferSourceConverter=ve;Ir.Convert=Zn;Ir.assign=Sp;Ir.combine=kp;Ir.isEqual=Ip});var ug={};gt(ug,{webTransport:()=>lg});var Rn=Symbol.for("@libp2p/peer-id");function nc(r){return r!=null&&!!r[Rn]}var oc=Symbol.for("@libp2p/transport");var sc;(function(r){r[r.FATAL_ALL=0]="FATAL_ALL",r[r.NO_FATAL=1]="NO_FATAL"})(sc||(sc={}));var Nn=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 Tn=Symbol.for("@libp2p/service-capabilities"),gg=Symbol.for("@libp2p/service-dependencies");var ki={};gt(ki,{Ed25519PrivateKey:()=>sr,Ed25519PublicKey:()=>nn,generateKeyPair:()=>wp,generateKeyPairFromSeed:()=>al,unmarshalEd25519PrivateKey:()=>mp,unmarshalEd25519PublicKey:()=>yp});var Ao={};gt(Ao,{base58btc:()=>ut,base58flickr:()=>Zf});var Og=new Uint8Array(0);function ic(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 ac(r){return new TextEncoder().encode(r)}function cc(r){return new TextDecoder().decode(r)}function Gf(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),f=Math.log(256)/Math.log(a);function u(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,E=0,w=p.length;E!==w&&p[E]===0;)E++,h++;for(var x=(w-E)*f+1>>>0,I=new Uint8Array(x);E!==w;){for(var N=p[E],S=0,R=x-1;(N!==0||S<d)&&R!==-1;R--,S++)N+=256*I[R]>>>0,I[R]=N%a>>>0,N=N/a>>>0;if(N!==0)throw new Error("Non-zero carry");d=S,E++}for(var _=x-d;_!==x&&I[_]===0;)_++;for(var V=c.repeat(h);_<x;++_)V+=r.charAt(I[_]);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,E=0;p[h]===c;)d++,h++;for(var w=(p.length-h)*l+1>>>0,x=new Uint8Array(w);p[h];){var I=e[p.charCodeAt(h)];if(I===255)return;for(var N=0,S=w-1;(I!==0||N<E)&&S!==-1;S--,N++)I+=a*x[S]>>>0,x[S]=I%256>>>0,I=I/256>>>0;if(I!==0)throw new Error("Non-zero carry");E=N,h++}if(p[h]!==" "){for(var R=w-E;R!==w&&x[R]===0;)R++;for(var _=new Uint8Array(d+(w-R)),V=d;R!==w;)_[V++]=x[R++];return _}}}function m(p){var h=g(p);if(h)return h;throw new Error(`Non-${t} character`)}return{encode:u,decodeUnsafe:g,decode:m}}var zf=Gf,jf=zf,uc=jf;var xo=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")}},Eo=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 fc(this,t)}},vo=class{decoders;constructor(t){this.decoders=t}or(t){return fc(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 fc(r,t){return new vo({...r.decoders??{[r.prefix]:r},...t.decoders??{[t.prefix]:t}})}var Bo=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 xo(t,e,n),this.decoder=new Eo(t,e,s)}encode(t){return this.encoder.encode(t)}decode(t){return this.decoder.decode(t)}};function hr({name:r,prefix:t,encode:e,decode:n}){return new Bo(r,t,e,n)}function Ne({name:r,prefix:t,alphabet:e}){let{encode:n,decode:s}=uc(e,r);return hr({prefix:t,name:r,encode:n,decode:o=>de(s(o))})}function Wf(r,t,e,n){let s={};for(let f=0;f<t.length;++f)s[t[f]]=f;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 f=0;f<o;++f){let u=s[r[f]];if(u===void 0)throw new SyntaxError(`Non-${n} character`);c=c<<e|u,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 Yf(r,t,e){let n=t[t.length-1]==="=",s=(1<<e)-1,o="",i=0,a=0;for(let c=0;c<r.length;++c)for(a=a<<8|r[c],i+=8;i>e;)i-=e,o+=t[s&a>>i];if(i!==0&&(o+=t[s&a<<e-i]),n)for(;o.length*e&7;)o+="=";return o}function ct({name:r,prefix:t,bitsPerChar:e,alphabet:n}){return hr({prefix:t,name:r,encode(s){return Yf(s,n,e)},decode(s){return Wf(s,n,e,r)}})}var ut=Ne({name:"base58btc",prefix:"z",alphabet:"123456789ABCDEFGHJKLMNPQRSTUVWXYZabcdefghijkmnopqrstuvwxyz"}),Zf=Ne({name:"base58flickr",prefix:"Z",alphabet:"123456789abcdefghijkmnopqrstuvwxyzABCDEFGHJKLMNPQRSTUVWXYZ"});var Io={};gt(Io,{identity:()=>pe});var se={};gt(se,{Digest:()=>je,create:()=>jt,decode:()=>Te,equals:()=>ko});var Xf=pc,hc=128,Jf=127,Qf=~Jf,th=Math.pow(2,31);function pc(r,t,e){t=t||[],e=e||0;for(var n=e;r>=th;)t[e++]=r&255|hc,r/=128;for(;r&Qf;)t[e++]=r&255|hc,r>>>=7;return t[e]=r|0,pc.bytes=e-n+1,t}var eh=So,rh=128,dc=127;function So(r,n){var e=0,n=n||0,s=0,o=n,i,a=r.length;do{if(o>=a)throw So.bytes=0,new RangeError("Could not decode varint");i=r[o++],e+=s<28?(i&dc)<<s:(i&dc)*Math.pow(2,s),s+=7}while(i>=rh);return So.bytes=o-n,e}var nh=Math.pow(2,7),sh=Math.pow(2,14),oh=Math.pow(2,21),ih=Math.pow(2,28),ah=Math.pow(2,35),ch=Math.pow(2,42),lh=Math.pow(2,49),uh=Math.pow(2,56),fh=Math.pow(2,63),hh=function(r){return r<nh?1:r<sh?2:r<oh?3:r<ih?4:r<ah?5:r<ch?6:r<lh?7:r<uh?8:r<fh?9:10},dh={encode:Xf,decode:eh,encodingLength:hh},ph=dh,Gr=ph;function zr(r,t=0){return[Gr.decode(r,t),Gr.decode.bytes]}function dr(r,t,e=0){return Gr.encode(r,t,e),t}function pr(r){return Gr.encodingLength(r)}function jt(r,t){let e=t.byteLength,n=pr(r),s=n+pr(e),o=new Uint8Array(s+e);return dr(r,o,0),dr(e,o,n),o.set(t,s),new je(r,e,t,o)}function Te(r){let t=de(r),[e,n]=zr(t),[s,o]=zr(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 ko(r,t){if(r===t)return!0;{let e=t;return r.code===e.code&&r.size===e.size&&e.bytes instanceof Uint8Array&&ic(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 gc=0,gh="identity",mc=de;function mh(r){return jt(gc,mc(r))}var pe={code:gc,name:gh,encode:mc,digest:mh};var No={};gt(No,{sha256:()=>At,sha512:()=>yh});function Ro({name:r,code:t,encode:e}){return new _o(r,t,e)}var _o=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?jt(this.code,e):e.then(n=>jt(this.code,n))}else throw Error("Unknown type, must be binary type")}};function wc(r){return async t=>new Uint8Array(await crypto.subtle.digest(r,t))}var At=Ro({name:"sha2-256",code:18,encode:wc("SHA-256")}),yh=Ro({name:"sha2-512",code:19,encode:wc("SHA-512")});function ft(r,t){if(r===t)return!0;if(r.byteLength!==t.byteLength)return!1;for(let e=0;e<r.byteLength;e++)if(r[e]!==t[e])return!1;return!0}function mt(r=0){return new Uint8Array(r)}function yt(r=0){return new Uint8Array(r)}function Et(r,t){t==null&&(t=r.reduce((s,o)=>s+o.length,0));let e=yt(t),n=0;for(let s of r)e.set(s,n),n+=s.length;return e}var To={};gt(To,{base10:()=>bh});var bh=Ne({prefix:"9",name:"base10",alphabet:"0123456789"});var Lo={};gt(Lo,{base16:()=>xh,base16upper:()=>Eh});var xh=ct({prefix:"f",name:"base16",alphabet:"0123456789abcdef",bitsPerChar:4}),Eh=ct({prefix:"F",name:"base16upper",alphabet:"0123456789ABCDEF",bitsPerChar:4});var Co={};gt(Co,{base2:()=>vh});var vh=ct({prefix:"0",name:"base2",alphabet:"01",bitsPerChar:1});var Uo={};gt(Uo,{base256emoji:()=>Ih});var bc=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}"),Bh=bc.reduce((r,t,e)=>(r[e]=t,r),[]),Ah=bc.reduce((r,t,e)=>(r[t.codePointAt(0)]=e,r),[]);function Sh(r){return r.reduce((t,e)=>(t+=Bh[e],t),"")}function kh(r){let t=[];for(let e of r){let n=Ah[e.codePointAt(0)];if(n===void 0)throw new Error(`Non-base256emoji character: ${e}`);t.push(n)}return new Uint8Array(t)}var Ih=hr({prefix:"\u{1F680}",name:"base256emoji",encode:Sh,decode:kh});var Po={};gt(Po,{base32:()=>ge,base32hex:()=>Th,base32hexpad:()=>Ch,base32hexpadupper:()=>Uh,base32hexupper:()=>Lh,base32pad:()=>Rh,base32padupper:()=>Nh,base32upper:()=>_h,base32z:()=>Ph});var ge=ct({prefix:"b",name:"base32",alphabet:"abcdefghijklmnopqrstuvwxyz234567",bitsPerChar:5}),_h=ct({prefix:"B",name:"base32upper",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZ234567",bitsPerChar:5}),Rh=ct({prefix:"c",name:"base32pad",alphabet:"abcdefghijklmnopqrstuvwxyz234567=",bitsPerChar:5}),Nh=ct({prefix:"C",name:"base32padupper",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZ234567=",bitsPerChar:5}),Th=ct({prefix:"v",name:"base32hex",alphabet:"0123456789abcdefghijklmnopqrstuv",bitsPerChar:5}),Lh=ct({prefix:"V",name:"base32hexupper",alphabet:"0123456789ABCDEFGHIJKLMNOPQRSTUV",bitsPerChar:5}),Ch=ct({prefix:"t",name:"base32hexpad",alphabet:"0123456789abcdefghijklmnopqrstuv=",bitsPerChar:5}),Uh=ct({prefix:"T",name:"base32hexpadupper",alphabet:"0123456789ABCDEFGHIJKLMNOPQRSTUV=",bitsPerChar:5}),Ph=ct({prefix:"h",name:"base32z",alphabet:"ybndrfg8ejkmcpqxot1uwisza345h769",bitsPerChar:5});var Do={};gt(Do,{base36:()=>Dh,base36upper:()=>Vh});var Dh=Ne({prefix:"k",name:"base36",alphabet:"0123456789abcdefghijklmnopqrstuvwxyz"}),Vh=Ne({prefix:"K",name:"base36upper",alphabet:"0123456789ABCDEFGHIJKLMNOPQRSTUVWXYZ"});var Oo={};gt(Oo,{base64:()=>Vo,base64pad:()=>Hh,base64url:()=>Ho,base64urlpad:()=>Oh});var Vo=ct({prefix:"m",name:"base64",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/",bitsPerChar:6}),Hh=ct({prefix:"M",name:"base64pad",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/=",bitsPerChar:6}),Ho=ct({prefix:"u",name:"base64url",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789-_",bitsPerChar:6}),Oh=ct({prefix:"U",name:"base64urlpad",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789-_=",bitsPerChar:6});var Mo={};gt(Mo,{base8:()=>Mh});var Mh=ct({prefix:"7",name:"base8",alphabet:"01234567",bitsPerChar:3});var Ko={};gt(Ko,{identity:()=>Kh});var Kh=hr({prefix:"\0",name:"identity",encode:r=>cc(r),decode:r=>ac(r)});var hm=new TextEncoder,dm=new TextDecoder;function xc(r,t){let{bytes:e,version:n}=r;switch(n){case 0:return Gh(e,Fo(r),t??ut.encoder);default:return zh(e,Fo(r),t??ge.encoder)}}var Ec=new WeakMap;function Fo(r){let t=Ec.get(r);if(t==null){let e=new Map;return Ec.set(r,e),e}return t}var Mt=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!==jr)throw new Error("Cannot convert a non dag-pb CID to CIDv0");if(e.code!==jh)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=jt(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&&ko(t.multihash,n.multihash)}toString(t){return xc(this,t)}toJSON(){return{"/":xc(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??vc(n,s,o.bytes))}else if(e[Wh]===!0){let{version:n,multihash:s,code:o}=e,i=Te(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!==jr)throw new Error(`Version 0 CID must use dag-pb (code: ${jr}) block encoding`);return new r(t,e,n,n.bytes)}case 1:{let s=vc(t,e,n.bytes);return new r(t,e,n,s)}default:throw new Error("Invalid version")}}static createV0(t){return r.create(0,jr,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[u,g]=zr(t.subarray(e));return e+=g,u},s=n(),o=jr;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,f=l-i;return{version:s,codec:o,multihashCode:a,digestSize:c,multihashSize:f,size:l}}static parse(t,e){let[n,s]=qh(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 Fo(o).set(n,t),o}};function qh(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 Gh(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 zh(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 jr=112,jh=18;function vc(r,t,e){let n=pr(r),s=n+pr(t),o=new Uint8Array(s+e.byteLength);return dr(r,o,0),dr(t,o,n),o.set(e,s),o}var Wh=Symbol.for("@ipld/js-cid/CID");var oe={...Ko,...Co,...Mo,...To,...Lo,...Po,...Do,...Ao,...Oo,...Uo},Rm={...No,...Io};function Ac(r,t,e,n){return{name:r,prefix:t,encoder:{name:r,prefix:t,encode:e},decoder:{decode:n}}}var Bc=Ac("utf8","u",r=>"u"+new TextDecoder("utf8").decode(r),r=>new TextEncoder().encode(r.substring(1))),$o=Ac("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=yt(r.length);for(let e=0;e<r.length;e++)t[e]=r.charCodeAt(e);return t}),Yh={utf8:Bc,"utf-8":Bc,hex:oe.base16,latin1:$o,ascii:$o,binary:$o,...oe},Cn=Yh;function W(r,t="utf8"){let e=Cn[t];if(e==null)throw new Error(`Unsupported encoding "${t}"`);return e.decoder.decode(`${e.prefix}${r}`)}function Kt(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 Zh(r){return r instanceof Uint8Array||r!=null&&typeof r=="object"&&r.constructor.name==="Uint8Array"}function gr(r,...t){if(!Zh(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 We(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 mr(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 Sc(r,t){gr(r);let e=t.outputLen;if(r.length<e)throw new Error(`digestInto() expects output buffer of length at least ${e}`)}var Un=typeof globalThis=="object"&&"crypto"in globalThis?globalThis.crypto:void 0;var wr=r=>new DataView(r.buffer,r.byteOffset,r.byteLength),Wt=(r,t)=>r<<32-t|r>>>t;var $m=new Uint8Array(new Uint32Array([287454020]).buffer)[0]===68;var Xh=async()=>{};async function kc(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 Xh(),n+=o)}}function Ic(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=Ic(r)),gr(r),r}function qo(...r){let t=0;for(let n=0;n<r.length;n++){let s=r[n];gr(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 yr=class{clone(){return this._cloneInto()}},Jh={}.toString;function _c(r,t){if(t!==void 0&&Jh.call(t)!=="[object Object]")throw new Error("Options should be object or undefined");return Object.assign(r,t)}function Pn(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 Ye(r=32){if(Un&&typeof Un.getRandomValues=="function")return Un.getRandomValues(new Uint8Array(r));throw new Error("crypto.getRandomValues must be defined")}function Qh(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 Rc=(r,t,e)=>r&t^~r&e,Nc=(r,t,e)=>r&t^r&e^t&e,br=class extends yr{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=wr(this.buffer)}update(t){mr(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=wr(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){mr(this),Sc(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 u=i;u<s;u++)e[u]=0;Qh(n,s-8,BigInt(this.length*8),o),this.process(n,0);let a=wr(t),c=this.outputLen;if(c%4)throw new Error("_sha2: outputLen should be aligned to 32bit");let l=c/4,f=this.get();if(l>f.length)throw new Error("_sha2: outputLen bigger than state");for(let u=0;u<l;u++)a.setUint32(4*u,f[u],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 Dn=BigInt(4294967295),Go=BigInt(32);function Tc(r,t=!1){return t?{h:Number(r&Dn),l:Number(r>>Go&Dn)}:{h:Number(r>>Go&Dn)|0,l:Number(r&Dn)|0}}function td(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}=Tc(r[s],t);[e[s],n[s]]=[o,i]}return[e,n]}var ed=(r,t)=>BigInt(r>>>0)<<Go|BigInt(t>>>0),rd=(r,t,e)=>r>>>e,nd=(r,t,e)=>r<<32-e|t>>>e,sd=(r,t,e)=>r>>>e|t<<32-e,od=(r,t,e)=>r<<32-e|t>>>e,id=(r,t,e)=>r<<64-e|t>>>e-32,ad=(r,t,e)=>r>>>e-32|t<<64-e,cd=(r,t)=>t,ld=(r,t)=>r,ud=(r,t,e)=>r<<e|t>>>32-e,fd=(r,t,e)=>t<<e|r>>>32-e,hd=(r,t,e)=>t<<e-32|r>>>64-e,dd=(r,t,e)=>r<<e-32|t>>>64-e;function pd(r,t,e,n){let s=(t>>>0)+(n>>>0);return{h:r+e+(s/2**32|0)|0,l:s|0}}var gd=(r,t,e)=>(r>>>0)+(t>>>0)+(e>>>0),md=(r,t,e,n)=>t+e+n+(r/2**32|0)|0,yd=(r,t,e,n)=>(r>>>0)+(t>>>0)+(e>>>0)+(n>>>0),wd=(r,t,e,n,s)=>t+e+n+s+(r/2**32|0)|0,bd=(r,t,e,n,s)=>(r>>>0)+(t>>>0)+(e>>>0)+(n>>>0)+(s>>>0),xd=(r,t,e,n,s,o)=>t+e+n+s+o+(r/2**32|0)|0;var Ed={fromBig:Tc,split:td,toBig:ed,shrSH:rd,shrSL:nd,rotrSH:sd,rotrSL:od,rotrBH:id,rotrBL:ad,rotr32H:cd,rotr32L:ld,rotlSH:ud,rotlSL:fd,rotlBH:hd,rotlBL:dd,add:pd,add3L:gd,add3H:md,add4L:yd,add4H:wd,add5H:xd,add5L:bd},G=Ed;var[vd,Bd]=G.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),zo=class extends br{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:f,Fh:u,Fl:g,Gh:m,Gl:p,Hh:h,Hl:d}=this;return[t,e,n,s,o,i,a,c,l,f,u,g,m,p,h,d]}set(t,e,n,s,o,i,a,c,l,f,u,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=f|0,this.Fh=u|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 x=0;x<16;x++,e+=4)Ce[x]=t.getUint32(e),Ue[x]=t.getUint32(e+=4);for(let x=16;x<80;x++){let I=Ce[x-15]|0,N=Ue[x-15]|0,S=G.rotrSH(I,N,1)^G.rotrSH(I,N,8)^G.shrSH(I,N,7),R=G.rotrSL(I,N,1)^G.rotrSL(I,N,8)^G.shrSL(I,N,7),_=Ce[x-2]|0,V=Ue[x-2]|0,U=G.rotrSH(_,V,19)^G.rotrBH(_,V,61)^G.shrSH(_,V,6),T=G.rotrSL(_,V,19)^G.rotrBL(_,V,61)^G.shrSL(_,V,6),F=G.add4L(R,T,Ue[x-7],Ue[x-16]),K=G.add4H(F,S,U,Ce[x-7],Ce[x-16]);Ce[x]=K|0,Ue[x]=F|0}let{Ah:n,Al:s,Bh:o,Bl:i,Ch:a,Cl:c,Dh:l,Dl:f,Eh:u,El:g,Fh:m,Fl:p,Gh:h,Gl:d,Hh:E,Hl:w}=this;for(let x=0;x<80;x++){let I=G.rotrSH(u,g,14)^G.rotrSH(u,g,18)^G.rotrBH(u,g,41),N=G.rotrSL(u,g,14)^G.rotrSL(u,g,18)^G.rotrBL(u,g,41),S=u&m^~u&h,R=g&p^~g&d,_=G.add5L(w,N,R,Bd[x],Ue[x]),V=G.add5H(_,E,I,S,vd[x],Ce[x]),U=_|0,T=G.rotrSH(n,s,28)^G.rotrBH(n,s,34)^G.rotrBH(n,s,39),F=G.rotrSL(n,s,28)^G.rotrBL(n,s,34)^G.rotrBL(n,s,39),K=n&o^n&a^o&a,k=s&i^s&c^i&c;E=h|0,w=d|0,h=m|0,d=p|0,m=u|0,p=g|0,{h:u,l:g}=G.add(l|0,f|0,V|0,U|0),l=a|0,f=c|0,a=o|0,c=i|0,o=n|0,i=s|0;let b=G.add3L(U,F,k);n=G.add3H(b,V,T,K),s=b|0}({h:n,l:s}=G.add(this.Ah|0,this.Al|0,n|0,s|0)),{h:o,l:i}=G.add(this.Bh|0,this.Bl|0,o|0,i|0),{h:a,l:c}=G.add(this.Ch|0,this.Cl|0,a|0,c|0),{h:l,l:f}=G.add(this.Dh|0,this.Dl|0,l|0,f|0),{h:u,l:g}=G.add(this.Eh|0,this.El|0,u|0,g|0),{h:m,l:p}=G.add(this.Fh|0,this.Fl|0,m|0,p|0),{h,l:d}=G.add(this.Gh|0,this.Gl|0,h|0,d|0),{h:E,l:w}=G.add(this.Hh|0,this.Hl|0,E|0,w|0),this.set(n,s,o,i,a,c,l,f,u,g,m,p,h,d,E,w)}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 Wr=Pn(()=>new zo);var Hn={};gt(Hn,{aInRange:()=>St,abool:()=>Zt,abytes:()=>xr,bitGet:()=>Nd,bitLen:()=>Rd,bitMask:()=>Zr,bitSet:()=>Td,bytesToHex:()=>ye,bytesToNumberBE:()=>we,bytesToNumberLE:()=>Xt,concatBytes:()=>xe,createHmacDrbg:()=>Xo,ensureBytes:()=>nt,equalBytes:()=>Id,hexToBytes:()=>Ze,hexToNumber:()=>Zo,inRange:()=>Yr,isBytes:()=>Pe,memoized:()=>Xe,notImplemented:()=>Cd,numberToBytesBE:()=>De,numberToBytesLE:()=>be,numberToHexUnpadded:()=>Uc,numberToVarBytesBE:()=>kd,utf8ToBytes:()=>_d,validateObject:()=>Ft});var Yo=BigInt(0),Vn=BigInt(1),Ad=BigInt(2);function Pe(r){return r instanceof Uint8Array||r!=null&&typeof r=="object"&&r.constructor.name==="Uint8Array"}function xr(r){if(!Pe(r))throw new Error("Uint8Array expected")}function Zt(r,t){if(typeof t!="boolean")throw new Error(`${r} must be valid boolean, got "${t}".`)}var Sd=Array.from({length:256},(r,t)=>t.toString(16).padStart(2,"0"));function ye(r){xr(r);let t="";for(let e=0;e<r.length;e++)t+=Sd[r[e]];return t}function Uc(r){let t=r.toString(16);return t.length&1?`0${t}`:t}function Zo(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 Lc(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 Ze(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=Lc(r.charCodeAt(o)),a=Lc(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 Zo(ye(r))}function Xt(r){return xr(r),Zo(ye(Uint8Array.from(r).reverse()))}function De(r,t){return Ze(r.toString(16).padStart(t*2,"0"))}function be(r,t){return De(r,t).reverse()}function kd(r){return Ze(Uc(r))}function nt(r,t,e){let n;if(typeof t=="string")try{n=Ze(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];xr(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 Id(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 _d(r){if(typeof r!="string")throw new Error(`utf8ToBytes expected string, got ${typeof r}`);return new Uint8Array(new TextEncoder().encode(r))}var jo=r=>typeof r=="bigint"&&Yo<=r;function Yr(r,t,e){return jo(r)&&jo(t)&&jo(e)&&t<=r&&r<e}function St(r,t,e,n){if(!Yr(t,e,n))throw new Error(`expected valid ${r}: ${e} <= n < ${n}, got ${typeof t} ${t}`)}function Rd(r){let t;for(t=0;r>Yo;r>>=Vn,t+=1);return t}function Nd(r,t){return r>>BigInt(t)&Vn}function Td(r,t,e){return r|(e?Vn:Yo)<<BigInt(t)}var Zr=r=>(Ad<<BigInt(r-1))-Vn,Wo=r=>new Uint8Array(r),Cc=r=>Uint8Array.from(r);function Xo(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=Wo(r),s=Wo(r),o=0,i=()=>{n.fill(1),s.fill(0),o=0},a=(...u)=>e(s,n,...u),c=(u=Wo())=>{s=a(Cc([0]),u),n=a(),u.length!==0&&(s=a(Cc([1]),u),n=a())},l=()=>{if(o++>=1e3)throw new Error("drbg: tried 1000 values");let u=0,g=[];for(;u<t;){n=a();let m=n.slice();g.push(m),u+=n.length}return xe(...g)};return(u,g)=>{i(),c(u);let m;for(;!(m=g(l()));)c();return i(),m}}var Ld={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 Ft(r,t,e={}){let n=(s,o,i)=>{let a=Ld[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 Cd=()=>{throw new Error("not implemented")};function Xe(r){let t=new WeakMap;return(e,...n)=>{let s=t.get(e);if(s!==void 0)return s;let o=r(e,...n);return t.set(e,o),o}}var wt=BigInt(0),ot=BigInt(1),Je=BigInt(2),Ud=BigInt(3),Jo=BigInt(4),Pc=BigInt(5),Dc=BigInt(8),Pd=BigInt(9),Dd=BigInt(16);function Y(r,t){let e=r%t;return e>=wt?e:t+e}function Qo(r,t,e){if(e<=wt||t<wt)throw new Error("Expected power/modulo > 0");if(e===ot)return wt;let n=ot;for(;t>wt;)t&ot&&(n=n*r%e),r=r*r%e,t>>=ot;return n}function st(r,t,e){let n=r;for(;t-- >wt;)n*=n,n%=e;return n}function On(r,t){if(r===wt||t<=wt)throw new Error(`invert: expected positive integers, got n=${r} mod=${t}`);let e=Y(r,t),n=t,s=wt,o=ot,i=ot,a=wt;for(;e!==wt;){let l=n/e,f=n%e,u=s-i*l,g=o-a*l;n=e,e=f,s=i,o=a,i=u,a=g}if(n!==ot)throw new Error("invert: does not exist");return Y(s,t)}function Vd(r){let t=(r-ot)/Je,e,n,s;for(e=r-ot,n=0;e%Je===wt;e/=Je,n++);for(s=Je;s<r&&Qo(s,t,r)!==r-ot;s++);if(n===1){let i=(r+ot)/Jo;return function(c,l){let f=c.pow(l,i);if(!c.eql(c.sqr(f),l))throw new Error("Cannot find square root");return f}}let o=(e+ot)/Je;return function(a,c){if(a.pow(c,t)===a.neg(a.ONE))throw new Error("Cannot find square root");let l=n,f=a.pow(a.mul(a.ONE,s),e),u=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(f,ot<<BigInt(l-m-1));f=a.sqr(p),u=a.mul(u,p),g=a.mul(g,f),l=m}return u}}function Hd(r){if(r%Jo===Ud){let t=(r+ot)/Jo;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%Dc===Pc){let t=(r-Pc)/Dc;return function(n,s){let o=n.mul(s,Je),i=n.pow(o,t),a=n.mul(s,i),c=n.mul(n.mul(a,Je),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%Dd,Vd(r)}var Vc=(r,t)=>(Y(r,t)&ot)===ot,Od=["create","isValid","is0","neg","inv","sqrt","sqr","eql","add","sub","mul","pow","div","addN","subN","mulN","sqrN"];function ti(r){let t={ORDER:"bigint",MASK:"bigint",BYTES:"isSafeInteger",BITS:"isSafeInteger"},e=Od.reduce((n,s)=>(n[s]="function",n),t);return Ft(r,e)}function Md(r,t,e){if(e<wt)throw new Error("Expected power > 0");if(e===wt)return r.ONE;if(e===ot)return t;let n=r.ONE,s=t;for(;e>wt;)e&ot&&(n=r.mul(n,s)),s=r.sqr(s),e>>=ot;return n}function Kd(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 ei(r,t){let e=t!==void 0?t:r.toString(2).length,n=Math.ceil(e/8);return{nBitLength:e,nByteLength:n}}function Mn(r,t,e=!1,n={}){if(r<=wt)throw new Error(`Expected Field ORDER > 0, got ${r}`);let{nBitLength:s,nByteLength:o}=ei(r,t);if(o>2048)throw new Error("Field lengths over 2048 bytes are not supported");let i=Hd(r),a=Object.freeze({ORDER:r,BITS:s,BYTES:o,MASK:Zr(s),ZERO:wt,ONE:ot,create:c=>Y(c,r),isValid:c=>{if(typeof c!="bigint")throw new Error(`Invalid field element: expected bigint, got ${typeof c}`);return wt<=c&&c<r},is0:c=>c===wt,isOdd:c=>(c&ot)===ot,neg:c=>Y(-c,r),eql:(c,l)=>c===l,sqr:c=>Y(c*c,r),add:(c,l)=>Y(c+l,r),sub:(c,l)=>Y(c-l,r),mul:(c,l)=>Y(c*l,r),pow:(c,l)=>Md(a,c,l),div:(c,l)=>Y(c*On(l,r),r),sqrN:c=>c*c,addN:(c,l)=>c+l,subN:(c,l)=>c-l,mulN:(c,l)=>c*l,inv:c=>On(c,r),sqrt:n.sqrt||(c=>i(a,c)),invertBatch:c=>Kd(a,c),cmov:(c,l,f)=>f?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?Xt(c):we(c)}});return Object.freeze(a)}function Hc(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 ri(r){let t=Hc(r);return t+Math.ceil(t/2)}function Oc(r,t,e=!1){let n=r.length,s=Hc(t),o=ri(t);if(n<16||n<o||n>1024)throw new Error(`expected ${o}-1024 bytes of input, got ${n}`);let i=e?we(r):Xt(r),a=Y(i,t-ot)+ot;return e?be(a,s):De(a,s)}var $d=BigInt(0),ni=BigInt(1),si=new WeakMap,Mc=new WeakMap;function Kn(r,t){let e=(o,i)=>{let a=i.negate();return o?a:i},n=o=>{if(!Number.isSafeInteger(o)||o<=0||o>t)throw new Error(`Wrong window size=${o}, should be [1..${t}]`)},s=o=>{n(o);let i=Math.ceil(t/o)+1,a=2**(o-1);return{windows:i,windowSize:a}};return{constTimeNegate:e,unsafeLadder(o,i){let a=r.ZERO,c=o;for(;i>$d;)i&ni&&(a=a.add(c)),c=c.double(),i>>=ni;return a},precomputeWindow(o,i){let{windows:a,windowSize:c}=s(i),l=[],f=o,u=f;for(let g=0;g<a;g++){u=f,l.push(u);for(let m=1;m<c;m++)u=u.add(f),l.push(u);f=u.double()}return l},wNAF(o,i,a){let{windows:c,windowSize:l}=s(o),f=r.ZERO,u=r.BASE,g=BigInt(2**o-1),m=2**o,p=BigInt(o);for(let h=0;h<c;h++){let d=h*l,E=Number(a&g);a>>=p,E>l&&(E-=m,a+=ni);let w=d,x=d+Math.abs(E)-1,I=h%2!==0,N=E<0;E===0?u=u.add(e(I,i[w])):f=f.add(e(N,i[x]))}return{p:f,f:u}},wNAFCached(o,i,a){let c=Mc.get(o)||1,l=si.get(o);return l||(l=this.precomputeWindow(o,c),c!==1&&si.set(o,a(l))),this.wNAF(c,l,i)},setWindowSize(o,i){n(i),Mc.set(o,i),si.delete(o)}}}function Xr(r){return ti(r.Fp),Ft(r,{n:"bigint",h:"bigint",Gx:"field",Gy:"field"},{nBitLength:"isSafeInteger",nByteLength:"isSafeInteger"}),Object.freeze({...ei(r.n,r.nBitLength),...r,p:r.Fp.ORDER})}var Jt=BigInt(0),Dt=BigInt(1),Fn=BigInt(2),qd=BigInt(8),Gd={zip215:!0};function zd(r){let t=Xr(r);return Ft(r,{hash:"function",a:"bigint",d:"bigint",randomBytes:"function"},{adjustScalarBytes:"function",domain:"function",uvRatio:"function",mapToCurve:"function"}),Object.freeze({...t})}function Kc(r){let t=zd(r),{Fp:e,n,prehash:s,hash:o,randomBytes:i,nByteLength:a,h:c}=t,l=Fn<<BigInt(a*8)-Dt,f=e.create,u=t.uvRatio||((b,y)=>{try{return{isValid:!0,value:e.sqrt(b*e.inv(y))}}catch{return{isValid:!1,value:Jt}}}),g=t.adjustScalarBytes||(b=>b),m=t.domain||((b,y,B)=>{if(Zt("phflag",B),y.length||B)throw new Error("Contexts/pre-hash are not supported");return b});function p(b,y){St("coordinate "+b,y,Jt,l)}function h(b){if(!(b instanceof w))throw new Error("ExtendedPoint expected")}let d=Xe((b,y)=>{let{ex:B,ey:A,ez:v}=b,L=b.is0();y==null&&(y=L?qd:e.inv(v));let P=f(B*y),H=f(A*y),O=f(v*y);if(L)return{x:Jt,y:Dt};if(O!==Dt)throw new Error("invZ was invalid");return{x:P,y:H}}),E=Xe(b=>{let{a:y,d:B}=t;if(b.is0())throw new Error("bad point: ZERO");let{ex:A,ey:v,ez:L,et:P}=b,H=f(A*A),O=f(v*v),q=f(L*L),j=f(q*q),X=f(H*y),lt=f(q*f(X+O)),rt=f(j+f(B*f(H*O)));if(lt!==rt)throw new Error("bad point: equation left != right (1)");let et=f(A*v),Gt=f(L*P);if(et!==Gt)throw new Error("bad point: equation left != right (2)");return!0});class w{constructor(y,B,A,v){this.ex=y,this.ey=B,this.ez=A,this.et=v,p("x",y),p("y",B),p("z",A),p("t",v),Object.freeze(this)}get x(){return this.toAffine().x}get y(){return this.toAffine().y}static fromAffine(y){if(y instanceof w)throw new Error("extended point not allowed");let{x:B,y:A}=y||{};return p("x",B),p("y",A),new w(B,A,Dt,f(B*A))}static normalizeZ(y){let B=e.invertBatch(y.map(A=>A.ez));return y.map((A,v)=>A.toAffine(B[v])).map(w.fromAffine)}_setWindowSize(y){N.setWindowSize(this,y)}assertValidity(){E(this)}equals(y){h(y);let{ex:B,ey:A,ez:v}=this,{ex:L,ey:P,ez:H}=y,O=f(B*H),q=f(L*v),j=f(A*H),X=f(P*v);return O===q&&j===X}is0(){return this.equals(w.ZERO)}negate(){return new w(f(-this.ex),this.ey,this.ez,f(-this.et))}double(){let{a:y}=t,{ex:B,ey:A,ez:v}=this,L=f(B*B),P=f(A*A),H=f(Fn*f(v*v)),O=f(y*L),q=B+A,j=f(f(q*q)-L-P),X=O+P,lt=X-H,rt=O-P,et=f(j*lt),Gt=f(X*rt),xt=f(j*rt),zt=f(lt*X);return new w(et,Gt,zt,xt)}add(y){h(y);let{a:B,d:A}=t,{ex:v,ey:L,ez:P,et:H}=this,{ex:O,ey:q,ez:j,et:X}=y;if(B===BigInt(-1)){let Ya=f((L-v)*(q+O)),Za=f((L+v)*(q-O)),bo=f(Za-Ya);if(bo===Jt)return this.double();let Xa=f(P*Fn*X),Ja=f(H*Fn*j),Qa=Ja+Xa,tc=Za+Ya,ec=Ja-Xa,Cf=f(Qa*bo),Uf=f(tc*ec),Pf=f(Qa*ec),Df=f(bo*tc);return new w(Cf,Uf,Df,Pf)}let lt=f(v*O),rt=f(L*q),et=f(H*A*X),Gt=f(P*j),xt=f((v+L)*(O+q)-lt-rt),zt=Gt-et,ze=Gt+et,qr=f(rt-B*lt),In=f(xt*zt),Nf=f(ze*qr),Tf=f(xt*qr),Lf=f(zt*ze);return new w(In,Nf,Lf,Tf)}subtract(y){return this.add(y.negate())}wNAF(y){return N.wNAFCached(this,y,w.normalizeZ)}multiply(y){let B=y;St("scalar",B,Dt,n);let{p:A,f:v}=this.wNAF(B);return w.normalizeZ([A,v])[0]}multiplyUnsafe(y){let B=y;return St("scalar",B,Jt,n),B===Jt?I:this.equals(I)||B===Dt?this:this.equals(x)?this.wNAF(B).p:N.unsafeLadder(this,B)}isSmallOrder(){return this.multiplyUnsafe(c).is0()}isTorsionFree(){return N.unsafeLadder(this,n).is0()}toAffine(y){return d(this,y)}clearCofactor(){let{h:y}=t;return y===Dt?this:this.multiplyUnsafe(y)}static fromHex(y,B=!1){let{d:A,a:v}=t,L=e.BYTES;y=nt("pointHex",y,L),Zt("zip215",B);let P=y.slice(),H=y[L-1];P[L-1]=H&-129;let O=Xt(P),q=B?l:e.ORDER;St("pointHex.y",O,Jt,q);let j=f(O*O),X=f(j-Dt),lt=f(A*j-v),{isValid:rt,value:et}=u(X,lt);if(!rt)throw new Error("Point.fromHex: invalid y coordinate");let Gt=(et&Dt)===Dt,xt=(H&128)!==0;if(!B&&et===Jt&&xt)throw new Error("Point.fromHex: x=0 and x_0=1");return xt!==Gt&&(et=f(-et)),w.fromAffine({x:et,y:O})}static fromPrivateKey(y){return _(y).point}toRawBytes(){let{x:y,y:B}=this.toAffine(),A=be(B,e.BYTES);return A[A.length-1]|=y&Dt?128:0,A}toHex(){return ye(this.toRawBytes())}}w.BASE=new w(t.Gx,t.Gy,Dt,f(t.Gx*t.Gy)),w.ZERO=new w(Jt,Dt,Dt,Jt);let{BASE:x,ZERO:I}=w,N=Kn(w,a*8);function S(b){return Y(b,n)}function R(b){return S(Xt(b))}function _(b){let y=a;b=nt("private key",b,y);let B=nt("hashed private key",o(b),2*y),A=g(B.slice(0,y)),v=B.slice(y,2*y),L=R(A),P=x.multiply(L),H=P.toRawBytes();return{head:A,prefix:v,scalar:L,point:P,pointBytes:H}}function V(b){return _(b).pointBytes}function U(b=new Uint8Array,...y){let B=xe(...y);return R(o(m(B,nt("context",b),!!s)))}function T(b,y,B={}){b=nt("message",b),s&&(b=s(b));let{prefix:A,scalar:v,pointBytes:L}=_(y),P=U(B.context,A,b),H=x.multiply(P).toRawBytes(),O=U(B.context,H,L,b),q=S(P+O*v);St("signature.s",q,Jt,n);let j=xe(H,be(q,e.BYTES));return nt("result",j,a*2)}let F=Gd;function K(b,y,B,A=F){let{context:v,zip215:L}=A,P=e.BYTES;b=nt("signature",b,2*P),y=nt("message",y),L!==void 0&&Zt("zip215",L),s&&(y=s(y));let H=Xt(b.slice(P,2*P)),O,q,j;try{O=w.fromHex(B,L),q=w.fromHex(b.slice(0,P),L),j=x.multiplyUnsafe(H)}catch{return!1}if(!L&&O.isSmallOrder())return!1;let X=U(v,q.toRawBytes(),O.toRawBytes(),y);return q.add(O.multiplyUnsafe(X)).subtract(j).clearCofactor().equals(w.ZERO)}return x._setWindowSize(8),{CURVE:t,getPublicKey:V,sign:T,verify:K,ExtendedPoint:w,utils:{getExtendedPublicKey:_,randomPrivateKey:()=>i(e.BYTES),precompute(b=8,y=w.BASE){return y._setWindowSize(b),y.multiply(BigInt(3)),y}}}}var Er=BigInt(0),oi=BigInt(1);function jd(r){return Ft(r,{a:"bigint"},{montgomeryBits:"isSafeInteger",nByteLength:"isSafeInteger",adjustScalarBytes:"function",domain:"function",powPminus2:"function",Gu:"bigint"}),Object.freeze({...r})}function Fc(r){let t=jd(r),{P:e}=t,n=w=>Y(w,e),s=t.montgomeryBits,o=Math.ceil(s/8),i=t.nByteLength,a=t.adjustScalarBytes||(w=>w),c=t.powPminus2||(w=>Qo(w,e-BigInt(2),e));function l(w,x,I){let N=n(w*(x-I));return x=n(x-N),I=n(I+N),[x,I]}let f=(t.a-BigInt(2))/BigInt(4);function u(w,x){St("u",w,Er,e),St("scalar",x,Er,e);let I=x,N=w,S=oi,R=Er,_=w,V=oi,U=Er,T;for(let K=BigInt(s-1);K>=Er;K--){let k=I>>K&oi;U^=k,T=l(U,S,_),S=T[0],_=T[1],T=l(U,R,V),R=T[0],V=T[1],U=k;let b=S+R,y=n(b*b),B=S-R,A=n(B*B),v=y-A,L=_+V,P=_-V,H=n(P*b),O=n(L*B),q=H+O,j=H-O;_=n(q*q),V=n(N*n(j*j)),S=n(y*A),R=n(v*(y+n(f*v)))}T=l(U,S,_),S=T[0],_=T[1],T=l(U,R,V),R=T[0],V=T[1];let F=c(R);return n(S*F)}function g(w){return be(n(w),o)}function m(w){let x=nt("u coordinate",w,o);return i===32&&(x[31]&=127),Xt(x)}function p(w){let x=nt("scalar",w),I=x.length;if(I!==o&&I!==i)throw new Error(`Expected ${o} or ${i} bytes, got ${I}`);return Xt(a(x))}function h(w,x){let I=m(x),N=p(w),S=u(I,N);if(S===Er)throw new Error("Invalid private or public key received");return g(S)}let d=g(t.Gu);function E(w){return h(w,d)}return{scalarMult:h,scalarMultBase:E,getSharedSecret:(w,x)=>h(w,x),getPublicKey:w=>E(w),utils:{randomPrivateKey:()=>t.randomBytes(t.nByteLength)},GuBytes:d}}var Jr=BigInt("57896044618658097711785492504343953926634992332820282019728792003956564819949"),$c=BigInt("19681161376707505956807079304988542015446066515923890162744021073123829784752"),my=BigInt(0),Wd=BigInt(1),qc=BigInt(2),Yd=BigInt(3),Zd=BigInt(5),Xd=BigInt(8);function Gc(r){let t=BigInt(10),e=BigInt(20),n=BigInt(40),s=BigInt(80),o=Jr,a=r*r%o*r%o,c=st(a,qc,o)*a%o,l=st(c,Wd,o)*r%o,f=st(l,Zd,o)*l%o,u=st(f,t,o)*f%o,g=st(u,e,o)*u%o,m=st(g,n,o)*g%o,p=st(m,s,o)*m%o,h=st(p,s,o)*m%o,d=st(h,t,o)*f%o;return{pow_p_5_8:st(d,qc,o)*r%o,b2:a}}function zc(r){return r[0]&=248,r[31]&=127,r[31]|=64,r}function Jd(r,t){let e=Jr,n=Y(t*t*t,e),s=Y(n*n*t,e),o=Gc(r*s).pow_p_5_8,i=Y(r*n*o,e),a=Y(t*i*i,e),c=i,l=Y(i*$c,e),f=a===r,u=a===Y(-r,e),g=a===Y(-r*$c,e);return f&&(i=c),(u||g)&&(i=l),Vc(i,e)&&(i=Y(-i,e)),{isValid:f||u,value:i}}var Qd=Mn(Jr,void 0,!0),tp={a:BigInt(-1),d:BigInt("37095705934669439343138083508754565189542113879843219016388785533085940283555"),Fp:Qd,n:BigInt("7237005577332262213973186563042994240857116359379907606001950938285454250989"),h:Xd,Gx:BigInt("15112221349535400772501151409588531511454012693041857206046113283949847762202"),Gy:BigInt("46316835694926478169428394003475163141307993866256225615783033603165251855960"),hash:Wr,randomBytes:Ye,adjustScalarBytes:zc,uvRatio:Jd},vr=Kc(tp);var Qr=Fc({P:Jr,a:BigInt(486662),montgomeryBits:255,nByteLength:32,Gu:BigInt(9),powPminus2:r=>{let t=Jr,{pow_p_5_8:e,b2:n}=Gc(r);return Y(st(e,Yd,t)*n,t)},adjustScalarBytes:zc,randomBytes:Ye});var Br=32,Ee=64,$n=32;function jc(){let r=vr.utils.randomPrivateKey(),t=vr.getPublicKey(r);return{privateKey:Xc(r,t),publicKey:t}}function Wc(r){if(r.length!==$n)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=vr.getPublicKey(t);return{privateKey:Xc(t,e),publicKey:e}}function Yc(r,t){let e=r.subarray(0,$n);return vr.sign(t instanceof Uint8Array?t:t.subarray(),e)}function Zc(r,t,e){return vr.verify(t,e instanceof Uint8Array?e:e.subarray(),r)}function Xc(r,t){let e=new Uint8Array(Ee);for(let n=0;n<$n;n++)e[n]=r[n],e[$n+n]=t[n];return e}var Ct={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 ii={alg:"A128GCM",ext:!0,k:"scm9jmO_4BJAgdwWGVulLg",key_ops:["encrypt","decrypt"],kty:"oct"};function Jc(r){let t=r?.algorithm??"AES-GCM",e=r?.keyLength??16,n=r?.nonceLength??12,s=r?.digest??"SHA-256",o=r?.saltLength??16,i=r?.iterations??32767,a=Ct.get();e*=8;async function c(u,g){let m=a.getRandomValues(new Uint8Array(o)),p=a.getRandomValues(new Uint8Array(n)),h={name:t,iv:p};typeof g=="string"&&(g=W(g));let d;if(g.length===0){d=await a.subtle.importKey("jwk",ii,{name:"AES-GCM"},!0,["encrypt"]);try{let w={name:"PBKDF2",salt:m,iterations:i,hash:{name:s}},x=await a.subtle.importKey("raw",g,{name:"PBKDF2"},!1,["deriveKey"]);d=await a.subtle.deriveKey(w,x,{name:t,length:e},!0,["encrypt"])}catch{d=await a.subtle.importKey("jwk",ii,{name:"AES-GCM"},!0,["encrypt"])}}else{let w={name:"PBKDF2",salt:m,iterations:i,hash:{name:s}},x=await a.subtle.importKey("raw",g,{name:"PBKDF2"},!1,["deriveKey"]);d=await a.subtle.deriveKey(w,x,{name:t,length:e},!0,["encrypt"])}let E=await a.subtle.encrypt(h,d,u);return Et([m,h.iv,new Uint8Array(E)])}async function l(u,g){let m=u.subarray(0,o),p=u.subarray(o,o+n),h=u.subarray(o+n),d={name:t,iv:p};typeof g=="string"&&(g=W(g));let E;if(g.length===0)try{let x={name:"PBKDF2",salt:m,iterations:i,hash:{name:s}},I=await a.subtle.importKey("raw",g,{name:"PBKDF2"},!1,["deriveKey"]);E=await a.subtle.deriveKey(x,I,{name:t,length:e},!0,["decrypt"])}catch{E=await a.subtle.importKey("jwk",ii,{name:"AES-GCM"},!0,["decrypt"])}else{let x={name:"PBKDF2",salt:m,iterations:i,hash:{name:s}},I=await a.subtle.importKey("raw",g,{name:"PBKDF2"},!1,["deriveKey"]);E=await a.subtle.deriveKey(x,I,{name:t,length:e},!0,["decrypt"])}let w=await a.subtle.decrypt(d,E,h);return new Uint8Array(w)}return{encrypt:c,decrypt:l}}async function Ar(r,t){let n=await Jc().encrypt(r,t);return Vo.encode(n)}var np=Math.pow(2,7),sp=Math.pow(2,14),op=Math.pow(2,21),ai=Math.pow(2,28),ci=Math.pow(2,35),li=Math.pow(2,42),ui=Math.pow(2,49),J=128,Rt=127;function dt(r){if(r<np)return 1;if(r<sp)return 2;if(r<op)return 3;if(r<ai)return 4;if(r<ci)return 5;if(r<li)return 6;if(r<ui)return 7;if(Number.MAX_SAFE_INTEGER!=null&&r>Number.MAX_SAFE_INTEGER)throw new RangeError("Could not encode varint");return 8}function fi(r,t,e=0){switch(dt(r)){case 8:t[e++]=r&255|J,r/=128;case 7:t[e++]=r&255|J,r/=128;case 6:t[e++]=r&255|J,r/=128;case 5:t[e++]=r&255|J,r/=128;case 4:t[e++]=r&255|J,r>>>=7;case 3:t[e++]=r&255|J,r>>>=7;case 2:t[e++]=r&255|J,r>>>=7;case 1:{t[e++]=r&255,r>>>=7;break}default:throw new Error("unreachable")}return t}function ip(r,t,e=0){switch(dt(r)){case 8:t.set(e++,r&255|J),r/=128;case 7:t.set(e++,r&255|J),r/=128;case 6:t.set(e++,r&255|J),r/=128;case 5:t.set(e++,r&255|J),r/=128;case 4:t.set(e++,r&255|J),r>>>=7;case 3:t.set(e++,r&255|J),r>>>=7;case 2:t.set(e++,r&255|J),r>>>=7;case 1:{t.set(e++,r&255),r>>>=7;break}default:throw new Error("unreachable")}return t}function hi(r,t){let e=r[t],n=0;if(n+=e&Rt,e<J||(e=r[t+1],n+=(e&Rt)<<7,e<J)||(e=r[t+2],n+=(e&Rt)<<14,e<J)||(e=r[t+3],n+=(e&Rt)<<21,e<J)||(e=r[t+4],n+=(e&Rt)*ai,e<J)||(e=r[t+5],n+=(e&Rt)*ci,e<J)||(e=r[t+6],n+=(e&Rt)*li,e<J)||(e=r[t+7],n+=(e&Rt)*ui,e<J))return n;throw new RangeError("Could not decode varint")}function ap(r,t){let e=r.get(t),n=0;if(n+=e&Rt,e<J||(e=r.get(t+1),n+=(e&Rt)<<7,e<J)||(e=r.get(t+2),n+=(e&Rt)<<14,e<J)||(e=r.get(t+3),n+=(e&Rt)<<21,e<J)||(e=r.get(t+4),n+=(e&Rt)*ai,e<J)||(e=r.get(t+5),n+=(e&Rt)*ci,e<J)||(e=r.get(t+6),n+=(e&Rt)*li,e<J)||(e=r.get(t+7),n+=(e&Rt)*ui,e<J))return n;throw new RangeError("Could not decode varint")}function ie(r,t,e=0){return t==null&&(t=yt(dt(r))),t instanceof Uint8Array?fi(r,t,e):ip(r,t,e)}function Qt(r,t=0){return r instanceof Uint8Array?hi(r,t):ap(r,t)}var di=new Float32Array([-0]),Ve=new Uint8Array(di.buffer);function Qc(r,t,e){di[0]=r,t[e]=Ve[0],t[e+1]=Ve[1],t[e+2]=Ve[2],t[e+3]=Ve[3]}function tl(r,t){return Ve[0]=r[t],Ve[1]=r[t+1],Ve[2]=r[t+2],Ve[3]=r[t+3],di[0]}var pi=new Float64Array([-0]),Nt=new Uint8Array(pi.buffer);function el(r,t,e){pi[0]=r,t[e]=Nt[0],t[e+1]=Nt[1],t[e+2]=Nt[2],t[e+3]=Nt[3],t[e+4]=Nt[4],t[e+5]=Nt[5],t[e+6]=Nt[6],t[e+7]=Nt[7]}function rl(r,t){return Nt[0]=r[t],Nt[1]=r[t+1],Nt[2]=r[t+2],Nt[3]=r[t+3],Nt[4]=r[t+4],Nt[5]=r[t+5],Nt[6]=r[t+6],Nt[7]=r[t+7],pi[0]}var cp=BigInt(Number.MAX_SAFE_INTEGER),lp=BigInt(Number.MIN_SAFE_INTEGER),Ot=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 Qe;if(t<cp&&t>lp)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>nl&&(s=0n,++n>nl&&(n=0n))),new r(Number(s),Number(n))}static fromNumber(t){if(t===0)return Qe;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):Qe}},Qe=new Ot(0,0);Qe.toBigInt=function(){return 0n};Qe.zzEncode=Qe.zzDecode=function(){return this};Qe.length=function(){return 1};var nl=4294967296n;function sl(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 ol(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 gi(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 te(r,t){return RangeError(`index out of range: ${r.pos} + ${t??1} > ${r.len}`)}function qn(r,t){return(r[t-4]|r[t-3]<<8|r[t-2]<<16|r[t-1]<<24)>>>0}var mi=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,te(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 te(this,4);return qn(this.buf,this.pos+=4)}sfixed32(){if(this.pos+4>this.len)throw te(this,4);return qn(this.buf,this.pos+=4)|0}float(){if(this.pos+4>this.len)throw te(this,4);let t=tl(this.buf,this.pos);return this.pos+=4,t}double(){if(this.pos+8>this.len)throw te(this,4);let t=rl(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 te(this,t);return this.pos+=t,e===n?new Uint8Array(0):this.buf.subarray(e,n)}string(){let t=this.bytes();return ol(t,0,t.length)}skip(t){if(typeof t=="number"){if(this.pos+t>this.len)throw te(this,t);this.pos+=t}else do if(this.pos>=this.len)throw te(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 Ot(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 te(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 te(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 te(this,8);let t=qn(this.buf,this.pos+=4),e=qn(this.buf,this.pos+=4);return new Ot(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=hi(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 yi(r){return new mi(r instanceof Uint8Array?r:r.subarray())}function tr(r,t,e){let n=yi(r);return t.decode(n,void 0,e)}function wi(r){let t=r??8192,e=t>>>1,n,s=t;return function(i){if(i<1||i>e)return yt(i);s+i>t&&(n=yt(t),s=0);let a=n.subarray(s,s+=i);return s&7&&(s=(s|7)+1),a}}var er=class{fn;len;next;val;constructor(t,e,n){this.fn=t,this.len=e,this.next=void 0,this.val=n}};function bi(){}var Ei=class{head;tail;len;next;constructor(t){this.head=t.head,this.tail=t.tail,this.len=t.len,this.next=t.states}},up=wi();function fp(r){return globalThis.Buffer!=null?yt(r):up(r)}var rn=class{len;head;tail;states;constructor(){this.len=0,this.head=new er(bi,0,0),this.tail=this.head,this.states=null}_push(t,e,n){return this.tail=this.tail.next=new er(t,e,n),this.len+=e,this}uint32(t){return this.len+=(this.tail=this.tail.next=new vi((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(Gn,10,Ot.fromNumber(t)):this.uint32(t)}sint32(t){return this.uint32((t<<1^t>>31)>>>0)}uint64(t){let e=Ot.fromBigInt(t);return this._push(Gn,e.length(),e)}uint64Number(t){return this._push(fi,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=Ot.fromBigInt(t).zzEncode();return this._push(Gn,e.length(),e)}sint64Number(t){let e=Ot.fromNumber(t).zzEncode();return this._push(Gn,e.length(),e)}sint64String(t){return this.sint64(BigInt(t))}bool(t){return this._push(xi,1,t?1:0)}fixed32(t){return this._push(en,4,t>>>0)}sfixed32(t){return this.fixed32(t)}fixed64(t){let e=Ot.fromBigInt(t);return this._push(en,4,e.lo)._push(en,4,e.hi)}fixed64Number(t){let e=Ot.fromNumber(t);return this._push(en,4,e.lo)._push(en,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(Qc,4,t)}double(t){return this._push(el,8,t)}bytes(t){let e=t.length>>>0;return e===0?this._push(xi,1,0):this.uint32(e)._push(dp,e,t)}string(t){let e=sl(t);return e!==0?this.uint32(e)._push(gi,e,t):this._push(xi,1,0)}fork(){return this.states=new Ei(this),this.head=this.tail=new er(bi,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 er(bi,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=fp(this.len),n=0;for(;t!=null;)t.fn(t.val,e,n),n+=t.len,t=t.next;return e}};function xi(r,t,e){t[e]=r&255}function hp(r,t,e){for(;r>127;)t[e++]=r&127|128,r>>>=7;t[e]=r}var vi=class extends er{next;constructor(t,e){super(hp,t,e),this.next=void 0}};function Gn(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 en(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 dp(r,t,e){t.set(r,e)}globalThis.Buffer!=null&&(rn.prototype.bytes=function(r){let t=r.length>>>0;return this.uint32(t),t>0&&this._push(pp,t,r),this},rn.prototype.string=function(r){let t=globalThis.Buffer.byteLength(r);return this.uint32(t),t>0&&this._push(gp,t,r),this});function pp(r,t,e){t.set(r,e)}function gp(r,t,e){r.length<40?gi(r,t,e):t.utf8Write!=null?t.utf8Write(r,e):t.set(W(r),e)}function Bi(){return new rn}function rr(r,t){let e=Bi();return t.encode(r,e,{lengthDelimited:!1}),e.finish()}var Sr;(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"})(Sr||(Sr={}));function zn(r,t,e,n){return{name:r,type:t,encode:e,decode:n}}function Ai(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 zn("enum",Sr.VARINT,e,n)}function nr(r,t){return zn("message",Sr.LENGTH_DELIMITED,r,t)}var it;(function(r){r.RSA="RSA",r.Ed25519="Ed25519",r.Secp256k1="Secp256k1"})(it||(it={}));var Si;(function(r){r[r.RSA=0]="RSA",r[r.Ed25519=1]="Ed25519",r[r.Secp256k1=2]="Secp256k1"})(Si||(Si={}));(function(r){r.codec=()=>Ai(Si)})(it||(it={}));var ae;(function(r){let t;r.codec=()=>(t==null&&(t=nr((e,n,s={})=>{s.lengthDelimited!==!1&&n.fork(),e.Type!=null&&(n.uint32(8),it.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=it.codec().decode(e);break;case 2:s.Data=e.bytes();break;default:e.skipType(i&7);break}}return s})),t),r.encode=e=>rr(e,r.codec()),r.decode=e=>tr(e,r.codec())})(ae||(ae={}));var ce;(function(r){let t;r.codec=()=>(t==null&&(t=nr((e,n,s={})=>{s.lengthDelimited!==!1&&n.fork(),e.Type!=null&&(n.uint32(8),it.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=it.codec().decode(e);break;case 2:s.Data=e.bytes();break;default:e.skipType(i&7);break}}return s})),t),r.encode=e=>rr(e,r.codec()),r.decode=e=>tr(e,r.codec())})(ce||(ce={}));var nn=class{_key;constructor(t){this._key=kr(t,Br)}verify(t,e){return Zc(this._key,e,t)}marshal(){return this._key}get bytes(){return ae.encode({Type:it.Ed25519,Data:this.marshal()}).subarray()}equals(t){return ft(this.bytes,t.bytes)}hash(){let t=At.digest(this.bytes);return Kt(t)?t.then(({bytes:e})=>e):t.bytes}},sr=class{_key;_publicKey;constructor(t,e){this._key=kr(t,Ee),this._publicKey=kr(e,Br)}sign(t){return Yc(this._key,t)}get public(){return new nn(this._publicKey)}marshal(){return this._key}get bytes(){return ce.encode({Type:it.Ed25519,Data:this.marshal()}).subarray()}equals(t){return ft(this.bytes,t.bytes)}async hash(){let t=At.digest(this.bytes),e;return Kt(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 Ar(this.bytes,t);throw new M(`export format '${e}' is not supported`,"ERR_INVALID_EXPORT_FORMAT")}};function mp(r){if(r.length>Ee){r=kr(r,Ee+Br);let n=r.subarray(0,Ee),s=r.subarray(Ee,r.length);return new sr(n,s)}r=kr(r,Ee);let t=r.subarray(0,Ee),e=r.subarray(Br);return new sr(t,e)}function yp(r){return r=kr(r,Br),new nn(r)}async function wp(){let{privateKey:r,publicKey:t}=jc();return new sr(r,t)}async function al(r){let{privateKey:t,publicKey:e}=Wc(r);return new sr(t,e)}function kr(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=Cn[t];if(e==null)throw new Error(`Unsupported encoding "${t}"`);return e.encoder.encode(r).substring(1)}var Di={};gt(Di,{MAX_RSA_KEY_SIZE:()=>gn,RsaPrivateKey:()=>Tr,RsaPublicKey:()=>pn,fromJwk:()=>Gp,generateKeyPair:()=>zp,unmarshalRsaPrivateKey:()=>Ui,unmarshalRsaPublicKey:()=>qp});function or(r){if(isNaN(r)||r<=0)throw new M("random bytes length must be a Number bigger than 0","ERR_INVALID_LENGTH");return Ye(r)}var Fe={};gt(Fe,{exportToPem:()=>Op,importFromPem:()=>Mp,jwkToPkcs1:()=>Pp,jwkToPkix:()=>Vp,pkcs1ToJwk:()=>Up,pkixToJwk:()=>Dp});var Wn=class extends yr{constructor(t,e){super(),this.finished=!1,this.destroyed=!1,We(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 mr(this),this.iHash.update(t),this}digestInto(t){mr(this),gr(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 Wn(r,t).update(e).digest();He.create=(r,t)=>new Wn(r,t);function bp(r,t,e,n){We(r);let s=_c({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),f=new Uint8Array(i),u=He.create(r,c),g=u._cloneInto().update(l);return{c:o,dkLen:i,asyncTick:a,DK:f,PRF:u,PRFSalt:g}}function xp(r,t,e,n,s){return r.destroy(),t.destroy(),n&&n.destroy(),s.fill(0),e}async function Ii(r,t,e,n){let{c:s,dkLen:o,asyncTick:i,DK:a,PRF:c,PRFSalt:l}=bp(r,t,e,n),f,u=new Uint8Array(4),g=wr(u),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),(f=l._cloneInto(f)).update(u).digestInto(m),d.set(m.subarray(0,d.length)),await kc(s-1,i,()=>{c._cloneInto(f).update(m).digestInto(m);for(let E=0;E<d.length;E++)d[E]^=m[E]})}return xp(c,l,a,f,m)}var z=$f(cl());function ir(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 f=a-1;f>=0;f--){let u=Math.pow(2,f*t);l[o-f-1]=Math.floor(s/u),s-=l[o-f-1]*u}return c}i*=Math.pow(2,t)}return new ArrayBuffer(0)}function Xn(...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 Ri(){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=ir(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,ir(o,8)-n}function ll(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 ul(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 Aw=Math.log(2);function Jn(){if(typeof BigInt>"u")throw new Error("BigInt is not defined. Your environment doesn't implement BigInt.")}function Ni(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 on=class{constructor(){this.items=[]}write(t){this.items.push(t)}final(){return Ni(this.items)}},sn=[new Uint8Array([1])],fl="0123456789";var Rr="",re=new ArrayBuffer(0),Ti=new Uint8Array(0),an="EndOfContent",dl="OCTET STRING",pl="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?z.BufferSourceConverter.toUint8Array(o.valueHex):Ti}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",re)}toJSON(){return{...super.toJSON(),isHexOnly:this.isHexOnly,valueHex:z.Convert.ToHex(this.valueHexView)}}},t.NAME="hexBlock",t}var Be=class{constructor({blockLength:t=0,error:e=Rr,warnings:n=[],valueBeforeDecode:s=Ti}={}){this.blockLength=t,this.error=e,this.warnings=n,this.valueBeforeDecodeView=z.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:z.Convert.ToHex(this.valueBeforeDecodeView)}}};Be.NAME="baseBlock";var Tt=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'")}};Tt.NAME="valueBlock";var Qn=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?z.BufferSourceConverter.toUint8Array(t.valueHex):Ti,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",re}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=z.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),f=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===f){f+=255;let g=new Uint8Array(f);for(let m=0;m<l.length;m++)g[m]=l[m];l=this.valueHexView=new Uint8Array(f)}}this.blockLength=c+1,l[c-1]=o[c]&127;let u=new Uint8Array(c);for(let g=0;g<c;g++)u[g]=l[g];l=this.valueHexView=new Uint8Array(c),l.set(u),this.blockLength<=9?this.tagNumber=ir(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}}};Qn.NAME="identificationBlock";var ts=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=z.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=ir(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",re;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}}};ts.NAME="lengthBlock";var C={},kt=class extends Be{constructor({name:t=Rr,optional:e=!1,primitiveSchema:n,...s}={},o){super(s),this.name=t,this.optional=e,n&&(this.primitiveSchema=n),this.idBlock=new Qn(s),this.lenBlock=new ts(s),this.valueBlock=o?new o(s):new Tt(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 on;e||gl(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?re: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():z.Convert.ToHex(this.toBER())}onAsciiEncoding(){return`${this.constructor.NAME} : ${z.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 ul(e,n)}};kt.NAME="BaseBlock";function gl(r){if(r instanceof C.Constructed)for(let t of r.valueBlock.value)gl(t)&&(r.lenBlock.isIndefiniteForm=!0);return!!r.lenBlock.isIndefiniteForm}var es=class extends kt{constructor({value:t=Rr,...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}'`}};es.NAME="BaseStringBlock";var rs=class extends Ie(Tt){constructor({isHexOnly:t=!0,...e}={}){super(e),this.isHexOnly=t}};rs.NAME="PrimitiveValueBlock";var ml,ns=class extends kt{constructor(t={}){super(t,rs),this.idBlock.isConstructed=!1}};ml=ns;C.Primitive=ml;ns.NAME="PRIMITIVE";function Rp(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 Ds(r,t=0,e=r.length){let n=t,s=new kt({},Tt),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=C.EndOfContent;break;case 1:c=C.Boolean;break;case 2:c=C.Integer;break;case 3:c=C.BitString;break;case 4:c=C.OctetString;break;case 5:c=C.Null;break;case 6:c=C.ObjectIdentifier;break;case 10:c=C.Enumerated;break;case 12:c=C.Utf8String;break;case 13:c=C.RelativeObjectIdentifier;break;case 14:c=C.TIME;break;case 15:return s.error="[UNIVERSAL 15] is reserved by ASN.1 standard",{offset:-1,result:s};case 16:c=C.Sequence;break;case 17:c=C.Set;break;case 18:c=C.NumericString;break;case 19:c=C.PrintableString;break;case 20:c=C.TeletexString;break;case 21:c=C.VideotexString;break;case 22:c=C.IA5String;break;case 23:c=C.UTCTime;break;case 24:c=C.GeneralizedTime;break;case 25:c=C.GraphicString;break;case 26:c=C.VisibleString;break;case 27:c=C.GeneralString;break;case 28:c=C.UniversalString;break;case 29:c=C.CharacterString;break;case 30:c=C.BmpString;break;case 31:c=C.DATE;break;case 32:c=C.TimeOfDay;break;case 33:c=C.DateTime;break;case 34:c=C.Duration;break;default:{let l=s.idBlock.isConstructed?new C.Constructed:new C.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?C.Constructed:C.Primitive}return s=Rp(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 Nr(r){if(!r.byteLength){let t=new kt({},Tt);return t.error="Input buffer has zero length",{offset:-1,result:t}}return Ds(z.BufferSourceConverter.toUint8Array(r).slice(),0,r.byteLength)}function Np(r,t){return r?1:t}var le=class extends Tt{constructor({value:t=[],isIndefiniteForm:e=!1,...n}={}){super(n),this.value=t,this.isIndefiniteForm=e}fromBER(t,e,n){let s=z.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(;Np(this.isIndefiniteForm,n)>0;){let i=Ds(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===an)break}return this.isIndefiniteForm&&(this.value[this.value.length-1].constructor.NAME===an?this.value.pop():this.warnings.push("No EndOfContent block encoded")),o}toBER(t,e){let n=e||new on;for(let s=0;s<this.value.length;s++)this.value[s].toBER(t,n);return e?re:n.final()}toJSON(){let t={...super.toJSON(),isIndefiniteForm:this.isIndefiniteForm,value:[]};for(let e of this.value)t.value.push(e.toJSON());return t}};le.NAME="ConstructedValueBlock";var yl,Me=class extends kt{constructor(t={}){super(t,le),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 Mf=Object.create;var Tn=Object.defineProperty;var Kf=Object.getOwnPropertyDescriptor;var Ff=Object.getOwnPropertyNames;var $f=Object.getPrototypeOf,qf=Object.prototype.hasOwnProperty;var Gf=(r,t)=>()=>(t||r((t={exports:{}}).exports,t),t.exports),mt=(r,t)=>{for(var e in t)Tn(r,e,{get:t[e],enumerable:!0})},oc=(r,t,e,n)=>{if(t&&typeof t=="object"||typeof t=="function")for(let s of Ff(t))!qf.call(r,s)&&s!==e&&Tn(r,s,{get:()=>t[s],enumerable:!(n=Kf(t,s))||n.enumerable});return r};var zf=(r,t,e)=>(e=r!=null?Mf($f(r)):{},oc(t||!r||!r.__esModule?Tn(e,"default",{value:r,enumerable:!0}):e,r)),jf=r=>oc(Tn({},"__esModule",{value:!0}),r);var ul=Gf(Nr=>{"use strict";var Bp="[object ArrayBuffer]",Be=class r{static isArrayBuffer(t){return Object.prototype.toString.call(t)===Bp}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}},Ti="string",Ap=/^[0-9a-f]+$/i,Sp=/^(?:[A-Za-z0-9+/]{4})*(?:[A-Za-z0-9+/]{2}==|[A-Za-z0-9+/]{3}=)?$/,kp=/^[a-zA-Z0-9-_]+$/,Xn=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=Be.toUint8Array(t),n="";for(let o=0;o<e.length;o++)n+=String.fromCharCode(e[o]);return decodeURIComponent(escape(n))}},Gt=class{static toString(t,e=!1){let n=Be.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}},Jn=class r{static isHex(t){return typeof t===Ti&&Ap.test(t)}static isBase64(t){return typeof t===Ti&&Sp.test(t)}static isBase64Url(t){return typeof t===Ti&&kp.test(t)}static ToString(t,e="utf8"){let n=Be.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 Gt.toString(n,!0);case"utf16":case"utf16be":return Gt.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 Gt.fromString(t,!0);case"utf16":case"utf16be":return Gt.fromString(t);default:throw new Error(`Unknown type of encoding '${e}'`)}}static ToBase64(t){let e=Be.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 Xn.fromString(t);case"utf16":case"utf16be":return Gt.fromString(t);case"utf16le":case"usc2":return Gt.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 Xn.toString(t);case"utf16":case"utf16be":return Gt.toString(t);case"utf16le":case"usc2":return Gt.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=Be.toUint8Array(t),n="";for(let s=0;s<e.length;s++)n+=String.fromCharCode(e[s]);return n}static ToHex(t){let e=Be.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 Gt.toString(t,e)}static FromUtf16String(t,e=!1){return Gt.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,"")||""}};Jn.DEFAULT_UTF8_ENCODING="utf8";function Ip(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 _p(...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 Rp(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}Nr.BufferSourceConverter=Be;Nr.Convert=Jn;Nr.assign=Ip;Nr.combine=_p;Nr.isEqual=Rp});var hg={};mt(hg,{webTransport:()=>fg});var Ln=Symbol.for("@libp2p/peer-id");function ic(r){return r!=null&&!!r[Ln]}var cc=Symbol.for("@libp2p/transport");var ac;(function(r){r[r.FATAL_ALL=0]="FATAL_ALL",r[r.NO_FATAL=1]="NO_FATAL"})(ac||(ac={}));var Cn=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 Un=Symbol.for("@libp2p/service-capabilities"),yg=Symbol.for("@libp2p/service-dependencies");var Ri={};mt(Ri,{Ed25519PrivateKey:()=>cr,Ed25519PublicKey:()=>cn,generateKeyPair:()=>xp,generateKeyPairFromSeed:()=>ll,unmarshalEd25519PrivateKey:()=>wp,unmarshalEd25519PublicKey:()=>bp});var ko={};mt(ko,{base58btc:()=>ut,base58flickr:()=>Qf});var Kg=new Uint8Array(0);function lc(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 pe(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 uc(r){return new TextEncoder().encode(r)}function fc(r){return new TextDecoder().decode(r)}function Wf(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),f=Math.log(256)/Math.log(a);function u(y){if(y instanceof Uint8Array||(ArrayBuffer.isView(y)?y=new Uint8Array(y.buffer,y.byteOffset,y.byteLength):Array.isArray(y)&&(y=Uint8Array.from(y))),!(y instanceof Uint8Array))throw new TypeError("Expected Uint8Array");if(y.length===0)return"";for(var m=0,h=0,w=0,x=y.length;w!==x&&y[w]===0;)w++,m++;for(var g=(x-w)*f+1>>>0,A=new Uint8Array(g);w!==x;){for(var L=y[w],N=0,k=g-1;(L!==0||N<h)&&k!==-1;k--,N++)L+=256*A[k]>>>0,A[k]=L%a>>>0,L=L/a>>>0;if(L!==0)throw new Error("Non-zero carry");h=N,w++}for(var R=g-h;R!==g&&A[R]===0;)R++;for(var I=c.repeat(m);R<g;++R)I+=r.charAt(A[R]);return I}function d(y){if(typeof y!="string")throw new TypeError("Expected String");if(y.length===0)return new Uint8Array;var m=0;if(y[m]!==" "){for(var h=0,w=0;y[m]===c;)h++,m++;for(var x=(y.length-m)*l+1>>>0,g=new Uint8Array(x);y[m];){var A=e[y.charCodeAt(m)];if(A===255)return;for(var L=0,N=x-1;(A!==0||L<w)&&N!==-1;N--,L++)A+=a*g[N]>>>0,g[N]=A%256>>>0,A=A/256>>>0;if(A!==0)throw new Error("Non-zero carry");w=L,m++}if(y[m]!==" "){for(var k=x-w;k!==x&&g[k]===0;)k++;for(var R=new Uint8Array(h+(x-k)),I=h;k!==x;)R[I++]=g[k++];return R}}}function p(y){var m=d(y);if(m)return m;throw new Error(`Non-${t} character`)}return{encode:u,decodeUnsafe:d,decode:p}}var Yf=Wf,Zf=Yf,dc=Zf;var vo=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")}},Bo=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 pc(this,t)}},Ao=class{decoders;constructor(t){this.decoders=t}or(t){return pc(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 pc(r,t){return new Ao({...r.decoders??{[r.prefix]:r},...t.decoders??{[t.prefix]:t}})}var So=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 vo(t,e,n),this.decoder=new Bo(t,e,s)}encode(t){return this.encoder.encode(t)}decode(t){return this.decoder.decode(t)}};function gr({name:r,prefix:t,encode:e,decode:n}){return new So(r,t,e,n)}function Ce({name:r,prefix:t,alphabet:e}){let{encode:n,decode:s}=dc(e,r);return gr({prefix:t,name:r,encode:n,decode:o=>pe(s(o))})}function Xf(r,t,e,n){let s={};for(let f=0;f<t.length;++f)s[t[f]]=f;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 f=0;f<o;++f){let u=s[r[f]];if(u===void 0)throw new SyntaxError(`Non-${n} character`);c=c<<e|u,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 Jf(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 gr({prefix:t,name:r,encode(s){return Jf(s,n,e)},decode(s){return Xf(s,n,e,r)}})}var ut=Ce({name:"base58btc",prefix:"z",alphabet:"123456789ABCDEFGHJKLMNPQRSTUVWXYZabcdefghijkmnopqrstuvwxyz"}),Qf=Ce({name:"base58flickr",prefix:"Z",alphabet:"123456789abcdefghijkmnopqrstuvwxyzABCDEFGHJKLMNPQRSTUVWXYZ"});var Ro={};mt(Ro,{identity:()=>ge});var se={};mt(se,{Digest:()=>Ye,create:()=>jt,decode:()=>Ue,equals:()=>_o});var th=yc,gc=128,eh=127,rh=~eh,nh=Math.pow(2,31);function yc(r,t,e){t=t||[],e=e||0;for(var n=e;r>=nh;)t[e++]=r&255|gc,r/=128;for(;r&rh;)t[e++]=r&255|gc,r>>>=7;return t[e]=r|0,yc.bytes=e-n+1,t}var sh=Io,oh=128,mc=127;function Io(r,n){var e=0,n=n||0,s=0,o=n,i,a=r.length;do{if(o>=a)throw Io.bytes=0,new RangeError("Could not decode varint");i=r[o++],e+=s<28?(i&mc)<<s:(i&mc)*Math.pow(2,s),s+=7}while(i>=oh);return Io.bytes=o-n,e}var ih=Math.pow(2,7),ah=Math.pow(2,14),ch=Math.pow(2,21),lh=Math.pow(2,28),uh=Math.pow(2,35),fh=Math.pow(2,42),hh=Math.pow(2,49),dh=Math.pow(2,56),ph=Math.pow(2,63),gh=function(r){return r<ih?1:r<ah?2:r<ch?3:r<lh?4:r<uh?5:r<fh?6:r<hh?7:r<dh?8:r<ph?9:10},mh={encode:th,decode:sh,encodingLength:gh},yh=mh,Yr=yh;function Zr(r,t=0){return[Yr.decode(r,t),Yr.decode.bytes]}function mr(r,t,e=0){return Yr.encode(r,t,e),t}function yr(r){return Yr.encodingLength(r)}function jt(r,t){let e=t.byteLength,n=yr(r),s=n+yr(e),o=new Uint8Array(s+e);return mr(r,o,0),mr(e,o,n),o.set(t,s),new Ye(r,e,t,o)}function Ue(r){let t=pe(r),[e,n]=Zr(t),[s,o]=Zr(t.subarray(n)),i=t.subarray(n+o);if(i.byteLength!==s)throw new Error("Incorrect length");return new Ye(e,s,i,t)}function _o(r,t){if(r===t)return!0;{let e=t;return r.code===e.code&&r.size===e.size&&e.bytes instanceof Uint8Array&&lc(r.bytes,e.bytes)}}var Ye=class{code;size;digest;bytes;constructor(t,e,n,s){this.code=t,this.size=e,this.digest=n,this.bytes=s}};var wc=0,wh="identity",bc=pe;function bh(r){return jt(wc,bc(r))}var ge={code:wc,name:wh,encode:bc,digest:bh};var Lo={};mt(Lo,{sha256:()=>At,sha512:()=>xh});function To({name:r,code:t,encode:e}){return new No(r,t,e)}var No=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?jt(this.code,e):e.then(n=>jt(this.code,n))}else throw Error("Unknown type, must be binary type")}};function Ec(r){return async t=>new Uint8Array(await crypto.subtle.digest(r,t))}var At=To({name:"sha2-256",code:18,encode:Ec("SHA-256")}),xh=To({name:"sha2-512",code:19,encode:Ec("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 Co={};mt(Co,{base10:()=>vh});var vh=Ce({prefix:"9",name:"base10",alphabet:"0123456789"});var Uo={};mt(Uo,{base16:()=>Bh,base16upper:()=>Ah});var Bh=lt({prefix:"f",name:"base16",alphabet:"0123456789abcdef",bitsPerChar:4}),Ah=lt({prefix:"F",name:"base16upper",alphabet:"0123456789ABCDEF",bitsPerChar:4});var Po={};mt(Po,{base2:()=>Sh});var Sh=lt({prefix:"0",name:"base2",alphabet:"01",bitsPerChar:1});var Do={};mt(Do,{base256emoji:()=>Nh});var vc=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}"),kh=vc.reduce((r,t,e)=>(r[e]=t,r),[]),Ih=vc.reduce((r,t,e)=>(r[t.codePointAt(0)]=e,r),[]);function _h(r){return r.reduce((t,e)=>(t+=kh[e],t),"")}function Rh(r){let t=[];for(let e of r){let n=Ih[e.codePointAt(0)];if(n===void 0)throw new Error(`Non-base256emoji character: ${e}`);t.push(n)}return new Uint8Array(t)}var Nh=gr({prefix:"\u{1F680}",name:"base256emoji",encode:_h,decode:Rh});var Vo={};mt(Vo,{base32:()=>me,base32hex:()=>Uh,base32hexpad:()=>Dh,base32hexpadupper:()=>Vh,base32hexupper:()=>Ph,base32pad:()=>Lh,base32padupper:()=>Ch,base32upper:()=>Th,base32z:()=>Hh});var me=lt({prefix:"b",name:"base32",alphabet:"abcdefghijklmnopqrstuvwxyz234567",bitsPerChar:5}),Th=lt({prefix:"B",name:"base32upper",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZ234567",bitsPerChar:5}),Lh=lt({prefix:"c",name:"base32pad",alphabet:"abcdefghijklmnopqrstuvwxyz234567=",bitsPerChar:5}),Ch=lt({prefix:"C",name:"base32padupper",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZ234567=",bitsPerChar:5}),Uh=lt({prefix:"v",name:"base32hex",alphabet:"0123456789abcdefghijklmnopqrstuv",bitsPerChar:5}),Ph=lt({prefix:"V",name:"base32hexupper",alphabet:"0123456789ABCDEFGHIJKLMNOPQRSTUV",bitsPerChar:5}),Dh=lt({prefix:"t",name:"base32hexpad",alphabet:"0123456789abcdefghijklmnopqrstuv=",bitsPerChar:5}),Vh=lt({prefix:"T",name:"base32hexpadupper",alphabet:"0123456789ABCDEFGHIJKLMNOPQRSTUV=",bitsPerChar:5}),Hh=lt({prefix:"h",name:"base32z",alphabet:"ybndrfg8ejkmcpqxot1uwisza345h769",bitsPerChar:5});var Ho={};mt(Ho,{base36:()=>Oh,base36upper:()=>Mh});var Oh=Ce({prefix:"k",name:"base36",alphabet:"0123456789abcdefghijklmnopqrstuvwxyz"}),Mh=Ce({prefix:"K",name:"base36upper",alphabet:"0123456789ABCDEFGHIJKLMNOPQRSTUVWXYZ"});var Ko={};mt(Ko,{base64:()=>Oo,base64pad:()=>Kh,base64url:()=>Mo,base64urlpad:()=>Fh});var Oo=lt({prefix:"m",name:"base64",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/",bitsPerChar:6}),Kh=lt({prefix:"M",name:"base64pad",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/=",bitsPerChar:6}),Mo=lt({prefix:"u",name:"base64url",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789-_",bitsPerChar:6}),Fh=lt({prefix:"U",name:"base64urlpad",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789-_=",bitsPerChar:6});var Fo={};mt(Fo,{base8:()=>$h});var $h=lt({prefix:"7",name:"base8",alphabet:"01234567",bitsPerChar:3});var $o={};mt($o,{identity:()=>qh});var qh=gr({prefix:"\0",name:"identity",encode:r=>fc(r),decode:r=>uc(r)});var pm=new TextEncoder,gm=new TextDecoder;function Bc(r,t){let{bytes:e,version:n}=r;switch(n){case 0:return Wh(e,qo(r),t??ut.encoder);default:return Yh(e,qo(r),t??me.encoder)}}var Ac=new WeakMap;function qo(r){let t=Ac.get(r);if(t==null){let e=new Map;return Ac.set(r,e),e}return t}var Ft=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!==Xr)throw new Error("Cannot convert a non dag-pb CID to CIDv0");if(e.code!==Zh)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=jt(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&&_o(t.multihash,n.multihash)}toString(t){return Bc(this,t)}toJSON(){return{"/":Bc(this)}}link(){return this}[Symbol.toStringTag]="CID";[Symbol.for("nodejs.util.inspect.custom")](){return`CID(${this.toString()})`}static asCID(t){if(t==null)return null;let e=t;if(e instanceof r)return e;if(e["/"]!=null&&e["/"]===e.bytes||e.asCID===e){let{version:n,code:s,multihash:o,bytes:i}=e;return new r(n,s,o,i??Sc(n,s,o.bytes))}else if(e[Xh]===!0){let{version:n,multihash:s,code:o}=e,i=Ue(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!==Xr)throw new Error(`Version 0 CID must use dag-pb (code: ${Xr}) block encoding`);return new r(t,e,n,n.bytes)}case 1:{let s=Sc(t,e,n.bytes);return new r(t,e,n,s)}default:throw new Error("Invalid version")}}static createV0(t){return r.create(0,Xr,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=pe(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 Ye(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[u,d]=Zr(t.subarray(e));return e+=d,u},s=n(),o=Xr;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,f=l-i;return{version:s,codec:o,multihashCode:a,digestSize:c,multihashSize:f,size:l}}static parse(t,e){let[n,s]=jh(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 qo(o).set(n,t),o}};function jh(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 me.prefix:{let e=t??me;return[me.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 Wh(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 Yh(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 Xr=112,Zh=18;function Sc(r,t,e){let n=yr(r),s=n+yr(t),o=new Uint8Array(s+e.byteLength);return mr(r,o,0),mr(t,o,n),o.set(e,s),o}var Xh=Symbol.for("@ipld/js-cid/CID");var oe={...$o,...Po,...Fo,...Co,...Uo,...Vo,...Ho,...ko,...Ko,...Do},Tm={...Lo,...Ro};function Ic(r,t,e,n){return{name:r,prefix:t,encoder:{name:r,prefix:t,encode:e},decoder:{decode:n}}}var kc=Ic("utf8","u",r=>"u"+new TextDecoder("utf8").decode(r),r=>new TextEncoder().encode(r.substring(1))),Go=Ic("ascii","a",r=>{let t="a";for(let e=0;e<r.length;e++)t+=String.fromCharCode(r[e]);return t},r=>{r=r.substring(1);let t=wt(r.length);for(let e=0;e<r.length;e++)t[e]=r.charCodeAt(e);return t}),Jh={utf8:kc,"utf-8":kc,hex:oe.base16,latin1:Go,ascii:Go,binary:Go,...oe},Dn=Jh;function Y(r,t="utf8"){let e=Dn[t];if(e==null)throw new Error(`Unsupported encoding "${t}"`);return e.decoder.decode(`${e.prefix}${r}`)}function $t(r){return r==null?!1:typeof r.then=="function"&&typeof r.catch=="function"&&typeof r.finally=="function"}function Pe(r){if(!Number.isSafeInteger(r)||r<0)throw new Error(`positive integer expected, not ${r}`)}function Qh(r){return r instanceof Uint8Array||r!=null&&typeof r=="object"&&r.constructor.name==="Uint8Array"}function wr(r,...t){if(!Qh(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");Pe(r.outputLen),Pe(r.blockLen)}function br(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 _c(r,t){wr(r);let e=t.outputLen;if(r.length<e)throw new Error(`digestInto() expects output buffer of length at least ${e}`)}var Xe=typeof globalThis=="object"&&"crypto"in globalThis?globalThis.crypto:void 0;var Er=r=>new DataView(r.buffer,r.byteOffset,r.byteLength),Wt=(r,t)=>r<<32-t|r>>>t;var Gm=new Uint8Array(new Uint32Array([287454020]).buffer)[0]===68;var td=async()=>{};async function Rc(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 td(),n+=o)}}function Nc(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=Nc(r)),wr(r),r}function zo(...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}var xr=class{clone(){return this._cloneInto()}},ed={}.toString;function Tc(r,t){if(t!==void 0&&ed.call(t)!=="[object Object]")throw new Error("Options should be object or undefined");return Object.assign(r,t)}function Vn(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 Je(r=32){if(Xe&&typeof Xe.getRandomValues=="function")return Xe.getRandomValues(new Uint8Array(r));if(Xe&&typeof Xe.randomBytes=="function")return Xe.randomBytes(r);throw new Error("crypto.getRandomValues must be defined")}function rd(r,t,e,n){if(typeof r.setBigUint64=="function")return r.setBigUint64(t,e,n);let s=BigInt(32),o=BigInt(4294967295),i=Number(e>>s&o),a=Number(e&o),c=n?4:0,l=n?0:4;r.setUint32(t+c,i,n),r.setUint32(t+l,a,n)}var Lc=(r,t,e)=>r&t^~r&e,Cc=(r,t,e)=>r&t^r&e^t&e,vr=class extends xr{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=Er(this.buffer)}update(t){br(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=Er(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){br(this),_c(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 u=i;u<s;u++)e[u]=0;rd(n,s-8,BigInt(this.length*8),o),this.process(n,0);let a=Er(t),c=this.outputLen;if(c%4)throw new Error("_sha2: outputLen should be aligned to 32bit");let l=c/4,f=this.get();if(l>f.length)throw new Error("_sha2: outputLen bigger than state");for(let u=0;u<l;u++)a.setUint32(4*u,f[u],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 Hn=BigInt(4294967295),jo=BigInt(32);function Uc(r,t=!1){return t?{h:Number(r&Hn),l:Number(r>>jo&Hn)}:{h:Number(r>>jo&Hn)|0,l:Number(r&Hn)|0}}function nd(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}=Uc(r[s],t);[e[s],n[s]]=[o,i]}return[e,n]}var sd=(r,t)=>BigInt(r>>>0)<<jo|BigInt(t>>>0),od=(r,t,e)=>r>>>e,id=(r,t,e)=>r<<32-e|t>>>e,ad=(r,t,e)=>r>>>e|t<<32-e,cd=(r,t,e)=>r<<32-e|t>>>e,ld=(r,t,e)=>r<<64-e|t>>>e-32,ud=(r,t,e)=>r>>>e-32|t<<64-e,fd=(r,t)=>t,hd=(r,t)=>r,dd=(r,t,e)=>r<<e|t>>>32-e,pd=(r,t,e)=>t<<e|r>>>32-e,gd=(r,t,e)=>t<<e-32|r>>>64-e,md=(r,t,e)=>r<<e-32|t>>>64-e;function yd(r,t,e,n){let s=(t>>>0)+(n>>>0);return{h:r+e+(s/2**32|0)|0,l:s|0}}var wd=(r,t,e)=>(r>>>0)+(t>>>0)+(e>>>0),bd=(r,t,e,n)=>t+e+n+(r/2**32|0)|0,xd=(r,t,e,n)=>(r>>>0)+(t>>>0)+(e>>>0)+(n>>>0),Ed=(r,t,e,n,s)=>t+e+n+s+(r/2**32|0)|0,vd=(r,t,e,n,s)=>(r>>>0)+(t>>>0)+(e>>>0)+(n>>>0)+(s>>>0),Bd=(r,t,e,n,s,o)=>t+e+n+s+o+(r/2**32|0)|0;var Ad={fromBig:Uc,split:nd,toBig:sd,shrSH:od,shrSL:id,rotrSH:ad,rotrSL:cd,rotrBH:ld,rotrBL:ud,rotr32H:fd,rotr32L:hd,rotlSH:dd,rotlSL:pd,rotlBH:gd,rotlBL:md,add:yd,add3L:wd,add3H:bd,add4L:xd,add4H:Ed,add5H:Bd,add5L:vd},G=Ad;var[Sd,kd]=G.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))),De=new Uint32Array(80),Ve=new Uint32Array(80),Wo=class extends vr{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:f,Fh:u,Fl:d,Gh:p,Gl:y,Hh:m,Hl:h}=this;return[t,e,n,s,o,i,a,c,l,f,u,d,p,y,m,h]}set(t,e,n,s,o,i,a,c,l,f,u,d,p,y,m,h){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=f|0,this.Fh=u|0,this.Fl=d|0,this.Gh=p|0,this.Gl=y|0,this.Hh=m|0,this.Hl=h|0}process(t,e){for(let g=0;g<16;g++,e+=4)De[g]=t.getUint32(e),Ve[g]=t.getUint32(e+=4);for(let g=16;g<80;g++){let A=De[g-15]|0,L=Ve[g-15]|0,N=G.rotrSH(A,L,1)^G.rotrSH(A,L,8)^G.shrSH(A,L,7),k=G.rotrSL(A,L,1)^G.rotrSL(A,L,8)^G.shrSL(A,L,7),R=De[g-2]|0,I=Ve[g-2]|0,O=G.rotrSH(R,I,19)^G.rotrBH(R,I,61)^G.shrSH(R,I,6),C=G.rotrSL(R,I,19)^G.rotrBL(R,I,61)^G.shrSL(R,I,6),V=G.add4L(k,C,Ve[g-7],Ve[g-16]),K=G.add4H(V,N,O,De[g-7],De[g-16]);De[g]=K|0,Ve[g]=V|0}let{Ah:n,Al:s,Bh:o,Bl:i,Ch:a,Cl:c,Dh:l,Dl:f,Eh:u,El:d,Fh:p,Fl:y,Gh:m,Gl:h,Hh:w,Hl:x}=this;for(let g=0;g<80;g++){let A=G.rotrSH(u,d,14)^G.rotrSH(u,d,18)^G.rotrBH(u,d,41),L=G.rotrSL(u,d,14)^G.rotrSL(u,d,18)^G.rotrBL(u,d,41),N=u&p^~u&m,k=d&y^~d&h,R=G.add5L(x,L,k,kd[g],Ve[g]),I=G.add5H(R,w,A,N,Sd[g],De[g]),O=R|0,C=G.rotrSH(n,s,28)^G.rotrBH(n,s,34)^G.rotrBH(n,s,39),V=G.rotrSL(n,s,28)^G.rotrBL(n,s,34)^G.rotrBL(n,s,39),K=n&o^n&a^o&a,S=s&i^s&c^i&c;w=m|0,x=h|0,m=p|0,h=y|0,p=u|0,y=d|0,{h:u,l:d}=G.add(l|0,f|0,I|0,O|0),l=a|0,f=c|0,a=o|0,c=i|0,o=n|0,i=s|0;let _=G.add3L(O,V,S);n=G.add3H(_,I,C,K),s=_|0}({h:n,l:s}=G.add(this.Ah|0,this.Al|0,n|0,s|0)),{h:o,l:i}=G.add(this.Bh|0,this.Bl|0,o|0,i|0),{h:a,l:c}=G.add(this.Ch|0,this.Cl|0,a|0,c|0),{h:l,l:f}=G.add(this.Dh|0,this.Dl|0,l|0,f|0),{h:u,l:d}=G.add(this.Eh|0,this.El|0,u|0,d|0),{h:p,l:y}=G.add(this.Fh|0,this.Fl|0,p|0,y|0),{h:m,l:h}=G.add(this.Gh|0,this.Gl|0,m|0,h|0),{h:w,l:x}=G.add(this.Hh|0,this.Hl|0,w|0,x|0),this.set(n,s,o,i,a,c,l,f,u,d,p,y,m,h,w,x)}roundClean(){De.fill(0),Ve.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=Vn(()=>new Wo);var Mn={};mt(Mn,{aInRange:()=>St,abool:()=>Zt,abytes:()=>Br,bitGet:()=>Ld,bitLen:()=>Qo,bitMask:()=>tn,bitSet:()=>Cd,bytesToHex:()=>we,bytesToNumberBE:()=>be,bytesToNumberLE:()=>Xt,concatBytes:()=>Ee,createHmacDrbg:()=>ti,ensureBytes:()=>nt,equalBytes:()=>Nd,hexToBytes:()=>tr,hexToNumber:()=>Jo,inRange:()=>Qr,isBytes:()=>He,memoized:()=>er,notImplemented:()=>Pd,numberToBytesBE:()=>Oe,numberToBytesLE:()=>xe,numberToHexUnpadded:()=>Qe,numberToVarBytesBE:()=>Rd,utf8ToBytes:()=>Td,validateObject:()=>qt});var Xo=BigInt(0),On=BigInt(1),Id=BigInt(2);function He(r){return r instanceof Uint8Array||r!=null&&typeof r=="object"&&r.constructor.name==="Uint8Array"}function Br(r){if(!He(r))throw new Error("Uint8Array expected")}function Zt(r,t){if(typeof t!="boolean")throw new Error(`${r} must be valid boolean, got "${t}".`)}var _d=Array.from({length:256},(r,t)=>t.toString(16).padStart(2,"0"));function we(r){Br(r);let t="";for(let e=0;e<r.length;e++)t+=_d[r[e]];return t}function Qe(r){let t=r.toString(16);return t.length&1?`0${t}`:t}function Jo(r){if(typeof r!="string")throw new Error("hex string expected, got "+typeof r);return BigInt(r===""?"0":`0x${r}`)}var ye={_0:48,_9:57,_A:65,_F:70,_a:97,_f:102};function Pc(r){if(r>=ye._0&&r<=ye._9)return r-ye._0;if(r>=ye._A&&r<=ye._F)return r-(ye._A-10);if(r>=ye._a&&r<=ye._f)return r-(ye._a-10)}function tr(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=Pc(r.charCodeAt(o)),a=Pc(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 be(r){return Jo(we(r))}function Xt(r){return Br(r),Jo(we(Uint8Array.from(r).reverse()))}function Oe(r,t){return tr(r.toString(16).padStart(t*2,"0"))}function xe(r,t){return Oe(r,t).reverse()}function Rd(r){return tr(Qe(r))}function nt(r,t,e){let n;if(typeof t=="string")try{n=tr(t)}catch(o){throw new Error(`${r} must be valid hex string, got "${t}". Cause: ${o}`)}else if(He(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 Ee(...r){let t=0;for(let n=0;n<r.length;n++){let s=r[n];Br(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 Nd(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 Td(r){if(typeof r!="string")throw new Error(`utf8ToBytes expected string, got ${typeof r}`);return new Uint8Array(new TextEncoder().encode(r))}var Yo=r=>typeof r=="bigint"&&Xo<=r;function Qr(r,t,e){return Yo(r)&&Yo(t)&&Yo(e)&&t<=r&&r<e}function St(r,t,e,n){if(!Qr(t,e,n))throw new Error(`expected valid ${r}: ${e} <= n < ${n}, got ${typeof t} ${t}`)}function Qo(r){let t;for(t=0;r>Xo;r>>=On,t+=1);return t}function Ld(r,t){return r>>BigInt(t)&On}function Cd(r,t,e){return r|(e?On:Xo)<<BigInt(t)}var tn=r=>(Id<<BigInt(r-1))-On,Zo=r=>new Uint8Array(r),Dc=r=>Uint8Array.from(r);function ti(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=Zo(r),s=Zo(r),o=0,i=()=>{n.fill(1),s.fill(0),o=0},a=(...u)=>e(s,n,...u),c=(u=Zo())=>{s=a(Dc([0]),u),n=a(),u.length!==0&&(s=a(Dc([1]),u),n=a())},l=()=>{if(o++>=1e3)throw new Error("drbg: tried 1000 values");let u=0,d=[];for(;u<t;){n=a();let p=n.slice();d.push(p),u+=n.length}return Ee(...d)};return(u,d)=>{i(),c(u);let p;for(;!(p=d(l()));)c();return i(),p}}var Ud={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"||He(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 qt(r,t,e={}){let n=(s,o,i)=>{let a=Ud[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 Pd=()=>{throw new Error("not implemented")};function er(r){let t=new WeakMap;return(e,...n)=>{let s=t.get(e);if(s!==void 0)return s;let o=r(e,...n);return t.set(e,o),o}}var bt=BigInt(0),it=BigInt(1),rr=BigInt(2),Dd=BigInt(3),ei=BigInt(4),Vc=BigInt(5),Hc=BigInt(8),Vd=BigInt(9),Hd=BigInt(16);function Z(r,t){let e=r%t;return e>=bt?e:t+e}function ri(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 st(r,t,e){let n=r;for(;t-- >bt;)n*=n,n%=e;return n}function Kn(r,t){if(r===bt||t<=bt)throw new Error(`invert: expected positive integers, got n=${r} mod=${t}`);let e=Z(r,t),n=t,s=bt,o=it,i=it,a=bt;for(;e!==bt;){let l=n/e,f=n%e,u=s-i*l,d=o-a*l;n=e,e=f,s=i,o=a,i=u,a=d}if(n!==it)throw new Error("invert: does not exist");return Z(s,t)}function Od(r){let t=(r-it)/rr,e,n,s;for(e=r-it,n=0;e%rr===bt;e/=rr,n++);for(s=rr;s<r&&ri(s,t,r)!==r-it;s++);if(n===1){let i=(r+it)/ei;return function(c,l){let f=c.pow(l,i);if(!c.eql(c.sqr(f),l))throw new Error("Cannot find square root");return f}}let o=(e+it)/rr;return function(a,c){if(a.pow(c,t)===a.neg(a.ONE))throw new Error("Cannot find square root");let l=n,f=a.pow(a.mul(a.ONE,s),e),u=a.pow(c,o),d=a.pow(c,e);for(;!a.eql(d,a.ONE);){if(a.eql(d,a.ZERO))return a.ZERO;let p=1;for(let m=a.sqr(d);p<l&&!a.eql(m,a.ONE);p++)m=a.sqr(m);let y=a.pow(f,it<<BigInt(l-p-1));f=a.sqr(y),u=a.mul(u,y),d=a.mul(d,f),l=p}return u}}function Md(r){if(r%ei===Dd){let t=(r+it)/ei;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%Hc===Vc){let t=(r-Vc)/Hc;return function(n,s){let o=n.mul(s,rr),i=n.pow(o,t),a=n.mul(s,i),c=n.mul(n.mul(a,rr),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%Hd,Od(r)}var Oc=(r,t)=>(Z(r,t)&it)===it,Kd=["create","isValid","is0","neg","inv","sqrt","sqr","eql","add","sub","mul","pow","div","addN","subN","mulN","sqrN"];function ni(r){let t={ORDER:"bigint",MASK:"bigint",BYTES:"isSafeInteger",BITS:"isSafeInteger"},e=Kd.reduce((n,s)=>(n[s]="function",n),t);return qt(r,e)}function Fd(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 $d(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 si(r,t){let e=t!==void 0?t:r.toString(2).length,n=Math.ceil(e/8);return{nBitLength:e,nByteLength:n}}function Me(r,t,e=!1,n={}){if(r<=bt)throw new Error(`Expected Field ORDER > 0, got ${r}`);let{nBitLength:s,nByteLength:o}=si(r,t);if(o>2048)throw new Error("Field lengths over 2048 bytes are not supported");let i=Md(r),a=Object.freeze({ORDER:r,BITS:s,BYTES:o,MASK:tn(s),ZERO:bt,ONE:it,create:c=>Z(c,r),isValid:c=>{if(typeof c!="bigint")throw new Error(`Invalid field element: expected bigint, got ${typeof c}`);return bt<=c&&c<r},is0:c=>c===bt,isOdd:c=>(c&it)===it,neg:c=>Z(-c,r),eql:(c,l)=>c===l,sqr:c=>Z(c*c,r),add:(c,l)=>Z(c+l,r),sub:(c,l)=>Z(c-l,r),mul:(c,l)=>Z(c*l,r),pow:(c,l)=>Fd(a,c,l),div:(c,l)=>Z(c*Kn(l,r),r),sqrN:c=>c*c,addN:(c,l)=>c+l,subN:(c,l)=>c-l,mulN:(c,l)=>c*l,inv:c=>Kn(c,r),sqrt:n.sqrt||(c=>i(a,c)),invertBatch:c=>$d(a,c),cmov:(c,l,f)=>f?l:c,toBytes:c=>e?xe(c,o):Oe(c,o),fromBytes:c=>{if(c.length!==o)throw new Error(`Fp.fromBytes: expected ${o}, got ${c.length}`);return e?Xt(c):be(c)}});return Object.freeze(a)}function Mc(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 oi(r){let t=Mc(r);return t+Math.ceil(t/2)}function Kc(r,t,e=!1){let n=r.length,s=Mc(t),o=oi(t);if(n<16||n<o||n>1024)throw new Error(`expected ${o}-1024 bytes of input, got ${n}`);let i=e?be(r):Xt(r),a=Z(i,t-it)+it;return e?xe(a,s):Oe(a,s)}var Gd=BigInt(0),ii=BigInt(1),ai=new WeakMap,Fc=new WeakMap;function Fn(r,t){let e=(o,i)=>{let a=i.negate();return o?a:i},n=o=>{if(!Number.isSafeInteger(o)||o<=0||o>t)throw new Error(`Wrong window size=${o}, should be [1..${t}]`)},s=o=>{n(o);let i=Math.ceil(t/o)+1,a=2**(o-1);return{windows:i,windowSize:a}};return{constTimeNegate:e,unsafeLadder(o,i){let a=r.ZERO,c=o;for(;i>Gd;)i&ii&&(a=a.add(c)),c=c.double(),i>>=ii;return a},precomputeWindow(o,i){let{windows:a,windowSize:c}=s(i),l=[],f=o,u=f;for(let d=0;d<a;d++){u=f,l.push(u);for(let p=1;p<c;p++)u=u.add(f),l.push(u);f=u.double()}return l},wNAF(o,i,a){let{windows:c,windowSize:l}=s(o),f=r.ZERO,u=r.BASE,d=BigInt(2**o-1),p=2**o,y=BigInt(o);for(let m=0;m<c;m++){let h=m*l,w=Number(a&d);a>>=y,w>l&&(w-=p,a+=ii);let x=h,g=h+Math.abs(w)-1,A=m%2!==0,L=w<0;w===0?u=u.add(e(A,i[x])):f=f.add(e(L,i[g]))}return{p:f,f:u}},wNAFCached(o,i,a){let c=Fc.get(o)||1,l=ai.get(o);return l||(l=this.precomputeWindow(o,c),c!==1&&ai.set(o,a(l))),this.wNAF(c,l,i)},setWindowSize(o,i){n(i),Fc.set(o,i),ai.delete(o)}}}function $n(r,t,e,n){if(!Array.isArray(e)||!Array.isArray(n)||n.length!==e.length)throw new Error("arrays of points and scalars must have equal length");n.forEach((f,u)=>{if(!t.isValid(f))throw new Error(`wrong scalar at index ${u}`)}),e.forEach((f,u)=>{if(!(f instanceof r))throw new Error(`wrong point at index ${u}`)});let s=Qo(BigInt(e.length)),o=s>12?s-3:s>4?s-2:s?2:1,i=(1<<o)-1,a=new Array(i+1).fill(r.ZERO),c=Math.floor((t.BITS-1)/o)*o,l=r.ZERO;for(let f=c;f>=0;f-=o){a.fill(r.ZERO);for(let d=0;d<n.length;d++){let p=n[d],y=Number(p>>BigInt(f)&BigInt(i));a[y]=a[y].add(e[d])}let u=r.ZERO;for(let d=a.length-1,p=r.ZERO;d>0;d--)p=p.add(a[d]),u=u.add(p);if(l=l.add(u),f!==0)for(let d=0;d<o;d++)l=l.double()}return l}function en(r){return ni(r.Fp),qt(r,{n:"bigint",h:"bigint",Gx:"field",Gy:"field"},{nBitLength:"isSafeInteger",nByteLength:"isSafeInteger"}),Object.freeze({...si(r.n,r.nBitLength),...r,p:r.Fp.ORDER})}var Jt=BigInt(0),Ht=BigInt(1),qn=BigInt(2),zd=BigInt(8),jd={zip215:!0};function Wd(r){let t=en(r);return qt(r,{hash:"function",a:"bigint",d:"bigint",randomBytes:"function"},{adjustScalarBytes:"function",domain:"function",uvRatio:"function",mapToCurve:"function"}),Object.freeze({...t})}function $c(r){let t=Wd(r),{Fp:e,n,prehash:s,hash:o,randomBytes:i,nByteLength:a,h:c}=t,l=qn<<BigInt(a*8)-Ht,f=e.create,u=Me(t.n,t.nBitLength),d=t.uvRatio||((E,b)=>{try{return{isValid:!0,value:e.sqrt(E*e.inv(b))}}catch{return{isValid:!1,value:Jt}}}),p=t.adjustScalarBytes||(E=>E),y=t.domain||((E,b,B)=>{if(Zt("phflag",B),b.length||B)throw new Error("Contexts/pre-hash are not supported");return E});function m(E,b){St("coordinate "+E,b,Jt,l)}function h(E){if(!(E instanceof g))throw new Error("ExtendedPoint expected")}let w=er((E,b)=>{let{ex:B,ey:v,ez:T}=E,U=E.is0();b==null&&(b=U?zd:e.inv(T));let H=f(B*b),F=f(v*b),q=f(T*b);if(U)return{x:Jt,y:Ht};if(q!==Ht)throw new Error("invZ was invalid");return{x:H,y:F}}),x=er(E=>{let{a:b,d:B}=t;if(E.is0())throw new Error("bad point: ZERO");let{ex:v,ey:T,ez:U,et:H}=E,F=f(v*v),q=f(T*T),z=f(U*U),W=f(z*z),et=f(F*b),rt=f(z*f(et+q)),ot=f(W+f(B*f(F*q)));if(rt!==ot)throw new Error("bad point: equation left != right (1)");let Ct=f(v*T),gt=f(U*H);if(Ct!==gt)throw new Error("bad point: equation left != right (2)");return!0});class g{constructor(b,B,v,T){this.ex=b,this.ey=B,this.ez=v,this.et=T,m("x",b),m("y",B),m("z",v),m("t",T),Object.freeze(this)}get x(){return this.toAffine().x}get y(){return this.toAffine().y}static fromAffine(b){if(b instanceof g)throw new Error("extended point not allowed");let{x:B,y:v}=b||{};return m("x",B),m("y",v),new g(B,v,Ht,f(B*v))}static normalizeZ(b){let B=e.invertBatch(b.map(v=>v.ez));return b.map((v,T)=>v.toAffine(B[T])).map(g.fromAffine)}static msm(b,B){return $n(g,u,b,B)}_setWindowSize(b){N.setWindowSize(this,b)}assertValidity(){x(this)}equals(b){h(b);let{ex:B,ey:v,ez:T}=this,{ex:U,ey:H,ez:F}=b,q=f(B*F),z=f(U*T),W=f(v*F),et=f(H*T);return q===z&&W===et}is0(){return this.equals(g.ZERO)}negate(){return new g(f(-this.ex),this.ey,this.ez,f(-this.et))}double(){let{a:b}=t,{ex:B,ey:v,ez:T}=this,U=f(B*B),H=f(v*v),F=f(qn*f(T*T)),q=f(b*U),z=B+v,W=f(f(z*z)-U-H),et=q+H,rt=et-F,ot=q-H,Ct=f(W*rt),gt=f(et*ot),Vt=f(W*ot),de=f(rt*et);return new g(Ct,gt,de,Vt)}add(b){h(b);let{a:B,d:v}=t,{ex:T,ey:U,ez:H,et:F}=this,{ex:q,ey:z,ez:W,et}=b;if(B===BigInt(-1)){let Ja=f((U-T)*(z+q)),Qa=f((U+T)*(z-q)),Eo=f(Qa-Ja);if(Eo===Jt)return this.double();let tc=f(H*qn*et),ec=f(F*qn*W),rc=ec+tc,nc=Qa+Ja,sc=ec-tc,Df=f(rc*Eo),Vf=f(nc*sc),Hf=f(rc*sc),Of=f(Eo*nc);return new g(Df,Vf,Of,Hf)}let rt=f(T*q),ot=f(U*z),Ct=f(F*v*et),gt=f(H*W),Vt=f((T+U)*(q+z)-rt-ot),de=gt-Ct,jr=gt+Ct,Wr=f(ot-B*rt),Lf=f(Vt*de),Cf=f(jr*Wr),Uf=f(Vt*Wr),Pf=f(de*jr);return new g(Lf,Cf,Pf,Uf)}subtract(b){return this.add(b.negate())}wNAF(b){return N.wNAFCached(this,b,g.normalizeZ)}multiply(b){let B=b;St("scalar",B,Ht,n);let{p:v,f:T}=this.wNAF(B);return g.normalizeZ([v,T])[0]}multiplyUnsafe(b){let B=b;return St("scalar",B,Jt,n),B===Jt?L:this.equals(L)||B===Ht?this:this.equals(A)?this.wNAF(B).p:N.unsafeLadder(this,B)}isSmallOrder(){return this.multiplyUnsafe(c).is0()}isTorsionFree(){return N.unsafeLadder(this,n).is0()}toAffine(b){return w(this,b)}clearCofactor(){let{h:b}=t;return b===Ht?this:this.multiplyUnsafe(b)}static fromHex(b,B=!1){let{d:v,a:T}=t,U=e.BYTES;b=nt("pointHex",b,U),Zt("zip215",B);let H=b.slice(),F=b[U-1];H[U-1]=F&-129;let q=Xt(H),z=B?l:e.ORDER;St("pointHex.y",q,Jt,z);let W=f(q*q),et=f(W-Ht),rt=f(v*W-T),{isValid:ot,value:Ct}=d(et,rt);if(!ot)throw new Error("Point.fromHex: invalid y coordinate");let gt=(Ct&Ht)===Ht,Vt=(F&128)!==0;if(!B&&Ct===Jt&&Vt)throw new Error("Point.fromHex: x=0 and x_0=1");return Vt!==gt&&(Ct=f(-Ct)),g.fromAffine({x:Ct,y:q})}static fromPrivateKey(b){return I(b).point}toRawBytes(){let{x:b,y:B}=this.toAffine(),v=xe(B,e.BYTES);return v[v.length-1]|=b&Ht?128:0,v}toHex(){return we(this.toRawBytes())}}g.BASE=new g(t.Gx,t.Gy,Ht,f(t.Gx*t.Gy)),g.ZERO=new g(Jt,Ht,Ht,Jt);let{BASE:A,ZERO:L}=g,N=Fn(g,a*8);function k(E){return Z(E,n)}function R(E){return k(Xt(E))}function I(E){let b=a;E=nt("private key",E,b);let B=nt("hashed private key",o(E),2*b),v=p(B.slice(0,b)),T=B.slice(b,2*b),U=R(v),H=A.multiply(U),F=H.toRawBytes();return{head:v,prefix:T,scalar:U,point:H,pointBytes:F}}function O(E){return I(E).pointBytes}function C(E=new Uint8Array,...b){let B=Ee(...b);return R(o(y(B,nt("context",E),!!s)))}function V(E,b,B={}){E=nt("message",E),s&&(E=s(E));let{prefix:v,scalar:T,pointBytes:U}=I(b),H=C(B.context,v,E),F=A.multiply(H).toRawBytes(),q=C(B.context,F,U,E),z=k(H+q*T);St("signature.s",z,Jt,n);let W=Ee(F,xe(z,e.BYTES));return nt("result",W,a*2)}let K=jd;function S(E,b,B,v=K){let{context:T,zip215:U}=v,H=e.BYTES;E=nt("signature",E,2*H),b=nt("message",b),U!==void 0&&Zt("zip215",U),s&&(b=s(b));let F=Xt(E.slice(H,2*H)),q,z,W;try{q=g.fromHex(B,U),z=g.fromHex(E.slice(0,H),U),W=A.multiplyUnsafe(F)}catch{return!1}if(!U&&q.isSmallOrder())return!1;let et=C(T,z.toRawBytes(),q.toRawBytes(),b);return z.add(q.multiplyUnsafe(et)).subtract(W).clearCofactor().equals(g.ZERO)}return A._setWindowSize(8),{CURVE:t,getPublicKey:O,sign:V,verify:S,ExtendedPoint:g,utils:{getExtendedPublicKey:I,randomPrivateKey:()=>i(e.BYTES),precompute(E=8,b=g.BASE){return b._setWindowSize(E),b.multiply(BigInt(3)),b}}}}var Ar=BigInt(0),ci=BigInt(1);function Yd(r){return qt(r,{a:"bigint"},{montgomeryBits:"isSafeInteger",nByteLength:"isSafeInteger",adjustScalarBytes:"function",domain:"function",powPminus2:"function",Gu:"bigint"}),Object.freeze({...r})}function qc(r){let t=Yd(r),{P:e}=t,n=x=>Z(x,e),s=t.montgomeryBits,o=Math.ceil(s/8),i=t.nByteLength,a=t.adjustScalarBytes||(x=>x),c=t.powPminus2||(x=>ri(x,e-BigInt(2),e));function l(x,g,A){let L=n(x*(g-A));return g=n(g-L),A=n(A+L),[g,A]}let f=(t.a-BigInt(2))/BigInt(4);function u(x,g){St("u",x,Ar,e),St("scalar",g,Ar,e);let A=g,L=x,N=ci,k=Ar,R=x,I=ci,O=Ar,C;for(let K=BigInt(s-1);K>=Ar;K--){let S=A>>K&ci;O^=S,C=l(O,N,R),N=C[0],R=C[1],C=l(O,k,I),k=C[0],I=C[1],O=S;let _=N+k,E=n(_*_),b=N-k,B=n(b*b),v=E-B,T=R+I,U=R-I,H=n(U*_),F=n(T*b),q=H+F,z=H-F;R=n(q*q),I=n(L*n(z*z)),N=n(E*B),k=n(v*(E+n(f*v)))}C=l(O,N,R),N=C[0],R=C[1],C=l(O,k,I),k=C[0],I=C[1];let V=c(k);return n(N*V)}function d(x){return xe(n(x),o)}function p(x){let g=nt("u coordinate",x,o);return i===32&&(g[31]&=127),Xt(g)}function y(x){let g=nt("scalar",x),A=g.length;if(A!==o&&A!==i)throw new Error(`Expected ${o} or ${i} bytes, got ${A}`);return Xt(a(g))}function m(x,g){let A=p(g),L=y(x),N=u(A,L);if(N===Ar)throw new Error("Invalid private or public key received");return d(N)}let h=d(t.Gu);function w(x){return m(x,h)}return{scalarMult:m,scalarMultBase:w,getSharedSecret:(x,g)=>m(x,g),getPublicKey:x=>w(x),utils:{randomPrivateKey:()=>t.randomBytes(t.nByteLength)},GuBytes:h}}var rn=BigInt("57896044618658097711785492504343953926634992332820282019728792003956564819949"),Gc=BigInt("19681161376707505956807079304988542015446066515923890162744021073123829784752"),wy=BigInt(0),Zd=BigInt(1),zc=BigInt(2),Xd=BigInt(3),Jd=BigInt(5),Qd=BigInt(8);function jc(r){let t=BigInt(10),e=BigInt(20),n=BigInt(40),s=BigInt(80),o=rn,a=r*r%o*r%o,c=st(a,zc,o)*a%o,l=st(c,Zd,o)*r%o,f=st(l,Jd,o)*l%o,u=st(f,t,o)*f%o,d=st(u,e,o)*u%o,p=st(d,n,o)*d%o,y=st(p,s,o)*p%o,m=st(y,s,o)*p%o,h=st(m,t,o)*f%o;return{pow_p_5_8:st(h,zc,o)*r%o,b2:a}}function Wc(r){return r[0]&=248,r[31]&=127,r[31]|=64,r}function tp(r,t){let e=rn,n=Z(t*t*t,e),s=Z(n*n*t,e),o=jc(r*s).pow_p_5_8,i=Z(r*n*o,e),a=Z(t*i*i,e),c=i,l=Z(i*Gc,e),f=a===r,u=a===Z(-r,e),d=a===Z(-r*Gc,e);return f&&(i=c),(u||d)&&(i=l),Oc(i,e)&&(i=Z(-i,e)),{isValid:f||u,value:i}}var ep=Me(rn,void 0,!0),rp={a:BigInt(-1),d:BigInt("37095705934669439343138083508754565189542113879843219016388785533085940283555"),Fp:ep,n:BigInt("7237005577332262213973186563042994240857116359379907606001950938285454250989"),h:Qd,Gx:BigInt("15112221349535400772501151409588531511454012693041857206046113283949847762202"),Gy:BigInt("46316835694926478169428394003475163141307993866256225615783033603165251855960"),hash:Jr,randomBytes:Je,adjustScalarBytes:Wc,uvRatio:tp},Sr=$c(rp);var nn=qc({P:rn,a:BigInt(486662),montgomeryBits:255,nByteLength:32,Gu:BigInt(9),powPminus2:r=>{let t=rn,{pow_p_5_8:e,b2:n}=jc(r);return Z(st(e,Xd,t)*n,t)},adjustScalarBytes:Wc,randomBytes:Je});var kr=32,ve=64,Gn=32;function Yc(){let r=Sr.utils.randomPrivateKey(),t=Sr.getPublicKey(r);return{privateKey:Qc(r,t),publicKey:t}}function Zc(r){if(r.length!==Gn)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=Sr.getPublicKey(t);return{privateKey:Qc(t,e),publicKey:e}}function Xc(r,t){let e=r.subarray(0,Gn);return Sr.sign(t instanceof Uint8Array?t:t.subarray(),e)}function Jc(r,t,e){return Sr.verify(t,e instanceof Uint8Array?e:e.subarray(),r)}function Qc(r,t){let e=new Uint8Array(ve);for(let n=0;n<Gn;n++)e[n]=r[n],e[Gn+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 li={alg:"A128GCM",ext:!0,k:"scm9jmO_4BJAgdwWGVulLg",key_ops:["encrypt","decrypt"],kty:"oct"};function tl(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(u,d){let p=a.getRandomValues(new Uint8Array(o)),y=a.getRandomValues(new Uint8Array(n)),m={name:t,iv:y};typeof d=="string"&&(d=Y(d));let h;if(d.length===0){h=await a.subtle.importKey("jwk",li,{name:"AES-GCM"},!0,["encrypt"]);try{let x={name:"PBKDF2",salt:p,iterations:i,hash:{name:s}},g=await a.subtle.importKey("raw",d,{name:"PBKDF2"},!1,["deriveKey"]);h=await a.subtle.deriveKey(x,g,{name:t,length:e},!0,["encrypt"])}catch{h=await a.subtle.importKey("jwk",li,{name:"AES-GCM"},!0,["encrypt"])}}else{let x={name:"PBKDF2",salt:p,iterations:i,hash:{name:s}},g=await a.subtle.importKey("raw",d,{name:"PBKDF2"},!1,["deriveKey"]);h=await a.subtle.deriveKey(x,g,{name:t,length:e},!0,["encrypt"])}let w=await a.subtle.encrypt(m,h,u);return Et([p,m.iv,new Uint8Array(w)])}async function l(u,d){let p=u.subarray(0,o),y=u.subarray(o,o+n),m=u.subarray(o+n),h={name:t,iv:y};typeof d=="string"&&(d=Y(d));let w;if(d.length===0)try{let g={name:"PBKDF2",salt:p,iterations:i,hash:{name:s}},A=await a.subtle.importKey("raw",d,{name:"PBKDF2"},!1,["deriveKey"]);w=await a.subtle.deriveKey(g,A,{name:t,length:e},!0,["decrypt"])}catch{w=await a.subtle.importKey("jwk",li,{name:"AES-GCM"},!0,["decrypt"])}else{let g={name:"PBKDF2",salt:p,iterations:i,hash:{name:s}},A=await a.subtle.importKey("raw",d,{name:"PBKDF2"},!1,["deriveKey"]);w=await a.subtle.deriveKey(g,A,{name:t,length:e},!0,["decrypt"])}let x=await a.subtle.decrypt(h,w,m);return new Uint8Array(x)}return{encrypt:c,decrypt:l}}async function Ir(r,t){let n=await tl().encrypt(r,t);return Oo.encode(n)}var op=Math.pow(2,7),ip=Math.pow(2,14),ap=Math.pow(2,21),ui=Math.pow(2,28),fi=Math.pow(2,35),hi=Math.pow(2,42),di=Math.pow(2,49),J=128,Rt=127;function dt(r){if(r<op)return 1;if(r<ip)return 2;if(r<ap)return 3;if(r<ui)return 4;if(r<fi)return 5;if(r<hi)return 6;if(r<di)return 7;if(Number.MAX_SAFE_INTEGER!=null&&r>Number.MAX_SAFE_INTEGER)throw new RangeError("Could not encode varint");return 8}function pi(r,t,e=0){switch(dt(r)){case 8:t[e++]=r&255|J,r/=128;case 7:t[e++]=r&255|J,r/=128;case 6:t[e++]=r&255|J,r/=128;case 5:t[e++]=r&255|J,r/=128;case 4:t[e++]=r&255|J,r>>>=7;case 3:t[e++]=r&255|J,r>>>=7;case 2:t[e++]=r&255|J,r>>>=7;case 1:{t[e++]=r&255,r>>>=7;break}default:throw new Error("unreachable")}return t}function cp(r,t,e=0){switch(dt(r)){case 8:t.set(e++,r&255|J),r/=128;case 7:t.set(e++,r&255|J),r/=128;case 6:t.set(e++,r&255|J),r/=128;case 5:t.set(e++,r&255|J),r/=128;case 4:t.set(e++,r&255|J),r>>>=7;case 3:t.set(e++,r&255|J),r>>>=7;case 2:t.set(e++,r&255|J),r>>>=7;case 1:{t.set(e++,r&255),r>>>=7;break}default:throw new Error("unreachable")}return t}function gi(r,t){let e=r[t],n=0;if(n+=e&Rt,e<J||(e=r[t+1],n+=(e&Rt)<<7,e<J)||(e=r[t+2],n+=(e&Rt)<<14,e<J)||(e=r[t+3],n+=(e&Rt)<<21,e<J)||(e=r[t+4],n+=(e&Rt)*ui,e<J)||(e=r[t+5],n+=(e&Rt)*fi,e<J)||(e=r[t+6],n+=(e&Rt)*hi,e<J)||(e=r[t+7],n+=(e&Rt)*di,e<J))return n;throw new RangeError("Could not decode varint")}function lp(r,t){let e=r.get(t),n=0;if(n+=e&Rt,e<J||(e=r.get(t+1),n+=(e&Rt)<<7,e<J)||(e=r.get(t+2),n+=(e&Rt)<<14,e<J)||(e=r.get(t+3),n+=(e&Rt)<<21,e<J)||(e=r.get(t+4),n+=(e&Rt)*ui,e<J)||(e=r.get(t+5),n+=(e&Rt)*fi,e<J)||(e=r.get(t+6),n+=(e&Rt)*hi,e<J)||(e=r.get(t+7),n+=(e&Rt)*di,e<J))return n;throw new RangeError("Could not decode varint")}function ie(r,t,e=0){return t==null&&(t=wt(dt(r))),t instanceof Uint8Array?pi(r,t,e):cp(r,t,e)}function Qt(r,t=0){return r instanceof Uint8Array?gi(r,t):lp(r,t)}var mi=new Float32Array([-0]),Ke=new Uint8Array(mi.buffer);function el(r,t,e){mi[0]=r,t[e]=Ke[0],t[e+1]=Ke[1],t[e+2]=Ke[2],t[e+3]=Ke[3]}function rl(r,t){return Ke[0]=r[t],Ke[1]=r[t+1],Ke[2]=r[t+2],Ke[3]=r[t+3],mi[0]}var yi=new Float64Array([-0]),Nt=new Uint8Array(yi.buffer);function nl(r,t,e){yi[0]=r,t[e]=Nt[0],t[e+1]=Nt[1],t[e+2]=Nt[2],t[e+3]=Nt[3],t[e+4]=Nt[4],t[e+5]=Nt[5],t[e+6]=Nt[6],t[e+7]=Nt[7]}function sl(r,t){return Nt[0]=r[t],Nt[1]=r[t+1],Nt[2]=r[t+2],Nt[3]=r[t+3],Nt[4]=r[t+4],Nt[5]=r[t+5],Nt[6]=r[t+6],Nt[7]=r[t+7],yi[0]}var up=BigInt(Number.MAX_SAFE_INTEGER),fp=BigInt(Number.MIN_SAFE_INTEGER),Kt=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 nr;if(t<up&&t>fp)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>ol&&(s=0n,++n>ol&&(n=0n))),new r(Number(s),Number(n))}static fromNumber(t){if(t===0)return nr;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):nr}},nr=new Kt(0,0);nr.toBigInt=function(){return 0n};nr.zzEncode=nr.zzDecode=function(){return this};nr.length=function(){return 1};var ol=4294967296n;function il(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 al(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 wi(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 te(r,t){return RangeError(`index out of range: ${r.pos} + ${t??1} > ${r.len}`)}function zn(r,t){return(r[t-4]|r[t-3]<<8|r[t-2]<<16|r[t-1]<<24)>>>0}var bi=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,te(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 te(this,4);return zn(this.buf,this.pos+=4)}sfixed32(){if(this.pos+4>this.len)throw te(this,4);return zn(this.buf,this.pos+=4)|0}float(){if(this.pos+4>this.len)throw te(this,4);let t=rl(this.buf,this.pos);return this.pos+=4,t}double(){if(this.pos+8>this.len)throw te(this,4);let t=sl(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 te(this,t);return this.pos+=t,e===n?new Uint8Array(0):this.buf.subarray(e,n)}string(){let t=this.bytes();return al(t,0,t.length)}skip(t){if(typeof t=="number"){if(this.pos+t>this.len)throw te(this,t);this.pos+=t}else do if(this.pos>=this.len)throw te(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 Kt(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 te(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 te(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 te(this,8);let t=zn(this.buf,this.pos+=4),e=zn(this.buf,this.pos+=4);return new Kt(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=gi(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 xi(r){return new bi(r instanceof Uint8Array?r:r.subarray())}function sr(r,t,e){let n=xi(r);return t.decode(n,void 0,e)}function Ei(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 or=class{fn;len;next;val;constructor(t,e,n){this.fn=t,this.len=e,this.next=void 0,this.val=n}};function vi(){}var Ai=class{head;tail;len;next;constructor(t){this.head=t.head,this.tail=t.tail,this.len=t.len,this.next=t.states}},hp=Ei();function dp(r){return globalThis.Buffer!=null?wt(r):hp(r)}var an=class{len;head;tail;states;constructor(){this.len=0,this.head=new or(vi,0,0),this.tail=this.head,this.states=null}_push(t,e,n){return this.tail=this.tail.next=new or(t,e,n),this.len+=e,this}uint32(t){return this.len+=(this.tail=this.tail.next=new Si((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(jn,10,Kt.fromNumber(t)):this.uint32(t)}sint32(t){return this.uint32((t<<1^t>>31)>>>0)}uint64(t){let e=Kt.fromBigInt(t);return this._push(jn,e.length(),e)}uint64Number(t){return this._push(pi,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=Kt.fromBigInt(t).zzEncode();return this._push(jn,e.length(),e)}sint64Number(t){let e=Kt.fromNumber(t).zzEncode();return this._push(jn,e.length(),e)}sint64String(t){return this.sint64(BigInt(t))}bool(t){return this._push(Bi,1,t?1:0)}fixed32(t){return this._push(on,4,t>>>0)}sfixed32(t){return this.fixed32(t)}fixed64(t){let e=Kt.fromBigInt(t);return this._push(on,4,e.lo)._push(on,4,e.hi)}fixed64Number(t){let e=Kt.fromNumber(t);return this._push(on,4,e.lo)._push(on,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(el,4,t)}double(t){return this._push(nl,8,t)}bytes(t){let e=t.length>>>0;return e===0?this._push(Bi,1,0):this.uint32(e)._push(gp,e,t)}string(t){let e=il(t);return e!==0?this.uint32(e)._push(wi,e,t):this._push(Bi,1,0)}fork(){return this.states=new Ai(this),this.head=this.tail=new or(vi,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 or(vi,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=dp(this.len),n=0;for(;t!=null;)t.fn(t.val,e,n),n+=t.len,t=t.next;return e}};function Bi(r,t,e){t[e]=r&255}function pp(r,t,e){for(;r>127;)t[e++]=r&127|128,r>>>=7;t[e]=r}var Si=class extends or{next;constructor(t,e){super(pp,t,e),this.next=void 0}};function jn(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 on(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 gp(r,t,e){t.set(r,e)}globalThis.Buffer!=null&&(an.prototype.bytes=function(r){let t=r.length>>>0;return this.uint32(t),t>0&&this._push(mp,t,r),this},an.prototype.string=function(r){let t=globalThis.Buffer.byteLength(r);return this.uint32(t),t>0&&this._push(yp,t,r),this});function mp(r,t,e){t.set(r,e)}function yp(r,t,e){r.length<40?wi(r,t,e):t.utf8Write!=null?t.utf8Write(r,e):t.set(Y(r),e)}function ki(){return new an}function ir(r,t){let e=ki();return t.encode(r,e,{lengthDelimited:!1}),e.finish()}var _r;(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"})(_r||(_r={}));function Wn(r,t,e,n){return{name:r,type:t,encode:e,decode:n}}function Ii(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 Wn("enum",_r.VARINT,e,n)}function ar(r,t){return Wn("message",_r.LENGTH_DELIMITED,r,t)}var at;(function(r){r.RSA="RSA",r.Ed25519="Ed25519",r.Secp256k1="Secp256k1"})(at||(at={}));var _i;(function(r){r[r.RSA=0]="RSA",r[r.Ed25519=1]="Ed25519",r[r.Secp256k1=2]="Secp256k1"})(_i||(_i={}));(function(r){r.codec=()=>Ii(_i)})(at||(at={}));var ae;(function(r){let t;r.codec=()=>(t==null&&(t=ar((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=>ir(e,r.codec()),r.decode=e=>sr(e,r.codec())})(ae||(ae={}));var ce;(function(r){let t;r.codec=()=>(t==null&&(t=ar((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=>ir(e,r.codec()),r.decode=e=>sr(e,r.codec())})(ce||(ce={}));var cn=class{_key;constructor(t){this._key=Rr(t,kr)}verify(t,e){return Jc(this._key,e,t)}marshal(){return this._key}get bytes(){return ae.encode({Type:at.Ed25519,Data:this.marshal()}).subarray()}equals(t){return ft(this.bytes,t.bytes)}hash(){let t=At.digest(this.bytes);return $t(t)?t.then(({bytes:e})=>e):t.bytes}},cr=class{_key;_publicKey;constructor(t,e){this._key=Rr(t,ve),this._publicKey=Rr(e,kr)}sign(t){return Xc(this._key,t)}get public(){return new cn(this._publicKey)}marshal(){return this._key}get bytes(){return ce.encode({Type:at.Ed25519,Data:this.marshal()}).subarray()}equals(t){return ft(this.bytes,t.bytes)}async hash(){let t=At.digest(this.bytes),e;return $t(t)?{bytes:e}=await t:e=t.bytes,e}async id(){let t=ge.digest(this.public.bytes);return ut.encode(t.bytes).substring(1)}async export(t,e="libp2p-key"){if(e==="libp2p-key")return Ir(this.bytes,t);throw new M(`export format '${e}' is not supported`,"ERR_INVALID_EXPORT_FORMAT")}};function wp(r){if(r.length>ve){r=Rr(r,ve+kr);let n=r.subarray(0,ve),s=r.subarray(ve,r.length);return new cr(n,s)}r=Rr(r,ve);let t=r.subarray(0,ve),e=r.subarray(kr);return new cr(t,e)}function bp(r){return r=Rr(r,kr),new cn(r)}async function xp(){let{privateKey:r,publicKey:t}=Yc();return new cr(r,t)}async function ll(r){let{privateKey:t,publicKey:e}=Zc(r);return new cr(t,e)}function Rr(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=Dn[t];if(e==null)throw new Error(`Unsupported encoding "${t}"`);return e.encoder.encode(r).substring(1)}var Oi={};mt(Oi,{MAX_RSA_KEY_SIZE:()=>bn,RsaPrivateKey:()=>Ur,RsaPublicKey:()=>wn,fromJwk:()=>jp,generateKeyPair:()=>Wp,unmarshalRsaPrivateKey:()=>Vi,unmarshalRsaPublicKey:()=>zp});function lr(r){if(isNaN(r)||r<=0)throw new M("random bytes length must be a Number bigger than 0","ERR_INVALID_LENGTH");return Je(r)}var ze={};mt(ze,{exportToPem:()=>Kp,importFromPem:()=>Fp,jwkToPkcs1:()=>Vp,jwkToPkix:()=>Op,pkcs1ToJwk:()=>Dp,pkixToJwk:()=>Hp});var Zn=class extends xr{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 br(this),this.iHash.update(t),this}digestInto(t){br(this),wr(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()}},Fe=(r,t,e)=>new Zn(r,t).update(e).digest();Fe.create=(r,t)=>new Zn(r,t);function Ep(r,t,e,n){Ze(r);let s=Tc({dkLen:32,asyncTick:10},n),{c:o,dkLen:i,asyncTick:a}=s;if(Pe(o),Pe(i),Pe(a),o<1)throw new Error("PBKDF2: iterations (c) should be >= 1");let c=Yt(t),l=Yt(e),f=new Uint8Array(i),u=Fe.create(r,c),d=u._cloneInto().update(l);return{c:o,dkLen:i,asyncTick:a,DK:f,PRF:u,PRFSalt:d}}function vp(r,t,e,n,s){return r.destroy(),t.destroy(),n&&n.destroy(),s.fill(0),e}async function Ni(r,t,e,n){let{c:s,dkLen:o,asyncTick:i,DK:a,PRF:c,PRFSalt:l}=Ep(r,t,e,n),f,u=new Uint8Array(4),d=Er(u),p=new Uint8Array(c.outputLen);for(let y=1,m=0;m<o;y++,m+=c.outputLen){let h=a.subarray(m,m+c.outputLen);d.setInt32(0,y,!1),(f=l._cloneInto(f)).update(u).digestInto(p),h.set(p.subarray(0,h.length)),await Rc(s-1,i,()=>{c._cloneInto(f).update(p).digestInto(p);for(let w=0;w<h.length;w++)h[w]^=p[w]})}return vp(c,l,a,f,p)}var j=zf(ul());function ur(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 $e(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 f=a-1;f>=0;f--){let u=Math.pow(2,f*t);l[o-f-1]=Math.floor(s/u),s-=l[o-f-1]*u}return c}i*=Math.pow(2,t)}return new ArrayBuffer(0)}function Qn(...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 Li(){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=ur(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,ur(o,8)-n}function fl(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=$e(i,8,n),c=new Uint8Array(a);return c[0]|=128,a}let s=$e(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 hl(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 Ot(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 kw=Math.log(2);function ts(){if(typeof BigInt>"u")throw new Error("BigInt is not defined. Your environment doesn't implement BigInt.")}function Ci(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 Ie(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 un=class{constructor(){this.items=[]}write(t){this.items.push(t)}final(){return Ci(this.items)}},ln=[new Uint8Array([1])],dl="0123456789";var Lr="",re=new ArrayBuffer(0),Ui=new Uint8Array(0),fn="EndOfContent",gl="OCTET STRING",ml="BIT STRING";function _e(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?j.BufferSourceConverter.toUint8Array(o.valueHex):Ui}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(!Ie(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",re)}toJSON(){return{...super.toJSON(),isHexOnly:this.isHexOnly,valueHex:j.Convert.ToHex(this.valueHexView)}}},t.NAME="hexBlock",t}var Ae=class{constructor({blockLength:t=0,error:e=Lr,warnings:n=[],valueBeforeDecode:s=Ui}={}){this.blockLength=t,this.error=e,this.warnings=n,this.valueBeforeDecodeView=j.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:j.Convert.ToHex(this.valueBeforeDecodeView)}}};Ae.NAME="baseBlock";var Tt=class extends Ae{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'")}};Tt.NAME="valueBlock";var es=class extends _e(Ae){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?j.BufferSourceConverter.toUint8Array(t.valueHex):Ui,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",re}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=$e(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=j.BufferSourceConverter.toUint8Array(t);if(!Ie(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),f=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===f){f+=255;let d=new Uint8Array(f);for(let p=0;p<l.length;p++)d[p]=l[p];l=this.valueHexView=new Uint8Array(f)}}this.blockLength=c+1,l[c-1]=o[c]&127;let u=new Uint8Array(c);for(let d=0;d<c;d++)u[d]=l[d];l=this.valueHexView=new Uint8Array(c),l.set(u),this.blockLength<=9?this.tagNumber=ur(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}}};es.NAME="identificationBlock";var rs=class extends Ae{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=j.BufferSourceConverter.toUint8Array(t);if(!Ie(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=ur(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=$e(this.length,8);if(s.byteLength>127)return this.error="Too big length",re;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}}};rs.NAME="lengthBlock";var P={},kt=class extends Ae{constructor({name:t=Lr,optional:e=!1,primitiveSchema:n,...s}={},o){super(s),this.name=t,this.optional=e,n&&(this.primitiveSchema=n),this.idBlock=new es(s),this.lenBlock=new rs(s),this.valueBlock=o?new o(s):new Tt(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 un;e||yl(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?re: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():j.Convert.ToHex(this.toBER())}onAsciiEncoding(){return`${this.constructor.NAME} : ${j.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 hl(e,n)}};kt.NAME="BaseBlock";function yl(r){if(r instanceof P.Constructed)for(let t of r.valueBlock.value)yl(t)&&(r.lenBlock.isIndefiniteForm=!0);return!!r.lenBlock.isIndefiniteForm}var ns=class extends kt{constructor({value:t=Lr,...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}'`}};ns.NAME="BaseStringBlock";var ss=class extends _e(Tt){constructor({isHexOnly:t=!0,...e}={}){super(e),this.isHexOnly=t}};ss.NAME="PrimitiveValueBlock";var wl,os=class extends kt{constructor(t={}){super(t,ss),this.idBlock.isConstructed=!1}};wl=os;P.Primitive=wl;os.NAME="PRIMITIVE";function Tp(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 Hs(r,t=0,e=r.length){let n=t,s=new kt({},Tt),o=new Ae;if(!Ie(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=P.EndOfContent;break;case 1:c=P.Boolean;break;case 2:c=P.Integer;break;case 3:c=P.BitString;break;case 4:c=P.OctetString;break;case 5:c=P.Null;break;case 6:c=P.ObjectIdentifier;break;case 10:c=P.Enumerated;break;case 12:c=P.Utf8String;break;case 13:c=P.RelativeObjectIdentifier;break;case 14:c=P.TIME;break;case 15:return s.error="[UNIVERSAL 15] is reserved by ASN.1 standard",{offset:-1,result:s};case 16:c=P.Sequence;break;case 17:c=P.Set;break;case 18:c=P.NumericString;break;case 19:c=P.PrintableString;break;case 20:c=P.TeletexString;break;case 21:c=P.VideotexString;break;case 22:c=P.IA5String;break;case 23:c=P.UTCTime;break;case 24:c=P.GeneralizedTime;break;case 25:c=P.GraphicString;break;case 26:c=P.VisibleString;break;case 27:c=P.GeneralString;break;case 28:c=P.UniversalString;break;case 29:c=P.CharacterString;break;case 30:c=P.BmpString;break;case 31:c=P.DATE;break;case 32:c=P.TimeOfDay;break;case 33:c=P.DateTime;break;case 34:c=P.Duration;break;default:{let l=s.idBlock.isConstructed?new P.Constructed:new P.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?P.Constructed:P.Primitive}return s=Tp(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 Cr(r){if(!r.byteLength){let t=new kt({},Tt);return t.error="Input buffer has zero length",{offset:-1,result:t}}return Hs(j.BufferSourceConverter.toUint8Array(r).slice(),0,r.byteLength)}function Lp(r,t){return r?1:t}var le=class extends Tt{constructor({value:t=[],isIndefiniteForm:e=!1,...n}={}){super(n),this.value=t,this.isIndefiniteForm=e}fromBER(t,e,n){let s=j.BufferSourceConverter.toUint8Array(t);if(!Ie(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(;Lp(this.isIndefiniteForm,n)>0;){let i=Hs(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===fn)break}return this.isIndefiniteForm&&(this.value[this.value.length-1].constructor.NAME===fn?this.value.pop():this.warnings.push("No EndOfContent block encoded")),o}toBER(t,e){let n=e||new un;for(let s=0;s<this.value.length;s++)this.value[s].toBER(t,n);return e?re:n.final()}toJSON(){let t={...super.toJSON(),isIndefiniteForm:this.isIndefiniteForm,value:[]};for(let e of this.value)t.value.push(e.toJSON());return t}};le.NAME="ConstructedValueBlock";var bl,qe=class extends kt{constructor(t={}){super(t,le),this.idBlock.isConstructed=!0}fromBER(t,e,n){this.valueBlock.isIndefiniteForm=this.lenBlock.isIndefiniteForm;let s=this.valueBlock.fromBER(t,e,this.lenBlock.isIndefiniteForm?n:this.lenBlock.length);return s===-1?(this.error=this.valueBlock.error,s):(this.idBlock.error.length||(this.blockLength+=this.idBlock.blockLength),this.lenBlock.error.length||(this.blockLength+=this.lenBlock.blockLength),this.valueBlock.error.length||(this.blockLength+=this.valueBlock.blockLength),s)}onAsciiEncoding(){let t=[];for(let n of this.valueBlock.value)t.push(n.toString("ascii").split(`
3
3
  `).map(s=>` ${s}`).join(`
4
4
  `));let e=this.idBlock.tagClass===3?`[${this.idBlock.tagNumber}]`:this.constructor.NAME;return t.length?`${e} :
5
5
  ${t.join(`
6
- `)}`:`${e} :`}};yl=Me;C.Constructed=yl;Me.NAME="CONSTRUCTED";var ss=class extends Tt{fromBER(t,e,n){return e}toBER(t){return re}};ss.override="EndOfContentValueBlock";var wl,os=class extends kt{constructor(t={}){super(t,ss),this.idBlock.tagClass=1,this.idBlock.tagNumber=0}};wl=os;C.EndOfContent=wl;os.NAME=an;var bl,Ke=class extends kt{constructor(t={}){super(t,Tt),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}`}};bl=Ke;C.Null=bl;Ke.NAME="NULL";var is=class extends Ie(Tt){constructor({value:t,...e}={}){super(e),e.valueHex?this.valueHexView=z.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=z.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,Ri.call(this),this.blockLength=n,e+n):-1}toBER(){return this.valueHexView.slice()}toJSON(){return{...super.toJSON(),value:this.value}}};is.NAME="BooleanValueBlock";var xl,as=class extends kt{constructor(t={}){super(t,is),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}`}};xl=as;C.Boolean=xl;as.NAME="BOOLEAN";var cs=class extends Ie(le){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=le.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===an){if(this.isIndefiniteForm)break;return this.error="EndOfContent is unexpected, OCTET STRING may consists of OCTET STRINGs only",-1}if(i!==dl)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?le.prototype.toBER.call(this,t,e):t?new ArrayBuffer(this.valueHexView.byteLength):this.valueHexView.slice().buffer}toJSON(){return{...super.toJSON(),isConstructed:this.isConstructed}}};cs.NAME="OctetStringValueBlock";var El,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},cs),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=Ds(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} : ${z.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 z.BufferSourceConverter.concat(t)}};El=Ae;C.OctetString=El;Ae.NAME=dl;var ls=class extends Ie(le){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=le.prototype.fromBER.call(this,t,e,n),s===-1)return s;for(let a of this.value){let c=a.constructor.NAME;if(c===an){if(this.isIndefiniteForm)break;return this.error="EndOfContent is unexpected, BIT STRING may consists of BIT STRINGs only",-1}if(c!==pl)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=z.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=Ds(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 le.prototype.toBER.call(this,t,e);if(t)return new ArrayBuffer(this.valueHexView.byteLength+1);if(!this.valueHexView.byteLength)return re;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}}};ls.NAME="BitStringValueBlock";var vl,_r=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},ls),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)}`}}};vl=_r;C.BitString=vl;_r.NAME=pl;var Bl;function Tp(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,f=c<i?i:c,u=0;for(let g=f;g>=0;g--,u++){switch(!0){case u<a.length:l=o[i-u]+a[c-u]+e[0];break;default:l=o[i-u]+e[0]}switch(e[0]=l/10,!0){case u>=o.length:o=Xn(new Uint8Array([l%10]),o);break;default:o[i-u]=l%10}}return e[0]>0&&(o=Xn(e,o)),o}function hl(r){if(r>=sn.length)for(let t=sn.length;t<=r;t++){let e=new Uint8Array([0]),n=sn[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=Xn(e,n)),sn.push(n)}return sn[r]}function Lp(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,f=0;for(let u=c;u>=0;u--,f++)switch(l=o[i-f]-a[c-f]-e,!0){case l<0:e=1,o[i-f]=l+10;break;default:e=0,o[i-f]=l}if(e>0)for(let u=i-c+1;u>=0;u--,f++)if(l=o[i-f]-e,l<0)e=1,o[i-f]=l+10;else{e=0,o[i-f]=l;break}return o.slice()}var cn=class extends Ie(Tt){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=Ri.call(this)))}set valueDec(t){this._valueDec=t,this.isHexOnly=!1,this.valueHexView=new Uint8Array(ll(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=Lp(hl(n),e),i="-";break;default:e=Tp(e,hl(n))}n++,s>>=1}}for(let c=0;c<e.length;c++)e[c]&&(a=!0),a&&(i+=fl.charAt(e[c]));return a===!1&&(i+=fl.charAt(0)),i}};Bl=cn;cn.NAME="IntegerValueBlock";Object.defineProperty(Bl.prototype,"valueHex",{set:function(r){this.valueHexView=new Uint8Array(r),this.setValueHex()},get:function(){return this.valueHexView.slice().buffer}});var Al,pt=class r extends kt{constructor(t={}){super(t,cn),this.idBlock.tagClass=1,this.idBlock.tagNumber=2}toBigInt(){return Jn(),BigInt(this.valueBlock.toString())}static fromBigInt(t){Jn();let e=BigInt(t),n=new on,s=e.toString(16).replace(/^-/,""),o=new Uint8Array(z.Convert.FromHex(s));if(e<0){let a=new Uint8Array(o.length+(o[0]&128?1:0));a[0]|=128;let l=BigInt(`0x${z.Convert.ToHex(a)}`)+e,f=z.BufferSourceConverter.toUint8Array(z.Convert.FromHex(l.toString(16)));f[0]|=128,n.write(f)}else o[0]&128&&n.write(new Uint8Array([0])),n.write(o);return new r({valueHex:n.final()})}convertToDER(){let t=new r({valueHex:this.valueBlock.valueHexView});return t.valueBlock.toDER(),t}convertFromDER(){return new r({valueHex:this.valueBlock.valueHexView[0]===0?this.valueBlock.valueHexView.subarray(1):this.valueBlock.valueHexView})}onAsciiEncoding(){return`${this.constructor.NAME} : ${this.valueBlock.toString()}`}};Al=pt;C.Integer=Al;pt.NAME="INTEGER";var Sl,us=class extends pt{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=10}};Sl=us;C.Enumerated=Sl;us.NAME="ENUMERATED";var ln=class extends Ie(Tt){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=z.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=ir(this.valueHexView,7):(this.isHexOnly=!0,this.warnings.push("Too big SID for decoding, hex only")),e+this.blockLength)}set valueBigInt(t){Jn();let e=BigInt(t).toString(2);for(;e.length%7;)e="0"+e;let n=new Uint8Array(e.length/7);for(let s=0;s<n.length;s++)n[s]=parseInt(e.slice(s*7,s*7+7),2)+(s+1<n.length?128:0);this.fromBER(n.buffer,0,n.length)}toBER(t){if(this.isHexOnly){if(t)return new ArrayBuffer(this.valueHexView.byteLength);let s=this.valueHexView,o=new Uint8Array(this.blockLength);for(let i=0;i<this.blockLength-1;i++)o[i]=s[i]|128;return o[this.blockLength-1]=s[this.blockLength-1],o.buffer}let e=Oe(this.valueDec,7);if(e.byteLength===0)return this.error="Error during encoding SID value",re;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=z.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}}};ln.NAME="sidBlock";var fs=class extends Tt{constructor({value:t=Rr,...e}={}){super(e),this.value=[],t&&this.fromString(t)}fromBER(t,e,n){let s=e;for(;n>0;){let o=new ln;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,re;e.push(s)}return Ni(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 ln;if(s>Number.MAX_SAFE_INTEGER){Jn();let a=BigInt(s);i.valueBigInt=a}else if(i.valueDec=parseInt(s,10),isNaN(i.valueDec))return;this.value.length||(i.isFirstSid=!0,o=!0),this.value.push(i)}while(n!==-1)}toString(){let t="",e=!1;for(let n=0;n<this.value.length;n++){e=this.value[n].isHexOnly;let s=this.value[n].toString();n!==0&&(t=`${t}.`),e?(s=`{${s}}`,this.value[n].isFirstSid?t=`2.{${s} - 80}`:t+=s):t+=s}return t}toJSON(){let t={...super.toJSON(),value:this.toString(),sidArray:[]};for(let e=0;e<this.value.length;e++)t.sidArray.push(this.value[e].toJSON());return t}};fs.NAME="ObjectIdentifierValueBlock";var kl,ee=class extends kt{constructor(t={}){super(t,fs),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()}}};kl=ee;C.ObjectIdentifier=kl;ee.NAME="OBJECT IDENTIFIER";var un=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=z.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=ir(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",re;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=z.Convert.ToHex(this.valueHexView):t=this.valueDec.toString(),t}toJSON(){return{...super.toJSON(),valueDec:this.valueDec}}};un.NAME="relativeSidBlock";var hs=class extends Tt{constructor({value:t=Rr,...e}={}){super(e),this.value=[],t&&this.fromString(t)}fromBER(t,e,n){let s=e;for(;n>0;){let o=new un;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,re;n.push(o)}return Ni(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 un;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}};hs.NAME="RelativeObjectIdentifierValueBlock";var Il,ds=class extends kt{constructor(t={}){super(t,hs),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()}}};Il=ds;C.RelativeObjectIdentifier=Il;ds.NAME="RelativeObjectIdentifier";var _l,vt=class extends Me{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=16}};_l=vt;C.Sequence=_l;vt.NAME="SEQUENCE";var Rl,ps=class extends Me{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=17}};Rl=ps;C.Set=Rl;ps.NAME="SET";var gs=class extends Ie(Tt){constructor({...t}={}){super(t),this.isHexOnly=!0,this.value=Rr}toJSON(){return{...super.toJSON(),value:this.value}}};gs.NAME="StringValueBlock";var ms=class extends gs{};ms.NAME="SimpleStringValueBlock";var Ut=class extends es{constructor({...t}={}){super(t,ms)}fromBuffer(t){this.valueBlock.value=String.fromCharCode.apply(null,z.BufferSourceConverter.toUint8Array(t))}fromString(t){let e=t.length,n=this.valueBlock.valueHexView=new Uint8Array(e);for(let s=0;s<e;s++)n[s]=t.charCodeAt(s);this.valueBlock.value=t}};Ut.NAME="SIMPLE STRING";var ys=class extends Ut{fromBuffer(t){this.valueBlock.valueHexView=z.BufferSourceConverter.toUint8Array(t);try{this.valueBlock.value=z.Convert.ToUtf8String(t)}catch(e){this.warnings.push(`Error during "decodeURIComponent": ${e}, using raw string`),this.valueBlock.value=z.Convert.ToBinary(t)}}fromString(t){this.valueBlock.valueHexView=new Uint8Array(z.Convert.FromUtf8String(t)),this.valueBlock.value=t}};ys.NAME="Utf8StringValueBlock";var Nl,Se=class extends ys{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=12}};Nl=Se;C.Utf8String=Nl;Se.NAME="UTF8String";var ws=class extends Ut{fromBuffer(t){this.valueBlock.value=z.Convert.ToUtf16String(t),this.valueBlock.valueHexView=z.BufferSourceConverter.toUint8Array(t)}fromString(t){this.valueBlock.value=t,this.valueBlock.valueHexView=new Uint8Array(z.Convert.FromUtf16String(t))}};ws.NAME="BmpStringValueBlock";var Tl,bs=class extends ws{constructor({...t}={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=30}};Tl=bs;C.BmpString=Tl;bs.NAME="BMPString";var xs=class extends Ut{fromBuffer(t){let e=ArrayBuffer.isView(t)?t.slice().buffer:t.slice(0),n=new Uint8Array(e);for(let s=0;s<n.length;s+=4)n[s]=n[s+3],n[s+1]=n[s+2],n[s+2]=0,n[s+3]=0;this.valueBlock.value=String.fromCharCode.apply(null,new Uint32Array(e))}fromString(t){let e=t.length,n=this.valueBlock.valueHexView=new Uint8Array(e*4);for(let s=0;s<e;s++){let o=Oe(t.charCodeAt(s),8),i=new Uint8Array(o);if(i.length>4)continue;let a=4-i.length;for(let c=i.length-1;c>=0;c--)n[s*4+c+a]=i[c]}this.valueBlock.value=t}};xs.NAME="UniversalStringValueBlock";var Ll,Es=class extends xs{constructor({...t}={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=28}};Ll=Es;C.UniversalString=Ll;Es.NAME="UniversalString";var Cl,vs=class extends Ut{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=18}};Cl=vs;C.NumericString=Cl;vs.NAME="NumericString";var Ul,Bs=class extends Ut{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=19}};Ul=Bs;C.PrintableString=Ul;Bs.NAME="PrintableString";var Pl,As=class extends Ut{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=20}};Pl=As;C.TeletexString=Pl;As.NAME="TeletexString";var Dl,Ss=class extends Ut{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=21}};Dl=Ss;C.VideotexString=Dl;Ss.NAME="VideotexString";var Vl,ks=class extends Ut{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=22}};Vl=ks;C.IA5String=Vl;ks.NAME="IA5String";var Hl,Is=class extends Ut{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=25}};Hl=Is;C.GraphicString=Hl;Is.NAME="GraphicString";var Ol,fn=class extends Ut{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=26}};Ol=fn;C.VisibleString=Ol;fn.NAME="VisibleString";var Ml,_s=class extends Ut{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=27}};Ml=_s;C.GeneralString=Ml;_s.NAME="GeneralString";var Kl,Rs=class extends Ut{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=29}};Kl=Rs;C.CharacterString=Kl;Rs.NAME="CharacterString";var Fl,hn=class extends fn{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,z.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}}};Fl=hn;C.UTCTime=Fl;hn.NAME="UTCTime";var $l,Ns=class extends hn{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 u=new Number(t[t.length-1]);if(isNaN(u.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 u=1,g=n.indexOf("+"),m="";if(g===-1&&(g=n.indexOf("-"),u=-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=u*p,m.length===4){if(p=parseInt(m.substring(2,4),10),isNaN(p.valueOf()))throw new Error("Wrong input string for conversion");c=u*p}}}let l=n.indexOf(".");if(l===-1&&(l=n.indexOf(",")),l!==-1){let u=new Number(`0${n.substring(l)}`);if(isNaN(u.valueOf()))throw new Error("Wrong input string for conversion");o=u.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 u=60*o;this.minute=Math.floor(u),u=60*(u-this.minute),this.second=Math.floor(u),u=1e3*(u-this.second),this.millisecond=Math.floor(u)}break;case s.length===12:if(i=/(\d{4})(\d{2})(\d{2})(\d{2})(\d{2})/ig,l!==-1){let u=60*o;this.second=Math.floor(u),u=1e3*(u-this.second),this.millisecond=Math.floor(u)}break;case s.length===14:if(i=/(\d{4})(\d{2})(\d{2})(\d{2})(\d{2})(\d{2})/ig,l!==-1){let u=1e3*o;this.millisecond=Math.floor(u)}break;default:throw new Error("Wrong input string for conversion")}let f=i.exec(s);if(f===null)throw new Error("Wrong input string for conversion");for(let u=1;u<f.length;u++)switch(u){case 1:this.year=parseInt(f[u],10);break;case 2:this.month=parseInt(f[u],10);break;case 3:this.day=parseInt(f[u],10);break;case 4:this.hour=parseInt(f[u],10)+a;break;case 5:this.minute=parseInt(f[u],10)+c;break;case 6:this.second=parseInt(f[u],10);break;default:throw new Error("Wrong input string for conversion")}if(e===!1){let u=new Date(this.year,this.month,this.day,this.hour,this.minute,this.second,this.millisecond);this.year=u.getUTCFullYear(),this.month=u.getUTCMonth(),this.day=u.getUTCDay(),this.hour=u.getUTCHours(),this.minute=u.getUTCMinutes(),this.second=u.getUTCSeconds(),this.millisecond=u.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}}};$l=Ns;C.GeneralizedTime=$l;Ns.NAME="GeneralizedTime";var ql,Ts=class extends Se{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=31}};ql=Ts;C.DATE=ql;Ts.NAME="DATE";var Gl,Ls=class extends Se{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=32}};Gl=Ls;C.TimeOfDay=Gl;Ls.NAME="TimeOfDay";var zl,Cs=class extends Se{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=33}};zl=Cs;C.DateTime=zl;Cs.NAME="DateTime";var jl,Us=class extends Se{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=34}};jl=Us;C.Duration=jl;Us.NAME="Duration";var Wl,Ps=class extends Se{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=14}};Wl=Ps;C.TIME=Wl;Ps.NAME="TIME";function Up(r){let{result:t}=Nr(r),e=t.valueBlock.value;return{n:$(ue(e[1].toBigInt()),"base64url"),e:$(ue(e[2].toBigInt()),"base64url"),d:$(ue(e[3].toBigInt()),"base64url"),p:$(ue(e[4].toBigInt()),"base64url"),q:$(ue(e[5].toBigInt()),"base64url"),dp:$(ue(e[6].toBigInt()),"base64url"),dq:$(ue(e[7].toBigInt()),"base64url"),qi:$(ue(e[8].toBigInt()),"base64url"),kty:"RSA",alg:"RS256"}}function Pp(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(fe(W(r.n,"base64url"))),pt.fromBigInt(fe(W(r.e,"base64url"))),pt.fromBigInt(fe(W(r.d,"base64url"))),pt.fromBigInt(fe(W(r.p,"base64url"))),pt.fromBigInt(fe(W(r.q,"base64url"))),pt.fromBigInt(fe(W(r.dp,"base64url"))),pt.fromBigInt(fe(W(r.dq,"base64url"))),pt.fromBigInt(fe(W(r.qi,"base64url")))]}).toBER();return new Uint8Array(e,0,e.byteLength)}function Dp(r){let{result:t}=Nr(r),e=t.valueBlock.value[1].valueBlock.value[0].valueBlock.value;return{kty:"RSA",n:$(ue(e[0].toBigInt()),"base64url"),e:$(ue(e[1].toBigInt()),"base64url")}}function Vp(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 ee({value:"1.2.840.113549.1.1.1"}),new Ke]}),new _r({valueHex:new vt({value:[pt.fromBigInt(fe(W(r.n,"base64url"))),pt.fromBigInt(fe(W(r.e,"base64url")))]}).toBER()})]}).toBER();return new Uint8Array(e,0,e.byteLength)}function ue(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 fe(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 Hp=16,Li=32,Ci=1e4;async function Op(r,t){let e=Ct.get(),s=new vt({value:[new pt({value:0}),new vt({value:[new ee({value:"1.2.840.113549.1.1.1"}),new Ke]}),new Ae({valueHex:r.marshal()})]}).toBER(),o=new Uint8Array(s,0,s.byteLength),i=or(Hp),a=await Ii(Wr,t,i,{c:Ci,dkLen:Li}),c=or(16),l=await e.subtle.importKey("raw",a,"AES-CBC",!1,["encrypt"]),f=await e.subtle.encrypt({name:"AES-CBC",iv:c},l,o),u=new vt({value:[new Ae({valueHex:i}),new pt({value:Ci}),new pt({value:Li}),new vt({value:[new ee({value:"1.2.840.113549.2.11"}),new Ke]})]}),g=new vt({value:[new ee({value:"1.2.840.113549.1.5.13"}),new vt({value:[new vt({value:[new ee({value:"1.2.840.113549.1.5.12"}),u]}),new vt({value:[new ee({value:"2.16.840.1.101.3.4.1.42"}),new Ae({valueHex:c})]})]})]}),p=new vt({value:[g,new Ae({valueHex:f})]}).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 Mp(r,t){let e=Ct.get(),n;if(r.includes("-----BEGIN ENCRYPTED PRIVATE KEY-----")){let s=W(r.replace("-----BEGIN ENCRYPTED PRIVATE KEY-----","").replace("-----END ENCRYPTED PRIVATE KEY-----","").replace(/\n/g,"").trim(),"base64pad"),{result:o}=Nr(s),{iv:i,salt:a,iterations:c,keySize:l,cipherText:f}=Kp(o),u=await Ii(Wr,t,a,{c,dkLen:l}),g=await e.subtle.importKey("raw",u,"AES-CBC",!1,["decrypt"]),m=dn(await e.subtle.decrypt({name:"AES-CBC",iv:i},g,f)),{result:p}=Nr(m);n=Yl(p)}else if(r.includes("-----BEGIN PRIVATE KEY-----")){let s=W(r.replace("-----BEGIN PRIVATE KEY-----","").replace("-----END PRIVATE KEY-----","").replace(/\n/g,"").trim(),"base64pad"),{result:o}=Nr(s);n=Yl(o)}else throw new M("Could not parse private key from PEM data","ERR_INVALID_PARAMETERS");return Ui(n)}function Kp(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=dn(o.valueBlock.value[0].getValue()),a=Ci,c=Li;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],f=l.valueBlock.value[0].toString();if(f!=="OBJECT IDENTIFIER : 1.2.840.113549.3.7"){if(f!=="OBJECT IDENTIFIER : 1.3.14.3.2.7"){if(f!=="OBJECT IDENTIFIER : 2.16.840.1.101.3.4.1.2"){if(f!=="OBJECT IDENTIFIER : 2.16.840.1.101.3.4.1.22"){if(f!=="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 u=dn(l.valueBlock.value[1].getValue());return{cipherText:dn(r.valueBlock.value[1].getValue()),salt:i,iterations:a,keySize:c,iv:u}}function Yl(r){return dn(r.valueBlock.value[2].getValue())}function dn(r){return new Uint8Array(r,0,r.byteLength)}async function Zl(r){let t=await Ct.get().subtle.generateKey({name:"RSASSA-PKCS1-v1_5",modulusLength:r,publicExponent:new Uint8Array([1,0,1]),hash:{name:"SHA-256"}},!0,["sign","verify"]),e=await Ql(t);return{privateKey:e[0],publicKey:e[1]}}async function Pi(r){let e=[await Ct.get().subtle.importKey("jwk",r,{name:"RSASSA-PKCS1-v1_5",hash:{name:"SHA-256"}},!0,["sign"]),await Fp(r)],n=await Ql({privateKey:e[0],publicKey:e[1]});return{privateKey:n[0],publicKey:n[1]}}async function Xl(r,t){let e=await Ct.get().subtle.importKey("jwk",r,{name:"RSASSA-PKCS1-v1_5",hash:{name:"SHA-256"}},!1,["sign"]),n=await Ct.get().subtle.sign({name:"RSASSA-PKCS1-v1_5"},e,t instanceof Uint8Array?t:t.subarray());return new Uint8Array(n,0,n.byteLength)}async function Jl(r,t,e){let n=await Ct.get().subtle.importKey("jwk",r,{name:"RSASSA-PKCS1-v1_5",hash:{name:"SHA-256"}},!1,["verify"]);return Ct.get().subtle.verify({name:"RSASSA-PKCS1-v1_5"},n,t,e instanceof Uint8Array?e:e.subarray())}async function Ql(r){if(r.privateKey==null||r.publicKey==null)throw new M("Private and public key are required","ERR_INVALID_PARAMETERS");return Promise.all([Ct.get().subtle.exportKey("jwk",r.privateKey),Ct.get().subtle.exportKey("jwk",r.publicKey)])}async function Fp(r){return Ct.get().subtle.importKey("jwk",{kty:r.kty,n:r.n,e:r.e},{name:"RSASSA-PKCS1-v1_5",hash:{name:"SHA-256"}},!0,["verify"])}function Vs(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 W(r.n,"base64url").length*8}var gn=8192,pn=class{_key;constructor(t){this._key=t}verify(t,e){return Jl(this._key,e,t)}marshal(){return Fe.jwkToPkix(this._key)}get bytes(){return ae.encode({Type:it.RSA,Data:this.marshal()}).subarray()}equals(t){return ft(this.bytes,t.bytes)}hash(){let t=At.digest(this.bytes);return Kt(t)?t.then(({bytes:e})=>e):t.bytes}},Tr=class{_key;_publicKey;constructor(t,e){this._key=t,this._publicKey=e}genSecret(){return or(16)}sign(t){return Xl(this._key,t)}get public(){if(this._publicKey==null)throw new M("public key not provided","ERR_PUBKEY_NOT_PROVIDED");return new pn(this._publicKey)}marshal(){return Fe.jwkToPkcs1(this._key)}get bytes(){return ce.encode({Type:it.RSA,Data:this.marshal()}).subarray()}equals(t){return ft(this.bytes,t.bytes)}hash(){let t=At.digest(this.bytes);return Kt(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 Ar(this.bytes,t);throw new M(`export format '${e}' is not supported`,"ERR_INVALID_EXPORT_FORMAT")}};async function Ui(r){let t=Fe.pkcs1ToJwk(r);if(Vs(t)>gn)throw new M("key size is too large","ERR_KEY_SIZE_TOO_LARGE");let e=await Pi(t);return new Tr(e.privateKey,e.publicKey)}function qp(r){let t=Fe.pkixToJwk(r);if(Vs(t)>gn)throw new M("key size is too large","ERR_KEY_SIZE_TOO_LARGE");return new pn(t)}async function Gp(r){if(Vs(r)>gn)throw new M("key size is too large","ERR_KEY_SIZE_TOO_LARGE");let t=await Pi(r);return new Tr(t.privateKey,t.publicKey)}async function zp(r){if(r>gn)throw new M("key size is too large","ERR_KEY_SIZE_TOO_LARGE");let t=await Zl(r);return new Tr(t.privateKey,t.publicKey)}var Ki={};gt(Ki,{Secp256k1PrivateKey:()=>yn,Secp256k1PublicKey:()=>mn,generateKeyPair:()=>o0,unmarshalSecp256k1PrivateKey:()=>n0,unmarshalSecp256k1PublicKey:()=>s0});var jp=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),Vi=class extends br{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 u=0;u<16;u++,e+=4)qe[u]=t.getUint32(e,!1);for(let u=16;u<64;u++){let g=qe[u-15],m=qe[u-2],p=Wt(g,7)^Wt(g,18)^g>>>3,h=Wt(m,17)^Wt(m,19)^m>>>10;qe[u]=h+qe[u-7]+p+qe[u-16]|0}let{A:n,B:s,C:o,D:i,E:a,F:c,G:l,H:f}=this;for(let u=0;u<64;u++){let g=Wt(a,6)^Wt(a,11)^Wt(a,25),m=f+g+Rc(a,c,l)+jp[u]+qe[u]|0,h=(Wt(n,2)^Wt(n,13)^Wt(n,22))+Nc(n,s,o)|0;f=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,f=f+this.H|0,this.set(n,s,o,i,a,c,l,f)}roundClean(){qe.fill(0)}destroy(){this.set(0,0,0,0,0,0,0,0),this.buffer.fill(0)}};var Lr=Pn(()=>new Vi);function tu(r){r.lowS!==void 0&&Zt("lowS",r.lowS),r.prehash!==void 0&&Zt("prehash",r.prehash)}function Wp(r){let t=Xr(r);Ft(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:Yp,hexToBytes:Zp}=Hn,ar={Err:class extends Error{constructor(t=""){super(t)}},_parseInt(r){let{Err:t}=ar;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:Yp(n),l:r.subarray(e+2)}},toSig(r){let{Err:t}=ar,e=typeof r=="string"?Zp(r):r;xr(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}=ar._parseInt(e.subarray(2)),{d:i,l:a}=ar._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 f=l.toString(16);return f.length&1?`0${f}`:f},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}`}},Ge=BigInt(0),Bt=BigInt(1),Zw=BigInt(2),eu=BigInt(3),Xw=BigInt(4);function Xp(r){let t=Wp(r),{Fp:e}=t,n=t.toBytes||((p,h,d)=>{let E=h.toAffine();return xe(Uint8Array.from([4]),e.toBytes(E.x),e.toBytes(E.y))}),s=t.fromBytes||(p=>{let h=p.subarray(1),d=e.fromBytes(h.subarray(0,e.BYTES)),E=e.fromBytes(h.subarray(e.BYTES,2*e.BYTES));return{x:d,y:E}});function o(p){let{a:h,b:d}=t,E=e.sqr(p),w=e.mul(E,p);return e.add(e.add(w,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 Yr(p,Bt,t.n)}function a(p){let{allowedPrivateKeyLengths:h,nByteLength:d,wrapPrivateKey:E,n:w}=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 x;try{x=typeof p=="bigint"?p:we(nt("private key",p,d))}catch{throw new Error(`private key must be ${d} bytes, hex or bigint, not ${typeof p}`)}return E&&(x=Y(x,w)),St("private key",x,Bt,w),x}function c(p){if(!(p instanceof u))throw new Error("ProjectivePoint expected")}let l=Xe((p,h)=>{let{px:d,py:E,pz:w}=p;if(e.eql(w,e.ONE))return{x:d,y:E};let x=p.is0();h==null&&(h=x?e.ONE:e.inv(w));let I=e.mul(d,h),N=e.mul(E,h),S=e.mul(w,h);if(x)return{x:e.ZERO,y:e.ZERO};if(!e.eql(S,e.ONE))throw new Error("invZ was invalid");return{x:I,y:N}}),f=Xe(p=>{if(p.is0()){if(t.allowInfinityPoint&&!e.is0(p.py))return;throw new Error("bad point: ZERO")}let{x:h,y:d}=p.toAffine();if(!e.isValid(h)||!e.isValid(d))throw new Error("bad point: x or y not FE");let E=e.sqr(d),w=o(h);if(!e.eql(E,w))throw new Error("bad point: equation left != right");if(!p.isTorsionFree())throw new Error("bad point: not in prime-order subgroup");return!0});class u{constructor(h,d,E){if(this.px=h,this.py=d,this.pz=E,h==null||!e.isValid(h))throw new Error("x required");if(d==null||!e.isValid(d))throw new Error("y required");if(E==null||!e.isValid(E))throw new Error("z required");Object.freeze(this)}static fromAffine(h){let{x:d,y:E}=h||{};if(!h||!e.isValid(d)||!e.isValid(E))throw new Error("invalid affine point");if(h instanceof u)throw new Error("projective point not allowed");let w=x=>e.eql(x,e.ZERO);return w(d)&&w(E)?u.ZERO:new u(d,E,e.ONE)}get x(){return this.toAffine().x}get y(){return this.toAffine().y}static normalizeZ(h){let d=e.invertBatch(h.map(E=>E.pz));return h.map((E,w)=>E.toAffine(d[w])).map(u.fromAffine)}static fromHex(h){let d=u.fromAffine(s(nt("pointHex",h)));return d.assertValidity(),d}static fromPrivateKey(h){return u.BASE.multiply(a(h))}_setWindowSize(h){m.setWindowSize(this,h)}assertValidity(){f(this)}hasEvenY(){let{y:h}=this.toAffine();if(e.isOdd)return!e.isOdd(h);throw new Error("Field doesn't support isOdd")}equals(h){c(h);let{px:d,py:E,pz:w}=this,{px:x,py:I,pz:N}=h,S=e.eql(e.mul(d,N),e.mul(x,w)),R=e.eql(e.mul(E,N),e.mul(I,w));return S&&R}negate(){return new u(this.px,e.neg(this.py),this.pz)}double(){let{a:h,b:d}=t,E=e.mul(d,eu),{px:w,py:x,pz:I}=this,N=e.ZERO,S=e.ZERO,R=e.ZERO,_=e.mul(w,w),V=e.mul(x,x),U=e.mul(I,I),T=e.mul(w,x);return T=e.add(T,T),R=e.mul(w,I),R=e.add(R,R),N=e.mul(h,R),S=e.mul(E,U),S=e.add(N,S),N=e.sub(V,S),S=e.add(V,S),S=e.mul(N,S),N=e.mul(T,N),R=e.mul(E,R),U=e.mul(h,U),T=e.sub(_,U),T=e.mul(h,T),T=e.add(T,R),R=e.add(_,_),_=e.add(R,_),_=e.add(_,U),_=e.mul(_,T),S=e.add(S,_),U=e.mul(x,I),U=e.add(U,U),_=e.mul(U,T),N=e.sub(N,_),R=e.mul(U,V),R=e.add(R,R),R=e.add(R,R),new u(N,S,R)}add(h){c(h);let{px:d,py:E,pz:w}=this,{px:x,py:I,pz:N}=h,S=e.ZERO,R=e.ZERO,_=e.ZERO,V=t.a,U=e.mul(t.b,eu),T=e.mul(d,x),F=e.mul(E,I),K=e.mul(w,N),k=e.add(d,E),b=e.add(x,I);k=e.mul(k,b),b=e.add(T,F),k=e.sub(k,b),b=e.add(d,w);let y=e.add(x,N);return b=e.mul(b,y),y=e.add(T,K),b=e.sub(b,y),y=e.add(E,w),S=e.add(I,N),y=e.mul(y,S),S=e.add(F,K),y=e.sub(y,S),_=e.mul(V,b),S=e.mul(U,K),_=e.add(S,_),S=e.sub(F,_),_=e.add(F,_),R=e.mul(S,_),F=e.add(T,T),F=e.add(F,T),K=e.mul(V,K),b=e.mul(U,b),F=e.add(F,K),K=e.sub(T,K),K=e.mul(V,K),b=e.add(b,K),T=e.mul(F,b),R=e.add(R,T),T=e.mul(y,b),S=e.mul(k,S),S=e.sub(S,T),T=e.mul(k,F),_=e.mul(y,_),_=e.add(_,T),new u(S,R,_)}subtract(h){return this.add(h.negate())}is0(){return this.equals(u.ZERO)}wNAF(h){return m.wNAFCached(this,h,u.normalizeZ)}multiplyUnsafe(h){St("scalar",h,Ge,t.n);let d=u.ZERO;if(h===Ge)return d;if(h===Bt)return this;let{endo:E}=t;if(!E)return m.unsafeLadder(this,h);let{k1neg:w,k1:x,k2neg:I,k2:N}=E.splitScalar(h),S=d,R=d,_=this;for(;x>Ge||N>Ge;)x&Bt&&(S=S.add(_)),N&Bt&&(R=R.add(_)),_=_.double(),x>>=Bt,N>>=Bt;return w&&(S=S.negate()),I&&(R=R.negate()),R=new u(e.mul(R.px,E.beta),R.py,R.pz),S.add(R)}multiply(h){let{endo:d,n:E}=t;St("scalar",h,Bt,E);let w,x;if(d){let{k1neg:I,k1:N,k2neg:S,k2:R}=d.splitScalar(h),{p:_,f:V}=this.wNAF(N),{p:U,f:T}=this.wNAF(R);_=m.constTimeNegate(I,_),U=m.constTimeNegate(S,U),U=new u(e.mul(U.px,d.beta),U.py,U.pz),w=_.add(U),x=V.add(T)}else{let{p:I,f:N}=this.wNAF(h);w=I,x=N}return u.normalizeZ([w,x])[0]}multiplyAndAddUnsafe(h,d,E){let w=u.BASE,x=(N,S)=>S===Ge||S===Bt||!N.equals(w)?N.multiplyUnsafe(S):N.multiply(S),I=x(this,d).add(x(h,E));return I.is0()?void 0:I}toAffine(h){return l(this,h)}isTorsionFree(){let{h,isTorsionFree:d}=t;if(h===Bt)return!0;if(d)return d(u,this);throw new Error("isTorsionFree() has not been declared for the elliptic curve")}clearCofactor(){let{h,clearCofactor:d}=t;return h===Bt?this:d?d(u,this):this.multiplyUnsafe(t.h)}toRawBytes(h=!0){return Zt("isCompressed",h),this.assertValidity(),n(u,this,h)}toHex(h=!0){return Zt("isCompressed",h),ye(this.toRawBytes(h))}}u.BASE=new u(t.Gx,t.Gy,e.ONE),u.ZERO=new u(e.ZERO,e.ONE,e.ZERO);let g=t.nBitLength,m=Kn(u,t.endo?Math.ceil(g/2):g);return{CURVE:t,ProjectivePoint:u,normPrivateKeyToScalar:a,weierstrassEquation:o,isWithinCurveOrder:i}}function Jp(r){let t=Xr(r);return Ft(t,{hash:"hash",hmac:"function",randomBytes:"function"},{bits2int:"function",bits2int_modN:"function",lowS:"boolean"}),Object.freeze({lowS:!0,...t})}function ru(r){let t=Jp(r),{Fp:e,n}=t,s=e.BYTES+1,o=2*e.BYTES+1;function i(k){return Y(k,n)}function a(k){return On(k,n)}let{ProjectivePoint:c,normPrivateKeyToScalar:l,weierstrassEquation:f,isWithinCurveOrder:u}=Xp({...t,toBytes(k,b,y){let B=b.toAffine(),A=e.toBytes(B.x),v=xe;return Zt("isCompressed",y),y?v(Uint8Array.from([b.hasEvenY()?2:3]),A):v(Uint8Array.from([4]),A,e.toBytes(B.y))},fromBytes(k){let b=k.length,y=k[0],B=k.subarray(1);if(b===s&&(y===2||y===3)){let A=we(B);if(!Yr(A,Bt,e.ORDER))throw new Error("Point is not on curve");let v=f(A),L;try{L=e.sqrt(v)}catch(O){let q=O instanceof Error?": "+O.message:"";throw new Error("Point is not on curve"+q)}let P=(L&Bt)===Bt;return(y&1)===1!==P&&(L=e.neg(L)),{x:A,y:L}}else if(b===o&&y===4){let A=e.fromBytes(B.subarray(0,e.BYTES)),v=e.fromBytes(B.subarray(e.BYTES,2*e.BYTES));return{x:A,y:v}}else throw new Error(`Point of length ${b} was invalid. Expected ${s} compressed bytes or ${o} uncompressed bytes`)}}),g=k=>ye(De(k,t.nByteLength));function m(k){let b=n>>Bt;return k>b}function p(k){return m(k)?i(-k):k}let h=(k,b,y)=>we(k.slice(b,y));class d{constructor(b,y,B){this.r=b,this.s=y,this.recovery=B,this.assertValidity()}static fromCompact(b){let y=t.nByteLength;return b=nt("compactSignature",b,y*2),new d(h(b,0,y),h(b,y,2*y))}static fromDER(b){let{r:y,s:B}=ar.toSig(nt("DER",b));return new d(y,B)}assertValidity(){St("r",this.r,Bt,n),St("s",this.s,Bt,n)}addRecoveryBit(b){return new d(this.r,this.s,b)}recoverPublicKey(b){let{r:y,s:B,recovery:A}=this,v=S(nt("msgHash",b));if(A==null||![0,1,2,3].includes(A))throw new Error("recovery id invalid");let L=A===2||A===3?y+t.n:y;if(L>=e.ORDER)throw new Error("recovery id 2 or 3 invalid");let P=A&1?"03":"02",H=c.fromHex(P+g(L)),O=a(L),q=i(-v*O),j=i(B*O),X=c.BASE.multiplyAndAddUnsafe(H,q,j);if(!X)throw new Error("point at infinify");return X.assertValidity(),X}hasHighS(){return m(this.s)}normalizeS(){return this.hasHighS()?new d(this.r,i(-this.s),this.recovery):this}toDERRawBytes(){return Ze(this.toDERHex())}toDERHex(){return ar.hexFromSig({r:this.r,s:this.s})}toCompactRawBytes(){return Ze(this.toCompactHex())}toCompactHex(){return g(this.r)+g(this.s)}}let E={isValidPrivateKey(k){try{return l(k),!0}catch{return!1}},normPrivateKeyToScalar:l,randomPrivateKey:()=>{let k=ri(t.n);return Oc(t.randomBytes(k),t.n)},precompute(k=8,b=c.BASE){return b._setWindowSize(k),b.multiply(BigInt(3)),b}};function w(k,b=!0){return c.fromPrivateKey(k).toRawBytes(b)}function x(k){let b=Pe(k),y=typeof k=="string",B=(b||y)&&k.length;return b?B===s||B===o:y?B===2*s||B===2*o:k instanceof c}function I(k,b,y=!0){if(x(k))throw new Error("first arg must be private key");if(!x(b))throw new Error("second arg must be public key");return c.fromHex(b).multiply(l(k)).toRawBytes(y)}let N=t.bits2int||function(k){let b=we(k),y=k.length*8-t.nBitLength;return y>0?b>>BigInt(y):b},S=t.bits2int_modN||function(k){return i(N(k))},R=Zr(t.nBitLength);function _(k){return St(`num < 2^${t.nBitLength}`,k,Ge,R),De(k,t.nByteLength)}function V(k,b,y=U){if(["recovered","canonical"].some(rt=>rt in y))throw new Error("sign() legacy options not supported");let{hash:B,randomBytes:A}=t,{lowS:v,prehash:L,extraEntropy:P}=y;v==null&&(v=!0),k=nt("msgHash",k),tu(y),L&&(k=nt("prehashed msgHash",B(k)));let H=S(k),O=l(b),q=[_(O),_(H)];if(P!=null&&P!==!1){let rt=P===!0?A(e.BYTES):P;q.push(nt("extraEntropy",rt))}let j=xe(...q),X=H;function lt(rt){let et=N(rt);if(!u(et))return;let Gt=a(et),xt=c.BASE.multiply(et).toAffine(),zt=i(xt.x);if(zt===Ge)return;let ze=i(Gt*i(X+zt*O));if(ze===Ge)return;let qr=(xt.x===zt?0:2)|Number(xt.y&Bt),In=ze;return v&&m(ze)&&(In=p(ze),qr^=1),new d(zt,In,qr)}return{seed:j,k2sig:lt}}let U={lowS:t.lowS,prehash:!1},T={lowS:t.lowS,prehash:!1};function F(k,b,y=U){let{seed:B,k2sig:A}=V(k,b,y),v=t;return Xo(v.hash.outputLen,v.nByteLength,v.hmac)(B,A)}c.BASE._setWindowSize(8);function K(k,b,y,B=T){let A=k;if(b=nt("msgHash",b),y=nt("publicKey",y),"strict"in B)throw new Error("options.strict was renamed to lowS");tu(B);let{lowS:v,prehash:L}=B,P,H;try{if(typeof A=="string"||Pe(A))try{P=d.fromDER(A)}catch(xt){if(!(xt instanceof ar.Err))throw xt;P=d.fromCompact(A)}else if(typeof A=="object"&&typeof A.r=="bigint"&&typeof A.s=="bigint"){let{r:xt,s:zt}=A;P=new d(xt,zt)}else throw new Error("PARSE");H=c.fromHex(y)}catch(xt){if(xt.message==="PARSE")throw new Error("signature must be Signature instance, Uint8Array or hex string");return!1}if(v&&P.hasHighS())return!1;L&&(b=t.hash(b));let{r:O,s:q}=P,j=S(b),X=a(q),lt=i(j*X),rt=i(O*X),et=c.BASE.multiplyAndAddUnsafe(H,lt,rt)?.toAffine();return et?i(et.x)===O:!1}return{CURVE:t,getPublicKey:w,getSharedSecret:I,sign:F,verify:K,ProjectivePoint:c,Signature:d,utils:E}}function Qp(r){return{hash:r,hmac:(t,...e)=>He(r,t,qo(...e)),randomBytes:Ye}}function nu(r,t){let e=n=>ru({...r,...Qp(n)});return Object.freeze({...e(t),create:e})}var iu=BigInt("0xfffffffffffffffffffffffffffffffffffffffffffffffffffffffefffffc2f"),su=BigInt("0xfffffffffffffffffffffffffffffffebaaedce6af48a03bbfd25e8cd0364141"),t0=BigInt(1),Hi=BigInt(2),ou=(r,t)=>(r+t/Hi)/t;function e0(r){let t=iu,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,f=l*l*r%t,u=st(f,e,t)*f%t,g=st(u,e,t)*f%t,m=st(g,Hi,t)*l%t,p=st(m,s,t)*m%t,h=st(p,o,t)*p%t,d=st(h,a,t)*h%t,E=st(d,c,t)*d%t,w=st(E,a,t)*h%t,x=st(w,e,t)*f%t,I=st(x,i,t)*p%t,N=st(I,n,t)*l%t,S=st(N,Hi,t);if(!Oi.eql(Oi.sqr(S),r))throw new Error("Cannot find square root");return S}var Oi=Mn(iu,void 0,void 0,{sqrt:e0}),ne=nu({a:BigInt(0),b:BigInt(7),Fp:Oi,n:su,Gx:BigInt("55066263022277343669578718895168534326250603453777594175500187360389116729240"),Gy:BigInt("32670510020758816978083085130507043184471273380659243275938904335757337482424"),h:BigInt(1),lowS:!0,endo:{beta:BigInt("0x7ae96a2b657c07106e64479eac3434e99cf0497512f58995c1396c28719501ee"),splitScalar:r=>{let t=su,e=BigInt("0x3086d221a7d46bcde86c90e49284eb15"),n=-t0*BigInt("0xe4437ed6010e88286f547fa90abfe4c3"),s=BigInt("0x114ca50f7a8e2f3f657c1108d9d44cfd8"),o=e,i=BigInt("0x100000000000000000000000000000000"),a=ou(o*r,t),c=ou(-n*r,t),l=Y(r-a*e-c*s,t),f=Y(-a*n-c*o,t),u=l>i,g=f>i;if(u&&(l=t-l),g&&(f=t-f),l>i||f>i)throw new Error("splitScalar: Endomorphism failed, k="+r);return{k1neg:u,k1:l,k2neg:g,k2:f}}}},Lr),ib=BigInt(0);var ab=ne.ProjectivePoint;function au(){return ne.utils.randomPrivateKey()}function cu(r,t){let e=At.digest(t instanceof Uint8Array?t:t.subarray());if(Kt(e))return e.then(({digest:n})=>ne.sign(n,r).toDERRawBytes()).catch(n=>{throw new M(String(n),"ERR_INVALID_INPUT")});try{return ne.sign(e.digest,r).toDERRawBytes()}catch(n){throw new M(String(n),"ERR_INVALID_INPUT")}}function lu(r,t,e){let n=At.digest(e instanceof Uint8Array?e:e.subarray());if(Kt(n))return n.then(({digest:s})=>ne.verify(t,s,r)).catch(s=>{throw new M(String(s),"ERR_INVALID_INPUT")});try{return ne.verify(t,n.digest,r)}catch(s){throw new M(String(s),"ERR_INVALID_INPUT")}}function uu(r){return ne.ProjectivePoint.fromHex(r).toRawBytes(!0)}function fu(r){try{ne.getPublicKey(r,!0)}catch(t){throw new M(String(t),"ERR_INVALID_PRIVATE_KEY")}}function Mi(r){try{ne.ProjectivePoint.fromHex(r)}catch(t){throw new M(String(t),"ERR_INVALID_PUBLIC_KEY")}}function hu(r){try{return ne.getPublicKey(r,!0)}catch(t){throw new M(String(t),"ERR_INVALID_PRIVATE_KEY")}}var mn=class{_key;constructor(t){Mi(t),this._key=t}verify(t,e){return lu(this._key,e,t)}marshal(){return uu(this._key)}get bytes(){return ae.encode({Type:it.Secp256k1,Data:this.marshal()}).subarray()}equals(t){return ft(this.bytes,t.bytes)}async hash(){let t=At.digest(this.bytes),e;return Kt(t)?{bytes:e}=await t:e=t.bytes,e}},yn=class{_key;_publicKey;constructor(t,e){this._key=t,this._publicKey=e??hu(t),fu(this._key),Mi(this._publicKey)}sign(t){return cu(this._key,t)}get public(){return new mn(this._publicKey)}marshal(){return this._key}get bytes(){return ce.encode({Type:it.Secp256k1,Data:this.marshal()}).subarray()}equals(t){return ft(this.bytes,t.bytes)}hash(){let t=At.digest(this.bytes);return Kt(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 Ar(this.bytes,t);throw new M(`export format '${e}' is not supported`,"ERR_INVALID_EXPORT_FORMAT")}};function n0(r){return new yn(r)}function s0(r){return new mn(r)}async function o0(){let r=au();return new yn(r)}var cr={rsa:Di,ed25519:ki,secp256k1:Ki};function du(r){let t=Object.keys(cr).join(" / ");return new M(`invalid or unsupported key type ${r}. Must be ${t}`,"ERR_UNSUPPORTED_KEY_TYPE")}function pu(r){let t=ae.decode(r),e=t.Data??new Uint8Array;switch(t.Type){case it.RSA:return cr.rsa.unmarshalRsaPublicKey(e);case it.Ed25519:return cr.ed25519.unmarshalEd25519PublicKey(e);case it.Secp256k1:return cr.secp256k1.unmarshalSecp256k1PublicKey(e);default:throw du(t.Type??"unknown")}}async function Fi(r){let t=ce.decode(r),e=t.Data??new Uint8Array;switch(t.Type){case it.RSA:return cr.rsa.unmarshalRsaPrivateKey(e);case it.Ed25519:return cr.ed25519.unmarshalEd25519PrivateKey(e);case it.Secp256k1:return cr.secp256k1.unmarshalSecp256k1PrivateKey(e);default:throw du(t.Type??"RSA")}}var mu=Symbol.for("nodejs.util.inspect.custom"),gu=Object.values(oe).map(r=>r.decoder).reduce((r,t)=>r.or(t),oe.identity.decoder),yu=114,Gi=36,zi=37,wn=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()})`}[Rn]=!0;toString(){return this.string==null&&(this.string=ut.encode(this.multihash.bytes).slice(1)),this.string}toCID(){return Mt.createV1(yu,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 ji(t).equals(this);if(t?.multihash?.bytes!=null)return ft(this.multihash.bytes,t.multihash.bytes);throw new Error("not valid Id")}[mu](){return`PeerId(${this.toString()})`}},Cr=class extends wn{type="RSA";publicKey;constructor(t){super({...t,type:"RSA"}),this.publicKey=t.publicKey}},Ur=class extends wn{type="Ed25519";publicKey;constructor(t){super({...t,type:"Ed25519"}),this.publicKey=t.multihash.digest}},Pr=class extends wn{type="secp256k1";publicKey;constructor(t){super({...t,type:"secp256k1"}),this.publicKey=t.multihash.digest}},$i=2336,qi=class{type="url";multihash;privateKey;publicKey;url;constructor(t){this.url=t.toString(),this.multihash=pe.digest(W(this.url))}[mu](){return`PeerId(${this.url})`}[Rn]=!0;toString(){return this.toCID().toString()}toCID(){return Mt.createV1($i,this.multihash)}toBytes(){return this.toCID().bytes}equals(t){return t==null?!1:(t instanceof Uint8Array&&(t=$(t)),t.toString()===this.toString())}};function ji(r,t){if(t=t??gu,r.charAt(0)==="1"||r.charAt(0)==="Q"){let e=Te(ut.decode(`z${r}`));return r.startsWith("12D")?new Ur({multihash:e}):r.startsWith("16U")?new Pr({multihash:e}):new Cr({multihash:e})}return i0(gu.decode(r))}function i0(r){try{let t=Te(r);if(t.code===pe.code){if(t.digest.length===Gi)return new Ur({multihash:t});if(t.digest.length===zi)return new Pr({multihash:t})}if(t.code===At.code)return new Cr({multihash:t})}catch{return a0(Mt.decode(r))}throw new Error("Supplied PeerID CID is invalid")}function a0(r){if(r?.multihash==null||r.version==null||r.version===1&&r.code!==yu&&r.code!==$i)throw new Error("Supplied PeerID CID is invalid");if(r.code===$i){let e=$(r.multihash.digest);return new qi(new URL(e))}let t=r.multihash;if(t.code===At.code)return new Cr({multihash:r.multihash});if(t.code===pe.code){if(t.digest.length===Gi)return new Ur({multihash:r.multihash});if(t.digest.length===zi)return new Pr({multihash:r.multihash})}throw new Error("Supplied PeerID CID is invalid")}async function Wi(r,t){return r.length===Gi?new Ur({multihash:jt(pe.code,r),privateKey:t}):r.length===zi?new Pr({multihash:jt(pe.code,r),privateKey:t}):new Cr({multihash:await At.digest(r),publicKey:r,privateKey:t})}var bu=Symbol.for("@achingbrain/uint8arraylist");function wu(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 Hs(r){return!!r?.[bu]}var at=class r{bufs;length;[bu]=!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(Hs(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(Hs(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=wu(this.bufs,t);return e.buf[e.index]}set(t,e){let n=wu(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(Hs(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,f=e>a&&e<=c;if(l&&f){if(t===a&&e===c){n.push(i);break}let u=t-a;n.push(i.subarray(u,u+(e-t)));break}if(l){if(t===0){n.push(i);continue}n.push(i.subarray(t-a));continue}if(f){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(!Hs(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 u=0;u<o;u++)i[u]=-1;for(let u=0;u<s;u++)i[n[u]]=u;let a=i,c=this.byteLength-n.byteLength,l=n.byteLength-1,f;for(let u=e;u<=c;u+=f){f=0;for(let g=l;g>=0;g--){let m=this.get(u+g);if(n[g]!==m){f=Math.max(1,g-a[m]);break}}if(f===0)return u}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=yt(1);new DataView(n.buffer,n.byteOffset,n.byteLength).setInt8(0,e),this.write(n,t)}getInt16(t,e){let n=this.subarray(t,t+2);return new DataView(n.buffer,n.byteOffset,n.byteLength).getInt16(0,e)}setInt16(t,e,n){let s=mt(2);new DataView(s.buffer,s.byteOffset,s.byteLength).setInt16(0,e,n),this.write(s,t)}getInt32(t,e){let n=this.subarray(t,t+4);return new DataView(n.buffer,n.byteOffset,n.byteLength).getInt32(0,e)}setInt32(t,e,n){let s=mt(4);new DataView(s.buffer,s.byteOffset,s.byteLength).setInt32(0,e,n),this.write(s,t)}getBigInt64(t,e){let n=this.subarray(t,t+8);return new DataView(n.buffer,n.byteOffset,n.byteLength).getBigInt64(0,e)}setBigInt64(t,e,n){let s=mt(8);new DataView(s.buffer,s.byteOffset,s.byteLength).setBigInt64(0,e,n),this.write(s,t)}getUint8(t){let e=this.subarray(t,t+1);return new DataView(e.buffer,e.byteOffset,e.byteLength).getUint8(0)}setUint8(t,e){let n=yt(1);new DataView(n.buffer,n.byteOffset,n.byteLength).setUint8(0,e),this.write(n,t)}getUint16(t,e){let n=this.subarray(t,t+2);return new DataView(n.buffer,n.byteOffset,n.byteLength).getUint16(0,e)}setUint16(t,e,n){let s=mt(2);new DataView(s.buffer,s.byteOffset,s.byteLength).setUint16(0,e,n),this.write(s,t)}getUint32(t,e){let n=this.subarray(t,t+4);return new DataView(n.buffer,n.byteOffset,n.byteLength).getUint32(0,e)}setUint32(t,e,n){let s=mt(4);new DataView(s.buffer,s.byteOffset,s.byteLength).setUint32(0,e,n),this.write(s,t)}getBigUint64(t,e){let n=this.subarray(t,t+8);return new DataView(n.buffer,n.byteOffset,n.byteLength).getBigUint64(0,e)}setBigUint64(t,e,n){let s=mt(8);new DataView(s.buffer,s.byteOffset,s.byteLength).setBigUint64(0,e,n),this.write(s,t)}getFloat32(t,e){let n=this.subarray(t,t+4);return new DataView(n.buffer,n.byteOffset,n.byteLength).getFloat32(0,e)}setFloat32(t,e,n){let s=mt(4);new DataView(s.buffer,s.byteOffset,s.byteLength).setFloat32(0,e,n),this.write(s,t)}getFloat64(t,e){let n=this.subarray(t,t+8);return new DataView(n.buffer,n.byteOffset,n.byteLength).getFloat64(0,e)}setFloat64(t,e,n){let s=mt(8);new DataView(s.buffer,s.byteOffset,s.byteLength).setFloat64(0,e,n),this.write(s,t)}equals(t){if(t==null||!(t instanceof r)||t.bufs.length!==this.bufs.length)return!1;for(let e=0;e<this.bufs.length;e++)if(!ft(this.bufs[e],t.bufs[e]))return!1;return!0}static fromUint8Arrays(t,e){let n=new r;return n.bufs=t,e==null&&(e=t.reduce((s,o)=>s+o.byteLength,0)),n.length=e,n}};function Os(r){return r[Symbol.asyncIterator]!=null}var Ms=r=>{let t=dt(r),e=yt(t);return ie(r,e),Ms.bytes=t,e};Ms.bytes=0;function xu(r,t){t=t??{};let e=t.lengthEncoder??Ms;function*n(s){let o=e(s.byteLength);o instanceof Uint8Array?yield o:yield*o,s instanceof Uint8Array?yield s:yield*s}return Os(r)?async function*(){for await(let s of r)yield*n(s)}():function*(){for(let s of r)yield*n(s)}()}xu.single=(r,t)=>{t=t??{};let e=t.lengthEncoder??Ms;return new at(e(r.byteLength),r)};var Ks=class extends Error{name="InvalidMessageLengthError";code="ERR_INVALID_MSG_LENGTH"},Fs=class extends Error{name="InvalidDataLengthError";code="ERR_MSG_DATA_TOO_LONG"},$s=class extends Error{name="InvalidDataLengthLengthError";code="ERR_MSG_LENGTH_TOO_LONG"},bn=class extends Error{name="UnexpectedEOFError";code="ERR_UNEXPECTED_EOF"};var c0=8,l0=1024*1024*4,lr;(function(r){r[r.LENGTH=0]="LENGTH",r[r.DATA=1]="DATA"})(lr||(lr={}));var Yi=r=>{let t=Qt(r);return Yi.bytes=dt(t),t};Yi.bytes=0;function xn(r,t){let e=new at,n=lr.LENGTH,s=-1,o=t?.lengthDecoder??Yi,i=t?.maxLengthLength??c0,a=t?.maxDataLength??l0;function*c(){for(;e.byteLength>0;){if(n===lr.LENGTH)try{if(s=o(e),s<0)throw new Ks("Invalid message length");if(s>a)throw new Fs("Message length too long");let l=o.bytes;e.consume(l),t?.onLength!=null&&t.onLength(s),n=lr.DATA}catch(l){if(l instanceof RangeError){if(e.byteLength>i)throw new $s("Message length length too long");break}throw l}if(n===lr.DATA){if(e.byteLength<s)break;let l=e.sublist(0,s);e.consume(s),t?.onData!=null&&t.onData(l),yield l,n=lr.LENGTH}}}return Os(r)?async function*(){for await(let l of r)e.append(l),yield*c();if(e.byteLength>0)throw new bn("Unexpected end of input")}():function*(){for(let l of r)e.append(l),yield*c();if(e.byteLength>0)throw new bn("Unexpected end of input")}()}xn.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 xn(n,{...t??{},onLength:o=>{e=o}})};function Lt(){let r={};return r.promise=new Promise((t,e)=>{r.resolve=t,r.reject=e}),r}var qs=class extends Error{type;code;constructor(t,e,n){super(t??"The operation was aborted"),this.type="aborted",this.name=n??"AbortError",this.code=e??"ABORT_ERR"}};async function Pt(r,t,e){if(t==null)return r;if(t.aborted)return Promise.reject(new qs(e?.errorMessage,e?.errorCode,e?.errorName));let n,s=new qs(e?.errorMessage,e?.errorCode,e?.errorName);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 Zi=class{readNext;haveNext;ended;nextResult;constructor(){this.ended=!1,this.readNext=Lt(),this.haveNext=Lt()}[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=Lt(),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=Lt(),await Pt(this.readNext.promise,e?.signal,e)}};function Eu(){return new Zi}var Gs=class extends Error{name="UnexpectedEOFError";code="ERR_UNEXPECTED_EOF"};var Xi=class extends Error{code;constructor(t,e){super(t),this.code=e}},Ji=class extends Xi{type;constructor(t){super(t,"ABORT_ERR"),this.type="aborted",this.name="AbortError"}};function vu(r,t){let e=Eu();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 at;return{read:async(i,a)=>{a?.signal?.throwIfAborted();let c,l=new Promise((f,u)=>{c=()=>{u(new Ji("Read aborted"))},a?.signal?.addEventListener("abort",c)});try{if(i==null){let{done:u,value:g}=await Promise.race([n.next(),l]);return u===!0?new at:g}for(;s.byteLength<i;){let{value:u,done:g}=await Promise.race([n.next(),l]);if(g===!0)throw new Gs("unexpected end of input");s.append(u)}let f=s.sublist(0,i);return s.consume(i),f}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 zs=class extends Error{name="InvalidMessageLengthError";code="ERR_INVALID_MSG_LENGTH"},js=class extends Error{name="InvalidDataLengthError";code="ERR_MSG_DATA_TOO_LONG"},Ws=class extends Error{name="InvalidDataLengthLengthError";code="ERR_MSG_LENGTH_TOO_LONG"};function Qi(r,t={}){let e=vu(r,t);t.maxDataLength!=null&&t.maxLengthLength==null&&(t.maxLengthLength=dt(t.maxDataLength));let n=t?.lengthDecoder??Qt,s=t?.lengthEncoder??ie;return{read:async i=>{let a=-1,c=new at;for(;;){c.append(await e.read(1,i));try{a=n(c)}catch(l){if(l instanceof RangeError)continue;throw l}if(a<0)throw new zs("Invalid message length");if(t?.maxLengthLength!=null&&c.byteLength>t.maxLengthLength)throw new Ws("message length length too long");if(a>-1)break}if(t?.maxDataLength!=null&&a>t.maxDataLength)throw new js("message length too long");return e.read(a,i)},write:async(i,a)=>{await e.write(new at(s(i.byteLength),i),a)},writeV:async(i,a)=>{let c=new at(...i.flatMap(l=>[s(l.byteLength),l]));await e.write(c,a)},unwrap:()=>e.unwrap()}}function ta(){let r=Lt(),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 Bu(){let r=ta(),t=ta();return[{source:r.source,sink:t.sink},{source:t.source,sink:r.sink}]}var Ys=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}},Dr=class{size;hwm;head;tail;constructor(t={}){this.hwm=t.splitLimit??16,this.head=new Ys(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 Ys(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 ea=class extends Error{type;code;constructor(t,e){super(t??"The operation was aborted"),this.type="aborted",this.code=e??"ABORT_ERR"}};function Vr(r={}){return u0(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 u0(r,t){t=t??{};let e=t.onEnd,n=new Dr,s,o,i,a=Lt(),c=async()=>{try{return n.isEmpty()?i?{done:!0}:await new Promise((d,E)=>{o=w=>{o=null,n.push(w);try{d(r(n))}catch(x){E(x)}return s}}):r(n)}finally{n.isEmpty()&&queueMicrotask(()=>{a.resolve(),a=Lt()})}},l=d=>o!=null?o(d):(n.push(d),s),f=d=>(n=new Dr,o!=null?o({error:d}):(n.push({error:d}),s)),u=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?f(d):l({done:!0})),m=()=>(n=new Dr,g(),{done:!0}),p=d=>(g(d),{done:!0});if(s={[Symbol.asyncIterator](){return this},next:c,return:m,throw:p,push:u,end:g,get readableLength(){return n.size},onEmpty:async d=>{let E=d?.signal;if(E?.throwIfAborted(),n.isEmpty())return;let w,x;E!=null&&(w=new Promise((I,N)=>{x=()=>{N(new ea)},E.addEventListener("abort",x)}));try{await Promise.race([a.promise,w])}finally{x!=null&&E!=null&&E?.removeEventListener("abort",x)}}},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:u,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 f0(r){return r[Symbol.asyncIterator]!=null}function h0(...r){let t=[];for(let e of r)f0(e)||t.push(e);return t.length===r.length?function*(){for(let e of t)yield*e}():async function*(){let e=Vr({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 Au=h0;function Su(r,...t){if(r==null)throw new Error("Empty pipeline");if(ra(r)){let n=r;r=()=>n.source}else if(Iu(r)||ku(r)){let n=r;r=()=>n}let e=[r,...t];if(e.length>1&&ra(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++)ra(e[n])&&(e[n]=p0(e[n]));return d0(...e)}var d0=(...r)=>{let t;for(;r.length>0;)t=r.shift()(t);return t},ku=r=>r?.[Symbol.asyncIterator]!=null,Iu=r=>r?.[Symbol.iterator]!=null,ra=r=>r==null?!1:r.sink!=null&&r.source!=null,p0=r=>t=>{let e=r.sink(t);if(e?.then!=null){let n=Vr({objectMode:!0});e.then(()=>{n.end()},i=>{n.end(i)});let s,o=r.source;if(ku(o))s=async function*(){yield*o,n.end()};else if(Iu(o))s=function*(){yield*o,n.end()};else throw new Error("Unknown duplex source type - must be Iterable or AsyncIterable");return Au(n,s())}return r.source};var Hr=!!globalThis.process?.env?.DUMP_SESSION_KEYS;function Zs(r){if(!Number.isSafeInteger(r)||r<0)throw new Error(`positive integer expected, not ${r}`)}function na(r){if(typeof r!="boolean")throw new Error(`boolean expected, not ${r}`)}function sa(r){return r instanceof Uint8Array||r!=null&&typeof r=="object"&&r.constructor.name==="Uint8Array"}function Ht(r,...t){if(!sa(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 oa(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 _u(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 _e=r=>new Uint32Array(r.buffer,r.byteOffset,Math.floor(r.byteLength/4)),Ru=r=>new DataView(r.buffer,r.byteOffset,r.byteLength),g0=new Uint8Array(new Uint32Array([287454020]).buffer)[0]===68;if(!g0)throw new Error("Non little-endian hardware is not supported");function m0(r){if(typeof r!="string")throw new Error(`string expected, got ${typeof r}`);return new Uint8Array(new TextEncoder().encode(r))}function Xs(r){if(typeof r=="string")r=m0(r);else if(sa(r))r=Js(r);else throw new Error(`Uint8Array expected, got ${typeof r}`);return r}function Nu(r,t){if(t==null||typeof t!="object")throw new Error("options must be defined");return Object.assign(r,t)}function Tu(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 ia=(r,t)=>(Object.assign(t,r),t);function aa(r,t,e,n){if(typeof r.setBigUint64=="function")return r.setBigUint64(t,e,n);let s=BigInt(32),o=BigInt(4294967295),i=Number(e>>s&o),a=Number(e&o),c=n?4:0,l=n?0:4;r.setUint32(t+c,i,n),r.setUint32(t+l,a,n)}function Js(r){return Uint8Array.from(r)}function Re(...r){for(let t=0;t<r.length;t++)r[t].fill(0)}var Cu=r=>Uint8Array.from(r.split("").map(t=>t.charCodeAt(0))),y0=Cu("expand 16-byte k"),w0=Cu("expand 32-byte k"),b0=_e(y0),Uu=_e(w0),_x=Uu.slice();function D(r,t){return r<<t|r>>>32-t}function ca(r){return r.byteOffset%4===0}var Qs=64,x0=16,Pu=2**32-1,Lu=new Uint32Array;function E0(r,t,e,n,s,o,i,a){let c=s.length,l=new Uint8Array(Qs),f=_e(l),u=ca(s)&&ca(o),g=u?_e(s):Lu,m=u?_e(o):Lu;for(let p=0;p<c;i++){if(r(t,e,n,f,i,a),i>=Pu)throw new Error("arx: counter overflow");let h=Math.min(Qs,c-p);if(u&&h===Qs){let d=p/4;if(p%4!==0)throw new Error("arx: invalid block position");for(let E=0,w;E<x0;E++)w=d+E,m[w]=g[w]^f[E];p+=Qs;continue}for(let d=0,E;d<h;d++)E=p+d,o[E]=s[E]^l[d];p+=h}}function la(r,t){let{allowShortKeys:e,extendNonceFn:n,counterLength:s,counterRight:o,rounds:i}=Nu({allowShortKeys:!1,counterLength:8,counterRight:!1,rounds:20},t);if(typeof r!="function")throw new Error("core must be a function");return Zs(s),Zs(i),na(o),na(e),(a,c,l,f,u=0)=>{Ht(a),Ht(c),Ht(l);let g=l.length;if(f===void 0&&(f=new Uint8Array(g)),Ht(f),Zs(u),u<0||u>=Pu)throw new Error("arx: counter overflow");if(f.length<g)throw new Error(`arx: output (${f.length}) is shorter than data (${g})`);let m=[],p=a.length,h,d;if(p===32)m.push(h=Js(a)),d=Uu;else if(p===16&&e)h=new Uint8Array(32),h.set(a),h.set(a,16),d=b0,m.push(h);else throw new Error(`arx: invalid 32-byte key, got length=${p}`);ca(c)||m.push(c=Js(c));let E=_e(h);if(n){if(c.length!==24)throw new Error("arx: extended nonce must be 24 bytes");n(d,E,_e(c.subarray(0,16)),E),c=c.subarray(16)}let w=16-s;if(w!==c.length)throw new Error(`arx: nonce must be ${w} or 16 bytes`);if(w!==12){let I=new Uint8Array(12);I.set(c,o?0:12-c.length),c=I,m.push(c)}let x=_e(c);return E0(r,d,E,x,l,f,u,i),Re(...m),f}}var It=(r,t)=>r[t++]&255|(r[t++]&255)<<8,ua=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=Xs(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 f=0;f<8;f++)this.pad[f]=It(t,16+2*f)}process(t,e,n=!1){let s=n?0:2048,{h:o,r:i}=this,a=i[0],c=i[1],l=i[2],f=i[3],u=i[4],g=i[5],m=i[6],p=i[7],h=i[8],d=i[9],E=It(t,e+0),w=It(t,e+2),x=It(t,e+4),I=It(t,e+6),N=It(t,e+8),S=It(t,e+10),R=It(t,e+12),_=It(t,e+14),V=o[0]+(E&8191),U=o[1]+((E>>>13|w<<3)&8191),T=o[2]+((w>>>10|x<<6)&8191),F=o[3]+((x>>>7|I<<9)&8191),K=o[4]+((I>>>4|N<<12)&8191),k=o[5]+(N>>>1&8191),b=o[6]+((N>>>14|S<<2)&8191),y=o[7]+((S>>>11|R<<5)&8191),B=o[8]+((R>>>8|_<<8)&8191),A=o[9]+(_>>>5|s),v=0,L=v+V*a+U*(5*d)+T*(5*h)+F*(5*p)+K*(5*m);v=L>>>13,L&=8191,L+=k*(5*g)+b*(5*u)+y*(5*f)+B*(5*l)+A*(5*c),v+=L>>>13,L&=8191;let P=v+V*c+U*a+T*(5*d)+F*(5*h)+K*(5*p);v=P>>>13,P&=8191,P+=k*(5*m)+b*(5*g)+y*(5*u)+B*(5*f)+A*(5*l),v+=P>>>13,P&=8191;let H=v+V*l+U*c+T*a+F*(5*d)+K*(5*h);v=H>>>13,H&=8191,H+=k*(5*p)+b*(5*m)+y*(5*g)+B*(5*u)+A*(5*f),v+=H>>>13,H&=8191;let O=v+V*f+U*l+T*c+F*a+K*(5*d);v=O>>>13,O&=8191,O+=k*(5*h)+b*(5*p)+y*(5*m)+B*(5*g)+A*(5*u),v+=O>>>13,O&=8191;let q=v+V*u+U*f+T*l+F*c+K*a;v=q>>>13,q&=8191,q+=k*(5*d)+b*(5*h)+y*(5*p)+B*(5*m)+A*(5*g),v+=q>>>13,q&=8191;let j=v+V*g+U*u+T*f+F*l+K*c;v=j>>>13,j&=8191,j+=k*a+b*(5*d)+y*(5*h)+B*(5*p)+A*(5*m),v+=j>>>13,j&=8191;let X=v+V*m+U*g+T*u+F*f+K*l;v=X>>>13,X&=8191,X+=k*c+b*a+y*(5*d)+B*(5*h)+A*(5*p),v+=X>>>13,X&=8191;let lt=v+V*p+U*m+T*g+F*u+K*f;v=lt>>>13,lt&=8191,lt+=k*l+b*c+y*a+B*(5*d)+A*(5*h),v+=lt>>>13,lt&=8191;let rt=v+V*h+U*p+T*m+F*g+K*u;v=rt>>>13,rt&=8191,rt+=k*f+b*l+y*c+B*a+A*(5*d),v+=rt>>>13,rt&=8191;let et=v+V*d+U*h+T*p+F*m+K*g;v=et>>>13,et&=8191,et+=k*u+b*f+y*l+B*c+A*a,v+=et>>>13,et&=8191,v=(v<<2)+v|0,v=v+L|0,L=v&8191,v=v>>>13,P+=v,o[0]=L,o[1]=P,o[2]=H,o[3]=O,o[4]=q,o[5]=j,o[6]=X,o[7]=lt,o[8]=rt,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;Re(n)}update(t){oa(this);let{buffer:e,blockLen:n}=this;t=Xs(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(){Re(this.h,this.r,this.buffer,this.pad)}digestInto(t){oa(this),_u(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 v0(r){let t=(n,s)=>r(s).update(Xs(n)).digest(),e=r(new Uint8Array(32));return t.outputLen=e.outputLen,t.blockLen=e.blockLen,t.create=n=>r(n),t}var Du=v0(r=>new ua(r));function Ou(r,t,e,n,s,o=20){let i=r[0],a=r[1],c=r[2],l=r[3],f=t[0],u=t[1],g=t[2],m=t[3],p=t[4],h=t[5],d=t[6],E=t[7],w=s,x=e[0],I=e[1],N=e[2],S=i,R=a,_=c,V=l,U=f,T=u,F=g,K=m,k=p,b=h,y=d,B=E,A=w,v=x,L=I,P=N;for(let O=0;O<o;O+=2)S=S+U|0,A=D(A^S,16),k=k+A|0,U=D(U^k,12),S=S+U|0,A=D(A^S,8),k=k+A|0,U=D(U^k,7),R=R+T|0,v=D(v^R,16),b=b+v|0,T=D(T^b,12),R=R+T|0,v=D(v^R,8),b=b+v|0,T=D(T^b,7),_=_+F|0,L=D(L^_,16),y=y+L|0,F=D(F^y,12),_=_+F|0,L=D(L^_,8),y=y+L|0,F=D(F^y,7),V=V+K|0,P=D(P^V,16),B=B+P|0,K=D(K^B,12),V=V+K|0,P=D(P^V,8),B=B+P|0,K=D(K^B,7),S=S+T|0,P=D(P^S,16),y=y+P|0,T=D(T^y,12),S=S+T|0,P=D(P^S,8),y=y+P|0,T=D(T^y,7),R=R+F|0,A=D(A^R,16),B=B+A|0,F=D(F^B,12),R=R+F|0,A=D(A^R,8),B=B+A|0,F=D(F^B,7),_=_+K|0,v=D(v^_,16),k=k+v|0,K=D(K^k,12),_=_+K|0,v=D(v^_,8),k=k+v|0,K=D(K^k,7),V=V+U|0,L=D(L^V,16),b=b+L|0,U=D(U^b,12),V=V+U|0,L=D(L^V,8),b=b+L|0,U=D(U^b,7);let H=0;n[H++]=i+S|0,n[H++]=a+R|0,n[H++]=c+_|0,n[H++]=l+V|0,n[H++]=f+U|0,n[H++]=u+T|0,n[H++]=g+F|0,n[H++]=m+K|0,n[H++]=p+k|0,n[H++]=h+b|0,n[H++]=d+y|0,n[H++]=E+B|0,n[H++]=w+A|0,n[H++]=x+v|0,n[H++]=I+L|0,n[H++]=N+P|0}function B0(r,t,e,n){let s=r[0],o=r[1],i=r[2],a=r[3],c=t[0],l=t[1],f=t[2],u=t[3],g=t[4],m=t[5],p=t[6],h=t[7],d=e[0],E=e[1],w=e[2],x=e[3];for(let N=0;N<20;N+=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,E=D(E^o,16),m=m+E|0,l=D(l^m,12),o=o+l|0,E=D(E^o,8),m=m+E|0,l=D(l^m,7),i=i+f|0,w=D(w^i,16),p=p+w|0,f=D(f^p,12),i=i+f|0,w=D(w^i,8),p=p+w|0,f=D(f^p,7),a=a+u|0,x=D(x^a,16),h=h+x|0,u=D(u^h,12),a=a+u|0,x=D(x^a,8),h=h+x|0,u=D(u^h,7),s=s+l|0,x=D(x^s,16),p=p+x|0,l=D(l^p,12),s=s+l|0,x=D(x^s,8),p=p+x|0,l=D(l^p,7),o=o+f|0,d=D(d^o,16),h=h+d|0,f=D(f^h,12),o=o+f|0,d=D(d^o,8),h=h+d|0,f=D(f^h,7),i=i+u|0,E=D(E^i,16),g=g+E|0,u=D(u^g,12),i=i+u|0,E=D(E^i,8),g=g+E|0,u=D(u^g,7),a=a+c|0,w=D(w^a,16),m=m+w|0,c=D(c^m,12),a=a+c|0,w=D(w^a,8),m=m+w|0,c=D(c^m,7);let I=0;n[I++]=s,n[I++]=o,n[I++]=i,n[I++]=a,n[I++]=d,n[I++]=E,n[I++]=w,n[I++]=x}var A0=la(Ou,{counterRight:!1,counterLength:4,allowShortKeys:!1}),S0=la(Ou,{counterRight:!1,counterLength:8,extendNonceFn:B0,allowShortKeys:!1});var k0=new Uint8Array(16),Vu=(r,t)=>{r.update(t);let e=t.length%16;e&&r.update(k0.subarray(e))},I0=new Uint8Array(32);function Hu(r,t,e,n,s){let o=r(t,e,I0),i=Du.create(o);s&&Vu(i,s),Vu(i,n);let a=new Uint8Array(16),c=Ru(a);aa(c,0,BigInt(s?s.length:0),!0),aa(c,8,BigInt(n.length),!0),i.update(a);let l=i.digest();return Re(o,a),l}var Mu=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=Hu(r,t,e,i.subarray(0,-16),n);return i.set(l,a),Re(l),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),f=o.subarray(-16),u=Hu(r,t,e,l,n);if(!Tu(f,u))throw new Error("invalid tag");return r(t,e,l,i,1),Re(u),i}}),fa=ia({blockSize:64,nonceLength:12,tagLength:16},Mu(A0)),Vx=ia({blockSize:64,nonceLength:24,tagLength:16},Mu(S0));function Fu(r,t,e){return We(r),e===void 0&&(e=new Uint8Array(r.outputLen)),He(r,Yt(e),Yt(t))}var ha=new Uint8Array([0]),Ku=new Uint8Array;function $u(r,t,e,n=32){if(We(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=Ku);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++)ha[0]=l+1,a.update(l===0?Ku:c).update(e).update(ha).digestInto(c),o.set(c,r.outputLen*l),i._cloneInto(a);return i.destroy(),a.destroy(),c.fill(0),ha.fill(0),o.slice(0,n)}var da={hashSHA256(r){return Lr(r.subarray())},getHKDF(r,t){let e=Fu(Lr,t,r),s=$u(Lr,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=Qr.utils.randomPrivateKey();return{publicKey:Qr.getPublicKey(r),privateKey:r}},generateX25519KeyPairFromSeed(r){return{publicKey:Qr.getPublicKey(r),privateKey:r}},generateX25519SharedKey(r,t){return Qr.getSharedSecret(r.subarray(),t.subarray())},chaCha20Poly1305Encrypt(r,t,e,n){return fa(n,t,e).encrypt(r.subarray())},chaCha20Poly1305Decrypt(r,t,e,n,s){return fa(n,t,e).decrypt(r.subarray(),s)}};var qu=da;function Gu(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 Or=r=>{let t=yt(2);return t[0]=r>>8,t[1]=r,t};Or.bytes=2;var En=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)};En.bytes=2;function zu(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 pa(r,t){!t.enabled||!Hr||(r?(t(`LOCAL_STATIC_PUBLIC_KEY ${$(r.publicKey,"hex")}`),t(`LOCAL_STATIC_PRIVATE_KEY ${$(r.privateKey,"hex")}`)):t("Missing local static keys."))}function ga(r,t){!t.enabled||!Hr||(r?(t(`LOCAL_PUBLIC_EPHEMERAL_KEY ${$(r.publicKey,"hex")}`),t(`LOCAL_PRIVATE_EPHEMERAL_KEY ${$(r.privateKey,"hex")}`)):t("Missing local ephemeral keys."))}function ju(r,t){!t.enabled||!Hr||t(r?`REMOTE_STATIC_PUBLIC_KEY ${$(r.subarray(),"hex")}`:"Missing remote static public key.")}function ma(r,t){!t.enabled||!Hr||t(r?`REMOTE_EPHEMERAL_PUBLIC_KEY ${$(r.subarray(),"hex")}`:"Missing remote ephemeral keys.")}function ya(r,t,e){!e.enabled||!Hr||(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 to=class r extends Error{code;constructor(t="Unexpected Peer"){super(t),this.code=r.code}static code="ERR_UNEXPECTED_PEER"},Mr=class r extends Error{code;constructor(t="Invalid crypto exchange"){super(t),this.code=r.code}static code="ERR_INVALID_CRYPTO_EXCHANGE"};var _0=0,R0=4294967295,N0="Cipherstate has reached maximum n, a new handshake must be performed",eo=class{n;bytes;view;constructor(t=_0){this.n=t,this.bytes=mt(12),this.view=new DataView(this.bytes.buffer,this.bytes.byteOffset,this.bytes.byteLength),this.view.setUint32(4,t,!0)}increment(){this.n++,this.view.setUint32(4,this.n,!0)}getBytes(){return this.bytes}getUint64(){return this.n}assertValue(){if(this.n>R0)throw new Error(N0)}};var ur=mt(0),Kr=class{k;n;crypto;constructor(t,e=void 0,n=0){this.crypto=t,this.k=e,this.n=new eo(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}},wa=class{cs;ck;h;crypto;constructor(t,e){this.crypto=t;let n=W(e,"utf-8");this.h=T0(t,n),this.ck=this.h,this.cs=new Kr(t)}mixKey(t){let[e,n]=this.crypto.hkdf(this.ck,t);this.ck=e,this.cs=new Kr(this.crypto,n)}mixHash(t){this.h=this.crypto.hash(new at(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,ur);return[new Kr(this.crypto,t),new Kr(this.crypto,e)]}},ba=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 wa(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()}},vn=class extends ba{writeMessageA(t){return new at(this.writeE(),this.ss.encryptAndHash(t))}writeMessageB(t){let e=this.writeE();this.writeEE();let n=this.writeS();return this.writeES(),new at(e,n,this.ss.encryptAndHash(t))}writeMessageC(t){let e=this.writeS();return this.writeSE(),new at(e,this.ss.encryptAndHash(t))}readMessageA(t){try{return this.readE(t),this.ss.decryptAndHash(t.sublist(32))}catch(e){throw new Mr(`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 Mr(`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 Mr(`handshake stage 2 validation fail: ${e.message}`)}}};function T0(r,t){if(t.length<=32){let e=mt(32);return e.set(t),e}else return r.hash(t)}var ro;(function(r){let t;r.codec=()=>(t==null&&(t=nr((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=>rr(e,r.codec()),r.decode=e=>tr(e,r.codec())})(ro||(ro={}));var Bn;(function(r){let t;r.codec=()=>(t==null&&(t=nr((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),ro.codec().encode(e.extensions,n)),s.lengthDelimited!==!1&&n.ldelim()},(e,n)=>{let s={identityKey:mt(0),identitySig:mt(0)},o=n==null?e.len:e.pos+n;for(;e.pos<o;){let i=e.uint32();switch(i>>>3){case 1:{s.identityKey=e.bytes();break}case 2:{s.identitySig=e.bytes();break}case 4:{s.extensions=ro.codec().decode(e,e.uint32());break}default:{e.skipType(i&7);break}}}return s})),t),r.encode=e=>rr(e,r.codec()),r.decode=e=>tr(e,r.codec())})(Bn||(Bn={}));async function xa(r,t,e){let n=await r.sign(Wu(t));return Bn.encode({identityKey:r.public.bytes,identitySig:n,extensions:e})}async function Ea(r,t,e){try{let n=Bn.decode(r);if(e){let i=e.subarray();if(!ft(i,n.identityKey))throw new Error(`Payload identity key ${$(n.identityKey,"hex")} does not match expected remote identity key ${$(i,"hex")}`)}if(!t)throw new Error("Remote static does not exist");let s=Wu(t);if(!await pu(n.identityKey).verify(s,n.identitySig))throw new Error("Invalid payload signature");return n}catch(n){throw new to(n.message)}}function Wu(r){let t=W("noise-libp2p-static-key:");return r instanceof Uint8Array?Et([t,r],t.length+r.length):(r.prepend(t),r)}async function Yu(r){let{log:t,connection:e,crypto:n,privateKey:s,prologue:o,s:i,remoteIdentityKey:a,extensions:c}=r,l=await xa(s,i.publicKey,c),f=new vn({crypto:n,protocolName:"Noise_XX_25519_ChaChaPoly_SHA256",initiator:!0,prologue:o,s:i});pa(f.s,t),t.trace("Stage 0 - Initiator starting to send first message."),await e.write(f.writeMessageA(ur)),t.trace("Stage 0 - Initiator finished sending first message."),ga(f.e,t),t.trace("Stage 1 - Initiator waiting to receive first message from responder...");let u=f.readMessageB(await e.read());t.trace("Stage 1 - Initiator received the message."),ma(f.re,t),ju(f.rs,t),t.trace("Initiator going to check remote's signature...");let g=await Ea(u,f.rs,a);t.trace("All good with the signature!"),t.trace("Stage 2 - Initiator sending third handshake message."),await e.write(f.writeMessageC(l)),t.trace("Stage 2 - Initiator sent message with signed payload.");let[m,p]=f.ss.split();return ya(m,p,t),{payload:g,encrypt:h=>m.encryptWithAd(ur,h),decrypt:(h,d)=>p.decryptWithAd(ur,h,d)}}async function Zu(r){let{log:t,connection:e,crypto:n,privateKey:s,prologue:o,s:i,remoteIdentityKey:a,extensions:c}=r,l=await xa(s,i.publicKey,c),f=new vn({crypto:n,protocolName:"Noise_XX_25519_ChaChaPoly_SHA256",initiator:!1,prologue:o,s:i});pa(f.s,t),t.trace("Stage 0 - Responder waiting to receive first message."),f.readMessageA(await e.read()),t.trace("Stage 0 - Responder received first message."),ma(f.re,t),t.trace("Stage 1 - Responder sending out first message with signed payload and static key."),await e.write(f.writeMessageB(l)),t.trace("Stage 1 - Responder sent the second handshake message with signed payload."),ga(f.e,t),t.trace("Stage 2 - Responder waiting for third handshake message...");let u=f.readMessageC(await e.read());t.trace("Stage 2 - Responder received the message, finished handshake.");let g=await Ea(u,f.rs,a),[m,p]=f.ss.split();return ya(m,p,t),{payload:g,encrypt:h=>p.encryptWithAd(ur,h),decrypt:(h,d)=>m.decryptWithAd(ur,h,d)}}var Ju=16;function Qu(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 at(Or(i.byteLength),i)}}}function tf(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-Ju<s)throw new Error("Invalid chunk");let i=n.sublist(s,o),a=n.subarray(s,o-Ju);try{let c=r.decrypt(i,a);t?.decryptedPackets.increment(),yield c}catch(c){throw t?.decryptErrors.increment(),c}}}}var no=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??qu;this.crypto=Gu(c),this.extensions=s,this.metrics=a?zu(a):void 0,n?this.staticKey=c.generateX25519KeyPairFromSeed(n):this.staticKey=c.generateX25519KeyPair(),this.prologue=i??mt(0)}[Symbol.toStringTag]="@chainsafe/libp2p-noise";[Tn]=["@libp2p/connection-encryption","@chainsafe/libp2p-noise"];async secureOutbound(...t){let{localPeer:e,connection:n,remotePeer:s}=this.parseArgs(t),o=Qi(n,{lengthEncoder:Or,lengthDecoder:En,maxDataLength:65535});if(!e.privateKey)throw new M("local peerId does not contain private key","ERR_NO_PRIVATE_KEY");let i=await Fi(e.privateKey),a=s?.publicKey,c=await this.performHandshakeInitiator(o,i,a),l=await this.createSecureConnection(o,c);return n.source=l.source,n.sink=l.sink,{conn:n,remoteExtensions:c.payload.extensions,remotePeer:await Wi(c.payload.identityKey)}}async secureInbound(...t){let{localPeer:e,connection:n,remotePeer:s}=this.parseArgs(t),o=Qi(n,{lengthEncoder:Or,lengthDecoder:En,maxDataLength:65535});if(!e.privateKey)throw new M("local peerId does not contain private key","ERR_NO_PRIVATE_KEY");let i=await Fi(e.privateKey),a=s?.publicKey,c=await this.performHandshakeResponder(o,i,a),l=await this.createSecureConnection(o,c);return n.source=l.source,n.sink=l.sink,{conn:n,remoteExtensions:c.payload.extensions,remotePeer:await Wi(c.payload.identityKey)}}async performHandshakeInitiator(t,e,n){let s;try{s=await Yu({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 Zu({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]=Bu(),o=t.unwrap();return await Su(n,Qu(e,this.metrics),o,i=>xn(i,{lengthDecoder:En}),tf(e,this.metrics),n),s}parseArgs(t){return nc(t[0])?{localPeer:t[0],connection:t[1],remotePeer:t[2]}:{localPeer:this.components.peerId,connection:t[0],remotePeer:t[1]}}};function ef(r={}){return t=>new no(t,r)}var so=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 f=this.readAtomically(()=>{let u=this.readChar();if(u===void 0)return;let g=Number.parseInt(u,t);if(!Number.isNaN(g))return g});if(f===void 0)break;if(o*=t,o+=f,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 rf=45,L0=15,Fr=new so;function va(r){if(!(r.length>L0))return Fr.new(r).parseWith(()=>Fr.readIPv4Addr())}function Ba(r){if(r.includes("%")&&(r=r.split("%")[0]),!(r.length>rf))return Fr.new(r).parseWith(()=>Fr.readIPv6Addr())}function oo(r){if(r.includes("%")&&(r=r.split("%")[0]),!(r.length>rf))return Fr.new(r).parseWith(()=>Fr.readIPAddr())}function io(r){return!!va(r)}function ao(r){return!!Ba(r)}function co(r){return!!oo(r)}var E2=parseInt("0xFFFF",16),v2=new Uint8Array([0,0,0,0,0,0,0,0,0,0,255,255]);var of=io,V0=ao,Aa=function(r){let t=0;if(r=r.toString().trim(),of(r)){let e=new Uint8Array(t+4);return r.split(/\./g).forEach(n=>{e[t++]=parseInt(n,10)&255}),e}if(V0(r)){let e=r.split(":",8),n;for(n=0;n<e.length;n++){let o=of(e[n]),i;o&&(i=Aa(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")},af=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 $r={},Sa={},O0=[[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"]];O0.forEach(r=>{let t=M0(...r);Sa[t.code]=t,$r[t.name]=t});function M0(r,t,e,n,s){return{code:r,size:t,name:e,resolvable:!!n,path:!!s}}function Q(r){if(typeof r=="number"){if(Sa[r]!=null)return Sa[r];throw new Error(`no protocol with code: ${r}`)}else if(typeof r=="string"){if($r[r]!=null)return $r[r];throw new Error(`no protocol with name: ${r}`)}throw new Error(`invalid protocol id type: ${typeof r}`)}var nE=Q("ip4"),sE=Q("ip6"),oE=Q("ipcidr");function Ra(r,t){switch(Q(r).code){case 4:case 41:return F0(t);case 42:return _a(t);case 6:case 273:case 33:case 132:return uf(t).toString();case 53:case 54:case 55:case 56:case 400:case 449:case 777:return _a(t);case 421:return z0(t);case 444:return lf(t);case 445:return lf(t);case 466:return G0(t);case 481:return globalThis.encodeURIComponent(_a(t));default:return $(t,"base16")}}function Na(r,t){switch(Q(r).code){case 4:return cf(t);case 41:return cf(t);case 42:return Ia(t);case 6:case 273:case 33:case 132:return Ta(parseInt(t,10));case 53:case 54:case 55:case 56:case 400:case 449:case 777:return Ia(t);case 421:return $0(t);case 444:return j0(t);case 445:return W0(t);case 466:return q0(t);case 481:return Ia(globalThis.decodeURIComponent(t));default:return W(t,"base16")}}var ka=Object.values(oe).map(r=>r.decoder),K0=function(){let r=ka[0].or(ka[1]);return ka.slice(2).forEach(t=>r=r.or(t)),r}();function cf(r){if(!co(r))throw new Error("invalid ip address");return Aa(r)}function F0(r){let t=af(r,0,r.length);if(t==null)throw new Error("ipBuff is required");if(!co(t))throw new Error("invalid ip address");return t}function Ta(r){let t=new ArrayBuffer(2);return new DataView(t).setUint16(0,r),new Uint8Array(t)}function uf(r){return new DataView(r.buffer).getUint16(r.byteOffset)}function Ia(r){let t=W(r),e=Uint8Array.from(ie(t.length));return Et([e,t],e.length+t.length)}function _a(r){let t=Qt(r);if(r=r.slice(dt(t)),r.length!==t)throw new Error("inconsistent lengths");return $(r)}function $0(r){let t;r[0]==="Q"||r[0]==="1"?t=Te(ut.decode(`z${r}`)).bytes:t=Mt.parse(r).multihash.bytes;let e=Uint8Array.from(ie(t.length));return Et([e,t],e.length+t.length)}function q0(r){let t=K0.decode(r),e=Uint8Array.from(ie(t.length));return Et([e,t],e.length+t.length)}function G0(r){let t=Qt(r),e=r.slice(dt(t));if(e.length!==t)throw new Error("inconsistent lengths");return"u"+$(e,"base64url")}function z0(r){let t=Qt(r),e=r.slice(dt(t));if(e.length!==t)throw new Error("inconsistent lengths");return $(e,"base58btc")}function j0(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=Ta(n);return Et([e,s],e.length+s.length)}function W0(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=Ta(n);return Et([e,s],e.length+s.length)}function lf(r){let t=r.slice(0,r.length-2),e=r.slice(r.length-2),n=$(t,"base32"),s=uf(e);return`${n}:${s}`}function ff(r){r=La(r);let t=[],e=[],n=null,s=r.split("/").slice(1);if(s.length===1&&s[0]==="")return{bytes:new Uint8Array,string:"/",tuples:[],stringTuples:[],path:null};for(let o=0;o<s.length;o++){let i=s[o],a=Q(i);if(a.size===0){t.push([a.code]),e.push([a.code]);continue}if(o++,o>=s.length)throw df("invalid address: "+r);if(a.path===!0){n=La(s.slice(o).join("/")),t.push([a.code,Na(a.code,n)]),e.push([a.code,n]);break}let c=Na(a.code,s[o]);t.push([a.code,c]),e.push([a.code,Ra(a.code,c)])}return{string:hf(e),bytes:Ua(t),tuples:t,stringTuples:e,path:n}}function Ca(r){let t=[],e=[],n=null,s=0;for(;s<r.length;){let o=Qt(r,s),i=dt(o),a=Q(o),c=Y0(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 df("Invalid address Uint8Array: "+$(r,"base16"));t.push([o,l]);let f=Ra(o,l);if(e.push([o,f]),a.path===!0){n=f;break}}return{bytes:Uint8Array.from(r),string:hf(e),tuples:t,stringTuples:e,path:n}}function hf(r){let t=[];return r.map(e=>{let n=Q(e[0]);return t.push(n.name),e.length>1&&e[1]!=null&&t.push(e[1]),null}),La(t.join("/"))}function Ua(r){return Et(r.map(t=>{let e=Q(t[0]),n=Uint8Array.from(ie(e.code));return t.length>1&&t[1]!=null&&(n=Et([n,t[1]])),n}))}function Y0(r,t){if(r.size>0)return r.size/8;if(r.size===0)return 0;{let e=Qt(t instanceof Uint8Array?t:Uint8Array.from(t));return e+dt(e)}}function La(r){return"/"+r.trim().split("/").filter(t=>t).join("/")}function df(r){return new Error("Error parsing address: "+r)}var Z0=Symbol.for("nodejs.util.inspect.custom"),Pa=Symbol.for("@multiformats/js-multiaddr/multiaddr"),X0=[Q("dns").code,Q("dns4").code,Q("dns6").code,Q("dnsaddr").code],lo=class r{bytes;#e;#t;#r;#n;[Pa]=!0;constructor(t){t==null&&(t="");let e;if(t instanceof Uint8Array)e=Ca(t);else if(typeof t=="string"){if(t.length>0&&t.charAt(0)!=="/")throw new Error(`multiaddr "${t}" must start with a "/"`);e=ff(t)}else if(gf(t))e=Ca(t.bytes);else throw new Error("addr must be a string, Buffer, or another Multiaddr");this.bytes=e.bytes,this.#e=e.string,this.#t=e.tuples,this.#r=e.stringTuples,this.#n=e.path}toString(){return this.#e}toJSON(){return this.toString()}toOptions(){let t,e,n,s,o="",i=Q("tcp"),a=Q("udp"),c=Q("ip4"),l=Q("ip6"),f=Q("dns6"),u=Q("ip6zone");for(let[m,p]of this.stringTuples())m===u.code&&(o=`%${p??""}`),X0.includes(m)&&(e=i.name,s=443,n=`${p??""}${o}`,t=m===f.code?6:4),(m===i.code||m===a.code)&&(e=Q(m).name,s=parseInt(p??"")),(m===c.code||m===l.code)&&(e=Q(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({},Q(t)))}protoCodes(){return this.#t.map(([t])=>t)}protoNames(){return this.#t.map(([t])=>Q(t).name)}tuples(){return this.#t}stringTuples(){return this.#r}encapsulate(t){return t=new r(t),new r(this.toString()+t.toString())}decapsulate(t){let e=t.toString(),n=this.toString(),s=n.lastIndexOf(e);if(s<0)throw new Error(`Address ${this.toString()} does not contain subaddress: ${t.toString()}`);return new r(n.slice(0,s))}decapsulateCode(t){let e=this.tuples();for(let n=e.length-1;n>=0;n--)if(e[n][0]===t)return new r(Ua(e.slice(0,n)));return this}getPeerId(){try{let t=[];this.stringTuples().forEach(([n,s])=>{n===$r.p2p.code&&t.push([n,s]),n===$r["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"):$(Mt.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=pf.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=>Da(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)}[Z0](){return`Multiaddr(${this.#e})`}};var pf=new Map;function gf(r){return!!r?.[Pa]}function Da(r){return new lo(r)}var J0=r=>r.toString().split("/").slice(1),Sn=r=>({match:t=>t.length<1?!1:r(t[0])?t.slice(1):!1,pattern:"fn"}),Z=r=>({match:t=>Sn(e=>e===r).match(t),pattern:r}),ho=()=>({match:r=>Sn(t=>typeof t=="string").match(r),pattern:"{string}"}),po=()=>({match:r=>Sn(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}"}),uo=()=>({match:r=>{if(r.length<2||r[0]!=="certhash")return!1;try{Ho.decode(r[1])}catch{return!1}return r.slice(2)},pattern:"/certhash/{certhash}"}),bt=r=>({match:t=>{let e=r.match(t);return e===!1?t:e},pattern:`optional(${r.pattern})`}),qt=(...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(", ")})`}),tt=(...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=J0(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 Ha=tt(Z("dns4"),ho()),Oa=tt(Z("dns6"),ho()),Ma=tt(Z("dnsaddr"),ho()),mf=tt(Z("dns"),ho()),UE=ht(Ha),PE=ht(Oa),DE=ht(Ma),VE=ht(qt(mf,Ma,Ha,Oa)),yf=tt(Z("ip4"),Sn(io)),wf=tt(Z("ip6"),Sn(ao)),bf=qt(yf,wf),he=qt(bf,mf,Ha,Oa,Ma),HE=ht(he),OE=ht(yf),ME=ht(wf),KE=ht(bf),Ka=tt(he,Z("tcp"),po()),kn=tt(he,Z("udp"),po()),FE=ht(Ka),$E=ht(kn),Fa=tt(kn,Z("quic")),go=tt(kn,Z("quic-v1")),Q0=qt(Fa,go),qE=ht(Fa),GE=ht(go),Va=qt(he,Ka,kn,Fa,go),xf=qt(tt(Va,Z("ws"),bt(_t()))),zE=ht(xf),Ef=qt(tt(Va,Z("wss"),bt(_t())),tt(Va,Z("tls"),Z("ws"),bt(_t()))),jE=ht(Ef),vf=tt(kn,Z("webrtc-direct"),bt(uo()),bt(uo()),bt(_t())),WE=ht(vf),Bf=tt(go,Z("webtransport"),bt(uo()),bt(uo()),bt(_t())),mo=ht(Bf),fo=qt(xf,Ef,tt(Ka,bt(_t())),tt(Q0,bt(_t())),tt(he,bt(_t())),vf,Bf,_t()),YE=ht(fo),tg=tt(fo,Z("p2p-circuit"),_t()),ZE=ht(tg),eg=qt(tt(fo,Z("p2p-circuit"),Z("webrtc"),bt(_t())),tt(fo,Z("webrtc"),bt(_t())),Z("webrtc")),XE=ht(eg),rg=qt(tt(he,Z("tcp"),po(),Z("http"),bt(_t())),tt(he,Z("http"),bt(_t()))),JE=ht(rg),ng=qt(tt(he,Z("tcp"),qt(tt(Z("443"),Z("http")),tt(po(),Z("https"))),bt(_t())),tt(he,Z("tls"),Z("http"),bt(_t())),tt(he,Z("https"),bt(_t()))),QE=ht(ng);var fr=class extends Event{type;detail;constructor(t,e){super(t),this.type=t,this.detail=e}};function $a(r){throw new Error("Not implemented")}function Af(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 Sf(r){return r==null?!1:typeof r.then=="function"&&typeof r.catch=="function"&&typeof r.finally=="function"}function kf(r,t){let e=Af(r).return?.();Sf(e)&&e.catch(n=>{t.error("could not cause iterator to return",n)})}var sg="ERR_STREAM_RESET",og="ERR_SINK_INVALID_STATE",ig=5e3;function qa(r){return r==null?!1:typeof r.then=="function"&&typeof r.catch=="function"&&typeof r.finally=="function"}var yo=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=Lt(),this.closed=Lt(),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??ig,this.onEnd=t.onEnd,this.onCloseRead=t?.onCloseRead,this.onCloseWrite=t?.onCloseWrite,this.onReset=t?.onReset,this.onAbort=t?.onAbort,this.source=this.streamSource=Vr({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"`,og);try{this.writeStatus="writing";let e={signal:this.sinkController.signal};if(this.direction==="outbound"){let s=this.sendNewStream(e);qa(s)&&await s}let n=()=>{kf(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 at(s):s;let o=this.sendData(s,e);qa(o)&&(this.sendingData=Lt(),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 Pt(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 Pt(this.sink([]),t.signal)),this.writeStatus==="writing"&&(this.sendingData!=null&&await Pt(this.sendingData.promise,t.signal),this.log.trace("aborting source passed to .sink"),this.sinkController.abort(),await Pt(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();qa(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",sg);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 Ga=class extends yo{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 at(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 Pt(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 Pt(this.writer.abort(),t?.signal),this.log("sendReset aborted writer")}async sendCloseWrite(t){this.log("sendCloseWrite closing writer"),await Pt(this.writer.close(),t?.signal),this.log("sendCloseWrite closed writer")}async sendCloseRead(t){this.log("sendCloseRead cancelling reader"),await Pt(this.reader.cancel(),t?.signal),this.log("sendCloseRead cancelled reader")}};async function za(r,t,e,n,s,o){let i=o.forComponent(`libp2p:webtransport:stream:${e}:${t}`),a=new Ga({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 wo(){return{source:{[Symbol.asyncIterator](){return{async next(){return new Promise(()=>{})}}}},sink:async r=>new Promise(()=>{})}}function If(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:f}=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`),f.writable.close().catch(u=>{o.error(`failed to close inbound stream that crossed our maxInboundStream limit: ${u.message}`)}),f.readable.cancel().catch(u=>{o.error(`failed to close inbound stream that crossed our maxInboundStream limit: ${u.message}`)});else{let u=await za(f,String(s++),"inbound",a,i?.onStreamEnd,e);a.push(u),i?.onIncomingStream?.(u)}}}).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 f=await r.createBidirectionalStream(),u=await za(f,String(s++),i?.direction??"outbound",a,i?.onStreamEnd,e);return a.push(u),u},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(f){o.error("webtransport session threw error during close",f)}},...wo()};return c}}}function _f(r,t){return t.filter(n=>!!r.find(s=>ft(n,s))).length===t.length}var ag=Object.values(oe).map(r=>r.decoder).reduce((r,t)=>r.or(t));function cg(r){return se.decode(ag.decode(r))}function ja(r){if(!mo.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===Q("certhash").code).map(([i,a])=>cg(a??"")),n=t.filter(([i,a])=>i===Q("p2p").code).map(([i,a])=>ji(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 Rf=globalThis.WebTransport;var Wa=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";[oc]=!0;[Tn]=["@libp2p/transport"];async dial(t,e){if(e?.signal?.aborted===!0)throw new Nn;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}=ja(t),a,c,l=()=>{},f=!1,u=!1,g=!1;try{this.metrics?.dialerEvents.increment({pending:!0});let m=new Rf(`${s}/.well-known/libp2p-webtransport?type=noise`,{serverCertificateHashes:o.map(p=>({algorithm:"sha-256",value:p.digest}))});if(l=p=>{if(!f)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()),f=!0}},a=()=>{l(u?"noise_timeout":"ready_timeout")},e.signal?.addEventListener("abort",a,{once:!0}),this.log("wait for session to be ready"),e.onProgress?.(new fr("webtransport:wait-for-session")),await Promise.race([m.closed,m.ready]),this.log("session became ready"),u=!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 Pt(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"),...wo()},await e.upgrader.upgradeOutbound(c,{skipEncryption:!0,muxerFactory:If(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":u?"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 fr("webtransport:open-authentication-stream"));let a=await t.createBidirectionalStream(),c=a.writable.getWriter(),l=a.readable.getReader(),f={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 Pt(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)})}}},u=ef()(this.components);o?.(new fr("webtransport:secure-outbound-connection"));let{remoteExtensions:g}=await u.secureOutbound(e,f,n);if(o?.(new fr("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}`)}),!_f(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 $a(this.components,{...t,certificates:this.config.certificates,maxInboundStreams:this.config.maxInboundStreams})}listenFilter(){return[]}dialFilter(t){return globalThis.WebTransport==null?[]:t.filter(e=>{if(!mo.exactMatch(e))return!1;let{url:n,certhashes:s}=ja(e);return n!=null&&s.length>0})}};function lg(r={}){return t=>new Wa(t,r)}return qf(ug);})();
6
+ `)}`:`${e} :`}};bl=qe;P.Constructed=bl;qe.NAME="CONSTRUCTED";var is=class extends Tt{fromBER(t,e,n){return e}toBER(t){return re}};is.override="EndOfContentValueBlock";var xl,as=class extends kt{constructor(t={}){super(t,is),this.idBlock.tagClass=1,this.idBlock.tagNumber=0}};xl=as;P.EndOfContent=xl;as.NAME=fn;var El,Ge=class extends kt{constructor(t={}){super(t,Tt),this.idBlock.tagClass=1,this.idBlock.tagNumber=5}fromBER(t,e,n){return this.lenBlock.length>0&&this.warnings.push("Non-zero length of value block for Null type"),this.idBlock.error.length||(this.blockLength+=this.idBlock.blockLength),this.lenBlock.error.length||(this.blockLength+=this.lenBlock.blockLength),this.blockLength+=n,e+n>t.byteLength?(this.error="End of input reached before message was fully decoded (inconsistent offset and length values)",-1):e+n}toBER(t,e){let n=new ArrayBuffer(2);if(!t){let s=new Uint8Array(n);s[0]=5,s[1]=0}return e&&e.write(n),n}onAsciiEncoding(){return`${this.constructor.NAME}`}};El=Ge;P.Null=El;Ge.NAME="NULL";var cs=class extends _e(Tt){constructor({value:t,...e}={}){super(e),e.valueHex?this.valueHexView=j.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=j.BufferSourceConverter.toUint8Array(t);return Ie(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,Li.call(this),this.blockLength=n,e+n):-1}toBER(){return this.valueHexView.slice()}toJSON(){return{...super.toJSON(),value:this.value}}};cs.NAME="BooleanValueBlock";var vl,ls=class extends kt{constructor(t={}){super(t,cs),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}`}};vl=ls;P.Boolean=vl;ls.NAME="BOOLEAN";var us=class extends _e(le){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=le.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===fn){if(this.isIndefiniteForm)break;return this.error="EndOfContent is unexpected, OCTET STRING may consists of OCTET STRINGs only",-1}if(i!==gl)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?le.prototype.toBER.call(this,t,e):t?new ArrayBuffer(this.valueHexView.byteLength):this.valueHexView.slice().buffer}toJSON(){return{...super.toJSON(),isConstructed:this.isConstructed}}};us.NAME="OctetStringValueBlock";var Bl,Se=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},us),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=Hs(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?qe.prototype.onAsciiEncoding.call(this):`${this.constructor.NAME} : ${j.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 j.BufferSourceConverter.concat(t)}};Bl=Se;P.OctetString=Bl;Se.NAME=gl;var fs=class extends _e(le){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=le.prototype.fromBER.call(this,t,e,n),s===-1)return s;for(let a of this.value){let c=a.constructor.NAME;if(c===fn){if(this.isIndefiniteForm)break;return this.error="EndOfContent is unexpected, BIT STRING may consists of BIT STRINGs only",-1}if(c!==ml)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=j.BufferSourceConverter.toUint8Array(t);if(!Ie(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=Hs(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 le.prototype.toBER.call(this,t,e);if(t)return new ArrayBuffer(this.valueHexView.byteLength+1);if(!this.valueHexView.byteLength)return re;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}}};fs.NAME="BitStringValueBlock";var Al,Tr=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},fs),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 qe.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)}`}}};Al=Tr;P.BitString=Al;Tr.NAME=ml;var Sl;function Cp(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,f=c<i?i:c,u=0;for(let d=f;d>=0;d--,u++){switch(!0){case u<a.length:l=o[i-u]+a[c-u]+e[0];break;default:l=o[i-u]+e[0]}switch(e[0]=l/10,!0){case u>=o.length:o=Qn(new Uint8Array([l%10]),o);break;default:o[i-u]=l%10}}return e[0]>0&&(o=Qn(e,o)),o}function pl(r){if(r>=ln.length)for(let t=ln.length;t<=r;t++){let e=new Uint8Array([0]),n=ln[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=Qn(e,n)),ln.push(n)}return ln[r]}function Up(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,f=0;for(let u=c;u>=0;u--,f++)switch(l=o[i-f]-a[c-f]-e,!0){case l<0:e=1,o[i-f]=l+10;break;default:e=0,o[i-f]=l}if(e>0)for(let u=i-c+1;u>=0;u--,f++)if(l=o[i-f]-e,l<0)e=1,o[i-f]=l+10;else{e=0,o[i-f]=l;break}return o.slice()}var hn=class extends _e(Tt){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=Li.call(this)))}set valueDec(t){this._valueDec=t,this.isHexOnly=!1,this.valueHexView=new Uint8Array(fl(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=Up(pl(n),e),i="-";break;default:e=Cp(e,pl(n))}n++,s>>=1}}for(let c=0;c<e.length;c++)e[c]&&(a=!0),a&&(i+=dl.charAt(e[c]));return a===!1&&(i+=dl.charAt(0)),i}};Sl=hn;hn.NAME="IntegerValueBlock";Object.defineProperty(Sl.prototype,"valueHex",{set:function(r){this.valueHexView=new Uint8Array(r),this.setValueHex()},get:function(){return this.valueHexView.slice().buffer}});var kl,pt=class r extends kt{constructor(t={}){super(t,hn),this.idBlock.tagClass=1,this.idBlock.tagNumber=2}toBigInt(){return ts(),BigInt(this.valueBlock.toString())}static fromBigInt(t){ts();let e=BigInt(t),n=new un,s=e.toString(16).replace(/^-/,""),o=new Uint8Array(j.Convert.FromHex(s));if(e<0){let a=new Uint8Array(o.length+(o[0]&128?1:0));a[0]|=128;let l=BigInt(`0x${j.Convert.ToHex(a)}`)+e,f=j.BufferSourceConverter.toUint8Array(j.Convert.FromHex(l.toString(16)));f[0]|=128,n.write(f)}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()}`}};kl=pt;P.Integer=kl;pt.NAME="INTEGER";var Il,hs=class extends pt{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=10}};Il=hs;P.Enumerated=Il;hs.NAME="ENUMERATED";var dn=class extends _e(Tt){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=j.BufferSourceConverter.toUint8Array(t);if(!Ie(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=ur(this.valueHexView,7):(this.isHexOnly=!0,this.warnings.push("Too big SID for decoding, hex only")),e+this.blockLength)}set valueBigInt(t){ts();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=$e(this.valueDec,7);if(e.byteLength===0)return this.error="Error during encoding SID value",re;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=j.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}}};dn.NAME="sidBlock";var ds=class extends Tt{constructor({value:t=Lr,...e}={}){super(e),this.value=[],t&&this.fromString(t)}fromBER(t,e,n){let s=e;for(;n>0;){let o=new dn;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,re;e.push(s)}return Ci(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 dn;if(s>Number.MAX_SAFE_INTEGER){ts();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}};ds.NAME="ObjectIdentifierValueBlock";var _l,ee=class extends kt{constructor(t={}){super(t,ds),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()}}};_l=ee;P.ObjectIdentifier=_l;ee.NAME="OBJECT IDENTIFIER";var pn=class extends _e(Ae){constructor({valueDec:t=0,...e}={}){super(e),this.valueDec=t}fromBER(t,e,n){if(n===0)return e;let s=j.BufferSourceConverter.toUint8Array(t);if(!Ie(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=ur(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=$e(this.valueDec,7);if(e.byteLength===0)return this.error="Error during encoding SID value",re;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=j.Convert.ToHex(this.valueHexView):t=this.valueDec.toString(),t}toJSON(){return{...super.toJSON(),valueDec:this.valueDec}}};pn.NAME="relativeSidBlock";var ps=class extends Tt{constructor({value:t=Lr,...e}={}){super(e),this.value=[],t&&this.fromString(t)}fromBER(t,e,n){let s=e;for(;n>0;){let o=new pn;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,re;n.push(o)}return Ci(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 pn;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}};ps.NAME="RelativeObjectIdentifierValueBlock";var Rl,gs=class extends kt{constructor(t={}){super(t,ps),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()}}};Rl=gs;P.RelativeObjectIdentifier=Rl;gs.NAME="RelativeObjectIdentifier";var Nl,vt=class extends qe{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=16}};Nl=vt;P.Sequence=Nl;vt.NAME="SEQUENCE";var Tl,ms=class extends qe{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=17}};Tl=ms;P.Set=Tl;ms.NAME="SET";var ys=class extends _e(Tt){constructor({...t}={}){super(t),this.isHexOnly=!0,this.value=Lr}toJSON(){return{...super.toJSON(),value:this.value}}};ys.NAME="StringValueBlock";var ws=class extends ys{};ws.NAME="SimpleStringValueBlock";var Pt=class extends ns{constructor({...t}={}){super(t,ws)}fromBuffer(t){this.valueBlock.value=String.fromCharCode.apply(null,j.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 bs=class extends Pt{fromBuffer(t){this.valueBlock.valueHexView=j.BufferSourceConverter.toUint8Array(t);try{this.valueBlock.value=j.Convert.ToUtf8String(t)}catch(e){this.warnings.push(`Error during "decodeURIComponent": ${e}, using raw string`),this.valueBlock.value=j.Convert.ToBinary(t)}}fromString(t){this.valueBlock.valueHexView=new Uint8Array(j.Convert.FromUtf8String(t)),this.valueBlock.value=t}};bs.NAME="Utf8StringValueBlock";var Ll,ke=class extends bs{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=12}};Ll=ke;P.Utf8String=Ll;ke.NAME="UTF8String";var xs=class extends Pt{fromBuffer(t){this.valueBlock.value=j.Convert.ToUtf16String(t),this.valueBlock.valueHexView=j.BufferSourceConverter.toUint8Array(t)}fromString(t){this.valueBlock.value=t,this.valueBlock.valueHexView=new Uint8Array(j.Convert.FromUtf16String(t))}};xs.NAME="BmpStringValueBlock";var Cl,Es=class extends xs{constructor({...t}={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=30}};Cl=Es;P.BmpString=Cl;Es.NAME="BMPString";var vs=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=$e(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}};vs.NAME="UniversalStringValueBlock";var Ul,Bs=class extends vs{constructor({...t}={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=28}};Ul=Bs;P.UniversalString=Ul;Bs.NAME="UniversalString";var Pl,As=class extends Pt{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=18}};Pl=As;P.NumericString=Pl;As.NAME="NumericString";var Dl,Ss=class extends Pt{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=19}};Dl=Ss;P.PrintableString=Dl;Ss.NAME="PrintableString";var Vl,ks=class extends Pt{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=20}};Vl=ks;P.TeletexString=Vl;ks.NAME="TeletexString";var Hl,Is=class extends Pt{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=21}};Hl=Is;P.VideotexString=Hl;Is.NAME="VideotexString";var Ol,_s=class extends Pt{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=22}};Ol=_s;P.IA5String=Ol;_s.NAME="IA5String";var Ml,Rs=class extends Pt{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=25}};Ml=Rs;P.GraphicString=Ml;Rs.NAME="GraphicString";var Kl,gn=class extends Pt{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=26}};Kl=gn;P.VisibleString=Kl;gn.NAME="VisibleString";var Fl,Ns=class extends Pt{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=27}};Fl=Ns;P.GeneralString=Fl;Ns.NAME="GeneralString";var $l,Ts=class extends Pt{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=29}};$l=Ts;P.CharacterString=$l;Ts.NAME="CharacterString";var ql,mn=class extends gn{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,j.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]=Ot(this.year<2e3?this.year-1900:this.year-2e3,2),e[1]=Ot(this.month,2),e[2]=Ot(this.day,2),e[3]=Ot(this.hour,2),e[4]=Ot(this.minute,2),e[5]=Ot(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}}};ql=mn;P.UTCTime=ql;mn.NAME="UTCTime";var Gl,Ls=class extends mn{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 u=new Number(t[t.length-1]);if(isNaN(u.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 u=1,d=n.indexOf("+"),p="";if(d===-1&&(d=n.indexOf("-"),u=-1),d!==-1){if(p=n.substring(d+1),n=n.substring(0,d),p.length!==2&&p.length!==4)throw new Error("Wrong input string for conversion");let y=parseInt(p.substring(0,2),10);if(isNaN(y.valueOf()))throw new Error("Wrong input string for conversion");if(a=u*y,p.length===4){if(y=parseInt(p.substring(2,4),10),isNaN(y.valueOf()))throw new Error("Wrong input string for conversion");c=u*y}}}let l=n.indexOf(".");if(l===-1&&(l=n.indexOf(",")),l!==-1){let u=new Number(`0${n.substring(l)}`);if(isNaN(u.valueOf()))throw new Error("Wrong input string for conversion");o=u.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 u=60*o;this.minute=Math.floor(u),u=60*(u-this.minute),this.second=Math.floor(u),u=1e3*(u-this.second),this.millisecond=Math.floor(u)}break;case s.length===12:if(i=/(\d{4})(\d{2})(\d{2})(\d{2})(\d{2})/ig,l!==-1){let u=60*o;this.second=Math.floor(u),u=1e3*(u-this.second),this.millisecond=Math.floor(u)}break;case s.length===14:if(i=/(\d{4})(\d{2})(\d{2})(\d{2})(\d{2})(\d{2})/ig,l!==-1){let u=1e3*o;this.millisecond=Math.floor(u)}break;default:throw new Error("Wrong input string for conversion")}let f=i.exec(s);if(f===null)throw new Error("Wrong input string for conversion");for(let u=1;u<f.length;u++)switch(u){case 1:this.year=parseInt(f[u],10);break;case 2:this.month=parseInt(f[u],10);break;case 3:this.day=parseInt(f[u],10);break;case 4:this.hour=parseInt(f[u],10)+a;break;case 5:this.minute=parseInt(f[u],10)+c;break;case 6:this.second=parseInt(f[u],10);break;default:throw new Error("Wrong input string for conversion")}if(e===!1){let u=new Date(this.year,this.month,this.day,this.hour,this.minute,this.second,this.millisecond);this.year=u.getUTCFullYear(),this.month=u.getUTCMonth(),this.day=u.getUTCDay(),this.hour=u.getUTCHours(),this.minute=u.getUTCMinutes(),this.second=u.getUTCSeconds(),this.millisecond=u.getUTCMilliseconds()}}toString(t="iso"){if(t==="iso"){let e=[];return e.push(Ot(this.year,4)),e.push(Ot(this.month,2)),e.push(Ot(this.day,2)),e.push(Ot(this.hour,2)),e.push(Ot(this.minute,2)),e.push(Ot(this.second,2)),this.millisecond!==0&&(e.push("."),e.push(Ot(this.millisecond,3))),e.push("Z"),e.join("")}return super.toString(t)}toJSON(){return{...super.toJSON(),millisecond:this.millisecond}}};Gl=Ls;P.GeneralizedTime=Gl;Ls.NAME="GeneralizedTime";var zl,Cs=class extends ke{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=31}};zl=Cs;P.DATE=zl;Cs.NAME="DATE";var jl,Us=class extends ke{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=32}};jl=Us;P.TimeOfDay=jl;Us.NAME="TimeOfDay";var Wl,Ps=class extends ke{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=33}};Wl=Ps;P.DateTime=Wl;Ps.NAME="DateTime";var Yl,Ds=class extends ke{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=34}};Yl=Ds;P.Duration=Yl;Ds.NAME="Duration";var Zl,Vs=class extends ke{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=14}};Zl=Vs;P.TIME=Zl;Vs.NAME="TIME";function Dp(r){let{result:t}=Cr(r),e=t.valueBlock.value;return{n:$(ue(e[1].toBigInt()),"base64url"),e:$(ue(e[2].toBigInt()),"base64url"),d:$(ue(e[3].toBigInt()),"base64url"),p:$(ue(e[4].toBigInt()),"base64url"),q:$(ue(e[5].toBigInt()),"base64url"),dp:$(ue(e[6].toBigInt()),"base64url"),dq:$(ue(e[7].toBigInt()),"base64url"),qi:$(ue(e[8].toBigInt()),"base64url"),kty:"RSA",alg:"RS256"}}function Vp(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(fe(Y(r.n,"base64url"))),pt.fromBigInt(fe(Y(r.e,"base64url"))),pt.fromBigInt(fe(Y(r.d,"base64url"))),pt.fromBigInt(fe(Y(r.p,"base64url"))),pt.fromBigInt(fe(Y(r.q,"base64url"))),pt.fromBigInt(fe(Y(r.dp,"base64url"))),pt.fromBigInt(fe(Y(r.dq,"base64url"))),pt.fromBigInt(fe(Y(r.qi,"base64url")))]}).toBER();return new Uint8Array(e,0,e.byteLength)}function Hp(r){let{result:t}=Cr(r),e=t.valueBlock.value[1].valueBlock.value[0].valueBlock.value;return{kty:"RSA",n:$(ue(e[0].toBigInt()),"base64url"),e:$(ue(e[1].toBigInt()),"base64url")}}function Op(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 ee({value:"1.2.840.113549.1.1.1"}),new Ge]}),new Tr({valueHex:new vt({value:[pt.fromBigInt(fe(Y(r.n,"base64url"))),pt.fromBigInt(fe(Y(r.e,"base64url")))]}).toBER()})]}).toBER();return new Uint8Array(e,0,e.byteLength)}function ue(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 fe(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 Mp=16,Pi=32,Di=1e4;async function Kp(r,t){let e=Ut.get(),s=new vt({value:[new pt({value:0}),new vt({value:[new ee({value:"1.2.840.113549.1.1.1"}),new Ge]}),new Se({valueHex:r.marshal()})]}).toBER(),o=new Uint8Array(s,0,s.byteLength),i=lr(Mp),a=await Ni(Jr,t,i,{c:Di,dkLen:Pi}),c=lr(16),l=await e.subtle.importKey("raw",a,"AES-CBC",!1,["encrypt"]),f=await e.subtle.encrypt({name:"AES-CBC",iv:c},l,o),u=new vt({value:[new Se({valueHex:i}),new pt({value:Di}),new pt({value:Pi}),new vt({value:[new ee({value:"1.2.840.113549.2.11"}),new Ge]})]}),d=new vt({value:[new ee({value:"1.2.840.113549.1.5.13"}),new vt({value:[new vt({value:[new ee({value:"1.2.840.113549.1.5.12"}),u]}),new vt({value:[new ee({value:"2.16.840.1.101.3.4.1.42"}),new Se({valueHex:c})]})]})]}),y=new vt({value:[d,new Se({valueHex:f})]}).toBER(),m=new Uint8Array(y,0,y.byteLength);return["-----BEGIN ENCRYPTED PRIVATE KEY-----",...$(m,"base64pad").split(/(.{64})/).filter(Boolean),"-----END ENCRYPTED PRIVATE KEY-----"].join(`
7
+ `)}async function Fp(r,t){let e=Ut.get(),n;if(r.includes("-----BEGIN ENCRYPTED PRIVATE KEY-----")){let s=Y(r.replace("-----BEGIN ENCRYPTED PRIVATE KEY-----","").replace("-----END ENCRYPTED PRIVATE KEY-----","").replace(/\n/g,"").trim(),"base64pad"),{result:o}=Cr(s),{iv:i,salt:a,iterations:c,keySize:l,cipherText:f}=$p(o),u=await Ni(Jr,t,a,{c,dkLen:l}),d=await e.subtle.importKey("raw",u,"AES-CBC",!1,["decrypt"]),p=yn(await e.subtle.decrypt({name:"AES-CBC",iv:i},d,f)),{result:y}=Cr(p);n=Xl(y)}else if(r.includes("-----BEGIN PRIVATE KEY-----")){let s=Y(r.replace("-----BEGIN PRIVATE KEY-----","").replace("-----END PRIVATE KEY-----","").replace(/\n/g,"").trim(),"base64pad"),{result:o}=Cr(s);n=Xl(o)}else throw new M("Could not parse private key from PEM data","ERR_INVALID_PARAMETERS");return Vi(n)}function $p(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=yn(o.valueBlock.value[0].getValue()),a=Di,c=Pi;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],f=l.valueBlock.value[0].toString();if(f!=="OBJECT IDENTIFIER : 1.2.840.113549.3.7"){if(f!=="OBJECT IDENTIFIER : 1.3.14.3.2.7"){if(f!=="OBJECT IDENTIFIER : 2.16.840.1.101.3.4.1.2"){if(f!=="OBJECT IDENTIFIER : 2.16.840.1.101.3.4.1.22"){if(f!=="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 u=yn(l.valueBlock.value[1].getValue());return{cipherText:yn(r.valueBlock.value[1].getValue()),salt:i,iterations:a,keySize:c,iv:u}}function Xl(r){return yn(r.valueBlock.value[2].getValue())}function yn(r){return new Uint8Array(r,0,r.byteLength)}async function Jl(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 eu(t);return{privateKey:e[0],publicKey:e[1]}}async function Hi(r){let e=[await Ut.get().subtle.importKey("jwk",r,{name:"RSASSA-PKCS1-v1_5",hash:{name:"SHA-256"}},!0,["sign"]),await qp(r)],n=await eu({privateKey:e[0],publicKey:e[1]});return{privateKey:n[0],publicKey:n[1]}}async function Ql(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 tu(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 eu(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 qp(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 Os(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 Y(r.n,"base64url").length*8}var bn=8192,wn=class{_key;constructor(t){this._key=t}verify(t,e){return tu(this._key,e,t)}marshal(){return ze.jwkToPkix(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=At.digest(this.bytes);return $t(t)?t.then(({bytes:e})=>e):t.bytes}},Ur=class{_key;_publicKey;constructor(t,e){this._key=t,this._publicKey=e}genSecret(){return lr(16)}sign(t){return Ql(this._key,t)}get public(){if(this._publicKey==null)throw new M("public key not provided","ERR_PUBKEY_NOT_PROVIDED");return new wn(this._publicKey)}marshal(){return ze.jwkToPkcs1(this._key)}get bytes(){return ce.encode({Type:at.RSA,Data:this.marshal()}).subarray()}equals(t){return ft(this.bytes,t.bytes)}hash(){let t=At.digest(this.bytes);return $t(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 ze.exportToPem(this,t);if(e==="libp2p-key")return Ir(this.bytes,t);throw new M(`export format '${e}' is not supported`,"ERR_INVALID_EXPORT_FORMAT")}};async function Vi(r){let t=ze.pkcs1ToJwk(r);if(Os(t)>bn)throw new M("key size is too large","ERR_KEY_SIZE_TOO_LARGE");let e=await Hi(t);return new Ur(e.privateKey,e.publicKey)}function zp(r){let t=ze.pkixToJwk(r);if(Os(t)>bn)throw new M("key size is too large","ERR_KEY_SIZE_TOO_LARGE");return new wn(t)}async function jp(r){if(Os(r)>bn)throw new M("key size is too large","ERR_KEY_SIZE_TOO_LARGE");let t=await Hi(r);return new Ur(t.privateKey,t.publicKey)}async function Wp(r){if(r>bn)throw new M("key size is too large","ERR_KEY_SIZE_TOO_LARGE");let t=await Jl(r);return new Ur(t.privateKey,t.publicKey)}var qi={};mt(qi,{Secp256k1PrivateKey:()=>En,Secp256k1PublicKey:()=>xn,generateKeyPair:()=>a0,unmarshalSecp256k1PrivateKey:()=>o0,unmarshalSecp256k1PublicKey:()=>i0});var Yp=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]),je=new Uint32Array([1779033703,3144134277,1013904242,2773480762,1359893119,2600822924,528734635,1541459225]),We=new Uint32Array(64),Mi=class extends vr{constructor(){super(64,32,8,!1),this.A=je[0]|0,this.B=je[1]|0,this.C=je[2]|0,this.D=je[3]|0,this.E=je[4]|0,this.F=je[5]|0,this.G=je[6]|0,this.H=je[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 u=0;u<16;u++,e+=4)We[u]=t.getUint32(e,!1);for(let u=16;u<64;u++){let d=We[u-15],p=We[u-2],y=Wt(d,7)^Wt(d,18)^d>>>3,m=Wt(p,17)^Wt(p,19)^p>>>10;We[u]=m+We[u-7]+y+We[u-16]|0}let{A:n,B:s,C:o,D:i,E:a,F:c,G:l,H:f}=this;for(let u=0;u<64;u++){let d=Wt(a,6)^Wt(a,11)^Wt(a,25),p=f+d+Lc(a,c,l)+Yp[u]+We[u]|0,m=(Wt(n,2)^Wt(n,13)^Wt(n,22))+Cc(n,s,o)|0;f=l,l=c,c=a,a=i+p|0,i=o,o=s,s=n,n=p+m|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,f=f+this.H|0,this.set(n,s,o,i,a,c,l,f)}roundClean(){We.fill(0)}destroy(){this.set(0,0,0,0,0,0,0,0),this.buffer.fill(0)}};var Pr=Vn(()=>new Mi);function ru(r){r.lowS!==void 0&&Zt("lowS",r.lowS),r.prehash!==void 0&&Zt("prehash",r.prehash)}function Zp(r){let t=en(r);qt(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:Xp,hexToBytes:Jp}=Mn,Re={Err:class extends Error{constructor(t=""){super(t)}},_tlv:{encode:(r,t)=>{let{Err:e}=Re;if(r<0||r>256)throw new e("tlv.encode: wrong tag");if(t.length&1)throw new e("tlv.encode: unpadded data");let n=t.length/2,s=Qe(n);if(s.length/2&128)throw new e("tlv.encode: long form length too big");let o=n>127?Qe(s.length/2|128):"";return`${Qe(r)}${o}${s}${t}`},decode(r,t){let{Err:e}=Re,n=0;if(r<0||r>256)throw new e("tlv.encode: wrong tag");if(t.length<2||t[n++]!==r)throw new e("tlv.decode: wrong tlv");let s=t[n++],o=!!(s&128),i=0;if(!o)i=s;else{let c=s&127;if(!c)throw new e("tlv.decode(long): indefinite length not supported");if(c>4)throw new e("tlv.decode(long): byte length is too big");let l=t.subarray(n,n+c);if(l.length!==c)throw new e("tlv.decode: length bytes not complete");if(l[0]===0)throw new e("tlv.decode(long): zero leftmost byte");for(let f of l)i=i<<8|f;if(n+=c,i<128)throw new e("tlv.decode(long): not minimal encoding")}let a=t.subarray(n,n+i);if(a.length!==i)throw new e("tlv.decode: wrong value length");return{v:a,l:t.subarray(n+i)}}},_int:{encode(r){let{Err:t}=Re;if(r<Ne)throw new t("integer: negative integers are not allowed");let e=Qe(r);if(Number.parseInt(e[0],16)&8&&(e="00"+e),e.length&1)throw new t("unexpected assertion");return e},decode(r){let{Err:t}=Re;if(r[0]&128)throw new t("Invalid signature integer: negative");if(r[0]===0&&!(r[1]&128))throw new t("Invalid signature integer: unnecessary leading zero");return Xp(r)}},toSig(r){let{Err:t,_int:e,_tlv:n}=Re,s=typeof r=="string"?Jp(r):r;Br(s);let{v:o,l:i}=n.decode(48,s);if(i.length)throw new t("Invalid signature: left bytes after parsing");let{v:a,l:c}=n.decode(2,o),{v:l,l:f}=n.decode(2,c);if(f.length)throw new t("Invalid signature: left bytes after parsing");return{r:e.decode(a),s:e.decode(l)}},hexFromSig(r){let{_tlv:t,_int:e}=Re,n=`${t.encode(2,e.encode(r.r))}${t.encode(2,e.encode(r.s))}`;return t.encode(48,n)}},Ne=BigInt(0),Bt=BigInt(1),Jw=BigInt(2),nu=BigInt(3),Qw=BigInt(4);function Qp(r){let t=Zp(r),{Fp:e}=t,n=Me(t.n,t.nBitLength),s=t.toBytes||((m,h,w)=>{let x=h.toAffine();return Ee(Uint8Array.from([4]),e.toBytes(x.x),e.toBytes(x.y))}),o=t.fromBytes||(m=>{let h=m.subarray(1),w=e.fromBytes(h.subarray(0,e.BYTES)),x=e.fromBytes(h.subarray(e.BYTES,2*e.BYTES));return{x:w,y:x}});function i(m){let{a:h,b:w}=t,x=e.sqr(m),g=e.mul(x,m);return e.add(e.add(g,e.mul(m,h)),w)}if(!e.eql(e.sqr(t.Gy),i(t.Gx)))throw new Error("bad generator point: equation left != right");function a(m){return Qr(m,Bt,t.n)}function c(m){let{allowedPrivateKeyLengths:h,nByteLength:w,wrapPrivateKey:x,n:g}=t;if(h&&typeof m!="bigint"){if(He(m)&&(m=we(m)),typeof m!="string"||!h.includes(m.length))throw new Error("Invalid key");m=m.padStart(w*2,"0")}let A;try{A=typeof m=="bigint"?m:be(nt("private key",m,w))}catch{throw new Error(`private key must be ${w} bytes, hex or bigint, not ${typeof m}`)}return x&&(A=Z(A,g)),St("private key",A,Bt,g),A}function l(m){if(!(m instanceof d))throw new Error("ProjectivePoint expected")}let f=er((m,h)=>{let{px:w,py:x,pz:g}=m;if(e.eql(g,e.ONE))return{x:w,y:x};let A=m.is0();h==null&&(h=A?e.ONE:e.inv(g));let L=e.mul(w,h),N=e.mul(x,h),k=e.mul(g,h);if(A)return{x:e.ZERO,y:e.ZERO};if(!e.eql(k,e.ONE))throw new Error("invZ was invalid");return{x:L,y:N}}),u=er(m=>{if(m.is0()){if(t.allowInfinityPoint&&!e.is0(m.py))return;throw new Error("bad point: ZERO")}let{x:h,y:w}=m.toAffine();if(!e.isValid(h)||!e.isValid(w))throw new Error("bad point: x or y not FE");let x=e.sqr(w),g=i(h);if(!e.eql(x,g))throw new Error("bad point: equation left != right");if(!m.isTorsionFree())throw new Error("bad point: not in prime-order subgroup");return!0});class d{constructor(h,w,x){if(this.px=h,this.py=w,this.pz=x,h==null||!e.isValid(h))throw new Error("x required");if(w==null||!e.isValid(w))throw new Error("y required");if(x==null||!e.isValid(x))throw new Error("z required");Object.freeze(this)}static fromAffine(h){let{x:w,y:x}=h||{};if(!h||!e.isValid(w)||!e.isValid(x))throw new Error("invalid affine point");if(h instanceof d)throw new Error("projective point not allowed");let g=A=>e.eql(A,e.ZERO);return g(w)&&g(x)?d.ZERO:new d(w,x,e.ONE)}get x(){return this.toAffine().x}get y(){return this.toAffine().y}static normalizeZ(h){let w=e.invertBatch(h.map(x=>x.pz));return h.map((x,g)=>x.toAffine(w[g])).map(d.fromAffine)}static fromHex(h){let w=d.fromAffine(o(nt("pointHex",h)));return w.assertValidity(),w}static fromPrivateKey(h){return d.BASE.multiply(c(h))}static msm(h,w){return $n(d,n,h,w)}_setWindowSize(h){y.setWindowSize(this,h)}assertValidity(){u(this)}hasEvenY(){let{y:h}=this.toAffine();if(e.isOdd)return!e.isOdd(h);throw new Error("Field doesn't support isOdd")}equals(h){l(h);let{px:w,py:x,pz:g}=this,{px:A,py:L,pz:N}=h,k=e.eql(e.mul(w,N),e.mul(A,g)),R=e.eql(e.mul(x,N),e.mul(L,g));return k&&R}negate(){return new d(this.px,e.neg(this.py),this.pz)}double(){let{a:h,b:w}=t,x=e.mul(w,nu),{px:g,py:A,pz:L}=this,N=e.ZERO,k=e.ZERO,R=e.ZERO,I=e.mul(g,g),O=e.mul(A,A),C=e.mul(L,L),V=e.mul(g,A);return V=e.add(V,V),R=e.mul(g,L),R=e.add(R,R),N=e.mul(h,R),k=e.mul(x,C),k=e.add(N,k),N=e.sub(O,k),k=e.add(O,k),k=e.mul(N,k),N=e.mul(V,N),R=e.mul(x,R),C=e.mul(h,C),V=e.sub(I,C),V=e.mul(h,V),V=e.add(V,R),R=e.add(I,I),I=e.add(R,I),I=e.add(I,C),I=e.mul(I,V),k=e.add(k,I),C=e.mul(A,L),C=e.add(C,C),I=e.mul(C,V),N=e.sub(N,I),R=e.mul(C,O),R=e.add(R,R),R=e.add(R,R),new d(N,k,R)}add(h){l(h);let{px:w,py:x,pz:g}=this,{px:A,py:L,pz:N}=h,k=e.ZERO,R=e.ZERO,I=e.ZERO,O=t.a,C=e.mul(t.b,nu),V=e.mul(w,A),K=e.mul(x,L),S=e.mul(g,N),_=e.add(w,x),E=e.add(A,L);_=e.mul(_,E),E=e.add(V,K),_=e.sub(_,E),E=e.add(w,g);let b=e.add(A,N);return E=e.mul(E,b),b=e.add(V,S),E=e.sub(E,b),b=e.add(x,g),k=e.add(L,N),b=e.mul(b,k),k=e.add(K,S),b=e.sub(b,k),I=e.mul(O,E),k=e.mul(C,S),I=e.add(k,I),k=e.sub(K,I),I=e.add(K,I),R=e.mul(k,I),K=e.add(V,V),K=e.add(K,V),S=e.mul(O,S),E=e.mul(C,E),K=e.add(K,S),S=e.sub(V,S),S=e.mul(O,S),E=e.add(E,S),V=e.mul(K,E),R=e.add(R,V),V=e.mul(b,E),k=e.mul(_,k),k=e.sub(k,V),V=e.mul(_,K),I=e.mul(b,I),I=e.add(I,V),new d(k,R,I)}subtract(h){return this.add(h.negate())}is0(){return this.equals(d.ZERO)}wNAF(h){return y.wNAFCached(this,h,d.normalizeZ)}multiplyUnsafe(h){St("scalar",h,Ne,t.n);let w=d.ZERO;if(h===Ne)return w;if(h===Bt)return this;let{endo:x}=t;if(!x)return y.unsafeLadder(this,h);let{k1neg:g,k1:A,k2neg:L,k2:N}=x.splitScalar(h),k=w,R=w,I=this;for(;A>Ne||N>Ne;)A&Bt&&(k=k.add(I)),N&Bt&&(R=R.add(I)),I=I.double(),A>>=Bt,N>>=Bt;return g&&(k=k.negate()),L&&(R=R.negate()),R=new d(e.mul(R.px,x.beta),R.py,R.pz),k.add(R)}multiply(h){let{endo:w,n:x}=t;St("scalar",h,Bt,x);let g,A;if(w){let{k1neg:L,k1:N,k2neg:k,k2:R}=w.splitScalar(h),{p:I,f:O}=this.wNAF(N),{p:C,f:V}=this.wNAF(R);I=y.constTimeNegate(L,I),C=y.constTimeNegate(k,C),C=new d(e.mul(C.px,w.beta),C.py,C.pz),g=I.add(C),A=O.add(V)}else{let{p:L,f:N}=this.wNAF(h);g=L,A=N}return d.normalizeZ([g,A])[0]}multiplyAndAddUnsafe(h,w,x){let g=d.BASE,A=(N,k)=>k===Ne||k===Bt||!N.equals(g)?N.multiplyUnsafe(k):N.multiply(k),L=A(this,w).add(A(h,x));return L.is0()?void 0:L}toAffine(h){return f(this,h)}isTorsionFree(){let{h,isTorsionFree:w}=t;if(h===Bt)return!0;if(w)return w(d,this);throw new Error("isTorsionFree() has not been declared for the elliptic curve")}clearCofactor(){let{h,clearCofactor:w}=t;return h===Bt?this:w?w(d,this):this.multiplyUnsafe(t.h)}toRawBytes(h=!0){return Zt("isCompressed",h),this.assertValidity(),s(d,this,h)}toHex(h=!0){return Zt("isCompressed",h),we(this.toRawBytes(h))}}d.BASE=new d(t.Gx,t.Gy,e.ONE),d.ZERO=new d(e.ZERO,e.ONE,e.ZERO);let p=t.nBitLength,y=Fn(d,t.endo?Math.ceil(p/2):p);return{CURVE:t,ProjectivePoint:d,normPrivateKeyToScalar:c,weierstrassEquation:i,isWithinCurveOrder:a}}function t0(r){let t=en(r);return qt(t,{hash:"hash",hmac:"function",randomBytes:"function"},{bits2int:"function",bits2int_modN:"function",lowS:"boolean"}),Object.freeze({lowS:!0,...t})}function su(r){let t=t0(r),{Fp:e,n}=t,s=e.BYTES+1,o=2*e.BYTES+1;function i(S){return Z(S,n)}function a(S){return Kn(S,n)}let{ProjectivePoint:c,normPrivateKeyToScalar:l,weierstrassEquation:f,isWithinCurveOrder:u}=Qp({...t,toBytes(S,_,E){let b=_.toAffine(),B=e.toBytes(b.x),v=Ee;return Zt("isCompressed",E),E?v(Uint8Array.from([_.hasEvenY()?2:3]),B):v(Uint8Array.from([4]),B,e.toBytes(b.y))},fromBytes(S){let _=S.length,E=S[0],b=S.subarray(1);if(_===s&&(E===2||E===3)){let B=be(b);if(!Qr(B,Bt,e.ORDER))throw new Error("Point is not on curve");let v=f(B),T;try{T=e.sqrt(v)}catch(F){let q=F instanceof Error?": "+F.message:"";throw new Error("Point is not on curve"+q)}let U=(T&Bt)===Bt;return(E&1)===1!==U&&(T=e.neg(T)),{x:B,y:T}}else if(_===o&&E===4){let B=e.fromBytes(b.subarray(0,e.BYTES)),v=e.fromBytes(b.subarray(e.BYTES,2*e.BYTES));return{x:B,y:v}}else throw new Error(`Point of length ${_} was invalid. Expected ${s} compressed bytes or ${o} uncompressed bytes`)}}),d=S=>we(Oe(S,t.nByteLength));function p(S){let _=n>>Bt;return S>_}function y(S){return p(S)?i(-S):S}let m=(S,_,E)=>be(S.slice(_,E));class h{constructor(_,E,b){this.r=_,this.s=E,this.recovery=b,this.assertValidity()}static fromCompact(_){let E=t.nByteLength;return _=nt("compactSignature",_,E*2),new h(m(_,0,E),m(_,E,2*E))}static fromDER(_){let{r:E,s:b}=Re.toSig(nt("DER",_));return new h(E,b)}assertValidity(){St("r",this.r,Bt,n),St("s",this.s,Bt,n)}addRecoveryBit(_){return new h(this.r,this.s,_)}recoverPublicKey(_){let{r:E,s:b,recovery:B}=this,v=N(nt("msgHash",_));if(B==null||![0,1,2,3].includes(B))throw new Error("recovery id invalid");let T=B===2||B===3?E+t.n:E;if(T>=e.ORDER)throw new Error("recovery id 2 or 3 invalid");let U=B&1?"03":"02",H=c.fromHex(U+d(T)),F=a(T),q=i(-v*F),z=i(b*F),W=c.BASE.multiplyAndAddUnsafe(H,q,z);if(!W)throw new Error("point at infinify");return W.assertValidity(),W}hasHighS(){return p(this.s)}normalizeS(){return this.hasHighS()?new h(this.r,i(-this.s),this.recovery):this}toDERRawBytes(){return tr(this.toDERHex())}toDERHex(){return Re.hexFromSig({r:this.r,s:this.s})}toCompactRawBytes(){return tr(this.toCompactHex())}toCompactHex(){return d(this.r)+d(this.s)}}let w={isValidPrivateKey(S){try{return l(S),!0}catch{return!1}},normPrivateKeyToScalar:l,randomPrivateKey:()=>{let S=oi(t.n);return Kc(t.randomBytes(S),t.n)},precompute(S=8,_=c.BASE){return _._setWindowSize(S),_.multiply(BigInt(3)),_}};function x(S,_=!0){return c.fromPrivateKey(S).toRawBytes(_)}function g(S){let _=He(S),E=typeof S=="string",b=(_||E)&&S.length;return _?b===s||b===o:E?b===2*s||b===2*o:S instanceof c}function A(S,_,E=!0){if(g(S))throw new Error("first arg must be private key");if(!g(_))throw new Error("second arg must be public key");return c.fromHex(_).multiply(l(S)).toRawBytes(E)}let L=t.bits2int||function(S){let _=be(S),E=S.length*8-t.nBitLength;return E>0?_>>BigInt(E):_},N=t.bits2int_modN||function(S){return i(L(S))},k=tn(t.nBitLength);function R(S){return St(`num < 2^${t.nBitLength}`,S,Ne,k),Oe(S,t.nByteLength)}function I(S,_,E=O){if(["recovered","canonical"].some(rt=>rt in E))throw new Error("sign() legacy options not supported");let{hash:b,randomBytes:B}=t,{lowS:v,prehash:T,extraEntropy:U}=E;v==null&&(v=!0),S=nt("msgHash",S),ru(E),T&&(S=nt("prehashed msgHash",b(S)));let H=N(S),F=l(_),q=[R(F),R(H)];if(U!=null&&U!==!1){let rt=U===!0?B(e.BYTES):U;q.push(nt("extraEntropy",rt))}let z=Ee(...q),W=H;function et(rt){let ot=L(rt);if(!u(ot))return;let Ct=a(ot),gt=c.BASE.multiply(ot).toAffine(),Vt=i(gt.x);if(Vt===Ne)return;let de=i(Ct*i(W+Vt*F));if(de===Ne)return;let jr=(gt.x===Vt?0:2)|Number(gt.y&Bt),Wr=de;return v&&p(de)&&(Wr=y(de),jr^=1),new h(Vt,Wr,jr)}return{seed:z,k2sig:et}}let O={lowS:t.lowS,prehash:!1},C={lowS:t.lowS,prehash:!1};function V(S,_,E=O){let{seed:b,k2sig:B}=I(S,_,E),v=t;return ti(v.hash.outputLen,v.nByteLength,v.hmac)(b,B)}c.BASE._setWindowSize(8);function K(S,_,E,b=C){let B=S;if(_=nt("msgHash",_),E=nt("publicKey",E),"strict"in b)throw new Error("options.strict was renamed to lowS");ru(b);let{lowS:v,prehash:T}=b,U,H;try{if(typeof B=="string"||He(B))try{U=h.fromDER(B)}catch(gt){if(!(gt instanceof Re.Err))throw gt;U=h.fromCompact(B)}else if(typeof B=="object"&&typeof B.r=="bigint"&&typeof B.s=="bigint"){let{r:gt,s:Vt}=B;U=new h(gt,Vt)}else throw new Error("PARSE");H=c.fromHex(E)}catch(gt){if(gt.message==="PARSE")throw new Error("signature must be Signature instance, Uint8Array or hex string");return!1}if(v&&U.hasHighS())return!1;T&&(_=t.hash(_));let{r:F,s:q}=U,z=N(_),W=a(q),et=i(z*W),rt=i(F*W),ot=c.BASE.multiplyAndAddUnsafe(H,et,rt)?.toAffine();return ot?i(ot.x)===F:!1}return{CURVE:t,getPublicKey:x,getSharedSecret:A,sign:V,verify:K,ProjectivePoint:c,Signature:h,utils:w}}function e0(r){return{hash:r,hmac:(t,...e)=>Fe(r,t,zo(...e)),randomBytes:Je}}function ou(r,t){let e=n=>su({...r,...e0(n)});return Object.freeze({...e(t),create:e})}var cu=BigInt("0xfffffffffffffffffffffffffffffffffffffffffffffffffffffffefffffc2f"),iu=BigInt("0xfffffffffffffffffffffffffffffffebaaedce6af48a03bbfd25e8cd0364141"),r0=BigInt(1),Ki=BigInt(2),au=(r,t)=>(r+t/Ki)/t;function n0(r){let t=cu,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,f=l*l*r%t,u=st(f,e,t)*f%t,d=st(u,e,t)*f%t,p=st(d,Ki,t)*l%t,y=st(p,s,t)*p%t,m=st(y,o,t)*y%t,h=st(m,a,t)*m%t,w=st(h,c,t)*h%t,x=st(w,a,t)*m%t,g=st(x,e,t)*f%t,A=st(g,i,t)*y%t,L=st(A,n,t)*l%t,N=st(L,Ki,t);if(!Fi.eql(Fi.sqr(N),r))throw new Error("Cannot find square root");return N}var Fi=Me(cu,void 0,void 0,{sqrt:n0}),ne=ou({a:BigInt(0),b:BigInt(7),Fp:Fi,n:iu,Gx:BigInt("55066263022277343669578718895168534326250603453777594175500187360389116729240"),Gy:BigInt("32670510020758816978083085130507043184471273380659243275938904335757337482424"),h:BigInt(1),lowS:!0,endo:{beta:BigInt("0x7ae96a2b657c07106e64479eac3434e99cf0497512f58995c1396c28719501ee"),splitScalar:r=>{let t=iu,e=BigInt("0x3086d221a7d46bcde86c90e49284eb15"),n=-r0*BigInt("0xe4437ed6010e88286f547fa90abfe4c3"),s=BigInt("0x114ca50f7a8e2f3f657c1108d9d44cfd8"),o=e,i=BigInt("0x100000000000000000000000000000000"),a=au(o*r,t),c=au(-n*r,t),l=Z(r-a*e-c*s,t),f=Z(-a*n-c*o,t),u=l>i,d=f>i;if(u&&(l=t-l),d&&(f=t-f),l>i||f>i)throw new Error("splitScalar: Endomorphism failed, k="+r);return{k1neg:u,k1:l,k2neg:d,k2:f}}}},Pr),cb=BigInt(0);var lb=ne.ProjectivePoint;function lu(){return ne.utils.randomPrivateKey()}function uu(r,t){let e=At.digest(t instanceof Uint8Array?t:t.subarray());if($t(e))return e.then(({digest:n})=>ne.sign(n,r).toDERRawBytes()).catch(n=>{throw new M(String(n),"ERR_INVALID_INPUT")});try{return ne.sign(e.digest,r).toDERRawBytes()}catch(n){throw new M(String(n),"ERR_INVALID_INPUT")}}function fu(r,t,e){let n=At.digest(e instanceof Uint8Array?e:e.subarray());if($t(n))return n.then(({digest:s})=>ne.verify(t,s,r)).catch(s=>{throw new M(String(s),"ERR_INVALID_INPUT")});try{return ne.verify(t,n.digest,r)}catch(s){throw new M(String(s),"ERR_INVALID_INPUT")}}function hu(r){return ne.ProjectivePoint.fromHex(r).toRawBytes(!0)}function du(r){try{ne.getPublicKey(r,!0)}catch(t){throw new M(String(t),"ERR_INVALID_PRIVATE_KEY")}}function $i(r){try{ne.ProjectivePoint.fromHex(r)}catch(t){throw new M(String(t),"ERR_INVALID_PUBLIC_KEY")}}function pu(r){try{return ne.getPublicKey(r,!0)}catch(t){throw new M(String(t),"ERR_INVALID_PRIVATE_KEY")}}var xn=class{_key;constructor(t){$i(t),this._key=t}verify(t,e){return fu(this._key,e,t)}marshal(){return hu(this._key)}get bytes(){return ae.encode({Type:at.Secp256k1,Data:this.marshal()}).subarray()}equals(t){return ft(this.bytes,t.bytes)}async hash(){let t=At.digest(this.bytes),e;return $t(t)?{bytes:e}=await t:e=t.bytes,e}},En=class{_key;_publicKey;constructor(t,e){this._key=t,this._publicKey=e??pu(t),du(this._key),$i(this._publicKey)}sign(t){return uu(this._key,t)}get public(){return new xn(this._publicKey)}marshal(){return this._key}get bytes(){return ce.encode({Type:at.Secp256k1,Data:this.marshal()}).subarray()}equals(t){return ft(this.bytes,t.bytes)}hash(){let t=At.digest(this.bytes);return $t(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 Ir(this.bytes,t);throw new M(`export format '${e}' is not supported`,"ERR_INVALID_EXPORT_FORMAT")}};function o0(r){return new En(r)}function i0(r){return new xn(r)}async function a0(){let r=lu();return new En(r)}var fr={rsa:Oi,ed25519:Ri,secp256k1:qi};function gu(r){let t=Object.keys(fr).join(" / ");return new M(`invalid or unsupported key type ${r}. Must be ${t}`,"ERR_UNSUPPORTED_KEY_TYPE")}function mu(r){let t=ae.decode(r),e=t.Data??new Uint8Array;switch(t.Type){case at.RSA:return fr.rsa.unmarshalRsaPublicKey(e);case at.Ed25519:return fr.ed25519.unmarshalEd25519PublicKey(e);case at.Secp256k1:return fr.secp256k1.unmarshalSecp256k1PublicKey(e);default:throw gu(t.Type??"unknown")}}async function Gi(r){let t=ce.decode(r),e=t.Data??new Uint8Array;switch(t.Type){case at.RSA:return fr.rsa.unmarshalRsaPrivateKey(e);case at.Ed25519:return fr.ed25519.unmarshalEd25519PrivateKey(e);case at.Secp256k1:return fr.secp256k1.unmarshalSecp256k1PrivateKey(e);default:throw gu(t.Type??"RSA")}}var wu=Symbol.for("nodejs.util.inspect.custom"),yu=Object.values(oe).map(r=>r.decoder).reduce((r,t)=>r.or(t),oe.identity.decoder),bu=114,Wi=36,Yi=37,vn=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()})`}[Ln]=!0;toString(){return this.string==null&&(this.string=ut.encode(this.multihash.bytes).slice(1)),this.string}toCID(){return Ft.createV1(bu,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 Zi(t).equals(this);if(t?.multihash?.bytes!=null)return ft(this.multihash.bytes,t.multihash.bytes);throw new Error("not valid Id")}[wu](){return`PeerId(${this.toString()})`}},Dr=class extends vn{type="RSA";publicKey;constructor(t){super({...t,type:"RSA"}),this.publicKey=t.publicKey}},Vr=class extends vn{type="Ed25519";publicKey;constructor(t){super({...t,type:"Ed25519"}),this.publicKey=t.multihash.digest}},Hr=class extends vn{type="secp256k1";publicKey;constructor(t){super({...t,type:"secp256k1"}),this.publicKey=t.multihash.digest}},zi=2336,ji=class{type="url";multihash;privateKey;publicKey;url;constructor(t){this.url=t.toString(),this.multihash=ge.digest(Y(this.url))}[wu](){return`PeerId(${this.url})`}[Ln]=!0;toString(){return this.toCID().toString()}toCID(){return Ft.createV1(zi,this.multihash)}toBytes(){return this.toCID().bytes}equals(t){return t==null?!1:(t instanceof Uint8Array&&(t=$(t)),t.toString()===this.toString())}};function Zi(r,t){if(t=t??yu,r.charAt(0)==="1"||r.charAt(0)==="Q"){let e=Ue(ut.decode(`z${r}`));return r.startsWith("12D")?new Vr({multihash:e}):r.startsWith("16U")?new Hr({multihash:e}):new Dr({multihash:e})}return c0(yu.decode(r))}function c0(r){try{let t=Ue(r);if(t.code===ge.code){if(t.digest.length===Wi)return new Vr({multihash:t});if(t.digest.length===Yi)return new Hr({multihash:t})}if(t.code===At.code)return new Dr({multihash:t})}catch{return l0(Ft.decode(r))}throw new Error("Supplied PeerID CID is invalid")}function l0(r){if(r?.multihash==null||r.version==null||r.version===1&&r.code!==bu&&r.code!==zi)throw new Error("Supplied PeerID CID is invalid");if(r.code===zi){let e=$(r.multihash.digest);return new ji(new URL(e))}let t=r.multihash;if(t.code===At.code)return new Dr({multihash:r.multihash});if(t.code===ge.code){if(t.digest.length===Wi)return new Vr({multihash:r.multihash});if(t.digest.length===Yi)return new Hr({multihash:r.multihash})}throw new Error("Supplied PeerID CID is invalid")}async function Xi(r,t){return r.length===Wi?new Vr({multihash:jt(ge.code,r),privateKey:t}):r.length===Yi?new Hr({multihash:jt(ge.code,r),privateKey:t}):new Dr({multihash:await At.digest(r),publicKey:r,privateKey:t})}var Eu=Symbol.for("@achingbrain/uint8arraylist");function xu(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 Ms(r){return!!r?.[Eu]}var ct=class r{bufs;length;[Eu]=!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(Ms(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(Ms(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=xu(this.bufs,t);return e.buf[e.index]}set(t,e){let n=xu(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(Ms(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,f=e>a&&e<=c;if(l&&f){if(t===a&&e===c){n.push(i);break}let u=t-a;n.push(i.subarray(u,u+(e-t)));break}if(l){if(t===0){n.push(i);continue}n.push(i.subarray(t-a));continue}if(f){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(!Ms(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 u=0;u<o;u++)i[u]=-1;for(let u=0;u<s;u++)i[n[u]]=u;let a=i,c=this.byteLength-n.byteLength,l=n.byteLength-1,f;for(let u=e;u<=c;u+=f){f=0;for(let d=l;d>=0;d--){let p=this.get(u+d);if(n[d]!==p){f=Math.max(1,d-a[p]);break}}if(f===0)return u}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 Ks(r){return r[Symbol.asyncIterator]!=null}var Fs=r=>{let t=dt(r),e=wt(t);return ie(r,e),Fs.bytes=t,e};Fs.bytes=0;function vu(r,t){t=t??{};let e=t.lengthEncoder??Fs;function*n(s){let o=e(s.byteLength);o instanceof Uint8Array?yield o:yield*o,s instanceof Uint8Array?yield s:yield*s}return Ks(r)?async function*(){for await(let s of r)yield*n(s)}():function*(){for(let s of r)yield*n(s)}()}vu.single=(r,t)=>{t=t??{};let e=t.lengthEncoder??Fs;return new ct(e(r.byteLength),r)};var $s=class extends Error{name="InvalidMessageLengthError";code="ERR_INVALID_MSG_LENGTH"},qs=class extends Error{name="InvalidDataLengthError";code="ERR_MSG_DATA_TOO_LONG"},Gs=class extends Error{name="InvalidDataLengthLengthError";code="ERR_MSG_LENGTH_TOO_LONG"},Bn=class extends Error{name="UnexpectedEOFError";code="ERR_UNEXPECTED_EOF"};var u0=8,f0=1024*1024*4,hr;(function(r){r[r.LENGTH=0]="LENGTH",r[r.DATA=1]="DATA"})(hr||(hr={}));var Ji=r=>{let t=Qt(r);return Ji.bytes=dt(t),t};Ji.bytes=0;function An(r,t){let e=new ct,n=hr.LENGTH,s=-1,o=t?.lengthDecoder??Ji,i=t?.maxLengthLength??u0,a=t?.maxDataLength??f0;function*c(){for(;e.byteLength>0;){if(n===hr.LENGTH)try{if(s=o(e),s<0)throw new $s("Invalid message length");if(s>a)throw new qs("Message length too long");let l=o.bytes;e.consume(l),t?.onLength!=null&&t.onLength(s),n=hr.DATA}catch(l){if(l instanceof RangeError){if(e.byteLength>i)throw new Gs("Message length length too long");break}throw l}if(n===hr.DATA){if(e.byteLength<s)break;let l=e.sublist(0,s);e.consume(s),t?.onData!=null&&t.onData(l),yield l,n=hr.LENGTH}}}return Ks(r)?async function*(){for await(let l of r)e.append(l),yield*c();if(e.byteLength>0)throw new Bn("Unexpected end of input")}():function*(){for(let l of r)e.append(l),yield*c();if(e.byteLength>0)throw new Bn("Unexpected end of input")}()}An.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 An(n,{...t??{},onLength:o=>{e=o}})};function Lt(){let r={};return r.promise=new Promise((t,e)=>{r.resolve=t,r.reject=e}),r}var zs=class extends Error{type;code;constructor(t,e,n){super(t??"The operation was aborted"),this.type="aborted",this.name=n??"AbortError",this.code=e??"ABORT_ERR"}};async function Dt(r,t,e){if(t==null)return r;if(t.aborted)return Promise.reject(new zs(e?.errorMessage,e?.errorCode,e?.errorName));let n,s=new zs(e?.errorMessage,e?.errorCode,e?.errorName);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 Qi=class{readNext;haveNext;ended;nextResult;constructor(){this.ended=!1,this.readNext=Lt(),this.haveNext=Lt()}[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=Lt(),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=Lt(),await Dt(this.readNext.promise,e?.signal,e)}};function Bu(){return new Qi}var js=class extends Error{name="UnexpectedEOFError";code="ERR_UNEXPECTED_EOF"};var ta=class extends Error{code;constructor(t,e){super(t),this.code=e}},ea=class extends ta{type;constructor(t){super(t,"ABORT_ERR"),this.type="aborted",this.name="AbortError"}};function Au(r,t){let e=Bu();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((f,u)=>{c=()=>{u(new ea("Read aborted"))},a?.signal?.addEventListener("abort",c)});try{if(i==null){let{done:u,value:d}=await Promise.race([n.next(),l]);return u===!0?new ct:d}for(;s.byteLength<i;){let{value:u,done:d}=await Promise.race([n.next(),l]);if(d===!0)throw new js("unexpected end of input");s.append(u)}let f=s.sublist(0,i);return s.consume(i),f}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 Ws=class extends Error{name="InvalidMessageLengthError";code="ERR_INVALID_MSG_LENGTH"},Ys=class extends Error{name="InvalidDataLengthError";code="ERR_MSG_DATA_TOO_LONG"},Zs=class extends Error{name="InvalidDataLengthLengthError";code="ERR_MSG_LENGTH_TOO_LONG"};function ra(r,t={}){let e=Au(r,t);t.maxDataLength!=null&&t.maxLengthLength==null&&(t.maxLengthLength=dt(t.maxDataLength));let n=t?.lengthDecoder??Qt,s=t?.lengthEncoder??ie;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(a<0)throw new Ws("Invalid message length");if(t?.maxLengthLength!=null&&c.byteLength>t.maxLengthLength)throw new Zs("message length length too long");if(a>-1)break}if(t?.maxDataLength!=null&&a>t.maxDataLength)throw new Ys("message length 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 na(){let r=Lt(),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 Su(){let r=na(),t=na();return[{source:r.source,sink:t.sink},{source:t.source,sink:r.sink}]}var Xs=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}},Or=class{size;hwm;head;tail;constructor(t={}){this.hwm=t.splitLimit??16,this.head=new Xs(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 Xs(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 sa=class extends Error{type;code;constructor(t,e){super(t??"The operation was aborted"),this.type="aborted",this.code=e??"ABORT_ERR"}};function Mr(r={}){return h0(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 h0(r,t){t=t??{};let e=t.onEnd,n=new Or,s,o,i,a=Lt(),c=async()=>{try{return n.isEmpty()?i?{done:!0}:await new Promise((h,w)=>{o=x=>{o=null,n.push(x);try{h(r(n))}catch(g){w(g)}return s}}):r(n)}finally{n.isEmpty()&&queueMicrotask(()=>{a.resolve(),a=Lt()})}},l=h=>o!=null?o(h):(n.push(h),s),f=h=>(n=new Or,o!=null?o({error:h}):(n.push({error:h}),s)),u=h=>{if(i)return s;if(t?.objectMode!==!0&&h?.byteLength==null)throw new Error("objectMode was not true but tried to push non-Uint8Array value");return l({done:!1,value:h})},d=h=>i?s:(i=!0,h!=null?f(h):l({done:!0})),p=()=>(n=new Or,d(),{done:!0}),y=h=>(d(h),{done:!0});if(s={[Symbol.asyncIterator](){return this},next:c,return:p,throw:y,push:u,end:d,get readableLength(){return n.size},onEmpty:async h=>{let w=h?.signal;if(w?.throwIfAborted(),n.isEmpty())return;let x,g;w!=null&&(x=new Promise((A,L)=>{g=()=>{L(new sa)},w.addEventListener("abort",g)}));try{await Promise.race([a.promise,x])}finally{g!=null&&w!=null&&w?.removeEventListener("abort",g)}}},e==null)return s;let m=s;return s={[Symbol.asyncIterator](){return this},next(){return m.next()},throw(h){return m.throw(h),e!=null&&(e(h),e=void 0),{done:!0}},return(){return m.return(),e!=null&&(e(),e=void 0),{done:!0}},push:u,end(h){return m.end(h),e!=null&&(e(h),e=void 0),s},get readableLength(){return m.readableLength},onEmpty:h=>m.onEmpty(h)},s}function d0(r){return r[Symbol.asyncIterator]!=null}function p0(...r){let t=[];for(let e of r)d0(e)||t.push(e);return t.length===r.length?function*(){for(let e of t)yield*e}():async function*(){let e=Mr({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 ku=p0;function Iu(r,...t){if(r==null)throw new Error("Empty pipeline");if(oa(r)){let n=r;r=()=>n.source}else if(Ru(r)||_u(r)){let n=r;r=()=>n}let e=[r,...t];if(e.length>1&&oa(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++)oa(e[n])&&(e[n]=m0(e[n]));return g0(...e)}var g0=(...r)=>{let t;for(;r.length>0;)t=r.shift()(t);return t},_u=r=>r?.[Symbol.asyncIterator]!=null,Ru=r=>r?.[Symbol.iterator]!=null,oa=r=>r==null?!1:r.sink!=null&&r.source!=null,m0=r=>t=>{let e=r.sink(t);if(e?.then!=null){let n=Mr({objectMode:!0});e.then(()=>{n.end()},i=>{n.end(i)});let s,o=r.source;if(_u(o))s=async function*(){yield*o,n.end()};else if(Ru(o))s=function*(){yield*o,n.end()};else throw new Error("Unknown duplex source type - must be Iterable or AsyncIterable");return ku(n,s())}return r.source};var Kr=!!globalThis.process?.env?.DUMP_SESSION_KEYS;function Js(r){if(!Number.isSafeInteger(r)||r<0)throw new Error(`positive integer expected, not ${r}`)}function ia(r){if(typeof r!="boolean")throw new Error(`boolean expected, not ${r}`)}function aa(r){return r instanceof Uint8Array||r!=null&&typeof r=="object"&&r.constructor.name==="Uint8Array"}function Mt(r,...t){if(!aa(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 ca(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 Nu(r,t){Mt(r);let e=t.outputLen;if(r.length<e)throw new Error(`digestInto() expects output buffer of length at least ${e}`)}var Te=r=>new Uint32Array(r.buffer,r.byteOffset,Math.floor(r.byteLength/4)),Tu=r=>new DataView(r.buffer,r.byteOffset,r.byteLength),y0=new Uint8Array(new Uint32Array([287454020]).buffer)[0]===68;if(!y0)throw new Error("Non little-endian hardware is not supported");function w0(r){if(typeof r!="string")throw new Error(`string expected, got ${typeof r}`);return new Uint8Array(new TextEncoder().encode(r))}function Qs(r){if(typeof r=="string")r=w0(r);else if(aa(r))r=to(r);else throw new Error(`Uint8Array expected, got ${typeof r}`);return r}function Lu(r,t){if(t==null||typeof t!="object")throw new Error("options must be defined");return Object.assign(r,t)}function Cu(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 la=(r,t)=>(Object.assign(t,r),t);function ua(r,t,e,n){if(typeof r.setBigUint64=="function")return r.setBigUint64(t,e,n);let s=BigInt(32),o=BigInt(4294967295),i=Number(e>>s&o),a=Number(e&o),c=n?4:0,l=n?0:4;r.setUint32(t+c,i,n),r.setUint32(t+l,a,n)}function to(r){return Uint8Array.from(r)}function Le(...r){for(let t=0;t<r.length;t++)r[t].fill(0)}var Pu=r=>Uint8Array.from(r.split("").map(t=>t.charCodeAt(0))),b0=Pu("expand 16-byte k"),x0=Pu("expand 32-byte k"),E0=Te(b0),Du=Te(x0),Nx=Du.slice();function D(r,t){return r<<t|r>>>32-t}function fa(r){return r.byteOffset%4===0}var eo=64,v0=16,Vu=2**32-1,Uu=new Uint32Array;function B0(r,t,e,n,s,o,i,a){let c=s.length,l=new Uint8Array(eo),f=Te(l),u=fa(s)&&fa(o),d=u?Te(s):Uu,p=u?Te(o):Uu;for(let y=0;y<c;i++){if(r(t,e,n,f,i,a),i>=Vu)throw new Error("arx: counter overflow");let m=Math.min(eo,c-y);if(u&&m===eo){let h=y/4;if(y%4!==0)throw new Error("arx: invalid block position");for(let w=0,x;w<v0;w++)x=h+w,p[x]=d[x]^f[w];y+=eo;continue}for(let h=0,w;h<m;h++)w=y+h,o[w]=s[w]^l[h];y+=m}}function ha(r,t){let{allowShortKeys:e,extendNonceFn:n,counterLength:s,counterRight:o,rounds:i}=Lu({allowShortKeys:!1,counterLength:8,counterRight:!1,rounds:20},t);if(typeof r!="function")throw new Error("core must be a function");return Js(s),Js(i),ia(o),ia(e),(a,c,l,f,u=0)=>{Mt(a),Mt(c),Mt(l);let d=l.length;if(f===void 0&&(f=new Uint8Array(d)),Mt(f),Js(u),u<0||u>=Vu)throw new Error("arx: counter overflow");if(f.length<d)throw new Error(`arx: output (${f.length}) is shorter than data (${d})`);let p=[],y=a.length,m,h;if(y===32)p.push(m=to(a)),h=Du;else if(y===16&&e)m=new Uint8Array(32),m.set(a),m.set(a,16),h=E0,p.push(m);else throw new Error(`arx: invalid 32-byte key, got length=${y}`);fa(c)||p.push(c=to(c));let w=Te(m);if(n){if(c.length!==24)throw new Error("arx: extended nonce must be 24 bytes");n(h,w,Te(c.subarray(0,16)),w),c=c.subarray(16)}let x=16-s;if(x!==c.length)throw new Error(`arx: nonce must be ${x} or 16 bytes`);if(x!==12){let A=new Uint8Array(12);A.set(c,o?0:12-c.length),c=A,p.push(c)}let g=Te(c);return B0(r,h,w,g,l,f,u,i),Le(...p),f}}var It=(r,t)=>r[t++]&255|(r[t++]&255)<<8,da=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=Qs(t),Mt(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 f=0;f<8;f++)this.pad[f]=It(t,16+2*f)}process(t,e,n=!1){let s=n?0:2048,{h:o,r:i}=this,a=i[0],c=i[1],l=i[2],f=i[3],u=i[4],d=i[5],p=i[6],y=i[7],m=i[8],h=i[9],w=It(t,e+0),x=It(t,e+2),g=It(t,e+4),A=It(t,e+6),L=It(t,e+8),N=It(t,e+10),k=It(t,e+12),R=It(t,e+14),I=o[0]+(w&8191),O=o[1]+((w>>>13|x<<3)&8191),C=o[2]+((x>>>10|g<<6)&8191),V=o[3]+((g>>>7|A<<9)&8191),K=o[4]+((A>>>4|L<<12)&8191),S=o[5]+(L>>>1&8191),_=o[6]+((L>>>14|N<<2)&8191),E=o[7]+((N>>>11|k<<5)&8191),b=o[8]+((k>>>8|R<<8)&8191),B=o[9]+(R>>>5|s),v=0,T=v+I*a+O*(5*h)+C*(5*m)+V*(5*y)+K*(5*p);v=T>>>13,T&=8191,T+=S*(5*d)+_*(5*u)+E*(5*f)+b*(5*l)+B*(5*c),v+=T>>>13,T&=8191;let U=v+I*c+O*a+C*(5*h)+V*(5*m)+K*(5*y);v=U>>>13,U&=8191,U+=S*(5*p)+_*(5*d)+E*(5*u)+b*(5*f)+B*(5*l),v+=U>>>13,U&=8191;let H=v+I*l+O*c+C*a+V*(5*h)+K*(5*m);v=H>>>13,H&=8191,H+=S*(5*y)+_*(5*p)+E*(5*d)+b*(5*u)+B*(5*f),v+=H>>>13,H&=8191;let F=v+I*f+O*l+C*c+V*a+K*(5*h);v=F>>>13,F&=8191,F+=S*(5*m)+_*(5*y)+E*(5*p)+b*(5*d)+B*(5*u),v+=F>>>13,F&=8191;let q=v+I*u+O*f+C*l+V*c+K*a;v=q>>>13,q&=8191,q+=S*(5*h)+_*(5*m)+E*(5*y)+b*(5*p)+B*(5*d),v+=q>>>13,q&=8191;let z=v+I*d+O*u+C*f+V*l+K*c;v=z>>>13,z&=8191,z+=S*a+_*(5*h)+E*(5*m)+b*(5*y)+B*(5*p),v+=z>>>13,z&=8191;let W=v+I*p+O*d+C*u+V*f+K*l;v=W>>>13,W&=8191,W+=S*c+_*a+E*(5*h)+b*(5*m)+B*(5*y),v+=W>>>13,W&=8191;let et=v+I*y+O*p+C*d+V*u+K*f;v=et>>>13,et&=8191,et+=S*l+_*c+E*a+b*(5*h)+B*(5*m),v+=et>>>13,et&=8191;let rt=v+I*m+O*y+C*p+V*d+K*u;v=rt>>>13,rt&=8191,rt+=S*f+_*l+E*c+b*a+B*(5*h),v+=rt>>>13,rt&=8191;let ot=v+I*h+O*m+C*y+V*p+K*d;v=ot>>>13,ot&=8191,ot+=S*u+_*f+E*l+b*c+B*a,v+=ot>>>13,ot&=8191,v=(v<<2)+v|0,v=v+T|0,T=v&8191,v=v>>>13,U+=v,o[0]=T,o[1]=U,o[2]=H,o[3]=F,o[4]=q,o[5]=z,o[6]=W,o[7]=et,o[8]=rt,o[9]=ot}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;Le(n)}update(t){ca(this);let{buffer:e,blockLen:n}=this;t=Qs(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(){Le(this.h,this.r,this.buffer,this.pad)}digestInto(t){ca(this),Nu(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 A0(r){let t=(n,s)=>r(s).update(Qs(n)).digest(),e=r(new Uint8Array(32));return t.outputLen=e.outputLen,t.blockLen=e.blockLen,t.create=n=>r(n),t}var Hu=A0(r=>new da(r));function Ku(r,t,e,n,s,o=20){let i=r[0],a=r[1],c=r[2],l=r[3],f=t[0],u=t[1],d=t[2],p=t[3],y=t[4],m=t[5],h=t[6],w=t[7],x=s,g=e[0],A=e[1],L=e[2],N=i,k=a,R=c,I=l,O=f,C=u,V=d,K=p,S=y,_=m,E=h,b=w,B=x,v=g,T=A,U=L;for(let F=0;F<o;F+=2)N=N+O|0,B=D(B^N,16),S=S+B|0,O=D(O^S,12),N=N+O|0,B=D(B^N,8),S=S+B|0,O=D(O^S,7),k=k+C|0,v=D(v^k,16),_=_+v|0,C=D(C^_,12),k=k+C|0,v=D(v^k,8),_=_+v|0,C=D(C^_,7),R=R+V|0,T=D(T^R,16),E=E+T|0,V=D(V^E,12),R=R+V|0,T=D(T^R,8),E=E+T|0,V=D(V^E,7),I=I+K|0,U=D(U^I,16),b=b+U|0,K=D(K^b,12),I=I+K|0,U=D(U^I,8),b=b+U|0,K=D(K^b,7),N=N+C|0,U=D(U^N,16),E=E+U|0,C=D(C^E,12),N=N+C|0,U=D(U^N,8),E=E+U|0,C=D(C^E,7),k=k+V|0,B=D(B^k,16),b=b+B|0,V=D(V^b,12),k=k+V|0,B=D(B^k,8),b=b+B|0,V=D(V^b,7),R=R+K|0,v=D(v^R,16),S=S+v|0,K=D(K^S,12),R=R+K|0,v=D(v^R,8),S=S+v|0,K=D(K^S,7),I=I+O|0,T=D(T^I,16),_=_+T|0,O=D(O^_,12),I=I+O|0,T=D(T^I,8),_=_+T|0,O=D(O^_,7);let H=0;n[H++]=i+N|0,n[H++]=a+k|0,n[H++]=c+R|0,n[H++]=l+I|0,n[H++]=f+O|0,n[H++]=u+C|0,n[H++]=d+V|0,n[H++]=p+K|0,n[H++]=y+S|0,n[H++]=m+_|0,n[H++]=h+E|0,n[H++]=w+b|0,n[H++]=x+B|0,n[H++]=g+v|0,n[H++]=A+T|0,n[H++]=L+U|0}function S0(r,t,e,n){let s=r[0],o=r[1],i=r[2],a=r[3],c=t[0],l=t[1],f=t[2],u=t[3],d=t[4],p=t[5],y=t[6],m=t[7],h=e[0],w=e[1],x=e[2],g=e[3];for(let L=0;L<20;L+=2)s=s+c|0,h=D(h^s,16),d=d+h|0,c=D(c^d,12),s=s+c|0,h=D(h^s,8),d=d+h|0,c=D(c^d,7),o=o+l|0,w=D(w^o,16),p=p+w|0,l=D(l^p,12),o=o+l|0,w=D(w^o,8),p=p+w|0,l=D(l^p,7),i=i+f|0,x=D(x^i,16),y=y+x|0,f=D(f^y,12),i=i+f|0,x=D(x^i,8),y=y+x|0,f=D(f^y,7),a=a+u|0,g=D(g^a,16),m=m+g|0,u=D(u^m,12),a=a+u|0,g=D(g^a,8),m=m+g|0,u=D(u^m,7),s=s+l|0,g=D(g^s,16),y=y+g|0,l=D(l^y,12),s=s+l|0,g=D(g^s,8),y=y+g|0,l=D(l^y,7),o=o+f|0,h=D(h^o,16),m=m+h|0,f=D(f^m,12),o=o+f|0,h=D(h^o,8),m=m+h|0,f=D(f^m,7),i=i+u|0,w=D(w^i,16),d=d+w|0,u=D(u^d,12),i=i+u|0,w=D(w^i,8),d=d+w|0,u=D(u^d,7),a=a+c|0,x=D(x^a,16),p=p+x|0,c=D(c^p,12),a=a+c|0,x=D(x^a,8),p=p+x|0,c=D(c^p,7);let A=0;n[A++]=s,n[A++]=o,n[A++]=i,n[A++]=a,n[A++]=h,n[A++]=w,n[A++]=x,n[A++]=g}var k0=ha(Ku,{counterRight:!1,counterLength:4,allowShortKeys:!1}),I0=ha(Ku,{counterRight:!1,counterLength:8,extendNonceFn:S0,allowShortKeys:!1});var _0=new Uint8Array(16),Ou=(r,t)=>{r.update(t);let e=t.length%16;e&&r.update(_0.subarray(e))},R0=new Uint8Array(32);function Mu(r,t,e,n,s){let o=r(t,e,R0),i=Hu.create(o);s&&Ou(i,s),Ou(i,n);let a=new Uint8Array(16),c=Tu(a);ua(c,0,BigInt(s?s.length:0),!0),ua(c,8,BigInt(n.length),!0),i.update(a);let l=i.digest();return Le(o,a),l}var Fu=r=>(t,e,n)=>(Mt(t,32),Mt(e),{encrypt(o,i){let a=o.length,c=a+16;i?Mt(i,c):i=new Uint8Array(c),r(t,e,o,i,1);let l=Mu(r,t,e,i.subarray(0,-16),n);return i.set(l,a),Le(l),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?Mt(i,c):i=new Uint8Array(c);let l=o.subarray(0,-16),f=o.subarray(-16),u=Mu(r,t,e,l,n);if(!Cu(f,u))throw new Error("invalid tag");return r(t,e,l,i,1),Le(u),i}}),pa=la({blockSize:64,nonceLength:12,tagLength:16},Fu(k0)),Ox=la({blockSize:64,nonceLength:24,tagLength:16},Fu(I0));function qu(r,t,e){return Ze(r),e===void 0&&(e=new Uint8Array(r.outputLen)),Fe(r,Yt(e),Yt(t))}var ga=new Uint8Array([0]),$u=new Uint8Array;function Gu(r,t,e,n=32){if(Ze(r),Pe(n),n>255*r.outputLen)throw new Error("Length should be <= 255*HashLen");let s=Math.ceil(n/r.outputLen);e===void 0&&(e=$u);let o=new Uint8Array(s*r.outputLen),i=Fe.create(r,t),a=i._cloneInto(),c=new Uint8Array(i.outputLen);for(let l=0;l<s;l++)ga[0]=l+1,a.update(l===0?$u:c).update(e).update(ga).digestInto(c),o.set(c,r.outputLen*l),i._cloneInto(a);return i.destroy(),a.destroy(),c.fill(0),ga.fill(0),o.slice(0,n)}var ma={hashSHA256(r){return Pr(r.subarray())},getHKDF(r,t){let e=qu(Pr,t,r),s=Gu(Pr,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=nn.utils.randomPrivateKey();return{publicKey:nn.getPublicKey(r),privateKey:r}},generateX25519KeyPairFromSeed(r){return{publicKey:nn.getPublicKey(r),privateKey:r}},generateX25519SharedKey(r,t){return nn.getSharedSecret(r.subarray(),t.subarray())},chaCha20Poly1305Encrypt(r,t,e,n){return pa(n,t,e).encrypt(r.subarray())},chaCha20Poly1305Decrypt(r,t,e,n,s){return pa(n,t,e).decrypt(r.subarray(),s)}};var zu=ma;function ju(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 Fr=r=>{let t=wt(2);return t[0]=r>>8,t[1]=r,t};Fr.bytes=2;var Sn=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)};Sn.bytes=2;function Wu(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 ya(r,t){!t.enabled||!Kr||(r?(t(`LOCAL_STATIC_PUBLIC_KEY ${$(r.publicKey,"hex")}`),t(`LOCAL_STATIC_PRIVATE_KEY ${$(r.privateKey,"hex")}`)):t("Missing local static keys."))}function wa(r,t){!t.enabled||!Kr||(r?(t(`LOCAL_PUBLIC_EPHEMERAL_KEY ${$(r.publicKey,"hex")}`),t(`LOCAL_PRIVATE_EPHEMERAL_KEY ${$(r.privateKey,"hex")}`)):t("Missing local ephemeral keys."))}function Yu(r,t){!t.enabled||!Kr||t(r?`REMOTE_STATIC_PUBLIC_KEY ${$(r.subarray(),"hex")}`:"Missing remote static public key.")}function ba(r,t){!t.enabled||!Kr||t(r?`REMOTE_EPHEMERAL_PUBLIC_KEY ${$(r.subarray(),"hex")}`:"Missing remote ephemeral keys.")}function xa(r,t,e){!e.enabled||!Kr||(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 ro=class r extends Error{code;constructor(t="Unexpected Peer"){super(t),this.code=r.code}static code="ERR_UNEXPECTED_PEER"},$r=class r extends Error{code;constructor(t="Invalid crypto exchange"){super(t),this.code=r.code}static code="ERR_INVALID_CRYPTO_EXCHANGE"};var N0=0,T0=4294967295,L0="Cipherstate has reached maximum n, a new handshake must be performed",no=class{n;bytes;view;constructor(t=N0){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>T0)throw new Error(L0)}};var dr=yt(0),qr=class{k;n;crypto;constructor(t,e=void 0,n=0){this.crypto=t,this.k=e,this.n=new no(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}},Ea=class{cs;ck;h;crypto;constructor(t,e){this.crypto=t;let n=Y(e,"utf-8");this.h=C0(t,n),this.ck=this.h,this.cs=new qr(t)}mixKey(t){let[e,n]=this.crypto.hkdf(this.ck,t);this.ck=e,this.cs=new qr(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,dr);return[new qr(this.crypto,t),new qr(this.crypto,e)]}},va=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 Ea(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()}},kn=class extends va{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 $r(`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 $r(`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 $r(`handshake stage 2 validation fail: ${e.message}`)}}};function C0(r,t){if(t.length<=32){let e=yt(32);return e.set(t),e}else return r.hash(t)}var so;(function(r){let t;r.codec=()=>(t==null&&(t=ar((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=>ir(e,r.codec()),r.decode=e=>sr(e,r.codec())})(so||(so={}));var In;(function(r){let t;r.codec=()=>(t==null&&(t=ar((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),so.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=so.codec().decode(e,e.uint32());break}default:{e.skipType(i&7);break}}}return s})),t),r.encode=e=>ir(e,r.codec()),r.decode=e=>sr(e,r.codec())})(In||(In={}));async function Ba(r,t,e){let n=await r.sign(Zu(t));return In.encode({identityKey:r.public.bytes,identitySig:n,extensions:e})}async function Aa(r,t,e){try{let n=In.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=Zu(t);if(!await mu(n.identityKey).verify(s,n.identitySig))throw new Error("Invalid payload signature");return n}catch(n){throw new ro(n.message)}}function Zu(r){let t=Y("noise-libp2p-static-key:");return r instanceof Uint8Array?Et([t,r],t.length+r.length):(r.prepend(t),r)}async function Xu(r,t){let{log:e,connection:n,crypto:s,privateKey:o,prologue:i,s:a,remoteIdentityKey:c,extensions:l}=r,f=await Ba(o,a.publicKey,l),u=new kn({crypto:s,protocolName:"Noise_XX_25519_ChaChaPoly_SHA256",initiator:!0,prologue:i,s:a});ya(u.s,e),e.trace("Stage 0 - Initiator starting to send first message."),await n.write(u.writeMessageA(dr),t),e.trace("Stage 0 - Initiator finished sending first message."),wa(u.e,e),e.trace("Stage 1 - Initiator waiting to receive first message from responder...");let d=u.readMessageB(await n.read(t));e.trace("Stage 1 - Initiator received the message."),ba(u.re,e),Yu(u.rs,e),e.trace("Initiator going to check remote's signature...");let p=await Aa(d,u.rs,c);e.trace("All good with the signature!"),e.trace("Stage 2 - Initiator sending third handshake message."),await n.write(u.writeMessageC(f),t),e.trace("Stage 2 - Initiator sent message with signed payload.");let[y,m]=u.ss.split();return xa(y,m,e),{payload:p,encrypt:h=>y.encryptWithAd(dr,h),decrypt:(h,w)=>m.decryptWithAd(dr,h,w)}}async function Ju(r,t){let{log:e,connection:n,crypto:s,privateKey:o,prologue:i,s:a,remoteIdentityKey:c,extensions:l}=r,f=await Ba(o,a.publicKey,l),u=new kn({crypto:s,protocolName:"Noise_XX_25519_ChaChaPoly_SHA256",initiator:!1,prologue:i,s:a});ya(u.s,e),e.trace("Stage 0 - Responder waiting to receive first message."),u.readMessageA(await n.read(t)),e.trace("Stage 0 - Responder received first message."),ba(u.re,e),e.trace("Stage 1 - Responder sending out first message with signed payload and static key."),await n.write(u.writeMessageB(f),t),e.trace("Stage 1 - Responder sent the second handshake message with signed payload."),wa(u.e,e),e.trace("Stage 2 - Responder waiting for third handshake message...");let d=u.readMessageC(await n.read(t));e.trace("Stage 2 - Responder received the message, finished handshake.");let p=await Aa(d,u.rs,c),[y,m]=u.ss.split();return xa(y,m,e),{payload:p,encrypt:h=>m.encryptWithAd(dr,h),decrypt:(h,w)=>y.decryptWithAd(dr,h,w)}}var tf=16;function ef(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(Fr(i.byteLength),i)}}}function rf(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-tf<s)throw new Error("Invalid chunk");let i=n.sublist(s,o),a=n.subarray(s,o-tf);try{let c=r.decrypt(i,a);t?.decryptedPackets.increment(),yield c}catch(c){throw t?.decryptErrors.increment(),c}}}}var oo=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??zu;this.crypto=ju(c),this.extensions=s,this.metrics=a?Wu(a):void 0,n?this.staticKey=c.generateX25519KeyPairFromSeed(n):this.staticKey=c.generateX25519KeyPair(),this.prologue=i??yt(0)}[Symbol.toStringTag]="@chainsafe/libp2p-noise";[Un]=["@libp2p/connection-encryption","@chainsafe/libp2p-noise"];async secureOutbound(...t){let{localPeer:e,connection:n,remotePeer:s,signal:o}=this.parseArgs(t),i=ra(n,{lengthEncoder:Fr,lengthDecoder:Sn,maxDataLength:65535});if(!e.privateKey)throw new M("local peerId does not contain private key","ERR_NO_PRIVATE_KEY");let a=await Gi(e.privateKey),c=s?.publicKey,l=await this.performHandshakeInitiator(i,a,c,{signal:o}),f=await this.createSecureConnection(i,l);return n.source=f.source,n.sink=f.sink,{conn:n,remoteExtensions:l.payload.extensions,remotePeer:await Xi(l.payload.identityKey)}}async secureInbound(...t){let{localPeer:e,connection:n,remotePeer:s,signal:o}=this.parseArgs(t),i=ra(n,{lengthEncoder:Fr,lengthDecoder:Sn,maxDataLength:65535});if(!e.privateKey)throw new M("local peerId does not contain private key","ERR_NO_PRIVATE_KEY");let a=await Gi(e.privateKey),c=s?.publicKey,l=await this.performHandshakeResponder(i,a,c,{signal:o}),f=await this.createSecureConnection(i,l);return n.source=f.source,n.sink=f.sink,{conn:n,remoteExtensions:l.payload.extensions,remotePeer:await Xi(l.payload.identityKey)}}async performHandshakeInitiator(t,e,n,s){let o;try{o=await Xu({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},s),this.metrics?.xxHandshakeSuccesses.increment()}catch(i){throw this.metrics?.xxHandshakeErrors.increment(),i}return o}async performHandshakeResponder(t,e,n,s){let o;try{o=await Ju({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},s),this.metrics?.xxHandshakeSuccesses.increment()}catch(i){throw this.metrics?.xxHandshakeErrors.increment(),i}return o}async createSecureConnection(t,e){let[n,s]=Su(),o=t.unwrap();return await Iu(n,ef(e,this.metrics),o,i=>An(i,{lengthDecoder:Sn}),rf(e,this.metrics),n),s}parseArgs(t){return ic(t[0])?{localPeer:t[0],connection:t[1],remotePeer:t[2]}:{localPeer:this.components.peerId,connection:t[0],remotePeer:t[1]?.remotePeer,signal:t[1]?.signal}}};function nf(r={}){return t=>new oo(t,r)}var io=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 f=this.readAtomically(()=>{let u=this.readChar();if(u===void 0)return;let d=Number.parseInt(u,t);if(!Number.isNaN(d))return d});if(f===void 0)break;if(o*=t,o+=f,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 sf=45,U0=15,Gr=new io;function Sa(r){if(!(r.length>U0))return Gr.new(r).parseWith(()=>Gr.readIPv4Addr())}function ka(r){if(r.includes("%")&&(r=r.split("%")[0]),!(r.length>sf))return Gr.new(r).parseWith(()=>Gr.readIPv6Addr())}function ao(r){if(r.includes("%")&&(r=r.split("%")[0]),!(r.length>sf))return Gr.new(r).parseWith(()=>Gr.readIPAddr())}function co(r){return!!Sa(r)}function lo(r){return!!ka(r)}function uo(r){return!!ao(r)}var B2=parseInt("0xFFFF",16),A2=new Uint8Array([0,0,0,0,0,0,0,0,0,0,255,255]);var cf=co,O0=lo,Ia=function(r){let t=0;if(r=r.toString().trim(),cf(r)){let e=new Uint8Array(t+4);return r.split(/\./g).forEach(n=>{e[t++]=parseInt(n,10)&255}),e}if(O0(r)){let e=r.split(":",8),n;for(n=0;n<e.length;n++){let o=cf(e[n]),i;o&&(i=Ia(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")},lf=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 zr={},_a={},K0=[[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"]];K0.forEach(r=>{let t=F0(...r);_a[t.code]=t,zr[t.name]=t});function F0(r,t,e,n,s){return{code:r,size:t,name:e,resolvable:!!n,path:!!s}}function Q(r){if(typeof r=="number"){if(_a[r]!=null)return _a[r];throw new Error(`no protocol with code: ${r}`)}else if(typeof r=="string"){if(zr[r]!=null)return zr[r];throw new Error(`no protocol with name: ${r}`)}throw new Error(`invalid protocol id type: ${typeof r}`)}var oE=Q("ip4"),iE=Q("ip6"),aE=Q("ipcidr");function La(r,t){switch(Q(r).code){case 4:case 41:return q0(t);case 42:return Ta(t);case 6:case 273:case 33:case 132:return hf(t).toString();case 53:case 54:case 55:case 56:case 400:case 449:case 777:return Ta(t);case 421:return W0(t);case 444:return ff(t);case 445:return ff(t);case 466:return j0(t);case 481:return globalThis.encodeURIComponent(Ta(t));default:return $(t,"base16")}}function Ca(r,t){switch(Q(r).code){case 4:return uf(t);case 41:return uf(t);case 42:return Na(t);case 6:case 273:case 33:case 132:return Ua(parseInt(t,10));case 53:case 54:case 55:case 56:case 400:case 449:case 777:return Na(t);case 421:return G0(t);case 444:return Y0(t);case 445:return Z0(t);case 466:return z0(t);case 481:return Na(globalThis.decodeURIComponent(t));default:return Y(t,"base16")}}var Ra=Object.values(oe).map(r=>r.decoder),$0=function(){let r=Ra[0].or(Ra[1]);return Ra.slice(2).forEach(t=>r=r.or(t)),r}();function uf(r){if(!uo(r))throw new Error("invalid ip address");return Ia(r)}function q0(r){let t=lf(r,0,r.length);if(t==null)throw new Error("ipBuff is required");if(!uo(t))throw new Error("invalid ip address");return t}function Ua(r){let t=new ArrayBuffer(2);return new DataView(t).setUint16(0,r),new Uint8Array(t)}function hf(r){return new DataView(r.buffer).getUint16(r.byteOffset)}function Na(r){let t=Y(r),e=Uint8Array.from(ie(t.length));return Et([e,t],e.length+t.length)}function Ta(r){let t=Qt(r);if(r=r.slice(dt(t)),r.length!==t)throw new Error("inconsistent lengths");return $(r)}function G0(r){let t;r[0]==="Q"||r[0]==="1"?t=Ue(ut.decode(`z${r}`)).bytes:t=Ft.parse(r).multihash.bytes;let e=Uint8Array.from(ie(t.length));return Et([e,t],e.length+t.length)}function z0(r){let t=$0.decode(r),e=Uint8Array.from(ie(t.length));return Et([e,t],e.length+t.length)}function j0(r){let t=Qt(r),e=r.slice(dt(t));if(e.length!==t)throw new Error("inconsistent lengths");return"u"+$(e,"base64url")}function W0(r){let t=Qt(r),e=r.slice(dt(t));if(e.length!==t)throw new Error("inconsistent lengths");return $(e,"base58btc")}function Y0(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=me.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=Ua(n);return Et([e,s],e.length+s.length)}function Z0(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=me.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=Ua(n);return Et([e,s],e.length+s.length)}function ff(r){let t=r.slice(0,r.length-2),e=r.slice(r.length-2),n=$(t,"base32"),s=hf(e);return`${n}:${s}`}function df(r){r=Pa(r);let t=[],e=[],n=null,s=r.split("/").slice(1);if(s.length===1&&s[0]==="")return{bytes:new Uint8Array,string:"/",tuples:[],stringTuples:[],path:null};for(let o=0;o<s.length;o++){let i=s[o],a=Q(i);if(a.size===0){t.push([a.code]),e.push([a.code]);continue}if(o++,o>=s.length)throw gf("invalid address: "+r);if(a.path===!0){n=Pa(s.slice(o).join("/")),t.push([a.code,Ca(a.code,n)]),e.push([a.code,n]);break}let c=Ca(a.code,s[o]);t.push([a.code,c]),e.push([a.code,La(a.code,c)])}return{string:pf(e),bytes:Va(t),tuples:t,stringTuples:e,path:n}}function Da(r){let t=[],e=[],n=null,s=0;for(;s<r.length;){let o=Qt(r,s),i=dt(o),a=Q(o),c=X0(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 gf("Invalid address Uint8Array: "+$(r,"base16"));t.push([o,l]);let f=La(o,l);if(e.push([o,f]),a.path===!0){n=f;break}}return{bytes:Uint8Array.from(r),string:pf(e),tuples:t,stringTuples:e,path:n}}function pf(r){let t=[];return r.map(e=>{let n=Q(e[0]);return t.push(n.name),e.length>1&&e[1]!=null&&t.push(e[1]),null}),Pa(t.join("/"))}function Va(r){return Et(r.map(t=>{let e=Q(t[0]),n=Uint8Array.from(ie(e.code));return t.length>1&&t[1]!=null&&(n=Et([n,t[1]])),n}))}function X0(r,t){if(r.size>0)return r.size/8;if(r.size===0)return 0;{let e=Qt(t instanceof Uint8Array?t:Uint8Array.from(t));return e+dt(e)}}function Pa(r){return"/"+r.trim().split("/").filter(t=>t).join("/")}function gf(r){return new Error("Error parsing address: "+r)}var J0=Symbol.for("nodejs.util.inspect.custom"),Ha=Symbol.for("@multiformats/js-multiaddr/multiaddr"),Q0=[Q("dns").code,Q("dns4").code,Q("dns6").code,Q("dnsaddr").code],fo=class r{bytes;#e;#t;#r;#n;[Ha]=!0;constructor(t){t==null&&(t="");let e;if(t instanceof Uint8Array)e=Da(t);else if(typeof t=="string"){if(t.length>0&&t.charAt(0)!=="/")throw new Error(`multiaddr "${t}" must start with a "/"`);e=df(t)}else if(yf(t))e=Da(t.bytes);else throw new Error("addr must be a string, Buffer, or another Multiaddr");this.bytes=e.bytes,this.#e=e.string,this.#t=e.tuples,this.#r=e.stringTuples,this.#n=e.path}toString(){return this.#e}toJSON(){return this.toString()}toOptions(){let t,e,n,s,o="",i=Q("tcp"),a=Q("udp"),c=Q("ip4"),l=Q("ip6"),f=Q("dns6"),u=Q("ip6zone");for(let[p,y]of this.stringTuples())p===u.code&&(o=`%${y??""}`),Q0.includes(p)&&(e=i.name,s=443,n=`${y??""}${o}`,t=p===f.code?6:4),(p===i.code||p===a.code)&&(e=Q(p).name,s=parseInt(y??"")),(p===c.code||p===l.code)&&(e=Q(p).name,n=`${y??""}${o}`,t=p===l.code?6:4);if(t==null||e==null||n==null||s==null)throw new Error('multiaddr must have a valid format: "/{ip4, ip6, dns4, dns6, dnsaddr}/{address}/{tcp, udp}/{port}".');return{family:t,host:n,transport:e,port:s}}protos(){return this.#t.map(([t])=>Object.assign({},Q(t)))}protoCodes(){return this.#t.map(([t])=>t)}protoNames(){return this.#t.map(([t])=>Q(t).name)}tuples(){return this.#t}stringTuples(){return this.#r}encapsulate(t){return t=new r(t),new r(this.toString()+t.toString())}decapsulate(t){let e=t.toString(),n=this.toString(),s=n.lastIndexOf(e);if(s<0)throw new Error(`Address ${this.toString()} does not contain subaddress: ${t.toString()}`);return new r(n.slice(0,s))}decapsulateCode(t){let e=this.tuples();for(let n=e.length-1;n>=0;n--)if(e[n][0]===t)return new r(Va(e.slice(0,n)));return this}getPeerId(){try{let t=[];this.stringTuples().forEach(([n,s])=>{n===zr.p2p.code&&t.push([n,s]),n===zr["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"):$(Ft.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=mf.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=>Oa(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)}[J0](){return`Multiaddr(${this.#e})`}};var mf=new Map;function yf(r){return!!r?.[Ha]}function Oa(r){return new fo(r)}var tg=r=>r.toString().split("/").slice(1),Rn=r=>({match:t=>t.length<1?!1:r(t[0])?t.slice(1):!1,pattern:"fn"}),X=r=>({match:t=>Rn(e=>e===r).match(t),pattern:r}),go=()=>({match:r=>Rn(t=>typeof t=="string").match(r),pattern:"{string}"}),mo=()=>({match:r=>Rn(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}"}),ho=()=>({match:r=>{if(r.length<2||r[0]!=="certhash")return!1;try{Mo.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})`}),zt=(...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(", ")})`}),tt=(...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=tg(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 Ka=tt(X("dns4"),go()),Fa=tt(X("dns6"),go()),$a=tt(X("dnsaddr"),go()),wf=tt(X("dns"),go()),DE=ht(Ka),VE=ht(Fa),HE=ht($a),OE=ht(zt(wf,$a,Ka,Fa)),bf=tt(X("ip4"),Rn(co)),xf=tt(X("ip6"),Rn(lo)),Ef=zt(bf,xf),he=zt(Ef,wf,Ka,Fa,$a),ME=ht(he),KE=ht(bf),FE=ht(xf),$E=ht(Ef),qa=tt(he,X("tcp"),mo()),Nn=tt(he,X("udp"),mo()),qE=ht(qa),GE=ht(Nn),Ga=tt(Nn,X("quic")),yo=tt(Nn,X("quic-v1")),eg=zt(Ga,yo),zE=ht(Ga),jE=ht(yo),Ma=zt(he,qa,Nn,Ga,yo),vf=zt(tt(Ma,X("ws"),xt(_t()))),WE=ht(vf),Bf=zt(tt(Ma,X("wss"),xt(_t())),tt(Ma,X("tls"),X("ws"),xt(_t()))),YE=ht(Bf),Af=tt(Nn,X("webrtc-direct"),xt(ho()),xt(ho()),xt(_t())),ZE=ht(Af),Sf=tt(yo,X("webtransport"),xt(ho()),xt(ho()),xt(_t())),wo=ht(Sf),po=zt(vf,Bf,tt(qa,xt(_t())),tt(eg,xt(_t())),tt(he,xt(_t())),Af,Sf,_t()),XE=ht(po),rg=tt(po,X("p2p-circuit"),_t()),JE=ht(rg),ng=zt(tt(po,X("p2p-circuit"),X("webrtc"),xt(_t())),tt(po,X("webrtc"),xt(_t())),X("webrtc")),QE=ht(ng),sg=zt(tt(he,X("tcp"),mo(),X("http"),xt(_t())),tt(he,X("http"),xt(_t()))),tv=ht(sg),og=zt(tt(he,X("tcp"),zt(tt(X("443"),X("http")),tt(mo(),X("https"))),xt(_t())),tt(he,X("tls"),X("http"),xt(_t())),tt(he,X("https"),xt(_t()))),ev=ht(og);var pr=class extends Event{type;detail;constructor(t,e){super(t),this.type=t,this.detail=e}};function za(r){throw new Error("Not implemented")}function kf(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 If(r){return r==null?!1:typeof r.then=="function"&&typeof r.catch=="function"&&typeof r.finally=="function"}function _f(r,t){let e=kf(r).return?.();If(e)&&e.catch(n=>{t.error("could not cause iterator to return",n)})}var ig="ERR_STREAM_RESET",ag="ERR_SINK_INVALID_STATE",cg=5e3;function ja(r){return r==null?!1:typeof r.then=="function"&&typeof r.catch=="function"&&typeof r.finally=="function"}var bo=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=Lt(),this.closed=Lt(),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??cg,this.onEnd=t.onEnd,this.onCloseRead=t?.onCloseRead,this.onCloseWrite=t?.onCloseWrite,this.onReset=t?.onReset,this.onAbort=t?.onAbort,this.source=this.streamSource=Mr({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"`,ag);try{this.writeStatus="writing";let e={signal:this.sinkController.signal};if(this.direction==="outbound"){let s=this.sendNewStream(e);ja(s)&&await s}let n=()=>{_f(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);ja(o)&&(this.sendingData=Lt(),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();ja(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",ig);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 Wa=class extends bo{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 Ya(r,t,e,n,s,o){let i=o.forComponent(`libp2p:webtransport:stream:${e}:${t}`),a=new Wa({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 xo(){return{source:{[Symbol.asyncIterator](){return{async next(){return new Promise(()=>{})}}}},sink:async r=>new Promise(()=>{})}}function Rf(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:f}=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`),f.writable.close().catch(u=>{o.error(`failed to close inbound stream that crossed our maxInboundStream limit: ${u.message}`)}),f.readable.cancel().catch(u=>{o.error(`failed to close inbound stream that crossed our maxInboundStream limit: ${u.message}`)});else{let u=await Ya(f,String(s++),"inbound",a,i?.onStreamEnd,e);a.push(u),i?.onIncomingStream?.(u)}}}).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 f=await r.createBidirectionalStream(),u=await Ya(f,String(s++),i?.direction??"outbound",a,i?.onStreamEnd,e);return a.push(u),u},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(f){o.error("webtransport session threw error during close",f)}},...xo()};return c}}}function Nf(r,t){return t.filter(n=>!!r.find(s=>ft(n,s))).length===t.length}var lg=Object.values(oe).map(r=>r.decoder).reduce((r,t)=>r.or(t));function ug(r){return se.decode(lg.decode(r))}function Za(r){if(!wo.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===Q("certhash").code).map(([i,a])=>ug(a??"")),n=t.filter(([i,a])=>i===Q("p2p").code).map(([i,a])=>Zi(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 Tf=globalThis.WebTransport;var Xa=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";[cc]=!0;[Un]=["@libp2p/transport"];async dial(t,e){if(e?.signal?.aborted===!0)throw new Cn;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}=Za(t),a,c,l=()=>{},f=!1,u=!1,d=!1;try{this.metrics?.dialerEvents.increment({pending:!0});let p=new Tf(`${s}/.well-known/libp2p-webtransport?type=noise`,{serverCertificateHashes:o.map(y=>({algorithm:"sha-256",value:y.digest}))});if(l=y=>{if(!f)try{this.metrics?.dialerEvents.increment({[y]:!0}),p.close()}catch(m){this.log.error("error closing wt session",m)}finally{c!=null&&(c.timeline.close=Date.now()),f=!0}},a=()=>{l(u?"noise_timeout":"ready_timeout")},e.signal?.addEventListener("abort",a,{once:!0}),this.log("wait for session to be ready"),e.onProgress?.(new pr("webtransport:wait-for-session")),await Promise.race([p.closed,p.ready]),this.log("session became ready"),u=!0,this.metrics?.dialerEvents.increment({ready:!0}),p.closed.catch(y=>{this.log.error("error on remote wt session close",y)}).finally(()=>{l("remote_close")}),d=await Dt(this.authenticateWebTransport({wt:p,localPeer:n,remotePeer:i,certhashes:o,...e}),e.signal),!d)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:y=>{this.log("aborting webtransport due to passed err",y),l("abort")},remoteAddr:t,timeline:{open:Date.now()},log:this.components.logger.forComponent("libp2p:webtransport:maconn"),...xo()},await e.upgrader.upgradeOutbound(c,{skipEncryption:!0,muxerFactory:Rf(p,p.incomingBidirectionalStreams.getReader(),this.components.logger,this.config),skipProtection:!0,onProgress:e.onProgress})}catch(p){throw this.log.error("caught wt session err",p),l(d?"upgrade_error":u?"noise_error":"ready_error"),p}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 pr("webtransport:open-authentication-stream"));let a=await t.createBidirectionalStream(),c=a.writable.getWriter(),l=a.readable.getReader(),f={source:async function*(){for(;;){let p=await l.read();if(p.value!=null&&(yield p.value),p.done)break}}(),sink:async p=>{for await(let y of p){await Dt(c.ready,i);let m=y instanceof Uint8Array?y:y.subarray();c.write(m).catch(h=>{this.log.error("could not write chunk during authentication of WebTransport stream",h)})}}},u=nf()(this.components);o?.(new pr("webtransport:secure-outbound-connection"));let{remoteExtensions:d}=await u.secureOutbound(e,f,n);if(o?.(new pr("webtransport:close-authentication-stream")),c.close().catch(p=>{this.log.error(`Failed to close authentication stream writer: ${p.message}`)}),l.cancel().catch(p=>{this.log.error(`Failed to close authentication stream reader: ${p.message}`)}),!Nf(d?.webtransportCerthashes??[],s.map(p=>p.bytes)))throw new Error("Our certhashes are not a subset of the remote's reported certhashes");return!0}createListener(t){return za(this.components,{...t,certificates:this.config.certificates,maxInboundStreams:this.config.maxInboundStreams})}listenFilter(){return[]}dialFilter(t){return globalThis.WebTransport==null?[]:t.filter(e=>{if(!wo.exactMatch(e))return!1;let{url:n,certhashes:s}=Za(e);return n!=null&&s.length>0})}};function fg(r={}){return t=>new Xa(t,r)}return jf(hg);})();
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.8-1675adee2",
3
+ "version": "4.1.8-737b3ea5b",
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.7.0-1675adee2",
55
- "@libp2p/peer-id": "4.2.4-1675adee2",
56
- "@libp2p/utils": "5.4.9-1675adee2",
54
+ "@libp2p/interface": "1.7.0-737b3ea5b",
55
+ "@libp2p/peer-id": "4.2.4-737b3ea5b",
56
+ "@libp2p/utils": "5.4.9-737b3ea5b",
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.20-1675adee2",
69
- "@libp2p/peer-id-factory": "4.2.4-1675adee2",
70
- "@libp2p/ping": "1.1.6-1675adee2",
68
+ "@libp2p/logger": "4.0.20-737b3ea5b",
69
+ "@libp2p/peer-id-factory": "4.2.4-737b3ea5b",
70
+ "@libp2p/ping": "1.1.6-737b3ea5b",
71
71
  "@noble/hashes": "^1.4.0",
72
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.9.3-1675adee2",
77
+ "libp2p": "1.9.3-737b3ea5b",
78
78
  "p-defer": "^4.0.1",
79
79
  "p-wait-for": "^5.0.2"
80
80
  },