@libp2p/circuit-relay-v2 4.2.6-a34745c01 → 4.2.7
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 +4 -4
- package/dist/typedoc-urls.json +41 -0
- package/package.json +13 -13
package/dist/index.min.js
CHANGED
|
@@ -1,5 +1,5 @@
|
|
|
1
1
|
(function (root, factory) {(typeof module === 'object' && module.exports) ? module.exports = factory() : root.Libp2PCircuitRelayV2 = factory()}(typeof self !== 'undefined' ? self : this, function () {
|
|
2
|
-
"use strict";var Libp2PCircuitRelayV2=(()=>{var _s=Object.defineProperty;var bd=Object.getOwnPropertyDescriptor;var wd=Object.getOwnPropertyNames;var xd=Object.prototype.hasOwnProperty;var J=(r,e)=>{for(var t in e)_s(r,t,{get:e[t],enumerable:!0})},Ed=(r,e,t,n)=>{if(e&&typeof e=="object"||typeof e=="function")for(let s of wd(e))!xd.call(r,s)&&s!==t&&_s(r,s,{get:()=>e[s],enumerable:!(n=bd(e,s))||n.enumerable});return r};var Sd=r=>Ed(_s({},"__esModule",{value:!0}),r);var Ny={};J(Ny,{RELAY_V2_HOP_CODEC:()=>Ke,RELAY_V2_STOP_CODEC:()=>fr,circuitRelayServer:()=>Oy,circuitRelayTransport:()=>Py});function vd(r){return typeof r?.handleEvent=="function"}function _d(r){return(r!==!0&&r!==!1&&r?.once)??!1}var Ie=class extends EventTarget{#e=new Map;constructor(){super()}listenerCount(e){let t=this.#e.get(e);return t==null?0:t.length}addEventListener(e,t,n){let s=_d(n);super.addEventListener(e,i=>{if(s){let a=this.#e.get(i.type);a!=null&&(a=a.filter(({callback:c})=>c!==t),this.#e.set(i.type,a))}vd(t)?t.handleEvent(i):t(i)},n);let o=this.#e.get(e);o==null&&(o=[],this.#e.set(e,o)),o.push({callback:t,once:s})}removeEventListener(e,t,n){super.removeEventListener(e.toString(),t??null,n);let s=this.#e.get(e);s!=null&&(s=s.filter(({callback:o})=>o!==t),this.#e.set(e,s))}safeDispatchEvent(e,t={}){return this.dispatchEvent(new CustomEvent(e,t))}};var st=class extends Error{static name="AbortError";constructor(e="The operation was aborted"){super(e),this.name="AbortError"}};var se=class extends Error{static name="InvalidParametersError";constructor(e="Invalid parameters"){super(e),this.name="InvalidParametersError"}},pr=class extends Error{static name="InvalidPublicKeyError";constructor(e="Invalid public key"){super(e),this.name="InvalidPublicKeyError"}};var jn=class extends Error{static name="StreamResetError";constructor(e="The stream has been reset"){super(e),this.name="StreamResetError"}};var xt=class extends Error{static name="StreamStateError";constructor(e="The stream is in an invalid state"){super(e),this.name="StreamStateError"}},Jr=class extends Error{static name="StreamBufferError";constructor(e="The stream buffer was full"){super(e),this.name="StreamBufferError"}};var Wn=class extends Error{static name="InvalidCIDError";constructor(e="Invalid CID"){super(e),this.name="InvalidCIDError"}},Gn=class extends Error{static name="InvalidMultihashError";constructor(e="Invalid Multihash"){super(e),this.name="InvalidMultihashError"}};var Yn=class extends Error{static name="InvalidMessageError";constructor(e="Invalid message"){super(e),this.name="InvalidMessageError"}};var Zn=class extends Error{static name="DialError";constructor(e="Dial error"){super(e),this.name="DialError"}},zt=class extends Error{static name="ListenError";constructor(e="Listen error"){super(e),this.name="ListenError"}};var mr=class extends Error{static name="UnsupportedKeyTypeError";constructor(e="Unsupported key type"){super(e),this.name="UnsupportedKeyTypeError"}};var Xn=class extends Event{data;constructor(e,t){super("message",t),this.data=e}},yr=class extends Event{error;local;constructor(e,t,n){super("close",n),this.error=t,this.local=e}},Qn=class extends yr{constructor(e,t){super(!0,e,t)}},Jn=class extends yr{constructor(e,t){super(!1,e,t)}};var As=Symbol.for("@libp2p/peer-id");var zc="keep-alive";function Vc(r){return r!=null&&typeof r.start=="function"&&typeof r.stop=="function"}async function Hc(...r){let e=[];for(let t of r)Vc(t)&&e.push(t);await Promise.all(e.map(async t=>{t.beforeStart!=null&&await t.beforeStart()})),await Promise.all(e.map(async t=>{await t.start()})),await Promise.all(e.map(async t=>{t.afterStart!=null&&await t.afterStart()}))}async function $c(...r){let e=[];for(let t of r)Vc(t)&&e.push(t);await Promise.all(e.map(async t=>{t.beforeStop!=null&&await t.beforeStop()})),await Promise.all(e.map(async t=>{await t.stop()})),await Promise.all(e.map(async t=>{t.afterStop!=null&&await t.afterStop()}))}var Wc=Symbol.for("@libp2p/transport");var jc;(function(r){r[r.FATAL_ALL=0]="FATAL_ALL",r[r.NO_FATAL=1]="NO_FATAL"})(jc||(jc={}));var Gc=Symbol.for("@libp2p/service-capabilities"),Yc=Symbol.for("@libp2p/service-dependencies");var Ls={};J(Ls,{base58btc:()=>re,base58flickr:()=>Rd});var mg=new Uint8Array(0);function Zc(r,e){if(r===e)return!0;if(r.byteLength!==e.byteLength)return!1;for(let t=0;t<r.byteLength;t++)if(r[t]!==e[t])return!1;return!0}function it(r){if(r instanceof Uint8Array&&r.constructor.name==="Uint8Array")return Vt(r);if(r instanceof ArrayBuffer)return new Uint8Array(r);if(ArrayBuffer.isView(r))return Vt(new Uint8Array(r.buffer,r.byteOffset,r.byteLength));throw new Error("Unknown type, must be binary type")}function Xc(r){return new TextEncoder().encode(r)}function Qc(r){return new TextDecoder().decode(r)}function Ad(r){return r?.buffer instanceof ArrayBuffer}function Vt(r){return Ad(r)?r:r.slice()}function Td(r,e){if(r.length>=255)throw new TypeError("Alphabet too long");for(var t=new Uint8Array(256),n=0;n<t.length;n++)t[n]=255;for(var s=0;s<r.length;s++){var o=r.charAt(s),i=o.charCodeAt(0);if(t[i]!==255)throw new TypeError(o+" is ambiguous");t[i]=s}var a=r.length,c=r.charAt(0),u=Math.log(a)/Math.log(256),l=Math.log(256)/Math.log(a);function f(p){if(p instanceof Uint8Array||(ArrayBuffer.isView(p)?p=new Uint8Array(p.buffer,p.byteOffset,p.byteLength):Array.isArray(p)&&(p=Uint8Array.from(p))),!(p instanceof Uint8Array))throw new TypeError("Expected Uint8Array");if(p.length===0)return"";for(var b=0,h=0,g=0,E=p.length;g!==E&&p[g]===0;)g++,b++;for(var v=(E-g)*l+1>>>0,I=new Uint8Array(v);g!==E;){for(var D=p[g],P=0,B=v-1;(D!==0||P<h)&&B!==-1;B--,P++)D+=256*I[B]>>>0,I[B]=D%a>>>0,D=D/a>>>0;if(D!==0)throw new Error("Non-zero carry");h=P,g++}for(var T=v-h;T!==v&&I[T]===0;)T++;for(var U=c.repeat(b);T<v;++T)U+=r.charAt(I[T]);return U}function m(p){if(typeof p!="string")throw new TypeError("Expected String");if(p.length===0)return new Uint8Array;var b=0;if(p[b]!==" "){for(var h=0,g=0;p[b]===c;)h++,b++;for(var E=(p.length-b)*u+1>>>0,v=new Uint8Array(E);p[b];){var I=t[p.charCodeAt(b)];if(I===255)return;for(var D=0,P=E-1;(I!==0||D<g)&&P!==-1;P--,D++)I+=a*v[P]>>>0,v[P]=I%256>>>0,I=I/256>>>0;if(I!==0)throw new Error("Non-zero carry");g=D,b++}if(p[b]!==" "){for(var B=E-g;B!==E&&v[B]===0;)B++;for(var T=new Uint8Array(h+(E-B)),U=h;B!==E;)T[U++]=v[B++];return T}}}function d(p){var b=m(p);if(b)return b;throw new Error(`Non-${e} character`)}return{encode:f,decodeUnsafe:m,decode:d}}var Dd=Td,Id=Dd,eu=Id;var Ts=class{name;prefix;baseEncode;constructor(e,t,n){this.name=e,this.prefix=t,this.baseEncode=n}encode(e){if(e instanceof Uint8Array)return`${this.prefix}${this.baseEncode(e)}`;throw Error("Unknown type, must be binary type")}},Ds=class{name;prefix;baseDecode;prefixCodePoint;constructor(e,t,n){this.name=e,this.prefix=t;let s=t.codePointAt(0);if(s===void 0)throw new Error("Invalid prefix character");this.prefixCodePoint=s,this.baseDecode=n}decode(e){if(typeof e=="string"){if(e.codePointAt(0)!==this.prefixCodePoint)throw Error(`Unable to decode multibase string ${JSON.stringify(e)}, ${this.name} decoder only supports inputs prefixed with ${this.prefix}`);return this.baseDecode(e.slice(this.prefix.length))}else throw Error("Can only multibase decode strings")}or(e){return tu(this,e)}},Is=class{decoders;constructor(e){this.decoders=e}or(e){return tu(this,e)}decode(e){let t=e[0],n=this.decoders[t];if(n!=null)return n.decode(e);throw RangeError(`Unable to decode multibase string ${JSON.stringify(e)}, only inputs prefixed with ${Object.keys(this.decoders)} are supported`)}};function tu(r,e){return new Is({...r.decoders??{[r.prefix]:r},...e.decoders??{[e.prefix]:e}})}var Cs=class{name;prefix;baseEncode;baseDecode;encoder;decoder;constructor(e,t,n,s){this.name=e,this.prefix=t,this.baseEncode=n,this.baseDecode=s,this.encoder=new Ts(e,t,n),this.decoder=new Ds(e,t,s)}encode(e){return this.encoder.encode(e)}decode(e){return this.decoder.decode(e)}};function gr({name:r,prefix:e,encode:t,decode:n}){return new Cs(r,e,t,n)}function Et({name:r,prefix:e,alphabet:t}){let{encode:n,decode:s}=eu(t,r);return gr({prefix:e,name:r,encode:n,decode:o=>it(s(o))})}function Cd(r,e,t,n){let s=r.length;for(;r[s-1]==="=";)--s;let o=new Uint8Array(s*t/8|0),i=0,a=0,c=0;for(let u=0;u<s;++u){let l=e[r[u]];if(l===void 0)throw new SyntaxError(`Non-${n} character`);a=a<<t|l,i+=t,i>=8&&(i-=8,o[c++]=255&a>>i)}if(i>=t||(255&a<<8-i)!==0)throw new SyntaxError("Unexpected end of data");return o}function Ld(r,e,t){let n=e[e.length-1]==="=",s=(1<<t)-1,o="",i=0,a=0;for(let c=0;c<r.length;++c)for(a=a<<8|r[c],i+=8;i>t;)i-=t,o+=e[s&a>>i];if(i!==0&&(o+=e[s&a<<t-i]),n)for(;(o.length*t&7)!==0;)o+="=";return o}function Bd(r){let e={};for(let t=0;t<r.length;++t)e[r[t]]=t;return e}function ie({name:r,prefix:e,bitsPerChar:t,alphabet:n}){let s=Bd(n);return gr({prefix:e,name:r,encode(o){return Ld(o,n,t)},decode(o){return Cd(o,s,t,r)}})}var re=Et({name:"base58btc",prefix:"z",alphabet:"123456789ABCDEFGHJKLMNPQRSTUVWXYZabcdefghijkmnopqrstuvwxyz"}),Rd=Et({name:"base58flickr",prefix:"Z",alphabet:"123456789abcdefghijkmnopqrstuvwxyzABCDEFGHJKLMNPQRSTUVWXYZ"});var Bs={};J(Bs,{base32:()=>St,base32hex:()=>Ud,base32hexpad:()=>Fd,base32hexpadupper:()=>Md,base32hexupper:()=>kd,base32pad:()=>Pd,base32padupper:()=>Nd,base32upper:()=>Od,base32z:()=>Kd});var St=ie({prefix:"b",name:"base32",alphabet:"abcdefghijklmnopqrstuvwxyz234567",bitsPerChar:5}),Od=ie({prefix:"B",name:"base32upper",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZ234567",bitsPerChar:5}),Pd=ie({prefix:"c",name:"base32pad",alphabet:"abcdefghijklmnopqrstuvwxyz234567=",bitsPerChar:5}),Nd=ie({prefix:"C",name:"base32padupper",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZ234567=",bitsPerChar:5}),Ud=ie({prefix:"v",name:"base32hex",alphabet:"0123456789abcdefghijklmnopqrstuv",bitsPerChar:5}),kd=ie({prefix:"V",name:"base32hexupper",alphabet:"0123456789ABCDEFGHIJKLMNOPQRSTUV",bitsPerChar:5}),Fd=ie({prefix:"t",name:"base32hexpad",alphabet:"0123456789abcdefghijklmnopqrstuv=",bitsPerChar:5}),Md=ie({prefix:"T",name:"base32hexpadupper",alphabet:"0123456789ABCDEFGHIJKLMNOPQRSTUV=",bitsPerChar:5}),Kd=ie({prefix:"h",name:"base32z",alphabet:"ybndrfg8ejkmcpqxot1uwisza345h769",bitsPerChar:5});var Rs={};J(Rs,{base36:()=>en,base36upper:()=>qd});var en=Et({prefix:"k",name:"base36",alphabet:"0123456789abcdefghijklmnopqrstuvwxyz"}),qd=Et({prefix:"K",name:"base36upper",alphabet:"0123456789ABCDEFGHIJKLMNOPQRSTUVWXYZ"});var zd=ou,ru=128,Vd=127,Hd=~Vd,$d=Math.pow(2,31);function ou(r,e,t){e=e||[],t=t||0;for(var n=t;r>=$d;)e[t++]=r&255|ru,r/=128;for(;r&Hd;)e[t++]=r&255|ru,r>>>=7;return e[t]=r|0,ou.bytes=t-n+1,e}var jd=Os,Wd=128,nu=127;function Os(r,n){var t=0,n=n||0,s=0,o=n,i,a=r.length;do{if(o>=a)throw Os.bytes=0,new RangeError("Could not decode varint");i=r[o++],t+=s<28?(i&nu)<<s:(i&nu)*Math.pow(2,s),s+=7}while(i>=Wd);return Os.bytes=o-n,t}var Gd=Math.pow(2,7),Yd=Math.pow(2,14),Zd=Math.pow(2,21),Xd=Math.pow(2,28),Qd=Math.pow(2,35),Jd=Math.pow(2,42),eh=Math.pow(2,49),th=Math.pow(2,56),rh=Math.pow(2,63),nh=function(r){return r<Gd?1:r<Yd?2:r<Zd?3:r<Xd?4:r<Qd?5:r<Jd?6:r<eh?7:r<th?8:r<rh?9:10},oh={encode:zd,decode:jd,encodingLength:nh},sh=oh,tn=sh;function rn(r,e=0){return[tn.decode(r,e),tn.decode.bytes]}function br(r,e,t=0){return tn.encode(r,e,t),e}function wr(r){return tn.encodingLength(r)}function Ze(r,e){let t=e.byteLength,n=wr(r),s=n+wr(t),o=new Uint8Array(s+t);return br(r,o,0),br(t,o,n),o.set(e,s),new xr(r,t,e,o)}function Xe(r){let e=it(r),[t,n]=rn(e),[s,o]=rn(e.subarray(n)),i=e.subarray(n+o);if(i.byteLength!==s)throw new Error("Incorrect length");return new xr(t,s,i,e)}function su(r,e){if(r===e)return!0;{let t=e;return r.code===t.code&&r.size===t.size&&t.bytes instanceof Uint8Array&&Zc(r.bytes,t.bytes)}}var xr=class{code;size;digest;bytes;constructor(e,t,n,s){this.code=e,this.size=t,this.digest=Vt(n),this.bytes=Vt(s)}};function iu(r,e){let{bytes:t,version:n}=r;return n===0?ah(t,Ps(r),e??re.encoder):ch(t,Ps(r),e??St.encoder)}var au=new WeakMap;function Ps(r){let e=au.get(r);if(e==null){let t=new Map;return au.set(r,t),t}return e}var fe=class r{code;version;multihash;bytes;"/";constructor(e,t,n,s){this.code=t,this.version=e,this.multihash=n,this.bytes=Vt(s),this["/"]=this.bytes}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:e,multihash:t}=this;if(e!==nn)throw new Error("Cannot convert a non dag-pb CID to CIDv0");if(t.code!==uh)throw new Error("Cannot convert non sha2-256 multihash CID to CIDv0");return r.createV0(t)}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:e,digest:t}=this.multihash,n=Ze(e,t);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(e){return r.equals(this,e)}static equals(e,t){let n=t;return n!=null&&e.code===n.code&&e.version===n.version&&su(e.multihash,n.multihash)}toString(e){return iu(this,e)}toJSON(){return{"/":iu(this)}}link(){return this}[Symbol.toStringTag]="CID";[Symbol.for("nodejs.util.inspect.custom")](){return`CID(${this.toString()})`}static asCID(e){if(e==null)return null;let t=e;if(t instanceof r)return t;if(t["/"]!=null&&t["/"]===t.bytes||t.asCID===t){let{version:n,code:s,multihash:o,bytes:i}=t;return new r(n,s,o,i??cu(n,s,o.bytes))}else if(t[lh]===!0){let{version:n,multihash:s,code:o}=t,i=Xe(s);return r.create(n,o,i)}else return null}static create(e,t,n){if(typeof t!="number")throw new Error("String codecs are no longer supported");if(!(n.bytes instanceof Uint8Array))throw new Error("Invalid digest");switch(e){case 0:{if(t!==nn)throw new Error(`Version 0 CID must use dag-pb (code: ${nn}) block encoding`);return new r(e,t,n,n.bytes)}case 1:{let s=cu(e,t,n.bytes);return new r(e,t,n,s)}default:throw new Error("Invalid version")}}static createV0(e){return r.create(0,nn,e)}static createV1(e,t){return r.create(1,e,t)}static decode(e){let[t,n]=r.decodeFirst(e);if(n.length!==0)throw new Error("Incorrect length");return t}static decodeFirst(e){let t=r.inspectBytes(e),n=t.size-t.multihashSize,s=it(e.subarray(n,n+t.multihashSize));if(s.byteLength!==t.multihashSize)throw new Error("Incorrect length");let o=s.subarray(t.multihashSize-t.digestSize),i=new xr(t.multihashCode,t.digestSize,o,s);return[t.version===0?r.createV0(i):r.createV1(t.codec,i),e.subarray(t.size)]}static inspectBytes(e){let t=0,n=()=>{let[f,m]=rn(e.subarray(t));return t+=m,f},s=n(),o=nn;if(s===18?(s=0,t=0):o=n(),s!==0&&s!==1)throw new RangeError(`Invalid CID version ${s}`);let i=t,a=n(),c=n(),u=t+c,l=u-i;return{version:s,codec:o,multihashCode:a,digestSize:c,multihashSize:l,size:u}}static parse(e,t){let[n,s]=ih(e,t),o=r.decode(s);if(o.version===0&&e[0]!=="Q")throw Error("Version 0 CID string must not include multibase prefix");return Ps(o).set(n,e),o}};function ih(r,e){switch(r[0]){case"Q":{let t=e??re;return[re.prefix,t.decode(`${re.prefix}${r}`)]}case re.prefix:{let t=e??re;return[re.prefix,t.decode(r)]}case St.prefix:{let t=e??St;return[St.prefix,t.decode(r)]}case en.prefix:{let t=e??en;return[en.prefix,t.decode(r)]}default:{if(e==null)throw Error("To parse non base32, base36 or base58btc encoded CID multibase decoder must be provided");return[r[0],e.decode(r)]}}}function ah(r,e,t){let{prefix:n}=t;if(n!==re.prefix)throw Error(`Cannot string encode V0 in ${t.name} encoding`);let s=e.get(n);if(s==null){let o=t.encode(r).slice(1);return e.set(n,o),o}else return s}function ch(r,e,t){let{prefix:n}=t,s=e.get(n);if(s==null){let o=t.encode(r);return e.set(n,o),o}else return s}var nn=112,uh=18;function cu(r,e,t){let n=wr(r),s=n+wr(e),o=new Uint8Array(s+t.byteLength);return br(r,o,0),br(e,o,n),o.set(t,s),o}var lh=Symbol.for("@ipld/js-cid/CID");var Ns={};J(Ns,{identity:()=>qe});var uu=0,fh="identity",lu=it;function dh(r,e){if(e?.truncate!=null&&e.truncate!==r.byteLength){if(e.truncate<0||e.truncate>r.byteLength)throw new Error(`Invalid truncate option, must be less than or equal to ${r.byteLength}`);r=r.subarray(0,e.truncate)}return Ze(uu,lu(r))}var qe={code:uu,name:fh,encode:lu,digest:dh};function he(r,e){if(r===e)return!0;if(r.byteLength!==e.byteLength)return!1;for(let t=0;t<r.byteLength;t++)if(r[t]!==e[t])return!1;return!0}function hh(r){return r.buffer instanceof ArrayBuffer}function Pe(r){return hh(r)?r:r.slice()}async function fu(r,e,t,n){let s=await crypto.subtle.importKey("jwk",r,{name:"ECDSA",namedCurve:r.crv??"P-256"},!1,["verify"]);n?.signal?.throwIfAborted();let o=await crypto.subtle.verify({name:"ECDSA",hash:{name:"SHA-256"}},s,Pe(e),Pe(t.subarray()));return n?.signal?.throwIfAborted(),o}function ct(r=0){return new Uint8Array(r)}function on(r=0){return new Uint8Array(r)}function Us(r,e){e==null&&(e=r.reduce((s,o)=>s+o.length,0));let t=on(e),n=0;for(let s of r)t.set(s,n),n+=s.length;return t}function du(r,e){if(r===e)return!0;if(r.byteLength!==e.byteLength)return!1;for(let t=0;t<r.byteLength;t++)if(r[t]!==e[t])return!1;return!0}var pu=Symbol.for("@achingbrain/uint8arraylist");function hu(r,e){if(e==null||e<0)throw new RangeError("index is out of bounds");let t=0;for(let n of r){let s=t+n.byteLength;if(e<s)return{buf:n,index:e-t};t=s}throw new RangeError("index is out of bounds")}function to(r){return!!r?.[pu]}var ee=class r{bufs;length;[pu]=!0;constructor(...e){this.bufs=[],this.length=0,e.length>0&&this.appendAll(e)}*[Symbol.iterator](){yield*this.bufs}get byteLength(){return this.length}append(...e){this.appendAll(e)}appendAll(e){let t=0;for(let n of e)if(n instanceof Uint8Array)t+=n.byteLength,this.bufs.push(n);else if(to(n)){t+=n.byteLength;for(let s of n.bufs)this.bufs.push(s)}else throw new Error("Could not append value, must be an Uint8Array or a Uint8ArrayList");this.length+=t}prepend(...e){this.prependAll(e)}prependAll(e){let t=0;for(let n of e.reverse())if(n instanceof Uint8Array)t+=n.byteLength,this.bufs.unshift(n);else if(to(n))t+=n.byteLength,this.bufs.unshift(...n.bufs);else throw new Error("Could not prepend value, must be an Uint8Array or a Uint8ArrayList");this.length+=t}get(e){let t=hu(this.bufs,e);return t.buf[t.index]}set(e,t){let n=hu(this.bufs,e);n.buf[n.index]=t}write(e,t=0){if(e instanceof Uint8Array)for(let n=0;n<e.length;n++)this.set(t+n,e[n]);else if(to(e))for(let n=0;n<e.length;n++)this.set(t+n,e.get(n));else throw new Error("Could not write value, must be an Uint8Array or a Uint8ArrayList")}consume(e){if(e=Math.trunc(e),!(Number.isNaN(e)||e<=0)){if(e===this.byteLength){this.bufs=[],this.length=0;return}for(;this.bufs.length>0;)if(e>=this.bufs[0].byteLength)e-=this.bufs[0].byteLength,this.length-=this.bufs[0].byteLength,this.bufs.shift();else{this.bufs[0]=this.bufs[0].subarray(e),this.length-=e;break}}}slice(e,t){let{bufs:n,length:s}=this._subList(e,t);return Us(n,s)}subarray(e,t){let{bufs:n,length:s}=this._subList(e,t);return n.length===1?n[0]:Us(n,s)}sublist(e,t){let{bufs:n,length:s}=this._subList(e,t),o=new r;return o.length=s,o.bufs=n,o}_subList(e,t){if(e=e??0,t=t??this.length,e<0&&(e=this.length+e),t<0&&(t=this.length+t),e<0||t>this.length)throw new RangeError("index is out of bounds");if(e===t)return{bufs:[],length:0};if(e===0&&t===this.length)return{bufs:[...this.bufs],length:this.length};let n=[],s=0;for(let o=0;o<this.bufs.length;o++){let i=this.bufs[o],a=s,c=a+i.byteLength;if(s=c,e>=c)continue;let u=e>=a&&e<c,l=t>a&&t<=c;if(u&&l){if(e===a&&t===c){n.push(i);break}let f=e-a;n.push(i.subarray(f,f+(t-e)));break}if(u){if(e===0){n.push(i);continue}n.push(i.subarray(e-a));continue}if(l){if(t===c){n.push(i);break}n.push(i.subarray(0,t-a));break}n.push(i)}return{bufs:n,length:t-e}}indexOf(e,t=0){if(!to(e)&&!(e instanceof Uint8Array))throw new TypeError('The "value" argument must be a Uint8ArrayList or Uint8Array');let n=e instanceof Uint8Array?e:e.subarray();if(t=Number(t??0),isNaN(t)&&(t=0),t<0&&(t=this.length+t),t<0&&(t=0),e.length===0)return t>this.length?this.length:t;let s=n.byteLength;if(s===0)throw new TypeError("search must be at least 1 byte long");let o=256,i=new Int32Array(o);for(let f=0;f<o;f++)i[f]=-1;for(let f=0;f<s;f++)i[n[f]]=f;let a=i,c=this.byteLength-n.byteLength,u=n.byteLength-1,l;for(let f=t;f<=c;f+=l){l=0;for(let m=u;m>=0;m--){let d=this.get(f+m);if(n[m]!==d){l=Math.max(1,m-a[d]);break}}if(l===0)return f}return-1}getInt8(e){let t=this.subarray(e,e+1);return new DataView(t.buffer,t.byteOffset,t.byteLength).getInt8(0)}setInt8(e,t){let n=on(1);new DataView(n.buffer,n.byteOffset,n.byteLength).setInt8(0,t),this.write(n,e)}getInt16(e,t){let n=this.subarray(e,e+2);return new DataView(n.buffer,n.byteOffset,n.byteLength).getInt16(0,t)}setInt16(e,t,n){let s=ct(2);new DataView(s.buffer,s.byteOffset,s.byteLength).setInt16(0,t,n),this.write(s,e)}getInt32(e,t){let n=this.subarray(e,e+4);return new DataView(n.buffer,n.byteOffset,n.byteLength).getInt32(0,t)}setInt32(e,t,n){let s=ct(4);new DataView(s.buffer,s.byteOffset,s.byteLength).setInt32(0,t,n),this.write(s,e)}getBigInt64(e,t){let n=this.subarray(e,e+8);return new DataView(n.buffer,n.byteOffset,n.byteLength).getBigInt64(0,t)}setBigInt64(e,t,n){let s=ct(8);new DataView(s.buffer,s.byteOffset,s.byteLength).setBigInt64(0,t,n),this.write(s,e)}getUint8(e){let t=this.subarray(e,e+1);return new DataView(t.buffer,t.byteOffset,t.byteLength).getUint8(0)}setUint8(e,t){let n=on(1);new DataView(n.buffer,n.byteOffset,n.byteLength).setUint8(0,t),this.write(n,e)}getUint16(e,t){let n=this.subarray(e,e+2);return new DataView(n.buffer,n.byteOffset,n.byteLength).getUint16(0,t)}setUint16(e,t,n){let s=ct(2);new DataView(s.buffer,s.byteOffset,s.byteLength).setUint16(0,t,n),this.write(s,e)}getUint32(e,t){let n=this.subarray(e,e+4);return new DataView(n.buffer,n.byteOffset,n.byteLength).getUint32(0,t)}setUint32(e,t,n){let s=ct(4);new DataView(s.buffer,s.byteOffset,s.byteLength).setUint32(0,t,n),this.write(s,e)}getBigUint64(e,t){let n=this.subarray(e,e+8);return new DataView(n.buffer,n.byteOffset,n.byteLength).getBigUint64(0,t)}setBigUint64(e,t,n){let s=ct(8);new DataView(s.buffer,s.byteOffset,s.byteLength).setBigUint64(0,t,n),this.write(s,e)}getFloat32(e,t){let n=this.subarray(e,e+4);return new DataView(n.buffer,n.byteOffset,n.byteLength).getFloat32(0,t)}setFloat32(e,t,n){let s=ct(4);new DataView(s.buffer,s.byteOffset,s.byteLength).setFloat32(0,t,n),this.write(s,e)}getFloat64(e,t){let n=this.subarray(e,e+8);return new DataView(n.buffer,n.byteOffset,n.byteLength).getFloat64(0,t)}setFloat64(e,t,n){let s=ct(8);new DataView(s.buffer,s.byteOffset,s.byteLength).setFloat64(0,t,n),this.write(s,e)}equals(e){if(e==null||!(e instanceof r)||e.bufs.length!==this.bufs.length)return!1;for(let t=0;t<this.bufs.length;t++)if(!du(this.bufs[t],e.bufs[t]))return!1;return!0}static fromUint8Arrays(e,t){let n=new r;return n.bufs=e,t==null&&(t=e.reduce((s,o)=>s+o.byteLength,0)),n.length=t,n}};var ks={};J(ks,{base10:()=>ph});var ph=Et({prefix:"9",name:"base10",alphabet:"0123456789"});var Fs={};J(Fs,{base16:()=>mh,base16upper:()=>yh});var mh=ie({prefix:"f",name:"base16",alphabet:"0123456789abcdef",bitsPerChar:4}),yh=ie({prefix:"F",name:"base16upper",alphabet:"0123456789ABCDEF",bitsPerChar:4});var Ms={};J(Ms,{base2:()=>gh});var gh=ie({prefix:"0",name:"base2",alphabet:"01",bitsPerChar:1});var Ks={};J(Ks,{base256emoji:()=>Sh});var mu=Array.from("\u{1F680}\u{1FA90}\u2604\u{1F6F0}\u{1F30C}\u{1F311}\u{1F312}\u{1F313}\u{1F314}\u{1F315}\u{1F316}\u{1F317}\u{1F318}\u{1F30D}\u{1F30F}\u{1F30E}\u{1F409}\u2600\u{1F4BB}\u{1F5A5}\u{1F4BE}\u{1F4BF}\u{1F602}\u2764\u{1F60D}\u{1F923}\u{1F60A}\u{1F64F}\u{1F495}\u{1F62D}\u{1F618}\u{1F44D}\u{1F605}\u{1F44F}\u{1F601}\u{1F525}\u{1F970}\u{1F494}\u{1F496}\u{1F499}\u{1F622}\u{1F914}\u{1F606}\u{1F644}\u{1F4AA}\u{1F609}\u263A\u{1F44C}\u{1F917}\u{1F49C}\u{1F614}\u{1F60E}\u{1F607}\u{1F339}\u{1F926}\u{1F389}\u{1F49E}\u270C\u2728\u{1F937}\u{1F631}\u{1F60C}\u{1F338}\u{1F64C}\u{1F60B}\u{1F497}\u{1F49A}\u{1F60F}\u{1F49B}\u{1F642}\u{1F493}\u{1F929}\u{1F604}\u{1F600}\u{1F5A4}\u{1F603}\u{1F4AF}\u{1F648}\u{1F447}\u{1F3B6}\u{1F612}\u{1F92D}\u2763\u{1F61C}\u{1F48B}\u{1F440}\u{1F62A}\u{1F611}\u{1F4A5}\u{1F64B}\u{1F61E}\u{1F629}\u{1F621}\u{1F92A}\u{1F44A}\u{1F973}\u{1F625}\u{1F924}\u{1F449}\u{1F483}\u{1F633}\u270B\u{1F61A}\u{1F61D}\u{1F634}\u{1F31F}\u{1F62C}\u{1F643}\u{1F340}\u{1F337}\u{1F63B}\u{1F613}\u2B50\u2705\u{1F97A}\u{1F308}\u{1F608}\u{1F918}\u{1F4A6}\u2714\u{1F623}\u{1F3C3}\u{1F490}\u2639\u{1F38A}\u{1F498}\u{1F620}\u261D\u{1F615}\u{1F33A}\u{1F382}\u{1F33B}\u{1F610}\u{1F595}\u{1F49D}\u{1F64A}\u{1F639}\u{1F5E3}\u{1F4AB}\u{1F480}\u{1F451}\u{1F3B5}\u{1F91E}\u{1F61B}\u{1F534}\u{1F624}\u{1F33C}\u{1F62B}\u26BD\u{1F919}\u2615\u{1F3C6}\u{1F92B}\u{1F448}\u{1F62E}\u{1F646}\u{1F37B}\u{1F343}\u{1F436}\u{1F481}\u{1F632}\u{1F33F}\u{1F9E1}\u{1F381}\u26A1\u{1F31E}\u{1F388}\u274C\u270A\u{1F44B}\u{1F630}\u{1F928}\u{1F636}\u{1F91D}\u{1F6B6}\u{1F4B0}\u{1F353}\u{1F4A2}\u{1F91F}\u{1F641}\u{1F6A8}\u{1F4A8}\u{1F92C}\u2708\u{1F380}\u{1F37A}\u{1F913}\u{1F619}\u{1F49F}\u{1F331}\u{1F616}\u{1F476}\u{1F974}\u25B6\u27A1\u2753\u{1F48E}\u{1F4B8}\u2B07\u{1F628}\u{1F31A}\u{1F98B}\u{1F637}\u{1F57A}\u26A0\u{1F645}\u{1F61F}\u{1F635}\u{1F44E}\u{1F932}\u{1F920}\u{1F927}\u{1F4CC}\u{1F535}\u{1F485}\u{1F9D0}\u{1F43E}\u{1F352}\u{1F617}\u{1F911}\u{1F30A}\u{1F92F}\u{1F437}\u260E\u{1F4A7}\u{1F62F}\u{1F486}\u{1F446}\u{1F3A4}\u{1F647}\u{1F351}\u2744\u{1F334}\u{1F4A3}\u{1F438}\u{1F48C}\u{1F4CD}\u{1F940}\u{1F922}\u{1F445}\u{1F4A1}\u{1F4A9}\u{1F450}\u{1F4F8}\u{1F47B}\u{1F910}\u{1F92E}\u{1F3BC}\u{1F975}\u{1F6A9}\u{1F34E}\u{1F34A}\u{1F47C}\u{1F48D}\u{1F4E3}\u{1F942}"),bh=mu.reduce((r,e,t)=>(r[t]=e,r),[]),wh=mu.reduce((r,e,t)=>{let n=e.codePointAt(0);if(n==null)throw new Error(`Invalid character: ${e}`);return r[n]=t,r},[]);function xh(r){return r.reduce((e,t)=>(e+=bh[t],e),"")}function Eh(r){let e=[];for(let t of r){let n=t.codePointAt(0);if(n==null)throw new Error(`Invalid character: ${t}`);let s=wh[n];if(s==null)throw new Error(`Non-base256emoji character: ${t}`);e.push(s)}return new Uint8Array(e)}var Sh=gr({prefix:"\u{1F680}",name:"base256emoji",encode:xh,decode:Eh});var zs={};J(zs,{base64:()=>vh,base64pad:()=>_h,base64url:()=>qs,base64urlpad:()=>Ah});var vh=ie({prefix:"m",name:"base64",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/",bitsPerChar:6}),_h=ie({prefix:"M",name:"base64pad",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/=",bitsPerChar:6}),qs=ie({prefix:"u",name:"base64url",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789-_",bitsPerChar:6}),Ah=ie({prefix:"U",name:"base64urlpad",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789-_=",bitsPerChar:6});var Vs={};J(Vs,{base8:()=>Th});var Th=ie({prefix:"7",name:"base8",alphabet:"01234567",bitsPerChar:3});var Hs={};J(Hs,{identity:()=>Dh});var Dh=gr({prefix:"\0",name:"identity",encode:r=>Qc(r),decode:r=>Xc(r)});var rb=new TextEncoder,nb=new TextDecoder;var Ws={};J(Ws,{sha256:()=>Er,sha512:()=>Bh});var Lh=20;function js({name:r,code:e,encode:t,minDigestLength:n,maxDigestLength:s}){return new $s(r,e,t,n,s)}var $s=class{name;code;encode;minDigestLength;maxDigestLength;constructor(e,t,n,s,o){this.name=e,this.code=t,this.encode=n,this.minDigestLength=s??Lh,this.maxDigestLength=o}digest(e,t){if(t?.truncate!=null){if(t.truncate<this.minDigestLength)throw new Error(`Invalid truncate option, must be greater than or equal to ${this.minDigestLength}`);if(this.maxDigestLength!=null&&t.truncate>this.maxDigestLength)throw new Error(`Invalid truncate option, must be less than or equal to ${this.maxDigestLength}`)}if(e instanceof Uint8Array){let n=this.encode(e);return n instanceof Uint8Array?yu(n,this.code,t?.truncate):n.then(s=>yu(s,this.code,t?.truncate))}else throw Error("Unknown type, must be binary type")}};function yu(r,e,t){if(t!=null&&t!==r.byteLength){if(t>r.byteLength)throw new Error(`Invalid truncate option, must be less than or equal to ${r.byteLength}`);r=r.subarray(0,t)}return Ze(e,r)}function bu(r){return async e=>new Uint8Array(await crypto.subtle.digest(r,e))}var Er=js({name:"sha2-256",code:18,encode:bu("SHA-256")}),Bh=js({name:"sha2-512",code:19,encode:bu("SHA-512")});var sn={...Hs,...Ms,...Vs,...ks,...Fs,...Bs,...Rs,...Ls,...zs,...Ks},mb={...Ws,...Ns};function Te(r=0){return new Uint8Array(r)}function Ht(r=0){return new Uint8Array(r)}function xu(r,e,t,n){return{name:r,prefix:e,encoder:{name:r,prefix:e,encode:t},decoder:{decode:n}}}var wu=xu("utf8","u",r=>"u"+new TextDecoder("utf8").decode(r),r=>new TextEncoder().encode(r.substring(1))),Gs=xu("ascii","a",r=>{let e="a";for(let t=0;t<r.length;t++)e+=String.fromCharCode(r[t]);return e},r=>{r=r.substring(1);let e=Ht(r.length);for(let t=0;t<r.length;t++)e[t]=r.charCodeAt(t);return e}),Rh={utf8:wu,"utf-8":wu,hex:sn.base16,latin1:Gs,ascii:Gs,binary:Gs,...sn},ro=Rh;function M(r,e="utf8"){let t=ro[e];if(t==null)throw new Error(`Unsupported encoding "${e}"`);return t.decoder.decode(`${t.prefix}${r}`)}function V(r,e="utf8"){let t=ro[e];if(t==null)throw new Error(`Unsupported encoding "${e}"`);return t.encoder.encode(r).substring(1)}var Oh=parseInt("11111",2),Ys=parseInt("10000000",2),Ph=parseInt("01111111",2),Eu={0:an,1:an,2:Nh,3:Fh,4:Mh,5:kh,6:Uh,16:an,22:an,48:an};function ut(r,e={offset:0}){let t=r[e.offset]&Oh;if(e.offset++,Eu[t]!=null)return Eu[t](r,e);throw new Error("No decoder for tag "+t)}function cn(r,e){let t=0;if((r[e.offset]&Ys)===Ys){let n=r[e.offset]&Ph,s="0x";e.offset++;for(let o=0;o<n;o++,e.offset++)s+=r[e.offset].toString(16).padStart(2,"0");t=parseInt(s,16)}else t=r[e.offset],e.offset++;return t}function an(r,e){cn(r,e);let t=[];for(;!(e.offset>=r.byteLength);){let n=ut(r,e);if(n===null)break;t.push(n)}return t}function Nh(r,e){let t=cn(r,e),n=e.offset,s=e.offset+t,o=[];for(let i=n;i<s;i++)i===n&&r[i]===0||o.push(r[i]);return e.offset+=t,Uint8Array.from(o)}function Uh(r,e){let t=cn(r,e),n=e.offset+t,s=r[e.offset];e.offset++;let o=0,i=0;s<40?(o=0,i=s):s<80?(o=1,i=s-40):(o=2,i=s-80);let a=`${o}.${i}`,c=[];for(;e.offset<n;){let u=r[e.offset];if(e.offset++,c.push(u&127),u<128){c.reverse();let l=0;for(let f=0;f<c.length;f++)l+=c[f]<<f*7;a+=`.${l}`,c=[]}}return a}function kh(r,e){return e.offset++,null}function Fh(r,e){let t=cn(r,e),n=r[e.offset];e.offset++;let s=r.subarray(e.offset,e.offset+t-1);if(e.offset+=t,n!==0)throw new Error("Unused bits in bit string is unimplemented");return s}function Mh(r,e){let t=cn(r,e),n=r.subarray(e.offset,e.offset+t);return e.offset+=t,n}function Kh(r){let e=r.toString(16);e.length%2===1&&(e="0"+e);let t=new ee;for(let n=0;n<e.length;n+=2)t.append(Uint8Array.from([parseInt(`${e[n]}${e[n+1]}`,16)]));return t}function Zs(r){if(r.byteLength<128)return Uint8Array.from([r.byteLength]);let e=Kh(r.byteLength);return new ee(Uint8Array.from([e.byteLength|Ys]),e)}function Ce(r){let e=new ee,t=128;return(r.subarray()[0]&t)===t&&e.append(Uint8Array.from([0])),e.append(r),new ee(Uint8Array.from([2]),Zs(e),e)}function no(r){let e=Uint8Array.from([0]),t=new ee(e,r);return new ee(Uint8Array.from([3]),Zs(t),t)}function vt(r,e=48){let t=new ee;for(let n of r)t.append(n);return new ee(Uint8Array.from([e]),Zs(t),t)}var qh=Uint8Array.from([6,8,42,134,72,206,61,3,1,7]),zh=Uint8Array.from([6,5,43,129,4,0,34]),Vh=Uint8Array.from([6,5,43,129,4,0,35]),Hh={ext:!0,kty:"EC",crv:"P-256"},$h={ext:!0,kty:"EC",crv:"P-384"},jh={ext:!0,kty:"EC",crv:"P-521"},Xs=32,Qs=48,Js=66;function ei(r){let e=ut(r);return Su(e)}function Su(r){let e=r[1][1][0],t=1,n,s;if(e.byteLength===Xs*2+1)return n=V(e.subarray(t,t+Xs),"base64url"),s=V(e.subarray(t+Xs),"base64url"),new Sr({...Hh,key_ops:["verify"],x:n,y:s});if(e.byteLength===Qs*2+1)return n=V(e.subarray(t,t+Qs),"base64url"),s=V(e.subarray(t+Qs),"base64url"),new Sr({...$h,key_ops:["verify"],x:n,y:s});if(e.byteLength===Js*2+1)return n=V(e.subarray(t,t+Js),"base64url"),s=V(e.subarray(t+Js),"base64url"),new Sr({...jh,key_ops:["verify"],x:n,y:s});throw new se(`coordinates were wrong length, got ${e.byteLength}, expected 65, 97 or 133`)}function vu(r){return vt([Ce(Uint8Array.from([1])),vt([Wh(r.crv)],160),vt([no(new ee(Uint8Array.from([4]),M(r.x??"","base64url"),M(r.y??"","base64url")))],161)]).subarray()}function Wh(r){if(r==="P-256")return qh;if(r==="P-384")return zh;if(r==="P-521")return Vh;throw new se(`Invalid curve ${r}`)}var Sr=class{type="ECDSA";jwk;_raw;constructor(e){this.jwk=e}get raw(){return this._raw==null&&(this._raw=vu(this.jwk)),this._raw}toMultihash(){return qe.digest(Qe(this))}toCID(){return fe.createV1(114,this.toMultihash())}toString(){return re.encode(this.toMultihash().bytes).substring(1)}equals(e){return e==null||!(e.raw instanceof Uint8Array)?!1:he(this.raw,e.raw)}async verify(e,t,n){return fu(this.jwk,t,e,n)}};function ti(r){return r instanceof Uint8Array||ArrayBuffer.isView(r)&&r.constructor.name==="Uint8Array"&&"BYTES_PER_ELEMENT"in r&&r.BYTES_PER_ELEMENT===1}function _t(r,e=""){if(typeof r!="number"){let t=e&&`"${e}" `;throw new TypeError(`${t}expected number, got ${typeof r}`)}if(!Number.isSafeInteger(r)||r<0){let t=e&&`"${e}" `;throw new RangeError(`${t}expected integer >= 0, got ${r}`)}}function Ne(r,e,t=""){let n=ti(r),s=r?.length,o=e!==void 0;if(!n||o&&s!==e){let i=t&&`"${t}" `,a=o?` of length ${e}`:"",c=n?`length=${s}`:`type=${typeof r}`,u=i+"expected Uint8Array"+a+", got "+c;throw n?new RangeError(u):new TypeError(u)}return r}function oo(r){if(typeof r!="function"||typeof r.create!="function")throw new TypeError("Hash must wrapped by utils.createHasher");if(_t(r.outputLen),_t(r.blockLen),r.outputLen<1)throw new Error('"outputLen" must be >= 1');if(r.blockLen<1)throw new Error('"blockLen" must be >= 1')}function vr(r,e=!0){if(r.destroyed)throw new Error("Hash instance has been destroyed");if(e&&r.finished)throw new Error("Hash#digest() has already been called")}function so(r,e){Ne(r,void 0,"digestInto() output");let t=e.outputLen;if(r.length<t)throw new RangeError('"digestInto() output" expected to be of length >='+t)}function ft(...r){for(let e=0;e<r.length;e++)r[e].fill(0)}function io(r){return new DataView(r.buffer,r.byteOffset,r.byteLength)}function ze(r,e){return r<<32-e|r>>>e}var Au=typeof Uint8Array.from([]).toHex=="function"&&typeof Uint8Array.fromHex=="function",Gh=Array.from({length:256},(r,e)=>e.toString(16).padStart(2,"0"));function ao(r){if(Ne(r),Au)return r.toHex();let e="";for(let t=0;t<r.length;t++)e+=Gh[r[t]];return e}var lt={_0:48,_9:57,A:65,F:70,a:97,f:102};function _u(r){if(r>=lt._0&&r<=lt._9)return r-lt._0;if(r>=lt.A&&r<=lt.F)return r-(lt.A-10);if(r>=lt.a&&r<=lt.f)return r-(lt.a-10)}function un(r){if(typeof r!="string")throw new TypeError("hex string expected, got "+typeof r);if(Au)try{return Uint8Array.fromHex(r)}catch(s){throw s instanceof SyntaxError?new RangeError(s.message):s}let e=r.length,t=e/2;if(e%2)throw new RangeError("hex string expected, got unpadded hex of length "+e);let n=new Uint8Array(t);for(let s=0,o=0;s<t;s++,o+=2){let i=_u(r.charCodeAt(o)),a=_u(r.charCodeAt(o+1));if(i===void 0||a===void 0){let c=r[o]+r[o+1];throw new RangeError('hex string expected, got non-hex character "'+c+'" at index '+o)}n[s]=i*16+a}return n}function ri(...r){let e=0;for(let n=0;n<r.length;n++){let s=r[n];Ne(s),e+=s.length}let t=new Uint8Array(e);for(let n=0,s=0;n<r.length;n++){let o=r[n];t.set(o,s),s+=o.length}return t}function ni(r,e={}){let t=(s,o)=>r(o).update(s).digest(),n=r(void 0);return t.outputLen=n.outputLen,t.blockLen=n.blockLen,t.canXOF=n.canXOF,t.create=s=>r(s),Object.assign(t,e),Object.freeze(t)}function Tu(r=32){_t(r,"bytesLength");let e=typeof globalThis=="object"?globalThis.crypto:null;if(typeof e?.getRandomValues!="function")throw new Error("crypto.getRandomValues must be defined");if(r>65536)throw new RangeError(`"bytesLength" expected <= 65536, got ${r}`);return e.getRandomValues(new Uint8Array(r))}var oi=r=>({oid:Uint8Array.from([6,9,96,134,72,1,101,3,4,2,r])});function Du(r,e,t){return r&e^~r&t}function Iu(r,e,t){return r&e^r&t^e&t}var ln=class{blockLen;outputLen;canXOF=!1;padOffset;isLE;buffer;view;finished=!1;length=0;pos=0;destroyed=!1;constructor(e,t,n,s){this.blockLen=e,this.outputLen=t,this.padOffset=n,this.isLE=s,this.buffer=new Uint8Array(e),this.view=io(this.buffer)}update(e){vr(this),Ne(e);let{view:t,buffer:n,blockLen:s}=this,o=e.length;for(let i=0;i<o;){let a=Math.min(s-this.pos,o-i);if(a===s){let c=io(e);for(;s<=o-i;i+=s)this.process(c,i);continue}n.set(e.subarray(i,i+a),this.pos),this.pos+=a,i+=a,this.pos===s&&(this.process(t,0),this.pos=0)}return this.length+=e.length,this.roundClean(),this}digestInto(e){vr(this),so(e,this),this.finished=!0;let{buffer:t,view:n,blockLen:s,isLE:o}=this,{pos:i}=this;t[i++]=128,ft(this.buffer.subarray(i)),this.padOffset>s-i&&(this.process(n,0),i=0);for(let f=i;f<s;f++)t[f]=0;n.setBigUint64(s-8,BigInt(this.length*8),o),this.process(n,0);let a=io(e),c=this.outputLen;if(c%4)throw new Error("_sha2: outputLen must be aligned to 32bit");let u=c/4,l=this.get();if(u>l.length)throw new Error("_sha2: outputLen bigger than state");for(let f=0;f<u;f++)a.setUint32(4*f,l[f],o)}digest(){let{buffer:e,outputLen:t}=this;this.digestInto(e);let n=e.slice(0,t);return this.destroy(),n}_cloneInto(e){e||=new this.constructor,e.set(...this.get());let{blockLen:t,buffer:n,length:s,finished:o,destroyed:i,pos:a}=this;return e.destroyed=i,e.finished=o,e.length=s,e.pos=a,s%t&&e.buffer.set(n),e}clone(){return this._cloneInto()}},dt=Uint32Array.from([1779033703,3144134277,1013904242,2773480762,1359893119,2600822924,528734635,1541459225]);var we=Uint32Array.from([1779033703,4089235720,3144134277,2227873595,1013904242,4271175723,2773480762,1595750129,1359893119,2917565137,2600822924,725511199,528734635,4215389547,1541459225,327033209]);var co=BigInt(4294967295),Cu=BigInt(32);function Yh(r,e=!1){return e?{h:Number(r&co),l:Number(r>>Cu&co)}:{h:Number(r>>Cu&co)|0,l:Number(r&co)|0}}function Lu(r,e=!1){let t=r.length,n=new Uint32Array(t),s=new Uint32Array(t);for(let o=0;o<t;o++){let{h:i,l:a}=Yh(r[o],e);[n[o],s[o]]=[i,a]}return[n,s]}var si=(r,e,t)=>r>>>t,ii=(r,e,t)=>r<<32-t|e>>>t,$t=(r,e,t)=>r>>>t|e<<32-t,jt=(r,e,t)=>r<<32-t|e>>>t,fn=(r,e,t)=>r<<64-t|e>>>t-32,dn=(r,e,t)=>r>>>t-32|e<<64-t;function Je(r,e,t,n){let s=(e>>>0)+(n>>>0);return{h:r+t+(s/2**32|0)|0,l:s|0}}var Bu=(r,e,t)=>(r>>>0)+(e>>>0)+(t>>>0),Ru=(r,e,t,n)=>e+t+n+(r/2**32|0)|0,Ou=(r,e,t,n)=>(r>>>0)+(e>>>0)+(t>>>0)+(n>>>0),Pu=(r,e,t,n,s)=>e+t+n+s+(r/2**32|0)|0,Nu=(r,e,t,n,s)=>(r>>>0)+(e>>>0)+(t>>>0)+(n>>>0)+(s>>>0),Uu=(r,e,t,n,s,o)=>e+t+n+s+o+(r/2**32|0)|0;var Xh=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]),At=new Uint32Array(64),ai=class extends ln{constructor(e){super(64,e,8,!1)}get(){let{A:e,B:t,C:n,D:s,E:o,F:i,G:a,H:c}=this;return[e,t,n,s,o,i,a,c]}set(e,t,n,s,o,i,a,c){this.A=e|0,this.B=t|0,this.C=n|0,this.D=s|0,this.E=o|0,this.F=i|0,this.G=a|0,this.H=c|0}process(e,t){for(let f=0;f<16;f++,t+=4)At[f]=e.getUint32(t,!1);for(let f=16;f<64;f++){let m=At[f-15],d=At[f-2],p=ze(m,7)^ze(m,18)^m>>>3,b=ze(d,17)^ze(d,19)^d>>>10;At[f]=b+At[f-7]+p+At[f-16]|0}let{A:n,B:s,C:o,D:i,E:a,F:c,G:u,H:l}=this;for(let f=0;f<64;f++){let m=ze(a,6)^ze(a,11)^ze(a,25),d=l+m+Du(a,c,u)+Xh[f]+At[f]|0,b=(ze(n,2)^ze(n,13)^ze(n,22))+Iu(n,s,o)|0;l=u,u=c,c=a,a=i+d|0,i=o,o=s,s=n,n=d+b|0}n=n+this.A|0,s=s+this.B|0,o=o+this.C|0,i=i+this.D|0,a=a+this.E|0,c=c+this.F|0,u=u+this.G|0,l=l+this.H|0,this.set(n,s,o,i,a,c,u,l)}roundClean(){ft(At)}destroy(){this.destroyed=!0,this.set(0,0,0,0,0,0,0,0),ft(this.buffer)}},ci=class extends ai{A=dt[0]|0;B=dt[1]|0;C=dt[2]|0;D=dt[3]|0;E=dt[4]|0;F=dt[5]|0;G=dt[6]|0;H=dt[7]|0;constructor(){super(32)}};var ku=Lu(["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))),Qh=ku[0],Jh=ku[1],Tt=new Uint32Array(80),Dt=new Uint32Array(80),ui=class extends ln{constructor(e){super(128,e,16,!1)}get(){let{Ah:e,Al:t,Bh:n,Bl:s,Ch:o,Cl:i,Dh:a,Dl:c,Eh:u,El:l,Fh:f,Fl:m,Gh:d,Gl:p,Hh:b,Hl:h}=this;return[e,t,n,s,o,i,a,c,u,l,f,m,d,p,b,h]}set(e,t,n,s,o,i,a,c,u,l,f,m,d,p,b,h){this.Ah=e|0,this.Al=t|0,this.Bh=n|0,this.Bl=s|0,this.Ch=o|0,this.Cl=i|0,this.Dh=a|0,this.Dl=c|0,this.Eh=u|0,this.El=l|0,this.Fh=f|0,this.Fl=m|0,this.Gh=d|0,this.Gl=p|0,this.Hh=b|0,this.Hl=h|0}process(e,t){for(let v=0;v<16;v++,t+=4)Tt[v]=e.getUint32(t),Dt[v]=e.getUint32(t+=4);for(let v=16;v<80;v++){let I=Tt[v-15]|0,D=Dt[v-15]|0,P=$t(I,D,1)^$t(I,D,8)^si(I,D,7),B=jt(I,D,1)^jt(I,D,8)^ii(I,D,7),T=Tt[v-2]|0,U=Dt[v-2]|0,Z=$t(T,U,19)^fn(T,U,61)^si(T,U,6),k=jt(T,U,19)^dn(T,U,61)^ii(T,U,6),y=Ou(B,k,Dt[v-7],Dt[v-16]),w=Pu(y,P,Z,Tt[v-7],Tt[v-16]);Tt[v]=w|0,Dt[v]=y|0}let{Ah:n,Al:s,Bh:o,Bl:i,Ch:a,Cl:c,Dh:u,Dl:l,Eh:f,El:m,Fh:d,Fl:p,Gh:b,Gl:h,Hh:g,Hl:E}=this;for(let v=0;v<80;v++){let I=$t(f,m,14)^$t(f,m,18)^fn(f,m,41),D=jt(f,m,14)^jt(f,m,18)^dn(f,m,41),P=f&d^~f&b,B=m&p^~m&h,T=Nu(E,D,B,Jh[v],Dt[v]),U=Uu(T,g,I,P,Qh[v],Tt[v]),Z=T|0,k=$t(n,s,28)^fn(n,s,34)^fn(n,s,39),y=jt(n,s,28)^dn(n,s,34)^dn(n,s,39),w=n&o^n&a^o&a,_=s&i^s&c^i&c;g=b|0,E=h|0,b=d|0,h=p|0,d=f|0,p=m|0,{h:f,l:m}=Je(u|0,l|0,U|0,Z|0),u=a|0,l=c|0,a=o|0,c=i|0,o=n|0,i=s|0;let S=Bu(Z,y,_);n=Ru(S,U,k,w),s=S|0}({h:n,l:s}=Je(this.Ah|0,this.Al|0,n|0,s|0)),{h:o,l:i}=Je(this.Bh|0,this.Bl|0,o|0,i|0),{h:a,l:c}=Je(this.Ch|0,this.Cl|0,a|0,c|0),{h:u,l}=Je(this.Dh|0,this.Dl|0,u|0,l|0),{h:f,l:m}=Je(this.Eh|0,this.El|0,f|0,m|0),{h:d,l:p}=Je(this.Fh|0,this.Fl|0,d|0,p|0),{h:b,l:h}=Je(this.Gh|0,this.Gl|0,b|0,h|0),{h:g,l:E}=Je(this.Hh|0,this.Hl|0,g|0,E|0),this.set(n,s,o,i,a,c,u,l,f,m,d,p,b,h,g,E)}roundClean(){ft(Tt,Dt)}destroy(){this.destroyed=!0,ft(this.buffer),this.set(0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0)}},li=class extends ui{Ah=we[0]|0;Al=we[1]|0;Bh=we[2]|0;Bl=we[3]|0;Ch=we[4]|0;Cl=we[5]|0;Dh=we[6]|0;Dl=we[7]|0;Eh=we[8]|0;El=we[9]|0;Fh=we[10]|0;Fl=we[11]|0;Gh=we[12]|0;Gl=we[13]|0;Hh=we[14]|0;Hl=we[15]|0;constructor(){super(64)}};var _r=ni(()=>new ci,oi(1));var uo=ni(()=>new li,oi(3));var H=(r,e,t)=>Ne(r,e,t),di=_t,Ar=ao,pe=(...r)=>ri(...r),Tr=r=>un(r),Wt=ti,hn=r=>Tu(r),fo=BigInt(0),fi=BigInt(1);function Ve(r,e=""){if(typeof r!="boolean"){let t=e&&`"${e}" `;throw new TypeError(t+"expected boolean, got type="+typeof r)}return r}function ho(r){if(typeof r=="bigint"){if(!lo(r))throw new RangeError("positive bigint expected, got "+r)}else di(r);return r}function He(r,e=""){if(typeof r!="number"){let t=e&&`"${e}" `;throw new TypeError(t+"expected number, got type="+typeof r)}if(!Number.isSafeInteger(r)){let t=e&&`"${e}" `;throw new RangeError(t+"expected safe integer, got "+r)}}function pn(r){let e=ho(r).toString(16);return e.length&1?"0"+e:e}function Fu(r){if(typeof r!="string")throw new TypeError("hex string expected, got "+typeof r);return r===""?fo:BigInt("0x"+r)}function Gt(r){return Fu(ao(r))}function et(r){return Fu(ao(mn(Ne(r)).reverse()))}function po(r,e){if(_t(e),e===0)throw new RangeError("zero length");r=ho(r);let t=r.toString(16);if(t.length>e*2)throw new RangeError("number too large");return un(t.padStart(e*2,"0"))}function hi(r,e){return po(r,e).reverse()}function Mu(r,e){if(r=H(r),e=H(e),r.length!==e.length)return!1;let t=0;for(let n=0;n<r.length;n++)t|=r[n]^e[n];return t===0}function mn(r){return Uint8Array.from(H(r))}function mo(r){if(typeof r!="string")throw new TypeError("ascii string expected, got "+typeof r);return Uint8Array.from(r,(e,t)=>{let n=e.charCodeAt(0);if(e.length!==1||n>127)throw new RangeError(`string contains non-ASCII character "${r[t]}" with code ${n} at position ${t}`);return n})}var lo=r=>typeof r=="bigint"&&fo<=r;function ep(r,e,t){return lo(r)&&lo(e)&&lo(t)&&e<=r&&r<t}function Dr(r,e,t,n){if(!ep(e,t,n))throw new RangeError("expected valid "+r+": "+t+" <= n < "+n+", got "+e)}function Ir(r){if(r<fo)throw new Error("expected non-negative bigint, got "+r);let e;for(e=0;r>fo;r>>=fi,e+=1);return e}var yn=r=>(fi<<BigInt(r))-fi;function Ku(r,e,t){if(_t(r,"hashLen"),_t(e,"qByteLen"),typeof t!="function")throw new TypeError("hmacFn must be a function");let n=h=>new Uint8Array(h),s=Uint8Array.of(),o=Uint8Array.of(0),i=Uint8Array.of(1),a=1e3,c=n(r),u=n(r),l=0,f=()=>{c.fill(1),u.fill(0),l=0},m=(...h)=>t(u,pe(c,...h)),d=(h=s)=>{u=m(o,h),c=m(),h.length!==0&&(u=m(i,h),c=m())},p=()=>{if(l++>=a)throw new Error("drbg: tried max amount of iterations");let h=0,g=[];for(;h<e;){c=m();let E=c.slice();g.push(E),h+=c.length}return pe(...g)};return(h,g)=>{f(),d(h);let E;for(;(E=g(p()))===void 0;)d();return f(),E}}function $e(r,e={},t={}){if(Object.prototype.toString.call(r)!=="[object Object]")throw new TypeError("expected valid options object");function n(o,i,a){if(!a&&i!=="function"&&!Object.hasOwn(r,o))throw new TypeError(`param "${o}" is invalid: expected own property`);let c=r[o];if(a&&c===void 0)return;let u=typeof c;if(u!==i||c===null)throw new TypeError(`param "${o}" is invalid: expected ${i}, got ${u}`)}let s=(o,i)=>Object.entries(o).forEach(([a,c])=>n(a,c,i));s(e,!1),s(t,!0)}var pi=()=>{throw new Error("not implemented")};var xe=BigInt(0),ae=BigInt(1),Yt=BigInt(2),Hu=BigInt(3),$u=BigInt(4),ju=BigInt(5),tp=BigInt(7),Wu=BigInt(8),rp=BigInt(9),Gu=BigInt(16);function le(r,e){if(e<=xe)throw new Error("mod: expected positive modulus, got "+e);let t=r%e;return t>=xe?t:e+t}function te(r,e,t){if(e<xe)throw new Error("pow2: expected non-negative exponent, got "+e);let n=r;for(;e-- >xe;)n*=n,n%=t;return n}function qu(r,e){if(r===xe)throw new Error("invert: expected non-zero number");if(e<=xe)throw new Error("invert: expected positive modulus, got "+e);let t=le(r,e),n=e,s=xe,o=ae,i=ae,a=xe;for(;t!==xe;){let u=n/t,l=n-t*u,f=s-i*u,m=o-a*u;n=t,t=l,s=i,o=a,i=f,a=m}if(n!==ae)throw new Error("invert: does not exist");return le(s,e)}function mi(r,e,t){let n=r;if(!n.eql(n.sqr(e),t))throw new Error("Cannot find square root")}function Yu(r,e){let t=r,n=(t.ORDER+ae)/$u,s=t.pow(e,n);return mi(t,s,e),s}function np(r,e){let t=r,n=(t.ORDER-ju)/Wu,s=t.mul(e,Yt),o=t.pow(s,n),i=t.mul(e,o),a=t.mul(t.mul(i,Yt),o),c=t.mul(i,t.sub(a,t.ONE));return mi(t,c,e),c}function op(r){let e=Cr(r),t=Zu(r),n=t(e,e.neg(e.ONE)),s=t(e,n),o=t(e,e.neg(n)),i=(r+tp)/Gu;return((a,c)=>{let u=a,l=u.pow(c,i),f=u.mul(l,n),m=u.mul(l,s),d=u.mul(l,o),p=u.eql(u.sqr(f),c),b=u.eql(u.sqr(m),c);l=u.cmov(l,f,p),f=u.cmov(d,m,b);let h=u.eql(u.sqr(f),c),g=u.cmov(l,f,h);return mi(u,g,c),g})}function Zu(r){if(r<Hu)throw new Error("sqrt is not defined for small field");let e=r-ae,t=0;for(;e%Yt===xe;)e/=Yt,t++;let n=Yt,s=Cr(r);for(;zu(s,n)===1;)if(n++>1e3)throw new Error("Cannot find square root: probably non-prime P");if(t===1)return Yu;let o=s.pow(n,e),i=(e+ae)/Yt;return function(c,u){let l=c;if(l.is0(u))return u;if(zu(l,u)!==1)throw new Error("Cannot find square root");let f=t,m=l.mul(l.ONE,o),d=l.pow(u,e),p=l.pow(u,i);for(;!l.eql(d,l.ONE);){if(l.is0(d))return l.ZERO;let b=1,h=l.sqr(d);for(;!l.eql(h,l.ONE);)if(b++,h=l.sqr(h),b===f)throw new Error("Cannot find square root");let g=ae<<BigInt(f-b-1),E=l.pow(m,g);f=b,m=l.sqr(E),d=l.mul(d,m),p=l.mul(p,E)}return p}}function sp(r){return r%$u===Hu?Yu:r%Wu===ju?np:r%Gu===rp?op(r):Zu(r)}var ht=(r,e)=>(le(r,e)&ae)===ae,ip=["create","isValid","is0","neg","inv","sqrt","sqr","eql","add","sub","mul","pow","div","addN","subN","mulN","sqrN"];function yi(r){let e={ORDER:"bigint",BYTES:"number",BITS:"number"},t=ip.reduce((n,s)=>(n[s]="function",n),e);if($e(r,t),He(r.BYTES,"BYTES"),He(r.BITS,"BITS"),r.BYTES<1||r.BITS<1)throw new Error("invalid field: expected BYTES/BITS > 0");if(r.ORDER<=ae)throw new Error("invalid field: expected ORDER > 1, got "+r.ORDER);return r}function ap(r,e,t){let n=r;if(t<xe)throw new Error("invalid exponent, negatives unsupported");if(t===xe)return n.ONE;if(t===ae)return e;let s=n.ONE,o=e;for(;t>xe;)t&ae&&(s=n.mul(s,o)),o=n.sqr(o),t>>=ae;return s}function gn(r,e,t=!1){let n=r,s=new Array(e.length).fill(t?n.ZERO:void 0),o=e.reduce((a,c,u)=>n.is0(c)?a:(s[u]=a,n.mul(a,c)),n.ONE),i=n.inv(o);return e.reduceRight((a,c,u)=>n.is0(c)?a:(s[u]=n.mul(a,s[u]),n.mul(a,c)),i),s}function zu(r,e){let t=r,n=(t.ORDER-ae)/Yt,s=t.pow(e,n),o=t.eql(s,t.ONE),i=t.eql(s,t.ZERO),a=t.eql(s,t.neg(t.ONE));if(!o&&!i&&!a)throw new Error("invalid Legendre symbol result");return o?1:i?0:-1}function cp(r,e){if(e!==void 0&&di(e),r<=xe)throw new Error("invalid n length: expected positive n, got "+r);if(e!==void 0&&e<1)throw new Error("invalid n length: expected positive bit length, got "+e);let t=Ir(r);if(e!==void 0&&e<t)throw new Error(`invalid n length: expected bit length (${t}) >= n.length (${e})`);let n=e!==void 0?e:t,s=Math.ceil(n/8);return{nBitLength:n,nByteLength:s}}var Vu=new WeakMap,yo=class{ORDER;BITS;BYTES;isLE;ZERO=xe;ONE=ae;_lengths;_mod;constructor(e,t={}){if(e<=ae)throw new Error("invalid field: expected ORDER > 1, got "+e);let n;this.isLE=!1,t!=null&&typeof t=="object"&&(typeof t.BITS=="number"&&(n=t.BITS),typeof t.sqrt=="function"&&Object.defineProperty(this,"sqrt",{value:t.sqrt,enumerable:!0}),typeof t.isLE=="boolean"&&(this.isLE=t.isLE),t.allowedLengths&&(this._lengths=Object.freeze(t.allowedLengths.slice())),typeof t.modFromBytes=="boolean"&&(this._mod=t.modFromBytes));let{nBitLength:s,nByteLength:o}=cp(e,n);if(o>2048)throw new Error("invalid field: expected ORDER of <= 2048 bytes");this.ORDER=e,this.BITS=s,this.BYTES=o,Object.freeze(this)}create(e){return le(e,this.ORDER)}isValid(e){if(typeof e!="bigint")throw new TypeError("invalid field element: expected bigint, got "+typeof e);return xe<=e&&e<this.ORDER}is0(e){return e===xe}isValidNot0(e){return!this.is0(e)&&this.isValid(e)}isOdd(e){return(e&ae)===ae}neg(e){return le(-e,this.ORDER)}eql(e,t){return e===t}sqr(e){return le(e*e,this.ORDER)}add(e,t){return le(e+t,this.ORDER)}sub(e,t){return le(e-t,this.ORDER)}mul(e,t){return le(e*t,this.ORDER)}pow(e,t){return ap(this,e,t)}div(e,t){return le(e*qu(t,this.ORDER),this.ORDER)}sqrN(e){return e*e}addN(e,t){return e+t}subN(e,t){return e-t}mulN(e,t){return e*t}inv(e){return qu(e,this.ORDER)}sqrt(e){let t=Vu.get(this);return t||Vu.set(this,t=sp(this.ORDER)),t(this,e)}toBytes(e){return this.isLE?hi(e,this.BYTES):po(e,this.BYTES)}fromBytes(e,t=!1){H(e);let{_lengths:n,BYTES:s,isLE:o,ORDER:i,_mod:a}=this;if(n){if(e.length<1||!n.includes(e.length)||e.length>s)throw new Error("Field.fromBytes: expected "+n+" bytes, got "+e.length);let u=new Uint8Array(s);u.set(e,o?0:u.length-e.length),e=u}if(e.length!==s)throw new Error("Field.fromBytes: expected "+s+" bytes, got "+e.length);let c=o?et(e):Gt(e);if(a&&(c=le(c,i)),!t&&!this.isValid(c))throw new Error("invalid field element: outside of range 0..ORDER");return c}invertBatch(e){return gn(this,e)}cmov(e,t,n){return Ve(n,"condition"),n?t:e}};Object.freeze(yo.prototype);function Cr(r,e={}){return new yo(r,e)}function Xu(r){if(typeof r!="bigint")throw new Error("field order must be bigint");if(r<=ae)throw new Error("field order must be greater than 1");let e=Ir(r-ae);return Math.ceil(e/8)}function gi(r){let e=Xu(r);return e+Math.ceil(e/2)}function bi(r,e,t=!1){H(r);let n=r.length,s=Xu(e),o=Math.max(gi(e),16);if(n<o||n>1024)throw new Error("expected "+o+"-1024 bytes of input, got "+n);let i=t?et(r):Gt(r),a=le(i,e-ae)+ae;return t?hi(a,s):po(a,s)}var Lr=BigInt(0),Zt=BigInt(1);function bn(r,e){let t=e.negate();return r?t:e}function Xt(r,e){let t=gn(r.Fp,e.map(n=>n.Z));return e.map((n,s)=>r.fromAffine(n.toAffine(t[s])))}function tl(r,e){if(!Number.isSafeInteger(r)||r<=0||r>e)throw new Error("invalid window size, expected [1.."+e+"], got W="+r)}function wi(r,e){tl(r,e);let t=Math.ceil(e/r)+1,n=2**(r-1),s=2**r,o=yn(r),i=BigInt(r);return{windows:t,windowSize:n,mask:o,maxNumber:s,shiftBy:i}}function Qu(r,e,t){let{windowSize:n,mask:s,maxNumber:o,shiftBy:i}=t,a=Number(r&s),c=r>>i;a>n&&(a-=o,c+=Zt);let u=e*n,l=u+Math.abs(a)-1,f=a===0,m=a<0,d=e%2!==0;return{nextN:c,offset:l,isZero:f,isNeg:m,isNegF:d,offsetF:u}}var xi=new WeakMap,rl=new WeakMap;function Ei(r){return rl.get(r)||1}function Ju(r){if(r!==Lr)throw new Error("invalid wNAF")}var Br=class{BASE;ZERO;Fn;bits;constructor(e,t){this.BASE=e.BASE,this.ZERO=e.ZERO,this.Fn=e.Fn,this.bits=t}_unsafeLadder(e,t,n=this.ZERO){let s=e;for(;t>Lr;)t&Zt&&(n=n.add(s)),s=s.double(),t>>=Zt;return n}precomputeWindow(e,t){let{windows:n,windowSize:s}=wi(t,this.bits),o=[],i=e,a=i;for(let c=0;c<n;c++){a=i,o.push(a);for(let u=1;u<s;u++)a=a.add(i),o.push(a);i=a.double()}return o}wNAF(e,t,n){if(!this.Fn.isValid(n))throw new Error("invalid scalar");let s=this.ZERO,o=this.BASE,i=wi(e,this.bits);for(let a=0;a<i.windows;a++){let{nextN:c,offset:u,isZero:l,isNeg:f,isNegF:m,offsetF:d}=Qu(n,a,i);n=c,l?o=o.add(bn(m,t[d])):s=s.add(bn(f,t[u]))}return Ju(n),{p:s,f:o}}wNAFUnsafe(e,t,n,s=this.ZERO){let o=wi(e,this.bits);for(let i=0;i<o.windows&&n!==Lr;i++){let{nextN:a,offset:c,isZero:u,isNeg:l}=Qu(n,i,o);if(n=a,!u){let f=t[c];s=s.add(l?f.negate():f)}}return Ju(n),s}getPrecomputes(e,t,n){let s=xi.get(t);return s||(s=this.precomputeWindow(t,e),e!==1&&(typeof n=="function"&&(s=n(s)),xi.set(t,s))),s}cached(e,t,n){let s=Ei(e);return this.wNAF(s,this.getPrecomputes(s,e,n),t)}unsafe(e,t,n,s){let o=Ei(e);return o===1?this._unsafeLadder(e,t,s):this.wNAFUnsafe(o,this.getPrecomputes(o,e,n),t,s)}createCache(e,t){tl(t,this.bits),rl.set(e,t),xi.delete(e)}hasCache(e){return Ei(e)!==1}};function nl(r,e,t,n){let s=e,o=r.ZERO,i=r.ZERO;for(;t>Lr||n>Lr;)t&Zt&&(o=o.add(s)),n&Zt&&(i=i.add(s)),s=s.double(),t>>=Zt,n>>=Zt;return{p1:o,p2:i}}function el(r,e,t){if(e){if(e.ORDER!==r)throw new Error("Field.ORDER must match order: Fp == p, Fn == n");return yi(e),e}else return Cr(r,{isLE:t})}function go(r,e,t={},n){if(n===void 0&&(n=r==="edwards"),!e||typeof e!="object")throw new Error(`expected valid ${r} CURVE object`);for(let c of["p","n","h"]){let u=e[c];if(!(typeof u=="bigint"&&u>Lr))throw new Error(`CURVE.${c} must be positive bigint`)}let s=el(e.p,t.Fp,n),o=el(e.n,t.Fn,n),a=["Gx","Gy","a",r==="weierstrass"?"b":"d"];for(let c of a)if(!s.isValid(e[c]))throw new Error(`CURVE.${c} must be valid field element of CURVE.Fp`);return e=Object.freeze(Object.assign({},e)),{CURVE:e,Fp:s,Fn:o}}function bo(r,e){return function(n){let s=r(n);return{secretKey:s,publicKey:e(s)}}}var It=BigInt(0),ge=BigInt(1),Si=BigInt(2),up=BigInt(8);function lp(r,e,t,n){let s=r.sqr(t),o=r.sqr(n),i=r.add(r.mul(e.a,s),o),a=r.add(r.ONE,r.mul(e.d,r.mul(s,o)));return r.eql(i,a)}function ol(r,e={}){let t=e,n=go("edwards",r,t,t.FpFnLE),{Fp:s,Fn:o}=n,i=n.CURVE,{h:a}=i;$e(t,{},{uvRatio:"function"});let c=Si<<BigInt(o.BYTES*8)-ge,u=b=>s.create(b),l=t.uvRatio===void 0?(b,h)=>{try{return{isValid:!0,value:s.sqrt(s.div(b,h))}}catch{return{isValid:!1,value:It}}}:t.uvRatio;if(!lp(s,i,i.Gx,i.Gy))throw new Error("bad curve params: generator point");function f(b,h,g=!1){let E=g?ge:It;return Dr("coordinate "+b,h,E,c),h}function m(b){if(!(b instanceof d))throw new Error("EdwardsPoint expected")}class d{static BASE=new d(i.Gx,i.Gy,ge,u(i.Gx*i.Gy));static ZERO=new d(It,ge,ge,It);static Fp=s;static Fn=o;X;Y;Z;T;constructor(h,g,E,v){this.X=f("x",h),this.Y=f("y",g),this.Z=f("z",E,!0),this.T=f("t",v),Object.freeze(this)}static CURVE(){return i}static fromAffine(h){if(h instanceof d)throw new Error("extended point not allowed");let{x:g,y:E}=h||{};return f("x",g),f("y",E),new d(g,E,ge,u(g*E))}static fromBytes(h,g=!1){let E=s.BYTES,{a:v,d:I}=i;h=mn(H(h,E,"point")),Ve(g,"zip215");let D=mn(h),P=h[E-1];D[E-1]=P&-129;let B=et(D),T=g?c:s.ORDER;Dr("point.y",B,It,T);let U=u(B*B),Z=u(U-ge),k=u(I*U-v),{isValid:y,value:w}=l(Z,k);if(!y)throw new Error("bad point: invalid y coordinate");let _=(w&ge)===ge,S=(P&128)!==0;if(!g&&w===It&&S)throw new Error("bad point: x=0 and x_0=1");return S!==_&&(w=u(-w)),d.fromAffine({x:w,y:B})}static fromHex(h,g=!1){return d.fromBytes(Tr(h),g)}get x(){return this.toAffine().x}get y(){return this.toAffine().y}precompute(h=8,g=!0){return p.createCache(this,h),g||this.multiply(Si),this}assertValidity(){let h=this,{a:g,d:E}=i;if(h.is0())throw new Error("bad point: ZERO");let{X:v,Y:I,Z:D,T:P}=h,B=u(v*v),T=u(I*I),U=u(D*D),Z=u(U*U),k=u(B*g),y=u(U*u(k+T)),w=u(Z+u(E*u(B*T)));if(y!==w)throw new Error("bad point: equation left != right (1)");let _=u(v*I),S=u(D*P);if(_!==S)throw new Error("bad point: equation left != right (2)")}equals(h){m(h);let{X:g,Y:E,Z:v}=this,{X:I,Y:D,Z:P}=h,B=u(g*P),T=u(I*v),U=u(E*P),Z=u(D*v);return B===T&&U===Z}is0(){return this.equals(d.ZERO)}negate(){return new d(u(-this.X),this.Y,this.Z,u(-this.T))}double(){let{a:h}=i,{X:g,Y:E,Z:v}=this,I=u(g*g),D=u(E*E),P=u(Si*u(v*v)),B=u(h*I),T=g+E,U=u(u(T*T)-I-D),Z=B+D,k=Z-P,y=B-D,w=u(U*k),_=u(Z*y),S=u(U*y),x=u(k*Z);return new d(w,_,x,S)}add(h){m(h);let{a:g,d:E}=i,{X:v,Y:I,Z:D,T:P}=this,{X:B,Y:T,Z:U,T:Z}=h,k=u(v*B),y=u(I*T),w=u(P*E*Z),_=u(D*U),S=u((v+I)*(B+T)-k-y),x=_-w,A=_+w,L=u(y-g*k),C=u(S*x),R=u(A*L),N=u(S*L),z=u(x*A);return new d(C,R,z,N)}subtract(h){return m(h),this.add(h.negate())}multiply(h){if(!o.isValidNot0(h))throw new RangeError("invalid scalar: expected 1 <= sc < curve.n");let{p:g,f:E}=p.cached(this,h,v=>Xt(d,v));return Xt(d,[g,E])[0]}multiplyUnsafe(h){if(!o.isValid(h))throw new RangeError("invalid scalar: expected 0 <= sc < curve.n");return h===It?d.ZERO:this.is0()||h===ge?this:p.unsafe(this,h,g=>Xt(d,g))}isSmallOrder(){return this.clearCofactor().is0()}isTorsionFree(){return p.unsafe(this,i.n).is0()}toAffine(h){let g=this,E=h,{X:v,Y:I,Z:D}=g,P=g.is0();E==null&&(E=P?up:s.inv(D));let B=u(v*E),T=u(I*E),U=s.mul(D,E);if(P)return{x:It,y:ge};if(U!==ge)throw new Error("invZ was invalid");return{x:B,y:T}}clearCofactor(){return a===ge?this:this.multiplyUnsafe(a)}toBytes(){let{x:h,y:g}=this.toAffine(),E=s.toBytes(g);return E[E.length-1]|=h&ge?128:0,E}toHex(){return Ar(this.toBytes())}toString(){return`<Point ${this.is0()?"ZERO":this.toHex()}>`}}let p=new Br(d,o.BITS);return o.BITS>=8&&d.BASE.precompute(8),Object.freeze(d.prototype),Object.freeze(d),d}var wo=class{static BASE;static ZERO;static Fp;static Fn;ep;constructor(e){this.ep=e}static fromBytes(e){pi()}static fromHex(e){pi()}get x(){return this.toAffine().x}get y(){return this.toAffine().y}clearCofactor(){return this}assertValidity(){this.ep.assertValidity()}toAffine(e){return this.ep.toAffine(e)}toHex(){return Ar(this.toBytes())}toString(){return this.toHex()}isTorsionFree(){return!0}isSmallOrder(){return!1}add(e){return this.assertSame(e),this.init(this.ep.add(e.ep))}subtract(e){return this.assertSame(e),this.init(this.ep.subtract(e.ep))}multiply(e){return this.init(this.ep.multiply(e))}multiplyUnsafe(e){return this.init(this.ep.multiplyUnsafe(e))}double(){return this.init(this.ep.double())}negate(){return this.init(this.ep.negate())}precompute(e,t){return this.ep.precompute(e,t),this}};function sl(r,e,t={}){if(typeof e!="function")throw new Error('"hash" function param is required');let n=e,s=t;$e(s,{},{adjustScalarBytes:"function",randomBytes:"function",domain:"function",prehash:"function",zip215:"boolean",mapToCurve:"function"});let{prehash:o}=s,{BASE:i,Fp:a,Fn:c}=r,u=n.outputLen,l=2*a.BYTES;if(u!==void 0&&(He(u,"hash.outputLen"),u!==l))throw new Error(`hash.outputLen must be ${l}, got ${u}`);let f=s.randomBytes===void 0?hn:s.randomBytes,m=s.adjustScalarBytes===void 0?y=>y:s.adjustScalarBytes,d=s.domain===void 0?(y,w,_)=>{if(Ve(_,"phflag"),w.length||_)throw new Error("Contexts/pre-hash are not supported");return y}:s.domain;function p(y){return c.create(et(y))}function b(y){let w=B.secretKey;H(y,B.secretKey,"secretKey");let _=H(n(y),2*w,"hashedSecretKey"),S=m(_.slice(0,w)),x=_.slice(w,2*w),A=p(S);return{head:S,prefix:x,scalar:A}}function h(y){let{head:w,prefix:_,scalar:S}=b(y),x=i.multiply(S),A=x.toBytes();return{head:w,prefix:_,scalar:S,point:x,pointBytes:A}}function g(y){return h(y).pointBytes}function E(y=Uint8Array.of(),...w){let _=pe(...w);return p(n(d(_,H(y,void 0,"context"),!!o)))}function v(y,w,_={}){y=H(y,void 0,"message"),o&&(y=o(y));let{prefix:S,scalar:x,pointBytes:A}=h(w),L=E(_.context,S,y),C=i.multiply(L).toBytes(),R=E(_.context,C,A,y),N=c.create(L+R*x);if(!c.isValid(N))throw new Error("sign failed: invalid s");let z=pe(C,c.toBytes(N));return H(z,B.signature,"result")}let I={zip215:s.zip215};function D(y,w,_,S=I){let{context:x}=S,A=S.zip215===void 0?!!I.zip215:S.zip215,L=B.signature;y=H(y,L,"signature"),w=H(w,void 0,"message"),_=H(_,B.publicKey,"publicKey"),A!==void 0&&Ve(A,"zip215"),o&&(w=o(w));let C=L/2,R=y.subarray(0,C),N=et(y.subarray(C,L)),z,W,K;try{z=r.fromBytes(_,A),W=r.fromBytes(R,A),K=i.multiplyUnsafe(N)}catch{return!1}if(!A&&z.isSmallOrder())return!1;let de=E(x,R,_,w);return W.add(z.multiplyUnsafe(de)).subtract(K).clearCofactor().is0()}let P=a.BYTES,B={secretKey:P,publicKey:P,signature:2*P,seed:P};function T(y){return y=y===void 0?f(B.seed):y,H(y,B.seed,"seed")}function U(y){return Wt(y)&&y.length===B.secretKey}function Z(y,w){try{return!!r.fromBytes(y,w===void 0?I.zip215:w)}catch{return!1}}let k={getExtendedPublicKey:h,randomSecretKey:T,isValidSecretKey:U,isValidPublicKey:Z,toMontgomery(y){let{y:w}=r.fromBytes(y),_=B.publicKey,S=_===32;if(!S&&_!==57)throw new Error("only defined for 25519 and 448");let x=S?a.div(ge+w,ge-w):a.div(w-ge,w+ge);return a.toBytes(x)},toMontgomerySecret(y){let w=B.secretKey;H(y,w);let _=n(y.subarray(0,w));return m(_).subarray(0,w)}};return Object.freeze(B),Object.freeze(k),Object.freeze({keygen:bo(T,g),getPublicKey:g,sign:v,verify:D,utils:k,Point:r,lengths:B})}function wn(r,e){if(He(r),He(e),e<0||e>4)throw new Error("invalid I2OSP length: "+e);if(r<0||r>2**(8*e)-1)throw new Error("invalid I2OSP input: "+r);let t=Array.from({length:e}).fill(0);for(let n=e-1;n>=0;n--)t[n]=r&255,r>>>=8;return new Uint8Array(t)}function fp(r,e){let t=new Uint8Array(r.length);for(let n=0;n<r.length;n++)t[n]=r[n]^e[n];return t}function dp(r){if(!Wt(r)&&typeof r!="string")throw new Error("DST must be Uint8Array or ascii string");let e=typeof r=="string"?mo(r):r;if(e.length===0)throw new Error("DST must be non-empty");return e}function vi(r,e,t,n){H(r),He(t),e=dp(e),e.length>255&&(e=n(pe(mo("H2C-OVERSIZE-DST-"),e)));let{outputLen:s,blockLen:o}=n,i=Math.ceil(t/s);if(t>65535||i>255)throw new Error("expand_message_xmd: invalid lenInBytes");let a=pe(e,wn(e.length,1)),c=new Uint8Array(o),u=wn(t,2),l=new Array(i),f=n(pe(c,r,u,wn(0,1),a));l[0]=n(pe(f,wn(1,1),a));for(let d=1;d<i;d++){let p=[fp(f,l[d-1]),wn(d+1,1),a];l[d]=n(pe(...p))}return pe(...l).slice(0,t)}var il="HashToScalar-";var hp=BigInt(0),pt=BigInt(1),al=BigInt(2);var pp=BigInt(5),mp=BigInt(8),Rr=BigInt("0x7fffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffed"),Di={p:Rr,n:BigInt("0x1000000000000000000000000000000014def9dea2f79cd65812631a5cf5d3ed"),h:mp,a:BigInt("0x7fffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffec"),d:BigInt("0x52036cee2b6ffe738cc740797779e89800700a4d4141d8ab75eb4dca135978a3"),Gx:BigInt("0x216936d3cd6e53fec0a4e231fdd6dc5c692cc7609525a7b2c9562d608f25d51a"),Gy:BigInt("0x6666666666666666666666666666666666666666666666666666666666666658")};function yp(r){let e=BigInt(10),t=BigInt(20),n=BigInt(40),s=BigInt(80),o=Rr,a=r*r%o*r%o,c=te(a,al,o)*a%o,u=te(c,pt,o)*r%o,l=te(u,pp,o)*u%o,f=te(l,e,o)*l%o,m=te(f,t,o)*f%o,d=te(m,n,o)*m%o,p=te(d,s,o)*d%o,b=te(p,s,o)*d%o,h=te(b,e,o)*l%o;return{pow_p_5_8:te(h,al,o)*r%o,b2:a}}function gp(r){return r[0]&=248,r[31]&=127,r[31]|=64,r}var _i=BigInt("19681161376707505956807079304988542015446066515923890162744021073123829784752");function Ii(r,e){let t=Rr,n=le(e*e*e,t),s=le(n*n*e,t),o=yp(r*s).pow_p_5_8,i=le(r*n*o,t),a=le(e*i*i,t),c=i,u=le(i*_i,t),l=a===r,f=a===le(-r,t),m=a===le(-r*_i,t);return l&&(i=c),(f||m)&&(i=u),ht(i,t)&&(i=le(-i,t)),{isValid:l||f,value:i}}var Lt=ol(Di,{uvRatio:Ii}),Ct=Lt.Fp,ll=Lt.Fn;function bp(r){return sl(Lt,uo,Object.assign({adjustScalarBytes:gp,zip215:!0},r))}var fl=bp({});var Ai=_i,wp=BigInt("25063068953384623474111414158702152701244531502492656460079210482610430750235"),xp=BigInt("54469307008909316920995813868745141605393597292927456921205312896311721017578"),Ep=BigInt("1159843021668779879193775521855586647937357759715417654439879720876111806838"),Sp=BigInt("40440834346308536858101042469323190826248399146238708352240133220865137265952"),cl=r=>Ii(pt,r),vp=BigInt("0x7fffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffff"),Ti=r=>Ct.create(et(r)&vp);function ul(r){let{d:e}=Di,t=Rr,n=g=>Ct.create(g),s=n(Ai*r*r),o=n((s+pt)*Ep),i=BigInt(-1),a=n((i-e*s)*n(s+e)),{isValid:c,value:u}=Ii(o,a),l=n(u*r);ht(l,t)||(l=n(-l)),c||(u=l),c||(i=s);let f=n(i*(s-pt)*Sp-a),m=u*u,d=n((u+u)*a),p=n(f*wp),b=n(pt-m),h=n(pt+m);return new Lt(n(d*h),n(b*p),n(p*h),n(d*b))}var Bt=class r extends wo{static BASE=new r(Lt.BASE);static ZERO=new r(Lt.ZERO);static Fp=Ct;static Fn=ll;constructor(e){super(e)}static fromAffine(e){return new r(Lt.fromAffine(e))}assertSame(e){if(!(e instanceof r))throw new Error("RistrettoPoint expected")}init(e){return new r(e)}static fromBytes(e){Ne(e,32);let{a:t,d:n}=Di,s=Rr,o=I=>Ct.create(I),i=Ti(e);if(!Mu(Ct.toBytes(i),e)||ht(i,s))throw new Error("invalid ristretto255 encoding 1");let a=o(i*i),c=o(pt+t*a),u=o(pt-t*a),l=o(c*c),f=o(u*u),m=o(t*n*l-f),{isValid:d,value:p}=cl(o(m*f)),b=o(p*u),h=o(p*b*m),g=o((i+i)*b);ht(g,s)&&(g=o(-g));let E=o(c*h),v=o(g*E);if(!d||ht(v,s)||E===hp)throw new Error("invalid ristretto255 encoding 2");return new r(new Lt(g,E,pt,v))}static fromHex(e){return r.fromBytes(un(e))}toBytes(){let{X:e,Y:t,Z:n,T:s}=this.ep,o=Rr,i=h=>Ct.create(h),a=i(i(n+t)*i(n-t)),c=i(e*t),u=i(c*c),{value:l}=cl(i(a*u)),f=i(l*a),m=i(l*c),d=i(f*m*s),p;if(ht(s*d,o)){let h=i(t*Ai),g=i(e*Ai);e=h,t=g,p=i(f*xp)}else p=m;ht(e*d,o)&&(t=i(-t));let b=i((n-t)*p);return ht(b,o)&&(b=i(-b)),Ct.toBytes(b)}equals(e){this.assertSame(e);let{X:t,Y:n}=this.ep,{X:s,Y:o}=e.ep,i=u=>Ct.create(u),a=i(t*o)===i(n*s),c=i(n*o)===i(t*s);return a||c}is0(){return this.equals(r.ZERO)}};Object.freeze(Bt.BASE);Object.freeze(Bt.ZERO);Object.freeze(Bt.prototype);Object.freeze(Bt);var _p=Object.freeze({Point:Bt,hashToCurve(r,e){let t=e?.DST===void 0?"ristretto255_XMD:SHA-512_R255MAP_RO_":e.DST,n=vi(r,t,64,uo);return _p.deriveToCurve(n)},hashToScalar(r,e={DST:il}){let t=vi(r,e.DST,64,uo);return ll.create(et(t))},deriveToCurve(r){Ne(r,64);let e=Ti(r.subarray(0,32)),t=ul(e),n=Ti(r.subarray(32,64)),s=ul(n);return new Bt(t.add(s))}});var xn=class extends Error{constructor(e="An error occurred while verifying a message"){super(e),this.name="VerificationError"}},xo=class extends Error{constructor(e="Missing Web Crypto API"){super(e),this.name="WebCryptoMissingError"}};var Me={get(r=globalThis){let e=r.crypto;if(e?.subtle==null)throw new xo("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 e}};var Eo=32;var Ci,Ap=(async()=>{try{return await Me.get().subtle.generateKey({name:"Ed25519"},!0,["sign","verify"]),!0}catch{return!1}})();async function Tp(r,e,t){if(r.buffer instanceof ArrayBuffer){let n=await Me.get().subtle.importKey("raw",r.buffer,{name:"Ed25519"},!1,["verify"]);return await Me.get().subtle.verify({name:"Ed25519"},n,Pe(e),Pe(t instanceof Uint8Array?t:t.subarray()))}throw new TypeError("WebCrypto does not support SharedArrayBuffer for Ed25519 keys")}function Dp(r,e,t){return fl.verify(e,t instanceof Uint8Array?t:t.subarray(),r)}async function dl(r,e,t){return Ci==null&&(Ci=await Ap),Ci?Tp(r,e,t):Dp(r,e,t)}function Ip(r){return r?.buffer instanceof ArrayBuffer}function Li(r){if(Ip(r))return r;let e=r.slice();return new Uint8Array(e.buffer,0,e.byteLength)}function Qt(r,e){e==null&&(e=r.reduce((s,o)=>s+o.length,0));let t=Ht(e),n=0;for(let s of r)t.set(s,n),n+=s.length;return Li(t)}function So(r){return r==null?!1:typeof r.then=="function"&&typeof r.catch=="function"&&typeof r.finally=="function"}var vo=class{type="Ed25519";raw;constructor(e){this.raw=Bi(e,Eo)}toMultihash(){return qe.digest(Qe(this))}toCID(){return fe.createV1(114,this.toMultihash())}toString(){return re.encode(this.toMultihash().bytes).substring(1)}equals(e){return e==null||!(e.raw instanceof Uint8Array)?!1:he(this.raw,e.raw)}verify(e,t,n){n?.signal?.throwIfAborted();let s=dl(this.raw,t,e);return So(s)?s.then(o=>(n?.signal?.throwIfAborted(),o)):s}};function Ri(r){return r=Bi(r,Eo),new vo(r)}function Bi(r,e){if(r=Uint8Array.from(r??[]),r.length!==e)throw new se(`Key must be a Uint8Array of length ${e}, got ${r.length}`);return r}function pl(r=0){return new Uint8Array(r)}var Lp=Math.pow(2,7),Bp=Math.pow(2,14),Rp=Math.pow(2,21),Oi=Math.pow(2,28),Pi=Math.pow(2,35),Ni=Math.pow(2,42),Ui=Math.pow(2,49),G=128,Se=127;function mt(r){if(r<Lp)return 1;if(r<Bp)return 2;if(r<Rp)return 3;if(r<Oi)return 4;if(r<Pi)return 5;if(r<Ni)return 6;if(r<Ui)return 7;if(Number.MAX_SAFE_INTEGER!=null&&r>Number.MAX_SAFE_INTEGER)throw new RangeError("Could not encode varint");return 8}function ki(r,e,t=0){switch(mt(r)){case 8:e[t++]=r&255|G,r/=128;case 7:e[t++]=r&255|G,r/=128;case 6:e[t++]=r&255|G,r/=128;case 5:e[t++]=r&255|G,r/=128;case 4:e[t++]=r&255|G,r>>>=7;case 3:e[t++]=r&255|G,r>>>=7;case 2:e[t++]=r&255|G,r>>>=7;case 1:{e[t++]=r&255,r>>>=7;break}default:throw new Error("unreachable")}return e}function Op(r,e,t=0){switch(mt(r)){case 8:e.set(t++,r&255|G),r/=128;case 7:e.set(t++,r&255|G),r/=128;case 6:e.set(t++,r&255|G),r/=128;case 5:e.set(t++,r&255|G),r/=128;case 4:e.set(t++,r&255|G),r>>>=7;case 3:e.set(t++,r&255|G),r>>>=7;case 2:e.set(t++,r&255|G),r>>>=7;case 1:{e.set(t++,r&255),r>>>=7;break}default:throw new Error("unreachable")}return e}function Fi(r,e){let t=r[e],n=0;if(n+=t&Se,t<G||(t=r[e+1],n+=(t&Se)<<7,t<G)||(t=r[e+2],n+=(t&Se)<<14,t<G)||(t=r[e+3],n+=(t&Se)<<21,t<G)||(t=r[e+4],n+=(t&Se)*Oi,t<G)||(t=r[e+5],n+=(t&Se)*Pi,t<G)||(t=r[e+6],n+=(t&Se)*Ni,t<G)||(t=r[e+7],n+=(t&Se)*Ui,t<G))return n;throw new RangeError("Could not decode varint")}function Pp(r,e){let t=r.get(e),n=0;if(n+=t&Se,t<G||(t=r.get(e+1),n+=(t&Se)<<7,t<G)||(t=r.get(e+2),n+=(t&Se)<<14,t<G)||(t=r.get(e+3),n+=(t&Se)<<21,t<G)||(t=r.get(e+4),n+=(t&Se)*Oi,t<G)||(t=r.get(e+5),n+=(t&Se)*Pi,t<G)||(t=r.get(e+6),n+=(t&Se)*Ni,t<G)||(t=r.get(e+7),n+=(t&Se)*Ui,t<G))return n;throw new RangeError("Could not decode varint")}function Or(r,e,t=0){return e==null&&(e=pl(mt(r))),e instanceof Uint8Array?ki(r,e,t):Op(r,e,t)}function ml(r,e=0){return r instanceof Uint8Array?Fi(r,e):Pp(r,e)}var Mi=new Float32Array([-0]),Rt=new Uint8Array(Mi.buffer);function gl(r,e,t){Mi[0]=r,e[t]=Rt[0],e[t+1]=Rt[1],e[t+2]=Rt[2],e[t+3]=Rt[3]}function bl(r,e){return Rt[0]=r[e],Rt[1]=r[e+1],Rt[2]=r[e+2],Rt[3]=r[e+3],Mi[0]}var Ki=new Float64Array([-0]),ve=new Uint8Array(Ki.buffer);function wl(r,e,t){Ki[0]=r,e[t]=ve[0],e[t+1]=ve[1],e[t+2]=ve[2],e[t+3]=ve[3],e[t+4]=ve[4],e[t+5]=ve[5],e[t+6]=ve[6],e[t+7]=ve[7]}function xl(r,e){return ve[0]=r[e],ve[1]=r[e+1],ve[2]=r[e+2],ve[3]=r[e+3],ve[4]=r[e+4],ve[5]=r[e+5],ve[6]=r[e+6],ve[7]=r[e+7],Ki[0]}var Np=BigInt(Number.MAX_SAFE_INTEGER),Up=BigInt(Number.MIN_SAFE_INTEGER),Ue=class r{lo;hi;constructor(e,t){this.lo=e|0,this.hi=t|0}toNumber(e=!1){if(!e&&this.hi>>>31>0){let t=~this.lo+1>>>0,n=~this.hi>>>0;return t===0&&(n=n+1>>>0),-(t+n*4294967296)}return this.lo+this.hi*4294967296}toBigInt(e=!1){if(e)return BigInt(this.lo>>>0)+(BigInt(this.hi>>>0)<<32n);if(this.hi>>>31){let t=~this.lo+1>>>0,n=~this.hi>>>0;return t===0&&(n=n+1>>>0),-(BigInt(t)+(BigInt(n)<<32n))}return BigInt(this.lo>>>0)+(BigInt(this.hi>>>0)<<32n)}toString(e=!1){return this.toBigInt(e).toString()}zzEncode(){let e=this.hi>>31;return this.hi=((this.hi<<1|this.lo>>>31)^e)>>>0,this.lo=(this.lo<<1^e)>>>0,this}zzDecode(){let e=-(this.lo&1);return this.lo=((this.lo>>>1|this.hi<<31)^e)>>>0,this.hi=(this.hi>>>1^e)>>>0,this}length(){let e=this.lo,t=(this.lo>>>28|this.hi<<4)>>>0,n=this.hi>>>24;return n===0?t===0?e<16384?e<128?1:2:e<2097152?3:4:t<16384?t<128?5:6:t<2097152?7:8:n<128?9:10}static fromBigInt(e){if(e===0n)return Jt;if(e<Np&&e>Up)return this.fromNumber(Number(e));let t=e<0n;t&&(e=-e);let n=e>>32n,s=e-(n<<32n);return t&&(n=~n|0n,s=~s|0n,++s>El&&(s=0n,++n>El&&(n=0n))),new r(Number(s),Number(n))}static fromNumber(e){if(e===0)return Jt;let t=e<0;t&&(e=-e);let n=e>>>0,s=(e-n)/4294967296>>>0;return t&&(s=~s>>>0,n=~n>>>0,++n>4294967295&&(n=0,++s>4294967295&&(s=0))),new r(n,s)}static from(e){return typeof e=="number"?r.fromNumber(e):typeof e=="bigint"?r.fromBigInt(e):typeof e=="string"?r.fromBigInt(BigInt(e)):e.low!=null||e.high!=null?new r(e.low>>>0,e.high>>>0):Jt}},Jt=new Ue(0,0);Jt.toBigInt=function(){return 0n};Jt.zzEncode=Jt.zzDecode=function(){return this};Jt.length=function(){return 1};var El=4294967296n;function Sl(r){let e=0,t=0;for(let n=0;n<r.length;++n)t=r.charCodeAt(n),t<128?e+=1:t<2048?e+=2:(t&64512)===55296&&(r.charCodeAt(n+1)&64512)===56320?(++n,e+=4):e+=3;return e}function vl(r,e,t){if(t-e<1)return"";let s,o=[],i=0,a;for(;e<t;)a=r[e++],a<128?o[i++]=a:a>191&&a<224?o[i++]=(a&31)<<6|r[e++]&63:a>239&&a<365?(a=((a&7)<<18|(r[e++]&63)<<12|(r[e++]&63)<<6|r[e++]&63)-65536,o[i++]=55296+(a>>10),o[i++]=56320+(a&1023)):o[i++]=(a&15)<<12|(r[e++]&63)<<6|r[e++]&63,i>8191&&((s??(s=[])).push(String.fromCharCode.apply(String,o)),i=0);return s!=null?(i>0&&s.push(String.fromCharCode.apply(String,o.slice(0,i))),s.join("")):String.fromCharCode.apply(String,o.slice(0,i))}function qi(r,e,t){let n=t,s,o;for(let i=0;i<r.length;++i)s=r.charCodeAt(i),s<128?e[t++]=s:s<2048?(e[t++]=s>>6|192,e[t++]=s&63|128):(s&64512)===55296&&((o=r.charCodeAt(i+1))&64512)===56320?(s=65536+((s&1023)<<10)+(o&1023),++i,e[t++]=s>>18|240,e[t++]=s>>12&63|128,e[t++]=s>>6&63|128,e[t++]=s&63|128):(e[t++]=s>>12|224,e[t++]=s>>6&63|128,e[t++]=s&63|128);return t-n}function je(r,e){return RangeError(`index out of range: ${r.pos} + ${e??1} > ${r.len}`)}function _o(r,e){return(r[e-4]|r[e-3]<<8|r[e-2]<<16|r[e-1]<<24)>>>0}var zi=class{buf;pos;len;_slice=Uint8Array.prototype.subarray;constructor(e){this.buf=e,this.pos=0,this.len=e.length}uint32(){let e=4294967295;if(e=(this.buf[this.pos]&127)>>>0,this.buf[this.pos++]<128||(e=(e|(this.buf[this.pos]&127)<<7)>>>0,this.buf[this.pos++]<128)||(e=(e|(this.buf[this.pos]&127)<<14)>>>0,this.buf[this.pos++]<128)||(e=(e|(this.buf[this.pos]&127)<<21)>>>0,this.buf[this.pos++]<128)||(e=(e|(this.buf[this.pos]&15)<<28)>>>0,this.buf[this.pos++]<128))return e;if((this.pos+=5)>this.len)throw this.pos=this.len,je(this,10);return e}int32(){return this.uint32()|0}sint32(){let e=this.uint32();return e>>>1^-(e&1)|0}bool(){return this.uint32()!==0}fixed32(){if(this.pos+4>this.len)throw je(this,4);return _o(this.buf,this.pos+=4)}sfixed32(){if(this.pos+4>this.len)throw je(this,4);return _o(this.buf,this.pos+=4)|0}float(){if(this.pos+4>this.len)throw je(this,4);let e=bl(this.buf,this.pos);return this.pos+=4,e}double(){if(this.pos+8>this.len)throw je(this,4);let e=xl(this.buf,this.pos);return this.pos+=8,e}bytes(){let e=this.uint32(),t=this.pos,n=this.pos+e;if(n>this.len)throw je(this,e);return this.pos+=e,t===n?new Uint8Array(0):this.buf.subarray(t,n)}string(){let e=this.bytes();return vl(e,0,e.length)}skip(e){if(typeof e=="number"){if(this.pos+e>this.len)throw je(this,e);this.pos+=e}else do if(this.pos>=this.len)throw je(this);while((this.buf[this.pos++]&128)!==0);return this}skipType(e){switch(e){case 0:this.skip();break;case 1:this.skip(8);break;case 2:this.skip(this.uint32());break;case 3:for(;(e=this.uint32()&7)!==4;)this.skipType(e);break;case 5:this.skip(4);break;default:throw Error(`invalid wire type ${e} at offset ${this.pos}`)}return this}readLongVarint(){let e=new Ue(0,0),t=0;if(this.len-this.pos>4){for(;t<4;++t)if(e.lo=(e.lo|(this.buf[this.pos]&127)<<t*7)>>>0,this.buf[this.pos++]<128)return e;if(e.lo=(e.lo|(this.buf[this.pos]&127)<<28)>>>0,e.hi=(e.hi|(this.buf[this.pos]&127)>>4)>>>0,this.buf[this.pos++]<128)return e;t=0}else{for(;t<3;++t){if(this.pos>=this.len)throw je(this);if(e.lo=(e.lo|(this.buf[this.pos]&127)<<t*7)>>>0,this.buf[this.pos++]<128)return e}return e.lo=(e.lo|(this.buf[this.pos++]&127)<<t*7)>>>0,e}if(this.len-this.pos>4){for(;t<5;++t)if(e.hi=(e.hi|(this.buf[this.pos]&127)<<t*7+3)>>>0,this.buf[this.pos++]<128)return e}else for(;t<5;++t){if(this.pos>=this.len)throw je(this);if(e.hi=(e.hi|(this.buf[this.pos]&127)<<t*7+3)>>>0,this.buf[this.pos++]<128)return e}throw Error("invalid varint encoding")}readFixed64(){if(this.pos+8>this.len)throw je(this,8);let e=_o(this.buf,this.pos+=4),t=_o(this.buf,this.pos+=4);return new Ue(e,t)}int64(){return this.readLongVarint().toBigInt()}int64Number(){return this.readLongVarint().toNumber()}int64String(){return this.readLongVarint().toString()}uint64(){return this.readLongVarint().toBigInt(!0)}uint64Number(){let e=Fi(this.buf,this.pos);return this.pos+=mt(e),e}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 En(r){return new zi(r instanceof Uint8Array?r:r.subarray())}function Le(r,e,t){let n=En(r);return e.decode(n,void 0,t)}function er(r=0){return new Uint8Array(r)}var Wi={};J(Wi,{base10:()=>Vp});var ax=new Uint8Array(0);function Al(r,e){if(r===e)return!0;if(r.byteLength!==e.byteLength)return!1;for(let t=0;t<r.byteLength;t++)if(r[t]!==e[t])return!1;return!0}function yt(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 Tl(r){return new TextEncoder().encode(r)}function Dl(r){return new TextDecoder().decode(r)}function kp(r,e){if(r.length>=255)throw new TypeError("Alphabet too long");for(var t=new Uint8Array(256),n=0;n<t.length;n++)t[n]=255;for(var s=0;s<r.length;s++){var o=r.charAt(s),i=o.charCodeAt(0);if(t[i]!==255)throw new TypeError(o+" is ambiguous");t[i]=s}var a=r.length,c=r.charAt(0),u=Math.log(a)/Math.log(256),l=Math.log(256)/Math.log(a);function f(p){if(p instanceof Uint8Array||(ArrayBuffer.isView(p)?p=new Uint8Array(p.buffer,p.byteOffset,p.byteLength):Array.isArray(p)&&(p=Uint8Array.from(p))),!(p instanceof Uint8Array))throw new TypeError("Expected Uint8Array");if(p.length===0)return"";for(var b=0,h=0,g=0,E=p.length;g!==E&&p[g]===0;)g++,b++;for(var v=(E-g)*l+1>>>0,I=new Uint8Array(v);g!==E;){for(var D=p[g],P=0,B=v-1;(D!==0||P<h)&&B!==-1;B--,P++)D+=256*I[B]>>>0,I[B]=D%a>>>0,D=D/a>>>0;if(D!==0)throw new Error("Non-zero carry");h=P,g++}for(var T=v-h;T!==v&&I[T]===0;)T++;for(var U=c.repeat(b);T<v;++T)U+=r.charAt(I[T]);return U}function m(p){if(typeof p!="string")throw new TypeError("Expected String");if(p.length===0)return new Uint8Array;var b=0;if(p[b]!==" "){for(var h=0,g=0;p[b]===c;)h++,b++;for(var E=(p.length-b)*u+1>>>0,v=new Uint8Array(E);p[b];){var I=t[p.charCodeAt(b)];if(I===255)return;for(var D=0,P=E-1;(I!==0||D<g)&&P!==-1;P--,D++)I+=a*v[P]>>>0,v[P]=I%256>>>0,I=I/256>>>0;if(I!==0)throw new Error("Non-zero carry");g=D,b++}if(p[b]!==" "){for(var B=E-g;B!==E&&v[B]===0;)B++;for(var T=new Uint8Array(h+(E-B)),U=h;B!==E;)T[U++]=v[B++];return T}}}function d(p){var b=m(p);if(b)return b;throw new Error(`Non-${e} character`)}return{encode:f,decodeUnsafe:m,decode:d}}var Fp=kp,Mp=Fp,Cl=Mp;var Vi=class{name;prefix;baseEncode;constructor(e,t,n){this.name=e,this.prefix=t,this.baseEncode=n}encode(e){if(e instanceof Uint8Array)return`${this.prefix}${this.baseEncode(e)}`;throw Error("Unknown type, must be binary type")}},Hi=class{name;prefix;baseDecode;prefixCodePoint;constructor(e,t,n){this.name=e,this.prefix=t;let s=t.codePointAt(0);if(s===void 0)throw new Error("Invalid prefix character");this.prefixCodePoint=s,this.baseDecode=n}decode(e){if(typeof e=="string"){if(e.codePointAt(0)!==this.prefixCodePoint)throw Error(`Unable to decode multibase string ${JSON.stringify(e)}, ${this.name} decoder only supports inputs prefixed with ${this.prefix}`);return this.baseDecode(e.slice(this.prefix.length))}else throw Error("Can only multibase decode strings")}or(e){return Ll(this,e)}},$i=class{decoders;constructor(e){this.decoders=e}or(e){return Ll(this,e)}decode(e){let t=e[0],n=this.decoders[t];if(n!=null)return n.decode(e);throw RangeError(`Unable to decode multibase string ${JSON.stringify(e)}, only inputs prefixed with ${Object.keys(this.decoders)} are supported`)}};function Ll(r,e){return new $i({...r.decoders??{[r.prefix]:r},...e.decoders??{[e.prefix]:e}})}var ji=class{name;prefix;baseEncode;baseDecode;encoder;decoder;constructor(e,t,n,s){this.name=e,this.prefix=t,this.baseEncode=n,this.baseDecode=s,this.encoder=new Vi(e,t,n),this.decoder=new Hi(e,t,s)}encode(e){return this.encoder.encode(e)}decode(e){return this.decoder.decode(e)}};function Pr({name:r,prefix:e,encode:t,decode:n}){return new ji(r,e,t,n)}function Ot({name:r,prefix:e,alphabet:t}){let{encode:n,decode:s}=Cl(t,r);return Pr({prefix:e,name:r,encode:n,decode:o=>yt(s(o))})}function Kp(r,e,t,n){let s=r.length;for(;r[s-1]==="=";)--s;let o=new Uint8Array(s*t/8|0),i=0,a=0,c=0;for(let u=0;u<s;++u){let l=e[r[u]];if(l===void 0)throw new SyntaxError(`Non-${n} character`);a=a<<t|l,i+=t,i>=8&&(i-=8,o[c++]=255&a>>i)}if(i>=t||(255&a<<8-i)!==0)throw new SyntaxError("Unexpected end of data");return o}function qp(r,e,t){let n=e[e.length-1]==="=",s=(1<<t)-1,o="",i=0,a=0;for(let c=0;c<r.length;++c)for(a=a<<8|r[c],i+=8;i>t;)i-=t,o+=e[s&a>>i];if(i!==0&&(o+=e[s&a<<t-i]),n)for(;(o.length*t&7)!==0;)o+="=";return o}function zp(r){let e={};for(let t=0;t<r.length;++t)e[r[t]]=t;return e}function ce({name:r,prefix:e,bitsPerChar:t,alphabet:n}){let s=zp(n);return Pr({prefix:e,name:r,encode(o){return qp(o,n,t)},decode(o){return Kp(o,s,t,r)}})}var Vp=Ot({prefix:"9",name:"base10",alphabet:"0123456789"});var Gi={};J(Gi,{base16:()=>Hp,base16upper:()=>$p});var Hp=ce({prefix:"f",name:"base16",alphabet:"0123456789abcdef",bitsPerChar:4}),$p=ce({prefix:"F",name:"base16upper",alphabet:"0123456789ABCDEF",bitsPerChar:4});var Yi={};J(Yi,{base2:()=>jp});var jp=ce({prefix:"0",name:"base2",alphabet:"01",bitsPerChar:1});var Zi={};J(Zi,{base256emoji:()=>Xp});var Bl=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}"),Wp=Bl.reduce((r,e,t)=>(r[t]=e,r),[]),Gp=Bl.reduce((r,e,t)=>{let n=e.codePointAt(0);if(n==null)throw new Error(`Invalid character: ${e}`);return r[n]=t,r},[]);function Yp(r){return r.reduce((e,t)=>(e+=Wp[t],e),"")}function Zp(r){let e=[];for(let t of r){let n=t.codePointAt(0);if(n==null)throw new Error(`Invalid character: ${t}`);let s=Gp[n];if(s==null)throw new Error(`Non-base256emoji character: ${t}`);e.push(s)}return new Uint8Array(e)}var Xp=Pr({prefix:"\u{1F680}",name:"base256emoji",encode:Yp,decode:Zp});var Xi={};J(Xi,{base32:()=>Nr,base32hex:()=>tm,base32hexpad:()=>nm,base32hexpadupper:()=>om,base32hexupper:()=>rm,base32pad:()=>Jp,base32padupper:()=>em,base32upper:()=>Qp,base32z:()=>sm});var Nr=ce({prefix:"b",name:"base32",alphabet:"abcdefghijklmnopqrstuvwxyz234567",bitsPerChar:5}),Qp=ce({prefix:"B",name:"base32upper",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZ234567",bitsPerChar:5}),Jp=ce({prefix:"c",name:"base32pad",alphabet:"abcdefghijklmnopqrstuvwxyz234567=",bitsPerChar:5}),em=ce({prefix:"C",name:"base32padupper",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZ234567=",bitsPerChar:5}),tm=ce({prefix:"v",name:"base32hex",alphabet:"0123456789abcdefghijklmnopqrstuv",bitsPerChar:5}),rm=ce({prefix:"V",name:"base32hexupper",alphabet:"0123456789ABCDEFGHIJKLMNOPQRSTUV",bitsPerChar:5}),nm=ce({prefix:"t",name:"base32hexpad",alphabet:"0123456789abcdefghijklmnopqrstuv=",bitsPerChar:5}),om=ce({prefix:"T",name:"base32hexpadupper",alphabet:"0123456789ABCDEFGHIJKLMNOPQRSTUV=",bitsPerChar:5}),sm=ce({prefix:"h",name:"base32z",alphabet:"ybndrfg8ejkmcpqxot1uwisza345h769",bitsPerChar:5});var Qi={};J(Qi,{base36:()=>Sn,base36upper:()=>im});var Sn=Ot({prefix:"k",name:"base36",alphabet:"0123456789abcdefghijklmnopqrstuvwxyz"}),im=Ot({prefix:"K",name:"base36upper",alphabet:"0123456789ABCDEFGHIJKLMNOPQRSTUVWXYZ"});var Ji={};J(Ji,{base58btc:()=>tt,base58flickr:()=>am});var tt=Ot({name:"base58btc",prefix:"z",alphabet:"123456789ABCDEFGHJKLMNPQRSTUVWXYZabcdefghijkmnopqrstuvwxyz"}),am=Ot({name:"base58flickr",prefix:"Z",alphabet:"123456789abcdefghijkmnopqrstuvwxyzABCDEFGHJKLMNPQRSTUVWXYZ"});var ea={};J(ea,{base64:()=>cm,base64pad:()=>um,base64url:()=>lm,base64urlpad:()=>fm});var cm=ce({prefix:"m",name:"base64",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/",bitsPerChar:6}),um=ce({prefix:"M",name:"base64pad",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/=",bitsPerChar:6}),lm=ce({prefix:"u",name:"base64url",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789-_",bitsPerChar:6}),fm=ce({prefix:"U",name:"base64urlpad",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789-_=",bitsPerChar:6});var ta={};J(ta,{base8:()=>dm});var dm=ce({prefix:"7",name:"base8",alphabet:"01234567",bitsPerChar:3});var ra={};J(ra,{identity:()=>hm});var hm=Pr({prefix:"\0",name:"identity",encode:r=>Dl(r),decode:r=>Tl(r)});var vx=new TextEncoder,_x=new TextDecoder;var oa={};J(oa,{identity:()=>Um});var ym=Pl,Rl=128,gm=127,bm=~gm,wm=Math.pow(2,31);function Pl(r,e,t){e=e||[],t=t||0;for(var n=t;r>=wm;)e[t++]=r&255|Rl,r/=128;for(;r&bm;)e[t++]=r&255|Rl,r>>>=7;return e[t]=r|0,Pl.bytes=t-n+1,e}var xm=na,Em=128,Ol=127;function na(r,n){var t=0,n=n||0,s=0,o=n,i,a=r.length;do{if(o>=a)throw na.bytes=0,new RangeError("Could not decode varint");i=r[o++],t+=s<28?(i&Ol)<<s:(i&Ol)*Math.pow(2,s),s+=7}while(i>=Em);return na.bytes=o-n,t}var Sm=Math.pow(2,7),vm=Math.pow(2,14),_m=Math.pow(2,21),Am=Math.pow(2,28),Tm=Math.pow(2,35),Dm=Math.pow(2,42),Im=Math.pow(2,49),Cm=Math.pow(2,56),Lm=Math.pow(2,63),Bm=function(r){return r<Sm?1:r<vm?2:r<_m?3:r<Am?4:r<Tm?5:r<Dm?6:r<Im?7:r<Cm?8:r<Lm?9:10},Rm={encode:ym,decode:xm,encodingLength:Bm},Om=Rm,vn=Om;function _n(r,e=0){return[vn.decode(r,e),vn.decode.bytes]}function Ur(r,e,t=0){return vn.encode(r,e,t),e}function kr(r){return vn.encodingLength(r)}function Mr(r,e){let t=e.byteLength,n=kr(r),s=n+kr(t),o=new Uint8Array(s+t);return Ur(r,o,0),Ur(t,o,n),o.set(e,s),new Fr(r,t,e,o)}function Nl(r){let e=yt(r),[t,n]=_n(e),[s,o]=_n(e.subarray(n)),i=e.subarray(n+o);if(i.byteLength!==s)throw new Error("Incorrect length");return new Fr(t,s,i,e)}function Ul(r,e){if(r===e)return!0;{let t=e;return r.code===t.code&&r.size===t.size&&t.bytes instanceof Uint8Array&&Al(r.bytes,t.bytes)}}var Fr=class{code;size;digest;bytes;constructor(e,t,n,s){this.code=e,this.size=t,this.digest=n,this.bytes=s}};var kl=0,Pm="identity",Fl=yt;function Nm(r,e){if(e?.truncate!=null&&e.truncate!==r.byteLength){if(e.truncate<0||e.truncate>r.byteLength)throw new Error(`Invalid truncate option, must be less than or equal to ${r.byteLength}`);r=r.subarray(0,e.truncate)}return Mr(kl,Fl(r))}var Um={code:kl,name:Pm,encode:Fl,digest:Nm};var aa={};J(aa,{sha256:()=>Fm,sha512:()=>Mm});var km=20;function ia({name:r,code:e,encode:t,minDigestLength:n,maxDigestLength:s}){return new sa(r,e,t,n,s)}var sa=class{name;code;encode;minDigestLength;maxDigestLength;constructor(e,t,n,s,o){this.name=e,this.code=t,this.encode=n,this.minDigestLength=s??km,this.maxDigestLength=o}digest(e,t){if(t?.truncate!=null){if(t.truncate<this.minDigestLength)throw new Error(`Invalid truncate option, must be greater than or equal to ${this.minDigestLength}`);if(this.maxDigestLength!=null&&t.truncate>this.maxDigestLength)throw new Error(`Invalid truncate option, must be less than or equal to ${this.maxDigestLength}`)}if(e instanceof Uint8Array){let n=this.encode(e);return n instanceof Uint8Array?Ml(n,this.code,t?.truncate):n.then(s=>Ml(s,this.code,t?.truncate))}else throw Error("Unknown type, must be binary type")}};function Ml(r,e,t){if(t!=null&&t!==r.byteLength){if(t>r.byteLength)throw new Error(`Invalid truncate option, must be less than or equal to ${r.byteLength}`);r=r.subarray(0,t)}return Mr(e,r)}function ql(r){return async e=>new Uint8Array(await crypto.subtle.digest(r,e))}var Fm=ia({name:"sha2-256",code:18,encode:ql("SHA-256")}),Mm=ia({name:"sha2-512",code:19,encode:ql("SHA-512")});function zl(r,e){let{bytes:t,version:n}=r;return n===0?qm(t,ca(r),e??tt.encoder):zm(t,ca(r),e??Nr.encoder)}var Vl=new WeakMap;function ca(r){let e=Vl.get(r);if(e==null){let t=new Map;return Vl.set(r,t),t}return e}var To=class r{code;version;multihash;bytes;"/";constructor(e,t,n,s){this.code=t,this.version=e,this.multihash=n,this.bytes=s,this["/"]=s}get asCID(){return this}get byteOffset(){return this.bytes.byteOffset}get byteLength(){return this.bytes.byteLength}toV0(){switch(this.version){case 0:return this;case 1:{let{code:e,multihash:t}=this;if(e!==Tn)throw new Error("Cannot convert a non dag-pb CID to CIDv0");if(t.code!==Vm)throw new Error("Cannot convert non sha2-256 multihash CID to CIDv0");return r.createV0(t)}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:e,digest:t}=this.multihash,n=Mr(e,t);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(e){return r.equals(this,e)}static equals(e,t){let n=t;return n!=null&&e.code===n.code&&e.version===n.version&&Ul(e.multihash,n.multihash)}toString(e){return zl(this,e)}toJSON(){return{"/":zl(this)}}link(){return this}[Symbol.toStringTag]="CID";[Symbol.for("nodejs.util.inspect.custom")](){return`CID(${this.toString()})`}static asCID(e){if(e==null)return null;let t=e;if(t instanceof r)return t;if(t["/"]!=null&&t["/"]===t.bytes||t.asCID===t){let{version:n,code:s,multihash:o,bytes:i}=t;return new r(n,s,o,i??Hl(n,s,o.bytes))}else if(t[Hm]===!0){let{version:n,multihash:s,code:o}=t,i=Nl(s);return r.create(n,o,i)}else return null}static create(e,t,n){if(typeof t!="number")throw new Error("String codecs are no longer supported");if(!(n.bytes instanceof Uint8Array))throw new Error("Invalid digest");switch(e){case 0:{if(t!==Tn)throw new Error(`Version 0 CID must use dag-pb (code: ${Tn}) block encoding`);return new r(e,t,n,n.bytes)}case 1:{let s=Hl(e,t,n.bytes);return new r(e,t,n,s)}default:throw new Error("Invalid version")}}static createV0(e){return r.create(0,Tn,e)}static createV1(e,t){return r.create(1,e,t)}static decode(e){let[t,n]=r.decodeFirst(e);if(n.length!==0)throw new Error("Incorrect length");return t}static decodeFirst(e){let t=r.inspectBytes(e),n=t.size-t.multihashSize,s=yt(e.subarray(n,n+t.multihashSize));if(s.byteLength!==t.multihashSize)throw new Error("Incorrect length");let o=s.subarray(t.multihashSize-t.digestSize),i=new Fr(t.multihashCode,t.digestSize,o,s);return[t.version===0?r.createV0(i):r.createV1(t.codec,i),e.subarray(t.size)]}static inspectBytes(e){let t=0,n=()=>{let[f,m]=_n(e.subarray(t));return t+=m,f},s=n(),o=Tn;if(s===18?(s=0,t=0):o=n(),s!==0&&s!==1)throw new RangeError(`Invalid CID version ${s}`);let i=t,a=n(),c=n(),u=t+c,l=u-i;return{version:s,codec:o,multihashCode:a,digestSize:c,multihashSize:l,size:u}}static parse(e,t){let[n,s]=Km(e,t),o=r.decode(s);if(o.version===0&&e[0]!=="Q")throw Error("Version 0 CID string must not include multibase prefix");return ca(o).set(n,e),o}};function Km(r,e){switch(r[0]){case"Q":{let t=e??tt;return[tt.prefix,t.decode(`${tt.prefix}${r}`)]}case tt.prefix:{let t=e??tt;return[tt.prefix,t.decode(r)]}case Nr.prefix:{let t=e??Nr;return[Nr.prefix,t.decode(r)]}case Sn.prefix:{let t=e??Sn;return[Sn.prefix,t.decode(r)]}default:{if(e==null)throw Error("To parse non base32, base36 or base58btc encoded CID multibase decoder must be provided");return[r[0],e.decode(r)]}}}function qm(r,e,t){let{prefix:n}=t;if(n!==tt.prefix)throw Error(`Cannot string encode V0 in ${t.name} encoding`);let s=e.get(n);if(s==null){let o=t.encode(r).slice(1);return e.set(n,o),o}else return s}function zm(r,e,t){let{prefix:n}=t,s=e.get(n);if(s==null){let o=t.encode(r);return e.set(n,o),o}else return s}var Tn=112,Vm=18;function Hl(r,e,t){let n=kr(r),s=n+kr(e),o=new Uint8Array(s+t.byteLength);return Ur(r,o,0),Ur(e,o,n),o.set(t,s),o}var Hm=Symbol.for("@ipld/js-cid/CID");var ua={...ra,...Yi,...ta,...Wi,...Gi,...Xi,...Qi,...Ji,...ea,...Zi},jx={...aa,...oa};function jl(r,e,t,n){return{name:r,prefix:e,encoder:{name:r,prefix:e,encode:t},decoder:{decode:n}}}var $l=jl("utf8","u",r=>"u"+new TextDecoder("utf8").decode(r),r=>new TextEncoder().encode(r.substring(1))),la=jl("ascii","a",r=>{let e="a";for(let t=0;t<r.length;t++)e+=String.fromCharCode(r[t]);return e},r=>{r=r.substring(1);let e=er(r.length);for(let t=0;t<r.length;t++)e[t]=r.charCodeAt(t);return e}),$m={utf8:$l,"utf-8":$l,hex:ua.base16,latin1:la,ascii:la,binary:la,...ua},Wl=$m;function Gl(r,e="utf8"){let t=Wl[e];if(t==null)throw new Error(`Unsupported encoding "${e}"`);return t.decoder.decode(`${t.prefix}${r}`)}function fa(r){let e=r??8192,t=e>>>1,n,s=e;return function(i){if(i<1||i>t)return er(i);s+i>e&&(n=er(e),s=0);let a=n.subarray(s,s+=i);return(s&7)!==0&&(s=(s|7)+1),a}}var tr=class{fn;len;next;val;constructor(e,t,n){this.fn=e,this.len=t,this.next=void 0,this.val=n}};function da(){}var pa=class{head;tail;len;next;constructor(e){this.head=e.head,this.tail=e.tail,this.len=e.len,this.next=e.states}},jm=fa();function Wm(r){return globalThis.Buffer!=null?er(r):jm(r)}var In=class{len;head;tail;states;constructor(){this.len=0,this.head=new tr(da,0,0),this.tail=this.head,this.states=null}_push(e,t,n){return this.tail=this.tail.next=new tr(e,t,n),this.len+=t,this}uint32(e){return this.len+=(this.tail=this.tail.next=new ma((e=e>>>0)<128?1:e<16384?2:e<2097152?3:e<268435456?4:5,e)).len,this}int32(e){return e<0?this._push(Do,10,Ue.fromNumber(e)):this.uint32(e)}sint32(e){return this.uint32((e<<1^e>>31)>>>0)}uint64(e){let t=Ue.fromBigInt(e);return this._push(Do,t.length(),t)}uint64Number(e){return this._push(ki,mt(e),e)}uint64String(e){return this.uint64(BigInt(e))}int64(e){return this.uint64(e)}int64Number(e){return this.uint64Number(e)}int64String(e){return this.uint64String(e)}sint64(e){let t=Ue.fromBigInt(e).zzEncode();return this._push(Do,t.length(),t)}sint64Number(e){let t=Ue.fromNumber(e).zzEncode();return this._push(Do,t.length(),t)}sint64String(e){return this.sint64(BigInt(e))}bool(e){return this._push(ha,1,e?1:0)}fixed32(e){return this._push(Dn,4,e>>>0)}sfixed32(e){return this.fixed32(e)}fixed64(e){let t=Ue.fromBigInt(e);return this._push(Dn,4,t.lo)._push(Dn,4,t.hi)}fixed64Number(e){let t=Ue.fromNumber(e);return this._push(Dn,4,t.lo)._push(Dn,4,t.hi)}fixed64String(e){return this.fixed64(BigInt(e))}sfixed64(e){return this.fixed64(e)}sfixed64Number(e){return this.fixed64Number(e)}sfixed64String(e){return this.fixed64String(e)}float(e){return this._push(gl,4,e)}double(e){return this._push(wl,8,e)}bytes(e){let t=e.length>>>0;return t===0?this._push(ha,1,0):this.uint32(t)._push(Ym,t,e)}string(e){let t=Sl(e);return t!==0?this.uint32(t)._push(qi,t,e):this._push(ha,1,0)}fork(){return this.states=new pa(this),this.head=this.tail=new tr(da,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 tr(da,0,0),this.len=0),this}ldelim(){let e=this.head,t=this.tail,n=this.len;return this.reset().uint32(n),n!==0&&(this.tail.next=e.next,this.tail=t,this.len+=n),this}finish(){let e=this.head.next,t=Wm(this.len),n=0;for(;e!=null;)e.fn(e.val,t,n),n+=e.len,e=e.next;return t}};function ha(r,e,t){e[t]=r&255}function Gm(r,e,t){for(;r>127;)e[t++]=r&127|128,r>>>=7;e[t]=r}var ma=class extends tr{next;constructor(e,t){super(Gm,e,t),this.next=void 0}};function Do(r,e,t){for(;r.hi!==0;)e[t++]=r.lo&127|128,r.lo=(r.lo>>>7|r.hi<<25)>>>0,r.hi>>>=7;for(;r.lo>127;)e[t++]=r.lo&127|128,r.lo=r.lo>>>7;e[t++]=r.lo}function Dn(r,e,t){e[t]=r&255,e[t+1]=r>>>8&255,e[t+2]=r>>>16&255,e[t+3]=r>>>24}function Ym(r,e,t){e.set(r,t)}globalThis.Buffer!=null&&(In.prototype.bytes=function(r){let e=r.length>>>0;return this.uint32(e),e>0&&this._push(Zm,e,r),this},In.prototype.string=function(r){let e=globalThis.Buffer.byteLength(r);return this.uint32(e),e>0&&this._push(Xm,e,r),this});function Zm(r,e,t){e.set(r,t)}function Xm(r,e,t){r.length<40?qi(r,e,t):e.utf8Write!=null?e.utf8Write(r,t):e.set(Gl(r),t)}function ya(){return new In}function Be(r,e){let t=ya();return e.encode(r,t,{lengthDelimited:!1}),t.finish()}function*Re(r,e,t){let n=En(r);yield*e.stream(n,void 0,"$",t)}var Io={VARINT:0,BIT64:1,LENGTH_DELIMITED:2,START_GROUP:3,END_GROUP:4,BIT32:5};function Co(r,e,t,n,s){return{name:r,type:e,encode:t,decode:n,stream:s}}function rr(r){function e(o){if(r[o.toString()]==null)throw new Error("Invalid enum value");return r[o]}let t=function(i,a){let c=e(i);a.int32(c)},n=function(i){let a=i.int32();return e(a)},s=function*(i){let a=i.int32();yield e(a)};return Co("enum",Io.VARINT,t,n,s)}function Oe(r,e,t){return Co("message",Io.LENGTH_DELIMITED,r,e,t)}var nr=class extends Error{code="ERR_MAX_LENGTH";name="MaxLengthError"};var ne;(function(r){r.RSA="RSA",r.Ed25519="Ed25519",r.secp256k1="secp256k1",r.ECDSA="ECDSA"})(ne||(ne={}));var ga;(function(r){r[r.RSA=0]="RSA",r[r.Ed25519=1]="Ed25519",r[r.secp256k1=2]="secp256k1",r[r.ECDSA=3]="ECDSA"})(ga||(ga={}));(function(r){r.codec=()=>rr(ga)})(ne||(ne={}));var rt;(function(r){let e;r.codec=()=>(e==null&&(e=Oe((o,i,a={})=>{a.lengthDelimited!==!1&&i.fork(),o.Type!=null&&(i.uint32(8),ne.codec().encode(o.Type,i)),o.Data!=null&&(i.uint32(18),i.bytes(o.Data)),a.lengthDelimited!==!1&&i.ldelim()},(o,i,a={})=>{let c={},u=i==null?o.len:o.pos+i;for(;o.pos<u;){let l=o.uint32();switch(l>>>3){case 1:{c.Type=ne.codec().decode(o);break}case 2:{c.Data=o.bytes();break}default:{o.skipType(l&7);break}}}return c},function*(o,i,a,c={}){let u=i==null?o.len:o.pos+i;for(;o.pos<u;){let l=o.uint32();switch(l>>>3){case 1:{yield{field:`${a}.Type`,value:ne.codec().decode(o)};break}case 2:{yield{field:`${a}.Data`,value:o.bytes()};break}default:{o.skipType(l&7);break}}}})),e);function t(o){return Be(o,r.codec())}r.encode=t;function n(o,i){return Le(o,r.codec(),i)}r.decode=n;function s(o,i){return Re(o,r.codec(),i)}r.stream=s})(rt||(rt={}));var ba;(function(r){let e;r.codec=()=>(e==null&&(e=Oe((o,i,a={})=>{a.lengthDelimited!==!1&&i.fork(),o.Type!=null&&(i.uint32(8),ne.codec().encode(o.Type,i)),o.Data!=null&&(i.uint32(18),i.bytes(o.Data)),a.lengthDelimited!==!1&&i.ldelim()},(o,i,a={})=>{let c={},u=i==null?o.len:o.pos+i;for(;o.pos<u;){let l=o.uint32();switch(l>>>3){case 1:{c.Type=ne.codec().decode(o);break}case 2:{c.Data=o.bytes();break}default:{o.skipType(l&7);break}}}return c},function*(o,i,a,c={}){let u=i==null?o.len:o.pos+i;for(;o.pos<u;){let l=o.uint32();switch(l>>>3){case 1:{yield{field:`${a}.Type`,value:ne.codec().decode(o)};break}case 2:{yield{field:`${a}.Data`,value:o.bytes()};break}default:{o.skipType(l&7);break}}}})),e);function t(o){return Be(o,r.codec())}r.encode=t;function n(o,i){return Le(o,r.codec(),i)}r.decode=n;function s(o,i){return Re(o,r.codec(),i)}r.stream=s})(ba||(ba={}));var Ln={};J(Ln,{MAX_RSA_KEY_SIZE:()=>wa,generateRSAKeyPair:()=>Jl,jwkToJWKKeyPair:()=>ef,jwkToPkcs1:()=>t0,jwkToPkix:()=>va,jwkToRSAPrivateKey:()=>Da,pkcs1MessageToJwk:()=>Ea,pkcs1MessageToRSAPrivateKey:()=>_a,pkcs1ToJwk:()=>e0,pkcs1ToRSAPrivateKey:()=>Ql,pkixMessageToJwk:()=>Sa,pkixMessageToRSAPublicKey:()=>Ta,pkixToJwk:()=>r0,pkixToRSAPublicKey:()=>Aa});var Kr=class{type="RSA";jwk;_raw;_multihash;constructor(e,t){this.jwk=e,this._multihash=t}get raw(){return this._raw==null&&(this._raw=Ln.jwkToPkix(this.jwk)),this._raw}toMultihash(){return this._multihash}toCID(){return fe.createV1(114,this._multihash)}toString(){return re.encode(this.toMultihash().bytes).substring(1)}equals(e){return e==null||!(e.raw instanceof Uint8Array)?!1:he(this.raw,e.raw)}verify(e,t,n){return Xl(this.jwk,t,e,n)}},Cn=class{type="RSA";jwk;_raw;publicKey;constructor(e,t){this.jwk=e,this.publicKey=t}get raw(){return this._raw==null&&(this._raw=Ln.jwkToPkcs1(this.jwk)),this._raw}equals(e){return e==null||!(e.raw instanceof Uint8Array)?!1:he(this.raw,e.raw)}sign(e,t){return Zl(this.jwk,e,t)}};var wa=8192,xa=18,Qm=1062,Jm=Uint8Array.from([48,13,6,9,42,134,72,134,247,13,1,1,1,5,0]);function e0(r){let e=ut(r);return Ea(e)}function Ea(r){return{n:V(r[1],"base64url"),e:V(r[2],"base64url"),d:V(r[3],"base64url"),p:V(r[4],"base64url"),q:V(r[5],"base64url"),dp:V(r[6],"base64url"),dq:V(r[7],"base64url"),qi:V(r[8],"base64url"),kty:"RSA"}}function t0(r){if(r.n==null||r.e==null||r.d==null||r.p==null||r.q==null||r.dp==null||r.dq==null||r.qi==null)throw new se("JWK was missing components");return vt([Ce(Uint8Array.from([0])),Ce(M(r.n,"base64url")),Ce(M(r.e,"base64url")),Ce(M(r.d,"base64url")),Ce(M(r.p,"base64url")),Ce(M(r.q,"base64url")),Ce(M(r.dp,"base64url")),Ce(M(r.dq,"base64url")),Ce(M(r.qi,"base64url"))]).subarray()}function r0(r){let e=ut(r,{offset:0});return Sa(e)}function Sa(r){let e=ut(r[1],{offset:0});return{kty:"RSA",n:V(e[0],"base64url"),e:V(e[1],"base64url")}}function va(r){if(r.n==null||r.e==null)throw new se("JWK was missing components");return vt([Jm,no(vt([Ce(M(r.n,"base64url")),Ce(M(r.e,"base64url"))]))]).subarray()}function Ql(r){let e=ut(r);return _a(e)}function _a(r){let e=Ea(r);return Da(e)}function Aa(r,e){if(r.byteLength>=Qm)throw new pr("Key size is too large");let t=ut(r,{offset:0});return Ta(t,r,e)}function Ta(r,e,t){let n=Sa(r);if(t==null){let s=_r(rt.encode({Type:ne.RSA,Data:e}));t=Ze(xa,s)}return new Kr(n,t)}function Da(r){if(rf(r)>wa)throw new se("Key size is too large");let e=ef(r),t=_r(rt.encode({Type:ne.RSA,Data:va(e.publicKey)})),n=Ze(xa,t);return new Cn(e.privateKey,new Kr(e.publicKey,n))}async function Jl(r){if(r>wa)throw new se("Key size is too large");let e=await tf(r),t=_r(rt.encode({Type:ne.RSA,Data:va(e.publicKey)})),n=Ze(xa,t);return new Cn(e.privateKey,new Kr(e.publicKey,n))}function ef(r){if(r==null)throw new se("Missing key parameter");return{privateKey:r,publicKey:{kty:r.kty,n:r.n,e:r.e}}}async function tf(r,e){let t=await Me.get().subtle.generateKey({name:"RSASSA-PKCS1-v1_5",modulusLength:r,publicExponent:new Uint8Array([1,0,1]),hash:{name:"SHA-256"}},!0,["sign","verify"]);e?.signal?.throwIfAborted();let n=await n0(t,e);return{privateKey:n[0],publicKey:n[1]}}async function Zl(r,e,t){let n=await Me.get().subtle.importKey("jwk",r,{name:"RSASSA-PKCS1-v1_5",hash:{name:"SHA-256"}},!1,["sign"]);t?.signal?.throwIfAborted();let s=await Me.get().subtle.sign({name:"RSASSA-PKCS1-v1_5"},n,Pe(e instanceof Uint8Array?e:e.subarray()));return t?.signal?.throwIfAborted(),new Uint8Array(s,0,s.byteLength)}async function Xl(r,e,t,n){let s=await Me.get().subtle.importKey("jwk",r,{name:"RSASSA-PKCS1-v1_5",hash:{name:"SHA-256"}},!1,["verify"]);n?.signal?.throwIfAborted();let o=await Me.get().subtle.verify({name:"RSASSA-PKCS1-v1_5"},s,Pe(e),Pe(t instanceof Uint8Array?t:t.subarray()));return n?.signal?.throwIfAborted(),o}async function n0(r,e){if(r.privateKey==null||r.publicKey==null)throw new se("Private and public key are required");let t=await Promise.all([Me.get().subtle.exportKey("jwk",r.privateKey),Me.get().subtle.exportKey("jwk",r.publicKey)]);return e?.signal?.throwIfAborted(),t}function rf(r){if(r.kty!=="RSA")throw new se("invalid key type");if(r.n==null)throw new se("invalid key modulus");return M(r.n,"base64url").length*8}var Lo=class{oHash;iHash;blockLen;outputLen;canXOF=!1;finished=!1;destroyed=!1;constructor(e,t){if(oo(e),Ne(t,void 0,"key"),this.iHash=e.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 n=this.blockLen,s=new Uint8Array(n);s.set(t.length>n?e.create().update(t).digest():t);for(let o=0;o<s.length;o++)s[o]^=54;this.iHash.update(s),this.oHash=e.create();for(let o=0;o<s.length;o++)s[o]^=106;this.oHash.update(s),ft(s)}update(e){return vr(this),this.iHash.update(e),this}digestInto(e){vr(this),so(e,this),this.finished=!0;let t=e.subarray(0,this.outputLen);this.iHash.digestInto(t),this.oHash.update(t),this.oHash.digestInto(t),this.destroy()}digest(){let e=new Uint8Array(this.oHash.outputLen);return this.digestInto(e),e}_cloneInto(e){e||=Object.create(Object.getPrototypeOf(this),{});let{oHash:t,iHash:n,finished:s,destroyed:o,blockLen:i,outputLen:a}=this;return e=e,e.finished=s,e.destroyed=o,e.blockLen=i,e.outputLen=a,e.oHash=t._cloneInto(e.oHash),e.iHash=n._cloneInto(e.iHash),e}clone(){return this._cloneInto()}destroy(){this.destroyed=!0,this.oHash.destroy(),this.iHash.destroy()}},nf=(()=>{let r=((e,t,n)=>new Lo(e,t).update(n).digest());return r.create=(e,t)=>new Lo(e,t),r})();var of=(r,e)=>(r+(r>=0?e:-e)/sf)/e;function o0(r,e,t){Dr("scalar",r,nt,t);let[[n,s],[o,i]]=e,a=of(i*r,t),c=of(-s*r,t),u=r-a*n-c*o,l=-a*s-c*i,f=u<nt,m=l<nt;f&&(u=-u),m&&(l=-l);let d=yn(Math.ceil(Ir(t)/2))+Pt;if(u<nt||u>=d||l<nt||l>=d)throw new Error("splitScalar (endomorphism): failed for k");return{k1neg:f,k1:u,k2neg:m,k2:l}}function Ca(r){if(!["compact","recovered","der"].includes(r))throw new Error('Signature format must be "compact", "recovered", or "der"');return r}function Ia(r,e){$e(r);let t={};for(let n of Object.keys(e))t[n]=r[n]===void 0?e[n]:r[n];return Ve(t.lowS,"lowS"),Ve(t.prehash,"prehash"),t.format!==void 0&&Ca(t.format),t}var La=class extends Error{constructor(e=""){super(e)}},We={Err:La,_tlv:{encode:(r,e)=>{let{Err:t}=We;if(He(r,"tag"),r<0||r>255)throw new t("tlv.encode: wrong tag");if(typeof e!="string")throw new TypeError('"data" expected string, got type='+typeof e);if(e.length&1)throw new t("tlv.encode: unpadded data");let n=e.length/2,s=pn(n);if(s.length/2&128)throw new t("tlv.encode: long form length too big");let o=n>127?pn(s.length/2|128):"";return pn(r)+o+s+e},decode(r,e){let{Err:t}=We;e=H(e,void 0,"DER data");let n=0;if(r<0||r>255)throw new t("tlv.encode: wrong tag");if(e.length<2||e[n++]!==r)throw new t("tlv.decode: wrong tlv");let s=e[n++],o=!!(s&128),i=0;if(!o)i=s;else{let c=s&127;if(!c)throw new t("tlv.decode(long): indefinite length not supported");if(c>4)throw new t("tlv.decode(long): byte length is too big");let u=e.subarray(n,n+c);if(u.length!==c)throw new t("tlv.decode: length bytes not complete");if(u[0]===0)throw new t("tlv.decode(long): zero leftmost byte");for(let l of u)i=i<<8|l;if(n+=c,i<128)throw new t("tlv.decode(long): not minimal encoding")}let a=e.subarray(n,n+i);if(a.length!==i)throw new t("tlv.decode: wrong value length");return{v:a,l:e.subarray(n+i)}}},_int:{encode(r){let{Err:e}=We;if(ho(r),r<nt)throw new e("integer: negative integers are not allowed");let t=pn(r);if(Number.parseInt(t[0],16)&8&&(t="00"+t),t.length&1)throw new e("unexpected DER parsing assertion: unpadded hex");return t},decode(r){let{Err:e}=We;if(r.length<1)throw new e("invalid signature integer: empty");if(r[0]&128)throw new e("invalid signature integer: negative");if(r.length>1&&r[0]===0&&!(r[1]&128))throw new e("invalid signature integer: unnecessary leading zero");return Gt(r)}},toSig(r){let{Err:e,_int:t,_tlv:n}=We,s=H(r,void 0,"signature"),{v:o,l:i}=n.decode(48,s);if(i.length)throw new e("invalid signature: left bytes after parsing");let{v:a,l:c}=n.decode(2,o),{v:u,l}=n.decode(2,c);if(l.length)throw new e("invalid signature: left bytes after parsing");return{r:t.decode(a),s:t.decode(u)}},hexFromSig(r){let{_tlv:e,_int:t}=We,n=e.encode(2,t.encode(r.r)),s=e.encode(2,t.encode(r.s)),o=n+s;return e.encode(48,o)}};Object.freeze(We._tlv);Object.freeze(We._int);Object.freeze(We);var nt=BigInt(0),Pt=BigInt(1),sf=BigInt(2),Bo=BigInt(3),s0=BigInt(4);function af(r,e={}){let t=go("weierstrass",r,e),n=t.Fp,s=t.Fn,o=t.CURVE,{h:i,n:a}=o;$e(e,{},{allowInfinityPoint:"boolean",clearCofactor:"function",isTorsionFree:"function",fromBytes:"function",toBytes:"function",endo:"object"});let{endo:c,allowInfinityPoint:u}=e;if(c&&(!n.is0(o.a)||typeof c.beta!="bigint"||!Array.isArray(c.basises)))throw new Error('invalid endo: expected "beta": bigint and "basises": array');let l=uf(n,s);function f(){if(!n.isOdd)throw new Error("compression is not supported: Field does not have .isOdd()")}function m(k,y,w){if(u&&y.is0())return Uint8Array.of(0);let{x:_,y:S}=y.toAffine(),x=n.toBytes(_);if(Ve(w,"isCompressed"),w){f();let A=!n.isOdd(S);return pe(cf(A),x)}else return pe(Uint8Array.of(4),x,n.toBytes(S))}function d(k){H(k,void 0,"Point");let{publicKey:y,publicKeyUncompressed:w}=l,_=k.length,S=k[0],x=k.subarray(1);if(u&&_===1&&S===0)return{x:n.ZERO,y:n.ZERO};if(_===y&&(S===2||S===3)){let A=n.fromBytes(x);if(!n.isValid(A))throw new Error("bad point: is not on curve, wrong x");let L=h(A),C;try{C=n.sqrt(L)}catch(z){let W=z instanceof Error?": "+z.message:"";throw new Error("bad point: is not on curve, sqrt error"+W)}f();let R=n.isOdd(C);return(S&1)===1!==R&&(C=n.neg(C)),{x:A,y:C}}else if(_===w&&S===4){let A=n.BYTES,L=n.fromBytes(x.subarray(0,A)),C=n.fromBytes(x.subarray(A,A*2));if(!g(L,C))throw new Error("bad point: is not on curve");return{x:L,y:C}}else throw new Error(`bad point: got length ${_}, expected compressed=${y} or uncompressed=${w}`)}let p=e.toBytes===void 0?m:e.toBytes,b=e.fromBytes===void 0?d:e.fromBytes;function h(k){let y=n.sqr(k),w=n.mul(y,k);return n.add(n.add(w,n.mul(k,o.a)),o.b)}function g(k,y){let w=n.sqr(y),_=h(k);return n.eql(w,_)}if(!g(o.Gx,o.Gy))throw new Error("bad curve params: generator point");let E=n.mul(n.pow(o.a,Bo),s0),v=n.mul(n.sqr(o.b),BigInt(27));if(n.is0(n.add(E,v)))throw new Error("bad curve params: a or b");function I(k,y,w=!1){if(!n.isValid(y)||w&&n.is0(y))throw new Error(`bad point coordinate ${k}`);return y}function D(k){if(!(k instanceof T))throw new Error("Weierstrass Point expected")}function P(k){if(!c||!c.basises)throw new Error("no endo");return o0(k,c.basises,s.ORDER)}function B(k,y,w,_,S){return w=new T(n.mul(w.X,k),w.Y,w.Z),y=bn(_,y),w=bn(S,w),y.add(w)}class T{static BASE=new T(o.Gx,o.Gy,n.ONE);static ZERO=new T(n.ZERO,n.ONE,n.ZERO);static Fp=n;static Fn=s;X;Y;Z;constructor(y,w,_){this.X=I("x",y),this.Y=I("y",w,!0),this.Z=I("z",_),Object.freeze(this)}static CURVE(){return o}static fromAffine(y){let{x:w,y:_}=y||{};if(!y||!n.isValid(w)||!n.isValid(_))throw new Error("invalid affine point");if(y instanceof T)throw new Error("projective point not allowed");return n.is0(w)&&n.is0(_)?T.ZERO:new T(w,_,n.ONE)}static fromBytes(y){let w=T.fromAffine(b(H(y,void 0,"point")));return w.assertValidity(),w}static fromHex(y){return T.fromBytes(Tr(y))}get x(){return this.toAffine().x}get y(){return this.toAffine().y}precompute(y=8,w=!0){return Z.createCache(this,y),w||this.multiply(Bo),this}assertValidity(){let y=this;if(y.is0()){if(e.allowInfinityPoint&&n.is0(y.X)&&n.eql(y.Y,n.ONE)&&n.is0(y.Z))return;throw new Error("bad point: ZERO")}let{x:w,y:_}=y.toAffine();if(!n.isValid(w)||!n.isValid(_))throw new Error("bad point: x or y not field elements");if(!g(w,_))throw new Error("bad point: equation left != right");if(!y.isTorsionFree())throw new Error("bad point: not in prime-order subgroup")}hasEvenY(){let{y}=this.toAffine();if(!n.isOdd)throw new Error("Field doesn't support isOdd");return!n.isOdd(y)}equals(y){D(y);let{X:w,Y:_,Z:S}=this,{X:x,Y:A,Z:L}=y,C=n.eql(n.mul(w,L),n.mul(x,S)),R=n.eql(n.mul(_,L),n.mul(A,S));return C&&R}negate(){return new T(this.X,n.neg(this.Y),this.Z)}double(){let{a:y,b:w}=o,_=n.mul(w,Bo),{X:S,Y:x,Z:A}=this,L=n.ZERO,C=n.ZERO,R=n.ZERO,N=n.mul(S,S),z=n.mul(x,x),W=n.mul(A,A),K=n.mul(S,x);return K=n.add(K,K),R=n.mul(S,A),R=n.add(R,R),L=n.mul(y,R),C=n.mul(_,W),C=n.add(L,C),L=n.sub(z,C),C=n.add(z,C),C=n.mul(L,C),L=n.mul(K,L),R=n.mul(_,R),W=n.mul(y,W),K=n.sub(N,W),K=n.mul(y,K),K=n.add(K,R),R=n.add(N,N),N=n.add(R,N),N=n.add(N,W),N=n.mul(N,K),C=n.add(C,N),W=n.mul(x,A),W=n.add(W,W),N=n.mul(W,K),L=n.sub(L,N),R=n.mul(W,z),R=n.add(R,R),R=n.add(R,R),new T(L,C,R)}add(y){D(y);let{X:w,Y:_,Z:S}=this,{X:x,Y:A,Z:L}=y,C=n.ZERO,R=n.ZERO,N=n.ZERO,z=o.a,W=n.mul(o.b,Bo),K=n.mul(w,x),de=n.mul(_,A),me=n.mul(S,L),ye=n.add(w,_),ue=n.add(x,A);ye=n.mul(ye,ue),ue=n.add(K,de),ye=n.sub(ye,ue),ue=n.add(w,S);let De=n.add(x,L);return ue=n.mul(ue,De),De=n.add(K,me),ue=n.sub(ue,De),De=n.add(_,S),C=n.add(A,L),De=n.mul(De,C),C=n.add(de,me),De=n.sub(De,C),N=n.mul(z,ue),C=n.mul(W,me),N=n.add(C,N),C=n.sub(de,N),N=n.add(de,N),R=n.mul(C,N),de=n.add(K,K),de=n.add(de,K),me=n.mul(z,me),ue=n.mul(W,ue),de=n.add(de,me),me=n.sub(K,me),me=n.mul(z,me),ue=n.add(ue,me),K=n.mul(de,ue),R=n.add(R,K),K=n.mul(De,ue),C=n.mul(ye,C),C=n.sub(C,K),K=n.mul(ye,de),N=n.mul(De,N),N=n.add(N,K),new T(C,R,N)}subtract(y){return D(y),this.add(y.negate())}is0(){return this.equals(T.ZERO)}multiply(y){let{endo:w}=e;if(!s.isValidNot0(y))throw new RangeError("invalid scalar: out of range");let _,S,x=A=>Z.cached(this,A,L=>Xt(T,L));if(w){let{k1neg:A,k1:L,k2neg:C,k2:R}=P(y),{p:N,f:z}=x(L),{p:W,f:K}=x(R);S=z.add(K),_=B(w.beta,N,W,A,C)}else{let{p:A,f:L}=x(y);_=A,S=L}return Xt(T,[_,S])[0]}multiplyUnsafe(y){let{endo:w}=e,_=this,S=y;if(!s.isValid(S))throw new RangeError("invalid scalar: out of range");if(S===nt||_.is0())return T.ZERO;if(S===Pt)return _;if(Z.hasCache(this))return this.multiply(S);if(w){let{k1neg:x,k1:A,k2neg:L,k2:C}=P(S),{p1:R,p2:N}=nl(T,_,A,C);return B(w.beta,R,N,x,L)}else return Z.unsafe(_,S)}toAffine(y){let w=this,_=y,{X:S,Y:x,Z:A}=w;if(n.eql(A,n.ONE))return{x:S,y:x};let L=w.is0();_==null&&(_=L?n.ONE:n.inv(A));let C=n.mul(S,_),R=n.mul(x,_),N=n.mul(A,_);if(L)return{x:n.ZERO,y:n.ZERO};if(!n.eql(N,n.ONE))throw new Error("invZ was invalid");return{x:C,y:R}}isTorsionFree(){let{isTorsionFree:y}=e;return i===Pt?!0:y?y(T,this):Z.unsafe(this,a).is0()}clearCofactor(){let{clearCofactor:y}=e;return i===Pt?this:y?y(T,this):this.multiplyUnsafe(i)}isSmallOrder(){return i===Pt?this.is0():this.clearCofactor().is0()}toBytes(y=!0){return Ve(y,"isCompressed"),this.assertValidity(),p(T,this,y)}toHex(y=!0){return Ar(this.toBytes(y))}toString(){return`<Point ${this.is0()?"ZERO":this.toHex()}>`}}let U=s.BITS,Z=new Br(T,e.endo?Math.ceil(U/2):U);return U>=8&&T.BASE.precompute(8),Object.freeze(T.prototype),Object.freeze(T),T}function cf(r){return Uint8Array.of(r?2:3)}function uf(r,e){return{secretKey:e.BYTES,publicKey:1+r.BYTES,publicKeyUncompressed:1+2*r.BYTES,publicKeyHasPrefix:!0,signature:2*e.BYTES}}function i0(r,e={}){let{Fn:t}=r,n=e.randomBytes===void 0?hn:e.randomBytes,s=Object.assign(uf(r.Fp,t),{seed:Math.max(gi(t.ORDER),16)});function o(d){try{let p=t.fromBytes(d);return t.isValidNot0(p)}catch{return!1}}function i(d,p){let{publicKey:b,publicKeyUncompressed:h}=s;try{let g=d.length;return p===!0&&g!==b||p===!1&&g!==h?!1:!!r.fromBytes(d)}catch{return!1}}function a(d){return d=d===void 0?n(s.seed):d,bi(H(d,s.seed,"seed"),t.ORDER)}function c(d,p=!0){return r.BASE.multiply(t.fromBytes(d)).toBytes(p)}function u(d){let{secretKey:p,publicKey:b,publicKeyUncompressed:h}=s,g=t._lengths;if(!Wt(d))return;let E=H(d,void 0,"key").length,v=E===b||E===h,I=E===p||!!g?.includes(E);if(!(v&&I))return v}function l(d,p,b=!0){if(u(d)===!0)throw new Error("first arg must be private key");if(u(p)===!1)throw new Error("second arg must be public key");let h=t.fromBytes(d);return r.fromBytes(p).multiply(h).toBytes(b)}let f={isValidSecretKey:o,isValidPublicKey:i,randomSecretKey:a},m=bo(a,c);return Object.freeze(f),Object.freeze(s),Object.freeze({getPublicKey:c,getSharedSecret:l,keygen:m,Point:r,utils:f,lengths:s})}function lf(r,e,t={}){let n=e;oo(n),$e(t,{},{hmac:"function",lowS:"boolean",randomBytes:"function",bits2int:"function",bits2int_modN:"function"}),t=Object.assign({},t);let s=t.randomBytes===void 0?hn:t.randomBytes,o=t.hmac===void 0?(S,x)=>nf(n,S,x):t.hmac,{Fp:i,Fn:a}=r,{ORDER:c,BITS:u}=a,{keygen:l,getPublicKey:f,getSharedSecret:m,utils:d,lengths:p}=i0(r,t),b={prehash:!0,lowS:typeof t.lowS=="boolean"?t.lowS:!0,format:"compact",extraEntropy:!1},h=c*sf+Pt<i.ORDER;function g(S){let x=c>>Pt;return S>x}function E(S,x){if(!a.isValidNot0(x))throw new Error(`invalid signature ${S}: out of range 1..Point.Fn.ORDER`);return x}function v(){if(h)throw new Error('"recovered" sig type is not supported for cofactor >2 curves')}function I(S,x){Ca(x);let A=p.signature,L=x==="compact"?A:x==="recovered"?A+1:void 0;return H(S,L)}class D{r;s;recovery;constructor(x,A,L){if(this.r=E("r",x),this.s=E("s",A),L!=null){if(v(),![0,1,2,3].includes(L))throw new Error("invalid recovery id");this.recovery=L}Object.freeze(this)}static fromBytes(x,A=b.format){I(x,A);let L;if(A==="der"){let{r:z,s:W}=We.toSig(H(x));return new D(z,W)}A==="recovered"&&(L=x[0],A="compact",x=x.subarray(1));let C=p.signature/2,R=x.subarray(0,C),N=x.subarray(C,C*2);return new D(a.fromBytes(R),a.fromBytes(N),L)}static fromHex(x,A){return this.fromBytes(Tr(x),A)}assertRecovery(){let{recovery:x}=this;if(x==null)throw new Error("invalid recovery id: must be present");return x}addRecoveryBit(x){return new D(this.r,this.s,x)}recoverPublicKey(x){let{r:A,s:L}=this,C=this.assertRecovery(),R=C===2||C===3?A+c:A;if(!i.isValid(R))throw new Error("invalid recovery id: sig.r+curve.n != R.x");let N=i.toBytes(R),z=r.fromBytes(pe(cf((C&1)===0),N)),W=a.inv(R),K=B(H(x,void 0,"msgHash")),de=a.create(-K*W),me=a.create(L*W),ye=r.BASE.multiplyUnsafe(de).add(z.multiplyUnsafe(me));if(ye.is0())throw new Error("invalid recovery: point at infinify");return ye.assertValidity(),ye}hasHighS(){return g(this.s)}toBytes(x=b.format){if(Ca(x),x==="der")return Tr(We.hexFromSig(this));let{r:A,s:L}=this,C=a.toBytes(A),R=a.toBytes(L);return x==="recovered"?(v(),pe(Uint8Array.of(this.assertRecovery()),C,R)):pe(C,R)}toHex(x){return Ar(this.toBytes(x))}}Object.freeze(D.prototype),Object.freeze(D);let P=t.bits2int===void 0?function(x){if(x.length>8192)throw new Error("input is too large");let A=Gt(x),L=x.length*8-u;return L>0?A>>BigInt(L):A}:t.bits2int,B=t.bits2int_modN===void 0?function(x){return a.create(P(x))}:t.bits2int_modN,T=yn(u);function U(S){return Dr("num < 2^"+u,S,nt,T),a.toBytes(S)}function Z(S,x){return H(S,void 0,"message"),x?H(n(S),void 0,"prehashed message"):S}function k(S,x,A){let{lowS:L,prehash:C,extraEntropy:R}=Ia(A,b);S=Z(S,C);let N=B(S),z=a.fromBytes(x);if(!a.isValidNot0(z))throw new Error("invalid private key");let W=[U(z),U(N)];if(R!=null&&R!==!1){let ye=R===!0?s(p.secretKey):R;W.push(H(ye,void 0,"extraEntropy"))}let K=pe(...W),de=N;function me(ye){let ue=P(ye);if(!a.isValidNot0(ue))return;let De=a.inv(ue),hr=r.BASE.multiply(ue).toAffine(),Qr=a.create(hr.x);if(Qr===nt)return;let $n=a.create(De*a.create(de+Qr*z));if($n===nt)return;let Kc=(hr.x===Qr?0:2)|Number(hr.y&Pt),qc=$n;return L&&g($n)&&(qc=a.neg($n),Kc^=1),new D(Qr,qc,h?void 0:Kc)}return{seed:K,k2sig:me}}function y(S,x,A={}){let{seed:L,k2sig:C}=k(S,x,A);return Ku(n.outputLen,a.BYTES,o)(L,C).toBytes(A.format)}function w(S,x,A,L={}){let{lowS:C,prehash:R,format:N}=Ia(L,b);if(A=H(A,void 0,"publicKey"),x=Z(x,R),!Wt(S)){let z=S instanceof D?", use sig.toBytes()":"";throw new Error("verify expects Uint8Array signature"+z)}I(S,N);try{let z=D.fromBytes(S,N),W=r.fromBytes(A);if(C&&z.hasHighS())return!1;let{r:K,s:de}=z,me=B(x),ye=a.inv(de),ue=a.create(me*ye),De=a.create(K*ye),hr=r.BASE.multiplyUnsafe(ue).add(W.multiplyUnsafe(De));return hr.is0()?!1:a.create(hr.x)===K}catch{return!1}}function _(S,x,A={}){let{prehash:L}=Ia(A,b);return x=Z(x,L),D.fromBytes(S,"recovered").recoverPublicKey(x).toBytes()}return Object.freeze({keygen:l,getPublicKey:f,getSharedSecret:m,utils:d,lengths:p,Point:r,sign:y,verify:w,recoverPublicKey:_,Signature:D,hash:n})}var Ra={p:BigInt("0xfffffffffffffffffffffffffffffffffffffffffffffffffffffffefffffc2f"),n:BigInt("0xfffffffffffffffffffffffffffffffebaaedce6af48a03bbfd25e8cd0364141"),h:BigInt(1),a:BigInt(0),b:BigInt(7),Gx:BigInt("0x79be667ef9dcbbac55a06295ce870b07029bfcdb2dce28d959f2815b16f81798"),Gy:BigInt("0x483ada7726a3c4655da4fbfc0e1108a8fd17b448a68554199c47d08ffb10d4b8")},a0={beta:BigInt("0x7ae96a2b657c07106e64479eac3434e99cf0497512f58995c1396c28719501ee"),basises:[[BigInt("0x3086d221a7d46bcde86c90e49284eb15"),-BigInt("0xe4437ed6010e88286f547fa90abfe4c3")],[BigInt("0x114ca50f7a8e2f3f657c1108d9d44cfd8"),BigInt("0x3086d221a7d46bcde86c90e49284eb15")]]};var ff=BigInt(2);function c0(r){let e=Ra.p,t=BigInt(3),n=BigInt(6),s=BigInt(11),o=BigInt(22),i=BigInt(23),a=BigInt(44),c=BigInt(88),u=r*r*r%e,l=u*u*r%e,f=te(l,t,e)*l%e,m=te(f,t,e)*l%e,d=te(m,ff,e)*u%e,p=te(d,s,e)*d%e,b=te(p,o,e)*p%e,h=te(b,a,e)*b%e,g=te(h,c,e)*h%e,E=te(g,a,e)*b%e,v=te(E,t,e)*l%e,I=te(v,i,e)*p%e,D=te(I,n,e)*u%e,P=te(D,ff,e);if(!Ba.eql(Ba.sqr(P),r))throw new Error("Cannot find square root");return P}var Ba=Cr(Ra.p,{sqrt:c0}),u0=af(Ra,{Fp:Ba,endo:a0}),qr=lf(u0,_r);function df(r,e,t,n){let s=Er.digest(t instanceof Uint8Array?t:t.subarray());if(So(s))return s.then(({digest:o})=>(n?.signal?.throwIfAborted(),qr.verify(e,o,r,{prehash:!1,format:"der"}))).catch(o=>{throw o.name==="AbortError"?o:new xn(String(o))});try{return n?.signal?.throwIfAborted(),qr.verify(e,s.digest,r,{prehash:!1,format:"der"})}catch(o){throw new xn(String(o))}}var Ro=class{type="secp256k1";raw;_key;constructor(e){this._key=pf(e),this.raw=hf(this._key)}toMultihash(){return qe.digest(Qe(this))}toCID(){return fe.createV1(114,this.toMultihash())}toString(){return re.encode(this.toMultihash().bytes).substring(1)}equals(e){return e==null||!(e.raw instanceof Uint8Array)?!1:he(this.raw,e.raw)}verify(e,t,n){return df(this._key,t,e,n)}};function Oa(r){return new Ro(r)}function hf(r){return qr.Point.fromBytes(r).toBytes()}function pf(r){try{return qr.Point.fromBytes(r),r}catch(e){throw new pr(String(e))}}function mf(r,e){let{Type:t,Data:n}=rt.decode(r),s=n??new Uint8Array;switch(t){case ne.RSA:return Aa(s,e);case ne.Ed25519:return Ri(s);case ne.secp256k1:return Oa(s);case ne.ECDSA:return ei(s);default:throw new mr}}function yf(r){let{Type:e,Data:t}=rt.decode(r.digest),n=t??new Uint8Array;switch(e){case ne.Ed25519:return Ri(n);case ne.secp256k1:return Oa(n);case ne.ECDSA:return ei(n);default:throw new mr}}function Qe(r){return rt.encode({Type:ne[r.type],Data:r.raw})}var gf=Symbol.for("nodejs.util.inspect.custom"),l0=114,Bn=class{type;multihash;publicKey;string;constructor(e){this.type=e.type,this.multihash=e.multihash,Object.defineProperty(this,"string",{enumerable:!1,writable:!0})}get[Symbol.toStringTag](){return`PeerId(${this.toString()})`}[As]=!0;toString(){return this.string==null&&(this.string=re.encode(this.multihash.bytes).slice(1)),this.string}toMultihash(){return this.multihash}toCID(){return fe.createV1(l0,this.multihash)}toJSON(){return this.toString()}equals(e){if(e==null)return!1;if(e instanceof Uint8Array)return he(this.multihash.bytes,e);if(typeof e=="string")return this.toString()===e;if(e?.toMultihash()?.bytes!=null)return he(this.multihash.bytes,e.toMultihash().bytes);throw new Error("not valid Id")}[gf](){return`PeerId(${this.toString()})`}},Oo=class extends Bn{type="RSA";publicKey;constructor(e){super({...e,type:"RSA"}),this.publicKey=e.publicKey}},Po=class extends Bn{type="Ed25519";publicKey;constructor(e){super({...e,type:"Ed25519"}),this.publicKey=e.publicKey}},No=class extends Bn{type="secp256k1";publicKey;constructor(e){super({...e,type:"secp256k1"}),this.publicKey=e.publicKey}},f0=2336,Rn=class{type="url";multihash;publicKey;url;constructor(e){this.url=e.toString(),this.multihash=qe.digest(M(this.url))}[gf](){return`PeerId(${this.url})`}[As]=!0;toString(){return this.toCID().toString()}toMultihash(){return this.multihash}toCID(){return fe.createV1(f0,this.toMultihash())}toJSON(){return this.toString()}equals(e){return e==null?!1:(e instanceof Uint8Array&&(e=V(e)),e.toString()===this.toString())}};var d0=114,bf=2336;function Pa(r,e){let t;if(r.charAt(0)==="1"||r.charAt(0)==="Q")t=Xe(re.decode(`z${r}`));else{if(r.startsWith("k51qzi5uqu5")||r.startsWith("kzwfwjn5ji4")||r.startsWith("k2k4r8")||r.startsWith("bafz"))return h0(fe.parse(r));if(e==null)throw new se('Please pass a multibase decoder for strings that do not start with "1" or "Q"');t=Xe(e.decode(r))}return zr(t)}function zr(r){if(m0(r))return new Oo({multihash:r});if(p0(r))try{let e=yf(r);if(e.type==="Ed25519")return new Po({multihash:r,publicKey:e});if(e.type==="secp256k1")return new No({multihash:r,publicKey:e})}catch{let t=V(r.digest);return new Rn(new URL(t))}throw new Gn("Supplied PeerID Multihash is invalid")}function h0(r){if(r?.multihash==null||r.version==null||r.version===1&&r.code!==d0&&r.code!==bf)throw new Wn("Supplied PeerID CID is invalid");if(r.code===bf){let e=V(r.multihash.digest);return new Rn(new URL(e))}return zr(r.multihash)}function p0(r){return r.code===qe.code}function m0(r){return r.code===Er.code}var On;(function(r){let e;r.codec=()=>(e==null&&(e=Oe((o,i,a={})=>{a.lengthDelimited!==!1&&i.fork(),o.publicKey!=null&&o.publicKey.byteLength>0&&(i.uint32(10),i.bytes(o.publicKey)),o.payloadType!=null&&o.payloadType.byteLength>0&&(i.uint32(18),i.bytes(o.payloadType)),o.payload!=null&&o.payload.byteLength>0&&(i.uint32(26),i.bytes(o.payload)),o.signature!=null&&o.signature.byteLength>0&&(i.uint32(42),i.bytes(o.signature)),a.lengthDelimited!==!1&&i.ldelim()},(o,i,a={})=>{let c={publicKey:Te(0),payloadType:Te(0),payload:Te(0),signature:Te(0)},u=i==null?o.len:o.pos+i;for(;o.pos<u;){let l=o.uint32();switch(l>>>3){case 1:{c.publicKey=o.bytes();break}case 2:{c.payloadType=o.bytes();break}case 3:{c.payload=o.bytes();break}case 5:{c.signature=o.bytes();break}default:{o.skipType(l&7);break}}}return c},function*(o,i,a,c={}){let u=i==null?o.len:o.pos+i;for(;o.pos<u;){let l=o.uint32();switch(l>>>3){case 1:{yield{field:`${a}.publicKey`,value:o.bytes()};break}case 2:{yield{field:`${a}.payloadType`,value:o.bytes()};break}case 3:{yield{field:`${a}.payload`,value:o.bytes()};break}case 5:{yield{field:`${a}.signature`,value:o.bytes()};break}default:{o.skipType(l&7);break}}}})),e);function t(o){return Be(o,r.codec())}r.encode=t;function n(o,i){return Le(o,r.codec(),i)}r.decode=n;function s(o,i){return Re(o,r.codec(),i)}r.stream=s})(On||(On={}));var Uo=class extends Error{constructor(e="Invalid signature"){super(e),this.name="InvalidSignatureError"}};var Pn=class r{static createFromProtobuf=e=>{let t=On.decode(e),n=mf(t.publicKey);return new r({publicKey:n,payloadType:t.payloadType,payload:t.payload,signature:t.signature})};static seal=async(e,t,n)=>{if(t==null)throw new Error("Missing private key");let s=e.domain,o=e.codec,i=e.marshal(),a=wf(s,o,i),c=await t.sign(a.subarray(),n);return new r({publicKey:t.publicKey,payloadType:o,payload:i,signature:c})};static openAndCertify=async(e,t,n)=>{let s=r.createFromProtobuf(e);if(!await s.validate(t,n))throw new Uo("Envelope signature is not valid for the given domain");return s};publicKey;payloadType;payload;signature;marshaled;constructor(e){let{publicKey:t,payloadType:n,payload:s,signature:o}=e;this.publicKey=t,this.payloadType=n,this.payload=s,this.signature=o}marshal(){return this.marshaled==null&&(this.marshaled=On.encode({publicKey:Qe(this.publicKey),payloadType:this.payloadType,payload:this.payload.subarray(),signature:this.signature})),this.marshaled}equals(e){return e==null?!1:he(this.marshal(),e.marshal())}async validate(e,t){let n=wf(e,this.payloadType,this.payload);return this.publicKey.verify(n.subarray(),this.signature,t)}},wf=(r,e,t)=>{let n=M(r),s=Or(n.byteLength),o=Or(e.length),i=Or(t.length);return new ee(s,n,o,e,i,t)};var y0=Math.pow(2,7),g0=Math.pow(2,14),b0=Math.pow(2,21),Na=Math.pow(2,28),Ua=Math.pow(2,35),ka=Math.pow(2,42),Fa=Math.pow(2,49),oe=128,_e=127;function Vr(r){if(r<y0)return 1;if(r<g0)return 2;if(r<b0)return 3;if(r<Na)return 4;if(r<Ua)return 5;if(r<ka)return 6;if(r<Fa)return 7;if(Number.MAX_SAFE_INTEGER!=null&&r>Number.MAX_SAFE_INTEGER)throw new RangeError("Could not encode varint");return 8}function Ma(r,e,t=0){switch(Vr(r)){case 8:e[t++]=r&255|oe,r/=128;case 7:e[t++]=r&255|oe,r/=128;case 6:e[t++]=r&255|oe,r/=128;case 5:e[t++]=r&255|oe,r/=128;case 4:e[t++]=r&255|oe,r>>>=7;case 3:e[t++]=r&255|oe,r>>>=7;case 2:e[t++]=r&255|oe,r>>>=7;case 1:{e[t++]=r&255,r>>>=7;break}default:throw new Error("unreachable")}return e}function w0(r,e){let t=r[e],n=0;if(n+=t&_e,t<oe||(t=r[e+1],n+=(t&_e)<<7,t<oe)||(t=r[e+2],n+=(t&_e)<<14,t<oe)||(t=r[e+3],n+=(t&_e)<<21,t<oe)||(t=r[e+4],n+=(t&_e)*Na,t<oe)||(t=r[e+5],n+=(t&_e)*Ua,t<oe)||(t=r[e+6],n+=(t&_e)*ka,t<oe)||(t=r[e+7],n+=(t&_e)*Fa,t<oe))return n;throw new RangeError("Could not decode varint")}function x0(r,e){let t=r.get(e),n=0;if(n+=t&_e,t<oe||(t=r.get(e+1),n+=(t&_e)<<7,t<oe)||(t=r.get(e+2),n+=(t&_e)<<14,t<oe)||(t=r.get(e+3),n+=(t&_e)<<21,t<oe)||(t=r.get(e+4),n+=(t&_e)*Na,t<oe)||(t=r.get(e+5),n+=(t&_e)*Ua,t<oe)||(t=r.get(e+6),n+=(t&_e)*ka,t<oe)||(t=r.get(e+7),n+=(t&_e)*Fa,t<oe))return n;throw new RangeError("Could not decode varint")}function Ka(r,e=0){return r instanceof Uint8Array?w0(r,e):x0(r,e)}var Ee=class extends Error{static name="InvalidMultiaddrError";name="InvalidMultiaddrError"},gt=class extends Error{static name="ValidationError";name="ValidationError"},ko=class extends Error{static name="InvalidParametersError";name="InvalidParametersError"},Fo=class extends Error{static name="UnknownProtocolError";name="UnknownProtocolError"};var Mo=class{index=0;input="";new(e){return this.index=0,this.input=e,this}readAtomically(e){let t=this.index,n=e();return n===void 0&&(this.index=t),n}parseWith(e){let t=e();if(this.index===this.input.length)return t}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(e){return this.readAtomically(()=>{let t=this.readChar();if(t===e)return t})}readSeparator(e,t,n){return this.readAtomically(()=>{if(!(t>0&&this.readGivenChar(e)===void 0))return n()})}readNumber(e,t,n,s){return this.readAtomically(()=>{let o=0,i=0,a=this.peekChar();if(a===void 0)return;let c=a==="0",u=2**(8*s)-1;for(;;){let l=this.readAtomically(()=>{let f=this.readChar();if(f===void 0)return;let m=Number.parseInt(f,e);if(!Number.isNaN(m))return m});if(l===void 0)break;if(o*=e,o+=l,o>u||(i+=1,t!==void 0&&i>t))return}if(i!==0)return!n&&c&&i>1?void 0:o})}readIPv4Addr(){return this.readAtomically(()=>{let e=new Uint8Array(4);for(let t=0;t<e.length;t++){let n=this.readSeparator(".",t,()=>this.readNumber(10,3,!1,1));if(n===void 0)return;e[t]=n}return e})}readIPv6Addr(){let e=t=>{for(let n=0;n<t.length/2;n++){let s=n*2;if(n<t.length-3){let i=this.readSeparator(":",n,()=>this.readIPv4Addr());if(i!==void 0)return t[s]=i[0],t[s+1]=i[1],t[s+2]=i[2],t[s+3]=i[3],[s+4,!0]}let o=this.readSeparator(":",n,()=>this.readNumber(16,4,!0,2));if(o===void 0)return[s,!1];t[s]=o>>8,t[s+1]=o&255}return[t.length,!1]};return this.readAtomically(()=>{let t=new Uint8Array(16),[n,s]=e(t);if(n===16)return t;if(s||this.readGivenChar(":")===void 0||this.readGivenChar(":")===void 0)return;let o=new Uint8Array(14),i=16-(n+2),[a]=e(o.subarray(0,i));return t.set(o.subarray(0,a),16-a),t})}readIPAddr(){return this.readIPv4Addr()??this.readIPv6Addr()}};var S0=45,v0=15,Ko=new Mo;function xf(r){if(!(r.length>v0))return Ko.new(r).parseWith(()=>Ko.readIPv4Addr())}function Ef(r){if(r.includes("%")&&(r=r.split("%")[0]),!(r.length>S0))return Ko.new(r).parseWith(()=>Ko.readIPv6Addr())}function qo(r){return!!xf(r)}function Sf(r){return!!Ef(r)}function za(r){return e=>V(e,r)}function Va(r){return e=>M(e,r)}function Hr(r){return new DataView(r.buffer).getUint16(r.byteOffset).toString()}function or(r){let e=new ArrayBuffer(2);return new DataView(e).setUint16(0,typeof r=="string"?parseInt(r):r),new Uint8Array(e)}function vf(r){let e=r.split(":");if(e.length!==2)throw new Error(`failed to parse onion addr: ["'${e.join('", "')}'"]' does not contain a port number`);if(e[0].length!==16)throw new Error(`failed to parse onion addr: ${e[0]} not a Tor onion address.`);let t=M(e[0],"base32"),n=parseInt(e[1],10);if(n<1||n>65536)throw new Error("Port number is not in range(1, 65536)");let s=or(n);return Qt([t,s],t.length+s.length)}function _f(r){let e=r.split(":");if(e.length!==2)throw new Error(`failed to parse onion addr: ["'${e.join('", "')}'"]' does not contain a port number`);if(e[0].length!==56)throw new Error(`failed to parse onion addr: ${e[0]} not a Tor onion3 address.`);let t=St.decode(`b${e[0]}`),n=parseInt(e[1],10);if(n<1||n>65536)throw new Error("Port number is not in range(1, 65536)");let s=or(n);return Qt([t,s],t.length+s.length)}function Ha(r){let e=r.subarray(0,r.length-2),t=r.subarray(r.length-2),n=V(e,"base32"),s=Hr(t);return`${n}:${s}`}var $a=function(r){r=r.toString().trim();let e=new Uint8Array(4);return r.split(/\./g).forEach((t,n)=>{let s=parseInt(t,10);if(isNaN(s)||s<0||s>255)throw new Ee("Invalid byte value in IP address");e[n]=s}),e},Af=function(r){let e=0;r=r.toString().trim();let t=r.split(":",8),n;for(n=0;n<t.length;n++){let o=qo(t[n]),i;o&&(i=$a(t[n]),t[n]=V(i.subarray(0,2),"base16")),i!=null&&++n<8&&t.splice(n,0,V(i.subarray(2,4),"base16"))}if(t[0]==="")for(;t.length<8;)t.unshift("0");else if(t[t.length-1]==="")for(;t.length<8;)t.push("0");else if(t.length<8){for(n=0;n<t.length&&t[n]!=="";n++);let o=[n,1];for(n=9-t.length;n>0;n--)o.push("0");t.splice.apply(t,o)}let s=new Uint8Array(e+16);for(n=0;n<t.length;n++){t[n]===""&&(t[n]="0");let o=parseInt(t[n],16);if(isNaN(o)||o<0||o>65535)throw new Ee("Invalid byte value in IP address");s[e++]=o>>8&255,s[e++]=o&255}return s},Tf=function(r){if(r.byteLength!==4)throw new Ee("IPv4 address was incorrect length");let e=[];for(let t=0;t<r.byteLength;t++)e.push(r[t]);return e.join(".")},Df=function(r){if(r.byteLength!==16)throw new Ee("IPv6 address was incorrect length");let e=[];for(let n=0;n<r.byteLength;n+=2){let s=r[n],o=r[n+1],i=`${s.toString(16).padStart(2,"0")}${o.toString(16).padStart(2,"0")}`;e.push(i)}let t=e.join(":");try{let n=new URL(`http://[${t}]`);return n.hostname.substring(1,n.hostname.length-1)}catch{throw new Ee(`Invalid IPv6 address "${t}"`)}};function If(r){try{let e=new URL(`http://[${r}]`);return e.hostname.substring(1,e.hostname.length-1)}catch{throw new Ee(`Invalid IPv6 address "${r}"`)}}var qa=Object.values(sn).map(r=>r.decoder),_0=(function(){let r=qa[0].or(qa[1]);return qa.slice(2).forEach(e=>r=r.or(e)),r})();function Cf(r){return _0.decode(r)}function Lf(r){return e=>r.encoder.encode(e)}function A0(r){if(parseInt(r).toString()!==r)throw new gt("Value must be an integer")}function T0(r){if(r<0)throw new gt("Value must be a positive integer, or zero")}function D0(r){return e=>{if(e>r)throw new gt(`Value must be smaller than or equal to ${r}`)}}function I0(...r){return e=>{for(let t of r)t(e)}}var Nn=I0(A0,T0,D0(65535));var be=-1,ja=class{protocolsByCode=new Map;protocolsByName=new Map;getProtocol(e){let t;if(typeof e=="string"?t=this.protocolsByName.get(e):t=this.protocolsByCode.get(e),t==null)throw new Fo(`Protocol ${e} was unknown`);return t}addProtocol(e){this.protocolsByCode.set(e.code,e),this.protocolsByName.set(e.name,e),e.aliases?.forEach(t=>{this.protocolsByName.set(t,e)})}removeProtocol(e){let t=this.protocolsByCode.get(e);t!=null&&(this.protocolsByCode.delete(t.code),this.protocolsByName.delete(t.name),t.aliases?.forEach(n=>{this.protocolsByName.delete(n)}))}},wt=new ja,z0=[{code:4,name:"ip4",size:32,valueToBytes:$a,bytesToValue:Tf,validate:r=>{if(!qo(r))throw new gt(`Invalid IPv4 address "${r}"`)}},{code:6,name:"tcp",size:16,valueToBytes:or,bytesToValue:Hr,validate:Nn},{code:273,name:"udp",size:16,valueToBytes:or,bytesToValue:Hr,validate:Nn},{code:33,name:"dccp",size:16,valueToBytes:or,bytesToValue:Hr,validate:Nn},{code:41,name:"ip6",size:128,valueToBytes:Af,bytesToValue:Df,stringToValue:If,validate:r=>{if(!Sf(r))throw new gt(`Invalid IPv6 address "${r}"`)}},{code:42,name:"ip6zone",size:be},{code:43,name:"ipcidr",size:8,bytesToValue:za("base10"),valueToBytes:Va("base10")},{code:53,name:"dns",size:be},{code:54,name:"dns4",size:be},{code:55,name:"dns6",size:be},{code:56,name:"dnsaddr",size:be},{code:132,name:"sctp",size:16,valueToBytes:or,bytesToValue:Hr,validate:Nn},{code:301,name:"udt"},{code:302,name:"utp"},{code:400,name:"unix",size:be,stringToValue:r=>decodeURIComponent(r),valueToString:r=>encodeURIComponent(r)},{code:421,name:"p2p",aliases:["ipfs"],size:be,bytesToValue:za("base58btc"),valueToBytes:r=>r.startsWith("Q")||r.startsWith("1")?Va("base58btc")(r):fe.parse(r).multihash.bytes},{code:444,name:"onion",size:96,bytesToValue:Ha,valueToBytes:vf},{code:445,name:"onion3",size:296,bytesToValue:Ha,valueToBytes:_f},{code:446,name:"garlic64",size:be},{code:447,name:"garlic32",size:be},{code:448,name:"tls"},{code:449,name:"sni",size:be},{code:454,name:"noise"},{code:460,name:"quic"},{code:461,name:"quic-v1"},{code:465,name:"webtransport"},{code:466,name:"certhash",size:be,bytesToValue:Lf(qs),valueToBytes:Cf},{code:480,name:"http"},{code:481,name:"http-path",size:be,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:be}];z0.forEach(r=>{wt.addProtocol(r)});function Bf(r){let e=[],t=0;for(;t<r.length;){let n=Ka(r,t),s=wt.getProtocol(n),o=Vr(n),i=V0(s,r,t+o),a=0;i>0&&s.size===be&&(a=Vr(i));let c=o+a+i,u={code:n,name:s.name,bytes:Pe(r.subarray(t,t+c))};if(i>0){let l=t+o+a,f=r.subarray(l,l+i);u.value=s.bytesToValue?.(f)??V(f)}e.push(u),t+=c}return e}function Rf(r){let e=0,t=[];for(let n of r){if(n.bytes==null){let s=wt.getProtocol(n.code),o=Vr(n.code),i,a=0,c=0;n.value!=null&&(i=s.valueToBytes?.(n.value)??M(n.value),a=i.byteLength,s.size===be&&(c=Vr(a)));let u=new Uint8Array(o+c+a),l=0;Ma(n.code,u,l),l+=o,i!=null&&(s.size===be&&(Ma(a,u,l),l+=c),u.set(i,l)),n.bytes=u}t.push(n.bytes),e+=n.bytes.byteLength}return Qt(t,e)}function Of(r){if(r.charAt(0)!=="/")throw new Ee('String multiaddr must start with "/"');let e=[],t="protocol",n="",s="";for(let o=1;o<r.length;o++){let i=r.charAt(o);i!=="/"&&(t==="protocol"?s+=r.charAt(o):n+=r.charAt(o));let a=o===r.length-1;if(i==="/"||a){let c=wt.getProtocol(s);if(t==="protocol"){if(c.size==null||c.size===0){e.push({code:c.code,name:c.name}),n="",s="",t="protocol";continue}else if(a)throw new Ee(`Component ${s} was missing value`);t="value"}else if(t==="value"){let u={code:c.code,name:c.name};if(c.size!=null&&c.size!==0){if(n==="")throw new Ee(`Component ${s} was missing value`);u.value=c.stringToValue?.(n)??n}e.push(u),n="",s="",t="protocol"}}}if(s!==""&&n!=="")throw new Ee("Incomplete multiaddr");return e}function Pf(r){return`/${r.flatMap(e=>{if(e.value==null)return e.name;let t=wt.getProtocol(e.code);if(t==null)throw new Ee(`Unknown protocol code ${e.code}`);return[e.name,t.valueToString?.(e.value)??e.value]}).join("/")}`}function V0(r,e,t){return r.size==null||r.size===0?0:r.size>0?r.size/8:Ka(e,t)}var H0=Symbol.for("nodejs.util.inspect.custom"),uc=Symbol.for("@multiformats/multiaddr");function $0(r){if(r==null&&(r="/"),Nf(r))return r.getComponents();if(r instanceof Uint8Array)return Bf(r);if(typeof r=="string")return r=r.replace(/\/(\/)+/,"/").replace(/(\/)+$/,""),r===""&&(r="/"),Of(r);if(Array.isArray(r))return r;throw new Ee("Must be a string, Uint8Array, Component[], or another Multiaddr")}var jo=class r{[uc]=!0;#e;#t;#r;constructor(e="/",t={}){this.#e=$0(e),t.validate!==!1&&j0(this)}get bytes(){return this.#r==null&&(this.#r=Rf(this.#e)),this.#r}toString(){return this.#t==null&&(this.#t=Pf(this.#e)),this.#t}toJSON(){return this.toString()}getComponents(){return[...this.#e.map(e=>({...e}))]}encapsulate(e){let t=new r(e);return new r([...this.#e,...t.getComponents()],{validate:!1})}decapsulate(e){let t=e.toString(),n=this.toString(),s=n.lastIndexOf(t);if(s<0)throw new ko(`Address ${this.toString()} does not contain subaddress: ${t}`);return new r(n.slice(0,s),{validate:!1})}decapsulateCode(e){let t;for(let n=this.#e.length-1;n>-1;n--)if(this.#e[n].code===e){t=n;break}return new r(this.#e.slice(0,t),{validate:!1})}equals(e){return he(this.bytes,e.bytes)}[H0](){return`Multiaddr(${this.toString()})`}};function j0(r){r.getComponents().forEach(e=>{let t=wt.getProtocol(e.code);e.value!=null&&t.validate?.(e.value)})}function Nf(r){return!!r?.[uc]}function ke(r){return new jo(r)}var lc={32:16777619n,64:1099511628211n,128:309485009821345068724781371n,256:374144419156711147060143317175368453031918731002211n,512:35835915874844867368919076489095108449946327955754392558399825615420669938882575126094039892345713852759n,1024:5016456510113118655434598811035278955030765345404790744303017523831112055108147451509157692220295382716162651878526895249385292291816524375083746691371804094271873160484737966720260389217684476157468082573n},Uf={32:2166136261n,64:14695981039346656037n,128:144066263297769815596495629667062367629n,256:100029257958052580907070968620625704837092796014241193945225284501741471925557n,512:9659303129496669498009435400716310466090418745672637896108374329434462657994582932197716438449813051892206539805784495328239340083876191928701583869517785n,1024:14197795064947621068722070641403218320880622795441933960878474914617582723252296732303717722150864096521202355549365628174669108571814760471015076148029755969804077320157692458563003215304957150157403644460363550505412711285966361610267868082893823963790439336411086884584107735010676915n},kf=new globalThis.TextEncoder;function W0(r,e){let t=lc[e],n=Uf[e];for(let s=0;s<r.length;s++)n^=BigInt(r[s]),n=BigInt.asUintN(e,n*t);return n}function G0(r,e,t){if(t.length===0)throw new Error("The `utf8Buffer` option must have a length greater than zero");let n=lc[e],s=Uf[e],o=r;for(;o.length>0;){let i=kf.encodeInto(o,t);o=o.slice(i.read);for(let a=0;a<i.written;a++)s^=BigInt(t[a]),s=BigInt.asUintN(e,s*n)}return s}function fc(r,{size:e=32,utf8Buffer:t}={}){if(!lc[e])throw new Error("The `size` option must be one of 32, 64, 128, 256, 512, or 1024");if(typeof r=="string"){if(t)return G0(r,e,t);r=kf.encode(r)}return W0(r,e)}var Un={hash:r=>Number(fc(r,{size:32})),hashV:(r,e)=>Y0(Un.hash(r,e))};function Y0(r){let e=r.toString(16);return e.length%2===1&&(e=`0${e}`),M(e,"base16")}var dc=64,Ge=class{fp;h;seed;constructor(e,t,n,s=2){if(s>dc)throw new TypeError("Invalid Fingerprint Size");let o=t.hashV(e,n),i=Te(s);for(let a=0;a<i.length;a++)i[a]=o[a];i.length===0&&(i[0]=7),this.fp=i,this.h=t,this.seed=n}hash(){return this.h.hash(this.fp,this.seed)}equals(e){return e?.fp instanceof Uint8Array?he(this.fp,e.fp):!1}};function ar(r,e){return Math.floor(Math.random()*(e-r))+r}var cr=class{contents;constructor(e){this.contents=new Array(e).fill(null)}has(e){if(!(e instanceof Ge))throw new TypeError("Invalid Fingerprint");return this.contents.some(t=>e.equals(t))}add(e){if(!(e instanceof Ge))throw new TypeError("Invalid Fingerprint");for(let t=0;t<this.contents.length;t++)if(this.contents[t]==null)return this.contents[t]=e,!0;return!0}swap(e){if(!(e instanceof Ge))throw new TypeError("Invalid Fingerprint");let t=ar(0,this.contents.length-1),n=this.contents[t];return this.contents[t]=e,n}remove(e){if(!(e instanceof Ge))throw new TypeError("Invalid Fingerprint");let t=this.contents.findIndex(n=>e.equals(n));return t>-1?(this.contents[t]=null,!0):!1}};var Z0=500,kn=class{bucketSize;filterSize;fingerprintSize;buckets;count;hash;seed;constructor(e){this.filterSize=e.filterSize,this.bucketSize=e.bucketSize??4,this.fingerprintSize=e.fingerprintSize??2,this.count=0,this.buckets=[],this.hash=e.hash??Un,this.seed=e.seed??ar(0,Math.pow(2,10))}add(e){typeof e=="string"&&(e=M(e));let t=new Ge(e,this.hash,this.seed,this.fingerprintSize),n=this.hash.hash(e,this.seed)%this.filterSize,s=(n^t.hash())%this.filterSize;if(this.buckets[n]==null&&(this.buckets[n]=new cr(this.bucketSize)),this.buckets[s]==null&&(this.buckets[s]=new cr(this.bucketSize)),this.buckets[n].add(t)||this.buckets[s].add(t))return this.count++,!0;let o=[n,s],i=o[ar(0,o.length-1)];this.buckets[i]==null&&(this.buckets[i]=new cr(this.bucketSize));for(let a=0;a<Z0;a++){let c=this.buckets[i].swap(t);if(c!=null&&(i=(i^c.hash())%this.filterSize,this.buckets[i]==null&&(this.buckets[i]=new cr(this.bucketSize)),this.buckets[i].add(c)))return this.count++,!0}return!1}has(e){typeof e=="string"&&(e=M(e));let t=new Ge(e,this.hash,this.seed,this.fingerprintSize),n=this.hash.hash(e,this.seed)%this.filterSize,s=this.buckets[n]?.has(t)??!1;if(s)return s;let o=(n^t.hash())%this.filterSize;return this.buckets[o]?.has(t)??!1}remove(e){typeof e=="string"&&(e=M(e));let t=new Ge(e,this.hash,this.seed,this.fingerprintSize),n=this.hash.hash(e,this.seed)%this.filterSize,s=this.buckets[n]?.remove(t)??!1;if(s)return this.count--,s;let o=(n^t.hash())%this.filterSize,i=this.buckets[o]?.remove(t)??!1;return i&&this.count--,i}get reliable(){return Math.floor(100*(this.count/this.filterSize))<=90}},X0={1:.5,2:.84,4:.95,8:.98};function Q0(r=.001){return r>.002?2:r>1e-5?4:8}function Ff(r,e=.001){let t=Q0(e),n=X0[t],s=Math.round(r/n),o=Math.min(Math.ceil(Math.log2(1/e)+Math.log2(2*t)),dc);return{filterSize:s,bucketSize:t,fingerprintSize:o}}var Wo=class{filterSize;bucketSize;fingerprintSize;scale;filterSeries;hash;seed;constructor(e){this.bucketSize=e.bucketSize??4,this.filterSize=e.filterSize??(1<<18)/this.bucketSize,this.fingerprintSize=e.fingerprintSize??2,this.scale=e.scale??2,this.hash=e.hash??Un,this.seed=e.seed??ar(0,Math.pow(2,10)),this.filterSeries=[new kn({filterSize:this.filterSize,bucketSize:this.bucketSize,fingerprintSize:this.fingerprintSize,hash:this.hash,seed:this.seed})]}add(e){if(typeof e=="string"&&(e=M(e)),this.has(e))return!0;let t=this.filterSeries.find(n=>n.reliable);if(t==null){let n=this.filterSize*Math.pow(this.scale,this.filterSeries.length);t=new kn({filterSize:n,bucketSize:this.bucketSize,fingerprintSize:this.fingerprintSize,hash:this.hash,seed:this.seed}),this.filterSeries.push(t)}return t.add(e)}has(e){typeof e=="string"&&(e=M(e));for(let t=0;t<this.filterSeries.length;t++)if(this.filterSeries[t].has(e))return!0;return!1}remove(e){typeof e=="string"&&(e=M(e));for(let t=0;t<this.filterSeries.length;t++)if(this.filterSeries[t].remove(e))return!0;return!1}get count(){return this.filterSeries.reduce((e,t)=>e+t.count,0)}};function Gr(r,e=.001,t){return new Wo({...Ff(r,e),...t??{}})}var X=r=>({match:e=>{let t=e[0];return t==null||t.code!==r||t.value!=null?!1:e.slice(1)}}),O=(r,e)=>({match:t=>{let n=t[0];return n?.code!==r||n.value==null||e!=null&&n.value!==e?!1:t.slice(1)}}),Mf=r=>({match:e=>r.match(e)===!1?e:!1}),q=r=>({match:e=>{let t=r.match(e);return t===!1?e:t}}),Ae=(...r)=>({match:e=>{let t;for(let n of r){let s=n.match(e);s!==!1&&(t==null||s.length<t.length)&&(t=s)}return t??!1}}),$=(...r)=>({match:e=>{for(let t of r){let n=t.match(e);if(n===!1)return!1;e=n}return e}});function Q(...r){function e(s){if(s==null)return!1;let o=s.getComponents();for(let i of r){let a=i.match(o);if(a===!1)return!1;o=a}return o}function t(s){return e(s)!==!1}function n(s){let o=e(s);return o===!1?!1:o.length===0}return{matchers:r,matches:t,exactMatch:n}}var J0=O(421),QS=Q(J0),Yo=O(54),Zo=O(55),Xo=O(56),pc=O(53),JS=Q(Yo,q(O(421))),ev=Q(Zo,q(O(421))),tv=Q(Xo,q(O(421))),rv=Q(Ae(pc,Xo,Yo,Zo),q(O(421))),Kf=$(O(4),q(O(43))),qf=$(q(O(42)),O(41),q(O(43))),mc=Ae(Kf,qf),Yr=Ae(mc,pc,Yo,Zo,Xo),nv=Q(Ae(mc,$(Ae(pc,Xo,Yo,Zo),q(O(421))))),ov=Q(Kf),sv=Q(qf),iv=Q(mc),yc=$(Yr,O(6)),Fn=$(Yr,O(273)),av=Q($(yc,q(O(421)))),cv=Q(Fn),gc=$(Fn,X(460),q(O(421))),Qo=$(Fn,X(461),q(O(421))),ey=Ae(gc,Qo),uv=Q(gc),lv=Q(Qo),hc=Ae(Yr,yc,Fn,gc,Qo),zf=Ae($(hc,X(477),q(O(421)))),fv=Q(zf),Vf=Ae($(hc,X(478),q(O(421))),$(hc,X(448),q(O(449)),X(477),q(O(421)))),dv=Q(Vf),Hf=$(Fn,X(280),q(O(466)),q(O(466)),q(O(421))),hv=Q(Hf),$f=$(Qo,X(465),q(O(466)),q(O(466)),q(O(421))),pv=Q($f),Go=Ae(zf,Vf,$(yc,q(O(421))),$(ey,q(O(421))),$(Yr,q(O(421))),Hf,$f,O(421)),jf=Q(Go),ty=$(q(Go),X(290),Mf(X(281)),q(O(421))),ur=Q(ty),ry=Ae($(Go,X(290),X(281),q(O(421))),$(Go,X(281),q(O(421))),$(X(281),q(O(421)))),mv=Q(ry),ny=$(Yr,Ae($(O(6,"80")),$(O(6),X(480)),X(480)),q(O(481)),q(O(421))),yv=Q(ny),oy=$(Yr,Ae($(O(6,"443")),$(O(6,"443"),X(480)),$(O(6),X(443)),$(O(6),X(448),X(480)),$(X(448),X(480)),X(448),X(443)),q(O(481)),q(O(421))),gv=Q(oy),sy=Ae($(O(777),q(O(421)))),bv=Q(sy),iy=Ae($(O(400),q(O(421)))),wv=Q(iy);function Ye(){let r={};return r.promise=new Promise((e,t)=>{r.resolve=e,r.reject=t}),r}var Jo=class{buffer;mask;top;btm;next;constructor(e){if(!(e>0)||(e-1&e)!==0)throw new Error("Max size for a FixedFIFO should be a power of two");this.buffer=new Array(e),this.mask=e-1,this.top=0,this.btm=0,this.next=null}push(e){return this.buffer[this.top]!==void 0?!1:(this.buffer[this.top]=e,this.top=this.top+1&this.mask,!0)}shift(){let e=this.buffer[this.btm];if(e!==void 0)return this.buffer[this.btm]=void 0,this.btm=this.btm+1&this.mask,e}isEmpty(){return this.buffer[this.btm]===void 0}},Zr=class{size;hwm;head;tail;constructor(e={}){this.hwm=e.splitLimit??16,this.head=new Jo(this.hwm),this.tail=this.head,this.size=0}calculateSize(e){return e?.byteLength!=null?e.byteLength:1}push(e){if(e?.value!=null&&(this.size+=this.calculateSize(e.value)),!this.head.push(e)){let t=this.head;this.head=t.next=new Jo(2*this.head.buffer.length),this.head.push(e)}}shift(){let e=this.tail.shift();if(e===void 0&&this.tail.next!=null){let t=this.tail.next;this.tail.next=null,this.tail=t,e=this.tail.shift()}return e?.value!=null&&(this.size-=this.calculateSize(e.value)),e}isEmpty(){return this.head.isEmpty()}};var bc=class extends Error{type;code;constructor(e,t){super(e??"The operation was aborted"),this.type="aborted",this.code=t??"ABORT_ERR"}};function Nt(r={}){return ay(t=>{let n=t.shift();if(n==null)return{done:!0};if(n.error!=null)throw n.error;return{done:n.done===!0,value:n.value}},r)}function ay(r,e){e=e??{};let t=e.onEnd,n=new Zr,s,o,i,a=Ye(),c=async()=>{try{return n.isEmpty()?i?{done:!0}:await new Promise((h,g)=>{o=E=>{o=null,n.push(E);try{h(r(n))}catch(v){g(v)}return s}}):r(n)}finally{n.isEmpty()&&queueMicrotask(()=>{a.resolve(),a=Ye()})}},u=h=>o!=null?o(h):(n.push(h),s),l=h=>(n=new Zr,o!=null?o({error:h}):(n.push({error:h}),s)),f=h=>{if(i)return s;if(e?.objectMode!==!0&&h?.byteLength==null)throw new Error("objectMode was not true but tried to push non-Uint8Array value");return u({done:!1,value:h})},m=h=>i?s:(i=!0,h!=null?l(h):u({done:!0})),d=()=>(n=new Zr,m(),{done:!0}),p=h=>(m(h),{done:!0});if(s={[Symbol.asyncIterator](){return this},next:c,return:d,throw:p,push:f,end:m,get readableLength(){return n.size},onEmpty:async h=>{let g=h?.signal;if(g?.throwIfAborted(),n.isEmpty())return;let E,v;g!=null&&(E=new Promise((I,D)=>{v=()=>{D(new bc)},g.addEventListener("abort",v)}));try{await Promise.race([a.promise,E])}finally{v!=null&&g!=null&&g?.removeEventListener("abort",v)}}},t==null)return s;let b=s;return s={[Symbol.asyncIterator](){return this},next(){return b.next()},throw(h){return b.throw(h),t!=null&&(t(h),t=void 0),{done:!0}},return(){return b.return(),t!=null&&(t(),t=void 0),{done:!0}},push:f,end(h){return b.end(h),t!=null&&(t(h),t=void 0),s},get readableLength(){return b.readableLength},onEmpty:h=>b.onEmpty(h)},s}var wc=class r extends Error{name="TimeoutError";constructor(e,t){super(e,t),Error.captureStackTrace?.(this,r)}},Wf=r=>r.reason??new DOMException("This operation was aborted.","AbortError");function xc(r,e){let{milliseconds:t,fallback:n,message:s,customTimers:o={setTimeout,clearTimeout},signal:i}=e,a,c,l=new Promise((f,m)=>{if(typeof t!="number"||Math.sign(t)!==1)throw new TypeError(`Expected \`milliseconds\` to be a positive number, got \`${t}\``);if(i?.aborted){m(Wf(i));return}if(i&&(c=()=>{m(Wf(i))},i.addEventListener("abort",c,{once:!0})),r.then(f,m),t===Number.POSITIVE_INFINITY)return;let d=new wc;a=o.setTimeout.call(void 0,()=>{if(n){try{f(n())}catch(p){m(p)}return}typeof r.cancel=="function"&&r.cancel(),s===!1?f():s instanceof Error?m(s):(d.message=s??`Promise timed out after ${t} milliseconds`,m(d))},t)}).finally(()=>{l.clear(),c&&i&&i.removeEventListener("abort",c)});return l.clear=()=>{o.clearTimeout.call(void 0,a),a=void 0},l}var cy=r=>{let e=r.addEventListener||r.on||r.addListener,t=r.removeEventListener||r.off||r.removeListener;if(!e||!t)throw new TypeError("Emitter is not compatible");return{addListener:e.bind(r),removeListener:t.bind(r)}};function uy(r,e,t){let n,s=new Promise((o,i)=>{if(t={rejectionEvents:["error"],multiArgs:!1,rejectionMultiArgs:!1,resolveImmediately:!1,...t},!(t.count>=0&&(t.count===Number.POSITIVE_INFINITY||Number.isInteger(t.count))))throw new TypeError("The `count` option should be at least 0 or more");t.signal?.throwIfAborted();let a=[e].flat(),c=[],{addListener:u,removeListener:l}=cy(r),f=async(...d)=>{let p=t.multiArgs?d:d[0];if(t.filter)try{if(!await t.filter(p))return}catch(b){n(),i(b);return}c.push(p),t.count===c.length&&(n(),o(c))},m=(...d)=>{n(),i(t.rejectionMultiArgs?d:d[0])};n=()=>{for(let d of a)l(d,f);for(let d of t.rejectionEvents)a.includes(d)||l(d,m)};for(let d of a)u(d,f);for(let d of t.rejectionEvents)a.includes(d)||u(d,m);t.signal&&t.signal.addEventListener("abort",()=>{m(t.signal.reason)},{once:!0}),t.resolveImmediately&&o(c)});if(s.cancel=n,typeof t.timeout=="number"){let o=xc(s,{milliseconds:t.timeout});return o.cancel=()=>{n(),o.clear()},o}return s}function ot(r,e,t){typeof t=="function"&&(t={filter:t}),t={...t,count:1,resolveImmediately:!1};let n=uy(r,e,t),s=n.then(o=>o[0]);return s.cancel=n.cancel,s}function Ec(r,e){let t,n=function(){let s=function(){t=void 0,r()};clearTimeout(t),t=setTimeout(s,e)};return n.start=()=>{},n.stop=()=>{clearTimeout(t)},n}var es=class extends Error{static name="QueueFullError";constructor(e="The queue was full"){super(e),this.name="QueueFullError"}},lr=class extends Error{static name="UnexpectedEOFError";name="UnexpectedEOFError"};var ts=class extends Error{static name="StreamClosedError";name="StreamClosedError"};function ly(r){return r.reason}async function Ut(r,e,t){if(e==null)return r;let n=t?.translateError??ly;if(e.aborted)return r.catch(()=>{}),Promise.reject(n(e));let s;try{return await Promise.race([r,new Promise((o,i)=>{s=()=>{i(n(e))},e.addEventListener("abort",s)})])}finally{s!=null&&e.removeEventListener("abort",s)}}var rs=class{deferred;signal;onProgress;constructor(e){this.signal=e?.signal,this.onProgress=e?.onProgress,this.deferred=Ye(),this.onAbort=this.onAbort.bind(this),this.signal?.addEventListener("abort",this.onAbort)}onAbort(){this.deferred.reject(this.signal?.reason??new st)}cleanup(){this.signal?.removeEventListener("abort",this.onAbort)}};function fy(){return`${parseInt(String(Math.random()*1e9),10).toString()}${Date.now()}`}var ns=class{id;fn;options;recipients;status;timeline;controller;dispatchingProgress;constructor(e,t){this.id=fy(),this.status="queued",this.fn=e,this.options=t,this.recipients=[],this.timeline={created:Date.now()},this.controller=new AbortController,this.controller.signal,this.dispatchingProgress=!1,this.onAbort=this.onAbort.bind(this)}abort(e){this.controller.abort(e)}onAbort(){this.recipients.reduce((t,n)=>t&&n.signal?.aborted===!0,!0)&&(this.controller.abort(new st),this.cleanup())}async join(e){let t=new rs(e);return this.recipients.push(t),e?.signal?.addEventListener("abort",this.onAbort),t.deferred.promise}async run(){this.status="running",this.timeline.started=Date.now();try{this.controller.signal.throwIfAborted();let e=await Ut(this.fn({...this.options??{},signal:this.controller.signal,onProgress:t=>{if(!this.dispatchingProgress){this.dispatchingProgress=!0;try{this.recipients.forEach(n=>{n.onProgress?.(t)})}finally{this.dispatchingProgress=!1}}}}),this.controller.signal);this.recipients.forEach(t=>{t.deferred.resolve(e)}),this.status="complete"}catch(e){this.recipients.forEach(t=>{t.deferred.reject(e)}),this.status="errored"}finally{this.timeline.finished=Date.now(),this.cleanup()}}cleanup(){this.recipients.forEach(e=>{e.cleanup(),e.signal?.removeEventListener("abort",this.onAbort)})}};var os=class extends Ie{concurrency;maxSize;queue;pending;sort;paused;constructor(e={}){super(),this.concurrency=e.concurrency??Number.POSITIVE_INFINITY,this.maxSize=e.maxSize??Number.POSITIVE_INFINITY,this.pending=0,this.paused=!1,e.metricName!=null&&e.metrics?.registerMetricGroup(e.metricName,{calculate:()=>({size:this.queue.length,running:this.pending,queued:this.queue.length-this.pending})}),this.sort=e.sort,this.queue=[],this.emitEmpty=Ec(this.emitEmpty.bind(this),1),this.emitIdle=Ec(this.emitIdle.bind(this),1)}emitEmpty(){this.size===0&&this.safeDispatchEvent("empty")}emitIdle(){this.running===0&&this.safeDispatchEvent("idle")}pause(){this.paused=!0}resume(){this.paused&&(this.paused=!1,this.tryToStartAnother())}tryToStartAnother(){if(this.paused)return!1;if(this.size===0)return this.emitEmpty(),this.running===0&&this.emitIdle(),!1;if(this.pending<this.concurrency){let e;for(let t of this.queue)if(t.status==="queued"){e=t;break}return e==null?!1:(this.safeDispatchEvent("active"),this.pending++,e.run().finally(()=>{for(let t=0;t<this.queue.length;t++)if(this.queue[t]===e){this.queue.splice(t,1);break}this.pending--,this.tryToStartAnother(),this.safeDispatchEvent("next")}),!0)}return!1}enqueue(e){this.queue.push(e),this.sort!=null&&this.queue.sort(this.sort)}async add(e,t){if(t?.signal?.throwIfAborted(),this.size===this.maxSize)throw new es;let n=new ns(e,t);this.enqueue(n),this.safeDispatchEvent("add");let s=n.join(t).then(o=>(this.safeDispatchEvent("completed",{detail:o}),this.safeDispatchEvent("success",{detail:{job:n,result:o}}),o)).catch(o=>{if(n.status==="queued"){for(let i=0;i<this.queue.length;i++)if(this.queue[i]===n){this.queue.splice(i,1);break}}throw this.safeDispatchEvent("failure",{detail:{job:n,error:o}}),o});return this.tryToStartAnother(),s}clear(){this.queue.splice(0,this.queue.length)}abort(){this.queue.forEach(e=>{e.abort(new st)}),this.clear()}async onEmpty(e){this.size!==0&&await ot(this,"empty",e)}async onSizeLessThan(e,t){this.size<e||await ot(this,"next",{...t,filter:()=>this.size<e})}async onIdle(e){this.pending===0&&this.size===0||await ot(this,"idle",e)}get size(){return this.queue.length}get queued(){return this.queue.length-this.pending}get running(){return this.pending}async*toGenerator(e){e?.signal?.throwIfAborted();let t=Nt({objectMode:!0}),n=c=>{c!=null?this.abort():this.clear(),t.end(c)},s=c=>{c.detail!=null&&t.push(c.detail)},o=c=>{n(c.detail.error)},i=()=>{n()},a=()=>{n(new st("Queue aborted"))};this.addEventListener("completed",s),this.addEventListener("failure",o),this.addEventListener("idle",i),e?.signal?.addEventListener("abort",a);try{yield*t}finally{this.removeEventListener("completed",s),this.removeEventListener("failure",o),this.removeEventListener("idle",i),e?.signal?.removeEventListener("abort",a),n()}}};var dy=Math.pow(2,20)*4,ss=class extends Ie{status;timeline;inactivityTimeout;maxReadBufferLength;maxWriteBufferLength;log;direction;maxMessageSize;readStatus;writeStatus;remoteReadStatus;remoteWriteStatus;writableNeedsDrain;readBuffer;writeBuffer;sendingData;onDrainPromise;constructor(e){super(),this.status="open",this.log=e.log,this.direction=e.direction??"outbound",this.inactivityTimeout=e.inactivityTimeout??12e4,this.maxReadBufferLength=e.maxReadBufferLength??dy,this.maxWriteBufferLength=e.maxWriteBufferLength,this.maxMessageSize=e.maxMessageSize,this.readBuffer=new ee,this.writeBuffer=new ee,this.readStatus="readable",this.remoteReadStatus="readable",this.writeStatus="writable",this.remoteWriteStatus="writable",this.sendingData=!1,this.writableNeedsDrain=!1,this.timeline={open:Date.now()},this.processSendQueue=this.processSendQueue.bind(this);let t=()=>{this.writableNeedsDrain&&(this.log.trace("drain event received, continue sending data"),this.writableNeedsDrain=!1,queueMicrotask(()=>{try{this.processSendQueue()}catch(s){this.log.error("processSendQueue threw - %e",s)}})),this.onDrainPromise?.resolve()};this.addEventListener("drain",t);let n=s=>{this.onDrainPromise?.reject(s.error??new ts)};this.addEventListener("close",n)}get readBufferLength(){return this.readBuffer.byteLength}get writeBufferLength(){return this.writeBuffer.byteLength}async onDrain(e){return this.writableNeedsDrain!==!0?Promise.resolve():(this.onDrainPromise==null&&(this.onDrainPromise=Promise.withResolvers()),Ut(this.onDrainPromise.promise,e?.signal))}async*[Symbol.asyncIterator](){if(this.readStatus!=="readable"&&this.readStatus!=="paused")return;let e=Nt(),t=o=>{e.push(o.data)};this.addEventListener("message",t);let n=o=>{e.end(o.error)};this.addEventListener("close",n);let s=()=>{e.end()};this.addEventListener("remoteCloseWrite",s);try{yield*e}finally{this.removeEventListener("message",t),this.removeEventListener("close",n),this.removeEventListener("remoteCloseWrite",s)}}isReadable(){return this.status==="open"}send(e){if(this.writeStatus==="closed"||this.writeStatus==="closing")throw new xt(`Cannot write to a stream that is ${this.writeStatus}`);return this.log.trace("append %d bytes to write buffer",e.byteLength),this.writeBuffer.append(e),this.processSendQueue()}abort(e){if(!(this.status==="aborted"||this.status==="reset"||this.status==="closed")){this.log.error("abort with error - %e",e),this.status="aborted",this.readBuffer.byteLength>0&&this.readBuffer.consume(this.readBuffer.byteLength),this.writeBuffer.byteLength>0&&(this.writeBuffer.consume(this.writeBuffer.byteLength),this.safeDispatchEvent("idle")),this.writeStatus="closed",this.remoteWriteStatus="closed",this.readStatus="closed",this.remoteReadStatus="closed",this.timeline.close=Date.now();try{this.sendReset(e)}catch(t){this.log("failed to send reset to remote - %e",t)}this.dispatchEvent(new Qn(e))}}pause(){if(this.readStatus==="closed"||this.readStatus==="closing")throw new xt("Cannot pause a stream that is closing/closed");this.readStatus!=="paused"&&(this.readStatus="paused",this.sendPause())}resume(){if(this.readStatus==="closed"||this.readStatus==="closing")throw new xt("Cannot resume a stream that is closing/closed");this.readStatus!=="readable"&&(this.readStatus="readable",this.dispatchReadBuffer(),this.sendResume())}push(e){if(this.readStatus==="closed"||this.readStatus==="closing")throw new xt(`Cannot push data onto a stream that is ${this.readStatus}`);if(e.byteLength!==0){if(this.readBuffer.append(e),this.readStatus==="paused"||this.listenerCount("message")===0){this.checkReadBufferLength();return}setTimeout(()=>{this.dispatchReadBuffer()},0)}}unshift(e){if(this.readStatus==="closed"||this.readStatus==="closing")throw new xt(`Cannot push data onto a stream that is ${this.readStatus}`);if(e.byteLength!==0){if(this.readBuffer.prepend(e),this.readStatus==="paused"||this.listenerCount("message")===0){this.checkReadBufferLength();return}setTimeout(()=>{this.dispatchReadBuffer()},0)}}onData(e){if(e.byteLength!==0){if(this.readStatus==="closing"||this.readStatus==="closed"){this.log("ignoring data - read status %s",this.readStatus);return}this.readBuffer.append(e),this.dispatchReadBuffer()}}addEventListener(...e){super.addEventListener.apply(this,e),e[0]==="message"&&this.readBuffer.byteLength>0&&queueMicrotask(()=>{this.dispatchReadBuffer()})}onRemoteReset(){this.log("remote reset"),this.status="reset",this.writeStatus="closed",this.remoteWriteStatus="closed",this.remoteReadStatus="closed",this.timeline.close=Date.now(),this.readBuffer.byteLength===0&&(this.readStatus="closed");let e=new jn;this.dispatchEvent(new Jn(e))}onTransportClosed(e){this.log("transport closed"),this.readStatus==="readable"&&this.readBuffer.byteLength===0&&(this.log("close readable end after transport closed and read buffer is empty"),this.readStatus="closed"),this.remoteReadStatus!=="closed"&&(this.remoteReadStatus="closed"),this.remoteWriteStatus!=="closed"&&(this.remoteWriteStatus="closed"),this.writeStatus!=="closed"&&(this.writeStatus="closed"),e!=null?this.abort(e):(this.status==="open"||this.status==="closing")&&(this.timeline.close=Date.now(),this.status="closed",this.writeStatus="closed",this.remoteWriteStatus="closed",this.remoteReadStatus="closed",this.dispatchEvent(new yr))}onRemoteCloseWrite(){this.remoteWriteStatus!=="closed"&&(this.log.trace("on remote close write"),this.remoteWriteStatus="closed",this.safeDispatchEvent("remoteCloseWrite"),this.writeStatus==="closed"&&this.onTransportClosed())}onRemoteCloseRead(){this.log.trace("on remote close read"),this.remoteReadStatus="closed",this.writeBuffer.byteLength>0&&(this.writeBuffer.consume(this.writeBuffer.byteLength),this.safeDispatchEvent("idle"))}processSendQueue(){if(this.writableNeedsDrain)return this.log.trace("not processing send queue as drain is required"),this.checkWriteBufferLength(),!1;if(this.writeBuffer.byteLength===0)return this.log.trace("not processing send queue as no bytes to send"),!0;if(this.sendingData)return this.log.trace("not processing send queue as already sending data"),!0;if(this.writeStatus!=="writable"&&this.writeStatus!=="closing")return this.log.trace("not processing send queue as stream is %s",this.writeStatus),!1;this.sendingData=!0,this.log.trace("processing send queue with %d queued bytes",this.writeBuffer.byteLength);try{let e=!0,t=this.writeBuffer.byteLength,n=0;for(;this.writeBuffer.byteLength>0;){let s=Math.min(this.maxMessageSize??this.writeBuffer.byteLength,this.writeBuffer.byteLength);if(s===0){e=!1;break}let o=this.writeBuffer.sublist(0,s),i=new ee(o);this.writeBuffer.consume(o.byteLength);let a;try{a=this.sendData(o)}catch(c){throw this.writeBuffer.prepend(i),this.abort(c),c}if(e=a.canSendMore,n+=a.sentBytes,a.sentBytes!==i.byteLength&&(i.consume(a.sentBytes),this.writeBuffer.prepend(i)),!e)break}return e||(this.log.trace("sent %d/%d bytes, pausing sending because underlying stream is full, %d bytes left in the write buffer",n,t,this.writeBuffer.byteLength),this.writableNeedsDrain=!0,this.checkWriteBufferLength()),this.writeBuffer.byteLength===0&&this.safeDispatchEvent("idle"),e}finally{this.sendingData=!1}}dispatchReadBuffer(){try{if(this.listenerCount("message")===0){this.log.trace("not dispatching pause buffer as there are no listeners for the message event");return}if(this.readBuffer.byteLength===0){this.log.trace("not dispatching pause buffer as there is no data to dispatch");return}if(this.readStatus==="paused"){this.log.trace("not dispatching pause buffer we are paused");return}if(this.readStatus==="closing"||this.readStatus==="closed"){this.log("dropping %d bytes because the readable end is %s",this.readBuffer.byteLength,this.readStatus),this.readBuffer.consume(this.readBuffer.byteLength);return}let e=this.readBuffer.sublist();this.readBuffer.consume(e.byteLength),this.dispatchEvent(new Xn(e))}finally{this.readBuffer.byteLength===0&&this.remoteWriteStatus==="closed"&&(this.log("close readable end after dispatching read buffer and remote writable end is closed"),this.readStatus="closed"),this.checkReadBufferLength()}}checkReadBufferLength(){this.readBuffer.byteLength>this.maxReadBufferLength&&this.abort(new Jr(`Read buffer length of ${this.readBuffer.byteLength} exceeded limit of ${this.maxReadBufferLength}, read status is ${this.readStatus}`))}checkWriteBufferLength(){this.maxWriteBufferLength!=null&&this.writeBuffer.byteLength>this.maxWriteBufferLength&&this.abort(new Jr(`Write buffer length of ${this.writeBuffer.byteLength} exceeded limit of ${this.maxWriteBufferLength}, write status is ${this.writeStatus}`))}onMuxerNeedsDrain(){this.writableNeedsDrain=!0}onMuxerDrain(){this.safeDispatchEvent("drain")}};var is=class extends ss{remoteAddr;metricPrefix;metrics;constructor(e){super(e),this.metricPrefix=e.metricPrefix??"",this.metrics=e.metrics,this.remoteAddr=e.remoteAddr,this.addEventListener("close",t=>{this.metrics?.increment({[`${this.metricPrefix}end`]:!0}),t.error!=null?t.local?this.metrics?.increment({[`${this.metricPrefix}abort`]:!0}):this.metrics?.increment({[`${this.metricPrefix}reset`]:!0}):t.local?this.metrics?.increment({[`${this.metricPrefix}_local_close`]:!0}):this.metrics?.increment({[`${this.metricPrefix}_remote_close`]:!0})})}async close(e){this.status==="open"&&(this.status="closing",this.writeStatus="closing",this.remoteWriteStatus="closing",this.remoteReadStatus="closing",(this.sendingData||this.writeBuffer.byteLength>0)&&(this.log("waiting for write queue to become idle before closing writable end of stream, %d unsent bytes",this.writeBuffer.byteLength),await ot(this,"idle",{...e,rejectionEvents:["close"]})),this.writableNeedsDrain&&(this.log("waiting for write queue to drain before closing writable end of stream, %d unsent bytes",this.writeBuffer.byteLength),await ot(this,"drain",{...e,rejectionEvents:["close"]})),await this.sendClose(e),this.onTransportClosed())}};function as(r){let e=new globalThis.AbortController;function t(){let o=r.filter(i=>i?.aborted===!0).map(i=>i?.reason).pop();e.abort(o);for(let i of r)i?.removeEventListener!=null&&i.removeEventListener("abort",t)}for(let o of r){if(o?.aborted===!0){t();break}o?.addEventListener!=null&&o.addEventListener("abort",t)}function n(){for(let o of r)o?.removeEventListener!=null&&o.removeEventListener("abort",t)}let s=e.signal;return s.clear=n,s}var Sc=class{readNext;haveNext;ended;nextResult;error;constructor(){this.ended=!1,this.readNext=Ye(),this.haveNext=Ye()}[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 e=this.nextResult;return this.nextResult=void 0,this.readNext.resolve(),this.readNext=Ye(),e}async throw(e){return this.ended=!0,this.error=e,e!=null&&(this.haveNext.promise.catch(()=>{}),this.haveNext.reject(e)),{done:!0,value:void 0}}async return(){let e={done:!0,value:void 0};return this.ended=!0,this.nextResult=e,this.haveNext.resolve(),e}async push(e,t){await this._push(e,t)}async end(e,t){e!=null?await this.throw(e):await this._push(void 0,t)}async _push(e,t){if(e!=null&&this.ended)throw this.error??new Error("Cannot push value onto an ended pushable");for(;this.nextResult!=null;)await this.readNext.promise;e!=null?this.nextResult={done:!1,value:e}:(this.ended=!0,this.nextResult={done:!0,value:void 0}),this.haveNext.resolve(),this.haveNext=Ye(),await Ut(this.readNext.promise,t?.signal,t)}};function Gf(){return new Sc}function hy(r){return r[Symbol.asyncIterator]!=null}async function py(r,e,t){try{await Promise.all(r.map(async n=>{for await(let s of n)await e.push(s,{signal:t}),t.throwIfAborted()})),await e.end(void 0,{signal:t})}catch(n){await e.end(n,{signal:t}).catch(()=>{})}}async function*my(r){let e=new AbortController,t=Gf();py(r,t,e.signal).catch(()=>{});try{yield*t}finally{e.abort()}}function*yy(r){for(let e of r)yield*e}function gy(...r){let e=[];for(let t of r)hy(t)||e.push(t);return e.length===r.length?yy(e):my(r)}var Yf=gy;function Zf(r,...e){if(r==null)throw new Error("Empty pipeline");if(vc(r)){let n=r;r=()=>n.source}else if(Qf(r)||Xf(r)){let n=r;r=()=>n}let t=[r,...e];if(t.length>1&&vc(t[t.length-1])&&(t[t.length-1]=t[t.length-1].sink),t.length>2)for(let n=1;n<t.length-1;n++)vc(t[n])&&(t[n]=wy(t[n]));return by(...t)}var by=(...r)=>{let e;for(;r.length>0;)e=r.shift()(e);return e},Xf=r=>r?.[Symbol.asyncIterator]!=null,Qf=r=>r?.[Symbol.iterator]!=null,vc=r=>r==null?!1:r.sink!=null&&r.source!=null,wy=r=>e=>{let t=r.sink(e);if(t?.then!=null){let n=Nt({objectMode:!0});t.then(()=>{n.end()},i=>{n.end(i)});let s,o=r.source;if(Xf(o))s=async function*(){yield*o,n.end()};else if(Qf(o))s=function*(){yield*o,n.end()};else throw new Error("Unknown duplex source type - must be Iterable or AsyncIterable");return Yf(n,s())}return r.source};var xy=4194304,cs=class extends Error{static name="UnwrappedError";name="UnwrappedError"},Ac=class extends Error{name="InvalidMessageLengthError";code="ERR_INVALID_MSG_LENGTH"},Tc=class extends Error{name="InvalidDataLengthError";code="ERR_MSG_DATA_TOO_LONG"},Dc=class extends Error{name="InvalidDataLengthLengthError";code="ERR_MSG_LENGTH_TOO_LONG"};function Ey(r){return typeof r?.closeRead=="function"}function Sy(r){return typeof r?.close=="function"}function _c(r){return Ey(r)?r.remoteWriteStatus!=="writable"&&r.readBufferLength===0:Sy(r)?r.status!=="open":!1}function vy(r){return r?.addEventListener!=null&&r?.removeEventListener!=null&&r?.send!=null&&r?.push!=null&&r?.log!=null}function _y(r,e){let t=e?.maxBufferSize??xy,n=new ee,s,o=!1;if(!vy(r))throw new se("Argument should be a Stream or a Multiaddr");let i=l=>{if(n.append(l.data),n.byteLength>t){let f=n.byteLength;n.consume(n.byteLength),s?.reject(new Error(`Read buffer overflow - ${f} > ${t}`))}s?.resolve()};r.addEventListener("message",i);let a=l=>{l.error!=null?s?.reject(l.error):s?.resolve()};r.addEventListener("close",a);let c=()=>{s?.resolve()};r.addEventListener("remoteCloseWrite",c);let u={readBuffer:n,async read(l){if(o===!0)throw new cs("Stream was unwrapped");if(_c(r)){if(n.byteLength===0&&l?.bytes==null)return null;if(l?.bytes!=null&&n.byteLength<l.bytes)throw r.log.error("closed after reading %d/%d bytes",n.byteLength,l.bytes),new lr(`Unexpected EOF - stream closed after reading ${n.byteLength}/${l.bytes} bytes`)}let f=l?.bytes??1;for(s=Promise.withResolvers();;){if(n.byteLength>=f){s.resolve();break}if(await Ut(s.promise,l?.signal),_c(r)){if(n.byteLength===0&&l?.bytes==null)return null;break}s=Promise.withResolvers()}let m=l?.bytes??n.byteLength;if(n.byteLength<m){if(_c(r))throw r.log.error("closed while reading %d/%d bytes",n.byteLength,m),new lr(`Unexpected EOF - stream closed while reading ${n.byteLength}/${m} bytes`);return u.read(l)}let d=n.sublist(0,m);return n.consume(m),d},async write(l,f){if(o===!0)throw new cs("Stream was unwrapped");r.send(l)||await ot(r,"drain",{signal:f?.signal,rejectionEvents:["close"]})},unwrap(){return o||(o=!0,r.removeEventListener("message",i),r.removeEventListener("close",a),r.removeEventListener("remoteCloseWrite",c),n.byteLength>0&&(r.log("stream unwrapped with %d unread bytes",n.byteLength),r.unshift(n))),r}};return u}function Ay(r,e={}){let t=_y(r,e);e.maxDataLength!=null&&e.maxLengthLength==null&&(e.maxLengthLength=mt(e.maxDataLength));let n=e?.lengthDecoder??ml,s=e?.lengthEncoder??Or;return{async read(i){let a=-1,c=new ee;for(;;){let l=await t.read({...i,bytes:1});if(l==null)break;c.append(l);try{a=n(c)}catch(f){if(f instanceof RangeError)continue;throw f}if(a<0)throw new Ac("Invalid message length");if(e?.maxLengthLength!=null&&c.byteLength>e.maxLengthLength)throw new Dc(`Message length length too long - ${c.byteLength} > ${e.maxLengthLength}`);if(a>-1)break}if(e?.maxDataLength!=null&&a>e.maxDataLength)throw new Tc(`Message length too long - ${a} > ${e.maxDataLength}`);let u=await t.read({...i,bytes:a});if(u==null)throw r.log.error("tried to read %d bytes but the stream closed",a),new lr(`Unexpected EOF - tried to read ${a} bytes but the stream closed`);if(u.byteLength!==a)throw r.log.error("read %d/%d bytes before the stream closed",u.byteLength,a),new lr(`Unexpected EOF - read ${u.byteLength}/${a} bytes before the stream closed`);return u},async write(i,a){await t.write(new ee(s(i.byteLength),i),a)},async writeV(i,a){let c=new ee(...i.flatMap(u=>[s(u.byteLength),u]));await t.write(c,a)},unwrap(){return t.unwrap()}}}function kt(r,e){let t=Ay(r,e),n={read:async(s,o)=>{let i=await t.read(o);return s.decode(i)},write:async(s,o,i)=>{await t.write(o.encode(s),i)},writeV:async(s,o,i)=>{await t.writeV(s.map(a=>o.encode(a)),i)},pb:s=>({read:async o=>n.read(s,o),write:async(o,i)=>n.write(o,s,i),writeV:async(o,i)=>n.writeV(o,s,i),unwrap:()=>n}),unwrap:()=>t.unwrap()};return n}function Ty(r){return r?.addEventListener!=null}function Dy(r){let e=Nt(),t,n=i=>{e.push(i.data)},s=()=>{e.end(),r.removeEventListener("message",n),r.removeEventListener("close",o),r.removeEventListener("remoteCloseWrite",s)},o=i=>{e.end(i.error),i.error!=null&&t?.reject(i.error),r.removeEventListener("message",n),r.removeEventListener("close",o),r.removeEventListener("remoteCloseWrite",s)};return r.addEventListener("message",n),r.addEventListener("close",o,{once:!0}),r.addEventListener("remoteCloseWrite",s,{once:!0}),{source:e,async sink(i){async function*a(){yield*i}let c=a();for(;;){t=Promise.withResolvers();let{done:u,value:l}=await Promise.race([c.next(),t.promise]);if(r.writeStatus==="closing"||r.writeStatus==="closed"||(l!=null&&(r.send(l)||await Promise.race([ot(r,"drain",{rejectionEvents:["close"]})])),u===!0))break}await r.close()}}}function Jf(...r){let e=r.map(t=>Ty(t)?Dy(t):t);return Zf(...e)}var Xr=class extends os{has(e){return this.find(e)!=null}find(e){return this.queue.find(t=>e.equals(t.options.peerId))}};var Ic=1e3,ed=60*Ic,td=15,rd=120*ed,nd=1,us=5e3,od=100,Cc="circuit-relay-source",Mn=`${zc}-circuit-relay`,sd=2*ed,id=BigInt(1<<17),Ke="/libp2p/circuit/relay/0.2.0/hop",fr="/libp2p/circuit/relay/0.2.0/stop",ad=30*Ic,_6=30*Ic,Kn=300,cd=4096,ud=.001;var Y;(function(r){let e;(function(a){a.RESERVE="RESERVE",a.CONNECT="CONNECT",a.STATUS="STATUS"})(e=r.Type||(r.Type={}));let t;(function(a){a[a.RESERVE=0]="RESERVE",a[a.CONNECT=1]="CONNECT",a[a.STATUS=2]="STATUS"})(t||(t={})),(function(a){a.codec=()=>rr(t)})(e=r.Type||(r.Type={}));let n;r.codec=()=>(n==null&&(n=Oe((a,c,u={})=>{u.lengthDelimited!==!1&&c.fork(),a.type!=null&&(c.uint32(8),r.Type.codec().encode(a.type,c)),a.peer!=null&&(c.uint32(18),Ft.codec().encode(a.peer,c)),a.reservation!=null&&(c.uint32(26),qn.codec().encode(a.reservation,c)),a.limit!=null&&(c.uint32(34),Mt.codec().encode(a.limit,c)),a.status!=null&&(c.uint32(40),F.codec().encode(a.status,c)),u.lengthDelimited!==!1&&c.ldelim()},(a,c,u={})=>{let l={},f=c==null?a.len:a.pos+c;for(;a.pos<f;){let m=a.uint32();switch(m>>>3){case 1:{l.type=r.Type.codec().decode(a);break}case 2:{l.peer=Ft.codec().decode(a,a.uint32(),{limits:u.limits?.peer});break}case 3:{l.reservation=qn.codec().decode(a,a.uint32(),{limits:u.limits?.reservation});break}case 4:{l.limit=Mt.codec().decode(a,a.uint32(),{limits:u.limits?.limit});break}case 5:{l.status=F.codec().decode(a);break}default:{a.skipType(m&7);break}}}return l},function*(a,c,u,l={}){let f=c==null?a.len:a.pos+c;for(;a.pos<f;){let m=a.uint32();switch(m>>>3){case 1:{yield{field:`${u}.type`,value:r.Type.codec().decode(a)};break}case 2:{yield*Ft.codec().stream(a,a.uint32(),`${u}.peer`,{limits:l.limits?.peer});break}case 3:{yield*qn.codec().stream(a,a.uint32(),`${u}.reservation`,{limits:l.limits?.reservation});break}case 4:{yield*Mt.codec().stream(a,a.uint32(),`${u}.limit`,{limits:l.limits?.limit});break}case 5:{yield{field:`${u}.status`,value:F.codec().decode(a)};break}default:{a.skipType(m&7);break}}}})),n);function s(a){return Be(a,r.codec())}r.encode=s;function o(a,c){return Le(a,r.codec(),c)}r.decode=o;function i(a,c){return Re(a,r.codec(),c)}r.stream=i})(Y||(Y={}));var Fe;(function(r){let e;(function(a){a.CONNECT="CONNECT",a.STATUS="STATUS"})(e=r.Type||(r.Type={}));let t;(function(a){a[a.CONNECT=0]="CONNECT",a[a.STATUS=1]="STATUS"})(t||(t={})),(function(a){a.codec=()=>rr(t)})(e=r.Type||(r.Type={}));let n;r.codec=()=>(n==null&&(n=Oe((a,c,u={})=>{u.lengthDelimited!==!1&&c.fork(),a.type!=null&&(c.uint32(8),r.Type.codec().encode(a.type,c)),a.peer!=null&&(c.uint32(18),Ft.codec().encode(a.peer,c)),a.limit!=null&&(c.uint32(26),Mt.codec().encode(a.limit,c)),a.status!=null&&(c.uint32(32),F.codec().encode(a.status,c)),u.lengthDelimited!==!1&&c.ldelim()},(a,c,u={})=>{let l={},f=c==null?a.len:a.pos+c;for(;a.pos<f;){let m=a.uint32();switch(m>>>3){case 1:{l.type=r.Type.codec().decode(a);break}case 2:{l.peer=Ft.codec().decode(a,a.uint32(),{limits:u.limits?.peer});break}case 3:{l.limit=Mt.codec().decode(a,a.uint32(),{limits:u.limits?.limit});break}case 4:{l.status=F.codec().decode(a);break}default:{a.skipType(m&7);break}}}return l},function*(a,c,u,l={}){let f=c==null?a.len:a.pos+c;for(;a.pos<f;){let m=a.uint32();switch(m>>>3){case 1:{yield{field:`${u}.type`,value:r.Type.codec().decode(a)};break}case 2:{yield*Ft.codec().stream(a,a.uint32(),`${u}.peer`,{limits:l.limits?.peer});break}case 3:{yield*Mt.codec().stream(a,a.uint32(),`${u}.limit`,{limits:l.limits?.limit});break}case 4:{yield{field:`${u}.status`,value:F.codec().decode(a)};break}default:{a.skipType(m&7);break}}}})),n);function s(a){return Be(a,r.codec())}r.encode=s;function o(a,c){return Le(a,r.codec(),c)}r.decode=o;function i(a,c){return Re(a,r.codec(),c)}r.stream=i})(Fe||(Fe={}));var Ft;(function(r){let e;r.codec=()=>(e==null&&(e=Oe((o,i,a={})=>{if(a.lengthDelimited!==!1&&i.fork(),o.id!=null&&o.id.byteLength>0&&(i.uint32(10),i.bytes(o.id)),o.addrs!=null&&o.addrs.length>0)for(let c of o.addrs)i.uint32(18),i.bytes(c);a.lengthDelimited!==!1&&i.ldelim()},(o,i,a={})=>{let c={id:Te(0),addrs:[]},u=i==null?o.len:o.pos+i;for(;o.pos<u;){let l=o.uint32();switch(l>>>3){case 1:{c.id=o.bytes();break}case 2:{if(a.limits?.addrs!=null&&c.addrs.length===a.limits.addrs)throw new nr('Decode error - repeated field "addrs" had too many elements');c.addrs.push(o.bytes());break}default:{o.skipType(l&7);break}}}return c},function*(o,i,a,c={}){let u={addrs:0},l=i==null?o.len:o.pos+i;for(;o.pos<l;){let f=o.uint32();switch(f>>>3){case 1:{yield{field:`${a}.id`,value:o.bytes()};break}case 2:{if(c.limits?.addrs!=null&&u.addrs===c.limits.addrs)throw new nr('Streaming decode error - repeated field "addrs" had too many elements');yield{field:`${a}.addrs[]`,index:u.addrs,value:o.bytes()},u.addrs++;break}default:{o.skipType(f&7);break}}}})),e);function t(o){return Be(o,r.codec())}r.encode=t;function n(o,i){return Le(o,r.codec(),i)}r.decode=n;function s(o,i){return Re(o,r.codec(),i)}r.stream=s})(Ft||(Ft={}));var qn;(function(r){let e;r.codec=()=>(e==null&&(e=Oe((o,i,a={})=>{if(a.lengthDelimited!==!1&&i.fork(),o.expire!=null&&o.expire!==0n&&(i.uint32(8),i.uint64(o.expire)),o.addrs!=null&&o.addrs.length>0)for(let c of o.addrs)i.uint32(18),i.bytes(c);o.voucher!=null&&(i.uint32(26),zn.codec().encode(o.voucher,i)),a.lengthDelimited!==!1&&i.ldelim()},(o,i,a={})=>{let c={expire:0n,addrs:[]},u=i==null?o.len:o.pos+i;for(;o.pos<u;){let l=o.uint32();switch(l>>>3){case 1:{c.expire=o.uint64();break}case 2:{if(a.limits?.addrs!=null&&c.addrs.length===a.limits.addrs)throw new nr('Decode error - repeated field "addrs" had too many elements');c.addrs.push(o.bytes());break}case 3:{c.voucher=zn.codec().decode(o,o.uint32(),{limits:a.limits?.voucher});break}default:{o.skipType(l&7);break}}}return c},function*(o,i,a,c={}){let u={addrs:0},l=i==null?o.len:o.pos+i;for(;o.pos<l;){let f=o.uint32();switch(f>>>3){case 1:{yield{field:`${a}.expire`,value:o.uint64()};break}case 2:{if(c.limits?.addrs!=null&&u.addrs===c.limits.addrs)throw new nr('Streaming decode error - repeated field "addrs" had too many elements');yield{field:`${a}.addrs[]`,index:u.addrs,value:o.bytes()},u.addrs++;break}case 3:{yield*zn.codec().stream(o,o.uint32(),`${a}.voucher`,{limits:c.limits?.voucher});break}default:{o.skipType(f&7);break}}}})),e);function t(o){return Be(o,r.codec())}r.encode=t;function n(o,i){return Le(o,r.codec(),i)}r.decode=n;function s(o,i){return Re(o,r.codec(),i)}r.stream=s})(qn||(qn={}));var Mt;(function(r){let e;r.codec=()=>(e==null&&(e=Oe((o,i,a={})=>{a.lengthDelimited!==!1&&i.fork(),o.duration!=null&&(i.uint32(8),i.uint32(o.duration)),o.data!=null&&(i.uint32(16),i.uint64(o.data)),a.lengthDelimited!==!1&&i.ldelim()},(o,i,a={})=>{let c={},u=i==null?o.len:o.pos+i;for(;o.pos<u;){let l=o.uint32();switch(l>>>3){case 1:{c.duration=o.uint32();break}case 2:{c.data=o.uint64();break}default:{o.skipType(l&7);break}}}return c},function*(o,i,a,c={}){let u=i==null?o.len:o.pos+i;for(;o.pos<u;){let l=o.uint32();switch(l>>>3){case 1:{yield{field:`${a}.duration`,value:o.uint32()};break}case 2:{yield{field:`${a}.data`,value:o.uint64()};break}default:{o.skipType(l&7);break}}}})),e);function t(o){return Be(o,r.codec())}r.encode=t;function n(o,i){return Le(o,r.codec(),i)}r.decode=n;function s(o,i){return Re(o,r.codec(),i)}r.stream=s})(Mt||(Mt={}));var F;(function(r){r.UNUSED="UNUSED",r.OK="OK",r.RESERVATION_REFUSED="RESERVATION_REFUSED",r.RESOURCE_LIMIT_EXCEEDED="RESOURCE_LIMIT_EXCEEDED",r.PERMISSION_DENIED="PERMISSION_DENIED",r.CONNECTION_FAILED="CONNECTION_FAILED",r.NO_RESERVATION="NO_RESERVATION",r.MALFORMED_MESSAGE="MALFORMED_MESSAGE",r.UNEXPECTED_MESSAGE="UNEXPECTED_MESSAGE"})(F||(F={}));var Lc;(function(r){r[r.UNUSED=0]="UNUSED",r[r.OK=100]="OK",r[r.RESERVATION_REFUSED=200]="RESERVATION_REFUSED",r[r.RESOURCE_LIMIT_EXCEEDED=201]="RESOURCE_LIMIT_EXCEEDED",r[r.PERMISSION_DENIED=202]="PERMISSION_DENIED",r[r.CONNECTION_FAILED=203]="CONNECTION_FAILED",r[r.NO_RESERVATION=204]="NO_RESERVATION",r[r.MALFORMED_MESSAGE=400]="MALFORMED_MESSAGE",r[r.UNEXPECTED_MESSAGE=401]="UNEXPECTED_MESSAGE"})(Lc||(Lc={}));(function(r){r.codec=()=>rr(Lc)})(F||(F={}));var dr;(function(r){let e;r.codec=()=>(e==null&&(e=Oe((o,i,a={})=>{a.lengthDelimited!==!1&&i.fork(),o.relay!=null&&o.relay.byteLength>0&&(i.uint32(10),i.bytes(o.relay)),o.peer!=null&&o.peer.byteLength>0&&(i.uint32(18),i.bytes(o.peer)),o.expiration!=null&&o.expiration!==0n&&(i.uint32(24),i.uint64(o.expiration)),a.lengthDelimited!==!1&&i.ldelim()},(o,i,a={})=>{let c={relay:Te(0),peer:Te(0),expiration:0n},u=i==null?o.len:o.pos+i;for(;o.pos<u;){let l=o.uint32();switch(l>>>3){case 1:{c.relay=o.bytes();break}case 2:{c.peer=o.bytes();break}case 3:{c.expiration=o.uint64();break}default:{o.skipType(l&7);break}}}return c},function*(o,i,a,c={}){let u=i==null?o.len:o.pos+i;for(;o.pos<u;){let l=o.uint32();switch(l>>>3){case 1:{yield{field:`${a}.relay`,value:o.bytes()};break}case 2:{yield{field:`${a}.peer`,value:o.bytes()};break}case 3:{yield{field:`${a}.expiration`,value:o.uint64()};break}default:{o.skipType(l&7);break}}}})),e);function t(o){return Be(o,r.codec())}r.encode=t;function n(o,i){return Le(o,r.codec(),i)}r.decode=n;function s(o,i){return Re(o,r.codec(),i)}r.stream=s})(dr||(dr={}));var zn;(function(r){let e;r.codec=()=>(e==null&&(e=Oe((o,i,a={})=>{a.lengthDelimited!==!1&&i.fork(),o.publicKey!=null&&o.publicKey.byteLength>0&&(i.uint32(10),i.bytes(o.publicKey)),o.payloadType!=null&&o.payloadType.byteLength>0&&(i.uint32(18),i.bytes(o.payloadType)),o.payload!=null&&(i.uint32(26),dr.codec().encode(o.payload,i)),o.signature!=null&&o.signature.byteLength>0&&(i.uint32(42),i.bytes(o.signature)),a.lengthDelimited!==!1&&i.ldelim()},(o,i,a={})=>{let c={publicKey:Te(0),payloadType:Te(0),signature:Te(0)},u=i==null?o.len:o.pos+i;for(;o.pos<u;){let l=o.uint32();switch(l>>>3){case 1:{c.publicKey=o.bytes();break}case 2:{c.payloadType=o.bytes();break}case 3:{c.payload=dr.codec().decode(o,o.uint32(),{limits:a.limits?.payload});break}case 5:{c.signature=o.bytes();break}default:{o.skipType(l&7);break}}}return c},function*(o,i,a,c={}){let u=i==null?o.len:o.pos+i;for(;o.pos<u;){let l=o.uint32();switch(l>>>3){case 1:{yield{field:`${a}.publicKey`,value:o.bytes()};break}case 2:{yield{field:`${a}.payloadType`,value:o.bytes()};break}case 3:{yield*dr.codec().stream(o,o.uint32(),`${a}.payload`,{limits:c.limits?.payload});break}case 5:{yield{field:`${a}.signature`,value:o.bytes()};break}default:{o.skipType(l&7);break}}}})),e);function t(o){return Be(o,r.codec())}r.encode=t;function n(o,i){return Le(o,r.codec(),i)}r.decode=n;function s(o,i){return Re(o,r.codec(),i)}r.stream=s})(zn||(zn={}));var ls=class extends Error{constructor(e="Transfer limit error"){super(e),this.name="TransferLimitError"}},fs=class extends Error{constructor(e="Duration limit error"){super(e),this.name="DurationLimitError"}},Vn=class extends Error{static name="HadEnoughRelaysError";name="HadEnoughRelaysError"},ds=class extends Error{static name="DoubleRelayError";name="DoubleRelayError"},hs=class extends Error{static name="RelayQueueFullError";name="RelayQueueFullError"};function ld(r,e,t){let n=e.remaining,s=o=>{let i=BigInt(o.data.byteLength);e.remaining-=i,e.remaining<0&&r.abort(new ls(`data limit of ${n} bytes exceeded`))};r.addEventListener("message",s)}function fd(r,e,t,n,s){function o(l){r.abort(l),e.abort(l)}let i=[t,n.signal];if(n.limit?.duration!=null){s.log("limiting relayed connection duration to %dms",n.limit.duration);let l=AbortSignal.timeout(n.limit.duration);i.push(l)}let a=as(i);let c;n.limit?.data!=null&&(c={remaining:n.limit.data});let u=()=>{let l;t.aborted?l=t.reason:l=new fs(`duration limit of ${n.limit?.duration} ms exceeded`),o(l)};a.addEventListener("abort",u,{once:!0}),c!=null&&(ld(e,c,s),ld(r,c,s)),Jf(r,e,r).catch(l=>{o(l)}).finally(()=>{a.clear()})}function Bc(r){let e=r*BigInt(1e3),t=new Date().getTime();return Number(e-BigInt(t))}var Hn=class{expires;bytes;constructor(e){e?.duration!=null&&e?.duration!==0&&(this.expires=Date.now()+e.duration*1e3),this.bytes=e?.data,this.bytes===0n&&(this.bytes=void 0),this.onData=this.onData.bind(this)}onData(e){this.bytes!=null&&(this.bytes-=BigInt(e.byteLength),this.bytes<0n&&(this.bytes=0n))}getLimits(){if(this.expires==null&&this.bytes==null)return;let e={};if(this.bytes!=null){let t=this;Object.defineProperty(e,"bytes",{get(){return t.bytes}})}if(this.expires!=null){let t=this;Object.defineProperty(e,"seconds",{get(){return Math.round(((t.expires??0)-Date.now())/1e3)}})}return e}},ps=Q($(jf.matchers[0],X(290))),ms=Q(X(290));function ys(r,e){let t={[Symbol.iterator]:()=>t,next:()=>{let n=r.next(),s=n.value;return n.done===!0||s==null?{done:!0,value:void 0}:{done:!1,value:e(s)}}};return t}var Kt=class{map;constructor(e){if(this.map=new Map,e!=null)for(let[t,n]of e.entries())this.map.set(t.toString(),{key:t,value:n})}[Symbol.iterator](){return this.entries()}clear(){this.map.clear()}delete(e){return this.map.delete(e.toString())}entries(){return ys(this.map.entries(),e=>[e[1].key,e[1].value])}forEach(e){this.map.forEach((t,n)=>{e(t.value,t.key,this)})}get(e){return this.map.get(e.toString())?.value}has(e){return this.map.has(e.toString())}set(e,t){this.map.set(e.toString(),{key:e,value:t})}keys(){return ys(this.map.values(),e=>e.key)}values(){return ys(this.map.values(),e=>e.value)}get size(){return this.map.size}};var gs=class{filter;constructor(e,t){this.filter=Gr(e,t)}has(e){return this.filter.has(e.toMultihash().bytes)}add(e){this.filter.add(e.toMultihash().bytes)}remove(e){this.filter.remove?.(e.toMultihash().bytes)}};function Rc(r,e=.001){return new gs(r,e)}var Oc=class extends Kt{metric;constructor(e){super();let{name:t,metrics:n}=e;this.metric=n.registerMetric(t),this.updateComponentMetric()}set(e,t){return super.set(e,t),this.updateComponentMetric(),this}delete(e){let t=super.delete(e);return this.updateComponentMetric(),t}clear(){super.clear(),this.updateComponentMetric()}updateComponentMetric(){this.metric.update(this.size)}};function Pc(r){let{name:e,metrics:t}=r,n;return t!=null?n=new Oc({name:e,metrics:t}):n=new Kt,n}var Nc=class extends Error{type;code;constructor(e,t,n){super(e??"The operation was aborted"),this.type="aborted",this.name=n??"AbortError",this.code=t??"ABORT_ERR"}};function dd(r,e){let t=new Nc(e?.errorMessage,e?.errorCode,e?.errorName),n=new AbortController,s=()=>{n.abort(t)},o=AbortSignal.timeout(r);o.addEventListener("abort",s);let i=n.signal;return i.reset=a=>{o?.removeEventListener("abort",s),o=AbortSignal.timeout(a??r),o.addEventListener("abort",()=>{n.abort(t)})},i.clear=()=>{o?.removeEventListener("abort",s),o=void 0},i}var bs=class{reservations;maxReservations;applyDefaultLimit;reservationTtl;defaultDurationLimit;defaultDataLimit;log;constructor(e,t={}){this.log=e.logger.forComponent("libp2p:circuit-relay:server:reservation-store"),this.maxReservations=t.maxReservations??td,this.applyDefaultLimit=t.applyDefaultLimit!==!1,this.reservationTtl=t.reservationTtl??rd,this.defaultDurationLimit=t.defaultDurationLimit??sd,this.defaultDataLimit=t.defaultDataLimit??id,this.reservations=Pc({metrics:e.metrics,name:"libp2p_circuit_relay_server_reservations_total"})}reserve(e,t,n){let s=this.reservations.get(e);if(this.reservations.size>=this.maxReservations&&s==null)return{status:F.RESERVATION_REFUSED};let o=new Date(Date.now()+this.reservationTtl),i;return this.applyDefaultLimit&&(i=n??{data:this.defaultDataLimit,duration:this.defaultDurationLimit}),s!=null?(this.log("refreshing reservation for client %p",e),s.signal.reset(this.reservationTtl)):(this.log("creating new reservation for client %p",e),s={addr:t,expiry:o,limit:i,signal:dd(this.reservationTtl)}),this.reservations.set(e,s),s.signal.addEventListener("abort",()=>{this.reservations.delete(e)}),{status:F.OK,expire:Math.round(o.getTime()/1e3)}}removeReservation(e){this.reservations.delete(e)}get(e){return this.reservations.get(e)}clear(){this.reservations.clear()}};var ws=class r{domain="libp2p-relay-rsvp";codec=new Uint8Array([3,2]);relay;peer;expiration;constructor({relay:e,peer:t,expiration:n}){this.relay=e,this.peer=t,this.expiration=n}marshal(){return dr.encode({relay:this.relay.toMultihash().bytes,peer:this.peer.toMultihash().bytes,expiration:BigInt(this.expiration)})}equals(e){return!(!(e instanceof r)||!this.peer.equals(e.peer)||!this.relay.equals(e.relay)||this.expiration!==e.expiration)}};var Iy={maxOutboundStopStreams:Kn},xs=class extends Ie{components;reservationStore;started;hopTimeout;shutdownController;maxInboundHopStreams;maxOutboundHopStreams;maxOutboundStopStreams;log;constructor(e,t={}){super(),this.log=e.logger.forComponent("libp2p:circuit-relay:server"),this.components=e,this.started=!1,this.hopTimeout=t?.hopTimeout??ad,this.maxInboundHopStreams=t.maxInboundHopStreams,this.maxOutboundHopStreams=t.maxOutboundHopStreams,this.maxOutboundStopStreams=t.maxOutboundStopStreams??Iy.maxOutboundStopStreams,this.reservationStore=new bs(e,t.reservations),this.shutdownController=new AbortController,this.shutdownController.signal,this.onHop=this.onHop.bind(this)}[Symbol.toStringTag]="@libp2p/circuit-relay-v2-server";isStarted(){return this.started}async start(){this.started||(await this.components.registrar.handle(Ke,this.onHop,{maxInboundStreams:this.maxInboundHopStreams,maxOutboundStreams:this.maxOutboundHopStreams,runOnLimitedConnection:!0}),this.started=!0)}async stop(){this.reservationStore.clear(),this.shutdownController.abort(),await this.components.registrar.unhandle(Ke),this.started=!1}async onHop(e,t){this.log("received circuit v2 hop protocol stream from %p",t.remotePeer);let n=AbortSignal.timeout(this.hopTimeout);let s={signal:n},o=kt(e);try{let i=await o.pb(Y).read(s);if(i?.type==null)throw new Error("request was invalid, could not read from stream");this.log("received",i.type),await this.handleHopProtocol({connection:t,stream:o,request:i},s)}catch(i){this.log.error("error while handling hop - %e",i),await o.pb(Y).write({type:Y.Type.STATUS,status:F.MALFORMED_MESSAGE},s),e.abort(i)}}async handleHopProtocol({stream:e,request:t,connection:n},s){switch(this.log("received hop message"),t.type){case Y.Type.RESERVE:await this.handleReserve({stream:e,request:t,connection:n},s);break;case Y.Type.CONNECT:await this.handleConnect({stream:e,request:t,connection:n},s);break;default:this.log.error("invalid hop request type %s via peer %p",t.type,n.remotePeer),await e.pb(Y).write({type:Y.Type.STATUS,status:F.UNEXPECTED_MESSAGE})}}async handleReserve({stream:e,connection:t},n){let s=e.pb(Y);if(this.log("hop reserve request from %p",t.remotePeer),ur.exactMatch(t.remoteAddr)){this.log.error("relay reservation over circuit connection denied for peer: %p",t.remotePeer),await s.write({type:Y.Type.STATUS,status:F.PERMISSION_DENIED},n);return}if(await this.components.connectionGater.denyInboundRelayReservation?.(t.remotePeer)===!0){this.log.error("reservation for %p denied by connection gater",t.remotePeer),await s.write({type:Y.Type.STATUS,status:F.PERMISSION_DENIED},n);return}let o=this.reservationStore.reserve(t.remotePeer,t.remoteAddr);try{if(o.status!==F.OK){await s.write({type:Y.Type.STATUS,status:o.status},n);return}if(o.expire!=null){let i=o.expire*1e3-Date.now();await this.components.peerStore.merge(t.remotePeer,{tags:{[Cc]:{value:1,ttl:i}}},n)}await s.write({type:Y.Type.STATUS,status:F.OK,reservation:await this.makeReservation(t.remotePeer,BigInt(o.expire??0)),limit:this.reservationStore.get(t.remotePeer)?.limit},n),this.log("sent confirmation response to %s",t.remotePeer),await s.unwrap().unwrap().close(n)}catch(i){this.log.error("failed to send confirmation response to %p - %e",t.remotePeer,i),this.reservationStore.removeReservation(t.remotePeer);try{await this.components.peerStore.merge(t.remotePeer,{tags:{[Cc]:void 0}},n)}catch(a){this.log.error("failed to untag relay source peer %p - %e",t.remotePeer,a)}}}async makeReservation(e,t){let n=[];for(let o of this.components.addressManager.getAddresses())o.toString().includes("/p2p-circuit")||n.push(o.bytes);let s=await Pn.seal(new ws({peer:e,relay:this.components.peerId,expiration:t}),this.components.privateKey);return{addrs:n,expire:t,voucher:{publicKey:Qe(s.publicKey),payloadType:s.payloadType,payload:{peer:e.toMultihash().bytes,relay:this.components.peerId.toMultihash().bytes,expiration:t},signature:s.signature}}}async handleConnect({stream:e,request:t,connection:n},s){let o=e.pb(Y);if(ur.matches(n.remoteAddr)){this.log.error("relay reservation over circuit connection denied for peer: %p",n.remotePeer),await o.write({type:Y.Type.STATUS,status:F.PERMISSION_DENIED},s);return}this.log("hop connect request from %p",n.remotePeer);let i;try{if(t.peer==null)throw this.log.error("no peer info in hop connect request"),new Error("no peer info in request");t.peer.addrs.forEach(ke),i=zr(Xe(t.peer.id))}catch(f){this.log.error("invalid hop connect request via peer %p - %e",n.remotePeer,f),await o.write({type:Y.Type.STATUS,status:F.MALFORMED_MESSAGE},s);return}let a=this.reservationStore.get(i);if(a==null){this.log.error("hop connect denied for destination peer %p not having a reservation for %p with status %s",i,n.remotePeer,F.NO_RESERVATION),await o.write({type:Y.Type.STATUS,status:F.NO_RESERVATION},s);return}if(await this.components.connectionGater.denyOutboundRelayedConnection?.(n.remotePeer,i)===!0){this.log.error("hop connect for %p to %p denied by connection gater",n.remotePeer,i),await o.write({type:Y.Type.STATUS,status:F.PERMISSION_DENIED},s);return}let c=this.components.connectionManager.getConnections(i);if(c.length===0){this.log("hop connect denied for destination peer %p not having a connection for %p as there is no destination connection",i,n.remotePeer),await o.write({type:Y.Type.STATUS,status:F.NO_RESERVATION},s);return}let u=c[0],l=await this.stopHop({connection:u,request:{type:Fe.Type.CONNECT,peer:{id:n.remotePeer.toMultihash().bytes,addrs:[]},limit:a?.limit}},s);if(l==null){this.log.error("failed to open stream to destination peer %p",u?.remotePeer),await o.write({type:Y.Type.STATUS,status:F.CONNECTION_FAILED},s);return}await o.write({type:Y.Type.STATUS,status:F.OK,limit:a?.limit},s),this.log("connection from %p to %p established - merging streams",n.remotePeer,i),fd(e.unwrap(),l,this.shutdownController.signal,a,{log:this.log})}async stopHop({connection:e,request:t},n){this.log("starting circuit relay v2 stop request to %s",e.remotePeer);let s=await e.newStream(fr,{maxOutboundStreams:this.maxOutboundStopStreams,runOnLimitedConnection:!0,...n}),o=kt(s),i=o.pb(Fe);await i.write(t,n);let a;try{a=await i.read(n)}catch(c){this.log.error("error parsing stop message response from %p - %e",e.remotePeer,c)}if(a==null){this.log.error("could not read response from %p",e.remotePeer),await s.close(n);return}if(a.status===F.OK)return this.log("stop request to %p was successful",e.remotePeer),o.unwrap();this.log("stop request failed with code %d",a.status),await s.close(n)}get reservations(){return this.reservationStore.reservations}};var qt=class extends Event{type;detail;constructor(e,t){super(e),this.type=e,this.detail=t}};var Es=class extends Ie{components;started;running;topologyId;log;discoveryController;filter;queue;constructor(e,t={}){super(),this.log=e.logger.forComponent("libp2p:circuit-relay:discover-relays"),this.components=e,this.started=!1,this.running=!1,this.filter=t.filter,this.discoveryController=new AbortController,this.discoveryController.signal,this.dialPeer=this.dialPeer.bind(this),this.onPeer=this.onPeer.bind(this)}isStarted(){return this.started}async start(){this.topologyId=await this.components.registrar.register(Ke,{filter:this.filter,onConnect:e=>{this.log.trace("discovered relay %p queue (length: %d, active %d)",e,this.queue?.size,this.queue?.running),this.safeDispatchEvent("relay:discover",{detail:e})}}),this.started=!0}stop(){this.topologyId!=null&&this.components.registrar.unregister(this.topologyId),this.running&&this.stopDiscovery(),this.started=!1}startDiscovery(){this.running||(this.log("start discovery"),this.running=!0,this.discoveryController=new AbortController,this.discoveryController.signal,this.components.events.addEventListener("peer:discovery",this.onPeer),Promise.resolve().then(async()=>{this.log("searching peer store for relays");let e=await this.components.peerStore.all({filters:[n=>n.protocols.includes(Ke)],orders:[()=>Math.random()<.5?1:-1,(n,s)=>{let o=hd(n),i=hd(s);return o>i?-1:i>o?1:0}]});for(let n of e)this.log.trace("found relay peer %p in peer store",n.id),this.safeDispatchEvent("relay:discover",{detail:n.id});this.log("found %d relay peers in peer store",e.length);let t=this.queue=new Xr({concurrency:5});this.log("start random walk");for await(let n of this.components.randomWalk.walk({signal:this.discoveryController.signal})){if(this.log.trace("found random peer %p",n.id),t.has(n.id)){this.log.trace("random peer %p was already in queue",n.id);continue}if(this.components.connectionManager.getConnections(n.id)?.length>0){this.log.trace("random peer %p was already connected",n.id);continue}if(!await this.components.connectionManager.isDialable(n.multiaddrs)){this.log.trace("random peer %p was not dialable",n.id,n.multiaddrs.map(s=>s.toString()));continue}t.queued>10&&(this.log.trace("wait for space in queue for %p",n.id),await t.onSizeLessThan(10,{signal:this.discoveryController.signal})),this.log("adding random peer %p to dial queue (length: %d, active %d)",n.id,t.size,t.running),t.add(this.dialPeer,{peerId:n.id,signal:this.discoveryController.signal}).catch(s=>{this.log.error("error opening connection to random peer %p - %e",n.id,s)})}this.log("stop random walk"),await t.onIdle()}).catch(e=>{this.discoveryController.signal.aborted||this.log.error("failed when finding relays on the network - %e",e)}))}stopDiscovery(){this.log("stop discovery"),this.running=!1,this.discoveryController?.abort(),this.queue?.clear(),this.components.events.removeEventListener("peer:discovery",this.onPeer)}onPeer(e){this.log.trace("maybe dialing discovered peer %p",e.detail.id),this.maybeDialPeer(e).catch(t=>{this.log.trace("error dialing discovered peer %p - %e",e.detail.id,t)})}async maybeDialPeer(e){if(this.queue==null)return;let t=e.detail.id,n=e.detail.multiaddrs;if(this.queue.has(t)){this.log.trace("random peer %p was already in queue",t);return}if(this.components.connectionManager.getConnections(t)?.length>0){this.log.trace("random peer %p was already connected",t);return}if(!await this.components.connectionManager.isDialable(n)){this.log.trace("random peer %p was not dialable",t);return}this.queue?.add(this.dialPeer,{peerId:e.detail.id,signal:this.discoveryController.signal}).catch(s=>{this.log.error("error opening connection to discovered peer %p - %e",e.detail.id,s)})}async dialPeer({peerId:e,signal:t}){let n=as([AbortSignal.timeout(5e3),t]);try{await this.components.connectionManager.openConnection(e,{signal:n})}finally{n.clear()}}};function hd(r){let e=r.metadata.get("last-dial-success");return e==null?0:new Date(V(e)).getTime()}var kc=class extends Ie{connectionManager;addressManager;reservationStore;listeningAddrs;log;listenTimeout;reservationId;relay;constructor(e,t={}){super(),this.log=e.logger.forComponent("libp2p:circuit-relay:transport:listener"),this.connectionManager=e.connectionManager,this.addressManager=e.addressManager,this.reservationStore=e.reservationStore,this.listeningAddrs=[],this.listenTimeout=t.listenTimeout??us,this.reservationStore.addEventListener("relay:removed",this._onRemoveRelayPeer),this.reservationStore.addEventListener("relay:created-reservation",this._onAddRelayPeer)}_onRemoveRelayPeer=e=>{this.log("relay removed %p our relay %p",e.detail.relay,this.relay,this.relay?.equals(e.detail.relay)),this.relay?.equals(e.detail.relay)===!0&&(this.log("relay peer removed %p",e.detail.relay),this.listeningAddrs.forEach(t=>{this.addressManager.removeObservedAddr(t)}),this.listeningAddrs=[],this.safeDispatchEvent("listening"))};_onAddRelayPeer=e=>{let{details:t}=e.detail;t.type!=="configured"&&t.id===this.reservationId&&this.addedRelay(e.detail)};async listen(e){if(ms.exactMatch(e))this.log("searching for circuit relay servers"),this.reservationId=this.reservationStore.reserveRelay();else if(ps.exactMatch(e)){this.log("listen on specific relay server %a",e);let t=AbortSignal.timeout(this.listenTimeout);let n=e.decapsulate("/p2p-circuit"),s=await this.connectionManager.openConnection(n,{signal:t});if(!this.reservationStore.hasReservation(s.remotePeer)){this.log("making reservation on peer %p",s.remotePeer);let o=await this.reservationStore.addRelay(s.remotePeer,"configured");this.addedRelay(o)}}else throw new zt(`Could not listen on p2p-circuit address "${e}"`)}getAddrs(){return[...this.listeningAddrs.values()].flat()}updateAnnounceAddrs(){}async close(){this.reservationStore.cancelReservations(),this.listeningAddrs=[],this.reservationStore.removeEventListener("relay:removed",this._onRemoveRelayPeer),queueMicrotask(()=>{this.safeDispatchEvent("close")})}addedRelay(e){this.log("relay peer added %p",e.relay),this.relay=e.relay,this.listeningAddrs=e.details.reservation.addrs.map(t=>ke(t).encapsulate("/p2p-circuit")),this.listeningAddrs.forEach(t=>{this.addressManager.confirmObservedAddr(t,{type:"transport"})}),queueMicrotask(()=>{this.safeDispatchEvent("listening")})}};function pd(r){return new kc(r)}var md="useandom-26T198340PX75pxJACKVERYMINDBUSHWOLF_GQZbfghjklqvwyzrict";var yd=(r=21)=>{let e="",t=crypto.getRandomValues(new Uint8Array(r|=0));for(;r--;)e+=md[t[r]&63];return e};var Cy=60*1e3*10,Ly=60*1e3*5,By=30*1e3,Ss=class extends Ie{peerId;connectionManager;peerStore;events;reserveQueue;reservations;pendingReservations;maxReservationQueueLength;reservationCompletionTimeout;started;log;relayFilter;constructor(e,t){super(),this.log=e.logger.forComponent("libp2p:circuit-relay:transport:reservation-store"),this.peerId=e.peerId,this.connectionManager=e.connectionManager,this.peerStore=e.peerStore,this.events=e.events,this.reservations=new Kt,this.pendingReservations=[],this.maxReservationQueueLength=t?.maxReservationQueueLength??od,this.reservationCompletionTimeout=t?.reservationCompletionTimeout??us,this.started=!1,this.relayFilter=Gr(100),this.reserveQueue=new Xr({concurrency:t?.reservationConcurrency??nd,metricName:"libp2p_relay_reservation_queue",metrics:e.metrics}),this.events.addEventListener("connection:close",n=>{[...this.reservations.values()].find(o=>o.connection===n.detail.id)!=null&&this.#t(n.detail.remotePeer).catch(o=>{this.log("could not remove relay %p - %e",n.detail,o)})})}isStarted(){return this.started}start(){this.started=!0}afterStart(){Promise.resolve().then(async()=>{let e=await this.peerStore.all({filters:[t=>t.tags.has(Mn)]});this.log("removing tag from %d old relays",e.length),await Promise.all(e.map(async t=>{await this.peerStore.merge(t.id,{tags:{[Mn]:void 0}})})),this.log("redialing %d old relays",e.length),await Promise.all(e.map(async t=>this.addRelay(t.id,"discovered"))),this.#r()}).catch(e=>{this.log.error("failed to clean up and redial old relays during afterStart - %e",e)})}stop(){this.reserveQueue.clear(),this.reservations.forEach(({timeout:e})=>{clearTimeout(e)}),this.reservations.clear(),this.started=!1}reserveRelay(){let e=yd();return this.pendingReservations.push(e),this.#r(),e}async addRelay(e,t){if(this.peerId.equals(e))throw this.log.trace("not trying to use self as relay"),new zt("Cannot use self as relay");if(this.reserveQueue.size>this.maxReservationQueueLength)throw new hs("The reservation queue is full");let n=this.reserveQueue.find(e);if(n!=null)return this.log.trace("potential relay peer %p is already in the reservation queue",e),n.join();if(this.relayFilter.has(e.toMultihash().bytes))throw new zt("The relay was previously invalid");return this.log.trace("try to reserve relay slot with %p",e),this.reserveQueue.add(async()=>{let s=Date.now();try{let o=this.reservations.get(e);if(o!=null){let p=this.connectionManager.getConnections(e),b=!1;if(p.length===0&&this.log("already have relay reservation with %p but we are no longer connected",e),p.map(h=>h.id).includes(o.connection)&&(this.log("already have relay reservation with %p and the original connection is still open",e),b=!0),b&&Bc(o.reservation.expire)>Cy)return this.log("already have relay reservation with %p but we are still connected and it does not expire soon",e),{relay:e,details:o};await this.#t(e)}if(t==="discovered"&&this.pendingReservations.length===0)throw new Vn("Not making reservation on discovered relay because we do not need any more relays");let i=AbortSignal.timeout(this.reservationCompletionTimeout);let a=await this.connectionManager.openConnection(e,{signal:i});if(ur.matches(a.remoteAddr))throw new ds("not creating reservation over relayed connection");let c=await this.#e(a,{signal:i}),u=Bc(c.expire);this.log("created reservation on relay peer %p, expiry date is %s",e,new Date(Date.now()+u).toString());let l=Math.min(Math.max(u-Ly,By),Math.pow(2,31)-1),f=setTimeout(()=>{this.log("refresh reservation to relay %p",e),this.addRelay(e,t).catch(async p=>{this.log.error("could not refresh reservation to relay %p - %e",e,p),await this.#t(e)}).catch(p=>{this.log.error("could not remove expired reservation to relay %p - %e",e,p)})},l),m;if(t==="discovered"){let p=this.pendingReservations.pop();if(p==null)throw new Vn("Made reservation on relay but did not need any more discovered relays");m={timeout:f,reservation:c,type:t,connection:a.id,id:p}}else m={timeout:f,reservation:c,type:t,connection:a.id};this.reservations.set(e,m),await this.peerStore.merge(e,{tags:{[Mn]:{value:1,ttl:u}}}),this.#r();let d={relay:e,details:m};return this.safeDispatchEvent("relay:created-reservation",{detail:d}),d}catch(o){throw t==="discovered"&&o.name==="HadEnoughRelaysError"||this.log.error("could not reserve slot on %p after %dms - %e",e,Date.now()-s,o),(o.name==="DialError"||o.name==="UnsupportedProtocolError")&&this.relayFilter.add(e.toMultihash().bytes),this.#t(e).catch(i=>{this.log.error("could not remove reservation on %p after reserving slot failed - %e",e,i)}),o}},{peerId:e})}hasReservation(e){return this.reservations.has(e)}getReservation(e){return this.reservations.get(e)?.reservation}reservationCount(e){return e==null?this.reservations.size:[...this.reservations.values()].reduce((t,n)=>(n.type===e&&t++,t),0)}cancelReservations(){[...this.reservations.values()].forEach(e=>{clearTimeout(e.timeout)}),this.reservations.clear()}async#e(e,t){t.signal?.throwIfAborted(),this.log("requesting reservation from %p",e.remotePeer);let n=await e.newStream(Ke,t),o=kt(n).pb(Y);this.log.trace("send RESERVE to %p",e.remotePeer),await o.write({type:Y.Type.RESERVE},t);let i;try{this.log.trace("reading response from %p",e.remotePeer),i=await o.read(t)}catch(c){throw n.abort(c),c}finally{n.status!=="closed"&&await n.close(t)}if(this.log.trace("read response %s",i.status),i.status===F.OK&&i.reservation!=null){let c=new Set;c.add(e.remoteAddr.toString());for(let u of i.reservation.addrs){let l=ke(u);l.getComponents().find(f=>f.code===421)==null&&(l=l.encapsulate(`/p2p/${e.remotePeer}`)),l=ke(l.toString().replace(`/p2p/${e.remotePeer}/p2p/${e.remotePeer}`,`/p2p/${e.remotePeer}`)),c.add(l.toString())}return i.reservation.addrs=[...c].map(u=>ke(u).bytes),i.reservation}let a=`reservation failed with status ${i.status??"undefined"}`;throw this.log.error(a),new Error(a)}async#t(e){let t=this.reservations.get(e);t!=null&&(this.log("removing relay reservation with %p from local store",e),clearTimeout(t.timeout),this.reservations.delete(e),t.type==="discovered"&&this.pendingReservations.push(t.id),await this.peerStore.merge(e,{tags:{[Mn]:void 0}}),this.safeDispatchEvent("relay:removed",{detail:{relay:e,details:t}}),this.#r())}#r(){if(this.pendingReservations.length===0){this.log.trace("have discovered enough relays"),this.reserveQueue.clear(),this.safeDispatchEvent("relay:found-enough-relays");return}this.relayFilter=Gr(100),this.log("not discovered enough relays %d/%d",this.reservations.size,this.pendingReservations.length),this.safeDispatchEvent("relay:not-enough-relays")}};var Fc=class extends is{stream;init;constructor(e){super({...e,direction:e.stream.direction}),this.init=e,this.stream=e.stream,this.stream.addEventListener("close",t=>{this.onTransportClosed(t.error)}),this.stream.addEventListener("remoteCloseWrite",t=>{this.onRemoteCloseWrite(),this.close().catch(n=>{this.abort(n)})}),this.stream.addEventListener("message",t=>{e.onDataRead?.(t.data),this.onData(t.data)}),this.stream.addEventListener("drain",()=>{this.safeDispatchEvent("drain")})}sendData(e){return this.init.onDataWrite?.(e),{sentBytes:e.byteLength,canSendMore:this.stream.send(e)}}async sendClose(e){await this.stream.close(e)}sendReset(){this.stream.abort(new Error("An error occurred"))}sendPause(){this.stream.pause()}sendResume(){this.stream.resume()}};function Mc(r){return new Fc(r)}var Ry=r=>{if(r.peer==null)return!1;try{r.peer.addrs.forEach(ke)}catch{return!1}return!0},gd={maxInboundStopStreams:Kn,maxOutboundStopStreams:Kn,stopTimeout:3e4},vs=class{components;discovery;reservationStore;maxInboundStopStreams;maxOutboundStopStreams;started;log;shutdownController;constructor(e,t={}){this.components=e,this.log=e.logger.forComponent("libp2p:circuit-relay:transport"),this.maxInboundStopStreams=t.maxInboundStopStreams??gd.maxInboundStopStreams,this.maxOutboundStopStreams=t.maxOutboundStopStreams??gd.maxOutboundStopStreams,this.shutdownController=new AbortController,this.discovery=new Es(e,{filter:t.discoveryFilter??Rc(cd,ud)}),this.discovery.addEventListener("relay:discover",n=>{this.reservationStore.addRelay(n.detail,"discovered").catch(s=>{s.name!=="HadEnoughRelaysError"&&s.name!=="RelayQueueFullError"&&this.log.error("could not add discovered relay %p - %e",n.detail,s)})}),this.reservationStore=new Ss(e,t),this.reservationStore.addEventListener("relay:not-enough-relays",()=>{this.discovery?.startDiscovery()}),this.reservationStore.addEventListener("relay:found-enough-relays",()=>{this.discovery?.stopDiscovery()}),this.started=!1,this.onStop=this.onStop.bind(this)}[Symbol.toStringTag]="@libp2p/circuit-relay-v2-transport";[Gc]=["@libp2p/transport","@libp2p/circuit-relay-v2-transport"];get[Yc](){return this.discovery!=null?["@libp2p/identify"]:[]}[Wc]=!0;isStarted(){return this.started}async start(){this.shutdownController=new AbortController,this.shutdownController.signal,await this.components.registrar.handle(fr,this.onStop,{maxInboundStreams:this.maxInboundStopStreams,maxOutboundStreams:this.maxOutboundStopStreams,runOnLimitedConnection:!0}),await Hc(this.discovery,this.reservationStore),this.started=!0}async stop(){this.shutdownController.abort(),await $c(this.discovery,this.reservationStore),await this.components.registrar.unhandle(fr),this.started=!1}async dial(e,t){let n=e.toString().split("/p2p-circuit"),s=ke(n[0]),o=ke(n[n.length-1]),i=s.getComponents().find(d=>d.code===421)?.value,a=o.getComponents().find(d=>d.code===421)?.value;if(i==null||a==null){let d=`ircuit relay dial to ${e.toString()} failed as address did not have both relay and destination PeerIDs`;throw this.log.error(`c${d}`),new Zn(`C${d}`)}let c=Pa(i),u=Pa(a),f=this.components.connectionManager.getConnections(c)[0];f==null?(await this.components.peerStore.merge(c,{multiaddrs:[s]}),t.onProgress?.(new qt("circuit-relay:open-connection")),f=await this.components.connectionManager.openConnection(c,t)):t.onProgress?.(new qt("circuit-relay:reuse-connection"));let m;try{t.onProgress?.(new qt("circuit-relay:open-hop-stream")),m=await f.newStream(Ke,t);let d=kt(m).pb(Y);t.onProgress?.(new qt("circuit-relay:write-connect-message")),await d.write({type:Y.Type.CONNECT,peer:{id:u.toMultihash().bytes,addrs:[ke(o).bytes]}},t),t.onProgress?.(new qt("circuit-relay:read-connect-response"));let p=await d.read(t);if(p.status!==F.OK)throw new Yn(`failed to connect via relay with status ${p?.status?.toString()??"undefined"}`);let b=new Hn(p.limit),h=Mc({stream:d.unwrap().unwrap(),remoteAddr:e,localAddr:s.encapsulate(`/p2p-circuit/p2p/${this.components.peerId.toString()}`),onDataRead:b.onData,onDataWrite:b.onData,log:m.log.newScope("circuit-relay:connection")}),g=await this.components.upgrader.upgradeOutbound(h,{...t,limits:b.getLimits()});return g.log("outbound relayed connection established to %p with limits %o, over connection %s",g.remotePeer,p.limit??"none",f.id),g}catch(d){throw this.log.error("circuit relay dial to destination %p via relay %p failed - %e",u,c,d),m?.abort(d),d}}createListener(e){return pd({peerId:this.components.peerId,connectionManager:this.components.connectionManager,addressManager:this.components.addressManager,reservationStore:this.reservationStore,logger:this.components.logger})}listenFilter(e){return e=Array.isArray(e)?e:[e],e.filter(t=>ps.exactMatch(t)||ms.exactMatch(t))}dialFilter(e){return e=Array.isArray(e)?e:[e],e.filter(t=>ur.exactMatch(t))}async onStop(e,t){let n=this.components.upgrader.createInboundAbortSignal(this.shutdownController.signal);try{if(!this.reservationStore.hasReservation(t.remotePeer))try{this.log("dialed via relay we did not have a reservation on, start listening on that relay address"),await this.components.transportManager.listen([t.remoteAddr.encapsulate("/p2p-circuit")])}catch(f){this.log.error("failed to listen on a relay peer we were dialed via but did not have a reservation on - %e",f)}let s=kt(e).pb(Fe),o=await s.read({signal:n});if(this.log("new circuit relay v2 stop stream from %p with type %s",t.remotePeer,o.type),o?.type===void 0){this.log.error("type was missing from circuit v2 stop protocol request from %s",t.remotePeer),await s.write({type:Fe.Type.STATUS,status:F.MALFORMED_MESSAGE},{signal:n}),await e.close({signal:n});return}if(o.type!==Fe.Type.CONNECT){this.log.error("invalid stop connect request via peer %p",t.remotePeer),await s.write({type:Fe.Type.STATUS,status:F.UNEXPECTED_MESSAGE},{signal:n}),await e.close({signal:n});return}if(!Ry(o)){this.log.error("invalid stop connect request via peer %p",t.remotePeer),await s.write({type:Fe.Type.STATUS,status:F.MALFORMED_MESSAGE},{signal:n}),await e.close({signal:n});return}let i=zr(Xe(o.peer.id));if(await this.components.connectionGater.denyInboundRelayedConnection?.(t.remotePeer,i)===!0){this.log.error("connection gater denied inbound relayed connection from %p",t.remotePeer),await s.write({type:Fe.Type.STATUS,status:F.PERMISSION_DENIED},{signal:n}),await e.close({signal:n});return}this.log.trace("sending success response to %p",t.remotePeer),await s.write({type:Fe.Type.STATUS,status:F.OK},{signal:n});let a=new Hn(o.limit),c=t.remoteAddr.encapsulate(`/p2p-circuit/p2p/${i.toString()}`),u=this.components.addressManager.getAddresses()[0],l=Mc({stream:s.unwrap().unwrap(),remoteAddr:c,localAddr:u,onDataRead:a.onData,onDataWrite:a.onData,log:e.log.newScope("circuit-relay:connection")});await this.components.upgrader.upgradeInbound(l,{limits:a.getLimits(),signal:n}),l.log("inbound relayed connection established to %p with limits %o, over connection %s",i,o.limit??"none",t.id)}finally{n?.clear()}}};function Oy(r={}){return e=>new xs(e,r)}function Py(r={}){return e=>new vs(e,r)}return Sd(Ny);})();
|
|
2
|
+
"use strict";var Libp2PCircuitRelayV2=(()=>{var ns=Object.defineProperty;var jl=Object.getOwnPropertyDescriptor;var Gl=Object.getOwnPropertyNames;var Yl=Object.prototype.hasOwnProperty;var Te=(r,e)=>{for(var t in e)ns(r,t,{get:e[t],enumerable:!0})},Zl=(r,e,t,n)=>{if(e&&typeof e=="object"||typeof e=="function")for(let s of Gl(e))!Yl.call(r,s)&&s!==t&&ns(r,s,{get:()=>e[s],enumerable:!(n=jl(e,s))||n.enumerable});return r};var Xl=r=>Zl(ns({},"__esModule",{value:!0}),r);var Zp={};Te(Zp,{RELAY_V2_HOP_CODEC:()=>Fe,RELAY_V2_STOP_CODEC:()=>nr,circuitRelayServer:()=>Gp,circuitRelayTransport:()=>Yp});function Ql(r){return typeof r?.handleEvent=="function"}function Jl(r){return(r!==!0&&r!==!1&&r?.once)??!1}var Ie=class extends EventTarget{#e=new Map;constructor(){super()}listenerCount(e){let t=this.#e.get(e);return t==null?0:t.length}addEventListener(e,t,n){let s=Jl(n);super.addEventListener(e,i=>{if(s){let a=this.#e.get(i.type);a!=null&&(a=a.filter(({callback:c})=>c!==t),this.#e.set(i.type,a))}Ql(t)?t.handleEvent(i):t(i)},n);let o=this.#e.get(e);o==null&&(o=[],this.#e.set(e,o)),o.push({callback:t,once:s})}removeEventListener(e,t,n){super.removeEventListener(e.toString(),t??null,n);let s=this.#e.get(e);s!=null&&(s=s.filter(({callback:o})=>o!==t),this.#e.set(e,s))}safeDispatchEvent(e,t={}){return this.dispatchEvent(new CustomEvent(e,t))}};var ot=class extends Error{static name="AbortError";constructor(e="The operation was aborted"){super(e),this.name="AbortError"}};var oe=class extends Error{static name="InvalidParametersError";constructor(e="Invalid parameters"){super(e),this.name="InvalidParametersError"}},ir=class extends Error{static name="InvalidPublicKeyError";constructor(e="Invalid public key"){super(e),this.name="InvalidPublicKeyError"}};var In=class extends Error{static name="StreamResetError";constructor(e="The stream has been reset"){super(e),this.name="StreamResetError"}};var yt=class extends Error{static name="StreamStateError";constructor(e="The stream is in an invalid state"){super(e),this.name="StreamStateError"}},Fr=class extends Error{static name="StreamBufferError";constructor(e="The stream buffer was full"){super(e),this.name="StreamBufferError"}};var Dn=class extends Error{static name="InvalidCIDError";constructor(e="Invalid CID"){super(e),this.name="InvalidCIDError"}},Cn=class extends Error{static name="InvalidMultihashError";constructor(e="Invalid Multihash"){super(e),this.name="InvalidMultihashError"}};var Ln=class extends Error{static name="InvalidMessageError";constructor(e="Invalid message"){super(e),this.name="InvalidMessageError"}};var Bn=class extends Error{static name="DialError";constructor(e="Dial error"){super(e),this.name="DialError"}},kt=class extends Error{static name="ListenError";constructor(e="Listen error"){super(e),this.name="ListenError"}};var ar=class extends Error{static name="UnsupportedKeyTypeError";constructor(e="Unsupported key type"){super(e),this.name="UnsupportedKeyTypeError"}};var Rn=class extends Event{data;constructor(e,t){super("message",t),this.data=e}},cr=class extends Event{error;local;constructor(e,t,n){super("close",n),this.error=t,this.local=e}},On=class extends cr{constructor(e,t){super(!0,e,t)}},Pn=class extends cr{constructor(e,t){super(!1,e,t)}};var os=Symbol.for("@libp2p/peer-id");var Wa="keep-alive";function ja(r){return r!=null&&typeof r.start=="function"&&typeof r.stop=="function"}async function Ga(...r){let e=[];for(let t of r)ja(t)&&e.push(t);await Promise.all(e.map(async t=>{t.beforeStart!=null&&await t.beforeStart()})),await Promise.all(e.map(async t=>{await t.start()})),await Promise.all(e.map(async t=>{t.afterStart!=null&&await t.afterStart()}))}async function Ya(...r){let e=[];for(let t of r)ja(t)&&e.push(t);await Promise.all(e.map(async t=>{t.beforeStop!=null&&await t.beforeStop()})),await Promise.all(e.map(async t=>{await t.stop()})),await Promise.all(e.map(async t=>{t.afterStop!=null&&await t.afterStop()}))}var Xa=Symbol.for("@libp2p/transport");var Za;(function(r){r[r.FATAL_ALL=0]="FATAL_ALL",r[r.NO_FATAL=1]="NO_FATAL"})(Za||(Za={}));var Qa=Symbol.for("@libp2p/service-capabilities"),Ja=Symbol.for("@libp2p/service-dependencies");var us={};Te(us,{base58btc:()=>re,base58flickr:()=>cf});var Lm=new Uint8Array(0);function ec(r,e){if(r===e)return!0;if(r.byteLength!==e.byteLength)return!1;for(let t=0;t<r.byteLength;t++)if(r[t]!==e[t])return!1;return!0}function st(r){if(r instanceof Uint8Array&&r.constructor.name==="Uint8Array")return Mt(r);if(r instanceof ArrayBuffer)return new Uint8Array(r);if(ArrayBuffer.isView(r))return Mt(new Uint8Array(r.buffer,r.byteOffset,r.byteLength));throw new Error("Unknown type, must be binary type")}function tc(r){return new TextEncoder().encode(r)}function rc(r){return new TextDecoder().decode(r)}function ef(r){return r?.buffer instanceof ArrayBuffer}function Mt(r){return ef(r)?r:r.slice()}function tf(r,e){if(r.length>=255)throw new TypeError("Alphabet too long");for(var t=new Uint8Array(256),n=0;n<t.length;n++)t[n]=255;for(var s=0;s<r.length;s++){var o=r.charAt(s),i=o.charCodeAt(0);if(t[i]!==255)throw new TypeError(o+" is ambiguous");t[i]=s}var a=r.length,c=r.charAt(0),u=Math.log(a)/Math.log(256),l=Math.log(256)/Math.log(a);function f(y){if(y instanceof Uint8Array||(ArrayBuffer.isView(y)?y=new Uint8Array(y.buffer,y.byteOffset,y.byteLength):Array.isArray(y)&&(y=Uint8Array.from(y))),!(y instanceof Uint8Array))throw new TypeError("Expected Uint8Array");if(y.length===0)return"";for(var x=0,h=0,g=0,S=y.length;g!==S&&y[g]===0;)g++,x++;for(var _=(S-g)*l+1>>>0,B=new Uint8Array(_);g!==S;){for(var C=y[g],N=0,R=_-1;(C!==0||N<h)&&R!==-1;R--,N++)C+=256*B[R]>>>0,B[R]=C%a>>>0,C=C/a>>>0;if(C!==0)throw new Error("Non-zero carry");h=N,g++}for(var I=_-h;I!==_&&B[I]===0;)I++;for(var U=c.repeat(x);I<_;++I)U+=r.charAt(B[I]);return U}function p(y){if(typeof y!="string")throw new TypeError("Expected String");if(y.length===0)return new Uint8Array;var x=0;if(y[x]!==" "){for(var h=0,g=0;y[x]===c;)h++,x++;for(var S=(y.length-x)*u+1>>>0,_=new Uint8Array(S);y[x];){var B=t[y.charCodeAt(x)];if(B===255)return;for(var C=0,N=S-1;(B!==0||C<g)&&N!==-1;N--,C++)B+=a*_[N]>>>0,_[N]=B%256>>>0,B=B/256>>>0;if(B!==0)throw new Error("Non-zero carry");g=C,x++}if(y[x]!==" "){for(var R=S-g;R!==S&&_[R]===0;)R++;for(var I=new Uint8Array(h+(S-R)),U=h;R!==S;)I[U++]=_[R++];return I}}}function d(y){var x=p(y);if(x)return x;throw new Error(`Non-${e} character`)}return{encode:f,decodeUnsafe:p,decode:d}}var rf=tf,nf=rf,oc=nf;var ss=class{name;prefix;baseEncode;constructor(e,t,n){this.name=e,this.prefix=t,this.baseEncode=n}encode(e){if(e instanceof Uint8Array)return`${this.prefix}${this.baseEncode(e)}`;throw Error("Unknown type, must be binary type")}},is=class{name;prefix;baseDecode;prefixCodePoint;constructor(e,t,n){this.name=e,this.prefix=t;let s=t.codePointAt(0);if(s===void 0)throw new Error("Invalid prefix character");this.prefixCodePoint=s,this.baseDecode=n}decode(e){if(typeof e=="string"){if(e.codePointAt(0)!==this.prefixCodePoint)throw Error(`Unable to decode multibase string ${JSON.stringify(e)}, ${this.name} decoder only supports inputs prefixed with ${this.prefix}`);return this.baseDecode(e.slice(this.prefix.length))}else throw Error("Can only multibase decode strings")}or(e){return sc(this,e)}},as=class{decoders;constructor(e){this.decoders=e}or(e){return sc(this,e)}decode(e){let t=e[0],n=this.decoders[t];if(n!=null)return n.decode(e);throw RangeError(`Unable to decode multibase string ${JSON.stringify(e)}, only inputs prefixed with ${Object.keys(this.decoders)} are supported`)}};function sc(r,e){return new as({...r.decoders??{[r.prefix]:r},...e.decoders??{[e.prefix]:e}})}var cs=class{name;prefix;baseEncode;baseDecode;encoder;decoder;constructor(e,t,n,s){this.name=e,this.prefix=t,this.baseEncode=n,this.baseDecode=s,this.encoder=new ss(e,t,n),this.decoder=new is(e,t,s)}encode(e){return this.encoder.encode(e)}decode(e){return this.decoder.decode(e)}};function ur({name:r,prefix:e,encode:t,decode:n}){return new cs(r,e,t,n)}function gt({name:r,prefix:e,alphabet:t}){let{encode:n,decode:s}=oc(t,r);return ur({prefix:e,name:r,encode:n,decode:o=>st(s(o))})}function of(r,e,t,n){let s=r.length;for(;r[s-1]==="=";)--s;let o=new Uint8Array(s*t/8|0),i=0,a=0,c=0;for(let u=0;u<s;++u){let l=e[r[u]];if(l===void 0)throw new SyntaxError(`Non-${n} character`);a=a<<t|l,i+=t,i>=8&&(i-=8,o[c++]=255&a>>i)}if(i>=t||(255&a<<8-i)!==0)throw new SyntaxError("Unexpected end of data");return o}function sf(r,e,t){let n=e[e.length-1]==="=",s=(1<<t)-1,o="",i=0,a=0;for(let c=0;c<r.length;++c)for(a=a<<8|r[c],i+=8;i>t;)i-=t,o+=e[s&a>>i];if(i!==0&&(o+=e[s&a<<t-i]),n)for(;(o.length*t&7)!==0;)o+="=";return o}function af(r){let e={};for(let t=0;t<r.length;++t)e[r[t]]=t;return e}function se({name:r,prefix:e,bitsPerChar:t,alphabet:n}){let s=af(n);return ur({prefix:e,name:r,encode(o){return sf(o,n,t)},decode(o){return of(o,s,t,r)}})}var re=gt({name:"base58btc",prefix:"z",alphabet:"123456789ABCDEFGHJKLMNPQRSTUVWXYZabcdefghijkmnopqrstuvwxyz"}),cf=gt({name:"base58flickr",prefix:"Z",alphabet:"123456789abcdefghijkmnopqrstuvwxyzABCDEFGHJKLMNPQRSTUVWXYZ"});var ls={};Te(ls,{base32:()=>bt,base32hex:()=>df,base32hexpad:()=>pf,base32hexpadupper:()=>mf,base32hexupper:()=>hf,base32pad:()=>lf,base32padupper:()=>ff,base32upper:()=>uf,base32z:()=>yf});var bt=se({prefix:"b",name:"base32",alphabet:"abcdefghijklmnopqrstuvwxyz234567",bitsPerChar:5}),uf=se({prefix:"B",name:"base32upper",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZ234567",bitsPerChar:5}),lf=se({prefix:"c",name:"base32pad",alphabet:"abcdefghijklmnopqrstuvwxyz234567=",bitsPerChar:5}),ff=se({prefix:"C",name:"base32padupper",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZ234567=",bitsPerChar:5}),df=se({prefix:"v",name:"base32hex",alphabet:"0123456789abcdefghijklmnopqrstuv",bitsPerChar:5}),hf=se({prefix:"V",name:"base32hexupper",alphabet:"0123456789ABCDEFGHIJKLMNOPQRSTUV",bitsPerChar:5}),pf=se({prefix:"t",name:"base32hexpad",alphabet:"0123456789abcdefghijklmnopqrstuv=",bitsPerChar:5}),mf=se({prefix:"T",name:"base32hexpadupper",alphabet:"0123456789ABCDEFGHIJKLMNOPQRSTUV=",bitsPerChar:5}),yf=se({prefix:"h",name:"base32z",alphabet:"ybndrfg8ejkmcpqxot1uwisza345h769",bitsPerChar:5});var fs={};Te(fs,{base36:()=>Kr,base36upper:()=>gf});var Kr=gt({prefix:"k",name:"base36",alphabet:"0123456789abcdefghijklmnopqrstuvwxyz"}),gf=gt({prefix:"K",name:"base36upper",alphabet:"0123456789ABCDEFGHIJKLMNOPQRSTUVWXYZ"});var bf=cc,ic=128,wf=127,xf=~wf,Ef=Math.pow(2,31);function cc(r,e,t){e=e||[],t=t||0;for(var n=t;r>=Ef;)e[t++]=r&255|ic,r/=128;for(;r&xf;)e[t++]=r&255|ic,r>>>=7;return e[t]=r|0,cc.bytes=t-n+1,e}var Sf=ds,vf=128,ac=127;function ds(r,n){var t=0,n=n||0,s=0,o=n,i,a=r.length;do{if(o>=a)throw ds.bytes=0,new RangeError("Could not decode varint");i=r[o++],t+=s<28?(i&ac)<<s:(i&ac)*Math.pow(2,s),s+=7}while(i>=vf);return ds.bytes=o-n,t}var _f=Math.pow(2,7),Af=Math.pow(2,14),Tf=Math.pow(2,21),If=Math.pow(2,28),Df=Math.pow(2,35),Cf=Math.pow(2,42),Lf=Math.pow(2,49),Bf=Math.pow(2,56),Rf=Math.pow(2,63),Of=function(r){return r<_f?1:r<Af?2:r<Tf?3:r<If?4:r<Df?5:r<Cf?6:r<Lf?7:r<Bf?8:r<Rf?9:10},Pf={encode:bf,decode:Sf,encodingLength:Of},Nf=Pf,qr=Nf;function zr(r,e=0){return[qr.decode(r,e),qr.decode.bytes]}function lr(r,e,t=0){return qr.encode(r,e,t),e}function fr(r){return qr.encodingLength(r)}function Ye(r,e){let t=e.byteLength,n=fr(r),s=n+fr(t),o=new Uint8Array(s+t);return lr(r,o,0),lr(t,o,n),o.set(e,s),new dr(r,t,e,o)}function Ze(r){let e=st(r),[t,n]=zr(e),[s,o]=zr(e.subarray(n)),i=e.subarray(n+o);if(i.byteLength!==s)throw new Error("Incorrect length");return new dr(t,s,i,e)}function uc(r,e){if(r===e)return!0;{let t=e;return r.code===t.code&&r.size===t.size&&t.bytes instanceof Uint8Array&&ec(r.bytes,t.bytes)}}var dr=class{code;size;digest;bytes;constructor(e,t,n,s){this.code=e,this.size=t,this.digest=Mt(n),this.bytes=Mt(s)}};function lc(r,e){let{bytes:t,version:n}=r;return n===0?kf(t,hs(r),e??re.encoder):Mf(t,hs(r),e??bt.encoder)}var fc=new WeakMap;function hs(r){let e=fc.get(r);if(e==null){let t=new Map;return fc.set(r,t),t}return e}var le=class r{code;version;multihash;bytes;"/";constructor(e,t,n,s){this.code=t,this.version=e,this.multihash=n,this.bytes=Mt(s),this["/"]=this.bytes}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:e,multihash:t}=this;if(e!==Vr)throw new Error("Cannot convert a non dag-pb CID to CIDv0");if(t.code!==Ff)throw new Error("Cannot convert non sha2-256 multihash CID to CIDv0");return r.createV0(t)}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:e,digest:t}=this.multihash,n=Ye(e,t);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(e){return r.equals(this,e)}static equals(e,t){let n=t;return n!=null&&e.code===n.code&&e.version===n.version&&uc(e.multihash,n.multihash)}toString(e){return lc(this,e)}toJSON(){return{"/":lc(this)}}link(){return this}[Symbol.toStringTag]="CID";[Symbol.for("nodejs.util.inspect.custom")](){return`CID(${this.toString()})`}static asCID(e){if(e==null)return null;let t=e;if(t instanceof r)return t;if(t["/"]!=null&&t["/"]===t.bytes||t.asCID===t){let{version:n,code:s,multihash:o,bytes:i}=t;return new r(n,s,o,i??dc(n,s,o.bytes))}else if(t[Kf]===!0){let{version:n,multihash:s,code:o}=t,i=Ze(s);return r.create(n,o,i)}else return null}static create(e,t,n){if(typeof t!="number")throw new Error("String codecs are no longer supported");if(!(n.bytes instanceof Uint8Array))throw new Error("Invalid digest");switch(e){case 0:{if(t!==Vr)throw new Error(`Version 0 CID must use dag-pb (code: ${Vr}) block encoding`);return new r(e,t,n,n.bytes)}case 1:{let s=dc(e,t,n.bytes);return new r(e,t,n,s)}default:throw new Error("Invalid version")}}static createV0(e){return r.create(0,Vr,e)}static createV1(e,t){return r.create(1,e,t)}static decode(e){let[t,n]=r.decodeFirst(e);if(n.length!==0)throw new Error("Incorrect length");return t}static decodeFirst(e){let t=r.inspectBytes(e),n=t.size-t.multihashSize,s=st(e.subarray(n,n+t.multihashSize));if(s.byteLength!==t.multihashSize)throw new Error("Incorrect length");let o=s.subarray(t.multihashSize-t.digestSize),i=new dr(t.multihashCode,t.digestSize,o,s);return[t.version===0?r.createV0(i):r.createV1(t.codec,i),e.subarray(t.size)]}static inspectBytes(e){let t=0,n=()=>{let[f,p]=zr(e.subarray(t));return t+=p,f},s=n(),o=Vr;if(s===18?(s=0,t=0):o=n(),s!==0&&s!==1)throw new RangeError(`Invalid CID version ${s}`);let i=t,a=n(),c=n(),u=t+c,l=u-i;return{version:s,codec:o,multihashCode:a,digestSize:c,multihashSize:l,size:u}}static parse(e,t){let[n,s]=Uf(e,t),o=r.decode(s);if(o.version===0&&e[0]!=="Q")throw Error("Version 0 CID string must not include multibase prefix");return hs(o).set(n,e),o}};function Uf(r,e){switch(r[0]){case"Q":{let t=e??re;return[re.prefix,t.decode(`${re.prefix}${r}`)]}case re.prefix:{let t=e??re;return[re.prefix,t.decode(r)]}case bt.prefix:{let t=e??bt;return[bt.prefix,t.decode(r)]}case Kr.prefix:{let t=e??Kr;return[Kr.prefix,t.decode(r)]}default:{if(e==null)throw Error("To parse non base32, base36 or base58btc encoded CID multibase decoder must be provided");return[r[0],e.decode(r)]}}}function kf(r,e,t){let{prefix:n}=t;if(n!==re.prefix)throw Error(`Cannot string encode V0 in ${t.name} encoding`);let s=e.get(n);if(s==null){let o=t.encode(r).slice(1);return e.set(n,o),o}else return s}function Mf(r,e,t){let{prefix:n}=t,s=e.get(n);if(s==null){let o=t.encode(r);return e.set(n,o),o}else return s}var Vr=112,Ff=18;function dc(r,e,t){let n=fr(r),s=n+fr(e),o=new Uint8Array(s+t.byteLength);return lr(r,o,0),lr(e,o,n),o.set(t,s),o}var Kf=Symbol.for("@ipld/js-cid/CID");var ps={};Te(ps,{identity:()=>Ke});var hc=0,qf="identity",pc=st;function zf(r,e){if(e?.truncate!=null&&e.truncate!==r.byteLength){if(e.truncate<0||e.truncate>r.byteLength)throw new Error(`Invalid truncate option, must be less than or equal to ${r.byteLength}`);r=r.subarray(0,e.truncate)}return Ye(hc,pc(r))}var Ke={code:hc,name:qf,encode:pc,digest:zf};function ce(r,e){if(r===e)return!0;if(r.byteLength!==e.byteLength)return!1;for(let t=0;t<r.byteLength;t++)if(r[t]!==e[t])return!1;return!0}function Vf(r){return r.buffer instanceof ArrayBuffer}function _e(r){return Vf(r)?r:r.slice()}async function mc(r,e,t,n){let s=await crypto.subtle.importKey("jwk",r,{name:"ECDSA",namedCurve:r.crv??"P-256"},!1,["verify"]);n?.signal?.throwIfAborted();let o=await crypto.subtle.verify({name:"ECDSA",hash:{name:"SHA-256"}},s,_e(e),_e(t.subarray()));return n?.signal?.throwIfAborted(),o}function J(r=0){return new Uint8Array(r)}function xe(r=0){return new Uint8Array(r)}function Hf(r){return r?.buffer instanceof ArrayBuffer}function ms(r){if(Hf(r))return r;let e=r.slice();return new Uint8Array(e.buffer,0,e.byteLength)}function Xe(r,e){e==null&&(e=r.reduce((s,o)=>s+o.length,0));let t=xe(e),n=0;for(let s of r)t.set(s,n),n+=s.length;return ms(t)}var gc=Symbol.for("@achingbrain/uint8arraylist");function yc(r,e){if(e==null||e<0)throw new RangeError("index is out of bounds");let t=0;for(let n of r){let s=t+n.byteLength;if(e<s)return{buf:n,index:e-t};t=s}throw new RangeError("index is out of bounds")}function Un(r){return!!r?.[gc]}var ee=class r{bufs;length;[gc]=!0;constructor(...e){this.bufs=[],this.length=0,e.length>0&&this.appendAll(e)}*[Symbol.iterator](){yield*this.bufs}get byteLength(){return this.length}append(...e){this.appendAll(e)}appendAll(e){let t=0;for(let n of e)if(n instanceof Uint8Array)t+=n.byteLength,this.bufs.push(n);else if(Un(n)){t+=n.byteLength;for(let s of n.bufs)this.bufs.push(s)}else throw new Error("Could not append value, must be an Uint8Array or a Uint8ArrayList");this.length+=t}prepend(...e){this.prependAll(e)}prependAll(e){let t=0;for(let n of e.reverse())if(n instanceof Uint8Array)t+=n.byteLength,this.bufs.unshift(n);else if(Un(n))t+=n.byteLength,this.bufs.unshift(...n.bufs);else throw new Error("Could not prepend value, must be an Uint8Array or a Uint8ArrayList");this.length+=t}get(e){let t=yc(this.bufs,e);return t.buf[t.index]}set(e,t){let n=yc(this.bufs,e);n.buf[n.index]=t}write(e,t=0){if(e instanceof Uint8Array)for(let n=0;n<e.length;n++)this.set(t+n,e[n]);else if(Un(e))for(let n=0;n<e.length;n++)this.set(t+n,e.get(n));else throw new Error("Could not write value, must be an Uint8Array or a Uint8ArrayList")}consume(e){if(e=Math.trunc(e),!(Number.isNaN(e)||e<=0)){if(e===this.byteLength){this.bufs=[],this.length=0;return}for(;this.bufs.length>0;)if(e>=this.bufs[0].byteLength)e-=this.bufs[0].byteLength,this.length-=this.bufs[0].byteLength,this.bufs.shift();else{this.bufs[0]=this.bufs[0].subarray(e),this.length-=e;break}}}slice(e,t){let{bufs:n,length:s}=this._subList(e,t);return Xe(n,s)}subarray(e,t){let{bufs:n,length:s}=this._subList(e,t);return n.length===1?n[0]:Xe(n,s)}sublist(e,t){let{bufs:n,length:s}=this._subList(e,t),o=new r;return o.length=s,o.bufs=n,o}_subList(e,t){if(e=e??0,t=t??this.length,e<0&&(e=this.length+e),t<0&&(t=this.length+t),e<0||t>this.length)throw new RangeError("index is out of bounds");if(e===t)return{bufs:[],length:0};if(e===0&&t===this.length)return{bufs:[...this.bufs],length:this.length};let n=[],s=0;for(let o=0;o<this.bufs.length;o++){let i=this.bufs[o],a=s,c=a+i.byteLength;if(s=c,e>=c)continue;let u=e>=a&&e<c,l=t>a&&t<=c;if(u&&l){if(e===a&&t===c){n.push(i);break}let f=e-a;n.push(i.subarray(f,f+(t-e)));break}if(u){if(e===0){n.push(i);continue}n.push(i.subarray(e-a));continue}if(l){if(t===c){n.push(i);break}n.push(i.subarray(0,t-a));break}n.push(i)}return{bufs:n,length:t-e}}indexOf(e,t=0){if(!Un(e)&&!(e instanceof Uint8Array))throw new TypeError('The "value" argument must be a Uint8ArrayList or Uint8Array');let n=e instanceof Uint8Array?e:e.subarray();if(t=Number(t??0),isNaN(t)&&(t=0),t<0&&(t=this.length+t),t<0&&(t=0),e.length===0)return t>this.length?this.length:t;let s=n.byteLength;if(s===0)throw new TypeError("search must be at least 1 byte long");let o=256,i=new Int32Array(o);for(let f=0;f<o;f++)i[f]=-1;for(let f=0;f<s;f++)i[n[f]]=f;let a=i,c=this.byteLength-n.byteLength,u=n.byteLength-1,l;for(let f=t;f<=c;f+=l){l=0;for(let p=u;p>=0;p--){let d=this.get(f+p);if(n[p]!==d){l=Math.max(1,p-a[d]);break}}if(l===0)return f}return-1}getInt8(e){let t=this.subarray(e,e+1);return new DataView(t.buffer,t.byteOffset,t.byteLength).getInt8(0)}setInt8(e,t){let n=xe(1);new DataView(n.buffer,n.byteOffset,n.byteLength).setInt8(0,t),this.write(n,e)}getInt16(e,t){let n=this.subarray(e,e+2);return new DataView(n.buffer,n.byteOffset,n.byteLength).getInt16(0,t)}setInt16(e,t,n){let s=J(2);new DataView(s.buffer,s.byteOffset,s.byteLength).setInt16(0,t,n),this.write(s,e)}getInt32(e,t){let n=this.subarray(e,e+4);return new DataView(n.buffer,n.byteOffset,n.byteLength).getInt32(0,t)}setInt32(e,t,n){let s=J(4);new DataView(s.buffer,s.byteOffset,s.byteLength).setInt32(0,t,n),this.write(s,e)}getBigInt64(e,t){let n=this.subarray(e,e+8);return new DataView(n.buffer,n.byteOffset,n.byteLength).getBigInt64(0,t)}setBigInt64(e,t,n){let s=J(8);new DataView(s.buffer,s.byteOffset,s.byteLength).setBigInt64(0,t,n),this.write(s,e)}getUint8(e){let t=this.subarray(e,e+1);return new DataView(t.buffer,t.byteOffset,t.byteLength).getUint8(0)}setUint8(e,t){let n=xe(1);new DataView(n.buffer,n.byteOffset,n.byteLength).setUint8(0,t),this.write(n,e)}getUint16(e,t){let n=this.subarray(e,e+2);return new DataView(n.buffer,n.byteOffset,n.byteLength).getUint16(0,t)}setUint16(e,t,n){let s=J(2);new DataView(s.buffer,s.byteOffset,s.byteLength).setUint16(0,t,n),this.write(s,e)}getUint32(e,t){let n=this.subarray(e,e+4);return new DataView(n.buffer,n.byteOffset,n.byteLength).getUint32(0,t)}setUint32(e,t,n){let s=J(4);new DataView(s.buffer,s.byteOffset,s.byteLength).setUint32(0,t,n),this.write(s,e)}getBigUint64(e,t){let n=this.subarray(e,e+8);return new DataView(n.buffer,n.byteOffset,n.byteLength).getBigUint64(0,t)}setBigUint64(e,t,n){let s=J(8);new DataView(s.buffer,s.byteOffset,s.byteLength).setBigUint64(0,t,n),this.write(s,e)}getFloat32(e,t){let n=this.subarray(e,e+4);return new DataView(n.buffer,n.byteOffset,n.byteLength).getFloat32(0,t)}setFloat32(e,t,n){let s=J(4);new DataView(s.buffer,s.byteOffset,s.byteLength).setFloat32(0,t,n),this.write(s,e)}getFloat64(e,t){let n=this.subarray(e,e+8);return new DataView(n.buffer,n.byteOffset,n.byteLength).getFloat64(0,t)}setFloat64(e,t,n){let s=J(8);new DataView(s.buffer,s.byteOffset,s.byteLength).setFloat64(0,t,n),this.write(s,e)}equals(e){if(e==null||!(e instanceof r)||e.bufs.length!==this.bufs.length)return!1;for(let t=0;t<this.bufs.length;t++)if(!ce(this.bufs[t],e.bufs[t]))return!1;return!0}static fromUint8Arrays(e,t){let n=new r;return n.bufs=e,t==null&&(t=e.reduce((s,o)=>s+o.byteLength,0)),n.length=t,n}};var ys={};Te(ys,{base10:()=>$f});var $f=gt({prefix:"9",name:"base10",alphabet:"0123456789"});var gs={};Te(gs,{base16:()=>Wf,base16upper:()=>jf});var Wf=se({prefix:"f",name:"base16",alphabet:"0123456789abcdef",bitsPerChar:4}),jf=se({prefix:"F",name:"base16upper",alphabet:"0123456789ABCDEF",bitsPerChar:4});var bs={};Te(bs,{base2:()=>Gf});var Gf=se({prefix:"0",name:"base2",alphabet:"01",bitsPerChar:1});var ws={};Te(ws,{base256emoji:()=>Jf});var bc=Array.from("\u{1F680}\u{1FA90}\u2604\u{1F6F0}\u{1F30C}\u{1F311}\u{1F312}\u{1F313}\u{1F314}\u{1F315}\u{1F316}\u{1F317}\u{1F318}\u{1F30D}\u{1F30F}\u{1F30E}\u{1F409}\u2600\u{1F4BB}\u{1F5A5}\u{1F4BE}\u{1F4BF}\u{1F602}\u2764\u{1F60D}\u{1F923}\u{1F60A}\u{1F64F}\u{1F495}\u{1F62D}\u{1F618}\u{1F44D}\u{1F605}\u{1F44F}\u{1F601}\u{1F525}\u{1F970}\u{1F494}\u{1F496}\u{1F499}\u{1F622}\u{1F914}\u{1F606}\u{1F644}\u{1F4AA}\u{1F609}\u263A\u{1F44C}\u{1F917}\u{1F49C}\u{1F614}\u{1F60E}\u{1F607}\u{1F339}\u{1F926}\u{1F389}\u{1F49E}\u270C\u2728\u{1F937}\u{1F631}\u{1F60C}\u{1F338}\u{1F64C}\u{1F60B}\u{1F497}\u{1F49A}\u{1F60F}\u{1F49B}\u{1F642}\u{1F493}\u{1F929}\u{1F604}\u{1F600}\u{1F5A4}\u{1F603}\u{1F4AF}\u{1F648}\u{1F447}\u{1F3B6}\u{1F612}\u{1F92D}\u2763\u{1F61C}\u{1F48B}\u{1F440}\u{1F62A}\u{1F611}\u{1F4A5}\u{1F64B}\u{1F61E}\u{1F629}\u{1F621}\u{1F92A}\u{1F44A}\u{1F973}\u{1F625}\u{1F924}\u{1F449}\u{1F483}\u{1F633}\u270B\u{1F61A}\u{1F61D}\u{1F634}\u{1F31F}\u{1F62C}\u{1F643}\u{1F340}\u{1F337}\u{1F63B}\u{1F613}\u2B50\u2705\u{1F97A}\u{1F308}\u{1F608}\u{1F918}\u{1F4A6}\u2714\u{1F623}\u{1F3C3}\u{1F490}\u2639\u{1F38A}\u{1F498}\u{1F620}\u261D\u{1F615}\u{1F33A}\u{1F382}\u{1F33B}\u{1F610}\u{1F595}\u{1F49D}\u{1F64A}\u{1F639}\u{1F5E3}\u{1F4AB}\u{1F480}\u{1F451}\u{1F3B5}\u{1F91E}\u{1F61B}\u{1F534}\u{1F624}\u{1F33C}\u{1F62B}\u26BD\u{1F919}\u2615\u{1F3C6}\u{1F92B}\u{1F448}\u{1F62E}\u{1F646}\u{1F37B}\u{1F343}\u{1F436}\u{1F481}\u{1F632}\u{1F33F}\u{1F9E1}\u{1F381}\u26A1\u{1F31E}\u{1F388}\u274C\u270A\u{1F44B}\u{1F630}\u{1F928}\u{1F636}\u{1F91D}\u{1F6B6}\u{1F4B0}\u{1F353}\u{1F4A2}\u{1F91F}\u{1F641}\u{1F6A8}\u{1F4A8}\u{1F92C}\u2708\u{1F380}\u{1F37A}\u{1F913}\u{1F619}\u{1F49F}\u{1F331}\u{1F616}\u{1F476}\u{1F974}\u25B6\u27A1\u2753\u{1F48E}\u{1F4B8}\u2B07\u{1F628}\u{1F31A}\u{1F98B}\u{1F637}\u{1F57A}\u26A0\u{1F645}\u{1F61F}\u{1F635}\u{1F44E}\u{1F932}\u{1F920}\u{1F927}\u{1F4CC}\u{1F535}\u{1F485}\u{1F9D0}\u{1F43E}\u{1F352}\u{1F617}\u{1F911}\u{1F30A}\u{1F92F}\u{1F437}\u260E\u{1F4A7}\u{1F62F}\u{1F486}\u{1F446}\u{1F3A4}\u{1F647}\u{1F351}\u2744\u{1F334}\u{1F4A3}\u{1F438}\u{1F48C}\u{1F4CD}\u{1F940}\u{1F922}\u{1F445}\u{1F4A1}\u{1F4A9}\u{1F450}\u{1F4F8}\u{1F47B}\u{1F910}\u{1F92E}\u{1F3BC}\u{1F975}\u{1F6A9}\u{1F34E}\u{1F34A}\u{1F47C}\u{1F48D}\u{1F4E3}\u{1F942}"),Yf=bc.reduce((r,e,t)=>(r[t]=e,r),[]),Zf=bc.reduce((r,e,t)=>{let n=e.codePointAt(0);if(n==null)throw new Error(`Invalid character: ${e}`);return r[n]=t,r},[]);function Xf(r){return r.reduce((e,t)=>(e+=Yf[t],e),"")}function Qf(r){let e=[];for(let t of r){let n=t.codePointAt(0);if(n==null)throw new Error(`Invalid character: ${t}`);let s=Zf[n];if(s==null)throw new Error(`Non-base256emoji character: ${t}`);e.push(s)}return new Uint8Array(e)}var Jf=ur({prefix:"\u{1F680}",name:"base256emoji",encode:Xf,decode:Qf});var Es={};Te(Es,{base64:()=>ed,base64pad:()=>td,base64url:()=>xs,base64urlpad:()=>rd});var ed=se({prefix:"m",name:"base64",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/",bitsPerChar:6}),td=se({prefix:"M",name:"base64pad",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/=",bitsPerChar:6}),xs=se({prefix:"u",name:"base64url",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789-_",bitsPerChar:6}),rd=se({prefix:"U",name:"base64urlpad",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789-_=",bitsPerChar:6});var Ss={};Te(Ss,{base8:()=>nd});var nd=se({prefix:"7",name:"base8",alphabet:"01234567",bitsPerChar:3});var vs={};Te(vs,{identity:()=>od});var od=ur({prefix:"\0",name:"identity",encode:r=>rc(r),decode:r=>tc(r)});var m0=new TextEncoder,y0=new TextDecoder;var Ts={};Te(Ts,{sha256:()=>hr,sha512:()=>cd});var ad=20;function As({name:r,code:e,encode:t,minDigestLength:n,maxDigestLength:s}){return new _s(r,e,t,n,s)}var _s=class{name;code;encode;minDigestLength;maxDigestLength;constructor(e,t,n,s,o){this.name=e,this.code=t,this.encode=n,this.minDigestLength=s??ad,this.maxDigestLength=o}digest(e,t){if(t?.truncate!=null){if(t.truncate<this.minDigestLength)throw new Error(`Invalid truncate option, must be greater than or equal to ${this.minDigestLength}`);if(this.maxDigestLength!=null&&t.truncate>this.maxDigestLength)throw new Error(`Invalid truncate option, must be less than or equal to ${this.maxDigestLength}`)}if(e instanceof Uint8Array){let n=this.encode(e);return n instanceof Uint8Array?wc(n,this.code,t?.truncate):n.then(s=>wc(s,this.code,t?.truncate))}else throw Error("Unknown type, must be binary type")}};function wc(r,e,t){if(t!=null&&t!==r.byteLength){if(t>r.byteLength)throw new Error(`Invalid truncate option, must be less than or equal to ${r.byteLength}`);r=r.subarray(0,t)}return Ye(e,r)}function Ec(r){return async e=>new Uint8Array(await crypto.subtle.digest(r,e))}var hr=As({name:"sha2-256",code:18,encode:Ec("SHA-256")}),cd=As({name:"sha2-512",code:19,encode:Ec("SHA-512")});var Hr={...vs,...bs,...Ss,...ys,...gs,...ls,...fs,...us,...Es,...ws},D0={...Ts,...ps};function vc(r,e,t,n){return{name:r,prefix:e,encoder:{name:r,prefix:e,encode:t},decoder:{decode:n}}}var Sc=vc("utf8","u",r=>"u"+new TextDecoder("utf8").decode(r),r=>new TextEncoder().encode(r.substring(1))),Is=vc("ascii","a",r=>{let e="a";for(let t=0;t<r.length;t++)e+=String.fromCharCode(r[t]);return e},r=>{r=r.substring(1);let e=xe(r.length);for(let t=0;t<r.length;t++)e[t]=r.charCodeAt(t);return e}),ud={utf8:Sc,"utf-8":Sc,hex:Hr.base16,latin1:Is,ascii:Is,binary:Is,...Hr},kn=ud;function k(r,e="utf8"){let t=kn[e];if(t==null)throw new Error(`Unsupported encoding "${e}"`);return t.decoder.decode(`${t.prefix}${r}`)}function V(r,e="utf8"){let t=kn[e];if(t==null)throw new Error(`Unsupported encoding "${e}"`);return t.encoder.encode(r).substring(1)}var ld=parseInt("11111",2),Ds=parseInt("10000000",2),fd=parseInt("01111111",2),_c={0:$r,1:$r,2:dd,3:md,4:yd,5:pd,6:hd,16:$r,22:$r,48:$r};function at(r,e={offset:0}){let t=r[e.offset]&ld;if(e.offset++,_c[t]!=null)return _c[t](r,e);throw new Error("No decoder for tag "+t)}function Wr(r,e){let t=0;if((r[e.offset]&Ds)===Ds){let n=r[e.offset]&fd,s="0x";e.offset++;for(let o=0;o<n;o++,e.offset++)s+=r[e.offset].toString(16).padStart(2,"0");t=parseInt(s,16)}else t=r[e.offset],e.offset++;return t}function $r(r,e){Wr(r,e);let t=[];for(;!(e.offset>=r.byteLength);){let n=at(r,e);if(n===null)break;t.push(n)}return t}function dd(r,e){let t=Wr(r,e),n=e.offset,s=e.offset+t,o=[];for(let i=n;i<s;i++)i===n&&r[i]===0||o.push(r[i]);return e.offset+=t,Uint8Array.from(o)}function hd(r,e){let t=Wr(r,e),n=e.offset+t,s=r[e.offset];e.offset++;let o=0,i=0;s<40?(o=0,i=s):s<80?(o=1,i=s-40):(o=2,i=s-80);let a=`${o}.${i}`,c=[];for(;e.offset<n;){let u=r[e.offset];if(e.offset++,c.push(u&127),u<128){c.reverse();let l=0;for(let f=0;f<c.length;f++)l+=c[f]<<f*7;a+=`.${l}`,c=[]}}return a}function pd(r,e){return e.offset++,null}function md(r,e){let t=Wr(r,e),n=r[e.offset];e.offset++;let s=r.subarray(e.offset,e.offset+t-1);if(e.offset+=t,n!==0)throw new Error("Unused bits in bit string is unimplemented");return s}function yd(r,e){let t=Wr(r,e),n=r.subarray(e.offset,e.offset+t);return e.offset+=t,n}function gd(r){let e=r.toString(16);e.length%2===1&&(e="0"+e);let t=new ee;for(let n=0;n<e.length;n+=2)t.append(Uint8Array.from([parseInt(`${e[n]}${e[n+1]}`,16)]));return t}function Cs(r){if(r.byteLength<128)return Uint8Array.from([r.byteLength]);let e=gd(r.byteLength);return new ee(Uint8Array.from([e.byteLength|Ds]),e)}function De(r){let e=new ee,t=128;return(r.subarray()[0]&t)===t&&e.append(Uint8Array.from([0])),e.append(r),new ee(Uint8Array.from([2]),Cs(e),e)}function Mn(r){let e=Uint8Array.from([0]),t=new ee(e,r);return new ee(Uint8Array.from([3]),Cs(t),t)}function wt(r,e=48){let t=new ee;for(let n of r)t.append(n);return new ee(Uint8Array.from([e]),Cs(t),t)}var bd=Uint8Array.from([6,8,42,134,72,206,61,3,1,7]),wd=Uint8Array.from([6,5,43,129,4,0,34]),xd=Uint8Array.from([6,5,43,129,4,0,35]),Ed={ext:!0,kty:"EC",crv:"P-256"},Sd={ext:!0,kty:"EC",crv:"P-384"},vd={ext:!0,kty:"EC",crv:"P-521"},Ls=32,Bs=48,Rs=66;function Os(r){let e=at(r);return Ac(e)}function Ac(r){let e=r[1][1][0],t=1,n,s;if(e.byteLength===Ls*2+1)return n=V(e.subarray(t,t+Ls),"base64url"),s=V(e.subarray(t+Ls),"base64url"),new pr({...Ed,key_ops:["verify"],x:n,y:s});if(e.byteLength===Bs*2+1)return n=V(e.subarray(t,t+Bs),"base64url"),s=V(e.subarray(t+Bs),"base64url"),new pr({...Sd,key_ops:["verify"],x:n,y:s});if(e.byteLength===Rs*2+1)return n=V(e.subarray(t,t+Rs),"base64url"),s=V(e.subarray(t+Rs),"base64url"),new pr({...vd,key_ops:["verify"],x:n,y:s});throw new oe(`coordinates were wrong length, got ${e.byteLength}, expected 65, 97 or 133`)}function Tc(r){return wt([De(Uint8Array.from([1])),wt([_d(r.crv)],160),wt([Mn(new ee(Uint8Array.from([4]),k(r.x??"","base64url"),k(r.y??"","base64url")))],161)]).subarray()}function _d(r){if(r==="P-256")return bd;if(r==="P-384")return wd;if(r==="P-521")return xd;throw new oe(`Invalid curve ${r}`)}var pr=class{type="ECDSA";jwk;_raw;constructor(e){this.jwk=e}get raw(){return this._raw==null&&(this._raw=Tc(this.jwk)),this._raw}toMultihash(){return Ke.digest(Qe(this))}toCID(){return le.createV1(114,this.toMultihash())}toString(){return re.encode(this.toMultihash().bytes).substring(1)}equals(e){return e==null||!(e.raw instanceof Uint8Array)?!1:ce(this.raw,e.raw)}async verify(e,t,n){return mc(this.jwk,t,e,n)}};function Ps(r){return r instanceof Uint8Array||ArrayBuffer.isView(r)&&r.constructor.name==="Uint8Array"&&"BYTES_PER_ELEMENT"in r&&r.BYTES_PER_ELEMENT===1}function xt(r,e=""){if(typeof r!="number"){let t=e&&`"${e}" `;throw new TypeError(`${t}expected number, got ${typeof r}`)}if(!Number.isSafeInteger(r)||r<0){let t=e&&`"${e}" `;throw new RangeError(`${t}expected integer >= 0, got ${r}`)}}function Pe(r,e,t=""){let n=Ps(r),s=r?.length,o=e!==void 0;if(!n||o&&s!==e){let i=t&&`"${t}" `,a=o?` of length ${e}`:"",c=n?`length=${s}`:`type=${typeof r}`,u=i+"expected Uint8Array"+a+", got "+c;throw n?new RangeError(u):new TypeError(u)}return r}function Fn(r){if(typeof r!="function"||typeof r.create!="function")throw new TypeError("Hash must wrapped by utils.createHasher");if(xt(r.outputLen),xt(r.blockLen),r.outputLen<1)throw new Error('"outputLen" must be >= 1');if(r.blockLen<1)throw new Error('"blockLen" must be >= 1')}function mr(r,e=!0){if(r.destroyed)throw new Error("Hash instance has been destroyed");if(e&&r.finished)throw new Error("Hash#digest() has already been called")}function Kn(r,e){Pe(r,void 0,"digestInto() output");let t=e.outputLen;if(r.length<t)throw new RangeError('"digestInto() output" expected to be of length >='+t)}function ut(...r){for(let e=0;e<r.length;e++)r[e].fill(0)}function qn(r){return new DataView(r.buffer,r.byteOffset,r.byteLength)}function qe(r,e){return r<<32-e|r>>>e}var Dc=typeof Uint8Array.from([]).toHex=="function"&&typeof Uint8Array.fromHex=="function",Ad=Array.from({length:256},(r,e)=>e.toString(16).padStart(2,"0"));function zn(r){if(Pe(r),Dc)return r.toHex();let e="";for(let t=0;t<r.length;t++)e+=Ad[r[t]];return e}var ct={_0:48,_9:57,A:65,F:70,a:97,f:102};function Ic(r){if(r>=ct._0&&r<=ct._9)return r-ct._0;if(r>=ct.A&&r<=ct.F)return r-(ct.A-10);if(r>=ct.a&&r<=ct.f)return r-(ct.a-10)}function jr(r){if(typeof r!="string")throw new TypeError("hex string expected, got "+typeof r);if(Dc)try{return Uint8Array.fromHex(r)}catch(s){throw s instanceof SyntaxError?new RangeError(s.message):s}let e=r.length,t=e/2;if(e%2)throw new RangeError("hex string expected, got unpadded hex of length "+e);let n=new Uint8Array(t);for(let s=0,o=0;s<t;s++,o+=2){let i=Ic(r.charCodeAt(o)),a=Ic(r.charCodeAt(o+1));if(i===void 0||a===void 0){let c=r[o]+r[o+1];throw new RangeError('hex string expected, got non-hex character "'+c+'" at index '+o)}n[s]=i*16+a}return n}function Ns(...r){let e=0;for(let n=0;n<r.length;n++){let s=r[n];Pe(s),e+=s.length}let t=new Uint8Array(e);for(let n=0,s=0;n<r.length;n++){let o=r[n];t.set(o,s),s+=o.length}return t}function Us(r,e={}){let t=(s,o)=>r(o).update(s).digest(),n=r(void 0);return t.outputLen=n.outputLen,t.blockLen=n.blockLen,t.canXOF=n.canXOF,t.create=s=>r(s),Object.assign(t,e),Object.freeze(t)}function Cc(r=32){xt(r,"bytesLength");let e=typeof globalThis=="object"?globalThis.crypto:null;if(typeof e?.getRandomValues!="function")throw new Error("crypto.getRandomValues must be defined");if(r>65536)throw new RangeError(`"bytesLength" expected <= 65536, got ${r}`);return e.getRandomValues(new Uint8Array(r))}var ks=r=>({oid:Uint8Array.from([6,9,96,134,72,1,101,3,4,2,r])});function Lc(r,e,t){return r&e^~r&t}function Bc(r,e,t){return r&e^r&t^e&t}var Gr=class{blockLen;outputLen;canXOF=!1;padOffset;isLE;buffer;view;finished=!1;length=0;pos=0;destroyed=!1;constructor(e,t,n,s){this.blockLen=e,this.outputLen=t,this.padOffset=n,this.isLE=s,this.buffer=new Uint8Array(e),this.view=qn(this.buffer)}update(e){mr(this),Pe(e);let{view:t,buffer:n,blockLen:s}=this,o=e.length;for(let i=0;i<o;){let a=Math.min(s-this.pos,o-i);if(a===s){let c=qn(e);for(;s<=o-i;i+=s)this.process(c,i);continue}n.set(e.subarray(i,i+a),this.pos),this.pos+=a,i+=a,this.pos===s&&(this.process(t,0),this.pos=0)}return this.length+=e.length,this.roundClean(),this}digestInto(e){mr(this),Kn(e,this),this.finished=!0;let{buffer:t,view:n,blockLen:s,isLE:o}=this,{pos:i}=this;t[i++]=128,ut(this.buffer.subarray(i)),this.padOffset>s-i&&(this.process(n,0),i=0);for(let f=i;f<s;f++)t[f]=0;n.setBigUint64(s-8,BigInt(this.length*8),o),this.process(n,0);let a=qn(e),c=this.outputLen;if(c%4)throw new Error("_sha2: outputLen must be aligned to 32bit");let u=c/4,l=this.get();if(u>l.length)throw new Error("_sha2: outputLen bigger than state");for(let f=0;f<u;f++)a.setUint32(4*f,l[f],o)}digest(){let{buffer:e,outputLen:t}=this;this.digestInto(e);let n=e.slice(0,t);return this.destroy(),n}_cloneInto(e){e||=new this.constructor,e.set(...this.get());let{blockLen:t,buffer:n,length:s,finished:o,destroyed:i,pos:a}=this;return e.destroyed=i,e.finished=o,e.length=s,e.pos=a,s%t&&e.buffer.set(n),e}clone(){return this._cloneInto()}},lt=Uint32Array.from([1779033703,3144134277,1013904242,2773480762,1359893119,2600822924,528734635,1541459225]);var ge=Uint32Array.from([1779033703,4089235720,3144134277,2227873595,1013904242,4271175723,2773480762,1595750129,1359893119,2917565137,2600822924,725511199,528734635,4215389547,1541459225,327033209]);var Vn=BigInt(4294967295),Rc=BigInt(32);function Td(r,e=!1){return e?{h:Number(r&Vn),l:Number(r>>Rc&Vn)}:{h:Number(r>>Rc&Vn)|0,l:Number(r&Vn)|0}}function Oc(r,e=!1){let t=r.length,n=new Uint32Array(t),s=new Uint32Array(t);for(let o=0;o<t;o++){let{h:i,l:a}=Td(r[o],e);[n[o],s[o]]=[i,a]}return[n,s]}var Ms=(r,e,t)=>r>>>t,Fs=(r,e,t)=>r<<32-t|e>>>t,Ft=(r,e,t)=>r>>>t|e<<32-t,Kt=(r,e,t)=>r<<32-t|e>>>t,Yr=(r,e,t)=>r<<64-t|e>>>t-32,Zr=(r,e,t)=>r>>>t-32|e<<64-t;function Je(r,e,t,n){let s=(e>>>0)+(n>>>0);return{h:r+t+(s/2**32|0)|0,l:s|0}}var Pc=(r,e,t)=>(r>>>0)+(e>>>0)+(t>>>0),Nc=(r,e,t,n)=>e+t+n+(r/2**32|0)|0,Uc=(r,e,t,n)=>(r>>>0)+(e>>>0)+(t>>>0)+(n>>>0),kc=(r,e,t,n,s)=>e+t+n+s+(r/2**32|0)|0,Mc=(r,e,t,n,s)=>(r>>>0)+(e>>>0)+(t>>>0)+(n>>>0)+(s>>>0),Fc=(r,e,t,n,s,o)=>e+t+n+s+o+(r/2**32|0)|0;var Dd=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]),Et=new Uint32Array(64),Ks=class extends Gr{constructor(e){super(64,e,8,!1)}get(){let{A:e,B:t,C:n,D:s,E:o,F:i,G:a,H:c}=this;return[e,t,n,s,o,i,a,c]}set(e,t,n,s,o,i,a,c){this.A=e|0,this.B=t|0,this.C=n|0,this.D=s|0,this.E=o|0,this.F=i|0,this.G=a|0,this.H=c|0}process(e,t){for(let f=0;f<16;f++,t+=4)Et[f]=e.getUint32(t,!1);for(let f=16;f<64;f++){let p=Et[f-15],d=Et[f-2],y=qe(p,7)^qe(p,18)^p>>>3,x=qe(d,17)^qe(d,19)^d>>>10;Et[f]=x+Et[f-7]+y+Et[f-16]|0}let{A:n,B:s,C:o,D:i,E:a,F:c,G:u,H:l}=this;for(let f=0;f<64;f++){let p=qe(a,6)^qe(a,11)^qe(a,25),d=l+p+Lc(a,c,u)+Dd[f]+Et[f]|0,x=(qe(n,2)^qe(n,13)^qe(n,22))+Bc(n,s,o)|0;l=u,u=c,c=a,a=i+d|0,i=o,o=s,s=n,n=d+x|0}n=n+this.A|0,s=s+this.B|0,o=o+this.C|0,i=i+this.D|0,a=a+this.E|0,c=c+this.F|0,u=u+this.G|0,l=l+this.H|0,this.set(n,s,o,i,a,c,u,l)}roundClean(){ut(Et)}destroy(){this.destroyed=!0,this.set(0,0,0,0,0,0,0,0),ut(this.buffer)}},qs=class extends Ks{A=lt[0]|0;B=lt[1]|0;C=lt[2]|0;D=lt[3]|0;E=lt[4]|0;F=lt[5]|0;G=lt[6]|0;H=lt[7]|0;constructor(){super(32)}};var Kc=Oc(["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))),Cd=Kc[0],Ld=Kc[1],St=new Uint32Array(80),vt=new Uint32Array(80),zs=class extends Gr{constructor(e){super(128,e,16,!1)}get(){let{Ah:e,Al:t,Bh:n,Bl:s,Ch:o,Cl:i,Dh:a,Dl:c,Eh:u,El:l,Fh:f,Fl:p,Gh:d,Gl:y,Hh:x,Hl:h}=this;return[e,t,n,s,o,i,a,c,u,l,f,p,d,y,x,h]}set(e,t,n,s,o,i,a,c,u,l,f,p,d,y,x,h){this.Ah=e|0,this.Al=t|0,this.Bh=n|0,this.Bl=s|0,this.Ch=o|0,this.Cl=i|0,this.Dh=a|0,this.Dl=c|0,this.Eh=u|0,this.El=l|0,this.Fh=f|0,this.Fl=p|0,this.Gh=d|0,this.Gl=y|0,this.Hh=x|0,this.Hl=h|0}process(e,t){for(let _=0;_<16;_++,t+=4)St[_]=e.getUint32(t),vt[_]=e.getUint32(t+=4);for(let _=16;_<80;_++){let B=St[_-15]|0,C=vt[_-15]|0,N=Ft(B,C,1)^Ft(B,C,8)^Ms(B,C,7),R=Kt(B,C,1)^Kt(B,C,8)^Fs(B,C,7),I=St[_-2]|0,U=vt[_-2]|0,Z=Ft(I,U,19)^Yr(I,U,61)^Ms(I,U,6),M=Kt(I,U,19)^Zr(I,U,61)^Fs(I,U,6),m=Uc(R,M,vt[_-7],vt[_-16]),b=kc(m,N,Z,St[_-7],St[_-16]);St[_]=b|0,vt[_]=m|0}let{Ah:n,Al:s,Bh:o,Bl:i,Ch:a,Cl:c,Dh:u,Dl:l,Eh:f,El:p,Fh:d,Fl:y,Gh:x,Gl:h,Hh:g,Hl:S}=this;for(let _=0;_<80;_++){let B=Ft(f,p,14)^Ft(f,p,18)^Yr(f,p,41),C=Kt(f,p,14)^Kt(f,p,18)^Zr(f,p,41),N=f&d^~f&x,R=p&y^~p&h,I=Mc(S,C,R,Ld[_],vt[_]),U=Fc(I,g,B,N,Cd[_],St[_]),Z=I|0,M=Ft(n,s,28)^Yr(n,s,34)^Yr(n,s,39),m=Kt(n,s,28)^Zr(n,s,34)^Zr(n,s,39),b=n&o^n&a^o&a,v=s&i^s&c^i&c;g=x|0,S=h|0,x=d|0,h=y|0,d=f|0,y=p|0,{h:f,l:p}=Je(u|0,l|0,U|0,Z|0),u=a|0,l=c|0,a=o|0,c=i|0,o=n|0,i=s|0;let E=Pc(Z,m,v);n=Nc(E,U,M,b),s=E|0}({h:n,l:s}=Je(this.Ah|0,this.Al|0,n|0,s|0)),{h:o,l:i}=Je(this.Bh|0,this.Bl|0,o|0,i|0),{h:a,l:c}=Je(this.Ch|0,this.Cl|0,a|0,c|0),{h:u,l}=Je(this.Dh|0,this.Dl|0,u|0,l|0),{h:f,l:p}=Je(this.Eh|0,this.El|0,f|0,p|0),{h:d,l:y}=Je(this.Fh|0,this.Fl|0,d|0,y|0),{h:x,l:h}=Je(this.Gh|0,this.Gl|0,x|0,h|0),{h:g,l:S}=Je(this.Hh|0,this.Hl|0,g|0,S|0),this.set(n,s,o,i,a,c,u,l,f,p,d,y,x,h,g,S)}roundClean(){ut(St,vt)}destroy(){this.destroyed=!0,ut(this.buffer),this.set(0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0)}},Vs=class extends zs{Ah=ge[0]|0;Al=ge[1]|0;Bh=ge[2]|0;Bl=ge[3]|0;Ch=ge[4]|0;Cl=ge[5]|0;Dh=ge[6]|0;Dl=ge[7]|0;Eh=ge[8]|0;El=ge[9]|0;Fh=ge[10]|0;Fl=ge[11]|0;Gh=ge[12]|0;Gl=ge[13]|0;Hh=ge[14]|0;Hl=ge[15]|0;constructor(){super(64)}};var yr=Us(()=>new qs,ks(1));var Hn=Us(()=>new Vs,ks(3));var H=(r,e,t)=>Pe(r,e,t),$s=xt,gr=zn,de=(...r)=>Ns(...r),br=r=>jr(r),qt=Ps,Xr=r=>Cc(r),Wn=BigInt(0),Hs=BigInt(1);function ze(r,e=""){if(typeof r!="boolean"){let t=e&&`"${e}" `;throw new TypeError(t+"expected boolean, got type="+typeof r)}return r}function jn(r){if(typeof r=="bigint"){if(!$n(r))throw new RangeError("positive bigint expected, got "+r)}else $s(r);return r}function Ve(r,e=""){if(typeof r!="number"){let t=e&&`"${e}" `;throw new TypeError(t+"expected number, got type="+typeof r)}if(!Number.isSafeInteger(r)){let t=e&&`"${e}" `;throw new RangeError(t+"expected safe integer, got "+r)}}function Qr(r){let e=jn(r).toString(16);return e.length&1?"0"+e:e}function qc(r){if(typeof r!="string")throw new TypeError("hex string expected, got "+typeof r);return r===""?Wn:BigInt("0x"+r)}function zt(r){return qc(zn(r))}function et(r){return qc(zn(Jr(Pe(r)).reverse()))}function Gn(r,e){if(xt(e),e===0)throw new RangeError("zero length");r=jn(r);let t=r.toString(16);if(t.length>e*2)throw new RangeError("number too large");return jr(t.padStart(e*2,"0"))}function Ws(r,e){return Gn(r,e).reverse()}function zc(r,e){if(r=H(r),e=H(e),r.length!==e.length)return!1;let t=0;for(let n=0;n<r.length;n++)t|=r[n]^e[n];return t===0}function Jr(r){return Uint8Array.from(H(r))}function Yn(r){if(typeof r!="string")throw new TypeError("ascii string expected, got "+typeof r);return Uint8Array.from(r,(e,t)=>{let n=e.charCodeAt(0);if(e.length!==1||n>127)throw new RangeError(`string contains non-ASCII character "${r[t]}" with code ${n} at position ${t}`);return n})}var $n=r=>typeof r=="bigint"&&Wn<=r;function Bd(r,e,t){return $n(r)&&$n(e)&&$n(t)&&e<=r&&r<t}function wr(r,e,t,n){if(!Bd(e,t,n))throw new RangeError("expected valid "+r+": "+t+" <= n < "+n+", got "+e)}function xr(r){if(r<Wn)throw new Error("expected non-negative bigint, got "+r);let e;for(e=0;r>Wn;r>>=Hs,e+=1);return e}var en=r=>(Hs<<BigInt(r))-Hs;function Vc(r,e,t){if(xt(r,"hashLen"),xt(e,"qByteLen"),typeof t!="function")throw new TypeError("hmacFn must be a function");let n=h=>new Uint8Array(h),s=Uint8Array.of(),o=Uint8Array.of(0),i=Uint8Array.of(1),a=1e3,c=n(r),u=n(r),l=0,f=()=>{c.fill(1),u.fill(0),l=0},p=(...h)=>t(u,de(c,...h)),d=(h=s)=>{u=p(o,h),c=p(),h.length!==0&&(u=p(i,h),c=p())},y=()=>{if(l++>=a)throw new Error("drbg: tried max amount of iterations");let h=0,g=[];for(;h<e;){c=p();let S=c.slice();g.push(S),h+=c.length}return de(...g)};return(h,g)=>{f(),d(h);let S;for(;(S=g(y()))===void 0;)d();return f(),S}}function He(r,e={},t={}){if(Object.prototype.toString.call(r)!=="[object Object]")throw new TypeError("expected valid options object");function n(o,i,a){if(!a&&i!=="function"&&!Object.hasOwn(r,o))throw new TypeError(`param "${o}" is invalid: expected own property`);let c=r[o];if(a&&c===void 0)return;let u=typeof c;if(u!==i||c===null)throw new TypeError(`param "${o}" is invalid: expected ${i}, got ${u}`)}let s=(o,i)=>Object.entries(o).forEach(([a,c])=>n(a,c,i));s(e,!1),s(t,!0)}var js=()=>{throw new Error("not implemented")};var be=BigInt(0),ie=BigInt(1),Vt=BigInt(2),jc=BigInt(3),Gc=BigInt(4),Yc=BigInt(5),Rd=BigInt(7),Zc=BigInt(8),Od=BigInt(9),Xc=BigInt(16);function ue(r,e){if(e<=be)throw new Error("mod: expected positive modulus, got "+e);let t=r%e;return t>=be?t:e+t}function te(r,e,t){if(e<be)throw new Error("pow2: expected non-negative exponent, got "+e);let n=r;for(;e-- >be;)n*=n,n%=t;return n}function Hc(r,e){if(r===be)throw new Error("invert: expected non-zero number");if(e<=be)throw new Error("invert: expected positive modulus, got "+e);let t=ue(r,e),n=e,s=be,o=ie,i=ie,a=be;for(;t!==be;){let u=n/t,l=n-t*u,f=s-i*u,p=o-a*u;n=t,t=l,s=i,o=a,i=f,a=p}if(n!==ie)throw new Error("invert: does not exist");return ue(s,e)}function Gs(r,e,t){let n=r;if(!n.eql(n.sqr(e),t))throw new Error("Cannot find square root")}function Qc(r,e){let t=r,n=(t.ORDER+ie)/Gc,s=t.pow(e,n);return Gs(t,s,e),s}function Pd(r,e){let t=r,n=(t.ORDER-Yc)/Zc,s=t.mul(e,Vt),o=t.pow(s,n),i=t.mul(e,o),a=t.mul(t.mul(i,Vt),o),c=t.mul(i,t.sub(a,t.ONE));return Gs(t,c,e),c}function Nd(r){let e=Er(r),t=Jc(r),n=t(e,e.neg(e.ONE)),s=t(e,n),o=t(e,e.neg(n)),i=(r+Rd)/Xc;return((a,c)=>{let u=a,l=u.pow(c,i),f=u.mul(l,n),p=u.mul(l,s),d=u.mul(l,o),y=u.eql(u.sqr(f),c),x=u.eql(u.sqr(p),c);l=u.cmov(l,f,y),f=u.cmov(d,p,x);let h=u.eql(u.sqr(f),c),g=u.cmov(l,f,h);return Gs(u,g,c),g})}function Jc(r){if(r<jc)throw new Error("sqrt is not defined for small field");let e=r-ie,t=0;for(;e%Vt===be;)e/=Vt,t++;let n=Vt,s=Er(r);for(;$c(s,n)===1;)if(n++>1e3)throw new Error("Cannot find square root: probably non-prime P");if(t===1)return Qc;let o=s.pow(n,e),i=(e+ie)/Vt;return function(c,u){let l=c;if(l.is0(u))return u;if($c(l,u)!==1)throw new Error("Cannot find square root");let f=t,p=l.mul(l.ONE,o),d=l.pow(u,e),y=l.pow(u,i);for(;!l.eql(d,l.ONE);){if(l.is0(d))return l.ZERO;let x=1,h=l.sqr(d);for(;!l.eql(h,l.ONE);)if(x++,h=l.sqr(h),x===f)throw new Error("Cannot find square root");let g=ie<<BigInt(f-x-1),S=l.pow(p,g);f=x,p=l.sqr(S),d=l.mul(d,p),y=l.mul(y,S)}return y}}function Ud(r){return r%Gc===jc?Qc:r%Zc===Yc?Pd:r%Xc===Od?Nd(r):Jc(r)}var ft=(r,e)=>(ue(r,e)&ie)===ie,kd=["create","isValid","is0","neg","inv","sqrt","sqr","eql","add","sub","mul","pow","div","addN","subN","mulN","sqrN"];function Ys(r){let e={ORDER:"bigint",BYTES:"number",BITS:"number"},t=kd.reduce((n,s)=>(n[s]="function",n),e);if(He(r,t),Ve(r.BYTES,"BYTES"),Ve(r.BITS,"BITS"),r.BYTES<1||r.BITS<1)throw new Error("invalid field: expected BYTES/BITS > 0");if(r.ORDER<=ie)throw new Error("invalid field: expected ORDER > 1, got "+r.ORDER);return r}function Md(r,e,t){let n=r;if(t<be)throw new Error("invalid exponent, negatives unsupported");if(t===be)return n.ONE;if(t===ie)return e;let s=n.ONE,o=e;for(;t>be;)t&ie&&(s=n.mul(s,o)),o=n.sqr(o),t>>=ie;return s}function tn(r,e,t=!1){let n=r,s=new Array(e.length).fill(t?n.ZERO:void 0),o=e.reduce((a,c,u)=>n.is0(c)?a:(s[u]=a,n.mul(a,c)),n.ONE),i=n.inv(o);return e.reduceRight((a,c,u)=>n.is0(c)?a:(s[u]=n.mul(a,s[u]),n.mul(a,c)),i),s}function $c(r,e){let t=r,n=(t.ORDER-ie)/Vt,s=t.pow(e,n),o=t.eql(s,t.ONE),i=t.eql(s,t.ZERO),a=t.eql(s,t.neg(t.ONE));if(!o&&!i&&!a)throw new Error("invalid Legendre symbol result");return o?1:i?0:-1}function Fd(r,e){if(e!==void 0&&$s(e),r<=be)throw new Error("invalid n length: expected positive n, got "+r);if(e!==void 0&&e<1)throw new Error("invalid n length: expected positive bit length, got "+e);let t=xr(r);if(e!==void 0&&e<t)throw new Error(`invalid n length: expected bit length (${t}) >= n.length (${e})`);let n=e!==void 0?e:t,s=Math.ceil(n/8);return{nBitLength:n,nByteLength:s}}var Wc=new WeakMap,Zn=class{ORDER;BITS;BYTES;isLE;ZERO=be;ONE=ie;_lengths;_mod;constructor(e,t={}){if(e<=ie)throw new Error("invalid field: expected ORDER > 1, got "+e);let n;this.isLE=!1,t!=null&&typeof t=="object"&&(typeof t.BITS=="number"&&(n=t.BITS),typeof t.sqrt=="function"&&Object.defineProperty(this,"sqrt",{value:t.sqrt,enumerable:!0}),typeof t.isLE=="boolean"&&(this.isLE=t.isLE),t.allowedLengths&&(this._lengths=Object.freeze(t.allowedLengths.slice())),typeof t.modFromBytes=="boolean"&&(this._mod=t.modFromBytes));let{nBitLength:s,nByteLength:o}=Fd(e,n);if(o>2048)throw new Error("invalid field: expected ORDER of <= 2048 bytes");this.ORDER=e,this.BITS=s,this.BYTES=o,Object.freeze(this)}create(e){return ue(e,this.ORDER)}isValid(e){if(typeof e!="bigint")throw new TypeError("invalid field element: expected bigint, got "+typeof e);return be<=e&&e<this.ORDER}is0(e){return e===be}isValidNot0(e){return!this.is0(e)&&this.isValid(e)}isOdd(e){return(e&ie)===ie}neg(e){return ue(-e,this.ORDER)}eql(e,t){return e===t}sqr(e){return ue(e*e,this.ORDER)}add(e,t){return ue(e+t,this.ORDER)}sub(e,t){return ue(e-t,this.ORDER)}mul(e,t){return ue(e*t,this.ORDER)}pow(e,t){return Md(this,e,t)}div(e,t){return ue(e*Hc(t,this.ORDER),this.ORDER)}sqrN(e){return e*e}addN(e,t){return e+t}subN(e,t){return e-t}mulN(e,t){return e*t}inv(e){return Hc(e,this.ORDER)}sqrt(e){let t=Wc.get(this);return t||Wc.set(this,t=Ud(this.ORDER)),t(this,e)}toBytes(e){return this.isLE?Ws(e,this.BYTES):Gn(e,this.BYTES)}fromBytes(e,t=!1){H(e);let{_lengths:n,BYTES:s,isLE:o,ORDER:i,_mod:a}=this;if(n){if(e.length<1||!n.includes(e.length)||e.length>s)throw new Error("Field.fromBytes: expected "+n+" bytes, got "+e.length);let u=new Uint8Array(s);u.set(e,o?0:u.length-e.length),e=u}if(e.length!==s)throw new Error("Field.fromBytes: expected "+s+" bytes, got "+e.length);let c=o?et(e):zt(e);if(a&&(c=ue(c,i)),!t&&!this.isValid(c))throw new Error("invalid field element: outside of range 0..ORDER");return c}invertBatch(e){return tn(this,e)}cmov(e,t,n){return ze(n,"condition"),n?t:e}};Object.freeze(Zn.prototype);function Er(r,e={}){return new Zn(r,e)}function eu(r){if(typeof r!="bigint")throw new Error("field order must be bigint");if(r<=ie)throw new Error("field order must be greater than 1");let e=xr(r-ie);return Math.ceil(e/8)}function Zs(r){let e=eu(r);return e+Math.ceil(e/2)}function Xs(r,e,t=!1){H(r);let n=r.length,s=eu(e),o=Math.max(Zs(e),16);if(n<o||n>1024)throw new Error("expected "+o+"-1024 bytes of input, got "+n);let i=t?et(r):zt(r),a=ue(i,e-ie)+ie;return t?Ws(a,s):Gn(a,s)}var Sr=BigInt(0),Ht=BigInt(1);function rn(r,e){let t=e.negate();return r?t:e}function $t(r,e){let t=tn(r.Fp,e.map(n=>n.Z));return e.map((n,s)=>r.fromAffine(n.toAffine(t[s])))}function ou(r,e){if(!Number.isSafeInteger(r)||r<=0||r>e)throw new Error("invalid window size, expected [1.."+e+"], got W="+r)}function Qs(r,e){ou(r,e);let t=Math.ceil(e/r)+1,n=2**(r-1),s=2**r,o=en(r),i=BigInt(r);return{windows:t,windowSize:n,mask:o,maxNumber:s,shiftBy:i}}function tu(r,e,t){let{windowSize:n,mask:s,maxNumber:o,shiftBy:i}=t,a=Number(r&s),c=r>>i;a>n&&(a-=o,c+=Ht);let u=e*n,l=u+Math.abs(a)-1,f=a===0,p=a<0,d=e%2!==0;return{nextN:c,offset:l,isZero:f,isNeg:p,isNegF:d,offsetF:u}}var Js=new WeakMap,su=new WeakMap;function ei(r){return su.get(r)||1}function ru(r){if(r!==Sr)throw new Error("invalid wNAF")}var vr=class{BASE;ZERO;Fn;bits;constructor(e,t){this.BASE=e.BASE,this.ZERO=e.ZERO,this.Fn=e.Fn,this.bits=t}_unsafeLadder(e,t,n=this.ZERO){let s=e;for(;t>Sr;)t&Ht&&(n=n.add(s)),s=s.double(),t>>=Ht;return n}precomputeWindow(e,t){let{windows:n,windowSize:s}=Qs(t,this.bits),o=[],i=e,a=i;for(let c=0;c<n;c++){a=i,o.push(a);for(let u=1;u<s;u++)a=a.add(i),o.push(a);i=a.double()}return o}wNAF(e,t,n){if(!this.Fn.isValid(n))throw new Error("invalid scalar");let s=this.ZERO,o=this.BASE,i=Qs(e,this.bits);for(let a=0;a<i.windows;a++){let{nextN:c,offset:u,isZero:l,isNeg:f,isNegF:p,offsetF:d}=tu(n,a,i);n=c,l?o=o.add(rn(p,t[d])):s=s.add(rn(f,t[u]))}return ru(n),{p:s,f:o}}wNAFUnsafe(e,t,n,s=this.ZERO){let o=Qs(e,this.bits);for(let i=0;i<o.windows&&n!==Sr;i++){let{nextN:a,offset:c,isZero:u,isNeg:l}=tu(n,i,o);if(n=a,!u){let f=t[c];s=s.add(l?f.negate():f)}}return ru(n),s}getPrecomputes(e,t,n){let s=Js.get(t);return s||(s=this.precomputeWindow(t,e),e!==1&&(typeof n=="function"&&(s=n(s)),Js.set(t,s))),s}cached(e,t,n){let s=ei(e);return this.wNAF(s,this.getPrecomputes(s,e,n),t)}unsafe(e,t,n,s){let o=ei(e);return o===1?this._unsafeLadder(e,t,s):this.wNAFUnsafe(o,this.getPrecomputes(o,e,n),t,s)}createCache(e,t){ou(t,this.bits),su.set(e,t),Js.delete(e)}hasCache(e){return ei(e)!==1}};function iu(r,e,t,n){let s=e,o=r.ZERO,i=r.ZERO;for(;t>Sr||n>Sr;)t&Ht&&(o=o.add(s)),n&Ht&&(i=i.add(s)),s=s.double(),t>>=Ht,n>>=Ht;return{p1:o,p2:i}}function nu(r,e,t){if(e){if(e.ORDER!==r)throw new Error("Field.ORDER must match order: Fp == p, Fn == n");return Ys(e),e}else return Er(r,{isLE:t})}function Xn(r,e,t={},n){if(n===void 0&&(n=r==="edwards"),!e||typeof e!="object")throw new Error(`expected valid ${r} CURVE object`);for(let c of["p","n","h"]){let u=e[c];if(!(typeof u=="bigint"&&u>Sr))throw new Error(`CURVE.${c} must be positive bigint`)}let s=nu(e.p,t.Fp,n),o=nu(e.n,t.Fn,n),a=["Gx","Gy","a",r==="weierstrass"?"b":"d"];for(let c of a)if(!s.isValid(e[c]))throw new Error(`CURVE.${c} must be valid field element of CURVE.Fp`);return e=Object.freeze(Object.assign({},e)),{CURVE:e,Fp:s,Fn:o}}function Qn(r,e){return function(n){let s=r(n);return{secretKey:s,publicKey:e(s)}}}var _t=BigInt(0),me=BigInt(1),ti=BigInt(2),Kd=BigInt(8);function qd(r,e,t,n){let s=r.sqr(t),o=r.sqr(n),i=r.add(r.mul(e.a,s),o),a=r.add(r.ONE,r.mul(e.d,r.mul(s,o)));return r.eql(i,a)}function au(r,e={}){let t=e,n=Xn("edwards",r,t,t.FpFnLE),{Fp:s,Fn:o}=n,i=n.CURVE,{h:a}=i;He(t,{},{uvRatio:"function"});let c=ti<<BigInt(o.BYTES*8)-me,u=x=>s.create(x),l=t.uvRatio===void 0?(x,h)=>{try{return{isValid:!0,value:s.sqrt(s.div(x,h))}}catch{return{isValid:!1,value:_t}}}:t.uvRatio;if(!qd(s,i,i.Gx,i.Gy))throw new Error("bad curve params: generator point");function f(x,h,g=!1){let S=g?me:_t;return wr("coordinate "+x,h,S,c),h}function p(x){if(!(x instanceof d))throw new Error("EdwardsPoint expected")}class d{static BASE=new d(i.Gx,i.Gy,me,u(i.Gx*i.Gy));static ZERO=new d(_t,me,me,_t);static Fp=s;static Fn=o;X;Y;Z;T;constructor(h,g,S,_){this.X=f("x",h),this.Y=f("y",g),this.Z=f("z",S,!0),this.T=f("t",_),Object.freeze(this)}static CURVE(){return i}static fromAffine(h){if(h instanceof d)throw new Error("extended point not allowed");let{x:g,y:S}=h||{};return f("x",g),f("y",S),new d(g,S,me,u(g*S))}static fromBytes(h,g=!1){let S=s.BYTES,{a:_,d:B}=i;h=Jr(H(h,S,"point")),ze(g,"zip215");let C=Jr(h),N=h[S-1];C[S-1]=N&-129;let R=et(C),I=g?c:s.ORDER;wr("point.y",R,_t,I);let U=u(R*R),Z=u(U-me),M=u(B*U-_),{isValid:m,value:b}=l(Z,M);if(!m)throw new Error("bad point: invalid y coordinate");let v=(b&me)===me,E=(N&128)!==0;if(!g&&b===_t&&E)throw new Error("bad point: x=0 and x_0=1");return E!==v&&(b=u(-b)),d.fromAffine({x:b,y:R})}static fromHex(h,g=!1){return d.fromBytes(br(h),g)}get x(){return this.toAffine().x}get y(){return this.toAffine().y}precompute(h=8,g=!0){return y.createCache(this,h),g||this.multiply(ti),this}assertValidity(){let h=this,{a:g,d:S}=i;if(h.is0())throw new Error("bad point: ZERO");let{X:_,Y:B,Z:C,T:N}=h,R=u(_*_),I=u(B*B),U=u(C*C),Z=u(U*U),M=u(R*g),m=u(U*u(M+I)),b=u(Z+u(S*u(R*I)));if(m!==b)throw new Error("bad point: equation left != right (1)");let v=u(_*B),E=u(C*N);if(v!==E)throw new Error("bad point: equation left != right (2)")}equals(h){p(h);let{X:g,Y:S,Z:_}=this,{X:B,Y:C,Z:N}=h,R=u(g*N),I=u(B*_),U=u(S*N),Z=u(C*_);return R===I&&U===Z}is0(){return this.equals(d.ZERO)}negate(){return new d(u(-this.X),this.Y,this.Z,u(-this.T))}double(){let{a:h}=i,{X:g,Y:S,Z:_}=this,B=u(g*g),C=u(S*S),N=u(ti*u(_*_)),R=u(h*B),I=g+S,U=u(u(I*I)-B-C),Z=R+C,M=Z-N,m=R-C,b=u(U*M),v=u(Z*m),E=u(U*m),w=u(M*Z);return new d(b,v,w,E)}add(h){p(h);let{a:g,d:S}=i,{X:_,Y:B,Z:C,T:N}=this,{X:R,Y:I,Z:U,T:Z}=h,M=u(_*R),m=u(B*I),b=u(N*S*Z),v=u(C*U),E=u((_+B)*(R+I)-M-m),w=v-b,A=v+b,D=u(m-g*M),T=u(E*w),L=u(A*D),P=u(E*D),z=u(w*A);return new d(T,L,z,P)}subtract(h){return p(h),this.add(h.negate())}multiply(h){if(!o.isValidNot0(h))throw new RangeError("invalid scalar: expected 1 <= sc < curve.n");let{p:g,f:S}=y.cached(this,h,_=>$t(d,_));return $t(d,[g,S])[0]}multiplyUnsafe(h){if(!o.isValid(h))throw new RangeError("invalid scalar: expected 0 <= sc < curve.n");return h===_t?d.ZERO:this.is0()||h===me?this:y.unsafe(this,h,g=>$t(d,g))}isSmallOrder(){return this.clearCofactor().is0()}isTorsionFree(){return y.unsafe(this,i.n).is0()}toAffine(h){let g=this,S=h,{X:_,Y:B,Z:C}=g,N=g.is0();S==null&&(S=N?Kd:s.inv(C));let R=u(_*S),I=u(B*S),U=s.mul(C,S);if(N)return{x:_t,y:me};if(U!==me)throw new Error("invZ was invalid");return{x:R,y:I}}clearCofactor(){return a===me?this:this.multiplyUnsafe(a)}toBytes(){let{x:h,y:g}=this.toAffine(),S=s.toBytes(g);return S[S.length-1]|=h&me?128:0,S}toHex(){return gr(this.toBytes())}toString(){return`<Point ${this.is0()?"ZERO":this.toHex()}>`}}let y=new vr(d,o.BITS);return o.BITS>=8&&d.BASE.precompute(8),Object.freeze(d.prototype),Object.freeze(d),d}var Jn=class{static BASE;static ZERO;static Fp;static Fn;ep;constructor(e){this.ep=e}static fromBytes(e){js()}static fromHex(e){js()}get x(){return this.toAffine().x}get y(){return this.toAffine().y}clearCofactor(){return this}assertValidity(){this.ep.assertValidity()}toAffine(e){return this.ep.toAffine(e)}toHex(){return gr(this.toBytes())}toString(){return this.toHex()}isTorsionFree(){return!0}isSmallOrder(){return!1}add(e){return this.assertSame(e),this.init(this.ep.add(e.ep))}subtract(e){return this.assertSame(e),this.init(this.ep.subtract(e.ep))}multiply(e){return this.init(this.ep.multiply(e))}multiplyUnsafe(e){return this.init(this.ep.multiplyUnsafe(e))}double(){return this.init(this.ep.double())}negate(){return this.init(this.ep.negate())}precompute(e,t){return this.ep.precompute(e,t),this}};function cu(r,e,t={}){if(typeof e!="function")throw new Error('"hash" function param is required');let n=e,s=t;He(s,{},{adjustScalarBytes:"function",randomBytes:"function",domain:"function",prehash:"function",zip215:"boolean",mapToCurve:"function"});let{prehash:o}=s,{BASE:i,Fp:a,Fn:c}=r,u=n.outputLen,l=2*a.BYTES;if(u!==void 0&&(Ve(u,"hash.outputLen"),u!==l))throw new Error(`hash.outputLen must be ${l}, got ${u}`);let f=s.randomBytes===void 0?Xr:s.randomBytes,p=s.adjustScalarBytes===void 0?m=>m:s.adjustScalarBytes,d=s.domain===void 0?(m,b,v)=>{if(ze(v,"phflag"),b.length||v)throw new Error("Contexts/pre-hash are not supported");return m}:s.domain;function y(m){return c.create(et(m))}function x(m){let b=R.secretKey;H(m,R.secretKey,"secretKey");let v=H(n(m),2*b,"hashedSecretKey"),E=p(v.slice(0,b)),w=v.slice(b,2*b),A=y(E);return{head:E,prefix:w,scalar:A}}function h(m){let{head:b,prefix:v,scalar:E}=x(m),w=i.multiply(E),A=w.toBytes();return{head:b,prefix:v,scalar:E,point:w,pointBytes:A}}function g(m){return h(m).pointBytes}function S(m=Uint8Array.of(),...b){let v=de(...b);return y(n(d(v,H(m,void 0,"context"),!!o)))}function _(m,b,v={}){m=H(m,void 0,"message"),o&&(m=o(m));let{prefix:E,scalar:w,pointBytes:A}=h(b),D=S(v.context,E,m),T=i.multiply(D).toBytes(),L=S(v.context,T,A,m),P=c.create(D+L*w);if(!c.isValid(P))throw new Error("sign failed: invalid s");let z=de(T,c.toBytes(P));return H(z,R.signature,"result")}let B={zip215:s.zip215};function C(m,b,v,E=B){let{context:w}=E,A=E.zip215===void 0?!!B.zip215:E.zip215,D=R.signature;m=H(m,D,"signature"),b=H(b,void 0,"message"),v=H(v,R.publicKey,"publicKey"),A!==void 0&&ze(A,"zip215"),o&&(b=o(b));let T=D/2,L=m.subarray(0,T),P=et(m.subarray(T,D)),z,j,K;try{z=r.fromBytes(v,A),j=r.fromBytes(L,A),K=i.multiplyUnsafe(P)}catch{return!1}if(!A&&z.isSmallOrder())return!1;let fe=S(w,L,v,b);return j.add(z.multiplyUnsafe(fe)).subtract(K).clearCofactor().is0()}let N=a.BYTES,R={secretKey:N,publicKey:N,signature:2*N,seed:N};function I(m){return m=m===void 0?f(R.seed):m,H(m,R.seed,"seed")}function U(m){return qt(m)&&m.length===R.secretKey}function Z(m,b){try{return!!r.fromBytes(m,b===void 0?B.zip215:b)}catch{return!1}}let M={getExtendedPublicKey:h,randomSecretKey:I,isValidSecretKey:U,isValidPublicKey:Z,toMontgomery(m){let{y:b}=r.fromBytes(m),v=R.publicKey,E=v===32;if(!E&&v!==57)throw new Error("only defined for 25519 and 448");let w=E?a.div(me+b,me-b):a.div(b-me,b+me);return a.toBytes(w)},toMontgomerySecret(m){let b=R.secretKey;H(m,b);let v=n(m.subarray(0,b));return p(v).subarray(0,b)}};return Object.freeze(R),Object.freeze(M),Object.freeze({keygen:Qn(I,g),getPublicKey:g,sign:_,verify:C,utils:M,Point:r,lengths:R})}function nn(r,e){if(Ve(r),Ve(e),e<0||e>4)throw new Error("invalid I2OSP length: "+e);if(r<0||r>2**(8*e)-1)throw new Error("invalid I2OSP input: "+r);let t=Array.from({length:e}).fill(0);for(let n=e-1;n>=0;n--)t[n]=r&255,r>>>=8;return new Uint8Array(t)}function zd(r,e){let t=new Uint8Array(r.length);for(let n=0;n<r.length;n++)t[n]=r[n]^e[n];return t}function Vd(r){if(!qt(r)&&typeof r!="string")throw new Error("DST must be Uint8Array or ascii string");let e=typeof r=="string"?Yn(r):r;if(e.length===0)throw new Error("DST must be non-empty");return e}function ri(r,e,t,n){H(r),Ve(t),e=Vd(e),e.length>255&&(e=n(de(Yn("H2C-OVERSIZE-DST-"),e)));let{outputLen:s,blockLen:o}=n,i=Math.ceil(t/s);if(t>65535||i>255)throw new Error("expand_message_xmd: invalid lenInBytes");let a=de(e,nn(e.length,1)),c=new Uint8Array(o),u=nn(t,2),l=new Array(i),f=n(de(c,r,u,nn(0,1),a));l[0]=n(de(f,nn(1,1),a));for(let d=1;d<i;d++){let y=[zd(f,l[d-1]),nn(d+1,1),a];l[d]=n(de(...y))}return de(...l).slice(0,t)}var uu="HashToScalar-";var Hd=BigInt(0),dt=BigInt(1),lu=BigInt(2);var $d=BigInt(5),Wd=BigInt(8),_r=BigInt("0x7fffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffed"),ii={p:_r,n:BigInt("0x1000000000000000000000000000000014def9dea2f79cd65812631a5cf5d3ed"),h:Wd,a:BigInt("0x7fffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffec"),d:BigInt("0x52036cee2b6ffe738cc740797779e89800700a4d4141d8ab75eb4dca135978a3"),Gx:BigInt("0x216936d3cd6e53fec0a4e231fdd6dc5c692cc7609525a7b2c9562d608f25d51a"),Gy:BigInt("0x6666666666666666666666666666666666666666666666666666666666666658")};function jd(r){let e=BigInt(10),t=BigInt(20),n=BigInt(40),s=BigInt(80),o=_r,a=r*r%o*r%o,c=te(a,lu,o)*a%o,u=te(c,dt,o)*r%o,l=te(u,$d,o)*u%o,f=te(l,e,o)*l%o,p=te(f,t,o)*f%o,d=te(p,n,o)*p%o,y=te(d,s,o)*d%o,x=te(y,s,o)*d%o,h=te(x,e,o)*l%o;return{pow_p_5_8:te(h,lu,o)*r%o,b2:a}}function Gd(r){return r[0]&=248,r[31]&=127,r[31]|=64,r}var ni=BigInt("19681161376707505956807079304988542015446066515923890162744021073123829784752");function ai(r,e){let t=_r,n=ue(e*e*e,t),s=ue(n*n*e,t),o=jd(r*s).pow_p_5_8,i=ue(r*n*o,t),a=ue(e*i*i,t),c=i,u=ue(i*ni,t),l=a===r,f=a===ue(-r,t),p=a===ue(-r*ni,t);return l&&(i=c),(f||p)&&(i=u),ft(i,t)&&(i=ue(-i,t)),{isValid:l||f,value:i}}var Tt=au(ii,{uvRatio:ai}),At=Tt.Fp,hu=Tt.Fn;function Yd(r){return cu(Tt,Hn,Object.assign({adjustScalarBytes:Gd,zip215:!0},r))}var pu=Yd({});var oi=ni,Zd=BigInt("25063068953384623474111414158702152701244531502492656460079210482610430750235"),Xd=BigInt("54469307008909316920995813868745141605393597292927456921205312896311721017578"),Qd=BigInt("1159843021668779879193775521855586647937357759715417654439879720876111806838"),Jd=BigInt("40440834346308536858101042469323190826248399146238708352240133220865137265952"),fu=r=>ai(dt,r),eh=BigInt("0x7fffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffff"),si=r=>At.create(et(r)&eh);function du(r){let{d:e}=ii,t=_r,n=g=>At.create(g),s=n(oi*r*r),o=n((s+dt)*Qd),i=BigInt(-1),a=n((i-e*s)*n(s+e)),{isValid:c,value:u}=ai(o,a),l=n(u*r);ft(l,t)||(l=n(-l)),c||(u=l),c||(i=s);let f=n(i*(s-dt)*Jd-a),p=u*u,d=n((u+u)*a),y=n(f*Zd),x=n(dt-p),h=n(dt+p);return new Tt(n(d*h),n(x*y),n(y*h),n(d*x))}var It=class r extends Jn{static BASE=new r(Tt.BASE);static ZERO=new r(Tt.ZERO);static Fp=At;static Fn=hu;constructor(e){super(e)}static fromAffine(e){return new r(Tt.fromAffine(e))}assertSame(e){if(!(e instanceof r))throw new Error("RistrettoPoint expected")}init(e){return new r(e)}static fromBytes(e){Pe(e,32);let{a:t,d:n}=ii,s=_r,o=B=>At.create(B),i=si(e);if(!zc(At.toBytes(i),e)||ft(i,s))throw new Error("invalid ristretto255 encoding 1");let a=o(i*i),c=o(dt+t*a),u=o(dt-t*a),l=o(c*c),f=o(u*u),p=o(t*n*l-f),{isValid:d,value:y}=fu(o(p*f)),x=o(y*u),h=o(y*x*p),g=o((i+i)*x);ft(g,s)&&(g=o(-g));let S=o(c*h),_=o(g*S);if(!d||ft(_,s)||S===Hd)throw new Error("invalid ristretto255 encoding 2");return new r(new Tt(g,S,dt,_))}static fromHex(e){return r.fromBytes(jr(e))}toBytes(){let{X:e,Y:t,Z:n,T:s}=this.ep,o=_r,i=h=>At.create(h),a=i(i(n+t)*i(n-t)),c=i(e*t),u=i(c*c),{value:l}=fu(i(a*u)),f=i(l*a),p=i(l*c),d=i(f*p*s),y;if(ft(s*d,o)){let h=i(t*oi),g=i(e*oi);e=h,t=g,y=i(f*Xd)}else y=p;ft(e*d,o)&&(t=i(-t));let x=i((n-t)*y);return ft(x,o)&&(x=i(-x)),At.toBytes(x)}equals(e){this.assertSame(e);let{X:t,Y:n}=this.ep,{X:s,Y:o}=e.ep,i=u=>At.create(u),a=i(t*o)===i(n*s),c=i(n*o)===i(t*s);return a||c}is0(){return this.equals(r.ZERO)}};Object.freeze(It.BASE);Object.freeze(It.ZERO);Object.freeze(It.prototype);Object.freeze(It);var th=Object.freeze({Point:It,hashToCurve(r,e){let t=e?.DST===void 0?"ristretto255_XMD:SHA-512_R255MAP_RO_":e.DST,n=ri(r,t,64,Hn);return th.deriveToCurve(n)},hashToScalar(r,e={DST:uu}){let t=ri(r,e.DST,64,Hn);return hu.create(et(t))},deriveToCurve(r){Pe(r,64);let e=si(r.subarray(0,32)),t=du(e),n=si(r.subarray(32,64)),s=du(n);return new It(t.add(s))}});var on=class extends Error{constructor(e="An error occurred while verifying a message"){super(e),this.name="VerificationError"}},eo=class extends Error{constructor(e="Missing Web Crypto API"){super(e),this.name="WebCryptoMissingError"}};var Me={get(r=globalThis){let e=r.crypto;if(e?.subtle==null)throw new eo("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 e}};var to=32;var ci,rh=(async()=>{try{return await Me.get().subtle.generateKey({name:"Ed25519"},!0,["sign","verify"]),!0}catch{return!1}})();async function nh(r,e,t){if(r.buffer instanceof ArrayBuffer){let n=await Me.get().subtle.importKey("raw",r.buffer,{name:"Ed25519"},!1,["verify"]);return await Me.get().subtle.verify({name:"Ed25519"},n,_e(e),_e(t instanceof Uint8Array?t:t.subarray()))}throw new TypeError("WebCrypto does not support SharedArrayBuffer for Ed25519 keys")}function oh(r,e,t){return pu.verify(e,t instanceof Uint8Array?t:t.subarray(),r)}async function mu(r,e,t){return ci==null&&(ci=await rh),ci?nh(r,e,t):oh(r,e,t)}function ro(r){return r==null?!1:typeof r.then=="function"&&typeof r.catch=="function"&&typeof r.finally=="function"}var no=class{type="Ed25519";raw;constructor(e){this.raw=ui(e,to)}toMultihash(){return Ke.digest(Qe(this))}toCID(){return le.createV1(114,this.toMultihash())}toString(){return re.encode(this.toMultihash().bytes).substring(1)}equals(e){return e==null||!(e.raw instanceof Uint8Array)?!1:ce(this.raw,e.raw)}verify(e,t,n){n?.signal?.throwIfAborted();let s=mu(this.raw,t,e);return ro(s)?s.then(o=>(n?.signal?.throwIfAborted(),o)):s}};function li(r){return r=ui(r,to),new no(r)}function ui(r,e){if(r=Uint8Array.from(r??[]),r.length!==e)throw new oe(`Key must be a Uint8Array of length ${e}, got ${r.length}`);return r}var ih=Math.pow(2,7),ah=Math.pow(2,14),ch=Math.pow(2,21),fi=Math.pow(2,28),di=Math.pow(2,35),hi=Math.pow(2,42),pi=Math.pow(2,49),G=128,Ee=127;function Ce(r){if(r<ih)return 1;if(r<ah)return 2;if(r<ch)return 3;if(r<fi)return 4;if(r<di)return 5;if(r<hi)return 6;if(r<pi)return 7;if(Number.MAX_SAFE_INTEGER!=null&&r>Number.MAX_SAFE_INTEGER)throw new RangeError("Could not encode varint");return 8}function Ar(r,e,t=0){switch(Ce(r)){case 8:e[t++]=r&255|G,r/=128;case 7:e[t++]=r&255|G,r/=128;case 6:e[t++]=r&255|G,r/=128;case 5:e[t++]=r&255|G,r/=128;case 4:e[t++]=r&255|G,r>>>=7;case 3:e[t++]=r&255|G,r>>>=7;case 2:e[t++]=r&255|G,r>>>=7;case 1:{e[t++]=r&255,r>>>=7;break}default:throw new Error("unreachable")}return e}function uh(r,e,t=0){switch(Ce(r)){case 8:e.set(t++,r&255|G),r/=128;case 7:e.set(t++,r&255|G),r/=128;case 6:e.set(t++,r&255|G),r/=128;case 5:e.set(t++,r&255|G),r/=128;case 4:e.set(t++,r&255|G),r>>>=7;case 3:e.set(t++,r&255|G),r>>>=7;case 2:e.set(t++,r&255|G),r>>>=7;case 1:{e.set(t++,r&255),r>>>=7;break}default:throw new Error("unreachable")}return e}function mi(r,e){let t=r[e],n=0;if(n+=t&Ee,t<G||(t=r[e+1],n+=(t&Ee)<<7,t<G)||(t=r[e+2],n+=(t&Ee)<<14,t<G)||(t=r[e+3],n+=(t&Ee)<<21,t<G)||(t=r[e+4],n+=(t&Ee)*fi,t<G)||(t=r[e+5],n+=(t&Ee)*di,t<G)||(t=r[e+6],n+=(t&Ee)*hi,t<G)||(t=r[e+7],n+=(t&Ee)*pi,t<G))return n;throw new RangeError("Could not decode varint")}function lh(r,e){let t=r.get(e),n=0;if(n+=t&Ee,t<G||(t=r.get(e+1),n+=(t&Ee)<<7,t<G)||(t=r.get(e+2),n+=(t&Ee)<<14,t<G)||(t=r.get(e+3),n+=(t&Ee)<<21,t<G)||(t=r.get(e+4),n+=(t&Ee)*fi,t<G)||(t=r.get(e+5),n+=(t&Ee)*di,t<G)||(t=r.get(e+6),n+=(t&Ee)*hi,t<G)||(t=r.get(e+7),n+=(t&Ee)*pi,t<G))return n;throw new RangeError("Could not decode varint")}function Tr(r,e,t=0){return e==null&&(e=xe(Ce(r))),e instanceof Uint8Array?Ar(r,e,t):uh(r,e,t)}function sn(r,e=0){return r instanceof Uint8Array?mi(r,e):lh(r,e)}var gi=new Float32Array([-0]),Dt=new Uint8Array(gi.buffer);function gu(r,e,t){gi[0]=r,e[t]=Dt[0],e[t+1]=Dt[1],e[t+2]=Dt[2],e[t+3]=Dt[3]}function bu(r,e){return Dt[0]=r[e],Dt[1]=r[e+1],Dt[2]=r[e+2],Dt[3]=r[e+3],gi[0]}var bi=new Float64Array([-0]),Se=new Uint8Array(bi.buffer);function wu(r,e,t){bi[0]=r,e[t]=Se[0],e[t+1]=Se[1],e[t+2]=Se[2],e[t+3]=Se[3],e[t+4]=Se[4],e[t+5]=Se[5],e[t+6]=Se[6],e[t+7]=Se[7]}function xu(r,e){return Se[0]=r[e],Se[1]=r[e+1],Se[2]=r[e+2],Se[3]=r[e+3],Se[4]=r[e+4],Se[5]=r[e+5],Se[6]=r[e+6],Se[7]=r[e+7],bi[0]}var fh=BigInt(Number.MAX_SAFE_INTEGER),dh=BigInt(Number.MIN_SAFE_INTEGER),Ne=class r{lo;hi;constructor(e,t){this.lo=e|0,this.hi=t|0}toNumber(e=!1){if(!e&&this.hi>>>31>0){let t=~this.lo+1>>>0,n=~this.hi>>>0;return t===0&&(n=n+1>>>0),-(t+n*4294967296)}return this.lo+this.hi*4294967296}toBigInt(e=!1){if(e)return BigInt(this.lo>>>0)+(BigInt(this.hi>>>0)<<32n);if(this.hi>>>31){let t=~this.lo+1>>>0,n=~this.hi>>>0;return t===0&&(n=n+1>>>0),-(BigInt(t)+(BigInt(n)<<32n))}return BigInt(this.lo>>>0)+(BigInt(this.hi>>>0)<<32n)}toString(e=!1){return this.toBigInt(e).toString()}zzEncode(){let e=this.hi>>31;return this.hi=((this.hi<<1|this.lo>>>31)^e)>>>0,this.lo=(this.lo<<1^e)>>>0,this}zzDecode(){let e=-(this.lo&1);return this.lo=((this.lo>>>1|this.hi<<31)^e)>>>0,this.hi=(this.hi>>>1^e)>>>0,this}length(){let e=this.lo,t=(this.lo>>>28|this.hi<<4)>>>0,n=this.hi>>>24;return n===0?t===0?e<16384?e<128?1:2:e<2097152?3:4:t<16384?t<128?5:6:t<2097152?7:8:n<128?9:10}static fromBigInt(e){if(e===0n)return Wt;if(e<fh&&e>dh)return this.fromNumber(Number(e));let t=e<0n;t&&(e=-e);let n=e>>32n,s=e-(n<<32n);return t&&(n=~n|0n,s=~s|0n,++s>Eu&&(s=0n,++n>Eu&&(n=0n))),new r(Number(s),Number(n))}static fromNumber(e){if(e===0)return Wt;let t=e<0;t&&(e=-e);let n=e>>>0,s=(e-n)/4294967296>>>0;return t&&(s=~s>>>0,n=~n>>>0,++n>4294967295&&(n=0,++s>4294967295&&(s=0))),new r(n,s)}static from(e){return typeof e=="number"?r.fromNumber(e):typeof e=="bigint"?r.fromBigInt(e):typeof e=="string"?r.fromBigInt(BigInt(e)):e.low!=null||e.high!=null?new r(e.low>>>0,e.high>>>0):Wt}},Wt=new Ne(0,0);Wt.toBigInt=function(){return 0n};Wt.zzEncode=Wt.zzDecode=function(){return this};Wt.length=function(){return 1};var Eu=4294967296n;function Su(r){let e=0,t=0;for(let n=0;n<r.length;++n)t=r.charCodeAt(n),t<128?e+=1:t<2048?e+=2:(t&64512)===55296&&(r.charCodeAt(n+1)&64512)===56320?(++n,e+=4):e+=3;return e}function vu(r,e,t){if(t-e<1)return"";let s,o=[],i=0,a;for(;e<t;)a=r[e++],a<128?o[i++]=a:a>191&&a<224?o[i++]=(a&31)<<6|r[e++]&63:a>239&&a<365?(a=((a&7)<<18|(r[e++]&63)<<12|(r[e++]&63)<<6|r[e++]&63)-65536,o[i++]=55296+(a>>10),o[i++]=56320+(a&1023)):o[i++]=(a&15)<<12|(r[e++]&63)<<6|r[e++]&63,i>8191&&((s??(s=[])).push(String.fromCharCode.apply(String,o)),i=0);return s!=null?(i>0&&s.push(String.fromCharCode.apply(String,o.slice(0,i))),s.join("")):String.fromCharCode.apply(String,o.slice(0,i))}function wi(r,e,t){let n=t,s,o;for(let i=0;i<r.length;++i)s=r.charCodeAt(i),s<128?e[t++]=s:s<2048?(e[t++]=s>>6|192,e[t++]=s&63|128):(s&64512)===55296&&((o=r.charCodeAt(i+1))&64512)===56320?(s=65536+((s&1023)<<10)+(o&1023),++i,e[t++]=s>>18|240,e[t++]=s>>12&63|128,e[t++]=s>>6&63|128,e[t++]=s&63|128):(e[t++]=s>>12|224,e[t++]=s>>6&63|128,e[t++]=s&63|128);return t-n}function $e(r,e){return RangeError(`index out of range: ${r.pos} + ${e??1} > ${r.len}`)}function oo(r,e){return(r[e-4]|r[e-3]<<8|r[e-2]<<16|r[e-1]<<24)>>>0}var xi=class{buf;pos;len;_slice=Uint8Array.prototype.subarray;constructor(e){this.buf=_e(e),this.pos=0,this.len=e.length}uint32(){let e=4294967295;if(e=(this.buf[this.pos]&127)>>>0,this.buf[this.pos++]<128||(e=(e|(this.buf[this.pos]&127)<<7)>>>0,this.buf[this.pos++]<128)||(e=(e|(this.buf[this.pos]&127)<<14)>>>0,this.buf[this.pos++]<128)||(e=(e|(this.buf[this.pos]&127)<<21)>>>0,this.buf[this.pos++]<128)||(e=(e|(this.buf[this.pos]&15)<<28)>>>0,this.buf[this.pos++]<128))return e;if((this.pos+=5)>this.len)throw this.pos=this.len,$e(this,10);return e}int32(){return this.uint32()|0}sint32(){let e=this.uint32();return e>>>1^-(e&1)|0}bool(){return this.uint32()!==0}fixed32(){if(this.pos+4>this.len)throw $e(this,4);return oo(this.buf,this.pos+=4)}sfixed32(){if(this.pos+4>this.len)throw $e(this,4);return oo(this.buf,this.pos+=4)|0}float(){if(this.pos+4>this.len)throw $e(this,4);let e=bu(this.buf,this.pos);return this.pos+=4,e}double(){if(this.pos+8>this.len)throw $e(this,4);let e=xu(this.buf,this.pos);return this.pos+=8,e}bytes(){let e=this.uint32(),t=this.pos,n=this.pos+e;if(n>this.len)throw $e(this,e);return this.pos+=e,t===n?new Uint8Array(0):this.buf.subarray(t,n)}string(){let e=this.bytes();return vu(e,0,e.length)}skip(e){if(typeof e=="number"){if(this.pos+e>this.len)throw $e(this,e);this.pos+=e}else do if(this.pos>=this.len)throw $e(this);while((this.buf[this.pos++]&128)!==0);return this}skipType(e){switch(e){case 0:this.skip();break;case 1:this.skip(8);break;case 2:this.skip(this.uint32());break;case 3:for(;(e=this.uint32()&7)!==4;)this.skipType(e);break;case 5:this.skip(4);break;default:throw Error(`invalid wire type ${e} at offset ${this.pos}`)}return this}readLongVarint(){let e=new Ne(0,0),t=0;if(this.len-this.pos>4){for(;t<4;++t)if(e.lo=(e.lo|(this.buf[this.pos]&127)<<t*7)>>>0,this.buf[this.pos++]<128)return e;if(e.lo=(e.lo|(this.buf[this.pos]&127)<<28)>>>0,e.hi=(e.hi|(this.buf[this.pos]&127)>>4)>>>0,this.buf[this.pos++]<128)return e;t=0}else{for(;t<3;++t){if(this.pos>=this.len)throw $e(this);if(e.lo=(e.lo|(this.buf[this.pos]&127)<<t*7)>>>0,this.buf[this.pos++]<128)return e}return e.lo=(e.lo|(this.buf[this.pos++]&127)<<t*7)>>>0,e}if(this.len-this.pos>4){for(;t<5;++t)if(e.hi=(e.hi|(this.buf[this.pos]&127)<<t*7+3)>>>0,this.buf[this.pos++]<128)return e}else for(;t<5;++t){if(this.pos>=this.len)throw $e(this);if(e.hi=(e.hi|(this.buf[this.pos]&127)<<t*7+3)>>>0,this.buf[this.pos++]<128)return e}throw Error("invalid varint encoding")}readFixed64(){if(this.pos+8>this.len)throw $e(this,8);let e=oo(this.buf,this.pos+=4),t=oo(this.buf,this.pos+=4);return new Ne(e,t)}int64(){return this.readLongVarint().toBigInt()}int64Number(){return this.readLongVarint().toNumber()}int64String(){return this.readLongVarint().toString()}uint64(){return this.readLongVarint().toBigInt(!0)}uint64Number(){let e=mi(this.buf,this.pos);return this.pos+=Ce(e),e}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 an(r){return new xi(r instanceof Uint8Array?r:r.subarray())}function Le(r,e,t){let n=an(r);return e.decode(n,void 0,t)}function Ei(r){let e=r??8192,t=e>>>1,n,s=e;return function(i){if(i<1||i>t)return xe(i);s+i>e&&(n=xe(e),s=0);let a=n.subarray(s,s+=i);return(s&7)!==0&&(s=(s|7)+1),a}}var jt=class{fn;len;next;val;constructor(e,t,n){this.fn=e,this.len=t,this.next=void 0,this.val=n}};function Si(){}var _i=class{head;tail;len;next;constructor(e){this.head=e.head,this.tail=e.tail,this.len=e.len,this.next=e.states}},hh=Ei();function ph(r){return globalThis.Buffer!=null?xe(r):hh(r)}var un=class{len;head;tail;states;constructor(){this.len=0,this.head=new jt(Si,0,0),this.tail=this.head,this.states=null}_push(e,t,n){return this.tail=this.tail.next=new jt(e,t,n),this.len+=t,this}uint32(e){return this.len+=(this.tail=this.tail.next=new Ai((e=e>>>0)<128?1:e<16384?2:e<2097152?3:e<268435456?4:5,e)).len,this}int32(e){return e<0?this._push(so,10,Ne.fromNumber(e)):this.uint32(e)}sint32(e){return this.uint32((e<<1^e>>31)>>>0)}uint64(e){let t=Ne.fromBigInt(e);return this._push(so,t.length(),t)}uint64Number(e){return this._push(Ar,Ce(e),e)}uint64String(e){return this.uint64(BigInt(e))}int64(e){return this.uint64(e)}int64Number(e){return this.uint64Number(e)}int64String(e){return this.uint64String(e)}sint64(e){let t=Ne.fromBigInt(e).zzEncode();return this._push(so,t.length(),t)}sint64Number(e){let t=Ne.fromNumber(e).zzEncode();return this._push(so,t.length(),t)}sint64String(e){return this.sint64(BigInt(e))}bool(e){return this._push(vi,1,e?1:0)}fixed32(e){return this._push(cn,4,e>>>0)}sfixed32(e){return this.fixed32(e)}fixed64(e){let t=Ne.fromBigInt(e);return this._push(cn,4,t.lo)._push(cn,4,t.hi)}fixed64Number(e){let t=Ne.fromNumber(e);return this._push(cn,4,t.lo)._push(cn,4,t.hi)}fixed64String(e){return this.fixed64(BigInt(e))}sfixed64(e){return this.fixed64(e)}sfixed64Number(e){return this.fixed64Number(e)}sfixed64String(e){return this.fixed64String(e)}float(e){return this._push(gu,4,e)}double(e){return this._push(wu,8,e)}bytes(e){let t=e.length>>>0;return t===0?this._push(vi,1,0):this.uint32(t)._push(yh,t,e)}string(e){let t=Su(e);return t!==0?this.uint32(t)._push(wi,t,e):this._push(vi,1,0)}fork(){return this.states=new _i(this),this.head=this.tail=new jt(Si,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 jt(Si,0,0),this.len=0),this}ldelim(){let e=this.head,t=this.tail,n=this.len;return this.reset().uint32(n),n!==0&&(this.tail.next=e.next,this.tail=t,this.len+=n),this}finish(){let e=this.head.next,t=ph(this.len),n=0;for(;e!=null;)e.fn(e.val,t,n),n+=e.len,e=e.next;return t}};function vi(r,e,t){e[t]=r&255}function mh(r,e,t){for(;r>127;)e[t++]=r&127|128,r>>>=7;e[t]=r}var Ai=class extends jt{next;constructor(e,t){super(mh,e,t),this.next=void 0}};function so(r,e,t){for(;r.hi!==0;)e[t++]=r.lo&127|128,r.lo=(r.lo>>>7|r.hi<<25)>>>0,r.hi>>>=7;for(;r.lo>127;)e[t++]=r.lo&127|128,r.lo=r.lo>>>7;e[t++]=r.lo}function cn(r,e,t){e[t]=r&255,e[t+1]=r>>>8&255,e[t+2]=r>>>16&255,e[t+3]=r>>>24}function yh(r,e,t){e.set(r,t)}globalThis.Buffer!=null&&(un.prototype.bytes=function(r){let e=r.length>>>0;return this.uint32(e),e>0&&this._push(gh,e,r),this},un.prototype.string=function(r){let e=globalThis.Buffer.byteLength(r);return this.uint32(e),e>0&&this._push(bh,e,r),this});function gh(r,e,t){e.set(r,t)}function bh(r,e,t){r.length<40?wi(r,e,t):e.utf8Write!=null?e.utf8Write(r,t):e.set(k(r),t)}function Ti(){return new un}function Be(r,e){let t=Ti();return e.encode(r,t,{lengthDelimited:!1}),t.finish()}function*Re(r,e,t){let n=an(r);yield*e.stream(n,void 0,"$",t)}var io={VARINT:0,BIT64:1,LENGTH_DELIMITED:2,START_GROUP:3,END_GROUP:4,BIT32:5};function ao(r,e,t,n,s){return{name:r,type:e,encode:t,decode:n,stream:s}}function Gt(r){function e(o){if(r[o.toString()]==null)throw new Error("Invalid enum value");return r[o]}let t=function(i,a){let c=e(i);a.int32(c)},n=function(i){let a=i.int32();return e(a)},s=function*(i){let a=i.int32();yield e(a)};return ao("enum",io.VARINT,t,n,s)}function Oe(r,e,t){return ao("message",io.LENGTH_DELIMITED,r,e,t)}var Yt=class extends Error{code="ERR_MAX_LENGTH";name="MaxLengthError"};var ne;(function(r){r.RSA="RSA",r.Ed25519="Ed25519",r.secp256k1="secp256k1",r.ECDSA="ECDSA"})(ne||(ne={}));var Ii;(function(r){r[r.RSA=0]="RSA",r[r.Ed25519=1]="Ed25519",r[r.secp256k1=2]="secp256k1",r[r.ECDSA=3]="ECDSA"})(Ii||(Ii={}));(function(r){r.codec=()=>Gt(Ii)})(ne||(ne={}));var tt;(function(r){let e;r.codec=()=>(e==null&&(e=Oe((o,i,a={})=>{a.lengthDelimited!==!1&&i.fork(),o.Type!=null&&(i.uint32(8),ne.codec().encode(o.Type,i)),o.Data!=null&&(i.uint32(18),i.bytes(o.Data)),a.lengthDelimited!==!1&&i.ldelim()},(o,i,a={})=>{let c={},u=i==null?o.len:o.pos+i;for(;o.pos<u;){let l=o.uint32();switch(l>>>3){case 1:{c.Type=ne.codec().decode(o);break}case 2:{c.Data=o.bytes();break}default:{o.skipType(l&7);break}}}return c},function*(o,i,a,c={}){let u=i==null?o.len:o.pos+i;for(;o.pos<u;){let l=o.uint32();switch(l>>>3){case 1:{yield{field:`${a}.Type`,value:ne.codec().decode(o)};break}case 2:{yield{field:`${a}.Data`,value:o.bytes()};break}default:{o.skipType(l&7);break}}}})),e);function t(o){return Be(o,r.codec())}r.encode=t;function n(o,i){return Le(o,r.codec(),i)}r.decode=n;function s(o,i){return Re(o,r.codec(),i)}r.stream=s})(tt||(tt={}));var Di;(function(r){let e;r.codec=()=>(e==null&&(e=Oe((o,i,a={})=>{a.lengthDelimited!==!1&&i.fork(),o.Type!=null&&(i.uint32(8),ne.codec().encode(o.Type,i)),o.Data!=null&&(i.uint32(18),i.bytes(o.Data)),a.lengthDelimited!==!1&&i.ldelim()},(o,i,a={})=>{let c={},u=i==null?o.len:o.pos+i;for(;o.pos<u;){let l=o.uint32();switch(l>>>3){case 1:{c.Type=ne.codec().decode(o);break}case 2:{c.Data=o.bytes();break}default:{o.skipType(l&7);break}}}return c},function*(o,i,a,c={}){let u=i==null?o.len:o.pos+i;for(;o.pos<u;){let l=o.uint32();switch(l>>>3){case 1:{yield{field:`${a}.Type`,value:ne.codec().decode(o)};break}case 2:{yield{field:`${a}.Data`,value:o.bytes()};break}default:{o.skipType(l&7);break}}}})),e);function t(o){return Be(o,r.codec())}r.encode=t;function n(o,i){return Le(o,r.codec(),i)}r.decode=n;function s(o,i){return Re(o,r.codec(),i)}r.stream=s})(Di||(Di={}));var fn={};Te(fn,{MAX_RSA_KEY_SIZE:()=>Ci,generateRSAKeyPair:()=>Cu,jwkToJWKKeyPair:()=>Lu,jwkToPkcs1:()=>Sh,jwkToPkix:()=>Oi,jwkToRSAPrivateKey:()=>ki,pkcs1MessageToJwk:()=>Bi,pkcs1MessageToRSAPrivateKey:()=>Pi,pkcs1ToJwk:()=>Eh,pkcs1ToRSAPrivateKey:()=>Du,pkixMessageToJwk:()=>Ri,pkixMessageToRSAPublicKey:()=>Ui,pkixToJwk:()=>vh,pkixToRSAPublicKey:()=>Ni});var Ir=class{type="RSA";jwk;_raw;_multihash;constructor(e,t){this.jwk=e,this._multihash=t}get raw(){return this._raw==null&&(this._raw=fn.jwkToPkix(this.jwk)),this._raw}toMultihash(){return this._multihash}toCID(){return le.createV1(114,this._multihash)}toString(){return re.encode(this.toMultihash().bytes).substring(1)}equals(e){return e==null||!(e.raw instanceof Uint8Array)?!1:ce(this.raw,e.raw)}verify(e,t,n){return Iu(this.jwk,t,e,n)}},ln=class{type="RSA";jwk;_raw;publicKey;constructor(e,t){this.jwk=e,this.publicKey=t}get raw(){return this._raw==null&&(this._raw=fn.jwkToPkcs1(this.jwk)),this._raw}equals(e){return e==null||!(e.raw instanceof Uint8Array)?!1:ce(this.raw,e.raw)}sign(e,t){return Tu(this.jwk,e,t)}};var Ci=8192,Li=18,wh=1062,xh=Uint8Array.from([48,13,6,9,42,134,72,134,247,13,1,1,1,5,0]);function Eh(r){let e=at(r);return Bi(e)}function Bi(r){return{n:V(r[1],"base64url"),e:V(r[2],"base64url"),d:V(r[3],"base64url"),p:V(r[4],"base64url"),q:V(r[5],"base64url"),dp:V(r[6],"base64url"),dq:V(r[7],"base64url"),qi:V(r[8],"base64url"),kty:"RSA"}}function Sh(r){if(r.n==null||r.e==null||r.d==null||r.p==null||r.q==null||r.dp==null||r.dq==null||r.qi==null)throw new oe("JWK was missing components");return wt([De(Uint8Array.from([0])),De(k(r.n,"base64url")),De(k(r.e,"base64url")),De(k(r.d,"base64url")),De(k(r.p,"base64url")),De(k(r.q,"base64url")),De(k(r.dp,"base64url")),De(k(r.dq,"base64url")),De(k(r.qi,"base64url"))]).subarray()}function vh(r){let e=at(r,{offset:0});return Ri(e)}function Ri(r){let e=at(r[1],{offset:0});return{kty:"RSA",n:V(e[0],"base64url"),e:V(e[1],"base64url")}}function Oi(r){if(r.n==null||r.e==null)throw new oe("JWK was missing components");return wt([xh,Mn(wt([De(k(r.n,"base64url")),De(k(r.e,"base64url"))]))]).subarray()}function Du(r){let e=at(r);return Pi(e)}function Pi(r){let e=Bi(r);return ki(e)}function Ni(r,e){if(r.byteLength>=wh)throw new ir("Key size is too large");let t=at(r,{offset:0});return Ui(t,r,e)}function Ui(r,e,t){let n=Ri(r);if(t==null){let s=yr(tt.encode({Type:ne.RSA,Data:e}));t=Ye(Li,s)}return new Ir(n,t)}function ki(r){if(Ru(r)>Ci)throw new oe("Key size is too large");let e=Lu(r),t=yr(tt.encode({Type:ne.RSA,Data:Oi(e.publicKey)})),n=Ye(Li,t);return new ln(e.privateKey,new Ir(e.publicKey,n))}async function Cu(r){if(r>Ci)throw new oe("Key size is too large");let e=await Bu(r),t=yr(tt.encode({Type:ne.RSA,Data:Oi(e.publicKey)})),n=Ye(Li,t);return new ln(e.privateKey,new Ir(e.publicKey,n))}function Lu(r){if(r==null)throw new oe("Missing key parameter");return{privateKey:r,publicKey:{kty:r.kty,n:r.n,e:r.e}}}async function Bu(r,e){let t=await Me.get().subtle.generateKey({name:"RSASSA-PKCS1-v1_5",modulusLength:r,publicExponent:new Uint8Array([1,0,1]),hash:{name:"SHA-256"}},!0,["sign","verify"]);e?.signal?.throwIfAborted();let n=await _h(t,e);return{privateKey:n[0],publicKey:n[1]}}async function Tu(r,e,t){let n=await Me.get().subtle.importKey("jwk",r,{name:"RSASSA-PKCS1-v1_5",hash:{name:"SHA-256"}},!1,["sign"]);t?.signal?.throwIfAborted();let s=await Me.get().subtle.sign({name:"RSASSA-PKCS1-v1_5"},n,_e(e instanceof Uint8Array?e:e.subarray()));return t?.signal?.throwIfAborted(),new Uint8Array(s,0,s.byteLength)}async function Iu(r,e,t,n){let s=await Me.get().subtle.importKey("jwk",r,{name:"RSASSA-PKCS1-v1_5",hash:{name:"SHA-256"}},!1,["verify"]);n?.signal?.throwIfAborted();let o=await Me.get().subtle.verify({name:"RSASSA-PKCS1-v1_5"},s,_e(e),_e(t instanceof Uint8Array?t:t.subarray()));return n?.signal?.throwIfAborted(),o}async function _h(r,e){if(r.privateKey==null||r.publicKey==null)throw new oe("Private and public key are required");let t=await Promise.all([Me.get().subtle.exportKey("jwk",r.privateKey),Me.get().subtle.exportKey("jwk",r.publicKey)]);return e?.signal?.throwIfAborted(),t}function Ru(r){if(r.kty!=="RSA")throw new oe("invalid key type");if(r.n==null)throw new oe("invalid key modulus");return k(r.n,"base64url").length*8}var co=class{oHash;iHash;blockLen;outputLen;canXOF=!1;finished=!1;destroyed=!1;constructor(e,t){if(Fn(e),Pe(t,void 0,"key"),this.iHash=e.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 n=this.blockLen,s=new Uint8Array(n);s.set(t.length>n?e.create().update(t).digest():t);for(let o=0;o<s.length;o++)s[o]^=54;this.iHash.update(s),this.oHash=e.create();for(let o=0;o<s.length;o++)s[o]^=106;this.oHash.update(s),ut(s)}update(e){return mr(this),this.iHash.update(e),this}digestInto(e){mr(this),Kn(e,this),this.finished=!0;let t=e.subarray(0,this.outputLen);this.iHash.digestInto(t),this.oHash.update(t),this.oHash.digestInto(t),this.destroy()}digest(){let e=new Uint8Array(this.oHash.outputLen);return this.digestInto(e),e}_cloneInto(e){e||=Object.create(Object.getPrototypeOf(this),{});let{oHash:t,iHash:n,finished:s,destroyed:o,blockLen:i,outputLen:a}=this;return e=e,e.finished=s,e.destroyed=o,e.blockLen=i,e.outputLen=a,e.oHash=t._cloneInto(e.oHash),e.iHash=n._cloneInto(e.iHash),e}clone(){return this._cloneInto()}destroy(){this.destroyed=!0,this.oHash.destroy(),this.iHash.destroy()}},Ou=(()=>{let r=((e,t,n)=>new co(e,t).update(n).digest());return r.create=(e,t)=>new co(e,t),r})();var Pu=(r,e)=>(r+(r>=0?e:-e)/Nu)/e;function Ah(r,e,t){wr("scalar",r,rt,t);let[[n,s],[o,i]]=e,a=Pu(i*r,t),c=Pu(-s*r,t),u=r-a*n-c*o,l=-a*s-c*i,f=u<rt,p=l<rt;f&&(u=-u),p&&(l=-l);let d=en(Math.ceil(xr(t)/2))+Ct;if(u<rt||u>=d||l<rt||l>=d)throw new Error("splitScalar (endomorphism): failed for k");return{k1neg:f,k1:u,k2neg:p,k2:l}}function Fi(r){if(!["compact","recovered","der"].includes(r))throw new Error('Signature format must be "compact", "recovered", or "der"');return r}function Mi(r,e){He(r);let t={};for(let n of Object.keys(e))t[n]=r[n]===void 0?e[n]:r[n];return ze(t.lowS,"lowS"),ze(t.prehash,"prehash"),t.format!==void 0&&Fi(t.format),t}var Ki=class extends Error{constructor(e=""){super(e)}},We={Err:Ki,_tlv:{encode:(r,e)=>{let{Err:t}=We;if(Ve(r,"tag"),r<0||r>255)throw new t("tlv.encode: wrong tag");if(typeof e!="string")throw new TypeError('"data" expected string, got type='+typeof e);if(e.length&1)throw new t("tlv.encode: unpadded data");let n=e.length/2,s=Qr(n);if(s.length/2&128)throw new t("tlv.encode: long form length too big");let o=n>127?Qr(s.length/2|128):"";return Qr(r)+o+s+e},decode(r,e){let{Err:t}=We;e=H(e,void 0,"DER data");let n=0;if(r<0||r>255)throw new t("tlv.encode: wrong tag");if(e.length<2||e[n++]!==r)throw new t("tlv.decode: wrong tlv");let s=e[n++],o=!!(s&128),i=0;if(!o)i=s;else{let c=s&127;if(!c)throw new t("tlv.decode(long): indefinite length not supported");if(c>4)throw new t("tlv.decode(long): byte length is too big");let u=e.subarray(n,n+c);if(u.length!==c)throw new t("tlv.decode: length bytes not complete");if(u[0]===0)throw new t("tlv.decode(long): zero leftmost byte");for(let l of u)i=i<<8|l;if(n+=c,i<128)throw new t("tlv.decode(long): not minimal encoding")}let a=e.subarray(n,n+i);if(a.length!==i)throw new t("tlv.decode: wrong value length");return{v:a,l:e.subarray(n+i)}}},_int:{encode(r){let{Err:e}=We;if(jn(r),r<rt)throw new e("integer: negative integers are not allowed");let t=Qr(r);if(Number.parseInt(t[0],16)&8&&(t="00"+t),t.length&1)throw new e("unexpected DER parsing assertion: unpadded hex");return t},decode(r){let{Err:e}=We;if(r.length<1)throw new e("invalid signature integer: empty");if(r[0]&128)throw new e("invalid signature integer: negative");if(r.length>1&&r[0]===0&&!(r[1]&128))throw new e("invalid signature integer: unnecessary leading zero");return zt(r)}},toSig(r){let{Err:e,_int:t,_tlv:n}=We,s=H(r,void 0,"signature"),{v:o,l:i}=n.decode(48,s);if(i.length)throw new e("invalid signature: left bytes after parsing");let{v:a,l:c}=n.decode(2,o),{v:u,l}=n.decode(2,c);if(l.length)throw new e("invalid signature: left bytes after parsing");return{r:t.decode(a),s:t.decode(u)}},hexFromSig(r){let{_tlv:e,_int:t}=We,n=e.encode(2,t.encode(r.r)),s=e.encode(2,t.encode(r.s)),o=n+s;return e.encode(48,o)}};Object.freeze(We._tlv);Object.freeze(We._int);Object.freeze(We);var rt=BigInt(0),Ct=BigInt(1),Nu=BigInt(2),uo=BigInt(3),Th=BigInt(4);function Uu(r,e={}){let t=Xn("weierstrass",r,e),n=t.Fp,s=t.Fn,o=t.CURVE,{h:i,n:a}=o;He(e,{},{allowInfinityPoint:"boolean",clearCofactor:"function",isTorsionFree:"function",fromBytes:"function",toBytes:"function",endo:"object"});let{endo:c,allowInfinityPoint:u}=e;if(c&&(!n.is0(o.a)||typeof c.beta!="bigint"||!Array.isArray(c.basises)))throw new Error('invalid endo: expected "beta": bigint and "basises": array');let l=Mu(n,s);function f(){if(!n.isOdd)throw new Error("compression is not supported: Field does not have .isOdd()")}function p(M,m,b){if(u&&m.is0())return Uint8Array.of(0);let{x:v,y:E}=m.toAffine(),w=n.toBytes(v);if(ze(b,"isCompressed"),b){f();let A=!n.isOdd(E);return de(ku(A),w)}else return de(Uint8Array.of(4),w,n.toBytes(E))}function d(M){H(M,void 0,"Point");let{publicKey:m,publicKeyUncompressed:b}=l,v=M.length,E=M[0],w=M.subarray(1);if(u&&v===1&&E===0)return{x:n.ZERO,y:n.ZERO};if(v===m&&(E===2||E===3)){let A=n.fromBytes(w);if(!n.isValid(A))throw new Error("bad point: is not on curve, wrong x");let D=h(A),T;try{T=n.sqrt(D)}catch(z){let j=z instanceof Error?": "+z.message:"";throw new Error("bad point: is not on curve, sqrt error"+j)}f();let L=n.isOdd(T);return(E&1)===1!==L&&(T=n.neg(T)),{x:A,y:T}}else if(v===b&&E===4){let A=n.BYTES,D=n.fromBytes(w.subarray(0,A)),T=n.fromBytes(w.subarray(A,A*2));if(!g(D,T))throw new Error("bad point: is not on curve");return{x:D,y:T}}else throw new Error(`bad point: got length ${v}, expected compressed=${m} or uncompressed=${b}`)}let y=e.toBytes===void 0?p:e.toBytes,x=e.fromBytes===void 0?d:e.fromBytes;function h(M){let m=n.sqr(M),b=n.mul(m,M);return n.add(n.add(b,n.mul(M,o.a)),o.b)}function g(M,m){let b=n.sqr(m),v=h(M);return n.eql(b,v)}if(!g(o.Gx,o.Gy))throw new Error("bad curve params: generator point");let S=n.mul(n.pow(o.a,uo),Th),_=n.mul(n.sqr(o.b),BigInt(27));if(n.is0(n.add(S,_)))throw new Error("bad curve params: a or b");function B(M,m,b=!1){if(!n.isValid(m)||b&&n.is0(m))throw new Error(`bad point coordinate ${M}`);return m}function C(M){if(!(M instanceof I))throw new Error("Weierstrass Point expected")}function N(M){if(!c||!c.basises)throw new Error("no endo");return Ah(M,c.basises,s.ORDER)}function R(M,m,b,v,E){return b=new I(n.mul(b.X,M),b.Y,b.Z),m=rn(v,m),b=rn(E,b),m.add(b)}class I{static BASE=new I(o.Gx,o.Gy,n.ONE);static ZERO=new I(n.ZERO,n.ONE,n.ZERO);static Fp=n;static Fn=s;X;Y;Z;constructor(m,b,v){this.X=B("x",m),this.Y=B("y",b,!0),this.Z=B("z",v),Object.freeze(this)}static CURVE(){return o}static fromAffine(m){let{x:b,y:v}=m||{};if(!m||!n.isValid(b)||!n.isValid(v))throw new Error("invalid affine point");if(m instanceof I)throw new Error("projective point not allowed");return n.is0(b)&&n.is0(v)?I.ZERO:new I(b,v,n.ONE)}static fromBytes(m){let b=I.fromAffine(x(H(m,void 0,"point")));return b.assertValidity(),b}static fromHex(m){return I.fromBytes(br(m))}get x(){return this.toAffine().x}get y(){return this.toAffine().y}precompute(m=8,b=!0){return Z.createCache(this,m),b||this.multiply(uo),this}assertValidity(){let m=this;if(m.is0()){if(e.allowInfinityPoint&&n.is0(m.X)&&n.eql(m.Y,n.ONE)&&n.is0(m.Z))return;throw new Error("bad point: ZERO")}let{x:b,y:v}=m.toAffine();if(!n.isValid(b)||!n.isValid(v))throw new Error("bad point: x or y not field elements");if(!g(b,v))throw new Error("bad point: equation left != right");if(!m.isTorsionFree())throw new Error("bad point: not in prime-order subgroup")}hasEvenY(){let{y:m}=this.toAffine();if(!n.isOdd)throw new Error("Field doesn't support isOdd");return!n.isOdd(m)}equals(m){C(m);let{X:b,Y:v,Z:E}=this,{X:w,Y:A,Z:D}=m,T=n.eql(n.mul(b,D),n.mul(w,E)),L=n.eql(n.mul(v,D),n.mul(A,E));return T&&L}negate(){return new I(this.X,n.neg(this.Y),this.Z)}double(){let{a:m,b}=o,v=n.mul(b,uo),{X:E,Y:w,Z:A}=this,D=n.ZERO,T=n.ZERO,L=n.ZERO,P=n.mul(E,E),z=n.mul(w,w),j=n.mul(A,A),K=n.mul(E,w);return K=n.add(K,K),L=n.mul(E,A),L=n.add(L,L),D=n.mul(m,L),T=n.mul(v,j),T=n.add(D,T),D=n.sub(z,T),T=n.add(z,T),T=n.mul(D,T),D=n.mul(K,D),L=n.mul(v,L),j=n.mul(m,j),K=n.sub(P,j),K=n.mul(m,K),K=n.add(K,L),L=n.add(P,P),P=n.add(L,P),P=n.add(P,j),P=n.mul(P,K),T=n.add(T,P),j=n.mul(w,A),j=n.add(j,j),P=n.mul(j,K),D=n.sub(D,P),L=n.mul(j,z),L=n.add(L,L),L=n.add(L,L),new I(D,T,L)}add(m){C(m);let{X:b,Y:v,Z:E}=this,{X:w,Y:A,Z:D}=m,T=n.ZERO,L=n.ZERO,P=n.ZERO,z=o.a,j=n.mul(o.b,uo),K=n.mul(b,w),fe=n.mul(v,A),he=n.mul(E,D),pe=n.add(b,v),ae=n.add(w,A);pe=n.mul(pe,ae),ae=n.add(K,fe),pe=n.sub(pe,ae),ae=n.add(b,E);let Ae=n.add(w,D);return ae=n.mul(ae,Ae),Ae=n.add(K,he),ae=n.sub(ae,Ae),Ae=n.add(v,E),T=n.add(A,D),Ae=n.mul(Ae,T),T=n.add(fe,he),Ae=n.sub(Ae,T),P=n.mul(z,ae),T=n.mul(j,he),P=n.add(T,P),T=n.sub(fe,P),P=n.add(fe,P),L=n.mul(T,P),fe=n.add(K,K),fe=n.add(fe,K),he=n.mul(z,he),ae=n.mul(j,ae),fe=n.add(fe,he),he=n.sub(K,he),he=n.mul(z,he),ae=n.add(ae,he),K=n.mul(fe,ae),L=n.add(L,K),K=n.mul(Ae,ae),T=n.mul(pe,T),T=n.sub(T,K),K=n.mul(pe,fe),P=n.mul(Ae,P),P=n.add(P,K),new I(T,L,P)}subtract(m){return C(m),this.add(m.negate())}is0(){return this.equals(I.ZERO)}multiply(m){let{endo:b}=e;if(!s.isValidNot0(m))throw new RangeError("invalid scalar: out of range");let v,E,w=A=>Z.cached(this,A,D=>$t(I,D));if(b){let{k1neg:A,k1:D,k2neg:T,k2:L}=N(m),{p:P,f:z}=w(D),{p:j,f:K}=w(L);E=z.add(K),v=R(b.beta,P,j,A,T)}else{let{p:A,f:D}=w(m);v=A,E=D}return $t(I,[v,E])[0]}multiplyUnsafe(m){let{endo:b}=e,v=this,E=m;if(!s.isValid(E))throw new RangeError("invalid scalar: out of range");if(E===rt||v.is0())return I.ZERO;if(E===Ct)return v;if(Z.hasCache(this))return this.multiply(E);if(b){let{k1neg:w,k1:A,k2neg:D,k2:T}=N(E),{p1:L,p2:P}=iu(I,v,A,T);return R(b.beta,L,P,w,D)}else return Z.unsafe(v,E)}toAffine(m){let b=this,v=m,{X:E,Y:w,Z:A}=b;if(n.eql(A,n.ONE))return{x:E,y:w};let D=b.is0();v==null&&(v=D?n.ONE:n.inv(A));let T=n.mul(E,v),L=n.mul(w,v),P=n.mul(A,v);if(D)return{x:n.ZERO,y:n.ZERO};if(!n.eql(P,n.ONE))throw new Error("invZ was invalid");return{x:T,y:L}}isTorsionFree(){let{isTorsionFree:m}=e;return i===Ct?!0:m?m(I,this):Z.unsafe(this,a).is0()}clearCofactor(){let{clearCofactor:m}=e;return i===Ct?this:m?m(I,this):this.multiplyUnsafe(i)}isSmallOrder(){return i===Ct?this.is0():this.clearCofactor().is0()}toBytes(m=!0){return ze(m,"isCompressed"),this.assertValidity(),y(I,this,m)}toHex(m=!0){return gr(this.toBytes(m))}toString(){return`<Point ${this.is0()?"ZERO":this.toHex()}>`}}let U=s.BITS,Z=new vr(I,e.endo?Math.ceil(U/2):U);return U>=8&&I.BASE.precompute(8),Object.freeze(I.prototype),Object.freeze(I),I}function ku(r){return Uint8Array.of(r?2:3)}function Mu(r,e){return{secretKey:e.BYTES,publicKey:1+r.BYTES,publicKeyUncompressed:1+2*r.BYTES,publicKeyHasPrefix:!0,signature:2*e.BYTES}}function Ih(r,e={}){let{Fn:t}=r,n=e.randomBytes===void 0?Xr:e.randomBytes,s=Object.assign(Mu(r.Fp,t),{seed:Math.max(Zs(t.ORDER),16)});function o(d){try{let y=t.fromBytes(d);return t.isValidNot0(y)}catch{return!1}}function i(d,y){let{publicKey:x,publicKeyUncompressed:h}=s;try{let g=d.length;return y===!0&&g!==x||y===!1&&g!==h?!1:!!r.fromBytes(d)}catch{return!1}}function a(d){return d=d===void 0?n(s.seed):d,Xs(H(d,s.seed,"seed"),t.ORDER)}function c(d,y=!0){return r.BASE.multiply(t.fromBytes(d)).toBytes(y)}function u(d){let{secretKey:y,publicKey:x,publicKeyUncompressed:h}=s,g=t._lengths;if(!qt(d))return;let S=H(d,void 0,"key").length,_=S===x||S===h,B=S===y||!!g?.includes(S);if(!(_&&B))return _}function l(d,y,x=!0){if(u(d)===!0)throw new Error("first arg must be private key");if(u(y)===!1)throw new Error("second arg must be public key");let h=t.fromBytes(d);return r.fromBytes(y).multiply(h).toBytes(x)}let f={isValidSecretKey:o,isValidPublicKey:i,randomSecretKey:a},p=Qn(a,c);return Object.freeze(f),Object.freeze(s),Object.freeze({getPublicKey:c,getSharedSecret:l,keygen:p,Point:r,utils:f,lengths:s})}function Fu(r,e,t={}){let n=e;Fn(n),He(t,{},{hmac:"function",lowS:"boolean",randomBytes:"function",bits2int:"function",bits2int_modN:"function"}),t=Object.assign({},t);let s=t.randomBytes===void 0?Xr:t.randomBytes,o=t.hmac===void 0?(E,w)=>Ou(n,E,w):t.hmac,{Fp:i,Fn:a}=r,{ORDER:c,BITS:u}=a,{keygen:l,getPublicKey:f,getSharedSecret:p,utils:d,lengths:y}=Ih(r,t),x={prehash:!0,lowS:typeof t.lowS=="boolean"?t.lowS:!0,format:"compact",extraEntropy:!1},h=c*Nu+Ct<i.ORDER;function g(E){let w=c>>Ct;return E>w}function S(E,w){if(!a.isValidNot0(w))throw new Error(`invalid signature ${E}: out of range 1..Point.Fn.ORDER`);return w}function _(){if(h)throw new Error('"recovered" sig type is not supported for cofactor >2 curves')}function B(E,w){Fi(w);let A=y.signature,D=w==="compact"?A:w==="recovered"?A+1:void 0;return H(E,D)}class C{r;s;recovery;constructor(w,A,D){if(this.r=S("r",w),this.s=S("s",A),D!=null){if(_(),![0,1,2,3].includes(D))throw new Error("invalid recovery id");this.recovery=D}Object.freeze(this)}static fromBytes(w,A=x.format){B(w,A);let D;if(A==="der"){let{r:z,s:j}=We.toSig(H(w));return new C(z,j)}A==="recovered"&&(D=w[0],A="compact",w=w.subarray(1));let T=y.signature/2,L=w.subarray(0,T),P=w.subarray(T,T*2);return new C(a.fromBytes(L),a.fromBytes(P),D)}static fromHex(w,A){return this.fromBytes(br(w),A)}assertRecovery(){let{recovery:w}=this;if(w==null)throw new Error("invalid recovery id: must be present");return w}addRecoveryBit(w){return new C(this.r,this.s,w)}recoverPublicKey(w){let{r:A,s:D}=this,T=this.assertRecovery(),L=T===2||T===3?A+c:A;if(!i.isValid(L))throw new Error("invalid recovery id: sig.r+curve.n != R.x");let P=i.toBytes(L),z=r.fromBytes(de(ku((T&1)===0),P)),j=a.inv(L),K=R(H(w,void 0,"msgHash")),fe=a.create(-K*j),he=a.create(D*j),pe=r.BASE.multiplyUnsafe(fe).add(z.multiplyUnsafe(he));if(pe.is0())throw new Error("invalid recovery: point at infinify");return pe.assertValidity(),pe}hasHighS(){return g(this.s)}toBytes(w=x.format){if(Fi(w),w==="der")return br(We.hexFromSig(this));let{r:A,s:D}=this,T=a.toBytes(A),L=a.toBytes(D);return w==="recovered"?(_(),de(Uint8Array.of(this.assertRecovery()),T,L)):de(T,L)}toHex(w){return gr(this.toBytes(w))}}Object.freeze(C.prototype),Object.freeze(C);let N=t.bits2int===void 0?function(w){if(w.length>8192)throw new Error("input is too large");let A=zt(w),D=w.length*8-u;return D>0?A>>BigInt(D):A}:t.bits2int,R=t.bits2int_modN===void 0?function(w){return a.create(N(w))}:t.bits2int_modN,I=en(u);function U(E){return wr("num < 2^"+u,E,rt,I),a.toBytes(E)}function Z(E,w){return H(E,void 0,"message"),w?H(n(E),void 0,"prehashed message"):E}function M(E,w,A){let{lowS:D,prehash:T,extraEntropy:L}=Mi(A,x);E=Z(E,T);let P=R(E),z=a.fromBytes(w);if(!a.isValidNot0(z))throw new Error("invalid private key");let j=[U(z),U(P)];if(L!=null&&L!==!1){let pe=L===!0?s(y.secretKey):L;j.push(H(pe,void 0,"extraEntropy"))}let K=de(...j),fe=P;function he(pe){let ae=N(pe);if(!a.isValidNot0(ae))return;let Ae=a.inv(ae),sr=r.BASE.multiply(ae).toAffine(),Mr=a.create(sr.x);if(Mr===rt)return;let Tn=a.create(Ae*a.create(fe+Mr*z));if(Tn===rt)return;let Ha=(sr.x===Mr?0:2)|Number(sr.y&Ct),$a=Tn;return D&&g(Tn)&&($a=a.neg(Tn),Ha^=1),new C(Mr,$a,h?void 0:Ha)}return{seed:K,k2sig:he}}function m(E,w,A={}){let{seed:D,k2sig:T}=M(E,w,A);return Vc(n.outputLen,a.BYTES,o)(D,T).toBytes(A.format)}function b(E,w,A,D={}){let{lowS:T,prehash:L,format:P}=Mi(D,x);if(A=H(A,void 0,"publicKey"),w=Z(w,L),!qt(E)){let z=E instanceof C?", use sig.toBytes()":"";throw new Error("verify expects Uint8Array signature"+z)}B(E,P);try{let z=C.fromBytes(E,P),j=r.fromBytes(A);if(T&&z.hasHighS())return!1;let{r:K,s:fe}=z,he=R(w),pe=a.inv(fe),ae=a.create(he*pe),Ae=a.create(K*pe),sr=r.BASE.multiplyUnsafe(ae).add(j.multiplyUnsafe(Ae));return sr.is0()?!1:a.create(sr.x)===K}catch{return!1}}function v(E,w,A={}){let{prehash:D}=Mi(A,x);return w=Z(w,D),C.fromBytes(E,"recovered").recoverPublicKey(w).toBytes()}return Object.freeze({keygen:l,getPublicKey:f,getSharedSecret:p,utils:d,lengths:y,Point:r,sign:m,verify:b,recoverPublicKey:v,Signature:C,hash:n})}var zi={p:BigInt("0xfffffffffffffffffffffffffffffffffffffffffffffffffffffffefffffc2f"),n:BigInt("0xfffffffffffffffffffffffffffffffebaaedce6af48a03bbfd25e8cd0364141"),h:BigInt(1),a:BigInt(0),b:BigInt(7),Gx:BigInt("0x79be667ef9dcbbac55a06295ce870b07029bfcdb2dce28d959f2815b16f81798"),Gy:BigInt("0x483ada7726a3c4655da4fbfc0e1108a8fd17b448a68554199c47d08ffb10d4b8")},Dh={beta:BigInt("0x7ae96a2b657c07106e64479eac3434e99cf0497512f58995c1396c28719501ee"),basises:[[BigInt("0x3086d221a7d46bcde86c90e49284eb15"),-BigInt("0xe4437ed6010e88286f547fa90abfe4c3")],[BigInt("0x114ca50f7a8e2f3f657c1108d9d44cfd8"),BigInt("0x3086d221a7d46bcde86c90e49284eb15")]]};var Ku=BigInt(2);function Ch(r){let e=zi.p,t=BigInt(3),n=BigInt(6),s=BigInt(11),o=BigInt(22),i=BigInt(23),a=BigInt(44),c=BigInt(88),u=r*r*r%e,l=u*u*r%e,f=te(l,t,e)*l%e,p=te(f,t,e)*l%e,d=te(p,Ku,e)*u%e,y=te(d,s,e)*d%e,x=te(y,o,e)*y%e,h=te(x,a,e)*x%e,g=te(h,c,e)*h%e,S=te(g,a,e)*x%e,_=te(S,t,e)*l%e,B=te(_,i,e)*y%e,C=te(B,n,e)*u%e,N=te(C,Ku,e);if(!qi.eql(qi.sqr(N),r))throw new Error("Cannot find square root");return N}var qi=Er(zi.p,{sqrt:Ch}),Lh=Uu(zi,{Fp:qi,endo:Dh}),Dr=Fu(Lh,yr);function qu(r,e,t,n){let s=hr.digest(t instanceof Uint8Array?t:t.subarray());if(ro(s))return s.then(({digest:o})=>(n?.signal?.throwIfAborted(),Dr.verify(e,o,r,{prehash:!1,format:"der"}))).catch(o=>{throw o.name==="AbortError"?o:new on(String(o))});try{return n?.signal?.throwIfAborted(),Dr.verify(e,s.digest,r,{prehash:!1,format:"der"})}catch(o){throw new on(String(o))}}var lo=class{type="secp256k1";raw;_key;constructor(e){this._key=Vu(e),this.raw=zu(this._key)}toMultihash(){return Ke.digest(Qe(this))}toCID(){return le.createV1(114,this.toMultihash())}toString(){return re.encode(this.toMultihash().bytes).substring(1)}equals(e){return e==null||!(e.raw instanceof Uint8Array)?!1:ce(this.raw,e.raw)}verify(e,t,n){return qu(this._key,t,e,n)}};function Vi(r){return new lo(r)}function zu(r){return Dr.Point.fromBytes(r).toBytes()}function Vu(r){try{return Dr.Point.fromBytes(r),r}catch(e){throw new ir(String(e))}}function Hu(r,e){let{Type:t,Data:n}=tt.decode(r),s=n??new Uint8Array;switch(t){case ne.RSA:return Ni(s,e);case ne.Ed25519:return li(s);case ne.secp256k1:return Vi(s);case ne.ECDSA:return Os(s);default:throw new ar}}function $u(r){let{Type:e,Data:t}=tt.decode(r.digest),n=t??new Uint8Array;switch(e){case ne.Ed25519:return li(n);case ne.secp256k1:return Vi(n);case ne.ECDSA:return Os(n);default:throw new ar}}function Qe(r){return tt.encode({Type:ne[r.type],Data:r.raw})}var Wu=Symbol.for("nodejs.util.inspect.custom"),Bh=114,dn=class{type;multihash;publicKey;string;constructor(e){this.type=e.type,this.multihash=e.multihash,Object.defineProperty(this,"string",{enumerable:!1,writable:!0})}get[Symbol.toStringTag](){return`PeerId(${this.toString()})`}[os]=!0;toString(){return this.string==null&&(this.string=re.encode(this.multihash.bytes).slice(1)),this.string}toMultihash(){return this.multihash}toCID(){return le.createV1(Bh,this.multihash)}toJSON(){return this.toString()}equals(e){if(e==null)return!1;if(e instanceof Uint8Array)return ce(this.multihash.bytes,e);if(typeof e=="string")return this.toString()===e;if(e?.toMultihash()?.bytes!=null)return ce(this.multihash.bytes,e.toMultihash().bytes);throw new Error("not valid Id")}[Wu](){return`PeerId(${this.toString()})`}},fo=class extends dn{type="RSA";publicKey;constructor(e){super({...e,type:"RSA"}),this.publicKey=e.publicKey}},ho=class extends dn{type="Ed25519";publicKey;constructor(e){super({...e,type:"Ed25519"}),this.publicKey=e.publicKey}},po=class extends dn{type="secp256k1";publicKey;constructor(e){super({...e,type:"secp256k1"}),this.publicKey=e.publicKey}},Rh=2336,hn=class{type="url";multihash;publicKey;url;constructor(e){this.url=e.toString(),this.multihash=Ke.digest(k(this.url))}[Wu](){return`PeerId(${this.url})`}[os]=!0;toString(){return this.toCID().toString()}toMultihash(){return this.multihash}toCID(){return le.createV1(Rh,this.toMultihash())}toJSON(){return this.toString()}equals(e){return e==null?!1:(e instanceof Uint8Array&&(e=V(e)),e.toString()===this.toString())}};var Oh=114,ju=2336;function Hi(r,e){let t;if(r.charAt(0)==="1"||r.charAt(0)==="Q")t=Ze(re.decode(`z${r}`));else{if(r.startsWith("k51qzi5uqu5")||r.startsWith("kzwfwjn5ji4")||r.startsWith("k2k4r8")||r.startsWith("bafz"))return Ph(le.parse(r));if(e==null)throw new oe('Please pass a multibase decoder for strings that do not start with "1" or "Q"');t=Ze(e.decode(r))}return Cr(t)}function Cr(r){if(Uh(r))return new fo({multihash:r});if(Nh(r))try{let e=$u(r);if(e.type==="Ed25519")return new ho({multihash:r,publicKey:e});if(e.type==="secp256k1")return new po({multihash:r,publicKey:e})}catch{let t=V(r.digest);return new hn(new URL(t))}throw new Cn("Supplied PeerID Multihash is invalid")}function Ph(r){if(r?.multihash==null||r.version==null||r.version===1&&r.code!==Oh&&r.code!==ju)throw new Dn("Supplied PeerID CID is invalid");if(r.code===ju){let e=V(r.multihash.digest);return new hn(new URL(e))}return Cr(r.multihash)}function Nh(r){return r.code===Ke.code}function Uh(r){return r.code===hr.code}var pn;(function(r){let e;r.codec=()=>(e==null&&(e=Oe((o,i,a={})=>{a.lengthDelimited!==!1&&i.fork(),o.publicKey!=null&&o.publicKey.byteLength>0&&(i.uint32(10),i.bytes(o.publicKey)),o.payloadType!=null&&o.payloadType.byteLength>0&&(i.uint32(18),i.bytes(o.payloadType)),o.payload!=null&&o.payload.byteLength>0&&(i.uint32(26),i.bytes(o.payload)),o.signature!=null&&o.signature.byteLength>0&&(i.uint32(42),i.bytes(o.signature)),a.lengthDelimited!==!1&&i.ldelim()},(o,i,a={})=>{let c={publicKey:J(0),payloadType:J(0),payload:J(0),signature:J(0)},u=i==null?o.len:o.pos+i;for(;o.pos<u;){let l=o.uint32();switch(l>>>3){case 1:{c.publicKey=o.bytes();break}case 2:{c.payloadType=o.bytes();break}case 3:{c.payload=o.bytes();break}case 5:{c.signature=o.bytes();break}default:{o.skipType(l&7);break}}}return c},function*(o,i,a,c={}){let u=i==null?o.len:o.pos+i;for(;o.pos<u;){let l=o.uint32();switch(l>>>3){case 1:{yield{field:`${a}.publicKey`,value:o.bytes()};break}case 2:{yield{field:`${a}.payloadType`,value:o.bytes()};break}case 3:{yield{field:`${a}.payload`,value:o.bytes()};break}case 5:{yield{field:`${a}.signature`,value:o.bytes()};break}default:{o.skipType(l&7);break}}}})),e);function t(o){return Be(o,r.codec())}r.encode=t;function n(o,i){return Le(o,r.codec(),i)}r.decode=n;function s(o,i){return Re(o,r.codec(),i)}r.stream=s})(pn||(pn={}));var mo=class extends Error{constructor(e="Invalid signature"){super(e),this.name="InvalidSignatureError"}};var mn=class r{static createFromProtobuf=e=>{let t=pn.decode(e),n=Hu(t.publicKey);return new r({publicKey:n,payloadType:t.payloadType,payload:t.payload,signature:t.signature})};static seal=async(e,t,n)=>{if(t==null)throw new Error("Missing private key");let s=e.domain,o=e.codec,i=e.marshal(),a=Gu(s,o,i),c=await t.sign(a.subarray(),n);return new r({publicKey:t.publicKey,payloadType:o,payload:i,signature:c})};static openAndCertify=async(e,t,n)=>{let s=r.createFromProtobuf(e);if(!await s.validate(t,n))throw new mo("Envelope signature is not valid for the given domain");return s};publicKey;payloadType;payload;signature;marshaled;constructor(e){let{publicKey:t,payloadType:n,payload:s,signature:o}=e;this.publicKey=t,this.payloadType=n,this.payload=s,this.signature=o}marshal(){return this.marshaled==null&&(this.marshaled=pn.encode({publicKey:Qe(this.publicKey),payloadType:this.payloadType,payload:this.payload.subarray(),signature:this.signature})),this.marshaled}equals(e){return e==null?!1:ce(this.marshal(),e.marshal())}async validate(e,t){let n=Gu(e,this.payloadType,this.payload);return this.publicKey.verify(n.subarray(),this.signature,t)}},Gu=(r,e,t)=>{let n=k(r),s=Tr(n.byteLength),o=Tr(e.length),i=Tr(t.length);return new ee(s,n,o,e,i,t)};var we=class extends Error{static name="InvalidMultiaddrError";name="InvalidMultiaddrError"},ht=class extends Error{static name="ValidationError";name="ValidationError"},yo=class extends Error{static name="InvalidParametersError";name="InvalidParametersError"},go=class extends Error{static name="UnknownProtocolError";name="UnknownProtocolError"};var bo=class{index=0;input="";new(e){return this.index=0,this.input=e,this}readAtomically(e){let t=this.index,n=e();return n===void 0&&(this.index=t),n}parseWith(e){let t=e();if(this.index===this.input.length)return t}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(e){return this.readAtomically(()=>{let t=this.readChar();if(t===e)return t})}readSeparator(e,t,n){return this.readAtomically(()=>{if(!(t>0&&this.readGivenChar(e)===void 0))return n()})}readNumber(e,t,n,s){return this.readAtomically(()=>{let o=0,i=0,a=this.peekChar();if(a===void 0)return;let c=a==="0",u=2**(8*s)-1;for(;;){let l=this.readAtomically(()=>{let f=this.readChar();if(f===void 0)return;let p=Number.parseInt(f,e);if(!Number.isNaN(p))return p});if(l===void 0)break;if(o*=e,o+=l,o>u||(i+=1,t!==void 0&&i>t))return}if(i!==0)return!n&&c&&i>1?void 0:o})}readIPv4Addr(){return this.readAtomically(()=>{let e=new Uint8Array(4);for(let t=0;t<e.length;t++){let n=this.readSeparator(".",t,()=>this.readNumber(10,3,!1,1));if(n===void 0)return;e[t]=n}return e})}readIPv6Addr(){let e=t=>{for(let n=0;n<t.length/2;n++){let s=n*2;if(n<t.length-3){let i=this.readSeparator(":",n,()=>this.readIPv4Addr());if(i!==void 0)return t[s]=i[0],t[s+1]=i[1],t[s+2]=i[2],t[s+3]=i[3],[s+4,!0]}let o=this.readSeparator(":",n,()=>this.readNumber(16,4,!0,2));if(o===void 0)return[s,!1];t[s]=o>>8,t[s+1]=o&255}return[t.length,!1]};return this.readAtomically(()=>{let t=new Uint8Array(16),[n,s]=e(t);if(n===16)return t;if(s||this.readGivenChar(":")===void 0||this.readGivenChar(":")===void 0)return;let o=new Uint8Array(14),i=16-(n+2),[a]=e(o.subarray(0,i));return t.set(o.subarray(0,a),16-a),t})}readIPAddr(){return this.readIPv4Addr()??this.readIPv6Addr()}};var kh=45,Mh=15,wo=new bo;function Yu(r){if(!(r.length>Mh))return wo.new(r).parseWith(()=>wo.readIPv4Addr())}function Zu(r){if(r.includes("%")&&(r=r.split("%")[0]),!(r.length>kh))return wo.new(r).parseWith(()=>wo.readIPv6Addr())}function xo(r){return!!Yu(r)}function Xu(r){return!!Zu(r)}function Wi(r){return e=>V(e,r)}function ji(r){return e=>k(e,r)}function Lr(r){return new DataView(r.buffer).getUint16(r.byteOffset).toString()}function Zt(r){let e=new ArrayBuffer(2);return new DataView(e).setUint16(0,typeof r=="string"?parseInt(r):r),new Uint8Array(e)}function Qu(r){let e=r.split(":");if(e.length!==2)throw new Error(`failed to parse onion addr: ["'${e.join('", "')}'"]' does not contain a port number`);if(e[0].length!==16)throw new Error(`failed to parse onion addr: ${e[0]} not a Tor onion address.`);let t=k(e[0],"base32"),n=parseInt(e[1],10);if(n<1||n>65536)throw new Error("Port number is not in range(1, 65536)");let s=Zt(n);return Xe([t,s],t.length+s.length)}function Ju(r){let e=r.split(":");if(e.length!==2)throw new Error(`failed to parse onion addr: ["'${e.join('", "')}'"]' does not contain a port number`);if(e[0].length!==56)throw new Error(`failed to parse onion addr: ${e[0]} not a Tor onion3 address.`);let t=bt.decode(`b${e[0]}`),n=parseInt(e[1],10);if(n<1||n>65536)throw new Error("Port number is not in range(1, 65536)");let s=Zt(n);return Xe([t,s],t.length+s.length)}function Gi(r){let e=r.subarray(0,r.length-2),t=r.subarray(r.length-2),n=V(e,"base32"),s=Lr(t);return`${n}:${s}`}var Yi=function(r){r=r.toString().trim();let e=new Uint8Array(4);return r.split(/\./g).forEach((t,n)=>{let s=parseInt(t,10);if(isNaN(s)||s<0||s>255)throw new we("Invalid byte value in IP address");e[n]=s}),e},el=function(r){let e=0;r=r.toString().trim();let t=r.split(":",8),n;for(n=0;n<t.length;n++){let o=xo(t[n]),i;o&&(i=Yi(t[n]),t[n]=V(i.subarray(0,2),"base16")),i!=null&&++n<8&&t.splice(n,0,V(i.subarray(2,4),"base16"))}if(t[0]==="")for(;t.length<8;)t.unshift("0");else if(t[t.length-1]==="")for(;t.length<8;)t.push("0");else if(t.length<8){for(n=0;n<t.length&&t[n]!=="";n++);let o=[n,1];for(n=9-t.length;n>0;n--)o.push("0");t.splice.apply(t,o)}let s=new Uint8Array(e+16);for(n=0;n<t.length;n++){t[n]===""&&(t[n]="0");let o=parseInt(t[n],16);if(isNaN(o)||o<0||o>65535)throw new we("Invalid byte value in IP address");s[e++]=o>>8&255,s[e++]=o&255}return s},tl=function(r){if(r.byteLength!==4)throw new we("IPv4 address was incorrect length");let e=[];for(let t=0;t<r.byteLength;t++)e.push(r[t]);return e.join(".")},rl=function(r){if(r.byteLength!==16)throw new we("IPv6 address was incorrect length");let e=[];for(let n=0;n<r.byteLength;n+=2){let s=r[n],o=r[n+1],i=`${s.toString(16).padStart(2,"0")}${o.toString(16).padStart(2,"0")}`;e.push(i)}let t=e.join(":");try{let n=new URL(`http://[${t}]`);return n.hostname.substring(1,n.hostname.length-1)}catch{throw new we(`Invalid IPv6 address "${t}"`)}};function nl(r){try{let e=new URL(`http://[${r}]`);return e.hostname.substring(1,e.hostname.length-1)}catch{throw new we(`Invalid IPv6 address "${r}"`)}}var $i=Object.values(Hr).map(r=>r.decoder),Fh=(function(){let r=$i[0].or($i[1]);return $i.slice(2).forEach(e=>r=r.or(e)),r})();function ol(r){return Fh.decode(r)}function sl(r){return e=>r.encoder.encode(e)}function Kh(r){if(parseInt(r).toString()!==r)throw new ht("Value must be an integer")}function qh(r){if(r<0)throw new ht("Value must be a positive integer, or zero")}function zh(r){return e=>{if(e>r)throw new ht(`Value must be smaller than or equal to ${r}`)}}function Vh(...r){return e=>{for(let t of r)t(e)}}var yn=Vh(Kh,qh,zh(65535));var ye=-1,Zi=class{protocolsByCode=new Map;protocolsByName=new Map;getProtocol(e){let t;if(typeof e=="string"?t=this.protocolsByName.get(e):t=this.protocolsByCode.get(e),t==null)throw new go(`Protocol ${e} was unknown`);return t}addProtocol(e){this.protocolsByCode.set(e.code,e),this.protocolsByName.set(e.name,e),e.aliases?.forEach(t=>{this.protocolsByName.set(t,e)})}removeProtocol(e){let t=this.protocolsByCode.get(e);t!=null&&(this.protocolsByCode.delete(t.code),this.protocolsByName.delete(t.name),t.aliases?.forEach(n=>{this.protocolsByName.delete(n)}))}},mt=new Zi,np=[{code:4,name:"ip4",size:32,valueToBytes:Yi,bytesToValue:tl,validate:r=>{if(!xo(r))throw new ht(`Invalid IPv4 address "${r}"`)}},{code:6,name:"tcp",size:16,valueToBytes:Zt,bytesToValue:Lr,validate:yn},{code:273,name:"udp",size:16,valueToBytes:Zt,bytesToValue:Lr,validate:yn},{code:33,name:"dccp",size:16,valueToBytes:Zt,bytesToValue:Lr,validate:yn},{code:41,name:"ip6",size:128,valueToBytes:el,bytesToValue:rl,stringToValue:nl,validate:r=>{if(!Xu(r))throw new ht(`Invalid IPv6 address "${r}"`)}},{code:42,name:"ip6zone",size:ye},{code:43,name:"ipcidr",size:8,bytesToValue:Wi("base10"),valueToBytes:ji("base10")},{code:53,name:"dns",size:ye},{code:54,name:"dns4",size:ye},{code:55,name:"dns6",size:ye},{code:56,name:"dnsaddr",size:ye},{code:132,name:"sctp",size:16,valueToBytes:Zt,bytesToValue:Lr,validate:yn},{code:301,name:"udt"},{code:302,name:"utp"},{code:400,name:"unix",size:ye,stringToValue:r=>decodeURIComponent(r),valueToString:r=>encodeURIComponent(r)},{code:421,name:"p2p",aliases:["ipfs"],size:ye,bytesToValue:Wi("base58btc"),valueToBytes:r=>r.startsWith("Q")||r.startsWith("1")?ji("base58btc")(r):le.parse(r).multihash.bytes},{code:444,name:"onion",size:96,bytesToValue:Gi,valueToBytes:Qu},{code:445,name:"onion3",size:296,bytesToValue:Gi,valueToBytes:Ju},{code:446,name:"garlic64",size:ye},{code:447,name:"garlic32",size:ye},{code:448,name:"tls"},{code:449,name:"sni",size:ye},{code:454,name:"noise"},{code:460,name:"quic"},{code:461,name:"quic-v1"},{code:465,name:"webtransport"},{code:466,name:"certhash",size:ye,bytesToValue:sl(xs),valueToBytes:ol},{code:480,name:"http"},{code:481,name:"http-path",size:ye,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:ye}];np.forEach(r=>{mt.addProtocol(r)});function il(r){let e=[],t=0;for(;t<r.length;){let n=sn(r,t),s=mt.getProtocol(n),o=Ce(n),i=op(s,r,t+o),a=0;i>0&&s.size===ye&&(a=Ce(i));let c=o+a+i,u={code:n,name:s.name,bytes:_e(r.subarray(t,t+c))};if(i>0){let l=t+o+a,f=r.subarray(l,l+i);u.value=s.bytesToValue?.(f)??V(f)}e.push(u),t+=c}return e}function al(r){let e=0,t=[];for(let n of r){if(n.bytes==null){let s=mt.getProtocol(n.code),o=Ce(n.code),i,a=0,c=0;n.value!=null&&(i=s.valueToBytes?.(n.value)??k(n.value),a=i.byteLength,s.size===ye&&(c=Ce(a)));let u=new Uint8Array(o+c+a),l=0;Ar(n.code,u,l),l+=o,i!=null&&(s.size===ye&&(Ar(a,u,l),l+=c),u.set(i,l)),n.bytes=u}t.push(n.bytes),e+=n.bytes.byteLength}return Xe(t,e)}function cl(r){if(r.charAt(0)!=="/")throw new we('String multiaddr must start with "/"');let e=[],t="protocol",n="",s="";for(let o=1;o<r.length;o++){let i=r.charAt(o);i!=="/"&&(t==="protocol"?s+=r.charAt(o):n+=r.charAt(o));let a=o===r.length-1;if(i==="/"||a){let c=mt.getProtocol(s);if(t==="protocol"){if(c.size==null||c.size===0){e.push({code:c.code,name:c.name}),n="",s="",t="protocol";continue}else if(a)throw new we(`Component ${s} was missing value`);t="value"}else if(t==="value"){let u={code:c.code,name:c.name};if(c.size!=null&&c.size!==0){if(n==="")throw new we(`Component ${s} was missing value`);u.value=c.stringToValue?.(n)??n}e.push(u),n="",s="",t="protocol"}}}if(s!==""&&n!=="")throw new we("Incomplete multiaddr");return e}function ul(r){return`/${r.flatMap(e=>{if(e.value==null)return e.name;let t=mt.getProtocol(e.code);if(t==null)throw new we(`Unknown protocol code ${e.code}`);return[e.name,t.valueToString?.(e.value)??e.value]}).join("/")}`}function op(r,e,t){return r.size==null||r.size===0?0:r.size>0?r.size/8:sn(e,t)}var sp=Symbol.for("nodejs.util.inspect.custom"),ha=Symbol.for("@multiformats/multiaddr");function ip(r){if(r==null&&(r="/"),ll(r))return r.getComponents();if(r instanceof Uint8Array)return il(r);if(typeof r=="string")return r=r.replace(/\/(\/)+/,"/").replace(/(\/)+$/,""),r===""&&(r="/"),cl(r);if(Array.isArray(r))return r;throw new we("Must be a string, Uint8Array, Component[], or another Multiaddr")}var Ao=class r{[ha]=!0;#e;#t;#r;constructor(e="/",t={}){this.#e=ip(e),t.validate!==!1&&ap(this)}get bytes(){return this.#r==null&&(this.#r=al(this.#e)),this.#r}toString(){return this.#t==null&&(this.#t=ul(this.#e)),this.#t}toJSON(){return this.toString()}getComponents(){return[...this.#e.map(e=>({...e}))]}encapsulate(e){let t=new r(e);return new r([...this.#e,...t.getComponents()],{validate:!1})}decapsulate(e){let t=e.toString(),n=this.toString(),s=n.lastIndexOf(t);if(s<0)throw new yo(`Address ${this.toString()} does not contain subaddress: ${t}`);return new r(n.slice(0,s),{validate:!1})}decapsulateCode(e){let t;for(let n=this.#e.length-1;n>-1;n--)if(this.#e[n].code===e){t=n;break}return new r(this.#e.slice(0,t),{validate:!1})}equals(e){return ce(this.bytes,e.bytes)}[sp](){return`Multiaddr(${this.toString()})`}};function ap(r){r.getComponents().forEach(e=>{let t=mt.getProtocol(e.code);e.value!=null&&t.validate?.(e.value)})}function ll(r){return!!r?.[ha]}function Ue(r){return new Ao(r)}var pa={32:16777619n,64:1099511628211n,128:309485009821345068724781371n,256:374144419156711147060143317175368453031918731002211n,512:35835915874844867368919076489095108449946327955754392558399825615420669938882575126094039892345713852759n,1024:5016456510113118655434598811035278955030765345404790744303017523831112055108147451509157692220295382716162651878526895249385292291816524375083746691371804094271873160484737966720260389217684476157468082573n},fl={32:2166136261n,64:14695981039346656037n,128:144066263297769815596495629667062367629n,256:100029257958052580907070968620625704837092796014241193945225284501741471925557n,512:9659303129496669498009435400716310466090418745672637896108374329434462657994582932197716438449813051892206539805784495328239340083876191928701583869517785n,1024:14197795064947621068722070641403218320880622795441933960878474914617582723252296732303717722150864096521202355549365628174669108571814760471015076148029755969804077320157692458563003215304957150157403644460363550505412711285966361610267868082893823963790439336411086884584107735010676915n},dl=new globalThis.TextEncoder;function cp(r,e){let t=pa[e],n=fl[e];for(let s=0;s<r.length;s++)n^=BigInt(r[s]),n=BigInt.asUintN(e,n*t);return n}function up(r,e,t){if(t.length===0)throw new Error("The `utf8Buffer` option must have a length greater than zero");let n=pa[e],s=fl[e],o=r;for(;o.length>0;){let i=dl.encodeInto(o,t);o=o.slice(i.read);for(let a=0;a<i.written;a++)s^=BigInt(t[a]),s=BigInt.asUintN(e,s*n)}return s}function ma(r,{size:e=32,utf8Buffer:t}={}){if(!pa[e])throw new Error("The `size` option must be one of 32, 64, 128, 256, 512, or 1024");if(typeof r=="string"){if(t)return up(r,e,t);r=dl.encode(r)}return cp(r,e)}var gn={hash:r=>Number(ma(r,{size:32})),hashV:(r,e)=>lp(gn.hash(r,e))};function lp(r){let e=r.toString(16);return e.length%2===1&&(e=`0${e}`),k(e,"base16")}var ya=64,je=class{fp;h;seed;constructor(e,t,n,s=2){if(s>ya)throw new TypeError("Invalid Fingerprint Size");let o=t.hashV(e,n),i=J(s);for(let a=0;a<i.length;a++)i[a]=o[a];i.length===0&&(i[0]=7),this.fp=i,this.h=t,this.seed=n}hash(){return this.h.hash(this.fp,this.seed)}equals(e){return e?.fp instanceof Uint8Array?ce(this.fp,e.fp):!1}};function Jt(r,e){return Math.floor(Math.random()*(e-r))+r}var er=class{contents;constructor(e){this.contents=new Array(e).fill(null)}has(e){if(!(e instanceof je))throw new TypeError("Invalid Fingerprint");return this.contents.some(t=>e.equals(t))}add(e){if(!(e instanceof je))throw new TypeError("Invalid Fingerprint");for(let t=0;t<this.contents.length;t++)if(this.contents[t]==null)return this.contents[t]=e,!0;return!0}swap(e){if(!(e instanceof je))throw new TypeError("Invalid Fingerprint");let t=Jt(0,this.contents.length-1),n=this.contents[t];return this.contents[t]=e,n}remove(e){if(!(e instanceof je))throw new TypeError("Invalid Fingerprint");let t=this.contents.findIndex(n=>e.equals(n));return t>-1?(this.contents[t]=null,!0):!1}};var fp=500,bn=class{bucketSize;filterSize;fingerprintSize;buckets;count;hash;seed;constructor(e){this.filterSize=e.filterSize,this.bucketSize=e.bucketSize??4,this.fingerprintSize=e.fingerprintSize??2,this.count=0,this.buckets=[],this.hash=e.hash??gn,this.seed=e.seed??Jt(0,Math.pow(2,10))}add(e){typeof e=="string"&&(e=k(e));let t=new je(e,this.hash,this.seed,this.fingerprintSize),n=this.hash.hash(e,this.seed)%this.filterSize,s=(n^t.hash())%this.filterSize;if(this.buckets[n]==null&&(this.buckets[n]=new er(this.bucketSize)),this.buckets[s]==null&&(this.buckets[s]=new er(this.bucketSize)),this.buckets[n].add(t)||this.buckets[s].add(t))return this.count++,!0;let o=[n,s],i=o[Jt(0,o.length-1)];this.buckets[i]==null&&(this.buckets[i]=new er(this.bucketSize));for(let a=0;a<fp;a++){let c=this.buckets[i].swap(t);if(c!=null&&(i=(i^c.hash())%this.filterSize,this.buckets[i]==null&&(this.buckets[i]=new er(this.bucketSize)),this.buckets[i].add(c)))return this.count++,!0}return!1}has(e){typeof e=="string"&&(e=k(e));let t=new je(e,this.hash,this.seed,this.fingerprintSize),n=this.hash.hash(e,this.seed)%this.filterSize,s=this.buckets[n]?.has(t)??!1;if(s)return s;let o=(n^t.hash())%this.filterSize;return this.buckets[o]?.has(t)??!1}remove(e){typeof e=="string"&&(e=k(e));let t=new je(e,this.hash,this.seed,this.fingerprintSize),n=this.hash.hash(e,this.seed)%this.filterSize,s=this.buckets[n]?.remove(t)??!1;if(s)return this.count--,s;let o=(n^t.hash())%this.filterSize,i=this.buckets[o]?.remove(t)??!1;return i&&this.count--,i}get reliable(){return Math.floor(100*(this.count/this.filterSize))<=90}},dp={1:.5,2:.84,4:.95,8:.98};function hp(r=.001){return r>.002?2:r>1e-5?4:8}function hl(r,e=.001){let t=hp(e),n=dp[t],s=Math.round(r/n),o=Math.min(Math.ceil(Math.log2(1/e)+Math.log2(2*t)),ya);return{filterSize:s,bucketSize:t,fingerprintSize:o}}var To=class{filterSize;bucketSize;fingerprintSize;scale;filterSeries;hash;seed;constructor(e){this.bucketSize=e.bucketSize??4,this.filterSize=e.filterSize??(1<<18)/this.bucketSize,this.fingerprintSize=e.fingerprintSize??2,this.scale=e.scale??2,this.hash=e.hash??gn,this.seed=e.seed??Jt(0,Math.pow(2,10)),this.filterSeries=[new bn({filterSize:this.filterSize,bucketSize:this.bucketSize,fingerprintSize:this.fingerprintSize,hash:this.hash,seed:this.seed})]}add(e){if(typeof e=="string"&&(e=k(e)),this.has(e))return!0;let t=this.filterSeries.find(n=>n.reliable);if(t==null){let n=this.filterSize*Math.pow(this.scale,this.filterSeries.length);t=new bn({filterSize:n,bucketSize:this.bucketSize,fingerprintSize:this.fingerprintSize,hash:this.hash,seed:this.seed}),this.filterSeries.push(t)}return t.add(e)}has(e){typeof e=="string"&&(e=k(e));for(let t=0;t<this.filterSeries.length;t++)if(this.filterSeries[t].has(e))return!0;return!1}remove(e){typeof e=="string"&&(e=k(e));for(let t=0;t<this.filterSeries.length;t++)if(this.filterSeries[t].remove(e))return!0;return!1}get count(){return this.filterSeries.reduce((e,t)=>e+t.count,0)}};function Pr(r,e=.001,t){return new To({...hl(r,e),...t??{}})}var X=r=>({match:e=>{let t=e[0];return t==null||t.code!==r||t.value!=null?!1:e.slice(1)}}),O=(r,e)=>({match:t=>{let n=t[0];return n?.code!==r||n.value==null||e!=null&&n.value!==e?!1:t.slice(1)}}),pl=r=>({match:e=>r.match(e)===!1?e:!1}),q=r=>({match:e=>{let t=r.match(e);return t===!1?e:t}}),ve=(...r)=>({match:e=>{let t;for(let n of r){let s=n.match(e);s!==!1&&(t==null||s.length<t.length)&&(t=s)}return t??!1}}),$=(...r)=>({match:e=>{for(let t of r){let n=t.match(e);if(n===!1)return!1;e=n}return e}});function Q(...r){function e(s){if(s==null)return!1;let o=s.getComponents();for(let i of r){let a=i.match(o);if(a===!1)return!1;o=a}return o}function t(s){return e(s)!==!1}function n(s){let o=e(s);return o===!1?!1:o.length===0}return{matchers:r,matches:t,exactMatch:n}}var pp=O(421),dE=Q(pp),Do=O(54),Co=O(55),Lo=O(56),ba=O(53),hE=Q(Do,q(O(421))),pE=Q(Co,q(O(421))),mE=Q(Lo,q(O(421))),yE=Q(ve(ba,Lo,Do,Co),q(O(421))),ml=$(O(4),q(O(43))),yl=$(q(O(42)),O(41),q(O(43))),wa=ve(ml,yl),Nr=ve(wa,ba,Do,Co,Lo),gE=Q(ve(wa,$(ve(ba,Lo,Do,Co),q(O(421))))),bE=Q(ml),wE=Q(yl),xE=Q(wa),xa=$(Nr,O(6)),wn=$(Nr,O(273)),EE=Q($(xa,q(O(421)))),SE=Q(wn),Ea=$(wn,X(460),q(O(421))),Bo=$(wn,X(461),q(O(421))),mp=ve(Ea,Bo),vE=Q(Ea),_E=Q(Bo),ga=ve(Nr,xa,wn,Ea,Bo),gl=ve($(ga,X(477),q(O(421)))),AE=Q(gl),bl=ve($(ga,X(478),q(O(421))),$(ga,X(448),q(O(449)),X(477),q(O(421)))),TE=Q(bl),wl=$(wn,X(280),q(O(466)),q(O(466)),q(O(421))),IE=Q(wl),xl=$(Bo,X(465),q(O(466)),q(O(466)),q(O(421))),DE=Q(xl),Io=ve(gl,bl,$(xa,q(O(421))),$(mp,q(O(421))),$(Nr,q(O(421))),wl,xl,O(421)),El=Q(Io),yp=$(q(Io),X(290),pl(X(281)),q(O(421))),tr=Q(yp),gp=ve($(Io,X(290),X(281),q(O(421))),$(Io,X(281),q(O(421))),$(X(281),q(O(421)))),CE=Q(gp),bp=$(Nr,ve($(O(6,"80")),$(O(6),X(480)),X(480)),q(O(481)),q(O(421))),LE=Q(bp),wp=$(Nr,ve($(O(6,"443")),$(O(6,"443"),X(480)),$(O(6),X(443)),$(O(6),X(448),X(480)),$(X(448),X(480)),X(448),X(443)),q(O(481)),q(O(421))),BE=Q(wp),xp=ve($(O(777),q(O(421)))),RE=Q(xp),Ep=ve($(O(400),q(O(421)))),OE=Q(Ep);function Ge(){let r={};return r.promise=new Promise((e,t)=>{r.resolve=e,r.reject=t}),r}var Ro=class{buffer;mask;top;btm;next;constructor(e){if(!(e>0)||(e-1&e)!==0)throw new Error("Max size for a FixedFIFO should be a power of two");this.buffer=new Array(e),this.mask=e-1,this.top=0,this.btm=0,this.next=null}push(e){return this.buffer[this.top]!==void 0?!1:(this.buffer[this.top]=e,this.top=this.top+1&this.mask,!0)}shift(){let e=this.buffer[this.btm];if(e!==void 0)return this.buffer[this.btm]=void 0,this.btm=this.btm+1&this.mask,e}isEmpty(){return this.buffer[this.btm]===void 0}},Ur=class{size;hwm;head;tail;constructor(e={}){this.hwm=e.splitLimit??16,this.head=new Ro(this.hwm),this.tail=this.head,this.size=0}calculateSize(e){return e?.byteLength!=null?e.byteLength:1}push(e){if(e?.value!=null&&(this.size+=this.calculateSize(e.value)),!this.head.push(e)){let t=this.head;this.head=t.next=new Ro(2*this.head.buffer.length),this.head.push(e)}}shift(){let e=this.tail.shift();if(e===void 0&&this.tail.next!=null){let t=this.tail.next;this.tail.next=null,this.tail=t,e=this.tail.shift()}return e?.value!=null&&(this.size-=this.calculateSize(e.value)),e}isEmpty(){return this.head.isEmpty()}};var Sa=class extends Error{type;code;constructor(e,t){super(e??"The operation was aborted"),this.type="aborted",this.code=t??"ABORT_ERR"}};function Lt(r={}){return Sp(t=>{let n=t.shift();if(n==null)return{done:!0};if(n.error!=null)throw n.error;return{done:n.done===!0,value:n.value}},r)}function Sp(r,e){e=e??{};let t=e.onEnd,n=new Ur,s,o,i,a=Ge(),c=async()=>{try{return n.isEmpty()?i?{done:!0}:await new Promise((h,g)=>{o=S=>{o=null,n.push(S);try{h(r(n))}catch(_){g(_)}return s}}):r(n)}finally{n.isEmpty()&&queueMicrotask(()=>{a.resolve(),a=Ge()})}},u=h=>o!=null?o(h):(n.push(h),s),l=h=>(n=new Ur,o!=null?o({error:h}):(n.push({error:h}),s)),f=h=>{if(i)return s;if(e?.objectMode!==!0&&h?.byteLength==null)throw new Error("objectMode was not true but tried to push non-Uint8Array value");return u({done:!1,value:h})},p=h=>i?s:(i=!0,h!=null?l(h):u({done:!0})),d=()=>(n=new Ur,p(),{done:!0}),y=h=>(p(h),{done:!0});if(s={[Symbol.asyncIterator](){return this},next:c,return:d,throw:y,push:f,end:p,get readableLength(){return n.size},onEmpty:async h=>{let g=h?.signal;if(g?.throwIfAborted(),n.isEmpty())return;let S,_;g!=null&&(S=new Promise((B,C)=>{_=()=>{C(new Sa)},g.addEventListener("abort",_)}));try{await Promise.race([a.promise,S])}finally{_!=null&&g!=null&&g?.removeEventListener("abort",_)}}},t==null)return s;let x=s;return s={[Symbol.asyncIterator](){return this},next(){return x.next()},throw(h){return x.throw(h),t!=null&&(t(h),t=void 0),{done:!0}},return(){return x.return(),t!=null&&(t(),t=void 0),{done:!0}},push:f,end(h){return x.end(h),t!=null&&(t(h),t=void 0),s},get readableLength(){return x.readableLength},onEmpty:h=>x.onEmpty(h)},s}var va=class r extends Error{name="TimeoutError";constructor(e,t){super(e,t),Error.captureStackTrace?.(this,r)}},Sl=r=>r.reason??new DOMException("This operation was aborted.","AbortError");function _a(r,e){let{milliseconds:t,fallback:n,message:s,customTimers:o={setTimeout,clearTimeout},signal:i}=e,a,c,l=new Promise((f,p)=>{if(typeof t!="number"||Math.sign(t)!==1)throw new TypeError(`Expected \`milliseconds\` to be a positive number, got \`${t}\``);if(i?.aborted){p(Sl(i));return}if(i&&(c=()=>{p(Sl(i))},i.addEventListener("abort",c,{once:!0})),r.then(f,p),t===Number.POSITIVE_INFINITY)return;let d=new va;a=o.setTimeout.call(void 0,()=>{if(n){try{f(n())}catch(y){p(y)}return}typeof r.cancel=="function"&&r.cancel(),s===!1?f():s instanceof Error?p(s):(d.message=s??`Promise timed out after ${t} milliseconds`,p(d))},t)}).finally(()=>{l.clear(),c&&i&&i.removeEventListener("abort",c)});return l.clear=()=>{o.clearTimeout.call(void 0,a),a=void 0},l}var vp=r=>{let e=r.addEventListener||r.on||r.addListener,t=r.removeEventListener||r.off||r.removeListener;if(!e||!t)throw new TypeError("Emitter is not compatible");return{addListener:e.bind(r),removeListener:t.bind(r)}};function _p(r,e,t){let n,s=new Promise((o,i)=>{if(t={rejectionEvents:["error"],multiArgs:!1,rejectionMultiArgs:!1,resolveImmediately:!1,...t},!(t.count>=0&&(t.count===Number.POSITIVE_INFINITY||Number.isInteger(t.count))))throw new TypeError("The `count` option should be at least 0 or more");t.signal?.throwIfAborted();let a=[e].flat(),c=[],{addListener:u,removeListener:l}=vp(r),f=async(...d)=>{let y=t.multiArgs?d:d[0];if(t.filter)try{if(!await t.filter(y))return}catch(x){n(),i(x);return}c.push(y),t.count===c.length&&(n(),o(c))},p=(...d)=>{n(),i(t.rejectionMultiArgs?d:d[0])};n=()=>{for(let d of a)l(d,f);for(let d of t.rejectionEvents)a.includes(d)||l(d,p)};for(let d of a)u(d,f);for(let d of t.rejectionEvents)a.includes(d)||u(d,p);t.signal&&t.signal.addEventListener("abort",()=>{p(t.signal.reason)},{once:!0}),t.resolveImmediately&&o(c)});if(s.cancel=n,typeof t.timeout=="number"){let o=_a(s,{milliseconds:t.timeout});return o.cancel=()=>{n(),o.clear()},o}return s}function nt(r,e,t){typeof t=="function"&&(t={filter:t}),t={...t,count:1,resolveImmediately:!1};let n=_p(r,e,t),s=n.then(o=>o[0]);return s.cancel=n.cancel,s}function Aa(r,e){let t,n=function(){let s=function(){t=void 0,r()};clearTimeout(t),t=setTimeout(s,e)};return n.start=()=>{},n.stop=()=>{clearTimeout(t)},n}var Oo=class extends Error{static name="QueueFullError";constructor(e="The queue was full"){super(e),this.name="QueueFullError"}},rr=class extends Error{static name="UnexpectedEOFError";name="UnexpectedEOFError"};var Po=class extends Error{static name="StreamClosedError";name="StreamClosedError"};function Ap(r){return r.reason}async function Bt(r,e,t){if(e==null)return r;let n=t?.translateError??Ap;if(e.aborted)return r.catch(()=>{}),Promise.reject(n(e));let s;try{return await Promise.race([r,new Promise((o,i)=>{s=()=>{i(n(e))},e.addEventListener("abort",s)})])}finally{s!=null&&e.removeEventListener("abort",s)}}var No=class{deferred;signal;onProgress;constructor(e){this.signal=e?.signal,this.onProgress=e?.onProgress,this.deferred=Ge(),this.onAbort=this.onAbort.bind(this),this.signal?.addEventListener("abort",this.onAbort)}onAbort(){this.deferred.reject(this.signal?.reason??new ot)}cleanup(){this.signal?.removeEventListener("abort",this.onAbort)}};function Tp(){return`${parseInt(String(Math.random()*1e9),10).toString()}${Date.now()}`}var Uo=class{id;fn;options;recipients;status;timeline;controller;dispatchingProgress;constructor(e,t){this.id=Tp(),this.status="queued",this.fn=e,this.options=t,this.recipients=[],this.timeline={created:Date.now()},this.controller=new AbortController,this.controller.signal,this.dispatchingProgress=!1,this.onAbort=this.onAbort.bind(this)}abort(e){this.controller.abort(e)}onAbort(){this.recipients.reduce((t,n)=>t&&n.signal?.aborted===!0,!0)&&(this.controller.abort(new ot),this.cleanup())}async join(e){let t=new No(e);return this.recipients.push(t),e?.signal?.addEventListener("abort",this.onAbort),t.deferred.promise}async run(){this.status="running",this.timeline.started=Date.now();try{this.controller.signal.throwIfAborted();let e=await Bt(this.fn({...this.options??{},signal:this.controller.signal,onProgress:t=>{if(!this.dispatchingProgress){this.dispatchingProgress=!0;try{this.recipients.forEach(n=>{n.onProgress?.(t)})}finally{this.dispatchingProgress=!1}}}}),this.controller.signal);this.recipients.forEach(t=>{t.deferred.resolve(e)}),this.status="complete"}catch(e){this.recipients.forEach(t=>{t.deferred.reject(e)}),this.status="errored"}finally{this.timeline.finished=Date.now(),this.cleanup()}}cleanup(){this.recipients.forEach(e=>{e.cleanup(),e.signal?.removeEventListener("abort",this.onAbort)})}};var ko=class extends Ie{concurrency;maxSize;queue;pending;sort;paused;constructor(e={}){super(),this.concurrency=e.concurrency??Number.POSITIVE_INFINITY,this.maxSize=e.maxSize??Number.POSITIVE_INFINITY,this.pending=0,this.paused=!1,e.metricName!=null&&e.metrics?.registerMetricGroup(e.metricName,{calculate:()=>({size:this.queue.length,running:this.pending,queued:this.queue.length-this.pending})}),this.sort=e.sort,this.queue=[],this.emitEmpty=Aa(this.emitEmpty.bind(this),1),this.emitIdle=Aa(this.emitIdle.bind(this),1)}emitEmpty(){this.size===0&&this.safeDispatchEvent("empty")}emitIdle(){this.running===0&&this.safeDispatchEvent("idle")}pause(){this.paused=!0}resume(){this.paused&&(this.paused=!1,this.tryToStartAnother())}tryToStartAnother(){if(this.paused)return!1;if(this.size===0)return this.emitEmpty(),this.running===0&&this.emitIdle(),!1;if(this.pending<this.concurrency){let e;for(let t of this.queue)if(t.status==="queued"){e=t;break}return e==null?!1:(this.safeDispatchEvent("active"),this.pending++,e.run().finally(()=>{for(let t=0;t<this.queue.length;t++)if(this.queue[t]===e){this.queue.splice(t,1);break}this.pending--,this.tryToStartAnother(),this.safeDispatchEvent("next")}),!0)}return!1}enqueue(e){this.queue.push(e),this.sort!=null&&this.queue.sort(this.sort)}async add(e,t){if(t?.signal?.throwIfAborted(),this.size===this.maxSize)throw new Oo;let n=new Uo(e,t);this.enqueue(n),this.safeDispatchEvent("add");let s=n.join(t).then(o=>(this.safeDispatchEvent("completed",{detail:o}),this.safeDispatchEvent("success",{detail:{job:n,result:o}}),o)).catch(o=>{if(n.status==="queued"){for(let i=0;i<this.queue.length;i++)if(this.queue[i]===n){this.queue.splice(i,1);break}}throw this.safeDispatchEvent("failure",{detail:{job:n,error:o}}),o});return this.tryToStartAnother(),s}clear(){this.queue.splice(0,this.queue.length)}abort(){this.queue.forEach(e=>{e.abort(new ot)}),this.clear()}async onEmpty(e){this.size!==0&&await nt(this,"empty",e)}async onSizeLessThan(e,t){this.size<e||await nt(this,"next",{...t,filter:()=>this.size<e})}async onIdle(e){this.pending===0&&this.size===0||await nt(this,"idle",e)}get size(){return this.queue.length}get queued(){return this.queue.length-this.pending}get running(){return this.pending}async*toGenerator(e){e?.signal?.throwIfAborted();let t=Lt({objectMode:!0}),n=c=>{c!=null?this.abort():this.clear(),t.end(c)},s=c=>{c.detail!=null&&t.push(c.detail)},o=c=>{n(c.detail.error)},i=()=>{n()},a=()=>{n(new ot("Queue aborted"))};this.addEventListener("completed",s),this.addEventListener("failure",o),this.addEventListener("idle",i),e?.signal?.addEventListener("abort",a);try{yield*t}finally{this.removeEventListener("completed",s),this.removeEventListener("failure",o),this.removeEventListener("idle",i),e?.signal?.removeEventListener("abort",a),n()}}};var Ip=Math.pow(2,20)*4,Mo=class extends Ie{status;timeline;inactivityTimeout;maxReadBufferLength;maxWriteBufferLength;log;direction;maxMessageSize;readStatus;writeStatus;remoteReadStatus;remoteWriteStatus;writableNeedsDrain;readBuffer;writeBuffer;sendingData;onDrainPromise;constructor(e){super(),this.status="open",this.log=e.log,this.direction=e.direction??"outbound",this.inactivityTimeout=e.inactivityTimeout??12e4,this.maxReadBufferLength=e.maxReadBufferLength??Ip,this.maxWriteBufferLength=e.maxWriteBufferLength,this.maxMessageSize=e.maxMessageSize,this.readBuffer=new ee,this.writeBuffer=new ee,this.readStatus="readable",this.remoteReadStatus="readable",this.writeStatus="writable",this.remoteWriteStatus="writable",this.sendingData=!1,this.writableNeedsDrain=!1,this.timeline={open:Date.now()},this.processSendQueue=this.processSendQueue.bind(this);let t=()=>{this.writableNeedsDrain&&(this.log.trace("drain event received, continue sending data"),this.writableNeedsDrain=!1,queueMicrotask(()=>{try{this.processSendQueue()}catch(s){this.log.error("processSendQueue threw - %e",s)}})),this.onDrainPromise?.resolve()};this.addEventListener("drain",t);let n=s=>{this.onDrainPromise?.reject(s.error??new Po)};this.addEventListener("close",n)}get readBufferLength(){return this.readBuffer.byteLength}get writeBufferLength(){return this.writeBuffer.byteLength}async onDrain(e){return this.writableNeedsDrain!==!0?Promise.resolve():(this.onDrainPromise==null&&(this.onDrainPromise=Promise.withResolvers()),Bt(this.onDrainPromise.promise,e?.signal))}async*[Symbol.asyncIterator](){if(this.readStatus!=="readable"&&this.readStatus!=="paused")return;let e=Lt(),t=o=>{e.push(o.data)};this.addEventListener("message",t);let n=o=>{e.end(o.error)};this.addEventListener("close",n);let s=()=>{e.end()};this.addEventListener("remoteCloseWrite",s);try{yield*e}finally{this.removeEventListener("message",t),this.removeEventListener("close",n),this.removeEventListener("remoteCloseWrite",s)}}isReadable(){return this.status==="open"}send(e){if(this.writeStatus==="closed"||this.writeStatus==="closing")throw new yt(`Cannot write to a stream that is ${this.writeStatus}`);return this.log.trace("append %d bytes to write buffer",e.byteLength),this.writeBuffer.append(e),this.processSendQueue()}abort(e){if(!(this.status==="aborted"||this.status==="reset"||this.status==="closed")){this.log.error("abort with error - %e",e),this.status="aborted",this.readBuffer.byteLength>0&&this.readBuffer.consume(this.readBuffer.byteLength),this.writeBuffer.byteLength>0&&(this.writeBuffer.consume(this.writeBuffer.byteLength),this.safeDispatchEvent("idle")),this.writeStatus="closed",this.remoteWriteStatus="closed",this.readStatus="closed",this.remoteReadStatus="closed",this.timeline.close=Date.now();try{this.sendReset(e)}catch(t){this.log("failed to send reset to remote - %e",t)}this.dispatchEvent(new On(e))}}pause(){if(this.readStatus==="closed"||this.readStatus==="closing")throw new yt("Cannot pause a stream that is closing/closed");this.readStatus!=="paused"&&(this.readStatus="paused",this.sendPause())}resume(){if(this.readStatus==="closed"||this.readStatus==="closing")throw new yt("Cannot resume a stream that is closing/closed");this.readStatus!=="readable"&&(this.readStatus="readable",this.dispatchReadBuffer(),this.sendResume())}push(e){if(this.readStatus==="closed"||this.readStatus==="closing")throw new yt(`Cannot push data onto a stream that is ${this.readStatus}`);if(e.byteLength!==0){if(this.readBuffer.append(e),this.readStatus==="paused"||this.listenerCount("message")===0){this.checkReadBufferLength();return}setTimeout(()=>{this.dispatchReadBuffer()},0)}}unshift(e){if(this.readStatus==="closed"||this.readStatus==="closing")throw new yt(`Cannot push data onto a stream that is ${this.readStatus}`);if(e.byteLength!==0){if(this.readBuffer.prepend(e),this.readStatus==="paused"||this.listenerCount("message")===0){this.checkReadBufferLength();return}setTimeout(()=>{this.dispatchReadBuffer()},0)}}onData(e){if(e.byteLength!==0){if(this.readStatus==="closing"||this.readStatus==="closed"){this.log("ignoring data - read status %s",this.readStatus);return}this.readBuffer.append(e),this.dispatchReadBuffer()}}addEventListener(...e){super.addEventListener.apply(this,e),e[0]==="message"&&this.readBuffer.byteLength>0&&queueMicrotask(()=>{this.dispatchReadBuffer()})}onRemoteReset(){this.log("remote reset"),this.status="reset",this.writeStatus="closed",this.remoteWriteStatus="closed",this.remoteReadStatus="closed",this.timeline.close=Date.now(),this.readBuffer.byteLength===0&&(this.readStatus="closed");let e=new In;this.dispatchEvent(new Pn(e))}onTransportClosed(e){this.log("transport closed"),this.readStatus==="readable"&&this.readBuffer.byteLength===0&&(this.log("close readable end after transport closed and read buffer is empty"),this.readStatus="closed"),this.remoteReadStatus!=="closed"&&(this.remoteReadStatus="closed"),this.remoteWriteStatus!=="closed"&&(this.remoteWriteStatus="closed"),this.writeStatus!=="closed"&&(this.writeStatus="closed"),e!=null?this.abort(e):(this.status==="open"||this.status==="closing")&&(this.timeline.close=Date.now(),this.status="closed",this.writeStatus="closed",this.remoteWriteStatus="closed",this.remoteReadStatus="closed",this.dispatchEvent(new cr))}onRemoteCloseWrite(){this.remoteWriteStatus!=="closed"&&(this.log.trace("on remote close write"),this.remoteWriteStatus="closed",this.safeDispatchEvent("remoteCloseWrite"),this.writeStatus==="closed"&&this.onTransportClosed())}onRemoteCloseRead(){this.log.trace("on remote close read"),this.remoteReadStatus="closed",this.writeBuffer.byteLength>0&&(this.writeBuffer.consume(this.writeBuffer.byteLength),this.safeDispatchEvent("idle"))}processSendQueue(){if(this.writableNeedsDrain)return this.log.trace("not processing send queue as drain is required"),this.checkWriteBufferLength(),!1;if(this.writeBuffer.byteLength===0)return this.log.trace("not processing send queue as no bytes to send"),!0;if(this.sendingData)return this.log.trace("not processing send queue as already sending data"),!0;if(this.writeStatus!=="writable"&&this.writeStatus!=="closing")return this.log.trace("not processing send queue as stream is %s",this.writeStatus),!1;this.sendingData=!0,this.log.trace("processing send queue with %d queued bytes",this.writeBuffer.byteLength);try{let e=!0,t=this.writeBuffer.byteLength,n=0;for(;this.writeBuffer.byteLength>0;){let s=Math.min(this.maxMessageSize??this.writeBuffer.byteLength,this.writeBuffer.byteLength);if(s===0){e=!1;break}let o=this.writeBuffer.sublist(0,s),i=new ee(o);this.writeBuffer.consume(o.byteLength);let a;try{a=this.sendData(o)}catch(c){throw this.writeBuffer.prepend(i),this.abort(c),c}if(e=a.canSendMore,n+=a.sentBytes,a.sentBytes!==i.byteLength&&(i.consume(a.sentBytes),this.writeBuffer.prepend(i)),!e)break}return e||(this.log.trace("sent %d/%d bytes, pausing sending because underlying stream is full, %d bytes left in the write buffer",n,t,this.writeBuffer.byteLength),this.writableNeedsDrain=!0,this.checkWriteBufferLength()),this.writeBuffer.byteLength===0&&this.safeDispatchEvent("idle"),e}finally{this.sendingData=!1}}dispatchReadBuffer(){try{if(this.listenerCount("message")===0){this.log.trace("not dispatching pause buffer as there are no listeners for the message event");return}if(this.readBuffer.byteLength===0){this.log.trace("not dispatching pause buffer as there is no data to dispatch");return}if(this.readStatus==="paused"){this.log.trace("not dispatching pause buffer we are paused");return}if(this.readStatus==="closing"||this.readStatus==="closed"){this.log("dropping %d bytes because the readable end is %s",this.readBuffer.byteLength,this.readStatus),this.readBuffer.consume(this.readBuffer.byteLength);return}let e=this.readBuffer.sublist();this.readBuffer.consume(e.byteLength),this.dispatchEvent(new Rn(e))}finally{this.readBuffer.byteLength===0&&this.remoteWriteStatus==="closed"&&(this.log("close readable end after dispatching read buffer and remote writable end is closed"),this.readStatus="closed"),this.checkReadBufferLength()}}checkReadBufferLength(){this.readBuffer.byteLength>this.maxReadBufferLength&&this.abort(new Fr(`Read buffer length of ${this.readBuffer.byteLength} exceeded limit of ${this.maxReadBufferLength}, read status is ${this.readStatus}`))}checkWriteBufferLength(){this.maxWriteBufferLength!=null&&this.writeBuffer.byteLength>this.maxWriteBufferLength&&this.abort(new Fr(`Write buffer length of ${this.writeBuffer.byteLength} exceeded limit of ${this.maxWriteBufferLength}, write status is ${this.writeStatus}`))}onMuxerNeedsDrain(){this.writableNeedsDrain=!0}onMuxerDrain(){this.safeDispatchEvent("drain")}};var Fo=class extends Mo{remoteAddr;metricPrefix;metrics;constructor(e){super(e),this.metricPrefix=e.metricPrefix??"",this.metrics=e.metrics,this.remoteAddr=e.remoteAddr,this.addEventListener("close",t=>{this.metrics?.increment({[`${this.metricPrefix}end`]:!0}),t.error!=null?t.local?this.metrics?.increment({[`${this.metricPrefix}abort`]:!0}):this.metrics?.increment({[`${this.metricPrefix}reset`]:!0}):t.local?this.metrics?.increment({[`${this.metricPrefix}_local_close`]:!0}):this.metrics?.increment({[`${this.metricPrefix}_remote_close`]:!0})})}async close(e){this.status==="open"&&(this.status="closing",this.writeStatus="closing",this.remoteWriteStatus="closing",this.remoteReadStatus="closing",(this.sendingData||this.writeBuffer.byteLength>0)&&(this.log("waiting for write queue to become idle before closing writable end of stream, %d unsent bytes",this.writeBuffer.byteLength),await nt(this,"idle",{...e,rejectionEvents:["close"]})),this.writableNeedsDrain&&(this.log("waiting for write queue to drain before closing writable end of stream, %d unsent bytes",this.writeBuffer.byteLength),await nt(this,"drain",{...e,rejectionEvents:["close"]})),await this.sendClose(e),this.onTransportClosed())}};function Ko(r){let e=new globalThis.AbortController;function t(){let o=r.filter(i=>i?.aborted===!0).map(i=>i?.reason).pop();e.abort(o);for(let i of r)i?.removeEventListener!=null&&i.removeEventListener("abort",t)}for(let o of r){if(o?.aborted===!0){t();break}o?.addEventListener!=null&&o.addEventListener("abort",t)}function n(){for(let o of r)o?.removeEventListener!=null&&o.removeEventListener("abort",t)}let s=e.signal;return s.clear=n,s}var Ta=class{readNext;haveNext;ended;nextResult;error;constructor(){this.ended=!1,this.readNext=Ge(),this.haveNext=Ge()}[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 e=this.nextResult;return this.nextResult=void 0,this.readNext.resolve(),this.readNext=Ge(),e}async throw(e){return this.ended=!0,this.error=e,e!=null&&(this.haveNext.promise.catch(()=>{}),this.haveNext.reject(e)),{done:!0,value:void 0}}async return(){let e={done:!0,value:void 0};return this.ended=!0,this.nextResult=e,this.haveNext.resolve(),e}async push(e,t){await this._push(e,t)}async end(e,t){e!=null?await this.throw(e):await this._push(void 0,t)}async _push(e,t){if(e!=null&&this.ended)throw this.error??new Error("Cannot push value onto an ended pushable");for(;this.nextResult!=null;)await this.readNext.promise;e!=null?this.nextResult={done:!1,value:e}:(this.ended=!0,this.nextResult={done:!0,value:void 0}),this.haveNext.resolve(),this.haveNext=Ge(),await Bt(this.readNext.promise,t?.signal,t)}};function vl(){return new Ta}function Dp(r){return r[Symbol.asyncIterator]!=null}async function Cp(r,e,t){try{await Promise.all(r.map(async n=>{for await(let s of n)await e.push(s,{signal:t}),t.throwIfAborted()})),await e.end(void 0,{signal:t})}catch(n){await e.end(n,{signal:t}).catch(()=>{})}}async function*Lp(r){let e=new AbortController,t=vl();Cp(r,t,e.signal).catch(()=>{});try{yield*t}finally{e.abort()}}function*Bp(r){for(let e of r)yield*e}function Rp(...r){let e=[];for(let t of r)Dp(t)||e.push(t);return e.length===r.length?Bp(e):Lp(r)}var _l=Rp;function Al(r,...e){if(r==null)throw new Error("Empty pipeline");if(Ia(r)){let n=r;r=()=>n.source}else if(Il(r)||Tl(r)){let n=r;r=()=>n}let t=[r,...e];if(t.length>1&&Ia(t[t.length-1])&&(t[t.length-1]=t[t.length-1].sink),t.length>2)for(let n=1;n<t.length-1;n++)Ia(t[n])&&(t[n]=Pp(t[n]));return Op(...t)}var Op=(...r)=>{let e;for(;r.length>0;)e=r.shift()(e);return e},Tl=r=>r?.[Symbol.asyncIterator]!=null,Il=r=>r?.[Symbol.iterator]!=null,Ia=r=>r==null?!1:r.sink!=null&&r.source!=null,Pp=r=>e=>{let t=r.sink(e);if(t?.then!=null){let n=Lt({objectMode:!0});t.then(()=>{n.end()},i=>{n.end(i)});let s,o=r.source;if(Tl(o))s=async function*(){yield*o,n.end()};else if(Il(o))s=function*(){yield*o,n.end()};else throw new Error("Unknown duplex source type - must be Iterable or AsyncIterable");return _l(n,s())}return r.source};var Np=4194304,qo=class extends Error{static name="UnwrappedError";name="UnwrappedError"},Ca=class extends Error{name="InvalidMessageLengthError";code="ERR_INVALID_MSG_LENGTH"},La=class extends Error{name="InvalidDataLengthError";code="ERR_MSG_DATA_TOO_LONG"},Ba=class extends Error{name="InvalidDataLengthLengthError";code="ERR_MSG_LENGTH_TOO_LONG"};function Up(r){return typeof r?.closeRead=="function"}function kp(r){return typeof r?.close=="function"}function Da(r){return Up(r)?r.remoteWriteStatus!=="writable"&&r.readBufferLength===0:kp(r)?r.status!=="open":!1}function Mp(r){return r?.addEventListener!=null&&r?.removeEventListener!=null&&r?.send!=null&&r?.push!=null&&r?.log!=null}function Fp(r,e){let t=e?.maxBufferSize??Np,n=new ee,s,o=!1;if(!Mp(r))throw new oe("Argument should be a Stream or a Multiaddr");let i=l=>{if(n.append(l.data),n.byteLength>t){let f=n.byteLength;n.consume(n.byteLength),s?.reject(new Error(`Read buffer overflow - ${f} > ${t}`))}s?.resolve()};r.addEventListener("message",i);let a=l=>{l.error!=null?s?.reject(l.error):s?.resolve()};r.addEventListener("close",a);let c=()=>{s?.resolve()};r.addEventListener("remoteCloseWrite",c);let u={readBuffer:n,async read(l){if(o===!0)throw new qo("Stream was unwrapped");if(Da(r)){if(n.byteLength===0&&l?.bytes==null)return null;if(l?.bytes!=null&&n.byteLength<l.bytes)throw r.log.error("closed after reading %d/%d bytes",n.byteLength,l.bytes),new rr(`Unexpected EOF - stream closed after reading ${n.byteLength}/${l.bytes} bytes`)}let f=l?.bytes??1;for(s=Promise.withResolvers();;){if(n.byteLength>=f){s.resolve();break}if(await Bt(s.promise,l?.signal),Da(r)){if(n.byteLength===0&&l?.bytes==null)return null;break}s=Promise.withResolvers()}let p=l?.bytes??n.byteLength;if(n.byteLength<p){if(Da(r))throw r.log.error("closed while reading %d/%d bytes",n.byteLength,p),new rr(`Unexpected EOF - stream closed while reading ${n.byteLength}/${p} bytes`);return u.read(l)}let d=n.sublist(0,p);return n.consume(p),d},async write(l,f){if(o===!0)throw new qo("Stream was unwrapped");r.send(l)||await nt(r,"drain",{signal:f?.signal,rejectionEvents:["close"]})},unwrap(){return o||(o=!0,r.removeEventListener("message",i),r.removeEventListener("close",a),r.removeEventListener("remoteCloseWrite",c),n.byteLength>0&&(r.log("stream unwrapped with %d unread bytes",n.byteLength),r.unshift(n))),r}};return u}function Kp(r,e={}){let t=Fp(r,e);e.maxDataLength!=null&&e.maxLengthLength==null&&(e.maxLengthLength=Ce(e.maxDataLength));let n=e?.lengthDecoder??sn,s=e?.lengthEncoder??Tr;return{async read(i){let a=-1,c=new ee;for(;;){let l=await t.read({...i,bytes:1});if(l==null)break;c.append(l);try{a=n(c)}catch(f){if(f instanceof RangeError)continue;throw f}if(a<0)throw new Ca("Invalid message length");if(e?.maxLengthLength!=null&&c.byteLength>e.maxLengthLength)throw new Ba(`Message length length too long - ${c.byteLength} > ${e.maxLengthLength}`);if(a>-1)break}if(e?.maxDataLength!=null&&a>e.maxDataLength)throw new La(`Message length too long - ${a} > ${e.maxDataLength}`);let u=await t.read({...i,bytes:a});if(u==null)throw r.log.error("tried to read %d bytes but the stream closed",a),new rr(`Unexpected EOF - tried to read ${a} bytes but the stream closed`);if(u.byteLength!==a)throw r.log.error("read %d/%d bytes before the stream closed",u.byteLength,a),new rr(`Unexpected EOF - read ${u.byteLength}/${a} bytes before the stream closed`);return u},async write(i,a){await t.write(new ee(s(i.byteLength),i),a)},async writeV(i,a){let c=new ee(...i.flatMap(u=>[s(u.byteLength),u]));await t.write(c,a)},unwrap(){return t.unwrap()}}}function Rt(r,e){let t=Kp(r,e),n={read:async(s,o)=>{let i=await t.read(o);return s.decode(i)},write:async(s,o,i)=>{await t.write(o.encode(s),i)},writeV:async(s,o,i)=>{await t.writeV(s.map(a=>o.encode(a)),i)},pb:s=>({read:async o=>n.read(s,o),write:async(o,i)=>n.write(o,s,i),writeV:async(o,i)=>n.writeV(o,s,i),unwrap:()=>n}),unwrap:()=>t.unwrap()};return n}function qp(r){return r?.addEventListener!=null}function zp(r){let e=Lt(),t,n=i=>{e.push(i.data)},s=()=>{e.end(),r.removeEventListener("message",n),r.removeEventListener("close",o),r.removeEventListener("remoteCloseWrite",s)},o=i=>{e.end(i.error),i.error!=null&&t?.reject(i.error),r.removeEventListener("message",n),r.removeEventListener("close",o),r.removeEventListener("remoteCloseWrite",s)};return r.addEventListener("message",n),r.addEventListener("close",o,{once:!0}),r.addEventListener("remoteCloseWrite",s,{once:!0}),{source:e,async sink(i){async function*a(){yield*i}let c=a();for(;;){t=Promise.withResolvers();let{done:u,value:l}=await Promise.race([c.next(),t.promise]);if(r.writeStatus==="closing"||r.writeStatus==="closed"||(l!=null&&(r.send(l)||await Promise.race([nt(r,"drain",{rejectionEvents:["close"]})])),u===!0))break}await r.close()}}}function Dl(...r){let e=r.map(t=>qp(t)?zp(t):t);return Al(...e)}var kr=class extends ko{has(e){return this.find(e)!=null}find(e){return this.queue.find(t=>e.equals(t.options.peerId))}};var Ra=1e3,Cl=60*Ra,Ll=15,Bl=120*Cl,Rl=1,zo=5e3,Ol=100,Oa="circuit-relay-source",xn=`${Wa}-circuit-relay`,Pl=2*Cl,Nl=BigInt(1<<17),Fe="/libp2p/circuit/relay/0.2.0/hop",nr="/libp2p/circuit/relay/0.2.0/stop",Ul=30*Ra,M2=30*Ra,En=300,kl=4096,Ml=.001;var Y;(function(r){let e;(function(a){a.RESERVE="RESERVE",a.CONNECT="CONNECT",a.STATUS="STATUS"})(e=r.Type||(r.Type={}));let t;(function(a){a[a.RESERVE=0]="RESERVE",a[a.CONNECT=1]="CONNECT",a[a.STATUS=2]="STATUS"})(t||(t={})),(function(a){a.codec=()=>Gt(t)})(e=r.Type||(r.Type={}));let n;r.codec=()=>(n==null&&(n=Oe((a,c,u={})=>{u.lengthDelimited!==!1&&c.fork(),a.type!=null&&(c.uint32(8),r.Type.codec().encode(a.type,c)),a.peer!=null&&(c.uint32(18),Ot.codec().encode(a.peer,c)),a.reservation!=null&&(c.uint32(26),Sn.codec().encode(a.reservation,c)),a.limit!=null&&(c.uint32(34),Pt.codec().encode(a.limit,c)),a.status!=null&&(c.uint32(40),F.codec().encode(a.status,c)),u.lengthDelimited!==!1&&c.ldelim()},(a,c,u={})=>{let l={},f=c==null?a.len:a.pos+c;for(;a.pos<f;){let p=a.uint32();switch(p>>>3){case 1:{l.type=r.Type.codec().decode(a);break}case 2:{l.peer=Ot.codec().decode(a,a.uint32(),{limits:u.limits?.peer});break}case 3:{l.reservation=Sn.codec().decode(a,a.uint32(),{limits:u.limits?.reservation});break}case 4:{l.limit=Pt.codec().decode(a,a.uint32(),{limits:u.limits?.limit});break}case 5:{l.status=F.codec().decode(a);break}default:{a.skipType(p&7);break}}}return l},function*(a,c,u,l={}){let f=c==null?a.len:a.pos+c;for(;a.pos<f;){let p=a.uint32();switch(p>>>3){case 1:{yield{field:`${u}.type`,value:r.Type.codec().decode(a)};break}case 2:{yield*Ot.codec().stream(a,a.uint32(),`${u}.peer`,{limits:l.limits?.peer});break}case 3:{yield*Sn.codec().stream(a,a.uint32(),`${u}.reservation`,{limits:l.limits?.reservation});break}case 4:{yield*Pt.codec().stream(a,a.uint32(),`${u}.limit`,{limits:l.limits?.limit});break}case 5:{yield{field:`${u}.status`,value:F.codec().decode(a)};break}default:{a.skipType(p&7);break}}}})),n);function s(a){return Be(a,r.codec())}r.encode=s;function o(a,c){return Le(a,r.codec(),c)}r.decode=o;function i(a,c){return Re(a,r.codec(),c)}r.stream=i})(Y||(Y={}));var ke;(function(r){let e;(function(a){a.CONNECT="CONNECT",a.STATUS="STATUS"})(e=r.Type||(r.Type={}));let t;(function(a){a[a.CONNECT=0]="CONNECT",a[a.STATUS=1]="STATUS"})(t||(t={})),(function(a){a.codec=()=>Gt(t)})(e=r.Type||(r.Type={}));let n;r.codec=()=>(n==null&&(n=Oe((a,c,u={})=>{u.lengthDelimited!==!1&&c.fork(),a.type!=null&&(c.uint32(8),r.Type.codec().encode(a.type,c)),a.peer!=null&&(c.uint32(18),Ot.codec().encode(a.peer,c)),a.limit!=null&&(c.uint32(26),Pt.codec().encode(a.limit,c)),a.status!=null&&(c.uint32(32),F.codec().encode(a.status,c)),u.lengthDelimited!==!1&&c.ldelim()},(a,c,u={})=>{let l={},f=c==null?a.len:a.pos+c;for(;a.pos<f;){let p=a.uint32();switch(p>>>3){case 1:{l.type=r.Type.codec().decode(a);break}case 2:{l.peer=Ot.codec().decode(a,a.uint32(),{limits:u.limits?.peer});break}case 3:{l.limit=Pt.codec().decode(a,a.uint32(),{limits:u.limits?.limit});break}case 4:{l.status=F.codec().decode(a);break}default:{a.skipType(p&7);break}}}return l},function*(a,c,u,l={}){let f=c==null?a.len:a.pos+c;for(;a.pos<f;){let p=a.uint32();switch(p>>>3){case 1:{yield{field:`${u}.type`,value:r.Type.codec().decode(a)};break}case 2:{yield*Ot.codec().stream(a,a.uint32(),`${u}.peer`,{limits:l.limits?.peer});break}case 3:{yield*Pt.codec().stream(a,a.uint32(),`${u}.limit`,{limits:l.limits?.limit});break}case 4:{yield{field:`${u}.status`,value:F.codec().decode(a)};break}default:{a.skipType(p&7);break}}}})),n);function s(a){return Be(a,r.codec())}r.encode=s;function o(a,c){return Le(a,r.codec(),c)}r.decode=o;function i(a,c){return Re(a,r.codec(),c)}r.stream=i})(ke||(ke={}));var Ot;(function(r){let e;r.codec=()=>(e==null&&(e=Oe((o,i,a={})=>{if(a.lengthDelimited!==!1&&i.fork(),o.id!=null&&o.id.byteLength>0&&(i.uint32(10),i.bytes(o.id)),o.addrs!=null&&o.addrs.length>0)for(let c of o.addrs)i.uint32(18),i.bytes(c);a.lengthDelimited!==!1&&i.ldelim()},(o,i,a={})=>{let c={id:J(0),addrs:[]},u=i==null?o.len:o.pos+i;for(;o.pos<u;){let l=o.uint32();switch(l>>>3){case 1:{c.id=o.bytes();break}case 2:{if(a.limits?.addrs!=null&&c.addrs.length===a.limits.addrs)throw new Yt('Decode error - repeated field "addrs" had too many elements');c.addrs.push(o.bytes());break}default:{o.skipType(l&7);break}}}return c},function*(o,i,a,c={}){let u={addrs:0},l=i==null?o.len:o.pos+i;for(;o.pos<l;){let f=o.uint32();switch(f>>>3){case 1:{yield{field:`${a}.id`,value:o.bytes()};break}case 2:{if(c.limits?.addrs!=null&&u.addrs===c.limits.addrs)throw new Yt('Streaming decode error - repeated field "addrs" had too many elements');yield{field:`${a}.addrs[]`,index:u.addrs,value:o.bytes()},u.addrs++;break}default:{o.skipType(f&7);break}}}})),e);function t(o){return Be(o,r.codec())}r.encode=t;function n(o,i){return Le(o,r.codec(),i)}r.decode=n;function s(o,i){return Re(o,r.codec(),i)}r.stream=s})(Ot||(Ot={}));var Sn;(function(r){let e;r.codec=()=>(e==null&&(e=Oe((o,i,a={})=>{if(a.lengthDelimited!==!1&&i.fork(),o.expire!=null&&o.expire!==0n&&(i.uint32(8),i.uint64(o.expire)),o.addrs!=null&&o.addrs.length>0)for(let c of o.addrs)i.uint32(18),i.bytes(c);o.voucher!=null&&(i.uint32(26),vn.codec().encode(o.voucher,i)),a.lengthDelimited!==!1&&i.ldelim()},(o,i,a={})=>{let c={expire:0n,addrs:[]},u=i==null?o.len:o.pos+i;for(;o.pos<u;){let l=o.uint32();switch(l>>>3){case 1:{c.expire=o.uint64();break}case 2:{if(a.limits?.addrs!=null&&c.addrs.length===a.limits.addrs)throw new Yt('Decode error - repeated field "addrs" had too many elements');c.addrs.push(o.bytes());break}case 3:{c.voucher=vn.codec().decode(o,o.uint32(),{limits:a.limits?.voucher});break}default:{o.skipType(l&7);break}}}return c},function*(o,i,a,c={}){let u={addrs:0},l=i==null?o.len:o.pos+i;for(;o.pos<l;){let f=o.uint32();switch(f>>>3){case 1:{yield{field:`${a}.expire`,value:o.uint64()};break}case 2:{if(c.limits?.addrs!=null&&u.addrs===c.limits.addrs)throw new Yt('Streaming decode error - repeated field "addrs" had too many elements');yield{field:`${a}.addrs[]`,index:u.addrs,value:o.bytes()},u.addrs++;break}case 3:{yield*vn.codec().stream(o,o.uint32(),`${a}.voucher`,{limits:c.limits?.voucher});break}default:{o.skipType(f&7);break}}}})),e);function t(o){return Be(o,r.codec())}r.encode=t;function n(o,i){return Le(o,r.codec(),i)}r.decode=n;function s(o,i){return Re(o,r.codec(),i)}r.stream=s})(Sn||(Sn={}));var Pt;(function(r){let e;r.codec=()=>(e==null&&(e=Oe((o,i,a={})=>{a.lengthDelimited!==!1&&i.fork(),o.duration!=null&&(i.uint32(8),i.uint32(o.duration)),o.data!=null&&(i.uint32(16),i.uint64(o.data)),a.lengthDelimited!==!1&&i.ldelim()},(o,i,a={})=>{let c={},u=i==null?o.len:o.pos+i;for(;o.pos<u;){let l=o.uint32();switch(l>>>3){case 1:{c.duration=o.uint32();break}case 2:{c.data=o.uint64();break}default:{o.skipType(l&7);break}}}return c},function*(o,i,a,c={}){let u=i==null?o.len:o.pos+i;for(;o.pos<u;){let l=o.uint32();switch(l>>>3){case 1:{yield{field:`${a}.duration`,value:o.uint32()};break}case 2:{yield{field:`${a}.data`,value:o.uint64()};break}default:{o.skipType(l&7);break}}}})),e);function t(o){return Be(o,r.codec())}r.encode=t;function n(o,i){return Le(o,r.codec(),i)}r.decode=n;function s(o,i){return Re(o,r.codec(),i)}r.stream=s})(Pt||(Pt={}));var F;(function(r){r.UNUSED="UNUSED",r.OK="OK",r.RESERVATION_REFUSED="RESERVATION_REFUSED",r.RESOURCE_LIMIT_EXCEEDED="RESOURCE_LIMIT_EXCEEDED",r.PERMISSION_DENIED="PERMISSION_DENIED",r.CONNECTION_FAILED="CONNECTION_FAILED",r.NO_RESERVATION="NO_RESERVATION",r.MALFORMED_MESSAGE="MALFORMED_MESSAGE",r.UNEXPECTED_MESSAGE="UNEXPECTED_MESSAGE"})(F||(F={}));var Pa;(function(r){r[r.UNUSED=0]="UNUSED",r[r.OK=100]="OK",r[r.RESERVATION_REFUSED=200]="RESERVATION_REFUSED",r[r.RESOURCE_LIMIT_EXCEEDED=201]="RESOURCE_LIMIT_EXCEEDED",r[r.PERMISSION_DENIED=202]="PERMISSION_DENIED",r[r.CONNECTION_FAILED=203]="CONNECTION_FAILED",r[r.NO_RESERVATION=204]="NO_RESERVATION",r[r.MALFORMED_MESSAGE=400]="MALFORMED_MESSAGE",r[r.UNEXPECTED_MESSAGE=401]="UNEXPECTED_MESSAGE"})(Pa||(Pa={}));(function(r){r.codec=()=>Gt(Pa)})(F||(F={}));var or;(function(r){let e;r.codec=()=>(e==null&&(e=Oe((o,i,a={})=>{a.lengthDelimited!==!1&&i.fork(),o.relay!=null&&o.relay.byteLength>0&&(i.uint32(10),i.bytes(o.relay)),o.peer!=null&&o.peer.byteLength>0&&(i.uint32(18),i.bytes(o.peer)),o.expiration!=null&&o.expiration!==0n&&(i.uint32(24),i.uint64(o.expiration)),a.lengthDelimited!==!1&&i.ldelim()},(o,i,a={})=>{let c={relay:J(0),peer:J(0),expiration:0n},u=i==null?o.len:o.pos+i;for(;o.pos<u;){let l=o.uint32();switch(l>>>3){case 1:{c.relay=o.bytes();break}case 2:{c.peer=o.bytes();break}case 3:{c.expiration=o.uint64();break}default:{o.skipType(l&7);break}}}return c},function*(o,i,a,c={}){let u=i==null?o.len:o.pos+i;for(;o.pos<u;){let l=o.uint32();switch(l>>>3){case 1:{yield{field:`${a}.relay`,value:o.bytes()};break}case 2:{yield{field:`${a}.peer`,value:o.bytes()};break}case 3:{yield{field:`${a}.expiration`,value:o.uint64()};break}default:{o.skipType(l&7);break}}}})),e);function t(o){return Be(o,r.codec())}r.encode=t;function n(o,i){return Le(o,r.codec(),i)}r.decode=n;function s(o,i){return Re(o,r.codec(),i)}r.stream=s})(or||(or={}));var vn;(function(r){let e;r.codec=()=>(e==null&&(e=Oe((o,i,a={})=>{a.lengthDelimited!==!1&&i.fork(),o.publicKey!=null&&o.publicKey.byteLength>0&&(i.uint32(10),i.bytes(o.publicKey)),o.payloadType!=null&&o.payloadType.byteLength>0&&(i.uint32(18),i.bytes(o.payloadType)),o.payload!=null&&(i.uint32(26),or.codec().encode(o.payload,i)),o.signature!=null&&o.signature.byteLength>0&&(i.uint32(42),i.bytes(o.signature)),a.lengthDelimited!==!1&&i.ldelim()},(o,i,a={})=>{let c={publicKey:J(0),payloadType:J(0),signature:J(0)},u=i==null?o.len:o.pos+i;for(;o.pos<u;){let l=o.uint32();switch(l>>>3){case 1:{c.publicKey=o.bytes();break}case 2:{c.payloadType=o.bytes();break}case 3:{c.payload=or.codec().decode(o,o.uint32(),{limits:a.limits?.payload});break}case 5:{c.signature=o.bytes();break}default:{o.skipType(l&7);break}}}return c},function*(o,i,a,c={}){let u=i==null?o.len:o.pos+i;for(;o.pos<u;){let l=o.uint32();switch(l>>>3){case 1:{yield{field:`${a}.publicKey`,value:o.bytes()};break}case 2:{yield{field:`${a}.payloadType`,value:o.bytes()};break}case 3:{yield*or.codec().stream(o,o.uint32(),`${a}.payload`,{limits:c.limits?.payload});break}case 5:{yield{field:`${a}.signature`,value:o.bytes()};break}default:{o.skipType(l&7);break}}}})),e);function t(o){return Be(o,r.codec())}r.encode=t;function n(o,i){return Le(o,r.codec(),i)}r.decode=n;function s(o,i){return Re(o,r.codec(),i)}r.stream=s})(vn||(vn={}));var Vo=class extends Error{constructor(e="Transfer limit error"){super(e),this.name="TransferLimitError"}},Ho=class extends Error{constructor(e="Duration limit error"){super(e),this.name="DurationLimitError"}},_n=class extends Error{static name="HadEnoughRelaysError";name="HadEnoughRelaysError"},$o=class extends Error{static name="DoubleRelayError";name="DoubleRelayError"},Wo=class extends Error{static name="RelayQueueFullError";name="RelayQueueFullError"};function Fl(r,e,t){let n=e.remaining,s=o=>{let i=BigInt(o.data.byteLength);e.remaining-=i,e.remaining<0&&r.abort(new Vo(`data limit of ${n} bytes exceeded`))};r.addEventListener("message",s)}function Kl(r,e,t,n,s){function o(l){r.abort(l),e.abort(l)}let i=[t,n.signal];if(n.limit?.duration!=null){s.log("limiting relayed connection duration to %dms",n.limit.duration);let l=AbortSignal.timeout(n.limit.duration);i.push(l)}let a=Ko(i);let c;n.limit?.data!=null&&(c={remaining:n.limit.data});let u=()=>{let l;t.aborted?l=t.reason:l=new Ho(`duration limit of ${n.limit?.duration} ms exceeded`),o(l)};a.addEventListener("abort",u,{once:!0}),c!=null&&(Fl(e,c,s),Fl(r,c,s)),Dl(r,e,r).catch(l=>{o(l)}).finally(()=>{a.clear()})}function Na(r){let e=r*BigInt(1e3),t=new Date().getTime();return Number(e-BigInt(t))}var An=class{expires;bytes;constructor(e){e?.duration!=null&&e?.duration!==0&&(this.expires=Date.now()+e.duration*1e3),this.bytes=e?.data,this.bytes===0n&&(this.bytes=void 0),this.onData=this.onData.bind(this)}onData(e){this.bytes!=null&&(this.bytes-=BigInt(e.byteLength),this.bytes<0n&&(this.bytes=0n))}getLimits(){if(this.expires==null&&this.bytes==null)return;let e={};if(this.bytes!=null){let t=this;Object.defineProperty(e,"bytes",{get(){return t.bytes}})}if(this.expires!=null){let t=this;Object.defineProperty(e,"seconds",{get(){return Math.round(((t.expires??0)-Date.now())/1e3)}})}return e}},jo=Q($(El.matchers[0],X(290))),Go=Q(X(290));function Yo(r,e){let t={[Symbol.iterator]:()=>t,next:()=>{let n=r.next(),s=n.value;return n.done===!0||s==null?{done:!0,value:void 0}:{done:!1,value:e(s)}}};return t}var Nt=class{map;constructor(e){if(this.map=new Map,e!=null)for(let[t,n]of e.entries())this.map.set(t.toString(),{key:t,value:n})}[Symbol.iterator](){return this.entries()}clear(){this.map.clear()}delete(e){return this.map.delete(e.toString())}entries(){return Yo(this.map.entries(),e=>[e[1].key,e[1].value])}forEach(e){this.map.forEach((t,n)=>{e(t.value,t.key,this)})}get(e){return this.map.get(e.toString())?.value}has(e){return this.map.has(e.toString())}set(e,t){this.map.set(e.toString(),{key:e,value:t})}keys(){return Yo(this.map.values(),e=>e.key)}values(){return Yo(this.map.values(),e=>e.value)}get size(){return this.map.size}};var Zo=class{filter;constructor(e,t){this.filter=Pr(e,t)}has(e){return this.filter.has(e.toMultihash().bytes)}add(e){this.filter.add(e.toMultihash().bytes)}remove(e){this.filter.remove?.(e.toMultihash().bytes)}};function Ua(r,e=.001){return new Zo(r,e)}var ka=class extends Nt{metric;constructor(e){super();let{name:t,metrics:n}=e;this.metric=n.registerMetric(t),this.updateComponentMetric()}set(e,t){return super.set(e,t),this.updateComponentMetric(),this}delete(e){let t=super.delete(e);return this.updateComponentMetric(),t}clear(){super.clear(),this.updateComponentMetric()}updateComponentMetric(){this.metric.update(this.size)}};function Ma(r){let{name:e,metrics:t}=r,n;return t!=null?n=new ka({name:e,metrics:t}):n=new Nt,n}var Fa=class extends Error{type;code;constructor(e,t,n){super(e??"The operation was aborted"),this.type="aborted",this.name=n??"AbortError",this.code=t??"ABORT_ERR"}};function ql(r,e){let t=new Fa(e?.errorMessage,e?.errorCode,e?.errorName),n=new AbortController,s=()=>{n.abort(t)},o=AbortSignal.timeout(r);o.addEventListener("abort",s);let i=n.signal;return i.reset=a=>{o?.removeEventListener("abort",s),o=AbortSignal.timeout(a??r),o.addEventListener("abort",()=>{n.abort(t)})},i.clear=()=>{o?.removeEventListener("abort",s),o=void 0},i}var Xo=class{reservations;maxReservations;applyDefaultLimit;reservationTtl;defaultDurationLimit;defaultDataLimit;log;constructor(e,t={}){this.log=e.logger.forComponent("libp2p:circuit-relay:server:reservation-store"),this.maxReservations=t.maxReservations??Ll,this.applyDefaultLimit=t.applyDefaultLimit!==!1,this.reservationTtl=t.reservationTtl??Bl,this.defaultDurationLimit=t.defaultDurationLimit??Pl,this.defaultDataLimit=t.defaultDataLimit??Nl,this.reservations=Ma({metrics:e.metrics,name:"libp2p_circuit_relay_server_reservations_total"})}reserve(e,t,n){let s=this.reservations.get(e);if(this.reservations.size>=this.maxReservations&&s==null)return{status:F.RESERVATION_REFUSED};let o=new Date(Date.now()+this.reservationTtl),i;return this.applyDefaultLimit&&(i=n??{data:this.defaultDataLimit,duration:this.defaultDurationLimit}),s!=null?(this.log("refreshing reservation for client %p",e),s.signal.reset(this.reservationTtl)):(this.log("creating new reservation for client %p",e),s={addr:t,expiry:o,limit:i,signal:ql(this.reservationTtl)}),this.reservations.set(e,s),s.signal.addEventListener("abort",()=>{this.reservations.delete(e)}),{status:F.OK,expire:Math.round(o.getTime()/1e3)}}removeReservation(e){this.reservations.delete(e)}get(e){return this.reservations.get(e)}clear(){this.reservations.clear()}};var Qo=class r{domain="libp2p-relay-rsvp";codec=new Uint8Array([3,2]);relay;peer;expiration;constructor({relay:e,peer:t,expiration:n}){this.relay=e,this.peer=t,this.expiration=n}marshal(){return or.encode({relay:this.relay.toMultihash().bytes,peer:this.peer.toMultihash().bytes,expiration:BigInt(this.expiration)})}equals(e){return!(!(e instanceof r)||!this.peer.equals(e.peer)||!this.relay.equals(e.relay)||this.expiration!==e.expiration)}};var Vp={maxOutboundStopStreams:En},Jo=class extends Ie{components;reservationStore;started;hopTimeout;shutdownController;maxInboundHopStreams;maxOutboundHopStreams;maxOutboundStopStreams;log;constructor(e,t={}){super(),this.log=e.logger.forComponent("libp2p:circuit-relay:server"),this.components=e,this.started=!1,this.hopTimeout=t?.hopTimeout??Ul,this.maxInboundHopStreams=t.maxInboundHopStreams,this.maxOutboundHopStreams=t.maxOutboundHopStreams,this.maxOutboundStopStreams=t.maxOutboundStopStreams??Vp.maxOutboundStopStreams,this.reservationStore=new Xo(e,t.reservations),this.shutdownController=new AbortController,this.shutdownController.signal,this.onHop=this.onHop.bind(this)}[Symbol.toStringTag]="@libp2p/circuit-relay-v2-server";isStarted(){return this.started}async start(){this.started||(await this.components.registrar.handle(Fe,this.onHop,{maxInboundStreams:this.maxInboundHopStreams,maxOutboundStreams:this.maxOutboundHopStreams,runOnLimitedConnection:!0}),this.started=!0)}async stop(){this.reservationStore.clear(),this.shutdownController.abort(),await this.components.registrar.unhandle(Fe),this.started=!1}async onHop(e,t){this.log("received circuit v2 hop protocol stream from %p",t.remotePeer);let n=AbortSignal.timeout(this.hopTimeout);let s={signal:n},o=Rt(e);try{let i=await o.pb(Y).read(s);if(i?.type==null)throw new Error("request was invalid, could not read from stream");this.log("received",i.type),await this.handleHopProtocol({connection:t,stream:o,request:i},s)}catch(i){this.log.error("error while handling hop - %e",i),await o.pb(Y).write({type:Y.Type.STATUS,status:F.MALFORMED_MESSAGE},s),e.abort(i)}}async handleHopProtocol({stream:e,request:t,connection:n},s){switch(this.log("received hop message"),t.type){case Y.Type.RESERVE:await this.handleReserve({stream:e,request:t,connection:n},s);break;case Y.Type.CONNECT:await this.handleConnect({stream:e,request:t,connection:n},s);break;default:this.log.error("invalid hop request type %s via peer %p",t.type,n.remotePeer),await e.pb(Y).write({type:Y.Type.STATUS,status:F.UNEXPECTED_MESSAGE})}}async handleReserve({stream:e,connection:t},n){let s=e.pb(Y);if(this.log("hop reserve request from %p",t.remotePeer),tr.exactMatch(t.remoteAddr)){this.log.error("relay reservation over circuit connection denied for peer: %p",t.remotePeer),await s.write({type:Y.Type.STATUS,status:F.PERMISSION_DENIED},n);return}if(await this.components.connectionGater.denyInboundRelayReservation?.(t.remotePeer)===!0){this.log.error("reservation for %p denied by connection gater",t.remotePeer),await s.write({type:Y.Type.STATUS,status:F.PERMISSION_DENIED},n);return}let o=this.reservationStore.reserve(t.remotePeer,t.remoteAddr);try{if(o.status!==F.OK){await s.write({type:Y.Type.STATUS,status:o.status},n);return}if(o.expire!=null){let i=o.expire*1e3-Date.now();await this.components.peerStore.merge(t.remotePeer,{tags:{[Oa]:{value:1,ttl:i}}},n)}await s.write({type:Y.Type.STATUS,status:F.OK,reservation:await this.makeReservation(t.remotePeer,BigInt(o.expire??0)),limit:this.reservationStore.get(t.remotePeer)?.limit},n),this.log("sent confirmation response to %s",t.remotePeer),await s.unwrap().unwrap().close(n)}catch(i){this.log.error("failed to send confirmation response to %p - %e",t.remotePeer,i),this.reservationStore.removeReservation(t.remotePeer);try{await this.components.peerStore.merge(t.remotePeer,{tags:{[Oa]:void 0}},n)}catch(a){this.log.error("failed to untag relay source peer %p - %e",t.remotePeer,a)}}}async makeReservation(e,t){let n=[];for(let o of this.components.addressManager.getAddresses())o.toString().includes("/p2p-circuit")||n.push(o.bytes);let s=await mn.seal(new Qo({peer:e,relay:this.components.peerId,expiration:t}),this.components.privateKey);return{addrs:n,expire:t,voucher:{publicKey:Qe(s.publicKey),payloadType:s.payloadType,payload:{peer:e.toMultihash().bytes,relay:this.components.peerId.toMultihash().bytes,expiration:t},signature:s.signature}}}async handleConnect({stream:e,request:t,connection:n},s){let o=e.pb(Y);if(tr.matches(n.remoteAddr)){this.log.error("relay reservation over circuit connection denied for peer: %p",n.remotePeer),await o.write({type:Y.Type.STATUS,status:F.PERMISSION_DENIED},s);return}this.log("hop connect request from %p",n.remotePeer);let i;try{if(t.peer==null)throw this.log.error("no peer info in hop connect request"),new Error("no peer info in request");t.peer.addrs.forEach(Ue),i=Cr(Ze(t.peer.id))}catch(f){this.log.error("invalid hop connect request via peer %p - %e",n.remotePeer,f),await o.write({type:Y.Type.STATUS,status:F.MALFORMED_MESSAGE},s);return}let a=this.reservationStore.get(i);if(a==null){this.log.error("hop connect denied for destination peer %p not having a reservation for %p with status %s",i,n.remotePeer,F.NO_RESERVATION),await o.write({type:Y.Type.STATUS,status:F.NO_RESERVATION},s);return}if(await this.components.connectionGater.denyOutboundRelayedConnection?.(n.remotePeer,i)===!0){this.log.error("hop connect for %p to %p denied by connection gater",n.remotePeer,i),await o.write({type:Y.Type.STATUS,status:F.PERMISSION_DENIED},s);return}let c=this.components.connectionManager.getConnections(i);if(c.length===0){this.log("hop connect denied for destination peer %p not having a connection for %p as there is no destination connection",i,n.remotePeer),await o.write({type:Y.Type.STATUS,status:F.NO_RESERVATION},s);return}let u=c[0],l=await this.stopHop({connection:u,request:{type:ke.Type.CONNECT,peer:{id:n.remotePeer.toMultihash().bytes,addrs:[]},limit:a?.limit}},s);if(l==null){this.log.error("failed to open stream to destination peer %p",u?.remotePeer),await o.write({type:Y.Type.STATUS,status:F.CONNECTION_FAILED},s);return}await o.write({type:Y.Type.STATUS,status:F.OK,limit:a?.limit},s),this.log("connection from %p to %p established - merging streams",n.remotePeer,i),Kl(e.unwrap(),l,this.shutdownController.signal,a,{log:this.log})}async stopHop({connection:e,request:t},n){this.log("starting circuit relay v2 stop request to %s",e.remotePeer);let s=await e.newStream(nr,{maxOutboundStreams:this.maxOutboundStopStreams,runOnLimitedConnection:!0,...n}),o=Rt(s),i=o.pb(ke);await i.write(t,n);let a;try{a=await i.read(n)}catch(c){this.log.error("error parsing stop message response from %p - %e",e.remotePeer,c)}if(a==null){this.log.error("could not read response from %p",e.remotePeer),await s.close(n);return}if(a.status===F.OK)return this.log("stop request to %p was successful",e.remotePeer),o.unwrap();this.log("stop request failed with code %d",a.status),await s.close(n)}get reservations(){return this.reservationStore.reservations}};var Ut=class extends Event{type;detail;constructor(e,t){super(e),this.type=e,this.detail=t}};var es=class extends Ie{components;started;running;topologyId;log;discoveryController;filter;queue;constructor(e,t={}){super(),this.log=e.logger.forComponent("libp2p:circuit-relay:discover-relays"),this.components=e,this.started=!1,this.running=!1,this.filter=t.filter,this.discoveryController=new AbortController,this.discoveryController.signal,this.dialPeer=this.dialPeer.bind(this),this.onPeer=this.onPeer.bind(this)}isStarted(){return this.started}async start(){this.topologyId=await this.components.registrar.register(Fe,{filter:this.filter,onConnect:e=>{this.log.trace("discovered relay %p queue (length: %d, active %d)",e,this.queue?.size,this.queue?.running),this.safeDispatchEvent("relay:discover",{detail:e})}}),this.started=!0}stop(){this.topologyId!=null&&this.components.registrar.unregister(this.topologyId),this.running&&this.stopDiscovery(),this.started=!1}startDiscovery(){this.running||(this.log("start discovery"),this.running=!0,this.discoveryController=new AbortController,this.discoveryController.signal,this.components.events.addEventListener("peer:discovery",this.onPeer),Promise.resolve().then(async()=>{this.log("searching peer store for relays");let e=await this.components.peerStore.all({filters:[n=>n.protocols.includes(Fe)],orders:[()=>Math.random()<.5?1:-1,(n,s)=>{let o=zl(n),i=zl(s);return o>i?-1:i>o?1:0}]});for(let n of e)this.log.trace("found relay peer %p in peer store",n.id),this.safeDispatchEvent("relay:discover",{detail:n.id});this.log("found %d relay peers in peer store",e.length);let t=this.queue=new kr({concurrency:5});this.log("start random walk");for await(let n of this.components.randomWalk.walk({signal:this.discoveryController.signal})){if(this.log.trace("found random peer %p",n.id),t.has(n.id)){this.log.trace("random peer %p was already in queue",n.id);continue}if(this.components.connectionManager.getConnections(n.id)?.length>0){this.log.trace("random peer %p was already connected",n.id);continue}if(!await this.components.connectionManager.isDialable(n.multiaddrs)){this.log.trace("random peer %p was not dialable",n.id,n.multiaddrs.map(s=>s.toString()));continue}t.queued>10&&(this.log.trace("wait for space in queue for %p",n.id),await t.onSizeLessThan(10,{signal:this.discoveryController.signal})),this.log("adding random peer %p to dial queue (length: %d, active %d)",n.id,t.size,t.running),t.add(this.dialPeer,{peerId:n.id,signal:this.discoveryController.signal}).catch(s=>{this.log.error("error opening connection to random peer %p - %e",n.id,s)})}this.log("stop random walk"),await t.onIdle()}).catch(e=>{this.discoveryController.signal.aborted||this.log.error("failed when finding relays on the network - %e",e)}))}stopDiscovery(){this.log("stop discovery"),this.running=!1,this.discoveryController?.abort(),this.queue?.clear(),this.components.events.removeEventListener("peer:discovery",this.onPeer)}onPeer(e){this.log.trace("maybe dialing discovered peer %p",e.detail.id),this.maybeDialPeer(e).catch(t=>{this.log.trace("error dialing discovered peer %p - %e",e.detail.id,t)})}async maybeDialPeer(e){if(this.queue==null)return;let t=e.detail.id,n=e.detail.multiaddrs;if(this.queue.has(t)){this.log.trace("random peer %p was already in queue",t);return}if(this.components.connectionManager.getConnections(t)?.length>0){this.log.trace("random peer %p was already connected",t);return}if(!await this.components.connectionManager.isDialable(n)){this.log.trace("random peer %p was not dialable",t);return}this.queue?.add(this.dialPeer,{peerId:e.detail.id,signal:this.discoveryController.signal}).catch(s=>{this.log.error("error opening connection to discovered peer %p - %e",e.detail.id,s)})}async dialPeer({peerId:e,signal:t}){let n=Ko([AbortSignal.timeout(5e3),t]);try{await this.components.connectionManager.openConnection(e,{signal:n})}finally{n.clear()}}};function zl(r){let e=r.metadata.get("last-dial-success");return e==null?0:new Date(V(e)).getTime()}var qa=class extends Ie{connectionManager;addressManager;reservationStore;listeningAddrs;log;listenTimeout;reservationId;relay;constructor(e,t={}){super(),this.log=e.logger.forComponent("libp2p:circuit-relay:transport:listener"),this.connectionManager=e.connectionManager,this.addressManager=e.addressManager,this.reservationStore=e.reservationStore,this.listeningAddrs=[],this.listenTimeout=t.listenTimeout??zo,this.reservationStore.addEventListener("relay:removed",this._onRemoveRelayPeer),this.reservationStore.addEventListener("relay:created-reservation",this._onAddRelayPeer)}_onRemoveRelayPeer=e=>{this.log("relay removed %p our relay %p",e.detail.relay,this.relay,this.relay?.equals(e.detail.relay)),this.relay?.equals(e.detail.relay)===!0&&(this.log("relay peer removed %p",e.detail.relay),this.listeningAddrs.forEach(t=>{this.addressManager.removeObservedAddr(t)}),this.listeningAddrs=[],this.safeDispatchEvent("listening"))};_onAddRelayPeer=e=>{let{details:t}=e.detail;t.type!=="configured"&&t.id===this.reservationId&&this.addedRelay(e.detail)};async listen(e){if(Go.exactMatch(e))this.log("searching for circuit relay servers"),this.reservationId=this.reservationStore.reserveRelay();else if(jo.exactMatch(e)){this.log("listen on specific relay server %a",e);let t=AbortSignal.timeout(this.listenTimeout);let n=e.decapsulate("/p2p-circuit"),s=await this.connectionManager.openConnection(n,{signal:t});if(!this.reservationStore.hasReservation(s.remotePeer)){this.log("making reservation on peer %p",s.remotePeer);let o=await this.reservationStore.addRelay(s.remotePeer,"configured");this.addedRelay(o)}}else throw new kt(`Could not listen on p2p-circuit address "${e}"`)}getAddrs(){return[...this.listeningAddrs.values()].flat()}updateAnnounceAddrs(){}async close(){this.reservationStore.cancelReservations(),this.listeningAddrs=[],this.reservationStore.removeEventListener("relay:removed",this._onRemoveRelayPeer),queueMicrotask(()=>{this.safeDispatchEvent("close")})}addedRelay(e){this.log("relay peer added %p",e.relay),this.relay=e.relay,this.listeningAddrs=e.details.reservation.addrs.map(t=>Ue(t).encapsulate("/p2p-circuit")),this.listeningAddrs.forEach(t=>{this.addressManager.confirmObservedAddr(t,{type:"transport"})}),queueMicrotask(()=>{this.safeDispatchEvent("listening")})}};function Vl(r){return new qa(r)}var Hl="useandom-26T198340PX75pxJACKVERYMINDBUSHWOLF_GQZbfghjklqvwyzrict";var $l=(r=21)=>{let e="",t=crypto.getRandomValues(new Uint8Array(r|=0));for(;r--;)e+=Hl[t[r]&63];return e};var Hp=60*1e3*10,$p=60*1e3*5,Wp=30*1e3,ts=class extends Ie{peerId;connectionManager;peerStore;events;reserveQueue;reservations;pendingReservations;maxReservationQueueLength;reservationCompletionTimeout;started;log;relayFilter;constructor(e,t){super(),this.log=e.logger.forComponent("libp2p:circuit-relay:transport:reservation-store"),this.peerId=e.peerId,this.connectionManager=e.connectionManager,this.peerStore=e.peerStore,this.events=e.events,this.reservations=new Nt,this.pendingReservations=[],this.maxReservationQueueLength=t?.maxReservationQueueLength??Ol,this.reservationCompletionTimeout=t?.reservationCompletionTimeout??zo,this.started=!1,this.relayFilter=Pr(100),this.reserveQueue=new kr({concurrency:t?.reservationConcurrency??Rl,metricName:"libp2p_relay_reservation_queue",metrics:e.metrics}),this.events.addEventListener("connection:close",n=>{[...this.reservations.values()].find(o=>o.connection===n.detail.id)!=null&&this.#t(n.detail.remotePeer).catch(o=>{this.log("could not remove relay %p - %e",n.detail,o)})})}isStarted(){return this.started}start(){this.started=!0}afterStart(){Promise.resolve().then(async()=>{let e=await this.peerStore.all({filters:[t=>t.tags.has(xn)]});this.log("removing tag from %d old relays",e.length),await Promise.all(e.map(async t=>{await this.peerStore.merge(t.id,{tags:{[xn]:void 0}})})),this.log("redialing %d old relays",e.length),await Promise.all(e.map(async t=>this.addRelay(t.id,"discovered"))),this.#r()}).catch(e=>{this.log.error("failed to clean up and redial old relays during afterStart - %e",e)})}stop(){this.reserveQueue.clear(),this.reservations.forEach(({timeout:e})=>{clearTimeout(e)}),this.reservations.clear(),this.started=!1}reserveRelay(){let e=$l();return this.pendingReservations.push(e),this.#r(),e}async addRelay(e,t){if(this.peerId.equals(e))throw this.log.trace("not trying to use self as relay"),new kt("Cannot use self as relay");if(this.reserveQueue.size>this.maxReservationQueueLength)throw new Wo("The reservation queue is full");let n=this.reserveQueue.find(e);if(n!=null)return this.log.trace("potential relay peer %p is already in the reservation queue",e),n.join();if(this.relayFilter.has(e.toMultihash().bytes))throw new kt("The relay was previously invalid");return this.log.trace("try to reserve relay slot with %p",e),this.reserveQueue.add(async()=>{let s=Date.now();try{let o=this.reservations.get(e);if(o!=null){let y=this.connectionManager.getConnections(e),x=!1;if(y.length===0&&this.log("already have relay reservation with %p but we are no longer connected",e),y.map(h=>h.id).includes(o.connection)&&(this.log("already have relay reservation with %p and the original connection is still open",e),x=!0),x&&Na(o.reservation.expire)>Hp)return this.log("already have relay reservation with %p but we are still connected and it does not expire soon",e),{relay:e,details:o};await this.#t(e)}if(t==="discovered"&&this.pendingReservations.length===0)throw new _n("Not making reservation on discovered relay because we do not need any more relays");let i=AbortSignal.timeout(this.reservationCompletionTimeout);let a=await this.connectionManager.openConnection(e,{signal:i});if(tr.matches(a.remoteAddr))throw new $o("not creating reservation over relayed connection");let c=await this.#e(a,{signal:i}),u=Na(c.expire);this.log("created reservation on relay peer %p, expiry date is %s",e,new Date(Date.now()+u).toString());let l=Math.min(Math.max(u-$p,Wp),Math.pow(2,31)-1),f=setTimeout(()=>{this.log("refresh reservation to relay %p",e),this.addRelay(e,t).catch(async y=>{this.log.error("could not refresh reservation to relay %p - %e",e,y),await this.#t(e)}).catch(y=>{this.log.error("could not remove expired reservation to relay %p - %e",e,y)})},l),p;if(t==="discovered"){let y=this.pendingReservations.pop();if(y==null)throw new _n("Made reservation on relay but did not need any more discovered relays");p={timeout:f,reservation:c,type:t,connection:a.id,id:y}}else p={timeout:f,reservation:c,type:t,connection:a.id};this.reservations.set(e,p),await this.peerStore.merge(e,{tags:{[xn]:{value:1,ttl:u}}}),this.#r();let d={relay:e,details:p};return this.safeDispatchEvent("relay:created-reservation",{detail:d}),d}catch(o){throw t==="discovered"&&o.name==="HadEnoughRelaysError"||this.log.error("could not reserve slot on %p after %dms - %e",e,Date.now()-s,o),(o.name==="DialError"||o.name==="UnsupportedProtocolError")&&this.relayFilter.add(e.toMultihash().bytes),this.#t(e).catch(i=>{this.log.error("could not remove reservation on %p after reserving slot failed - %e",e,i)}),o}},{peerId:e})}hasReservation(e){return this.reservations.has(e)}getReservation(e){return this.reservations.get(e)?.reservation}reservationCount(e){return e==null?this.reservations.size:[...this.reservations.values()].reduce((t,n)=>(n.type===e&&t++,t),0)}cancelReservations(){[...this.reservations.values()].forEach(e=>{clearTimeout(e.timeout)}),this.reservations.clear()}async#e(e,t){t.signal?.throwIfAborted(),this.log("requesting reservation from %p",e.remotePeer);let n=await e.newStream(Fe,t),o=Rt(n).pb(Y);this.log.trace("send RESERVE to %p",e.remotePeer),await o.write({type:Y.Type.RESERVE},t);let i;try{this.log.trace("reading response from %p",e.remotePeer),i=await o.read(t)}catch(c){throw n.abort(c),c}finally{n.status!=="closed"&&await n.close(t)}if(this.log.trace("read response %s",i.status),i.status===F.OK&&i.reservation!=null){let c=new Set;c.add(e.remoteAddr.toString());for(let u of i.reservation.addrs){let l=Ue(u);l.getComponents().find(f=>f.code===421)==null&&(l=l.encapsulate(`/p2p/${e.remotePeer}`)),l=Ue(l.toString().replace(`/p2p/${e.remotePeer}/p2p/${e.remotePeer}`,`/p2p/${e.remotePeer}`)),c.add(l.toString())}return i.reservation.addrs=[...c].map(u=>Ue(u).bytes),i.reservation}let a=`reservation failed with status ${i.status??"undefined"}`;throw this.log.error(a),new Error(a)}async#t(e){let t=this.reservations.get(e);t!=null&&(this.log("removing relay reservation with %p from local store",e),clearTimeout(t.timeout),this.reservations.delete(e),t.type==="discovered"&&this.pendingReservations.push(t.id),await this.peerStore.merge(e,{tags:{[xn]:void 0}}),this.safeDispatchEvent("relay:removed",{detail:{relay:e,details:t}}),this.#r())}#r(){if(this.pendingReservations.length===0){this.log.trace("have discovered enough relays"),this.reserveQueue.clear(),this.safeDispatchEvent("relay:found-enough-relays");return}this.relayFilter=Pr(100),this.log("not discovered enough relays %d/%d",this.reservations.size,this.pendingReservations.length),this.safeDispatchEvent("relay:not-enough-relays")}};var za=class extends Fo{stream;init;constructor(e){super({...e,direction:e.stream.direction}),this.init=e,this.stream=e.stream,this.stream.addEventListener("close",t=>{this.onTransportClosed(t.error)}),this.stream.addEventListener("remoteCloseWrite",t=>{this.onRemoteCloseWrite(),this.close().catch(n=>{this.abort(n)})}),this.stream.addEventListener("message",t=>{e.onDataRead?.(t.data),this.onData(t.data)}),this.stream.addEventListener("drain",()=>{this.safeDispatchEvent("drain")})}sendData(e){return this.init.onDataWrite?.(e),{sentBytes:e.byteLength,canSendMore:this.stream.send(e)}}async sendClose(e){await this.stream.close(e)}sendReset(){this.stream.abort(new Error("An error occurred"))}sendPause(){this.stream.pause()}sendResume(){this.stream.resume()}};function Va(r){return new za(r)}var jp=r=>{if(r.peer==null)return!1;try{r.peer.addrs.forEach(Ue)}catch{return!1}return!0},Wl={maxInboundStopStreams:En,maxOutboundStopStreams:En,stopTimeout:3e4},rs=class{components;discovery;reservationStore;maxInboundStopStreams;maxOutboundStopStreams;started;log;shutdownController;constructor(e,t={}){this.components=e,this.log=e.logger.forComponent("libp2p:circuit-relay:transport"),this.maxInboundStopStreams=t.maxInboundStopStreams??Wl.maxInboundStopStreams,this.maxOutboundStopStreams=t.maxOutboundStopStreams??Wl.maxOutboundStopStreams,this.shutdownController=new AbortController,this.discovery=new es(e,{filter:t.discoveryFilter??Ua(kl,Ml)}),this.discovery.addEventListener("relay:discover",n=>{this.reservationStore.addRelay(n.detail,"discovered").catch(s=>{s.name!=="HadEnoughRelaysError"&&s.name!=="RelayQueueFullError"&&this.log.error("could not add discovered relay %p - %e",n.detail,s)})}),this.reservationStore=new ts(e,t),this.reservationStore.addEventListener("relay:not-enough-relays",()=>{this.discovery?.startDiscovery()}),this.reservationStore.addEventListener("relay:found-enough-relays",()=>{this.discovery?.stopDiscovery()}),this.started=!1,this.onStop=this.onStop.bind(this)}[Symbol.toStringTag]="@libp2p/circuit-relay-v2-transport";[Qa]=["@libp2p/transport","@libp2p/circuit-relay-v2-transport"];get[Ja](){return this.discovery!=null?["@libp2p/identify"]:[]}[Xa]=!0;isStarted(){return this.started}async start(){this.shutdownController=new AbortController,this.shutdownController.signal,await this.components.registrar.handle(nr,this.onStop,{maxInboundStreams:this.maxInboundStopStreams,maxOutboundStreams:this.maxOutboundStopStreams,runOnLimitedConnection:!0}),await Ga(this.discovery,this.reservationStore),this.started=!0}async stop(){this.shutdownController.abort(),await Ya(this.discovery,this.reservationStore),await this.components.registrar.unhandle(nr),this.started=!1}async dial(e,t){let n=e.toString().split("/p2p-circuit"),s=Ue(n[0]),o=Ue(n[n.length-1]),i=s.getComponents().find(d=>d.code===421)?.value,a=o.getComponents().find(d=>d.code===421)?.value;if(i==null||a==null){let d=`ircuit relay dial to ${e.toString()} failed as address did not have both relay and destination PeerIDs`;throw this.log.error(`c${d}`),new Bn(`C${d}`)}let c=Hi(i),u=Hi(a),f=this.components.connectionManager.getConnections(c)[0];f==null?(await this.components.peerStore.merge(c,{multiaddrs:[s]}),t.onProgress?.(new Ut("circuit-relay:open-connection")),f=await this.components.connectionManager.openConnection(c,t)):t.onProgress?.(new Ut("circuit-relay:reuse-connection"));let p;try{t.onProgress?.(new Ut("circuit-relay:open-hop-stream")),p=await f.newStream(Fe,t);let d=Rt(p).pb(Y);t.onProgress?.(new Ut("circuit-relay:write-connect-message")),await d.write({type:Y.Type.CONNECT,peer:{id:u.toMultihash().bytes,addrs:[Ue(o).bytes]}},t),t.onProgress?.(new Ut("circuit-relay:read-connect-response"));let y=await d.read(t);if(y.status!==F.OK)throw new Ln(`failed to connect via relay with status ${y?.status?.toString()??"undefined"}`);let x=new An(y.limit),h=Va({stream:d.unwrap().unwrap(),remoteAddr:e,localAddr:s.encapsulate(`/p2p-circuit/p2p/${this.components.peerId.toString()}`),onDataRead:x.onData,onDataWrite:x.onData,log:p.log.newScope("circuit-relay:connection")}),g=await this.components.upgrader.upgradeOutbound(h,{...t,limits:x.getLimits()});return g.log("outbound relayed connection established to %p with limits %o, over connection %s",g.remotePeer,y.limit??"none",f.id),g}catch(d){throw this.log.error("circuit relay dial to destination %p via relay %p failed - %e",u,c,d),p?.abort(d),d}}createListener(e){return Vl({peerId:this.components.peerId,connectionManager:this.components.connectionManager,addressManager:this.components.addressManager,reservationStore:this.reservationStore,logger:this.components.logger})}listenFilter(e){return e=Array.isArray(e)?e:[e],e.filter(t=>jo.exactMatch(t)||Go.exactMatch(t))}dialFilter(e){return e=Array.isArray(e)?e:[e],e.filter(t=>tr.exactMatch(t))}async onStop(e,t){let n=this.components.upgrader.createInboundAbortSignal(this.shutdownController.signal);try{if(!this.reservationStore.hasReservation(t.remotePeer))try{this.log("dialed via relay we did not have a reservation on, start listening on that relay address"),await this.components.transportManager.listen([t.remoteAddr.encapsulate("/p2p-circuit")])}catch(f){this.log.error("failed to listen on a relay peer we were dialed via but did not have a reservation on - %e",f)}let s=Rt(e).pb(ke),o=await s.read({signal:n});if(this.log("new circuit relay v2 stop stream from %p with type %s",t.remotePeer,o.type),o?.type===void 0){this.log.error("type was missing from circuit v2 stop protocol request from %s",t.remotePeer),await s.write({type:ke.Type.STATUS,status:F.MALFORMED_MESSAGE},{signal:n}),await e.close({signal:n});return}if(o.type!==ke.Type.CONNECT){this.log.error("invalid stop connect request via peer %p",t.remotePeer),await s.write({type:ke.Type.STATUS,status:F.UNEXPECTED_MESSAGE},{signal:n}),await e.close({signal:n});return}if(!jp(o)){this.log.error("invalid stop connect request via peer %p",t.remotePeer),await s.write({type:ke.Type.STATUS,status:F.MALFORMED_MESSAGE},{signal:n}),await e.close({signal:n});return}let i=Cr(Ze(o.peer.id));if(await this.components.connectionGater.denyInboundRelayedConnection?.(t.remotePeer,i)===!0){this.log.error("connection gater denied inbound relayed connection from %p",t.remotePeer),await s.write({type:ke.Type.STATUS,status:F.PERMISSION_DENIED},{signal:n}),await e.close({signal:n});return}this.log.trace("sending success response to %p",t.remotePeer),await s.write({type:ke.Type.STATUS,status:F.OK},{signal:n});let a=new An(o.limit),c=t.remoteAddr.encapsulate(`/p2p-circuit/p2p/${i.toString()}`),u=this.components.addressManager.getAddresses()[0],l=Va({stream:s.unwrap().unwrap(),remoteAddr:c,localAddr:u,onDataRead:a.onData,onDataWrite:a.onData,log:e.log.newScope("circuit-relay:connection")});await this.components.upgrader.upgradeInbound(l,{limits:a.getLimits(),signal:n}),l.log("inbound relayed connection established to %p with limits %o, over connection %s",i,o.limit??"none",t.id)}finally{n?.clear()}}};function Gp(r={}){return e=>new Jo(e,r)}function Yp(r={}){return e=>new rs(e,r)}return Xl(Zp);})();
|
|
3
3
|
/*! Bundled license information:
|
|
4
4
|
|
|
5
5
|
@noble/curves/utils.js:
|