@libp2p/autonat 2.0.37-cb1c14e62 → 2.0.37-cf9aab5c8
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 +1 -1
- package/dist/index.min.js.map +3 -3
- package/package.json +8 -8
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 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);})();
|
|
2
|
+
"use strict";var Libp2PAutonat=(()=>{var Sc=Object.create;var Nr=Object.defineProperty;var vc=Object.getOwnPropertyDescriptor;var Ac=Object.getOwnPropertyNames;var Ic=Object.getPrototypeOf,Bc=Object.prototype.hasOwnProperty;var Tc=(e,t)=>()=>(t||e((t={exports:{}}).exports,t),t.exports),bt=(e,t)=>{for(var r in t)Nr(e,r,{get:t[r],enumerable:!0})},$s=(e,t,r,n)=>{if(t&&typeof t=="object"||typeof t=="function")for(let o of Ac(t))!Bc.call(e,o)&&o!==r&&Nr(e,o,{get:()=>t[o],enumerable:!(n=vc(t,o))||n.enumerable});return e};var Cc=(e,t,r)=>(r=e!=null?Sc(Ic(e)):{},$s(t||!e||!e.__esModule?Nr(r,"default",{value:e,enumerable:!0}):r,e)),Dc=e=>$s(Nr({},"__esModule",{value:!0}),e);var uc=Tc(Pr=>{(function(){var e,t,r,n,o,s,i,c;c=function(a){var u,h,f,l;return u=(a&255<<24)>>>24,h=(a&255<<16)>>>16,f=(a&65280)>>>8,l=a&255,[u,h,f,l].join(".")},i=function(a){var u,h,f,l,p,d;for(u=[],f=l=0;l<=3&&a.length!==0;f=++l){if(f>0){if(a[0]!==".")throw new Error("Invalid IP");a=a.substring(1)}d=t(a),p=d[0],h=d[1],a=a.substring(h),u.push(p)}if(a.length!==0)throw new Error("Invalid IP");switch(u.length){case 1:if(u[0]>4294967295)throw new Error("Invalid IP");return u[0]>>>0;case 2:if(u[0]>255||u[1]>16777215)throw new Error("Invalid IP");return(u[0]<<24|u[1])>>>0;case 3:if(u[0]>255||u[1]>255||u[2]>65535)throw new Error("Invalid IP");return(u[0]<<24|u[1]<<16|u[2])>>>0;case 4:if(u[0]>255||u[1]>255||u[2]>255||u[3]>255)throw new Error("Invalid IP");return(u[0]<<24|u[1]<<16|u[2]<<8|u[3])>>>0;default:throw new Error("Invalid IP")}},r=function(a){return a.charCodeAt(0)},n=r("0"),s=r("a"),o=r("A"),t=function(a){var u,h,f,l,p;for(l=0,u=10,h="9",f=0,a.length>1&&a[f]==="0"&&(a[f+1]==="x"||a[f+1]==="X"?(f+=2,u=16):"0"<=a[f+1]&&a[f+1]<="9"&&(f++,u=8,h="7")),p=f;f<a.length;){if("0"<=a[f]&&a[f]<=h)l=l*u+(r(a[f])-n)>>>0;else if(u===16)if("a"<=a[f]&&a[f]<="f")l=l*u+(10+r(a[f])-s)>>>0;else if("A"<=a[f]&&a[f]<="F")l=l*u+(10+r(a[f])-o)>>>0;else break;else break;if(l>4294967295)throw new Error("too large");f++}if(f===p)throw new Error("empty octet");return[l,f]},e=function(){function a(u,h){var f,l,p,d;if(typeof u!="string")throw new Error("Missing `net' parameter");if(h||(d=u.split("/",2),u=d[0],h=d[1]),h||(h=32),typeof h=="string"&&h.indexOf(".")>-1){try{this.maskLong=i(h)}catch(x){throw f=x,new Error("Invalid mask: "+h)}for(l=p=32;p>=0;l=--p)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(u)&this.maskLong)>>>0}catch(x){throw f=x,new Error("Invalid net address: "+u)}if(!(this.bitmask<=32))throw new Error("Invalid mask for ip4: "+h);this.size=Math.pow(2,32-this.bitmask),this.base=c(this.netLong),this.mask=c(this.maskLong),this.hostmask=c(~this.maskLong),this.first=this.bitmask<=30?c(this.netLong+1):this.base,this.last=this.bitmask<=30?c(this.netLong+this.size-2):c(this.netLong+this.size-1),this.broadcast=this.bitmask<=30?c(this.netLong+this.size-1):void 0}return a.prototype.contains=function(u){return typeof u=="string"&&(u.indexOf("/")>0||u.split(".").length!==4)&&(u=new a(u)),u instanceof a?this.contains(u.base)&&this.contains(u.broadcast||u.last):(i(u)&this.maskLong)>>>0===(this.netLong&this.maskLong)>>>0},a.prototype.next=function(u){return u==null&&(u=1),new a(c(this.netLong+this.size*u),this.mask)},a.prototype.forEach=function(u){var h,f,l;for(l=i(this.first),f=i(this.last),h=0;l<=f;)u(c(l),l,h),h++,l++},a.prototype.toString=function(){return this.base+"/"+this.bitmask},a}(),Pr.ip2long=i,Pr.long2ip=c,Pr.Netmask=e}).call(Pr)});var _h={};bt(_h,{autoNAT:()=>Eh});var qn=Symbol.for("@libp2p/peer-id");var Lt=class extends Error{static name="AbortError";constructor(t="The operation was aborted"){super(t),this.name="AbortError"}};var Pt=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 kr=class extends Error{static name="InvalidMultihashError";constructor(t="Invalid Multihash"){super(t),this.name="InvalidMultihashError"}};var tr=class extends Error{static name="UnsupportedKeyTypeError";constructor(t="Unsupported key type"){super(t),this.name="UnsupportedKeyTypeError"}};var Mr=class extends EventTarget{#t=new Map;constructor(){super()}listenerCount(t){let r=this.#t.get(t);return r==null?0:r.length}addEventListener(t,r,n){super.addEventListener(t,r,n);let o=this.#t.get(t);o==null&&(o=[],this.#t.set(t,o)),o.push({callback:r,once:(n!==!0&&n!==!1&&n?.once)??!1})}removeEventListener(t,r,n){super.removeEventListener(t.toString(),r??null,n);let o=this.#t.get(t);o!=null&&(o=o.filter(({callback:s})=>s!==r),this.#t.set(t,o))}dispatchEvent(t){let r=super.dispatchEvent(t),n=this.#t.get(t.type);return n==null||(n=n.filter(({once:o})=>!o),this.#t.set(t.type,n)),r}safeDispatchEvent(t,r={}){return this.dispatchEvent(new CustomEvent(t,r))}};var Gs=Symbol.for("@libp2p/service-capabilities"),Zs=Symbol.for("@libp2p/service-dependencies");var Gn={};bt(Gn,{base58btc:()=>G,base58flickr:()=>kc});var Zh=new Uint8Array(0);function Xs(e,t){if(e===t)return!0;if(e.byteLength!==t.byteLength)return!1;for(let r=0;r<e.byteLength;r++)if(e[r]!==t[r])return!1;return!0}function Rt(e){if(e instanceof Uint8Array&&e.constructor.name==="Uint8Array")return e;if(e instanceof ArrayBuffer)return new Uint8Array(e);if(ArrayBuffer.isView(e))return new Uint8Array(e.buffer,e.byteOffset,e.byteLength);throw new Error("Unknown type, must be binary type")}function Ws(e){return new TextEncoder().encode(e)}function Ys(e){return new TextDecoder().decode(e)}function Lc(e,t){if(e.length>=255)throw new TypeError("Alphabet too long");for(var r=new Uint8Array(256),n=0;n<r.length;n++)r[n]=255;for(var o=0;o<e.length;o++){var s=e.charAt(o),i=s.charCodeAt(0);if(r[i]!==255)throw new TypeError(s+" is ambiguous");r[i]=o}var c=e.length,a=e.charAt(0),u=Math.log(c)/Math.log(256),h=Math.log(256)/Math.log(c);function f(d){if(d instanceof Uint8Array||(ArrayBuffer.isView(d)?d=new Uint8Array(d.buffer,d.byteOffset,d.byteLength):Array.isArray(d)&&(d=Uint8Array.from(d))),!(d instanceof Uint8Array))throw new TypeError("Expected Uint8Array");if(d.length===0)return"";for(var x=0,E=0,y=0,v=d.length;y!==v&&d[y]===0;)y++,x++;for(var w=(v-y)*h+1>>>0,T=new Uint8Array(w);y!==v;){for(var P=d[y],M=0,k=w-1;(P!==0||M<E)&&k!==-1;k--,M++)P+=256*T[k]>>>0,T[k]=P%c>>>0,P=P/c>>>0;if(P!==0)throw new Error("Non-zero carry");E=M,y++}for(var O=w-E;O!==w&&T[O]===0;)O++;for(var _=a.repeat(x);O<w;++O)_+=e.charAt(T[O]);return _}function l(d){if(typeof d!="string")throw new TypeError("Expected String");if(d.length===0)return new Uint8Array;var x=0;if(d[x]!==" "){for(var E=0,y=0;d[x]===a;)E++,x++;for(var v=(d.length-x)*u+1>>>0,w=new Uint8Array(v);d[x];){var T=r[d.charCodeAt(x)];if(T===255)return;for(var P=0,M=v-1;(T!==0||P<y)&&M!==-1;M--,P++)T+=c*w[M]>>>0,w[M]=T%256>>>0,T=T/256>>>0;if(T!==0)throw new Error("Non-zero carry");y=P,x++}if(d[x]!==" "){for(var k=v-y;k!==v&&w[k]===0;)k++;for(var O=new Uint8Array(E+(v-k)),_=E;k!==v;)O[_++]=w[k++];return O}}}function p(d){var x=l(d);if(x)return x;throw new Error(`Non-${t} character`)}return{encode:f,decodeUnsafe:l,decode:p}}var Pc=Lc,Rc=Pc,Js=Rc;var Vn=class{name;prefix;baseEncode;constructor(t,r,n){this.name=t,this.prefix=r,this.baseEncode=n}encode(t){if(t instanceof Uint8Array)return`${this.prefix}${this.baseEncode(t)}`;throw Error("Unknown type, must be binary type")}},Hn=class{name;prefix;baseDecode;prefixCodePoint;constructor(t,r,n){this.name=t,this.prefix=r;let o=r.codePointAt(0);if(o===void 0)throw new Error("Invalid prefix character");this.prefixCodePoint=o,this.baseDecode=n}decode(t){if(typeof t=="string"){if(t.codePointAt(0)!==this.prefixCodePoint)throw Error(`Unable to decode multibase string ${JSON.stringify(t)}, ${this.name} decoder only supports inputs prefixed with ${this.prefix}`);return this.baseDecode(t.slice(this.prefix.length))}else throw Error("Can only multibase decode strings")}or(t){return ti(this,t)}},jn=class{decoders;constructor(t){this.decoders=t}or(t){return ti(this,t)}decode(t){let r=t[0],n=this.decoders[r];if(n!=null)return n.decode(t);throw RangeError(`Unable to decode multibase string ${JSON.stringify(t)}, only inputs prefixed with ${Object.keys(this.decoders)} are supported`)}};function ti(e,t){return new jn({...e.decoders??{[e.prefix]:e},...t.decoders??{[t.prefix]:t}})}var $n=class{name;prefix;baseEncode;baseDecode;encoder;decoder;constructor(t,r,n,o){this.name=t,this.prefix=r,this.baseEncode=n,this.baseDecode=o,this.encoder=new Vn(t,r,n),this.decoder=new Hn(t,r,o)}encode(t){return this.encoder.encode(t)}decode(t){return this.decoder.decode(t)}};function Ie({name:e,prefix:t,encode:r,decode:n}){return new $n(e,t,r,n)}function Jt({name:e,prefix:t,alphabet:r}){let{encode:n,decode:o}=Js(r,e);return Ie({prefix:t,name:e,encode:n,decode:s=>Rt(o(s))})}function Oc(e,t,r,n){let o=e.length;for(;e[o-1]==="=";)--o;let s=new Uint8Array(o*r/8|0),i=0,c=0,a=0;for(let u=0;u<o;++u){let h=t[e[u]];if(h===void 0)throw new SyntaxError(`Non-${n} character`);c=c<<r|h,i+=r,i>=8&&(i-=8,s[a++]=255&c>>i)}if(i>=r||(255&c<<8-i)!==0)throw new SyntaxError("Unexpected end of data");return s}function Nc(e,t,r){let n=t[t.length-1]==="=",o=(1<<r)-1,s="",i=0,c=0;for(let a=0;a<e.length;++a)for(c=c<<8|e[a],i+=8;i>r;)i-=r,s+=t[o&c>>i];if(i!==0&&(s+=t[o&c<<r-i]),n)for(;(s.length*r&7)!==0;)s+="=";return s}function Uc(e){let t={};for(let r=0;r<e.length;++r)t[e[r]]=r;return t}function Y({name:e,prefix:t,bitsPerChar:r,alphabet:n}){let o=Uc(n);return Ie({prefix:t,name:e,encode(s){return Nc(s,n,r)},decode(s){return Oc(s,o,r,e)}})}var G=Jt({name:"base58btc",prefix:"z",alphabet:"123456789ABCDEFGHJKLMNPQRSTUVWXYZabcdefghijkmnopqrstuvwxyz"}),kc=Jt({name:"base58flickr",prefix:"Z",alphabet:"123456789abcdefghijkmnopqrstuvwxyzABCDEFGHJKLMNPQRSTUVWXYZ"});var Zn={};bt(Zn,{base32:()=>te,base32hex:()=>zc,base32hexpad:()=>Vc,base32hexpadupper:()=>Hc,base32hexupper:()=>qc,base32pad:()=>Kc,base32padupper:()=>Fc,base32upper:()=>Mc,base32z:()=>jc});var te=Y({prefix:"b",name:"base32",alphabet:"abcdefghijklmnopqrstuvwxyz234567",bitsPerChar:5}),Mc=Y({prefix:"B",name:"base32upper",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZ234567",bitsPerChar:5}),Kc=Y({prefix:"c",name:"base32pad",alphabet:"abcdefghijklmnopqrstuvwxyz234567=",bitsPerChar:5}),Fc=Y({prefix:"C",name:"base32padupper",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZ234567=",bitsPerChar:5}),zc=Y({prefix:"v",name:"base32hex",alphabet:"0123456789abcdefghijklmnopqrstuv",bitsPerChar:5}),qc=Y({prefix:"V",name:"base32hexupper",alphabet:"0123456789ABCDEFGHIJKLMNOPQRSTUV",bitsPerChar:5}),Vc=Y({prefix:"t",name:"base32hexpad",alphabet:"0123456789abcdefghijklmnopqrstuv=",bitsPerChar:5}),Hc=Y({prefix:"T",name:"base32hexpadupper",alphabet:"0123456789ABCDEFGHIJKLMNOPQRSTUV=",bitsPerChar:5}),jc=Y({prefix:"h",name:"base32z",alphabet:"ybndrfg8ejkmcpqxot1uwisza345h769",bitsPerChar:5});var Xn={};bt(Xn,{base36:()=>er,base36upper:()=>$c});var er=Jt({prefix:"k",name:"base36",alphabet:"0123456789abcdefghijklmnopqrstuvwxyz"}),$c=Jt({prefix:"K",name:"base36upper",alphabet:"0123456789ABCDEFGHIJKLMNOPQRSTUVWXYZ"});var Gc=ni,ei=128,Zc=127,Xc=~Zc,Wc=Math.pow(2,31);function ni(e,t,r){t=t||[],r=r||0;for(var n=r;e>=Wc;)t[r++]=e&255|ei,e/=128;for(;e&Xc;)t[r++]=e&255|ei,e>>>=7;return t[r]=e|0,ni.bytes=r-n+1,t}var Yc=Wn,Qc=128,ri=127;function Wn(e,n){var r=0,n=n||0,o=0,s=n,i,c=e.length;do{if(s>=c)throw Wn.bytes=0,new RangeError("Could not decode varint");i=e[s++],r+=o<28?(i&ri)<<o:(i&ri)*Math.pow(2,o),o+=7}while(i>=Qc);return Wn.bytes=s-n,r}var Jc=Math.pow(2,7),tu=Math.pow(2,14),eu=Math.pow(2,21),ru=Math.pow(2,28),nu=Math.pow(2,35),ou=Math.pow(2,42),su=Math.pow(2,49),iu=Math.pow(2,56),au=Math.pow(2,63),cu=function(e){return e<Jc?1:e<tu?2:e<eu?3:e<ru?4:e<nu?5:e<ou?6:e<su?7:e<iu?8:e<au?9:10},uu={encode:Gc,decode:Yc,encodingLength:cu},fu=uu,rr=fu;function nr(e,t=0){return[rr.decode(e,t),rr.decode.bytes]}function Be(e,t,r=0){return rr.encode(e,t,r),t}function Te(e){return rr.encodingLength(e)}function fe(e,t){let r=t.byteLength,n=Te(e),o=n+Te(r),s=new Uint8Array(o+r);return Be(e,s,0),Be(r,s,n),s.set(t,o),new Ce(e,r,t,s)}function le(e){let t=Rt(e),[r,n]=nr(t),[o,s]=nr(t.subarray(n)),i=t.subarray(n+s);if(i.byteLength!==o)throw new Error("Incorrect length");return new Ce(r,o,i,t)}function oi(e,t){if(e===t)return!0;{let r=t;return e.code===r.code&&e.size===r.size&&r.bytes instanceof Uint8Array&&Xs(e.bytes,r.bytes)}}var Ce=class{code;size;digest;bytes;constructor(t,r,n,o){this.code=t,this.size=r,this.digest=n,this.bytes=o}};function si(e,t){let{bytes:r,version:n}=e;switch(n){case 0:return hu(r,Yn(e),t??G.encoder);default:return du(r,Yn(e),t??te.encoder)}}var ii=new WeakMap;function Yn(e){let t=ii.get(e);if(t==null){let r=new Map;return ii.set(e,r),r}return t}var et=class e{code;version;multihash;bytes;"/";constructor(t,r,n,o){this.code=r,this.version=t,this.multihash=n,this.bytes=o,this["/"]=o}get asCID(){return this}get byteOffset(){return this.bytes.byteOffset}get byteLength(){return this.bytes.byteLength}toV0(){switch(this.version){case 0:return this;case 1:{let{code:t,multihash:r}=this;if(t!==or)throw new Error("Cannot convert a non dag-pb CID to CIDv0");if(r.code!==pu)throw new Error("Cannot convert non sha2-256 multihash CID to CIDv0");return e.createV0(r)}default:throw Error(`Can not convert CID version ${this.version} to version 0. This is a bug please report`)}}toV1(){switch(this.version){case 0:{let{code:t,digest:r}=this.multihash,n=fe(t,r);return e.createV1(this.code,n)}case 1:return this;default:throw Error(`Can not convert CID version ${this.version} to version 1. This is a bug please report`)}}equals(t){return e.equals(this,t)}static equals(t,r){let n=r;return n!=null&&t.code===n.code&&t.version===n.version&&oi(t.multihash,n.multihash)}toString(t){return si(this,t)}toJSON(){return{"/":si(this)}}link(){return this}[Symbol.toStringTag]="CID";[Symbol.for("nodejs.util.inspect.custom")](){return`CID(${this.toString()})`}static asCID(t){if(t==null)return null;let r=t;if(r instanceof e)return r;if(r["/"]!=null&&r["/"]===r.bytes||r.asCID===r){let{version:n,code:o,multihash:s,bytes:i}=r;return new e(n,o,s,i??ai(n,o,s.bytes))}else if(r[mu]===!0){let{version:n,multihash:o,code:s}=r,i=le(o);return e.create(n,s,i)}else return null}static create(t,r,n){if(typeof r!="number")throw new Error("String codecs are no longer supported");if(!(n.bytes instanceof Uint8Array))throw new Error("Invalid digest");switch(t){case 0:{if(r!==or)throw new Error(`Version 0 CID must use dag-pb (code: ${or}) block encoding`);return new e(t,r,n,n.bytes)}case 1:{let o=ai(t,r,n.bytes);return new e(t,r,n,o)}default:throw new Error("Invalid version")}}static createV0(t){return e.create(0,or,t)}static createV1(t,r){return e.create(1,t,r)}static decode(t){let[r,n]=e.decodeFirst(t);if(n.length!==0)throw new Error("Incorrect length");return r}static decodeFirst(t){let r=e.inspectBytes(t),n=r.size-r.multihashSize,o=Rt(t.subarray(n,n+r.multihashSize));if(o.byteLength!==r.multihashSize)throw new Error("Incorrect length");let s=o.subarray(r.multihashSize-r.digestSize),i=new Ce(r.multihashCode,r.digestSize,s,o);return[r.version===0?e.createV0(i):e.createV1(r.codec,i),t.subarray(r.size)]}static inspectBytes(t){let r=0,n=()=>{let[f,l]=nr(t.subarray(r));return r+=l,f},o=n(),s=or;if(o===18?(o=0,r=0):s=n(),o!==0&&o!==1)throw new RangeError(`Invalid CID version ${o}`);let i=r,c=n(),a=n(),u=r+a,h=u-i;return{version:o,codec:s,multihashCode:c,digestSize:a,multihashSize:h,size:u}}static parse(t,r){let[n,o]=lu(t,r),s=e.decode(o);if(s.version===0&&t[0]!=="Q")throw Error("Version 0 CID string must not include multibase prefix");return Yn(s).set(n,t),s}};function lu(e,t){switch(e[0]){case"Q":{let r=t??G;return[G.prefix,r.decode(`${G.prefix}${e}`)]}case G.prefix:{let r=t??G;return[G.prefix,r.decode(e)]}case te.prefix:{let r=t??te;return[te.prefix,r.decode(e)]}case er.prefix:{let r=t??er;return[er.prefix,r.decode(e)]}default:{if(t==null)throw Error("To parse non base32, base36 or base58btc encoded CID multibase decoder must be provided");return[e[0],t.decode(e)]}}}function hu(e,t,r){let{prefix:n}=r;if(n!==G.prefix)throw Error(`Cannot string encode V0 in ${r.name} encoding`);let o=t.get(n);if(o==null){let s=r.encode(e).slice(1);return t.set(n,s),s}else return o}function du(e,t,r){let{prefix:n}=r,o=t.get(n);if(o==null){let s=r.encode(e);return t.set(n,s),s}else return o}var or=112,pu=18;function ai(e,t,r){let n=Te(e),o=n+Te(t),s=new Uint8Array(o+r.byteLength);return Be(e,s,0),Be(t,s,n),s.set(r,o),s}var mu=Symbol.for("@ipld/js-cid/CID");var Qn={};bt(Qn,{identity:()=>vt});var ci=0,gu="identity",ui=Rt;function yu(e){return fe(ci,ui(e))}var vt={code:ci,name:gu,encode:ui,digest:yu};function ft(e,t){if(e===t)return!0;if(e.byteLength!==t.byteLength)return!1;for(let r=0;r<e.byteLength;r++)if(e[r]!==t[r])return!1;return!0}function At(e=0){return new Uint8Array(e)}function pt(e=0){return new Uint8Array(e)}function Ot(e,t){t==null&&(t=e.reduce((o,s)=>o+s.length,0));let r=pt(t),n=0;for(let o of e)r.set(o,n),n+=o.length;return r}var li=Symbol.for("@achingbrain/uint8arraylist");function fi(e,t){if(t==null||t<0)throw new RangeError("index is out of bounds");let r=0;for(let n of e){let o=r+n.byteLength;if(t<o)return{buf:n,index:t-r};r=o}throw new RangeError("index is out of bounds")}function Fr(e){return!!e?.[li]}var tt=class e{bufs;length;[li]=!0;constructor(...t){this.bufs=[],this.length=0,t.length>0&&this.appendAll(t)}*[Symbol.iterator](){yield*this.bufs}get byteLength(){return this.length}append(...t){this.appendAll(t)}appendAll(t){let r=0;for(let n of t)if(n instanceof Uint8Array)r+=n.byteLength,this.bufs.push(n);else if(Fr(n))r+=n.byteLength,this.bufs.push(...n.bufs);else throw new Error("Could not append value, must be an Uint8Array or a Uint8ArrayList");this.length+=r}prepend(...t){this.prependAll(t)}prependAll(t){let r=0;for(let n of t.reverse())if(n instanceof Uint8Array)r+=n.byteLength,this.bufs.unshift(n);else if(Fr(n))r+=n.byteLength,this.bufs.unshift(...n.bufs);else throw new Error("Could not prepend value, must be an Uint8Array or a Uint8ArrayList");this.length+=r}get(t){let r=fi(this.bufs,t);return r.buf[r.index]}set(t,r){let n=fi(this.bufs,t);n.buf[n.index]=r}write(t,r=0){if(t instanceof Uint8Array)for(let n=0;n<t.length;n++)this.set(r+n,t[n]);else if(Fr(t))for(let n=0;n<t.length;n++)this.set(r+n,t.get(n));else throw new Error("Could not write value, must be an Uint8Array or a Uint8ArrayList")}consume(t){if(t=Math.trunc(t),!(Number.isNaN(t)||t<=0)){if(t===this.byteLength){this.bufs=[],this.length=0;return}for(;this.bufs.length>0;)if(t>=this.bufs[0].byteLength)t-=this.bufs[0].byteLength,this.length-=this.bufs[0].byteLength,this.bufs.shift();else{this.bufs[0]=this.bufs[0].subarray(t),this.length-=t;break}}}slice(t,r){let{bufs:n,length:o}=this._subList(t,r);return Ot(n,o)}subarray(t,r){let{bufs:n,length:o}=this._subList(t,r);return n.length===1?n[0]:Ot(n,o)}sublist(t,r){let{bufs:n,length:o}=this._subList(t,r),s=new e;return s.length=o,s.bufs=[...n],s}_subList(t,r){if(t=t??0,r=r??this.length,t<0&&(t=this.length+t),r<0&&(r=this.length+r),t<0||r>this.length)throw new RangeError("index is out of bounds");if(t===r)return{bufs:[],length:0};if(t===0&&r===this.length)return{bufs:this.bufs,length:this.length};let n=[],o=0;for(let s=0;s<this.bufs.length;s++){let i=this.bufs[s],c=o,a=c+i.byteLength;if(o=a,t>=a)continue;let u=t>=c&&t<a,h=r>c&&r<=a;if(u&&h){if(t===c&&r===a){n.push(i);break}let f=t-c;n.push(i.subarray(f,f+(r-t)));break}if(u){if(t===0){n.push(i);continue}n.push(i.subarray(t-c));continue}if(h){if(r===a){n.push(i);break}n.push(i.subarray(0,r-c));break}n.push(i)}return{bufs:n,length:r-t}}indexOf(t,r=0){if(!Fr(t)&&!(t instanceof Uint8Array))throw new TypeError('The "value" argument must be a Uint8ArrayList or Uint8Array');let n=t instanceof Uint8Array?t:t.subarray();if(r=Number(r??0),isNaN(r)&&(r=0),r<0&&(r=this.length+r),r<0&&(r=0),t.length===0)return r>this.length?this.length:r;let o=n.byteLength;if(o===0)throw new TypeError("search must be at least 1 byte long");let s=256,i=new Int32Array(s);for(let f=0;f<s;f++)i[f]=-1;for(let f=0;f<o;f++)i[n[f]]=f;let c=i,a=this.byteLength-n.byteLength,u=n.byteLength-1,h;for(let f=r;f<=a;f+=h){h=0;for(let l=u;l>=0;l--){let p=this.get(f+l);if(n[l]!==p){h=Math.max(1,l-c[p]);break}}if(h===0)return f}return-1}getInt8(t){let r=this.subarray(t,t+1);return new DataView(r.buffer,r.byteOffset,r.byteLength).getInt8(0)}setInt8(t,r){let n=pt(1);new DataView(n.buffer,n.byteOffset,n.byteLength).setInt8(0,r),this.write(n,t)}getInt16(t,r){let n=this.subarray(t,t+2);return new DataView(n.buffer,n.byteOffset,n.byteLength).getInt16(0,r)}setInt16(t,r,n){let o=At(2);new DataView(o.buffer,o.byteOffset,o.byteLength).setInt16(0,r,n),this.write(o,t)}getInt32(t,r){let n=this.subarray(t,t+4);return new DataView(n.buffer,n.byteOffset,n.byteLength).getInt32(0,r)}setInt32(t,r,n){let o=At(4);new DataView(o.buffer,o.byteOffset,o.byteLength).setInt32(0,r,n),this.write(o,t)}getBigInt64(t,r){let n=this.subarray(t,t+8);return new DataView(n.buffer,n.byteOffset,n.byteLength).getBigInt64(0,r)}setBigInt64(t,r,n){let o=At(8);new DataView(o.buffer,o.byteOffset,o.byteLength).setBigInt64(0,r,n),this.write(o,t)}getUint8(t){let r=this.subarray(t,t+1);return new DataView(r.buffer,r.byteOffset,r.byteLength).getUint8(0)}setUint8(t,r){let n=pt(1);new DataView(n.buffer,n.byteOffset,n.byteLength).setUint8(0,r),this.write(n,t)}getUint16(t,r){let n=this.subarray(t,t+2);return new DataView(n.buffer,n.byteOffset,n.byteLength).getUint16(0,r)}setUint16(t,r,n){let o=At(2);new DataView(o.buffer,o.byteOffset,o.byteLength).setUint16(0,r,n),this.write(o,t)}getUint32(t,r){let n=this.subarray(t,t+4);return new DataView(n.buffer,n.byteOffset,n.byteLength).getUint32(0,r)}setUint32(t,r,n){let o=At(4);new DataView(o.buffer,o.byteOffset,o.byteLength).setUint32(0,r,n),this.write(o,t)}getBigUint64(t,r){let n=this.subarray(t,t+8);return new DataView(n.buffer,n.byteOffset,n.byteLength).getBigUint64(0,r)}setBigUint64(t,r,n){let o=At(8);new DataView(o.buffer,o.byteOffset,o.byteLength).setBigUint64(0,r,n),this.write(o,t)}getFloat32(t,r){let n=this.subarray(t,t+4);return new DataView(n.buffer,n.byteOffset,n.byteLength).getFloat32(0,r)}setFloat32(t,r,n){let o=At(4);new DataView(o.buffer,o.byteOffset,o.byteLength).setFloat32(0,r,n),this.write(o,t)}getFloat64(t,r){let n=this.subarray(t,t+8);return new DataView(n.buffer,n.byteOffset,n.byteLength).getFloat64(0,r)}setFloat64(t,r,n){let o=At(8);new DataView(o.buffer,o.byteOffset,o.byteLength).setFloat64(0,r,n),this.write(o,t)}equals(t){if(t==null||!(t instanceof e)||t.bufs.length!==this.bufs.length)return!1;for(let r=0;r<this.bufs.length;r++)if(!ft(this.bufs[r],t.bufs[r]))return!1;return!0}static fromUint8Arrays(t,r){let n=new e;return n.bufs=t,r==null&&(r=t.reduce((o,s)=>o+s.byteLength,0)),n.length=r,n}};var Jn={};bt(Jn,{base10:()=>bu});var bu=Jt({prefix:"9",name:"base10",alphabet:"0123456789"});var to={};bt(to,{base16:()=>xu,base16upper:()=>wu});var xu=Y({prefix:"f",name:"base16",alphabet:"0123456789abcdef",bitsPerChar:4}),wu=Y({prefix:"F",name:"base16upper",alphabet:"0123456789ABCDEF",bitsPerChar:4});var eo={};bt(eo,{base2:()=>Eu});var Eu=Y({prefix:"0",name:"base2",alphabet:"01",bitsPerChar:1});var ro={};bt(ro,{base256emoji:()=>Iu});var hi=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}"),_u=hi.reduce((e,t,r)=>(e[r]=t,e),[]),Su=hi.reduce((e,t,r)=>{let n=t.codePointAt(0);if(n==null)throw new Error(`Invalid character: ${t}`);return e[n]=r,e},[]);function vu(e){return e.reduce((t,r)=>(t+=_u[r],t),"")}function Au(e){let t=[];for(let r of e){let n=r.codePointAt(0);if(n==null)throw new Error(`Invalid character: ${r}`);let o=Su[n];if(o==null)throw new Error(`Non-base256emoji character: ${r}`);t.push(o)}return new Uint8Array(t)}var Iu=Ie({prefix:"\u{1F680}",name:"base256emoji",encode:vu,decode:Au});var oo={};bt(oo,{base64:()=>Bu,base64pad:()=>Tu,base64url:()=>no,base64urlpad:()=>Cu});var Bu=Y({prefix:"m",name:"base64",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/",bitsPerChar:6}),Tu=Y({prefix:"M",name:"base64pad",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/=",bitsPerChar:6}),no=Y({prefix:"u",name:"base64url",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789-_",bitsPerChar:6}),Cu=Y({prefix:"U",name:"base64urlpad",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789-_=",bitsPerChar:6});var so={};bt(so,{base8:()=>Du});var Du=Y({prefix:"7",name:"base8",alphabet:"01234567",bitsPerChar:3});var io={};bt(io,{identity:()=>Lu});var Lu=Ie({prefix:"\0",name:"identity",encode:e=>Ys(e),decode:e=>Ws(e)});var Ld=new TextEncoder,Pd=new TextDecoder;var uo={};bt(uo,{sha256:()=>sr,sha512:()=>Ou});function co({name:e,code:t,encode:r}){return new ao(e,t,r)}var ao=class{name;code;encode;constructor(t,r,n){this.name=t,this.code=r,this.encode=n}digest(t){if(t instanceof Uint8Array){let r=this.encode(t);return r instanceof Uint8Array?fe(this.code,r):r.then(n=>fe(this.code,n))}else throw Error("Unknown type, must be binary type")}};function pi(e){return async t=>new Uint8Array(await crypto.subtle.digest(e,t))}var sr=co({name:"sha2-256",code:18,encode:pi("SHA-256")}),Ou=co({name:"sha2-512",code:19,encode:pi("SHA-512")});var ir={...io,...eo,...so,...Jn,...to,...Zn,...Xn,...Gn,...oo,...ro},Hd={...uo,...Qn};function gi(e,t,r,n){return{name:e,prefix:t,encoder:{name:e,prefix:t,encode:r},decoder:{decode:n}}}var mi=gi("utf8","u",e=>"u"+new TextDecoder("utf8").decode(e),e=>new TextEncoder().encode(e.substring(1))),fo=gi("ascii","a",e=>{let t="a";for(let r=0;r<e.length;r++)t+=String.fromCharCode(e[r]);return t},e=>{e=e.substring(1);let t=pt(e.length);for(let r=0;r<e.length;r++)t[r]=e.charCodeAt(r);return t}),Nu={utf8:mi,"utf-8":mi,hex:ir.base16,latin1:fo,ascii:fo,binary:fo,...ir},zr=Nu;function V(e,t="utf8"){let r=zr[t];if(r==null)throw new Error(`Unsupported encoding "${t}"`);return r.decoder.decode(`${r.prefix}${e}`)}function j(e,t="utf8"){let r=zr[t];if(r==null)throw new Error(`Unsupported encoding "${t}"`);return r.encoder.encode(e).substring(1)}var Uu=parseInt("11111",2),lo=parseInt("10000000",2),ku=parseInt("01111111",2),yi={0:ar,1:ar,2:Mu,3:zu,4:qu,5:Fu,6:Ku,16:ar,22:ar,48:ar};function ho(e,t={offset:0}){let r=e[t.offset]&Uu;if(t.offset++,yi[r]!=null)return yi[r](e,t);throw new Error("No decoder for tag "+r)}function cr(e,t){let r=0;if((e[t.offset]&lo)===lo){let n=e[t.offset]&ku,o="0x";t.offset++;for(let s=0;s<n;s++,t.offset++)o+=e[t.offset].toString(16).padStart(2,"0");r=parseInt(o,16)}else r=e[t.offset],t.offset++;return r}function ar(e,t){cr(e,t);let r=[];for(;!(t.offset>=e.byteLength);){let n=ho(e,t);if(n===null)break;r.push(n)}return r}function Mu(e,t){let r=cr(e,t),n=t.offset,o=t.offset+r,s=[];for(let i=n;i<o;i++)i===n&&e[i]===0||s.push(e[i]);return t.offset+=r,Uint8Array.from(s)}function Ku(e,t){let r=cr(e,t),n=t.offset+r,o=e[t.offset];t.offset++;let s=0,i=0;o<40?(s=0,i=o):o<80?(s=1,i=o-40):(s=2,i=o-80);let c=`${s}.${i}`,a=[];for(;t.offset<n;){let u=e[t.offset];if(t.offset++,a.push(u&127),u<128){a.reverse();let h=0;for(let f=0;f<a.length;f++)h+=a[f]<<f*7;c+=`.${h}`,a=[]}}return c}function Fu(e,t){return t.offset++,null}function zu(e,t){let r=cr(e,t),n=e[t.offset];t.offset++;let o=e.subarray(t.offset,t.offset+r-1);if(t.offset+=r,n!==0)throw new Error("Unused bits in bit string is unimplemented");return o}function qu(e,t){let r=cr(e,t),n=e.subarray(t.offset,t.offset+r);return t.offset+=r,n}function Vu(e){let t=e.toString(16);t.length%2===1&&(t="0"+t);let r=new tt;for(let n=0;n<t.length;n+=2)r.append(Uint8Array.from([parseInt(`${t[n]}${t[n+1]}`,16)]));return r}function po(e){if(e.byteLength<128)return Uint8Array.from([e.byteLength]);let t=Vu(e.byteLength);return new tt(Uint8Array.from([t.byteLength|lo]),t)}function bi(e){let t=new tt,r=128;return(e.subarray()[0]&r)===r&&t.append(Uint8Array.from([0])),t.append(e),new tt(Uint8Array.from([2]),po(t),t)}function xi(e){let t=Uint8Array.from([0]),r=new tt(t,e);return new tt(Uint8Array.from([3]),po(r),r)}function qr(e,t=48){let r=new tt;for(let n of e)r.append(n);return new tt(Uint8Array.from([t]),po(r),r)}async function wi(e,t,r,n){let o=await crypto.subtle.importKey("jwk",e,{name:"ECDSA",namedCurve:e.crv??"P-256"},!1,["verify"]);n?.signal?.throwIfAborted();let s=await crypto.subtle.verify({name:"ECDSA",hash:{name:"SHA-256"}},o,t,r.subarray());return n?.signal?.throwIfAborted(),s}var Hu=Uint8Array.from([6,8,42,134,72,206,61,3,1,7]),ju=Uint8Array.from([6,5,43,129,4,0,34]),$u=Uint8Array.from([6,5,43,129,4,0,35]),Gu={ext:!0,kty:"EC",crv:"P-256"},Zu={ext:!0,kty:"EC",crv:"P-384"},Xu={ext:!0,kty:"EC",crv:"P-521"},mo=32,go=48,yo=66;function Ei(e){let t=ho(e);return _i(t)}function _i(e){let t=e[1][1][0],r=1,n,o;if(t.byteLength===mo*2+1)return n=j(t.subarray(r,r+mo),"base64url"),o=j(t.subarray(r+mo),"base64url"),new De({...Gu,key_ops:["verify"],x:n,y:o});if(t.byteLength===go*2+1)return n=j(t.subarray(r,r+go),"base64url"),o=j(t.subarray(r+go),"base64url"),new De({...Zu,key_ops:["verify"],x:n,y:o});if(t.byteLength===yo*2+1)return n=j(t.subarray(r,r+yo),"base64url"),o=j(t.subarray(r+yo),"base64url"),new De({...Xu,key_ops:["verify"],x:n,y:o});throw new Pt(`coordinates were wrong length, got ${t.byteLength}, expected 65, 97 or 133`)}function Si(e){return qr([bi(Uint8Array.from([1])),qr([Wu(e.crv)],160),qr([xi(new tt(Uint8Array.from([4]),V(e.x??"","base64url"),V(e.y??"","base64url")))],161)]).subarray()}function Wu(e){if(e==="P-256")return Hu;if(e==="P-384")return ju;if(e==="P-521")return $u;throw new Pt(`Invalid curve ${e}`)}var De=class{type="ECDSA";jwk;_raw;constructor(t){this.jwk=t}get raw(){return this._raw==null&&(this._raw=Si(this.jwk)),this._raw}toMultihash(){return vt.digest(Le(this))}toCID(){return et.createV1(114,this.toMultihash())}toString(){return G.encode(this.toMultihash().bytes).substring(1)}equals(t){return t==null||!(t.raw instanceof Uint8Array)?!1:ft(this.raw,t.raw)}async verify(t,r,n){return wi(this.jwk,r,t,n)}};var he=typeof globalThis=="object"&&"crypto"in globalThis?globalThis.crypto:void 0;function Ut(e){return e instanceof Uint8Array||ArrayBuffer.isView(e)&&e.constructor.name==="Uint8Array"}function ur(e){if(!Number.isSafeInteger(e)||e<0)throw new Error("positive integer expected, got "+e)}function mt(e,...t){if(!Ut(e))throw new Error("Uint8Array expected");if(t.length>0&&!t.includes(e.length))throw new Error("Uint8Array expected of length "+t+", got length="+e.length)}function Vr(e){if(typeof e!="function"||typeof e.create!="function")throw new Error("Hash should be wrapped by utils.createHasher");ur(e.outputLen),ur(e.blockLen)}function Re(e,t=!0){if(e.destroyed)throw new Error("Hash instance has been destroyed");if(t&&e.finished)throw new Error("Hash#digest() has already been called")}function Ai(e,t){mt(e);let r=t.outputLen;if(e.length<r)throw new Error("digestInto() expects output buffer of length at least "+r)}function kt(...e){for(let t=0;t<e.length;t++)e[t].fill(0)}function Hr(e){return new DataView(e.buffer,e.byteOffset,e.byteLength)}function It(e,t){return e<<32-t|e>>>t}var Ii=typeof Uint8Array.from([]).toHex=="function"&&typeof Uint8Array.fromHex=="function",Yu=Array.from({length:256},(e,t)=>t.toString(16).padStart(2,"0"));function St(e){if(mt(e),Ii)return e.toHex();let t="";for(let r=0;r<e.length;r++)t+=Yu[e[r]];return t}var Nt={_0:48,_9:57,A:65,F:70,a:97,f:102};function vi(e){if(e>=Nt._0&&e<=Nt._9)return e-Nt._0;if(e>=Nt.A&&e<=Nt.F)return e-(Nt.A-10);if(e>=Nt.a&&e<=Nt.f)return e-(Nt.a-10)}function de(e){if(typeof e!="string")throw new Error("hex string expected, got "+typeof e);if(Ii)return Uint8Array.fromHex(e);let t=e.length,r=t/2;if(t%2)throw new Error("hex string expected, got unpadded hex of length "+t);let n=new Uint8Array(r);for(let o=0,s=0;o<r;o++,s+=2){let i=vi(e.charCodeAt(s)),c=vi(e.charCodeAt(s+1));if(i===void 0||c===void 0){let a=e[s]+e[s+1];throw new Error('hex string expected, got non-hex character "'+a+'" at index '+s)}n[o]=i*16+c}return n}function bo(e){if(typeof e!="string")throw new Error("string expected");return new Uint8Array(new TextEncoder().encode(e))}function fr(e){return typeof e=="string"&&(e=bo(e)),mt(e),e}function lt(...e){let t=0;for(let n=0;n<e.length;n++){let o=e[n];mt(o),t+=o.length}let r=new Uint8Array(t);for(let n=0,o=0;n<e.length;n++){let s=e[n];r.set(s,o),o+=s.length}return r}var Pe=class{};function xo(e){let t=n=>e().update(fr(n)).digest(),r=e();return t.outputLen=r.outputLen,t.blockLen=r.blockLen,t.create=()=>e(),t}function Oe(e=32){if(he&&typeof he.getRandomValues=="function")return he.getRandomValues(new Uint8Array(e));if(he&&typeof he.randomBytes=="function")return Uint8Array.from(he.randomBytes(e));throw new Error("crypto.getRandomValues must be defined")}function Qu(e,t,r,n){if(typeof e.setBigUint64=="function")return e.setBigUint64(t,r,n);let o=BigInt(32),s=BigInt(4294967295),i=Number(r>>o&s),c=Number(r&s),a=n?4:0,u=n?0:4;e.setUint32(t+a,i,n),e.setUint32(t+u,c,n)}function Bi(e,t,r){return e&t^~e&r}function Ti(e,t,r){return e&t^e&r^t&r}var lr=class extends Pe{constructor(t,r,n,o){super(),this.finished=!1,this.length=0,this.pos=0,this.destroyed=!1,this.blockLen=t,this.outputLen=r,this.padOffset=n,this.isLE=o,this.buffer=new Uint8Array(t),this.view=Hr(this.buffer)}update(t){Re(this),t=fr(t),mt(t);let{view:r,buffer:n,blockLen:o}=this,s=t.length;for(let i=0;i<s;){let c=Math.min(o-this.pos,s-i);if(c===o){let a=Hr(t);for(;o<=s-i;i+=o)this.process(a,i);continue}n.set(t.subarray(i,i+c),this.pos),this.pos+=c,i+=c,this.pos===o&&(this.process(r,0),this.pos=0)}return this.length+=t.length,this.roundClean(),this}digestInto(t){Re(this),Ai(t,this),this.finished=!0;let{buffer:r,view:n,blockLen:o,isLE:s}=this,{pos:i}=this;r[i++]=128,kt(this.buffer.subarray(i)),this.padOffset>o-i&&(this.process(n,0),i=0);for(let f=i;f<o;f++)r[f]=0;Qu(n,o-8,BigInt(this.length*8),s),this.process(n,0);let c=Hr(t),a=this.outputLen;if(a%4)throw new Error("_sha2: outputLen should be aligned to 32bit");let u=a/4,h=this.get();if(u>h.length)throw new Error("_sha2: outputLen bigger than state");for(let f=0;f<u;f++)c.setUint32(4*f,h[f],s)}digest(){let{buffer:t,outputLen:r}=this;this.digestInto(t);let n=t.slice(0,r);return this.destroy(),n}_cloneInto(t){t||(t=new this.constructor),t.set(...this.get());let{blockLen:r,buffer:n,length:o,finished:s,destroyed:i,pos:c}=this;return t.destroyed=i,t.finished=s,t.length=o,t.pos=c,o%r&&t.buffer.set(n),t}clone(){return this._cloneInto()}},Mt=Uint32Array.from([1779033703,3144134277,1013904242,2773480762,1359893119,2600822924,528734635,1541459225]);var st=Uint32Array.from([1779033703,4089235720,3144134277,2227873595,1013904242,4271175723,2773480762,1595750129,1359893119,2917565137,2600822924,725511199,528734635,4215389547,1541459225,327033209]);var jr=BigInt(4294967295),Ci=BigInt(32);function Ju(e,t=!1){return t?{h:Number(e&jr),l:Number(e>>Ci&jr)}:{h:Number(e>>Ci&jr)|0,l:Number(e&jr)|0}}function Di(e,t=!1){let r=e.length,n=new Uint32Array(r),o=new Uint32Array(r);for(let s=0;s<r;s++){let{h:i,l:c}=Ju(e[s],t);[n[s],o[s]]=[i,c]}return[n,o]}var wo=(e,t,r)=>e>>>r,Eo=(e,t,r)=>e<<32-r|t>>>r,pe=(e,t,r)=>e>>>r|t<<32-r,me=(e,t,r)=>e<<32-r|t>>>r,hr=(e,t,r)=>e<<64-r|t>>>r-32,dr=(e,t,r)=>e>>>r-32|t<<64-r;function Dt(e,t,r,n){let o=(t>>>0)+(n>>>0);return{h:e+r+(o/2**32|0)|0,l:o|0}}var Li=(e,t,r)=>(e>>>0)+(t>>>0)+(r>>>0),Pi=(e,t,r,n)=>t+r+n+(e/2**32|0)|0,Ri=(e,t,r,n)=>(e>>>0)+(t>>>0)+(r>>>0)+(n>>>0),Oi=(e,t,r,n,o)=>t+r+n+o+(e/2**32|0)|0,Ni=(e,t,r,n,o)=>(e>>>0)+(t>>>0)+(r>>>0)+(n>>>0)+(o>>>0),Ui=(e,t,r,n,o,s)=>t+r+n+o+s+(e/2**32|0)|0;var ef=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]),re=new Uint32Array(64),_o=class extends lr{constructor(t=32){super(64,t,8,!1),this.A=Mt[0]|0,this.B=Mt[1]|0,this.C=Mt[2]|0,this.D=Mt[3]|0,this.E=Mt[4]|0,this.F=Mt[5]|0,this.G=Mt[6]|0,this.H=Mt[7]|0}get(){let{A:t,B:r,C:n,D:o,E:s,F:i,G:c,H:a}=this;return[t,r,n,o,s,i,c,a]}set(t,r,n,o,s,i,c,a){this.A=t|0,this.B=r|0,this.C=n|0,this.D=o|0,this.E=s|0,this.F=i|0,this.G=c|0,this.H=a|0}process(t,r){for(let f=0;f<16;f++,r+=4)re[f]=t.getUint32(r,!1);for(let f=16;f<64;f++){let l=re[f-15],p=re[f-2],d=It(l,7)^It(l,18)^l>>>3,x=It(p,17)^It(p,19)^p>>>10;re[f]=x+re[f-7]+d+re[f-16]|0}let{A:n,B:o,C:s,D:i,E:c,F:a,G:u,H:h}=this;for(let f=0;f<64;f++){let l=It(c,6)^It(c,11)^It(c,25),p=h+l+Bi(c,a,u)+ef[f]+re[f]|0,x=(It(n,2)^It(n,13)^It(n,22))+Ti(n,o,s)|0;h=u,u=a,a=c,c=i+p|0,i=s,s=o,o=n,n=p+x|0}n=n+this.A|0,o=o+this.B|0,s=s+this.C|0,i=i+this.D|0,c=c+this.E|0,a=a+this.F|0,u=u+this.G|0,h=h+this.H|0,this.set(n,o,s,i,c,a,u,h)}roundClean(){kt(re)}destroy(){this.set(0,0,0,0,0,0,0,0),kt(this.buffer)}};var ki=Di(["0x428a2f98d728ae22","0x7137449123ef65cd","0xb5c0fbcfec4d3b2f","0xe9b5dba58189dbbc","0x3956c25bf348b538","0x59f111f1b605d019","0x923f82a4af194f9b","0xab1c5ed5da6d8118","0xd807aa98a3030242","0x12835b0145706fbe","0x243185be4ee4b28c","0x550c7dc3d5ffb4e2","0x72be5d74f27b896f","0x80deb1fe3b1696b1","0x9bdc06a725c71235","0xc19bf174cf692694","0xe49b69c19ef14ad2","0xefbe4786384f25e3","0x0fc19dc68b8cd5b5","0x240ca1cc77ac9c65","0x2de92c6f592b0275","0x4a7484aa6ea6e483","0x5cb0a9dcbd41fbd4","0x76f988da831153b5","0x983e5152ee66dfab","0xa831c66d2db43210","0xb00327c898fb213f","0xbf597fc7beef0ee4","0xc6e00bf33da88fc2","0xd5a79147930aa725","0x06ca6351e003826f","0x142929670a0e6e70","0x27b70a8546d22ffc","0x2e1b21385c26c926","0x4d2c6dfc5ac42aed","0x53380d139d95b3df","0x650a73548baf63de","0x766a0abb3c77b2a8","0x81c2c92e47edaee6","0x92722c851482353b","0xa2bfe8a14cf10364","0xa81a664bbc423001","0xc24b8b70d0f89791","0xc76c51a30654be30","0xd192e819d6ef5218","0xd69906245565a910","0xf40e35855771202a","0x106aa07032bbd1b8","0x19a4c116b8d2d0c8","0x1e376c085141ab53","0x2748774cdf8eeb99","0x34b0bcb5e19b48a8","0x391c0cb3c5c95a63","0x4ed8aa4ae3418acb","0x5b9cca4f7763e373","0x682e6ff3d6b2b8a3","0x748f82ee5defb2fc","0x78a5636f43172f60","0x84c87814a1f0ab72","0x8cc702081a6439ec","0x90befffa23631e28","0xa4506cebde82bde9","0xbef9a3f7b2c67915","0xc67178f2e372532b","0xca273eceea26619c","0xd186b8c721c0c207","0xeada7dd6cde0eb1e","0xf57d4f7fee6ed178","0x06f067aa72176fba","0x0a637dc5a2c898a6","0x113f9804bef90dae","0x1b710b35131c471b","0x28db77f523047d84","0x32caab7b40c72493","0x3c9ebe0a15c9bebc","0x431d67c49c100d4c","0x4cc5d4becb3e42b6","0x597f299cfc657e2a","0x5fcb6fab3ad6faec","0x6c44198c4a475817"].map(e=>BigInt(e))),rf=ki[0],nf=ki[1],ne=new Uint32Array(80),oe=new Uint32Array(80),So=class extends lr{constructor(t=64){super(128,t,16,!1),this.Ah=st[0]|0,this.Al=st[1]|0,this.Bh=st[2]|0,this.Bl=st[3]|0,this.Ch=st[4]|0,this.Cl=st[5]|0,this.Dh=st[6]|0,this.Dl=st[7]|0,this.Eh=st[8]|0,this.El=st[9]|0,this.Fh=st[10]|0,this.Fl=st[11]|0,this.Gh=st[12]|0,this.Gl=st[13]|0,this.Hh=st[14]|0,this.Hl=st[15]|0}get(){let{Ah:t,Al:r,Bh:n,Bl:o,Ch:s,Cl:i,Dh:c,Dl:a,Eh:u,El:h,Fh:f,Fl:l,Gh:p,Gl:d,Hh:x,Hl:E}=this;return[t,r,n,o,s,i,c,a,u,h,f,l,p,d,x,E]}set(t,r,n,o,s,i,c,a,u,h,f,l,p,d,x,E){this.Ah=t|0,this.Al=r|0,this.Bh=n|0,this.Bl=o|0,this.Ch=s|0,this.Cl=i|0,this.Dh=c|0,this.Dl=a|0,this.Eh=u|0,this.El=h|0,this.Fh=f|0,this.Fl=l|0,this.Gh=p|0,this.Gl=d|0,this.Hh=x|0,this.Hl=E|0}process(t,r){for(let w=0;w<16;w++,r+=4)ne[w]=t.getUint32(r),oe[w]=t.getUint32(r+=4);for(let w=16;w<80;w++){let T=ne[w-15]|0,P=oe[w-15]|0,M=pe(T,P,1)^pe(T,P,8)^wo(T,P,7),k=me(T,P,1)^me(T,P,8)^Eo(T,P,7),O=ne[w-2]|0,_=oe[w-2]|0,C=pe(O,_,19)^hr(O,_,61)^wo(O,_,6),N=me(O,_,19)^dr(O,_,61)^Eo(O,_,6),D=Ri(k,N,oe[w-7],oe[w-16]),b=Oi(D,M,C,ne[w-7],ne[w-16]);ne[w]=b|0,oe[w]=D|0}let{Ah:n,Al:o,Bh:s,Bl:i,Ch:c,Cl:a,Dh:u,Dl:h,Eh:f,El:l,Fh:p,Fl:d,Gh:x,Gl:E,Hh:y,Hl:v}=this;for(let w=0;w<80;w++){let T=pe(f,l,14)^pe(f,l,18)^hr(f,l,41),P=me(f,l,14)^me(f,l,18)^dr(f,l,41),M=f&p^~f&x,k=l&d^~l&E,O=Ni(v,P,k,nf[w],oe[w]),_=Ui(O,y,T,M,rf[w],ne[w]),C=O|0,N=pe(n,o,28)^hr(n,o,34)^hr(n,o,39),D=me(n,o,28)^dr(n,o,34)^dr(n,o,39),b=n&s^n&c^s&c,m=o&i^o&a^i&a;y=x|0,v=E|0,x=p|0,E=d|0,p=f|0,d=l|0,{h:f,l}=Dt(u|0,h|0,_|0,C|0),u=c|0,h=a|0,c=s|0,a=i|0,s=n|0,i=o|0;let g=Li(C,D,m);n=Pi(g,_,N,b),o=g|0}({h:n,l:o}=Dt(this.Ah|0,this.Al|0,n|0,o|0)),{h:s,l:i}=Dt(this.Bh|0,this.Bl|0,s|0,i|0),{h:c,l:a}=Dt(this.Ch|0,this.Cl|0,c|0,a|0),{h:u,l:h}=Dt(this.Dh|0,this.Dl|0,u|0,h|0),{h:f,l}=Dt(this.Eh|0,this.El|0,f|0,l|0),{h:p,l:d}=Dt(this.Fh|0,this.Fl|0,p|0,d|0),{h:x,l:E}=Dt(this.Gh|0,this.Gl|0,x|0,E|0),{h:y,l:v}=Dt(this.Hh|0,this.Hl|0,y|0,v|0),this.set(n,o,s,i,c,a,u,h,f,l,p,d,x,E,y,v)}roundClean(){kt(ne,oe)}destroy(){kt(this.buffer),this.set(0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0)}};var Mi=xo(()=>new _o);var Ki=xo(()=>new So);var Io=BigInt(0),Ao=BigInt(1);function Kt(e,t=""){if(typeof e!="boolean"){let r=t&&`"${t}"`;throw new Error(r+"expected boolean, got type="+typeof e)}return e}function xt(e,t,r=""){let n=Ut(e),o=e?.length,s=t!==void 0;if(!n||s&&o!==t){let i=r&&`"${r}" `,c=s?` of length ${t}`:"",a=n?`length=${o}`:`type=${typeof e}`;throw new Error(i+"expected Uint8Array"+c+", got "+a)}return e}function pr(e){let t=e.toString(16);return t.length&1?"0"+t:t}function Fi(e){if(typeof e!="string")throw new Error("hex string expected, got "+typeof e);return e===""?Io:BigInt("0x"+e)}function Ne(e){return Fi(St(e))}function Ft(e){return mt(e),Fi(St(Uint8Array.from(e).reverse()))}function $r(e,t){return de(e.toString(16).padStart(t*2,"0"))}function Bo(e,t){return $r(e,t).reverse()}function z(e,t,r){let n;if(typeof t=="string")try{n=de(t)}catch(s){throw new Error(e+" must be hex string or Uint8Array, cause: "+s)}else if(Ut(t))n=Uint8Array.from(t);else throw new Error(e+" must be hex string or Uint8Array");let o=n.length;if(typeof r=="number"&&o!==r)throw new Error(e+" of length "+r+" expected, got "+o);return n}function zi(e,t){if(e.length!==t.length)return!1;let r=0;for(let n=0;n<e.length;n++)r|=e[n]^t[n];return r===0}function To(e){return Uint8Array.from(e)}var vo=e=>typeof e=="bigint"&&Io<=e;function qi(e,t,r){return vo(e)&&vo(t)&&vo(r)&&t<=e&&e<r}function mr(e,t,r,n){if(!qi(t,r,n))throw new Error("expected valid "+e+": "+r+" <= n < "+n+", got "+t)}function Gr(e){let t;for(t=0;e>Io;e>>=Ao,t+=1);return t}var se=e=>(Ao<<BigInt(e))-Ao;function Vi(e,t,r){if(typeof e!="number"||e<2)throw new Error("hashLen must be a number");if(typeof t!="number"||t<2)throw new Error("qByteLen must be a number");if(typeof r!="function")throw new Error("hmacFn must be a function");let n=p=>new Uint8Array(p),o=p=>Uint8Array.of(p),s=n(e),i=n(e),c=0,a=()=>{s.fill(1),i.fill(0),c=0},u=(...p)=>r(i,s,...p),h=(p=n(0))=>{i=u(o(0),p),s=u(),p.length!==0&&(i=u(o(1),p),s=u())},f=()=>{if(c++>=1e3)throw new Error("drbg: tried 1000 values");let p=0,d=[];for(;p<t;){s=u();let x=s.slice();d.push(x),p+=s.length}return lt(...d)};return(p,d)=>{a(),h(p);let x;for(;!(x=d(f()));)h();return a(),x}}function ie(e,t,r={}){if(!e||typeof e!="object")throw new Error("expected valid options object");function n(o,s,i){let c=e[o];if(i&&c===void 0)return;let a=typeof c;if(a!==s||c===null)throw new Error(`param "${o}" is invalid: expected ${s}, got ${a}`)}Object.entries(t).forEach(([o,s])=>n(o,s,!1)),Object.entries(r).forEach(([o,s])=>n(o,s,!0))}var Co=()=>{throw new Error("not implemented")};function Ue(e){let t=new WeakMap;return(r,...n)=>{let o=t.get(r);if(o!==void 0)return o;let s=e(r,...n);return t.set(r,s),s}}var ht=BigInt(0),rt=BigInt(1),ge=BigInt(2),$i=BigInt(3),Gi=BigInt(4),Zi=BigInt(5),of=BigInt(7),Xi=BigInt(8),sf=BigInt(9),Wi=BigInt(16);function Q(e,t){let r=e%t;return r>=ht?r:t+r}function $(e,t,r){let n=e;for(;t-- >ht;)n*=n,n%=r;return n}function Hi(e,t){if(e===ht)throw new Error("invert: expected non-zero number");if(t<=ht)throw new Error("invert: expected positive modulus, got "+t);let r=Q(e,t),n=t,o=ht,s=rt,i=rt,c=ht;for(;r!==ht;){let u=n/r,h=n%r,f=o-i*u,l=s-c*u;n=r,r=h,o=i,s=c,i=f,c=l}if(n!==rt)throw new Error("invert: does not exist");return Q(o,t)}function Do(e,t,r){if(!e.eql(e.sqr(t),r))throw new Error("Cannot find square root")}function Yi(e,t){let r=(e.ORDER+rt)/Gi,n=e.pow(t,r);return Do(e,n,t),n}function af(e,t){let r=(e.ORDER-Zi)/Xi,n=e.mul(t,ge),o=e.pow(n,r),s=e.mul(t,o),i=e.mul(e.mul(s,ge),o),c=e.mul(s,e.sub(i,e.ONE));return Do(e,c,t),c}function cf(e){let t=wt(e),r=Qi(e),n=r(t,t.neg(t.ONE)),o=r(t,n),s=r(t,t.neg(n)),i=(e+of)/Wi;return(c,a)=>{let u=c.pow(a,i),h=c.mul(u,n),f=c.mul(u,o),l=c.mul(u,s),p=c.eql(c.sqr(h),a),d=c.eql(c.sqr(f),a);u=c.cmov(u,h,p),h=c.cmov(l,f,d);let x=c.eql(c.sqr(h),a),E=c.cmov(u,h,x);return Do(c,E,a),E}}function Qi(e){if(e<$i)throw new Error("sqrt is not defined for small field");let t=e-rt,r=0;for(;t%ge===ht;)t/=ge,r++;let n=ge,o=wt(e);for(;ji(o,n)===1;)if(n++>1e3)throw new Error("Cannot find square root: probably non-prime P");if(r===1)return Yi;let s=o.pow(n,t),i=(t+rt)/ge;return function(a,u){if(a.is0(u))return u;if(ji(a,u)!==1)throw new Error("Cannot find square root");let h=r,f=a.mul(a.ONE,s),l=a.pow(u,t),p=a.pow(u,i);for(;!a.eql(l,a.ONE);){if(a.is0(l))return a.ZERO;let d=1,x=a.sqr(l);for(;!a.eql(x,a.ONE);)if(d++,x=a.sqr(x),d===h)throw new Error("Cannot find square root");let E=rt<<BigInt(h-d-1),y=a.pow(f,E);h=d,f=a.sqr(y),l=a.mul(l,f),p=a.mul(p,y)}return p}}function uf(e){return e%Gi===$i?Yi:e%Xi===Zi?af:e%Wi===sf?cf(e):Qi(e)}var zt=(e,t)=>(Q(e,t)&rt)===rt,ff=["create","isValid","is0","neg","inv","sqrt","sqr","eql","add","sub","mul","pow","div","addN","subN","mulN","sqrN"];function Lo(e){let t={ORDER:"bigint",MASK:"bigint",BYTES:"number",BITS:"number"},r=ff.reduce((n,o)=>(n[o]="function",n),t);return ie(e,r),e}function lf(e,t,r){if(r<ht)throw new Error("invalid exponent, negatives unsupported");if(r===ht)return e.ONE;if(r===rt)return t;let n=e.ONE,o=t;for(;r>ht;)r&rt&&(n=e.mul(n,o)),o=e.sqr(o),r>>=rt;return n}function gr(e,t,r=!1){let n=new Array(t.length).fill(r?e.ZERO:void 0),o=t.reduce((i,c,a)=>e.is0(c)?i:(n[a]=i,e.mul(i,c)),e.ONE),s=e.inv(o);return t.reduceRight((i,c,a)=>e.is0(c)?i:(n[a]=e.mul(i,n[a]),e.mul(i,c)),s),n}function ji(e,t){let r=(e.ORDER-rt)/ge,n=e.pow(t,r),o=e.eql(n,e.ONE),s=e.eql(n,e.ZERO),i=e.eql(n,e.neg(e.ONE));if(!o&&!s&&!i)throw new Error("invalid Legendre symbol result");return o?1:s?0:-1}function Zr(e,t){t!==void 0&&ur(t);let r=t!==void 0?t:e.toString(2).length,n=Math.ceil(r/8);return{nBitLength:r,nByteLength:n}}function wt(e,t,r=!1,n={}){if(e<=ht)throw new Error("invalid field: expected ORDER > 0, got "+e);let o,s,i=!1,c;if(typeof t=="object"&&t!=null){if(n.sqrt||r)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"&&(r=l.isLE),typeof l.modFromBytes=="boolean"&&(i=l.modFromBytes),c=l.allowedLengths}else typeof t=="number"&&(o=t),n.sqrt&&(s=n.sqrt);let{nBitLength:a,nByteLength:u}=Zr(e,o);if(u>2048)throw new Error("invalid field: expected ORDER of <= 2048 bytes");let h,f=Object.freeze({ORDER:e,isLE:r,BITS:a,BYTES:u,MASK:se(a),ZERO:ht,ONE:rt,allowedLengths:c,create:l=>Q(l,e),isValid:l=>{if(typeof l!="bigint")throw new Error("invalid field element: expected bigint, got "+typeof l);return ht<=l&&l<e},is0:l=>l===ht,isValidNot0:l=>!f.is0(l)&&f.isValid(l),isOdd:l=>(l&rt)===rt,neg:l=>Q(-l,e),eql:(l,p)=>l===p,sqr:l=>Q(l*l,e),add:(l,p)=>Q(l+p,e),sub:(l,p)=>Q(l-p,e),mul:(l,p)=>Q(l*p,e),pow:(l,p)=>lf(f,l,p),div:(l,p)=>Q(l*Hi(p,e),e),sqrN:l=>l*l,addN:(l,p)=>l+p,subN:(l,p)=>l-p,mulN:(l,p)=>l*p,inv:l=>Hi(l,e),sqrt:s||(l=>(h||(h=uf(e)),h(f,l))),toBytes:l=>r?Bo(l,u):$r(l,u),fromBytes:(l,p=!0)=>{if(c){if(!c.includes(l.length)||l.length>u)throw new Error("Field.fromBytes: expected "+c+" bytes, got "+l.length);let x=new Uint8Array(u);x.set(l,r?0:x.length-l.length),l=x}if(l.length!==u)throw new Error("Field.fromBytes: expected "+u+" bytes, got "+l.length);let d=r?Ft(l):Ne(l);if(i&&(d=Q(d,e)),!p&&!f.isValid(d))throw new Error("invalid field element: outside of range 0..ORDER");return d},invertBatch:l=>gr(f,l),cmov:(l,p,d)=>d?p:l});return Object.freeze(f)}function Ji(e){if(typeof e!="bigint")throw new Error("field order must be bigint");let t=e.toString(2).length;return Math.ceil(t/8)}function Po(e){let t=Ji(e);return t+Math.ceil(t/2)}function Ro(e,t,r=!1){let n=e.length,o=Ji(t),s=Po(t);if(n<16||n<s||n>1024)throw new Error("expected "+s+"-1024 bytes of input, got "+n);let i=r?Ft(e):Ne(e),c=Q(i,t-rt)+rt;return r?Bo(c,o):$r(c,o)}var ke=BigInt(0),ye=BigInt(1);function yr(e,t){let r=t.negate();return e?r:t}function qt(e,t){let r=gr(e.Fp,t.map(n=>n.Z));return t.map((n,o)=>e.fromAffine(n.toAffine(r[o])))}function na(e,t){if(!Number.isSafeInteger(e)||e<=0||e>t)throw new Error("invalid window size, expected [1.."+t+"], got W="+e)}function Oo(e,t){na(e,t);let r=Math.ceil(t/e)+1,n=2**(e-1),o=2**e,s=se(e),i=BigInt(e);return{windows:r,windowSize:n,mask:s,maxNumber:o,shiftBy:i}}function ta(e,t,r){let{windowSize:n,mask:o,maxNumber:s,shiftBy:i}=r,c=Number(e&o),a=e>>i;c>n&&(c-=s,a+=ye);let u=t*n,h=u+Math.abs(c)-1,f=c===0,l=c<0,p=t%2!==0;return{nextN:a,offset:h,isZero:f,isNeg:l,isNegF:p,offsetF:u}}function hf(e,t){if(!Array.isArray(e))throw new Error("array expected");e.forEach((r,n)=>{if(!(r instanceof t))throw new Error("invalid point at index "+n)})}function df(e,t){if(!Array.isArray(e))throw new Error("array of scalars expected");e.forEach((r,n)=>{if(!t.isValid(r))throw new Error("invalid scalar at index "+n)})}var No=new WeakMap,oa=new WeakMap;function Uo(e){return oa.get(e)||1}function ea(e){if(e!==ke)throw new Error("invalid wNAF")}var Me=class{constructor(t,r){this.BASE=t.BASE,this.ZERO=t.ZERO,this.Fn=t.Fn,this.bits=r}_unsafeLadder(t,r,n=this.ZERO){let o=t;for(;r>ke;)r&ye&&(n=n.add(o)),o=o.double(),r>>=ye;return n}precomputeWindow(t,r){let{windows:n,windowSize:o}=Oo(r,this.bits),s=[],i=t,c=i;for(let a=0;a<n;a++){c=i,s.push(c);for(let u=1;u<o;u++)c=c.add(i),s.push(c);i=c.double()}return s}wNAF(t,r,n){if(!this.Fn.isValid(n))throw new Error("invalid scalar");let o=this.ZERO,s=this.BASE,i=Oo(t,this.bits);for(let c=0;c<i.windows;c++){let{nextN:a,offset:u,isZero:h,isNeg:f,isNegF:l,offsetF:p}=ta(n,c,i);n=a,h?s=s.add(yr(l,r[p])):o=o.add(yr(f,r[u]))}return ea(n),{p:o,f:s}}wNAFUnsafe(t,r,n,o=this.ZERO){let s=Oo(t,this.bits);for(let i=0;i<s.windows&&n!==ke;i++){let{nextN:c,offset:a,isZero:u,isNeg:h}=ta(n,i,s);if(n=c,!u){let f=r[a];o=o.add(h?f.negate():f)}}return ea(n),o}getPrecomputes(t,r,n){let o=No.get(r);return o||(o=this.precomputeWindow(r,t),t!==1&&(typeof n=="function"&&(o=n(o)),No.set(r,o))),o}cached(t,r,n){let o=Uo(t);return this.wNAF(o,this.getPrecomputes(o,t,n),r)}unsafe(t,r,n,o){let s=Uo(t);return s===1?this._unsafeLadder(t,r,o):this.wNAFUnsafe(s,this.getPrecomputes(s,t,n),r,o)}createCache(t,r){na(r,this.bits),oa.set(t,r),No.delete(t)}hasCache(t){return Uo(t)!==1}};function sa(e,t,r,n){let o=t,s=e.ZERO,i=e.ZERO;for(;r>ke||n>ke;)r&ye&&(s=s.add(o)),n&ye&&(i=i.add(o)),o=o.double(),r>>=ye,n>>=ye;return{p1:s,p2:i}}function Ke(e,t,r,n){hf(r,e),df(n,t);let o=r.length,s=n.length;if(o!==s)throw new Error("arrays of points and scalars must have equal length");let i=e.ZERO,c=Gr(BigInt(o)),a=1;c>12?a=c-3:c>4?a=c-2:c>0&&(a=2);let u=se(a),h=new Array(Number(u)+1).fill(i),f=Math.floor((t.BITS-1)/a)*a,l=i;for(let p=f;p>=0;p-=a){h.fill(i);for(let x=0;x<s;x++){let E=n[x],y=Number(E>>BigInt(p)&u);h[y]=h[y].add(r[x])}let d=i;for(let x=h.length-1,E=i;x>0;x--)E=E.add(h[x]),d=d.add(E);if(l=l.add(d),p!==0)for(let x=0;x<a;x++)l=l.double()}return l}function ra(e,t,r){if(t){if(t.ORDER!==e)throw new Error("Field.ORDER must match order: Fp == p, Fn == n");return Lo(t),t}else return wt(e,{isLE:r})}function Xr(e,t,r={},n){if(n===void 0&&(n=e==="edwards"),!t||typeof t!="object")throw new Error(`expected valid ${e} CURVE object`);for(let a of["p","n","h"]){let u=t[a];if(!(typeof u=="bigint"&&u>ke))throw new Error(`CURVE.${a} must be positive bigint`)}let o=ra(t.p,r.Fp,n),s=ra(t.n,r.Fn,n),c=["Gx","Gy","a",e==="weierstrass"?"b":"d"];for(let a of c)if(!o.isValid(t[a]))throw new Error(`CURVE.${a} must be valid field element of CURVE.Fp`);return t=Object.freeze(Object.assign({},t)),{CURVE:t,Fp:o,Fn:s}}var ae=BigInt(0),nt=BigInt(1),ko=BigInt(2),pf=BigInt(8);function mf(e,t,r,n){let o=e.sqr(r),s=e.sqr(n),i=e.add(e.mul(t.a,o),s),c=e.add(e.ONE,e.mul(t.d,e.mul(o,s)));return e.eql(i,c)}function gf(e,t={}){let r=Xr("edwards",e,t,t.FpFnLE),{Fp:n,Fn:o}=r,s=r.CURVE,{h:i}=s;ie(t,{},{uvRatio:"function"});let c=ko<<BigInt(o.BYTES*8)-nt,a=E=>n.create(E),u=t.uvRatio||((E,y)=>{try{return{isValid:!0,value:n.sqrt(n.div(E,y))}}catch{return{isValid:!1,value:ae}}});if(!mf(n,s,s.Gx,s.Gy))throw new Error("bad curve params: generator point");function h(E,y,v=!1){let w=v?nt:ae;return mr("coordinate "+E,y,w,c),y}function f(E){if(!(E instanceof d))throw new Error("ExtendedPoint expected")}let l=Ue((E,y)=>{let{X:v,Y:w,Z:T}=E,P=E.is0();y==null&&(y=P?pf:n.inv(T));let M=a(v*y),k=a(w*y),O=n.mul(T,y);if(P)return{x:ae,y:nt};if(O!==nt)throw new Error("invZ was invalid");return{x:M,y:k}}),p=Ue(E=>{let{a:y,d:v}=s;if(E.is0())throw new Error("bad point: ZERO");let{X:w,Y:T,Z:P,T:M}=E,k=a(w*w),O=a(T*T),_=a(P*P),C=a(_*_),N=a(k*y),D=a(_*a(N+O)),b=a(C+a(v*a(k*O)));if(D!==b)throw new Error("bad point: equation left != right (1)");let m=a(w*T),g=a(P*M);if(m!==g)throw new Error("bad point: equation left != right (2)");return!0});class d{constructor(y,v,w,T){this.X=h("x",y),this.Y=h("y",v),this.Z=h("z",w,!0),this.T=h("t",T),Object.freeze(this)}static CURVE(){return s}static fromAffine(y){if(y instanceof d)throw new Error("extended point not allowed");let{x:v,y:w}=y||{};return h("x",v),h("y",w),new d(v,w,nt,a(v*w))}static fromBytes(y,v=!1){let w=n.BYTES,{a:T,d:P}=s;y=To(xt(y,w,"point")),Kt(v,"zip215");let M=To(y),k=y[w-1];M[w-1]=k&-129;let O=Ft(M),_=v?c:n.ORDER;mr("point.y",O,ae,_);let C=a(O*O),N=a(C-nt),D=a(P*C-T),{isValid:b,value:m}=u(N,D);if(!b)throw new Error("bad point: invalid y coordinate");let g=(m&nt)===nt,S=(k&128)!==0;if(!v&&m===ae&&S)throw new Error("bad point: x=0 and x_0=1");return S!==g&&(m=a(-m)),d.fromAffine({x:m,y:O})}static fromHex(y,v=!1){return d.fromBytes(z("point",y),v)}get x(){return this.toAffine().x}get y(){return this.toAffine().y}precompute(y=8,v=!0){return x.createCache(this,y),v||this.multiply(ko),this}assertValidity(){p(this)}equals(y){f(y);let{X:v,Y:w,Z:T}=this,{X:P,Y:M,Z:k}=y,O=a(v*k),_=a(P*T),C=a(w*k),N=a(M*T);return O===_&&C===N}is0(){return this.equals(d.ZERO)}negate(){return new d(a(-this.X),this.Y,this.Z,a(-this.T))}double(){let{a:y}=s,{X:v,Y:w,Z:T}=this,P=a(v*v),M=a(w*w),k=a(ko*a(T*T)),O=a(y*P),_=v+w,C=a(a(_*_)-P-M),N=O+M,D=N-k,b=O-M,m=a(C*D),g=a(N*b),S=a(C*b),A=a(D*N);return new d(m,g,A,S)}add(y){f(y);let{a:v,d:w}=s,{X:T,Y:P,Z:M,T:k}=this,{X:O,Y:_,Z:C,T:N}=y,D=a(T*O),b=a(P*_),m=a(k*w*N),g=a(M*C),S=a((T+P)*(O+_)-D-b),A=g-m,L=g+m,I=a(b-v*D),B=a(S*A),R=a(L*I),U=a(S*I),Z=a(A*L);return new d(B,R,Z,U)}subtract(y){return this.add(y.negate())}multiply(y){if(!o.isValidNot0(y))throw new Error("invalid scalar: expected 1 <= sc < curve.n");let{p:v,f:w}=x.cached(this,y,T=>qt(d,T));return qt(d,[v,w])[0]}multiplyUnsafe(y,v=d.ZERO){if(!o.isValid(y))throw new Error("invalid scalar: expected 0 <= sc < curve.n");return y===ae?d.ZERO:this.is0()||y===nt?this:x.unsafe(this,y,w=>qt(d,w),v)}isSmallOrder(){return this.multiplyUnsafe(i).is0()}isTorsionFree(){return x.unsafe(this,s.n).is0()}toAffine(y){return l(this,y)}clearCofactor(){return i===nt?this:this.multiplyUnsafe(i)}toBytes(){let{x:y,y:v}=this.toAffine(),w=n.toBytes(v);return w[w.length-1]|=y&nt?128:0,w}toHex(){return St(this.toBytes())}toString(){return`<Point ${this.is0()?"ZERO":this.toHex()}>`}get ex(){return this.X}get ey(){return this.Y}get ez(){return this.Z}get et(){return this.T}static normalizeZ(y){return qt(d,y)}static msm(y,v){return Ke(d,o,y,v)}_setWindowSize(y){this.precompute(y)}toRawBytes(){return this.toBytes()}}d.BASE=new d(s.Gx,s.Gy,nt,a(s.Gx*s.Gy)),d.ZERO=new d(ae,nt,nt,ae),d.Fp=n,d.Fn=o;let x=new Me(d,o.BITS);return d.BASE.precompute(8),d}var Wr=class{constructor(t){this.ep=t}static fromBytes(t){Co()}static fromHex(t){Co()}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)}toHex(){return St(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,r){return this.init(this.ep.precompute(t,r))}toRawBytes(){return this.toBytes()}};function yf(e,t,r={}){if(typeof t!="function")throw new Error('"hash" function param is required');ie(r,{},{adjustScalarBytes:"function",randomBytes:"function",domain:"function",prehash:"function",mapToCurve:"function"});let{prehash:n}=r,{BASE:o,Fp:s,Fn:i}=e,c=r.randomBytes||Oe,a=r.adjustScalarBytes||(_=>_),u=r.domain||((_,C,N)=>{if(Kt(N,"phflag"),C.length||N)throw new Error("Contexts/pre-hash are not supported");return _});function h(_){return i.create(Ft(_))}function f(_){let C=w.secretKey;_=z("private key",_,C);let N=z("hashed private key",t(_),2*C),D=a(N.slice(0,C)),b=N.slice(C,2*C),m=h(D);return{head:D,prefix:b,scalar:m}}function l(_){let{head:C,prefix:N,scalar:D}=f(_),b=o.multiply(D),m=b.toBytes();return{head:C,prefix:N,scalar:D,point:b,pointBytes:m}}function p(_){return l(_).pointBytes}function d(_=Uint8Array.of(),...C){let N=lt(...C);return h(t(u(N,z("context",_),!!n)))}function x(_,C,N={}){_=z("message",_),n&&(_=n(_));let{prefix:D,scalar:b,pointBytes:m}=l(C),g=d(N.context,D,_),S=o.multiply(g).toBytes(),A=d(N.context,S,m,_),L=i.create(g+A*b);if(!i.isValid(L))throw new Error("sign failed: invalid s");let I=lt(S,i.toBytes(L));return xt(I,w.signature,"result")}let E={zip215:!0};function y(_,C,N,D=E){let{context:b,zip215:m}=D,g=w.signature;_=z("signature",_,g),C=z("message",C),N=z("publicKey",N,w.publicKey),m!==void 0&&Kt(m,"zip215"),n&&(C=n(C));let S=g/2,A=_.subarray(0,S),L=Ft(_.subarray(S,g)),I,B,R;try{I=e.fromBytes(N,m),B=e.fromBytes(A,m),R=o.multiplyUnsafe(L)}catch{return!1}if(!m&&I.isSmallOrder())return!1;let U=d(b,B.toBytes(),I.toBytes(),C);return B.add(I.multiplyUnsafe(U)).subtract(R).clearCofactor().is0()}let v=s.BYTES,w={secretKey:v,publicKey:v,signature:2*v,seed:v};function T(_=c(w.seed)){return xt(_,w.seed,"seed")}function P(_){let C=O.randomSecretKey(_);return{secretKey:C,publicKey:p(C)}}function M(_){return Ut(_)&&_.length===i.BYTES}function k(_,C){try{return!!e.fromBytes(_,C)}catch{return!1}}let O={getExtendedPublicKey:l,randomSecretKey:T,isValidSecretKey:M,isValidPublicKey:k,toMontgomery(_){let{y:C}=e.fromBytes(_),N=w.publicKey,D=N===32;if(!D&&N!==57)throw new Error("only defined for 25519 and 448");let b=D?s.div(nt+C,nt-C):s.div(C-nt,C+nt);return s.toBytes(b)},toMontgomeryPriv(_){let C=w.secretKey;xt(_,C);let N=t(_.subarray(0,C));return a(N).subarray(0,C)},randomPrivateKey:T,precompute(_=8,C=e.BASE){return C.precompute(_,!1)}};return Object.freeze({keygen:P,getPublicKey:p,sign:x,verify:y,utils:O,Point:e,lengths:w})}function bf(e){let t={a:e.a,d:e.d,p:e.Fp.ORDER,n:e.n,h:e.h,Gx:e.Gx,Gy:e.Gy},r=e.Fp,n=wt(t.n,e.nBitLength,!0),o={Fp:r,Fn:n,uvRatio:e.uvRatio},s={randomBytes:e.randomBytes,adjustScalarBytes:e.adjustScalarBytes,domain:e.domain,prehash:e.prehash,mapToCurve:e.mapToCurve};return{CURVE:t,curveOpts:o,hash:e.hash,eddsaOpts:s}}function xf(e,t){let r=t.Point;return Object.assign({},t,{ExtendedPoint:r,CURVE:e,nBitLength:r.Fn.BITS,nByteLength:r.Fn.BYTES})}function ia(e){let{CURVE:t,curveOpts:r,hash:n,eddsaOpts:o}=bf(e),s=gf(t,r),i=yf(s,n,o);return xf(e,i)}var wf=BigInt(0),Vt=BigInt(1),aa=BigInt(2),Qp=BigInt(3),Ef=BigInt(5),_f=BigInt(8),Fe=BigInt("0x7fffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffed"),br={p:Fe,n:BigInt("0x1000000000000000000000000000000014def9dea2f79cd65812631a5cf5d3ed"),h:_f,a:BigInt("0x7fffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffec"),d:BigInt("0x52036cee2b6ffe738cc740797779e89800700a4d4141d8ab75eb4dca135978a3"),Gx:BigInt("0x216936d3cd6e53fec0a4e231fdd6dc5c692cc7609525a7b2c9562d608f25d51a"),Gy:BigInt("0x6666666666666666666666666666666666666666666666666666666666666658")};function Sf(e){let t=BigInt(10),r=BigInt(20),n=BigInt(40),o=BigInt(80),s=Fe,c=e*e%s*e%s,a=$(c,aa,s)*c%s,u=$(a,Vt,s)*e%s,h=$(u,Ef,s)*u%s,f=$(h,t,s)*h%s,l=$(f,r,s)*f%s,p=$(l,n,s)*l%s,d=$(p,o,s)*p%s,x=$(d,o,s)*p%s,E=$(x,t,s)*h%s;return{pow_p_5_8:$(E,aa,s)*e%s,b2:c}}function vf(e){return e[0]&=248,e[31]&=127,e[31]|=64,e}var Mo=BigInt("19681161376707505956807079304988542015446066515923890162744021073123829784752");function zo(e,t){let r=Fe,n=Q(t*t*t,r),o=Q(n*n*t,r),s=Sf(e*o).pow_p_5_8,i=Q(e*n*s,r),c=Q(t*i*i,r),a=i,u=Q(i*Mo,r),h=c===e,f=c===Q(-e,r),l=c===Q(-e*Mo,r);return h&&(i=a),(f||l)&&(i=u),zt(i,r)&&(i=Q(-i,r)),{isValid:h||f,value:i}}var ce=wt(br.p,{isLE:!0}),Af=wt(br.n,{isLE:!0}),If={...br,Fp:ce,hash:Ki,adjustScalarBytes:vf,uvRatio:zo},Ht=ia(If);var Ko=Mo,Bf=BigInt("25063068953384623474111414158702152701244531502492656460079210482610430750235"),Tf=BigInt("54469307008909316920995813868745141605393597292927456921205312896311721017578"),Cf=BigInt("1159843021668779879193775521855586647937357759715417654439879720876111806838"),Df=BigInt("40440834346308536858101042469323190826248399146238708352240133220865137265952"),ca=e=>zo(Vt,e),Lf=BigInt("0x7fffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffff"),Fo=e=>Ht.Point.Fp.create(Ft(e)&Lf);function ua(e){let{d:t}=br,r=Fe,n=y=>ce.create(y),o=n(Ko*e*e),s=n((o+Vt)*Cf),i=BigInt(-1),c=n((i-t*o)*n(o+t)),{isValid:a,value:u}=zo(s,c),h=n(u*e);zt(h,r)||(h=n(-h)),a||(u=h),a||(i=o);let f=n(i*(o-Vt)*Df-c),l=u*u,p=n((u+u)*c),d=n(f*Bf),x=n(Vt-l),E=n(Vt+l);return new Ht.Point(n(p*E),n(x*d),n(d*E),n(p*x))}function Pf(e){mt(e,64);let t=Fo(e.subarray(0,32)),r=ua(t),n=Fo(e.subarray(32,64)),o=ua(n);return new jt(r.add(o))}var jt=class e extends Wr{constructor(t){super(t)}static fromAffine(t){return new e(Ht.Point.fromAffine(t))}assertSame(t){if(!(t instanceof e))throw new Error("RistrettoPoint expected")}init(t){return new e(t)}static hashToCurve(t){return Pf(z("ristrettoHash",t,64))}static fromBytes(t){mt(t,32);let{a:r,d:n}=br,o=Fe,s=T=>ce.create(T),i=Fo(t);if(!zi(ce.toBytes(i),t)||zt(i,o))throw new Error("invalid ristretto255 encoding 1");let c=s(i*i),a=s(Vt+r*c),u=s(Vt-r*c),h=s(a*a),f=s(u*u),l=s(r*n*h-f),{isValid:p,value:d}=ca(s(l*f)),x=s(d*u),E=s(d*x*l),y=s((i+i)*x);zt(y,o)&&(y=s(-y));let v=s(a*E),w=s(y*v);if(!p||zt(w,o)||v===wf)throw new Error("invalid ristretto255 encoding 2");return new e(new Ht.Point(y,v,Vt,w))}static fromHex(t){return e.fromBytes(z("ristrettoHex",t,32))}static msm(t,r){return Ke(e,Ht.Point.Fn,t,r)}toBytes(){let{X:t,Y:r,Z:n,T:o}=this.ep,s=Fe,i=E=>ce.create(E),c=i(i(n+r)*i(n-r)),a=i(t*r),u=i(a*a),{value:h}=ca(i(c*u)),f=i(h*c),l=i(h*a),p=i(f*l*o),d;if(zt(o*p,s)){let E=i(r*Ko),y=i(t*Ko);t=E,r=y,d=i(f*Tf)}else d=l;zt(t*p,s)&&(r=i(-r));let x=i((n-r)*d);return zt(x,s)&&(x=i(-x)),ce.toBytes(x)}equals(t){this.assertSame(t);let{X:r,Y:n}=this.ep,{X:o,Y:s}=t.ep,i=u=>ce.create(u),c=i(r*s)===i(n*o),a=i(n*s)===i(r*o);return c||a}is0(){return this.equals(e.ZERO)}};jt.BASE=new jt(Ht.Point.BASE);jt.ZERO=new jt(Ht.Point.ZERO);jt.Fp=ce;jt.Fn=Af;var xr=class extends Error{constructor(t="An error occurred while verifying a message"){super(t),this.name="VerificationError"}},Yr=class extends Error{constructor(t="Missing Web Crypto API"){super(t),this.name="WebCryptoMissingError"}};var fa={get(e=globalThis){let t=e.crypto;if(t?.subtle==null)throw new Yr("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=fa;var Jr=32;var qo,Rf=(async()=>{try{return await Qr.get().subtle.generateKey({name:"Ed25519"},!0,["sign","verify"]),!0}catch{return!1}})();async function Of(e,t,r){if(e.buffer instanceof ArrayBuffer){let n=await Qr.get().subtle.importKey("raw",e.buffer,{name:"Ed25519"},!1,["verify"]);return await Qr.get().subtle.verify({name:"Ed25519"},n,t,r instanceof Uint8Array?r:r.subarray())}throw new TypeError("WebCrypto does not support SharedArrayBuffer for Ed25519 keys")}function Nf(e,t,r){return Ht.verify(t,r instanceof Uint8Array?r:r.subarray(),e)}async function la(e,t,r){return qo==null&&(qo=await Rf),qo?Of(e,t,r):Nf(e,t,r)}function tn(e){return e==null?!1:typeof e.then=="function"&&typeof e.catch=="function"&&typeof e.finally=="function"}var en=class{type="Ed25519";raw;constructor(t){this.raw=Vo(t,Jr)}toMultihash(){return vt.digest(Le(this))}toCID(){return et.createV1(114,this.toMultihash())}toString(){return G.encode(this.toMultihash().bytes).substring(1)}equals(t){return t==null||!(t.raw instanceof Uint8Array)?!1:ft(this.raw,t.raw)}verify(t,r,n){n?.signal?.throwIfAborted();let o=la(this.raw,r,t);return tn(o)?o.then(s=>(n?.signal?.throwIfAborted(),s)):o}};function da(e){return e=Vo(e,Jr),new en(e)}function Vo(e,t){if(e=Uint8Array.from(e??[]),e.length!==t)throw new Pt(`Key must be a Uint8Array of length ${t}, got ${e.length}`);return e}var kf=Math.pow(2,7),Mf=Math.pow(2,14),Kf=Math.pow(2,21),Ho=Math.pow(2,28),jo=Math.pow(2,35),$o=Math.pow(2,42),Go=Math.pow(2,49),F=128,ct=127;function gt(e){if(e<kf)return 1;if(e<Mf)return 2;if(e<Kf)return 3;if(e<Ho)return 4;if(e<jo)return 5;if(e<$o)return 6;if(e<Go)return 7;if(Number.MAX_SAFE_INTEGER!=null&&e>Number.MAX_SAFE_INTEGER)throw new RangeError("Could not encode varint");return 8}function ze(e,t,r=0){switch(gt(e)){case 8:t[r++]=e&255|F,e/=128;case 7:t[r++]=e&255|F,e/=128;case 6:t[r++]=e&255|F,e/=128;case 5:t[r++]=e&255|F,e/=128;case 4:t[r++]=e&255|F,e>>>=7;case 3:t[r++]=e&255|F,e>>>=7;case 2:t[r++]=e&255|F,e>>>=7;case 1:{t[r++]=e&255,e>>>=7;break}default:throw new Error("unreachable")}return t}function Ff(e,t,r=0){switch(gt(e)){case 8:t.set(r++,e&255|F),e/=128;case 7:t.set(r++,e&255|F),e/=128;case 6:t.set(r++,e&255|F),e/=128;case 5:t.set(r++,e&255|F),e/=128;case 4:t.set(r++,e&255|F),e>>>=7;case 3:t.set(r++,e&255|F),e>>>=7;case 2:t.set(r++,e&255|F),e>>>=7;case 1:{t.set(r++,e&255),e>>>=7;break}default:throw new Error("unreachable")}return t}function Zo(e,t){let r=e[t],n=0;if(n+=r&ct,r<F||(r=e[t+1],n+=(r&ct)<<7,r<F)||(r=e[t+2],n+=(r&ct)<<14,r<F)||(r=e[t+3],n+=(r&ct)<<21,r<F)||(r=e[t+4],n+=(r&ct)*Ho,r<F)||(r=e[t+5],n+=(r&ct)*jo,r<F)||(r=e[t+6],n+=(r&ct)*$o,r<F)||(r=e[t+7],n+=(r&ct)*Go,r<F))return n;throw new RangeError("Could not decode varint")}function zf(e,t){let r=e.get(t),n=0;if(n+=r&ct,r<F||(r=e.get(t+1),n+=(r&ct)<<7,r<F)||(r=e.get(t+2),n+=(r&ct)<<14,r<F)||(r=e.get(t+3),n+=(r&ct)<<21,r<F)||(r=e.get(t+4),n+=(r&ct)*Ho,r<F)||(r=e.get(t+5),n+=(r&ct)*jo,r<F)||(r=e.get(t+6),n+=(r&ct)*$o,r<F)||(r=e.get(t+7),n+=(r&ct)*Go,r<F))return n;throw new RangeError("Could not decode varint")}function pa(e,t,r=0){return t==null&&(t=pt(gt(e))),t instanceof Uint8Array?ze(e,t,r):Ff(e,t,r)}function wr(e,t=0){return e instanceof Uint8Array?Zo(e,t):zf(e,t)}var Xo=new Float32Array([-0]),ue=new Uint8Array(Xo.buffer);function ga(e,t,r){Xo[0]=e,t[r]=ue[0],t[r+1]=ue[1],t[r+2]=ue[2],t[r+3]=ue[3]}function ya(e,t){return ue[0]=e[t],ue[1]=e[t+1],ue[2]=e[t+2],ue[3]=e[t+3],Xo[0]}var Wo=new Float64Array([-0]),ut=new Uint8Array(Wo.buffer);function ba(e,t,r){Wo[0]=e,t[r]=ut[0],t[r+1]=ut[1],t[r+2]=ut[2],t[r+3]=ut[3],t[r+4]=ut[4],t[r+5]=ut[5],t[r+6]=ut[6],t[r+7]=ut[7]}function xa(e,t){return ut[0]=e[t],ut[1]=e[t+1],ut[2]=e[t+2],ut[3]=e[t+3],ut[4]=e[t+4],ut[5]=e[t+5],ut[6]=e[t+6],ut[7]=e[t+7],Wo[0]}var qf=BigInt(Number.MAX_SAFE_INTEGER),Vf=BigInt(Number.MIN_SAFE_INTEGER),Et=class e{lo;hi;constructor(t,r){this.lo=t|0,this.hi=r|0}toNumber(t=!1){if(!t&&this.hi>>>31>0){let r=~this.lo+1>>>0,n=~this.hi>>>0;return r===0&&(n=n+1>>>0),-(r+n*4294967296)}return this.lo+this.hi*4294967296}toBigInt(t=!1){if(t)return BigInt(this.lo>>>0)+(BigInt(this.hi>>>0)<<32n);if(this.hi>>>31){let r=~this.lo+1>>>0,n=~this.hi>>>0;return r===0&&(n=n+1>>>0),-(BigInt(r)+(BigInt(n)<<32n))}return BigInt(this.lo>>>0)+(BigInt(this.hi>>>0)<<32n)}toString(t=!1){return this.toBigInt(t).toString()}zzEncode(){let t=this.hi>>31;return this.hi=((this.hi<<1|this.lo>>>31)^t)>>>0,this.lo=(this.lo<<1^t)>>>0,this}zzDecode(){let t=-(this.lo&1);return this.lo=((this.lo>>>1|this.hi<<31)^t)>>>0,this.hi=(this.hi>>>1^t)>>>0,this}length(){let t=this.lo,r=(this.lo>>>28|this.hi<<4)>>>0,n=this.hi>>>24;return n===0?r===0?t<16384?t<128?1:2:t<2097152?3:4:r<16384?r<128?5:6:r<2097152?7:8:n<128?9:10}static fromBigInt(t){if(t===0n)return be;if(t<qf&&t>Vf)return this.fromNumber(Number(t));let r=t<0n;r&&(t=-t);let n=t>>32n,o=t-(n<<32n);return r&&(n=~n|0n,o=~o|0n,++o>wa&&(o=0n,++n>wa&&(n=0n))),new e(Number(o),Number(n))}static fromNumber(t){if(t===0)return be;let r=t<0;r&&(t=-t);let n=t>>>0,o=(t-n)/4294967296>>>0;return r&&(o=~o>>>0,n=~n>>>0,++n>4294967295&&(n=0,++o>4294967295&&(o=0))),new e(n,o)}static from(t){return typeof t=="number"?e.fromNumber(t):typeof t=="bigint"?e.fromBigInt(t):typeof t=="string"?e.fromBigInt(BigInt(t)):t.low!=null||t.high!=null?new e(t.low>>>0,t.high>>>0):be}},be=new Et(0,0);be.toBigInt=function(){return 0n};be.zzEncode=be.zzDecode=function(){return this};be.length=function(){return 1};var wa=4294967296n;function Ea(e){let t=0,r=0;for(let n=0;n<e.length;++n)r=e.charCodeAt(n),r<128?t+=1:r<2048?t+=2:(r&64512)===55296&&(e.charCodeAt(n+1)&64512)===56320?(++n,t+=4):t+=3;return t}function _a(e,t,r){if(r-t<1)return"";let o,s=[],i=0,c;for(;t<r;)c=e[t++],c<128?s[i++]=c:c>191&&c<224?s[i++]=(c&31)<<6|e[t++]&63:c>239&&c<365?(c=((c&7)<<18|(e[t++]&63)<<12|(e[t++]&63)<<6|e[t++]&63)-65536,s[i++]=55296+(c>>10),s[i++]=56320+(c&1023)):s[i++]=(c&15)<<12|(e[t++]&63)<<6|e[t++]&63,i>8191&&((o??(o=[])).push(String.fromCharCode.apply(String,s)),i=0);return o!=null?(i>0&&o.push(String.fromCharCode.apply(String,s.slice(0,i))),o.join("")):String.fromCharCode.apply(String,s.slice(0,i))}function Yo(e,t,r){let n=r,o,s;for(let i=0;i<e.length;++i)o=e.charCodeAt(i),o<128?t[r++]=o:o<2048?(t[r++]=o>>6|192,t[r++]=o&63|128):(o&64512)===55296&&((s=e.charCodeAt(i+1))&64512)===56320?(o=65536+((o&1023)<<10)+(s&1023),++i,t[r++]=o>>18|240,t[r++]=o>>12&63|128,t[r++]=o>>6&63|128,t[r++]=o&63|128):(t[r++]=o>>12|224,t[r++]=o>>6&63|128,t[r++]=o&63|128);return r-n}function Bt(e,t){return RangeError(`index out of range: ${e.pos} + ${t??1} > ${e.len}`)}function rn(e,t){return(e[t-4]|e[t-3]<<8|e[t-2]<<16|e[t-1]<<24)>>>0}var Qo=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,Bt(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 Bt(this,4);return rn(this.buf,this.pos+=4)}sfixed32(){if(this.pos+4>this.len)throw Bt(this,4);return rn(this.buf,this.pos+=4)|0}float(){if(this.pos+4>this.len)throw Bt(this,4);let t=ya(this.buf,this.pos);return this.pos+=4,t}double(){if(this.pos+8>this.len)throw Bt(this,4);let t=xa(this.buf,this.pos);return this.pos+=8,t}bytes(){let t=this.uint32(),r=this.pos,n=this.pos+t;if(n>this.len)throw Bt(this,t);return this.pos+=t,r===n?new Uint8Array(0):this.buf.subarray(r,n)}string(){let t=this.bytes();return _a(t,0,t.length)}skip(t){if(typeof t=="number"){if(this.pos+t>this.len)throw Bt(this,t);this.pos+=t}else do if(this.pos>=this.len)throw Bt(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 Et(0,0),r=0;if(this.len-this.pos>4){for(;r<4;++r)if(t.lo=(t.lo|(this.buf[this.pos]&127)<<r*7)>>>0,this.buf[this.pos++]<128)return t;if(t.lo=(t.lo|(this.buf[this.pos]&127)<<28)>>>0,t.hi=(t.hi|(this.buf[this.pos]&127)>>4)>>>0,this.buf[this.pos++]<128)return t;r=0}else{for(;r<3;++r){if(this.pos>=this.len)throw Bt(this);if(t.lo=(t.lo|(this.buf[this.pos]&127)<<r*7)>>>0,this.buf[this.pos++]<128)return t}return t.lo=(t.lo|(this.buf[this.pos++]&127)<<r*7)>>>0,t}if(this.len-this.pos>4){for(;r<5;++r)if(t.hi=(t.hi|(this.buf[this.pos]&127)<<r*7+3)>>>0,this.buf[this.pos++]<128)return t}else for(;r<5;++r){if(this.pos>=this.len)throw Bt(this);if(t.hi=(t.hi|(this.buf[this.pos]&127)<<r*7+3)>>>0,this.buf[this.pos++]<128)return t}throw Error("invalid varint encoding")}readFixed64(){if(this.pos+8>this.len)throw Bt(this,8);let t=rn(this.buf,this.pos+=4),r=rn(this.buf,this.pos+=4);return new Et(t,r)}int64(){return this.readLongVarint().toBigInt()}int64Number(){return this.readLongVarint().toNumber()}int64String(){return this.readLongVarint().toString()}uint64(){return this.readLongVarint().toBigInt(!0)}uint64Number(){let t=Zo(this.buf,this.pos);return this.pos+=gt(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 Jo(e){return new Qo(e instanceof Uint8Array?e:e.subarray())}function $t(e,t,r){let n=Jo(e);return t.decode(n,void 0,r)}function ts(e){let t=e??8192,r=t>>>1,n,o=t;return function(i){if(i<1||i>r)return pt(i);o+i>t&&(n=pt(t),o=0);let c=n.subarray(o,o+=i);return(o&7)!==0&&(o=(o|7)+1),c}}var xe=class{fn;len;next;val;constructor(t,r,n){this.fn=t,this.len=r,this.next=void 0,this.val=n}};function es(){}var ns=class{head;tail;len;next;constructor(t){this.head=t.head,this.tail=t.tail,this.len=t.len,this.next=t.states}},Hf=ts();function jf(e){return globalThis.Buffer!=null?pt(e):Hf(e)}var _r=class{len;head;tail;states;constructor(){this.len=0,this.head=new xe(es,0,0),this.tail=this.head,this.states=null}_push(t,r,n){return this.tail=this.tail.next=new xe(t,r,n),this.len+=r,this}uint32(t){return this.len+=(this.tail=this.tail.next=new os((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,Et.fromNumber(t)):this.uint32(t)}sint32(t){return this.uint32((t<<1^t>>31)>>>0)}uint64(t){let r=Et.fromBigInt(t);return this._push(nn,r.length(),r)}uint64Number(t){return this._push(ze,gt(t),t)}uint64String(t){return this.uint64(BigInt(t))}int64(t){return this.uint64(t)}int64Number(t){return this.uint64Number(t)}int64String(t){return this.uint64String(t)}sint64(t){let r=Et.fromBigInt(t).zzEncode();return this._push(nn,r.length(),r)}sint64Number(t){let r=Et.fromNumber(t).zzEncode();return this._push(nn,r.length(),r)}sint64String(t){return this.sint64(BigInt(t))}bool(t){return this._push(rs,1,t?1:0)}fixed32(t){return this._push(Er,4,t>>>0)}sfixed32(t){return this.fixed32(t)}fixed64(t){let r=Et.fromBigInt(t);return this._push(Er,4,r.lo)._push(Er,4,r.hi)}fixed64Number(t){let r=Et.fromNumber(t);return this._push(Er,4,r.lo)._push(Er,4,r.hi)}fixed64String(t){return this.fixed64(BigInt(t))}sfixed64(t){return this.fixed64(t)}sfixed64Number(t){return this.fixed64Number(t)}sfixed64String(t){return this.fixed64String(t)}float(t){return this._push(ga,4,t)}double(t){return this._push(ba,8,t)}bytes(t){let r=t.length>>>0;return r===0?this._push(rs,1,0):this.uint32(r)._push(Gf,r,t)}string(t){let r=Ea(t);return r!==0?this.uint32(r)._push(Yo,r,t):this._push(rs,1,0)}fork(){return this.states=new ns(this),this.head=this.tail=new xe(es,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 xe(es,0,0),this.len=0),this}ldelim(){let t=this.head,r=this.tail,n=this.len;return this.reset().uint32(n),n!==0&&(this.tail.next=t.next,this.tail=r,this.len+=n),this}finish(){let t=this.head.next,r=jf(this.len),n=0;for(;t!=null;)t.fn(t.val,r,n),n+=t.len,t=t.next;return r}};function rs(e,t,r){t[r]=e&255}function $f(e,t,r){for(;e>127;)t[r++]=e&127|128,e>>>=7;t[r]=e}var os=class extends xe{next;constructor(t,r){super($f,t,r),this.next=void 0}};function nn(e,t,r){for(;e.hi!==0;)t[r++]=e.lo&127|128,e.lo=(e.lo>>>7|e.hi<<25)>>>0,e.hi>>>=7;for(;e.lo>127;)t[r++]=e.lo&127|128,e.lo=e.lo>>>7;t[r++]=e.lo}function Er(e,t,r){t[r]=e&255,t[r+1]=e>>>8&255,t[r+2]=e>>>16&255,t[r+3]=e>>>24}function Gf(e,t,r){t.set(e,r)}globalThis.Buffer!=null&&(_r.prototype.bytes=function(e){let t=e.length>>>0;return this.uint32(t),t>0&&this._push(Zf,t,e),this},_r.prototype.string=function(e){let t=globalThis.Buffer.byteLength(e);return this.uint32(t),t>0&&this._push(Xf,t,e),this});function Zf(e,t,r){t.set(e,r)}function Xf(e,t,r){e.length<40?Yo(e,t,r):t.utf8Write!=null?t.utf8Write(e,r):t.set(V(e),r)}function ss(){return new _r}function Gt(e,t){let r=ss();return t.encode(e,r,{lengthDelimited:!1}),r.finish()}var qe;(function(e){e[e.VARINT=0]="VARINT",e[e.BIT64=1]="BIT64",e[e.LENGTH_DELIMITED=2]="LENGTH_DELIMITED",e[e.START_GROUP=3]="START_GROUP",e[e.END_GROUP=4]="END_GROUP",e[e.BIT32=5]="BIT32"})(qe||(qe={}));function on(e,t,r,n){return{name:e,type:t,encode:r,decode:n}}function Ve(e){function t(o){if(e[o.toString()]==null)throw new Error("Invalid enum value");return e[o]}let r=function(s,i){let c=t(s);i.int32(c)},n=function(s){let i=s.int32();return t(i)};return on("enum",qe.VARINT,r,n)}function Zt(e,t){return on("message",qe.LENGTH_DELIMITED,e,t)}var sn=class extends Error{code="ERR_MAX_LENGTH";name="MaxLengthError"};var _t;(function(e){e.RSA="RSA",e.Ed25519="Ed25519",e.secp256k1="secp256k1",e.ECDSA="ECDSA"})(_t||(_t={}));var is;(function(e){e[e.RSA=0]="RSA",e[e.Ed25519=1]="Ed25519",e[e.secp256k1=2]="secp256k1",e[e.ECDSA=3]="ECDSA"})(is||(is={}));(function(e){e.codec=()=>Ve(is)})(_t||(_t={}));var Sr;(function(e){let t;e.codec=()=>(t==null&&(t=Zt((r,n,o={})=>{o.lengthDelimited!==!1&&n.fork(),r.Type!=null&&(n.uint32(8),_t.codec().encode(r.Type,n)),r.Data!=null&&(n.uint32(18),n.bytes(r.Data)),o.lengthDelimited!==!1&&n.ldelim()},(r,n,o={})=>{let s={},i=n==null?r.len:r.pos+n;for(;r.pos<i;){let c=r.uint32();switch(c>>>3){case 1:{s.Type=_t.codec().decode(r);break}case 2:{s.Data=r.bytes();break}default:{r.skipType(c&7);break}}}return s})),t),e.encode=r=>Gt(r,e.codec()),e.decode=(r,n)=>$t(r,e.codec(),n)})(Sr||(Sr={}));var as;(function(e){let t;e.codec=()=>(t==null&&(t=Zt((r,n,o={})=>{o.lengthDelimited!==!1&&n.fork(),r.Type!=null&&(n.uint32(8),_t.codec().encode(r.Type,n)),r.Data!=null&&(n.uint32(18),n.bytes(r.Data)),o.lengthDelimited!==!1&&n.ldelim()},(r,n,o={})=>{let s={},i=n==null?r.len:r.pos+n;for(;r.pos<i;){let c=r.uint32();switch(c>>>3){case 1:{s.Type=_t.codec().decode(r);break}case 2:{s.Data=r.bytes();break}default:{r.skipType(c&7);break}}}return s})),t),e.encode=r=>Gt(r,e.codec()),e.decode=(r,n)=>$t(r,e.codec(),n)})(as||(as={}));var an=class extends Pe{constructor(t,r){super(),this.finished=!1,this.destroyed=!1,Vr(t);let n=fr(r);if(this.iHash=t.create(),typeof this.iHash.update!="function")throw new Error("Expected instance of class which extends utils.Hash");this.blockLen=this.iHash.blockLen,this.outputLen=this.iHash.outputLen;let o=this.blockLen,s=new Uint8Array(o);s.set(n.length>o?t.create().update(n).digest():n);for(let i=0;i<s.length;i++)s[i]^=54;this.iHash.update(s),this.oHash=t.create();for(let i=0;i<s.length;i++)s[i]^=106;this.oHash.update(s),kt(s)}update(t){return Re(this),this.iHash.update(t),this}digestInto(t){Re(this),mt(t,this.outputLen),this.finished=!0,this.iHash.digestInto(t),this.oHash.update(t),this.oHash.digestInto(t),this.destroy()}digest(){let t=new Uint8Array(this.oHash.outputLen);return this.digestInto(t),t}_cloneInto(t){t||(t=Object.create(Object.getPrototypeOf(this),{}));let{oHash:r,iHash:n,finished:o,destroyed:s,blockLen:i,outputLen:c}=this;return t=t,t.finished=o,t.destroyed=s,t.blockLen=i,t.outputLen=c,t.oHash=r._cloneInto(t.oHash),t.iHash=n._cloneInto(t.iHash),t}clone(){return this._cloneInto()}destroy(){this.destroyed=!0,this.oHash.destroy(),this.iHash.destroy()}},cs=(e,t,r)=>new an(e,t).update(r).digest();cs.create=(e,t)=>new an(e,t);var va=(e,t)=>(e+(e>=0?t:-t)/Aa)/t;function Yf(e,t,r){let[[n,o],[s,i]]=t,c=va(i*e,r),a=va(-o*e,r),u=e-c*n-a*s,h=-c*o-a*i,f=u<Wt,l=h<Wt;f&&(u=-u),l&&(h=-h);let p=se(Math.ceil(Gr(r)/2))+je;if(u<Wt||u>=p||h<Wt||h>=p)throw new Error("splitScalar (endomorphism): failed, k="+e);return{k1neg:f,k1:u,k2neg:l,k2:h}}function fs(e){if(!["compact","recovered","der"].includes(e))throw new Error('Signature format must be "compact", "recovered", or "der"');return e}function us(e,t){let r={};for(let n of Object.keys(t))r[n]=e[n]===void 0?t[n]:e[n];return Kt(r.lowS,"lowS"),Kt(r.prehash,"prehash"),r.format!==void 0&&fs(r.format),r}var ls=class extends Error{constructor(t=""){super(t)}},Xt={Err:ls,_tlv:{encode:(e,t)=>{let{Err:r}=Xt;if(e<0||e>256)throw new r("tlv.encode: wrong tag");if(t.length&1)throw new r("tlv.encode: unpadded data");let n=t.length/2,o=pr(n);if(o.length/2&128)throw new r("tlv.encode: long form length too big");let s=n>127?pr(o.length/2|128):"";return pr(e)+s+o+t},decode(e,t){let{Err:r}=Xt,n=0;if(e<0||e>256)throw new r("tlv.encode: wrong tag");if(t.length<2||t[n++]!==e)throw new r("tlv.decode: wrong tlv");let o=t[n++],s=!!(o&128),i=0;if(!s)i=o;else{let a=o&127;if(!a)throw new r("tlv.decode(long): indefinite length not supported");if(a>4)throw new r("tlv.decode(long): byte length is too big");let u=t.subarray(n,n+a);if(u.length!==a)throw new r("tlv.decode: length bytes not complete");if(u[0]===0)throw new r("tlv.decode(long): zero leftmost byte");for(let h of u)i=i<<8|h;if(n+=a,i<128)throw new r("tlv.decode(long): not minimal encoding")}let c=t.subarray(n,n+i);if(c.length!==i)throw new r("tlv.decode: wrong value length");return{v:c,l:t.subarray(n+i)}}},_int:{encode(e){let{Err:t}=Xt;if(e<Wt)throw new t("integer: negative integers are not allowed");let r=pr(e);if(Number.parseInt(r[0],16)&8&&(r="00"+r),r.length&1)throw new t("unexpected DER parsing assertion: unpadded hex");return r},decode(e){let{Err:t}=Xt;if(e[0]&128)throw new t("invalid signature integer: negative");if(e[0]===0&&!(e[1]&128))throw new t("invalid signature integer: unnecessary leading zero");return Ne(e)}},toSig(e){let{Err:t,_int:r,_tlv:n}=Xt,o=z("signature",e),{v:s,l:i}=n.decode(48,o);if(i.length)throw new t("invalid signature: left bytes after parsing");let{v:c,l:a}=n.decode(2,s),{v:u,l:h}=n.decode(2,a);if(h.length)throw new t("invalid signature: left bytes after parsing");return{r:r.decode(c),s:r.decode(u)}},hexFromSig(e){let{_tlv:t,_int:r}=Xt,n=t.encode(2,r.encode(e.r)),o=t.encode(2,r.encode(e.s)),s=n+o;return t.encode(48,s)}},Wt=BigInt(0),je=BigInt(1),Aa=BigInt(2),cn=BigInt(3),Qf=BigInt(4);function He(e,t){let{BYTES:r}=e,n;if(typeof t=="bigint")n=t;else{let o=z("private key",t);try{n=e.fromBytes(o)}catch{throw new Error(`invalid private key: expected ui8a of size ${r}, got ${typeof t}`)}}if(!e.isValidNot0(n))throw new Error("invalid private key: out of range [1..N-1]");return n}function Jf(e,t={}){let r=Xr("weierstrass",e,t),{Fp:n,Fn:o}=r,s=r.CURVE,{h:i,n:c}=s;ie(t,{},{allowInfinityPoint:"boolean",clearCofactor:"function",isTorsionFree:"function",fromBytes:"function",toBytes:"function",endo:"object",wrapPrivateKey:"boolean"});let{endo:a}=t;if(a&&(!n.is0(s.a)||typeof a.beta!="bigint"||!Array.isArray(a.basises)))throw new Error('invalid endo: expected "beta": bigint and "basises": array');let u=Ba(n,o);function h(){if(!n.isOdd)throw new Error("compression is not supported: Field does not have .isOdd()")}function f(D,b,m){let{x:g,y:S}=b.toAffine(),A=n.toBytes(g);if(Kt(m,"isCompressed"),m){h();let L=!n.isOdd(S);return lt(Ia(L),A)}else return lt(Uint8Array.of(4),A,n.toBytes(S))}function l(D){xt(D,void 0,"Point");let{publicKey:b,publicKeyUncompressed:m}=u,g=D.length,S=D[0],A=D.subarray(1);if(g===b&&(S===2||S===3)){let L=n.fromBytes(A);if(!n.isValid(L))throw new Error("bad point: is not on curve, wrong x");let I=x(L),B;try{B=n.sqrt(I)}catch(Z){let q=Z instanceof Error?": "+Z.message:"";throw new Error("bad point: is not on curve, sqrt error"+q)}h();let R=n.isOdd(B);return(S&1)===1!==R&&(B=n.neg(B)),{x:L,y:B}}else if(g===m&&S===4){let L=n.BYTES,I=n.fromBytes(A.subarray(0,L)),B=n.fromBytes(A.subarray(L,L*2));if(!E(I,B))throw new Error("bad point: is not on curve");return{x:I,y:B}}else throw new Error(`bad point: got length ${g}, expected compressed=${b} or uncompressed=${m}`)}let p=t.toBytes||f,d=t.fromBytes||l;function x(D){let b=n.sqr(D),m=n.mul(b,D);return n.add(n.add(m,n.mul(D,s.a)),s.b)}function E(D,b){let m=n.sqr(b),g=x(D);return n.eql(m,g)}if(!E(s.Gx,s.Gy))throw new Error("bad curve params: generator point");let y=n.mul(n.pow(s.a,cn),Qf),v=n.mul(n.sqr(s.b),BigInt(27));if(n.is0(n.add(y,v)))throw new Error("bad curve params: a or b");function w(D,b,m=!1){if(!n.isValid(b)||m&&n.is0(b))throw new Error(`bad point coordinate ${D}`);return b}function T(D){if(!(D instanceof _))throw new Error("ProjectivePoint expected")}function P(D){if(!a||!a.basises)throw new Error("no endo");return Yf(D,a.basises,o.ORDER)}let M=Ue((D,b)=>{let{X:m,Y:g,Z:S}=D;if(n.eql(S,n.ONE))return{x:m,y:g};let A=D.is0();b==null&&(b=A?n.ONE:n.inv(S));let L=n.mul(m,b),I=n.mul(g,b),B=n.mul(S,b);if(A)return{x:n.ZERO,y:n.ZERO};if(!n.eql(B,n.ONE))throw new Error("invZ was invalid");return{x:L,y:I}}),k=Ue(D=>{if(D.is0()){if(t.allowInfinityPoint&&!n.is0(D.Y))return;throw new Error("bad point: ZERO")}let{x:b,y:m}=D.toAffine();if(!n.isValid(b)||!n.isValid(m))throw new Error("bad point: x or y not field elements");if(!E(b,m))throw new Error("bad point: equation left != right");if(!D.isTorsionFree())throw new Error("bad point: not in prime-order subgroup");return!0});function O(D,b,m,g,S){return m=new _(n.mul(m.X,D),m.Y,m.Z),b=yr(g,b),m=yr(S,m),b.add(m)}class _{constructor(b,m,g){this.X=w("x",b),this.Y=w("y",m,!0),this.Z=w("z",g),Object.freeze(this)}static CURVE(){return s}static fromAffine(b){let{x:m,y:g}=b||{};if(!b||!n.isValid(m)||!n.isValid(g))throw new Error("invalid affine point");if(b instanceof _)throw new Error("projective point not allowed");return n.is0(m)&&n.is0(g)?_.ZERO:new _(m,g,n.ONE)}static fromBytes(b){let m=_.fromAffine(d(xt(b,void 0,"point")));return m.assertValidity(),m}static fromHex(b){return _.fromBytes(z("pointHex",b))}get x(){return this.toAffine().x}get y(){return this.toAffine().y}precompute(b=8,m=!0){return N.createCache(this,b),m||this.multiply(cn),this}assertValidity(){k(this)}hasEvenY(){let{y:b}=this.toAffine();if(!n.isOdd)throw new Error("Field doesn't support isOdd");return!n.isOdd(b)}equals(b){T(b);let{X:m,Y:g,Z:S}=this,{X:A,Y:L,Z:I}=b,B=n.eql(n.mul(m,I),n.mul(A,S)),R=n.eql(n.mul(g,I),n.mul(L,S));return B&&R}negate(){return new _(this.X,n.neg(this.Y),this.Z)}double(){let{a:b,b:m}=s,g=n.mul(m,cn),{X:S,Y:A,Z:L}=this,I=n.ZERO,B=n.ZERO,R=n.ZERO,U=n.mul(S,S),Z=n.mul(A,A),q=n.mul(L,L),K=n.mul(S,A);return K=n.add(K,K),R=n.mul(S,L),R=n.add(R,R),I=n.mul(b,R),B=n.mul(g,q),B=n.add(I,B),I=n.sub(Z,B),B=n.add(Z,B),B=n.mul(I,B),I=n.mul(K,I),R=n.mul(g,R),q=n.mul(b,q),K=n.sub(U,q),K=n.mul(b,K),K=n.add(K,R),R=n.add(U,U),U=n.add(R,U),U=n.add(U,q),U=n.mul(U,K),B=n.add(B,U),q=n.mul(A,L),q=n.add(q,q),U=n.mul(q,K),I=n.sub(I,U),R=n.mul(q,Z),R=n.add(R,R),R=n.add(R,R),new _(I,B,R)}add(b){T(b);let{X:m,Y:g,Z:S}=this,{X:A,Y:L,Z:I}=b,B=n.ZERO,R=n.ZERO,U=n.ZERO,Z=s.a,q=n.mul(s.b,cn),K=n.mul(m,A),X=n.mul(g,L),J=n.mul(S,I),dt=n.add(m,g),W=n.add(A,L);dt=n.mul(dt,W),W=n.add(K,X),dt=n.sub(dt,W),W=n.add(m,S);let at=n.add(A,I);return W=n.mul(W,at),at=n.add(K,J),W=n.sub(W,at),at=n.add(g,S),B=n.add(L,I),at=n.mul(at,B),B=n.add(X,J),at=n.sub(at,B),U=n.mul(Z,W),B=n.mul(q,J),U=n.add(B,U),B=n.sub(X,U),U=n.add(X,U),R=n.mul(B,U),X=n.add(K,K),X=n.add(X,K),J=n.mul(Z,J),W=n.mul(q,W),X=n.add(X,J),J=n.sub(K,J),J=n.mul(Z,J),W=n.add(W,J),K=n.mul(X,W),R=n.add(R,K),K=n.mul(at,W),B=n.mul(dt,B),B=n.sub(B,K),K=n.mul(dt,X),U=n.mul(at,U),U=n.add(U,K),new _(B,R,U)}subtract(b){return this.add(b.negate())}is0(){return this.equals(_.ZERO)}multiply(b){let{endo:m}=t;if(!o.isValidNot0(b))throw new Error("invalid scalar: out of range");let g,S,A=L=>N.cached(this,L,I=>qt(_,I));if(m){let{k1neg:L,k1:I,k2neg:B,k2:R}=P(b),{p:U,f:Z}=A(I),{p:q,f:K}=A(R);S=Z.add(K),g=O(m.beta,U,q,L,B)}else{let{p:L,f:I}=A(b);g=L,S=I}return qt(_,[g,S])[0]}multiplyUnsafe(b){let{endo:m}=t,g=this;if(!o.isValid(b))throw new Error("invalid scalar: out of range");if(b===Wt||g.is0())return _.ZERO;if(b===je)return g;if(N.hasCache(this))return this.multiply(b);if(m){let{k1neg:S,k1:A,k2neg:L,k2:I}=P(b),{p1:B,p2:R}=sa(_,g,A,I);return O(m.beta,B,R,S,L)}else return N.unsafe(g,b)}multiplyAndAddUnsafe(b,m,g){let S=this.multiplyUnsafe(m).add(b.multiplyUnsafe(g));return S.is0()?void 0:S}toAffine(b){return M(this,b)}isTorsionFree(){let{isTorsionFree:b}=t;return i===je?!0:b?b(_,this):N.unsafe(this,c).is0()}clearCofactor(){let{clearCofactor:b}=t;return i===je?this:b?b(_,this):this.multiplyUnsafe(i)}isSmallOrder(){return this.multiplyUnsafe(i).is0()}toBytes(b=!0){return Kt(b,"isCompressed"),this.assertValidity(),p(_,this,b)}toHex(b=!0){return St(this.toBytes(b))}toString(){return`<Point ${this.is0()?"ZERO":this.toHex()}>`}get px(){return this.X}get py(){return this.X}get pz(){return this.Z}toRawBytes(b=!0){return this.toBytes(b)}_setWindowSize(b){this.precompute(b)}static normalizeZ(b){return qt(_,b)}static msm(b,m){return Ke(_,o,b,m)}static fromPrivateKey(b){return _.BASE.multiply(He(o,b))}}_.BASE=new _(s.Gx,s.Gy,n.ONE),_.ZERO=new _(n.ZERO,n.ONE,n.ZERO),_.Fp=n,_.Fn=o;let C=o.BITS,N=new Me(_,t.endo?Math.ceil(C/2):C);return _.BASE.precompute(8),_}function Ia(e){return Uint8Array.of(e?2:3)}function Ba(e,t){return{secretKey:t.BYTES,publicKey:1+e.BYTES,publicKeyUncompressed:1+2*e.BYTES,publicKeyHasPrefix:!0,signature:2*t.BYTES}}function tl(e,t={}){let{Fn:r}=e,n=t.randomBytes||Oe,o=Object.assign(Ba(e.Fp,r),{seed:Po(r.ORDER)});function s(p){try{return!!He(r,p)}catch{return!1}}function i(p,d){let{publicKey:x,publicKeyUncompressed:E}=o;try{let y=p.length;return d===!0&&y!==x||d===!1&&y!==E?!1:!!e.fromBytes(p)}catch{return!1}}function c(p=n(o.seed)){return Ro(xt(p,o.seed,"seed"),r.ORDER)}function a(p,d=!0){return e.BASE.multiply(He(r,p)).toBytes(d)}function u(p){let d=c(p);return{secretKey:d,publicKey:a(d)}}function h(p){if(typeof p=="bigint")return!1;if(p instanceof e)return!0;let{secretKey:d,publicKey:x,publicKeyUncompressed:E}=o;if(r.allowedLengths||d===x)return;let y=z("key",p).length;return y===x||y===E}function f(p,d,x=!0){if(h(p)===!0)throw new Error("first arg must be private key");if(h(d)===!1)throw new Error("second arg must be public key");let E=He(r,p);return e.fromHex(d).multiply(E).toBytes(x)}return Object.freeze({getPublicKey:a,getSharedSecret:f,keygen:u,Point:e,utils:{isValidSecretKey:s,isValidPublicKey:i,randomSecretKey:c,isValidPrivateKey:s,randomPrivateKey:c,normPrivateKeyToScalar:p=>He(r,p),precompute(p=8,d=e.BASE){return d.precompute(p,!1)}},lengths:o})}function el(e,t,r={}){Vr(t),ie(r,{},{hmac:"function",lowS:"boolean",randomBytes:"function",bits2int:"function",bits2int_modN:"function"});let n=r.randomBytes||Oe,o=r.hmac||((m,...g)=>cs(t,m,lt(...g))),{Fp:s,Fn:i}=e,{ORDER:c,BITS:a}=i,{keygen:u,getPublicKey:h,getSharedSecret:f,utils:l,lengths:p}=tl(e,r),d={prehash:!1,lowS:typeof r.lowS=="boolean"?r.lowS:!1,format:void 0,extraEntropy:!1},x="compact";function E(m){let g=c>>je;return m>g}function y(m,g){if(!i.isValidNot0(g))throw new Error(`invalid signature ${m}: out of range 1..Point.Fn.ORDER`);return g}function v(m,g){fs(g);let S=p.signature,A=g==="compact"?S:g==="recovered"?S+1:void 0;return xt(m,A,`${g} signature`)}class w{constructor(g,S,A){this.r=y("r",g),this.s=y("s",S),A!=null&&(this.recovery=A),Object.freeze(this)}static fromBytes(g,S=x){v(g,S);let A;if(S==="der"){let{r:R,s:U}=Xt.toSig(xt(g));return new w(R,U)}S==="recovered"&&(A=g[0],S="compact",g=g.subarray(1));let L=i.BYTES,I=g.subarray(0,L),B=g.subarray(L,L*2);return new w(i.fromBytes(I),i.fromBytes(B),A)}static fromHex(g,S){return this.fromBytes(de(g),S)}addRecoveryBit(g){return new w(this.r,this.s,g)}recoverPublicKey(g){let S=s.ORDER,{r:A,s:L,recovery:I}=this;if(I==null||![0,1,2,3].includes(I))throw new Error("recovery id invalid");if(c*Aa<S&&I>1)throw new Error("recovery id is ambiguous for h>1 curve");let R=I===2||I===3?A+c:A;if(!s.isValid(R))throw new Error("recovery id 2 or 3 invalid");let U=s.toBytes(R),Z=e.fromBytes(lt(Ia((I&1)===0),U)),q=i.inv(R),K=P(z("msgHash",g)),X=i.create(-K*q),J=i.create(L*q),dt=e.BASE.multiplyUnsafe(X).add(Z.multiplyUnsafe(J));if(dt.is0())throw new Error("point at infinify");return dt.assertValidity(),dt}hasHighS(){return E(this.s)}toBytes(g=x){if(fs(g),g==="der")return de(Xt.hexFromSig(this));let S=i.toBytes(this.r),A=i.toBytes(this.s);if(g==="recovered"){if(this.recovery==null)throw new Error("recovery bit must be present");return lt(Uint8Array.of(this.recovery),S,A)}return lt(S,A)}toHex(g){return St(this.toBytes(g))}assertValidity(){}static fromCompact(g){return w.fromBytes(z("sig",g),"compact")}static fromDER(g){return w.fromBytes(z("sig",g),"der")}normalizeS(){return this.hasHighS()?new w(this.r,i.neg(this.s),this.recovery):this}toDERRawBytes(){return this.toBytes("der")}toDERHex(){return St(this.toBytes("der"))}toCompactRawBytes(){return this.toBytes("compact")}toCompactHex(){return St(this.toBytes("compact"))}}let T=r.bits2int||function(g){if(g.length>8192)throw new Error("input is too large");let S=Ne(g),A=g.length*8-a;return A>0?S>>BigInt(A):S},P=r.bits2int_modN||function(g){return i.create(T(g))},M=se(a);function k(m){return mr("num < 2^"+a,m,Wt,M),i.toBytes(m)}function O(m,g){return xt(m,void 0,"message"),g?xt(t(m),void 0,"prehashed message"):m}function _(m,g,S){if(["recovered","canonical"].some(X=>X in S))throw new Error("sign() legacy options not supported");let{lowS:A,prehash:L,extraEntropy:I}=us(S,d);m=O(m,L);let B=P(m),R=He(i,g),U=[k(R),k(B)];if(I!=null&&I!==!1){let X=I===!0?n(p.secretKey):I;U.push(z("extraEntropy",X))}let Z=lt(...U),q=B;function K(X){let J=T(X);if(!i.isValidNot0(J))return;let dt=i.inv(J),W=e.BASE.multiply(J).toAffine(),at=i.create(W.x);if(at===Wt)return;let Or=i.create(dt*i.create(q+at*R));if(Or===Wt)return;let Hs=(W.x===at?0:2)|Number(W.y&je),js=Or;return A&&E(Or)&&(js=i.neg(Or),Hs^=1),new w(at,js,Hs)}return{seed:Z,k2sig:K}}function C(m,g,S={}){m=z("message",m);let{seed:A,k2sig:L}=_(m,g,S);return Vi(t.outputLen,i.BYTES,o)(A,L)}function N(m){let g,S=typeof m=="string"||Ut(m),A=!S&&m!==null&&typeof m=="object"&&typeof m.r=="bigint"&&typeof m.s=="bigint";if(!S&&!A)throw new Error("invalid signature, expected Uint8Array, hex string or Signature instance");if(A)g=new w(m.r,m.s);else if(S){try{g=w.fromBytes(z("sig",m),"der")}catch(L){if(!(L instanceof Xt.Err))throw L}if(!g)try{g=w.fromBytes(z("sig",m),"compact")}catch{return!1}}return g||!1}function D(m,g,S,A={}){let{lowS:L,prehash:I,format:B}=us(A,d);if(S=z("publicKey",S),g=O(z("message",g),I),"strict"in A)throw new Error("options.strict was renamed to lowS");let R=B===void 0?N(m):w.fromBytes(z("sig",m),B);if(R===!1)return!1;try{let U=e.fromBytes(S);if(L&&R.hasHighS())return!1;let{r:Z,s:q}=R,K=P(g),X=i.inv(q),J=i.create(K*X),dt=i.create(Z*X),W=e.BASE.multiplyUnsafe(J).add(U.multiplyUnsafe(dt));return W.is0()?!1:i.create(W.x)===Z}catch{return!1}}function b(m,g,S={}){let{prehash:A}=us(S,d);return g=O(g,A),w.fromBytes(m,"recovered").recoverPublicKey(g).toBytes()}return Object.freeze({keygen:u,getPublicKey:h,getSharedSecret:f,utils:l,lengths:p,Point:e,sign:C,verify:D,recoverPublicKey:b,Signature:w,hash:t})}function rl(e){let t={a:e.a,b:e.b,p:e.Fp.ORDER,n:e.n,h:e.h,Gx:e.Gx,Gy:e.Gy},r=e.Fp,n=e.allowedPrivateKeyLengths?Array.from(new Set(e.allowedPrivateKeyLengths.map(i=>Math.ceil(i/2)))):void 0,o=wt(t.n,{BITS:e.nBitLength,allowedLengths:n,modFromBytes:e.wrapPrivateKey}),s={Fp:r,Fn:o,allowInfinityPoint:e.allowInfinityPoint,endo:e.endo,isTorsionFree:e.isTorsionFree,clearCofactor:e.clearCofactor,fromBytes:e.fromBytes,toBytes:e.toBytes};return{CURVE:t,curveOpts:s}}function nl(e){let{CURVE:t,curveOpts:r}=rl(e),n={hmac:e.hmac,randomBytes:e.randomBytes,lowS:e.lowS,bits2int:e.bits2int,bits2int_modN:e.bits2int_modN};return{CURVE:t,curveOpts:r,hash:e.hash,ecdsaOpts:n}}function ol(e,t){let r=t.Point;return Object.assign({},t,{ProjectivePoint:r,CURVE:Object.assign({},e,Zr(r.Fn.ORDER,r.Fn.BITS))})}function Ta(e){let{CURVE:t,curveOpts:r,hash:n,ecdsaOpts:o}=nl(e),s=Jf(t,r),i=el(s,n,o);return ol(e,i)}function Ca(e,t){let r=n=>Ta({...e,hash:n});return{...r(t),create:r}}var ds={p:BigInt("0xfffffffffffffffffffffffffffffffffffffffffffffffffffffffefffffc2f"),n:BigInt("0xfffffffffffffffffffffffffffffffebaaedce6af48a03bbfd25e8cd0364141"),h:BigInt(1),a:BigInt(0),b:BigInt(7),Gx:BigInt("0x79be667ef9dcbbac55a06295ce870b07029bfcdb2dce28d959f2815b16f81798"),Gy:BigInt("0x483ada7726a3c4655da4fbfc0e1108a8fd17b448a68554199c47d08ffb10d4b8")},sl={beta:BigInt("0x7ae96a2b657c07106e64479eac3434e99cf0497512f58995c1396c28719501ee"),basises:[[BigInt("0x3086d221a7d46bcde86c90e49284eb15"),-BigInt("0xe4437ed6010e88286f547fa90abfe4c3")],[BigInt("0x114ca50f7a8e2f3f657c1108d9d44cfd8"),BigInt("0x3086d221a7d46bcde86c90e49284eb15")]]};var Da=BigInt(2);function il(e){let t=ds.p,r=BigInt(3),n=BigInt(6),o=BigInt(11),s=BigInt(22),i=BigInt(23),c=BigInt(44),a=BigInt(88),u=e*e*e%t,h=u*u*e%t,f=$(h,r,t)*h%t,l=$(f,r,t)*h%t,p=$(l,Da,t)*u%t,d=$(p,o,t)*p%t,x=$(d,s,t)*d%t,E=$(x,c,t)*x%t,y=$(E,a,t)*E%t,v=$(y,c,t)*x%t,w=$(v,r,t)*h%t,T=$(w,i,t)*d%t,P=$(T,n,t)*u%t,M=$(P,Da,t);if(!hs.eql(hs.sqr(M),e))throw new Error("Cannot find square root");return M}var hs=wt(ds.p,{sqrt:il}),$e=Ca({...ds,Fp:hs,lowS:!0,endo:sl},Mi);function La(e,t,r,n){let o=sr.digest(r instanceof Uint8Array?r:r.subarray());if(tn(o))return o.then(({digest:s})=>(n?.signal?.throwIfAborted(),$e.verify(t,s,e))).catch(s=>{throw s.name==="AbortError"?s:new xr(String(s))});try{return n?.signal?.throwIfAborted(),$e.verify(t,o.digest,e)}catch(s){throw new xr(String(s))}}var un=class{type="secp256k1";raw;_key;constructor(t){this._key=Ra(t),this.raw=Pa(this._key)}toMultihash(){return vt.digest(Le(this))}toCID(){return et.createV1(114,this.toMultihash())}toString(){return G.encode(this.toMultihash().bytes).substring(1)}equals(t){return t==null||!(t.raw instanceof Uint8Array)?!1:ft(this.raw,t.raw)}verify(t,r,n){return La(this._key,r,t,n)}};function Oa(e){return new un(e)}function Pa(e){return $e.ProjectivePoint.fromHex(e).toRawBytes(!0)}function Ra(e){try{return $e.ProjectivePoint.fromHex(e),e}catch(t){throw new Ur(String(t))}}function Na(e){let{Type:t,Data:r}=Sr.decode(e.digest),n=r??new Uint8Array;switch(t){case _t.Ed25519:return da(n);case _t.secp256k1:return Oa(n);case _t.ECDSA:return Ei(n);default:throw new tr}}function Le(e){return Sr.encode({Type:_t[e.type],Data:e.raw})}var Ua=Symbol.for("nodejs.util.inspect.custom"),al=114,vr=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=G.encode(this.multihash.bytes).slice(1)),this.string}toMultihash(){return this.multihash}toCID(){return et.createV1(al,this.multihash)}toJSON(){return this.toString()}equals(t){if(t==null)return!1;if(t instanceof Uint8Array)return ft(this.multihash.bytes,t);if(typeof t=="string")return this.toString()===t;if(t?.toMultihash()?.bytes!=null)return ft(this.multihash.bytes,t.toMultihash().bytes);throw new Error("not valid Id")}[Ua](){return`PeerId(${this.toString()})`}},fn=class extends vr{type="RSA";publicKey;constructor(t){super({...t,type:"RSA"}),this.publicKey=t.publicKey}},ln=class extends vr{type="Ed25519";publicKey;constructor(t){super({...t,type:"Ed25519"}),this.publicKey=t.publicKey}},hn=class extends vr{type="secp256k1";publicKey;constructor(t){super({...t,type:"secp256k1"}),this.publicKey=t.publicKey}},cl=2336,dn=class{type="url";multihash;publicKey;url;constructor(t){this.url=t.toString(),this.multihash=vt.digest(V(this.url))}[Ua](){return`PeerId(${this.url})`}[qn]=!0;toString(){return this.toCID().toString()}toMultihash(){return this.multihash}toCID(){return et.createV1(cl,this.toMultihash())}toJSON(){return this.toString()}equals(t){return t==null?!1:(t instanceof Uint8Array&&(t=j(t)),t.toString()===this.toString())}};function pn(e){if(fl(e))return new fn({multihash:e});if(ul(e))try{let t=Na(e);if(t.type==="Ed25519")return new ln({multihash:e,publicKey:t});if(t.type==="secp256k1")return new hn({multihash:e,publicKey:t})}catch{let r=j(e.digest);return new dn(new URL(r))}throw new kr("Supplied PeerID Multihash is invalid")}function ul(e){return e.code===vt.code}function fl(e){return e.code===sr.code}function ps(e,t){let r={[Symbol.iterator]:()=>r,next:()=>{let n=e.next(),o=n.value;return n.done===!0||o==null?{done:!0,value:void 0}:{done:!1,value:t(o)}}};return r}function mn(e){let t=le(G.decode(`z${e}`));return pn(t)}var gn=class e{set;constructor(t){if(this.set=new Set,t!=null)for(let r of t)this.set.add(r.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 ps(this.set.entries(),t=>{let r=mn(t[0]);return[r,r]})}forEach(t){this.set.forEach(r=>{let n=mn(r);t(n,n,this)})}has(t){return this.set.has(t.toString())}values(){return ps(this.set.values(),t=>mn(t))}intersection(t){let r=new e;for(let n of t)this.has(n)&&r.add(n);return r}difference(t){let r=new e;for(let n of this)t.has(n)||r.add(n);return r}union(t){let r=new e;for(let n of t)r.add(n);for(let n of this)r.add(n);return r}};function ms(){return new gn}var gs={32:16777619n,64:1099511628211n,128:309485009821345068724781371n,256:374144419156711147060143317175368453031918731002211n,512:35835915874844867368919076489095108449946327955754392558399825615420669938882575126094039892345713852759n,1024:5016456510113118655434598811035278955030765345404790744303017523831112055108147451509157692220295382716162651878526895249385292291816524375083746691371804094271873160484737966720260389217684476157468082573n},ka={32:2166136261n,64:14695981039346656037n,128:144066263297769815596495629667062367629n,256:100029257958052580907070968620625704837092796014241193945225284501741471925557n,512:9659303129496669498009435400716310466090418745672637896108374329434462657994582932197716438449813051892206539805784495328239340083876191928701583869517785n,1024:14197795064947621068722070641403218320880622795441933960878474914617582723252296732303717722150864096521202355549365628174669108571814760471015076148029755969804077320157692458563003215304957150157403644460363550505412711285966361610267868082893823963790439336411086884584107735010676915n},Ma=new globalThis.TextEncoder;function ll(e,t){let r=gs[t],n=ka[t];for(let o=0;o<e.length;o++)n^=BigInt(e[o]),n=BigInt.asUintN(t,n*r);return n}function hl(e,t,r){if(r.length===0)throw new Error("The `utf8Buffer` option must have a length greater than zero");let n=gs[t],o=ka[t],s=e;for(;s.length>0;){let i=Ma.encodeInto(s,r);s=s.slice(i.read);for(let c=0;c<i.written;c++)o^=BigInt(r[c]),o=BigInt.asUintN(t,o*n)}return o}function ys(e,{size:t=32,utf8Buffer:r}={}){if(!gs[t])throw new Error("The `size` option must be one of 32, 64, 128, 256, 512, or 1024");if(typeof e=="string"){if(r)return hl(e,t,r);e=Ma.encode(e)}return ll(e,t)}var Ar={hash:e=>Number(ys(e,{size:32})),hashV:(e,t)=>dl(Ar.hash(e,t))};function dl(e){let t=e.toString(16);return t.length%2===1&&(t=`0${t}`),V(t,"base16")}var bs=64,Tt=class{fp;h;seed;constructor(t,r,n,o=2){if(o>bs)throw new TypeError("Invalid Fingerprint Size");let s=r.hashV(t,n),i=At(o);for(let c=0;c<i.length;c++)i[c]=s[c];i.length===0&&(i[0]=7),this.fp=i,this.h=r,this.seed=n}hash(){return this.h.hash(this.fp,this.seed)}equals(t){return t?.fp instanceof Uint8Array?ft(this.fp,t.fp):!1}};function we(e,t){return Math.floor(Math.random()*(t-e))+e}var Ee=class{contents;constructor(t){this.contents=new Array(t).fill(null)}has(t){if(!(t instanceof Tt))throw new TypeError("Invalid Fingerprint");return this.contents.some(r=>t.equals(r))}add(t){if(!(t instanceof Tt))throw new TypeError("Invalid Fingerprint");for(let r=0;r<this.contents.length;r++)if(this.contents[r]==null)return this.contents[r]=t,!0;return!0}swap(t){if(!(t instanceof Tt))throw new TypeError("Invalid Fingerprint");let r=we(0,this.contents.length-1),n=this.contents[r];return this.contents[r]=t,n}remove(t){if(!(t instanceof Tt))throw new TypeError("Invalid Fingerprint");let r=this.contents.findIndex(n=>t.equals(n));return r>-1?(this.contents[r]=null,!0):!1}};var pl=500,Ir=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??Ar,this.seed=t.seed??we(0,Math.pow(2,10))}add(t){typeof t=="string"&&(t=V(t));let r=new Tt(t,this.hash,this.seed,this.fingerprintSize),n=this.hash.hash(t,this.seed)%this.filterSize,o=(n^r.hash())%this.filterSize;if(this.buckets[n]==null&&(this.buckets[n]=new Ee(this.bucketSize)),this.buckets[o]==null&&(this.buckets[o]=new Ee(this.bucketSize)),this.buckets[n].add(r)||this.buckets[o].add(r))return this.count++,!0;let s=[n,o],i=s[we(0,s.length-1)];this.buckets[i]==null&&(this.buckets[i]=new Ee(this.bucketSize));for(let c=0;c<pl;c++){let a=this.buckets[i].swap(r);if(a!=null&&(i=(i^a.hash())%this.filterSize,this.buckets[i]==null&&(this.buckets[i]=new Ee(this.bucketSize)),this.buckets[i].add(a)))return this.count++,!0}return!1}has(t){typeof t=="string"&&(t=V(t));let r=new Tt(t,this.hash,this.seed,this.fingerprintSize),n=this.hash.hash(t,this.seed)%this.filterSize,o=this.buckets[n]?.has(r)??!1;if(o)return o;let s=(n^r.hash())%this.filterSize;return this.buckets[s]?.has(r)??!1}remove(t){typeof t=="string"&&(t=V(t));let r=new Tt(t,this.hash,this.seed,this.fingerprintSize),n=this.hash.hash(t,this.seed)%this.filterSize,o=this.buckets[n]?.remove(r)??!1;if(o)return this.count--,o;let s=(n^r.hash())%this.filterSize,i=this.buckets[s]?.remove(r)??!1;return i&&this.count--,i}get reliable(){return Math.floor(100*(this.count/this.filterSize))<=90}},ml={1:.5,2:.84,4:.95,8:.98};function gl(e=.001){return e>.002?2:e>1e-5?4:8}function Ka(e,t=.001){let r=gl(t),n=ml[r],o=Math.round(e/n),s=Math.min(Math.ceil(Math.log2(1/t)+Math.log2(2*r)),bs);return{filterSize:o,bucketSize:r,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??Ar,this.seed=t.seed??we(0,Math.pow(2,10)),this.filterSeries=[new Ir({filterSize:this.filterSize,bucketSize:this.bucketSize,fingerprintSize:this.fingerprintSize,hash:this.hash,seed:this.seed})]}add(t){if(typeof t=="string"&&(t=V(t)),this.has(t))return!0;let r=this.filterSeries.find(n=>n.reliable);if(r==null){let n=this.filterSize*Math.pow(this.scale,this.filterSeries.length);r=new Ir({filterSize:n,bucketSize:this.bucketSize,fingerprintSize:this.fingerprintSize,hash:this.hash,seed:this.seed}),this.filterSeries.push(r)}return r.add(t)}has(t){typeof t=="string"&&(t=V(t));for(let r=0;r<this.filterSeries.length;r++)if(this.filterSeries[r].has(t))return!0;return!1}remove(t){typeof t=="string"&&(t=V(t));for(let r=0;r<this.filterSeries.length;r++)if(this.filterSeries[r].remove(t))return!0;return!1}get count(){return this.filterSeries.reduce((t,r)=>t+r.count,0)}};function xs(e,t=.001,r){return new yn({...Ka(e,t),...r??{}})}var bn=class{index=0;input="";new(t){return this.index=0,this.input=t,this}readAtomically(t){let r=this.index,n=t();return n===void 0&&(this.index=r),n}parseWith(t){let r=t();if(this.index===this.input.length)return r}peekChar(){if(!(this.index>=this.input.length))return this.input[this.index]}readChar(){if(!(this.index>=this.input.length))return this.input[this.index++]}readGivenChar(t){return this.readAtomically(()=>{let r=this.readChar();if(r===t)return r})}readSeparator(t,r,n){return this.readAtomically(()=>{if(!(r>0&&this.readGivenChar(t)===void 0))return n()})}readNumber(t,r,n,o){return this.readAtomically(()=>{let s=0,i=0,c=this.peekChar();if(c===void 0)return;let a=c==="0",u=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>u||(i+=1,r!==void 0&&i>r))return}if(i!==0)return!n&&a&&i>1?void 0:s})}readIPv4Addr(){return this.readAtomically(()=>{let t=new Uint8Array(4);for(let r=0;r<t.length;r++){let n=this.readSeparator(".",r,()=>this.readNumber(10,3,!1,1));if(n===void 0)return;t[r]=n}return t})}readIPv6Addr(){let t=r=>{for(let n=0;n<r.length/2;n++){let o=n*2;if(n<r.length-3){let i=this.readSeparator(":",n,()=>this.readIPv4Addr());if(i!==void 0)return r[o]=i[0],r[o+1]=i[1],r[o+2]=i[2],r[o+3]=i[3],[o+4,!0]}let s=this.readSeparator(":",n,()=>this.readNumber(16,4,!0,2));if(s===void 0)return[o,!1];r[o]=s>>8,r[o+1]=s&255}return[r.length,!1]};return this.readAtomically(()=>{let r=new Uint8Array(16),[n,o]=t(r);if(n===16)return r;if(o||this.readGivenChar(":")===void 0||this.readGivenChar(":")===void 0)return;let s=new Uint8Array(14),i=16-(n+2),[c]=t(s.subarray(0,i));return r.set(s.subarray(0,c),16-c),r})}readIPAddr(){return this.readIPv4Addr()??this.readIPv6Addr()}};var Fa=45,yl=15,Ge=new bn;function xn(e){if(!(e.length>yl))return Ge.new(e).parseWith(()=>Ge.readIPv4Addr())}function wn(e){if(e.includes("%")&&(e=e.split("%")[0]),!(e.length>Fa))return Ge.new(e).parseWith(()=>Ge.readIPv6Addr())}function Ze(e,t=!1){if(e.includes("%")&&(e=e.split("%")[0]),e.length>Fa)return;let r=Ge.new(e).parseWith(()=>Ge.readIPAddr());if(r)return t&&r.length===4?Uint8Array.from([0,0,0,0,0,0,0,0,0,0,255,255,r[0],r[1],r[2],r[3]]):r}function za(e,t,r){let n=0;for(let o of e)if(!(n<t)){if(n>r)break;if(o!==255)return!1;n++}return!0}function qa(e,t,r,n){let o=0;for(let s of e)if(!(o<r)){if(o>n)break;if(s!==t[o])return!1;o++}return!0}function ws(e){switch(e.length){case _e:return e.join(".");case Se:{let t=[];for(let r=0;r<e.length;r++)r%2===0&&t.push(e[r].toString(16).padStart(2,"0")+e[r+1].toString(16).padStart(2,"0"));return t.join(":")}default:throw new Error("Invalid ip length")}}function Va(e){let t=0;for(let[r,n]of e.entries()){if(n===255){t+=8;continue}for(;(n&128)!=0;)t++,n=n<<1;if((n&128)!=0)return-1;for(let o=r+1;o<e.length;o++)if(e[o]!=0)return-1;break}return t}function Ha(e){let t="0x";for(let r of e)t+=(r>>4).toString(16)+(r&15).toString(16);return t}var _e=4,Se=16,ny=parseInt("0xFFFF",16),bl=new Uint8Array([0,0,0,0,0,0,0,0,0,0,255,255]);function Br(e,t){t.length===Se&&e.length===_e&&za(t,0,11)&&(t=t.slice(12)),t.length===_e&&e.length===Se&&qa(e,bl,0,11)&&(e=e.slice(12));let r=e.length;if(r!=t.length)throw new Error("Failed to mask ip");let n=new Uint8Array(r);for(let o=0;o<r;o++)n[o]=e[o]&t[o];return n}function ja(e,t){if(typeof t=="string"&&(t=Ze(t)),t==null)throw new Error("Invalid ip");if(t.length!==e.network.length)return!1;for(let r=0;r<t.length;r++)if((e.network[r]&e.mask[r])!==(t[r]&e.mask[r]))return!1;return!0}function Es(e){let[t,r]=e.split("/");if(!t||!r)throw new Error("Failed to parse given CIDR: "+e);let n=_e,o=xn(t);if(o==null&&(n=Se,o=wn(t),o==null))throw new Error("Failed to parse given CIDR: "+e);let s=parseInt(r,10);if(Number.isNaN(s)||String(s).length!==r.length||s<0||s>n*8)throw new Error("Failed to parse given CIDR: "+e);let i=_s(s,8*n);return{network:Br(o,i),mask:i}}function _s(e,t){if(t!==8*_e&&t!==8*Se)throw new Error("Invalid CIDR mask");if(e<0||e>t)throw new Error("Invalid CIDR mask");let r=t/8,n=new Uint8Array(r);for(let o=0;o<r;o++){if(e>=8){n[o]=255,e-=8;continue}n[o]=255-(255>>e),e=0}return n}var Xe=class{constructor(t,r){if(r==null)({network:this.network,mask:this.mask}=Es(t));else{let n=Ze(t);if(n==null)throw new Error("Failed to parse network");r=String(r);let o=parseInt(r,10);if(Number.isNaN(o)||String(o).length!==r.length||o<0||o>n.length*8){let s=Ze(r);if(s==null)throw new Error("Failed to parse mask");this.mask=s}else this.mask=_s(o,8*n.length);this.network=Br(n,this.mask)}}contains(t){return ja({network:this.network,mask:this.mask},t)}toString(){let t=Va(this.mask),r=t!==-1?String(t):Ha(this.mask);return ws(this.network)+"/"+r}};function $a(e,t){return new Xe(e).contains(t)}var it=class extends Error{static name="InvalidMultiaddrError";name="InvalidMultiaddrError"},Yt=class extends Error{static name="ValidationError";name="ValidationError"},Tr=class extends Error{static name="InvalidParametersError";name="InvalidParametersError"},En=class extends Error{static name="UnknownProtocolError";name="UnknownProtocolError"};function We(e){return!!xn(e)}function _n(e){return!!wn(e)}function vs(e){return t=>j(t,e)}function As(e){return t=>V(t,e)}function Ye(e){return new DataView(e.buffer).getUint16(e.byteOffset).toString()}function ve(e){let t=new ArrayBuffer(2);return new DataView(t).setUint16(0,typeof e=="string"?parseInt(e):e),new Uint8Array(t)}function Ga(e){let t=e.split(":");if(t.length!==2)throw new Error(`failed to parse onion addr: ["'${t.join('", "')}'"]' does not contain a port number`);if(t[0].length!==16)throw new Error(`failed to parse onion addr: ${t[0]} not a Tor onion address.`);let r=V(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=ve(n);return Ot([r,o],r.length+o.length)}function Za(e){let t=e.split(":");if(t.length!==2)throw new Error(`failed to parse onion addr: ["'${t.join('", "')}'"]' does not contain a port number`);if(t[0].length!==56)throw new Error(`failed to parse onion addr: ${t[0]} not a Tor onion3 address.`);let r=te.decode(`b${t[0]}`),n=parseInt(t[1],10);if(n<1||n>65536)throw new Error("Port number is not in range(1, 65536)");let o=ve(n);return Ot([r,o],r.length+o.length)}function Is(e){let t=e.subarray(0,e.length-2),r=e.subarray(e.length-2),n=j(t,"base32"),o=Ye(r);return`${n}:${o}`}var Bs=function(e){e=e.toString().trim();let t=new Uint8Array(4);return e.split(/\./g).forEach((r,n)=>{let o=parseInt(r,10);if(isNaN(o)||o<0||o>255)throw new it("Invalid byte value in IP address");t[n]=o}),t},Xa=function(e){let t=0;e=e.toString().trim();let r=e.split(":",8),n;for(n=0;n<r.length;n++){let s=We(r[n]),i;s&&(i=Bs(r[n]),r[n]=j(i.subarray(0,2),"base16")),i!=null&&++n<8&&r.splice(n,0,j(i.subarray(2,4),"base16"))}if(r[0]==="")for(;r.length<8;)r.unshift("0");else if(r[r.length-1]==="")for(;r.length<8;)r.push("0");else if(r.length<8){for(n=0;n<r.length&&r[n]!=="";n++);let s=[n,1];for(n=9-r.length;n>0;n--)s.push("0");r.splice.apply(r,s)}let o=new Uint8Array(t+16);for(n=0;n<r.length;n++){r[n]===""&&(r[n]="0");let s=parseInt(r[n],16);if(isNaN(s)||s<0||s>65535)throw new it("Invalid byte value in IP address");o[t++]=s>>8&255,o[t++]=s&255}return o},Wa=function(e){if(e.byteLength!==4)throw new it("IPv4 address was incorrect length");let t=[];for(let r=0;r<e.byteLength;r++)t.push(e[r]);return t.join(".")},Ya=function(e){if(e.byteLength!==16)throw new it("IPv6 address was incorrect length");let t=[];for(let n=0;n<e.byteLength;n+=2){let o=e[n],s=e[n+1],i=`${o.toString(16).padStart(2,"0")}${s.toString(16).padStart(2,"0")}`;t.push(i)}let r=t.join(":");try{let n=new URL(`http://[${r}]`);return n.hostname.substring(1,n.hostname.length-1)}catch{throw new it(`Invalid IPv6 address "${r}"`)}};function Qa(e){try{let t=new URL(`http://[${e}]`);return t.hostname.substring(1,t.hostname.length-1)}catch{throw new it(`Invalid IPv6 address "${e}"`)}}var Ss=Object.values(ir).map(e=>e.decoder),xl=function(){let e=Ss[0].or(Ss[1]);return Ss.slice(2).forEach(t=>e=e.or(t)),e}();function Ja(e){return xl.decode(e)}function tc(e){return t=>e.encoder.encode(t)}function wl(e){if(parseInt(e).toString()!==e)throw new Yt("Value must be an integer")}function El(e){if(e<0)throw new Yt("Value must be a positive integer, or zero")}function _l(e){return t=>{if(t>e)throw new Yt(`Value must be smaller than or equal to ${e}`)}}function Sl(...e){return t=>{for(let r of e)r(t)}}var Cr=Sl(wl,El,_l(65535));var ot=-1,Ts=class{protocolsByCode=new Map;protocolsByName=new Map;getProtocol(t){let r;if(typeof t=="string"?r=this.protocolsByName.get(t):r=this.protocolsByCode.get(t),r==null)throw new En(`Protocol ${t} was unknown`);return r}addProtocol(t){this.protocolsByCode.set(t.code,t),this.protocolsByName.set(t.name,t),t.aliases?.forEach(r=>{this.protocolsByName.set(r,t)})}removeProtocol(t){let r=this.protocolsByCode.get(t);r!=null&&(this.protocolsByCode.delete(r.code),this.protocolsByName.delete(r.name),r.aliases?.forEach(n=>{this.protocolsByName.delete(n)}))}},yt=new Ts,Jl=[{code:4,name:"ip4",size:32,valueToBytes:Bs,bytesToValue:Wa,validate:e=>{if(!We(e))throw new Yt(`Invalid IPv4 address "${e}"`)}},{code:6,name:"tcp",size:16,valueToBytes:ve,bytesToValue:Ye,validate:Cr},{code:273,name:"udp",size:16,valueToBytes:ve,bytesToValue:Ye,validate:Cr},{code:33,name:"dccp",size:16,valueToBytes:ve,bytesToValue:Ye,validate:Cr},{code:41,name:"ip6",size:128,valueToBytes:Xa,bytesToValue:Ya,stringToValue:Qa,validate:e=>{if(!_n(e))throw new Yt(`Invalid IPv6 address "${e}"`)}},{code:42,name:"ip6zone",size:ot},{code:43,name:"ipcidr",size:8,bytesToValue:vs("base10"),valueToBytes:As("base10")},{code:53,name:"dns",size:ot,resolvable:!0},{code:54,name:"dns4",size:ot,resolvable:!0},{code:55,name:"dns6",size:ot,resolvable:!0},{code:56,name:"dnsaddr",size:ot,resolvable:!0},{code:132,name:"sctp",size:16,valueToBytes:ve,bytesToValue:Ye,validate:Cr},{code:301,name:"udt"},{code:302,name:"utp"},{code:400,name:"unix",size:ot,path:!0,stringToValue:e=>decodeURIComponent(e),valueToString:e=>encodeURIComponent(e)},{code:421,name:"p2p",aliases:["ipfs"],size:ot,bytesToValue:vs("base58btc"),valueToBytes:e=>e.startsWith("Q")||e.startsWith("1")?As("base58btc")(e):et.parse(e).multihash.bytes},{code:444,name:"onion",size:96,bytesToValue:Is,valueToBytes:Ga},{code:445,name:"onion3",size:296,bytesToValue:Is,valueToBytes:Za},{code:446,name:"garlic64",size:ot},{code:447,name:"garlic32",size:ot},{code:448,name:"tls"},{code:449,name:"sni",size:ot},{code:454,name:"noise"},{code:460,name:"quic"},{code:461,name:"quic-v1"},{code:465,name:"webtransport"},{code:466,name:"certhash",size:ot,bytesToValue:tc(no),valueToBytes:Ja},{code:480,name:"http"},{code:481,name:"http-path",size:ot,stringToValue:e=>`/${decodeURIComponent(e)}`,valueToString:e=>encodeURIComponent(e.substring(1))},{code:443,name:"https"},{code:477,name:"ws"},{code:478,name:"wss"},{code:479,name:"p2p-websocket-star"},{code:277,name:"p2p-stardust"},{code:275,name:"p2p-webrtc-star"},{code:276,name:"p2p-webrtc-direct"},{code:280,name:"webrtc-direct"},{code:281,name:"webrtc"},{code:290,name:"p2p-circuit"},{code:777,name:"memory",size:ot}];Jl.forEach(e=>{yt.addProtocol(e)});function ec(e){let t=[],r=0;for(;r<e.length;){let n=wr(e,r),o=yt.getProtocol(n),s=gt(n),i=th(o,e,r+s),c=0;i>0&&o.size===ot&&(c=gt(i));let a=s+c+i,u={code:n,name:o.name,bytes:e.subarray(r,r+a)};if(i>0){let h=r+s+c,f=e.subarray(h,h+i);u.value=o.bytesToValue?.(f)??j(f)}t.push(u),r+=a}return t}function rc(e){let t=0,r=[];for(let n of e){if(n.bytes==null){let o=yt.getProtocol(n.code),s=gt(n.code),i,c=0,a=0;n.value!=null&&(i=o.valueToBytes?.(n.value)??V(n.value),c=i.byteLength,o.size===ot&&(a=gt(c)));let u=new Uint8Array(s+a+c),h=0;ze(n.code,u,h),h+=s,i!=null&&(o.size===ot&&(ze(c,u,h),h+=a),u.set(i,h)),n.bytes=u}r.push(n.bytes),t+=n.bytes.byteLength}return Ot(r,t)}function nc(e){if(e.charAt(0)!=="/")throw new it('String multiaddr must start with "/"');let t=[],r="protocol",n="",o="";for(let s=1;s<e.length;s++){let i=e.charAt(s);i!=="/"&&(r==="protocol"?o+=e.charAt(s):n+=e.charAt(s));let c=s===e.length-1;if(i==="/"||c){let a=yt.getProtocol(o);if(r==="protocol"){if(a.size==null||a.size===0){t.push({code:a.code,name:a.name}),n="",o="",r="protocol";continue}else if(c)throw new it(`Component ${o} was missing value`);r="value"}else if(r==="value"){let u={code:a.code,name:a.name};if(a.size!=null&&a.size!==0){if(n==="")throw new it(`Component ${o} was missing value`);u.value=a.stringToValue?.(n)??n}t.push(u),n="",o="",r="protocol"}}}if(o!==""&&n!=="")throw new it("Incomplete multiaddr");return t}function oc(e){return`/${e.flatMap(t=>{if(t.value==null)return t.name;let r=yt.getProtocol(t.code);if(r==null)throw new it(`Unknown protocol code ${t.code}`);return[t.name,r.valueToString?.(t.value)??t.value]}).join("/")}`}function th(e,t,r){return e.size==null||e.size===0?0:e.size>0?e.size/8:wr(t,r)}var eh=Symbol.for("nodejs.util.inspect.custom"),Ns=Symbol.for("@multiformats/multiaddr"),rh=[53,54,55,56],Os=class extends Error{constructor(t="No available resolver"){super(t),this.name="NoAvailableResolverError"}};function nh(e){if(e==null&&(e="/"),ic(e))return e.getComponents();if(e instanceof Uint8Array)return ec(e);if(typeof e=="string")return e=e.replace(/\/(\/)+/,"/").replace(/(\/)+$/,""),e===""&&(e="/"),nc(e);if(Array.isArray(e))return e;throw new it("Must be a string, Uint8Array, Component[], or another Multiaddr")}var In=class e{[Ns]=!0;#t;#e;#r;constructor(t="/",r={}){this.#t=nh(t),r.validate!==!1&&oh(this)}get bytes(){return this.#r==null&&(this.#r=rc(this.#t)),this.#r}toString(){return this.#e==null&&(this.#e=oc(this.#t)),this.#e}toJSON(){return this.toString()}toOptions(){let t,r,n,o,s="";for(let{code:c,name:a,value:u}of this.#t)c===42&&(s=`%${u??""}`),rh.includes(c)&&(r="tcp",o=443,n=`${u??""}${s}`,t=c===55?6:4),(c===6||c===273)&&(r=a==="tcp"?"tcp":"udp",o=parseInt(u??"")),(c===4||c===41)&&(r="tcp",n=`${u??""}${s}`,t=c===41?6:4);if(t==null||r==null||n==null||o==null)throw new Error('multiaddr must have a valid format: "/{ip4, ip6, dns4, dns6, dnsaddr}/{address}/{tcp, udp}/{port}".');return{family:t,host:n,transport:r,port:o}}getComponents(){return[...this.#t]}protos(){return this.#t.map(({code:t,value:r})=>{let n=yt.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:r})=>{if(r==null)return[t];let n=yt.getProtocol(t),o=[t];return r!=null&&o.push(n.valueToBytes?.(r)??V(r)),o})}stringTuples(){return this.#t.map(({code:t,value:r})=>r==null?[t]:[t,r])}encapsulate(t){let r=new e(t);return new e([...this.#t,...r.getComponents()],{validate:!1})}decapsulate(t){let r=t.toString(),n=this.toString(),o=n.lastIndexOf(r);if(o<0)throw new Tr(`Address ${this.toString()} does not contain subaddress: ${t.toString()}`);return new e(n.slice(0,o),{validate:!1})}decapsulateCode(t){let r;for(let n=this.#t.length-1;n>-1;n--)if(this.#t[n].code===t){r=n;break}return new e(this.#t.slice(0,r),{validate:!1})}getPeerId(){try{let t=[];this.#t.forEach(({code:n,value:o})=>{n===421&&t.push([n,o]),n===290&&(t=[])});let r=t.pop();if(r?.[1]!=null){let n=r[1];return n[0]==="Q"||n[0]==="1"?j(G.decode(`z${n}`),"base58btc"):j(et.parse(n).multihash.bytes,"base58btc")}return null}catch{return null}}getPath(){for(let t of this.#t)if(yt.getProtocol(t.code).path)return t.value??null;return null}equals(t){return ft(this.bytes,t.bytes)}async resolve(t){let r=this.protos().find(s=>s.resolvable);if(r==null)return[this];let n=sc.get(r.name);if(n==null)throw new Os(`no available resolver for ${r.name}`);return(await n(this,t)).map(s=>Lr(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)}[eh](){return`Multiaddr(${this.toString()})`}};function oh(e){e.getComponents().forEach(t=>{let r=yt.getProtocol(t.code);t.value!=null&&r.validate?.(t.value)})}var sc=new Map;function ic(e){return!!e?.[Ns]}function Lr(e){return new In(e)}function ac(e){let t=yt.getProtocol(e);return{code:t.code,size:t.size??0,name:t.name,resolvable:!!t.resolvable,path:!!t.path}}function cc(e){try{for(let{code:t,value:r}of e.getComponents())if(r!=null&&t===41)return $a("2000::/3",r)}catch{}return!1}var fc=Cc(uc(),1),sh=["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"],ih=sh.map(e=>new fc.Netmask(e));function Us(e){for(let t of ih)if(t.contains(e))return!0;return!1}function ah(e){return/^::ffff:([0-9a-fA-F]{1,4}):([0-9a-fA-F]{1,4})$/.test(e)}function ch(e){let t=e.split(":");if(t.length<2)return!1;let r=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(r.substring(0,2),16)}.${parseInt(r.substring(2),16)}`;return Us(o)}function uh(e){return/^::ffff:([0-9]{1,3})\.([0-9]{1,3})\.([0-9]{1,3})\.([0-9]{1,3})$/.test(e)}function fh(e){let t=e.split(":"),r=t[t.length-1];return Us(r)}function lh(e){return/^::$/.test(e)||/^::1$/.test(e)||/^64:ff9b::([0-9]{1,3})\.([0-9]{1,3})\.([0-9]{1,3})\.([0-9]{1,3})$/.test(e)||/^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(e)||/^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(e)||/^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(e)||/^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(e)||/^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(e)||/^f[c-d]([0-9a-fA-F]{2,2}):/i.test(e)||/^fe[8-9a-bA-B][0-9a-fA-F]:/i.test(e)||/^ff([0-9a-fA-F]{2,2}):/i.test(e)}function lc(e){if(We(e))return Us(e);if(ah(e))return ch(e);if(uh(e))return fh(e);if(_n(e))return lh(e)}function hc(e){try{for(let{code:t}of e.getComponents())if(t!==42)return t===4||t===41}catch{}return!1}function ks(e){try{if(!hc(e))return!1;let[[,t]]=e.stringTuples();return t==null?!1:lc(t)??!1}catch{}return!0}function Ct(){let e={};return e.promise=new Promise((t,r)=>{e.resolve=t,e.reject=r}),e}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 r=this.head;this.head=r.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 r=this.tail.next;this.tail.next=null,this.tail=r,t=this.tail.shift()}return t?.value!=null&&(this.size-=this.calculateSize(t.value)),t}isEmpty(){return this.head.isEmpty()}};var Ms=class extends Error{type;code;constructor(t,r){super(t??"The operation was aborted"),this.type="aborted",this.code=r??"ABORT_ERR"}};function dc(e={}){return hh(r=>{let n=r.shift();if(n==null)return{done:!0};if(n.error!=null)throw n.error;return{done:n.done===!0,value:n.value}},e)}function hh(e,t){t=t??{};let r=t.onEnd,n=new Je,o,s,i,c=Ct(),a=async()=>{try{return n.isEmpty()?i?{done:!0}:await new Promise((E,y)=>{s=v=>{s=null,n.push(v);try{E(e(n))}catch(w){y(w)}return o}}):e(n)}finally{n.isEmpty()&&queueMicrotask(()=>{c.resolve(),c=Ct()})}},u=E=>s!=null?s(E):(n.push(E),o),h=E=>(n=new Je,s!=null?s({error:E}):(n.push({error:E}),o)),f=E=>{if(i)return o;if(t?.objectMode!==!0&&E?.byteLength==null)throw new Error("objectMode was not true but tried to push non-Uint8Array value");return u({done:!1,value:E})},l=E=>i?o:(i=!0,E!=null?h(E):u({done:!0})),p=()=>(n=new Je,l(),{done:!0}),d=E=>(l(E),{done:!0});if(o={[Symbol.asyncIterator](){return this},next:a,return:p,throw:d,push:f,end:l,get readableLength(){return n.size},onEmpty:async E=>{let y=E?.signal;if(y?.throwIfAborted(),n.isEmpty())return;let v,w;y!=null&&(v=new Promise((T,P)=>{w=()=>{P(new Ms)},y.addEventListener("abort",w)}));try{await Promise.race([c.promise,v])}finally{w!=null&&y!=null&&y?.removeEventListener("abort",w)}}},r==null)return o;let x=o;return o={[Symbol.asyncIterator](){return this},next(){return x.next()},throw(E){return x.throw(E),r!=null&&(r(E),r=void 0),{done:!0}},return(){return x.return(),r!=null&&(r(),r=void 0),{done:!0}},push:f,end(E){return x.end(E),r!=null&&(r(E),r=void 0),o},get readableLength(){return x.readableLength},onEmpty:E=>x.onEmpty(E)},o}var Tn=class extends Error{static name="AbortError";name="AbortError";constructor(t="The operation was aborted",...r){super(t,...r)}};async function Cn(e,t,r,n){let o=new Tn(n?.errorMessage);n?.errorCode!=null&&(o.code=n.errorCode);let s=n?.errorEvent??"error";return r?.aborted===!0?Promise.reject(o):new Promise((i,c)=>{function a(){Fs(r,"abort",f),Fs(e,t,u),Fs(e,s,h)}let u=l=>{try{if(n?.filter?.(l)===!1)return}catch(p){a(),c(p);return}a(),i(l)},h=l=>{if(a(),l instanceof Error){c(l);return}c(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=()=>{a(),c(o)};Ks(r,"abort",f),Ks(e,t,u),Ks(e,s,h)})}function Ks(e,t,r){e!=null&&(pc(e)?e.addEventListener(t,r):e.addListener(t,r))}function Fs(e,t,r){e!=null&&(pc(e)?e.removeEventListener(t,r):e.removeListener(t,r))}function pc(e){return typeof e.addEventListener=="function"&&typeof e.removeEventListener=="function"}function Rr(e,t){let r,n=function(){let o=function(){r=void 0,e()};clearTimeout(r),r=setTimeout(o,t)};return n.start=()=>{},n.stop=()=>{clearTimeout(r)},n}var Dn=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,r,n){super(t??"The operation was aborted"),this.type="aborted",this.name=n??"AbortError",this.code=r??"ABORT_ERR"}};async function Ae(e,t,r){if(t==null)return e;if(t.aborted)return e.catch(()=>{}),Promise.reject(new Ln(r?.errorMessage,r?.errorCode,r?.errorName));let n,o=new Ln(r?.errorMessage,r?.errorCode,r?.errorName);try{return await Promise.race([e,new Promise((s,i)=>{n=()=>{i(o)},t.addEventListener("abort",n)})])}finally{n!=null&&t.removeEventListener("abort",n)}}var Pn=class{deferred;signal;constructor(t){this.signal=t,this.deferred=Ct(),this.onAbort=this.onAbort.bind(this),this.signal?.addEventListener("abort",this.onAbort)}onAbort(){this.deferred.reject(this.signal?.reason??new Lt)}cleanup(){this.signal?.removeEventListener("abort",this.onAbort)}};function dh(){return`${parseInt(String(Math.random()*1e9),10).toString()}${Date.now()}`}var Rn=class{id;fn;options;recipients;status;timeline;controller;constructor(t,r){this.id=dh(),this.status="queued",this.fn=t,this.options=r,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((r,n)=>r&&n.signal?.aborted===!0,!0)&&(this.controller.abort(new Lt),this.cleanup())}async join(t={}){let r=new Pn(t.signal);return this.recipients.push(r),t.signal?.addEventListener("abort",this.onAbort),r.deferred.promise}async run(){this.status="running",this.timeline.started=Date.now();try{this.controller.signal.throwIfAborted();let t=await Ae(this.fn({...this.options??{},signal:this.controller.signal}),this.controller.signal);this.recipients.forEach(r=>{r.deferred.resolve(t)}),this.status="complete"}catch(t){this.recipients.forEach(r=>{r.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 Mr{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=Rr(this.emitEmpty.bind(this),1),this.emitIdle=Rr(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 r of this.queue)if(r.status==="queued"){t=r;break}return t==null?!1:(this.safeDispatchEvent("active"),this.pending++,t.run().finally(()=>{for(let r=0;r<this.queue.length;r++)if(this.queue[r]===t){this.queue.splice(r,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,r){if(r?.signal?.throwIfAborted(),this.size===this.maxSize)throw new Dn;let n=new Rn(t,r);return this.enqueue(n),this.safeDispatchEvent("add"),this.tryToStartAnother(),n.join(r).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 Lt)}),this.clear()}async onEmpty(t){this.size!==0&&await Cn(this,"empty",t?.signal)}async onSizeLessThan(t,r){this.size<t||await Cn(this,"next",r?.signal,{filter:()=>this.size<t})}async onIdle(t){this.pending===0&&this.size===0||await Cn(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 r=dc({objectMode:!0}),n=a=>{a!=null?this.abort():this.clear(),r.end(a)},o=a=>{a.detail!=null&&r.push(a.detail)},s=a=>{n(a.detail.error)},i=()=>{n()},c=()=>{n(new Lt("Queue aborted"))};this.addEventListener("completed",o),this.addEventListener("failure",s),this.addEventListener("idle",i),t?.signal?.addEventListener("abort",c);try{yield*r}finally{this.removeEventListener("completed",o),this.removeEventListener("failure",s),this.removeEventListener("idle",i),t?.signal?.removeEventListener("abort",c),n()}}};var Nn=class extends On{has(t){return this.find(t)!=null}find(t){return this.queue.find(r=>t.equals(r.options.peerId))}};function Un(e){let t=new globalThis.AbortController;function r(){t.abort();for(let s of e)s?.removeEventListener!=null&&s.removeEventListener("abort",r)}for(let s of e){if(s?.aborted===!0){r();break}s?.addEventListener!=null&&s.addEventListener("abort",r)}function n(){for(let s of e)s?.removeEventListener!=null&&s.removeEventListener("abort",r)}let o=t.signal;return o.clear=n,o}function mc(e,t,r){let n,o,s=!1;function i(){let u={signal:o.signal};if(r?.timeout!=null){let h=Un([o.signal,AbortSignal.timeout(r.timeout)]);u.signal=h}s=!0,Promise.resolve().then(async()=>{await e(u)}).catch(()=>{}).finally(()=>{s=!1,!o.signal.aborted&&(n=setTimeout(i,t))})}let c=Rr(i,r?.debounce??100),a=!1;return{setInterval:u=>{t!==u&&(t=u,n!=null&&(clearTimeout(n),n=setTimeout(i,t)))},setTimeout:u=>{r??={},r.timeout=u},run:()=>{s||(clearTimeout(n),c())},start:()=>{a||(a=!0,o=new AbortController,o.signal,r?.runImmediately===!0?queueMicrotask(()=>{i()}):n=setTimeout(i,t))},stop:()=>{clearTimeout(n),o?.abort(),a=!1}}}var zs=class extends Map{metric;constructor(t){super();let{name:r,metrics:n}=t;this.metric=n.registerMetric(r),this.updateComponentMetric()}set(t,r){return super.set(t,r),this.updateComponentMetric(),this}delete(t){let r=super.delete(t);return this.updateComponentMetric(),r}clear(){super.clear(),this.updateComponentMetric()}updateComponentMetric(){this.metric.update(this.size)}};function gc(e){let{name:t,metrics:r}=e,n;return r!=null?n=new zs({name:t,metrics:r}):n=new Map,n}var qs=class{readNext;haveNext;ended;nextResult;error;constructor(){this.ended=!1,this.readNext=Ct(),this.haveNext=Ct()}[Symbol.asyncIterator](){return this}async next(){if(this.nextResult==null&&await this.haveNext.promise,this.nextResult==null)throw new Error("HaveNext promise resolved but nextResult was undefined");let t=this.nextResult;return this.nextResult=void 0,this.readNext.resolve(),this.readNext=Ct(),t}async throw(t){return this.ended=!0,this.error=t,t!=null&&(this.haveNext.promise.catch(()=>{}),this.haveNext.reject(t)),{done:!0,value:void 0}}async return(){let t={done:!0,value:void 0};return this.ended=!0,this.nextResult=t,this.haveNext.resolve(),t}async push(t,r){await this._push(t,r)}async end(t,r){t!=null?await this.throw(t):await this._push(void 0,r)}async _push(t,r){if(t!=null&&this.ended)throw this.error??new Error("Cannot push value onto an ended pushable");for(;this.nextResult!=null;)await this.readNext.promise;t!=null?this.nextResult={done:!1,value:t}:(this.ended=!0,this.nextResult={done:!0,value:void 0}),this.haveNext.resolve(),this.haveNext=Ct(),await Ae(this.readNext.promise,r?.signal,r)}};function yc(){return new qs}var kn=class extends Error{name="UnexpectedEOFError";code="ERR_UNEXPECTED_EOF"};function bc(e,t){let r=yc();e.sink(r).catch(async i=>{await r.end(i)}),e.sink=async i=>{for await(let c of i)await r.push(c);await r.end()};let n=e.source;e.source[Symbol.iterator]!=null?n=e.source[Symbol.iterator]():e.source[Symbol.asyncIterator]!=null&&(n=e.source[Symbol.asyncIterator]());let o=new tt;return{read:async i=>{if(i?.signal?.throwIfAborted(),i?.bytes==null){let{done:a,value:u}=await Ae(n.next(),i?.signal);return a===!0?null:u}for(;o.byteLength<i.bytes;){let{value:a,done:u}=await Ae(n.next(),i?.signal);if(u===!0)throw new kn("unexpected end of input");o.append(a)}let c=o.sublist(0,i.bytes);return o.consume(i.bytes),c},write:async(i,c)=>{c?.signal?.throwIfAborted(),i instanceof Uint8Array?await r.push(i,c):await r.push(i.subarray(),c)},unwrap:()=>{if(o.byteLength>0){let i=e.source;e.source=async function*(){t?.yieldBytes===!1?yield o:yield*o,yield*i}()}return e}}}var 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 xc(e,t={}){let r=bc(e,t);t.maxDataLength!=null&&t.maxLengthLength==null&&(t.maxLengthLength=gt(t.maxDataLength));let n=t?.lengthDecoder??wr,o=t?.lengthEncoder??pa;return{read:async i=>{let c=-1,a=new tt;for(;;){a.append(await r.read({...i,bytes:1}));try{c=n(a)}catch(u){if(u instanceof RangeError)continue;throw u}if(c<0)throw new Mn("Invalid message length");if(t?.maxLengthLength!=null&&a.byteLength>t.maxLengthLength)throw new Fn("message length length too long");if(c>-1)break}if(t?.maxDataLength!=null&&c>t.maxDataLength)throw new Kn("message length too long");return r.read({...i,bytes:c})},write:async(i,c)=>{await r.write(new tt(o(i.byteLength),i),c)},writeV:async(i,c)=>{let a=new tt(...i.flatMap(u=>[o(u.byteLength),u]));await r.write(a,c)},unwrap:()=>r.unwrap()}}function Vs(e,t){let r=xc(e,t),n={read:async(o,s)=>{let i=await r.read(s);return o.decode(i)},write:async(o,s,i)=>{await r.write(s.encode(o),i)},writeV:async(o,s,i)=>{await r.writeV(o.map(c=>s.encode(c)),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:()=>r.unwrap()};return n}var wc="libp2p",Ec="autonat",_c="1.0.0";var H;(function(e){let t;(function(u){u.DIAL="DIAL",u.DIAL_RESPONSE="DIAL_RESPONSE"})(t=e.MessageType||(e.MessageType={}));let r;(function(u){u[u.DIAL=0]="DIAL",u[u.DIAL_RESPONSE=1]="DIAL_RESPONSE"})(r||(r={})),function(u){u.codec=()=>Ve(r)}(t=e.MessageType||(e.MessageType={}));let n;(function(u){u.OK="OK",u.E_DIAL_ERROR="E_DIAL_ERROR",u.E_DIAL_REFUSED="E_DIAL_REFUSED",u.E_BAD_REQUEST="E_BAD_REQUEST",u.E_INTERNAL_ERROR="E_INTERNAL_ERROR"})(n=e.ResponseStatus||(e.ResponseStatus={}));let o;(function(u){u[u.OK=0]="OK",u[u.E_DIAL_ERROR=100]="E_DIAL_ERROR",u[u.E_DIAL_REFUSED=101]="E_DIAL_REFUSED",u[u.E_BAD_REQUEST=200]="E_BAD_REQUEST",u[u.E_INTERNAL_ERROR=300]="E_INTERNAL_ERROR"})(o||(o={})),function(u){u.codec=()=>Ve(o)}(n=e.ResponseStatus||(e.ResponseStatus={}));let s;(function(u){let h;u.codec=()=>(h==null&&(h=Zt((f,l,p={})=>{if(p.lengthDelimited!==!1&&l.fork(),f.id!=null&&(l.uint32(10),l.bytes(f.id)),f.addrs!=null)for(let d of f.addrs)l.uint32(18),l.bytes(d);p.lengthDelimited!==!1&&l.ldelim()},(f,l,p={})=>{let d={addrs:[]},x=l==null?f.len:f.pos+l;for(;f.pos<x;){let E=f.uint32();switch(E>>>3){case 1:{d.id=f.bytes();break}case 2:{if(p.limits?.addrs!=null&&d.addrs.length===p.limits.addrs)throw new sn('Decode error - map field "addrs" had too many elements');d.addrs.push(f.bytes());break}default:{f.skipType(E&7);break}}}return d})),h),u.encode=f=>Gt(f,u.codec()),u.decode=(f,l)=>$t(f,u.codec(),l)})(s=e.PeerInfo||(e.PeerInfo={}));let i;(function(u){let h;u.codec=()=>(h==null&&(h=Zt((f,l,p={})=>{p.lengthDelimited!==!1&&l.fork(),f.peer!=null&&(l.uint32(10),e.PeerInfo.codec().encode(f.peer,l)),p.lengthDelimited!==!1&&l.ldelim()},(f,l,p={})=>{let d={},x=l==null?f.len:f.pos+l;for(;f.pos<x;){let E=f.uint32();switch(E>>>3){case 1:{d.peer=e.PeerInfo.codec().decode(f,f.uint32(),{limits:p.limits?.peer});break}default:{f.skipType(E&7);break}}}return d})),h),u.encode=f=>Gt(f,u.codec()),u.decode=(f,l)=>$t(f,u.codec(),l)})(i=e.Dial||(e.Dial={}));let c;(function(u){let h;u.codec=()=>(h==null&&(h=Zt((f,l,p={})=>{p.lengthDelimited!==!1&&l.fork(),f.status!=null&&(l.uint32(8),e.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)),p.lengthDelimited!==!1&&l.ldelim()},(f,l,p={})=>{let d={},x=l==null?f.len:f.pos+l;for(;f.pos<x;){let E=f.uint32();switch(E>>>3){case 1:{d.status=e.ResponseStatus.codec().decode(f);break}case 2:{d.statusText=f.string();break}case 3:{d.addr=f.bytes();break}default:{f.skipType(E&7);break}}}return d})),h),u.encode=f=>Gt(f,u.codec()),u.decode=(f,l)=>$t(f,u.codec(),l)})(c=e.DialResponse||(e.DialResponse={}));let a;e.codec=()=>(a==null&&(a=Zt((u,h,f={})=>{f.lengthDelimited!==!1&&h.fork(),u.type!=null&&(h.uint32(8),e.MessageType.codec().encode(u.type,h)),u.dial!=null&&(h.uint32(18),e.Dial.codec().encode(u.dial,h)),u.dialResponse!=null&&(h.uint32(26),e.DialResponse.codec().encode(u.dialResponse,h)),f.lengthDelimited!==!1&&h.ldelim()},(u,h,f={})=>{let l={},p=h==null?u.len:u.pos+h;for(;u.pos<p;){let d=u.uint32();switch(d>>>3){case 1:{l.type=e.MessageType.codec().decode(u);break}case 2:{l.dial=e.Dial.codec().decode(u,u.uint32(),{limits:f.limits?.dial});break}case 3:{l.dialResponse=e.DialResponse.codec().decode(u,u.uint32(),{limits:f.limits?.dialResponse});break}default:{u.skipType(d&7);break}}}return l})),a),e.encode=u=>Gt(u,e.codec()),e.decode=(u,h)=>$t(u,e.codec(),h)})(H||(H={}));var xh=4,wh=8,zn=class{components;protocol;timeout;maxInboundStreams;maxOutboundStreams;maxMessageSize;started;log;topologyId;dialResults;findPeers;addressFilter;connectionThreshold;constructor(t,r){this.components=t,this.log=t.logger.forComponent("libp2p:auto-nat"),this.started=!1,this.protocol=`/${r.protocolPrefix??wc}/${Ec}/${_c}`,this.timeout=r.timeout??3e4,this.maxInboundStreams=r.maxInboundStreams??2,this.maxOutboundStreams=r.maxOutboundStreams??20,this.connectionThreshold=r.connectionThreshold??80,this.maxMessageSize=r.maxMessageSize??8192,this.dialResults=gc({name:"libp2p_autonat_dial_results",metrics:t.metrics}),this.findPeers=mc(this.findRandomPeers.bind(this),6e4),this.addressFilter=xs(1024)}[Symbol.toStringTag]="@libp2p/autonat";[Gs]=["@libp2p/autonat"];get[Zs](){return["@libp2p/identify"]}isStarted(){return this.started}async start(){this.started||(await this.components.registrar.handle(this.protocol,t=>{this.handleIncomingAutonatStream(t).catch(r=>{this.log.error("error handling incoming autonat stream - %e",r)})},{maxInboundStreams:this.maxInboundStreams,maxOutboundStreams:this.maxOutboundStreams}),this.topologyId=await this.components.registrar.register(this.protocol,{onConnect:(t,r)=>{this.verifyExternalAddresses(r).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 r=Un([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:r})){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:r})}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 r=AbortSignal.timeout(this.timeout);let n=Vs(t.stream,{maxDataLength:this.maxMessageSize}).pb(H);try{let o=await n.read({signal:r}),s=await this.handleAutonatMessage(o,t.connection,{signal:r});await n.write(s,{signal:r}),await n.unwrap().unwrap().close({signal:r})}catch(o){this.log.error("error handling incoming autonat stream - %e",o),t.stream.abort(o)}}async handleAutonatMessage(t,r,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:H.MessageType.DIAL_RESPONSE,dialResponse:{status:H.ResponseStatus.E_BAD_REQUEST,statusText:"No Dial message found in message"}};let i,c=s.peer;if(c?.id==null)return this.log.error("PeerId missing from message"),{type:H.MessageType.DIAL_RESPONSE,dialResponse:{status:H.ResponseStatus.E_BAD_REQUEST,statusText:"missing peer info"}};try{let f=le(c.id);i=pn(f)}catch(f){return this.log.error("invalid PeerId - %e",f),{type:H.MessageType.DIAL_RESPONSE,dialResponse:{status:H.ResponseStatus.E_BAD_REQUEST,statusText:"bad peer id"}}}if(this.log("incoming request from %p",i),!r.remotePeer.equals(i))return this.log("target peer %p did not equal sending peer %p",i,r.remotePeer),{type:H.MessageType.DIAL_RESPONSE,dialResponse:{status:H.ResponseStatus.E_BAD_REQUEST,statusText:"peer id mismatch"}};let a=c.addrs.map(f=>Lr(f)).filter(f=>{try{let l=f.toOptions();return ks(f)?!1:l.host!==r.remoteAddr.toOptions().host?(this.log.trace("not dialing %a - target host did not match remote host %a",f,r.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(a.length===0)return this.log("refused to dial all multiaddrs for %p from message",i),{type:H.MessageType.DIAL_RESPONSE,dialResponse:{status:H.ResponseStatus.E_DIAL_REFUSED,statusText:"no dialable addresses"}};this.log("dial multiaddrs %s for peer %p",a.map(f=>f.toString()).join(", "),i);let u="",h=a[0];for(let f of a){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:H.MessageType.DIAL_RESPONSE,dialResponse:{status:H.ResponseStatus.OK,addr:l.remoteAddr.decapsulateCode(ac("p2p").code).bytes}}}catch(p){this.log.error("could not dial %p - %e",i,p),u=p.message}finally{l!=null&&await l.close()}}return{type:H.MessageType.DIAL_RESPONSE,dialResponse:{status:H.ResponseStatus.E_DIAL_ERROR,statusText:u,addr:h.bytes}}}getFirstUnverifiedMultiaddr(t,r){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&&(!r||!cc(o.multiaddr))||ks(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 c=o.expires<Date.now();if(c&&this.addressFilter.remove?.(s),this.addressFilter.has(s))continue;this.addressFilter.add(s),this.log.trace("creating dial result %s %s",c?"to revalidate":"for",s),i={multiaddr:o.multiaddr,success:0,failure:0,networkSegments:[],verifyingPeers:ms(),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:r})=>r<Date.now()).map(({multiaddr:r})=>r.toString()));for(let r of this.dialResults.keys())t.has(r)||(this.log.trace("remove results for %a",r),this.dialResults.delete(r))}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,r,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 c=Vs(i).pb(H),[,a]=await Promise.all([c.write({type:H.MessageType.DIAL,dial:{peer:{id:this.components.peerId.toMultihash().bytes,addrs:[n.multiaddr.bytes]}}},{signal:s}),c.read({signal:s})]);if(a.type!==H.MessageType.DIAL_RESPONSE||a.dialResponse==null){this.log("invalid autonat response from %p - %j",t.remotePeer,a);return}let u=a.dialResponse.status;if(this.log.trace("autonat response from %p for %a is %s",t.remotePeer,n.multiaddr,u),u!==H.ResponseStatus.OK&&u!==H.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,a.dialResponse.status);return}if(o.networkSegments.includes(r)){this.log.trace("%a results included network segment %s",n.multiaddr,r);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(r),u===H.ResponseStatus.OK){if(o.success++,o.type!=="observed"){this.confirmAddress(o);return}}else u===H.ResponseStatus.E_DIAL_ERROR&&o.failure++;this.log("%a success %d failure %d",o.multiaddr,o.success,o.failure),o.success===xh&&this.confirmAddress(o),o.failure===wh&&this.unconfirmAddress(o)}finally{try{await i.close({signal:s})}catch(c){i.abort(c)}}}hasConnectionCapacity(){let r=this.components.connectionManager.getConnections().length,n=this.components.connectionManager.getMaxConnections();return r/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 r=t.toOptions();return r.family===4?r.host.split(".")[0].padStart(3,"0"):r.host.split(":")[0].padStart(4,"0")}};function Eh(e={}){return t=>new zn(t,e)}return Dc(_h);})();
|
|
3
3
|
/*! Bundled license information:
|
|
4
4
|
|
|
5
5
|
@noble/hashes/esm/utils.js:
|