@libp2p/webtransport 5.0.44 → 5.0.45-7eed3b40d

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,12 +1,12 @@
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 yo=Object.defineProperty;var Yu=Object.getOwnPropertyDescriptor;var Xu=Object.getOwnPropertyNames;var Ju=Object.prototype.hasOwnProperty;var Tt=(r,t)=>{for(var e in t)yo(r,e,{get:t[e],enumerable:!0})},Qu=(r,t,e,n)=>{if(t&&typeof t=="object"||typeof t=="function")for(let o of Xu(t))!Ju.call(r,o)&&o!==e&&yo(r,o,{get:()=>t[o],enumerable:!(n=Yu(t,o))||n.enumerable});return r};var tf=r=>Qu(yo({},"__esModule",{value:!0}),r);var Vd={};Tt(Vd,{webTransport:()=>Hd});var go=Symbol.for("@libp2p/peer-id");var ji=Symbol.for("@libp2p/transport");var Wi;(function(r){r[r.FATAL_ALL=0]="FATAL_ALL",r[r.NO_FATAL=1]="NO_FATAL"})(Wi||(Wi={}));var rn=class extends Error{static name="UnexpectedPeerError";constructor(t="Unexpected Peer"){super(t),this.name="UnexpectedPeerError"}},ze=class extends Error{static name="InvalidCryptoExchangeError";constructor(t="Invalid crypto exchange"){super(t),this.name="InvalidCryptoExchangeError"}},at=class extends Error{static name="InvalidParametersError";constructor(t="Invalid parameters"){super(t),this.name="InvalidParametersError"}},Fe=class extends Error{static name="InvalidPublicKeyError";constructor(t="Invalid public key"){super(t),this.name="InvalidPublicKeyError"}};var nn=class extends Error{static name="StreamResetError";constructor(t="The stream has been reset"){super(t),this.name="StreamResetError"}},on=class extends Error{static name="StreamStateError";constructor(t="The stream is in an invalid state"){super(t),this.name="StreamStateError"}};var sn=class extends Error{static name="InvalidMultiaddrError";constructor(t="Invalid multiaddr"){super(t),this.name="InvalidMultiaddrError"}},an=class extends Error{static name="InvalidCIDError";constructor(t="Invalid CID"){super(t),this.name="InvalidCIDError"}},cn=class extends Error{static name="InvalidMultihashError";constructor(t="Invalid Multihash"){super(t),this.name="InvalidMultihashError"}};var ve=class extends Error{static name="UnsupportedKeyTypeError";constructor(t="Unsupported key type"){super(t),this.name="UnsupportedKeyTypeError"}};var un=Symbol.for("@libp2p/service-capabilities"),Wd=Symbol.for("@libp2p/service-dependencies");var So={};Tt(So,{base58btc:()=>nt,base58flickr:()=>cf});var pp=new Uint8Array(0);function $i(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 Qt(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 Zi(r){return new TextEncoder().encode(r)}function Yi(r){return new TextDecoder().decode(r)}function ef(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 o=0;o<r.length;o++){var s=r.charAt(o),i=s.charCodeAt(0);if(e[i]!==255)throw new TypeError(s+" is ambiguous");e[i]=o}var a=r.length,c=r.charAt(0),f=Math.log(a)/Math.log(256),u=Math.log(256)/Math.log(a);function l(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,w=0,_=0,M=y.length;_!==M&&y[_]===0;)_++,m++;for(var S=(M-_)*u+1>>>0,d=new Uint8Array(S);_!==M;){for(var I=y[_],U=0,B=S-1;(I!==0||U<w)&&B!==-1;B--,U++)I+=256*d[B]>>>0,d[B]=I%a>>>0,I=I/a>>>0;if(I!==0)throw new Error("Non-zero carry");w=U,_++}for(var L=S-w;L!==S&&d[L]===0;)L++;for(var k=c.repeat(m);L<S;++L)k+=r.charAt(d[L]);return k}function p(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 w=0,_=0;y[m]===c;)w++,m++;for(var M=(y.length-m)*f+1>>>0,S=new Uint8Array(M);y[m];){var d=e[y.charCodeAt(m)];if(d===255)return;for(var I=0,U=M-1;(d!==0||I<_)&&U!==-1;U--,I++)d+=a*S[U]>>>0,S[U]=d%256>>>0,d=d/256>>>0;if(d!==0)throw new Error("Non-zero carry");_=I,m++}if(y[m]!==" "){for(var B=M-_;B!==M&&S[B]===0;)B++;for(var L=new Uint8Array(w+(M-B)),k=w;B!==M;)L[k++]=S[B++];return L}}}function x(y){var m=p(y);if(m)return m;throw new Error(`Non-${t} character`)}return{encode:l,decodeUnsafe:p,decode:x}}var rf=ef,nf=rf,Ji=nf;var wo=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")}},xo=class{name;prefix;baseDecode;prefixCodePoint;constructor(t,e,n){this.name=t,this.prefix=e;let o=e.codePointAt(0);if(o===void 0)throw new Error("Invalid prefix character");this.prefixCodePoint=o,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 Qi(this,t)}},bo=class{decoders;constructor(t){this.decoders=t}or(t){return Qi(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 Qi(r,t){return new bo({...r.decoders??{[r.prefix]:r},...t.decoders??{[t.prefix]:t}})}var Eo=class{name;prefix;baseEncode;baseDecode;encoder;decoder;constructor(t,e,n,o){this.name=t,this.prefix=e,this.baseEncode=n,this.baseDecode=o,this.encoder=new wo(t,e,n),this.decoder=new xo(t,e,o)}encode(t){return this.encoder.encode(t)}decode(t){return this.decoder.decode(t)}};function Ge({name:r,prefix:t,encode:e,decode:n}){return new Eo(r,t,e,n)}function le({name:r,prefix:t,alphabet:e}){let{encode:n,decode:o}=Ji(e,r);return Ge({prefix:t,name:r,encode:n,decode:s=>Qt(o(s))})}function of(r,t,e,n){let o=r.length;for(;r[o-1]==="=";)--o;let s=new Uint8Array(o*e/8|0),i=0,a=0,c=0;for(let f=0;f<o;++f){let u=t[r[f]];if(u===void 0)throw new SyntaxError(`Non-${n} character`);a=a<<e|u,i+=e,i>=8&&(i-=8,s[c++]=255&a>>i)}if(i>=e||(255&a<<8-i)!==0)throw new SyntaxError("Unexpected end of data");return s}function sf(r,t,e){let n=t[t.length-1]==="=",o=(1<<e)-1,s="",i=0,a=0;for(let c=0;c<r.length;++c)for(a=a<<8|r[c],i+=8;i>e;)i-=e,s+=t[o&a>>i];if(i!==0&&(s+=t[o&a<<e-i]),n)for(;(s.length*e&7)!==0;)s+="=";return s}function af(r){let t={};for(let e=0;e<r.length;++e)t[r[e]]=e;return t}function ct({name:r,prefix:t,bitsPerChar:e,alphabet:n}){let o=af(n);return Ge({prefix:t,name:r,encode(s){return sf(s,n,e)},decode(s){return of(s,o,e,r)}})}var nt=le({name:"base58btc",prefix:"z",alphabet:"123456789ABCDEFGHJKLMNPQRSTUVWXYZabcdefghijkmnopqrstuvwxyz"}),cf=le({name:"base58flickr",prefix:"Z",alphabet:"123456789abcdefghijkmnopqrstuvwxyzABCDEFGHJKLMNPQRSTUVWXYZ"});var Ao={};Tt(Ao,{base32:()=>te,base32hex:()=>hf,base32hexpad:()=>pf,base32hexpadupper:()=>mf,base32hexupper:()=>df,base32pad:()=>ff,base32padupper:()=>lf,base32upper:()=>uf,base32z:()=>yf});var te=ct({prefix:"b",name:"base32",alphabet:"abcdefghijklmnopqrstuvwxyz234567",bitsPerChar:5}),uf=ct({prefix:"B",name:"base32upper",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZ234567",bitsPerChar:5}),ff=ct({prefix:"c",name:"base32pad",alphabet:"abcdefghijklmnopqrstuvwxyz234567=",bitsPerChar:5}),lf=ct({prefix:"C",name:"base32padupper",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZ234567=",bitsPerChar:5}),hf=ct({prefix:"v",name:"base32hex",alphabet:"0123456789abcdefghijklmnopqrstuv",bitsPerChar:5}),df=ct({prefix:"V",name:"base32hexupper",alphabet:"0123456789ABCDEFGHIJKLMNOPQRSTUV",bitsPerChar:5}),pf=ct({prefix:"t",name:"base32hexpad",alphabet:"0123456789abcdefghijklmnopqrstuv=",bitsPerChar:5}),mf=ct({prefix:"T",name:"base32hexpadupper",alphabet:"0123456789ABCDEFGHIJKLMNOPQRSTUV=",bitsPerChar:5}),yf=ct({prefix:"h",name:"base32z",alphabet:"ybndrfg8ejkmcpqxot1uwisza345h769",bitsPerChar:5});var vo={};Tt(vo,{base36:()=>gr,base36upper:()=>gf});var gr=le({prefix:"k",name:"base36",alphabet:"0123456789abcdefghijklmnopqrstuvwxyz"}),gf=le({prefix:"K",name:"base36upper",alphabet:"0123456789ABCDEFGHIJKLMNOPQRSTUVWXYZ"});var Wt={};Tt(Wt,{Digest:()=>Ie,create:()=>Nt,decode:()=>he,equals:()=>Bo,hasCode:()=>Kf});var wf=ra,ta=128,xf=127,bf=~xf,Ef=Math.pow(2,31);function ra(r,t,e){t=t||[],e=e||0;for(var n=e;r>=Ef;)t[e++]=r&255|ta,r/=128;for(;r&bf;)t[e++]=r&255|ta,r>>>=7;return t[e]=r|0,ra.bytes=e-n+1,t}var Sf=Io,Af=128,ea=127;function Io(r,n){var e=0,n=n||0,o=0,s=n,i,a=r.length;do{if(s>=a)throw Io.bytes=0,new RangeError("Could not decode varint");i=r[s++],e+=o<28?(i&ea)<<o:(i&ea)*Math.pow(2,o),o+=7}while(i>=Af);return Io.bytes=s-n,e}var vf=Math.pow(2,7),If=Math.pow(2,14),Bf=Math.pow(2,21),_f=Math.pow(2,28),Lf=Math.pow(2,35),Tf=Math.pow(2,42),Cf=Math.pow(2,49),Pf=Math.pow(2,56),Uf=Math.pow(2,63),kf=function(r){return r<vf?1:r<If?2:r<Bf?3:r<_f?4:r<Lf?5:r<Tf?6:r<Cf?7:r<Pf?8:r<Uf?9:10},Rf={encode:wf,decode:Sf,encodingLength:kf},Df=Rf,wr=Df;function xr(r,t=0){return[wr.decode(r,t),wr.decode.bytes]}function We(r,t,e=0){return wr.encode(r,t,e),t}function je(r){return wr.encodingLength(r)}function Nt(r,t){let e=t.byteLength,n=je(r),o=n+je(e),s=new Uint8Array(o+e);return We(r,s,0),We(e,s,n),s.set(t,o),new Ie(r,e,t,s)}function he(r){let t=Qt(r),[e,n]=xr(t),[o,s]=xr(t.subarray(n)),i=t.subarray(n+s);if(i.byteLength!==o)throw new Error("Incorrect length");return new Ie(e,o,i,t)}function Bo(r,t){if(r===t)return!0;{let e=t;return r.code===e.code&&r.size===e.size&&e.bytes instanceof Uint8Array&&$i(r.bytes,e.bytes)}}var Ie=class{code;size;digest;bytes;constructor(t,e,n,o){this.code=t,this.size=e,this.digest=n,this.bytes=o}};function Kf(r,t){return r.code===t}function na(r,t){let{bytes:e,version:n}=r;switch(n){case 0:return Mf(e,_o(r),t??nt.encoder);default:return Of(e,_o(r),t??te.encoder)}}var oa=new WeakMap;function _o(r){let t=oa.get(r);if(t==null){let e=new Map;return oa.set(r,e),e}return t}var ut=class r{code;version;multihash;bytes;"/";constructor(t,e,n,o){this.code=e,this.version=t,this.multihash=n,this.bytes=o,this["/"]=o}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!==br)throw new Error("Cannot convert a non dag-pb CID to CIDv0");if(e.code!==Hf)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=Nt(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&&Bo(t.multihash,n.multihash)}toString(t){return na(this,t)}toJSON(){return{"/":na(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:o,multihash:s,bytes:i}=e;return new r(n,o,s,i??sa(n,o,s.bytes))}else if(e[Vf]===!0){let{version:n,multihash:o,code:s}=e,i=he(o);return r.create(n,s,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!==br)throw new Error(`Version 0 CID must use dag-pb (code: ${br}) block encoding`);return new r(t,e,n,n.bytes)}case 1:{let o=sa(t,e,n.bytes);return new r(t,e,n,o)}default:throw new Error("Invalid version")}}static createV0(t){return r.create(0,br,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,o=Qt(t.subarray(n,n+e.multihashSize));if(o.byteLength!==e.multihashSize)throw new Error("Incorrect length");let s=o.subarray(e.multihashSize-e.digestSize),i=new Ie(e.multihashCode,e.digestSize,s,o);return[e.version===0?r.createV0(i):r.createV1(e.codec,i),t.subarray(e.size)]}static inspectBytes(t){let e=0,n=()=>{let[l,p]=xr(t.subarray(e));return e+=p,l},o=n(),s=br;if(o===18?(o=0,e=0):s=n(),o!==0&&o!==1)throw new RangeError(`Invalid CID version ${o}`);let i=e,a=n(),c=n(),f=e+c,u=f-i;return{version:o,codec:s,multihashCode:a,digestSize:c,multihashSize:u,size:f}}static parse(t,e){let[n,o]=Nf(t,e),s=r.decode(o);if(s.version===0&&t[0]!=="Q")throw Error("Version 0 CID string must not include multibase prefix");return _o(s).set(n,t),s}};function Nf(r,t){switch(r[0]){case"Q":{let e=t??nt;return[nt.prefix,e.decode(`${nt.prefix}${r}`)]}case nt.prefix:{let e=t??nt;return[nt.prefix,e.decode(r)]}case te.prefix:{let e=t??te;return[te.prefix,e.decode(r)]}case gr.prefix:{let e=t??gr;return[gr.prefix,e.decode(r)]}default:{if(t==null)throw Error("To parse non base32, base36 or base58btc encoded CID multibase decoder must be provided");return[r[0],t.decode(r)]}}}function Mf(r,t,e){let{prefix:n}=e;if(n!==nt.prefix)throw Error(`Cannot string encode V0 in ${e.name} encoding`);let o=t.get(n);if(o==null){let s=e.encode(r).slice(1);return t.set(n,s),s}else return o}function Of(r,t,e){let{prefix:n}=e,o=t.get(n);if(o==null){let s=e.encode(r);return t.set(n,s),s}else return o}var br=112,Hf=18;function sa(r,t,e){let n=je(r),o=n+je(t),s=new Uint8Array(o+e.byteLength);return We(r,s,0),We(t,s,n),s.set(e,o),s}var Vf=Symbol.for("@ipld/js-cid/CID");var Lo={};Tt(Lo,{identity:()=>Ht});var ia=0,qf="identity",aa=Qt;function zf(r){return Nt(ia,aa(r))}var Ht={code:ia,name:qf,encode:aa,digest:zf};function ht(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 dt(r=0){return new Uint8Array(r)}function pt(r=0){return new Uint8Array(r)}function At(r,t){t==null&&(t=r.reduce((o,s)=>o+s.length,0));let e=pt(t),n=0;for(let o of r)e.set(o,n),n+=o.length;return e}var ua=Symbol.for("@achingbrain/uint8arraylist");function ca(r,t){if(t==null||t<0)throw new RangeError("index is out of bounds");let e=0;for(let n of r){let o=e+n.byteLength;if(t<o)return{buf:n,index:t-e};e=o}throw new RangeError("index is out of bounds")}function ln(r){return!!r?.[ua]}var $=class r{bufs;length;[ua]=!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(ln(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(ln(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=ca(this.bufs,t);return e.buf[e.index]}set(t,e){let n=ca(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(ln(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:o}=this._subList(t,e);return At(n,o)}subarray(t,e){let{bufs:n,length:o}=this._subList(t,e);return n.length===1?n[0]:At(n,o)}sublist(t,e){let{bufs:n,length:o}=this._subList(t,e),s=new r;return s.length=o,s.bufs=[...n],s}_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=[],o=0;for(let s=0;s<this.bufs.length;s++){let i=this.bufs[s],a=o,c=a+i.byteLength;if(o=c,t>=c)continue;let f=t>=a&&t<c,u=e>a&&e<=c;if(f&&u){if(t===a&&e===c){n.push(i);break}let l=t-a;n.push(i.subarray(l,l+(e-t)));break}if(f){if(t===0){n.push(i);continue}n.push(i.subarray(t-a));continue}if(u){if(e===c){n.push(i);break}n.push(i.subarray(0,e-a));break}n.push(i)}return{bufs:n,length:e-t}}indexOf(t,e=0){if(!ln(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 o=n.byteLength;if(o===0)throw new TypeError("search must be at least 1 byte long");let s=256,i=new Int32Array(s);for(let l=0;l<s;l++)i[l]=-1;for(let l=0;l<o;l++)i[n[l]]=l;let a=i,c=this.byteLength-n.byteLength,f=n.byteLength-1,u;for(let l=e;l<=c;l+=u){u=0;for(let p=f;p>=0;p--){let x=this.get(l+p);if(n[p]!==x){u=Math.max(1,p-a[x]);break}}if(u===0)return l}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=pt(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 o=dt(2);new DataView(o.buffer,o.byteOffset,o.byteLength).setInt16(0,e,n),this.write(o,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 o=dt(4);new DataView(o.buffer,o.byteOffset,o.byteLength).setInt32(0,e,n),this.write(o,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 o=dt(8);new DataView(o.buffer,o.byteOffset,o.byteLength).setBigInt64(0,e,n),this.write(o,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=pt(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 o=dt(2);new DataView(o.buffer,o.byteOffset,o.byteLength).setUint16(0,e,n),this.write(o,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 o=dt(4);new DataView(o.buffer,o.byteOffset,o.byteLength).setUint32(0,e,n),this.write(o,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 o=dt(8);new DataView(o.buffer,o.byteOffset,o.byteLength).setBigUint64(0,e,n),this.write(o,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 o=dt(4);new DataView(o.buffer,o.byteOffset,o.byteLength).setFloat32(0,e,n),this.write(o,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 o=dt(8);new DataView(o.buffer,o.byteOffset,o.byteLength).setFloat64(0,e,n),this.write(o,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(!ht(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((o,s)=>o+s.byteLength,0)),n.length=e,n}};var To={};Tt(To,{base10:()=>Gf});var Gf=le({prefix:"9",name:"base10",alphabet:"0123456789"});var Co={};Tt(Co,{base16:()=>Wf,base16upper:()=>jf});var Wf=ct({prefix:"f",name:"base16",alphabet:"0123456789abcdef",bitsPerChar:4}),jf=ct({prefix:"F",name:"base16upper",alphabet:"0123456789ABCDEF",bitsPerChar:4});var Po={};Tt(Po,{base2:()=>$f});var $f=ct({prefix:"0",name:"base2",alphabet:"01",bitsPerChar:1});var Uo={};Tt(Uo,{base256emoji:()=>Qf});var fa=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}"),Zf=fa.reduce((r,t,e)=>(r[e]=t,r),[]),Yf=fa.reduce((r,t,e)=>{let n=t.codePointAt(0);if(n==null)throw new Error(`Invalid character: ${t}`);return r[n]=e,r},[]);function Xf(r){return r.reduce((t,e)=>(t+=Zf[e],t),"")}function Jf(r){let t=[];for(let e of r){let n=e.codePointAt(0);if(n==null)throw new Error(`Invalid character: ${e}`);let o=Yf[n];if(o==null)throw new Error(`Non-base256emoji character: ${e}`);t.push(o)}return new Uint8Array(t)}var Qf=Ge({prefix:"\u{1F680}",name:"base256emoji",encode:Xf,decode:Jf});var Ro={};Tt(Ro,{base64:()=>tl,base64pad:()=>el,base64url:()=>ko,base64urlpad:()=>rl});var tl=ct({prefix:"m",name:"base64",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/",bitsPerChar:6}),el=ct({prefix:"M",name:"base64pad",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/=",bitsPerChar:6}),ko=ct({prefix:"u",name:"base64url",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789-_",bitsPerChar:6}),rl=ct({prefix:"U",name:"base64urlpad",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789-_=",bitsPerChar:6});var Do={};Tt(Do,{base8:()=>nl});var nl=ct({prefix:"7",name:"base8",alphabet:"01234567",bitsPerChar:3});var Ko={};Tt(Ko,{identity:()=>ol});var ol=Ge({prefix:"\0",name:"identity",encode:r=>Yi(r),decode:r=>Zi(r)});var Yp=new TextEncoder,Xp=new TextDecoder;var Oo={};Tt(Oo,{sha256:()=>Er,sha512:()=>al});function Mo({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?Nt(this.code,e):e.then(n=>Nt(this.code,n))}else throw Error("Unknown type, must be binary type")}};function ha(r){return async t=>new Uint8Array(await crypto.subtle.digest(r,t))}var Er=Mo({name:"sha2-256",code:18,encode:ha("SHA-256")}),al=Mo({name:"sha2-512",code:19,encode:ha("SHA-512")});var Be={...Ko,...Po,...Do,...To,...Co,...Ao,...vo,...So,...Ro,...Uo},u0={...Oo,...Lo};function pa(r,t,e,n){return{name:r,prefix:t,encoder:{name:r,prefix:t,encode:e},decoder:{decode:n}}}var da=pa("utf8","u",r=>"u"+new TextDecoder("utf8").decode(r),r=>new TextEncoder().encode(r.substring(1))),Ho=pa("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=pt(r.length);for(let e=0;e<r.length;e++)t[e]=r.charCodeAt(e);return t}),cl={utf8:da,"utf-8":da,hex:Be.base16,latin1:Ho,ascii:Ho,binary:Ho,...Be},hn=cl;function Q(r,t="utf8"){let e=hn[t];if(e==null)throw new Error(`Unsupported encoding "${t}"`);return e.decoder.decode(`${e.prefix}${r}`)}function V(r,t="utf8"){let e=hn[t];if(e==null)throw new Error(`Unsupported encoding "${t}"`);return e.encoder.encode(r).substring(1)}var ul=parseInt("11111",2),Vo=parseInt("10000000",2),fl=parseInt("01111111",2),ma={0:Sr,1:Sr,2:ll,3:pl,4:ml,5:dl,6:hl,16:Sr,22:Sr,48:Sr};function ee(r,t={offset:0}){let e=r[t.offset]&ul;if(t.offset++,ma[e]!=null)return ma[e](r,t);throw new Error("No decoder for tag "+e)}function Ar(r,t){let e=0;if((r[t.offset]&Vo)===Vo){let n=r[t.offset]&fl,o="0x";t.offset++;for(let s=0;s<n;s++,t.offset++)o+=r[t.offset].toString(16).padStart(2,"0");e=parseInt(o,16)}else e=r[t.offset],t.offset++;return e}function Sr(r,t){Ar(r,t);let e=[];for(;!(t.offset>=r.byteLength);){let n=ee(r,t);if(n===null)break;e.push(n)}return e}function ll(r,t){let e=Ar(r,t),n=t.offset,o=t.offset+e,s=[];for(let i=n;i<o;i++)i===n&&r[i]===0||s.push(r[i]);return t.offset+=e,Uint8Array.from(s)}function hl(r,t){let e=Ar(r,t),n=t.offset+e,o=r[t.offset];t.offset++;let s=0,i=0;o<40?(s=0,i=o):o<80?(s=1,i=o-40):(s=2,i=o-80);let a=`${s}.${i}`,c=[];for(;t.offset<n;){let f=r[t.offset];if(t.offset++,c.push(f&127),f<128){c.reverse();let u=0;for(let l=0;l<c.length;l++)u+=c[l]<<l*7;a+=`.${u}`,c=[]}}return a}function dl(r,t){return t.offset++,null}function pl(r,t){let e=Ar(r,t),n=r[t.offset];t.offset++;let o=r.subarray(t.offset,t.offset+e-1);if(t.offset+=e,n!==0)throw new Error("Unused bits in bit string is unimplemented");return o}function ml(r,t){let e=Ar(r,t),n=r.subarray(t.offset,t.offset+e);return t.offset+=e,n}function yl(r){let t=r.toString(16);t.length%2===1&&(t="0"+t);let e=new $;for(let n=0;n<t.length;n+=2)e.append(Uint8Array.from([parseInt(`${t[n]}${t[n+1]}`,16)]));return e}function qo(r){if(r.byteLength<128)return Uint8Array.from([r.byteLength]);let t=yl(r.byteLength);return new $(Uint8Array.from([t.byteLength|Vo]),t)}function Rt(r){let t=new $,e=128;return(r.subarray()[0]&e)===e&&t.append(Uint8Array.from([0])),t.append(r),new $(Uint8Array.from([2]),qo(t),t)}function dn(r){let t=Uint8Array.from([0]),e=new $(t,r);return new $(Uint8Array.from([3]),qo(e),e)}function de(r,t=48){let e=new $;for(let n of r)e.append(n);return new $(Uint8Array.from([t]),qo(e),e)}async function ya(r,t,e,n){let o=await crypto.subtle.importKey("jwk",r,{name:"ECDSA",namedCurve:r.crv??"P-256"},!1,["verify"]);n?.signal?.throwIfAborted();let s=await crypto.subtle.verify({name:"ECDSA",hash:{name:"SHA-256"}},o,t,e.subarray());return n?.signal?.throwIfAborted(),s}var gl=Uint8Array.from([6,8,42,134,72,206,61,3,1,7]),wl=Uint8Array.from([6,5,43,129,4,0,34]),xl=Uint8Array.from([6,5,43,129,4,0,35]),bl={ext:!0,kty:"EC",crv:"P-256"},El={ext:!0,kty:"EC",crv:"P-384"},Sl={ext:!0,kty:"EC",crv:"P-521"},zo=32,Fo=48,Go=66;function Wo(r){let t=ee(r);return ga(t)}function ga(r){let t=r[1][1][0],e=1,n,o;if(t.byteLength===zo*2+1)return n=V(t.subarray(e,e+zo),"base64url"),o=V(t.subarray(e+zo),"base64url"),new $e({...bl,key_ops:["verify"],x:n,y:o});if(t.byteLength===Fo*2+1)return n=V(t.subarray(e,e+Fo),"base64url"),o=V(t.subarray(e+Fo),"base64url"),new $e({...El,key_ops:["verify"],x:n,y:o});if(t.byteLength===Go*2+1)return n=V(t.subarray(e,e+Go),"base64url"),o=V(t.subarray(e+Go),"base64url"),new $e({...Sl,key_ops:["verify"],x:n,y:o});throw new at(`coordinates were wrong length, got ${t.byteLength}, expected 65, 97 or 133`)}function wa(r){return de([Rt(Uint8Array.from([1])),de([Al(r.crv)],160),de([dn(new $(Uint8Array.from([4]),Q(r.x??"","base64url"),Q(r.y??"","base64url")))],161)]).subarray()}function Al(r){if(r==="P-256")return gl;if(r==="P-384")return wl;if(r==="P-521")return xl;throw new at(`Invalid curve ${r}`)}var $e=class{type="ECDSA";jwk;_raw;constructor(t){this.jwk=t}get raw(){return this._raw==null&&(this._raw=wa(this.jwk)),this._raw}toMultihash(){return Ht.digest(pe(this))}toCID(){return ut.createV1(114,this.toMultihash())}toString(){return nt.encode(this.toMultihash().bytes).substring(1)}equals(t){return t==null||!(t.raw instanceof Uint8Array)?!1:ht(this.raw,t.raw)}async verify(t,e,n){return ya(this.jwk,e,t,n)}};var _e=typeof globalThis=="object"&&"crypto"in globalThis?globalThis.crypto:void 0;function vl(r){return r instanceof Uint8Array||ArrayBuffer.isView(r)&&r.constructor.name==="Uint8Array"}function Ze(r){if(!Number.isSafeInteger(r)||r<0)throw new Error("positive integer expected, got "+r)}function Le(r,...t){if(!vl(r))throw new Error("Uint8Array expected");if(t.length>0&&!t.includes(r.length))throw new Error("Uint8Array expected of length "+t+", got length="+r.length)}function vr(r){if(typeof r!="function"||typeof r.create!="function")throw new Error("Hash should be wrapped by utils.createHasher");Ze(r.outputLen),Ze(r.blockLen)}function Xe(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 xa(r,t){Le(r);let e=t.outputLen;if(r.length<e)throw new Error("digestInto() expects output buffer of length at least "+e)}function Vt(...r){for(let t=0;t<r.length;t++)r[t].fill(0)}function pn(r){return new DataView(r.buffer,r.byteOffset,r.byteLength)}function qt(r,t){return r<<32-t|r>>>t}function ba(r){if(typeof r!="string")throw new Error("string expected");return new Uint8Array(new TextEncoder().encode(r))}function me(r){return typeof r=="string"&&(r=ba(r)),Le(r),r}function jo(...r){let t=0;for(let n=0;n<r.length;n++){let o=r[n];Le(o),t+=o.length}let e=new Uint8Array(t);for(let n=0,o=0;n<r.length;n++){let s=r[n];e.set(s,o),o+=s.length}return e}var Ye=class{};function $o(r){let t=n=>r().update(me(n)).digest(),e=r();return t.outputLen=e.outputLen,t.blockLen=e.blockLen,t.create=()=>r(),t}function Ir(r=32){if(_e&&typeof _e.getRandomValues=="function")return _e.getRandomValues(new Uint8Array(r));if(_e&&typeof _e.randomBytes=="function")return Uint8Array.from(_e.randomBytes(r));throw new Error("crypto.getRandomValues must be defined")}function Il(r,t,e,n){if(typeof r.setBigUint64=="function")return r.setBigUint64(t,e,n);let o=BigInt(32),s=BigInt(4294967295),i=Number(e>>o&s),a=Number(e&s),c=n?4:0,f=n?0:4;r.setUint32(t+c,i,n),r.setUint32(t+f,a,n)}function Ea(r,t,e){return r&t^~r&e}function Sa(r,t,e){return r&t^r&e^t&e}var Br=class extends Ye{constructor(t,e,n,o){super(),this.finished=!1,this.length=0,this.pos=0,this.destroyed=!1,this.blockLen=t,this.outputLen=e,this.padOffset=n,this.isLE=o,this.buffer=new Uint8Array(t),this.view=pn(this.buffer)}update(t){Xe(this),t=me(t),Le(t);let{view:e,buffer:n,blockLen:o}=this,s=t.length;for(let i=0;i<s;){let a=Math.min(o-this.pos,s-i);if(a===o){let c=pn(t);for(;o<=s-i;i+=o)this.process(c,i);continue}n.set(t.subarray(i,i+a),this.pos),this.pos+=a,i+=a,this.pos===o&&(this.process(e,0),this.pos=0)}return this.length+=t.length,this.roundClean(),this}digestInto(t){Xe(this),xa(t,this),this.finished=!0;let{buffer:e,view:n,blockLen:o,isLE:s}=this,{pos:i}=this;e[i++]=128,Vt(this.buffer.subarray(i)),this.padOffset>o-i&&(this.process(n,0),i=0);for(let l=i;l<o;l++)e[l]=0;Il(n,o-8,BigInt(this.length*8),s),this.process(n,0);let a=pn(t),c=this.outputLen;if(c%4)throw new Error("_sha2: outputLen should be aligned to 32bit");let f=c/4,u=this.get();if(f>u.length)throw new Error("_sha2: outputLen bigger than state");for(let l=0;l<f;l++)a.setUint32(4*l,u[l],s)}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:o,finished:s,destroyed:i,pos:a}=this;return t.destroyed=i,t.finished=s,t.length=o,t.pos=a,o%e&&t.buffer.set(n),t}clone(){return this._cloneInto()}},re=Uint32Array.from([1779033703,3144134277,1013904242,2773480762,1359893119,2600822924,528734635,1541459225]);var bt=Uint32Array.from([1779033703,4089235720,3144134277,2227873595,1013904242,4271175723,2773480762,1595750129,1359893119,2917565137,2600822924,725511199,528734635,4215389547,1541459225,327033209]);var mn=BigInt(4294967295),Aa=BigInt(32);function Bl(r,t=!1){return t?{h:Number(r&mn),l:Number(r>>Aa&mn)}:{h:Number(r>>Aa&mn)|0,l:Number(r&mn)|0}}function va(r,t=!1){let e=r.length,n=new Uint32Array(e),o=new Uint32Array(e);for(let s=0;s<e;s++){let{h:i,l:a}=Bl(r[s],t);[n[s],o[s]]=[i,a]}return[n,o]}var Zo=(r,t,e)=>r>>>e,Yo=(r,t,e)=>r<<32-e|t>>>e,Te=(r,t,e)=>r>>>e|t<<32-e,Ce=(r,t,e)=>r<<32-e|t>>>e,_r=(r,t,e)=>r<<64-e|t>>>e-32,Lr=(r,t,e)=>r>>>e-32|t<<64-e;function jt(r,t,e,n){let o=(t>>>0)+(n>>>0);return{h:r+e+(o/2**32|0)|0,l:o|0}}var Ia=(r,t,e)=>(r>>>0)+(t>>>0)+(e>>>0),Ba=(r,t,e,n)=>t+e+n+(r/2**32|0)|0,_a=(r,t,e,n)=>(r>>>0)+(t>>>0)+(e>>>0)+(n>>>0),La=(r,t,e,n,o)=>t+e+n+o+(r/2**32|0)|0,Ta=(r,t,e,n,o)=>(r>>>0)+(t>>>0)+(e>>>0)+(n>>>0)+(o>>>0),Ca=(r,t,e,n,o,s)=>t+e+n+o+s+(r/2**32|0)|0;var Ll=Uint32Array.from([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]),ye=new Uint32Array(64),yn=class extends Br{constructor(t=32){super(64,t,8,!1),this.A=re[0]|0,this.B=re[1]|0,this.C=re[2]|0,this.D=re[3]|0,this.E=re[4]|0,this.F=re[5]|0,this.G=re[6]|0,this.H=re[7]|0}get(){let{A:t,B:e,C:n,D:o,E:s,F:i,G:a,H:c}=this;return[t,e,n,o,s,i,a,c]}set(t,e,n,o,s,i,a,c){this.A=t|0,this.B=e|0,this.C=n|0,this.D=o|0,this.E=s|0,this.F=i|0,this.G=a|0,this.H=c|0}process(t,e){for(let l=0;l<16;l++,e+=4)ye[l]=t.getUint32(e,!1);for(let l=16;l<64;l++){let p=ye[l-15],x=ye[l-2],y=qt(p,7)^qt(p,18)^p>>>3,m=qt(x,17)^qt(x,19)^x>>>10;ye[l]=m+ye[l-7]+y+ye[l-16]|0}let{A:n,B:o,C:s,D:i,E:a,F:c,G:f,H:u}=this;for(let l=0;l<64;l++){let p=qt(a,6)^qt(a,11)^qt(a,25),x=u+p+Ea(a,c,f)+Ll[l]+ye[l]|0,m=(qt(n,2)^qt(n,13)^qt(n,22))+Sa(n,o,s)|0;u=f,f=c,c=a,a=i+x|0,i=s,s=o,o=n,n=x+m|0}n=n+this.A|0,o=o+this.B|0,s=s+this.C|0,i=i+this.D|0,a=a+this.E|0,c=c+this.F|0,f=f+this.G|0,u=u+this.H|0,this.set(n,o,s,i,a,c,f,u)}roundClean(){Vt(ye)}destroy(){this.set(0,0,0,0,0,0,0,0),Vt(this.buffer)}};var Pa=va(["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))),Tl=Pa[0],Cl=Pa[1],ge=new Uint32Array(80),we=new Uint32Array(80),Xo=class extends Br{constructor(t=64){super(128,t,16,!1),this.Ah=bt[0]|0,this.Al=bt[1]|0,this.Bh=bt[2]|0,this.Bl=bt[3]|0,this.Ch=bt[4]|0,this.Cl=bt[5]|0,this.Dh=bt[6]|0,this.Dl=bt[7]|0,this.Eh=bt[8]|0,this.El=bt[9]|0,this.Fh=bt[10]|0,this.Fl=bt[11]|0,this.Gh=bt[12]|0,this.Gl=bt[13]|0,this.Hh=bt[14]|0,this.Hl=bt[15]|0}get(){let{Ah:t,Al:e,Bh:n,Bl:o,Ch:s,Cl:i,Dh:a,Dl:c,Eh:f,El:u,Fh:l,Fl:p,Gh:x,Gl:y,Hh:m,Hl:w}=this;return[t,e,n,o,s,i,a,c,f,u,l,p,x,y,m,w]}set(t,e,n,o,s,i,a,c,f,u,l,p,x,y,m,w){this.Ah=t|0,this.Al=e|0,this.Bh=n|0,this.Bl=o|0,this.Ch=s|0,this.Cl=i|0,this.Dh=a|0,this.Dl=c|0,this.Eh=f|0,this.El=u|0,this.Fh=l|0,this.Fl=p|0,this.Gh=x|0,this.Gl=y|0,this.Hh=m|0,this.Hl=w|0}process(t,e){for(let S=0;S<16;S++,e+=4)ge[S]=t.getUint32(e),we[S]=t.getUint32(e+=4);for(let S=16;S<80;S++){let d=ge[S-15]|0,I=we[S-15]|0,U=Te(d,I,1)^Te(d,I,8)^Zo(d,I,7),B=Ce(d,I,1)^Ce(d,I,8)^Yo(d,I,7),L=ge[S-2]|0,k=we[S-2]|0,K=Te(L,k,19)^_r(L,k,61)^Zo(L,k,6),T=Ce(L,k,19)^Lr(L,k,61)^Yo(L,k,6),D=_a(B,T,we[S-7],we[S-16]),C=La(D,U,K,ge[S-7],ge[S-16]);ge[S]=C|0,we[S]=D|0}let{Ah:n,Al:o,Bh:s,Bl:i,Ch:a,Cl:c,Dh:f,Dl:u,Eh:l,El:p,Fh:x,Fl:y,Gh:m,Gl:w,Hh:_,Hl:M}=this;for(let S=0;S<80;S++){let d=Te(l,p,14)^Te(l,p,18)^_r(l,p,41),I=Ce(l,p,14)^Ce(l,p,18)^Lr(l,p,41),U=l&x^~l&m,B=p&y^~p&w,L=Ta(M,I,B,Cl[S],we[S]),k=Ca(L,_,d,U,Tl[S],ge[S]),K=L|0,T=Te(n,o,28)^_r(n,o,34)^_r(n,o,39),D=Ce(n,o,28)^Lr(n,o,34)^Lr(n,o,39),C=n&s^n&a^s&a,H=o&i^o&c^i&c;_=m|0,M=w|0,m=x|0,w=y|0,x=l|0,y=p|0,{h:l,l:p}=jt(f|0,u|0,k|0,K|0),f=a|0,u=c|0,a=s|0,c=i|0,s=n|0,i=o|0;let E=Ia(K,D,H);n=Ba(E,k,T,C),o=E|0}({h:n,l:o}=jt(this.Ah|0,this.Al|0,n|0,o|0)),{h:s,l:i}=jt(this.Bh|0,this.Bl|0,s|0,i|0),{h:a,l:c}=jt(this.Ch|0,this.Cl|0,a|0,c|0),{h:f,l:u}=jt(this.Dh|0,this.Dl|0,f|0,u|0),{h:l,l:p}=jt(this.Eh|0,this.El|0,l|0,p|0),{h:x,l:y}=jt(this.Fh|0,this.Fl|0,x|0,y|0),{h:m,l:w}=jt(this.Gh|0,this.Gl|0,m|0,w|0),{h:_,l:M}=jt(this.Hh|0,this.Hl|0,_|0,M|0),this.set(n,o,s,i,a,c,f,u,l,p,x,y,m,w,_,M)}roundClean(){Vt(ge,we)}destroy(){Vt(this.buffer),this.set(0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0)}};var gn=$o(()=>new yn);var Ua=$o(()=>new Xo);var es=BigInt(0),ts=BigInt(1);function Je(r){return r instanceof Uint8Array||ArrayBuffer.isView(r)&&r.constructor.name==="Uint8Array"}function rs(r){if(!Je(r))throw new Error("Uint8Array expected")}function $t(r,t){if(typeof t!="boolean")throw new Error(r+" boolean expected, got "+t)}function Tr(r){let t=r.toString(16);return t.length&1?"0"+t:t}function Da(r){if(typeof r!="string")throw new Error("hex string expected, got "+typeof r);return r===""?es:BigInt("0x"+r)}var Ka=typeof Uint8Array.from([]).toHex=="function"&&typeof Uint8Array.fromHex=="function",Pl=Array.from({length:256},(r,t)=>t.toString(16).padStart(2,"0"));function xe(r){if(rs(r),Ka)return r.toHex();let t="";for(let e=0;e<r.length;e++)t+=Pl[r[e]];return t}var ne={_0:48,_9:57,A:65,F:70,a:97,f:102};function ka(r){if(r>=ne._0&&r<=ne._9)return r-ne._0;if(r>=ne.A&&r<=ne.F)return r-(ne.A-10);if(r>=ne.a&&r<=ne.f)return r-(ne.a-10)}function Cr(r){if(typeof r!="string")throw new Error("hex string expected, got "+typeof r);if(Ka)return Uint8Array.fromHex(r);let t=r.length,e=t/2;if(t%2)throw new Error("hex string expected, got unpadded hex of length "+t);let n=new Uint8Array(e);for(let o=0,s=0;o<e;o++,s+=2){let i=ka(r.charCodeAt(s)),a=ka(r.charCodeAt(s+1));if(i===void 0||a===void 0){let c=r[s]+r[s+1];throw new Error('hex string expected, got non-hex character "'+c+'" at index '+s)}n[o]=i*16+a}return n}function oe(r){return Da(xe(r))}function Zt(r){return rs(r),Da(xe(Uint8Array.from(r).reverse()))}function Pe(r,t){return Cr(r.toString(16).padStart(t*2,"0"))}function be(r,t){return Pe(r,t).reverse()}function ot(r,t,e){let n;if(typeof t=="string")try{n=Cr(t)}catch(s){throw new Error(r+" must be hex string or Uint8Array, cause: "+s)}else if(Je(t))n=Uint8Array.from(t);else throw new Error(r+" must be hex string or Uint8Array");let o=n.length;if(typeof e=="number"&&o!==e)throw new Error(r+" of length "+e+" expected, got "+o);return n}function Ee(...r){let t=0;for(let n=0;n<r.length;n++){let o=r[n];rs(o),t+=o.length}let e=new Uint8Array(t);for(let n=0,o=0;n<r.length;n++){let s=r[n];e.set(s,o),o+=s.length}return e}var Jo=r=>typeof r=="bigint"&&es<=r;function wn(r,t,e){return Jo(r)&&Jo(t)&&Jo(e)&&t<=r&&r<e}function vt(r,t,e,n){if(!wn(t,e,n))throw new Error("expected valid "+r+": "+e+" <= n < "+n+", got "+t)}function Na(r){let t;for(t=0;r>es;r>>=ts,t+=1);return t}var Ue=r=>(ts<<BigInt(r))-ts,Qo=r=>new Uint8Array(r),Ra=r=>Uint8Array.from(r);function Ma(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=Qo(r),o=Qo(r),s=0,i=()=>{n.fill(1),o.fill(0),s=0},a=(...l)=>e(o,n,...l),c=(l=Qo(0))=>{o=a(Ra([0]),l),n=a(),l.length!==0&&(o=a(Ra([1]),l),n=a())},f=()=>{if(s++>=1e3)throw new Error("drbg: tried 1000 values");let l=0,p=[];for(;l<t;){n=a();let x=n.slice();p.push(x),l+=n.length}return Ee(...p)};return(l,p)=>{i(),c(l);let x;for(;!(x=p(f()));)c();return i(),x}}var Ul={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"||Je(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 zt(r,t,e={}){let n=(o,s,i)=>{let a=Ul[s];if(typeof a!="function")throw new Error("invalid validator function");let c=r[o];if(!(i&&c===void 0)&&!a(c,r))throw new Error("param "+String(o)+" is invalid. Expected "+s+", got "+c)};for(let[o,s]of Object.entries(t))n(o,s,!1);for(let[o,s]of Object.entries(e))n(o,s,!0);return r}function Qe(r){let t=new WeakMap;return(e,...n)=>{let o=t.get(e);if(o!==void 0)return o;let s=r(e,...n);return t.set(e,s),s}}var Ct=BigInt(0),yt=BigInt(1),ke=BigInt(2),kl=BigInt(3),Ha=BigInt(4),Va=BigInt(5),qa=BigInt(8);function Y(r,t){let e=r%t;return e>=Ct?e:t+e}function st(r,t,e){let n=r;for(;t-- >Ct;)n*=n,n%=e;return n}function xn(r,t){if(r===Ct)throw new Error("invert: expected non-zero number");if(t<=Ct)throw new Error("invert: expected positive modulus, got "+t);let e=Y(r,t),n=t,o=Ct,s=yt,i=yt,a=Ct;for(;e!==Ct;){let f=n/e,u=n%e,l=o-i*f,p=s-a*f;n=e,e=u,o=i,s=a,i=l,a=p}if(n!==yt)throw new Error("invert: does not exist");return Y(o,t)}function za(r,t){let e=(r.ORDER+yt)/Ha,n=r.pow(t,e);if(!r.eql(r.sqr(n),t))throw new Error("Cannot find square root");return n}function Rl(r,t){let e=(r.ORDER-Va)/qa,n=r.mul(t,ke),o=r.pow(n,e),s=r.mul(t,o),i=r.mul(r.mul(s,ke),o),a=r.mul(s,r.sub(i,r.ONE));if(!r.eql(r.sqr(a),t))throw new Error("Cannot find square root");return a}function Dl(r){if(r<BigInt(3))throw new Error("sqrt is not defined for small field");let t=r-yt,e=0;for(;t%ke===Ct;)t/=ke,e++;let n=ke,o=se(r);for(;Oa(o,n)===1;)if(n++>1e3)throw new Error("Cannot find square root: probably non-prime P");if(e===1)return za;let s=o.pow(n,t),i=(t+yt)/ke;return function(c,f){if(c.is0(f))return f;if(Oa(c,f)!==1)throw new Error("Cannot find square root");let u=e,l=c.mul(c.ONE,s),p=c.pow(f,t),x=c.pow(f,i);for(;!c.eql(p,c.ONE);){if(c.is0(p))return c.ZERO;let y=1,m=c.sqr(p);for(;!c.eql(m,c.ONE);)if(y++,m=c.sqr(m),y===u)throw new Error("Cannot find square root");let w=yt<<BigInt(u-y-1),_=c.pow(l,w);u=y,l=c.sqr(_),p=c.mul(p,l),x=c.mul(x,_)}return x}}function Kl(r){return r%Ha===kl?za:r%qa===Va?Rl:Dl(r)}var Fa=(r,t)=>(Y(r,t)&yt)===yt,Nl=["create","isValid","is0","neg","inv","sqrt","sqr","eql","add","sub","mul","pow","div","addN","subN","mulN","sqrN"];function ns(r){let t={ORDER:"bigint",MASK:"bigint",BYTES:"isSafeInteger",BITS:"isSafeInteger"},e=Nl.reduce((n,o)=>(n[o]="function",n),t);return zt(r,e)}function Ml(r,t,e){if(e<Ct)throw new Error("invalid exponent, negatives unsupported");if(e===Ct)return r.ONE;if(e===yt)return t;let n=r.ONE,o=t;for(;e>Ct;)e&yt&&(n=r.mul(n,o)),o=r.sqr(o),e>>=yt;return n}function tr(r,t,e=!1){let n=new Array(t.length).fill(e?r.ZERO:void 0),o=t.reduce((i,a,c)=>r.is0(a)?i:(n[c]=i,r.mul(i,a)),r.ONE),s=r.inv(o);return t.reduceRight((i,a,c)=>r.is0(a)?i:(n[c]=r.mul(i,n[c]),r.mul(i,a)),s),n}function Oa(r,t){let e=(r.ORDER-yt)/ke,n=r.pow(t,e),o=r.eql(n,r.ONE),s=r.eql(n,r.ZERO),i=r.eql(n,r.neg(r.ONE));if(!o&&!s&&!i)throw new Error("invalid Legendre symbol result");return o?1:s?0:-1}function os(r,t){t!==void 0&&Ze(t);let e=t!==void 0?t:r.toString(2).length,n=Math.ceil(e/8);return{nBitLength:e,nByteLength:n}}function se(r,t,e=!1,n={}){if(r<=Ct)throw new Error("invalid field: expected ORDER > 0, got "+r);let{nBitLength:o,nByteLength:s}=os(r,t);if(s>2048)throw new Error("invalid field: expected ORDER of <= 2048 bytes");let i,a=Object.freeze({ORDER:r,isLE:e,BITS:o,BYTES:s,MASK:Ue(o),ZERO:Ct,ONE:yt,create:c=>Y(c,r),isValid:c=>{if(typeof c!="bigint")throw new Error("invalid field element: expected bigint, got "+typeof c);return Ct<=c&&c<r},is0:c=>c===Ct,isOdd:c=>(c&yt)===yt,neg:c=>Y(-c,r),eql:(c,f)=>c===f,sqr:c=>Y(c*c,r),add:(c,f)=>Y(c+f,r),sub:(c,f)=>Y(c-f,r),mul:(c,f)=>Y(c*f,r),pow:(c,f)=>Ml(a,c,f),div:(c,f)=>Y(c*xn(f,r),r),sqrN:c=>c*c,addN:(c,f)=>c+f,subN:(c,f)=>c-f,mulN:(c,f)=>c*f,inv:c=>xn(c,r),sqrt:n.sqrt||(c=>(i||(i=Kl(r)),i(a,c))),toBytes:c=>e?be(c,s):Pe(c,s),fromBytes:c=>{if(c.length!==s)throw new Error("Field.fromBytes: expected "+s+" bytes, got "+c.length);return e?Zt(c):oe(c)},invertBatch:c=>tr(a,c),cmov:(c,f,u)=>u?f:c});return Object.freeze(a)}function Ga(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 ss(r){let t=Ga(r);return t+Math.ceil(t/2)}function Wa(r,t,e=!1){let n=r.length,o=Ga(t),s=ss(t);if(n<16||n<s||n>1024)throw new Error("expected "+s+"-1024 bytes of input, got "+n);let i=e?Zt(r):oe(r),a=Y(i,t-yt)+yt;return e?be(a,o):Pe(a,o)}var ja=BigInt(0),fs=BigInt(1);function is(r,t){let e=t.negate();return r?e:t}function Za(r,t){if(!Number.isSafeInteger(r)||r<=0||r>t)throw new Error("invalid window size, expected [1.."+t+"], got W="+r)}function as(r,t){Za(r,t);let e=Math.ceil(t/r)+1,n=2**(r-1),o=2**r,s=Ue(r),i=BigInt(r);return{windows:e,windowSize:n,mask:s,maxNumber:o,shiftBy:i}}function $a(r,t,e){let{windowSize:n,mask:o,maxNumber:s,shiftBy:i}=e,a=Number(r&o),c=r>>i;a>n&&(a-=s,c+=fs);let f=t*n,u=f+Math.abs(a)-1,l=a===0,p=a<0,x=t%2!==0;return{nextN:c,offset:u,isZero:l,isNeg:p,isNegF:x,offsetF:f}}function Ol(r,t){if(!Array.isArray(r))throw new Error("array expected");r.forEach((e,n)=>{if(!(e instanceof t))throw new Error("invalid point at index "+n)})}function Hl(r,t){if(!Array.isArray(r))throw new Error("array of scalars expected");r.forEach((e,n)=>{if(!t.isValid(e))throw new Error("invalid scalar at index "+n)})}var cs=new WeakMap,Ya=new WeakMap;function us(r){return Ya.get(r)||1}function bn(r,t){return{constTimeNegate:is,hasPrecomputes(e){return us(e)!==1},unsafeLadder(e,n,o=r.ZERO){let s=e;for(;n>ja;)n&fs&&(o=o.add(s)),s=s.double(),n>>=fs;return o},precomputeWindow(e,n){let{windows:o,windowSize:s}=as(n,t),i=[],a=e,c=a;for(let f=0;f<o;f++){c=a,i.push(c);for(let u=1;u<s;u++)c=c.add(a),i.push(c);a=c.double()}return i},wNAF(e,n,o){let s=r.ZERO,i=r.BASE,a=as(e,t);for(let c=0;c<a.windows;c++){let{nextN:f,offset:u,isZero:l,isNeg:p,isNegF:x,offsetF:y}=$a(o,c,a);o=f,l?i=i.add(is(x,n[y])):s=s.add(is(p,n[u]))}return{p:s,f:i}},wNAFUnsafe(e,n,o,s=r.ZERO){let i=as(e,t);for(let a=0;a<i.windows&&o!==ja;a++){let{nextN:c,offset:f,isZero:u,isNeg:l}=$a(o,a,i);if(o=c,!u){let p=n[f];s=s.add(l?p.negate():p)}}return s},getPrecomputes(e,n,o){let s=cs.get(n);return s||(s=this.precomputeWindow(n,e),e!==1&&cs.set(n,o(s))),s},wNAFCached(e,n,o){let s=us(e);return this.wNAF(s,this.getPrecomputes(s,e,o),n)},wNAFCachedUnsafe(e,n,o,s){let i=us(e);return i===1?this.unsafeLadder(e,n,s):this.wNAFUnsafe(i,this.getPrecomputes(i,e,o),n,s)},setWindowSize(e,n){Za(n,t),Ya.set(e,n),cs.delete(e)}}}function En(r,t,e,n){Ol(e,r),Hl(n,t);let o=e.length,s=n.length;if(o!==s)throw new Error("arrays of points and scalars must have equal length");let i=r.ZERO,a=Na(BigInt(o)),c=1;a>12?c=a-3:a>4?c=a-2:a>0&&(c=2);let f=Ue(c),u=new Array(Number(f)+1).fill(i),l=Math.floor((t.BITS-1)/c)*c,p=i;for(let x=l;x>=0;x-=c){u.fill(i);for(let m=0;m<s;m++){let w=n[m],_=Number(w>>BigInt(x)&f);u[_]=u[_].add(e[m])}let y=i;for(let m=u.length-1,w=i;m>0;m--)w=w.add(u[m]),y=y.add(w);if(p=p.add(y),x!==0)for(let m=0;m<c;m++)p=p.double()}return p}function Pr(r){return ns(r.Fp),zt(r,{n:"bigint",h:"bigint",Gx:"field",Gy:"field"},{nBitLength:"isSafeInteger",nByteLength:"isSafeInteger"}),Object.freeze({...os(r.n,r.nBitLength),...r,p:r.Fp.ORDER})}var Yt=BigInt(0),Pt=BigInt(1),Xa=BigInt(2),Vl=BigInt(8),ql={zip215:!0};function zl(r){let t=Pr(r);return zt(r,{hash:"function",a:"bigint",d:"bigint",randomBytes:"function"},{adjustScalarBytes:"function",domain:"function",uvRatio:"function",mapToCurve:"function"}),Object.freeze({...t})}function Ja(r){let t=zl(r),{Fp:e,n,prehash:o,hash:s,randomBytes:i,nByteLength:a,h:c}=t,f=Xa<<BigInt(a*8)-Pt,u=e.create,l=se(t.n,t.nBitLength);function p(b,h){let g=e.sqr(b),v=e.sqr(h),R=e.add(e.mul(t.a,g),v),O=e.add(e.ONE,e.mul(t.d,e.mul(g,v)));return e.eql(R,O)}if(!p(t.Gx,t.Gy))throw new Error("bad curve params: generator point");let x=t.uvRatio||((b,h)=>{try{return{isValid:!0,value:e.sqrt(b*e.inv(h))}}catch{return{isValid:!1,value:Yt}}}),y=t.adjustScalarBytes||(b=>b),m=t.domain||((b,h,g)=>{if($t("phflag",g),h.length||g)throw new Error("Contexts/pre-hash are not supported");return b});function w(b,h,g=!1){let v=g?Pt:Yt;vt("coordinate "+b,h,v,f)}function _(b){if(!(b instanceof d))throw new Error("ExtendedPoint expected")}let M=Qe((b,h)=>{let{ex:g,ey:v,ez:R}=b,O=b.is0();h==null&&(h=O?Vl:e.inv(R));let q=u(g*h),z=u(v*h),F=u(R*h);if(O)return{x:Yt,y:Pt};if(F!==Pt)throw new Error("invZ was invalid");return{x:q,y:z}}),S=Qe(b=>{let{a:h,d:g}=t;if(b.is0())throw new Error("bad point: ZERO");let{ex:v,ey:R,ez:O,et:q}=b,z=u(v*v),F=u(R*R),G=u(O*O),J=u(G*G),Z=u(z*h),xt=u(G*u(Z+F)),kt=u(J+u(g*u(z*F)));if(xt!==kt)throw new Error("bad point: equation left != right (1)");let mt=u(v*R),St=u(O*q);if(mt!==St)throw new Error("bad point: equation left != right (2)");return!0});class d{constructor(h,g,v,R){w("x",h),w("y",g),w("z",v,!0),w("t",R),this.ex=h,this.ey=g,this.ez=v,this.et=R,Object.freeze(this)}get x(){return this.toAffine().x}get y(){return this.toAffine().y}static fromAffine(h){if(h instanceof d)throw new Error("extended point not allowed");let{x:g,y:v}=h||{};return w("x",g),w("y",v),new d(g,v,Pt,u(g*v))}static normalizeZ(h){let g=tr(e,h.map(v=>v.ez));return h.map((v,R)=>v.toAffine(g[R])).map(d.fromAffine)}static msm(h,g){return En(d,l,h,g)}_setWindowSize(h){B.setWindowSize(this,h)}assertValidity(){S(this)}equals(h){_(h);let{ex:g,ey:v,ez:R}=this,{ex:O,ey:q,ez:z}=h,F=u(g*z),G=u(O*R),J=u(v*z),Z=u(q*R);return F===G&&J===Z}is0(){return this.equals(d.ZERO)}negate(){return new d(u(-this.ex),this.ey,this.ez,u(-this.et))}double(){let{a:h}=t,{ex:g,ey:v,ez:R}=this,O=u(g*g),q=u(v*v),z=u(Xa*u(R*R)),F=u(h*O),G=g+v,J=u(u(G*G)-O-q),Z=F+q,xt=Z-z,kt=F-q,mt=u(J*xt),St=u(Z*kt),Dt=u(J*kt),Ot=u(xt*Z);return new d(mt,St,Ot,Dt)}add(h){_(h);let{a:g,d:v}=t,{ex:R,ey:O,ez:q,et:z}=this,{ex:F,ey:G,ez:J,et:Z}=h,xt=u(R*F),kt=u(O*G),mt=u(z*v*Z),St=u(q*J),Dt=u((R+O)*(F+G)-xt-kt),Ot=St-mt,yr=St+mt,Gi=u(kt-g*xt),Wu=u(Dt*Ot),ju=u(yr*Gi),$u=u(Dt*Gi),Zu=u(Ot*yr);return new d(Wu,ju,Zu,$u)}subtract(h){return this.add(h.negate())}wNAF(h){return B.wNAFCached(this,h,d.normalizeZ)}multiply(h){let g=h;vt("scalar",g,Pt,n);let{p:v,f:R}=this.wNAF(g);return d.normalizeZ([v,R])[0]}multiplyUnsafe(h,g=d.ZERO){let v=h;return vt("scalar",v,Yt,n),v===Yt?U:this.is0()||v===Pt?this:B.wNAFCachedUnsafe(this,v,d.normalizeZ,g)}isSmallOrder(){return this.multiplyUnsafe(c).is0()}isTorsionFree(){return B.unsafeLadder(this,n).is0()}toAffine(h){return M(this,h)}clearCofactor(){let{h}=t;return h===Pt?this:this.multiplyUnsafe(h)}static fromHex(h,g=!1){let{d:v,a:R}=t,O=e.BYTES;h=ot("pointHex",h,O),$t("zip215",g);let q=h.slice(),z=h[O-1];q[O-1]=z&-129;let F=Zt(q),G=g?f:e.ORDER;vt("pointHex.y",F,Yt,G);let J=u(F*F),Z=u(J-Pt),xt=u(v*J-R),{isValid:kt,value:mt}=x(Z,xt);if(!kt)throw new Error("Point.fromHex: invalid y coordinate");let St=(mt&Pt)===Pt,Dt=(z&128)!==0;if(!g&&mt===Yt&&Dt)throw new Error("Point.fromHex: x=0 and x_0=1");return Dt!==St&&(mt=u(-mt)),d.fromAffine({x:mt,y:F})}static fromPrivateKey(h){let{scalar:g}=K(h);return I.multiply(g)}toRawBytes(){let{x:h,y:g}=this.toAffine(),v=be(g,e.BYTES);return v[v.length-1]|=h&Pt?128:0,v}toHex(){return xe(this.toRawBytes())}}d.BASE=new d(t.Gx,t.Gy,Pt,u(t.Gx*t.Gy)),d.ZERO=new d(Yt,Pt,Pt,Yt);let{BASE:I,ZERO:U}=d,B=bn(d,a*8);function L(b){return Y(b,n)}function k(b){return L(Zt(b))}function K(b){let h=e.BYTES;b=ot("private key",b,h);let g=ot("hashed private key",s(b),2*h),v=y(g.slice(0,h)),R=g.slice(h,2*h),O=k(v);return{head:v,prefix:R,scalar:O}}function T(b){let{head:h,prefix:g,scalar:v}=K(b),R=I.multiply(v),O=R.toRawBytes();return{head:h,prefix:g,scalar:v,point:R,pointBytes:O}}function D(b){return T(b).pointBytes}function C(b=Uint8Array.of(),...h){let g=Ee(...h);return k(s(m(g,ot("context",b),!!o)))}function H(b,h,g={}){b=ot("message",b),o&&(b=o(b));let{prefix:v,scalar:R,pointBytes:O}=T(h),q=C(g.context,v,b),z=I.multiply(q).toRawBytes(),F=C(g.context,z,O,b),G=L(q+F*R);vt("signature.s",G,Yt,n);let J=Ee(z,be(G,e.BYTES));return ot("result",J,e.BYTES*2)}let E=ql;function A(b,h,g,v=E){let{context:R,zip215:O}=v,q=e.BYTES;b=ot("signature",b,2*q),h=ot("message",h),g=ot("publicKey",g,q),O!==void 0&&$t("zip215",O),o&&(h=o(h));let z=Zt(b.slice(q,2*q)),F,G,J;try{F=d.fromHex(g,O),G=d.fromHex(b.slice(0,q),O),J=I.multiplyUnsafe(z)}catch{return!1}if(!O&&F.isSmallOrder())return!1;let Z=C(R,G.toRawBytes(),F.toRawBytes(),h);return G.add(F.multiplyUnsafe(Z)).subtract(J).clearCofactor().equals(d.ZERO)}return I._setWindowSize(8),{CURVE:t,getPublicKey:D,sign:H,verify:A,ExtendedPoint:d,utils:{getExtendedPublicKey:T,randomPrivateKey:()=>i(e.BYTES),precompute(b=8,h=d.BASE){return h._setWindowSize(b),h.multiply(BigInt(3)),h}}}}var Ur=BigInt(0),er=BigInt(1),Sn=BigInt(2);function Fl(r){return zt(r,{adjustScalarBytes:"function",powPminus2:"function"}),Object.freeze({...r})}function Qa(r){let t=Fl(r),{P:e,type:n,adjustScalarBytes:o,powPminus2:s}=t,i=n==="x25519";if(!i&&n!=="x448")throw new Error("invalid type");let a=i?255:448,c=i?32:56,f=BigInt(i?9:5),u=BigInt(i?121665:39081),l=i?Sn**BigInt(254):Sn**BigInt(447),p=i?BigInt(8)*Sn**BigInt(251)-er:BigInt(4)*Sn**BigInt(445)-er,x=l+p+er,y=B=>Y(B,e),m=w(f);function w(B){return be(y(B),c)}function _(B){let L=ot("u coordinate",B,c);return i&&(L[31]&=127),y(Zt(L))}function M(B){return Zt(o(ot("scalar",B,c)))}function S(B,L){let k=U(_(L),M(B));if(k===Ur)throw new Error("invalid private or public key received");return w(k)}function d(B){return S(B,m)}function I(B,L,k){let K=y(B*(L-k));return L=y(L-K),k=y(k+K),{x_2:L,x_3:k}}function U(B,L){vt("u",B,Ur,e),vt("scalar",L,l,x);let k=L,K=B,T=er,D=Ur,C=B,H=er,E=Ur;for(let P=BigInt(a-1);P>=Ur;P--){let b=k>>P&er;E^=b,{x_2:T,x_3:C}=I(E,T,C),{x_2:D,x_3:H}=I(E,D,H),E=b;let h=T+D,g=y(h*h),v=T-D,R=y(v*v),O=g-R,q=C+H,z=C-H,F=y(z*h),G=y(q*v),J=F+G,Z=F-G;C=y(J*J),H=y(K*y(Z*Z)),T=y(g*R),D=y(O*(g+y(u*O)))}({x_2:T,x_3:C}=I(E,T,C)),{x_2:D,x_3:H}=I(E,D,H);let A=s(D);return y(T*A)}return{scalarMult:S,scalarMultBase:d,getSharedSecret:(B,L)=>S(B,L),getPublicKey:B=>d(B),utils:{randomPrivateKey:()=>t.randomBytes(c)},GuBytes:m.slice()}}var kr=BigInt("57896044618658097711785492504343953926634992332820282019728792003956564819949"),tc=BigInt("19681161376707505956807079304988542015446066515923890162744021073123829784752"),ym=BigInt(0),Gl=BigInt(1),ec=BigInt(2),Wl=BigInt(3),jl=BigInt(5),$l=BigInt(8);function nc(r){let t=BigInt(10),e=BigInt(20),n=BigInt(40),o=BigInt(80),s=kr,a=r*r%s*r%s,c=st(a,ec,s)*a%s,f=st(c,Gl,s)*r%s,u=st(f,jl,s)*f%s,l=st(u,t,s)*u%s,p=st(l,e,s)*l%s,x=st(p,n,s)*p%s,y=st(x,o,s)*x%s,m=st(y,o,s)*x%s,w=st(m,t,s)*u%s;return{pow_p_5_8:st(w,ec,s)*r%s,b2:a}}function oc(r){return r[0]&=248,r[31]&=127,r[31]|=64,r}function Zl(r,t){let e=kr,n=Y(t*t*t,e),o=Y(n*n*t,e),s=nc(r*o).pow_p_5_8,i=Y(r*n*s,e),a=Y(t*i*i,e),c=i,f=Y(i*tc,e),u=a===r,l=a===Y(-r,e),p=a===Y(-r*tc,e);return u&&(i=c),(l||p)&&(i=f),Fa(i,e)&&(i=Y(-i,e)),{isValid:u||l,value:i}}var rc=se(kr,void 0,!0),Yl={a:rc.create(BigInt(-1)),d:BigInt("37095705934669439343138083508754565189542113879843219016388785533085940283555"),Fp:rc,n:BigInt("7237005577332262213973186563042994240857116359379907606001950938285454250989"),h:$l,Gx:BigInt("15112221349535400772501151409588531511454012693041857206046113283949847762202"),Gy:BigInt("46316835694926478169428394003475163141307993866256225615783033603165251855960"),hash:Ua,randomBytes:Ir,adjustScalarBytes:oc,uvRatio:Zl},sc=Ja(Yl);var Rr=Qa({P:kr,type:"x25519",powPminus2:r=>{let t=kr,{pow_p_5_8:e,b2:n}=nc(r);return Y(st(e,Wl,t)*n,t)},adjustScalarBytes:oc,randomBytes:Ir});var Dr=class extends Error{constructor(t="An error occurred while verifying a message"){super(t),this.name="VerificationError"}},An=class extends Error{constructor(t="Missing Web Crypto API"){super(t),this.name="WebCryptoMissingError"}};var ic={get(r=globalThis){let t=r.crypto;if(t?.subtle==null)throw new An("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");return t}};var Mt=ic;var vn=32;var ls,Xl=(async()=>{try{return await Mt.get().subtle.generateKey({name:"Ed25519"},!0,["sign","verify"]),!0}catch{return!1}})();async function Jl(r,t,e){if(r.buffer instanceof ArrayBuffer){let n=await Mt.get().subtle.importKey("raw",r.buffer,{name:"Ed25519"},!1,["verify"]);return await Mt.get().subtle.verify({name:"Ed25519"},n,t,e instanceof Uint8Array?e:e.subarray())}throw new TypeError("WebCrypto does not support SharedArrayBuffer for Ed25519 keys")}function Ql(r,t,e){return sc.verify(t,e instanceof Uint8Array?e:e.subarray(),r)}async function ac(r,t,e){return ls==null&&(ls=await Xl),ls?Jl(r,t,e):Ql(r,t,e)}function In(r){return r==null?!1:typeof r.then=="function"&&typeof r.catch=="function"&&typeof r.finally=="function"}var Bn=class{type="Ed25519";raw;constructor(t){this.raw=hs(t,vn)}toMultihash(){return Ht.digest(pe(this))}toCID(){return ut.createV1(114,this.toMultihash())}toString(){return nt.encode(this.toMultihash().bytes).substring(1)}equals(t){return t==null||!(t.raw instanceof Uint8Array)?!1:ht(this.raw,t.raw)}verify(t,e,n){n?.signal?.throwIfAborted();let o=ac(this.raw,e,t);return In(o)?o.then(s=>(n?.signal?.throwIfAborted(),s)):o}};function ds(r){return r=hs(r,vn),new Bn(r)}function hs(r,t){if(r=Uint8Array.from(r??[]),r.length!==t)throw new at(`Key must be a Uint8Array of length ${t}, got ${r.length}`);return r}var eh=Math.pow(2,7),rh=Math.pow(2,14),nh=Math.pow(2,21),ps=Math.pow(2,28),ms=Math.pow(2,35),ys=Math.pow(2,42),gs=Math.pow(2,49),tt=128,It=127;function lt(r){if(r<eh)return 1;if(r<rh)return 2;if(r<nh)return 3;if(r<ps)return 4;if(r<ms)return 5;if(r<ys)return 6;if(r<gs)return 7;if(Number.MAX_SAFE_INTEGER!=null&&r>Number.MAX_SAFE_INTEGER)throw new RangeError("Could not encode varint");return 8}function ws(r,t,e=0){switch(lt(r)){case 8:t[e++]=r&255|tt,r/=128;case 7:t[e++]=r&255|tt,r/=128;case 6:t[e++]=r&255|tt,r/=128;case 5:t[e++]=r&255|tt,r/=128;case 4:t[e++]=r&255|tt,r>>>=7;case 3:t[e++]=r&255|tt,r>>>=7;case 2:t[e++]=r&255|tt,r>>>=7;case 1:{t[e++]=r&255,r>>>=7;break}default:throw new Error("unreachable")}return t}function oh(r,t,e=0){switch(lt(r)){case 8:t.set(e++,r&255|tt),r/=128;case 7:t.set(e++,r&255|tt),r/=128;case 6:t.set(e++,r&255|tt),r/=128;case 5:t.set(e++,r&255|tt),r/=128;case 4:t.set(e++,r&255|tt),r>>>=7;case 3:t.set(e++,r&255|tt),r>>>=7;case 2:t.set(e++,r&255|tt),r>>>=7;case 1:{t.set(e++,r&255),r>>>=7;break}default:throw new Error("unreachable")}return t}function xs(r,t){let e=r[t],n=0;if(n+=e&It,e<tt||(e=r[t+1],n+=(e&It)<<7,e<tt)||(e=r[t+2],n+=(e&It)<<14,e<tt)||(e=r[t+3],n+=(e&It)<<21,e<tt)||(e=r[t+4],n+=(e&It)*ps,e<tt)||(e=r[t+5],n+=(e&It)*ms,e<tt)||(e=r[t+6],n+=(e&It)*ys,e<tt)||(e=r[t+7],n+=(e&It)*gs,e<tt))return n;throw new RangeError("Could not decode varint")}function sh(r,t){let e=r.get(t),n=0;if(n+=e&It,e<tt||(e=r.get(t+1),n+=(e&It)<<7,e<tt)||(e=r.get(t+2),n+=(e&It)<<14,e<tt)||(e=r.get(t+3),n+=(e&It)<<21,e<tt)||(e=r.get(t+4),n+=(e&It)*ps,e<tt)||(e=r.get(t+5),n+=(e&It)*ms,e<tt)||(e=r.get(t+6),n+=(e&It)*ys,e<tt)||(e=r.get(t+7),n+=(e&It)*gs,e<tt))return n;throw new RangeError("Could not decode varint")}function Xt(r,t,e=0){return t==null&&(t=pt(lt(r))),t instanceof Uint8Array?ws(r,t,e):oh(r,t,e)}function Ft(r,t=0){return r instanceof Uint8Array?xs(r,t):sh(r,t)}var bs=new Float32Array([-0]),Se=new Uint8Array(bs.buffer);function uc(r,t,e){bs[0]=r,t[e]=Se[0],t[e+1]=Se[1],t[e+2]=Se[2],t[e+3]=Se[3]}function fc(r,t){return Se[0]=r[t],Se[1]=r[t+1],Se[2]=r[t+2],Se[3]=r[t+3],bs[0]}var Es=new Float64Array([-0]),Bt=new Uint8Array(Es.buffer);function lc(r,t,e){Es[0]=r,t[e]=Bt[0],t[e+1]=Bt[1],t[e+2]=Bt[2],t[e+3]=Bt[3],t[e+4]=Bt[4],t[e+5]=Bt[5],t[e+6]=Bt[6],t[e+7]=Bt[7]}function hc(r,t){return Bt[0]=r[t],Bt[1]=r[t+1],Bt[2]=r[t+2],Bt[3]=r[t+3],Bt[4]=r[t+4],Bt[5]=r[t+5],Bt[6]=r[t+6],Bt[7]=r[t+7],Es[0]}var ih=BigInt(Number.MAX_SAFE_INTEGER),ah=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 Re;if(t<ih&&t>ah)return this.fromNumber(Number(t));let e=t<0n;e&&(t=-t);let n=t>>32n,o=t-(n<<32n);return e&&(n=~n|0n,o=~o|0n,++o>dc&&(o=0n,++n>dc&&(n=0n))),new r(Number(o),Number(n))}static fromNumber(t){if(t===0)return Re;let e=t<0;e&&(t=-t);let n=t>>>0,o=(t-n)/4294967296>>>0;return e&&(o=~o>>>0,n=~n>>>0,++n>4294967295&&(n=0,++o>4294967295&&(o=0))),new r(n,o)}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):Re}},Re=new Kt(0,0);Re.toBigInt=function(){return 0n};Re.zzEncode=Re.zzDecode=function(){return this};Re.length=function(){return 1};var dc=4294967296n;function pc(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 mc(r,t,e){if(e-t<1)return"";let o,s=[],i=0,a;for(;t<e;)a=r[t++],a<128?s[i++]=a:a>191&&a<224?s[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,s[i++]=55296+(a>>10),s[i++]=56320+(a&1023)):s[i++]=(a&15)<<12|(r[t++]&63)<<6|r[t++]&63,i>8191&&((o??(o=[])).push(String.fromCharCode.apply(String,s)),i=0);return o!=null?(i>0&&o.push(String.fromCharCode.apply(String,s.slice(0,i))),o.join("")):String.fromCharCode.apply(String,s.slice(0,i))}function Ss(r,t,e){let n=e,o,s;for(let i=0;i<r.length;++i)o=r.charCodeAt(i),o<128?t[e++]=o:o<2048?(t[e++]=o>>6|192,t[e++]=o&63|128):(o&64512)===55296&&((s=r.charCodeAt(i+1))&64512)===56320?(o=65536+((o&1023)<<10)+(s&1023),++i,t[e++]=o>>18|240,t[e++]=o>>12&63|128,t[e++]=o>>6&63|128,t[e++]=o&63|128):(t[e++]=o>>12|224,t[e++]=o>>6&63|128,t[e++]=o&63|128);return e-n}function Gt(r,t){return RangeError(`index out of range: ${r.pos} + ${t??1} > ${r.len}`)}function _n(r,t){return(r[t-4]|r[t-3]<<8|r[t-2]<<16|r[t-1]<<24)>>>0}var As=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,Gt(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 Gt(this,4);return _n(this.buf,this.pos+=4)}sfixed32(){if(this.pos+4>this.len)throw Gt(this,4);return _n(this.buf,this.pos+=4)|0}float(){if(this.pos+4>this.len)throw Gt(this,4);let t=fc(this.buf,this.pos);return this.pos+=4,t}double(){if(this.pos+8>this.len)throw Gt(this,4);let t=hc(this.buf,this.pos);return this.pos+=8,t}bytes(){let t=this.uint32(),e=this.pos,n=this.pos+t;if(n>this.len)throw Gt(this,t);return this.pos+=t,e===n?new Uint8Array(0):this.buf.subarray(e,n)}string(){let t=this.bytes();return mc(t,0,t.length)}skip(t){if(typeof t=="number"){if(this.pos+t>this.len)throw Gt(this,t);this.pos+=t}else do if(this.pos>=this.len)throw Gt(this);while((this.buf[this.pos++]&128)!==0);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 Gt(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 Gt(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 Gt(this,8);let t=_n(this.buf,this.pos+=4),e=_n(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=xs(this.buf,this.pos);return this.pos+=lt(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 vs(r){return new As(r instanceof Uint8Array?r:r.subarray())}function De(r,t,e){let n=vs(r);return t.decode(n,void 0,e)}function Is(r){let t=r??8192,e=t>>>1,n,o=t;return function(i){if(i<1||i>e)return pt(i);o+i>t&&(n=pt(t),o=0);let a=n.subarray(o,o+=i);return(o&7)!==0&&(o=(o|7)+1),a}}var Ke=class{fn;len;next;val;constructor(t,e,n){this.fn=t,this.len=e,this.next=void 0,this.val=n}};function Bs(){}var Ls=class{head;tail;len;next;constructor(t){this.head=t.head,this.tail=t.tail,this.len=t.len,this.next=t.states}},ch=Is();function uh(r){return globalThis.Buffer!=null?pt(r):ch(r)}var Mr=class{len;head;tail;states;constructor(){this.len=0,this.head=new Ke(Bs,0,0),this.tail=this.head,this.states=null}_push(t,e,n){return this.tail=this.tail.next=new Ke(t,e,n),this.len+=e,this}uint32(t){return this.len+=(this.tail=this.tail.next=new Ts((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(Ln,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(Ln,e.length(),e)}uint64Number(t){return this._push(ws,lt(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(Ln,e.length(),e)}sint64Number(t){let e=Kt.fromNumber(t).zzEncode();return this._push(Ln,e.length(),e)}sint64String(t){return this.sint64(BigInt(t))}bool(t){return this._push(_s,1,t?1:0)}fixed32(t){return this._push(Nr,4,t>>>0)}sfixed32(t){return this.fixed32(t)}fixed64(t){let e=Kt.fromBigInt(t);return this._push(Nr,4,e.lo)._push(Nr,4,e.hi)}fixed64Number(t){let e=Kt.fromNumber(t);return this._push(Nr,4,e.lo)._push(Nr,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(uc,4,t)}double(t){return this._push(lc,8,t)}bytes(t){let e=t.length>>>0;return e===0?this._push(_s,1,0):this.uint32(e)._push(lh,e,t)}string(t){let e=pc(t);return e!==0?this.uint32(e)._push(Ss,e,t):this._push(_s,1,0)}fork(){return this.states=new Ls(this),this.head=this.tail=new Ke(Bs,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 Ke(Bs,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=uh(this.len),n=0;for(;t!=null;)t.fn(t.val,e,n),n+=t.len,t=t.next;return e}};function _s(r,t,e){t[e]=r&255}function fh(r,t,e){for(;r>127;)t[e++]=r&127|128,r>>>=7;t[e]=r}var Ts=class extends Ke{next;constructor(t,e){super(fh,t,e),this.next=void 0}};function Ln(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 Nr(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 lh(r,t,e){t.set(r,e)}globalThis.Buffer!=null&&(Mr.prototype.bytes=function(r){let t=r.length>>>0;return this.uint32(t),t>0&&this._push(hh,t,r),this},Mr.prototype.string=function(r){let t=globalThis.Buffer.byteLength(r);return this.uint32(t),t>0&&this._push(dh,t,r),this});function hh(r,t,e){t.set(r,e)}function dh(r,t,e){r.length<40?Ss(r,t,e):t.utf8Write!=null?t.utf8Write(r,e):t.set(Q(r),e)}function Cs(){return new Mr}function Ne(r,t){let e=Cs();return t.encode(r,e,{lengthDelimited:!1}),e.finish()}var rr;(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"})(rr||(rr={}));function Tn(r,t,e,n){return{name:r,type:t,encode:e,decode:n}}function Ps(r){function t(o){if(r[o.toString()]==null)throw new Error("Invalid enum value");return r[o]}let e=function(s,i){let a=t(s);i.int32(a)},n=function(s){let i=s.int32();return t(i)};return Tn("enum",rr.VARINT,e,n)}function Me(r,t){return Tn("message",rr.LENGTH_DELIMITED,r,t)}var Or=class extends Error{code="ERR_MAX_LENGTH";name="MaxLengthError"};var ft;(function(r){r.RSA="RSA",r.Ed25519="Ed25519",r.secp256k1="secp256k1",r.ECDSA="ECDSA"})(ft||(ft={}));var Us;(function(r){r[r.RSA=0]="RSA",r[r.Ed25519=1]="Ed25519",r[r.secp256k1=2]="secp256k1",r[r.ECDSA=3]="ECDSA"})(Us||(Us={}));(function(r){r.codec=()=>Ps(Us)})(ft||(ft={}));var Jt;(function(r){let t;r.codec=()=>(t==null&&(t=Me((e,n,o={})=>{o.lengthDelimited!==!1&&n.fork(),e.Type!=null&&(n.uint32(8),ft.codec().encode(e.Type,n)),e.Data!=null&&(n.uint32(18),n.bytes(e.Data)),o.lengthDelimited!==!1&&n.ldelim()},(e,n,o={})=>{let s={},i=n==null?e.len:e.pos+n;for(;e.pos<i;){let a=e.uint32();switch(a>>>3){case 1:{s.Type=ft.codec().decode(e);break}case 2:{s.Data=e.bytes();break}default:{e.skipType(a&7);break}}}return s})),t),r.encode=e=>Ne(e,r.codec()),r.decode=(e,n)=>De(e,r.codec(),n)})(Jt||(Jt={}));var ks;(function(r){let t;r.codec=()=>(t==null&&(t=Me((e,n,o={})=>{o.lengthDelimited!==!1&&n.fork(),e.Type!=null&&(n.uint32(8),ft.codec().encode(e.Type,n)),e.Data!=null&&(n.uint32(18),n.bytes(e.Data)),o.lengthDelimited!==!1&&n.ldelim()},(e,n,o={})=>{let s={},i=n==null?e.len:e.pos+n;for(;e.pos<i;){let a=e.uint32();switch(a>>>3){case 1:{s.Type=ft.codec().decode(e);break}case 2:{s.Data=e.bytes();break}default:{e.skipType(a&7);break}}}return s})),t),r.encode=e=>Ne(e,r.codec()),r.decode=(e,n)=>De(e,r.codec(),n)})(ks||(ks={}));var Vr={};Tt(Vr,{MAX_RSA_KEY_SIZE:()=>Rs,generateRSAKeyPair:()=>Ec,jwkToJWKKeyPair:()=>Sc,jwkToPkcs1:()=>gh,jwkToPkix:()=>Ms,jwkToRSAPrivateKey:()=>qs,pkcs1MessageToJwk:()=>Ks,pkcs1MessageToRSAPrivateKey:()=>Os,pkcs1ToJwk:()=>yh,pkcs1ToRSAPrivateKey:()=>bc,pkixMessageToJwk:()=>Ns,pkixMessageToRSAPublicKey:()=>Vs,pkixToJwk:()=>wh,pkixToRSAPublicKey:()=>Hs});var Ae=gn;var nr=class{type="RSA";jwk;_raw;_multihash;constructor(t,e){this.jwk=t,this._multihash=e}get raw(){return this._raw==null&&(this._raw=Vr.jwkToPkix(this.jwk)),this._raw}toMultihash(){return this._multihash}toCID(){return ut.createV1(114,this._multihash)}toString(){return nt.encode(this.toMultihash().bytes).substring(1)}equals(t){return t==null||!(t.raw instanceof Uint8Array)?!1:ht(this.raw,t.raw)}verify(t,e,n){return xc(this.jwk,e,t,n)}},Hr=class{type="RSA";jwk;_raw;publicKey;constructor(t,e){this.jwk=t,this.publicKey=e}get raw(){return this._raw==null&&(this._raw=Vr.jwkToPkcs1(this.jwk)),this._raw}equals(t){return t==null||!(t.raw instanceof Uint8Array)?!1:ht(this.raw,t.raw)}sign(t,e){return wc(this.jwk,t,e)}};var Rs=8192,Ds=18,ph=1062,mh=Uint8Array.from([48,13,6,9,42,134,72,134,247,13,1,1,1,5,0]);function yh(r){let t=ee(r);return Ks(t)}function Ks(r){return{n:V(r[1],"base64url"),e:V(r[2],"base64url"),d:V(r[3],"base64url"),p:V(r[4],"base64url"),q:V(r[5],"base64url"),dp:V(r[6],"base64url"),dq:V(r[7],"base64url"),qi:V(r[8],"base64url"),kty:"RSA"}}function gh(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 at("JWK was missing components");return de([Rt(Uint8Array.from([0])),Rt(Q(r.n,"base64url")),Rt(Q(r.e,"base64url")),Rt(Q(r.d,"base64url")),Rt(Q(r.p,"base64url")),Rt(Q(r.q,"base64url")),Rt(Q(r.dp,"base64url")),Rt(Q(r.dq,"base64url")),Rt(Q(r.qi,"base64url"))]).subarray()}function wh(r){let t=ee(r,{offset:0});return Ns(t)}function Ns(r){let t=ee(r[1],{offset:0});return{kty:"RSA",n:V(t[0],"base64url"),e:V(t[1],"base64url")}}function Ms(r){if(r.n==null||r.e==null)throw new at("JWK was missing components");return de([mh,dn(de([Rt(Q(r.n,"base64url")),Rt(Q(r.e,"base64url"))]))]).subarray()}function bc(r){let t=ee(r);return Os(t)}function Os(r){let t=Ks(r);return qs(t)}function Hs(r,t){if(r.byteLength>=ph)throw new Fe("Key size is too large");let e=ee(r,{offset:0});return Vs(e,r,t)}function Vs(r,t,e){let n=Ns(r);if(e==null){let o=Ae(Jt.encode({Type:ft.RSA,Data:t}));e=Nt(Ds,o)}return new nr(n,e)}function qs(r){if(vc(r)>Rs)throw new at("Key size is too large");let t=Sc(r),e=Ae(Jt.encode({Type:ft.RSA,Data:Ms(t.publicKey)})),n=Nt(Ds,e);return new Hr(t.privateKey,new nr(t.publicKey,n))}async function Ec(r){if(r>Rs)throw new at("Key size is too large");let t=await Ac(r),e=Ae(Jt.encode({Type:ft.RSA,Data:Ms(t.publicKey)})),n=Nt(Ds,e);return new Hr(t.privateKey,new nr(t.publicKey,n))}function Sc(r){if(r==null)throw new at("Missing key parameter");return{privateKey:r,publicKey:{kty:r.kty,n:r.n,e:r.e}}}async function Ac(r,t){let e=await Mt.get().subtle.generateKey({name:"RSASSA-PKCS1-v1_5",modulusLength:r,publicExponent:new Uint8Array([1,0,1]),hash:{name:"SHA-256"}},!0,["sign","verify"]);t?.signal?.throwIfAborted();let n=await xh(e,t);return{privateKey:n[0],publicKey:n[1]}}async function wc(r,t,e){let n=await Mt.get().subtle.importKey("jwk",r,{name:"RSASSA-PKCS1-v1_5",hash:{name:"SHA-256"}},!1,["sign"]);e?.signal?.throwIfAborted();let o=await Mt.get().subtle.sign({name:"RSASSA-PKCS1-v1_5"},n,t instanceof Uint8Array?t:t.subarray());return e?.signal?.throwIfAborted(),new Uint8Array(o,0,o.byteLength)}async function xc(r,t,e,n){let o=await Mt.get().subtle.importKey("jwk",r,{name:"RSASSA-PKCS1-v1_5",hash:{name:"SHA-256"}},!1,["verify"]);n?.signal?.throwIfAborted();let s=await Mt.get().subtle.verify({name:"RSASSA-PKCS1-v1_5"},o,t,e instanceof Uint8Array?e:e.subarray());return n?.signal?.throwIfAborted(),s}async function xh(r,t){if(r.privateKey==null||r.publicKey==null)throw new at("Private and public key are required");let e=await Promise.all([Mt.get().subtle.exportKey("jwk",r.privateKey),Mt.get().subtle.exportKey("jwk",r.publicKey)]);return t?.signal?.throwIfAborted(),e}function vc(r){if(r.kty!=="RSA")throw new at("invalid key type");if(r.n==null)throw new at("invalid key modulus");return Q(r.n,"base64url").length*8}var Cn=class extends Ye{constructor(t,e){super(),this.finished=!1,this.destroyed=!1,vr(t);let n=me(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 o=this.blockLen,s=new Uint8Array(o);s.set(n.length>o?t.create().update(n).digest():n);for(let i=0;i<s.length;i++)s[i]^=54;this.iHash.update(s),this.oHash=t.create();for(let i=0;i<s.length;i++)s[i]^=106;this.oHash.update(s),Vt(s)}update(t){return Xe(this),this.iHash.update(t),this}digestInto(t){Xe(this),Le(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:o,destroyed:s,blockLen:i,outputLen:a}=this;return t=t,t.finished=o,t.destroyed=s,t.blockLen=i,t.outputLen=a,t.oHash=e._cloneInto(t.oHash),t.iHash=n._cloneInto(t.iHash),t}clone(){return this._cloneInto()}destroy(){this.destroyed=!0,this.oHash.destroy(),this.iHash.destroy()}},or=(r,t,e)=>new Cn(r,t).update(e).digest();or.create=(r,t)=>new Cn(r,t);function Ic(r){r.lowS!==void 0&&$t("lowS",r.lowS),r.prehash!==void 0&&$t("prehash",r.prehash)}function bh(r){let t=Pr(r);zt(t,{a:"field",b:"field"},{allowInfinityPoint:"boolean",allowedPrivateKeyLengths:"array",clearCofactor:"function",fromBytes:"function",isTorsionFree:"function",toBytes:"function",wrapPrivateKey:"boolean"});let{endo:e,Fp:n,a:o}=t;if(e){if(!n.eql(o,n.ZERO))throw new Error("invalid endo: CURVE.a must be 0");if(typeof e!="object"||typeof e.beta!="bigint"||typeof e.splitScalar!="function")throw new Error('invalid endo: expected "beta": bigint and "splitScalar": function')}return Object.freeze({...t})}var Gs=class extends Error{constructor(t=""){super(t)}},ie={Err:Gs,_tlv:{encode:(r,t)=>{let{Err:e}=ie;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,o=Tr(n);if(o.length/2&128)throw new e("tlv.encode: long form length too big");let s=n>127?Tr(o.length/2|128):"";return Tr(r)+s+o+t},decode(r,t){let{Err:e}=ie,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 o=t[n++],s=!!(o&128),i=0;if(!s)i=o;else{let c=o&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 f=t.subarray(n,n+c);if(f.length!==c)throw new e("tlv.decode: length bytes not complete");if(f[0]===0)throw new e("tlv.decode(long): zero leftmost byte");for(let u of f)i=i<<8|u;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}=ie;if(r<ae)throw new t("integer: negative integers are not allowed");let e=Tr(r);if(Number.parseInt(e[0],16)&8&&(e="00"+e),e.length&1)throw new t("unexpected DER parsing assertion: unpadded hex");return e},decode(r){let{Err:t}=ie;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 oe(r)}},toSig(r){let{Err:t,_int:e,_tlv:n}=ie,o=ot("signature",r),{v:s,l:i}=n.decode(48,o);if(i.length)throw new t("invalid signature: left bytes after parsing");let{v:a,l:c}=n.decode(2,s),{v:f,l:u}=n.decode(2,c);if(u.length)throw new t("invalid signature: left bytes after parsing");return{r:e.decode(a),s:e.decode(f)}},hexFromSig(r){let{_tlv:t,_int:e}=ie,n=t.encode(2,e.encode(r.r)),o=t.encode(2,e.encode(r.s)),s=n+o;return t.encode(48,s)}};function zs(r,t){return xe(Pe(r,t))}var ae=BigInt(0),gt=BigInt(1),Zy=BigInt(2),Fs=BigInt(3),Eh=BigInt(4);function Sh(r){let t=bh(r),{Fp:e}=t,n=se(t.n,t.nBitLength),o=t.toBytes||((S,d,I)=>{let U=d.toAffine();return Ee(Uint8Array.from([4]),e.toBytes(U.x),e.toBytes(U.y))}),s=t.fromBytes||(S=>{let d=S.subarray(1),I=e.fromBytes(d.subarray(0,e.BYTES)),U=e.fromBytes(d.subarray(e.BYTES,2*e.BYTES));return{x:I,y:U}});function i(S){let{a:d,b:I}=t,U=e.sqr(S),B=e.mul(U,S);return e.add(e.add(B,e.mul(S,d)),I)}function a(S,d){let I=e.sqr(d),U=i(S);return e.eql(I,U)}if(!a(t.Gx,t.Gy))throw new Error("bad curve params: generator point");let c=e.mul(e.pow(t.a,Fs),Eh),f=e.mul(e.sqr(t.b),BigInt(27));if(e.is0(e.add(c,f)))throw new Error("bad curve params: a or b");function u(S){return wn(S,gt,t.n)}function l(S){let{allowedPrivateKeyLengths:d,nByteLength:I,wrapPrivateKey:U,n:B}=t;if(d&&typeof S!="bigint"){if(Je(S)&&(S=xe(S)),typeof S!="string"||!d.includes(S.length))throw new Error("invalid private key");S=S.padStart(I*2,"0")}let L;try{L=typeof S=="bigint"?S:oe(ot("private key",S,I))}catch{throw new Error("invalid private key, expected hex or "+I+" bytes, got "+typeof S)}return U&&(L=Y(L,B)),vt("private key",L,gt,B),L}function p(S){if(!(S instanceof m))throw new Error("ProjectivePoint expected")}let x=Qe((S,d)=>{let{px:I,py:U,pz:B}=S;if(e.eql(B,e.ONE))return{x:I,y:U};let L=S.is0();d==null&&(d=L?e.ONE:e.inv(B));let k=e.mul(I,d),K=e.mul(U,d),T=e.mul(B,d);if(L)return{x:e.ZERO,y:e.ZERO};if(!e.eql(T,e.ONE))throw new Error("invZ was invalid");return{x:k,y:K}}),y=Qe(S=>{if(S.is0()){if(t.allowInfinityPoint&&!e.is0(S.py))return;throw new Error("bad point: ZERO")}let{x:d,y:I}=S.toAffine();if(!e.isValid(d)||!e.isValid(I))throw new Error("bad point: x or y not FE");if(!a(d,I))throw new Error("bad point: equation left != right");if(!S.isTorsionFree())throw new Error("bad point: not in prime-order subgroup");return!0});class m{constructor(d,I,U){if(d==null||!e.isValid(d))throw new Error("x required");if(I==null||!e.isValid(I)||e.is0(I))throw new Error("y required");if(U==null||!e.isValid(U))throw new Error("z required");this.px=d,this.py=I,this.pz=U,Object.freeze(this)}static fromAffine(d){let{x:I,y:U}=d||{};if(!d||!e.isValid(I)||!e.isValid(U))throw new Error("invalid affine point");if(d instanceof m)throw new Error("projective point not allowed");let B=L=>e.eql(L,e.ZERO);return B(I)&&B(U)?m.ZERO:new m(I,U,e.ONE)}get x(){return this.toAffine().x}get y(){return this.toAffine().y}static normalizeZ(d){let I=tr(e,d.map(U=>U.pz));return d.map((U,B)=>U.toAffine(I[B])).map(m.fromAffine)}static fromHex(d){let I=m.fromAffine(s(ot("pointHex",d)));return I.assertValidity(),I}static fromPrivateKey(d){return m.BASE.multiply(l(d))}static msm(d,I){return En(m,n,d,I)}_setWindowSize(d){M.setWindowSize(this,d)}assertValidity(){y(this)}hasEvenY(){let{y:d}=this.toAffine();if(e.isOdd)return!e.isOdd(d);throw new Error("Field doesn't support isOdd")}equals(d){p(d);let{px:I,py:U,pz:B}=this,{px:L,py:k,pz:K}=d,T=e.eql(e.mul(I,K),e.mul(L,B)),D=e.eql(e.mul(U,K),e.mul(k,B));return T&&D}negate(){return new m(this.px,e.neg(this.py),this.pz)}double(){let{a:d,b:I}=t,U=e.mul(I,Fs),{px:B,py:L,pz:k}=this,K=e.ZERO,T=e.ZERO,D=e.ZERO,C=e.mul(B,B),H=e.mul(L,L),E=e.mul(k,k),A=e.mul(B,L);return A=e.add(A,A),D=e.mul(B,k),D=e.add(D,D),K=e.mul(d,D),T=e.mul(U,E),T=e.add(K,T),K=e.sub(H,T),T=e.add(H,T),T=e.mul(K,T),K=e.mul(A,K),D=e.mul(U,D),E=e.mul(d,E),A=e.sub(C,E),A=e.mul(d,A),A=e.add(A,D),D=e.add(C,C),C=e.add(D,C),C=e.add(C,E),C=e.mul(C,A),T=e.add(T,C),E=e.mul(L,k),E=e.add(E,E),C=e.mul(E,A),K=e.sub(K,C),D=e.mul(E,H),D=e.add(D,D),D=e.add(D,D),new m(K,T,D)}add(d){p(d);let{px:I,py:U,pz:B}=this,{px:L,py:k,pz:K}=d,T=e.ZERO,D=e.ZERO,C=e.ZERO,H=t.a,E=e.mul(t.b,Fs),A=e.mul(I,L),P=e.mul(U,k),b=e.mul(B,K),h=e.add(I,U),g=e.add(L,k);h=e.mul(h,g),g=e.add(A,P),h=e.sub(h,g),g=e.add(I,B);let v=e.add(L,K);return g=e.mul(g,v),v=e.add(A,b),g=e.sub(g,v),v=e.add(U,B),T=e.add(k,K),v=e.mul(v,T),T=e.add(P,b),v=e.sub(v,T),C=e.mul(H,g),T=e.mul(E,b),C=e.add(T,C),T=e.sub(P,C),C=e.add(P,C),D=e.mul(T,C),P=e.add(A,A),P=e.add(P,A),b=e.mul(H,b),g=e.mul(E,g),P=e.add(P,b),b=e.sub(A,b),b=e.mul(H,b),g=e.add(g,b),A=e.mul(P,g),D=e.add(D,A),A=e.mul(v,g),T=e.mul(h,T),T=e.sub(T,A),A=e.mul(h,P),C=e.mul(v,C),C=e.add(C,A),new m(T,D,C)}subtract(d){return this.add(d.negate())}is0(){return this.equals(m.ZERO)}wNAF(d){return M.wNAFCached(this,d,m.normalizeZ)}multiplyUnsafe(d){let{endo:I,n:U}=t;vt("scalar",d,ae,U);let B=m.ZERO;if(d===ae)return B;if(this.is0()||d===gt)return this;if(!I||M.hasPrecomputes(this))return M.wNAFCachedUnsafe(this,d,m.normalizeZ);let{k1neg:L,k1:k,k2neg:K,k2:T}=I.splitScalar(d),D=B,C=B,H=this;for(;k>ae||T>ae;)k&gt&&(D=D.add(H)),T&gt&&(C=C.add(H)),H=H.double(),k>>=gt,T>>=gt;return L&&(D=D.negate()),K&&(C=C.negate()),C=new m(e.mul(C.px,I.beta),C.py,C.pz),D.add(C)}multiply(d){let{endo:I,n:U}=t;vt("scalar",d,gt,U);let B,L;if(I){let{k1neg:k,k1:K,k2neg:T,k2:D}=I.splitScalar(d),{p:C,f:H}=this.wNAF(K),{p:E,f:A}=this.wNAF(D);C=M.constTimeNegate(k,C),E=M.constTimeNegate(T,E),E=new m(e.mul(E.px,I.beta),E.py,E.pz),B=C.add(E),L=H.add(A)}else{let{p:k,f:K}=this.wNAF(d);B=k,L=K}return m.normalizeZ([B,L])[0]}multiplyAndAddUnsafe(d,I,U){let B=m.BASE,L=(K,T)=>T===ae||T===gt||!K.equals(B)?K.multiplyUnsafe(T):K.multiply(T),k=L(this,I).add(L(d,U));return k.is0()?void 0:k}toAffine(d){return x(this,d)}isTorsionFree(){let{h:d,isTorsionFree:I}=t;if(d===gt)return!0;if(I)return I(m,this);throw new Error("isTorsionFree() has not been declared for the elliptic curve")}clearCofactor(){let{h:d,clearCofactor:I}=t;return d===gt?this:I?I(m,this):this.multiplyUnsafe(t.h)}toRawBytes(d=!0){return $t("isCompressed",d),this.assertValidity(),o(m,this,d)}toHex(d=!0){return $t("isCompressed",d),xe(this.toRawBytes(d))}}m.BASE=new m(t.Gx,t.Gy,e.ONE),m.ZERO=new m(e.ZERO,e.ONE,e.ZERO);let{endo:w,nBitLength:_}=t,M=bn(m,w?Math.ceil(_/2):_);return{CURVE:t,ProjectivePoint:m,normPrivateKeyToScalar:l,weierstrassEquation:i,isWithinCurveOrder:u}}function Ah(r){let t=Pr(r);return zt(t,{hash:"hash",hmac:"function",randomBytes:"function"},{bits2int:"function",bits2int_modN:"function",lowS:"boolean"}),Object.freeze({lowS:!0,...t})}function Bc(r){let t=Ah(r),{Fp:e,n,nByteLength:o,nBitLength:s}=t,i=e.BYTES+1,a=2*e.BYTES+1;function c(E){return Y(E,n)}function f(E){return xn(E,n)}let{ProjectivePoint:u,normPrivateKeyToScalar:l,weierstrassEquation:p,isWithinCurveOrder:x}=Sh({...t,toBytes(E,A,P){let b=A.toAffine(),h=e.toBytes(b.x),g=Ee;return $t("isCompressed",P),P?g(Uint8Array.from([A.hasEvenY()?2:3]),h):g(Uint8Array.from([4]),h,e.toBytes(b.y))},fromBytes(E){let A=E.length,P=E[0],b=E.subarray(1);if(A===i&&(P===2||P===3)){let h=oe(b);if(!wn(h,gt,e.ORDER))throw new Error("Point is not on curve");let g=p(h),v;try{v=e.sqrt(g)}catch(q){let z=q instanceof Error?": "+q.message:"";throw new Error("Point is not on curve"+z)}let R=(v&gt)===gt;return(P&1)===1!==R&&(v=e.neg(v)),{x:h,y:v}}else if(A===a&&P===4){let h=e.fromBytes(b.subarray(0,e.BYTES)),g=e.fromBytes(b.subarray(e.BYTES,2*e.BYTES));return{x:h,y:g}}else{let h=i,g=a;throw new Error("invalid Point, expected length of "+h+", or uncompressed "+g+", got "+A)}}});function y(E){let A=n>>gt;return E>A}function m(E){return y(E)?c(-E):E}let w=(E,A,P)=>oe(E.slice(A,P));class _{constructor(A,P,b){vt("r",A,gt,n),vt("s",P,gt,n),this.r=A,this.s=P,b!=null&&(this.recovery=b),Object.freeze(this)}static fromCompact(A){let P=o;return A=ot("compactSignature",A,P*2),new _(w(A,0,P),w(A,P,2*P))}static fromDER(A){let{r:P,s:b}=ie.toSig(ot("DER",A));return new _(P,b)}assertValidity(){}addRecoveryBit(A){return new _(this.r,this.s,A)}recoverPublicKey(A){let{r:P,s:b,recovery:h}=this,g=B(ot("msgHash",A));if(h==null||![0,1,2,3].includes(h))throw new Error("recovery id invalid");let v=h===2||h===3?P+t.n:P;if(v>=e.ORDER)throw new Error("recovery id 2 or 3 invalid");let R=(h&1)===0?"02":"03",O=u.fromHex(R+zs(v,e.BYTES)),q=f(v),z=c(-g*q),F=c(b*q),G=u.BASE.multiplyAndAddUnsafe(O,z,F);if(!G)throw new Error("point at infinify");return G.assertValidity(),G}hasHighS(){return y(this.s)}normalizeS(){return this.hasHighS()?new _(this.r,c(-this.s),this.recovery):this}toDERRawBytes(){return Cr(this.toDERHex())}toDERHex(){return ie.hexFromSig(this)}toCompactRawBytes(){return Cr(this.toCompactHex())}toCompactHex(){let A=o;return zs(this.r,A)+zs(this.s,A)}}let M={isValidPrivateKey(E){try{return l(E),!0}catch{return!1}},normPrivateKeyToScalar:l,randomPrivateKey:()=>{let E=ss(t.n);return Wa(t.randomBytes(E),t.n)},precompute(E=8,A=u.BASE){return A._setWindowSize(E),A.multiply(BigInt(3)),A}};function S(E,A=!0){return u.fromPrivateKey(E).toRawBytes(A)}function d(E){if(typeof E=="bigint")return!1;if(E instanceof u)return!0;let P=ot("key",E).length,b=e.BYTES,h=b+1,g=2*b+1;if(!(t.allowedPrivateKeyLengths||o===h))return P===h||P===g}function I(E,A,P=!0){if(d(E)===!0)throw new Error("first arg must be private key");if(d(A)===!1)throw new Error("second arg must be public key");return u.fromHex(A).multiply(l(E)).toRawBytes(P)}let U=t.bits2int||function(E){if(E.length>8192)throw new Error("input is too large");let A=oe(E),P=E.length*8-s;return P>0?A>>BigInt(P):A},B=t.bits2int_modN||function(E){return c(U(E))},L=Ue(s);function k(E){return vt("num < 2^"+s,E,ae,L),Pe(E,o)}function K(E,A,P=T){if(["recovered","canonical"].some(Z=>Z in P))throw new Error("sign() legacy options not supported");let{hash:b,randomBytes:h}=t,{lowS:g,prehash:v,extraEntropy:R}=P;g==null&&(g=!0),E=ot("msgHash",E),Ic(P),v&&(E=ot("prehashed msgHash",b(E)));let O=B(E),q=l(A),z=[k(q),k(O)];if(R!=null&&R!==!1){let Z=R===!0?h(e.BYTES):R;z.push(ot("extraEntropy",Z))}let F=Ee(...z),G=O;function J(Z){let xt=U(Z);if(!x(xt))return;let kt=f(xt),mt=u.BASE.multiply(xt).toAffine(),St=c(mt.x);if(St===ae)return;let Dt=c(kt*c(G+St*q));if(Dt===ae)return;let Ot=(mt.x===St?0:2)|Number(mt.y&gt),yr=Dt;return g&&y(Dt)&&(yr=m(Dt),Ot^=1),new _(St,yr,Ot)}return{seed:F,k2sig:J}}let T={lowS:t.lowS,prehash:!1},D={lowS:t.lowS,prehash:!1};function C(E,A,P=T){let{seed:b,k2sig:h}=K(E,A,P),g=t;return Ma(g.hash.outputLen,g.nByteLength,g.hmac)(b,h)}u.BASE._setWindowSize(8);function H(E,A,P,b=D){let h=E;A=ot("msgHash",A),P=ot("publicKey",P);let{lowS:g,prehash:v,format:R}=b;if(Ic(b),"strict"in b)throw new Error("options.strict was renamed to lowS");if(R!==void 0&&R!=="compact"&&R!=="der")throw new Error("format must be compact or der");let O=typeof h=="string"||Je(h),q=!O&&!R&&typeof h=="object"&&h!==null&&typeof h.r=="bigint"&&typeof h.s=="bigint";if(!O&&!q)throw new Error("invalid signature, expected Uint8Array, hex string or Signature instance");let z,F;try{if(q&&(z=new _(h.r,h.s)),O){try{R!=="compact"&&(z=_.fromDER(h))}catch(Ot){if(!(Ot instanceof ie.Err))throw Ot}!z&&R!=="der"&&(z=_.fromCompact(h))}F=u.fromHex(P)}catch{return!1}if(!z||g&&z.hasHighS())return!1;v&&(A=t.hash(A));let{r:G,s:J}=z,Z=B(A),xt=f(J),kt=c(Z*xt),mt=c(G*xt),St=u.BASE.multiplyAndAddUnsafe(F,kt,mt)?.toAffine();return St?c(St.x)===G:!1}return{CURVE:t,getPublicKey:S,getSharedSecret:I,sign:C,verify:H,ProjectivePoint:u,Signature:_,utils:M}}function vh(r){return{hash:r,hmac:(t,...e)=>or(r,t,jo(...e)),randomBytes:Ir}}function _c(r,t){let e=n=>Bc({...r,...vh(n)});return{...e(t),create:e}}var Cc=BigInt("0xfffffffffffffffffffffffffffffffffffffffffffffffffffffffefffffc2f"),Lc=BigInt("0xfffffffffffffffffffffffffffffffebaaedce6af48a03bbfd25e8cd0364141"),Ih=BigInt(0),Bh=BigInt(1),Ws=BigInt(2),Tc=(r,t)=>(r+t/Ws)/t;function _h(r){let t=Cc,e=BigInt(3),n=BigInt(6),o=BigInt(11),s=BigInt(22),i=BigInt(23),a=BigInt(44),c=BigInt(88),f=r*r*r%t,u=f*f*r%t,l=st(u,e,t)*u%t,p=st(l,e,t)*u%t,x=st(p,Ws,t)*f%t,y=st(x,o,t)*x%t,m=st(y,s,t)*y%t,w=st(m,a,t)*m%t,_=st(w,c,t)*w%t,M=st(_,a,t)*m%t,S=st(M,e,t)*u%t,d=st(S,i,t)*y%t,I=st(d,n,t)*f%t,U=st(I,Ws,t);if(!js.eql(js.sqr(U),r))throw new Error("Cannot find square root");return U}var js=se(Cc,void 0,void 0,{sqrt:_h}),sr=_c({a:Ih,b:BigInt(7),Fp:js,n:Lc,Gx:BigInt("55066263022277343669578718895168534326250603453777594175500187360389116729240"),Gy:BigInt("32670510020758816978083085130507043184471273380659243275938904335757337482424"),h:BigInt(1),lowS:!0,endo:{beta:BigInt("0x7ae96a2b657c07106e64479eac3434e99cf0497512f58995c1396c28719501ee"),splitScalar:r=>{let t=Lc,e=BigInt("0x3086d221a7d46bcde86c90e49284eb15"),n=-Bh*BigInt("0xe4437ed6010e88286f547fa90abfe4c3"),o=BigInt("0x114ca50f7a8e2f3f657c1108d9d44cfd8"),s=e,i=BigInt("0x100000000000000000000000000000000"),a=Tc(s*r,t),c=Tc(-n*r,t),f=Y(r-a*e-c*o,t),u=Y(-a*n-c*s,t),l=f>i,p=u>i;if(l&&(f=t-f),p&&(u=t-u),f>i||u>i)throw new Error("splitScalar: Endomorphism failed, k="+r);return{k1neg:l,k1:f,k2neg:p,k2:u}}}},gn);function Pc(r,t,e,n){let o=Er.digest(e instanceof Uint8Array?e:e.subarray());if(In(o))return o.then(({digest:s})=>(n?.signal?.throwIfAborted(),sr.verify(t,s,r))).catch(s=>{throw s.name==="AbortError"?s:new Dr(String(s))});try{return n?.signal?.throwIfAborted(),sr.verify(t,o.digest,r)}catch(s){throw new Dr(String(s))}}var Pn=class{type="secp256k1";raw;_key;constructor(t){this._key=kc(t),this.raw=Uc(this._key)}toMultihash(){return Ht.digest(pe(this))}toCID(){return ut.createV1(114,this.toMultihash())}toString(){return nt.encode(this.toMultihash().bytes).substring(1)}equals(t){return t==null||!(t.raw instanceof Uint8Array)?!1:ht(this.raw,t.raw)}verify(t,e,n){return Pc(this._key,e,t,n)}};function $s(r){return new Pn(r)}function Uc(r){return sr.ProjectivePoint.fromHex(r).toRawBytes(!0)}function kc(r){try{return sr.ProjectivePoint.fromHex(r),r}catch(t){throw new Fe(String(t))}}function qr(r,t){let{Type:e,Data:n}=Jt.decode(r),o=n??new Uint8Array;switch(e){case ft.RSA:return Hs(o,t);case ft.Ed25519:return ds(o);case ft.secp256k1:return $s(o);case ft.ECDSA:return Wo(o);default:throw new ve}}function Rc(r){let{Type:t,Data:e}=Jt.decode(r.digest),n=e??new Uint8Array;switch(t){case ft.Ed25519:return ds(n);case ft.secp256k1:return $s(n);case ft.ECDSA:return Wo(n);default:throw new ve}}function pe(r){return Jt.encode({Type:ft[r.type],Data:r.raw})}var Dc=Symbol.for("nodejs.util.inspect.custom"),Lh=114,zr=class{type;multihash;publicKey;string;constructor(t){this.type=t.type,this.multihash=t.multihash,Object.defineProperty(this,"string",{enumerable:!1,writable:!0})}get[Symbol.toStringTag](){return`PeerId(${this.toString()})`}[go]=!0;toString(){return this.string==null&&(this.string=nt.encode(this.multihash.bytes).slice(1)),this.string}toMultihash(){return this.multihash}toCID(){return ut.createV1(Lh,this.multihash)}toJSON(){return this.toString()}equals(t){if(t==null)return!1;if(t instanceof Uint8Array)return ht(this.multihash.bytes,t);if(typeof t=="string")return this.toString()===t;if(t?.toMultihash()?.bytes!=null)return ht(this.multihash.bytes,t.toMultihash().bytes);throw new Error("not valid Id")}[Dc](){return`PeerId(${this.toString()})`}},Fr=class extends zr{type="RSA";publicKey;constructor(t){super({...t,type:"RSA"}),this.publicKey=t.publicKey}},Gr=class extends zr{type="Ed25519";publicKey;constructor(t){super({...t,type:"Ed25519"}),this.publicKey=t.publicKey}},Wr=class extends zr{type="secp256k1";publicKey;constructor(t){super({...t,type:"secp256k1"}),this.publicKey=t.publicKey}},Th=2336,jr=class{type="url";multihash;publicKey;url;constructor(t){this.url=t.toString(),this.multihash=Ht.digest(Q(this.url))}[Dc](){return`PeerId(${this.url})`}[go]=!0;toString(){return this.toCID().toString()}toMultihash(){return this.multihash}toCID(){return ut.createV1(Th,this.toMultihash())}toJSON(){return this.toString()}equals(t){return t==null?!1:(t instanceof Uint8Array&&(t=V(t)),t.toString()===this.toString())}};var Ch=114,Kc=2336;function Nc(r,t){let e;if(r.charAt(0)==="1"||r.charAt(0)==="Q")e=he(nt.decode(`z${r}`));else{if(r.startsWith("k51qzi5uqu5")||r.startsWith("kzwfwjn5ji4")||r.startsWith("k2k4r8")||r.startsWith("bafz"))return Ph(ut.parse(r));if(t==null)throw new at('Please pass a multibase decoder for strings that do not start with "1" or "Q"');e=he(t.decode(r))}return Mc(e)}function Zs(r){if(r.type==="Ed25519")return new Gr({multihash:r.toCID().multihash,publicKey:r});if(r.type==="secp256k1")return new Wr({multihash:r.toCID().multihash,publicKey:r});if(r.type==="RSA")return new Fr({multihash:r.toCID().multihash,publicKey:r});throw new ve}function Mc(r){if(kh(r))return new Fr({multihash:r});if(Uh(r))try{let t=Rc(r);if(t.type==="Ed25519")return new Gr({multihash:r,publicKey:t});if(t.type==="secp256k1")return new Wr({multihash:r,publicKey:t})}catch{let e=V(r.digest);return new jr(new URL(e))}throw new cn("Supplied PeerID Multihash is invalid")}function Ph(r){if(r?.multihash==null||r.version==null||r.version===1&&r.code!==Ch&&r.code!==Kc)throw new an("Supplied PeerID CID is invalid");if(r.code===Kc){let t=V(r.multihash.digest);return new jr(new URL(t))}return Mc(r.multihash)}function Uh(r){return r.code===Ht.code}function kh(r){return r.code===Er.code}var Un=class extends Error{name="InvalidMessageLengthError";code="ERR_INVALID_MSG_LENGTH"},ir=class extends Error{name="InvalidDataLengthError";code="ERR_MSG_DATA_TOO_LONG"},kn=class extends Error{name="InvalidDataLengthLengthError";code="ERR_MSG_LENGTH_TOO_LONG"},$r=class extends Error{name="UnexpectedEOFError";code="ERR_UNEXPECTED_EOF"};function Rn(r){return r[Symbol.asyncIterator]!=null}function Oc(r,t){if(r.byteLength>t)throw new ir("Message length too long")}var Kn=r=>{let t=lt(r),e=pt(t);return Xt(r,e),Kn.bytes=t,e};Kn.bytes=0;function Hc(r,t){t=t??{};let e=t.lengthEncoder??Kn,n=t?.maxDataLength??4194304;function*o(s){Oc(s,n);let i=e(s.byteLength);i instanceof Uint8Array?yield i:yield*i,s instanceof Uint8Array?yield s:yield*s}return Rn(r)?async function*(){for await(let s of r)yield*o(s)}():function*(){for(let s of r)yield*o(s)}()}Hc.single=(r,t)=>{t=t??{};let e=t.lengthEncoder??Kn,n=t?.maxDataLength??4194304;return Oc(r,n),new $(e(r.byteLength),r)};var Oe;(function(r){r[r.LENGTH=0]="LENGTH",r[r.DATA=1]="DATA"})(Oe||(Oe={}));var Ys=r=>{let t=Ft(r);return Ys.bytes=lt(t),t};Ys.bytes=0;function Zr(r,t){let e=new $,n=Oe.LENGTH,o=-1,s=t?.lengthDecoder??Ys,i=t?.maxLengthLength??8,a=t?.maxDataLength??4194304;function*c(){for(;e.byteLength>0;){if(n===Oe.LENGTH)try{if(o=s(e),o<0)throw new Un("Invalid message length");if(o>a)throw new ir("Message length too long");let f=s.bytes;e.consume(f),t?.onLength!=null&&t.onLength(o),n=Oe.DATA}catch(f){if(f instanceof RangeError){if(e.byteLength>i)throw new kn("Message length length too long");break}throw f}if(n===Oe.DATA){if(e.byteLength<o)break;let f=e.sublist(0,o);e.consume(o),t?.onData!=null&&t.onData(f),yield f,n=Oe.LENGTH}}}return Rn(r)?async function*(){for await(let f of r)e.append(f),yield*c();if(e.byteLength>0)throw new $r("Unexpected end of input")}():function*(){for(let f of r)e.append(f),yield*c();if(e.byteLength>0)throw new $r("Unexpected end of input")}()}Zr.fromReader=(r,t)=>{let e=1,n=async function*(){for(;;)try{let{done:s,value:i}=await r.next(e);if(s===!0)return;i!=null&&(yield i)}catch(s){if(s.code==="ERR_UNDER_READ")return{done:!0,value:null};throw s}finally{e=1}}();return Zr(n,{...t??{},onLength:s=>{e=s}})};function Ut(){let r={};return r.promise=new Promise((t,e)=>{r.resolve=t,r.reject=e}),r}var Nn=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 wt(r,t,e){if(t==null)return r;if(t.aborted)return r.catch(()=>{}),Promise.reject(new Nn(e?.errorMessage,e?.errorCode,e?.errorName));let n,o=new Nn(e?.errorMessage,e?.errorCode,e?.errorName);try{return await Promise.race([r,new Promise((s,i)=>{n=()=>{i(o)},t.addEventListener("abort",n)})])}finally{n!=null&&t.removeEventListener("abort",n)}}var Xs=class{readNext;haveNext;ended;nextResult;error;constructor(){this.ended=!1,this.readNext=Ut(),this.haveNext=Ut()}[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=Ut(),t}async throw(t){return this.ended=!0,this.error=t,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 this.ended=!0,this.nextResult=t,this.haveNext.resolve(),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 this.error??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=Ut(),await wt(this.readNext.promise,e?.signal,e)}};function Mn(){return new Xs}var On=class extends Error{name="UnexpectedEOFError";code="ERR_UNEXPECTED_EOF"};function Vc(r,t){let e=Mn();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 o=new $;return{read:async i=>{if(i?.signal?.throwIfAborted(),i?.bytes==null){let{done:c,value:f}=await wt(n.next(),i?.signal);return c===!0?null:f}for(;o.byteLength<i.bytes;){let{value:c,done:f}=await wt(n.next(),i?.signal);if(f===!0)throw new On("unexpected end of input");o.append(c)}let a=o.sublist(0,i.bytes);return o.consume(i.bytes),a},write:async(i,a)=>{a?.signal?.throwIfAborted(),i instanceof Uint8Array?await e.push(i,a):await e.push(i.subarray(),a)},unwrap:()=>{if(o.byteLength>0){let i=r.source;r.source=async function*(){t?.yieldBytes===!1?yield o:yield*o,yield*i}()}return r}}}var Hn=class extends Error{name="InvalidMessageLengthError";code="ERR_INVALID_MSG_LENGTH"},Vn=class extends Error{name="InvalidDataLengthError";code="ERR_MSG_DATA_TOO_LONG"},qn=class extends Error{name="InvalidDataLengthLengthError";code="ERR_MSG_LENGTH_TOO_LONG"};function Js(r,t={}){let e=Vc(r,t);t.maxDataLength!=null&&t.maxLengthLength==null&&(t.maxLengthLength=lt(t.maxDataLength));let n=t?.lengthDecoder??Ft,o=t?.lengthEncoder??Xt;return{read:async i=>{let a=-1,c=new $;for(;;){c.append(await e.read({...i,bytes:1}));try{a=n(c)}catch(f){if(f instanceof RangeError)continue;throw f}if(a<0)throw new Hn("Invalid message length");if(t?.maxLengthLength!=null&&c.byteLength>t.maxLengthLength)throw new qn("message length length too long");if(a>-1)break}if(t?.maxDataLength!=null&&a>t.maxDataLength)throw new Vn("message length too long");return e.read({...i,bytes:a})},write:async(i,a)=>{await e.write(new $(o(i.byteLength),i),a)},writeV:async(i,a)=>{let c=new $(...i.flatMap(f=>[o(f.byteLength),f]));await e.write(c,a)},unwrap:()=>e.unwrap()}}function Qs(){let r=Ut(),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 qc(){let r=Qs(),t=Qs();return[{source:r.source,sink:t.sink},{source:t.source,sink:r.sink}]}var zn=class{buffer;mask;top;btm;next;constructor(t){if(!(t>0)||(t-1&t)!==0)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}},ar=class{size;hwm;head;tail;constructor(t={}){this.hwm=t.splitLimit??16,this.head=new zn(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 zn(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 ti=class extends Error{type;code;constructor(t,e){super(t??"The operation was aborted"),this.type="aborted",this.code=e??"ABORT_ERR"}};function Fn(r={}){return Dh(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 Dh(r,t){t=t??{};let e=t.onEnd,n=new ar,o,s,i,a=Ut(),c=async()=>{try{return n.isEmpty()?i?{done:!0}:await new Promise((w,_)=>{s=M=>{s=null,n.push(M);try{w(r(n))}catch(S){_(S)}return o}}):r(n)}finally{n.isEmpty()&&queueMicrotask(()=>{a.resolve(),a=Ut()})}},f=w=>s!=null?s(w):(n.push(w),o),u=w=>(n=new ar,s!=null?s({error:w}):(n.push({error:w}),o)),l=w=>{if(i)return o;if(t?.objectMode!==!0&&w?.byteLength==null)throw new Error("objectMode was not true but tried to push non-Uint8Array value");return f({done:!1,value:w})},p=w=>i?o:(i=!0,w!=null?u(w):f({done:!0})),x=()=>(n=new ar,p(),{done:!0}),y=w=>(p(w),{done:!0});if(o={[Symbol.asyncIterator](){return this},next:c,return:x,throw:y,push:l,end:p,get readableLength(){return n.size},onEmpty:async w=>{let _=w?.signal;if(_?.throwIfAborted(),n.isEmpty())return;let M,S;_!=null&&(M=new Promise((d,I)=>{S=()=>{I(new ti)},_.addEventListener("abort",S)}));try{await Promise.race([a.promise,M])}finally{S!=null&&_!=null&&_?.removeEventListener("abort",S)}}},e==null)return o;let m=o;return o={[Symbol.asyncIterator](){return this},next(){return m.next()},throw(w){return m.throw(w),e!=null&&(e(w),e=void 0),{done:!0}},return(){return m.return(),e!=null&&(e(),e=void 0),{done:!0}},push:l,end(w){return m.end(w),e!=null&&(e(w),e=void 0),o},get readableLength(){return m.readableLength},onEmpty:w=>m.onEmpty(w)},o}function Kh(r){return r[Symbol.asyncIterator]!=null}async function Nh(r,t,e){try{await Promise.all(r.map(async n=>{for await(let o of n)await t.push(o,{signal:e}),e.throwIfAborted()})),await t.end(void 0,{signal:e})}catch(n){await t.end(n,{signal:e}).catch(()=>{})}}async function*Mh(r){let t=new AbortController,e=Mn();Nh(r,e,t.signal).catch(()=>{});try{yield*e}finally{t.abort()}}function*Oh(r){for(let t of r)yield*t}function Hh(...r){let t=[];for(let e of r)Kh(e)||t.push(e);return t.length===r.length?Oh(t):Mh(r)}var zc=Hh;function Fc(r,...t){if(r==null)throw new Error("Empty pipeline");if(ei(r)){let n=r;r=()=>n.source}else if(Wc(r)||Gc(r)){let n=r;r=()=>n}let e=[r,...t];if(e.length>1&&ei(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++)ei(e[n])&&(e[n]=qh(e[n]));return Vh(...e)}var Vh=(...r)=>{let t;for(;r.length>0;)t=r.shift()(t);return t},Gc=r=>r?.[Symbol.asyncIterator]!=null,Wc=r=>r?.[Symbol.iterator]!=null,ei=r=>r==null?!1:r.sink!=null&&r.source!=null,qh=r=>t=>{let e=r.sink(t);if(e?.then!=null){let n=Fn({objectMode:!0});e.then(()=>{n.end()},i=>{n.end(i)});let o,s=r.source;if(Gc(s))o=async function*(){yield*s,n.end()};else if(Wc(s))o=function*(){yield*s,n.end()};else throw new Error("Unknown duplex source type - must be Iterable or AsyncIterable");return zc(n,o())}return r.source};var cr=!!globalThis.process?.env?.DUMP_SESSION_KEYS;function $c(r){return r instanceof Uint8Array||ArrayBuffer.isView(r)&&r.constructor.name==="Uint8Array"}function Gn(r){if(typeof r!="boolean")throw new Error(`boolean expected, not ${r}`)}function Wn(r){if(!Number.isSafeInteger(r)||r<0)throw new Error("positive integer expected, got "+r)}function _t(r,...t){if(!$c(r))throw new Error("Uint8Array expected");if(t.length>0&&!t.includes(r.length))throw new Error("Uint8Array expected of length "+t+", got length="+r.length)}function ri(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 Zc(r,t){_t(r);let e=t.outputLen;if(r.length<e)throw new Error("digestInto() expects output buffer of length at least "+e)}function ce(r){return new Uint32Array(r.buffer,r.byteOffset,Math.floor(r.byteLength/4))}function ue(...r){for(let t=0;t<r.length;t++)r[t].fill(0)}function zh(r){return new DataView(r.buffer,r.byteOffset,r.byteLength)}var Fh=new Uint8Array(new Uint32Array([287454020]).buffer)[0]===68;function Gh(r){if(typeof r!="string")throw new Error("string expected");return new Uint8Array(new TextEncoder().encode(r))}function jn(r){if(typeof r=="string")r=Gh(r);else if($c(r))r=$n(r);else throw new Error("Uint8Array expected, got "+typeof r);return r}function Yc(r,t){if(t==null||typeof t!="object")throw new Error("options must be defined");return Object.assign(r,t)}function Xc(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 ni=(r,t)=>{function e(n,...o){if(_t(n),!Fh)throw new Error("Non little-endian hardware is not yet supported");if(r.nonceLength!==void 0){let u=o[0];if(!u)throw new Error("nonce / iv required");r.varSizeNonce?_t(u):_t(u,r.nonceLength)}let s=r.tagLength;s&&o[1]!==void 0&&_t(o[1]);let i=t(n,...o),a=(u,l)=>{if(l!==void 0){if(u!==2)throw new Error("cipher output not supported");_t(l)}},c=!1;return{encrypt(u,l){if(c)throw new Error("cannot encrypt() twice with same key + nonce");return c=!0,_t(u),a(i.encrypt.length,l),i.encrypt(u,l)},decrypt(u,l){if(_t(u),s&&u.length<s)throw new Error("invalid ciphertext length: smaller than tagLength="+s);return a(i.decrypt.length,l),i.decrypt(u,l)}}}return Object.assign(e,r),e};function oi(r,t,e=!0){if(t===void 0)return new Uint8Array(r);if(t.length!==r)throw new Error("invalid output length, expected "+r+", got: "+t.length);if(e&&!Wh(t))throw new Error("invalid output, must be aligned");return t}function jc(r,t,e,n){if(typeof r.setBigUint64=="function")return r.setBigUint64(t,e,n);let o=BigInt(32),s=BigInt(4294967295),i=Number(e>>o&s),a=Number(e&s),c=n?4:0,f=n?0:4;r.setUint32(t+c,i,n),r.setUint32(t+f,a,n)}function Jc(r,t,e){Gn(e);let n=new Uint8Array(16),o=zh(n);return jc(o,0,BigInt(t),e),jc(o,8,BigInt(r),e),n}function Wh(r){return r.byteOffset%4===0}function $n(r){return Uint8Array.from(r)}var tu=r=>Uint8Array.from(r.split("").map(t=>t.charCodeAt(0))),jh=tu("expand 16-byte k"),$h=tu("expand 32-byte k"),Zh=ce(jh),Yh=ce($h);function N(r,t){return r<<t|r>>>32-t}function si(r){return r.byteOffset%4===0}var Zn=64,Xh=16,eu=2**32-1,Qc=new Uint32Array;function Jh(r,t,e,n,o,s,i,a){let c=o.length,f=new Uint8Array(Zn),u=ce(f),l=si(o)&&si(s),p=l?ce(o):Qc,x=l?ce(s):Qc;for(let y=0;y<c;i++){if(r(t,e,n,u,i,a),i>=eu)throw new Error("arx: counter overflow");let m=Math.min(Zn,c-y);if(l&&m===Zn){let w=y/4;if(y%4!==0)throw new Error("arx: invalid block position");for(let _=0,M;_<Xh;_++)M=w+_,x[M]=p[M]^u[_];y+=Zn;continue}for(let w=0,_;w<m;w++)_=y+w,s[_]=o[_]^f[w];y+=m}}function ii(r,t){let{allowShortKeys:e,extendNonceFn:n,counterLength:o,counterRight:s,rounds:i}=Yc({allowShortKeys:!1,counterLength:8,counterRight:!1,rounds:20},t);if(typeof r!="function")throw new Error("core must be a function");return Wn(o),Wn(i),Gn(s),Gn(e),(a,c,f,u,l=0)=>{_t(a),_t(c),_t(f);let p=f.length;if(u===void 0&&(u=new Uint8Array(p)),_t(u),Wn(l),l<0||l>=eu)throw new Error("arx: counter overflow");if(u.length<p)throw new Error(`arx: output (${u.length}) is shorter than data (${p})`);let x=[],y=a.length,m,w;if(y===32)x.push(m=$n(a)),w=Yh;else if(y===16&&e)m=new Uint8Array(32),m.set(a),m.set(a,16),w=Zh,x.push(m);else throw new Error(`arx: invalid 32-byte key, got length=${y}`);si(c)||x.push(c=$n(c));let _=ce(m);if(n){if(c.length!==24)throw new Error("arx: extended nonce must be 24 bytes");n(w,_,ce(c.subarray(0,16)),_),c=c.subarray(16)}let M=16-o;if(M!==c.length)throw new Error(`arx: nonce must be ${M} or 16 bytes`);if(M!==12){let d=new Uint8Array(12);d.set(c,s?0:12-c.length),c=d,x.push(c)}let S=ce(c);return Jh(r,w,_,S,f,u,l,i),ue(...x),u}}var Et=(r,t)=>r[t++]&255|(r[t++]&255)<<8,ai=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=jn(t),_t(t,32);let e=Et(t,0),n=Et(t,2),o=Et(t,4),s=Et(t,6),i=Et(t,8),a=Et(t,10),c=Et(t,12),f=Et(t,14);this.r[0]=e&8191,this.r[1]=(e>>>13|n<<3)&8191,this.r[2]=(n>>>10|o<<6)&7939,this.r[3]=(o>>>7|s<<9)&8191,this.r[4]=(s>>>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|f<<8)&8191,this.r[9]=f>>>5&127;for(let u=0;u<8;u++)this.pad[u]=Et(t,16+2*u)}process(t,e,n=!1){let o=n?0:2048,{h:s,r:i}=this,a=i[0],c=i[1],f=i[2],u=i[3],l=i[4],p=i[5],x=i[6],y=i[7],m=i[8],w=i[9],_=Et(t,e+0),M=Et(t,e+2),S=Et(t,e+4),d=Et(t,e+6),I=Et(t,e+8),U=Et(t,e+10),B=Et(t,e+12),L=Et(t,e+14),k=s[0]+(_&8191),K=s[1]+((_>>>13|M<<3)&8191),T=s[2]+((M>>>10|S<<6)&8191),D=s[3]+((S>>>7|d<<9)&8191),C=s[4]+((d>>>4|I<<12)&8191),H=s[5]+(I>>>1&8191),E=s[6]+((I>>>14|U<<2)&8191),A=s[7]+((U>>>11|B<<5)&8191),P=s[8]+((B>>>8|L<<8)&8191),b=s[9]+(L>>>5|o),h=0,g=h+k*a+K*(5*w)+T*(5*m)+D*(5*y)+C*(5*x);h=g>>>13,g&=8191,g+=H*(5*p)+E*(5*l)+A*(5*u)+P*(5*f)+b*(5*c),h+=g>>>13,g&=8191;let v=h+k*c+K*a+T*(5*w)+D*(5*m)+C*(5*y);h=v>>>13,v&=8191,v+=H*(5*x)+E*(5*p)+A*(5*l)+P*(5*u)+b*(5*f),h+=v>>>13,v&=8191;let R=h+k*f+K*c+T*a+D*(5*w)+C*(5*m);h=R>>>13,R&=8191,R+=H*(5*y)+E*(5*x)+A*(5*p)+P*(5*l)+b*(5*u),h+=R>>>13,R&=8191;let O=h+k*u+K*f+T*c+D*a+C*(5*w);h=O>>>13,O&=8191,O+=H*(5*m)+E*(5*y)+A*(5*x)+P*(5*p)+b*(5*l),h+=O>>>13,O&=8191;let q=h+k*l+K*u+T*f+D*c+C*a;h=q>>>13,q&=8191,q+=H*(5*w)+E*(5*m)+A*(5*y)+P*(5*x)+b*(5*p),h+=q>>>13,q&=8191;let z=h+k*p+K*l+T*u+D*f+C*c;h=z>>>13,z&=8191,z+=H*a+E*(5*w)+A*(5*m)+P*(5*y)+b*(5*x),h+=z>>>13,z&=8191;let F=h+k*x+K*p+T*l+D*u+C*f;h=F>>>13,F&=8191,F+=H*c+E*a+A*(5*w)+P*(5*m)+b*(5*y),h+=F>>>13,F&=8191;let G=h+k*y+K*x+T*p+D*l+C*u;h=G>>>13,G&=8191,G+=H*f+E*c+A*a+P*(5*w)+b*(5*m),h+=G>>>13,G&=8191;let J=h+k*m+K*y+T*x+D*p+C*l;h=J>>>13,J&=8191,J+=H*u+E*f+A*c+P*a+b*(5*w),h+=J>>>13,J&=8191;let Z=h+k*w+K*m+T*y+D*x+C*p;h=Z>>>13,Z&=8191,Z+=H*l+E*u+A*f+P*c+b*a,h+=Z>>>13,Z&=8191,h=(h<<2)+h|0,h=h+g|0,g=h&8191,h=h>>>13,v+=h,s[0]=g,s[1]=v,s[2]=R,s[3]=O,s[4]=q,s[5]=z,s[6]=F,s[7]=G,s[8]=J,s[9]=Z}finalize(){let{h:t,pad:e}=this,n=new Uint16Array(10),o=t[1]>>>13;t[1]&=8191;for(let a=2;a<10;a++)t[a]+=o,o=t[a]>>>13,t[a]&=8191;t[0]+=o*5,o=t[0]>>>13,t[0]&=8191,t[1]+=o,o=t[1]>>>13,t[1]&=8191,t[2]+=o,n[0]=t[0]+5,o=n[0]>>>13,n[0]&=8191;for(let a=1;a<10;a++)n[a]=t[a]+o,o=n[a]>>>13,n[a]&=8191;n[9]-=8192;let s=(o^1)-1;for(let a=0;a<10;a++)n[a]&=s;s=~s;for(let a=0;a<10;a++)t[a]=t[a]&s|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;ue(n)}update(t){ri(this),t=jn(t),_t(t);let{buffer:e,blockLen:n}=this,o=t.length;for(let s=0;s<o;){let i=Math.min(n-this.pos,o-s);if(i===n){for(;n<=o-s;s+=n)this.process(t,s);continue}e.set(t.subarray(s,s+i),this.pos),this.pos+=i,s+=i,this.pos===n&&(this.process(e,0,!1),this.pos=0)}return this}destroy(){ue(this.h,this.r,this.buffer,this.pad)}digestInto(t){ri(this),Zc(t,this),this.finished=!0;let{buffer:e,h:n}=this,{pos:o}=this;if(o){for(e[o++]=1;o<16;o++)e[o]=0;this.process(e,0,!0)}this.finalize();let s=0;for(let i=0;i<8;i++)t[s++]=n[i]>>>0,t[s++]=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 Qh(r){let t=(n,o)=>r(o).update(jn(n)).digest(),e=r(new Uint8Array(32));return t.outputLen=e.outputLen,t.blockLen=e.blockLen,t.create=n=>r(n),t}var ru=Qh(r=>new ai(r));function su(r,t,e,n,o,s=20){let i=r[0],a=r[1],c=r[2],f=r[3],u=t[0],l=t[1],p=t[2],x=t[3],y=t[4],m=t[5],w=t[6],_=t[7],M=o,S=e[0],d=e[1],I=e[2],U=i,B=a,L=c,k=f,K=u,T=l,D=p,C=x,H=y,E=m,A=w,P=_,b=M,h=S,g=d,v=I;for(let O=0;O<s;O+=2)U=U+K|0,b=N(b^U,16),H=H+b|0,K=N(K^H,12),U=U+K|0,b=N(b^U,8),H=H+b|0,K=N(K^H,7),B=B+T|0,h=N(h^B,16),E=E+h|0,T=N(T^E,12),B=B+T|0,h=N(h^B,8),E=E+h|0,T=N(T^E,7),L=L+D|0,g=N(g^L,16),A=A+g|0,D=N(D^A,12),L=L+D|0,g=N(g^L,8),A=A+g|0,D=N(D^A,7),k=k+C|0,v=N(v^k,16),P=P+v|0,C=N(C^P,12),k=k+C|0,v=N(v^k,8),P=P+v|0,C=N(C^P,7),U=U+T|0,v=N(v^U,16),A=A+v|0,T=N(T^A,12),U=U+T|0,v=N(v^U,8),A=A+v|0,T=N(T^A,7),B=B+D|0,b=N(b^B,16),P=P+b|0,D=N(D^P,12),B=B+D|0,b=N(b^B,8),P=P+b|0,D=N(D^P,7),L=L+C|0,h=N(h^L,16),H=H+h|0,C=N(C^H,12),L=L+C|0,h=N(h^L,8),H=H+h|0,C=N(C^H,7),k=k+K|0,g=N(g^k,16),E=E+g|0,K=N(K^E,12),k=k+K|0,g=N(g^k,8),E=E+g|0,K=N(K^E,7);let R=0;n[R++]=i+U|0,n[R++]=a+B|0,n[R++]=c+L|0,n[R++]=f+k|0,n[R++]=u+K|0,n[R++]=l+T|0,n[R++]=p+D|0,n[R++]=x+C|0,n[R++]=y+H|0,n[R++]=m+E|0,n[R++]=w+A|0,n[R++]=_+P|0,n[R++]=M+b|0,n[R++]=S+h|0,n[R++]=d+g|0,n[R++]=I+v|0}function td(r,t,e,n){let o=r[0],s=r[1],i=r[2],a=r[3],c=t[0],f=t[1],u=t[2],l=t[3],p=t[4],x=t[5],y=t[6],m=t[7],w=e[0],_=e[1],M=e[2],S=e[3];for(let I=0;I<20;I+=2)o=o+c|0,w=N(w^o,16),p=p+w|0,c=N(c^p,12),o=o+c|0,w=N(w^o,8),p=p+w|0,c=N(c^p,7),s=s+f|0,_=N(_^s,16),x=x+_|0,f=N(f^x,12),s=s+f|0,_=N(_^s,8),x=x+_|0,f=N(f^x,7),i=i+u|0,M=N(M^i,16),y=y+M|0,u=N(u^y,12),i=i+u|0,M=N(M^i,8),y=y+M|0,u=N(u^y,7),a=a+l|0,S=N(S^a,16),m=m+S|0,l=N(l^m,12),a=a+l|0,S=N(S^a,8),m=m+S|0,l=N(l^m,7),o=o+f|0,S=N(S^o,16),y=y+S|0,f=N(f^y,12),o=o+f|0,S=N(S^o,8),y=y+S|0,f=N(f^y,7),s=s+u|0,w=N(w^s,16),m=m+w|0,u=N(u^m,12),s=s+u|0,w=N(w^s,8),m=m+w|0,u=N(u^m,7),i=i+l|0,_=N(_^i,16),p=p+_|0,l=N(l^p,12),i=i+l|0,_=N(_^i,8),p=p+_|0,l=N(l^p,7),a=a+c|0,M=N(M^a,16),x=x+M|0,c=N(c^x,12),a=a+c|0,M=N(M^a,8),x=x+M|0,c=N(c^x,7);let d=0;n[d++]=o,n[d++]=s,n[d++]=i,n[d++]=a,n[d++]=w,n[d++]=_,n[d++]=M,n[d++]=S}var ed=ii(su,{counterRight:!1,counterLength:4,allowShortKeys:!1}),rd=ii(su,{counterRight:!1,counterLength:8,extendNonceFn:td,allowShortKeys:!1});var nd=new Uint8Array(16),nu=(r,t)=>{r.update(t);let e=t.length%16;e&&r.update(nd.subarray(e))},od=new Uint8Array(32);function ou(r,t,e,n,o){let s=r(t,e,od),i=ru.create(s);o&&nu(i,o),nu(i,n);let a=Jc(n.length,o?o.length:0,!0);i.update(a);let c=i.digest();return ue(s,a),c}var iu=r=>(t,e,n)=>({encrypt(s,i){let a=s.length;i=oi(a+16,i,!1),i.set(s);let c=i.subarray(0,-16);r(t,e,c,c,1);let f=ou(r,t,e,c,n);return i.set(f,a),ue(f),i},decrypt(s,i){i=oi(s.length-16,i,!1);let a=s.subarray(0,-16),c=s.subarray(-16),f=ou(r,t,e,a,n);if(!Xc(c,f))throw new Error("invalid tag");return i.set(s.subarray(0,-16)),r(t,e,i,i,1),ue(f),i}}),ci=ni({blockSize:64,nonceLength:12,tagLength:16},iu(ed)),ax=ni({blockSize:64,nonceLength:24,tagLength:16},iu(rd));function cu(r,t,e){return vr(r),e===void 0&&(e=new Uint8Array(r.outputLen)),or(r,me(e),me(t))}var ui=Uint8Array.from([0]),au=Uint8Array.of();function uu(r,t,e,n=32){vr(r),Ze(n);let o=r.outputLen;if(n>255*o)throw new Error("Length should be <= 255*HashLen");let s=Math.ceil(n/o);e===void 0&&(e=au);let i=new Uint8Array(s*o),a=or.create(r,t),c=a._cloneInto(),f=new Uint8Array(a.outputLen);for(let u=0;u<s;u++)ui[0]=u+1,c.update(u===0?au:f).update(e).update(ui).digestInto(f),i.set(f,o*u),a._cloneInto(c);return a.destroy(),c.destroy(),Vt(f,ui),i.slice(0,n)}var fi={hashSHA256(r){return Ae(r.subarray())},getHKDF(r,t){let e=cu(Ae,t,r),o=uu(Ae,e,void 0,96),s=o.subarray(0,32),i=o.subarray(32,64),a=o.subarray(64,96);return[s,i,a]},generateX25519KeyPair(){let r=Rr.utils.randomPrivateKey();return{publicKey:Rr.getPublicKey(r),privateKey:r}},generateX25519KeyPairFromSeed(r){return{publicKey:Rr.getPublicKey(r),privateKey:r}},generateX25519SharedKey(r,t){return Rr.getSharedSecret(r.subarray(),t.subarray())},chaCha20Poly1305Encrypt(r,t,e,n){return ci(n,t,e).encrypt(r.subarray())},chaCha20Poly1305Decrypt(r,t,e,n,o){return ci(n,t,e).decrypt(r.subarray(),o)}};var fu=fi;function lu(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 ur=r=>{let t=pt(2);return t[0]=r>>8,t[1]=r,t};ur.bytes=2;var Yr=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)};Yr.bytes=2;function hu(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 li(r,t){!t.enabled||!cr||(r?(t(`LOCAL_STATIC_PUBLIC_KEY ${V(r.publicKey,"hex")}`),t(`LOCAL_STATIC_PRIVATE_KEY ${V(r.privateKey,"hex")}`)):t("Missing local static keys."))}function hi(r,t){!t.enabled||!cr||(r?(t(`LOCAL_PUBLIC_EPHEMERAL_KEY ${V(r.publicKey,"hex")}`),t(`LOCAL_PRIVATE_EPHEMERAL_KEY ${V(r.privateKey,"hex")}`)):t("Missing local ephemeral keys."))}function du(r,t){!t.enabled||!cr||t(r?`REMOTE_STATIC_PUBLIC_KEY ${V(r.subarray(),"hex")}`:"Missing remote static public key.")}function di(r,t){!t.enabled||!cr||t(r?`REMOTE_EPHEMERAL_PUBLIC_KEY ${V(r.subarray(),"hex")}`:"Missing remote ephemeral keys.")}function pi(r,t,e){!e.enabled||!cr||(e(`CIPHER_STATE_1 ${r.n.getUint64()} ${r.k&&V(r.k,"hex")}`),e(`CIPHER_STATE_2 ${t.n.getUint64()} ${t.k&&V(t.k,"hex")}`))}var fr=class r extends Error{code;constructor(t="Invalid crypto exchange"){super(t),this.code=r.code}static code="ERR_INVALID_CRYPTO_EXCHANGE"};var sd=0,id=4294967295,ad="Cipherstate has reached maximum n, a new handshake must be performed",Yn=class{n;bytes;view;constructor(t=sd){this.n=t,this.bytes=dt(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>id)throw new Error(ad)}};var He=dt(0),lr=class{k;n;crypto;constructor(t,e=void 0,n=0){this.crypto=t,this.k=e,this.n=new Yn(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 o=this.crypto.decrypt(e,this.n.getBytes(),t,this.k,n);return this.n.increment(),o}},mi=class{cs;ck;h;crypto;constructor(t,e){this.crypto=t;let n=Q(e,"utf-8");this.h=cd(t,n),this.ck=this.h,this.cs=new lr(t)}mixKey(t){let[e,n]=this.crypto.hkdf(this.ck,t);this.ck=e,this.cs=new lr(this.crypto,n)}mixHash(t){this.h=this.crypto.hash(new $(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,He);return[new lr(this.crypto,t),new lr(this.crypto,e)]}},yi=class{ss;s;e;rs;re;initiator;crypto;constructor(t){let{crypto:e,protocolName:n,prologue:o,initiator:s,s:i,e:a,rs:c,re:f}=t;this.crypto=e,this.ss=new mi(e,n),this.ss.mixHash(o),this.initiator=s,this.s=i,this.e=a,this.rs=c,this.re=f}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 o=t.sublist(e,e+n);return this.rs=this.ss.decryptAndHash(o),n}readEE(){this.writeEE()}readES(){this.writeES()}readSE(){this.writeSE()}},Xr=class extends yi{writeMessageA(t){return new $(this.writeE(),this.ss.encryptAndHash(t))}writeMessageB(t){let e=this.writeE();this.writeEE();let n=this.writeS();return this.writeES(),new $(e,n,this.ss.encryptAndHash(t))}writeMessageC(t){let e=this.writeS();return this.writeSE(),new $(e,this.ss.encryptAndHash(t))}readMessageA(t){try{return this.readE(t),this.ss.decryptAndHash(t.sublist(32))}catch(e){throw new fr(`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 fr(`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 fr(`handshake stage 2 validation fail: ${e.message}`)}}};function cd(r,t){if(t.length<=32){let e=dt(32);return e.set(t),e}else return r.hash(t)}var Xn;(function(r){let t;r.codec=()=>(t==null&&(t=Me((e,n,o={})=>{if(o.lengthDelimited!==!1&&n.fork(),e.webtransportCerthashes!=null)for(let s of e.webtransportCerthashes)n.uint32(10),n.bytes(s);if(e.streamMuxers!=null)for(let s of e.streamMuxers)n.uint32(18),n.string(s);o.lengthDelimited!==!1&&n.ldelim()},(e,n,o={})=>{let s={webtransportCerthashes:[],streamMuxers:[]},i=n==null?e.len:e.pos+n;for(;e.pos<i;){let a=e.uint32();switch(a>>>3){case 1:{if(o.limits?.webtransportCerthashes!=null&&s.webtransportCerthashes.length===o.limits.webtransportCerthashes)throw new Or('Decode error - map field "webtransportCerthashes" had too many elements');s.webtransportCerthashes.push(e.bytes());break}case 2:{if(o.limits?.streamMuxers!=null&&s.streamMuxers.length===o.limits.streamMuxers)throw new Or('Decode error - map field "streamMuxers" had too many elements');s.streamMuxers.push(e.string());break}default:{e.skipType(a&7);break}}}return s})),t),r.encode=e=>Ne(e,r.codec()),r.decode=(e,n)=>De(e,r.codec(),n)})(Xn||(Xn={}));var Jr;(function(r){let t;r.codec=()=>(t==null&&(t=Me((e,n,o={})=>{o.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),Xn.codec().encode(e.extensions,n)),o.lengthDelimited!==!1&&n.ldelim()},(e,n,o={})=>{let s={identityKey:dt(0),identitySig:dt(0)},i=n==null?e.len:e.pos+n;for(;e.pos<i;){let a=e.uint32();switch(a>>>3){case 1:{s.identityKey=e.bytes();break}case 2:{s.identitySig=e.bytes();break}case 4:{s.extensions=Xn.codec().decode(e,e.uint32(),{limits:o.limits?.extensions});break}default:{e.skipType(a&7);break}}}return s})),t),r.encode=e=>Ne(e,r.codec()),r.decode=(e,n)=>De(e,r.codec(),n)})(Jr||(Jr={}));async function gi(r,t,e){let n=await r.sign(pu(t));return Jr.encode({identityKey:pe(r.publicKey),identitySig:n,extensions:e})}async function wi(r,t,e){try{let n=Jr.decode(r),o=qr(n.identityKey);if(e?.equals(o)===!1)throw new Error(`Payload identity key ${o} does not match expected remote identity key ${e}`);if(!t)throw new Error("Remote static does not exist");let s=pu(t);if(!await o.verify(s,n.identitySig))throw new Error("Invalid payload signature");return n}catch(n){throw new rn(n.message)}}function pu(r){let t=Q("noise-libp2p-static-key:");return r instanceof Uint8Array?At([t,r],t.length+r.length):(r.prepend(t),r)}async function mu(r,t){let{log:e,connection:n,crypto:o,privateKey:s,prologue:i,s:a,remoteIdentityKey:c,extensions:f}=r,u=await gi(s,a.publicKey,f),l=new Xr({crypto:o,protocolName:"Noise_XX_25519_ChaChaPoly_SHA256",initiator:!0,prologue:i,s:a});li(l.s,e),e.trace("Stage 0 - Initiator starting to send first message."),await n.write(l.writeMessageA(He),t),e.trace("Stage 0 - Initiator finished sending first message."),hi(l.e,e),e.trace("Stage 1 - Initiator waiting to receive first message from responder...");let p=l.readMessageB(await n.read(t));e.trace("Stage 1 - Initiator received the message."),di(l.re,e),du(l.rs,e),e.trace("Initiator going to check remote's signature...");let x=await wi(p,l.rs,c);e.trace("All good with the signature!"),e.trace("Stage 2 - Initiator sending third handshake message."),await n.write(l.writeMessageC(u),t),e.trace("Stage 2 - Initiator sent message with signed payload.");let[y,m]=l.ss.split();return pi(y,m,e),{payload:x,encrypt:w=>y.encryptWithAd(He,w),decrypt:(w,_)=>m.decryptWithAd(He,w,_)}}async function yu(r,t){let{log:e,connection:n,crypto:o,privateKey:s,prologue:i,s:a,remoteIdentityKey:c,extensions:f}=r,u=await gi(s,a.publicKey,f),l=new Xr({crypto:o,protocolName:"Noise_XX_25519_ChaChaPoly_SHA256",initiator:!1,prologue:i,s:a});li(l.s,e),e.trace("Stage 0 - Responder waiting to receive first message."),l.readMessageA(await n.read(t)),e.trace("Stage 0 - Responder received first message."),di(l.re,e),e.trace("Stage 1 - Responder sending out first message with signed payload and static key."),await n.write(l.writeMessageB(u),t),e.trace("Stage 1 - Responder sent the second handshake message with signed payload."),hi(l.e,e),e.trace("Stage 2 - Responder waiting for third handshake message...");let p=l.readMessageC(await n.read(t));e.trace("Stage 2 - Responder received the message, finished handshake.");let x=await wi(p,l.rs,c),[y,m]=l.ss.split();return pi(y,m,e),{payload:x,encrypt:w=>m.encryptWithAd(He,w),decrypt:(w,_)=>y.decryptWithAd(He,w,_)}}var wu=16;function xu(r,t){return async function*(e){for await(let n of e)for(let o=0;o<n.length;o+=65519){let s=o+65519;s>n.length&&(s=n.length);let i;n instanceof Uint8Array?i=r.encrypt(n.subarray(o,s)):i=r.encrypt(n.sublist(o,s)),t?.encryptedPackets.increment(),yield new $(ur(i.byteLength),i)}}}function bu(r,t){return async function*(e){for await(let n of e)for(let o=0;o<n.length;o+=65535){let s=o+65535;if(s>n.length&&(s=n.length),s-wu<o)throw new Error("Invalid chunk");let i=n.sublist(o,s),a=n.subarray(o,s-wu);try{let c=r.decrypt(i,a);t?.decryptedPackets.increment(),yield c}catch(c){throw t?.decryptErrors.increment(),c}}}}var Jn=class{protocol="/noise";crypto;prologue;staticKey;extensions;metrics;components;constructor(t,e={}){let{staticNoiseKey:n,extensions:o,crypto:s,prologueBytes:i}=e,{metrics:a}=t;this.components=t;let c=s??fu;this.crypto=lu(c),this.extensions={webtransportCerthashes:[],...o},this.metrics=a?hu(a):void 0,n?this.staticKey=c.generateX25519KeyPairFromSeed(n):this.staticKey=c.generateX25519KeyPair(),this.prologue=i??dt(0)}[Symbol.toStringTag]="@chainsafe/libp2p-noise";[un]=["@libp2p/connection-encryption","@chainsafe/libp2p-noise"];async secureOutbound(t,e){let n=Js(t,{lengthEncoder:ur,lengthDecoder:Yr,maxDataLength:65535}),o=await this.performHandshakeInitiator(n,this.components.privateKey,e?.remotePeer?.publicKey,e),s=await this.createSecureConnection(n,o);t.source=s.source,t.sink=s.sink;let i=qr(o.payload.identityKey);return{conn:t,remoteExtensions:o.payload.extensions,remotePeer:Zs(i),streamMuxer:e?.skipStreamMuxerNegotiation===!0?void 0:this.getStreamMuxer(o.payload.extensions?.streamMuxers)}}getStreamMuxer(t){if(t==null||t.length===0)return;let e=this.components.upgrader.getStreamMuxers();if(e!=null)for(let n of t){let o=e.get(n);if(o!=null)return o}if(t.length)throw new ze("Early muxer negotiation was requested but the initiator and responder had no common muxers")}async secureInbound(t,e){let n=Js(t,{lengthEncoder:ur,lengthDecoder:Yr,maxDataLength:65535}),o=await this.performHandshakeResponder(n,this.components.privateKey,e?.remotePeer?.publicKey,e),s=await this.createSecureConnection(n,o);t.source=s.source,t.sink=s.sink;let i=qr(o.payload.identityKey);return{conn:t,remoteExtensions:o.payload.extensions,remotePeer:Zs(i),streamMuxer:e?.skipStreamMuxerNegotiation===!0?void 0:this.getStreamMuxer(o.payload.extensions?.streamMuxers)}}async performHandshakeInitiator(t,e,n,o){let s,i=o?.skipStreamMuxerNegotiation===!0?[]:[...this.components.upgrader.getStreamMuxers().keys()];try{s=await mu({connection:t,privateKey:e,remoteIdentityKey:n,log:this.components.logger.forComponent("libp2p:noise:xxhandshake"),crypto:this.crypto,prologue:this.prologue,s:this.staticKey,extensions:{streamMuxers:i,webtransportCerthashes:[],...this.extensions}},o),this.metrics?.xxHandshakeSuccesses.increment()}catch(a){throw this.metrics?.xxHandshakeErrors.increment(),a}return s}async performHandshakeResponder(t,e,n,o){let s,i=o?.skipStreamMuxerNegotiation===!0?[]:[...this.components.upgrader.getStreamMuxers().keys()];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:{streamMuxers:i,webtransportCerthashes:[],...this.extensions}},o),this.metrics?.xxHandshakeSuccesses.increment()}catch(a){throw this.metrics?.xxHandshakeErrors.increment(),a}return s}async createSecureConnection(t,e){let[n,o]=qc(),s=t.unwrap();return await Fc(n,xu(e,this.metrics),s,i=>Zr(i,{lengthDecoder:Yr}),bu(e,this.metrics),n),o}};function Eu(r={}){return t=>new Jn(t,r)}var Qn=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,o){return this.readAtomically(()=>{let s=0,i=0,a=this.peekChar();if(a===void 0)return;let c=a==="0",f=2**(8*o)-1;for(;;){let u=this.readAtomically(()=>{let l=this.readChar();if(l===void 0)return;let p=Number.parseInt(l,t);if(!Number.isNaN(p))return p});if(u===void 0)break;if(s*=t,s+=u,s>f||(i+=1,e!==void 0&&i>e))return}if(i!==0)return!n&&c&&i>1?void 0:s})}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 o=n*2;if(n<e.length-3){let i=this.readSeparator(":",n,()=>this.readIPv4Addr());if(i!==void 0)return e[o]=i[0],e[o+1]=i[1],e[o+2]=i[2],e[o+3]=i[3],[o+4,!0]}let s=this.readSeparator(":",n,()=>this.readNumber(16,4,!0,2));if(s===void 0)return[o,!1];e[o]=s>>8,e[o+1]=s&255}return[e.length,!1]};return this.readAtomically(()=>{let e=new Uint8Array(16),[n,o]=t(e);if(n===16)return e;if(o||this.readGivenChar(":")===void 0||this.readGivenChar(":")===void 0)return;let s=new Uint8Array(14),i=16-(n+2),[a]=t(s.subarray(0,i));return e.set(s.subarray(0,a),16-a),e})}readIPAddr(){return this.readIPv4Addr()??this.readIPv6Addr()}};var Su=45,ud=15,hr=new Qn;function xi(r){if(!(r.length>ud))return hr.new(r).parseWith(()=>hr.readIPv4Addr())}function bi(r){if(r.includes("%")&&(r=r.split("%")[0]),!(r.length>Su))return hr.new(r).parseWith(()=>hr.readIPv6Addr())}function to(r,t=!1){if(r.includes("%")&&(r=r.split("%")[0]),r.length>Su)return;let e=hr.new(r).parseWith(()=>hr.readIPAddr());if(e)return t&&e.length===4?Uint8Array.from([0,0,0,0,0,0,0,0,0,0,255,255,e[0],e[1],e[2],e[3]]):e}function eo(r){return!!xi(r)}function ro(r){return!!bi(r)}function no(r){return!!to(r)}var fd=r=>r.toString().split("/").slice(1),dr=r=>({match:t=>t.length<1?!1:r(t[0])?t.slice(1):!1,pattern:"fn"}),W=r=>({match:t=>dr(e=>e===r).match(t),pattern:r}),Ve=()=>({match:r=>dr(t=>typeof t=="string").match(r),pattern:"{string}"}),pr=()=>({match:r=>dr(t=>!isNaN(parseInt(t))).match(r),pattern:"{number}"}),rt=()=>({match:r=>{if(r.length<2||r[0]!=="p2p"&&r[0]!=="ipfs")return!1;if(r[1].startsWith("Q")||r[1].startsWith("1"))try{nt.decode(`z${r[1]}`)}catch{return!1}else return!1;return r.slice(2)},pattern:"/p2p/{peerid}"}),tn=()=>({match:r=>{if(r.length<2||r[0]!=="certhash")return!1;try{ko.decode(r[1])}catch{return!1}return r.slice(2)},pattern:"/certhash/{certhash}"}),X=r=>({match:t=>{let e=r.match(t);return e===!1?t:e},pattern:`optional(${r.pattern})`}),Lt=(...r)=>({match:t=>{let e;for(let n of r){let o=n.match(t);o!==!1&&(e==null||o.length<e.length)&&(e=o)}return e??!1},pattern:`or(${r.map(t=>t.pattern).join(", ")})`}),j=(...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 it(...r){function t(o){let s=fd(o);for(let i of r){let a=i.match(s);if(a===!1)return!1;s=a}return s}function e(o){return t(o)!==!1}function n(o){let s=t(o);return s===!1?!1:s.length===0}return{matchers:r,matches:e,exactMatch:n}}var ld=rt(),qb=it(ld),so=j(W("dns4"),Ve()),io=j(W("dns6"),Ve()),ao=j(W("dnsaddr"),Ve()),Si=j(W("dns"),Ve()),zb=it(so,X(rt())),Fb=it(io,X(rt())),Gb=it(ao,X(rt())),Wb=it(Lt(Si,ao,so,io),X(rt())),Au=j(W("ip4"),dr(eo)),vu=j(W("ip6"),dr(ro)),Ai=Lt(Au,vu),fe=Lt(Ai,Si,so,io,ao),jb=it(Lt(Ai,j(Lt(Si,ao,so,io),X(rt())))),$b=it(Au),Zb=it(vu),Yb=it(Ai),vi=j(fe,W("tcp"),pr()),en=j(fe,W("udp"),pr()),Xb=it(j(vi,X(rt()))),Jb=it(en),Ii=j(en,W("quic"),X(rt())),co=j(en,W("quic-v1"),X(rt())),hd=Lt(Ii,co),Qb=it(Ii),t1=it(co),Ei=Lt(fe,vi,en,Ii,co),Iu=Lt(j(Ei,W("ws"),X(rt()))),e1=it(Iu),Bu=Lt(j(Ei,W("wss"),X(rt())),j(Ei,W("tls"),X(j(W("sni"),Ve())),W("ws"),X(rt()))),r1=it(Bu),_u=j(en,W("webrtc-direct"),X(tn()),X(tn()),X(rt())),n1=it(_u),Lu=j(co,W("webtransport"),X(tn()),X(tn()),X(rt())),uo=it(Lu),oo=Lt(Iu,Bu,j(vi,X(rt())),j(hd,X(rt())),j(fe,X(rt())),_u,Lu,rt()),o1=it(oo),dd=j(oo,W("p2p-circuit"),rt()),s1=it(dd),pd=Lt(j(oo,W("p2p-circuit"),W("webrtc"),X(rt())),j(oo,W("webrtc"),X(rt())),j(W("webrtc"),X(rt()))),i1=it(pd),md=Lt(j(fe,W("tcp"),pr(),W("http"),X(rt())),j(fe,W("http"),X(rt()))),a1=it(md),yd=Lt(j(fe,W("tcp"),Lt(j(W("443"),W("http")),j(pr(),W("https")),j(pr(),W("tls"),W("http"))),X(rt())),j(fe,W("tls"),W("http"),X(rt())),j(fe,W("https"),X(rt()))),c1=it(yd),gd=Lt(j(W("memory"),Ve(),X(rt()))),u1=it(gd);var qe=class extends Event{type;detail;constructor(t,e){super(t),this.type=t,this.detail=e}};function Bi(r){throw new Error("Not implemented")}function Tu(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 Cu(r){return r==null?!1:typeof r.then=="function"&&typeof r.catch=="function"&&typeof r.finally=="function"}function Pu(r,t){let e=Tu(r).return?.();Cu(e)&&e.catch(n=>{t.error("could not cause iterator to return",n)})}var wd=5e3;function _i(r){return r==null?!1:typeof r.then=="function"&&typeof r.catch=="function"&&typeof r.finally=="function"}var fo=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=Ut(),this.closed=Ut(),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??wd,this.onEnd=t.onEnd,this.onCloseRead=t.onCloseRead,this.onCloseWrite=t.onCloseWrite,this.onReset=t.onReset,this.onAbort=t.onAbort,this.source=this.streamSource=Fn({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 on(`writable end state is "${this.writeStatus}" not "ready"`);try{this.writeStatus="writing";let e={signal:this.sinkController.signal};if(this.direction==="outbound"){let o=this.sendNewStream(e);_i(o)&&await o}let n=()=>{Pu(t,this.log)};try{this.sinkController.signal.addEventListener("abort",n),this.log.trace("sink reading from source");for await(let o of t){o=o instanceof Uint8Array?new $(o):o;let s=this.sendData(o,e);_i(s)&&(this.sendingData=Ut(),await s,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.status==="open"&&(this.log.trace("closing gracefully"),this.status="closing",await wt(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 wt(this.sink([]),t.signal)),this.writeStatus==="writing"&&(this.sendingData!=null&&await wt(this.sendingData.promise,t.signal),this.log.trace("aborting source passed to .sink"),this.sinkController.abort(),await wt(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();_i(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 nn("stream reset");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 Li=class extends fo{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 $(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(let n of t)this.log("sendData waiting for writer to be ready"),await wt(this.writer.ready,e?.signal),this.writer.write(n).catch(o=>{this.log.error("error sending stream data",o)})}async sendReset(t){this.log("sendReset aborting writer"),await wt(this.writer.abort(),t?.signal),this.log("sendReset aborted writer")}async sendCloseWrite(t){this.log("sendCloseWrite closing writer"),await wt(this.writer.close(),t?.signal),this.log("sendCloseWrite closed writer")}async sendCloseRead(t){this.log("sendCloseRead cancelling reader"),await wt(this.reader.cancel(),t?.signal),this.log("sendCloseRead cancelled reader")}};async function Ti(r,t,e,n,o,s){let i=s.forComponent(`libp2p:webtransport:stream:${e}:${t}`),a=new Li({bidiStream:r,id:t,direction:e,log:i,onEnd:()=>{let c=n.findIndex(f=>f===a);c!==-1&&n.splice(c,1),o?.(a)}});return a}function lo(){return{source:{[Symbol.asyncIterator](){return{async next(){return new Promise(()=>{})}}}},sink:async r=>new Promise(()=>{})}}function Uu(r,t,e,n){let o=0,s=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:f,value:u}=await t.read();if(f)break;if(a.length>=n.maxInboundStreams)s(`too many inbound streams open - ${a.length}/${n.maxInboundStreams}, closing new incoming stream`),u.writable.close().catch(l=>{s.error(`failed to close inbound stream that crossed our maxInboundStream limit: ${l.message}`)}),u.readable.cancel().catch(l=>{s.error(`failed to close inbound stream that crossed our maxInboundStream limit: ${l.message}`)});else{let l=await Ti(u,String(o++),"inbound",a,i?.onStreamEnd,e);a.push(l),i?.onIncomingStream?.(l)}}}).catch(f=>{s.error("could not create a new stream",f)});let c={protocol:"webtransport",streams:a,newStream:async f=>{s("new outgoing stream",f);let u=await r.createBidirectionalStream(),l=await Ti(u,String(o++),i?.direction??"outbound",a,i?.onStreamEnd,e);return a.push(l),l},close:async()=>{s("closing webtransport muxer gracefully");try{r.close()}catch(f){c.abort(f)}},abort:f=>{s("closing webtransport muxer with err:",f);try{r.close()}catch(u){s.error("webtransport session threw error during close",u)}},...lo()};return c}}}function ku(r,t){return t.filter(n=>!!r.find(o=>ht(n,o))).length===t.length}var V1=parseInt("0xFFFF",16),q1=new Uint8Array([0,0,0,0,0,0,0,0,0,0,255,255]);var Ku=eo,Ad=ro,Ci=function(r){let t=0;if(r=r.toString().trim(),Ku(r)){let e=new Uint8Array(t+4);return r.split(/\./g).forEach(n=>{e[t++]=parseInt(n,10)&255}),e}if(Ad(r)){let e=r.split(":",8),n;for(n=0;n<e.length;n++){let s=Ku(e[n]),i;s&&(i=Ci(e[n]),e[n]=V(i.slice(0,2),"base16")),i!=null&&++n<8&&e.splice(n,0,V(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 s=[n,1];for(n=9-e.length;n>0;n--)s.push("0");e.splice.apply(e,s)}let o=new Uint8Array(t+16);for(n=0;n<e.length;n++){let s=parseInt(e[n],16);o[t++]=s>>8&255,o[t++]=s&255}return o}throw new Error("invalid ip address")},Nu=function(r,t=0,e){t=~~t,e=e??r.length-t;let n=new DataView(r.buffer);if(e===4){let o=[];for(let s=0;s<e;s++)o.push(r[t+s]);return o.join(".")}if(e===16){let o=[];for(let s=0;s<e;s+=2)o.push(n.getUint16(t+s).toString(16));return o.join(":").replace(/(^|:)0(:0)*:0(:|$)/,"$1::$3").replace(/:{3,4}/,"::")}return""};var mr={},Pi={},Id=[[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"]];Id.forEach(r=>{let t=Bd(...r);Pi[t.code]=t,mr[t.name]=t});function Bd(r,t,e,n,o){return{code:r,size:t,name:e,resolvable:!!n,path:!!o}}function et(r){if(typeof r=="number"){if(Pi[r]!=null)return Pi[r];throw new Error(`no protocol with code: ${r}`)}else if(typeof r=="string"){if(mr[r]!=null)return mr[r];throw new Error(`no protocol with name: ${r}`)}throw new Error(`invalid protocol id type: ${typeof r}`)}var A2=et("ip4"),v2=et("ip6"),I2=et("ipcidr");function Di(r,t){switch(et(r).code){case 4:case 41:return Ld(t);case 42:return Ri(t);case 43:return V(t,"base10");case 6:case 273:case 33:case 132:return Hu(t).toString();case 53:case 54:case 55:case 56:case 400:case 449:case 777:return Ri(t);case 421:return Ud(t);case 444:return Ou(t);case 445:return Ou(t);case 466:return Pd(t);case 481:return globalThis.encodeURIComponent(Ri(t));default:return V(t,"base16")}}function Ki(r,t){switch(et(r).code){case 4:return Mu(t);case 41:return Mu(t);case 42:return ki(t);case 43:return Q(t,"base10");case 6:case 273:case 33:case 132:return Ni(parseInt(t,10));case 53:case 54:case 55:case 56:case 400:case 449:case 777:return ki(t);case 421:return Td(t);case 444:return kd(t);case 445:return Rd(t);case 466:return Cd(t);case 481:return ki(globalThis.decodeURIComponent(t));default:return Q(t,"base16")}}var Ui=Object.values(Be).map(r=>r.decoder),_d=function(){let r=Ui[0].or(Ui[1]);return Ui.slice(2).forEach(t=>r=r.or(t)),r}();function Mu(r){if(!no(r))throw new Error("invalid ip address");return Ci(r)}function Ld(r){let t=Nu(r,0,r.length);if(t==null)throw new Error("ipBuff is required");if(!no(t))throw new Error("invalid ip address");return t}function Ni(r){let t=new ArrayBuffer(2);return new DataView(t).setUint16(0,r),new Uint8Array(t)}function Hu(r){return new DataView(r.buffer).getUint16(r.byteOffset)}function ki(r){let t=Q(r),e=Uint8Array.from(Xt(t.length));return At([e,t],e.length+t.length)}function Ri(r){let t=Ft(r);if(r=r.slice(lt(t)),r.length!==t)throw new Error("inconsistent lengths");return V(r)}function Td(r){let t;r[0]==="Q"||r[0]==="1"?t=he(nt.decode(`z${r}`)).bytes:t=ut.parse(r).multihash.bytes;let e=Uint8Array.from(Xt(t.length));return At([e,t],e.length+t.length)}function Cd(r){let t=_d.decode(r),e=Uint8Array.from(Xt(t.length));return At([e,t],e.length+t.length)}function Pd(r){let t=Ft(r),e=r.slice(lt(t));if(e.length!==t)throw new Error("inconsistent lengths");return"u"+V(e,"base64url")}function Ud(r){let t=Ft(r),e=r.slice(lt(t));if(e.length!==t)throw new Error("inconsistent lengths");return V(e,"base58btc")}function kd(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=te.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 o=Ni(n);return At([e,o],e.length+o.length)}function Rd(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=te.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 o=Ni(n);return At([e,o],e.length+o.length)}function Ou(r){let t=r.slice(0,r.length-2),e=r.slice(r.length-2),n=V(t,"base32"),o=Hu(e);return`${n}:${o}`}function Vu(r){r=Mi(r);let t=[],e=[],n=null,o=r.split("/").slice(1);if(o.length===1&&o[0]==="")return{bytes:new Uint8Array,string:"/",tuples:[],stringTuples:[],path:null};for(let s=0;s<o.length;s++){let i=o[s],a=et(i);if(a.size===0){t.push([a.code]),e.push([a.code]);continue}if(s++,s>=o.length)throw new ho("invalid address: "+r);if(a.path===!0){n=Mi(o.slice(s).join("/")),t.push([a.code,Ki(a.code,n)]),e.push([a.code,n]);break}let c=Ki(a.code,o[s]);t.push([a.code,c]),e.push([a.code,Di(a.code,c)])}return{string:qu(e),bytes:po(t),tuples:t,stringTuples:e,path:n}}function Oi(r){let t=[],e=[],n=null,o=0;for(;o<r.length;){let s=Ft(r,o),i=lt(s),a=et(s),c=Dd(a,r.slice(o+i));if(c===0){t.push([s]),e.push([s]),o+=i;continue}let f=r.slice(o+i,o+i+c);if(o+=c+i,o>r.length)throw new ho("Invalid address Uint8Array: "+V(r,"base16"));t.push([s,f]);let u=Di(s,f);if(e.push([s,u]),a.path===!0){n=u;break}}return{bytes:Uint8Array.from(r),string:qu(e),tuples:t,stringTuples:e,path:n}}function qu(r){let t=[];return r.map(e=>{let n=et(e[0]);return t.push(n.name),e.length>1&&e[1]!=null&&t.push(e[1]),null}),Mi(t.join("/"))}function po(r){return At(r.map(t=>{let e=et(t[0]),n=Uint8Array.from(Xt(e.code));return t.length>1&&t[1]!=null&&(n=At([n,t[1]])),n}))}function Dd(r,t){if(r.size>0)return r.size/8;if(r.size===0)return 0;{let e=Ft(t instanceof Uint8Array?t:Uint8Array.from(t));return e+lt(e)}}function Mi(r){return"/"+r.trim().split("/").filter(t=>t).join("/")}var ho=class extends Error{static name="ParseError";name="ParseError";constructor(t){super(`Error parsing address: ${t}`)}};var Kd=Symbol.for("nodejs.util.inspect.custom"),Vi=Symbol.for("@multiformats/js-multiaddr/multiaddr"),Nd=[et("dns").code,et("dns4").code,et("dns6").code,et("dnsaddr").code],Hi=class extends Error{constructor(t="No available resolver"){super(t),this.name="NoAvailableResolverError"}},mo=class r{bytes;#e;#t;#r;#n;[Vi]=!0;constructor(t){t==null&&(t="");let e;if(t instanceof Uint8Array)e=Oi(t);else if(typeof t=="string"){if(t.length>0&&t.charAt(0)!=="/")throw new Error(`multiaddr "${t}" must start with a "/"`);e=Vu(t)}else if(Fu(t))e=Oi(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,o,s="",i=et("tcp"),a=et("udp"),c=et("ip4"),f=et("ip6"),u=et("dns6"),l=et("ip6zone");for(let[x,y]of this.stringTuples())x===l.code&&(s=`%${y??""}`),Nd.includes(x)&&(e=i.name==="tcp"?"tcp":"udp",o=443,n=`${y??""}${s}`,t=x===u.code?6:4),(x===i.code||x===a.code)&&(e=et(x).name==="tcp"?"tcp":"udp",o=parseInt(y??"")),(x===c.code||x===f.code)&&(e=et(x).name==="tcp"?"tcp":"udp",n=`${y??""}${s}`,t=x===f.code?6:4);if(t==null||e==null||n==null||o==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:o}}protos(){return this.#t.map(([t])=>Object.assign({},et(t)))}protoCodes(){return this.#t.map(([t])=>t)}protoNames(){return this.#t.map(([t])=>et(t).name)}tuples(){return this.#t.map(([t,e])=>e==null?[t]:[t,e])}stringTuples(){return this.#r.map(([t,e])=>e==null?[t]:[t,e])}encapsulate(t){return t=new r(t),new r(this.toString()+t.toString())}decapsulate(t){let e=t.toString(),n=this.toString(),o=n.lastIndexOf(e);if(o<0)throw new Error(`Address ${this.toString()} does not contain subaddress: ${t.toString()}`);return new r(n.slice(0,o))}decapsulateCode(t){let e=this.tuples();for(let n=e.length-1;n>=0;n--)if(e[n][0]===t)return new r(po(e.slice(0,n)));return this}getPeerId(){try{let t=[];this.stringTuples().forEach(([n,o])=>{n===mr.p2p.code&&t.push([n,o]),n===mr["p2p-circuit"].code&&(t=[])});let e=t.pop();if(e?.[1]!=null){let n=e[1];return n[0]==="Q"||n[0]==="1"?V(nt.decode(`z${n}`),"base58btc"):V(ut.parse(n).multihash.bytes,"base58btc")}return null}catch{return null}}getPath(){return this.#n}equals(t){return ht(this.bytes,t.bytes)}async resolve(t){let e=this.protos().find(s=>s.resolvable);if(e==null)return[this];let n=zu.get(e.name);if(n==null)throw new Hi(`no available resolver for ${e.name}`);return(await n(this,t)).map(s=>qi(s))}nodeAddress(){let t=this.toOptions();if(t.transport!=="tcp"&&t.transport!=="udp")throw new Error(`multiaddr must have a valid format - no protocol with name: "${t.transport}". Must have a valid transport protocol: "{tcp, udp}"`);return{family:t.family,address:t.host,port:t.port}}isThinWaistAddress(t){let e=(t??this).protos();return!(e.length!==2||e[0].code!==4&&e[0].code!==41||e[1].code!==6&&e[1].code!==273)}[Kd](){return`Multiaddr(${this.#e})`}};var zu=new Map;function Fu(r){return!!r?.[Vi]}function qi(r){return new mo(r)}var Md=Object.values(Be).map(r=>r.decoder).reduce((r,t)=>r.or(t));function Od(r){return Wt.decode(Md.decode(r))}function zi(r){if(!uo.matches(r))throw new sn("Invalid multiaddr, was not a WebTransport address");let t=r.stringTuples(),e=t.filter(([i,a])=>i===et("certhash").code).map(([i,a])=>Od(a??"")),n=t.filter(([i,a])=>i===et("p2p").code).map(([i,a])=>Nc(a??""))[0],o=r.toOptions(),s=o.host;return o.family===6&&s?.includes(":")&&(s=`[${s}]`),{url:`https://${s}:${o.port}`,certhashes:e,remotePeer:n}}var Gu=globalThis.WebTransport;var Fi=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";[ji]=!0;[un]=["@libp2p/transport"];async dial(t,e){e.signal.throwIfAborted(),this.log("dialing %s",t),e=e??{};let{url:n,certhashes:o,remotePeer:s}=zi(t),i,a,c=()=>{},f=!1,u=!1,l=!1;try{this.metrics?.dialerEvents.increment({pending:!0});let p=new Gu(`${n}/.well-known/libp2p-webtransport?type=noise`,{serverCertificateHashes:o.map(x=>({algorithm:"sha-256",value:x.digest}))});if(c=x=>{if(!f)try{this.metrics?.dialerEvents.increment({[x]:!0}),p.close()}catch(y){this.log.error("error closing wt session",y)}finally{a!=null&&(a.timeline.close=Date.now()),f=!0}},i=()=>{c(u?"noise_timeout":"ready_timeout")},e.signal.addEventListener("abort",i,{once:!0}),this.log("wait for session to be ready"),e.onProgress?.(new qe("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(x=>{this.log.error("error on remote wt session close",x)}).finally(()=>{c("remote_close")}),l=await wt(this.authenticateWebTransport({wt:p,remotePeer:s,certhashes:o,...e}),e.signal),!l)throw new ze("Failed to authenticate webtransport");return this.metrics?.dialerEvents.increment({open:!0}),a={close:async()=>{this.log("closing webtransport"),c("close")},abort:x=>{this.log("aborting webtransport due to passed err",x),c("abort")},remoteAddr:t,timeline:{open:Date.now()},log:this.components.logger.forComponent("libp2p:webtransport:maconn"),...lo()},await e.upgrader.upgradeOutbound(a,{...e,skipEncryption:!0,muxerFactory:Uu(p,p.incomingBidirectionalStreams.getReader(),this.components.logger,this.config),skipProtection:!0})}catch(p){throw this.log.error("caught wt session err",p),c(l?"upgrade_error":u?"noise_error":"ready_error"),p}finally{i!=null&&e.signal?.removeEventListener("abort",i)}}async authenticateWebTransport({wt:t,remotePeer:e,certhashes:n,onProgress:o,signal:s}){s?.throwIfAborted(),o?.(new qe("webtransport:open-authentication-stream"));let i=await t.createBidirectionalStream(),a=i.writable.getWriter(),c=i.readable.getReader(),f={source:async function*(){for(;;){let p=await c.read();if(p.value!=null&&(yield p.value),p.done)break}}(),sink:async p=>{for await(let x of p){await wt(a.ready,s);let y=x instanceof Uint8Array?x:x.subarray();a.write(y).catch(m=>{this.log.error("could not write chunk during authentication of WebTransport stream",m)})}}},u=Eu()(this.components);o?.(new qe("webtransport:secure-outbound-connection"));let{remoteExtensions:l}=await u.secureOutbound(f,{signal:s,remotePeer:e,skipStreamMuxerNegotiation:!0});if(o?.(new qe("webtransport:close-authentication-stream")),a.close().catch(p=>{this.log.error(`Failed to close authentication stream writer: ${p.message}`)}),c.cancel().catch(p=>{this.log.error(`Failed to close authentication stream reader: ${p.message}`)}),!ku(l?.webtransportCerthashes??[],n.map(p=>p.bytes)))throw new at("Our certhashes are not a subset of the remote's reported certhashes");return!0}createListener(t){return Bi(this.components,{...t,certificates:this.config.certificates,maxInboundStreams:this.config.maxInboundStreams})}listenFilter(){return[]}dialFilter(t){return globalThis.WebTransport==null?[]:t.filter(e=>{if(!uo.exactMatch(e))return!1;let{url:n,certhashes:o}=zi(e);return n!=null&&o.length>0})}};function Hd(r={}){return t=>new Fi(t,r)}return tf(Vd);})();
2
+ "use strict";var Libp2PWebtransport=(()=>{var _o=Object.defineProperty;var ru=Object.getOwnPropertyDescriptor;var nu=Object.getOwnPropertyNames;var ou=Object.prototype.hasOwnProperty;var vt=(e,t)=>{for(var r in t)_o(e,r,{get:t[r],enumerable:!0})},su=(e,t,r,n)=>{if(t&&typeof t=="object"||typeof t=="function")for(let o of nu(t))!ou.call(e,o)&&o!==r&&_o(e,o,{get:()=>t[o],enumerable:!(n=ru(t,o))||n.enumerable});return e};var iu=e=>su(_o({},"__esModule",{value:!0}),e);var Ap={};vt(Ap,{webTransport:()=>Sp});var Io=Symbol.for("@libp2p/peer-id");var Zi=Symbol.for("@libp2p/transport");var ji;(function(e){e[e.FATAL_ALL=0]="FATAL_ALL",e[e.NO_FATAL=1]="NO_FATAL"})(ji||(ji={}));var sn=class extends Error{static name="UnexpectedPeerError";constructor(t="Unexpected Peer"){super(t),this.name="UnexpectedPeerError"}},He=class extends Error{static name="InvalidCryptoExchangeError";constructor(t="Invalid crypto exchange"){super(t),this.name="InvalidCryptoExchangeError"}},nt=class extends Error{static name="InvalidParametersError";constructor(t="Invalid parameters"){super(t),this.name="InvalidParametersError"}},Ve=class extends Error{static name="InvalidPublicKeyError";constructor(t="Invalid public key"){super(t),this.name="InvalidPublicKeyError"}};var an=class extends Error{static name="StreamResetError";constructor(t="The stream has been reset"){super(t),this.name="StreamResetError"}},cn=class extends Error{static name="StreamStateError";constructor(t="The stream is in an invalid state"){super(t),this.name="StreamStateError"}};var fn=class extends Error{static name="InvalidMultiaddrError";constructor(t="Invalid multiaddr"){super(t),this.name="InvalidMultiaddrError"}},un=class extends Error{static name="InvalidCIDError";constructor(t="Invalid CID"){super(t),this.name="InvalidCIDError"}},ln=class extends Error{static name="InvalidMultihashError";constructor(t="Invalid Multihash"){super(t),this.name="InvalidMultihashError"}};var ge=class extends Error{static name="UnsupportedKeyTypeError";constructor(t="Unsupported key type"){super(t),this.name="UnsupportedKeyTypeError"}};var hn=Symbol.for("@libp2p/service-capabilities"),Bp=Symbol.for("@libp2p/service-dependencies");var Do={};vt(Do,{base58btc:()=>J,base58flickr:()=>du});var Yp=new Uint8Array(0);function Yi(e,t){if(e===t)return!0;if(e.byteLength!==t.byteLength)return!1;for(let r=0;r<e.byteLength;r++)if(e[r]!==t[r])return!1;return!0}function Zt(e){if(e instanceof Uint8Array&&e.constructor.name==="Uint8Array")return e;if(e instanceof ArrayBuffer)return new Uint8Array(e);if(ArrayBuffer.isView(e))return new Uint8Array(e.buffer,e.byteOffset,e.byteLength);throw new Error("Unknown type, must be binary type")}function Xi(e){return new TextEncoder().encode(e)}function Ji(e){return new TextDecoder().decode(e)}function au(e,t){if(e.length>=255)throw new TypeError("Alphabet too long");for(var r=new Uint8Array(256),n=0;n<r.length;n++)r[n]=255;for(var o=0;o<e.length;o++){var s=e.charAt(o),i=s.charCodeAt(0);if(r[i]!==255)throw new TypeError(s+" is ambiguous");r[i]=o}var a=e.length,c=e.charAt(0),u=Math.log(a)/Math.log(256),f=Math.log(256)/Math.log(a);function l(x){if(x instanceof Uint8Array||(ArrayBuffer.isView(x)?x=new Uint8Array(x.buffer,x.byteOffset,x.byteLength):Array.isArray(x)&&(x=Uint8Array.from(x))),!(x instanceof Uint8Array))throw new TypeError("Expected Uint8Array");if(x.length===0)return"";for(var g=0,h=0,E=0,C=x.length;E!==C&&x[E]===0;)E++,g++;for(var I=(C-E)*f+1>>>0,N=new Uint8Array(I);E!==C;){for(var S=x[E],R=0,L=I-1;(S!==0||R<h)&&L!==-1;L--,R++)S+=256*N[L]>>>0,N[L]=S%a>>>0,S=S/a>>>0;if(S!==0)throw new Error("Non-zero carry");h=R,E++}for(var T=I-h;T!==I&&N[T]===0;)T++;for(var d=c.repeat(g);T<I;++T)d+=e.charAt(N[T]);return d}function p(x){if(typeof x!="string")throw new TypeError("Expected String");if(x.length===0)return new Uint8Array;var g=0;if(x[g]!==" "){for(var h=0,E=0;x[g]===c;)h++,g++;for(var C=(x.length-g)*u+1>>>0,I=new Uint8Array(C);x[g];){var N=r[x.charCodeAt(g)];if(N===255)return;for(var S=0,R=C-1;(N!==0||S<E)&&R!==-1;R--,S++)N+=a*I[R]>>>0,I[R]=N%256>>>0,N=N/256>>>0;if(N!==0)throw new Error("Non-zero carry");E=S,g++}if(x[g]!==" "){for(var L=C-E;L!==C&&I[L]===0;)L++;for(var T=new Uint8Array(h+(C-L)),d=h;L!==C;)T[d++]=I[L++];return T}}}function m(x){var g=p(x);if(g)return g;throw new Error(`Non-${t} character`)}return{encode:l,decodeUnsafe:p,decode:m}}var cu=au,fu=cu,ta=fu;var Co=class{name;prefix;baseEncode;constructor(t,r,n){this.name=t,this.prefix=r,this.baseEncode=n}encode(t){if(t instanceof Uint8Array)return`${this.prefix}${this.baseEncode(t)}`;throw Error("Unknown type, must be binary type")}},Bo=class{name;prefix;baseDecode;prefixCodePoint;constructor(t,r,n){this.name=t,this.prefix=r;let o=r.codePointAt(0);if(o===void 0)throw new Error("Invalid prefix character");this.prefixCodePoint=o,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 ea(this,t)}},To=class{decoders;constructor(t){this.decoders=t}or(t){return ea(this,t)}decode(t){let r=t[0],n=this.decoders[r];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 ea(e,t){return new To({...e.decoders??{[e.prefix]:e},...t.decoders??{[t.prefix]:t}})}var Lo=class{name;prefix;baseEncode;baseDecode;encoder;decoder;constructor(t,r,n,o){this.name=t,this.prefix=r,this.baseEncode=n,this.baseDecode=o,this.encoder=new Co(t,r,n),this.decoder=new Bo(t,r,o)}encode(t){return this.encoder.encode(t)}decode(t){return this.decoder.decode(t)}};function qe({name:e,prefix:t,encode:r,decode:n}){return new Lo(e,t,r,n)}function ie({name:e,prefix:t,alphabet:r}){let{encode:n,decode:o}=ta(r,e);return qe({prefix:t,name:e,encode:n,decode:s=>Zt(o(s))})}function uu(e,t,r,n){let o=e.length;for(;e[o-1]==="=";)--o;let s=new Uint8Array(o*r/8|0),i=0,a=0,c=0;for(let u=0;u<o;++u){let f=t[e[u]];if(f===void 0)throw new SyntaxError(`Non-${n} character`);a=a<<r|f,i+=r,i>=8&&(i-=8,s[c++]=255&a>>i)}if(i>=r||(255&a<<8-i)!==0)throw new SyntaxError("Unexpected end of data");return s}function lu(e,t,r){let n=t[t.length-1]==="=",o=(1<<r)-1,s="",i=0,a=0;for(let c=0;c<e.length;++c)for(a=a<<8|e[c],i+=8;i>r;)i-=r,s+=t[o&a>>i];if(i!==0&&(s+=t[o&a<<r-i]),n)for(;(s.length*r&7)!==0;)s+="=";return s}function hu(e){let t={};for(let r=0;r<e.length;++r)t[e[r]]=r;return t}function ot({name:e,prefix:t,bitsPerChar:r,alphabet:n}){let o=hu(n);return qe({prefix:t,name:e,encode(s){return lu(s,n,r)},decode(s){return uu(s,o,r,e)}})}var J=ie({name:"base58btc",prefix:"z",alphabet:"123456789ABCDEFGHJKLMNPQRSTUVWXYZabcdefghijkmnopqrstuvwxyz"}),du=ie({name:"base58flickr",prefix:"Z",alphabet:"123456789abcdefghijkmnopqrstuvwxyzABCDEFGHJKLMNPQRSTUVWXYZ"});var Po={};vt(Po,{base32:()=>ae,base32hex:()=>gu,base32hexpad:()=>bu,base32hexpadupper:()=>wu,base32hexupper:()=>xu,base32pad:()=>mu,base32padupper:()=>yu,base32upper:()=>pu,base32z:()=>Eu});var ae=ot({prefix:"b",name:"base32",alphabet:"abcdefghijklmnopqrstuvwxyz234567",bitsPerChar:5}),pu=ot({prefix:"B",name:"base32upper",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZ234567",bitsPerChar:5}),mu=ot({prefix:"c",name:"base32pad",alphabet:"abcdefghijklmnopqrstuvwxyz234567=",bitsPerChar:5}),yu=ot({prefix:"C",name:"base32padupper",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZ234567=",bitsPerChar:5}),gu=ot({prefix:"v",name:"base32hex",alphabet:"0123456789abcdefghijklmnopqrstuv",bitsPerChar:5}),xu=ot({prefix:"V",name:"base32hexupper",alphabet:"0123456789ABCDEFGHIJKLMNOPQRSTUV",bitsPerChar:5}),bu=ot({prefix:"t",name:"base32hexpad",alphabet:"0123456789abcdefghijklmnopqrstuv=",bitsPerChar:5}),wu=ot({prefix:"T",name:"base32hexpadupper",alphabet:"0123456789ABCDEFGHIJKLMNOPQRSTUV=",bitsPerChar:5}),Eu=ot({prefix:"h",name:"base32z",alphabet:"ybndrfg8ejkmcpqxot1uwisza345h769",bitsPerChar:5});var Ro={};vt(Ro,{base36:()=>gr,base36upper:()=>Su});var gr=ie({prefix:"k",name:"base36",alphabet:"0123456789abcdefghijklmnopqrstuvwxyz"}),Su=ie({prefix:"K",name:"base36upper",alphabet:"0123456789ABCDEFGHIJKLMNOPQRSTUVWXYZ"});var Yt={};vt(Yt,{Digest:()=>xe,create:()=>Rt,decode:()=>Ge,equals:()=>No,hasCode:()=>Vu});var Au=oa,ra=128,vu=127,_u=~vu,Iu=Math.pow(2,31);function oa(e,t,r){t=t||[],r=r||0;for(var n=r;e>=Iu;)t[r++]=e&255|ra,e/=128;for(;e&_u;)t[r++]=e&255|ra,e>>>=7;return t[r]=e|0,oa.bytes=r-n+1,t}var Cu=Uo,Bu=128,na=127;function Uo(e,n){var r=0,n=n||0,o=0,s=n,i,a=e.length;do{if(s>=a)throw Uo.bytes=0,new RangeError("Could not decode varint");i=e[s++],r+=o<28?(i&na)<<o:(i&na)*Math.pow(2,o),o+=7}while(i>=Bu);return Uo.bytes=s-n,r}var Tu=Math.pow(2,7),Lu=Math.pow(2,14),Du=Math.pow(2,21),Pu=Math.pow(2,28),Ru=Math.pow(2,35),Uu=Math.pow(2,42),Nu=Math.pow(2,49),ku=Math.pow(2,56),Ou=Math.pow(2,63),Ku=function(e){return e<Tu?1:e<Lu?2:e<Du?3:e<Pu?4:e<Ru?5:e<Uu?6:e<Nu?7:e<ku?8:e<Ou?9:10},Mu={encode:Au,decode:Cu,encodingLength:Ku},Hu=Mu,xr=Hu;function br(e,t=0){return[xr.decode(e,t),xr.decode.bytes]}function ze(e,t,r=0){return xr.encode(e,t,r),t}function Fe(e){return xr.encodingLength(e)}function Rt(e,t){let r=t.byteLength,n=Fe(e),o=n+Fe(r),s=new Uint8Array(o+r);return ze(e,s,0),ze(r,s,n),s.set(t,o),new xe(e,r,t,s)}function Ge(e){let t=Zt(e),[r,n]=br(t),[o,s]=br(t.subarray(n)),i=t.subarray(n+s);if(i.byteLength!==o)throw new Error("Incorrect length");return new xe(r,o,i,t)}function No(e,t){if(e===t)return!0;{let r=t;return e.code===r.code&&e.size===r.size&&r.bytes instanceof Uint8Array&&Yi(e.bytes,r.bytes)}}var xe=class{code;size;digest;bytes;constructor(t,r,n,o){this.code=t,this.size=r,this.digest=n,this.bytes=o}};function Vu(e,t){return e.code===t}function sa(e,t){let{bytes:r,version:n}=e;switch(n){case 0:return zu(r,ko(e),t??J.encoder);default:return Fu(r,ko(e),t??ae.encoder)}}var ia=new WeakMap;function ko(e){let t=ia.get(e);if(t==null){let r=new Map;return ia.set(e,r),r}return t}var st=class e{code;version;multihash;bytes;"/";constructor(t,r,n,o){this.code=r,this.version=t,this.multihash=n,this.bytes=o,this["/"]=o}get asCID(){return this}get byteOffset(){return this.bytes.byteOffset}get byteLength(){return this.bytes.byteLength}toV0(){switch(this.version){case 0:return this;case 1:{let{code:t,multihash:r}=this;if(t!==wr)throw new Error("Cannot convert a non dag-pb CID to CIDv0");if(r.code!==Gu)throw new Error("Cannot convert non sha2-256 multihash CID to CIDv0");return e.createV0(r)}default:throw Error(`Can not convert CID version ${this.version} to version 0. This is a bug please report`)}}toV1(){switch(this.version){case 0:{let{code:t,digest:r}=this.multihash,n=Rt(t,r);return e.createV1(this.code,n)}case 1:return this;default:throw Error(`Can not convert CID version ${this.version} to version 1. This is a bug please report`)}}equals(t){return e.equals(this,t)}static equals(t,r){let n=r;return n!=null&&t.code===n.code&&t.version===n.version&&No(t.multihash,n.multihash)}toString(t){return sa(this,t)}toJSON(){return{"/":sa(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 r=t;if(r instanceof e)return r;if(r["/"]!=null&&r["/"]===r.bytes||r.asCID===r){let{version:n,code:o,multihash:s,bytes:i}=r;return new e(n,o,s,i??aa(n,o,s.bytes))}else if(r[Wu]===!0){let{version:n,multihash:o,code:s}=r,i=Ge(o);return e.create(n,s,i)}else return null}static create(t,r,n){if(typeof r!="number")throw new Error("String codecs are no longer supported");if(!(n.bytes instanceof Uint8Array))throw new Error("Invalid digest");switch(t){case 0:{if(r!==wr)throw new Error(`Version 0 CID must use dag-pb (code: ${wr}) block encoding`);return new e(t,r,n,n.bytes)}case 1:{let o=aa(t,r,n.bytes);return new e(t,r,n,o)}default:throw new Error("Invalid version")}}static createV0(t){return e.create(0,wr,t)}static createV1(t,r){return e.create(1,t,r)}static decode(t){let[r,n]=e.decodeFirst(t);if(n.length!==0)throw new Error("Incorrect length");return r}static decodeFirst(t){let r=e.inspectBytes(t),n=r.size-r.multihashSize,o=Zt(t.subarray(n,n+r.multihashSize));if(o.byteLength!==r.multihashSize)throw new Error("Incorrect length");let s=o.subarray(r.multihashSize-r.digestSize),i=new xe(r.multihashCode,r.digestSize,s,o);return[r.version===0?e.createV0(i):e.createV1(r.codec,i),t.subarray(r.size)]}static inspectBytes(t){let r=0,n=()=>{let[l,p]=br(t.subarray(r));return r+=p,l},o=n(),s=wr;if(o===18?(o=0,r=0):s=n(),o!==0&&o!==1)throw new RangeError(`Invalid CID version ${o}`);let i=r,a=n(),c=n(),u=r+c,f=u-i;return{version:o,codec:s,multihashCode:a,digestSize:c,multihashSize:f,size:u}}static parse(t,r){let[n,o]=qu(t,r),s=e.decode(o);if(s.version===0&&t[0]!=="Q")throw Error("Version 0 CID string must not include multibase prefix");return ko(s).set(n,t),s}};function qu(e,t){switch(e[0]){case"Q":{let r=t??J;return[J.prefix,r.decode(`${J.prefix}${e}`)]}case J.prefix:{let r=t??J;return[J.prefix,r.decode(e)]}case ae.prefix:{let r=t??ae;return[ae.prefix,r.decode(e)]}case gr.prefix:{let r=t??gr;return[gr.prefix,r.decode(e)]}default:{if(t==null)throw Error("To parse non base32, base36 or base58btc encoded CID multibase decoder must be provided");return[e[0],t.decode(e)]}}}function zu(e,t,r){let{prefix:n}=r;if(n!==J.prefix)throw Error(`Cannot string encode V0 in ${r.name} encoding`);let o=t.get(n);if(o==null){let s=r.encode(e).slice(1);return t.set(n,s),s}else return o}function Fu(e,t,r){let{prefix:n}=r,o=t.get(n);if(o==null){let s=r.encode(e);return t.set(n,s),s}else return o}var wr=112,Gu=18;function aa(e,t,r){let n=Fe(e),o=n+Fe(t),s=new Uint8Array(o+r.byteLength);return ze(e,s,0),ze(t,s,n),s.set(r,o),s}var Wu=Symbol.for("@ipld/js-cid/CID");var Oo={};vt(Oo,{identity:()=>kt});var ca=0,$u="identity",fa=Zt;function ju(e){return Rt(ca,fa(e))}var kt={code:ca,name:$u,encode:fa,digest:ju};function at(e,t){if(e===t)return!0;if(e.byteLength!==t.byteLength)return!1;for(let r=0;r<e.byteLength;r++)if(e[r]!==t[r])return!1;return!0}function ct(e=0){return new Uint8Array(e)}function ft(e=0){return new Uint8Array(e)}function Ut(e,t){t==null&&(t=e.reduce((o,s)=>o+s.length,0));let r=ft(t),n=0;for(let o of e)r.set(o,n),n+=o.length;return r}var la=Symbol.for("@achingbrain/uint8arraylist");function ua(e,t){if(t==null||t<0)throw new RangeError("index is out of bounds");let r=0;for(let n of e){let o=r+n.byteLength;if(t<o)return{buf:n,index:t-r};r=o}throw new RangeError("index is out of bounds")}function pn(e){return!!e?.[la]}var F=class e{bufs;length;[la]=!0;constructor(...t){this.bufs=[],this.length=0,t.length>0&&this.appendAll(t)}*[Symbol.iterator](){yield*this.bufs}get byteLength(){return this.length}append(...t){this.appendAll(t)}appendAll(t){let r=0;for(let n of t)if(n instanceof Uint8Array)r+=n.byteLength,this.bufs.push(n);else if(pn(n))r+=n.byteLength,this.bufs.push(...n.bufs);else throw new Error("Could not append value, must be an Uint8Array or a Uint8ArrayList");this.length+=r}prepend(...t){this.prependAll(t)}prependAll(t){let r=0;for(let n of t.reverse())if(n instanceof Uint8Array)r+=n.byteLength,this.bufs.unshift(n);else if(pn(n))r+=n.byteLength,this.bufs.unshift(...n.bufs);else throw new Error("Could not prepend value, must be an Uint8Array or a Uint8ArrayList");this.length+=r}get(t){let r=ua(this.bufs,t);return r.buf[r.index]}set(t,r){let n=ua(this.bufs,t);n.buf[n.index]=r}write(t,r=0){if(t instanceof Uint8Array)for(let n=0;n<t.length;n++)this.set(r+n,t[n]);else if(pn(t))for(let n=0;n<t.length;n++)this.set(r+n,t.get(n));else throw new Error("Could not write value, must be an Uint8Array or a Uint8ArrayList")}consume(t){if(t=Math.trunc(t),!(Number.isNaN(t)||t<=0)){if(t===this.byteLength){this.bufs=[],this.length=0;return}for(;this.bufs.length>0;)if(t>=this.bufs[0].byteLength)t-=this.bufs[0].byteLength,this.length-=this.bufs[0].byteLength,this.bufs.shift();else{this.bufs[0]=this.bufs[0].subarray(t),this.length-=t;break}}}slice(t,r){let{bufs:n,length:o}=this._subList(t,r);return Ut(n,o)}subarray(t,r){let{bufs:n,length:o}=this._subList(t,r);return n.length===1?n[0]:Ut(n,o)}sublist(t,r){let{bufs:n,length:o}=this._subList(t,r),s=new e;return s.length=o,s.bufs=[...n],s}_subList(t,r){if(t=t??0,r=r??this.length,t<0&&(t=this.length+t),r<0&&(r=this.length+r),t<0||r>this.length)throw new RangeError("index is out of bounds");if(t===r)return{bufs:[],length:0};if(t===0&&r===this.length)return{bufs:this.bufs,length:this.length};let n=[],o=0;for(let s=0;s<this.bufs.length;s++){let i=this.bufs[s],a=o,c=a+i.byteLength;if(o=c,t>=c)continue;let u=t>=a&&t<c,f=r>a&&r<=c;if(u&&f){if(t===a&&r===c){n.push(i);break}let l=t-a;n.push(i.subarray(l,l+(r-t)));break}if(u){if(t===0){n.push(i);continue}n.push(i.subarray(t-a));continue}if(f){if(r===c){n.push(i);break}n.push(i.subarray(0,r-a));break}n.push(i)}return{bufs:n,length:r-t}}indexOf(t,r=0){if(!pn(t)&&!(t instanceof Uint8Array))throw new TypeError('The "value" argument must be a Uint8ArrayList or Uint8Array');let n=t instanceof Uint8Array?t:t.subarray();if(r=Number(r??0),isNaN(r)&&(r=0),r<0&&(r=this.length+r),r<0&&(r=0),t.length===0)return r>this.length?this.length:r;let o=n.byteLength;if(o===0)throw new TypeError("search must be at least 1 byte long");let s=256,i=new Int32Array(s);for(let l=0;l<s;l++)i[l]=-1;for(let l=0;l<o;l++)i[n[l]]=l;let a=i,c=this.byteLength-n.byteLength,u=n.byteLength-1,f;for(let l=r;l<=c;l+=f){f=0;for(let p=u;p>=0;p--){let m=this.get(l+p);if(n[p]!==m){f=Math.max(1,p-a[m]);break}}if(f===0)return l}return-1}getInt8(t){let r=this.subarray(t,t+1);return new DataView(r.buffer,r.byteOffset,r.byteLength).getInt8(0)}setInt8(t,r){let n=ft(1);new DataView(n.buffer,n.byteOffset,n.byteLength).setInt8(0,r),this.write(n,t)}getInt16(t,r){let n=this.subarray(t,t+2);return new DataView(n.buffer,n.byteOffset,n.byteLength).getInt16(0,r)}setInt16(t,r,n){let o=ct(2);new DataView(o.buffer,o.byteOffset,o.byteLength).setInt16(0,r,n),this.write(o,t)}getInt32(t,r){let n=this.subarray(t,t+4);return new DataView(n.buffer,n.byteOffset,n.byteLength).getInt32(0,r)}setInt32(t,r,n){let o=ct(4);new DataView(o.buffer,o.byteOffset,o.byteLength).setInt32(0,r,n),this.write(o,t)}getBigInt64(t,r){let n=this.subarray(t,t+8);return new DataView(n.buffer,n.byteOffset,n.byteLength).getBigInt64(0,r)}setBigInt64(t,r,n){let o=ct(8);new DataView(o.buffer,o.byteOffset,o.byteLength).setBigInt64(0,r,n),this.write(o,t)}getUint8(t){let r=this.subarray(t,t+1);return new DataView(r.buffer,r.byteOffset,r.byteLength).getUint8(0)}setUint8(t,r){let n=ft(1);new DataView(n.buffer,n.byteOffset,n.byteLength).setUint8(0,r),this.write(n,t)}getUint16(t,r){let n=this.subarray(t,t+2);return new DataView(n.buffer,n.byteOffset,n.byteLength).getUint16(0,r)}setUint16(t,r,n){let o=ct(2);new DataView(o.buffer,o.byteOffset,o.byteLength).setUint16(0,r,n),this.write(o,t)}getUint32(t,r){let n=this.subarray(t,t+4);return new DataView(n.buffer,n.byteOffset,n.byteLength).getUint32(0,r)}setUint32(t,r,n){let o=ct(4);new DataView(o.buffer,o.byteOffset,o.byteLength).setUint32(0,r,n),this.write(o,t)}getBigUint64(t,r){let n=this.subarray(t,t+8);return new DataView(n.buffer,n.byteOffset,n.byteLength).getBigUint64(0,r)}setBigUint64(t,r,n){let o=ct(8);new DataView(o.buffer,o.byteOffset,o.byteLength).setBigUint64(0,r,n),this.write(o,t)}getFloat32(t,r){let n=this.subarray(t,t+4);return new DataView(n.buffer,n.byteOffset,n.byteLength).getFloat32(0,r)}setFloat32(t,r,n){let o=ct(4);new DataView(o.buffer,o.byteOffset,o.byteLength).setFloat32(0,r,n),this.write(o,t)}getFloat64(t,r){let n=this.subarray(t,t+8);return new DataView(n.buffer,n.byteOffset,n.byteLength).getFloat64(0,r)}setFloat64(t,r,n){let o=ct(8);new DataView(o.buffer,o.byteOffset,o.byteLength).setFloat64(0,r,n),this.write(o,t)}equals(t){if(t==null||!(t instanceof e)||t.bufs.length!==this.bufs.length)return!1;for(let r=0;r<this.bufs.length;r++)if(!at(this.bufs[r],t.bufs[r]))return!1;return!0}static fromUint8Arrays(t,r){let n=new e;return n.bufs=t,r==null&&(r=t.reduce((o,s)=>o+s.byteLength,0)),n.length=r,n}};var Ko={};vt(Ko,{base10:()=>Yu});var Yu=ie({prefix:"9",name:"base10",alphabet:"0123456789"});var Mo={};vt(Mo,{base16:()=>Xu,base16upper:()=>Ju});var Xu=ot({prefix:"f",name:"base16",alphabet:"0123456789abcdef",bitsPerChar:4}),Ju=ot({prefix:"F",name:"base16upper",alphabet:"0123456789ABCDEF",bitsPerChar:4});var Ho={};vt(Ho,{base2:()=>Qu});var Qu=ot({prefix:"0",name:"base2",alphabet:"01",bitsPerChar:1});var Vo={};vt(Vo,{base256emoji:()=>ol});var ha=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}"),tl=ha.reduce((e,t,r)=>(e[r]=t,e),[]),el=ha.reduce((e,t,r)=>{let n=t.codePointAt(0);if(n==null)throw new Error(`Invalid character: ${t}`);return e[n]=r,e},[]);function rl(e){return e.reduce((t,r)=>(t+=tl[r],t),"")}function nl(e){let t=[];for(let r of e){let n=r.codePointAt(0);if(n==null)throw new Error(`Invalid character: ${r}`);let o=el[n];if(o==null)throw new Error(`Non-base256emoji character: ${r}`);t.push(o)}return new Uint8Array(t)}var ol=qe({prefix:"\u{1F680}",name:"base256emoji",encode:rl,decode:nl});var qo={};vt(qo,{base64:()=>sl,base64pad:()=>il,base64url:()=>Er,base64urlpad:()=>al});var sl=ot({prefix:"m",name:"base64",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/",bitsPerChar:6}),il=ot({prefix:"M",name:"base64pad",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/=",bitsPerChar:6}),Er=ot({prefix:"u",name:"base64url",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789-_",bitsPerChar:6}),al=ot({prefix:"U",name:"base64urlpad",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789-_=",bitsPerChar:6});var zo={};vt(zo,{base8:()=>cl});var cl=ot({prefix:"7",name:"base8",alphabet:"01234567",bitsPerChar:3});var Fo={};vt(Fo,{identity:()=>fl});var fl=qe({prefix:"\0",name:"identity",encode:e=>Ji(e),decode:e=>Xi(e)});var Pm=new TextEncoder,Rm=new TextDecoder;var $o={};vt($o,{sha256:()=>Sr,sha512:()=>hl});function Wo({name:e,code:t,encode:r}){return new Go(e,t,r)}var Go=class{name;code;encode;constructor(t,r,n){this.name=t,this.code=r,this.encode=n}digest(t){if(t instanceof Uint8Array){let r=this.encode(t);return r instanceof Uint8Array?Rt(this.code,r):r.then(n=>Rt(this.code,n))}else throw Error("Unknown type, must be binary type")}};function pa(e){return async t=>new Uint8Array(await crypto.subtle.digest(e,t))}var Sr=Wo({name:"sha2-256",code:18,encode:pa("SHA-256")}),hl=Wo({name:"sha2-512",code:19,encode:pa("SHA-512")});var be={...Fo,...Ho,...zo,...Ko,...Mo,...Po,...Ro,...Do,...qo,...Vo},Gm={...$o,...Oo};function ya(e,t,r,n){return{name:e,prefix:t,encoder:{name:e,prefix:t,encode:r},decoder:{decode:n}}}var ma=ya("utf8","u",e=>"u"+new TextDecoder("utf8").decode(e),e=>new TextEncoder().encode(e.substring(1))),jo=ya("ascii","a",e=>{let t="a";for(let r=0;r<e.length;r++)t+=String.fromCharCode(e[r]);return t},e=>{e=e.substring(1);let t=ft(e.length);for(let r=0;r<e.length;r++)t[r]=e.charCodeAt(r);return t}),dl={utf8:ma,"utf-8":ma,hex:be.base16,latin1:jo,ascii:jo,binary:jo,...be},mn=dl;function G(e,t="utf8"){let r=mn[t];if(r==null)throw new Error(`Unsupported encoding "${t}"`);return r.decoder.decode(`${r.prefix}${e}`)}function H(e,t="utf8"){let r=mn[t];if(r==null)throw new Error(`Unsupported encoding "${t}"`);return r.encoder.encode(e).substring(1)}var pl=parseInt("11111",2),Zo=parseInt("10000000",2),ml=parseInt("01111111",2),ga={0:Ar,1:Ar,2:yl,3:bl,4:wl,5:xl,6:gl,16:Ar,22:Ar,48:Ar};function Xt(e,t={offset:0}){let r=e[t.offset]&pl;if(t.offset++,ga[r]!=null)return ga[r](e,t);throw new Error("No decoder for tag "+r)}function vr(e,t){let r=0;if((e[t.offset]&Zo)===Zo){let n=e[t.offset]&ml,o="0x";t.offset++;for(let s=0;s<n;s++,t.offset++)o+=e[t.offset].toString(16).padStart(2,"0");r=parseInt(o,16)}else r=e[t.offset],t.offset++;return r}function Ar(e,t){vr(e,t);let r=[];for(;!(t.offset>=e.byteLength);){let n=Xt(e,t);if(n===null)break;r.push(n)}return r}function yl(e,t){let r=vr(e,t),n=t.offset,o=t.offset+r,s=[];for(let i=n;i<o;i++)i===n&&e[i]===0||s.push(e[i]);return t.offset+=r,Uint8Array.from(s)}function gl(e,t){let r=vr(e,t),n=t.offset+r,o=e[t.offset];t.offset++;let s=0,i=0;o<40?(s=0,i=o):o<80?(s=1,i=o-40):(s=2,i=o-80);let a=`${s}.${i}`,c=[];for(;t.offset<n;){let u=e[t.offset];if(t.offset++,c.push(u&127),u<128){c.reverse();let f=0;for(let l=0;l<c.length;l++)f+=c[l]<<l*7;a+=`.${f}`,c=[]}}return a}function xl(e,t){return t.offset++,null}function bl(e,t){let r=vr(e,t),n=e[t.offset];t.offset++;let o=e.subarray(t.offset,t.offset+r-1);if(t.offset+=r,n!==0)throw new Error("Unused bits in bit string is unimplemented");return o}function wl(e,t){let r=vr(e,t),n=e.subarray(t.offset,t.offset+r);return t.offset+=r,n}function El(e){let t=e.toString(16);t.length%2===1&&(t="0"+t);let r=new F;for(let n=0;n<t.length;n+=2)r.append(Uint8Array.from([parseInt(`${t[n]}${t[n+1]}`,16)]));return r}function Yo(e){if(e.byteLength<128)return Uint8Array.from([e.byteLength]);let t=El(e.byteLength);return new F(Uint8Array.from([t.byteLength|Zo]),t)}function Tt(e){let t=new F,r=128;return(e.subarray()[0]&r)===r&&t.append(Uint8Array.from([0])),t.append(e),new F(Uint8Array.from([2]),Yo(t),t)}function yn(e){let t=Uint8Array.from([0]),r=new F(t,e);return new F(Uint8Array.from([3]),Yo(r),r)}function ce(e,t=48){let r=new F;for(let n of e)r.append(n);return new F(Uint8Array.from([t]),Yo(r),r)}async function xa(e,t,r,n){let o=await crypto.subtle.importKey("jwk",e,{name:"ECDSA",namedCurve:e.crv??"P-256"},!1,["verify"]);n?.signal?.throwIfAborted();let s=await crypto.subtle.verify({name:"ECDSA",hash:{name:"SHA-256"}},o,t,r.subarray());return n?.signal?.throwIfAborted(),s}var Sl=Uint8Array.from([6,8,42,134,72,206,61,3,1,7]),Al=Uint8Array.from([6,5,43,129,4,0,34]),vl=Uint8Array.from([6,5,43,129,4,0,35]),_l={ext:!0,kty:"EC",crv:"P-256"},Il={ext:!0,kty:"EC",crv:"P-384"},Cl={ext:!0,kty:"EC",crv:"P-521"},Xo=32,Jo=48,Qo=66;function ts(e){let t=Xt(e);return ba(t)}function ba(e){let t=e[1][1][0],r=1,n,o;if(t.byteLength===Xo*2+1)return n=H(t.subarray(r,r+Xo),"base64url"),o=H(t.subarray(r+Xo),"base64url"),new We({..._l,key_ops:["verify"],x:n,y:o});if(t.byteLength===Jo*2+1)return n=H(t.subarray(r,r+Jo),"base64url"),o=H(t.subarray(r+Jo),"base64url"),new We({...Il,key_ops:["verify"],x:n,y:o});if(t.byteLength===Qo*2+1)return n=H(t.subarray(r,r+Qo),"base64url"),o=H(t.subarray(r+Qo),"base64url"),new We({...Cl,key_ops:["verify"],x:n,y:o});throw new nt(`coordinates were wrong length, got ${t.byteLength}, expected 65, 97 or 133`)}function wa(e){return ce([Tt(Uint8Array.from([1])),ce([Bl(e.crv)],160),ce([yn(new F(Uint8Array.from([4]),G(e.x??"","base64url"),G(e.y??"","base64url")))],161)]).subarray()}function Bl(e){if(e==="P-256")return Sl;if(e==="P-384")return Al;if(e==="P-521")return vl;throw new nt(`Invalid curve ${e}`)}var We=class{type="ECDSA";jwk;_raw;constructor(t){this.jwk=t}get raw(){return this._raw==null&&(this._raw=wa(this.jwk)),this._raw}toMultihash(){return kt.digest(fe(this))}toCID(){return st.createV1(114,this.toMultihash())}toString(){return J.encode(this.toMultihash().bytes).substring(1)}equals(t){return t==null||!(t.raw instanceof Uint8Array)?!1:at(this.raw,t.raw)}async verify(t,r,n){return xa(this.jwk,r,t,n)}};var we=typeof globalThis=="object"&&"crypto"in globalThis?globalThis.crypto:void 0;function je(e){return e instanceof Uint8Array||ArrayBuffer.isView(e)&&e.constructor.name==="Uint8Array"}function Ee(e){if(!Number.isSafeInteger(e)||e<0)throw new Error("positive integer expected, got "+e)}function bt(e,...t){if(!je(e))throw new Error("Uint8Array expected");if(t.length>0&&!t.includes(e.length))throw new Error("Uint8Array expected of length "+t+", got length="+e.length)}function _r(e){if(typeof e!="function"||typeof e.create!="function")throw new Error("Hash should be wrapped by utils.createHasher");Ee(e.outputLen),Ee(e.blockLen)}function Ze(e,t=!0){if(e.destroyed)throw new Error("Hash instance has been destroyed");if(t&&e.finished)throw new Error("Hash#digest() has already been called")}function Sa(e,t){bt(e);let r=t.outputLen;if(e.length<r)throw new Error("digestInto() expects output buffer of length at least "+r)}function Ot(...e){for(let t=0;t<e.length;t++)e[t].fill(0)}function gn(e){return new DataView(e.buffer,e.byteOffset,e.byteLength)}function Kt(e,t){return e<<32-t|e>>>t}var Aa=typeof Uint8Array.from([]).toHex=="function"&&typeof Uint8Array.fromHex=="function",Tl=Array.from({length:256},(e,t)=>t.toString(16).padStart(2,"0"));function qt(e){if(bt(e),Aa)return e.toHex();let t="";for(let r=0;r<e.length;r++)t+=Tl[e[r]];return t}var Jt={_0:48,_9:57,A:65,F:70,a:97,f:102};function Ea(e){if(e>=Jt._0&&e<=Jt._9)return e-Jt._0;if(e>=Jt.A&&e<=Jt.F)return e-(Jt.A-10);if(e>=Jt.a&&e<=Jt.f)return e-(Jt.a-10)}function Ye(e){if(typeof e!="string")throw new Error("hex string expected, got "+typeof e);if(Aa)return Uint8Array.fromHex(e);let t=e.length,r=t/2;if(t%2)throw new Error("hex string expected, got unpadded hex of length "+t);let n=new Uint8Array(r);for(let o=0,s=0;o<r;o++,s+=2){let i=Ea(e.charCodeAt(s)),a=Ea(e.charCodeAt(s+1));if(i===void 0||a===void 0){let c=e[s]+e[s+1];throw new Error('hex string expected, got non-hex character "'+c+'" at index '+s)}n[o]=i*16+a}return n}function va(e){if(typeof e!="string")throw new Error("string expected");return new Uint8Array(new TextEncoder().encode(e))}function ue(e){return typeof e=="string"&&(e=va(e)),bt(e),e}function Dt(...e){let t=0;for(let n=0;n<e.length;n++){let o=e[n];bt(o),t+=o.length}let r=new Uint8Array(t);for(let n=0,o=0;n<e.length;n++){let s=e[n];r.set(s,o),o+=s.length}return r}var $e=class{};function es(e){let t=n=>e().update(ue(n)).digest(),r=e();return t.outputLen=r.outputLen,t.blockLen=r.blockLen,t.create=()=>e(),t}function Se(e=32){if(we&&typeof we.getRandomValues=="function")return we.getRandomValues(new Uint8Array(e));if(we&&typeof we.randomBytes=="function")return Uint8Array.from(we.randomBytes(e));throw new Error("crypto.getRandomValues must be defined")}function Ll(e,t,r,n){if(typeof e.setBigUint64=="function")return e.setBigUint64(t,r,n);let o=BigInt(32),s=BigInt(4294967295),i=Number(r>>o&s),a=Number(r&s),c=n?4:0,u=n?0:4;e.setUint32(t+c,i,n),e.setUint32(t+u,a,n)}function _a(e,t,r){return e&t^~e&r}function Ia(e,t,r){return e&t^e&r^t&r}var Ir=class extends $e{constructor(t,r,n,o){super(),this.finished=!1,this.length=0,this.pos=0,this.destroyed=!1,this.blockLen=t,this.outputLen=r,this.padOffset=n,this.isLE=o,this.buffer=new Uint8Array(t),this.view=gn(this.buffer)}update(t){Ze(this),t=ue(t),bt(t);let{view:r,buffer:n,blockLen:o}=this,s=t.length;for(let i=0;i<s;){let a=Math.min(o-this.pos,s-i);if(a===o){let c=gn(t);for(;o<=s-i;i+=o)this.process(c,i);continue}n.set(t.subarray(i,i+a),this.pos),this.pos+=a,i+=a,this.pos===o&&(this.process(r,0),this.pos=0)}return this.length+=t.length,this.roundClean(),this}digestInto(t){Ze(this),Sa(t,this),this.finished=!0;let{buffer:r,view:n,blockLen:o,isLE:s}=this,{pos:i}=this;r[i++]=128,Ot(this.buffer.subarray(i)),this.padOffset>o-i&&(this.process(n,0),i=0);for(let l=i;l<o;l++)r[l]=0;Ll(n,o-8,BigInt(this.length*8),s),this.process(n,0);let a=gn(t),c=this.outputLen;if(c%4)throw new Error("_sha2: outputLen should be aligned to 32bit");let u=c/4,f=this.get();if(u>f.length)throw new Error("_sha2: outputLen bigger than state");for(let l=0;l<u;l++)a.setUint32(4*l,f[l],s)}digest(){let{buffer:t,outputLen:r}=this;this.digestInto(t);let n=t.slice(0,r);return this.destroy(),n}_cloneInto(t){t||(t=new this.constructor),t.set(...this.get());let{blockLen:r,buffer:n,length:o,finished:s,destroyed:i,pos:a}=this;return t.destroyed=i,t.finished=s,t.length=o,t.pos=a,o%r&&t.buffer.set(n),t}clone(){return this._cloneInto()}},Qt=Uint32Array.from([1779033703,3144134277,1013904242,2773480762,1359893119,2600822924,528734635,1541459225]);var pt=Uint32Array.from([1779033703,4089235720,3144134277,2227873595,1013904242,4271175723,2773480762,1595750129,1359893119,2917565137,2600822924,725511199,528734635,4215389547,1541459225,327033209]);var xn=BigInt(4294967295),Ca=BigInt(32);function Dl(e,t=!1){return t?{h:Number(e&xn),l:Number(e>>Ca&xn)}:{h:Number(e>>Ca&xn)|0,l:Number(e&xn)|0}}function Ba(e,t=!1){let r=e.length,n=new Uint32Array(r),o=new Uint32Array(r);for(let s=0;s<r;s++){let{h:i,l:a}=Dl(e[s],t);[n[s],o[s]]=[i,a]}return[n,o]}var rs=(e,t,r)=>e>>>r,ns=(e,t,r)=>e<<32-r|t>>>r,Ae=(e,t,r)=>e>>>r|t<<32-r,ve=(e,t,r)=>e<<32-r|t>>>r,Cr=(e,t,r)=>e<<64-r|t>>>r-32,Br=(e,t,r)=>e>>>r-32|t<<64-r;function zt(e,t,r,n){let o=(t>>>0)+(n>>>0);return{h:e+r+(o/2**32|0)|0,l:o|0}}var Ta=(e,t,r)=>(e>>>0)+(t>>>0)+(r>>>0),La=(e,t,r,n)=>t+r+n+(e/2**32|0)|0,Da=(e,t,r,n)=>(e>>>0)+(t>>>0)+(r>>>0)+(n>>>0),Pa=(e,t,r,n,o)=>t+r+n+o+(e/2**32|0)|0,Ra=(e,t,r,n,o)=>(e>>>0)+(t>>>0)+(r>>>0)+(n>>>0)+(o>>>0),Ua=(e,t,r,n,o,s)=>t+r+n+o+s+(e/2**32|0)|0;var Rl=Uint32Array.from([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]),le=new Uint32Array(64),bn=class extends Ir{constructor(t=32){super(64,t,8,!1),this.A=Qt[0]|0,this.B=Qt[1]|0,this.C=Qt[2]|0,this.D=Qt[3]|0,this.E=Qt[4]|0,this.F=Qt[5]|0,this.G=Qt[6]|0,this.H=Qt[7]|0}get(){let{A:t,B:r,C:n,D:o,E:s,F:i,G:a,H:c}=this;return[t,r,n,o,s,i,a,c]}set(t,r,n,o,s,i,a,c){this.A=t|0,this.B=r|0,this.C=n|0,this.D=o|0,this.E=s|0,this.F=i|0,this.G=a|0,this.H=c|0}process(t,r){for(let l=0;l<16;l++,r+=4)le[l]=t.getUint32(r,!1);for(let l=16;l<64;l++){let p=le[l-15],m=le[l-2],x=Kt(p,7)^Kt(p,18)^p>>>3,g=Kt(m,17)^Kt(m,19)^m>>>10;le[l]=g+le[l-7]+x+le[l-16]|0}let{A:n,B:o,C:s,D:i,E:a,F:c,G:u,H:f}=this;for(let l=0;l<64;l++){let p=Kt(a,6)^Kt(a,11)^Kt(a,25),m=f+p+_a(a,c,u)+Rl[l]+le[l]|0,g=(Kt(n,2)^Kt(n,13)^Kt(n,22))+Ia(n,o,s)|0;f=u,u=c,c=a,a=i+m|0,i=s,s=o,o=n,n=m+g|0}n=n+this.A|0,o=o+this.B|0,s=s+this.C|0,i=i+this.D|0,a=a+this.E|0,c=c+this.F|0,u=u+this.G|0,f=f+this.H|0,this.set(n,o,s,i,a,c,u,f)}roundClean(){Ot(le)}destroy(){this.set(0,0,0,0,0,0,0,0),Ot(this.buffer)}};var Na=Ba(["0x428a2f98d728ae22","0x7137449123ef65cd","0xb5c0fbcfec4d3b2f","0xe9b5dba58189dbbc","0x3956c25bf348b538","0x59f111f1b605d019","0x923f82a4af194f9b","0xab1c5ed5da6d8118","0xd807aa98a3030242","0x12835b0145706fbe","0x243185be4ee4b28c","0x550c7dc3d5ffb4e2","0x72be5d74f27b896f","0x80deb1fe3b1696b1","0x9bdc06a725c71235","0xc19bf174cf692694","0xe49b69c19ef14ad2","0xefbe4786384f25e3","0x0fc19dc68b8cd5b5","0x240ca1cc77ac9c65","0x2de92c6f592b0275","0x4a7484aa6ea6e483","0x5cb0a9dcbd41fbd4","0x76f988da831153b5","0x983e5152ee66dfab","0xa831c66d2db43210","0xb00327c898fb213f","0xbf597fc7beef0ee4","0xc6e00bf33da88fc2","0xd5a79147930aa725","0x06ca6351e003826f","0x142929670a0e6e70","0x27b70a8546d22ffc","0x2e1b21385c26c926","0x4d2c6dfc5ac42aed","0x53380d139d95b3df","0x650a73548baf63de","0x766a0abb3c77b2a8","0x81c2c92e47edaee6","0x92722c851482353b","0xa2bfe8a14cf10364","0xa81a664bbc423001","0xc24b8b70d0f89791","0xc76c51a30654be30","0xd192e819d6ef5218","0xd69906245565a910","0xf40e35855771202a","0x106aa07032bbd1b8","0x19a4c116b8d2d0c8","0x1e376c085141ab53","0x2748774cdf8eeb99","0x34b0bcb5e19b48a8","0x391c0cb3c5c95a63","0x4ed8aa4ae3418acb","0x5b9cca4f7763e373","0x682e6ff3d6b2b8a3","0x748f82ee5defb2fc","0x78a5636f43172f60","0x84c87814a1f0ab72","0x8cc702081a6439ec","0x90befffa23631e28","0xa4506cebde82bde9","0xbef9a3f7b2c67915","0xc67178f2e372532b","0xca273eceea26619c","0xd186b8c721c0c207","0xeada7dd6cde0eb1e","0xf57d4f7fee6ed178","0x06f067aa72176fba","0x0a637dc5a2c898a6","0x113f9804bef90dae","0x1b710b35131c471b","0x28db77f523047d84","0x32caab7b40c72493","0x3c9ebe0a15c9bebc","0x431d67c49c100d4c","0x4cc5d4becb3e42b6","0x597f299cfc657e2a","0x5fcb6fab3ad6faec","0x6c44198c4a475817"].map(e=>BigInt(e))),Ul=Na[0],Nl=Na[1],he=new Uint32Array(80),de=new Uint32Array(80),os=class extends Ir{constructor(t=64){super(128,t,16,!1),this.Ah=pt[0]|0,this.Al=pt[1]|0,this.Bh=pt[2]|0,this.Bl=pt[3]|0,this.Ch=pt[4]|0,this.Cl=pt[5]|0,this.Dh=pt[6]|0,this.Dl=pt[7]|0,this.Eh=pt[8]|0,this.El=pt[9]|0,this.Fh=pt[10]|0,this.Fl=pt[11]|0,this.Gh=pt[12]|0,this.Gl=pt[13]|0,this.Hh=pt[14]|0,this.Hl=pt[15]|0}get(){let{Ah:t,Al:r,Bh:n,Bl:o,Ch:s,Cl:i,Dh:a,Dl:c,Eh:u,El:f,Fh:l,Fl:p,Gh:m,Gl:x,Hh:g,Hl:h}=this;return[t,r,n,o,s,i,a,c,u,f,l,p,m,x,g,h]}set(t,r,n,o,s,i,a,c,u,f,l,p,m,x,g,h){this.Ah=t|0,this.Al=r|0,this.Bh=n|0,this.Bl=o|0,this.Ch=s|0,this.Cl=i|0,this.Dh=a|0,this.Dl=c|0,this.Eh=u|0,this.El=f|0,this.Fh=l|0,this.Fl=p|0,this.Gh=m|0,this.Gl=x|0,this.Hh=g|0,this.Hl=h|0}process(t,r){for(let I=0;I<16;I++,r+=4)he[I]=t.getUint32(r),de[I]=t.getUint32(r+=4);for(let I=16;I<80;I++){let N=he[I-15]|0,S=de[I-15]|0,R=Ae(N,S,1)^Ae(N,S,8)^rs(N,S,7),L=ve(N,S,1)^ve(N,S,8)^ns(N,S,7),T=he[I-2]|0,d=de[I-2]|0,b=Ae(T,d,19)^Cr(T,d,61)^rs(T,d,6),y=ve(T,d,19)^Br(T,d,61)^ns(T,d,6),w=Da(L,y,de[I-7],de[I-16]),A=Pa(w,R,b,he[I-7],he[I-16]);he[I]=A|0,de[I]=w|0}let{Ah:n,Al:o,Bh:s,Bl:i,Ch:a,Cl:c,Dh:u,Dl:f,Eh:l,El:p,Fh:m,Fl:x,Gh:g,Gl:h,Hh:E,Hl:C}=this;for(let I=0;I<80;I++){let N=Ae(l,p,14)^Ae(l,p,18)^Cr(l,p,41),S=ve(l,p,14)^ve(l,p,18)^Br(l,p,41),R=l&m^~l&g,L=p&x^~p&h,T=Ra(C,S,L,Nl[I],de[I]),d=Ua(T,E,N,R,Ul[I],he[I]),b=T|0,y=Ae(n,o,28)^Cr(n,o,34)^Cr(n,o,39),w=ve(n,o,28)^Br(n,o,34)^Br(n,o,39),A=n&s^n&a^s&a,_=o&i^o&c^i&c;E=g|0,C=h|0,g=m|0,h=x|0,m=l|0,x=p|0,{h:l,l:p}=zt(u|0,f|0,d|0,b|0),u=a|0,f=c|0,a=s|0,c=i|0,s=n|0,i=o|0;let v=Ta(b,w,_);n=La(v,d,y,A),o=v|0}({h:n,l:o}=zt(this.Ah|0,this.Al|0,n|0,o|0)),{h:s,l:i}=zt(this.Bh|0,this.Bl|0,s|0,i|0),{h:a,l:c}=zt(this.Ch|0,this.Cl|0,a|0,c|0),{h:u,l:f}=zt(this.Dh|0,this.Dl|0,u|0,f|0),{h:l,l:p}=zt(this.Eh|0,this.El|0,l|0,p|0),{h:m,l:x}=zt(this.Fh|0,this.Fl|0,m|0,x|0),{h:g,l:h}=zt(this.Gh|0,this.Gl|0,g|0,h|0),{h:E,l:C}=zt(this.Hh|0,this.Hl|0,E|0,C|0),this.set(n,o,s,i,a,c,u,f,l,p,m,x,g,h,E,C)}roundClean(){Ot(he,de)}destroy(){Ot(this.buffer),this.set(0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0)}};var wn=es(()=>new bn);var ka=es(()=>new os);var as=BigInt(0),is=BigInt(1);function te(e,t){if(typeof t!="boolean")throw new Error(e+" boolean expected, got "+t)}function Tr(e){let t=e.toString(16);return t.length&1?"0"+t:t}function Oa(e){if(typeof e!="string")throw new Error("hex string expected, got "+typeof e);return e===""?as:BigInt("0x"+e)}function Xe(e){return Oa(qt(e))}function Ft(e){return bt(e),Oa(qt(Uint8Array.from(e).reverse()))}function En(e,t){return Ye(e.toString(16).padStart(t*2,"0"))}function pe(e,t){return En(e,t).reverse()}function Y(e,t,r){let n;if(typeof t=="string")try{n=Ye(t)}catch(s){throw new Error(e+" must be hex string or Uint8Array, cause: "+s)}else if(je(t))n=Uint8Array.from(t);else throw new Error(e+" must be hex string or Uint8Array");let o=n.length;if(typeof r=="number"&&o!==r)throw new Error(e+" of length "+r+" expected, got "+o);return n}var ss=e=>typeof e=="bigint"&&as<=e;function Ka(e,t,r){return ss(e)&&ss(t)&&ss(r)&&t<=e&&e<r}function Mt(e,t,r,n){if(!Ka(t,r,n))throw new Error("expected valid "+e+": "+r+" <= n < "+n+", got "+t)}function Ma(e){let t;for(t=0;e>as;e>>=is,t+=1);return t}var _e=e=>(is<<BigInt(e))-is;function Ha(e,t,r){if(typeof e!="number"||e<2)throw new Error("hashLen must be a number");if(typeof t!="number"||t<2)throw new Error("qByteLen must be a number");if(typeof r!="function")throw new Error("hmacFn must be a function");let n=m=>new Uint8Array(m),o=m=>Uint8Array.of(m),s=n(e),i=n(e),a=0,c=()=>{s.fill(1),i.fill(0),a=0},u=(...m)=>r(i,s,...m),f=(m=n(0))=>{i=u(o(0),m),s=u(),m.length!==0&&(i=u(o(1),m),s=u())},l=()=>{if(a++>=1e3)throw new Error("drbg: tried 1000 values");let m=0,x=[];for(;m<t;){s=u();let g=s.slice();x.push(g),m+=s.length}return Dt(...x)};return(m,x)=>{c(),f(m);let g;for(;!(g=x(l()));)f();return c(),g}}function Gt(e,t,r={}){if(!e||typeof e!="object")throw new Error("expected valid options object");function n(o,s,i){let a=e[o];if(i&&a===void 0)return;let c=typeof a;if(c!==s||a===null)throw new Error(`param "${o}" is invalid: expected ${s}, got ${c}`)}Object.entries(t).forEach(([o,s])=>n(o,s,!1)),Object.entries(r).forEach(([o,s])=>n(o,s,!0))}function Je(e){let t=new WeakMap;return(r,...n)=>{let o=t.get(r);if(o!==void 0)return o;let s=e(r,...n);return t.set(r,s),s}}var _t=BigInt(0),ut=BigInt(1),Ie=BigInt(2),kl=BigInt(3),za=BigInt(4),Fa=BigInt(5),Ga=BigInt(8);function Q(e,t){let r=e%t;return r>=_t?r:t+r}function tt(e,t,r){let n=e;for(;t-- >_t;)n*=n,n%=r;return n}function Va(e,t){if(e===_t)throw new Error("invert: expected non-zero number");if(t<=_t)throw new Error("invert: expected positive modulus, got "+t);let r=Q(e,t),n=t,o=_t,s=ut,i=ut,a=_t;for(;r!==_t;){let u=n/r,f=n%r,l=o-i*u,p=s-a*u;n=r,r=f,o=i,s=a,i=l,a=p}if(n!==ut)throw new Error("invert: does not exist");return Q(o,t)}function Wa(e,t){let r=(e.ORDER+ut)/za,n=e.pow(t,r);if(!e.eql(e.sqr(n),t))throw new Error("Cannot find square root");return n}function Ol(e,t){let r=(e.ORDER-Fa)/Ga,n=e.mul(t,Ie),o=e.pow(n,r),s=e.mul(t,o),i=e.mul(e.mul(s,Ie),o),a=e.mul(s,e.sub(i,e.ONE));if(!e.eql(e.sqr(a),t))throw new Error("Cannot find square root");return a}function Kl(e){if(e<BigInt(3))throw new Error("sqrt is not defined for small field");let t=e-ut,r=0;for(;t%Ie===_t;)t/=Ie,r++;let n=Ie,o=Ht(e);for(;qa(o,n)===1;)if(n++>1e3)throw new Error("Cannot find square root: probably non-prime P");if(r===1)return Wa;let s=o.pow(n,t),i=(t+ut)/Ie;return function(c,u){if(c.is0(u))return u;if(qa(c,u)!==1)throw new Error("Cannot find square root");let f=r,l=c.mul(c.ONE,s),p=c.pow(u,t),m=c.pow(u,i);for(;!c.eql(p,c.ONE);){if(c.is0(p))return c.ZERO;let x=1,g=c.sqr(p);for(;!c.eql(g,c.ONE);)if(x++,g=c.sqr(g),x===f)throw new Error("Cannot find square root");let h=ut<<BigInt(f-x-1),E=c.pow(l,h);f=x,l=c.sqr(E),p=c.mul(p,l),m=c.mul(m,E)}return m}}function Ml(e){return e%za===kl?Wa:e%Ga===Fa?Ol:Kl(e)}var $a=(e,t)=>(Q(e,t)&ut)===ut,Hl=["create","isValid","is0","neg","inv","sqrt","sqr","eql","add","sub","mul","pow","div","addN","subN","mulN","sqrN"];function cs(e){let t={ORDER:"bigint",MASK:"bigint",BYTES:"number",BITS:"number"},r=Hl.reduce((n,o)=>(n[o]="function",n),t);return Gt(e,r),e}function Vl(e,t,r){if(r<_t)throw new Error("invalid exponent, negatives unsupported");if(r===_t)return e.ONE;if(r===ut)return t;let n=e.ONE,o=t;for(;r>_t;)r&ut&&(n=e.mul(n,o)),o=e.sqr(o),r>>=ut;return n}function Lr(e,t,r=!1){let n=new Array(t.length).fill(r?e.ZERO:void 0),o=t.reduce((i,a,c)=>e.is0(a)?i:(n[c]=i,e.mul(i,a)),e.ONE),s=e.inv(o);return t.reduceRight((i,a,c)=>e.is0(a)?i:(n[c]=e.mul(i,n[c]),e.mul(i,a)),s),n}function qa(e,t){let r=(e.ORDER-ut)/Ie,n=e.pow(t,r),o=e.eql(n,e.ONE),s=e.eql(n,e.ZERO),i=e.eql(n,e.neg(e.ONE));if(!o&&!s&&!i)throw new Error("invalid Legendre symbol result");return o?1:s?0:-1}function ja(e,t){t!==void 0&&Ee(t);let r=t!==void 0?t:e.toString(2).length,n=Math.ceil(r/8);return{nBitLength:r,nByteLength:n}}function Ht(e,t,r=!1,n={}){if(e<=_t)throw new Error("invalid field: expected ORDER > 0, got "+e);let o,s;if(typeof t=="object"&&t!=null){if(n.sqrt||r)throw new Error("cannot specify opts in two arguments");let f=t;f.BITS&&(o=f.BITS),f.sqrt&&(s=f.sqrt),typeof f.isLE=="boolean"&&(r=f.isLE)}else typeof t=="number"&&(o=t),n.sqrt&&(s=n.sqrt);let{nBitLength:i,nByteLength:a}=ja(e,o);if(a>2048)throw new Error("invalid field: expected ORDER of <= 2048 bytes");let c,u=Object.freeze({ORDER:e,isLE:r,BITS:i,BYTES:a,MASK:_e(i),ZERO:_t,ONE:ut,create:f=>Q(f,e),isValid:f=>{if(typeof f!="bigint")throw new Error("invalid field element: expected bigint, got "+typeof f);return _t<=f&&f<e},is0:f=>f===_t,isValidNot0:f=>!u.is0(f)&&u.isValid(f),isOdd:f=>(f&ut)===ut,neg:f=>Q(-f,e),eql:(f,l)=>f===l,sqr:f=>Q(f*f,e),add:(f,l)=>Q(f+l,e),sub:(f,l)=>Q(f-l,e),mul:(f,l)=>Q(f*l,e),pow:(f,l)=>Vl(u,f,l),div:(f,l)=>Q(f*Va(l,e),e),sqrN:f=>f*f,addN:(f,l)=>f+l,subN:(f,l)=>f-l,mulN:(f,l)=>f*l,inv:f=>Va(f,e),sqrt:s||(f=>(c||(c=Ml(e)),c(u,f))),toBytes:f=>r?pe(f,a):En(f,a),fromBytes:f=>{if(f.length!==a)throw new Error("Field.fromBytes: expected "+a+" bytes, got "+f.length);return r?Ft(f):Xe(f)},invertBatch:f=>Lr(u,f),cmov:(f,l,p)=>p?l:f});return Object.freeze(u)}function Za(e){if(typeof e!="bigint")throw new Error("field order must be bigint");let t=e.toString(2).length;return Math.ceil(t/8)}function fs(e){let t=Za(e);return t+Math.ceil(t/2)}function Ya(e,t,r=!1){let n=e.length,o=Za(t),s=fs(t);if(n<16||n<s||n>1024)throw new Error("expected "+s+"-1024 bytes of input, got "+n);let i=r?Ft(e):Xe(e),a=Q(i,t-ut)+ut;return r?pe(a,o):En(a,o)}var tr=BigInt(0),Ce=BigInt(1);function Qe(e,t){let r=t.negate();return e?r:t}function Sn(e,t,r){let n=t==="pz"?i=>i.pz:i=>i.ez,o=Lr(e.Fp,r.map(n));return r.map((i,a)=>i.toAffine(o[a])).map(e.fromAffine)}function tc(e,t){if(!Number.isSafeInteger(e)||e<=0||e>t)throw new Error("invalid window size, expected [1.."+t+"], got W="+e)}function us(e,t){tc(e,t);let r=Math.ceil(t/e)+1,n=2**(e-1),o=2**e,s=_e(e),i=BigInt(e);return{windows:r,windowSize:n,mask:s,maxNumber:o,shiftBy:i}}function Xa(e,t,r){let{windowSize:n,mask:o,maxNumber:s,shiftBy:i}=r,a=Number(e&o),c=e>>i;a>n&&(a-=s,c+=Ce);let u=t*n,f=u+Math.abs(a)-1,l=a===0,p=a<0,m=t%2!==0;return{nextN:c,offset:f,isZero:l,isNeg:p,isNegF:m,offsetF:u}}function ql(e,t){if(!Array.isArray(e))throw new Error("array expected");e.forEach((r,n)=>{if(!(r instanceof t))throw new Error("invalid point at index "+n)})}function zl(e,t){if(!Array.isArray(e))throw new Error("array of scalars expected");e.forEach((r,n)=>{if(!t.isValid(r))throw new Error("invalid scalar at index "+n)})}var ls=new WeakMap,ec=new WeakMap;function hs(e){return ec.get(e)||1}function Ja(e){if(e!==tr)throw new Error("invalid wNAF")}function An(e,t){return{constTimeNegate:Qe,hasPrecomputes(r){return hs(r)!==1},unsafeLadder(r,n,o=e.ZERO){let s=r;for(;n>tr;)n&Ce&&(o=o.add(s)),s=s.double(),n>>=Ce;return o},precomputeWindow(r,n){let{windows:o,windowSize:s}=us(n,t),i=[],a=r,c=a;for(let u=0;u<o;u++){c=a,i.push(c);for(let f=1;f<s;f++)c=c.add(a),i.push(c);a=c.double()}return i},wNAF(r,n,o){let s=e.ZERO,i=e.BASE,a=us(r,t);for(let c=0;c<a.windows;c++){let{nextN:u,offset:f,isZero:l,isNeg:p,isNegF:m,offsetF:x}=Xa(o,c,a);o=u,l?i=i.add(Qe(m,n[x])):s=s.add(Qe(p,n[f]))}return Ja(o),{p:s,f:i}},wNAFUnsafe(r,n,o,s=e.ZERO){let i=us(r,t);for(let a=0;a<i.windows&&o!==tr;a++){let{nextN:c,offset:u,isZero:f,isNeg:l}=Xa(o,a,i);if(o=c,!f){let p=n[u];s=s.add(l?p.negate():p)}}return Ja(o),s},getPrecomputes(r,n,o){let s=ls.get(n);return s||(s=this.precomputeWindow(n,r),r!==1&&(typeof o=="function"&&(s=o(s)),ls.set(n,s))),s},wNAFCached(r,n,o){let s=hs(r);return this.wNAF(s,this.getPrecomputes(s,r,o),n)},wNAFCachedUnsafe(r,n,o,s){let i=hs(r);return i===1?this.unsafeLadder(r,n,s):this.wNAFUnsafe(i,this.getPrecomputes(i,r,o),n,s)},setWindowSize(r,n){tc(n,t),ec.set(r,n),ls.delete(r)}}}function rc(e,t,r,n){let o=t,s=e.ZERO,i=e.ZERO;for(;r>tr||n>tr;)r&Ce&&(s=s.add(o)),n&Ce&&(i=i.add(o)),o=o.double(),r>>=Ce,n>>=Ce;return{p1:s,p2:i}}function vn(e,t,r,n){ql(r,e),zl(n,t);let o=r.length,s=n.length;if(o!==s)throw new Error("arrays of points and scalars must have equal length");let i=e.ZERO,a=Ma(BigInt(o)),c=1;a>12?c=a-3:a>4?c=a-2:a>0&&(c=2);let u=_e(c),f=new Array(Number(u)+1).fill(i),l=Math.floor((t.BITS-1)/c)*c,p=i;for(let m=l;m>=0;m-=c){f.fill(i);for(let g=0;g<s;g++){let h=n[g],E=Number(h>>BigInt(m)&u);f[E]=f[E].add(r[g])}let x=i;for(let g=f.length-1,h=i;g>0;g--)h=h.add(f[g]),x=x.add(h);if(p=p.add(x),m!==0)for(let g=0;g<c;g++)p=p.double()}return p}function Qa(e,t){if(t){if(t.ORDER!==e)throw new Error("Field.ORDER must match order: Fp == p, Fn == n");return cs(t),t}else return Ht(e)}function _n(e,t,r={}){if(!t||typeof t!="object")throw new Error(`expected valid ${e} CURVE object`);for(let a of["p","n","h"]){let c=t[a];if(!(typeof c=="bigint"&&c>tr))throw new Error(`CURVE.${a} must be positive bigint`)}let n=Qa(t.p,r.Fp),o=Qa(t.n,r.Fn),i=["Gx","Gy","a",e==="weierstrass"?"b":"d"];for(let a of i)if(!n.isValid(t[a]))throw new Error(`CURVE.${a} must be valid field element of CURVE.Fp`);return{Fp:n,Fn:o}}var Wt=BigInt(0),It=BigInt(1),ds=BigInt(2),Fl=BigInt(8),Gl={zip215:!0};function Wl(e,t,r,n){let o=e.sqr(r),s=e.sqr(n),i=e.add(e.mul(t.a,o),s),a=e.add(e.ONE,e.mul(t.d,e.mul(o,s)));return e.eql(i,a)}function $l(e,t={}){let{Fp:r,Fn:n}=_n("edwards",e,t),{h:o,n:s}=e;Gt(t,{},{uvRatio:"function"});let i=ds<<BigInt(n.BYTES*8)-It,a=g=>r.create(g),c=t.uvRatio||((g,h)=>{try{return{isValid:!0,value:r.sqrt(r.div(g,h))}}catch{return{isValid:!1,value:Wt}}});if(!Wl(r,e,e.Gx,e.Gy))throw new Error("bad curve params: generator point");function u(g,h,E=!1){let C=E?It:Wt;return Mt("coordinate "+g,h,C,i),h}function f(g){if(!(g instanceof m))throw new Error("ExtendedPoint expected")}let l=Je((g,h)=>{let{ex:E,ey:C,ez:I}=g,N=g.is0();h==null&&(h=N?Fl:r.inv(I));let S=a(E*h),R=a(C*h),L=a(I*h);if(N)return{x:Wt,y:It};if(L!==It)throw new Error("invZ was invalid");return{x:S,y:R}}),p=Je(g=>{let{a:h,d:E}=e;if(g.is0())throw new Error("bad point: ZERO");let{ex:C,ey:I,ez:N,et:S}=g,R=a(C*C),L=a(I*I),T=a(N*N),d=a(T*T),b=a(R*h),y=a(T*a(b+L)),w=a(d+a(E*a(R*L)));if(y!==w)throw new Error("bad point: equation left != right (1)");let A=a(C*I),_=a(N*S);if(A!==_)throw new Error("bad point: equation left != right (2)");return!0});class m{constructor(h,E,C,I){this.ex=u("x",h),this.ey=u("y",E),this.ez=u("z",C,!0),this.et=u("t",I),Object.freeze(this)}get x(){return this.toAffine().x}get y(){return this.toAffine().y}static fromAffine(h){if(h instanceof m)throw new Error("extended point not allowed");let{x:E,y:C}=h||{};return u("x",E),u("y",C),new m(E,C,It,a(E*C))}static normalizeZ(h){return Sn(m,"ez",h)}static msm(h,E){return vn(m,n,h,E)}_setWindowSize(h){this.precompute(h)}precompute(h=8,E=!0){return x.setWindowSize(this,h),E||this.multiply(ds),this}assertValidity(){p(this)}equals(h){f(h);let{ex:E,ey:C,ez:I}=this,{ex:N,ey:S,ez:R}=h,L=a(E*R),T=a(N*I),d=a(C*R),b=a(S*I);return L===T&&d===b}is0(){return this.equals(m.ZERO)}negate(){return new m(a(-this.ex),this.ey,this.ez,a(-this.et))}double(){let{a:h}=e,{ex:E,ey:C,ez:I}=this,N=a(E*E),S=a(C*C),R=a(ds*a(I*I)),L=a(h*N),T=E+C,d=a(a(T*T)-N-S),b=L+S,y=b-R,w=L-S,A=a(d*y),_=a(b*w),v=a(d*w),B=a(y*b);return new m(A,_,B,v)}add(h){f(h);let{a:E,d:C}=e,{ex:I,ey:N,ez:S,et:R}=this,{ex:L,ey:T,ez:d,et:b}=h,y=a(I*L),w=a(N*T),A=a(R*C*b),_=a(S*d),v=a((I+N)*(L+T)-y-w),B=_-A,D=_+A,U=a(w-E*y),P=a(v*B),K=a(D*U),k=a(v*U),M=a(B*D);return new m(P,K,M,k)}subtract(h){return this.add(h.negate())}multiply(h){let E=h;Mt("scalar",E,It,s);let{p:C,f:I}=x.wNAFCached(this,E,m.normalizeZ);return m.normalizeZ([C,I])[0]}multiplyUnsafe(h,E=m.ZERO){let C=h;return Mt("scalar",C,Wt,s),C===Wt?m.ZERO:this.is0()||C===It?this:x.wNAFCachedUnsafe(this,C,m.normalizeZ,E)}isSmallOrder(){return this.multiplyUnsafe(o).is0()}isTorsionFree(){return x.wNAFCachedUnsafe(this,s).is0()}toAffine(h){return l(this,h)}clearCofactor(){return o===It?this:this.multiplyUnsafe(o)}static fromBytes(h,E=!1){return bt(h),this.fromHex(h,E)}static fromHex(h,E=!1){let{d:C,a:I}=e,N=r.BYTES;h=Y("pointHex",h,N),te("zip215",E);let S=h.slice(),R=h[N-1];S[N-1]=R&-129;let L=Ft(S),T=E?i:r.ORDER;Mt("pointHex.y",L,Wt,T);let d=a(L*L),b=a(d-It),y=a(C*d-I),{isValid:w,value:A}=c(b,y);if(!w)throw new Error("Point.fromHex: invalid y coordinate");let _=(A&It)===It,v=(R&128)!==0;if(!E&&A===Wt&&v)throw new Error("Point.fromHex: x=0 and x_0=1");return v!==_&&(A=a(-A)),m.fromAffine({x:A,y:L})}static fromPrivateScalar(h){return m.BASE.multiply(h)}toBytes(){let{x:h,y:E}=this.toAffine(),C=pe(E,r.BYTES);return C[C.length-1]|=h&It?128:0,C}toRawBytes(){return this.toBytes()}toHex(){return qt(this.toBytes())}toString(){return`<Point ${this.is0()?"ZERO":this.toHex()}>`}}m.BASE=new m(e.Gx,e.Gy,It,a(e.Gx*e.Gy)),m.ZERO=new m(Wt,It,It,Wt),m.Fp=r,m.Fn=n;let x=An(m,n.BYTES*8);return m}function jl(e,t){Gt(t,{hash:"function"},{adjustScalarBytes:"function",randomBytes:"function",domain:"function",prehash:"function",mapToCurve:"function"});let{prehash:r,hash:n}=t,{BASE:o,Fp:s,Fn:i}=e,a=i.ORDER,c=t.randomBytes||Se,u=t.adjustScalarBytes||(S=>S),f=t.domain||((S,R,L)=>{if(te("phflag",L),R.length||L)throw new Error("Contexts/pre-hash are not supported");return S});function l(S){return i.create(S)}function p(S){return l(Ft(S))}function m(S){let R=s.BYTES;S=Y("private key",S,R);let L=Y("hashed private key",n(S),2*R),T=u(L.slice(0,R)),d=L.slice(R,2*R),b=p(T);return{head:T,prefix:d,scalar:b}}function x(S){let{head:R,prefix:L,scalar:T}=m(S),d=o.multiply(T),b=d.toBytes();return{head:R,prefix:L,scalar:T,point:d,pointBytes:b}}function g(S){return x(S).pointBytes}function h(S=Uint8Array.of(),...R){let L=Dt(...R);return p(n(f(L,Y("context",S),!!r)))}function E(S,R,L={}){S=Y("message",S),r&&(S=r(S));let{prefix:T,scalar:d,pointBytes:b}=x(R),y=h(L.context,T,S),w=o.multiply(y).toBytes(),A=h(L.context,w,b,S),_=l(y+A*d);Mt("signature.s",_,Wt,a);let v=s.BYTES,B=Dt(w,pe(_,v));return Y("result",B,v*2)}let C=Gl;function I(S,R,L,T=C){let{context:d,zip215:b}=T,y=s.BYTES;S=Y("signature",S,2*y),R=Y("message",R),L=Y("publicKey",L,y),b!==void 0&&te("zip215",b),r&&(R=r(R));let w=Ft(S.slice(y,2*y)),A,_,v;try{A=e.fromHex(L,b),_=e.fromHex(S.slice(0,y),b),v=o.multiplyUnsafe(w)}catch{return!1}if(!b&&A.isSmallOrder())return!1;let B=h(d,_.toBytes(),A.toBytes(),R);return _.add(A.multiplyUnsafe(B)).subtract(v).clearCofactor().is0()}return o.precompute(8),{getPublicKey:g,sign:E,verify:I,utils:{getExtendedPublicKey:x,randomPrivateKey:()=>c(s.BYTES),precompute(S=8,R=e.BASE){return R.precompute(S,!1)}},Point:e}}function Zl(e){let t={a:e.a,d:e.d,p:e.Fp.ORDER,n:e.n,h:e.h,Gx:e.Gx,Gy:e.Gy},r=e.Fp,n=Ht(t.n,e.nBitLength,!0),o={Fp:r,Fn:n,uvRatio:e.uvRatio},s={hash:e.hash,randomBytes:e.randomBytes,adjustScalarBytes:e.adjustScalarBytes,domain:e.domain,prehash:e.prehash,mapToCurve:e.mapToCurve};return{CURVE:t,curveOpts:o,eddsaOpts:s}}function Yl(e,t){return Object.assign({},t,{ExtendedPoint:t.Point,CURVE:e})}function nc(e){let{CURVE:t,curveOpts:r,eddsaOpts:n}=Zl(e),o=$l(t,r),s=jl(o,n);return Yl(e,s)}var Dr=BigInt(0),er=BigInt(1),In=BigInt(2);function Xl(e){return Gt(e,{adjustScalarBytes:"function",powPminus2:"function"}),Object.freeze({...e})}function oc(e){let t=Xl(e),{P:r,type:n,adjustScalarBytes:o,powPminus2:s,randomBytes:i}=t,a=n==="x25519";if(!a&&n!=="x448")throw new Error("invalid type");let c=i||Se,u=a?255:448,f=a?32:56,l=BigInt(a?9:5),p=BigInt(a?121665:39081),m=a?In**BigInt(254):In**BigInt(447),x=a?BigInt(8)*In**BigInt(251)-er:BigInt(4)*In**BigInt(445)-er,g=m+x+er,h=d=>Q(d,r),E=C(l);function C(d){return pe(h(d),f)}function I(d){let b=Y("u coordinate",d,f);return a&&(b[31]&=127),h(Ft(b))}function N(d){return Ft(o(Y("scalar",d,f)))}function S(d,b){let y=T(I(b),N(d));if(y===Dr)throw new Error("invalid private or public key received");return C(y)}function R(d){return S(d,E)}function L(d,b,y){let w=h(d*(b-y));return b=h(b-w),y=h(y+w),{x_2:b,x_3:y}}function T(d,b){Mt("u",d,Dr,r),Mt("scalar",b,m,g);let y=b,w=d,A=er,_=Dr,v=d,B=er,D=Dr;for(let P=BigInt(u-1);P>=Dr;P--){let K=y>>P&er;D^=K,{x_2:A,x_3:v}=L(D,A,v),{x_2:_,x_3:B}=L(D,_,B),D=K;let k=A+_,M=h(k*k),W=A-_,X=h(W*W),q=M-X,et=v+B,Bt=v-B,xt=h(Bt*k),dt=h(et*W),Me=xt+dt,jt=xt-dt;v=h(Me*Me),B=h(w*h(jt*jt)),A=h(M*X),_=h(q*(M+h(p*q)))}({x_2:A,x_3:v}=L(D,A,v)),{x_2:_,x_3:B}=L(D,_,B);let U=s(_);return h(A*U)}return{scalarMult:S,scalarMultBase:R,getSharedSecret:(d,b)=>S(d,b),getPublicKey:d=>R(d),utils:{randomPrivateKey:()=>c(f)},GuBytes:E.slice()}}var ty=BigInt(0),Jl=BigInt(1),sc=BigInt(2),Ql=BigInt(3),th=BigInt(5),eh=BigInt(8),Pr={p:BigInt("0x7fffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffed"),n:BigInt("0x1000000000000000000000000000000014def9dea2f79cd65812631a5cf5d3ed"),h:eh,a:BigInt("0x7fffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffec"),d:BigInt("0x52036cee2b6ffe738cc740797779e89800700a4d4141d8ab75eb4dca135978a3"),Gx:BigInt("0x216936d3cd6e53fec0a4e231fdd6dc5c692cc7609525a7b2c9562d608f25d51a"),Gy:BigInt("0x6666666666666666666666666666666666666666666666666666666666666658")};function ac(e){let t=BigInt(10),r=BigInt(20),n=BigInt(40),o=BigInt(80),s=Pr.p,a=e*e%s*e%s,c=tt(a,sc,s)*a%s,u=tt(c,Jl,s)*e%s,f=tt(u,th,s)*u%s,l=tt(f,t,s)*f%s,p=tt(l,r,s)*l%s,m=tt(p,n,s)*p%s,x=tt(m,o,s)*m%s,g=tt(x,o,s)*m%s,h=tt(g,t,s)*f%s;return{pow_p_5_8:tt(h,sc,s)*e%s,b2:a}}function cc(e){return e[0]&=248,e[31]&=127,e[31]|=64,e}var ic=BigInt("19681161376707505956807079304988542015446066515923890162744021073123829784752");function rh(e,t){let r=Pr.p,n=Q(t*t*t,r),o=Q(n*n*t,r),s=ac(e*o).pow_p_5_8,i=Q(e*n*s,r),a=Q(t*i*i,r),c=i,u=Q(i*ic,r),f=a===e,l=a===Q(-e,r),p=a===Q(-e*ic,r);return f&&(i=c),(l||p)&&(i=u),$a(i,r)&&(i=Q(-i,r)),{isValid:f||l,value:i}}var nh=Ht(Pr.p,void 0,!0),oh={...Pr,Fp:nh,hash:ka,adjustScalarBytes:cc,uvRatio:rh},fc=nc(oh);var Rr=(()=>{let e=Pr.p;return oc({P:e,type:"x25519",powPminus2:t=>{let{pow_p_5_8:r,b2:n}=ac(t);return Q(tt(r,Ql,e)*n,e)},adjustScalarBytes:cc})})();var Ur=class extends Error{constructor(t="An error occurred while verifying a message"){super(t),this.name="VerificationError"}},Cn=class extends Error{constructor(t="Missing Web Crypto API"){super(t),this.name="WebCryptoMissingError"}};var uc={get(e=globalThis){let t=e.crypto;if(t?.subtle==null)throw new Cn("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");return t}};var Nt=uc;var Bn=32;var ps,sh=(async()=>{try{return await Nt.get().subtle.generateKey({name:"Ed25519"},!0,["sign","verify"]),!0}catch{return!1}})();async function ih(e,t,r){if(e.buffer instanceof ArrayBuffer){let n=await Nt.get().subtle.importKey("raw",e.buffer,{name:"Ed25519"},!1,["verify"]);return await Nt.get().subtle.verify({name:"Ed25519"},n,t,r instanceof Uint8Array?r:r.subarray())}throw new TypeError("WebCrypto does not support SharedArrayBuffer for Ed25519 keys")}function ah(e,t,r){return fc.verify(t,r instanceof Uint8Array?r:r.subarray(),e)}async function lc(e,t,r){return ps==null&&(ps=await sh),ps?ih(e,t,r):ah(e,t,r)}function Tn(e){return e==null?!1:typeof e.then=="function"&&typeof e.catch=="function"&&typeof e.finally=="function"}var Ln=class{type="Ed25519";raw;constructor(t){this.raw=ms(t,Bn)}toMultihash(){return kt.digest(fe(this))}toCID(){return st.createV1(114,this.toMultihash())}toString(){return J.encode(this.toMultihash().bytes).substring(1)}equals(t){return t==null||!(t.raw instanceof Uint8Array)?!1:at(this.raw,t.raw)}verify(t,r,n){n?.signal?.throwIfAborted();let o=lc(this.raw,r,t);return Tn(o)?o.then(s=>(n?.signal?.throwIfAborted(),s)):o}};function ys(e){return e=ms(e,Bn),new Ln(e)}function ms(e,t){if(e=Uint8Array.from(e??[]),e.length!==t)throw new nt(`Key must be a Uint8Array of length ${t}, got ${e.length}`);return e}var fh=Math.pow(2,7),uh=Math.pow(2,14),lh=Math.pow(2,21),gs=Math.pow(2,28),xs=Math.pow(2,35),bs=Math.pow(2,42),ws=Math.pow(2,49),j=128,wt=127;function lt(e){if(e<fh)return 1;if(e<uh)return 2;if(e<lh)return 3;if(e<gs)return 4;if(e<xs)return 5;if(e<bs)return 6;if(e<ws)return 7;if(Number.MAX_SAFE_INTEGER!=null&&e>Number.MAX_SAFE_INTEGER)throw new RangeError("Could not encode varint");return 8}function rr(e,t,r=0){switch(lt(e)){case 8:t[r++]=e&255|j,e/=128;case 7:t[r++]=e&255|j,e/=128;case 6:t[r++]=e&255|j,e/=128;case 5:t[r++]=e&255|j,e/=128;case 4:t[r++]=e&255|j,e>>>=7;case 3:t[r++]=e&255|j,e>>>=7;case 2:t[r++]=e&255|j,e>>>=7;case 1:{t[r++]=e&255,e>>>=7;break}default:throw new Error("unreachable")}return t}function hh(e,t,r=0){switch(lt(e)){case 8:t.set(r++,e&255|j),e/=128;case 7:t.set(r++,e&255|j),e/=128;case 6:t.set(r++,e&255|j),e/=128;case 5:t.set(r++,e&255|j),e/=128;case 4:t.set(r++,e&255|j),e>>>=7;case 3:t.set(r++,e&255|j),e>>>=7;case 2:t.set(r++,e&255|j),e>>>=7;case 1:{t.set(r++,e&255),e>>>=7;break}default:throw new Error("unreachable")}return t}function Es(e,t){let r=e[t],n=0;if(n+=r&wt,r<j||(r=e[t+1],n+=(r&wt)<<7,r<j)||(r=e[t+2],n+=(r&wt)<<14,r<j)||(r=e[t+3],n+=(r&wt)<<21,r<j)||(r=e[t+4],n+=(r&wt)*gs,r<j)||(r=e[t+5],n+=(r&wt)*xs,r<j)||(r=e[t+6],n+=(r&wt)*bs,r<j)||(r=e[t+7],n+=(r&wt)*ws,r<j))return n;throw new RangeError("Could not decode varint")}function dh(e,t){let r=e.get(t),n=0;if(n+=r&wt,r<j||(r=e.get(t+1),n+=(r&wt)<<7,r<j)||(r=e.get(t+2),n+=(r&wt)<<14,r<j)||(r=e.get(t+3),n+=(r&wt)<<21,r<j)||(r=e.get(t+4),n+=(r&wt)*gs,r<j)||(r=e.get(t+5),n+=(r&wt)*xs,r<j)||(r=e.get(t+6),n+=(r&wt)*bs,r<j)||(r=e.get(t+7),n+=(r&wt)*ws,r<j))return n;throw new RangeError("Could not decode varint")}function Dn(e,t,r=0){return t==null&&(t=ft(lt(e))),t instanceof Uint8Array?rr(e,t,r):hh(e,t,r)}function Be(e,t=0){return e instanceof Uint8Array?Es(e,t):dh(e,t)}var Ss=new Float32Array([-0]),me=new Uint8Array(Ss.buffer);function dc(e,t,r){Ss[0]=e,t[r]=me[0],t[r+1]=me[1],t[r+2]=me[2],t[r+3]=me[3]}function pc(e,t){return me[0]=e[t],me[1]=e[t+1],me[2]=e[t+2],me[3]=e[t+3],Ss[0]}var As=new Float64Array([-0]),Et=new Uint8Array(As.buffer);function mc(e,t,r){As[0]=e,t[r]=Et[0],t[r+1]=Et[1],t[r+2]=Et[2],t[r+3]=Et[3],t[r+4]=Et[4],t[r+5]=Et[5],t[r+6]=Et[6],t[r+7]=Et[7]}function yc(e,t){return Et[0]=e[t],Et[1]=e[t+1],Et[2]=e[t+2],Et[3]=e[t+3],Et[4]=e[t+4],Et[5]=e[t+5],Et[6]=e[t+6],Et[7]=e[t+7],As[0]}var ph=BigInt(Number.MAX_SAFE_INTEGER),mh=BigInt(Number.MIN_SAFE_INTEGER),Pt=class e{lo;hi;constructor(t,r){this.lo=t|0,this.hi=r|0}toNumber(t=!1){if(!t&&this.hi>>>31>0){let r=~this.lo+1>>>0,n=~this.hi>>>0;return r===0&&(n=n+1>>>0),-(r+n*4294967296)}return this.lo+this.hi*4294967296}toBigInt(t=!1){if(t)return BigInt(this.lo>>>0)+(BigInt(this.hi>>>0)<<32n);if(this.hi>>>31){let r=~this.lo+1>>>0,n=~this.hi>>>0;return r===0&&(n=n+1>>>0),-(BigInt(r)+(BigInt(n)<<32n))}return BigInt(this.lo>>>0)+(BigInt(this.hi>>>0)<<32n)}toString(t=!1){return this.toBigInt(t).toString()}zzEncode(){let t=this.hi>>31;return this.hi=((this.hi<<1|this.lo>>>31)^t)>>>0,this.lo=(this.lo<<1^t)>>>0,this}zzDecode(){let t=-(this.lo&1);return this.lo=((this.lo>>>1|this.hi<<31)^t)>>>0,this.hi=(this.hi>>>1^t)>>>0,this}length(){let t=this.lo,r=(this.lo>>>28|this.hi<<4)>>>0,n=this.hi>>>24;return n===0?r===0?t<16384?t<128?1:2:t<2097152?3:4:r<16384?r<128?5:6:r<2097152?7:8:n<128?9:10}static fromBigInt(t){if(t===0n)return Te;if(t<ph&&t>mh)return this.fromNumber(Number(t));let r=t<0n;r&&(t=-t);let n=t>>32n,o=t-(n<<32n);return r&&(n=~n|0n,o=~o|0n,++o>gc&&(o=0n,++n>gc&&(n=0n))),new e(Number(o),Number(n))}static fromNumber(t){if(t===0)return Te;let r=t<0;r&&(t=-t);let n=t>>>0,o=(t-n)/4294967296>>>0;return r&&(o=~o>>>0,n=~n>>>0,++n>4294967295&&(n=0,++o>4294967295&&(o=0))),new e(n,o)}static from(t){return typeof t=="number"?e.fromNumber(t):typeof t=="bigint"?e.fromBigInt(t):typeof t=="string"?e.fromBigInt(BigInt(t)):t.low!=null||t.high!=null?new e(t.low>>>0,t.high>>>0):Te}},Te=new Pt(0,0);Te.toBigInt=function(){return 0n};Te.zzEncode=Te.zzDecode=function(){return this};Te.length=function(){return 1};var gc=4294967296n;function xc(e){let t=0,r=0;for(let n=0;n<e.length;++n)r=e.charCodeAt(n),r<128?t+=1:r<2048?t+=2:(r&64512)===55296&&(e.charCodeAt(n+1)&64512)===56320?(++n,t+=4):t+=3;return t}function bc(e,t,r){if(r-t<1)return"";let o,s=[],i=0,a;for(;t<r;)a=e[t++],a<128?s[i++]=a:a>191&&a<224?s[i++]=(a&31)<<6|e[t++]&63:a>239&&a<365?(a=((a&7)<<18|(e[t++]&63)<<12|(e[t++]&63)<<6|e[t++]&63)-65536,s[i++]=55296+(a>>10),s[i++]=56320+(a&1023)):s[i++]=(a&15)<<12|(e[t++]&63)<<6|e[t++]&63,i>8191&&((o??(o=[])).push(String.fromCharCode.apply(String,s)),i=0);return o!=null?(i>0&&o.push(String.fromCharCode.apply(String,s.slice(0,i))),o.join("")):String.fromCharCode.apply(String,s.slice(0,i))}function vs(e,t,r){let n=r,o,s;for(let i=0;i<e.length;++i)o=e.charCodeAt(i),o<128?t[r++]=o:o<2048?(t[r++]=o>>6|192,t[r++]=o&63|128):(o&64512)===55296&&((s=e.charCodeAt(i+1))&64512)===56320?(o=65536+((o&1023)<<10)+(s&1023),++i,t[r++]=o>>18|240,t[r++]=o>>12&63|128,t[r++]=o>>6&63|128,t[r++]=o&63|128):(t[r++]=o>>12|224,t[r++]=o>>6&63|128,t[r++]=o&63|128);return r-n}function Vt(e,t){return RangeError(`index out of range: ${e.pos} + ${t??1} > ${e.len}`)}function Rn(e,t){return(e[t-4]|e[t-3]<<8|e[t-2]<<16|e[t-1]<<24)>>>0}var _s=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,Vt(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 Vt(this,4);return Rn(this.buf,this.pos+=4)}sfixed32(){if(this.pos+4>this.len)throw Vt(this,4);return Rn(this.buf,this.pos+=4)|0}float(){if(this.pos+4>this.len)throw Vt(this,4);let t=pc(this.buf,this.pos);return this.pos+=4,t}double(){if(this.pos+8>this.len)throw Vt(this,4);let t=yc(this.buf,this.pos);return this.pos+=8,t}bytes(){let t=this.uint32(),r=this.pos,n=this.pos+t;if(n>this.len)throw Vt(this,t);return this.pos+=t,r===n?new Uint8Array(0):this.buf.subarray(r,n)}string(){let t=this.bytes();return bc(t,0,t.length)}skip(t){if(typeof t=="number"){if(this.pos+t>this.len)throw Vt(this,t);this.pos+=t}else do if(this.pos>=this.len)throw Vt(this);while((this.buf[this.pos++]&128)!==0);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 Pt(0,0),r=0;if(this.len-this.pos>4){for(;r<4;++r)if(t.lo=(t.lo|(this.buf[this.pos]&127)<<r*7)>>>0,this.buf[this.pos++]<128)return t;if(t.lo=(t.lo|(this.buf[this.pos]&127)<<28)>>>0,t.hi=(t.hi|(this.buf[this.pos]&127)>>4)>>>0,this.buf[this.pos++]<128)return t;r=0}else{for(;r<3;++r){if(this.pos>=this.len)throw Vt(this);if(t.lo=(t.lo|(this.buf[this.pos]&127)<<r*7)>>>0,this.buf[this.pos++]<128)return t}return t.lo=(t.lo|(this.buf[this.pos++]&127)<<r*7)>>>0,t}if(this.len-this.pos>4){for(;r<5;++r)if(t.hi=(t.hi|(this.buf[this.pos]&127)<<r*7+3)>>>0,this.buf[this.pos++]<128)return t}else for(;r<5;++r){if(this.pos>=this.len)throw Vt(this);if(t.hi=(t.hi|(this.buf[this.pos]&127)<<r*7+3)>>>0,this.buf[this.pos++]<128)return t}throw Error("invalid varint encoding")}readFixed64(){if(this.pos+8>this.len)throw Vt(this,8);let t=Rn(this.buf,this.pos+=4),r=Rn(this.buf,this.pos+=4);return new Pt(t,r)}int64(){return this.readLongVarint().toBigInt()}int64Number(){return this.readLongVarint().toNumber()}int64String(){return this.readLongVarint().toString()}uint64(){return this.readLongVarint().toBigInt(!0)}uint64Number(){let t=Es(this.buf,this.pos);return this.pos+=lt(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 Is(e){return new _s(e instanceof Uint8Array?e:e.subarray())}function Le(e,t,r){let n=Is(e);return t.decode(n,void 0,r)}function Cs(e){let t=e??8192,r=t>>>1,n,o=t;return function(i){if(i<1||i>r)return ft(i);o+i>t&&(n=ft(t),o=0);let a=n.subarray(o,o+=i);return(o&7)!==0&&(o=(o|7)+1),a}}var De=class{fn;len;next;val;constructor(t,r,n){this.fn=t,this.len=r,this.next=void 0,this.val=n}};function Bs(){}var Ls=class{head;tail;len;next;constructor(t){this.head=t.head,this.tail=t.tail,this.len=t.len,this.next=t.states}},yh=Cs();function gh(e){return globalThis.Buffer!=null?ft(e):yh(e)}var kr=class{len;head;tail;states;constructor(){this.len=0,this.head=new De(Bs,0,0),this.tail=this.head,this.states=null}_push(t,r,n){return this.tail=this.tail.next=new De(t,r,n),this.len+=r,this}uint32(t){return this.len+=(this.tail=this.tail.next=new Ds((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(Un,10,Pt.fromNumber(t)):this.uint32(t)}sint32(t){return this.uint32((t<<1^t>>31)>>>0)}uint64(t){let r=Pt.fromBigInt(t);return this._push(Un,r.length(),r)}uint64Number(t){return this._push(rr,lt(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 r=Pt.fromBigInt(t).zzEncode();return this._push(Un,r.length(),r)}sint64Number(t){let r=Pt.fromNumber(t).zzEncode();return this._push(Un,r.length(),r)}sint64String(t){return this.sint64(BigInt(t))}bool(t){return this._push(Ts,1,t?1:0)}fixed32(t){return this._push(Nr,4,t>>>0)}sfixed32(t){return this.fixed32(t)}fixed64(t){let r=Pt.fromBigInt(t);return this._push(Nr,4,r.lo)._push(Nr,4,r.hi)}fixed64Number(t){let r=Pt.fromNumber(t);return this._push(Nr,4,r.lo)._push(Nr,4,r.hi)}fixed64String(t){return this.fixed64(BigInt(t))}sfixed64(t){return this.fixed64(t)}sfixed64Number(t){return this.fixed64Number(t)}sfixed64String(t){return this.fixed64String(t)}float(t){return this._push(dc,4,t)}double(t){return this._push(mc,8,t)}bytes(t){let r=t.length>>>0;return r===0?this._push(Ts,1,0):this.uint32(r)._push(bh,r,t)}string(t){let r=xc(t);return r!==0?this.uint32(r)._push(vs,r,t):this._push(Ts,1,0)}fork(){return this.states=new Ls(this),this.head=this.tail=new De(Bs,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 De(Bs,0,0),this.len=0),this}ldelim(){let t=this.head,r=this.tail,n=this.len;return this.reset().uint32(n),n!==0&&(this.tail.next=t.next,this.tail=r,this.len+=n),this}finish(){let t=this.head.next,r=gh(this.len),n=0;for(;t!=null;)t.fn(t.val,r,n),n+=t.len,t=t.next;return r}};function Ts(e,t,r){t[r]=e&255}function xh(e,t,r){for(;e>127;)t[r++]=e&127|128,e>>>=7;t[r]=e}var Ds=class extends De{next;constructor(t,r){super(xh,t,r),this.next=void 0}};function Un(e,t,r){for(;e.hi!==0;)t[r++]=e.lo&127|128,e.lo=(e.lo>>>7|e.hi<<25)>>>0,e.hi>>>=7;for(;e.lo>127;)t[r++]=e.lo&127|128,e.lo=e.lo>>>7;t[r++]=e.lo}function Nr(e,t,r){t[r]=e&255,t[r+1]=e>>>8&255,t[r+2]=e>>>16&255,t[r+3]=e>>>24}function bh(e,t,r){t.set(e,r)}globalThis.Buffer!=null&&(kr.prototype.bytes=function(e){let t=e.length>>>0;return this.uint32(t),t>0&&this._push(wh,t,e),this},kr.prototype.string=function(e){let t=globalThis.Buffer.byteLength(e);return this.uint32(t),t>0&&this._push(Eh,t,e),this});function wh(e,t,r){t.set(e,r)}function Eh(e,t,r){e.length<40?vs(e,t,r):t.utf8Write!=null?t.utf8Write(e,r):t.set(G(e),r)}function Ps(){return new kr}function Pe(e,t){let r=Ps();return t.encode(e,r,{lengthDelimited:!1}),r.finish()}var nr;(function(e){e[e.VARINT=0]="VARINT",e[e.BIT64=1]="BIT64",e[e.LENGTH_DELIMITED=2]="LENGTH_DELIMITED",e[e.START_GROUP=3]="START_GROUP",e[e.END_GROUP=4]="END_GROUP",e[e.BIT32=5]="BIT32"})(nr||(nr={}));function Nn(e,t,r,n){return{name:e,type:t,encode:r,decode:n}}function Rs(e){function t(o){if(e[o.toString()]==null)throw new Error("Invalid enum value");return e[o]}let r=function(s,i){let a=t(s);i.int32(a)},n=function(s){let i=s.int32();return t(i)};return Nn("enum",nr.VARINT,r,n)}function Re(e,t){return Nn("message",nr.LENGTH_DELIMITED,e,t)}var Or=class extends Error{code="ERR_MAX_LENGTH";name="MaxLengthError"};var it;(function(e){e.RSA="RSA",e.Ed25519="Ed25519",e.secp256k1="secp256k1",e.ECDSA="ECDSA"})(it||(it={}));var Us;(function(e){e[e.RSA=0]="RSA",e[e.Ed25519=1]="Ed25519",e[e.secp256k1=2]="secp256k1",e[e.ECDSA=3]="ECDSA"})(Us||(Us={}));(function(e){e.codec=()=>Rs(Us)})(it||(it={}));var $t;(function(e){let t;e.codec=()=>(t==null&&(t=Re((r,n,o={})=>{o.lengthDelimited!==!1&&n.fork(),r.Type!=null&&(n.uint32(8),it.codec().encode(r.Type,n)),r.Data!=null&&(n.uint32(18),n.bytes(r.Data)),o.lengthDelimited!==!1&&n.ldelim()},(r,n,o={})=>{let s={},i=n==null?r.len:r.pos+n;for(;r.pos<i;){let a=r.uint32();switch(a>>>3){case 1:{s.Type=it.codec().decode(r);break}case 2:{s.Data=r.bytes();break}default:{r.skipType(a&7);break}}}return s})),t),e.encode=r=>Pe(r,e.codec()),e.decode=(r,n)=>Le(r,e.codec(),n)})($t||($t={}));var Ns;(function(e){let t;e.codec=()=>(t==null&&(t=Re((r,n,o={})=>{o.lengthDelimited!==!1&&n.fork(),r.Type!=null&&(n.uint32(8),it.codec().encode(r.Type,n)),r.Data!=null&&(n.uint32(18),n.bytes(r.Data)),o.lengthDelimited!==!1&&n.ldelim()},(r,n,o={})=>{let s={},i=n==null?r.len:r.pos+n;for(;r.pos<i;){let a=r.uint32();switch(a>>>3){case 1:{s.Type=it.codec().decode(r);break}case 2:{s.Data=r.bytes();break}default:{r.skipType(a&7);break}}}return s})),t),e.encode=r=>Pe(r,e.codec()),e.decode=(r,n)=>Le(r,e.codec(),n)})(Ns||(Ns={}));var Mr={};vt(Mr,{MAX_RSA_KEY_SIZE:()=>ks,generateRSAKeyPair:()=>_c,jwkToJWKKeyPair:()=>Ic,jwkToPkcs1:()=>_h,jwkToPkix:()=>Hs,jwkToRSAPrivateKey:()=>Fs,pkcs1MessageToJwk:()=>Ks,pkcs1MessageToRSAPrivateKey:()=>Vs,pkcs1ToJwk:()=>vh,pkcs1ToRSAPrivateKey:()=>vc,pkixMessageToJwk:()=>Ms,pkixMessageToRSAPublicKey:()=>zs,pkixToJwk:()=>Ih,pkixToRSAPublicKey:()=>qs});var ye=wn;var or=class{type="RSA";jwk;_raw;_multihash;constructor(t,r){this.jwk=t,this._multihash=r}get raw(){return this._raw==null&&(this._raw=Mr.jwkToPkix(this.jwk)),this._raw}toMultihash(){return this._multihash}toCID(){return st.createV1(114,this._multihash)}toString(){return J.encode(this.toMultihash().bytes).substring(1)}equals(t){return t==null||!(t.raw instanceof Uint8Array)?!1:at(this.raw,t.raw)}verify(t,r,n){return Ac(this.jwk,r,t,n)}},Kr=class{type="RSA";jwk;_raw;publicKey;constructor(t,r){this.jwk=t,this.publicKey=r}get raw(){return this._raw==null&&(this._raw=Mr.jwkToPkcs1(this.jwk)),this._raw}equals(t){return t==null||!(t.raw instanceof Uint8Array)?!1:at(this.raw,t.raw)}sign(t,r){return Sc(this.jwk,t,r)}};var ks=8192,Os=18,Sh=1062,Ah=Uint8Array.from([48,13,6,9,42,134,72,134,247,13,1,1,1,5,0]);function vh(e){let t=Xt(e);return Ks(t)}function Ks(e){return{n:H(e[1],"base64url"),e:H(e[2],"base64url"),d:H(e[3],"base64url"),p:H(e[4],"base64url"),q:H(e[5],"base64url"),dp:H(e[6],"base64url"),dq:H(e[7],"base64url"),qi:H(e[8],"base64url"),kty:"RSA"}}function _h(e){if(e.n==null||e.e==null||e.d==null||e.p==null||e.q==null||e.dp==null||e.dq==null||e.qi==null)throw new nt("JWK was missing components");return ce([Tt(Uint8Array.from([0])),Tt(G(e.n,"base64url")),Tt(G(e.e,"base64url")),Tt(G(e.d,"base64url")),Tt(G(e.p,"base64url")),Tt(G(e.q,"base64url")),Tt(G(e.dp,"base64url")),Tt(G(e.dq,"base64url")),Tt(G(e.qi,"base64url"))]).subarray()}function Ih(e){let t=Xt(e,{offset:0});return Ms(t)}function Ms(e){let t=Xt(e[1],{offset:0});return{kty:"RSA",n:H(t[0],"base64url"),e:H(t[1],"base64url")}}function Hs(e){if(e.n==null||e.e==null)throw new nt("JWK was missing components");return ce([Ah,yn(ce([Tt(G(e.n,"base64url")),Tt(G(e.e,"base64url"))]))]).subarray()}function vc(e){let t=Xt(e);return Vs(t)}function Vs(e){let t=Ks(e);return Fs(t)}function qs(e,t){if(e.byteLength>=Sh)throw new Ve("Key size is too large");let r=Xt(e,{offset:0});return zs(r,e,t)}function zs(e,t,r){let n=Ms(e);if(r==null){let o=ye($t.encode({Type:it.RSA,Data:t}));r=Rt(Os,o)}return new or(n,r)}function Fs(e){if(Bc(e)>ks)throw new nt("Key size is too large");let t=Ic(e),r=ye($t.encode({Type:it.RSA,Data:Hs(t.publicKey)})),n=Rt(Os,r);return new Kr(t.privateKey,new or(t.publicKey,n))}async function _c(e){if(e>ks)throw new nt("Key size is too large");let t=await Cc(e),r=ye($t.encode({Type:it.RSA,Data:Hs(t.publicKey)})),n=Rt(Os,r);return new Kr(t.privateKey,new or(t.publicKey,n))}function Ic(e){if(e==null)throw new nt("Missing key parameter");return{privateKey:e,publicKey:{kty:e.kty,n:e.n,e:e.e}}}async function Cc(e,t){let r=await Nt.get().subtle.generateKey({name:"RSASSA-PKCS1-v1_5",modulusLength:e,publicExponent:new Uint8Array([1,0,1]),hash:{name:"SHA-256"}},!0,["sign","verify"]);t?.signal?.throwIfAborted();let n=await Ch(r,t);return{privateKey:n[0],publicKey:n[1]}}async function Sc(e,t,r){let n=await Nt.get().subtle.importKey("jwk",e,{name:"RSASSA-PKCS1-v1_5",hash:{name:"SHA-256"}},!1,["sign"]);r?.signal?.throwIfAborted();let o=await Nt.get().subtle.sign({name:"RSASSA-PKCS1-v1_5"},n,t instanceof Uint8Array?t:t.subarray());return r?.signal?.throwIfAborted(),new Uint8Array(o,0,o.byteLength)}async function Ac(e,t,r,n){let o=await Nt.get().subtle.importKey("jwk",e,{name:"RSASSA-PKCS1-v1_5",hash:{name:"SHA-256"}},!1,["verify"]);n?.signal?.throwIfAborted();let s=await Nt.get().subtle.verify({name:"RSASSA-PKCS1-v1_5"},o,t,r instanceof Uint8Array?r:r.subarray());return n?.signal?.throwIfAborted(),s}async function Ch(e,t){if(e.privateKey==null||e.publicKey==null)throw new nt("Private and public key are required");let r=await Promise.all([Nt.get().subtle.exportKey("jwk",e.privateKey),Nt.get().subtle.exportKey("jwk",e.publicKey)]);return t?.signal?.throwIfAborted(),r}function Bc(e){if(e.kty!=="RSA")throw new nt("invalid key type");if(e.n==null)throw new nt("invalid key modulus");return G(e.n,"base64url").length*8}var kn=class extends $e{constructor(t,r){super(),this.finished=!1,this.destroyed=!1,_r(t);let n=ue(r);if(this.iHash=t.create(),typeof this.iHash.update!="function")throw new Error("Expected instance of class which extends utils.Hash");this.blockLen=this.iHash.blockLen,this.outputLen=this.iHash.outputLen;let o=this.blockLen,s=new Uint8Array(o);s.set(n.length>o?t.create().update(n).digest():n);for(let i=0;i<s.length;i++)s[i]^=54;this.iHash.update(s),this.oHash=t.create();for(let i=0;i<s.length;i++)s[i]^=106;this.oHash.update(s),Ot(s)}update(t){return Ze(this),this.iHash.update(t),this}digestInto(t){Ze(this),bt(t,this.outputLen),this.finished=!0,this.iHash.digestInto(t),this.oHash.update(t),this.oHash.digestInto(t),this.destroy()}digest(){let t=new Uint8Array(this.oHash.outputLen);return this.digestInto(t),t}_cloneInto(t){t||(t=Object.create(Object.getPrototypeOf(this),{}));let{oHash:r,iHash:n,finished:o,destroyed:s,blockLen:i,outputLen:a}=this;return t=t,t.finished=o,t.destroyed=s,t.blockLen=i,t.outputLen=a,t.oHash=r._cloneInto(t.oHash),t.iHash=n._cloneInto(t.iHash),t}clone(){return this._cloneInto()}destroy(){this.destroyed=!0,this.oHash.destroy(),this.iHash.destroy()}},sr=(e,t,r)=>new kn(e,t).update(r).digest();sr.create=(e,t)=>new kn(e,t);function Tc(e){e.lowS!==void 0&&te("lowS",e.lowS),e.prehash!==void 0&&te("prehash",e.prehash)}var Gs=class extends Error{constructor(t=""){super(t)}},ee={Err:Gs,_tlv:{encode:(e,t)=>{let{Err:r}=ee;if(e<0||e>256)throw new r("tlv.encode: wrong tag");if(t.length&1)throw new r("tlv.encode: unpadded data");let n=t.length/2,o=Tr(n);if(o.length/2&128)throw new r("tlv.encode: long form length too big");let s=n>127?Tr(o.length/2|128):"";return Tr(e)+s+o+t},decode(e,t){let{Err:r}=ee,n=0;if(e<0||e>256)throw new r("tlv.encode: wrong tag");if(t.length<2||t[n++]!==e)throw new r("tlv.decode: wrong tlv");let o=t[n++],s=!!(o&128),i=0;if(!s)i=o;else{let c=o&127;if(!c)throw new r("tlv.decode(long): indefinite length not supported");if(c>4)throw new r("tlv.decode(long): byte length is too big");let u=t.subarray(n,n+c);if(u.length!==c)throw new r("tlv.decode: length bytes not complete");if(u[0]===0)throw new r("tlv.decode(long): zero leftmost byte");for(let f of u)i=i<<8|f;if(n+=c,i<128)throw new r("tlv.decode(long): not minimal encoding")}let a=t.subarray(n,n+i);if(a.length!==i)throw new r("tlv.decode: wrong value length");return{v:a,l:t.subarray(n+i)}}},_int:{encode(e){let{Err:t}=ee;if(e<Hr)throw new t("integer: negative integers are not allowed");let r=Tr(e);if(Number.parseInt(r[0],16)&8&&(r="00"+r),r.length&1)throw new t("unexpected DER parsing assertion: unpadded hex");return r},decode(e){let{Err:t}=ee;if(e[0]&128)throw new t("invalid signature integer: negative");if(e[0]===0&&!(e[1]&128))throw new t("invalid signature integer: unnecessary leading zero");return Xe(e)}},toSig(e){let{Err:t,_int:r,_tlv:n}=ee,o=Y("signature",e),{v:s,l:i}=n.decode(48,o);if(i.length)throw new t("invalid signature: left bytes after parsing");let{v:a,l:c}=n.decode(2,s),{v:u,l:f}=n.decode(2,c);if(f.length)throw new t("invalid signature: left bytes after parsing");return{r:r.decode(a),s:r.decode(u)}},hexFromSig(e){let{_tlv:t,_int:r}=ee,n=t.encode(2,r.encode(e.r)),o=t.encode(2,r.encode(e.s)),s=n+o;return t.encode(48,s)}},Hr=BigInt(0),Vr=BigInt(1),Bh=BigInt(2),On=BigInt(3),Th=BigInt(4);function Lh(e,t,r){function n(o){let s=e.sqr(o),i=e.mul(s,o);return e.add(e.add(i,e.mul(o,t)),r)}return n}function Lc(e,t,r){let{BYTES:n}=e;function o(s){let i;if(typeof s=="bigint")i=s;else{let a=Y("private key",s);if(t){if(!t.includes(a.length*2))throw new Error("invalid private key");let c=new Uint8Array(n);c.set(a,c.length-a.length),a=c}try{i=e.fromBytes(a)}catch{throw new Error(`invalid private key: expected ui8a of size ${n}, got ${typeof s}`)}}if(r&&(i=e.create(i)),!e.isValidNot0(i))throw new Error("invalid private key: out of range [1..N-1]");return i}return o}function Dh(e,t={}){let{Fp:r,Fn:n}=_n("weierstrass",e,t),{h:o,n:s}=e;Gt(t,{},{allowInfinityPoint:"boolean",clearCofactor:"function",isTorsionFree:"function",fromBytes:"function",toBytes:"function",endo:"object",wrapPrivateKey:"boolean"});let{endo:i}=t;if(i&&(!r.is0(e.a)||typeof i.beta!="bigint"||typeof i.splitScalar!="function"))throw new Error('invalid endo: expected "beta": bigint and "splitScalar": function');function a(){if(!r.isOdd)throw new Error("compression is not supported: Field does not have .isOdd()")}function c(T,d,b){let{x:y,y:w}=d.toAffine(),A=r.toBytes(y);if(te("isCompressed",b),b){a();let _=!r.isOdd(w);return Dt(Dc(_),A)}else return Dt(Uint8Array.of(4),A,r.toBytes(w))}function u(T){bt(T);let d=r.BYTES,b=d+1,y=2*d+1,w=T.length,A=T[0],_=T.subarray(1);if(w===b&&(A===2||A===3)){let v=r.fromBytes(_);if(!r.isValid(v))throw new Error("bad point: is not on curve, wrong x");let B=p(v),D;try{D=r.sqrt(B)}catch(K){let k=K instanceof Error?": "+K.message:"";throw new Error("bad point: is not on curve, sqrt error"+k)}a();let U=r.isOdd(D);return(A&1)===1!==U&&(D=r.neg(D)),{x:v,y:D}}else if(w===y&&A===4){let v=r.fromBytes(_.subarray(d*0,d*1)),B=r.fromBytes(_.subarray(d*1,d*2));if(!m(v,B))throw new Error("bad point: is not on curve");return{x:v,y:B}}else throw new Error(`bad point: got length ${w}, expected compressed=${b} or uncompressed=${y}`)}let f=t.toBytes||c,l=t.fromBytes||u,p=Lh(r,e.a,e.b);function m(T,d){let b=r.sqr(d),y=p(T);return r.eql(b,y)}if(!m(e.Gx,e.Gy))throw new Error("bad curve params: generator point");let x=r.mul(r.pow(e.a,On),Th),g=r.mul(r.sqr(e.b),BigInt(27));if(r.is0(r.add(x,g)))throw new Error("bad curve params: a or b");function h(T,d,b=!1){if(!r.isValid(d)||b&&r.is0(d))throw new Error(`bad point coordinate ${T}`);return d}function E(T){if(!(T instanceof S))throw new Error("ProjectivePoint expected")}let C=Je((T,d)=>{let{px:b,py:y,pz:w}=T;if(r.eql(w,r.ONE))return{x:b,y};let A=T.is0();d==null&&(d=A?r.ONE:r.inv(w));let _=r.mul(b,d),v=r.mul(y,d),B=r.mul(w,d);if(A)return{x:r.ZERO,y:r.ZERO};if(!r.eql(B,r.ONE))throw new Error("invZ was invalid");return{x:_,y:v}}),I=Je(T=>{if(T.is0()){if(t.allowInfinityPoint&&!r.is0(T.py))return;throw new Error("bad point: ZERO")}let{x:d,y:b}=T.toAffine();if(!r.isValid(d)||!r.isValid(b))throw new Error("bad point: x or y not field elements");if(!m(d,b))throw new Error("bad point: equation left != right");if(!T.isTorsionFree())throw new Error("bad point: not in prime-order subgroup");return!0});function N(T,d,b,y,w){return b=new S(r.mul(b.px,T),b.py,b.pz),d=Qe(y,d),b=Qe(w,b),d.add(b)}class S{constructor(d,b,y){this.px=h("x",d),this.py=h("y",b,!0),this.pz=h("z",y),Object.freeze(this)}static fromAffine(d){let{x:b,y}=d||{};if(!d||!r.isValid(b)||!r.isValid(y))throw new Error("invalid affine point");if(d instanceof S)throw new Error("projective point not allowed");return r.is0(b)&&r.is0(y)?S.ZERO:new S(b,y,r.ONE)}get x(){return this.toAffine().x}get y(){return this.toAffine().y}static normalizeZ(d){return Sn(S,"pz",d)}static fromBytes(d){return bt(d),S.fromHex(d)}static fromHex(d){let b=S.fromAffine(l(Y("pointHex",d)));return b.assertValidity(),b}static fromPrivateKey(d){let b=Lc(n,t.allowedPrivateKeyLengths,t.wrapPrivateKey);return S.BASE.multiply(b(d))}static msm(d,b){return vn(S,n,d,b)}precompute(d=8,b=!0){return L.setWindowSize(this,d),b||this.multiply(On),this}_setWindowSize(d){this.precompute(d)}assertValidity(){I(this)}hasEvenY(){let{y:d}=this.toAffine();if(!r.isOdd)throw new Error("Field doesn't support isOdd");return!r.isOdd(d)}equals(d){E(d);let{px:b,py:y,pz:w}=this,{px:A,py:_,pz:v}=d,B=r.eql(r.mul(b,v),r.mul(A,w)),D=r.eql(r.mul(y,v),r.mul(_,w));return B&&D}negate(){return new S(this.px,r.neg(this.py),this.pz)}double(){let{a:d,b}=e,y=r.mul(b,On),{px:w,py:A,pz:_}=this,v=r.ZERO,B=r.ZERO,D=r.ZERO,U=r.mul(w,w),P=r.mul(A,A),K=r.mul(_,_),k=r.mul(w,A);return k=r.add(k,k),D=r.mul(w,_),D=r.add(D,D),v=r.mul(d,D),B=r.mul(y,K),B=r.add(v,B),v=r.sub(P,B),B=r.add(P,B),B=r.mul(v,B),v=r.mul(k,v),D=r.mul(y,D),K=r.mul(d,K),k=r.sub(U,K),k=r.mul(d,k),k=r.add(k,D),D=r.add(U,U),U=r.add(D,U),U=r.add(U,K),U=r.mul(U,k),B=r.add(B,U),K=r.mul(A,_),K=r.add(K,K),U=r.mul(K,k),v=r.sub(v,U),D=r.mul(K,P),D=r.add(D,D),D=r.add(D,D),new S(v,B,D)}add(d){E(d);let{px:b,py:y,pz:w}=this,{px:A,py:_,pz:v}=d,B=r.ZERO,D=r.ZERO,U=r.ZERO,P=e.a,K=r.mul(e.b,On),k=r.mul(b,A),M=r.mul(y,_),W=r.mul(w,v),X=r.add(b,y),q=r.add(A,_);X=r.mul(X,q),q=r.add(k,M),X=r.sub(X,q),q=r.add(b,w);let et=r.add(A,v);return q=r.mul(q,et),et=r.add(k,W),q=r.sub(q,et),et=r.add(y,w),B=r.add(_,v),et=r.mul(et,B),B=r.add(M,W),et=r.sub(et,B),U=r.mul(P,q),B=r.mul(K,W),U=r.add(B,U),B=r.sub(M,U),U=r.add(M,U),D=r.mul(B,U),M=r.add(k,k),M=r.add(M,k),W=r.mul(P,W),q=r.mul(K,q),M=r.add(M,W),W=r.sub(k,W),W=r.mul(P,W),q=r.add(q,W),k=r.mul(M,q),D=r.add(D,k),k=r.mul(et,q),B=r.mul(X,B),B=r.sub(B,k),k=r.mul(X,M),U=r.mul(et,U),U=r.add(U,k),new S(B,D,U)}subtract(d){return this.add(d.negate())}is0(){return this.equals(S.ZERO)}multiply(d){let{endo:b}=t;if(!n.isValidNot0(d))throw new Error("invalid scalar: out of range");let y,w,A=_=>L.wNAFCached(this,_,S.normalizeZ);if(b){let{k1neg:_,k1:v,k2neg:B,k2:D}=b.splitScalar(d),{p:U,f:P}=A(v),{p:K,f:k}=A(D);w=P.add(k),y=N(b.beta,U,K,_,B)}else{let{p:_,f:v}=A(d);y=_,w=v}return S.normalizeZ([y,w])[0]}multiplyUnsafe(d){let{endo:b}=t,y=this;if(!n.isValid(d))throw new Error("invalid scalar: out of range");if(d===Hr||y.is0())return S.ZERO;if(d===Vr)return y;if(L.hasPrecomputes(this))return this.multiply(d);if(b){let{k1neg:w,k1:A,k2neg:_,k2:v}=b.splitScalar(d),{p1:B,p2:D}=rc(S,y,A,v);return N(b.beta,B,D,w,_)}else return L.wNAFCachedUnsafe(y,d)}multiplyAndAddUnsafe(d,b,y){let w=this.multiplyUnsafe(b).add(d.multiplyUnsafe(y));return w.is0()?void 0:w}toAffine(d){return C(this,d)}isTorsionFree(){let{isTorsionFree:d}=t;return o===Vr?!0:d?d(S,this):L.wNAFCachedUnsafe(this,s).is0()}clearCofactor(){let{clearCofactor:d}=t;return o===Vr?this:d?d(S,this):this.multiplyUnsafe(o)}toBytes(d=!0){return te("isCompressed",d),this.assertValidity(),f(S,this,d)}toRawBytes(d=!0){return this.toBytes(d)}toHex(d=!0){return qt(this.toBytes(d))}toString(){return`<Point ${this.is0()?"ZERO":this.toHex()}>`}}S.BASE=new S(e.Gx,e.Gy,r.ONE),S.ZERO=new S(r.ZERO,r.ONE,r.ZERO),S.Fp=r,S.Fn=n;let R=n.BITS,L=An(S,t.endo?Math.ceil(R/2):R);return S}function Dc(e){return Uint8Array.of(e?2:3)}function Ph(e,t,r={}){Gt(t,{hash:"function"},{hmac:"function",lowS:"boolean",randomBytes:"function",bits2int:"function",bits2int_modN:"function"});let n=t.randomBytes||Se,o=t.hmac||((y,...w)=>sr(t.hash,y,Dt(...w))),{Fp:s,Fn:i}=e,{ORDER:a,BITS:c}=i;function u(y){let w=a>>Vr;return y>w}function f(y){return u(y)?i.neg(y):y}function l(y,w){if(!i.isValidNot0(w))throw new Error(`invalid signature ${y}: out of range 1..CURVE.n`)}class p{constructor(w,A,_){l("r",w),l("s",A),this.r=w,this.s=A,_!=null&&(this.recovery=_),Object.freeze(this)}static fromCompact(w){let A=i.BYTES,_=Y("compactSignature",w,A*2);return new p(i.fromBytes(_.subarray(0,A)),i.fromBytes(_.subarray(A,A*2)))}static fromDER(w){let{r:A,s:_}=ee.toSig(Y("DER",w));return new p(A,_)}assertValidity(){}addRecoveryBit(w){return new p(this.r,this.s,w)}recoverPublicKey(w){let A=s.ORDER,{r:_,s:v,recovery:B}=this;if(B==null||![0,1,2,3].includes(B))throw new Error("recovery id invalid");if(a*Bh<A&&B>1)throw new Error("recovery id is ambiguous for h>1 curve");let U=B===2||B===3?_+a:_;if(!s.isValid(U))throw new Error("recovery id 2 or 3 invalid");let P=s.toBytes(U),K=e.fromHex(Dt(Dc((B&1)===0),P)),k=i.inv(U),M=I(Y("msgHash",w)),W=i.create(-M*k),X=i.create(v*k),q=e.BASE.multiplyUnsafe(W).add(K.multiplyUnsafe(X));if(q.is0())throw new Error("point at infinify");return q.assertValidity(),q}hasHighS(){return u(this.s)}normalizeS(){return this.hasHighS()?new p(this.r,i.neg(this.s),this.recovery):this}toBytes(w){if(w==="compact")return Dt(i.toBytes(this.r),i.toBytes(this.s));if(w==="der")return Ye(ee.hexFromSig(this));throw new Error("invalid format")}toDERRawBytes(){return this.toBytes("der")}toDERHex(){return qt(this.toBytes("der"))}toCompactRawBytes(){return this.toBytes("compact")}toCompactHex(){return qt(this.toBytes("compact"))}}let m=Lc(i,r.allowedPrivateKeyLengths,r.wrapPrivateKey),x={isValidPrivateKey(y){try{return m(y),!0}catch{return!1}},normPrivateKeyToScalar:m,randomPrivateKey:()=>{let y=a;return Ya(n(fs(y)),y)},precompute(y=8,w=e.BASE){return w.precompute(y,!1)}};function g(y,w=!0){return e.fromPrivateKey(y).toBytes(w)}function h(y){if(typeof y=="bigint")return!1;if(y instanceof e)return!0;let A=Y("key",y).length,_=s.BYTES,v=_+1,B=2*_+1;if(!(r.allowedPrivateKeyLengths||i.BYTES===v))return A===v||A===B}function E(y,w,A=!0){if(h(y)===!0)throw new Error("first arg must be private key");if(h(w)===!1)throw new Error("second arg must be public key");return e.fromHex(w).multiply(m(y)).toBytes(A)}let C=t.bits2int||function(y){if(y.length>8192)throw new Error("input is too large");let w=Xe(y),A=y.length*8-c;return A>0?w>>BigInt(A):w},I=t.bits2int_modN||function(y){return i.create(C(y))},N=_e(c);function S(y){return Mt("num < 2^"+c,y,Hr,N),i.toBytes(y)}function R(y,w,A=L){if(["recovered","canonical"].some(X=>X in A))throw new Error("sign() legacy options not supported");let{hash:_}=t,{lowS:v,prehash:B,extraEntropy:D}=A;v==null&&(v=!0),y=Y("msgHash",y),Tc(A),B&&(y=Y("prehashed msgHash",_(y)));let U=I(y),P=m(w),K=[S(P),S(U)];if(D!=null&&D!==!1){let X=D===!0?n(s.BYTES):D;K.push(Y("extraEntropy",X))}let k=Dt(...K),M=U;function W(X){let q=C(X);if(!i.isValidNot0(q))return;let et=i.inv(q),Bt=e.BASE.multiply(q).toAffine(),xt=i.create(Bt.x);if(xt===Hr)return;let dt=i.create(et*i.create(M+xt*P));if(dt===Hr)return;let Me=(Bt.x===xt?0:2)|Number(Bt.y&Vr),jt=dt;return v&&u(dt)&&(jt=f(dt),Me^=1),new p(xt,jt,Me)}return{seed:k,k2sig:W}}let L={lowS:t.lowS,prehash:!1},T={lowS:t.lowS,prehash:!1};function d(y,w,A=L){let{seed:_,k2sig:v}=R(y,w,A);return Ha(t.hash.outputLen,i.BYTES,o)(_,v)}e.BASE.precompute(8);function b(y,w,A,_=T){let v=y;w=Y("msgHash",w),A=Y("publicKey",A),Tc(_);let{lowS:B,prehash:D,format:U}=_;if("strict"in _)throw new Error("options.strict was renamed to lowS");if(U!==void 0&&!["compact","der","js"].includes(U))throw new Error('format must be "compact", "der" or "js"');let P=typeof v=="string"||je(v),K=!P&&!U&&typeof v=="object"&&v!==null&&typeof v.r=="bigint"&&typeof v.s=="bigint";if(!P&&!K)throw new Error("invalid signature, expected Uint8Array, hex string or Signature instance");let k,M;try{if(K)if(U===void 0||U==="js")k=new p(v.r,v.s);else throw new Error("invalid format");if(P){try{U!=="compact"&&(k=p.fromDER(v))}catch(jt){if(!(jt instanceof ee.Err))throw jt}!k&&U!=="der"&&(k=p.fromCompact(v))}M=e.fromHex(A)}catch{return!1}if(!k||B&&k.hasHighS())return!1;D&&(w=t.hash(w));let{r:W,s:X}=k,q=I(w),et=i.inv(X),Bt=i.create(q*et),xt=i.create(W*et),dt=e.BASE.multiplyUnsafe(Bt).add(M.multiplyUnsafe(xt));return dt.is0()?!1:i.create(dt.x)===W}return Object.freeze({getPublicKey:g,getSharedSecret:E,sign:d,verify:b,utils:x,Point:e,Signature:p})}function Rh(e){let t={a:e.a,b:e.b,p:e.Fp.ORDER,n:e.n,h:e.h,Gx:e.Gx,Gy:e.Gy},r=e.Fp,n=Ht(t.n,e.nBitLength),o={Fp:r,Fn:n,allowedPrivateKeyLengths:e.allowedPrivateKeyLengths,allowInfinityPoint:e.allowInfinityPoint,endo:e.endo,wrapPrivateKey:e.wrapPrivateKey,isTorsionFree:e.isTorsionFree,clearCofactor:e.clearCofactor,fromBytes:e.fromBytes,toBytes:e.toBytes};return{CURVE:t,curveOpts:o}}function Uh(e){let{CURVE:t,curveOpts:r}=Rh(e),n={hash:e.hash,hmac:e.hmac,randomBytes:e.randomBytes,lowS:e.lowS,bits2int:e.bits2int,bits2int_modN:e.bits2int_modN};return{CURVE:t,curveOpts:r,ecdsaOpts:n}}function Nh(e,t){return Object.assign({},t,{ProjectivePoint:t.Point,CURVE:e})}function Pc(e){let{CURVE:t,curveOpts:r,ecdsaOpts:n}=Uh(e),o=Dh(t,r),s=Ph(o,n,r);return Nh(e,s)}function Rc(e,t){let r=n=>Pc({...e,hash:n});return{...r(t),create:r}}var Kn={p:BigInt("0xfffffffffffffffffffffffffffffffffffffffffffffffffffffffefffffc2f"),n:BigInt("0xfffffffffffffffffffffffffffffffebaaedce6af48a03bbfd25e8cd0364141"),h:BigInt(1),a:BigInt(0),b:BigInt(7),Gx:BigInt("0x79be667ef9dcbbac55a06295ce870b07029bfcdb2dce28d959f2815b16f81798"),Gy:BigInt("0x483ada7726a3c4655da4fbfc0e1108a8fd17b448a68554199c47d08ffb10d4b8")},Hg=BigInt(0),kh=BigInt(1),Ws=BigInt(2),Uc=(e,t)=>(e+t/Ws)/t;function Oh(e){let t=Kn.p,r=BigInt(3),n=BigInt(6),o=BigInt(11),s=BigInt(22),i=BigInt(23),a=BigInt(44),c=BigInt(88),u=e*e*e%t,f=u*u*e%t,l=tt(f,r,t)*f%t,p=tt(l,r,t)*f%t,m=tt(p,Ws,t)*u%t,x=tt(m,o,t)*m%t,g=tt(x,s,t)*x%t,h=tt(g,a,t)*g%t,E=tt(h,c,t)*h%t,C=tt(E,a,t)*g%t,I=tt(C,r,t)*f%t,N=tt(I,i,t)*x%t,S=tt(N,n,t)*u%t,R=tt(S,Ws,t);if(!$s.eql($s.sqr(R),e))throw new Error("Cannot find square root");return R}var $s=Ht(Kn.p,void 0,void 0,{sqrt:Oh}),ir=Rc({...Kn,Fp:$s,lowS:!0,endo:{beta:BigInt("0x7ae96a2b657c07106e64479eac3434e99cf0497512f58995c1396c28719501ee"),splitScalar:e=>{let t=Kn.n,r=BigInt("0x3086d221a7d46bcde86c90e49284eb15"),n=-kh*BigInt("0xe4437ed6010e88286f547fa90abfe4c3"),o=BigInt("0x114ca50f7a8e2f3f657c1108d9d44cfd8"),s=r,i=BigInt("0x100000000000000000000000000000000"),a=Uc(s*e,t),c=Uc(-n*e,t),u=Q(e-a*r-c*o,t),f=Q(-a*n-c*s,t),l=u>i,p=f>i;if(l&&(u=t-u),p&&(f=t-f),u>i||f>i)throw new Error("splitScalar: Endomorphism failed, k="+e);return{k1neg:l,k1:u,k2neg:p,k2:f}}}},wn);function Nc(e,t,r,n){let o=Sr.digest(r instanceof Uint8Array?r:r.subarray());if(Tn(o))return o.then(({digest:s})=>(n?.signal?.throwIfAborted(),ir.verify(t,s,e))).catch(s=>{throw s.name==="AbortError"?s:new Ur(String(s))});try{return n?.signal?.throwIfAborted(),ir.verify(t,o.digest,e)}catch(s){throw new Ur(String(s))}}var Mn=class{type="secp256k1";raw;_key;constructor(t){this._key=Oc(t),this.raw=kc(this._key)}toMultihash(){return kt.digest(fe(this))}toCID(){return st.createV1(114,this.toMultihash())}toString(){return J.encode(this.toMultihash().bytes).substring(1)}equals(t){return t==null||!(t.raw instanceof Uint8Array)?!1:at(this.raw,t.raw)}verify(t,r,n){return Nc(this._key,r,t,n)}};function js(e){return new Mn(e)}function kc(e){return ir.ProjectivePoint.fromHex(e).toRawBytes(!0)}function Oc(e){try{return ir.ProjectivePoint.fromHex(e),e}catch(t){throw new Ve(String(t))}}function qr(e,t){let{Type:r,Data:n}=$t.decode(e),o=n??new Uint8Array;switch(r){case it.RSA:return qs(o,t);case it.Ed25519:return ys(o);case it.secp256k1:return js(o);case it.ECDSA:return ts(o);default:throw new ge}}function Kc(e){let{Type:t,Data:r}=$t.decode(e.digest),n=r??new Uint8Array;switch(t){case it.Ed25519:return ys(n);case it.secp256k1:return js(n);case it.ECDSA:return ts(n);default:throw new ge}}function fe(e){return $t.encode({Type:it[e.type],Data:e.raw})}var Mc=Symbol.for("nodejs.util.inspect.custom"),Kh=114,zr=class{type;multihash;publicKey;string;constructor(t){this.type=t.type,this.multihash=t.multihash,Object.defineProperty(this,"string",{enumerable:!1,writable:!0})}get[Symbol.toStringTag](){return`PeerId(${this.toString()})`}[Io]=!0;toString(){return this.string==null&&(this.string=J.encode(this.multihash.bytes).slice(1)),this.string}toMultihash(){return this.multihash}toCID(){return st.createV1(Kh,this.multihash)}toJSON(){return this.toString()}equals(t){if(t==null)return!1;if(t instanceof Uint8Array)return at(this.multihash.bytes,t);if(typeof t=="string")return this.toString()===t;if(t?.toMultihash()?.bytes!=null)return at(this.multihash.bytes,t.toMultihash().bytes);throw new Error("not valid Id")}[Mc](){return`PeerId(${this.toString()})`}},Fr=class extends zr{type="RSA";publicKey;constructor(t){super({...t,type:"RSA"}),this.publicKey=t.publicKey}},Gr=class extends zr{type="Ed25519";publicKey;constructor(t){super({...t,type:"Ed25519"}),this.publicKey=t.publicKey}},Wr=class extends zr{type="secp256k1";publicKey;constructor(t){super({...t,type:"secp256k1"}),this.publicKey=t.publicKey}},Mh=2336,$r=class{type="url";multihash;publicKey;url;constructor(t){this.url=t.toString(),this.multihash=kt.digest(G(this.url))}[Mc](){return`PeerId(${this.url})`}[Io]=!0;toString(){return this.toCID().toString()}toMultihash(){return this.multihash}toCID(){return st.createV1(Mh,this.toMultihash())}toJSON(){return this.toString()}equals(t){return t==null?!1:(t instanceof Uint8Array&&(t=H(t)),t.toString()===this.toString())}};var Hh=114,Hc=2336;function Vc(e,t){let r;if(e.charAt(0)==="1"||e.charAt(0)==="Q")r=Ge(J.decode(`z${e}`));else{if(e.startsWith("k51qzi5uqu5")||e.startsWith("kzwfwjn5ji4")||e.startsWith("k2k4r8")||e.startsWith("bafz"))return Vh(st.parse(e));if(t==null)throw new nt('Please pass a multibase decoder for strings that do not start with "1" or "Q"');r=Ge(t.decode(e))}return qc(r)}function Zs(e){if(e.type==="Ed25519")return new Gr({multihash:e.toCID().multihash,publicKey:e});if(e.type==="secp256k1")return new Wr({multihash:e.toCID().multihash,publicKey:e});if(e.type==="RSA")return new Fr({multihash:e.toCID().multihash,publicKey:e});throw new ge}function qc(e){if(zh(e))return new Fr({multihash:e});if(qh(e))try{let t=Kc(e);if(t.type==="Ed25519")return new Gr({multihash:e,publicKey:t});if(t.type==="secp256k1")return new Wr({multihash:e,publicKey:t})}catch{let r=H(e.digest);return new $r(new URL(r))}throw new ln("Supplied PeerID Multihash is invalid")}function Vh(e){if(e?.multihash==null||e.version==null||e.version===1&&e.code!==Hh&&e.code!==Hc)throw new un("Supplied PeerID CID is invalid");if(e.code===Hc){let t=H(e.multihash.digest);return new $r(new URL(t))}return qc(e.multihash)}function qh(e){return e.code===kt.code}function zh(e){return e.code===Sr.code}var Hn=class extends Error{name="InvalidMessageLengthError";code="ERR_INVALID_MSG_LENGTH"},ar=class extends Error{name="InvalidDataLengthError";code="ERR_MSG_DATA_TOO_LONG"},Vn=class extends Error{name="InvalidDataLengthLengthError";code="ERR_MSG_LENGTH_TOO_LONG"},jr=class extends Error{name="UnexpectedEOFError";code="ERR_UNEXPECTED_EOF"};function qn(e){return e[Symbol.asyncIterator]!=null}function zc(e,t){if(e.byteLength>t)throw new ar("Message length too long")}var Fn=e=>{let t=lt(e),r=ft(t);return Dn(e,r),Fn.bytes=t,r};Fn.bytes=0;function Fc(e,t){t=t??{};let r=t.lengthEncoder??Fn,n=t?.maxDataLength??4194304;function*o(s){zc(s,n);let i=r(s.byteLength);i instanceof Uint8Array?yield i:yield*i,s instanceof Uint8Array?yield s:yield*s}return qn(e)?async function*(){for await(let s of e)yield*o(s)}():function*(){for(let s of e)yield*o(s)}()}Fc.single=(e,t)=>{t=t??{};let r=t.lengthEncoder??Fn,n=t?.maxDataLength??4194304;return zc(e,n),new F(r(e.byteLength),e)};var Ue;(function(e){e[e.LENGTH=0]="LENGTH",e[e.DATA=1]="DATA"})(Ue||(Ue={}));var Ys=e=>{let t=Be(e);return Ys.bytes=lt(t),t};Ys.bytes=0;function Zr(e,t){let r=new F,n=Ue.LENGTH,o=-1,s=t?.lengthDecoder??Ys,i=t?.maxLengthLength??8,a=t?.maxDataLength??4194304;function*c(){for(;r.byteLength>0;){if(n===Ue.LENGTH)try{if(o=s(r),o<0)throw new Hn("Invalid message length");if(o>a)throw new ar("Message length too long");let u=s.bytes;r.consume(u),t?.onLength!=null&&t.onLength(o),n=Ue.DATA}catch(u){if(u instanceof RangeError){if(r.byteLength>i)throw new Vn("Message length length too long");break}throw u}if(n===Ue.DATA){if(r.byteLength<o)break;let u=r.sublist(0,o);r.consume(o),t?.onData!=null&&t.onData(u),yield u,n=Ue.LENGTH}}}return qn(e)?async function*(){for await(let u of e)r.append(u),yield*c();if(r.byteLength>0)throw new jr("Unexpected end of input")}():function*(){for(let u of e)r.append(u),yield*c();if(r.byteLength>0)throw new jr("Unexpected end of input")}()}Zr.fromReader=(e,t)=>{let r=1,n=async function*(){for(;;)try{let{done:s,value:i}=await e.next(r);if(s===!0)return;i!=null&&(yield i)}catch(s){if(s.code==="ERR_UNDER_READ")return{done:!0,value:null};throw s}finally{r=1}}();return Zr(n,{...t??{},onLength:s=>{r=s}})};function Ct(){let e={};return e.promise=new Promise((t,r)=>{e.resolve=t,e.reject=r}),e}var Gn=class extends Error{type;code;constructor(t,r,n){super(t??"The operation was aborted"),this.type="aborted",this.name=n??"AbortError",this.code=r??"ABORT_ERR"}};async function ht(e,t,r){if(t==null)return e;if(t.aborted)return e.catch(()=>{}),Promise.reject(new Gn(r?.errorMessage,r?.errorCode,r?.errorName));let n,o=new Gn(r?.errorMessage,r?.errorCode,r?.errorName);try{return await Promise.race([e,new Promise((s,i)=>{n=()=>{i(o)},t.addEventListener("abort",n)})])}finally{n!=null&&t.removeEventListener("abort",n)}}var Xs=class{readNext;haveNext;ended;nextResult;error;constructor(){this.ended=!1,this.readNext=Ct(),this.haveNext=Ct()}[Symbol.asyncIterator](){return this}async next(){if(this.nextResult==null&&await this.haveNext.promise,this.nextResult==null)throw new Error("HaveNext promise resolved but nextResult was undefined");let t=this.nextResult;return this.nextResult=void 0,this.readNext.resolve(),this.readNext=Ct(),t}async throw(t){return this.ended=!0,this.error=t,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 this.ended=!0,this.nextResult=t,this.haveNext.resolve(),t}async push(t,r){await this._push(t,r)}async end(t,r){t!=null?await this.throw(t):await this._push(void 0,r)}async _push(t,r){if(t!=null&&this.ended)throw this.error??new Error("Cannot push value onto an ended pushable");for(;this.nextResult!=null;)await this.readNext.promise;t!=null?this.nextResult={done:!1,value:t}:(this.ended=!0,this.nextResult={done:!0,value:void 0}),this.haveNext.resolve(),this.haveNext=Ct(),await ht(this.readNext.promise,r?.signal,r)}};function Wn(){return new Xs}var $n=class extends Error{name="UnexpectedEOFError";code="ERR_UNEXPECTED_EOF"};function Gc(e,t){let r=Wn();e.sink(r).catch(async i=>{await r.end(i)}),e.sink=async i=>{for await(let a of i)await r.push(a);await r.end()};let n=e.source;e.source[Symbol.iterator]!=null?n=e.source[Symbol.iterator]():e.source[Symbol.asyncIterator]!=null&&(n=e.source[Symbol.asyncIterator]());let o=new F;return{read:async i=>{if(i?.signal?.throwIfAborted(),i?.bytes==null){let{done:c,value:u}=await ht(n.next(),i?.signal);return c===!0?null:u}for(;o.byteLength<i.bytes;){let{value:c,done:u}=await ht(n.next(),i?.signal);if(u===!0)throw new $n("unexpected end of input");o.append(c)}let a=o.sublist(0,i.bytes);return o.consume(i.bytes),a},write:async(i,a)=>{a?.signal?.throwIfAborted(),i instanceof Uint8Array?await r.push(i,a):await r.push(i.subarray(),a)},unwrap:()=>{if(o.byteLength>0){let i=e.source;e.source=async function*(){t?.yieldBytes===!1?yield o:yield*o,yield*i}()}return e}}}var jn=class extends Error{name="InvalidMessageLengthError";code="ERR_INVALID_MSG_LENGTH"},Zn=class extends Error{name="InvalidDataLengthError";code="ERR_MSG_DATA_TOO_LONG"},Yn=class extends Error{name="InvalidDataLengthLengthError";code="ERR_MSG_LENGTH_TOO_LONG"};function Js(e,t={}){let r=Gc(e,t);t.maxDataLength!=null&&t.maxLengthLength==null&&(t.maxLengthLength=lt(t.maxDataLength));let n=t?.lengthDecoder??Be,o=t?.lengthEncoder??Dn;return{read:async i=>{let a=-1,c=new F;for(;;){c.append(await r.read({...i,bytes:1}));try{a=n(c)}catch(u){if(u instanceof RangeError)continue;throw u}if(a<0)throw new jn("Invalid message length");if(t?.maxLengthLength!=null&&c.byteLength>t.maxLengthLength)throw new Yn("message length length too long");if(a>-1)break}if(t?.maxDataLength!=null&&a>t.maxDataLength)throw new Zn("message length too long");return r.read({...i,bytes:a})},write:async(i,a)=>{await r.write(new F(o(i.byteLength),i),a)},writeV:async(i,a)=>{let c=new F(...i.flatMap(u=>[o(u.byteLength),u]));await r.write(c,a)},unwrap:()=>r.unwrap()}}function Qs(){let e=Ct(),t=!1;return{sink:async r=>{if(t)throw new Error("already piped");t=!0,e.resolve(r)},source:async function*(){yield*await e.promise}()}}function Wc(){let e=Qs(),t=Qs();return[{source:e.source,sink:t.sink},{source:t.source,sink:e.sink}]}var Xn=class{buffer;mask;top;btm;next;constructor(t){if(!(t>0)||(t-1&t)!==0)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}},cr=class{size;hwm;head;tail;constructor(t={}){this.hwm=t.splitLimit??16,this.head=new Xn(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 r=this.head;this.head=r.next=new Xn(2*this.head.buffer.length),this.head.push(t)}}shift(){let t=this.tail.shift();if(t===void 0&&this.tail.next!=null){let r=this.tail.next;this.tail.next=null,this.tail=r,t=this.tail.shift()}return t?.value!=null&&(this.size-=this.calculateSize(t.value)),t}isEmpty(){return this.head.isEmpty()}};var ti=class extends Error{type;code;constructor(t,r){super(t??"The operation was aborted"),this.type="aborted",this.code=r??"ABORT_ERR"}};function Jn(e={}){return Gh(r=>{let n=r.shift();if(n==null)return{done:!0};if(n.error!=null)throw n.error;return{done:n.done===!0,value:n.value}},e)}function Gh(e,t){t=t??{};let r=t.onEnd,n=new cr,o,s,i,a=Ct(),c=async()=>{try{return n.isEmpty()?i?{done:!0}:await new Promise((h,E)=>{s=C=>{s=null,n.push(C);try{h(e(n))}catch(I){E(I)}return o}}):e(n)}finally{n.isEmpty()&&queueMicrotask(()=>{a.resolve(),a=Ct()})}},u=h=>s!=null?s(h):(n.push(h),o),f=h=>(n=new cr,s!=null?s({error:h}):(n.push({error:h}),o)),l=h=>{if(i)return o;if(t?.objectMode!==!0&&h?.byteLength==null)throw new Error("objectMode was not true but tried to push non-Uint8Array value");return u({done:!1,value:h})},p=h=>i?o:(i=!0,h!=null?f(h):u({done:!0})),m=()=>(n=new cr,p(),{done:!0}),x=h=>(p(h),{done:!0});if(o={[Symbol.asyncIterator](){return this},next:c,return:m,throw:x,push:l,end:p,get readableLength(){return n.size},onEmpty:async h=>{let E=h?.signal;if(E?.throwIfAborted(),n.isEmpty())return;let C,I;E!=null&&(C=new Promise((N,S)=>{I=()=>{S(new ti)},E.addEventListener("abort",I)}));try{await Promise.race([a.promise,C])}finally{I!=null&&E!=null&&E?.removeEventListener("abort",I)}}},r==null)return o;let g=o;return o={[Symbol.asyncIterator](){return this},next(){return g.next()},throw(h){return g.throw(h),r!=null&&(r(h),r=void 0),{done:!0}},return(){return g.return(),r!=null&&(r(),r=void 0),{done:!0}},push:l,end(h){return g.end(h),r!=null&&(r(h),r=void 0),o},get readableLength(){return g.readableLength},onEmpty:h=>g.onEmpty(h)},o}function Wh(e){return e[Symbol.asyncIterator]!=null}async function $h(e,t,r){try{await Promise.all(e.map(async n=>{for await(let o of n)await t.push(o,{signal:r}),r.throwIfAborted()})),await t.end(void 0,{signal:r})}catch(n){await t.end(n,{signal:r}).catch(()=>{})}}async function*jh(e){let t=new AbortController,r=Wn();$h(e,r,t.signal).catch(()=>{});try{yield*r}finally{t.abort()}}function*Zh(e){for(let t of e)yield*t}function Yh(...e){let t=[];for(let r of e)Wh(r)||t.push(r);return t.length===e.length?Zh(t):jh(e)}var $c=Yh;function jc(e,...t){if(e==null)throw new Error("Empty pipeline");if(ei(e)){let n=e;e=()=>n.source}else if(Yc(e)||Zc(e)){let n=e;e=()=>n}let r=[e,...t];if(r.length>1&&ei(r[r.length-1])&&(r[r.length-1]=r[r.length-1].sink),r.length>2)for(let n=1;n<r.length-1;n++)ei(r[n])&&(r[n]=Jh(r[n]));return Xh(...r)}var Xh=(...e)=>{let t;for(;e.length>0;)t=e.shift()(t);return t},Zc=e=>e?.[Symbol.asyncIterator]!=null,Yc=e=>e?.[Symbol.iterator]!=null,ei=e=>e==null?!1:e.sink!=null&&e.source!=null,Jh=e=>t=>{let r=e.sink(t);if(r?.then!=null){let n=Jn({objectMode:!0});r.then(()=>{n.end()},i=>{n.end(i)});let o,s=e.source;if(Zc(s))o=async function*(){yield*s,n.end()};else if(Yc(s))o=function*(){yield*s,n.end()};else throw new Error("Unknown duplex source type - must be Iterable or AsyncIterable");return $c(n,o())}return e.source};var fr=!!globalThis.process?.env?.DUMP_SESSION_KEYS;function Jc(e){return e instanceof Uint8Array||ArrayBuffer.isView(e)&&e.constructor.name==="Uint8Array"}function Qn(e){if(typeof e!="boolean")throw new Error(`boolean expected, not ${e}`)}function to(e){if(!Number.isSafeInteger(e)||e<0)throw new Error("positive integer expected, got "+e)}function St(e,...t){if(!Jc(e))throw new Error("Uint8Array expected");if(t.length>0&&!t.includes(e.length))throw new Error("Uint8Array expected of length "+t+", got length="+e.length)}function ri(e,t=!0){if(e.destroyed)throw new Error("Hash instance has been destroyed");if(t&&e.finished)throw new Error("Hash#digest() has already been called")}function Qc(e,t){St(e);let r=t.outputLen;if(e.length<r)throw new Error("digestInto() expects output buffer of length at least "+r)}function re(e){return new Uint32Array(e.buffer,e.byteOffset,Math.floor(e.byteLength/4))}function ne(...e){for(let t=0;t<e.length;t++)e[t].fill(0)}function Qh(e){return new DataView(e.buffer,e.byteOffset,e.byteLength)}var td=new Uint8Array(new Uint32Array([287454020]).buffer)[0]===68;function ed(e){if(typeof e!="string")throw new Error("string expected");return new Uint8Array(new TextEncoder().encode(e))}function eo(e){if(typeof e=="string")e=ed(e);else if(Jc(e))e=ro(e);else throw new Error("Uint8Array expected, got "+typeof e);return e}function tf(e,t){if(t==null||typeof t!="object")throw new Error("options must be defined");return Object.assign(e,t)}function ef(e,t){if(e.length!==t.length)return!1;let r=0;for(let n=0;n<e.length;n++)r|=e[n]^t[n];return r===0}var ni=(e,t)=>{function r(n,...o){if(St(n),!td)throw new Error("Non little-endian hardware is not yet supported");if(e.nonceLength!==void 0){let f=o[0];if(!f)throw new Error("nonce / iv required");e.varSizeNonce?St(f):St(f,e.nonceLength)}let s=e.tagLength;s&&o[1]!==void 0&&St(o[1]);let i=t(n,...o),a=(f,l)=>{if(l!==void 0){if(f!==2)throw new Error("cipher output not supported");St(l)}},c=!1;return{encrypt(f,l){if(c)throw new Error("cannot encrypt() twice with same key + nonce");return c=!0,St(f),a(i.encrypt.length,l),i.encrypt(f,l)},decrypt(f,l){if(St(f),s&&f.length<s)throw new Error("invalid ciphertext length: smaller than tagLength="+s);return a(i.decrypt.length,l),i.decrypt(f,l)}}}return Object.assign(r,e),r};function oi(e,t,r=!0){if(t===void 0)return new Uint8Array(e);if(t.length!==e)throw new Error("invalid output length, expected "+e+", got: "+t.length);if(r&&!rd(t))throw new Error("invalid output, must be aligned");return t}function Xc(e,t,r,n){if(typeof e.setBigUint64=="function")return e.setBigUint64(t,r,n);let o=BigInt(32),s=BigInt(4294967295),i=Number(r>>o&s),a=Number(r&s),c=n?4:0,u=n?0:4;e.setUint32(t+c,i,n),e.setUint32(t+u,a,n)}function rf(e,t,r){Qn(r);let n=new Uint8Array(16),o=Qh(n);return Xc(o,0,BigInt(t),r),Xc(o,8,BigInt(e),r),n}function rd(e){return e.byteOffset%4===0}function ro(e){return Uint8Array.from(e)}var of=e=>Uint8Array.from(e.split("").map(t=>t.charCodeAt(0))),nd=of("expand 16-byte k"),od=of("expand 32-byte k"),sd=re(nd),id=re(od);function O(e,t){return e<<t|e>>>32-t}function si(e){return e.byteOffset%4===0}var no=64,ad=16,sf=2**32-1,nf=new Uint32Array;function cd(e,t,r,n,o,s,i,a){let c=o.length,u=new Uint8Array(no),f=re(u),l=si(o)&&si(s),p=l?re(o):nf,m=l?re(s):nf;for(let x=0;x<c;i++){if(e(t,r,n,f,i,a),i>=sf)throw new Error("arx: counter overflow");let g=Math.min(no,c-x);if(l&&g===no){let h=x/4;if(x%4!==0)throw new Error("arx: invalid block position");for(let E=0,C;E<ad;E++)C=h+E,m[C]=p[C]^f[E];x+=no;continue}for(let h=0,E;h<g;h++)E=x+h,s[E]=o[E]^u[h];x+=g}}function ii(e,t){let{allowShortKeys:r,extendNonceFn:n,counterLength:o,counterRight:s,rounds:i}=tf({allowShortKeys:!1,counterLength:8,counterRight:!1,rounds:20},t);if(typeof e!="function")throw new Error("core must be a function");return to(o),to(i),Qn(s),Qn(r),(a,c,u,f,l=0)=>{St(a),St(c),St(u);let p=u.length;if(f===void 0&&(f=new Uint8Array(p)),St(f),to(l),l<0||l>=sf)throw new Error("arx: counter overflow");if(f.length<p)throw new Error(`arx: output (${f.length}) is shorter than data (${p})`);let m=[],x=a.length,g,h;if(x===32)m.push(g=ro(a)),h=id;else if(x===16&&r)g=new Uint8Array(32),g.set(a),g.set(a,16),h=sd,m.push(g);else throw new Error(`arx: invalid 32-byte key, got length=${x}`);si(c)||m.push(c=ro(c));let E=re(g);if(n){if(c.length!==24)throw new Error("arx: extended nonce must be 24 bytes");n(h,E,re(c.subarray(0,16)),E),c=c.subarray(16)}let C=16-o;if(C!==c.length)throw new Error(`arx: nonce must be ${C} or 16 bytes`);if(C!==12){let N=new Uint8Array(12);N.set(c,s?0:12-c.length),c=N,m.push(c)}let I=re(c);return cd(e,h,E,I,u,f,l,i),ne(...m),f}}var mt=(e,t)=>e[t++]&255|(e[t++]&255)<<8,ai=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=eo(t),St(t,32);let r=mt(t,0),n=mt(t,2),o=mt(t,4),s=mt(t,6),i=mt(t,8),a=mt(t,10),c=mt(t,12),u=mt(t,14);this.r[0]=r&8191,this.r[1]=(r>>>13|n<<3)&8191,this.r[2]=(n>>>10|o<<6)&7939,this.r[3]=(o>>>7|s<<9)&8191,this.r[4]=(s>>>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|u<<8)&8191,this.r[9]=u>>>5&127;for(let f=0;f<8;f++)this.pad[f]=mt(t,16+2*f)}process(t,r,n=!1){let o=n?0:2048,{h:s,r:i}=this,a=i[0],c=i[1],u=i[2],f=i[3],l=i[4],p=i[5],m=i[6],x=i[7],g=i[8],h=i[9],E=mt(t,r+0),C=mt(t,r+2),I=mt(t,r+4),N=mt(t,r+6),S=mt(t,r+8),R=mt(t,r+10),L=mt(t,r+12),T=mt(t,r+14),d=s[0]+(E&8191),b=s[1]+((E>>>13|C<<3)&8191),y=s[2]+((C>>>10|I<<6)&8191),w=s[3]+((I>>>7|N<<9)&8191),A=s[4]+((N>>>4|S<<12)&8191),_=s[5]+(S>>>1&8191),v=s[6]+((S>>>14|R<<2)&8191),B=s[7]+((R>>>11|L<<5)&8191),D=s[8]+((L>>>8|T<<8)&8191),U=s[9]+(T>>>5|o),P=0,K=P+d*a+b*(5*h)+y*(5*g)+w*(5*x)+A*(5*m);P=K>>>13,K&=8191,K+=_*(5*p)+v*(5*l)+B*(5*f)+D*(5*u)+U*(5*c),P+=K>>>13,K&=8191;let k=P+d*c+b*a+y*(5*h)+w*(5*g)+A*(5*x);P=k>>>13,k&=8191,k+=_*(5*m)+v*(5*p)+B*(5*l)+D*(5*f)+U*(5*u),P+=k>>>13,k&=8191;let M=P+d*u+b*c+y*a+w*(5*h)+A*(5*g);P=M>>>13,M&=8191,M+=_*(5*x)+v*(5*m)+B*(5*p)+D*(5*l)+U*(5*f),P+=M>>>13,M&=8191;let W=P+d*f+b*u+y*c+w*a+A*(5*h);P=W>>>13,W&=8191,W+=_*(5*g)+v*(5*x)+B*(5*m)+D*(5*p)+U*(5*l),P+=W>>>13,W&=8191;let X=P+d*l+b*f+y*u+w*c+A*a;P=X>>>13,X&=8191,X+=_*(5*h)+v*(5*g)+B*(5*x)+D*(5*m)+U*(5*p),P+=X>>>13,X&=8191;let q=P+d*p+b*l+y*f+w*u+A*c;P=q>>>13,q&=8191,q+=_*a+v*(5*h)+B*(5*g)+D*(5*x)+U*(5*m),P+=q>>>13,q&=8191;let et=P+d*m+b*p+y*l+w*f+A*u;P=et>>>13,et&=8191,et+=_*c+v*a+B*(5*h)+D*(5*g)+U*(5*x),P+=et>>>13,et&=8191;let Bt=P+d*x+b*m+y*p+w*l+A*f;P=Bt>>>13,Bt&=8191,Bt+=_*u+v*c+B*a+D*(5*h)+U*(5*g),P+=Bt>>>13,Bt&=8191;let xt=P+d*g+b*x+y*m+w*p+A*l;P=xt>>>13,xt&=8191,xt+=_*f+v*u+B*c+D*a+U*(5*h),P+=xt>>>13,xt&=8191;let dt=P+d*h+b*g+y*x+w*m+A*p;P=dt>>>13,dt&=8191,dt+=_*l+v*f+B*u+D*c+U*a,P+=dt>>>13,dt&=8191,P=(P<<2)+P|0,P=P+K|0,K=P&8191,P=P>>>13,k+=P,s[0]=K,s[1]=k,s[2]=M,s[3]=W,s[4]=X,s[5]=q,s[6]=et,s[7]=Bt,s[8]=xt,s[9]=dt}finalize(){let{h:t,pad:r}=this,n=new Uint16Array(10),o=t[1]>>>13;t[1]&=8191;for(let a=2;a<10;a++)t[a]+=o,o=t[a]>>>13,t[a]&=8191;t[0]+=o*5,o=t[0]>>>13,t[0]&=8191,t[1]+=o,o=t[1]>>>13,t[1]&=8191,t[2]+=o,n[0]=t[0]+5,o=n[0]>>>13,n[0]&=8191;for(let a=1;a<10;a++)n[a]=t[a]+o,o=n[a]>>>13,n[a]&=8191;n[9]-=8192;let s=(o^1)-1;for(let a=0;a<10;a++)n[a]&=s;s=~s;for(let a=0;a<10;a++)t[a]=t[a]&s|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]+r[0];t[0]=i&65535;for(let a=1;a<8;a++)i=(t[a]+r[a]|0)+(i>>>16)|0,t[a]=i&65535;ne(n)}update(t){ri(this),t=eo(t),St(t);let{buffer:r,blockLen:n}=this,o=t.length;for(let s=0;s<o;){let i=Math.min(n-this.pos,o-s);if(i===n){for(;n<=o-s;s+=n)this.process(t,s);continue}r.set(t.subarray(s,s+i),this.pos),this.pos+=i,s+=i,this.pos===n&&(this.process(r,0,!1),this.pos=0)}return this}destroy(){ne(this.h,this.r,this.buffer,this.pad)}digestInto(t){ri(this),Qc(t,this),this.finished=!0;let{buffer:r,h:n}=this,{pos:o}=this;if(o){for(r[o++]=1;o<16;o++)r[o]=0;this.process(r,0,!0)}this.finalize();let s=0;for(let i=0;i<8;i++)t[s++]=n[i]>>>0,t[s++]=n[i]>>>8;return t}digest(){let{buffer:t,outputLen:r}=this;this.digestInto(t);let n=t.slice(0,r);return this.destroy(),n}};function fd(e){let t=(n,o)=>e(o).update(eo(n)).digest(),r=e(new Uint8Array(32));return t.outputLen=r.outputLen,t.blockLen=r.blockLen,t.create=n=>e(n),t}var af=fd(e=>new ai(e));function uf(e,t,r,n,o,s=20){let i=e[0],a=e[1],c=e[2],u=e[3],f=t[0],l=t[1],p=t[2],m=t[3],x=t[4],g=t[5],h=t[6],E=t[7],C=o,I=r[0],N=r[1],S=r[2],R=i,L=a,T=c,d=u,b=f,y=l,w=p,A=m,_=x,v=g,B=h,D=E,U=C,P=I,K=N,k=S;for(let W=0;W<s;W+=2)R=R+b|0,U=O(U^R,16),_=_+U|0,b=O(b^_,12),R=R+b|0,U=O(U^R,8),_=_+U|0,b=O(b^_,7),L=L+y|0,P=O(P^L,16),v=v+P|0,y=O(y^v,12),L=L+y|0,P=O(P^L,8),v=v+P|0,y=O(y^v,7),T=T+w|0,K=O(K^T,16),B=B+K|0,w=O(w^B,12),T=T+w|0,K=O(K^T,8),B=B+K|0,w=O(w^B,7),d=d+A|0,k=O(k^d,16),D=D+k|0,A=O(A^D,12),d=d+A|0,k=O(k^d,8),D=D+k|0,A=O(A^D,7),R=R+y|0,k=O(k^R,16),B=B+k|0,y=O(y^B,12),R=R+y|0,k=O(k^R,8),B=B+k|0,y=O(y^B,7),L=L+w|0,U=O(U^L,16),D=D+U|0,w=O(w^D,12),L=L+w|0,U=O(U^L,8),D=D+U|0,w=O(w^D,7),T=T+A|0,P=O(P^T,16),_=_+P|0,A=O(A^_,12),T=T+A|0,P=O(P^T,8),_=_+P|0,A=O(A^_,7),d=d+b|0,K=O(K^d,16),v=v+K|0,b=O(b^v,12),d=d+b|0,K=O(K^d,8),v=v+K|0,b=O(b^v,7);let M=0;n[M++]=i+R|0,n[M++]=a+L|0,n[M++]=c+T|0,n[M++]=u+d|0,n[M++]=f+b|0,n[M++]=l+y|0,n[M++]=p+w|0,n[M++]=m+A|0,n[M++]=x+_|0,n[M++]=g+v|0,n[M++]=h+B|0,n[M++]=E+D|0,n[M++]=C+U|0,n[M++]=I+P|0,n[M++]=N+K|0,n[M++]=S+k|0}function ud(e,t,r,n){let o=e[0],s=e[1],i=e[2],a=e[3],c=t[0],u=t[1],f=t[2],l=t[3],p=t[4],m=t[5],x=t[6],g=t[7],h=r[0],E=r[1],C=r[2],I=r[3];for(let S=0;S<20;S+=2)o=o+c|0,h=O(h^o,16),p=p+h|0,c=O(c^p,12),o=o+c|0,h=O(h^o,8),p=p+h|0,c=O(c^p,7),s=s+u|0,E=O(E^s,16),m=m+E|0,u=O(u^m,12),s=s+u|0,E=O(E^s,8),m=m+E|0,u=O(u^m,7),i=i+f|0,C=O(C^i,16),x=x+C|0,f=O(f^x,12),i=i+f|0,C=O(C^i,8),x=x+C|0,f=O(f^x,7),a=a+l|0,I=O(I^a,16),g=g+I|0,l=O(l^g,12),a=a+l|0,I=O(I^a,8),g=g+I|0,l=O(l^g,7),o=o+u|0,I=O(I^o,16),x=x+I|0,u=O(u^x,12),o=o+u|0,I=O(I^o,8),x=x+I|0,u=O(u^x,7),s=s+f|0,h=O(h^s,16),g=g+h|0,f=O(f^g,12),s=s+f|0,h=O(h^s,8),g=g+h|0,f=O(f^g,7),i=i+l|0,E=O(E^i,16),p=p+E|0,l=O(l^p,12),i=i+l|0,E=O(E^i,8),p=p+E|0,l=O(l^p,7),a=a+c|0,C=O(C^a,16),m=m+C|0,c=O(c^m,12),a=a+c|0,C=O(C^a,8),m=m+C|0,c=O(c^m,7);let N=0;n[N++]=o,n[N++]=s,n[N++]=i,n[N++]=a,n[N++]=h,n[N++]=E,n[N++]=C,n[N++]=I}var ld=ii(uf,{counterRight:!1,counterLength:4,allowShortKeys:!1}),hd=ii(uf,{counterRight:!1,counterLength:8,extendNonceFn:ud,allowShortKeys:!1});var dd=new Uint8Array(16),cf=(e,t)=>{e.update(t);let r=t.length%16;r&&e.update(dd.subarray(r))},pd=new Uint8Array(32);function ff(e,t,r,n,o){let s=e(t,r,pd),i=af.create(s);o&&cf(i,o),cf(i,n);let a=rf(n.length,o?o.length:0,!0);i.update(a);let c=i.digest();return ne(s,a),c}var lf=e=>(t,r,n)=>({encrypt(s,i){let a=s.length;i=oi(a+16,i,!1),i.set(s);let c=i.subarray(0,-16);e(t,r,c,c,1);let u=ff(e,t,r,c,n);return i.set(u,a),ne(u),i},decrypt(s,i){i=oi(s.length-16,i,!1);let a=s.subarray(0,-16),c=s.subarray(-16),u=ff(e,t,r,a,n);if(!ef(c,u))throw new Error("invalid tag");return i.set(s.subarray(0,-16)),e(t,r,i,i,1),ne(u),i}}),ci=ni({blockSize:64,nonceLength:12,tagLength:16},lf(ld)),Fb=ni({blockSize:64,nonceLength:24,tagLength:16},lf(hd));function df(e,t,r){return _r(e),r===void 0&&(r=new Uint8Array(e.outputLen)),sr(e,ue(r),ue(t))}var fi=Uint8Array.from([0]),hf=Uint8Array.of();function pf(e,t,r,n=32){_r(e),Ee(n);let o=e.outputLen;if(n>255*o)throw new Error("Length should be <= 255*HashLen");let s=Math.ceil(n/o);r===void 0&&(r=hf);let i=new Uint8Array(s*o),a=sr.create(e,t),c=a._cloneInto(),u=new Uint8Array(a.outputLen);for(let f=0;f<s;f++)fi[0]=f+1,c.update(f===0?hf:u).update(r).update(fi).digestInto(u),i.set(u,o*f),a._cloneInto(c);return a.destroy(),c.destroy(),Ot(u,fi),i.slice(0,n)}var ui={hashSHA256(e){return ye(e.subarray())},getHKDF(e,t){let r=df(ye,t,e),o=pf(ye,r,void 0,96),s=o.subarray(0,32),i=o.subarray(32,64),a=o.subarray(64,96);return[s,i,a]},generateX25519KeyPair(){let e=Rr.utils.randomPrivateKey();return{publicKey:Rr.getPublicKey(e),privateKey:e}},generateX25519KeyPairFromSeed(e){return{publicKey:Rr.getPublicKey(e),privateKey:e}},generateX25519SharedKey(e,t){return Rr.getSharedSecret(e.subarray(),t.subarray())},chaCha20Poly1305Encrypt(e,t,r,n){return ci(n,t,r).encrypt(e.subarray())},chaCha20Poly1305Decrypt(e,t,r,n,o){return ci(n,t,r).decrypt(e.subarray(),o)}};var mf=ui;function yf(e){return{generateKeypair:e.generateX25519KeyPair,dh:(t,r)=>e.generateX25519SharedKey(t.privateKey,r).subarray(0,32),encrypt:e.chaCha20Poly1305Encrypt,decrypt:e.chaCha20Poly1305Decrypt,hash:e.hashSHA256,hkdf:e.getHKDF}}var ur=e=>{let t=ft(2);return t[0]=e>>8,t[1]=e,t};ur.bytes=2;var Yr=e=>{if(e.length<2)throw RangeError("Could not decode int16BE");if(e instanceof Uint8Array){let t=0;return t+=e[0]<<8,t+=e[1],t}return e.getUint16(0)};Yr.bytes=2;function gf(e){return{xxHandshakeSuccesses:e.registerCounter("libp2p_noise_xxhandshake_successes_total",{help:"Total count of noise xxHandshakes successes_"}),xxHandshakeErrors:e.registerCounter("libp2p_noise_xxhandshake_error_total",{help:"Total count of noise xxHandshakes errors"}),encryptedPackets:e.registerCounter("libp2p_noise_encrypted_packets_total",{help:"Total count of noise encrypted packets successfully"}),decryptedPackets:e.registerCounter("libp2p_noise_decrypted_packets_total",{help:"Total count of noise decrypted packets"}),decryptErrors:e.registerCounter("libp2p_noise_decrypt_errors_total",{help:"Total count of noise decrypt errors"})}}function li(e,t){!t.enabled||!fr||(e?(t(`LOCAL_STATIC_PUBLIC_KEY ${H(e.publicKey,"hex")}`),t(`LOCAL_STATIC_PRIVATE_KEY ${H(e.privateKey,"hex")}`)):t("Missing local static keys."))}function hi(e,t){!t.enabled||!fr||(e?(t(`LOCAL_PUBLIC_EPHEMERAL_KEY ${H(e.publicKey,"hex")}`),t(`LOCAL_PRIVATE_EPHEMERAL_KEY ${H(e.privateKey,"hex")}`)):t("Missing local ephemeral keys."))}function xf(e,t){!t.enabled||!fr||t(e?`REMOTE_STATIC_PUBLIC_KEY ${H(e.subarray(),"hex")}`:"Missing remote static public key.")}function di(e,t){!t.enabled||!fr||t(e?`REMOTE_EPHEMERAL_PUBLIC_KEY ${H(e.subarray(),"hex")}`:"Missing remote ephemeral keys.")}function pi(e,t,r){!r.enabled||!fr||(r(`CIPHER_STATE_1 ${e.n.getUint64()} ${e.k&&H(e.k,"hex")}`),r(`CIPHER_STATE_2 ${t.n.getUint64()} ${t.k&&H(t.k,"hex")}`))}var lr=class e extends Error{code;constructor(t="Invalid crypto exchange"){super(t),this.code=e.code}static code="ERR_INVALID_CRYPTO_EXCHANGE"};var md=0,yd=4294967295,gd="Cipherstate has reached maximum n, a new handshake must be performed",oo=class{n;bytes;view;constructor(t=md){this.n=t,this.bytes=ct(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>yd)throw new Error(gd)}};var Ne=ct(0),hr=class{k;n;crypto;constructor(t,r=void 0,n=0){this.crypto=t,this.k=r,this.n=new oo(n)}hasKey(){return!!this.k}encryptWithAd(t,r){if(!this.hasKey())return r;this.n.assertValue();let n=this.crypto.encrypt(r,this.n.getBytes(),t,this.k);return this.n.increment(),n}decryptWithAd(t,r,n){if(!this.hasKey())return r;this.n.assertValue();let o=this.crypto.decrypt(r,this.n.getBytes(),t,this.k,n);return this.n.increment(),o}},mi=class{cs;ck;h;crypto;constructor(t,r){this.crypto=t;let n=G(r,"utf-8");this.h=xd(t,n),this.ck=this.h,this.cs=new hr(t)}mixKey(t){let[r,n]=this.crypto.hkdf(this.ck,t);this.ck=r,this.cs=new hr(this.crypto,n)}mixHash(t){this.h=this.crypto.hash(new F(this.h,t))}encryptAndHash(t){let r=this.cs.encryptWithAd(this.h,t);return this.mixHash(r),r}decryptAndHash(t){let r=this.cs.decryptWithAd(this.h,t);return this.mixHash(t),r}split(){let[t,r]=this.crypto.hkdf(this.ck,Ne);return[new hr(this.crypto,t),new hr(this.crypto,r)]}},yi=class{ss;s;e;rs;re;initiator;crypto;constructor(t){let{crypto:r,protocolName:n,prologue:o,initiator:s,s:i,e:a,rs:c,re:u}=t;this.crypto=r,this.ss=new mi(r,n),this.ss.mixHash(o),this.initiator=s,this.s=i,this.e=a,this.rs=c,this.re=u}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,r=0){if(this.re)throw new Error("remote ephemeral public key is already set");if(t.byteLength<r+32)throw new Error("message is not long enough");this.re=t.sublist(r,r+32),this.ss.mixHash(this.re)}readS(t,r=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<r+n)throw new Error("message is not long enough");let o=t.sublist(r,r+n);return this.rs=this.ss.decryptAndHash(o),n}readEE(){this.writeEE()}readES(){this.writeES()}readSE(){this.writeSE()}},Xr=class extends yi{writeMessageA(t){return new F(this.writeE(),this.ss.encryptAndHash(t))}writeMessageB(t){let r=this.writeE();this.writeEE();let n=this.writeS();return this.writeES(),new F(r,n,this.ss.encryptAndHash(t))}writeMessageC(t){let r=this.writeS();return this.writeSE(),new F(r,this.ss.encryptAndHash(t))}readMessageA(t){try{return this.readE(t),this.ss.decryptAndHash(t.sublist(32))}catch(r){throw new lr(`handshake stage 0 validation fail: ${r.message}`)}}readMessageB(t){try{this.readE(t),this.readEE();let r=this.readS(t,32);return this.readES(),this.ss.decryptAndHash(t.sublist(32+r))}catch(r){throw new lr(`handshake stage 1 validation fail: ${r.message}`)}}readMessageC(t){try{let r=this.readS(t);return this.readSE(),this.ss.decryptAndHash(t.sublist(r))}catch(r){throw new lr(`handshake stage 2 validation fail: ${r.message}`)}}};function xd(e,t){if(t.length<=32){let r=ct(32);return r.set(t),r}else return e.hash(t)}var so;(function(e){let t;e.codec=()=>(t==null&&(t=Re((r,n,o={})=>{if(o.lengthDelimited!==!1&&n.fork(),r.webtransportCerthashes!=null)for(let s of r.webtransportCerthashes)n.uint32(10),n.bytes(s);if(r.streamMuxers!=null)for(let s of r.streamMuxers)n.uint32(18),n.string(s);o.lengthDelimited!==!1&&n.ldelim()},(r,n,o={})=>{let s={webtransportCerthashes:[],streamMuxers:[]},i=n==null?r.len:r.pos+n;for(;r.pos<i;){let a=r.uint32();switch(a>>>3){case 1:{if(o.limits?.webtransportCerthashes!=null&&s.webtransportCerthashes.length===o.limits.webtransportCerthashes)throw new Or('Decode error - map field "webtransportCerthashes" had too many elements');s.webtransportCerthashes.push(r.bytes());break}case 2:{if(o.limits?.streamMuxers!=null&&s.streamMuxers.length===o.limits.streamMuxers)throw new Or('Decode error - map field "streamMuxers" had too many elements');s.streamMuxers.push(r.string());break}default:{r.skipType(a&7);break}}}return s})),t),e.encode=r=>Pe(r,e.codec()),e.decode=(r,n)=>Le(r,e.codec(),n)})(so||(so={}));var Jr;(function(e){let t;e.codec=()=>(t==null&&(t=Re((r,n,o={})=>{o.lengthDelimited!==!1&&n.fork(),r.identityKey!=null&&r.identityKey.byteLength>0&&(n.uint32(10),n.bytes(r.identityKey)),r.identitySig!=null&&r.identitySig.byteLength>0&&(n.uint32(18),n.bytes(r.identitySig)),r.extensions!=null&&(n.uint32(34),so.codec().encode(r.extensions,n)),o.lengthDelimited!==!1&&n.ldelim()},(r,n,o={})=>{let s={identityKey:ct(0),identitySig:ct(0)},i=n==null?r.len:r.pos+n;for(;r.pos<i;){let a=r.uint32();switch(a>>>3){case 1:{s.identityKey=r.bytes();break}case 2:{s.identitySig=r.bytes();break}case 4:{s.extensions=so.codec().decode(r,r.uint32(),{limits:o.limits?.extensions});break}default:{r.skipType(a&7);break}}}return s})),t),e.encode=r=>Pe(r,e.codec()),e.decode=(r,n)=>Le(r,e.codec(),n)})(Jr||(Jr={}));async function gi(e,t,r){let n=await e.sign(bf(t));return Jr.encode({identityKey:fe(e.publicKey),identitySig:n,extensions:r})}async function xi(e,t,r){try{let n=Jr.decode(e),o=qr(n.identityKey);if(r?.equals(o)===!1)throw new Error(`Payload identity key ${o} does not match expected remote identity key ${r}`);if(!t)throw new Error("Remote static does not exist");let s=bf(t);if(!await o.verify(s,n.identitySig))throw new Error("Invalid payload signature");return n}catch(n){throw new sn(n.message)}}function bf(e){let t=G("noise-libp2p-static-key:");return e instanceof Uint8Array?Ut([t,e],t.length+e.length):(e.prepend(t),e)}async function wf(e,t){let{log:r,connection:n,crypto:o,privateKey:s,prologue:i,s:a,remoteIdentityKey:c,extensions:u}=e,f=await gi(s,a.publicKey,u),l=new Xr({crypto:o,protocolName:"Noise_XX_25519_ChaChaPoly_SHA256",initiator:!0,prologue:i,s:a});li(l.s,r),r.trace("Stage 0 - Initiator starting to send first message."),await n.write(l.writeMessageA(Ne),t),r.trace("Stage 0 - Initiator finished sending first message."),hi(l.e,r),r.trace("Stage 1 - Initiator waiting to receive first message from responder...");let p=l.readMessageB(await n.read(t));r.trace("Stage 1 - Initiator received the message."),di(l.re,r),xf(l.rs,r),r.trace("Initiator going to check remote's signature...");let m=await xi(p,l.rs,c);r.trace("All good with the signature!"),r.trace("Stage 2 - Initiator sending third handshake message."),await n.write(l.writeMessageC(f),t),r.trace("Stage 2 - Initiator sent message with signed payload.");let[x,g]=l.ss.split();return pi(x,g,r),{payload:m,encrypt:h=>x.encryptWithAd(Ne,h),decrypt:(h,E)=>g.decryptWithAd(Ne,h,E)}}async function Ef(e,t){let{log:r,connection:n,crypto:o,privateKey:s,prologue:i,s:a,remoteIdentityKey:c,extensions:u}=e,f=await gi(s,a.publicKey,u),l=new Xr({crypto:o,protocolName:"Noise_XX_25519_ChaChaPoly_SHA256",initiator:!1,prologue:i,s:a});li(l.s,r),r.trace("Stage 0 - Responder waiting to receive first message."),l.readMessageA(await n.read(t)),r.trace("Stage 0 - Responder received first message."),di(l.re,r),r.trace("Stage 1 - Responder sending out first message with signed payload and static key."),await n.write(l.writeMessageB(f),t),r.trace("Stage 1 - Responder sent the second handshake message with signed payload."),hi(l.e,r),r.trace("Stage 2 - Responder waiting for third handshake message...");let p=l.readMessageC(await n.read(t));r.trace("Stage 2 - Responder received the message, finished handshake.");let m=await xi(p,l.rs,c),[x,g]=l.ss.split();return pi(x,g,r),{payload:m,encrypt:h=>g.encryptWithAd(Ne,h),decrypt:(h,E)=>x.decryptWithAd(Ne,h,E)}}var Af=16;function vf(e,t){return async function*(r){for await(let n of r)for(let o=0;o<n.length;o+=65519){let s=o+65519;s>n.length&&(s=n.length);let i;n instanceof Uint8Array?i=e.encrypt(n.subarray(o,s)):i=e.encrypt(n.sublist(o,s)),t?.encryptedPackets.increment(),yield new F(ur(i.byteLength),i)}}}function _f(e,t){return async function*(r){for await(let n of r)for(let o=0;o<n.length;o+=65535){let s=o+65535;if(s>n.length&&(s=n.length),s-Af<o)throw new Error("Invalid chunk");let i=n.sublist(o,s),a=n.subarray(o,s-Af);try{let c=e.decrypt(i,a);t?.decryptedPackets.increment(),yield c}catch(c){throw t?.decryptErrors.increment(),c}}}}var io=class{protocol="/noise";crypto;prologue;staticKey;extensions;metrics;components;constructor(t,r={}){let{staticNoiseKey:n,extensions:o,crypto:s,prologueBytes:i}=r,{metrics:a}=t;this.components=t;let c=s??mf;this.crypto=yf(c),this.extensions={webtransportCerthashes:[],...o},this.metrics=a?gf(a):void 0,n?this.staticKey=c.generateX25519KeyPairFromSeed(n):this.staticKey=c.generateX25519KeyPair(),this.prologue=i??ct(0)}[Symbol.toStringTag]="@chainsafe/libp2p-noise";[hn]=["@libp2p/connection-encryption","@chainsafe/libp2p-noise"];async secureOutbound(t,r){let n=Js(t,{lengthEncoder:ur,lengthDecoder:Yr,maxDataLength:65535}),o=await this.performHandshakeInitiator(n,this.components.privateKey,r?.remotePeer?.publicKey,r),s=await this.createSecureConnection(n,o);t.source=s.source,t.sink=s.sink;let i=qr(o.payload.identityKey);return{conn:t,remoteExtensions:o.payload.extensions,remotePeer:Zs(i),streamMuxer:r?.skipStreamMuxerNegotiation===!0?void 0:this.getStreamMuxer(o.payload.extensions?.streamMuxers)}}getStreamMuxer(t){if(t==null||t.length===0)return;let r=this.components.upgrader.getStreamMuxers();if(r!=null)for(let n of t){let o=r.get(n);if(o!=null)return o}if(t.length)throw new He("Early muxer negotiation was requested but the initiator and responder had no common muxers")}async secureInbound(t,r){let n=Js(t,{lengthEncoder:ur,lengthDecoder:Yr,maxDataLength:65535}),o=await this.performHandshakeResponder(n,this.components.privateKey,r?.remotePeer?.publicKey,r),s=await this.createSecureConnection(n,o);t.source=s.source,t.sink=s.sink;let i=qr(o.payload.identityKey);return{conn:t,remoteExtensions:o.payload.extensions,remotePeer:Zs(i),streamMuxer:r?.skipStreamMuxerNegotiation===!0?void 0:this.getStreamMuxer(o.payload.extensions?.streamMuxers)}}async performHandshakeInitiator(t,r,n,o){let s,i=o?.skipStreamMuxerNegotiation===!0?[]:[...this.components.upgrader.getStreamMuxers().keys()];try{s=await wf({connection:t,privateKey:r,remoteIdentityKey:n,log:this.components.logger.forComponent("libp2p:noise:xxhandshake"),crypto:this.crypto,prologue:this.prologue,s:this.staticKey,extensions:{streamMuxers:i,webtransportCerthashes:[],...this.extensions}},o),this.metrics?.xxHandshakeSuccesses.increment()}catch(a){throw this.metrics?.xxHandshakeErrors.increment(),a}return s}async performHandshakeResponder(t,r,n,o){let s,i=o?.skipStreamMuxerNegotiation===!0?[]:[...this.components.upgrader.getStreamMuxers().keys()];try{s=await Ef({connection:t,privateKey:r,remoteIdentityKey:n,log:this.components.logger.forComponent("libp2p:noise:xxhandshake"),crypto:this.crypto,prologue:this.prologue,s:this.staticKey,extensions:{streamMuxers:i,webtransportCerthashes:[],...this.extensions}},o),this.metrics?.xxHandshakeSuccesses.increment()}catch(a){throw this.metrics?.xxHandshakeErrors.increment(),a}return s}async createSecureConnection(t,r){let[n,o]=Wc(),s=t.unwrap();return await jc(n,vf(r,this.metrics),s,i=>Zr(i,{lengthDecoder:Yr}),_f(r,this.metrics),n),o}};function If(e={}){return t=>new io(t,e)}var ao=class{index=0;input="";new(t){return this.index=0,this.input=t,this}readAtomically(t){let r=this.index,n=t();return n===void 0&&(this.index=r),n}parseWith(t){let r=t();if(this.index===this.input.length)return r}peekChar(){if(!(this.index>=this.input.length))return this.input[this.index]}readChar(){if(!(this.index>=this.input.length))return this.input[this.index++]}readGivenChar(t){return this.readAtomically(()=>{let r=this.readChar();if(r===t)return r})}readSeparator(t,r,n){return this.readAtomically(()=>{if(!(r>0&&this.readGivenChar(t)===void 0))return n()})}readNumber(t,r,n,o){return this.readAtomically(()=>{let s=0,i=0,a=this.peekChar();if(a===void 0)return;let c=a==="0",u=2**(8*o)-1;for(;;){let f=this.readAtomically(()=>{let l=this.readChar();if(l===void 0)return;let p=Number.parseInt(l,t);if(!Number.isNaN(p))return p});if(f===void 0)break;if(s*=t,s+=f,s>u||(i+=1,r!==void 0&&i>r))return}if(i!==0)return!n&&c&&i>1?void 0:s})}readIPv4Addr(){return this.readAtomically(()=>{let t=new Uint8Array(4);for(let r=0;r<t.length;r++){let n=this.readSeparator(".",r,()=>this.readNumber(10,3,!1,1));if(n===void 0)return;t[r]=n}return t})}readIPv6Addr(){let t=r=>{for(let n=0;n<r.length/2;n++){let o=n*2;if(n<r.length-3){let i=this.readSeparator(":",n,()=>this.readIPv4Addr());if(i!==void 0)return r[o]=i[0],r[o+1]=i[1],r[o+2]=i[2],r[o+3]=i[3],[o+4,!0]}let s=this.readSeparator(":",n,()=>this.readNumber(16,4,!0,2));if(s===void 0)return[o,!1];r[o]=s>>8,r[o+1]=s&255}return[r.length,!1]};return this.readAtomically(()=>{let r=new Uint8Array(16),[n,o]=t(r);if(n===16)return r;if(o||this.readGivenChar(":")===void 0||this.readGivenChar(":")===void 0)return;let s=new Uint8Array(14),i=16-(n+2),[a]=t(s.subarray(0,i));return r.set(s.subarray(0,a),16-a),r})}readIPAddr(){return this.readIPv4Addr()??this.readIPv6Addr()}};var bd=45,wd=15,co=new ao;function bi(e){if(!(e.length>wd))return co.new(e).parseWith(()=>co.readIPv4Addr())}function wi(e){if(e.includes("%")&&(e=e.split("%")[0]),!(e.length>bd))return co.new(e).parseWith(()=>co.readIPv6Addr())}function dr(e){return!!bi(e)}function fo(e){return!!wi(e)}var Ed=e=>e.toString().split("/").slice(1),pr=e=>({match:t=>t.length<1?!1:e(t[0])?t.slice(1):!1,pattern:"fn"}),V=e=>({match:t=>pr(r=>r===e).match(t),pattern:e}),ke=()=>({match:e=>pr(t=>typeof t=="string").match(e),pattern:"{string}"}),mr=()=>({match:e=>pr(t=>!isNaN(parseInt(t))).match(e),pattern:"{number}"}),Z=()=>({match:e=>{if(e.length<2||e[0]!=="p2p"&&e[0]!=="ipfs")return!1;if(e[1].startsWith("Q")||e[1].startsWith("1"))try{J.decode(`z${e[1]}`)}catch{return!1}else return!1;return e.slice(2)},pattern:"/p2p/{peerid}"}),tn=()=>({match:e=>{if(e.length<2||e[0]!=="certhash")return!1;try{Er.decode(e[1])}catch{return!1}return e.slice(2)},pattern:"/certhash/{certhash}"}),$=e=>({match:t=>{let r=e.match(t);return r===!1?t:r},pattern:`optional(${e.pattern})`}),At=(...e)=>({match:t=>{let r;for(let n of e){let o=n.match(t);o!==!1&&(r==null||o.length<r.length)&&(r=o)}return r??!1},pattern:`or(${e.map(t=>t.pattern).join(", ")})`}),z=(...e)=>({match:t=>{for(let r of e){let n=r.match(t);if(n===!1)return!1;t=n}return t},pattern:`and(${e.map(t=>t.pattern).join(", ")})`});function rt(...e){function t(o){let s=Ed(o);for(let i of e){let a=i.match(s);if(a===!1)return!1;s=a}return s}function r(o){return t(o)!==!1}function n(o){let s=t(o);return s===!1?!1:s.length===0}return{matchers:e,matches:r,exactMatch:n}}var Sd=Z(),_1=rt(Sd),lo=z(V("dns4"),ke()),ho=z(V("dns6"),ke()),po=z(V("dnsaddr"),ke()),Si=z(V("dns"),ke()),I1=rt(lo,$(Z())),C1=rt(ho,$(Z())),B1=rt(po,$(Z())),T1=rt(At(Si,po,lo,ho),$(Z())),Bf=z(V("ip4"),pr(dr)),Tf=z(V("ip6"),pr(fo)),Ai=At(Bf,Tf),oe=At(Ai,Si,lo,ho,po),L1=rt(At(Ai,z(At(Si,po,lo,ho),$(Z())))),D1=rt(Bf),P1=rt(Tf),R1=rt(Ai),vi=z(oe,V("tcp"),mr()),en=z(oe,V("udp"),mr()),U1=rt(z(vi,$(Z()))),N1=rt(en),_i=z(en,V("quic"),$(Z())),mo=z(en,V("quic-v1"),$(Z())),Ad=At(_i,mo),k1=rt(_i),O1=rt(mo),Ei=At(oe,vi,en,_i,mo),Lf=At(z(Ei,V("ws"),$(Z()))),K1=rt(Lf),Df=At(z(Ei,V("wss"),$(Z())),z(Ei,V("tls"),$(z(V("sni"),ke())),V("ws"),$(Z()))),M1=rt(Df),Pf=z(en,V("webrtc-direct"),$(tn()),$(tn()),$(Z())),H1=rt(Pf),Rf=z(mo,V("webtransport"),$(tn()),$(tn()),$(Z())),yo=rt(Rf),uo=At(Lf,Df,z(vi,$(Z())),z(Ad,$(Z())),z(oe,$(Z())),Pf,Rf,Z()),V1=rt(uo),vd=z(uo,V("p2p-circuit"),Z()),q1=rt(vd),_d=At(z(uo,V("p2p-circuit"),V("webrtc"),$(Z())),z(uo,V("webrtc"),$(Z())),z(V("webrtc"),$(Z()))),z1=rt(_d),Id=At(z(oe,V("tcp"),mr(),V("http"),$(Z())),z(oe,V("http"),$(Z()))),F1=rt(Id),Cd=At(z(oe,V("tcp"),At(z(V("443"),V("http")),z(mr(),V("https")),z(mr(),V("tls"),V("http"))),$(Z())),z(oe,V("tls"),V("http"),$(Z())),z(oe,V("https"),$(Z()))),G1=rt(Cd),Bd=At(z(V("memory"),ke(),$(Z()))),W1=rt(Bd);var Oe=class extends Event{type;detail;constructor(t,r){super(t),this.type=t,this.detail=r}};function Ii(e){throw new Error("Not implemented")}function Uf(e){if(e!=null){if(typeof e[Symbol.iterator]=="function")return e[Symbol.iterator]();if(typeof e[Symbol.asyncIterator]=="function")return e[Symbol.asyncIterator]();if(typeof e.next=="function")return e}throw new Error("argument is not an iterator or iterable")}function Nf(e){return e==null?!1:typeof e.then=="function"&&typeof e.catch=="function"&&typeof e.finally=="function"}function kf(e,t){let r=Uf(e).return?.();Nf(r)&&r.catch(n=>{t.error("could not cause iterator to return",n)})}var Td=5e3;function Ci(e){return e==null?!1:typeof e.then=="function"&&typeof e.catch=="function"&&typeof e.finally=="function"}var go=class{id;direction;timeline;protocol;metadata;source;status;readStatus;writeStatus;log;sinkController;sinkEnd;closed;endErr;streamSource;onEnd;onCloseRead;onCloseWrite;onReset;onAbort;sendCloseWriteTimeout;sendingData;constructor(t){this.sinkController=new AbortController,this.sinkEnd=Ct(),this.closed=Ct(),this.log=t.log,this.status="open",this.readStatus="ready",this.writeStatus="ready",this.id=t.id,this.metadata=t.metadata??{},this.direction=t.direction,this.timeline={open:Date.now()},this.sendCloseWriteTimeout=t.sendCloseWriteTimeout??Td,this.onEnd=t.onEnd,this.onCloseRead=t.onCloseRead,this.onCloseWrite=t.onCloseWrite,this.onReset=t.onReset,this.onAbort=t.onAbort,this.source=this.streamSource=Jn({onEnd:r=>{r!=null?this.log.trace("source ended with error",r):this.log.trace("source ended"),this.onSourceEnd(r)}}),this.sink=this.sink.bind(this)}async sink(t){if(this.writeStatus!=="ready")throw new cn(`writable end state is "${this.writeStatus}" not "ready"`);try{this.writeStatus="writing";let r={signal:this.sinkController.signal};if(this.direction==="outbound"){let o=this.sendNewStream(r);Ci(o)&&await o}let n=()=>{kf(t,this.log)};try{this.sinkController.signal.addEventListener("abort",n),this.log.trace("sink reading from source");for await(let o of t){o=o instanceof Uint8Array?new F(o):o;let s=this.sendData(o,r);Ci(s)&&(this.sendingData=Ct(),await s,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(r){throw this.log.trace("sink ended with error, calling abort with error",r),this.abort(r),r}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.status==="open"&&(this.log.trace("closing gracefully"),this.status="closing",await ht(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 r=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)),r==="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 ht(this.sink([]),t.signal)),this.writeStatus==="writing"&&(this.sendingData!=null&&await ht(this.sendingData.promise,t.signal),this.log.trace("aborting source passed to .sink"),this.sinkController.abort(),await ht(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 r=this.sendReset();Ci(r)&&r.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 an("stream reset");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 Bi=class extends go{writer;reader;constructor(t){super(t),this.writer=t.bidiStream.writable.getWriter(),this.reader=t.bidiStream.readable.getReader(),Promise.resolve().then(async()=>{for(;;){let r=await this.reader.read();if(r.done){t.log("remote closed write");return}r.value!=null&&this.sourcePush(new F(r.value))}}).catch(r=>{t.log.error("error reading from stream",r),this.abort(r)}).finally(()=>{this.remoteCloseWrite()}),this.writer.closed.then(()=>{t.log("writer closed")}).catch(r=>{t.log("writer close promise rejected",r)}).finally(()=>{this.remoteCloseRead()})}sendNewStream(t){}async sendData(t,r){for(let n of t)this.log("sendData waiting for writer to be ready"),await ht(this.writer.ready,r?.signal),this.writer.write(n).catch(o=>{this.log.error("error sending stream data",o)})}async sendReset(t){this.log("sendReset aborting writer"),await ht(this.writer.abort(),t?.signal),this.log("sendReset aborted writer")}async sendCloseWrite(t){this.log("sendCloseWrite closing writer"),await ht(this.writer.close(),t?.signal),this.log("sendCloseWrite closed writer")}async sendCloseRead(t){this.log("sendCloseRead cancelling reader"),await ht(this.reader.cancel(),t?.signal),this.log("sendCloseRead cancelled reader")}};async function Ti(e,t,r,n,o,s){let i=s.forComponent(`libp2p:webtransport:stream:${r}:${t}`),a=new Bi({bidiStream:e,id:t,direction:r,log:i,onEnd:()=>{let c=n.findIndex(u=>u===a);c!==-1&&n.splice(c,1),o?.(a)}});return a}function xo(){return{source:{[Symbol.asyncIterator](){return{async next(){return new Promise(()=>{})}}}},sink:async e=>new Promise(()=>{})}}function Of(e,t,r,n){let o=0,s=r.forComponent("libp2p:webtransport:muxer");return{protocol:"webtransport",createStreamMuxer:i=>{typeof i=="function"&&(i={onIncomingStream:i});let a=[];Promise.resolve().then(async()=>{for(;;){let{done:u,value:f}=await t.read();if(u)break;if(a.length>=n.maxInboundStreams)s(`too many inbound streams open - ${a.length}/${n.maxInboundStreams}, closing new incoming stream`),f.writable.close().catch(l=>{s.error(`failed to close inbound stream that crossed our maxInboundStream limit: ${l.message}`)}),f.readable.cancel().catch(l=>{s.error(`failed to close inbound stream that crossed our maxInboundStream limit: ${l.message}`)});else{let l=await Ti(f,String(o++),"inbound",a,i?.onStreamEnd,r);a.push(l),i?.onIncomingStream?.(l)}}}).catch(u=>{s.error("could not create a new stream",u)});let c={protocol:"webtransport",streams:a,newStream:async u=>{s("new outgoing stream",u);let f=await e.createBidirectionalStream(),l=await Ti(f,String(o++),i?.direction??"outbound",a,i?.onStreamEnd,r);return a.push(l),l},close:async()=>{s("closing webtransport muxer gracefully");try{e.close()}catch(u){c.abort(u)}},abort:u=>{s("closing webtransport muxer with err:",u);try{e.close()}catch(f){s.error("webtransport session threw error during close",f)}},...xo()};return c}}}function Kf(e,t){return t.filter(n=>!!e.find(o=>at(n,o))).length===t.length}var yt=class extends Error{static name="InvalidMultiaddrError";name="InvalidMultiaddrError"},se=class extends Error{static name="ValidationError";name="ValidationError"},rn=class extends Error{static name="InvalidParametersError";name="InvalidParametersError"},bo=class extends Error{static name="InvalidProtocolError";name="InvalidProtocolError"};function Di(e){return t=>H(t,e)}function Pi(e){return t=>G(t,e)}function yr(e){return new DataView(e.buffer).getUint16(e.byteOffset).toString()}function Ke(e){let t=new ArrayBuffer(2);return new DataView(t).setUint16(0,typeof e=="string"?parseInt(e):e),new Uint8Array(t)}function Mf(e){let t=e.split(":");if(t.length!==2)throw new Error(`failed to parse onion addr: ["'${t.join('", "')}'"]' does not contain a port number`);if(t[0].length!==16)throw new Error(`failed to parse onion addr: ${t[0]} not a Tor onion address.`);let r=G(t[0],"base32"),n=parseInt(t[1],10);if(n<1||n>65536)throw new Error("Port number is not in range(1, 65536)");let o=Ke(n);return Ut([r,o],r.length+o.length)}function Hf(e){let t=e.split(":");if(t.length!==2)throw new Error(`failed to parse onion addr: ["'${t.join('", "')}'"]' does not contain a port number`);if(t[0].length!==56)throw new Error(`failed to parse onion addr: ${t[0]} not a Tor onion3 address.`);let r=ae.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 o=Ke(n);return Ut([r,o],r.length+o.length)}function Ri(e){let t=e.subarray(0,e.length-2),r=e.subarray(e.length-2),n=H(t,"base32"),o=yr(r);return`${n}:${o}`}var Ui=function(e){e=e.toString().trim();let t=new Uint8Array(4);return e.split(/\./g).forEach((r,n)=>{let o=parseInt(r,10);if(isNaN(o)||o<0||o>255)throw new yt("Invalid byte value in IP address");t[n]=o}),t},Vf=function(e){let t=0;e=e.toString().trim();let r=e.split(":",8),n;for(n=0;n<r.length;n++){let s=dr(r[n]),i;s&&(i=Ui(r[n]),r[n]=H(i.subarray(0,2),"base16")),i!=null&&++n<8&&r.splice(n,0,H(i.subarray(2,4),"base16"))}if(r[0]==="")for(;r.length<8;)r.unshift("0");else if(r[r.length-1]==="")for(;r.length<8;)r.push("0");else if(r.length<8){for(n=0;n<r.length&&r[n]!=="";n++);let s=[n,1];for(n=9-r.length;n>0;n--)s.push("0");r.splice.apply(r,s)}let o=new Uint8Array(t+16);for(n=0;n<r.length;n++){r[n]===""&&(r[n]="0");let s=parseInt(r[n],16);if(isNaN(s)||s<0||s>65535)throw new yt("Invalid byte value in IP address");o[t++]=s>>8&255,o[t++]=s&255}return o},qf=function(e){if(e.byteLength!==4)throw new yt("IPv4 address was incorrect length");let t=[];for(let r=0;r<e.byteLength;r++)t.push(e[r]);return t.join(".")},zf=function(e){if(e.byteLength!==16)throw new yt("IPv6 address was incorrect length");let t=[];for(let n=0;n<e.byteLength;n+=2){let o=e[n],s=e[n+1],i=`${o.toString(16).padStart(2,"0")}${s.toString(16).padStart(2,"0")}`;t.push(i)}let r=t.join(":");try{let n=new URL(`http://[${r}]`);return n.hostname.substring(1,n.hostname.length-1)}catch{throw new yt(`Invalid IPv6 address "${r}"`)}};function Ff(e){try{let t=new URL(`http://[${e}]`);return t.hostname.substring(1,t.hostname.length-1)}catch{throw new yt(`Invalid IPv6 address "${e}"`)}}var Li=Object.values(be).map(e=>e.decoder),Ld=function(){let e=Li[0].or(Li[1]);return Li.slice(2).forEach(t=>e=e.or(t)),e}();function Gf(e){return Ld.decode(e)}function Wf(e){return t=>e.encoder.encode(t)}function Dd(e){if(parseInt(e).toString()!==e)throw new se("Value must be an integer")}function Pd(e){if(e<0)throw new se("Value must be a positive integer, or zero")}function Rd(e){return t=>{if(t>e)throw new se(`Value must be smaller than or equal to ${e}`)}}function Ud(...e){return t=>{for(let r of e)r(t)}}var nn=Ud(Dd,Pd,Rd(65535));var gt=-1,Ni=class{protocolsByCode=new Map;protocolsByName=new Map;getCodec(t){let r;if(typeof t=="string"?r=this.protocolsByName.get(t):r=this.protocolsByCode.get(t),r==null)throw new bo(`Protocol ${t} was unknown`);return r}addCodec(t,r,n){this.protocolsByCode.set(t,r),this.protocolsByName.set(r.name,r),n?.forEach(o=>{this.protocolsByName.set(o,r)})}deleteCodec(t){let r=this.getCodec(t);r!=null&&(this.protocolsByCode.delete(r.code),this.protocolsByName.delete(r.name),r.aliases?.forEach(n=>{this.protocolsByName.delete(n)}))}},Lt=new Ni,up=[{code:4,name:"ip4",size:32,valueToBytes:Ui,bytesToValue:qf,validate:e=>{if(!dr(e))throw new se(`Invalid IPv4 address "${e}"`)}},{code:6,name:"tcp",size:16,valueToBytes:Ke,bytesToValue:yr,validate:nn},{code:273,name:"udp",size:16,valueToBytes:Ke,bytesToValue:yr,validate:nn},{code:33,name:"dccp",size:16,valueToBytes:Ke,bytesToValue:yr,validate:nn},{code:41,name:"ip6",size:128,valueToBytes:Vf,bytesToValue:zf,stringToValue:Ff,validate:e=>{if(!fo(e))throw new se(`Invalid IPv6 address "${e}"`)}},{code:42,name:"ip6zone",size:gt},{code:43,name:"ipcidr",size:8,bytesToValue:Di("base10"),valueToBytes:Pi("base10")},{code:53,name:"dns",size:gt,resolvable:!0},{code:54,name:"dns4",size:gt,resolvable:!0},{code:55,name:"dns6",size:gt,resolvable:!0},{code:56,name:"dnsaddr",size:gt,resolvable:!0},{code:132,name:"sctp",size:16,valueToBytes:Ke,bytesToValue:yr,validate:nn},{code:301,name:"udt"},{code:302,name:"utp"},{code:400,name:"unix",size:gt,path:!0,stringToValue:e=>decodeURIComponent(e),valueToString:e=>encodeURIComponent(e)},{code:421,name:"p2p",aliases:["ipfs"],size:gt,bytesToValue:Di("base58btc"),valueToBytes:e=>e.startsWith("Q")||e.startsWith("1")?Pi("base58btc")(e):st.parse(e).multihash.bytes},{code:444,name:"onion",size:96,bytesToValue:Ri,valueToBytes:Mf},{code:445,name:"onion3",size:296,bytesToValue:Ri,valueToBytes:Hf},{code:446,name:"garlic64",size:gt},{code:447,name:"garlic32",size:gt},{code:448,name:"tls"},{code:449,name:"sni",size:gt},{code:454,name:"noise"},{code:460,name:"quic"},{code:461,name:"quic-v1"},{code:465,name:"webtransport"},{code:466,name:"certhash",size:gt,bytesToValue:Wf(Er),valueToBytes:Gf},{code:480,name:"http"},{code:481,name:"http-path",size:gt,stringToValue:e=>`/${decodeURIComponent(e)}`,valueToString:e=>encodeURIComponent(e.substring(1))},{code:443,name:"https"},{code:477,name:"ws"},{code:478,name:"wss"},{code:479,name:"p2p-websocket-star"},{code:277,name:"p2p-stardust"},{code:275,name:"p2p-webrtc-star"},{code:276,name:"p2p-webrtc-direct"},{code:280,name:"webrtc-direct"},{code:281,name:"webrtc"},{code:290,name:"p2p-circuit"},{code:777,name:"memory",size:gt}];up.forEach(e=>{Lt.addCodec(e.code,e,e.aliases)});function $f(e){let t=[],r=0;for(;r<e.length;){let n=Be(e,r),o=Lt.getCodec(n),s=lt(n),i=lp(o,e,r+s),a=0;i>0&&o.size===gt&&(a=lt(i));let c=s+a+i,u={code:n,name:o.name,bytes:e.subarray(r,r+c)};if(i>0){let f=r+s+a,l=e.subarray(f,f+i);u.value=o.bytesToValue?.(l)??H(l)}t.push(u),r+=c}return t}function jf(e){let t=0,r=[];for(let n of e){if(n.bytes==null){let o=Lt.getCodec(n.code),s=lt(n.code),i,a=0,c=0;n.value!=null&&(i=o.valueToBytes?.(n.value)??G(n.value),a=i.byteLength,o.size===gt&&(c=lt(a)));let u=new Uint8Array(s+c+a),f=0;rr(n.code,u,f),f+=s,i!=null&&(o.size===gt&&(rr(a,u,f),f+=c),u.set(i,f)),n.bytes=u}r.push(n.bytes),t+=n.bytes.byteLength}return Ut(r,t)}function Zf(e){if(e.charAt(0)!=="/")throw new yt('String multiaddr must start with "/"');let t=[],r="protocol",n="",o="";for(let s=1;s<e.length;s++){let i=e.charAt(s);i!=="/"&&(r==="protocol"?o+=e.charAt(s):n+=e.charAt(s));let a=s===e.length-1;if(i==="/"||a){let c=Lt.getCodec(o);if(r==="protocol"){if(c.size==null||c.size===0){t.push({code:c.code,name:c.name}),n="",o="",r="protocol";continue}else if(a)throw new yt(`Component ${o} was missing value`);r="value"}else if(r==="value"){let u={code:c.code,name:c.name};if(c.size!=null&&c.size!==0){if(n==="")throw new yt(`Component ${o} was missing value`);u.value=c.stringToValue?.(n)??n}t.push(u),n="",o="",r="protocol"}}}if(o!==""&&n!=="")throw new yt("Incomplete multiaddr");return t}function Yf(e){return`/${e.flatMap(t=>{if(t.value==null)return t.name;let r=Lt.getCodec(t.code);if(r==null)throw new yt(`Unknown protocol code ${t.code}`);return[t.name,r.valueToString?.(t.value)??t.value]}).join("/")}`}function lp(e,t,r){return e.size==null||e.size===0?0:e.size>0?e.size/8:Be(t,r)}var hp=Symbol.for("nodejs.util.inspect.custom"),zi=Symbol.for("@multiformats/multiaddr"),dp=[53,54,55,56],qi=class extends Error{constructor(t="No available resolver"){super(t),this.name="NoAvailableResolverError"}};function pp(e){if(e==null&&(e="/"),Jf(e))return e.getComponents();if(e instanceof Uint8Array)return $f(e);if(typeof e=="string")return e=e.replace(/\/(\/)+/,"/").replace(/(\/)+$/,""),e===""&&(e="/"),Zf(e);if(Array.isArray(e))return e;throw new yt("Must be a string, Uint8Array, Component[], or another Multiaddr")}var vo=class e{[zi]=!0;#t;#e;#r;constructor(t="/",r={}){this.#t=pp(t),r.validate!==!1&&mp(this)}get bytes(){return this.#r==null&&(this.#r=jf(this.#t)),this.#r}toString(){return this.#e==null&&(this.#e=Yf(this.#t)),this.#e}toJSON(){return this.toString()}toOptions(){let t,r,n,o,s="";for(let{code:a,name:c,value:u}of this.#t)a===42&&(s=`%${u??""}`),dp.includes(a)&&(r="tcp",o=443,n=`${u??""}${s}`,t=a===55?6:4),(a===6||a===273)&&(r=c==="tcp"?"tcp":"udp",o=parseInt(u??"")),(a===4||a===41)&&(r="tcp",n=`${u??""}${s}`,t=a===41?6:4);if(t==null||r==null||n==null||o==null)throw new Error('multiaddr must have a valid format: "/{ip4, ip6, dns4, dns6, dnsaddr}/{address}/{tcp, udp}/{port}".');return{family:t,host:n,transport:r,port:o}}getComponents(){return[...this.#t]}protos(){return this.#t.map(({code:t,value:r})=>{let n=Lt.getCodec(t);return{code:t,size:n.size??0,name:n.name,resolvable:!!n.resolvable,path:!!n.path}})}protoCodes(){return this.#t.map(({code:t})=>t)}protoNames(){return this.#t.map(({name:t})=>t)}tuples(){return this.#t.map(({code:t,value:r})=>{if(r==null)return[t];let n=Lt.getCodec(t),o=[t];return r!=null&&o.push(n.valueToBytes?.(r)??G(r)),o})}stringTuples(){return this.#t.map(({code:t,value:r})=>r==null?[t]:[t,r])}encapsulate(t){let r=new e(t);return new e([...this.#t,...r.getComponents()],{validate:!1})}decapsulate(t){let r=t.toString(),n=this.toString(),o=n.lastIndexOf(r);if(o<0)throw new rn(`Address ${this.toString()} does not contain subaddress: ${t.toString()}`);return new e(n.slice(0,o),{validate:!1})}decapsulateCode(t){let r;for(let n=this.#t.length-1;n>-1;n--)if(this.#t[n].code===t){r=n;break}return new e(this.#t.slice(0,r),{validate:!1})}getPeerId(){try{let t=[];this.#t.forEach(({code:n,value:o})=>{n===421&&t.push([n,o]),n===290&&(t=[])});let r=t.pop();if(r?.[1]!=null){let n=r[1];return n[0]==="Q"||n[0]==="1"?H(J.decode(`z${n}`),"base58btc"):H(st.parse(n).multihash.bytes,"base58btc")}return null}catch{return null}}getPath(){for(let t of this.#t)if(Lt.getCodec(t.code).path)return t.value??null;return null}equals(t){return at(this.bytes,t.bytes)}async resolve(t){let r=this.protos().find(s=>s.resolvable);if(r==null)return[this];let n=Xf.get(r.name);if(n==null)throw new qi(`no available resolver for ${r.name}`);return(await n(this,t)).map(s=>Fi(s))}nodeAddress(){let t=this.toOptions();if(t.transport!=="tcp"&&t.transport!=="udp")throw new Error(`multiaddr must have a valid format - no protocol with name: "${t.transport}". Must have a valid transport protocol: "{tcp, udp}"`);return{family:t.family,address:t.host,port:t.port}}isThinWaistAddress(){return!(this.#t.length!==2||this.#t[0].code!==4&&this.#t[0].code!==41||this.#t[1].code!==6&&this.#t[1].code!==273)}[hp](){return`Multiaddr(${this.toString()})`}};function mp(e){e.getComponents().forEach(t=>{let r=Lt.getCodec(t.code);t.value!=null&&r.validate?.(t.value)})}var aE=parseInt("0xFFFF",16),cE=new Uint8Array([0,0,0,0,0,0,0,0,0,0,255,255]);var Xf=new Map;function Jf(e){return!!e?.[zi]}function Fi(e){return new vo(e)}function Gi(e){let t=Lt.getCodec(e);return{code:t.code,size:t.size??0,name:t.name,resolvable:!!t.resolvable,path:!!t.path}}var wp=Object.values(be).map(e=>e.decoder).reduce((e,t)=>e.or(t));function Ep(e){return Yt.decode(wp.decode(e))}function Wi(e){if(!yo.matches(e))throw new fn("Invalid multiaddr, was not a WebTransport address");let t=e.stringTuples(),r=t.filter(([i,a])=>i===Gi("certhash").code).map(([i,a])=>Ep(a??"")),n=t.filter(([i,a])=>i===Gi("p2p").code).map(([i,a])=>Vc(a??""))[0],o=e.toOptions(),s=o.host;return o.family===6&&s?.includes(":")&&(s=`[${s}]`),{url:`https://${s}:${o.port}`,certhashes:r,remotePeer:n}}var eu=globalThis.WebTransport;var $i=class{log;components;config;metrics;constructor(t,r={}){this.log=t.logger.forComponent("libp2p:webtransport"),this.components=t,this.config={...r,maxInboundStreams:r.maxInboundStreams??1e3,certificates:r.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";[Zi]=!0;[hn]=["@libp2p/transport"];async dial(t,r){r.signal.throwIfAborted(),this.log("dialing %s",t),r=r??{};let{url:n,certhashes:o,remotePeer:s}=Wi(t),i,a,c=()=>{},u=!1,f=!1,l=!1;try{this.metrics?.dialerEvents.increment({pending:!0});let p=new eu(`${n}/.well-known/libp2p-webtransport?type=noise`,{serverCertificateHashes:o.map(m=>({algorithm:"sha-256",value:m.digest}))});if(c=m=>{if(!u)try{this.metrics?.dialerEvents.increment({[m]:!0}),p.close()}catch(x){this.log.error("error closing wt session",x)}finally{a!=null&&(a.timeline.close=Date.now()),u=!0}},i=()=>{c(f?"noise_timeout":"ready_timeout")},r.signal.addEventListener("abort",i,{once:!0}),this.log("wait for session to be ready"),r.onProgress?.(new Oe("webtransport:wait-for-session")),await Promise.race([p.closed,p.ready]),this.log("session became ready"),f=!0,this.metrics?.dialerEvents.increment({ready:!0}),p.closed.catch(m=>{this.log.error("error on remote wt session close",m)}).finally(()=>{c("remote_close")}),l=await ht(this.authenticateWebTransport({wt:p,remotePeer:s,certhashes:o,...r}),r.signal),!l)throw new He("Failed to authenticate webtransport");return this.metrics?.dialerEvents.increment({open:!0}),a={close:async()=>{this.log("closing webtransport"),c("close")},abort:m=>{this.log("aborting webtransport due to passed err",m),c("abort")},remoteAddr:t,timeline:{open:Date.now()},log:this.components.logger.forComponent("libp2p:webtransport:maconn"),...xo()},await r.upgrader.upgradeOutbound(a,{...r,skipEncryption:!0,muxerFactory:Of(p,p.incomingBidirectionalStreams.getReader(),this.components.logger,this.config),skipProtection:!0})}catch(p){throw this.log.error("caught wt session err",p),c(l?"upgrade_error":f?"noise_error":"ready_error"),p}finally{i!=null&&r.signal?.removeEventListener("abort",i)}}async authenticateWebTransport({wt:t,remotePeer:r,certhashes:n,onProgress:o,signal:s}){s?.throwIfAborted(),o?.(new Oe("webtransport:open-authentication-stream"));let i=await t.createBidirectionalStream(),a=i.writable.getWriter(),c=i.readable.getReader(),u={source:async function*(){for(;;){let p=await c.read();if(p.value!=null&&(yield p.value),p.done)break}}(),sink:async p=>{for await(let m of p){await ht(a.ready,s);let x=m instanceof Uint8Array?m:m.subarray();a.write(x).catch(g=>{this.log.error("could not write chunk during authentication of WebTransport stream",g)})}}},f=If()(this.components);o?.(new Oe("webtransport:secure-outbound-connection"));let{remoteExtensions:l}=await f.secureOutbound(u,{signal:s,remotePeer:r,skipStreamMuxerNegotiation:!0});if(o?.(new Oe("webtransport:close-authentication-stream")),a.close().catch(p=>{this.log.error(`Failed to close authentication stream writer: ${p.message}`)}),c.cancel().catch(p=>{this.log.error(`Failed to close authentication stream reader: ${p.message}`)}),!Kf(l?.webtransportCerthashes??[],n.map(p=>p.bytes)))throw new nt("Our certhashes are not a subset of the remote's reported certhashes");return!0}createListener(t){return Ii(this.components,{...t,certificates:this.config.certificates,maxInboundStreams:this.config.maxInboundStreams})}listenFilter(){return[]}dialFilter(t){return globalThis.WebTransport==null?[]:t.filter(r=>{if(!yo.exactMatch(r))return!1;let{url:n,certhashes:o}=Wi(r);return n!=null&&o.length>0})}};function Sp(e={}){return t=>new $i(t,e)}return iu(Ap);})();
3
3
  //! TODO unclear how to add backpressure here?
4
4
  /*! Bundled license information:
5
5
 
6
6
  @noble/hashes/esm/utils.js:
7
7
  (*! noble-hashes - MIT License (c) 2022 Paul Miller (paulmillr.com) *)
8
8
 
9
- @noble/curves/esm/abstract/utils.js:
9
+ @noble/curves/esm/utils.js:
10
10
  @noble/curves/esm/abstract/modular.js:
11
11
  @noble/curves/esm/abstract/curve.js:
12
12
  @noble/curves/esm/abstract/edwards.js: