@libp2p/autonat 2.0.37-87e5d5938 → 2.0.37-cb1c14e62

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,5 +1,5 @@
1
1
  (function (root, factory) {(typeof module === 'object' && module.exports) ? module.exports = factory() : root.Libp2PAutonat = factory()}(typeof self !== 'undefined' ? self : this, function () {
2
- "use strict";var Libp2PAutonat=(()=>{var Xa=Object.create;var Sr=Object.defineProperty;var Qa=Object.getOwnPropertyDescriptor;var Ja=Object.getOwnPropertyNames;var tc=Object.getPrototypeOf,ec=Object.prototype.hasOwnProperty;var rc=(r,t)=>()=>(t||r((t={exports:{}}).exports,t),t.exports),dt=(r,t)=>{for(var e in t)Sr(r,e,{get:t[e],enumerable:!0})},ws=(r,t,e,n)=>{if(t&&typeof t=="object"||typeof t=="function")for(let o of Ja(t))!ec.call(r,o)&&o!==e&&Sr(r,o,{get:()=>t[o],enumerable:!(n=Qa(t,o))||n.enumerable});return r};var nc=(r,t,e)=>(e=r!=null?Xa(tc(r)):{},ws(t||!r||!r.__esModule?Sr(e,"default",{value:r,enumerable:!0}):e,r)),oc=r=>ws(Sr({},"__esModule",{value:!0}),r);var Ma=rc(Er=>{(function(){var r,t,e,n,o,s,i,a;a=function(u){var c,l,f,h;return c=(u&255<<24)>>>24,l=(u&255<<16)>>>16,f=(u&65280)>>>8,h=u&255,[c,l,f,h].join(".")},i=function(u){var c,l,f,h,m,b;for(c=[],f=h=0;h<=3&&u.length!==0;f=++h){if(f>0){if(u[0]!==".")throw new Error("Invalid IP");u=u.substring(1)}b=t(u),m=b[0],l=b[1],u=u.substring(l),c.push(m)}if(u.length!==0)throw new Error("Invalid IP");switch(c.length){case 1:if(c[0]>4294967295)throw new Error("Invalid IP");return c[0]>>>0;case 2:if(c[0]>255||c[1]>16777215)throw new Error("Invalid IP");return(c[0]<<24|c[1])>>>0;case 3:if(c[0]>255||c[1]>255||c[2]>65535)throw new Error("Invalid IP");return(c[0]<<24|c[1]<<16|c[2])>>>0;case 4:if(c[0]>255||c[1]>255||c[2]>255||c[3]>255)throw new Error("Invalid IP");return(c[0]<<24|c[1]<<16|c[2]<<8|c[3])>>>0;default:throw new Error("Invalid IP")}},e=function(u){return u.charCodeAt(0)},n=e("0"),s=e("a"),o=e("A"),t=function(u){var c,l,f,h,m;for(h=0,c=10,l="9",f=0,u.length>1&&u[f]==="0"&&(u[f+1]==="x"||u[f+1]==="X"?(f+=2,c=16):"0"<=u[f+1]&&u[f+1]<="9"&&(f++,c=8,l="7")),m=f;f<u.length;){if("0"<=u[f]&&u[f]<=l)h=h*c+(e(u[f])-n)>>>0;else if(c===16)if("a"<=u[f]&&u[f]<="f")h=h*c+(10+e(u[f])-s)>>>0;else if("A"<=u[f]&&u[f]<="F")h=h*c+(10+e(u[f])-o)>>>0;else break;else break;if(h>4294967295)throw new Error("too large");f++}if(f===m)throw new Error("empty octet");return[h,f]},r=function(){function u(c,l){var f,h,m,b;if(typeof c!="string")throw new Error("Missing `net' parameter");if(l||(b=c.split("/",2),c=b[0],l=b[1]),l||(l=32),typeof l=="string"&&l.indexOf(".")>-1){try{this.maskLong=i(l)}catch(w){throw f=w,new Error("Invalid mask: "+l)}for(h=m=32;m>=0;h=--m)if(this.maskLong===4294967295<<32-h>>>0){this.bitmask=h;break}}else if(l||l===0)this.bitmask=parseInt(l,10),this.maskLong=0,this.bitmask>0&&(this.maskLong=4294967295<<32-this.bitmask>>>0);else throw new Error("Invalid mask: empty");try{this.netLong=(i(c)&this.maskLong)>>>0}catch(w){throw f=w,new Error("Invalid net address: "+c)}if(!(this.bitmask<=32))throw new Error("Invalid mask for ip4: "+l);this.size=Math.pow(2,32-this.bitmask),this.base=a(this.netLong),this.mask=a(this.maskLong),this.hostmask=a(~this.maskLong),this.first=this.bitmask<=30?a(this.netLong+1):this.base,this.last=this.bitmask<=30?a(this.netLong+this.size-2):a(this.netLong+this.size-1),this.broadcast=this.bitmask<=30?a(this.netLong+this.size-1):void 0}return u.prototype.contains=function(c){return typeof c=="string"&&(c.indexOf("/")>0||c.split(".").length!==4)&&(c=new u(c)),c instanceof u?this.contains(c.base)&&this.contains(c.broadcast||c.last):(i(c)&this.maskLong)>>>0===(this.netLong&this.maskLong)>>>0},u.prototype.next=function(c){return c==null&&(c=1),new u(a(this.netLong+this.size*c),this.mask)},u.prototype.forEach=function(c){var l,f,h;for(h=i(this.first),f=i(this.last),l=0;h<=f;)c(a(h),h,l),l++,h++},u.prototype.toString=function(){return this.base+"/"+this.bitmask},u}(),Er.ip2long=i,Er.long2ip=a,Er.Netmask=r}).call(Er)});var jl={};dt(jl,{autoNAT:()=>Vl});var Ln=Symbol.for("@libp2p/peer-id");var Bt=class extends Error{static name="AbortError";constructor(t="The operation was aborted"){super(t),this.name="AbortError"}};var Tt=class extends Error{static name="InvalidParametersError";constructor(t="Invalid parameters"){super(t),this.name="InvalidParametersError"}},vr=class extends Error{static name="InvalidPublicKeyError";constructor(t="Invalid public key"){super(t),this.name="InvalidPublicKeyError"}};var Ar=class extends Error{static name="InvalidMultihashError";constructor(t="Invalid Multihash"){super(t),this.name="InvalidMultihashError"}};var He=class extends Error{static name="UnsupportedKeyTypeError";constructor(t="Unsupported key type"){super(t),this.name="UnsupportedKeyTypeError"}};var Ir=class extends EventTarget{#t=new Map;constructor(){super()}listenerCount(t){let e=this.#t.get(t);return e==null?0:e.length}addEventListener(t,e,n){super.addEventListener(t,e,n);let o=this.#t.get(t);o==null&&(o=[],this.#t.set(t,o)),o.push({callback:e,once:(n!==!0&&n!==!1&&n?.once)??!1})}removeEventListener(t,e,n){super.removeEventListener(t.toString(),e??null,n);let o=this.#t.get(t);o!=null&&(o=o.filter(({callback:s})=>s!==e),this.#t.set(t,o))}dispatchEvent(t){let e=super.dispatchEvent(t),n=this.#t.get(t.type);return n==null||(n=n.filter(({once:o})=>!o),this.#t.set(t.type,n)),e}safeDispatchEvent(t,e={}){return this.dispatchEvent(new CustomEvent(t,e))}};var Es=Symbol.for("@libp2p/service-capabilities"),_s=Symbol.for("@libp2p/service-dependencies");var kn={};dt(kn,{base58btc:()=>V,base58flickr:()=>lc});var yh=new Uint8Array(0);function Ss(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){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 vs(r){return new TextEncoder().encode(r)}function As(r){return new TextDecoder().decode(r)}function sc(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,u=r.charAt(0),c=Math.log(a)/Math.log(256),l=Math.log(256)/Math.log(a);function f(b){if(b instanceof Uint8Array||(ArrayBuffer.isView(b)?b=new Uint8Array(b.buffer,b.byteOffset,b.byteLength):Array.isArray(b)&&(b=Uint8Array.from(b))),!(b instanceof Uint8Array))throw new TypeError("Expected Uint8Array");if(b.length===0)return"";for(var w=0,d=0,S=0,T=b.length;S!==T&&b[S]===0;)S++,w++;for(var v=(T-S)*l+1>>>0,P=new Uint8Array(v);S!==T;){for(var y=b[S],L=0,C=v-1;(y!==0||L<d)&&C!==-1;C--,L++)y+=256*P[C]>>>0,P[C]=y%a>>>0,y=y/a>>>0;if(y!==0)throw new Error("Non-zero carry");d=L,S++}for(var I=v-d;I!==v&&P[I]===0;)I++;for(var p=u.repeat(w);I<v;++I)p+=r.charAt(P[I]);return p}function h(b){if(typeof b!="string")throw new TypeError("Expected String");if(b.length===0)return new Uint8Array;var w=0;if(b[w]!==" "){for(var d=0,S=0;b[w]===u;)d++,w++;for(var T=(b.length-w)*c+1>>>0,v=new Uint8Array(T);b[w];){var P=e[b.charCodeAt(w)];if(P===255)return;for(var y=0,L=T-1;(P!==0||y<S)&&L!==-1;L--,y++)P+=a*v[L]>>>0,v[L]=P%256>>>0,P=P/256>>>0;if(P!==0)throw new Error("Non-zero carry");S=y,w++}if(b[w]!==" "){for(var C=T-S;C!==T&&v[C]===0;)C++;for(var I=new Uint8Array(d+(T-C)),p=d;C!==T;)I[p++]=v[C++];return I}}}function m(b){var w=h(b);if(w)return w;throw new Error(`Non-${t} character`)}return{encode:f,decodeUnsafe:h,decode:m}}var ic=sc,ac=ic,Bs=ac;var Pn=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")}},Rn=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 Ts(this,t)}},On=class{decoders;constructor(t){this.decoders=t}or(t){return Ts(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 Ts(r,t){return new On({...r.decoders??{[r.prefix]:r},...t.decoders??{[t.prefix]:t}})}var Nn=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 Pn(t,e,n),this.decoder=new Rn(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 Nn(r,t,e,n)}function zt({name:r,prefix:t,alphabet:e}){let{encode:n,decode:o}=Bs(e,r);return ge({prefix:t,name:r,encode:n,decode:s=>Dt(o(s))})}function cc(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,u=0;for(let c=0;c<o;++c){let l=t[r[c]];if(l===void 0)throw new SyntaxError(`Non-${n} character`);a=a<<e|l,i+=e,i>=8&&(i-=8,s[u++]=255&a>>i)}if(i>=e||(255&a<<8-i)!==0)throw new SyntaxError("Unexpected end of data");return s}function uc(r,t,e){let n=t[t.length-1]==="=",o=(1<<e)-1,s="",i=0,a=0;for(let u=0;u<r.length;++u)for(a=a<<8|r[u],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 fc(r){let t={};for(let e=0;e<r.length;++e)t[r[e]]=e;return t}function G({name:r,prefix:t,bitsPerChar:e,alphabet:n}){let o=fc(n);return ge({prefix:t,name:r,encode(s){return uc(s,n,e)},decode(s){return cc(s,o,e,r)}})}var V=zt({name:"base58btc",prefix:"z",alphabet:"123456789ABCDEFGHJKLMNPQRSTUVWXYZabcdefghijkmnopqrstuvwxyz"}),lc=zt({name:"base58flickr",prefix:"Z",alphabet:"123456789abcdefghijkmnopqrstuvwxyzABCDEFGHJKLMNPQRSTUVWXYZ"});var Un={};dt(Un,{base32:()=>qt,base32hex:()=>mc,base32hexpad:()=>yc,base32hexpadupper:()=>bc,base32hexupper:()=>gc,base32pad:()=>dc,base32padupper:()=>pc,base32upper:()=>hc,base32z:()=>xc});var qt=G({prefix:"b",name:"base32",alphabet:"abcdefghijklmnopqrstuvwxyz234567",bitsPerChar:5}),hc=G({prefix:"B",name:"base32upper",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZ234567",bitsPerChar:5}),dc=G({prefix:"c",name:"base32pad",alphabet:"abcdefghijklmnopqrstuvwxyz234567=",bitsPerChar:5}),pc=G({prefix:"C",name:"base32padupper",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZ234567=",bitsPerChar:5}),mc=G({prefix:"v",name:"base32hex",alphabet:"0123456789abcdefghijklmnopqrstuv",bitsPerChar:5}),gc=G({prefix:"V",name:"base32hexupper",alphabet:"0123456789ABCDEFGHIJKLMNOPQRSTUV",bitsPerChar:5}),yc=G({prefix:"t",name:"base32hexpad",alphabet:"0123456789abcdefghijklmnopqrstuv=",bitsPerChar:5}),bc=G({prefix:"T",name:"base32hexpadupper",alphabet:"0123456789ABCDEFGHIJKLMNOPQRSTUV=",bitsPerChar:5}),xc=G({prefix:"h",name:"base32z",alphabet:"ybndrfg8ejkmcpqxot1uwisza345h769",bitsPerChar:5});var Mn={};dt(Mn,{base36:()=>Ve,base36upper:()=>wc});var Ve=zt({prefix:"k",name:"base36",alphabet:"0123456789abcdefghijklmnopqrstuvwxyz"}),wc=zt({prefix:"K",name:"base36upper",alphabet:"0123456789ABCDEFGHIJKLMNOPQRSTUVWXYZ"});var Ec=Ls,Ds=128,_c=127,Sc=~_c,vc=Math.pow(2,31);function Ls(r,t,e){t=t||[],e=e||0;for(var n=e;r>=vc;)t[e++]=r&255|Ds,r/=128;for(;r&Sc;)t[e++]=r&255|Ds,r>>>=7;return t[e]=r|0,Ls.bytes=e-n+1,t}var Ac=Fn,Ic=128,Cs=127;function Fn(r,n){var e=0,n=n||0,o=0,s=n,i,a=r.length;do{if(s>=a)throw Fn.bytes=0,new RangeError("Could not decode varint");i=r[s++],e+=o<28?(i&Cs)<<o:(i&Cs)*Math.pow(2,o),o+=7}while(i>=Ic);return Fn.bytes=s-n,e}var Bc=Math.pow(2,7),Tc=Math.pow(2,14),Dc=Math.pow(2,21),Cc=Math.pow(2,28),Lc=Math.pow(2,35),Pc=Math.pow(2,42),Rc=Math.pow(2,49),Oc=Math.pow(2,56),Nc=Math.pow(2,63),kc=function(r){return r<Bc?1:r<Tc?2:r<Dc?3:r<Cc?4:r<Lc?5:r<Pc?6:r<Rc?7:r<Oc?8:r<Nc?9:10},Uc={encode:Ec,decode:Ac,encodingLength:kc},Mc=Uc,je=Mc;function Ge(r,t=0){return[je.decode(r,t),je.decode.bytes]}function ye(r,t,e=0){return je.encode(r,t,e),t}function be(r){return je.encodingLength(r)}function Xt(r,t){let e=t.byteLength,n=be(r),o=n+be(e),s=new Uint8Array(o+e);return ye(r,s,0),ye(e,s,n),s.set(t,o),new xe(r,e,t,s)}function Qt(r){let t=Dt(r),[e,n]=Ge(t),[o,s]=Ge(t.subarray(n)),i=t.subarray(n+s);if(i.byteLength!==o)throw new Error("Incorrect length");return new xe(e,o,i,t)}function Ps(r,t){if(r===t)return!0;{let e=t;return r.code===e.code&&r.size===e.size&&e.bytes instanceof Uint8Array&&Ss(r.bytes,e.bytes)}}var xe=class{code;size;digest;bytes;constructor(t,e,n,o){this.code=t,this.size=e,this.digest=n,this.bytes=o}};function Rs(r,t){let{bytes:e,version:n}=r;switch(n){case 0:return Kc(e,Kn(r),t??V.encoder);default:return zc(e,Kn(r),t??qt.encoder)}}var Os=new WeakMap;function Kn(r){let t=Os.get(r);if(t==null){let e=new Map;return Os.set(r,e),e}return t}var X=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!==$e)throw new Error("Cannot convert a non dag-pb CID to CIDv0");if(e.code!==qc)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=Xt(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&&Ps(t.multihash,n.multihash)}toString(t){return Rs(this,t)}toJSON(){return{"/":Rs(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??Ns(n,o,s.bytes))}else if(e[Hc]===!0){let{version:n,multihash:o,code:s}=e,i=Qt(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!==$e)throw new Error(`Version 0 CID must use dag-pb (code: ${$e}) block encoding`);return new r(t,e,n,n.bytes)}case 1:{let o=Ns(t,e,n.bytes);return new r(t,e,n,o)}default:throw new Error("Invalid version")}}static createV0(t){return r.create(0,$e,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=Dt(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 xe(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[f,h]=Ge(t.subarray(e));return e+=h,f},o=n(),s=$e;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(),u=n(),c=e+u,l=c-i;return{version:o,codec:s,multihashCode:a,digestSize:u,multihashSize:l,size:c}}static parse(t,e){let[n,o]=Fc(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 Kn(s).set(n,t),s}};function Fc(r,t){switch(r[0]){case"Q":{let e=t??V;return[V.prefix,e.decode(`${V.prefix}${r}`)]}case V.prefix:{let e=t??V;return[V.prefix,e.decode(r)]}case qt.prefix:{let e=t??qt;return[qt.prefix,e.decode(r)]}case Ve.prefix:{let e=t??Ve;return[Ve.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 Kc(r,t,e){let{prefix:n}=e;if(n!==V.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 zc(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 $e=112,qc=18;function Ns(r,t,e){let n=be(r),o=n+be(t),s=new Uint8Array(o+e.byteLength);return ye(r,s,0),ye(t,s,n),s.set(e,o),s}var Hc=Symbol.for("@ipld/js-cid/CID");var zn={};dt(zn,{identity:()=>yt});var ks=0,Vc="identity",Us=Dt;function jc(r){return Xt(ks,Us(r))}var yt={code:ks,name:Vc,encode:Us,digest:jc};function at(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 bt(r=0){return new Uint8Array(r)}function ft(r=0){return new Uint8Array(r)}function Ct(r,t){t==null&&(t=r.reduce((o,s)=>o+s.length,0));let e=ft(t),n=0;for(let o of r)e.set(o,n),n+=o.length;return e}var Fs=Symbol.for("@achingbrain/uint8arraylist");function Ms(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 Tr(r){return!!r?.[Fs]}var W=class r{bufs;length;[Fs]=!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(Tr(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(Tr(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=Ms(this.bufs,t);return e.buf[e.index]}set(t,e){let n=Ms(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(Tr(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 Ct(n,o)}subarray(t,e){let{bufs:n,length:o}=this._subList(t,e);return n.length===1?n[0]:Ct(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,u=a+i.byteLength;if(o=u,t>=u)continue;let c=t>=a&&t<u,l=e>a&&e<=u;if(c&&l){if(t===a&&e===u){n.push(i);break}let f=t-a;n.push(i.subarray(f,f+(e-t)));break}if(c){if(t===0){n.push(i);continue}n.push(i.subarray(t-a));continue}if(l){if(e===u){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(!Tr(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 f=0;f<s;f++)i[f]=-1;for(let f=0;f<o;f++)i[n[f]]=f;let a=i,u=this.byteLength-n.byteLength,c=n.byteLength-1,l;for(let f=e;f<=u;f+=l){l=0;for(let h=c;h>=0;h--){let m=this.get(f+h);if(n[h]!==m){l=Math.max(1,h-a[m]);break}}if(l===0)return f}return-1}getInt8(t){let e=this.subarray(t,t+1);return new DataView(e.buffer,e.byteOffset,e.byteLength).getInt8(0)}setInt8(t,e){let n=ft(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=bt(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=bt(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=bt(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=ft(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=bt(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=bt(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=bt(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=bt(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=bt(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(!at(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 qn={};dt(qn,{base10:()=>Gc});var Gc=zt({prefix:"9",name:"base10",alphabet:"0123456789"});var Hn={};dt(Hn,{base16:()=>$c,base16upper:()=>Zc});var $c=G({prefix:"f",name:"base16",alphabet:"0123456789abcdef",bitsPerChar:4}),Zc=G({prefix:"F",name:"base16upper",alphabet:"0123456789ABCDEF",bitsPerChar:4});var Vn={};dt(Vn,{base2:()=>Wc});var Wc=G({prefix:"0",name:"base2",alphabet:"01",bitsPerChar:1});var jn={};dt(jn,{base256emoji:()=>tu});var Ks=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}"),Yc=Ks.reduce((r,t,e)=>(r[e]=t,r),[]),Xc=Ks.reduce((r,t,e)=>{let n=t.codePointAt(0);if(n==null)throw new Error(`Invalid character: ${t}`);return r[n]=e,r},[]);function Qc(r){return r.reduce((t,e)=>(t+=Yc[e],t),"")}function Jc(r){let t=[];for(let e of r){let n=e.codePointAt(0);if(n==null)throw new Error(`Invalid character: ${e}`);let o=Xc[n];if(o==null)throw new Error(`Non-base256emoji character: ${e}`);t.push(o)}return new Uint8Array(t)}var tu=ge({prefix:"\u{1F680}",name:"base256emoji",encode:Qc,decode:Jc});var $n={};dt($n,{base64:()=>eu,base64pad:()=>ru,base64url:()=>Gn,base64urlpad:()=>nu});var eu=G({prefix:"m",name:"base64",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/",bitsPerChar:6}),ru=G({prefix:"M",name:"base64pad",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/=",bitsPerChar:6}),Gn=G({prefix:"u",name:"base64url",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789-_",bitsPerChar:6}),nu=G({prefix:"U",name:"base64urlpad",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789-_=",bitsPerChar:6});var Zn={};dt(Zn,{base8:()=>ou});var ou=G({prefix:"7",name:"base8",alphabet:"01234567",bitsPerChar:3});var Wn={};dt(Wn,{identity:()=>su});var su=ge({prefix:"\0",name:"identity",encode:r=>As(r),decode:r=>vs(r)});var td=new TextEncoder,ed=new TextDecoder;var Qn={};dt(Qn,{sha256:()=>Ze,sha512:()=>cu});function Xn({name:r,code:t,encode:e}){return new Yn(r,t,e)}var Yn=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?Xt(this.code,e):e.then(n=>Xt(this.code,n))}else throw Error("Unknown type, must be binary type")}};function qs(r){return async t=>new Uint8Array(await crypto.subtle.digest(r,t))}var Ze=Xn({name:"sha2-256",code:18,encode:qs("SHA-256")}),cu=Xn({name:"sha2-512",code:19,encode:qs("SHA-512")});var We={...Wn,...Vn,...Zn,...qn,...Hn,...Un,...Mn,...kn,...$n,...jn},dd={...Qn,...zn};function Vs(r,t,e,n){return{name:r,prefix:t,encoder:{name:r,prefix:t,encode:e},decoder:{decode:n}}}var Hs=Vs("utf8","u",r=>"u"+new TextDecoder("utf8").decode(r),r=>new TextEncoder().encode(r.substring(1))),Jn=Vs("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=ft(r.length);for(let e=0;e<r.length;e++)t[e]=r.charCodeAt(e);return t}),uu={utf8:Hs,"utf-8":Hs,hex:We.base16,latin1:Jn,ascii:Jn,binary:Jn,...We},Dr=uu;function M(r,t="utf8"){let e=Dr[t];if(e==null)throw new Error(`Unsupported encoding "${t}"`);return e.decoder.decode(`${e.prefix}${r}`)}function z(r,t="utf8"){let e=Dr[t];if(e==null)throw new Error(`Unsupported encoding "${t}"`);return e.encoder.encode(r).substring(1)}var fu=parseInt("11111",2),to=parseInt("10000000",2),lu=parseInt("01111111",2),js={0:Ye,1:Ye,2:hu,3:mu,4:gu,5:pu,6:du,16:Ye,22:Ye,48:Ye};function eo(r,t={offset:0}){let e=r[t.offset]&fu;if(t.offset++,js[e]!=null)return js[e](r,t);throw new Error("No decoder for tag "+e)}function Xe(r,t){let e=0;if((r[t.offset]&to)===to){let n=r[t.offset]&lu,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 Ye(r,t){Xe(r,t);let e=[];for(;!(t.offset>=r.byteLength);){let n=eo(r,t);if(n===null)break;e.push(n)}return e}function hu(r,t){let e=Xe(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 du(r,t){let e=Xe(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}`,u=[];for(;t.offset<n;){let c=r[t.offset];if(t.offset++,u.push(c&127),c<128){u.reverse();let l=0;for(let f=0;f<u.length;f++)l+=u[f]<<f*7;a+=`.${l}`,u=[]}}return a}function pu(r,t){return t.offset++,null}function mu(r,t){let e=Xe(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 gu(r,t){let e=Xe(r,t),n=r.subarray(t.offset,t.offset+e);return t.offset+=e,n}function yu(r){let t=r.toString(16);t.length%2===1&&(t="0"+t);let e=new W;for(let n=0;n<t.length;n+=2)e.append(Uint8Array.from([parseInt(`${t[n]}${t[n+1]}`,16)]));return e}function ro(r){if(r.byteLength<128)return Uint8Array.from([r.byteLength]);let t=yu(r.byteLength);return new W(Uint8Array.from([t.byteLength|to]),t)}function Gs(r){let t=new W,e=128;return(r.subarray()[0]&e)===e&&t.append(Uint8Array.from([0])),t.append(r),new W(Uint8Array.from([2]),ro(t),t)}function $s(r){let t=Uint8Array.from([0]),e=new W(t,r);return new W(Uint8Array.from([3]),ro(e),e)}function Cr(r,t=48){let e=new W;for(let n of r)e.append(n);return new W(Uint8Array.from([t]),ro(e),e)}async function Zs(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 bu=Uint8Array.from([6,8,42,134,72,206,61,3,1,7]),xu=Uint8Array.from([6,5,43,129,4,0,34]),wu=Uint8Array.from([6,5,43,129,4,0,35]),Eu={ext:!0,kty:"EC",crv:"P-256"},_u={ext:!0,kty:"EC",crv:"P-384"},Su={ext:!0,kty:"EC",crv:"P-521"},no=32,oo=48,so=66;function Ws(r){let t=eo(r);return Ys(t)}function Ys(r){let t=r[1][1][0],e=1,n,o;if(t.byteLength===no*2+1)return n=z(t.subarray(e,e+no),"base64url"),o=z(t.subarray(e+no),"base64url"),new we({...Eu,key_ops:["verify"],x:n,y:o});if(t.byteLength===oo*2+1)return n=z(t.subarray(e,e+oo),"base64url"),o=z(t.subarray(e+oo),"base64url"),new we({..._u,key_ops:["verify"],x:n,y:o});if(t.byteLength===so*2+1)return n=z(t.subarray(e,e+so),"base64url"),o=z(t.subarray(e+so),"base64url"),new we({...Su,key_ops:["verify"],x:n,y:o});throw new Tt(`coordinates were wrong length, got ${t.byteLength}, expected 65, 97 or 133`)}function Xs(r){return Cr([Gs(Uint8Array.from([1])),Cr([vu(r.crv)],160),Cr([$s(new W(Uint8Array.from([4]),M(r.x??"","base64url"),M(r.y??"","base64url")))],161)]).subarray()}function vu(r){if(r==="P-256")return bu;if(r==="P-384")return xu;if(r==="P-521")return wu;throw new Tt(`Invalid curve ${r}`)}var we=class{type="ECDSA";jwk;_raw;constructor(t){this.jwk=t}get raw(){return this._raw==null&&(this._raw=Xs(this.jwk)),this._raw}toMultihash(){return yt.digest(Ee(this))}toCID(){return X.createV1(114,this.toMultihash())}toString(){return V.encode(this.toMultihash().bytes).substring(1)}equals(t){return t==null||!(t.raw instanceof Uint8Array)?!1:at(this.raw,t.raw)}async verify(t,e,n){return Zs(this.jwk,e,t,n)}};var Jt=typeof globalThis=="object"&&"crypto"in globalThis?globalThis.crypto:void 0;function Se(r){return r instanceof Uint8Array||ArrayBuffer.isView(r)&&r.constructor.name==="Uint8Array"}function Qe(r){if(!Number.isSafeInteger(r)||r<0)throw new Error("positive integer expected, got "+r)}function nt(r,...t){if(!Se(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 Js(r){if(typeof r!="function"||typeof r.create!="function")throw new Error("Hash should be wrapped by utils.createHasher");Qe(r.outputLen),Qe(r.blockLen)}function ve(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 ti(r,t){nt(r);let e=t.outputLen;if(r.length<e)throw new Error("digestInto() expects output buffer of length at least "+e)}function Pt(...r){for(let t=0;t<r.length;t++)r[t].fill(0)}function Lr(r){return new DataView(r.buffer,r.byteOffset,r.byteLength)}function xt(r,t){return r<<32-t|r>>>t}var ei=typeof Uint8Array.from([]).toHex=="function"&&typeof Uint8Array.fromHex=="function",Au=Array.from({length:256},(r,t)=>t.toString(16).padStart(2,"0"));function vt(r){if(nt(r),ei)return r.toHex();let t="";for(let e=0;e<r.length;e++)t+=Au[r[e]];return t}var Lt={_0:48,_9:57,A:65,F:70,a:97,f:102};function Qs(r){if(r>=Lt._0&&r<=Lt._9)return r-Lt._0;if(r>=Lt.A&&r<=Lt.F)return r-(Lt.A-10);if(r>=Lt.a&&r<=Lt.f)return r-(Lt.a-10)}function Ae(r){if(typeof r!="string")throw new Error("hex string expected, got "+typeof r);if(ei)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=Qs(r.charCodeAt(s)),a=Qs(r.charCodeAt(s+1));if(i===void 0||a===void 0){let u=r[s]+r[s+1];throw new Error('hex string expected, got non-hex character "'+u+'" at index '+s)}n[o]=i*16+a}return n}function ri(r){if(typeof r!="string")throw new Error("string expected");return new Uint8Array(new TextEncoder().encode(r))}function Je(r){return typeof r=="string"&&(r=ri(r)),nt(r),r}function pt(...r){let t=0;for(let n=0;n<r.length;n++){let o=r[n];nt(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 _e=class{};function io(r){let t=n=>r().update(Je(n)).digest(),e=r();return t.outputLen=e.outputLen,t.blockLen=e.blockLen,t.create=()=>r(),t}function tr(r=32){if(Jt&&typeof Jt.getRandomValues=="function")return Jt.getRandomValues(new Uint8Array(r));if(Jt&&typeof Jt.randomBytes=="function")return Uint8Array.from(Jt.randomBytes(r));throw new Error("crypto.getRandomValues must be defined")}function Iu(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),u=n?4:0,c=n?0:4;r.setUint32(t+u,i,n),r.setUint32(t+c,a,n)}function ni(r,t,e){return r&t^~r&e}function oi(r,t,e){return r&t^r&e^t&e}var er=class extends _e{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=Lr(this.buffer)}update(t){ve(this),t=Je(t),nt(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 u=Lr(t);for(;o<=s-i;i+=o)this.process(u,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){ve(this),ti(t,this),this.finished=!0;let{buffer:e,view:n,blockLen:o,isLE:s}=this,{pos:i}=this;e[i++]=128,Pt(this.buffer.subarray(i)),this.padOffset>o-i&&(this.process(n,0),i=0);for(let f=i;f<o;f++)e[f]=0;Iu(n,o-8,BigInt(this.length*8),s),this.process(n,0);let a=Lr(t),u=this.outputLen;if(u%4)throw new Error("_sha2: outputLen should be aligned to 32bit");let c=u/4,l=this.get();if(c>l.length)throw new Error("_sha2: outputLen bigger than state");for(let f=0;f<c;f++)a.setUint32(4*f,l[f],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()}},Rt=Uint32Array.from([1779033703,3144134277,1013904242,2773480762,1359893119,2600822924,528734635,1541459225]);var tt=Uint32Array.from([1779033703,4089235720,3144134277,2227873595,1013904242,4271175723,2773480762,1595750129,1359893119,2917565137,2600822924,725511199,528734635,4215389547,1541459225,327033209]);var Pr=BigInt(4294967295),si=BigInt(32);function Bu(r,t=!1){return t?{h:Number(r&Pr),l:Number(r>>si&Pr)}:{h:Number(r>>si&Pr)|0,l:Number(r&Pr)|0}}function ii(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}=Bu(r[s],t);[n[s],o[s]]=[i,a]}return[n,o]}var ao=(r,t,e)=>r>>>e,co=(r,t,e)=>r<<32-e|t>>>e,te=(r,t,e)=>r>>>e|t<<32-e,ee=(r,t,e)=>r<<32-e|t>>>e,rr=(r,t,e)=>r<<64-e|t>>>e-32,nr=(r,t,e)=>r>>>e-32|t<<64-e;function At(r,t,e,n){let o=(t>>>0)+(n>>>0);return{h:r+e+(o/2**32|0)|0,l:o|0}}var ai=(r,t,e)=>(r>>>0)+(t>>>0)+(e>>>0),ci=(r,t,e,n)=>t+e+n+(r/2**32|0)|0,ui=(r,t,e,n)=>(r>>>0)+(t>>>0)+(e>>>0)+(n>>>0),fi=(r,t,e,n,o)=>t+e+n+o+(r/2**32|0)|0,li=(r,t,e,n,o)=>(r>>>0)+(t>>>0)+(e>>>0)+(n>>>0)+(o>>>0),hi=(r,t,e,n,o,s)=>t+e+n+o+s+(r/2**32|0)|0;var Du=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]),Vt=new Uint32Array(64),uo=class extends er{constructor(t=32){super(64,t,8,!1),this.A=Rt[0]|0,this.B=Rt[1]|0,this.C=Rt[2]|0,this.D=Rt[3]|0,this.E=Rt[4]|0,this.F=Rt[5]|0,this.G=Rt[6]|0,this.H=Rt[7]|0}get(){let{A:t,B:e,C:n,D:o,E:s,F:i,G:a,H:u}=this;return[t,e,n,o,s,i,a,u]}set(t,e,n,o,s,i,a,u){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=u|0}process(t,e){for(let f=0;f<16;f++,e+=4)Vt[f]=t.getUint32(e,!1);for(let f=16;f<64;f++){let h=Vt[f-15],m=Vt[f-2],b=xt(h,7)^xt(h,18)^h>>>3,w=xt(m,17)^xt(m,19)^m>>>10;Vt[f]=w+Vt[f-7]+b+Vt[f-16]|0}let{A:n,B:o,C:s,D:i,E:a,F:u,G:c,H:l}=this;for(let f=0;f<64;f++){let h=xt(a,6)^xt(a,11)^xt(a,25),m=l+h+ni(a,u,c)+Du[f]+Vt[f]|0,w=(xt(n,2)^xt(n,13)^xt(n,22))+oi(n,o,s)|0;l=c,c=u,u=a,a=i+m|0,i=s,s=o,o=n,n=m+w|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,u=u+this.F|0,c=c+this.G|0,l=l+this.H|0,this.set(n,o,s,i,a,u,c,l)}roundClean(){Pt(Vt)}destroy(){this.set(0,0,0,0,0,0,0,0),Pt(this.buffer)}};var di=ii(["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))),Cu=di[0],Lu=di[1],jt=new Uint32Array(80),Gt=new Uint32Array(80),fo=class extends er{constructor(t=64){super(128,t,16,!1),this.Ah=tt[0]|0,this.Al=tt[1]|0,this.Bh=tt[2]|0,this.Bl=tt[3]|0,this.Ch=tt[4]|0,this.Cl=tt[5]|0,this.Dh=tt[6]|0,this.Dl=tt[7]|0,this.Eh=tt[8]|0,this.El=tt[9]|0,this.Fh=tt[10]|0,this.Fl=tt[11]|0,this.Gh=tt[12]|0,this.Gl=tt[13]|0,this.Hh=tt[14]|0,this.Hl=tt[15]|0}get(){let{Ah:t,Al:e,Bh:n,Bl:o,Ch:s,Cl:i,Dh:a,Dl:u,Eh:c,El:l,Fh:f,Fl:h,Gh:m,Gl:b,Hh:w,Hl:d}=this;return[t,e,n,o,s,i,a,u,c,l,f,h,m,b,w,d]}set(t,e,n,o,s,i,a,u,c,l,f,h,m,b,w,d){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=u|0,this.Eh=c|0,this.El=l|0,this.Fh=f|0,this.Fl=h|0,this.Gh=m|0,this.Gl=b|0,this.Hh=w|0,this.Hl=d|0}process(t,e){for(let v=0;v<16;v++,e+=4)jt[v]=t.getUint32(e),Gt[v]=t.getUint32(e+=4);for(let v=16;v<80;v++){let P=jt[v-15]|0,y=Gt[v-15]|0,L=te(P,y,1)^te(P,y,8)^ao(P,y,7),C=ee(P,y,1)^ee(P,y,8)^co(P,y,7),I=jt[v-2]|0,p=Gt[v-2]|0,E=te(I,p,19)^rr(I,p,61)^ao(I,p,6),g=ee(I,p,19)^nr(I,p,61)^co(I,p,6),x=ui(C,g,Gt[v-7],Gt[v-16]),_=fi(x,L,E,jt[v-7],jt[v-16]);jt[v]=_|0,Gt[v]=x|0}let{Ah:n,Al:o,Bh:s,Bl:i,Ch:a,Cl:u,Dh:c,Dl:l,Eh:f,El:h,Fh:m,Fl:b,Gh:w,Gl:d,Hh:S,Hl:T}=this;for(let v=0;v<80;v++){let P=te(f,h,14)^te(f,h,18)^rr(f,h,41),y=ee(f,h,14)^ee(f,h,18)^nr(f,h,41),L=f&m^~f&w,C=h&b^~h&d,I=li(T,y,C,Lu[v],Gt[v]),p=hi(I,S,P,L,Cu[v],jt[v]),E=I|0,g=te(n,o,28)^rr(n,o,34)^rr(n,o,39),x=ee(n,o,28)^nr(n,o,34)^nr(n,o,39),_=n&s^n&a^s&a,B=o&i^o&u^i&u;S=w|0,T=d|0,w=m|0,d=b|0,m=f|0,b=h|0,{h:f,l:h}=At(c|0,l|0,p|0,E|0),c=a|0,l=u|0,a=s|0,u=i|0,s=n|0,i=o|0;let A=ai(E,x,B);n=ci(A,p,g,_),o=A|0}({h:n,l:o}=At(this.Ah|0,this.Al|0,n|0,o|0)),{h:s,l:i}=At(this.Bh|0,this.Bl|0,s|0,i|0),{h:a,l:u}=At(this.Ch|0,this.Cl|0,a|0,u|0),{h:c,l}=At(this.Dh|0,this.Dl|0,c|0,l|0),{h:f,l:h}=At(this.Eh|0,this.El|0,f|0,h|0),{h:m,l:b}=At(this.Fh|0,this.Fl|0,m|0,b|0),{h:w,l:d}=At(this.Gh|0,this.Gl|0,w|0,d|0),{h:S,l:T}=At(this.Hh|0,this.Hl|0,S|0,T|0),this.set(n,o,s,i,a,u,c,l,f,h,m,b,w,d,S,T)}roundClean(){Pt(jt,Gt)}destroy(){Pt(this.buffer),this.set(0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0)}};var pi=io(()=>new uo);var mi=io(()=>new fo);var po=BigInt(0),ho=BigInt(1);function Ot(r,t){if(typeof t!="boolean")throw new Error(r+" boolean expected, got "+t)}function or(r){let t=r.toString(16);return t.length&1?"0"+t:t}function gi(r){if(typeof r!="string")throw new Error("hex string expected, got "+typeof r);return r===""?po:BigInt("0x"+r)}function Ie(r){return gi(vt(r))}function re(r){return nt(r),gi(vt(Uint8Array.from(r).reverse()))}function Rr(r,t){return Ae(r.toString(16).padStart(t*2,"0"))}function Be(r,t){return Rr(r,t).reverse()}function q(r,t,e){let n;if(typeof t=="string")try{n=Ae(t)}catch(s){throw new Error(r+" must be hex string or Uint8Array, cause: "+s)}else if(Se(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}var lo=r=>typeof r=="bigint"&&po<=r;function yi(r,t,e){return lo(r)&&lo(t)&&lo(e)&&t<=r&&r<e}function $t(r,t,e,n){if(!yi(t,e,n))throw new Error("expected valid "+r+": "+e+" <= n < "+n+", got "+t)}function bi(r){let t;for(t=0;r>po;r>>=ho,t+=1);return t}var ne=r=>(ho<<BigInt(r))-ho;function xi(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=m=>new Uint8Array(m),o=m=>Uint8Array.of(m),s=n(r),i=n(r),a=0,u=()=>{s.fill(1),i.fill(0),a=0},c=(...m)=>e(i,s,...m),l=(m=n(0))=>{i=c(o(0),m),s=c(),m.length!==0&&(i=c(o(1),m),s=c())},f=()=>{if(a++>=1e3)throw new Error("drbg: tried 1000 values");let m=0,b=[];for(;m<t;){s=c();let w=s.slice();b.push(w),m+=s.length}return pt(...b)};return(m,b)=>{u(),l(m);let w;for(;!(w=b(f()));)l();return u(),w}}function Zt(r,t,e={}){if(!r||typeof r!="object")throw new Error("expected valid options object");function n(o,s,i){let a=r[o];if(i&&a===void 0)return;let u=typeof a;if(u!==s||a===null)throw new Error(`param "${o}" is invalid: expected ${s}, got ${u}`)}Object.entries(t).forEach(([o,s])=>n(o,s,!1)),Object.entries(e).forEach(([o,s])=>n(o,s,!0))}function Te(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),Q=BigInt(1),oe=BigInt(2),Pu=BigInt(3),_i=BigInt(4),Si=BigInt(5),vi=BigInt(8);function j(r,t){let e=r%t;return e>=ct?e:t+e}function H(r,t,e){let n=r;for(;t-- >ct;)n*=n,n%=e;return n}function wi(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=j(r,t),n=t,o=ct,s=Q,i=Q,a=ct;for(;e!==ct;){let c=n/e,l=n%e,f=o-i*c,h=s-a*c;n=e,e=l,o=i,s=a,i=f,a=h}if(n!==Q)throw new Error("invert: does not exist");return j(o,t)}function Ai(r,t){let e=(r.ORDER+Q)/_i,n=r.pow(t,e);if(!r.eql(r.sqr(n),t))throw new Error("Cannot find square root");return n}function Ru(r,t){let e=(r.ORDER-Si)/vi,n=r.mul(t,oe),o=r.pow(n,e),s=r.mul(t,o),i=r.mul(r.mul(s,oe),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 Ou(r){if(r<BigInt(3))throw new Error("sqrt is not defined for small field");let t=r-Q,e=0;for(;t%oe===ct;)t/=oe,e++;let n=oe,o=wt(r);for(;Ei(o,n)===1;)if(n++>1e3)throw new Error("Cannot find square root: probably non-prime P");if(e===1)return Ai;let s=o.pow(n,t),i=(t+Q)/oe;return function(u,c){if(u.is0(c))return c;if(Ei(u,c)!==1)throw new Error("Cannot find square root");let l=e,f=u.mul(u.ONE,s),h=u.pow(c,t),m=u.pow(c,i);for(;!u.eql(h,u.ONE);){if(u.is0(h))return u.ZERO;let b=1,w=u.sqr(h);for(;!u.eql(w,u.ONE);)if(b++,w=u.sqr(w),b===l)throw new Error("Cannot find square root");let d=Q<<BigInt(l-b-1),S=u.pow(f,d);l=b,f=u.sqr(S),h=u.mul(h,f),m=u.mul(m,S)}return m}}function Nu(r){return r%_i===Pu?Ai:r%vi===Si?Ru:Ou(r)}var Ii=(r,t)=>(j(r,t)&Q)===Q,ku=["create","isValid","is0","neg","inv","sqrt","sqr","eql","add","sub","mul","pow","div","addN","subN","mulN","sqrN"];function mo(r){let t={ORDER:"bigint",MASK:"bigint",BYTES:"number",BITS:"number"},e=ku.reduce((n,o)=>(n[o]="function",n),t);return Zt(r,e),r}function Uu(r,t,e){if(e<ct)throw new Error("invalid exponent, negatives unsupported");if(e===ct)return r.ONE;if(e===Q)return t;let n=r.ONE,o=t;for(;e>ct;)e&Q&&(n=r.mul(n,o)),o=r.sqr(o),e>>=Q;return n}function sr(r,t,e=!1){let n=new Array(t.length).fill(e?r.ZERO:void 0),o=t.reduce((i,a,u)=>r.is0(a)?i:(n[u]=i,r.mul(i,a)),r.ONE),s=r.inv(o);return t.reduceRight((i,a,u)=>r.is0(a)?i:(n[u]=r.mul(i,n[u]),r.mul(i,a)),s),n}function Ei(r,t){let e=(r.ORDER-Q)/oe,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 Bi(r,t){t!==void 0&&Qe(t);let e=t!==void 0?t:r.toString(2).length,n=Math.ceil(e/8);return{nBitLength:e,nByteLength:n}}function wt(r,t,e=!1,n={}){if(r<=ct)throw new Error("invalid field: expected ORDER > 0, got "+r);let o,s;if(typeof t=="object"&&t!=null){if(n.sqrt||e)throw new Error("cannot specify opts in two arguments");let l=t;l.BITS&&(o=l.BITS),l.sqrt&&(s=l.sqrt),typeof l.isLE=="boolean"&&(e=l.isLE)}else typeof t=="number"&&(o=t),n.sqrt&&(s=n.sqrt);let{nBitLength:i,nByteLength:a}=Bi(r,o);if(a>2048)throw new Error("invalid field: expected ORDER of <= 2048 bytes");let u,c=Object.freeze({ORDER:r,isLE:e,BITS:i,BYTES:a,MASK:ne(i),ZERO:ct,ONE:Q,create:l=>j(l,r),isValid:l=>{if(typeof l!="bigint")throw new Error("invalid field element: expected bigint, got "+typeof l);return ct<=l&&l<r},is0:l=>l===ct,isValidNot0:l=>!c.is0(l)&&c.isValid(l),isOdd:l=>(l&Q)===Q,neg:l=>j(-l,r),eql:(l,f)=>l===f,sqr:l=>j(l*l,r),add:(l,f)=>j(l+f,r),sub:(l,f)=>j(l-f,r),mul:(l,f)=>j(l*f,r),pow:(l,f)=>Uu(c,l,f),div:(l,f)=>j(l*wi(f,r),r),sqrN:l=>l*l,addN:(l,f)=>l+f,subN:(l,f)=>l-f,mulN:(l,f)=>l*f,inv:l=>wi(l,r),sqrt:s||(l=>(u||(u=Nu(r)),u(c,l))),toBytes:l=>e?Be(l,a):Rr(l,a),fromBytes:l=>{if(l.length!==a)throw new Error("Field.fromBytes: expected "+a+" bytes, got "+l.length);return e?re(l):Ie(l)},invertBatch:l=>sr(c,l),cmov:(l,f,h)=>h?f:l});return Object.freeze(c)}function Ti(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 go(r){let t=Ti(r);return t+Math.ceil(t/2)}function Di(r,t,e=!1){let n=r.length,o=Ti(t),s=go(t);if(n<16||n<s||n>1024)throw new Error("expected "+s+"-1024 bytes of input, got "+n);let i=e?re(r):Ie(r),a=j(i,t-Q)+Q;return e?Be(a,o):Rr(a,o)}var Ce=BigInt(0),se=BigInt(1);function De(r,t){let e=t.negate();return r?e:t}function Or(r,t,e){let n=t==="pz"?i=>i.pz:i=>i.ez,o=sr(r.Fp,e.map(n));return e.map((i,a)=>i.toAffine(o[a])).map(r.fromAffine)}function Ri(r,t){if(!Number.isSafeInteger(r)||r<=0||r>t)throw new Error("invalid window size, expected [1.."+t+"], got W="+r)}function yo(r,t){Ri(r,t);let e=Math.ceil(t/r)+1,n=2**(r-1),o=2**r,s=ne(r),i=BigInt(r);return{windows:e,windowSize:n,mask:s,maxNumber:o,shiftBy:i}}function Ci(r,t,e){let{windowSize:n,mask:o,maxNumber:s,shiftBy:i}=e,a=Number(r&o),u=r>>i;a>n&&(a-=s,u+=se);let c=t*n,l=c+Math.abs(a)-1,f=a===0,h=a<0,m=t%2!==0;return{nextN:u,offset:l,isZero:f,isNeg:h,isNegF:m,offsetF:c}}function Mu(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 Fu(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 bo=new WeakMap,Oi=new WeakMap;function xo(r){return Oi.get(r)||1}function Li(r){if(r!==Ce)throw new Error("invalid wNAF")}function Nr(r,t){return{constTimeNegate:De,hasPrecomputes(e){return xo(e)!==1},unsafeLadder(e,n,o=r.ZERO){let s=e;for(;n>Ce;)n&se&&(o=o.add(s)),s=s.double(),n>>=se;return o},precomputeWindow(e,n){let{windows:o,windowSize:s}=yo(n,t),i=[],a=e,u=a;for(let c=0;c<o;c++){u=a,i.push(u);for(let l=1;l<s;l++)u=u.add(a),i.push(u);a=u.double()}return i},wNAF(e,n,o){let s=r.ZERO,i=r.BASE,a=yo(e,t);for(let u=0;u<a.windows;u++){let{nextN:c,offset:l,isZero:f,isNeg:h,isNegF:m,offsetF:b}=Ci(o,u,a);o=c,f?i=i.add(De(m,n[b])):s=s.add(De(h,n[l]))}return Li(o),{p:s,f:i}},wNAFUnsafe(e,n,o,s=r.ZERO){let i=yo(e,t);for(let a=0;a<i.windows&&o!==Ce;a++){let{nextN:u,offset:c,isZero:l,isNeg:f}=Ci(o,a,i);if(o=u,!l){let h=n[c];s=s.add(f?h.negate():h)}}return Li(o),s},getPrecomputes(e,n,o){let s=bo.get(n);return s||(s=this.precomputeWindow(n,e),e!==1&&(typeof o=="function"&&(s=o(s)),bo.set(n,s))),s},wNAFCached(e,n,o){let s=xo(e);return this.wNAF(s,this.getPrecomputes(s,e,o),n)},wNAFCachedUnsafe(e,n,o,s){let i=xo(e);return i===1?this.unsafeLadder(e,n,s):this.wNAFUnsafe(i,this.getPrecomputes(i,e,o),n,s)},setWindowSize(e,n){Ri(n,t),Oi.set(e,n),bo.delete(e)}}}function Ni(r,t,e,n){let o=t,s=r.ZERO,i=r.ZERO;for(;e>Ce||n>Ce;)e&se&&(s=s.add(o)),n&se&&(i=i.add(o)),o=o.double(),e>>=se,n>>=se;return{p1:s,p2:i}}function kr(r,t,e,n){Mu(e,r),Fu(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=bi(BigInt(o)),u=1;a>12?u=a-3:a>4?u=a-2:a>0&&(u=2);let c=ne(u),l=new Array(Number(c)+1).fill(i),f=Math.floor((t.BITS-1)/u)*u,h=i;for(let m=f;m>=0;m-=u){l.fill(i);for(let w=0;w<s;w++){let d=n[w],S=Number(d>>BigInt(m)&c);l[S]=l[S].add(e[w])}let b=i;for(let w=l.length-1,d=i;w>0;w--)d=d.add(l[w]),b=b.add(d);if(h=h.add(b),m!==0)for(let w=0;w<u;w++)h=h.double()}return h}function Pi(r,t){if(t){if(t.ORDER!==r)throw new Error("Field.ORDER must match order: Fp == p, Fn == n");return mo(t),t}else return wt(r)}function Ur(r,t,e={}){if(!t||typeof t!="object")throw new Error(`expected valid ${r} CURVE object`);for(let a of["p","n","h"]){let u=t[a];if(!(typeof u=="bigint"&&u>Ce))throw new Error(`CURVE.${a} must be positive bigint`)}let n=Pi(t.p,e.Fp),o=Pi(t.n,e.Fn),i=["Gx","Gy","a",r==="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 It=BigInt(0),ut=BigInt(1),wo=BigInt(2),Ku=BigInt(8),zu={zip215:!0};function qu(r,t,e,n){let o=r.sqr(e),s=r.sqr(n),i=r.add(r.mul(t.a,o),s),a=r.add(r.ONE,r.mul(t.d,r.mul(o,s)));return r.eql(i,a)}function Hu(r,t={}){let{Fp:e,Fn:n}=Ur("edwards",r,t),{h:o,n:s}=r;Zt(t,{},{uvRatio:"function"});let i=wo<<BigInt(n.BYTES*8)-ut,a=w=>e.create(w),u=t.uvRatio||((w,d)=>{try{return{isValid:!0,value:e.sqrt(e.div(w,d))}}catch{return{isValid:!1,value:It}}});if(!qu(e,r,r.Gx,r.Gy))throw new Error("bad curve params: generator point");function c(w,d,S=!1){let T=S?ut:It;return $t("coordinate "+w,d,T,i),d}function l(w){if(!(w instanceof m))throw new Error("ExtendedPoint expected")}let f=Te((w,d)=>{let{ex:S,ey:T,ez:v}=w,P=w.is0();d==null&&(d=P?Ku:e.inv(v));let y=a(S*d),L=a(T*d),C=a(v*d);if(P)return{x:It,y:ut};if(C!==ut)throw new Error("invZ was invalid");return{x:y,y:L}}),h=Te(w=>{let{a:d,d:S}=r;if(w.is0())throw new Error("bad point: ZERO");let{ex:T,ey:v,ez:P,et:y}=w,L=a(T*T),C=a(v*v),I=a(P*P),p=a(I*I),E=a(L*d),g=a(I*a(E+C)),x=a(p+a(S*a(L*C)));if(g!==x)throw new Error("bad point: equation left != right (1)");let _=a(T*v),B=a(P*y);if(_!==B)throw new Error("bad point: equation left != right (2)");return!0});class m{constructor(d,S,T,v){this.ex=c("x",d),this.ey=c("y",S),this.ez=c("z",T,!0),this.et=c("t",v),Object.freeze(this)}get x(){return this.toAffine().x}get y(){return this.toAffine().y}static fromAffine(d){if(d instanceof m)throw new Error("extended point not allowed");let{x:S,y:T}=d||{};return c("x",S),c("y",T),new m(S,T,ut,a(S*T))}static normalizeZ(d){return Or(m,"ez",d)}static msm(d,S){return kr(m,n,d,S)}_setWindowSize(d){this.precompute(d)}precompute(d=8,S=!0){return b.setWindowSize(this,d),S||this.multiply(wo),this}assertValidity(){h(this)}equals(d){l(d);let{ex:S,ey:T,ez:v}=this,{ex:P,ey:y,ez:L}=d,C=a(S*L),I=a(P*v),p=a(T*L),E=a(y*v);return C===I&&p===E}is0(){return this.equals(m.ZERO)}negate(){return new m(a(-this.ex),this.ey,this.ez,a(-this.et))}double(){let{a:d}=r,{ex:S,ey:T,ez:v}=this,P=a(S*S),y=a(T*T),L=a(wo*a(v*v)),C=a(d*P),I=S+T,p=a(a(I*I)-P-y),E=C+y,g=E-L,x=C-y,_=a(p*g),B=a(E*x),A=a(p*x),D=a(g*E);return new m(_,B,D,A)}add(d){l(d);let{a:S,d:T}=r,{ex:v,ey:P,ez:y,et:L}=this,{ex:C,ey:I,ez:p,et:E}=d,g=a(v*C),x=a(P*I),_=a(L*T*E),B=a(y*p),A=a((v+P)*(C+I)-g-x),D=B-_,O=B+_,R=a(x-S*g),$=a(A*D),U=a(O*R),N=a(A*R),Z=a(D*O);return new m($,U,Z,N)}subtract(d){return this.add(d.negate())}multiply(d){let S=d;$t("scalar",S,ut,s);let{p:T,f:v}=b.wNAFCached(this,S,m.normalizeZ);return m.normalizeZ([T,v])[0]}multiplyUnsafe(d,S=m.ZERO){let T=d;return $t("scalar",T,It,s),T===It?m.ZERO:this.is0()||T===ut?this:b.wNAFCachedUnsafe(this,T,m.normalizeZ,S)}isSmallOrder(){return this.multiplyUnsafe(o).is0()}isTorsionFree(){return b.wNAFCachedUnsafe(this,s).is0()}toAffine(d){return f(this,d)}clearCofactor(){return o===ut?this:this.multiplyUnsafe(o)}static fromBytes(d,S=!1){return nt(d),this.fromHex(d,S)}static fromHex(d,S=!1){let{d:T,a:v}=r,P=e.BYTES;d=q("pointHex",d,P),Ot("zip215",S);let y=d.slice(),L=d[P-1];y[P-1]=L&-129;let C=re(y),I=S?i:e.ORDER;$t("pointHex.y",C,It,I);let p=a(C*C),E=a(p-ut),g=a(T*p-v),{isValid:x,value:_}=u(E,g);if(!x)throw new Error("Point.fromHex: invalid y coordinate");let B=(_&ut)===ut,A=(L&128)!==0;if(!S&&_===It&&A)throw new Error("Point.fromHex: x=0 and x_0=1");return A!==B&&(_=a(-_)),m.fromAffine({x:_,y:C})}static fromPrivateScalar(d){return m.BASE.multiply(d)}toBytes(){let{x:d,y:S}=this.toAffine(),T=Be(S,e.BYTES);return T[T.length-1]|=d&ut?128:0,T}toRawBytes(){return this.toBytes()}toHex(){return vt(this.toBytes())}toString(){return`<Point ${this.is0()?"ZERO":this.toHex()}>`}}m.BASE=new m(r.Gx,r.Gy,ut,a(r.Gx*r.Gy)),m.ZERO=new m(It,ut,ut,It),m.Fp=e,m.Fn=n;let b=Nr(m,n.BYTES*8);return m}function Vu(r,t){Zt(t,{hash:"function"},{adjustScalarBytes:"function",randomBytes:"function",domain:"function",prehash:"function",mapToCurve:"function"});let{prehash:e,hash:n}=t,{BASE:o,Fp:s,Fn:i}=r,a=i.ORDER,u=t.randomBytes||tr,c=t.adjustScalarBytes||(y=>y),l=t.domain||((y,L,C)=>{if(Ot("phflag",C),L.length||C)throw new Error("Contexts/pre-hash are not supported");return y});function f(y){return i.create(y)}function h(y){return f(re(y))}function m(y){let L=s.BYTES;y=q("private key",y,L);let C=q("hashed private key",n(y),2*L),I=c(C.slice(0,L)),p=C.slice(L,2*L),E=h(I);return{head:I,prefix:p,scalar:E}}function b(y){let{head:L,prefix:C,scalar:I}=m(y),p=o.multiply(I),E=p.toBytes();return{head:L,prefix:C,scalar:I,point:p,pointBytes:E}}function w(y){return b(y).pointBytes}function d(y=Uint8Array.of(),...L){let C=pt(...L);return h(n(l(C,q("context",y),!!e)))}function S(y,L,C={}){y=q("message",y),e&&(y=e(y));let{prefix:I,scalar:p,pointBytes:E}=b(L),g=d(C.context,I,y),x=o.multiply(g).toBytes(),_=d(C.context,x,E,y),B=f(g+_*p);$t("signature.s",B,It,a);let A=s.BYTES,D=pt(x,Be(B,A));return q("result",D,A*2)}let T=zu;function v(y,L,C,I=T){let{context:p,zip215:E}=I,g=s.BYTES;y=q("signature",y,2*g),L=q("message",L),C=q("publicKey",C,g),E!==void 0&&Ot("zip215",E),e&&(L=e(L));let x=re(y.slice(g,2*g)),_,B,A;try{_=r.fromHex(C,E),B=r.fromHex(y.slice(0,g),E),A=o.multiplyUnsafe(x)}catch{return!1}if(!E&&_.isSmallOrder())return!1;let D=d(p,B.toBytes(),_.toBytes(),L);return B.add(_.multiplyUnsafe(D)).subtract(A).clearCofactor().is0()}return o.precompute(8),{getPublicKey:w,sign:S,verify:v,utils:{getExtendedPublicKey:b,randomPrivateKey:()=>u(s.BYTES),precompute(y=8,L=r.BASE){return L.precompute(y,!1)}},Point:r}}function ju(r){let t={a:r.a,d:r.d,p:r.Fp.ORDER,n:r.n,h:r.h,Gx:r.Gx,Gy:r.Gy},e=r.Fp,n=wt(t.n,r.nBitLength,!0),o={Fp:e,Fn:n,uvRatio:r.uvRatio},s={hash:r.hash,randomBytes:r.randomBytes,adjustScalarBytes:r.adjustScalarBytes,domain:r.domain,prehash:r.prehash,mapToCurve:r.mapToCurve};return{CURVE:t,curveOpts:o,eddsaOpts:s}}function Gu(r,t){return Object.assign({},t,{ExtendedPoint:t.Point,CURVE:r})}function ki(r){let{CURVE:t,curveOpts:e,eddsaOpts:n}=ju(r),o=Hu(t,e),s=Vu(o,n);return Gu(r,s)}var bp=BigInt(0),$u=BigInt(1),Ui=BigInt(2),xp=BigInt(3),Zu=BigInt(5),Wu=BigInt(8),Mr={p:BigInt("0x7fffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffed"),n:BigInt("0x1000000000000000000000000000000014def9dea2f79cd65812631a5cf5d3ed"),h:Wu,a:BigInt("0x7fffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffec"),d:BigInt("0x52036cee2b6ffe738cc740797779e89800700a4d4141d8ab75eb4dca135978a3"),Gx:BigInt("0x216936d3cd6e53fec0a4e231fdd6dc5c692cc7609525a7b2c9562d608f25d51a"),Gy:BigInt("0x6666666666666666666666666666666666666666666666666666666666666658")};function Yu(r){let t=BigInt(10),e=BigInt(20),n=BigInt(40),o=BigInt(80),s=Mr.p,a=r*r%s*r%s,u=H(a,Ui,s)*a%s,c=H(u,$u,s)*r%s,l=H(c,Zu,s)*c%s,f=H(l,t,s)*l%s,h=H(f,e,s)*f%s,m=H(h,n,s)*h%s,b=H(m,o,s)*m%s,w=H(b,o,s)*m%s,d=H(w,t,s)*l%s;return{pow_p_5_8:H(d,Ui,s)*r%s,b2:a}}function Xu(r){return r[0]&=248,r[31]&=127,r[31]|=64,r}var Mi=BigInt("19681161376707505956807079304988542015446066515923890162744021073123829784752");function Qu(r,t){let e=Mr.p,n=j(t*t*t,e),o=j(n*n*t,e),s=Yu(r*o).pow_p_5_8,i=j(r*n*s,e),a=j(t*i*i,e),u=i,c=j(i*Mi,e),l=a===r,f=a===j(-r,e),h=a===j(-r*Mi,e);return l&&(i=u),(f||h)&&(i=c),Ii(i,e)&&(i=j(-i,e)),{isValid:l||f,value:i}}var Ju=wt(Mr.p,void 0,!0),tf={...Mr,Fp:Ju,hash:mi,adjustScalarBytes:Xu,uvRatio:Qu},Fi=ki(tf);var ir=class extends Error{constructor(t="An error occurred while verifying a message"){super(t),this.name="VerificationError"}},Fr=class extends Error{constructor(t="Missing Web Crypto API"){super(t),this.name="WebCryptoMissingError"}};var Ki={get(r=globalThis){let t=r.crypto;if(t?.subtle==null)throw new Fr("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 Kr=Ki;var zr=32;var Eo,ef=(async()=>{try{return await Kr.get().subtle.generateKey({name:"Ed25519"},!0,["sign","verify"]),!0}catch{return!1}})();async function rf(r,t,e){if(r.buffer instanceof ArrayBuffer){let n=await Kr.get().subtle.importKey("raw",r.buffer,{name:"Ed25519"},!1,["verify"]);return await Kr.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 nf(r,t,e){return Fi.verify(t,e instanceof Uint8Array?e:e.subarray(),r)}async function zi(r,t,e){return Eo==null&&(Eo=await ef),Eo?rf(r,t,e):nf(r,t,e)}function qr(r){return r==null?!1:typeof r.then=="function"&&typeof r.catch=="function"&&typeof r.finally=="function"}var Hr=class{type="Ed25519";raw;constructor(t){this.raw=_o(t,zr)}toMultihash(){return yt.digest(Ee(this))}toCID(){return X.createV1(114,this.toMultihash())}toString(){return V.encode(this.toMultihash().bytes).substring(1)}equals(t){return t==null||!(t.raw instanceof Uint8Array)?!1:at(this.raw,t.raw)}verify(t,e,n){n?.signal?.throwIfAborted();let o=zi(this.raw,e,t);return qr(o)?o.then(s=>(n?.signal?.throwIfAborted(),s)):o}};function Hi(r){return r=_o(r,zr),new Hr(r)}function _o(r,t){if(r=Uint8Array.from(r??[]),r.length!==t)throw new Tt(`Key must be a Uint8Array of length ${t}, got ${r.length}`);return r}var sf=Math.pow(2,7),af=Math.pow(2,14),cf=Math.pow(2,21),So=Math.pow(2,28),vo=Math.pow(2,35),Ao=Math.pow(2,42),Io=Math.pow(2,49),k=128,ot=127;function lt(r){if(r<sf)return 1;if(r<af)return 2;if(r<cf)return 3;if(r<So)return 4;if(r<vo)return 5;if(r<Ao)return 6;if(r<Io)return 7;if(Number.MAX_SAFE_INTEGER!=null&&r>Number.MAX_SAFE_INTEGER)throw new RangeError("Could not encode varint");return 8}function Le(r,t,e=0){switch(lt(r)){case 8:t[e++]=r&255|k,r/=128;case 7:t[e++]=r&255|k,r/=128;case 6:t[e++]=r&255|k,r/=128;case 5:t[e++]=r&255|k,r/=128;case 4:t[e++]=r&255|k,r>>>=7;case 3:t[e++]=r&255|k,r>>>=7;case 2:t[e++]=r&255|k,r>>>=7;case 1:{t[e++]=r&255,r>>>=7;break}default:throw new Error("unreachable")}return t}function uf(r,t,e=0){switch(lt(r)){case 8:t.set(e++,r&255|k),r/=128;case 7:t.set(e++,r&255|k),r/=128;case 6:t.set(e++,r&255|k),r/=128;case 5:t.set(e++,r&255|k),r/=128;case 4:t.set(e++,r&255|k),r>>>=7;case 3:t.set(e++,r&255|k),r>>>=7;case 2:t.set(e++,r&255|k),r>>>=7;case 1:{t.set(e++,r&255),r>>>=7;break}default:throw new Error("unreachable")}return t}function Bo(r,t){let e=r[t],n=0;if(n+=e&ot,e<k||(e=r[t+1],n+=(e&ot)<<7,e<k)||(e=r[t+2],n+=(e&ot)<<14,e<k)||(e=r[t+3],n+=(e&ot)<<21,e<k)||(e=r[t+4],n+=(e&ot)*So,e<k)||(e=r[t+5],n+=(e&ot)*vo,e<k)||(e=r[t+6],n+=(e&ot)*Ao,e<k)||(e=r[t+7],n+=(e&ot)*Io,e<k))return n;throw new RangeError("Could not decode varint")}function ff(r,t){let e=r.get(t),n=0;if(n+=e&ot,e<k||(e=r.get(t+1),n+=(e&ot)<<7,e<k)||(e=r.get(t+2),n+=(e&ot)<<14,e<k)||(e=r.get(t+3),n+=(e&ot)<<21,e<k)||(e=r.get(t+4),n+=(e&ot)*So,e<k)||(e=r.get(t+5),n+=(e&ot)*vo,e<k)||(e=r.get(t+6),n+=(e&ot)*Ao,e<k)||(e=r.get(t+7),n+=(e&ot)*Io,e<k))return n;throw new RangeError("Could not decode varint")}function Vi(r,t,e=0){return t==null&&(t=ft(lt(r))),t instanceof Uint8Array?Le(r,t,e):uf(r,t,e)}function ar(r,t=0){return r instanceof Uint8Array?Bo(r,t):ff(r,t)}var To=new Float32Array([-0]),Wt=new Uint8Array(To.buffer);function Gi(r,t,e){To[0]=r,t[e]=Wt[0],t[e+1]=Wt[1],t[e+2]=Wt[2],t[e+3]=Wt[3]}function $i(r,t){return Wt[0]=r[t],Wt[1]=r[t+1],Wt[2]=r[t+2],Wt[3]=r[t+3],To[0]}var Do=new Float64Array([-0]),st=new Uint8Array(Do.buffer);function Zi(r,t,e){Do[0]=r,t[e]=st[0],t[e+1]=st[1],t[e+2]=st[2],t[e+3]=st[3],t[e+4]=st[4],t[e+5]=st[5],t[e+6]=st[6],t[e+7]=st[7]}function Wi(r,t){return st[0]=r[t],st[1]=r[t+1],st[2]=r[t+2],st[3]=r[t+3],st[4]=r[t+4],st[5]=r[t+5],st[6]=r[t+6],st[7]=r[t+7],Do[0]}var lf=BigInt(Number.MAX_SAFE_INTEGER),hf=BigInt(Number.MIN_SAFE_INTEGER),mt=class r{lo;hi;constructor(t,e){this.lo=t|0,this.hi=e|0}toNumber(t=!1){if(!t&&this.hi>>>31>0){let e=~this.lo+1>>>0,n=~this.hi>>>0;return e===0&&(n=n+1>>>0),-(e+n*4294967296)}return this.lo+this.hi*4294967296}toBigInt(t=!1){if(t)return BigInt(this.lo>>>0)+(BigInt(this.hi>>>0)<<32n);if(this.hi>>>31){let e=~this.lo+1>>>0,n=~this.hi>>>0;return e===0&&(n=n+1>>>0),-(BigInt(e)+(BigInt(n)<<32n))}return BigInt(this.lo>>>0)+(BigInt(this.hi>>>0)<<32n)}toString(t=!1){return this.toBigInt(t).toString()}zzEncode(){let t=this.hi>>31;return this.hi=((this.hi<<1|this.lo>>>31)^t)>>>0,this.lo=(this.lo<<1^t)>>>0,this}zzDecode(){let t=-(this.lo&1);return this.lo=((this.lo>>>1|this.hi<<31)^t)>>>0,this.hi=(this.hi>>>1^t)>>>0,this}length(){let t=this.lo,e=(this.lo>>>28|this.hi<<4)>>>0,n=this.hi>>>24;return n===0?e===0?t<16384?t<128?1:2:t<2097152?3:4:e<16384?e<128?5:6:e<2097152?7:8:n<128?9:10}static fromBigInt(t){if(t===0n)return ie;if(t<lf&&t>hf)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>Yi&&(o=0n,++n>Yi&&(n=0n))),new r(Number(o),Number(n))}static fromNumber(t){if(t===0)return ie;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):ie}},ie=new mt(0,0);ie.toBigInt=function(){return 0n};ie.zzEncode=ie.zzDecode=function(){return this};ie.length=function(){return 1};var Yi=4294967296n;function Xi(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 Qi(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 Co(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 Et(r,t){return RangeError(`index out of range: ${r.pos} + ${t??1} > ${r.len}`)}function Vr(r,t){return(r[t-4]|r[t-3]<<8|r[t-2]<<16|r[t-1]<<24)>>>0}var Lo=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,Et(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 Et(this,4);return Vr(this.buf,this.pos+=4)}sfixed32(){if(this.pos+4>this.len)throw Et(this,4);return Vr(this.buf,this.pos+=4)|0}float(){if(this.pos+4>this.len)throw Et(this,4);let t=$i(this.buf,this.pos);return this.pos+=4,t}double(){if(this.pos+8>this.len)throw Et(this,4);let t=Wi(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 Et(this,t);return this.pos+=t,e===n?new Uint8Array(0):this.buf.subarray(e,n)}string(){let t=this.bytes();return Qi(t,0,t.length)}skip(t){if(typeof t=="number"){if(this.pos+t>this.len)throw Et(this,t);this.pos+=t}else do if(this.pos>=this.len)throw Et(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 mt(0,0),e=0;if(this.len-this.pos>4){for(;e<4;++e)if(t.lo=(t.lo|(this.buf[this.pos]&127)<<e*7)>>>0,this.buf[this.pos++]<128)return t;if(t.lo=(t.lo|(this.buf[this.pos]&127)<<28)>>>0,t.hi=(t.hi|(this.buf[this.pos]&127)>>4)>>>0,this.buf[this.pos++]<128)return t;e=0}else{for(;e<3;++e){if(this.pos>=this.len)throw Et(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 Et(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 Et(this,8);let t=Vr(this.buf,this.pos+=4),e=Vr(this.buf,this.pos+=4);return new mt(t,e)}int64(){return this.readLongVarint().toBigInt()}int64Number(){return this.readLongVarint().toNumber()}int64String(){return this.readLongVarint().toString()}uint64(){return this.readLongVarint().toBigInt(!0)}uint64Number(){let t=Bo(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 Po(r){return new Lo(r instanceof Uint8Array?r:r.subarray())}function Nt(r,t,e){let n=Po(r);return t.decode(n,void 0,e)}function Ro(r){let t=r??8192,e=t>>>1,n,o=t;return function(i){if(i<1||i>e)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 ae=class{fn;len;next;val;constructor(t,e,n){this.fn=t,this.len=e,this.next=void 0,this.val=n}};function Oo(){}var ko=class{head;tail;len;next;constructor(t){this.head=t.head,this.tail=t.tail,this.len=t.len,this.next=t.states}},df=Ro();function pf(r){return globalThis.Buffer!=null?ft(r):df(r)}var ur=class{len;head;tail;states;constructor(){this.len=0,this.head=new ae(Oo,0,0),this.tail=this.head,this.states=null}_push(t,e,n){return this.tail=this.tail.next=new ae(t,e,n),this.len+=e,this}uint32(t){return this.len+=(this.tail=this.tail.next=new Uo((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(jr,10,mt.fromNumber(t)):this.uint32(t)}sint32(t){return this.uint32((t<<1^t>>31)>>>0)}uint64(t){let e=mt.fromBigInt(t);return this._push(jr,e.length(),e)}uint64Number(t){return this._push(Le,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=mt.fromBigInt(t).zzEncode();return this._push(jr,e.length(),e)}sint64Number(t){let e=mt.fromNumber(t).zzEncode();return this._push(jr,e.length(),e)}sint64String(t){return this.sint64(BigInt(t))}bool(t){return this._push(No,1,t?1:0)}fixed32(t){return this._push(cr,4,t>>>0)}sfixed32(t){return this.fixed32(t)}fixed64(t){let e=mt.fromBigInt(t);return this._push(cr,4,e.lo)._push(cr,4,e.hi)}fixed64Number(t){let e=mt.fromNumber(t);return this._push(cr,4,e.lo)._push(cr,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(Gi,4,t)}double(t){return this._push(Zi,8,t)}bytes(t){let e=t.length>>>0;return e===0?this._push(No,1,0):this.uint32(e)._push(gf,e,t)}string(t){let e=Xi(t);return e!==0?this.uint32(e)._push(Co,e,t):this._push(No,1,0)}fork(){return this.states=new ko(this),this.head=this.tail=new ae(Oo,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 ae(Oo,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=pf(this.len),n=0;for(;t!=null;)t.fn(t.val,e,n),n+=t.len,t=t.next;return e}};function No(r,t,e){t[e]=r&255}function mf(r,t,e){for(;r>127;)t[e++]=r&127|128,r>>>=7;t[e]=r}var Uo=class extends ae{next;constructor(t,e){super(mf,t,e),this.next=void 0}};function jr(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 cr(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 gf(r,t,e){t.set(r,e)}globalThis.Buffer!=null&&(ur.prototype.bytes=function(r){let t=r.length>>>0;return this.uint32(t),t>0&&this._push(yf,t,r),this},ur.prototype.string=function(r){let t=globalThis.Buffer.byteLength(r);return this.uint32(t),t>0&&this._push(bf,t,r),this});function yf(r,t,e){t.set(r,e)}function bf(r,t,e){r.length<40?Co(r,t,e):t.utf8Write!=null?t.utf8Write(r,e):t.set(M(r),e)}function Mo(){return new ur}function kt(r,t){let e=Mo();return t.encode(r,e,{lengthDelimited:!1}),e.finish()}var Pe;(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"})(Pe||(Pe={}));function Gr(r,t,e,n){return{name:r,type:t,encode:e,decode:n}}function Re(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 Gr("enum",Pe.VARINT,e,n)}function Ut(r,t){return Gr("message",Pe.LENGTH_DELIMITED,r,t)}var $r=class extends Error{code="ERR_MAX_LENGTH";name="MaxLengthError"};var gt;(function(r){r.RSA="RSA",r.Ed25519="Ed25519",r.secp256k1="secp256k1",r.ECDSA="ECDSA"})(gt||(gt={}));var Fo;(function(r){r[r.RSA=0]="RSA",r[r.Ed25519=1]="Ed25519",r[r.secp256k1=2]="secp256k1",r[r.ECDSA=3]="ECDSA"})(Fo||(Fo={}));(function(r){r.codec=()=>Re(Fo)})(gt||(gt={}));var fr;(function(r){let t;r.codec=()=>(t==null&&(t=Ut((e,n,o={})=>{o.lengthDelimited!==!1&&n.fork(),e.Type!=null&&(n.uint32(8),gt.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=gt.codec().decode(e);break}case 2:{s.Data=e.bytes();break}default:{e.skipType(a&7);break}}}return s})),t),r.encode=e=>kt(e,r.codec()),r.decode=(e,n)=>Nt(e,r.codec(),n)})(fr||(fr={}));var Ko;(function(r){let t;r.codec=()=>(t==null&&(t=Ut((e,n,o={})=>{o.lengthDelimited!==!1&&n.fork(),e.Type!=null&&(n.uint32(8),gt.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=gt.codec().decode(e);break}case 2:{s.Data=e.bytes();break}default:{e.skipType(a&7);break}}}return s})),t),r.encode=e=>kt(e,r.codec()),r.decode=(e,n)=>Nt(e,r.codec(),n)})(Ko||(Ko={}));var Zr=class extends _e{constructor(t,e){super(),this.finished=!1,this.destroyed=!1,Js(t);let n=Je(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),Pt(s)}update(t){return ve(this),this.iHash.update(t),this}digestInto(t){ve(this),nt(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()}},zo=(r,t,e)=>new Zr(r,t).update(e).digest();zo.create=(r,t)=>new Zr(r,t);function ta(r){r.lowS!==void 0&&Ot("lowS",r.lowS),r.prehash!==void 0&&Ot("prehash",r.prehash)}var qo=class extends Error{constructor(t=""){super(t)}},Mt={Err:qo,_tlv:{encode:(r,t)=>{let{Err:e}=Mt;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=or(n);if(o.length/2&128)throw new e("tlv.encode: long form length too big");let s=n>127?or(o.length/2|128):"";return or(r)+s+o+t},decode(r,t){let{Err:e}=Mt,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 u=o&127;if(!u)throw new e("tlv.decode(long): indefinite length not supported");if(u>4)throw new e("tlv.decode(long): byte length is too big");let c=t.subarray(n,n+u);if(c.length!==u)throw new e("tlv.decode: length bytes not complete");if(c[0]===0)throw new e("tlv.decode(long): zero leftmost byte");for(let l of c)i=i<<8|l;if(n+=u,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}=Mt;if(r<lr)throw new t("integer: negative integers are not allowed");let e=or(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}=Mt;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 Ie(r)}},toSig(r){let{Err:t,_int:e,_tlv:n}=Mt,o=q("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:u}=n.decode(2,s),{v:c,l}=n.decode(2,u);if(l.length)throw new t("invalid signature: left bytes after parsing");return{r:e.decode(a),s:e.decode(c)}},hexFromSig(r){let{_tlv:t,_int:e}=Mt,n=t.encode(2,e.encode(r.r)),o=t.encode(2,e.encode(r.s)),s=n+o;return t.encode(48,s)}},lr=BigInt(0),hr=BigInt(1),wf=BigInt(2),Wr=BigInt(3),Ef=BigInt(4);function _f(r,t,e){function n(o){let s=r.sqr(o),i=r.mul(s,o);return r.add(r.add(i,r.mul(o,t)),e)}return n}function ea(r,t,e){let{BYTES:n}=r;function o(s){let i;if(typeof s=="bigint")i=s;else{let a=q("private key",s);if(t){if(!t.includes(a.length*2))throw new Error("invalid private key");let u=new Uint8Array(n);u.set(a,u.length-a.length),a=u}try{i=r.fromBytes(a)}catch{throw new Error(`invalid private key: expected ui8a of size ${n}, got ${typeof s}`)}}if(e&&(i=r.create(i)),!r.isValidNot0(i))throw new Error("invalid private key: out of range [1..N-1]");return i}return o}function Sf(r,t={}){let{Fp:e,Fn:n}=Ur("weierstrass",r,t),{h:o,n:s}=r;Zt(t,{},{allowInfinityPoint:"boolean",clearCofactor:"function",isTorsionFree:"function",fromBytes:"function",toBytes:"function",endo:"object",wrapPrivateKey:"boolean"});let{endo:i}=t;if(i&&(!e.is0(r.a)||typeof i.beta!="bigint"||typeof i.splitScalar!="function"))throw new Error('invalid endo: expected "beta": bigint and "splitScalar": function');function a(){if(!e.isOdd)throw new Error("compression is not supported: Field does not have .isOdd()")}function u(I,p,E){let{x:g,y:x}=p.toAffine(),_=e.toBytes(g);if(Ot("isCompressed",E),E){a();let B=!e.isOdd(x);return pt(ra(B),_)}else return pt(Uint8Array.of(4),_,e.toBytes(x))}function c(I){nt(I);let p=e.BYTES,E=p+1,g=2*p+1,x=I.length,_=I[0],B=I.subarray(1);if(x===E&&(_===2||_===3)){let A=e.fromBytes(B);if(!e.isValid(A))throw new Error("bad point: is not on curve, wrong x");let D=h(A),O;try{O=e.sqrt(D)}catch(U){let N=U instanceof Error?": "+U.message:"";throw new Error("bad point: is not on curve, sqrt error"+N)}a();let R=e.isOdd(O);return(_&1)===1!==R&&(O=e.neg(O)),{x:A,y:O}}else if(x===g&&_===4){let A=e.fromBytes(B.subarray(p*0,p*1)),D=e.fromBytes(B.subarray(p*1,p*2));if(!m(A,D))throw new Error("bad point: is not on curve");return{x:A,y:D}}else throw new Error(`bad point: got length ${x}, expected compressed=${E} or uncompressed=${g}`)}let l=t.toBytes||u,f=t.fromBytes||c,h=_f(e,r.a,r.b);function m(I,p){let E=e.sqr(p),g=h(I);return e.eql(E,g)}if(!m(r.Gx,r.Gy))throw new Error("bad curve params: generator point");let b=e.mul(e.pow(r.a,Wr),Ef),w=e.mul(e.sqr(r.b),BigInt(27));if(e.is0(e.add(b,w)))throw new Error("bad curve params: a or b");function d(I,p,E=!1){if(!e.isValid(p)||E&&e.is0(p))throw new Error(`bad point coordinate ${I}`);return p}function S(I){if(!(I instanceof y))throw new Error("ProjectivePoint expected")}let T=Te((I,p)=>{let{px:E,py:g,pz:x}=I;if(e.eql(x,e.ONE))return{x:E,y:g};let _=I.is0();p==null&&(p=_?e.ONE:e.inv(x));let B=e.mul(E,p),A=e.mul(g,p),D=e.mul(x,p);if(_)return{x:e.ZERO,y:e.ZERO};if(!e.eql(D,e.ONE))throw new Error("invZ was invalid");return{x:B,y:A}}),v=Te(I=>{if(I.is0()){if(t.allowInfinityPoint&&!e.is0(I.py))return;throw new Error("bad point: ZERO")}let{x:p,y:E}=I.toAffine();if(!e.isValid(p)||!e.isValid(E))throw new Error("bad point: x or y not field elements");if(!m(p,E))throw new Error("bad point: equation left != right");if(!I.isTorsionFree())throw new Error("bad point: not in prime-order subgroup");return!0});function P(I,p,E,g,x){return E=new y(e.mul(E.px,I),E.py,E.pz),p=De(g,p),E=De(x,E),p.add(E)}class y{constructor(p,E,g){this.px=d("x",p),this.py=d("y",E,!0),this.pz=d("z",g),Object.freeze(this)}static fromAffine(p){let{x:E,y:g}=p||{};if(!p||!e.isValid(E)||!e.isValid(g))throw new Error("invalid affine point");if(p instanceof y)throw new Error("projective point not allowed");return e.is0(E)&&e.is0(g)?y.ZERO:new y(E,g,e.ONE)}get x(){return this.toAffine().x}get y(){return this.toAffine().y}static normalizeZ(p){return Or(y,"pz",p)}static fromBytes(p){return nt(p),y.fromHex(p)}static fromHex(p){let E=y.fromAffine(f(q("pointHex",p)));return E.assertValidity(),E}static fromPrivateKey(p){let E=ea(n,t.allowedPrivateKeyLengths,t.wrapPrivateKey);return y.BASE.multiply(E(p))}static msm(p,E){return kr(y,n,p,E)}precompute(p=8,E=!0){return C.setWindowSize(this,p),E||this.multiply(Wr),this}_setWindowSize(p){this.precompute(p)}assertValidity(){v(this)}hasEvenY(){let{y:p}=this.toAffine();if(!e.isOdd)throw new Error("Field doesn't support isOdd");return!e.isOdd(p)}equals(p){S(p);let{px:E,py:g,pz:x}=this,{px:_,py:B,pz:A}=p,D=e.eql(e.mul(E,A),e.mul(_,x)),O=e.eql(e.mul(g,A),e.mul(B,x));return D&&O}negate(){return new y(this.px,e.neg(this.py),this.pz)}double(){let{a:p,b:E}=r,g=e.mul(E,Wr),{px:x,py:_,pz:B}=this,A=e.ZERO,D=e.ZERO,O=e.ZERO,R=e.mul(x,x),$=e.mul(_,_),U=e.mul(B,B),N=e.mul(x,_);return N=e.add(N,N),O=e.mul(x,B),O=e.add(O,O),A=e.mul(p,O),D=e.mul(g,U),D=e.add(A,D),A=e.sub($,D),D=e.add($,D),D=e.mul(A,D),A=e.mul(N,A),O=e.mul(g,O),U=e.mul(p,U),N=e.sub(R,U),N=e.mul(p,N),N=e.add(N,O),O=e.add(R,R),R=e.add(O,R),R=e.add(R,U),R=e.mul(R,N),D=e.add(D,R),U=e.mul(_,B),U=e.add(U,U),R=e.mul(U,N),A=e.sub(A,R),O=e.mul(U,$),O=e.add(O,O),O=e.add(O,O),new y(A,D,O)}add(p){S(p);let{px:E,py:g,pz:x}=this,{px:_,py:B,pz:A}=p,D=e.ZERO,O=e.ZERO,R=e.ZERO,$=r.a,U=e.mul(r.b,Wr),N=e.mul(E,_),Z=e.mul(g,B),Y=e.mul(x,A),rt=e.add(E,g),F=e.add(_,B);rt=e.mul(rt,F),F=e.add(N,Z),rt=e.sub(rt,F),F=e.add(E,x);let it=e.add(_,A);return F=e.mul(F,it),it=e.add(N,Y),F=e.sub(F,it),it=e.add(g,x),D=e.add(B,A),it=e.mul(it,D),D=e.add(Z,Y),it=e.sub(it,D),R=e.mul($,F),D=e.mul(U,Y),R=e.add(D,R),D=e.sub(Z,R),R=e.add(Z,R),O=e.mul(D,R),Z=e.add(N,N),Z=e.add(Z,N),Y=e.mul($,Y),F=e.mul(U,F),Z=e.add(Z,Y),Y=e.sub(N,Y),Y=e.mul($,Y),F=e.add(F,Y),N=e.mul(Z,F),O=e.add(O,N),N=e.mul(it,F),D=e.mul(rt,D),D=e.sub(D,N),N=e.mul(rt,Z),R=e.mul(it,R),R=e.add(R,N),new y(D,O,R)}subtract(p){return this.add(p.negate())}is0(){return this.equals(y.ZERO)}multiply(p){let{endo:E}=t;if(!n.isValidNot0(p))throw new Error("invalid scalar: out of range");let g,x,_=B=>C.wNAFCached(this,B,y.normalizeZ);if(E){let{k1neg:B,k1:A,k2neg:D,k2:O}=E.splitScalar(p),{p:R,f:$}=_(A),{p:U,f:N}=_(O);x=$.add(N),g=P(E.beta,R,U,B,D)}else{let{p:B,f:A}=_(p);g=B,x=A}return y.normalizeZ([g,x])[0]}multiplyUnsafe(p){let{endo:E}=t,g=this;if(!n.isValid(p))throw new Error("invalid scalar: out of range");if(p===lr||g.is0())return y.ZERO;if(p===hr)return g;if(C.hasPrecomputes(this))return this.multiply(p);if(E){let{k1neg:x,k1:_,k2neg:B,k2:A}=E.splitScalar(p),{p1:D,p2:O}=Ni(y,g,_,A);return P(E.beta,D,O,x,B)}else return C.wNAFCachedUnsafe(g,p)}multiplyAndAddUnsafe(p,E,g){let x=this.multiplyUnsafe(E).add(p.multiplyUnsafe(g));return x.is0()?void 0:x}toAffine(p){return T(this,p)}isTorsionFree(){let{isTorsionFree:p}=t;return o===hr?!0:p?p(y,this):C.wNAFCachedUnsafe(this,s).is0()}clearCofactor(){let{clearCofactor:p}=t;return o===hr?this:p?p(y,this):this.multiplyUnsafe(o)}toBytes(p=!0){return Ot("isCompressed",p),this.assertValidity(),l(y,this,p)}toRawBytes(p=!0){return this.toBytes(p)}toHex(p=!0){return vt(this.toBytes(p))}toString(){return`<Point ${this.is0()?"ZERO":this.toHex()}>`}}y.BASE=new y(r.Gx,r.Gy,e.ONE),y.ZERO=new y(e.ZERO,e.ONE,e.ZERO),y.Fp=e,y.Fn=n;let L=n.BITS,C=Nr(y,t.endo?Math.ceil(L/2):L);return y}function ra(r){return Uint8Array.of(r?2:3)}function vf(r,t,e={}){Zt(t,{hash:"function"},{hmac:"function",lowS:"boolean",randomBytes:"function",bits2int:"function",bits2int_modN:"function"});let n=t.randomBytes||tr,o=t.hmac||((g,...x)=>zo(t.hash,g,pt(...x))),{Fp:s,Fn:i}=r,{ORDER:a,BITS:u}=i;function c(g){let x=a>>hr;return g>x}function l(g){return c(g)?i.neg(g):g}function f(g,x){if(!i.isValidNot0(x))throw new Error(`invalid signature ${g}: out of range 1..CURVE.n`)}class h{constructor(x,_,B){f("r",x),f("s",_),this.r=x,this.s=_,B!=null&&(this.recovery=B),Object.freeze(this)}static fromCompact(x){let _=i.BYTES,B=q("compactSignature",x,_*2);return new h(i.fromBytes(B.subarray(0,_)),i.fromBytes(B.subarray(_,_*2)))}static fromDER(x){let{r:_,s:B}=Mt.toSig(q("DER",x));return new h(_,B)}assertValidity(){}addRecoveryBit(x){return new h(this.r,this.s,x)}recoverPublicKey(x){let _=s.ORDER,{r:B,s:A,recovery:D}=this;if(D==null||![0,1,2,3].includes(D))throw new Error("recovery id invalid");if(a*wf<_&&D>1)throw new Error("recovery id is ambiguous for h>1 curve");let R=D===2||D===3?B+a:B;if(!s.isValid(R))throw new Error("recovery id 2 or 3 invalid");let $=s.toBytes(R),U=r.fromHex(pt(ra((D&1)===0),$)),N=i.inv(R),Z=v(q("msgHash",x)),Y=i.create(-Z*N),rt=i.create(A*N),F=r.BASE.multiplyUnsafe(Y).add(U.multiplyUnsafe(rt));if(F.is0())throw new Error("point at infinify");return F.assertValidity(),F}hasHighS(){return c(this.s)}normalizeS(){return this.hasHighS()?new h(this.r,i.neg(this.s),this.recovery):this}toBytes(x){if(x==="compact")return pt(i.toBytes(this.r),i.toBytes(this.s));if(x==="der")return Ae(Mt.hexFromSig(this));throw new Error("invalid format")}toDERRawBytes(){return this.toBytes("der")}toDERHex(){return vt(this.toBytes("der"))}toCompactRawBytes(){return this.toBytes("compact")}toCompactHex(){return vt(this.toBytes("compact"))}}let m=ea(i,e.allowedPrivateKeyLengths,e.wrapPrivateKey),b={isValidPrivateKey(g){try{return m(g),!0}catch{return!1}},normPrivateKeyToScalar:m,randomPrivateKey:()=>{let g=a;return Di(n(go(g)),g)},precompute(g=8,x=r.BASE){return x.precompute(g,!1)}};function w(g,x=!0){return r.fromPrivateKey(g).toBytes(x)}function d(g){if(typeof g=="bigint")return!1;if(g instanceof r)return!0;let _=q("key",g).length,B=s.BYTES,A=B+1,D=2*B+1;if(!(e.allowedPrivateKeyLengths||i.BYTES===A))return _===A||_===D}function S(g,x,_=!0){if(d(g)===!0)throw new Error("first arg must be private key");if(d(x)===!1)throw new Error("second arg must be public key");return r.fromHex(x).multiply(m(g)).toBytes(_)}let T=t.bits2int||function(g){if(g.length>8192)throw new Error("input is too large");let x=Ie(g),_=g.length*8-u;return _>0?x>>BigInt(_):x},v=t.bits2int_modN||function(g){return i.create(T(g))},P=ne(u);function y(g){return $t("num < 2^"+u,g,lr,P),i.toBytes(g)}function L(g,x,_=C){if(["recovered","canonical"].some(rt=>rt in _))throw new Error("sign() legacy options not supported");let{hash:B}=t,{lowS:A,prehash:D,extraEntropy:O}=_;A==null&&(A=!0),g=q("msgHash",g),ta(_),D&&(g=q("prehashed msgHash",B(g)));let R=v(g),$=m(x),U=[y($),y(R)];if(O!=null&&O!==!1){let rt=O===!0?n(s.BYTES):O;U.push(q("extraEntropy",rt))}let N=pt(...U),Z=R;function Y(rt){let F=T(rt);if(!i.isValidNot0(F))return;let it=i.inv(F),qe=r.BASE.multiply(F).toAffine(),pe=i.create(qe.x);if(pe===lr)return;let Yt=i.create(it*i.create(Z+pe*$));if(Yt===lr)return;let Cn=(qe.x===pe?0:2)|Number(qe.y&hr),me=Yt;return A&&c(Yt)&&(me=l(Yt),Cn^=1),new h(pe,me,Cn)}return{seed:N,k2sig:Y}}let C={lowS:t.lowS,prehash:!1},I={lowS:t.lowS,prehash:!1};function p(g,x,_=C){let{seed:B,k2sig:A}=L(g,x,_);return xi(t.hash.outputLen,i.BYTES,o)(B,A)}r.BASE.precompute(8);function E(g,x,_,B=I){let A=g;x=q("msgHash",x),_=q("publicKey",_),ta(B);let{lowS:D,prehash:O,format:R}=B;if("strict"in B)throw new Error("options.strict was renamed to lowS");if(R!==void 0&&!["compact","der","js"].includes(R))throw new Error('format must be "compact", "der" or "js"');let $=typeof A=="string"||Se(A),U=!$&&!R&&typeof A=="object"&&A!==null&&typeof A.r=="bigint"&&typeof A.s=="bigint";if(!$&&!U)throw new Error("invalid signature, expected Uint8Array, hex string or Signature instance");let N,Z;try{if(U)if(R===void 0||R==="js")N=new h(A.r,A.s);else throw new Error("invalid format");if($){try{R!=="compact"&&(N=h.fromDER(A))}catch(me){if(!(me instanceof Mt.Err))throw me}!N&&R!=="der"&&(N=h.fromCompact(A))}Z=r.fromHex(_)}catch{return!1}if(!N||D&&N.hasHighS())return!1;O&&(x=t.hash(x));let{r:Y,s:rt}=N,F=v(x),it=i.inv(rt),qe=i.create(F*it),pe=i.create(Y*it),Yt=r.BASE.multiplyUnsafe(qe).add(Z.multiplyUnsafe(pe));return Yt.is0()?!1:i.create(Yt.x)===Y}return Object.freeze({getPublicKey:w,getSharedSecret:S,sign:p,verify:E,utils:b,Point:r,Signature:h})}function Af(r){let t={a:r.a,b:r.b,p:r.Fp.ORDER,n:r.n,h:r.h,Gx:r.Gx,Gy:r.Gy},e=r.Fp,n=wt(t.n,r.nBitLength),o={Fp:e,Fn:n,allowedPrivateKeyLengths:r.allowedPrivateKeyLengths,allowInfinityPoint:r.allowInfinityPoint,endo:r.endo,wrapPrivateKey:r.wrapPrivateKey,isTorsionFree:r.isTorsionFree,clearCofactor:r.clearCofactor,fromBytes:r.fromBytes,toBytes:r.toBytes};return{CURVE:t,curveOpts:o}}function If(r){let{CURVE:t,curveOpts:e}=Af(r),n={hash:r.hash,hmac:r.hmac,randomBytes:r.randomBytes,lowS:r.lowS,bits2int:r.bits2int,bits2int_modN:r.bits2int_modN};return{CURVE:t,curveOpts:e,ecdsaOpts:n}}function Bf(r,t){return Object.assign({},t,{ProjectivePoint:t.Point,CURVE:r})}function na(r){let{CURVE:t,curveOpts:e,ecdsaOpts:n}=If(r),o=Sf(t,e),s=vf(o,n,e);return Bf(r,s)}function oa(r,t){let e=n=>na({...r,hash:n});return{...e(t),create:e}}var Yr={p:BigInt("0xfffffffffffffffffffffffffffffffffffffffffffffffffffffffefffffc2f"),n:BigInt("0xfffffffffffffffffffffffffffffffebaaedce6af48a03bbfd25e8cd0364141"),h:BigInt(1),a:BigInt(0),b:BigInt(7),Gx:BigInt("0x79be667ef9dcbbac55a06295ce870b07029bfcdb2dce28d959f2815b16f81798"),Gy:BigInt("0x483ada7726a3c4655da4fbfc0e1108a8fd17b448a68554199c47d08ffb10d4b8")},M0=BigInt(0),Tf=BigInt(1),Ho=BigInt(2),sa=(r,t)=>(r+t/Ho)/t;function Df(r){let t=Yr.p,e=BigInt(3),n=BigInt(6),o=BigInt(11),s=BigInt(22),i=BigInt(23),a=BigInt(44),u=BigInt(88),c=r*r*r%t,l=c*c*r%t,f=H(l,e,t)*l%t,h=H(f,e,t)*l%t,m=H(h,Ho,t)*c%t,b=H(m,o,t)*m%t,w=H(b,s,t)*b%t,d=H(w,a,t)*w%t,S=H(d,u,t)*d%t,T=H(S,a,t)*w%t,v=H(T,e,t)*l%t,P=H(v,i,t)*b%t,y=H(P,n,t)*c%t,L=H(y,Ho,t);if(!Vo.eql(Vo.sqr(L),r))throw new Error("Cannot find square root");return L}var Vo=wt(Yr.p,void 0,void 0,{sqrt:Df}),Oe=oa({...Yr,Fp:Vo,lowS:!0,endo:{beta:BigInt("0x7ae96a2b657c07106e64479eac3434e99cf0497512f58995c1396c28719501ee"),splitScalar:r=>{let t=Yr.n,e=BigInt("0x3086d221a7d46bcde86c90e49284eb15"),n=-Tf*BigInt("0xe4437ed6010e88286f547fa90abfe4c3"),o=BigInt("0x114ca50f7a8e2f3f657c1108d9d44cfd8"),s=e,i=BigInt("0x100000000000000000000000000000000"),a=sa(s*r,t),u=sa(-n*r,t),c=j(r-a*e-u*o,t),l=j(-a*n-u*s,t),f=c>i,h=l>i;if(f&&(c=t-c),h&&(l=t-l),c>i||l>i)throw new Error("splitScalar: Endomorphism failed, k="+r);return{k1neg:f,k1:c,k2neg:h,k2:l}}}},pi);function ia(r,t,e,n){let o=Ze.digest(e instanceof Uint8Array?e:e.subarray());if(qr(o))return o.then(({digest:s})=>(n?.signal?.throwIfAborted(),Oe.verify(t,s,r))).catch(s=>{throw s.name==="AbortError"?s:new ir(String(s))});try{return n?.signal?.throwIfAborted(),Oe.verify(t,o.digest,r)}catch(s){throw new ir(String(s))}}var Xr=class{type="secp256k1";raw;_key;constructor(t){this._key=ca(t),this.raw=aa(this._key)}toMultihash(){return yt.digest(Ee(this))}toCID(){return X.createV1(114,this.toMultihash())}toString(){return V.encode(this.toMultihash().bytes).substring(1)}equals(t){return t==null||!(t.raw instanceof Uint8Array)?!1:at(this.raw,t.raw)}verify(t,e,n){return ia(this._key,e,t,n)}};function ua(r){return new Xr(r)}function aa(r){return Oe.ProjectivePoint.fromHex(r).toRawBytes(!0)}function ca(r){try{return Oe.ProjectivePoint.fromHex(r),r}catch(t){throw new vr(String(t))}}function fa(r){let{Type:t,Data:e}=fr.decode(r.digest),n=e??new Uint8Array;switch(t){case gt.Ed25519:return Hi(n);case gt.secp256k1:return ua(n);case gt.ECDSA:return Ws(n);default:throw new He}}function Ee(r){return fr.encode({Type:gt[r.type],Data:r.raw})}var la=Symbol.for("nodejs.util.inspect.custom"),Cf=114,dr=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()})`}[Ln]=!0;toString(){return this.string==null&&(this.string=V.encode(this.multihash.bytes).slice(1)),this.string}toMultihash(){return this.multihash}toCID(){return X.createV1(Cf,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")}[la](){return`PeerId(${this.toString()})`}},Qr=class extends dr{type="RSA";publicKey;constructor(t){super({...t,type:"RSA"}),this.publicKey=t.publicKey}},Jr=class extends dr{type="Ed25519";publicKey;constructor(t){super({...t,type:"Ed25519"}),this.publicKey=t.publicKey}},tn=class extends dr{type="secp256k1";publicKey;constructor(t){super({...t,type:"secp256k1"}),this.publicKey=t.publicKey}},Lf=2336,en=class{type="url";multihash;publicKey;url;constructor(t){this.url=t.toString(),this.multihash=yt.digest(M(this.url))}[la](){return`PeerId(${this.url})`}[Ln]=!0;toString(){return this.toCID().toString()}toMultihash(){return this.multihash}toCID(){return X.createV1(Lf,this.toMultihash())}toJSON(){return this.toString()}equals(t){return t==null?!1:(t instanceof Uint8Array&&(t=z(t)),t.toString()===this.toString())}};function rn(r){if(Rf(r))return new Qr({multihash:r});if(Pf(r))try{let t=fa(r);if(t.type==="Ed25519")return new Jr({multihash:r,publicKey:t});if(t.type==="secp256k1")return new tn({multihash:r,publicKey:t})}catch{let e=z(r.digest);return new en(new URL(e))}throw new Ar("Supplied PeerID Multihash is invalid")}function Pf(r){return r.code===yt.code}function Rf(r){return r.code===Ze.code}function jo(r,t){let e={[Symbol.iterator]:()=>e,next:()=>{let n=r.next(),o=n.value;return n.done===!0||o==null?{done:!0,value:void 0}:{done:!1,value:t(o)}}};return e}function nn(r){let t=Qt(V.decode(`z${r}`));return rn(t)}var on=class r{set;constructor(t){if(this.set=new Set,t!=null)for(let e of t)this.set.add(e.toString())}get size(){return this.set.size}[Symbol.iterator](){return this.values()}add(t){this.set.add(t.toString())}clear(){this.set.clear()}delete(t){this.set.delete(t.toString())}entries(){return jo(this.set.entries(),t=>{let e=nn(t[0]);return[e,e]})}forEach(t){this.set.forEach(e=>{let n=nn(e);t(n,n,this)})}has(t){return this.set.has(t.toString())}values(){return jo(this.set.values(),t=>nn(t))}intersection(t){let e=new r;for(let n of t)this.has(n)&&e.add(n);return e}difference(t){let e=new r;for(let n of this)t.has(n)||e.add(n);return e}union(t){let e=new r;for(let n of t)e.add(n);for(let n of this)e.add(n);return e}};function Go(){return new on}var $o={32:16777619n,64:1099511628211n,128:309485009821345068724781371n,256:374144419156711147060143317175368453031918731002211n,512:35835915874844867368919076489095108449946327955754392558399825615420669938882575126094039892345713852759n,1024:5016456510113118655434598811035278955030765345404790744303017523831112055108147451509157692220295382716162651878526895249385292291816524375083746691371804094271873160484737966720260389217684476157468082573n},ha={32:2166136261n,64:14695981039346656037n,128:144066263297769815596495629667062367629n,256:100029257958052580907070968620625704837092796014241193945225284501741471925557n,512:9659303129496669498009435400716310466090418745672637896108374329434462657994582932197716438449813051892206539805784495328239340083876191928701583869517785n,1024:14197795064947621068722070641403218320880622795441933960878474914617582723252296732303717722150864096521202355549365628174669108571814760471015076148029755969804077320157692458563003215304957150157403644460363550505412711285966361610267868082893823963790439336411086884584107735010676915n},da=new globalThis.TextEncoder;function Of(r,t){let e=$o[t],n=ha[t];for(let o=0;o<r.length;o++)n^=BigInt(r[o]),n=BigInt.asUintN(t,n*e);return n}function Nf(r,t,e){if(e.length===0)throw new Error("The `utf8Buffer` option must have a length greater than zero");let n=$o[t],o=ha[t],s=r;for(;s.length>0;){let i=da.encodeInto(s,e);s=s.slice(i.read);for(let a=0;a<i.written;a++)o^=BigInt(e[a]),o=BigInt.asUintN(t,o*n)}return o}function Zo(r,{size:t=32,utf8Buffer:e}={}){if(!$o[t])throw new Error("The `size` option must be one of 32, 64, 128, 256, 512, or 1024");if(typeof r=="string"){if(e)return Nf(r,t,e);r=da.encode(r)}return Of(r,t)}var pr={hash:r=>Number(Zo(r,{size:32})),hashV:(r,t)=>kf(pr.hash(r,t))};function kf(r){let t=r.toString(16);return t.length%2===1&&(t=`0${t}`),M(t,"base16")}var Wo=64,_t=class{fp;h;seed;constructor(t,e,n,o=2){if(o>Wo)throw new TypeError("Invalid Fingerprint Size");let s=e.hashV(t,n),i=bt(o);for(let a=0;a<i.length;a++)i[a]=s[a];i.length===0&&(i[0]=7),this.fp=i,this.h=e,this.seed=n}hash(){return this.h.hash(this.fp,this.seed)}equals(t){return t?.fp instanceof Uint8Array?at(this.fp,t.fp):!1}};function ce(r,t){return Math.floor(Math.random()*(t-r))+r}var ue=class{contents;constructor(t){this.contents=new Array(t).fill(null)}has(t){if(!(t instanceof _t))throw new TypeError("Invalid Fingerprint");return this.contents.some(e=>t.equals(e))}add(t){if(!(t instanceof _t))throw new TypeError("Invalid Fingerprint");for(let e=0;e<this.contents.length;e++)if(this.contents[e]==null)return this.contents[e]=t,!0;return!0}swap(t){if(!(t instanceof _t))throw new TypeError("Invalid Fingerprint");let e=ce(0,this.contents.length-1),n=this.contents[e];return this.contents[e]=t,n}remove(t){if(!(t instanceof _t))throw new TypeError("Invalid Fingerprint");let e=this.contents.findIndex(n=>t.equals(n));return e>-1?(this.contents[e]=null,!0):!1}};var Uf=500,mr=class{bucketSize;filterSize;fingerprintSize;buckets;count;hash;seed;constructor(t){this.filterSize=t.filterSize,this.bucketSize=t.bucketSize??4,this.fingerprintSize=t.fingerprintSize??2,this.count=0,this.buckets=[],this.hash=t.hash??pr,this.seed=t.seed??ce(0,Math.pow(2,10))}add(t){typeof t=="string"&&(t=M(t));let e=new _t(t,this.hash,this.seed,this.fingerprintSize),n=this.hash.hash(t,this.seed)%this.filterSize,o=(n^e.hash())%this.filterSize;if(this.buckets[n]==null&&(this.buckets[n]=new ue(this.bucketSize)),this.buckets[o]==null&&(this.buckets[o]=new ue(this.bucketSize)),this.buckets[n].add(e)||this.buckets[o].add(e))return this.count++,!0;let s=[n,o],i=s[ce(0,s.length-1)];this.buckets[i]==null&&(this.buckets[i]=new ue(this.bucketSize));for(let a=0;a<Uf;a++){let u=this.buckets[i].swap(e);if(u!=null&&(i=(i^u.hash())%this.filterSize,this.buckets[i]==null&&(this.buckets[i]=new ue(this.bucketSize)),this.buckets[i].add(u)))return this.count++,!0}return!1}has(t){typeof t=="string"&&(t=M(t));let e=new _t(t,this.hash,this.seed,this.fingerprintSize),n=this.hash.hash(t,this.seed)%this.filterSize,o=this.buckets[n]?.has(e)??!1;if(o)return o;let s=(n^e.hash())%this.filterSize;return this.buckets[s]?.has(e)??!1}remove(t){typeof t=="string"&&(t=M(t));let e=new _t(t,this.hash,this.seed,this.fingerprintSize),n=this.hash.hash(t,this.seed)%this.filterSize,o=this.buckets[n]?.remove(e)??!1;if(o)return this.count--,o;let s=(n^e.hash())%this.filterSize,i=this.buckets[s]?.remove(e)??!1;return i&&this.count--,i}get reliable(){return Math.floor(100*(this.count/this.filterSize))<=90}},Mf={1:.5,2:.84,4:.95,8:.98};function Ff(r=.001){return r>.002?2:r>1e-5?4:8}function pa(r,t=.001){let e=Ff(t),n=Mf[e],o=Math.round(r/n),s=Math.min(Math.ceil(Math.log2(1/t)+Math.log2(2*e)),Wo);return{filterSize:o,bucketSize:e,fingerprintSize:s}}var sn=class{filterSize;bucketSize;fingerprintSize;scale;filterSeries;hash;seed;constructor(t){this.bucketSize=t.bucketSize??4,this.filterSize=t.filterSize??(1<<18)/this.bucketSize,this.fingerprintSize=t.fingerprintSize??2,this.scale=t.scale??2,this.hash=t.hash??pr,this.seed=t.seed??ce(0,Math.pow(2,10)),this.filterSeries=[new mr({filterSize:this.filterSize,bucketSize:this.bucketSize,fingerprintSize:this.fingerprintSize,hash:this.hash,seed:this.seed})]}add(t){if(typeof t=="string"&&(t=M(t)),this.has(t))return!0;let e=this.filterSeries.find(n=>n.reliable);if(e==null){let n=this.filterSize*Math.pow(this.scale,this.filterSeries.length);e=new mr({filterSize:n,bucketSize:this.bucketSize,fingerprintSize:this.fingerprintSize,hash:this.hash,seed:this.seed}),this.filterSeries.push(e)}return e.add(t)}has(t){typeof t=="string"&&(t=M(t));for(let e=0;e<this.filterSeries.length;e++)if(this.filterSeries[e].has(t))return!0;return!1}remove(t){typeof t=="string"&&(t=M(t));for(let e=0;e<this.filterSeries.length;e++)if(this.filterSeries[e].remove(t))return!0;return!1}get count(){return this.filterSeries.reduce((t,e)=>t+e.count,0)}};function Yo(r,t=.001,e){return new sn({...pa(r,t),...e??{}})}var an=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 u=a==="0",c=2**(8*o)-1;for(;;){let l=this.readAtomically(()=>{let f=this.readChar();if(f===void 0)return;let h=Number.parseInt(f,t);if(!Number.isNaN(h))return h});if(l===void 0)break;if(s*=t,s+=l,s>c||(i+=1,e!==void 0&&i>e))return}if(i!==0)return!n&&u&&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 ma=45,Kf=15,Ne=new an;function cn(r){if(!(r.length>Kf))return Ne.new(r).parseWith(()=>Ne.readIPv4Addr())}function un(r){if(r.includes("%")&&(r=r.split("%")[0]),!(r.length>ma))return Ne.new(r).parseWith(()=>Ne.readIPv6Addr())}function ke(r,t=!1){if(r.includes("%")&&(r=r.split("%")[0]),r.length>ma)return;let e=Ne.new(r).parseWith(()=>Ne.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 ga(r,t,e){let n=0;for(let o of r)if(!(n<t)){if(n>e)break;if(o!==255)return!1;n++}return!0}function ya(r,t,e,n){let o=0;for(let s of r)if(!(o<e)){if(o>n)break;if(s!==t[o])return!1;o++}return!0}function Xo(r){switch(r.length){case fe:return r.join(".");case le:{let t=[];for(let e=0;e<r.length;e++)e%2===0&&t.push(r[e].toString(16).padStart(2,"0")+r[e+1].toString(16).padStart(2,"0"));return t.join(":")}default:throw new Error("Invalid ip length")}}function ba(r){let t=0;for(let[e,n]of r.entries()){if(n===255){t+=8;continue}for(;(n&128)!=0;)t++,n=n<<1;if((n&128)!=0)return-1;for(let o=e+1;o<r.length;o++)if(r[o]!=0)return-1;break}return t}function xa(r){let t="0x";for(let e of r)t+=(e>>4).toString(16)+(e&15).toString(16);return t}var fe=4,le=16,vg=parseInt("0xFFFF",16),zf=new Uint8Array([0,0,0,0,0,0,0,0,0,0,255,255]);function gr(r,t){t.length===le&&r.length===fe&&ga(t,0,11)&&(t=t.slice(12)),t.length===fe&&r.length===le&&ya(r,zf,0,11)&&(r=r.slice(12));let e=r.length;if(e!=t.length)throw new Error("Failed to mask ip");let n=new Uint8Array(e);for(let o=0;o<e;o++)n[o]=r[o]&t[o];return n}function wa(r,t){if(typeof t=="string"&&(t=ke(t)),t==null)throw new Error("Invalid ip");if(t.length!==r.network.length)return!1;for(let e=0;e<t.length;e++)if((r.network[e]&r.mask[e])!==(t[e]&r.mask[e]))return!1;return!0}function Qo(r){let[t,e]=r.split("/");if(!t||!e)throw new Error("Failed to parse given CIDR: "+r);let n=fe,o=cn(t);if(o==null&&(n=le,o=un(t),o==null))throw new Error("Failed to parse given CIDR: "+r);let s=parseInt(e,10);if(Number.isNaN(s)||String(s).length!==e.length||s<0||s>n*8)throw new Error("Failed to parse given CIDR: "+r);let i=Jo(s,8*n);return{network:gr(o,i),mask:i}}function Jo(r,t){if(t!==8*fe&&t!==8*le)throw new Error("Invalid CIDR mask");if(r<0||r>t)throw new Error("Invalid CIDR mask");let e=t/8,n=new Uint8Array(e);for(let o=0;o<e;o++){if(r>=8){n[o]=255,r-=8;continue}n[o]=255-(255>>r),r=0}return n}var Ue=class{constructor(t,e){if(e==null)({network:this.network,mask:this.mask}=Qo(t));else{let n=ke(t);if(n==null)throw new Error("Failed to parse network");e=String(e);let o=parseInt(e,10);if(Number.isNaN(o)||String(o).length!==e.length||o<0||o>n.length*8){let s=ke(e);if(s==null)throw new Error("Failed to parse mask");this.mask=s}else this.mask=Jo(o,8*n.length);this.network=gr(n,this.mask)}}contains(t){return wa({network:this.network,mask:this.mask},t)}toString(){let t=ba(this.mask),e=t!==-1?String(t):xa(this.mask);return Xo(this.network)+"/"+e}};function Ea(r,t){return new Ue(r).contains(t)}var et=class extends Error{static name="InvalidMultiaddrError";name="InvalidMultiaddrError"},Ft=class extends Error{static name="ValidationError";name="ValidationError"},yr=class extends Error{static name="InvalidParametersError";name="InvalidParametersError"},fn=class extends Error{static name="UnknownProtocolError";name="UnknownProtocolError"};function Me(r){return!!cn(r)}function ln(r){return!!un(r)}function es(r){return t=>z(t,r)}function rs(r){return t=>M(t,r)}function Fe(r){return new DataView(r.buffer).getUint16(r.byteOffset).toString()}function he(r){let t=new ArrayBuffer(2);return new DataView(t).setUint16(0,typeof r=="string"?parseInt(r):r),new Uint8Array(t)}function _a(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=M(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=he(n);return Ct([e,o],e.length+o.length)}function Sa(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=qt.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=he(n);return Ct([e,o],e.length+o.length)}function ns(r){let t=r.subarray(0,r.length-2),e=r.subarray(r.length-2),n=z(t,"base32"),o=Fe(e);return`${n}:${o}`}var os=function(r){r=r.toString().trim();let t=new Uint8Array(4);return r.split(/\./g).forEach((e,n)=>{let o=parseInt(e,10);if(isNaN(o)||o<0||o>255)throw new et("Invalid byte value in IP address");t[n]=o}),t},va=function(r){let t=0;r=r.toString().trim();let e=r.split(":",8),n;for(n=0;n<e.length;n++){let s=Me(e[n]),i;s&&(i=os(e[n]),e[n]=z(i.subarray(0,2),"base16")),i!=null&&++n<8&&e.splice(n,0,z(i.subarray(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++){e[n]===""&&(e[n]="0");let s=parseInt(e[n],16);if(isNaN(s)||s<0||s>65535)throw new et("Invalid byte value in IP address");o[t++]=s>>8&255,o[t++]=s&255}return o},Aa=function(r){if(r.byteLength!==4)throw new et("IPv4 address was incorrect length");let t=[];for(let e=0;e<r.byteLength;e++)t.push(r[e]);return t.join(".")},Ia=function(r){if(r.byteLength!==16)throw new et("IPv6 address was incorrect length");let t=[];for(let n=0;n<r.byteLength;n+=2){let o=r[n],s=r[n+1],i=`${o.toString(16).padStart(2,"0")}${s.toString(16).padStart(2,"0")}`;t.push(i)}let e=t.join(":");try{let n=new URL(`http://[${e}]`);return n.hostname.substring(1,n.hostname.length-1)}catch{throw new et(`Invalid IPv6 address "${e}"`)}};function Ba(r){try{let t=new URL(`http://[${r}]`);return t.hostname.substring(1,t.hostname.length-1)}catch{throw new et(`Invalid IPv6 address "${r}"`)}}var ts=Object.values(We).map(r=>r.decoder),qf=function(){let r=ts[0].or(ts[1]);return ts.slice(2).forEach(t=>r=r.or(t)),r}();function Ta(r){return qf.decode(r)}function Da(r){return t=>r.encoder.encode(t)}function Hf(r){if(parseInt(r).toString()!==r)throw new Ft("Value must be an integer")}function Vf(r){if(r<0)throw new Ft("Value must be a positive integer, or zero")}function jf(r){return t=>{if(t>r)throw new Ft(`Value must be smaller than or equal to ${r}`)}}function Gf(...r){return t=>{for(let e of r)e(t)}}var br=Gf(Hf,Vf,jf(65535));var J=-1,ss=class{protocolsByCode=new Map;protocolsByName=new Map;getProtocol(t){let e;if(typeof t=="string"?e=this.protocolsByName.get(t):e=this.protocolsByCode.get(t),e==null)throw new fn(`Protocol ${t} was unknown`);return e}addProtocol(t){this.protocolsByCode.set(t.code,t),this.protocolsByName.set(t.name,t),t.aliases?.forEach(e=>{this.protocolsByName.set(e,t)})}removeProtocol(t){let e=this.protocolsByCode.get(t);e!=null&&(this.protocolsByCode.delete(e.code),this.protocolsByName.delete(e.name),e.aliases?.forEach(n=>{this.protocolsByName.delete(n)}))}},ht=new ss,_l=[{code:4,name:"ip4",size:32,valueToBytes:os,bytesToValue:Aa,validate:r=>{if(!Me(r))throw new Ft(`Invalid IPv4 address "${r}"`)}},{code:6,name:"tcp",size:16,valueToBytes:he,bytesToValue:Fe,validate:br},{code:273,name:"udp",size:16,valueToBytes:he,bytesToValue:Fe,validate:br},{code:33,name:"dccp",size:16,valueToBytes:he,bytesToValue:Fe,validate:br},{code:41,name:"ip6",size:128,valueToBytes:va,bytesToValue:Ia,stringToValue:Ba,validate:r=>{if(!ln(r))throw new Ft(`Invalid IPv6 address "${r}"`)}},{code:42,name:"ip6zone",size:J},{code:43,name:"ipcidr",size:8,bytesToValue:es("base10"),valueToBytes:rs("base10")},{code:53,name:"dns",size:J,resolvable:!0},{code:54,name:"dns4",size:J,resolvable:!0},{code:55,name:"dns6",size:J,resolvable:!0},{code:56,name:"dnsaddr",size:J,resolvable:!0},{code:132,name:"sctp",size:16,valueToBytes:he,bytesToValue:Fe,validate:br},{code:301,name:"udt"},{code:302,name:"utp"},{code:400,name:"unix",size:J,path:!0,stringToValue:r=>decodeURIComponent(r),valueToString:r=>encodeURIComponent(r)},{code:421,name:"p2p",aliases:["ipfs"],size:J,bytesToValue:es("base58btc"),valueToBytes:r=>r.startsWith("Q")||r.startsWith("1")?rs("base58btc")(r):X.parse(r).multihash.bytes},{code:444,name:"onion",size:96,bytesToValue:ns,valueToBytes:_a},{code:445,name:"onion3",size:296,bytesToValue:ns,valueToBytes:Sa},{code:446,name:"garlic64",size:J},{code:447,name:"garlic32",size:J},{code:448,name:"tls"},{code:449,name:"sni",size:J},{code:454,name:"noise"},{code:460,name:"quic"},{code:461,name:"quic-v1"},{code:465,name:"webtransport"},{code:466,name:"certhash",size:J,bytesToValue:Da(Gn),valueToBytes:Ta},{code:480,name:"http"},{code:481,name:"http-path",size:J,stringToValue:r=>`/${decodeURIComponent(r)}`,valueToString:r=>encodeURIComponent(r.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:J}];_l.forEach(r=>{ht.addProtocol(r)});function Ca(r){let t=[],e=0;for(;e<r.length;){let n=ar(r,e),o=ht.getProtocol(n),s=lt(n),i=Sl(o,r,e+s),a=0;i>0&&o.size===J&&(a=lt(i));let u=s+a+i,c={code:n,name:o.name,bytes:r.subarray(e,e+u)};if(i>0){let l=e+s+a,f=r.subarray(l,l+i);c.value=o.bytesToValue?.(f)??z(f)}t.push(c),e+=u}return t}function La(r){let t=0,e=[];for(let n of r){if(n.bytes==null){let o=ht.getProtocol(n.code),s=lt(n.code),i,a=0,u=0;n.value!=null&&(i=o.valueToBytes?.(n.value)??M(n.value),a=i.byteLength,o.size===J&&(u=lt(a)));let c=new Uint8Array(s+u+a),l=0;Le(n.code,c,l),l+=s,i!=null&&(o.size===J&&(Le(a,c,l),l+=u),c.set(i,l)),n.bytes=c}e.push(n.bytes),t+=n.bytes.byteLength}return Ct(e,t)}function Pa(r){if(r.charAt(0)!=="/")throw new et('String multiaddr must start with "/"');let t=[],e="protocol",n="",o="";for(let s=1;s<r.length;s++){let i=r.charAt(s);i!=="/"&&(e==="protocol"?o+=r.charAt(s):n+=r.charAt(s));let a=s===r.length-1;if(i==="/"||a){let u=ht.getProtocol(o);if(e==="protocol"){if(u.size==null||u.size===0){t.push({code:u.code,name:u.name}),n="",o="",e="protocol";continue}else if(a)throw new et(`Component ${o} was missing value`);e="value"}else if(e==="value"){let c={code:u.code,name:u.name};if(u.size!=null&&u.size!==0){if(n==="")throw new et(`Component ${o} was missing value`);c.value=u.stringToValue?.(n)??n}t.push(c),n="",o="",e="protocol"}}}if(o!==""&&n!=="")throw new et("Incomplete multiaddr");return t}function Ra(r){return`/${r.flatMap(t=>{if(t.value==null)return t.name;let e=ht.getProtocol(t.code);if(e==null)throw new et(`Unknown protocol code ${t.code}`);return[t.name,e.valueToString?.(t.value)??t.value]}).join("/")}`}function Sl(r,t,e){return r.size==null||r.size===0?0:r.size>0?r.size/8:ar(t,e)}var vl=Symbol.for("nodejs.util.inspect.custom"),hs=Symbol.for("@multiformats/multiaddr"),Al=[53,54,55,56],ls=class extends Error{constructor(t="No available resolver"){super(t),this.name="NoAvailableResolverError"}};function Il(r){if(r==null&&(r="/"),Na(r))return r.getComponents();if(r instanceof Uint8Array)return Ca(r);if(typeof r=="string")return r=r.replace(/\/(\/)+/,"/").replace(/(\/)+$/,""),r===""&&(r="/"),Pa(r);if(Array.isArray(r))return r;throw new et("Must be a string, Uint8Array, Component[], or another Multiaddr")}var mn=class r{[hs]=!0;#t;#e;#r;constructor(t="/",e={}){this.#t=Il(t),e.validate!==!1&&Bl(this)}get bytes(){return this.#r==null&&(this.#r=La(this.#t)),this.#r}toString(){return this.#e==null&&(this.#e=Ra(this.#t)),this.#e}toJSON(){return this.toString()}toOptions(){let t,e,n,o,s="";for(let{code:a,name:u,value:c}of this.#t)a===42&&(s=`%${c??""}`),Al.includes(a)&&(e="tcp",o=443,n=`${c??""}${s}`,t=a===55?6:4),(a===6||a===273)&&(e=u==="tcp"?"tcp":"udp",o=parseInt(c??"")),(a===4||a===41)&&(e="tcp",n=`${c??""}${s}`,t=a===41?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}}getComponents(){return[...this.#t]}protos(){return this.#t.map(({code:t,value:e})=>{let n=ht.getProtocol(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:e})=>{if(e==null)return[t];let n=ht.getProtocol(t),o=[t];return e!=null&&o.push(n.valueToBytes?.(e)??M(e)),o})}stringTuples(){return this.#t.map(({code:t,value:e})=>e==null?[t]:[t,e])}encapsulate(t){let e=new r(t);return new r([...this.#t,...e.getComponents()],{validate:!1})}decapsulate(t){let e=t.toString(),n=this.toString(),o=n.lastIndexOf(e);if(o<0)throw new yr(`Address ${this.toString()} does not contain subaddress: ${t.toString()}`);return new r(n.slice(0,o),{validate:!1})}decapsulateCode(t){let e;for(let n=this.#t.length-1;n>-1;n--)if(this.#t[n].code===t){e=n;break}return new r(this.#t.slice(0,e),{validate:!1})}getPeerId(){try{let t=[];this.#t.forEach(({code:n,value:o})=>{n===421&&t.push([n,o]),n===290&&(t=[])});let e=t.pop();if(e?.[1]!=null){let n=e[1];return n[0]==="Q"||n[0]==="1"?z(V.decode(`z${n}`),"base58btc"):z(X.parse(n).multihash.bytes,"base58btc")}return null}catch{return null}}getPath(){for(let t of this.#t)if(ht.getProtocol(t.code).path)return t.value??null;return null}equals(t){return at(this.bytes,t.bytes)}async resolve(t){let e=this.protos().find(s=>s.resolvable);if(e==null)return[this];let n=Oa.get(e.name);if(n==null)throw new ls(`no available resolver for ${e.name}`);return(await n(this,t)).map(s=>wr(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)}[vl](){return`Multiaddr(${this.toString()})`}};function Bl(r){r.getComponents().forEach(t=>{let e=ht.getProtocol(t.code);t.value!=null&&e.validate?.(t.value)})}var Oa=new Map;function Na(r){return!!r?.[hs]}function wr(r){return new mn(r)}function ka(r){let t=ht.getProtocol(r);return{code:t.code,size:t.size??0,name:t.name,resolvable:!!t.resolvable,path:!!t.path}}function Ua(r){try{for(let{code:t,value:e}of r.getComponents())if(e!=null&&t===41)return Ea("2000::/3",e)}catch{}return!1}var Fa=nc(Ma(),1),Tl=["0.0.0.0/8","10.0.0.0/8","100.64.0.0/10","127.0.0.0/8","169.254.0.0/16","172.16.0.0/12","192.0.0.0/24","192.0.0.0/29","192.0.0.8/32","192.0.0.9/32","192.0.0.10/32","192.0.0.170/32","192.0.0.171/32","192.0.2.0/24","192.31.196.0/24","192.52.193.0/24","192.88.99.0/24","192.168.0.0/16","192.175.48.0/24","198.18.0.0/15","198.51.100.0/24","203.0.113.0/24","240.0.0.0/4","255.255.255.255/32"],Dl=Tl.map(r=>new Fa.Netmask(r));function ds(r){for(let t of Dl)if(t.contains(r))return!0;return!1}function Cl(r){return/^::ffff:([0-9a-fA-F]{1,4}):([0-9a-fA-F]{1,4})$/.test(r)}function Ll(r){let t=r.split(":");if(t.length<2)return!1;let e=t[t.length-1].padStart(4,"0"),n=t[t.length-2].padStart(4,"0"),o=`${parseInt(n.substring(0,2),16)}.${parseInt(n.substring(2),16)}.${parseInt(e.substring(0,2),16)}.${parseInt(e.substring(2),16)}`;return ds(o)}function Pl(r){return/^::ffff:([0-9]{1,3})\.([0-9]{1,3})\.([0-9]{1,3})\.([0-9]{1,3})$/.test(r)}function Rl(r){let t=r.split(":"),e=t[t.length-1];return ds(e)}function Ol(r){return/^::$/.test(r)||/^::1$/.test(r)||/^64:ff9b::([0-9]{1,3})\.([0-9]{1,3})\.([0-9]{1,3})\.([0-9]{1,3})$/.test(r)||/^100::([0-9a-fA-F]{0,4}):?([0-9a-fA-F]{0,4}):?([0-9a-fA-F]{0,4}):?([0-9a-fA-F]{0,4})$/.test(r)||/^2001::([0-9a-fA-F]{0,4}):?([0-9a-fA-F]{0,4}):?([0-9a-fA-F]{0,4}):?([0-9a-fA-F]{0,4}):?([0-9a-fA-F]{0,4}):?([0-9a-fA-F]{0,4})$/.test(r)||/^2001:2[0-9a-fA-F]:([0-9a-fA-F]{0,4}):?([0-9a-fA-F]{0,4}):?([0-9a-fA-F]{0,4}):?([0-9a-fA-F]{0,4}):?([0-9a-fA-F]{0,4}):?([0-9a-fA-F]{0,4})$/.test(r)||/^2001:db8:([0-9a-fA-F]{0,4}):?([0-9a-fA-F]{0,4}):?([0-9a-fA-F]{0,4}):?([0-9a-fA-F]{0,4}):?([0-9a-fA-F]{0,4}):?([0-9a-fA-F]{0,4})$/.test(r)||/^2002:([0-9a-fA-F]{0,4}):?([0-9a-fA-F]{0,4}):?([0-9a-fA-F]{0,4}):?([0-9a-fA-F]{0,4}):?([0-9a-fA-F]{0,4}):?([0-9a-fA-F]{0,4}):?([0-9a-fA-F]{0,4})$/.test(r)||/^f[c-d]([0-9a-fA-F]{2,2}):/i.test(r)||/^fe[8-9a-bA-B][0-9a-fA-F]:/i.test(r)||/^ff([0-9a-fA-F]{2,2}):/i.test(r)}function Ka(r){if(Me(r))return ds(r);if(Cl(r))return Ll(r);if(Pl(r))return Rl(r);if(ln(r))return Ol(r)}function za(r){try{for(let{code:t}of r.getComponents())if(t!==42)return t===4||t===41}catch{}return!1}function ps(r){try{if(!za(r))return!1;let[[,t]]=r.stringTuples();return t==null?!1:Ka(t)??!1}catch{}return!0}function St(){let r={};return r.promise=new Promise((t,e)=>{r.resolve=t,r.reject=e}),r}var gn=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}},ze=class{size;hwm;head;tail;constructor(t={}){this.hwm=t.splitLimit??16,this.head=new gn(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 gn(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 ms=class extends Error{type;code;constructor(t,e){super(t??"The operation was aborted"),this.type="aborted",this.code=e??"ABORT_ERR"}};function qa(r={}){return Nl(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 Nl(r,t){t=t??{};let e=t.onEnd,n=new ze,o,s,i,a=St(),u=async()=>{try{return n.isEmpty()?i?{done:!0}:await new Promise((d,S)=>{s=T=>{s=null,n.push(T);try{d(r(n))}catch(v){S(v)}return o}}):r(n)}finally{n.isEmpty()&&queueMicrotask(()=>{a.resolve(),a=St()})}},c=d=>s!=null?s(d):(n.push(d),o),l=d=>(n=new ze,s!=null?s({error:d}):(n.push({error:d}),o)),f=d=>{if(i)return o;if(t?.objectMode!==!0&&d?.byteLength==null)throw new Error("objectMode was not true but tried to push non-Uint8Array value");return c({done:!1,value:d})},h=d=>i?o:(i=!0,d!=null?l(d):c({done:!0})),m=()=>(n=new ze,h(),{done:!0}),b=d=>(h(d),{done:!0});if(o={[Symbol.asyncIterator](){return this},next:u,return:m,throw:b,push:f,end:h,get readableLength(){return n.size},onEmpty:async d=>{let S=d?.signal;if(S?.throwIfAborted(),n.isEmpty())return;let T,v;S!=null&&(T=new Promise((P,y)=>{v=()=>{y(new ms)},S.addEventListener("abort",v)}));try{await Promise.race([a.promise,T])}finally{v!=null&&S!=null&&S?.removeEventListener("abort",v)}}},e==null)return o;let w=o;return o={[Symbol.asyncIterator](){return this},next(){return w.next()},throw(d){return w.throw(d),e!=null&&(e(d),e=void 0),{done:!0}},return(){return w.return(),e!=null&&(e(),e=void 0),{done:!0}},push:f,end(d){return w.end(d),e!=null&&(e(d),e=void 0),o},get readableLength(){return w.readableLength},onEmpty:d=>w.onEmpty(d)},o}var gs=class extends Error{type;code;constructor(t,e){super(t??"The operation was aborted"),this.type="aborted",this.name="AbortError",this.code=e??"ABORT_ERR"}};async function yn(r,t,e,n){let o=new gs(n?.errorMessage,n?.errorCode);return e?.aborted===!0?Promise.reject(o):new Promise((s,i)=>{function a(){e?.removeEventListener("abort",l),r.removeEventListener(t,u),n?.errorEvent!=null&&r.removeEventListener(n.errorEvent,c)}let u=f=>{try{if(n?.filter?.(f)===!1)return}catch(h){a(),i(h);return}a(),s(f)},c=f=>{a(),i(f.detail)},l=()=>{a(),i(o)};e?.addEventListener("abort",l),r.addEventListener(t,u),n?.errorEvent!=null&&r.addEventListener(n.errorEvent,c)})}function _r(r,t){let e,n=function(){let o=function(){e=void 0,r()};clearTimeout(e),e=setTimeout(o,t)};return n.start=()=>{},n.stop=()=>{clearTimeout(e)},n}var bn=class extends Error{static name="QueueFullError";constructor(t="The queue was full"){super(t),this.name="QueueFullError"}};var xn=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 de(r,t,e){if(t==null)return r;if(t.aborted)return r.catch(()=>{}),Promise.reject(new xn(e?.errorMessage,e?.errorCode,e?.errorName));let n,o=new xn(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 wn=class{deferred;signal;constructor(t){this.signal=t,this.deferred=St(),this.onAbort=this.onAbort.bind(this),this.signal?.addEventListener("abort",this.onAbort)}onAbort(){this.deferred.reject(this.signal?.reason??new Bt)}cleanup(){this.signal?.removeEventListener("abort",this.onAbort)}};function kl(){return`${parseInt(String(Math.random()*1e9),10).toString()}${Date.now()}`}var En=class{id;fn;options;recipients;status;timeline;controller;constructor(t,e){this.id=kl(),this.status="queued",this.fn=t,this.options=e,this.recipients=[],this.timeline={created:Date.now()},this.controller=new AbortController,this.controller.signal,this.onAbort=this.onAbort.bind(this)}abort(t){this.controller.abort(t)}onAbort(){this.recipients.reduce((e,n)=>e&&n.signal?.aborted===!0,!0)&&(this.controller.abort(new Bt),this.cleanup())}async join(t={}){let e=new wn(t.signal);return this.recipients.push(e),t.signal?.addEventListener("abort",this.onAbort),e.deferred.promise}async run(){this.status="running",this.timeline.started=Date.now();try{this.controller.signal.throwIfAborted();let t=await de(this.fn({...this.options??{},signal:this.controller.signal}),this.controller.signal);this.recipients.forEach(e=>{e.deferred.resolve(t)}),this.status="complete"}catch(t){this.recipients.forEach(e=>{e.deferred.reject(t)}),this.status="errored"}finally{this.timeline.finished=Date.now(),this.cleanup()}}cleanup(){this.recipients.forEach(t=>{t.cleanup(),t.signal?.removeEventListener("abort",this.onAbort)})}};var _n=class extends Ir{concurrency;maxSize;queue;pending;sort;constructor(t={}){super(),this.concurrency=t.concurrency??Number.POSITIVE_INFINITY,this.maxSize=t.maxSize??Number.POSITIVE_INFINITY,this.pending=0,t.metricName!=null&&t.metrics?.registerMetricGroup(t.metricName,{calculate:()=>({size:this.queue.length,running:this.pending,queued:this.queue.length-this.pending})}),this.sort=t.sort,this.queue=[],this.emitEmpty=_r(this.emitEmpty.bind(this),1),this.emitIdle=_r(this.emitIdle.bind(this),1)}emitEmpty(){this.size===0&&this.safeDispatchEvent("empty")}emitIdle(){this.running===0&&this.safeDispatchEvent("idle")}tryToStartAnother(){if(this.size===0)return this.emitEmpty(),this.running===0&&this.emitIdle(),!1;if(this.pending<this.concurrency){let t;for(let e of this.queue)if(e.status==="queued"){t=e;break}return t==null?!1:(this.safeDispatchEvent("active"),this.pending++,t.run().finally(()=>{for(let e=0;e<this.queue.length;e++)if(this.queue[e]===t){this.queue.splice(e,1);break}this.pending--,this.tryToStartAnother(),this.safeDispatchEvent("next")}),!0)}return!1}enqueue(t){this.queue.push(t),this.sort!=null&&this.queue.sort(this.sort)}async add(t,e){if(e?.signal?.throwIfAborted(),this.size===this.maxSize)throw new bn;let n=new En(t,e);return this.enqueue(n),this.safeDispatchEvent("add"),this.tryToStartAnother(),n.join(e).then(o=>(this.safeDispatchEvent("completed",{detail:o}),this.safeDispatchEvent("success",{detail:{job:n,result:o}}),o)).catch(o=>{if(n.status==="queued"){for(let s=0;s<this.queue.length;s++)if(this.queue[s]===n){this.queue.splice(s,1);break}}throw this.safeDispatchEvent("error",{detail:o}),this.safeDispatchEvent("failure",{detail:{job:n,error:o}}),o})}clear(){this.queue.splice(0,this.queue.length)}abort(){this.queue.forEach(t=>{t.abort(new Bt)}),this.clear()}async onEmpty(t){this.size!==0&&await yn(this,"empty",t?.signal)}async onSizeLessThan(t,e){this.size<t||await yn(this,"next",e?.signal,{filter:()=>this.size<t})}async onIdle(t){this.pending===0&&this.size===0||await yn(this,"idle",t?.signal)}get size(){return this.queue.length}get queued(){return this.queue.length-this.pending}get running(){return this.pending}async*toGenerator(t){t?.signal?.throwIfAborted();let e=qa({objectMode:!0}),n=u=>{u!=null?this.abort():this.clear(),e.end(u)},o=u=>{u.detail!=null&&e.push(u.detail)},s=u=>{n(u.detail)},i=()=>{n()},a=()=>{n(new Bt("Queue aborted"))};this.addEventListener("completed",o),this.addEventListener("error",s),this.addEventListener("idle",i),t?.signal?.addEventListener("abort",a);try{yield*e}finally{this.removeEventListener("completed",o),this.removeEventListener("error",s),this.removeEventListener("idle",i),t?.signal?.removeEventListener("abort",a),n()}}};var Sn=class extends _n{has(t){return this.find(t)!=null}find(t){return this.queue.find(e=>t.equals(e.options.peerId))}};function vn(r){let t=new globalThis.AbortController;function e(){t.abort();for(let s of r)s?.removeEventListener!=null&&s.removeEventListener("abort",e)}for(let s of r){if(s?.aborted===!0){e();break}s?.addEventListener!=null&&s.addEventListener("abort",e)}function n(){for(let s of r)s?.removeEventListener!=null&&s.removeEventListener("abort",e)}let o=t.signal;return o.clear=n,o}function Ha(r,t,e){let n,o,s=!1;function i(){let c={signal:o.signal};if(e?.timeout!=null){let l=vn([o.signal,AbortSignal.timeout(e.timeout)]);c.signal=l}s=!0,Promise.resolve().then(async()=>{await r(c)}).catch(()=>{}).finally(()=>{s=!1,!o.signal.aborted&&(n=setTimeout(i,t))})}let a=_r(i,e?.debounce??100),u=!1;return{setInterval:c=>{t!==c&&(t=c,n!=null&&(clearTimeout(n),n=setTimeout(i,t)))},setTimeout:c=>{e??={},e.timeout=c},run:()=>{s||(clearTimeout(n),a())},start:()=>{u||(u=!0,o=new AbortController,o.signal,e?.runImmediately===!0?queueMicrotask(()=>{i()}):n=setTimeout(i,t))},stop:()=>{clearTimeout(n),o?.abort(),u=!1}}}var ys=class extends Map{metric;constructor(t){super();let{name:e,metrics:n}=t;this.metric=n.registerMetric(e),this.updateComponentMetric()}set(t,e){return super.set(t,e),this.updateComponentMetric(),this}delete(t){let e=super.delete(t);return this.updateComponentMetric(),e}clear(){super.clear(),this.updateComponentMetric()}updateComponentMetric(){this.metric.update(this.size)}};function Va(r){let{name:t,metrics:e}=r,n;return e!=null?n=new ys({name:t,metrics:e}):n=new Map,n}var bs=class{readNext;haveNext;ended;nextResult;error;constructor(){this.ended=!1,this.readNext=St(),this.haveNext=St()}[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=St(),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=St(),await de(this.readNext.promise,e?.signal,e)}};function ja(){return new bs}var An=class extends Error{name="UnexpectedEOFError";code="ERR_UNEXPECTED_EOF"};function Ga(r,t){let e=ja();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 W;return{read:async i=>{if(i?.signal?.throwIfAborted(),i?.bytes==null){let{done:u,value:c}=await de(n.next(),i?.signal);return u===!0?null:c}for(;o.byteLength<i.bytes;){let{value:u,done:c}=await de(n.next(),i?.signal);if(c===!0)throw new An("unexpected end of input");o.append(u)}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 In=class extends Error{name="InvalidMessageLengthError";code="ERR_INVALID_MSG_LENGTH"},Bn=class extends Error{name="InvalidDataLengthError";code="ERR_MSG_DATA_TOO_LONG"},Tn=class extends Error{name="InvalidDataLengthLengthError";code="ERR_MSG_LENGTH_TOO_LONG"};function $a(r,t={}){let e=Ga(r,t);t.maxDataLength!=null&&t.maxLengthLength==null&&(t.maxLengthLength=lt(t.maxDataLength));let n=t?.lengthDecoder??ar,o=t?.lengthEncoder??Vi;return{read:async i=>{let a=-1,u=new W;for(;;){u.append(await e.read({...i,bytes:1}));try{a=n(u)}catch(c){if(c instanceof RangeError)continue;throw c}if(a<0)throw new In("Invalid message length");if(t?.maxLengthLength!=null&&u.byteLength>t.maxLengthLength)throw new Tn("message length length too long");if(a>-1)break}if(t?.maxDataLength!=null&&a>t.maxDataLength)throw new Bn("message length too long");return e.read({...i,bytes:a})},write:async(i,a)=>{await e.write(new W(o(i.byteLength),i),a)},writeV:async(i,a)=>{let u=new W(...i.flatMap(c=>[o(c.byteLength),c]));await e.write(u,a)},unwrap:()=>e.unwrap()}}function xs(r,t){let e=$a(r,t),n={read:async(o,s)=>{let i=await e.read(s);return o.decode(i)},write:async(o,s,i)=>{await e.write(s.encode(o),i)},writeV:async(o,s,i)=>{await e.writeV(o.map(a=>s.encode(a)),i)},pb:o=>({read:async s=>n.read(o,s),write:async(s,i)=>n.write(s,o,i),writeV:async(s,i)=>n.writeV(s,o,i),unwrap:()=>n}),unwrap:()=>e.unwrap()};return n}var Za="libp2p",Wa="autonat",Ya="1.0.0";var K;(function(r){let t;(function(c){c.DIAL="DIAL",c.DIAL_RESPONSE="DIAL_RESPONSE"})(t=r.MessageType||(r.MessageType={}));let e;(function(c){c[c.DIAL=0]="DIAL",c[c.DIAL_RESPONSE=1]="DIAL_RESPONSE"})(e||(e={})),function(c){c.codec=()=>Re(e)}(t=r.MessageType||(r.MessageType={}));let n;(function(c){c.OK="OK",c.E_DIAL_ERROR="E_DIAL_ERROR",c.E_DIAL_REFUSED="E_DIAL_REFUSED",c.E_BAD_REQUEST="E_BAD_REQUEST",c.E_INTERNAL_ERROR="E_INTERNAL_ERROR"})(n=r.ResponseStatus||(r.ResponseStatus={}));let o;(function(c){c[c.OK=0]="OK",c[c.E_DIAL_ERROR=100]="E_DIAL_ERROR",c[c.E_DIAL_REFUSED=101]="E_DIAL_REFUSED",c[c.E_BAD_REQUEST=200]="E_BAD_REQUEST",c[c.E_INTERNAL_ERROR=300]="E_INTERNAL_ERROR"})(o||(o={})),function(c){c.codec=()=>Re(o)}(n=r.ResponseStatus||(r.ResponseStatus={}));let s;(function(c){let l;c.codec=()=>(l==null&&(l=Ut((f,h,m={})=>{if(m.lengthDelimited!==!1&&h.fork(),f.id!=null&&(h.uint32(10),h.bytes(f.id)),f.addrs!=null)for(let b of f.addrs)h.uint32(18),h.bytes(b);m.lengthDelimited!==!1&&h.ldelim()},(f,h,m={})=>{let b={addrs:[]},w=h==null?f.len:f.pos+h;for(;f.pos<w;){let d=f.uint32();switch(d>>>3){case 1:{b.id=f.bytes();break}case 2:{if(m.limits?.addrs!=null&&b.addrs.length===m.limits.addrs)throw new $r('Decode error - map field "addrs" had too many elements');b.addrs.push(f.bytes());break}default:{f.skipType(d&7);break}}}return b})),l),c.encode=f=>kt(f,c.codec()),c.decode=(f,h)=>Nt(f,c.codec(),h)})(s=r.PeerInfo||(r.PeerInfo={}));let i;(function(c){let l;c.codec=()=>(l==null&&(l=Ut((f,h,m={})=>{m.lengthDelimited!==!1&&h.fork(),f.peer!=null&&(h.uint32(10),r.PeerInfo.codec().encode(f.peer,h)),m.lengthDelimited!==!1&&h.ldelim()},(f,h,m={})=>{let b={},w=h==null?f.len:f.pos+h;for(;f.pos<w;){let d=f.uint32();switch(d>>>3){case 1:{b.peer=r.PeerInfo.codec().decode(f,f.uint32(),{limits:m.limits?.peer});break}default:{f.skipType(d&7);break}}}return b})),l),c.encode=f=>kt(f,c.codec()),c.decode=(f,h)=>Nt(f,c.codec(),h)})(i=r.Dial||(r.Dial={}));let a;(function(c){let l;c.codec=()=>(l==null&&(l=Ut((f,h,m={})=>{m.lengthDelimited!==!1&&h.fork(),f.status!=null&&(h.uint32(8),r.ResponseStatus.codec().encode(f.status,h)),f.statusText!=null&&(h.uint32(18),h.string(f.statusText)),f.addr!=null&&(h.uint32(26),h.bytes(f.addr)),m.lengthDelimited!==!1&&h.ldelim()},(f,h,m={})=>{let b={},w=h==null?f.len:f.pos+h;for(;f.pos<w;){let d=f.uint32();switch(d>>>3){case 1:{b.status=r.ResponseStatus.codec().decode(f);break}case 2:{b.statusText=f.string();break}case 3:{b.addr=f.bytes();break}default:{f.skipType(d&7);break}}}return b})),l),c.encode=f=>kt(f,c.codec()),c.decode=(f,h)=>Nt(f,c.codec(),h)})(a=r.DialResponse||(r.DialResponse={}));let u;r.codec=()=>(u==null&&(u=Ut((c,l,f={})=>{f.lengthDelimited!==!1&&l.fork(),c.type!=null&&(l.uint32(8),r.MessageType.codec().encode(c.type,l)),c.dial!=null&&(l.uint32(18),r.Dial.codec().encode(c.dial,l)),c.dialResponse!=null&&(l.uint32(26),r.DialResponse.codec().encode(c.dialResponse,l)),f.lengthDelimited!==!1&&l.ldelim()},(c,l,f={})=>{let h={},m=l==null?c.len:c.pos+l;for(;c.pos<m;){let b=c.uint32();switch(b>>>3){case 1:{h.type=r.MessageType.codec().decode(c);break}case 2:{h.dial=r.Dial.codec().decode(c,c.uint32(),{limits:f.limits?.dial});break}case 3:{h.dialResponse=r.DialResponse.codec().decode(c,c.uint32(),{limits:f.limits?.dialResponse});break}default:{c.skipType(b&7);break}}}return h})),u),r.encode=c=>kt(c,r.codec()),r.decode=(c,l)=>Nt(c,r.codec(),l)})(K||(K={}));var ql=4,Hl=8,Dn=class{components;protocol;timeout;maxInboundStreams;maxOutboundStreams;maxMessageSize;started;log;topologyId;dialResults;findPeers;addressFilter;connectionThreshold;constructor(t,e){this.components=t,this.log=t.logger.forComponent("libp2p:auto-nat"),this.started=!1,this.protocol=`/${e.protocolPrefix??Za}/${Wa}/${Ya}`,this.timeout=e.timeout??3e4,this.maxInboundStreams=e.maxInboundStreams??2,this.maxOutboundStreams=e.maxOutboundStreams??20,this.connectionThreshold=e.connectionThreshold??80,this.maxMessageSize=e.maxMessageSize??8192,this.dialResults=Va({name:"libp2p_autonat_dial_results",metrics:t.metrics}),this.findPeers=Ha(this.findRandomPeers.bind(this),6e4),this.addressFilter=Yo(1024)}[Symbol.toStringTag]="@libp2p/autonat";[Es]=["@libp2p/autonat"];get[_s](){return["@libp2p/identify"]}isStarted(){return this.started}async start(){this.started||(await this.components.registrar.handle(this.protocol,t=>{this.handleIncomingAutonatStream(t).catch(e=>{this.log.error("error handling incoming autonat stream - %e",e)})},{maxInboundStreams:this.maxInboundStreams,maxOutboundStreams:this.maxOutboundStreams}),this.topologyId=await this.components.registrar.register(this.protocol,{onConnect:(t,e)=>{this.verifyExternalAddresses(e).catch(n=>{this.log.error("could not verify addresses - %e",n)})}}),this.findPeers.start(),this.started=!0)}async stop(){await this.components.registrar.unhandle(this.protocol),this.topologyId!=null&&await this.components.registrar.unhandle(this.topologyId),this.dialResults.clear(),this.findPeers.stop(),this.started=!1}allAddressesAreVerified(){return this.components.addressManager.getAddressesWithMetadata().every(t=>t.expires>Date.now()?!0:t.verified)}async findRandomPeers(t){if(this.allAddressesAreVerified())return;let e=vn([AbortSignal.timeout(1e4),t?.signal]);try{this.log("starting random walk to find peers to run AutoNAT");for await(let n of this.components.randomWalk.walk({signal:e})){if(!await this.components.connectionManager.isDialable(n.multiaddrs)){this.log.trace("random peer %p was not dialable %s",n.id,n.multiaddrs.map(o=>o.toString()).join(", "));continue}try{this.log.trace("dial random peer %p",n.id),await this.components.connectionManager.openConnection(n.multiaddrs,{signal:e})}catch{}if(this.allAddressesAreVerified()){this.log("stopping random walk, all addresses are verified");return}if(!this.hasConnectionCapacity()){this.log("stopping random walk, too close to max connections");return}}}catch{}}async handleIncomingAutonatStream(t){let e=AbortSignal.timeout(this.timeout);let n=xs(t.stream,{maxDataLength:this.maxMessageSize}).pb(K);try{let o=await n.read({signal:e}),s=await this.handleAutonatMessage(o,t.connection,{signal:e});await n.write(s,{signal:e}),await n.unwrap().unwrap().close({signal:e})}catch(o){this.log.error("error handling incoming autonat stream - %e",o),t.stream.abort(o)}}async handleAutonatMessage(t,e,n){let o=this.components.addressManager.getAddresses().map(f=>f.toOptions().host),s=t.dial;if(s==null)return this.log.error("dial was missing from message"),{type:K.MessageType.DIAL_RESPONSE,dialResponse:{status:K.ResponseStatus.E_BAD_REQUEST,statusText:"No Dial message found in message"}};let i,a=s.peer;if(a?.id==null)return this.log.error("PeerId missing from message"),{type:K.MessageType.DIAL_RESPONSE,dialResponse:{status:K.ResponseStatus.E_BAD_REQUEST,statusText:"missing peer info"}};try{let f=Qt(a.id);i=rn(f)}catch(f){return this.log.error("invalid PeerId - %e",f),{type:K.MessageType.DIAL_RESPONSE,dialResponse:{status:K.ResponseStatus.E_BAD_REQUEST,statusText:"bad peer id"}}}if(this.log("incoming request from %p",i),!e.remotePeer.equals(i))return this.log("target peer %p did not equal sending peer %p",i,e.remotePeer),{type:K.MessageType.DIAL_RESPONSE,dialResponse:{status:K.ResponseStatus.E_BAD_REQUEST,statusText:"peer id mismatch"}};let u=a.addrs.map(f=>wr(f)).filter(f=>{let h=f.toOptions();return ps(f)?!1:h.host!==e.remoteAddr.toOptions().host?(this.log.trace("not dialing %a - target host did not match remote host %a",f,e.remoteAddr),!1):o.includes(h.host)?!1:this.components.transportManager.dialTransportForMultiaddr(f)==null?(this.log.trace("not dialing %a - transport unsupported",f),!1):!0}).map(f=>(f.getPeerId()==null&&(f=f.encapsulate(`/p2p/${i.toString()}`)),f));if(u.length===0)return this.log("refused to dial all multiaddrs for %p from message",i),{type:K.MessageType.DIAL_RESPONSE,dialResponse:{status:K.ResponseStatus.E_DIAL_REFUSED,statusText:"no dialable addresses"}};this.log("dial multiaddrs %s for peer %p",u.map(f=>f.toString()).join(", "),i);let c="",l=u[0];for(let f of u){let h;l=f;try{if(h=await this.components.connectionManager.openConnection(f,n),!h.remoteAddr.equals(f))throw this.log.error("tried to dial %a but dialed %a",f,h.remoteAddr),new Error("Unexpected remote address");return this.log("successfully dialed %p via %a",i,f),{type:K.MessageType.DIAL_RESPONSE,dialResponse:{status:K.ResponseStatus.OK,addr:h.remoteAddr.decapsulateCode(ka("p2p").code).bytes}}}catch(m){this.log.error("could not dial %p - %e",i,m),c=m.message}finally{h!=null&&await h.close()}}return{type:K.MessageType.DIAL_RESPONSE,dialResponse:{status:K.ResponseStatus.E_DIAL_ERROR,statusText:c,addr:l.bytes}}}getFirstUnverifiedMultiaddr(t,e){let n=this.components.addressManager.getAddressesWithMetadata().sort((o,s)=>o.type==="observed"&&s.type!=="observed"?1:s.type==="observed"&&o.type!=="observed"?-1:0).filter(o=>!(!(o.expires<Date.now())||o.multiaddr.toOptions().family===6&&(!e||!Ua(o.multiaddr))||ps(o.multiaddr)));for(let o of n){let s=o.multiaddr.toString(),i=this.dialResults.get(s);if(i!=null){if(i.networkSegments.includes(t)){this.log.trace("%a already has a network segment result from %s",i.multiaddr,t);continue}if(i.queue.size>10){this.log.trace("%a already has enough peers queued",i.multiaddr);continue}}if(i==null){let a=o.expires<Date.now();if(a&&this.addressFilter.remove?.(s),this.addressFilter.has(s))continue;this.addressFilter.add(s),this.log.trace("creating dial result %s %s",a?"to revalidate":"for",s),i={multiaddr:o.multiaddr,success:0,failure:0,networkSegments:[],verifyingPeers:Go(),queue:new Sn({concurrency:3,maxSize:50}),type:o.type,lastVerified:o.lastVerified},this.dialResults.set(s,i)}return i}}removeOutdatedMultiaddrResults(){let t=new Set(this.components.addressManager.getAddressesWithMetadata().filter(({expires:e})=>e<Date.now()).map(({multiaddr:e})=>e.toString()));for(let e of this.dialResults.keys())t.has(e)||(this.log.trace("remove results for %a",e),this.dialResults.delete(e))}async verifyExternalAddresses(t){if(!this.isStarted())return;this.removeOutdatedMultiaddrResults();let n=(await this.components.peerStore.get(t.remotePeer)).addresses.some(({multiaddr:i})=>i.toOptions().family===6),o=this.getNetworkSegment(t.remoteAddr),s=this.getFirstUnverifiedMultiaddr(o,n);if(s==null){this.log.trace("no unverified public addresses found for peer %p to verify, not requesting verification",t.remotePeer);return}if(!this.hasConnectionCapacity()){s.lastVerified!=null?(this.log("automatically re-verifying %a because we are too close to the connection limit",s.multiaddr),this.confirmAddress(s)):this.log("skipping verifying %a because we are too close to the connection limit",s.multiaddr);return}s.queue.add(async i=>{await this.askPeerToVerify(t,o,i)},{peerId:t.remotePeer,multiaddr:s.multiaddr}).catch(i=>{s?.result==null&&this.log.error("error from %p verifying address %a - %e",t.remotePeer,s?.multiaddr,i)})}async askPeerToVerify(t,e,n){let o=this.dialResults.get(n.multiaddr.toString());if(o==null){this.log("%a was verified while %p was queued",n.multiaddr,t.remotePeer);return}let s=AbortSignal.timeout(this.timeout);this.log.trace("asking %p to verify multiaddr %s",t.remotePeer,n.multiaddr);let i=await t.newStream(this.protocol,{signal:s});try{let a=xs(i).pb(K),[,u]=await Promise.all([a.write({type:K.MessageType.DIAL,dial:{peer:{id:this.components.peerId.toMultihash().bytes,addrs:[n.multiaddr.bytes]}}},{signal:s}),a.read({signal:s})]);if(u.type!==K.MessageType.DIAL_RESPONSE||u.dialResponse==null){this.log("invalid autonat response from %p - %j",t.remotePeer,u);return}let c=u.dialResponse.status;if(this.log.trace("autonat response from %p for %a is %s",t.remotePeer,n.multiaddr,c),c!==K.ResponseStatus.OK&&c!==K.ResponseStatus.E_DIAL_ERROR)return;if(o=this.dialResults.get(n.multiaddr.toString()),o==null){this.log.trace("peer reported %a as %s but there is no result object",n.multiaddr,u.dialResponse.status);return}if(o.networkSegments.includes(e)){this.log.trace("%a results included network segment %s",n.multiaddr,e);return}if(o.result!=null){this.log.trace("already resolved result for %a, ignoring response from",n.multiaddr,t.remotePeer);return}if(o.verifyingPeers.has(t.remotePeer)){this.log.trace("peer %p has already verified %a, ignoring response",t.remotePeer,n.multiaddr);return}if(o.verifyingPeers.add(t.remotePeer),o.networkSegments.push(e),c===K.ResponseStatus.OK){if(o.success++,o.type!=="observed"){this.confirmAddress(o);return}}else c===K.ResponseStatus.E_DIAL_ERROR&&o.failure++;this.log("%a success %d failure %d",o.multiaddr,o.success,o.failure),o.success===ql&&this.confirmAddress(o),o.failure===Hl&&this.unconfirmAddress(o)}finally{try{await i.close({signal:s})}catch(a){i.abort(a)}}}hasConnectionCapacity(){let e=this.components.connectionManager.getConnections().length,n=this.components.connectionManager.getMaxConnections();return e/n*100<this.connectionThreshold}confirmAddress(t){this.log("%s address %a is externally dialable",t.type,t.multiaddr),this.components.addressManager.confirmObservedAddr(t.multiaddr),this.dialResults.delete(t.multiaddr.toString()),t.result=!0,t.queue.abort()}unconfirmAddress(t){this.log("%s address %a is not externally dialable",t.type,t.multiaddr),this.components.addressManager.removeObservedAddr(t.multiaddr),this.dialResults.delete(t.multiaddr.toString()),t.result=!1,t.queue.abort()}getNetworkSegment(t){let e=t.toOptions();return e.family===4?e.host.split(".")[0].padStart(3,"0"):e.host.split(":")[0].padStart(4,"0")}};function Vl(r={}){return t=>new Dn(t,r)}return oc(jl);})();
2
+ "use strict";var Libp2PAutonat=(()=>{var xc=Object.create;var kr=Object.defineProperty;var wc=Object.getOwnPropertyDescriptor;var Ec=Object.getOwnPropertyNames;var _c=Object.getPrototypeOf,Sc=Object.prototype.hasOwnProperty;var vc=(r,t)=>()=>(t||r((t={exports:{}}).exports,t),t.exports),gt=(r,t)=>{for(var e in t)kr(r,e,{get:t[e],enumerable:!0})},zs=(r,t,e,n)=>{if(t&&typeof t=="object"||typeof t=="function")for(let o of Ec(t))!Sc.call(r,o)&&o!==e&&kr(r,o,{get:()=>t[o],enumerable:!(n=wc(t,o))||n.enumerable});return r};var Ac=(r,t,e)=>(e=r!=null?xc(_c(r)):{},zs(t||!r||!r.__esModule?kr(e,"default",{value:r,enumerable:!0}):e,r)),Ic=r=>zs(kr({},"__esModule",{value:!0}),r);var sc=vc(Or=>{(function(){var r,t,e,n,o,s,i,a;a=function(u){var c,h,f,l;return c=(u&255<<24)>>>24,h=(u&255<<16)>>>16,f=(u&65280)>>>8,l=u&255,[c,h,f,l].join(".")},i=function(u){var c,h,f,l,d,m;for(c=[],f=l=0;l<=3&&u.length!==0;f=++l){if(f>0){if(u[0]!==".")throw new Error("Invalid IP");u=u.substring(1)}m=t(u),d=m[0],h=m[1],u=u.substring(h),c.push(d)}if(u.length!==0)throw new Error("Invalid IP");switch(c.length){case 1:if(c[0]>4294967295)throw new Error("Invalid IP");return c[0]>>>0;case 2:if(c[0]>255||c[1]>16777215)throw new Error("Invalid IP");return(c[0]<<24|c[1])>>>0;case 3:if(c[0]>255||c[1]>255||c[2]>65535)throw new Error("Invalid IP");return(c[0]<<24|c[1]<<16|c[2])>>>0;case 4:if(c[0]>255||c[1]>255||c[2]>255||c[3]>255)throw new Error("Invalid IP");return(c[0]<<24|c[1]<<16|c[2]<<8|c[3])>>>0;default:throw new Error("Invalid IP")}},e=function(u){return u.charCodeAt(0)},n=e("0"),s=e("a"),o=e("A"),t=function(u){var c,h,f,l,d;for(l=0,c=10,h="9",f=0,u.length>1&&u[f]==="0"&&(u[f+1]==="x"||u[f+1]==="X"?(f+=2,c=16):"0"<=u[f+1]&&u[f+1]<="9"&&(f++,c=8,h="7")),d=f;f<u.length;){if("0"<=u[f]&&u[f]<=h)l=l*c+(e(u[f])-n)>>>0;else if(c===16)if("a"<=u[f]&&u[f]<="f")l=l*c+(10+e(u[f])-s)>>>0;else if("A"<=u[f]&&u[f]<="F")l=l*c+(10+e(u[f])-o)>>>0;else break;else break;if(l>4294967295)throw new Error("too large");f++}if(f===d)throw new Error("empty octet");return[l,f]},r=function(){function u(c,h){var f,l,d,m;if(typeof c!="string")throw new Error("Missing `net' parameter");if(h||(m=c.split("/",2),c=m[0],h=m[1]),h||(h=32),typeof h=="string"&&h.indexOf(".")>-1){try{this.maskLong=i(h)}catch(y){throw f=y,new Error("Invalid mask: "+h)}for(l=d=32;d>=0;l=--d)if(this.maskLong===4294967295<<32-l>>>0){this.bitmask=l;break}}else if(h||h===0)this.bitmask=parseInt(h,10),this.maskLong=0,this.bitmask>0&&(this.maskLong=4294967295<<32-this.bitmask>>>0);else throw new Error("Invalid mask: empty");try{this.netLong=(i(c)&this.maskLong)>>>0}catch(y){throw f=y,new Error("Invalid net address: "+c)}if(!(this.bitmask<=32))throw new Error("Invalid mask for ip4: "+h);this.size=Math.pow(2,32-this.bitmask),this.base=a(this.netLong),this.mask=a(this.maskLong),this.hostmask=a(~this.maskLong),this.first=this.bitmask<=30?a(this.netLong+1):this.base,this.last=this.bitmask<=30?a(this.netLong+this.size-2):a(this.netLong+this.size-1),this.broadcast=this.bitmask<=30?a(this.netLong+this.size-1):void 0}return u.prototype.contains=function(c){return typeof c=="string"&&(c.indexOf("/")>0||c.split(".").length!==4)&&(c=new u(c)),c instanceof u?this.contains(c.base)&&this.contains(c.broadcast||c.last):(i(c)&this.maskLong)>>>0===(this.netLong&this.maskLong)>>>0},u.prototype.next=function(c){return c==null&&(c=1),new u(a(this.netLong+this.size*c),this.mask)},u.prototype.forEach=function(c){var h,f,l;for(l=i(this.first),f=i(this.last),h=0;l<=f;)c(a(l),l,h),h++,l++},u.prototype.toString=function(){return this.base+"/"+this.bitmask},u}(),Or.ip2long=i,Or.long2ip=a,Or.Netmask=r}).call(Or)});var bh={};gt(bh,{autoNAT:()=>yh});var qn=Symbol.for("@libp2p/peer-id");var Ct=class extends Error{static name="AbortError";constructor(t="The operation was aborted"){super(t),this.name="AbortError"}};var Lt=class extends Error{static name="InvalidParametersError";constructor(t="Invalid parameters"){super(t),this.name="InvalidParametersError"}},Ur=class extends Error{static name="InvalidPublicKeyError";constructor(t="Invalid public key"){super(t),this.name="InvalidPublicKeyError"}};var Mr=class extends Error{static name="InvalidMultihashError";constructor(t="Invalid Multihash"){super(t),this.name="InvalidMultihashError"}};var rr=class extends Error{static name="UnsupportedKeyTypeError";constructor(t="Unsupported key type"){super(t),this.name="UnsupportedKeyTypeError"}};var Kr=class extends EventTarget{#t=new Map;constructor(){super()}listenerCount(t){let e=this.#t.get(t);return e==null?0:e.length}addEventListener(t,e,n){super.addEventListener(t,e,n);let o=this.#t.get(t);o==null&&(o=[],this.#t.set(t,o)),o.push({callback:e,once:(n!==!0&&n!==!1&&n?.once)??!1})}removeEventListener(t,e,n){super.removeEventListener(t.toString(),e??null,n);let o=this.#t.get(t);o!=null&&(o=o.filter(({callback:s})=>s!==e),this.#t.set(t,o))}dispatchEvent(t){let e=super.dispatchEvent(t),n=this.#t.get(t.type);return n==null||(n=n.filter(({once:o})=>!o),this.#t.set(t.type,n)),e}safeDispatchEvent(t,e={}){return this.dispatchEvent(new CustomEvent(t,e))}};var qs=Symbol.for("@libp2p/service-capabilities"),Hs=Symbol.for("@libp2p/service-dependencies");var $n={};gt($n,{base58btc:()=>Z,base58flickr:()=>Rc});var Vh=new Uint8Array(0);function Vs(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 Pt(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 js(r){return new TextEncoder().encode(r)}function Gs(r){return new TextDecoder().decode(r)}function Bc(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,u=r.charAt(0),c=Math.log(a)/Math.log(256),h=Math.log(256)/Math.log(a);function f(m){if(m instanceof Uint8Array||(ArrayBuffer.isView(m)?m=new Uint8Array(m.buffer,m.byteOffset,m.byteLength):Array.isArray(m)&&(m=Uint8Array.from(m))),!(m instanceof Uint8Array))throw new TypeError("Expected Uint8Array");if(m.length===0)return"";for(var y=0,p=0,_=0,I=m.length;_!==I&&m[_]===0;)_++,y++;for(var S=(I-_)*h+1>>>0,D=new Uint8Array(S);_!==I;){for(var R=m[_],B=0,k=S-1;(R!==0||B<p)&&k!==-1;k--,B++)R+=256*D[k]>>>0,D[k]=R%a>>>0,R=R/a>>>0;if(R!==0)throw new Error("Non-zero carry");p=B,_++}for(var U=S-p;U!==S&&D[U]===0;)U++;for(var C=u.repeat(y);U<S;++U)C+=r.charAt(D[U]);return C}function l(m){if(typeof m!="string")throw new TypeError("Expected String");if(m.length===0)return new Uint8Array;var y=0;if(m[y]!==" "){for(var p=0,_=0;m[y]===u;)p++,y++;for(var I=(m.length-y)*c+1>>>0,S=new Uint8Array(I);m[y];){var D=e[m.charCodeAt(y)];if(D===255)return;for(var R=0,B=I-1;(D!==0||R<_)&&B!==-1;B--,R++)D+=a*S[B]>>>0,S[B]=D%256>>>0,D=D/256>>>0;if(D!==0)throw new Error("Non-zero carry");_=R,y++}if(m[y]!==" "){for(var k=I-_;k!==I&&S[k]===0;)k++;for(var U=new Uint8Array(p+(I-k)),C=p;k!==I;)U[C++]=S[k++];return U}}}function d(m){var y=l(m);if(y)return y;throw new Error(`Non-${t} character`)}return{encode:f,decodeUnsafe:l,decode:d}}var Tc=Bc,Dc=Tc,Zs=Dc;var Hn=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")}},Vn=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 Xs(this,t)}},jn=class{decoders;constructor(t){this.decoders=t}or(t){return Xs(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 Xs(r,t){return new jn({...r.decoders??{[r.prefix]:r},...t.decoders??{[t.prefix]:t}})}var Gn=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 Hn(t,e,n),this.decoder=new Vn(t,e,o)}encode(t){return this.encoder.encode(t)}decode(t){return this.decoder.decode(t)}};function Te({name:r,prefix:t,encode:e,decode:n}){return new Gn(r,t,e,n)}function Qt({name:r,prefix:t,alphabet:e}){let{encode:n,decode:o}=Zs(e,r);return Te({prefix:t,name:r,encode:n,decode:s=>Pt(o(s))})}function Cc(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,u=0;for(let c=0;c<o;++c){let h=t[r[c]];if(h===void 0)throw new SyntaxError(`Non-${n} character`);a=a<<e|h,i+=e,i>=8&&(i-=8,s[u++]=255&a>>i)}if(i>=e||(255&a<<8-i)!==0)throw new SyntaxError("Unexpected end of data");return s}function Lc(r,t,e){let n=t[t.length-1]==="=",o=(1<<e)-1,s="",i=0,a=0;for(let u=0;u<r.length;++u)for(a=a<<8|r[u],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 Pc(r){let t={};for(let e=0;e<r.length;++e)t[r[e]]=e;return t}function X({name:r,prefix:t,bitsPerChar:e,alphabet:n}){let o=Pc(n);return Te({prefix:t,name:r,encode(s){return Lc(s,n,e)},decode(s){return Cc(s,o,e,r)}})}var Z=Qt({name:"base58btc",prefix:"z",alphabet:"123456789ABCDEFGHJKLMNPQRSTUVWXYZabcdefghijkmnopqrstuvwxyz"}),Rc=Qt({name:"base58flickr",prefix:"Z",alphabet:"123456789abcdefghijkmnopqrstuvwxyzABCDEFGHJKLMNPQRSTUVWXYZ"});var Zn={};gt(Zn,{base32:()=>Jt,base32hex:()=>Uc,base32hexpad:()=>Kc,base32hexpadupper:()=>Fc,base32hexupper:()=>Mc,base32pad:()=>Nc,base32padupper:()=>kc,base32upper:()=>Oc,base32z:()=>zc});var Jt=X({prefix:"b",name:"base32",alphabet:"abcdefghijklmnopqrstuvwxyz234567",bitsPerChar:5}),Oc=X({prefix:"B",name:"base32upper",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZ234567",bitsPerChar:5}),Nc=X({prefix:"c",name:"base32pad",alphabet:"abcdefghijklmnopqrstuvwxyz234567=",bitsPerChar:5}),kc=X({prefix:"C",name:"base32padupper",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZ234567=",bitsPerChar:5}),Uc=X({prefix:"v",name:"base32hex",alphabet:"0123456789abcdefghijklmnopqrstuv",bitsPerChar:5}),Mc=X({prefix:"V",name:"base32hexupper",alphabet:"0123456789ABCDEFGHIJKLMNOPQRSTUV",bitsPerChar:5}),Kc=X({prefix:"t",name:"base32hexpad",alphabet:"0123456789abcdefghijklmnopqrstuv=",bitsPerChar:5}),Fc=X({prefix:"T",name:"base32hexpadupper",alphabet:"0123456789ABCDEFGHIJKLMNOPQRSTUV=",bitsPerChar:5}),zc=X({prefix:"h",name:"base32z",alphabet:"ybndrfg8ejkmcpqxot1uwisza345h769",bitsPerChar:5});var Xn={};gt(Xn,{base36:()=>nr,base36upper:()=>qc});var nr=Qt({prefix:"k",name:"base36",alphabet:"0123456789abcdefghijklmnopqrstuvwxyz"}),qc=Qt({prefix:"K",name:"base36upper",alphabet:"0123456789ABCDEFGHIJKLMNOPQRSTUVWXYZ"});var Hc=Qs,Ys=128,Vc=127,jc=~Vc,Gc=Math.pow(2,31);function Qs(r,t,e){t=t||[],e=e||0;for(var n=e;r>=Gc;)t[e++]=r&255|Ys,r/=128;for(;r&jc;)t[e++]=r&255|Ys,r>>>=7;return t[e]=r|0,Qs.bytes=e-n+1,t}var $c=Yn,Zc=128,Ws=127;function Yn(r,n){var e=0,n=n||0,o=0,s=n,i,a=r.length;do{if(s>=a)throw Yn.bytes=0,new RangeError("Could not decode varint");i=r[s++],e+=o<28?(i&Ws)<<o:(i&Ws)*Math.pow(2,o),o+=7}while(i>=Zc);return Yn.bytes=s-n,e}var Xc=Math.pow(2,7),Yc=Math.pow(2,14),Wc=Math.pow(2,21),Qc=Math.pow(2,28),Jc=Math.pow(2,35),tu=Math.pow(2,42),eu=Math.pow(2,49),ru=Math.pow(2,56),nu=Math.pow(2,63),ou=function(r){return r<Xc?1:r<Yc?2:r<Wc?3:r<Qc?4:r<Jc?5:r<tu?6:r<eu?7:r<ru?8:r<nu?9:10},su={encode:Hc,decode:$c,encodingLength:ou},iu=su,or=iu;function sr(r,t=0){return[or.decode(r,t),or.decode.bytes]}function De(r,t,e=0){return or.encode(r,t,e),t}function Ce(r){return or.encodingLength(r)}function fe(r,t){let e=t.byteLength,n=Ce(r),o=n+Ce(e),s=new Uint8Array(o+e);return De(r,s,0),De(e,s,n),s.set(t,o),new Le(r,e,t,s)}function le(r){let t=Pt(r),[e,n]=sr(t),[o,s]=sr(t.subarray(n)),i=t.subarray(n+s);if(i.byteLength!==o)throw new Error("Incorrect length");return new Le(e,o,i,t)}function Js(r,t){if(r===t)return!0;{let e=t;return r.code===e.code&&r.size===e.size&&e.bytes instanceof Uint8Array&&Vs(r.bytes,e.bytes)}}var Le=class{code;size;digest;bytes;constructor(t,e,n,o){this.code=t,this.size=e,this.digest=n,this.bytes=o}};function ti(r,t){let{bytes:e,version:n}=r;switch(n){case 0:return cu(e,Wn(r),t??Z.encoder);default:return uu(e,Wn(r),t??Jt.encoder)}}var ei=new WeakMap;function Wn(r){let t=ei.get(r);if(t==null){let e=new Map;return ei.set(r,e),e}return t}var et=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!==ir)throw new Error("Cannot convert a non dag-pb CID to CIDv0");if(e.code!==fu)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=fe(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&&Js(t.multihash,n.multihash)}toString(t){return ti(this,t)}toJSON(){return{"/":ti(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??ri(n,o,s.bytes))}else if(e[lu]===!0){let{version:n,multihash:o,code:s}=e,i=le(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!==ir)throw new Error(`Version 0 CID must use dag-pb (code: ${ir}) block encoding`);return new r(t,e,n,n.bytes)}case 1:{let o=ri(t,e,n.bytes);return new r(t,e,n,o)}default:throw new Error("Invalid version")}}static createV0(t){return r.create(0,ir,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=Pt(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 Le(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[f,l]=sr(t.subarray(e));return e+=l,f},o=n(),s=ir;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(),u=n(),c=e+u,h=c-i;return{version:o,codec:s,multihashCode:a,digestSize:u,multihashSize:h,size:c}}static parse(t,e){let[n,o]=au(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 Wn(s).set(n,t),s}};function au(r,t){switch(r[0]){case"Q":{let e=t??Z;return[Z.prefix,e.decode(`${Z.prefix}${r}`)]}case Z.prefix:{let e=t??Z;return[Z.prefix,e.decode(r)]}case Jt.prefix:{let e=t??Jt;return[Jt.prefix,e.decode(r)]}case nr.prefix:{let e=t??nr;return[nr.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 cu(r,t,e){let{prefix:n}=e;if(n!==Z.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 uu(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 ir=112,fu=18;function ri(r,t,e){let n=Ce(r),o=n+Ce(t),s=new Uint8Array(o+e.byteLength);return De(r,s,0),De(t,s,n),s.set(e,o),s}var lu=Symbol.for("@ipld/js-cid/CID");var Qn={};gt(Qn,{identity:()=>_t});var ni=0,hu="identity",oi=Pt;function du(r){return fe(ni,oi(r))}var _t={code:ni,name:hu,encode:oi,digest:du};function ct(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 St(r=0){return new Uint8Array(r)}function ft(r=0){return new Uint8Array(r)}function Rt(r,t){t==null&&(t=r.reduce((o,s)=>o+s.length,0));let e=ft(t),n=0;for(let o of r)e.set(o,n),n+=o.length;return e}var ii=Symbol.for("@achingbrain/uint8arraylist");function si(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 zr(r){return!!r?.[ii]}var J=class r{bufs;length;[ii]=!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(zr(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(zr(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=si(this.bufs,t);return e.buf[e.index]}set(t,e){let n=si(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(zr(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 Rt(n,o)}subarray(t,e){let{bufs:n,length:o}=this._subList(t,e);return n.length===1?n[0]:Rt(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,u=a+i.byteLength;if(o=u,t>=u)continue;let c=t>=a&&t<u,h=e>a&&e<=u;if(c&&h){if(t===a&&e===u){n.push(i);break}let f=t-a;n.push(i.subarray(f,f+(e-t)));break}if(c){if(t===0){n.push(i);continue}n.push(i.subarray(t-a));continue}if(h){if(e===u){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(!zr(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 f=0;f<s;f++)i[f]=-1;for(let f=0;f<o;f++)i[n[f]]=f;let a=i,u=this.byteLength-n.byteLength,c=n.byteLength-1,h;for(let f=e;f<=u;f+=h){h=0;for(let l=c;l>=0;l--){let d=this.get(f+l);if(n[l]!==d){h=Math.max(1,l-a[d]);break}}if(h===0)return f}return-1}getInt8(t){let e=this.subarray(t,t+1);return new DataView(e.buffer,e.byteOffset,e.byteLength).getInt8(0)}setInt8(t,e){let n=ft(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=St(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=St(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=St(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=ft(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=St(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=St(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=St(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=St(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=St(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(!ct(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 Jn={};gt(Jn,{base10:()=>pu});var pu=Qt({prefix:"9",name:"base10",alphabet:"0123456789"});var to={};gt(to,{base16:()=>mu,base16upper:()=>gu});var mu=X({prefix:"f",name:"base16",alphabet:"0123456789abcdef",bitsPerChar:4}),gu=X({prefix:"F",name:"base16upper",alphabet:"0123456789ABCDEF",bitsPerChar:4});var eo={};gt(eo,{base2:()=>yu});var yu=X({prefix:"0",name:"base2",alphabet:"01",bitsPerChar:1});var ro={};gt(ro,{base256emoji:()=>_u});var ai=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}"),bu=ai.reduce((r,t,e)=>(r[e]=t,r),[]),xu=ai.reduce((r,t,e)=>{let n=t.codePointAt(0);if(n==null)throw new Error(`Invalid character: ${t}`);return r[n]=e,r},[]);function wu(r){return r.reduce((t,e)=>(t+=bu[e],t),"")}function Eu(r){let t=[];for(let e of r){let n=e.codePointAt(0);if(n==null)throw new Error(`Invalid character: ${e}`);let o=xu[n];if(o==null)throw new Error(`Non-base256emoji character: ${e}`);t.push(o)}return new Uint8Array(t)}var _u=Te({prefix:"\u{1F680}",name:"base256emoji",encode:wu,decode:Eu});var oo={};gt(oo,{base64:()=>Su,base64pad:()=>vu,base64url:()=>no,base64urlpad:()=>Au});var Su=X({prefix:"m",name:"base64",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/",bitsPerChar:6}),vu=X({prefix:"M",name:"base64pad",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/=",bitsPerChar:6}),no=X({prefix:"u",name:"base64url",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789-_",bitsPerChar:6}),Au=X({prefix:"U",name:"base64urlpad",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789-_=",bitsPerChar:6});var so={};gt(so,{base8:()=>Iu});var Iu=X({prefix:"7",name:"base8",alphabet:"01234567",bitsPerChar:3});var io={};gt(io,{identity:()=>Bu});var Bu=Te({prefix:"\0",name:"identity",encode:r=>Gs(r),decode:r=>js(r)});var Bd=new TextEncoder,Td=new TextDecoder;var uo={};gt(uo,{sha256:()=>ar,sha512:()=>Cu});function co({name:r,code:t,encode:e}){return new ao(r,t,e)}var ao=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?fe(this.code,e):e.then(n=>fe(this.code,n))}else throw Error("Unknown type, must be binary type")}};function ui(r){return async t=>new Uint8Array(await crypto.subtle.digest(r,t))}var ar=co({name:"sha2-256",code:18,encode:ui("SHA-256")}),Cu=co({name:"sha2-512",code:19,encode:ui("SHA-512")});var cr={...io,...eo,...so,...Jn,...to,...Zn,...Xn,...$n,...oo,...ro},Fd={...uo,...Qn};function li(r,t,e,n){return{name:r,prefix:t,encoder:{name:r,prefix:t,encode:e},decoder:{decode:n}}}var fi=li("utf8","u",r=>"u"+new TextDecoder("utf8").decode(r),r=>new TextEncoder().encode(r.substring(1))),fo=li("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=ft(r.length);for(let e=0;e<r.length;e++)t[e]=r.charCodeAt(e);return t}),Lu={utf8:fi,"utf-8":fi,hex:cr.base16,latin1:fo,ascii:fo,binary:fo,...cr},qr=Lu;function H(r,t="utf8"){let e=qr[t];if(e==null)throw new Error(`Unsupported encoding "${t}"`);return e.decoder.decode(`${e.prefix}${r}`)}function G(r,t="utf8"){let e=qr[t];if(e==null)throw new Error(`Unsupported encoding "${t}"`);return e.encoder.encode(r).substring(1)}var Pu=parseInt("11111",2),lo=parseInt("10000000",2),Ru=parseInt("01111111",2),hi={0:ur,1:ur,2:Ou,3:Uu,4:Mu,5:ku,6:Nu,16:ur,22:ur,48:ur};function ho(r,t={offset:0}){let e=r[t.offset]&Pu;if(t.offset++,hi[e]!=null)return hi[e](r,t);throw new Error("No decoder for tag "+e)}function fr(r,t){let e=0;if((r[t.offset]&lo)===lo){let n=r[t.offset]&Ru,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 ur(r,t){fr(r,t);let e=[];for(;!(t.offset>=r.byteLength);){let n=ho(r,t);if(n===null)break;e.push(n)}return e}function Ou(r,t){let e=fr(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 Nu(r,t){let e=fr(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}`,u=[];for(;t.offset<n;){let c=r[t.offset];if(t.offset++,u.push(c&127),c<128){u.reverse();let h=0;for(let f=0;f<u.length;f++)h+=u[f]<<f*7;a+=`.${h}`,u=[]}}return a}function ku(r,t){return t.offset++,null}function Uu(r,t){let e=fr(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 Mu(r,t){let e=fr(r,t),n=r.subarray(t.offset,t.offset+e);return t.offset+=e,n}function Ku(r){let t=r.toString(16);t.length%2===1&&(t="0"+t);let e=new J;for(let n=0;n<t.length;n+=2)e.append(Uint8Array.from([parseInt(`${t[n]}${t[n+1]}`,16)]));return e}function po(r){if(r.byteLength<128)return Uint8Array.from([r.byteLength]);let t=Ku(r.byteLength);return new J(Uint8Array.from([t.byteLength|lo]),t)}function di(r){let t=new J,e=128;return(r.subarray()[0]&e)===e&&t.append(Uint8Array.from([0])),t.append(r),new J(Uint8Array.from([2]),po(t),t)}function pi(r){let t=Uint8Array.from([0]),e=new J(t,r);return new J(Uint8Array.from([3]),po(e),e)}function Hr(r,t=48){let e=new J;for(let n of r)e.append(n);return new J(Uint8Array.from([t]),po(e),e)}async function mi(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 Fu=Uint8Array.from([6,8,42,134,72,206,61,3,1,7]),zu=Uint8Array.from([6,5,43,129,4,0,34]),qu=Uint8Array.from([6,5,43,129,4,0,35]),Hu={ext:!0,kty:"EC",crv:"P-256"},Vu={ext:!0,kty:"EC",crv:"P-384"},ju={ext:!0,kty:"EC",crv:"P-521"},mo=32,go=48,yo=66;function gi(r){let t=ho(r);return yi(t)}function yi(r){let t=r[1][1][0],e=1,n,o;if(t.byteLength===mo*2+1)return n=G(t.subarray(e,e+mo),"base64url"),o=G(t.subarray(e+mo),"base64url"),new Pe({...Hu,key_ops:["verify"],x:n,y:o});if(t.byteLength===go*2+1)return n=G(t.subarray(e,e+go),"base64url"),o=G(t.subarray(e+go),"base64url"),new Pe({...Vu,key_ops:["verify"],x:n,y:o});if(t.byteLength===yo*2+1)return n=G(t.subarray(e,e+yo),"base64url"),o=G(t.subarray(e+yo),"base64url"),new Pe({...ju,key_ops:["verify"],x:n,y:o});throw new Lt(`coordinates were wrong length, got ${t.byteLength}, expected 65, 97 or 133`)}function bi(r){return Hr([di(Uint8Array.from([1])),Hr([Gu(r.crv)],160),Hr([pi(new J(Uint8Array.from([4]),H(r.x??"","base64url"),H(r.y??"","base64url")))],161)]).subarray()}function Gu(r){if(r==="P-256")return Fu;if(r==="P-384")return zu;if(r==="P-521")return qu;throw new Lt(`Invalid curve ${r}`)}var Pe=class{type="ECDSA";jwk;_raw;constructor(t){this.jwk=t}get raw(){return this._raw==null&&(this._raw=bi(this.jwk)),this._raw}toMultihash(){return _t.digest(Re(this))}toCID(){return et.createV1(114,this.toMultihash())}toString(){return Z.encode(this.toMultihash().bytes).substring(1)}equals(t){return t==null||!(t.raw instanceof Uint8Array)?!1:ct(this.raw,t.raw)}async verify(t,e,n){return mi(this.jwk,e,t,n)}};var he=typeof globalThis=="object"&&"crypto"in globalThis?globalThis.crypto:void 0;function de(r){return r instanceof Uint8Array||ArrayBuffer.isView(r)&&r.constructor.name==="Uint8Array"}function lr(r){if(!Number.isSafeInteger(r)||r<0)throw new Error("positive integer expected, got "+r)}function Y(r,...t){if(!de(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");lr(r.outputLen),lr(r.blockLen)}function Ne(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 wi(r,t){Y(r);let e=t.outputLen;if(r.length<e)throw new Error("digestInto() expects output buffer of length at least "+e)}function Nt(...r){for(let t=0;t<r.length;t++)r[t].fill(0)}function jr(r){return new DataView(r.buffer,r.byteOffset,r.byteLength)}function vt(r,t){return r<<32-t|r>>>t}var Ei=typeof Uint8Array.from([]).toHex=="function"&&typeof Uint8Array.fromHex=="function",$u=Array.from({length:256},(r,t)=>t.toString(16).padStart(2,"0"));function Et(r){if(Y(r),Ei)return r.toHex();let t="";for(let e=0;e<r.length;e++)t+=$u[r[e]];return t}var Ot={_0:48,_9:57,A:65,F:70,a:97,f:102};function xi(r){if(r>=Ot._0&&r<=Ot._9)return r-Ot._0;if(r>=Ot.A&&r<=Ot.F)return r-(Ot.A-10);if(r>=Ot.a&&r<=Ot.f)return r-(Ot.a-10)}function pe(r){if(typeof r!="string")throw new Error("hex string expected, got "+typeof r);if(Ei)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=xi(r.charCodeAt(s)),a=xi(r.charCodeAt(s+1));if(i===void 0||a===void 0){let u=r[s]+r[s+1];throw new Error('hex string expected, got non-hex character "'+u+'" at index '+s)}n[o]=i*16+a}return n}function bo(r){if(typeof r!="string")throw new Error("string expected");return new Uint8Array(new TextEncoder().encode(r))}function hr(r){return typeof r=="string"&&(r=bo(r)),Y(r),r}function lt(...r){let t=0;for(let n=0;n<r.length;n++){let o=r[n];Y(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 Oe=class{};function xo(r){let t=n=>r().update(hr(n)).digest(),e=r();return t.outputLen=e.outputLen,t.blockLen=e.blockLen,t.create=()=>r(),t}function dr(r=32){if(he&&typeof he.getRandomValues=="function")return he.getRandomValues(new Uint8Array(r));if(he&&typeof he.randomBytes=="function")return Uint8Array.from(he.randomBytes(r));throw new Error("crypto.getRandomValues must be defined")}function Zu(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),u=n?4:0,c=n?0:4;r.setUint32(t+u,i,n),r.setUint32(t+c,a,n)}function _i(r,t,e){return r&t^~r&e}function Si(r,t,e){return r&t^r&e^t&e}var pr=class extends Oe{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=jr(this.buffer)}update(t){Ne(this),t=hr(t),Y(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 u=jr(t);for(;o<=s-i;i+=o)this.process(u,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){Ne(this),wi(t,this),this.finished=!0;let{buffer:e,view:n,blockLen:o,isLE:s}=this,{pos:i}=this;e[i++]=128,Nt(this.buffer.subarray(i)),this.padOffset>o-i&&(this.process(n,0),i=0);for(let f=i;f<o;f++)e[f]=0;Zu(n,o-8,BigInt(this.length*8),s),this.process(n,0);let a=jr(t),u=this.outputLen;if(u%4)throw new Error("_sha2: outputLen should be aligned to 32bit");let c=u/4,h=this.get();if(c>h.length)throw new Error("_sha2: outputLen bigger than state");for(let f=0;f<c;f++)a.setUint32(4*f,h[f],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()}},kt=Uint32Array.from([1779033703,3144134277,1013904242,2773480762,1359893119,2600822924,528734635,1541459225]);var ot=Uint32Array.from([1779033703,4089235720,3144134277,2227873595,1013904242,4271175723,2773480762,1595750129,1359893119,2917565137,2600822924,725511199,528734635,4215389547,1541459225,327033209]);var Gr=BigInt(4294967295),vi=BigInt(32);function Xu(r,t=!1){return t?{h:Number(r&Gr),l:Number(r>>vi&Gr)}:{h:Number(r>>vi&Gr)|0,l:Number(r&Gr)|0}}function Ai(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}=Xu(r[s],t);[n[s],o[s]]=[i,a]}return[n,o]}var wo=(r,t,e)=>r>>>e,Eo=(r,t,e)=>r<<32-e|t>>>e,me=(r,t,e)=>r>>>e|t<<32-e,ge=(r,t,e)=>r<<32-e|t>>>e,mr=(r,t,e)=>r<<64-e|t>>>e-32,gr=(r,t,e)=>r>>>e-32|t<<64-e;function Tt(r,t,e,n){let o=(t>>>0)+(n>>>0);return{h:r+e+(o/2**32|0)|0,l:o|0}}var Ii=(r,t,e)=>(r>>>0)+(t>>>0)+(e>>>0),Bi=(r,t,e,n)=>t+e+n+(r/2**32|0)|0,Ti=(r,t,e,n)=>(r>>>0)+(t>>>0)+(e>>>0)+(n>>>0),Di=(r,t,e,n,o)=>t+e+n+o+(r/2**32|0)|0,Ci=(r,t,e,n,o)=>(r>>>0)+(t>>>0)+(e>>>0)+(n>>>0)+(o>>>0),Li=(r,t,e,n,o,s)=>t+e+n+o+s+(r/2**32|0)|0;var Wu=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]),ee=new Uint32Array(64),_o=class extends pr{constructor(t=32){super(64,t,8,!1),this.A=kt[0]|0,this.B=kt[1]|0,this.C=kt[2]|0,this.D=kt[3]|0,this.E=kt[4]|0,this.F=kt[5]|0,this.G=kt[6]|0,this.H=kt[7]|0}get(){let{A:t,B:e,C:n,D:o,E:s,F:i,G:a,H:u}=this;return[t,e,n,o,s,i,a,u]}set(t,e,n,o,s,i,a,u){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=u|0}process(t,e){for(let f=0;f<16;f++,e+=4)ee[f]=t.getUint32(e,!1);for(let f=16;f<64;f++){let l=ee[f-15],d=ee[f-2],m=vt(l,7)^vt(l,18)^l>>>3,y=vt(d,17)^vt(d,19)^d>>>10;ee[f]=y+ee[f-7]+m+ee[f-16]|0}let{A:n,B:o,C:s,D:i,E:a,F:u,G:c,H:h}=this;for(let f=0;f<64;f++){let l=vt(a,6)^vt(a,11)^vt(a,25),d=h+l+_i(a,u,c)+Wu[f]+ee[f]|0,y=(vt(n,2)^vt(n,13)^vt(n,22))+Si(n,o,s)|0;h=c,c=u,u=a,a=i+d|0,i=s,s=o,o=n,n=d+y|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,u=u+this.F|0,c=c+this.G|0,h=h+this.H|0,this.set(n,o,s,i,a,u,c,h)}roundClean(){Nt(ee)}destroy(){this.set(0,0,0,0,0,0,0,0),Nt(this.buffer)}};var Pi=Ai(["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))),Qu=Pi[0],Ju=Pi[1],re=new Uint32Array(80),ne=new Uint32Array(80),So=class extends pr{constructor(t=64){super(128,t,16,!1),this.Ah=ot[0]|0,this.Al=ot[1]|0,this.Bh=ot[2]|0,this.Bl=ot[3]|0,this.Ch=ot[4]|0,this.Cl=ot[5]|0,this.Dh=ot[6]|0,this.Dl=ot[7]|0,this.Eh=ot[8]|0,this.El=ot[9]|0,this.Fh=ot[10]|0,this.Fl=ot[11]|0,this.Gh=ot[12]|0,this.Gl=ot[13]|0,this.Hh=ot[14]|0,this.Hl=ot[15]|0}get(){let{Ah:t,Al:e,Bh:n,Bl:o,Ch:s,Cl:i,Dh:a,Dl:u,Eh:c,El:h,Fh:f,Fl:l,Gh:d,Gl:m,Hh:y,Hl:p}=this;return[t,e,n,o,s,i,a,u,c,h,f,l,d,m,y,p]}set(t,e,n,o,s,i,a,u,c,h,f,l,d,m,y,p){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=u|0,this.Eh=c|0,this.El=h|0,this.Fh=f|0,this.Fl=l|0,this.Gh=d|0,this.Gl=m|0,this.Hh=y|0,this.Hl=p|0}process(t,e){for(let S=0;S<16;S++,e+=4)re[S]=t.getUint32(e),ne[S]=t.getUint32(e+=4);for(let S=16;S<80;S++){let D=re[S-15]|0,R=ne[S-15]|0,B=me(D,R,1)^me(D,R,8)^wo(D,R,7),k=ge(D,R,1)^ge(D,R,8)^Eo(D,R,7),U=re[S-2]|0,C=ne[S-2]|0,b=me(U,C,19)^mr(U,C,61)^wo(U,C,6),g=ge(U,C,19)^gr(U,C,61)^Eo(U,C,6),E=Ti(k,g,ne[S-7],ne[S-16]),v=Di(E,B,b,re[S-7],re[S-16]);re[S]=v|0,ne[S]=E|0}let{Ah:n,Al:o,Bh:s,Bl:i,Ch:a,Cl:u,Dh:c,Dl:h,Eh:f,El:l,Fh:d,Fl:m,Gh:y,Gl:p,Hh:_,Hl:I}=this;for(let S=0;S<80;S++){let D=me(f,l,14)^me(f,l,18)^mr(f,l,41),R=ge(f,l,14)^ge(f,l,18)^gr(f,l,41),B=f&d^~f&y,k=l&m^~l&p,U=Ci(I,R,k,Ju[S],ne[S]),C=Li(U,_,D,B,Qu[S],re[S]),b=U|0,g=me(n,o,28)^mr(n,o,34)^mr(n,o,39),E=ge(n,o,28)^gr(n,o,34)^gr(n,o,39),v=n&s^n&a^s&a,L=o&i^o&u^i&u;_=y|0,I=p|0,y=d|0,p=m|0,d=f|0,m=l|0,{h:f,l}=Tt(c|0,h|0,C|0,b|0),c=a|0,h=u|0,a=s|0,u=i|0,s=n|0,i=o|0;let P=Ii(b,E,L);n=Bi(P,C,g,v),o=P|0}({h:n,l:o}=Tt(this.Ah|0,this.Al|0,n|0,o|0)),{h:s,l:i}=Tt(this.Bh|0,this.Bl|0,s|0,i|0),{h:a,l:u}=Tt(this.Ch|0,this.Cl|0,a|0,u|0),{h:c,l:h}=Tt(this.Dh|0,this.Dl|0,c|0,h|0),{h:f,l}=Tt(this.Eh|0,this.El|0,f|0,l|0),{h:d,l:m}=Tt(this.Fh|0,this.Fl|0,d|0,m|0),{h:y,l:p}=Tt(this.Gh|0,this.Gl|0,y|0,p|0),{h:_,l:I}=Tt(this.Hh|0,this.Hl|0,_|0,I|0),this.set(n,o,s,i,a,u,c,h,f,l,d,m,y,p,_,I)}roundClean(){Nt(re,ne)}destroy(){Nt(this.buffer),this.set(0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0)}};var Ri=xo(()=>new _o);var Oi=xo(()=>new So);var Io=BigInt(0),Ao=BigInt(1);function Ut(r,t){if(typeof t!="boolean")throw new Error(r+" boolean expected, got "+t)}function yr(r){let t=r.toString(16);return t.length&1?"0"+t:t}function Ni(r){if(typeof r!="string")throw new Error("hex string expected, got "+typeof r);return r===""?Io:BigInt("0x"+r)}function ke(r){return Ni(Et(r))}function Mt(r){return Y(r),Ni(Et(Uint8Array.from(r).reverse()))}function $r(r,t){return pe(r.toString(16).padStart(t*2,"0"))}function Kt(r,t){return $r(r,t).reverse()}function z(r,t,e){let n;if(typeof t=="string")try{n=pe(t)}catch(s){throw new Error(r+" must be hex string or Uint8Array, cause: "+s)}else if(de(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 ki(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 vo=r=>typeof r=="bigint"&&Io<=r;function Ui(r,t,e){return vo(r)&&vo(t)&&vo(e)&&t<=r&&r<e}function oe(r,t,e,n){if(!Ui(t,e,n))throw new Error("expected valid "+r+": "+e+" <= n < "+n+", got "+t)}function Zr(r){let t;for(t=0;r>Io;r>>=Ao,t+=1);return t}var se=r=>(Ao<<BigInt(r))-Ao;function Mi(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=d=>new Uint8Array(d),o=d=>Uint8Array.of(d),s=n(r),i=n(r),a=0,u=()=>{s.fill(1),i.fill(0),a=0},c=(...d)=>e(i,s,...d),h=(d=n(0))=>{i=c(o(0),d),s=c(),d.length!==0&&(i=c(o(1),d),s=c())},f=()=>{if(a++>=1e3)throw new Error("drbg: tried 1000 values");let d=0,m=[];for(;d<t;){s=c();let y=s.slice();m.push(y),d+=s.length}return lt(...m)};return(d,m)=>{u(),h(d);let y;for(;!(y=m(f()));)h();return u(),y}}function ie(r,t,e={}){if(!r||typeof r!="object")throw new Error("expected valid options object");function n(o,s,i){let a=r[o];if(i&&a===void 0)return;let u=typeof a;if(u!==s||a===null)throw new Error(`param "${o}" is invalid: expected ${s}, got ${u}`)}Object.entries(t).forEach(([o,s])=>n(o,s,!1)),Object.entries(e).forEach(([o,s])=>n(o,s,!0))}function Ue(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 ut=BigInt(0),rt=BigInt(1),ye=BigInt(2),zi=BigInt(3),qi=BigInt(4),Hi=BigInt(5),tf=BigInt(7),Vi=BigInt(8),ef=BigInt(9),ji=BigInt(16);function W(r,t){let e=r%t;return e>=ut?e:t+e}function $(r,t,e){let n=r;for(;t-- >ut;)n*=n,n%=e;return n}function Ki(r,t){if(r===ut)throw new Error("invert: expected non-zero number");if(t<=ut)throw new Error("invert: expected positive modulus, got "+t);let e=W(r,t),n=t,o=ut,s=rt,i=rt,a=ut;for(;e!==ut;){let c=n/e,h=n%e,f=o-i*c,l=s-a*c;n=e,e=h,o=i,s=a,i=f,a=l}if(n!==rt)throw new Error("invert: does not exist");return W(o,t)}function Bo(r,t,e){if(!r.eql(r.sqr(t),e))throw new Error("Cannot find square root")}function Gi(r,t){let e=(r.ORDER+rt)/qi,n=r.pow(t,e);return Bo(r,n,t),n}function rf(r,t){let e=(r.ORDER-Hi)/Vi,n=r.mul(t,ye),o=r.pow(n,e),s=r.mul(t,o),i=r.mul(r.mul(s,ye),o),a=r.mul(s,r.sub(i,r.ONE));return Bo(r,a,t),a}function nf(r){let t=yt(r),e=$i(r),n=e(t,t.neg(t.ONE)),o=e(t,n),s=e(t,t.neg(n)),i=(r+tf)/ji;return(a,u)=>{let c=a.pow(u,i),h=a.mul(c,n),f=a.mul(c,o),l=a.mul(c,s),d=a.eql(a.sqr(h),u),m=a.eql(a.sqr(f),u);c=a.cmov(c,h,d),h=a.cmov(l,f,m);let y=a.eql(a.sqr(h),u),p=a.cmov(c,h,y);return Bo(a,p,u),p}}function $i(r){if(r<zi)throw new Error("sqrt is not defined for small field");let t=r-rt,e=0;for(;t%ye===ut;)t/=ye,e++;let n=ye,o=yt(r);for(;Fi(o,n)===1;)if(n++>1e3)throw new Error("Cannot find square root: probably non-prime P");if(e===1)return Gi;let s=o.pow(n,t),i=(t+rt)/ye;return function(u,c){if(u.is0(c))return c;if(Fi(u,c)!==1)throw new Error("Cannot find square root");let h=e,f=u.mul(u.ONE,s),l=u.pow(c,t),d=u.pow(c,i);for(;!u.eql(l,u.ONE);){if(u.is0(l))return u.ZERO;let m=1,y=u.sqr(l);for(;!u.eql(y,u.ONE);)if(m++,y=u.sqr(y),m===h)throw new Error("Cannot find square root");let p=rt<<BigInt(h-m-1),_=u.pow(f,p);h=m,f=u.sqr(_),l=u.mul(l,f),d=u.mul(d,_)}return d}}function of(r){return r%qi===zi?Gi:r%Vi===Hi?rf:r%ji===ef?nf(r):$i(r)}var Ft=(r,t)=>(W(r,t)&rt)===rt,sf=["create","isValid","is0","neg","inv","sqrt","sqr","eql","add","sub","mul","pow","div","addN","subN","mulN","sqrN"];function To(r){let t={ORDER:"bigint",MASK:"bigint",BYTES:"number",BITS:"number"},e=sf.reduce((n,o)=>(n[o]="function",n),t);return ie(r,e),r}function af(r,t,e){if(e<ut)throw new Error("invalid exponent, negatives unsupported");if(e===ut)return r.ONE;if(e===rt)return t;let n=r.ONE,o=t;for(;e>ut;)e&rt&&(n=r.mul(n,o)),o=r.sqr(o),e>>=rt;return n}function br(r,t,e=!1){let n=new Array(t.length).fill(e?r.ZERO:void 0),o=t.reduce((i,a,u)=>r.is0(a)?i:(n[u]=i,r.mul(i,a)),r.ONE),s=r.inv(o);return t.reduceRight((i,a,u)=>r.is0(a)?i:(n[u]=r.mul(i,n[u]),r.mul(i,a)),s),n}function Fi(r,t){let e=(r.ORDER-rt)/ye,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 Zi(r,t){t!==void 0&&lr(t);let e=t!==void 0?t:r.toString(2).length,n=Math.ceil(e/8);return{nBitLength:e,nByteLength:n}}function yt(r,t,e=!1,n={}){if(r<=ut)throw new Error("invalid field: expected ORDER > 0, got "+r);let o,s,i=!1,a;if(typeof t=="object"&&t!=null){if(n.sqrt||e)throw new Error("cannot specify opts in two arguments");let l=t;l.BITS&&(o=l.BITS),l.sqrt&&(s=l.sqrt),typeof l.isLE=="boolean"&&(e=l.isLE),typeof l.modOnDecode=="boolean"&&(i=l.modOnDecode),a=l.allowedLengths}else typeof t=="number"&&(o=t),n.sqrt&&(s=n.sqrt);let{nBitLength:u,nByteLength:c}=Zi(r,o);if(c>2048)throw new Error("invalid field: expected ORDER of <= 2048 bytes");let h,f=Object.freeze({ORDER:r,isLE:e,BITS:u,BYTES:c,MASK:se(u),ZERO:ut,ONE:rt,allowedLengths:a,create:l=>W(l,r),isValid:l=>{if(typeof l!="bigint")throw new Error("invalid field element: expected bigint, got "+typeof l);return ut<=l&&l<r},is0:l=>l===ut,isValidNot0:l=>!f.is0(l)&&f.isValid(l),isOdd:l=>(l&rt)===rt,neg:l=>W(-l,r),eql:(l,d)=>l===d,sqr:l=>W(l*l,r),add:(l,d)=>W(l+d,r),sub:(l,d)=>W(l-d,r),mul:(l,d)=>W(l*d,r),pow:(l,d)=>af(f,l,d),div:(l,d)=>W(l*Ki(d,r),r),sqrN:l=>l*l,addN:(l,d)=>l+d,subN:(l,d)=>l-d,mulN:(l,d)=>l*d,inv:l=>Ki(l,r),sqrt:s||(l=>(h||(h=of(r)),h(f,l))),toBytes:l=>e?Kt(l,c):$r(l,c),fromBytes:(l,d=!0)=>{if(a){if(!a.includes(l.length)||l.length>c)throw new Error("Field.fromBytes: expected "+a+" bytes, got "+l.length);let y=new Uint8Array(c);y.set(l,e?0:y.length-l.length),l=y}if(l.length!==c)throw new Error("Field.fromBytes: expected "+c+" bytes, got "+l.length);let m=e?Mt(l):ke(l);if(i&&(m=W(m,r)),!d&&!f.isValid(m))throw new Error("invalid field element: outside of range 0..ORDER");return m},invertBatch:l=>br(f,l),cmov:(l,d,m)=>m?d:l});return Object.freeze(f)}function Xi(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 Do(r){let t=Xi(r);return t+Math.ceil(t/2)}function Co(r,t,e=!1){let n=r.length,o=Xi(t),s=Do(t);if(n<16||n<s||n>1024)throw new Error("expected "+s+"-1024 bytes of input, got "+n);let i=e?Mt(r):ke(r),a=W(i,t-rt)+rt;return e?Kt(a,o):$r(a,o)}var Me=BigInt(0),be=BigInt(1);function xr(r,t){let e=t.negate();return r?e:t}function zt(r,t){let e=br(r.Fp,t.map(n=>n.Z));return t.map((n,o)=>r.fromAffine(n.toAffine(e[o])))}function Ji(r,t){if(!Number.isSafeInteger(r)||r<=0||r>t)throw new Error("invalid window size, expected [1.."+t+"], got W="+r)}function Lo(r,t){Ji(r,t);let e=Math.ceil(t/r)+1,n=2**(r-1),o=2**r,s=se(r),i=BigInt(r);return{windows:e,windowSize:n,mask:s,maxNumber:o,shiftBy:i}}function Yi(r,t,e){let{windowSize:n,mask:o,maxNumber:s,shiftBy:i}=e,a=Number(r&o),u=r>>i;a>n&&(a-=s,u+=be);let c=t*n,h=c+Math.abs(a)-1,f=a===0,l=a<0,d=t%2!==0;return{nextN:u,offset:h,isZero:f,isNeg:l,isNegF:d,offsetF:c}}function cf(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 uf(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 Po=new WeakMap,ta=new WeakMap;function Ro(r){return ta.get(r)||1}function Wi(r){if(r!==Me)throw new Error("invalid wNAF")}var Ke=class{constructor(t,e){this.BASE=t.BASE,this.ZERO=t.ZERO,this.Fn=t.Fn,this.bits=e}_unsafeLadder(t,e,n=this.ZERO){let o=t;for(;e>Me;)e&be&&(n=n.add(o)),o=o.double(),e>>=be;return n}precomputeWindow(t,e){let{windows:n,windowSize:o}=Lo(e,this.bits),s=[],i=t,a=i;for(let u=0;u<n;u++){a=i,s.push(a);for(let c=1;c<o;c++)a=a.add(i),s.push(a);i=a.double()}return s}wNAF(t,e,n){if(!this.Fn.isValid(n))throw new Error("invalid scalar");let o=this.ZERO,s=this.BASE,i=Lo(t,this.bits);for(let a=0;a<i.windows;a++){let{nextN:u,offset:c,isZero:h,isNeg:f,isNegF:l,offsetF:d}=Yi(n,a,i);n=u,h?s=s.add(xr(l,e[d])):o=o.add(xr(f,e[c]))}return Wi(n),{p:o,f:s}}wNAFUnsafe(t,e,n,o=this.ZERO){let s=Lo(t,this.bits);for(let i=0;i<s.windows&&n!==Me;i++){let{nextN:a,offset:u,isZero:c,isNeg:h}=Yi(n,i,s);if(n=a,!c){let f=e[u];o=o.add(h?f.negate():f)}}return Wi(n),o}getPrecomputes(t,e,n){let o=Po.get(e);return o||(o=this.precomputeWindow(e,t),t!==1&&(typeof n=="function"&&(o=n(o)),Po.set(e,o))),o}cached(t,e,n){let o=Ro(t);return this.wNAF(o,this.getPrecomputes(o,t,n),e)}unsafe(t,e,n,o){let s=Ro(t);return s===1?this._unsafeLadder(t,e,o):this.wNAFUnsafe(s,this.getPrecomputes(s,t,n),e,o)}createCache(t,e){Ji(e,this.bits),ta.set(t,e),Po.delete(t)}hasCache(t){return Ro(t)!==1}};function ea(r,t,e,n){let o=t,s=r.ZERO,i=r.ZERO;for(;e>Me||n>Me;)e&be&&(s=s.add(o)),n&be&&(i=i.add(o)),o=o.double(),e>>=be,n>>=be;return{p1:s,p2:i}}function Fe(r,t,e,n){cf(e,r),uf(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=Zr(BigInt(o)),u=1;a>12?u=a-3:a>4?u=a-2:a>0&&(u=2);let c=se(u),h=new Array(Number(c)+1).fill(i),f=Math.floor((t.BITS-1)/u)*u,l=i;for(let d=f;d>=0;d-=u){h.fill(i);for(let y=0;y<s;y++){let p=n[y],_=Number(p>>BigInt(d)&c);h[_]=h[_].add(e[y])}let m=i;for(let y=h.length-1,p=i;y>0;y--)p=p.add(h[y]),m=m.add(p);if(l=l.add(m),d!==0)for(let y=0;y<u;y++)l=l.double()}return l}function Qi(r,t){if(t){if(t.ORDER!==r)throw new Error("Field.ORDER must match order: Fp == p, Fn == n");return To(t),t}else return yt(r)}function Xr(r,t,e={}){if(!t||typeof t!="object")throw new Error(`expected valid ${r} CURVE object`);for(let a of["p","n","h"]){let u=t[a];if(!(typeof u=="bigint"&&u>Me))throw new Error(`CURVE.${a} must be positive bigint`)}let n=Qi(t.p,e.Fp),o=Qi(t.n,e.Fn),i=["Gx","Gy","a",r==="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 Dt=BigInt(0),tt=BigInt(1),Oo=BigInt(2),ff=BigInt(8);function lf(r,t,e,n){let o=r.sqr(e),s=r.sqr(n),i=r.add(r.mul(t.a,o),s),a=r.add(r.ONE,r.mul(t.d,r.mul(o,s)));return r.eql(i,a)}function hf(r,t={}){let{Fp:e,Fn:n}=Xr("edwards",r,t),{h:o,n:s}=r;ie(t,{},{uvRatio:"function"});let i=Oo<<BigInt(n.BYTES*8)-tt,a=y=>e.create(y),u=t.uvRatio||((y,p)=>{try{return{isValid:!0,value:e.sqrt(e.div(y,p))}}catch{return{isValid:!1,value:Dt}}});if(!lf(e,r,r.Gx,r.Gy))throw new Error("bad curve params: generator point");function c(y,p,_=!1){let I=_?tt:Dt;return oe("coordinate "+y,p,I,i),p}function h(y){if(!(y instanceof d))throw new Error("ExtendedPoint expected")}let f=Ue((y,p)=>{let{X:_,Y:I,Z:S}=y,D=y.is0();p==null&&(p=D?ff:e.inv(S));let R=a(_*p),B=a(I*p),k=e.mul(S,p);if(D)return{x:Dt,y:tt};if(k!==tt)throw new Error("invZ was invalid");return{x:R,y:B}}),l=Ue(y=>{let{a:p,d:_}=r;if(y.is0())throw new Error("bad point: ZERO");let{X:I,Y:S,Z:D,T:R}=y,B=a(I*I),k=a(S*S),U=a(D*D),C=a(U*U),b=a(B*p),g=a(U*a(b+k)),E=a(C+a(_*a(B*k)));if(g!==E)throw new Error("bad point: equation left != right (1)");let v=a(I*S),L=a(D*R);if(v!==L)throw new Error("bad point: equation left != right (2)");return!0});class d{constructor(p,_,I,S){this.X=c("x",p),this.Y=c("y",_),this.Z=c("z",I,!0),this.T=c("t",S),Object.freeze(this)}get x(){return this.toAffine().x}get y(){return this.toAffine().y}get ex(){return this.X}get ey(){return this.Y}get ez(){return this.Z}get et(){return this.T}static normalizeZ(p){return zt(d,p)}static msm(p,_){return Fe(d,n,p,_)}_setWindowSize(p){this.precompute(p)}static fromAffine(p){if(p instanceof d)throw new Error("extended point not allowed");let{x:_,y:I}=p||{};return c("x",_),c("y",I),new d(_,I,tt,a(_*I))}precompute(p=8,_=!0){return m.createCache(this,p),_||this.multiply(Oo),this}assertValidity(){l(this)}equals(p){h(p);let{X:_,Y:I,Z:S}=this,{X:D,Y:R,Z:B}=p,k=a(_*B),U=a(D*S),C=a(I*B),b=a(R*S);return k===U&&C===b}is0(){return this.equals(d.ZERO)}negate(){return new d(a(-this.X),this.Y,this.Z,a(-this.T))}double(){let{a:p}=r,{X:_,Y:I,Z:S}=this,D=a(_*_),R=a(I*I),B=a(Oo*a(S*S)),k=a(p*D),U=_+I,C=a(a(U*U)-D-R),b=k+R,g=b-B,E=k-R,v=a(C*g),L=a(b*E),P=a(C*E),w=a(g*b);return new d(v,L,w,P)}add(p){h(p);let{a:_,d:I}=r,{X:S,Y:D,Z:R,T:B}=this,{X:k,Y:U,Z:C,T:b}=p,g=a(S*k),E=a(D*U),v=a(B*I*b),L=a(R*C),P=a((S+D)*(k+U)-g-E),w=L-v,x=L+v,A=a(E-_*g),T=a(P*w),O=a(x*A),N=a(P*A),M=a(w*x);return new d(T,O,M,N)}subtract(p){return this.add(p.negate())}multiply(p){let _=p;oe("scalar",_,tt,s);let{p:I,f:S}=m.cached(this,_,D=>zt(d,D));return zt(d,[I,S])[0]}multiplyUnsafe(p,_=d.ZERO){let I=p;return oe("scalar",I,Dt,s),I===Dt?d.ZERO:this.is0()||I===tt?this:m.unsafe(this,I,S=>zt(d,S),_)}isSmallOrder(){return this.multiplyUnsafe(o).is0()}isTorsionFree(){return m.unsafe(this,s).is0()}toAffine(p){return f(this,p)}clearCofactor(){return o===tt?this:this.multiplyUnsafe(o)}static fromBytes(p,_=!1){return Y(p),d.fromHex(p,_)}static fromHex(p,_=!1){let{d:I,a:S}=r,D=e.BYTES;p=z("pointHex",p,D),Ut("zip215",_);let R=p.slice(),B=p[D-1];R[D-1]=B&-129;let k=Mt(R),U=_?i:e.ORDER;oe("pointHex.y",k,Dt,U);let C=a(k*k),b=a(C-tt),g=a(I*C-S),{isValid:E,value:v}=u(b,g);if(!E)throw new Error("Point.fromHex: invalid y coordinate");let L=(v&tt)===tt,P=(B&128)!==0;if(!_&&v===Dt&&P)throw new Error("Point.fromHex: x=0 and x_0=1");return P!==L&&(v=a(-v)),d.fromAffine({x:v,y:k})}toBytes(){let{x:p,y:_}=this.toAffine(),I=Kt(_,e.BYTES);return I[I.length-1]|=p&tt?128:0,I}toRawBytes(){return this.toBytes()}toHex(){return Et(this.toBytes())}toString(){return`<Point ${this.is0()?"ZERO":this.toHex()}>`}}d.BASE=new d(r.Gx,r.Gy,tt,a(r.Gx*r.Gy)),d.ZERO=new d(Dt,tt,tt,Dt),d.Fp=e,d.Fn=n;let m=new Ke(d,n.BYTES*8);return d}var Yr=class{constructor(t){this.ep=t}static fromBytes(t){throw new Error("fromBytes must be implemented by subclass")}static fromHex(t){throw new Error("fromHex must be implemented by subclass")}get x(){return this.toAffine().x}get y(){return this.toAffine().y}clearCofactor(){return this}assertValidity(){this.ep.assertValidity()}toAffine(t){return this.ep.toAffine(t)}toRawBytes(){return this.toBytes()}toHex(){return Et(this.toBytes())}toString(){return this.toHex()}isTorsionFree(){return!0}isSmallOrder(){return!1}add(t){return this.assertSame(t),this.init(this.ep.add(t.ep))}subtract(t){return this.assertSame(t),this.init(this.ep.subtract(t.ep))}multiply(t){return this.init(this.ep.multiply(t))}multiplyUnsafe(t){return this.init(this.ep.multiplyUnsafe(t))}double(){return this.init(this.ep.double())}negate(){return this.init(this.ep.negate())}precompute(t,e){return this.init(this.ep.precompute(t,e))}};function df(r,t,e){if(typeof t!="function")throw new Error('"hash" function param is required');ie(e,{},{adjustScalarBytes:"function",randomBytes:"function",domain:"function",prehash:"function",mapToCurve:"function"});let{prehash:n}=e,{BASE:o,Fp:s,Fn:i}=r,a=i.ORDER,u=e.randomBytes||dr,c=e.adjustScalarBytes||(g=>g),h=e.domain||((g,E,v)=>{if(Ut("phflag",v),E.length||v)throw new Error("Contexts/pre-hash are not supported");return g});function f(g){return i.create(g)}function l(g){return f(Mt(g))}function d(g){let E=s.BYTES;g=z("private key",g,E);let v=z("hashed private key",t(g),2*E),L=c(v.slice(0,E)),P=v.slice(E,2*E),w=l(L);return{head:L,prefix:P,scalar:w}}function m(g){let{head:E,prefix:v,scalar:L}=d(g),P=o.multiply(L),w=P.toBytes();return{head:E,prefix:v,scalar:L,point:P,pointBytes:w}}function y(g){return m(g).pointBytes}function p(g=Uint8Array.of(),...E){let v=lt(...E);return l(t(h(v,z("context",g),!!n)))}function _(g,E,v={}){g=z("message",g),n&&(g=n(g));let{prefix:L,scalar:P,pointBytes:w}=m(E),x=p(v.context,L,g),A=o.multiply(x).toBytes(),T=p(v.context,A,w,g),O=f(x+T*P);oe("signature.s",O,Dt,a);let N=s.BYTES,M=lt(A,Kt(O,N));return z("result",M,N*2)}let I={zip215:!0};function S(g,E,v,L=I){let{context:P,zip215:w}=L,x=s.BYTES;g=z("signature",g,2*x),E=z("message",E),v=z("publicKey",v,x),w!==void 0&&Ut("zip215",w),n&&(E=n(E));let A=Mt(g.slice(x,2*x)),T,O,N;try{T=r.fromHex(v,w),O=r.fromHex(g.slice(0,x),w),N=o.multiplyUnsafe(A)}catch{return!1}if(!w&&T.isSmallOrder())return!1;let M=p(P,O.toBytes(),T.toBytes(),E);return O.add(T.multiplyUnsafe(M)).subtract(N).clearCofactor().is0()}o.precompute(8);let D=s.BYTES,R={secret:D,public:D,signature:2*D,seed:D};function B(g=u(R.seed)){return g}let k={getExtendedPublicKey:m,randomSecretKey:B,isValidSecretKey:C,isValidPublicKey:b,randomPrivateKey:B,toMontgomery(g){let{y:E}=r.fromBytes(g),v=D===32;if(!v&&D!==57)throw new Error("only defined for 25519 and 448");let L=v?s.div(tt+E,tt-E):s.div(E-tt,E+tt);return s.toBytes(L)},toMontgomeryPriv(g){Y(g,D);let E=t(g.subarray(0,D));return c(E).subarray(0,D)},precompute(g=8,E=r.BASE){return E.precompute(g,!1)}};function U(g){let E=k.randomSecretKey(g);return{secretKey:E,publicKey:y(E)}}function C(g){try{return!!i.fromBytes(g,!1)}catch{return!1}}function b(g,E){try{return!!r.fromBytes(g,E)}catch{return!1}}return Object.freeze({keygen:U,getPublicKey:y,sign:_,verify:S,utils:k,Point:r,info:{type:"edwards",lengths:R}})}function pf(r){let t={a:r.a,d:r.d,p:r.Fp.ORDER,n:r.n,h:r.h,Gx:r.Gx,Gy:r.Gy},e=r.Fp,n=yt(t.n,r.nBitLength,!0),o={Fp:e,Fn:n,uvRatio:r.uvRatio},s={randomBytes:r.randomBytes,adjustScalarBytes:r.adjustScalarBytes,domain:r.domain,prehash:r.prehash,mapToCurve:r.mapToCurve};return{CURVE:t,curveOpts:o,hash:r.hash,eddsaOpts:s}}function mf(r,t){return Object.assign({},t,{ExtendedPoint:t.Point,CURVE:r})}function ra(r){let{CURVE:t,curveOpts:e,hash:n,eddsaOpts:o}=pf(r),s=hf(t,e),i=df(s,n,o);return mf(r,i)}var gf=BigInt(0),qt=BigInt(1),na=BigInt(2),Zp=BigInt(3),yf=BigInt(5),bf=BigInt(8),wr={p:BigInt("0x7fffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffed"),n:BigInt("0x1000000000000000000000000000000014def9dea2f79cd65812631a5cf5d3ed"),h:bf,a:BigInt("0x7fffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffec"),d:BigInt("0x52036cee2b6ffe738cc740797779e89800700a4d4141d8ab75eb4dca135978a3"),Gx:BigInt("0x216936d3cd6e53fec0a4e231fdd6dc5c692cc7609525a7b2c9562d608f25d51a"),Gy:BigInt("0x6666666666666666666666666666666666666666666666666666666666666658")};function xf(r){let t=BigInt(10),e=BigInt(20),n=BigInt(40),o=BigInt(80),s=wr.p,a=r*r%s*r%s,u=$(a,na,s)*a%s,c=$(u,qt,s)*r%s,h=$(c,yf,s)*c%s,f=$(h,t,s)*h%s,l=$(f,e,s)*f%s,d=$(l,n,s)*l%s,m=$(d,o,s)*d%s,y=$(m,o,s)*d%s,p=$(y,t,s)*h%s;return{pow_p_5_8:$(p,na,s)*r%s,b2:a}}function wf(r){return r[0]&=248,r[31]&=127,r[31]|=64,r}var No=BigInt("19681161376707505956807079304988542015446066515923890162744021073123829784752");function Mo(r,t){let e=wr.p,n=W(t*t*t,e),o=W(n*n*t,e),s=xf(r*o).pow_p_5_8,i=W(r*n*s,e),a=W(t*i*i,e),u=i,c=W(i*No,e),h=a===r,f=a===W(-r,e),l=a===W(-r*No,e);return h&&(i=u),(f||l)&&(i=c),Ft(i,e)&&(i=W(-i,e)),{isValid:h||f,value:i}}var xe=yt(wr.p,{isLE:!0}),Ef=yt(wr.n,{isLE:!0}),_f={...wr,Fp:xe,hash:Oi,adjustScalarBytes:wf,uvRatio:Mo},bt=ra(_f);var ko=No,Sf=BigInt("25063068953384623474111414158702152701244531502492656460079210482610430750235"),vf=BigInt("54469307008909316920995813868745141605393597292927456921205312896311721017578"),Af=BigInt("1159843021668779879193775521855586647937357759715417654439879720876111806838"),If=BigInt("40440834346308536858101042469323190826248399146238708352240133220865137265952"),oa=r=>Mo(qt,r),Bf=BigInt("0x7fffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffff"),Uo=r=>bt.CURVE.Fp.create(Mt(r)&Bf);function sa(r){let{d:t}=bt.CURVE,e=bt.CURVE.Fp.ORDER,n=bt.CURVE.Fp.create,o=n(ko*r*r),s=n((o+qt)*Af),i=BigInt(-1),a=n((i-t*o)*n(o+t)),{isValid:u,value:c}=Mo(s,a),h=n(c*r);Ft(h,e)||(h=n(-h)),u||(c=h),u||(i=o);let f=n(i*(o-qt)*If-a),l=c*c,d=n((c+c)*a),m=n(f*Sf),y=n(qt-l),p=n(qt+l);return new bt.Point(n(d*p),n(y*m),n(m*p),n(d*y))}function Tf(r){Y(r,64);let t=Uo(r.subarray(0,32)),e=sa(t),n=Uo(r.subarray(32,64)),o=sa(n);return new Ht(e.add(o))}var Ht=class r extends Yr{constructor(t){super(t)}static fromAffine(t){return new r(bt.Point.fromAffine(t))}assertSame(t){if(!(t instanceof r))throw new Error("RistrettoPoint expected")}init(t){return new r(t)}static hashToCurve(t){return Tf(z("ristrettoHash",t,64))}static fromBytes(t){Y(t,32);let{a:e,d:n}=bt.CURVE,o=xe.ORDER,s=xe.create,i=Uo(t);if(!ki(Kt(i,32),t)||Ft(i,o))throw new Error("invalid ristretto255 encoding 1");let a=s(i*i),u=s(qt+e*a),c=s(qt-e*a),h=s(u*u),f=s(c*c),l=s(e*n*h-f),{isValid:d,value:m}=oa(s(l*f)),y=s(m*c),p=s(m*y*l),_=s((i+i)*y);Ft(_,o)&&(_=s(-_));let I=s(u*p),S=s(_*I);if(!d||Ft(S,o)||I===gf)throw new Error("invalid ristretto255 encoding 2");return new r(new bt.Point(_,I,qt,S))}static fromHex(t){return r.fromBytes(z("ristrettoHex",t,32))}static msm(t,e){return Fe(r,bt.Point.Fn,t,e)}toBytes(){let{X:t,Y:e,Z:n,T:o}=this.ep,s=xe.ORDER,i=xe.create,a=i(i(n+e)*i(n-e)),u=i(t*e),c=i(u*u),{value:h}=oa(i(a*c)),f=i(h*a),l=i(h*u),d=i(f*l*o),m;if(Ft(o*d,s)){let p=i(e*ko),_=i(t*ko);t=p,e=_,m=i(f*vf)}else m=l;Ft(t*d,s)&&(e=i(-e));let y=i((n-e)*m);return Ft(y,s)&&(y=i(-y)),Kt(y,32)}equals(t){this.assertSame(t);let{X:e,Y:n}=this.ep,{X:o,Y:s}=t.ep,i=xe.create,a=i(e*s)===i(n*o),u=i(n*s)===i(e*o);return a||u}is0(){return this.equals(r.ZERO)}};Ht.BASE=new Ht(bt.Point.BASE);Ht.ZERO=new Ht(bt.Point.ZERO);Ht.Fp=xe;Ht.Fn=Ef;var Er=class extends Error{constructor(t="An error occurred while verifying a message"){super(t),this.name="VerificationError"}},Wr=class extends Error{constructor(t="Missing Web Crypto API"){super(t),this.name="WebCryptoMissingError"}};var ia={get(r=globalThis){let t=r.crypto;if(t?.subtle==null)throw new Wr("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 Qr=ia;var Jr=32;var Ko,Df=(async()=>{try{return await Qr.get().subtle.generateKey({name:"Ed25519"},!0,["sign","verify"]),!0}catch{return!1}})();async function Cf(r,t,e){if(r.buffer instanceof ArrayBuffer){let n=await Qr.get().subtle.importKey("raw",r.buffer,{name:"Ed25519"},!1,["verify"]);return await Qr.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 Lf(r,t,e){return bt.verify(t,e instanceof Uint8Array?e:e.subarray(),r)}async function aa(r,t,e){return Ko==null&&(Ko=await Df),Ko?Cf(r,t,e):Lf(r,t,e)}function tn(r){return r==null?!1:typeof r.then=="function"&&typeof r.catch=="function"&&typeof r.finally=="function"}var en=class{type="Ed25519";raw;constructor(t){this.raw=Fo(t,Jr)}toMultihash(){return _t.digest(Re(this))}toCID(){return et.createV1(114,this.toMultihash())}toString(){return Z.encode(this.toMultihash().bytes).substring(1)}equals(t){return t==null||!(t.raw instanceof Uint8Array)?!1:ct(this.raw,t.raw)}verify(t,e,n){n?.signal?.throwIfAborted();let o=aa(this.raw,e,t);return tn(o)?o.then(s=>(n?.signal?.throwIfAborted(),s)):o}};function ua(r){return r=Fo(r,Jr),new en(r)}function Fo(r,t){if(r=Uint8Array.from(r??[]),r.length!==t)throw new Lt(`Key must be a Uint8Array of length ${t}, got ${r.length}`);return r}var Rf=Math.pow(2,7),Of=Math.pow(2,14),Nf=Math.pow(2,21),zo=Math.pow(2,28),qo=Math.pow(2,35),Ho=Math.pow(2,42),Vo=Math.pow(2,49),K=128,it=127;function ht(r){if(r<Rf)return 1;if(r<Of)return 2;if(r<Nf)return 3;if(r<zo)return 4;if(r<qo)return 5;if(r<Ho)return 6;if(r<Vo)return 7;if(Number.MAX_SAFE_INTEGER!=null&&r>Number.MAX_SAFE_INTEGER)throw new RangeError("Could not encode varint");return 8}function ze(r,t,e=0){switch(ht(r)){case 8:t[e++]=r&255|K,r/=128;case 7:t[e++]=r&255|K,r/=128;case 6:t[e++]=r&255|K,r/=128;case 5:t[e++]=r&255|K,r/=128;case 4:t[e++]=r&255|K,r>>>=7;case 3:t[e++]=r&255|K,r>>>=7;case 2:t[e++]=r&255|K,r>>>=7;case 1:{t[e++]=r&255,r>>>=7;break}default:throw new Error("unreachable")}return t}function kf(r,t,e=0){switch(ht(r)){case 8:t.set(e++,r&255|K),r/=128;case 7:t.set(e++,r&255|K),r/=128;case 6:t.set(e++,r&255|K),r/=128;case 5:t.set(e++,r&255|K),r/=128;case 4:t.set(e++,r&255|K),r>>>=7;case 3:t.set(e++,r&255|K),r>>>=7;case 2:t.set(e++,r&255|K),r>>>=7;case 1:{t.set(e++,r&255),r>>>=7;break}default:throw new Error("unreachable")}return t}function jo(r,t){let e=r[t],n=0;if(n+=e&it,e<K||(e=r[t+1],n+=(e&it)<<7,e<K)||(e=r[t+2],n+=(e&it)<<14,e<K)||(e=r[t+3],n+=(e&it)<<21,e<K)||(e=r[t+4],n+=(e&it)*zo,e<K)||(e=r[t+5],n+=(e&it)*qo,e<K)||(e=r[t+6],n+=(e&it)*Ho,e<K)||(e=r[t+7],n+=(e&it)*Vo,e<K))return n;throw new RangeError("Could not decode varint")}function Uf(r,t){let e=r.get(t),n=0;if(n+=e&it,e<K||(e=r.get(t+1),n+=(e&it)<<7,e<K)||(e=r.get(t+2),n+=(e&it)<<14,e<K)||(e=r.get(t+3),n+=(e&it)<<21,e<K)||(e=r.get(t+4),n+=(e&it)*zo,e<K)||(e=r.get(t+5),n+=(e&it)*qo,e<K)||(e=r.get(t+6),n+=(e&it)*Ho,e<K)||(e=r.get(t+7),n+=(e&it)*Vo,e<K))return n;throw new RangeError("Could not decode varint")}function fa(r,t,e=0){return t==null&&(t=ft(ht(r))),t instanceof Uint8Array?ze(r,t,e):kf(r,t,e)}function _r(r,t=0){return r instanceof Uint8Array?jo(r,t):Uf(r,t)}var Go=new Float32Array([-0]),ae=new Uint8Array(Go.buffer);function ha(r,t,e){Go[0]=r,t[e]=ae[0],t[e+1]=ae[1],t[e+2]=ae[2],t[e+3]=ae[3]}function da(r,t){return ae[0]=r[t],ae[1]=r[t+1],ae[2]=r[t+2],ae[3]=r[t+3],Go[0]}var $o=new Float64Array([-0]),at=new Uint8Array($o.buffer);function pa(r,t,e){$o[0]=r,t[e]=at[0],t[e+1]=at[1],t[e+2]=at[2],t[e+3]=at[3],t[e+4]=at[4],t[e+5]=at[5],t[e+6]=at[6],t[e+7]=at[7]}function ma(r,t){return at[0]=r[t],at[1]=r[t+1],at[2]=r[t+2],at[3]=r[t+3],at[4]=r[t+4],at[5]=r[t+5],at[6]=r[t+6],at[7]=r[t+7],$o[0]}var Mf=BigInt(Number.MAX_SAFE_INTEGER),Kf=BigInt(Number.MIN_SAFE_INTEGER),xt=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 we;if(t<Mf&&t>Kf)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>ga&&(o=0n,++n>ga&&(n=0n))),new r(Number(o),Number(n))}static fromNumber(t){if(t===0)return we;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):we}},we=new xt(0,0);we.toBigInt=function(){return 0n};we.zzEncode=we.zzDecode=function(){return this};we.length=function(){return 1};var ga=4294967296n;function ya(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 ba(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 Zo(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 At(r,t){return RangeError(`index out of range: ${r.pos} + ${t??1} > ${r.len}`)}function rn(r,t){return(r[t-4]|r[t-3]<<8|r[t-2]<<16|r[t-1]<<24)>>>0}var Xo=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,At(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 At(this,4);return rn(this.buf,this.pos+=4)}sfixed32(){if(this.pos+4>this.len)throw At(this,4);return rn(this.buf,this.pos+=4)|0}float(){if(this.pos+4>this.len)throw At(this,4);let t=da(this.buf,this.pos);return this.pos+=4,t}double(){if(this.pos+8>this.len)throw At(this,4);let t=ma(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 At(this,t);return this.pos+=t,e===n?new Uint8Array(0):this.buf.subarray(e,n)}string(){let t=this.bytes();return ba(t,0,t.length)}skip(t){if(typeof t=="number"){if(this.pos+t>this.len)throw At(this,t);this.pos+=t}else do if(this.pos>=this.len)throw At(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 xt(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 At(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 At(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 At(this,8);let t=rn(this.buf,this.pos+=4),e=rn(this.buf,this.pos+=4);return new xt(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=jo(this.buf,this.pos);return this.pos+=ht(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 Yo(r){return new Xo(r instanceof Uint8Array?r:r.subarray())}function Vt(r,t,e){let n=Yo(r);return t.decode(n,void 0,e)}function Wo(r){let t=r??8192,e=t>>>1,n,o=t;return function(i){if(i<1||i>e)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 Ee=class{fn;len;next;val;constructor(t,e,n){this.fn=t,this.len=e,this.next=void 0,this.val=n}};function Qo(){}var ts=class{head;tail;len;next;constructor(t){this.head=t.head,this.tail=t.tail,this.len=t.len,this.next=t.states}},Ff=Wo();function zf(r){return globalThis.Buffer!=null?ft(r):Ff(r)}var vr=class{len;head;tail;states;constructor(){this.len=0,this.head=new Ee(Qo,0,0),this.tail=this.head,this.states=null}_push(t,e,n){return this.tail=this.tail.next=new Ee(t,e,n),this.len+=e,this}uint32(t){return this.len+=(this.tail=this.tail.next=new es((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(nn,10,xt.fromNumber(t)):this.uint32(t)}sint32(t){return this.uint32((t<<1^t>>31)>>>0)}uint64(t){let e=xt.fromBigInt(t);return this._push(nn,e.length(),e)}uint64Number(t){return this._push(ze,ht(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=xt.fromBigInt(t).zzEncode();return this._push(nn,e.length(),e)}sint64Number(t){let e=xt.fromNumber(t).zzEncode();return this._push(nn,e.length(),e)}sint64String(t){return this.sint64(BigInt(t))}bool(t){return this._push(Jo,1,t?1:0)}fixed32(t){return this._push(Sr,4,t>>>0)}sfixed32(t){return this.fixed32(t)}fixed64(t){let e=xt.fromBigInt(t);return this._push(Sr,4,e.lo)._push(Sr,4,e.hi)}fixed64Number(t){let e=xt.fromNumber(t);return this._push(Sr,4,e.lo)._push(Sr,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(ha,4,t)}double(t){return this._push(pa,8,t)}bytes(t){let e=t.length>>>0;return e===0?this._push(Jo,1,0):this.uint32(e)._push(Hf,e,t)}string(t){let e=ya(t);return e!==0?this.uint32(e)._push(Zo,e,t):this._push(Jo,1,0)}fork(){return this.states=new ts(this),this.head=this.tail=new Ee(Qo,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 Ee(Qo,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=zf(this.len),n=0;for(;t!=null;)t.fn(t.val,e,n),n+=t.len,t=t.next;return e}};function Jo(r,t,e){t[e]=r&255}function qf(r,t,e){for(;r>127;)t[e++]=r&127|128,r>>>=7;t[e]=r}var es=class extends Ee{next;constructor(t,e){super(qf,t,e),this.next=void 0}};function nn(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 Sr(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 Hf(r,t,e){t.set(r,e)}globalThis.Buffer!=null&&(vr.prototype.bytes=function(r){let t=r.length>>>0;return this.uint32(t),t>0&&this._push(Vf,t,r),this},vr.prototype.string=function(r){let t=globalThis.Buffer.byteLength(r);return this.uint32(t),t>0&&this._push(jf,t,r),this});function Vf(r,t,e){t.set(r,e)}function jf(r,t,e){r.length<40?Zo(r,t,e):t.utf8Write!=null?t.utf8Write(r,e):t.set(H(r),e)}function rs(){return new vr}function jt(r,t){let e=rs();return t.encode(r,e,{lengthDelimited:!1}),e.finish()}var qe;(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"})(qe||(qe={}));function on(r,t,e,n){return{name:r,type:t,encode:e,decode:n}}function He(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 on("enum",qe.VARINT,e,n)}function Gt(r,t){return on("message",qe.LENGTH_DELIMITED,r,t)}var sn=class extends Error{code="ERR_MAX_LENGTH";name="MaxLengthError"};var wt;(function(r){r.RSA="RSA",r.Ed25519="Ed25519",r.secp256k1="secp256k1",r.ECDSA="ECDSA"})(wt||(wt={}));var ns;(function(r){r[r.RSA=0]="RSA",r[r.Ed25519=1]="Ed25519",r[r.secp256k1=2]="secp256k1",r[r.ECDSA=3]="ECDSA"})(ns||(ns={}));(function(r){r.codec=()=>He(ns)})(wt||(wt={}));var Ar;(function(r){let t;r.codec=()=>(t==null&&(t=Gt((e,n,o={})=>{o.lengthDelimited!==!1&&n.fork(),e.Type!=null&&(n.uint32(8),wt.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=wt.codec().decode(e);break}case 2:{s.Data=e.bytes();break}default:{e.skipType(a&7);break}}}return s})),t),r.encode=e=>jt(e,r.codec()),r.decode=(e,n)=>Vt(e,r.codec(),n)})(Ar||(Ar={}));var os;(function(r){let t;r.codec=()=>(t==null&&(t=Gt((e,n,o={})=>{o.lengthDelimited!==!1&&n.fork(),e.Type!=null&&(n.uint32(8),wt.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=wt.codec().decode(e);break}case 2:{s.Data=e.bytes();break}default:{e.skipType(a&7);break}}}return s})),t),r.encode=e=>jt(e,r.codec()),r.decode=(e,n)=>Vt(e,r.codec(),n)})(os||(os={}));var an=class extends Oe{constructor(t,e){super(),this.finished=!1,this.destroyed=!1,Vr(t);let n=hr(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),Nt(s)}update(t){return Ne(this),this.iHash.update(t),this}digestInto(t){Ne(this),Y(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()}},ss=(r,t,e)=>new an(r,t).update(e).digest();ss.create=(r,t)=>new an(r,t);var wa=(r,t)=>(r+(r>=0?t:-t)/_a)/t;function $f(r,t,e){let[[n,o],[s,i]]=t,a=wa(i*r,e),u=wa(-o*r,e),c=r-a*n-u*s,h=-a*o-u*i,f=c<Zt,l=h<Zt;f&&(c=-c),l&&(h=-h);let d=se(Math.ceil(Zr(e)/2))+je;if(c<Zt||c>=d||h<Zt||h>=d)throw new Error("splitScalar (endomorphism): failed, k="+r);return{k1neg:f,k1:c,k2neg:l,k2:h}}function Ea(r){r.lowS!==void 0&&Ut("lowS",r.lowS),r.prehash!==void 0&&Ut("prehash",r.prehash)}var is=class extends Error{constructor(t=""){super(t)}},$t={Err:is,_tlv:{encode:(r,t)=>{let{Err:e}=$t;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=yr(n);if(o.length/2&128)throw new e("tlv.encode: long form length too big");let s=n>127?yr(o.length/2|128):"";return yr(r)+s+o+t},decode(r,t){let{Err:e}=$t,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 u=o&127;if(!u)throw new e("tlv.decode(long): indefinite length not supported");if(u>4)throw new e("tlv.decode(long): byte length is too big");let c=t.subarray(n,n+u);if(c.length!==u)throw new e("tlv.decode: length bytes not complete");if(c[0]===0)throw new e("tlv.decode(long): zero leftmost byte");for(let h of c)i=i<<8|h;if(n+=u,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}=$t;if(r<Zt)throw new t("integer: negative integers are not allowed");let e=yr(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}=$t;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 ke(r)}},toSig(r){let{Err:t,_int:e,_tlv:n}=$t,o=z("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:u}=n.decode(2,s),{v:c,l:h}=n.decode(2,u);if(h.length)throw new t("invalid signature: left bytes after parsing");return{r:e.decode(a),s:e.decode(c)}},hexFromSig(r){let{_tlv:t,_int:e}=$t,n=t.encode(2,e.encode(r.r)),o=t.encode(2,e.encode(r.s)),s=n+o;return t.encode(48,s)}},Zt=BigInt(0),je=BigInt(1),_a=BigInt(2),cn=BigInt(3),Zf=BigInt(4);function Xf(r,t,e){function n(o){let s=r.sqr(o),i=r.mul(s,o);return r.add(r.add(i,r.mul(o,t)),e)}return n}function Ve(r,t){let{BYTES:e}=r,n;if(typeof t=="bigint")n=t;else{let o=z("private key",t);try{n=r.fromBytes(o)}catch{throw new Error(`invalid private key: expected ui8a of size ${e}, got ${typeof t}`)}}if(!r.isValidNot0(n))throw new Error("invalid private key: out of range [1..N-1]");return n}function Yf(r,t={}){let{Fp:e,Fn:n}=Xr("weierstrass",r,t),{h:o,n:s}=r;ie(t,{},{allowInfinityPoint:"boolean",clearCofactor:"function",isTorsionFree:"function",fromBytes:"function",toBytes:"function",endo:"object",wrapPrivateKey:"boolean"});let{endo:i}=t;if(i&&(!e.is0(r.a)||typeof i.beta!="bigint"||!Array.isArray(i.basises)))throw new Error('invalid endo: expected "beta": bigint and "basises": array');function a(){if(!e.isOdd)throw new Error("compression is not supported: Field does not have .isOdd()")}function u(C,b,g){let{x:E,y:v}=b.toAffine(),L=e.toBytes(E);if(Ut("isCompressed",g),g){a();let P=!e.isOdd(v);return lt(Sa(P),L)}else return lt(Uint8Array.of(4),L,e.toBytes(v))}function c(C){Y(C);let b=e.BYTES,g=b+1,E=2*b+1,v=C.length,L=C[0],P=C.subarray(1);if(v===g&&(L===2||L===3)){let w=e.fromBytes(P);if(!e.isValid(w))throw new Error("bad point: is not on curve, wrong x");let x=l(w),A;try{A=e.sqrt(x)}catch(N){let M=N instanceof Error?": "+N.message:"";throw new Error("bad point: is not on curve, sqrt error"+M)}a();let T=e.isOdd(A);return(L&1)===1!==T&&(A=e.neg(A)),{x:w,y:A}}else if(v===E&&L===4){let w=e.fromBytes(P.subarray(b*0,b*1)),x=e.fromBytes(P.subarray(b*1,b*2));if(!d(w,x))throw new Error("bad point: is not on curve");return{x:w,y:x}}else throw new Error(`bad point: got length ${v}, expected compressed=${g} or uncompressed=${E}`)}let h=t.toBytes||u,f=t.fromBytes||c,l=Xf(e,r.a,r.b);function d(C,b){let g=e.sqr(b),E=l(C);return e.eql(g,E)}if(!d(r.Gx,r.Gy))throw new Error("bad curve params: generator point");let m=e.mul(e.pow(r.a,cn),Zf),y=e.mul(e.sqr(r.b),BigInt(27));if(e.is0(e.add(m,y)))throw new Error("bad curve params: a or b");function p(C,b,g=!1){if(!e.isValid(b)||g&&e.is0(b))throw new Error(`bad point coordinate ${C}`);return b}function _(C){if(!(C instanceof B))throw new Error("ProjectivePoint expected")}function I(C){if(!i||!i.basises)throw new Error("no endo");return $f(C,i.basises,n.ORDER)}let S=Ue((C,b)=>{let{X:g,Y:E,Z:v}=C;if(e.eql(v,e.ONE))return{x:g,y:E};let L=C.is0();b==null&&(b=L?e.ONE:e.inv(v));let P=e.mul(g,b),w=e.mul(E,b),x=e.mul(v,b);if(L)return{x:e.ZERO,y:e.ZERO};if(!e.eql(x,e.ONE))throw new Error("invZ was invalid");return{x:P,y:w}}),D=Ue(C=>{if(C.is0()){if(t.allowInfinityPoint&&!e.is0(C.Y))return;throw new Error("bad point: ZERO")}let{x:b,y:g}=C.toAffine();if(!e.isValid(b)||!e.isValid(g))throw new Error("bad point: x or y not field elements");if(!d(b,g))throw new Error("bad point: equation left != right");if(!C.isTorsionFree())throw new Error("bad point: not in prime-order subgroup");return!0});function R(C,b,g,E,v){return g=new B(e.mul(g.X,C),g.Y,g.Z),b=xr(E,b),g=xr(v,g),b.add(g)}class B{constructor(b,g,E){this.X=p("x",b),this.Y=p("y",g,!0),this.Z=p("z",E),Object.freeze(this)}static fromAffine(b){let{x:g,y:E}=b||{};if(!b||!e.isValid(g)||!e.isValid(E))throw new Error("invalid affine point");if(b instanceof B)throw new Error("projective point not allowed");return e.is0(g)&&e.is0(E)?B.ZERO:new B(g,E,e.ONE)}get x(){return this.toAffine().x}get y(){return this.toAffine().y}get px(){return this.X}get py(){return this.X}get pz(){return this.Z}static normalizeZ(b){return zt(B,b)}static fromBytes(b){return Y(b),B.fromHex(b)}static fromHex(b){let g=B.fromAffine(f(z("pointHex",b)));return g.assertValidity(),g}static fromPrivateKey(b){return B.BASE.multiply(Ve(n,b))}static msm(b,g){return Fe(B,n,b,g)}_setWindowSize(b){this.precompute(b)}precompute(b=8,g=!0){return U.createCache(this,b),g||this.multiply(cn),this}assertValidity(){D(this)}hasEvenY(){let{y:b}=this.toAffine();if(!e.isOdd)throw new Error("Field doesn't support isOdd");return!e.isOdd(b)}equals(b){_(b);let{X:g,Y:E,Z:v}=this,{X:L,Y:P,Z:w}=b,x=e.eql(e.mul(g,w),e.mul(L,v)),A=e.eql(e.mul(E,w),e.mul(P,v));return x&&A}negate(){return new B(this.X,e.neg(this.Y),this.Z)}double(){let{a:b,b:g}=r,E=e.mul(g,cn),{X:v,Y:L,Z:P}=this,w=e.ZERO,x=e.ZERO,A=e.ZERO,T=e.mul(v,v),O=e.mul(L,L),N=e.mul(P,P),M=e.mul(v,L);return M=e.add(M,M),A=e.mul(v,P),A=e.add(A,A),w=e.mul(b,A),x=e.mul(E,N),x=e.add(w,x),w=e.sub(O,x),x=e.add(O,x),x=e.mul(w,x),w=e.mul(M,w),A=e.mul(E,A),N=e.mul(b,N),M=e.sub(T,N),M=e.mul(b,M),M=e.add(M,A),A=e.add(T,T),T=e.add(A,T),T=e.add(T,N),T=e.mul(T,M),x=e.add(x,T),N=e.mul(L,P),N=e.add(N,N),T=e.mul(N,M),w=e.sub(w,T),A=e.mul(N,O),A=e.add(A,A),A=e.add(A,A),new B(w,x,A)}add(b){_(b);let{X:g,Y:E,Z:v}=this,{X:L,Y:P,Z:w}=b,x=e.ZERO,A=e.ZERO,T=e.ZERO,O=r.a,N=e.mul(r.b,cn),M=e.mul(g,L),V=e.mul(E,P),q=e.mul(v,w),pt=e.add(g,E),F=e.add(L,P);pt=e.mul(pt,F),F=e.add(M,V),pt=e.sub(pt,F),F=e.add(g,v);let Q=e.add(L,w);return F=e.mul(F,Q),Q=e.add(M,q),F=e.sub(F,Q),Q=e.add(E,v),x=e.add(P,w),Q=e.mul(Q,x),x=e.add(V,q),Q=e.sub(Q,x),T=e.mul(O,F),x=e.mul(N,q),T=e.add(x,T),x=e.sub(V,T),T=e.add(V,T),A=e.mul(x,T),V=e.add(M,M),V=e.add(V,M),q=e.mul(O,q),F=e.mul(N,F),V=e.add(V,q),q=e.sub(M,q),q=e.mul(O,q),F=e.add(F,q),M=e.mul(V,F),A=e.add(A,M),M=e.mul(Q,F),x=e.mul(pt,x),x=e.sub(x,M),M=e.mul(pt,V),T=e.mul(Q,T),T=e.add(T,M),new B(x,A,T)}subtract(b){return this.add(b.negate())}is0(){return this.equals(B.ZERO)}multiply(b){let{endo:g}=t;if(!n.isValidNot0(b))throw new Error("invalid scalar: out of range");let E,v,L=P=>U.cached(this,P,w=>zt(B,w));if(g){let{k1neg:P,k1:w,k2neg:x,k2:A}=I(b),{p:T,f:O}=L(w),{p:N,f:M}=L(A);v=O.add(M),E=R(g.beta,T,N,P,x)}else{let{p:P,f:w}=L(b);E=P,v=w}return zt(B,[E,v])[0]}multiplyUnsafe(b){let{endo:g}=t,E=this;if(!n.isValid(b))throw new Error("invalid scalar: out of range");if(b===Zt||E.is0())return B.ZERO;if(b===je)return E;if(U.hasCache(this))return this.multiply(b);if(g){let{k1neg:v,k1:L,k2neg:P,k2:w}=I(b),{p1:x,p2:A}=ea(B,E,L,w);return R(g.beta,x,A,v,P)}else return U.unsafe(E,b)}multiplyAndAddUnsafe(b,g,E){let v=this.multiplyUnsafe(g).add(b.multiplyUnsafe(E));return v.is0()?void 0:v}toAffine(b){return S(this,b)}isTorsionFree(){let{isTorsionFree:b}=t;return o===je?!0:b?b(B,this):U.unsafe(this,s).is0()}clearCofactor(){let{clearCofactor:b}=t;return o===je?this:b?b(B,this):this.multiplyUnsafe(o)}isSmallOrder(){return this.multiplyUnsafe(o).is0()}toBytes(b=!0){return Ut("isCompressed",b),this.assertValidity(),h(B,this,b)}toRawBytes(b=!0){return this.toBytes(b)}toHex(b=!0){return Et(this.toBytes(b))}toString(){return`<Point ${this.is0()?"ZERO":this.toHex()}>`}}B.BASE=new B(r.Gx,r.Gy,e.ONE),B.ZERO=new B(e.ZERO,e.ONE,e.ZERO),B.Fp=e,B.Fn=n;let k=n.BITS,U=new Ke(B,t.endo?Math.ceil(k/2):k);return B}function Sa(r){return Uint8Array.of(r?2:3)}function Wf(r,t,e={}){Vr(t),ie(e,{},{hmac:"function",lowS:"boolean",randomBytes:"function",bits2int:"function",bits2int_modN:"function"});let n=e.randomBytes||dr,o=e.hmac||((w,...x)=>ss(t,w,lt(...x))),{Fp:s,Fn:i}=r,{ORDER:a,BITS:u}=i,c=Do(a),h={secret:i.BYTES,public:1+s.BYTES,publicUncompressed:1+2*s.BYTES,signature:2*i.BYTES,seed:c};function f(w){let x=a>>je;return w>x}function l(w){return f(w)?i.neg(w):w}function d(w,x){if(!i.isValidNot0(x))throw new Error(`invalid signature ${w}: out of range 1..CURVE.n`)}class m{constructor(x,A,T){d("r",x),d("s",A),this.r=x,this.s=A,T!=null&&(this.recovery=T),Object.freeze(this)}static fromBytes(x,A="compact"){if(A==="compact"){let T=i.BYTES;Y(x,T*2);let O=x.subarray(0,T),N=x.subarray(T,T*2);return new m(i.fromBytes(O),i.fromBytes(N))}if(A==="der"){Y(x);let{r:T,s:O}=$t.toSig(x);return new m(T,O)}throw new Error("invalid format")}static fromHex(x,A){return this.fromBytes(pe(x),A)}addRecoveryBit(x){return new m(this.r,this.s,x)}recoverPublicKey(x){let A=s.ORDER,{r:T,s:O,recovery:N}=this;if(N==null||![0,1,2,3].includes(N))throw new Error("recovery id invalid");if(a*_a<A&&N>1)throw new Error("recovery id is ambiguous for h>1 curve");let V=N===2||N===3?T+a:T;if(!s.isValid(V))throw new Error("recovery id 2 or 3 invalid");let q=s.toBytes(V),pt=r.fromHex(lt(Sa((N&1)===0),q)),F=i.inv(V),Q=k(z("msgHash",x)),mt=i.create(-Q*F),Wt=i.create(O*F),ce=r.BASE.multiplyUnsafe(mt).add(pt.multiplyUnsafe(Wt));if(ce.is0())throw new Error("point at infinify");return ce.assertValidity(),ce}hasHighS(){return f(this.s)}normalizeS(){return this.hasHighS()?new m(this.r,i.neg(this.s),this.recovery):this}toBytes(x="compact"){if(x==="compact")return lt(i.toBytes(this.r),i.toBytes(this.s));if(x==="der")return pe($t.hexFromSig(this));throw new Error("invalid format")}toHex(x){return Et(this.toBytes(x))}assertValidity(){}static fromCompact(x){return m.fromBytes(z("sig",x),"compact")}static fromDER(x){return m.fromBytes(z("sig",x),"der")}toDERRawBytes(){return this.toBytes("der")}toDERHex(){return Et(this.toBytes("der"))}toCompactRawBytes(){return this.toBytes("compact")}toCompactHex(){return Et(this.toBytes("compact"))}}function y(w){try{return!!Ve(i,w)}catch{return!1}}function p(w,x){try{let A=w.length;return x===!0&&A!==h.public||x===!1&&A!==h.publicUncompressed?!1:!!r.fromBytes(w)}catch{return!1}}function _(w=n(c)){return Co(w,a)}let I={isValidSecretKey:y,isValidPublicKey:p,randomSecretKey:_,isValidPrivateKey:y,randomPrivateKey:_,normPrivateKeyToScalar:w=>Ve(i,w),precompute(w=8,x=r.BASE){return x.precompute(w,!1)}};function S(w,x=!0){return r.BASE.multiply(Ve(i,w)).toBytes(x)}function D(w){if(typeof w=="bigint")return!1;if(w instanceof r)return!0;if(i.allowedLengths||h.secret===h.public)return;let x=z("key",w).length;return x===h.public||x===h.publicUncompressed}function R(w,x,A=!0){if(D(w)===!0)throw new Error("first arg must be private key");if(D(x)===!1)throw new Error("second arg must be public key");let T=Ve(i,w);return r.fromHex(x).multiply(T).toBytes(A)}let B=e.bits2int||function(w){if(w.length>8192)throw new Error("input is too large");let x=ke(w),A=w.length*8-u;return A>0?x>>BigInt(A):x},k=e.bits2int_modN||function(w){return i.create(B(w))},U=se(u);function C(w){return oe("num < 2^"+u,w,Zt,U),i.toBytes(w)}function b(w,x,A=g){if(["recovered","canonical"].some(mt=>mt in A))throw new Error("sign() legacy options not supported");let{lowS:T,prehash:O,extraEntropy:N}=A;T==null&&(T=!0),w=z("msgHash",w),Ea(A),O&&(w=z("prehashed msgHash",t(w)));let M=k(w),V=Ve(i,x),q=[C(V),C(M)];if(N!=null&&N!==!1){let mt=N===!0?n(h.secret):N;q.push(z("extraEntropy",mt))}let pt=lt(...q),F=M;function Q(mt){let Wt=B(mt);if(!i.isValidNot0(Wt))return;let ce=i.inv(Wt),tr=r.BASE.multiply(Wt).toAffine(),ue=i.create(tr.x);if(ue===Zt)return;let er=i.create(ce*i.create(F+ue*V));if(er===Zt)return;let Ks=(tr.x===ue?0:2)|Number(tr.y&je),Fs=er;return T&&f(er)&&(Fs=l(er),Ks^=1),new m(ue,Fs,Ks)}return{seed:pt,k2sig:Q}}let g={lowS:e.lowS,prehash:!1},E={lowS:e.lowS,prehash:!1};function v(w,x,A=g){let{seed:T,k2sig:O}=b(w,x,A);return Mi(t.outputLen,i.BYTES,o)(T,O)}r.BASE.precompute(8);function L(w,x,A,T=E){let O=w;x=z("msgHash",x),A=z("publicKey",A),Ea(T);let{lowS:N,prehash:M,format:V}=T;if("strict"in T)throw new Error("options.strict was renamed to lowS");let q,pt;if(V===void 0){let F=typeof O=="string"||de(O),Q=!F&&O!==null&&typeof O=="object"&&typeof O.r=="bigint"&&typeof O.s=="bigint";if(!F&&!Q)throw new Error("invalid signature, expected Uint8Array, hex string or Signature instance");if(Q)q=new m(O.r,O.s);else if(F){try{q=m.fromDER(O)}catch(mt){if(!(mt instanceof $t.Err))throw mt}if(!q)try{q=m.fromCompact(O)}catch{return!1}}}else if(V==="compact"||V==="der"){if(typeof O!="string"&&!de(O))throw new Error('"der" / "compact" format expects Uint8Array signature');q=m.fromBytes(z("sig",O),V)}else if(V==="js"){if(!(O instanceof m))throw new Error('"js" format expects Signature instance');q=O}else throw new Error('format must be "compact", "der" or "js"');if(!q)return!1;try{if(pt=r.fromHex(A),N&&q.hasHighS())return!1;M&&(x=t(x));let{r:F,s:Q}=q,mt=k(x),Wt=i.inv(Q),ce=i.create(mt*Wt),tr=i.create(F*Wt),ue=r.BASE.multiplyUnsafe(ce).add(pt.multiplyUnsafe(tr));return ue.is0()?!1:i.create(ue.x)===F}catch{return!1}}function P(w){let x=I.randomSecretKey(w);return{secretKey:x,publicKey:S(x)}}return Object.freeze({keygen:P,getPublicKey:S,sign:v,verify:L,getSharedSecret:R,utils:I,Point:r,Signature:m,info:{type:"weierstrass",lengths:h,publicKeyHasPrefix:!0}})}function Qf(r){let t={a:r.a,b:r.b,p:r.Fp.ORDER,n:r.n,h:r.h,Gx:r.Gx,Gy:r.Gy},e=r.Fp,n=r.allowedPrivateKeyLengths?Array.from(new Set(r.allowedPrivateKeyLengths.map(i=>Math.ceil(i/2)))):void 0,o=yt(t.n,{BITS:r.nBitLength,allowedLengths:n,modOnDecode:r.wrapPrivateKey}),s={Fp:e,Fn:o,allowInfinityPoint:r.allowInfinityPoint,endo:r.endo,isTorsionFree:r.isTorsionFree,clearCofactor:r.clearCofactor,fromBytes:r.fromBytes,toBytes:r.toBytes};return{CURVE:t,curveOpts:s}}function Jf(r){let{CURVE:t,curveOpts:e}=Qf(r),n={hmac:r.hmac,randomBytes:r.randomBytes,lowS:r.lowS,bits2int:r.bits2int,bits2int_modN:r.bits2int_modN};return{CURVE:t,curveOpts:e,hash:r.hash,ecdsaOpts:n}}function tl(r,t){return Object.assign({},t,{ProjectivePoint:t.Point,CURVE:r})}function va(r){let{CURVE:t,curveOpts:e,hash:n,ecdsaOpts:o}=Jf(r),s=Yf(t,e),i=Wf(s,n,o);return tl(r,i)}function Aa(r,t){let e=n=>va({...r,hash:n});return{...e(t),create:e}}var cs={p:BigInt("0xfffffffffffffffffffffffffffffffffffffffffffffffffffffffefffffc2f"),n:BigInt("0xfffffffffffffffffffffffffffffffebaaedce6af48a03bbfd25e8cd0364141"),h:BigInt(1),a:BigInt(0),b:BigInt(7),Gx:BigInt("0x79be667ef9dcbbac55a06295ce870b07029bfcdb2dce28d959f2815b16f81798"),Gy:BigInt("0x483ada7726a3c4655da4fbfc0e1108a8fd17b448a68554199c47d08ffb10d4b8")},el={beta:BigInt("0x7ae96a2b657c07106e64479eac3434e99cf0497512f58995c1396c28719501ee"),basises:[[BigInt("0x3086d221a7d46bcde86c90e49284eb15"),-BigInt("0xe4437ed6010e88286f547fa90abfe4c3")],[BigInt("0x114ca50f7a8e2f3f657c1108d9d44cfd8"),BigInt("0x3086d221a7d46bcde86c90e49284eb15")]]};var Ia=BigInt(2);function rl(r){let t=cs.p,e=BigInt(3),n=BigInt(6),o=BigInt(11),s=BigInt(22),i=BigInt(23),a=BigInt(44),u=BigInt(88),c=r*r*r%t,h=c*c*r%t,f=$(h,e,t)*h%t,l=$(f,e,t)*h%t,d=$(l,Ia,t)*c%t,m=$(d,o,t)*d%t,y=$(m,s,t)*m%t,p=$(y,a,t)*y%t,_=$(p,u,t)*p%t,I=$(_,a,t)*y%t,S=$(I,e,t)*h%t,D=$(S,i,t)*m%t,R=$(D,n,t)*c%t,B=$(R,Ia,t);if(!as.eql(as.sqr(B),r))throw new Error("Cannot find square root");return B}var as=yt(cs.p,void 0,void 0,{sqrt:rl}),Ge=Aa({...cs,Fp:as,lowS:!0,endo:el},Ri);function Ba(r,t,e,n){let o=ar.digest(e instanceof Uint8Array?e:e.subarray());if(tn(o))return o.then(({digest:s})=>(n?.signal?.throwIfAborted(),Ge.verify(t,s,r))).catch(s=>{throw s.name==="AbortError"?s:new Er(String(s))});try{return n?.signal?.throwIfAborted(),Ge.verify(t,o.digest,r)}catch(s){throw new Er(String(s))}}var un=class{type="secp256k1";raw;_key;constructor(t){this._key=Da(t),this.raw=Ta(this._key)}toMultihash(){return _t.digest(Re(this))}toCID(){return et.createV1(114,this.toMultihash())}toString(){return Z.encode(this.toMultihash().bytes).substring(1)}equals(t){return t==null||!(t.raw instanceof Uint8Array)?!1:ct(this.raw,t.raw)}verify(t,e,n){return Ba(this._key,e,t,n)}};function Ca(r){return new un(r)}function Ta(r){return Ge.ProjectivePoint.fromHex(r).toRawBytes(!0)}function Da(r){try{return Ge.ProjectivePoint.fromHex(r),r}catch(t){throw new Ur(String(t))}}function La(r){let{Type:t,Data:e}=Ar.decode(r.digest),n=e??new Uint8Array;switch(t){case wt.Ed25519:return ua(n);case wt.secp256k1:return Ca(n);case wt.ECDSA:return gi(n);default:throw new rr}}function Re(r){return Ar.encode({Type:wt[r.type],Data:r.raw})}var Pa=Symbol.for("nodejs.util.inspect.custom"),nl=114,Ir=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()})`}[qn]=!0;toString(){return this.string==null&&(this.string=Z.encode(this.multihash.bytes).slice(1)),this.string}toMultihash(){return this.multihash}toCID(){return et.createV1(nl,this.multihash)}toJSON(){return this.toString()}equals(t){if(t==null)return!1;if(t instanceof Uint8Array)return ct(this.multihash.bytes,t);if(typeof t=="string")return this.toString()===t;if(t?.toMultihash()?.bytes!=null)return ct(this.multihash.bytes,t.toMultihash().bytes);throw new Error("not valid Id")}[Pa](){return`PeerId(${this.toString()})`}},fn=class extends Ir{type="RSA";publicKey;constructor(t){super({...t,type:"RSA"}),this.publicKey=t.publicKey}},ln=class extends Ir{type="Ed25519";publicKey;constructor(t){super({...t,type:"Ed25519"}),this.publicKey=t.publicKey}},hn=class extends Ir{type="secp256k1";publicKey;constructor(t){super({...t,type:"secp256k1"}),this.publicKey=t.publicKey}},ol=2336,dn=class{type="url";multihash;publicKey;url;constructor(t){this.url=t.toString(),this.multihash=_t.digest(H(this.url))}[Pa](){return`PeerId(${this.url})`}[qn]=!0;toString(){return this.toCID().toString()}toMultihash(){return this.multihash}toCID(){return et.createV1(ol,this.toMultihash())}toJSON(){return this.toString()}equals(t){return t==null?!1:(t instanceof Uint8Array&&(t=G(t)),t.toString()===this.toString())}};function pn(r){if(il(r))return new fn({multihash:r});if(sl(r))try{let t=La(r);if(t.type==="Ed25519")return new ln({multihash:r,publicKey:t});if(t.type==="secp256k1")return new hn({multihash:r,publicKey:t})}catch{let e=G(r.digest);return new dn(new URL(e))}throw new Mr("Supplied PeerID Multihash is invalid")}function sl(r){return r.code===_t.code}function il(r){return r.code===ar.code}function us(r,t){let e={[Symbol.iterator]:()=>e,next:()=>{let n=r.next(),o=n.value;return n.done===!0||o==null?{done:!0,value:void 0}:{done:!1,value:t(o)}}};return e}function mn(r){let t=le(Z.decode(`z${r}`));return pn(t)}var gn=class r{set;constructor(t){if(this.set=new Set,t!=null)for(let e of t)this.set.add(e.toString())}get size(){return this.set.size}[Symbol.iterator](){return this.values()}add(t){this.set.add(t.toString())}clear(){this.set.clear()}delete(t){this.set.delete(t.toString())}entries(){return us(this.set.entries(),t=>{let e=mn(t[0]);return[e,e]})}forEach(t){this.set.forEach(e=>{let n=mn(e);t(n,n,this)})}has(t){return this.set.has(t.toString())}values(){return us(this.set.values(),t=>mn(t))}intersection(t){let e=new r;for(let n of t)this.has(n)&&e.add(n);return e}difference(t){let e=new r;for(let n of this)t.has(n)||e.add(n);return e}union(t){let e=new r;for(let n of t)e.add(n);for(let n of this)e.add(n);return e}};function fs(){return new gn}var ls={32:16777619n,64:1099511628211n,128:309485009821345068724781371n,256:374144419156711147060143317175368453031918731002211n,512:35835915874844867368919076489095108449946327955754392558399825615420669938882575126094039892345713852759n,1024:5016456510113118655434598811035278955030765345404790744303017523831112055108147451509157692220295382716162651878526895249385292291816524375083746691371804094271873160484737966720260389217684476157468082573n},Ra={32:2166136261n,64:14695981039346656037n,128:144066263297769815596495629667062367629n,256:100029257958052580907070968620625704837092796014241193945225284501741471925557n,512:9659303129496669498009435400716310466090418745672637896108374329434462657994582932197716438449813051892206539805784495328239340083876191928701583869517785n,1024:14197795064947621068722070641403218320880622795441933960878474914617582723252296732303717722150864096521202355549365628174669108571814760471015076148029755969804077320157692458563003215304957150157403644460363550505412711285966361610267868082893823963790439336411086884584107735010676915n},Oa=new globalThis.TextEncoder;function al(r,t){let e=ls[t],n=Ra[t];for(let o=0;o<r.length;o++)n^=BigInt(r[o]),n=BigInt.asUintN(t,n*e);return n}function cl(r,t,e){if(e.length===0)throw new Error("The `utf8Buffer` option must have a length greater than zero");let n=ls[t],o=Ra[t],s=r;for(;s.length>0;){let i=Oa.encodeInto(s,e);s=s.slice(i.read);for(let a=0;a<i.written;a++)o^=BigInt(e[a]),o=BigInt.asUintN(t,o*n)}return o}function hs(r,{size:t=32,utf8Buffer:e}={}){if(!ls[t])throw new Error("The `size` option must be one of 32, 64, 128, 256, 512, or 1024");if(typeof r=="string"){if(e)return cl(r,t,e);r=Oa.encode(r)}return al(r,t)}var Br={hash:r=>Number(hs(r,{size:32})),hashV:(r,t)=>ul(Br.hash(r,t))};function ul(r){let t=r.toString(16);return t.length%2===1&&(t=`0${t}`),H(t,"base16")}var ds=64,It=class{fp;h;seed;constructor(t,e,n,o=2){if(o>ds)throw new TypeError("Invalid Fingerprint Size");let s=e.hashV(t,n),i=St(o);for(let a=0;a<i.length;a++)i[a]=s[a];i.length===0&&(i[0]=7),this.fp=i,this.h=e,this.seed=n}hash(){return this.h.hash(this.fp,this.seed)}equals(t){return t?.fp instanceof Uint8Array?ct(this.fp,t.fp):!1}};function _e(r,t){return Math.floor(Math.random()*(t-r))+r}var Se=class{contents;constructor(t){this.contents=new Array(t).fill(null)}has(t){if(!(t instanceof It))throw new TypeError("Invalid Fingerprint");return this.contents.some(e=>t.equals(e))}add(t){if(!(t instanceof It))throw new TypeError("Invalid Fingerprint");for(let e=0;e<this.contents.length;e++)if(this.contents[e]==null)return this.contents[e]=t,!0;return!0}swap(t){if(!(t instanceof It))throw new TypeError("Invalid Fingerprint");let e=_e(0,this.contents.length-1),n=this.contents[e];return this.contents[e]=t,n}remove(t){if(!(t instanceof It))throw new TypeError("Invalid Fingerprint");let e=this.contents.findIndex(n=>t.equals(n));return e>-1?(this.contents[e]=null,!0):!1}};var fl=500,Tr=class{bucketSize;filterSize;fingerprintSize;buckets;count;hash;seed;constructor(t){this.filterSize=t.filterSize,this.bucketSize=t.bucketSize??4,this.fingerprintSize=t.fingerprintSize??2,this.count=0,this.buckets=[],this.hash=t.hash??Br,this.seed=t.seed??_e(0,Math.pow(2,10))}add(t){typeof t=="string"&&(t=H(t));let e=new It(t,this.hash,this.seed,this.fingerprintSize),n=this.hash.hash(t,this.seed)%this.filterSize,o=(n^e.hash())%this.filterSize;if(this.buckets[n]==null&&(this.buckets[n]=new Se(this.bucketSize)),this.buckets[o]==null&&(this.buckets[o]=new Se(this.bucketSize)),this.buckets[n].add(e)||this.buckets[o].add(e))return this.count++,!0;let s=[n,o],i=s[_e(0,s.length-1)];this.buckets[i]==null&&(this.buckets[i]=new Se(this.bucketSize));for(let a=0;a<fl;a++){let u=this.buckets[i].swap(e);if(u!=null&&(i=(i^u.hash())%this.filterSize,this.buckets[i]==null&&(this.buckets[i]=new Se(this.bucketSize)),this.buckets[i].add(u)))return this.count++,!0}return!1}has(t){typeof t=="string"&&(t=H(t));let e=new It(t,this.hash,this.seed,this.fingerprintSize),n=this.hash.hash(t,this.seed)%this.filterSize,o=this.buckets[n]?.has(e)??!1;if(o)return o;let s=(n^e.hash())%this.filterSize;return this.buckets[s]?.has(e)??!1}remove(t){typeof t=="string"&&(t=H(t));let e=new It(t,this.hash,this.seed,this.fingerprintSize),n=this.hash.hash(t,this.seed)%this.filterSize,o=this.buckets[n]?.remove(e)??!1;if(o)return this.count--,o;let s=(n^e.hash())%this.filterSize,i=this.buckets[s]?.remove(e)??!1;return i&&this.count--,i}get reliable(){return Math.floor(100*(this.count/this.filterSize))<=90}},ll={1:.5,2:.84,4:.95,8:.98};function hl(r=.001){return r>.002?2:r>1e-5?4:8}function Na(r,t=.001){let e=hl(t),n=ll[e],o=Math.round(r/n),s=Math.min(Math.ceil(Math.log2(1/t)+Math.log2(2*e)),ds);return{filterSize:o,bucketSize:e,fingerprintSize:s}}var yn=class{filterSize;bucketSize;fingerprintSize;scale;filterSeries;hash;seed;constructor(t){this.bucketSize=t.bucketSize??4,this.filterSize=t.filterSize??(1<<18)/this.bucketSize,this.fingerprintSize=t.fingerprintSize??2,this.scale=t.scale??2,this.hash=t.hash??Br,this.seed=t.seed??_e(0,Math.pow(2,10)),this.filterSeries=[new Tr({filterSize:this.filterSize,bucketSize:this.bucketSize,fingerprintSize:this.fingerprintSize,hash:this.hash,seed:this.seed})]}add(t){if(typeof t=="string"&&(t=H(t)),this.has(t))return!0;let e=this.filterSeries.find(n=>n.reliable);if(e==null){let n=this.filterSize*Math.pow(this.scale,this.filterSeries.length);e=new Tr({filterSize:n,bucketSize:this.bucketSize,fingerprintSize:this.fingerprintSize,hash:this.hash,seed:this.seed}),this.filterSeries.push(e)}return e.add(t)}has(t){typeof t=="string"&&(t=H(t));for(let e=0;e<this.filterSeries.length;e++)if(this.filterSeries[e].has(t))return!0;return!1}remove(t){typeof t=="string"&&(t=H(t));for(let e=0;e<this.filterSeries.length;e++)if(this.filterSeries[e].remove(t))return!0;return!1}get count(){return this.filterSeries.reduce((t,e)=>t+e.count,0)}};function ps(r,t=.001,e){return new yn({...Na(r,t),...e??{}})}var bn=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 u=a==="0",c=2**(8*o)-1;for(;;){let h=this.readAtomically(()=>{let f=this.readChar();if(f===void 0)return;let l=Number.parseInt(f,t);if(!Number.isNaN(l))return l});if(h===void 0)break;if(s*=t,s+=h,s>c||(i+=1,e!==void 0&&i>e))return}if(i!==0)return!n&&u&&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 ka=45,dl=15,$e=new bn;function xn(r){if(!(r.length>dl))return $e.new(r).parseWith(()=>$e.readIPv4Addr())}function wn(r){if(r.includes("%")&&(r=r.split("%")[0]),!(r.length>ka))return $e.new(r).parseWith(()=>$e.readIPv6Addr())}function Ze(r,t=!1){if(r.includes("%")&&(r=r.split("%")[0]),r.length>ka)return;let e=$e.new(r).parseWith(()=>$e.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 Ua(r,t,e){let n=0;for(let o of r)if(!(n<t)){if(n>e)break;if(o!==255)return!1;n++}return!0}function Ma(r,t,e,n){let o=0;for(let s of r)if(!(o<e)){if(o>n)break;if(s!==t[o])return!1;o++}return!0}function ms(r){switch(r.length){case ve:return r.join(".");case Ae:{let t=[];for(let e=0;e<r.length;e++)e%2===0&&t.push(r[e].toString(16).padStart(2,"0")+r[e+1].toString(16).padStart(2,"0"));return t.join(":")}default:throw new Error("Invalid ip length")}}function Ka(r){let t=0;for(let[e,n]of r.entries()){if(n===255){t+=8;continue}for(;(n&128)!=0;)t++,n=n<<1;if((n&128)!=0)return-1;for(let o=e+1;o<r.length;o++)if(r[o]!=0)return-1;break}return t}function Fa(r){let t="0x";for(let e of r)t+=(e>>4).toString(16)+(e&15).toString(16);return t}var ve=4,Ae=16,Jg=parseInt("0xFFFF",16),pl=new Uint8Array([0,0,0,0,0,0,0,0,0,0,255,255]);function Dr(r,t){t.length===Ae&&r.length===ve&&Ua(t,0,11)&&(t=t.slice(12)),t.length===ve&&r.length===Ae&&Ma(r,pl,0,11)&&(r=r.slice(12));let e=r.length;if(e!=t.length)throw new Error("Failed to mask ip");let n=new Uint8Array(e);for(let o=0;o<e;o++)n[o]=r[o]&t[o];return n}function za(r,t){if(typeof t=="string"&&(t=Ze(t)),t==null)throw new Error("Invalid ip");if(t.length!==r.network.length)return!1;for(let e=0;e<t.length;e++)if((r.network[e]&r.mask[e])!==(t[e]&r.mask[e]))return!1;return!0}function gs(r){let[t,e]=r.split("/");if(!t||!e)throw new Error("Failed to parse given CIDR: "+r);let n=ve,o=xn(t);if(o==null&&(n=Ae,o=wn(t),o==null))throw new Error("Failed to parse given CIDR: "+r);let s=parseInt(e,10);if(Number.isNaN(s)||String(s).length!==e.length||s<0||s>n*8)throw new Error("Failed to parse given CIDR: "+r);let i=ys(s,8*n);return{network:Dr(o,i),mask:i}}function ys(r,t){if(t!==8*ve&&t!==8*Ae)throw new Error("Invalid CIDR mask");if(r<0||r>t)throw new Error("Invalid CIDR mask");let e=t/8,n=new Uint8Array(e);for(let o=0;o<e;o++){if(r>=8){n[o]=255,r-=8;continue}n[o]=255-(255>>r),r=0}return n}var Xe=class{constructor(t,e){if(e==null)({network:this.network,mask:this.mask}=gs(t));else{let n=Ze(t);if(n==null)throw new Error("Failed to parse network");e=String(e);let o=parseInt(e,10);if(Number.isNaN(o)||String(o).length!==e.length||o<0||o>n.length*8){let s=Ze(e);if(s==null)throw new Error("Failed to parse mask");this.mask=s}else this.mask=ys(o,8*n.length);this.network=Dr(n,this.mask)}}contains(t){return za({network:this.network,mask:this.mask},t)}toString(){let t=Ka(this.mask),e=t!==-1?String(t):Fa(this.mask);return ms(this.network)+"/"+e}};function qa(r,t){return new Xe(r).contains(t)}var st=class extends Error{static name="InvalidMultiaddrError";name="InvalidMultiaddrError"},Xt=class extends Error{static name="ValidationError";name="ValidationError"},Cr=class extends Error{static name="InvalidParametersError";name="InvalidParametersError"},En=class extends Error{static name="UnknownProtocolError";name="UnknownProtocolError"};function Ye(r){return!!xn(r)}function _n(r){return!!wn(r)}function xs(r){return t=>G(t,r)}function ws(r){return t=>H(t,r)}function We(r){return new DataView(r.buffer).getUint16(r.byteOffset).toString()}function Ie(r){let t=new ArrayBuffer(2);return new DataView(t).setUint16(0,typeof r=="string"?parseInt(r):r),new Uint8Array(t)}function Ha(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=H(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=Ie(n);return Rt([e,o],e.length+o.length)}function Va(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=Jt.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=Ie(n);return Rt([e,o],e.length+o.length)}function Es(r){let t=r.subarray(0,r.length-2),e=r.subarray(r.length-2),n=G(t,"base32"),o=We(e);return`${n}:${o}`}var _s=function(r){r=r.toString().trim();let t=new Uint8Array(4);return r.split(/\./g).forEach((e,n)=>{let o=parseInt(e,10);if(isNaN(o)||o<0||o>255)throw new st("Invalid byte value in IP address");t[n]=o}),t},ja=function(r){let t=0;r=r.toString().trim();let e=r.split(":",8),n;for(n=0;n<e.length;n++){let s=Ye(e[n]),i;s&&(i=_s(e[n]),e[n]=G(i.subarray(0,2),"base16")),i!=null&&++n<8&&e.splice(n,0,G(i.subarray(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++){e[n]===""&&(e[n]="0");let s=parseInt(e[n],16);if(isNaN(s)||s<0||s>65535)throw new st("Invalid byte value in IP address");o[t++]=s>>8&255,o[t++]=s&255}return o},Ga=function(r){if(r.byteLength!==4)throw new st("IPv4 address was incorrect length");let t=[];for(let e=0;e<r.byteLength;e++)t.push(r[e]);return t.join(".")},$a=function(r){if(r.byteLength!==16)throw new st("IPv6 address was incorrect length");let t=[];for(let n=0;n<r.byteLength;n+=2){let o=r[n],s=r[n+1],i=`${o.toString(16).padStart(2,"0")}${s.toString(16).padStart(2,"0")}`;t.push(i)}let e=t.join(":");try{let n=new URL(`http://[${e}]`);return n.hostname.substring(1,n.hostname.length-1)}catch{throw new st(`Invalid IPv6 address "${e}"`)}};function Za(r){try{let t=new URL(`http://[${r}]`);return t.hostname.substring(1,t.hostname.length-1)}catch{throw new st(`Invalid IPv6 address "${r}"`)}}var bs=Object.values(cr).map(r=>r.decoder),ml=function(){let r=bs[0].or(bs[1]);return bs.slice(2).forEach(t=>r=r.or(t)),r}();function Xa(r){return ml.decode(r)}function Ya(r){return t=>r.encoder.encode(t)}function gl(r){if(parseInt(r).toString()!==r)throw new Xt("Value must be an integer")}function yl(r){if(r<0)throw new Xt("Value must be a positive integer, or zero")}function bl(r){return t=>{if(t>r)throw new Xt(`Value must be smaller than or equal to ${r}`)}}function xl(...r){return t=>{for(let e of r)e(t)}}var Lr=xl(gl,yl,bl(65535));var nt=-1,Ss=class{protocolsByCode=new Map;protocolsByName=new Map;getProtocol(t){let e;if(typeof t=="string"?e=this.protocolsByName.get(t):e=this.protocolsByCode.get(t),e==null)throw new En(`Protocol ${t} was unknown`);return e}addProtocol(t){this.protocolsByCode.set(t.code,t),this.protocolsByName.set(t.name,t),t.aliases?.forEach(e=>{this.protocolsByName.set(e,t)})}removeProtocol(t){let e=this.protocolsByCode.get(t);e!=null&&(this.protocolsByCode.delete(e.code),this.protocolsByName.delete(e.name),e.aliases?.forEach(n=>{this.protocolsByName.delete(n)}))}},dt=new Ss,Xl=[{code:4,name:"ip4",size:32,valueToBytes:_s,bytesToValue:Ga,validate:r=>{if(!Ye(r))throw new Xt(`Invalid IPv4 address "${r}"`)}},{code:6,name:"tcp",size:16,valueToBytes:Ie,bytesToValue:We,validate:Lr},{code:273,name:"udp",size:16,valueToBytes:Ie,bytesToValue:We,validate:Lr},{code:33,name:"dccp",size:16,valueToBytes:Ie,bytesToValue:We,validate:Lr},{code:41,name:"ip6",size:128,valueToBytes:ja,bytesToValue:$a,stringToValue:Za,validate:r=>{if(!_n(r))throw new Xt(`Invalid IPv6 address "${r}"`)}},{code:42,name:"ip6zone",size:nt},{code:43,name:"ipcidr",size:8,bytesToValue:xs("base10"),valueToBytes:ws("base10")},{code:53,name:"dns",size:nt,resolvable:!0},{code:54,name:"dns4",size:nt,resolvable:!0},{code:55,name:"dns6",size:nt,resolvable:!0},{code:56,name:"dnsaddr",size:nt,resolvable:!0},{code:132,name:"sctp",size:16,valueToBytes:Ie,bytesToValue:We,validate:Lr},{code:301,name:"udt"},{code:302,name:"utp"},{code:400,name:"unix",size:nt,path:!0,stringToValue:r=>decodeURIComponent(r),valueToString:r=>encodeURIComponent(r)},{code:421,name:"p2p",aliases:["ipfs"],size:nt,bytesToValue:xs("base58btc"),valueToBytes:r=>r.startsWith("Q")||r.startsWith("1")?ws("base58btc")(r):et.parse(r).multihash.bytes},{code:444,name:"onion",size:96,bytesToValue:Es,valueToBytes:Ha},{code:445,name:"onion3",size:296,bytesToValue:Es,valueToBytes:Va},{code:446,name:"garlic64",size:nt},{code:447,name:"garlic32",size:nt},{code:448,name:"tls"},{code:449,name:"sni",size:nt},{code:454,name:"noise"},{code:460,name:"quic"},{code:461,name:"quic-v1"},{code:465,name:"webtransport"},{code:466,name:"certhash",size:nt,bytesToValue:Ya(no),valueToBytes:Xa},{code:480,name:"http"},{code:481,name:"http-path",size:nt,stringToValue:r=>`/${decodeURIComponent(r)}`,valueToString:r=>encodeURIComponent(r.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:nt}];Xl.forEach(r=>{dt.addProtocol(r)});function Wa(r){let t=[],e=0;for(;e<r.length;){let n=_r(r,e),o=dt.getProtocol(n),s=ht(n),i=Yl(o,r,e+s),a=0;i>0&&o.size===nt&&(a=ht(i));let u=s+a+i,c={code:n,name:o.name,bytes:r.subarray(e,e+u)};if(i>0){let h=e+s+a,f=r.subarray(h,h+i);c.value=o.bytesToValue?.(f)??G(f)}t.push(c),e+=u}return t}function Qa(r){let t=0,e=[];for(let n of r){if(n.bytes==null){let o=dt.getProtocol(n.code),s=ht(n.code),i,a=0,u=0;n.value!=null&&(i=o.valueToBytes?.(n.value)??H(n.value),a=i.byteLength,o.size===nt&&(u=ht(a)));let c=new Uint8Array(s+u+a),h=0;ze(n.code,c,h),h+=s,i!=null&&(o.size===nt&&(ze(a,c,h),h+=u),c.set(i,h)),n.bytes=c}e.push(n.bytes),t+=n.bytes.byteLength}return Rt(e,t)}function Ja(r){if(r.charAt(0)!=="/")throw new st('String multiaddr must start with "/"');let t=[],e="protocol",n="",o="";for(let s=1;s<r.length;s++){let i=r.charAt(s);i!=="/"&&(e==="protocol"?o+=r.charAt(s):n+=r.charAt(s));let a=s===r.length-1;if(i==="/"||a){let u=dt.getProtocol(o);if(e==="protocol"){if(u.size==null||u.size===0){t.push({code:u.code,name:u.name}),n="",o="",e="protocol";continue}else if(a)throw new st(`Component ${o} was missing value`);e="value"}else if(e==="value"){let c={code:u.code,name:u.name};if(u.size!=null&&u.size!==0){if(n==="")throw new st(`Component ${o} was missing value`);c.value=u.stringToValue?.(n)??n}t.push(c),n="",o="",e="protocol"}}}if(o!==""&&n!=="")throw new st("Incomplete multiaddr");return t}function tc(r){return`/${r.flatMap(t=>{if(t.value==null)return t.name;let e=dt.getProtocol(t.code);if(e==null)throw new st(`Unknown protocol code ${t.code}`);return[t.name,e.valueToString?.(t.value)??t.value]}).join("/")}`}function Yl(r,t,e){return r.size==null||r.size===0?0:r.size>0?r.size/8:_r(t,e)}var Wl=Symbol.for("nodejs.util.inspect.custom"),Cs=Symbol.for("@multiformats/multiaddr"),Ql=[53,54,55,56],Ds=class extends Error{constructor(t="No available resolver"){super(t),this.name="NoAvailableResolverError"}};function Jl(r){if(r==null&&(r="/"),rc(r))return r.getComponents();if(r instanceof Uint8Array)return Wa(r);if(typeof r=="string")return r=r.replace(/\/(\/)+/,"/").replace(/(\/)+$/,""),r===""&&(r="/"),Ja(r);if(Array.isArray(r))return r;throw new st("Must be a string, Uint8Array, Component[], or another Multiaddr")}var In=class r{[Cs]=!0;#t;#e;#r;constructor(t="/",e={}){this.#t=Jl(t),e.validate!==!1&&th(this)}get bytes(){return this.#r==null&&(this.#r=Qa(this.#t)),this.#r}toString(){return this.#e==null&&(this.#e=tc(this.#t)),this.#e}toJSON(){return this.toString()}toOptions(){let t,e,n,o,s="";for(let{code:a,name:u,value:c}of this.#t)a===42&&(s=`%${c??""}`),Ql.includes(a)&&(e="tcp",o=443,n=`${c??""}${s}`,t=a===55?6:4),(a===6||a===273)&&(e=u==="tcp"?"tcp":"udp",o=parseInt(c??"")),(a===4||a===41)&&(e="tcp",n=`${c??""}${s}`,t=a===41?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}}getComponents(){return[...this.#t]}protos(){return this.#t.map(({code:t,value:e})=>{let n=dt.getProtocol(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:e})=>{if(e==null)return[t];let n=dt.getProtocol(t),o=[t];return e!=null&&o.push(n.valueToBytes?.(e)??H(e)),o})}stringTuples(){return this.#t.map(({code:t,value:e})=>e==null?[t]:[t,e])}encapsulate(t){let e=new r(t);return new r([...this.#t,...e.getComponents()],{validate:!1})}decapsulate(t){let e=t.toString(),n=this.toString(),o=n.lastIndexOf(e);if(o<0)throw new Cr(`Address ${this.toString()} does not contain subaddress: ${t.toString()}`);return new r(n.slice(0,o),{validate:!1})}decapsulateCode(t){let e;for(let n=this.#t.length-1;n>-1;n--)if(this.#t[n].code===t){e=n;break}return new r(this.#t.slice(0,e),{validate:!1})}getPeerId(){try{let t=[];this.#t.forEach(({code:n,value:o})=>{n===421&&t.push([n,o]),n===290&&(t=[])});let e=t.pop();if(e?.[1]!=null){let n=e[1];return n[0]==="Q"||n[0]==="1"?G(Z.decode(`z${n}`),"base58btc"):G(et.parse(n).multihash.bytes,"base58btc")}return null}catch{return null}}getPath(){for(let t of this.#t)if(dt.getProtocol(t.code).path)return t.value??null;return null}equals(t){return ct(this.bytes,t.bytes)}async resolve(t){let e=this.protos().find(s=>s.resolvable);if(e==null)return[this];let n=ec.get(e.name);if(n==null)throw new Ds(`no available resolver for ${e.name}`);return(await n(this,t)).map(s=>Rr(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)}[Wl](){return`Multiaddr(${this.toString()})`}};function th(r){r.getComponents().forEach(t=>{let e=dt.getProtocol(t.code);t.value!=null&&e.validate?.(t.value)})}var ec=new Map;function rc(r){return!!r?.[Cs]}function Rr(r){return new In(r)}function nc(r){let t=dt.getProtocol(r);return{code:t.code,size:t.size??0,name:t.name,resolvable:!!t.resolvable,path:!!t.path}}function oc(r){try{for(let{code:t,value:e}of r.getComponents())if(e!=null&&t===41)return qa("2000::/3",e)}catch{}return!1}var ic=Ac(sc(),1),eh=["0.0.0.0/8","10.0.0.0/8","100.64.0.0/10","127.0.0.0/8","169.254.0.0/16","172.16.0.0/12","192.0.0.0/24","192.0.0.0/29","192.0.0.8/32","192.0.0.9/32","192.0.0.10/32","192.0.0.170/32","192.0.0.171/32","192.0.2.0/24","192.31.196.0/24","192.52.193.0/24","192.88.99.0/24","192.168.0.0/16","192.175.48.0/24","198.18.0.0/15","198.51.100.0/24","203.0.113.0/24","240.0.0.0/4","255.255.255.255/32"],rh=eh.map(r=>new ic.Netmask(r));function Ls(r){for(let t of rh)if(t.contains(r))return!0;return!1}function nh(r){return/^::ffff:([0-9a-fA-F]{1,4}):([0-9a-fA-F]{1,4})$/.test(r)}function oh(r){let t=r.split(":");if(t.length<2)return!1;let e=t[t.length-1].padStart(4,"0"),n=t[t.length-2].padStart(4,"0"),o=`${parseInt(n.substring(0,2),16)}.${parseInt(n.substring(2),16)}.${parseInt(e.substring(0,2),16)}.${parseInt(e.substring(2),16)}`;return Ls(o)}function sh(r){return/^::ffff:([0-9]{1,3})\.([0-9]{1,3})\.([0-9]{1,3})\.([0-9]{1,3})$/.test(r)}function ih(r){let t=r.split(":"),e=t[t.length-1];return Ls(e)}function ah(r){return/^::$/.test(r)||/^::1$/.test(r)||/^64:ff9b::([0-9]{1,3})\.([0-9]{1,3})\.([0-9]{1,3})\.([0-9]{1,3})$/.test(r)||/^100::([0-9a-fA-F]{0,4}):?([0-9a-fA-F]{0,4}):?([0-9a-fA-F]{0,4}):?([0-9a-fA-F]{0,4})$/.test(r)||/^2001::([0-9a-fA-F]{0,4}):?([0-9a-fA-F]{0,4}):?([0-9a-fA-F]{0,4}):?([0-9a-fA-F]{0,4}):?([0-9a-fA-F]{0,4}):?([0-9a-fA-F]{0,4})$/.test(r)||/^2001:2[0-9a-fA-F]:([0-9a-fA-F]{0,4}):?([0-9a-fA-F]{0,4}):?([0-9a-fA-F]{0,4}):?([0-9a-fA-F]{0,4}):?([0-9a-fA-F]{0,4}):?([0-9a-fA-F]{0,4})$/.test(r)||/^2001:db8:([0-9a-fA-F]{0,4}):?([0-9a-fA-F]{0,4}):?([0-9a-fA-F]{0,4}):?([0-9a-fA-F]{0,4}):?([0-9a-fA-F]{0,4}):?([0-9a-fA-F]{0,4})$/.test(r)||/^2002:([0-9a-fA-F]{0,4}):?([0-9a-fA-F]{0,4}):?([0-9a-fA-F]{0,4}):?([0-9a-fA-F]{0,4}):?([0-9a-fA-F]{0,4}):?([0-9a-fA-F]{0,4}):?([0-9a-fA-F]{0,4})$/.test(r)||/^f[c-d]([0-9a-fA-F]{2,2}):/i.test(r)||/^fe[8-9a-bA-B][0-9a-fA-F]:/i.test(r)||/^ff([0-9a-fA-F]{2,2}):/i.test(r)}function ac(r){if(Ye(r))return Ls(r);if(nh(r))return oh(r);if(sh(r))return ih(r);if(_n(r))return ah(r)}function cc(r){try{for(let{code:t}of r.getComponents())if(t!==42)return t===4||t===41}catch{}return!1}function Ps(r){try{if(!cc(r))return!1;let[[,t]]=r.stringTuples();return t==null?!1:ac(t)??!1}catch{}return!0}function Bt(){let r={};return r.promise=new Promise((t,e)=>{r.resolve=t,r.reject=e}),r}var Bn=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}},Je=class{size;hwm;head;tail;constructor(t={}){this.hwm=t.splitLimit??16,this.head=new Bn(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 Bn(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 Rs=class extends Error{type;code;constructor(t,e){super(t??"The operation was aborted"),this.type="aborted",this.code=e??"ABORT_ERR"}};function uc(r={}){return ch(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 ch(r,t){t=t??{};let e=t.onEnd,n=new Je,o,s,i,a=Bt(),u=async()=>{try{return n.isEmpty()?i?{done:!0}:await new Promise((p,_)=>{s=I=>{s=null,n.push(I);try{p(r(n))}catch(S){_(S)}return o}}):r(n)}finally{n.isEmpty()&&queueMicrotask(()=>{a.resolve(),a=Bt()})}},c=p=>s!=null?s(p):(n.push(p),o),h=p=>(n=new Je,s!=null?s({error:p}):(n.push({error:p}),o)),f=p=>{if(i)return o;if(t?.objectMode!==!0&&p?.byteLength==null)throw new Error("objectMode was not true but tried to push non-Uint8Array value");return c({done:!1,value:p})},l=p=>i?o:(i=!0,p!=null?h(p):c({done:!0})),d=()=>(n=new Je,l(),{done:!0}),m=p=>(l(p),{done:!0});if(o={[Symbol.asyncIterator](){return this},next:u,return:d,throw:m,push:f,end:l,get readableLength(){return n.size},onEmpty:async p=>{let _=p?.signal;if(_?.throwIfAborted(),n.isEmpty())return;let I,S;_!=null&&(I=new Promise((D,R)=>{S=()=>{R(new Rs)},_.addEventListener("abort",S)}));try{await Promise.race([a.promise,I])}finally{S!=null&&_!=null&&_?.removeEventListener("abort",S)}}},e==null)return o;let y=o;return o={[Symbol.asyncIterator](){return this},next(){return y.next()},throw(p){return y.throw(p),e!=null&&(e(p),e=void 0),{done:!0}},return(){return y.return(),e!=null&&(e(),e=void 0),{done:!0}},push:f,end(p){return y.end(p),e!=null&&(e(p),e=void 0),o},get readableLength(){return y.readableLength},onEmpty:p=>y.onEmpty(p)},o}var Tn=class extends Error{static name="AbortError";name="AbortError";constructor(t="The operation was aborted",...e){super(t,...e)}};async function Dn(r,t,e,n){let o=new Tn(n?.errorMessage);n?.errorCode!=null&&(o.code=n.errorCode);let s=n?.errorEvent??"error";return e?.aborted===!0?Promise.reject(o):new Promise((i,a)=>{function u(){Ns(e,"abort",f),Ns(r,t,c),Ns(r,s,h)}let c=l=>{try{if(n?.filter?.(l)===!1)return}catch(d){u(),a(d);return}u(),i(l)},h=l=>{if(u(),l instanceof Error){a(l);return}a(l.detail??n?.error??new Error(`The "${n?.errorEvent}" event was emitted but the event had no '.detail' field. Pass an 'error' option to race-event to change this message.`))},f=()=>{u(),a(o)};Os(e,"abort",f),Os(r,t,c),Os(r,s,h)})}function Os(r,t,e){r!=null&&(fc(r)?r.addEventListener(t,e):r.addListener(t,e))}function Ns(r,t,e){r!=null&&(fc(r)?r.removeEventListener(t,e):r.removeListener(t,e))}function fc(r){return typeof r.addEventListener=="function"&&typeof r.removeEventListener=="function"}function Nr(r,t){let e,n=function(){let o=function(){e=void 0,r()};clearTimeout(e),e=setTimeout(o,t)};return n.start=()=>{},n.stop=()=>{clearTimeout(e)},n}var Cn=class extends Error{static name="QueueFullError";constructor(t="The queue was full"){super(t),this.name="QueueFullError"}};var Ln=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 Be(r,t,e){if(t==null)return r;if(t.aborted)return r.catch(()=>{}),Promise.reject(new Ln(e?.errorMessage,e?.errorCode,e?.errorName));let n,o=new Ln(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 Pn=class{deferred;signal;constructor(t){this.signal=t,this.deferred=Bt(),this.onAbort=this.onAbort.bind(this),this.signal?.addEventListener("abort",this.onAbort)}onAbort(){this.deferred.reject(this.signal?.reason??new Ct)}cleanup(){this.signal?.removeEventListener("abort",this.onAbort)}};function uh(){return`${parseInt(String(Math.random()*1e9),10).toString()}${Date.now()}`}var Rn=class{id;fn;options;recipients;status;timeline;controller;constructor(t,e){this.id=uh(),this.status="queued",this.fn=t,this.options=e,this.recipients=[],this.timeline={created:Date.now()},this.controller=new AbortController,this.controller.signal,this.onAbort=this.onAbort.bind(this)}abort(t){this.controller.abort(t)}onAbort(){this.recipients.reduce((e,n)=>e&&n.signal?.aborted===!0,!0)&&(this.controller.abort(new Ct),this.cleanup())}async join(t={}){let e=new Pn(t.signal);return this.recipients.push(e),t.signal?.addEventListener("abort",this.onAbort),e.deferred.promise}async run(){this.status="running",this.timeline.started=Date.now();try{this.controller.signal.throwIfAborted();let t=await Be(this.fn({...this.options??{},signal:this.controller.signal}),this.controller.signal);this.recipients.forEach(e=>{e.deferred.resolve(t)}),this.status="complete"}catch(t){this.recipients.forEach(e=>{e.deferred.reject(t)}),this.status="errored"}finally{this.timeline.finished=Date.now(),this.cleanup()}}cleanup(){this.recipients.forEach(t=>{t.cleanup(),t.signal?.removeEventListener("abort",this.onAbort)})}};var On=class extends Kr{concurrency;maxSize;queue;pending;sort;constructor(t={}){super(),this.concurrency=t.concurrency??Number.POSITIVE_INFINITY,this.maxSize=t.maxSize??Number.POSITIVE_INFINITY,this.pending=0,t.metricName!=null&&t.metrics?.registerMetricGroup(t.metricName,{calculate:()=>({size:this.queue.length,running:this.pending,queued:this.queue.length-this.pending})}),this.sort=t.sort,this.queue=[],this.emitEmpty=Nr(this.emitEmpty.bind(this),1),this.emitIdle=Nr(this.emitIdle.bind(this),1)}emitEmpty(){this.size===0&&this.safeDispatchEvent("empty")}emitIdle(){this.running===0&&this.safeDispatchEvent("idle")}tryToStartAnother(){if(this.size===0)return this.emitEmpty(),this.running===0&&this.emitIdle(),!1;if(this.pending<this.concurrency){let t;for(let e of this.queue)if(e.status==="queued"){t=e;break}return t==null?!1:(this.safeDispatchEvent("active"),this.pending++,t.run().finally(()=>{for(let e=0;e<this.queue.length;e++)if(this.queue[e]===t){this.queue.splice(e,1);break}this.pending--,this.tryToStartAnother(),this.safeDispatchEvent("next")}),!0)}return!1}enqueue(t){this.queue.push(t),this.sort!=null&&this.queue.sort(this.sort)}async add(t,e){if(e?.signal?.throwIfAborted(),this.size===this.maxSize)throw new Cn;let n=new Rn(t,e);return this.enqueue(n),this.safeDispatchEvent("add"),this.tryToStartAnother(),n.join(e).then(o=>(this.safeDispatchEvent("completed",{detail:o}),this.safeDispatchEvent("success",{detail:{job:n,result:o}}),o)).catch(o=>{if(n.status==="queued"){for(let s=0;s<this.queue.length;s++)if(this.queue[s]===n){this.queue.splice(s,1);break}}throw this.safeDispatchEvent("failure",{detail:{job:n,error:o}}),o})}clear(){this.queue.splice(0,this.queue.length)}abort(){this.queue.forEach(t=>{t.abort(new Ct)}),this.clear()}async onEmpty(t){this.size!==0&&await Dn(this,"empty",t?.signal)}async onSizeLessThan(t,e){this.size<t||await Dn(this,"next",e?.signal,{filter:()=>this.size<t})}async onIdle(t){this.pending===0&&this.size===0||await Dn(this,"idle",t?.signal)}get size(){return this.queue.length}get queued(){return this.queue.length-this.pending}get running(){return this.pending}async*toGenerator(t){t?.signal?.throwIfAborted();let e=uc({objectMode:!0}),n=u=>{u!=null?this.abort():this.clear(),e.end(u)},o=u=>{u.detail!=null&&e.push(u.detail)},s=u=>{n(u.detail.error)},i=()=>{n()},a=()=>{n(new Ct("Queue aborted"))};this.addEventListener("completed",o),this.addEventListener("failure",s),this.addEventListener("idle",i),t?.signal?.addEventListener("abort",a);try{yield*e}finally{this.removeEventListener("completed",o),this.removeEventListener("failure",s),this.removeEventListener("idle",i),t?.signal?.removeEventListener("abort",a),n()}}};var Nn=class extends On{has(t){return this.find(t)!=null}find(t){return this.queue.find(e=>t.equals(e.options.peerId))}};function kn(r){let t=new globalThis.AbortController;function e(){t.abort();for(let s of r)s?.removeEventListener!=null&&s.removeEventListener("abort",e)}for(let s of r){if(s?.aborted===!0){e();break}s?.addEventListener!=null&&s.addEventListener("abort",e)}function n(){for(let s of r)s?.removeEventListener!=null&&s.removeEventListener("abort",e)}let o=t.signal;return o.clear=n,o}function lc(r,t,e){let n,o,s=!1;function i(){let c={signal:o.signal};if(e?.timeout!=null){let h=kn([o.signal,AbortSignal.timeout(e.timeout)]);c.signal=h}s=!0,Promise.resolve().then(async()=>{await r(c)}).catch(()=>{}).finally(()=>{s=!1,!o.signal.aborted&&(n=setTimeout(i,t))})}let a=Nr(i,e?.debounce??100),u=!1;return{setInterval:c=>{t!==c&&(t=c,n!=null&&(clearTimeout(n),n=setTimeout(i,t)))},setTimeout:c=>{e??={},e.timeout=c},run:()=>{s||(clearTimeout(n),a())},start:()=>{u||(u=!0,o=new AbortController,o.signal,e?.runImmediately===!0?queueMicrotask(()=>{i()}):n=setTimeout(i,t))},stop:()=>{clearTimeout(n),o?.abort(),u=!1}}}var ks=class extends Map{metric;constructor(t){super();let{name:e,metrics:n}=t;this.metric=n.registerMetric(e),this.updateComponentMetric()}set(t,e){return super.set(t,e),this.updateComponentMetric(),this}delete(t){let e=super.delete(t);return this.updateComponentMetric(),e}clear(){super.clear(),this.updateComponentMetric()}updateComponentMetric(){this.metric.update(this.size)}};function hc(r){let{name:t,metrics:e}=r,n;return e!=null?n=new ks({name:t,metrics:e}):n=new Map,n}var Us=class{readNext;haveNext;ended;nextResult;error;constructor(){this.ended=!1,this.readNext=Bt(),this.haveNext=Bt()}[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=Bt(),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=Bt(),await Be(this.readNext.promise,e?.signal,e)}};function dc(){return new Us}var Un=class extends Error{name="UnexpectedEOFError";code="ERR_UNEXPECTED_EOF"};function pc(r,t){let e=dc();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 J;return{read:async i=>{if(i?.signal?.throwIfAborted(),i?.bytes==null){let{done:u,value:c}=await Be(n.next(),i?.signal);return u===!0?null:c}for(;o.byteLength<i.bytes;){let{value:u,done:c}=await Be(n.next(),i?.signal);if(c===!0)throw new Un("unexpected end of input");o.append(u)}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 Mn=class extends Error{name="InvalidMessageLengthError";code="ERR_INVALID_MSG_LENGTH"},Kn=class extends Error{name="InvalidDataLengthError";code="ERR_MSG_DATA_TOO_LONG"},Fn=class extends Error{name="InvalidDataLengthLengthError";code="ERR_MSG_LENGTH_TOO_LONG"};function mc(r,t={}){let e=pc(r,t);t.maxDataLength!=null&&t.maxLengthLength==null&&(t.maxLengthLength=ht(t.maxDataLength));let n=t?.lengthDecoder??_r,o=t?.lengthEncoder??fa;return{read:async i=>{let a=-1,u=new J;for(;;){u.append(await e.read({...i,bytes:1}));try{a=n(u)}catch(c){if(c instanceof RangeError)continue;throw c}if(a<0)throw new Mn("Invalid message length");if(t?.maxLengthLength!=null&&u.byteLength>t.maxLengthLength)throw new Fn("message length length too long");if(a>-1)break}if(t?.maxDataLength!=null&&a>t.maxDataLength)throw new Kn("message length too long");return e.read({...i,bytes:a})},write:async(i,a)=>{await e.write(new J(o(i.byteLength),i),a)},writeV:async(i,a)=>{let u=new J(...i.flatMap(c=>[o(c.byteLength),c]));await e.write(u,a)},unwrap:()=>e.unwrap()}}function Ms(r,t){let e=mc(r,t),n={read:async(o,s)=>{let i=await e.read(s);return o.decode(i)},write:async(o,s,i)=>{await e.write(s.encode(o),i)},writeV:async(o,s,i)=>{await e.writeV(o.map(a=>s.encode(a)),i)},pb:o=>({read:async s=>n.read(o,s),write:async(s,i)=>n.write(s,o,i),writeV:async(s,i)=>n.writeV(s,o,i),unwrap:()=>n}),unwrap:()=>e.unwrap()};return n}var gc="libp2p",yc="autonat",bc="1.0.0";var j;(function(r){let t;(function(c){c.DIAL="DIAL",c.DIAL_RESPONSE="DIAL_RESPONSE"})(t=r.MessageType||(r.MessageType={}));let e;(function(c){c[c.DIAL=0]="DIAL",c[c.DIAL_RESPONSE=1]="DIAL_RESPONSE"})(e||(e={})),function(c){c.codec=()=>He(e)}(t=r.MessageType||(r.MessageType={}));let n;(function(c){c.OK="OK",c.E_DIAL_ERROR="E_DIAL_ERROR",c.E_DIAL_REFUSED="E_DIAL_REFUSED",c.E_BAD_REQUEST="E_BAD_REQUEST",c.E_INTERNAL_ERROR="E_INTERNAL_ERROR"})(n=r.ResponseStatus||(r.ResponseStatus={}));let o;(function(c){c[c.OK=0]="OK",c[c.E_DIAL_ERROR=100]="E_DIAL_ERROR",c[c.E_DIAL_REFUSED=101]="E_DIAL_REFUSED",c[c.E_BAD_REQUEST=200]="E_BAD_REQUEST",c[c.E_INTERNAL_ERROR=300]="E_INTERNAL_ERROR"})(o||(o={})),function(c){c.codec=()=>He(o)}(n=r.ResponseStatus||(r.ResponseStatus={}));let s;(function(c){let h;c.codec=()=>(h==null&&(h=Gt((f,l,d={})=>{if(d.lengthDelimited!==!1&&l.fork(),f.id!=null&&(l.uint32(10),l.bytes(f.id)),f.addrs!=null)for(let m of f.addrs)l.uint32(18),l.bytes(m);d.lengthDelimited!==!1&&l.ldelim()},(f,l,d={})=>{let m={addrs:[]},y=l==null?f.len:f.pos+l;for(;f.pos<y;){let p=f.uint32();switch(p>>>3){case 1:{m.id=f.bytes();break}case 2:{if(d.limits?.addrs!=null&&m.addrs.length===d.limits.addrs)throw new sn('Decode error - map field "addrs" had too many elements');m.addrs.push(f.bytes());break}default:{f.skipType(p&7);break}}}return m})),h),c.encode=f=>jt(f,c.codec()),c.decode=(f,l)=>Vt(f,c.codec(),l)})(s=r.PeerInfo||(r.PeerInfo={}));let i;(function(c){let h;c.codec=()=>(h==null&&(h=Gt((f,l,d={})=>{d.lengthDelimited!==!1&&l.fork(),f.peer!=null&&(l.uint32(10),r.PeerInfo.codec().encode(f.peer,l)),d.lengthDelimited!==!1&&l.ldelim()},(f,l,d={})=>{let m={},y=l==null?f.len:f.pos+l;for(;f.pos<y;){let p=f.uint32();switch(p>>>3){case 1:{m.peer=r.PeerInfo.codec().decode(f,f.uint32(),{limits:d.limits?.peer});break}default:{f.skipType(p&7);break}}}return m})),h),c.encode=f=>jt(f,c.codec()),c.decode=(f,l)=>Vt(f,c.codec(),l)})(i=r.Dial||(r.Dial={}));let a;(function(c){let h;c.codec=()=>(h==null&&(h=Gt((f,l,d={})=>{d.lengthDelimited!==!1&&l.fork(),f.status!=null&&(l.uint32(8),r.ResponseStatus.codec().encode(f.status,l)),f.statusText!=null&&(l.uint32(18),l.string(f.statusText)),f.addr!=null&&(l.uint32(26),l.bytes(f.addr)),d.lengthDelimited!==!1&&l.ldelim()},(f,l,d={})=>{let m={},y=l==null?f.len:f.pos+l;for(;f.pos<y;){let p=f.uint32();switch(p>>>3){case 1:{m.status=r.ResponseStatus.codec().decode(f);break}case 2:{m.statusText=f.string();break}case 3:{m.addr=f.bytes();break}default:{f.skipType(p&7);break}}}return m})),h),c.encode=f=>jt(f,c.codec()),c.decode=(f,l)=>Vt(f,c.codec(),l)})(a=r.DialResponse||(r.DialResponse={}));let u;r.codec=()=>(u==null&&(u=Gt((c,h,f={})=>{f.lengthDelimited!==!1&&h.fork(),c.type!=null&&(h.uint32(8),r.MessageType.codec().encode(c.type,h)),c.dial!=null&&(h.uint32(18),r.Dial.codec().encode(c.dial,h)),c.dialResponse!=null&&(h.uint32(26),r.DialResponse.codec().encode(c.dialResponse,h)),f.lengthDelimited!==!1&&h.ldelim()},(c,h,f={})=>{let l={},d=h==null?c.len:c.pos+h;for(;c.pos<d;){let m=c.uint32();switch(m>>>3){case 1:{l.type=r.MessageType.codec().decode(c);break}case 2:{l.dial=r.Dial.codec().decode(c,c.uint32(),{limits:f.limits?.dial});break}case 3:{l.dialResponse=r.DialResponse.codec().decode(c,c.uint32(),{limits:f.limits?.dialResponse});break}default:{c.skipType(m&7);break}}}return l})),u),r.encode=c=>jt(c,r.codec()),r.decode=(c,h)=>Vt(c,r.codec(),h)})(j||(j={}));var mh=4,gh=8,zn=class{components;protocol;timeout;maxInboundStreams;maxOutboundStreams;maxMessageSize;started;log;topologyId;dialResults;findPeers;addressFilter;connectionThreshold;constructor(t,e){this.components=t,this.log=t.logger.forComponent("libp2p:auto-nat"),this.started=!1,this.protocol=`/${e.protocolPrefix??gc}/${yc}/${bc}`,this.timeout=e.timeout??3e4,this.maxInboundStreams=e.maxInboundStreams??2,this.maxOutboundStreams=e.maxOutboundStreams??20,this.connectionThreshold=e.connectionThreshold??80,this.maxMessageSize=e.maxMessageSize??8192,this.dialResults=hc({name:"libp2p_autonat_dial_results",metrics:t.metrics}),this.findPeers=lc(this.findRandomPeers.bind(this),6e4),this.addressFilter=ps(1024)}[Symbol.toStringTag]="@libp2p/autonat";[qs]=["@libp2p/autonat"];get[Hs](){return["@libp2p/identify"]}isStarted(){return this.started}async start(){this.started||(await this.components.registrar.handle(this.protocol,t=>{this.handleIncomingAutonatStream(t).catch(e=>{this.log.error("error handling incoming autonat stream - %e",e)})},{maxInboundStreams:this.maxInboundStreams,maxOutboundStreams:this.maxOutboundStreams}),this.topologyId=await this.components.registrar.register(this.protocol,{onConnect:(t,e)=>{this.verifyExternalAddresses(e).catch(n=>{this.log.error("could not verify addresses - %e",n)})}}),this.findPeers.start(),this.started=!0)}async stop(){await this.components.registrar.unhandle(this.protocol),this.topologyId!=null&&await this.components.registrar.unhandle(this.topologyId),this.dialResults.clear(),this.findPeers.stop(),this.started=!1}allAddressesAreVerified(){return this.components.addressManager.getAddressesWithMetadata().every(t=>t.expires>Date.now()?!0:t.verified)}async findRandomPeers(t){if(this.allAddressesAreVerified())return;let e=kn([AbortSignal.timeout(1e4),t?.signal]);try{this.log("starting random walk to find peers to run AutoNAT");for await(let n of this.components.randomWalk.walk({signal:e})){if(!await this.components.connectionManager.isDialable(n.multiaddrs)){this.log.trace("random peer %p was not dialable %s",n.id,n.multiaddrs.map(o=>o.toString()).join(", "));continue}try{this.log.trace("dial random peer %p",n.id),await this.components.connectionManager.openConnection(n.multiaddrs,{signal:e})}catch{}if(this.allAddressesAreVerified()){this.log("stopping random walk, all addresses are verified");return}if(!this.hasConnectionCapacity()){this.log("stopping random walk, too close to max connections");return}}}catch{}}async handleIncomingAutonatStream(t){let e=AbortSignal.timeout(this.timeout);let n=Ms(t.stream,{maxDataLength:this.maxMessageSize}).pb(j);try{let o=await n.read({signal:e}),s=await this.handleAutonatMessage(o,t.connection,{signal:e});await n.write(s,{signal:e}),await n.unwrap().unwrap().close({signal:e})}catch(o){this.log.error("error handling incoming autonat stream - %e",o),t.stream.abort(o)}}async handleAutonatMessage(t,e,n){let o=this.components.addressManager.getAddresses().map(f=>f.toOptions().host),s=t.dial;if(s==null)return this.log.error("dial was missing from message"),{type:j.MessageType.DIAL_RESPONSE,dialResponse:{status:j.ResponseStatus.E_BAD_REQUEST,statusText:"No Dial message found in message"}};let i,a=s.peer;if(a?.id==null)return this.log.error("PeerId missing from message"),{type:j.MessageType.DIAL_RESPONSE,dialResponse:{status:j.ResponseStatus.E_BAD_REQUEST,statusText:"missing peer info"}};try{let f=le(a.id);i=pn(f)}catch(f){return this.log.error("invalid PeerId - %e",f),{type:j.MessageType.DIAL_RESPONSE,dialResponse:{status:j.ResponseStatus.E_BAD_REQUEST,statusText:"bad peer id"}}}if(this.log("incoming request from %p",i),!e.remotePeer.equals(i))return this.log("target peer %p did not equal sending peer %p",i,e.remotePeer),{type:j.MessageType.DIAL_RESPONSE,dialResponse:{status:j.ResponseStatus.E_BAD_REQUEST,statusText:"peer id mismatch"}};let u=a.addrs.map(f=>Rr(f)).filter(f=>{try{let l=f.toOptions();return Ps(f)?!1:l.host!==e.remoteAddr.toOptions().host?(this.log.trace("not dialing %a - target host did not match remote host %a",f,e.remoteAddr),!1):o.includes(l.host)?!1:this.components.transportManager.dialTransportForMultiaddr(f)==null?(this.log.trace("not dialing %a - transport unsupported",f),!1):!0}catch{return!1}}).map(f=>(f.getPeerId()==null&&(f=f.encapsulate(`/p2p/${i.toString()}`)),f));if(u.length===0)return this.log("refused to dial all multiaddrs for %p from message",i),{type:j.MessageType.DIAL_RESPONSE,dialResponse:{status:j.ResponseStatus.E_DIAL_REFUSED,statusText:"no dialable addresses"}};this.log("dial multiaddrs %s for peer %p",u.map(f=>f.toString()).join(", "),i);let c="",h=u[0];for(let f of u){let l;h=f;try{if(l=await this.components.connectionManager.openConnection(f,n),!l.remoteAddr.equals(f))throw this.log.error("tried to dial %a but dialed %a",f,l.remoteAddr),new Error("Unexpected remote address");return this.log("successfully dialed %p via %a",i,f),{type:j.MessageType.DIAL_RESPONSE,dialResponse:{status:j.ResponseStatus.OK,addr:l.remoteAddr.decapsulateCode(nc("p2p").code).bytes}}}catch(d){this.log.error("could not dial %p - %e",i,d),c=d.message}finally{l!=null&&await l.close()}}return{type:j.MessageType.DIAL_RESPONSE,dialResponse:{status:j.ResponseStatus.E_DIAL_ERROR,statusText:c,addr:h.bytes}}}getFirstUnverifiedMultiaddr(t,e){let n=this.components.addressManager.getAddressesWithMetadata().sort((o,s)=>o.type==="observed"&&s.type!=="observed"?1:s.type==="observed"&&o.type!=="observed"?-1:0).filter(o=>!(!(o.expires<Date.now())||o.multiaddr.toOptions().family===6&&(!e||!oc(o.multiaddr))||Ps(o.multiaddr)));for(let o of n){let s=o.multiaddr.toString(),i=this.dialResults.get(s);if(i!=null){if(i.networkSegments.includes(t)){this.log.trace("%a already has a network segment result from %s",i.multiaddr,t);continue}if(i.queue.size>10){this.log.trace("%a already has enough peers queued",i.multiaddr);continue}}if(i==null){let a=o.expires<Date.now();if(a&&this.addressFilter.remove?.(s),this.addressFilter.has(s))continue;this.addressFilter.add(s),this.log.trace("creating dial result %s %s",a?"to revalidate":"for",s),i={multiaddr:o.multiaddr,success:0,failure:0,networkSegments:[],verifyingPeers:fs(),queue:new Nn({concurrency:3,maxSize:50}),type:o.type,lastVerified:o.lastVerified},this.dialResults.set(s,i)}return i}}removeOutdatedMultiaddrResults(){let t=new Set(this.components.addressManager.getAddressesWithMetadata().filter(({expires:e})=>e<Date.now()).map(({multiaddr:e})=>e.toString()));for(let e of this.dialResults.keys())t.has(e)||(this.log.trace("remove results for %a",e),this.dialResults.delete(e))}async verifyExternalAddresses(t){if(!this.isStarted())return;this.removeOutdatedMultiaddrResults();let n=(await this.components.peerStore.get(t.remotePeer)).addresses.some(({multiaddr:i})=>i.toOptions().family===6),o=this.getNetworkSegment(t.remoteAddr),s=this.getFirstUnverifiedMultiaddr(o,n);if(s==null){this.log.trace("no unverified public addresses found for peer %p to verify, not requesting verification",t.remotePeer);return}if(!this.hasConnectionCapacity()){s.lastVerified!=null?(this.log("automatically re-verifying %a because we are too close to the connection limit",s.multiaddr),this.confirmAddress(s)):this.log("skipping verifying %a because we are too close to the connection limit",s.multiaddr);return}s.queue.add(async i=>{await this.askPeerToVerify(t,o,i)},{peerId:t.remotePeer,multiaddr:s.multiaddr}).catch(i=>{s?.result==null&&this.log.error("error from %p verifying address %a - %e",t.remotePeer,s?.multiaddr,i)})}async askPeerToVerify(t,e,n){let o=this.dialResults.get(n.multiaddr.toString());if(o==null){this.log("%a was verified while %p was queued",n.multiaddr,t.remotePeer);return}let s=AbortSignal.timeout(this.timeout);this.log.trace("asking %p to verify multiaddr %s",t.remotePeer,n.multiaddr);let i=await t.newStream(this.protocol,{signal:s});try{let a=Ms(i).pb(j),[,u]=await Promise.all([a.write({type:j.MessageType.DIAL,dial:{peer:{id:this.components.peerId.toMultihash().bytes,addrs:[n.multiaddr.bytes]}}},{signal:s}),a.read({signal:s})]);if(u.type!==j.MessageType.DIAL_RESPONSE||u.dialResponse==null){this.log("invalid autonat response from %p - %j",t.remotePeer,u);return}let c=u.dialResponse.status;if(this.log.trace("autonat response from %p for %a is %s",t.remotePeer,n.multiaddr,c),c!==j.ResponseStatus.OK&&c!==j.ResponseStatus.E_DIAL_ERROR)return;if(o=this.dialResults.get(n.multiaddr.toString()),o==null){this.log.trace("peer reported %a as %s but there is no result object",n.multiaddr,u.dialResponse.status);return}if(o.networkSegments.includes(e)){this.log.trace("%a results included network segment %s",n.multiaddr,e);return}if(o.result!=null){this.log.trace("already resolved result for %a, ignoring response from",n.multiaddr,t.remotePeer);return}if(o.verifyingPeers.has(t.remotePeer)){this.log.trace("peer %p has already verified %a, ignoring response",t.remotePeer,n.multiaddr);return}if(o.verifyingPeers.add(t.remotePeer),o.networkSegments.push(e),c===j.ResponseStatus.OK){if(o.success++,o.type!=="observed"){this.confirmAddress(o);return}}else c===j.ResponseStatus.E_DIAL_ERROR&&o.failure++;this.log("%a success %d failure %d",o.multiaddr,o.success,o.failure),o.success===mh&&this.confirmAddress(o),o.failure===gh&&this.unconfirmAddress(o)}finally{try{await i.close({signal:s})}catch(a){i.abort(a)}}}hasConnectionCapacity(){let e=this.components.connectionManager.getConnections().length,n=this.components.connectionManager.getMaxConnections();return e/n*100<this.connectionThreshold}confirmAddress(t){this.log("%s address %a is externally dialable",t.type,t.multiaddr),this.components.addressManager.confirmObservedAddr(t.multiaddr),this.dialResults.delete(t.multiaddr.toString()),t.result=!0,t.queue.abort()}unconfirmAddress(t){this.log("%s address %a is not externally dialable",t.type,t.multiaddr),this.components.addressManager.removeObservedAddr(t.multiaddr),this.dialResults.delete(t.multiaddr.toString()),t.result=!1,t.queue.abort()}getNetworkSegment(t){let e=t.toOptions();return e.family===4?e.host.split(".")[0].padStart(3,"0"):e.host.split(":")[0].padStart(4,"0")}};function yh(r={}){return t=>new zn(t,r)}return Ic(bh);})();
3
3
  /*! Bundled license information:
4
4
 
5
5
  @noble/hashes/esm/utils.js: