@libp2p/circuit-relay-v2 3.2.6-5fe2a18fc → 3.2.6-a6c9aee5a
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/index.min.js +1 -1
- package/package.json +10 -10
package/dist/index.min.js
CHANGED
@@ -1,5 +1,5 @@
|
|
1
1
|
(function (root, factory) {(typeof module === 'object' && module.exports) ? module.exports = factory() : root.Libp2PCircuitRelayV2 = factory()}(typeof self !== 'undefined' ? self : this, function () {
|
2
|
-
"use strict";var Libp2PCircuitRelayV2=(()=>{var go=Object.defineProperty;var vu=Object.getOwnPropertyDescriptor;var Su=Object.getOwnPropertyNames;var Au=Object.prototype.hasOwnProperty;var _t=(r,t)=>{for(var e in t)go(r,e,{get:t[e],enumerable:!0})},_u=(r,t,e,n)=>{if(t&&typeof t=="object"||typeof t=="function")for(let o of Su(t))!Au.call(r,o)&&o!==e&&go(r,o,{get:()=>t[o],enumerable:!(n=vu(t,o))||n.enumerable});return r};var Iu=r=>_u(go({},"__esModule",{value:!0}),r);var hd={};_t(hd,{RELAY_V2_HOP_CODEC:()=>qt,RELAY_V2_STOP_CODEC:()=>Me,circuitRelayServer:()=>tu,circuitRelayTransport:()=>du});var bo=Symbol.for("@libp2p/peer-id");var xo="keep-alive";var Ns=Symbol.for("@libp2p/transport");var Ps;(function(r){r[r.FATAL_ALL=0]="FATAL_ALL",r[r.NO_FATAL=1]="NO_FATAL"})(Ps||(Ps={}));var Jt=class extends Error{static name="AbortError";constructor(t="The operation was aborted"){super(t),this.name="AbortError"}};var bt=class extends Error{static name="InvalidParametersError";constructor(t="Invalid parameters"){super(t),this.name="InvalidParametersError"}},Fe=class extends Error{static name="InvalidPublicKeyError";constructor(t="Invalid public key"){super(t),this.name="InvalidPublicKeyError"}};var Hr=class extends Error{static name="InvalidMultihashError";constructor(t="Invalid Multihash"){super(t),this.name="InvalidMultihashError"}};var Gr=class extends Error{static name="InvalidMessageError";constructor(t="Invalid message"){super(t),this.name="InvalidMessageError"}};var dr=class extends Error{static name="DialError";constructor(t="Dial error"){super(t),this.name="DialError"}},Ie=class extends Error{static name="ListenError";constructor(t="Listen error"){super(t),this.name="ListenError"}};var ze=class extends Error{static name="UnsupportedKeyTypeError";constructor(t="Unsupported key type"){super(t),this.name="UnsupportedKeyTypeError"}};var Ot=class extends EventTarget{#t=new Map;constructor(){super()}listenerCount(t){let e=this.#t.get(t);return e==null?0:e.length}addEventListener(t,e,n){super.addEventListener(t,e,n);let o=this.#t.get(t);o==null&&(o=[],this.#t.set(t,o)),o.push({callback:e,once:(n!==!0&&n!==!1&&n?.once)??!1})}removeEventListener(t,e,n){super.removeEventListener(t.toString(),e??null,n);let o=this.#t.get(t);o!=null&&(o=o.filter(({callback:i})=>i!==e),this.#t.set(t,o))}dispatchEvent(t){let e=super.dispatchEvent(t),n=this.#t.get(t.type);return n==null||(n=n.filter(({once:o})=>!o),this.#t.set(t.type,n)),e}safeDispatchEvent(t,e={}){return this.dispatchEvent(new CustomEvent(t,e))}};function Us(r){return r!=null&&typeof r.start=="function"&&typeof r.stop=="function"}async function Os(...r){let t=[];for(let e of r)Us(e)&&t.push(e);await Promise.all(t.map(async e=>{e.beforeStart!=null&&await e.beforeStart()})),await Promise.all(t.map(async e=>{await e.start()})),await Promise.all(t.map(async e=>{e.afterStart!=null&&await e.afterStart()}))}async function Ms(...r){let t=[];for(let e of r)Us(e)&&t.push(e);await Promise.all(t.map(async e=>{e.beforeStop!=null&&await e.beforeStop()})),await Promise.all(t.map(async e=>{await e.stop()})),await Promise.all(t.map(async e=>{e.afterStop!=null&&await e.afterStop()}))}var ks=Symbol.for("@libp2p/service-capabilities"),Ks=Symbol.for("@libp2p/service-dependencies");var Ao={};_t(Ao,{base58btc:()=>Q,base58flickr:()=>Du});var zd=new Uint8Array(0);function qs(r,t){if(r===t)return!0;if(r.byteLength!==t.byteLength)return!1;for(let e=0;e<r.byteLength;e++)if(r[e]!==t[e])return!1;return!0}function te(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 Fs(r){return new TextEncoder().encode(r)}function zs(r){return new TextDecoder().decode(r)}function Tu(r,t){if(r.length>=255)throw new TypeError("Alphabet too long");for(var e=new Uint8Array(256),n=0;n<e.length;n++)e[n]=255;for(var o=0;o<r.length;o++){var i=r.charAt(o),s=i.charCodeAt(0);if(e[s]!==255)throw new TypeError(i+" is ambiguous");e[s]=o}var a=r.length,c=r.charAt(0),l=Math.log(a)/Math.log(256),u=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 b=0,h=0,w=0,v=y.length;w!==v&&y[w]===0;)w++,b++;for(var m=(v-w)*u+1>>>0,_=new Uint8Array(m);w!==v;){for(var B=y[w],C=0,I=m-1;(B!==0||C<h)&&I!==-1;I--,C++)B+=256*_[I]>>>0,_[I]=B%a>>>0,B=B/a>>>0;if(B!==0)throw new Error("Non-zero carry");h=C,w++}for(var R=m-h;R!==m&&_[R]===0;)R++;for(var T=c.repeat(b);R<m;++R)T+=r.charAt(_[R]);return T}function d(y){if(typeof y!="string")throw new TypeError("Expected String");if(y.length===0)return new Uint8Array;var b=0;if(y[b]!==" "){for(var h=0,w=0;y[b]===c;)h++,b++;for(var v=(y.length-b)*l+1>>>0,m=new Uint8Array(v);y[b];){var _=e[y.charCodeAt(b)];if(_===255)return;for(var B=0,C=v-1;(_!==0||B<w)&&C!==-1;C--,B++)_+=a*m[C]>>>0,m[C]=_%256>>>0,_=_/256>>>0;if(_!==0)throw new Error("Non-zero carry");w=B,b++}if(y[b]!==" "){for(var I=v-w;I!==v&&m[I]===0;)I++;for(var R=new Uint8Array(h+(v-I)),T=h;I!==v;)R[T++]=m[I++];return R}}}function g(y){var b=d(y);if(b)return b;throw new Error(`Non-${t} character`)}return{encode:f,decodeUnsafe:d,decode:g}}var Lu=Tu,Ru=Lu,Hs=Ru;var wo=class{name;prefix;baseEncode;constructor(t,e,n){this.name=t,this.prefix=e,this.baseEncode=n}encode(t){if(t instanceof Uint8Array)return`${this.prefix}${this.baseEncode(t)}`;throw Error("Unknown type, must be binary type")}},Eo=class{name;prefix;baseDecode;prefixCodePoint;constructor(t,e,n){this.name=t,this.prefix=e;let o=e.codePointAt(0);if(o===void 0)throw new Error("Invalid prefix character");this.prefixCodePoint=o,this.baseDecode=n}decode(t){if(typeof t=="string"){if(t.codePointAt(0)!==this.prefixCodePoint)throw Error(`Unable to decode multibase string ${JSON.stringify(t)}, ${this.name} decoder only supports inputs prefixed with ${this.prefix}`);return this.baseDecode(t.slice(this.prefix.length))}else throw Error("Can only multibase decode strings")}or(t){return Gs(this,t)}},vo=class{decoders;constructor(t){this.decoders=t}or(t){return Gs(this,t)}decode(t){let e=t[0],n=this.decoders[e];if(n!=null)return n.decode(t);throw RangeError(`Unable to decode multibase string ${JSON.stringify(t)}, only inputs prefixed with ${Object.keys(this.decoders)} are supported`)}};function Gs(r,t){return new vo({...r.decoders??{[r.prefix]:r},...t.decoders??{[t.prefix]:t}})}var So=class{name;prefix;baseEncode;baseDecode;encoder;decoder;constructor(t,e,n,o){this.name=t,this.prefix=e,this.baseEncode=n,this.baseDecode=o,this.encoder=new wo(t,e,n),this.decoder=new Eo(t,e,o)}encode(t){return this.encoder.encode(t)}decode(t){return this.decoder.decode(t)}};function Ve({name:r,prefix:t,encode:e,decode:n}){return new So(r,t,e,n)}function fe({name:r,prefix:t,alphabet:e}){let{encode:n,decode:o}=Hs(e,r);return Ve({prefix:t,name:r,encode:n,decode:i=>te(o(i))})}function Bu(r,t,e,n){let o={};for(let u=0;u<t.length;++u)o[t[u]]=u;let i=r.length;for(;r[i-1]==="=";)--i;let s=new Uint8Array(i*e/8|0),a=0,c=0,l=0;for(let u=0;u<i;++u){let f=o[r[u]];if(f===void 0)throw new SyntaxError(`Non-${n} character`);c=c<<e|f,a+=e,a>=8&&(a-=8,s[l++]=255&c>>a)}if(a>=e||(255&c<<8-a)!==0)throw new SyntaxError("Unexpected end of data");return s}function Cu(r,t,e){let n=t[t.length-1]==="=",o=(1<<e)-1,i="",s=0,a=0;for(let c=0;c<r.length;++c)for(a=a<<8|r[c],s+=8;s>e;)s-=e,i+=t[o&a>>s];if(s!==0&&(i+=t[o&a<<e-s]),n)for(;(i.length*e&7)!==0;)i+="=";return i}function st({name:r,prefix:t,bitsPerChar:e,alphabet:n}){return Ve({prefix:t,name:r,encode(o){return Cu(o,n,e)},decode(o){return Bu(o,n,e,r)}})}var Q=fe({name:"base58btc",prefix:"z",alphabet:"123456789ABCDEFGHJKLMNPQRSTUVWXYZabcdefghijkmnopqrstuvwxyz"}),Du=fe({name:"base58flickr",prefix:"Z",alphabet:"123456789abcdefghijkmnopqrstuvwxyzABCDEFGHJKLMNPQRSTUVWXYZ"});var _o={};_t(_o,{base32:()=>ee,base32hex:()=>Ou,base32hexpad:()=>ku,base32hexpadupper:()=>Ku,base32hexupper:()=>Mu,base32pad:()=>Nu,base32padupper:()=>Uu,base32upper:()=>Pu,base32z:()=>qu});var ee=st({prefix:"b",name:"base32",alphabet:"abcdefghijklmnopqrstuvwxyz234567",bitsPerChar:5}),Pu=st({prefix:"B",name:"base32upper",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZ234567",bitsPerChar:5}),Nu=st({prefix:"c",name:"base32pad",alphabet:"abcdefghijklmnopqrstuvwxyz234567=",bitsPerChar:5}),Uu=st({prefix:"C",name:"base32padupper",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZ234567=",bitsPerChar:5}),Ou=st({prefix:"v",name:"base32hex",alphabet:"0123456789abcdefghijklmnopqrstuv",bitsPerChar:5}),Mu=st({prefix:"V",name:"base32hexupper",alphabet:"0123456789ABCDEFGHIJKLMNOPQRSTUV",bitsPerChar:5}),ku=st({prefix:"t",name:"base32hexpad",alphabet:"0123456789abcdefghijklmnopqrstuv=",bitsPerChar:5}),Ku=st({prefix:"T",name:"base32hexpadupper",alphabet:"0123456789ABCDEFGHIJKLMNOPQRSTUV=",bitsPerChar:5}),qu=st({prefix:"h",name:"base32z",alphabet:"ybndrfg8ejkmcpqxot1uwisza345h769",bitsPerChar:5});var Io={};_t(Io,{base36:()=>pr,base36upper:()=>Fu});var pr=fe({prefix:"k",name:"base36",alphabet:"0123456789abcdefghijklmnopqrstuvwxyz"}),Fu=fe({prefix:"K",name:"base36upper",alphabet:"0123456789ABCDEFGHIJKLMNOPQRSTUVWXYZ"});var zu=$s,Zs=128,Vu=127,Hu=~Vu,Gu=Math.pow(2,31);function $s(r,t,e){t=t||[],e=e||0;for(var n=e;r>=Gu;)t[e++]=r&255|Zs,r/=128;for(;r&Hu;)t[e++]=r&255|Zs,r>>>=7;return t[e]=r|0,$s.bytes=e-n+1,t}var Zu=To,Wu=128,Ws=127;function To(r,n){var e=0,n=n||0,o=0,i=n,s,a=r.length;do{if(i>=a)throw To.bytes=0,new RangeError("Could not decode varint");s=r[i++],e+=o<28?(s&Ws)<<o:(s&Ws)*Math.pow(2,o),o+=7}while(s>=Wu);return To.bytes=i-n,e}var $u=Math.pow(2,7),Yu=Math.pow(2,14),Xu=Math.pow(2,21),Qu=Math.pow(2,28),ju=Math.pow(2,35),Ju=Math.pow(2,42),tl=Math.pow(2,49),el=Math.pow(2,56),rl=Math.pow(2,63),nl=function(r){return r<$u?1:r<Yu?2:r<Xu?3:r<Qu?4:r<ju?5:r<Ju?6:r<tl?7:r<el?8:r<rl?9:10},ol={encode:zu,decode:Zu,encodingLength:nl},il=ol,mr=il;function yr(r,t=0){return[mr.decode(r,t),mr.decode.bytes]}function He(r,t,e=0){return mr.encode(r,t,e),t}function Ge(r){return mr.encodingLength(r)}function Ft(r,t){let e=t.byteLength,n=Ge(r),o=n+Ge(e),i=new Uint8Array(o+e);return He(r,i,0),He(e,i,n),i.set(t,o),new Ze(r,e,t,i)}function Mt(r){let t=te(r),[e,n]=yr(t),[o,i]=yr(t.subarray(n)),s=t.subarray(n+i);if(s.byteLength!==o)throw new Error("Incorrect length");return new Ze(e,o,s,t)}function Ys(r,t){if(r===t)return!0;{let e=t;return r.code===e.code&&r.size===e.size&&e.bytes instanceof Uint8Array&&qs(r.bytes,e.bytes)}}var Ze=class{code;size;digest;bytes;constructor(t,e,n,o){this.code=t,this.size=e,this.digest=n,this.bytes=o}};function Xs(r,t){let{bytes:e,version:n}=r;switch(n){case 0:return al(e,Lo(r),t??Q.encoder);default:return cl(e,Lo(r),t??ee.encoder)}}var Qs=new WeakMap;function Lo(r){let t=Qs.get(r);if(t==null){let e=new Map;return Qs.set(r,e),e}return t}var dt=class r{code;version;multihash;bytes;"/";constructor(t,e,n,o){this.code=e,this.version=t,this.multihash=n,this.bytes=o,this["/"]=o}get asCID(){return this}get byteOffset(){return this.bytes.byteOffset}get byteLength(){return this.bytes.byteLength}toV0(){switch(this.version){case 0:return this;case 1:{let{code:t,multihash:e}=this;if(t!==gr)throw new Error("Cannot convert a non dag-pb CID to CIDv0");if(e.code!==ul)throw new Error("Cannot convert non sha2-256 multihash CID to CIDv0");return r.createV0(e)}default:throw Error(`Can not convert CID version ${this.version} to version 0. This is a bug please report`)}}toV1(){switch(this.version){case 0:{let{code:t,digest:e}=this.multihash,n=Ft(t,e);return r.createV1(this.code,n)}case 1:return this;default:throw Error(`Can not convert CID version ${this.version} to version 1. This is a bug please report`)}}equals(t){return r.equals(this,t)}static equals(t,e){let n=e;return n!=null&&t.code===n.code&&t.version===n.version&&Ys(t.multihash,n.multihash)}toString(t){return Xs(this,t)}toJSON(){return{"/":Xs(this)}}link(){return this}[Symbol.toStringTag]="CID";[Symbol.for("nodejs.util.inspect.custom")](){return`CID(${this.toString()})`}static asCID(t){if(t==null)return null;let e=t;if(e instanceof r)return e;if(e["/"]!=null&&e["/"]===e.bytes||e.asCID===e){let{version:n,code:o,multihash:i,bytes:s}=e;return new r(n,o,i,s??js(n,o,i.bytes))}else if(e[ll]===!0){let{version:n,multihash:o,code:i}=e,s=Mt(o);return r.create(n,i,s)}else return null}static create(t,e,n){if(typeof e!="number")throw new Error("String codecs are no longer supported");if(!(n.bytes instanceof Uint8Array))throw new Error("Invalid digest");switch(t){case 0:{if(e!==gr)throw new Error(`Version 0 CID must use dag-pb (code: ${gr}) block encoding`);return new r(t,e,n,n.bytes)}case 1:{let o=js(t,e,n.bytes);return new r(t,e,n,o)}default:throw new Error("Invalid version")}}static createV0(t){return r.create(0,gr,t)}static createV1(t,e){return r.create(1,t,e)}static decode(t){let[e,n]=r.decodeFirst(t);if(n.length!==0)throw new Error("Incorrect length");return e}static decodeFirst(t){let e=r.inspectBytes(t),n=e.size-e.multihashSize,o=te(t.subarray(n,n+e.multihashSize));if(o.byteLength!==e.multihashSize)throw new Error("Incorrect length");let i=o.subarray(e.multihashSize-e.digestSize),s=new Ze(e.multihashCode,e.digestSize,i,o);return[e.version===0?r.createV0(s):r.createV1(e.codec,s),t.subarray(e.size)]}static inspectBytes(t){let e=0,n=()=>{let[f,d]=yr(t.subarray(e));return e+=d,f},o=n(),i=gr;if(o===18?(o=0,e=0):i=n(),o!==0&&o!==1)throw new RangeError(`Invalid CID version ${o}`);let s=e,a=n(),c=n(),l=e+c,u=l-s;return{version:o,codec:i,multihashCode:a,digestSize:c,multihashSize:u,size:l}}static parse(t,e){let[n,o]=sl(t,e),i=r.decode(o);if(i.version===0&&t[0]!=="Q")throw Error("Version 0 CID string must not include multibase prefix");return Lo(i).set(n,t),i}};function sl(r,t){switch(r[0]){case"Q":{let e=t??Q;return[Q.prefix,e.decode(`${Q.prefix}${r}`)]}case Q.prefix:{let e=t??Q;return[Q.prefix,e.decode(r)]}case ee.prefix:{let e=t??ee;return[ee.prefix,e.decode(r)]}case pr.prefix:{let e=t??pr;return[pr.prefix,e.decode(r)]}default:{if(t==null)throw Error("To parse non base32, base36 or base58btc encoded CID multibase decoder must be provided");return[r[0],t.decode(r)]}}}function al(r,t,e){let{prefix:n}=e;if(n!==Q.prefix)throw Error(`Cannot string encode V0 in ${e.name} encoding`);let o=t.get(n);if(o==null){let i=e.encode(r).slice(1);return t.set(n,i),i}else return o}function cl(r,t,e){let{prefix:n}=e,o=t.get(n);if(o==null){let i=e.encode(r);return t.set(n,i),i}else return o}var gr=112,ul=18;function js(r,t,e){let n=Ge(r),o=n+Ge(t),i=new Uint8Array(o+e.byteLength);return He(r,i,0),He(t,i,n),i.set(e,o),i}var ll=Symbol.for("@ipld/js-cid/CID");var Ro={};_t(Ro,{identity:()=>re});var Js=0,fl="identity",ta=te;function hl(r){return Ft(Js,ta(r))}var re={code:Js,name:fl,encode:ta,digest:hl};function pt(r,t){if(r===t)return!0;if(r.byteLength!==t.byteLength)return!1;for(let e=0;e<r.byteLength;e++)if(r[e]!==t[e])return!1;return!0}function ea(r){if(!Number.isSafeInteger(r)||r<0)throw new Error("positive integer expected, got "+r)}function dl(r){return r instanceof Uint8Array||ArrayBuffer.isView(r)&&r.constructor.name==="Uint8Array"}function We(r,...t){if(!dl(r))throw new Error("Uint8Array expected");if(t.length>0&&!t.includes(r.length))throw new Error("Uint8Array expected of length "+t+", got length="+r.length)}function ra(r){if(typeof r!="function"||typeof r.create!="function")throw new Error("Hash should be wrapped by utils.wrapConstructor");ea(r.outputLen),ea(r.blockLen)}function $e(r,t=!0){if(r.destroyed)throw new Error("Hash instance has been destroyed");if(t&&r.finished)throw new Error("Hash#digest() has already been called")}function na(r,t){We(r);let e=t.outputLen;if(r.length<e)throw new Error("digestInto() expects output buffer of length at least "+e)}var Te=typeof globalThis=="object"&&"crypto"in globalThis?globalThis.crypto:void 0;function Wr(r){return new DataView(r.buffer,r.byteOffset,r.byteLength)}function zt(r,t){return r<<32-t|r>>>t}function oa(r){if(typeof r!="string")throw new Error("utf8ToBytes expected string, got "+typeof r);return new Uint8Array(new TextEncoder().encode(r))}function br(r){return typeof r=="string"&&(r=oa(r)),We(r),r}function Bo(...r){let t=0;for(let n=0;n<r.length;n++){let o=r[n];We(o),t+=o.length}let e=new Uint8Array(t);for(let n=0,o=0;n<r.length;n++){let i=r[n];e.set(i,o),o+=i.length}return e}var Ye=class{clone(){return this._cloneInto()}};function $r(r){let t=n=>r().update(br(n)).digest(),e=r();return t.outputLen=e.outputLen,t.blockLen=e.blockLen,t.create=()=>r(),t}function Yr(r=32){if(Te&&typeof Te.getRandomValues=="function")return Te.getRandomValues(new Uint8Array(r));if(Te&&typeof Te.randomBytes=="function")return Te.randomBytes(r);throw new Error("crypto.getRandomValues must be defined")}function pl(r,t,e,n){if(typeof r.setBigUint64=="function")return r.setBigUint64(t,e,n);let o=BigInt(32),i=BigInt(4294967295),s=Number(e>>o&i),a=Number(e&i),c=n?4:0,l=n?0:4;r.setUint32(t+c,s,n),r.setUint32(t+l,a,n)}function ia(r,t,e){return r&t^~r&e}function sa(r,t,e){return r&t^r&e^t&e}var Xe=class extends Ye{constructor(t,e,n,o){super(),this.blockLen=t,this.outputLen=e,this.padOffset=n,this.isLE=o,this.finished=!1,this.length=0,this.pos=0,this.destroyed=!1,this.buffer=new Uint8Array(t),this.view=Wr(this.buffer)}update(t){$e(this);let{view:e,buffer:n,blockLen:o}=this;t=br(t);let i=t.length;for(let s=0;s<i;){let a=Math.min(o-this.pos,i-s);if(a===o){let c=Wr(t);for(;o<=i-s;s+=o)this.process(c,s);continue}n.set(t.subarray(s,s+a),this.pos),this.pos+=a,s+=a,this.pos===o&&(this.process(e,0),this.pos=0)}return this.length+=t.length,this.roundClean(),this}digestInto(t){$e(this),na(t,this),this.finished=!0;let{buffer:e,view:n,blockLen:o,isLE:i}=this,{pos:s}=this;e[s++]=128,this.buffer.subarray(s).fill(0),this.padOffset>o-s&&(this.process(n,0),s=0);for(let f=s;f<o;f++)e[f]=0;pl(n,o-8,BigInt(this.length*8),i),this.process(n,0);let a=Wr(t),c=this.outputLen;if(c%4)throw new Error("_sha2: outputLen should 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],i)}digest(){let{buffer:t,outputLen:e}=this;this.digestInto(t);let n=t.slice(0,e);return this.destroy(),n}_cloneInto(t){t||(t=new this.constructor),t.set(...this.get());let{blockLen:e,buffer:n,length:o,finished:i,destroyed:s,pos:a}=this;return t.length=o,t.pos=a,t.finished=i,t.destroyed=s,o%e&&t.buffer.set(n),t}};var Xr=BigInt(4294967295),Co=BigInt(32);function aa(r,t=!1){return t?{h:Number(r&Xr),l:Number(r>>Co&Xr)}:{h:Number(r>>Co&Xr)|0,l:Number(r&Xr)|0}}function ml(r,t=!1){let e=new Uint32Array(r.length),n=new Uint32Array(r.length);for(let o=0;o<r.length;o++){let{h:i,l:s}=aa(r[o],t);[e[o],n[o]]=[i,s]}return[e,n]}var yl=(r,t)=>BigInt(r>>>0)<<Co|BigInt(t>>>0),gl=(r,t,e)=>r>>>e,bl=(r,t,e)=>r<<32-e|t>>>e,xl=(r,t,e)=>r>>>e|t<<32-e,wl=(r,t,e)=>r<<32-e|t>>>e,El=(r,t,e)=>r<<64-e|t>>>e-32,vl=(r,t,e)=>r>>>e-32|t<<64-e,Sl=(r,t)=>t,Al=(r,t)=>r,_l=(r,t,e)=>r<<e|t>>>32-e,Il=(r,t,e)=>t<<e|r>>>32-e,Tl=(r,t,e)=>t<<e-32|r>>>64-e,Ll=(r,t,e)=>r<<e-32|t>>>64-e;function Rl(r,t,e,n){let o=(t>>>0)+(n>>>0);return{h:r+e+(o/2**32|0)|0,l:o|0}}var Bl=(r,t,e)=>(r>>>0)+(t>>>0)+(e>>>0),Cl=(r,t,e,n)=>t+e+n+(r/2**32|0)|0,Dl=(r,t,e,n)=>(r>>>0)+(t>>>0)+(e>>>0)+(n>>>0),Pl=(r,t,e,n,o)=>t+e+n+o+(r/2**32|0)|0,Nl=(r,t,e,n,o)=>(r>>>0)+(t>>>0)+(e>>>0)+(n>>>0)+(o>>>0),Ul=(r,t,e,n,o,i)=>t+e+n+o+i+(r/2**32|0)|0;var Ol={fromBig:aa,split:ml,toBig:yl,shrSH:gl,shrSL:bl,rotrSH:xl,rotrSL:wl,rotrBH:El,rotrBL:vl,rotr32H:Sl,rotr32L:Al,rotlSH:_l,rotlSL:Il,rotlBH:Tl,rotlBL:Ll,add:Rl,add3L:Bl,add3H:Cl,add4L:Dl,add4H:Pl,add5H:Ul,add5L:Nl},U=Ol;var[Ml,kl]=U.split(["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))),he=new Uint32Array(80),de=new Uint32Array(80),Do=class extends Xe{constructor(){super(128,64,16,!1),this.Ah=1779033703,this.Al=-205731576,this.Bh=-1150833019,this.Bl=-2067093701,this.Ch=1013904242,this.Cl=-23791573,this.Dh=-1521486534,this.Dl=1595750129,this.Eh=1359893119,this.El=-1377402159,this.Fh=-1694144372,this.Fl=725511199,this.Gh=528734635,this.Gl=-79577749,this.Hh=1541459225,this.Hl=327033209}get(){let{Ah:t,Al:e,Bh:n,Bl:o,Ch:i,Cl:s,Dh:a,Dl:c,Eh:l,El:u,Fh:f,Fl:d,Gh:g,Gl:y,Hh:b,Hl:h}=this;return[t,e,n,o,i,s,a,c,l,u,f,d,g,y,b,h]}set(t,e,n,o,i,s,a,c,l,u,f,d,g,y,b,h){this.Ah=t|0,this.Al=e|0,this.Bh=n|0,this.Bl=o|0,this.Ch=i|0,this.Cl=s|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=g|0,this.Gl=y|0,this.Hh=b|0,this.Hl=h|0}process(t,e){for(let m=0;m<16;m++,e+=4)he[m]=t.getUint32(e),de[m]=t.getUint32(e+=4);for(let m=16;m<80;m++){let _=he[m-15]|0,B=de[m-15]|0,C=U.rotrSH(_,B,1)^U.rotrSH(_,B,8)^U.shrSH(_,B,7),I=U.rotrSL(_,B,1)^U.rotrSL(_,B,8)^U.shrSL(_,B,7),R=he[m-2]|0,T=de[m-2]|0,et=U.rotrSH(R,T,19)^U.rotrBH(R,T,61)^U.shrSH(R,T,6),V=U.rotrSL(R,T,19)^U.rotrBL(R,T,61)^U.shrSL(R,T,6),q=U.add4L(I,V,de[m-7],de[m-16]),ct=U.add4H(q,C,et,he[m-7],he[m-16]);he[m]=ct|0,de[m]=q|0}let{Ah:n,Al:o,Bh:i,Bl:s,Ch:a,Cl:c,Dh:l,Dl:u,Eh:f,El:d,Fh:g,Fl:y,Gh:b,Gl:h,Hh:w,Hl:v}=this;for(let m=0;m<80;m++){let _=U.rotrSH(f,d,14)^U.rotrSH(f,d,18)^U.rotrBH(f,d,41),B=U.rotrSL(f,d,14)^U.rotrSL(f,d,18)^U.rotrBL(f,d,41),C=f&g^~f&b,I=d&y^~d&h,R=U.add5L(v,B,I,kl[m],de[m]),T=U.add5H(R,w,_,C,Ml[m],he[m]),et=R|0,V=U.rotrSH(n,o,28)^U.rotrBH(n,o,34)^U.rotrBH(n,o,39),q=U.rotrSL(n,o,28)^U.rotrBL(n,o,34)^U.rotrBL(n,o,39),ct=n&i^n&a^i&a,S=o&s^o&c^s&c;w=b|0,v=h|0,b=g|0,h=y|0,g=f|0,y=d|0,{h:f,l:d}=U.add(l|0,u|0,T|0,et|0),l=a|0,u=c|0,a=i|0,c=s|0,i=n|0,s=o|0;let L=U.add3L(et,q,S);n=U.add3H(L,T,V,ct),o=L|0}({h:n,l:o}=U.add(this.Ah|0,this.Al|0,n|0,o|0)),{h:i,l:s}=U.add(this.Bh|0,this.Bl|0,i|0,s|0),{h:a,l:c}=U.add(this.Ch|0,this.Cl|0,a|0,c|0),{h:l,l:u}=U.add(this.Dh|0,this.Dl|0,l|0,u|0),{h:f,l:d}=U.add(this.Eh|0,this.El|0,f|0,d|0),{h:g,l:y}=U.add(this.Fh|0,this.Fl|0,g|0,y|0),{h:b,l:h}=U.add(this.Gh|0,this.Gl|0,b|0,h|0),{h:w,l:v}=U.add(this.Hh|0,this.Hl|0,w|0,v|0),this.set(n,o,i,s,a,c,l,u,f,d,g,y,b,h,w,v)}roundClean(){he.fill(0),de.fill(0)}destroy(){this.buffer.fill(0),this.set(0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0)}};var ca=$r(()=>new Do);var Jr={};_t(Jr,{aInRange:()=>Tt,abool:()=>Vt,abytes:()=>Qe,bitGet:()=>Hl,bitLen:()=>Oo,bitMask:()=>wr,bitSet:()=>Gl,bytesToHex:()=>oe,bytesToNumberBE:()=>ie,bytesToNumberLE:()=>me,concatBytes:()=>se,createHmacDrbg:()=>Mo,ensureBytes:()=>ot,equalBytes:()=>zl,hexToBytes:()=>Re,hexToNumber:()=>Uo,inRange:()=>xr,isBytes:()=>pe,memoized:()=>Ce,notImplemented:()=>Wl,numberToBytesBE:()=>ye,numberToBytesLE:()=>Be,numberToHexUnpadded:()=>Le,numberToVarBytesBE:()=>Fl,utf8ToBytes:()=>Vl,validateObject:()=>Xt});var Qr=BigInt(0),jr=BigInt(1),Kl=BigInt(2);function pe(r){return r instanceof Uint8Array||ArrayBuffer.isView(r)&&r.constructor.name==="Uint8Array"}function Qe(r){if(!pe(r))throw new Error("Uint8Array expected")}function Vt(r,t){if(typeof t!="boolean")throw new Error(r+" boolean expected, got "+t)}var ql=Array.from({length:256},(r,t)=>t.toString(16).padStart(2,"0"));function oe(r){Qe(r);let t="";for(let e=0;e<r.length;e++)t+=ql[r[e]];return t}function Le(r){let t=r.toString(16);return t.length&1?"0"+t:t}function Uo(r){if(typeof r!="string")throw new Error("hex string expected, got "+typeof r);return r===""?Qr:BigInt("0x"+r)}var ne={_0:48,_9:57,A:65,F:70,a:97,f:102};function ua(r){if(r>=ne._0&&r<=ne._9)return r-ne._0;if(r>=ne.A&&r<=ne.F)return r-(ne.A-10);if(r>=ne.a&&r<=ne.f)return r-(ne.a-10)}function Re(r){if(typeof r!="string")throw new Error("hex string expected, got "+typeof r);let t=r.length,e=t/2;if(t%2)throw new Error("hex string expected, got unpadded hex of length "+t);let n=new Uint8Array(e);for(let o=0,i=0;o<e;o++,i+=2){let s=ua(r.charCodeAt(i)),a=ua(r.charCodeAt(i+1));if(s===void 0||a===void 0){let c=r[i]+r[i+1];throw new Error('hex string expected, got non-hex character "'+c+'" at index '+i)}n[o]=s*16+a}return n}function ie(r){return Uo(oe(r))}function me(r){return Qe(r),Uo(oe(Uint8Array.from(r).reverse()))}function ye(r,t){return Re(r.toString(16).padStart(t*2,"0"))}function Be(r,t){return ye(r,t).reverse()}function Fl(r){return Re(Le(r))}function ot(r,t,e){let n;if(typeof t=="string")try{n=Re(t)}catch(i){throw new Error(r+" must be hex string or Uint8Array, cause: "+i)}else if(pe(t))n=Uint8Array.from(t);else throw new Error(r+" must be hex string or Uint8Array");let o=n.length;if(typeof e=="number"&&o!==e)throw new Error(r+" of length "+e+" expected, got "+o);return n}function se(...r){let t=0;for(let n=0;n<r.length;n++){let o=r[n];Qe(o),t+=o.length}let e=new Uint8Array(t);for(let n=0,o=0;n<r.length;n++){let i=r[n];e.set(i,o),o+=i.length}return e}function zl(r,t){if(r.length!==t.length)return!1;let e=0;for(let n=0;n<r.length;n++)e|=r[n]^t[n];return e===0}function Vl(r){if(typeof r!="string")throw new Error("string expected");return new Uint8Array(new TextEncoder().encode(r))}var Po=r=>typeof r=="bigint"&&Qr<=r;function xr(r,t,e){return Po(r)&&Po(t)&&Po(e)&&t<=r&&r<e}function Tt(r,t,e,n){if(!xr(t,e,n))throw new Error("expected valid "+r+": "+e+" <= n < "+n+", got "+t)}function Oo(r){let t;for(t=0;r>Qr;r>>=jr,t+=1);return t}function Hl(r,t){return r>>BigInt(t)&jr}function Gl(r,t,e){return r|(e?jr:Qr)<<BigInt(t)}var wr=r=>(Kl<<BigInt(r-1))-jr,No=r=>new Uint8Array(r),la=r=>Uint8Array.from(r);function Mo(r,t,e){if(typeof r!="number"||r<2)throw new Error("hashLen must be a number");if(typeof t!="number"||t<2)throw new Error("qByteLen must be a number");if(typeof e!="function")throw new Error("hmacFn must be a function");let n=No(r),o=No(r),i=0,s=()=>{n.fill(1),o.fill(0),i=0},a=(...f)=>e(o,n,...f),c=(f=No())=>{o=a(la([0]),f),n=a(),f.length!==0&&(o=a(la([1]),f),n=a())},l=()=>{if(i++>=1e3)throw new Error("drbg: tried 1000 values");let f=0,d=[];for(;f<t;){n=a();let g=n.slice();d.push(g),f+=n.length}return se(...d)};return(f,d)=>{s(),c(f);let g;for(;!(g=d(l()));)c();return s(),g}}var Zl={bigint:r=>typeof r=="bigint",function:r=>typeof r=="function",boolean:r=>typeof r=="boolean",string:r=>typeof r=="string",stringOrUint8Array:r=>typeof r=="string"||pe(r),isSafeInteger:r=>Number.isSafeInteger(r),array:r=>Array.isArray(r),field:(r,t)=>t.Fp.isValid(r),hash:r=>typeof r=="function"&&Number.isSafeInteger(r.outputLen)};function Xt(r,t,e={}){let n=(o,i,s)=>{let a=Zl[i];if(typeof a!="function")throw new Error("invalid validator function");let c=r[o];if(!(s&&c===void 0)&&!a(c,r))throw new Error("param "+String(o)+" is invalid. Expected "+i+", got "+c)};for(let[o,i]of Object.entries(t))n(o,i,!1);for(let[o,i]of Object.entries(e))n(o,i,!0);return r}var Wl=()=>{throw new Error("not implemented")};function Ce(r){let t=new WeakMap;return(e,...n)=>{let o=t.get(e);if(o!==void 0)return o;let i=r(e,...n);return t.set(e,i),i}}var ut=BigInt(0),rt=BigInt(1),De=BigInt(2),$l=BigInt(3),ko=BigInt(4),fa=BigInt(5),ha=BigInt(8),Yl=BigInt(9),Xl=BigInt(16);function Y(r,t){let e=r%t;return e>=ut?e:t+e}function Ql(r,t,e){if(t<ut)throw new Error("invalid exponent, negatives unsupported");if(e<=ut)throw new Error("invalid modulus");if(e===rt)return ut;let n=rt;for(;t>ut;)t&rt&&(n=n*r%e),r=r*r%e,t>>=rt;return n}function nt(r,t,e){let n=r;for(;t-- >ut;)n*=n,n%=e;return n}function tn(r,t){if(r===ut)throw new Error("invert: expected non-zero number");if(t<=ut)throw new Error("invert: expected positive modulus, got "+t);let e=Y(r,t),n=t,o=ut,i=rt,s=rt,a=ut;for(;e!==ut;){let l=n/e,u=n%e,f=o-s*l,d=i-a*l;n=e,e=u,o=s,i=a,s=f,a=d}if(n!==rt)throw new Error("invert: does not exist");return Y(o,t)}function jl(r){let t=(r-rt)/De,e,n,o;for(e=r-rt,n=0;e%De===ut;e/=De,n++);for(o=De;o<r&&Ql(o,t,r)!==r-rt;o++)if(o>1e3)throw new Error("Cannot find square root: likely non-prime P");if(n===1){let s=(r+rt)/ko;return function(c,l){let u=c.pow(l,s);if(!c.eql(c.sqr(u),l))throw new Error("Cannot find square root");return u}}let i=(e+rt)/De;return function(a,c){if(a.pow(c,t)===a.neg(a.ONE))throw new Error("Cannot find square root");let l=n,u=a.pow(a.mul(a.ONE,o),e),f=a.pow(c,i),d=a.pow(c,e);for(;!a.eql(d,a.ONE);){if(a.eql(d,a.ZERO))return a.ZERO;let g=1;for(let b=a.sqr(d);g<l&&!a.eql(b,a.ONE);g++)b=a.sqr(b);let y=a.pow(u,rt<<BigInt(l-g-1));u=a.sqr(y),f=a.mul(f,y),d=a.mul(d,u),l=g}return f}}function Jl(r){if(r%ko===$l){let t=(r+rt)/ko;return function(n,o){let i=n.pow(o,t);if(!n.eql(n.sqr(i),o))throw new Error("Cannot find square root");return i}}if(r%ha===fa){let t=(r-fa)/ha;return function(n,o){let i=n.mul(o,De),s=n.pow(i,t),a=n.mul(o,s),c=n.mul(n.mul(a,De),s),l=n.mul(a,n.sub(c,n.ONE));if(!n.eql(n.sqr(l),o))throw new Error("Cannot find square root");return l}}return r%Xl,jl(r)}var da=(r,t)=>(Y(r,t)&rt)===rt,tf=["create","isValid","is0","neg","inv","sqrt","sqr","eql","add","sub","mul","pow","div","addN","subN","mulN","sqrN"];function Ko(r){let t={ORDER:"bigint",MASK:"bigint",BYTES:"isSafeInteger",BITS:"isSafeInteger"},e=tf.reduce((n,o)=>(n[o]="function",n),t);return Xt(r,e)}function ef(r,t,e){if(e<ut)throw new Error("invalid exponent, negatives unsupported");if(e===ut)return r.ONE;if(e===rt)return t;let n=r.ONE,o=t;for(;e>ut;)e&rt&&(n=r.mul(n,o)),o=r.sqr(o),e>>=rt;return n}function rf(r,t){let e=new Array(t.length),n=t.reduce((i,s,a)=>r.is0(s)?i:(e[a]=i,r.mul(i,s)),r.ONE),o=r.inv(n);return t.reduceRight((i,s,a)=>r.is0(s)?i:(e[a]=r.mul(i,e[a]),r.mul(i,s)),o),e}function qo(r,t){let e=t!==void 0?t:r.toString(2).length,n=Math.ceil(e/8);return{nBitLength:e,nByteLength:n}}function ge(r,t,e=!1,n={}){if(r<=ut)throw new Error("invalid field: expected ORDER > 0, got "+r);let{nBitLength:o,nByteLength:i}=qo(r,t);if(i>2048)throw new Error("invalid field: expected ORDER of <= 2048 bytes");let s,a=Object.freeze({ORDER:r,isLE:e,BITS:o,BYTES:i,MASK:wr(o),ZERO:ut,ONE:rt,create:c=>Y(c,r),isValid:c=>{if(typeof c!="bigint")throw new Error("invalid field element: expected bigint, got "+typeof c);return ut<=c&&c<r},is0:c=>c===ut,isOdd:c=>(c&rt)===rt,neg:c=>Y(-c,r),eql:(c,l)=>c===l,sqr:c=>Y(c*c,r),add:(c,l)=>Y(c+l,r),sub:(c,l)=>Y(c-l,r),mul:(c,l)=>Y(c*l,r),pow:(c,l)=>ef(a,c,l),div:(c,l)=>Y(c*tn(l,r),r),sqrN:c=>c*c,addN:(c,l)=>c+l,subN:(c,l)=>c-l,mulN:(c,l)=>c*l,inv:c=>tn(c,r),sqrt:n.sqrt||(c=>(s||(s=Jl(r)),s(a,c))),invertBatch:c=>rf(a,c),cmov:(c,l,u)=>u?l:c,toBytes:c=>e?Be(c,i):ye(c,i),fromBytes:c=>{if(c.length!==i)throw new Error("Field.fromBytes: expected "+i+" bytes, got "+c.length);return e?me(c):ie(c)}});return Object.freeze(a)}function pa(r){if(typeof r!="bigint")throw new Error("field order must be bigint");let t=r.toString(2).length;return Math.ceil(t/8)}function Fo(r){let t=pa(r);return t+Math.ceil(t/2)}function ma(r,t,e=!1){let n=r.length,o=pa(t),i=Fo(t);if(n<16||n<i||n>1024)throw new Error("expected "+i+"-1024 bytes of input, got "+n);let s=e?me(r):ie(r),a=Y(s,t-rt)+rt;return e?Be(a,o):ye(a,o)}var ya=BigInt(0),en=BigInt(1);function zo(r,t){let e=t.negate();return r?e:t}function ga(r,t){if(!Number.isSafeInteger(r)||r<=0||r>t)throw new Error("invalid window size, expected [1.."+t+"], got W="+r)}function Vo(r,t){ga(r,t);let e=Math.ceil(t/r)+1,n=2**(r-1);return{windows:e,windowSize:n}}function nf(r,t){if(!Array.isArray(r))throw new Error("array expected");r.forEach((e,n)=>{if(!(e instanceof t))throw new Error("invalid point at index "+n)})}function of(r,t){if(!Array.isArray(r))throw new Error("array of scalars expected");r.forEach((e,n)=>{if(!t.isValid(e))throw new Error("invalid scalar at index "+n)})}var Ho=new WeakMap,ba=new WeakMap;function Go(r){return ba.get(r)||1}function rn(r,t){return{constTimeNegate:zo,hasPrecomputes(e){return Go(e)!==1},unsafeLadder(e,n,o=r.ZERO){let i=e;for(;n>ya;)n&en&&(o=o.add(i)),i=i.double(),n>>=en;return o},precomputeWindow(e,n){let{windows:o,windowSize:i}=Vo(n,t),s=[],a=e,c=a;for(let l=0;l<o;l++){c=a,s.push(c);for(let u=1;u<i;u++)c=c.add(a),s.push(c);a=c.double()}return s},wNAF(e,n,o){let{windows:i,windowSize:s}=Vo(e,t),a=r.ZERO,c=r.BASE,l=BigInt(2**e-1),u=2**e,f=BigInt(e);for(let d=0;d<i;d++){let g=d*s,y=Number(o&l);o>>=f,y>s&&(y-=u,o+=en);let b=g,h=g+Math.abs(y)-1,w=d%2!==0,v=y<0;y===0?c=c.add(zo(w,n[b])):a=a.add(zo(v,n[h]))}return{p:a,f:c}},wNAFUnsafe(e,n,o,i=r.ZERO){let{windows:s,windowSize:a}=Vo(e,t),c=BigInt(2**e-1),l=2**e,u=BigInt(e);for(let f=0;f<s;f++){let d=f*a;if(o===ya)break;let g=Number(o&c);if(o>>=u,g>a&&(g-=l,o+=en),g===0)continue;let y=n[d+Math.abs(g)-1];g<0&&(y=y.negate()),i=i.add(y)}return i},getPrecomputes(e,n,o){let i=Ho.get(n);return i||(i=this.precomputeWindow(n,e),e!==1&&Ho.set(n,o(i))),i},wNAFCached(e,n,o){let i=Go(e);return this.wNAF(i,this.getPrecomputes(i,e,o),n)},wNAFCachedUnsafe(e,n,o,i){let s=Go(e);return s===1?this.unsafeLadder(e,n,i):this.wNAFUnsafe(s,this.getPrecomputes(s,e,o),n,i)},setWindowSize(e,n){ga(n,t),ba.set(e,n),Ho.delete(e)}}}function nn(r,t,e,n){if(nf(e,r),of(n,t),e.length!==n.length)throw new Error("arrays of points and scalars must have equal length");let o=r.ZERO,i=Oo(BigInt(e.length)),s=i>12?i-3:i>4?i-2:i?2:1,a=(1<<s)-1,c=new Array(a+1).fill(o),l=Math.floor((t.BITS-1)/s)*s,u=o;for(let f=l;f>=0;f-=s){c.fill(o);for(let g=0;g<n.length;g++){let y=n[g],b=Number(y>>BigInt(f)&BigInt(a));c[b]=c[b].add(e[g])}let d=o;for(let g=c.length-1,y=o;g>0;g--)y=y.add(c[g]),d=d.add(y);if(u=u.add(d),f!==0)for(let g=0;g<s;g++)u=u.double()}return u}function Er(r){return Ko(r.Fp),Xt(r,{n:"bigint",h:"bigint",Gx:"field",Gy:"field"},{nBitLength:"isSafeInteger",nByteLength:"isSafeInteger"}),Object.freeze({...qo(r.n,r.nBitLength),...r,p:r.Fp.ORDER})}var Ht=BigInt(0),Lt=BigInt(1),on=BigInt(2),sf=BigInt(8),af={zip215:!0};function cf(r){let t=Er(r);return Xt(r,{hash:"function",a:"bigint",d:"bigint",randomBytes:"function"},{adjustScalarBytes:"function",domain:"function",uvRatio:"function",mapToCurve:"function"}),Object.freeze({...t})}function xa(r){let t=cf(r),{Fp:e,n,prehash:o,hash:i,randomBytes:s,nByteLength:a,h:c}=t,l=on<<BigInt(a*8)-Lt,u=e.create,f=ge(t.n,t.nBitLength),d=t.uvRatio||((x,p)=>{try{return{isValid:!0,value:e.sqrt(x*e.inv(p))}}catch{return{isValid:!1,value:Ht}}}),g=t.adjustScalarBytes||(x=>x),y=t.domain||((x,p,E)=>{if(Vt("phflag",E),p.length||E)throw new Error("Contexts/pre-hash are not supported");return x});function b(x,p){Tt("coordinate "+x,p,Ht,l)}function h(x){if(!(x instanceof m))throw new Error("ExtendedPoint expected")}let w=Ce((x,p)=>{let{ex:E,ey:A,ez:D}=x,P=x.is0();p==null&&(p=P?sf:e.inv(D));let O=u(E*p),F=u(A*p),N=u(D*p);if(P)return{x:Ht,y:Lt};if(N!==Lt)throw new Error("invZ was invalid");return{x:O,y:F}}),v=Ce(x=>{let{a:p,d:E}=t;if(x.is0())throw new Error("bad point: ZERO");let{ex:A,ey:D,ez:P,et:O}=x,F=u(A*A),N=u(D*D),W=u(P*P),J=u(W*W),ft=u(F*p),ht=u(W*u(ft+N)),yt=u(J+u(E*u(F*N)));if(ht!==yt)throw new Error("bad point: equation left != right (1)");let gt=u(A*D),It=u(P*O);if(gt!==It)throw new Error("bad point: equation left != right (2)");return!0});class m{constructor(p,E,A,D){this.ex=p,this.ey=E,this.ez=A,this.et=D,b("x",p),b("y",E),b("z",A),b("t",D),Object.freeze(this)}get x(){return this.toAffine().x}get y(){return this.toAffine().y}static fromAffine(p){if(p instanceof m)throw new Error("extended point not allowed");let{x:E,y:A}=p||{};return b("x",E),b("y",A),new m(E,A,Lt,u(E*A))}static normalizeZ(p){let E=e.invertBatch(p.map(A=>A.ez));return p.map((A,D)=>A.toAffine(E[D])).map(m.fromAffine)}static msm(p,E){return nn(m,f,p,E)}_setWindowSize(p){C.setWindowSize(this,p)}assertValidity(){v(this)}equals(p){h(p);let{ex:E,ey:A,ez:D}=this,{ex:P,ey:O,ez:F}=p,N=u(E*F),W=u(P*D),J=u(A*F),ft=u(O*D);return N===W&&J===ft}is0(){return this.equals(m.ZERO)}negate(){return new m(u(-this.ex),this.ey,this.ez,u(-this.et))}double(){let{a:p}=t,{ex:E,ey:A,ez:D}=this,P=u(E*E),O=u(A*A),F=u(on*u(D*D)),N=u(p*P),W=E+A,J=u(u(W*W)-P-O),ft=N+O,ht=ft-F,yt=N-O,gt=u(J*ht),It=u(ft*yt),At=u(J*yt),$t=u(ht*ft);return new m(gt,It,$t,At)}add(p){h(p);let{a:E,d:A}=t,{ex:D,ey:P,ez:O,et:F}=this,{ex:N,ey:W,ez:J,et:ft}=p;if(E===BigInt(-1)){let Is=u((P-D)*(W+N)),Ts=u((P+D)*(W-N)),yo=u(Ts-Is);if(yo===Ht)return this.double();let Ls=u(O*on*ft),Rs=u(F*on*J),Bs=Rs+Ls,Cs=Ts+Is,Ds=Rs-Ls,bu=u(Bs*yo),xu=u(Cs*Ds),wu=u(Bs*Ds),Eu=u(yo*Cs);return new m(bu,xu,Eu,wu)}let ht=u(D*N),yt=u(P*W),gt=u(F*A*ft),It=u(O*J),At=u((D+P)*(N+W)-ht-yt),$t=It-gt,jt=It+gt,hr=u(yt-E*ht),pu=u(At*$t),mu=u(jt*hr),yu=u(At*hr),gu=u($t*jt);return new m(pu,mu,gu,yu)}subtract(p){return this.add(p.negate())}wNAF(p){return C.wNAFCached(this,p,m.normalizeZ)}multiply(p){let E=p;Tt("scalar",E,Lt,n);let{p:A,f:D}=this.wNAF(E);return m.normalizeZ([A,D])[0]}multiplyUnsafe(p,E=m.ZERO){let A=p;return Tt("scalar",A,Ht,n),A===Ht?B:this.is0()||A===Lt?this:C.wNAFCachedUnsafe(this,A,m.normalizeZ,E)}isSmallOrder(){return this.multiplyUnsafe(c).is0()}isTorsionFree(){return C.unsafeLadder(this,n).is0()}toAffine(p){return w(this,p)}clearCofactor(){let{h:p}=t;return p===Lt?this:this.multiplyUnsafe(p)}static fromHex(p,E=!1){let{d:A,a:D}=t,P=e.BYTES;p=ot("pointHex",p,P),Vt("zip215",E);let O=p.slice(),F=p[P-1];O[P-1]=F&-129;let N=me(O),W=E?l:e.ORDER;Tt("pointHex.y",N,Ht,W);let J=u(N*N),ft=u(J-Lt),ht=u(A*J-D),{isValid:yt,value:gt}=d(ft,ht);if(!yt)throw new Error("Point.fromHex: invalid y coordinate");let It=(gt&Lt)===Lt,At=(F&128)!==0;if(!E&>===Ht&&At)throw new Error("Point.fromHex: x=0 and x_0=1");return At!==It&&(gt=u(-gt)),m.fromAffine({x:gt,y:N})}static fromPrivateKey(p){return T(p).point}toRawBytes(){let{x:p,y:E}=this.toAffine(),A=Be(E,e.BYTES);return A[A.length-1]|=p&Lt?128:0,A}toHex(){return oe(this.toRawBytes())}}m.BASE=new m(t.Gx,t.Gy,Lt,u(t.Gx*t.Gy)),m.ZERO=new m(Ht,Lt,Lt,Ht);let{BASE:_,ZERO:B}=m,C=rn(m,a*8);function I(x){return Y(x,n)}function R(x){return I(me(x))}function T(x){let p=e.BYTES;x=ot("private key",x,p);let E=ot("hashed private key",i(x),2*p),A=g(E.slice(0,p)),D=E.slice(p,2*p),P=R(A),O=_.multiply(P),F=O.toRawBytes();return{head:A,prefix:D,scalar:P,point:O,pointBytes:F}}function et(x){return T(x).pointBytes}function V(x=new Uint8Array,...p){let E=se(...p);return R(i(y(E,ot("context",x),!!o)))}function q(x,p,E={}){x=ot("message",x),o&&(x=o(x));let{prefix:A,scalar:D,pointBytes:P}=T(p),O=V(E.context,A,x),F=_.multiply(O).toRawBytes(),N=V(E.context,F,P,x),W=I(O+N*D);Tt("signature.s",W,Ht,n);let J=se(F,Be(W,e.BYTES));return ot("result",J,e.BYTES*2)}let ct=af;function S(x,p,E,A=ct){let{context:D,zip215:P}=A,O=e.BYTES;x=ot("signature",x,2*O),p=ot("message",p),E=ot("publicKey",E,O),P!==void 0&&Vt("zip215",P),o&&(p=o(p));let F=me(x.slice(O,2*O)),N,W,J;try{N=m.fromHex(E,P),W=m.fromHex(x.slice(0,O),P),J=_.multiplyUnsafe(F)}catch{return!1}if(!P&&N.isSmallOrder())return!1;let ft=V(D,W.toRawBytes(),N.toRawBytes(),p);return W.add(N.multiplyUnsafe(ft)).subtract(J).clearCofactor().equals(m.ZERO)}return _._setWindowSize(8),{CURVE:t,getPublicKey:et,sign:q,verify:S,ExtendedPoint:m,utils:{getExtendedPublicKey:T,randomPrivateKey:()=>s(e.BYTES),precompute(x=8,p=m.BASE){return p._setWindowSize(x),p.multiply(BigInt(3)),p}}}}var Zo=BigInt("57896044618658097711785492504343953926634992332820282019728792003956564819949"),wa=BigInt("19681161376707505956807079304988542015446066515923890162744021073123829784752"),Np=BigInt(0),uf=BigInt(1),Ea=BigInt(2),Up=BigInt(3),lf=BigInt(5),ff=BigInt(8);function hf(r){let t=BigInt(10),e=BigInt(20),n=BigInt(40),o=BigInt(80),i=Zo,a=r*r%i*r%i,c=nt(a,Ea,i)*a%i,l=nt(c,uf,i)*r%i,u=nt(l,lf,i)*l%i,f=nt(u,t,i)*u%i,d=nt(f,e,i)*f%i,g=nt(d,n,i)*d%i,y=nt(g,o,i)*g%i,b=nt(y,o,i)*g%i,h=nt(b,t,i)*u%i;return{pow_p_5_8:nt(h,Ea,i)*r%i,b2:a}}function df(r){return r[0]&=248,r[31]&=127,r[31]|=64,r}function pf(r,t){let e=Zo,n=Y(t*t*t,e),o=Y(n*n*t,e),i=hf(r*o).pow_p_5_8,s=Y(r*n*i,e),a=Y(t*s*s,e),c=s,l=Y(s*wa,e),u=a===r,f=a===Y(-r,e),d=a===Y(-r*wa,e);return u&&(s=c),(f||d)&&(s=l),da(s,e)&&(s=Y(-s,e)),{isValid:u||f,value:s}}var mf=ge(Zo,void 0,!0),yf={a:BigInt(-1),d:BigInt("37095705934669439343138083508754565189542113879843219016388785533085940283555"),Fp:mf,n:BigInt("7237005577332262213973186563042994240857116359379907606001950938285454250989"),h:ff,Gx:BigInt("15112221349535400772501151409588531511454012693041857206046113283949847762202"),Gy:BigInt("46316835694926478169428394003475163141307993866256225615783033603165251855960"),hash:ca,randomBytes:Yr,adjustScalarBytes:df,uvRatio:pf},va=xa(yf);var sn=32;function Sa(r,t,e){return va.verify(t,e instanceof Uint8Array?e:e.subarray(),r)}var an=class{type="Ed25519";raw;constructor(t){this.raw=Wo(t,sn)}toMultihash(){return re.digest(be(this))}toCID(){return dt.createV1(114,this.toMultihash())}toString(){return Q.encode(this.toMultihash().bytes).substring(1)}equals(t){return t==null||!(t.raw instanceof Uint8Array)?!1:pt(this.raw,t.raw)}verify(t,e){return Sa(this.raw,e,t)}};function $o(r){return r=Wo(r,sn),new an(r)}function Wo(r,t){if(r=Uint8Array.from(r??[]),r.length!==t)throw new bt(`Key must be a Uint8Array of length ${t}, got ${r.length}`);return r}function it(r=0){return new Uint8Array(r)}function Rt(r=0){return new Uint8Array(r)}var bf=Math.pow(2,7),xf=Math.pow(2,14),wf=Math.pow(2,21),Yo=Math.pow(2,28),Xo=Math.pow(2,35),Qo=Math.pow(2,42),jo=Math.pow(2,49),Z=128,xt=127;function wt(r){if(r<bf)return 1;if(r<xf)return 2;if(r<wf)return 3;if(r<Yo)return 4;if(r<Xo)return 5;if(r<Qo)return 6;if(r<jo)return 7;if(Number.MAX_SAFE_INTEGER!=null&&r>Number.MAX_SAFE_INTEGER)throw new RangeError("Could not encode varint");return 8}function Jo(r,t,e=0){switch(wt(r)){case 8:t[e++]=r&255|Z,r/=128;case 7:t[e++]=r&255|Z,r/=128;case 6:t[e++]=r&255|Z,r/=128;case 5:t[e++]=r&255|Z,r/=128;case 4:t[e++]=r&255|Z,r>>>=7;case 3:t[e++]=r&255|Z,r>>>=7;case 2:t[e++]=r&255|Z,r>>>=7;case 1:{t[e++]=r&255,r>>>=7;break}default:throw new Error("unreachable")}return t}function Ef(r,t,e=0){switch(wt(r)){case 8:t.set(e++,r&255|Z),r/=128;case 7:t.set(e++,r&255|Z),r/=128;case 6:t.set(e++,r&255|Z),r/=128;case 5:t.set(e++,r&255|Z),r/=128;case 4:t.set(e++,r&255|Z),r>>>=7;case 3:t.set(e++,r&255|Z),r>>>=7;case 2:t.set(e++,r&255|Z),r>>>=7;case 1:{t.set(e++,r&255),r>>>=7;break}default:throw new Error("unreachable")}return t}function ti(r,t){let e=r[t],n=0;if(n+=e&xt,e<Z||(e=r[t+1],n+=(e&xt)<<7,e<Z)||(e=r[t+2],n+=(e&xt)<<14,e<Z)||(e=r[t+3],n+=(e&xt)<<21,e<Z)||(e=r[t+4],n+=(e&xt)*Yo,e<Z)||(e=r[t+5],n+=(e&xt)*Xo,e<Z)||(e=r[t+6],n+=(e&xt)*Qo,e<Z)||(e=r[t+7],n+=(e&xt)*jo,e<Z))return n;throw new RangeError("Could not decode varint")}function vf(r,t){let e=r.get(t),n=0;if(n+=e&xt,e<Z||(e=r.get(t+1),n+=(e&xt)<<7,e<Z)||(e=r.get(t+2),n+=(e&xt)<<14,e<Z)||(e=r.get(t+3),n+=(e&xt)<<21,e<Z)||(e=r.get(t+4),n+=(e&xt)*Yo,e<Z)||(e=r.get(t+5),n+=(e&xt)*Xo,e<Z)||(e=r.get(t+6),n+=(e&xt)*Qo,e<Z)||(e=r.get(t+7),n+=(e&xt)*jo,e<Z))return n;throw new RangeError("Could not decode varint")}function kt(r,t,e=0){return t==null&&(t=Rt(wt(r))),t instanceof Uint8Array?Jo(r,t,e):Ef(r,t,e)}function ae(r,t=0){return r instanceof Uint8Array?ti(r,t):vf(r,t)}var ei=new Float32Array([-0]),xe=new Uint8Array(ei.buffer);function _a(r,t,e){ei[0]=r,t[e]=xe[0],t[e+1]=xe[1],t[e+2]=xe[2],t[e+3]=xe[3]}function Ia(r,t){return xe[0]=r[t],xe[1]=r[t+1],xe[2]=r[t+2],xe[3]=r[t+3],ei[0]}var ri=new Float64Array([-0]),Et=new Uint8Array(ri.buffer);function Ta(r,t,e){ri[0]=r,t[e]=Et[0],t[e+1]=Et[1],t[e+2]=Et[2],t[e+3]=Et[3],t[e+4]=Et[4],t[e+5]=Et[5],t[e+6]=Et[6],t[e+7]=Et[7]}function La(r,t){return Et[0]=r[t],Et[1]=r[t+1],Et[2]=r[t+2],Et[3]=r[t+3],Et[4]=r[t+4],Et[5]=r[t+5],Et[6]=r[t+6],Et[7]=r[t+7],ri[0]}var Sf=BigInt(Number.MAX_SAFE_INTEGER),Af=BigInt(Number.MIN_SAFE_INTEGER),Pt=class r{lo;hi;constructor(t,e){this.lo=t|0,this.hi=e|0}toNumber(t=!1){if(!t&&this.hi>>>31>0){let e=~this.lo+1>>>0,n=~this.hi>>>0;return e===0&&(n=n+1>>>0),-(e+n*4294967296)}return this.lo+this.hi*4294967296}toBigInt(t=!1){if(t)return BigInt(this.lo>>>0)+(BigInt(this.hi>>>0)<<32n);if(this.hi>>>31){let e=~this.lo+1>>>0,n=~this.hi>>>0;return e===0&&(n=n+1>>>0),-(BigInt(e)+(BigInt(n)<<32n))}return BigInt(this.lo>>>0)+(BigInt(this.hi>>>0)<<32n)}toString(t=!1){return this.toBigInt(t).toString()}zzEncode(){let t=this.hi>>31;return this.hi=((this.hi<<1|this.lo>>>31)^t)>>>0,this.lo=(this.lo<<1^t)>>>0,this}zzDecode(){let t=-(this.lo&1);return this.lo=((this.lo>>>1|this.hi<<31)^t)>>>0,this.hi=(this.hi>>>1^t)>>>0,this}length(){let t=this.lo,e=(this.lo>>>28|this.hi<<4)>>>0,n=this.hi>>>24;return n===0?e===0?t<16384?t<128?1:2:t<2097152?3:4:e<16384?e<128?5:6:e<2097152?7:8:n<128?9:10}static fromBigInt(t){if(t===0n)return Pe;if(t<Sf&&t>Af)return this.fromNumber(Number(t));let e=t<0n;e&&(t=-t);let n=t>>32n,o=t-(n<<32n);return e&&(n=~n|0n,o=~o|0n,++o>Ra&&(o=0n,++n>Ra&&(n=0n))),new r(Number(o),Number(n))}static fromNumber(t){if(t===0)return Pe;let e=t<0;e&&(t=-t);let n=t>>>0,o=(t-n)/4294967296>>>0;return e&&(o=~o>>>0,n=~n>>>0,++n>4294967295&&(n=0,++o>4294967295&&(o=0))),new r(n,o)}static from(t){return typeof t=="number"?r.fromNumber(t):typeof t=="bigint"?r.fromBigInt(t):typeof t=="string"?r.fromBigInt(BigInt(t)):t.low!=null||t.high!=null?new r(t.low>>>0,t.high>>>0):Pe}},Pe=new Pt(0,0);Pe.toBigInt=function(){return 0n};Pe.zzEncode=Pe.zzDecode=function(){return this};Pe.length=function(){return 1};var Ra=4294967296n;function Ba(r){let t=0,e=0;for(let n=0;n<r.length;++n)e=r.charCodeAt(n),e<128?t+=1:e<2048?t+=2:(e&64512)===55296&&(r.charCodeAt(n+1)&64512)===56320?(++n,t+=4):t+=3;return t}function Ca(r,t,e){if(e-t<1)return"";let o,i=[],s=0,a;for(;t<e;)a=r[t++],a<128?i[s++]=a:a>191&&a<224?i[s++]=(a&31)<<6|r[t++]&63:a>239&&a<365?(a=((a&7)<<18|(r[t++]&63)<<12|(r[t++]&63)<<6|r[t++]&63)-65536,i[s++]=55296+(a>>10),i[s++]=56320+(a&1023)):i[s++]=(a&15)<<12|(r[t++]&63)<<6|r[t++]&63,s>8191&&((o??(o=[])).push(String.fromCharCode.apply(String,i)),s=0);return o!=null?(s>0&&o.push(String.fromCharCode.apply(String,i.slice(0,s))),o.join("")):String.fromCharCode.apply(String,i.slice(0,s))}function ni(r,t,e){let n=e,o,i;for(let s=0;s<r.length;++s)o=r.charCodeAt(s),o<128?t[e++]=o:o<2048?(t[e++]=o>>6|192,t[e++]=o&63|128):(o&64512)===55296&&((i=r.charCodeAt(s+1))&64512)===56320?(o=65536+((o&1023)<<10)+(i&1023),++s,t[e++]=o>>18|240,t[e++]=o>>12&63|128,t[e++]=o>>6&63|128,t[e++]=o&63|128):(t[e++]=o>>12|224,t[e++]=o>>6&63|128,t[e++]=o&63|128);return e-n}function Gt(r,t){return RangeError(`index out of range: ${r.pos} + ${t??1} > ${r.len}`)}function un(r,t){return(r[t-4]|r[t-3]<<8|r[t-2]<<16|r[t-1]<<24)>>>0}var oi=class{buf;pos;len;_slice=Uint8Array.prototype.subarray;constructor(t){this.buf=t,this.pos=0,this.len=t.length}uint32(){let t=4294967295;if(t=(this.buf[this.pos]&127)>>>0,this.buf[this.pos++]<128||(t=(t|(this.buf[this.pos]&127)<<7)>>>0,this.buf[this.pos++]<128)||(t=(t|(this.buf[this.pos]&127)<<14)>>>0,this.buf[this.pos++]<128)||(t=(t|(this.buf[this.pos]&127)<<21)>>>0,this.buf[this.pos++]<128)||(t=(t|(this.buf[this.pos]&15)<<28)>>>0,this.buf[this.pos++]<128))return t;if((this.pos+=5)>this.len)throw this.pos=this.len,Gt(this,10);return t}int32(){return this.uint32()|0}sint32(){let t=this.uint32();return t>>>1^-(t&1)|0}bool(){return this.uint32()!==0}fixed32(){if(this.pos+4>this.len)throw Gt(this,4);return un(this.buf,this.pos+=4)}sfixed32(){if(this.pos+4>this.len)throw Gt(this,4);return un(this.buf,this.pos+=4)|0}float(){if(this.pos+4>this.len)throw Gt(this,4);let t=Ia(this.buf,this.pos);return this.pos+=4,t}double(){if(this.pos+8>this.len)throw Gt(this,4);let t=La(this.buf,this.pos);return this.pos+=8,t}bytes(){let t=this.uint32(),e=this.pos,n=this.pos+t;if(n>this.len)throw Gt(this,t);return this.pos+=t,e===n?new Uint8Array(0):this.buf.subarray(e,n)}string(){let t=this.bytes();return Ca(t,0,t.length)}skip(t){if(typeof t=="number"){if(this.pos+t>this.len)throw Gt(this,t);this.pos+=t}else do if(this.pos>=this.len)throw Gt(this);while((this.buf[this.pos++]&128)!==0);return this}skipType(t){switch(t){case 0:this.skip();break;case 1:this.skip(8);break;case 2:this.skip(this.uint32());break;case 3:for(;(t=this.uint32()&7)!==4;)this.skipType(t);break;case 5:this.skip(4);break;default:throw Error(`invalid wire type ${t} at offset ${this.pos}`)}return this}readLongVarint(){let t=new Pt(0,0),e=0;if(this.len-this.pos>4){for(;e<4;++e)if(t.lo=(t.lo|(this.buf[this.pos]&127)<<e*7)>>>0,this.buf[this.pos++]<128)return t;if(t.lo=(t.lo|(this.buf[this.pos]&127)<<28)>>>0,t.hi=(t.hi|(this.buf[this.pos]&127)>>4)>>>0,this.buf[this.pos++]<128)return t;e=0}else{for(;e<3;++e){if(this.pos>=this.len)throw Gt(this);if(t.lo=(t.lo|(this.buf[this.pos]&127)<<e*7)>>>0,this.buf[this.pos++]<128)return t}return t.lo=(t.lo|(this.buf[this.pos++]&127)<<e*7)>>>0,t}if(this.len-this.pos>4){for(;e<5;++e)if(t.hi=(t.hi|(this.buf[this.pos]&127)<<e*7+3)>>>0,this.buf[this.pos++]<128)return t}else for(;e<5;++e){if(this.pos>=this.len)throw Gt(this);if(t.hi=(t.hi|(this.buf[this.pos]&127)<<e*7+3)>>>0,this.buf[this.pos++]<128)return t}throw Error("invalid varint encoding")}readFixed64(){if(this.pos+8>this.len)throw Gt(this,8);let t=un(this.buf,this.pos+=4),e=un(this.buf,this.pos+=4);return new Pt(t,e)}int64(){return this.readLongVarint().toBigInt()}int64Number(){return this.readLongVarint().toNumber()}int64String(){return this.readLongVarint().toString()}uint64(){return this.readLongVarint().toBigInt(!0)}uint64Number(){let t=ti(this.buf,this.pos);return this.pos+=wt(t),t}uint64String(){return this.readLongVarint().toString(!0)}sint64(){return this.readLongVarint().zzDecode().toBigInt()}sint64Number(){return this.readLongVarint().zzDecode().toNumber()}sint64String(){return this.readLongVarint().zzDecode().toString()}fixed64(){return this.readFixed64().toBigInt()}fixed64Number(){return this.readFixed64().toNumber()}fixed64String(){return this.readFixed64().toString()}sfixed64(){return this.readFixed64().toBigInt()}sfixed64Number(){return this.readFixed64().toNumber()}sfixed64String(){return this.readFixed64().toString()}};function ii(r){return new oi(r instanceof Uint8Array?r:r.subarray())}function Bt(r,t,e){let n=ii(r);return t.decode(n,void 0,e)}var si={};_t(si,{base10:()=>_f});var _f=fe({prefix:"9",name:"base10",alphabet:"0123456789"});var ai={};_t(ai,{base16:()=>If,base16upper:()=>Tf});var If=st({prefix:"f",name:"base16",alphabet:"0123456789abcdef",bitsPerChar:4}),Tf=st({prefix:"F",name:"base16upper",alphabet:"0123456789ABCDEF",bitsPerChar:4});var ci={};_t(ci,{base2:()=>Lf});var Lf=st({prefix:"0",name:"base2",alphabet:"01",bitsPerChar:1});var ui={};_t(ui,{base256emoji:()=>Pf});var Pa=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}"),Rf=Pa.reduce((r,t,e)=>(r[e]=t,r),[]),Bf=Pa.reduce((r,t,e)=>{let n=t.codePointAt(0);if(n==null)throw new Error(`Invalid character: ${t}`);return r[n]=e,r},[]);function Cf(r){return r.reduce((t,e)=>(t+=Rf[e],t),"")}function Df(r){let t=[];for(let e of r){let n=e.codePointAt(0);if(n==null)throw new Error(`Invalid character: ${e}`);let o=Bf[n];if(o==null)throw new Error(`Non-base256emoji character: ${e}`);t.push(o)}return new Uint8Array(t)}var Pf=Ve({prefix:"\u{1F680}",name:"base256emoji",encode:Cf,decode:Df});var fi={};_t(fi,{base64:()=>Nf,base64pad:()=>Uf,base64url:()=>li,base64urlpad:()=>Of});var Nf=st({prefix:"m",name:"base64",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/",bitsPerChar:6}),Uf=st({prefix:"M",name:"base64pad",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/=",bitsPerChar:6}),li=st({prefix:"u",name:"base64url",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789-_",bitsPerChar:6}),Of=st({prefix:"U",name:"base64urlpad",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789-_=",bitsPerChar:6});var hi={};_t(hi,{base8:()=>Mf});var Mf=st({prefix:"7",name:"base8",alphabet:"01234567",bitsPerChar:3});var di={};_t(di,{identity:()=>kf});var kf=Ve({prefix:"\0",name:"identity",encode:r=>zs(r),decode:r=>Fs(r)});var gm=new TextEncoder,bm=new TextDecoder;var yi={};_t(yi,{sha256:()=>je,sha512:()=>Ff});function mi({name:r,code:t,encode:e}){return new pi(r,t,e)}var pi=class{name;code;encode;constructor(t,e,n){this.name=t,this.code=e,this.encode=n}digest(t){if(t instanceof Uint8Array){let e=this.encode(t);return e instanceof Uint8Array?Ft(this.code,e):e.then(n=>Ft(this.code,n))}else throw Error("Unknown type, must be binary type")}};function Ua(r){return async t=>new Uint8Array(await crypto.subtle.digest(r,t))}var je=mi({name:"sha2-256",code:18,encode:Ua("SHA-256")}),Ff=mi({name:"sha2-512",code:19,encode:Ua("SHA-512")});var vr={...di,...ci,...hi,...si,...ai,..._o,...Io,...Ao,...fi,...ui},Bm={...yi,...Ro};function Ma(r,t,e,n){return{name:r,prefix:t,encoder:{name:r,prefix:t,encode:e},decoder:{decode:n}}}var Oa=Ma("utf8","u",r=>"u"+new TextDecoder("utf8").decode(r),r=>new TextEncoder().encode(r.substring(1))),gi=Ma("ascii","a",r=>{let t="a";for(let e=0;e<r.length;e++)t+=String.fromCharCode(r[e]);return t},r=>{r=r.substring(1);let t=Rt(r.length);for(let e=0;e<r.length;e++)t[e]=r.charCodeAt(e);return t}),zf={utf8:Oa,"utf-8":Oa,hex:vr.base16,latin1:gi,ascii:gi,binary:gi,...vr},ln=zf;function z(r,t="utf8"){let e=ln[t];if(e==null)throw new Error(`Unsupported encoding "${t}"`);return e.decoder.decode(`${e.prefix}${r}`)}function bi(r){let t=r??8192,e=t>>>1,n,o=t;return function(s){if(s<1||s>e)return Rt(s);o+s>t&&(n=Rt(t),o=0);let a=n.subarray(o,o+=s);return(o&7)!==0&&(o=(o|7)+1),a}}var Ne=class{fn;len;next;val;constructor(t,e,n){this.fn=t,this.len=e,this.next=void 0,this.val=n}};function xi(){}var Ei=class{head;tail;len;next;constructor(t){this.head=t.head,this.tail=t.tail,this.len=t.len,this.next=t.states}},Vf=bi();function Hf(r){return globalThis.Buffer!=null?Rt(r):Vf(r)}var Ar=class{len;head;tail;states;constructor(){this.len=0,this.head=new Ne(xi,0,0),this.tail=this.head,this.states=null}_push(t,e,n){return this.tail=this.tail.next=new Ne(t,e,n),this.len+=e,this}uint32(t){return this.len+=(this.tail=this.tail.next=new vi((t=t>>>0)<128?1:t<16384?2:t<2097152?3:t<268435456?4:5,t)).len,this}int32(t){return t<0?this._push(fn,10,Pt.fromNumber(t)):this.uint32(t)}sint32(t){return this.uint32((t<<1^t>>31)>>>0)}uint64(t){let e=Pt.fromBigInt(t);return this._push(fn,e.length(),e)}uint64Number(t){return this._push(Jo,wt(t),t)}uint64String(t){return this.uint64(BigInt(t))}int64(t){return this.uint64(t)}int64Number(t){return this.uint64Number(t)}int64String(t){return this.uint64String(t)}sint64(t){let e=Pt.fromBigInt(t).zzEncode();return this._push(fn,e.length(),e)}sint64Number(t){let e=Pt.fromNumber(t).zzEncode();return this._push(fn,e.length(),e)}sint64String(t){return this.sint64(BigInt(t))}bool(t){return this._push(wi,1,t?1:0)}fixed32(t){return this._push(Sr,4,t>>>0)}sfixed32(t){return this.fixed32(t)}fixed64(t){let e=Pt.fromBigInt(t);return this._push(Sr,4,e.lo)._push(Sr,4,e.hi)}fixed64Number(t){let e=Pt.fromNumber(t);return this._push(Sr,4,e.lo)._push(Sr,4,e.hi)}fixed64String(t){return this.fixed64(BigInt(t))}sfixed64(t){return this.fixed64(t)}sfixed64Number(t){return this.fixed64Number(t)}sfixed64String(t){return this.fixed64String(t)}float(t){return this._push(_a,4,t)}double(t){return this._push(Ta,8,t)}bytes(t){let e=t.length>>>0;return e===0?this._push(wi,1,0):this.uint32(e)._push(Zf,e,t)}string(t){let e=Ba(t);return e!==0?this.uint32(e)._push(ni,e,t):this._push(wi,1,0)}fork(){return this.states=new Ei(this),this.head=this.tail=new Ne(xi,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 Ne(xi,0,0),this.len=0),this}ldelim(){let t=this.head,e=this.tail,n=this.len;return this.reset().uint32(n),n!==0&&(this.tail.next=t.next,this.tail=e,this.len+=n),this}finish(){let t=this.head.next,e=Hf(this.len),n=0;for(;t!=null;)t.fn(t.val,e,n),n+=t.len,t=t.next;return e}};function wi(r,t,e){t[e]=r&255}function Gf(r,t,e){for(;r>127;)t[e++]=r&127|128,r>>>=7;t[e]=r}var vi=class extends Ne{next;constructor(t,e){super(Gf,t,e),this.next=void 0}};function fn(r,t,e){for(;r.hi!==0;)t[e++]=r.lo&127|128,r.lo=(r.lo>>>7|r.hi<<25)>>>0,r.hi>>>=7;for(;r.lo>127;)t[e++]=r.lo&127|128,r.lo=r.lo>>>7;t[e++]=r.lo}function Sr(r,t,e){t[e]=r&255,t[e+1]=r>>>8&255,t[e+2]=r>>>16&255,t[e+3]=r>>>24}function Zf(r,t,e){t.set(r,e)}globalThis.Buffer!=null&&(Ar.prototype.bytes=function(r){let t=r.length>>>0;return this.uint32(t),t>0&&this._push(Wf,t,r),this},Ar.prototype.string=function(r){let t=globalThis.Buffer.byteLength(r);return this.uint32(t),t>0&&this._push($f,t,r),this});function Wf(r,t,e){t.set(r,e)}function $f(r,t,e){r.length<40?ni(r,t,e):t.utf8Write!=null?t.utf8Write(r,e):t.set(z(r),e)}function Si(){return new Ar}function Ct(r,t){let e=Si();return t.encode(r,e,{lengthDelimited:!1}),e.finish()}var Je;(function(r){r[r.VARINT=0]="VARINT",r[r.BIT64=1]="BIT64",r[r.LENGTH_DELIMITED=2]="LENGTH_DELIMITED",r[r.START_GROUP=3]="START_GROUP",r[r.END_GROUP=4]="END_GROUP",r[r.BIT32=5]="BIT32"})(Je||(Je={}));function hn(r,t,e,n){return{name:r,type:t,encode:e,decode:n}}function Ue(r){function t(o){if(r[o.toString()]==null)throw new Error("Invalid enum value");return r[o]}let e=function(i,s){let a=t(i);s.int32(a)},n=function(i){let s=i.int32();return t(s)};return hn("enum",Je.VARINT,e,n)}function Dt(r,t){return hn("message",Je.LENGTH_DELIMITED,r,t)}var _r=class extends Error{code="ERR_MAX_LENGTH";name="MaxLengthError"};var lt;(function(r){r.RSA="RSA",r.Ed25519="Ed25519",r.secp256k1="secp256k1"})(lt||(lt={}));var Ai;(function(r){r[r.RSA=0]="RSA",r[r.Ed25519=1]="Ed25519",r[r.secp256k1=2]="secp256k1"})(Ai||(Ai={}));(function(r){r.codec=()=>Ue(Ai)})(lt||(lt={}));var Qt;(function(r){let t;r.codec=()=>(t==null&&(t=Dt((e,n,o={})=>{o.lengthDelimited!==!1&&n.fork(),e.Type!=null&&(n.uint32(8),lt.codec().encode(e.Type,n)),e.Data!=null&&(n.uint32(18),n.bytes(e.Data)),o.lengthDelimited!==!1&&n.ldelim()},(e,n,o={})=>{let i={},s=n==null?e.len:e.pos+n;for(;e.pos<s;){let a=e.uint32();switch(a>>>3){case 1:{i.Type=lt.codec().decode(e);break}case 2:{i.Data=e.bytes();break}default:{e.skipType(a&7);break}}}return i})),t),r.encode=e=>Ct(e,r.codec()),r.decode=(e,n)=>Bt(e,r.codec(),n)})(Qt||(Qt={}));var _i;(function(r){let t;r.codec=()=>(t==null&&(t=Dt((e,n,o={})=>{o.lengthDelimited!==!1&&n.fork(),e.Type!=null&&(n.uint32(8),lt.codec().encode(e.Type,n)),e.Data!=null&&(n.uint32(18),n.bytes(e.Data)),o.lengthDelimited!==!1&&n.ldelim()},(e,n,o={})=>{let i={},s=n==null?e.len:e.pos+n;for(;e.pos<s;){let a=e.uint32();switch(a>>>3){case 1:{i.Type=lt.codec().decode(e);break}case 2:{i.Data=e.bytes();break}default:{e.skipType(a&7);break}}}return i})),t),r.encode=e=>Ct(e,r.codec()),r.decode=(e,n)=>Bt(e,r.codec(),n)})(_i||(_i={}));var Lr={};_t(Lr,{MAX_RSA_KEY_SIZE:()=>Bi,generateRSAKeyPair:()=>ja,jwkToJWKKeyPair:()=>Ja,jwkToPkcs1:()=>sh,jwkToPkix:()=>Di,jwkToRSAPrivateKey:()=>Qa,pkcs1ToJwk:()=>$a,pkcs1ToRSAPrivateKey:()=>Xa,pkixToJwk:()=>Ya,pkixToRSAPublicKey:()=>Pi});var Yf=new Uint32Array([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]),we=new Uint32Array([1779033703,3144134277,1013904242,2773480762,1359893119,2600822924,528734635,1541459225]),Ee=new Uint32Array(64),Ii=class extends Xe{constructor(){super(64,32,8,!1),this.A=we[0]|0,this.B=we[1]|0,this.C=we[2]|0,this.D=we[3]|0,this.E=we[4]|0,this.F=we[5]|0,this.G=we[6]|0,this.H=we[7]|0}get(){let{A:t,B:e,C:n,D:o,E:i,F:s,G:a,H:c}=this;return[t,e,n,o,i,s,a,c]}set(t,e,n,o,i,s,a,c){this.A=t|0,this.B=e|0,this.C=n|0,this.D=o|0,this.E=i|0,this.F=s|0,this.G=a|0,this.H=c|0}process(t,e){for(let f=0;f<16;f++,e+=4)Ee[f]=t.getUint32(e,!1);for(let f=16;f<64;f++){let d=Ee[f-15],g=Ee[f-2],y=zt(d,7)^zt(d,18)^d>>>3,b=zt(g,17)^zt(g,19)^g>>>10;Ee[f]=b+Ee[f-7]+y+Ee[f-16]|0}let{A:n,B:o,C:i,D:s,E:a,F:c,G:l,H:u}=this;for(let f=0;f<64;f++){let d=zt(a,6)^zt(a,11)^zt(a,25),g=u+d+ia(a,c,l)+Yf[f]+Ee[f]|0,b=(zt(n,2)^zt(n,13)^zt(n,22))+sa(n,o,i)|0;u=l,l=c,c=a,a=s+g|0,s=i,i=o,o=n,n=g+b|0}n=n+this.A|0,o=o+this.B|0,i=i+this.C|0,s=s+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,o,i,s,a,c,l,u)}roundClean(){Ee.fill(0)}destroy(){this.set(0,0,0,0,0,0,0,0),this.buffer.fill(0)}};var tr=$r(()=>new Ii);function H(r,t="utf8"){let e=ln[t];if(e==null)throw new Error(`Unsupported encoding "${t}"`);return e.encoder.encode(r).substring(1)}function Nt(r,t){t==null&&(t=r.reduce((o,i)=>o+i.length,0));let e=Rt(t),n=0;for(let o of r)e.set(o,n),n+=o.length;return e}var qa=Symbol.for("@achingbrain/uint8arraylist");function Ka(r,t){if(t==null||t<0)throw new RangeError("index is out of bounds");let e=0;for(let n of r){let o=e+n.byteLength;if(t<o)return{buf:n,index:t-e};e=o}throw new RangeError("index is out of bounds")}function dn(r){return!!r?.[qa]}var at=class r{bufs;length;[qa]=!0;constructor(...t){this.bufs=[],this.length=0,t.length>0&&this.appendAll(t)}*[Symbol.iterator](){yield*this.bufs}get byteLength(){return this.length}append(...t){this.appendAll(t)}appendAll(t){let e=0;for(let n of t)if(n instanceof Uint8Array)e+=n.byteLength,this.bufs.push(n);else if(dn(n))e+=n.byteLength,this.bufs.push(...n.bufs);else throw new Error("Could not append value, must be an Uint8Array or a Uint8ArrayList");this.length+=e}prepend(...t){this.prependAll(t)}prependAll(t){let e=0;for(let n of t.reverse())if(n instanceof Uint8Array)e+=n.byteLength,this.bufs.unshift(n);else if(dn(n))e+=n.byteLength,this.bufs.unshift(...n.bufs);else throw new Error("Could not prepend value, must be an Uint8Array or a Uint8ArrayList");this.length+=e}get(t){let e=Ka(this.bufs,t);return e.buf[e.index]}set(t,e){let n=Ka(this.bufs,t);n.buf[n.index]=e}write(t,e=0){if(t instanceof Uint8Array)for(let n=0;n<t.length;n++)this.set(e+n,t[n]);else if(dn(t))for(let n=0;n<t.length;n++)this.set(e+n,t.get(n));else throw new Error("Could not write value, must be an Uint8Array or a Uint8ArrayList")}consume(t){if(t=Math.trunc(t),!(Number.isNaN(t)||t<=0)){if(t===this.byteLength){this.bufs=[],this.length=0;return}for(;this.bufs.length>0;)if(t>=this.bufs[0].byteLength)t-=this.bufs[0].byteLength,this.length-=this.bufs[0].byteLength,this.bufs.shift();else{this.bufs[0]=this.bufs[0].subarray(t),this.length-=t;break}}}slice(t,e){let{bufs:n,length:o}=this._subList(t,e);return Nt(n,o)}subarray(t,e){let{bufs:n,length:o}=this._subList(t,e);return n.length===1?n[0]:Nt(n,o)}sublist(t,e){let{bufs:n,length:o}=this._subList(t,e),i=new r;return i.length=o,i.bufs=[...n],i}_subList(t,e){if(t=t??0,e=e??this.length,t<0&&(t=this.length+t),e<0&&(e=this.length+e),t<0||e>this.length)throw new RangeError("index is out of bounds");if(t===e)return{bufs:[],length:0};if(t===0&&e===this.length)return{bufs:this.bufs,length:this.length};let n=[],o=0;for(let i=0;i<this.bufs.length;i++){let s=this.bufs[i],a=o,c=a+s.byteLength;if(o=c,t>=c)continue;let l=t>=a&&t<c,u=e>a&&e<=c;if(l&&u){if(t===a&&e===c){n.push(s);break}let f=t-a;n.push(s.subarray(f,f+(e-t)));break}if(l){if(t===0){n.push(s);continue}n.push(s.subarray(t-a));continue}if(u){if(e===c){n.push(s);break}n.push(s.subarray(0,e-a));break}n.push(s)}return{bufs:n,length:e-t}}indexOf(t,e=0){if(!dn(t)&&!(t instanceof Uint8Array))throw new TypeError('The "value" argument must be a Uint8ArrayList or Uint8Array');let n=t instanceof Uint8Array?t:t.subarray();if(e=Number(e??0),isNaN(e)&&(e=0),e<0&&(e=this.length+e),e<0&&(e=0),t.length===0)return e>this.length?this.length:e;let o=n.byteLength;if(o===0)throw new TypeError("search must be at least 1 byte long");let i=256,s=new Int32Array(i);for(let f=0;f<i;f++)s[f]=-1;for(let f=0;f<o;f++)s[n[f]]=f;let a=s,c=this.byteLength-n.byteLength,l=n.byteLength-1,u;for(let f=e;f<=c;f+=u){u=0;for(let d=l;d>=0;d--){let g=this.get(f+d);if(n[d]!==g){u=Math.max(1,d-a[g]);break}}if(u===0)return f}return-1}getInt8(t){let e=this.subarray(t,t+1);return new DataView(e.buffer,e.byteOffset,e.byteLength).getInt8(0)}setInt8(t,e){let n=Rt(1);new DataView(n.buffer,n.byteOffset,n.byteLength).setInt8(0,e),this.write(n,t)}getInt16(t,e){let n=this.subarray(t,t+2);return new DataView(n.buffer,n.byteOffset,n.byteLength).getInt16(0,e)}setInt16(t,e,n){let o=it(2);new DataView(o.buffer,o.byteOffset,o.byteLength).setInt16(0,e,n),this.write(o,t)}getInt32(t,e){let n=this.subarray(t,t+4);return new DataView(n.buffer,n.byteOffset,n.byteLength).getInt32(0,e)}setInt32(t,e,n){let o=it(4);new DataView(o.buffer,o.byteOffset,o.byteLength).setInt32(0,e,n),this.write(o,t)}getBigInt64(t,e){let n=this.subarray(t,t+8);return new DataView(n.buffer,n.byteOffset,n.byteLength).getBigInt64(0,e)}setBigInt64(t,e,n){let o=it(8);new DataView(o.buffer,o.byteOffset,o.byteLength).setBigInt64(0,e,n),this.write(o,t)}getUint8(t){let e=this.subarray(t,t+1);return new DataView(e.buffer,e.byteOffset,e.byteLength).getUint8(0)}setUint8(t,e){let n=Rt(1);new DataView(n.buffer,n.byteOffset,n.byteLength).setUint8(0,e),this.write(n,t)}getUint16(t,e){let n=this.subarray(t,t+2);return new DataView(n.buffer,n.byteOffset,n.byteLength).getUint16(0,e)}setUint16(t,e,n){let o=it(2);new DataView(o.buffer,o.byteOffset,o.byteLength).setUint16(0,e,n),this.write(o,t)}getUint32(t,e){let n=this.subarray(t,t+4);return new DataView(n.buffer,n.byteOffset,n.byteLength).getUint32(0,e)}setUint32(t,e,n){let o=it(4);new DataView(o.buffer,o.byteOffset,o.byteLength).setUint32(0,e,n),this.write(o,t)}getBigUint64(t,e){let n=this.subarray(t,t+8);return new DataView(n.buffer,n.byteOffset,n.byteLength).getBigUint64(0,e)}setBigUint64(t,e,n){let o=it(8);new DataView(o.buffer,o.byteOffset,o.byteLength).setBigUint64(0,e,n),this.write(o,t)}getFloat32(t,e){let n=this.subarray(t,t+4);return new DataView(n.buffer,n.byteOffset,n.byteLength).getFloat32(0,e)}setFloat32(t,e,n){let o=it(4);new DataView(o.buffer,o.byteOffset,o.byteLength).setFloat32(0,e,n),this.write(o,t)}getFloat64(t,e){let n=this.subarray(t,t+8);return new DataView(n.buffer,n.byteOffset,n.byteLength).getFloat64(0,e)}setFloat64(t,e,n){let o=it(8);new DataView(o.buffer,o.byteOffset,o.byteLength).setFloat64(0,e,n),this.write(o,t)}equals(t){if(t==null||!(t instanceof r)||t.bufs.length!==this.bufs.length)return!1;for(let e=0;e<this.bufs.length;e++)if(!pt(this.bufs[e],t.bufs[e]))return!1;return!0}static fromUint8Arrays(t,e){let n=new r;return n.bufs=t,e==null&&(e=t.reduce((o,i)=>o+i.byteLength,0)),n.length=e,n}};var Xf=parseInt("11111",2),Li=parseInt("10000000",2),Qf=parseInt("01111111",2),Fa={2:jf,3:eh,5:th,6:Jf,16:Ti,22:Ti,48:Ti};function Ir(r,t={offset:0}){let e=r[t.offset]&Xf;if(t.offset++,Fa[e]!=null)return Fa[e](r,t);throw new Error("No decoder for tag "+e)}function pn(r,t){let e=0;if((r[t.offset]&Li)===Li){let n=r[t.offset]&Qf,o="0x";t.offset++;for(let i=0;i<n;i++,t.offset++)o+=r[t.offset].toString(16).padStart(2,"0");e=parseInt(o,16)}else e=r[t.offset],t.offset++;return e}function Ti(r,t){pn(r,t);let e=[];for(;!(t.offset>=r.byteLength);){let n=Ir(r,t);if(n===null)break;e.push(n)}return e}function jf(r,t){let e=pn(r,t),n=t.offset,o=t.offset+e,i=[];for(let s=n;s<o;s++)s===n&&r[s]===0||i.push(r[s]);return t.offset+=e,Uint8Array.from(i)}function Jf(r,t){let e=pn(r,t);return t.offset+=e,["oid-unimplemented"]}function th(r,t){return t.offset++,null}function eh(r,t){let e=pn(r,t),n=r[t.offset];t.offset++;let o=r.subarray(t.offset,t.offset+e);if(t.offset+=e,n!==0)throw new Error("Unused bits in bit string is unimplemented");return Ir(o,{offset:0})}function rh(r){let t=r.toString(16);t.length%2===1&&(t="0"+t);let e=new at;for(let n=0;n<t.length;n+=2)e.append(Uint8Array.from([parseInt(`${t[n]}${t[n+1]}`,16)]));return e}function Ri(r){if(r.byteLength<128)return Uint8Array.from([r.byteLength]);let t=rh(r.byteLength);return new at(Uint8Array.from([t.byteLength|Li]),t)}function Kt(r){let t=new at,e=parseInt("10000000",2);return(r.subarray()[0]&e)===e&&t.append(Uint8Array.from([0])),t.append(r),new at(Uint8Array.from([2]),Ri(t),t)}function za(r){let t=Uint8Array.from([0]),e=new at(t,r);return new at(Uint8Array.from([3]),Ri(e),e)}function mn(r){let t=new at;for(let e of r)t.append(e);return new at(Uint8Array.from([48]),Ri(t),t)}var Tr=class extends Error{constructor(t="An error occurred while verifying a message"){super(t),this.name="VerificationError"}},yn=class extends Error{constructor(t="Missing Web Crypto API"){super(t),this.name="WebCryptoMissingError"}};var Va={get(r=globalThis){let t=r.crypto;if(t?.subtle==null)throw new yn("Missing Web Crypto API. The most likely cause of this error is that this page is being accessed from an insecure context (i.e. not HTTPS). For more information and possible resolutions see https://github.com/libp2p/js-libp2p/blob/main/packages/crypto/README.md#web-crypto-api");return t}};var ve=Va;async function Ha(r){let t=await ve.get().subtle.generateKey({name:"RSASSA-PKCS1-v1_5",modulusLength:r,publicExponent:new Uint8Array([1,0,1]),hash:{name:"SHA-256"}},!0,["sign","verify"]),e=await nh(t);return{privateKey:e[0],publicKey:e[1]}}async function Ga(r,t){let e=await ve.get().subtle.importKey("jwk",r,{name:"RSASSA-PKCS1-v1_5",hash:{name:"SHA-256"}},!1,["sign"]),n=await ve.get().subtle.sign({name:"RSASSA-PKCS1-v1_5"},e,t instanceof Uint8Array?t:t.subarray());return new Uint8Array(n,0,n.byteLength)}async function Za(r,t,e){let n=await ve.get().subtle.importKey("jwk",r,{name:"RSASSA-PKCS1-v1_5",hash:{name:"SHA-256"}},!1,["verify"]);return ve.get().subtle.verify({name:"RSASSA-PKCS1-v1_5"},n,t,e instanceof Uint8Array?e:e.subarray())}async function nh(r){if(r.privateKey==null||r.publicKey==null)throw new bt("Private and public key are required");return Promise.all([ve.get().subtle.exportKey("jwk",r.privateKey),ve.get().subtle.exportKey("jwk",r.publicKey)])}function Wa(r){if(r.kty!=="RSA")throw new bt("invalid key type");if(r.n==null)throw new bt("invalid key modulus");return z(r.n,"base64url").length*8}var er=class{type="RSA";_key;_raw;_multihash;constructor(t,e){this._key=t,this._multihash=e}get raw(){return this._raw==null&&(this._raw=Lr.jwkToPkix(this._key)),this._raw}toMultihash(){return this._multihash}toCID(){return dt.createV1(114,this._multihash)}toString(){return Q.encode(this.toMultihash().bytes).substring(1)}equals(t){return t==null||!(t.raw instanceof Uint8Array)?!1:pt(this.raw,t.raw)}verify(t,e){return Za(this._key,e,t)}},Rr=class{type="RSA";_key;_raw;publicKey;constructor(t,e){this._key=t,this.publicKey=e}get raw(){return this._raw==null&&(this._raw=Lr.jwkToPkcs1(this._key)),this._raw}equals(t){return t==null||!(t.raw instanceof Uint8Array)?!1:pt(this.raw,t.raw)}sign(t){return Ga(this._key,t)}};var Bi=8192,Ci=18,oh=1062,ih=Uint8Array.from([48,13,6,9,42,134,72,134,247,13,1,1,1,5,0]);function $a(r){let t=Ir(r);return{n:H(t[1],"base64url"),e:H(t[2],"base64url"),d:H(t[3],"base64url"),p:H(t[4],"base64url"),q:H(t[5],"base64url"),dp:H(t[6],"base64url"),dq:H(t[7],"base64url"),qi:H(t[8],"base64url"),kty:"RSA"}}function sh(r){if(r.n==null||r.e==null||r.d==null||r.p==null||r.q==null||r.dp==null||r.dq==null||r.qi==null)throw new bt("JWK was missing components");return mn([Kt(Uint8Array.from([0])),Kt(z(r.n,"base64url")),Kt(z(r.e,"base64url")),Kt(z(r.d,"base64url")),Kt(z(r.p,"base64url")),Kt(z(r.q,"base64url")),Kt(z(r.dp,"base64url")),Kt(z(r.dq,"base64url")),Kt(z(r.qi,"base64url"))]).subarray()}function Ya(r){let t=Ir(r,{offset:0});return{kty:"RSA",n:H(t[1][0],"base64url"),e:H(t[1][1],"base64url")}}function Di(r){if(r.n==null||r.e==null)throw new bt("JWK was missing components");return mn([ih,za(mn([Kt(z(r.n,"base64url")),Kt(z(r.e,"base64url"))]))]).subarray()}function Xa(r){let t=$a(r);return Qa(t)}function Pi(r,t){if(r.byteLength>=oh)throw new Fe("Key size is too large");let e=Ya(r);if(t==null){let n=tr(Qt.encode({Type:lt.RSA,Data:r}));t=Ft(Ci,n)}return new er(e,t)}function Qa(r){if(Wa(r)>Bi)throw new bt("Key size is too large");let t=Ja(r),e=tr(Qt.encode({Type:lt.RSA,Data:Di(t.publicKey)})),n=Ft(Ci,e);return new Rr(t.privateKey,new er(t.publicKey,n))}async function ja(r){if(r>Bi)throw new bt("Key size is too large");let t=await Ha(r),e=tr(Qt.encode({Type:lt.RSA,Data:Di(t.publicKey)})),n=Ft(Ci,e);return new Rr(t.privateKey,new er(t.publicKey,n))}function Ja(r){if(r==null)throw new bt("Missing key parameter");return{privateKey:r,publicKey:{kty:r.kty,n:r.n,e:r.e}}}var gn=class extends Ye{constructor(t,e){super(),this.finished=!1,this.destroyed=!1,ra(t);let n=br(e);if(this.iHash=t.create(),typeof this.iHash.update!="function")throw new Error("Expected instance of class which extends utils.Hash");this.blockLen=this.iHash.blockLen,this.outputLen=this.iHash.outputLen;let o=this.blockLen,i=new Uint8Array(o);i.set(n.length>o?t.create().update(n).digest():n);for(let s=0;s<i.length;s++)i[s]^=54;this.iHash.update(i),this.oHash=t.create();for(let s=0;s<i.length;s++)i[s]^=106;this.oHash.update(i),i.fill(0)}update(t){return $e(this),this.iHash.update(t),this}digestInto(t){$e(this),We(t,this.outputLen),this.finished=!0,this.iHash.digestInto(t),this.oHash.update(t),this.oHash.digestInto(t),this.destroy()}digest(){let t=new Uint8Array(this.oHash.outputLen);return this.digestInto(t),t}_cloneInto(t){t||(t=Object.create(Object.getPrototypeOf(this),{}));let{oHash:e,iHash:n,finished:o,destroyed:i,blockLen:s,outputLen:a}=this;return t=t,t.finished=o,t.destroyed=i,t.blockLen=s,t.outputLen=a,t.oHash=e._cloneInto(t.oHash),t.iHash=n._cloneInto(t.iHash),t}destroy(){this.destroyed=!0,this.oHash.destroy(),this.iHash.destroy()}},Ni=(r,t,e)=>new gn(r,t).update(e).digest();Ni.create=(r,t)=>new gn(r,t);function tc(r){r.lowS!==void 0&&Vt("lowS",r.lowS),r.prehash!==void 0&&Vt("prehash",r.prehash)}function ah(r){let t=Er(r);Xt(t,{a:"field",b:"field"},{allowedPrivateKeyLengths:"array",wrapPrivateKey:"boolean",isTorsionFree:"function",clearCofactor:"function",allowInfinityPoint:"boolean",fromBytes:"function",toBytes:"function"});let{endo:e,Fp:n,a:o}=t;if(e){if(!n.eql(o,n.ZERO))throw new Error("invalid endomorphism, can only be defined for Koblitz curves that have a=0");if(typeof e!="object"||typeof e.beta!="bigint"||typeof e.splitScalar!="function")throw new Error("invalid endomorphism, expected beta: bigint and splitScalar: function")}return Object.freeze({...t})}var{bytesToNumberBE:ch,hexToBytes:uh}=Jr,Ui=class extends Error{constructor(t=""){super(t)}},ce={Err:Ui,_tlv:{encode:(r,t)=>{let{Err:e}=ce;if(r<0||r>256)throw new e("tlv.encode: wrong tag");if(t.length&1)throw new e("tlv.encode: unpadded data");let n=t.length/2,o=Le(n);if(o.length/2&128)throw new e("tlv.encode: long form length too big");let i=n>127?Le(o.length/2|128):"";return Le(r)+i+o+t},decode(r,t){let{Err:e}=ce,n=0;if(r<0||r>256)throw new e("tlv.encode: wrong tag");if(t.length<2||t[n++]!==r)throw new e("tlv.decode: wrong tlv");let o=t[n++],i=!!(o&128),s=0;if(!i)s=o;else{let c=o&127;if(!c)throw new e("tlv.decode(long): indefinite length not supported");if(c>4)throw new e("tlv.decode(long): byte length is too big");let l=t.subarray(n,n+c);if(l.length!==c)throw new e("tlv.decode: length bytes not complete");if(l[0]===0)throw new e("tlv.decode(long): zero leftmost byte");for(let u of l)s=s<<8|u;if(n+=c,s<128)throw new e("tlv.decode(long): not minimal encoding")}let a=t.subarray(n,n+s);if(a.length!==s)throw new e("tlv.decode: wrong value length");return{v:a,l:t.subarray(n+s)}}},_int:{encode(r){let{Err:t}=ce;if(r<ue)throw new t("integer: negative integers are not allowed");let e=Le(r);if(Number.parseInt(e[0],16)&8&&(e="00"+e),e.length&1)throw new t("unexpected DER parsing assertion: unpadded hex");return e},decode(r){let{Err:t}=ce;if(r[0]&128)throw new t("invalid signature integer: negative");if(r[0]===0&&!(r[1]&128))throw new t("invalid signature integer: unnecessary leading zero");return ch(r)}},toSig(r){let{Err:t,_int:e,_tlv:n}=ce,o=typeof r=="string"?uh(r):r;Qe(o);let{v:i,l:s}=n.decode(48,o);if(s.length)throw new t("invalid signature: left bytes after parsing");let{v:a,l:c}=n.decode(2,i),{v:l,l:u}=n.decode(2,c);if(u.length)throw new t("invalid signature: left bytes after parsing");return{r:e.decode(a),s:e.decode(l)}},hexFromSig(r){let{_tlv:t,_int:e}=ce,n=t.encode(2,e.encode(r.r)),o=t.encode(2,e.encode(r.s)),i=n+o;return t.encode(48,i)}},ue=BigInt(0),mt=BigInt(1),j0=BigInt(2),ec=BigInt(3),J0=BigInt(4);function lh(r){let t=ah(r),{Fp:e}=t,n=ge(t.n,t.nBitLength),o=t.toBytes||((b,h,w)=>{let v=h.toAffine();return se(Uint8Array.from([4]),e.toBytes(v.x),e.toBytes(v.y))}),i=t.fromBytes||(b=>{let h=b.subarray(1),w=e.fromBytes(h.subarray(0,e.BYTES)),v=e.fromBytes(h.subarray(e.BYTES,2*e.BYTES));return{x:w,y:v}});function s(b){let{a:h,b:w}=t,v=e.sqr(b),m=e.mul(v,b);return e.add(e.add(m,e.mul(b,h)),w)}if(!e.eql(e.sqr(t.Gy),s(t.Gx)))throw new Error("bad generator point: equation left != right");function a(b){return xr(b,mt,t.n)}function c(b){let{allowedPrivateKeyLengths:h,nByteLength:w,wrapPrivateKey:v,n:m}=t;if(h&&typeof b!="bigint"){if(pe(b)&&(b=oe(b)),typeof b!="string"||!h.includes(b.length))throw new Error("invalid private key");b=b.padStart(w*2,"0")}let _;try{_=typeof b=="bigint"?b:ie(ot("private key",b,w))}catch{throw new Error("invalid private key, expected hex or "+w+" bytes, got "+typeof b)}return v&&(_=Y(_,m)),Tt("private key",_,mt,m),_}function l(b){if(!(b instanceof d))throw new Error("ProjectivePoint expected")}let u=Ce((b,h)=>{let{px:w,py:v,pz:m}=b;if(e.eql(m,e.ONE))return{x:w,y:v};let _=b.is0();h==null&&(h=_?e.ONE:e.inv(m));let B=e.mul(w,h),C=e.mul(v,h),I=e.mul(m,h);if(_)return{x:e.ZERO,y:e.ZERO};if(!e.eql(I,e.ONE))throw new Error("invZ was invalid");return{x:B,y:C}}),f=Ce(b=>{if(b.is0()){if(t.allowInfinityPoint&&!e.is0(b.py))return;throw new Error("bad point: ZERO")}let{x:h,y:w}=b.toAffine();if(!e.isValid(h)||!e.isValid(w))throw new Error("bad point: x or y not FE");let v=e.sqr(w),m=s(h);if(!e.eql(v,m))throw new Error("bad point: equation left != right");if(!b.isTorsionFree())throw new Error("bad point: not in prime-order subgroup");return!0});class d{constructor(h,w,v){if(this.px=h,this.py=w,this.pz=v,h==null||!e.isValid(h))throw new Error("x required");if(w==null||!e.isValid(w))throw new Error("y required");if(v==null||!e.isValid(v))throw new Error("z required");Object.freeze(this)}static fromAffine(h){let{x:w,y:v}=h||{};if(!h||!e.isValid(w)||!e.isValid(v))throw new Error("invalid affine point");if(h instanceof d)throw new Error("projective point not allowed");let m=_=>e.eql(_,e.ZERO);return m(w)&&m(v)?d.ZERO:new d(w,v,e.ONE)}get x(){return this.toAffine().x}get y(){return this.toAffine().y}static normalizeZ(h){let w=e.invertBatch(h.map(v=>v.pz));return h.map((v,m)=>v.toAffine(w[m])).map(d.fromAffine)}static fromHex(h){let w=d.fromAffine(i(ot("pointHex",h)));return w.assertValidity(),w}static fromPrivateKey(h){return d.BASE.multiply(c(h))}static msm(h,w){return nn(d,n,h,w)}_setWindowSize(h){y.setWindowSize(this,h)}assertValidity(){f(this)}hasEvenY(){let{y:h}=this.toAffine();if(e.isOdd)return!e.isOdd(h);throw new Error("Field doesn't support isOdd")}equals(h){l(h);let{px:w,py:v,pz:m}=this,{px:_,py:B,pz:C}=h,I=e.eql(e.mul(w,C),e.mul(_,m)),R=e.eql(e.mul(v,C),e.mul(B,m));return I&&R}negate(){return new d(this.px,e.neg(this.py),this.pz)}double(){let{a:h,b:w}=t,v=e.mul(w,ec),{px:m,py:_,pz:B}=this,C=e.ZERO,I=e.ZERO,R=e.ZERO,T=e.mul(m,m),et=e.mul(_,_),V=e.mul(B,B),q=e.mul(m,_);return q=e.add(q,q),R=e.mul(m,B),R=e.add(R,R),C=e.mul(h,R),I=e.mul(v,V),I=e.add(C,I),C=e.sub(et,I),I=e.add(et,I),I=e.mul(C,I),C=e.mul(q,C),R=e.mul(v,R),V=e.mul(h,V),q=e.sub(T,V),q=e.mul(h,q),q=e.add(q,R),R=e.add(T,T),T=e.add(R,T),T=e.add(T,V),T=e.mul(T,q),I=e.add(I,T),V=e.mul(_,B),V=e.add(V,V),T=e.mul(V,q),C=e.sub(C,T),R=e.mul(V,et),R=e.add(R,R),R=e.add(R,R),new d(C,I,R)}add(h){l(h);let{px:w,py:v,pz:m}=this,{px:_,py:B,pz:C}=h,I=e.ZERO,R=e.ZERO,T=e.ZERO,et=t.a,V=e.mul(t.b,ec),q=e.mul(w,_),ct=e.mul(v,B),S=e.mul(m,C),L=e.add(w,v),x=e.add(_,B);L=e.mul(L,x),x=e.add(q,ct),L=e.sub(L,x),x=e.add(w,m);let p=e.add(_,C);return x=e.mul(x,p),p=e.add(q,S),x=e.sub(x,p),p=e.add(v,m),I=e.add(B,C),p=e.mul(p,I),I=e.add(ct,S),p=e.sub(p,I),T=e.mul(et,x),I=e.mul(V,S),T=e.add(I,T),I=e.sub(ct,T),T=e.add(ct,T),R=e.mul(I,T),ct=e.add(q,q),ct=e.add(ct,q),S=e.mul(et,S),x=e.mul(V,x),ct=e.add(ct,S),S=e.sub(q,S),S=e.mul(et,S),x=e.add(x,S),q=e.mul(ct,x),R=e.add(R,q),q=e.mul(p,x),I=e.mul(L,I),I=e.sub(I,q),q=e.mul(L,ct),T=e.mul(p,T),T=e.add(T,q),new d(I,R,T)}subtract(h){return this.add(h.negate())}is0(){return this.equals(d.ZERO)}wNAF(h){return y.wNAFCached(this,h,d.normalizeZ)}multiplyUnsafe(h){let{endo:w,n:v}=t;Tt("scalar",h,ue,v);let m=d.ZERO;if(h===ue)return m;if(this.is0()||h===mt)return this;if(!w||y.hasPrecomputes(this))return y.wNAFCachedUnsafe(this,h,d.normalizeZ);let{k1neg:_,k1:B,k2neg:C,k2:I}=w.splitScalar(h),R=m,T=m,et=this;for(;B>ue||I>ue;)B&mt&&(R=R.add(et)),I&mt&&(T=T.add(et)),et=et.double(),B>>=mt,I>>=mt;return _&&(R=R.negate()),C&&(T=T.negate()),T=new d(e.mul(T.px,w.beta),T.py,T.pz),R.add(T)}multiply(h){let{endo:w,n:v}=t;Tt("scalar",h,mt,v);let m,_;if(w){let{k1neg:B,k1:C,k2neg:I,k2:R}=w.splitScalar(h),{p:T,f:et}=this.wNAF(C),{p:V,f:q}=this.wNAF(R);T=y.constTimeNegate(B,T),V=y.constTimeNegate(I,V),V=new d(e.mul(V.px,w.beta),V.py,V.pz),m=T.add(V),_=et.add(q)}else{let{p:B,f:C}=this.wNAF(h);m=B,_=C}return d.normalizeZ([m,_])[0]}multiplyAndAddUnsafe(h,w,v){let m=d.BASE,_=(C,I)=>I===ue||I===mt||!C.equals(m)?C.multiplyUnsafe(I):C.multiply(I),B=_(this,w).add(_(h,v));return B.is0()?void 0:B}toAffine(h){return u(this,h)}isTorsionFree(){let{h,isTorsionFree:w}=t;if(h===mt)return!0;if(w)return w(d,this);throw new Error("isTorsionFree() has not been declared for the elliptic curve")}clearCofactor(){let{h,clearCofactor:w}=t;return h===mt?this:w?w(d,this):this.multiplyUnsafe(t.h)}toRawBytes(h=!0){return Vt("isCompressed",h),this.assertValidity(),o(d,this,h)}toHex(h=!0){return Vt("isCompressed",h),oe(this.toRawBytes(h))}}d.BASE=new d(t.Gx,t.Gy,e.ONE),d.ZERO=new d(e.ZERO,e.ONE,e.ZERO);let g=t.nBitLength,y=rn(d,t.endo?Math.ceil(g/2):g);return{CURVE:t,ProjectivePoint:d,normPrivateKeyToScalar:c,weierstrassEquation:s,isWithinCurveOrder:a}}function fh(r){let t=Er(r);return Xt(t,{hash:"hash",hmac:"function",randomBytes:"function"},{bits2int:"function",bits2int_modN:"function",lowS:"boolean"}),Object.freeze({lowS:!0,...t})}function rc(r){let t=fh(r),{Fp:e,n}=t,o=e.BYTES+1,i=2*e.BYTES+1;function s(S){return Y(S,n)}function a(S){return tn(S,n)}let{ProjectivePoint:c,normPrivateKeyToScalar:l,weierstrassEquation:u,isWithinCurveOrder:f}=lh({...t,toBytes(S,L,x){let p=L.toAffine(),E=e.toBytes(p.x),A=se;return Vt("isCompressed",x),x?A(Uint8Array.from([L.hasEvenY()?2:3]),E):A(Uint8Array.from([4]),E,e.toBytes(p.y))},fromBytes(S){let L=S.length,x=S[0],p=S.subarray(1);if(L===o&&(x===2||x===3)){let E=ie(p);if(!xr(E,mt,e.ORDER))throw new Error("Point is not on curve");let A=u(E),D;try{D=e.sqrt(A)}catch(F){let N=F instanceof Error?": "+F.message:"";throw new Error("Point is not on curve"+N)}let P=(D&mt)===mt;return(x&1)===1!==P&&(D=e.neg(D)),{x:E,y:D}}else if(L===i&&x===4){let E=e.fromBytes(p.subarray(0,e.BYTES)),A=e.fromBytes(p.subarray(e.BYTES,2*e.BYTES));return{x:E,y:A}}else{let E=o,A=i;throw new Error("invalid Point, expected length of "+E+", or uncompressed "+A+", got "+L)}}}),d=S=>oe(ye(S,t.nByteLength));function g(S){let L=n>>mt;return S>L}function y(S){return g(S)?s(-S):S}let b=(S,L,x)=>ie(S.slice(L,x));class h{constructor(L,x,p){this.r=L,this.s=x,this.recovery=p,this.assertValidity()}static fromCompact(L){let x=t.nByteLength;return L=ot("compactSignature",L,x*2),new h(b(L,0,x),b(L,x,2*x))}static fromDER(L){let{r:x,s:p}=ce.toSig(ot("DER",L));return new h(x,p)}assertValidity(){Tt("r",this.r,mt,n),Tt("s",this.s,mt,n)}addRecoveryBit(L){return new h(this.r,this.s,L)}recoverPublicKey(L){let{r:x,s:p,recovery:E}=this,A=C(ot("msgHash",L));if(E==null||![0,1,2,3].includes(E))throw new Error("recovery id invalid");let D=E===2||E===3?x+t.n:x;if(D>=e.ORDER)throw new Error("recovery id 2 or 3 invalid");let P=(E&1)===0?"02":"03",O=c.fromHex(P+d(D)),F=a(D),N=s(-A*F),W=s(p*F),J=c.BASE.multiplyAndAddUnsafe(O,N,W);if(!J)throw new Error("point at infinify");return J.assertValidity(),J}hasHighS(){return g(this.s)}normalizeS(){return this.hasHighS()?new h(this.r,s(-this.s),this.recovery):this}toDERRawBytes(){return Re(this.toDERHex())}toDERHex(){return ce.hexFromSig({r:this.r,s:this.s})}toCompactRawBytes(){return Re(this.toCompactHex())}toCompactHex(){return d(this.r)+d(this.s)}}let w={isValidPrivateKey(S){try{return l(S),!0}catch{return!1}},normPrivateKeyToScalar:l,randomPrivateKey:()=>{let S=Fo(t.n);return ma(t.randomBytes(S),t.n)},precompute(S=8,L=c.BASE){return L._setWindowSize(S),L.multiply(BigInt(3)),L}};function v(S,L=!0){return c.fromPrivateKey(S).toRawBytes(L)}function m(S){let L=pe(S),x=typeof S=="string",p=(L||x)&&S.length;return L?p===o||p===i:x?p===2*o||p===2*i:S instanceof c}function _(S,L,x=!0){if(m(S))throw new Error("first arg must be private key");if(!m(L))throw new Error("second arg must be public key");return c.fromHex(L).multiply(l(S)).toRawBytes(x)}let B=t.bits2int||function(S){if(S.length>8192)throw new Error("input is too large");let L=ie(S),x=S.length*8-t.nBitLength;return x>0?L>>BigInt(x):L},C=t.bits2int_modN||function(S){return s(B(S))},I=wr(t.nBitLength);function R(S){return Tt("num < 2^"+t.nBitLength,S,ue,I),ye(S,t.nByteLength)}function T(S,L,x=et){if(["recovered","canonical"].some(ht=>ht in x))throw new Error("sign() legacy options not supported");let{hash:p,randomBytes:E}=t,{lowS:A,prehash:D,extraEntropy:P}=x;A==null&&(A=!0),S=ot("msgHash",S),tc(x),D&&(S=ot("prehashed msgHash",p(S)));let O=C(S),F=l(L),N=[R(F),R(O)];if(P!=null&&P!==!1){let ht=P===!0?E(e.BYTES):P;N.push(ot("extraEntropy",ht))}let W=se(...N),J=O;function ft(ht){let yt=B(ht);if(!f(yt))return;let gt=a(yt),It=c.BASE.multiply(yt).toAffine(),At=s(It.x);if(At===ue)return;let $t=s(gt*s(J+At*F));if($t===ue)return;let jt=(It.x===At?0:2)|Number(It.y&mt),hr=$t;return A&&g($t)&&(hr=y($t),jt^=1),new h(At,hr,jt)}return{seed:W,k2sig:ft}}let et={lowS:t.lowS,prehash:!1},V={lowS:t.lowS,prehash:!1};function q(S,L,x=et){let{seed:p,k2sig:E}=T(S,L,x),A=t;return Mo(A.hash.outputLen,A.nByteLength,A.hmac)(p,E)}c.BASE._setWindowSize(8);function ct(S,L,x,p=V){let E=S;L=ot("msgHash",L),x=ot("publicKey",x);let{lowS:A,prehash:D,format:P}=p;if(tc(p),"strict"in p)throw new Error("options.strict was renamed to lowS");if(P!==void 0&&P!=="compact"&&P!=="der")throw new Error("format must be compact or der");let O=typeof E=="string"||pe(E),F=!O&&!P&&typeof E=="object"&&E!==null&&typeof E.r=="bigint"&&typeof E.s=="bigint";if(!O&&!F)throw new Error("invalid signature, expected Uint8Array, hex string or Signature instance");let N,W;try{if(F&&(N=new h(E.r,E.s)),O){try{P!=="compact"&&(N=h.fromDER(E))}catch(jt){if(!(jt instanceof ce.Err))throw jt}!N&&P!=="der"&&(N=h.fromCompact(E))}W=c.fromHex(x)}catch{return!1}if(!N||A&&N.hasHighS())return!1;D&&(L=t.hash(L));let{r:J,s:ft}=N,ht=C(L),yt=a(ft),gt=s(ht*yt),It=s(J*yt),At=c.BASE.multiplyAndAddUnsafe(W,gt,It)?.toAffine();return At?s(At.x)===J:!1}return{CURVE:t,getPublicKey:v,getSharedSecret:_,sign:q,verify:ct,ProjectivePoint:c,Signature:h,utils:w}}function hh(r){return{hash:r,hmac:(t,...e)=>Ni(r,t,Bo(...e)),randomBytes:Yr}}function nc(r,t){let e=n=>rc({...r,...hh(n)});return{...e(t),create:e}}var sc=BigInt("0xfffffffffffffffffffffffffffffffffffffffffffffffffffffffefffffc2f"),oc=BigInt("0xfffffffffffffffffffffffffffffffebaaedce6af48a03bbfd25e8cd0364141"),dh=BigInt(1),Oi=BigInt(2),ic=(r,t)=>(r+t/Oi)/t;function ph(r){let t=sc,e=BigInt(3),n=BigInt(6),o=BigInt(11),i=BigInt(22),s=BigInt(23),a=BigInt(44),c=BigInt(88),l=r*r*r%t,u=l*l*r%t,f=nt(u,e,t)*u%t,d=nt(f,e,t)*u%t,g=nt(d,Oi,t)*l%t,y=nt(g,o,t)*g%t,b=nt(y,i,t)*y%t,h=nt(b,a,t)*b%t,w=nt(h,c,t)*h%t,v=nt(w,a,t)*b%t,m=nt(v,e,t)*u%t,_=nt(m,s,t)*y%t,B=nt(_,n,t)*l%t,C=nt(B,Oi,t);if(!Mi.eql(Mi.sqr(C),r))throw new Error("Cannot find square root");return C}var Mi=ge(sc,void 0,void 0,{sqrt:ph}),Oe=nc({a:BigInt(0),b:BigInt(7),Fp:Mi,n:oc,Gx:BigInt("55066263022277343669578718895168534326250603453777594175500187360389116729240"),Gy:BigInt("32670510020758816978083085130507043184471273380659243275938904335757337482424"),h:BigInt(1),lowS:!0,endo:{beta:BigInt("0x7ae96a2b657c07106e64479eac3434e99cf0497512f58995c1396c28719501ee"),splitScalar:r=>{let t=oc,e=BigInt("0x3086d221a7d46bcde86c90e49284eb15"),n=-dh*BigInt("0xe4437ed6010e88286f547fa90abfe4c3"),o=BigInt("0x114ca50f7a8e2f3f657c1108d9d44cfd8"),i=e,s=BigInt("0x100000000000000000000000000000000"),a=ic(i*r,t),c=ic(-n*r,t),l=Y(r-a*e-c*o,t),u=Y(-a*n-c*i,t),f=l>s,d=u>s;if(f&&(l=t-l),d&&(u=t-u),l>s||u>s)throw new Error("splitScalar: Endomorphism failed, k="+r);return{k1neg:f,k1:l,k2neg:d,k2:u}}}},tr),cy=BigInt(0);var uy=Oe.ProjectivePoint;function ac(r){return r==null?!1:typeof r.then=="function"&&typeof r.catch=="function"&&typeof r.finally=="function"}function cc(r,t,e){let n=je.digest(e instanceof Uint8Array?e:e.subarray());if(ac(n))return n.then(({digest:o})=>Oe.verify(t,o,r)).catch(o=>{throw new Tr(String(o))});try{return Oe.verify(t,n.digest,r)}catch(o){throw new Tr(String(o))}}var bn=class{type="secp256k1";raw;_key;constructor(t){this._key=lc(t),this.raw=uc(this._key)}toMultihash(){return re.digest(be(this))}toCID(){return dt.createV1(114,this.toMultihash())}toString(){return Q.encode(this.toMultihash().bytes).substring(1)}equals(t){return t==null||!(t.raw instanceof Uint8Array)?!1:pt(this.raw,t.raw)}verify(t,e){return cc(this._key,e,t)}};function ki(r){return new bn(r)}function uc(r){return Oe.ProjectivePoint.fromHex(r).toRawBytes(!0)}function lc(r){try{return Oe.ProjectivePoint.fromHex(r),r}catch(t){throw new Fe(String(t))}}function fc(r,t){let{Type:e,Data:n}=Qt.decode(r),o=n??new Uint8Array;switch(e){case lt.RSA:return Pi(o,t);case lt.Ed25519:return $o(o);case lt.secp256k1:return ki(o);default:throw new ze}}function hc(r){let{Type:t,Data:e}=Qt.decode(r.digest),n=e??new Uint8Array;switch(t){case lt.Ed25519:return $o(n);case lt.secp256k1:return ki(n);default:throw new ze}}function be(r){return Qt.encode({Type:lt[r.type],Data:r.raw})}var dc=Symbol.for("nodejs.util.inspect.custom"),mh=114,Br=class{type;multihash;publicKey;string;constructor(t){this.type=t.type,this.multihash=t.multihash,Object.defineProperty(this,"string",{enumerable:!1,writable:!0})}get[Symbol.toStringTag](){return`PeerId(${this.toString()})`}[bo]=!0;toString(){return this.string==null&&(this.string=Q.encode(this.multihash.bytes).slice(1)),this.string}toMultihash(){return this.multihash}toCID(){return dt.createV1(mh,this.multihash)}toJSON(){return this.toString()}equals(t){if(t==null)return!1;if(t instanceof Uint8Array)return pt(this.multihash.bytes,t);if(typeof t=="string")return this.toString()===t;if(t?.toMultihash()?.bytes!=null)return pt(this.multihash.bytes,t.toMultihash().bytes);throw new Error("not valid Id")}[dc](){return`PeerId(${this.toString()})`}},xn=class extends Br{type="RSA";publicKey;constructor(t){super({...t,type:"RSA"}),this.publicKey=t.publicKey}},wn=class extends Br{type="Ed25519";publicKey;constructor(t){super({...t,type:"Ed25519"}),this.publicKey=t.publicKey}},En=class extends Br{type="secp256k1";publicKey;constructor(t){super({...t,type:"secp256k1"}),this.publicKey=t.publicKey}},yh=2336,vn=class{type="url";multihash;publicKey;url;constructor(t){this.url=t.toString(),this.multihash=re.digest(z(this.url))}[dc](){return`PeerId(${this.url})`}[bo]=!0;toString(){return this.toCID().toString()}toMultihash(){return this.multihash}toCID(){return dt.createV1(yh,this.toMultihash())}toJSON(){return this.toString()}equals(t){return t==null?!1:(t instanceof Uint8Array&&(t=H(t)),t.toString()===this.toString())}};function Ki(r,t){let e;if(r.charAt(0)==="1"||r.charAt(0)==="Q")e=Mt(Q.decode(`z${r}`));else{if(t==null)throw new bt('Please pass a multibase decoder for strings that do not start with "1" or "Q"');e=Mt(t.decode(r))}return Cr(e)}function Cr(r){if(bh(r))return new xn({multihash:r});if(gh(r))try{let t=hc(r);if(t.type==="Ed25519")return new wn({multihash:r,publicKey:t});if(t.type==="secp256k1")return new En({multihash:r,publicKey:t})}catch{let e=H(r.digest);return new vn(new URL(e))}throw new Hr("Supplied PeerID Multihash is invalid")}function gh(r){return r.code===re.code}function bh(r){return r.code===je.code}var Dr;(function(r){let t;r.codec=()=>(t==null&&(t=Dt((e,n,o={})=>{o.lengthDelimited!==!1&&n.fork(),e.publicKey!=null&&e.publicKey.byteLength>0&&(n.uint32(10),n.bytes(e.publicKey)),e.payloadType!=null&&e.payloadType.byteLength>0&&(n.uint32(18),n.bytes(e.payloadType)),e.payload!=null&&e.payload.byteLength>0&&(n.uint32(26),n.bytes(e.payload)),e.signature!=null&&e.signature.byteLength>0&&(n.uint32(42),n.bytes(e.signature)),o.lengthDelimited!==!1&&n.ldelim()},(e,n,o={})=>{let i={publicKey:it(0),payloadType:it(0),payload:it(0),signature:it(0)},s=n==null?e.len:e.pos+n;for(;e.pos<s;){let a=e.uint32();switch(a>>>3){case 1:{i.publicKey=e.bytes();break}case 2:{i.payloadType=e.bytes();break}case 3:{i.payload=e.bytes();break}case 5:{i.signature=e.bytes();break}default:{e.skipType(a&7);break}}}return i})),t),r.encode=e=>Ct(e,r.codec()),r.decode=(e,n)=>Bt(e,r.codec(),n)})(Dr||(Dr={}));var Sn=class extends Error{constructor(t="Invalid signature"){super(t),this.name="InvalidSignatureError"}};var Pr=class r{static createFromProtobuf=async t=>{let e=Dr.decode(t),n=fc(e.publicKey);return new r({publicKey:n,payloadType:e.payloadType,payload:e.payload,signature:e.signature})};static seal=async(t,e)=>{if(e==null)throw new Error("Missing private key");let n=t.domain,o=t.codec,i=t.marshal(),s=pc(n,o,i),a=await e.sign(s.subarray());return new r({publicKey:e.publicKey,payloadType:o,payload:i,signature:a})};static openAndCertify=async(t,e)=>{let n=await r.createFromProtobuf(t);if(!await n.validate(e))throw new Sn("Envelope signature is not valid for the given domain");return n};publicKey;payloadType;payload;signature;marshaled;constructor(t){let{publicKey:e,payloadType:n,payload:o,signature:i}=t;this.publicKey=e,this.payloadType=n,this.payload=o,this.signature=i}marshal(){return this.marshaled==null&&(this.marshaled=Dr.encode({publicKey:be(this.publicKey),payloadType:this.payloadType,payload:this.payload.subarray(),signature:this.signature})),this.marshaled}equals(t){return pt(this.marshal(),t.marshal())}async validate(t){let e=pc(t,this.payloadType,this.payload);return this.publicKey.verify(e.subarray(),this.signature)}},pc=(r,t,e)=>{let n=z(r),o=kt(n.byteLength),i=kt(t.length),s=kt(e.length);return new at(o,n,i,t,s,e)};var An=class{index=0;input="";new(t){return this.index=0,this.input=t,this}readAtomically(t){let e=this.index,n=t();return n===void 0&&(this.index=e),n}parseWith(t){let e=t();if(this.index===this.input.length)return e}peekChar(){if(!(this.index>=this.input.length))return this.input[this.index]}readChar(){if(!(this.index>=this.input.length))return this.input[this.index++]}readGivenChar(t){return this.readAtomically(()=>{let e=this.readChar();if(e===t)return e})}readSeparator(t,e,n){return this.readAtomically(()=>{if(!(e>0&&this.readGivenChar(t)===void 0))return n()})}readNumber(t,e,n,o){return this.readAtomically(()=>{let i=0,s=0,a=this.peekChar();if(a===void 0)return;let c=a==="0",l=2**(8*o)-1;for(;;){let u=this.readAtomically(()=>{let f=this.readChar();if(f===void 0)return;let d=Number.parseInt(f,t);if(!Number.isNaN(d))return d});if(u===void 0)break;if(i*=t,i+=u,i>l||(s+=1,e!==void 0&&s>e))return}if(s!==0)return!n&&c&&s>1?void 0:i})}readIPv4Addr(){return this.readAtomically(()=>{let t=new Uint8Array(4);for(let e=0;e<t.length;e++){let n=this.readSeparator(".",e,()=>this.readNumber(10,3,!1,1));if(n===void 0)return;t[e]=n}return t})}readIPv6Addr(){let t=e=>{for(let n=0;n<e.length/2;n++){let o=n*2;if(n<e.length-3){let s=this.readSeparator(":",n,()=>this.readIPv4Addr());if(s!==void 0)return e[o]=s[0],e[o+1]=s[1],e[o+2]=s[2],e[o+3]=s[3],[o+4,!0]}let i=this.readSeparator(":",n,()=>this.readNumber(16,4,!0,2));if(i===void 0)return[o,!1];e[o]=i>>8,e[o+1]=i&255}return[e.length,!1]};return this.readAtomically(()=>{let e=new Uint8Array(16),[n,o]=t(e);if(n===16)return e;if(o||this.readGivenChar(":")===void 0||this.readGivenChar(":")===void 0)return;let i=new Uint8Array(14),s=16-(n+2),[a]=t(i.subarray(0,s));return e.set(i.subarray(0,a),16-a),e})}readIPAddr(){return this.readIPv4Addr()??this.readIPv6Addr()}};var mc=45,xh=15,rr=new An;function qi(r){if(!(r.length>xh))return rr.new(r).parseWith(()=>rr.readIPv4Addr())}function Fi(r){if(r.includes("%")&&(r=r.split("%")[0]),!(r.length>mc))return rr.new(r).parseWith(()=>rr.readIPv6Addr())}function _n(r,t=!1){if(r.includes("%")&&(r=r.split("%")[0]),r.length>mc)return;let e=rr.new(r).parseWith(()=>rr.readIPAddr());if(e)return t&&e.length===4?Uint8Array.from([0,0,0,0,0,0,0,0,0,0,255,255,e[0],e[1],e[2],e[3]]):e}var Cg=parseInt("0xFFFF",16),Dg=new Uint8Array([0,0,0,0,0,0,0,0,0,0,255,255]);function In(r){return!!qi(r)}function Tn(r){return!!Fi(r)}function Ln(r){return!!_n(r)}var bc=In,Ah=Tn,zi=function(r){let t=0;if(r=r.toString().trim(),bc(r)){let e=new Uint8Array(t+4);return r.split(/\./g).forEach(n=>{e[t++]=parseInt(n,10)&255}),e}if(Ah(r)){let e=r.split(":",8),n;for(n=0;n<e.length;n++){let i=bc(e[n]),s;i&&(s=zi(e[n]),e[n]=H(s.slice(0,2),"base16")),s!=null&&++n<8&&e.splice(n,0,H(s.slice(2,4),"base16"))}if(e[0]==="")for(;e.length<8;)e.unshift("0");else if(e[e.length-1]==="")for(;e.length<8;)e.push("0");else if(e.length<8){for(n=0;n<e.length&&e[n]!=="";n++);let i=[n,1];for(n=9-e.length;n>0;n--)i.push("0");e.splice.apply(e,i)}let o=new Uint8Array(t+16);for(n=0;n<e.length;n++){let i=parseInt(e[n],16);o[t++]=i>>8&255,o[t++]=i&255}return o}throw new Error("invalid ip address")},xc=function(r,t=0,e){t=~~t,e=e??r.length-t;let n=new DataView(r.buffer);if(e===4){let o=[];for(let i=0;i<e;i++)o.push(r[t+i]);return o.join(".")}if(e===16){let o=[];for(let i=0;i<e;i+=2)o.push(n.getUint16(t+i).toString(16));return o.join(":").replace(/(^|:)0(:0)*:0(:|$)/,"$1::$3").replace(/:{3,4}/,"::")}return""};var nr={},Vi={},Ih=[[4,32,"ip4"],[6,16,"tcp"],[33,16,"dccp"],[41,128,"ip6"],[42,-1,"ip6zone"],[43,8,"ipcidr"],[53,-1,"dns",!0],[54,-1,"dns4",!0],[55,-1,"dns6",!0],[56,-1,"dnsaddr",!0],[132,16,"sctp"],[273,16,"udp"],[275,0,"p2p-webrtc-star"],[276,0,"p2p-webrtc-direct"],[277,0,"p2p-stardust"],[280,0,"webrtc-direct"],[281,0,"webrtc"],[290,0,"p2p-circuit"],[301,0,"udt"],[302,0,"utp"],[400,-1,"unix",!1,!0],[421,-1,"ipfs"],[421,-1,"p2p"],[443,0,"https"],[444,96,"onion"],[445,296,"onion3"],[446,-1,"garlic64"],[448,0,"tls"],[449,-1,"sni"],[460,0,"quic"],[461,0,"quic-v1"],[465,0,"webtransport"],[466,-1,"certhash"],[477,0,"ws"],[478,0,"wss"],[479,0,"p2p-websocket-star"],[480,0,"http"],[481,-1,"http-path"],[777,-1,"memory"]];Ih.forEach(r=>{let t=Th(...r);Vi[t.code]=t,nr[t.name]=t});function Th(r,t,e,n,o){return{code:r,size:t,name:e,resolvable:!!n,path:!!o}}function j(r){if(typeof r=="number"){if(Vi[r]!=null)return Vi[r];throw new Error(`no protocol with code: ${r}`)}else if(typeof r=="string"){if(nr[r]!=null)return nr[r];throw new Error(`no protocol with name: ${r}`)}throw new Error(`invalid protocol id type: ${typeof r}`)}var mb=j("ip4"),yb=j("ip6"),gb=j("ipcidr");function Wi(r,t){switch(j(r).code){case 4:case 41:return Rh(t);case 42:return Zi(t);case 43:return H(t,"base10");case 6:case 273:case 33:case 132:return vc(t).toString();case 53:case 54:case 55:case 56:case 400:case 449:case 777:return Zi(t);case 421:return Ph(t);case 444:return Ec(t);case 445:return Ec(t);case 466:return Dh(t);case 481:return globalThis.encodeURIComponent(Zi(t));default:return H(t,"base16")}}function $i(r,t){switch(j(r).code){case 4:return wc(t);case 41:return wc(t);case 42:return Gi(t);case 43:return z(t,"base10");case 6:case 273:case 33:case 132:return Yi(parseInt(t,10));case 53:case 54:case 55:case 56:case 400:case 449:case 777:return Gi(t);case 421:return Bh(t);case 444:return Nh(t);case 445:return Uh(t);case 466:return Ch(t);case 481:return Gi(globalThis.decodeURIComponent(t));default:return z(t,"base16")}}var Hi=Object.values(vr).map(r=>r.decoder),Lh=function(){let r=Hi[0].or(Hi[1]);return Hi.slice(2).forEach(t=>r=r.or(t)),r}();function wc(r){if(!Ln(r))throw new Error("invalid ip address");return zi(r)}function Rh(r){let t=xc(r,0,r.length);if(t==null)throw new Error("ipBuff is required");if(!Ln(t))throw new Error("invalid ip address");return t}function Yi(r){let t=new ArrayBuffer(2);return new DataView(t).setUint16(0,r),new Uint8Array(t)}function vc(r){return new DataView(r.buffer).getUint16(r.byteOffset)}function Gi(r){let t=z(r),e=Uint8Array.from(kt(t.length));return Nt([e,t],e.length+t.length)}function Zi(r){let t=ae(r);if(r=r.slice(wt(t)),r.length!==t)throw new Error("inconsistent lengths");return H(r)}function Bh(r){let t;r[0]==="Q"||r[0]==="1"?t=Mt(Q.decode(`z${r}`)).bytes:t=dt.parse(r).multihash.bytes;let e=Uint8Array.from(kt(t.length));return Nt([e,t],e.length+t.length)}function Ch(r){let t=Lh.decode(r),e=Uint8Array.from(kt(t.length));return Nt([e,t],e.length+t.length)}function Dh(r){let t=ae(r),e=r.slice(wt(t));if(e.length!==t)throw new Error("inconsistent lengths");return"u"+H(e,"base64url")}function Ph(r){let t=ae(r),e=r.slice(wt(t));if(e.length!==t)throw new Error("inconsistent lengths");return H(e,"base58btc")}function Nh(r){let t=r.split(":");if(t.length!==2)throw new Error(`failed to parse onion addr: ["'${t.join('", "')}'"]' does not contain a port number`);if(t[0].length!==16)throw new Error(`failed to parse onion addr: ${t[0]} not a Tor onion address.`);let e=ee.decode("b"+t[0]),n=parseInt(t[1],10);if(n<1||n>65536)throw new Error("Port number is not in range(1, 65536)");let o=Yi(n);return Nt([e,o],e.length+o.length)}function Uh(r){let t=r.split(":");if(t.length!==2)throw new Error(`failed to parse onion addr: ["'${t.join('", "')}'"]' does not contain a port number`);if(t[0].length!==56)throw new Error(`failed to parse onion addr: ${t[0]} not a Tor onion3 address.`);let e=ee.decode(`b${t[0]}`),n=parseInt(t[1],10);if(n<1||n>65536)throw new Error("Port number is not in range(1, 65536)");let o=Yi(n);return Nt([e,o],e.length+o.length)}function Ec(r){let t=r.slice(0,r.length-2),e=r.slice(r.length-2),n=H(t,"base32"),o=vc(e);return`${n}:${o}`}function Sc(r){r=Xi(r);let t=[],e=[],n=null,o=r.split("/").slice(1);if(o.length===1&&o[0]==="")return{bytes:new Uint8Array,string:"/",tuples:[],stringTuples:[],path:null};for(let i=0;i<o.length;i++){let s=o[i],a=j(s);if(a.size===0){t.push([a.code]),e.push([a.code]);continue}if(i++,i>=o.length)throw new Rn("invalid address: "+r);if(a.path===!0){n=Xi(o.slice(i).join("/")),t.push([a.code,$i(a.code,n)]),e.push([a.code,n]);break}let c=$i(a.code,o[i]);t.push([a.code,c]),e.push([a.code,Wi(a.code,c)])}return{string:Ac(e),bytes:Bn(t),tuples:t,stringTuples:e,path:n}}function Qi(r){let t=[],e=[],n=null,o=0;for(;o<r.length;){let i=ae(r,o),s=wt(i),a=j(i),c=Oh(a,r.slice(o+s));if(c===0){t.push([i]),e.push([i]),o+=s;continue}let l=r.slice(o+s,o+s+c);if(o+=c+s,o>r.length)throw new Rn("Invalid address Uint8Array: "+H(r,"base16"));t.push([i,l]);let u=Wi(i,l);if(e.push([i,u]),a.path===!0){n=u;break}}return{bytes:Uint8Array.from(r),string:Ac(e),tuples:t,stringTuples:e,path:n}}function Ac(r){let t=[];return r.map(e=>{let n=j(e[0]);return t.push(n.name),e.length>1&&e[1]!=null&&t.push(e[1]),null}),Xi(t.join("/"))}function Bn(r){return Nt(r.map(t=>{let e=j(t[0]),n=Uint8Array.from(kt(e.code));return t.length>1&&t[1]!=null&&(n=Nt([n,t[1]])),n}))}function Oh(r,t){if(r.size>0)return r.size/8;if(r.size===0)return 0;{let e=ae(t instanceof Uint8Array?t:Uint8Array.from(t));return e+wt(e)}}function Xi(r){return"/"+r.trim().split("/").filter(t=>t).join("/")}var Rn=class extends Error{static name="ParseError";name="ParseError";constructor(t){super(`Error parsing address: ${t}`)}};var Mh=Symbol.for("nodejs.util.inspect.custom"),Ji=Symbol.for("@multiformats/js-multiaddr/multiaddr"),kh=[j("dns").code,j("dns4").code,j("dns6").code,j("dnsaddr").code],ji=class extends Error{constructor(t="No available resolver"){super(t),this.name="NoAvailableResolverError"}},Cn=class r{bytes;#t;#e;#r;#n;[Ji]=!0;constructor(t){t==null&&(t="");let e;if(t instanceof Uint8Array)e=Qi(t);else if(typeof t=="string"){if(t.length>0&&t.charAt(0)!=="/")throw new Error(`multiaddr "${t}" must start with a "/"`);e=Sc(t)}else if(Ic(t))e=Qi(t.bytes);else throw new Error("addr must be a string, Buffer, or another Multiaddr");this.bytes=e.bytes,this.#t=e.string,this.#e=e.tuples,this.#r=e.stringTuples,this.#n=e.path}toString(){return this.#t}toJSON(){return this.toString()}toOptions(){let t,e,n,o,i="",s=j("tcp"),a=j("udp"),c=j("ip4"),l=j("ip6"),u=j("dns6"),f=j("ip6zone");for(let[g,y]of this.stringTuples())g===f.code&&(i=`%${y??""}`),kh.includes(g)&&(e=s.name==="tcp"?"tcp":"udp",o=443,n=`${y??""}${i}`,t=g===u.code?6:4),(g===s.code||g===a.code)&&(e=j(g).name==="tcp"?"tcp":"udp",o=parseInt(y??"")),(g===c.code||g===l.code)&&(e=j(g).name==="tcp"?"tcp":"udp",n=`${y??""}${i}`,t=g===l.code?6:4);if(t==null||e==null||n==null||o==null)throw new Error('multiaddr must have a valid format: "/{ip4, ip6, dns4, dns6, dnsaddr}/{address}/{tcp, udp}/{port}".');return{family:t,host:n,transport:e,port:o}}protos(){return this.#e.map(([t])=>Object.assign({},j(t)))}protoCodes(){return this.#e.map(([t])=>t)}protoNames(){return this.#e.map(([t])=>j(t).name)}tuples(){return this.#e.map(([t,e])=>e==null?[t]:[t,e])}stringTuples(){return this.#r.map(([t,e])=>e==null?[t]:[t,e])}encapsulate(t){return t=new r(t),new r(this.toString()+t.toString())}decapsulate(t){let e=t.toString(),n=this.toString(),o=n.lastIndexOf(e);if(o<0)throw new Error(`Address ${this.toString()} does not contain subaddress: ${t.toString()}`);return new r(n.slice(0,o))}decapsulateCode(t){let e=this.tuples();for(let n=e.length-1;n>=0;n--)if(e[n][0]===t)return new r(Bn(e.slice(0,n)));return this}getPeerId(){try{let t=[];this.stringTuples().forEach(([n,o])=>{n===nr.p2p.code&&t.push([n,o]),n===nr["p2p-circuit"].code&&(t=[])});let e=t.pop();if(e?.[1]!=null){let n=e[1];return n[0]==="Q"||n[0]==="1"?H(Q.decode(`z${n}`),"base58btc"):H(dt.parse(n).multihash.bytes,"base58btc")}return null}catch{return null}}getPath(){return this.#n}equals(t){return pt(this.bytes,t.bytes)}async resolve(t){let e=this.protos().find(i=>i.resolvable);if(e==null)return[this];let n=_c.get(e.name);if(n==null)throw new ji(`no available resolver for ${e.name}`);return(await n(this,t)).map(i=>vt(i))}nodeAddress(){let t=this.toOptions();if(t.transport!=="tcp"&&t.transport!=="udp")throw new Error(`multiaddr must have a valid format - no protocol with name: "${t.transport}". Must have a valid transport protocol: "{tcp, udp}"`);return{family:t.family,address:t.host,port:t.port}}isThinWaistAddress(t){let e=(t??this).protos();return!(e.length!==2||e[0].code!==4&&e[0].code!==41||e[1].code!==6&&e[1].code!==273)}[Mh](){return`Multiaddr(${this.#t})`}};var _c=new Map;function Ic(r){return!!r?.[Ji]}function vt(r){return new Cn(r)}function Zt(){let r={};return r.promise=new Promise((t,e)=>{r.resolve=t,r.reject=e}),r}var Dn=class extends Error{type;code;constructor(t,e,n){super(t??"The operation was aborted"),this.type="aborted",this.name=n??"AbortError",this.code=e??"ABORT_ERR"}};async function Pn(r,t,e){if(t==null)return r;if(t.aborted)return r.catch(()=>{}),Promise.reject(new Dn(e?.errorMessage,e?.errorCode,e?.errorName));let n,o=new Dn(e?.errorMessage,e?.errorCode,e?.errorName);try{return await Promise.race([r,new Promise((i,s)=>{n=()=>{s(o)},t.addEventListener("abort",n)})])}finally{n!=null&&t.removeEventListener("abort",n)}}var ts=class{readNext;haveNext;ended;nextResult;constructor(){this.ended=!1,this.readNext=Zt(),this.haveNext=Zt()}[Symbol.asyncIterator](){return this}async next(){if(this.nextResult==null&&await this.haveNext.promise,this.nextResult==null)throw new Error("HaveNext promise resolved but nextResult was undefined");let t=this.nextResult;return this.nextResult=void 0,this.readNext.resolve(),this.readNext=Zt(),t}async throw(t){return this.ended=!0,t!=null&&(this.haveNext.promise.catch(()=>{}),this.haveNext.reject(t)),{done:!0,value:void 0}}async return(){let t={done:!0,value:void 0};return await this._push(void 0),t}async push(t,e){await this._push(t,e)}async end(t,e){t!=null?await this.throw(t):await this._push(void 0,e)}async _push(t,e){if(t!=null&&this.ended)throw new Error("Cannot push value onto an ended pushable");for(;this.nextResult!=null;)await this.readNext.promise;t!=null?this.nextResult={done:!1,value:t}:(this.ended=!0,this.nextResult={done:!0,value:void 0}),this.haveNext.resolve(),this.haveNext=Zt(),await Pn(this.readNext.promise,e?.signal,e)}};function Tc(){return new ts}var Nn=class extends Error{name="UnexpectedEOFError";code="ERR_UNEXPECTED_EOF"};var es=class extends Error{code;constructor(t,e){super(t),this.code=e}},rs=class extends es{type;constructor(t){super(t,"ABORT_ERR"),this.type="aborted",this.name="AbortError"}};function Lc(r,t){let e=Tc();r.sink(e).catch(async s=>{await e.end(s)}),r.sink=async s=>{for await(let a of s)await e.push(a);await e.end()};let n=r.source;r.source[Symbol.iterator]!=null?n=r.source[Symbol.iterator]():r.source[Symbol.asyncIterator]!=null&&(n=r.source[Symbol.asyncIterator]());let o=new at;return{read:async(s,a)=>{a?.signal?.throwIfAborted();let c,l=new Promise((u,f)=>{c=()=>{f(new rs("Read aborted"))},a?.signal?.addEventListener("abort",c)});try{if(s==null){let{done:f,value:d}=await Promise.race([n.next(),l]);return f===!0?new at:d}for(;o.byteLength<s;){let{value:f,done:d}=await Promise.race([n.next(),l]);if(d===!0)throw new Nn("unexpected end of input");o.append(f)}let u=o.sublist(0,s);return o.consume(s),u}finally{c!=null&&a?.signal?.removeEventListener("abort",c)}},write:async(s,a)=>{a?.signal?.throwIfAborted(),s instanceof Uint8Array?await e.push(s,a):await e.push(s.subarray(),a)},unwrap:()=>{if(o.byteLength>0){let s=r.source;r.source=async function*(){t?.yieldBytes===!1?yield o:yield*o,yield*s}()}return r}}}var Un=class extends Error{name="InvalidMessageLengthError";code="ERR_INVALID_MSG_LENGTH"},On=class extends Error{name="InvalidDataLengthError";code="ERR_MSG_DATA_TOO_LONG"},Mn=class extends Error{name="InvalidDataLengthLengthError";code="ERR_MSG_LENGTH_TOO_LONG"};function Rc(r,t={}){let e=Lc(r,t);t.maxDataLength!=null&&t.maxLengthLength==null&&(t.maxLengthLength=wt(t.maxDataLength));let n=t?.lengthDecoder??ae,o=t?.lengthEncoder??kt;return{read:async s=>{let a=-1,c=new at;for(;;){c.append(await e.read(1,s));try{a=n(c)}catch(l){if(l instanceof RangeError)continue;throw l}if(a<0)throw new Un("Invalid message length");if(t?.maxLengthLength!=null&&c.byteLength>t.maxLengthLength)throw new Mn("message length length too long");if(a>-1)break}if(t?.maxDataLength!=null&&a>t.maxDataLength)throw new On("message length too long");return e.read(a,s)},write:async(s,a)=>{await e.write(new at(o(s.byteLength),s),a)},writeV:async(s,a)=>{let c=new at(...s.flatMap(l=>[o(l.byteLength),l]));await e.write(c,a)},unwrap:()=>e.unwrap()}}function Se(r,t){let e=Rc(r,t),n={read:async(o,i)=>{let s=await e.read(i);return o.decode(s)},write:async(o,i,s)=>{await e.write(i.encode(o),s)},writeV:async(o,i,s)=>{await e.writeV(o.map(a=>i.encode(a)),s)},pb:o=>({read:async i=>n.read(o,i),write:async(i,s)=>n.write(i,o,s),writeV:async(i,s)=>n.writeV(i,o,s),unwrap:()=>n}),unwrap:()=>e.unwrap()};return n}var ns=1e3,Bc=60*ns,kn=290,Cc=15,Dc=2*60*Bc,Pc=1,Kn=2e3,Nc=100,os="circuit-relay-source",Nr=`${xo}-circuit-relay`,is=`${xo}-circuit-relay-source`,Uc=2*Bc,Oc=BigInt(1<<17),qt="/libp2p/circuit/relay/0.2.0/hop",Me="/libp2p/circuit/relay/0.2.0/stop",Mc=30*ns,ux=30*ns,Ur=300,kc=4096,Kc=.001;var $;(function(r){let t;(function(o){o.RESERVE="RESERVE",o.CONNECT="CONNECT",o.STATUS="STATUS"})(t=r.Type||(r.Type={}));let e;(function(o){o[o.RESERVE=0]="RESERVE",o[o.CONNECT=1]="CONNECT",o[o.STATUS=2]="STATUS"})(e||(e={})),function(o){o.codec=()=>Ue(e)}(t=r.Type||(r.Type={}));let n;r.codec=()=>(n==null&&(n=Dt((o,i,s={})=>{s.lengthDelimited!==!1&&i.fork(),o.type!=null&&(i.uint32(8),r.Type.codec().encode(o.type,i)),o.peer!=null&&(i.uint32(18),or.codec().encode(o.peer,i)),o.reservation!=null&&(i.uint32(26),qn.codec().encode(o.reservation,i)),o.limit!=null&&(i.uint32(34),ir.codec().encode(o.limit,i)),o.status!=null&&(i.uint32(40),k.codec().encode(o.status,i)),s.lengthDelimited!==!1&&i.ldelim()},(o,i,s={})=>{let a={},c=i==null?o.len:o.pos+i;for(;o.pos<c;){let l=o.uint32();switch(l>>>3){case 1:{a.type=r.Type.codec().decode(o);break}case 2:{a.peer=or.codec().decode(o,o.uint32(),{limits:s.limits?.peer});break}case 3:{a.reservation=qn.codec().decode(o,o.uint32(),{limits:s.limits?.reservation});break}case 4:{a.limit=ir.codec().decode(o,o.uint32(),{limits:s.limits?.limit});break}case 5:{a.status=k.codec().decode(o);break}default:{o.skipType(l&7);break}}}return a})),n),r.encode=o=>Ct(o,r.codec()),r.decode=(o,i)=>Bt(o,r.codec(),i)})($||($={}));var Ut;(function(r){let t;(function(o){o.CONNECT="CONNECT",o.STATUS="STATUS"})(t=r.Type||(r.Type={}));let e;(function(o){o[o.CONNECT=0]="CONNECT",o[o.STATUS=1]="STATUS"})(e||(e={})),function(o){o.codec=()=>Ue(e)}(t=r.Type||(r.Type={}));let n;r.codec=()=>(n==null&&(n=Dt((o,i,s={})=>{s.lengthDelimited!==!1&&i.fork(),o.type!=null&&(i.uint32(8),r.Type.codec().encode(o.type,i)),o.peer!=null&&(i.uint32(18),or.codec().encode(o.peer,i)),o.limit!=null&&(i.uint32(26),ir.codec().encode(o.limit,i)),o.status!=null&&(i.uint32(32),k.codec().encode(o.status,i)),s.lengthDelimited!==!1&&i.ldelim()},(o,i,s={})=>{let a={},c=i==null?o.len:o.pos+i;for(;o.pos<c;){let l=o.uint32();switch(l>>>3){case 1:{a.type=r.Type.codec().decode(o);break}case 2:{a.peer=or.codec().decode(o,o.uint32(),{limits:s.limits?.peer});break}case 3:{a.limit=ir.codec().decode(o,o.uint32(),{limits:s.limits?.limit});break}case 4:{a.status=k.codec().decode(o);break}default:{o.skipType(l&7);break}}}return a})),n),r.encode=o=>Ct(o,r.codec()),r.decode=(o,i)=>Bt(o,r.codec(),i)})(Ut||(Ut={}));var or;(function(r){let t;r.codec=()=>(t==null&&(t=Dt((e,n,o={})=>{if(o.lengthDelimited!==!1&&n.fork(),e.id!=null&&e.id.byteLength>0&&(n.uint32(10),n.bytes(e.id)),e.addrs!=null)for(let i of e.addrs)n.uint32(18),n.bytes(i);o.lengthDelimited!==!1&&n.ldelim()},(e,n,o={})=>{let i={id:it(0),addrs:[]},s=n==null?e.len:e.pos+n;for(;e.pos<s;){let a=e.uint32();switch(a>>>3){case 1:{i.id=e.bytes();break}case 2:{if(o.limits?.addrs!=null&&i.addrs.length===o.limits.addrs)throw new _r('Decode error - map field "addrs" had too many elements');i.addrs.push(e.bytes());break}default:{e.skipType(a&7);break}}}return i})),t),r.encode=e=>Ct(e,r.codec()),r.decode=(e,n)=>Bt(e,r.codec(),n)})(or||(or={}));var qn;(function(r){let t;r.codec=()=>(t==null&&(t=Dt((e,n,o={})=>{if(o.lengthDelimited!==!1&&n.fork(),e.expire!=null&&e.expire!==0n&&(n.uint32(8),n.uint64(e.expire)),e.addrs!=null)for(let i of e.addrs)n.uint32(18),n.bytes(i);e.voucher!=null&&(n.uint32(26),Fn.codec().encode(e.voucher,n)),o.lengthDelimited!==!1&&n.ldelim()},(e,n,o={})=>{let i={expire:0n,addrs:[]},s=n==null?e.len:e.pos+n;for(;e.pos<s;){let a=e.uint32();switch(a>>>3){case 1:{i.expire=e.uint64();break}case 2:{if(o.limits?.addrs!=null&&i.addrs.length===o.limits.addrs)throw new _r('Decode error - map field "addrs" had too many elements');i.addrs.push(e.bytes());break}case 3:{i.voucher=Fn.codec().decode(e,e.uint32(),{limits:o.limits?.voucher});break}default:{e.skipType(a&7);break}}}return i})),t),r.encode=e=>Ct(e,r.codec()),r.decode=(e,n)=>Bt(e,r.codec(),n)})(qn||(qn={}));var ir;(function(r){let t;r.codec=()=>(t==null&&(t=Dt((e,n,o={})=>{o.lengthDelimited!==!1&&n.fork(),e.duration!=null&&(n.uint32(8),n.uint32(e.duration)),e.data!=null&&(n.uint32(16),n.uint64(e.data)),o.lengthDelimited!==!1&&n.ldelim()},(e,n,o={})=>{let i={},s=n==null?e.len:e.pos+n;for(;e.pos<s;){let a=e.uint32();switch(a>>>3){case 1:{i.duration=e.uint32();break}case 2:{i.data=e.uint64();break}default:{e.skipType(a&7);break}}}return i})),t),r.encode=e=>Ct(e,r.codec()),r.decode=(e,n)=>Bt(e,r.codec(),n)})(ir||(ir={}));var k;(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"})(k||(k={}));var ss;(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"})(ss||(ss={}));(function(r){r.codec=()=>Ue(ss)})(k||(k={}));var sr;(function(r){let t;r.codec=()=>(t==null&&(t=Dt((e,n,o={})=>{o.lengthDelimited!==!1&&n.fork(),e.relay!=null&&e.relay.byteLength>0&&(n.uint32(10),n.bytes(e.relay)),e.peer!=null&&e.peer.byteLength>0&&(n.uint32(18),n.bytes(e.peer)),e.expiration!=null&&e.expiration!==0n&&(n.uint32(24),n.uint64(e.expiration)),o.lengthDelimited!==!1&&n.ldelim()},(e,n,o={})=>{let i={relay:it(0),peer:it(0),expiration:0n},s=n==null?e.len:e.pos+n;for(;e.pos<s;){let a=e.uint32();switch(a>>>3){case 1:{i.relay=e.bytes();break}case 2:{i.peer=e.bytes();break}case 3:{i.expiration=e.uint64();break}default:{e.skipType(a&7);break}}}return i})),t),r.encode=e=>Ct(e,r.codec()),r.decode=(e,n)=>Bt(e,r.codec(),n)})(sr||(sr={}));var Fn;(function(r){let t;r.codec=()=>(t==null&&(t=Dt((e,n,o={})=>{o.lengthDelimited!==!1&&n.fork(),e.publicKey!=null&&e.publicKey.byteLength>0&&(n.uint32(10),n.bytes(e.publicKey)),e.payloadType!=null&&e.payloadType.byteLength>0&&(n.uint32(18),n.bytes(e.payloadType)),e.payload!=null&&(n.uint32(26),sr.codec().encode(e.payload,n)),e.signature!=null&&e.signature.byteLength>0&&(n.uint32(42),n.bytes(e.signature)),o.lengthDelimited!==!1&&n.ldelim()},(e,n,o={})=>{let i={publicKey:it(0),payloadType:it(0),signature:it(0)},s=n==null?e.len:e.pos+n;for(;e.pos<s;){let a=e.uint32();switch(a>>>3){case 1:{i.publicKey=e.bytes();break}case 2:{i.payloadType=e.bytes();break}case 3:{i.payload=sr.codec().decode(e,e.uint32(),{limits:o.limits?.payload});break}case 5:{i.signature=e.bytes();break}default:{e.skipType(a&7);break}}}return i})),t),r.encode=e=>Ct(e,r.codec()),r.decode=(e,n)=>Bt(e,r.codec(),n)})(Fn||(Fn={}));var Kh=r=>r.toString().split("/").slice(1),ar=r=>({match:t=>t.length<1?!1:r(t[0])?t.slice(1):!1,pattern:"fn"}),M=r=>({match:t=>ar(e=>e===r).match(t),pattern:r}),ke=()=>({match:r=>ar(t=>typeof t=="string").match(r),pattern:"{string}"}),Or=()=>({match:r=>ar(t=>!isNaN(parseInt(t))).match(r),pattern:"{number}"}),X=()=>({match:r=>{if(r.length<2||r[0]!=="p2p"&&r[0]!=="ipfs")return!1;if(r[1].startsWith("Q")||r[1].startsWith("1"))try{Q.decode(`z${r[1]}`)}catch{return!1}else return!1;return r.slice(2)},pattern:"/p2p/{peerid}"}),Mr=()=>({match:r=>{if(r.length<2||r[0]!=="certhash")return!1;try{li.decode(r[1])}catch{return!1}return r.slice(2)},pattern:"/certhash/{certhash}"}),G=r=>({match:t=>{let e=r.match(t);return e===!1?t:e},pattern:`optional(${r.pattern})`}),St=(...r)=>({match:t=>{let e;for(let n of r){let o=n.match(t);o!==!1&&(e==null||o.length<e.length)&&(e=o)}return e??!1},pattern:`or(${r.map(t=>t.pattern).join(", ")})`}),K=(...r)=>({match:t=>{for(let e of r){let n=e.match(t);if(n===!1)return!1;t=n}return t},pattern:`and(${r.map(t=>t.pattern).join(", ")})`});function tt(...r){function t(o){let i=Kh(o);for(let s of r){let a=s.match(i);if(a===!1)return!1;i=a}return i}function e(o){return t(o)!==!1}function n(o){let i=t(o);return i===!1?!1:i.length===0}return{matchers:r,matches:e,exactMatch:n}}var Vn=K(M("dns4"),ke()),Hn=K(M("dns6"),ke()),Gn=K(M("dnsaddr"),ke()),cs=K(M("dns"),ke()),xx=tt(Vn,G(X())),wx=tt(Hn,G(X())),Ex=tt(Gn,G(X())),vx=tt(St(cs,Gn,Vn,Hn),G(X())),qc=K(M("ip4"),ar(In)),Fc=K(M("ip6"),ar(Tn)),us=St(qc,Fc),le=St(us,cs,Vn,Hn,Gn),Sx=tt(St(us,K(St(cs,Gn,Vn,Hn),G(X())))),Ax=tt(qc),_x=tt(Fc),Ix=tt(us),ls=K(le,M("tcp"),Or()),kr=K(le,M("udp"),Or()),Tx=tt(K(ls,G(X()))),Lx=tt(kr),fs=K(kr,M("quic"),G(X())),Zn=K(kr,M("quic-v1"),G(X())),qh=St(fs,Zn),Rx=tt(fs),Bx=tt(Zn),as=St(le,ls,kr,fs,Zn),zc=St(K(as,M("ws"),G(X()))),Cx=tt(zc),Vc=St(K(as,M("wss"),G(X())),K(as,M("tls"),G(K(M("sni"),ke())),M("ws"),G(X()))),Dx=tt(Vc),Hc=K(kr,M("webrtc-direct"),G(Mr()),G(Mr()),G(X())),Px=tt(Hc),Gc=K(Zn,M("webtransport"),G(Mr()),G(Mr()),G(X())),Nx=tt(Gc),zn=St(zc,Vc,K(ls,G(X())),K(qh,G(X())),K(le,G(X())),Hc,Gc,X()),Zc=tt(zn),Fh=K(zn,M("p2p-circuit"),X()),Wn=tt(Fh),zh=St(K(zn,M("p2p-circuit"),M("webrtc"),G(X())),K(zn,M("webrtc"),G(X())),K(M("webrtc"),G(X()))),Ux=tt(zh),Vh=St(K(le,M("tcp"),Or(),M("http"),G(X())),K(le,M("http"),G(X()))),Ox=tt(Vh),Hh=St(K(le,M("tcp"),St(K(M("443"),M("http")),K(Or(),M("https"))),G(X())),K(le,M("tls"),M("http"),G(X())),K(le,M("https"),G(X()))),Mx=tt(Hh),Gh=St(K(M("memory"),ke(),G(X()))),kx=tt(Gh);function $n(r){let t=new globalThis.AbortController;function e(){t.abort();for(let i of r)i?.removeEventListener!=null&&i.removeEventListener("abort",e)}for(let i of r){if(i?.aborted===!0){e();break}i?.addEventListener!=null&&i.addEventListener("abort",e)}function n(){for(let i of r)i?.removeEventListener!=null&&i.removeEventListener("abort",e)}let o=t.signal;return o.clear=n,o}var Yn=class extends Error{constructor(t="Transfer limit error"){super(t),this.name="TransferLimitError"}},Kr=class extends Error{constructor(t="Duration limit error"){super(t),this.name="DurationLimitError"}},qr=class extends Error{static name="HadEnoughRelaysError";name="HadEnoughRelaysError"},Xn=class extends Error{static name="DoubleRelayError";name="DoubleRelayError"},Qn=class extends Error{static name="RelayQueueFullError";name="RelayQueueFullError"};async function*Wc(r,t,e){let n=t.remaining;for await(let o of r){let i=BigInt(o.byteLength);if(t.remaining-i<0){let s=Number(t.remaining);t.remaining=0n;try{s!==0&&(yield o.subarray(0,s))}catch(a){e.log.error(a)}throw new Yn(`data limit of ${n} bytes exceeded`)}t.remaining-=i,yield o}}function $c(r,t,e,n,o){function i(f){r.abort(f),t.abort(f)}let s=[e,n.signal];n.limit?.duration!=null&&(o.log("limiting relayed connection duration to %dms",n.limit.duration),s.push(AbortSignal.timeout(n.limit.duration)));let a=$n(s),c=!1,l=!1,u;n.limit?.data!=null&&(u={remaining:n.limit.data}),queueMicrotask(()=>{let f=()=>{o.log("relayed connection reached time limit"),t.abort(new Kr(`duration limit of ${n.limit?.duration} ms exceeded`))};a.addEventListener("abort",f,{once:!0}),t.sink(u==null?r.source:Wc(r.source,u,o)).catch(d=>{o.log.error("error while relaying streams src -> dst",d),i(d)}).finally(()=>{c=!0,l&&(a.removeEventListener("abort",f),a.clear())})}),queueMicrotask(()=>{let f=()=>{o.log("relayed connection reached time limit"),r.abort(new Kr(`duration limit of ${n.limit?.duration} ms exceeded`))};a.addEventListener("abort",f,{once:!0}),r.sink(u==null?t.source:Wc(t.source,u,o)).catch(d=>{o.log.error("error while relaying streams dst -> src",d),i(d)}).finally(()=>{l=!0,c&&(a.removeEventListener("abort",f),a.clear())})})}function hs(r){let t=r*BigInt(1e3),e=new Date().getTime();return Number(t-BigInt(e))}var Fr=class{expires;bytes;constructor(t){t?.duration!=null&&t?.duration!==0&&(this.expires=Date.now()+t.duration*1e3),this.bytes=t?.data,this.bytes===0n&&(this.bytes=void 0),this.onData=this.onData.bind(this)}onData(t){this.bytes!=null&&(this.bytes-=BigInt(t.byteLength),this.bytes<0n&&(this.bytes=0n))}getLimits(){if(this.expires==null&&this.bytes==null)return;let t={};if(this.bytes!=null){let e=this;Object.defineProperty(t,"bytes",{get(){return e.bytes}})}if(this.expires!=null){let e=this;Object.defineProperty(t,"seconds",{get(){return Math.round(((e.expires??0)-Date.now())/1e3)}})}return t}},jn=tt(K(Zc.matchers[0],M("p2p-circuit"))),Jn=tt(M("p2p-circuit"));function to(r,t){let e={[Symbol.iterator]:()=>e,next:()=>{let n=r.next(),o=n.value;return n.done===!0||o==null?{done:!0,value:void 0}:{done:!1,value:t(o)}}};return e}var Ae=class{map;constructor(t){if(this.map=new Map,t!=null)for(let[e,n]of t.entries())this.map.set(e.toString(),{key:e,value:n})}[Symbol.iterator](){return this.entries()}clear(){this.map.clear()}delete(t){return this.map.delete(t.toString())}entries(){return to(this.map.entries(),t=>[t[1].key,t[1].value])}forEach(t){this.map.forEach((e,n)=>{t(e.value,e.key,this)})}get(t){return this.map.get(t.toString())?.value}has(t){return this.map.has(t.toString())}set(t,e){this.map.set(t.toString(),{key:t,value:e})}keys(){return to(this.map.values(),t=>t.key)}values(){return to(this.map.values(),t=>t.value)}get size(){return this.map.size}};var ds={32:16777619n,64:1099511628211n,128:309485009821345068724781371n,256:374144419156711147060143317175368453031918731002211n,512:35835915874844867368919076489095108449946327955754392558399825615420669938882575126094039892345713852759n,1024:5016456510113118655434598811035278955030765345404790744303017523831112055108147451509157692220295382716162651878526895249385292291816524375083746691371804094271873160484737966720260389217684476157468082573n},Yc={32:2166136261n,64:14695981039346656037n,128:144066263297769815596495629667062367629n,256:100029257958052580907070968620625704837092796014241193945225284501741471925557n,512:9659303129496669498009435400716310466090418745672637896108374329434462657994582932197716438449813051892206539805784495328239340083876191928701583869517785n,1024:14197795064947621068722070641403218320880622795441933960878474914617582723252296732303717722150864096521202355549365628174669108571814760471015076148029755969804077320157692458563003215304957150157403644460363550505412711285966361610267868082893823963790439336411086884584107735010676915n},Xc=new globalThis.TextEncoder;function Zh(r,t){let e=ds[t],n=Yc[t];for(let o=0;o<r.length;o++)n^=BigInt(r[o]),n=BigInt.asUintN(t,n*e);return n}function Wh(r,t,e){if(e.length===0)throw new Error("The `utf8Buffer` option must have a length greater than zero");let n=ds[t],o=Yc[t],i=r;for(;i.length>0;){let s=Xc.encodeInto(i,e);i=i.slice(s.read);for(let a=0;a<s.written;a++)o^=BigInt(e[a]),o=BigInt.asUintN(t,o*n)}return o}function ps(r,{size:t=32,utf8Buffer:e}={}){if(!ds[t])throw new Error("The `size` option must be one of 32, 64, 128, 256, 512, or 1024");if(typeof r=="string"){if(e)return Wh(r,t,e);r=Xc.encode(r)}return Zh(r,t)}var zr={hash:r=>Number(ps(r,{size:32})),hashV:(r,t)=>$h(zr.hash(r,t))};function $h(r){let t=r.toString(16);return t.length%2===1&&(t=`0${t}`),z(t,"base16")}var ms=64,Wt=class{fp;h;seed;constructor(t,e,n,o=2){if(o>ms)throw new TypeError("Invalid Fingerprint Size");let i=e.hashV(t,n),s=it(o);for(let a=0;a<s.length;a++)s[a]=i[a];s.length===0&&(s[0]=7),this.fp=s,this.h=e,this.seed=n}hash(){return this.h.hash(this.fp,this.seed)}equals(t){return t?.fp instanceof Uint8Array?pt(this.fp,t.fp):!1}};function Ke(r,t){return Math.floor(Math.random()*(t-r))+r}var qe=class{contents;constructor(t){this.contents=new Array(t).fill(null)}has(t){if(!(t instanceof Wt))throw new TypeError("Invalid Fingerprint");return this.contents.some(e=>t.equals(e))}add(t){if(!(t instanceof Wt))throw new TypeError("Invalid Fingerprint");for(let e=0;e<this.contents.length;e++)if(this.contents[e]==null)return this.contents[e]=t,!0;return!0}swap(t){if(!(t instanceof Wt))throw new TypeError("Invalid Fingerprint");let e=Ke(0,this.contents.length-1),n=this.contents[e];return this.contents[e]=t,n}remove(t){if(!(t instanceof Wt))throw new TypeError("Invalid Fingerprint");let e=this.contents.findIndex(n=>t.equals(n));return e>-1?(this.contents[e]=null,!0):!1}};var Yh=500,Vr=class{bucketSize;filterSize;fingerprintSize;buckets;count;hash;seed;constructor(t){this.filterSize=t.filterSize,this.bucketSize=t.bucketSize??4,this.fingerprintSize=t.fingerprintSize??2,this.count=0,this.buckets=[],this.hash=t.hash??zr,this.seed=t.seed??Ke(0,Math.pow(2,10))}add(t){typeof t=="string"&&(t=z(t));let e=new Wt(t,this.hash,this.seed,this.fingerprintSize),n=this.hash.hash(t,this.seed)%this.filterSize,o=(n^e.hash())%this.filterSize;if(this.buckets[n]==null&&(this.buckets[n]=new qe(this.bucketSize)),this.buckets[o]==null&&(this.buckets[o]=new qe(this.bucketSize)),this.buckets[n].add(e)||this.buckets[o].add(e))return this.count++,!0;let i=[n,o],s=i[Ke(0,i.length-1)];this.buckets[s]==null&&(this.buckets[s]=new qe(this.bucketSize));for(let a=0;a<Yh;a++){let c=this.buckets[s].swap(e);if(c!=null&&(s=(s^c.hash())%this.filterSize,this.buckets[s]==null&&(this.buckets[s]=new qe(this.bucketSize)),this.buckets[s].add(c)))return this.count++,!0}return!1}has(t){typeof t=="string"&&(t=z(t));let e=new Wt(t,this.hash,this.seed,this.fingerprintSize),n=this.hash.hash(t,this.seed)%this.filterSize,o=this.buckets[n]?.has(e)??!1;if(o)return o;let i=(n^e.hash())%this.filterSize;return this.buckets[i]?.has(e)??!1}remove(t){typeof t=="string"&&(t=z(t));let e=new Wt(t,this.hash,this.seed,this.fingerprintSize),n=this.hash.hash(t,this.seed)%this.filterSize,o=this.buckets[n]?.remove(e)??!1;if(o)return this.count--,o;let i=(n^e.hash())%this.filterSize,s=this.buckets[i]?.remove(e)??!1;return s&&this.count--,s}get reliable(){return Math.floor(100*(this.count/this.filterSize))<=90}},Xh={1:.5,2:.84,4:.95,8:.98};function Qh(r=.001){return r>.002?2:r>1e-5?4:8}function Qc(r,t=.001){let e=Qh(t),n=Xh[e],o=Math.round(r/n),i=Math.min(Math.ceil(Math.log2(1/t)+Math.log2(2*e)),ms);return{filterSize:o,bucketSize:e,fingerprintSize:i}}var eo=class{filterSize;bucketSize;fingerprintSize;scale;filterSeries;hash;seed;constructor(t){this.bucketSize=t.bucketSize??4,this.filterSize=t.filterSize??(1<<18)/this.bucketSize,this.fingerprintSize=t.fingerprintSize??2,this.scale=t.scale??2,this.hash=t.hash??zr,this.seed=t.seed??Ke(0,Math.pow(2,10)),this.filterSeries=[new Vr({filterSize:this.filterSize,bucketSize:this.bucketSize,fingerprintSize:this.fingerprintSize,hash:this.hash,seed:this.seed})]}add(t){if(typeof t=="string"&&(t=z(t)),this.has(t))return!0;let e=this.filterSeries.find(n=>n.reliable);if(e==null){let n=this.filterSize*Math.pow(this.scale,this.filterSeries.length);e=new Vr({filterSize:n,bucketSize:this.bucketSize,fingerprintSize:this.fingerprintSize,hash:this.hash,seed:this.seed}),this.filterSeries.push(e)}return e.add(t)}has(t){typeof t=="string"&&(t=z(t));for(let e=0;e<this.filterSeries.length;e++)if(this.filterSeries[e].has(t))return!0;return!1}remove(t){typeof t=="string"&&(t=z(t));for(let e=0;e<this.filterSeries.length;e++)if(this.filterSeries[e].remove(t))return!0;return!1}get count(){return this.filterSeries.reduce((t,e)=>t+e.count,0)}};function cr(r,t=.001,e){return new eo({...Qc(r,t),...e??{}})}var ro=class{filter;constructor(t,e){this.filter=cr(t,e)}has(t){return this.filter.has(t.toMultihash().bytes)}add(t){this.filter.add(t.toMultihash().bytes)}remove(t){this.filter.remove?.(t.toMultihash().bytes)}};function ys(r,t=.001){return new ro(r,t)}var gs=class extends Ae{metric;constructor(t){super();let{name:e,metrics:n}=t;this.metric=n.registerMetric(e),this.updateComponentMetric()}set(t,e){return super.set(t,e),this.updateComponentMetric(),this}delete(t){let e=super.delete(t);return this.updateComponentMetric(),e}clear(){super.clear(),this.updateComponentMetric()}updateComponentMetric(){this.metric.update(this.size)}};function bs(r){let{name:t,metrics:e}=r,n;return e!=null?n=new gs({name:t,metrics:e}):n=new Ae,n}var xs=class extends Error{type;code;constructor(t,e,n){super(t??"The operation was aborted"),this.type="aborted",this.name=n??"AbortError",this.code=e??"ABORT_ERR"}};function jc(r,t){let e=new xs(t?.errorMessage,t?.errorCode,t?.errorName),n=new AbortController,o=()=>{n.abort(e)},i=AbortSignal.timeout(r);i.addEventListener("abort",o);let s=n.signal;return s.reset=a=>{i?.removeEventListener("abort",o),i=AbortSignal.timeout(a??r),i.addEventListener("abort",()=>{n.abort(e)})},s.clear=()=>{i?.removeEventListener("abort",o),i=void 0},s}var no=class{reservations;maxReservations;applyDefaultLimit;reservationTtl;defaultDurationLimit;defaultDataLimit;log;constructor(t,e={}){this.log=t.logger.forComponent("libp2p:circuit-relay:server:reservation-store"),this.maxReservations=e.maxReservations??Cc,this.applyDefaultLimit=e.applyDefaultLimit!==!1,this.reservationTtl=e.reservationTtl??Dc,this.defaultDurationLimit=e.defaultDurationLimit??Uc,this.defaultDataLimit=e.defaultDataLimit??Oc,this.reservations=bs({metrics:t.metrics,name:"libp2p_circuit_relay_server_reservations_total"})}reserve(t,e,n){let o=this.reservations.get(t);if(this.reservations.size>=this.maxReservations&&o==null)return{status:k.RESERVATION_REFUSED};let i=new Date(Date.now()+this.reservationTtl),s;return this.applyDefaultLimit&&(s=n??{data:this.defaultDataLimit,duration:this.defaultDurationLimit}),o!=null?(this.log("refreshing reservation for client %p",t),o.signal.reset(this.reservationTtl)):(this.log("creating new reservation for client %p",t),o={addr:e,expiry:i,limit:s,signal:jc(this.reservationTtl)}),this.reservations.set(t,o),o.signal.addEventListener("abort",()=>{this.reservations.delete(t)}),{status:k.OK,expire:Math.round(i.getTime()/1e3)}}removeReservation(t){this.reservations.delete(t)}get(t){return this.reservations.get(t)}clear(){this.reservations.clear()}};var oo=class r{domain="libp2p-relay-rsvp";codec=new Uint8Array([3,2]);relay;peer;expiration;constructor({relay:t,peer:e,expiration:n}){this.relay=t,this.peer=e,this.expiration=n}marshal(){return sr.encode({relay:this.relay.toMultihash().bytes,peer:this.peer.toMultihash().bytes,expiration:BigInt(this.expiration)})}equals(t){return!(!(t instanceof r)||!this.peer.equals(t.peer)||!this.relay.equals(t.relay)||this.expiration!==t.expiration)}};var Jc=r=>r.protoCodes().includes(kn),jh={maxOutboundStopStreams:Ur},ws=class extends Ot{registrar;peerStore;addressManager;peerId;privateKey;connectionManager;connectionGater;reservationStore;started;hopTimeout;shutdownController;maxInboundHopStreams;maxOutboundHopStreams;maxOutboundStopStreams;log;constructor(t,e={}){super(),this.log=t.logger.forComponent("libp2p:circuit-relay:server"),this.registrar=t.registrar,this.peerStore=t.peerStore,this.addressManager=t.addressManager,this.peerId=t.peerId,this.privateKey=t.privateKey,this.connectionManager=t.connectionManager,this.connectionGater=t.connectionGater,this.started=!1,this.hopTimeout=e?.hopTimeout??Mc,this.maxInboundHopStreams=e.maxInboundHopStreams,this.maxOutboundHopStreams=e.maxOutboundHopStreams,this.maxOutboundStopStreams=e.maxOutboundStopStreams??jh.maxOutboundStopStreams,this.reservationStore=new no(t,e.reservations),this.shutdownController=new AbortController,this.shutdownController.signal}[Symbol.toStringTag]="@libp2p/circuit-relay-v2-server";isStarted(){return this.started}async start(){this.started||(await this.registrar.handle(qt,t=>{this.onHop(t).catch(e=>{this.log.error(e)})},{maxInboundStreams:this.maxInboundHopStreams,maxOutboundStreams:this.maxOutboundHopStreams,runOnLimitedConnection:!0}),this.started=!0)}async stop(){this.reservationStore.clear(),this.shutdownController.abort(),await this.registrar.unhandle(qt),this.started=!1}async onHop({connection:t,stream:e}){this.log("received circuit v2 hop protocol stream from %p",t.remotePeer);let n={signal:AbortSignal.timeout(this.hopTimeout)},o=Se(e);try{let i=await o.pb($).read(n);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},n)}catch(i){this.log.error("error while handling hop",i),await o.pb($).write({type:$.Type.STATUS,status:k.MALFORMED_MESSAGE},n),e.abort(i)}}async handleHopProtocol({stream:t,request:e,connection:n},o){switch(this.log("received hop message"),e.type){case $.Type.RESERVE:await this.handleReserve({stream:t,request:e,connection:n},o);break;case $.Type.CONNECT:await this.handleConnect({stream:t,request:e,connection:n},o);break;default:this.log.error("invalid hop request type %s via peer %p",e.type,n.remotePeer),await t.pb($).write({type:$.Type.STATUS,status:k.UNEXPECTED_MESSAGE})}}async handleReserve({stream:t,connection:e},n){let o=t.pb($);if(this.log("hop reserve request from %p",e.remotePeer),Jc(e.remoteAddr)){this.log.error("relay reservation over circuit connection denied for peer: %p",e.remotePeer),await o.write({type:$.Type.STATUS,status:k.PERMISSION_DENIED},n);return}if(await this.connectionGater.denyInboundRelayReservation?.(e.remotePeer)===!0){this.log.error("reservation for %p denied by connection gater",e.remotePeer),await o.write({type:$.Type.STATUS,status:k.PERMISSION_DENIED},n);return}let i=this.reservationStore.reserve(e.remotePeer,e.remoteAddr);try{if(i.status!==k.OK){await o.write({type:$.Type.STATUS,status:i.status},n);return}if(i.expire!=null){let s=i.expire*1e3-Date.now();await this.peerStore.merge(e.remotePeer,{tags:{[os]:{value:1,ttl:s},[is]:{value:1,ttl:s}}})}await o.write({type:$.Type.STATUS,status:k.OK,reservation:await this.makeReservation(e.remotePeer,BigInt(i.expire??0)),limit:this.reservationStore.get(e.remotePeer)?.limit},n),this.log("sent confirmation response to %s",e.remotePeer)}catch(s){this.log.error("failed to send confirmation response to %p - %e",e.remotePeer,s),this.reservationStore.removeReservation(e.remotePeer);try{await this.peerStore.merge(e.remotePeer,{tags:{[os]:void 0,[is]:void 0}})}catch(a){this.log.error("failed to untag relay source peer %p - %e",e.remotePeer,a)}}}async makeReservation(t,e){let n=[];for(let i of this.addressManager.getAddresses())i.toString().includes("/p2p-circuit")||n.push(i.bytes);let o=await Pr.seal(new oo({peer:t,relay:this.peerId,expiration:e}),this.privateKey);return{addrs:n,expire:e,voucher:{publicKey:be(o.publicKey),payloadType:o.payloadType,payload:{peer:t.toMultihash().bytes,relay:this.peerId.toMultihash().bytes,expiration:e},signature:o.signature}}}async handleConnect({stream:t,request:e,connection:n},o){let i=t.pb($);if(Jc(n.remoteAddr)){this.log.error("relay reservation over circuit connection denied for peer: %p",n.remotePeer),await i.write({type:$.Type.STATUS,status:k.PERMISSION_DENIED},o);return}this.log("hop connect request from %p",n.remotePeer);let s;try{if(e.peer==null)throw this.log.error("no peer info in hop connect request"),new Error("no peer info in request");e.peer.addrs.forEach(vt),s=Cr(Mt(e.peer.id))}catch(d){this.log.error("invalid hop connect request via peer %p %s",n.remotePeer,d),await i.write({type:$.Type.STATUS,status:k.MALFORMED_MESSAGE},o);return}let a=this.reservationStore.get(s);if(a==null){this.log.error("hop connect denied for destination peer %p not having a reservation for %p with status %s",s,n.remotePeer,k.NO_RESERVATION),await i.write({type:$.Type.STATUS,status:k.NO_RESERVATION},o);return}if(await this.connectionGater.denyOutboundRelayedConnection?.(n.remotePeer,s)===!0){this.log.error("hop connect for %p to %p denied by connection gater",n.remotePeer,s),await i.write({type:$.Type.STATUS,status:k.PERMISSION_DENIED},o);return}let c=this.connectionManager.getConnections(s);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",s,n.remotePeer),await i.write({type:$.Type.STATUS,status:k.NO_RESERVATION},o);return}let l=c[0],u=await this.stopHop({connection:l,request:{type:Ut.Type.CONNECT,peer:{id:n.remotePeer.toMultihash().bytes,addrs:[]},limit:a?.limit}},o);if(u==null){this.log.error("failed to open stream to destination peer %p",l?.remotePeer),await i.write({type:$.Type.STATUS,status:k.CONNECTION_FAILED},o);return}await i.write({type:$.Type.STATUS,status:k.OK,limit:a?.limit},o);let f=t.unwrap();this.log("connection from %p to %p established - merging streams",n.remotePeer,s),$c(f,u,this.shutdownController.signal,a,{log:this.log})}async stopHop({connection:t,request:e},n){this.log("starting circuit relay v2 stop request to %s",t.remotePeer);let o=await t.newStream([Me],{maxOutboundStreams:this.maxOutboundStopStreams,runOnLimitedConnection:!0,...n}),i=Se(o),s=i.pb(Ut);await s.write(e,n);let a;try{a=await s.read(n)}catch{this.log.error("error parsing stop message response from %p",t.remotePeer)}if(a==null){this.log.error("could not read response from %p",t.remotePeer),await o.close(n);return}if(a.status===k.OK)return this.log("stop request to %p was successful",t.remotePeer),i.unwrap();this.log("stop request failed with code %d",a.status),await o.close(n)}get reservations(){return this.reservationStore.reservations}};function tu(r={}){return t=>new ws(t,r)}function Jh(r){let[t,e]=r[Symbol.asyncIterator]!=null?[r[Symbol.asyncIterator](),Symbol.asyncIterator]:[r[Symbol.iterator](),Symbol.iterator],n=[];return{peek:()=>t.next(),push:o=>{n.push(o)},next:()=>n.length>0?{done:!1,value:n.shift()}:t.next(),[e](){return this}}}var eu=Jh;function td(r){return r[Symbol.asyncIterator]!=null}function ru(r){return r?.then!=null}function ed(r,t){let e=0;if(td(r))return async function*(){for await(let c of r){let l=t(c,e++);ru(l)&&await l,yield c}}();let n=eu(r),{value:o,done:i}=n.next();if(i===!0)return function*(){}();if(typeof t(o,e++)?.then=="function")return async function*(){yield o;for await(let c of n){let l=t(c,e++);ru(l)&&await l,yield c}}();let a=t;return function*(){yield o;for(let c of n)a(c,e++),yield c}()}var nu=ed;var so=class{buffer;mask;top;btm;next;constructor(t){if(!(t>0)||(t-1&t)!==0)throw new Error("Max size for a FixedFIFO should be a power of two");this.buffer=new Array(t),this.mask=t-1,this.top=0,this.btm=0,this.next=null}push(t){return this.buffer[this.top]!==void 0?!1:(this.buffer[this.top]=t,this.top=this.top+1&this.mask,!0)}shift(){let t=this.buffer[this.btm];if(t!==void 0)return this.buffer[this.btm]=void 0,this.btm=this.btm+1&this.mask,t}isEmpty(){return this.buffer[this.btm]===void 0}},ur=class{size;hwm;head;tail;constructor(t={}){this.hwm=t.splitLimit??16,this.head=new so(this.hwm),this.tail=this.head,this.size=0}calculateSize(t){return t?.byteLength!=null?t.byteLength:1}push(t){if(t?.value!=null&&(this.size+=this.calculateSize(t.value)),!this.head.push(t)){let e=this.head;this.head=e.next=new so(2*this.head.buffer.length),this.head.push(t)}}shift(){let t=this.tail.shift();if(t===void 0&&this.tail.next!=null){let e=this.tail.next;this.tail.next=null,this.tail=e,t=this.tail.shift()}return t?.value!=null&&(this.size-=this.calculateSize(t.value)),t}isEmpty(){return this.head.isEmpty()}};var Es=class extends Error{type;code;constructor(t,e){super(t??"The operation was aborted"),this.type="aborted",this.code=e??"ABORT_ERR"}};function lr(r={}){return rd(e=>{let n=e.shift();if(n==null)return{done:!0};if(n.error!=null)throw n.error;return{done:n.done===!0,value:n.value}},r)}function rd(r,t){t=t??{};let e=t.onEnd,n=new ur,o,i,s,a=Zt(),c=async()=>{try{return n.isEmpty()?s?{done:!0}:await new Promise((h,w)=>{i=v=>{i=null,n.push(v);try{h(r(n))}catch(m){w(m)}return o}}):r(n)}finally{n.isEmpty()&&queueMicrotask(()=>{a.resolve(),a=Zt()})}},l=h=>i!=null?i(h):(n.push(h),o),u=h=>(n=new ur,i!=null?i({error:h}):(n.push({error:h}),o)),f=h=>{if(s)return o;if(t?.objectMode!==!0&&h?.byteLength==null)throw new Error("objectMode was not true but tried to push non-Uint8Array value");return l({done:!1,value:h})},d=h=>s?o:(s=!0,h!=null?u(h):l({done:!0})),g=()=>(n=new ur,d(),{done:!0}),y=h=>(d(h),{done:!0});if(o={[Symbol.asyncIterator](){return this},next:c,return:g,throw:y,push:f,end:d,get readableLength(){return n.size},onEmpty:async h=>{let w=h?.signal;if(w?.throwIfAborted(),n.isEmpty())return;let v,m;w!=null&&(v=new Promise((_,B)=>{m=()=>{B(new Es)},w.addEventListener("abort",m)}));try{await Promise.race([a.promise,v])}finally{m!=null&&w!=null&&w?.removeEventListener("abort",m)}}},e==null)return o;let b=o;return o={[Symbol.asyncIterator](){return this},next(){return b.next()},throw(h){return b.throw(h),e!=null&&(e(h),e=void 0),{done:!0}},return(){return b.return(),e!=null&&(e(),e=void 0),{done:!0}},push:f,end(h){return b.end(h),e!=null&&(e(h),e=void 0),o},get readableLength(){return b.readableLength},onEmpty:h=>b.onEmpty(h)},o}function nd(r){return r[Symbol.asyncIterator]!=null}function od(...r){let t=[];for(let e of r)nd(e)||t.push(e);return t.length===r.length?function*(){for(let e of t)yield*e}():async function*(){let e=lr({objectMode:!0});Promise.resolve().then(async()=>{try{await Promise.all(r.map(async n=>{for await(let o of n)e.push(o)})),e.end()}catch(n){e.end(n)}}),yield*e}()}var ou=od;function iu(r,...t){if(r==null)throw new Error("Empty pipeline");if(vs(r)){let n=r;r=()=>n.source}else if(au(r)||su(r)){let n=r;r=()=>n}let e=[r,...t];if(e.length>1&&vs(e[e.length-1])&&(e[e.length-1]=e[e.length-1].sink),e.length>2)for(let n=1;n<e.length-1;n++)vs(e[n])&&(e[n]=sd(e[n]));return id(...e)}var id=(...r)=>{let t;for(;r.length>0;)t=r.shift()(t);return t},su=r=>r?.[Symbol.asyncIterator]!=null,au=r=>r?.[Symbol.iterator]!=null,vs=r=>r==null?!1:r.sink!=null&&r.source!=null,sd=r=>t=>{let e=r.sink(t);if(e?.then!=null){let n=lr({objectMode:!0});e.then(()=>{n.end()},s=>{n.end(s)});let o,i=r.source;if(su(i))o=async function*(){yield*i,n.end()};else if(au(i))o=function*(){yield*i,n.end()};else throw new Error("Unknown duplex source type - must be Iterable or AsyncIterable");return ou(n,o())}return r.source};function Ss(r){let{stream:t,remoteAddr:e,logger:n,onDataRead:o,onDataWrite:i}=r,s=n.forComponent("libp2p:stream:converter"),a=!1,c=!1,l=t.close.bind(t);t.close=async y=>{await l(y),g(!0)};let u=t.abort.bind(t);t.abort=y=>{u(y),g(!0)};let f=t.sink.bind(t);t.sink=async y=>{try{await f(iu(y,b=>nu(b,h=>i?.(h))))}catch(b){b.type!=="aborted"&&s.error("%s error in sink",e,b)}finally{c=!0,g()}};let d={log:s,sink:t.sink,source:async function*(){try{for await(let y of t.source)o?.(y),yield y}finally{a=!0,g()}}(),remoteAddr:e,timeline:{open:Date.now(),close:void 0},close:t.close,abort:t.abort};function g(y){y===!0&&(a=!0,c=!0),a&&c&&d.timeline.close==null&&(d.timeline.close=Date.now())}return d}var _e=class extends Event{type;detail;constructor(t,e){super(t),this.type=t,this.detail=e}};var As=class extends Error{type;code;constructor(t,e){super(t??"The operation was aborted"),this.type="aborted",this.name="AbortError",this.code=e??"ABORT_ERR"}};async function ao(r,t,e,n){let o=new As(n?.errorMessage,n?.errorCode);return e?.aborted===!0?Promise.reject(o):new Promise((i,s)=>{function a(){e?.removeEventListener("abort",u),r.removeEventListener(t,c),n?.errorEvent!=null&&r.removeEventListener(n.errorEvent,l)}let c=f=>{try{if(n?.filter?.(f)===!1)return}catch(d){a(),s(d);return}a(),i(f)},l=f=>{a(),s(f.detail)},u=()=>{a(),s(o)};e?.addEventListener("abort",u),r.addEventListener(t,c),n?.errorEvent!=null&&r.addEventListener(n.errorEvent,l)})}var co=class extends Error{static name="QueueFullError";constructor(t="The queue was full"){super(t),this.name="QueueFullError"}};var uo=class{deferred;signal;constructor(t){this.signal=t,this.deferred=Zt(),this.onAbort=this.onAbort.bind(this),this.signal?.addEventListener("abort",this.onAbort)}onAbort(){this.deferred.reject(this.signal?.reason??new Jt)}cleanup(){this.signal?.removeEventListener("abort",this.onAbort)}};function ad(){return`${parseInt(String(Math.random()*1e9),10).toString()}${Date.now()}`}var lo=class{id;fn;options;recipients;status;timeline;controller;constructor(t,e){this.id=ad(),this.status="queued",this.fn=t,this.options=e,this.recipients=[],this.timeline={created:Date.now()},this.controller=new AbortController,this.controller.signal,this.onAbort=this.onAbort.bind(this)}abort(t){this.controller.abort(t)}onAbort(){this.recipients.reduce((e,n)=>e&&n.signal?.aborted===!0,!0)&&(this.controller.abort(new Jt),this.cleanup())}async join(t={}){let e=new uo(t.signal);return this.recipients.push(e),t.signal?.addEventListener("abort",this.onAbort),e.deferred.promise}async run(){this.status="running",this.timeline.started=Date.now();try{this.controller.signal.throwIfAborted();let t=await Pn(this.fn({...this.options??{},signal:this.controller.signal}),this.controller.signal);this.recipients.forEach(e=>{e.deferred.resolve(t)}),this.status="complete"}catch(t){this.recipients.forEach(e=>{e.deferred.reject(t)}),this.status="errored"}finally{this.timeline.finished=Date.now(),this.cleanup()}}cleanup(){this.recipients.forEach(t=>{t.cleanup(),t.signal?.removeEventListener("abort",this.onAbort)})}};var fo=class extends Ot{concurrency;maxSize;queue;pending;sort;constructor(t={}){super(),this.concurrency=t.concurrency??Number.POSITIVE_INFINITY,this.maxSize=t.maxSize??Number.POSITIVE_INFINITY,this.pending=0,t.metricName!=null&&t.metrics?.registerMetricGroup(t.metricName,{calculate:()=>({size:this.queue.length,running:this.pending,queued:this.queue.length-this.pending})}),this.sort=t.sort,this.queue=[]}tryToStartAnother(){if(this.size===0)return queueMicrotask(()=>{this.safeDispatchEvent("empty")}),this.running===0&&queueMicrotask(()=>{this.safeDispatchEvent("idle")}),!1;if(this.pending<this.concurrency){let t;for(let e of this.queue)if(e.status==="queued"){t=e;break}return t==null?!1:(this.safeDispatchEvent("active"),this.pending++,t.run().finally(()=>{for(let e=0;e<this.queue.length;e++)if(this.queue[e]===t){this.queue.splice(e,1);break}this.pending--,this.tryToStartAnother(),this.safeDispatchEvent("next")}),!0)}return!1}enqueue(t){this.queue.push(t),this.sort!=null&&this.queue.sort(this.sort)}async add(t,e){if(e?.signal?.throwIfAborted(),this.size===this.maxSize)throw new co;let n=new lo(t,e);return this.enqueue(n),this.safeDispatchEvent("add"),this.tryToStartAnother(),n.join(e).then(o=>(this.safeDispatchEvent("completed",{detail:o}),this.safeDispatchEvent("success",{detail:{job:n,result:o}}),o)).catch(o=>{if(n.status==="queued"){for(let i=0;i<this.queue.length;i++)if(this.queue[i]===n){this.queue.splice(i,1);break}}throw this.safeDispatchEvent("error",{detail:o}),this.safeDispatchEvent("failure",{detail:{job:n,error:o}}),o})}clear(){this.queue.splice(0,this.queue.length)}abort(){this.queue.forEach(t=>{t.abort(new Jt)}),this.clear()}async onEmpty(t){this.size!==0&&await ao(this,"empty",t?.signal)}async onSizeLessThan(t,e){this.size<t||await ao(this,"next",e?.signal,{filter:()=>this.size<t})}async onIdle(t){this.pending===0&&this.size===0||await ao(this,"idle",t?.signal)}get size(){return this.queue.length}get queued(){return this.queue.length-this.pending}get running(){return this.pending}async*toGenerator(t){t?.signal?.throwIfAborted();let e=lr({objectMode:!0}),n=c=>{c!=null?this.abort():this.clear(),e.end(c)},o=c=>{c.detail!=null&&e.push(c.detail)},i=c=>{n(c.detail)},s=()=>{n()},a=()=>{n(new Jt("Queue aborted"))};this.addEventListener("completed",o),this.addEventListener("error",i),this.addEventListener("idle",s),t?.signal?.addEventListener("abort",a);try{yield*e}finally{this.removeEventListener("completed",o),this.removeEventListener("error",i),this.removeEventListener("idle",s),t?.signal?.removeEventListener("abort",a),n()}}};var fr=class extends fo{has(t){return this.find(t)!=null}find(t){return this.queue.find(e=>t.equals(e.options.peerId))}};var ho=class extends Ot{peerStore;registrar;connectionManager;randomWalk;started;running;topologyId;log;discoveryController;filter;queue;constructor(t,e={}){super(),this.log=t.logger.forComponent("libp2p:circuit-relay:discover-relays"),this.started=!1,this.running=!1,this.peerStore=t.peerStore,this.registrar=t.registrar,this.connectionManager=t.connectionManager,this.randomWalk=t.randomWalk,this.filter=e.filter,this.discoveryController=new AbortController,this.discoveryController.signal}isStarted(){return this.started}async start(){this.topologyId=await this.registrar.register(qt,{filter:this.filter,onConnect:t=>{this.log.trace("discovered relay %p queue (length: %d, active %d)",t,this.queue?.size,this.queue?.running),this.safeDispatchEvent("relay:discover",{detail:t})}}),this.started=!0}stop(){this.topologyId!=null&&this.registrar.unregister(this.topologyId),this.discoveryController?.abort(),this.started=!1}startDiscovery(){this.running||(this.log("start discovery"),this.running=!0,this.discoveryController=new AbortController,this.discoveryController.signal,Promise.resolve().then(async()=>{this.log("searching peer store for relays");let t=await this.peerStore.all({filters:[n=>n.protocols.includes(qt)],orders:[()=>Math.random()<.5?1:-1,(n,o)=>{let i=cu(n),s=cu(o);return i>s?-1:s>i?1:0}]});for(let n of t)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",t.length);let e=this.queue=new fr({concurrency:5});this.log("start random walk");for await(let n of this.randomWalk.walk({signal:this.discoveryController.signal})){if(this.log.trace("found random peer %p",n.id),e.has(n.id)){this.log.trace("random peer %p was already in queue",n.id);continue}if(this.connectionManager.getConnections(n.id)?.length>0){this.log.trace("random peer %p was already connected",n.id);continue}if(!await this.connectionManager.isDialable(n.multiaddrs)){this.log.trace("random peer %p was not dialable",n.id,n.multiaddrs.map(o=>o.toString()));continue}e.queued>10&&(this.log.trace("wait for space in queue for %p",n.id),await e.onSizeLessThan(10,{signal:this.discoveryController.signal})),this.log("adding random peer %p to dial queue (length: %d, active %d)",n.id,e.size,e.running),e.add(async()=>{let o=$n([this.discoveryController.signal,AbortSignal.timeout(5e3)]);try{await this.connectionManager.openConnection(n.id,{signal:o})}finally{o.clear()}},{peerId:n.id,signal:this.discoveryController.signal}).catch(o=>{this.log.error("error opening connection to random peer %p",n.id,o)})}this.log("stop random walk"),await e.onIdle()}).catch(t=>{this.discoveryController.signal.aborted||this.log.error("failed when finding relays on the network",t)}))}stopDiscovery(){this.log("stop discovery"),this.running=!1,this.discoveryController?.abort()}};function cu(r){let t=r.metadata.get("last-dial-success");return t==null?0:new Date(H(t)).getTime()}var _s=class extends Ot{connectionManager;addressManager;reservationStore;listeningAddrs;log;listenTimeout;reservationId;relay;constructor(t,e={}){super(),this.log=t.logger.forComponent("libp2p:circuit-relay:transport:listener"),this.connectionManager=t.connectionManager,this.addressManager=t.addressManager,this.reservationStore=t.reservationStore,this.listeningAddrs=[],this.listenTimeout=e.listenTimeout??Kn,this.reservationStore.addEventListener("relay:removed",this._onRemoveRelayPeer),this.reservationStore.addEventListener("relay:created-reservation",this._onAddRelayPeer)}_onRemoveRelayPeer=t=>{this.log("relay removed %p our relay %p",t.detail.relay,this.relay,this.relay?.equals(t.detail.relay)),this.relay?.equals(t.detail.relay)===!0&&(this.log("relay peer removed %p",t.detail.relay),this.listeningAddrs.forEach(e=>{this.addressManager.removeObservedAddr(e)}),this.listeningAddrs=[],this.safeDispatchEvent("listening"))};_onAddRelayPeer=t=>{let{details:e}=t.detail;e.type!=="configured"&&e.id===this.reservationId&&this.addedRelay(t.detail)};async listen(t){if(Jn.exactMatch(t))this.log("searching for circuit relay servers"),this.reservationId=this.reservationStore.reserveRelay();else if(jn.exactMatch(t)){this.log("listen on specific relay server %a",t);let e=AbortSignal.timeout(this.listenTimeout);let n=t.decapsulate("/p2p-circuit"),o=await this.connectionManager.openConnection(n,{signal:e});if(!this.reservationStore.hasReservation(o.remotePeer)){this.log("making reservation on peer %p",o.remotePeer);let i=await this.reservationStore.addRelay(o.remotePeer,"configured");this.addedRelay(i)}}else throw new Ie(`Could not listen on p2p-circuit address "${t}"`)}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(t){this.log("relay peer added %p",t.relay),this.relay=t.relay,this.listeningAddrs=t.details.reservation.addrs.map(e=>vt(e).encapsulate("/p2p-circuit")),this.listeningAddrs.forEach(e=>{this.addressManager.confirmObservedAddr(e,{type:"transport"})}),queueMicrotask(()=>{this.safeDispatchEvent("listening")})}};function uu(r){return new _s(r)}var lu="useandom-26T198340PX75pxJACKVERYMINDBUSHWOLF_GQZbfghjklqvwyzrict";var fu=(r=21)=>{let t="",e=crypto.getRandomValues(new Uint8Array(r|=0));for(;r--;)t+=lu[e[r]&63];return t};var cd=60*1e3*10,ud=60*1e3*5,ld=30*1e3,po=class extends Ot{peerId;connectionManager;peerStore;events;reserveQueue;reservations;pendingReservations;maxReservationQueueLength;reservationCompletionTimeout;started;log;relayFilter;constructor(t,e){super(),this.log=t.logger.forComponent("libp2p:circuit-relay:transport:reservation-store"),this.peerId=t.peerId,this.connectionManager=t.connectionManager,this.peerStore=t.peerStore,this.events=t.events,this.reservations=new Ae,this.pendingReservations=[],this.maxReservationQueueLength=e?.maxReservationQueueLength??Nc,this.reservationCompletionTimeout=e?.reservationCompletionTimeout??Kn,this.started=!1,this.relayFilter=cr(100),this.reserveQueue=new fr({concurrency:e?.reservationConcurrency??Pc,metricName:"libp2p_relay_reservation_queue",metrics:t.metrics}),this.events.addEventListener("connection:close",n=>{[...this.reservations.values()].find(i=>i.connection===n.detail.id)!=null&&this.#e(n.detail.remotePeer).catch(i=>{this.log("could not remove relay %p - %e",n.detail,i)})})}isStarted(){return this.started}start(){this.started=!0}afterStart(){Promise.resolve().then(async()=>{let t=await this.peerStore.all({filters:[e=>e.tags.has(Nr)]});this.log("removing tag from %d old relays",t.length),await Promise.all(t.map(async e=>{await this.peerStore.merge(e.id,{tags:{[Nr]:void 0}})})),this.log("redialing %d old relays",t.length),await Promise.all(t.map(async e=>this.addRelay(e.id,"discovered"))),this.#r()}).catch(t=>{this.log.error(t)})}stop(){this.reserveQueue.clear(),this.reservations.forEach(({timeout:t})=>{clearTimeout(t)}),this.reservations.clear(),this.started=!1}reserveRelay(){let t=fu();return this.pendingReservations.push(t),this.#r(),t}async addRelay(t,e){if(this.peerId.equals(t))throw this.log.trace("not trying to use self as relay"),new Ie("Cannot use self as relay");if(this.reserveQueue.size>this.maxReservationQueueLength)throw new Qn("The reservation queue is full");let n=this.reserveQueue.find(t);if(n!=null)return this.log.trace("potential relay peer %p is already in the reservation queue",t),n.join();if(this.relayFilter.has(t.toMultihash().bytes))throw new Ie("The relay was previously invalid");return this.log.trace("try to reserve relay slot with %p",t),this.reserveQueue.add(async()=>{let o=Date.now();try{let i=this.reservations.get(t);if(i!=null){let y=this.connectionManager.getConnections(t),b=!1;if(y.length===0&&this.log("already have relay reservation with %p but we are no longer connected",t),y.map(h=>h.id).includes(i.connection)&&(this.log("already have relay reservation with %p and the original connection is still open",t),b=!0),b&&hs(i.reservation.expire)>cd)return this.log("already have relay reservation with %p but we are still connected and it does not expire soon",t),{relay:t,details:i};await this.#e(t)}if(e==="discovered"&&this.pendingReservations.length===0)throw new qr("Not making reservation on discovered relay because we do not need any more relays");let s=AbortSignal.timeout(this.reservationCompletionTimeout);let a=await this.connectionManager.openConnection(t,{signal:s});if(Wn.matches(a.remoteAddr))throw new Xn("not creating reservation over relayed connection");let c=await this.#t(a,{signal:s}),l=hs(c.expire);this.log("created reservation on relay peer %p, expiry date is %s",t,new Date(Date.now()+l).toString());let u=Math.min(Math.max(l-ud,ld),Math.pow(2,31)-1),f=setTimeout(()=>{this.log("refresh reservation to relay %p",t),this.addRelay(t,e).catch(async y=>{this.log.error("could not refresh reservation to relay %p - %e",t,y),await this.#e(t)}).catch(y=>{this.log.error("could not remove expired reservation to relay %p - %e",t,y)})},u),d;if(e==="discovered"){let y=this.pendingReservations.pop();if(y==null)throw new qr("Made reservation on relay but did not need any more discovered relays");d={timeout:f,reservation:c,type:e,connection:a.id,id:y}}else d={timeout:f,reservation:c,type:e,connection:a.id};this.reservations.set(t,d),await this.peerStore.merge(t,{tags:{[Nr]:{value:1,ttl:l}}}),this.#r();let g={relay:t,details:d};return this.safeDispatchEvent("relay:created-reservation",{detail:g}),g}catch(i){throw e==="discovered"&&i.name==="HadEnoughRelaysError"||this.log.error("could not reserve slot on %p after %dms - %e",t,Date.now()-o,i),(i.name==="DialError"||i.name==="UnsupportedProtocolError")&&this.relayFilter.add(t.toMultihash().bytes),this.#e(t).catch(s=>{this.log.error("could not remove reservation on %p after reserving slot failed - %e",t,s)}),i}},{peerId:t})}hasReservation(t){return this.reservations.has(t)}getReservation(t){return this.reservations.get(t)?.reservation}reservationCount(t){return t==null?this.reservations.size:[...this.reservations.values()].reduce((e,n)=>(n.type===t&&e++,e),0)}cancelReservations(){[...this.reservations.values()].forEach(t=>{clearTimeout(t.timeout)}),this.reservations.clear()}async#t(t,e){e.signal?.throwIfAborted(),this.log("requesting reservation from %p",t.remotePeer);let n=await t.newStream(qt,e),i=Se(n).pb($);this.log.trace("send RESERVE to %p",t.remotePeer),await i.write({type:$.Type.RESERVE},e);let s;try{this.log.trace("reading response from %p",t.remotePeer),s=await i.read(e)}catch(c){throw n.abort(c),c}finally{n.status!=="closed"&&await n.close(e)}if(this.log.trace("read response %o",s),s.status===k.OK&&s.reservation!=null){let c=new Set;c.add(t.remoteAddr.toString());for(let l of s.reservation.addrs){let u=vt(l);u.getPeerId()==null&&(u=u.encapsulate(`/p2p/${t.remotePeer}`)),u=vt(u.toString().replace(`/p2p/${t.remotePeer}/p2p/${t.remotePeer}`,`/p2p/${t.remotePeer}`)),c.add(u.toString())}return s.reservation.addrs=[...c].map(l=>vt(l).bytes),s.reservation}let a=`reservation failed with status ${s.status??"undefined"}`;throw this.log.error(a),new Error(a)}async#e(t){let e=this.reservations.get(t);e!=null&&(this.log("removing relay reservation with %p from local store",t),clearTimeout(e.timeout),this.reservations.delete(t),e.type==="discovered"&&this.pendingReservations.push(e.id),await this.peerStore.merge(t,{tags:{[Nr]:void 0}}),this.safeDispatchEvent("relay:removed",{detail:{relay:t,details:e}}),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=cr(100),this.log("not discovered enough relays %d/%d",this.reservations.size,this.pendingReservations.length),this.safeDispatchEvent("relay:not-enough-relays")}};var fd=r=>{if(r.peer==null)return!1;try{r.peer.addrs.forEach(vt)}catch{return!1}return!0},hu={maxInboundStopStreams:Ur,maxOutboundStopStreams:Ur,stopTimeout:3e4},mo=class{discovery;registrar;peerStore;connectionManager;transportManager;peerId;upgrader;addressManager;connectionGater;reservationStore;logger;maxInboundStopStreams;maxOutboundStopStreams;started;log;shutdownController;constructor(t,e={}){this.log=t.logger.forComponent("libp2p:circuit-relay:transport"),this.registrar=t.registrar,this.peerStore=t.peerStore,this.connectionManager=t.connectionManager,this.transportManager=t.transportManager,this.logger=t.logger,this.peerId=t.peerId,this.upgrader=t.upgrader,this.addressManager=t.addressManager,this.connectionGater=t.connectionGater,this.maxInboundStopStreams=e.maxInboundStopStreams??hu.maxInboundStopStreams,this.maxOutboundStopStreams=e.maxOutboundStopStreams??hu.maxOutboundStopStreams,this.shutdownController=new AbortController,this.discovery=new ho(t,{filter:e.discoveryFilter??ys(kc,Kc)}),this.discovery.addEventListener("relay:discover",n=>{this.reservationStore.addRelay(n.detail,"discovered").catch(o=>{o.name!=="HadEnoughRelaysError"&&o.name!=="RelayQueueFullError"&&this.log.error("could not add discovered relay %p",n.detail,o)})}),this.reservationStore=new po(t,e),this.reservationStore.addEventListener("relay:not-enough-relays",()=>{this.discovery?.startDiscovery()}),this.reservationStore.addEventListener("relay:found-enough-relays",()=>{this.discovery?.stopDiscovery()}),this.started=!1}[Symbol.toStringTag]="@libp2p/circuit-relay-v2-transport";[ks]=["@libp2p/transport","@libp2p/circuit-relay-v2-transport"];get[Ks](){return this.discovery!=null?["@libp2p/identify"]:[]}[Ns]=!0;isStarted(){return this.started}async start(){this.shutdownController=new AbortController,await this.registrar.handle(Me,t=>{let e=this.upgrader.createInboundAbortSignal(this.shutdownController.signal);this.onStop(t,e).catch(n=>{this.log.error("error while handling STOP protocol",n),t.stream.abort(n)}).finally(()=>{e.clear()})},{maxInboundStreams:this.maxInboundStopStreams,maxOutboundStreams:this.maxOutboundStopStreams,runOnLimitedConnection:!0}),await Os(this.discovery,this.reservationStore),this.started=!0}async stop(){this.shutdownController.abort(),await Ms(this.discovery,this.reservationStore),await this.registrar.unhandle(Me),this.started=!1}async dial(t,e){if(t.protoCodes().filter(g=>g===kn).length!==1){let g="Invalid circuit relay address";throw this.log.error(g,t),new dr(g)}let n=t.toString().split("/p2p-circuit"),o=vt(n[0]),i=vt(n[n.length-1]),s=o.getPeerId(),a=i.getPeerId();if(s==null||a==null){let g=`ircuit relay dial to ${t.toString()} failed as address did not have both relay and destination PeerIDs`;throw this.log.error(`c${g}`),new dr(`C${g}`)}let c=Ki(s),l=Ki(a),f=this.connectionManager.getConnections(c)[0];f==null?(await this.peerStore.merge(c,{multiaddrs:[o]}),e.onProgress?.(new _e("circuit-relay:open-connection")),f=await this.connectionManager.openConnection(c,e)):e.onProgress?.(new _e("circuit-relay:reuse-connection"));let d;try{e.onProgress?.(new _e("circuit-relay:open-hop-stream")),d=await f.newStream(qt,e);let g=Se(d),y=g.pb($);e.onProgress?.(new _e("circuit-relay:write-connect-message")),await y.write({type:$.Type.CONNECT,peer:{id:l.toMultihash().bytes,addrs:[vt(i).bytes]}},e),e.onProgress?.(new _e("circuit-relay:read-connect-response"));let b=await y.read(e);if(b.status!==k.OK)throw new Gr(`failed to connect via relay with status ${b?.status?.toString()??"undefined"}`);let h=new Fr(b.limit),w=Ss({stream:g.unwrap(),remoteAddr:t,localAddr:o.encapsulate(`/p2p-circuit/p2p/${this.peerId.toString()}`),logger:this.logger,onDataRead:h.onData,onDataWrite:h.onData});return this.log("new outbound relayed connection %a",w.remoteAddr),await this.upgrader.upgradeOutbound(w,{...e,limits:h.getLimits()})}catch(g){throw this.log.error("circuit relay dial to destination %p via relay %p failed",l,c,g),d?.abort(g),g}}createListener(t){return uu({peerId:this.peerId,connectionManager:this.connectionManager,addressManager:this.addressManager,reservationStore:this.reservationStore,logger:this.logger})}listenFilter(t){return t=Array.isArray(t)?t:[t],t.filter(e=>jn.exactMatch(e)||Jn.exactMatch(e))}dialFilter(t){return t=Array.isArray(t)?t:[t],t.filter(e=>Wn.exactMatch(e))}async onStop({connection:t,stream:e},n){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.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",f)}let o=Se(e).pb(Ut),i=await o.read({signal:n});if(this.log("new circuit relay v2 stop stream from %p with type %s",t.remotePeer,i.type),i?.type===void 0){this.log.error("type was missing from circuit v2 stop protocol request from %s",t.remotePeer),await o.write({type:Ut.Type.STATUS,status:k.MALFORMED_MESSAGE},{signal:n}),await e.close();return}if(i.type!==Ut.Type.CONNECT){this.log.error("invalid stop connect request via peer %p",t.remotePeer),await o.write({type:Ut.Type.STATUS,status:k.UNEXPECTED_MESSAGE},{signal:n}),await e.close();return}if(!fd(i)){this.log.error("invalid stop connect request via peer %p",t.remotePeer),await o.write({type:Ut.Type.STATUS,status:k.MALFORMED_MESSAGE},{signal:n}),await e.close({signal:n});return}let s=Cr(Mt(i.peer.id));if(await this.connectionGater.denyInboundRelayedConnection?.(t.remotePeer,s)===!0){this.log.error("connection gater denied inbound relayed connection from %p",t.remotePeer),await o.write({type:Ut.Type.STATUS,status:k.PERMISSION_DENIED},{signal:n}),await e.close({signal:n});return}this.log.trace("sending success response to %p",t.remotePeer),await o.write({type:Ut.Type.STATUS,status:k.OK},{signal:n});let a=new Fr(i.limit),c=t.remoteAddr.encapsulate(`/p2p-circuit/p2p/${s.toString()}`),l=this.addressManager.getAddresses()[0],u=Ss({stream:o.unwrap().unwrap(),remoteAddr:c,localAddr:l,logger:this.logger,onDataRead:a.onData,onDataWrite:a.onData});this.log("new inbound relayed connection %a",u.remoteAddr),await this.upgrader.upgradeInbound(u,{limits:a.getLimits(),signal:n}),this.log("%s connection %a upgraded","inbound",u.remoteAddr)}};function du(r={}){return t=>new mo(t,r)}return Iu(hd);})();
|
2
|
+
"use strict";var Libp2PCircuitRelayV2=(()=>{var go=Object.defineProperty;var vu=Object.getOwnPropertyDescriptor;var Su=Object.getOwnPropertyNames;var Au=Object.prototype.hasOwnProperty;var _t=(r,t)=>{for(var e in t)go(r,e,{get:t[e],enumerable:!0})},_u=(r,t,e,n)=>{if(t&&typeof t=="object"||typeof t=="function")for(let o of Su(t))!Au.call(r,o)&&o!==e&&go(r,o,{get:()=>t[o],enumerable:!(n=vu(t,o))||n.enumerable});return r};var Iu=r=>_u(go({},"__esModule",{value:!0}),r);var md={};_t(md,{RELAY_V2_HOP_CODEC:()=>qt,RELAY_V2_STOP_CODEC:()=>Me,circuitRelayServer:()=>tu,circuitRelayTransport:()=>du});var bo=Symbol.for("@libp2p/peer-id");var xo="keep-alive";var Ns=Symbol.for("@libp2p/transport");var Ps;(function(r){r[r.FATAL_ALL=0]="FATAL_ALL",r[r.NO_FATAL=1]="NO_FATAL"})(Ps||(Ps={}));var Jt=class extends Error{static name="AbortError";constructor(t="The operation was aborted"){super(t),this.name="AbortError"}};var bt=class extends Error{static name="InvalidParametersError";constructor(t="Invalid parameters"){super(t),this.name="InvalidParametersError"}},Fe=class extends Error{static name="InvalidPublicKeyError";constructor(t="Invalid public key"){super(t),this.name="InvalidPublicKeyError"}};var Hr=class extends Error{static name="InvalidMultihashError";constructor(t="Invalid Multihash"){super(t),this.name="InvalidMultihashError"}};var Gr=class extends Error{static name="InvalidMessageError";constructor(t="Invalid message"){super(t),this.name="InvalidMessageError"}};var dr=class extends Error{static name="DialError";constructor(t="Dial error"){super(t),this.name="DialError"}},Ie=class extends Error{static name="ListenError";constructor(t="Listen error"){super(t),this.name="ListenError"}};var ze=class extends Error{static name="UnsupportedKeyTypeError";constructor(t="Unsupported key type"){super(t),this.name="UnsupportedKeyTypeError"}};var Ot=class extends EventTarget{#t=new Map;constructor(){super()}listenerCount(t){let e=this.#t.get(t);return e==null?0:e.length}addEventListener(t,e,n){super.addEventListener(t,e,n);let o=this.#t.get(t);o==null&&(o=[],this.#t.set(t,o)),o.push({callback:e,once:(n!==!0&&n!==!1&&n?.once)??!1})}removeEventListener(t,e,n){super.removeEventListener(t.toString(),e??null,n);let o=this.#t.get(t);o!=null&&(o=o.filter(({callback:i})=>i!==e),this.#t.set(t,o))}dispatchEvent(t){let e=super.dispatchEvent(t),n=this.#t.get(t.type);return n==null||(n=n.filter(({once:o})=>!o),this.#t.set(t.type,n)),e}safeDispatchEvent(t,e={}){return this.dispatchEvent(new CustomEvent(t,e))}};function Us(r){return r!=null&&typeof r.start=="function"&&typeof r.stop=="function"}async function Os(...r){let t=[];for(let e of r)Us(e)&&t.push(e);await Promise.all(t.map(async e=>{e.beforeStart!=null&&await e.beforeStart()})),await Promise.all(t.map(async e=>{await e.start()})),await Promise.all(t.map(async e=>{e.afterStart!=null&&await e.afterStart()}))}async function Ms(...r){let t=[];for(let e of r)Us(e)&&t.push(e);await Promise.all(t.map(async e=>{e.beforeStop!=null&&await e.beforeStop()})),await Promise.all(t.map(async e=>{await e.stop()})),await Promise.all(t.map(async e=>{e.afterStop!=null&&await e.afterStop()}))}var ks=Symbol.for("@libp2p/service-capabilities"),Ks=Symbol.for("@libp2p/service-dependencies");var Ao={};_t(Ao,{base58btc:()=>Q,base58flickr:()=>Du});var Gd=new Uint8Array(0);function qs(r,t){if(r===t)return!0;if(r.byteLength!==t.byteLength)return!1;for(let e=0;e<r.byteLength;e++)if(r[e]!==t[e])return!1;return!0}function te(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 Fs(r){return new TextEncoder().encode(r)}function zs(r){return new TextDecoder().decode(r)}function Tu(r,t){if(r.length>=255)throw new TypeError("Alphabet too long");for(var e=new Uint8Array(256),n=0;n<e.length;n++)e[n]=255;for(var o=0;o<r.length;o++){var i=r.charAt(o),s=i.charCodeAt(0);if(e[s]!==255)throw new TypeError(i+" is ambiguous");e[s]=o}var a=r.length,c=r.charAt(0),l=Math.log(a)/Math.log(256),u=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 b=0,h=0,w=0,v=y.length;w!==v&&y[w]===0;)w++,b++;for(var m=(v-w)*u+1>>>0,_=new Uint8Array(m);w!==v;){for(var B=y[w],C=0,I=m-1;(B!==0||C<h)&&I!==-1;I--,C++)B+=256*_[I]>>>0,_[I]=B%a>>>0,B=B/a>>>0;if(B!==0)throw new Error("Non-zero carry");h=C,w++}for(var R=m-h;R!==m&&_[R]===0;)R++;for(var T=c.repeat(b);R<m;++R)T+=r.charAt(_[R]);return T}function d(y){if(typeof y!="string")throw new TypeError("Expected String");if(y.length===0)return new Uint8Array;var b=0;if(y[b]!==" "){for(var h=0,w=0;y[b]===c;)h++,b++;for(var v=(y.length-b)*l+1>>>0,m=new Uint8Array(v);y[b];){var _=e[y.charCodeAt(b)];if(_===255)return;for(var B=0,C=v-1;(_!==0||B<w)&&C!==-1;C--,B++)_+=a*m[C]>>>0,m[C]=_%256>>>0,_=_/256>>>0;if(_!==0)throw new Error("Non-zero carry");w=B,b++}if(y[b]!==" "){for(var I=v-w;I!==v&&m[I]===0;)I++;for(var R=new Uint8Array(h+(v-I)),T=h;I!==v;)R[T++]=m[I++];return R}}}function g(y){var b=d(y);if(b)return b;throw new Error(`Non-${t} character`)}return{encode:f,decodeUnsafe:d,decode:g}}var Lu=Tu,Ru=Lu,Hs=Ru;var wo=class{name;prefix;baseEncode;constructor(t,e,n){this.name=t,this.prefix=e,this.baseEncode=n}encode(t){if(t instanceof Uint8Array)return`${this.prefix}${this.baseEncode(t)}`;throw Error("Unknown type, must be binary type")}},Eo=class{name;prefix;baseDecode;prefixCodePoint;constructor(t,e,n){this.name=t,this.prefix=e;let o=e.codePointAt(0);if(o===void 0)throw new Error("Invalid prefix character");this.prefixCodePoint=o,this.baseDecode=n}decode(t){if(typeof t=="string"){if(t.codePointAt(0)!==this.prefixCodePoint)throw Error(`Unable to decode multibase string ${JSON.stringify(t)}, ${this.name} decoder only supports inputs prefixed with ${this.prefix}`);return this.baseDecode(t.slice(this.prefix.length))}else throw Error("Can only multibase decode strings")}or(t){return Gs(this,t)}},vo=class{decoders;constructor(t){this.decoders=t}or(t){return Gs(this,t)}decode(t){let e=t[0],n=this.decoders[e];if(n!=null)return n.decode(t);throw RangeError(`Unable to decode multibase string ${JSON.stringify(t)}, only inputs prefixed with ${Object.keys(this.decoders)} are supported`)}};function Gs(r,t){return new vo({...r.decoders??{[r.prefix]:r},...t.decoders??{[t.prefix]:t}})}var So=class{name;prefix;baseEncode;baseDecode;encoder;decoder;constructor(t,e,n,o){this.name=t,this.prefix=e,this.baseEncode=n,this.baseDecode=o,this.encoder=new wo(t,e,n),this.decoder=new Eo(t,e,o)}encode(t){return this.encoder.encode(t)}decode(t){return this.decoder.decode(t)}};function Ve({name:r,prefix:t,encode:e,decode:n}){return new So(r,t,e,n)}function fe({name:r,prefix:t,alphabet:e}){let{encode:n,decode:o}=Hs(e,r);return Ve({prefix:t,name:r,encode:n,decode:i=>te(o(i))})}function Bu(r,t,e,n){let o={};for(let u=0;u<t.length;++u)o[t[u]]=u;let i=r.length;for(;r[i-1]==="=";)--i;let s=new Uint8Array(i*e/8|0),a=0,c=0,l=0;for(let u=0;u<i;++u){let f=o[r[u]];if(f===void 0)throw new SyntaxError(`Non-${n} character`);c=c<<e|f,a+=e,a>=8&&(a-=8,s[l++]=255&c>>a)}if(a>=e||(255&c<<8-a)!==0)throw new SyntaxError("Unexpected end of data");return s}function Cu(r,t,e){let n=t[t.length-1]==="=",o=(1<<e)-1,i="",s=0,a=0;for(let c=0;c<r.length;++c)for(a=a<<8|r[c],s+=8;s>e;)s-=e,i+=t[o&a>>s];if(s!==0&&(i+=t[o&a<<e-s]),n)for(;(i.length*e&7)!==0;)i+="=";return i}function st({name:r,prefix:t,bitsPerChar:e,alphabet:n}){return Ve({prefix:t,name:r,encode(o){return Cu(o,n,e)},decode(o){return Bu(o,n,e,r)}})}var Q=fe({name:"base58btc",prefix:"z",alphabet:"123456789ABCDEFGHJKLMNPQRSTUVWXYZabcdefghijkmnopqrstuvwxyz"}),Du=fe({name:"base58flickr",prefix:"Z",alphabet:"123456789abcdefghijkmnopqrstuvwxyzABCDEFGHJKLMNPQRSTUVWXYZ"});var _o={};_t(_o,{base32:()=>ee,base32hex:()=>Ou,base32hexpad:()=>ku,base32hexpadupper:()=>Ku,base32hexupper:()=>Mu,base32pad:()=>Nu,base32padupper:()=>Uu,base32upper:()=>Pu,base32z:()=>qu});var ee=st({prefix:"b",name:"base32",alphabet:"abcdefghijklmnopqrstuvwxyz234567",bitsPerChar:5}),Pu=st({prefix:"B",name:"base32upper",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZ234567",bitsPerChar:5}),Nu=st({prefix:"c",name:"base32pad",alphabet:"abcdefghijklmnopqrstuvwxyz234567=",bitsPerChar:5}),Uu=st({prefix:"C",name:"base32padupper",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZ234567=",bitsPerChar:5}),Ou=st({prefix:"v",name:"base32hex",alphabet:"0123456789abcdefghijklmnopqrstuv",bitsPerChar:5}),Mu=st({prefix:"V",name:"base32hexupper",alphabet:"0123456789ABCDEFGHIJKLMNOPQRSTUV",bitsPerChar:5}),ku=st({prefix:"t",name:"base32hexpad",alphabet:"0123456789abcdefghijklmnopqrstuv=",bitsPerChar:5}),Ku=st({prefix:"T",name:"base32hexpadupper",alphabet:"0123456789ABCDEFGHIJKLMNOPQRSTUV=",bitsPerChar:5}),qu=st({prefix:"h",name:"base32z",alphabet:"ybndrfg8ejkmcpqxot1uwisza345h769",bitsPerChar:5});var Io={};_t(Io,{base36:()=>pr,base36upper:()=>Fu});var pr=fe({prefix:"k",name:"base36",alphabet:"0123456789abcdefghijklmnopqrstuvwxyz"}),Fu=fe({prefix:"K",name:"base36upper",alphabet:"0123456789ABCDEFGHIJKLMNOPQRSTUVWXYZ"});var zu=$s,Zs=128,Vu=127,Hu=~Vu,Gu=Math.pow(2,31);function $s(r,t,e){t=t||[],e=e||0;for(var n=e;r>=Gu;)t[e++]=r&255|Zs,r/=128;for(;r&Hu;)t[e++]=r&255|Zs,r>>>=7;return t[e]=r|0,$s.bytes=e-n+1,t}var Zu=To,Wu=128,Ws=127;function To(r,n){var e=0,n=n||0,o=0,i=n,s,a=r.length;do{if(i>=a)throw To.bytes=0,new RangeError("Could not decode varint");s=r[i++],e+=o<28?(s&Ws)<<o:(s&Ws)*Math.pow(2,o),o+=7}while(s>=Wu);return To.bytes=i-n,e}var $u=Math.pow(2,7),Yu=Math.pow(2,14),Xu=Math.pow(2,21),Qu=Math.pow(2,28),ju=Math.pow(2,35),Ju=Math.pow(2,42),tl=Math.pow(2,49),el=Math.pow(2,56),rl=Math.pow(2,63),nl=function(r){return r<$u?1:r<Yu?2:r<Xu?3:r<Qu?4:r<ju?5:r<Ju?6:r<tl?7:r<el?8:r<rl?9:10},ol={encode:zu,decode:Zu,encodingLength:nl},il=ol,mr=il;function yr(r,t=0){return[mr.decode(r,t),mr.decode.bytes]}function He(r,t,e=0){return mr.encode(r,t,e),t}function Ge(r){return mr.encodingLength(r)}function Ft(r,t){let e=t.byteLength,n=Ge(r),o=n+Ge(e),i=new Uint8Array(o+e);return He(r,i,0),He(e,i,n),i.set(t,o),new Ze(r,e,t,i)}function Mt(r){let t=te(r),[e,n]=yr(t),[o,i]=yr(t.subarray(n)),s=t.subarray(n+i);if(s.byteLength!==o)throw new Error("Incorrect length");return new Ze(e,o,s,t)}function Ys(r,t){if(r===t)return!0;{let e=t;return r.code===e.code&&r.size===e.size&&e.bytes instanceof Uint8Array&&qs(r.bytes,e.bytes)}}var Ze=class{code;size;digest;bytes;constructor(t,e,n,o){this.code=t,this.size=e,this.digest=n,this.bytes=o}};function Xs(r,t){let{bytes:e,version:n}=r;switch(n){case 0:return al(e,Lo(r),t??Q.encoder);default:return cl(e,Lo(r),t??ee.encoder)}}var Qs=new WeakMap;function Lo(r){let t=Qs.get(r);if(t==null){let e=new Map;return Qs.set(r,e),e}return t}var dt=class r{code;version;multihash;bytes;"/";constructor(t,e,n,o){this.code=e,this.version=t,this.multihash=n,this.bytes=o,this["/"]=o}get asCID(){return this}get byteOffset(){return this.bytes.byteOffset}get byteLength(){return this.bytes.byteLength}toV0(){switch(this.version){case 0:return this;case 1:{let{code:t,multihash:e}=this;if(t!==gr)throw new Error("Cannot convert a non dag-pb CID to CIDv0");if(e.code!==ul)throw new Error("Cannot convert non sha2-256 multihash CID to CIDv0");return r.createV0(e)}default:throw Error(`Can not convert CID version ${this.version} to version 0. This is a bug please report`)}}toV1(){switch(this.version){case 0:{let{code:t,digest:e}=this.multihash,n=Ft(t,e);return r.createV1(this.code,n)}case 1:return this;default:throw Error(`Can not convert CID version ${this.version} to version 1. This is a bug please report`)}}equals(t){return r.equals(this,t)}static equals(t,e){let n=e;return n!=null&&t.code===n.code&&t.version===n.version&&Ys(t.multihash,n.multihash)}toString(t){return Xs(this,t)}toJSON(){return{"/":Xs(this)}}link(){return this}[Symbol.toStringTag]="CID";[Symbol.for("nodejs.util.inspect.custom")](){return`CID(${this.toString()})`}static asCID(t){if(t==null)return null;let e=t;if(e instanceof r)return e;if(e["/"]!=null&&e["/"]===e.bytes||e.asCID===e){let{version:n,code:o,multihash:i,bytes:s}=e;return new r(n,o,i,s??js(n,o,i.bytes))}else if(e[ll]===!0){let{version:n,multihash:o,code:i}=e,s=Mt(o);return r.create(n,i,s)}else return null}static create(t,e,n){if(typeof e!="number")throw new Error("String codecs are no longer supported");if(!(n.bytes instanceof Uint8Array))throw new Error("Invalid digest");switch(t){case 0:{if(e!==gr)throw new Error(`Version 0 CID must use dag-pb (code: ${gr}) block encoding`);return new r(t,e,n,n.bytes)}case 1:{let o=js(t,e,n.bytes);return new r(t,e,n,o)}default:throw new Error("Invalid version")}}static createV0(t){return r.create(0,gr,t)}static createV1(t,e){return r.create(1,t,e)}static decode(t){let[e,n]=r.decodeFirst(t);if(n.length!==0)throw new Error("Incorrect length");return e}static decodeFirst(t){let e=r.inspectBytes(t),n=e.size-e.multihashSize,o=te(t.subarray(n,n+e.multihashSize));if(o.byteLength!==e.multihashSize)throw new Error("Incorrect length");let i=o.subarray(e.multihashSize-e.digestSize),s=new Ze(e.multihashCode,e.digestSize,i,o);return[e.version===0?r.createV0(s):r.createV1(e.codec,s),t.subarray(e.size)]}static inspectBytes(t){let e=0,n=()=>{let[f,d]=yr(t.subarray(e));return e+=d,f},o=n(),i=gr;if(o===18?(o=0,e=0):i=n(),o!==0&&o!==1)throw new RangeError(`Invalid CID version ${o}`);let s=e,a=n(),c=n(),l=e+c,u=l-s;return{version:o,codec:i,multihashCode:a,digestSize:c,multihashSize:u,size:l}}static parse(t,e){let[n,o]=sl(t,e),i=r.decode(o);if(i.version===0&&t[0]!=="Q")throw Error("Version 0 CID string must not include multibase prefix");return Lo(i).set(n,t),i}};function sl(r,t){switch(r[0]){case"Q":{let e=t??Q;return[Q.prefix,e.decode(`${Q.prefix}${r}`)]}case Q.prefix:{let e=t??Q;return[Q.prefix,e.decode(r)]}case ee.prefix:{let e=t??ee;return[ee.prefix,e.decode(r)]}case pr.prefix:{let e=t??pr;return[pr.prefix,e.decode(r)]}default:{if(t==null)throw Error("To parse non base32, base36 or base58btc encoded CID multibase decoder must be provided");return[r[0],t.decode(r)]}}}function al(r,t,e){let{prefix:n}=e;if(n!==Q.prefix)throw Error(`Cannot string encode V0 in ${e.name} encoding`);let o=t.get(n);if(o==null){let i=e.encode(r).slice(1);return t.set(n,i),i}else return o}function cl(r,t,e){let{prefix:n}=e,o=t.get(n);if(o==null){let i=e.encode(r);return t.set(n,i),i}else return o}var gr=112,ul=18;function js(r,t,e){let n=Ge(r),o=n+Ge(t),i=new Uint8Array(o+e.byteLength);return He(r,i,0),He(t,i,n),i.set(e,o),i}var ll=Symbol.for("@ipld/js-cid/CID");var Ro={};_t(Ro,{identity:()=>re});var Js=0,fl="identity",ta=te;function hl(r){return Ft(Js,ta(r))}var re={code:Js,name:fl,encode:ta,digest:hl};function pt(r,t){if(r===t)return!0;if(r.byteLength!==t.byteLength)return!1;for(let e=0;e<r.byteLength;e++)if(r[e]!==t[e])return!1;return!0}function ea(r){if(!Number.isSafeInteger(r)||r<0)throw new Error("positive integer expected, got "+r)}function dl(r){return r instanceof Uint8Array||ArrayBuffer.isView(r)&&r.constructor.name==="Uint8Array"}function We(r,...t){if(!dl(r))throw new Error("Uint8Array expected");if(t.length>0&&!t.includes(r.length))throw new Error("Uint8Array expected of length "+t+", got length="+r.length)}function ra(r){if(typeof r!="function"||typeof r.create!="function")throw new Error("Hash should be wrapped by utils.wrapConstructor");ea(r.outputLen),ea(r.blockLen)}function $e(r,t=!0){if(r.destroyed)throw new Error("Hash instance has been destroyed");if(t&&r.finished)throw new Error("Hash#digest() has already been called")}function na(r,t){We(r);let e=t.outputLen;if(r.length<e)throw new Error("digestInto() expects output buffer of length at least "+e)}var Te=typeof globalThis=="object"&&"crypto"in globalThis?globalThis.crypto:void 0;function Wr(r){return new DataView(r.buffer,r.byteOffset,r.byteLength)}function zt(r,t){return r<<32-t|r>>>t}function oa(r){if(typeof r!="string")throw new Error("utf8ToBytes expected string, got "+typeof r);return new Uint8Array(new TextEncoder().encode(r))}function br(r){return typeof r=="string"&&(r=oa(r)),We(r),r}function Bo(...r){let t=0;for(let n=0;n<r.length;n++){let o=r[n];We(o),t+=o.length}let e=new Uint8Array(t);for(let n=0,o=0;n<r.length;n++){let i=r[n];e.set(i,o),o+=i.length}return e}var Ye=class{clone(){return this._cloneInto()}};function $r(r){let t=n=>r().update(br(n)).digest(),e=r();return t.outputLen=e.outputLen,t.blockLen=e.blockLen,t.create=()=>r(),t}function Yr(r=32){if(Te&&typeof Te.getRandomValues=="function")return Te.getRandomValues(new Uint8Array(r));if(Te&&typeof Te.randomBytes=="function")return Te.randomBytes(r);throw new Error("crypto.getRandomValues must be defined")}function pl(r,t,e,n){if(typeof r.setBigUint64=="function")return r.setBigUint64(t,e,n);let o=BigInt(32),i=BigInt(4294967295),s=Number(e>>o&i),a=Number(e&i),c=n?4:0,l=n?0:4;r.setUint32(t+c,s,n),r.setUint32(t+l,a,n)}function ia(r,t,e){return r&t^~r&e}function sa(r,t,e){return r&t^r&e^t&e}var Xe=class extends Ye{constructor(t,e,n,o){super(),this.blockLen=t,this.outputLen=e,this.padOffset=n,this.isLE=o,this.finished=!1,this.length=0,this.pos=0,this.destroyed=!1,this.buffer=new Uint8Array(t),this.view=Wr(this.buffer)}update(t){$e(this);let{view:e,buffer:n,blockLen:o}=this;t=br(t);let i=t.length;for(let s=0;s<i;){let a=Math.min(o-this.pos,i-s);if(a===o){let c=Wr(t);for(;o<=i-s;s+=o)this.process(c,s);continue}n.set(t.subarray(s,s+a),this.pos),this.pos+=a,s+=a,this.pos===o&&(this.process(e,0),this.pos=0)}return this.length+=t.length,this.roundClean(),this}digestInto(t){$e(this),na(t,this),this.finished=!0;let{buffer:e,view:n,blockLen:o,isLE:i}=this,{pos:s}=this;e[s++]=128,this.buffer.subarray(s).fill(0),this.padOffset>o-s&&(this.process(n,0),s=0);for(let f=s;f<o;f++)e[f]=0;pl(n,o-8,BigInt(this.length*8),i),this.process(n,0);let a=Wr(t),c=this.outputLen;if(c%4)throw new Error("_sha2: outputLen should 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],i)}digest(){let{buffer:t,outputLen:e}=this;this.digestInto(t);let n=t.slice(0,e);return this.destroy(),n}_cloneInto(t){t||(t=new this.constructor),t.set(...this.get());let{blockLen:e,buffer:n,length:o,finished:i,destroyed:s,pos:a}=this;return t.length=o,t.pos=a,t.finished=i,t.destroyed=s,o%e&&t.buffer.set(n),t}};var Xr=BigInt(4294967295),Co=BigInt(32);function aa(r,t=!1){return t?{h:Number(r&Xr),l:Number(r>>Co&Xr)}:{h:Number(r>>Co&Xr)|0,l:Number(r&Xr)|0}}function ml(r,t=!1){let e=new Uint32Array(r.length),n=new Uint32Array(r.length);for(let o=0;o<r.length;o++){let{h:i,l:s}=aa(r[o],t);[e[o],n[o]]=[i,s]}return[e,n]}var yl=(r,t)=>BigInt(r>>>0)<<Co|BigInt(t>>>0),gl=(r,t,e)=>r>>>e,bl=(r,t,e)=>r<<32-e|t>>>e,xl=(r,t,e)=>r>>>e|t<<32-e,wl=(r,t,e)=>r<<32-e|t>>>e,El=(r,t,e)=>r<<64-e|t>>>e-32,vl=(r,t,e)=>r>>>e-32|t<<64-e,Sl=(r,t)=>t,Al=(r,t)=>r,_l=(r,t,e)=>r<<e|t>>>32-e,Il=(r,t,e)=>t<<e|r>>>32-e,Tl=(r,t,e)=>t<<e-32|r>>>64-e,Ll=(r,t,e)=>r<<e-32|t>>>64-e;function Rl(r,t,e,n){let o=(t>>>0)+(n>>>0);return{h:r+e+(o/2**32|0)|0,l:o|0}}var Bl=(r,t,e)=>(r>>>0)+(t>>>0)+(e>>>0),Cl=(r,t,e,n)=>t+e+n+(r/2**32|0)|0,Dl=(r,t,e,n)=>(r>>>0)+(t>>>0)+(e>>>0)+(n>>>0),Pl=(r,t,e,n,o)=>t+e+n+o+(r/2**32|0)|0,Nl=(r,t,e,n,o)=>(r>>>0)+(t>>>0)+(e>>>0)+(n>>>0)+(o>>>0),Ul=(r,t,e,n,o,i)=>t+e+n+o+i+(r/2**32|0)|0;var Ol={fromBig:aa,split:ml,toBig:yl,shrSH:gl,shrSL:bl,rotrSH:xl,rotrSL:wl,rotrBH:El,rotrBL:vl,rotr32H:Sl,rotr32L:Al,rotlSH:_l,rotlSL:Il,rotlBH:Tl,rotlBL:Ll,add:Rl,add3L:Bl,add3H:Cl,add4L:Dl,add4H:Pl,add5H:Ul,add5L:Nl},U=Ol;var[Ml,kl]=U.split(["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))),he=new Uint32Array(80),de=new Uint32Array(80),Do=class extends Xe{constructor(){super(128,64,16,!1),this.Ah=1779033703,this.Al=-205731576,this.Bh=-1150833019,this.Bl=-2067093701,this.Ch=1013904242,this.Cl=-23791573,this.Dh=-1521486534,this.Dl=1595750129,this.Eh=1359893119,this.El=-1377402159,this.Fh=-1694144372,this.Fl=725511199,this.Gh=528734635,this.Gl=-79577749,this.Hh=1541459225,this.Hl=327033209}get(){let{Ah:t,Al:e,Bh:n,Bl:o,Ch:i,Cl:s,Dh:a,Dl:c,Eh:l,El:u,Fh:f,Fl:d,Gh:g,Gl:y,Hh:b,Hl:h}=this;return[t,e,n,o,i,s,a,c,l,u,f,d,g,y,b,h]}set(t,e,n,o,i,s,a,c,l,u,f,d,g,y,b,h){this.Ah=t|0,this.Al=e|0,this.Bh=n|0,this.Bl=o|0,this.Ch=i|0,this.Cl=s|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=g|0,this.Gl=y|0,this.Hh=b|0,this.Hl=h|0}process(t,e){for(let m=0;m<16;m++,e+=4)he[m]=t.getUint32(e),de[m]=t.getUint32(e+=4);for(let m=16;m<80;m++){let _=he[m-15]|0,B=de[m-15]|0,C=U.rotrSH(_,B,1)^U.rotrSH(_,B,8)^U.shrSH(_,B,7),I=U.rotrSL(_,B,1)^U.rotrSL(_,B,8)^U.shrSL(_,B,7),R=he[m-2]|0,T=de[m-2]|0,et=U.rotrSH(R,T,19)^U.rotrBH(R,T,61)^U.shrSH(R,T,6),V=U.rotrSL(R,T,19)^U.rotrBL(R,T,61)^U.shrSL(R,T,6),q=U.add4L(I,V,de[m-7],de[m-16]),ct=U.add4H(q,C,et,he[m-7],he[m-16]);he[m]=ct|0,de[m]=q|0}let{Ah:n,Al:o,Bh:i,Bl:s,Ch:a,Cl:c,Dh:l,Dl:u,Eh:f,El:d,Fh:g,Fl:y,Gh:b,Gl:h,Hh:w,Hl:v}=this;for(let m=0;m<80;m++){let _=U.rotrSH(f,d,14)^U.rotrSH(f,d,18)^U.rotrBH(f,d,41),B=U.rotrSL(f,d,14)^U.rotrSL(f,d,18)^U.rotrBL(f,d,41),C=f&g^~f&b,I=d&y^~d&h,R=U.add5L(v,B,I,kl[m],de[m]),T=U.add5H(R,w,_,C,Ml[m],he[m]),et=R|0,V=U.rotrSH(n,o,28)^U.rotrBH(n,o,34)^U.rotrBH(n,o,39),q=U.rotrSL(n,o,28)^U.rotrBL(n,o,34)^U.rotrBL(n,o,39),ct=n&i^n&a^i&a,S=o&s^o&c^s&c;w=b|0,v=h|0,b=g|0,h=y|0,g=f|0,y=d|0,{h:f,l:d}=U.add(l|0,u|0,T|0,et|0),l=a|0,u=c|0,a=i|0,c=s|0,i=n|0,s=o|0;let L=U.add3L(et,q,S);n=U.add3H(L,T,V,ct),o=L|0}({h:n,l:o}=U.add(this.Ah|0,this.Al|0,n|0,o|0)),{h:i,l:s}=U.add(this.Bh|0,this.Bl|0,i|0,s|0),{h:a,l:c}=U.add(this.Ch|0,this.Cl|0,a|0,c|0),{h:l,l:u}=U.add(this.Dh|0,this.Dl|0,l|0,u|0),{h:f,l:d}=U.add(this.Eh|0,this.El|0,f|0,d|0),{h:g,l:y}=U.add(this.Fh|0,this.Fl|0,g|0,y|0),{h:b,l:h}=U.add(this.Gh|0,this.Gl|0,b|0,h|0),{h:w,l:v}=U.add(this.Hh|0,this.Hl|0,w|0,v|0),this.set(n,o,i,s,a,c,l,u,f,d,g,y,b,h,w,v)}roundClean(){he.fill(0),de.fill(0)}destroy(){this.buffer.fill(0),this.set(0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0)}};var ca=$r(()=>new Do);var Jr={};_t(Jr,{aInRange:()=>Tt,abool:()=>Vt,abytes:()=>Qe,bitGet:()=>Hl,bitLen:()=>Oo,bitMask:()=>wr,bitSet:()=>Gl,bytesToHex:()=>oe,bytesToNumberBE:()=>ie,bytesToNumberLE:()=>me,concatBytes:()=>se,createHmacDrbg:()=>Mo,ensureBytes:()=>ot,equalBytes:()=>zl,hexToBytes:()=>Re,hexToNumber:()=>Uo,inRange:()=>xr,isBytes:()=>pe,memoized:()=>Ce,notImplemented:()=>Wl,numberToBytesBE:()=>ye,numberToBytesLE:()=>Be,numberToHexUnpadded:()=>Le,numberToVarBytesBE:()=>Fl,utf8ToBytes:()=>Vl,validateObject:()=>Xt});var Qr=BigInt(0),jr=BigInt(1),Kl=BigInt(2);function pe(r){return r instanceof Uint8Array||ArrayBuffer.isView(r)&&r.constructor.name==="Uint8Array"}function Qe(r){if(!pe(r))throw new Error("Uint8Array expected")}function Vt(r,t){if(typeof t!="boolean")throw new Error(r+" boolean expected, got "+t)}var ql=Array.from({length:256},(r,t)=>t.toString(16).padStart(2,"0"));function oe(r){Qe(r);let t="";for(let e=0;e<r.length;e++)t+=ql[r[e]];return t}function Le(r){let t=r.toString(16);return t.length&1?"0"+t:t}function Uo(r){if(typeof r!="string")throw new Error("hex string expected, got "+typeof r);return r===""?Qr:BigInt("0x"+r)}var ne={_0:48,_9:57,A:65,F:70,a:97,f:102};function ua(r){if(r>=ne._0&&r<=ne._9)return r-ne._0;if(r>=ne.A&&r<=ne.F)return r-(ne.A-10);if(r>=ne.a&&r<=ne.f)return r-(ne.a-10)}function Re(r){if(typeof r!="string")throw new Error("hex string expected, got "+typeof r);let t=r.length,e=t/2;if(t%2)throw new Error("hex string expected, got unpadded hex of length "+t);let n=new Uint8Array(e);for(let o=0,i=0;o<e;o++,i+=2){let s=ua(r.charCodeAt(i)),a=ua(r.charCodeAt(i+1));if(s===void 0||a===void 0){let c=r[i]+r[i+1];throw new Error('hex string expected, got non-hex character "'+c+'" at index '+i)}n[o]=s*16+a}return n}function ie(r){return Uo(oe(r))}function me(r){return Qe(r),Uo(oe(Uint8Array.from(r).reverse()))}function ye(r,t){return Re(r.toString(16).padStart(t*2,"0"))}function Be(r,t){return ye(r,t).reverse()}function Fl(r){return Re(Le(r))}function ot(r,t,e){let n;if(typeof t=="string")try{n=Re(t)}catch(i){throw new Error(r+" must be hex string or Uint8Array, cause: "+i)}else if(pe(t))n=Uint8Array.from(t);else throw new Error(r+" must be hex string or Uint8Array");let o=n.length;if(typeof e=="number"&&o!==e)throw new Error(r+" of length "+e+" expected, got "+o);return n}function se(...r){let t=0;for(let n=0;n<r.length;n++){let o=r[n];Qe(o),t+=o.length}let e=new Uint8Array(t);for(let n=0,o=0;n<r.length;n++){let i=r[n];e.set(i,o),o+=i.length}return e}function zl(r,t){if(r.length!==t.length)return!1;let e=0;for(let n=0;n<r.length;n++)e|=r[n]^t[n];return e===0}function Vl(r){if(typeof r!="string")throw new Error("string expected");return new Uint8Array(new TextEncoder().encode(r))}var Po=r=>typeof r=="bigint"&&Qr<=r;function xr(r,t,e){return Po(r)&&Po(t)&&Po(e)&&t<=r&&r<e}function Tt(r,t,e,n){if(!xr(t,e,n))throw new Error("expected valid "+r+": "+e+" <= n < "+n+", got "+t)}function Oo(r){let t;for(t=0;r>Qr;r>>=jr,t+=1);return t}function Hl(r,t){return r>>BigInt(t)&jr}function Gl(r,t,e){return r|(e?jr:Qr)<<BigInt(t)}var wr=r=>(Kl<<BigInt(r-1))-jr,No=r=>new Uint8Array(r),la=r=>Uint8Array.from(r);function Mo(r,t,e){if(typeof r!="number"||r<2)throw new Error("hashLen must be a number");if(typeof t!="number"||t<2)throw new Error("qByteLen must be a number");if(typeof e!="function")throw new Error("hmacFn must be a function");let n=No(r),o=No(r),i=0,s=()=>{n.fill(1),o.fill(0),i=0},a=(...f)=>e(o,n,...f),c=(f=No())=>{o=a(la([0]),f),n=a(),f.length!==0&&(o=a(la([1]),f),n=a())},l=()=>{if(i++>=1e3)throw new Error("drbg: tried 1000 values");let f=0,d=[];for(;f<t;){n=a();let g=n.slice();d.push(g),f+=n.length}return se(...d)};return(f,d)=>{s(),c(f);let g;for(;!(g=d(l()));)c();return s(),g}}var Zl={bigint:r=>typeof r=="bigint",function:r=>typeof r=="function",boolean:r=>typeof r=="boolean",string:r=>typeof r=="string",stringOrUint8Array:r=>typeof r=="string"||pe(r),isSafeInteger:r=>Number.isSafeInteger(r),array:r=>Array.isArray(r),field:(r,t)=>t.Fp.isValid(r),hash:r=>typeof r=="function"&&Number.isSafeInteger(r.outputLen)};function Xt(r,t,e={}){let n=(o,i,s)=>{let a=Zl[i];if(typeof a!="function")throw new Error("invalid validator function");let c=r[o];if(!(s&&c===void 0)&&!a(c,r))throw new Error("param "+String(o)+" is invalid. Expected "+i+", got "+c)};for(let[o,i]of Object.entries(t))n(o,i,!1);for(let[o,i]of Object.entries(e))n(o,i,!0);return r}var Wl=()=>{throw new Error("not implemented")};function Ce(r){let t=new WeakMap;return(e,...n)=>{let o=t.get(e);if(o!==void 0)return o;let i=r(e,...n);return t.set(e,i),i}}var ut=BigInt(0),rt=BigInt(1),De=BigInt(2),$l=BigInt(3),ko=BigInt(4),fa=BigInt(5),ha=BigInt(8),Yl=BigInt(9),Xl=BigInt(16);function Y(r,t){let e=r%t;return e>=ut?e:t+e}function Ql(r,t,e){if(t<ut)throw new Error("invalid exponent, negatives unsupported");if(e<=ut)throw new Error("invalid modulus");if(e===rt)return ut;let n=rt;for(;t>ut;)t&rt&&(n=n*r%e),r=r*r%e,t>>=rt;return n}function nt(r,t,e){let n=r;for(;t-- >ut;)n*=n,n%=e;return n}function tn(r,t){if(r===ut)throw new Error("invert: expected non-zero number");if(t<=ut)throw new Error("invert: expected positive modulus, got "+t);let e=Y(r,t),n=t,o=ut,i=rt,s=rt,a=ut;for(;e!==ut;){let l=n/e,u=n%e,f=o-s*l,d=i-a*l;n=e,e=u,o=s,i=a,s=f,a=d}if(n!==rt)throw new Error("invert: does not exist");return Y(o,t)}function jl(r){let t=(r-rt)/De,e,n,o;for(e=r-rt,n=0;e%De===ut;e/=De,n++);for(o=De;o<r&&Ql(o,t,r)!==r-rt;o++)if(o>1e3)throw new Error("Cannot find square root: likely non-prime P");if(n===1){let s=(r+rt)/ko;return function(c,l){let u=c.pow(l,s);if(!c.eql(c.sqr(u),l))throw new Error("Cannot find square root");return u}}let i=(e+rt)/De;return function(a,c){if(a.pow(c,t)===a.neg(a.ONE))throw new Error("Cannot find square root");let l=n,u=a.pow(a.mul(a.ONE,o),e),f=a.pow(c,i),d=a.pow(c,e);for(;!a.eql(d,a.ONE);){if(a.eql(d,a.ZERO))return a.ZERO;let g=1;for(let b=a.sqr(d);g<l&&!a.eql(b,a.ONE);g++)b=a.sqr(b);let y=a.pow(u,rt<<BigInt(l-g-1));u=a.sqr(y),f=a.mul(f,y),d=a.mul(d,u),l=g}return f}}function Jl(r){if(r%ko===$l){let t=(r+rt)/ko;return function(n,o){let i=n.pow(o,t);if(!n.eql(n.sqr(i),o))throw new Error("Cannot find square root");return i}}if(r%ha===fa){let t=(r-fa)/ha;return function(n,o){let i=n.mul(o,De),s=n.pow(i,t),a=n.mul(o,s),c=n.mul(n.mul(a,De),s),l=n.mul(a,n.sub(c,n.ONE));if(!n.eql(n.sqr(l),o))throw new Error("Cannot find square root");return l}}return r%Xl,jl(r)}var da=(r,t)=>(Y(r,t)&rt)===rt,tf=["create","isValid","is0","neg","inv","sqrt","sqr","eql","add","sub","mul","pow","div","addN","subN","mulN","sqrN"];function Ko(r){let t={ORDER:"bigint",MASK:"bigint",BYTES:"isSafeInteger",BITS:"isSafeInteger"},e=tf.reduce((n,o)=>(n[o]="function",n),t);return Xt(r,e)}function ef(r,t,e){if(e<ut)throw new Error("invalid exponent, negatives unsupported");if(e===ut)return r.ONE;if(e===rt)return t;let n=r.ONE,o=t;for(;e>ut;)e&rt&&(n=r.mul(n,o)),o=r.sqr(o),e>>=rt;return n}function rf(r,t){let e=new Array(t.length),n=t.reduce((i,s,a)=>r.is0(s)?i:(e[a]=i,r.mul(i,s)),r.ONE),o=r.inv(n);return t.reduceRight((i,s,a)=>r.is0(s)?i:(e[a]=r.mul(i,e[a]),r.mul(i,s)),o),e}function qo(r,t){let e=t!==void 0?t:r.toString(2).length,n=Math.ceil(e/8);return{nBitLength:e,nByteLength:n}}function ge(r,t,e=!1,n={}){if(r<=ut)throw new Error("invalid field: expected ORDER > 0, got "+r);let{nBitLength:o,nByteLength:i}=qo(r,t);if(i>2048)throw new Error("invalid field: expected ORDER of <= 2048 bytes");let s,a=Object.freeze({ORDER:r,isLE:e,BITS:o,BYTES:i,MASK:wr(o),ZERO:ut,ONE:rt,create:c=>Y(c,r),isValid:c=>{if(typeof c!="bigint")throw new Error("invalid field element: expected bigint, got "+typeof c);return ut<=c&&c<r},is0:c=>c===ut,isOdd:c=>(c&rt)===rt,neg:c=>Y(-c,r),eql:(c,l)=>c===l,sqr:c=>Y(c*c,r),add:(c,l)=>Y(c+l,r),sub:(c,l)=>Y(c-l,r),mul:(c,l)=>Y(c*l,r),pow:(c,l)=>ef(a,c,l),div:(c,l)=>Y(c*tn(l,r),r),sqrN:c=>c*c,addN:(c,l)=>c+l,subN:(c,l)=>c-l,mulN:(c,l)=>c*l,inv:c=>tn(c,r),sqrt:n.sqrt||(c=>(s||(s=Jl(r)),s(a,c))),invertBatch:c=>rf(a,c),cmov:(c,l,u)=>u?l:c,toBytes:c=>e?Be(c,i):ye(c,i),fromBytes:c=>{if(c.length!==i)throw new Error("Field.fromBytes: expected "+i+" bytes, got "+c.length);return e?me(c):ie(c)}});return Object.freeze(a)}function pa(r){if(typeof r!="bigint")throw new Error("field order must be bigint");let t=r.toString(2).length;return Math.ceil(t/8)}function Fo(r){let t=pa(r);return t+Math.ceil(t/2)}function ma(r,t,e=!1){let n=r.length,o=pa(t),i=Fo(t);if(n<16||n<i||n>1024)throw new Error("expected "+i+"-1024 bytes of input, got "+n);let s=e?me(r):ie(r),a=Y(s,t-rt)+rt;return e?Be(a,o):ye(a,o)}var ya=BigInt(0),en=BigInt(1);function zo(r,t){let e=t.negate();return r?e:t}function ga(r,t){if(!Number.isSafeInteger(r)||r<=0||r>t)throw new Error("invalid window size, expected [1.."+t+"], got W="+r)}function Vo(r,t){ga(r,t);let e=Math.ceil(t/r)+1,n=2**(r-1);return{windows:e,windowSize:n}}function nf(r,t){if(!Array.isArray(r))throw new Error("array expected");r.forEach((e,n)=>{if(!(e instanceof t))throw new Error("invalid point at index "+n)})}function of(r,t){if(!Array.isArray(r))throw new Error("array of scalars expected");r.forEach((e,n)=>{if(!t.isValid(e))throw new Error("invalid scalar at index "+n)})}var Ho=new WeakMap,ba=new WeakMap;function Go(r){return ba.get(r)||1}function rn(r,t){return{constTimeNegate:zo,hasPrecomputes(e){return Go(e)!==1},unsafeLadder(e,n,o=r.ZERO){let i=e;for(;n>ya;)n&en&&(o=o.add(i)),i=i.double(),n>>=en;return o},precomputeWindow(e,n){let{windows:o,windowSize:i}=Vo(n,t),s=[],a=e,c=a;for(let l=0;l<o;l++){c=a,s.push(c);for(let u=1;u<i;u++)c=c.add(a),s.push(c);a=c.double()}return s},wNAF(e,n,o){let{windows:i,windowSize:s}=Vo(e,t),a=r.ZERO,c=r.BASE,l=BigInt(2**e-1),u=2**e,f=BigInt(e);for(let d=0;d<i;d++){let g=d*s,y=Number(o&l);o>>=f,y>s&&(y-=u,o+=en);let b=g,h=g+Math.abs(y)-1,w=d%2!==0,v=y<0;y===0?c=c.add(zo(w,n[b])):a=a.add(zo(v,n[h]))}return{p:a,f:c}},wNAFUnsafe(e,n,o,i=r.ZERO){let{windows:s,windowSize:a}=Vo(e,t),c=BigInt(2**e-1),l=2**e,u=BigInt(e);for(let f=0;f<s;f++){let d=f*a;if(o===ya)break;let g=Number(o&c);if(o>>=u,g>a&&(g-=l,o+=en),g===0)continue;let y=n[d+Math.abs(g)-1];g<0&&(y=y.negate()),i=i.add(y)}return i},getPrecomputes(e,n,o){let i=Ho.get(n);return i||(i=this.precomputeWindow(n,e),e!==1&&Ho.set(n,o(i))),i},wNAFCached(e,n,o){let i=Go(e);return this.wNAF(i,this.getPrecomputes(i,e,o),n)},wNAFCachedUnsafe(e,n,o,i){let s=Go(e);return s===1?this.unsafeLadder(e,n,i):this.wNAFUnsafe(s,this.getPrecomputes(s,e,o),n,i)},setWindowSize(e,n){ga(n,t),ba.set(e,n),Ho.delete(e)}}}function nn(r,t,e,n){if(nf(e,r),of(n,t),e.length!==n.length)throw new Error("arrays of points and scalars must have equal length");let o=r.ZERO,i=Oo(BigInt(e.length)),s=i>12?i-3:i>4?i-2:i?2:1,a=(1<<s)-1,c=new Array(a+1).fill(o),l=Math.floor((t.BITS-1)/s)*s,u=o;for(let f=l;f>=0;f-=s){c.fill(o);for(let g=0;g<n.length;g++){let y=n[g],b=Number(y>>BigInt(f)&BigInt(a));c[b]=c[b].add(e[g])}let d=o;for(let g=c.length-1,y=o;g>0;g--)y=y.add(c[g]),d=d.add(y);if(u=u.add(d),f!==0)for(let g=0;g<s;g++)u=u.double()}return u}function Er(r){return Ko(r.Fp),Xt(r,{n:"bigint",h:"bigint",Gx:"field",Gy:"field"},{nBitLength:"isSafeInteger",nByteLength:"isSafeInteger"}),Object.freeze({...qo(r.n,r.nBitLength),...r,p:r.Fp.ORDER})}var Ht=BigInt(0),Lt=BigInt(1),on=BigInt(2),sf=BigInt(8),af={zip215:!0};function cf(r){let t=Er(r);return Xt(r,{hash:"function",a:"bigint",d:"bigint",randomBytes:"function"},{adjustScalarBytes:"function",domain:"function",uvRatio:"function",mapToCurve:"function"}),Object.freeze({...t})}function xa(r){let t=cf(r),{Fp:e,n,prehash:o,hash:i,randomBytes:s,nByteLength:a,h:c}=t,l=on<<BigInt(a*8)-Lt,u=e.create,f=ge(t.n,t.nBitLength),d=t.uvRatio||((x,p)=>{try{return{isValid:!0,value:e.sqrt(x*e.inv(p))}}catch{return{isValid:!1,value:Ht}}}),g=t.adjustScalarBytes||(x=>x),y=t.domain||((x,p,E)=>{if(Vt("phflag",E),p.length||E)throw new Error("Contexts/pre-hash are not supported");return x});function b(x,p){Tt("coordinate "+x,p,Ht,l)}function h(x){if(!(x instanceof m))throw new Error("ExtendedPoint expected")}let w=Ce((x,p)=>{let{ex:E,ey:A,ez:D}=x,P=x.is0();p==null&&(p=P?sf:e.inv(D));let O=u(E*p),F=u(A*p),N=u(D*p);if(P)return{x:Ht,y:Lt};if(N!==Lt)throw new Error("invZ was invalid");return{x:O,y:F}}),v=Ce(x=>{let{a:p,d:E}=t;if(x.is0())throw new Error("bad point: ZERO");let{ex:A,ey:D,ez:P,et:O}=x,F=u(A*A),N=u(D*D),W=u(P*P),J=u(W*W),ft=u(F*p),ht=u(W*u(ft+N)),yt=u(J+u(E*u(F*N)));if(ht!==yt)throw new Error("bad point: equation left != right (1)");let gt=u(A*D),It=u(P*O);if(gt!==It)throw new Error("bad point: equation left != right (2)");return!0});class m{constructor(p,E,A,D){this.ex=p,this.ey=E,this.ez=A,this.et=D,b("x",p),b("y",E),b("z",A),b("t",D),Object.freeze(this)}get x(){return this.toAffine().x}get y(){return this.toAffine().y}static fromAffine(p){if(p instanceof m)throw new Error("extended point not allowed");let{x:E,y:A}=p||{};return b("x",E),b("y",A),new m(E,A,Lt,u(E*A))}static normalizeZ(p){let E=e.invertBatch(p.map(A=>A.ez));return p.map((A,D)=>A.toAffine(E[D])).map(m.fromAffine)}static msm(p,E){return nn(m,f,p,E)}_setWindowSize(p){C.setWindowSize(this,p)}assertValidity(){v(this)}equals(p){h(p);let{ex:E,ey:A,ez:D}=this,{ex:P,ey:O,ez:F}=p,N=u(E*F),W=u(P*D),J=u(A*F),ft=u(O*D);return N===W&&J===ft}is0(){return this.equals(m.ZERO)}negate(){return new m(u(-this.ex),this.ey,this.ez,u(-this.et))}double(){let{a:p}=t,{ex:E,ey:A,ez:D}=this,P=u(E*E),O=u(A*A),F=u(on*u(D*D)),N=u(p*P),W=E+A,J=u(u(W*W)-P-O),ft=N+O,ht=ft-F,yt=N-O,gt=u(J*ht),It=u(ft*yt),At=u(J*yt),$t=u(ht*ft);return new m(gt,It,$t,At)}add(p){h(p);let{a:E,d:A}=t,{ex:D,ey:P,ez:O,et:F}=this,{ex:N,ey:W,ez:J,et:ft}=p;if(E===BigInt(-1)){let Is=u((P-D)*(W+N)),Ts=u((P+D)*(W-N)),yo=u(Ts-Is);if(yo===Ht)return this.double();let Ls=u(O*on*ft),Rs=u(F*on*J),Bs=Rs+Ls,Cs=Ts+Is,Ds=Rs-Ls,bu=u(Bs*yo),xu=u(Cs*Ds),wu=u(Bs*Ds),Eu=u(yo*Cs);return new m(bu,xu,Eu,wu)}let ht=u(D*N),yt=u(P*W),gt=u(F*A*ft),It=u(O*J),At=u((D+P)*(N+W)-ht-yt),$t=It-gt,jt=It+gt,hr=u(yt-E*ht),pu=u(At*$t),mu=u(jt*hr),yu=u(At*hr),gu=u($t*jt);return new m(pu,mu,gu,yu)}subtract(p){return this.add(p.negate())}wNAF(p){return C.wNAFCached(this,p,m.normalizeZ)}multiply(p){let E=p;Tt("scalar",E,Lt,n);let{p:A,f:D}=this.wNAF(E);return m.normalizeZ([A,D])[0]}multiplyUnsafe(p,E=m.ZERO){let A=p;return Tt("scalar",A,Ht,n),A===Ht?B:this.is0()||A===Lt?this:C.wNAFCachedUnsafe(this,A,m.normalizeZ,E)}isSmallOrder(){return this.multiplyUnsafe(c).is0()}isTorsionFree(){return C.unsafeLadder(this,n).is0()}toAffine(p){return w(this,p)}clearCofactor(){let{h:p}=t;return p===Lt?this:this.multiplyUnsafe(p)}static fromHex(p,E=!1){let{d:A,a:D}=t,P=e.BYTES;p=ot("pointHex",p,P),Vt("zip215",E);let O=p.slice(),F=p[P-1];O[P-1]=F&-129;let N=me(O),W=E?l:e.ORDER;Tt("pointHex.y",N,Ht,W);let J=u(N*N),ft=u(J-Lt),ht=u(A*J-D),{isValid:yt,value:gt}=d(ft,ht);if(!yt)throw new Error("Point.fromHex: invalid y coordinate");let It=(gt&Lt)===Lt,At=(F&128)!==0;if(!E&>===Ht&&At)throw new Error("Point.fromHex: x=0 and x_0=1");return At!==It&&(gt=u(-gt)),m.fromAffine({x:gt,y:N})}static fromPrivateKey(p){return T(p).point}toRawBytes(){let{x:p,y:E}=this.toAffine(),A=Be(E,e.BYTES);return A[A.length-1]|=p&Lt?128:0,A}toHex(){return oe(this.toRawBytes())}}m.BASE=new m(t.Gx,t.Gy,Lt,u(t.Gx*t.Gy)),m.ZERO=new m(Ht,Lt,Lt,Ht);let{BASE:_,ZERO:B}=m,C=rn(m,a*8);function I(x){return Y(x,n)}function R(x){return I(me(x))}function T(x){let p=e.BYTES;x=ot("private key",x,p);let E=ot("hashed private key",i(x),2*p),A=g(E.slice(0,p)),D=E.slice(p,2*p),P=R(A),O=_.multiply(P),F=O.toRawBytes();return{head:A,prefix:D,scalar:P,point:O,pointBytes:F}}function et(x){return T(x).pointBytes}function V(x=new Uint8Array,...p){let E=se(...p);return R(i(y(E,ot("context",x),!!o)))}function q(x,p,E={}){x=ot("message",x),o&&(x=o(x));let{prefix:A,scalar:D,pointBytes:P}=T(p),O=V(E.context,A,x),F=_.multiply(O).toRawBytes(),N=V(E.context,F,P,x),W=I(O+N*D);Tt("signature.s",W,Ht,n);let J=se(F,Be(W,e.BYTES));return ot("result",J,e.BYTES*2)}let ct=af;function S(x,p,E,A=ct){let{context:D,zip215:P}=A,O=e.BYTES;x=ot("signature",x,2*O),p=ot("message",p),E=ot("publicKey",E,O),P!==void 0&&Vt("zip215",P),o&&(p=o(p));let F=me(x.slice(O,2*O)),N,W,J;try{N=m.fromHex(E,P),W=m.fromHex(x.slice(0,O),P),J=_.multiplyUnsafe(F)}catch{return!1}if(!P&&N.isSmallOrder())return!1;let ft=V(D,W.toRawBytes(),N.toRawBytes(),p);return W.add(N.multiplyUnsafe(ft)).subtract(J).clearCofactor().equals(m.ZERO)}return _._setWindowSize(8),{CURVE:t,getPublicKey:et,sign:q,verify:S,ExtendedPoint:m,utils:{getExtendedPublicKey:T,randomPrivateKey:()=>s(e.BYTES),precompute(x=8,p=m.BASE){return p._setWindowSize(x),p.multiply(BigInt(3)),p}}}}var Zo=BigInt("57896044618658097711785492504343953926634992332820282019728792003956564819949"),wa=BigInt("19681161376707505956807079304988542015446066515923890162744021073123829784752"),Mp=BigInt(0),uf=BigInt(1),Ea=BigInt(2),kp=BigInt(3),lf=BigInt(5),ff=BigInt(8);function hf(r){let t=BigInt(10),e=BigInt(20),n=BigInt(40),o=BigInt(80),i=Zo,a=r*r%i*r%i,c=nt(a,Ea,i)*a%i,l=nt(c,uf,i)*r%i,u=nt(l,lf,i)*l%i,f=nt(u,t,i)*u%i,d=nt(f,e,i)*f%i,g=nt(d,n,i)*d%i,y=nt(g,o,i)*g%i,b=nt(y,o,i)*g%i,h=nt(b,t,i)*u%i;return{pow_p_5_8:nt(h,Ea,i)*r%i,b2:a}}function df(r){return r[0]&=248,r[31]&=127,r[31]|=64,r}function pf(r,t){let e=Zo,n=Y(t*t*t,e),o=Y(n*n*t,e),i=hf(r*o).pow_p_5_8,s=Y(r*n*i,e),a=Y(t*s*s,e),c=s,l=Y(s*wa,e),u=a===r,f=a===Y(-r,e),d=a===Y(-r*wa,e);return u&&(s=c),(f||d)&&(s=l),da(s,e)&&(s=Y(-s,e)),{isValid:u||f,value:s}}var mf=ge(Zo,void 0,!0),yf={a:BigInt(-1),d:BigInt("37095705934669439343138083508754565189542113879843219016388785533085940283555"),Fp:mf,n:BigInt("7237005577332262213973186563042994240857116359379907606001950938285454250989"),h:ff,Gx:BigInt("15112221349535400772501151409588531511454012693041857206046113283949847762202"),Gy:BigInt("46316835694926478169428394003475163141307993866256225615783033603165251855960"),hash:ca,randomBytes:Yr,adjustScalarBytes:df,uvRatio:pf},va=xa(yf);var sn=32;function Sa(r,t,e){return va.verify(t,e instanceof Uint8Array?e:e.subarray(),r)}var an=class{type="Ed25519";raw;constructor(t){this.raw=Wo(t,sn)}toMultihash(){return re.digest(be(this))}toCID(){return dt.createV1(114,this.toMultihash())}toString(){return Q.encode(this.toMultihash().bytes).substring(1)}equals(t){return t==null||!(t.raw instanceof Uint8Array)?!1:pt(this.raw,t.raw)}verify(t,e){return Sa(this.raw,e,t)}};function $o(r){return r=Wo(r,sn),new an(r)}function Wo(r,t){if(r=Uint8Array.from(r??[]),r.length!==t)throw new bt(`Key must be a Uint8Array of length ${t}, got ${r.length}`);return r}function it(r=0){return new Uint8Array(r)}function Rt(r=0){return new Uint8Array(r)}var bf=Math.pow(2,7),xf=Math.pow(2,14),wf=Math.pow(2,21),Yo=Math.pow(2,28),Xo=Math.pow(2,35),Qo=Math.pow(2,42),jo=Math.pow(2,49),Z=128,xt=127;function wt(r){if(r<bf)return 1;if(r<xf)return 2;if(r<wf)return 3;if(r<Yo)return 4;if(r<Xo)return 5;if(r<Qo)return 6;if(r<jo)return 7;if(Number.MAX_SAFE_INTEGER!=null&&r>Number.MAX_SAFE_INTEGER)throw new RangeError("Could not encode varint");return 8}function Jo(r,t,e=0){switch(wt(r)){case 8:t[e++]=r&255|Z,r/=128;case 7:t[e++]=r&255|Z,r/=128;case 6:t[e++]=r&255|Z,r/=128;case 5:t[e++]=r&255|Z,r/=128;case 4:t[e++]=r&255|Z,r>>>=7;case 3:t[e++]=r&255|Z,r>>>=7;case 2:t[e++]=r&255|Z,r>>>=7;case 1:{t[e++]=r&255,r>>>=7;break}default:throw new Error("unreachable")}return t}function Ef(r,t,e=0){switch(wt(r)){case 8:t.set(e++,r&255|Z),r/=128;case 7:t.set(e++,r&255|Z),r/=128;case 6:t.set(e++,r&255|Z),r/=128;case 5:t.set(e++,r&255|Z),r/=128;case 4:t.set(e++,r&255|Z),r>>>=7;case 3:t.set(e++,r&255|Z),r>>>=7;case 2:t.set(e++,r&255|Z),r>>>=7;case 1:{t.set(e++,r&255),r>>>=7;break}default:throw new Error("unreachable")}return t}function ti(r,t){let e=r[t],n=0;if(n+=e&xt,e<Z||(e=r[t+1],n+=(e&xt)<<7,e<Z)||(e=r[t+2],n+=(e&xt)<<14,e<Z)||(e=r[t+3],n+=(e&xt)<<21,e<Z)||(e=r[t+4],n+=(e&xt)*Yo,e<Z)||(e=r[t+5],n+=(e&xt)*Xo,e<Z)||(e=r[t+6],n+=(e&xt)*Qo,e<Z)||(e=r[t+7],n+=(e&xt)*jo,e<Z))return n;throw new RangeError("Could not decode varint")}function vf(r,t){let e=r.get(t),n=0;if(n+=e&xt,e<Z||(e=r.get(t+1),n+=(e&xt)<<7,e<Z)||(e=r.get(t+2),n+=(e&xt)<<14,e<Z)||(e=r.get(t+3),n+=(e&xt)<<21,e<Z)||(e=r.get(t+4),n+=(e&xt)*Yo,e<Z)||(e=r.get(t+5),n+=(e&xt)*Xo,e<Z)||(e=r.get(t+6),n+=(e&xt)*Qo,e<Z)||(e=r.get(t+7),n+=(e&xt)*jo,e<Z))return n;throw new RangeError("Could not decode varint")}function kt(r,t,e=0){return t==null&&(t=Rt(wt(r))),t instanceof Uint8Array?Jo(r,t,e):Ef(r,t,e)}function ae(r,t=0){return r instanceof Uint8Array?ti(r,t):vf(r,t)}var ei=new Float32Array([-0]),xe=new Uint8Array(ei.buffer);function _a(r,t,e){ei[0]=r,t[e]=xe[0],t[e+1]=xe[1],t[e+2]=xe[2],t[e+3]=xe[3]}function Ia(r,t){return xe[0]=r[t],xe[1]=r[t+1],xe[2]=r[t+2],xe[3]=r[t+3],ei[0]}var ri=new Float64Array([-0]),Et=new Uint8Array(ri.buffer);function Ta(r,t,e){ri[0]=r,t[e]=Et[0],t[e+1]=Et[1],t[e+2]=Et[2],t[e+3]=Et[3],t[e+4]=Et[4],t[e+5]=Et[5],t[e+6]=Et[6],t[e+7]=Et[7]}function La(r,t){return Et[0]=r[t],Et[1]=r[t+1],Et[2]=r[t+2],Et[3]=r[t+3],Et[4]=r[t+4],Et[5]=r[t+5],Et[6]=r[t+6],Et[7]=r[t+7],ri[0]}var Sf=BigInt(Number.MAX_SAFE_INTEGER),Af=BigInt(Number.MIN_SAFE_INTEGER),Pt=class r{lo;hi;constructor(t,e){this.lo=t|0,this.hi=e|0}toNumber(t=!1){if(!t&&this.hi>>>31>0){let e=~this.lo+1>>>0,n=~this.hi>>>0;return e===0&&(n=n+1>>>0),-(e+n*4294967296)}return this.lo+this.hi*4294967296}toBigInt(t=!1){if(t)return BigInt(this.lo>>>0)+(BigInt(this.hi>>>0)<<32n);if(this.hi>>>31){let e=~this.lo+1>>>0,n=~this.hi>>>0;return e===0&&(n=n+1>>>0),-(BigInt(e)+(BigInt(n)<<32n))}return BigInt(this.lo>>>0)+(BigInt(this.hi>>>0)<<32n)}toString(t=!1){return this.toBigInt(t).toString()}zzEncode(){let t=this.hi>>31;return this.hi=((this.hi<<1|this.lo>>>31)^t)>>>0,this.lo=(this.lo<<1^t)>>>0,this}zzDecode(){let t=-(this.lo&1);return this.lo=((this.lo>>>1|this.hi<<31)^t)>>>0,this.hi=(this.hi>>>1^t)>>>0,this}length(){let t=this.lo,e=(this.lo>>>28|this.hi<<4)>>>0,n=this.hi>>>24;return n===0?e===0?t<16384?t<128?1:2:t<2097152?3:4:e<16384?e<128?5:6:e<2097152?7:8:n<128?9:10}static fromBigInt(t){if(t===0n)return Pe;if(t<Sf&&t>Af)return this.fromNumber(Number(t));let e=t<0n;e&&(t=-t);let n=t>>32n,o=t-(n<<32n);return e&&(n=~n|0n,o=~o|0n,++o>Ra&&(o=0n,++n>Ra&&(n=0n))),new r(Number(o),Number(n))}static fromNumber(t){if(t===0)return Pe;let e=t<0;e&&(t=-t);let n=t>>>0,o=(t-n)/4294967296>>>0;return e&&(o=~o>>>0,n=~n>>>0,++n>4294967295&&(n=0,++o>4294967295&&(o=0))),new r(n,o)}static from(t){return typeof t=="number"?r.fromNumber(t):typeof t=="bigint"?r.fromBigInt(t):typeof t=="string"?r.fromBigInt(BigInt(t)):t.low!=null||t.high!=null?new r(t.low>>>0,t.high>>>0):Pe}},Pe=new Pt(0,0);Pe.toBigInt=function(){return 0n};Pe.zzEncode=Pe.zzDecode=function(){return this};Pe.length=function(){return 1};var Ra=4294967296n;function Ba(r){let t=0,e=0;for(let n=0;n<r.length;++n)e=r.charCodeAt(n),e<128?t+=1:e<2048?t+=2:(e&64512)===55296&&(r.charCodeAt(n+1)&64512)===56320?(++n,t+=4):t+=3;return t}function Ca(r,t,e){if(e-t<1)return"";let o,i=[],s=0,a;for(;t<e;)a=r[t++],a<128?i[s++]=a:a>191&&a<224?i[s++]=(a&31)<<6|r[t++]&63:a>239&&a<365?(a=((a&7)<<18|(r[t++]&63)<<12|(r[t++]&63)<<6|r[t++]&63)-65536,i[s++]=55296+(a>>10),i[s++]=56320+(a&1023)):i[s++]=(a&15)<<12|(r[t++]&63)<<6|r[t++]&63,s>8191&&((o??(o=[])).push(String.fromCharCode.apply(String,i)),s=0);return o!=null?(s>0&&o.push(String.fromCharCode.apply(String,i.slice(0,s))),o.join("")):String.fromCharCode.apply(String,i.slice(0,s))}function ni(r,t,e){let n=e,o,i;for(let s=0;s<r.length;++s)o=r.charCodeAt(s),o<128?t[e++]=o:o<2048?(t[e++]=o>>6|192,t[e++]=o&63|128):(o&64512)===55296&&((i=r.charCodeAt(s+1))&64512)===56320?(o=65536+((o&1023)<<10)+(i&1023),++s,t[e++]=o>>18|240,t[e++]=o>>12&63|128,t[e++]=o>>6&63|128,t[e++]=o&63|128):(t[e++]=o>>12|224,t[e++]=o>>6&63|128,t[e++]=o&63|128);return e-n}function Gt(r,t){return RangeError(`index out of range: ${r.pos} + ${t??1} > ${r.len}`)}function un(r,t){return(r[t-4]|r[t-3]<<8|r[t-2]<<16|r[t-1]<<24)>>>0}var oi=class{buf;pos;len;_slice=Uint8Array.prototype.subarray;constructor(t){this.buf=t,this.pos=0,this.len=t.length}uint32(){let t=4294967295;if(t=(this.buf[this.pos]&127)>>>0,this.buf[this.pos++]<128||(t=(t|(this.buf[this.pos]&127)<<7)>>>0,this.buf[this.pos++]<128)||(t=(t|(this.buf[this.pos]&127)<<14)>>>0,this.buf[this.pos++]<128)||(t=(t|(this.buf[this.pos]&127)<<21)>>>0,this.buf[this.pos++]<128)||(t=(t|(this.buf[this.pos]&15)<<28)>>>0,this.buf[this.pos++]<128))return t;if((this.pos+=5)>this.len)throw this.pos=this.len,Gt(this,10);return t}int32(){return this.uint32()|0}sint32(){let t=this.uint32();return t>>>1^-(t&1)|0}bool(){return this.uint32()!==0}fixed32(){if(this.pos+4>this.len)throw Gt(this,4);return un(this.buf,this.pos+=4)}sfixed32(){if(this.pos+4>this.len)throw Gt(this,4);return un(this.buf,this.pos+=4)|0}float(){if(this.pos+4>this.len)throw Gt(this,4);let t=Ia(this.buf,this.pos);return this.pos+=4,t}double(){if(this.pos+8>this.len)throw Gt(this,4);let t=La(this.buf,this.pos);return this.pos+=8,t}bytes(){let t=this.uint32(),e=this.pos,n=this.pos+t;if(n>this.len)throw Gt(this,t);return this.pos+=t,e===n?new Uint8Array(0):this.buf.subarray(e,n)}string(){let t=this.bytes();return Ca(t,0,t.length)}skip(t){if(typeof t=="number"){if(this.pos+t>this.len)throw Gt(this,t);this.pos+=t}else do if(this.pos>=this.len)throw Gt(this);while((this.buf[this.pos++]&128)!==0);return this}skipType(t){switch(t){case 0:this.skip();break;case 1:this.skip(8);break;case 2:this.skip(this.uint32());break;case 3:for(;(t=this.uint32()&7)!==4;)this.skipType(t);break;case 5:this.skip(4);break;default:throw Error(`invalid wire type ${t} at offset ${this.pos}`)}return this}readLongVarint(){let t=new Pt(0,0),e=0;if(this.len-this.pos>4){for(;e<4;++e)if(t.lo=(t.lo|(this.buf[this.pos]&127)<<e*7)>>>0,this.buf[this.pos++]<128)return t;if(t.lo=(t.lo|(this.buf[this.pos]&127)<<28)>>>0,t.hi=(t.hi|(this.buf[this.pos]&127)>>4)>>>0,this.buf[this.pos++]<128)return t;e=0}else{for(;e<3;++e){if(this.pos>=this.len)throw Gt(this);if(t.lo=(t.lo|(this.buf[this.pos]&127)<<e*7)>>>0,this.buf[this.pos++]<128)return t}return t.lo=(t.lo|(this.buf[this.pos++]&127)<<e*7)>>>0,t}if(this.len-this.pos>4){for(;e<5;++e)if(t.hi=(t.hi|(this.buf[this.pos]&127)<<e*7+3)>>>0,this.buf[this.pos++]<128)return t}else for(;e<5;++e){if(this.pos>=this.len)throw Gt(this);if(t.hi=(t.hi|(this.buf[this.pos]&127)<<e*7+3)>>>0,this.buf[this.pos++]<128)return t}throw Error("invalid varint encoding")}readFixed64(){if(this.pos+8>this.len)throw Gt(this,8);let t=un(this.buf,this.pos+=4),e=un(this.buf,this.pos+=4);return new Pt(t,e)}int64(){return this.readLongVarint().toBigInt()}int64Number(){return this.readLongVarint().toNumber()}int64String(){return this.readLongVarint().toString()}uint64(){return this.readLongVarint().toBigInt(!0)}uint64Number(){let t=ti(this.buf,this.pos);return this.pos+=wt(t),t}uint64String(){return this.readLongVarint().toString(!0)}sint64(){return this.readLongVarint().zzDecode().toBigInt()}sint64Number(){return this.readLongVarint().zzDecode().toNumber()}sint64String(){return this.readLongVarint().zzDecode().toString()}fixed64(){return this.readFixed64().toBigInt()}fixed64Number(){return this.readFixed64().toNumber()}fixed64String(){return this.readFixed64().toString()}sfixed64(){return this.readFixed64().toBigInt()}sfixed64Number(){return this.readFixed64().toNumber()}sfixed64String(){return this.readFixed64().toString()}};function ii(r){return new oi(r instanceof Uint8Array?r:r.subarray())}function Bt(r,t,e){let n=ii(r);return t.decode(n,void 0,e)}var si={};_t(si,{base10:()=>_f});var _f=fe({prefix:"9",name:"base10",alphabet:"0123456789"});var ai={};_t(ai,{base16:()=>If,base16upper:()=>Tf});var If=st({prefix:"f",name:"base16",alphabet:"0123456789abcdef",bitsPerChar:4}),Tf=st({prefix:"F",name:"base16upper",alphabet:"0123456789ABCDEF",bitsPerChar:4});var ci={};_t(ci,{base2:()=>Lf});var Lf=st({prefix:"0",name:"base2",alphabet:"01",bitsPerChar:1});var ui={};_t(ui,{base256emoji:()=>Pf});var Pa=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}"),Rf=Pa.reduce((r,t,e)=>(r[e]=t,r),[]),Bf=Pa.reduce((r,t,e)=>{let n=t.codePointAt(0);if(n==null)throw new Error(`Invalid character: ${t}`);return r[n]=e,r},[]);function Cf(r){return r.reduce((t,e)=>(t+=Rf[e],t),"")}function Df(r){let t=[];for(let e of r){let n=e.codePointAt(0);if(n==null)throw new Error(`Invalid character: ${e}`);let o=Bf[n];if(o==null)throw new Error(`Non-base256emoji character: ${e}`);t.push(o)}return new Uint8Array(t)}var Pf=Ve({prefix:"\u{1F680}",name:"base256emoji",encode:Cf,decode:Df});var fi={};_t(fi,{base64:()=>Nf,base64pad:()=>Uf,base64url:()=>li,base64urlpad:()=>Of});var Nf=st({prefix:"m",name:"base64",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/",bitsPerChar:6}),Uf=st({prefix:"M",name:"base64pad",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/=",bitsPerChar:6}),li=st({prefix:"u",name:"base64url",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789-_",bitsPerChar:6}),Of=st({prefix:"U",name:"base64urlpad",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789-_=",bitsPerChar:6});var hi={};_t(hi,{base8:()=>Mf});var Mf=st({prefix:"7",name:"base8",alphabet:"01234567",bitsPerChar:3});var di={};_t(di,{identity:()=>kf});var kf=Ve({prefix:"\0",name:"identity",encode:r=>zs(r),decode:r=>Fs(r)});var wm=new TextEncoder,Em=new TextDecoder;var yi={};_t(yi,{sha256:()=>je,sha512:()=>Ff});function mi({name:r,code:t,encode:e}){return new pi(r,t,e)}var pi=class{name;code;encode;constructor(t,e,n){this.name=t,this.code=e,this.encode=n}digest(t){if(t instanceof Uint8Array){let e=this.encode(t);return e instanceof Uint8Array?Ft(this.code,e):e.then(n=>Ft(this.code,n))}else throw Error("Unknown type, must be binary type")}};function Ua(r){return async t=>new Uint8Array(await crypto.subtle.digest(r,t))}var je=mi({name:"sha2-256",code:18,encode:Ua("SHA-256")}),Ff=mi({name:"sha2-512",code:19,encode:Ua("SHA-512")});var vr={...di,...ci,...hi,...si,...ai,..._o,...Io,...Ao,...fi,...ui},Pm={...yi,...Ro};function Ma(r,t,e,n){return{name:r,prefix:t,encoder:{name:r,prefix:t,encode:e},decoder:{decode:n}}}var Oa=Ma("utf8","u",r=>"u"+new TextDecoder("utf8").decode(r),r=>new TextEncoder().encode(r.substring(1))),gi=Ma("ascii","a",r=>{let t="a";for(let e=0;e<r.length;e++)t+=String.fromCharCode(r[e]);return t},r=>{r=r.substring(1);let t=Rt(r.length);for(let e=0;e<r.length;e++)t[e]=r.charCodeAt(e);return t}),zf={utf8:Oa,"utf-8":Oa,hex:vr.base16,latin1:gi,ascii:gi,binary:gi,...vr},ln=zf;function z(r,t="utf8"){let e=ln[t];if(e==null)throw new Error(`Unsupported encoding "${t}"`);return e.decoder.decode(`${e.prefix}${r}`)}function bi(r){let t=r??8192,e=t>>>1,n,o=t;return function(s){if(s<1||s>e)return Rt(s);o+s>t&&(n=Rt(t),o=0);let a=n.subarray(o,o+=s);return(o&7)!==0&&(o=(o|7)+1),a}}var Ne=class{fn;len;next;val;constructor(t,e,n){this.fn=t,this.len=e,this.next=void 0,this.val=n}};function xi(){}var Ei=class{head;tail;len;next;constructor(t){this.head=t.head,this.tail=t.tail,this.len=t.len,this.next=t.states}},Vf=bi();function Hf(r){return globalThis.Buffer!=null?Rt(r):Vf(r)}var Ar=class{len;head;tail;states;constructor(){this.len=0,this.head=new Ne(xi,0,0),this.tail=this.head,this.states=null}_push(t,e,n){return this.tail=this.tail.next=new Ne(t,e,n),this.len+=e,this}uint32(t){return this.len+=(this.tail=this.tail.next=new vi((t=t>>>0)<128?1:t<16384?2:t<2097152?3:t<268435456?4:5,t)).len,this}int32(t){return t<0?this._push(fn,10,Pt.fromNumber(t)):this.uint32(t)}sint32(t){return this.uint32((t<<1^t>>31)>>>0)}uint64(t){let e=Pt.fromBigInt(t);return this._push(fn,e.length(),e)}uint64Number(t){return this._push(Jo,wt(t),t)}uint64String(t){return this.uint64(BigInt(t))}int64(t){return this.uint64(t)}int64Number(t){return this.uint64Number(t)}int64String(t){return this.uint64String(t)}sint64(t){let e=Pt.fromBigInt(t).zzEncode();return this._push(fn,e.length(),e)}sint64Number(t){let e=Pt.fromNumber(t).zzEncode();return this._push(fn,e.length(),e)}sint64String(t){return this.sint64(BigInt(t))}bool(t){return this._push(wi,1,t?1:0)}fixed32(t){return this._push(Sr,4,t>>>0)}sfixed32(t){return this.fixed32(t)}fixed64(t){let e=Pt.fromBigInt(t);return this._push(Sr,4,e.lo)._push(Sr,4,e.hi)}fixed64Number(t){let e=Pt.fromNumber(t);return this._push(Sr,4,e.lo)._push(Sr,4,e.hi)}fixed64String(t){return this.fixed64(BigInt(t))}sfixed64(t){return this.fixed64(t)}sfixed64Number(t){return this.fixed64Number(t)}sfixed64String(t){return this.fixed64String(t)}float(t){return this._push(_a,4,t)}double(t){return this._push(Ta,8,t)}bytes(t){let e=t.length>>>0;return e===0?this._push(wi,1,0):this.uint32(e)._push(Zf,e,t)}string(t){let e=Ba(t);return e!==0?this.uint32(e)._push(ni,e,t):this._push(wi,1,0)}fork(){return this.states=new Ei(this),this.head=this.tail=new Ne(xi,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 Ne(xi,0,0),this.len=0),this}ldelim(){let t=this.head,e=this.tail,n=this.len;return this.reset().uint32(n),n!==0&&(this.tail.next=t.next,this.tail=e,this.len+=n),this}finish(){let t=this.head.next,e=Hf(this.len),n=0;for(;t!=null;)t.fn(t.val,e,n),n+=t.len,t=t.next;return e}};function wi(r,t,e){t[e]=r&255}function Gf(r,t,e){for(;r>127;)t[e++]=r&127|128,r>>>=7;t[e]=r}var vi=class extends Ne{next;constructor(t,e){super(Gf,t,e),this.next=void 0}};function fn(r,t,e){for(;r.hi!==0;)t[e++]=r.lo&127|128,r.lo=(r.lo>>>7|r.hi<<25)>>>0,r.hi>>>=7;for(;r.lo>127;)t[e++]=r.lo&127|128,r.lo=r.lo>>>7;t[e++]=r.lo}function Sr(r,t,e){t[e]=r&255,t[e+1]=r>>>8&255,t[e+2]=r>>>16&255,t[e+3]=r>>>24}function Zf(r,t,e){t.set(r,e)}globalThis.Buffer!=null&&(Ar.prototype.bytes=function(r){let t=r.length>>>0;return this.uint32(t),t>0&&this._push(Wf,t,r),this},Ar.prototype.string=function(r){let t=globalThis.Buffer.byteLength(r);return this.uint32(t),t>0&&this._push($f,t,r),this});function Wf(r,t,e){t.set(r,e)}function $f(r,t,e){r.length<40?ni(r,t,e):t.utf8Write!=null?t.utf8Write(r,e):t.set(z(r),e)}function Si(){return new Ar}function Ct(r,t){let e=Si();return t.encode(r,e,{lengthDelimited:!1}),e.finish()}var Je;(function(r){r[r.VARINT=0]="VARINT",r[r.BIT64=1]="BIT64",r[r.LENGTH_DELIMITED=2]="LENGTH_DELIMITED",r[r.START_GROUP=3]="START_GROUP",r[r.END_GROUP=4]="END_GROUP",r[r.BIT32=5]="BIT32"})(Je||(Je={}));function hn(r,t,e,n){return{name:r,type:t,encode:e,decode:n}}function Ue(r){function t(o){if(r[o.toString()]==null)throw new Error("Invalid enum value");return r[o]}let e=function(i,s){let a=t(i);s.int32(a)},n=function(i){let s=i.int32();return t(s)};return hn("enum",Je.VARINT,e,n)}function Dt(r,t){return hn("message",Je.LENGTH_DELIMITED,r,t)}var _r=class extends Error{code="ERR_MAX_LENGTH";name="MaxLengthError"};var lt;(function(r){r.RSA="RSA",r.Ed25519="Ed25519",r.secp256k1="secp256k1"})(lt||(lt={}));var Ai;(function(r){r[r.RSA=0]="RSA",r[r.Ed25519=1]="Ed25519",r[r.secp256k1=2]="secp256k1"})(Ai||(Ai={}));(function(r){r.codec=()=>Ue(Ai)})(lt||(lt={}));var Qt;(function(r){let t;r.codec=()=>(t==null&&(t=Dt((e,n,o={})=>{o.lengthDelimited!==!1&&n.fork(),e.Type!=null&&(n.uint32(8),lt.codec().encode(e.Type,n)),e.Data!=null&&(n.uint32(18),n.bytes(e.Data)),o.lengthDelimited!==!1&&n.ldelim()},(e,n,o={})=>{let i={},s=n==null?e.len:e.pos+n;for(;e.pos<s;){let a=e.uint32();switch(a>>>3){case 1:{i.Type=lt.codec().decode(e);break}case 2:{i.Data=e.bytes();break}default:{e.skipType(a&7);break}}}return i})),t),r.encode=e=>Ct(e,r.codec()),r.decode=(e,n)=>Bt(e,r.codec(),n)})(Qt||(Qt={}));var _i;(function(r){let t;r.codec=()=>(t==null&&(t=Dt((e,n,o={})=>{o.lengthDelimited!==!1&&n.fork(),e.Type!=null&&(n.uint32(8),lt.codec().encode(e.Type,n)),e.Data!=null&&(n.uint32(18),n.bytes(e.Data)),o.lengthDelimited!==!1&&n.ldelim()},(e,n,o={})=>{let i={},s=n==null?e.len:e.pos+n;for(;e.pos<s;){let a=e.uint32();switch(a>>>3){case 1:{i.Type=lt.codec().decode(e);break}case 2:{i.Data=e.bytes();break}default:{e.skipType(a&7);break}}}return i})),t),r.encode=e=>Ct(e,r.codec()),r.decode=(e,n)=>Bt(e,r.codec(),n)})(_i||(_i={}));var Lr={};_t(Lr,{MAX_RSA_KEY_SIZE:()=>Bi,generateRSAKeyPair:()=>ja,jwkToJWKKeyPair:()=>Ja,jwkToPkcs1:()=>sh,jwkToPkix:()=>Di,jwkToRSAPrivateKey:()=>Qa,pkcs1ToJwk:()=>$a,pkcs1ToRSAPrivateKey:()=>Xa,pkixToJwk:()=>Ya,pkixToRSAPublicKey:()=>Pi});var Yf=new Uint32Array([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]),we=new Uint32Array([1779033703,3144134277,1013904242,2773480762,1359893119,2600822924,528734635,1541459225]),Ee=new Uint32Array(64),Ii=class extends Xe{constructor(){super(64,32,8,!1),this.A=we[0]|0,this.B=we[1]|0,this.C=we[2]|0,this.D=we[3]|0,this.E=we[4]|0,this.F=we[5]|0,this.G=we[6]|0,this.H=we[7]|0}get(){let{A:t,B:e,C:n,D:o,E:i,F:s,G:a,H:c}=this;return[t,e,n,o,i,s,a,c]}set(t,e,n,o,i,s,a,c){this.A=t|0,this.B=e|0,this.C=n|0,this.D=o|0,this.E=i|0,this.F=s|0,this.G=a|0,this.H=c|0}process(t,e){for(let f=0;f<16;f++,e+=4)Ee[f]=t.getUint32(e,!1);for(let f=16;f<64;f++){let d=Ee[f-15],g=Ee[f-2],y=zt(d,7)^zt(d,18)^d>>>3,b=zt(g,17)^zt(g,19)^g>>>10;Ee[f]=b+Ee[f-7]+y+Ee[f-16]|0}let{A:n,B:o,C:i,D:s,E:a,F:c,G:l,H:u}=this;for(let f=0;f<64;f++){let d=zt(a,6)^zt(a,11)^zt(a,25),g=u+d+ia(a,c,l)+Yf[f]+Ee[f]|0,b=(zt(n,2)^zt(n,13)^zt(n,22))+sa(n,o,i)|0;u=l,l=c,c=a,a=s+g|0,s=i,i=o,o=n,n=g+b|0}n=n+this.A|0,o=o+this.B|0,i=i+this.C|0,s=s+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,o,i,s,a,c,l,u)}roundClean(){Ee.fill(0)}destroy(){this.set(0,0,0,0,0,0,0,0),this.buffer.fill(0)}};var tr=$r(()=>new Ii);function H(r,t="utf8"){let e=ln[t];if(e==null)throw new Error(`Unsupported encoding "${t}"`);return e.encoder.encode(r).substring(1)}function Nt(r,t){t==null&&(t=r.reduce((o,i)=>o+i.length,0));let e=Rt(t),n=0;for(let o of r)e.set(o,n),n+=o.length;return e}var qa=Symbol.for("@achingbrain/uint8arraylist");function Ka(r,t){if(t==null||t<0)throw new RangeError("index is out of bounds");let e=0;for(let n of r){let o=e+n.byteLength;if(t<o)return{buf:n,index:t-e};e=o}throw new RangeError("index is out of bounds")}function dn(r){return!!r?.[qa]}var at=class r{bufs;length;[qa]=!0;constructor(...t){this.bufs=[],this.length=0,t.length>0&&this.appendAll(t)}*[Symbol.iterator](){yield*this.bufs}get byteLength(){return this.length}append(...t){this.appendAll(t)}appendAll(t){let e=0;for(let n of t)if(n instanceof Uint8Array)e+=n.byteLength,this.bufs.push(n);else if(dn(n))e+=n.byteLength,this.bufs.push(...n.bufs);else throw new Error("Could not append value, must be an Uint8Array or a Uint8ArrayList");this.length+=e}prepend(...t){this.prependAll(t)}prependAll(t){let e=0;for(let n of t.reverse())if(n instanceof Uint8Array)e+=n.byteLength,this.bufs.unshift(n);else if(dn(n))e+=n.byteLength,this.bufs.unshift(...n.bufs);else throw new Error("Could not prepend value, must be an Uint8Array or a Uint8ArrayList");this.length+=e}get(t){let e=Ka(this.bufs,t);return e.buf[e.index]}set(t,e){let n=Ka(this.bufs,t);n.buf[n.index]=e}write(t,e=0){if(t instanceof Uint8Array)for(let n=0;n<t.length;n++)this.set(e+n,t[n]);else if(dn(t))for(let n=0;n<t.length;n++)this.set(e+n,t.get(n));else throw new Error("Could not write value, must be an Uint8Array or a Uint8ArrayList")}consume(t){if(t=Math.trunc(t),!(Number.isNaN(t)||t<=0)){if(t===this.byteLength){this.bufs=[],this.length=0;return}for(;this.bufs.length>0;)if(t>=this.bufs[0].byteLength)t-=this.bufs[0].byteLength,this.length-=this.bufs[0].byteLength,this.bufs.shift();else{this.bufs[0]=this.bufs[0].subarray(t),this.length-=t;break}}}slice(t,e){let{bufs:n,length:o}=this._subList(t,e);return Nt(n,o)}subarray(t,e){let{bufs:n,length:o}=this._subList(t,e);return n.length===1?n[0]:Nt(n,o)}sublist(t,e){let{bufs:n,length:o}=this._subList(t,e),i=new r;return i.length=o,i.bufs=[...n],i}_subList(t,e){if(t=t??0,e=e??this.length,t<0&&(t=this.length+t),e<0&&(e=this.length+e),t<0||e>this.length)throw new RangeError("index is out of bounds");if(t===e)return{bufs:[],length:0};if(t===0&&e===this.length)return{bufs:this.bufs,length:this.length};let n=[],o=0;for(let i=0;i<this.bufs.length;i++){let s=this.bufs[i],a=o,c=a+s.byteLength;if(o=c,t>=c)continue;let l=t>=a&&t<c,u=e>a&&e<=c;if(l&&u){if(t===a&&e===c){n.push(s);break}let f=t-a;n.push(s.subarray(f,f+(e-t)));break}if(l){if(t===0){n.push(s);continue}n.push(s.subarray(t-a));continue}if(u){if(e===c){n.push(s);break}n.push(s.subarray(0,e-a));break}n.push(s)}return{bufs:n,length:e-t}}indexOf(t,e=0){if(!dn(t)&&!(t instanceof Uint8Array))throw new TypeError('The "value" argument must be a Uint8ArrayList or Uint8Array');let n=t instanceof Uint8Array?t:t.subarray();if(e=Number(e??0),isNaN(e)&&(e=0),e<0&&(e=this.length+e),e<0&&(e=0),t.length===0)return e>this.length?this.length:e;let o=n.byteLength;if(o===0)throw new TypeError("search must be at least 1 byte long");let i=256,s=new Int32Array(i);for(let f=0;f<i;f++)s[f]=-1;for(let f=0;f<o;f++)s[n[f]]=f;let a=s,c=this.byteLength-n.byteLength,l=n.byteLength-1,u;for(let f=e;f<=c;f+=u){u=0;for(let d=l;d>=0;d--){let g=this.get(f+d);if(n[d]!==g){u=Math.max(1,d-a[g]);break}}if(u===0)return f}return-1}getInt8(t){let e=this.subarray(t,t+1);return new DataView(e.buffer,e.byteOffset,e.byteLength).getInt8(0)}setInt8(t,e){let n=Rt(1);new DataView(n.buffer,n.byteOffset,n.byteLength).setInt8(0,e),this.write(n,t)}getInt16(t,e){let n=this.subarray(t,t+2);return new DataView(n.buffer,n.byteOffset,n.byteLength).getInt16(0,e)}setInt16(t,e,n){let o=it(2);new DataView(o.buffer,o.byteOffset,o.byteLength).setInt16(0,e,n),this.write(o,t)}getInt32(t,e){let n=this.subarray(t,t+4);return new DataView(n.buffer,n.byteOffset,n.byteLength).getInt32(0,e)}setInt32(t,e,n){let o=it(4);new DataView(o.buffer,o.byteOffset,o.byteLength).setInt32(0,e,n),this.write(o,t)}getBigInt64(t,e){let n=this.subarray(t,t+8);return new DataView(n.buffer,n.byteOffset,n.byteLength).getBigInt64(0,e)}setBigInt64(t,e,n){let o=it(8);new DataView(o.buffer,o.byteOffset,o.byteLength).setBigInt64(0,e,n),this.write(o,t)}getUint8(t){let e=this.subarray(t,t+1);return new DataView(e.buffer,e.byteOffset,e.byteLength).getUint8(0)}setUint8(t,e){let n=Rt(1);new DataView(n.buffer,n.byteOffset,n.byteLength).setUint8(0,e),this.write(n,t)}getUint16(t,e){let n=this.subarray(t,t+2);return new DataView(n.buffer,n.byteOffset,n.byteLength).getUint16(0,e)}setUint16(t,e,n){let o=it(2);new DataView(o.buffer,o.byteOffset,o.byteLength).setUint16(0,e,n),this.write(o,t)}getUint32(t,e){let n=this.subarray(t,t+4);return new DataView(n.buffer,n.byteOffset,n.byteLength).getUint32(0,e)}setUint32(t,e,n){let o=it(4);new DataView(o.buffer,o.byteOffset,o.byteLength).setUint32(0,e,n),this.write(o,t)}getBigUint64(t,e){let n=this.subarray(t,t+8);return new DataView(n.buffer,n.byteOffset,n.byteLength).getBigUint64(0,e)}setBigUint64(t,e,n){let o=it(8);new DataView(o.buffer,o.byteOffset,o.byteLength).setBigUint64(0,e,n),this.write(o,t)}getFloat32(t,e){let n=this.subarray(t,t+4);return new DataView(n.buffer,n.byteOffset,n.byteLength).getFloat32(0,e)}setFloat32(t,e,n){let o=it(4);new DataView(o.buffer,o.byteOffset,o.byteLength).setFloat32(0,e,n),this.write(o,t)}getFloat64(t,e){let n=this.subarray(t,t+8);return new DataView(n.buffer,n.byteOffset,n.byteLength).getFloat64(0,e)}setFloat64(t,e,n){let o=it(8);new DataView(o.buffer,o.byteOffset,o.byteLength).setFloat64(0,e,n),this.write(o,t)}equals(t){if(t==null||!(t instanceof r)||t.bufs.length!==this.bufs.length)return!1;for(let e=0;e<this.bufs.length;e++)if(!pt(this.bufs[e],t.bufs[e]))return!1;return!0}static fromUint8Arrays(t,e){let n=new r;return n.bufs=t,e==null&&(e=t.reduce((o,i)=>o+i.byteLength,0)),n.length=e,n}};var Xf=parseInt("11111",2),Li=parseInt("10000000",2),Qf=parseInt("01111111",2),Fa={2:jf,3:eh,5:th,6:Jf,16:Ti,22:Ti,48:Ti};function Ir(r,t={offset:0}){let e=r[t.offset]&Xf;if(t.offset++,Fa[e]!=null)return Fa[e](r,t);throw new Error("No decoder for tag "+e)}function pn(r,t){let e=0;if((r[t.offset]&Li)===Li){let n=r[t.offset]&Qf,o="0x";t.offset++;for(let i=0;i<n;i++,t.offset++)o+=r[t.offset].toString(16).padStart(2,"0");e=parseInt(o,16)}else e=r[t.offset],t.offset++;return e}function Ti(r,t){pn(r,t);let e=[];for(;!(t.offset>=r.byteLength);){let n=Ir(r,t);if(n===null)break;e.push(n)}return e}function jf(r,t){let e=pn(r,t),n=t.offset,o=t.offset+e,i=[];for(let s=n;s<o;s++)s===n&&r[s]===0||i.push(r[s]);return t.offset+=e,Uint8Array.from(i)}function Jf(r,t){let e=pn(r,t);return t.offset+=e,["oid-unimplemented"]}function th(r,t){return t.offset++,null}function eh(r,t){let e=pn(r,t),n=r[t.offset];t.offset++;let o=r.subarray(t.offset,t.offset+e);if(t.offset+=e,n!==0)throw new Error("Unused bits in bit string is unimplemented");return Ir(o,{offset:0})}function rh(r){let t=r.toString(16);t.length%2===1&&(t="0"+t);let e=new at;for(let n=0;n<t.length;n+=2)e.append(Uint8Array.from([parseInt(`${t[n]}${t[n+1]}`,16)]));return e}function Ri(r){if(r.byteLength<128)return Uint8Array.from([r.byteLength]);let t=rh(r.byteLength);return new at(Uint8Array.from([t.byteLength|Li]),t)}function Kt(r){let t=new at,e=parseInt("10000000",2);return(r.subarray()[0]&e)===e&&t.append(Uint8Array.from([0])),t.append(r),new at(Uint8Array.from([2]),Ri(t),t)}function za(r){let t=Uint8Array.from([0]),e=new at(t,r);return new at(Uint8Array.from([3]),Ri(e),e)}function mn(r){let t=new at;for(let e of r)t.append(e);return new at(Uint8Array.from([48]),Ri(t),t)}var Tr=class extends Error{constructor(t="An error occurred while verifying a message"){super(t),this.name="VerificationError"}},yn=class extends Error{constructor(t="Missing Web Crypto API"){super(t),this.name="WebCryptoMissingError"}};var Va={get(r=globalThis){let t=r.crypto;if(t?.subtle==null)throw new yn("Missing Web Crypto API. The most likely cause of this error is that this page is being accessed from an insecure context (i.e. not HTTPS). For more information and possible resolutions see https://github.com/libp2p/js-libp2p/blob/main/packages/crypto/README.md#web-crypto-api");return t}};var ve=Va;async function Ha(r){let t=await ve.get().subtle.generateKey({name:"RSASSA-PKCS1-v1_5",modulusLength:r,publicExponent:new Uint8Array([1,0,1]),hash:{name:"SHA-256"}},!0,["sign","verify"]),e=await nh(t);return{privateKey:e[0],publicKey:e[1]}}async function Ga(r,t){let e=await ve.get().subtle.importKey("jwk",r,{name:"RSASSA-PKCS1-v1_5",hash:{name:"SHA-256"}},!1,["sign"]),n=await ve.get().subtle.sign({name:"RSASSA-PKCS1-v1_5"},e,t instanceof Uint8Array?t:t.subarray());return new Uint8Array(n,0,n.byteLength)}async function Za(r,t,e){let n=await ve.get().subtle.importKey("jwk",r,{name:"RSASSA-PKCS1-v1_5",hash:{name:"SHA-256"}},!1,["verify"]);return ve.get().subtle.verify({name:"RSASSA-PKCS1-v1_5"},n,t,e instanceof Uint8Array?e:e.subarray())}async function nh(r){if(r.privateKey==null||r.publicKey==null)throw new bt("Private and public key are required");return Promise.all([ve.get().subtle.exportKey("jwk",r.privateKey),ve.get().subtle.exportKey("jwk",r.publicKey)])}function Wa(r){if(r.kty!=="RSA")throw new bt("invalid key type");if(r.n==null)throw new bt("invalid key modulus");return z(r.n,"base64url").length*8}var er=class{type="RSA";_key;_raw;_multihash;constructor(t,e){this._key=t,this._multihash=e}get raw(){return this._raw==null&&(this._raw=Lr.jwkToPkix(this._key)),this._raw}toMultihash(){return this._multihash}toCID(){return dt.createV1(114,this._multihash)}toString(){return Q.encode(this.toMultihash().bytes).substring(1)}equals(t){return t==null||!(t.raw instanceof Uint8Array)?!1:pt(this.raw,t.raw)}verify(t,e){return Za(this._key,e,t)}},Rr=class{type="RSA";_key;_raw;publicKey;constructor(t,e){this._key=t,this.publicKey=e}get raw(){return this._raw==null&&(this._raw=Lr.jwkToPkcs1(this._key)),this._raw}equals(t){return t==null||!(t.raw instanceof Uint8Array)?!1:pt(this.raw,t.raw)}sign(t){return Ga(this._key,t)}};var Bi=8192,Ci=18,oh=1062,ih=Uint8Array.from([48,13,6,9,42,134,72,134,247,13,1,1,1,5,0]);function $a(r){let t=Ir(r);return{n:H(t[1],"base64url"),e:H(t[2],"base64url"),d:H(t[3],"base64url"),p:H(t[4],"base64url"),q:H(t[5],"base64url"),dp:H(t[6],"base64url"),dq:H(t[7],"base64url"),qi:H(t[8],"base64url"),kty:"RSA"}}function sh(r){if(r.n==null||r.e==null||r.d==null||r.p==null||r.q==null||r.dp==null||r.dq==null||r.qi==null)throw new bt("JWK was missing components");return mn([Kt(Uint8Array.from([0])),Kt(z(r.n,"base64url")),Kt(z(r.e,"base64url")),Kt(z(r.d,"base64url")),Kt(z(r.p,"base64url")),Kt(z(r.q,"base64url")),Kt(z(r.dp,"base64url")),Kt(z(r.dq,"base64url")),Kt(z(r.qi,"base64url"))]).subarray()}function Ya(r){let t=Ir(r,{offset:0});return{kty:"RSA",n:H(t[1][0],"base64url"),e:H(t[1][1],"base64url")}}function Di(r){if(r.n==null||r.e==null)throw new bt("JWK was missing components");return mn([ih,za(mn([Kt(z(r.n,"base64url")),Kt(z(r.e,"base64url"))]))]).subarray()}function Xa(r){let t=$a(r);return Qa(t)}function Pi(r,t){if(r.byteLength>=oh)throw new Fe("Key size is too large");let e=Ya(r);if(t==null){let n=tr(Qt.encode({Type:lt.RSA,Data:r}));t=Ft(Ci,n)}return new er(e,t)}function Qa(r){if(Wa(r)>Bi)throw new bt("Key size is too large");let t=Ja(r),e=tr(Qt.encode({Type:lt.RSA,Data:Di(t.publicKey)})),n=Ft(Ci,e);return new Rr(t.privateKey,new er(t.publicKey,n))}async function ja(r){if(r>Bi)throw new bt("Key size is too large");let t=await Ha(r),e=tr(Qt.encode({Type:lt.RSA,Data:Di(t.publicKey)})),n=Ft(Ci,e);return new Rr(t.privateKey,new er(t.publicKey,n))}function Ja(r){if(r==null)throw new bt("Missing key parameter");return{privateKey:r,publicKey:{kty:r.kty,n:r.n,e:r.e}}}var gn=class extends Ye{constructor(t,e){super(),this.finished=!1,this.destroyed=!1,ra(t);let n=br(e);if(this.iHash=t.create(),typeof this.iHash.update!="function")throw new Error("Expected instance of class which extends utils.Hash");this.blockLen=this.iHash.blockLen,this.outputLen=this.iHash.outputLen;let o=this.blockLen,i=new Uint8Array(o);i.set(n.length>o?t.create().update(n).digest():n);for(let s=0;s<i.length;s++)i[s]^=54;this.iHash.update(i),this.oHash=t.create();for(let s=0;s<i.length;s++)i[s]^=106;this.oHash.update(i),i.fill(0)}update(t){return $e(this),this.iHash.update(t),this}digestInto(t){$e(this),We(t,this.outputLen),this.finished=!0,this.iHash.digestInto(t),this.oHash.update(t),this.oHash.digestInto(t),this.destroy()}digest(){let t=new Uint8Array(this.oHash.outputLen);return this.digestInto(t),t}_cloneInto(t){t||(t=Object.create(Object.getPrototypeOf(this),{}));let{oHash:e,iHash:n,finished:o,destroyed:i,blockLen:s,outputLen:a}=this;return t=t,t.finished=o,t.destroyed=i,t.blockLen=s,t.outputLen=a,t.oHash=e._cloneInto(t.oHash),t.iHash=n._cloneInto(t.iHash),t}destroy(){this.destroyed=!0,this.oHash.destroy(),this.iHash.destroy()}},Ni=(r,t,e)=>new gn(r,t).update(e).digest();Ni.create=(r,t)=>new gn(r,t);function tc(r){r.lowS!==void 0&&Vt("lowS",r.lowS),r.prehash!==void 0&&Vt("prehash",r.prehash)}function ah(r){let t=Er(r);Xt(t,{a:"field",b:"field"},{allowedPrivateKeyLengths:"array",wrapPrivateKey:"boolean",isTorsionFree:"function",clearCofactor:"function",allowInfinityPoint:"boolean",fromBytes:"function",toBytes:"function"});let{endo:e,Fp:n,a:o}=t;if(e){if(!n.eql(o,n.ZERO))throw new Error("invalid endomorphism, can only be defined for Koblitz curves that have a=0");if(typeof e!="object"||typeof e.beta!="bigint"||typeof e.splitScalar!="function")throw new Error("invalid endomorphism, expected beta: bigint and splitScalar: function")}return Object.freeze({...t})}var{bytesToNumberBE:ch,hexToBytes:uh}=Jr,Ui=class extends Error{constructor(t=""){super(t)}},ce={Err:Ui,_tlv:{encode:(r,t)=>{let{Err:e}=ce;if(r<0||r>256)throw new e("tlv.encode: wrong tag");if(t.length&1)throw new e("tlv.encode: unpadded data");let n=t.length/2,o=Le(n);if(o.length/2&128)throw new e("tlv.encode: long form length too big");let i=n>127?Le(o.length/2|128):"";return Le(r)+i+o+t},decode(r,t){let{Err:e}=ce,n=0;if(r<0||r>256)throw new e("tlv.encode: wrong tag");if(t.length<2||t[n++]!==r)throw new e("tlv.decode: wrong tlv");let o=t[n++],i=!!(o&128),s=0;if(!i)s=o;else{let c=o&127;if(!c)throw new e("tlv.decode(long): indefinite length not supported");if(c>4)throw new e("tlv.decode(long): byte length is too big");let l=t.subarray(n,n+c);if(l.length!==c)throw new e("tlv.decode: length bytes not complete");if(l[0]===0)throw new e("tlv.decode(long): zero leftmost byte");for(let u of l)s=s<<8|u;if(n+=c,s<128)throw new e("tlv.decode(long): not minimal encoding")}let a=t.subarray(n,n+s);if(a.length!==s)throw new e("tlv.decode: wrong value length");return{v:a,l:t.subarray(n+s)}}},_int:{encode(r){let{Err:t}=ce;if(r<ue)throw new t("integer: negative integers are not allowed");let e=Le(r);if(Number.parseInt(e[0],16)&8&&(e="00"+e),e.length&1)throw new t("unexpected DER parsing assertion: unpadded hex");return e},decode(r){let{Err:t}=ce;if(r[0]&128)throw new t("invalid signature integer: negative");if(r[0]===0&&!(r[1]&128))throw new t("invalid signature integer: unnecessary leading zero");return ch(r)}},toSig(r){let{Err:t,_int:e,_tlv:n}=ce,o=typeof r=="string"?uh(r):r;Qe(o);let{v:i,l:s}=n.decode(48,o);if(s.length)throw new t("invalid signature: left bytes after parsing");let{v:a,l:c}=n.decode(2,i),{v:l,l:u}=n.decode(2,c);if(u.length)throw new t("invalid signature: left bytes after parsing");return{r:e.decode(a),s:e.decode(l)}},hexFromSig(r){let{_tlv:t,_int:e}=ce,n=t.encode(2,e.encode(r.r)),o=t.encode(2,e.encode(r.s)),i=n+o;return t.encode(48,i)}},ue=BigInt(0),mt=BigInt(1),ey=BigInt(2),ec=BigInt(3),ry=BigInt(4);function lh(r){let t=ah(r),{Fp:e}=t,n=ge(t.n,t.nBitLength),o=t.toBytes||((b,h,w)=>{let v=h.toAffine();return se(Uint8Array.from([4]),e.toBytes(v.x),e.toBytes(v.y))}),i=t.fromBytes||(b=>{let h=b.subarray(1),w=e.fromBytes(h.subarray(0,e.BYTES)),v=e.fromBytes(h.subarray(e.BYTES,2*e.BYTES));return{x:w,y:v}});function s(b){let{a:h,b:w}=t,v=e.sqr(b),m=e.mul(v,b);return e.add(e.add(m,e.mul(b,h)),w)}if(!e.eql(e.sqr(t.Gy),s(t.Gx)))throw new Error("bad generator point: equation left != right");function a(b){return xr(b,mt,t.n)}function c(b){let{allowedPrivateKeyLengths:h,nByteLength:w,wrapPrivateKey:v,n:m}=t;if(h&&typeof b!="bigint"){if(pe(b)&&(b=oe(b)),typeof b!="string"||!h.includes(b.length))throw new Error("invalid private key");b=b.padStart(w*2,"0")}let _;try{_=typeof b=="bigint"?b:ie(ot("private key",b,w))}catch{throw new Error("invalid private key, expected hex or "+w+" bytes, got "+typeof b)}return v&&(_=Y(_,m)),Tt("private key",_,mt,m),_}function l(b){if(!(b instanceof d))throw new Error("ProjectivePoint expected")}let u=Ce((b,h)=>{let{px:w,py:v,pz:m}=b;if(e.eql(m,e.ONE))return{x:w,y:v};let _=b.is0();h==null&&(h=_?e.ONE:e.inv(m));let B=e.mul(w,h),C=e.mul(v,h),I=e.mul(m,h);if(_)return{x:e.ZERO,y:e.ZERO};if(!e.eql(I,e.ONE))throw new Error("invZ was invalid");return{x:B,y:C}}),f=Ce(b=>{if(b.is0()){if(t.allowInfinityPoint&&!e.is0(b.py))return;throw new Error("bad point: ZERO")}let{x:h,y:w}=b.toAffine();if(!e.isValid(h)||!e.isValid(w))throw new Error("bad point: x or y not FE");let v=e.sqr(w),m=s(h);if(!e.eql(v,m))throw new Error("bad point: equation left != right");if(!b.isTorsionFree())throw new Error("bad point: not in prime-order subgroup");return!0});class d{constructor(h,w,v){if(this.px=h,this.py=w,this.pz=v,h==null||!e.isValid(h))throw new Error("x required");if(w==null||!e.isValid(w))throw new Error("y required");if(v==null||!e.isValid(v))throw new Error("z required");Object.freeze(this)}static fromAffine(h){let{x:w,y:v}=h||{};if(!h||!e.isValid(w)||!e.isValid(v))throw new Error("invalid affine point");if(h instanceof d)throw new Error("projective point not allowed");let m=_=>e.eql(_,e.ZERO);return m(w)&&m(v)?d.ZERO:new d(w,v,e.ONE)}get x(){return this.toAffine().x}get y(){return this.toAffine().y}static normalizeZ(h){let w=e.invertBatch(h.map(v=>v.pz));return h.map((v,m)=>v.toAffine(w[m])).map(d.fromAffine)}static fromHex(h){let w=d.fromAffine(i(ot("pointHex",h)));return w.assertValidity(),w}static fromPrivateKey(h){return d.BASE.multiply(c(h))}static msm(h,w){return nn(d,n,h,w)}_setWindowSize(h){y.setWindowSize(this,h)}assertValidity(){f(this)}hasEvenY(){let{y:h}=this.toAffine();if(e.isOdd)return!e.isOdd(h);throw new Error("Field doesn't support isOdd")}equals(h){l(h);let{px:w,py:v,pz:m}=this,{px:_,py:B,pz:C}=h,I=e.eql(e.mul(w,C),e.mul(_,m)),R=e.eql(e.mul(v,C),e.mul(B,m));return I&&R}negate(){return new d(this.px,e.neg(this.py),this.pz)}double(){let{a:h,b:w}=t,v=e.mul(w,ec),{px:m,py:_,pz:B}=this,C=e.ZERO,I=e.ZERO,R=e.ZERO,T=e.mul(m,m),et=e.mul(_,_),V=e.mul(B,B),q=e.mul(m,_);return q=e.add(q,q),R=e.mul(m,B),R=e.add(R,R),C=e.mul(h,R),I=e.mul(v,V),I=e.add(C,I),C=e.sub(et,I),I=e.add(et,I),I=e.mul(C,I),C=e.mul(q,C),R=e.mul(v,R),V=e.mul(h,V),q=e.sub(T,V),q=e.mul(h,q),q=e.add(q,R),R=e.add(T,T),T=e.add(R,T),T=e.add(T,V),T=e.mul(T,q),I=e.add(I,T),V=e.mul(_,B),V=e.add(V,V),T=e.mul(V,q),C=e.sub(C,T),R=e.mul(V,et),R=e.add(R,R),R=e.add(R,R),new d(C,I,R)}add(h){l(h);let{px:w,py:v,pz:m}=this,{px:_,py:B,pz:C}=h,I=e.ZERO,R=e.ZERO,T=e.ZERO,et=t.a,V=e.mul(t.b,ec),q=e.mul(w,_),ct=e.mul(v,B),S=e.mul(m,C),L=e.add(w,v),x=e.add(_,B);L=e.mul(L,x),x=e.add(q,ct),L=e.sub(L,x),x=e.add(w,m);let p=e.add(_,C);return x=e.mul(x,p),p=e.add(q,S),x=e.sub(x,p),p=e.add(v,m),I=e.add(B,C),p=e.mul(p,I),I=e.add(ct,S),p=e.sub(p,I),T=e.mul(et,x),I=e.mul(V,S),T=e.add(I,T),I=e.sub(ct,T),T=e.add(ct,T),R=e.mul(I,T),ct=e.add(q,q),ct=e.add(ct,q),S=e.mul(et,S),x=e.mul(V,x),ct=e.add(ct,S),S=e.sub(q,S),S=e.mul(et,S),x=e.add(x,S),q=e.mul(ct,x),R=e.add(R,q),q=e.mul(p,x),I=e.mul(L,I),I=e.sub(I,q),q=e.mul(L,ct),T=e.mul(p,T),T=e.add(T,q),new d(I,R,T)}subtract(h){return this.add(h.negate())}is0(){return this.equals(d.ZERO)}wNAF(h){return y.wNAFCached(this,h,d.normalizeZ)}multiplyUnsafe(h){let{endo:w,n:v}=t;Tt("scalar",h,ue,v);let m=d.ZERO;if(h===ue)return m;if(this.is0()||h===mt)return this;if(!w||y.hasPrecomputes(this))return y.wNAFCachedUnsafe(this,h,d.normalizeZ);let{k1neg:_,k1:B,k2neg:C,k2:I}=w.splitScalar(h),R=m,T=m,et=this;for(;B>ue||I>ue;)B&mt&&(R=R.add(et)),I&mt&&(T=T.add(et)),et=et.double(),B>>=mt,I>>=mt;return _&&(R=R.negate()),C&&(T=T.negate()),T=new d(e.mul(T.px,w.beta),T.py,T.pz),R.add(T)}multiply(h){let{endo:w,n:v}=t;Tt("scalar",h,mt,v);let m,_;if(w){let{k1neg:B,k1:C,k2neg:I,k2:R}=w.splitScalar(h),{p:T,f:et}=this.wNAF(C),{p:V,f:q}=this.wNAF(R);T=y.constTimeNegate(B,T),V=y.constTimeNegate(I,V),V=new d(e.mul(V.px,w.beta),V.py,V.pz),m=T.add(V),_=et.add(q)}else{let{p:B,f:C}=this.wNAF(h);m=B,_=C}return d.normalizeZ([m,_])[0]}multiplyAndAddUnsafe(h,w,v){let m=d.BASE,_=(C,I)=>I===ue||I===mt||!C.equals(m)?C.multiplyUnsafe(I):C.multiply(I),B=_(this,w).add(_(h,v));return B.is0()?void 0:B}toAffine(h){return u(this,h)}isTorsionFree(){let{h,isTorsionFree:w}=t;if(h===mt)return!0;if(w)return w(d,this);throw new Error("isTorsionFree() has not been declared for the elliptic curve")}clearCofactor(){let{h,clearCofactor:w}=t;return h===mt?this:w?w(d,this):this.multiplyUnsafe(t.h)}toRawBytes(h=!0){return Vt("isCompressed",h),this.assertValidity(),o(d,this,h)}toHex(h=!0){return Vt("isCompressed",h),oe(this.toRawBytes(h))}}d.BASE=new d(t.Gx,t.Gy,e.ONE),d.ZERO=new d(e.ZERO,e.ONE,e.ZERO);let g=t.nBitLength,y=rn(d,t.endo?Math.ceil(g/2):g);return{CURVE:t,ProjectivePoint:d,normPrivateKeyToScalar:c,weierstrassEquation:s,isWithinCurveOrder:a}}function fh(r){let t=Er(r);return Xt(t,{hash:"hash",hmac:"function",randomBytes:"function"},{bits2int:"function",bits2int_modN:"function",lowS:"boolean"}),Object.freeze({lowS:!0,...t})}function rc(r){let t=fh(r),{Fp:e,n}=t,o=e.BYTES+1,i=2*e.BYTES+1;function s(S){return Y(S,n)}function a(S){return tn(S,n)}let{ProjectivePoint:c,normPrivateKeyToScalar:l,weierstrassEquation:u,isWithinCurveOrder:f}=lh({...t,toBytes(S,L,x){let p=L.toAffine(),E=e.toBytes(p.x),A=se;return Vt("isCompressed",x),x?A(Uint8Array.from([L.hasEvenY()?2:3]),E):A(Uint8Array.from([4]),E,e.toBytes(p.y))},fromBytes(S){let L=S.length,x=S[0],p=S.subarray(1);if(L===o&&(x===2||x===3)){let E=ie(p);if(!xr(E,mt,e.ORDER))throw new Error("Point is not on curve");let A=u(E),D;try{D=e.sqrt(A)}catch(F){let N=F instanceof Error?": "+F.message:"";throw new Error("Point is not on curve"+N)}let P=(D&mt)===mt;return(x&1)===1!==P&&(D=e.neg(D)),{x:E,y:D}}else if(L===i&&x===4){let E=e.fromBytes(p.subarray(0,e.BYTES)),A=e.fromBytes(p.subarray(e.BYTES,2*e.BYTES));return{x:E,y:A}}else{let E=o,A=i;throw new Error("invalid Point, expected length of "+E+", or uncompressed "+A+", got "+L)}}}),d=S=>oe(ye(S,t.nByteLength));function g(S){let L=n>>mt;return S>L}function y(S){return g(S)?s(-S):S}let b=(S,L,x)=>ie(S.slice(L,x));class h{constructor(L,x,p){this.r=L,this.s=x,this.recovery=p,this.assertValidity()}static fromCompact(L){let x=t.nByteLength;return L=ot("compactSignature",L,x*2),new h(b(L,0,x),b(L,x,2*x))}static fromDER(L){let{r:x,s:p}=ce.toSig(ot("DER",L));return new h(x,p)}assertValidity(){Tt("r",this.r,mt,n),Tt("s",this.s,mt,n)}addRecoveryBit(L){return new h(this.r,this.s,L)}recoverPublicKey(L){let{r:x,s:p,recovery:E}=this,A=C(ot("msgHash",L));if(E==null||![0,1,2,3].includes(E))throw new Error("recovery id invalid");let D=E===2||E===3?x+t.n:x;if(D>=e.ORDER)throw new Error("recovery id 2 or 3 invalid");let P=(E&1)===0?"02":"03",O=c.fromHex(P+d(D)),F=a(D),N=s(-A*F),W=s(p*F),J=c.BASE.multiplyAndAddUnsafe(O,N,W);if(!J)throw new Error("point at infinify");return J.assertValidity(),J}hasHighS(){return g(this.s)}normalizeS(){return this.hasHighS()?new h(this.r,s(-this.s),this.recovery):this}toDERRawBytes(){return Re(this.toDERHex())}toDERHex(){return ce.hexFromSig({r:this.r,s:this.s})}toCompactRawBytes(){return Re(this.toCompactHex())}toCompactHex(){return d(this.r)+d(this.s)}}let w={isValidPrivateKey(S){try{return l(S),!0}catch{return!1}},normPrivateKeyToScalar:l,randomPrivateKey:()=>{let S=Fo(t.n);return ma(t.randomBytes(S),t.n)},precompute(S=8,L=c.BASE){return L._setWindowSize(S),L.multiply(BigInt(3)),L}};function v(S,L=!0){return c.fromPrivateKey(S).toRawBytes(L)}function m(S){let L=pe(S),x=typeof S=="string",p=(L||x)&&S.length;return L?p===o||p===i:x?p===2*o||p===2*i:S instanceof c}function _(S,L,x=!0){if(m(S))throw new Error("first arg must be private key");if(!m(L))throw new Error("second arg must be public key");return c.fromHex(L).multiply(l(S)).toRawBytes(x)}let B=t.bits2int||function(S){if(S.length>8192)throw new Error("input is too large");let L=ie(S),x=S.length*8-t.nBitLength;return x>0?L>>BigInt(x):L},C=t.bits2int_modN||function(S){return s(B(S))},I=wr(t.nBitLength);function R(S){return Tt("num < 2^"+t.nBitLength,S,ue,I),ye(S,t.nByteLength)}function T(S,L,x=et){if(["recovered","canonical"].some(ht=>ht in x))throw new Error("sign() legacy options not supported");let{hash:p,randomBytes:E}=t,{lowS:A,prehash:D,extraEntropy:P}=x;A==null&&(A=!0),S=ot("msgHash",S),tc(x),D&&(S=ot("prehashed msgHash",p(S)));let O=C(S),F=l(L),N=[R(F),R(O)];if(P!=null&&P!==!1){let ht=P===!0?E(e.BYTES):P;N.push(ot("extraEntropy",ht))}let W=se(...N),J=O;function ft(ht){let yt=B(ht);if(!f(yt))return;let gt=a(yt),It=c.BASE.multiply(yt).toAffine(),At=s(It.x);if(At===ue)return;let $t=s(gt*s(J+At*F));if($t===ue)return;let jt=(It.x===At?0:2)|Number(It.y&mt),hr=$t;return A&&g($t)&&(hr=y($t),jt^=1),new h(At,hr,jt)}return{seed:W,k2sig:ft}}let et={lowS:t.lowS,prehash:!1},V={lowS:t.lowS,prehash:!1};function q(S,L,x=et){let{seed:p,k2sig:E}=T(S,L,x),A=t;return Mo(A.hash.outputLen,A.nByteLength,A.hmac)(p,E)}c.BASE._setWindowSize(8);function ct(S,L,x,p=V){let E=S;L=ot("msgHash",L),x=ot("publicKey",x);let{lowS:A,prehash:D,format:P}=p;if(tc(p),"strict"in p)throw new Error("options.strict was renamed to lowS");if(P!==void 0&&P!=="compact"&&P!=="der")throw new Error("format must be compact or der");let O=typeof E=="string"||pe(E),F=!O&&!P&&typeof E=="object"&&E!==null&&typeof E.r=="bigint"&&typeof E.s=="bigint";if(!O&&!F)throw new Error("invalid signature, expected Uint8Array, hex string or Signature instance");let N,W;try{if(F&&(N=new h(E.r,E.s)),O){try{P!=="compact"&&(N=h.fromDER(E))}catch(jt){if(!(jt instanceof ce.Err))throw jt}!N&&P!=="der"&&(N=h.fromCompact(E))}W=c.fromHex(x)}catch{return!1}if(!N||A&&N.hasHighS())return!1;D&&(L=t.hash(L));let{r:J,s:ft}=N,ht=C(L),yt=a(ft),gt=s(ht*yt),It=s(J*yt),At=c.BASE.multiplyAndAddUnsafe(W,gt,It)?.toAffine();return At?s(At.x)===J:!1}return{CURVE:t,getPublicKey:v,getSharedSecret:_,sign:q,verify:ct,ProjectivePoint:c,Signature:h,utils:w}}function hh(r){return{hash:r,hmac:(t,...e)=>Ni(r,t,Bo(...e)),randomBytes:Yr}}function nc(r,t){let e=n=>rc({...r,...hh(n)});return{...e(t),create:e}}var sc=BigInt("0xfffffffffffffffffffffffffffffffffffffffffffffffffffffffefffffc2f"),oc=BigInt("0xfffffffffffffffffffffffffffffffebaaedce6af48a03bbfd25e8cd0364141"),dh=BigInt(1),Oi=BigInt(2),ic=(r,t)=>(r+t/Oi)/t;function ph(r){let t=sc,e=BigInt(3),n=BigInt(6),o=BigInt(11),i=BigInt(22),s=BigInt(23),a=BigInt(44),c=BigInt(88),l=r*r*r%t,u=l*l*r%t,f=nt(u,e,t)*u%t,d=nt(f,e,t)*u%t,g=nt(d,Oi,t)*l%t,y=nt(g,o,t)*g%t,b=nt(y,i,t)*y%t,h=nt(b,a,t)*b%t,w=nt(h,c,t)*h%t,v=nt(w,a,t)*b%t,m=nt(v,e,t)*u%t,_=nt(m,s,t)*y%t,B=nt(_,n,t)*l%t,C=nt(B,Oi,t);if(!Mi.eql(Mi.sqr(C),r))throw new Error("Cannot find square root");return C}var Mi=ge(sc,void 0,void 0,{sqrt:ph}),Oe=nc({a:BigInt(0),b:BigInt(7),Fp:Mi,n:oc,Gx:BigInt("55066263022277343669578718895168534326250603453777594175500187360389116729240"),Gy:BigInt("32670510020758816978083085130507043184471273380659243275938904335757337482424"),h:BigInt(1),lowS:!0,endo:{beta:BigInt("0x7ae96a2b657c07106e64479eac3434e99cf0497512f58995c1396c28719501ee"),splitScalar:r=>{let t=oc,e=BigInt("0x3086d221a7d46bcde86c90e49284eb15"),n=-dh*BigInt("0xe4437ed6010e88286f547fa90abfe4c3"),o=BigInt("0x114ca50f7a8e2f3f657c1108d9d44cfd8"),i=e,s=BigInt("0x100000000000000000000000000000000"),a=ic(i*r,t),c=ic(-n*r,t),l=Y(r-a*e-c*o,t),u=Y(-a*n-c*i,t),f=l>s,d=u>s;if(f&&(l=t-l),d&&(u=t-u),l>s||u>s)throw new Error("splitScalar: Endomorphism failed, k="+r);return{k1neg:f,k1:l,k2neg:d,k2:u}}}},tr),fy=BigInt(0);var hy=Oe.ProjectivePoint;function ac(r){return r==null?!1:typeof r.then=="function"&&typeof r.catch=="function"&&typeof r.finally=="function"}function cc(r,t,e){let n=je.digest(e instanceof Uint8Array?e:e.subarray());if(ac(n))return n.then(({digest:o})=>Oe.verify(t,o,r)).catch(o=>{throw new Tr(String(o))});try{return Oe.verify(t,n.digest,r)}catch(o){throw new Tr(String(o))}}var bn=class{type="secp256k1";raw;_key;constructor(t){this._key=lc(t),this.raw=uc(this._key)}toMultihash(){return re.digest(be(this))}toCID(){return dt.createV1(114,this.toMultihash())}toString(){return Q.encode(this.toMultihash().bytes).substring(1)}equals(t){return t==null||!(t.raw instanceof Uint8Array)?!1:pt(this.raw,t.raw)}verify(t,e){return cc(this._key,e,t)}};function ki(r){return new bn(r)}function uc(r){return Oe.ProjectivePoint.fromHex(r).toRawBytes(!0)}function lc(r){try{return Oe.ProjectivePoint.fromHex(r),r}catch(t){throw new Fe(String(t))}}function fc(r,t){let{Type:e,Data:n}=Qt.decode(r),o=n??new Uint8Array;switch(e){case lt.RSA:return Pi(o,t);case lt.Ed25519:return $o(o);case lt.secp256k1:return ki(o);default:throw new ze}}function hc(r){let{Type:t,Data:e}=Qt.decode(r.digest),n=e??new Uint8Array;switch(t){case lt.Ed25519:return $o(n);case lt.secp256k1:return ki(n);default:throw new ze}}function be(r){return Qt.encode({Type:lt[r.type],Data:r.raw})}var dc=Symbol.for("nodejs.util.inspect.custom"),mh=114,Br=class{type;multihash;publicKey;string;constructor(t){this.type=t.type,this.multihash=t.multihash,Object.defineProperty(this,"string",{enumerable:!1,writable:!0})}get[Symbol.toStringTag](){return`PeerId(${this.toString()})`}[bo]=!0;toString(){return this.string==null&&(this.string=Q.encode(this.multihash.bytes).slice(1)),this.string}toMultihash(){return this.multihash}toCID(){return dt.createV1(mh,this.multihash)}toJSON(){return this.toString()}equals(t){if(t==null)return!1;if(t instanceof Uint8Array)return pt(this.multihash.bytes,t);if(typeof t=="string")return this.toString()===t;if(t?.toMultihash()?.bytes!=null)return pt(this.multihash.bytes,t.toMultihash().bytes);throw new Error("not valid Id")}[dc](){return`PeerId(${this.toString()})`}},xn=class extends Br{type="RSA";publicKey;constructor(t){super({...t,type:"RSA"}),this.publicKey=t.publicKey}},wn=class extends Br{type="Ed25519";publicKey;constructor(t){super({...t,type:"Ed25519"}),this.publicKey=t.publicKey}},En=class extends Br{type="secp256k1";publicKey;constructor(t){super({...t,type:"secp256k1"}),this.publicKey=t.publicKey}},yh=2336,vn=class{type="url";multihash;publicKey;url;constructor(t){this.url=t.toString(),this.multihash=re.digest(z(this.url))}[dc](){return`PeerId(${this.url})`}[bo]=!0;toString(){return this.toCID().toString()}toMultihash(){return this.multihash}toCID(){return dt.createV1(yh,this.toMultihash())}toJSON(){return this.toString()}equals(t){return t==null?!1:(t instanceof Uint8Array&&(t=H(t)),t.toString()===this.toString())}};function Ki(r,t){let e;if(r.charAt(0)==="1"||r.charAt(0)==="Q")e=Mt(Q.decode(`z${r}`));else{if(t==null)throw new bt('Please pass a multibase decoder for strings that do not start with "1" or "Q"');e=Mt(t.decode(r))}return Cr(e)}function Cr(r){if(bh(r))return new xn({multihash:r});if(gh(r))try{let t=hc(r);if(t.type==="Ed25519")return new wn({multihash:r,publicKey:t});if(t.type==="secp256k1")return new En({multihash:r,publicKey:t})}catch{let e=H(r.digest);return new vn(new URL(e))}throw new Hr("Supplied PeerID Multihash is invalid")}function gh(r){return r.code===re.code}function bh(r){return r.code===je.code}var Dr;(function(r){let t;r.codec=()=>(t==null&&(t=Dt((e,n,o={})=>{o.lengthDelimited!==!1&&n.fork(),e.publicKey!=null&&e.publicKey.byteLength>0&&(n.uint32(10),n.bytes(e.publicKey)),e.payloadType!=null&&e.payloadType.byteLength>0&&(n.uint32(18),n.bytes(e.payloadType)),e.payload!=null&&e.payload.byteLength>0&&(n.uint32(26),n.bytes(e.payload)),e.signature!=null&&e.signature.byteLength>0&&(n.uint32(42),n.bytes(e.signature)),o.lengthDelimited!==!1&&n.ldelim()},(e,n,o={})=>{let i={publicKey:it(0),payloadType:it(0),payload:it(0),signature:it(0)},s=n==null?e.len:e.pos+n;for(;e.pos<s;){let a=e.uint32();switch(a>>>3){case 1:{i.publicKey=e.bytes();break}case 2:{i.payloadType=e.bytes();break}case 3:{i.payload=e.bytes();break}case 5:{i.signature=e.bytes();break}default:{e.skipType(a&7);break}}}return i})),t),r.encode=e=>Ct(e,r.codec()),r.decode=(e,n)=>Bt(e,r.codec(),n)})(Dr||(Dr={}));var Sn=class extends Error{constructor(t="Invalid signature"){super(t),this.name="InvalidSignatureError"}};var Pr=class r{static createFromProtobuf=async t=>{let e=Dr.decode(t),n=fc(e.publicKey);return new r({publicKey:n,payloadType:e.payloadType,payload:e.payload,signature:e.signature})};static seal=async(t,e)=>{if(e==null)throw new Error("Missing private key");let n=t.domain,o=t.codec,i=t.marshal(),s=pc(n,o,i),a=await e.sign(s.subarray());return new r({publicKey:e.publicKey,payloadType:o,payload:i,signature:a})};static openAndCertify=async(t,e)=>{let n=await r.createFromProtobuf(t);if(!await n.validate(e))throw new Sn("Envelope signature is not valid for the given domain");return n};publicKey;payloadType;payload;signature;marshaled;constructor(t){let{publicKey:e,payloadType:n,payload:o,signature:i}=t;this.publicKey=e,this.payloadType=n,this.payload=o,this.signature=i}marshal(){return this.marshaled==null&&(this.marshaled=Dr.encode({publicKey:be(this.publicKey),payloadType:this.payloadType,payload:this.payload.subarray(),signature:this.signature})),this.marshaled}equals(t){return pt(this.marshal(),t.marshal())}async validate(t){let e=pc(t,this.payloadType,this.payload);return this.publicKey.verify(e.subarray(),this.signature)}},pc=(r,t,e)=>{let n=z(r),o=kt(n.byteLength),i=kt(t.length),s=kt(e.length);return new at(o,n,i,t,s,e)};var An=class{index=0;input="";new(t){return this.index=0,this.input=t,this}readAtomically(t){let e=this.index,n=t();return n===void 0&&(this.index=e),n}parseWith(t){let e=t();if(this.index===this.input.length)return e}peekChar(){if(!(this.index>=this.input.length))return this.input[this.index]}readChar(){if(!(this.index>=this.input.length))return this.input[this.index++]}readGivenChar(t){return this.readAtomically(()=>{let e=this.readChar();if(e===t)return e})}readSeparator(t,e,n){return this.readAtomically(()=>{if(!(e>0&&this.readGivenChar(t)===void 0))return n()})}readNumber(t,e,n,o){return this.readAtomically(()=>{let i=0,s=0,a=this.peekChar();if(a===void 0)return;let c=a==="0",l=2**(8*o)-1;for(;;){let u=this.readAtomically(()=>{let f=this.readChar();if(f===void 0)return;let d=Number.parseInt(f,t);if(!Number.isNaN(d))return d});if(u===void 0)break;if(i*=t,i+=u,i>l||(s+=1,e!==void 0&&s>e))return}if(s!==0)return!n&&c&&s>1?void 0:i})}readIPv4Addr(){return this.readAtomically(()=>{let t=new Uint8Array(4);for(let e=0;e<t.length;e++){let n=this.readSeparator(".",e,()=>this.readNumber(10,3,!1,1));if(n===void 0)return;t[e]=n}return t})}readIPv6Addr(){let t=e=>{for(let n=0;n<e.length/2;n++){let o=n*2;if(n<e.length-3){let s=this.readSeparator(":",n,()=>this.readIPv4Addr());if(s!==void 0)return e[o]=s[0],e[o+1]=s[1],e[o+2]=s[2],e[o+3]=s[3],[o+4,!0]}let i=this.readSeparator(":",n,()=>this.readNumber(16,4,!0,2));if(i===void 0)return[o,!1];e[o]=i>>8,e[o+1]=i&255}return[e.length,!1]};return this.readAtomically(()=>{let e=new Uint8Array(16),[n,o]=t(e);if(n===16)return e;if(o||this.readGivenChar(":")===void 0||this.readGivenChar(":")===void 0)return;let i=new Uint8Array(14),s=16-(n+2),[a]=t(i.subarray(0,s));return e.set(i.subarray(0,a),16-a),e})}readIPAddr(){return this.readIPv4Addr()??this.readIPv6Addr()}};var mc=45,xh=15,rr=new An;function qi(r){if(!(r.length>xh))return rr.new(r).parseWith(()=>rr.readIPv4Addr())}function Fi(r){if(r.includes("%")&&(r=r.split("%")[0]),!(r.length>mc))return rr.new(r).parseWith(()=>rr.readIPv6Addr())}function _n(r,t=!1){if(r.includes("%")&&(r=r.split("%")[0]),r.length>mc)return;let e=rr.new(r).parseWith(()=>rr.readIPAddr());if(e)return t&&e.length===4?Uint8Array.from([0,0,0,0,0,0,0,0,0,0,255,255,e[0],e[1],e[2],e[3]]):e}var Ng=parseInt("0xFFFF",16),Ug=new Uint8Array([0,0,0,0,0,0,0,0,0,0,255,255]);function In(r){return!!qi(r)}function Tn(r){return!!Fi(r)}function Ln(r){return!!_n(r)}var bc=In,Ah=Tn,zi=function(r){let t=0;if(r=r.toString().trim(),bc(r)){let e=new Uint8Array(t+4);return r.split(/\./g).forEach(n=>{e[t++]=parseInt(n,10)&255}),e}if(Ah(r)){let e=r.split(":",8),n;for(n=0;n<e.length;n++){let i=bc(e[n]),s;i&&(s=zi(e[n]),e[n]=H(s.slice(0,2),"base16")),s!=null&&++n<8&&e.splice(n,0,H(s.slice(2,4),"base16"))}if(e[0]==="")for(;e.length<8;)e.unshift("0");else if(e[e.length-1]==="")for(;e.length<8;)e.push("0");else if(e.length<8){for(n=0;n<e.length&&e[n]!=="";n++);let i=[n,1];for(n=9-e.length;n>0;n--)i.push("0");e.splice.apply(e,i)}let o=new Uint8Array(t+16);for(n=0;n<e.length;n++){let i=parseInt(e[n],16);o[t++]=i>>8&255,o[t++]=i&255}return o}throw new Error("invalid ip address")},xc=function(r,t=0,e){t=~~t,e=e??r.length-t;let n=new DataView(r.buffer);if(e===4){let o=[];for(let i=0;i<e;i++)o.push(r[t+i]);return o.join(".")}if(e===16){let o=[];for(let i=0;i<e;i+=2)o.push(n.getUint16(t+i).toString(16));return o.join(":").replace(/(^|:)0(:0)*:0(:|$)/,"$1::$3").replace(/:{3,4}/,"::")}return""};var nr={},Vi={},Ih=[[4,32,"ip4"],[6,16,"tcp"],[33,16,"dccp"],[41,128,"ip6"],[42,-1,"ip6zone"],[43,8,"ipcidr"],[53,-1,"dns",!0],[54,-1,"dns4",!0],[55,-1,"dns6",!0],[56,-1,"dnsaddr",!0],[132,16,"sctp"],[273,16,"udp"],[275,0,"p2p-webrtc-star"],[276,0,"p2p-webrtc-direct"],[277,0,"p2p-stardust"],[280,0,"webrtc-direct"],[281,0,"webrtc"],[290,0,"p2p-circuit"],[301,0,"udt"],[302,0,"utp"],[400,-1,"unix",!1,!0],[421,-1,"ipfs"],[421,-1,"p2p"],[443,0,"https"],[444,96,"onion"],[445,296,"onion3"],[446,-1,"garlic64"],[448,0,"tls"],[449,-1,"sni"],[460,0,"quic"],[461,0,"quic-v1"],[465,0,"webtransport"],[466,-1,"certhash"],[477,0,"ws"],[478,0,"wss"],[479,0,"p2p-websocket-star"],[480,0,"http"],[481,-1,"http-path"],[777,-1,"memory"]];Ih.forEach(r=>{let t=Th(...r);Vi[t.code]=t,nr[t.name]=t});function Th(r,t,e,n,o){return{code:r,size:t,name:e,resolvable:!!n,path:!!o}}function j(r){if(typeof r=="number"){if(Vi[r]!=null)return Vi[r];throw new Error(`no protocol with code: ${r}`)}else if(typeof r=="string"){if(nr[r]!=null)return nr[r];throw new Error(`no protocol with name: ${r}`)}throw new Error(`invalid protocol id type: ${typeof r}`)}var bb=j("ip4"),xb=j("ip6"),wb=j("ipcidr");function Wi(r,t){switch(j(r).code){case 4:case 41:return Rh(t);case 42:return Zi(t);case 43:return H(t,"base10");case 6:case 273:case 33:case 132:return vc(t).toString();case 53:case 54:case 55:case 56:case 400:case 449:case 777:return Zi(t);case 421:return Ph(t);case 444:return Ec(t);case 445:return Ec(t);case 466:return Dh(t);case 481:return globalThis.encodeURIComponent(Zi(t));default:return H(t,"base16")}}function $i(r,t){switch(j(r).code){case 4:return wc(t);case 41:return wc(t);case 42:return Gi(t);case 43:return z(t,"base10");case 6:case 273:case 33:case 132:return Yi(parseInt(t,10));case 53:case 54:case 55:case 56:case 400:case 449:case 777:return Gi(t);case 421:return Bh(t);case 444:return Nh(t);case 445:return Uh(t);case 466:return Ch(t);case 481:return Gi(globalThis.decodeURIComponent(t));default:return z(t,"base16")}}var Hi=Object.values(vr).map(r=>r.decoder),Lh=function(){let r=Hi[0].or(Hi[1]);return Hi.slice(2).forEach(t=>r=r.or(t)),r}();function wc(r){if(!Ln(r))throw new Error("invalid ip address");return zi(r)}function Rh(r){let t=xc(r,0,r.length);if(t==null)throw new Error("ipBuff is required");if(!Ln(t))throw new Error("invalid ip address");return t}function Yi(r){let t=new ArrayBuffer(2);return new DataView(t).setUint16(0,r),new Uint8Array(t)}function vc(r){return new DataView(r.buffer).getUint16(r.byteOffset)}function Gi(r){let t=z(r),e=Uint8Array.from(kt(t.length));return Nt([e,t],e.length+t.length)}function Zi(r){let t=ae(r);if(r=r.slice(wt(t)),r.length!==t)throw new Error("inconsistent lengths");return H(r)}function Bh(r){let t;r[0]==="Q"||r[0]==="1"?t=Mt(Q.decode(`z${r}`)).bytes:t=dt.parse(r).multihash.bytes;let e=Uint8Array.from(kt(t.length));return Nt([e,t],e.length+t.length)}function Ch(r){let t=Lh.decode(r),e=Uint8Array.from(kt(t.length));return Nt([e,t],e.length+t.length)}function Dh(r){let t=ae(r),e=r.slice(wt(t));if(e.length!==t)throw new Error("inconsistent lengths");return"u"+H(e,"base64url")}function Ph(r){let t=ae(r),e=r.slice(wt(t));if(e.length!==t)throw new Error("inconsistent lengths");return H(e,"base58btc")}function Nh(r){let t=r.split(":");if(t.length!==2)throw new Error(`failed to parse onion addr: ["'${t.join('", "')}'"]' does not contain a port number`);if(t[0].length!==16)throw new Error(`failed to parse onion addr: ${t[0]} not a Tor onion address.`);let e=ee.decode("b"+t[0]),n=parseInt(t[1],10);if(n<1||n>65536)throw new Error("Port number is not in range(1, 65536)");let o=Yi(n);return Nt([e,o],e.length+o.length)}function Uh(r){let t=r.split(":");if(t.length!==2)throw new Error(`failed to parse onion addr: ["'${t.join('", "')}'"]' does not contain a port number`);if(t[0].length!==56)throw new Error(`failed to parse onion addr: ${t[0]} not a Tor onion3 address.`);let e=ee.decode(`b${t[0]}`),n=parseInt(t[1],10);if(n<1||n>65536)throw new Error("Port number is not in range(1, 65536)");let o=Yi(n);return Nt([e,o],e.length+o.length)}function Ec(r){let t=r.slice(0,r.length-2),e=r.slice(r.length-2),n=H(t,"base32"),o=vc(e);return`${n}:${o}`}function Sc(r){r=Xi(r);let t=[],e=[],n=null,o=r.split("/").slice(1);if(o.length===1&&o[0]==="")return{bytes:new Uint8Array,string:"/",tuples:[],stringTuples:[],path:null};for(let i=0;i<o.length;i++){let s=o[i],a=j(s);if(a.size===0){t.push([a.code]),e.push([a.code]);continue}if(i++,i>=o.length)throw new Rn("invalid address: "+r);if(a.path===!0){n=Xi(o.slice(i).join("/")),t.push([a.code,$i(a.code,n)]),e.push([a.code,n]);break}let c=$i(a.code,o[i]);t.push([a.code,c]),e.push([a.code,Wi(a.code,c)])}return{string:Ac(e),bytes:Bn(t),tuples:t,stringTuples:e,path:n}}function Qi(r){let t=[],e=[],n=null,o=0;for(;o<r.length;){let i=ae(r,o),s=wt(i),a=j(i),c=Oh(a,r.slice(o+s));if(c===0){t.push([i]),e.push([i]),o+=s;continue}let l=r.slice(o+s,o+s+c);if(o+=c+s,o>r.length)throw new Rn("Invalid address Uint8Array: "+H(r,"base16"));t.push([i,l]);let u=Wi(i,l);if(e.push([i,u]),a.path===!0){n=u;break}}return{bytes:Uint8Array.from(r),string:Ac(e),tuples:t,stringTuples:e,path:n}}function Ac(r){let t=[];return r.map(e=>{let n=j(e[0]);return t.push(n.name),e.length>1&&e[1]!=null&&t.push(e[1]),null}),Xi(t.join("/"))}function Bn(r){return Nt(r.map(t=>{let e=j(t[0]),n=Uint8Array.from(kt(e.code));return t.length>1&&t[1]!=null&&(n=Nt([n,t[1]])),n}))}function Oh(r,t){if(r.size>0)return r.size/8;if(r.size===0)return 0;{let e=ae(t instanceof Uint8Array?t:Uint8Array.from(t));return e+wt(e)}}function Xi(r){return"/"+r.trim().split("/").filter(t=>t).join("/")}var Rn=class extends Error{static name="ParseError";name="ParseError";constructor(t){super(`Error parsing address: ${t}`)}};var Mh=Symbol.for("nodejs.util.inspect.custom"),Ji=Symbol.for("@multiformats/js-multiaddr/multiaddr"),kh=[j("dns").code,j("dns4").code,j("dns6").code,j("dnsaddr").code],ji=class extends Error{constructor(t="No available resolver"){super(t),this.name="NoAvailableResolverError"}},Cn=class r{bytes;#t;#e;#r;#n;[Ji]=!0;constructor(t){t==null&&(t="");let e;if(t instanceof Uint8Array)e=Qi(t);else if(typeof t=="string"){if(t.length>0&&t.charAt(0)!=="/")throw new Error(`multiaddr "${t}" must start with a "/"`);e=Sc(t)}else if(Ic(t))e=Qi(t.bytes);else throw new Error("addr must be a string, Buffer, or another Multiaddr");this.bytes=e.bytes,this.#t=e.string,this.#e=e.tuples,this.#r=e.stringTuples,this.#n=e.path}toString(){return this.#t}toJSON(){return this.toString()}toOptions(){let t,e,n,o,i="",s=j("tcp"),a=j("udp"),c=j("ip4"),l=j("ip6"),u=j("dns6"),f=j("ip6zone");for(let[g,y]of this.stringTuples())g===f.code&&(i=`%${y??""}`),kh.includes(g)&&(e=s.name==="tcp"?"tcp":"udp",o=443,n=`${y??""}${i}`,t=g===u.code?6:4),(g===s.code||g===a.code)&&(e=j(g).name==="tcp"?"tcp":"udp",o=parseInt(y??"")),(g===c.code||g===l.code)&&(e=j(g).name==="tcp"?"tcp":"udp",n=`${y??""}${i}`,t=g===l.code?6:4);if(t==null||e==null||n==null||o==null)throw new Error('multiaddr must have a valid format: "/{ip4, ip6, dns4, dns6, dnsaddr}/{address}/{tcp, udp}/{port}".');return{family:t,host:n,transport:e,port:o}}protos(){return this.#e.map(([t])=>Object.assign({},j(t)))}protoCodes(){return this.#e.map(([t])=>t)}protoNames(){return this.#e.map(([t])=>j(t).name)}tuples(){return this.#e.map(([t,e])=>e==null?[t]:[t,e])}stringTuples(){return this.#r.map(([t,e])=>e==null?[t]:[t,e])}encapsulate(t){return t=new r(t),new r(this.toString()+t.toString())}decapsulate(t){let e=t.toString(),n=this.toString(),o=n.lastIndexOf(e);if(o<0)throw new Error(`Address ${this.toString()} does not contain subaddress: ${t.toString()}`);return new r(n.slice(0,o))}decapsulateCode(t){let e=this.tuples();for(let n=e.length-1;n>=0;n--)if(e[n][0]===t)return new r(Bn(e.slice(0,n)));return this}getPeerId(){try{let t=[];this.stringTuples().forEach(([n,o])=>{n===nr.p2p.code&&t.push([n,o]),n===nr["p2p-circuit"].code&&(t=[])});let e=t.pop();if(e?.[1]!=null){let n=e[1];return n[0]==="Q"||n[0]==="1"?H(Q.decode(`z${n}`),"base58btc"):H(dt.parse(n).multihash.bytes,"base58btc")}return null}catch{return null}}getPath(){return this.#n}equals(t){return pt(this.bytes,t.bytes)}async resolve(t){let e=this.protos().find(i=>i.resolvable);if(e==null)return[this];let n=_c.get(e.name);if(n==null)throw new ji(`no available resolver for ${e.name}`);return(await n(this,t)).map(i=>vt(i))}nodeAddress(){let t=this.toOptions();if(t.transport!=="tcp"&&t.transport!=="udp")throw new Error(`multiaddr must have a valid format - no protocol with name: "${t.transport}". Must have a valid transport protocol: "{tcp, udp}"`);return{family:t.family,address:t.host,port:t.port}}isThinWaistAddress(t){let e=(t??this).protos();return!(e.length!==2||e[0].code!==4&&e[0].code!==41||e[1].code!==6&&e[1].code!==273)}[Mh](){return`Multiaddr(${this.#t})`}};var _c=new Map;function Ic(r){return!!r?.[Ji]}function vt(r){return new Cn(r)}function Zt(){let r={};return r.promise=new Promise((t,e)=>{r.resolve=t,r.reject=e}),r}var Dn=class extends Error{type;code;constructor(t,e,n){super(t??"The operation was aborted"),this.type="aborted",this.name=n??"AbortError",this.code=e??"ABORT_ERR"}};async function Pn(r,t,e){if(t==null)return r;if(t.aborted)return r.catch(()=>{}),Promise.reject(new Dn(e?.errorMessage,e?.errorCode,e?.errorName));let n,o=new Dn(e?.errorMessage,e?.errorCode,e?.errorName);try{return await Promise.race([r,new Promise((i,s)=>{n=()=>{s(o)},t.addEventListener("abort",n)})])}finally{n!=null&&t.removeEventListener("abort",n)}}var ts=class{readNext;haveNext;ended;nextResult;constructor(){this.ended=!1,this.readNext=Zt(),this.haveNext=Zt()}[Symbol.asyncIterator](){return this}async next(){if(this.nextResult==null&&await this.haveNext.promise,this.nextResult==null)throw new Error("HaveNext promise resolved but nextResult was undefined");let t=this.nextResult;return this.nextResult=void 0,this.readNext.resolve(),this.readNext=Zt(),t}async throw(t){return this.ended=!0,t!=null&&(this.haveNext.promise.catch(()=>{}),this.haveNext.reject(t)),{done:!0,value:void 0}}async return(){let t={done:!0,value:void 0};return this.ended=!0,this.nextResult=t,this.haveNext.resolve(),t}async push(t,e){await this._push(t,e)}async end(t,e){t!=null?await this.throw(t):await this._push(void 0,e)}async _push(t,e){if(t!=null&&this.ended)throw new Error("Cannot push value onto an ended pushable");for(;this.nextResult!=null;)await this.readNext.promise;t!=null?this.nextResult={done:!1,value:t}:(this.ended=!0,this.nextResult={done:!0,value:void 0}),this.haveNext.resolve(),this.haveNext=Zt(),await Pn(this.readNext.promise,e?.signal,e)}};function Tc(){return new ts}var Nn=class extends Error{name="UnexpectedEOFError";code="ERR_UNEXPECTED_EOF"};var es=class extends Error{code;constructor(t,e){super(t),this.code=e}},rs=class extends es{type;constructor(t){super(t,"ABORT_ERR"),this.type="aborted",this.name="AbortError"}};function Lc(r,t){let e=Tc();r.sink(e).catch(async s=>{await e.end(s)}),r.sink=async s=>{for await(let a of s)await e.push(a);await e.end()};let n=r.source;r.source[Symbol.iterator]!=null?n=r.source[Symbol.iterator]():r.source[Symbol.asyncIterator]!=null&&(n=r.source[Symbol.asyncIterator]());let o=new at;return{read:async(s,a)=>{a?.signal?.throwIfAborted();let c,l=new Promise((u,f)=>{c=()=>{f(new rs("Read aborted"))},a?.signal?.addEventListener("abort",c)});try{if(s==null){let{done:f,value:d}=await Promise.race([n.next(),l]);return f===!0?new at:d}for(;o.byteLength<s;){let{value:f,done:d}=await Promise.race([n.next(),l]);if(d===!0)throw new Nn("unexpected end of input");o.append(f)}let u=o.sublist(0,s);return o.consume(s),u}finally{c!=null&&a?.signal?.removeEventListener("abort",c)}},write:async(s,a)=>{a?.signal?.throwIfAborted(),s instanceof Uint8Array?await e.push(s,a):await e.push(s.subarray(),a)},unwrap:()=>{if(o.byteLength>0){let s=r.source;r.source=async function*(){t?.yieldBytes===!1?yield o:yield*o,yield*s}()}return r}}}var Un=class extends Error{name="InvalidMessageLengthError";code="ERR_INVALID_MSG_LENGTH"},On=class extends Error{name="InvalidDataLengthError";code="ERR_MSG_DATA_TOO_LONG"},Mn=class extends Error{name="InvalidDataLengthLengthError";code="ERR_MSG_LENGTH_TOO_LONG"};function Rc(r,t={}){let e=Lc(r,t);t.maxDataLength!=null&&t.maxLengthLength==null&&(t.maxLengthLength=wt(t.maxDataLength));let n=t?.lengthDecoder??ae,o=t?.lengthEncoder??kt;return{read:async s=>{let a=-1,c=new at;for(;;){c.append(await e.read(1,s));try{a=n(c)}catch(l){if(l instanceof RangeError)continue;throw l}if(a<0)throw new Un("Invalid message length");if(t?.maxLengthLength!=null&&c.byteLength>t.maxLengthLength)throw new Mn("message length length too long");if(a>-1)break}if(t?.maxDataLength!=null&&a>t.maxDataLength)throw new On("message length too long");return e.read(a,s)},write:async(s,a)=>{await e.write(new at(o(s.byteLength),s),a)},writeV:async(s,a)=>{let c=new at(...s.flatMap(l=>[o(l.byteLength),l]));await e.write(c,a)},unwrap:()=>e.unwrap()}}function Se(r,t){let e=Rc(r,t),n={read:async(o,i)=>{let s=await e.read(i);return o.decode(s)},write:async(o,i,s)=>{await e.write(i.encode(o),s)},writeV:async(o,i,s)=>{await e.writeV(o.map(a=>i.encode(a)),s)},pb:o=>({read:async i=>n.read(o,i),write:async(i,s)=>n.write(i,o,s),writeV:async(i,s)=>n.writeV(i,o,s),unwrap:()=>n}),unwrap:()=>e.unwrap()};return n}var ns=1e3,Bc=60*ns,kn=290,Cc=15,Dc=2*60*Bc,Pc=1,Kn=2e3,Nc=100,os="circuit-relay-source",Nr=`${xo}-circuit-relay`,is=`${xo}-circuit-relay-source`,Uc=2*Bc,Oc=BigInt(1<<17),qt="/libp2p/circuit/relay/0.2.0/hop",Me="/libp2p/circuit/relay/0.2.0/stop",Mc=30*ns,hx=30*ns,Ur=300,kc=4096,Kc=.001;var $;(function(r){let t;(function(o){o.RESERVE="RESERVE",o.CONNECT="CONNECT",o.STATUS="STATUS"})(t=r.Type||(r.Type={}));let e;(function(o){o[o.RESERVE=0]="RESERVE",o[o.CONNECT=1]="CONNECT",o[o.STATUS=2]="STATUS"})(e||(e={})),function(o){o.codec=()=>Ue(e)}(t=r.Type||(r.Type={}));let n;r.codec=()=>(n==null&&(n=Dt((o,i,s={})=>{s.lengthDelimited!==!1&&i.fork(),o.type!=null&&(i.uint32(8),r.Type.codec().encode(o.type,i)),o.peer!=null&&(i.uint32(18),or.codec().encode(o.peer,i)),o.reservation!=null&&(i.uint32(26),qn.codec().encode(o.reservation,i)),o.limit!=null&&(i.uint32(34),ir.codec().encode(o.limit,i)),o.status!=null&&(i.uint32(40),k.codec().encode(o.status,i)),s.lengthDelimited!==!1&&i.ldelim()},(o,i,s={})=>{let a={},c=i==null?o.len:o.pos+i;for(;o.pos<c;){let l=o.uint32();switch(l>>>3){case 1:{a.type=r.Type.codec().decode(o);break}case 2:{a.peer=or.codec().decode(o,o.uint32(),{limits:s.limits?.peer});break}case 3:{a.reservation=qn.codec().decode(o,o.uint32(),{limits:s.limits?.reservation});break}case 4:{a.limit=ir.codec().decode(o,o.uint32(),{limits:s.limits?.limit});break}case 5:{a.status=k.codec().decode(o);break}default:{o.skipType(l&7);break}}}return a})),n),r.encode=o=>Ct(o,r.codec()),r.decode=(o,i)=>Bt(o,r.codec(),i)})($||($={}));var Ut;(function(r){let t;(function(o){o.CONNECT="CONNECT",o.STATUS="STATUS"})(t=r.Type||(r.Type={}));let e;(function(o){o[o.CONNECT=0]="CONNECT",o[o.STATUS=1]="STATUS"})(e||(e={})),function(o){o.codec=()=>Ue(e)}(t=r.Type||(r.Type={}));let n;r.codec=()=>(n==null&&(n=Dt((o,i,s={})=>{s.lengthDelimited!==!1&&i.fork(),o.type!=null&&(i.uint32(8),r.Type.codec().encode(o.type,i)),o.peer!=null&&(i.uint32(18),or.codec().encode(o.peer,i)),o.limit!=null&&(i.uint32(26),ir.codec().encode(o.limit,i)),o.status!=null&&(i.uint32(32),k.codec().encode(o.status,i)),s.lengthDelimited!==!1&&i.ldelim()},(o,i,s={})=>{let a={},c=i==null?o.len:o.pos+i;for(;o.pos<c;){let l=o.uint32();switch(l>>>3){case 1:{a.type=r.Type.codec().decode(o);break}case 2:{a.peer=or.codec().decode(o,o.uint32(),{limits:s.limits?.peer});break}case 3:{a.limit=ir.codec().decode(o,o.uint32(),{limits:s.limits?.limit});break}case 4:{a.status=k.codec().decode(o);break}default:{o.skipType(l&7);break}}}return a})),n),r.encode=o=>Ct(o,r.codec()),r.decode=(o,i)=>Bt(o,r.codec(),i)})(Ut||(Ut={}));var or;(function(r){let t;r.codec=()=>(t==null&&(t=Dt((e,n,o={})=>{if(o.lengthDelimited!==!1&&n.fork(),e.id!=null&&e.id.byteLength>0&&(n.uint32(10),n.bytes(e.id)),e.addrs!=null)for(let i of e.addrs)n.uint32(18),n.bytes(i);o.lengthDelimited!==!1&&n.ldelim()},(e,n,o={})=>{let i={id:it(0),addrs:[]},s=n==null?e.len:e.pos+n;for(;e.pos<s;){let a=e.uint32();switch(a>>>3){case 1:{i.id=e.bytes();break}case 2:{if(o.limits?.addrs!=null&&i.addrs.length===o.limits.addrs)throw new _r('Decode error - map field "addrs" had too many elements');i.addrs.push(e.bytes());break}default:{e.skipType(a&7);break}}}return i})),t),r.encode=e=>Ct(e,r.codec()),r.decode=(e,n)=>Bt(e,r.codec(),n)})(or||(or={}));var qn;(function(r){let t;r.codec=()=>(t==null&&(t=Dt((e,n,o={})=>{if(o.lengthDelimited!==!1&&n.fork(),e.expire!=null&&e.expire!==0n&&(n.uint32(8),n.uint64(e.expire)),e.addrs!=null)for(let i of e.addrs)n.uint32(18),n.bytes(i);e.voucher!=null&&(n.uint32(26),Fn.codec().encode(e.voucher,n)),o.lengthDelimited!==!1&&n.ldelim()},(e,n,o={})=>{let i={expire:0n,addrs:[]},s=n==null?e.len:e.pos+n;for(;e.pos<s;){let a=e.uint32();switch(a>>>3){case 1:{i.expire=e.uint64();break}case 2:{if(o.limits?.addrs!=null&&i.addrs.length===o.limits.addrs)throw new _r('Decode error - map field "addrs" had too many elements');i.addrs.push(e.bytes());break}case 3:{i.voucher=Fn.codec().decode(e,e.uint32(),{limits:o.limits?.voucher});break}default:{e.skipType(a&7);break}}}return i})),t),r.encode=e=>Ct(e,r.codec()),r.decode=(e,n)=>Bt(e,r.codec(),n)})(qn||(qn={}));var ir;(function(r){let t;r.codec=()=>(t==null&&(t=Dt((e,n,o={})=>{o.lengthDelimited!==!1&&n.fork(),e.duration!=null&&(n.uint32(8),n.uint32(e.duration)),e.data!=null&&(n.uint32(16),n.uint64(e.data)),o.lengthDelimited!==!1&&n.ldelim()},(e,n,o={})=>{let i={},s=n==null?e.len:e.pos+n;for(;e.pos<s;){let a=e.uint32();switch(a>>>3){case 1:{i.duration=e.uint32();break}case 2:{i.data=e.uint64();break}default:{e.skipType(a&7);break}}}return i})),t),r.encode=e=>Ct(e,r.codec()),r.decode=(e,n)=>Bt(e,r.codec(),n)})(ir||(ir={}));var k;(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"})(k||(k={}));var ss;(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"})(ss||(ss={}));(function(r){r.codec=()=>Ue(ss)})(k||(k={}));var sr;(function(r){let t;r.codec=()=>(t==null&&(t=Dt((e,n,o={})=>{o.lengthDelimited!==!1&&n.fork(),e.relay!=null&&e.relay.byteLength>0&&(n.uint32(10),n.bytes(e.relay)),e.peer!=null&&e.peer.byteLength>0&&(n.uint32(18),n.bytes(e.peer)),e.expiration!=null&&e.expiration!==0n&&(n.uint32(24),n.uint64(e.expiration)),o.lengthDelimited!==!1&&n.ldelim()},(e,n,o={})=>{let i={relay:it(0),peer:it(0),expiration:0n},s=n==null?e.len:e.pos+n;for(;e.pos<s;){let a=e.uint32();switch(a>>>3){case 1:{i.relay=e.bytes();break}case 2:{i.peer=e.bytes();break}case 3:{i.expiration=e.uint64();break}default:{e.skipType(a&7);break}}}return i})),t),r.encode=e=>Ct(e,r.codec()),r.decode=(e,n)=>Bt(e,r.codec(),n)})(sr||(sr={}));var Fn;(function(r){let t;r.codec=()=>(t==null&&(t=Dt((e,n,o={})=>{o.lengthDelimited!==!1&&n.fork(),e.publicKey!=null&&e.publicKey.byteLength>0&&(n.uint32(10),n.bytes(e.publicKey)),e.payloadType!=null&&e.payloadType.byteLength>0&&(n.uint32(18),n.bytes(e.payloadType)),e.payload!=null&&(n.uint32(26),sr.codec().encode(e.payload,n)),e.signature!=null&&e.signature.byteLength>0&&(n.uint32(42),n.bytes(e.signature)),o.lengthDelimited!==!1&&n.ldelim()},(e,n,o={})=>{let i={publicKey:it(0),payloadType:it(0),signature:it(0)},s=n==null?e.len:e.pos+n;for(;e.pos<s;){let a=e.uint32();switch(a>>>3){case 1:{i.publicKey=e.bytes();break}case 2:{i.payloadType=e.bytes();break}case 3:{i.payload=sr.codec().decode(e,e.uint32(),{limits:o.limits?.payload});break}case 5:{i.signature=e.bytes();break}default:{e.skipType(a&7);break}}}return i})),t),r.encode=e=>Ct(e,r.codec()),r.decode=(e,n)=>Bt(e,r.codec(),n)})(Fn||(Fn={}));var Kh=r=>r.toString().split("/").slice(1),ar=r=>({match:t=>t.length<1?!1:r(t[0])?t.slice(1):!1,pattern:"fn"}),M=r=>({match:t=>ar(e=>e===r).match(t),pattern:r}),ke=()=>({match:r=>ar(t=>typeof t=="string").match(r),pattern:"{string}"}),Or=()=>({match:r=>ar(t=>!isNaN(parseInt(t))).match(r),pattern:"{number}"}),X=()=>({match:r=>{if(r.length<2||r[0]!=="p2p"&&r[0]!=="ipfs")return!1;if(r[1].startsWith("Q")||r[1].startsWith("1"))try{Q.decode(`z${r[1]}`)}catch{return!1}else return!1;return r.slice(2)},pattern:"/p2p/{peerid}"}),Mr=()=>({match:r=>{if(r.length<2||r[0]!=="certhash")return!1;try{li.decode(r[1])}catch{return!1}return r.slice(2)},pattern:"/certhash/{certhash}"}),G=r=>({match:t=>{let e=r.match(t);return e===!1?t:e},pattern:`optional(${r.pattern})`}),St=(...r)=>({match:t=>{let e;for(let n of r){let o=n.match(t);o!==!1&&(e==null||o.length<e.length)&&(e=o)}return e??!1},pattern:`or(${r.map(t=>t.pattern).join(", ")})`}),K=(...r)=>({match:t=>{for(let e of r){let n=e.match(t);if(n===!1)return!1;t=n}return t},pattern:`and(${r.map(t=>t.pattern).join(", ")})`});function tt(...r){function t(o){let i=Kh(o);for(let s of r){let a=s.match(i);if(a===!1)return!1;i=a}return i}function e(o){return t(o)!==!1}function n(o){let i=t(o);return i===!1?!1:i.length===0}return{matchers:r,matches:e,exactMatch:n}}var Vn=K(M("dns4"),ke()),Hn=K(M("dns6"),ke()),Gn=K(M("dnsaddr"),ke()),cs=K(M("dns"),ke()),vx=tt(Vn,G(X())),Sx=tt(Hn,G(X())),Ax=tt(Gn,G(X())),_x=tt(St(cs,Gn,Vn,Hn),G(X())),qc=K(M("ip4"),ar(In)),Fc=K(M("ip6"),ar(Tn)),us=St(qc,Fc),le=St(us,cs,Vn,Hn,Gn),Ix=tt(St(us,K(St(cs,Gn,Vn,Hn),G(X())))),Tx=tt(qc),Lx=tt(Fc),Rx=tt(us),ls=K(le,M("tcp"),Or()),kr=K(le,M("udp"),Or()),Bx=tt(K(ls,G(X()))),Cx=tt(kr),fs=K(kr,M("quic"),G(X())),Zn=K(kr,M("quic-v1"),G(X())),qh=St(fs,Zn),Dx=tt(fs),Px=tt(Zn),as=St(le,ls,kr,fs,Zn),zc=St(K(as,M("ws"),G(X()))),Nx=tt(zc),Vc=St(K(as,M("wss"),G(X())),K(as,M("tls"),G(K(M("sni"),ke())),M("ws"),G(X()))),Ux=tt(Vc),Hc=K(kr,M("webrtc-direct"),G(Mr()),G(Mr()),G(X())),Ox=tt(Hc),Gc=K(Zn,M("webtransport"),G(Mr()),G(Mr()),G(X())),Mx=tt(Gc),zn=St(zc,Vc,K(ls,G(X())),K(qh,G(X())),K(le,G(X())),Hc,Gc,X()),Zc=tt(zn),Fh=K(zn,M("p2p-circuit"),X()),Wn=tt(Fh),zh=St(K(zn,M("p2p-circuit"),M("webrtc"),G(X())),K(zn,M("webrtc"),G(X())),K(M("webrtc"),G(X()))),kx=tt(zh),Vh=St(K(le,M("tcp"),Or(),M("http"),G(X())),K(le,M("http"),G(X()))),Kx=tt(Vh),Hh=St(K(le,M("tcp"),St(K(M("443"),M("http")),K(Or(),M("https"))),G(X())),K(le,M("tls"),M("http"),G(X())),K(le,M("https"),G(X()))),qx=tt(Hh),Gh=St(K(M("memory"),ke(),G(X()))),Fx=tt(Gh);function $n(r){let t=new globalThis.AbortController;function e(){t.abort();for(let i of r)i?.removeEventListener!=null&&i.removeEventListener("abort",e)}for(let i of r){if(i?.aborted===!0){e();break}i?.addEventListener!=null&&i.addEventListener("abort",e)}function n(){for(let i of r)i?.removeEventListener!=null&&i.removeEventListener("abort",e)}let o=t.signal;return o.clear=n,o}var Yn=class extends Error{constructor(t="Transfer limit error"){super(t),this.name="TransferLimitError"}},Kr=class extends Error{constructor(t="Duration limit error"){super(t),this.name="DurationLimitError"}},qr=class extends Error{static name="HadEnoughRelaysError";name="HadEnoughRelaysError"},Xn=class extends Error{static name="DoubleRelayError";name="DoubleRelayError"},Qn=class extends Error{static name="RelayQueueFullError";name="RelayQueueFullError"};async function*Wc(r,t,e){let n=t.remaining;for await(let o of r){let i=BigInt(o.byteLength);if(t.remaining-i<0){let s=Number(t.remaining);t.remaining=0n;try{s!==0&&(yield o.subarray(0,s))}catch(a){e.log.error(a)}throw new Yn(`data limit of ${n} bytes exceeded`)}t.remaining-=i,yield o}}function $c(r,t,e,n,o){function i(f){r.abort(f),t.abort(f)}let s=[e,n.signal];n.limit?.duration!=null&&(o.log("limiting relayed connection duration to %dms",n.limit.duration),s.push(AbortSignal.timeout(n.limit.duration)));let a=$n(s),c=!1,l=!1,u;n.limit?.data!=null&&(u={remaining:n.limit.data}),queueMicrotask(()=>{let f=()=>{o.log("relayed connection reached time limit"),t.abort(new Kr(`duration limit of ${n.limit?.duration} ms exceeded`))};a.addEventListener("abort",f,{once:!0}),t.sink(u==null?r.source:Wc(r.source,u,o)).catch(d=>{o.log.error("error while relaying streams src -> dst",d),i(d)}).finally(()=>{c=!0,l&&(a.removeEventListener("abort",f),a.clear())})}),queueMicrotask(()=>{let f=()=>{o.log("relayed connection reached time limit"),r.abort(new Kr(`duration limit of ${n.limit?.duration} ms exceeded`))};a.addEventListener("abort",f,{once:!0}),r.sink(u==null?t.source:Wc(t.source,u,o)).catch(d=>{o.log.error("error while relaying streams dst -> src",d),i(d)}).finally(()=>{l=!0,c&&(a.removeEventListener("abort",f),a.clear())})})}function hs(r){let t=r*BigInt(1e3),e=new Date().getTime();return Number(t-BigInt(e))}var Fr=class{expires;bytes;constructor(t){t?.duration!=null&&t?.duration!==0&&(this.expires=Date.now()+t.duration*1e3),this.bytes=t?.data,this.bytes===0n&&(this.bytes=void 0),this.onData=this.onData.bind(this)}onData(t){this.bytes!=null&&(this.bytes-=BigInt(t.byteLength),this.bytes<0n&&(this.bytes=0n))}getLimits(){if(this.expires==null&&this.bytes==null)return;let t={};if(this.bytes!=null){let e=this;Object.defineProperty(t,"bytes",{get(){return e.bytes}})}if(this.expires!=null){let e=this;Object.defineProperty(t,"seconds",{get(){return Math.round(((e.expires??0)-Date.now())/1e3)}})}return t}},jn=tt(K(Zc.matchers[0],M("p2p-circuit"))),Jn=tt(M("p2p-circuit"));function to(r,t){let e={[Symbol.iterator]:()=>e,next:()=>{let n=r.next(),o=n.value;return n.done===!0||o==null?{done:!0,value:void 0}:{done:!1,value:t(o)}}};return e}var Ae=class{map;constructor(t){if(this.map=new Map,t!=null)for(let[e,n]of t.entries())this.map.set(e.toString(),{key:e,value:n})}[Symbol.iterator](){return this.entries()}clear(){this.map.clear()}delete(t){return this.map.delete(t.toString())}entries(){return to(this.map.entries(),t=>[t[1].key,t[1].value])}forEach(t){this.map.forEach((e,n)=>{t(e.value,e.key,this)})}get(t){return this.map.get(t.toString())?.value}has(t){return this.map.has(t.toString())}set(t,e){this.map.set(t.toString(),{key:t,value:e})}keys(){return to(this.map.values(),t=>t.key)}values(){return to(this.map.values(),t=>t.value)}get size(){return this.map.size}};var ds={32:16777619n,64:1099511628211n,128:309485009821345068724781371n,256:374144419156711147060143317175368453031918731002211n,512:35835915874844867368919076489095108449946327955754392558399825615420669938882575126094039892345713852759n,1024:5016456510113118655434598811035278955030765345404790744303017523831112055108147451509157692220295382716162651878526895249385292291816524375083746691371804094271873160484737966720260389217684476157468082573n},Yc={32:2166136261n,64:14695981039346656037n,128:144066263297769815596495629667062367629n,256:100029257958052580907070968620625704837092796014241193945225284501741471925557n,512:9659303129496669498009435400716310466090418745672637896108374329434462657994582932197716438449813051892206539805784495328239340083876191928701583869517785n,1024:14197795064947621068722070641403218320880622795441933960878474914617582723252296732303717722150864096521202355549365628174669108571814760471015076148029755969804077320157692458563003215304957150157403644460363550505412711285966361610267868082893823963790439336411086884584107735010676915n},Xc=new globalThis.TextEncoder;function Zh(r,t){let e=ds[t],n=Yc[t];for(let o=0;o<r.length;o++)n^=BigInt(r[o]),n=BigInt.asUintN(t,n*e);return n}function Wh(r,t,e){if(e.length===0)throw new Error("The `utf8Buffer` option must have a length greater than zero");let n=ds[t],o=Yc[t],i=r;for(;i.length>0;){let s=Xc.encodeInto(i,e);i=i.slice(s.read);for(let a=0;a<s.written;a++)o^=BigInt(e[a]),o=BigInt.asUintN(t,o*n)}return o}function ps(r,{size:t=32,utf8Buffer:e}={}){if(!ds[t])throw new Error("The `size` option must be one of 32, 64, 128, 256, 512, or 1024");if(typeof r=="string"){if(e)return Wh(r,t,e);r=Xc.encode(r)}return Zh(r,t)}var zr={hash:r=>Number(ps(r,{size:32})),hashV:(r,t)=>$h(zr.hash(r,t))};function $h(r){let t=r.toString(16);return t.length%2===1&&(t=`0${t}`),z(t,"base16")}var ms=64,Wt=class{fp;h;seed;constructor(t,e,n,o=2){if(o>ms)throw new TypeError("Invalid Fingerprint Size");let i=e.hashV(t,n),s=it(o);for(let a=0;a<s.length;a++)s[a]=i[a];s.length===0&&(s[0]=7),this.fp=s,this.h=e,this.seed=n}hash(){return this.h.hash(this.fp,this.seed)}equals(t){return t?.fp instanceof Uint8Array?pt(this.fp,t.fp):!1}};function Ke(r,t){return Math.floor(Math.random()*(t-r))+r}var qe=class{contents;constructor(t){this.contents=new Array(t).fill(null)}has(t){if(!(t instanceof Wt))throw new TypeError("Invalid Fingerprint");return this.contents.some(e=>t.equals(e))}add(t){if(!(t instanceof Wt))throw new TypeError("Invalid Fingerprint");for(let e=0;e<this.contents.length;e++)if(this.contents[e]==null)return this.contents[e]=t,!0;return!0}swap(t){if(!(t instanceof Wt))throw new TypeError("Invalid Fingerprint");let e=Ke(0,this.contents.length-1),n=this.contents[e];return this.contents[e]=t,n}remove(t){if(!(t instanceof Wt))throw new TypeError("Invalid Fingerprint");let e=this.contents.findIndex(n=>t.equals(n));return e>-1?(this.contents[e]=null,!0):!1}};var Yh=500,Vr=class{bucketSize;filterSize;fingerprintSize;buckets;count;hash;seed;constructor(t){this.filterSize=t.filterSize,this.bucketSize=t.bucketSize??4,this.fingerprintSize=t.fingerprintSize??2,this.count=0,this.buckets=[],this.hash=t.hash??zr,this.seed=t.seed??Ke(0,Math.pow(2,10))}add(t){typeof t=="string"&&(t=z(t));let e=new Wt(t,this.hash,this.seed,this.fingerprintSize),n=this.hash.hash(t,this.seed)%this.filterSize,o=(n^e.hash())%this.filterSize;if(this.buckets[n]==null&&(this.buckets[n]=new qe(this.bucketSize)),this.buckets[o]==null&&(this.buckets[o]=new qe(this.bucketSize)),this.buckets[n].add(e)||this.buckets[o].add(e))return this.count++,!0;let i=[n,o],s=i[Ke(0,i.length-1)];this.buckets[s]==null&&(this.buckets[s]=new qe(this.bucketSize));for(let a=0;a<Yh;a++){let c=this.buckets[s].swap(e);if(c!=null&&(s=(s^c.hash())%this.filterSize,this.buckets[s]==null&&(this.buckets[s]=new qe(this.bucketSize)),this.buckets[s].add(c)))return this.count++,!0}return!1}has(t){typeof t=="string"&&(t=z(t));let e=new Wt(t,this.hash,this.seed,this.fingerprintSize),n=this.hash.hash(t,this.seed)%this.filterSize,o=this.buckets[n]?.has(e)??!1;if(o)return o;let i=(n^e.hash())%this.filterSize;return this.buckets[i]?.has(e)??!1}remove(t){typeof t=="string"&&(t=z(t));let e=new Wt(t,this.hash,this.seed,this.fingerprintSize),n=this.hash.hash(t,this.seed)%this.filterSize,o=this.buckets[n]?.remove(e)??!1;if(o)return this.count--,o;let i=(n^e.hash())%this.filterSize,s=this.buckets[i]?.remove(e)??!1;return s&&this.count--,s}get reliable(){return Math.floor(100*(this.count/this.filterSize))<=90}},Xh={1:.5,2:.84,4:.95,8:.98};function Qh(r=.001){return r>.002?2:r>1e-5?4:8}function Qc(r,t=.001){let e=Qh(t),n=Xh[e],o=Math.round(r/n),i=Math.min(Math.ceil(Math.log2(1/t)+Math.log2(2*e)),ms);return{filterSize:o,bucketSize:e,fingerprintSize:i}}var eo=class{filterSize;bucketSize;fingerprintSize;scale;filterSeries;hash;seed;constructor(t){this.bucketSize=t.bucketSize??4,this.filterSize=t.filterSize??(1<<18)/this.bucketSize,this.fingerprintSize=t.fingerprintSize??2,this.scale=t.scale??2,this.hash=t.hash??zr,this.seed=t.seed??Ke(0,Math.pow(2,10)),this.filterSeries=[new Vr({filterSize:this.filterSize,bucketSize:this.bucketSize,fingerprintSize:this.fingerprintSize,hash:this.hash,seed:this.seed})]}add(t){if(typeof t=="string"&&(t=z(t)),this.has(t))return!0;let e=this.filterSeries.find(n=>n.reliable);if(e==null){let n=this.filterSize*Math.pow(this.scale,this.filterSeries.length);e=new Vr({filterSize:n,bucketSize:this.bucketSize,fingerprintSize:this.fingerprintSize,hash:this.hash,seed:this.seed}),this.filterSeries.push(e)}return e.add(t)}has(t){typeof t=="string"&&(t=z(t));for(let e=0;e<this.filterSeries.length;e++)if(this.filterSeries[e].has(t))return!0;return!1}remove(t){typeof t=="string"&&(t=z(t));for(let e=0;e<this.filterSeries.length;e++)if(this.filterSeries[e].remove(t))return!0;return!1}get count(){return this.filterSeries.reduce((t,e)=>t+e.count,0)}};function cr(r,t=.001,e){return new eo({...Qc(r,t),...e??{}})}var ro=class{filter;constructor(t,e){this.filter=cr(t,e)}has(t){return this.filter.has(t.toMultihash().bytes)}add(t){this.filter.add(t.toMultihash().bytes)}remove(t){this.filter.remove?.(t.toMultihash().bytes)}};function ys(r,t=.001){return new ro(r,t)}var gs=class extends Ae{metric;constructor(t){super();let{name:e,metrics:n}=t;this.metric=n.registerMetric(e),this.updateComponentMetric()}set(t,e){return super.set(t,e),this.updateComponentMetric(),this}delete(t){let e=super.delete(t);return this.updateComponentMetric(),e}clear(){super.clear(),this.updateComponentMetric()}updateComponentMetric(){this.metric.update(this.size)}};function bs(r){let{name:t,metrics:e}=r,n;return e!=null?n=new gs({name:t,metrics:e}):n=new Ae,n}var xs=class extends Error{type;code;constructor(t,e,n){super(t??"The operation was aborted"),this.type="aborted",this.name=n??"AbortError",this.code=e??"ABORT_ERR"}};function jc(r,t){let e=new xs(t?.errorMessage,t?.errorCode,t?.errorName),n=new AbortController,o=()=>{n.abort(e)},i=AbortSignal.timeout(r);i.addEventListener("abort",o);let s=n.signal;return s.reset=a=>{i?.removeEventListener("abort",o),i=AbortSignal.timeout(a??r),i.addEventListener("abort",()=>{n.abort(e)})},s.clear=()=>{i?.removeEventListener("abort",o),i=void 0},s}var no=class{reservations;maxReservations;applyDefaultLimit;reservationTtl;defaultDurationLimit;defaultDataLimit;log;constructor(t,e={}){this.log=t.logger.forComponent("libp2p:circuit-relay:server:reservation-store"),this.maxReservations=e.maxReservations??Cc,this.applyDefaultLimit=e.applyDefaultLimit!==!1,this.reservationTtl=e.reservationTtl??Dc,this.defaultDurationLimit=e.defaultDurationLimit??Uc,this.defaultDataLimit=e.defaultDataLimit??Oc,this.reservations=bs({metrics:t.metrics,name:"libp2p_circuit_relay_server_reservations_total"})}reserve(t,e,n){let o=this.reservations.get(t);if(this.reservations.size>=this.maxReservations&&o==null)return{status:k.RESERVATION_REFUSED};let i=new Date(Date.now()+this.reservationTtl),s;return this.applyDefaultLimit&&(s=n??{data:this.defaultDataLimit,duration:this.defaultDurationLimit}),o!=null?(this.log("refreshing reservation for client %p",t),o.signal.reset(this.reservationTtl)):(this.log("creating new reservation for client %p",t),o={addr:e,expiry:i,limit:s,signal:jc(this.reservationTtl)}),this.reservations.set(t,o),o.signal.addEventListener("abort",()=>{this.reservations.delete(t)}),{status:k.OK,expire:Math.round(i.getTime()/1e3)}}removeReservation(t){this.reservations.delete(t)}get(t){return this.reservations.get(t)}clear(){this.reservations.clear()}};var oo=class r{domain="libp2p-relay-rsvp";codec=new Uint8Array([3,2]);relay;peer;expiration;constructor({relay:t,peer:e,expiration:n}){this.relay=t,this.peer=e,this.expiration=n}marshal(){return sr.encode({relay:this.relay.toMultihash().bytes,peer:this.peer.toMultihash().bytes,expiration:BigInt(this.expiration)})}equals(t){return!(!(t instanceof r)||!this.peer.equals(t.peer)||!this.relay.equals(t.relay)||this.expiration!==t.expiration)}};var Jc=r=>r.protoCodes().includes(kn),jh={maxOutboundStopStreams:Ur},ws=class extends Ot{registrar;peerStore;addressManager;peerId;privateKey;connectionManager;connectionGater;reservationStore;started;hopTimeout;shutdownController;maxInboundHopStreams;maxOutboundHopStreams;maxOutboundStopStreams;log;constructor(t,e={}){super(),this.log=t.logger.forComponent("libp2p:circuit-relay:server"),this.registrar=t.registrar,this.peerStore=t.peerStore,this.addressManager=t.addressManager,this.peerId=t.peerId,this.privateKey=t.privateKey,this.connectionManager=t.connectionManager,this.connectionGater=t.connectionGater,this.started=!1,this.hopTimeout=e?.hopTimeout??Mc,this.maxInboundHopStreams=e.maxInboundHopStreams,this.maxOutboundHopStreams=e.maxOutboundHopStreams,this.maxOutboundStopStreams=e.maxOutboundStopStreams??jh.maxOutboundStopStreams,this.reservationStore=new no(t,e.reservations),this.shutdownController=new AbortController,this.shutdownController.signal}[Symbol.toStringTag]="@libp2p/circuit-relay-v2-server";isStarted(){return this.started}async start(){this.started||(await this.registrar.handle(qt,t=>{this.onHop(t).catch(e=>{this.log.error(e)})},{maxInboundStreams:this.maxInboundHopStreams,maxOutboundStreams:this.maxOutboundHopStreams,runOnLimitedConnection:!0}),this.started=!0)}async stop(){this.reservationStore.clear(),this.shutdownController.abort(),await this.registrar.unhandle(qt),this.started=!1}async onHop({connection:t,stream:e}){this.log("received circuit v2 hop protocol stream from %p",t.remotePeer);let n={signal:AbortSignal.timeout(this.hopTimeout)},o=Se(e);try{let i=await o.pb($).read(n);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},n)}catch(i){this.log.error("error while handling hop",i),await o.pb($).write({type:$.Type.STATUS,status:k.MALFORMED_MESSAGE},n),e.abort(i)}}async handleHopProtocol({stream:t,request:e,connection:n},o){switch(this.log("received hop message"),e.type){case $.Type.RESERVE:await this.handleReserve({stream:t,request:e,connection:n},o);break;case $.Type.CONNECT:await this.handleConnect({stream:t,request:e,connection:n},o);break;default:this.log.error("invalid hop request type %s via peer %p",e.type,n.remotePeer),await t.pb($).write({type:$.Type.STATUS,status:k.UNEXPECTED_MESSAGE})}}async handleReserve({stream:t,connection:e},n){let o=t.pb($);if(this.log("hop reserve request from %p",e.remotePeer),Jc(e.remoteAddr)){this.log.error("relay reservation over circuit connection denied for peer: %p",e.remotePeer),await o.write({type:$.Type.STATUS,status:k.PERMISSION_DENIED},n);return}if(await this.connectionGater.denyInboundRelayReservation?.(e.remotePeer)===!0){this.log.error("reservation for %p denied by connection gater",e.remotePeer),await o.write({type:$.Type.STATUS,status:k.PERMISSION_DENIED},n);return}let i=this.reservationStore.reserve(e.remotePeer,e.remoteAddr);try{if(i.status!==k.OK){await o.write({type:$.Type.STATUS,status:i.status},n);return}if(i.expire!=null){let s=i.expire*1e3-Date.now();await this.peerStore.merge(e.remotePeer,{tags:{[os]:{value:1,ttl:s},[is]:{value:1,ttl:s}}})}await o.write({type:$.Type.STATUS,status:k.OK,reservation:await this.makeReservation(e.remotePeer,BigInt(i.expire??0)),limit:this.reservationStore.get(e.remotePeer)?.limit},n),this.log("sent confirmation response to %s",e.remotePeer)}catch(s){this.log.error("failed to send confirmation response to %p - %e",e.remotePeer,s),this.reservationStore.removeReservation(e.remotePeer);try{await this.peerStore.merge(e.remotePeer,{tags:{[os]:void 0,[is]:void 0}})}catch(a){this.log.error("failed to untag relay source peer %p - %e",e.remotePeer,a)}}}async makeReservation(t,e){let n=[];for(let i of this.addressManager.getAddresses())i.toString().includes("/p2p-circuit")||n.push(i.bytes);let o=await Pr.seal(new oo({peer:t,relay:this.peerId,expiration:e}),this.privateKey);return{addrs:n,expire:e,voucher:{publicKey:be(o.publicKey),payloadType:o.payloadType,payload:{peer:t.toMultihash().bytes,relay:this.peerId.toMultihash().bytes,expiration:e},signature:o.signature}}}async handleConnect({stream:t,request:e,connection:n},o){let i=t.pb($);if(Jc(n.remoteAddr)){this.log.error("relay reservation over circuit connection denied for peer: %p",n.remotePeer),await i.write({type:$.Type.STATUS,status:k.PERMISSION_DENIED},o);return}this.log("hop connect request from %p",n.remotePeer);let s;try{if(e.peer==null)throw this.log.error("no peer info in hop connect request"),new Error("no peer info in request");e.peer.addrs.forEach(vt),s=Cr(Mt(e.peer.id))}catch(d){this.log.error("invalid hop connect request via peer %p %s",n.remotePeer,d),await i.write({type:$.Type.STATUS,status:k.MALFORMED_MESSAGE},o);return}let a=this.reservationStore.get(s);if(a==null){this.log.error("hop connect denied for destination peer %p not having a reservation for %p with status %s",s,n.remotePeer,k.NO_RESERVATION),await i.write({type:$.Type.STATUS,status:k.NO_RESERVATION},o);return}if(await this.connectionGater.denyOutboundRelayedConnection?.(n.remotePeer,s)===!0){this.log.error("hop connect for %p to %p denied by connection gater",n.remotePeer,s),await i.write({type:$.Type.STATUS,status:k.PERMISSION_DENIED},o);return}let c=this.connectionManager.getConnections(s);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",s,n.remotePeer),await i.write({type:$.Type.STATUS,status:k.NO_RESERVATION},o);return}let l=c[0],u=await this.stopHop({connection:l,request:{type:Ut.Type.CONNECT,peer:{id:n.remotePeer.toMultihash().bytes,addrs:[]},limit:a?.limit}},o);if(u==null){this.log.error("failed to open stream to destination peer %p",l?.remotePeer),await i.write({type:$.Type.STATUS,status:k.CONNECTION_FAILED},o);return}await i.write({type:$.Type.STATUS,status:k.OK,limit:a?.limit},o);let f=t.unwrap();this.log("connection from %p to %p established - merging streams",n.remotePeer,s),$c(f,u,this.shutdownController.signal,a,{log:this.log})}async stopHop({connection:t,request:e},n){this.log("starting circuit relay v2 stop request to %s",t.remotePeer);let o=await t.newStream([Me],{maxOutboundStreams:this.maxOutboundStopStreams,runOnLimitedConnection:!0,...n}),i=Se(o),s=i.pb(Ut);await s.write(e,n);let a;try{a=await s.read(n)}catch{this.log.error("error parsing stop message response from %p",t.remotePeer)}if(a==null){this.log.error("could not read response from %p",t.remotePeer),await o.close(n);return}if(a.status===k.OK)return this.log("stop request to %p was successful",t.remotePeer),i.unwrap();this.log("stop request failed with code %d",a.status),await o.close(n)}get reservations(){return this.reservationStore.reservations}};function tu(r={}){return t=>new ws(t,r)}function Jh(r){let[t,e]=r[Symbol.asyncIterator]!=null?[r[Symbol.asyncIterator](),Symbol.asyncIterator]:[r[Symbol.iterator](),Symbol.iterator],n=[];return{peek:()=>t.next(),push:o=>{n.push(o)},next:()=>n.length>0?{done:!1,value:n.shift()}:t.next(),[e](){return this}}}var eu=Jh;function td(r){return r[Symbol.asyncIterator]!=null}function ru(r){return r?.then!=null}function ed(r,t){let e=0;if(td(r))return async function*(){for await(let c of r){let l=t(c,e++);ru(l)&&await l,yield c}}();let n=eu(r),{value:o,done:i}=n.next();if(i===!0)return function*(){}();if(typeof t(o,e++)?.then=="function")return async function*(){yield o;for await(let c of n){let l=t(c,e++);ru(l)&&await l,yield c}}();let a=t;return function*(){yield o;for(let c of n)a(c,e++),yield c}()}var nu=ed;var so=class{buffer;mask;top;btm;next;constructor(t){if(!(t>0)||(t-1&t)!==0)throw new Error("Max size for a FixedFIFO should be a power of two");this.buffer=new Array(t),this.mask=t-1,this.top=0,this.btm=0,this.next=null}push(t){return this.buffer[this.top]!==void 0?!1:(this.buffer[this.top]=t,this.top=this.top+1&this.mask,!0)}shift(){let t=this.buffer[this.btm];if(t!==void 0)return this.buffer[this.btm]=void 0,this.btm=this.btm+1&this.mask,t}isEmpty(){return this.buffer[this.btm]===void 0}},ur=class{size;hwm;head;tail;constructor(t={}){this.hwm=t.splitLimit??16,this.head=new so(this.hwm),this.tail=this.head,this.size=0}calculateSize(t){return t?.byteLength!=null?t.byteLength:1}push(t){if(t?.value!=null&&(this.size+=this.calculateSize(t.value)),!this.head.push(t)){let e=this.head;this.head=e.next=new so(2*this.head.buffer.length),this.head.push(t)}}shift(){let t=this.tail.shift();if(t===void 0&&this.tail.next!=null){let e=this.tail.next;this.tail.next=null,this.tail=e,t=this.tail.shift()}return t?.value!=null&&(this.size-=this.calculateSize(t.value)),t}isEmpty(){return this.head.isEmpty()}};var Es=class extends Error{type;code;constructor(t,e){super(t??"The operation was aborted"),this.type="aborted",this.code=e??"ABORT_ERR"}};function lr(r={}){return rd(e=>{let n=e.shift();if(n==null)return{done:!0};if(n.error!=null)throw n.error;return{done:n.done===!0,value:n.value}},r)}function rd(r,t){t=t??{};let e=t.onEnd,n=new ur,o,i,s,a=Zt(),c=async()=>{try{return n.isEmpty()?s?{done:!0}:await new Promise((h,w)=>{i=v=>{i=null,n.push(v);try{h(r(n))}catch(m){w(m)}return o}}):r(n)}finally{n.isEmpty()&&queueMicrotask(()=>{a.resolve(),a=Zt()})}},l=h=>i!=null?i(h):(n.push(h),o),u=h=>(n=new ur,i!=null?i({error:h}):(n.push({error:h}),o)),f=h=>{if(s)return o;if(t?.objectMode!==!0&&h?.byteLength==null)throw new Error("objectMode was not true but tried to push non-Uint8Array value");return l({done:!1,value:h})},d=h=>s?o:(s=!0,h!=null?u(h):l({done:!0})),g=()=>(n=new ur,d(),{done:!0}),y=h=>(d(h),{done:!0});if(o={[Symbol.asyncIterator](){return this},next:c,return:g,throw:y,push:f,end:d,get readableLength(){return n.size},onEmpty:async h=>{let w=h?.signal;if(w?.throwIfAborted(),n.isEmpty())return;let v,m;w!=null&&(v=new Promise((_,B)=>{m=()=>{B(new Es)},w.addEventListener("abort",m)}));try{await Promise.race([a.promise,v])}finally{m!=null&&w!=null&&w?.removeEventListener("abort",m)}}},e==null)return o;let b=o;return o={[Symbol.asyncIterator](){return this},next(){return b.next()},throw(h){return b.throw(h),e!=null&&(e(h),e=void 0),{done:!0}},return(){return b.return(),e!=null&&(e(),e=void 0),{done:!0}},push:f,end(h){return b.end(h),e!=null&&(e(h),e=void 0),o},get readableLength(){return b.readableLength},onEmpty:h=>b.onEmpty(h)},o}function nd(r){return r[Symbol.asyncIterator]!=null}async function od(r,t){try{await Promise.all(r.map(async e=>{for await(let n of e)t.push(n)})),t.end()}catch(e){t.end(e)}}async function*id(r){let t=lr({objectMode:!0});od(r,t).catch(()=>{}),yield*t}function*sd(r){for(let t of r)yield*t}function ad(...r){let t=[];for(let e of r)nd(e)||t.push(e);return t.length===r.length?sd(t):id(r)}var ou=ad;function iu(r,...t){if(r==null)throw new Error("Empty pipeline");if(vs(r)){let n=r;r=()=>n.source}else if(au(r)||su(r)){let n=r;r=()=>n}let e=[r,...t];if(e.length>1&&vs(e[e.length-1])&&(e[e.length-1]=e[e.length-1].sink),e.length>2)for(let n=1;n<e.length-1;n++)vs(e[n])&&(e[n]=ud(e[n]));return cd(...e)}var cd=(...r)=>{let t;for(;r.length>0;)t=r.shift()(t);return t},su=r=>r?.[Symbol.asyncIterator]!=null,au=r=>r?.[Symbol.iterator]!=null,vs=r=>r==null?!1:r.sink!=null&&r.source!=null,ud=r=>t=>{let e=r.sink(t);if(e?.then!=null){let n=lr({objectMode:!0});e.then(()=>{n.end()},s=>{n.end(s)});let o,i=r.source;if(su(i))o=async function*(){yield*i,n.end()};else if(au(i))o=function*(){yield*i,n.end()};else throw new Error("Unknown duplex source type - must be Iterable or AsyncIterable");return ou(n,o())}return r.source};function Ss(r){let{stream:t,remoteAddr:e,logger:n,onDataRead:o,onDataWrite:i}=r,s=n.forComponent("libp2p:stream:converter"),a=!1,c=!1,l=t.close.bind(t);t.close=async y=>{await l(y),g(!0)};let u=t.abort.bind(t);t.abort=y=>{u(y),g(!0)};let f=t.sink.bind(t);t.sink=async y=>{try{await f(iu(y,b=>nu(b,h=>i?.(h))))}catch(b){b.type!=="aborted"&&s.error("%s error in sink",e,b)}finally{c=!0,g()}};let d={log:s,sink:t.sink,source:async function*(){try{for await(let y of t.source)o?.(y),yield y}finally{a=!0,g()}}(),remoteAddr:e,timeline:{open:Date.now(),close:void 0},close:t.close,abort:t.abort};function g(y){y===!0&&(a=!0,c=!0),a&&c&&d.timeline.close==null&&(d.timeline.close=Date.now())}return d}var _e=class extends Event{type;detail;constructor(t,e){super(t),this.type=t,this.detail=e}};var As=class extends Error{type;code;constructor(t,e){super(t??"The operation was aborted"),this.type="aborted",this.name="AbortError",this.code=e??"ABORT_ERR"}};async function ao(r,t,e,n){let o=new As(n?.errorMessage,n?.errorCode);return e?.aborted===!0?Promise.reject(o):new Promise((i,s)=>{function a(){e?.removeEventListener("abort",u),r.removeEventListener(t,c),n?.errorEvent!=null&&r.removeEventListener(n.errorEvent,l)}let c=f=>{try{if(n?.filter?.(f)===!1)return}catch(d){a(),s(d);return}a(),i(f)},l=f=>{a(),s(f.detail)},u=()=>{a(),s(o)};e?.addEventListener("abort",u),r.addEventListener(t,c),n?.errorEvent!=null&&r.addEventListener(n.errorEvent,l)})}var co=class extends Error{static name="QueueFullError";constructor(t="The queue was full"){super(t),this.name="QueueFullError"}};var uo=class{deferred;signal;constructor(t){this.signal=t,this.deferred=Zt(),this.onAbort=this.onAbort.bind(this),this.signal?.addEventListener("abort",this.onAbort)}onAbort(){this.deferred.reject(this.signal?.reason??new Jt)}cleanup(){this.signal?.removeEventListener("abort",this.onAbort)}};function ld(){return`${parseInt(String(Math.random()*1e9),10).toString()}${Date.now()}`}var lo=class{id;fn;options;recipients;status;timeline;controller;constructor(t,e){this.id=ld(),this.status="queued",this.fn=t,this.options=e,this.recipients=[],this.timeline={created:Date.now()},this.controller=new AbortController,this.controller.signal,this.onAbort=this.onAbort.bind(this)}abort(t){this.controller.abort(t)}onAbort(){this.recipients.reduce((e,n)=>e&&n.signal?.aborted===!0,!0)&&(this.controller.abort(new Jt),this.cleanup())}async join(t={}){let e=new uo(t.signal);return this.recipients.push(e),t.signal?.addEventListener("abort",this.onAbort),e.deferred.promise}async run(){this.status="running",this.timeline.started=Date.now();try{this.controller.signal.throwIfAborted();let t=await Pn(this.fn({...this.options??{},signal:this.controller.signal}),this.controller.signal);this.recipients.forEach(e=>{e.deferred.resolve(t)}),this.status="complete"}catch(t){this.recipients.forEach(e=>{e.deferred.reject(t)}),this.status="errored"}finally{this.timeline.finished=Date.now(),this.cleanup()}}cleanup(){this.recipients.forEach(t=>{t.cleanup(),t.signal?.removeEventListener("abort",this.onAbort)})}};var fo=class extends Ot{concurrency;maxSize;queue;pending;sort;constructor(t={}){super(),this.concurrency=t.concurrency??Number.POSITIVE_INFINITY,this.maxSize=t.maxSize??Number.POSITIVE_INFINITY,this.pending=0,t.metricName!=null&&t.metrics?.registerMetricGroup(t.metricName,{calculate:()=>({size:this.queue.length,running:this.pending,queued:this.queue.length-this.pending})}),this.sort=t.sort,this.queue=[]}tryToStartAnother(){if(this.size===0)return queueMicrotask(()=>{this.safeDispatchEvent("empty")}),this.running===0&&queueMicrotask(()=>{this.safeDispatchEvent("idle")}),!1;if(this.pending<this.concurrency){let t;for(let e of this.queue)if(e.status==="queued"){t=e;break}return t==null?!1:(this.safeDispatchEvent("active"),this.pending++,t.run().finally(()=>{for(let e=0;e<this.queue.length;e++)if(this.queue[e]===t){this.queue.splice(e,1);break}this.pending--,this.tryToStartAnother(),this.safeDispatchEvent("next")}),!0)}return!1}enqueue(t){this.queue.push(t),this.sort!=null&&this.queue.sort(this.sort)}async add(t,e){if(e?.signal?.throwIfAborted(),this.size===this.maxSize)throw new co;let n=new lo(t,e);return this.enqueue(n),this.safeDispatchEvent("add"),this.tryToStartAnother(),n.join(e).then(o=>(this.safeDispatchEvent("completed",{detail:o}),this.safeDispatchEvent("success",{detail:{job:n,result:o}}),o)).catch(o=>{if(n.status==="queued"){for(let i=0;i<this.queue.length;i++)if(this.queue[i]===n){this.queue.splice(i,1);break}}throw this.safeDispatchEvent("error",{detail:o}),this.safeDispatchEvent("failure",{detail:{job:n,error:o}}),o})}clear(){this.queue.splice(0,this.queue.length)}abort(){this.queue.forEach(t=>{t.abort(new Jt)}),this.clear()}async onEmpty(t){this.size!==0&&await ao(this,"empty",t?.signal)}async onSizeLessThan(t,e){this.size<t||await ao(this,"next",e?.signal,{filter:()=>this.size<t})}async onIdle(t){this.pending===0&&this.size===0||await ao(this,"idle",t?.signal)}get size(){return this.queue.length}get queued(){return this.queue.length-this.pending}get running(){return this.pending}async*toGenerator(t){t?.signal?.throwIfAborted();let e=lr({objectMode:!0}),n=c=>{c!=null?this.abort():this.clear(),e.end(c)},o=c=>{c.detail!=null&&e.push(c.detail)},i=c=>{n(c.detail)},s=()=>{n()},a=()=>{n(new Jt("Queue aborted"))};this.addEventListener("completed",o),this.addEventListener("error",i),this.addEventListener("idle",s),t?.signal?.addEventListener("abort",a);try{yield*e}finally{this.removeEventListener("completed",o),this.removeEventListener("error",i),this.removeEventListener("idle",s),t?.signal?.removeEventListener("abort",a),n()}}};var fr=class extends fo{has(t){return this.find(t)!=null}find(t){return this.queue.find(e=>t.equals(e.options.peerId))}};var ho=class extends Ot{peerStore;registrar;connectionManager;randomWalk;started;running;topologyId;log;discoveryController;filter;queue;constructor(t,e={}){super(),this.log=t.logger.forComponent("libp2p:circuit-relay:discover-relays"),this.started=!1,this.running=!1,this.peerStore=t.peerStore,this.registrar=t.registrar,this.connectionManager=t.connectionManager,this.randomWalk=t.randomWalk,this.filter=e.filter,this.discoveryController=new AbortController,this.discoveryController.signal}isStarted(){return this.started}async start(){this.topologyId=await this.registrar.register(qt,{filter:this.filter,onConnect:t=>{this.log.trace("discovered relay %p queue (length: %d, active %d)",t,this.queue?.size,this.queue?.running),this.safeDispatchEvent("relay:discover",{detail:t})}}),this.started=!0}stop(){this.topologyId!=null&&this.registrar.unregister(this.topologyId),this.discoveryController?.abort(),this.started=!1}startDiscovery(){this.running||(this.log("start discovery"),this.running=!0,this.discoveryController=new AbortController,this.discoveryController.signal,Promise.resolve().then(async()=>{this.log("searching peer store for relays");let t=await this.peerStore.all({filters:[n=>n.protocols.includes(qt)],orders:[()=>Math.random()<.5?1:-1,(n,o)=>{let i=cu(n),s=cu(o);return i>s?-1:s>i?1:0}]});for(let n of t)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",t.length);let e=this.queue=new fr({concurrency:5});this.log("start random walk");for await(let n of this.randomWalk.walk({signal:this.discoveryController.signal})){if(this.log.trace("found random peer %p",n.id),e.has(n.id)){this.log.trace("random peer %p was already in queue",n.id);continue}if(this.connectionManager.getConnections(n.id)?.length>0){this.log.trace("random peer %p was already connected",n.id);continue}if(!await this.connectionManager.isDialable(n.multiaddrs)){this.log.trace("random peer %p was not dialable",n.id,n.multiaddrs.map(o=>o.toString()));continue}e.queued>10&&(this.log.trace("wait for space in queue for %p",n.id),await e.onSizeLessThan(10,{signal:this.discoveryController.signal})),this.log("adding random peer %p to dial queue (length: %d, active %d)",n.id,e.size,e.running),e.add(async()=>{let o=$n([this.discoveryController.signal,AbortSignal.timeout(5e3)]);try{await this.connectionManager.openConnection(n.id,{signal:o})}finally{o.clear()}},{peerId:n.id,signal:this.discoveryController.signal}).catch(o=>{this.log.error("error opening connection to random peer %p",n.id,o)})}this.log("stop random walk"),await e.onIdle()}).catch(t=>{this.discoveryController.signal.aborted||this.log.error("failed when finding relays on the network",t)}))}stopDiscovery(){this.log("stop discovery"),this.running=!1,this.discoveryController?.abort()}};function cu(r){let t=r.metadata.get("last-dial-success");return t==null?0:new Date(H(t)).getTime()}var _s=class extends Ot{connectionManager;addressManager;reservationStore;listeningAddrs;log;listenTimeout;reservationId;relay;constructor(t,e={}){super(),this.log=t.logger.forComponent("libp2p:circuit-relay:transport:listener"),this.connectionManager=t.connectionManager,this.addressManager=t.addressManager,this.reservationStore=t.reservationStore,this.listeningAddrs=[],this.listenTimeout=e.listenTimeout??Kn,this.reservationStore.addEventListener("relay:removed",this._onRemoveRelayPeer),this.reservationStore.addEventListener("relay:created-reservation",this._onAddRelayPeer)}_onRemoveRelayPeer=t=>{this.log("relay removed %p our relay %p",t.detail.relay,this.relay,this.relay?.equals(t.detail.relay)),this.relay?.equals(t.detail.relay)===!0&&(this.log("relay peer removed %p",t.detail.relay),this.listeningAddrs.forEach(e=>{this.addressManager.removeObservedAddr(e)}),this.listeningAddrs=[],this.safeDispatchEvent("listening"))};_onAddRelayPeer=t=>{let{details:e}=t.detail;e.type!=="configured"&&e.id===this.reservationId&&this.addedRelay(t.detail)};async listen(t){if(Jn.exactMatch(t))this.log("searching for circuit relay servers"),this.reservationId=this.reservationStore.reserveRelay();else if(jn.exactMatch(t)){this.log("listen on specific relay server %a",t);let e=AbortSignal.timeout(this.listenTimeout);let n=t.decapsulate("/p2p-circuit"),o=await this.connectionManager.openConnection(n,{signal:e});if(!this.reservationStore.hasReservation(o.remotePeer)){this.log("making reservation on peer %p",o.remotePeer);let i=await this.reservationStore.addRelay(o.remotePeer,"configured");this.addedRelay(i)}}else throw new Ie(`Could not listen on p2p-circuit address "${t}"`)}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(t){this.log("relay peer added %p",t.relay),this.relay=t.relay,this.listeningAddrs=t.details.reservation.addrs.map(e=>vt(e).encapsulate("/p2p-circuit")),this.listeningAddrs.forEach(e=>{this.addressManager.confirmObservedAddr(e,{type:"transport"})}),queueMicrotask(()=>{this.safeDispatchEvent("listening")})}};function uu(r){return new _s(r)}var lu="useandom-26T198340PX75pxJACKVERYMINDBUSHWOLF_GQZbfghjklqvwyzrict";var fu=(r=21)=>{let t="",e=crypto.getRandomValues(new Uint8Array(r|=0));for(;r--;)t+=lu[e[r]&63];return t};var fd=60*1e3*10,hd=60*1e3*5,dd=30*1e3,po=class extends Ot{peerId;connectionManager;peerStore;events;reserveQueue;reservations;pendingReservations;maxReservationQueueLength;reservationCompletionTimeout;started;log;relayFilter;constructor(t,e){super(),this.log=t.logger.forComponent("libp2p:circuit-relay:transport:reservation-store"),this.peerId=t.peerId,this.connectionManager=t.connectionManager,this.peerStore=t.peerStore,this.events=t.events,this.reservations=new Ae,this.pendingReservations=[],this.maxReservationQueueLength=e?.maxReservationQueueLength??Nc,this.reservationCompletionTimeout=e?.reservationCompletionTimeout??Kn,this.started=!1,this.relayFilter=cr(100),this.reserveQueue=new fr({concurrency:e?.reservationConcurrency??Pc,metricName:"libp2p_relay_reservation_queue",metrics:t.metrics}),this.events.addEventListener("connection:close",n=>{[...this.reservations.values()].find(i=>i.connection===n.detail.id)!=null&&this.#e(n.detail.remotePeer).catch(i=>{this.log("could not remove relay %p - %e",n.detail,i)})})}isStarted(){return this.started}start(){this.started=!0}afterStart(){Promise.resolve().then(async()=>{let t=await this.peerStore.all({filters:[e=>e.tags.has(Nr)]});this.log("removing tag from %d old relays",t.length),await Promise.all(t.map(async e=>{await this.peerStore.merge(e.id,{tags:{[Nr]:void 0}})})),this.log("redialing %d old relays",t.length),await Promise.all(t.map(async e=>this.addRelay(e.id,"discovered"))),this.#r()}).catch(t=>{this.log.error(t)})}stop(){this.reserveQueue.clear(),this.reservations.forEach(({timeout:t})=>{clearTimeout(t)}),this.reservations.clear(),this.started=!1}reserveRelay(){let t=fu();return this.pendingReservations.push(t),this.#r(),t}async addRelay(t,e){if(this.peerId.equals(t))throw this.log.trace("not trying to use self as relay"),new Ie("Cannot use self as relay");if(this.reserveQueue.size>this.maxReservationQueueLength)throw new Qn("The reservation queue is full");let n=this.reserveQueue.find(t);if(n!=null)return this.log.trace("potential relay peer %p is already in the reservation queue",t),n.join();if(this.relayFilter.has(t.toMultihash().bytes))throw new Ie("The relay was previously invalid");return this.log.trace("try to reserve relay slot with %p",t),this.reserveQueue.add(async()=>{let o=Date.now();try{let i=this.reservations.get(t);if(i!=null){let y=this.connectionManager.getConnections(t),b=!1;if(y.length===0&&this.log("already have relay reservation with %p but we are no longer connected",t),y.map(h=>h.id).includes(i.connection)&&(this.log("already have relay reservation with %p and the original connection is still open",t),b=!0),b&&hs(i.reservation.expire)>fd)return this.log("already have relay reservation with %p but we are still connected and it does not expire soon",t),{relay:t,details:i};await this.#e(t)}if(e==="discovered"&&this.pendingReservations.length===0)throw new qr("Not making reservation on discovered relay because we do not need any more relays");let s=AbortSignal.timeout(this.reservationCompletionTimeout);let a=await this.connectionManager.openConnection(t,{signal:s});if(Wn.matches(a.remoteAddr))throw new Xn("not creating reservation over relayed connection");let c=await this.#t(a,{signal:s}),l=hs(c.expire);this.log("created reservation on relay peer %p, expiry date is %s",t,new Date(Date.now()+l).toString());let u=Math.min(Math.max(l-hd,dd),Math.pow(2,31)-1),f=setTimeout(()=>{this.log("refresh reservation to relay %p",t),this.addRelay(t,e).catch(async y=>{this.log.error("could not refresh reservation to relay %p - %e",t,y),await this.#e(t)}).catch(y=>{this.log.error("could not remove expired reservation to relay %p - %e",t,y)})},u),d;if(e==="discovered"){let y=this.pendingReservations.pop();if(y==null)throw new qr("Made reservation on relay but did not need any more discovered relays");d={timeout:f,reservation:c,type:e,connection:a.id,id:y}}else d={timeout:f,reservation:c,type:e,connection:a.id};this.reservations.set(t,d),await this.peerStore.merge(t,{tags:{[Nr]:{value:1,ttl:l}}}),this.#r();let g={relay:t,details:d};return this.safeDispatchEvent("relay:created-reservation",{detail:g}),g}catch(i){throw e==="discovered"&&i.name==="HadEnoughRelaysError"||this.log.error("could not reserve slot on %p after %dms - %e",t,Date.now()-o,i),(i.name==="DialError"||i.name==="UnsupportedProtocolError")&&this.relayFilter.add(t.toMultihash().bytes),this.#e(t).catch(s=>{this.log.error("could not remove reservation on %p after reserving slot failed - %e",t,s)}),i}},{peerId:t})}hasReservation(t){return this.reservations.has(t)}getReservation(t){return this.reservations.get(t)?.reservation}reservationCount(t){return t==null?this.reservations.size:[...this.reservations.values()].reduce((e,n)=>(n.type===t&&e++,e),0)}cancelReservations(){[...this.reservations.values()].forEach(t=>{clearTimeout(t.timeout)}),this.reservations.clear()}async#t(t,e){e.signal?.throwIfAborted(),this.log("requesting reservation from %p",t.remotePeer);let n=await t.newStream(qt,e),i=Se(n).pb($);this.log.trace("send RESERVE to %p",t.remotePeer),await i.write({type:$.Type.RESERVE},e);let s;try{this.log.trace("reading response from %p",t.remotePeer),s=await i.read(e)}catch(c){throw n.abort(c),c}finally{n.status!=="closed"&&await n.close(e)}if(this.log.trace("read response %o",s),s.status===k.OK&&s.reservation!=null){let c=new Set;c.add(t.remoteAddr.toString());for(let l of s.reservation.addrs){let u=vt(l);u.getPeerId()==null&&(u=u.encapsulate(`/p2p/${t.remotePeer}`)),u=vt(u.toString().replace(`/p2p/${t.remotePeer}/p2p/${t.remotePeer}`,`/p2p/${t.remotePeer}`)),c.add(u.toString())}return s.reservation.addrs=[...c].map(l=>vt(l).bytes),s.reservation}let a=`reservation failed with status ${s.status??"undefined"}`;throw this.log.error(a),new Error(a)}async#e(t){let e=this.reservations.get(t);e!=null&&(this.log("removing relay reservation with %p from local store",t),clearTimeout(e.timeout),this.reservations.delete(t),e.type==="discovered"&&this.pendingReservations.push(e.id),await this.peerStore.merge(t,{tags:{[Nr]:void 0}}),this.safeDispatchEvent("relay:removed",{detail:{relay:t,details:e}}),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=cr(100),this.log("not discovered enough relays %d/%d",this.reservations.size,this.pendingReservations.length),this.safeDispatchEvent("relay:not-enough-relays")}};var pd=r=>{if(r.peer==null)return!1;try{r.peer.addrs.forEach(vt)}catch{return!1}return!0},hu={maxInboundStopStreams:Ur,maxOutboundStopStreams:Ur,stopTimeout:3e4},mo=class{discovery;registrar;peerStore;connectionManager;transportManager;peerId;upgrader;addressManager;connectionGater;reservationStore;logger;maxInboundStopStreams;maxOutboundStopStreams;started;log;shutdownController;constructor(t,e={}){this.log=t.logger.forComponent("libp2p:circuit-relay:transport"),this.registrar=t.registrar,this.peerStore=t.peerStore,this.connectionManager=t.connectionManager,this.transportManager=t.transportManager,this.logger=t.logger,this.peerId=t.peerId,this.upgrader=t.upgrader,this.addressManager=t.addressManager,this.connectionGater=t.connectionGater,this.maxInboundStopStreams=e.maxInboundStopStreams??hu.maxInboundStopStreams,this.maxOutboundStopStreams=e.maxOutboundStopStreams??hu.maxOutboundStopStreams,this.shutdownController=new AbortController,this.discovery=new ho(t,{filter:e.discoveryFilter??ys(kc,Kc)}),this.discovery.addEventListener("relay:discover",n=>{this.reservationStore.addRelay(n.detail,"discovered").catch(o=>{o.name!=="HadEnoughRelaysError"&&o.name!=="RelayQueueFullError"&&this.log.error("could not add discovered relay %p",n.detail,o)})}),this.reservationStore=new po(t,e),this.reservationStore.addEventListener("relay:not-enough-relays",()=>{this.discovery?.startDiscovery()}),this.reservationStore.addEventListener("relay:found-enough-relays",()=>{this.discovery?.stopDiscovery()}),this.started=!1}[Symbol.toStringTag]="@libp2p/circuit-relay-v2-transport";[ks]=["@libp2p/transport","@libp2p/circuit-relay-v2-transport"];get[Ks](){return this.discovery!=null?["@libp2p/identify"]:[]}[Ns]=!0;isStarted(){return this.started}async start(){this.shutdownController=new AbortController,await this.registrar.handle(Me,t=>{let e=this.upgrader.createInboundAbortSignal(this.shutdownController.signal);this.onStop(t,e).catch(n=>{this.log.error("error while handling STOP protocol",n),t.stream.abort(n)}).finally(()=>{e.clear()})},{maxInboundStreams:this.maxInboundStopStreams,maxOutboundStreams:this.maxOutboundStopStreams,runOnLimitedConnection:!0}),await Os(this.discovery,this.reservationStore),this.started=!0}async stop(){this.shutdownController.abort(),await Ms(this.discovery,this.reservationStore),await this.registrar.unhandle(Me),this.started=!1}async dial(t,e){if(t.protoCodes().filter(g=>g===kn).length!==1){let g="Invalid circuit relay address";throw this.log.error(g,t),new dr(g)}let n=t.toString().split("/p2p-circuit"),o=vt(n[0]),i=vt(n[n.length-1]),s=o.getPeerId(),a=i.getPeerId();if(s==null||a==null){let g=`ircuit relay dial to ${t.toString()} failed as address did not have both relay and destination PeerIDs`;throw this.log.error(`c${g}`),new dr(`C${g}`)}let c=Ki(s),l=Ki(a),f=this.connectionManager.getConnections(c)[0];f==null?(await this.peerStore.merge(c,{multiaddrs:[o]}),e.onProgress?.(new _e("circuit-relay:open-connection")),f=await this.connectionManager.openConnection(c,e)):e.onProgress?.(new _e("circuit-relay:reuse-connection"));let d;try{e.onProgress?.(new _e("circuit-relay:open-hop-stream")),d=await f.newStream(qt,e);let g=Se(d),y=g.pb($);e.onProgress?.(new _e("circuit-relay:write-connect-message")),await y.write({type:$.Type.CONNECT,peer:{id:l.toMultihash().bytes,addrs:[vt(i).bytes]}},e),e.onProgress?.(new _e("circuit-relay:read-connect-response"));let b=await y.read(e);if(b.status!==k.OK)throw new Gr(`failed to connect via relay with status ${b?.status?.toString()??"undefined"}`);let h=new Fr(b.limit),w=Ss({stream:g.unwrap(),remoteAddr:t,localAddr:o.encapsulate(`/p2p-circuit/p2p/${this.peerId.toString()}`),logger:this.logger,onDataRead:h.onData,onDataWrite:h.onData});return this.log("new outbound relayed connection %a",w.remoteAddr),await this.upgrader.upgradeOutbound(w,{...e,limits:h.getLimits()})}catch(g){throw this.log.error("circuit relay dial to destination %p via relay %p failed",l,c,g),d?.abort(g),g}}createListener(t){return uu({peerId:this.peerId,connectionManager:this.connectionManager,addressManager:this.addressManager,reservationStore:this.reservationStore,logger:this.logger})}listenFilter(t){return t=Array.isArray(t)?t:[t],t.filter(e=>jn.exactMatch(e)||Jn.exactMatch(e))}dialFilter(t){return t=Array.isArray(t)?t:[t],t.filter(e=>Wn.exactMatch(e))}async onStop({connection:t,stream:e},n){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.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",f)}let o=Se(e).pb(Ut),i=await o.read({signal:n});if(this.log("new circuit relay v2 stop stream from %p with type %s",t.remotePeer,i.type),i?.type===void 0){this.log.error("type was missing from circuit v2 stop protocol request from %s",t.remotePeer),await o.write({type:Ut.Type.STATUS,status:k.MALFORMED_MESSAGE},{signal:n}),await e.close();return}if(i.type!==Ut.Type.CONNECT){this.log.error("invalid stop connect request via peer %p",t.remotePeer),await o.write({type:Ut.Type.STATUS,status:k.UNEXPECTED_MESSAGE},{signal:n}),await e.close();return}if(!pd(i)){this.log.error("invalid stop connect request via peer %p",t.remotePeer),await o.write({type:Ut.Type.STATUS,status:k.MALFORMED_MESSAGE},{signal:n}),await e.close({signal:n});return}let s=Cr(Mt(i.peer.id));if(await this.connectionGater.denyInboundRelayedConnection?.(t.remotePeer,s)===!0){this.log.error("connection gater denied inbound relayed connection from %p",t.remotePeer),await o.write({type:Ut.Type.STATUS,status:k.PERMISSION_DENIED},{signal:n}),await e.close({signal:n});return}this.log.trace("sending success response to %p",t.remotePeer),await o.write({type:Ut.Type.STATUS,status:k.OK},{signal:n});let a=new Fr(i.limit),c=t.remoteAddr.encapsulate(`/p2p-circuit/p2p/${s.toString()}`),l=this.addressManager.getAddresses()[0],u=Ss({stream:o.unwrap().unwrap(),remoteAddr:c,localAddr:l,logger:this.logger,onDataRead:a.onData,onDataWrite:a.onData});this.log("new inbound relayed connection %a",u.remoteAddr),await this.upgrader.upgradeInbound(u,{limits:a.getLimits(),signal:n}),this.log("%s connection %a upgraded","inbound",u.remoteAddr)}};function du(r={}){return t=>new mo(t,r)}return Iu(md);})();
|
3
3
|
/*! Bundled license information:
|
4
4
|
|
5
5
|
@noble/hashes/esm/utils.js:
|
package/package.json
CHANGED
@@ -1,6 +1,6 @@
|
|
1
1
|
{
|
2
2
|
"name": "@libp2p/circuit-relay-v2",
|
3
|
-
"version": "3.2.6-
|
3
|
+
"version": "3.2.6-a6c9aee5a",
|
4
4
|
"description": "Implementation of Circuit Relay v2",
|
5
5
|
"license": "Apache-2.0 OR MIT",
|
6
6
|
"homepage": "https://github.com/libp2p/js-libp2p/tree/main/packages/transport-circuit-relay-v2#readme",
|
@@ -52,13 +52,13 @@
|
|
52
52
|
"doc-check": "aegir doc-check"
|
53
53
|
},
|
54
54
|
"dependencies": {
|
55
|
-
"@libp2p/crypto": "5.0.15-
|
56
|
-
"@libp2p/interface": "2.7.0-
|
57
|
-
"@libp2p/interface-internal": "2.3.7-
|
58
|
-
"@libp2p/peer-collections": "6.0.23-
|
59
|
-
"@libp2p/peer-id": "5.0.16-
|
60
|
-
"@libp2p/peer-record": "8.0.23-
|
61
|
-
"@libp2p/utils": "6.5.7-
|
55
|
+
"@libp2p/crypto": "5.0.15-a6c9aee5a",
|
56
|
+
"@libp2p/interface": "2.7.0-a6c9aee5a",
|
57
|
+
"@libp2p/interface-internal": "2.3.7-a6c9aee5a",
|
58
|
+
"@libp2p/peer-collections": "6.0.23-a6c9aee5a",
|
59
|
+
"@libp2p/peer-id": "5.0.16-a6c9aee5a",
|
60
|
+
"@libp2p/peer-record": "8.0.23-a6c9aee5a",
|
61
|
+
"@libp2p/utils": "6.5.7-a6c9aee5a",
|
62
62
|
"@multiformats/multiaddr": "^12.3.3",
|
63
63
|
"@multiformats/multiaddr-matcher": "^1.6.0",
|
64
64
|
"any-signal": "^4.1.1",
|
@@ -73,8 +73,8 @@
|
|
73
73
|
"uint8arrays": "^5.1.0"
|
74
74
|
},
|
75
75
|
"devDependencies": {
|
76
|
-
"@libp2p/interface-compliance-tests": "6.4.0-
|
77
|
-
"@libp2p/logger": "5.1.12-
|
76
|
+
"@libp2p/interface-compliance-tests": "6.4.0-a6c9aee5a",
|
77
|
+
"@libp2p/logger": "5.1.12-a6c9aee5a",
|
78
78
|
"aegir": "^45.1.1",
|
79
79
|
"delay": "^6.0.0",
|
80
80
|
"it-drain": "^3.0.7",
|