@libp2p/circuit-relay-v2 4.2.0-2151144c3 → 4.2.0-811a29f8a
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 -4
- package/dist/index.min.js.map +4 -4
- package/package.json +9 -9
package/dist/index.min.js
CHANGED
|
@@ -1,10 +1,7 @@
|
|
|
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 Vo=Object.defineProperty;var Pl=Object.getOwnPropertyDescriptor;var Nl=Object.getOwnPropertyNames;var Ul=Object.prototype.hasOwnProperty;var ve=(r,e)=>{for(var t in e)Vo(r,t,{get:e[t],enumerable:!0})},kl=(r,e,t,n)=>{if(e&&typeof e=="object"||typeof e=="function")for(let s of Nl(e))!Ul.call(r,s)&&s!==t&&Vo(r,s,{get:()=>e[s],enumerable:!(n=Pl(e,s))||n.enumerable});return r};var Ml=r=>kl(Vo({},"__esModule",{value:!0}),r);var Bp={};ve(Bp,{RELAY_V2_HOP_CODEC:()=>ke,RELAY_V2_STOP_CODEC:()=>Qt,circuitRelayServer:()=>Cp,circuitRelayTransport:()=>Lp});function Kl(r){return typeof r?.handleEvent=="function"}function Hl(r){return(r!==!0&&r!==!1&&r?.once)??!1}var _e=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=Hl(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))}Kl(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 Qe=class extends Error{static name="AbortError";constructor(e="The operation was aborted"){super(e),this.name="AbortError"}};var ae=class extends Error{static name="InvalidParametersError";constructor(e="Invalid parameters"){super(e),this.name="InvalidParametersError"}},er=class extends Error{static name="InvalidPublicKeyError";constructor(e="Invalid public key"){super(e),this.name="InvalidPublicKeyError"}};var yn=class extends Error{static name="StreamResetError";constructor(e="The stream has been reset"){super(e),this.name="StreamResetError"}};var pt=class extends Error{static name="StreamStateError";constructor(e="The stream is in an invalid state"){super(e),this.name="StreamStateError"}},Lr=class extends Error{static name="StreamBufferError";constructor(e="The stream buffer was full"){super(e),this.name="StreamBufferError"}};var bn=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 xn=class extends Error{static name="InvalidMessageError";constructor(e="Invalid message"){super(e),this.name="InvalidMessageError"}};var wn=class extends Error{static name="DialError";constructor(e="Dial error"){super(e),this.name="DialError"}},Ot=class extends Error{static name="ListenError";constructor(e="Listen error"){super(e),this.name="ListenError"}};var tr=class extends Error{static name="UnsupportedKeyTypeError";constructor(e="Unsupported key type"){super(e),this.name="UnsupportedKeyTypeError"}};var En=class extends Event{data;constructor(e,t){super("message",t),this.data=e}},rr=class extends Event{error;local;constructor(e,t,n){super("close",n),this.error=t,this.local=e}},Sn=class extends rr{constructor(e,t){super(!0,e,t)}},vn=class extends rr{constructor(e,t){super(!1,e,t)}};var Fo=Symbol.for("@libp2p/peer-id");var Ca="keep-alive";function La(r){return r!=null&&typeof r.start=="function"&&typeof r.stop=="function"}async function Ba(...r){let e=[];for(let t of r)La(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 Ra(...r){let e=[];for(let t of r)La(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 Pa=Symbol.for("@libp2p/transport");var Oa;(function(r){r[r.FATAL_ALL=0]="FATAL_ALL",r[r.NO_FATAL=1]="NO_FATAL"})(Oa||(Oa={}));var Na=Symbol.for("@libp2p/service-capabilities"),Ua=Symbol.for("@libp2p/service-dependencies");var Yo={};ve(Yo,{base58btc:()=>te,base58flickr:()=>Wl});var f0=new Uint8Array(0);function ka(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 Je(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 Ma(r){return new TextEncoder().encode(r)}function Ka(r){return new TextDecoder().decode(r)}function ql(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),l=Math.log(a)/Math.log(256),u=Math.log(256)/Math.log(a);function f(h){if(h instanceof Uint8Array||(ArrayBuffer.isView(h)?h=new Uint8Array(h.buffer,h.byteOffset,h.byteLength):Array.isArray(h)&&(h=Uint8Array.from(h))),!(h instanceof Uint8Array))throw new TypeError("Expected Uint8Array");if(h.length===0)return"";for(var S=0,x=0,y=0,A=h.length;y!==A&&h[y]===0;)y++,S++;for(var w=(A-y)*u+1>>>0,T=new Uint8Array(w);y!==A;){for(var P=h[y],M=0,q=w-1;(P!==0||M<x)&&q!==-1;q--,M++)P+=256*T[q]>>>0,T[q]=P%a>>>0,P=P/a>>>0;if(P!==0)throw new Error("Non-zero carry");x=M,y++}for(var v=w-x;v!==w&&T[v]===0;)v++;for(var E=c.repeat(S);v<w;++v)E+=r.charAt(T[v]);return E}function d(h){if(typeof h!="string")throw new TypeError("Expected String");if(h.length===0)return new Uint8Array;var S=0;if(h[S]!==" "){for(var x=0,y=0;h[S]===c;)x++,S++;for(var A=(h.length-S)*l+1>>>0,w=new Uint8Array(A);h[S];){var T=t[h.charCodeAt(S)];if(T===255)return;for(var P=0,M=A-1;(T!==0||P<y)&&M!==-1;M--,P++)T+=a*w[M]>>>0,w[M]=T%256>>>0,T=T/256>>>0;if(T!==0)throw new Error("Non-zero carry");y=P,S++}if(h[S]!==" "){for(var q=A-y;q!==A&&w[q]===0;)q++;for(var v=new Uint8Array(x+(A-q)),E=x;q!==A;)v[E++]=w[q++];return v}}}function p(h){var S=d(h);if(S)return S;throw new Error(`Non-${e} character`)}return{encode:f,decodeUnsafe:d,decode:p}}var Vl=ql,Fl=Vl,qa=Fl;var zo=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")}},$o=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 Va(this,e)}},Go=class{decoders;constructor(e){this.decoders=e}or(e){return Va(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 Va(r,e){return new Go({...r.decoders??{[r.prefix]:r},...e.decoders??{[e.prefix]:e}})}var Wo=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 zo(e,t,n),this.decoder=new $o(e,t,s)}encode(e){return this.encoder.encode(e)}decode(e){return this.decoder.decode(e)}};function nr({name:r,prefix:e,encode:t,decode:n}){return new Wo(r,e,t,n)}function mt({name:r,prefix:e,alphabet:t}){let{encode:n,decode:s}=qa(t,r);return nr({prefix:e,name:r,encode:n,decode:o=>Je(s(o))})}function zl(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 l=0;l<s;++l){let u=e[r[l]];if(u===void 0)throw new SyntaxError(`Non-${n} character`);a=a<<t|u,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 $l(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 Gl(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=Gl(n);return nr({prefix:e,name:r,encode(o){return $l(o,n,t)},decode(o){return zl(o,s,t,r)}})}var te=mt({name:"base58btc",prefix:"z",alphabet:"123456789ABCDEFGHJKLMNPQRSTUVWXYZabcdefghijkmnopqrstuvwxyz"}),Wl=mt({name:"base58flickr",prefix:"Z",alphabet:"123456789abcdefghijkmnopqrstuvwxyzABCDEFGHJKLMNPQRSTUVWXYZ"});var Zo={};ve(Zo,{base32:()=>yt,base32hex:()=>jl,base32hexpad:()=>Jl,base32hexpadupper:()=>ef,base32hexupper:()=>Ql,base32pad:()=>Zl,base32padupper:()=>Xl,base32upper:()=>Yl,base32z:()=>tf});var yt=ce({prefix:"b",name:"base32",alphabet:"abcdefghijklmnopqrstuvwxyz234567",bitsPerChar:5}),Yl=ce({prefix:"B",name:"base32upper",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZ234567",bitsPerChar:5}),Zl=ce({prefix:"c",name:"base32pad",alphabet:"abcdefghijklmnopqrstuvwxyz234567=",bitsPerChar:5}),Xl=ce({prefix:"C",name:"base32padupper",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZ234567=",bitsPerChar:5}),jl=ce({prefix:"v",name:"base32hex",alphabet:"0123456789abcdefghijklmnopqrstuv",bitsPerChar:5}),Ql=ce({prefix:"V",name:"base32hexupper",alphabet:"0123456789ABCDEFGHIJKLMNOPQRSTUV",bitsPerChar:5}),Jl=ce({prefix:"t",name:"base32hexpad",alphabet:"0123456789abcdefghijklmnopqrstuv=",bitsPerChar:5}),ef=ce({prefix:"T",name:"base32hexpadupper",alphabet:"0123456789ABCDEFGHIJKLMNOPQRSTUV=",bitsPerChar:5}),tf=ce({prefix:"h",name:"base32z",alphabet:"ybndrfg8ejkmcpqxot1uwisza345h769",bitsPerChar:5});var Xo={};ve(Xo,{base36:()=>Br,base36upper:()=>rf});var Br=mt({prefix:"k",name:"base36",alphabet:"0123456789abcdefghijklmnopqrstuvwxyz"}),rf=mt({prefix:"K",name:"base36upper",alphabet:"0123456789ABCDEFGHIJKLMNOPQRSTUVWXYZ"});var nf=$a,Fa=128,of=127,sf=~of,af=Math.pow(2,31);function $a(r,e,t){e=e||[],t=t||0;for(var n=t;r>=af;)e[t++]=r&255|Fa,r/=128;for(;r&sf;)e[t++]=r&255|Fa,r>>>=7;return e[t]=r|0,$a.bytes=t-n+1,e}var cf=jo,uf=128,za=127;function jo(r,n){var t=0,n=n||0,s=0,o=n,i,a=r.length;do{if(o>=a)throw jo.bytes=0,new RangeError("Could not decode varint");i=r[o++],t+=s<28?(i&za)<<s:(i&za)*Math.pow(2,s),s+=7}while(i>=uf);return jo.bytes=o-n,t}var lf=Math.pow(2,7),ff=Math.pow(2,14),df=Math.pow(2,21),hf=Math.pow(2,28),pf=Math.pow(2,35),mf=Math.pow(2,42),yf=Math.pow(2,49),bf=Math.pow(2,56),gf=Math.pow(2,63),xf=function(r){return r<lf?1:r<ff?2:r<df?3:r<hf?4:r<pf?5:r<mf?6:r<yf?7:r<bf?8:r<gf?9:10},wf={encode:nf,decode:cf,encodingLength:xf},Ef=wf,Rr=Ef;function Or(r,e=0){return[Rr.decode(r,e),Rr.decode.bytes]}function or(r,e,t=0){return Rr.encode(r,e,t),e}function sr(r){return Rr.encodingLength(r)}function $e(r,e){let t=e.byteLength,n=sr(r),s=n+sr(t),o=new Uint8Array(s+t);return or(r,o,0),or(t,o,n),o.set(e,s),new ir(r,t,e,o)}function Ge(r){let e=Je(r),[t,n]=Or(e),[s,o]=Or(e.subarray(n)),i=e.subarray(n+o);if(i.byteLength!==s)throw new Error("Incorrect length");return new ir(t,s,i,e)}function Ga(r,e){if(r===e)return!0;{let t=e;return r.code===t.code&&r.size===t.size&&t.bytes instanceof Uint8Array&&ka(r.bytes,t.bytes)}}var ir=class{code;size;digest;bytes;constructor(e,t,n,s){this.code=e,this.size=t,this.digest=n,this.bytes=s}};function Wa(r,e){let{bytes:t,version:n}=r;return n===0?vf(t,Qo(r),e??te.encoder):_f(t,Qo(r),e??yt.encoder)}var Ya=new WeakMap;function Qo(r){let e=Ya.get(r);if(e==null){let t=new Map;return Ya.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=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!==Pr)throw new Error("Cannot convert a non dag-pb CID to CIDv0");if(t.code!==Af)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=$e(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&&Ga(e.multihash,n.multihash)}toString(e){return Wa(this,e)}toJSON(){return{"/":Wa(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??Za(n,s,o.bytes))}else if(t[Tf]===!0){let{version:n,multihash:s,code:o}=t,i=Ge(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!==Pr)throw new Error(`Version 0 CID must use dag-pb (code: ${Pr}) block encoding`);return new r(e,t,n,n.bytes)}case 1:{let s=Za(e,t,n.bytes);return new r(e,t,n,s)}default:throw new Error("Invalid version")}}static createV0(e){return r.create(0,Pr,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=Je(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 ir(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,d]=Or(e.subarray(t));return t+=d,f},s=n(),o=Pr;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(),l=t+c,u=l-i;return{version:s,codec:o,multihashCode:a,digestSize:c,multihashSize:u,size:l}}static parse(e,t){let[n,s]=Sf(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 Qo(o).set(n,e),o}};function Sf(r,e){switch(r[0]){case"Q":{let t=e??te;return[te.prefix,t.decode(`${te.prefix}${r}`)]}case te.prefix:{let t=e??te;return[te.prefix,t.decode(r)]}case yt.prefix:{let t=e??yt;return[yt.prefix,t.decode(r)]}case Br.prefix:{let t=e??Br;return[Br.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 vf(r,e,t){let{prefix:n}=t;if(n!==te.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 _f(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 Pr=112,Af=18;function Za(r,e,t){let n=sr(r),s=n+sr(e),o=new Uint8Array(s+t.byteLength);return or(r,o,0),or(e,o,n),o.set(t,s),o}var Tf=Symbol.for("@ipld/js-cid/CID");var Jo={};ve(Jo,{identity:()=>Me});var Xa=0,If="identity",ja=Je;function Df(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 $e(Xa,ja(r))}var Me={code:Xa,name:If,encode:ja,digest:Df};function fe(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 re(r=0){return new Uint8Array(r)}function Ae(r=0){return new Uint8Array(r)}function tt(r,e){e==null&&(e=r.reduce((s,o)=>s+o.length,0));let t=Ae(e),n=0;for(let s of r)t.set(s,n),n+=s.length;return t}var Ja=Symbol.for("@achingbrain/uint8arraylist");function Qa(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 An(r){return!!r?.[Ja]}var J=class r{bufs;length;[Ja]=!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(An(n))t+=n.byteLength,this.bufs.push(...n.bufs);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(An(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=Qa(this.bufs,e);return t.buf[t.index]}set(e,t){let n=Qa(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(An(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 tt(n,s)}subarray(e,t){let{bufs:n,length:s}=this._subList(e,t);return n.length===1?n[0]:tt(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 l=e>=a&&e<c,u=t>a&&t<=c;if(l&&u){if(e===a&&t===c){n.push(i);break}let f=e-a;n.push(i.subarray(f,f+(t-e)));break}if(l){if(e===0){n.push(i);continue}n.push(i.subarray(e-a));continue}if(u){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(!An(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,l=n.byteLength-1,u;for(let f=t;f<=c;f+=u){u=0;for(let d=l;d>=0;d--){let p=this.get(f+d);if(n[d]!==p){u=Math.max(1,d-a[p]);break}}if(u===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=Ae(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=re(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=re(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=re(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=Ae(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=re(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=re(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=re(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=re(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=re(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(!fe(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 es={};ve(es,{base10:()=>Cf});var Cf=mt({prefix:"9",name:"base10",alphabet:"0123456789"});var ts={};ve(ts,{base16:()=>Lf,base16upper:()=>Bf});var Lf=ce({prefix:"f",name:"base16",alphabet:"0123456789abcdef",bitsPerChar:4}),Bf=ce({prefix:"F",name:"base16upper",alphabet:"0123456789ABCDEF",bitsPerChar:4});var rs={};ve(rs,{base2:()=>Rf});var Rf=ce({prefix:"0",name:"base2",alphabet:"01",bitsPerChar:1});var ns={};ve(ns,{base256emoji:()=>kf});var ec=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}"),Of=ec.reduce((r,e,t)=>(r[t]=e,r),[]),Pf=ec.reduce((r,e,t)=>{let n=e.codePointAt(0);if(n==null)throw new Error(`Invalid character: ${e}`);return r[n]=t,r},[]);function Nf(r){return r.reduce((e,t)=>(e+=Of[t],e),"")}function Uf(r){let e=[];for(let t of r){let n=t.codePointAt(0);if(n==null)throw new Error(`Invalid character: ${t}`);let s=Pf[n];if(s==null)throw new Error(`Non-base256emoji character: ${t}`);e.push(s)}return new Uint8Array(e)}var kf=nr({prefix:"\u{1F680}",name:"base256emoji",encode:Nf,decode:Uf});var ss={};ve(ss,{base64:()=>Mf,base64pad:()=>Kf,base64url:()=>os,base64urlpad:()=>Hf});var Mf=ce({prefix:"m",name:"base64",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/",bitsPerChar:6}),Kf=ce({prefix:"M",name:"base64pad",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/=",bitsPerChar:6}),os=ce({prefix:"u",name:"base64url",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789-_",bitsPerChar:6}),Hf=ce({prefix:"U",name:"base64urlpad",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789-_=",bitsPerChar:6});var is={};ve(is,{base8:()=>qf});var qf=ce({prefix:"7",name:"base8",alphabet:"01234567",bitsPerChar:3});var as={};ve(as,{identity:()=>Vf});var Vf=nr({prefix:"\0",name:"identity",encode:r=>Ka(r),decode:r=>Ma(r)});var Y0=new TextEncoder,Z0=new TextDecoder;var ls={};ve(ls,{sha256:()=>ar,sha512:()=>Gf});var $f=20;function us({name:r,code:e,encode:t,minDigestLength:n,maxDigestLength:s}){return new cs(r,e,t,n,s)}var cs=class{name;code;encode;minDigestLength;maxDigestLength;constructor(e,t,n,s,o){this.name=e,this.code=t,this.encode=n,this.minDigestLength=s??$f,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?tc(n,this.code,t?.truncate):n.then(s=>tc(s,this.code,t?.truncate))}else throw Error("Unknown type, must be binary type")}};function tc(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 $e(e,r)}function nc(r){return async e=>new Uint8Array(await crypto.subtle.digest(r,e))}var ar=us({name:"sha2-256",code:18,encode:nc("SHA-256")}),Gf=us({name:"sha2-512",code:19,encode:nc("SHA-512")});var Nr={...as,...rs,...is,...es,...ts,...Zo,...Xo,...Yo,...ss,...ns},am={...ls,...Jo};function sc(r,e,t,n){return{name:r,prefix:e,encoder:{name:r,prefix:e,encode:t},decoder:{decode:n}}}var oc=sc("utf8","u",r=>"u"+new TextDecoder("utf8").decode(r),r=>new TextEncoder().encode(r.substring(1))),fs=sc("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=Ae(r.length);for(let t=0;t<r.length;t++)e[t]=r.charCodeAt(t);return e}),Wf={utf8:oc,"utf-8":oc,hex:Nr.base16,latin1:fs,ascii:fs,binary:fs,...Nr},Tn=Wf;function K(r,e="utf8"){let t=Tn[e];if(t==null)throw new Error(`Unsupported encoding "${e}"`);return t.decoder.decode(`${t.prefix}${r}`)}function $(r,e="utf8"){let t=Tn[e];if(t==null)throw new Error(`Unsupported encoding "${e}"`);return t.encoder.encode(r).substring(1)}var Yf=parseInt("11111",2),ds=parseInt("10000000",2),Zf=parseInt("01111111",2),ic={0:Ur,1:Ur,2:Xf,3:Jf,4:ed,5:Qf,6:jf,16:Ur,22:Ur,48:Ur};function rt(r,e={offset:0}){let t=r[e.offset]&Yf;if(e.offset++,ic[t]!=null)return ic[t](r,e);throw new Error("No decoder for tag "+t)}function kr(r,e){let t=0;if((r[e.offset]&ds)===ds){let n=r[e.offset]&Zf,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 Ur(r,e){kr(r,e);let t=[];for(;!(e.offset>=r.byteLength);){let n=rt(r,e);if(n===null)break;t.push(n)}return t}function Xf(r,e){let t=kr(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 jf(r,e){let t=kr(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 l=r[e.offset];if(e.offset++,c.push(l&127),l<128){c.reverse();let u=0;for(let f=0;f<c.length;f++)u+=c[f]<<f*7;a+=`.${u}`,c=[]}}return a}function Qf(r,e){return e.offset++,null}function Jf(r,e){let t=kr(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 ed(r,e){let t=kr(r,e),n=r.subarray(e.offset,e.offset+t);return e.offset+=t,n}function td(r){let e=r.toString(16);e.length%2===1&&(e="0"+e);let t=new J;for(let n=0;n<e.length;n+=2)t.append(Uint8Array.from([parseInt(`${e[n]}${e[n+1]}`,16)]));return t}function hs(r){if(r.byteLength<128)return Uint8Array.from([r.byteLength]);let e=td(r.byteLength);return new J(Uint8Array.from([e.byteLength|ds]),e)}function Te(r){let e=new J,t=128;return(r.subarray()[0]&t)===t&&e.append(Uint8Array.from([0])),e.append(r),new J(Uint8Array.from([2]),hs(e),e)}function In(r){let e=Uint8Array.from([0]),t=new J(e,r);return new J(Uint8Array.from([3]),hs(t),t)}function bt(r,e=48){let t=new J;for(let n of r)t.append(n);return new J(Uint8Array.from([e]),hs(t),t)}async function ac(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,t.subarray());return n?.signal?.throwIfAborted(),o}var rd=Uint8Array.from([6,8,42,134,72,206,61,3,1,7]),nd=Uint8Array.from([6,5,43,129,4,0,34]),od=Uint8Array.from([6,5,43,129,4,0,35]),sd={ext:!0,kty:"EC",crv:"P-256"},id={ext:!0,kty:"EC",crv:"P-384"},ad={ext:!0,kty:"EC",crv:"P-521"},ps=32,ms=48,ys=66;function bs(r){let e=rt(r);return cc(e)}function cc(r){let e=r[1][1][0],t=1,n,s;if(e.byteLength===ps*2+1)return n=$(e.subarray(t,t+ps),"base64url"),s=$(e.subarray(t+ps),"base64url"),new cr({...sd,key_ops:["verify"],x:n,y:s});if(e.byteLength===ms*2+1)return n=$(e.subarray(t,t+ms),"base64url"),s=$(e.subarray(t+ms),"base64url"),new cr({...id,key_ops:["verify"],x:n,y:s});if(e.byteLength===ys*2+1)return n=$(e.subarray(t,t+ys),"base64url"),s=$(e.subarray(t+ys),"base64url"),new cr({...ad,key_ops:["verify"],x:n,y:s});throw new ae(`coordinates were wrong length, got ${e.byteLength}, expected 65, 97 or 133`)}function uc(r){return bt([Te(Uint8Array.from([1])),bt([cd(r.crv)],160),bt([In(new J(Uint8Array.from([4]),K(r.x??"","base64url"),K(r.y??"","base64url")))],161)]).subarray()}function cd(r){if(r==="P-256")return rd;if(r==="P-384")return nd;if(r==="P-521")return od;throw new ae(`Invalid curve ${r}`)}var cr=class{type="ECDSA";jwk;_raw;constructor(e){this.jwk=e}get raw(){return this._raw==null&&(this._raw=uc(this.jwk)),this._raw}toMultihash(){return Me.digest(We(this))}toCID(){return le.createV1(114,this.toMultihash())}toString(){return te.encode(this.toMultihash().bytes).substring(1)}equals(e){return e==null||!(e.raw instanceof Uint8Array)?!1:fe(this.raw,e.raw)}async verify(e,t,n){return ac(this.jwk,t,e,n)}};function Pt(r){return r instanceof Uint8Array||ArrayBuffer.isView(r)&&r.constructor.name==="Uint8Array"}function Ye(r,e=""){if(!Number.isSafeInteger(r)||r<0){let t=e&&`"${e}" `;throw new Error(`${t}expected integer >= 0, got ${r}`)}}function k(r,e,t=""){let n=Pt(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}`;throw new Error(i+"expected Uint8Array"+a+", got "+c)}return r}function Dn(r){if(typeof r!="function"||typeof r.create!="function")throw new Error("Hash must wrapped by utils.createHasher");Ye(r.outputLen),Ye(r.blockLen)}function ur(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 fc(r,e){k(r,void 0,"digestInto() output");let t=e.outputLen;if(r.length<t)throw new Error('"digestInto() output" expected to be of length >='+t)}function ot(...r){for(let e=0;e<r.length;e++)r[e].fill(0)}function Cn(r){return new DataView(r.buffer,r.byteOffset,r.byteLength)}function Ke(r,e){return r<<32-e|r>>>e}var dc=typeof Uint8Array.from([]).toHex=="function"&&typeof Uint8Array.fromHex=="function",ud=Array.from({length:256},(r,e)=>e.toString(16).padStart(2,"0"));function st(r){if(k(r),dc)return r.toHex();let e="";for(let t=0;t<r.length;t++)e+=ud[r[t]];return e}var nt={_0:48,_9:57,A:65,F:70,a:97,f:102};function lc(r){if(r>=nt._0&&r<=nt._9)return r-nt._0;if(r>=nt.A&&r<=nt.F)return r-(nt.A-10);if(r>=nt.a&&r<=nt.f)return r-(nt.a-10)}function it(r){if(typeof r!="string")throw new Error("hex string expected, got "+typeof r);if(dc)return Uint8Array.fromHex(r);let e=r.length,t=e/2;if(e%2)throw new Error("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=lc(r.charCodeAt(o)),a=lc(r.charCodeAt(o+1));if(i===void 0||a===void 0){let c=r[o]+r[o+1];throw new Error('hex string expected, got non-hex character "'+c+'" at index '+o)}n[s]=i*16+a}return n}function Ie(...r){let e=0;for(let n=0;n<r.length;n++){let s=r[n];k(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 gs(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.create=s=>r(s),Object.assign(t,e),Object.freeze(t)}function lr(r=32){let e=typeof globalThis=="object"?globalThis.crypto:null;if(typeof e?.getRandomValues!="function")throw new Error("crypto.getRandomValues must be defined");return e.getRandomValues(new Uint8Array(r))}var xs=r=>({oid:Uint8Array.from([6,9,96,134,72,1,101,3,4,2,r])});function hc(r,e,t){return r&e^~r&t}function pc(r,e,t){return r&e^r&t^e&t}var Mr=class{blockLen;outputLen;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=Cn(this.buffer)}update(e){ur(this),k(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=Cn(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){ur(this),fc(e,this),this.finished=!0;let{buffer:t,view:n,blockLen:s,isLE:o}=this,{pos:i}=this;t[i++]=128,ot(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=Cn(e),c=this.outputLen;if(c%4)throw new Error("_sha2: outputLen must be aligned to 32bit");let l=c/4,u=this.get();if(l>u.length)throw new Error("_sha2: outputLen bigger than state");for(let f=0;f<l;f++)a.setUint32(4*f,u[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()}},at=Uint32Array.from([1779033703,3144134277,1013904242,2773480762,1359893119,2600822924,528734635,1541459225]);var ye=Uint32Array.from([1779033703,4089235720,3144134277,2227873595,1013904242,4271175723,2773480762,1595750129,1359893119,2917565137,2600822924,725511199,528734635,4215389547,1541459225,327033209]);var Ln=BigInt(4294967295),mc=BigInt(32);function ld(r,e=!1){return e?{h:Number(r&Ln),l:Number(r>>mc&Ln)}:{h:Number(r>>mc&Ln)|0,l:Number(r&Ln)|0}}function yc(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}=ld(r[o],e);[n[o],s[o]]=[i,a]}return[n,s]}var ws=(r,e,t)=>r>>>t,Es=(r,e,t)=>r<<32-t|e>>>t,Nt=(r,e,t)=>r>>>t|e<<32-t,Ut=(r,e,t)=>r<<32-t|e>>>t,Kr=(r,e,t)=>r<<64-t|e>>>t-32,Hr=(r,e,t)=>r>>>t-32|e<<64-t;function Ze(r,e,t,n){let s=(e>>>0)+(n>>>0);return{h:r+t+(s/2**32|0)|0,l:s|0}}var bc=(r,e,t)=>(r>>>0)+(e>>>0)+(t>>>0),gc=(r,e,t,n)=>e+t+n+(r/2**32|0)|0,xc=(r,e,t,n)=>(r>>>0)+(e>>>0)+(t>>>0)+(n>>>0),wc=(r,e,t,n,s)=>e+t+n+s+(r/2**32|0)|0,Ec=(r,e,t,n,s)=>(r>>>0)+(e>>>0)+(t>>>0)+(n>>>0)+(s>>>0),Sc=(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]),gt=new Uint32Array(64),Ss=class extends Mr{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)gt[f]=e.getUint32(t,!1);for(let f=16;f<64;f++){let d=gt[f-15],p=gt[f-2],h=Ke(d,7)^Ke(d,18)^d>>>3,S=Ke(p,17)^Ke(p,19)^p>>>10;gt[f]=S+gt[f-7]+h+gt[f-16]|0}let{A:n,B:s,C:o,D:i,E:a,F:c,G:l,H:u}=this;for(let f=0;f<64;f++){let d=Ke(a,6)^Ke(a,11)^Ke(a,25),p=u+d+hc(a,c,l)+dd[f]+gt[f]|0,S=(Ke(n,2)^Ke(n,13)^Ke(n,22))+pc(n,s,o)|0;u=l,l=c,c=a,a=i+p|0,i=o,o=s,s=n,n=p+S|0}n=n+this.A|0,s=s+this.B|0,o=o+this.C|0,i=i+this.D|0,a=a+this.E|0,c=c+this.F|0,l=l+this.G|0,u=u+this.H|0,this.set(n,s,o,i,a,c,l,u)}roundClean(){ot(gt)}destroy(){this.set(0,0,0,0,0,0,0,0),ot(this.buffer)}},vs=class extends Ss{A=at[0]|0;B=at[1]|0;C=at[2]|0;D=at[3]|0;E=at[4]|0;F=at[5]|0;G=at[6]|0;H=at[7]|0;constructor(){super(32)}};var vc=yc(["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))),hd=vc[0],pd=vc[1],xt=new Uint32Array(80),wt=new Uint32Array(80),_s=class extends Mr{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:l,El:u,Fh:f,Fl:d,Gh:p,Gl:h,Hh:S,Hl:x}=this;return[e,t,n,s,o,i,a,c,l,u,f,d,p,h,S,x]}set(e,t,n,s,o,i,a,c,l,u,f,d,p,h,S,x){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=l|0,this.El=u|0,this.Fh=f|0,this.Fl=d|0,this.Gh=p|0,this.Gl=h|0,this.Hh=S|0,this.Hl=x|0}process(e,t){for(let w=0;w<16;w++,t+=4)xt[w]=e.getUint32(t),wt[w]=e.getUint32(t+=4);for(let w=16;w<80;w++){let T=xt[w-15]|0,P=wt[w-15]|0,M=Nt(T,P,1)^Nt(T,P,8)^ws(T,P,7),q=Ut(T,P,1)^Ut(T,P,8)^Es(T,P,7),v=xt[w-2]|0,E=wt[w-2]|0,N=Nt(v,E,19)^Kr(v,E,61)^ws(v,E,6),V=Ut(v,E,19)^Hr(v,E,61)^Es(v,E,6),L=xc(q,V,wt[w-7],wt[w-16]),b=wc(L,M,N,xt[w-7],xt[w-16]);xt[w]=b|0,wt[w]=L|0}let{Ah:n,Al:s,Bh:o,Bl:i,Ch:a,Cl:c,Dh:l,Dl:u,Eh:f,El:d,Fh:p,Fl:h,Gh:S,Gl:x,Hh:y,Hl:A}=this;for(let w=0;w<80;w++){let T=Nt(f,d,14)^Nt(f,d,18)^Kr(f,d,41),P=Ut(f,d,14)^Ut(f,d,18)^Hr(f,d,41),M=f&p^~f&S,q=d&h^~d&x,v=Ec(A,P,q,pd[w],wt[w]),E=Sc(v,y,T,M,hd[w],xt[w]),N=v|0,V=Nt(n,s,28)^Kr(n,s,34)^Kr(n,s,39),L=Ut(n,s,28)^Hr(n,s,34)^Hr(n,s,39),b=n&o^n&a^o&a,g=s&i^s&c^i&c;y=S|0,A=x|0,S=p|0,x=h|0,p=f|0,h=d|0,{h:f,l:d}=Ze(l|0,u|0,E|0,N|0),l=a|0,u=c|0,a=o|0,c=i|0,o=n|0,i=s|0;let m=bc(N,L,g);n=gc(m,E,V,b),s=m|0}({h:n,l:s}=Ze(this.Ah|0,this.Al|0,n|0,s|0)),{h:o,l:i}=Ze(this.Bh|0,this.Bl|0,o|0,i|0),{h:a,l:c}=Ze(this.Ch|0,this.Cl|0,a|0,c|0),{h:l,l:u}=Ze(this.Dh|0,this.Dl|0,l|0,u|0),{h:f,l:d}=Ze(this.Eh|0,this.El|0,f|0,d|0),{h:p,l:h}=Ze(this.Fh|0,this.Fl|0,p|0,h|0),{h:S,l:x}=Ze(this.Gh|0,this.Gl|0,S|0,x|0),{h:y,l:A}=Ze(this.Hh|0,this.Hl|0,y|0,A|0),this.set(n,s,o,i,a,c,l,u,f,d,p,h,S,x,y,A)}roundClean(){ot(xt,wt)}destroy(){ot(this.buffer),this.set(0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0)}},As=class extends _s{Ah=ye[0]|0;Al=ye[1]|0;Bh=ye[2]|0;Bl=ye[3]|0;Ch=ye[4]|0;Cl=ye[5]|0;Dh=ye[6]|0;Dl=ye[7]|0;Eh=ye[8]|0;El=ye[9]|0;Fh=ye[10]|0;Fl=ye[11]|0;Gh=ye[12]|0;Gl=ye[13]|0;Hh=ye[14]|0;Hl=ye[15]|0;constructor(){super(64)}};var _c=gs(()=>new vs,xs(1));var Ac=gs(()=>new As,xs(3));var Is=BigInt(0),Ts=BigInt(1);function ct(r,e=""){if(typeof r!="boolean"){let t=e&&`"${e}" `;throw new Error(t+"expected boolean, got type="+typeof r)}return r}function Tc(r){if(typeof r=="bigint"){if(!Bn(r))throw new Error("positive bigint expected, got "+r)}else Ye(r);return r}function qr(r){let e=Tc(r).toString(16);return e.length&1?"0"+e:e}function Ic(r){if(typeof r!="string")throw new Error("hex string expected, got "+typeof r);return r===""?Is:BigInt("0x"+r)}function fr(r){return Ic(st(r))}function kt(r){return Ic(st(On(k(r)).reverse()))}function Rn(r,e){Ye(e),r=Tc(r);let t=it(r.toString(16).padStart(e*2,"0"));if(t.length!==e)throw new Error("number too large");return t}function Ds(r,e){return Rn(r,e).reverse()}function On(r){return Uint8Array.from(r)}var Bn=r=>typeof r=="bigint"&&Is<=r;function md(r,e,t){return Bn(r)&&Bn(e)&&Bn(t)&&e<=r&&r<t}function Vr(r,e,t,n){if(!md(e,t,n))throw new Error("expected valid "+r+": "+t+" <= n < "+n+", got "+e)}function Cs(r){let e;for(e=0;r>Is;r>>=Ts,e+=1);return e}var Fr=r=>(Ts<<BigInt(r))-Ts;function Dc(r,e,t){if(Ye(r,"hashLen"),Ye(e,"qByteLen"),typeof t!="function")throw new Error("hmacFn must be a function");let n=x=>new Uint8Array(x),s=Uint8Array.of(),o=Uint8Array.of(0),i=Uint8Array.of(1),a=1e3,c=n(r),l=n(r),u=0,f=()=>{c.fill(1),l.fill(0),u=0},d=(...x)=>t(l,Ie(c,...x)),p=(x=s)=>{l=d(o,x),c=d(),x.length!==0&&(l=d(i,x),c=d())},h=()=>{if(u++>=a)throw new Error("drbg: tried max amount of iterations");let x=0,y=[];for(;x<e;){c=d();let A=c.slice();y.push(A),x+=c.length}return Ie(...y)};return(x,y)=>{f(),p(x);let A;for(;!(A=y(h()));)p();return f(),A}}function Et(r,e={},t={}){if(!r||typeof r!="object")throw new Error("expected valid options object");function n(o,i,a){let c=r[o];if(a&&c===void 0)return;let l=typeof c;if(l!==i||c===null)throw new Error(`param "${o}" is invalid: expected ${i}, got ${l}`)}let s=(o,i)=>Object.entries(o).forEach(([a,c])=>n(a,c,i));s(e,!1),s(t,!0)}function dr(r){let e=new WeakMap;return(t,...n)=>{let s=e.get(t);if(s!==void 0)return s;let o=r(t,...n);return e.set(t,o),o}}var Se=BigInt(0),de=BigInt(1),Mt=BigInt(2),Bc=BigInt(3),Rc=BigInt(4),Oc=BigInt(5),yd=BigInt(7),Pc=BigInt(8),bd=BigInt(9),Nc=BigInt(16);function ue(r,e){let t=r%e;return t>=Se?t:e+t}function ee(r,e,t){let n=r;for(;e-- >Se;)n*=n,n%=t;return n}function Cc(r,e){if(r===Se)throw new Error("invert: expected non-zero number");if(e<=Se)throw new Error("invert: expected positive modulus, got "+e);let t=ue(r,e),n=e,s=Se,o=de,i=de,a=Se;for(;t!==Se;){let l=n/t,u=n%t,f=s-i*l,d=o-a*l;n=t,t=u,s=i,o=a,i=f,a=d}if(n!==de)throw new Error("invert: does not exist");return ue(s,e)}function Bs(r,e,t){if(!r.eql(r.sqr(e),t))throw new Error("Cannot find square root")}function Uc(r,e){let t=(r.ORDER+de)/Rc,n=r.pow(e,t);return Bs(r,n,e),n}function gd(r,e){let t=(r.ORDER-Oc)/Pc,n=r.mul(e,Mt),s=r.pow(n,t),o=r.mul(e,s),i=r.mul(r.mul(o,Mt),s),a=r.mul(o,r.sub(i,r.ONE));return Bs(r,a,e),a}function xd(r){let e=hr(r),t=kc(r),n=t(e,e.neg(e.ONE)),s=t(e,n),o=t(e,e.neg(n)),i=(r+yd)/Nc;return(a,c)=>{let l=a.pow(c,i),u=a.mul(l,n),f=a.mul(l,s),d=a.mul(l,o),p=a.eql(a.sqr(u),c),h=a.eql(a.sqr(f),c);l=a.cmov(l,u,p),u=a.cmov(d,f,h);let S=a.eql(a.sqr(u),c),x=a.cmov(l,u,S);return Bs(a,x,c),x}}function kc(r){if(r<Bc)throw new Error("sqrt is not defined for small field");let e=r-de,t=0;for(;e%Mt===Se;)e/=Mt,t++;let n=Mt,s=hr(r);for(;Lc(s,n)===1;)if(n++>1e3)throw new Error("Cannot find square root: probably non-prime P");if(t===1)return Uc;let o=s.pow(n,e),i=(e+de)/Mt;return function(c,l){if(c.is0(l))return l;if(Lc(c,l)!==1)throw new Error("Cannot find square root");let u=t,f=c.mul(c.ONE,o),d=c.pow(l,e),p=c.pow(l,i);for(;!c.eql(d,c.ONE);){if(c.is0(d))return c.ZERO;let h=1,S=c.sqr(d);for(;!c.eql(S,c.ONE);)if(h++,S=c.sqr(S),h===u)throw new Error("Cannot find square root");let x=de<<BigInt(u-h-1),y=c.pow(f,x);u=h,f=c.sqr(y),d=c.mul(d,f),p=c.mul(p,y)}return p}}function wd(r){return r%Rc===Bc?Uc:r%Pc===Oc?gd:r%Nc===bd?xd(r):kc(r)}var Mc=(r,e)=>(ue(r,e)&de)===de,Ed=["create","isValid","is0","neg","inv","sqrt","sqr","eql","add","sub","mul","pow","div","addN","subN","mulN","sqrN"];function Rs(r){let e={ORDER:"bigint",BYTES:"number",BITS:"number"},t=Ed.reduce((n,s)=>(n[s]="function",n),e);return Et(r,t),r}function Sd(r,e,t){if(t<Se)throw new Error("invalid exponent, negatives unsupported");if(t===Se)return r.ONE;if(t===de)return e;let n=r.ONE,s=e;for(;t>Se;)t&de&&(n=r.mul(n,s)),s=r.sqr(s),t>>=de;return n}function zr(r,e,t=!1){let n=new Array(e.length).fill(t?r.ZERO:void 0),s=e.reduce((i,a,c)=>r.is0(a)?i:(n[c]=i,r.mul(i,a)),r.ONE),o=r.inv(s);return e.reduceRight((i,a,c)=>r.is0(a)?i:(n[c]=r.mul(i,n[c]),r.mul(i,a)),o),n}function Lc(r,e){let t=(r.ORDER-de)/Mt,n=r.pow(e,t),s=r.eql(n,r.ONE),o=r.eql(n,r.ZERO),i=r.eql(n,r.neg(r.ONE));if(!s&&!o&&!i)throw new Error("invalid Legendre symbol result");return s?1:o?0:-1}function vd(r,e){e!==void 0&&Ye(e);let t=e!==void 0?e:r.toString(2).length,n=Math.ceil(t/8);return{nBitLength:t,nByteLength:n}}var Ls=class{ORDER;BITS;BYTES;isLE;ZERO=Se;ONE=de;_lengths;_sqrt;_mod;constructor(e,t={}){if(e<=Se)throw new Error("invalid field: expected ORDER > 0, got "+e);let n;this.isLE=!1,t!=null&&typeof t=="object"&&(typeof t.BITS=="number"&&(n=t.BITS),typeof t.sqrt=="function"&&(this.sqrt=t.sqrt),typeof t.isLE=="boolean"&&(this.isLE=t.isLE),t.allowedLengths&&(this._lengths=t.allowedLengths?.slice()),typeof t.modFromBytes=="boolean"&&(this._mod=t.modFromBytes));let{nBitLength:s,nByteLength:o}=vd(e,n);if(o>2048)throw new Error("invalid field: expected ORDER of <= 2048 bytes");this.ORDER=e,this.BITS=s,this.BYTES=o,this._sqrt=void 0,Object.preventExtensions(this)}create(e){return ue(e,this.ORDER)}isValid(e){if(typeof e!="bigint")throw new Error("invalid field element: expected bigint, got "+typeof e);return Se<=e&&e<this.ORDER}is0(e){return e===Se}isValidNot0(e){return!this.is0(e)&&this.isValid(e)}isOdd(e){return(e&de)===de}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 Sd(this,e,t)}div(e,t){return ue(e*Cc(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 Cc(e,this.ORDER)}sqrt(e){return this._sqrt||(this._sqrt=wd(this.ORDER)),this._sqrt(this,e)}toBytes(e){return this.isLE?Ds(e,this.BYTES):Rn(e,this.BYTES)}fromBytes(e,t=!1){k(e);let{_lengths:n,BYTES:s,isLE:o,ORDER:i,_mod:a}=this;if(n){if(!n.includes(e.length)||e.length>s)throw new Error("Field.fromBytes: expected "+n+" bytes, got "+e.length);let l=new Uint8Array(s);l.set(e,o?0:l.length-e.length),e=l}if(e.length!==s)throw new Error("Field.fromBytes: expected "+s+" bytes, got "+e.length);let c=o?kt(e):fr(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 zr(this,e)}cmov(e,t,n){return n?t:e}};function hr(r,e={}){return new Ls(r,e)}function Kc(r){if(typeof r!="bigint")throw new Error("field order must be bigint");let e=r.toString(2).length;return Math.ceil(e/8)}function Os(r){let e=Kc(r);return e+Math.ceil(e/2)}function Ps(r,e,t=!1){k(r);let n=r.length,s=Kc(e),o=Os(e);if(n<16||n<o||n>1024)throw new Error("expected "+o+"-1024 bytes of input, got "+n);let i=t?kt(r):fr(r),a=ue(i,e-de)+de;return t?Ds(a,s):Rn(a,s)}var pr=BigInt(0),Kt=BigInt(1);function $r(r,e){let t=e.negate();return r?t:e}function Ht(r,e){let t=zr(r.Fp,e.map(n=>n.Z));return e.map((n,s)=>r.fromAffine(n.toAffine(t[s])))}function Fc(r,e){if(!Number.isSafeInteger(r)||r<=0||r>e)throw new Error("invalid window size, expected [1.."+e+"], got W="+r)}function Ns(r,e){Fc(r,e);let t=Math.ceil(e/r)+1,n=2**(r-1),s=2**r,o=Fr(r),i=BigInt(r);return{windows:t,windowSize:n,mask:o,maxNumber:s,shiftBy:i}}function Hc(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+=Kt);let l=e*n,u=l+Math.abs(a)-1,f=a===0,d=a<0,p=e%2!==0;return{nextN:c,offset:u,isZero:f,isNeg:d,isNegF:p,offsetF:l}}var Us=new WeakMap,zc=new WeakMap;function ks(r){return zc.get(r)||1}function qc(r){if(r!==pr)throw new Error("invalid wNAF")}var mr=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>pr;)t&Kt&&(n=n.add(s)),s=s.double(),t>>=Kt;return n}precomputeWindow(e,t){let{windows:n,windowSize:s}=Ns(t,this.bits),o=[],i=e,a=i;for(let c=0;c<n;c++){a=i,o.push(a);for(let l=1;l<s;l++)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=Ns(e,this.bits);for(let a=0;a<i.windows;a++){let{nextN:c,offset:l,isZero:u,isNeg:f,isNegF:d,offsetF:p}=Hc(n,a,i);n=c,u?o=o.add($r(d,t[p])):s=s.add($r(f,t[l]))}return qc(n),{p:s,f:o}}wNAFUnsafe(e,t,n,s=this.ZERO){let o=Ns(e,this.bits);for(let i=0;i<o.windows&&n!==pr;i++){let{nextN:a,offset:c,isZero:l,isNeg:u}=Hc(n,i,o);if(n=a,!l){let f=t[c];s=s.add(u?f.negate():f)}}return qc(n),s}getPrecomputes(e,t,n){let s=Us.get(t);return s||(s=this.precomputeWindow(t,e),e!==1&&(typeof n=="function"&&(s=n(s)),Us.set(t,s))),s}cached(e,t,n){let s=ks(e);return this.wNAF(s,this.getPrecomputes(s,e,n),t)}unsafe(e,t,n,s){let o=ks(e);return o===1?this._unsafeLadder(e,t,s):this.wNAFUnsafe(o,this.getPrecomputes(o,e,n),t,s)}createCache(e,t){Fc(t,this.bits),zc.set(e,t),Us.delete(e)}hasCache(e){return ks(e)!==1}};function $c(r,e,t,n){let s=e,o=r.ZERO,i=r.ZERO;for(;t>pr||n>pr;)t&Kt&&(o=o.add(s)),n&Kt&&(i=i.add(s)),s=s.double(),t>>=Kt,n>>=Kt;return{p1:o,p2:i}}function Vc(r,e,t){if(e){if(e.ORDER!==r)throw new Error("Field.ORDER must match order: Fp == p, Fn == n");return Rs(e),e}else return hr(r,{isLE:t})}function Pn(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 l=e[c];if(!(typeof l=="bigint"&&l>pr))throw new Error(`CURVE.${c} must be positive bigint`)}let s=Vc(e.p,t.Fp,n),o=Vc(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 Nn(r,e){return function(n){let s=r(n);return{secretKey:s,publicKey:e(s)}}}var St=BigInt(0),he=BigInt(1),Ms=BigInt(2),_d=BigInt(8);function Ad(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 Gc(r,e={}){let t=Pn("edwards",r,e,e.FpFnLE),{Fp:n,Fn:s}=t,o=t.CURVE,{h:i}=o;Et(e,{},{uvRatio:"function"});let a=Ms<<BigInt(s.BYTES*8)-he,c=x=>n.create(x),l=e.uvRatio||((x,y)=>{try{return{isValid:!0,value:n.sqrt(n.div(x,y))}}catch{return{isValid:!1,value:St}}});if(!Ad(n,o,o.Gx,o.Gy))throw new Error("bad curve params: generator point");function u(x,y,A=!1){let w=A?he:St;return Vr("coordinate "+x,y,w,a),y}function f(x){if(!(x instanceof h))throw new Error("EdwardsPoint expected")}let d=dr((x,y)=>{let{X:A,Y:w,Z:T}=x,P=x.is0();y==null&&(y=P?_d:n.inv(T));let M=c(A*y),q=c(w*y),v=n.mul(T,y);if(P)return{x:St,y:he};if(v!==he)throw new Error("invZ was invalid");return{x:M,y:q}}),p=dr(x=>{let{a:y,d:A}=o;if(x.is0())throw new Error("bad point: ZERO");let{X:w,Y:T,Z:P,T:M}=x,q=c(w*w),v=c(T*T),E=c(P*P),N=c(E*E),V=c(q*y),L=c(E*c(V+v)),b=c(N+c(A*c(q*v)));if(L!==b)throw new Error("bad point: equation left != right (1)");let g=c(w*T),m=c(P*M);if(g!==m)throw new Error("bad point: equation left != right (2)");return!0});class h{static BASE=new h(o.Gx,o.Gy,he,c(o.Gx*o.Gy));static ZERO=new h(St,he,he,St);static Fp=n;static Fn=s;X;Y;Z;T;constructor(y,A,w,T){this.X=u("x",y),this.Y=u("y",A),this.Z=u("z",w,!0),this.T=u("t",T),Object.freeze(this)}static CURVE(){return o}static fromAffine(y){if(y instanceof h)throw new Error("extended point not allowed");let{x:A,y:w}=y||{};return u("x",A),u("y",w),new h(A,w,he,c(A*w))}static fromBytes(y,A=!1){let w=n.BYTES,{a:T,d:P}=o;y=On(k(y,w,"point")),ct(A,"zip215");let M=On(y),q=y[w-1];M[w-1]=q&-129;let v=kt(M),E=A?a:n.ORDER;Vr("point.y",v,St,E);let N=c(v*v),V=c(N-he),L=c(P*N-T),{isValid:b,value:g}=l(V,L);if(!b)throw new Error("bad point: invalid y coordinate");let m=(g&he)===he,_=(q&128)!==0;if(!A&&g===St&&_)throw new Error("bad point: x=0 and x_0=1");return _!==m&&(g=c(-g)),h.fromAffine({x:g,y:v})}static fromHex(y,A=!1){return h.fromBytes(it(y),A)}get x(){return this.toAffine().x}get y(){return this.toAffine().y}precompute(y=8,A=!0){return S.createCache(this,y),A||this.multiply(Ms),this}assertValidity(){p(this)}equals(y){f(y);let{X:A,Y:w,Z:T}=this,{X:P,Y:M,Z:q}=y,v=c(A*q),E=c(P*T),N=c(w*q),V=c(M*T);return v===E&&N===V}is0(){return this.equals(h.ZERO)}negate(){return new h(c(-this.X),this.Y,this.Z,c(-this.T))}double(){let{a:y}=o,{X:A,Y:w,Z:T}=this,P=c(A*A),M=c(w*w),q=c(Ms*c(T*T)),v=c(y*P),E=A+w,N=c(c(E*E)-P-M),V=v+M,L=V-q,b=v-M,g=c(N*L),m=c(V*b),_=c(N*b),I=c(L*V);return new h(g,m,I,_)}add(y){f(y);let{a:A,d:w}=o,{X:T,Y:P,Z:M,T:q}=this,{X:v,Y:E,Z:N,T:V}=y,L=c(T*v),b=c(P*E),g=c(q*w*V),m=c(M*N),_=c((T+P)*(v+E)-L-b),I=m-g,C=m+g,B=c(b-A*L),D=c(_*I),O=c(C*B),U=c(_*B),oe=c(I*C);return new h(D,O,oe,U)}subtract(y){return this.add(y.negate())}multiply(y){if(!s.isValidNot0(y))throw new Error("invalid scalar: expected 1 <= sc < curve.n");let{p:A,f:w}=S.cached(this,y,T=>Ht(h,T));return Ht(h,[A,w])[0]}multiplyUnsafe(y,A=h.ZERO){if(!s.isValid(y))throw new Error("invalid scalar: expected 0 <= sc < curve.n");return y===St?h.ZERO:this.is0()||y===he?this:S.unsafe(this,y,w=>Ht(h,w),A)}isSmallOrder(){return this.multiplyUnsafe(i).is0()}isTorsionFree(){return S.unsafe(this,o.n).is0()}toAffine(y){return d(this,y)}clearCofactor(){return i===he?this:this.multiplyUnsafe(i)}toBytes(){let{x:y,y:A}=this.toAffine(),w=n.toBytes(A);return w[w.length-1]|=y&he?128:0,w}toHex(){return st(this.toBytes())}toString(){return`<Point ${this.is0()?"ZERO":this.toHex()}>`}}let S=new mr(h,s.BITS);return h.BASE.precompute(8),h}function Wc(r,e,t={}){if(typeof e!="function")throw new Error('"hash" function param is required');Et(t,{},{adjustScalarBytes:"function",randomBytes:"function",domain:"function",prehash:"function",mapToCurve:"function"});let{prehash:n}=t,{BASE:s,Fp:o,Fn:i}=r,a=t.randomBytes||lr,c=t.adjustScalarBytes||(v=>v),l=t.domain||((v,E,N)=>{if(ct(N,"phflag"),E.length||N)throw new Error("Contexts/pre-hash are not supported");return v});function u(v){return i.create(kt(v))}function f(v){let E=w.secretKey;k(v,w.secretKey,"secretKey");let N=k(e(v),2*E,"hashedSecretKey"),V=c(N.slice(0,E)),L=N.slice(E,2*E),b=u(V);return{head:V,prefix:L,scalar:b}}function d(v){let{head:E,prefix:N,scalar:V}=f(v),L=s.multiply(V),b=L.toBytes();return{head:E,prefix:N,scalar:V,point:L,pointBytes:b}}function p(v){return d(v).pointBytes}function h(v=Uint8Array.of(),...E){let N=Ie(...E);return u(e(l(N,k(v,void 0,"context"),!!n)))}function S(v,E,N={}){v=k(v,void 0,"message"),n&&(v=n(v));let{prefix:V,scalar:L,pointBytes:b}=d(E),g=h(N.context,V,v),m=s.multiply(g).toBytes(),_=h(N.context,m,b,v),I=i.create(g+_*L);if(!i.isValid(I))throw new Error("sign failed: invalid s");let C=Ie(m,i.toBytes(I));return k(C,w.signature,"result")}let x={zip215:!0};function y(v,E,N,V=x){let{context:L,zip215:b}=V,g=w.signature;v=k(v,g,"signature"),E=k(E,void 0,"message"),N=k(N,w.publicKey,"publicKey"),b!==void 0&&ct(b,"zip215"),n&&(E=n(E));let m=g/2,_=v.subarray(0,m),I=kt(v.subarray(m,g)),C,B,D;try{C=r.fromBytes(N,b),B=r.fromBytes(_,b),D=s.multiplyUnsafe(I)}catch{return!1}if(!b&&C.isSmallOrder())return!1;let O=h(L,B.toBytes(),C.toBytes(),E);return B.add(C.multiplyUnsafe(O)).subtract(D).clearCofactor().is0()}let A=o.BYTES,w={secretKey:A,publicKey:A,signature:2*A,seed:A};function T(v=a(w.seed)){return k(v,w.seed,"seed")}function P(v){return Pt(v)&&v.length===i.BYTES}function M(v,E){try{return!!r.fromBytes(v,E)}catch{return!1}}let q={getExtendedPublicKey:d,randomSecretKey:T,isValidSecretKey:P,isValidPublicKey:M,toMontgomery(v){let{y:E}=r.fromBytes(v),N=w.publicKey,V=N===32;if(!V&&N!==57)throw new Error("only defined for 25519 and 448");let L=V?o.div(he+E,he-E):o.div(E-he,E+he);return o.toBytes(L)},toMontgomerySecret(v){let E=w.secretKey;k(v,E);let N=e(v.subarray(0,E));return c(N).subarray(0,E)}};return Object.freeze({keygen:Nn(T,p),getPublicKey:p,sign:S,verify:y,utils:q,Point:r,lengths:w})}var Td=BigInt(1),Yc=BigInt(2);var Id=BigInt(5),Dd=BigInt(8),Ks=BigInt("0x7fffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffed"),Cd={p:Ks,n:BigInt("0x1000000000000000000000000000000014def9dea2f79cd65812631a5cf5d3ed"),h:Dd,a:BigInt("0x7fffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffec"),d:BigInt("0x52036cee2b6ffe738cc740797779e89800700a4d4141d8ab75eb4dca135978a3"),Gx:BigInt("0x216936d3cd6e53fec0a4e231fdd6dc5c692cc7609525a7b2c9562d608f25d51a"),Gy:BigInt("0x6666666666666666666666666666666666666666666666666666666666666658")};function Ld(r){let e=BigInt(10),t=BigInt(20),n=BigInt(40),s=BigInt(80),o=Ks,a=r*r%o*r%o,c=ee(a,Yc,o)*a%o,l=ee(c,Td,o)*r%o,u=ee(l,Id,o)*l%o,f=ee(u,e,o)*u%o,d=ee(f,t,o)*f%o,p=ee(d,n,o)*d%o,h=ee(p,s,o)*p%o,S=ee(h,s,o)*p%o,x=ee(S,e,o)*u%o;return{pow_p_5_8:ee(x,Yc,o)*r%o,b2:a}}function Bd(r){return r[0]&=248,r[31]&=127,r[31]|=64,r}var Zc=BigInt("19681161376707505956807079304988542015446066515923890162744021073123829784752");function Rd(r,e){let t=Ks,n=ue(e*e*e,t),s=ue(n*n*e,t),o=Ld(r*s).pow_p_5_8,i=ue(r*n*o,t),a=ue(e*i*i,t),c=i,l=ue(i*Zc,t),u=a===r,f=a===ue(-r,t),d=a===ue(-r*Zc,t);return u&&(i=c),(f||d)&&(i=l),Mc(i,t)&&(i=ue(-i,t)),{isValid:u||f,value:i}}var Od=Gc(Cd,{uvRatio:Rd});function Pd(r){return Wc(Od,Ac,Object.assign({adjustScalarBytes:Bd},r))}var Xc=Pd({});var Gr=class extends Error{constructor(e="An error occurred while verifying a message"){super(e),this.name="VerificationError"}},Un=class extends Error{constructor(e="Missing Web Crypto API"){super(e),this.name="WebCryptoMissingError"}};var jc={get(r=globalThis){let e=r.crypto;if(e?.subtle==null)throw new Un("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 Ue=jc;var kn=32;var Hs,Nd=(async()=>{try{return await Ue.get().subtle.generateKey({name:"Ed25519"},!0,["sign","verify"]),!0}catch{return!1}})();async function Ud(r,e,t){if(r.buffer instanceof ArrayBuffer){let n=await Ue.get().subtle.importKey("raw",r.buffer,{name:"Ed25519"},!1,["verify"]);return await Ue.get().subtle.verify({name:"Ed25519"},n,e,t instanceof Uint8Array?t:t.subarray())}throw new TypeError("WebCrypto does not support SharedArrayBuffer for Ed25519 keys")}function kd(r,e,t){return Xc.verify(e,t instanceof Uint8Array?t:t.subarray(),r)}async function Qc(r,e,t){return Hs==null&&(Hs=await Nd),Hs?Ud(r,e,t):kd(r,e,t)}function Mn(r){return r==null?!1:typeof r.then=="function"&&typeof r.catch=="function"&&typeof r.finally=="function"}var Kn=class{type="Ed25519";raw;constructor(e){this.raw=qs(e,kn)}toMultihash(){return Me.digest(We(this))}toCID(){return le.createV1(114,this.toMultihash())}toString(){return te.encode(this.toMultihash().bytes).substring(1)}equals(e){return e==null||!(e.raw instanceof Uint8Array)?!1:fe(this.raw,e.raw)}verify(e,t,n){n?.signal?.throwIfAborted();let s=Qc(this.raw,t,e);return Mn(s)?s.then(o=>(n?.signal?.throwIfAborted(),o)):s}};function Vs(r){return r=qs(r,kn),new Kn(r)}function qs(r,e){if(r=Uint8Array.from(r??[]),r.length!==e)throw new ae(`Key must be a Uint8Array of length ${e}, got ${r.length}`);return r}var Kd=Math.pow(2,7),Hd=Math.pow(2,14),qd=Math.pow(2,21),Fs=Math.pow(2,28),zs=Math.pow(2,35),$s=Math.pow(2,42),Gs=Math.pow(2,49),Y=128,xe=127;function De(r){if(r<Kd)return 1;if(r<Hd)return 2;if(r<qd)return 3;if(r<Fs)return 4;if(r<zs)return 5;if(r<$s)return 6;if(r<Gs)return 7;if(Number.MAX_SAFE_INTEGER!=null&&r>Number.MAX_SAFE_INTEGER)throw new RangeError("Could not encode varint");return 8}function yr(r,e,t=0){switch(De(r)){case 8:e[t++]=r&255|Y,r/=128;case 7:e[t++]=r&255|Y,r/=128;case 6:e[t++]=r&255|Y,r/=128;case 5:e[t++]=r&255|Y,r/=128;case 4:e[t++]=r&255|Y,r>>>=7;case 3:e[t++]=r&255|Y,r>>>=7;case 2:e[t++]=r&255|Y,r>>>=7;case 1:{e[t++]=r&255,r>>>=7;break}default:throw new Error("unreachable")}return e}function Vd(r,e,t=0){switch(De(r)){case 8:e.set(t++,r&255|Y),r/=128;case 7:e.set(t++,r&255|Y),r/=128;case 6:e.set(t++,r&255|Y),r/=128;case 5:e.set(t++,r&255|Y),r/=128;case 4:e.set(t++,r&255|Y),r>>>=7;case 3:e.set(t++,r&255|Y),r>>>=7;case 2:e.set(t++,r&255|Y),r>>>=7;case 1:{e.set(t++,r&255),r>>>=7;break}default:throw new Error("unreachable")}return e}function Ws(r,e){let t=r[e],n=0;if(n+=t&xe,t<Y||(t=r[e+1],n+=(t&xe)<<7,t<Y)||(t=r[e+2],n+=(t&xe)<<14,t<Y)||(t=r[e+3],n+=(t&xe)<<21,t<Y)||(t=r[e+4],n+=(t&xe)*Fs,t<Y)||(t=r[e+5],n+=(t&xe)*zs,t<Y)||(t=r[e+6],n+=(t&xe)*$s,t<Y)||(t=r[e+7],n+=(t&xe)*Gs,t<Y))return n;throw new RangeError("Could not decode varint")}function Fd(r,e){let t=r.get(e),n=0;if(n+=t&xe,t<Y||(t=r.get(e+1),n+=(t&xe)<<7,t<Y)||(t=r.get(e+2),n+=(t&xe)<<14,t<Y)||(t=r.get(e+3),n+=(t&xe)<<21,t<Y)||(t=r.get(e+4),n+=(t&xe)*Fs,t<Y)||(t=r.get(e+5),n+=(t&xe)*zs,t<Y)||(t=r.get(e+6),n+=(t&xe)*$s,t<Y)||(t=r.get(e+7),n+=(t&xe)*Gs,t<Y))return n;throw new RangeError("Could not decode varint")}function br(r,e,t=0){return e==null&&(e=Ae(De(r))),e instanceof Uint8Array?yr(r,e,t):Vd(r,e,t)}function Wr(r,e=0){return r instanceof Uint8Array?Ws(r,e):Fd(r,e)}var Zs=new Float32Array([-0]),vt=new Uint8Array(Zs.buffer);function eu(r,e,t){Zs[0]=r,e[t]=vt[0],e[t+1]=vt[1],e[t+2]=vt[2],e[t+3]=vt[3]}function tu(r,e){return vt[0]=r[e],vt[1]=r[e+1],vt[2]=r[e+2],vt[3]=r[e+3],Zs[0]}var Xs=new Float64Array([-0]),we=new Uint8Array(Xs.buffer);function ru(r,e,t){Xs[0]=r,e[t]=we[0],e[t+1]=we[1],e[t+2]=we[2],e[t+3]=we[3],e[t+4]=we[4],e[t+5]=we[5],e[t+6]=we[6],e[t+7]=we[7]}function nu(r,e){return we[0]=r[e],we[1]=r[e+1],we[2]=r[e+2],we[3]=r[e+3],we[4]=r[e+4],we[5]=r[e+5],we[6]=r[e+6],we[7]=r[e+7],Xs[0]}var zd=BigInt(Number.MAX_SAFE_INTEGER),$d=BigInt(Number.MIN_SAFE_INTEGER),Oe=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 qt;if(e<zd&&e>$d)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>ou&&(s=0n,++n>ou&&(n=0n))),new r(Number(s),Number(n))}static fromNumber(e){if(e===0)return qt;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):qt}},qt=new Oe(0,0);qt.toBigInt=function(){return 0n};qt.zzEncode=qt.zzDecode=function(){return this};qt.length=function(){return 1};var ou=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 iu(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 js(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 He(r,e){return RangeError(`index out of range: ${r.pos} + ${e??1} > ${r.len}`)}function Hn(r,e){return(r[e-4]|r[e-3]<<8|r[e-2]<<16|r[e-1]<<24)>>>0}var Qs=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,He(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 He(this,4);return Hn(this.buf,this.pos+=4)}sfixed32(){if(this.pos+4>this.len)throw He(this,4);return Hn(this.buf,this.pos+=4)|0}float(){if(this.pos+4>this.len)throw He(this,4);let e=tu(this.buf,this.pos);return this.pos+=4,e}double(){if(this.pos+8>this.len)throw He(this,4);let e=nu(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 He(this,e);return this.pos+=e,t===n?new Uint8Array(0):this.buf.subarray(t,n)}string(){let e=this.bytes();return iu(e,0,e.length)}skip(e){if(typeof e=="number"){if(this.pos+e>this.len)throw He(this,e);this.pos+=e}else do if(this.pos>=this.len)throw He(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 Oe(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 He(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 He(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 He(this,8);let e=Hn(this.buf,this.pos+=4),t=Hn(this.buf,this.pos+=4);return new Oe(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=Ws(this.buf,this.pos);return this.pos+=De(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 Yr(r){return new Qs(r instanceof Uint8Array?r:r.subarray())}function Ce(r,e,t){let n=Yr(r);return e.decode(n,void 0,t)}function Js(r){let e=r??8192,t=e>>>1,n,s=e;return function(i){if(i<1||i>t)return Ae(i);s+i>e&&(n=Ae(e),s=0);let a=n.subarray(s,s+=i);return(s&7)!==0&&(s=(s|7)+1),a}}var Vt=class{fn;len;next;val;constructor(e,t,n){this.fn=e,this.len=t,this.next=void 0,this.val=n}};function ei(){}var ri=class{head;tail;len;next;constructor(e){this.head=e.head,this.tail=e.tail,this.len=e.len,this.next=e.states}},Gd=Js();function Wd(r){return globalThis.Buffer!=null?Ae(r):Gd(r)}var Xr=class{len;head;tail;states;constructor(){this.len=0,this.head=new Vt(ei,0,0),this.tail=this.head,this.states=null}_push(e,t,n){return this.tail=this.tail.next=new Vt(e,t,n),this.len+=t,this}uint32(e){return this.len+=(this.tail=this.tail.next=new ni((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(qn,10,Oe.fromNumber(e)):this.uint32(e)}sint32(e){return this.uint32((e<<1^e>>31)>>>0)}uint64(e){let t=Oe.fromBigInt(e);return this._push(qn,t.length(),t)}uint64Number(e){return this._push(yr,De(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=Oe.fromBigInt(e).zzEncode();return this._push(qn,t.length(),t)}sint64Number(e){let t=Oe.fromNumber(e).zzEncode();return this._push(qn,t.length(),t)}sint64String(e){return this.sint64(BigInt(e))}bool(e){return this._push(ti,1,e?1:0)}fixed32(e){return this._push(Zr,4,e>>>0)}sfixed32(e){return this.fixed32(e)}fixed64(e){let t=Oe.fromBigInt(e);return this._push(Zr,4,t.lo)._push(Zr,4,t.hi)}fixed64Number(e){let t=Oe.fromNumber(e);return this._push(Zr,4,t.lo)._push(Zr,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(eu,4,e)}double(e){return this._push(ru,8,e)}bytes(e){let t=e.length>>>0;return t===0?this._push(ti,1,0):this.uint32(t)._push(Zd,t,e)}string(e){let t=su(e);return t!==0?this.uint32(t)._push(js,t,e):this._push(ti,1,0)}fork(){return this.states=new ri(this),this.head=this.tail=new Vt(ei,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 Vt(ei,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=Wd(this.len),n=0;for(;e!=null;)e.fn(e.val,t,n),n+=e.len,e=e.next;return t}};function ti(r,e,t){e[t]=r&255}function Yd(r,e,t){for(;r>127;)e[t++]=r&127|128,r>>>=7;e[t]=r}var ni=class extends Vt{next;constructor(e,t){super(Yd,e,t),this.next=void 0}};function qn(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 Zr(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 Zd(r,e,t){e.set(r,t)}globalThis.Buffer!=null&&(Xr.prototype.bytes=function(r){let e=r.length>>>0;return this.uint32(e),e>0&&this._push(Xd,e,r),this},Xr.prototype.string=function(r){let e=globalThis.Buffer.byteLength(r);return this.uint32(e),e>0&&this._push(jd,e,r),this});function Xd(r,e,t){e.set(r,t)}function jd(r,e,t){r.length<40?js(r,e,t):e.utf8Write!=null?e.utf8Write(r,t):e.set(K(r),t)}function oi(){return new Xr}function Le(r,e){let t=oi();return e.encode(r,t,{lengthDelimited:!1}),t.finish()}function*Be(r,e,t){let n=Yr(r);yield*e.stream(n,void 0,"$",t)}var Vn={VARINT:0,BIT64:1,LENGTH_DELIMITED:2,START_GROUP:3,END_GROUP:4,BIT32:5};function Fn(r,e,t,n,s){return{name:r,type:e,encode:t,decode:n,stream:s}}function Ft(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 Fn("enum",Vn.VARINT,t,n,s)}function Re(r,e,t){return Fn("message",Vn.LENGTH_DELIMITED,r,e,t)}var zt=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 si;(function(r){r[r.RSA=0]="RSA",r[r.Ed25519=1]="Ed25519",r[r.secp256k1=2]="secp256k1",r[r.ECDSA=3]="ECDSA"})(si||(si={}));(function(r){r.codec=()=>Ft(si)})(ne||(ne={}));var Xe;(function(r){let e;r.codec=()=>(e==null&&(e=Re((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={},l=i==null?o.len:o.pos+i;for(;o.pos<l;){let u=o.uint32();switch(u>>>3){case 1:{c.Type=ne.codec().decode(o);break}case 2:{c.Data=o.bytes();break}default:{o.skipType(u&7);break}}}return c},function*(o,i,a,c={}){let l=i==null?o.len:o.pos+i;for(;o.pos<l;){let u=o.uint32();switch(u>>>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(u&7);break}}}})),e);function t(o){return Le(o,r.codec())}r.encode=t;function n(o,i){return Ce(o,r.codec(),i)}r.decode=n;function s(o,i){return Be(o,r.codec(),i)}r.stream=s})(Xe||(Xe={}));var ii;(function(r){let e;r.codec=()=>(e==null&&(e=Re((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={},l=i==null?o.len:o.pos+i;for(;o.pos<l;){let u=o.uint32();switch(u>>>3){case 1:{c.Type=ne.codec().decode(o);break}case 2:{c.Data=o.bytes();break}default:{o.skipType(u&7);break}}}return c},function*(o,i,a,c={}){let l=i==null?o.len:o.pos+i;for(;o.pos<l;){let u=o.uint32();switch(u>>>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(u&7);break}}}})),e);function t(o){return Le(o,r.codec())}r.encode=t;function n(o,i){return Ce(o,r.codec(),i)}r.decode=n;function s(o,i){return Be(o,r.codec(),i)}r.stream=s})(ii||(ii={}));function Qd(r){return r instanceof Uint8Array||ArrayBuffer.isView(r)&&r.constructor.name==="Uint8Array"&&"BYTES_PER_ELEMENT"in r&&r.BYTES_PER_ELEMENT===1}function ai(r,e,t=""){let n=Qd(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}`,l=i+"expected Uint8Array"+a+", got "+c;throw n?new RangeError(l):new TypeError(l)}return r}function ci(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 uu(r,e){ai(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 jr(...r){for(let e=0;e<r.length;e++)r[e].fill(0)}function zn(r){return new DataView(r.buffer,r.byteOffset,r.byteLength)}function qe(r,e){return r<<32-e|r>>>e}function lu(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)}var fu=r=>({oid:Uint8Array.from([6,9,96,134,72,1,101,3,4,2,r])});var Jr={};ve(Jr,{MAX_RSA_KEY_SIZE:()=>fi,generateRSAKeyPair:()=>bu,jwkToJWKKeyPair:()=>gu,jwkToPkcs1:()=>nh,jwkToPkix:()=>mi,jwkToRSAPrivateKey:()=>xi,pkcs1MessageToJwk:()=>hi,pkcs1MessageToRSAPrivateKey:()=>yi,pkcs1ToJwk:()=>rh,pkcs1ToRSAPrivateKey:()=>yu,pkixMessageToJwk:()=>pi,pkixMessageToRSAPublicKey:()=>gi,pkixToJwk:()=>oh,pkixToRSAPublicKey:()=>bi});function du(r,e,t){return r&e^~r&t}function hu(r,e,t){return r&e^r&t^e&t}var $n=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=zn(this.buffer)}update(e){ci(this),ai(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=zn(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){ci(this),uu(e,this),this.finished=!0;let{buffer:t,view:n,blockLen:s,isLE:o}=this,{pos:i}=this;t[i++]=128,jr(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=zn(e),c=this.outputLen;if(c%4)throw new Error("_sha2: outputLen must be aligned to 32bit");let l=c/4,u=this.get();if(l>u.length)throw new Error("_sha2: outputLen bigger than state");for(let f=0;f<l;f++)a.setUint32(4*f,u[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()}},ut=Uint32Array.from([1779033703,3144134277,1013904242,2773480762,1359893119,2600822924,528734635,1541459225]);var Jd=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]),_t=new Uint32Array(64),ui=class extends $n{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)_t[f]=e.getUint32(t,!1);for(let f=16;f<64;f++){let d=_t[f-15],p=_t[f-2],h=qe(d,7)^qe(d,18)^d>>>3,S=qe(p,17)^qe(p,19)^p>>>10;_t[f]=S+_t[f-7]+h+_t[f-16]|0}let{A:n,B:s,C:o,D:i,E:a,F:c,G:l,H:u}=this;for(let f=0;f<64;f++){let d=qe(a,6)^qe(a,11)^qe(a,25),p=u+d+du(a,c,l)+Jd[f]+_t[f]|0,S=(qe(n,2)^qe(n,13)^qe(n,22))+hu(n,s,o)|0;u=l,l=c,c=a,a=i+p|0,i=o,o=s,s=n,n=p+S|0}n=n+this.A|0,s=s+this.B|0,o=o+this.C|0,i=i+this.D|0,a=a+this.E|0,c=c+this.F|0,l=l+this.G|0,u=u+this.H|0,this.set(n,s,o,i,a,c,l,u)}roundClean(){jr(_t)}destroy(){this.destroyed=!0,this.set(0,0,0,0,0,0,0,0),jr(this.buffer)}},li=class extends ui{A=ut[0]|0;B=ut[1]|0;C=ut[2]|0;D=ut[3]|0;E=ut[4]|0;F=ut[5]|0;G=ut[6]|0;H=ut[7]|0;constructor(){super(32)}};var Gn=lu(()=>new li,fu(1));var gr=class{type="RSA";jwk;_raw;_multihash;constructor(e,t){this.jwk=e,this._multihash=t}get raw(){return this._raw==null&&(this._raw=Jr.jwkToPkix(this.jwk)),this._raw}toMultihash(){return this._multihash}toCID(){return le.createV1(114,this._multihash)}toString(){return te.encode(this.toMultihash().bytes).substring(1)}equals(e){return e==null||!(e.raw instanceof Uint8Array)?!1:fe(this.raw,e.raw)}verify(e,t,n){return mu(this.jwk,t,e,n)}},Qr=class{type="RSA";jwk;_raw;publicKey;constructor(e,t){this.jwk=e,this.publicKey=t}get raw(){return this._raw==null&&(this._raw=Jr.jwkToPkcs1(this.jwk)),this._raw}equals(e){return e==null||!(e.raw instanceof Uint8Array)?!1:fe(this.raw,e.raw)}sign(e,t){return pu(this.jwk,e,t)}};var fi=8192,di=18,eh=1062,th=Uint8Array.from([48,13,6,9,42,134,72,134,247,13,1,1,1,5,0]);function rh(r){let e=rt(r);return hi(e)}function hi(r){return{n:$(r[1],"base64url"),e:$(r[2],"base64url"),d:$(r[3],"base64url"),p:$(r[4],"base64url"),q:$(r[5],"base64url"),dp:$(r[6],"base64url"),dq:$(r[7],"base64url"),qi:$(r[8],"base64url"),kty:"RSA"}}function nh(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 ae("JWK was missing components");return bt([Te(Uint8Array.from([0])),Te(K(r.n,"base64url")),Te(K(r.e,"base64url")),Te(K(r.d,"base64url")),Te(K(r.p,"base64url")),Te(K(r.q,"base64url")),Te(K(r.dp,"base64url")),Te(K(r.dq,"base64url")),Te(K(r.qi,"base64url"))]).subarray()}function oh(r){let e=rt(r,{offset:0});return pi(e)}function pi(r){let e=rt(r[1],{offset:0});return{kty:"RSA",n:$(e[0],"base64url"),e:$(e[1],"base64url")}}function mi(r){if(r.n==null||r.e==null)throw new ae("JWK was missing components");return bt([th,In(bt([Te(K(r.n,"base64url")),Te(K(r.e,"base64url"))]))]).subarray()}function yu(r){let e=rt(r);return yi(e)}function yi(r){let e=hi(r);return xi(e)}function bi(r,e){if(r.byteLength>=eh)throw new er("Key size is too large");let t=rt(r,{offset:0});return gi(t,r,e)}function gi(r,e,t){let n=pi(r);if(t==null){let s=Gn(Xe.encode({Type:ne.RSA,Data:e}));t=$e(di,s)}return new gr(n,t)}function xi(r){if(wu(r)>fi)throw new ae("Key size is too large");let e=gu(r),t=Gn(Xe.encode({Type:ne.RSA,Data:mi(e.publicKey)})),n=$e(di,t);return new Qr(e.privateKey,new gr(e.publicKey,n))}async function bu(r){if(r>fi)throw new ae("Key size is too large");let e=await xu(r),t=Gn(Xe.encode({Type:ne.RSA,Data:mi(e.publicKey)})),n=$e(di,t);return new Qr(e.privateKey,new gr(e.publicKey,n))}function gu(r){if(r==null)throw new ae("Missing key parameter");return{privateKey:r,publicKey:{kty:r.kty,n:r.n,e:r.e}}}async function xu(r,e){let t=await Ue.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 sh(t,e);return{privateKey:n[0],publicKey:n[1]}}async function pu(r,e,t){let n=await Ue.get().subtle.importKey("jwk",r,{name:"RSASSA-PKCS1-v1_5",hash:{name:"SHA-256"}},!1,["sign"]);t?.signal?.throwIfAborted();let s=await Ue.get().subtle.sign({name:"RSASSA-PKCS1-v1_5"},n,e instanceof Uint8Array?e:e.subarray());return t?.signal?.throwIfAborted(),new Uint8Array(s,0,s.byteLength)}async function mu(r,e,t,n){let s=await Ue.get().subtle.importKey("jwk",r,{name:"RSASSA-PKCS1-v1_5",hash:{name:"SHA-256"}},!1,["verify"]);n?.signal?.throwIfAborted();let o=await Ue.get().subtle.verify({name:"RSASSA-PKCS1-v1_5"},s,e,t instanceof Uint8Array?t:t.subarray());return n?.signal?.throwIfAborted(),o}async function sh(r,e){if(r.privateKey==null||r.publicKey==null)throw new ae("Private and public key are required");let t=await Promise.all([Ue.get().subtle.exportKey("jwk",r.privateKey),Ue.get().subtle.exportKey("jwk",r.publicKey)]);return e?.signal?.throwIfAborted(),t}function wu(r){if(r.kty!=="RSA")throw new ae("invalid key type");if(r.n==null)throw new ae("invalid key modulus");return K(r.n,"base64url").length*8}var Wn=class{oHash;iHash;blockLen;outputLen;finished=!1;destroyed=!1;constructor(e,t){if(Dn(e),k(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),ot(s)}update(e){return ur(this),this.iHash.update(e),this}digestInto(e){ur(this),k(e,this.outputLen,"output"),this.finished=!0,this.iHash.digestInto(e),this.oHash.update(e),this.oHash.digestInto(e),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()}},wi=(r,e,t)=>new Wn(r,e).update(t).digest();wi.create=(r,e)=>new Wn(r,e);var Eu=(r,e)=>(r+(r>=0?e:-e)/Su)/e;function ih(r,e,t){let[[n,s],[o,i]]=e,a=Eu(i*r,t),c=Eu(-s*r,t),l=r-a*n-c*o,u=-a*s-c*i,f=l<lt,d=u<lt;f&&(l=-l),d&&(u=-u);let p=Fr(Math.ceil(Cs(t)/2))+xr;if(l<lt||l>=p||u<lt||u>=p)throw new Error("splitScalar (endomorphism): failed, k="+r);return{k1neg:f,k1:l,k2neg:d,k2:u}}function Si(r){if(!["compact","recovered","der"].includes(r))throw new Error('Signature format must be "compact", "recovered", or "der"');return r}function Ei(r,e){let t={};for(let n of Object.keys(e))t[n]=r[n]===void 0?e[n]:r[n];return ct(t.lowS,"lowS"),ct(t.prehash,"prehash"),t.format!==void 0&&Si(t.format),t}var vi=class extends Error{constructor(e=""){super(e)}},At={Err:vi,_tlv:{encode:(r,e)=>{let{Err:t}=At;if(r<0||r>256)throw new t("tlv.encode: wrong tag");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}=At,n=0;if(r<0||r>256)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 l=e.subarray(n,n+c);if(l.length!==c)throw new t("tlv.decode: length bytes not complete");if(l[0]===0)throw new t("tlv.decode(long): zero leftmost byte");for(let u of l)i=i<<8|u;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}=At;if(r<lt)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}=At;if(r[0]&128)throw new e("invalid signature integer: negative");if(r[0]===0&&!(r[1]&128))throw new e("invalid signature integer: unnecessary leading zero");return fr(r)}},toSig(r){let{Err:e,_int:t,_tlv:n}=At,s=k(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:l,l:u}=n.decode(2,c);if(u.length)throw new e("invalid signature: left bytes after parsing");return{r:t.decode(a),s:t.decode(l)}},hexFromSig(r){let{_tlv:e,_int:t}=At,n=e.encode(2,t.encode(r.r)),s=e.encode(2,t.encode(r.s)),o=n+s;return e.encode(48,o)}},lt=BigInt(0),xr=BigInt(1),Su=BigInt(2),Yn=BigInt(3),ah=BigInt(4);function vu(r,e={}){let t=Pn("weierstrass",r,e),{Fp:n,Fn:s}=t,o=t.CURVE,{h:i,n:a}=o;Et(e,{},{allowInfinityPoint:"boolean",clearCofactor:"function",isTorsionFree:"function",fromBytes:"function",toBytes:"function",endo:"object"});let{endo:c}=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=Au(n,s);function u(){if(!n.isOdd)throw new Error("compression is not supported: Field does not have .isOdd()")}function f(L,b,g){let{x:m,y:_}=b.toAffine(),I=n.toBytes(m);if(ct(g,"isCompressed"),g){u();let C=!n.isOdd(_);return Ie(_u(C),I)}else return Ie(Uint8Array.of(4),I,n.toBytes(_))}function d(L){k(L,void 0,"Point");let{publicKey:b,publicKeyUncompressed:g}=l,m=L.length,_=L[0],I=L.subarray(1);if(m===b&&(_===2||_===3)){let C=n.fromBytes(I);if(!n.isValid(C))throw new Error("bad point: is not on curve, wrong x");let B=S(C),D;try{D=n.sqrt(B)}catch(oe){let Q=oe instanceof Error?": "+oe.message:"";throw new Error("bad point: is not on curve, sqrt error"+Q)}u();let O=n.isOdd(D);return(_&1)===1!==O&&(D=n.neg(D)),{x:C,y:D}}else if(m===g&&_===4){let C=n.BYTES,B=n.fromBytes(I.subarray(0,C)),D=n.fromBytes(I.subarray(C,C*2));if(!x(B,D))throw new Error("bad point: is not on curve");return{x:B,y:D}}else throw new Error(`bad point: got length ${m}, expected compressed=${b} or uncompressed=${g}`)}let p=e.toBytes||f,h=e.fromBytes||d;function S(L){let b=n.sqr(L),g=n.mul(b,L);return n.add(n.add(g,n.mul(L,o.a)),o.b)}function x(L,b){let g=n.sqr(b),m=S(L);return n.eql(g,m)}if(!x(o.Gx,o.Gy))throw new Error("bad curve params: generator point");let y=n.mul(n.pow(o.a,Yn),ah),A=n.mul(n.sqr(o.b),BigInt(27));if(n.is0(n.add(y,A)))throw new Error("bad curve params: a or b");function w(L,b,g=!1){if(!n.isValid(b)||g&&n.is0(b))throw new Error(`bad point coordinate ${L}`);return b}function T(L){if(!(L instanceof E))throw new Error("Weierstrass Point expected")}function P(L){if(!c||!c.basises)throw new Error("no endo");return ih(L,c.basises,s.ORDER)}let M=dr((L,b)=>{let{X:g,Y:m,Z:_}=L;if(n.eql(_,n.ONE))return{x:g,y:m};let I=L.is0();b==null&&(b=I?n.ONE:n.inv(_));let C=n.mul(g,b),B=n.mul(m,b),D=n.mul(_,b);if(I)return{x:n.ZERO,y:n.ZERO};if(!n.eql(D,n.ONE))throw new Error("invZ was invalid");return{x:C,y:B}}),q=dr(L=>{if(L.is0()){if(e.allowInfinityPoint&&!n.is0(L.Y))return;throw new Error("bad point: ZERO")}let{x:b,y:g}=L.toAffine();if(!n.isValid(b)||!n.isValid(g))throw new Error("bad point: x or y not field elements");if(!x(b,g))throw new Error("bad point: equation left != right");if(!L.isTorsionFree())throw new Error("bad point: not in prime-order subgroup");return!0});function v(L,b,g,m,_){return g=new E(n.mul(g.X,L),g.Y,g.Z),b=$r(m,b),g=$r(_,g),b.add(g)}class E{static BASE=new E(o.Gx,o.Gy,n.ONE);static ZERO=new E(n.ZERO,n.ONE,n.ZERO);static Fp=n;static Fn=s;X;Y;Z;constructor(b,g,m){this.X=w("x",b),this.Y=w("y",g,!0),this.Z=w("z",m),Object.freeze(this)}static CURVE(){return o}static fromAffine(b){let{x:g,y:m}=b||{};if(!b||!n.isValid(g)||!n.isValid(m))throw new Error("invalid affine point");if(b instanceof E)throw new Error("projective point not allowed");return n.is0(g)&&n.is0(m)?E.ZERO:new E(g,m,n.ONE)}static fromBytes(b){let g=E.fromAffine(h(k(b,void 0,"point")));return g.assertValidity(),g}static fromHex(b){return E.fromBytes(it(b))}get x(){return this.toAffine().x}get y(){return this.toAffine().y}precompute(b=8,g=!0){return V.createCache(this,b),g||this.multiply(Yn),this}assertValidity(){q(this)}hasEvenY(){let{y:b}=this.toAffine();if(!n.isOdd)throw new Error("Field doesn't support isOdd");return!n.isOdd(b)}equals(b){T(b);let{X:g,Y:m,Z:_}=this,{X:I,Y:C,Z:B}=b,D=n.eql(n.mul(g,B),n.mul(I,_)),O=n.eql(n.mul(m,B),n.mul(C,_));return D&&O}negate(){return new E(this.X,n.neg(this.Y),this.Z)}double(){let{a:b,b:g}=o,m=n.mul(g,Yn),{X:_,Y:I,Z:C}=this,B=n.ZERO,D=n.ZERO,O=n.ZERO,U=n.mul(_,_),oe=n.mul(I,I),Q=n.mul(C,C),W=n.mul(_,I);return W=n.add(W,W),O=n.mul(_,C),O=n.add(O,O),B=n.mul(b,O),D=n.mul(m,Q),D=n.add(B,D),B=n.sub(oe,D),D=n.add(oe,D),D=n.mul(B,D),B=n.mul(W,B),O=n.mul(m,O),Q=n.mul(b,Q),W=n.sub(U,Q),W=n.mul(b,W),W=n.add(W,O),O=n.add(U,U),U=n.add(O,U),U=n.add(U,Q),U=n.mul(U,W),D=n.add(D,U),Q=n.mul(I,C),Q=n.add(Q,Q),U=n.mul(Q,W),B=n.sub(B,U),O=n.mul(Q,oe),O=n.add(O,O),O=n.add(O,O),new E(B,D,O)}add(b){T(b);let{X:g,Y:m,Z:_}=this,{X:I,Y:C,Z:B}=b,D=n.ZERO,O=n.ZERO,U=n.ZERO,oe=o.a,Q=n.mul(o.b,Yn),W=n.mul(g,I),se=n.mul(m,C),me=n.mul(_,B),ze=n.add(g,m),ie=n.add(I,C);ze=n.mul(ze,ie),ie=n.add(W,se),ze=n.sub(ze,ie),ie=n.add(g,_);let ge=n.add(I,B);return ie=n.mul(ie,ge),ge=n.add(W,me),ie=n.sub(ie,ge),ge=n.add(m,_),D=n.add(C,B),ge=n.mul(ge,D),D=n.add(se,me),ge=n.sub(ge,D),U=n.mul(oe,ie),D=n.mul(Q,me),U=n.add(D,U),D=n.sub(se,U),U=n.add(se,U),O=n.mul(D,U),se=n.add(W,W),se=n.add(se,W),me=n.mul(oe,me),ie=n.mul(Q,ie),se=n.add(se,me),me=n.sub(W,me),me=n.mul(oe,me),ie=n.add(ie,me),W=n.mul(se,ie),O=n.add(O,W),W=n.mul(ge,ie),D=n.mul(ze,D),D=n.sub(D,W),W=n.mul(ze,se),U=n.mul(ge,U),U=n.add(U,W),new E(D,O,U)}subtract(b){return this.add(b.negate())}is0(){return this.equals(E.ZERO)}multiply(b){let{endo:g}=e;if(!s.isValidNot0(b))throw new Error("invalid scalar: out of range");let m,_,I=C=>V.cached(this,C,B=>Ht(E,B));if(g){let{k1neg:C,k1:B,k2neg:D,k2:O}=P(b),{p:U,f:oe}=I(B),{p:Q,f:W}=I(O);_=oe.add(W),m=v(g.beta,U,Q,C,D)}else{let{p:C,f:B}=I(b);m=C,_=B}return Ht(E,[m,_])[0]}multiplyUnsafe(b){let{endo:g}=e,m=this;if(!s.isValid(b))throw new Error("invalid scalar: out of range");if(b===lt||m.is0())return E.ZERO;if(b===xr)return m;if(V.hasCache(this))return this.multiply(b);if(g){let{k1neg:_,k1:I,k2neg:C,k2:B}=P(b),{p1:D,p2:O}=$c(E,m,I,B);return v(g.beta,D,O,_,C)}else return V.unsafe(m,b)}toAffine(b){return M(this,b)}isTorsionFree(){let{isTorsionFree:b}=e;return i===xr?!0:b?b(E,this):V.unsafe(this,a).is0()}clearCofactor(){let{clearCofactor:b}=e;return i===xr?this:b?b(E,this):this.multiplyUnsafe(i)}isSmallOrder(){return this.multiplyUnsafe(i).is0()}toBytes(b=!0){return ct(b,"isCompressed"),this.assertValidity(),p(E,this,b)}toHex(b=!0){return st(this.toBytes(b))}toString(){return`<Point ${this.is0()?"ZERO":this.toHex()}>`}}let N=s.BITS,V=new mr(E,e.endo?Math.ceil(N/2):N);return E.BASE.precompute(8),E}function _u(r){return Uint8Array.of(r?2:3)}function Au(r,e){return{secretKey:e.BYTES,publicKey:1+r.BYTES,publicKeyUncompressed:1+2*r.BYTES,publicKeyHasPrefix:!0,signature:2*e.BYTES}}function ch(r,e={}){let{Fn:t}=r,n=e.randomBytes||lr,s=Object.assign(Au(r.Fp,t),{seed:Os(t.ORDER)});function o(p){try{let h=t.fromBytes(p);return t.isValidNot0(h)}catch{return!1}}function i(p,h){let{publicKey:S,publicKeyUncompressed:x}=s;try{let y=p.length;return h===!0&&y!==S||h===!1&&y!==x?!1:!!r.fromBytes(p)}catch{return!1}}function a(p=n(s.seed)){return Ps(k(p,s.seed,"seed"),t.ORDER)}function c(p,h=!0){return r.BASE.multiply(t.fromBytes(p)).toBytes(h)}function l(p){let{secretKey:h,publicKey:S,publicKeyUncompressed:x}=s;if(!Pt(p)||"_lengths"in t&&t._lengths||h===S)return;let y=k(p,void 0,"key").length;return y===S||y===x}function u(p,h,S=!0){if(l(p)===!0)throw new Error("first arg must be private key");if(l(h)===!1)throw new Error("second arg must be public key");let x=t.fromBytes(p);return r.fromBytes(h).multiply(x).toBytes(S)}let f={isValidSecretKey:o,isValidPublicKey:i,randomSecretKey:a},d=Nn(a,c);return Object.freeze({getPublicKey:c,getSharedSecret:u,keygen:d,Point:r,utils:f,lengths:s})}function Tu(r,e,t={}){Dn(e),Et(t,{},{hmac:"function",lowS:"boolean",randomBytes:"function",bits2int:"function",bits2int_modN:"function"}),t=Object.assign({},t);let n=t.randomBytes||lr,s=t.hmac||((g,m)=>wi(e,g,m)),{Fp:o,Fn:i}=r,{ORDER:a,BITS:c}=i,{keygen:l,getPublicKey:u,getSharedSecret:f,utils:d,lengths:p}=ch(r,t),h={prehash:!0,lowS:typeof t.lowS=="boolean"?t.lowS:!0,format:"compact",extraEntropy:!1},S=a*Su<o.ORDER;function x(g){let m=a>>xr;return g>m}function y(g,m){if(!i.isValidNot0(m))throw new Error(`invalid signature ${g}: out of range 1..Point.Fn.ORDER`);return m}function A(){if(S)throw new Error('"recovered" sig type is not supported for cofactor >2 curves')}function w(g,m){Si(m);let _=p.signature,I=m==="compact"?_:m==="recovered"?_+1:void 0;return k(g,I)}class T{r;s;recovery;constructor(m,_,I){if(this.r=y("r",m),this.s=y("s",_),I!=null){if(A(),![0,1,2,3].includes(I))throw new Error("invalid recovery id");this.recovery=I}Object.freeze(this)}static fromBytes(m,_=h.format){w(m,_);let I;if(_==="der"){let{r:O,s:U}=At.toSig(k(m));return new T(O,U)}_==="recovered"&&(I=m[0],_="compact",m=m.subarray(1));let C=p.signature/2,B=m.subarray(0,C),D=m.subarray(C,C*2);return new T(i.fromBytes(B),i.fromBytes(D),I)}static fromHex(m,_){return this.fromBytes(it(m),_)}assertRecovery(){let{recovery:m}=this;if(m==null)throw new Error("invalid recovery id: must be present");return m}addRecoveryBit(m){return new T(this.r,this.s,m)}recoverPublicKey(m){let{r:_,s:I}=this,C=this.assertRecovery(),B=C===2||C===3?_+a:_;if(!o.isValid(B))throw new Error("invalid recovery id: sig.r+curve.n != R.x");let D=o.toBytes(B),O=r.fromBytes(Ie(_u((C&1)===0),D)),U=i.inv(B),oe=M(k(m,void 0,"msgHash")),Q=i.create(-oe*U),W=i.create(I*U),se=r.BASE.multiplyUnsafe(Q).add(O.multiplyUnsafe(W));if(se.is0())throw new Error("invalid recovery: point at infinify");return se.assertValidity(),se}hasHighS(){return x(this.s)}toBytes(m=h.format){if(Si(m),m==="der")return it(At.hexFromSig(this));let{r:_,s:I}=this,C=i.toBytes(_),B=i.toBytes(I);return m==="recovered"?(A(),Ie(Uint8Array.of(this.assertRecovery()),C,B)):Ie(C,B)}toHex(m){return st(this.toBytes(m))}}let P=t.bits2int||function(m){if(m.length>8192)throw new Error("input is too large");let _=fr(m),I=m.length*8-c;return I>0?_>>BigInt(I):_},M=t.bits2int_modN||function(m){return i.create(P(m))},q=Fr(c);function v(g){return Vr("num < 2^"+c,g,lt,q),i.toBytes(g)}function E(g,m){return k(g,void 0,"message"),m?k(e(g),void 0,"prehashed message"):g}function N(g,m,_){let{lowS:I,prehash:C,extraEntropy:B}=Ei(_,h);g=E(g,C);let D=M(g),O=i.fromBytes(m);if(!i.isValidNot0(O))throw new Error("invalid private key");let U=[v(O),v(D)];if(B!=null&&B!==!1){let se=B===!0?n(p.secretKey):B;U.push(k(se,void 0,"extraEntropy"))}let oe=Ie(...U),Q=D;function W(se){let me=P(se);if(!i.isValidNot0(me))return;let ze=i.inv(me),ie=r.BASE.multiply(me).toAffine(),ge=i.create(ie.x);if(ge===lt)return;let mn=i.create(ze*i.create(Q+ge*O));if(mn===lt)return;let Ia=(ie.x===ge?0:2)|Number(ie.y&xr),Da=mn;return I&&x(mn)&&(Da=i.neg(mn),Ia^=1),new T(ge,Da,S?void 0:Ia)}return{seed:oe,k2sig:W}}function V(g,m,_={}){let{seed:I,k2sig:C}=N(g,m,_);return Dc(e.outputLen,i.BYTES,s)(I,C).toBytes(_.format)}function L(g,m,_,I={}){let{lowS:C,prehash:B,format:D}=Ei(I,h);if(_=k(_,void 0,"publicKey"),m=E(m,B),!Pt(g)){let O=g instanceof T?", use sig.toBytes()":"";throw new Error("verify expects Uint8Array signature"+O)}w(g,D);try{let O=T.fromBytes(g,D),U=r.fromBytes(_);if(C&&O.hasHighS())return!1;let{r:oe,s:Q}=O,W=M(m),se=i.inv(Q),me=i.create(W*se),ze=i.create(oe*se),ie=r.BASE.multiplyUnsafe(me).add(U.multiplyUnsafe(ze));return ie.is0()?!1:i.create(ie.x)===oe}catch{return!1}}function b(g,m,_={}){let{prehash:I}=Ei(_,h);return m=E(m,I),T.fromBytes(g,"recovered").recoverPublicKey(m).toBytes()}return Object.freeze({keygen:l,getPublicKey:u,getSharedSecret:f,utils:d,lengths:p,Point:r,sign:V,verify:L,recoverPublicKey:b,Signature:T,hash:e})}var Ai={p:BigInt("0xfffffffffffffffffffffffffffffffffffffffffffffffffffffffefffffc2f"),n:BigInt("0xfffffffffffffffffffffffffffffffebaaedce6af48a03bbfd25e8cd0364141"),h:BigInt(1),a:BigInt(0),b:BigInt(7),Gx:BigInt("0x79be667ef9dcbbac55a06295ce870b07029bfcdb2dce28d959f2815b16f81798"),Gy:BigInt("0x483ada7726a3c4655da4fbfc0e1108a8fd17b448a68554199c47d08ffb10d4b8")},uh={beta:BigInt("0x7ae96a2b657c07106e64479eac3434e99cf0497512f58995c1396c28719501ee"),basises:[[BigInt("0x3086d221a7d46bcde86c90e49284eb15"),-BigInt("0xe4437ed6010e88286f547fa90abfe4c3")],[BigInt("0x114ca50f7a8e2f3f657c1108d9d44cfd8"),BigInt("0x3086d221a7d46bcde86c90e49284eb15")]]};var Iu=BigInt(2);function lh(r){let e=Ai.p,t=BigInt(3),n=BigInt(6),s=BigInt(11),o=BigInt(22),i=BigInt(23),a=BigInt(44),c=BigInt(88),l=r*r*r%e,u=l*l*r%e,f=ee(u,t,e)*u%e,d=ee(f,t,e)*u%e,p=ee(d,Iu,e)*l%e,h=ee(p,s,e)*p%e,S=ee(h,o,e)*h%e,x=ee(S,a,e)*S%e,y=ee(x,c,e)*x%e,A=ee(y,a,e)*S%e,w=ee(A,t,e)*u%e,T=ee(w,i,e)*h%e,P=ee(T,n,e)*l%e,M=ee(P,Iu,e);if(!_i.eql(_i.sqr(M),r))throw new Error("Cannot find square root");return M}var _i=hr(Ai.p,{sqrt:lh}),fh=vu(Ai,{Fp:_i,endo:uh}),wr=Tu(fh,_c);function Du(r,e,t,n){let s=ar.digest(t instanceof Uint8Array?t:t.subarray());if(Mn(s))return s.then(({digest:o})=>(n?.signal?.throwIfAborted(),wr.verify(e,o,r,{prehash:!1,format:"der"}))).catch(o=>{throw o.name==="AbortError"?o:new Gr(String(o))});try{return n?.signal?.throwIfAborted(),wr.verify(e,s.digest,r,{prehash:!1,format:"der"})}catch(o){throw new Gr(String(o))}}var Zn=class{type="secp256k1";raw;_key;constructor(e){this._key=Lu(e),this.raw=Cu(this._key)}toMultihash(){return Me.digest(We(this))}toCID(){return le.createV1(114,this.toMultihash())}toString(){return te.encode(this.toMultihash().bytes).substring(1)}equals(e){return e==null||!(e.raw instanceof Uint8Array)?!1:fe(this.raw,e.raw)}verify(e,t,n){return Du(this._key,t,e,n)}};function Ti(r){return new Zn(r)}function Cu(r){return wr.Point.fromBytes(r).toBytes()}function Lu(r){try{return wr.Point.fromBytes(r),r}catch(e){throw new er(String(e))}}function Bu(r,e){let{Type:t,Data:n}=Xe.decode(r),s=n??new Uint8Array;switch(t){case ne.RSA:return bi(s,e);case ne.Ed25519:return Vs(s);case ne.secp256k1:return Ti(s);case ne.ECDSA:return bs(s);default:throw new tr}}function Ru(r){let{Type:e,Data:t}=Xe.decode(r.digest),n=t??new Uint8Array;switch(e){case ne.Ed25519:return Vs(n);case ne.secp256k1:return Ti(n);case ne.ECDSA:return bs(n);default:throw new tr}}function We(r){return Xe.encode({Type:ne[r.type],Data:r.raw})}var Ou=Symbol.for("nodejs.util.inspect.custom"),dh=114,en=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()})`}[Fo]=!0;toString(){return this.string==null&&(this.string=te.encode(this.multihash.bytes).slice(1)),this.string}toMultihash(){return this.multihash}toCID(){return le.createV1(dh,this.multihash)}toJSON(){return this.toString()}equals(e){if(e==null)return!1;if(e instanceof Uint8Array)return fe(this.multihash.bytes,e);if(typeof e=="string")return this.toString()===e;if(e?.toMultihash()?.bytes!=null)return fe(this.multihash.bytes,e.toMultihash().bytes);throw new Error("not valid Id")}[Ou](){return`PeerId(${this.toString()})`}},Xn=class extends en{type="RSA";publicKey;constructor(e){super({...e,type:"RSA"}),this.publicKey=e.publicKey}},jn=class extends en{type="Ed25519";publicKey;constructor(e){super({...e,type:"Ed25519"}),this.publicKey=e.publicKey}},Qn=class extends en{type="secp256k1";publicKey;constructor(e){super({...e,type:"secp256k1"}),this.publicKey=e.publicKey}},hh=2336,tn=class{type="url";multihash;publicKey;url;constructor(e){this.url=e.toString(),this.multihash=Me.digest(K(this.url))}[Ou](){return`PeerId(${this.url})`}[Fo]=!0;toString(){return this.toCID().toString()}toMultihash(){return this.multihash}toCID(){return le.createV1(hh,this.toMultihash())}toJSON(){return this.toString()}equals(e){return e==null?!1:(e instanceof Uint8Array&&(e=$(e)),e.toString()===this.toString())}};var ph=114,Pu=2336;function Ii(r,e){let t;if(r.charAt(0)==="1"||r.charAt(0)==="Q")t=Ge(te.decode(`z${r}`));else{if(r.startsWith("k51qzi5uqu5")||r.startsWith("kzwfwjn5ji4")||r.startsWith("k2k4r8")||r.startsWith("bafz"))return mh(le.parse(r));if(e==null)throw new ae('Please pass a multibase decoder for strings that do not start with "1" or "Q"');t=Ge(e.decode(r))}return Er(t)}function Er(r){if(bh(r))return new Xn({multihash:r});if(yh(r))try{let e=Ru(r);if(e.type==="Ed25519")return new jn({multihash:r,publicKey:e});if(e.type==="secp256k1")return new Qn({multihash:r,publicKey:e})}catch{let t=$(r.digest);return new tn(new URL(t))}throw new gn("Supplied PeerID Multihash is invalid")}function mh(r){if(r?.multihash==null||r.version==null||r.version===1&&r.code!==ph&&r.code!==Pu)throw new bn("Supplied PeerID CID is invalid");if(r.code===Pu){let e=$(r.multihash.digest);return new tn(new URL(e))}return Er(r.multihash)}function yh(r){return r.code===Me.code}function bh(r){return r.code===ar.code}var rn;(function(r){let e;r.codec=()=>(e==null&&(e=Re((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:re(0),payloadType:re(0),payload:re(0),signature:re(0)},l=i==null?o.len:o.pos+i;for(;o.pos<l;){let u=o.uint32();switch(u>>>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(u&7);break}}}return c},function*(o,i,a,c={}){let l=i==null?o.len:o.pos+i;for(;o.pos<l;){let u=o.uint32();switch(u>>>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(u&7);break}}}})),e);function t(o){return Le(o,r.codec())}r.encode=t;function n(o,i){return Ce(o,r.codec(),i)}r.decode=n;function s(o,i){return Be(o,r.codec(),i)}r.stream=s})(rn||(rn={}));var Jn=class extends Error{constructor(e="Invalid signature"){super(e),this.name="InvalidSignatureError"}};var nn=class r{static createFromProtobuf=e=>{let t=rn.decode(e),n=Bu(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=Nu(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 Jn("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=rn.encode({publicKey:We(this.publicKey),payloadType:this.payloadType,payload:this.payload.subarray(),signature:this.signature})),this.marshaled}equals(e){return e==null?!1:fe(this.marshal(),e.marshal())}async validate(e,t){let n=Nu(e,this.payloadType,this.payload);return this.publicKey.verify(n.subarray(),this.signature,t)}},Nu=(r,e,t)=>{let n=K(r),s=br(n.byteLength),o=br(e.length),i=br(t.length);return new J(s,n,o,e,i,t)};var be=class extends Error{static name="InvalidMultiaddrError";name="InvalidMultiaddrError"},ft=class extends Error{static name="ValidationError";name="ValidationError"},eo=class extends Error{static name="InvalidParametersError";name="InvalidParametersError"},to=class extends Error{static name="UnknownProtocolError";name="UnknownProtocolError"};var ro=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",l=2**(8*s)-1;for(;;){let u=this.readAtomically(()=>{let f=this.readChar();if(f===void 0)return;let d=Number.parseInt(f,e);if(!Number.isNaN(d))return d});if(u===void 0)break;if(o*=e,o+=u,o>l||(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 gh=45,xh=15,no=new ro;function Uu(r){if(!(r.length>xh))return no.new(r).parseWith(()=>no.readIPv4Addr())}function ku(r){if(r.includes("%")&&(r=r.split("%")[0]),!(r.length>gh))return no.new(r).parseWith(()=>no.readIPv6Addr())}function oo(r){return!!Uu(r)}function Mu(r){return!!ku(r)}function Ci(r){return e=>$(e,r)}function Li(r){return e=>K(e,r)}function Sr(r){return new DataView(r.buffer).getUint16(r.byteOffset).toString()}function $t(r){let e=new ArrayBuffer(2);return new DataView(e).setUint16(0,typeof r=="string"?parseInt(r):r),new Uint8Array(e)}function Ku(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=$t(n);return tt([t,s],t.length+s.length)}function Hu(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=yt.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=$t(n);return tt([t,s],t.length+s.length)}function Bi(r){let e=r.subarray(0,r.length-2),t=r.subarray(r.length-2),n=$(e,"base32"),s=Sr(t);return`${n}:${s}`}var Ri=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 be("Invalid byte value in IP address");e[n]=s}),e},qu=function(r){let e=0;r=r.toString().trim();let t=r.split(":",8),n;for(n=0;n<t.length;n++){let o=oo(t[n]),i;o&&(i=Ri(t[n]),t[n]=$(i.subarray(0,2),"base16")),i!=null&&++n<8&&t.splice(n,0,$(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 be("Invalid byte value in IP address");s[e++]=o>>8&255,s[e++]=o&255}return s},Vu=function(r){if(r.byteLength!==4)throw new be("IPv4 address was incorrect length");let e=[];for(let t=0;t<r.byteLength;t++)e.push(r[t]);return e.join(".")},Fu=function(r){if(r.byteLength!==16)throw new be("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 be(`Invalid IPv6 address "${t}"`)}};function zu(r){try{let e=new URL(`http://[${r}]`);return e.hostname.substring(1,e.hostname.length-1)}catch{throw new be(`Invalid IPv6 address "${r}"`)}}var Di=Object.values(Nr).map(r=>r.decoder),wh=(function(){let r=Di[0].or(Di[1]);return Di.slice(2).forEach(e=>r=r.or(e)),r})();function $u(r){return wh.decode(r)}function Gu(r){return e=>r.encoder.encode(e)}function Eh(r){if(parseInt(r).toString()!==r)throw new ft("Value must be an integer")}function Sh(r){if(r<0)throw new ft("Value must be a positive integer, or zero")}function vh(r){return e=>{if(e>r)throw new ft(`Value must be smaller than or equal to ${r}`)}}function _h(...r){return e=>{for(let t of r)t(e)}}var on=_h(Eh,Sh,vh(65535));var pe=-1,Oi=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 to(`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)}))}},ht=new Oi,Mh=[{code:4,name:"ip4",size:32,valueToBytes:Ri,bytesToValue:Vu,validate:r=>{if(!oo(r))throw new ft(`Invalid IPv4 address "${r}"`)}},{code:6,name:"tcp",size:16,valueToBytes:$t,bytesToValue:Sr,validate:on},{code:273,name:"udp",size:16,valueToBytes:$t,bytesToValue:Sr,validate:on},{code:33,name:"dccp",size:16,valueToBytes:$t,bytesToValue:Sr,validate:on},{code:41,name:"ip6",size:128,valueToBytes:qu,bytesToValue:Fu,stringToValue:zu,validate:r=>{if(!Mu(r))throw new ft(`Invalid IPv6 address "${r}"`)}},{code:42,name:"ip6zone",size:pe},{code:43,name:"ipcidr",size:8,bytesToValue:Ci("base10"),valueToBytes:Li("base10")},{code:53,name:"dns",size:pe},{code:54,name:"dns4",size:pe},{code:55,name:"dns6",size:pe},{code:56,name:"dnsaddr",size:pe},{code:132,name:"sctp",size:16,valueToBytes:$t,bytesToValue:Sr,validate:on},{code:301,name:"udt"},{code:302,name:"utp"},{code:400,name:"unix",size:pe,stringToValue:r=>decodeURIComponent(r),valueToString:r=>encodeURIComponent(r)},{code:421,name:"p2p",aliases:["ipfs"],size:pe,bytesToValue:Ci("base58btc"),valueToBytes:r=>r.startsWith("Q")||r.startsWith("1")?Li("base58btc")(r):le.parse(r).multihash.bytes},{code:444,name:"onion",size:96,bytesToValue:Bi,valueToBytes:Ku},{code:445,name:"onion3",size:296,bytesToValue:Bi,valueToBytes:Hu},{code:446,name:"garlic64",size:pe},{code:447,name:"garlic32",size:pe},{code:448,name:"tls"},{code:449,name:"sni",size:pe},{code:454,name:"noise"},{code:460,name:"quic"},{code:461,name:"quic-v1"},{code:465,name:"webtransport"},{code:466,name:"certhash",size:pe,bytesToValue:Gu(os),valueToBytes:$u},{code:480,name:"http"},{code:481,name:"http-path",size:pe,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:pe}];Mh.forEach(r=>{ht.addProtocol(r)});function Wu(r){let e=[],t=0;for(;t<r.length;){let n=Wr(r,t),s=ht.getProtocol(n),o=De(n),i=Kh(s,r,t+o),a=0;i>0&&s.size===pe&&(a=De(i));let c=o+a+i,l={code:n,name:s.name,bytes:r.subarray(t,t+c)};if(i>0){let u=t+o+a,f=r.subarray(u,u+i);l.value=s.bytesToValue?.(f)??$(f)}e.push(l),t+=c}return e}function Yu(r){let e=0,t=[];for(let n of r){if(n.bytes==null){let s=ht.getProtocol(n.code),o=De(n.code),i,a=0,c=0;n.value!=null&&(i=s.valueToBytes?.(n.value)??K(n.value),a=i.byteLength,s.size===pe&&(c=De(a)));let l=new Uint8Array(o+c+a),u=0;yr(n.code,l,u),u+=o,i!=null&&(s.size===pe&&(yr(a,l,u),u+=c),l.set(i,u)),n.bytes=l}t.push(n.bytes),e+=n.bytes.byteLength}return tt(t,e)}function Zu(r){if(r.charAt(0)!=="/")throw new be('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=ht.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 be(`Component ${s} was missing value`);t="value"}else if(t==="value"){let l={code:c.code,name:c.name};if(c.size!=null&&c.size!==0){if(n==="")throw new be(`Component ${s} was missing value`);l.value=c.stringToValue?.(n)??n}e.push(l),n="",s="",t="protocol"}}}if(s!==""&&n!=="")throw new be("Incomplete multiaddr");return e}function Xu(r){return`/${r.flatMap(e=>{if(e.value==null)return e.name;let t=ht.getProtocol(e.code);if(t==null)throw new be(`Unknown protocol code ${e.code}`);return[e.name,t.valueToString?.(e.value)??e.value]}).join("/")}`}function Kh(r,e,t){return r.size==null||r.size===0?0:r.size>0?r.size/8:Wr(e,t)}var Hh=Symbol.for("nodejs.util.inspect.custom"),Xi=Symbol.for("@multiformats/multiaddr");function qh(r){if(r==null&&(r="/"),ju(r))return r.getComponents();if(r instanceof Uint8Array)return Wu(r);if(typeof r=="string")return r=r.replace(/\/(\/)+/,"/").replace(/(\/)+$/,""),r===""&&(r="/"),Zu(r);if(Array.isArray(r))return r;throw new be("Must be a string, Uint8Array, Component[], or another Multiaddr")}var uo=class r{[Xi]=!0;#e;#t;#r;constructor(e="/",t={}){this.#e=qh(e),t.validate!==!1&&Vh(this)}get bytes(){return this.#r==null&&(this.#r=Yu(this.#e)),this.#r}toString(){return this.#t==null&&(this.#t=Xu(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 eo(`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 fe(this.bytes,e.bytes)}[Hh](){return`Multiaddr(${this.toString()})`}};function Vh(r){r.getComponents().forEach(e=>{let t=ht.getProtocol(e.code);e.value!=null&&t.validate?.(e.value)})}function ju(r){return!!r?.[Xi]}function Pe(r){return new uo(r)}var ji={32:16777619n,64:1099511628211n,128:309485009821345068724781371n,256:374144419156711147060143317175368453031918731002211n,512:35835915874844867368919076489095108449946327955754392558399825615420669938882575126094039892345713852759n,1024:5016456510113118655434598811035278955030765345404790744303017523831112055108147451509157692220295382716162651878526895249385292291816524375083746691371804094271873160484737966720260389217684476157468082573n},Qu={32:2166136261n,64:14695981039346656037n,128:144066263297769815596495629667062367629n,256:100029257958052580907070968620625704837092796014241193945225284501741471925557n,512:9659303129496669498009435400716310466090418745672637896108374329434462657994582932197716438449813051892206539805784495328239340083876191928701583869517785n,1024:14197795064947621068722070641403218320880622795441933960878474914617582723252296732303717722150864096521202355549365628174669108571814760471015076148029755969804077320157692458563003215304957150157403644460363550505412711285966361610267868082893823963790439336411086884584107735010676915n},Ju=new globalThis.TextEncoder;function Fh(r,e){let t=ji[e],n=Qu[e];for(let s=0;s<r.length;s++)n^=BigInt(r[s]),n=BigInt.asUintN(e,n*t);return n}function zh(r,e,t){if(t.length===0)throw new Error("The `utf8Buffer` option must have a length greater than zero");let n=ji[e],s=Qu[e],o=r;for(;o.length>0;){let i=Ju.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 Qi(r,{size:e=32,utf8Buffer:t}={}){if(!ji[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 zh(r,e,t);r=Ju.encode(r)}return Fh(r,e)}var sn={hash:r=>Number(Qi(r,{size:32})),hashV:(r,e)=>$h(sn.hash(r,e))};function $h(r){let e=r.toString(16);return e.length%2===1&&(e=`0${e}`),K(e,"base16")}var Ji=64,Ve=class{fp;h;seed;constructor(e,t,n,s=2){if(s>Ji)throw new TypeError("Invalid Fingerprint Size");let o=t.hashV(e,n),i=re(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?fe(this.fp,e.fp):!1}};function Yt(r,e){return Math.floor(Math.random()*(e-r))+r}var Zt=class{contents;constructor(e){this.contents=new Array(e).fill(null)}has(e){if(!(e instanceof Ve))throw new TypeError("Invalid Fingerprint");return this.contents.some(t=>e.equals(t))}add(e){if(!(e instanceof Ve))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 Ve))throw new TypeError("Invalid Fingerprint");let t=Yt(0,this.contents.length-1),n=this.contents[t];return this.contents[t]=e,n}remove(e){if(!(e instanceof Ve))throw new TypeError("Invalid Fingerprint");let t=this.contents.findIndex(n=>e.equals(n));return t>-1?(this.contents[t]=null,!0):!1}};var Gh=500,an=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??sn,this.seed=e.seed??Yt(0,Math.pow(2,10))}add(e){typeof e=="string"&&(e=K(e));let t=new Ve(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 Zt(this.bucketSize)),this.buckets[s]==null&&(this.buckets[s]=new Zt(this.bucketSize)),this.buckets[n].add(t)||this.buckets[s].add(t))return this.count++,!0;let o=[n,s],i=o[Yt(0,o.length-1)];this.buckets[i]==null&&(this.buckets[i]=new Zt(this.bucketSize));for(let a=0;a<Gh;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 Zt(this.bucketSize)),this.buckets[i].add(c)))return this.count++,!0}return!1}has(e){typeof e=="string"&&(e=K(e));let t=new Ve(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 Ve(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}},Wh={1:.5,2:.84,4:.95,8:.98};function Yh(r=.001){return r>.002?2:r>1e-5?4:8}function el(r,e=.001){let t=Yh(e),n=Wh[t],s=Math.round(r/n),o=Math.min(Math.ceil(Math.log2(1/e)+Math.log2(2*t)),Ji);return{filterSize:s,bucketSize:t,fingerprintSize:o}}var lo=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??sn,this.seed=e.seed??Yt(0,Math.pow(2,10)),this.filterSeries=[new an({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 an({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 Tr(r,e=.001,t){return new lo({...el(r,e),...t??{}})}function Fe(){let r={};return r.promise=new Promise((e,t)=>{r.resolve=e,r.reject=t}),r}var fo=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}},Ir=class{size;hwm;head;tail;constructor(e={}){this.hwm=e.splitLimit??16,this.head=new fo(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 fo(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 ea=class extends Error{type;code;constructor(e,t){super(e??"The operation was aborted"),this.type="aborted",this.code=t??"ABORT_ERR"}};function Tt(r={}){return Zh(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 Zh(r,e){e=e??{};let t=e.onEnd,n=new Ir,s,o,i,a=Fe(),c=async()=>{try{return n.isEmpty()?i?{done:!0}:await new Promise((x,y)=>{o=A=>{o=null,n.push(A);try{x(r(n))}catch(w){y(w)}return s}}):r(n)}finally{n.isEmpty()&&queueMicrotask(()=>{a.resolve(),a=Fe()})}},l=x=>o!=null?o(x):(n.push(x),s),u=x=>(n=new Ir,o!=null?o({error:x}):(n.push({error:x}),s)),f=x=>{if(i)return s;if(e?.objectMode!==!0&&x?.byteLength==null)throw new Error("objectMode was not true but tried to push non-Uint8Array value");return l({done:!1,value:x})},d=x=>i?s:(i=!0,x!=null?u(x):l({done:!0})),p=()=>(n=new Ir,d(),{done:!0}),h=x=>(d(x),{done:!0});if(s={[Symbol.asyncIterator](){return this},next:c,return:p,throw:h,push:f,end:d,get readableLength(){return n.size},onEmpty:async x=>{let y=x?.signal;if(y?.throwIfAborted(),n.isEmpty())return;let A,w;y!=null&&(A=new Promise((T,P)=>{w=()=>{P(new ea)},y.addEventListener("abort",w)}));try{await Promise.race([a.promise,A])}finally{w!=null&&y!=null&&y?.removeEventListener("abort",w)}}},t==null)return s;let S=s;return s={[Symbol.asyncIterator](){return this},next(){return S.next()},throw(x){return S.throw(x),t!=null&&(t(x),t=void 0),{done:!0}},return(){return S.return(),t!=null&&(t(),t=void 0),{done:!0}},push:f,end(x){return S.end(x),t!=null&&(t(x),t=void 0),s},get readableLength(){return S.readableLength},onEmpty:x=>S.onEmpty(x)},s}var ta=class r extends Error{name="TimeoutError";constructor(e,t){super(e,t),Error.captureStackTrace?.(this,r)}},tl=r=>r.reason??new DOMException("This operation was aborted.","AbortError");function ra(r,e){let{milliseconds:t,fallback:n,message:s,customTimers:o={setTimeout,clearTimeout},signal:i}=e,a,c,u=new Promise((f,d)=>{if(typeof t!="number"||Math.sign(t)!==1)throw new TypeError(`Expected \`milliseconds\` to be a positive number, got \`${t}\``);if(i?.aborted){d(tl(i));return}if(i&&(c=()=>{d(tl(i))},i.addEventListener("abort",c,{once:!0})),r.then(f,d),t===Number.POSITIVE_INFINITY)return;let p=new ta;a=o.setTimeout.call(void 0,()=>{if(n){try{f(n())}catch(h){d(h)}return}typeof r.cancel=="function"&&r.cancel(),s===!1?f():s instanceof Error?d(s):(p.message=s??`Promise timed out after ${t} milliseconds`,d(p))},t)}).finally(()=>{u.clear(),c&&i&&i.removeEventListener("abort",c)});return u.clear=()=>{o.clearTimeout.call(void 0,a),a=void 0},u}var Xh=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 jh(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:l,removeListener:u}=Xh(r),f=async(...p)=>{let h=t.multiArgs?p:p[0];if(t.filter)try{if(!await t.filter(h))return}catch(S){n(),i(S);return}c.push(h),t.count===c.length&&(n(),o(c))},d=(...p)=>{n(),i(t.rejectionMultiArgs?p:p[0])};n=()=>{for(let p of a)u(p,f);for(let p of t.rejectionEvents)a.includes(p)||u(p,d)};for(let p of a)l(p,f);for(let p of t.rejectionEvents)a.includes(p)||l(p,d);t.signal&&t.signal.addEventListener("abort",()=>{d(t.signal.reason)},{once:!0}),t.resolveImmediately&&o(c)});if(s.cancel=n,typeof t.timeout=="number"){let o=ra(s,{milliseconds:t.timeout});return o.cancel=()=>{n(),o.clear()},o}return s}function je(r,e,t){typeof t=="function"&&(t={filter:t}),t={...t,count:1,resolveImmediately:!1};let n=jh(r,e,t),s=n.then(o=>o[0]);return s.cancel=n.cancel,s}function na(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 ho=class extends Error{static name="QueueFullError";constructor(e="The queue was full"){super(e),this.name="QueueFullError"}},Xt=class extends Error{static name="UnexpectedEOFError";name="UnexpectedEOFError"};var po=class extends Error{static name="StreamClosedError";name="StreamClosedError"};function Qh(r){return r.reason}async function It(r,e,t){if(e==null)return r;let n=t?.translateError??Qh;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 mo=class{deferred;signal;onProgress;constructor(e){this.signal=e?.signal,this.onProgress=e?.onProgress,this.deferred=Fe(),this.onAbort=this.onAbort.bind(this),this.signal?.addEventListener("abort",this.onAbort)}onAbort(){this.deferred.reject(this.signal?.reason??new Qe)}cleanup(){this.signal?.removeEventListener("abort",this.onAbort)}};function Jh(){return`${parseInt(String(Math.random()*1e9),10).toString()}${Date.now()}`}var yo=class{id;fn;options;recipients;status;timeline;controller;constructor(e,t){this.id=Jh(),this.status="queued",this.fn=e,this.options=t,this.recipients=[],this.timeline={created:Date.now()},this.controller=new AbortController,this.controller.signal,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 Qe),this.cleanup())}async join(e){let t=new mo(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 It(this.fn({...this.options??{},signal:this.controller.signal,onProgress:t=>{this.recipients.forEach(n=>{n.onProgress?.(t)})}}),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 bo=class extends _e{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=na(this.emitEmpty.bind(this),1),this.emitIdle=na(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 ho;let n=new yo(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 Qe)}),this.clear()}async onEmpty(e){this.size!==0&&await je(this,"empty",e)}async onSizeLessThan(e,t){this.size<e||await je(this,"next",{...t,filter:()=>this.size<e})}async onIdle(e){this.pending===0&&this.size===0||await je(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=Tt({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 Qe("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 ep=Math.pow(2,20)*4,go=class extends _e{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??ep,this.maxWriteBufferLength=e.maxWriteBufferLength,this.maxMessageSize=e.maxMessageSize,this.readBuffer=new J,this.writeBuffer=new J,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,this.processSendQueue()),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()),It(this.onDrainPromise.promise,e?.signal))}async*[Symbol.asyncIterator](){if(this.readStatus!=="readable"&&this.readStatus!=="paused")return;let e=Tt(),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 pt(`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 Sn(e))}}pause(){if(this.readStatus==="closed"||this.readStatus==="closing")throw new pt("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 pt("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 pt(`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 pt(`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 yn;this.dispatchEvent(new vn(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 rr))}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;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 J(o);this.writeBuffer.consume(o.byteLength);let a=this.sendData(o);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 En(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 Lr(`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 Lr(`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 xo=class extends go{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 je(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 je(this,"drain",{...e,rejectionEvents:["close"]})),await this.sendClose(e),this.onTransportClosed())}};function wo(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 oa=class{readNext;haveNext;ended;nextResult;error;constructor(){this.ended=!1,this.readNext=Fe(),this.haveNext=Fe()}[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=Fe(),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=Fe(),await It(this.readNext.promise,t?.signal,t)}};function rl(){return new oa}function tp(r){return r[Symbol.asyncIterator]!=null}async function rp(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*np(r){let e=new AbortController,t=rl();rp(r,t,e.signal).catch(()=>{});try{yield*t}finally{e.abort()}}function*op(r){for(let e of r)yield*e}function sp(...r){let e=[];for(let t of r)tp(t)||e.push(t);return e.length===r.length?op(e):np(r)}var nl=sp;function ol(r,...e){if(r==null)throw new Error("Empty pipeline");if(sa(r)){let n=r;r=()=>n.source}else if(il(r)||sl(r)){let n=r;r=()=>n}let t=[r,...e];if(t.length>1&&sa(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++)sa(t[n])&&(t[n]=ap(t[n]));return ip(...t)}var ip=(...r)=>{let e;for(;r.length>0;)e=r.shift()(e);return e},sl=r=>r?.[Symbol.asyncIterator]!=null,il=r=>r?.[Symbol.iterator]!=null,sa=r=>r==null?!1:r.sink!=null&&r.source!=null,ap=r=>e=>{let t=r.sink(e);if(t?.then!=null){let n=Tt({objectMode:!0});t.then(()=>{n.end()},i=>{n.end(i)});let s,o=r.source;if(sl(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 nl(n,s())}return r.source};var cp=4194304,Eo=class extends Error{static name="UnwrappedError";name="UnwrappedError"},aa=class extends Error{name="InvalidMessageLengthError";code="ERR_INVALID_MSG_LENGTH"},ca=class extends Error{name="InvalidDataLengthError";code="ERR_MSG_DATA_TOO_LONG"},ua=class extends Error{name="InvalidDataLengthLengthError";code="ERR_MSG_LENGTH_TOO_LONG"};function up(r){return typeof r?.closeRead=="function"}function lp(r){return typeof r?.close=="function"}function ia(r){return up(r)?r.remoteWriteStatus!=="writable"&&r.readBufferLength===0:lp(r)?r.status!=="open":!1}function fp(r){return r?.addEventListener!=null&&r?.removeEventListener!=null&&r?.send!=null&&r?.push!=null&&r?.log!=null}function dp(r,e){let t=e?.maxBufferSize??cp,n=new J,s,o=!1;if(!fp(r))throw new ae("Argument should be a Stream or a Multiaddr");let i=u=>{if(n.append(u.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=u=>{u.error!=null?s?.reject(u.error):s?.resolve()};r.addEventListener("close",a);let c=()=>{s?.resolve()};r.addEventListener("remoteCloseWrite",c);let l={readBuffer:n,async read(u){if(o===!0)throw new Eo("Stream was unwrapped");if(ia(r)){if(n.byteLength===0&&u?.bytes==null)return null;if(u?.bytes!=null&&n.byteLength<u.bytes)throw r.log.error("closed after reading %d/%d bytes",n.byteLength,u.bytes),new Xt(`Unexpected EOF - stream closed after reading ${n.byteLength}/${u.bytes} bytes`)}let f=u?.bytes??1;for(s=Promise.withResolvers();;){if(n.byteLength>=f){s.resolve();break}if(await It(s.promise,u?.signal),ia(r)){if(n.byteLength===0&&u?.bytes==null)return null;break}s=Promise.withResolvers()}let d=u?.bytes??n.byteLength;if(n.byteLength<d){if(ia(r))throw r.log.error("closed while reading %d/%d bytes",n.byteLength,d),new Xt(`Unexpected EOF - stream closed while reading ${n.byteLength}/${d} bytes`);return l.read(u)}let p=n.sublist(0,d);return n.consume(d),p},async write(u,f){if(o===!0)throw new Eo("Stream was unwrapped");r.send(u)||await je(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.push(n))),r}};return l}function hp(r,e={}){let t=dp(r,e);e.maxDataLength!=null&&e.maxLengthLength==null&&(e.maxLengthLength=De(e.maxDataLength));let n=e?.lengthDecoder??Wr,s=e?.lengthEncoder??br;return{async read(i){let a=-1,c=new J;for(;;){let u=await t.read({...i,bytes:1});if(u==null)break;c.append(u);try{a=n(c)}catch(f){if(f instanceof RangeError)continue;throw f}if(a<0)throw new aa("Invalid message length");if(e?.maxLengthLength!=null&&c.byteLength>e.maxLengthLength)throw new ua(`Message length length too long - ${c.byteLength} > ${e.maxLengthLength}`);if(a>-1)break}if(e?.maxDataLength!=null&&a>e.maxDataLength)throw new ca(`Message length too long - ${a} > ${e.maxDataLength}`);let l=await t.read({...i,bytes:a});if(l==null)throw r.log.error("tried to read %d bytes but the stream closed",a),new Xt(`Unexpected EOF - tried to read ${a} bytes but the stream closed`);if(l.byteLength!==a)throw r.log.error("read %d/%d bytes before the stream closed",l.byteLength,a),new Xt(`Unexpected EOF - read ${l.byteLength}/${a} bytes before the stream closed`);return l},async write(i,a){await t.write(new J(s(i.byteLength),i),a)},async writeV(i,a){let c=new J(...i.flatMap(l=>[s(l.byteLength),l]));await t.write(c,a)},unwrap(){return t.unwrap()}}}function Dt(r,e){let t=hp(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 pp(r){return r?.addEventListener!=null}function mp(r){let e=Tt(),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:l,value:u}=await Promise.race([c.next(),t.promise]);if(r.writeStatus==="closing"||r.writeStatus==="closed"||(u!=null&&(r.send(u)||await Promise.race([je(r,"drain",{rejectionEvents:["close"]})])),l===!0))break}await r.close()}}}function al(...r){let e=r.map(t=>pp(t)?mp(t):t);return ol(...e)}var Dr=class extends bo{has(e){return this.find(e)!=null}find(e){return this.queue.find(t=>e.equals(t.options.peerId))}};var X=r=>({match:e=>{let t=e[0];return t==null||t.code!==r||t.value!=null?!1:e.slice(1)}}),R=(r,e)=>({match:t=>{let n=t[0];return n?.code!==r||n.value==null||e!=null&&n.value!==e?!1:t.slice(1)}}),cl=r=>({match:e=>r.match(e)===!1?e:!1}),F=r=>({match:e=>{let t=r.match(e);return t===!1?e:t}}),Ee=(...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}}),z=(...r)=>({match:e=>{for(let t of r){let n=t.match(e);if(n===!1)return!1;e=n}return e}});function j(...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 yp=R(421),O2=j(yp),vo=R(54),_o=R(55),Ao=R(56),fa=R(53),P2=j(vo,F(R(421))),N2=j(_o,F(R(421))),U2=j(Ao,F(R(421))),k2=j(Ee(fa,Ao,vo,_o),F(R(421))),ul=z(R(4),F(R(43))),ll=z(F(R(42)),R(41),F(R(43))),da=Ee(ul,ll),Cr=Ee(da,fa,vo,_o,Ao),M2=j(Ee(da,z(Ee(fa,Ao,vo,_o),F(R(421))))),K2=j(ul),H2=j(ll),q2=j(da),ha=z(Cr,R(6)),cn=z(Cr,R(273)),V2=j(z(ha,F(R(421)))),F2=j(cn),pa=z(cn,X(460),F(R(421))),To=z(cn,X(461),F(R(421))),bp=Ee(pa,To),z2=j(pa),$2=j(To),la=Ee(Cr,ha,cn,pa,To),fl=Ee(z(la,X(477),F(R(421)))),G2=j(fl),dl=Ee(z(la,X(478),F(R(421))),z(la,X(448),F(R(449)),X(477),F(R(421)))),W2=j(dl),hl=z(cn,X(280),F(R(466)),F(R(466)),F(R(421))),Y2=j(hl),pl=z(To,X(465),F(R(466)),F(R(466)),F(R(421))),Z2=j(pl),So=Ee(fl,dl,z(ha,F(R(421))),z(bp,F(R(421))),z(Cr,F(R(421))),hl,pl,R(421)),ml=j(So),gp=z(F(So),X(290),cl(X(281)),F(R(421))),jt=j(gp),xp=Ee(z(So,X(290),X(281),F(R(421))),z(So,X(281),F(R(421))),z(X(281),F(R(421)))),X2=j(xp),wp=z(Cr,Ee(z(R(6,"80")),z(R(6),X(480)),X(480)),F(R(481)),F(R(421))),j2=j(wp),Ep=z(Cr,Ee(z(R(6,"443")),z(R(6,"443"),X(480)),z(R(6),X(443)),z(R(6),X(448),X(480)),z(X(448),X(480)),X(448),X(443)),F(R(481)),F(R(421))),Q2=j(Ep),Sp=Ee(z(R(777),F(R(421)))),J2=j(Sp),vp=Ee(z(R(400),F(R(421)))),e1=j(vp);var ma=1e3,yl=60*ma,bl=15,gl=120*yl,xl=1,Io=5e3,wl=100,ya="circuit-relay-source",un=`${Ca}-circuit-relay`,El=2*yl,Sl=BigInt(1<<17),ke="/libp2p/circuit/relay/0.2.0/hop",Qt="/libp2p/circuit/relay/0.2.0/stop",vl=30*ma,n1=30*ma,ln=300,_l=4096,Al=.001;var Z;(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=()=>Ft(t)})(e=r.Type||(r.Type={}));let n;r.codec=()=>(n==null&&(n=Re((a,c,l={})=>{l.lengthDelimited!==!1&&c.fork(),a.type!=null&&(c.uint32(8),r.Type.codec().encode(a.type,c)),a.peer!=null&&(c.uint32(18),Ct.codec().encode(a.peer,c)),a.reservation!=null&&(c.uint32(26),fn.codec().encode(a.reservation,c)),a.limit!=null&&(c.uint32(34),Lt.codec().encode(a.limit,c)),a.status!=null&&(c.uint32(40),H.codec().encode(a.status,c)),l.lengthDelimited!==!1&&c.ldelim()},(a,c,l={})=>{let u={},f=c==null?a.len:a.pos+c;for(;a.pos<f;){let d=a.uint32();switch(d>>>3){case 1:{u.type=r.Type.codec().decode(a);break}case 2:{u.peer=Ct.codec().decode(a,a.uint32(),{limits:l.limits?.peer});break}case 3:{u.reservation=fn.codec().decode(a,a.uint32(),{limits:l.limits?.reservation});break}case 4:{u.limit=Lt.codec().decode(a,a.uint32(),{limits:l.limits?.limit});break}case 5:{u.status=H.codec().decode(a);break}default:{a.skipType(d&7);break}}}return u},function*(a,c,l,u={}){let f=c==null?a.len:a.pos+c;for(;a.pos<f;){let d=a.uint32();switch(d>>>3){case 1:{yield{field:`${l}.type`,value:r.Type.codec().decode(a)};break}case 2:{yield*Ct.codec().stream(a,a.uint32(),`${l}.peer`,{limits:u.limits?.peer});break}case 3:{yield*fn.codec().stream(a,a.uint32(),`${l}.reservation`,{limits:u.limits?.reservation});break}case 4:{yield*Lt.codec().stream(a,a.uint32(),`${l}.limit`,{limits:u.limits?.limit});break}case 5:{yield{field:`${l}.status`,value:H.codec().decode(a)};break}default:{a.skipType(d&7);break}}}})),n);function s(a){return Le(a,r.codec())}r.encode=s;function o(a,c){return Ce(a,r.codec(),c)}r.decode=o;function i(a,c){return Be(a,r.codec(),c)}r.stream=i})(Z||(Z={}));var Ne;(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=()=>Ft(t)})(e=r.Type||(r.Type={}));let n;r.codec=()=>(n==null&&(n=Re((a,c,l={})=>{l.lengthDelimited!==!1&&c.fork(),a.type!=null&&(c.uint32(8),r.Type.codec().encode(a.type,c)),a.peer!=null&&(c.uint32(18),Ct.codec().encode(a.peer,c)),a.limit!=null&&(c.uint32(26),Lt.codec().encode(a.limit,c)),a.status!=null&&(c.uint32(32),H.codec().encode(a.status,c)),l.lengthDelimited!==!1&&c.ldelim()},(a,c,l={})=>{let u={},f=c==null?a.len:a.pos+c;for(;a.pos<f;){let d=a.uint32();switch(d>>>3){case 1:{u.type=r.Type.codec().decode(a);break}case 2:{u.peer=Ct.codec().decode(a,a.uint32(),{limits:l.limits?.peer});break}case 3:{u.limit=Lt.codec().decode(a,a.uint32(),{limits:l.limits?.limit});break}case 4:{u.status=H.codec().decode(a);break}default:{a.skipType(d&7);break}}}return u},function*(a,c,l,u={}){let f=c==null?a.len:a.pos+c;for(;a.pos<f;){let d=a.uint32();switch(d>>>3){case 1:{yield{field:`${l}.type`,value:r.Type.codec().decode(a)};break}case 2:{yield*Ct.codec().stream(a,a.uint32(),`${l}.peer`,{limits:u.limits?.peer});break}case 3:{yield*Lt.codec().stream(a,a.uint32(),`${l}.limit`,{limits:u.limits?.limit});break}case 4:{yield{field:`${l}.status`,value:H.codec().decode(a)};break}default:{a.skipType(d&7);break}}}})),n);function s(a){return Le(a,r.codec())}r.encode=s;function o(a,c){return Ce(a,r.codec(),c)}r.decode=o;function i(a,c){return Be(a,r.codec(),c)}r.stream=i})(Ne||(Ne={}));var Ct;(function(r){let e;r.codec=()=>(e==null&&(e=Re((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:re(0),addrs:[]},l=i==null?o.len:o.pos+i;for(;o.pos<l;){let u=o.uint32();switch(u>>>3){case 1:{c.id=o.bytes();break}case 2:{if(a.limits?.addrs!=null&&c.addrs.length===a.limits.addrs)throw new zt('Decode error - repeated field "addrs" had too many elements');c.addrs.push(o.bytes());break}default:{o.skipType(u&7);break}}}return c},function*(o,i,a,c={}){let l={addrs:0},u=i==null?o.len:o.pos+i;for(;o.pos<u;){let f=o.uint32();switch(f>>>3){case 1:{yield{field:`${a}.id`,value:o.bytes()};break}case 2:{if(c.limits?.addrs!=null&&l.addrs===c.limits.addrs)throw new zt('Streaming decode error - repeated field "addrs" had too many elements');yield{field:`${a}.addrs[]`,index:l.addrs,value:o.bytes()},l.addrs++;break}default:{o.skipType(f&7);break}}}})),e);function t(o){return Le(o,r.codec())}r.encode=t;function n(o,i){return Ce(o,r.codec(),i)}r.decode=n;function s(o,i){return Be(o,r.codec(),i)}r.stream=s})(Ct||(Ct={}));var fn;(function(r){let e;r.codec=()=>(e==null&&(e=Re((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),dn.codec().encode(o.voucher,i)),a.lengthDelimited!==!1&&i.ldelim()},(o,i,a={})=>{let c={expire:0n,addrs:[]},l=i==null?o.len:o.pos+i;for(;o.pos<l;){let u=o.uint32();switch(u>>>3){case 1:{c.expire=o.uint64();break}case 2:{if(a.limits?.addrs!=null&&c.addrs.length===a.limits.addrs)throw new zt('Decode error - repeated field "addrs" had too many elements');c.addrs.push(o.bytes());break}case 3:{c.voucher=dn.codec().decode(o,o.uint32(),{limits:a.limits?.voucher});break}default:{o.skipType(u&7);break}}}return c},function*(o,i,a,c={}){let l={addrs:0},u=i==null?o.len:o.pos+i;for(;o.pos<u;){let f=o.uint32();switch(f>>>3){case 1:{yield{field:`${a}.expire`,value:o.uint64()};break}case 2:{if(c.limits?.addrs!=null&&l.addrs===c.limits.addrs)throw new zt('Streaming decode error - repeated field "addrs" had too many elements');yield{field:`${a}.addrs[]`,index:l.addrs,value:o.bytes()},l.addrs++;break}case 3:{yield*dn.codec().stream(o,o.uint32(),`${a}.voucher`,{limits:c.limits?.voucher});break}default:{o.skipType(f&7);break}}}})),e);function t(o){return Le(o,r.codec())}r.encode=t;function n(o,i){return Ce(o,r.codec(),i)}r.decode=n;function s(o,i){return Be(o,r.codec(),i)}r.stream=s})(fn||(fn={}));var Lt;(function(r){let e;r.codec=()=>(e==null&&(e=Re((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={},l=i==null?o.len:o.pos+i;for(;o.pos<l;){let u=o.uint32();switch(u>>>3){case 1:{c.duration=o.uint32();break}case 2:{c.data=o.uint64();break}default:{o.skipType(u&7);break}}}return c},function*(o,i,a,c={}){let l=i==null?o.len:o.pos+i;for(;o.pos<l;){let u=o.uint32();switch(u>>>3){case 1:{yield{field:`${a}.duration`,value:o.uint32()};break}case 2:{yield{field:`${a}.data`,value:o.uint64()};break}default:{o.skipType(u&7);break}}}})),e);function t(o){return Le(o,r.codec())}r.encode=t;function n(o,i){return Ce(o,r.codec(),i)}r.decode=n;function s(o,i){return Be(o,r.codec(),i)}r.stream=s})(Lt||(Lt={}));var H;(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"})(H||(H={}));var ba;(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"})(ba||(ba={}));(function(r){r.codec=()=>Ft(ba)})(H||(H={}));var Jt;(function(r){let e;r.codec=()=>(e==null&&(e=Re((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:re(0),peer:re(0),expiration:0n},l=i==null?o.len:o.pos+i;for(;o.pos<l;){let u=o.uint32();switch(u>>>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(u&7);break}}}return c},function*(o,i,a,c={}){let l=i==null?o.len:o.pos+i;for(;o.pos<l;){let u=o.uint32();switch(u>>>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(u&7);break}}}})),e);function t(o){return Le(o,r.codec())}r.encode=t;function n(o,i){return Ce(o,r.codec(),i)}r.decode=n;function s(o,i){return Be(o,r.codec(),i)}r.stream=s})(Jt||(Jt={}));var dn;(function(r){let e;r.codec=()=>(e==null&&(e=Re((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),Jt.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:re(0),payloadType:re(0),signature:re(0)},l=i==null?o.len:o.pos+i;for(;o.pos<l;){let u=o.uint32();switch(u>>>3){case 1:{c.publicKey=o.bytes();break}case 2:{c.payloadType=o.bytes();break}case 3:{c.payload=Jt.codec().decode(o,o.uint32(),{limits:a.limits?.payload});break}case 5:{c.signature=o.bytes();break}default:{o.skipType(u&7);break}}}return c},function*(o,i,a,c={}){let l=i==null?o.len:o.pos+i;for(;o.pos<l;){let u=o.uint32();switch(u>>>3){case 1:{yield{field:`${a}.publicKey`,value:o.bytes()};break}case 2:{yield{field:`${a}.payloadType`,value:o.bytes()};break}case 3:{yield*Jt.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(u&7);break}}}})),e);function t(o){return Le(o,r.codec())}r.encode=t;function n(o,i){return Ce(o,r.codec(),i)}r.decode=n;function s(o,i){return Be(o,r.codec(),i)}r.stream=s})(dn||(dn={}));var Do=class extends Error{constructor(e="Transfer limit error"){super(e),this.name="TransferLimitError"}},Co=class extends Error{constructor(e="Duration limit error"){super(e),this.name="DurationLimitError"}},hn=class extends Error{static name="HadEnoughRelaysError";name="HadEnoughRelaysError"},Lo=class extends Error{static name="DoubleRelayError";name="DoubleRelayError"},Bo=class extends Error{static name="RelayQueueFullError";name="RelayQueueFullError"};function Tl(r,e,t){let n=e.remaining,s=o=>{let i=BigInt(o.data.byteLength);e.remaining-=i,e.remaining<0&&r.abort(new Do(`data limit of ${n} bytes exceeded`))};r.addEventListener("message",s)}function Il(r,e,t,n,s){function o(u){r.abort(u),e.abort(u)}let i=[t,n.signal];if(n.limit?.duration!=null){s.log("limiting relayed connection duration to %dms",n.limit.duration);let u=AbortSignal.timeout(n.limit.duration);i.push(u)}let a=wo(i);let c;n.limit?.data!=null&&(c={remaining:n.limit.data});let l=()=>{let u;t.aborted?u=t.reason:u=new Co(`duration limit of ${n.limit?.duration} ms exceeded`),o(u)};a.addEventListener("abort",l,{once:!0}),c!=null&&(Tl(e,c,s),Tl(r,c,s)),al(r,e,r).catch(u=>{o(u)}).finally(()=>{a.clear()})}function ga(r){let e=r*BigInt(1e3),t=new Date().getTime();return Number(e-BigInt(t))}var pn=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}},Ro=j(z(ml.matchers[0],X(290))),Oo=j(X(290));function Po(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 Bt=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 Po(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 Po(this.map.values(),e=>e.key)}values(){return Po(this.map.values(),e=>e.value)}get size(){return this.map.size}};var No=class{filter;constructor(e,t){this.filter=Tr(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 xa(r,e=.001){return new No(r,e)}var wa=class extends Bt{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 Ea(r){let{name:e,metrics:t}=r,n;return t!=null?n=new wa({name:e,metrics:t}):n=new Bt,n}var Sa=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 Dl(r,e){let t=new Sa(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 Uo=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??bl,this.applyDefaultLimit=t.applyDefaultLimit!==!1,this.reservationTtl=t.reservationTtl??gl,this.defaultDurationLimit=t.defaultDurationLimit??El,this.defaultDataLimit=t.defaultDataLimit??Sl,this.reservations=Ea({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:H.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:Dl(this.reservationTtl)}),this.reservations.set(e,s),s.signal.addEventListener("abort",()=>{this.reservations.delete(e)}),{status:H.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 ko=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 Jt.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 _p={maxOutboundStopStreams:ln},Mo=class extends _e{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??vl,this.maxInboundHopStreams=t.maxInboundHopStreams,this.maxOutboundHopStreams=t.maxOutboundHopStreams,this.maxOutboundStopStreams=t.maxOutboundStopStreams??_p.maxOutboundStopStreams,this.reservationStore=new Uo(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=Dt(e);try{let i=await o.pb(Z).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(Z).write({type:Z.Type.STATUS,status:H.MALFORMED_MESSAGE},s),e.abort(i)}}async handleHopProtocol({stream:e,request:t,connection:n},s){switch(this.log("received hop message"),t.type){case Z.Type.RESERVE:await this.handleReserve({stream:e,request:t,connection:n},s);break;case Z.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(Z).write({type:Z.Type.STATUS,status:H.UNEXPECTED_MESSAGE})}}async handleReserve({stream:e,connection:t},n){let s=e.pb(Z);if(this.log("hop reserve request from %p",t.remotePeer),jt.exactMatch(t.remoteAddr)){this.log.error("relay reservation over circuit connection denied for peer: %p",t.remotePeer),await s.write({type:Z.Type.STATUS,status:H.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:Z.Type.STATUS,status:H.PERMISSION_DENIED},n);return}let o=this.reservationStore.reserve(t.remotePeer,t.remoteAddr);try{if(o.status!==H.OK){await s.write({type:Z.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:{[ya]:{value:1,ttl:i}}},n)}await s.write({type:Z.Type.STATUS,status:H.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:{[ya]: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 nn.seal(new ko({peer:e,relay:this.components.peerId,expiration:t}),this.components.privateKey);return{addrs:n,expire:t,voucher:{publicKey:We(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(Z);if(jt.matches(n.remoteAddr)){this.log.error("relay reservation over circuit connection denied for peer: %p",n.remotePeer),await o.write({type:Z.Type.STATUS,status:H.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(Pe),i=Er(Ge(t.peer.id))}catch(f){this.log.error("invalid hop connect request via peer %p - %e",n.remotePeer,f),await o.write({type:Z.Type.STATUS,status:H.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,H.NO_RESERVATION),await o.write({type:Z.Type.STATUS,status:H.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:Z.Type.STATUS,status:H.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:Z.Type.STATUS,status:H.NO_RESERVATION},s);return}let l=c[0],u=await this.stopHop({connection:l,request:{type:Ne.Type.CONNECT,peer:{id:n.remotePeer.toMultihash().bytes,addrs:[]},limit:a?.limit}},s);if(u==null){this.log.error("failed to open stream to destination peer %p",l?.remotePeer),await o.write({type:Z.Type.STATUS,status:H.CONNECTION_FAILED},s);return}await o.write({type:Z.Type.STATUS,status:H.OK,limit:a?.limit},s),this.log("connection from %p to %p established - merging streams",n.remotePeer,i),Il(e.unwrap(),u,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(Qt,{maxOutboundStreams:this.maxOutboundStopStreams,runOnLimitedConnection:!0,...n}),o=Dt(s),i=o.pb(Ne);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===H.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 Rt=class extends Event{type;detail;constructor(e,t){super(e),this.type=e,this.detail=t}};var Ko=class extends _e{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=Cl(n),i=Cl(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 Dr({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=wo([AbortSignal.timeout(5e3),t]);try{await this.components.connectionManager.openConnection(e,{signal:n})}finally{n.clear()}}};function Cl(r){let e=r.metadata.get("last-dial-success");return e==null?0:new Date($(e)).getTime()}var _a=class extends _e{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??Io,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(Oo.exactMatch(e))this.log("searching for circuit relay servers"),this.reservationId=this.reservationStore.reserveRelay();else if(Ro.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 Ot(`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=>Pe(t).encapsulate("/p2p-circuit")),this.listeningAddrs.forEach(t=>{this.addressManager.confirmObservedAddr(t,{type:"transport"})}),queueMicrotask(()=>{this.safeDispatchEvent("listening")})}};function Ll(r){return new _a(r)}var Bl="useandom-26T198340PX75pxJACKVERYMINDBUSHWOLF_GQZbfghjklqvwyzrict";var Rl=(r=21)=>{let e="",t=crypto.getRandomValues(new Uint8Array(r|=0));for(;r--;)e+=Bl[t[r]&63];return e};var Ap=60*1e3*10,Tp=60*1e3*5,Ip=30*1e3,Ho=class extends _e{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 Bt,this.pendingReservations=[],this.maxReservationQueueLength=t?.maxReservationQueueLength??wl,this.reservationCompletionTimeout=t?.reservationCompletionTimeout??Io,this.started=!1,this.relayFilter=Tr(100),this.reserveQueue=new Dr({concurrency:t?.reservationConcurrency??xl,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(un)]});this.log("removing tag from %d old relays",e.length),await Promise.all(e.map(async t=>{await this.peerStore.merge(t.id,{tags:{[un]: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=Rl();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 Ot("Cannot use self as relay");if(this.reserveQueue.size>this.maxReservationQueueLength)throw new Bo("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 Ot("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 h=this.connectionManager.getConnections(e),S=!1;if(h.length===0&&this.log("already have relay reservation with %p but we are no longer connected",e),h.map(x=>x.id).includes(o.connection)&&(this.log("already have relay reservation with %p and the original connection is still open",e),S=!0),S&&ga(o.reservation.expire)>Ap)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 hn("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(jt.matches(a.remoteAddr))throw new Lo("not creating reservation over relayed connection");let c=await this.#e(a,{signal:i}),l=ga(c.expire);this.log("created reservation on relay peer %p, expiry date is %s",e,new Date(Date.now()+l).toString());let u=Math.min(Math.max(l-Tp,Ip),Math.pow(2,31)-1),f=setTimeout(()=>{this.log("refresh reservation to relay %p",e),this.addRelay(e,t).catch(async h=>{this.log.error("could not refresh reservation to relay %p - %e",e,h),await this.#t(e)}).catch(h=>{this.log.error("could not remove expired reservation to relay %p - %e",e,h)})},u),d;if(t==="discovered"){let h=this.pendingReservations.pop();if(h==null)throw new hn("Made reservation on relay but did not need any more discovered relays");d={timeout:f,reservation:c,type:t,connection:a.id,id:h}}else d={timeout:f,reservation:c,type:t,connection:a.id};this.reservations.set(e,d),await this.peerStore.merge(e,{tags:{[un]:{value:1,ttl:l}}}),this.#r();let p={relay:e,details:d};return this.safeDispatchEvent("relay:created-reservation",{detail:p}),p}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=Dt(n).pb(Z);this.log.trace("send RESERVE to %p",e.remotePeer),await o.write({type:Z.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===H.OK&&i.reservation!=null){let c=new Set;c.add(e.remoteAddr.toString());for(let l of i.reservation.addrs){let u=Pe(l);u.getComponents().find(f=>f.code===421)==null&&(u=u.encapsulate(`/p2p/${e.remotePeer}`)),u=Pe(u.toString().replace(`/p2p/${e.remotePeer}/p2p/${e.remotePeer}`,`/p2p/${e.remotePeer}`)),c.add(u.toString())}return i.reservation.addrs=[...c].map(l=>Pe(l).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:{[un]: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=Tr(100),this.log("not discovered enough relays %d/%d",this.reservations.size,this.pendingReservations.length),this.safeDispatchEvent("relay:not-enough-relays")}};var Aa=class extends xo{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 Ta(r){return new Aa(r)}var Dp=r=>{if(r.peer==null)return!1;try{r.peer.addrs.forEach(Pe)}catch{return!1}return!0},Ol={maxInboundStopStreams:ln,maxOutboundStopStreams:ln,stopTimeout:3e4},qo=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??Ol.maxInboundStopStreams,this.maxOutboundStopStreams=t.maxOutboundStopStreams??Ol.maxOutboundStopStreams,this.shutdownController=new AbortController,this.discovery=new Ko(e,{filter:t.discoveryFilter??xa(_l,Al)}),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 Ho(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";[Na]=["@libp2p/transport","@libp2p/circuit-relay-v2-transport"];get[Ua](){return this.discovery!=null?["@libp2p/identify"]:[]}[Pa]=!0;isStarted(){return this.started}async start(){this.shutdownController=new AbortController,this.shutdownController.signal,await this.components.registrar.handle(Qt,this.onStop,{maxInboundStreams:this.maxInboundStopStreams,maxOutboundStreams:this.maxOutboundStopStreams,runOnLimitedConnection:!0}),await Ba(this.discovery,this.reservationStore),this.started=!0}async stop(){this.shutdownController.abort(),await Ra(this.discovery,this.reservationStore),await this.components.registrar.unhandle(Qt),this.started=!1}async dial(e,t){let n=e.toString().split("/p2p-circuit"),s=Pe(n[0]),o=Pe(n[n.length-1]),i=s.getComponents().find(p=>p.code===421)?.value,a=o.getComponents().find(p=>p.code===421)?.value;if(i==null||a==null){let p=`ircuit relay dial to ${e.toString()} failed as address did not have both relay and destination PeerIDs`;throw this.log.error(`c${p}`),new wn(`C${p}`)}let c=Ii(i),l=Ii(a),f=this.components.connectionManager.getConnections(c)[0];f==null?(await this.components.peerStore.merge(c,{multiaddrs:[s]}),t.onProgress?.(new Rt("circuit-relay:open-connection")),f=await this.components.connectionManager.openConnection(c,t)):t.onProgress?.(new Rt("circuit-relay:reuse-connection"));let d;try{t.onProgress?.(new Rt("circuit-relay:open-hop-stream")),d=await f.newStream(ke,t);let p=Dt(d).pb(Z);t.onProgress?.(new Rt("circuit-relay:write-connect-message")),await p.write({type:Z.Type.CONNECT,peer:{id:l.toMultihash().bytes,addrs:[Pe(o).bytes]}},t),t.onProgress?.(new Rt("circuit-relay:read-connect-response"));let h=await p.read(t);if(h.status!==H.OK)throw new xn(`failed to connect via relay with status ${h?.status?.toString()??"undefined"}`);let S=new pn(h.limit),x=Ta({stream:p.unwrap().unwrap(),remoteAddr:e,localAddr:s.encapsulate(`/p2p-circuit/p2p/${this.components.peerId.toString()}`),onDataRead:S.onData,onDataWrite:S.onData,log:d.log.newScope("circuit-relay:connection")}),y=await this.components.upgrader.upgradeOutbound(x,{...t,limits:S.getLimits()});return y.log("outbound relayed connection established to %p with limits %o, over connection %s",y.remotePeer,h.limit??"none",f.id),y}catch(p){throw this.log.error("circuit relay dial to destination %p via relay %p failed - %e",l,c,p),d?.abort(p),p}}createListener(e){return Ll({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=>Ro.exactMatch(t)||Oo.exactMatch(t))}dialFilter(e){return e=Array.isArray(e)?e:[e],e.filter(t=>jt.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=Dt(e).pb(Ne),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:Ne.Type.STATUS,status:H.MALFORMED_MESSAGE},{signal:n}),await e.close({signal:n});return}if(o.type!==Ne.Type.CONNECT){this.log.error("invalid stop connect request via peer %p",t.remotePeer),await s.write({type:Ne.Type.STATUS,status:H.UNEXPECTED_MESSAGE},{signal:n}),await e.close({signal:n});return}if(!Dp(o)){this.log.error("invalid stop connect request via peer %p",t.remotePeer),await s.write({type:Ne.Type.STATUS,status:H.MALFORMED_MESSAGE},{signal:n}),await e.close({signal:n});return}let i=Er(Ge(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:Ne.Type.STATUS,status:H.PERMISSION_DENIED},{signal:n}),await e.close({signal:n});return}this.log.trace("sending success response to %p",t.remotePeer),await s.write({type:Ne.Type.STATUS,status:H.OK},{signal:n});let a=new pn(o.limit),c=t.remoteAddr.encapsulate(`/p2p-circuit/p2p/${i.toString()}`),l=this.components.addressManager.getAddresses()[0],u=Ta({stream:s.unwrap().unwrap(),remoteAddr:c,localAddr:l,onDataRead:a.onData,onDataWrite:a.onData,log:e.log.newScope("circuit-relay:connection")});await this.components.upgrader.upgradeInbound(u,{limits:a.getLimits(),signal:n}),u.log("inbound relayed connection established to %p with limits %o, over connection %s",i,o.limit??"none",t.id)}finally{n?.clear()}}};function Cp(r={}){return e=>new Mo(e,r)}function Lp(r={}){return e=>new qo(e,r)}return Ml(Bp);})();
|
|
2
|
+
"use strict";var Libp2PCircuitRelayV2=(()=>{var ts=Object.defineProperty;var $l=Object.getOwnPropertyDescriptor;var Wl=Object.getOwnPropertyNames;var jl=Object.prototype.hasOwnProperty;var _e=(r,e)=>{for(var t in e)ts(r,t,{get:e[t],enumerable:!0})},Gl=(r,e,t,n)=>{if(e&&typeof e=="object"||typeof e=="function")for(let s of Wl(e))!jl.call(r,s)&&s!==t&&ts(r,s,{get:()=>e[s],enumerable:!(n=$l(e,s))||n.enumerable});return r};var Yl=r=>Gl(ts({},"__esModule",{value:!0}),r);var $p={};_e($p,{RELAY_V2_HOP_CODEC:()=>Me,RELAY_V2_STOP_CODEC:()=>tr,circuitRelayServer:()=>Vp,circuitRelayTransport:()=>Hp});function Zl(r){return typeof r?.handleEvent=="function"}function Xl(r){return(r!==!0&&r!==!1&&r?.once)??!1}var Ae=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=Xl(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))}Zl(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 rt=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"}},or=class extends Error{static name="InvalidPublicKeyError";constructor(e="Invalid public key"){super(e),this.name="InvalidPublicKeyError"}};var An=class extends Error{static name="StreamResetError";constructor(e="The stream has been reset"){super(e),this.name="StreamResetError"}};var mt=class extends Error{static name="StreamStateError";constructor(e="The stream is in an invalid state"){super(e),this.name="StreamStateError"}},kr=class extends Error{static name="StreamBufferError";constructor(e="The stream buffer was full"){super(e),this.name="StreamBufferError"}};var Tn=class extends Error{static name="InvalidCIDError";constructor(e="Invalid CID"){super(e),this.name="InvalidCIDError"}},In=class extends Error{static name="InvalidMultihashError";constructor(e="Invalid Multihash"){super(e),this.name="InvalidMultihashError"}};var Dn=class extends Error{static name="InvalidMessageError";constructor(e="Invalid message"){super(e),this.name="InvalidMessageError"}};var Cn=class extends Error{static name="DialError";constructor(e="Dial error"){super(e),this.name="DialError"}},Ut=class extends Error{static name="ListenError";constructor(e="Listen error"){super(e),this.name="ListenError"}};var sr=class extends Error{static name="UnsupportedKeyTypeError";constructor(e="Unsupported key type"){super(e),this.name="UnsupportedKeyTypeError"}};var Ln=class extends Event{data;constructor(e,t){super("message",t),this.data=e}},ir=class extends Event{error;local;constructor(e,t,n){super("close",n),this.error=t,this.local=e}},Rn=class extends ir{constructor(e,t){super(!0,e,t)}},Bn=class extends ir{constructor(e,t){super(!1,e,t)}};var rs=Symbol.for("@libp2p/peer-id");var Va="keep-alive";function Ha(r){return r!=null&&typeof r.start=="function"&&typeof r.stop=="function"}async function $a(...r){let e=[];for(let t of r)Ha(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 Wa(...r){let e=[];for(let t of r)Ha(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 Ga=Symbol.for("@libp2p/transport");var ja;(function(r){r[r.FATAL_ALL=0]="FATAL_ALL",r[r.NO_FATAL=1]="NO_FATAL"})(ja||(ja={}));var Ya=Symbol.for("@libp2p/service-capabilities"),Za=Symbol.for("@libp2p/service-dependencies");var as={};_e(as,{base58btc:()=>te,base58flickr:()=>of});var Am=new Uint8Array(0);function Xa(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 nt(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 Qa(r){return new TextEncoder().encode(r)}function Ja(r){return new TextDecoder().decode(r)}function Ql(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,R=new Uint8Array(_);g!==S;){for(var C=y[g],N=0,B=_-1;(C!==0||N<h)&&B!==-1;B--,N++)C+=256*R[B]>>>0,R[B]=C%a>>>0,C=C/a>>>0;if(C!==0)throw new Error("Non-zero carry");h=N,g++}for(var I=_-h;I!==_&&R[I]===0;)I++;for(var U=c.repeat(x);I<_;++I)U+=r.charAt(R[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 R=t[y.charCodeAt(x)];if(R===255)return;for(var C=0,N=S-1;(R!==0||C<g)&&N!==-1;N--,C++)R+=a*_[N]>>>0,_[N]=R%256>>>0,R=R/256>>>0;if(R!==0)throw new Error("Non-zero carry");g=C,x++}if(y[x]!==" "){for(var B=S-g;B!==S&&_[B]===0;)B++;for(var I=new Uint8Array(h+(S-B)),U=h;B!==S;)I[U++]=_[B++];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 Jl=Ql,ef=Jl,tc=ef;var ns=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")}},os=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 rc(this,e)}},ss=class{decoders;constructor(e){this.decoders=e}or(e){return rc(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 rc(r,e){return new ss({...r.decoders??{[r.prefix]:r},...e.decoders??{[e.prefix]:e}})}var is=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 ns(e,t,n),this.decoder=new os(e,t,s)}encode(e){return this.encoder.encode(e)}decode(e){return this.decoder.decode(e)}};function ar({name:r,prefix:e,encode:t,decode:n}){return new is(r,e,t,n)}function yt({name:r,prefix:e,alphabet:t}){let{encode:n,decode:s}=tc(t,r);return ar({prefix:e,name:r,encode:n,decode:o=>nt(s(o))})}function tf(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 rf(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 nf(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=nf(n);return ar({prefix:e,name:r,encode(o){return rf(o,n,t)},decode(o){return tf(o,s,t,r)}})}var te=yt({name:"base58btc",prefix:"z",alphabet:"123456789ABCDEFGHJKLMNPQRSTUVWXYZabcdefghijkmnopqrstuvwxyz"}),of=yt({name:"base58flickr",prefix:"Z",alphabet:"123456789abcdefghijkmnopqrstuvwxyzABCDEFGHJKLMNPQRSTUVWXYZ"});var cs={};_e(cs,{base32:()=>gt,base32hex:()=>uf,base32hexpad:()=>ff,base32hexpadupper:()=>df,base32hexupper:()=>lf,base32pad:()=>af,base32padupper:()=>cf,base32upper:()=>sf,base32z:()=>hf});var gt=se({prefix:"b",name:"base32",alphabet:"abcdefghijklmnopqrstuvwxyz234567",bitsPerChar:5}),sf=se({prefix:"B",name:"base32upper",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZ234567",bitsPerChar:5}),af=se({prefix:"c",name:"base32pad",alphabet:"abcdefghijklmnopqrstuvwxyz234567=",bitsPerChar:5}),cf=se({prefix:"C",name:"base32padupper",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZ234567=",bitsPerChar:5}),uf=se({prefix:"v",name:"base32hex",alphabet:"0123456789abcdefghijklmnopqrstuv",bitsPerChar:5}),lf=se({prefix:"V",name:"base32hexupper",alphabet:"0123456789ABCDEFGHIJKLMNOPQRSTUV",bitsPerChar:5}),ff=se({prefix:"t",name:"base32hexpad",alphabet:"0123456789abcdefghijklmnopqrstuv=",bitsPerChar:5}),df=se({prefix:"T",name:"base32hexpadupper",alphabet:"0123456789ABCDEFGHIJKLMNOPQRSTUV=",bitsPerChar:5}),hf=se({prefix:"h",name:"base32z",alphabet:"ybndrfg8ejkmcpqxot1uwisza345h769",bitsPerChar:5});var us={};_e(us,{base36:()=>Mr,base36upper:()=>pf});var Mr=yt({prefix:"k",name:"base36",alphabet:"0123456789abcdefghijklmnopqrstuvwxyz"}),pf=yt({prefix:"K",name:"base36upper",alphabet:"0123456789ABCDEFGHIJKLMNOPQRSTUVWXYZ"});var mf=sc,nc=128,yf=127,gf=~yf,bf=Math.pow(2,31);function sc(r,e,t){e=e||[],t=t||0;for(var n=t;r>=bf;)e[t++]=r&255|nc,r/=128;for(;r&gf;)e[t++]=r&255|nc,r>>>=7;return e[t]=r|0,sc.bytes=t-n+1,e}var wf=ls,xf=128,oc=127;function ls(r,n){var t=0,n=n||0,s=0,o=n,i,a=r.length;do{if(o>=a)throw ls.bytes=0,new RangeError("Could not decode varint");i=r[o++],t+=s<28?(i&oc)<<s:(i&oc)*Math.pow(2,s),s+=7}while(i>=xf);return ls.bytes=o-n,t}var Ef=Math.pow(2,7),Sf=Math.pow(2,14),vf=Math.pow(2,21),_f=Math.pow(2,28),Af=Math.pow(2,35),Tf=Math.pow(2,42),If=Math.pow(2,49),Df=Math.pow(2,56),Cf=Math.pow(2,63),Lf=function(r){return r<Ef?1:r<Sf?2:r<vf?3:r<_f?4:r<Af?5:r<Tf?6:r<If?7:r<Df?8:r<Cf?9:10},Rf={encode:mf,decode:wf,encodingLength:Lf},Bf=Rf,Fr=Bf;function Kr(r,e=0){return[Fr.decode(r,e),Fr.decode.bytes]}function cr(r,e,t=0){return Fr.encode(r,e,t),e}function ur(r){return Fr.encodingLength(r)}function Ge(r,e){let t=e.byteLength,n=ur(r),s=n+ur(t),o=new Uint8Array(s+t);return cr(r,o,0),cr(t,o,n),o.set(e,s),new lr(r,t,e,o)}function Ye(r){let e=nt(r),[t,n]=Kr(e),[s,o]=Kr(e.subarray(n)),i=e.subarray(n+o);if(i.byteLength!==s)throw new Error("Incorrect length");return new lr(t,s,i,e)}function ic(r,e){if(r===e)return!0;{let t=e;return r.code===t.code&&r.size===t.size&&t.bytes instanceof Uint8Array&&Xa(r.bytes,t.bytes)}}var lr=class{code;size;digest;bytes;constructor(e,t,n,s){this.code=e,this.size=t,this.digest=n,this.bytes=s}};function ac(r,e){let{bytes:t,version:n}=r;return n===0?Pf(t,fs(r),e??te.encoder):Nf(t,fs(r),e??gt.encoder)}var cc=new WeakMap;function fs(r){let e=cc.get(r);if(e==null){let t=new Map;return cc.set(r,t),t}return e}var ue=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!==qr)throw new Error("Cannot convert a non dag-pb CID to CIDv0");if(t.code!==Uf)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=Ge(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&&ic(e.multihash,n.multihash)}toString(e){return ac(this,e)}toJSON(){return{"/":ac(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??uc(n,s,o.bytes))}else if(t[kf]===!0){let{version:n,multihash:s,code:o}=t,i=Ye(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!==qr)throw new Error(`Version 0 CID must use dag-pb (code: ${qr}) block encoding`);return new r(e,t,n,n.bytes)}case 1:{let s=uc(e,t,n.bytes);return new r(e,t,n,s)}default:throw new Error("Invalid version")}}static createV0(e){return r.create(0,qr,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=nt(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 lr(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]=Kr(e.subarray(t));return t+=p,f},s=n(),o=qr;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]=Of(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 fs(o).set(n,e),o}};function Of(r,e){switch(r[0]){case"Q":{let t=e??te;return[te.prefix,t.decode(`${te.prefix}${r}`)]}case te.prefix:{let t=e??te;return[te.prefix,t.decode(r)]}case gt.prefix:{let t=e??gt;return[gt.prefix,t.decode(r)]}case Mr.prefix:{let t=e??Mr;return[Mr.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 Pf(r,e,t){let{prefix:n}=t;if(n!==te.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 Nf(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 qr=112,Uf=18;function uc(r,e,t){let n=ur(r),s=n+ur(e),o=new Uint8Array(s+t.byteLength);return cr(r,o,0),cr(e,o,n),o.set(t,s),o}var kf=Symbol.for("@ipld/js-cid/CID");var ds={};_e(ds,{identity:()=>Fe});var lc=0,Mf="identity",fc=nt;function Ff(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 Ge(lc,fc(r))}var Fe={code:lc,name:Mf,encode:fc,digest:Ff};function le(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 re(r=0){return new Uint8Array(r)}function Te(r=0){return new Uint8Array(r)}function st(r,e){e==null&&(e=r.reduce((s,o)=>s+o.length,0));let t=Te(e),n=0;for(let s of r)t.set(s,n),n+=s.length;return t}var hc=Symbol.for("@achingbrain/uint8arraylist");function dc(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 Pn(r){return!!r?.[hc]}var J=class r{bufs;length;[hc]=!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(Pn(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(Pn(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=dc(this.bufs,e);return t.buf[t.index]}set(e,t){let n=dc(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(Pn(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 st(n,s)}subarray(e,t){let{bufs:n,length:s}=this._subList(e,t);return n.length===1?n[0]:st(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(!Pn(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=Te(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=re(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=re(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=re(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=Te(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=re(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=re(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=re(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=re(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=re(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(!le(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 hs={};_e(hs,{base10:()=>Kf});var Kf=yt({prefix:"9",name:"base10",alphabet:"0123456789"});var ps={};_e(ps,{base16:()=>qf,base16upper:()=>zf});var qf=se({prefix:"f",name:"base16",alphabet:"0123456789abcdef",bitsPerChar:4}),zf=se({prefix:"F",name:"base16upper",alphabet:"0123456789ABCDEF",bitsPerChar:4});var ms={};_e(ms,{base2:()=>Vf});var Vf=se({prefix:"0",name:"base2",alphabet:"01",bitsPerChar:1});var ys={};_e(ys,{base256emoji:()=>Gf});var pc=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}"),Hf=pc.reduce((r,e,t)=>(r[t]=e,r),[]),$f=pc.reduce((r,e,t)=>{let n=e.codePointAt(0);if(n==null)throw new Error(`Invalid character: ${e}`);return r[n]=t,r},[]);function Wf(r){return r.reduce((e,t)=>(e+=Hf[t],e),"")}function jf(r){let e=[];for(let t of r){let n=t.codePointAt(0);if(n==null)throw new Error(`Invalid character: ${t}`);let s=$f[n];if(s==null)throw new Error(`Non-base256emoji character: ${t}`);e.push(s)}return new Uint8Array(e)}var Gf=ar({prefix:"\u{1F680}",name:"base256emoji",encode:Wf,decode:jf});var bs={};_e(bs,{base64:()=>Yf,base64pad:()=>Zf,base64url:()=>gs,base64urlpad:()=>Xf});var Yf=se({prefix:"m",name:"base64",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/",bitsPerChar:6}),Zf=se({prefix:"M",name:"base64pad",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/=",bitsPerChar:6}),gs=se({prefix:"u",name:"base64url",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789-_",bitsPerChar:6}),Xf=se({prefix:"U",name:"base64urlpad",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789-_=",bitsPerChar:6});var ws={};_e(ws,{base8:()=>Qf});var Qf=se({prefix:"7",name:"base8",alphabet:"01234567",bitsPerChar:3});var xs={};_e(xs,{identity:()=>Jf});var Jf=ar({prefix:"\0",name:"identity",encode:r=>Ja(r),decode:r=>Qa(r)});var c0=new TextEncoder,u0=new TextDecoder;var vs={};_e(vs,{sha256:()=>fr,sha512:()=>nd});var rd=20;function Ss({name:r,code:e,encode:t,minDigestLength:n,maxDigestLength:s}){return new Es(r,e,t,n,s)}var Es=class{name;code;encode;minDigestLength;maxDigestLength;constructor(e,t,n,s,o){this.name=e,this.code=t,this.encode=n,this.minDigestLength=s??rd,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?mc(n,this.code,t?.truncate):n.then(s=>mc(s,this.code,t?.truncate))}else throw Error("Unknown type, must be binary type")}};function mc(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 Ge(e,r)}function gc(r){return async e=>new Uint8Array(await crypto.subtle.digest(r,e))}var fr=Ss({name:"sha2-256",code:18,encode:gc("SHA-256")}),nd=Ss({name:"sha2-512",code:19,encode:gc("SHA-512")});var zr={...xs,...ms,...ws,...hs,...ps,...cs,...us,...as,...bs,...ys},E0={...vs,...ds};function wc(r,e,t,n){return{name:r,prefix:e,encoder:{name:r,prefix:e,encode:t},decoder:{decode:n}}}var bc=wc("utf8","u",r=>"u"+new TextDecoder("utf8").decode(r),r=>new TextEncoder().encode(r.substring(1))),_s=wc("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=Te(r.length);for(let t=0;t<r.length;t++)e[t]=r.charCodeAt(t);return e}),od={utf8:bc,"utf-8":bc,hex:zr.base16,latin1:_s,ascii:_s,binary:_s,...zr},Nn=od;function M(r,e="utf8"){let t=Nn[e];if(t==null)throw new Error(`Unsupported encoding "${e}"`);return t.decoder.decode(`${t.prefix}${r}`)}function $(r,e="utf8"){let t=Nn[e];if(t==null)throw new Error(`Unsupported encoding "${e}"`);return t.encoder.encode(r).substring(1)}var sd=parseInt("11111",2),As=parseInt("10000000",2),id=parseInt("01111111",2),xc={0:Vr,1:Vr,2:ad,3:ld,4:fd,5:ud,6:cd,16:Vr,22:Vr,48:Vr};function it(r,e={offset:0}){let t=r[e.offset]&sd;if(e.offset++,xc[t]!=null)return xc[t](r,e);throw new Error("No decoder for tag "+t)}function Hr(r,e){let t=0;if((r[e.offset]&As)===As){let n=r[e.offset]&id,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 Vr(r,e){Hr(r,e);let t=[];for(;!(e.offset>=r.byteLength);){let n=it(r,e);if(n===null)break;t.push(n)}return t}function ad(r,e){let t=Hr(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 cd(r,e){let t=Hr(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 ud(r,e){return e.offset++,null}function ld(r,e){let t=Hr(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 fd(r,e){let t=Hr(r,e),n=r.subarray(e.offset,e.offset+t);return e.offset+=t,n}function dd(r){let e=r.toString(16);e.length%2===1&&(e="0"+e);let t=new J;for(let n=0;n<e.length;n+=2)t.append(Uint8Array.from([parseInt(`${e[n]}${e[n+1]}`,16)]));return t}function Ts(r){if(r.byteLength<128)return Uint8Array.from([r.byteLength]);let e=dd(r.byteLength);return new J(Uint8Array.from([e.byteLength|As]),e)}function Ie(r){let e=new J,t=128;return(r.subarray()[0]&t)===t&&e.append(Uint8Array.from([0])),e.append(r),new J(Uint8Array.from([2]),Ts(e),e)}function Un(r){let e=Uint8Array.from([0]),t=new J(e,r);return new J(Uint8Array.from([3]),Ts(t),t)}function bt(r,e=48){let t=new J;for(let n of r)t.append(n);return new J(Uint8Array.from([e]),Ts(t),t)}async function Ec(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,t.subarray());return n?.signal?.throwIfAborted(),o}var hd=Uint8Array.from([6,8,42,134,72,206,61,3,1,7]),pd=Uint8Array.from([6,5,43,129,4,0,34]),md=Uint8Array.from([6,5,43,129,4,0,35]),yd={ext:!0,kty:"EC",crv:"P-256"},gd={ext:!0,kty:"EC",crv:"P-384"},bd={ext:!0,kty:"EC",crv:"P-521"},Is=32,Ds=48,Cs=66;function Ls(r){let e=it(r);return Sc(e)}function Sc(r){let e=r[1][1][0],t=1,n,s;if(e.byteLength===Is*2+1)return n=$(e.subarray(t,t+Is),"base64url"),s=$(e.subarray(t+Is),"base64url"),new dr({...yd,key_ops:["verify"],x:n,y:s});if(e.byteLength===Ds*2+1)return n=$(e.subarray(t,t+Ds),"base64url"),s=$(e.subarray(t+Ds),"base64url"),new dr({...gd,key_ops:["verify"],x:n,y:s});if(e.byteLength===Cs*2+1)return n=$(e.subarray(t,t+Cs),"base64url"),s=$(e.subarray(t+Cs),"base64url"),new dr({...bd,key_ops:["verify"],x:n,y:s});throw new oe(`coordinates were wrong length, got ${e.byteLength}, expected 65, 97 or 133`)}function vc(r){return bt([Ie(Uint8Array.from([1])),bt([wd(r.crv)],160),bt([Un(new J(Uint8Array.from([4]),M(r.x??"","base64url"),M(r.y??"","base64url")))],161)]).subarray()}function wd(r){if(r==="P-256")return hd;if(r==="P-384")return pd;if(r==="P-521")return md;throw new oe(`Invalid curve ${r}`)}var dr=class{type="ECDSA";jwk;_raw;constructor(e){this.jwk=e}get raw(){return this._raw==null&&(this._raw=vc(this.jwk)),this._raw}toMultihash(){return Fe.digest(Ze(this))}toCID(){return ue.createV1(114,this.toMultihash())}toString(){return te.encode(this.toMultihash().bytes).substring(1)}equals(e){return e==null||!(e.raw instanceof Uint8Array)?!1:le(this.raw,e.raw)}async verify(e,t,n){return Ec(this.jwk,t,e,n)}};function Rs(r){return r instanceof Uint8Array||ArrayBuffer.isView(r)&&r.constructor.name==="Uint8Array"&&"BYTES_PER_ELEMENT"in r&&r.BYTES_PER_ELEMENT===1}function wt(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 Oe(r,e,t=""){let n=Rs(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 kn(r){if(typeof r!="function"||typeof r.create!="function")throw new TypeError("Hash must wrapped by utils.createHasher");if(wt(r.outputLen),wt(r.blockLen),r.outputLen<1)throw new Error('"outputLen" must be >= 1');if(r.blockLen<1)throw new Error('"blockLen" must be >= 1')}function hr(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 Mn(r,e){Oe(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 ct(...r){for(let e=0;e<r.length;e++)r[e].fill(0)}function Fn(r){return new DataView(r.buffer,r.byteOffset,r.byteLength)}function Ke(r,e){return r<<32-e|r>>>e}var Ac=typeof Uint8Array.from([]).toHex=="function"&&typeof Uint8Array.fromHex=="function",xd=Array.from({length:256},(r,e)=>e.toString(16).padStart(2,"0"));function Kn(r){if(Oe(r),Ac)return r.toHex();let e="";for(let t=0;t<r.length;t++)e+=xd[r[t]];return e}var at={_0:48,_9:57,A:65,F:70,a:97,f:102};function _c(r){if(r>=at._0&&r<=at._9)return r-at._0;if(r>=at.A&&r<=at.F)return r-(at.A-10);if(r>=at.a&&r<=at.f)return r-(at.a-10)}function $r(r){if(typeof r!="string")throw new TypeError("hex string expected, got "+typeof r);if(Ac)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=_c(r.charCodeAt(o)),a=_c(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 Bs(...r){let e=0;for(let n=0;n<r.length;n++){let s=r[n];Oe(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 Os(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 Tc(r=32){wt(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 Ps=r=>({oid:Uint8Array.from([6,9,96,134,72,1,101,3,4,2,r])});function Ic(r,e,t){return r&e^~r&t}function Dc(r,e,t){return r&e^r&t^e&t}var Wr=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=Fn(this.buffer)}update(e){hr(this),Oe(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=Fn(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){hr(this),Mn(e,this),this.finished=!0;let{buffer:t,view:n,blockLen:s,isLE:o}=this,{pos:i}=this;t[i++]=128,ct(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=Fn(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()}},ut=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 qn=BigInt(4294967295),Cc=BigInt(32);function Ed(r,e=!1){return e?{h:Number(r&qn),l:Number(r>>Cc&qn)}:{h:Number(r>>Cc&qn)|0,l:Number(r&qn)|0}}function Lc(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}=Ed(r[o],e);[n[o],s[o]]=[i,a]}return[n,s]}var Ns=(r,e,t)=>r>>>t,Us=(r,e,t)=>r<<32-t|e>>>t,kt=(r,e,t)=>r>>>t|e<<32-t,Mt=(r,e,t)=>r<<32-t|e>>>t,jr=(r,e,t)=>r<<64-t|e>>>t-32,Gr=(r,e,t)=>r>>>t-32|e<<64-t;function Xe(r,e,t,n){let s=(e>>>0)+(n>>>0);return{h:r+t+(s/2**32|0)|0,l:s|0}}var Rc=(r,e,t)=>(r>>>0)+(e>>>0)+(t>>>0),Bc=(r,e,t,n)=>e+t+n+(r/2**32|0)|0,Oc=(r,e,t,n)=>(r>>>0)+(e>>>0)+(t>>>0)+(n>>>0),Pc=(r,e,t,n,s)=>e+t+n+s+(r/2**32|0)|0,Nc=(r,e,t,n,s)=>(r>>>0)+(e>>>0)+(t>>>0)+(n>>>0)+(s>>>0),Uc=(r,e,t,n,s,o)=>e+t+n+s+o+(r/2**32|0)|0;var vd=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]),xt=new Uint32Array(64),ks=class extends Wr{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)xt[f]=e.getUint32(t,!1);for(let f=16;f<64;f++){let p=xt[f-15],d=xt[f-2],y=Ke(p,7)^Ke(p,18)^p>>>3,x=Ke(d,17)^Ke(d,19)^d>>>10;xt[f]=x+xt[f-7]+y+xt[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=Ke(a,6)^Ke(a,11)^Ke(a,25),d=l+p+Ic(a,c,u)+vd[f]+xt[f]|0,x=(Ke(n,2)^Ke(n,13)^Ke(n,22))+Dc(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(){ct(xt)}destroy(){this.destroyed=!0,this.set(0,0,0,0,0,0,0,0),ct(this.buffer)}},Ms=class extends ks{A=ut[0]|0;B=ut[1]|0;C=ut[2]|0;D=ut[3]|0;E=ut[4]|0;F=ut[5]|0;G=ut[6]|0;H=ut[7]|0;constructor(){super(32)}};var kc=Lc(["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))),_d=kc[0],Ad=kc[1],Et=new Uint32Array(80),St=new Uint32Array(80),Fs=class extends Wr{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)Et[_]=e.getUint32(t),St[_]=e.getUint32(t+=4);for(let _=16;_<80;_++){let R=Et[_-15]|0,C=St[_-15]|0,N=kt(R,C,1)^kt(R,C,8)^Ns(R,C,7),B=Mt(R,C,1)^Mt(R,C,8)^Us(R,C,7),I=Et[_-2]|0,U=St[_-2]|0,Z=kt(I,U,19)^jr(I,U,61)^Ns(I,U,6),k=Mt(I,U,19)^Gr(I,U,61)^Us(I,U,6),m=Oc(B,k,St[_-7],St[_-16]),b=Pc(m,N,Z,Et[_-7],Et[_-16]);Et[_]=b|0,St[_]=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 R=kt(f,p,14)^kt(f,p,18)^jr(f,p,41),C=Mt(f,p,14)^Mt(f,p,18)^Gr(f,p,41),N=f&d^~f&x,B=p&y^~p&h,I=Nc(S,C,B,Ad[_],St[_]),U=Uc(I,g,R,N,_d[_],Et[_]),Z=I|0,k=kt(n,s,28)^jr(n,s,34)^jr(n,s,39),m=Mt(n,s,28)^Gr(n,s,34)^Gr(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}=Xe(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=Rc(Z,m,v);n=Bc(E,U,k,b),s=E|0}({h:n,l:s}=Xe(this.Ah|0,this.Al|0,n|0,s|0)),{h:o,l:i}=Xe(this.Bh|0,this.Bl|0,o|0,i|0),{h:a,l:c}=Xe(this.Ch|0,this.Cl|0,a|0,c|0),{h:u,l}=Xe(this.Dh|0,this.Dl|0,u|0,l|0),{h:f,l:p}=Xe(this.Eh|0,this.El|0,f|0,p|0),{h:d,l:y}=Xe(this.Fh|0,this.Fl|0,d|0,y|0),{h:x,l:h}=Xe(this.Gh|0,this.Gl|0,x|0,h|0),{h:g,l:S}=Xe(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(){ct(Et,St)}destroy(){this.destroyed=!0,ct(this.buffer),this.set(0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0)}},Ks=class extends Fs{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 pr=Os(()=>new Ms,Ps(1));var zn=Os(()=>new Ks,Ps(3));var V=(r,e,t)=>Oe(r,e,t),zs=wt,mr=Kn,de=(...r)=>Bs(...r),yr=r=>$r(r),Ft=Rs,Yr=r=>Tc(r),Hn=BigInt(0),qs=BigInt(1);function qe(r,e=""){if(typeof r!="boolean"){let t=e&&`"${e}" `;throw new TypeError(t+"expected boolean, got type="+typeof r)}return r}function $n(r){if(typeof r=="bigint"){if(!Vn(r))throw new RangeError("positive bigint expected, got "+r)}else zs(r);return r}function ze(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 Zr(r){let e=$n(r).toString(16);return e.length&1?"0"+e:e}function Mc(r){if(typeof r!="string")throw new TypeError("hex string expected, got "+typeof r);return r===""?Hn:BigInt("0x"+r)}function Kt(r){return Mc(Kn(r))}function Qe(r){return Mc(Kn(Xr(Oe(r)).reverse()))}function Wn(r,e){if(wt(e),e===0)throw new RangeError("zero length");r=$n(r);let t=r.toString(16);if(t.length>e*2)throw new RangeError("number too large");return $r(t.padStart(e*2,"0"))}function Vs(r,e){return Wn(r,e).reverse()}function Fc(r,e){if(r=V(r),e=V(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 Xr(r){return Uint8Array.from(V(r))}function jn(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 Vn=r=>typeof r=="bigint"&&Hn<=r;function Td(r,e,t){return Vn(r)&&Vn(e)&&Vn(t)&&e<=r&&r<t}function gr(r,e,t,n){if(!Td(e,t,n))throw new RangeError("expected valid "+r+": "+t+" <= n < "+n+", got "+e)}function br(r){if(r<Hn)throw new Error("expected non-negative bigint, got "+r);let e;for(e=0;r>Hn;r>>=qs,e+=1);return e}var Qr=r=>(qs<<BigInt(r))-qs;function Kc(r,e,t){if(wt(r,"hashLen"),wt(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 Ve(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 Hs=()=>{throw new Error("not implemented")};var be=BigInt(0),ie=BigInt(1),qt=BigInt(2),Hc=BigInt(3),$c=BigInt(4),Wc=BigInt(5),Id=BigInt(7),jc=BigInt(8),Dd=BigInt(9),Gc=BigInt(16);function ce(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 ee(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 qc(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=ce(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 ce(s,e)}function $s(r,e,t){let n=r;if(!n.eql(n.sqr(e),t))throw new Error("Cannot find square root")}function Yc(r,e){let t=r,n=(t.ORDER+ie)/$c,s=t.pow(e,n);return $s(t,s,e),s}function Cd(r,e){let t=r,n=(t.ORDER-Wc)/jc,s=t.mul(e,qt),o=t.pow(s,n),i=t.mul(e,o),a=t.mul(t.mul(i,qt),o),c=t.mul(i,t.sub(a,t.ONE));return $s(t,c,e),c}function Ld(r){let e=wr(r),t=Zc(r),n=t(e,e.neg(e.ONE)),s=t(e,n),o=t(e,e.neg(n)),i=(r+Id)/Gc;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 $s(u,g,c),g})}function Zc(r){if(r<Hc)throw new Error("sqrt is not defined for small field");let e=r-ie,t=0;for(;e%qt===be;)e/=qt,t++;let n=qt,s=wr(r);for(;zc(s,n)===1;)if(n++>1e3)throw new Error("Cannot find square root: probably non-prime P");if(t===1)return Yc;let o=s.pow(n,e),i=(e+ie)/qt;return function(c,u){let l=c;if(l.is0(u))return u;if(zc(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 Rd(r){return r%$c===Hc?Yc:r%jc===Wc?Cd:r%Gc===Dd?Ld(r):Zc(r)}var lt=(r,e)=>(ce(r,e)&ie)===ie,Bd=["create","isValid","is0","neg","inv","sqrt","sqr","eql","add","sub","mul","pow","div","addN","subN","mulN","sqrN"];function Ws(r){let e={ORDER:"bigint",BYTES:"number",BITS:"number"},t=Bd.reduce((n,s)=>(n[s]="function",n),e);if(Ve(r,t),ze(r.BYTES,"BYTES"),ze(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 Od(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 Jr(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 zc(r,e){let t=r,n=(t.ORDER-ie)/qt,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 Pd(r,e){if(e!==void 0&&zs(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=br(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 Vc=new WeakMap,Gn=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}=Pd(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 ce(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 ce(-e,this.ORDER)}eql(e,t){return e===t}sqr(e){return ce(e*e,this.ORDER)}add(e,t){return ce(e+t,this.ORDER)}sub(e,t){return ce(e-t,this.ORDER)}mul(e,t){return ce(e*t,this.ORDER)}pow(e,t){return Od(this,e,t)}div(e,t){return ce(e*qc(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 qc(e,this.ORDER)}sqrt(e){let t=Vc.get(this);return t||Vc.set(this,t=Rd(this.ORDER)),t(this,e)}toBytes(e){return this.isLE?Vs(e,this.BYTES):Wn(e,this.BYTES)}fromBytes(e,t=!1){V(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?Qe(e):Kt(e);if(a&&(c=ce(c,i)),!t&&!this.isValid(c))throw new Error("invalid field element: outside of range 0..ORDER");return c}invertBatch(e){return Jr(this,e)}cmov(e,t,n){return qe(n,"condition"),n?t:e}};Object.freeze(Gn.prototype);function wr(r,e={}){return new Gn(r,e)}function Xc(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=br(r-ie);return Math.ceil(e/8)}function js(r){let e=Xc(r);return e+Math.ceil(e/2)}function Gs(r,e,t=!1){V(r);let n=r.length,s=Xc(e),o=Math.max(js(e),16);if(n<o||n>1024)throw new Error("expected "+o+"-1024 bytes of input, got "+n);let i=t?Qe(r):Kt(r),a=ce(i,e-ie)+ie;return t?Vs(a,s):Wn(a,s)}var xr=BigInt(0),zt=BigInt(1);function en(r,e){let t=e.negate();return r?t:e}function Vt(r,e){let t=Jr(r.Fp,e.map(n=>n.Z));return e.map((n,s)=>r.fromAffine(n.toAffine(t[s])))}function tu(r,e){if(!Number.isSafeInteger(r)||r<=0||r>e)throw new Error("invalid window size, expected [1.."+e+"], got W="+r)}function Ys(r,e){tu(r,e);let t=Math.ceil(e/r)+1,n=2**(r-1),s=2**r,o=Qr(r),i=BigInt(r);return{windows:t,windowSize:n,mask:o,maxNumber:s,shiftBy:i}}function Qc(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,p=a<0,d=e%2!==0;return{nextN:c,offset:l,isZero:f,isNeg:p,isNegF:d,offsetF:u}}var Zs=new WeakMap,ru=new WeakMap;function Xs(r){return ru.get(r)||1}function Jc(r){if(r!==xr)throw new Error("invalid wNAF")}var Er=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>xr;)t&zt&&(n=n.add(s)),s=s.double(),t>>=zt;return n}precomputeWindow(e,t){let{windows:n,windowSize:s}=Ys(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=Ys(e,this.bits);for(let a=0;a<i.windows;a++){let{nextN:c,offset:u,isZero:l,isNeg:f,isNegF:p,offsetF:d}=Qc(n,a,i);n=c,l?o=o.add(en(p,t[d])):s=s.add(en(f,t[u]))}return Jc(n),{p:s,f:o}}wNAFUnsafe(e,t,n,s=this.ZERO){let o=Ys(e,this.bits);for(let i=0;i<o.windows&&n!==xr;i++){let{nextN:a,offset:c,isZero:u,isNeg:l}=Qc(n,i,o);if(n=a,!u){let f=t[c];s=s.add(l?f.negate():f)}}return Jc(n),s}getPrecomputes(e,t,n){let s=Zs.get(t);return s||(s=this.precomputeWindow(t,e),e!==1&&(typeof n=="function"&&(s=n(s)),Zs.set(t,s))),s}cached(e,t,n){let s=Xs(e);return this.wNAF(s,this.getPrecomputes(s,e,n),t)}unsafe(e,t,n,s){let o=Xs(e);return o===1?this._unsafeLadder(e,t,s):this.wNAFUnsafe(o,this.getPrecomputes(o,e,n),t,s)}createCache(e,t){tu(t,this.bits),ru.set(e,t),Zs.delete(e)}hasCache(e){return Xs(e)!==1}};function nu(r,e,t,n){let s=e,o=r.ZERO,i=r.ZERO;for(;t>xr||n>xr;)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 eu(r,e,t){if(e){if(e.ORDER!==r)throw new Error("Field.ORDER must match order: Fp == p, Fn == n");return Ws(e),e}else return wr(r,{isLE:t})}function Yn(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>xr))throw new Error(`CURVE.${c} must be positive bigint`)}let s=eu(e.p,t.Fp,n),o=eu(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 Zn(r,e){return function(n){let s=r(n);return{secretKey:s,publicKey:e(s)}}}var vt=BigInt(0),me=BigInt(1),Qs=BigInt(2),Nd=BigInt(8);function Ud(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 ou(r,e={}){let t=e,n=Yn("edwards",r,t,t.FpFnLE),{Fp:s,Fn:o}=n,i=n.CURVE,{h:a}=i;Ve(t,{},{uvRatio:"function"});let c=Qs<<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:vt}}}:t.uvRatio;if(!Ud(s,i,i.Gx,i.Gy))throw new Error("bad curve params: generator point");function f(x,h,g=!1){let S=g?me:vt;return gr("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(vt,me,me,vt);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:R}=i;h=Xr(V(h,S,"point")),qe(g,"zip215");let C=Xr(h),N=h[S-1];C[S-1]=N&-129;let B=Qe(C),I=g?c:s.ORDER;gr("point.y",B,vt,I);let U=u(B*B),Z=u(U-me),k=u(R*U-_),{isValid:m,value:b}=l(Z,k);if(!m)throw new Error("bad point: invalid y coordinate");let v=(b&me)===me,E=(N&128)!==0;if(!g&&b===vt&&E)throw new Error("bad point: x=0 and x_0=1");return E!==v&&(b=u(-b)),d.fromAffine({x:b,y:B})}static fromHex(h,g=!1){return d.fromBytes(yr(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(Qs),this}assertValidity(){let h=this,{a:g,d:S}=i;if(h.is0())throw new Error("bad point: ZERO");let{X:_,Y:R,Z:C,T:N}=h,B=u(_*_),I=u(R*R),U=u(C*C),Z=u(U*U),k=u(B*g),m=u(U*u(k+I)),b=u(Z+u(S*u(B*I)));if(m!==b)throw new Error("bad point: equation left != right (1)");let v=u(_*R),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:R,Y:C,Z:N}=h,B=u(g*N),I=u(R*_),U=u(S*N),Z=u(C*_);return B===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,R=u(g*g),C=u(S*S),N=u(Qs*u(_*_)),B=u(h*R),I=g+S,U=u(u(I*I)-R-C),Z=B+C,k=Z-N,m=B-C,b=u(U*k),v=u(Z*m),E=u(U*m),w=u(k*Z);return new d(b,v,w,E)}add(h){p(h);let{a:g,d:S}=i,{X:_,Y:R,Z:C,T:N}=this,{X:B,Y:I,Z:U,T:Z}=h,k=u(_*B),m=u(R*I),b=u(N*S*Z),v=u(C*U),E=u((_+R)*(B+I)-k-m),w=v-b,A=v+b,D=u(m-g*k),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,_=>Vt(d,_));return Vt(d,[g,S])[0]}multiplyUnsafe(h){if(!o.isValid(h))throw new RangeError("invalid scalar: expected 0 <= sc < curve.n");return h===vt?d.ZERO:this.is0()||h===me?this:y.unsafe(this,h,g=>Vt(d,g))}isSmallOrder(){return this.clearCofactor().is0()}isTorsionFree(){return y.unsafe(this,i.n).is0()}toAffine(h){let g=this,S=h,{X:_,Y:R,Z:C}=g,N=g.is0();S==null&&(S=N?Nd:s.inv(C));let B=u(_*S),I=u(R*S),U=s.mul(C,S);if(N)return{x:vt,y:me};if(U!==me)throw new Error("invZ was invalid");return{x:B,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 mr(this.toBytes())}toString(){return`<Point ${this.is0()?"ZERO":this.toHex()}>`}}let y=new Er(d,o.BITS);return o.BITS>=8&&d.BASE.precompute(8),Object.freeze(d.prototype),Object.freeze(d),d}var Xn=class{static BASE;static ZERO;static Fp;static Fn;ep;constructor(e){this.ep=e}static fromBytes(e){Hs()}static fromHex(e){Hs()}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 mr(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 su(r,e,t={}){if(typeof e!="function")throw new Error('"hash" function param is required');let n=e,s=t;Ve(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&&(ze(u,"hash.outputLen"),u!==l))throw new Error(`hash.outputLen must be ${l}, got ${u}`);let f=s.randomBytes===void 0?Yr:s.randomBytes,p=s.adjustScalarBytes===void 0?m=>m:s.adjustScalarBytes,d=s.domain===void 0?(m,b,v)=>{if(qe(v,"phflag"),b.length||v)throw new Error("Contexts/pre-hash are not supported");return m}:s.domain;function y(m){return c.create(Qe(m))}function x(m){let b=B.secretKey;V(m,B.secretKey,"secretKey");let v=V(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,V(m,void 0,"context"),!!o)))}function _(m,b,v={}){m=V(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 V(z,B.signature,"result")}let R={zip215:s.zip215};function C(m,b,v,E=R){let{context:w}=E,A=E.zip215===void 0?!!R.zip215:E.zip215,D=B.signature;m=V(m,D,"signature"),b=V(b,void 0,"message"),v=V(v,B.publicKey,"publicKey"),A!==void 0&&qe(A,"zip215"),o&&(b=o(b));let T=D/2,L=m.subarray(0,T),P=Qe(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,B={secretKey:N,publicKey:N,signature:2*N,seed:N};function I(m){return m=m===void 0?f(B.seed):m,V(m,B.seed,"seed")}function U(m){return Ft(m)&&m.length===B.secretKey}function Z(m,b){try{return!!r.fromBytes(m,b===void 0?R.zip215:b)}catch{return!1}}let k={getExtendedPublicKey:h,randomSecretKey:I,isValidSecretKey:U,isValidPublicKey:Z,toMontgomery(m){let{y:b}=r.fromBytes(m),v=B.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=B.secretKey;V(m,b);let v=n(m.subarray(0,b));return p(v).subarray(0,b)}};return Object.freeze(B),Object.freeze(k),Object.freeze({keygen:Zn(I,g),getPublicKey:g,sign:_,verify:C,utils:k,Point:r,lengths:B})}function tn(r,e){if(ze(r),ze(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 kd(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 Md(r){if(!Ft(r)&&typeof r!="string")throw new Error("DST must be Uint8Array or ascii string");let e=typeof r=="string"?jn(r):r;if(e.length===0)throw new Error("DST must be non-empty");return e}function Js(r,e,t,n){V(r),ze(t),e=Md(e),e.length>255&&(e=n(de(jn("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,tn(e.length,1)),c=new Uint8Array(o),u=tn(t,2),l=new Array(i),f=n(de(c,r,u,tn(0,1),a));l[0]=n(de(f,tn(1,1),a));for(let d=1;d<i;d++){let y=[kd(f,l[d-1]),tn(d+1,1),a];l[d]=n(de(...y))}return de(...l).slice(0,t)}var iu="HashToScalar-";var Fd=BigInt(0),ft=BigInt(1),au=BigInt(2);var Kd=BigInt(5),qd=BigInt(8),Sr=BigInt("0x7fffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffed"),ni={p:Sr,n:BigInt("0x1000000000000000000000000000000014def9dea2f79cd65812631a5cf5d3ed"),h:qd,a:BigInt("0x7fffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffec"),d:BigInt("0x52036cee2b6ffe738cc740797779e89800700a4d4141d8ab75eb4dca135978a3"),Gx:BigInt("0x216936d3cd6e53fec0a4e231fdd6dc5c692cc7609525a7b2c9562d608f25d51a"),Gy:BigInt("0x6666666666666666666666666666666666666666666666666666666666666658")};function zd(r){let e=BigInt(10),t=BigInt(20),n=BigInt(40),s=BigInt(80),o=Sr,a=r*r%o*r%o,c=ee(a,au,o)*a%o,u=ee(c,ft,o)*r%o,l=ee(u,Kd,o)*u%o,f=ee(l,e,o)*l%o,p=ee(f,t,o)*f%o,d=ee(p,n,o)*p%o,y=ee(d,s,o)*d%o,x=ee(y,s,o)*d%o,h=ee(x,e,o)*l%o;return{pow_p_5_8:ee(h,au,o)*r%o,b2:a}}function Vd(r){return r[0]&=248,r[31]&=127,r[31]|=64,r}var ei=BigInt("19681161376707505956807079304988542015446066515923890162744021073123829784752");function oi(r,e){let t=Sr,n=ce(e*e*e,t),s=ce(n*n*e,t),o=zd(r*s).pow_p_5_8,i=ce(r*n*o,t),a=ce(e*i*i,t),c=i,u=ce(i*ei,t),l=a===r,f=a===ce(-r,t),p=a===ce(-r*ei,t);return l&&(i=c),(f||p)&&(i=u),lt(i,t)&&(i=ce(-i,t)),{isValid:l||f,value:i}}var At=ou(ni,{uvRatio:oi}),_t=At.Fp,lu=At.Fn;function Hd(r){return su(At,zn,Object.assign({adjustScalarBytes:Vd,zip215:!0},r))}var fu=Hd({});var ti=ei,$d=BigInt("25063068953384623474111414158702152701244531502492656460079210482610430750235"),Wd=BigInt("54469307008909316920995813868745141605393597292927456921205312896311721017578"),jd=BigInt("1159843021668779879193775521855586647937357759715417654439879720876111806838"),Gd=BigInt("40440834346308536858101042469323190826248399146238708352240133220865137265952"),cu=r=>oi(ft,r),Yd=BigInt("0x7fffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffff"),ri=r=>_t.create(Qe(r)&Yd);function uu(r){let{d:e}=ni,t=Sr,n=g=>_t.create(g),s=n(ti*r*r),o=n((s+ft)*jd),i=BigInt(-1),a=n((i-e*s)*n(s+e)),{isValid:c,value:u}=oi(o,a),l=n(u*r);lt(l,t)||(l=n(-l)),c||(u=l),c||(i=s);let f=n(i*(s-ft)*Gd-a),p=u*u,d=n((u+u)*a),y=n(f*$d),x=n(ft-p),h=n(ft+p);return new At(n(d*h),n(x*y),n(y*h),n(d*x))}var Tt=class r extends Xn{static BASE=new r(At.BASE);static ZERO=new r(At.ZERO);static Fp=_t;static Fn=lu;constructor(e){super(e)}static fromAffine(e){return new r(At.fromAffine(e))}assertSame(e){if(!(e instanceof r))throw new Error("RistrettoPoint expected")}init(e){return new r(e)}static fromBytes(e){Oe(e,32);let{a:t,d:n}=ni,s=Sr,o=R=>_t.create(R),i=ri(e);if(!Fc(_t.toBytes(i),e)||lt(i,s))throw new Error("invalid ristretto255 encoding 1");let a=o(i*i),c=o(ft+t*a),u=o(ft-t*a),l=o(c*c),f=o(u*u),p=o(t*n*l-f),{isValid:d,value:y}=cu(o(p*f)),x=o(y*u),h=o(y*x*p),g=o((i+i)*x);lt(g,s)&&(g=o(-g));let S=o(c*h),_=o(g*S);if(!d||lt(_,s)||S===Fd)throw new Error("invalid ristretto255 encoding 2");return new r(new At(g,S,ft,_))}static fromHex(e){return r.fromBytes($r(e))}toBytes(){let{X:e,Y:t,Z:n,T:s}=this.ep,o=Sr,i=h=>_t.create(h),a=i(i(n+t)*i(n-t)),c=i(e*t),u=i(c*c),{value:l}=cu(i(a*u)),f=i(l*a),p=i(l*c),d=i(f*p*s),y;if(lt(s*d,o)){let h=i(t*ti),g=i(e*ti);e=h,t=g,y=i(f*Wd)}else y=p;lt(e*d,o)&&(t=i(-t));let x=i((n-t)*y);return lt(x,o)&&(x=i(-x)),_t.toBytes(x)}equals(e){this.assertSame(e);let{X:t,Y:n}=this.ep,{X:s,Y:o}=e.ep,i=u=>_t.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(Tt.BASE);Object.freeze(Tt.ZERO);Object.freeze(Tt.prototype);Object.freeze(Tt);var Zd=Object.freeze({Point:Tt,hashToCurve(r,e){let t=e?.DST===void 0?"ristretto255_XMD:SHA-512_R255MAP_RO_":e.DST,n=Js(r,t,64,zn);return Zd.deriveToCurve(n)},hashToScalar(r,e={DST:iu}){let t=Js(r,e.DST,64,zn);return lu.create(Qe(t))},deriveToCurve(r){Oe(r,64);let e=ri(r.subarray(0,32)),t=uu(e),n=ri(r.subarray(32,64)),s=uu(n);return new Tt(t.add(s))}});var rn=class extends Error{constructor(e="An error occurred while verifying a message"){super(e),this.name="VerificationError"}},Qn=class extends Error{constructor(e="Missing Web Crypto API"){super(e),this.name="WebCryptoMissingError"}};var du={get(r=globalThis){let e=r.crypto;if(e?.subtle==null)throw new Qn("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 ke=du;var Jn=32;var si,Xd=(async()=>{try{return await ke.get().subtle.generateKey({name:"Ed25519"},!0,["sign","verify"]),!0}catch{return!1}})();async function Qd(r,e,t){if(r.buffer instanceof ArrayBuffer){let n=await ke.get().subtle.importKey("raw",r.buffer,{name:"Ed25519"},!1,["verify"]);return await ke.get().subtle.verify({name:"Ed25519"},n,e,t instanceof Uint8Array?t:t.subarray())}throw new TypeError("WebCrypto does not support SharedArrayBuffer for Ed25519 keys")}function Jd(r,e,t){return fu.verify(e,t instanceof Uint8Array?t:t.subarray(),r)}async function hu(r,e,t){return si==null&&(si=await Xd),si?Qd(r,e,t):Jd(r,e,t)}function eo(r){return r==null?!1:typeof r.then=="function"&&typeof r.catch=="function"&&typeof r.finally=="function"}var to=class{type="Ed25519";raw;constructor(e){this.raw=ii(e,Jn)}toMultihash(){return Fe.digest(Ze(this))}toCID(){return ue.createV1(114,this.toMultihash())}toString(){return te.encode(this.toMultihash().bytes).substring(1)}equals(e){return e==null||!(e.raw instanceof Uint8Array)?!1:le(this.raw,e.raw)}verify(e,t,n){n?.signal?.throwIfAborted();let s=hu(this.raw,t,e);return eo(s)?s.then(o=>(n?.signal?.throwIfAborted(),o)):s}};function ai(r){return r=ii(r,Jn),new to(r)}function ii(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 th=Math.pow(2,7),rh=Math.pow(2,14),nh=Math.pow(2,21),ci=Math.pow(2,28),ui=Math.pow(2,35),li=Math.pow(2,42),fi=Math.pow(2,49),G=128,xe=127;function De(r){if(r<th)return 1;if(r<rh)return 2;if(r<nh)return 3;if(r<ci)return 4;if(r<ui)return 5;if(r<li)return 6;if(r<fi)return 7;if(Number.MAX_SAFE_INTEGER!=null&&r>Number.MAX_SAFE_INTEGER)throw new RangeError("Could not encode varint");return 8}function vr(r,e,t=0){switch(De(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 oh(r,e,t=0){switch(De(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 di(r,e){let t=r[e],n=0;if(n+=t&xe,t<G||(t=r[e+1],n+=(t&xe)<<7,t<G)||(t=r[e+2],n+=(t&xe)<<14,t<G)||(t=r[e+3],n+=(t&xe)<<21,t<G)||(t=r[e+4],n+=(t&xe)*ci,t<G)||(t=r[e+5],n+=(t&xe)*ui,t<G)||(t=r[e+6],n+=(t&xe)*li,t<G)||(t=r[e+7],n+=(t&xe)*fi,t<G))return n;throw new RangeError("Could not decode varint")}function sh(r,e){let t=r.get(e),n=0;if(n+=t&xe,t<G||(t=r.get(e+1),n+=(t&xe)<<7,t<G)||(t=r.get(e+2),n+=(t&xe)<<14,t<G)||(t=r.get(e+3),n+=(t&xe)<<21,t<G)||(t=r.get(e+4),n+=(t&xe)*ci,t<G)||(t=r.get(e+5),n+=(t&xe)*ui,t<G)||(t=r.get(e+6),n+=(t&xe)*li,t<G)||(t=r.get(e+7),n+=(t&xe)*fi,t<G))return n;throw new RangeError("Could not decode varint")}function _r(r,e,t=0){return e==null&&(e=Te(De(r))),e instanceof Uint8Array?vr(r,e,t):oh(r,e,t)}function nn(r,e=0){return r instanceof Uint8Array?di(r,e):sh(r,e)}var pi=new Float32Array([-0]),It=new Uint8Array(pi.buffer);function mu(r,e,t){pi[0]=r,e[t]=It[0],e[t+1]=It[1],e[t+2]=It[2],e[t+3]=It[3]}function yu(r,e){return It[0]=r[e],It[1]=r[e+1],It[2]=r[e+2],It[3]=r[e+3],pi[0]}var mi=new Float64Array([-0]),Ee=new Uint8Array(mi.buffer);function gu(r,e,t){mi[0]=r,e[t]=Ee[0],e[t+1]=Ee[1],e[t+2]=Ee[2],e[t+3]=Ee[3],e[t+4]=Ee[4],e[t+5]=Ee[5],e[t+6]=Ee[6],e[t+7]=Ee[7]}function bu(r,e){return Ee[0]=r[e],Ee[1]=r[e+1],Ee[2]=r[e+2],Ee[3]=r[e+3],Ee[4]=r[e+4],Ee[5]=r[e+5],Ee[6]=r[e+6],Ee[7]=r[e+7],mi[0]}var ih=BigInt(Number.MAX_SAFE_INTEGER),ah=BigInt(Number.MIN_SAFE_INTEGER),Pe=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 Ht;if(e<ih&&e>ah)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>wu&&(s=0n,++n>wu&&(n=0n))),new r(Number(s),Number(n))}static fromNumber(e){if(e===0)return Ht;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):Ht}},Ht=new Pe(0,0);Ht.toBigInt=function(){return 0n};Ht.zzEncode=Ht.zzDecode=function(){return this};Ht.length=function(){return 1};var wu=4294967296n;function xu(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 Eu(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 yi(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 He(r,e){return RangeError(`index out of range: ${r.pos} + ${e??1} > ${r.len}`)}function ro(r,e){return(r[e-4]|r[e-3]<<8|r[e-2]<<16|r[e-1]<<24)>>>0}var gi=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,He(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 He(this,4);return ro(this.buf,this.pos+=4)}sfixed32(){if(this.pos+4>this.len)throw He(this,4);return ro(this.buf,this.pos+=4)|0}float(){if(this.pos+4>this.len)throw He(this,4);let e=yu(this.buf,this.pos);return this.pos+=4,e}double(){if(this.pos+8>this.len)throw He(this,4);let e=bu(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 He(this,e);return this.pos+=e,t===n?new Uint8Array(0):this.buf.subarray(t,n)}string(){let e=this.bytes();return Eu(e,0,e.length)}skip(e){if(typeof e=="number"){if(this.pos+e>this.len)throw He(this,e);this.pos+=e}else do if(this.pos>=this.len)throw He(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 Pe(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 He(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 He(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 He(this,8);let e=ro(this.buf,this.pos+=4),t=ro(this.buf,this.pos+=4);return new Pe(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=di(this.buf,this.pos);return this.pos+=De(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 on(r){return new gi(r instanceof Uint8Array?r:r.subarray())}function Ce(r,e,t){let n=on(r);return e.decode(n,void 0,t)}function bi(r){let e=r??8192,t=e>>>1,n,s=e;return function(i){if(i<1||i>t)return Te(i);s+i>e&&(n=Te(e),s=0);let a=n.subarray(s,s+=i);return(s&7)!==0&&(s=(s|7)+1),a}}var $t=class{fn;len;next;val;constructor(e,t,n){this.fn=e,this.len=t,this.next=void 0,this.val=n}};function wi(){}var Ei=class{head;tail;len;next;constructor(e){this.head=e.head,this.tail=e.tail,this.len=e.len,this.next=e.states}},ch=bi();function uh(r){return globalThis.Buffer!=null?Te(r):ch(r)}var an=class{len;head;tail;states;constructor(){this.len=0,this.head=new $t(wi,0,0),this.tail=this.head,this.states=null}_push(e,t,n){return this.tail=this.tail.next=new $t(e,t,n),this.len+=t,this}uint32(e){return this.len+=(this.tail=this.tail.next=new Si((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(no,10,Pe.fromNumber(e)):this.uint32(e)}sint32(e){return this.uint32((e<<1^e>>31)>>>0)}uint64(e){let t=Pe.fromBigInt(e);return this._push(no,t.length(),t)}uint64Number(e){return this._push(vr,De(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=Pe.fromBigInt(e).zzEncode();return this._push(no,t.length(),t)}sint64Number(e){let t=Pe.fromNumber(e).zzEncode();return this._push(no,t.length(),t)}sint64String(e){return this.sint64(BigInt(e))}bool(e){return this._push(xi,1,e?1:0)}fixed32(e){return this._push(sn,4,e>>>0)}sfixed32(e){return this.fixed32(e)}fixed64(e){let t=Pe.fromBigInt(e);return this._push(sn,4,t.lo)._push(sn,4,t.hi)}fixed64Number(e){let t=Pe.fromNumber(e);return this._push(sn,4,t.lo)._push(sn,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(mu,4,e)}double(e){return this._push(gu,8,e)}bytes(e){let t=e.length>>>0;return t===0?this._push(xi,1,0):this.uint32(t)._push(fh,t,e)}string(e){let t=xu(e);return t!==0?this.uint32(t)._push(yi,t,e):this._push(xi,1,0)}fork(){return this.states=new Ei(this),this.head=this.tail=new $t(wi,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 $t(wi,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=uh(this.len),n=0;for(;e!=null;)e.fn(e.val,t,n),n+=e.len,e=e.next;return t}};function xi(r,e,t){e[t]=r&255}function lh(r,e,t){for(;r>127;)e[t++]=r&127|128,r>>>=7;e[t]=r}var Si=class extends $t{next;constructor(e,t){super(lh,e,t),this.next=void 0}};function no(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 sn(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 fh(r,e,t){e.set(r,t)}globalThis.Buffer!=null&&(an.prototype.bytes=function(r){let e=r.length>>>0;return this.uint32(e),e>0&&this._push(dh,e,r),this},an.prototype.string=function(r){let e=globalThis.Buffer.byteLength(r);return this.uint32(e),e>0&&this._push(hh,e,r),this});function dh(r,e,t){e.set(r,t)}function hh(r,e,t){r.length<40?yi(r,e,t):e.utf8Write!=null?e.utf8Write(r,t):e.set(M(r),t)}function vi(){return new an}function Le(r,e){let t=vi();return e.encode(r,t,{lengthDelimited:!1}),t.finish()}function*Re(r,e,t){let n=on(r);yield*e.stream(n,void 0,"$",t)}var oo={VARINT:0,BIT64:1,LENGTH_DELIMITED:2,START_GROUP:3,END_GROUP:4,BIT32:5};function so(r,e,t,n,s){return{name:r,type:e,encode:t,decode:n,stream:s}}function Wt(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 so("enum",oo.VARINT,t,n,s)}function Be(r,e,t){return so("message",oo.LENGTH_DELIMITED,r,e,t)}var jt=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 _i;(function(r){r[r.RSA=0]="RSA",r[r.Ed25519=1]="Ed25519",r[r.secp256k1=2]="secp256k1",r[r.ECDSA=3]="ECDSA"})(_i||(_i={}));(function(r){r.codec=()=>Wt(_i)})(ne||(ne={}));var Je;(function(r){let e;r.codec=()=>(e==null&&(e=Be((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 Le(o,r.codec())}r.encode=t;function n(o,i){return Ce(o,r.codec(),i)}r.decode=n;function s(o,i){return Re(o,r.codec(),i)}r.stream=s})(Je||(Je={}));var Ai;(function(r){let e;r.codec=()=>(e==null&&(e=Be((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 Le(o,r.codec())}r.encode=t;function n(o,i){return Ce(o,r.codec(),i)}r.decode=n;function s(o,i){return Re(o,r.codec(),i)}r.stream=s})(Ai||(Ai={}));var un={};_e(un,{MAX_RSA_KEY_SIZE:()=>Ti,generateRSAKeyPair:()=>Iu,jwkToJWKKeyPair:()=>Du,jwkToPkcs1:()=>gh,jwkToPkix:()=>Li,jwkToRSAPrivateKey:()=>Pi,pkcs1MessageToJwk:()=>Di,pkcs1MessageToRSAPrivateKey:()=>Ri,pkcs1ToJwk:()=>yh,pkcs1ToRSAPrivateKey:()=>Tu,pkixMessageToJwk:()=>Ci,pkixMessageToRSAPublicKey:()=>Oi,pkixToJwk:()=>bh,pkixToRSAPublicKey:()=>Bi});var Ar=class{type="RSA";jwk;_raw;_multihash;constructor(e,t){this.jwk=e,this._multihash=t}get raw(){return this._raw==null&&(this._raw=un.jwkToPkix(this.jwk)),this._raw}toMultihash(){return this._multihash}toCID(){return ue.createV1(114,this._multihash)}toString(){return te.encode(this.toMultihash().bytes).substring(1)}equals(e){return e==null||!(e.raw instanceof Uint8Array)?!1:le(this.raw,e.raw)}verify(e,t,n){return Au(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=un.jwkToPkcs1(this.jwk)),this._raw}equals(e){return e==null||!(e.raw instanceof Uint8Array)?!1:le(this.raw,e.raw)}sign(e,t){return _u(this.jwk,e,t)}};var Ti=8192,Ii=18,ph=1062,mh=Uint8Array.from([48,13,6,9,42,134,72,134,247,13,1,1,1,5,0]);function yh(r){let e=it(r);return Di(e)}function Di(r){return{n:$(r[1],"base64url"),e:$(r[2],"base64url"),d:$(r[3],"base64url"),p:$(r[4],"base64url"),q:$(r[5],"base64url"),dp:$(r[6],"base64url"),dq:$(r[7],"base64url"),qi:$(r[8],"base64url"),kty:"RSA"}}function gh(r){if(r.n==null||r.e==null||r.d==null||r.p==null||r.q==null||r.dp==null||r.dq==null||r.qi==null)throw new oe("JWK was missing components");return bt([Ie(Uint8Array.from([0])),Ie(M(r.n,"base64url")),Ie(M(r.e,"base64url")),Ie(M(r.d,"base64url")),Ie(M(r.p,"base64url")),Ie(M(r.q,"base64url")),Ie(M(r.dp,"base64url")),Ie(M(r.dq,"base64url")),Ie(M(r.qi,"base64url"))]).subarray()}function bh(r){let e=it(r,{offset:0});return Ci(e)}function Ci(r){let e=it(r[1],{offset:0});return{kty:"RSA",n:$(e[0],"base64url"),e:$(e[1],"base64url")}}function Li(r){if(r.n==null||r.e==null)throw new oe("JWK was missing components");return bt([mh,Un(bt([Ie(M(r.n,"base64url")),Ie(M(r.e,"base64url"))]))]).subarray()}function Tu(r){let e=it(r);return Ri(e)}function Ri(r){let e=Di(r);return Pi(e)}function Bi(r,e){if(r.byteLength>=ph)throw new or("Key size is too large");let t=it(r,{offset:0});return Oi(t,r,e)}function Oi(r,e,t){let n=Ci(r);if(t==null){let s=pr(Je.encode({Type:ne.RSA,Data:e}));t=Ge(Ii,s)}return new Ar(n,t)}function Pi(r){if(Lu(r)>Ti)throw new oe("Key size is too large");let e=Du(r),t=pr(Je.encode({Type:ne.RSA,Data:Li(e.publicKey)})),n=Ge(Ii,t);return new cn(e.privateKey,new Ar(e.publicKey,n))}async function Iu(r){if(r>Ti)throw new oe("Key size is too large");let e=await Cu(r),t=pr(Je.encode({Type:ne.RSA,Data:Li(e.publicKey)})),n=Ge(Ii,t);return new cn(e.privateKey,new Ar(e.publicKey,n))}function Du(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 Cu(r,e){let t=await ke.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 wh(t,e);return{privateKey:n[0],publicKey:n[1]}}async function _u(r,e,t){let n=await ke.get().subtle.importKey("jwk",r,{name:"RSASSA-PKCS1-v1_5",hash:{name:"SHA-256"}},!1,["sign"]);t?.signal?.throwIfAborted();let s=await ke.get().subtle.sign({name:"RSASSA-PKCS1-v1_5"},n,e instanceof Uint8Array?e:e.subarray());return t?.signal?.throwIfAborted(),new Uint8Array(s,0,s.byteLength)}async function Au(r,e,t,n){let s=await ke.get().subtle.importKey("jwk",r,{name:"RSASSA-PKCS1-v1_5",hash:{name:"SHA-256"}},!1,["verify"]);n?.signal?.throwIfAborted();let o=await ke.get().subtle.verify({name:"RSASSA-PKCS1-v1_5"},s,e,t instanceof Uint8Array?t:t.subarray());return n?.signal?.throwIfAborted(),o}async function wh(r,e){if(r.privateKey==null||r.publicKey==null)throw new oe("Private and public key are required");let t=await Promise.all([ke.get().subtle.exportKey("jwk",r.privateKey),ke.get().subtle.exportKey("jwk",r.publicKey)]);return e?.signal?.throwIfAborted(),t}function Lu(r){if(r.kty!=="RSA")throw new oe("invalid key type");if(r.n==null)throw new oe("invalid key modulus");return M(r.n,"base64url").length*8}var io=class{oHash;iHash;blockLen;outputLen;canXOF=!1;finished=!1;destroyed=!1;constructor(e,t){if(kn(e),Oe(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),ct(s)}update(e){return hr(this),this.iHash.update(e),this}digestInto(e){hr(this),Mn(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()}},Ru=(()=>{let r=((e,t,n)=>new io(e,t).update(n).digest());return r.create=(e,t)=>new io(e,t),r})();var Bu=(r,e)=>(r+(r>=0?e:-e)/Ou)/e;function xh(r,e,t){gr("scalar",r,et,t);let[[n,s],[o,i]]=e,a=Bu(i*r,t),c=Bu(-s*r,t),u=r-a*n-c*o,l=-a*s-c*i,f=u<et,p=l<et;f&&(u=-u),p&&(l=-l);let d=Qr(Math.ceil(br(t)/2))+Dt;if(u<et||u>=d||l<et||l>=d)throw new Error("splitScalar (endomorphism): failed for k");return{k1neg:f,k1:u,k2neg:p,k2:l}}function Ui(r){if(!["compact","recovered","der"].includes(r))throw new Error('Signature format must be "compact", "recovered", or "der"');return r}function Ni(r,e){Ve(r);let t={};for(let n of Object.keys(e))t[n]=r[n]===void 0?e[n]:r[n];return qe(t.lowS,"lowS"),qe(t.prehash,"prehash"),t.format!==void 0&&Ui(t.format),t}var ki=class extends Error{constructor(e=""){super(e)}},$e={Err:ki,_tlv:{encode:(r,e)=>{let{Err:t}=$e;if(ze(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=Zr(n);if(s.length/2&128)throw new t("tlv.encode: long form length too big");let o=n>127?Zr(s.length/2|128):"";return Zr(r)+o+s+e},decode(r,e){let{Err:t}=$e;e=V(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}=$e;if($n(r),r<et)throw new e("integer: negative integers are not allowed");let t=Zr(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}=$e;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 Kt(r)}},toSig(r){let{Err:e,_int:t,_tlv:n}=$e,s=V(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}=$e,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($e._tlv);Object.freeze($e._int);Object.freeze($e);var et=BigInt(0),Dt=BigInt(1),Ou=BigInt(2),ao=BigInt(3),Eh=BigInt(4);function Pu(r,e={}){let t=Yn("weierstrass",r,e),n=t.Fp,s=t.Fn,o=t.CURVE,{h:i,n:a}=o;Ve(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=Uu(n,s);function f(){if(!n.isOdd)throw new Error("compression is not supported: Field does not have .isOdd()")}function p(k,m,b){if(u&&m.is0())return Uint8Array.of(0);let{x:v,y:E}=m.toAffine(),w=n.toBytes(v);if(qe(b,"isCompressed"),b){f();let A=!n.isOdd(E);return de(Nu(A),w)}else return de(Uint8Array.of(4),w,n.toBytes(E))}function d(k){V(k,void 0,"Point");let{publicKey:m,publicKeyUncompressed:b}=l,v=k.length,E=k[0],w=k.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(k){let m=n.sqr(k),b=n.mul(m,k);return n.add(n.add(b,n.mul(k,o.a)),o.b)}function g(k,m){let b=n.sqr(m),v=h(k);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,ao),Eh),_=n.mul(n.sqr(o.b),BigInt(27));if(n.is0(n.add(S,_)))throw new Error("bad curve params: a or b");function R(k,m,b=!1){if(!n.isValid(m)||b&&n.is0(m))throw new Error(`bad point coordinate ${k}`);return m}function C(k){if(!(k instanceof I))throw new Error("Weierstrass Point expected")}function N(k){if(!c||!c.basises)throw new Error("no endo");return xh(k,c.basises,s.ORDER)}function B(k,m,b,v,E){return b=new I(n.mul(b.X,k),b.Y,b.Z),m=en(v,m),b=en(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=R("x",m),this.Y=R("y",b,!0),this.Z=R("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(V(m,void 0,"point")));return b.assertValidity(),b}static fromHex(m){return I.fromBytes(yr(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(ao),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,ao),{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,ao),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 ve=n.add(w,D);return ae=n.mul(ae,ve),ve=n.add(K,he),ae=n.sub(ae,ve),ve=n.add(v,E),T=n.add(A,D),ve=n.mul(ve,T),T=n.add(fe,he),ve=n.sub(ve,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(ve,ae),T=n.mul(pe,T),T=n.sub(T,K),K=n.mul(pe,fe),P=n.mul(ve,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=>Vt(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=B(b.beta,P,j,A,T)}else{let{p:A,f:D}=w(m);v=A,E=D}return Vt(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===et||v.is0())return I.ZERO;if(E===Dt)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}=nu(I,v,A,T);return B(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===Dt?!0:m?m(I,this):Z.unsafe(this,a).is0()}clearCofactor(){let{clearCofactor:m}=e;return i===Dt?this:m?m(I,this):this.multiplyUnsafe(i)}isSmallOrder(){return i===Dt?this.is0():this.clearCofactor().is0()}toBytes(m=!0){return qe(m,"isCompressed"),this.assertValidity(),y(I,this,m)}toHex(m=!0){return mr(this.toBytes(m))}toString(){return`<Point ${this.is0()?"ZERO":this.toHex()}>`}}let U=s.BITS,Z=new Er(I,e.endo?Math.ceil(U/2):U);return U>=8&&I.BASE.precompute(8),Object.freeze(I.prototype),Object.freeze(I),I}function Nu(r){return Uint8Array.of(r?2:3)}function Uu(r,e){return{secretKey:e.BYTES,publicKey:1+r.BYTES,publicKeyUncompressed:1+2*r.BYTES,publicKeyHasPrefix:!0,signature:2*e.BYTES}}function Sh(r,e={}){let{Fn:t}=r,n=e.randomBytes===void 0?Yr:e.randomBytes,s=Object.assign(Uu(r.Fp,t),{seed:Math.max(js(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,Gs(V(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(!Ft(d))return;let S=V(d,void 0,"key").length,_=S===x||S===h,R=S===y||!!g?.includes(S);if(!(_&&R))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=Zn(a,c);return Object.freeze(f),Object.freeze(s),Object.freeze({getPublicKey:c,getSharedSecret:l,keygen:p,Point:r,utils:f,lengths:s})}function ku(r,e,t={}){let n=e;kn(n),Ve(t,{},{hmac:"function",lowS:"boolean",randomBytes:"function",bits2int:"function",bits2int_modN:"function"}),t=Object.assign({},t);let s=t.randomBytes===void 0?Yr:t.randomBytes,o=t.hmac===void 0?(E,w)=>Ru(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}=Sh(r,t),x={prehash:!0,lowS:typeof t.lowS=="boolean"?t.lowS:!0,format:"compact",extraEntropy:!1},h=c*Ou+Dt<i.ORDER;function g(E){let w=c>>Dt;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 R(E,w){Ui(w);let A=y.signature,D=w==="compact"?A:w==="recovered"?A+1:void 0;return V(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){R(w,A);let D;if(A==="der"){let{r:z,s:j}=$e.toSig(V(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(yr(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(Nu((T&1)===0),P)),j=a.inv(L),K=B(V(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(Ui(w),w==="der")return yr($e.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 mr(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=Kt(w),D=w.length*8-u;return D>0?A>>BigInt(D):A}:t.bits2int,B=t.bits2int_modN===void 0?function(w){return a.create(N(w))}:t.bits2int_modN,I=Qr(u);function U(E){return gr("num < 2^"+u,E,et,I),a.toBytes(E)}function Z(E,w){return V(E,void 0,"message"),w?V(n(E),void 0,"prehashed message"):E}function k(E,w,A){let{lowS:D,prehash:T,extraEntropy:L}=Ni(A,x);E=Z(E,T);let P=B(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(V(pe,void 0,"extraEntropy"))}let K=de(...j),fe=P;function he(pe){let ae=N(pe);if(!a.isValidNot0(ae))return;let ve=a.inv(ae),nr=r.BASE.multiply(ae).toAffine(),Ur=a.create(nr.x);if(Ur===et)return;let _n=a.create(ve*a.create(fe+Ur*z));if(_n===et)return;let qa=(nr.x===Ur?0:2)|Number(nr.y&Dt),za=_n;return D&&g(_n)&&(za=a.neg(_n),qa^=1),new C(Ur,za,h?void 0:qa)}return{seed:K,k2sig:he}}function m(E,w,A={}){let{seed:D,k2sig:T}=k(E,w,A);return Kc(n.outputLen,a.BYTES,o)(D,T).toBytes(A.format)}function b(E,w,A,D={}){let{lowS:T,prehash:L,format:P}=Ni(D,x);if(A=V(A,void 0,"publicKey"),w=Z(w,L),!Ft(E)){let z=E instanceof C?", use sig.toBytes()":"";throw new Error("verify expects Uint8Array signature"+z)}R(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=B(w),pe=a.inv(fe),ae=a.create(he*pe),ve=a.create(K*pe),nr=r.BASE.multiplyUnsafe(ae).add(j.multiplyUnsafe(ve));return nr.is0()?!1:a.create(nr.x)===K}catch{return!1}}function v(E,w,A={}){let{prehash:D}=Ni(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 Fi={p:BigInt("0xfffffffffffffffffffffffffffffffffffffffffffffffffffffffefffffc2f"),n:BigInt("0xfffffffffffffffffffffffffffffffebaaedce6af48a03bbfd25e8cd0364141"),h:BigInt(1),a:BigInt(0),b:BigInt(7),Gx:BigInt("0x79be667ef9dcbbac55a06295ce870b07029bfcdb2dce28d959f2815b16f81798"),Gy:BigInt("0x483ada7726a3c4655da4fbfc0e1108a8fd17b448a68554199c47d08ffb10d4b8")},vh={beta:BigInt("0x7ae96a2b657c07106e64479eac3434e99cf0497512f58995c1396c28719501ee"),basises:[[BigInt("0x3086d221a7d46bcde86c90e49284eb15"),-BigInt("0xe4437ed6010e88286f547fa90abfe4c3")],[BigInt("0x114ca50f7a8e2f3f657c1108d9d44cfd8"),BigInt("0x3086d221a7d46bcde86c90e49284eb15")]]};var Mu=BigInt(2);function _h(r){let e=Fi.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=ee(l,t,e)*l%e,p=ee(f,t,e)*l%e,d=ee(p,Mu,e)*u%e,y=ee(d,s,e)*d%e,x=ee(y,o,e)*y%e,h=ee(x,a,e)*x%e,g=ee(h,c,e)*h%e,S=ee(g,a,e)*x%e,_=ee(S,t,e)*l%e,R=ee(_,i,e)*y%e,C=ee(R,n,e)*u%e,N=ee(C,Mu,e);if(!Mi.eql(Mi.sqr(N),r))throw new Error("Cannot find square root");return N}var Mi=wr(Fi.p,{sqrt:_h}),Ah=Pu(Fi,{Fp:Mi,endo:vh}),Tr=ku(Ah,pr);function Fu(r,e,t,n){let s=fr.digest(t instanceof Uint8Array?t:t.subarray());if(eo(s))return s.then(({digest:o})=>(n?.signal?.throwIfAborted(),Tr.verify(e,o,r,{prehash:!1,format:"der"}))).catch(o=>{throw o.name==="AbortError"?o:new rn(String(o))});try{return n?.signal?.throwIfAborted(),Tr.verify(e,s.digest,r,{prehash:!1,format:"der"})}catch(o){throw new rn(String(o))}}var co=class{type="secp256k1";raw;_key;constructor(e){this._key=qu(e),this.raw=Ku(this._key)}toMultihash(){return Fe.digest(Ze(this))}toCID(){return ue.createV1(114,this.toMultihash())}toString(){return te.encode(this.toMultihash().bytes).substring(1)}equals(e){return e==null||!(e.raw instanceof Uint8Array)?!1:le(this.raw,e.raw)}verify(e,t,n){return Fu(this._key,t,e,n)}};function Ki(r){return new co(r)}function Ku(r){return Tr.Point.fromBytes(r).toBytes()}function qu(r){try{return Tr.Point.fromBytes(r),r}catch(e){throw new or(String(e))}}function zu(r,e){let{Type:t,Data:n}=Je.decode(r),s=n??new Uint8Array;switch(t){case ne.RSA:return Bi(s,e);case ne.Ed25519:return ai(s);case ne.secp256k1:return Ki(s);case ne.ECDSA:return Ls(s);default:throw new sr}}function Vu(r){let{Type:e,Data:t}=Je.decode(r.digest),n=t??new Uint8Array;switch(e){case ne.Ed25519:return ai(n);case ne.secp256k1:return Ki(n);case ne.ECDSA:return Ls(n);default:throw new sr}}function Ze(r){return Je.encode({Type:ne[r.type],Data:r.raw})}var Hu=Symbol.for("nodejs.util.inspect.custom"),Th=114,ln=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()})`}[rs]=!0;toString(){return this.string==null&&(this.string=te.encode(this.multihash.bytes).slice(1)),this.string}toMultihash(){return this.multihash}toCID(){return ue.createV1(Th,this.multihash)}toJSON(){return this.toString()}equals(e){if(e==null)return!1;if(e instanceof Uint8Array)return le(this.multihash.bytes,e);if(typeof e=="string")return this.toString()===e;if(e?.toMultihash()?.bytes!=null)return le(this.multihash.bytes,e.toMultihash().bytes);throw new Error("not valid Id")}[Hu](){return`PeerId(${this.toString()})`}},uo=class extends ln{type="RSA";publicKey;constructor(e){super({...e,type:"RSA"}),this.publicKey=e.publicKey}},lo=class extends ln{type="Ed25519";publicKey;constructor(e){super({...e,type:"Ed25519"}),this.publicKey=e.publicKey}},fo=class extends ln{type="secp256k1";publicKey;constructor(e){super({...e,type:"secp256k1"}),this.publicKey=e.publicKey}},Ih=2336,fn=class{type="url";multihash;publicKey;url;constructor(e){this.url=e.toString(),this.multihash=Fe.digest(M(this.url))}[Hu](){return`PeerId(${this.url})`}[rs]=!0;toString(){return this.toCID().toString()}toMultihash(){return this.multihash}toCID(){return ue.createV1(Ih,this.toMultihash())}toJSON(){return this.toString()}equals(e){return e==null?!1:(e instanceof Uint8Array&&(e=$(e)),e.toString()===this.toString())}};var Dh=114,$u=2336;function qi(r,e){let t;if(r.charAt(0)==="1"||r.charAt(0)==="Q")t=Ye(te.decode(`z${r}`));else{if(r.startsWith("k51qzi5uqu5")||r.startsWith("kzwfwjn5ji4")||r.startsWith("k2k4r8")||r.startsWith("bafz"))return Ch(ue.parse(r));if(e==null)throw new oe('Please pass a multibase decoder for strings that do not start with "1" or "Q"');t=Ye(e.decode(r))}return Ir(t)}function Ir(r){if(Rh(r))return new uo({multihash:r});if(Lh(r))try{let e=Vu(r);if(e.type==="Ed25519")return new lo({multihash:r,publicKey:e});if(e.type==="secp256k1")return new fo({multihash:r,publicKey:e})}catch{let t=$(r.digest);return new fn(new URL(t))}throw new In("Supplied PeerID Multihash is invalid")}function Ch(r){if(r?.multihash==null||r.version==null||r.version===1&&r.code!==Dh&&r.code!==$u)throw new Tn("Supplied PeerID CID is invalid");if(r.code===$u){let e=$(r.multihash.digest);return new fn(new URL(e))}return Ir(r.multihash)}function Lh(r){return r.code===Fe.code}function Rh(r){return r.code===fr.code}var dn;(function(r){let e;r.codec=()=>(e==null&&(e=Be((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:re(0),payloadType:re(0),payload:re(0),signature:re(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 Le(o,r.codec())}r.encode=t;function n(o,i){return Ce(o,r.codec(),i)}r.decode=n;function s(o,i){return Re(o,r.codec(),i)}r.stream=s})(dn||(dn={}));var ho=class extends Error{constructor(e="Invalid signature"){super(e),this.name="InvalidSignatureError"}};var hn=class r{static createFromProtobuf=e=>{let t=dn.decode(e),n=zu(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=Wu(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 ho("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=dn.encode({publicKey:Ze(this.publicKey),payloadType:this.payloadType,payload:this.payload.subarray(),signature:this.signature})),this.marshaled}equals(e){return e==null?!1:le(this.marshal(),e.marshal())}async validate(e,t){let n=Wu(e,this.payloadType,this.payload);return this.publicKey.verify(n.subarray(),this.signature,t)}},Wu=(r,e,t)=>{let n=M(r),s=_r(n.byteLength),o=_r(e.length),i=_r(t.length);return new J(s,n,o,e,i,t)};var we=class extends Error{static name="InvalidMultiaddrError";name="InvalidMultiaddrError"},dt=class extends Error{static name="ValidationError";name="ValidationError"},po=class extends Error{static name="InvalidParametersError";name="InvalidParametersError"},mo=class extends Error{static name="UnknownProtocolError";name="UnknownProtocolError"};var yo=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 Bh=45,Oh=15,go=new yo;function ju(r){if(!(r.length>Oh))return go.new(r).parseWith(()=>go.readIPv4Addr())}function Gu(r){if(r.includes("%")&&(r=r.split("%")[0]),!(r.length>Bh))return go.new(r).parseWith(()=>go.readIPv6Addr())}function bo(r){return!!ju(r)}function Yu(r){return!!Gu(r)}function Vi(r){return e=>$(e,r)}function Hi(r){return e=>M(e,r)}function Dr(r){return new DataView(r.buffer).getUint16(r.byteOffset).toString()}function Gt(r){let e=new ArrayBuffer(2);return new DataView(e).setUint16(0,typeof r=="string"?parseInt(r):r),new Uint8Array(e)}function Zu(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=Gt(n);return st([t,s],t.length+s.length)}function Xu(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=gt.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=Gt(n);return st([t,s],t.length+s.length)}function $i(r){let e=r.subarray(0,r.length-2),t=r.subarray(r.length-2),n=$(e,"base32"),s=Dr(t);return`${n}:${s}`}var Wi=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},Qu=function(r){let e=0;r=r.toString().trim();let t=r.split(":",8),n;for(n=0;n<t.length;n++){let o=bo(t[n]),i;o&&(i=Wi(t[n]),t[n]=$(i.subarray(0,2),"base16")),i!=null&&++n<8&&t.splice(n,0,$(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},Ju=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(".")},el=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 tl(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 zi=Object.values(zr).map(r=>r.decoder),Ph=(function(){let r=zi[0].or(zi[1]);return zi.slice(2).forEach(e=>r=r.or(e)),r})();function rl(r){return Ph.decode(r)}function nl(r){return e=>r.encoder.encode(e)}function Nh(r){if(parseInt(r).toString()!==r)throw new dt("Value must be an integer")}function Uh(r){if(r<0)throw new dt("Value must be a positive integer, or zero")}function kh(r){return e=>{if(e>r)throw new dt(`Value must be smaller than or equal to ${r}`)}}function Mh(...r){return e=>{for(let t of r)t(e)}}var pn=Mh(Nh,Uh,kh(65535));var ye=-1,ji=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 mo(`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)}))}},pt=new ji,Qh=[{code:4,name:"ip4",size:32,valueToBytes:Wi,bytesToValue:Ju,validate:r=>{if(!bo(r))throw new dt(`Invalid IPv4 address "${r}"`)}},{code:6,name:"tcp",size:16,valueToBytes:Gt,bytesToValue:Dr,validate:pn},{code:273,name:"udp",size:16,valueToBytes:Gt,bytesToValue:Dr,validate:pn},{code:33,name:"dccp",size:16,valueToBytes:Gt,bytesToValue:Dr,validate:pn},{code:41,name:"ip6",size:128,valueToBytes:Qu,bytesToValue:el,stringToValue:tl,validate:r=>{if(!Yu(r))throw new dt(`Invalid IPv6 address "${r}"`)}},{code:42,name:"ip6zone",size:ye},{code:43,name:"ipcidr",size:8,bytesToValue:Vi("base10"),valueToBytes:Hi("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:Gt,bytesToValue:Dr,validate:pn},{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:Vi("base58btc"),valueToBytes:r=>r.startsWith("Q")||r.startsWith("1")?Hi("base58btc")(r):ue.parse(r).multihash.bytes},{code:444,name:"onion",size:96,bytesToValue:$i,valueToBytes:Zu},{code:445,name:"onion3",size:296,bytesToValue:$i,valueToBytes:Xu},{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:nl(gs),valueToBytes:rl},{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}];Qh.forEach(r=>{pt.addProtocol(r)});function ol(r){let e=[],t=0;for(;t<r.length;){let n=nn(r,t),s=pt.getProtocol(n),o=De(n),i=Jh(s,r,t+o),a=0;i>0&&s.size===ye&&(a=De(i));let c=o+a+i,u={code:n,name:s.name,bytes:r.subarray(t,t+c)};if(i>0){let l=t+o+a,f=r.subarray(l,l+i);u.value=s.bytesToValue?.(f)??$(f)}e.push(u),t+=c}return e}function sl(r){let e=0,t=[];for(let n of r){if(n.bytes==null){let s=pt.getProtocol(n.code),o=De(n.code),i,a=0,c=0;n.value!=null&&(i=s.valueToBytes?.(n.value)??M(n.value),a=i.byteLength,s.size===ye&&(c=De(a)));let u=new Uint8Array(o+c+a),l=0;vr(n.code,u,l),l+=o,i!=null&&(s.size===ye&&(vr(a,u,l),l+=c),u.set(i,l)),n.bytes=u}t.push(n.bytes),e+=n.bytes.byteLength}return st(t,e)}function il(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=pt.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 al(r){return`/${r.flatMap(e=>{if(e.value==null)return e.name;let t=pt.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 Jh(r,e,t){return r.size==null||r.size===0?0:r.size>0?r.size/8:nn(e,t)}var ep=Symbol.for("nodejs.util.inspect.custom"),la=Symbol.for("@multiformats/multiaddr");function tp(r){if(r==null&&(r="/"),cl(r))return r.getComponents();if(r instanceof Uint8Array)return ol(r);if(typeof r=="string")return r=r.replace(/\/(\/)+/,"/").replace(/(\/)+$/,""),r===""&&(r="/"),il(r);if(Array.isArray(r))return r;throw new we("Must be a string, Uint8Array, Component[], or another Multiaddr")}var vo=class r{[la]=!0;#e;#t;#r;constructor(e="/",t={}){this.#e=tp(e),t.validate!==!1&&rp(this)}get bytes(){return this.#r==null&&(this.#r=sl(this.#e)),this.#r}toString(){return this.#t==null&&(this.#t=al(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 po(`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 le(this.bytes,e.bytes)}[ep](){return`Multiaddr(${this.toString()})`}};function rp(r){r.getComponents().forEach(e=>{let t=pt.getProtocol(e.code);e.value!=null&&t.validate?.(e.value)})}function cl(r){return!!r?.[la]}function Ne(r){return new vo(r)}var fa={32:16777619n,64:1099511628211n,128:309485009821345068724781371n,256:374144419156711147060143317175368453031918731002211n,512:35835915874844867368919076489095108449946327955754392558399825615420669938882575126094039892345713852759n,1024:5016456510113118655434598811035278955030765345404790744303017523831112055108147451509157692220295382716162651878526895249385292291816524375083746691371804094271873160484737966720260389217684476157468082573n},ul={32:2166136261n,64:14695981039346656037n,128:144066263297769815596495629667062367629n,256:100029257958052580907070968620625704837092796014241193945225284501741471925557n,512:9659303129496669498009435400716310466090418745672637896108374329434462657994582932197716438449813051892206539805784495328239340083876191928701583869517785n,1024:14197795064947621068722070641403218320880622795441933960878474914617582723252296732303717722150864096521202355549365628174669108571814760471015076148029755969804077320157692458563003215304957150157403644460363550505412711285966361610267868082893823963790439336411086884584107735010676915n},ll=new globalThis.TextEncoder;function np(r,e){let t=fa[e],n=ul[e];for(let s=0;s<r.length;s++)n^=BigInt(r[s]),n=BigInt.asUintN(e,n*t);return n}function op(r,e,t){if(t.length===0)throw new Error("The `utf8Buffer` option must have a length greater than zero");let n=fa[e],s=ul[e],o=r;for(;o.length>0;){let i=ll.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 da(r,{size:e=32,utf8Buffer:t}={}){if(!fa[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 op(r,e,t);r=ll.encode(r)}return np(r,e)}var mn={hash:r=>Number(da(r,{size:32})),hashV:(r,e)=>sp(mn.hash(r,e))};function sp(r){let e=r.toString(16);return e.length%2===1&&(e=`0${e}`),M(e,"base16")}var ha=64,We=class{fp;h;seed;constructor(e,t,n,s=2){if(s>ha)throw new TypeError("Invalid Fingerprint Size");let o=t.hashV(e,n),i=re(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?le(this.fp,e.fp):!1}};function Xt(r,e){return Math.floor(Math.random()*(e-r))+r}var Qt=class{contents;constructor(e){this.contents=new Array(e).fill(null)}has(e){if(!(e instanceof We))throw new TypeError("Invalid Fingerprint");return this.contents.some(t=>e.equals(t))}add(e){if(!(e instanceof We))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 We))throw new TypeError("Invalid Fingerprint");let t=Xt(0,this.contents.length-1),n=this.contents[t];return this.contents[t]=e,n}remove(e){if(!(e instanceof We))throw new TypeError("Invalid Fingerprint");let t=this.contents.findIndex(n=>e.equals(n));return t>-1?(this.contents[t]=null,!0):!1}};var ip=500,yn=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??mn,this.seed=e.seed??Xt(0,Math.pow(2,10))}add(e){typeof e=="string"&&(e=M(e));let t=new We(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 Qt(this.bucketSize)),this.buckets[s]==null&&(this.buckets[s]=new Qt(this.bucketSize)),this.buckets[n].add(t)||this.buckets[s].add(t))return this.count++,!0;let o=[n,s],i=o[Xt(0,o.length-1)];this.buckets[i]==null&&(this.buckets[i]=new Qt(this.bucketSize));for(let a=0;a<ip;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 Qt(this.bucketSize)),this.buckets[i].add(c)))return this.count++,!0}return!1}has(e){typeof e=="string"&&(e=M(e));let t=new We(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 We(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}},ap={1:.5,2:.84,4:.95,8:.98};function cp(r=.001){return r>.002?2:r>1e-5?4:8}function fl(r,e=.001){let t=cp(e),n=ap[t],s=Math.round(r/n),o=Math.min(Math.ceil(Math.log2(1/e)+Math.log2(2*t)),ha);return{filterSize:s,bucketSize:t,fingerprintSize:o}}var _o=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??mn,this.seed=e.seed??Xt(0,Math.pow(2,10)),this.filterSeries=[new yn({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 yn({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 Br(r,e=.001,t){return new _o({...fl(r,e),...t??{}})}function je(){let r={};return r.promise=new Promise((e,t)=>{r.resolve=e,r.reject=t}),r}var Ao=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}},Or=class{size;hwm;head;tail;constructor(e={}){this.hwm=e.splitLimit??16,this.head=new Ao(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 Ao(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 pa=class extends Error{type;code;constructor(e,t){super(e??"The operation was aborted"),this.type="aborted",this.code=t??"ABORT_ERR"}};function Ct(r={}){return up(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 up(r,e){e=e??{};let t=e.onEnd,n=new Or,s,o,i,a=je(),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=je()})}},u=h=>o!=null?o(h):(n.push(h),s),l=h=>(n=new Or,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 Or,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((R,C)=>{_=()=>{C(new pa)},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 ma=class r extends Error{name="TimeoutError";constructor(e,t){super(e,t),Error.captureStackTrace?.(this,r)}},dl=r=>r.reason??new DOMException("This operation was aborted.","AbortError");function ya(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(dl(i));return}if(i&&(c=()=>{p(dl(i))},i.addEventListener("abort",c,{once:!0})),r.then(f,p),t===Number.POSITIVE_INFINITY)return;let d=new ma;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 lp=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 fp(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}=lp(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=ya(s,{milliseconds:t.timeout});return o.cancel=()=>{n(),o.clear()},o}return s}function tt(r,e,t){typeof t=="function"&&(t={filter:t}),t={...t,count:1,resolveImmediately:!1};let n=fp(r,e,t),s=n.then(o=>o[0]);return s.cancel=n.cancel,s}function ga(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 To=class extends Error{static name="QueueFullError";constructor(e="The queue was full"){super(e),this.name="QueueFullError"}},Jt=class extends Error{static name="UnexpectedEOFError";name="UnexpectedEOFError"};var Io=class extends Error{static name="StreamClosedError";name="StreamClosedError"};function dp(r){return r.reason}async function Lt(r,e,t){if(e==null)return r;let n=t?.translateError??dp;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 Do=class{deferred;signal;onProgress;constructor(e){this.signal=e?.signal,this.onProgress=e?.onProgress,this.deferred=je(),this.onAbort=this.onAbort.bind(this),this.signal?.addEventListener("abort",this.onAbort)}onAbort(){this.deferred.reject(this.signal?.reason??new rt)}cleanup(){this.signal?.removeEventListener("abort",this.onAbort)}};function hp(){return`${parseInt(String(Math.random()*1e9),10).toString()}${Date.now()}`}var Co=class{id;fn;options;recipients;status;timeline;controller;constructor(e,t){this.id=hp(),this.status="queued",this.fn=e,this.options=t,this.recipients=[],this.timeline={created:Date.now()},this.controller=new AbortController,this.controller.signal,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 rt),this.cleanup())}async join(e){let t=new Do(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 Lt(this.fn({...this.options??{},signal:this.controller.signal,onProgress:t=>{this.recipients.forEach(n=>{n.onProgress?.(t)})}}),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 Lo=class extends Ae{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=ga(this.emitEmpty.bind(this),1),this.emitIdle=ga(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 To;let n=new Co(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 rt)}),this.clear()}async onEmpty(e){this.size!==0&&await tt(this,"empty",e)}async onSizeLessThan(e,t){this.size<e||await tt(this,"next",{...t,filter:()=>this.size<e})}async onIdle(e){this.pending===0&&this.size===0||await tt(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=Ct({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 rt("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 pp=Math.pow(2,20)*4,Ro=class extends Ae{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??pp,this.maxWriteBufferLength=e.maxWriteBufferLength,this.maxMessageSize=e.maxMessageSize,this.readBuffer=new J,this.writeBuffer=new J,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,this.processSendQueue()),this.onDrainPromise?.resolve()};this.addEventListener("drain",t);let n=s=>{this.onDrainPromise?.reject(s.error??new Io)};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()),Lt(this.onDrainPromise.promise,e?.signal))}async*[Symbol.asyncIterator](){if(this.readStatus!=="readable"&&this.readStatus!=="paused")return;let e=Ct(),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 mt(`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 Rn(e))}}pause(){if(this.readStatus==="closed"||this.readStatus==="closing")throw new mt("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 mt("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 mt(`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 mt(`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 An;this.dispatchEvent(new Bn(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 ir))}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;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 J(o);this.writeBuffer.consume(o.byteLength);let a=this.sendData(o);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 Ln(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 kr(`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 kr(`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 Bo=class extends Ro{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 tt(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 tt(this,"drain",{...e,rejectionEvents:["close"]})),await this.sendClose(e),this.onTransportClosed())}};function Oo(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 ba=class{readNext;haveNext;ended;nextResult;error;constructor(){this.ended=!1,this.readNext=je(),this.haveNext=je()}[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=je(),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=je(),await Lt(this.readNext.promise,t?.signal,t)}};function hl(){return new ba}function mp(r){return r[Symbol.asyncIterator]!=null}async function yp(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*gp(r){let e=new AbortController,t=hl();yp(r,t,e.signal).catch(()=>{});try{yield*t}finally{e.abort()}}function*bp(r){for(let e of r)yield*e}function wp(...r){let e=[];for(let t of r)mp(t)||e.push(t);return e.length===r.length?bp(e):gp(r)}var pl=wp;function ml(r,...e){if(r==null)throw new Error("Empty pipeline");if(wa(r)){let n=r;r=()=>n.source}else if(gl(r)||yl(r)){let n=r;r=()=>n}let t=[r,...e];if(t.length>1&&wa(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++)wa(t[n])&&(t[n]=Ep(t[n]));return xp(...t)}var xp=(...r)=>{let e;for(;r.length>0;)e=r.shift()(e);return e},yl=r=>r?.[Symbol.asyncIterator]!=null,gl=r=>r?.[Symbol.iterator]!=null,wa=r=>r==null?!1:r.sink!=null&&r.source!=null,Ep=r=>e=>{let t=r.sink(e);if(t?.then!=null){let n=Ct({objectMode:!0});t.then(()=>{n.end()},i=>{n.end(i)});let s,o=r.source;if(yl(o))s=async function*(){yield*o,n.end()};else if(gl(o))s=function*(){yield*o,n.end()};else throw new Error("Unknown duplex source type - must be Iterable or AsyncIterable");return pl(n,s())}return r.source};var Sp=4194304,Po=class extends Error{static name="UnwrappedError";name="UnwrappedError"},Ea=class extends Error{name="InvalidMessageLengthError";code="ERR_INVALID_MSG_LENGTH"},Sa=class extends Error{name="InvalidDataLengthError";code="ERR_MSG_DATA_TOO_LONG"},va=class extends Error{name="InvalidDataLengthLengthError";code="ERR_MSG_LENGTH_TOO_LONG"};function vp(r){return typeof r?.closeRead=="function"}function _p(r){return typeof r?.close=="function"}function xa(r){return vp(r)?r.remoteWriteStatus!=="writable"&&r.readBufferLength===0:_p(r)?r.status!=="open":!1}function Ap(r){return r?.addEventListener!=null&&r?.removeEventListener!=null&&r?.send!=null&&r?.push!=null&&r?.log!=null}function Tp(r,e){let t=e?.maxBufferSize??Sp,n=new J,s,o=!1;if(!Ap(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 Po("Stream was unwrapped");if(xa(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 Jt(`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 Lt(s.promise,l?.signal),xa(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(xa(r))throw r.log.error("closed while reading %d/%d bytes",n.byteLength,p),new Jt(`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 Po("Stream was unwrapped");r.send(l)||await tt(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.push(n))),r}};return u}function Ip(r,e={}){let t=Tp(r,e);e.maxDataLength!=null&&e.maxLengthLength==null&&(e.maxLengthLength=De(e.maxDataLength));let n=e?.lengthDecoder??nn,s=e?.lengthEncoder??_r;return{async read(i){let a=-1,c=new J;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 Ea("Invalid message length");if(e?.maxLengthLength!=null&&c.byteLength>e.maxLengthLength)throw new va(`Message length length too long - ${c.byteLength} > ${e.maxLengthLength}`);if(a>-1)break}if(e?.maxDataLength!=null&&a>e.maxDataLength)throw new Sa(`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 Jt(`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 Jt(`Unexpected EOF - read ${u.byteLength}/${a} bytes before the stream closed`);return u},async write(i,a){await t.write(new J(s(i.byteLength),i),a)},async writeV(i,a){let c=new J(...i.flatMap(u=>[s(u.byteLength),u]));await t.write(c,a)},unwrap(){return t.unwrap()}}}function Rt(r,e){let t=Ip(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 Dp(r){return r?.addEventListener!=null}function Cp(r){let e=Ct(),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([tt(r,"drain",{rejectionEvents:["close"]})])),u===!0))break}await r.close()}}}function bl(...r){let e=r.map(t=>Dp(t)?Cp(t):t);return ml(...e)}var Pr=class extends Lo{has(e){return this.find(e)!=null}find(e){return this.queue.find(t=>e.equals(t.options.peerId))}};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)}}),wl=r=>({match:e=>r.match(e)===!1?e:!1}),q=r=>({match:e=>{let t=r.match(e);return t===!1?e:t}}),Se=(...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}}),H=(...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 Lp=O(421),zE=Q(Lp),Uo=O(54),ko=O(55),Mo=O(56),Aa=O(53),VE=Q(Uo,q(O(421))),HE=Q(ko,q(O(421))),$E=Q(Mo,q(O(421))),WE=Q(Se(Aa,Mo,Uo,ko),q(O(421))),xl=H(O(4),q(O(43))),El=H(q(O(42)),O(41),q(O(43))),Ta=Se(xl,El),Nr=Se(Ta,Aa,Uo,ko,Mo),jE=Q(Se(Ta,H(Se(Aa,Mo,Uo,ko),q(O(421))))),GE=Q(xl),YE=Q(El),ZE=Q(Ta),Ia=H(Nr,O(6)),gn=H(Nr,O(273)),XE=Q(H(Ia,q(O(421)))),QE=Q(gn),Da=H(gn,X(460),q(O(421))),Fo=H(gn,X(461),q(O(421))),Rp=Se(Da,Fo),JE=Q(Da),e2=Q(Fo),_a=Se(Nr,Ia,gn,Da,Fo),Sl=Se(H(_a,X(477),q(O(421)))),t2=Q(Sl),vl=Se(H(_a,X(478),q(O(421))),H(_a,X(448),q(O(449)),X(477),q(O(421)))),r2=Q(vl),_l=H(gn,X(280),q(O(466)),q(O(466)),q(O(421))),n2=Q(_l),Al=H(Fo,X(465),q(O(466)),q(O(466)),q(O(421))),o2=Q(Al),No=Se(Sl,vl,H(Ia,q(O(421))),H(Rp,q(O(421))),H(Nr,q(O(421))),_l,Al,O(421)),Tl=Q(No),Bp=H(q(No),X(290),wl(X(281)),q(O(421))),er=Q(Bp),Op=Se(H(No,X(290),X(281),q(O(421))),H(No,X(281),q(O(421))),H(X(281),q(O(421)))),s2=Q(Op),Pp=H(Nr,Se(H(O(6,"80")),H(O(6),X(480)),X(480)),q(O(481)),q(O(421))),i2=Q(Pp),Np=H(Nr,Se(H(O(6,"443")),H(O(6,"443"),X(480)),H(O(6),X(443)),H(O(6),X(448),X(480)),H(X(448),X(480)),X(448),X(443)),q(O(481)),q(O(421))),a2=Q(Np),Up=Se(H(O(777),q(O(421)))),c2=Q(Up),kp=Se(H(O(400),q(O(421)))),u2=Q(kp);var Ca=1e3,Il=60*Ca,Dl=15,Cl=120*Il,Ll=1,Ko=5e3,Rl=100,La="circuit-relay-source",bn=`${Va}-circuit-relay`,Bl=2*Il,Ol=BigInt(1<<17),Me="/libp2p/circuit/relay/0.2.0/hop",tr="/libp2p/circuit/relay/0.2.0/stop",Pl=30*Ca,d2=30*Ca,wn=300,Nl=4096,Ul=.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=()=>Wt(t)})(e=r.Type||(r.Type={}));let n;r.codec=()=>(n==null&&(n=Be((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),Bt.codec().encode(a.peer,c)),a.reservation!=null&&(c.uint32(26),xn.codec().encode(a.reservation,c)),a.limit!=null&&(c.uint32(34),Ot.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=Bt.codec().decode(a,a.uint32(),{limits:u.limits?.peer});break}case 3:{l.reservation=xn.codec().decode(a,a.uint32(),{limits:u.limits?.reservation});break}case 4:{l.limit=Ot.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*Bt.codec().stream(a,a.uint32(),`${u}.peer`,{limits:l.limits?.peer});break}case 3:{yield*xn.codec().stream(a,a.uint32(),`${u}.reservation`,{limits:l.limits?.reservation});break}case 4:{yield*Ot.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 Le(a,r.codec())}r.encode=s;function o(a,c){return Ce(a,r.codec(),c)}r.decode=o;function i(a,c){return Re(a,r.codec(),c)}r.stream=i})(Y||(Y={}));var Ue;(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=()=>Wt(t)})(e=r.Type||(r.Type={}));let n;r.codec=()=>(n==null&&(n=Be((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),Bt.codec().encode(a.peer,c)),a.limit!=null&&(c.uint32(26),Ot.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=Bt.codec().decode(a,a.uint32(),{limits:u.limits?.peer});break}case 3:{l.limit=Ot.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*Bt.codec().stream(a,a.uint32(),`${u}.peer`,{limits:l.limits?.peer});break}case 3:{yield*Ot.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 Le(a,r.codec())}r.encode=s;function o(a,c){return Ce(a,r.codec(),c)}r.decode=o;function i(a,c){return Re(a,r.codec(),c)}r.stream=i})(Ue||(Ue={}));var Bt;(function(r){let e;r.codec=()=>(e==null&&(e=Be((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:re(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 jt('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 jt('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 Le(o,r.codec())}r.encode=t;function n(o,i){return Ce(o,r.codec(),i)}r.decode=n;function s(o,i){return Re(o,r.codec(),i)}r.stream=s})(Bt||(Bt={}));var xn;(function(r){let e;r.codec=()=>(e==null&&(e=Be((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),En.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 jt('Decode error - repeated field "addrs" had too many elements');c.addrs.push(o.bytes());break}case 3:{c.voucher=En.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 jt('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*En.codec().stream(o,o.uint32(),`${a}.voucher`,{limits:c.limits?.voucher});break}default:{o.skipType(f&7);break}}}})),e);function t(o){return Le(o,r.codec())}r.encode=t;function n(o,i){return Ce(o,r.codec(),i)}r.decode=n;function s(o,i){return Re(o,r.codec(),i)}r.stream=s})(xn||(xn={}));var Ot;(function(r){let e;r.codec=()=>(e==null&&(e=Be((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 Le(o,r.codec())}r.encode=t;function n(o,i){return Ce(o,r.codec(),i)}r.decode=n;function s(o,i){return Re(o,r.codec(),i)}r.stream=s})(Ot||(Ot={}));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 Ra;(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"})(Ra||(Ra={}));(function(r){r.codec=()=>Wt(Ra)})(F||(F={}));var rr;(function(r){let e;r.codec=()=>(e==null&&(e=Be((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:re(0),peer:re(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 Le(o,r.codec())}r.encode=t;function n(o,i){return Ce(o,r.codec(),i)}r.decode=n;function s(o,i){return Re(o,r.codec(),i)}r.stream=s})(rr||(rr={}));var En;(function(r){let e;r.codec=()=>(e==null&&(e=Be((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),rr.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:re(0),payloadType:re(0),signature:re(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=rr.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*rr.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 Le(o,r.codec())}r.encode=t;function n(o,i){return Ce(o,r.codec(),i)}r.decode=n;function s(o,i){return Re(o,r.codec(),i)}r.stream=s})(En||(En={}));var qo=class extends Error{constructor(e="Transfer limit error"){super(e),this.name="TransferLimitError"}},zo=class extends Error{constructor(e="Duration limit error"){super(e),this.name="DurationLimitError"}},Sn=class extends Error{static name="HadEnoughRelaysError";name="HadEnoughRelaysError"},Vo=class extends Error{static name="DoubleRelayError";name="DoubleRelayError"},Ho=class extends Error{static name="RelayQueueFullError";name="RelayQueueFullError"};function kl(r,e,t){let n=e.remaining,s=o=>{let i=BigInt(o.data.byteLength);e.remaining-=i,e.remaining<0&&r.abort(new qo(`data limit of ${n} bytes exceeded`))};r.addEventListener("message",s)}function Ml(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=Oo(i);let c;n.limit?.data!=null&&(c={remaining:n.limit.data});let u=()=>{let l;t.aborted?l=t.reason:l=new zo(`duration limit of ${n.limit?.duration} ms exceeded`),o(l)};a.addEventListener("abort",u,{once:!0}),c!=null&&(kl(e,c,s),kl(r,c,s)),bl(r,e,r).catch(l=>{o(l)}).finally(()=>{a.clear()})}function Ba(r){let e=r*BigInt(1e3),t=new Date().getTime();return Number(e-BigInt(t))}var vn=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}},$o=Q(H(Tl.matchers[0],X(290))),Wo=Q(X(290));function jo(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 Pt=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 jo(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 jo(this.map.values(),e=>e.key)}values(){return jo(this.map.values(),e=>e.value)}get size(){return this.map.size}};var Go=class{filter;constructor(e,t){this.filter=Br(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 Oa(r,e=.001){return new Go(r,e)}var Pa=class extends Pt{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 Na(r){let{name:e,metrics:t}=r,n;return t!=null?n=new Pa({name:e,metrics:t}):n=new Pt,n}var Ua=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 Fl(r,e){let t=new Ua(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 Yo=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??Dl,this.applyDefaultLimit=t.applyDefaultLimit!==!1,this.reservationTtl=t.reservationTtl??Cl,this.defaultDurationLimit=t.defaultDurationLimit??Bl,this.defaultDataLimit=t.defaultDataLimit??Ol,this.reservations=Na({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:Fl(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 Zo=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 rr.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 Mp={maxOutboundStopStreams:wn},Xo=class extends Ae{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??Pl,this.maxInboundHopStreams=t.maxInboundHopStreams,this.maxOutboundHopStreams=t.maxOutboundHopStreams,this.maxOutboundStopStreams=t.maxOutboundStopStreams??Mp.maxOutboundStopStreams,this.reservationStore=new Yo(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(Me,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(Me),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),er.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:{[La]:{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:{[La]: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 hn.seal(new Zo({peer:e,relay:this.components.peerId,expiration:t}),this.components.privateKey);return{addrs:n,expire:t,voucher:{publicKey:Ze(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(er.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(Ne),i=Ir(Ye(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:Ue.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),Ml(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(tr,{maxOutboundStreams:this.maxOutboundStopStreams,runOnLimitedConnection:!0,...n}),o=Rt(s),i=o.pb(Ue);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 Nt=class extends Event{type;detail;constructor(e,t){super(e),this.type=e,this.detail=t}};var Qo=class extends Ae{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(Me,{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(Me)],orders:[()=>Math.random()<.5?1:-1,(n,s)=>{let o=Kl(n),i=Kl(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 Pr({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=Oo([AbortSignal.timeout(5e3),t]);try{await this.components.connectionManager.openConnection(e,{signal:n})}finally{n.clear()}}};function Kl(r){let e=r.metadata.get("last-dial-success");return e==null?0:new Date($(e)).getTime()}var Ma=class extends Ae{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??Ko,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(Wo.exactMatch(e))this.log("searching for circuit relay servers"),this.reservationId=this.reservationStore.reserveRelay();else if($o.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 Ut(`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=>Ne(t).encapsulate("/p2p-circuit")),this.listeningAddrs.forEach(t=>{this.addressManager.confirmObservedAddr(t,{type:"transport"})}),queueMicrotask(()=>{this.safeDispatchEvent("listening")})}};function ql(r){return new Ma(r)}var zl="useandom-26T198340PX75pxJACKVERYMINDBUSHWOLF_GQZbfghjklqvwyzrict";var Vl=(r=21)=>{let e="",t=crypto.getRandomValues(new Uint8Array(r|=0));for(;r--;)e+=zl[t[r]&63];return e};var Fp=60*1e3*10,Kp=60*1e3*5,qp=30*1e3,Jo=class extends Ae{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 Pt,this.pendingReservations=[],this.maxReservationQueueLength=t?.maxReservationQueueLength??Rl,this.reservationCompletionTimeout=t?.reservationCompletionTimeout??Ko,this.started=!1,this.relayFilter=Br(100),this.reserveQueue=new Pr({concurrency:t?.reservationConcurrency??Ll,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(bn)]});this.log("removing tag from %d old relays",e.length),await Promise.all(e.map(async t=>{await this.peerStore.merge(t.id,{tags:{[bn]: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=Vl();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 Ut("Cannot use self as relay");if(this.reserveQueue.size>this.maxReservationQueueLength)throw new Ho("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 Ut("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&&Ba(o.reservation.expire)>Fp)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 Sn("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(er.matches(a.remoteAddr))throw new Vo("not creating reservation over relayed connection");let c=await this.#e(a,{signal:i}),u=Ba(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-Kp,qp),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 Sn("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:{[bn]:{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(Me,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=Ne(u);l.getComponents().find(f=>f.code===421)==null&&(l=l.encapsulate(`/p2p/${e.remotePeer}`)),l=Ne(l.toString().replace(`/p2p/${e.remotePeer}/p2p/${e.remotePeer}`,`/p2p/${e.remotePeer}`)),c.add(l.toString())}return i.reservation.addrs=[...c].map(u=>Ne(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:{[bn]: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=Br(100),this.log("not discovered enough relays %d/%d",this.reservations.size,this.pendingReservations.length),this.safeDispatchEvent("relay:not-enough-relays")}};var Fa=class extends Bo{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 Ka(r){return new Fa(r)}var zp=r=>{if(r.peer==null)return!1;try{r.peer.addrs.forEach(Ne)}catch{return!1}return!0},Hl={maxInboundStopStreams:wn,maxOutboundStopStreams:wn,stopTimeout:3e4},es=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??Hl.maxInboundStopStreams,this.maxOutboundStopStreams=t.maxOutboundStopStreams??Hl.maxOutboundStopStreams,this.shutdownController=new AbortController,this.discovery=new Qo(e,{filter:t.discoveryFilter??Oa(Nl,Ul)}),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 Jo(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";[Ya]=["@libp2p/transport","@libp2p/circuit-relay-v2-transport"];get[Za](){return this.discovery!=null?["@libp2p/identify"]:[]}[Ga]=!0;isStarted(){return this.started}async start(){this.shutdownController=new AbortController,this.shutdownController.signal,await this.components.registrar.handle(tr,this.onStop,{maxInboundStreams:this.maxInboundStopStreams,maxOutboundStreams:this.maxOutboundStopStreams,runOnLimitedConnection:!0}),await $a(this.discovery,this.reservationStore),this.started=!0}async stop(){this.shutdownController.abort(),await Wa(this.discovery,this.reservationStore),await this.components.registrar.unhandle(tr),this.started=!1}async dial(e,t){let n=e.toString().split("/p2p-circuit"),s=Ne(n[0]),o=Ne(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 Cn(`C${d}`)}let c=qi(i),u=qi(a),f=this.components.connectionManager.getConnections(c)[0];f==null?(await this.components.peerStore.merge(c,{multiaddrs:[s]}),t.onProgress?.(new Nt("circuit-relay:open-connection")),f=await this.components.connectionManager.openConnection(c,t)):t.onProgress?.(new Nt("circuit-relay:reuse-connection"));let p;try{t.onProgress?.(new Nt("circuit-relay:open-hop-stream")),p=await f.newStream(Me,t);let d=Rt(p).pb(Y);t.onProgress?.(new Nt("circuit-relay:write-connect-message")),await d.write({type:Y.Type.CONNECT,peer:{id:u.toMultihash().bytes,addrs:[Ne(o).bytes]}},t),t.onProgress?.(new Nt("circuit-relay:read-connect-response"));let y=await d.read(t);if(y.status!==F.OK)throw new Dn(`failed to connect via relay with status ${y?.status?.toString()??"undefined"}`);let x=new vn(y.limit),h=Ka({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 ql({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=>$o.exactMatch(t)||Wo.exactMatch(t))}dialFilter(e){return e=Array.isArray(e)?e:[e],e.filter(t=>er.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(Ue),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:Ue.Type.STATUS,status:F.MALFORMED_MESSAGE},{signal:n}),await e.close({signal:n});return}if(o.type!==Ue.Type.CONNECT){this.log.error("invalid stop connect request via peer %p",t.remotePeer),await s.write({type:Ue.Type.STATUS,status:F.UNEXPECTED_MESSAGE},{signal:n}),await e.close({signal:n});return}if(!zp(o)){this.log.error("invalid stop connect request via peer %p",t.remotePeer),await s.write({type:Ue.Type.STATUS,status:F.MALFORMED_MESSAGE},{signal:n}),await e.close({signal:n});return}let i=Ir(Ye(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:Ue.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:Ue.Type.STATUS,status:F.OK},{signal:n});let a=new vn(o.limit),c=t.remoteAddr.encapsulate(`/p2p-circuit/p2p/${i.toString()}`),u=this.components.addressManager.getAddresses()[0],l=Ka({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 Vp(r={}){return e=>new Xo(e,r)}function Hp(r={}){return e=>new es(e,r)}return Yl($p);})();
|
|
3
3
|
/*! Bundled license information:
|
|
4
4
|
|
|
5
|
-
@noble/hashes/utils.js:
|
|
6
|
-
(*! noble-hashes - MIT License (c) 2022 Paul Miller (paulmillr.com) *)
|
|
7
|
-
|
|
8
5
|
@noble/curves/utils.js:
|
|
9
6
|
@noble/curves/abstract/modular.js:
|
|
10
7
|
@noble/curves/abstract/curve.js:
|