@libp2p/circuit-relay-v2 3.1.4-127abe24b → 3.1.4-5c4a79e5a
Sign up to get free protection for your applications and to get access to all the features.
- package/dist/index.min.js +4 -4
- package/dist/src/transport/listener.d.ts +5 -3
- package/dist/src/transport/listener.d.ts.map +1 -1
- package/dist/src/transport/listener.js +29 -19
- package/dist/src/transport/listener.js.map +1 -1
- package/dist/src/transport/transport.d.ts.map +1 -1
- package/dist/src/transport/transport.js +3 -1
- package/dist/src/transport/transport.js.map +1 -1
- package/package.json +10 -10
- package/src/transport/listener.ts +39 -28
- package/src/transport/transport.ts +3 -1
package/dist/index.min.js
CHANGED
@@ -1,9 +1,9 @@
|
|
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 Xf=Object.create;var In=Object.defineProperty;var Jf=Object.getOwnPropertyDescriptor;var Qf=Object.getOwnPropertyNames;var th=Object.getPrototypeOf,eh=Object.prototype.hasOwnProperty;var qi=(r,t)=>()=>(t||r((t={exports:{}}).exports,t),t.exports),kt=(r,t)=>{for(var e in t)In(r,e,{get:t[e],enumerable:!0})},dc=(r,t,e,n)=>{if(t&&typeof t=="object"||typeof t=="function")for(let s of Qf(t))!eh.call(r,s)&&s!==e&&In(r,s,{get:()=>t[s],enumerable:!(n=Jf(t,s))||n.enumerable});return r};var pc=(r,t,e)=>(e=r!=null?Xf(th(r)):{},dc(t||!r||!r.__esModule?In(e,"default",{value:r,enumerable:!0}):e,r)),rh=r=>dc(In({},"__esModule",{value:!0}),r);var Bl=qi(Ar=>{"use strict";var kp="[object ArrayBuffer]",ve=class r{static isArrayBuffer(t){return Object.prototype.toString.call(t)===kp}static toArrayBuffer(t){return this.isArrayBuffer(t)?t:t.byteLength===t.buffer.byteLength||t.byteOffset===0&&t.byteLength===t.buffer.byteLength?t.buffer:this.toUint8Array(t.buffer).slice(t.byteOffset,t.byteOffset+t.byteLength).buffer}static toUint8Array(t){return this.toView(t,Uint8Array)}static toView(t,e){if(t.constructor===e)return t;if(this.isArrayBuffer(t))return new e(t);if(this.isArrayBufferView(t))return new e(t.buffer,t.byteOffset,t.byteLength);throw new TypeError("The provided value is not of type '(ArrayBuffer or ArrayBufferView)'")}static isBufferSource(t){return this.isArrayBufferView(t)||this.isArrayBuffer(t)}static isArrayBufferView(t){return ArrayBuffer.isView(t)||t&&this.isArrayBuffer(t.buffer)}static isEqual(t,e){let n=r.toUint8Array(t),s=r.toUint8Array(e);if(n.length!==s.byteLength)return!1;for(let i=0;i<n.length;i++)if(n[i]!==s[i])return!1;return!0}static concat(...t){let e;Array.isArray(t[0])&&!(t[1]instanceof Function)||Array.isArray(t[0])&&t[1]instanceof Function?e=t[0]:t[t.length-1]instanceof Function?e=t.slice(0,t.length-1):e=t;let n=0;for(let o of e)n+=o.byteLength;let s=new Uint8Array(n),i=0;for(let o of e){let a=this.toUint8Array(o);s.set(a,i),i+=a.length}return t[t.length-1]instanceof Function?this.toView(s,t[t.length-1]):s.buffer}},na="string",Cp=/^[0-9a-f\s]+$/i,Np=/^(?:[A-Za-z0-9+/]{4})*(?:[A-Za-z0-9+/]{2}==|[A-Za-z0-9+/]{3}=)?$/,Lp=/^[a-zA-Z0-9-_]+$/,ts=class{static fromString(t){let e=unescape(encodeURIComponent(t)),n=new Uint8Array(e.length);for(let s=0;s<e.length;s++)n[s]=e.charCodeAt(s);return n.buffer}static toString(t){let e=ve.toUint8Array(t),n="";for(let i=0;i<e.length;i++)n+=String.fromCharCode(e[i]);return decodeURIComponent(escape(n))}},Gt=class{static toString(t,e=!1){let n=ve.toArrayBuffer(t),s=new DataView(n),i="";for(let o=0;o<n.byteLength;o+=2){let a=s.getUint16(o,e);i+=String.fromCharCode(a)}return i}static fromString(t,e=!1){let n=new ArrayBuffer(t.length*2),s=new DataView(n);for(let i=0;i<t.length;i++)s.setUint16(i*2,t.charCodeAt(i),e);return n}},es=class r{static isHex(t){return typeof t===na&&Cp.test(t)}static isBase64(t){return typeof t===na&&Np.test(t)}static isBase64Url(t){return typeof t===na&&Lp.test(t)}static ToString(t,e="utf8"){let n=ve.toUint8Array(t);switch(e.toLowerCase()){case"utf8":return this.ToUtf8String(n);case"binary":return this.ToBinary(n);case"hex":return this.ToHex(n);case"base64":return this.ToBase64(n);case"base64url":return this.ToBase64Url(n);case"utf16le":return Gt.toString(n,!0);case"utf16":case"utf16be":return Gt.toString(n);default:throw new Error(`Unknown type of encoding '${e}'`)}}static FromString(t,e="utf8"){if(!t)return new ArrayBuffer(0);switch(e.toLowerCase()){case"utf8":return this.FromUtf8String(t);case"binary":return this.FromBinary(t);case"hex":return this.FromHex(t);case"base64":return this.FromBase64(t);case"base64url":return this.FromBase64Url(t);case"utf16le":return Gt.fromString(t,!0);case"utf16":case"utf16be":return Gt.fromString(t);default:throw new Error(`Unknown type of encoding '${e}'`)}}static ToBase64(t){let e=ve.toUint8Array(t);if(typeof btoa<"u"){let n=this.ToString(e,"binary");return btoa(n)}else return Buffer.from(e).toString("base64")}static FromBase64(t){let e=this.formatString(t);if(!e)return new ArrayBuffer(0);if(!r.isBase64(e))throw new TypeError("Argument 'base64Text' is not Base64 encoded");return typeof atob<"u"?this.FromBinary(atob(e)):new Uint8Array(Buffer.from(e,"base64")).buffer}static FromBase64Url(t){let e=this.formatString(t);if(!e)return new ArrayBuffer(0);if(!r.isBase64Url(e))throw new TypeError("Argument 'base64url' is not Base64Url encoded");return this.FromBase64(this.Base64Padding(e.replace(/\-/g,"+").replace(/\_/g,"/")))}static ToBase64Url(t){return this.ToBase64(t).replace(/\+/g,"-").replace(/\//g,"_").replace(/\=/g,"")}static FromUtf8String(t,e=r.DEFAULT_UTF8_ENCODING){switch(e){case"ascii":return this.FromBinary(t);case"utf8":return ts.fromString(t);case"utf16":case"utf16be":return Gt.fromString(t);case"utf16le":case"usc2":return Gt.fromString(t,!0);default:throw new Error(`Unknown type of encoding '${e}'`)}}static ToUtf8String(t,e=r.DEFAULT_UTF8_ENCODING){switch(e){case"ascii":return this.ToBinary(t);case"utf8":return ts.toString(t);case"utf16":case"utf16be":return Gt.toString(t);case"utf16le":case"usc2":return Gt.toString(t,!0);default:throw new Error(`Unknown type of encoding '${e}'`)}}static FromBinary(t){let e=t.length,n=new Uint8Array(e);for(let s=0;s<e;s++)n[s]=t.charCodeAt(s);return n.buffer}static ToBinary(t){let e=ve.toUint8Array(t),n="";for(let s=0;s<e.length;s++)n+=String.fromCharCode(e[s]);return n}static ToHex(t){let e=ve.toUint8Array(t),n="",s=e.length;for(let i=0;i<s;i++){let o=e[i];o<16&&(n+="0"),n+=o.toString(16)}return n}static FromHex(t){let e=this.formatString(t);if(!e)return new ArrayBuffer(0);if(!r.isHex(e))throw new TypeError("Argument 'hexString' is not HEX encoded");e.length%2&&(e=`0${e}`);let n=new Uint8Array(e.length/2);for(let s=0;s<e.length;s=s+2){let i=e.slice(s,s+2);n[s/2]=parseInt(i,16)}return n.buffer}static ToUtf16String(t,e=!1){return Gt.toString(t,e)}static FromUtf16String(t,e=!1){return Gt.fromString(t,e)}static Base64Padding(t){let e=4-t.length%4;if(e<4)for(let n=0;n<e;n++)t+="=";return t}static formatString(t){return t?.replace(/[\n\r\t ]/g,"")||""}};es.DEFAULT_UTF8_ENCODING="utf8";function Rp(r,...t){let e=arguments[0];for(let n=1;n<arguments.length;n++){let s=arguments[n];for(let i in s)e[i]=s[i]}return e}function Up(...r){let t=r.map(s=>s.byteLength).reduce((s,i)=>s+i),e=new Uint8Array(t),n=0;return r.map(s=>new Uint8Array(s)).forEach(s=>{for(let i of s)e[n++]=i}),e.buffer}function Dp(r,t){if(!(r&&t)||r.byteLength!==t.byteLength)return!1;let e=new Uint8Array(r),n=new Uint8Array(t);for(let s=0;s<r.byteLength;s++)if(e[s]!==n[s])return!1;return!0}Ar.BufferSourceConverter=ve;Ar.Convert=es;Ar.assign=Rp;Ar.combine=Up;Ar.isEqual=Dp});var Ef=qi((An,Ti)=>{(function(r,t){"use strict";var e={version:"3.0.0",x86:{},x64:{},inputValidation:!0};function n(l){if(!Array.isArray(l)&&!ArrayBuffer.isView(l))return!1;for(var d=0;d<l.length;d++)if(!Number.isInteger(l[d])||l[d]<0||l[d]>255)return!1;return!0}function s(l,d){return(l&65535)*d+(((l>>>16)*d&65535)<<16)}function i(l,d){return l<<d|l>>>32-d}function o(l){return l^=l>>>16,l=s(l,2246822507),l^=l>>>13,l=s(l,3266489909),l^=l>>>16,l}function a(l,d){l=[l[0]>>>16,l[0]&65535,l[1]>>>16,l[1]&65535],d=[d[0]>>>16,d[0]&65535,d[1]>>>16,d[1]&65535];var p=[0,0,0,0];return p[3]+=l[3]+d[3],p[2]+=p[3]>>>16,p[3]&=65535,p[2]+=l[2]+d[2],p[1]+=p[2]>>>16,p[2]&=65535,p[1]+=l[1]+d[1],p[0]+=p[1]>>>16,p[1]&=65535,p[0]+=l[0]+d[0],p[0]&=65535,[p[0]<<16|p[1],p[2]<<16|p[3]]}function c(l,d){l=[l[0]>>>16,l[0]&65535,l[1]>>>16,l[1]&65535],d=[d[0]>>>16,d[0]&65535,d[1]>>>16,d[1]&65535];var p=[0,0,0,0];return p[3]+=l[3]*d[3],p[2]+=p[3]>>>16,p[3]&=65535,p[2]+=l[2]*d[3],p[1]+=p[2]>>>16,p[2]&=65535,p[2]+=l[3]*d[2],p[1]+=p[2]>>>16,p[2]&=65535,p[1]+=l[1]*d[3],p[0]+=p[1]>>>16,p[1]&=65535,p[1]+=l[2]*d[2],p[0]+=p[1]>>>16,p[1]&=65535,p[1]+=l[3]*d[1],p[0]+=p[1]>>>16,p[1]&=65535,p[0]+=l[0]*d[3]+l[1]*d[2]+l[2]*d[1]+l[3]*d[0],p[0]&=65535,[p[0]<<16|p[1],p[2]<<16|p[3]]}function h(l,d){return d%=64,d===32?[l[1],l[0]]:d<32?[l[0]<<d|l[1]>>>32-d,l[1]<<d|l[0]>>>32-d]:(d-=32,[l[1]<<d|l[0]>>>32-d,l[0]<<d|l[1]>>>32-d])}function f(l,d){return d%=64,d===0?l:d<32?[l[0]<<d|l[1]>>>32-d,l[1]<<d]:[l[1]<<d-32,0]}function u(l,d){return[l[0]^d[0],l[1]^d[1]]}function g(l){return l=u(l,[0,l[0]>>>1]),l=c(l,[4283543511,3981806797]),l=u(l,[0,l[0]>>>1]),l=c(l,[3301882366,444984403]),l=u(l,[0,l[0]>>>1]),l}e.x86.hash32=function(l,d){if(e.inputValidation&&!n(l))return t;d=d||0;for(var p=l.length%4,y=l.length-p,b=d,w=0,m=3432918353,E=461845907,A=0;A<y;A=A+4)w=l[A]|l[A+1]<<8|l[A+2]<<16|l[A+3]<<24,w=s(w,m),w=i(w,15),w=s(w,E),b^=w,b=i(b,13),b=s(b,5)+3864292196;switch(w=0,p){case 3:w^=l[A+2]<<16;case 2:w^=l[A+1]<<8;case 1:w^=l[A],w=s(w,m),w=i(w,15),w=s(w,E),b^=w}return b^=l.length,b=o(b),b>>>0},e.x86.hash128=function(l,d){if(e.inputValidation&&!n(l))return t;d=d||0;for(var p=l.length%16,y=l.length-p,b=d,w=d,m=d,E=d,A=0,_=0,x=0,I=0,C=597399067,j=2869860233,V=951274213,P=2716044179,R=0;R<y;R=R+16)A=l[R]|l[R+1]<<8|l[R+2]<<16|l[R+3]<<24,_=l[R+4]|l[R+5]<<8|l[R+6]<<16|l[R+7]<<24,x=l[R+8]|l[R+9]<<8|l[R+10]<<16|l[R+11]<<24,I=l[R+12]|l[R+13]<<8|l[R+14]<<16|l[R+15]<<24,A=s(A,C),A=i(A,15),A=s(A,j),b^=A,b=i(b,19),b+=w,b=s(b,5)+1444728091,_=s(_,j),_=i(_,16),_=s(_,V),w^=_,w=i(w,17),w+=m,w=s(w,5)+197830471,x=s(x,V),x=i(x,17),x=s(x,P),m^=x,m=i(m,15),m+=E,m=s(m,5)+2530024501,I=s(I,P),I=i(I,18),I=s(I,C),E^=I,E=i(E,13),E+=b,E=s(E,5)+850148119;switch(A=0,_=0,x=0,I=0,p){case 15:I^=l[R+14]<<16;case 14:I^=l[R+13]<<8;case 13:I^=l[R+12],I=s(I,P),I=i(I,18),I=s(I,C),E^=I;case 12:x^=l[R+11]<<24;case 11:x^=l[R+10]<<16;case 10:x^=l[R+9]<<8;case 9:x^=l[R+8],x=s(x,V),x=i(x,17),x=s(x,P),m^=x;case 8:_^=l[R+7]<<24;case 7:_^=l[R+6]<<16;case 6:_^=l[R+5]<<8;case 5:_^=l[R+4],_=s(_,j),_=i(_,16),_=s(_,V),w^=_;case 4:A^=l[R+3]<<24;case 3:A^=l[R+2]<<16;case 2:A^=l[R+1]<<8;case 1:A^=l[R],A=s(A,C),A=i(A,15),A=s(A,j),b^=A}return b^=l.length,w^=l.length,m^=l.length,E^=l.length,b+=w,b+=m,b+=E,w+=b,m+=b,E+=b,b=o(b),w=o(w),m=o(m),E=o(E),b+=w,b+=m,b+=E,w+=b,m+=b,E+=b,("00000000"+(b>>>0).toString(16)).slice(-8)+("00000000"+(w>>>0).toString(16)).slice(-8)+("00000000"+(m>>>0).toString(16)).slice(-8)+("00000000"+(E>>>0).toString(16)).slice(-8)},e.x64.hash128=function(l,d){if(e.inputValidation&&!n(l))return t;d=d||0;for(var p=l.length%16,y=l.length-p,b=[0,d],w=[0,d],m=[0,0],E=[0,0],A=[2277735313,289559509],_=[1291169091,658871167],x=0;x<y;x=x+16)m=[l[x+4]|l[x+5]<<8|l[x+6]<<16|l[x+7]<<24,l[x]|l[x+1]<<8|l[x+2]<<16|l[x+3]<<24],E=[l[x+12]|l[x+13]<<8|l[x+14]<<16|l[x+15]<<24,l[x+8]|l[x+9]<<8|l[x+10]<<16|l[x+11]<<24],m=c(m,A),m=h(m,31),m=c(m,_),b=u(b,m),b=h(b,27),b=a(b,w),b=a(c(b,[0,5]),[0,1390208809]),E=c(E,_),E=h(E,33),E=c(E,A),w=u(w,E),w=h(w,31),w=a(w,b),w=a(c(w,[0,5]),[0,944331445]);switch(m=[0,0],E=[0,0],p){case 15:E=u(E,f([0,l[x+14]],48));case 14:E=u(E,f([0,l[x+13]],40));case 13:E=u(E,f([0,l[x+12]],32));case 12:E=u(E,f([0,l[x+11]],24));case 11:E=u(E,f([0,l[x+10]],16));case 10:E=u(E,f([0,l[x+9]],8));case 9:E=u(E,[0,l[x+8]]),E=c(E,_),E=h(E,33),E=c(E,A),w=u(w,E);case 8:m=u(m,f([0,l[x+7]],56));case 7:m=u(m,f([0,l[x+6]],48));case 6:m=u(m,f([0,l[x+5]],40));case 5:m=u(m,f([0,l[x+4]],32));case 4:m=u(m,f([0,l[x+3]],24));case 3:m=u(m,f([0,l[x+2]],16));case 2:m=u(m,f([0,l[x+1]],8));case 1:m=u(m,[0,l[x]]),m=c(m,A),m=h(m,31),m=c(m,_),b=u(b,m)}return b=u(b,[0,l.length]),w=u(w,[0,l.length]),b=a(b,w),w=a(w,b),b=g(b),w=g(w),b=a(b,w),w=a(w,b),("00000000"+(b[0]>>>0).toString(16)).slice(-8)+("00000000"+(b[1]>>>0).toString(16)).slice(-8)+("00000000"+(w[0]>>>0).toString(16)).slice(-8)+("00000000"+(w[1]>>>0).toString(16)).slice(-8)},typeof An<"u"?(typeof Ti<"u"&&Ti.exports&&(An=Ti.exports=e),An.murmurHash3=e):typeof define=="function"&&define.amd?define([],function(){return e}):(e._murmurHash3=r.murmurHash3,e.noConflict=function(){return r.murmurHash3=e._murmurHash3,e._murmurHash3=t,e.noConflict=t,e},r.murmurHash3=e)})(An)});var Af=qi((W2,Sf)=>{Sf.exports=Ef()});var X0={};kt(X0,{RELAY_V2_HOP_CODEC:()=>Wt,RELAY_V2_STOP_CODEC:()=>ar,circuitRelayServer:()=>Cf,circuitRelayTransport:()=>Kf});var zi=Symbol.for("@libp2p/peer-id");var $i="keep-alive";var gc=Symbol.for("@libp2p/transport");var mc;(function(r){r[r.FATAL_ALL=0]="FATAL_ALL",r[r.NO_FATAL=1]="NO_FATAL"})(mc||(mc={}));var he=class extends Error{static name="AbortError";constructor(t="The operation was aborted"){super(t),this.name="AbortError"}};var Et=class extends Error{static name="InvalidParametersError";constructor(t="Invalid parameters"){super(t),this.name="InvalidParametersError"}},fr=class extends Error{static name="InvalidPublicKeyError";constructor(t="Invalid public key"){super(t),this.name="InvalidPublicKeyError"}};var Tn=class extends Error{static name="InvalidMultihashError";constructor(t="Invalid Multihash"){super(t),this.name="InvalidMultihashError"}};var kn=class extends Error{static name="InvalidMessageError";constructor(t="Invalid message"){super(t),this.name="InvalidMessageError"}};var Fr=class extends Error{static name="DialError";constructor(t="Dial error"){super(t),this.name="DialError"}},je=class extends Error{static name="ListenError";constructor(t="Listen error"){super(t),this.name="ListenError"}};var hr=class extends Error{static name="UnsupportedKeyTypeError";constructor(t="Unsupported key type"){super(t),this.name="UnsupportedKeyTypeError"}};var Lt=(r,...t)=>{try{[...t]}catch{}};var qt=class extends EventTarget{#t=new Map;constructor(){super(),Lt(1/0,this)}listenerCount(t){let e=this.#t.get(t);return e==null?0:e.length}addEventListener(t,e,n){super.addEventListener(t,e,n);let s=this.#t.get(t);s==null&&(s=[],this.#t.set(t,s)),s.push({callback:e,once:(n!==!0&&n!==!1&&n?.once)??!1})}removeEventListener(t,e,n){super.removeEventListener(t.toString(),e??null,n);let s=this.#t.get(t);s!=null&&(s=s.filter(({callback:i})=>i!==e),this.#t.set(t,s))}dispatchEvent(t){let e=super.dispatchEvent(t),n=this.#t.get(t.type);return n==null||(n=n.filter(({once:s})=>!s),this.#t.set(t.type,n)),e}safeDispatchEvent(t,e={}){return this.dispatchEvent(new CustomEvent(t,e))}};function yc(r){return r!=null&&typeof r.start=="function"&&typeof r.stop=="function"}async function bc(...r){let t=[];for(let e of r)yc(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 wc(...r){let t=[];for(let e of r)yc(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 xc=Symbol.for("@libp2p/service-capabilities"),vc=Symbol.for("@libp2p/service-dependencies");var Yi={};kt(Yi,{base58btc:()=>tt,base58flickr:()=>ch});var Cm=new Uint8Array(0);function Ec(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 de(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 Sc(r){return new TextEncoder().encode(r)}function Ac(r){return new TextDecoder().decode(r)}function nh(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 s=0;s<r.length;s++){var i=r.charAt(s),o=i.charCodeAt(0);if(e[o]!==255)throw new TypeError(i+" is ambiguous");e[o]=s}var a=r.length,c=r.charAt(0),h=Math.log(a)/Math.log(256),f=Math.log(256)/Math.log(a);function u(d){if(d instanceof Uint8Array||(ArrayBuffer.isView(d)?d=new Uint8Array(d.buffer,d.byteOffset,d.byteLength):Array.isArray(d)&&(d=Uint8Array.from(d))),!(d instanceof Uint8Array))throw new TypeError("Expected Uint8Array");if(d.length===0)return"";for(var p=0,y=0,b=0,w=d.length;b!==w&&d[b]===0;)b++,p++;for(var m=(w-b)*f+1>>>0,E=new Uint8Array(m);b!==w;){for(var A=d[b],_=0,x=m-1;(A!==0||_<y)&&x!==-1;x--,_++)A+=256*E[x]>>>0,E[x]=A%a>>>0,A=A/a>>>0;if(A!==0)throw new Error("Non-zero carry");y=_,b++}for(var I=m-y;I!==m&&E[I]===0;)I++;for(var C=c.repeat(p);I<m;++I)C+=r.charAt(E[I]);return C}function g(d){if(typeof d!="string")throw new TypeError("Expected String");if(d.length===0)return new Uint8Array;var p=0;if(d[p]!==" "){for(var y=0,b=0;d[p]===c;)y++,p++;for(var w=(d.length-p)*h+1>>>0,m=new Uint8Array(w);d[p];){var E=e[d.charCodeAt(p)];if(E===255)return;for(var A=0,_=w-1;(E!==0||A<b)&&_!==-1;_--,A++)E+=a*m[_]>>>0,m[_]=E%256>>>0,E=E/256>>>0;if(E!==0)throw new Error("Non-zero carry");b=A,p++}if(d[p]!==" "){for(var x=w-b;x!==w&&m[x]===0;)x++;for(var I=new Uint8Array(y+(w-x)),C=y;x!==w;)I[C++]=m[x++];return I}}}function l(d){var p=g(d);if(p)return p;throw new Error(`Non-${t} character`)}return{encode:u,decodeUnsafe:g,decode:l}}var sh=nh,ih=sh,_c=ih;var Gi=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")}},Wi=class{name;prefix;baseDecode;prefixCodePoint;constructor(t,e,n){this.name=t,this.prefix=e;let s=e.codePointAt(0);if(s===void 0)throw new Error("Invalid prefix character");this.prefixCodePoint=s,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 Ic(this,t)}},Zi=class{decoders;constructor(t){this.decoders=t}or(t){return Ic(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 Ic(r,t){return new Zi({...r.decoders??{[r.prefix]:r},...t.decoders??{[t.prefix]:t}})}var ji=class{name;prefix;baseEncode;baseDecode;encoder;decoder;constructor(t,e,n,s){this.name=t,this.prefix=e,this.baseEncode=n,this.baseDecode=s,this.encoder=new Gi(t,e,n),this.decoder=new Wi(t,e,s)}encode(t){return this.encoder.encode(t)}decode(t){return this.decoder.decode(t)}};function dr({name:r,prefix:t,encode:e,decode:n}){return new ji(r,t,e,n)}function Ce({name:r,prefix:t,alphabet:e}){let{encode:n,decode:s}=_c(e,r);return dr({prefix:t,name:r,encode:n,decode:i=>de(s(i))})}function oh(r,t,e,n){let s={};for(let f=0;f<t.length;++f)s[t[f]]=f;let i=r.length;for(;r[i-1]==="=";)--i;let o=new Uint8Array(i*e/8|0),a=0,c=0,h=0;for(let f=0;f<i;++f){let u=s[r[f]];if(u===void 0)throw new SyntaxError(`Non-${n} character`);c=c<<e|u,a+=e,a>=8&&(a-=8,o[h++]=255&c>>a)}if(a>=e||255&c<<8-a)throw new SyntaxError("Unexpected end of data");return o}function ah(r,t,e){let n=t[t.length-1]==="=",s=(1<<e)-1,i="",o=0,a=0;for(let c=0;c<r.length;++c)for(a=a<<8|r[c],o+=8;o>e;)o-=e,i+=t[s&a>>o];if(o!==0&&(i+=t[s&a<<e-o]),n)for(;i.length*e&7;)i+="=";return i}function lt({name:r,prefix:t,bitsPerChar:e,alphabet:n}){return dr({prefix:t,name:r,encode(s){return ah(s,n,e)},decode(s){return oh(s,n,e,r)}})}var tt=Ce({name:"base58btc",prefix:"z",alphabet:"123456789ABCDEFGHJKLMNPQRSTUVWXYZabcdefghijkmnopqrstuvwxyz"}),ch=Ce({name:"base58flickr",prefix:"Z",alphabet:"123456789abcdefghijkmnopqrstuvwxyzABCDEFGHJKLMNPQRSTUVWXYZ"});var Xi={};kt(Xi,{base32:()=>pe,base32hex:()=>hh,base32hexpad:()=>ph,base32hexpadupper:()=>mh,base32hexupper:()=>dh,base32pad:()=>uh,base32padupper:()=>fh,base32upper:()=>lh,base32z:()=>gh});var pe=lt({prefix:"b",name:"base32",alphabet:"abcdefghijklmnopqrstuvwxyz234567",bitsPerChar:5}),lh=lt({prefix:"B",name:"base32upper",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZ234567",bitsPerChar:5}),uh=lt({prefix:"c",name:"base32pad",alphabet:"abcdefghijklmnopqrstuvwxyz234567=",bitsPerChar:5}),fh=lt({prefix:"C",name:"base32padupper",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZ234567=",bitsPerChar:5}),hh=lt({prefix:"v",name:"base32hex",alphabet:"0123456789abcdefghijklmnopqrstuv",bitsPerChar:5}),dh=lt({prefix:"V",name:"base32hexupper",alphabet:"0123456789ABCDEFGHIJKLMNOPQRSTUV",bitsPerChar:5}),ph=lt({prefix:"t",name:"base32hexpad",alphabet:"0123456789abcdefghijklmnopqrstuv=",bitsPerChar:5}),mh=lt({prefix:"T",name:"base32hexpadupper",alphabet:"0123456789ABCDEFGHIJKLMNOPQRSTUV=",bitsPerChar:5}),gh=lt({prefix:"h",name:"base32z",alphabet:"ybndrfg8ejkmcpqxot1uwisza345h769",bitsPerChar:5});var Ji={};kt(Ji,{base36:()=>Kr,base36upper:()=>yh});var Kr=Ce({prefix:"k",name:"base36",alphabet:"0123456789abcdefghijklmnopqrstuvwxyz"}),yh=Ce({prefix:"K",name:"base36upper",alphabet:"0123456789ABCDEFGHIJKLMNOPQRSTUVWXYZ"});var bh=Cc,Tc=128,wh=127,xh=~wh,vh=Math.pow(2,31);function Cc(r,t,e){t=t||[],e=e||0;for(var n=e;r>=vh;)t[e++]=r&255|Tc,r/=128;for(;r&xh;)t[e++]=r&255|Tc,r>>>=7;return t[e]=r|0,Cc.bytes=e-n+1,t}var Eh=Qi,Sh=128,kc=127;function Qi(r,n){var e=0,n=n||0,s=0,i=n,o,a=r.length;do{if(i>=a)throw Qi.bytes=0,new RangeError("Could not decode varint");o=r[i++],e+=s<28?(o&kc)<<s:(o&kc)*Math.pow(2,s),s+=7}while(o>=Sh);return Qi.bytes=i-n,e}var Ah=Math.pow(2,7),Bh=Math.pow(2,14),_h=Math.pow(2,21),Ih=Math.pow(2,28),Th=Math.pow(2,35),kh=Math.pow(2,42),Ch=Math.pow(2,49),Nh=Math.pow(2,56),Lh=Math.pow(2,63),Rh=function(r){return r<Ah?1:r<Bh?2:r<_h?3:r<Ih?4:r<Th?5:r<kh?6:r<Ch?7:r<Nh?8:r<Lh?9:10},Uh={encode:bh,decode:Eh,encodingLength:Rh},Dh=Uh,qr=Dh;function zr(r,t=0){return[qr.decode(r,t),qr.decode.bytes]}function pr(r,t,e=0){return qr.encode(r,t,e),t}function mr(r){return qr.encodingLength(r)}function Zt(r,t){let e=t.byteLength,n=mr(r),s=n+mr(e),i=new Uint8Array(s+e);return pr(r,i,0),pr(e,i,n),i.set(t,s),new gr(r,e,t,i)}function zt(r){let t=de(r),[e,n]=zr(t),[s,i]=zr(t.subarray(n)),o=t.subarray(n+i);if(o.byteLength!==s)throw new Error("Incorrect length");return new gr(e,s,o,t)}function Nc(r,t){if(r===t)return!0;{let e=t;return r.code===e.code&&r.size===e.size&&e.bytes instanceof Uint8Array&&Ec(r.bytes,e.bytes)}}var gr=class{code;size;digest;bytes;constructor(t,e,n,s){this.code=t,this.size=e,this.digest=n,this.bytes=s}};function Lc(r,t){let{bytes:e,version:n}=r;switch(n){case 0:return Mh(e,to(r),t??tt.encoder);default:return Ph(e,to(r),t??pe.encoder)}}var Rc=new WeakMap;function to(r){let t=Rc.get(r);if(t==null){let e=new Map;return Rc.set(r,e),e}return t}var pt=class r{code;version;multihash;bytes;"/";constructor(t,e,n,s){this.code=e,this.version=t,this.multihash=n,this.bytes=s,this["/"]=s}get asCID(){return this}get byteOffset(){return this.bytes.byteOffset}get byteLength(){return this.bytes.byteLength}toV0(){switch(this.version){case 0:return this;case 1:{let{code:t,multihash:e}=this;if(t!==$r)throw new Error("Cannot convert a non dag-pb CID to CIDv0");if(e.code!==Vh)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=Zt(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&&Nc(t.multihash,n.multihash)}toString(t){return Lc(this,t)}toJSON(){return{"/":Lc(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:s,multihash:i,bytes:o}=e;return new r(n,s,i,o??Uc(n,s,i.bytes))}else if(e[Hh]===!0){let{version:n,multihash:s,code:i}=e,o=zt(s);return r.create(n,i,o)}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!==$r)throw new Error(`Version 0 CID must use dag-pb (code: ${$r}) block encoding`);return new r(t,e,n,n.bytes)}case 1:{let s=Uc(t,e,n.bytes);return new r(t,e,n,s)}default:throw new Error("Invalid version")}}static createV0(t){return r.create(0,$r,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,s=de(t.subarray(n,n+e.multihashSize));if(s.byteLength!==e.multihashSize)throw new Error("Incorrect length");let i=s.subarray(e.multihashSize-e.digestSize),o=new gr(e.multihashCode,e.digestSize,i,s);return[e.version===0?r.createV0(o):r.createV1(e.codec,o),t.subarray(e.size)]}static inspectBytes(t){let e=0,n=()=>{let[u,g]=zr(t.subarray(e));return e+=g,u},s=n(),i=$r;if(s===18?(s=0,e=0):i=n(),s!==0&&s!==1)throw new RangeError(`Invalid CID version ${s}`);let o=e,a=n(),c=n(),h=e+c,f=h-o;return{version:s,codec:i,multihashCode:a,digestSize:c,multihashSize:f,size:h}}static parse(t,e){let[n,s]=Oh(t,e),i=r.decode(s);if(i.version===0&&t[0]!=="Q")throw Error("Version 0 CID string must not include multibase prefix");return to(i).set(n,t),i}};function Oh(r,t){switch(r[0]){case"Q":{let e=t??tt;return[tt.prefix,e.decode(`${tt.prefix}${r}`)]}case tt.prefix:{let e=t??tt;return[tt.prefix,e.decode(r)]}case pe.prefix:{let e=t??pe;return[pe.prefix,e.decode(r)]}case Kr.prefix:{let e=t??Kr;return[Kr.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 Mh(r,t,e){let{prefix:n}=e;if(n!==tt.prefix)throw Error(`Cannot string encode V0 in ${e.name} encoding`);let s=t.get(n);if(s==null){let i=e.encode(r).slice(1);return t.set(n,i),i}else return s}function Ph(r,t,e){let{prefix:n}=e,s=t.get(n);if(s==null){let i=e.encode(r);return t.set(n,i),i}else return s}var $r=112,Vh=18;function Uc(r,t,e){let n=mr(r),s=n+mr(t),i=new Uint8Array(s+e.byteLength);return pr(r,i,0),pr(t,i,n),i.set(e,s),i}var Hh=Symbol.for("@ipld/js-cid/CID");var eo={};kt(eo,{identity:()=>me});var Dc=0,Fh="identity",Oc=de;function Kh(r){return Zt(Dc,Oc(r))}var me={code:Dc,name:Fh,encode:Oc,digest:Kh};function mt(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 Mc(r){if(!Number.isSafeInteger(r)||r<0)throw new Error("positive integer expected, got "+r)}function qh(r){return r instanceof Uint8Array||ArrayBuffer.isView(r)&&r.constructor.name==="Uint8Array"}function yr(r,...t){if(!qh(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 Pc(r){if(typeof r!="function"||typeof r.create!="function")throw new Error("Hash should be wrapped by utils.wrapConstructor");Mc(r.outputLen),Mc(r.blockLen)}function br(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 Vc(r,t){yr(r);let e=t.outputLen;if(r.length<e)throw new Error("digestInto() expects output buffer of length at least "+e)}var Ye=typeof globalThis=="object"&&"crypto"in globalThis?globalThis.crypto:void 0;var Nn=r=>new DataView(r.buffer,r.byteOffset,r.byteLength),jt=(r,t)=>r<<32-t|r>>>t;function Hc(r){if(typeof r!="string")throw new Error("utf8ToBytes expected string, got "+typeof r);return new Uint8Array(new TextEncoder().encode(r))}function Gr(r){return typeof r=="string"&&(r=Hc(r)),yr(r),r}function ro(...r){let t=0;for(let n=0;n<r.length;n++){let s=r[n];yr(s),t+=s.length}let e=new Uint8Array(t);for(let n=0,s=0;n<r.length;n++){let i=r[n];e.set(i,s),s+=i.length}return e}var wr=class{clone(){return this._cloneInto()}};function Ln(r){let t=n=>r().update(Gr(n)).digest(),e=r();return t.outputLen=e.outputLen,t.blockLen=e.blockLen,t.create=()=>r(),t}function Rn(r=32){if(Ye&&typeof Ye.getRandomValues=="function")return Ye.getRandomValues(new Uint8Array(r));if(Ye&&typeof Ye.randomBytes=="function")return Ye.randomBytes(r);throw new Error("crypto.getRandomValues must be defined")}function zh(r,t,e,n){if(typeof r.setBigUint64=="function")return r.setBigUint64(t,e,n);let s=BigInt(32),i=BigInt(4294967295),o=Number(e>>s&i),a=Number(e&i),c=n?4:0,h=n?0:4;r.setUint32(t+c,o,n),r.setUint32(t+h,a,n)}var Fc=(r,t,e)=>r&t^~r&e,Kc=(r,t,e)=>r&t^r&e^t&e,xr=class extends wr{constructor(t,e,n,s){super(),this.blockLen=t,this.outputLen=e,this.padOffset=n,this.isLE=s,this.finished=!1,this.length=0,this.pos=0,this.destroyed=!1,this.buffer=new Uint8Array(t),this.view=Nn(this.buffer)}update(t){br(this);let{view:e,buffer:n,blockLen:s}=this;t=Gr(t);let i=t.length;for(let o=0;o<i;){let a=Math.min(s-this.pos,i-o);if(a===s){let c=Nn(t);for(;s<=i-o;o+=s)this.process(c,o);continue}n.set(t.subarray(o,o+a),this.pos),this.pos+=a,o+=a,this.pos===s&&(this.process(e,0),this.pos=0)}return this.length+=t.length,this.roundClean(),this}digestInto(t){br(this),Vc(t,this),this.finished=!0;let{buffer:e,view:n,blockLen:s,isLE:i}=this,{pos:o}=this;e[o++]=128,this.buffer.subarray(o).fill(0),this.padOffset>s-o&&(this.process(n,0),o=0);for(let u=o;u<s;u++)e[u]=0;zh(n,s-8,BigInt(this.length*8),i),this.process(n,0);let a=Nn(t),c=this.outputLen;if(c%4)throw new Error("_sha2: outputLen should be aligned to 32bit");let h=c/4,f=this.get();if(h>f.length)throw new Error("_sha2: outputLen bigger than state");for(let u=0;u<h;u++)a.setUint32(4*u,f[u],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:s,finished:i,destroyed:o,pos:a}=this;return t.length=s,t.pos=a,t.finished=i,t.destroyed=o,s%e&&t.buffer.set(n),t}};var Un=BigInt(4294967295),no=BigInt(32);function qc(r,t=!1){return t?{h:Number(r&Un),l:Number(r>>no&Un)}:{h:Number(r>>no&Un)|0,l:Number(r&Un)|0}}function $h(r,t=!1){let e=new Uint32Array(r.length),n=new Uint32Array(r.length);for(let s=0;s<r.length;s++){let{h:i,l:o}=qc(r[s],t);[e[s],n[s]]=[i,o]}return[e,n]}var Gh=(r,t)=>BigInt(r>>>0)<<no|BigInt(t>>>0),Wh=(r,t,e)=>r>>>e,Zh=(r,t,e)=>r<<32-e|t>>>e,jh=(r,t,e)=>r>>>e|t<<32-e,Yh=(r,t,e)=>r<<32-e|t>>>e,Xh=(r,t,e)=>r<<64-e|t>>>e-32,Jh=(r,t,e)=>r>>>e-32|t<<64-e,Qh=(r,t)=>t,td=(r,t)=>r,ed=(r,t,e)=>r<<e|t>>>32-e,rd=(r,t,e)=>t<<e|r>>>32-e,nd=(r,t,e)=>t<<e-32|r>>>64-e,sd=(r,t,e)=>r<<e-32|t>>>64-e;function id(r,t,e,n){let s=(t>>>0)+(n>>>0);return{h:r+e+(s/2**32|0)|0,l:s|0}}var od=(r,t,e)=>(r>>>0)+(t>>>0)+(e>>>0),ad=(r,t,e,n)=>t+e+n+(r/2**32|0)|0,cd=(r,t,e,n)=>(r>>>0)+(t>>>0)+(e>>>0)+(n>>>0),ld=(r,t,e,n,s)=>t+e+n+s+(r/2**32|0)|0,ud=(r,t,e,n,s)=>(r>>>0)+(t>>>0)+(e>>>0)+(n>>>0)+(s>>>0),fd=(r,t,e,n,s,i)=>t+e+n+s+i+(r/2**32|0)|0;var hd={fromBig:qc,split:$h,toBig:Gh,shrSH:Wh,shrSL:Zh,rotrSH:jh,rotrSL:Yh,rotrBH:Xh,rotrBL:Jh,rotr32H:Qh,rotr32L:td,rotlSH:ed,rotlSL:rd,rotlBH:nd,rotlBL:sd,add:id,add3L:od,add3H:ad,add4L:cd,add4H:ld,add5H:fd,add5L:ud},M=hd;var[dd,pd]=M.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))),Ne=new Uint32Array(80),Le=new Uint32Array(80),so=class extends xr{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:s,Ch:i,Cl:o,Dh:a,Dl:c,Eh:h,El:f,Fh:u,Fl:g,Gh:l,Gl:d,Hh:p,Hl:y}=this;return[t,e,n,s,i,o,a,c,h,f,u,g,l,d,p,y]}set(t,e,n,s,i,o,a,c,h,f,u,g,l,d,p,y){this.Ah=t|0,this.Al=e|0,this.Bh=n|0,this.Bl=s|0,this.Ch=i|0,this.Cl=o|0,this.Dh=a|0,this.Dl=c|0,this.Eh=h|0,this.El=f|0,this.Fh=u|0,this.Fl=g|0,this.Gh=l|0,this.Gl=d|0,this.Hh=p|0,this.Hl=y|0}process(t,e){for(let m=0;m<16;m++,e+=4)Ne[m]=t.getUint32(e),Le[m]=t.getUint32(e+=4);for(let m=16;m<80;m++){let E=Ne[m-15]|0,A=Le[m-15]|0,_=M.rotrSH(E,A,1)^M.rotrSH(E,A,8)^M.shrSH(E,A,7),x=M.rotrSL(E,A,1)^M.rotrSL(E,A,8)^M.shrSL(E,A,7),I=Ne[m-2]|0,C=Le[m-2]|0,j=M.rotrSH(I,C,19)^M.rotrBH(I,C,61)^M.shrSH(I,C,6),V=M.rotrSL(I,C,19)^M.rotrBL(I,C,61)^M.shrSL(I,C,6),P=M.add4L(x,V,Le[m-7],Le[m-16]),R=M.add4H(P,_,j,Ne[m-7],Ne[m-16]);Ne[m]=R|0,Le[m]=P|0}let{Ah:n,Al:s,Bh:i,Bl:o,Ch:a,Cl:c,Dh:h,Dl:f,Eh:u,El:g,Fh:l,Fl:d,Gh:p,Gl:y,Hh:b,Hl:w}=this;for(let m=0;m<80;m++){let E=M.rotrSH(u,g,14)^M.rotrSH(u,g,18)^M.rotrBH(u,g,41),A=M.rotrSL(u,g,14)^M.rotrSL(u,g,18)^M.rotrBL(u,g,41),_=u&l^~u&p,x=g&d^~g&y,I=M.add5L(w,A,x,pd[m],Le[m]),C=M.add5H(I,b,E,_,dd[m],Ne[m]),j=I|0,V=M.rotrSH(n,s,28)^M.rotrBH(n,s,34)^M.rotrBH(n,s,39),P=M.rotrSL(n,s,28)^M.rotrBL(n,s,34)^M.rotrBL(n,s,39),R=n&i^n&a^i&a,T=s&o^s&c^o&c;b=p|0,w=y|0,p=l|0,y=d|0,l=u|0,d=g|0,{h:u,l:g}=M.add(h|0,f|0,C|0,j|0),h=a|0,f=c|0,a=i|0,c=o|0,i=n|0,o=s|0;let L=M.add3L(j,P,T);n=M.add3H(L,C,V,R),s=L|0}({h:n,l:s}=M.add(this.Ah|0,this.Al|0,n|0,s|0)),{h:i,l:o}=M.add(this.Bh|0,this.Bl|0,i|0,o|0),{h:a,l:c}=M.add(this.Ch|0,this.Cl|0,a|0,c|0),{h,l:f}=M.add(this.Dh|0,this.Dl|0,h|0,f|0),{h:u,l:g}=M.add(this.Eh|0,this.El|0,u|0,g|0),{h:l,l:d}=M.add(this.Fh|0,this.Fl|0,l|0,d|0),{h:p,l:y}=M.add(this.Gh|0,this.Gl|0,p|0,y|0),{h:b,l:w}=M.add(this.Hh|0,this.Hl|0,b|0,w|0),this.set(n,s,i,o,a,c,h,f,u,g,l,d,p,y,b,w)}roundClean(){Ne.fill(0),Le.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 zc=Ln(()=>new so);var Mn={};kt(Mn,{aInRange:()=>Rt,abool:()=>Yt,abytes:()=>vr,bitGet:()=>xd,bitLen:()=>co,bitMask:()=>Zr,bitSet:()=>vd,bytesToHex:()=>ye,bytesToNumberBE:()=>be,bytesToNumberLE:()=>Ue,concatBytes:()=>we,createHmacDrbg:()=>lo,ensureBytes:()=>ot,equalBytes:()=>bd,hexToBytes:()=>Je,hexToNumber:()=>ao,inRange:()=>Wr,isBytes:()=>Re,memoized:()=>tr,notImplemented:()=>Sd,numberToBytesBE:()=>De,numberToBytesLE:()=>Qe,numberToHexUnpadded:()=>Xe,numberToVarBytesBE:()=>yd,utf8ToBytes:()=>wd,validateObject:()=>oe});var Dn=BigInt(0),On=BigInt(1),md=BigInt(2);function Re(r){return r instanceof Uint8Array||ArrayBuffer.isView(r)&&r.constructor.name==="Uint8Array"}function vr(r){if(!Re(r))throw new Error("Uint8Array expected")}function Yt(r,t){if(typeof t!="boolean")throw new Error(r+" boolean expected, got "+t)}var gd=Array.from({length:256},(r,t)=>t.toString(16).padStart(2,"0"));function ye(r){vr(r);let t="";for(let e=0;e<r.length;e++)t+=gd[r[e]];return t}function Xe(r){let t=r.toString(16);return t.length&1?"0"+t:t}function ao(r){if(typeof r!="string")throw new Error("hex string expected, got "+typeof r);return r===""?Dn:BigInt("0x"+r)}var ge={_0:48,_9:57,A:65,F:70,a:97,f:102};function $c(r){if(r>=ge._0&&r<=ge._9)return r-ge._0;if(r>=ge.A&&r<=ge.F)return r-(ge.A-10);if(r>=ge.a&&r<=ge.f)return r-(ge.a-10)}function Je(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 s=0,i=0;s<e;s++,i+=2){let o=$c(r.charCodeAt(i)),a=$c(r.charCodeAt(i+1));if(o===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[s]=o*16+a}return n}function be(r){return ao(ye(r))}function Ue(r){return vr(r),ao(ye(Uint8Array.from(r).reverse()))}function De(r,t){return Je(r.toString(16).padStart(t*2,"0"))}function Qe(r,t){return De(r,t).reverse()}function yd(r){return Je(Xe(r))}function ot(r,t,e){let n;if(typeof t=="string")try{n=Je(t)}catch(i){throw new Error(r+" must be hex string or Uint8Array, cause: "+i)}else if(Re(t))n=Uint8Array.from(t);else throw new Error(r+" must be hex string or Uint8Array");let s=n.length;if(typeof e=="number"&&s!==e)throw new Error(r+" of length "+e+" expected, got "+s);return n}function we(...r){let t=0;for(let n=0;n<r.length;n++){let s=r[n];vr(s),t+=s.length}let e=new Uint8Array(t);for(let n=0,s=0;n<r.length;n++){let i=r[n];e.set(i,s),s+=i.length}return e}function bd(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 wd(r){if(typeof r!="string")throw new Error("string expected");return new Uint8Array(new TextEncoder().encode(r))}var io=r=>typeof r=="bigint"&&Dn<=r;function Wr(r,t,e){return io(r)&&io(t)&&io(e)&&t<=r&&r<e}function Rt(r,t,e,n){if(!Wr(t,e,n))throw new Error("expected valid "+r+": "+e+" <= n < "+n+", got "+t)}function co(r){let t;for(t=0;r>Dn;r>>=On,t+=1);return t}function xd(r,t){return r>>BigInt(t)&On}function vd(r,t,e){return r|(e?On:Dn)<<BigInt(t)}var Zr=r=>(md<<BigInt(r-1))-On,oo=r=>new Uint8Array(r),Gc=r=>Uint8Array.from(r);function lo(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=oo(r),s=oo(r),i=0,o=()=>{n.fill(1),s.fill(0),i=0},a=(...u)=>e(s,n,...u),c=(u=oo())=>{s=a(Gc([0]),u),n=a(),u.length!==0&&(s=a(Gc([1]),u),n=a())},h=()=>{if(i++>=1e3)throw new Error("drbg: tried 1000 values");let u=0,g=[];for(;u<t;){n=a();let l=n.slice();g.push(l),u+=n.length}return we(...g)};return(u,g)=>{o(),c(u);let l;for(;!(l=g(h()));)c();return o(),l}}var Ed={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"||Re(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 oe(r,t,e={}){let n=(s,i,o)=>{let a=Ed[i];if(typeof a!="function")throw new Error("invalid validator function");let c=r[s];if(!(o&&c===void 0)&&!a(c,r))throw new Error("param "+String(s)+" is invalid. Expected "+i+", got "+c)};for(let[s,i]of Object.entries(t))n(s,i,!1);for(let[s,i]of Object.entries(e))n(s,i,!0);return r}var Sd=()=>{throw new Error("not implemented")};function tr(r){let t=new WeakMap;return(e,...n)=>{let s=t.get(e);if(s!==void 0)return s;let i=r(e,...n);return t.set(e,i),i}}var ut=BigInt(0),st=BigInt(1),er=BigInt(2),Ad=BigInt(3),uo=BigInt(4),Wc=BigInt(5),Zc=BigInt(8),Bd=BigInt(9),_d=BigInt(16);function J(r,t){let e=r%t;return e>=ut?e:t+e}function Id(r,t,e){if(t<ut)throw new Error("invalid exponent, negatives unsupported");if(e<=ut)throw new Error("invalid modulus");if(e===st)return ut;let n=st;for(;t>ut;)t&st&&(n=n*r%e),r=r*r%e,t>>=st;return n}function it(r,t,e){let n=r;for(;t-- >ut;)n*=n,n%=e;return n}function Pn(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=J(r,t),n=t,s=ut,i=st,o=st,a=ut;for(;e!==ut;){let h=n/e,f=n%e,u=s-o*h,g=i-a*h;n=e,e=f,s=o,i=a,o=u,a=g}if(n!==st)throw new Error("invert: does not exist");return J(s,t)}function Td(r){let t=(r-st)/er,e,n,s;for(e=r-st,n=0;e%er===ut;e/=er,n++);for(s=er;s<r&&Id(s,t,r)!==r-st;s++)if(s>1e3)throw new Error("Cannot find square root: likely non-prime P");if(n===1){let o=(r+st)/uo;return function(c,h){let f=c.pow(h,o);if(!c.eql(c.sqr(f),h))throw new Error("Cannot find square root");return f}}let i=(e+st)/er;return function(a,c){if(a.pow(c,t)===a.neg(a.ONE))throw new Error("Cannot find square root");let h=n,f=a.pow(a.mul(a.ONE,s),e),u=a.pow(c,i),g=a.pow(c,e);for(;!a.eql(g,a.ONE);){if(a.eql(g,a.ZERO))return a.ZERO;let l=1;for(let p=a.sqr(g);l<h&&!a.eql(p,a.ONE);l++)p=a.sqr(p);let d=a.pow(f,st<<BigInt(h-l-1));f=a.sqr(d),u=a.mul(u,d),g=a.mul(g,f),h=l}return u}}function kd(r){if(r%uo===Ad){let t=(r+st)/uo;return function(n,s){let i=n.pow(s,t);if(!n.eql(n.sqr(i),s))throw new Error("Cannot find square root");return i}}if(r%Zc===Wc){let t=(r-Wc)/Zc;return function(n,s){let i=n.mul(s,er),o=n.pow(i,t),a=n.mul(s,o),c=n.mul(n.mul(a,er),o),h=n.mul(a,n.sub(c,n.ONE));if(!n.eql(n.sqr(h),s))throw new Error("Cannot find square root");return h}}return r%_d,Td(r)}var jc=(r,t)=>(J(r,t)&st)===st,Cd=["create","isValid","is0","neg","inv","sqrt","sqr","eql","add","sub","mul","pow","div","addN","subN","mulN","sqrN"];function fo(r){let t={ORDER:"bigint",MASK:"bigint",BYTES:"isSafeInteger",BITS:"isSafeInteger"},e=Cd.reduce((n,s)=>(n[s]="function",n),t);return oe(r,e)}function Nd(r,t,e){if(e<ut)throw new Error("invalid exponent, negatives unsupported");if(e===ut)return r.ONE;if(e===st)return t;let n=r.ONE,s=t;for(;e>ut;)e&st&&(n=r.mul(n,s)),s=r.sqr(s),e>>=st;return n}function Ld(r,t){let e=new Array(t.length),n=t.reduce((i,o,a)=>r.is0(o)?i:(e[a]=i,r.mul(i,o)),r.ONE),s=r.inv(n);return t.reduceRight((i,o,a)=>r.is0(o)?i:(e[a]=r.mul(i,e[a]),r.mul(i,o)),s),e}function ho(r,t){let e=t!==void 0?t:r.toString(2).length,n=Math.ceil(e/8);return{nBitLength:e,nByteLength:n}}function Oe(r,t,e=!1,n={}){if(r<=ut)throw new Error("invalid field: expected ORDER > 0, got "+r);let{nBitLength:s,nByteLength:i}=ho(r,t);if(i>2048)throw new Error("invalid field: expected ORDER of <= 2048 bytes");let o,a=Object.freeze({ORDER:r,BITS:s,BYTES:i,MASK:Zr(s),ZERO:ut,ONE:st,create:c=>J(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&st)===st,neg:c=>J(-c,r),eql:(c,h)=>c===h,sqr:c=>J(c*c,r),add:(c,h)=>J(c+h,r),sub:(c,h)=>J(c-h,r),mul:(c,h)=>J(c*h,r),pow:(c,h)=>Nd(a,c,h),div:(c,h)=>J(c*Pn(h,r),r),sqrN:c=>c*c,addN:(c,h)=>c+h,subN:(c,h)=>c-h,mulN:(c,h)=>c*h,inv:c=>Pn(c,r),sqrt:n.sqrt||(c=>(o||(o=kd(r)),o(a,c))),invertBatch:c=>Ld(a,c),cmov:(c,h,f)=>f?h:c,toBytes:c=>e?Qe(c,i):De(c,i),fromBytes:c=>{if(c.length!==i)throw new Error("Field.fromBytes: expected "+i+" bytes, got "+c.length);return e?Ue(c):be(c)}});return Object.freeze(a)}function Yc(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 po(r){let t=Yc(r);return t+Math.ceil(t/2)}function Xc(r,t,e=!1){let n=r.length,s=Yc(t),i=po(t);if(n<16||n<i||n>1024)throw new Error("expected "+i+"-1024 bytes of input, got "+n);let o=e?be(r):Ue(r),a=J(o,t-st)+st;return e?Qe(a,s):De(a,s)}var Jc=BigInt(0),Vn=BigInt(1);function mo(r,t){let e=t.negate();return r?e:t}function Qc(r,t){if(!Number.isSafeInteger(r)||r<=0||r>t)throw new Error("invalid window size, expected [1.."+t+"], got W="+r)}function go(r,t){Qc(r,t);let e=Math.ceil(t/r)+1,n=2**(r-1);return{windows:e,windowSize:n}}function Ud(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 Dd(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 yo=new WeakMap,tl=new WeakMap;function bo(r){return tl.get(r)||1}function Hn(r,t){return{constTimeNegate:mo,hasPrecomputes(e){return bo(e)!==1},unsafeLadder(e,n,s=r.ZERO){let i=e;for(;n>Jc;)n&Vn&&(s=s.add(i)),i=i.double(),n>>=Vn;return s},precomputeWindow(e,n){let{windows:s,windowSize:i}=go(n,t),o=[],a=e,c=a;for(let h=0;h<s;h++){c=a,o.push(c);for(let f=1;f<i;f++)c=c.add(a),o.push(c);a=c.double()}return o},wNAF(e,n,s){let{windows:i,windowSize:o}=go(e,t),a=r.ZERO,c=r.BASE,h=BigInt(2**e-1),f=2**e,u=BigInt(e);for(let g=0;g<i;g++){let l=g*o,d=Number(s&h);s>>=u,d>o&&(d-=f,s+=Vn);let p=l,y=l+Math.abs(d)-1,b=g%2!==0,w=d<0;d===0?c=c.add(mo(b,n[p])):a=a.add(mo(w,n[y]))}return{p:a,f:c}},wNAFUnsafe(e,n,s,i=r.ZERO){let{windows:o,windowSize:a}=go(e,t),c=BigInt(2**e-1),h=2**e,f=BigInt(e);for(let u=0;u<o;u++){let g=u*a;if(s===Jc)break;let l=Number(s&c);if(s>>=f,l>a&&(l-=h,s+=Vn),l===0)continue;let d=n[g+Math.abs(l)-1];l<0&&(d=d.negate()),i=i.add(d)}return i},getPrecomputes(e,n,s){let i=yo.get(n);return i||(i=this.precomputeWindow(n,e),e!==1&&yo.set(n,s(i))),i},wNAFCached(e,n,s){let i=bo(e);return this.wNAF(i,this.getPrecomputes(i,e,s),n)},wNAFCachedUnsafe(e,n,s,i){let o=bo(e);return o===1?this.unsafeLadder(e,n,i):this.wNAFUnsafe(o,this.getPrecomputes(o,e,s),n,i)},setWindowSize(e,n){Qc(n,t),tl.set(e,n),yo.delete(e)}}}function Fn(r,t,e,n){if(Ud(e,r),Dd(n,t),e.length!==n.length)throw new Error("arrays of points and scalars must have equal length");let s=r.ZERO,i=co(BigInt(e.length)),o=i>12?i-3:i>4?i-2:i?2:1,a=(1<<o)-1,c=new Array(a+1).fill(s),h=Math.floor((t.BITS-1)/o)*o,f=s;for(let u=h;u>=0;u-=o){c.fill(s);for(let l=0;l<n.length;l++){let d=n[l],p=Number(d>>BigInt(u)&BigInt(a));c[p]=c[p].add(e[l])}let g=s;for(let l=c.length-1,d=s;l>0;l--)d=d.add(c[l]),g=g.add(d);if(f=f.add(g),u!==0)for(let l=0;l<o;l++)f=f.double()}return f}function jr(r){return fo(r.Fp),oe(r,{n:"bigint",h:"bigint",Gx:"field",Gy:"field"},{nBitLength:"isSafeInteger",nByteLength:"isSafeInteger"}),Object.freeze({...ho(r.n,r.nBitLength),...r,p:r.Fp.ORDER})}var Xt=BigInt(0),Ut=BigInt(1),Kn=BigInt(2),Od=BigInt(8),Md={zip215:!0};function Pd(r){let t=jr(r);return oe(r,{hash:"function",a:"bigint",d:"bigint",randomBytes:"function"},{adjustScalarBytes:"function",domain:"function",uvRatio:"function",mapToCurve:"function"}),Object.freeze({...t})}function el(r){let t=Pd(r),{Fp:e,n,prehash:s,hash:i,randomBytes:o,nByteLength:a,h:c}=t,h=Kn<<BigInt(a*8)-Ut,f=e.create,u=Oe(t.n,t.nBitLength),g=t.uvRatio||((S,v)=>{try{return{isValid:!0,value:e.sqrt(S*e.inv(v))}}catch{return{isValid:!1,value:Xt}}}),l=t.adjustScalarBytes||(S=>S),d=t.domain||((S,v,B)=>{if(Yt("phflag",B),v.length||B)throw new Error("Contexts/pre-hash are not supported");return S});function p(S,v){Rt("coordinate "+S,v,Xt,h)}function y(S){if(!(S instanceof m))throw new Error("ExtendedPoint expected")}let b=tr((S,v)=>{let{ex:B,ey:N,ez:U}=S,D=S.is0();v==null&&(v=D?Od:e.inv(U));let H=f(B*v),$=f(N*v),O=f(U*v);if(D)return{x:Xt,y:Ut};if(O!==Ut)throw new Error("invZ was invalid");return{x:H,y:$}}),w=tr(S=>{let{a:v,d:B}=t;if(S.is0())throw new Error("bad point: ZERO");let{ex:N,ey:U,ez:D,et:H}=S,$=f(N*N),O=f(U*U),Y=f(D*D),rt=f(Y*Y),ht=f($*v),dt=f(Y*f(ht+O)),yt=f(rt+f(B*f($*O)));if(dt!==yt)throw new Error("bad point: equation left != right (1)");let vt=f(N*U),Nt=f(D*H);if(vt!==Nt)throw new Error("bad point: equation left != right (2)");return!0});class m{constructor(v,B,N,U){this.ex=v,this.ey=B,this.ez=N,this.et=U,p("x",v),p("y",B),p("z",N),p("t",U),Object.freeze(this)}get x(){return this.toAffine().x}get y(){return this.toAffine().y}static fromAffine(v){if(v instanceof m)throw new Error("extended point not allowed");let{x:B,y:N}=v||{};return p("x",B),p("y",N),new m(B,N,Ut,f(B*N))}static normalizeZ(v){let B=e.invertBatch(v.map(N=>N.ez));return v.map((N,U)=>N.toAffine(B[U])).map(m.fromAffine)}static msm(v,B){return Fn(m,u,v,B)}_setWindowSize(v){_.setWindowSize(this,v)}assertValidity(){w(this)}equals(v){y(v);let{ex:B,ey:N,ez:U}=this,{ex:D,ey:H,ez:$}=v,O=f(B*$),Y=f(D*U),rt=f(N*$),ht=f(H*U);return O===Y&&rt===ht}is0(){return this.equals(m.ZERO)}negate(){return new m(f(-this.ex),this.ey,this.ez,f(-this.et))}double(){let{a:v}=t,{ex:B,ey:N,ez:U}=this,D=f(B*B),H=f(N*N),$=f(Kn*f(U*U)),O=f(v*D),Y=B+N,rt=f(f(Y*Y)-D-H),ht=O+H,dt=ht-$,yt=O-H,vt=f(rt*dt),Nt=f(ht*yt),Tt=f(rt*yt),se=f(dt*ht);return new m(vt,Nt,se,Tt)}add(v){y(v);let{a:B,d:N}=t,{ex:U,ey:D,ez:H,et:$}=this,{ex:O,ey:Y,ez:rt,et:ht}=v;if(B===BigInt(-1)){let oc=f((D-U)*(Y+O)),ac=f((D+U)*(Y-O)),Ki=f(ac-oc);if(Ki===Xt)return this.double();let cc=f(H*Kn*ht),lc=f($*Kn*rt),uc=lc+cc,fc=ac+oc,hc=lc-cc,Wf=f(uc*Ki),Zf=f(fc*hc),jf=f(uc*hc),Yf=f(Ki*fc);return new m(Wf,Zf,Yf,jf)}let dt=f(U*O),yt=f(D*Y),vt=f($*N*ht),Nt=f(H*rt),Tt=f((U+D)*(O+Y)-dt-yt),se=Nt-vt,fe=Nt+vt,Hr=f(yt-B*dt),qf=f(Tt*se),zf=f(fe*Hr),$f=f(Tt*Hr),Gf=f(se*fe);return new m(qf,zf,Gf,$f)}subtract(v){return this.add(v.negate())}wNAF(v){return _.wNAFCached(this,v,m.normalizeZ)}multiply(v){let B=v;Rt("scalar",B,Ut,n);let{p:N,f:U}=this.wNAF(B);return m.normalizeZ([N,U])[0]}multiplyUnsafe(v,B=m.ZERO){let N=v;return Rt("scalar",N,Xt,n),N===Xt?A:this.is0()||N===Ut?this:_.wNAFCachedUnsafe(this,N,m.normalizeZ,B)}isSmallOrder(){return this.multiplyUnsafe(c).is0()}isTorsionFree(){return _.unsafeLadder(this,n).is0()}toAffine(v){return b(this,v)}clearCofactor(){let{h:v}=t;return v===Ut?this:this.multiplyUnsafe(v)}static fromHex(v,B=!1){let{d:N,a:U}=t,D=e.BYTES;v=ot("pointHex",v,D),Yt("zip215",B);let H=v.slice(),$=v[D-1];H[D-1]=$&-129;let O=Ue(H),Y=B?h:e.ORDER;Rt("pointHex.y",O,Xt,Y);let rt=f(O*O),ht=f(rt-Ut),dt=f(N*rt-U),{isValid:yt,value:vt}=g(ht,dt);if(!yt)throw new Error("Point.fromHex: invalid y coordinate");let Nt=(vt&Ut)===Ut,Tt=($&128)!==0;if(!B&&vt===Xt&&Tt)throw new Error("Point.fromHex: x=0 and x_0=1");return Tt!==Nt&&(vt=f(-vt)),m.fromAffine({x:vt,y:O})}static fromPrivateKey(v){return C(v).point}toRawBytes(){let{x:v,y:B}=this.toAffine(),N=Qe(B,e.BYTES);return N[N.length-1]|=v&Ut?128:0,N}toHex(){return ye(this.toRawBytes())}}m.BASE=new m(t.Gx,t.Gy,Ut,f(t.Gx*t.Gy)),m.ZERO=new m(Xt,Ut,Ut,Xt);let{BASE:E,ZERO:A}=m,_=Hn(m,a*8);function x(S){return J(S,n)}function I(S){return x(Ue(S))}function C(S){let v=e.BYTES;S=ot("private key",S,v);let B=ot("hashed private key",i(S),2*v),N=l(B.slice(0,v)),U=B.slice(v,2*v),D=I(N),H=E.multiply(D),$=H.toRawBytes();return{head:N,prefix:U,scalar:D,point:H,pointBytes:$}}function j(S){return C(S).pointBytes}function V(S=new Uint8Array,...v){let B=we(...v);return I(i(d(B,ot("context",S),!!s)))}function P(S,v,B={}){S=ot("message",S),s&&(S=s(S));let{prefix:N,scalar:U,pointBytes:D}=C(v),H=V(B.context,N,S),$=E.multiply(H).toRawBytes(),O=V(B.context,$,D,S),Y=x(H+O*U);Rt("signature.s",Y,Xt,n);let rt=we($,Qe(Y,e.BYTES));return ot("result",rt,e.BYTES*2)}let R=Md;function T(S,v,B,N=R){let{context:U,zip215:D}=N,H=e.BYTES;S=ot("signature",S,2*H),v=ot("message",v),B=ot("publicKey",B,H),D!==void 0&&Yt("zip215",D),s&&(v=s(v));let $=Ue(S.slice(H,2*H)),O,Y,rt;try{O=m.fromHex(B,D),Y=m.fromHex(S.slice(0,H),D),rt=E.multiplyUnsafe($)}catch{return!1}if(!D&&O.isSmallOrder())return!1;let ht=V(U,Y.toRawBytes(),O.toRawBytes(),v);return Y.add(O.multiplyUnsafe(ht)).subtract(rt).clearCofactor().equals(m.ZERO)}return E._setWindowSize(8),{CURVE:t,getPublicKey:j,sign:P,verify:T,ExtendedPoint:m,utils:{getExtendedPublicKey:C,randomPrivateKey:()=>o(e.BYTES),precompute(S=8,v=m.BASE){return v._setWindowSize(S),v.multiply(BigInt(3)),v}}}}var wo=BigInt("57896044618658097711785492504343953926634992332820282019728792003956564819949"),rl=BigInt("19681161376707505956807079304988542015446066515923890162744021073123829784752"),vg=BigInt(0),Vd=BigInt(1),nl=BigInt(2),Eg=BigInt(3),Hd=BigInt(5),Fd=BigInt(8);function Kd(r){let t=BigInt(10),e=BigInt(20),n=BigInt(40),s=BigInt(80),i=wo,a=r*r%i*r%i,c=it(a,nl,i)*a%i,h=it(c,Vd,i)*r%i,f=it(h,Hd,i)*h%i,u=it(f,t,i)*f%i,g=it(u,e,i)*u%i,l=it(g,n,i)*g%i,d=it(l,s,i)*l%i,p=it(d,s,i)*l%i,y=it(p,t,i)*f%i;return{pow_p_5_8:it(y,nl,i)*r%i,b2:a}}function qd(r){return r[0]&=248,r[31]&=127,r[31]|=64,r}function zd(r,t){let e=wo,n=J(t*t*t,e),s=J(n*n*t,e),i=Kd(r*s).pow_p_5_8,o=J(r*n*i,e),a=J(t*o*o,e),c=o,h=J(o*rl,e),f=a===r,u=a===J(-r,e),g=a===J(-r*rl,e);return f&&(o=c),(u||g)&&(o=h),jc(o,e)&&(o=J(-o,e)),{isValid:f||u,value:o}}var $d=Oe(wo,void 0,!0),Gd={a:BigInt(-1),d:BigInt("37095705934669439343138083508754565189542113879843219016388785533085940283555"),Fp:$d,n:BigInt("7237005577332262213973186563042994240857116359379907606001950938285454250989"),h:Fd,Gx:BigInt("15112221349535400772501151409588531511454012693041857206046113283949847762202"),Gy:BigInt("46316835694926478169428394003475163141307993866256225615783033603165251855960"),hash:zc,randomBytes:Rn,adjustScalarBytes:qd,uvRatio:zd},sl=el(Gd);var qn=32;function il(r,t,e){return sl.verify(t,e instanceof Uint8Array?e:e.subarray(),r)}var zn=class{type="Ed25519";raw;constructor(t){this.raw=xo(t,qn)}toMultihash(){return me.digest(Me(this))}toCID(){return pt.createV1(114,this.toMultihash())}toString(){return tt.encode(this.toMultihash().bytes).substring(1)}equals(t){return t==null||!(t.raw instanceof Uint8Array)?!1:mt(this.raw,t.raw)}verify(t,e){return il(this.raw,e,t)}};function vo(r){return r=xo(r,qn),new zn(r)}function xo(r,t){if(r=Uint8Array.from(r??[]),r.length!==t)throw new Et(`Key must be a Uint8Array of length ${t}, got ${r.length}`);return r}function at(r=0){return new Uint8Array(r)}function Dt(r=0){return new Uint8Array(r)}var Zd=Math.pow(2,7),jd=Math.pow(2,14),Yd=Math.pow(2,21),Eo=Math.pow(2,28),So=Math.pow(2,35),Ao=Math.pow(2,42),Bo=Math.pow(2,49),Z=128,St=127;function At(r){if(r<Zd)return 1;if(r<jd)return 2;if(r<Yd)return 3;if(r<Eo)return 4;if(r<So)return 5;if(r<Ao)return 6;if(r<Bo)return 7;if(Number.MAX_SAFE_INTEGER!=null&&r>Number.MAX_SAFE_INTEGER)throw new RangeError("Could not encode varint");return 8}function _o(r,t,e=0){switch(At(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 Xd(r,t,e=0){switch(At(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 Io(r,t){let e=r[t],n=0;if(n+=e&St,e<Z||(e=r[t+1],n+=(e&St)<<7,e<Z)||(e=r[t+2],n+=(e&St)<<14,e<Z)||(e=r[t+3],n+=(e&St)<<21,e<Z)||(e=r[t+4],n+=(e&St)*Eo,e<Z)||(e=r[t+5],n+=(e&St)*So,e<Z)||(e=r[t+6],n+=(e&St)*Ao,e<Z)||(e=r[t+7],n+=(e&St)*Bo,e<Z))return n;throw new RangeError("Could not decode varint")}function Jd(r,t){let e=r.get(t),n=0;if(n+=e&St,e<Z||(e=r.get(t+1),n+=(e&St)<<7,e<Z)||(e=r.get(t+2),n+=(e&St)<<14,e<Z)||(e=r.get(t+3),n+=(e&St)<<21,e<Z)||(e=r.get(t+4),n+=(e&St)*Eo,e<Z)||(e=r.get(t+5),n+=(e&St)*So,e<Z)||(e=r.get(t+6),n+=(e&St)*Ao,e<Z)||(e=r.get(t+7),n+=(e&St)*Bo,e<Z))return n;throw new RangeError("Could not decode varint")}function $t(r,t,e=0){return t==null&&(t=Dt(At(r))),t instanceof Uint8Array?_o(r,t,e):Xd(r,t,e)}function xe(r,t=0){return r instanceof Uint8Array?Io(r,t):Jd(r,t)}var To=new Float32Array([-0]),Pe=new Uint8Array(To.buffer);function al(r,t,e){To[0]=r,t[e]=Pe[0],t[e+1]=Pe[1],t[e+2]=Pe[2],t[e+3]=Pe[3]}function cl(r,t){return Pe[0]=r[t],Pe[1]=r[t+1],Pe[2]=r[t+2],Pe[3]=r[t+3],To[0]}var ko=new Float64Array([-0]),Bt=new Uint8Array(ko.buffer);function ll(r,t,e){ko[0]=r,t[e]=Bt[0],t[e+1]=Bt[1],t[e+2]=Bt[2],t[e+3]=Bt[3],t[e+4]=Bt[4],t[e+5]=Bt[5],t[e+6]=Bt[6],t[e+7]=Bt[7]}function ul(r,t){return Bt[0]=r[t],Bt[1]=r[t+1],Bt[2]=r[t+2],Bt[3]=r[t+3],Bt[4]=r[t+4],Bt[5]=r[t+5],Bt[6]=r[t+6],Bt[7]=r[t+7],ko[0]}var Qd=BigInt(Number.MAX_SAFE_INTEGER),tp=BigInt(Number.MIN_SAFE_INTEGER),Ht=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 rr;if(t<Qd&&t>tp)return this.fromNumber(Number(t));let e=t<0n;e&&(t=-t);let n=t>>32n,s=t-(n<<32n);return e&&(n=~n|0n,s=~s|0n,++s>fl&&(s=0n,++n>fl&&(n=0n))),new r(Number(s),Number(n))}static fromNumber(t){if(t===0)return rr;let e=t<0;e&&(t=-t);let n=t>>>0,s=(t-n)/4294967296>>>0;return e&&(s=~s>>>0,n=~n>>>0,++n>4294967295&&(n=0,++s>4294967295&&(s=0))),new r(n,s)}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):rr}},rr=new Ht(0,0);rr.toBigInt=function(){return 0n};rr.zzEncode=rr.zzDecode=function(){return this};rr.length=function(){return 1};var fl=4294967296n;function hl(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 dl(r,t,e){if(e-t<1)return"";let s,i=[],o=0,a;for(;t<e;)a=r[t++],a<128?i[o++]=a:a>191&&a<224?i[o++]=(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[o++]=55296+(a>>10),i[o++]=56320+(a&1023)):i[o++]=(a&15)<<12|(r[t++]&63)<<6|r[t++]&63,o>8191&&((s??(s=[])).push(String.fromCharCode.apply(String,i)),o=0);return s!=null?(o>0&&s.push(String.fromCharCode.apply(String,i.slice(0,o))),s.join("")):String.fromCharCode.apply(String,i.slice(0,o))}function Co(r,t,e){let n=e,s,i;for(let o=0;o<r.length;++o)s=r.charCodeAt(o),s<128?t[e++]=s:s<2048?(t[e++]=s>>6|192,t[e++]=s&63|128):(s&64512)===55296&&((i=r.charCodeAt(o+1))&64512)===56320?(s=65536+((s&1023)<<10)+(i&1023),++o,t[e++]=s>>18|240,t[e++]=s>>12&63|128,t[e++]=s>>6&63|128,t[e++]=s&63|128):(t[e++]=s>>12|224,t[e++]=s>>6&63|128,t[e++]=s&63|128);return e-n}function Jt(r,t){return RangeError(`index out of range: ${r.pos} + ${t??1} > ${r.len}`)}function Gn(r,t){return(r[t-4]|r[t-3]<<8|r[t-2]<<16|r[t-1]<<24)>>>0}var No=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,Jt(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 Jt(this,4);return Gn(this.buf,this.pos+=4)}sfixed32(){if(this.pos+4>this.len)throw Jt(this,4);return Gn(this.buf,this.pos+=4)|0}float(){if(this.pos+4>this.len)throw Jt(this,4);let t=cl(this.buf,this.pos);return this.pos+=4,t}double(){if(this.pos+8>this.len)throw Jt(this,4);let t=ul(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 Jt(this,t);return this.pos+=t,e===n?new Uint8Array(0):this.buf.subarray(e,n)}string(){let t=this.bytes();return dl(t,0,t.length)}skip(t){if(typeof t=="number"){if(this.pos+t>this.len)throw Jt(this,t);this.pos+=t}else do if(this.pos>=this.len)throw Jt(this);while(this.buf[this.pos++]&128);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 Ht(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 Jt(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 Jt(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 Jt(this,8);let t=Gn(this.buf,this.pos+=4),e=Gn(this.buf,this.pos+=4);return new Ht(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=Io(this.buf,this.pos);return this.pos+=At(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 Lo(r){return new No(r instanceof Uint8Array?r:r.subarray())}function Ot(r,t,e){let n=Lo(r);return t.decode(n,void 0,e)}var Ro={};kt(Ro,{base10:()=>ep});var ep=Ce({prefix:"9",name:"base10",alphabet:"0123456789"});var Uo={};kt(Uo,{base16:()=>rp,base16upper:()=>np});var rp=lt({prefix:"f",name:"base16",alphabet:"0123456789abcdef",bitsPerChar:4}),np=lt({prefix:"F",name:"base16upper",alphabet:"0123456789ABCDEF",bitsPerChar:4});var Do={};kt(Do,{base2:()=>sp});var sp=lt({prefix:"0",name:"base2",alphabet:"01",bitsPerChar:1});var Oo={};kt(Oo,{base256emoji:()=>lp});var ml=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}"),ip=ml.reduce((r,t,e)=>(r[e]=t,r),[]),op=ml.reduce((r,t,e)=>{let n=t.codePointAt(0);if(n==null)throw new Error(`Invalid character: ${t}`);return r[n]=e,r},[]);function ap(r){return r.reduce((t,e)=>(t+=ip[e],t),"")}function cp(r){let t=[];for(let e of r){let n=e.codePointAt(0);if(n==null)throw new Error(`Invalid character: ${e}`);let s=op[n];if(s==null)throw new Error(`Non-base256emoji character: ${e}`);t.push(s)}return new Uint8Array(t)}var lp=dr({prefix:"\u{1F680}",name:"base256emoji",encode:ap,decode:cp});var Po={};kt(Po,{base64:()=>up,base64pad:()=>fp,base64url:()=>Mo,base64urlpad:()=>hp});var up=lt({prefix:"m",name:"base64",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/",bitsPerChar:6}),fp=lt({prefix:"M",name:"base64pad",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/=",bitsPerChar:6}),Mo=lt({prefix:"u",name:"base64url",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789-_",bitsPerChar:6}),hp=lt({prefix:"U",name:"base64urlpad",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789-_=",bitsPerChar:6});var Vo={};kt(Vo,{base8:()=>dp});var dp=lt({prefix:"7",name:"base8",alphabet:"01234567",bitsPerChar:3});var Ho={};kt(Ho,{identity:()=>pp});var pp=dr({prefix:"\0",name:"identity",encode:r=>Ac(r),decode:r=>Sc(r)});var sy=new TextEncoder,iy=new TextDecoder;var qo={};kt(qo,{sha256:()=>Er,sha512:()=>yp});function Ko({name:r,code:t,encode:e}){return new Fo(r,t,e)}var Fo=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?Zt(this.code,e):e.then(n=>Zt(this.code,n))}else throw Error("Unknown type, must be binary type")}};function yl(r){return async t=>new Uint8Array(await crypto.subtle.digest(r,t))}var Er=Ko({name:"sha2-256",code:18,encode:yl("SHA-256")}),yp=Ko({name:"sha2-512",code:19,encode:yl("SHA-512")});var Yr={...Ho,...Do,...Vo,...Ro,...Uo,...Xi,...Ji,...Yi,...Po,...Oo},yy={...qo,...eo};function wl(r,t,e,n){return{name:r,prefix:t,encoder:{name:r,prefix:t,encode:e},decoder:{decode:n}}}var bl=wl("utf8","u",r=>"u"+new TextDecoder("utf8").decode(r),r=>new TextEncoder().encode(r.substring(1))),zo=wl("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=Dt(r.length);for(let e=0;e<r.length;e++)t[e]=r.charCodeAt(e);return t}),bp={utf8:bl,"utf-8":bl,hex:Yr.base16,latin1:zo,ascii:zo,binary:zo,...Yr},Wn=bp;function G(r,t="utf8"){let e=Wn[t];if(e==null)throw new Error(`Unsupported encoding "${t}"`);return e.decoder.decode(`${e.prefix}${r}`)}function $o(r){let t=r??8192,e=t>>>1,n,s=t;return function(o){if(o<1||o>e)return Dt(o);s+o>t&&(n=Dt(t),s=0);let a=n.subarray(s,s+=o);return s&7&&(s=(s|7)+1),a}}var nr=class{fn;len;next;val;constructor(t,e,n){this.fn=t,this.len=e,this.next=void 0,this.val=n}};function Go(){}var Zo=class{head;tail;len;next;constructor(t){this.head=t.head,this.tail=t.tail,this.len=t.len,this.next=t.states}},wp=$o();function xp(r){return globalThis.Buffer!=null?Dt(r):wp(r)}var Jr=class{len;head;tail;states;constructor(){this.len=0,this.head=new nr(Go,0,0),this.tail=this.head,this.states=null}_push(t,e,n){return this.tail=this.tail.next=new nr(t,e,n),this.len+=e,this}uint32(t){return this.len+=(this.tail=this.tail.next=new jo((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(Zn,10,Ht.fromNumber(t)):this.uint32(t)}sint32(t){return this.uint32((t<<1^t>>31)>>>0)}uint64(t){let e=Ht.fromBigInt(t);return this._push(Zn,e.length(),e)}uint64Number(t){return this._push(_o,At(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=Ht.fromBigInt(t).zzEncode();return this._push(Zn,e.length(),e)}sint64Number(t){let e=Ht.fromNumber(t).zzEncode();return this._push(Zn,e.length(),e)}sint64String(t){return this.sint64(BigInt(t))}bool(t){return this._push(Wo,1,t?1:0)}fixed32(t){return this._push(Xr,4,t>>>0)}sfixed32(t){return this.fixed32(t)}fixed64(t){let e=Ht.fromBigInt(t);return this._push(Xr,4,e.lo)._push(Xr,4,e.hi)}fixed64Number(t){let e=Ht.fromNumber(t);return this._push(Xr,4,e.lo)._push(Xr,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(al,4,t)}double(t){return this._push(ll,8,t)}bytes(t){let e=t.length>>>0;return e===0?this._push(Wo,1,0):this.uint32(e)._push(Ep,e,t)}string(t){let e=hl(t);return e!==0?this.uint32(e)._push(Co,e,t):this._push(Wo,1,0)}fork(){return this.states=new Zo(this),this.head=this.tail=new nr(Go,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 nr(Go,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=xp(this.len),n=0;for(;t!=null;)t.fn(t.val,e,n),n+=t.len,t=t.next;return e}};function Wo(r,t,e){t[e]=r&255}function vp(r,t,e){for(;r>127;)t[e++]=r&127|128,r>>>=7;t[e]=r}var jo=class extends nr{next;constructor(t,e){super(vp,t,e),this.next=void 0}};function Zn(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 Xr(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 Ep(r,t,e){t.set(r,e)}globalThis.Buffer!=null&&(Jr.prototype.bytes=function(r){let t=r.length>>>0;return this.uint32(t),t>0&&this._push(Sp,t,r),this},Jr.prototype.string=function(r){let t=globalThis.Buffer.byteLength(r);return this.uint32(t),t>0&&this._push(Ap,t,r),this});function Sp(r,t,e){t.set(r,e)}function Ap(r,t,e){r.length<40?Co(r,t,e):t.utf8Write!=null?t.utf8Write(r,e):t.set(G(r),e)}function Yo(){return new Jr}function Mt(r,t){let e=Yo();return t.encode(r,e,{lengthDelimited:!1}),e.finish()}var Sr;(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"})(Sr||(Sr={}));function jn(r,t,e,n){return{name:r,type:t,encode:e,decode:n}}function sr(r){function t(s){if(r[s.toString()]==null)throw new Error("Invalid enum value");return r[s]}let e=function(i,o){let a=t(i);o.int32(a)},n=function(i){let o=i.int32();return t(o)};return jn("enum",Sr.VARINT,e,n)}function Pt(r,t){return jn("message",Sr.LENGTH_DELIMITED,r,t)}var Qr=class extends Error{code="ERR_MAX_LENGTH";name="MaxLengthError"};var ft;(function(r){r.RSA="RSA",r.Ed25519="Ed25519",r.secp256k1="secp256k1"})(ft||(ft={}));var Xo;(function(r){r[r.RSA=0]="RSA",r[r.Ed25519=1]="Ed25519",r[r.secp256k1=2]="secp256k1"})(Xo||(Xo={}));(function(r){r.codec=()=>sr(Xo)})(ft||(ft={}));var ae;(function(r){let t;r.codec=()=>(t==null&&(t=Pt((e,n,s={})=>{s.lengthDelimited!==!1&&n.fork(),e.Type!=null&&(n.uint32(8),ft.codec().encode(e.Type,n)),e.Data!=null&&(n.uint32(18),n.bytes(e.Data)),s.lengthDelimited!==!1&&n.ldelim()},(e,n,s={})=>{let i={},o=n==null?e.len:e.pos+n;for(;e.pos<o;){let a=e.uint32();switch(a>>>3){case 1:{i.Type=ft.codec().decode(e);break}case 2:{i.Data=e.bytes();break}default:{e.skipType(a&7);break}}}return i})),t),r.encode=e=>Mt(e,r.codec()),r.decode=(e,n)=>Ot(e,r.codec(),n)})(ae||(ae={}));var Jo;(function(r){let t;r.codec=()=>(t==null&&(t=Pt((e,n,s={})=>{s.lengthDelimited!==!1&&n.fork(),e.Type!=null&&(n.uint32(8),ft.codec().encode(e.Type,n)),e.Data!=null&&(n.uint32(18),n.bytes(e.Data)),s.lengthDelimited!==!1&&n.ldelim()},(e,n,s={})=>{let i={},o=n==null?e.len:e.pos+n;for(;e.pos<o;){let a=e.uint32();switch(a>>>3){case 1:{i.Type=ft.codec().decode(e);break}case 2:{i.Data=e.bytes();break}default:{e.skipType(a&7);break}}}return i})),t),r.encode=e=>Mt(e,r.codec()),r.decode=(e,n)=>Ot(e,r.codec(),n)})(Jo||(Jo={}));var un={};kt(un,{MAX_RSA_KEY_SIZE:()=>zs,generateRSAKeyPair:()=>xu,jwkToJWKKeyPair:()=>vu,jwkToPkcs1:()=>qp,jwkToPkix:()=>ua,jwkToRSAPrivateKey:()=>wu,pkcs1ToJwk:()=>gu,pkcs1ToRSAPrivateKey:()=>bu,pkixToJwk:()=>yu,pkixToRSAPublicKey:()=>fa});function Bp(r){return r instanceof Uint8Array||ArrayBuffer.isView(r)&&r.constructor.name==="Uint8Array"}function Qo(r,...t){if(!Bp(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 ta(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 vl(r,t){Qo(r);let e=t.outputLen;if(r.length<e)throw new Error("digestInto() expects output buffer of length at least "+e)}var Xn=r=>new DataView(r.buffer,r.byteOffset,r.byteLength),Qt=(r,t)=>r<<32-t|r>>>t;function _p(r){if(typeof r!="string")throw new Error("utf8ToBytes expected string, got "+typeof r);return new Uint8Array(new TextEncoder().encode(r))}function ea(r){return typeof r=="string"&&(r=_p(r)),Qo(r),r}var Yn=class{clone(){return this._cloneInto()}};function El(r){let t=n=>r().update(ea(n)).digest(),e=r();return t.outputLen=e.outputLen,t.blockLen=e.blockLen,t.create=()=>r(),t}function Ip(r,t,e,n){if(typeof r.setBigUint64=="function")return r.setBigUint64(t,e,n);let s=BigInt(32),i=BigInt(4294967295),o=Number(e>>s&i),a=Number(e&i),c=n?4:0,h=n?0:4;r.setUint32(t+c,o,n),r.setUint32(t+h,a,n)}var Sl=(r,t,e)=>r&t^~r&e,Al=(r,t,e)=>r&t^r&e^t&e,Jn=class extends Yn{constructor(t,e,n,s){super(),this.blockLen=t,this.outputLen=e,this.padOffset=n,this.isLE=s,this.finished=!1,this.length=0,this.pos=0,this.destroyed=!1,this.buffer=new Uint8Array(t),this.view=Xn(this.buffer)}update(t){ta(this);let{view:e,buffer:n,blockLen:s}=this;t=ea(t);let i=t.length;for(let o=0;o<i;){let a=Math.min(s-this.pos,i-o);if(a===s){let c=Xn(t);for(;s<=i-o;o+=s)this.process(c,o);continue}n.set(t.subarray(o,o+a),this.pos),this.pos+=a,o+=a,this.pos===s&&(this.process(e,0),this.pos=0)}return this.length+=t.length,this.roundClean(),this}digestInto(t){ta(this),vl(t,this),this.finished=!0;let{buffer:e,view:n,blockLen:s,isLE:i}=this,{pos:o}=this;e[o++]=128,this.buffer.subarray(o).fill(0),this.padOffset>s-o&&(this.process(n,0),o=0);for(let u=o;u<s;u++)e[u]=0;Ip(n,s-8,BigInt(this.length*8),i),this.process(n,0);let a=Xn(t),c=this.outputLen;if(c%4)throw new Error("_sha2: outputLen should be aligned to 32bit");let h=c/4,f=this.get();if(h>f.length)throw new Error("_sha2: outputLen bigger than state");for(let u=0;u<h;u++)a.setUint32(4*u,f[u],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:s,finished:i,destroyed:o,pos:a}=this;return t.length=s,t.pos=a,t.finished=i,t.destroyed=o,s%e&&t.buffer.set(n),t}};var Tp=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]),Ve=new Uint32Array([1779033703,3144134277,1013904242,2773480762,1359893119,2600822924,528734635,1541459225]),He=new Uint32Array(64),ra=class extends Jn{constructor(){super(64,32,8,!1),this.A=Ve[0]|0,this.B=Ve[1]|0,this.C=Ve[2]|0,this.D=Ve[3]|0,this.E=Ve[4]|0,this.F=Ve[5]|0,this.G=Ve[6]|0,this.H=Ve[7]|0}get(){let{A:t,B:e,C:n,D:s,E:i,F:o,G:a,H:c}=this;return[t,e,n,s,i,o,a,c]}set(t,e,n,s,i,o,a,c){this.A=t|0,this.B=e|0,this.C=n|0,this.D=s|0,this.E=i|0,this.F=o|0,this.G=a|0,this.H=c|0}process(t,e){for(let u=0;u<16;u++,e+=4)He[u]=t.getUint32(e,!1);for(let u=16;u<64;u++){let g=He[u-15],l=He[u-2],d=Qt(g,7)^Qt(g,18)^g>>>3,p=Qt(l,17)^Qt(l,19)^l>>>10;He[u]=p+He[u-7]+d+He[u-16]|0}let{A:n,B:s,C:i,D:o,E:a,F:c,G:h,H:f}=this;for(let u=0;u<64;u++){let g=Qt(a,6)^Qt(a,11)^Qt(a,25),l=f+g+Sl(a,c,h)+Tp[u]+He[u]|0,p=(Qt(n,2)^Qt(n,13)^Qt(n,22))+Al(n,s,i)|0;f=h,h=c,c=a,a=o+l|0,o=i,i=s,s=n,n=l+p|0}n=n+this.A|0,s=s+this.B|0,i=i+this.C|0,o=o+this.D|0,a=a+this.E|0,c=c+this.F|0,h=h+this.G|0,f=f+this.H|0,this.set(n,s,i,o,a,c,h,f)}roundClean(){He.fill(0)}destroy(){this.set(0,0,0,0,0,0,0,0),this.buffer.fill(0)}};var Qn=El(()=>new ra);var z=pc(Bl());function ir(r,t){let e=0;if(r.length===1)return r[0];for(let n=r.length-1;n>=0;n--)e+=r[r.length-1-n]*Math.pow(2,t*n);return e}function Fe(r,t,e=-1){let n=e,s=r,i=0,o=Math.pow(2,t);for(let a=1;a<8;a++){if(r<o){let c;if(n<0)c=new ArrayBuffer(a),i=a;else{if(n<a)return new ArrayBuffer(0);c=new ArrayBuffer(n),i=n}let h=new Uint8Array(c);for(let f=a-1;f>=0;f--){let u=Math.pow(2,f*t);h[i-f-1]=Math.floor(s/u),s-=h[i-f-1]*u}return c}o*=Math.pow(2,t)}return new ArrayBuffer(0)}function rs(...r){let t=0,e=0;for(let i of r)t+=i.length;let n=new ArrayBuffer(t),s=new Uint8Array(n);for(let i of r)s.set(i,e),e+=i.length;return s}function sa(){let r=new Uint8Array(this.valueHex);if(this.valueHex.byteLength>=2){let a=r[0]===255&&r[1]&128,c=r[0]===0&&(r[1]&128)===0;(a||c)&&this.warnings.push("Needlessly long format")}let t=new ArrayBuffer(this.valueHex.byteLength),e=new Uint8Array(t);for(let a=0;a<this.valueHex.byteLength;a++)e[a]=0;e[0]=r[0]&128;let n=ir(e,8),s=new ArrayBuffer(this.valueHex.byteLength),i=new Uint8Array(s);for(let a=0;a<this.valueHex.byteLength;a++)i[a]=r[a];return i[0]&=127,ir(i,8)-n}function _l(r){let t=r<0?r*-1:r,e=128;for(let n=1;n<8;n++){if(t<=e){if(r<0){let o=e-t,a=Fe(o,8,n),c=new Uint8Array(a);return c[0]|=128,a}let s=Fe(t,8,n),i=new Uint8Array(s);if(i[0]&128){let o=s.slice(0),a=new Uint8Array(o);s=new ArrayBuffer(s.byteLength+1),i=new Uint8Array(s);for(let c=0;c<o.byteLength;c++)i[c+1]=a[c];i[0]=0}return s}e*=Math.pow(2,8)}return new ArrayBuffer(0)}function Il(r,t){if(r.byteLength!==t.byteLength)return!1;let e=new Uint8Array(r),n=new Uint8Array(t);for(let s=0;s<e.length;s++)if(e[s]!==n[s])return!1;return!0}function Vt(r,t){let e=r.toString(10);if(t<e.length)return"";let n=t-e.length,s=new Array(n);for(let o=0;o<n;o++)s[o]="0";return s.join("").concat(e)}var sb=Math.log(2);function ns(){if(typeof BigInt>"u")throw new Error("BigInt is not defined. Your environment doesn't implement BigInt.")}function ia(r){let t=0,e=0;for(let s=0;s<r.length;s++){let i=r[s];t+=i.byteLength}let n=new Uint8Array(t);for(let s=0;s<r.length;s++){let i=r[s];n.set(new Uint8Array(i),e),e+=i.byteLength}return n.buffer}function Be(r,t,e,n){return t instanceof Uint8Array?t.byteLength?e<0?(r.error="Wrong parameter: inputOffset less than zero",!1):n<0?(r.error="Wrong parameter: inputLength less than zero",!1):t.byteLength-e-n<0?(r.error="End of input reached before message was fully decoded (inconsistent offset and length values)",!1):!0:(r.error="Wrong parameter: inputBuffer has zero length",!1):(r.error="Wrong parameter: inputBuffer must be 'Uint8Array'",!1)}var en=class{constructor(){this.items=[]}write(t){this.items.push(t)}final(){return ia(this.items)}},tn=[new Uint8Array([1])],Tl="0123456789";var Tr="",te=new ArrayBuffer(0),oa=new Uint8Array(0),rn="EndOfContent",Cl="OCTET STRING",Nl="BIT STRING";function _e(r){var t;return t=class extends r{constructor(...n){var s;super(...n);let i=n[0]||{};this.isHexOnly=(s=i.isHexOnly)!==null&&s!==void 0?s:!1,this.valueHexView=i.valueHex?z.BufferSourceConverter.toUint8Array(i.valueHex):oa}get valueHex(){return this.valueHexView.slice().buffer}set valueHex(n){this.valueHexView=new Uint8Array(n)}fromBER(n,s,i){let o=n instanceof ArrayBuffer?new Uint8Array(n):n;if(!Be(this,o,s,i))return-1;let a=s+i;return this.valueHexView=o.subarray(s,a),this.valueHexView.length?(this.blockLength=i,a):(this.warnings.push("Zero buffer length"),s)}toBER(n=!1){return this.isHexOnly?n?new ArrayBuffer(this.valueHexView.byteLength):this.valueHexView.byteLength===this.valueHexView.buffer.byteLength?this.valueHexView.buffer:this.valueHexView.slice().buffer:(this.error="Flag 'isHexOnly' is not set, abort",te)}toJSON(){return{...super.toJSON(),isHexOnly:this.isHexOnly,valueHex:z.Convert.ToHex(this.valueHexView)}}},t.NAME="hexBlock",t}var Ee=class{constructor({blockLength:t=0,error:e=Tr,warnings:n=[],valueBeforeDecode:s=oa}={}){this.blockLength=t,this.error=e,this.warnings=n,this.valueBeforeDecodeView=z.BufferSourceConverter.toUint8Array(s)}static blockName(){return this.NAME}get valueBeforeDecode(){return this.valueBeforeDecodeView.slice().buffer}set valueBeforeDecode(t){this.valueBeforeDecodeView=new Uint8Array(t)}toJSON(){return{blockName:this.constructor.NAME,blockLength:this.blockLength,error:this.error,warnings:this.warnings,valueBeforeDecode:z.Convert.ToHex(this.valueBeforeDecodeView)}}};Ee.NAME="baseBlock";var _t=class extends Ee{fromBER(t,e,n){throw TypeError("User need to make a specific function in a class which extends 'ValueBlock'")}toBER(t,e){throw TypeError("User need to make a specific function in a class which extends 'ValueBlock'")}};_t.NAME="valueBlock";var ss=class extends _e(Ee){constructor({idBlock:t={}}={}){var e,n,s,i;super(),t?(this.isHexOnly=(e=t.isHexOnly)!==null&&e!==void 0?e:!1,this.valueHexView=t.valueHex?z.BufferSourceConverter.toUint8Array(t.valueHex):oa,this.tagClass=(n=t.tagClass)!==null&&n!==void 0?n:-1,this.tagNumber=(s=t.tagNumber)!==null&&s!==void 0?s:-1,this.isConstructed=(i=t.isConstructed)!==null&&i!==void 0?i:!1):(this.tagClass=-1,this.tagNumber=-1,this.isConstructed=!1)}toBER(t=!1){let e=0;switch(this.tagClass){case 1:e|=0;break;case 2:e|=64;break;case 3:e|=128;break;case 4:e|=192;break;default:return this.error="Unknown tag class",te}if(this.isConstructed&&(e|=32),this.tagNumber<31&&!this.isHexOnly){let s=new Uint8Array(1);if(!t){let i=this.tagNumber;i&=31,e|=i,s[0]=e}return s.buffer}if(!this.isHexOnly){let s=Fe(this.tagNumber,7),i=new Uint8Array(s),o=s.byteLength,a=new Uint8Array(o+1);if(a[0]=e|31,!t){for(let c=0;c<o-1;c++)a[c+1]=i[c]|128;a[o]=i[o-1]}return a.buffer}let n=new Uint8Array(this.valueHexView.byteLength+1);if(n[0]=e|31,!t){let s=this.valueHexView;for(let i=0;i<s.length-1;i++)n[i+1]=s[i]|128;n[this.valueHexView.byteLength]=s[s.length-1]}return n.buffer}fromBER(t,e,n){let s=z.BufferSourceConverter.toUint8Array(t);if(!Be(this,s,e,n))return-1;let i=s.subarray(e,e+n);if(i.length===0)return this.error="Zero buffer length",-1;switch(i[0]&192){case 0:this.tagClass=1;break;case 64:this.tagClass=2;break;case 128:this.tagClass=3;break;case 192:this.tagClass=4;break;default:return this.error="Unknown tag class",-1}this.isConstructed=(i[0]&32)===32,this.isHexOnly=!1;let a=i[0]&31;if(a!==31)this.tagNumber=a,this.blockLength=1;else{let c=1,h=this.valueHexView=new Uint8Array(255),f=255;for(;i[c]&128;){if(h[c-1]=i[c]&127,c++,c>=i.length)return this.error="End of input reached before message was fully decoded",-1;if(c===f){f+=255;let g=new Uint8Array(f);for(let l=0;l<h.length;l++)g[l]=h[l];h=this.valueHexView=new Uint8Array(f)}}this.blockLength=c+1,h[c-1]=i[c]&127;let u=new Uint8Array(c);for(let g=0;g<c;g++)u[g]=h[g];h=this.valueHexView=new Uint8Array(c),h.set(u),this.blockLength<=9?this.tagNumber=ir(h,7):(this.isHexOnly=!0,this.warnings.push("Tag too long, represented as hex-coded"))}if(this.tagClass===1&&this.isConstructed)switch(this.tagNumber){case 1:case 2:case 5:case 6:case 9:case 13:case 14:case 23:case 24:case 31:case 32:case 33:case 34:return this.error="Constructed encoding used for primitive type",-1}return e+this.blockLength}toJSON(){return{...super.toJSON(),tagClass:this.tagClass,tagNumber:this.tagNumber,isConstructed:this.isConstructed}}};ss.NAME="identificationBlock";var is=class extends Ee{constructor({lenBlock:t={}}={}){var e,n,s;super(),this.isIndefiniteForm=(e=t.isIndefiniteForm)!==null&&e!==void 0?e:!1,this.longFormUsed=(n=t.longFormUsed)!==null&&n!==void 0?n:!1,this.length=(s=t.length)!==null&&s!==void 0?s:0}fromBER(t,e,n){let s=z.BufferSourceConverter.toUint8Array(t);if(!Be(this,s,e,n))return-1;let i=s.subarray(e,e+n);if(i.length===0)return this.error="Zero buffer length",-1;if(i[0]===255)return this.error="Length block 0xFF is reserved by standard",-1;if(this.isIndefiniteForm=i[0]===128,this.isIndefiniteForm)return this.blockLength=1,e+this.blockLength;if(this.longFormUsed=!!(i[0]&128),this.longFormUsed===!1)return this.length=i[0],this.blockLength=1,e+this.blockLength;let o=i[0]&127;if(o>8)return this.error="Too big integer",-1;if(o+1>i.length)return this.error="End of input reached before message was fully decoded",-1;let a=e+1,c=s.subarray(a,a+o);return c[o-1]===0&&this.warnings.push("Needlessly long encoded length"),this.length=ir(c,8),this.longFormUsed&&this.length<=127&&this.warnings.push("Unnecessary usage of long length form"),this.blockLength=o+1,e+this.blockLength}toBER(t=!1){let e,n;if(this.length>127&&(this.longFormUsed=!0),this.isIndefiniteForm)return e=new ArrayBuffer(1),t===!1&&(n=new Uint8Array(e),n[0]=128),e;if(this.longFormUsed){let s=Fe(this.length,8);if(s.byteLength>127)return this.error="Too big length",te;if(e=new ArrayBuffer(s.byteLength+1),t)return e;let i=new Uint8Array(s);n=new Uint8Array(e),n[0]=s.byteLength|128;for(let o=0;o<s.byteLength;o++)n[o+1]=i[o];return e}return e=new ArrayBuffer(1),t===!1&&(n=new Uint8Array(e),n[0]=this.length),e}toJSON(){return{...super.toJSON(),isIndefiniteForm:this.isIndefiniteForm,longFormUsed:this.longFormUsed,length:this.length}}};is.NAME="lengthBlock";var k={},bt=class extends Ee{constructor({name:t=Tr,optional:e=!1,primitiveSchema:n,...s}={},i){super(s),this.name=t,this.optional=e,n&&(this.primitiveSchema=n),this.idBlock=new ss(s),this.lenBlock=new is(s),this.valueBlock=i?new i(s):new _t(s)}fromBER(t,e,n){let s=this.valueBlock.fromBER(t,e,this.lenBlock.isIndefiniteForm?n:this.lenBlock.length);return s===-1?(this.error=this.valueBlock.error,s):(this.idBlock.error.length||(this.blockLength+=this.idBlock.blockLength),this.lenBlock.error.length||(this.blockLength+=this.lenBlock.blockLength),this.valueBlock.error.length||(this.blockLength+=this.valueBlock.blockLength),s)}toBER(t,e){let n=e||new en;e||Ll(this);let s=this.idBlock.toBER(t);if(n.write(s),this.lenBlock.isIndefiniteForm)n.write(new Uint8Array([128]).buffer),this.valueBlock.toBER(t,n),n.write(new ArrayBuffer(2));else{let i=this.valueBlock.toBER(t);this.lenBlock.length=i.byteLength;let o=this.lenBlock.toBER(t);n.write(o),n.write(i)}return e?te:n.final()}toJSON(){let t={...super.toJSON(),idBlock:this.idBlock.toJSON(),lenBlock:this.lenBlock.toJSON(),valueBlock:this.valueBlock.toJSON(),name:this.name,optional:this.optional};return this.primitiveSchema&&(t.primitiveSchema=this.primitiveSchema.toJSON()),t}toString(t="ascii"){return t==="ascii"?this.onAsciiEncoding():z.Convert.ToHex(this.toBER())}onAsciiEncoding(){return`${this.constructor.NAME} : ${z.Convert.ToHex(this.valueBlock.valueBeforeDecodeView)}`}isEqual(t){if(this===t)return!0;if(!(t instanceof this.constructor))return!1;let e=this.toBER(),n=t.toBER();return Il(e,n)}};bt.NAME="BaseBlock";function Ll(r){if(r instanceof k.Constructed)for(let t of r.valueBlock.value)Ll(t)&&(r.lenBlock.isIndefiniteForm=!0);return!!r.lenBlock.isIndefiniteForm}var os=class extends bt{constructor({value:t=Tr,...e}={},n){super(e,n),t&&this.fromString(t)}getValue(){return this.valueBlock.value}setValue(t){this.valueBlock.value=t}fromBER(t,e,n){let s=this.valueBlock.fromBER(t,e,this.lenBlock.isIndefiniteForm?n:this.lenBlock.length);return s===-1?(this.error=this.valueBlock.error,s):(this.fromBuffer(this.valueBlock.valueHexView),this.idBlock.error.length||(this.blockLength+=this.idBlock.blockLength),this.lenBlock.error.length||(this.blockLength+=this.lenBlock.blockLength),this.valueBlock.error.length||(this.blockLength+=this.valueBlock.blockLength),s)}onAsciiEncoding(){return`${this.constructor.NAME} : '${this.valueBlock.value}'`}};os.NAME="BaseStringBlock";var as=class extends _e(_t){constructor({isHexOnly:t=!0,...e}={}){super(e),this.isHexOnly=t}};as.NAME="PrimitiveValueBlock";var Rl,cs=class extends bt{constructor(t={}){super(t,as),this.idBlock.isConstructed=!1}};Rl=cs;k.Primitive=Rl;cs.NAME="PRIMITIVE";function Mp(r,t){if(r instanceof t)return r;let e=new t;return e.idBlock=r.idBlock,e.lenBlock=r.lenBlock,e.warnings=r.warnings,e.valueBeforeDecodeView=r.valueBeforeDecodeView,e}function Ks(r,t=0,e=r.length){let n=t,s=new bt({},_t),i=new Ee;if(!Be(i,r,t,e))return s.error=i.error,{offset:-1,result:s};if(!r.subarray(t,t+e).length)return s.error="Zero buffer length",{offset:-1,result:s};let a=s.idBlock.fromBER(r,t,e);if(s.idBlock.warnings.length&&s.warnings.concat(s.idBlock.warnings),a===-1)return s.error=s.idBlock.error,{offset:-1,result:s};if(t=a,e-=s.idBlock.blockLength,a=s.lenBlock.fromBER(r,t,e),s.lenBlock.warnings.length&&s.warnings.concat(s.lenBlock.warnings),a===-1)return s.error=s.lenBlock.error,{offset:-1,result:s};if(t=a,e-=s.lenBlock.blockLength,!s.idBlock.isConstructed&&s.lenBlock.isIndefiniteForm)return s.error="Indefinite length form used for primitive encoding form",{offset:-1,result:s};let c=bt;switch(s.idBlock.tagClass){case 1:if(s.idBlock.tagNumber>=37&&s.idBlock.isHexOnly===!1)return s.error="UNIVERSAL 37 and upper tags are reserved by ASN.1 standard",{offset:-1,result:s};switch(s.idBlock.tagNumber){case 0:if(s.idBlock.isConstructed&&s.lenBlock.length>0)return s.error="Type [UNIVERSAL 0] is reserved",{offset:-1,result:s};c=k.EndOfContent;break;case 1:c=k.Boolean;break;case 2:c=k.Integer;break;case 3:c=k.BitString;break;case 4:c=k.OctetString;break;case 5:c=k.Null;break;case 6:c=k.ObjectIdentifier;break;case 10:c=k.Enumerated;break;case 12:c=k.Utf8String;break;case 13:c=k.RelativeObjectIdentifier;break;case 14:c=k.TIME;break;case 15:return s.error="[UNIVERSAL 15] is reserved by ASN.1 standard",{offset:-1,result:s};case 16:c=k.Sequence;break;case 17:c=k.Set;break;case 18:c=k.NumericString;break;case 19:c=k.PrintableString;break;case 20:c=k.TeletexString;break;case 21:c=k.VideotexString;break;case 22:c=k.IA5String;break;case 23:c=k.UTCTime;break;case 24:c=k.GeneralizedTime;break;case 25:c=k.GraphicString;break;case 26:c=k.VisibleString;break;case 27:c=k.GeneralString;break;case 28:c=k.UniversalString;break;case 29:c=k.CharacterString;break;case 30:c=k.BmpString;break;case 31:c=k.DATE;break;case 32:c=k.TimeOfDay;break;case 33:c=k.DateTime;break;case 34:c=k.Duration;break;default:{let h=s.idBlock.isConstructed?new k.Constructed:new k.Primitive;h.idBlock=s.idBlock,h.lenBlock=s.lenBlock,h.warnings=s.warnings,s=h}}break;case 2:case 3:case 4:default:c=s.idBlock.isConstructed?k.Constructed:k.Primitive}return s=Mp(s,c),a=s.fromBER(r,t,s.lenBlock.isIndefiniteForm?e:s.lenBlock.length),s.valueBeforeDecodeView=r.subarray(n,n+s.blockLength),{offset:a,result:s}}function aa(r){if(!r.byteLength){let t=new bt({},_t);return t.error="Input buffer has zero length",{offset:-1,result:t}}return Ks(z.BufferSourceConverter.toUint8Array(r).slice(),0,r.byteLength)}function Pp(r,t){return r?1:t}var ce=class extends _t{constructor({value:t=[],isIndefiniteForm:e=!1,...n}={}){super(n),this.value=t,this.isIndefiniteForm=e}fromBER(t,e,n){let s=z.BufferSourceConverter.toUint8Array(t);if(!Be(this,s,e,n))return-1;if(this.valueBeforeDecodeView=s.subarray(e,e+n),this.valueBeforeDecodeView.length===0)return this.warnings.push("Zero buffer length"),e;let i=e;for(;Pp(this.isIndefiniteForm,n)>0;){let o=Ks(s,i,n);if(o.offset===-1)return this.error=o.result.error,this.warnings.concat(o.result.warnings),-1;if(i=o.offset,this.blockLength+=o.result.blockLength,n-=o.result.blockLength,this.value.push(o.result),this.isIndefiniteForm&&o.result.constructor.NAME===rn)break}return this.isIndefiniteForm&&(this.value[this.value.length-1].constructor.NAME===rn?this.value.pop():this.warnings.push("No EndOfContent block encoded")),i}toBER(t,e){let n=e||new en;for(let s=0;s<this.value.length;s++)this.value[s].toBER(t,n);return e?te:n.final()}toJSON(){let t={...super.toJSON(),isIndefiniteForm:this.isIndefiniteForm,value:[]};for(let e of this.value)t.value.push(e.toJSON());return t}};ce.NAME="ConstructedValueBlock";var Ul,Ke=class extends bt{constructor(t={}){super(t,ce),this.idBlock.isConstructed=!0}fromBER(t,e,n){this.valueBlock.isIndefiniteForm=this.lenBlock.isIndefiniteForm;let s=this.valueBlock.fromBER(t,e,this.lenBlock.isIndefiniteForm?n:this.lenBlock.length);return s===-1?(this.error=this.valueBlock.error,s):(this.idBlock.error.length||(this.blockLength+=this.idBlock.blockLength),this.lenBlock.error.length||(this.blockLength+=this.lenBlock.blockLength),this.valueBlock.error.length||(this.blockLength+=this.valueBlock.blockLength),s)}onAsciiEncoding(){let t=[];for(let n of this.valueBlock.value)t.push(n.toString("ascii").split(`
|
2
|
+
"use strict";var Libp2PCircuitRelayV2=(()=>{var Xf=Object.create;var In=Object.defineProperty;var Jf=Object.getOwnPropertyDescriptor;var Qf=Object.getOwnPropertyNames;var eh=Object.getPrototypeOf,th=Object.prototype.hasOwnProperty;var qi=(r,e)=>()=>(e||r((e={exports:{}}).exports,e),e.exports),ke=(r,e)=>{for(var t in e)In(r,t,{get:e[t],enumerable:!0})},dc=(r,e,t,n)=>{if(e&&typeof e=="object"||typeof e=="function")for(let s of Qf(e))!th.call(r,s)&&s!==t&&In(r,s,{get:()=>e[s],enumerable:!(n=Jf(e,s))||n.enumerable});return r};var pc=(r,e,t)=>(t=r!=null?Xf(eh(r)):{},dc(e||!r||!r.__esModule?In(t,"default",{value:r,enumerable:!0}):t,r)),rh=r=>dc(In({},"__esModule",{value:!0}),r);var Bl=qi(Ar=>{"use strict";var kp="[object ArrayBuffer]",vt=class r{static isArrayBuffer(e){return Object.prototype.toString.call(e)===kp}static toArrayBuffer(e){return this.isArrayBuffer(e)?e:e.byteLength===e.buffer.byteLength||e.byteOffset===0&&e.byteLength===e.buffer.byteLength?e.buffer:this.toUint8Array(e.buffer).slice(e.byteOffset,e.byteOffset+e.byteLength).buffer}static toUint8Array(e){return this.toView(e,Uint8Array)}static toView(e,t){if(e.constructor===t)return e;if(this.isArrayBuffer(e))return new t(e);if(this.isArrayBufferView(e))return new t(e.buffer,e.byteOffset,e.byteLength);throw new TypeError("The provided value is not of type '(ArrayBuffer or ArrayBufferView)'")}static isBufferSource(e){return this.isArrayBufferView(e)||this.isArrayBuffer(e)}static isArrayBufferView(e){return ArrayBuffer.isView(e)||e&&this.isArrayBuffer(e.buffer)}static isEqual(e,t){let n=r.toUint8Array(e),s=r.toUint8Array(t);if(n.length!==s.byteLength)return!1;for(let i=0;i<n.length;i++)if(n[i]!==s[i])return!1;return!0}static concat(...e){let t;Array.isArray(e[0])&&!(e[1]instanceof Function)||Array.isArray(e[0])&&e[1]instanceof Function?t=e[0]:e[e.length-1]instanceof Function?t=e.slice(0,e.length-1):t=e;let n=0;for(let o of t)n+=o.byteLength;let s=new Uint8Array(n),i=0;for(let o of t){let a=this.toUint8Array(o);s.set(a,i),i+=a.length}return e[e.length-1]instanceof Function?this.toView(s,e[e.length-1]):s.buffer}},na="string",Cp=/^[0-9a-f\s]+$/i,Np=/^(?:[A-Za-z0-9+/]{4})*(?:[A-Za-z0-9+/]{2}==|[A-Za-z0-9+/]{3}=)?$/,Lp=/^[a-zA-Z0-9-_]+$/,es=class{static fromString(e){let t=unescape(encodeURIComponent(e)),n=new Uint8Array(t.length);for(let s=0;s<t.length;s++)n[s]=t.charCodeAt(s);return n.buffer}static toString(e){let t=vt.toUint8Array(e),n="";for(let i=0;i<t.length;i++)n+=String.fromCharCode(t[i]);return decodeURIComponent(escape(n))}},Ge=class{static toString(e,t=!1){let n=vt.toArrayBuffer(e),s=new DataView(n),i="";for(let o=0;o<n.byteLength;o+=2){let a=s.getUint16(o,t);i+=String.fromCharCode(a)}return i}static fromString(e,t=!1){let n=new ArrayBuffer(e.length*2),s=new DataView(n);for(let i=0;i<e.length;i++)s.setUint16(i*2,e.charCodeAt(i),t);return n}},ts=class r{static isHex(e){return typeof e===na&&Cp.test(e)}static isBase64(e){return typeof e===na&&Np.test(e)}static isBase64Url(e){return typeof e===na&&Lp.test(e)}static ToString(e,t="utf8"){let n=vt.toUint8Array(e);switch(t.toLowerCase()){case"utf8":return this.ToUtf8String(n);case"binary":return this.ToBinary(n);case"hex":return this.ToHex(n);case"base64":return this.ToBase64(n);case"base64url":return this.ToBase64Url(n);case"utf16le":return Ge.toString(n,!0);case"utf16":case"utf16be":return Ge.toString(n);default:throw new Error(`Unknown type of encoding '${t}'`)}}static FromString(e,t="utf8"){if(!e)return new ArrayBuffer(0);switch(t.toLowerCase()){case"utf8":return this.FromUtf8String(e);case"binary":return this.FromBinary(e);case"hex":return this.FromHex(e);case"base64":return this.FromBase64(e);case"base64url":return this.FromBase64Url(e);case"utf16le":return Ge.fromString(e,!0);case"utf16":case"utf16be":return Ge.fromString(e);default:throw new Error(`Unknown type of encoding '${t}'`)}}static ToBase64(e){let t=vt.toUint8Array(e);if(typeof btoa<"u"){let n=this.ToString(t,"binary");return btoa(n)}else return Buffer.from(t).toString("base64")}static FromBase64(e){let t=this.formatString(e);if(!t)return new ArrayBuffer(0);if(!r.isBase64(t))throw new TypeError("Argument 'base64Text' is not Base64 encoded");return typeof atob<"u"?this.FromBinary(atob(t)):new Uint8Array(Buffer.from(t,"base64")).buffer}static FromBase64Url(e){let t=this.formatString(e);if(!t)return new ArrayBuffer(0);if(!r.isBase64Url(t))throw new TypeError("Argument 'base64url' is not Base64Url encoded");return this.FromBase64(this.Base64Padding(t.replace(/\-/g,"+").replace(/\_/g,"/")))}static ToBase64Url(e){return this.ToBase64(e).replace(/\+/g,"-").replace(/\//g,"_").replace(/\=/g,"")}static FromUtf8String(e,t=r.DEFAULT_UTF8_ENCODING){switch(t){case"ascii":return this.FromBinary(e);case"utf8":return es.fromString(e);case"utf16":case"utf16be":return Ge.fromString(e);case"utf16le":case"usc2":return Ge.fromString(e,!0);default:throw new Error(`Unknown type of encoding '${t}'`)}}static ToUtf8String(e,t=r.DEFAULT_UTF8_ENCODING){switch(t){case"ascii":return this.ToBinary(e);case"utf8":return es.toString(e);case"utf16":case"utf16be":return Ge.toString(e);case"utf16le":case"usc2":return Ge.toString(e,!0);default:throw new Error(`Unknown type of encoding '${t}'`)}}static FromBinary(e){let t=e.length,n=new Uint8Array(t);for(let s=0;s<t;s++)n[s]=e.charCodeAt(s);return n.buffer}static ToBinary(e){let t=vt.toUint8Array(e),n="";for(let s=0;s<t.length;s++)n+=String.fromCharCode(t[s]);return n}static ToHex(e){let t=vt.toUint8Array(e),n="",s=t.length;for(let i=0;i<s;i++){let o=t[i];o<16&&(n+="0"),n+=o.toString(16)}return n}static FromHex(e){let t=this.formatString(e);if(!t)return new ArrayBuffer(0);if(!r.isHex(t))throw new TypeError("Argument 'hexString' is not HEX encoded");t.length%2&&(t=`0${t}`);let n=new Uint8Array(t.length/2);for(let s=0;s<t.length;s=s+2){let i=t.slice(s,s+2);n[s/2]=parseInt(i,16)}return n.buffer}static ToUtf16String(e,t=!1){return Ge.toString(e,t)}static FromUtf16String(e,t=!1){return Ge.fromString(e,t)}static Base64Padding(e){let t=4-e.length%4;if(t<4)for(let n=0;n<t;n++)e+="=";return e}static formatString(e){return e?.replace(/[\n\r\t ]/g,"")||""}};ts.DEFAULT_UTF8_ENCODING="utf8";function Rp(r,...e){let t=arguments[0];for(let n=1;n<arguments.length;n++){let s=arguments[n];for(let i in s)t[i]=s[i]}return t}function Up(...r){let e=r.map(s=>s.byteLength).reduce((s,i)=>s+i),t=new Uint8Array(e),n=0;return r.map(s=>new Uint8Array(s)).forEach(s=>{for(let i of s)t[n++]=i}),t.buffer}function Dp(r,e){if(!(r&&e)||r.byteLength!==e.byteLength)return!1;let t=new Uint8Array(r),n=new Uint8Array(e);for(let s=0;s<r.byteLength;s++)if(t[s]!==n[s])return!1;return!0}Ar.BufferSourceConverter=vt;Ar.Convert=ts;Ar.assign=Rp;Ar.combine=Up;Ar.isEqual=Dp});var Ef=qi((An,Ti)=>{(function(r,e){"use strict";var t={version:"3.0.0",x86:{},x64:{},inputValidation:!0};function n(l){if(!Array.isArray(l)&&!ArrayBuffer.isView(l))return!1;for(var d=0;d<l.length;d++)if(!Number.isInteger(l[d])||l[d]<0||l[d]>255)return!1;return!0}function s(l,d){return(l&65535)*d+(((l>>>16)*d&65535)<<16)}function i(l,d){return l<<d|l>>>32-d}function o(l){return l^=l>>>16,l=s(l,2246822507),l^=l>>>13,l=s(l,3266489909),l^=l>>>16,l}function a(l,d){l=[l[0]>>>16,l[0]&65535,l[1]>>>16,l[1]&65535],d=[d[0]>>>16,d[0]&65535,d[1]>>>16,d[1]&65535];var p=[0,0,0,0];return p[3]+=l[3]+d[3],p[2]+=p[3]>>>16,p[3]&=65535,p[2]+=l[2]+d[2],p[1]+=p[2]>>>16,p[2]&=65535,p[1]+=l[1]+d[1],p[0]+=p[1]>>>16,p[1]&=65535,p[0]+=l[0]+d[0],p[0]&=65535,[p[0]<<16|p[1],p[2]<<16|p[3]]}function c(l,d){l=[l[0]>>>16,l[0]&65535,l[1]>>>16,l[1]&65535],d=[d[0]>>>16,d[0]&65535,d[1]>>>16,d[1]&65535];var p=[0,0,0,0];return p[3]+=l[3]*d[3],p[2]+=p[3]>>>16,p[3]&=65535,p[2]+=l[2]*d[3],p[1]+=p[2]>>>16,p[2]&=65535,p[2]+=l[3]*d[2],p[1]+=p[2]>>>16,p[2]&=65535,p[1]+=l[1]*d[3],p[0]+=p[1]>>>16,p[1]&=65535,p[1]+=l[2]*d[2],p[0]+=p[1]>>>16,p[1]&=65535,p[1]+=l[3]*d[1],p[0]+=p[1]>>>16,p[1]&=65535,p[0]+=l[0]*d[3]+l[1]*d[2]+l[2]*d[1]+l[3]*d[0],p[0]&=65535,[p[0]<<16|p[1],p[2]<<16|p[3]]}function h(l,d){return d%=64,d===32?[l[1],l[0]]:d<32?[l[0]<<d|l[1]>>>32-d,l[1]<<d|l[0]>>>32-d]:(d-=32,[l[1]<<d|l[0]>>>32-d,l[0]<<d|l[1]>>>32-d])}function f(l,d){return d%=64,d===0?l:d<32?[l[0]<<d|l[1]>>>32-d,l[1]<<d]:[l[1]<<d-32,0]}function u(l,d){return[l[0]^d[0],l[1]^d[1]]}function m(l){return l=u(l,[0,l[0]>>>1]),l=c(l,[4283543511,3981806797]),l=u(l,[0,l[0]>>>1]),l=c(l,[3301882366,444984403]),l=u(l,[0,l[0]>>>1]),l}t.x86.hash32=function(l,d){if(t.inputValidation&&!n(l))return e;d=d||0;for(var p=l.length%4,y=l.length-p,b=d,w=0,g=3432918353,E=461845907,A=0;A<y;A=A+4)w=l[A]|l[A+1]<<8|l[A+2]<<16|l[A+3]<<24,w=s(w,g),w=i(w,15),w=s(w,E),b^=w,b=i(b,13),b=s(b,5)+3864292196;switch(w=0,p){case 3:w^=l[A+2]<<16;case 2:w^=l[A+1]<<8;case 1:w^=l[A],w=s(w,g),w=i(w,15),w=s(w,E),b^=w}return b^=l.length,b=o(b),b>>>0},t.x86.hash128=function(l,d){if(t.inputValidation&&!n(l))return e;d=d||0;for(var p=l.length%16,y=l.length-p,b=d,w=d,g=d,E=d,A=0,_=0,x=0,I=0,C=597399067,j=2869860233,V=951274213,P=2716044179,R=0;R<y;R=R+16)A=l[R]|l[R+1]<<8|l[R+2]<<16|l[R+3]<<24,_=l[R+4]|l[R+5]<<8|l[R+6]<<16|l[R+7]<<24,x=l[R+8]|l[R+9]<<8|l[R+10]<<16|l[R+11]<<24,I=l[R+12]|l[R+13]<<8|l[R+14]<<16|l[R+15]<<24,A=s(A,C),A=i(A,15),A=s(A,j),b^=A,b=i(b,19),b+=w,b=s(b,5)+1444728091,_=s(_,j),_=i(_,16),_=s(_,V),w^=_,w=i(w,17),w+=g,w=s(w,5)+197830471,x=s(x,V),x=i(x,17),x=s(x,P),g^=x,g=i(g,15),g+=E,g=s(g,5)+2530024501,I=s(I,P),I=i(I,18),I=s(I,C),E^=I,E=i(E,13),E+=b,E=s(E,5)+850148119;switch(A=0,_=0,x=0,I=0,p){case 15:I^=l[R+14]<<16;case 14:I^=l[R+13]<<8;case 13:I^=l[R+12],I=s(I,P),I=i(I,18),I=s(I,C),E^=I;case 12:x^=l[R+11]<<24;case 11:x^=l[R+10]<<16;case 10:x^=l[R+9]<<8;case 9:x^=l[R+8],x=s(x,V),x=i(x,17),x=s(x,P),g^=x;case 8:_^=l[R+7]<<24;case 7:_^=l[R+6]<<16;case 6:_^=l[R+5]<<8;case 5:_^=l[R+4],_=s(_,j),_=i(_,16),_=s(_,V),w^=_;case 4:A^=l[R+3]<<24;case 3:A^=l[R+2]<<16;case 2:A^=l[R+1]<<8;case 1:A^=l[R],A=s(A,C),A=i(A,15),A=s(A,j),b^=A}return b^=l.length,w^=l.length,g^=l.length,E^=l.length,b+=w,b+=g,b+=E,w+=b,g+=b,E+=b,b=o(b),w=o(w),g=o(g),E=o(E),b+=w,b+=g,b+=E,w+=b,g+=b,E+=b,("00000000"+(b>>>0).toString(16)).slice(-8)+("00000000"+(w>>>0).toString(16)).slice(-8)+("00000000"+(g>>>0).toString(16)).slice(-8)+("00000000"+(E>>>0).toString(16)).slice(-8)},t.x64.hash128=function(l,d){if(t.inputValidation&&!n(l))return e;d=d||0;for(var p=l.length%16,y=l.length-p,b=[0,d],w=[0,d],g=[0,0],E=[0,0],A=[2277735313,289559509],_=[1291169091,658871167],x=0;x<y;x=x+16)g=[l[x+4]|l[x+5]<<8|l[x+6]<<16|l[x+7]<<24,l[x]|l[x+1]<<8|l[x+2]<<16|l[x+3]<<24],E=[l[x+12]|l[x+13]<<8|l[x+14]<<16|l[x+15]<<24,l[x+8]|l[x+9]<<8|l[x+10]<<16|l[x+11]<<24],g=c(g,A),g=h(g,31),g=c(g,_),b=u(b,g),b=h(b,27),b=a(b,w),b=a(c(b,[0,5]),[0,1390208809]),E=c(E,_),E=h(E,33),E=c(E,A),w=u(w,E),w=h(w,31),w=a(w,b),w=a(c(w,[0,5]),[0,944331445]);switch(g=[0,0],E=[0,0],p){case 15:E=u(E,f([0,l[x+14]],48));case 14:E=u(E,f([0,l[x+13]],40));case 13:E=u(E,f([0,l[x+12]],32));case 12:E=u(E,f([0,l[x+11]],24));case 11:E=u(E,f([0,l[x+10]],16));case 10:E=u(E,f([0,l[x+9]],8));case 9:E=u(E,[0,l[x+8]]),E=c(E,_),E=h(E,33),E=c(E,A),w=u(w,E);case 8:g=u(g,f([0,l[x+7]],56));case 7:g=u(g,f([0,l[x+6]],48));case 6:g=u(g,f([0,l[x+5]],40));case 5:g=u(g,f([0,l[x+4]],32));case 4:g=u(g,f([0,l[x+3]],24));case 3:g=u(g,f([0,l[x+2]],16));case 2:g=u(g,f([0,l[x+1]],8));case 1:g=u(g,[0,l[x]]),g=c(g,A),g=h(g,31),g=c(g,_),b=u(b,g)}return b=u(b,[0,l.length]),w=u(w,[0,l.length]),b=a(b,w),w=a(w,b),b=m(b),w=m(w),b=a(b,w),w=a(w,b),("00000000"+(b[0]>>>0).toString(16)).slice(-8)+("00000000"+(b[1]>>>0).toString(16)).slice(-8)+("00000000"+(w[0]>>>0).toString(16)).slice(-8)+("00000000"+(w[1]>>>0).toString(16)).slice(-8)},typeof An<"u"?(typeof Ti<"u"&&Ti.exports&&(An=Ti.exports=t),An.murmurHash3=t):typeof define=="function"&&define.amd?define([],function(){return t}):(t._murmurHash3=r.murmurHash3,t.noConflict=function(){return r.murmurHash3=t._murmurHash3,t._murmurHash3=e,t.noConflict=e,t},r.murmurHash3=t)})(An)});var Af=qi((W2,Sf)=>{Sf.exports=Ef()});var X0={};ke(X0,{RELAY_V2_HOP_CODEC:()=>We,RELAY_V2_STOP_CODEC:()=>ar,circuitRelayServer:()=>Cf,circuitRelayTransport:()=>Kf});var zi=Symbol.for("@libp2p/peer-id");var $i="keep-alive";var mc=Symbol.for("@libp2p/transport");var gc;(function(r){r[r.FATAL_ALL=0]="FATAL_ALL",r[r.NO_FATAL=1]="NO_FATAL"})(gc||(gc={}));var ht=class extends Error{static name="AbortError";constructor(e="The operation was aborted"){super(e),this.name="AbortError"}};var ve=class extends Error{static name="InvalidParametersError";constructor(e="Invalid parameters"){super(e),this.name="InvalidParametersError"}},fr=class extends Error{static name="InvalidPublicKeyError";constructor(e="Invalid public key"){super(e),this.name="InvalidPublicKeyError"}};var Tn=class extends Error{static name="InvalidMultihashError";constructor(e="Invalid Multihash"){super(e),this.name="InvalidMultihashError"}};var kn=class extends Error{static name="InvalidMessageError";constructor(e="Invalid message"){super(e),this.name="InvalidMessageError"}};var Fr=class extends Error{static name="DialError";constructor(e="Dial error"){super(e),this.name="DialError"}},jt=class extends Error{static name="ListenError";constructor(e="Listen error"){super(e),this.name="ListenError"}};var hr=class extends Error{static name="UnsupportedKeyTypeError";constructor(e="Unsupported key type"){super(e),this.name="UnsupportedKeyTypeError"}};var Le=(r,...e)=>{try{[...e]}catch{}};var qe=class extends EventTarget{#e=new Map;constructor(){super(),Le(1/0,this)}listenerCount(e){let t=this.#e.get(e);return t==null?0:t.length}addEventListener(e,t,n){super.addEventListener(e,t,n);let s=this.#e.get(e);s==null&&(s=[],this.#e.set(e,s)),s.push({callback:t,once:(n!==!0&&n!==!1&&n?.once)??!1})}removeEventListener(e,t,n){super.removeEventListener(e.toString(),t??null,n);let s=this.#e.get(e);s!=null&&(s=s.filter(({callback:i})=>i!==t),this.#e.set(e,s))}dispatchEvent(e){let t=super.dispatchEvent(e),n=this.#e.get(e.type);return n==null||(n=n.filter(({once:s})=>!s),this.#e.set(e.type,n)),t}safeDispatchEvent(e,t={}){return this.dispatchEvent(new CustomEvent(e,t))}};function yc(r){return r!=null&&typeof r.start=="function"&&typeof r.stop=="function"}async function bc(...r){let e=[];for(let t of r)yc(t)&&e.push(t);await Promise.all(e.map(async t=>{t.beforeStart!=null&&await t.beforeStart()})),await Promise.all(e.map(async t=>{await t.start()})),await Promise.all(e.map(async t=>{t.afterStart!=null&&await t.afterStart()}))}async function wc(...r){let e=[];for(let t of r)yc(t)&&e.push(t);await Promise.all(e.map(async t=>{t.beforeStop!=null&&await t.beforeStop()})),await Promise.all(e.map(async t=>{await t.stop()})),await Promise.all(e.map(async t=>{t.afterStop!=null&&await t.afterStop()}))}var xc=Symbol.for("@libp2p/service-capabilities"),vc=Symbol.for("@libp2p/service-dependencies");var Yi={};ke(Yi,{base58btc:()=>ee,base58flickr:()=>ch});var Cg=new Uint8Array(0);function Ec(r,e){if(r===e)return!0;if(r.byteLength!==e.byteLength)return!1;for(let t=0;t<r.byteLength;t++)if(r[t]!==e[t])return!1;return!0}function dt(r){if(r instanceof Uint8Array&&r.constructor.name==="Uint8Array")return r;if(r instanceof ArrayBuffer)return new Uint8Array(r);if(ArrayBuffer.isView(r))return new Uint8Array(r.buffer,r.byteOffset,r.byteLength);throw new Error("Unknown type, must be binary type")}function Sc(r){return new TextEncoder().encode(r)}function Ac(r){return new TextDecoder().decode(r)}function nh(r,e){if(r.length>=255)throw new TypeError("Alphabet too long");for(var t=new Uint8Array(256),n=0;n<t.length;n++)t[n]=255;for(var s=0;s<r.length;s++){var i=r.charAt(s),o=i.charCodeAt(0);if(t[o]!==255)throw new TypeError(i+" is ambiguous");t[o]=s}var a=r.length,c=r.charAt(0),h=Math.log(a)/Math.log(256),f=Math.log(256)/Math.log(a);function u(d){if(d instanceof Uint8Array||(ArrayBuffer.isView(d)?d=new Uint8Array(d.buffer,d.byteOffset,d.byteLength):Array.isArray(d)&&(d=Uint8Array.from(d))),!(d instanceof Uint8Array))throw new TypeError("Expected Uint8Array");if(d.length===0)return"";for(var p=0,y=0,b=0,w=d.length;b!==w&&d[b]===0;)b++,p++;for(var g=(w-b)*f+1>>>0,E=new Uint8Array(g);b!==w;){for(var A=d[b],_=0,x=g-1;(A!==0||_<y)&&x!==-1;x--,_++)A+=256*E[x]>>>0,E[x]=A%a>>>0,A=A/a>>>0;if(A!==0)throw new Error("Non-zero carry");y=_,b++}for(var I=g-y;I!==g&&E[I]===0;)I++;for(var C=c.repeat(p);I<g;++I)C+=r.charAt(E[I]);return C}function m(d){if(typeof d!="string")throw new TypeError("Expected String");if(d.length===0)return new Uint8Array;var p=0;if(d[p]!==" "){for(var y=0,b=0;d[p]===c;)y++,p++;for(var w=(d.length-p)*h+1>>>0,g=new Uint8Array(w);d[p];){var E=t[d.charCodeAt(p)];if(E===255)return;for(var A=0,_=w-1;(E!==0||A<b)&&_!==-1;_--,A++)E+=a*g[_]>>>0,g[_]=E%256>>>0,E=E/256>>>0;if(E!==0)throw new Error("Non-zero carry");b=A,p++}if(d[p]!==" "){for(var x=w-b;x!==w&&g[x]===0;)x++;for(var I=new Uint8Array(y+(w-x)),C=y;x!==w;)I[C++]=g[x++];return I}}}function l(d){var p=m(d);if(p)return p;throw new Error(`Non-${e} character`)}return{encode:u,decodeUnsafe:m,decode:l}}var sh=nh,ih=sh,_c=ih;var Gi=class{name;prefix;baseEncode;constructor(e,t,n){this.name=e,this.prefix=t,this.baseEncode=n}encode(e){if(e instanceof Uint8Array)return`${this.prefix}${this.baseEncode(e)}`;throw Error("Unknown type, must be binary type")}},Wi=class{name;prefix;baseDecode;prefixCodePoint;constructor(e,t,n){this.name=e,this.prefix=t;let s=t.codePointAt(0);if(s===void 0)throw new Error("Invalid prefix character");this.prefixCodePoint=s,this.baseDecode=n}decode(e){if(typeof e=="string"){if(e.codePointAt(0)!==this.prefixCodePoint)throw Error(`Unable to decode multibase string ${JSON.stringify(e)}, ${this.name} decoder only supports inputs prefixed with ${this.prefix}`);return this.baseDecode(e.slice(this.prefix.length))}else throw Error("Can only multibase decode strings")}or(e){return Ic(this,e)}},Zi=class{decoders;constructor(e){this.decoders=e}or(e){return Ic(this,e)}decode(e){let t=e[0],n=this.decoders[t];if(n!=null)return n.decode(e);throw RangeError(`Unable to decode multibase string ${JSON.stringify(e)}, only inputs prefixed with ${Object.keys(this.decoders)} are supported`)}};function Ic(r,e){return new Zi({...r.decoders??{[r.prefix]:r},...e.decoders??{[e.prefix]:e}})}var ji=class{name;prefix;baseEncode;baseDecode;encoder;decoder;constructor(e,t,n,s){this.name=e,this.prefix=t,this.baseEncode=n,this.baseDecode=s,this.encoder=new Gi(e,t,n),this.decoder=new Wi(e,t,s)}encode(e){return this.encoder.encode(e)}decode(e){return this.decoder.decode(e)}};function dr({name:r,prefix:e,encode:t,decode:n}){return new ji(r,e,t,n)}function Ct({name:r,prefix:e,alphabet:t}){let{encode:n,decode:s}=_c(t,r);return dr({prefix:e,name:r,encode:n,decode:i=>dt(s(i))})}function oh(r,e,t,n){let s={};for(let f=0;f<e.length;++f)s[e[f]]=f;let i=r.length;for(;r[i-1]==="=";)--i;let o=new Uint8Array(i*t/8|0),a=0,c=0,h=0;for(let f=0;f<i;++f){let u=s[r[f]];if(u===void 0)throw new SyntaxError(`Non-${n} character`);c=c<<t|u,a+=t,a>=8&&(a-=8,o[h++]=255&c>>a)}if(a>=t||255&c<<8-a)throw new SyntaxError("Unexpected end of data");return o}function ah(r,e,t){let n=e[e.length-1]==="=",s=(1<<t)-1,i="",o=0,a=0;for(let c=0;c<r.length;++c)for(a=a<<8|r[c],o+=8;o>t;)o-=t,i+=e[s&a>>o];if(o!==0&&(i+=e[s&a<<t-o]),n)for(;i.length*t&7;)i+="=";return i}function le({name:r,prefix:e,bitsPerChar:t,alphabet:n}){return dr({prefix:e,name:r,encode(s){return ah(s,n,t)},decode(s){return oh(s,n,t,r)}})}var ee=Ct({name:"base58btc",prefix:"z",alphabet:"123456789ABCDEFGHJKLMNPQRSTUVWXYZabcdefghijkmnopqrstuvwxyz"}),ch=Ct({name:"base58flickr",prefix:"Z",alphabet:"123456789abcdefghijkmnopqrstuvwxyzABCDEFGHJKLMNPQRSTUVWXYZ"});var Xi={};ke(Xi,{base32:()=>pt,base32hex:()=>hh,base32hexpad:()=>ph,base32hexpadupper:()=>gh,base32hexupper:()=>dh,base32pad:()=>uh,base32padupper:()=>fh,base32upper:()=>lh,base32z:()=>mh});var pt=le({prefix:"b",name:"base32",alphabet:"abcdefghijklmnopqrstuvwxyz234567",bitsPerChar:5}),lh=le({prefix:"B",name:"base32upper",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZ234567",bitsPerChar:5}),uh=le({prefix:"c",name:"base32pad",alphabet:"abcdefghijklmnopqrstuvwxyz234567=",bitsPerChar:5}),fh=le({prefix:"C",name:"base32padupper",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZ234567=",bitsPerChar:5}),hh=le({prefix:"v",name:"base32hex",alphabet:"0123456789abcdefghijklmnopqrstuv",bitsPerChar:5}),dh=le({prefix:"V",name:"base32hexupper",alphabet:"0123456789ABCDEFGHIJKLMNOPQRSTUV",bitsPerChar:5}),ph=le({prefix:"t",name:"base32hexpad",alphabet:"0123456789abcdefghijklmnopqrstuv=",bitsPerChar:5}),gh=le({prefix:"T",name:"base32hexpadupper",alphabet:"0123456789ABCDEFGHIJKLMNOPQRSTUV=",bitsPerChar:5}),mh=le({prefix:"h",name:"base32z",alphabet:"ybndrfg8ejkmcpqxot1uwisza345h769",bitsPerChar:5});var Ji={};ke(Ji,{base36:()=>Kr,base36upper:()=>yh});var Kr=Ct({prefix:"k",name:"base36",alphabet:"0123456789abcdefghijklmnopqrstuvwxyz"}),yh=Ct({prefix:"K",name:"base36upper",alphabet:"0123456789ABCDEFGHIJKLMNOPQRSTUVWXYZ"});var bh=Cc,Tc=128,wh=127,xh=~wh,vh=Math.pow(2,31);function Cc(r,e,t){e=e||[],t=t||0;for(var n=t;r>=vh;)e[t++]=r&255|Tc,r/=128;for(;r&xh;)e[t++]=r&255|Tc,r>>>=7;return e[t]=r|0,Cc.bytes=t-n+1,e}var Eh=Qi,Sh=128,kc=127;function Qi(r,n){var t=0,n=n||0,s=0,i=n,o,a=r.length;do{if(i>=a)throw Qi.bytes=0,new RangeError("Could not decode varint");o=r[i++],t+=s<28?(o&kc)<<s:(o&kc)*Math.pow(2,s),s+=7}while(o>=Sh);return Qi.bytes=i-n,t}var Ah=Math.pow(2,7),Bh=Math.pow(2,14),_h=Math.pow(2,21),Ih=Math.pow(2,28),Th=Math.pow(2,35),kh=Math.pow(2,42),Ch=Math.pow(2,49),Nh=Math.pow(2,56),Lh=Math.pow(2,63),Rh=function(r){return r<Ah?1:r<Bh?2:r<_h?3:r<Ih?4:r<Th?5:r<kh?6:r<Ch?7:r<Nh?8:r<Lh?9:10},Uh={encode:bh,decode:Eh,encodingLength:Rh},Dh=Uh,qr=Dh;function zr(r,e=0){return[qr.decode(r,e),qr.decode.bytes]}function pr(r,e,t=0){return qr.encode(r,e,t),e}function gr(r){return qr.encodingLength(r)}function Ze(r,e){let t=e.byteLength,n=gr(r),s=n+gr(t),i=new Uint8Array(s+t);return pr(r,i,0),pr(t,i,n),i.set(e,s),new mr(r,t,e,i)}function ze(r){let e=dt(r),[t,n]=zr(e),[s,i]=zr(e.subarray(n)),o=e.subarray(n+i);if(o.byteLength!==s)throw new Error("Incorrect length");return new mr(t,s,o,e)}function Nc(r,e){if(r===e)return!0;{let t=e;return r.code===t.code&&r.size===t.size&&t.bytes instanceof Uint8Array&&Ec(r.bytes,t.bytes)}}var mr=class{code;size;digest;bytes;constructor(e,t,n,s){this.code=e,this.size=t,this.digest=n,this.bytes=s}};function Lc(r,e){let{bytes:t,version:n}=r;switch(n){case 0:return Mh(t,eo(r),e??ee.encoder);default:return Ph(t,eo(r),e??pt.encoder)}}var Rc=new WeakMap;function eo(r){let e=Rc.get(r);if(e==null){let t=new Map;return Rc.set(r,t),t}return e}var pe=class r{code;version;multihash;bytes;"/";constructor(e,t,n,s){this.code=t,this.version=e,this.multihash=n,this.bytes=s,this["/"]=s}get asCID(){return this}get byteOffset(){return this.bytes.byteOffset}get byteLength(){return this.bytes.byteLength}toV0(){switch(this.version){case 0:return this;case 1:{let{code:e,multihash:t}=this;if(e!==$r)throw new Error("Cannot convert a non dag-pb CID to CIDv0");if(t.code!==Vh)throw new Error("Cannot convert non sha2-256 multihash CID to CIDv0");return r.createV0(t)}default:throw Error(`Can not convert CID version ${this.version} to version 0. This is a bug please report`)}}toV1(){switch(this.version){case 0:{let{code:e,digest:t}=this.multihash,n=Ze(e,t);return r.createV1(this.code,n)}case 1:return this;default:throw Error(`Can not convert CID version ${this.version} to version 1. This is a bug please report`)}}equals(e){return r.equals(this,e)}static equals(e,t){let n=t;return n!=null&&e.code===n.code&&e.version===n.version&&Nc(e.multihash,n.multihash)}toString(e){return Lc(this,e)}toJSON(){return{"/":Lc(this)}}link(){return this}[Symbol.toStringTag]="CID";[Symbol.for("nodejs.util.inspect.custom")](){return`CID(${this.toString()})`}static asCID(e){if(e==null)return null;let t=e;if(t instanceof r)return t;if(t["/"]!=null&&t["/"]===t.bytes||t.asCID===t){let{version:n,code:s,multihash:i,bytes:o}=t;return new r(n,s,i,o??Uc(n,s,i.bytes))}else if(t[Hh]===!0){let{version:n,multihash:s,code:i}=t,o=ze(s);return r.create(n,i,o)}else return null}static create(e,t,n){if(typeof t!="number")throw new Error("String codecs are no longer supported");if(!(n.bytes instanceof Uint8Array))throw new Error("Invalid digest");switch(e){case 0:{if(t!==$r)throw new Error(`Version 0 CID must use dag-pb (code: ${$r}) block encoding`);return new r(e,t,n,n.bytes)}case 1:{let s=Uc(e,t,n.bytes);return new r(e,t,n,s)}default:throw new Error("Invalid version")}}static createV0(e){return r.create(0,$r,e)}static createV1(e,t){return r.create(1,e,t)}static decode(e){let[t,n]=r.decodeFirst(e);if(n.length!==0)throw new Error("Incorrect length");return t}static decodeFirst(e){let t=r.inspectBytes(e),n=t.size-t.multihashSize,s=dt(e.subarray(n,n+t.multihashSize));if(s.byteLength!==t.multihashSize)throw new Error("Incorrect length");let i=s.subarray(t.multihashSize-t.digestSize),o=new mr(t.multihashCode,t.digestSize,i,s);return[t.version===0?r.createV0(o):r.createV1(t.codec,o),e.subarray(t.size)]}static inspectBytes(e){let t=0,n=()=>{let[u,m]=zr(e.subarray(t));return t+=m,u},s=n(),i=$r;if(s===18?(s=0,t=0):i=n(),s!==0&&s!==1)throw new RangeError(`Invalid CID version ${s}`);let o=t,a=n(),c=n(),h=t+c,f=h-o;return{version:s,codec:i,multihashCode:a,digestSize:c,multihashSize:f,size:h}}static parse(e,t){let[n,s]=Oh(e,t),i=r.decode(s);if(i.version===0&&e[0]!=="Q")throw Error("Version 0 CID string must not include multibase prefix");return eo(i).set(n,e),i}};function Oh(r,e){switch(r[0]){case"Q":{let t=e??ee;return[ee.prefix,t.decode(`${ee.prefix}${r}`)]}case ee.prefix:{let t=e??ee;return[ee.prefix,t.decode(r)]}case pt.prefix:{let t=e??pt;return[pt.prefix,t.decode(r)]}case Kr.prefix:{let t=e??Kr;return[Kr.prefix,t.decode(r)]}default:{if(e==null)throw Error("To parse non base32, base36 or base58btc encoded CID multibase decoder must be provided");return[r[0],e.decode(r)]}}}function Mh(r,e,t){let{prefix:n}=t;if(n!==ee.prefix)throw Error(`Cannot string encode V0 in ${t.name} encoding`);let s=e.get(n);if(s==null){let i=t.encode(r).slice(1);return e.set(n,i),i}else return s}function Ph(r,e,t){let{prefix:n}=t,s=e.get(n);if(s==null){let i=t.encode(r);return e.set(n,i),i}else return s}var $r=112,Vh=18;function Uc(r,e,t){let n=gr(r),s=n+gr(e),i=new Uint8Array(s+t.byteLength);return pr(r,i,0),pr(e,i,n),i.set(t,s),i}var Hh=Symbol.for("@ipld/js-cid/CID");var to={};ke(to,{identity:()=>gt});var Dc=0,Fh="identity",Oc=dt;function Kh(r){return Ze(Dc,Oc(r))}var gt={code:Dc,name:Fh,encode:Oc,digest:Kh};function ge(r,e){if(r===e)return!0;if(r.byteLength!==e.byteLength)return!1;for(let t=0;t<r.byteLength;t++)if(r[t]!==e[t])return!1;return!0}function Mc(r){if(!Number.isSafeInteger(r)||r<0)throw new Error("positive integer expected, got "+r)}function qh(r){return r instanceof Uint8Array||ArrayBuffer.isView(r)&&r.constructor.name==="Uint8Array"}function yr(r,...e){if(!qh(r))throw new Error("Uint8Array expected");if(e.length>0&&!e.includes(r.length))throw new Error("Uint8Array expected of length "+e+", got length="+r.length)}function Pc(r){if(typeof r!="function"||typeof r.create!="function")throw new Error("Hash should be wrapped by utils.wrapConstructor");Mc(r.outputLen),Mc(r.blockLen)}function br(r,e=!0){if(r.destroyed)throw new Error("Hash instance has been destroyed");if(e&&r.finished)throw new Error("Hash#digest() has already been called")}function Vc(r,e){yr(r);let t=e.outputLen;if(r.length<t)throw new Error("digestInto() expects output buffer of length at least "+t)}var Yt=typeof globalThis=="object"&&"crypto"in globalThis?globalThis.crypto:void 0;var Nn=r=>new DataView(r.buffer,r.byteOffset,r.byteLength),je=(r,e)=>r<<32-e|r>>>e;function Hc(r){if(typeof r!="string")throw new Error("utf8ToBytes expected string, got "+typeof r);return new Uint8Array(new TextEncoder().encode(r))}function Gr(r){return typeof r=="string"&&(r=Hc(r)),yr(r),r}function ro(...r){let e=0;for(let n=0;n<r.length;n++){let s=r[n];yr(s),e+=s.length}let t=new Uint8Array(e);for(let n=0,s=0;n<r.length;n++){let i=r[n];t.set(i,s),s+=i.length}return t}var wr=class{clone(){return this._cloneInto()}};function Ln(r){let e=n=>r().update(Gr(n)).digest(),t=r();return e.outputLen=t.outputLen,e.blockLen=t.blockLen,e.create=()=>r(),e}function Rn(r=32){if(Yt&&typeof Yt.getRandomValues=="function")return Yt.getRandomValues(new Uint8Array(r));if(Yt&&typeof Yt.randomBytes=="function")return Yt.randomBytes(r);throw new Error("crypto.getRandomValues must be defined")}function zh(r,e,t,n){if(typeof r.setBigUint64=="function")return r.setBigUint64(e,t,n);let s=BigInt(32),i=BigInt(4294967295),o=Number(t>>s&i),a=Number(t&i),c=n?4:0,h=n?0:4;r.setUint32(e+c,o,n),r.setUint32(e+h,a,n)}var Fc=(r,e,t)=>r&e^~r&t,Kc=(r,e,t)=>r&e^r&t^e&t,xr=class extends wr{constructor(e,t,n,s){super(),this.blockLen=e,this.outputLen=t,this.padOffset=n,this.isLE=s,this.finished=!1,this.length=0,this.pos=0,this.destroyed=!1,this.buffer=new Uint8Array(e),this.view=Nn(this.buffer)}update(e){br(this);let{view:t,buffer:n,blockLen:s}=this;e=Gr(e);let i=e.length;for(let o=0;o<i;){let a=Math.min(s-this.pos,i-o);if(a===s){let c=Nn(e);for(;s<=i-o;o+=s)this.process(c,o);continue}n.set(e.subarray(o,o+a),this.pos),this.pos+=a,o+=a,this.pos===s&&(this.process(t,0),this.pos=0)}return this.length+=e.length,this.roundClean(),this}digestInto(e){br(this),Vc(e,this),this.finished=!0;let{buffer:t,view:n,blockLen:s,isLE:i}=this,{pos:o}=this;t[o++]=128,this.buffer.subarray(o).fill(0),this.padOffset>s-o&&(this.process(n,0),o=0);for(let u=o;u<s;u++)t[u]=0;zh(n,s-8,BigInt(this.length*8),i),this.process(n,0);let a=Nn(e),c=this.outputLen;if(c%4)throw new Error("_sha2: outputLen should be aligned to 32bit");let h=c/4,f=this.get();if(h>f.length)throw new Error("_sha2: outputLen bigger than state");for(let u=0;u<h;u++)a.setUint32(4*u,f[u],i)}digest(){let{buffer:e,outputLen:t}=this;this.digestInto(e);let n=e.slice(0,t);return this.destroy(),n}_cloneInto(e){e||(e=new this.constructor),e.set(...this.get());let{blockLen:t,buffer:n,length:s,finished:i,destroyed:o,pos:a}=this;return e.length=s,e.pos=a,e.finished=i,e.destroyed=o,s%t&&e.buffer.set(n),e}};var Un=BigInt(4294967295),no=BigInt(32);function qc(r,e=!1){return e?{h:Number(r&Un),l:Number(r>>no&Un)}:{h:Number(r>>no&Un)|0,l:Number(r&Un)|0}}function $h(r,e=!1){let t=new Uint32Array(r.length),n=new Uint32Array(r.length);for(let s=0;s<r.length;s++){let{h:i,l:o}=qc(r[s],e);[t[s],n[s]]=[i,o]}return[t,n]}var Gh=(r,e)=>BigInt(r>>>0)<<no|BigInt(e>>>0),Wh=(r,e,t)=>r>>>t,Zh=(r,e,t)=>r<<32-t|e>>>t,jh=(r,e,t)=>r>>>t|e<<32-t,Yh=(r,e,t)=>r<<32-t|e>>>t,Xh=(r,e,t)=>r<<64-t|e>>>t-32,Jh=(r,e,t)=>r>>>t-32|e<<64-t,Qh=(r,e)=>e,ed=(r,e)=>r,td=(r,e,t)=>r<<t|e>>>32-t,rd=(r,e,t)=>e<<t|r>>>32-t,nd=(r,e,t)=>e<<t-32|r>>>64-t,sd=(r,e,t)=>r<<t-32|e>>>64-t;function id(r,e,t,n){let s=(e>>>0)+(n>>>0);return{h:r+t+(s/2**32|0)|0,l:s|0}}var od=(r,e,t)=>(r>>>0)+(e>>>0)+(t>>>0),ad=(r,e,t,n)=>e+t+n+(r/2**32|0)|0,cd=(r,e,t,n)=>(r>>>0)+(e>>>0)+(t>>>0)+(n>>>0),ld=(r,e,t,n,s)=>e+t+n+s+(r/2**32|0)|0,ud=(r,e,t,n,s)=>(r>>>0)+(e>>>0)+(t>>>0)+(n>>>0)+(s>>>0),fd=(r,e,t,n,s,i)=>e+t+n+s+i+(r/2**32|0)|0;var hd={fromBig:qc,split:$h,toBig:Gh,shrSH:Wh,shrSL:Zh,rotrSH:jh,rotrSL:Yh,rotrBH:Xh,rotrBL:Jh,rotr32H:Qh,rotr32L:ed,rotlSH:td,rotlSL:rd,rotlBH:nd,rotlBL:sd,add:id,add3L:od,add3H:ad,add4L:cd,add4H:ld,add5H:fd,add5L:ud},M=hd;var[dd,pd]=M.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))),Nt=new Uint32Array(80),Lt=new Uint32Array(80),so=class extends xr{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:e,Al:t,Bh:n,Bl:s,Ch:i,Cl:o,Dh:a,Dl:c,Eh:h,El:f,Fh:u,Fl:m,Gh:l,Gl:d,Hh:p,Hl:y}=this;return[e,t,n,s,i,o,a,c,h,f,u,m,l,d,p,y]}set(e,t,n,s,i,o,a,c,h,f,u,m,l,d,p,y){this.Ah=e|0,this.Al=t|0,this.Bh=n|0,this.Bl=s|0,this.Ch=i|0,this.Cl=o|0,this.Dh=a|0,this.Dl=c|0,this.Eh=h|0,this.El=f|0,this.Fh=u|0,this.Fl=m|0,this.Gh=l|0,this.Gl=d|0,this.Hh=p|0,this.Hl=y|0}process(e,t){for(let g=0;g<16;g++,t+=4)Nt[g]=e.getUint32(t),Lt[g]=e.getUint32(t+=4);for(let g=16;g<80;g++){let E=Nt[g-15]|0,A=Lt[g-15]|0,_=M.rotrSH(E,A,1)^M.rotrSH(E,A,8)^M.shrSH(E,A,7),x=M.rotrSL(E,A,1)^M.rotrSL(E,A,8)^M.shrSL(E,A,7),I=Nt[g-2]|0,C=Lt[g-2]|0,j=M.rotrSH(I,C,19)^M.rotrBH(I,C,61)^M.shrSH(I,C,6),V=M.rotrSL(I,C,19)^M.rotrBL(I,C,61)^M.shrSL(I,C,6),P=M.add4L(x,V,Lt[g-7],Lt[g-16]),R=M.add4H(P,_,j,Nt[g-7],Nt[g-16]);Nt[g]=R|0,Lt[g]=P|0}let{Ah:n,Al:s,Bh:i,Bl:o,Ch:a,Cl:c,Dh:h,Dl:f,Eh:u,El:m,Fh:l,Fl:d,Gh:p,Gl:y,Hh:b,Hl:w}=this;for(let g=0;g<80;g++){let E=M.rotrSH(u,m,14)^M.rotrSH(u,m,18)^M.rotrBH(u,m,41),A=M.rotrSL(u,m,14)^M.rotrSL(u,m,18)^M.rotrBL(u,m,41),_=u&l^~u&p,x=m&d^~m&y,I=M.add5L(w,A,x,pd[g],Lt[g]),C=M.add5H(I,b,E,_,dd[g],Nt[g]),j=I|0,V=M.rotrSH(n,s,28)^M.rotrBH(n,s,34)^M.rotrBH(n,s,39),P=M.rotrSL(n,s,28)^M.rotrBL(n,s,34)^M.rotrBL(n,s,39),R=n&i^n&a^i&a,T=s&o^s&c^o&c;b=p|0,w=y|0,p=l|0,y=d|0,l=u|0,d=m|0,{h:u,l:m}=M.add(h|0,f|0,C|0,j|0),h=a|0,f=c|0,a=i|0,c=o|0,i=n|0,o=s|0;let L=M.add3L(j,P,T);n=M.add3H(L,C,V,R),s=L|0}({h:n,l:s}=M.add(this.Ah|0,this.Al|0,n|0,s|0)),{h:i,l:o}=M.add(this.Bh|0,this.Bl|0,i|0,o|0),{h:a,l:c}=M.add(this.Ch|0,this.Cl|0,a|0,c|0),{h,l:f}=M.add(this.Dh|0,this.Dl|0,h|0,f|0),{h:u,l:m}=M.add(this.Eh|0,this.El|0,u|0,m|0),{h:l,l:d}=M.add(this.Fh|0,this.Fl|0,l|0,d|0),{h:p,l:y}=M.add(this.Gh|0,this.Gl|0,p|0,y|0),{h:b,l:w}=M.add(this.Hh|0,this.Hl|0,b|0,w|0),this.set(n,s,i,o,a,c,h,f,u,m,l,d,p,y,b,w)}roundClean(){Nt.fill(0),Lt.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 zc=Ln(()=>new so);var Mn={};ke(Mn,{aInRange:()=>Re,abool:()=>Ye,abytes:()=>vr,bitGet:()=>xd,bitLen:()=>co,bitMask:()=>Zr,bitSet:()=>vd,bytesToHex:()=>yt,bytesToNumberBE:()=>bt,bytesToNumberLE:()=>Ut,concatBytes:()=>wt,createHmacDrbg:()=>lo,ensureBytes:()=>oe,equalBytes:()=>bd,hexToBytes:()=>Jt,hexToNumber:()=>ao,inRange:()=>Wr,isBytes:()=>Rt,memoized:()=>er,notImplemented:()=>Sd,numberToBytesBE:()=>Dt,numberToBytesLE:()=>Qt,numberToHexUnpadded:()=>Xt,numberToVarBytesBE:()=>yd,utf8ToBytes:()=>wd,validateObject:()=>ot});var Dn=BigInt(0),On=BigInt(1),gd=BigInt(2);function Rt(r){return r instanceof Uint8Array||ArrayBuffer.isView(r)&&r.constructor.name==="Uint8Array"}function vr(r){if(!Rt(r))throw new Error("Uint8Array expected")}function Ye(r,e){if(typeof e!="boolean")throw new Error(r+" boolean expected, got "+e)}var md=Array.from({length:256},(r,e)=>e.toString(16).padStart(2,"0"));function yt(r){vr(r);let e="";for(let t=0;t<r.length;t++)e+=md[r[t]];return e}function Xt(r){let e=r.toString(16);return e.length&1?"0"+e:e}function ao(r){if(typeof r!="string")throw new Error("hex string expected, got "+typeof r);return r===""?Dn:BigInt("0x"+r)}var mt={_0:48,_9:57,A:65,F:70,a:97,f:102};function $c(r){if(r>=mt._0&&r<=mt._9)return r-mt._0;if(r>=mt.A&&r<=mt.F)return r-(mt.A-10);if(r>=mt.a&&r<=mt.f)return r-(mt.a-10)}function Jt(r){if(typeof r!="string")throw new Error("hex string expected, got "+typeof r);let e=r.length,t=e/2;if(e%2)throw new Error("hex string expected, got unpadded hex of length "+e);let n=new Uint8Array(t);for(let s=0,i=0;s<t;s++,i+=2){let o=$c(r.charCodeAt(i)),a=$c(r.charCodeAt(i+1));if(o===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[s]=o*16+a}return n}function bt(r){return ao(yt(r))}function Ut(r){return vr(r),ao(yt(Uint8Array.from(r).reverse()))}function Dt(r,e){return Jt(r.toString(16).padStart(e*2,"0"))}function Qt(r,e){return Dt(r,e).reverse()}function yd(r){return Jt(Xt(r))}function oe(r,e,t){let n;if(typeof e=="string")try{n=Jt(e)}catch(i){throw new Error(r+" must be hex string or Uint8Array, cause: "+i)}else if(Rt(e))n=Uint8Array.from(e);else throw new Error(r+" must be hex string or Uint8Array");let s=n.length;if(typeof t=="number"&&s!==t)throw new Error(r+" of length "+t+" expected, got "+s);return n}function wt(...r){let e=0;for(let n=0;n<r.length;n++){let s=r[n];vr(s),e+=s.length}let t=new Uint8Array(e);for(let n=0,s=0;n<r.length;n++){let i=r[n];t.set(i,s),s+=i.length}return t}function bd(r,e){if(r.length!==e.length)return!1;let t=0;for(let n=0;n<r.length;n++)t|=r[n]^e[n];return t===0}function wd(r){if(typeof r!="string")throw new Error("string expected");return new Uint8Array(new TextEncoder().encode(r))}var io=r=>typeof r=="bigint"&&Dn<=r;function Wr(r,e,t){return io(r)&&io(e)&&io(t)&&e<=r&&r<t}function Re(r,e,t,n){if(!Wr(e,t,n))throw new Error("expected valid "+r+": "+t+" <= n < "+n+", got "+e)}function co(r){let e;for(e=0;r>Dn;r>>=On,e+=1);return e}function xd(r,e){return r>>BigInt(e)&On}function vd(r,e,t){return r|(t?On:Dn)<<BigInt(e)}var Zr=r=>(gd<<BigInt(r-1))-On,oo=r=>new Uint8Array(r),Gc=r=>Uint8Array.from(r);function lo(r,e,t){if(typeof r!="number"||r<2)throw new Error("hashLen must be a number");if(typeof e!="number"||e<2)throw new Error("qByteLen must be a number");if(typeof t!="function")throw new Error("hmacFn must be a function");let n=oo(r),s=oo(r),i=0,o=()=>{n.fill(1),s.fill(0),i=0},a=(...u)=>t(s,n,...u),c=(u=oo())=>{s=a(Gc([0]),u),n=a(),u.length!==0&&(s=a(Gc([1]),u),n=a())},h=()=>{if(i++>=1e3)throw new Error("drbg: tried 1000 values");let u=0,m=[];for(;u<e;){n=a();let l=n.slice();m.push(l),u+=n.length}return wt(...m)};return(u,m)=>{o(),c(u);let l;for(;!(l=m(h()));)c();return o(),l}}var Ed={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"||Rt(r),isSafeInteger:r=>Number.isSafeInteger(r),array:r=>Array.isArray(r),field:(r,e)=>e.Fp.isValid(r),hash:r=>typeof r=="function"&&Number.isSafeInteger(r.outputLen)};function ot(r,e,t={}){let n=(s,i,o)=>{let a=Ed[i];if(typeof a!="function")throw new Error("invalid validator function");let c=r[s];if(!(o&&c===void 0)&&!a(c,r))throw new Error("param "+String(s)+" is invalid. Expected "+i+", got "+c)};for(let[s,i]of Object.entries(e))n(s,i,!1);for(let[s,i]of Object.entries(t))n(s,i,!0);return r}var Sd=()=>{throw new Error("not implemented")};function er(r){let e=new WeakMap;return(t,...n)=>{let s=e.get(t);if(s!==void 0)return s;let i=r(t,...n);return e.set(t,i),i}}var ue=BigInt(0),se=BigInt(1),tr=BigInt(2),Ad=BigInt(3),uo=BigInt(4),Wc=BigInt(5),Zc=BigInt(8),Bd=BigInt(9),_d=BigInt(16);function J(r,e){let t=r%e;return t>=ue?t:e+t}function Id(r,e,t){if(e<ue)throw new Error("invalid exponent, negatives unsupported");if(t<=ue)throw new Error("invalid modulus");if(t===se)return ue;let n=se;for(;e>ue;)e&se&&(n=n*r%t),r=r*r%t,e>>=se;return n}function ie(r,e,t){let n=r;for(;e-- >ue;)n*=n,n%=t;return n}function Pn(r,e){if(r===ue)throw new Error("invert: expected non-zero number");if(e<=ue)throw new Error("invert: expected positive modulus, got "+e);let t=J(r,e),n=e,s=ue,i=se,o=se,a=ue;for(;t!==ue;){let h=n/t,f=n%t,u=s-o*h,m=i-a*h;n=t,t=f,s=o,i=a,o=u,a=m}if(n!==se)throw new Error("invert: does not exist");return J(s,e)}function Td(r){let e=(r-se)/tr,t,n,s;for(t=r-se,n=0;t%tr===ue;t/=tr,n++);for(s=tr;s<r&&Id(s,e,r)!==r-se;s++)if(s>1e3)throw new Error("Cannot find square root: likely non-prime P");if(n===1){let o=(r+se)/uo;return function(c,h){let f=c.pow(h,o);if(!c.eql(c.sqr(f),h))throw new Error("Cannot find square root");return f}}let i=(t+se)/tr;return function(a,c){if(a.pow(c,e)===a.neg(a.ONE))throw new Error("Cannot find square root");let h=n,f=a.pow(a.mul(a.ONE,s),t),u=a.pow(c,i),m=a.pow(c,t);for(;!a.eql(m,a.ONE);){if(a.eql(m,a.ZERO))return a.ZERO;let l=1;for(let p=a.sqr(m);l<h&&!a.eql(p,a.ONE);l++)p=a.sqr(p);let d=a.pow(f,se<<BigInt(h-l-1));f=a.sqr(d),u=a.mul(u,d),m=a.mul(m,f),h=l}return u}}function kd(r){if(r%uo===Ad){let e=(r+se)/uo;return function(n,s){let i=n.pow(s,e);if(!n.eql(n.sqr(i),s))throw new Error("Cannot find square root");return i}}if(r%Zc===Wc){let e=(r-Wc)/Zc;return function(n,s){let i=n.mul(s,tr),o=n.pow(i,e),a=n.mul(s,o),c=n.mul(n.mul(a,tr),o),h=n.mul(a,n.sub(c,n.ONE));if(!n.eql(n.sqr(h),s))throw new Error("Cannot find square root");return h}}return r%_d,Td(r)}var jc=(r,e)=>(J(r,e)&se)===se,Cd=["create","isValid","is0","neg","inv","sqrt","sqr","eql","add","sub","mul","pow","div","addN","subN","mulN","sqrN"];function fo(r){let e={ORDER:"bigint",MASK:"bigint",BYTES:"isSafeInteger",BITS:"isSafeInteger"},t=Cd.reduce((n,s)=>(n[s]="function",n),e);return ot(r,t)}function Nd(r,e,t){if(t<ue)throw new Error("invalid exponent, negatives unsupported");if(t===ue)return r.ONE;if(t===se)return e;let n=r.ONE,s=e;for(;t>ue;)t&se&&(n=r.mul(n,s)),s=r.sqr(s),t>>=se;return n}function Ld(r,e){let t=new Array(e.length),n=e.reduce((i,o,a)=>r.is0(o)?i:(t[a]=i,r.mul(i,o)),r.ONE),s=r.inv(n);return e.reduceRight((i,o,a)=>r.is0(o)?i:(t[a]=r.mul(i,t[a]),r.mul(i,o)),s),t}function ho(r,e){let t=e!==void 0?e:r.toString(2).length,n=Math.ceil(t/8);return{nBitLength:t,nByteLength:n}}function Ot(r,e,t=!1,n={}){if(r<=ue)throw new Error("invalid field: expected ORDER > 0, got "+r);let{nBitLength:s,nByteLength:i}=ho(r,e);if(i>2048)throw new Error("invalid field: expected ORDER of <= 2048 bytes");let o,a=Object.freeze({ORDER:r,BITS:s,BYTES:i,MASK:Zr(s),ZERO:ue,ONE:se,create:c=>J(c,r),isValid:c=>{if(typeof c!="bigint")throw new Error("invalid field element: expected bigint, got "+typeof c);return ue<=c&&c<r},is0:c=>c===ue,isOdd:c=>(c&se)===se,neg:c=>J(-c,r),eql:(c,h)=>c===h,sqr:c=>J(c*c,r),add:(c,h)=>J(c+h,r),sub:(c,h)=>J(c-h,r),mul:(c,h)=>J(c*h,r),pow:(c,h)=>Nd(a,c,h),div:(c,h)=>J(c*Pn(h,r),r),sqrN:c=>c*c,addN:(c,h)=>c+h,subN:(c,h)=>c-h,mulN:(c,h)=>c*h,inv:c=>Pn(c,r),sqrt:n.sqrt||(c=>(o||(o=kd(r)),o(a,c))),invertBatch:c=>Ld(a,c),cmov:(c,h,f)=>f?h:c,toBytes:c=>t?Qt(c,i):Dt(c,i),fromBytes:c=>{if(c.length!==i)throw new Error("Field.fromBytes: expected "+i+" bytes, got "+c.length);return t?Ut(c):bt(c)}});return Object.freeze(a)}function Yc(r){if(typeof r!="bigint")throw new Error("field order must be bigint");let e=r.toString(2).length;return Math.ceil(e/8)}function po(r){let e=Yc(r);return e+Math.ceil(e/2)}function Xc(r,e,t=!1){let n=r.length,s=Yc(e),i=po(e);if(n<16||n<i||n>1024)throw new Error("expected "+i+"-1024 bytes of input, got "+n);let o=t?bt(r):Ut(r),a=J(o,e-se)+se;return t?Qt(a,s):Dt(a,s)}var Jc=BigInt(0),Vn=BigInt(1);function go(r,e){let t=e.negate();return r?t:e}function Qc(r,e){if(!Number.isSafeInteger(r)||r<=0||r>e)throw new Error("invalid window size, expected [1.."+e+"], got W="+r)}function mo(r,e){Qc(r,e);let t=Math.ceil(e/r)+1,n=2**(r-1);return{windows:t,windowSize:n}}function Ud(r,e){if(!Array.isArray(r))throw new Error("array expected");r.forEach((t,n)=>{if(!(t instanceof e))throw new Error("invalid point at index "+n)})}function Dd(r,e){if(!Array.isArray(r))throw new Error("array of scalars expected");r.forEach((t,n)=>{if(!e.isValid(t))throw new Error("invalid scalar at index "+n)})}var yo=new WeakMap,el=new WeakMap;function bo(r){return el.get(r)||1}function Hn(r,e){return{constTimeNegate:go,hasPrecomputes(t){return bo(t)!==1},unsafeLadder(t,n,s=r.ZERO){let i=t;for(;n>Jc;)n&Vn&&(s=s.add(i)),i=i.double(),n>>=Vn;return s},precomputeWindow(t,n){let{windows:s,windowSize:i}=mo(n,e),o=[],a=t,c=a;for(let h=0;h<s;h++){c=a,o.push(c);for(let f=1;f<i;f++)c=c.add(a),o.push(c);a=c.double()}return o},wNAF(t,n,s){let{windows:i,windowSize:o}=mo(t,e),a=r.ZERO,c=r.BASE,h=BigInt(2**t-1),f=2**t,u=BigInt(t);for(let m=0;m<i;m++){let l=m*o,d=Number(s&h);s>>=u,d>o&&(d-=f,s+=Vn);let p=l,y=l+Math.abs(d)-1,b=m%2!==0,w=d<0;d===0?c=c.add(go(b,n[p])):a=a.add(go(w,n[y]))}return{p:a,f:c}},wNAFUnsafe(t,n,s,i=r.ZERO){let{windows:o,windowSize:a}=mo(t,e),c=BigInt(2**t-1),h=2**t,f=BigInt(t);for(let u=0;u<o;u++){let m=u*a;if(s===Jc)break;let l=Number(s&c);if(s>>=f,l>a&&(l-=h,s+=Vn),l===0)continue;let d=n[m+Math.abs(l)-1];l<0&&(d=d.negate()),i=i.add(d)}return i},getPrecomputes(t,n,s){let i=yo.get(n);return i||(i=this.precomputeWindow(n,t),t!==1&&yo.set(n,s(i))),i},wNAFCached(t,n,s){let i=bo(t);return this.wNAF(i,this.getPrecomputes(i,t,s),n)},wNAFCachedUnsafe(t,n,s,i){let o=bo(t);return o===1?this.unsafeLadder(t,n,i):this.wNAFUnsafe(o,this.getPrecomputes(o,t,s),n,i)},setWindowSize(t,n){Qc(n,e),el.set(t,n),yo.delete(t)}}}function Fn(r,e,t,n){if(Ud(t,r),Dd(n,e),t.length!==n.length)throw new Error("arrays of points and scalars must have equal length");let s=r.ZERO,i=co(BigInt(t.length)),o=i>12?i-3:i>4?i-2:i?2:1,a=(1<<o)-1,c=new Array(a+1).fill(s),h=Math.floor((e.BITS-1)/o)*o,f=s;for(let u=h;u>=0;u-=o){c.fill(s);for(let l=0;l<n.length;l++){let d=n[l],p=Number(d>>BigInt(u)&BigInt(a));c[p]=c[p].add(t[l])}let m=s;for(let l=c.length-1,d=s;l>0;l--)d=d.add(c[l]),m=m.add(d);if(f=f.add(m),u!==0)for(let l=0;l<o;l++)f=f.double()}return f}function jr(r){return fo(r.Fp),ot(r,{n:"bigint",h:"bigint",Gx:"field",Gy:"field"},{nBitLength:"isSafeInteger",nByteLength:"isSafeInteger"}),Object.freeze({...ho(r.n,r.nBitLength),...r,p:r.Fp.ORDER})}var Xe=BigInt(0),Ue=BigInt(1),Kn=BigInt(2),Od=BigInt(8),Md={zip215:!0};function Pd(r){let e=jr(r);return ot(r,{hash:"function",a:"bigint",d:"bigint",randomBytes:"function"},{adjustScalarBytes:"function",domain:"function",uvRatio:"function",mapToCurve:"function"}),Object.freeze({...e})}function tl(r){let e=Pd(r),{Fp:t,n,prehash:s,hash:i,randomBytes:o,nByteLength:a,h:c}=e,h=Kn<<BigInt(a*8)-Ue,f=t.create,u=Ot(e.n,e.nBitLength),m=e.uvRatio||((S,v)=>{try{return{isValid:!0,value:t.sqrt(S*t.inv(v))}}catch{return{isValid:!1,value:Xe}}}),l=e.adjustScalarBytes||(S=>S),d=e.domain||((S,v,B)=>{if(Ye("phflag",B),v.length||B)throw new Error("Contexts/pre-hash are not supported");return S});function p(S,v){Re("coordinate "+S,v,Xe,h)}function y(S){if(!(S instanceof g))throw new Error("ExtendedPoint expected")}let b=er((S,v)=>{let{ex:B,ey:N,ez:U}=S,D=S.is0();v==null&&(v=D?Od:t.inv(U));let H=f(B*v),$=f(N*v),O=f(U*v);if(D)return{x:Xe,y:Ue};if(O!==Ue)throw new Error("invZ was invalid");return{x:H,y:$}}),w=er(S=>{let{a:v,d:B}=e;if(S.is0())throw new Error("bad point: ZERO");let{ex:N,ey:U,ez:D,et:H}=S,$=f(N*N),O=f(U*U),Y=f(D*D),re=f(Y*Y),he=f($*v),de=f(Y*f(he+O)),ye=f(re+f(B*f($*O)));if(de!==ye)throw new Error("bad point: equation left != right (1)");let xe=f(N*U),Ne=f(D*H);if(xe!==Ne)throw new Error("bad point: equation left != right (2)");return!0});class g{constructor(v,B,N,U){this.ex=v,this.ey=B,this.ez=N,this.et=U,p("x",v),p("y",B),p("z",N),p("t",U),Object.freeze(this)}get x(){return this.toAffine().x}get y(){return this.toAffine().y}static fromAffine(v){if(v instanceof g)throw new Error("extended point not allowed");let{x:B,y:N}=v||{};return p("x",B),p("y",N),new g(B,N,Ue,f(B*N))}static normalizeZ(v){let B=t.invertBatch(v.map(N=>N.ez));return v.map((N,U)=>N.toAffine(B[U])).map(g.fromAffine)}static msm(v,B){return Fn(g,u,v,B)}_setWindowSize(v){_.setWindowSize(this,v)}assertValidity(){w(this)}equals(v){y(v);let{ex:B,ey:N,ez:U}=this,{ex:D,ey:H,ez:$}=v,O=f(B*$),Y=f(D*U),re=f(N*$),he=f(H*U);return O===Y&&re===he}is0(){return this.equals(g.ZERO)}negate(){return new g(f(-this.ex),this.ey,this.ez,f(-this.et))}double(){let{a:v}=e,{ex:B,ey:N,ez:U}=this,D=f(B*B),H=f(N*N),$=f(Kn*f(U*U)),O=f(v*D),Y=B+N,re=f(f(Y*Y)-D-H),he=O+H,de=he-$,ye=O-H,xe=f(re*de),Ne=f(he*ye),Te=f(re*ye),st=f(de*he);return new g(xe,Ne,st,Te)}add(v){y(v);let{a:B,d:N}=e,{ex:U,ey:D,ez:H,et:$}=this,{ex:O,ey:Y,ez:re,et:he}=v;if(B===BigInt(-1)){let oc=f((D-U)*(Y+O)),ac=f((D+U)*(Y-O)),Ki=f(ac-oc);if(Ki===Xe)return this.double();let cc=f(H*Kn*he),lc=f($*Kn*re),uc=lc+cc,fc=ac+oc,hc=lc-cc,Wf=f(uc*Ki),Zf=f(fc*hc),jf=f(uc*hc),Yf=f(Ki*fc);return new g(Wf,Zf,Yf,jf)}let de=f(U*O),ye=f(D*Y),xe=f($*N*he),Ne=f(H*re),Te=f((U+D)*(O+Y)-de-ye),st=Ne-xe,ft=Ne+xe,Hr=f(ye-B*de),qf=f(Te*st),zf=f(ft*Hr),$f=f(Te*Hr),Gf=f(st*ft);return new g(qf,zf,Gf,$f)}subtract(v){return this.add(v.negate())}wNAF(v){return _.wNAFCached(this,v,g.normalizeZ)}multiply(v){let B=v;Re("scalar",B,Ue,n);let{p:N,f:U}=this.wNAF(B);return g.normalizeZ([N,U])[0]}multiplyUnsafe(v,B=g.ZERO){let N=v;return Re("scalar",N,Xe,n),N===Xe?A:this.is0()||N===Ue?this:_.wNAFCachedUnsafe(this,N,g.normalizeZ,B)}isSmallOrder(){return this.multiplyUnsafe(c).is0()}isTorsionFree(){return _.unsafeLadder(this,n).is0()}toAffine(v){return b(this,v)}clearCofactor(){let{h:v}=e;return v===Ue?this:this.multiplyUnsafe(v)}static fromHex(v,B=!1){let{d:N,a:U}=e,D=t.BYTES;v=oe("pointHex",v,D),Ye("zip215",B);let H=v.slice(),$=v[D-1];H[D-1]=$&-129;let O=Ut(H),Y=B?h:t.ORDER;Re("pointHex.y",O,Xe,Y);let re=f(O*O),he=f(re-Ue),de=f(N*re-U),{isValid:ye,value:xe}=m(he,de);if(!ye)throw new Error("Point.fromHex: invalid y coordinate");let Ne=(xe&Ue)===Ue,Te=($&128)!==0;if(!B&&xe===Xe&&Te)throw new Error("Point.fromHex: x=0 and x_0=1");return Te!==Ne&&(xe=f(-xe)),g.fromAffine({x:xe,y:O})}static fromPrivateKey(v){return C(v).point}toRawBytes(){let{x:v,y:B}=this.toAffine(),N=Qt(B,t.BYTES);return N[N.length-1]|=v&Ue?128:0,N}toHex(){return yt(this.toRawBytes())}}g.BASE=new g(e.Gx,e.Gy,Ue,f(e.Gx*e.Gy)),g.ZERO=new g(Xe,Ue,Ue,Xe);let{BASE:E,ZERO:A}=g,_=Hn(g,a*8);function x(S){return J(S,n)}function I(S){return x(Ut(S))}function C(S){let v=t.BYTES;S=oe("private key",S,v);let B=oe("hashed private key",i(S),2*v),N=l(B.slice(0,v)),U=B.slice(v,2*v),D=I(N),H=E.multiply(D),$=H.toRawBytes();return{head:N,prefix:U,scalar:D,point:H,pointBytes:$}}function j(S){return C(S).pointBytes}function V(S=new Uint8Array,...v){let B=wt(...v);return I(i(d(B,oe("context",S),!!s)))}function P(S,v,B={}){S=oe("message",S),s&&(S=s(S));let{prefix:N,scalar:U,pointBytes:D}=C(v),H=V(B.context,N,S),$=E.multiply(H).toRawBytes(),O=V(B.context,$,D,S),Y=x(H+O*U);Re("signature.s",Y,Xe,n);let re=wt($,Qt(Y,t.BYTES));return oe("result",re,t.BYTES*2)}let R=Md;function T(S,v,B,N=R){let{context:U,zip215:D}=N,H=t.BYTES;S=oe("signature",S,2*H),v=oe("message",v),B=oe("publicKey",B,H),D!==void 0&&Ye("zip215",D),s&&(v=s(v));let $=Ut(S.slice(H,2*H)),O,Y,re;try{O=g.fromHex(B,D),Y=g.fromHex(S.slice(0,H),D),re=E.multiplyUnsafe($)}catch{return!1}if(!D&&O.isSmallOrder())return!1;let he=V(U,Y.toRawBytes(),O.toRawBytes(),v);return Y.add(O.multiplyUnsafe(he)).subtract(re).clearCofactor().equals(g.ZERO)}return E._setWindowSize(8),{CURVE:e,getPublicKey:j,sign:P,verify:T,ExtendedPoint:g,utils:{getExtendedPublicKey:C,randomPrivateKey:()=>o(t.BYTES),precompute(S=8,v=g.BASE){return v._setWindowSize(S),v.multiply(BigInt(3)),v}}}}var wo=BigInt("57896044618658097711785492504343953926634992332820282019728792003956564819949"),rl=BigInt("19681161376707505956807079304988542015446066515923890162744021073123829784752"),vm=BigInt(0),Vd=BigInt(1),nl=BigInt(2),Em=BigInt(3),Hd=BigInt(5),Fd=BigInt(8);function Kd(r){let e=BigInt(10),t=BigInt(20),n=BigInt(40),s=BigInt(80),i=wo,a=r*r%i*r%i,c=ie(a,nl,i)*a%i,h=ie(c,Vd,i)*r%i,f=ie(h,Hd,i)*h%i,u=ie(f,e,i)*f%i,m=ie(u,t,i)*u%i,l=ie(m,n,i)*m%i,d=ie(l,s,i)*l%i,p=ie(d,s,i)*l%i,y=ie(p,e,i)*f%i;return{pow_p_5_8:ie(y,nl,i)*r%i,b2:a}}function qd(r){return r[0]&=248,r[31]&=127,r[31]|=64,r}function zd(r,e){let t=wo,n=J(e*e*e,t),s=J(n*n*e,t),i=Kd(r*s).pow_p_5_8,o=J(r*n*i,t),a=J(e*o*o,t),c=o,h=J(o*rl,t),f=a===r,u=a===J(-r,t),m=a===J(-r*rl,t);return f&&(o=c),(u||m)&&(o=h),jc(o,t)&&(o=J(-o,t)),{isValid:f||u,value:o}}var $d=Ot(wo,void 0,!0),Gd={a:BigInt(-1),d:BigInt("37095705934669439343138083508754565189542113879843219016388785533085940283555"),Fp:$d,n:BigInt("7237005577332262213973186563042994240857116359379907606001950938285454250989"),h:Fd,Gx:BigInt("15112221349535400772501151409588531511454012693041857206046113283949847762202"),Gy:BigInt("46316835694926478169428394003475163141307993866256225615783033603165251855960"),hash:zc,randomBytes:Rn,adjustScalarBytes:qd,uvRatio:zd},sl=tl(Gd);var qn=32;function il(r,e,t){return sl.verify(e,t instanceof Uint8Array?t:t.subarray(),r)}var zn=class{type="Ed25519";raw;constructor(e){this.raw=xo(e,qn)}toMultihash(){return gt.digest(Mt(this))}toCID(){return pe.createV1(114,this.toMultihash())}toString(){return ee.encode(this.toMultihash().bytes).substring(1)}equals(e){return e==null||!(e.raw instanceof Uint8Array)?!1:ge(this.raw,e.raw)}verify(e,t){return il(this.raw,t,e)}};function vo(r){return r=xo(r,qn),new zn(r)}function xo(r,e){if(r=Uint8Array.from(r??[]),r.length!==e)throw new ve(`Key must be a Uint8Array of length ${e}, got ${r.length}`);return r}function ae(r=0){return new Uint8Array(r)}function De(r=0){return new Uint8Array(r)}var Zd=Math.pow(2,7),jd=Math.pow(2,14),Yd=Math.pow(2,21),Eo=Math.pow(2,28),So=Math.pow(2,35),Ao=Math.pow(2,42),Bo=Math.pow(2,49),Z=128,Ee=127;function Se(r){if(r<Zd)return 1;if(r<jd)return 2;if(r<Yd)return 3;if(r<Eo)return 4;if(r<So)return 5;if(r<Ao)return 6;if(r<Bo)return 7;if(Number.MAX_SAFE_INTEGER!=null&&r>Number.MAX_SAFE_INTEGER)throw new RangeError("Could not encode varint");return 8}function _o(r,e,t=0){switch(Se(r)){case 8:e[t++]=r&255|Z,r/=128;case 7:e[t++]=r&255|Z,r/=128;case 6:e[t++]=r&255|Z,r/=128;case 5:e[t++]=r&255|Z,r/=128;case 4:e[t++]=r&255|Z,r>>>=7;case 3:e[t++]=r&255|Z,r>>>=7;case 2:e[t++]=r&255|Z,r>>>=7;case 1:{e[t++]=r&255,r>>>=7;break}default:throw new Error("unreachable")}return e}function Xd(r,e,t=0){switch(Se(r)){case 8:e.set(t++,r&255|Z),r/=128;case 7:e.set(t++,r&255|Z),r/=128;case 6:e.set(t++,r&255|Z),r/=128;case 5:e.set(t++,r&255|Z),r/=128;case 4:e.set(t++,r&255|Z),r>>>=7;case 3:e.set(t++,r&255|Z),r>>>=7;case 2:e.set(t++,r&255|Z),r>>>=7;case 1:{e.set(t++,r&255),r>>>=7;break}default:throw new Error("unreachable")}return e}function Io(r,e){let t=r[e],n=0;if(n+=t&Ee,t<Z||(t=r[e+1],n+=(t&Ee)<<7,t<Z)||(t=r[e+2],n+=(t&Ee)<<14,t<Z)||(t=r[e+3],n+=(t&Ee)<<21,t<Z)||(t=r[e+4],n+=(t&Ee)*Eo,t<Z)||(t=r[e+5],n+=(t&Ee)*So,t<Z)||(t=r[e+6],n+=(t&Ee)*Ao,t<Z)||(t=r[e+7],n+=(t&Ee)*Bo,t<Z))return n;throw new RangeError("Could not decode varint")}function Jd(r,e){let t=r.get(e),n=0;if(n+=t&Ee,t<Z||(t=r.get(e+1),n+=(t&Ee)<<7,t<Z)||(t=r.get(e+2),n+=(t&Ee)<<14,t<Z)||(t=r.get(e+3),n+=(t&Ee)<<21,t<Z)||(t=r.get(e+4),n+=(t&Ee)*Eo,t<Z)||(t=r.get(e+5),n+=(t&Ee)*So,t<Z)||(t=r.get(e+6),n+=(t&Ee)*Ao,t<Z)||(t=r.get(e+7),n+=(t&Ee)*Bo,t<Z))return n;throw new RangeError("Could not decode varint")}function $e(r,e,t=0){return e==null&&(e=De(Se(r))),e instanceof Uint8Array?_o(r,e,t):Xd(r,e,t)}function xt(r,e=0){return r instanceof Uint8Array?Io(r,e):Jd(r,e)}var To=new Float32Array([-0]),Pt=new Uint8Array(To.buffer);function al(r,e,t){To[0]=r,e[t]=Pt[0],e[t+1]=Pt[1],e[t+2]=Pt[2],e[t+3]=Pt[3]}function cl(r,e){return Pt[0]=r[e],Pt[1]=r[e+1],Pt[2]=r[e+2],Pt[3]=r[e+3],To[0]}var ko=new Float64Array([-0]),Ae=new Uint8Array(ko.buffer);function ll(r,e,t){ko[0]=r,e[t]=Ae[0],e[t+1]=Ae[1],e[t+2]=Ae[2],e[t+3]=Ae[3],e[t+4]=Ae[4],e[t+5]=Ae[5],e[t+6]=Ae[6],e[t+7]=Ae[7]}function ul(r,e){return Ae[0]=r[e],Ae[1]=r[e+1],Ae[2]=r[e+2],Ae[3]=r[e+3],Ae[4]=r[e+4],Ae[5]=r[e+5],Ae[6]=r[e+6],Ae[7]=r[e+7],ko[0]}var Qd=BigInt(Number.MAX_SAFE_INTEGER),ep=BigInt(Number.MIN_SAFE_INTEGER),He=class r{lo;hi;constructor(e,t){this.lo=e|0,this.hi=t|0}toNumber(e=!1){if(!e&&this.hi>>>31>0){let t=~this.lo+1>>>0,n=~this.hi>>>0;return t===0&&(n=n+1>>>0),-(t+n*4294967296)}return this.lo+this.hi*4294967296}toBigInt(e=!1){if(e)return BigInt(this.lo>>>0)+(BigInt(this.hi>>>0)<<32n);if(this.hi>>>31){let t=~this.lo+1>>>0,n=~this.hi>>>0;return t===0&&(n=n+1>>>0),-(BigInt(t)+(BigInt(n)<<32n))}return BigInt(this.lo>>>0)+(BigInt(this.hi>>>0)<<32n)}toString(e=!1){return this.toBigInt(e).toString()}zzEncode(){let e=this.hi>>31;return this.hi=((this.hi<<1|this.lo>>>31)^e)>>>0,this.lo=(this.lo<<1^e)>>>0,this}zzDecode(){let e=-(this.lo&1);return this.lo=((this.lo>>>1|this.hi<<31)^e)>>>0,this.hi=(this.hi>>>1^e)>>>0,this}length(){let e=this.lo,t=(this.lo>>>28|this.hi<<4)>>>0,n=this.hi>>>24;return n===0?t===0?e<16384?e<128?1:2:e<2097152?3:4:t<16384?t<128?5:6:t<2097152?7:8:n<128?9:10}static fromBigInt(e){if(e===0n)return rr;if(e<Qd&&e>ep)return this.fromNumber(Number(e));let t=e<0n;t&&(e=-e);let n=e>>32n,s=e-(n<<32n);return t&&(n=~n|0n,s=~s|0n,++s>fl&&(s=0n,++n>fl&&(n=0n))),new r(Number(s),Number(n))}static fromNumber(e){if(e===0)return rr;let t=e<0;t&&(e=-e);let n=e>>>0,s=(e-n)/4294967296>>>0;return t&&(s=~s>>>0,n=~n>>>0,++n>4294967295&&(n=0,++s>4294967295&&(s=0))),new r(n,s)}static from(e){return typeof e=="number"?r.fromNumber(e):typeof e=="bigint"?r.fromBigInt(e):typeof e=="string"?r.fromBigInt(BigInt(e)):e.low!=null||e.high!=null?new r(e.low>>>0,e.high>>>0):rr}},rr=new He(0,0);rr.toBigInt=function(){return 0n};rr.zzEncode=rr.zzDecode=function(){return this};rr.length=function(){return 1};var fl=4294967296n;function hl(r){let e=0,t=0;for(let n=0;n<r.length;++n)t=r.charCodeAt(n),t<128?e+=1:t<2048?e+=2:(t&64512)===55296&&(r.charCodeAt(n+1)&64512)===56320?(++n,e+=4):e+=3;return e}function dl(r,e,t){if(t-e<1)return"";let s,i=[],o=0,a;for(;e<t;)a=r[e++],a<128?i[o++]=a:a>191&&a<224?i[o++]=(a&31)<<6|r[e++]&63:a>239&&a<365?(a=((a&7)<<18|(r[e++]&63)<<12|(r[e++]&63)<<6|r[e++]&63)-65536,i[o++]=55296+(a>>10),i[o++]=56320+(a&1023)):i[o++]=(a&15)<<12|(r[e++]&63)<<6|r[e++]&63,o>8191&&((s??(s=[])).push(String.fromCharCode.apply(String,i)),o=0);return s!=null?(o>0&&s.push(String.fromCharCode.apply(String,i.slice(0,o))),s.join("")):String.fromCharCode.apply(String,i.slice(0,o))}function Co(r,e,t){let n=t,s,i;for(let o=0;o<r.length;++o)s=r.charCodeAt(o),s<128?e[t++]=s:s<2048?(e[t++]=s>>6|192,e[t++]=s&63|128):(s&64512)===55296&&((i=r.charCodeAt(o+1))&64512)===56320?(s=65536+((s&1023)<<10)+(i&1023),++o,e[t++]=s>>18|240,e[t++]=s>>12&63|128,e[t++]=s>>6&63|128,e[t++]=s&63|128):(e[t++]=s>>12|224,e[t++]=s>>6&63|128,e[t++]=s&63|128);return t-n}function Je(r,e){return RangeError(`index out of range: ${r.pos} + ${e??1} > ${r.len}`)}function Gn(r,e){return(r[e-4]|r[e-3]<<8|r[e-2]<<16|r[e-1]<<24)>>>0}var No=class{buf;pos;len;_slice=Uint8Array.prototype.subarray;constructor(e){this.buf=e,this.pos=0,this.len=e.length}uint32(){let e=4294967295;if(e=(this.buf[this.pos]&127)>>>0,this.buf[this.pos++]<128||(e=(e|(this.buf[this.pos]&127)<<7)>>>0,this.buf[this.pos++]<128)||(e=(e|(this.buf[this.pos]&127)<<14)>>>0,this.buf[this.pos++]<128)||(e=(e|(this.buf[this.pos]&127)<<21)>>>0,this.buf[this.pos++]<128)||(e=(e|(this.buf[this.pos]&15)<<28)>>>0,this.buf[this.pos++]<128))return e;if((this.pos+=5)>this.len)throw this.pos=this.len,Je(this,10);return e}int32(){return this.uint32()|0}sint32(){let e=this.uint32();return e>>>1^-(e&1)|0}bool(){return this.uint32()!==0}fixed32(){if(this.pos+4>this.len)throw Je(this,4);return Gn(this.buf,this.pos+=4)}sfixed32(){if(this.pos+4>this.len)throw Je(this,4);return Gn(this.buf,this.pos+=4)|0}float(){if(this.pos+4>this.len)throw Je(this,4);let e=cl(this.buf,this.pos);return this.pos+=4,e}double(){if(this.pos+8>this.len)throw Je(this,4);let e=ul(this.buf,this.pos);return this.pos+=8,e}bytes(){let e=this.uint32(),t=this.pos,n=this.pos+e;if(n>this.len)throw Je(this,e);return this.pos+=e,t===n?new Uint8Array(0):this.buf.subarray(t,n)}string(){let e=this.bytes();return dl(e,0,e.length)}skip(e){if(typeof e=="number"){if(this.pos+e>this.len)throw Je(this,e);this.pos+=e}else do if(this.pos>=this.len)throw Je(this);while(this.buf[this.pos++]&128);return this}skipType(e){switch(e){case 0:this.skip();break;case 1:this.skip(8);break;case 2:this.skip(this.uint32());break;case 3:for(;(e=this.uint32()&7)!==4;)this.skipType(e);break;case 5:this.skip(4);break;default:throw Error(`invalid wire type ${e} at offset ${this.pos}`)}return this}readLongVarint(){let e=new He(0,0),t=0;if(this.len-this.pos>4){for(;t<4;++t)if(e.lo=(e.lo|(this.buf[this.pos]&127)<<t*7)>>>0,this.buf[this.pos++]<128)return e;if(e.lo=(e.lo|(this.buf[this.pos]&127)<<28)>>>0,e.hi=(e.hi|(this.buf[this.pos]&127)>>4)>>>0,this.buf[this.pos++]<128)return e;t=0}else{for(;t<3;++t){if(this.pos>=this.len)throw Je(this);if(e.lo=(e.lo|(this.buf[this.pos]&127)<<t*7)>>>0,this.buf[this.pos++]<128)return e}return e.lo=(e.lo|(this.buf[this.pos++]&127)<<t*7)>>>0,e}if(this.len-this.pos>4){for(;t<5;++t)if(e.hi=(e.hi|(this.buf[this.pos]&127)<<t*7+3)>>>0,this.buf[this.pos++]<128)return e}else for(;t<5;++t){if(this.pos>=this.len)throw Je(this);if(e.hi=(e.hi|(this.buf[this.pos]&127)<<t*7+3)>>>0,this.buf[this.pos++]<128)return e}throw Error("invalid varint encoding")}readFixed64(){if(this.pos+8>this.len)throw Je(this,8);let e=Gn(this.buf,this.pos+=4),t=Gn(this.buf,this.pos+=4);return new He(e,t)}int64(){return this.readLongVarint().toBigInt()}int64Number(){return this.readLongVarint().toNumber()}int64String(){return this.readLongVarint().toString()}uint64(){return this.readLongVarint().toBigInt(!0)}uint64Number(){let e=Io(this.buf,this.pos);return this.pos+=Se(e),e}uint64String(){return this.readLongVarint().toString(!0)}sint64(){return this.readLongVarint().zzDecode().toBigInt()}sint64Number(){return this.readLongVarint().zzDecode().toNumber()}sint64String(){return this.readLongVarint().zzDecode().toString()}fixed64(){return this.readFixed64().toBigInt()}fixed64Number(){return this.readFixed64().toNumber()}fixed64String(){return this.readFixed64().toString()}sfixed64(){return this.readFixed64().toBigInt()}sfixed64Number(){return this.readFixed64().toNumber()}sfixed64String(){return this.readFixed64().toString()}};function Lo(r){return new No(r instanceof Uint8Array?r:r.subarray())}function Oe(r,e,t){let n=Lo(r);return e.decode(n,void 0,t)}var Ro={};ke(Ro,{base10:()=>tp});var tp=Ct({prefix:"9",name:"base10",alphabet:"0123456789"});var Uo={};ke(Uo,{base16:()=>rp,base16upper:()=>np});var rp=le({prefix:"f",name:"base16",alphabet:"0123456789abcdef",bitsPerChar:4}),np=le({prefix:"F",name:"base16upper",alphabet:"0123456789ABCDEF",bitsPerChar:4});var Do={};ke(Do,{base2:()=>sp});var sp=le({prefix:"0",name:"base2",alphabet:"01",bitsPerChar:1});var Oo={};ke(Oo,{base256emoji:()=>lp});var gl=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}"),ip=gl.reduce((r,e,t)=>(r[t]=e,r),[]),op=gl.reduce((r,e,t)=>{let n=e.codePointAt(0);if(n==null)throw new Error(`Invalid character: ${e}`);return r[n]=t,r},[]);function ap(r){return r.reduce((e,t)=>(e+=ip[t],e),"")}function cp(r){let e=[];for(let t of r){let n=t.codePointAt(0);if(n==null)throw new Error(`Invalid character: ${t}`);let s=op[n];if(s==null)throw new Error(`Non-base256emoji character: ${t}`);e.push(s)}return new Uint8Array(e)}var lp=dr({prefix:"\u{1F680}",name:"base256emoji",encode:ap,decode:cp});var Po={};ke(Po,{base64:()=>up,base64pad:()=>fp,base64url:()=>Mo,base64urlpad:()=>hp});var up=le({prefix:"m",name:"base64",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/",bitsPerChar:6}),fp=le({prefix:"M",name:"base64pad",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/=",bitsPerChar:6}),Mo=le({prefix:"u",name:"base64url",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789-_",bitsPerChar:6}),hp=le({prefix:"U",name:"base64urlpad",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789-_=",bitsPerChar:6});var Vo={};ke(Vo,{base8:()=>dp});var dp=le({prefix:"7",name:"base8",alphabet:"01234567",bitsPerChar:3});var Ho={};ke(Ho,{identity:()=>pp});var pp=dr({prefix:"\0",name:"identity",encode:r=>Ac(r),decode:r=>Sc(r)});var sy=new TextEncoder,iy=new TextDecoder;var qo={};ke(qo,{sha256:()=>Er,sha512:()=>yp});function Ko({name:r,code:e,encode:t}){return new Fo(r,e,t)}var Fo=class{name;code;encode;constructor(e,t,n){this.name=e,this.code=t,this.encode=n}digest(e){if(e instanceof Uint8Array){let t=this.encode(e);return t instanceof Uint8Array?Ze(this.code,t):t.then(n=>Ze(this.code,n))}else throw Error("Unknown type, must be binary type")}};function yl(r){return async e=>new Uint8Array(await crypto.subtle.digest(r,e))}var Er=Ko({name:"sha2-256",code:18,encode:yl("SHA-256")}),yp=Ko({name:"sha2-512",code:19,encode:yl("SHA-512")});var Yr={...Ho,...Do,...Vo,...Ro,...Uo,...Xi,...Ji,...Yi,...Po,...Oo},yy={...qo,...to};function wl(r,e,t,n){return{name:r,prefix:e,encoder:{name:r,prefix:e,encode:t},decoder:{decode:n}}}var bl=wl("utf8","u",r=>"u"+new TextDecoder("utf8").decode(r),r=>new TextEncoder().encode(r.substring(1))),zo=wl("ascii","a",r=>{let e="a";for(let t=0;t<r.length;t++)e+=String.fromCharCode(r[t]);return e},r=>{r=r.substring(1);let e=De(r.length);for(let t=0;t<r.length;t++)e[t]=r.charCodeAt(t);return e}),bp={utf8:bl,"utf-8":bl,hex:Yr.base16,latin1:zo,ascii:zo,binary:zo,...Yr},Wn=bp;function G(r,e="utf8"){let t=Wn[e];if(t==null)throw new Error(`Unsupported encoding "${e}"`);return t.decoder.decode(`${t.prefix}${r}`)}function $o(r){let e=r??8192,t=e>>>1,n,s=e;return function(o){if(o<1||o>t)return De(o);s+o>e&&(n=De(e),s=0);let a=n.subarray(s,s+=o);return s&7&&(s=(s|7)+1),a}}var nr=class{fn;len;next;val;constructor(e,t,n){this.fn=e,this.len=t,this.next=void 0,this.val=n}};function Go(){}var Zo=class{head;tail;len;next;constructor(e){this.head=e.head,this.tail=e.tail,this.len=e.len,this.next=e.states}},wp=$o();function xp(r){return globalThis.Buffer!=null?De(r):wp(r)}var Jr=class{len;head;tail;states;constructor(){this.len=0,this.head=new nr(Go,0,0),this.tail=this.head,this.states=null}_push(e,t,n){return this.tail=this.tail.next=new nr(e,t,n),this.len+=t,this}uint32(e){return this.len+=(this.tail=this.tail.next=new jo((e=e>>>0)<128?1:e<16384?2:e<2097152?3:e<268435456?4:5,e)).len,this}int32(e){return e<0?this._push(Zn,10,He.fromNumber(e)):this.uint32(e)}sint32(e){return this.uint32((e<<1^e>>31)>>>0)}uint64(e){let t=He.fromBigInt(e);return this._push(Zn,t.length(),t)}uint64Number(e){return this._push(_o,Se(e),e)}uint64String(e){return this.uint64(BigInt(e))}int64(e){return this.uint64(e)}int64Number(e){return this.uint64Number(e)}int64String(e){return this.uint64String(e)}sint64(e){let t=He.fromBigInt(e).zzEncode();return this._push(Zn,t.length(),t)}sint64Number(e){let t=He.fromNumber(e).zzEncode();return this._push(Zn,t.length(),t)}sint64String(e){return this.sint64(BigInt(e))}bool(e){return this._push(Wo,1,e?1:0)}fixed32(e){return this._push(Xr,4,e>>>0)}sfixed32(e){return this.fixed32(e)}fixed64(e){let t=He.fromBigInt(e);return this._push(Xr,4,t.lo)._push(Xr,4,t.hi)}fixed64Number(e){let t=He.fromNumber(e);return this._push(Xr,4,t.lo)._push(Xr,4,t.hi)}fixed64String(e){return this.fixed64(BigInt(e))}sfixed64(e){return this.fixed64(e)}sfixed64Number(e){return this.fixed64Number(e)}sfixed64String(e){return this.fixed64String(e)}float(e){return this._push(al,4,e)}double(e){return this._push(ll,8,e)}bytes(e){let t=e.length>>>0;return t===0?this._push(Wo,1,0):this.uint32(t)._push(Ep,t,e)}string(e){let t=hl(e);return t!==0?this.uint32(t)._push(Co,t,e):this._push(Wo,1,0)}fork(){return this.states=new Zo(this),this.head=this.tail=new nr(Go,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 nr(Go,0,0),this.len=0),this}ldelim(){let e=this.head,t=this.tail,n=this.len;return this.reset().uint32(n),n!==0&&(this.tail.next=e.next,this.tail=t,this.len+=n),this}finish(){let e=this.head.next,t=xp(this.len),n=0;for(;e!=null;)e.fn(e.val,t,n),n+=e.len,e=e.next;return t}};function Wo(r,e,t){e[t]=r&255}function vp(r,e,t){for(;r>127;)e[t++]=r&127|128,r>>>=7;e[t]=r}var jo=class extends nr{next;constructor(e,t){super(vp,e,t),this.next=void 0}};function Zn(r,e,t){for(;r.hi!==0;)e[t++]=r.lo&127|128,r.lo=(r.lo>>>7|r.hi<<25)>>>0,r.hi>>>=7;for(;r.lo>127;)e[t++]=r.lo&127|128,r.lo=r.lo>>>7;e[t++]=r.lo}function Xr(r,e,t){e[t]=r&255,e[t+1]=r>>>8&255,e[t+2]=r>>>16&255,e[t+3]=r>>>24}function Ep(r,e,t){e.set(r,t)}globalThis.Buffer!=null&&(Jr.prototype.bytes=function(r){let e=r.length>>>0;return this.uint32(e),e>0&&this._push(Sp,e,r),this},Jr.prototype.string=function(r){let e=globalThis.Buffer.byteLength(r);return this.uint32(e),e>0&&this._push(Ap,e,r),this});function Sp(r,e,t){e.set(r,t)}function Ap(r,e,t){r.length<40?Co(r,e,t):e.utf8Write!=null?e.utf8Write(r,t):e.set(G(r),t)}function Yo(){return new Jr}function Me(r,e){let t=Yo();return e.encode(r,t,{lengthDelimited:!1}),t.finish()}var Sr;(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"})(Sr||(Sr={}));function jn(r,e,t,n){return{name:r,type:e,encode:t,decode:n}}function sr(r){function e(s){if(r[s.toString()]==null)throw new Error("Invalid enum value");return r[s]}let t=function(i,o){let a=e(i);o.int32(a)},n=function(i){let o=i.int32();return e(o)};return jn("enum",Sr.VARINT,t,n)}function Pe(r,e){return jn("message",Sr.LENGTH_DELIMITED,r,e)}var Qr=class extends Error{code="ERR_MAX_LENGTH";name="MaxLengthError"};var fe;(function(r){r.RSA="RSA",r.Ed25519="Ed25519",r.secp256k1="secp256k1"})(fe||(fe={}));var Xo;(function(r){r[r.RSA=0]="RSA",r[r.Ed25519=1]="Ed25519",r[r.secp256k1=2]="secp256k1"})(Xo||(Xo={}));(function(r){r.codec=()=>sr(Xo)})(fe||(fe={}));var at;(function(r){let e;r.codec=()=>(e==null&&(e=Pe((t,n,s={})=>{s.lengthDelimited!==!1&&n.fork(),t.Type!=null&&(n.uint32(8),fe.codec().encode(t.Type,n)),t.Data!=null&&(n.uint32(18),n.bytes(t.Data)),s.lengthDelimited!==!1&&n.ldelim()},(t,n,s={})=>{let i={},o=n==null?t.len:t.pos+n;for(;t.pos<o;){let a=t.uint32();switch(a>>>3){case 1:{i.Type=fe.codec().decode(t);break}case 2:{i.Data=t.bytes();break}default:{t.skipType(a&7);break}}}return i})),e),r.encode=t=>Me(t,r.codec()),r.decode=(t,n)=>Oe(t,r.codec(),n)})(at||(at={}));var Jo;(function(r){let e;r.codec=()=>(e==null&&(e=Pe((t,n,s={})=>{s.lengthDelimited!==!1&&n.fork(),t.Type!=null&&(n.uint32(8),fe.codec().encode(t.Type,n)),t.Data!=null&&(n.uint32(18),n.bytes(t.Data)),s.lengthDelimited!==!1&&n.ldelim()},(t,n,s={})=>{let i={},o=n==null?t.len:t.pos+n;for(;t.pos<o;){let a=t.uint32();switch(a>>>3){case 1:{i.Type=fe.codec().decode(t);break}case 2:{i.Data=t.bytes();break}default:{t.skipType(a&7);break}}}return i})),e),r.encode=t=>Me(t,r.codec()),r.decode=(t,n)=>Oe(t,r.codec(),n)})(Jo||(Jo={}));var un={};ke(un,{MAX_RSA_KEY_SIZE:()=>zs,generateRSAKeyPair:()=>xu,jwkToJWKKeyPair:()=>vu,jwkToPkcs1:()=>qp,jwkToPkix:()=>ua,jwkToRSAPrivateKey:()=>wu,pkcs1ToJwk:()=>mu,pkcs1ToRSAPrivateKey:()=>bu,pkixToJwk:()=>yu,pkixToRSAPublicKey:()=>fa});function Bp(r){return r instanceof Uint8Array||ArrayBuffer.isView(r)&&r.constructor.name==="Uint8Array"}function Qo(r,...e){if(!Bp(r))throw new Error("Uint8Array expected");if(e.length>0&&!e.includes(r.length))throw new Error("Uint8Array expected of length "+e+", got length="+r.length)}function ea(r,e=!0){if(r.destroyed)throw new Error("Hash instance has been destroyed");if(e&&r.finished)throw new Error("Hash#digest() has already been called")}function vl(r,e){Qo(r);let t=e.outputLen;if(r.length<t)throw new Error("digestInto() expects output buffer of length at least "+t)}var Xn=r=>new DataView(r.buffer,r.byteOffset,r.byteLength),Qe=(r,e)=>r<<32-e|r>>>e;function _p(r){if(typeof r!="string")throw new Error("utf8ToBytes expected string, got "+typeof r);return new Uint8Array(new TextEncoder().encode(r))}function ta(r){return typeof r=="string"&&(r=_p(r)),Qo(r),r}var Yn=class{clone(){return this._cloneInto()}};function El(r){let e=n=>r().update(ta(n)).digest(),t=r();return e.outputLen=t.outputLen,e.blockLen=t.blockLen,e.create=()=>r(),e}function Ip(r,e,t,n){if(typeof r.setBigUint64=="function")return r.setBigUint64(e,t,n);let s=BigInt(32),i=BigInt(4294967295),o=Number(t>>s&i),a=Number(t&i),c=n?4:0,h=n?0:4;r.setUint32(e+c,o,n),r.setUint32(e+h,a,n)}var Sl=(r,e,t)=>r&e^~r&t,Al=(r,e,t)=>r&e^r&t^e&t,Jn=class extends Yn{constructor(e,t,n,s){super(),this.blockLen=e,this.outputLen=t,this.padOffset=n,this.isLE=s,this.finished=!1,this.length=0,this.pos=0,this.destroyed=!1,this.buffer=new Uint8Array(e),this.view=Xn(this.buffer)}update(e){ea(this);let{view:t,buffer:n,blockLen:s}=this;e=ta(e);let i=e.length;for(let o=0;o<i;){let a=Math.min(s-this.pos,i-o);if(a===s){let c=Xn(e);for(;s<=i-o;o+=s)this.process(c,o);continue}n.set(e.subarray(o,o+a),this.pos),this.pos+=a,o+=a,this.pos===s&&(this.process(t,0),this.pos=0)}return this.length+=e.length,this.roundClean(),this}digestInto(e){ea(this),vl(e,this),this.finished=!0;let{buffer:t,view:n,blockLen:s,isLE:i}=this,{pos:o}=this;t[o++]=128,this.buffer.subarray(o).fill(0),this.padOffset>s-o&&(this.process(n,0),o=0);for(let u=o;u<s;u++)t[u]=0;Ip(n,s-8,BigInt(this.length*8),i),this.process(n,0);let a=Xn(e),c=this.outputLen;if(c%4)throw new Error("_sha2: outputLen should be aligned to 32bit");let h=c/4,f=this.get();if(h>f.length)throw new Error("_sha2: outputLen bigger than state");for(let u=0;u<h;u++)a.setUint32(4*u,f[u],i)}digest(){let{buffer:e,outputLen:t}=this;this.digestInto(e);let n=e.slice(0,t);return this.destroy(),n}_cloneInto(e){e||(e=new this.constructor),e.set(...this.get());let{blockLen:t,buffer:n,length:s,finished:i,destroyed:o,pos:a}=this;return e.length=s,e.pos=a,e.finished=i,e.destroyed=o,s%t&&e.buffer.set(n),e}};var Tp=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]),Vt=new Uint32Array([1779033703,3144134277,1013904242,2773480762,1359893119,2600822924,528734635,1541459225]),Ht=new Uint32Array(64),ra=class extends Jn{constructor(){super(64,32,8,!1),this.A=Vt[0]|0,this.B=Vt[1]|0,this.C=Vt[2]|0,this.D=Vt[3]|0,this.E=Vt[4]|0,this.F=Vt[5]|0,this.G=Vt[6]|0,this.H=Vt[7]|0}get(){let{A:e,B:t,C:n,D:s,E:i,F:o,G:a,H:c}=this;return[e,t,n,s,i,o,a,c]}set(e,t,n,s,i,o,a,c){this.A=e|0,this.B=t|0,this.C=n|0,this.D=s|0,this.E=i|0,this.F=o|0,this.G=a|0,this.H=c|0}process(e,t){for(let u=0;u<16;u++,t+=4)Ht[u]=e.getUint32(t,!1);for(let u=16;u<64;u++){let m=Ht[u-15],l=Ht[u-2],d=Qe(m,7)^Qe(m,18)^m>>>3,p=Qe(l,17)^Qe(l,19)^l>>>10;Ht[u]=p+Ht[u-7]+d+Ht[u-16]|0}let{A:n,B:s,C:i,D:o,E:a,F:c,G:h,H:f}=this;for(let u=0;u<64;u++){let m=Qe(a,6)^Qe(a,11)^Qe(a,25),l=f+m+Sl(a,c,h)+Tp[u]+Ht[u]|0,p=(Qe(n,2)^Qe(n,13)^Qe(n,22))+Al(n,s,i)|0;f=h,h=c,c=a,a=o+l|0,o=i,i=s,s=n,n=l+p|0}n=n+this.A|0,s=s+this.B|0,i=i+this.C|0,o=o+this.D|0,a=a+this.E|0,c=c+this.F|0,h=h+this.G|0,f=f+this.H|0,this.set(n,s,i,o,a,c,h,f)}roundClean(){Ht.fill(0)}destroy(){this.set(0,0,0,0,0,0,0,0),this.buffer.fill(0)}};var Qn=El(()=>new ra);var z=pc(Bl());function ir(r,e){let t=0;if(r.length===1)return r[0];for(let n=r.length-1;n>=0;n--)t+=r[r.length-1-n]*Math.pow(2,e*n);return t}function Ft(r,e,t=-1){let n=t,s=r,i=0,o=Math.pow(2,e);for(let a=1;a<8;a++){if(r<o){let c;if(n<0)c=new ArrayBuffer(a),i=a;else{if(n<a)return new ArrayBuffer(0);c=new ArrayBuffer(n),i=n}let h=new Uint8Array(c);for(let f=a-1;f>=0;f--){let u=Math.pow(2,f*e);h[i-f-1]=Math.floor(s/u),s-=h[i-f-1]*u}return c}o*=Math.pow(2,e)}return new ArrayBuffer(0)}function rs(...r){let e=0,t=0;for(let i of r)e+=i.length;let n=new ArrayBuffer(e),s=new Uint8Array(n);for(let i of r)s.set(i,t),t+=i.length;return s}function sa(){let r=new Uint8Array(this.valueHex);if(this.valueHex.byteLength>=2){let a=r[0]===255&&r[1]&128,c=r[0]===0&&(r[1]&128)===0;(a||c)&&this.warnings.push("Needlessly long format")}let e=new ArrayBuffer(this.valueHex.byteLength),t=new Uint8Array(e);for(let a=0;a<this.valueHex.byteLength;a++)t[a]=0;t[0]=r[0]&128;let n=ir(t,8),s=new ArrayBuffer(this.valueHex.byteLength),i=new Uint8Array(s);for(let a=0;a<this.valueHex.byteLength;a++)i[a]=r[a];return i[0]&=127,ir(i,8)-n}function _l(r){let e=r<0?r*-1:r,t=128;for(let n=1;n<8;n++){if(e<=t){if(r<0){let o=t-e,a=Ft(o,8,n),c=new Uint8Array(a);return c[0]|=128,a}let s=Ft(e,8,n),i=new Uint8Array(s);if(i[0]&128){let o=s.slice(0),a=new Uint8Array(o);s=new ArrayBuffer(s.byteLength+1),i=new Uint8Array(s);for(let c=0;c<o.byteLength;c++)i[c+1]=a[c];i[0]=0}return s}t*=Math.pow(2,8)}return new ArrayBuffer(0)}function Il(r,e){if(r.byteLength!==e.byteLength)return!1;let t=new Uint8Array(r),n=new Uint8Array(e);for(let s=0;s<t.length;s++)if(t[s]!==n[s])return!1;return!0}function Ve(r,e){let t=r.toString(10);if(e<t.length)return"";let n=e-t.length,s=new Array(n);for(let o=0;o<n;o++)s[o]="0";return s.join("").concat(t)}var sb=Math.log(2);function ns(){if(typeof BigInt>"u")throw new Error("BigInt is not defined. Your environment doesn't implement BigInt.")}function ia(r){let e=0,t=0;for(let s=0;s<r.length;s++){let i=r[s];e+=i.byteLength}let n=new Uint8Array(e);for(let s=0;s<r.length;s++){let i=r[s];n.set(new Uint8Array(i),t),t+=i.byteLength}return n.buffer}function Bt(r,e,t,n){return e instanceof Uint8Array?e.byteLength?t<0?(r.error="Wrong parameter: inputOffset less than zero",!1):n<0?(r.error="Wrong parameter: inputLength less than zero",!1):e.byteLength-t-n<0?(r.error="End of input reached before message was fully decoded (inconsistent offset and length values)",!1):!0:(r.error="Wrong parameter: inputBuffer has zero length",!1):(r.error="Wrong parameter: inputBuffer must be 'Uint8Array'",!1)}var tn=class{constructor(){this.items=[]}write(e){this.items.push(e)}final(){return ia(this.items)}},en=[new Uint8Array([1])],Tl="0123456789";var Tr="",et=new ArrayBuffer(0),oa=new Uint8Array(0),rn="EndOfContent",Cl="OCTET STRING",Nl="BIT STRING";function _t(r){var e;return e=class extends r{constructor(...n){var s;super(...n);let i=n[0]||{};this.isHexOnly=(s=i.isHexOnly)!==null&&s!==void 0?s:!1,this.valueHexView=i.valueHex?z.BufferSourceConverter.toUint8Array(i.valueHex):oa}get valueHex(){return this.valueHexView.slice().buffer}set valueHex(n){this.valueHexView=new Uint8Array(n)}fromBER(n,s,i){let o=n instanceof ArrayBuffer?new Uint8Array(n):n;if(!Bt(this,o,s,i))return-1;let a=s+i;return this.valueHexView=o.subarray(s,a),this.valueHexView.length?(this.blockLength=i,a):(this.warnings.push("Zero buffer length"),s)}toBER(n=!1){return this.isHexOnly?n?new ArrayBuffer(this.valueHexView.byteLength):this.valueHexView.byteLength===this.valueHexView.buffer.byteLength?this.valueHexView.buffer:this.valueHexView.slice().buffer:(this.error="Flag 'isHexOnly' is not set, abort",et)}toJSON(){return{...super.toJSON(),isHexOnly:this.isHexOnly,valueHex:z.Convert.ToHex(this.valueHexView)}}},e.NAME="hexBlock",e}var Et=class{constructor({blockLength:e=0,error:t=Tr,warnings:n=[],valueBeforeDecode:s=oa}={}){this.blockLength=e,this.error=t,this.warnings=n,this.valueBeforeDecodeView=z.BufferSourceConverter.toUint8Array(s)}static blockName(){return this.NAME}get valueBeforeDecode(){return this.valueBeforeDecodeView.slice().buffer}set valueBeforeDecode(e){this.valueBeforeDecodeView=new Uint8Array(e)}toJSON(){return{blockName:this.constructor.NAME,blockLength:this.blockLength,error:this.error,warnings:this.warnings,valueBeforeDecode:z.Convert.ToHex(this.valueBeforeDecodeView)}}};Et.NAME="baseBlock";var Be=class extends Et{fromBER(e,t,n){throw TypeError("User need to make a specific function in a class which extends 'ValueBlock'")}toBER(e,t){throw TypeError("User need to make a specific function in a class which extends 'ValueBlock'")}};Be.NAME="valueBlock";var ss=class extends _t(Et){constructor({idBlock:e={}}={}){var t,n,s,i;super(),e?(this.isHexOnly=(t=e.isHexOnly)!==null&&t!==void 0?t:!1,this.valueHexView=e.valueHex?z.BufferSourceConverter.toUint8Array(e.valueHex):oa,this.tagClass=(n=e.tagClass)!==null&&n!==void 0?n:-1,this.tagNumber=(s=e.tagNumber)!==null&&s!==void 0?s:-1,this.isConstructed=(i=e.isConstructed)!==null&&i!==void 0?i:!1):(this.tagClass=-1,this.tagNumber=-1,this.isConstructed=!1)}toBER(e=!1){let t=0;switch(this.tagClass){case 1:t|=0;break;case 2:t|=64;break;case 3:t|=128;break;case 4:t|=192;break;default:return this.error="Unknown tag class",et}if(this.isConstructed&&(t|=32),this.tagNumber<31&&!this.isHexOnly){let s=new Uint8Array(1);if(!e){let i=this.tagNumber;i&=31,t|=i,s[0]=t}return s.buffer}if(!this.isHexOnly){let s=Ft(this.tagNumber,7),i=new Uint8Array(s),o=s.byteLength,a=new Uint8Array(o+1);if(a[0]=t|31,!e){for(let c=0;c<o-1;c++)a[c+1]=i[c]|128;a[o]=i[o-1]}return a.buffer}let n=new Uint8Array(this.valueHexView.byteLength+1);if(n[0]=t|31,!e){let s=this.valueHexView;for(let i=0;i<s.length-1;i++)n[i+1]=s[i]|128;n[this.valueHexView.byteLength]=s[s.length-1]}return n.buffer}fromBER(e,t,n){let s=z.BufferSourceConverter.toUint8Array(e);if(!Bt(this,s,t,n))return-1;let i=s.subarray(t,t+n);if(i.length===0)return this.error="Zero buffer length",-1;switch(i[0]&192){case 0:this.tagClass=1;break;case 64:this.tagClass=2;break;case 128:this.tagClass=3;break;case 192:this.tagClass=4;break;default:return this.error="Unknown tag class",-1}this.isConstructed=(i[0]&32)===32,this.isHexOnly=!1;let a=i[0]&31;if(a!==31)this.tagNumber=a,this.blockLength=1;else{let c=1,h=this.valueHexView=new Uint8Array(255),f=255;for(;i[c]&128;){if(h[c-1]=i[c]&127,c++,c>=i.length)return this.error="End of input reached before message was fully decoded",-1;if(c===f){f+=255;let m=new Uint8Array(f);for(let l=0;l<h.length;l++)m[l]=h[l];h=this.valueHexView=new Uint8Array(f)}}this.blockLength=c+1,h[c-1]=i[c]&127;let u=new Uint8Array(c);for(let m=0;m<c;m++)u[m]=h[m];h=this.valueHexView=new Uint8Array(c),h.set(u),this.blockLength<=9?this.tagNumber=ir(h,7):(this.isHexOnly=!0,this.warnings.push("Tag too long, represented as hex-coded"))}if(this.tagClass===1&&this.isConstructed)switch(this.tagNumber){case 1:case 2:case 5:case 6:case 9:case 13:case 14:case 23:case 24:case 31:case 32:case 33:case 34:return this.error="Constructed encoding used for primitive type",-1}return t+this.blockLength}toJSON(){return{...super.toJSON(),tagClass:this.tagClass,tagNumber:this.tagNumber,isConstructed:this.isConstructed}}};ss.NAME="identificationBlock";var is=class extends Et{constructor({lenBlock:e={}}={}){var t,n,s;super(),this.isIndefiniteForm=(t=e.isIndefiniteForm)!==null&&t!==void 0?t:!1,this.longFormUsed=(n=e.longFormUsed)!==null&&n!==void 0?n:!1,this.length=(s=e.length)!==null&&s!==void 0?s:0}fromBER(e,t,n){let s=z.BufferSourceConverter.toUint8Array(e);if(!Bt(this,s,t,n))return-1;let i=s.subarray(t,t+n);if(i.length===0)return this.error="Zero buffer length",-1;if(i[0]===255)return this.error="Length block 0xFF is reserved by standard",-1;if(this.isIndefiniteForm=i[0]===128,this.isIndefiniteForm)return this.blockLength=1,t+this.blockLength;if(this.longFormUsed=!!(i[0]&128),this.longFormUsed===!1)return this.length=i[0],this.blockLength=1,t+this.blockLength;let o=i[0]&127;if(o>8)return this.error="Too big integer",-1;if(o+1>i.length)return this.error="End of input reached before message was fully decoded",-1;let a=t+1,c=s.subarray(a,a+o);return c[o-1]===0&&this.warnings.push("Needlessly long encoded length"),this.length=ir(c,8),this.longFormUsed&&this.length<=127&&this.warnings.push("Unnecessary usage of long length form"),this.blockLength=o+1,t+this.blockLength}toBER(e=!1){let t,n;if(this.length>127&&(this.longFormUsed=!0),this.isIndefiniteForm)return t=new ArrayBuffer(1),e===!1&&(n=new Uint8Array(t),n[0]=128),t;if(this.longFormUsed){let s=Ft(this.length,8);if(s.byteLength>127)return this.error="Too big length",et;if(t=new ArrayBuffer(s.byteLength+1),e)return t;let i=new Uint8Array(s);n=new Uint8Array(t),n[0]=s.byteLength|128;for(let o=0;o<s.byteLength;o++)n[o+1]=i[o];return t}return t=new ArrayBuffer(1),e===!1&&(n=new Uint8Array(t),n[0]=this.length),t}toJSON(){return{...super.toJSON(),isIndefiniteForm:this.isIndefiniteForm,longFormUsed:this.longFormUsed,length:this.length}}};is.NAME="lengthBlock";var k={},be=class extends Et{constructor({name:e=Tr,optional:t=!1,primitiveSchema:n,...s}={},i){super(s),this.name=e,this.optional=t,n&&(this.primitiveSchema=n),this.idBlock=new ss(s),this.lenBlock=new is(s),this.valueBlock=i?new i(s):new Be(s)}fromBER(e,t,n){let s=this.valueBlock.fromBER(e,t,this.lenBlock.isIndefiniteForm?n:this.lenBlock.length);return s===-1?(this.error=this.valueBlock.error,s):(this.idBlock.error.length||(this.blockLength+=this.idBlock.blockLength),this.lenBlock.error.length||(this.blockLength+=this.lenBlock.blockLength),this.valueBlock.error.length||(this.blockLength+=this.valueBlock.blockLength),s)}toBER(e,t){let n=t||new tn;t||Ll(this);let s=this.idBlock.toBER(e);if(n.write(s),this.lenBlock.isIndefiniteForm)n.write(new Uint8Array([128]).buffer),this.valueBlock.toBER(e,n),n.write(new ArrayBuffer(2));else{let i=this.valueBlock.toBER(e);this.lenBlock.length=i.byteLength;let o=this.lenBlock.toBER(e);n.write(o),n.write(i)}return t?et:n.final()}toJSON(){let e={...super.toJSON(),idBlock:this.idBlock.toJSON(),lenBlock:this.lenBlock.toJSON(),valueBlock:this.valueBlock.toJSON(),name:this.name,optional:this.optional};return this.primitiveSchema&&(e.primitiveSchema=this.primitiveSchema.toJSON()),e}toString(e="ascii"){return e==="ascii"?this.onAsciiEncoding():z.Convert.ToHex(this.toBER())}onAsciiEncoding(){return`${this.constructor.NAME} : ${z.Convert.ToHex(this.valueBlock.valueBeforeDecodeView)}`}isEqual(e){if(this===e)return!0;if(!(e instanceof this.constructor))return!1;let t=this.toBER(),n=e.toBER();return Il(t,n)}};be.NAME="BaseBlock";function Ll(r){if(r instanceof k.Constructed)for(let e of r.valueBlock.value)Ll(e)&&(r.lenBlock.isIndefiniteForm=!0);return!!r.lenBlock.isIndefiniteForm}var os=class extends be{constructor({value:e=Tr,...t}={},n){super(t,n),e&&this.fromString(e)}getValue(){return this.valueBlock.value}setValue(e){this.valueBlock.value=e}fromBER(e,t,n){let s=this.valueBlock.fromBER(e,t,this.lenBlock.isIndefiniteForm?n:this.lenBlock.length);return s===-1?(this.error=this.valueBlock.error,s):(this.fromBuffer(this.valueBlock.valueHexView),this.idBlock.error.length||(this.blockLength+=this.idBlock.blockLength),this.lenBlock.error.length||(this.blockLength+=this.lenBlock.blockLength),this.valueBlock.error.length||(this.blockLength+=this.valueBlock.blockLength),s)}onAsciiEncoding(){return`${this.constructor.NAME} : '${this.valueBlock.value}'`}};os.NAME="BaseStringBlock";var as=class extends _t(Be){constructor({isHexOnly:e=!0,...t}={}){super(t),this.isHexOnly=e}};as.NAME="PrimitiveValueBlock";var Rl,cs=class extends be{constructor(e={}){super(e,as),this.idBlock.isConstructed=!1}};Rl=cs;k.Primitive=Rl;cs.NAME="PRIMITIVE";function Mp(r,e){if(r instanceof e)return r;let t=new e;return t.idBlock=r.idBlock,t.lenBlock=r.lenBlock,t.warnings=r.warnings,t.valueBeforeDecodeView=r.valueBeforeDecodeView,t}function Ks(r,e=0,t=r.length){let n=e,s=new be({},Be),i=new Et;if(!Bt(i,r,e,t))return s.error=i.error,{offset:-1,result:s};if(!r.subarray(e,e+t).length)return s.error="Zero buffer length",{offset:-1,result:s};let a=s.idBlock.fromBER(r,e,t);if(s.idBlock.warnings.length&&s.warnings.concat(s.idBlock.warnings),a===-1)return s.error=s.idBlock.error,{offset:-1,result:s};if(e=a,t-=s.idBlock.blockLength,a=s.lenBlock.fromBER(r,e,t),s.lenBlock.warnings.length&&s.warnings.concat(s.lenBlock.warnings),a===-1)return s.error=s.lenBlock.error,{offset:-1,result:s};if(e=a,t-=s.lenBlock.blockLength,!s.idBlock.isConstructed&&s.lenBlock.isIndefiniteForm)return s.error="Indefinite length form used for primitive encoding form",{offset:-1,result:s};let c=be;switch(s.idBlock.tagClass){case 1:if(s.idBlock.tagNumber>=37&&s.idBlock.isHexOnly===!1)return s.error="UNIVERSAL 37 and upper tags are reserved by ASN.1 standard",{offset:-1,result:s};switch(s.idBlock.tagNumber){case 0:if(s.idBlock.isConstructed&&s.lenBlock.length>0)return s.error="Type [UNIVERSAL 0] is reserved",{offset:-1,result:s};c=k.EndOfContent;break;case 1:c=k.Boolean;break;case 2:c=k.Integer;break;case 3:c=k.BitString;break;case 4:c=k.OctetString;break;case 5:c=k.Null;break;case 6:c=k.ObjectIdentifier;break;case 10:c=k.Enumerated;break;case 12:c=k.Utf8String;break;case 13:c=k.RelativeObjectIdentifier;break;case 14:c=k.TIME;break;case 15:return s.error="[UNIVERSAL 15] is reserved by ASN.1 standard",{offset:-1,result:s};case 16:c=k.Sequence;break;case 17:c=k.Set;break;case 18:c=k.NumericString;break;case 19:c=k.PrintableString;break;case 20:c=k.TeletexString;break;case 21:c=k.VideotexString;break;case 22:c=k.IA5String;break;case 23:c=k.UTCTime;break;case 24:c=k.GeneralizedTime;break;case 25:c=k.GraphicString;break;case 26:c=k.VisibleString;break;case 27:c=k.GeneralString;break;case 28:c=k.UniversalString;break;case 29:c=k.CharacterString;break;case 30:c=k.BmpString;break;case 31:c=k.DATE;break;case 32:c=k.TimeOfDay;break;case 33:c=k.DateTime;break;case 34:c=k.Duration;break;default:{let h=s.idBlock.isConstructed?new k.Constructed:new k.Primitive;h.idBlock=s.idBlock,h.lenBlock=s.lenBlock,h.warnings=s.warnings,s=h}}break;case 2:case 3:case 4:default:c=s.idBlock.isConstructed?k.Constructed:k.Primitive}return s=Mp(s,c),a=s.fromBER(r,e,s.lenBlock.isIndefiniteForm?t:s.lenBlock.length),s.valueBeforeDecodeView=r.subarray(n,n+s.blockLength),{offset:a,result:s}}function aa(r){if(!r.byteLength){let e=new be({},Be);return e.error="Input buffer has zero length",{offset:-1,result:e}}return Ks(z.BufferSourceConverter.toUint8Array(r).slice(),0,r.byteLength)}function Pp(r,e){return r?1:e}var ct=class extends Be{constructor({value:e=[],isIndefiniteForm:t=!1,...n}={}){super(n),this.value=e,this.isIndefiniteForm=t}fromBER(e,t,n){let s=z.BufferSourceConverter.toUint8Array(e);if(!Bt(this,s,t,n))return-1;if(this.valueBeforeDecodeView=s.subarray(t,t+n),this.valueBeforeDecodeView.length===0)return this.warnings.push("Zero buffer length"),t;let i=t;for(;Pp(this.isIndefiniteForm,n)>0;){let o=Ks(s,i,n);if(o.offset===-1)return this.error=o.result.error,this.warnings.concat(o.result.warnings),-1;if(i=o.offset,this.blockLength+=o.result.blockLength,n-=o.result.blockLength,this.value.push(o.result),this.isIndefiniteForm&&o.result.constructor.NAME===rn)break}return this.isIndefiniteForm&&(this.value[this.value.length-1].constructor.NAME===rn?this.value.pop():this.warnings.push("No EndOfContent block encoded")),i}toBER(e,t){let n=t||new tn;for(let s=0;s<this.value.length;s++)this.value[s].toBER(e,n);return t?et:n.final()}toJSON(){let e={...super.toJSON(),isIndefiniteForm:this.isIndefiniteForm,value:[]};for(let t of this.value)e.value.push(t.toJSON());return e}};ct.NAME="ConstructedValueBlock";var Ul,Kt=class extends be{constructor(e={}){super(e,ct),this.idBlock.isConstructed=!0}fromBER(e,t,n){this.valueBlock.isIndefiniteForm=this.lenBlock.isIndefiniteForm;let s=this.valueBlock.fromBER(e,t,this.lenBlock.isIndefiniteForm?n:this.lenBlock.length);return s===-1?(this.error=this.valueBlock.error,s):(this.idBlock.error.length||(this.blockLength+=this.idBlock.blockLength),this.lenBlock.error.length||(this.blockLength+=this.lenBlock.blockLength),this.valueBlock.error.length||(this.blockLength+=this.valueBlock.blockLength),s)}onAsciiEncoding(){let e=[];for(let n of this.valueBlock.value)e.push(n.toString("ascii").split(`
|
3
3
|
`).map(s=>` ${s}`).join(`
|
4
|
-
`));let
|
5
|
-
${
|
6
|
-
`)}`:`${e} :`}};Ul=Ke;k.Constructed=Ul;Ke.NAME="CONSTRUCTED";var ls=class extends _t{fromBER(t,e,n){return e}toBER(t){return te}};ls.override="EndOfContentValueBlock";var Dl,us=class extends bt{constructor(t={}){super(t,ls),this.idBlock.tagClass=1,this.idBlock.tagNumber=0}};Dl=us;k.EndOfContent=Dl;us.NAME=rn;var Ol,Br=class extends bt{constructor(t={}){super(t,_t),this.idBlock.tagClass=1,this.idBlock.tagNumber=5}fromBER(t,e,n){return this.lenBlock.length>0&&this.warnings.push("Non-zero length of value block for Null type"),this.idBlock.error.length||(this.blockLength+=this.idBlock.blockLength),this.lenBlock.error.length||(this.blockLength+=this.lenBlock.blockLength),this.blockLength+=n,e+n>t.byteLength?(this.error="End of input reached before message was fully decoded (inconsistent offset and length values)",-1):e+n}toBER(t,e){let n=new ArrayBuffer(2);if(!t){let s=new Uint8Array(n);s[0]=5,s[1]=0}return e&&e.write(n),n}onAsciiEncoding(){return`${this.constructor.NAME}`}};Ol=Br;k.Null=Ol;Br.NAME="NULL";var fs=class extends _e(_t){constructor({value:t,...e}={}){super(e),e.valueHex?this.valueHexView=z.BufferSourceConverter.toUint8Array(e.valueHex):this.valueHexView=new Uint8Array(1),t&&(this.value=t)}get value(){for(let t of this.valueHexView)if(t>0)return!0;return!1}set value(t){this.valueHexView[0]=t?255:0}fromBER(t,e,n){let s=z.BufferSourceConverter.toUint8Array(t);return Be(this,s,e,n)?(this.valueHexView=s.subarray(e,e+n),n>1&&this.warnings.push("Boolean value encoded in more then 1 octet"),this.isHexOnly=!0,sa.call(this),this.blockLength=n,e+n):-1}toBER(){return this.valueHexView.slice()}toJSON(){return{...super.toJSON(),value:this.value}}};fs.NAME="BooleanValueBlock";var Ml,hs=class extends bt{constructor(t={}){super(t,fs),this.idBlock.tagClass=1,this.idBlock.tagNumber=1}getValue(){return this.valueBlock.value}setValue(t){this.valueBlock.value=t}onAsciiEncoding(){return`${this.constructor.NAME} : ${this.getValue}`}};Ml=hs;k.Boolean=Ml;hs.NAME="BOOLEAN";var ds=class extends _e(ce){constructor({isConstructed:t=!1,...e}={}){super(e),this.isConstructed=t}fromBER(t,e,n){let s=0;if(this.isConstructed){if(this.isHexOnly=!1,s=ce.prototype.fromBER.call(this,t,e,n),s===-1)return s;for(let i=0;i<this.value.length;i++){let o=this.value[i].constructor.NAME;if(o===rn){if(this.isIndefiniteForm)break;return this.error="EndOfContent is unexpected, OCTET STRING may consists of OCTET STRINGs only",-1}if(o!==Cl)return this.error="OCTET STRING may consists of OCTET STRINGs only",-1}}else this.isHexOnly=!0,s=super.fromBER(t,e,n),this.blockLength=n;return s}toBER(t,e){return this.isConstructed?ce.prototype.toBER.call(this,t,e):t?new ArrayBuffer(this.valueHexView.byteLength):this.valueHexView.slice().buffer}toJSON(){return{...super.toJSON(),isConstructed:this.isConstructed}}};ds.NAME="OctetStringValueBlock";var Pl,ps=class r extends bt{constructor({idBlock:t={},lenBlock:e={},...n}={}){var s,i;(s=n.isConstructed)!==null&&s!==void 0||(n.isConstructed=!!(!((i=n.value)===null||i===void 0)&&i.length)),super({idBlock:{isConstructed:n.isConstructed,...t},lenBlock:{...e,isIndefiniteForm:!!n.isIndefiniteForm},...n},ds),this.idBlock.tagClass=1,this.idBlock.tagNumber=4}fromBER(t,e,n){if(this.valueBlock.isConstructed=this.idBlock.isConstructed,this.valueBlock.isIndefiniteForm=this.lenBlock.isIndefiniteForm,n===0)return this.idBlock.error.length===0&&(this.blockLength+=this.idBlock.blockLength),this.lenBlock.error.length===0&&(this.blockLength+=this.lenBlock.blockLength),e;if(!this.valueBlock.isConstructed){let i=(t instanceof ArrayBuffer?new Uint8Array(t):t).subarray(e,e+n);try{if(i.byteLength){let o=Ks(i,0,i.byteLength);o.offset!==-1&&o.offset===n&&(this.valueBlock.value=[o.result])}}catch{}}return super.fromBER(t,e,n)}onAsciiEncoding(){return this.valueBlock.isConstructed||this.valueBlock.value&&this.valueBlock.value.length?Ke.prototype.onAsciiEncoding.call(this):`${this.constructor.NAME} : ${z.Convert.ToHex(this.valueBlock.valueHexView)}`}getValue(){if(!this.idBlock.isConstructed)return this.valueBlock.valueHexView.slice().buffer;let t=[];for(let e of this.valueBlock.value)e instanceof r&&t.push(e.valueBlock.valueHexView);return z.BufferSourceConverter.concat(t)}};Pl=ps;k.OctetString=Pl;ps.NAME=Cl;var ms=class extends _e(ce){constructor({unusedBits:t=0,isConstructed:e=!1,...n}={}){super(n),this.unusedBits=t,this.isConstructed=e,this.blockLength=this.valueHexView.byteLength}fromBER(t,e,n){if(!n)return e;let s=-1;if(this.isConstructed){if(s=ce.prototype.fromBER.call(this,t,e,n),s===-1)return s;for(let a of this.value){let c=a.constructor.NAME;if(c===rn){if(this.isIndefiniteForm)break;return this.error="EndOfContent is unexpected, BIT STRING may consists of BIT STRINGs only",-1}if(c!==Nl)return this.error="BIT STRING may consists of BIT STRINGs only",-1;let h=a.valueBlock;if(this.unusedBits>0&&h.unusedBits>0)return this.error='Using of "unused bits" inside constructive BIT STRING allowed for least one only',-1;this.unusedBits=h.unusedBits}return s}let i=z.BufferSourceConverter.toUint8Array(t);if(!Be(this,i,e,n))return-1;let o=i.subarray(e,e+n);if(this.unusedBits=o[0],this.unusedBits>7)return this.error="Unused bits for BitString must be in range 0-7",-1;if(!this.unusedBits){let a=o.subarray(1);try{if(a.byteLength){let c=Ks(a,0,a.byteLength);c.offset!==-1&&c.offset===n-1&&(this.value=[c.result])}}catch{}}return this.valueHexView=o.subarray(1),this.blockLength=o.length,e+n}toBER(t,e){if(this.isConstructed)return ce.prototype.toBER.call(this,t,e);if(t)return new ArrayBuffer(this.valueHexView.byteLength+1);if(!this.valueHexView.byteLength)return te;let n=new Uint8Array(this.valueHexView.length+1);return n[0]=this.unusedBits,n.set(this.valueHexView,1),n.buffer}toJSON(){return{...super.toJSON(),unusedBits:this.unusedBits,isConstructed:this.isConstructed}}};ms.NAME="BitStringValueBlock";var Vl,_r=class extends bt{constructor({idBlock:t={},lenBlock:e={},...n}={}){var s,i;(s=n.isConstructed)!==null&&s!==void 0||(n.isConstructed=!!(!((i=n.value)===null||i===void 0)&&i.length)),super({idBlock:{isConstructed:n.isConstructed,...t},lenBlock:{...e,isIndefiniteForm:!!n.isIndefiniteForm},...n},ms),this.idBlock.tagClass=1,this.idBlock.tagNumber=3}fromBER(t,e,n){return this.valueBlock.isConstructed=this.idBlock.isConstructed,this.valueBlock.isIndefiniteForm=this.lenBlock.isIndefiniteForm,super.fromBER(t,e,n)}onAsciiEncoding(){if(this.valueBlock.isConstructed||this.valueBlock.value&&this.valueBlock.value.length)return Ke.prototype.onAsciiEncoding.call(this);{let t=[],e=this.valueBlock.valueHexView;for(let s of e)t.push(s.toString(2).padStart(8,"0"));let n=t.join("");return`${this.constructor.NAME} : ${n.substring(0,n.length-this.valueBlock.unusedBits)}`}}};Vl=_r;k.BitString=Vl;_r.NAME=Nl;var Hl;function Vp(r,t){let e=new Uint8Array([0]),n=new Uint8Array(r),s=new Uint8Array(t),i=n.slice(0),o=i.length-1,a=s.slice(0),c=a.length-1,h=0,f=c<o?o:c,u=0;for(let g=f;g>=0;g--,u++){switch(!0){case u<a.length:h=i[o-u]+a[c-u]+e[0];break;default:h=i[o-u]+e[0]}switch(e[0]=h/10,!0){case u>=i.length:i=rs(new Uint8Array([h%10]),i);break;default:i[o-u]=h%10}}return e[0]>0&&(i=rs(e,i)),i}function kl(r){if(r>=tn.length)for(let t=tn.length;t<=r;t++){let e=new Uint8Array([0]),n=tn[t-1].slice(0);for(let s=n.length-1;s>=0;s--){let i=new Uint8Array([(n[s]<<1)+e[0]]);e[0]=i[0]/10,n[s]=i[0]%10}e[0]>0&&(n=rs(e,n)),tn.push(n)}return tn[r]}function Hp(r,t){let e=0,n=new Uint8Array(r),s=new Uint8Array(t),i=n.slice(0),o=i.length-1,a=s.slice(0),c=a.length-1,h,f=0;for(let u=c;u>=0;u--,f++)switch(h=i[o-f]-a[c-f]-e,!0){case h<0:e=1,i[o-f]=h+10;break;default:e=0,i[o-f]=h}if(e>0)for(let u=o-c+1;u>=0;u--,f++)if(h=i[o-f]-e,h<0)e=1,i[o-f]=h+10;else{e=0,i[o-f]=h;break}return i.slice()}var nn=class extends _e(_t){constructor({value:t,...e}={}){super(e),this._valueDec=0,e.valueHex&&this.setValueHex(),t!==void 0&&(this.valueDec=t)}setValueHex(){this.valueHexView.length>=4?(this.warnings.push("Too big Integer for decoding, hex only"),this.isHexOnly=!0,this._valueDec=0):(this.isHexOnly=!1,this.valueHexView.length>0&&(this._valueDec=sa.call(this)))}set valueDec(t){this._valueDec=t,this.isHexOnly=!1,this.valueHexView=new Uint8Array(_l(t))}get valueDec(){return this._valueDec}fromDER(t,e,n,s=0){let i=this.fromBER(t,e,n);if(i===-1)return i;let o=this.valueHexView;return o[0]===0&&o[1]&128?this.valueHexView=o.subarray(1):s!==0&&o.length<s&&(s-o.length>1&&(s=o.length+1),this.valueHexView=o.subarray(s-o.length)),i}toDER(t=!1){let e=this.valueHexView;switch(!0){case(e[0]&128)!==0:{let n=new Uint8Array(this.valueHexView.length+1);n[0]=0,n.set(e,1),this.valueHexView=n}break;case(e[0]===0&&(e[1]&128)===0):this.valueHexView=this.valueHexView.subarray(1);break}return this.toBER(t)}fromBER(t,e,n){let s=super.fromBER(t,e,n);return s===-1||this.setValueHex(),s}toBER(t){return t?new ArrayBuffer(this.valueHexView.length):this.valueHexView.slice().buffer}toJSON(){return{...super.toJSON(),valueDec:this.valueDec}}toString(){let t=this.valueHexView.length*8-1,e=new Uint8Array(this.valueHexView.length*8/3),n=0,s,i=this.valueHexView,o="",a=!1;for(let c=i.byteLength-1;c>=0;c--){s=i[c];for(let h=0;h<8;h++){if((s&1)===1)switch(n){case t:e=Hp(kl(n),e),o="-";break;default:e=Vp(e,kl(n))}n++,s>>=1}}for(let c=0;c<e.length;c++)e[c]&&(a=!0),a&&(o+=Tl.charAt(e[c]));return a===!1&&(o+=Tl.charAt(0)),o}};Hl=nn;nn.NAME="IntegerValueBlock";Object.defineProperty(Hl.prototype,"valueHex",{set:function(r){this.valueHexView=new Uint8Array(r),this.setValueHex()},get:function(){return this.valueHexView.slice().buffer}});var Fl,wt=class r extends bt{constructor(t={}){super(t,nn),this.idBlock.tagClass=1,this.idBlock.tagNumber=2}toBigInt(){return ns(),BigInt(this.valueBlock.toString())}static fromBigInt(t){ns();let e=BigInt(t),n=new en,s=e.toString(16).replace(/^-/,""),i=new Uint8Array(z.Convert.FromHex(s));if(e<0){let a=new Uint8Array(i.length+(i[0]&128?1:0));a[0]|=128;let h=BigInt(`0x${z.Convert.ToHex(a)}`)+e,f=z.BufferSourceConverter.toUint8Array(z.Convert.FromHex(h.toString(16)));f[0]|=128,n.write(f)}else i[0]&128&&n.write(new Uint8Array([0])),n.write(i);return new r({valueHex:n.final()})}convertToDER(){let t=new r({valueHex:this.valueBlock.valueHexView});return t.valueBlock.toDER(),t}convertFromDER(){return new r({valueHex:this.valueBlock.valueHexView[0]===0?this.valueBlock.valueHexView.subarray(1):this.valueBlock.valueHexView})}onAsciiEncoding(){return`${this.constructor.NAME} : ${this.valueBlock.toString()}`}};Fl=wt;k.Integer=Fl;wt.NAME="INTEGER";var Kl,gs=class extends wt{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=10}};Kl=gs;k.Enumerated=Kl;gs.NAME="ENUMERATED";var sn=class extends _e(_t){constructor({valueDec:t=-1,isFirstSid:e=!1,...n}={}){super(n),this.valueDec=t,this.isFirstSid=e}fromBER(t,e,n){if(!n)return e;let s=z.BufferSourceConverter.toUint8Array(t);if(!Be(this,s,e,n))return-1;let i=s.subarray(e,e+n);this.valueHexView=new Uint8Array(n);for(let a=0;a<n&&(this.valueHexView[a]=i[a]&127,this.blockLength++,!!(i[a]&128));a++);let o=new Uint8Array(this.blockLength);for(let a=0;a<this.blockLength;a++)o[a]=this.valueHexView[a];return this.valueHexView=o,i[this.blockLength-1]&128?(this.error="End of input reached before message was fully decoded",-1):(this.valueHexView[0]===0&&this.warnings.push("Needlessly long format of SID encoding"),this.blockLength<=8?this.valueDec=ir(this.valueHexView,7):(this.isHexOnly=!0,this.warnings.push("Too big SID for decoding, hex only")),e+this.blockLength)}set valueBigInt(t){ns();let e=BigInt(t).toString(2);for(;e.length%7;)e="0"+e;let n=new Uint8Array(e.length/7);for(let s=0;s<n.length;s++)n[s]=parseInt(e.slice(s*7,s*7+7),2)+(s+1<n.length?128:0);this.fromBER(n.buffer,0,n.length)}toBER(t){if(this.isHexOnly){if(t)return new ArrayBuffer(this.valueHexView.byteLength);let s=this.valueHexView,i=new Uint8Array(this.blockLength);for(let o=0;o<this.blockLength-1;o++)i[o]=s[o]|128;return i[this.blockLength-1]=s[this.blockLength-1],i.buffer}let e=Fe(this.valueDec,7);if(e.byteLength===0)return this.error="Error during encoding SID value",te;let n=new Uint8Array(e.byteLength);if(!t){let s=new Uint8Array(e),i=e.byteLength-1;for(let o=0;o<i;o++)n[o]=s[o]|128;n[i]=s[i]}return n}toString(){let t="";if(this.isHexOnly)t=z.Convert.ToHex(this.valueHexView);else if(this.isFirstSid){let e=this.valueDec;this.valueDec<=39?t="0.":this.valueDec<=79?(t="1.",e-=40):(t="2.",e-=80),t+=e.toString()}else t=this.valueDec.toString();return t}toJSON(){return{...super.toJSON(),valueDec:this.valueDec,isFirstSid:this.isFirstSid}}};sn.NAME="sidBlock";var ys=class extends _t{constructor({value:t=Tr,...e}={}){super(e),this.value=[],t&&this.fromString(t)}fromBER(t,e,n){let s=e;for(;n>0;){let i=new sn;if(s=i.fromBER(t,s,n),s===-1)return this.blockLength=0,this.error=i.error,s;this.value.length===0&&(i.isFirstSid=!0),this.blockLength+=i.blockLength,n-=i.blockLength,this.value.push(i)}return s}toBER(t){let e=[];for(let n=0;n<this.value.length;n++){let s=this.value[n].toBER(t);if(s.byteLength===0)return this.error=this.value[n].error,te;e.push(s)}return ia(e)}fromString(t){this.value=[];let e=0,n=0,s="",i=!1;do if(n=t.indexOf(".",e),n===-1?s=t.substring(e):s=t.substring(e,n),e=n+1,i){let o=this.value[0],a=0;switch(o.valueDec){case 0:break;case 1:a=40;break;case 2:a=80;break;default:this.value=[];return}let c=parseInt(s,10);if(isNaN(c))return;o.valueDec=c+a,i=!1}else{let o=new sn;if(s>Number.MAX_SAFE_INTEGER){ns();let a=BigInt(s);o.valueBigInt=a}else if(o.valueDec=parseInt(s,10),isNaN(o.valueDec))return;this.value.length||(o.isFirstSid=!0,i=!0),this.value.push(o)}while(n!==-1)}toString(){let t="",e=!1;for(let n=0;n<this.value.length;n++){e=this.value[n].isHexOnly;let s=this.value[n].toString();n!==0&&(t=`${t}.`),e?(s=`{${s}}`,this.value[n].isFirstSid?t=`2.{${s} - 80}`:t+=s):t+=s}return t}toJSON(){let t={...super.toJSON(),value:this.toString(),sidArray:[]};for(let e=0;e<this.value.length;e++)t.sidArray.push(this.value[e].toJSON());return t}};ys.NAME="ObjectIdentifierValueBlock";var ql,Ir=class extends bt{constructor(t={}){super(t,ys),this.idBlock.tagClass=1,this.idBlock.tagNumber=6}getValue(){return this.valueBlock.toString()}setValue(t){this.valueBlock.fromString(t)}onAsciiEncoding(){return`${this.constructor.NAME} : ${this.valueBlock.toString()||"empty"}`}toJSON(){return{...super.toJSON(),value:this.getValue()}}};ql=Ir;k.ObjectIdentifier=ql;Ir.NAME="OBJECT IDENTIFIER";var on=class extends _e(Ee){constructor({valueDec:t=0,...e}={}){super(e),this.valueDec=t}fromBER(t,e,n){if(n===0)return e;let s=z.BufferSourceConverter.toUint8Array(t);if(!Be(this,s,e,n))return-1;let i=s.subarray(e,e+n);this.valueHexView=new Uint8Array(n);for(let a=0;a<n&&(this.valueHexView[a]=i[a]&127,this.blockLength++,!!(i[a]&128));a++);let o=new Uint8Array(this.blockLength);for(let a=0;a<this.blockLength;a++)o[a]=this.valueHexView[a];return this.valueHexView=o,i[this.blockLength-1]&128?(this.error="End of input reached before message was fully decoded",-1):(this.valueHexView[0]===0&&this.warnings.push("Needlessly long format of SID encoding"),this.blockLength<=8?this.valueDec=ir(this.valueHexView,7):(this.isHexOnly=!0,this.warnings.push("Too big SID for decoding, hex only")),e+this.blockLength)}toBER(t){if(this.isHexOnly){if(t)return new ArrayBuffer(this.valueHexView.byteLength);let s=this.valueHexView,i=new Uint8Array(this.blockLength);for(let o=0;o<this.blockLength-1;o++)i[o]=s[o]|128;return i[this.blockLength-1]=s[this.blockLength-1],i.buffer}let e=Fe(this.valueDec,7);if(e.byteLength===0)return this.error="Error during encoding SID value",te;let n=new Uint8Array(e.byteLength);if(!t){let s=new Uint8Array(e),i=e.byteLength-1;for(let o=0;o<i;o++)n[o]=s[o]|128;n[i]=s[i]}return n.buffer}toString(){let t="";return this.isHexOnly?t=z.Convert.ToHex(this.valueHexView):t=this.valueDec.toString(),t}toJSON(){return{...super.toJSON(),valueDec:this.valueDec}}};on.NAME="relativeSidBlock";var bs=class extends _t{constructor({value:t=Tr,...e}={}){super(e),this.value=[],t&&this.fromString(t)}fromBER(t,e,n){let s=e;for(;n>0;){let i=new on;if(s=i.fromBER(t,s,n),s===-1)return this.blockLength=0,this.error=i.error,s;this.blockLength+=i.blockLength,n-=i.blockLength,this.value.push(i)}return s}toBER(t,e){let n=[];for(let s=0;s<this.value.length;s++){let i=this.value[s].toBER(t);if(i.byteLength===0)return this.error=this.value[s].error,te;n.push(i)}return ia(n)}fromString(t){this.value=[];let e=0,n=0,s="";do{n=t.indexOf(".",e),n===-1?s=t.substring(e):s=t.substring(e,n),e=n+1;let i=new on;if(i.valueDec=parseInt(s,10),isNaN(i.valueDec))return!0;this.value.push(i)}while(n!==-1);return!0}toString(){let t="",e=!1;for(let n=0;n<this.value.length;n++){e=this.value[n].isHexOnly;let s=this.value[n].toString();n!==0&&(t=`${t}.`),e&&(s=`{${s}}`),t+=s}return t}toJSON(){let t={...super.toJSON(),value:this.toString(),sidArray:[]};for(let e=0;e<this.value.length;e++)t.sidArray.push(this.value[e].toJSON());return t}};bs.NAME="RelativeObjectIdentifierValueBlock";var zl,ws=class extends bt{constructor(t={}){super(t,bs),this.idBlock.tagClass=1,this.idBlock.tagNumber=13}getValue(){return this.valueBlock.toString()}setValue(t){this.valueBlock.fromString(t)}onAsciiEncoding(){return`${this.constructor.NAME} : ${this.valueBlock.toString()||"empty"}`}toJSON(){return{...super.toJSON(),value:this.getValue()}}};zl=ws;k.RelativeObjectIdentifier=zl;ws.NAME="RelativeObjectIdentifier";var $l,Se=class extends Ke{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=16}};$l=Se;k.Sequence=$l;Se.NAME="SEQUENCE";var Gl,xs=class extends Ke{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=17}};Gl=xs;k.Set=Gl;xs.NAME="SET";var vs=class extends _e(_t){constructor({...t}={}){super(t),this.isHexOnly=!0,this.value=Tr}toJSON(){return{...super.toJSON(),value:this.value}}};vs.NAME="StringValueBlock";var Es=class extends vs{};Es.NAME="SimpleStringValueBlock";var Ct=class extends os{constructor({...t}={}){super(t,Es)}fromBuffer(t){this.valueBlock.value=String.fromCharCode.apply(null,z.BufferSourceConverter.toUint8Array(t))}fromString(t){let e=t.length,n=this.valueBlock.valueHexView=new Uint8Array(e);for(let s=0;s<e;s++)n[s]=t.charCodeAt(s);this.valueBlock.value=t}};Ct.NAME="SIMPLE STRING";var Ss=class extends Ct{fromBuffer(t){this.valueBlock.valueHexView=z.BufferSourceConverter.toUint8Array(t);try{this.valueBlock.value=z.Convert.ToUtf8String(t)}catch(e){this.warnings.push(`Error during "decodeURIComponent": ${e}, using raw string`),this.valueBlock.value=z.Convert.ToBinary(t)}}fromString(t){this.valueBlock.valueHexView=new Uint8Array(z.Convert.FromUtf8String(t)),this.valueBlock.value=t}};Ss.NAME="Utf8StringValueBlock";var Wl,Ae=class extends Ss{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=12}};Wl=Ae;k.Utf8String=Wl;Ae.NAME="UTF8String";var As=class extends Ct{fromBuffer(t){this.valueBlock.value=z.Convert.ToUtf16String(t),this.valueBlock.valueHexView=z.BufferSourceConverter.toUint8Array(t)}fromString(t){this.valueBlock.value=t,this.valueBlock.valueHexView=new Uint8Array(z.Convert.FromUtf16String(t))}};As.NAME="BmpStringValueBlock";var Zl,Bs=class extends As{constructor({...t}={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=30}};Zl=Bs;k.BmpString=Zl;Bs.NAME="BMPString";var _s=class extends Ct{fromBuffer(t){let e=ArrayBuffer.isView(t)?t.slice().buffer:t.slice(0),n=new Uint8Array(e);for(let s=0;s<n.length;s+=4)n[s]=n[s+3],n[s+1]=n[s+2],n[s+2]=0,n[s+3]=0;this.valueBlock.value=String.fromCharCode.apply(null,new Uint32Array(e))}fromString(t){let e=t.length,n=this.valueBlock.valueHexView=new Uint8Array(e*4);for(let s=0;s<e;s++){let i=Fe(t.charCodeAt(s),8),o=new Uint8Array(i);if(o.length>4)continue;let a=4-o.length;for(let c=o.length-1;c>=0;c--)n[s*4+c+a]=o[c]}this.valueBlock.value=t}};_s.NAME="UniversalStringValueBlock";var jl,Is=class extends _s{constructor({...t}={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=28}};jl=Is;k.UniversalString=jl;Is.NAME="UniversalString";var Yl,Ts=class extends Ct{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=18}};Yl=Ts;k.NumericString=Yl;Ts.NAME="NumericString";var Xl,ks=class extends Ct{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=19}};Xl=ks;k.PrintableString=Xl;ks.NAME="PrintableString";var Jl,Cs=class extends Ct{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=20}};Jl=Cs;k.TeletexString=Jl;Cs.NAME="TeletexString";var Ql,Ns=class extends Ct{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=21}};Ql=Ns;k.VideotexString=Ql;Ns.NAME="VideotexString";var tu,Ls=class extends Ct{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=22}};tu=Ls;k.IA5String=tu;Ls.NAME="IA5String";var eu,Rs=class extends Ct{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=25}};eu=Rs;k.GraphicString=eu;Rs.NAME="GraphicString";var ru,an=class extends Ct{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=26}};ru=an;k.VisibleString=ru;an.NAME="VisibleString";var nu,Us=class extends Ct{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=27}};nu=Us;k.GeneralString=nu;Us.NAME="GeneralString";var su,Ds=class extends Ct{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=29}};su=Ds;k.CharacterString=su;Ds.NAME="CharacterString";var iu,cn=class extends an{constructor({value:t,valueDate:e,...n}={}){if(super(n),this.year=0,this.month=0,this.day=0,this.hour=0,this.minute=0,this.second=0,t){this.fromString(t),this.valueBlock.valueHexView=new Uint8Array(t.length);for(let s=0;s<t.length;s++)this.valueBlock.valueHexView[s]=t.charCodeAt(s)}e&&(this.fromDate(e),this.valueBlock.valueHexView=new Uint8Array(this.toBuffer())),this.idBlock.tagClass=1,this.idBlock.tagNumber=23}fromBuffer(t){this.fromString(String.fromCharCode.apply(null,z.BufferSourceConverter.toUint8Array(t)))}toBuffer(){let t=this.toString(),e=new ArrayBuffer(t.length),n=new Uint8Array(e);for(let s=0;s<t.length;s++)n[s]=t.charCodeAt(s);return e}fromDate(t){this.year=t.getUTCFullYear(),this.month=t.getUTCMonth()+1,this.day=t.getUTCDate(),this.hour=t.getUTCHours(),this.minute=t.getUTCMinutes(),this.second=t.getUTCSeconds()}toDate(){return new Date(Date.UTC(this.year,this.month-1,this.day,this.hour,this.minute,this.second))}fromString(t){let n=/(\d{2})(\d{2})(\d{2})(\d{2})(\d{2})(\d{2})Z/ig.exec(t);if(n===null){this.error="Wrong input string for conversion";return}let s=parseInt(n[1],10);s>=50?this.year=1900+s:this.year=2e3+s,this.month=parseInt(n[2],10),this.day=parseInt(n[3],10),this.hour=parseInt(n[4],10),this.minute=parseInt(n[5],10),this.second=parseInt(n[6],10)}toString(t="iso"){if(t==="iso"){let e=new Array(7);return e[0]=Vt(this.year<2e3?this.year-1900:this.year-2e3,2),e[1]=Vt(this.month,2),e[2]=Vt(this.day,2),e[3]=Vt(this.hour,2),e[4]=Vt(this.minute,2),e[5]=Vt(this.second,2),e[6]="Z",e.join("")}return super.toString(t)}onAsciiEncoding(){return`${this.constructor.NAME} : ${this.toDate().toISOString()}`}toJSON(){return{...super.toJSON(),year:this.year,month:this.month,day:this.day,hour:this.hour,minute:this.minute,second:this.second}}};iu=cn;k.UTCTime=iu;cn.NAME="UTCTime";var ou,Os=class extends cn{constructor(t={}){var e;super(t),(e=this.millisecond)!==null&&e!==void 0||(this.millisecond=0),this.idBlock.tagClass=1,this.idBlock.tagNumber=24}fromDate(t){super.fromDate(t),this.millisecond=t.getUTCMilliseconds()}toDate(){return new Date(Date.UTC(this.year,this.month-1,this.day,this.hour,this.minute,this.second,this.millisecond))}fromString(t){let e=!1,n="",s="",i=0,o,a=0,c=0;if(t[t.length-1]==="Z")n=t.substring(0,t.length-1),e=!0;else{let u=new Number(t[t.length-1]);if(isNaN(u.valueOf()))throw new Error("Wrong input string for conversion");n=t}if(e){if(n.indexOf("+")!==-1)throw new Error("Wrong input string for conversion");if(n.indexOf("-")!==-1)throw new Error("Wrong input string for conversion")}else{let u=1,g=n.indexOf("+"),l="";if(g===-1&&(g=n.indexOf("-"),u=-1),g!==-1){if(l=n.substring(g+1),n=n.substring(0,g),l.length!==2&&l.length!==4)throw new Error("Wrong input string for conversion");let d=parseInt(l.substring(0,2),10);if(isNaN(d.valueOf()))throw new Error("Wrong input string for conversion");if(a=u*d,l.length===4){if(d=parseInt(l.substring(2,4),10),isNaN(d.valueOf()))throw new Error("Wrong input string for conversion");c=u*d}}}let h=n.indexOf(".");if(h===-1&&(h=n.indexOf(",")),h!==-1){let u=new Number(`0${n.substring(h)}`);if(isNaN(u.valueOf()))throw new Error("Wrong input string for conversion");i=u.valueOf(),s=n.substring(0,h)}else s=n;switch(!0){case s.length===8:if(o=/(\d{4})(\d{2})(\d{2})/ig,h!==-1)throw new Error("Wrong input string for conversion");break;case s.length===10:if(o=/(\d{4})(\d{2})(\d{2})(\d{2})/ig,h!==-1){let u=60*i;this.minute=Math.floor(u),u=60*(u-this.minute),this.second=Math.floor(u),u=1e3*(u-this.second),this.millisecond=Math.floor(u)}break;case s.length===12:if(o=/(\d{4})(\d{2})(\d{2})(\d{2})(\d{2})/ig,h!==-1){let u=60*i;this.second=Math.floor(u),u=1e3*(u-this.second),this.millisecond=Math.floor(u)}break;case s.length===14:if(o=/(\d{4})(\d{2})(\d{2})(\d{2})(\d{2})(\d{2})/ig,h!==-1){let u=1e3*i;this.millisecond=Math.floor(u)}break;default:throw new Error("Wrong input string for conversion")}let f=o.exec(s);if(f===null)throw new Error("Wrong input string for conversion");for(let u=1;u<f.length;u++)switch(u){case 1:this.year=parseInt(f[u],10);break;case 2:this.month=parseInt(f[u],10);break;case 3:this.day=parseInt(f[u],10);break;case 4:this.hour=parseInt(f[u],10)+a;break;case 5:this.minute=parseInt(f[u],10)+c;break;case 6:this.second=parseInt(f[u],10);break;default:throw new Error("Wrong input string for conversion")}if(e===!1){let u=new Date(this.year,this.month,this.day,this.hour,this.minute,this.second,this.millisecond);this.year=u.getUTCFullYear(),this.month=u.getUTCMonth(),this.day=u.getUTCDay(),this.hour=u.getUTCHours(),this.minute=u.getUTCMinutes(),this.second=u.getUTCSeconds(),this.millisecond=u.getUTCMilliseconds()}}toString(t="iso"){if(t==="iso"){let e=[];return e.push(Vt(this.year,4)),e.push(Vt(this.month,2)),e.push(Vt(this.day,2)),e.push(Vt(this.hour,2)),e.push(Vt(this.minute,2)),e.push(Vt(this.second,2)),this.millisecond!==0&&(e.push("."),e.push(Vt(this.millisecond,3))),e.push("Z"),e.join("")}return super.toString(t)}toJSON(){return{...super.toJSON(),millisecond:this.millisecond}}};ou=Os;k.GeneralizedTime=ou;Os.NAME="GeneralizedTime";var au,Ms=class extends Ae{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=31}};au=Ms;k.DATE=au;Ms.NAME="DATE";var cu,Ps=class extends Ae{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=32}};cu=Ps;k.TimeOfDay=cu;Ps.NAME="TimeOfDay";var lu,Vs=class extends Ae{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=33}};lu=Vs;k.DateTime=lu;Vs.NAME="DateTime";var uu,Hs=class extends Ae{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=34}};uu=Hs;k.Duration=uu;Hs.NAME="Duration";var fu,Fs=class extends Ae{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=14}};fu=Fs;k.TIME=fu;Fs.NAME="TIME";function ct(r,t="utf8"){let e=Wn[t];if(e==null)throw new Error(`Unsupported encoding "${t}"`);return e.encoder.encode(r).substring(1)}var ln=class extends Error{constructor(t="An error occurred while verifying a message"){super(t),this.name="VerificationError"}},qs=class extends Error{constructor(t="Missing Web Crypto API"){super(t),this.name="WebCryptoMissingError"}};var hu={get(r=globalThis){let t=r.crypto;if(t?.subtle==null)throw new qs("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 qe=hu;async function du(r){let t=await qe.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 Kp(t);return{privateKey:e[0],publicKey:e[1]}}async function pu(r,t){let e=await qe.get().subtle.importKey("jwk",r,{name:"RSASSA-PKCS1-v1_5",hash:{name:"SHA-256"}},!1,["sign"]),n=await qe.get().subtle.sign({name:"RSASSA-PKCS1-v1_5"},e,t instanceof Uint8Array?t:t.subarray());return new Uint8Array(n,0,n.byteLength)}async function mu(r,t,e){let n=await qe.get().subtle.importKey("jwk",r,{name:"RSASSA-PKCS1-v1_5",hash:{name:"SHA-256"}},!1,["verify"]);return qe.get().subtle.verify({name:"RSASSA-PKCS1-v1_5"},n,t,e instanceof Uint8Array?e:e.subarray())}async function Kp(r){if(r.privateKey==null||r.publicKey==null)throw new Et("Private and public key are required");return Promise.all([qe.get().subtle.exportKey("jwk",r.privateKey),qe.get().subtle.exportKey("jwk",r.publicKey)])}function ca(r){if(r.kty!=="RSA")throw new Et("invalid key type");if(r.n==null)throw new Et("invalid key modulus");return G(r.n,"base64url").length*8}var kr=class{type="RSA";_key;_raw;_multihash;constructor(t,e){this._key=t,this._multihash=e}get raw(){return this._raw==null&&(this._raw=un.jwkToPkix(this._key)),this._raw}toMultihash(){return this._multihash}toCID(){return pt.createV1(114,this._multihash)}toString(){return tt.encode(this.toMultihash().bytes).substring(1)}equals(t){return t==null||!(t.raw instanceof Uint8Array)?!1:mt(this.raw,t.raw)}verify(t,e){return mu(this._key,e,t)}},fn=class{type="RSA";_key;_raw;publicKey;constructor(t,e){this._key=t,this.publicKey=e}get raw(){return this._raw==null&&(this._raw=un.jwkToPkcs1(this._key)),this._raw}equals(t){return t==null||!(t.raw instanceof Uint8Array)?!1:mt(this.raw,t.raw)}sign(t){return pu(this._key,t)}};var zs=8192,la=18;function gu(r){let{result:t}=aa(r),e=t.valueBlock.value;return{n:le(e[1]),e:le(e[2]),d:le(e[3]),p:le(e[4]),q:le(e[5]),dp:le(e[6]),dq:le(e[7]),qi:le(e[8]),kty:"RSA",alg:"RS256"}}function qp(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 Et("JWK was missing components");let e=new Se({value:[new wt({value:0}),wt.fromBigInt(ue(G(r.n,"base64url"))),wt.fromBigInt(ue(G(r.e,"base64url"))),wt.fromBigInt(ue(G(r.d,"base64url"))),wt.fromBigInt(ue(G(r.p,"base64url"))),wt.fromBigInt(ue(G(r.q,"base64url"))),wt.fromBigInt(ue(G(r.dp,"base64url"))),wt.fromBigInt(ue(G(r.dq,"base64url"))),wt.fromBigInt(ue(G(r.qi,"base64url")))]}).toBER();return new Uint8Array(e,0,e.byteLength)}function yu(r){let{result:t}=aa(r),e=t.valueBlock.value[1].valueBlock.value[0].valueBlock.value;return{kty:"RSA",n:le(e[0]),e:le(e[1])}}function ua(r){if(r.n==null||r.e==null)throw new Et("JWK was missing components");let e=new Se({value:[new Se({value:[new Ir({value:"1.2.840.113549.1.1.1"}),new Br]}),new _r({valueHex:new Se({value:[wt.fromBigInt(ue(G(r.n,"base64url"))),wt.fromBigInt(ue(G(r.e,"base64url")))]}).toBER()})]}).toBER();return new Uint8Array(e,0,e.byteLength)}function le(r){let t=r.valueBlock.valueHexView;for(;t[0]===0;)t=t.subarray(1);return ct(t,"base64url")}function ue(r){let t=[];return r.forEach(function(e){let n=e.toString(16);n.length%2>0&&(n=`0${n}`),t.push(n)}),BigInt("0x"+t.join(""))}function bu(r){let t=gu(r);return wu(t)}function fa(r){let t=yu(r);if(ca(t)>zs)throw new fr("Key size is too large");let e=Qn(ae.encode({Type:ft.RSA,Data:r})),n=Zt(la,e);return new kr(t,n)}function wu(r){if(ca(r)>zs)throw new Et("Key size is too large");let t=vu(r),e=Qn(ae.encode({Type:ft.RSA,Data:ua(t.publicKey)})),n=Zt(la,e);return new fn(t.privateKey,new kr(t.publicKey,n))}async function xu(r){if(r>zs)throw new Et("Key size is too large");let t=await du(r),e=Qn(ae.encode({Type:ft.RSA,Data:ua(t.publicKey)})),n=Zt(la,e);return new fn(t.privateKey,new kr(t.publicKey,n))}function vu(r){if(r==null)throw new Et("Missing key parameter");return{privateKey:r,publicKey:{kty:r.kty,n:r.n,e:r.e}}}var zp=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]),ze=new Uint32Array([1779033703,3144134277,1013904242,2773480762,1359893119,2600822924,528734635,1541459225]),$e=new Uint32Array(64),ha=class extends xr{constructor(){super(64,32,8,!1),this.A=ze[0]|0,this.B=ze[1]|0,this.C=ze[2]|0,this.D=ze[3]|0,this.E=ze[4]|0,this.F=ze[5]|0,this.G=ze[6]|0,this.H=ze[7]|0}get(){let{A:t,B:e,C:n,D:s,E:i,F:o,G:a,H:c}=this;return[t,e,n,s,i,o,a,c]}set(t,e,n,s,i,o,a,c){this.A=t|0,this.B=e|0,this.C=n|0,this.D=s|0,this.E=i|0,this.F=o|0,this.G=a|0,this.H=c|0}process(t,e){for(let u=0;u<16;u++,e+=4)$e[u]=t.getUint32(e,!1);for(let u=16;u<64;u++){let g=$e[u-15],l=$e[u-2],d=jt(g,7)^jt(g,18)^g>>>3,p=jt(l,17)^jt(l,19)^l>>>10;$e[u]=p+$e[u-7]+d+$e[u-16]|0}let{A:n,B:s,C:i,D:o,E:a,F:c,G:h,H:f}=this;for(let u=0;u<64;u++){let g=jt(a,6)^jt(a,11)^jt(a,25),l=f+g+Fc(a,c,h)+zp[u]+$e[u]|0,p=(jt(n,2)^jt(n,13)^jt(n,22))+Kc(n,s,i)|0;f=h,h=c,c=a,a=o+l|0,o=i,i=s,s=n,n=l+p|0}n=n+this.A|0,s=s+this.B|0,i=i+this.C|0,o=o+this.D|0,a=a+this.E|0,c=c+this.F|0,h=h+this.G|0,f=f+this.H|0,this.set(n,s,i,o,a,c,h,f)}roundClean(){$e.fill(0)}destroy(){this.set(0,0,0,0,0,0,0,0),this.buffer.fill(0)}};var Eu=Ln(()=>new ha);var $s=class extends wr{constructor(t,e){super(),this.finished=!1,this.destroyed=!1,Pc(t);let n=Gr(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 s=this.blockLen,i=new Uint8Array(s);i.set(n.length>s?t.create().update(n).digest():n);for(let o=0;o<i.length;o++)i[o]^=54;this.iHash.update(i),this.oHash=t.create();for(let o=0;o<i.length;o++)i[o]^=106;this.oHash.update(i),i.fill(0)}update(t){return br(this),this.iHash.update(t),this}digestInto(t){br(this),yr(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:s,destroyed:i,blockLen:o,outputLen:a}=this;return t=t,t.finished=s,t.destroyed=i,t.blockLen=o,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()}},da=(r,t,e)=>new $s(r,t).update(e).digest();da.create=(r,t)=>new $s(r,t);function Su(r){r.lowS!==void 0&&Yt("lowS",r.lowS),r.prehash!==void 0&&Yt("prehash",r.prehash)}function $p(r){let t=jr(r);oe(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:s}=t;if(e){if(!n.eql(s,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:Gp,hexToBytes:Wp}=Mn,Ie={Err:class extends Error{constructor(t=""){super(t)}},_tlv:{encode:(r,t)=>{let{Err:e}=Ie;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,s=Xe(n);if(s.length/2&128)throw new e("tlv.encode: long form length too big");let i=n>127?Xe(s.length/2|128):"";return Xe(r)+i+s+t},decode(r,t){let{Err:e}=Ie,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 s=t[n++],i=!!(s&128),o=0;if(!i)o=s;else{let c=s&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 h=t.subarray(n,n+c);if(h.length!==c)throw new e("tlv.decode: length bytes not complete");if(h[0]===0)throw new e("tlv.decode(long): zero leftmost byte");for(let f of h)o=o<<8|f;if(n+=c,o<128)throw new e("tlv.decode(long): not minimal encoding")}let a=t.subarray(n,n+o);if(a.length!==o)throw new e("tlv.decode: wrong value length");return{v:a,l:t.subarray(n+o)}}},_int:{encode(r){let{Err:t}=Ie;if(r<Te)throw new t("integer: negative integers are not allowed");let e=Xe(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}=Ie;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 Gp(r)}},toSig(r){let{Err:t,_int:e,_tlv:n}=Ie,s=typeof r=="string"?Wp(r):r;vr(s);let{v:i,l:o}=n.decode(48,s);if(o.length)throw new t("invalid signature: left bytes after parsing");let{v:a,l:c}=n.decode(2,i),{v:h,l:f}=n.decode(2,c);if(f.length)throw new t("invalid signature: left bytes after parsing");return{r:e.decode(a),s:e.decode(h)}},hexFromSig(r){let{_tlv:t,_int:e}=Ie,n=t.encode(2,e.encode(r.r)),s=t.encode(2,e.encode(r.s)),i=n+s;return t.encode(48,i)}},Te=BigInt(0),gt=BigInt(1),Vb=BigInt(2),Au=BigInt(3),Hb=BigInt(4);function Zp(r){let t=$p(r),{Fp:e}=t,n=Oe(t.n,t.nBitLength),s=t.toBytes||((p,y,b)=>{let w=y.toAffine();return we(Uint8Array.from([4]),e.toBytes(w.x),e.toBytes(w.y))}),i=t.fromBytes||(p=>{let y=p.subarray(1),b=e.fromBytes(y.subarray(0,e.BYTES)),w=e.fromBytes(y.subarray(e.BYTES,2*e.BYTES));return{x:b,y:w}});function o(p){let{a:y,b}=t,w=e.sqr(p),m=e.mul(w,p);return e.add(e.add(m,e.mul(p,y)),b)}if(!e.eql(e.sqr(t.Gy),o(t.Gx)))throw new Error("bad generator point: equation left != right");function a(p){return Wr(p,gt,t.n)}function c(p){let{allowedPrivateKeyLengths:y,nByteLength:b,wrapPrivateKey:w,n:m}=t;if(y&&typeof p!="bigint"){if(Re(p)&&(p=ye(p)),typeof p!="string"||!y.includes(p.length))throw new Error("invalid private key");p=p.padStart(b*2,"0")}let E;try{E=typeof p=="bigint"?p:be(ot("private key",p,b))}catch{throw new Error("invalid private key, expected hex or "+b+" bytes, got "+typeof p)}return w&&(E=J(E,m)),Rt("private key",E,gt,m),E}function h(p){if(!(p instanceof g))throw new Error("ProjectivePoint expected")}let f=tr((p,y)=>{let{px:b,py:w,pz:m}=p;if(e.eql(m,e.ONE))return{x:b,y:w};let E=p.is0();y==null&&(y=E?e.ONE:e.inv(m));let A=e.mul(b,y),_=e.mul(w,y),x=e.mul(m,y);if(E)return{x:e.ZERO,y:e.ZERO};if(!e.eql(x,e.ONE))throw new Error("invZ was invalid");return{x:A,y:_}}),u=tr(p=>{if(p.is0()){if(t.allowInfinityPoint&&!e.is0(p.py))return;throw new Error("bad point: ZERO")}let{x:y,y:b}=p.toAffine();if(!e.isValid(y)||!e.isValid(b))throw new Error("bad point: x or y not FE");let w=e.sqr(b),m=o(y);if(!e.eql(w,m))throw new Error("bad point: equation left != right");if(!p.isTorsionFree())throw new Error("bad point: not in prime-order subgroup");return!0});class g{constructor(y,b,w){if(this.px=y,this.py=b,this.pz=w,y==null||!e.isValid(y))throw new Error("x required");if(b==null||!e.isValid(b))throw new Error("y required");if(w==null||!e.isValid(w))throw new Error("z required");Object.freeze(this)}static fromAffine(y){let{x:b,y:w}=y||{};if(!y||!e.isValid(b)||!e.isValid(w))throw new Error("invalid affine point");if(y instanceof g)throw new Error("projective point not allowed");let m=E=>e.eql(E,e.ZERO);return m(b)&&m(w)?g.ZERO:new g(b,w,e.ONE)}get x(){return this.toAffine().x}get y(){return this.toAffine().y}static normalizeZ(y){let b=e.invertBatch(y.map(w=>w.pz));return y.map((w,m)=>w.toAffine(b[m])).map(g.fromAffine)}static fromHex(y){let b=g.fromAffine(i(ot("pointHex",y)));return b.assertValidity(),b}static fromPrivateKey(y){return g.BASE.multiply(c(y))}static msm(y,b){return Fn(g,n,y,b)}_setWindowSize(y){d.setWindowSize(this,y)}assertValidity(){u(this)}hasEvenY(){let{y}=this.toAffine();if(e.isOdd)return!e.isOdd(y);throw new Error("Field doesn't support isOdd")}equals(y){h(y);let{px:b,py:w,pz:m}=this,{px:E,py:A,pz:_}=y,x=e.eql(e.mul(b,_),e.mul(E,m)),I=e.eql(e.mul(w,_),e.mul(A,m));return x&&I}negate(){return new g(this.px,e.neg(this.py),this.pz)}double(){let{a:y,b}=t,w=e.mul(b,Au),{px:m,py:E,pz:A}=this,_=e.ZERO,x=e.ZERO,I=e.ZERO,C=e.mul(m,m),j=e.mul(E,E),V=e.mul(A,A),P=e.mul(m,E);return P=e.add(P,P),I=e.mul(m,A),I=e.add(I,I),_=e.mul(y,I),x=e.mul(w,V),x=e.add(_,x),_=e.sub(j,x),x=e.add(j,x),x=e.mul(_,x),_=e.mul(P,_),I=e.mul(w,I),V=e.mul(y,V),P=e.sub(C,V),P=e.mul(y,P),P=e.add(P,I),I=e.add(C,C),C=e.add(I,C),C=e.add(C,V),C=e.mul(C,P),x=e.add(x,C),V=e.mul(E,A),V=e.add(V,V),C=e.mul(V,P),_=e.sub(_,C),I=e.mul(V,j),I=e.add(I,I),I=e.add(I,I),new g(_,x,I)}add(y){h(y);let{px:b,py:w,pz:m}=this,{px:E,py:A,pz:_}=y,x=e.ZERO,I=e.ZERO,C=e.ZERO,j=t.a,V=e.mul(t.b,Au),P=e.mul(b,E),R=e.mul(w,A),T=e.mul(m,_),L=e.add(b,w),S=e.add(E,A);L=e.mul(L,S),S=e.add(P,R),L=e.sub(L,S),S=e.add(b,m);let v=e.add(E,_);return S=e.mul(S,v),v=e.add(P,T),S=e.sub(S,v),v=e.add(w,m),x=e.add(A,_),v=e.mul(v,x),x=e.add(R,T),v=e.sub(v,x),C=e.mul(j,S),x=e.mul(V,T),C=e.add(x,C),x=e.sub(R,C),C=e.add(R,C),I=e.mul(x,C),R=e.add(P,P),R=e.add(R,P),T=e.mul(j,T),S=e.mul(V,S),R=e.add(R,T),T=e.sub(P,T),T=e.mul(j,T),S=e.add(S,T),P=e.mul(R,S),I=e.add(I,P),P=e.mul(v,S),x=e.mul(L,x),x=e.sub(x,P),P=e.mul(L,R),C=e.mul(v,C),C=e.add(C,P),new g(x,I,C)}subtract(y){return this.add(y.negate())}is0(){return this.equals(g.ZERO)}wNAF(y){return d.wNAFCached(this,y,g.normalizeZ)}multiplyUnsafe(y){let{endo:b,n:w}=t;Rt("scalar",y,Te,w);let m=g.ZERO;if(y===Te)return m;if(this.is0()||y===gt)return this;if(!b||d.hasPrecomputes(this))return d.wNAFCachedUnsafe(this,y,g.normalizeZ);let{k1neg:E,k1:A,k2neg:_,k2:x}=b.splitScalar(y),I=m,C=m,j=this;for(;A>Te||x>Te;)A>&&(I=I.add(j)),x>&&(C=C.add(j)),j=j.double(),A>>=gt,x>>=gt;return E&&(I=I.negate()),_&&(C=C.negate()),C=new g(e.mul(C.px,b.beta),C.py,C.pz),I.add(C)}multiply(y){let{endo:b,n:w}=t;Rt("scalar",y,gt,w);let m,E;if(b){let{k1neg:A,k1:_,k2neg:x,k2:I}=b.splitScalar(y),{p:C,f:j}=this.wNAF(_),{p:V,f:P}=this.wNAF(I);C=d.constTimeNegate(A,C),V=d.constTimeNegate(x,V),V=new g(e.mul(V.px,b.beta),V.py,V.pz),m=C.add(V),E=j.add(P)}else{let{p:A,f:_}=this.wNAF(y);m=A,E=_}return g.normalizeZ([m,E])[0]}multiplyAndAddUnsafe(y,b,w){let m=g.BASE,E=(_,x)=>x===Te||x===gt||!_.equals(m)?_.multiplyUnsafe(x):_.multiply(x),A=E(this,b).add(E(y,w));return A.is0()?void 0:A}toAffine(y){return f(this,y)}isTorsionFree(){let{h:y,isTorsionFree:b}=t;if(y===gt)return!0;if(b)return b(g,this);throw new Error("isTorsionFree() has not been declared for the elliptic curve")}clearCofactor(){let{h:y,clearCofactor:b}=t;return y===gt?this:b?b(g,this):this.multiplyUnsafe(t.h)}toRawBytes(y=!0){return Yt("isCompressed",y),this.assertValidity(),s(g,this,y)}toHex(y=!0){return Yt("isCompressed",y),ye(this.toRawBytes(y))}}g.BASE=new g(t.Gx,t.Gy,e.ONE),g.ZERO=new g(e.ZERO,e.ONE,e.ZERO);let l=t.nBitLength,d=Hn(g,t.endo?Math.ceil(l/2):l);return{CURVE:t,ProjectivePoint:g,normPrivateKeyToScalar:c,weierstrassEquation:o,isWithinCurveOrder:a}}function jp(r){let t=jr(r);return oe(t,{hash:"hash",hmac:"function",randomBytes:"function"},{bits2int:"function",bits2int_modN:"function",lowS:"boolean"}),Object.freeze({lowS:!0,...t})}function Bu(r){let t=jp(r),{Fp:e,n}=t,s=e.BYTES+1,i=2*e.BYTES+1;function o(T){return J(T,n)}function a(T){return Pn(T,n)}let{ProjectivePoint:c,normPrivateKeyToScalar:h,weierstrassEquation:f,isWithinCurveOrder:u}=Zp({...t,toBytes(T,L,S){let v=L.toAffine(),B=e.toBytes(v.x),N=we;return Yt("isCompressed",S),S?N(Uint8Array.from([L.hasEvenY()?2:3]),B):N(Uint8Array.from([4]),B,e.toBytes(v.y))},fromBytes(T){let L=T.length,S=T[0],v=T.subarray(1);if(L===s&&(S===2||S===3)){let B=be(v);if(!Wr(B,gt,e.ORDER))throw new Error("Point is not on curve");let N=f(B),U;try{U=e.sqrt(N)}catch($){let O=$ instanceof Error?": "+$.message:"";throw new Error("Point is not on curve"+O)}let D=(U>)===gt;return(S&1)===1!==D&&(U=e.neg(U)),{x:B,y:U}}else if(L===i&&S===4){let B=e.fromBytes(v.subarray(0,e.BYTES)),N=e.fromBytes(v.subarray(e.BYTES,2*e.BYTES));return{x:B,y:N}}else{let B=s,N=i;throw new Error("invalid Point, expected length of "+B+", or uncompressed "+N+", got "+L)}}}),g=T=>ye(De(T,t.nByteLength));function l(T){let L=n>>gt;return T>L}function d(T){return l(T)?o(-T):T}let p=(T,L,S)=>be(T.slice(L,S));class y{constructor(L,S,v){this.r=L,this.s=S,this.recovery=v,this.assertValidity()}static fromCompact(L){let S=t.nByteLength;return L=ot("compactSignature",L,S*2),new y(p(L,0,S),p(L,S,2*S))}static fromDER(L){let{r:S,s:v}=Ie.toSig(ot("DER",L));return new y(S,v)}assertValidity(){Rt("r",this.r,gt,n),Rt("s",this.s,gt,n)}addRecoveryBit(L){return new y(this.r,this.s,L)}recoverPublicKey(L){let{r:S,s:v,recovery:B}=this,N=_(ot("msgHash",L));if(B==null||![0,1,2,3].includes(B))throw new Error("recovery id invalid");let U=B===2||B===3?S+t.n:S;if(U>=e.ORDER)throw new Error("recovery id 2 or 3 invalid");let D=B&1?"03":"02",H=c.fromHex(D+g(U)),$=a(U),O=o(-N*$),Y=o(v*$),rt=c.BASE.multiplyAndAddUnsafe(H,O,Y);if(!rt)throw new Error("point at infinify");return rt.assertValidity(),rt}hasHighS(){return l(this.s)}normalizeS(){return this.hasHighS()?new y(this.r,o(-this.s),this.recovery):this}toDERRawBytes(){return Je(this.toDERHex())}toDERHex(){return Ie.hexFromSig({r:this.r,s:this.s})}toCompactRawBytes(){return Je(this.toCompactHex())}toCompactHex(){return g(this.r)+g(this.s)}}let b={isValidPrivateKey(T){try{return h(T),!0}catch{return!1}},normPrivateKeyToScalar:h,randomPrivateKey:()=>{let T=po(t.n);return Xc(t.randomBytes(T),t.n)},precompute(T=8,L=c.BASE){return L._setWindowSize(T),L.multiply(BigInt(3)),L}};function w(T,L=!0){return c.fromPrivateKey(T).toRawBytes(L)}function m(T){let L=Re(T),S=typeof T=="string",v=(L||S)&&T.length;return L?v===s||v===i:S?v===2*s||v===2*i:T instanceof c}function E(T,L,S=!0){if(m(T))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(h(T)).toRawBytes(S)}let A=t.bits2int||function(T){if(T.length>8192)throw new Error("input is too large");let L=be(T),S=T.length*8-t.nBitLength;return S>0?L>>BigInt(S):L},_=t.bits2int_modN||function(T){return o(A(T))},x=Zr(t.nBitLength);function I(T){return Rt("num < 2^"+t.nBitLength,T,Te,x),De(T,t.nByteLength)}function C(T,L,S=j){if(["recovered","canonical"].some(dt=>dt in S))throw new Error("sign() legacy options not supported");let{hash:v,randomBytes:B}=t,{lowS:N,prehash:U,extraEntropy:D}=S;N==null&&(N=!0),T=ot("msgHash",T),Su(S),U&&(T=ot("prehashed msgHash",v(T)));let H=_(T),$=h(L),O=[I($),I(H)];if(D!=null&&D!==!1){let dt=D===!0?B(e.BYTES):D;O.push(ot("extraEntropy",dt))}let Y=we(...O),rt=H;function ht(dt){let yt=A(dt);if(!u(yt))return;let vt=a(yt),Nt=c.BASE.multiply(yt).toAffine(),Tt=o(Nt.x);if(Tt===Te)return;let se=o(vt*o(rt+Tt*$));if(se===Te)return;let fe=(Nt.x===Tt?0:2)|Number(Nt.y>),Hr=se;return N&&l(se)&&(Hr=d(se),fe^=1),new y(Tt,Hr,fe)}return{seed:Y,k2sig:ht}}let j={lowS:t.lowS,prehash:!1},V={lowS:t.lowS,prehash:!1};function P(T,L,S=j){let{seed:v,k2sig:B}=C(T,L,S),N=t;return lo(N.hash.outputLen,N.nByteLength,N.hmac)(v,B)}c.BASE._setWindowSize(8);function R(T,L,S,v=V){let B=T;L=ot("msgHash",L),S=ot("publicKey",S);let{lowS:N,prehash:U,format:D}=v;if(Su(v),"strict"in v)throw new Error("options.strict was renamed to lowS");if(D!==void 0&&D!=="compact"&&D!=="der")throw new Error("format must be compact or der");let H=typeof B=="string"||Re(B),$=!H&&!D&&typeof B=="object"&&B!==null&&typeof B.r=="bigint"&&typeof B.s=="bigint";if(!H&&!$)throw new Error("invalid signature, expected Uint8Array, hex string or Signature instance");let O,Y;try{if($&&(O=new y(B.r,B.s)),H){try{D!=="compact"&&(O=y.fromDER(B))}catch(fe){if(!(fe instanceof Ie.Err))throw fe}!O&&D!=="der"&&(O=y.fromCompact(B))}Y=c.fromHex(S)}catch{return!1}if(!O||N&&O.hasHighS())return!1;U&&(L=t.hash(L));let{r:rt,s:ht}=O,dt=_(L),yt=a(ht),vt=o(dt*yt),Nt=o(rt*yt),Tt=c.BASE.multiplyAndAddUnsafe(Y,vt,Nt)?.toAffine();return Tt?o(Tt.x)===rt:!1}return{CURVE:t,getPublicKey:w,getSharedSecret:E,sign:P,verify:R,ProjectivePoint:c,Signature:y,utils:b}}function Yp(r){return{hash:r,hmac:(t,...e)=>da(r,t,ro(...e)),randomBytes:Rn}}function _u(r,t){let e=n=>Bu({...r,...Yp(n)});return Object.freeze({...e(t),create:e})}var ku=BigInt("0xfffffffffffffffffffffffffffffffffffffffffffffffffffffffefffffc2f"),Iu=BigInt("0xfffffffffffffffffffffffffffffffebaaedce6af48a03bbfd25e8cd0364141"),Xp=BigInt(1),pa=BigInt(2),Tu=(r,t)=>(r+t/pa)/t;function Jp(r){let t=ku,e=BigInt(3),n=BigInt(6),s=BigInt(11),i=BigInt(22),o=BigInt(23),a=BigInt(44),c=BigInt(88),h=r*r*r%t,f=h*h*r%t,u=it(f,e,t)*f%t,g=it(u,e,t)*f%t,l=it(g,pa,t)*h%t,d=it(l,s,t)*l%t,p=it(d,i,t)*d%t,y=it(p,a,t)*p%t,b=it(y,c,t)*y%t,w=it(b,a,t)*p%t,m=it(w,e,t)*f%t,E=it(m,o,t)*d%t,A=it(E,n,t)*h%t,_=it(A,pa,t);if(!ma.eql(ma.sqr(_),r))throw new Error("Cannot find square root");return _}var ma=Oe(ku,void 0,void 0,{sqrt:Jp}),or=_u({a:BigInt(0),b:BigInt(7),Fp:ma,n:Iu,Gx:BigInt("55066263022277343669578718895168534326250603453777594175500187360389116729240"),Gy:BigInt("32670510020758816978083085130507043184471273380659243275938904335757337482424"),h:BigInt(1),lowS:!0,endo:{beta:BigInt("0x7ae96a2b657c07106e64479eac3434e99cf0497512f58995c1396c28719501ee"),splitScalar:r=>{let t=Iu,e=BigInt("0x3086d221a7d46bcde86c90e49284eb15"),n=-Xp*BigInt("0xe4437ed6010e88286f547fa90abfe4c3"),s=BigInt("0x114ca50f7a8e2f3f657c1108d9d44cfd8"),i=e,o=BigInt("0x100000000000000000000000000000000"),a=Tu(i*r,t),c=Tu(-n*r,t),h=J(r-a*e-c*s,t),f=J(-a*n-c*i,t),u=h>o,g=f>o;if(u&&(h=t-h),g&&(f=t-f),h>o||f>o)throw new Error("splitScalar: Endomorphism failed, k="+r);return{k1neg:u,k1:h,k2neg:g,k2:f}}}},Eu),jb=BigInt(0);var Yb=or.ProjectivePoint;function Ft(r,t){t==null&&(t=r.reduce((s,i)=>s+i.length,0));let e=Dt(t),n=0;for(let s of r)e.set(s,n),n+=s.length;return e}function Cu(r){return r==null?!1:typeof r.then=="function"&&typeof r.catch=="function"&&typeof r.finally=="function"}function Nu(r,t,e){let n=Er.digest(e instanceof Uint8Array?e:e.subarray());if(Cu(n))return n.then(({digest:s})=>or.verify(t,s,r)).catch(s=>{throw new ln(String(s))});try{return or.verify(t,n.digest,r)}catch(s){throw new ln(String(s))}}var Gs=class{type="secp256k1";raw;_key;constructor(t){this._key=Ru(t),this.raw=Lu(this._key)}toMultihash(){return me.digest(Me(this))}toCID(){return pt.createV1(114,this.toMultihash())}toString(){return tt.encode(this.toMultihash().bytes).substring(1)}equals(t){return t==null||!(t.raw instanceof Uint8Array)?!1:mt(this.raw,t.raw)}verify(t,e){return Nu(this._key,e,t)}};function ga(r){return new Gs(r)}function Lu(r){return or.ProjectivePoint.fromHex(r).toRawBytes(!0)}function Ru(r){try{return or.ProjectivePoint.fromHex(r),r}catch(t){throw new fr(String(t))}}function Uu(r){let{Type:t,Data:e}=ae.decode(r),n=e??new Uint8Array;switch(t){case ft.RSA:return fa(n);case ft.Ed25519:return vo(n);case ft.secp256k1:return ga(n);default:throw new hr}}function Du(r){let{Type:t,Data:e}=ae.decode(r.digest),n=e??new Uint8Array;switch(t){case ft.Ed25519:return vo(n);case ft.secp256k1:return ga(n);default:throw new hr}}function Me(r){return ae.encode({Type:ft[r.type],Data:r.raw})}var Ou=Symbol.for("nodejs.util.inspect.custom"),Qp=114,hn=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()})`}[zi]=!0;toString(){return this.string==null&&(this.string=tt.encode(this.multihash.bytes).slice(1)),this.string}toMultihash(){return this.multihash}toCID(){return pt.createV1(Qp,this.multihash)}toJSON(){return this.toString()}equals(t){if(t==null)return!1;if(t instanceof Uint8Array)return mt(this.multihash.bytes,t);if(typeof t=="string")return this.toString()===t;if(t?.toMultihash()?.bytes!=null)return mt(this.multihash.bytes,t.toMultihash().bytes);throw new Error("not valid Id")}[Ou](){return`PeerId(${this.toString()})`}},Ws=class extends hn{type="RSA";publicKey;constructor(t){super({...t,type:"RSA"}),this.publicKey=t.publicKey}},Zs=class extends hn{type="Ed25519";publicKey;constructor(t){super({...t,type:"Ed25519"}),this.publicKey=t.publicKey}},js=class extends hn{type="secp256k1";publicKey;constructor(t){super({...t,type:"secp256k1"}),this.publicKey=t.publicKey}},t0=2336,Ys=class{type="url";multihash;publicKey;url;constructor(t){this.url=t.toString(),this.multihash=me.digest(G(this.url))}[Ou](){return`PeerId(${this.url})`}[zi]=!0;toString(){return this.toCID().toString()}toMultihash(){return this.multihash}toCID(){return pt.createV1(t0,this.toMultihash())}toJSON(){return this.toString()}equals(t){return t==null?!1:(t instanceof Uint8Array&&(t=ct(t)),t.toString()===this.toString())}};function ya(r,t){let e;if(r.charAt(0)==="1"||r.charAt(0)==="Q")e=zt(tt.decode(`z${r}`));else{if(t==null)throw new Et('Please pass a multibase decoder for strings that do not start with "1" or "Q"');e=zt(t.decode(r))}return dn(e)}function dn(r){if(r0(r))return new Ws({multihash:r});if(e0(r))try{let t=Du(r);if(t.type==="Ed25519")return new Zs({multihash:r,publicKey:t});if(t.type==="secp256k1")return new js({multihash:r,publicKey:t})}catch{let e=ct(r.digest);return new Ys(new URL(e))}throw new Tn("Supplied PeerID Multihash is invalid")}function e0(r){return r.code===me.code}function r0(r){return r.code===Er.code}var Pu=Symbol.for("@achingbrain/uint8arraylist");function Mu(r,t){if(t==null||t<0)throw new RangeError("index is out of bounds");let e=0;for(let n of r){let s=e+n.byteLength;if(t<s)return{buf:n,index:t-e};e=s}throw new RangeError("index is out of bounds")}function Xs(r){return!!r?.[Pu]}var ee=class r{bufs;length;[Pu]=!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(Xs(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(Xs(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=Mu(this.bufs,t);return e.buf[e.index]}set(t,e){let n=Mu(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(Xs(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:s}=this._subList(t,e);return Ft(n,s)}subarray(t,e){let{bufs:n,length:s}=this._subList(t,e);return n.length===1?n[0]:Ft(n,s)}sublist(t,e){let{bufs:n,length:s}=this._subList(t,e),i=new r;return i.length=s,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=[],s=0;for(let i=0;i<this.bufs.length;i++){let o=this.bufs[i],a=s,c=a+o.byteLength;if(s=c,t>=c)continue;let h=t>=a&&t<c,f=e>a&&e<=c;if(h&&f){if(t===a&&e===c){n.push(o);break}let u=t-a;n.push(o.subarray(u,u+(e-t)));break}if(h){if(t===0){n.push(o);continue}n.push(o.subarray(t-a));continue}if(f){if(e===c){n.push(o);break}n.push(o.subarray(0,e-a));break}n.push(o)}return{bufs:n,length:e-t}}indexOf(t,e=0){if(!Xs(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 s=n.byteLength;if(s===0)throw new TypeError("search must be at least 1 byte long");let i=256,o=new Int32Array(i);for(let u=0;u<i;u++)o[u]=-1;for(let u=0;u<s;u++)o[n[u]]=u;let a=o,c=this.byteLength-n.byteLength,h=n.byteLength-1,f;for(let u=e;u<=c;u+=f){f=0;for(let g=h;g>=0;g--){let l=this.get(u+g);if(n[g]!==l){f=Math.max(1,g-a[l]);break}}if(f===0)return u}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=Dt(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 s=at(2);new DataView(s.buffer,s.byteOffset,s.byteLength).setInt16(0,e,n),this.write(s,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 s=at(4);new DataView(s.buffer,s.byteOffset,s.byteLength).setInt32(0,e,n),this.write(s,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 s=at(8);new DataView(s.buffer,s.byteOffset,s.byteLength).setBigInt64(0,e,n),this.write(s,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=Dt(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 s=at(2);new DataView(s.buffer,s.byteOffset,s.byteLength).setUint16(0,e,n),this.write(s,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 s=at(4);new DataView(s.buffer,s.byteOffset,s.byteLength).setUint32(0,e,n),this.write(s,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 s=at(8);new DataView(s.buffer,s.byteOffset,s.byteLength).setBigUint64(0,e,n),this.write(s,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 s=at(4);new DataView(s.buffer,s.byteOffset,s.byteLength).setFloat32(0,e,n),this.write(s,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 s=at(8);new DataView(s.buffer,s.byteOffset,s.byteLength).setFloat64(0,e,n),this.write(s,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(!mt(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((s,i)=>s+i.byteLength,0)),n.length=e,n}};var pn;(function(r){let t;r.codec=()=>(t==null&&(t=Pt((e,n,s={})=>{s.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)),s.lengthDelimited!==!1&&n.ldelim()},(e,n,s={})=>{let i={publicKey:at(0),payloadType:at(0),payload:at(0),signature:at(0)},o=n==null?e.len:e.pos+n;for(;e.pos<o;){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=>Mt(e,r.codec()),r.decode=(e,n)=>Ot(e,r.codec(),n)})(pn||(pn={}));var Js=class extends Error{constructor(t="Invalid signature"){super(t),this.name="InvalidSignatureError"}};var mn=class r{static createFromProtobuf=async t=>{let e=pn.decode(t),n=Uu(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,s=t.codec,i=t.marshal(),o=Vu(n,s,i),a=await e.sign(o.subarray());return new r({publicKey:e.publicKey,payloadType:s,payload:i,signature:a})};static openAndCertify=async(t,e)=>{let n=await r.createFromProtobuf(t);if(!await n.validate(e))throw new Js("Envelope signature is not valid for the given domain");return n};publicKey;payloadType;payload;signature;marshaled;constructor(t){let{publicKey:e,payloadType:n,payload:s,signature:i}=t;this.publicKey=e,this.payloadType=n,this.payload=s,this.signature=i}marshal(){return this.marshaled==null&&(this.marshaled=pn.encode({publicKey:Me(this.publicKey),payloadType:this.payloadType,payload:this.payload.subarray(),signature:this.signature})),this.marshaled}equals(t){return mt(this.marshal(),t.marshal())}async validate(t){let e=Vu(t,this.payloadType,this.payload);return this.publicKey.verify(e.subarray(),this.signature)}},Vu=(r,t,e)=>{let n=G(r),s=$t(n.byteLength),i=$t(t.length),o=$t(e.length);return new ee(s,n,i,t,o,e)};var Qs=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,s){return this.readAtomically(()=>{let i=0,o=0,a=this.peekChar();if(a===void 0)return;let c=a==="0",h=2**(8*s)-1;for(;;){let f=this.readAtomically(()=>{let u=this.readChar();if(u===void 0)return;let g=Number.parseInt(u,t);if(!Number.isNaN(g))return g});if(f===void 0)break;if(i*=t,i+=f,i>h||(o+=1,e!==void 0&&o>e))return}if(o!==0)return!n&&c&&o>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 s=n*2;if(n<e.length-3){let o=this.readSeparator(":",n,()=>this.readIPv4Addr());if(o!==void 0)return e[s]=o[0],e[s+1]=o[1],e[s+2]=o[2],e[s+3]=o[3],[s+4,!0]}let i=this.readSeparator(":",n,()=>this.readNumber(16,4,!0,2));if(i===void 0)return[s,!1];e[s]=i>>8,e[s+1]=i&255}return[e.length,!1]};return this.readAtomically(()=>{let e=new Uint8Array(16),[n,s]=t(e);if(n===16)return e;if(s||this.readGivenChar(":")===void 0||this.readGivenChar(":")===void 0)return;let i=new Uint8Array(14),o=16-(n+2),[a]=t(i.subarray(0,o));return e.set(i.subarray(0,a),16-a),e})}readIPAddr(){return this.readIPv4Addr()??this.readIPv6Addr()}};var Hu=45,n0=15,Cr=new Qs;function ba(r){if(!(r.length>n0))return Cr.new(r).parseWith(()=>Cr.readIPv4Addr())}function wa(r){if(r.includes("%")&&(r=r.split("%")[0]),!(r.length>Hu))return Cr.new(r).parseWith(()=>Cr.readIPv6Addr())}function ti(r){if(r.includes("%")&&(r=r.split("%")[0]),!(r.length>Hu))return Cr.new(r).parseWith(()=>Cr.readIPAddr())}var Ix=parseInt("0xFFFF",16),Tx=new Uint8Array([0,0,0,0,0,0,0,0,0,0,255,255]);function ei(r){return!!ba(r)}function ri(r){return!!wa(r)}function ni(r){return!!ti(r)}var qu=ei,c0=ri,xa=function(r){let t=0;if(r=r.toString().trim(),qu(r)){let e=new Uint8Array(t+4);return r.split(/\./g).forEach(n=>{e[t++]=parseInt(n,10)&255}),e}if(c0(r)){let e=r.split(":",8),n;for(n=0;n<e.length;n++){let i=qu(e[n]),o;i&&(o=xa(e[n]),e[n]=ct(o.slice(0,2),"base16")),o!=null&&++n<8&&e.splice(n,0,ct(o.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 s=new Uint8Array(t+16);for(n=0;n<e.length;n++){let i=parseInt(e[n],16);s[t++]=i>>8&255,s[t++]=i&255}return s}throw new Error("invalid ip address")},zu=function(r,t=0,e){t=~~t,e=e??r.length-t;let n=new DataView(r.buffer);if(e===4){let s=[];for(let i=0;i<e;i++)s.push(r[t+i]);return s.join(".")}if(e===16){let s=[];for(let i=0;i<e;i+=2)s.push(n.getUint16(t+i).toString(16));return s.join(":").replace(/(^|:)0(:0)*:0(:|$)/,"$1::$3").replace(/:{3,4}/,"::")}return""};var Nr={},va={},u0=[[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"]];u0.forEach(r=>{let t=f0(...r);va[t.code]=t,Nr[t.name]=t});function f0(r,t,e,n,s){return{code:r,size:t,name:e,resolvable:!!n,path:!!s}}function et(r){if(typeof r=="number"){if(va[r]!=null)return va[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 f1=et("ip4"),h1=et("ip6"),d1=et("ipcidr");function Ba(r,t){switch(et(r).code){case 4:case 41:return d0(t);case 42:return Aa(t);case 43:return ct(t,"base10");case 6:case 273:case 33:case 132:return Wu(t).toString();case 53:case 54:case 55:case 56:case 400:case 449:case 777:return Aa(t);case 421:return y0(t);case 444:return Gu(t);case 445:return Gu(t);case 466:return g0(t);case 481:return globalThis.encodeURIComponent(Aa(t));default:return ct(t,"base16")}}function _a(r,t){switch(et(r).code){case 4:return $u(t);case 41:return $u(t);case 42:return Sa(t);case 43:return G(t,"base10");case 6:case 273:case 33:case 132:return Ia(parseInt(t,10));case 53:case 54:case 55:case 56:case 400:case 449:case 777:return Sa(t);case 421:return p0(t);case 444:return b0(t);case 445:return w0(t);case 466:return m0(t);case 481:return Sa(globalThis.decodeURIComponent(t));default:return G(t,"base16")}}var Ea=Object.values(Yr).map(r=>r.decoder),h0=function(){let r=Ea[0].or(Ea[1]);return Ea.slice(2).forEach(t=>r=r.or(t)),r}();function $u(r){if(!ni(r))throw new Error("invalid ip address");return xa(r)}function d0(r){let t=zu(r,0,r.length);if(t==null)throw new Error("ipBuff is required");if(!ni(t))throw new Error("invalid ip address");return t}function Ia(r){let t=new ArrayBuffer(2);return new DataView(t).setUint16(0,r),new Uint8Array(t)}function Wu(r){return new DataView(r.buffer).getUint16(r.byteOffset)}function Sa(r){let t=G(r),e=Uint8Array.from($t(t.length));return Ft([e,t],e.length+t.length)}function Aa(r){let t=xe(r);if(r=r.slice(At(t)),r.length!==t)throw new Error("inconsistent lengths");return ct(r)}function p0(r){let t;r[0]==="Q"||r[0]==="1"?t=zt(tt.decode(`z${r}`)).bytes:t=pt.parse(r).multihash.bytes;let e=Uint8Array.from($t(t.length));return Ft([e,t],e.length+t.length)}function m0(r){let t=h0.decode(r),e=Uint8Array.from($t(t.length));return Ft([e,t],e.length+t.length)}function g0(r){let t=xe(r),e=r.slice(At(t));if(e.length!==t)throw new Error("inconsistent lengths");return"u"+ct(e,"base64url")}function y0(r){let t=xe(r),e=r.slice(At(t));if(e.length!==t)throw new Error("inconsistent lengths");return ct(e,"base58btc")}function b0(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=pe.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 s=Ia(n);return Ft([e,s],e.length+s.length)}function w0(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=pe.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 s=Ia(n);return Ft([e,s],e.length+s.length)}function Gu(r){let t=r.slice(0,r.length-2),e=r.slice(r.length-2),n=ct(t,"base32"),s=Wu(e);return`${n}:${s}`}function Zu(r){r=Ta(r);let t=[],e=[],n=null,s=r.split("/").slice(1);if(s.length===1&&s[0]==="")return{bytes:new Uint8Array,string:"/",tuples:[],stringTuples:[],path:null};for(let i=0;i<s.length;i++){let o=s[i],a=et(o);if(a.size===0){t.push([a.code]),e.push([a.code]);continue}if(i++,i>=s.length)throw Yu("invalid address: "+r);if(a.path===!0){n=Ta(s.slice(i).join("/")),t.push([a.code,_a(a.code,n)]),e.push([a.code,n]);break}let c=_a(a.code,s[i]);t.push([a.code,c]),e.push([a.code,Ba(a.code,c)])}return{string:ju(e),bytes:Ca(t),tuples:t,stringTuples:e,path:n}}function ka(r){let t=[],e=[],n=null,s=0;for(;s<r.length;){let i=xe(r,s),o=At(i),a=et(i),c=x0(a,r.slice(s+o));if(c===0){t.push([i]),e.push([i]),s+=o;continue}let h=r.slice(s+o,s+o+c);if(s+=c+o,s>r.length)throw Yu("Invalid address Uint8Array: "+ct(r,"base16"));t.push([i,h]);let f=Ba(i,h);if(e.push([i,f]),a.path===!0){n=f;break}}return{bytes:Uint8Array.from(r),string:ju(e),tuples:t,stringTuples:e,path:n}}function ju(r){let t=[];return r.map(e=>{let n=et(e[0]);return t.push(n.name),e.length>1&&e[1]!=null&&t.push(e[1]),null}),Ta(t.join("/"))}function Ca(r){return Ft(r.map(t=>{let e=et(t[0]),n=Uint8Array.from($t(e.code));return t.length>1&&t[1]!=null&&(n=Ft([n,t[1]])),n}))}function x0(r,t){if(r.size>0)return r.size/8;if(r.size===0)return 0;{let e=xe(t instanceof Uint8Array?t:Uint8Array.from(t));return e+At(e)}}function Ta(r){return"/"+r.trim().split("/").filter(t=>t).join("/")}function Yu(r){return new Error("Error parsing address: "+r)}var v0=Symbol.for("nodejs.util.inspect.custom"),La=Symbol.for("@multiformats/js-multiaddr/multiaddr"),E0=[et("dns").code,et("dns4").code,et("dns6").code,et("dnsaddr").code],Na=class extends Error{constructor(t="No available resolver"){super(t),this.name="NoAvailableResolverError"}},si=class r{bytes;#t;#e;#r;#n;[La]=!0;constructor(t){t==null&&(t="");let e;if(t instanceof Uint8Array)e=ka(t);else if(typeof t=="string"){if(t.length>0&&t.charAt(0)!=="/")throw new Error(`multiaddr "${t}" must start with a "/"`);e=Zu(t)}else if(Ju(t))e=ka(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,s,i="",o=et("tcp"),a=et("udp"),c=et("ip4"),h=et("ip6"),f=et("dns6"),u=et("ip6zone");for(let[l,d]of this.stringTuples())l===u.code&&(i=`%${d??""}`),E0.includes(l)&&(e=o.name,s=443,n=`${d??""}${i}`,t=l===f.code?6:4),(l===o.code||l===a.code)&&(e=et(l).name,s=parseInt(d??"")),(l===c.code||l===h.code)&&(e=et(l).name,n=`${d??""}${i}`,t=l===h.code?6:4);if(t==null||e==null||n==null||s==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:s}}protos(){return this.#e.map(([t])=>Object.assign({},et(t)))}protoCodes(){return this.#e.map(([t])=>t)}protoNames(){return this.#e.map(([t])=>et(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(),s=n.lastIndexOf(e);if(s<0)throw new Error(`Address ${this.toString()} does not contain subaddress: ${t.toString()}`);return new r(n.slice(0,s))}decapsulateCode(t){let e=this.tuples();for(let n=e.length-1;n>=0;n--)if(e[n][0]===t)return new r(Ca(e.slice(0,n)));return this}getPeerId(){try{let t=[];this.stringTuples().forEach(([n,s])=>{n===Nr.p2p.code&&t.push([n,s]),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"?ct(tt.decode(`z${n}`),"base58btc"):ct(pt.parse(n).multihash.bytes,"base58btc")}return null}catch{return null}}getPath(){return this.#n}equals(t){return mt(this.bytes,t.bytes)}async resolve(t){let e=this.protos().find(i=>i.resolvable);if(e==null)return[this];let n=Xu.get(e.name);if(n==null)throw new Na(`no available resolver for ${e.name}`);return(await n(this,t)).map(i=>xt(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)}[v0](){return`Multiaddr(${this.#t})`}};var Xu=new Map;function Ju(r){return!!r?.[La]}function xt(r){return new si(r)}function re(){let r={};return r.promise=new Promise((t,e)=>{r.resolve=t,r.reject=e}),r}var ii=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 oi(r,t,e){if(t==null)return r;if(t.aborted)return Promise.reject(new ii(e?.errorMessage,e?.errorCode,e?.errorName));let n,s=new ii(e?.errorMessage,e?.errorCode,e?.errorName);try{return await Promise.race([r,new Promise((i,o)=>{n=()=>{o(s)},t.addEventListener("abort",n)})])}finally{n!=null&&t.removeEventListener("abort",n)}}var Ra=class{readNext;haveNext;ended;nextResult;constructor(){this.ended=!1,this.readNext=re(),this.haveNext=re()}[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=re(),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=re(),await oi(this.readNext.promise,e?.signal,e)}};function Qu(){return new Ra}var ai=class extends Error{name="UnexpectedEOFError";code="ERR_UNEXPECTED_EOF"};var Ua=class extends Error{code;constructor(t,e){super(t),this.code=e}},Da=class extends Ua{type;constructor(t){super(t,"ABORT_ERR"),this.type="aborted",this.name="AbortError"}};function tf(r,t){let e=Qu();r.sink(e).catch(async o=>{await e.end(o)}),r.sink=async o=>{for await(let a of o)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 s=new ee;return{read:async(o,a)=>{a?.signal?.throwIfAborted();let c,h=new Promise((f,u)=>{c=()=>{u(new Da("Read aborted"))},a?.signal?.addEventListener("abort",c)});try{if(o==null){let{done:u,value:g}=await Promise.race([n.next(),h]);return u===!0?new ee:g}for(;s.byteLength<o;){let{value:u,done:g}=await Promise.race([n.next(),h]);if(g===!0)throw new ai("unexpected end of input");s.append(u)}let f=s.sublist(0,o);return s.consume(o),f}finally{c!=null&&a?.signal?.removeEventListener("abort",c)}},write:async(o,a)=>{a?.signal?.throwIfAborted(),o instanceof Uint8Array?await e.push(o,a):await e.push(o.subarray(),a)},unwrap:()=>{if(s.byteLength>0){let o=r.source;r.source=async function*(){t?.yieldBytes===!1?yield s:yield*s,yield*o}()}return r}}}var ci=class extends Error{name="InvalidMessageLengthError";code="ERR_INVALID_MSG_LENGTH"},li=class extends Error{name="InvalidDataLengthError";code="ERR_MSG_DATA_TOO_LONG"},ui=class extends Error{name="InvalidDataLengthLengthError";code="ERR_MSG_LENGTH_TOO_LONG"};function ef(r,t={}){let e=tf(r,t);t.maxDataLength!=null&&t.maxLengthLength==null&&(t.maxLengthLength=At(t.maxDataLength));let n=t?.lengthDecoder??xe,s=t?.lengthEncoder??$t;return{read:async o=>{let a=-1,c=new ee;for(;;){c.append(await e.read(1,o));try{a=n(c)}catch(h){if(h instanceof RangeError)continue;throw h}if(a<0)throw new ci("Invalid message length");if(t?.maxLengthLength!=null&&c.byteLength>t.maxLengthLength)throw new ui("message length length too long");if(a>-1)break}if(t?.maxDataLength!=null&&a>t.maxDataLength)throw new li("message length too long");return e.read(a,o)},write:async(o,a)=>{await e.write(new ee(s(o.byteLength),o),a)},writeV:async(o,a)=>{let c=new ee(...o.flatMap(h=>[s(h.byteLength),h]));await e.write(c,a)},unwrap:()=>e.unwrap()}}function Ge(r,t){let e=ef(r,t),n={read:async(s,i)=>{let o=await e.read(i);return s.decode(o)},write:async(s,i,o)=>{await e.write(i.encode(s),o)},writeV:async(s,i,o)=>{await e.writeV(s.map(a=>i.encode(a)),o)},pb:s=>({read:async i=>n.read(s,i),write:async(i,o)=>n.write(i,s,o),writeV:async(i,o)=>n.writeV(i,s,o),unwrap:()=>n}),unwrap:()=>e.unwrap()};return n}var Oa=1e3,rf=60*Oa,fi=290,nf=15,sf=2*60*rf,of=1,hi=2e3,af=100,Ma="circuit-relay-source",gn=`${$i}-circuit-relay`,Pa=`${$i}-circuit-relay-source`,cf=2*rf,lf=BigInt(1<<17),Wt="/libp2p/circuit/relay/0.2.0/hop",ar="/libp2p/circuit/relay/0.2.0/stop",uf=30*Oa,n2=30*Oa,yn=300,ff=4096,hf=.001;var X;(function(r){let t;(function(s){s.RESERVE="RESERVE",s.CONNECT="CONNECT",s.STATUS="STATUS"})(t=r.Type||(r.Type={}));let e;(function(s){s[s.RESERVE=0]="RESERVE",s[s.CONNECT=1]="CONNECT",s[s.STATUS=2]="STATUS"})(e||(e={})),function(s){s.codec=()=>sr(e)}(t=r.Type||(r.Type={}));let n;r.codec=()=>(n==null&&(n=Pt((s,i,o={})=>{o.lengthDelimited!==!1&&i.fork(),s.type!=null&&(i.uint32(8),r.Type.codec().encode(s.type,i)),s.peer!=null&&(i.uint32(18),Lr.codec().encode(s.peer,i)),s.reservation!=null&&(i.uint32(26),di.codec().encode(s.reservation,i)),s.limit!=null&&(i.uint32(34),Rr.codec().encode(s.limit,i)),s.status!=null&&(i.uint32(40),K.codec().encode(s.status,i)),o.lengthDelimited!==!1&&i.ldelim()},(s,i,o={})=>{let a={},c=i==null?s.len:s.pos+i;for(;s.pos<c;){let h=s.uint32();switch(h>>>3){case 1:{a.type=r.Type.codec().decode(s);break}case 2:{a.peer=Lr.codec().decode(s,s.uint32(),{limits:o.limits?.peer});break}case 3:{a.reservation=di.codec().decode(s,s.uint32(),{limits:o.limits?.reservation});break}case 4:{a.limit=Rr.codec().decode(s,s.uint32(),{limits:o.limits?.limit});break}case 5:{a.status=K.codec().decode(s);break}default:{s.skipType(h&7);break}}}return a})),n),r.encode=s=>Mt(s,r.codec()),r.decode=(s,i)=>Ot(s,r.codec(),i)})(X||(X={}));var Kt;(function(r){let t;(function(s){s.CONNECT="CONNECT",s.STATUS="STATUS"})(t=r.Type||(r.Type={}));let e;(function(s){s[s.CONNECT=0]="CONNECT",s[s.STATUS=1]="STATUS"})(e||(e={})),function(s){s.codec=()=>sr(e)}(t=r.Type||(r.Type={}));let n;r.codec=()=>(n==null&&(n=Pt((s,i,o={})=>{o.lengthDelimited!==!1&&i.fork(),s.type!=null&&(i.uint32(8),r.Type.codec().encode(s.type,i)),s.peer!=null&&(i.uint32(18),Lr.codec().encode(s.peer,i)),s.limit!=null&&(i.uint32(26),Rr.codec().encode(s.limit,i)),s.status!=null&&(i.uint32(32),K.codec().encode(s.status,i)),o.lengthDelimited!==!1&&i.ldelim()},(s,i,o={})=>{let a={},c=i==null?s.len:s.pos+i;for(;s.pos<c;){let h=s.uint32();switch(h>>>3){case 1:{a.type=r.Type.codec().decode(s);break}case 2:{a.peer=Lr.codec().decode(s,s.uint32(),{limits:o.limits?.peer});break}case 3:{a.limit=Rr.codec().decode(s,s.uint32(),{limits:o.limits?.limit});break}case 4:{a.status=K.codec().decode(s);break}default:{s.skipType(h&7);break}}}return a})),n),r.encode=s=>Mt(s,r.codec()),r.decode=(s,i)=>Ot(s,r.codec(),i)})(Kt||(Kt={}));var Lr;(function(r){let t;r.codec=()=>(t==null&&(t=Pt((e,n,s={})=>{if(s.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);s.lengthDelimited!==!1&&n.ldelim()},(e,n,s={})=>{let i={id:at(0),addrs:[]},o=n==null?e.len:e.pos+n;for(;e.pos<o;){let a=e.uint32();switch(a>>>3){case 1:{i.id=e.bytes();break}case 2:{if(s.limits?.addrs!=null&&i.addrs.length===s.limits.addrs)throw new Qr('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=>Mt(e,r.codec()),r.decode=(e,n)=>Ot(e,r.codec(),n)})(Lr||(Lr={}));var di;(function(r){let t;r.codec=()=>(t==null&&(t=Pt((e,n,s={})=>{if(s.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),pi.codec().encode(e.voucher,n)),s.lengthDelimited!==!1&&n.ldelim()},(e,n,s={})=>{let i={expire:0n,addrs:[]},o=n==null?e.len:e.pos+n;for(;e.pos<o;){let a=e.uint32();switch(a>>>3){case 1:{i.expire=e.uint64();break}case 2:{if(s.limits?.addrs!=null&&i.addrs.length===s.limits.addrs)throw new Qr('Decode error - map field "addrs" had too many elements');i.addrs.push(e.bytes());break}case 3:{i.voucher=pi.codec().decode(e,e.uint32(),{limits:s.limits?.voucher});break}default:{e.skipType(a&7);break}}}return i})),t),r.encode=e=>Mt(e,r.codec()),r.decode=(e,n)=>Ot(e,r.codec(),n)})(di||(di={}));var Rr;(function(r){let t;r.codec=()=>(t==null&&(t=Pt((e,n,s={})=>{s.lengthDelimited!==!1&&n.fork(),e.duration!=null&&(n.uint32(8),n.uint32(e.duration)),e.data!=null&&(n.uint32(16),n.uint64(e.data)),s.lengthDelimited!==!1&&n.ldelim()},(e,n,s={})=>{let i={},o=n==null?e.len:e.pos+n;for(;e.pos<o;){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=>Mt(e,r.codec()),r.decode=(e,n)=>Ot(e,r.codec(),n)})(Rr||(Rr={}));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 Va;(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"})(Va||(Va={}));(function(r){r.codec=()=>sr(Va)})(K||(K={}));var Ur;(function(r){let t;r.codec=()=>(t==null&&(t=Pt((e,n,s={})=>{s.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)),s.lengthDelimited!==!1&&n.ldelim()},(e,n,s={})=>{let i={relay:at(0),peer:at(0),expiration:0n},o=n==null?e.len:e.pos+n;for(;e.pos<o;){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=>Mt(e,r.codec()),r.decode=(e,n)=>Ot(e,r.codec(),n)})(Ur||(Ur={}));var pi;(function(r){let t;r.codec=()=>(t==null&&(t=Pt((e,n,s={})=>{s.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),Ur.codec().encode(e.payload,n)),e.signature!=null&&e.signature.byteLength>0&&(n.uint32(42),n.bytes(e.signature)),s.lengthDelimited!==!1&&n.ldelim()},(e,n,s={})=>{let i={publicKey:at(0),payloadType:at(0),signature:at(0)},o=n==null?e.len:e.pos+n;for(;e.pos<o;){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=Ur.codec().decode(e,e.uint32(),{limits:s.limits?.payload});break}case 5:{i.signature=e.bytes();break}default:{e.skipType(a&7);break}}}return i})),t),r.encode=e=>Mt(e,r.codec()),r.decode=(e,n)=>Ot(e,r.codec(),n)})(pi||(pi={}));var S0=r=>r.toString().split("/").slice(1),Dr=r=>({match:t=>t.length<1?!1:r(t[0])?t.slice(1):!1,pattern:"fn"}),F=r=>({match:t=>Dr(e=>e===r).match(t),pattern:r}),cr=()=>({match:r=>Dr(t=>typeof t=="string").match(r),pattern:"{string}"}),bn=()=>({match:r=>Dr(t=>!isNaN(parseInt(t))).match(r),pattern:"{number}"}),Q=()=>({match:r=>{if(r.length<2||r[0]!=="p2p"&&r[0]!=="ipfs")return!1;if(r[1].startsWith("Q")||r[1].startsWith("1"))try{tt.decode(`z${r[1]}`)}catch{return!1}else return!1;return r.slice(2)},pattern:"/p2p/{peerid}"}),wn=()=>({match:r=>{if(r.length<2||r[0]!=="certhash")return!1;try{Mo.decode(r[1])}catch{return!1}return r.slice(2)},pattern:"/certhash/{certhash}"}),W=r=>({match:t=>{let e=r.match(t);return e===!1?t:e},pattern:`optional(${r.pattern})`}),It=(...r)=>({match:t=>{let e;for(let n of r){let s=n.match(t);s!==!1&&(e==null||s.length<e.length)&&(e=s)}return e??!1},pattern:`or(${r.map(t=>t.pattern).join(", ")})`}),q=(...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 nt(...r){function t(s){let i=S0(s);for(let o of r){let a=o.match(i);if(a===!1)return!1;i=a}return i}function e(s){return t(s)!==!1}function n(s){let i=t(s);return i===!1?!1:i.length===0}return{matchers:r,matches:e,exactMatch:n}}var gi=q(F("dns4"),cr()),yi=q(F("dns6"),cr()),bi=q(F("dnsaddr"),cr()),Fa=q(F("dns"),cr()),d2=nt(gi,W(Q())),p2=nt(yi,W(Q())),m2=nt(bi,W(Q())),g2=nt(It(Fa,bi,gi,yi),W(Q())),df=q(F("ip4"),Dr(ei)),pf=q(F("ip6"),Dr(ri)),Ka=It(df,pf),ke=It(Ka,Fa,gi,yi,bi),y2=nt(It(Ka,q(It(Fa,bi,gi,yi),W(Q())))),b2=nt(df),w2=nt(pf),x2=nt(Ka),qa=q(ke,F("tcp"),bn()),xn=q(ke,F("udp"),bn()),v2=nt(q(qa,W(Q()))),E2=nt(xn),za=q(xn,F("quic"),W(Q())),wi=q(xn,F("quic-v1"),W(Q())),A0=It(za,wi),S2=nt(za),A2=nt(wi),Ha=It(ke,qa,xn,za,wi),mf=It(q(Ha,F("ws"),W(Q()))),B2=nt(mf),gf=It(q(Ha,F("wss"),W(Q())),q(Ha,F("tls"),W(q(F("sni"),cr())),F("ws"),W(Q()))),_2=nt(gf),yf=q(xn,F("webrtc-direct"),W(wn()),W(wn()),W(Q())),I2=nt(yf),bf=q(wi,F("webtransport"),W(wn()),W(wn()),W(Q())),T2=nt(bf),mi=It(mf,gf,q(qa,W(Q())),q(A0,W(Q())),q(ke,W(Q())),yf,bf,Q()),wf=nt(mi),B0=q(mi,F("p2p-circuit"),Q()),xi=nt(B0),_0=It(q(mi,F("p2p-circuit"),F("webrtc"),W(Q())),q(mi,F("webrtc"),W(Q())),q(F("webrtc"),W(Q()))),k2=nt(_0),I0=It(q(ke,F("tcp"),bn(),F("http"),W(Q())),q(ke,F("http"),W(Q()))),C2=nt(I0),T0=It(q(ke,F("tcp"),It(q(F("443"),F("http")),q(bn(),F("https"))),W(Q())),q(ke,F("tls"),F("http"),W(Q())),q(ke,F("https"),W(Q()))),N2=nt(T0),k0=It(q(F("memory"),cr(),W(Q()))),L2=nt(k0);function vi(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 s=t.signal;return s.clear=n,s}var Ei=class extends Error{constructor(t="Transfer limit error"){super(t),this.name="TransferLimitError"}},vn=class extends Error{constructor(t="Duration limit error"){super(t),this.name="DurationLimitError"}},En=class extends Error{static name="HadEnoughRelaysError";name="HadEnoughRelaysError"},Si=class extends Error{static name="DoubleRelayError";name="DoubleRelayError"},Ai=class extends Error{static name="RelayQueueFullError";name="RelayQueueFullError"};async function*xf(r,t,e){let n=t.remaining;for await(let s of r){let i=BigInt(s.byteLength);if(t.remaining-i<0){let o=Number(t.remaining);t.remaining=0n;try{o!==0&&(yield s.subarray(0,o))}catch(a){e.log.error(a)}throw new Ei(`data limit of ${n} bytes exceeded`)}t.remaining-=i,yield s}}function vf(r,t,e,n,s){function i(u){r.abort(u),t.abort(u)}let o=[e,n.signal];n.limit?.duration!=null&&(s.log("limiting relayed connection duration to %dms",n.limit.duration),o.push(AbortSignal.timeout(n.limit.duration)));let a=vi(o),c=!1,h=!1,f;n.limit?.data!=null&&(f={remaining:n.limit.data}),queueMicrotask(()=>{let u=()=>{s.log("relayed connection reached time limit"),t.abort(new vn(`duration limit of ${n.limit?.duration} ms exceeded`))};a.addEventListener("abort",u,{once:!0}),t.sink(f==null?r.source:xf(r.source,f,s)).catch(g=>{s.log.error("error while relaying streams src -> dst",g),i(g)}).finally(()=>{c=!0,h&&(a.removeEventListener("abort",u),a.clear())})}),queueMicrotask(()=>{let u=()=>{s.log("relayed connection reached time limit"),r.abort(new vn(`duration limit of ${n.limit?.duration} ms exceeded`))};a.addEventListener("abort",u,{once:!0}),r.sink(f==null?t.source:xf(t.source,f,s)).catch(g=>{s.log.error("error while relaying streams dst -> src",g),i(g)}).finally(()=>{h=!0,c&&(a.removeEventListener("abort",u),a.clear())})})}function $a(r){let t=r*BigInt(1e3),e=new Date().getTime();return Number(t-BigInt(e))}var Sn=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}},Bi=nt(q(wf.matchers[0],F("p2p-circuit"))),_i=nt(F("p2p-circuit"));function Ii(r,t){let e={[Symbol.iterator]:()=>e,next:()=>{let n=r.next(),s=n.value;return n.done===!0||s==null?{done:!0,value:void 0}:{done:!1,value:t(s)}}};return e}var We=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 Ii(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 Ii(this.map.values(),t=>t.key)}values(){return Ii(this.map.values(),t=>t.value)}get size(){return this.map.size}};var Ga=64,ne=class{fp;h;seed;constructor(t,e,n,s=2){if(s>Ga)throw new TypeError("Invalid Fingerprint Size");let i=e.hashV(t,n),o=at(s);for(let a=0;a<o.length;a++)o[a]=i[a];o.length===0&&(o[0]=7),this.fp=o,this.h=e,this.seed=n}hash(){return this.h.hash(this.fp,this.seed)}equals(t){return t?.fp instanceof Uint8Array?mt(this.fp,t.fp):!1}};function lr(r,t){return Math.floor(Math.random()*(t-r))+r}var ur=class{contents;constructor(t){this.contents=new Array(t).fill(null)}has(t){if(!(t instanceof ne))throw new TypeError("Invalid Fingerprint");return this.contents.some(e=>t.equals(e))}add(t){if(!(t instanceof ne))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 ne))throw new TypeError("Invalid Fingerprint");let e=lr(0,this.contents.length-1),n=this.contents[e];return this.contents[e]=t,n}remove(t){if(!(t instanceof ne))throw new TypeError("Invalid Fingerprint");let e=this.contents.findIndex(n=>t.equals(n));return e>-1?(this.contents[e]=null,!0):!1}};var Wa={32:16777619n,64:1099511628211n,128:309485009821345068724781371n,256:374144419156711147060143317175368453031918731002211n,512:35835915874844867368919076489095108449946327955754392558399825615420669938882575126094039892345713852759n,1024:5016456510113118655434598811035278955030765345404790744303017523831112055108147451509157692220295382716162651878526895249385292291816524375083746691371804094271873160484737966720260389217684476157468082573n},Bf={32:2166136261n,64:14695981039346656037n,128:144066263297769815596495629667062367629n,256:100029257958052580907070968620625704837092796014241193945225284501741471925557n,512:9659303129496669498009435400716310466090418745672637896108374329434462657994582932197716438449813051892206539805784495328239340083876191928701583869517785n,1024:14197795064947621068722070641403218320880622795441933960878474914617582723252296732303717722150864096521202355549365628174669108571814760471015076148029755969804077320157692458563003215304957150157403644460363550505412711285966361610267868082893823963790439336411086884584107735010676915n},_f=new globalThis.TextEncoder;function C0(r,t){let e=Wa[t],n=Bf[t];for(let s=0;s<r.length;s++)n^=BigInt(r[s]),n=BigInt.asUintN(t,n*e);return n}function N0(r,t,e){if(e.length===0)throw new Error("The `utf8Buffer` option must have a length greater than zero");let n=Wa[t],s=Bf[t],i=r;for(;i.length>0;){let o=_f.encodeInto(i,e);i=i.slice(o.read);for(let a=0;a<o.written;a++)s^=BigInt(e[a]),s=BigInt.asUintN(t,s*n)}return s}function Za(r,{size:t=32,utf8Buffer:e}={}){if(!Wa[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 N0(r,t,e);r=_f.encode(r)}return C0(r,t)}var L0=pc(Af(),1);var Bn={hash:r=>Number(Za(r,{size:32})),hashV:(r,t)=>R0(Bn.hash(r,t))};function R0(r){let t=r.toString(16);return t.length%2===1&&(t=`0${t}`),G(t,"base16")}var U0=500,_n=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??Bn,this.seed=t.seed??lr(0,Math.pow(2,10))}add(t){typeof t=="string"&&(t=G(t));let e=new ne(t,this.hash,this.seed,this.fingerprintSize),n=this.hash.hash(t,this.seed)%this.filterSize,s=(n^e.hash())%this.filterSize;if(this.buckets[n]==null&&(this.buckets[n]=new ur(this.bucketSize)),this.buckets[s]==null&&(this.buckets[s]=new ur(this.bucketSize)),this.buckets[n].add(e)||this.buckets[s].add(e))return this.count++,!0;let i=[n,s],o=i[lr(0,i.length-1)];this.buckets[o]==null&&(this.buckets[o]=new ur(this.bucketSize));for(let a=0;a<U0;a++){let c=this.buckets[o].swap(e);if(c!=null&&(o=(o^c.hash())%this.filterSize,this.buckets[o]==null&&(this.buckets[o]=new ur(this.bucketSize)),this.buckets[o].add(c)))return this.count++,!0}return!1}has(t){typeof t=="string"&&(t=G(t));let e=new ne(t,this.hash,this.seed,this.fingerprintSize),n=this.hash.hash(t,this.seed)%this.filterSize,s=this.buckets[n]?.has(e)??!1;if(s)return s;let i=(n^e.hash())%this.filterSize;return this.buckets[i]?.has(e)??!1}remove(t){typeof t=="string"&&(t=G(t));let e=new ne(t,this.hash,this.seed,this.fingerprintSize),n=this.hash.hash(t,this.seed)%this.filterSize,s=this.buckets[n]?.remove(e)??!1;if(s)return this.count--,s;let i=(n^e.hash())%this.filterSize,o=this.buckets[i]?.remove(e)??!1;return o&&this.count--,o}get reliable(){return Math.floor(100*(this.count/this.filterSize))<=90}},D0={1:.5,2:.84,4:.95,8:.98};function O0(r=.001){return r>.002?2:r>1e-5?4:8}function If(r,t=.001){let e=O0(t),n=D0[e],s=Math.round(r/n),i=Math.min(Math.ceil(Math.log2(1/t)+Math.log2(2*e)),Ga);return{filterSize:s,bucketSize:e,fingerprintSize:i}}var ki=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??Bn,this.seed=t.seed??lr(0,Math.pow(2,10)),this.filterSeries=[new _n({filterSize:this.filterSize,bucketSize:this.bucketSize,fingerprintSize:this.fingerprintSize,hash:this.hash,seed:this.seed})]}add(t){if(typeof t=="string"&&(t=G(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 _n({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=G(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=G(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 Or(r,t=.001,e){return new ki({...If(r,t),...e??{}})}var Ci=class{filter;constructor(t,e){this.filter=Or(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 ja(r,t=.001){return new Ci(r,t)}var Ya=class extends We{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 Xa(r){let{name:t,metrics:e}=r,n;return e!=null?n=new Ya({name:t,metrics:e}):n=new We,n}var Ja=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 Tf(r,t){let e=new Ja(t?.errorMessage,t?.errorCode,t?.errorName),n=new AbortController,s=()=>{n.abort(e)},i=AbortSignal.timeout(r);i.addEventListener("abort",s);let o=n.signal;return o.reset=a=>{i?.removeEventListener("abort",s),i=AbortSignal.timeout(a??r),i.addEventListener("abort",()=>{n.abort(e)})},o.clear=()=>{i?.removeEventListener("abort",s),i=void 0},o}var Ni=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??nf,this.applyDefaultLimit=e.applyDefaultLimit!==!1,this.reservationTtl=e.reservationTtl??sf,this.defaultDurationLimit=e.defaultDurationLimit??cf,this.defaultDataLimit=e.defaultDataLimit??lf,this.reservations=Xa({metrics:t.metrics,name:"libp2p_circuit_relay_server_reservations_total"})}reserve(t,e,n){let s=this.reservations.get(t);if(this.reservations.size>=this.maxReservations&&s==null)return{status:K.RESERVATION_REFUSED};let i=new Date(Date.now()+this.reservationTtl),o;return this.applyDefaultLimit&&(o=n??{data:this.defaultDataLimit,duration:this.defaultDurationLimit}),s!=null?(this.log("refreshing reservation for client %p",t),s.signal.reset(this.reservationTtl)):(this.log("creating new reservation for client %p",t),s={addr:e,expiry:i,limit:o,signal:Tf(this.reservationTtl)}),this.reservations.set(t,s),s.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 Li=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 Ur.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 kf=r=>r.protoCodes().includes(fi),M0={maxOutboundStopStreams:yn},Qa=class extends qt{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??uf,this.maxInboundHopStreams=e.maxInboundHopStreams,this.maxOutboundHopStreams=e.maxOutboundHopStreams,this.maxOutboundStopStreams=e.maxOutboundStopStreams??M0.maxOutboundStopStreams,this.reservationStore=new Ni(t,e.reservations),this.shutdownController=new AbortController,Lt(1/0,this.shutdownController.signal)}[Symbol.toStringTag]="@libp2p/circuit-relay-v2-server";isStarted(){return this.started}async start(){this.started||(await this.registrar.handle(Wt,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(Wt),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)},s=Ge(e);try{let i=await s.pb(X).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:s,request:i},n)}catch(i){this.log.error("error while handling hop",i),await s.pb(X).write({type:X.Type.STATUS,status:K.MALFORMED_MESSAGE},n),e.abort(i)}}async handleHopProtocol({stream:t,request:e,connection:n},s){switch(this.log("received hop message"),e.type){case X.Type.RESERVE:await this.handleReserve({stream:t,request:e,connection:n},s);break;case X.Type.CONNECT:await this.handleConnect({stream:t,request:e,connection:n},s);break;default:this.log.error("invalid hop request type %s via peer %p",e.type,n.remotePeer),await t.pb(X).write({type:X.Type.STATUS,status:K.UNEXPECTED_MESSAGE})}}async handleReserve({stream:t,connection:e},n){let s=t.pb(X);if(this.log("hop reserve request from %p",e.remotePeer),kf(e.remoteAddr)){this.log.error("relay reservation over circuit connection denied for peer: %p",e.remotePeer),await s.write({type:X.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 s.write({type:X.Type.STATUS,status:K.PERMISSION_DENIED},n);return}let i=this.reservationStore.reserve(e.remotePeer,e.remoteAddr);try{if(i.status!==K.OK){await s.write({type:X.Type.STATUS,status:i.status},n);return}if(i.expire!=null){let o=i.expire*1e3-Date.now();await this.peerStore.merge(e.remotePeer,{tags:{[Ma]:{value:1,ttl:o},[Pa]:{value:1,ttl:o}}})}await s.write({type:X.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(o){this.log.error("failed to send confirmation response to %p - %e",e.remotePeer,o),this.reservationStore.removeReservation(e.remotePeer);try{await this.peerStore.merge(e.remotePeer,{tags:{[Ma]:void 0,[Pa]: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 s=await mn.seal(new Li({peer:t,relay:this.peerId,expiration:e}),this.privateKey);return{addrs:n,expire:e,voucher:{publicKey:Me(s.publicKey),payloadType:s.payloadType,payload:{peer:t.toMultihash().bytes,relay:this.peerId.toMultihash().bytes,expiration:e},signature:s.signature}}}async handleConnect({stream:t,request:e,connection:n},s){let i=t.pb(X);if(kf(n.remoteAddr)){this.log.error("relay reservation over circuit connection denied for peer: %p",n.remotePeer),await i.write({type:X.Type.STATUS,status:K.PERMISSION_DENIED},s);return}this.log("hop connect request from %p",n.remotePeer);let o;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(xt),o=dn(zt(e.peer.id))}catch(g){this.log.error("invalid hop connect request via peer %p %s",n.remotePeer,g),await i.write({type:X.Type.STATUS,status:K.MALFORMED_MESSAGE},s);return}let a=this.reservationStore.get(o);if(a==null){this.log.error("hop connect denied for destination peer %p not having a reservation for %p with status %s",o,n.remotePeer,K.NO_RESERVATION),await i.write({type:X.Type.STATUS,status:K.NO_RESERVATION},s);return}if(await this.connectionGater.denyOutboundRelayedConnection?.(n.remotePeer,o)===!0){this.log.error("hop connect for %p to %p denied by connection gater",n.remotePeer,o),await i.write({type:X.Type.STATUS,status:K.PERMISSION_DENIED},s);return}let c=this.connectionManager.getConnections(o);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",o,n.remotePeer),await i.write({type:X.Type.STATUS,status:K.NO_RESERVATION},s);return}let h=c[0],f=await this.stopHop({connection:h,request:{type:Kt.Type.CONNECT,peer:{id:n.remotePeer.toMultihash().bytes,addrs:[]},limit:a?.limit}},s);if(f==null){this.log.error("failed to open stream to destination peer %p",h?.remotePeer),await i.write({type:X.Type.STATUS,status:K.CONNECTION_FAILED},s);return}await i.write({type:X.Type.STATUS,status:K.OK,limit:a?.limit},s);let u=t.unwrap();this.log("connection from %p to %p established - merging streams",n.remotePeer,o),vf(u,f,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 s=await t.newStream([ar],{maxOutboundStreams:this.maxOutboundStopStreams,runOnLimitedConnection:!0,...n}),i=Ge(s),o=i.pb(Kt);await o.write(e,n);let a;try{a=await o.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 s.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 s.close(n)}get reservations(){return this.reservationStore.reservations}};function Cf(r={}){return t=>new Qa(t,r)}function P0(r){let[t,e]=r[Symbol.asyncIterator]!=null?[r[Symbol.asyncIterator](),Symbol.asyncIterator]:[r[Symbol.iterator](),Symbol.iterator],n=[];return{peek:()=>t.next(),push:s=>{n.push(s)},next:()=>n.length>0?{done:!1,value:n.shift()}:t.next(),[e](){return this}}}var Nf=P0;function V0(r){return r[Symbol.asyncIterator]!=null}function Lf(r){return r?.then!=null}function H0(r,t){let e=0;if(V0(r))return async function*(){for await(let c of r){let h=t(c,e++);Lf(h)&&await h,yield c}}();let n=Nf(r),{value:s,done:i}=n.next();if(i===!0)return function*(){}();if(typeof t(s,e++)?.then=="function")return async function*(){yield s;for await(let c of n){let h=t(c,e++);Lf(h)&&await h,yield c}}();let a=t;return function*(){yield s;for(let c of n)a(c,e++),yield c}()}var Rf=H0;var Ri=class{buffer;mask;top;btm;next;constructor(t){if(!(t>0)||t-1&t)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}},Mr=class{size;hwm;head;tail;constructor(t={}){this.hwm=t.splitLimit??16,this.head=new Ri(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 Ri(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 tc=class extends Error{type;code;constructor(t,e){super(t??"The operation was aborted"),this.type="aborted",this.code=e??"ABORT_ERR"}};function Pr(r={}){return F0(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 F0(r,t){t=t??{};let e=t.onEnd,n=new Mr,s,i,o,a=re(),c=async()=>{try{return n.isEmpty()?o?{done:!0}:await new Promise((y,b)=>{i=w=>{i=null,n.push(w);try{y(r(n))}catch(m){b(m)}return s}}):r(n)}finally{n.isEmpty()&&queueMicrotask(()=>{a.resolve(),a=re()})}},h=y=>i!=null?i(y):(n.push(y),s),f=y=>(n=new Mr,i!=null?i({error:y}):(n.push({error:y}),s)),u=y=>{if(o)return s;if(t?.objectMode!==!0&&y?.byteLength==null)throw new Error("objectMode was not true but tried to push non-Uint8Array value");return h({done:!1,value:y})},g=y=>o?s:(o=!0,y!=null?f(y):h({done:!0})),l=()=>(n=new Mr,g(),{done:!0}),d=y=>(g(y),{done:!0});if(s={[Symbol.asyncIterator](){return this},next:c,return:l,throw:d,push:u,end:g,get readableLength(){return n.size},onEmpty:async y=>{let b=y?.signal;if(b?.throwIfAborted(),n.isEmpty())return;let w,m;b!=null&&(w=new Promise((E,A)=>{m=()=>{A(new tc)},b.addEventListener("abort",m)}));try{await Promise.race([a.promise,w])}finally{m!=null&&b!=null&&b?.removeEventListener("abort",m)}}},e==null)return s;let p=s;return s={[Symbol.asyncIterator](){return this},next(){return p.next()},throw(y){return p.throw(y),e!=null&&(e(y),e=void 0),{done:!0}},return(){return p.return(),e!=null&&(e(),e=void 0),{done:!0}},push:u,end(y){return p.end(y),e!=null&&(e(y),e=void 0),s},get readableLength(){return p.readableLength},onEmpty:y=>p.onEmpty(y)},s}function K0(r){return r[Symbol.asyncIterator]!=null}function q0(...r){let t=[];for(let e of r)K0(e)||t.push(e);return t.length===r.length?function*(){for(let e of t)yield*e}():async function*(){let e=Pr({objectMode:!0});Promise.resolve().then(async()=>{try{await Promise.all(r.map(async n=>{for await(let s of n)e.push(s)})),e.end()}catch(n){e.end(n)}}),yield*e}()}var Uf=q0;function Df(r,...t){if(r==null)throw new Error("Empty pipeline");if(ec(r)){let n=r;r=()=>n.source}else if(Mf(r)||Of(r)){let n=r;r=()=>n}let e=[r,...t];if(e.length>1&&ec(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++)ec(e[n])&&(e[n]=$0(e[n]));return z0(...e)}var z0=(...r)=>{let t;for(;r.length>0;)t=r.shift()(t);return t},Of=r=>r?.[Symbol.asyncIterator]!=null,Mf=r=>r?.[Symbol.iterator]!=null,ec=r=>r==null?!1:r.sink!=null&&r.source!=null,$0=r=>t=>{let e=r.sink(t);if(e?.then!=null){let n=Pr({objectMode:!0});e.then(()=>{n.end()},o=>{n.end(o)});let s,i=r.source;if(Of(i))s=async function*(){yield*i,n.end()};else if(Mf(i))s=function*(){yield*i,n.end()};else throw new Error("Unknown duplex source type - must be Iterable or AsyncIterable");return Uf(n,s())}return r.source};function rc(r){let{stream:t,remoteAddr:e,logger:n,onDataRead:s,onDataWrite:i}=r,o=n.forComponent("libp2p:stream:converter"),a=!1,c=!1,h=t.close.bind(t);t.close=async d=>{await h(d),l(!0)};let f=t.abort.bind(t);t.abort=d=>{f(d),l(!0)};let u=t.sink.bind(t);t.sink=async d=>{try{await u(Df(d,p=>Rf(p,y=>i?.(y))))}catch(p){p.type!=="aborted"&&o.error("%s error in sink",e,p)}finally{c=!0,l()}};let g={log:o,sink:t.sink,source:async function*(){try{for await(let d of t.source)s?.(d),yield d}finally{a=!0,l()}}(),remoteAddr:e,timeline:{open:Date.now(),close:void 0},close:t.close,abort:t.abort};function l(d){d===!0&&(a=!0,c=!0),a&&c&&g.timeline.close==null&&(g.timeline.close=Date.now())}return g}var Ze=class extends Event{type;detail;constructor(t,e){super(t),this.type=t,this.detail=e}};var nc=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 Ui(r,t,e,n){let s=new nc(n?.errorMessage,n?.errorCode);return e?.aborted===!0?Promise.reject(s):new Promise((i,o)=>{function a(){e?.removeEventListener("abort",f),r.removeEventListener(t,c),n?.errorEvent!=null&&r.removeEventListener(n.errorEvent,h)}let c=u=>{try{if(n?.filter?.(u)===!1)return}catch(g){a(),o(g);return}a(),i(u)},h=u=>{a(),o(u.detail)},f=()=>{a(),o(s)};e?.addEventListener("abort",f),r.addEventListener(t,c),n?.errorEvent!=null&&r.addEventListener(n.errorEvent,h)})}var Di=class extends Error{static name="QueueFullError";constructor(t="The queue was full"){super(t),this.name="QueueFullError"}};var Oi=class{deferred;signal;constructor(t){this.signal=t,this.deferred=re(),this.onAbort=this.onAbort.bind(this),this.signal?.addEventListener("abort",this.onAbort)}onAbort(){this.deferred.reject(this.signal?.reason??new he)}cleanup(){this.signal?.removeEventListener("abort",this.onAbort)}};function G0(){return`${parseInt(String(Math.random()*1e9),10).toString()}${Date.now()}`}var Mi=class{id;fn;options;recipients;status;timeline;controller;constructor(t,e){this.id=G0(),this.status="queued",this.fn=t,this.options=e,this.recipients=[],this.timeline={created:Date.now()},this.controller=new AbortController,Lt(1/0,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 he),this.cleanup())}async join(t={}){let e=new Oi(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 oi(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 Pi=class extends qt{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 Di;let n=new Mi(t,e);return this.enqueue(n),this.safeDispatchEvent("add"),this.tryToStartAnother(),n.join(e).then(s=>(this.safeDispatchEvent("completed",{detail:s}),this.safeDispatchEvent("success",{detail:{job:n,result:s}}),s)).catch(s=>{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:s}),this.safeDispatchEvent("failure",{detail:{job:n,error:s}}),s})}clear(){this.queue.splice(0,this.queue.length)}abort(){this.queue.forEach(t=>{t.abort(new he)}),this.clear()}async onEmpty(t){this.size!==0&&await Ui(this,"empty",t?.signal)}async onSizeLessThan(t,e){this.size<t||await Ui(this,"next",e?.signal,{filter:()=>this.size<t})}async onIdle(t){this.pending===0&&this.size===0||await Ui(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=Pr({objectMode:!0}),n=c=>{c!=null?this.abort():this.clear(),e.end(c)},s=c=>{c.detail!=null&&e.push(c.detail)},i=c=>{n(c.detail)},o=()=>{n()},a=()=>{n(new he("Queue aborted"))};this.addEventListener("completed",s),this.addEventListener("error",i),this.addEventListener("idle",o),t?.signal?.addEventListener("abort",a);try{yield*e}finally{this.removeEventListener("completed",s),this.removeEventListener("error",i),this.removeEventListener("idle",o),t?.signal?.removeEventListener("abort",a),n()}}};var Vr=class extends Pi{has(t){return this.find(t)!=null}find(t){return this.queue.find(e=>t.equals(e.options.peerId))}};var Vi=class extends qt{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,Lt(1/0,this.discoveryController.signal)}isStarted(){return this.started}async start(){this.topologyId=await this.registrar.register(Wt,{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,Lt(1/0,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(Wt)],orders:[()=>Math.random()<.5?1:-1,(n,s)=>{let i=Pf(n),o=Pf(s);return i>o?-1:o>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 Vr({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(s=>s.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 s=vi([this.discoveryController.signal,AbortSignal.timeout(5e3)]);Lt(1/0,s);try{await this.connectionManager.openConnection(n.id,{signal:s})}finally{s.clear()}},{peerId:n.id,signal:this.discoveryController.signal}).catch(s=>{this.log.error("error opening connection to random peer %p",n.id,s)})}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 Pf(r){let t=r.metadata.get("last-dial-success");return t==null?0:new Date(ct(t)).getTime()}var sc=class extends qt{connectionManager;reservationStore;discovery;listeningAddrs;log;listenTimeout;reservationId;relay;constructor(t,e={}){super(),this.log=t.logger.forComponent("libp2p:circuit-relay:transport:listener"),this.connectionManager=t.connectionManager,this.reservationStore=t.relayStore,this.listeningAddrs=[],this.listenTimeout=e.listenTimeout??hi,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=[],this.safeDispatchEvent("listening"))};_onAddRelayPeer=t=>{let{relay:e,details:n}=t.detail;n.type!=="configured"&&n.id===this.reservationId&&(this.log("relay peer added %p",e),this.relay=e,this.listeningAddrs=n.reservation.addrs.map(s=>xt(s).encapsulate("/p2p-circuit")),this.safeDispatchEvent("listening"))};async listen(t){if(this.log("listen on %a",t),_i.exactMatch(t))this.reservationId=this.reservationStore.reserveRelay();else if(Bi.exactMatch(t)){let e=AbortSignal.timeout(this.listenTimeout);Lt(1/0,e);let n=t.decapsulate("/p2p-circuit"),s=await this.connectionManager.openConnection(n,{signal:e});if(!this.reservationStore.hasReservation(s.remotePeer)){this.log("making reservation on peer %p",s.remotePeer);let i=await this.reservationStore.addRelay(s.remotePeer,"configured");this.log("made reservation on peer %p",s.remotePeer),this.relay=i.relay,this.listeningAddrs=i.details.reservation.addrs.map(o=>xt(o).encapsulate("/p2p-circuit")),queueMicrotask(()=>{this.safeDispatchEvent("listening")})}}else throw new je(`Could not listen on p2p-circuit address "${t}"`)}getAddrs(){return[...this.listeningAddrs.values()].flat()}async close(){this.reservationStore.cancelReservations(),this.listeningAddrs=[],this.reservationStore.removeEventListener("relay:removed",this._onRemoveRelayPeer),queueMicrotask(()=>{this.safeDispatchEvent("close")})}};function Vf(r){return new sc(r)}var Hf="useandom-26T198340PX75pxJACKVERYMINDBUSHWOLF_GQZbfghjklqvwyzrict";var Ff=(r=21)=>{let t="",e=crypto.getRandomValues(new Uint8Array(r|=0));for(;r--;)t+=Hf[e[r]&63];return t};var W0=60*1e3*10,Z0=60*1e3*5,j0=30*1e3,Hi=class extends qt{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 We,this.pendingReservations=[],this.maxReservationQueueLength=e?.maxReservationQueueLength??af,this.reservationCompletionTimeout=e?.reservationCompletionTimeout??hi,this.started=!1,this.relayFilter=Or(100),this.reserveQueue=new Vr({concurrency:e?.reservationConcurrency??of,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(gn)]});this.log("removing tag from %d old relays",t.length),await Promise.all(t.map(async e=>{await this.peerStore.merge(e.id,{tags:{[gn]: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=Ff();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 je("Cannot use self as relay");if(this.reserveQueue.size>this.maxReservationQueueLength)throw new Ai("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 je("The relay was previously invalid");return this.log.trace("try to reserve relay slot with %p",t),this.reserveQueue.add(async()=>{let s=Date.now();try{let i=this.reservations.get(t);if(i!=null){let d=this.connectionManager.getConnections(t),p=!1;if(d.length===0&&this.log("already have relay reservation with %p but we are no longer connected",t),d.map(y=>y.id).includes(i.connection)&&(this.log("already have relay reservation with %p and the original connection is still open",t),p=!0),p&&$a(i.reservation.expire)>W0)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 En("Not making reservation on discovered relay because we do not need any more relays");let o=AbortSignal.timeout(this.reservationCompletionTimeout);Lt(1/0,o);let a=await this.connectionManager.openConnection(t,{signal:o});if(xi.matches(a.remoteAddr))throw new Si("not creating reservation over relayed connection");let c=await this.#t(a,{signal:o}),h=$a(c.expire);this.log("created reservation on relay peer %p, expiry date is %s",t,new Date(Date.now()+h).toString());let f=Math.min(Math.max(h-Z0,j0),Math.pow(2,31)-1),u=setTimeout(()=>{this.log("refresh reservation to relay %p",t),this.addRelay(t,e).catch(async d=>{this.log.error("could not refresh reservation to relay %p - %e",t,d),await this.#e(t)}).catch(d=>{this.log.error("could not remove expired reservation to relay %p - %e",t,d)})},f),g;if(e==="discovered"){let d=this.pendingReservations.pop();if(d==null)throw new En("Made reservation on relay but did not need any more discovered relays");g={timeout:u,reservation:c,type:e,connection:a.id,id:d}}else g={timeout:u,reservation:c,type:e,connection:a.id};this.reservations.set(t,g),await this.peerStore.merge(t,{tags:{[gn]:{value:1,ttl:h}}}),this.#r();let l={relay:t,details:g};return this.safeDispatchEvent("relay:created-reservation",{detail:l}),l}catch(i){throw e==="discovered"&&i.name==="HadEnoughRelaysError"||this.log.error("could not reserve slot on %p after %dms - %e",t,Date.now()-s,i),(i.name==="DialError"||i.name==="UnsupportedProtocolError")&&this.relayFilter.add(t.toMultihash().bytes),this.#e(t).catch(o=>{this.log.error("could not remove reservation on %p after reserving slot failed - %e",t,o)}),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(Wt,e),i=Ge(n).pb(X);this.log.trace("send RESERVE to %p",t.remotePeer),await i.write({type:X.Type.RESERVE},e);let o;try{this.log.trace("reading response from %p",t.remotePeer),o=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",o),o.status===K.OK&&o.reservation!=null){let c=new Set;c.add(t.remoteAddr.toString());for(let h of o.reservation.addrs){let f=xt(h);f.getPeerId()==null&&(f=f.encapsulate(`/p2p/${t.remotePeer}`)),f=xt(f.toString().replace(`/p2p/${t.remotePeer}/p2p/${t.remotePeer}`,`/p2p/${t.remotePeer}`)),c.add(f.toString())}return o.reservation.addrs=[...c].map(h=>xt(h).bytes),o.reservation}let a=`reservation failed with status ${o.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:{[gn]: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=Or(100),this.log("not discovered enough relays %d/%d",this.reservations.size,this.pendingReservations.length),this.safeDispatchEvent("relay:not-enough-relays")}};var Y0=r=>{if(r.peer==null)return!1;try{r.peer.addrs.forEach(xt)}catch{return!1}return!0},ic={maxInboundStopStreams:yn,maxOutboundStopStreams:yn,stopTimeout:3e4},Fi=class{discovery;registrar;peerStore;connectionManager;transportManager;peerId;upgrader;addressManager;connectionGater;reservationStore;logger;maxInboundStopStreams;maxOutboundStopStreams;stopTimeout;started;log;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??ic.maxInboundStopStreams,this.maxOutboundStopStreams=e.maxOutboundStopStreams??ic.maxOutboundStopStreams,this.stopTimeout=e.stopTimeout??ic.stopTimeout,this.discovery=new Vi(t,{filter:e.discoveryFilter??ja(ff,hf)}),this.discovery.addEventListener("relay:discover",n=>{this.reservationStore.addRelay(n.detail,"discovered").catch(s=>{s.name!=="HadEnoughRelaysError"&&s.name!=="RelayQueueFullError"&&this.log.error("could not add discovered relay %p",n.detail,s)})}),this.reservationStore=new Hi(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";[xc]=["@libp2p/transport","@libp2p/circuit-relay-v2-transport"];get[vc](){return this.discovery!=null?["@libp2p/identify"]:[]}[gc]=!0;isStarted(){return this.started}async start(){await this.registrar.handle(ar,t=>{this.onStop(t).catch(e=>{this.log.error("error while handling STOP protocol",e),t.stream.abort(e)})},{maxInboundStreams:this.maxInboundStopStreams,maxOutboundStreams:this.maxOutboundStopStreams,runOnLimitedConnection:!0}),await bc(this.discovery,this.reservationStore),this.started=!0}async stop(){await wc(this.discovery,this.reservationStore),await this.registrar.unhandle(ar),this.started=!1}async dial(t,e){if(t.protoCodes().filter(l=>l===fi).length!==1){let l="Invalid circuit relay address";throw this.log.error(l,t),new Fr(l)}let n=t.toString().split("/p2p-circuit"),s=xt(n[0]),i=xt(n[n.length-1]),o=s.getPeerId(),a=i.getPeerId();if(o==null||a==null){let l=`ircuit relay dial to ${t.toString()} failed as address did not have both relay and destination PeerIDs`;throw this.log.error(`c${l}`),new Fr(`C${l}`)}let c=ya(o),h=ya(a),u=this.connectionManager.getConnections(c)[0];u==null?(await this.peerStore.merge(c,{multiaddrs:[s]}),e.onProgress?.(new Ze("circuit-relay:open-connection")),u=await this.connectionManager.openConnection(c,e)):e.onProgress?.(new Ze("circuit-relay:reuse-connection"));let g;try{e.onProgress?.(new Ze("circuit-relay:open-hop-stream")),g=await u.newStream(Wt,e);let l=Ge(g),d=l.pb(X);e.onProgress?.(new Ze("circuit-relay:write-connect-message")),await d.write({type:X.Type.CONNECT,peer:{id:h.toMultihash().bytes,addrs:[xt(i).bytes]}},e),e.onProgress?.(new Ze("circuit-relay:read-connect-response"));let p=await d.read(e);if(p.status!==K.OK)throw new kn(`failed to connect via relay with status ${p?.status?.toString()??"undefined"}`);let y=new Sn(p.limit),b=rc({stream:l.unwrap(),remoteAddr:t,localAddr:s.encapsulate(`/p2p-circuit/p2p/${this.peerId.toString()}`),logger:this.logger,onDataRead:y.onData,onDataWrite:y.onData});return this.log("new outbound relayed connection %a",b.remoteAddr),await this.upgrader.upgradeOutbound(b,{...e,limits:y.getLimits()})}catch(l){throw this.log.error("circuit relay dial to destination %p via relay %p failed",h,c,l),g?.abort(l),l}}createListener(t){return Vf({connectionManager:this.connectionManager,relayStore:this.reservationStore,logger:this.logger})}listenFilter(t){return t=Array.isArray(t)?t:[t],t.filter(e=>Bi.exactMatch(e)||_i.exactMatch(e))}dialFilter(t){return t=Array.isArray(t)?t:[t],t.filter(e=>xi.exactMatch(e))}async onStop({connection:t,stream:e}){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(u){this.log.error("failed to listen on a relay peer we were dialed via but did not have a reservation on",u)}let n=AbortSignal.timeout(this.stopTimeout),s=Ge(e).pb(Kt),i=await s.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 s.write({type:Kt.Type.STATUS,status:K.MALFORMED_MESSAGE},{signal:n}),await e.close();return}if(i.type!==Kt.Type.CONNECT){this.log.error("invalid stop connect request via peer %p",t.remotePeer),await s.write({type:Kt.Type.STATUS,status:K.UNEXPECTED_MESSAGE},{signal:n}),await e.close();return}if(!Y0(i)){this.log.error("invalid stop connect request via peer %p",t.remotePeer),await s.write({type:Kt.Type.STATUS,status:K.MALFORMED_MESSAGE},{signal:n}),await e.close();return}let o=dn(zt(i.peer.id));if(await this.connectionGater.denyInboundRelayedConnection?.(t.remotePeer,o)===!0){this.log.error("connection gater denied inbound relayed connection from %p",t.remotePeer),await s.write({type:Kt.Type.STATUS,status:K.PERMISSION_DENIED},{signal:n}),await e.close();return}this.log.trace("sending success response to %p",t.remotePeer),await s.write({type:Kt.Type.STATUS,status:K.OK},{signal:n});let a=new Sn(i.limit),c=t.remoteAddr.encapsulate(`/p2p-circuit/p2p/${o.toString()}`),h=this.addressManager.getAddresses()[0],f=rc({stream:s.unwrap().unwrap(),remoteAddr:c,localAddr:h,logger:this.logger,onDataRead:a.onData,onDataWrite:a.onData});this.log("new inbound relayed connection %a",f.remoteAddr),await this.upgrader.upgradeInbound(f,{limits:a.getLimits()}),this.log("%s connection %a upgraded","inbound",f.remoteAddr)}};function Kf(r={}){return t=>new Fi(t,r)}return rh(X0);})();
|
4
|
+
`));let t=this.idBlock.tagClass===3?`[${this.idBlock.tagNumber}]`:this.constructor.NAME;return e.length?`${t} :
|
5
|
+
${e.join(`
|
6
|
+
`)}`:`${t} :`}};Ul=Kt;k.Constructed=Ul;Kt.NAME="CONSTRUCTED";var ls=class extends Be{fromBER(e,t,n){return t}toBER(e){return et}};ls.override="EndOfContentValueBlock";var Dl,us=class extends be{constructor(e={}){super(e,ls),this.idBlock.tagClass=1,this.idBlock.tagNumber=0}};Dl=us;k.EndOfContent=Dl;us.NAME=rn;var Ol,Br=class extends be{constructor(e={}){super(e,Be),this.idBlock.tagClass=1,this.idBlock.tagNumber=5}fromBER(e,t,n){return this.lenBlock.length>0&&this.warnings.push("Non-zero length of value block for Null type"),this.idBlock.error.length||(this.blockLength+=this.idBlock.blockLength),this.lenBlock.error.length||(this.blockLength+=this.lenBlock.blockLength),this.blockLength+=n,t+n>e.byteLength?(this.error="End of input reached before message was fully decoded (inconsistent offset and length values)",-1):t+n}toBER(e,t){let n=new ArrayBuffer(2);if(!e){let s=new Uint8Array(n);s[0]=5,s[1]=0}return t&&t.write(n),n}onAsciiEncoding(){return`${this.constructor.NAME}`}};Ol=Br;k.Null=Ol;Br.NAME="NULL";var fs=class extends _t(Be){constructor({value:e,...t}={}){super(t),t.valueHex?this.valueHexView=z.BufferSourceConverter.toUint8Array(t.valueHex):this.valueHexView=new Uint8Array(1),e&&(this.value=e)}get value(){for(let e of this.valueHexView)if(e>0)return!0;return!1}set value(e){this.valueHexView[0]=e?255:0}fromBER(e,t,n){let s=z.BufferSourceConverter.toUint8Array(e);return Bt(this,s,t,n)?(this.valueHexView=s.subarray(t,t+n),n>1&&this.warnings.push("Boolean value encoded in more then 1 octet"),this.isHexOnly=!0,sa.call(this),this.blockLength=n,t+n):-1}toBER(){return this.valueHexView.slice()}toJSON(){return{...super.toJSON(),value:this.value}}};fs.NAME="BooleanValueBlock";var Ml,hs=class extends be{constructor(e={}){super(e,fs),this.idBlock.tagClass=1,this.idBlock.tagNumber=1}getValue(){return this.valueBlock.value}setValue(e){this.valueBlock.value=e}onAsciiEncoding(){return`${this.constructor.NAME} : ${this.getValue}`}};Ml=hs;k.Boolean=Ml;hs.NAME="BOOLEAN";var ds=class extends _t(ct){constructor({isConstructed:e=!1,...t}={}){super(t),this.isConstructed=e}fromBER(e,t,n){let s=0;if(this.isConstructed){if(this.isHexOnly=!1,s=ct.prototype.fromBER.call(this,e,t,n),s===-1)return s;for(let i=0;i<this.value.length;i++){let o=this.value[i].constructor.NAME;if(o===rn){if(this.isIndefiniteForm)break;return this.error="EndOfContent is unexpected, OCTET STRING may consists of OCTET STRINGs only",-1}if(o!==Cl)return this.error="OCTET STRING may consists of OCTET STRINGs only",-1}}else this.isHexOnly=!0,s=super.fromBER(e,t,n),this.blockLength=n;return s}toBER(e,t){return this.isConstructed?ct.prototype.toBER.call(this,e,t):e?new ArrayBuffer(this.valueHexView.byteLength):this.valueHexView.slice().buffer}toJSON(){return{...super.toJSON(),isConstructed:this.isConstructed}}};ds.NAME="OctetStringValueBlock";var Pl,ps=class r extends be{constructor({idBlock:e={},lenBlock:t={},...n}={}){var s,i;(s=n.isConstructed)!==null&&s!==void 0||(n.isConstructed=!!(!((i=n.value)===null||i===void 0)&&i.length)),super({idBlock:{isConstructed:n.isConstructed,...e},lenBlock:{...t,isIndefiniteForm:!!n.isIndefiniteForm},...n},ds),this.idBlock.tagClass=1,this.idBlock.tagNumber=4}fromBER(e,t,n){if(this.valueBlock.isConstructed=this.idBlock.isConstructed,this.valueBlock.isIndefiniteForm=this.lenBlock.isIndefiniteForm,n===0)return this.idBlock.error.length===0&&(this.blockLength+=this.idBlock.blockLength),this.lenBlock.error.length===0&&(this.blockLength+=this.lenBlock.blockLength),t;if(!this.valueBlock.isConstructed){let i=(e instanceof ArrayBuffer?new Uint8Array(e):e).subarray(t,t+n);try{if(i.byteLength){let o=Ks(i,0,i.byteLength);o.offset!==-1&&o.offset===n&&(this.valueBlock.value=[o.result])}}catch{}}return super.fromBER(e,t,n)}onAsciiEncoding(){return this.valueBlock.isConstructed||this.valueBlock.value&&this.valueBlock.value.length?Kt.prototype.onAsciiEncoding.call(this):`${this.constructor.NAME} : ${z.Convert.ToHex(this.valueBlock.valueHexView)}`}getValue(){if(!this.idBlock.isConstructed)return this.valueBlock.valueHexView.slice().buffer;let e=[];for(let t of this.valueBlock.value)t instanceof r&&e.push(t.valueBlock.valueHexView);return z.BufferSourceConverter.concat(e)}};Pl=ps;k.OctetString=Pl;ps.NAME=Cl;var gs=class extends _t(ct){constructor({unusedBits:e=0,isConstructed:t=!1,...n}={}){super(n),this.unusedBits=e,this.isConstructed=t,this.blockLength=this.valueHexView.byteLength}fromBER(e,t,n){if(!n)return t;let s=-1;if(this.isConstructed){if(s=ct.prototype.fromBER.call(this,e,t,n),s===-1)return s;for(let a of this.value){let c=a.constructor.NAME;if(c===rn){if(this.isIndefiniteForm)break;return this.error="EndOfContent is unexpected, BIT STRING may consists of BIT STRINGs only",-1}if(c!==Nl)return this.error="BIT STRING may consists of BIT STRINGs only",-1;let h=a.valueBlock;if(this.unusedBits>0&&h.unusedBits>0)return this.error='Using of "unused bits" inside constructive BIT STRING allowed for least one only',-1;this.unusedBits=h.unusedBits}return s}let i=z.BufferSourceConverter.toUint8Array(e);if(!Bt(this,i,t,n))return-1;let o=i.subarray(t,t+n);if(this.unusedBits=o[0],this.unusedBits>7)return this.error="Unused bits for BitString must be in range 0-7",-1;if(!this.unusedBits){let a=o.subarray(1);try{if(a.byteLength){let c=Ks(a,0,a.byteLength);c.offset!==-1&&c.offset===n-1&&(this.value=[c.result])}}catch{}}return this.valueHexView=o.subarray(1),this.blockLength=o.length,t+n}toBER(e,t){if(this.isConstructed)return ct.prototype.toBER.call(this,e,t);if(e)return new ArrayBuffer(this.valueHexView.byteLength+1);if(!this.valueHexView.byteLength)return et;let n=new Uint8Array(this.valueHexView.length+1);return n[0]=this.unusedBits,n.set(this.valueHexView,1),n.buffer}toJSON(){return{...super.toJSON(),unusedBits:this.unusedBits,isConstructed:this.isConstructed}}};gs.NAME="BitStringValueBlock";var Vl,_r=class extends be{constructor({idBlock:e={},lenBlock:t={},...n}={}){var s,i;(s=n.isConstructed)!==null&&s!==void 0||(n.isConstructed=!!(!((i=n.value)===null||i===void 0)&&i.length)),super({idBlock:{isConstructed:n.isConstructed,...e},lenBlock:{...t,isIndefiniteForm:!!n.isIndefiniteForm},...n},gs),this.idBlock.tagClass=1,this.idBlock.tagNumber=3}fromBER(e,t,n){return this.valueBlock.isConstructed=this.idBlock.isConstructed,this.valueBlock.isIndefiniteForm=this.lenBlock.isIndefiniteForm,super.fromBER(e,t,n)}onAsciiEncoding(){if(this.valueBlock.isConstructed||this.valueBlock.value&&this.valueBlock.value.length)return Kt.prototype.onAsciiEncoding.call(this);{let e=[],t=this.valueBlock.valueHexView;for(let s of t)e.push(s.toString(2).padStart(8,"0"));let n=e.join("");return`${this.constructor.NAME} : ${n.substring(0,n.length-this.valueBlock.unusedBits)}`}}};Vl=_r;k.BitString=Vl;_r.NAME=Nl;var Hl;function Vp(r,e){let t=new Uint8Array([0]),n=new Uint8Array(r),s=new Uint8Array(e),i=n.slice(0),o=i.length-1,a=s.slice(0),c=a.length-1,h=0,f=c<o?o:c,u=0;for(let m=f;m>=0;m--,u++){switch(!0){case u<a.length:h=i[o-u]+a[c-u]+t[0];break;default:h=i[o-u]+t[0]}switch(t[0]=h/10,!0){case u>=i.length:i=rs(new Uint8Array([h%10]),i);break;default:i[o-u]=h%10}}return t[0]>0&&(i=rs(t,i)),i}function kl(r){if(r>=en.length)for(let e=en.length;e<=r;e++){let t=new Uint8Array([0]),n=en[e-1].slice(0);for(let s=n.length-1;s>=0;s--){let i=new Uint8Array([(n[s]<<1)+t[0]]);t[0]=i[0]/10,n[s]=i[0]%10}t[0]>0&&(n=rs(t,n)),en.push(n)}return en[r]}function Hp(r,e){let t=0,n=new Uint8Array(r),s=new Uint8Array(e),i=n.slice(0),o=i.length-1,a=s.slice(0),c=a.length-1,h,f=0;for(let u=c;u>=0;u--,f++)switch(h=i[o-f]-a[c-f]-t,!0){case h<0:t=1,i[o-f]=h+10;break;default:t=0,i[o-f]=h}if(t>0)for(let u=o-c+1;u>=0;u--,f++)if(h=i[o-f]-t,h<0)t=1,i[o-f]=h+10;else{t=0,i[o-f]=h;break}return i.slice()}var nn=class extends _t(Be){constructor({value:e,...t}={}){super(t),this._valueDec=0,t.valueHex&&this.setValueHex(),e!==void 0&&(this.valueDec=e)}setValueHex(){this.valueHexView.length>=4?(this.warnings.push("Too big Integer for decoding, hex only"),this.isHexOnly=!0,this._valueDec=0):(this.isHexOnly=!1,this.valueHexView.length>0&&(this._valueDec=sa.call(this)))}set valueDec(e){this._valueDec=e,this.isHexOnly=!1,this.valueHexView=new Uint8Array(_l(e))}get valueDec(){return this._valueDec}fromDER(e,t,n,s=0){let i=this.fromBER(e,t,n);if(i===-1)return i;let o=this.valueHexView;return o[0]===0&&o[1]&128?this.valueHexView=o.subarray(1):s!==0&&o.length<s&&(s-o.length>1&&(s=o.length+1),this.valueHexView=o.subarray(s-o.length)),i}toDER(e=!1){let t=this.valueHexView;switch(!0){case(t[0]&128)!==0:{let n=new Uint8Array(this.valueHexView.length+1);n[0]=0,n.set(t,1),this.valueHexView=n}break;case(t[0]===0&&(t[1]&128)===0):this.valueHexView=this.valueHexView.subarray(1);break}return this.toBER(e)}fromBER(e,t,n){let s=super.fromBER(e,t,n);return s===-1||this.setValueHex(),s}toBER(e){return e?new ArrayBuffer(this.valueHexView.length):this.valueHexView.slice().buffer}toJSON(){return{...super.toJSON(),valueDec:this.valueDec}}toString(){let e=this.valueHexView.length*8-1,t=new Uint8Array(this.valueHexView.length*8/3),n=0,s,i=this.valueHexView,o="",a=!1;for(let c=i.byteLength-1;c>=0;c--){s=i[c];for(let h=0;h<8;h++){if((s&1)===1)switch(n){case e:t=Hp(kl(n),t),o="-";break;default:t=Vp(t,kl(n))}n++,s>>=1}}for(let c=0;c<t.length;c++)t[c]&&(a=!0),a&&(o+=Tl.charAt(t[c]));return a===!1&&(o+=Tl.charAt(0)),o}};Hl=nn;nn.NAME="IntegerValueBlock";Object.defineProperty(Hl.prototype,"valueHex",{set:function(r){this.valueHexView=new Uint8Array(r),this.setValueHex()},get:function(){return this.valueHexView.slice().buffer}});var Fl,we=class r extends be{constructor(e={}){super(e,nn),this.idBlock.tagClass=1,this.idBlock.tagNumber=2}toBigInt(){return ns(),BigInt(this.valueBlock.toString())}static fromBigInt(e){ns();let t=BigInt(e),n=new tn,s=t.toString(16).replace(/^-/,""),i=new Uint8Array(z.Convert.FromHex(s));if(t<0){let a=new Uint8Array(i.length+(i[0]&128?1:0));a[0]|=128;let h=BigInt(`0x${z.Convert.ToHex(a)}`)+t,f=z.BufferSourceConverter.toUint8Array(z.Convert.FromHex(h.toString(16)));f[0]|=128,n.write(f)}else i[0]&128&&n.write(new Uint8Array([0])),n.write(i);return new r({valueHex:n.final()})}convertToDER(){let e=new r({valueHex:this.valueBlock.valueHexView});return e.valueBlock.toDER(),e}convertFromDER(){return new r({valueHex:this.valueBlock.valueHexView[0]===0?this.valueBlock.valueHexView.subarray(1):this.valueBlock.valueHexView})}onAsciiEncoding(){return`${this.constructor.NAME} : ${this.valueBlock.toString()}`}};Fl=we;k.Integer=Fl;we.NAME="INTEGER";var Kl,ms=class extends we{constructor(e={}){super(e),this.idBlock.tagClass=1,this.idBlock.tagNumber=10}};Kl=ms;k.Enumerated=Kl;ms.NAME="ENUMERATED";var sn=class extends _t(Be){constructor({valueDec:e=-1,isFirstSid:t=!1,...n}={}){super(n),this.valueDec=e,this.isFirstSid=t}fromBER(e,t,n){if(!n)return t;let s=z.BufferSourceConverter.toUint8Array(e);if(!Bt(this,s,t,n))return-1;let i=s.subarray(t,t+n);this.valueHexView=new Uint8Array(n);for(let a=0;a<n&&(this.valueHexView[a]=i[a]&127,this.blockLength++,!!(i[a]&128));a++);let o=new Uint8Array(this.blockLength);for(let a=0;a<this.blockLength;a++)o[a]=this.valueHexView[a];return this.valueHexView=o,i[this.blockLength-1]&128?(this.error="End of input reached before message was fully decoded",-1):(this.valueHexView[0]===0&&this.warnings.push("Needlessly long format of SID encoding"),this.blockLength<=8?this.valueDec=ir(this.valueHexView,7):(this.isHexOnly=!0,this.warnings.push("Too big SID for decoding, hex only")),t+this.blockLength)}set valueBigInt(e){ns();let t=BigInt(e).toString(2);for(;t.length%7;)t="0"+t;let n=new Uint8Array(t.length/7);for(let s=0;s<n.length;s++)n[s]=parseInt(t.slice(s*7,s*7+7),2)+(s+1<n.length?128:0);this.fromBER(n.buffer,0,n.length)}toBER(e){if(this.isHexOnly){if(e)return new ArrayBuffer(this.valueHexView.byteLength);let s=this.valueHexView,i=new Uint8Array(this.blockLength);for(let o=0;o<this.blockLength-1;o++)i[o]=s[o]|128;return i[this.blockLength-1]=s[this.blockLength-1],i.buffer}let t=Ft(this.valueDec,7);if(t.byteLength===0)return this.error="Error during encoding SID value",et;let n=new Uint8Array(t.byteLength);if(!e){let s=new Uint8Array(t),i=t.byteLength-1;for(let o=0;o<i;o++)n[o]=s[o]|128;n[i]=s[i]}return n}toString(){let e="";if(this.isHexOnly)e=z.Convert.ToHex(this.valueHexView);else if(this.isFirstSid){let t=this.valueDec;this.valueDec<=39?e="0.":this.valueDec<=79?(e="1.",t-=40):(e="2.",t-=80),e+=t.toString()}else e=this.valueDec.toString();return e}toJSON(){return{...super.toJSON(),valueDec:this.valueDec,isFirstSid:this.isFirstSid}}};sn.NAME="sidBlock";var ys=class extends Be{constructor({value:e=Tr,...t}={}){super(t),this.value=[],e&&this.fromString(e)}fromBER(e,t,n){let s=t;for(;n>0;){let i=new sn;if(s=i.fromBER(e,s,n),s===-1)return this.blockLength=0,this.error=i.error,s;this.value.length===0&&(i.isFirstSid=!0),this.blockLength+=i.blockLength,n-=i.blockLength,this.value.push(i)}return s}toBER(e){let t=[];for(let n=0;n<this.value.length;n++){let s=this.value[n].toBER(e);if(s.byteLength===0)return this.error=this.value[n].error,et;t.push(s)}return ia(t)}fromString(e){this.value=[];let t=0,n=0,s="",i=!1;do if(n=e.indexOf(".",t),n===-1?s=e.substring(t):s=e.substring(t,n),t=n+1,i){let o=this.value[0],a=0;switch(o.valueDec){case 0:break;case 1:a=40;break;case 2:a=80;break;default:this.value=[];return}let c=parseInt(s,10);if(isNaN(c))return;o.valueDec=c+a,i=!1}else{let o=new sn;if(s>Number.MAX_SAFE_INTEGER){ns();let a=BigInt(s);o.valueBigInt=a}else if(o.valueDec=parseInt(s,10),isNaN(o.valueDec))return;this.value.length||(o.isFirstSid=!0,i=!0),this.value.push(o)}while(n!==-1)}toString(){let e="",t=!1;for(let n=0;n<this.value.length;n++){t=this.value[n].isHexOnly;let s=this.value[n].toString();n!==0&&(e=`${e}.`),t?(s=`{${s}}`,this.value[n].isFirstSid?e=`2.{${s} - 80}`:e+=s):e+=s}return e}toJSON(){let e={...super.toJSON(),value:this.toString(),sidArray:[]};for(let t=0;t<this.value.length;t++)e.sidArray.push(this.value[t].toJSON());return e}};ys.NAME="ObjectIdentifierValueBlock";var ql,Ir=class extends be{constructor(e={}){super(e,ys),this.idBlock.tagClass=1,this.idBlock.tagNumber=6}getValue(){return this.valueBlock.toString()}setValue(e){this.valueBlock.fromString(e)}onAsciiEncoding(){return`${this.constructor.NAME} : ${this.valueBlock.toString()||"empty"}`}toJSON(){return{...super.toJSON(),value:this.getValue()}}};ql=Ir;k.ObjectIdentifier=ql;Ir.NAME="OBJECT IDENTIFIER";var on=class extends _t(Et){constructor({valueDec:e=0,...t}={}){super(t),this.valueDec=e}fromBER(e,t,n){if(n===0)return t;let s=z.BufferSourceConverter.toUint8Array(e);if(!Bt(this,s,t,n))return-1;let i=s.subarray(t,t+n);this.valueHexView=new Uint8Array(n);for(let a=0;a<n&&(this.valueHexView[a]=i[a]&127,this.blockLength++,!!(i[a]&128));a++);let o=new Uint8Array(this.blockLength);for(let a=0;a<this.blockLength;a++)o[a]=this.valueHexView[a];return this.valueHexView=o,i[this.blockLength-1]&128?(this.error="End of input reached before message was fully decoded",-1):(this.valueHexView[0]===0&&this.warnings.push("Needlessly long format of SID encoding"),this.blockLength<=8?this.valueDec=ir(this.valueHexView,7):(this.isHexOnly=!0,this.warnings.push("Too big SID for decoding, hex only")),t+this.blockLength)}toBER(e){if(this.isHexOnly){if(e)return new ArrayBuffer(this.valueHexView.byteLength);let s=this.valueHexView,i=new Uint8Array(this.blockLength);for(let o=0;o<this.blockLength-1;o++)i[o]=s[o]|128;return i[this.blockLength-1]=s[this.blockLength-1],i.buffer}let t=Ft(this.valueDec,7);if(t.byteLength===0)return this.error="Error during encoding SID value",et;let n=new Uint8Array(t.byteLength);if(!e){let s=new Uint8Array(t),i=t.byteLength-1;for(let o=0;o<i;o++)n[o]=s[o]|128;n[i]=s[i]}return n.buffer}toString(){let e="";return this.isHexOnly?e=z.Convert.ToHex(this.valueHexView):e=this.valueDec.toString(),e}toJSON(){return{...super.toJSON(),valueDec:this.valueDec}}};on.NAME="relativeSidBlock";var bs=class extends Be{constructor({value:e=Tr,...t}={}){super(t),this.value=[],e&&this.fromString(e)}fromBER(e,t,n){let s=t;for(;n>0;){let i=new on;if(s=i.fromBER(e,s,n),s===-1)return this.blockLength=0,this.error=i.error,s;this.blockLength+=i.blockLength,n-=i.blockLength,this.value.push(i)}return s}toBER(e,t){let n=[];for(let s=0;s<this.value.length;s++){let i=this.value[s].toBER(e);if(i.byteLength===0)return this.error=this.value[s].error,et;n.push(i)}return ia(n)}fromString(e){this.value=[];let t=0,n=0,s="";do{n=e.indexOf(".",t),n===-1?s=e.substring(t):s=e.substring(t,n),t=n+1;let i=new on;if(i.valueDec=parseInt(s,10),isNaN(i.valueDec))return!0;this.value.push(i)}while(n!==-1);return!0}toString(){let e="",t=!1;for(let n=0;n<this.value.length;n++){t=this.value[n].isHexOnly;let s=this.value[n].toString();n!==0&&(e=`${e}.`),t&&(s=`{${s}}`),e+=s}return e}toJSON(){let e={...super.toJSON(),value:this.toString(),sidArray:[]};for(let t=0;t<this.value.length;t++)e.sidArray.push(this.value[t].toJSON());return e}};bs.NAME="RelativeObjectIdentifierValueBlock";var zl,ws=class extends be{constructor(e={}){super(e,bs),this.idBlock.tagClass=1,this.idBlock.tagNumber=13}getValue(){return this.valueBlock.toString()}setValue(e){this.valueBlock.fromString(e)}onAsciiEncoding(){return`${this.constructor.NAME} : ${this.valueBlock.toString()||"empty"}`}toJSON(){return{...super.toJSON(),value:this.getValue()}}};zl=ws;k.RelativeObjectIdentifier=zl;ws.NAME="RelativeObjectIdentifier";var $l,St=class extends Kt{constructor(e={}){super(e),this.idBlock.tagClass=1,this.idBlock.tagNumber=16}};$l=St;k.Sequence=$l;St.NAME="SEQUENCE";var Gl,xs=class extends Kt{constructor(e={}){super(e),this.idBlock.tagClass=1,this.idBlock.tagNumber=17}};Gl=xs;k.Set=Gl;xs.NAME="SET";var vs=class extends _t(Be){constructor({...e}={}){super(e),this.isHexOnly=!0,this.value=Tr}toJSON(){return{...super.toJSON(),value:this.value}}};vs.NAME="StringValueBlock";var Es=class extends vs{};Es.NAME="SimpleStringValueBlock";var Ce=class extends os{constructor({...e}={}){super(e,Es)}fromBuffer(e){this.valueBlock.value=String.fromCharCode.apply(null,z.BufferSourceConverter.toUint8Array(e))}fromString(e){let t=e.length,n=this.valueBlock.valueHexView=new Uint8Array(t);for(let s=0;s<t;s++)n[s]=e.charCodeAt(s);this.valueBlock.value=e}};Ce.NAME="SIMPLE STRING";var Ss=class extends Ce{fromBuffer(e){this.valueBlock.valueHexView=z.BufferSourceConverter.toUint8Array(e);try{this.valueBlock.value=z.Convert.ToUtf8String(e)}catch(t){this.warnings.push(`Error during "decodeURIComponent": ${t}, using raw string`),this.valueBlock.value=z.Convert.ToBinary(e)}}fromString(e){this.valueBlock.valueHexView=new Uint8Array(z.Convert.FromUtf8String(e)),this.valueBlock.value=e}};Ss.NAME="Utf8StringValueBlock";var Wl,At=class extends Ss{constructor(e={}){super(e),this.idBlock.tagClass=1,this.idBlock.tagNumber=12}};Wl=At;k.Utf8String=Wl;At.NAME="UTF8String";var As=class extends Ce{fromBuffer(e){this.valueBlock.value=z.Convert.ToUtf16String(e),this.valueBlock.valueHexView=z.BufferSourceConverter.toUint8Array(e)}fromString(e){this.valueBlock.value=e,this.valueBlock.valueHexView=new Uint8Array(z.Convert.FromUtf16String(e))}};As.NAME="BmpStringValueBlock";var Zl,Bs=class extends As{constructor({...e}={}){super(e),this.idBlock.tagClass=1,this.idBlock.tagNumber=30}};Zl=Bs;k.BmpString=Zl;Bs.NAME="BMPString";var _s=class extends Ce{fromBuffer(e){let t=ArrayBuffer.isView(e)?e.slice().buffer:e.slice(0),n=new Uint8Array(t);for(let s=0;s<n.length;s+=4)n[s]=n[s+3],n[s+1]=n[s+2],n[s+2]=0,n[s+3]=0;this.valueBlock.value=String.fromCharCode.apply(null,new Uint32Array(t))}fromString(e){let t=e.length,n=this.valueBlock.valueHexView=new Uint8Array(t*4);for(let s=0;s<t;s++){let i=Ft(e.charCodeAt(s),8),o=new Uint8Array(i);if(o.length>4)continue;let a=4-o.length;for(let c=o.length-1;c>=0;c--)n[s*4+c+a]=o[c]}this.valueBlock.value=e}};_s.NAME="UniversalStringValueBlock";var jl,Is=class extends _s{constructor({...e}={}){super(e),this.idBlock.tagClass=1,this.idBlock.tagNumber=28}};jl=Is;k.UniversalString=jl;Is.NAME="UniversalString";var Yl,Ts=class extends Ce{constructor(e={}){super(e),this.idBlock.tagClass=1,this.idBlock.tagNumber=18}};Yl=Ts;k.NumericString=Yl;Ts.NAME="NumericString";var Xl,ks=class extends Ce{constructor(e={}){super(e),this.idBlock.tagClass=1,this.idBlock.tagNumber=19}};Xl=ks;k.PrintableString=Xl;ks.NAME="PrintableString";var Jl,Cs=class extends Ce{constructor(e={}){super(e),this.idBlock.tagClass=1,this.idBlock.tagNumber=20}};Jl=Cs;k.TeletexString=Jl;Cs.NAME="TeletexString";var Ql,Ns=class extends Ce{constructor(e={}){super(e),this.idBlock.tagClass=1,this.idBlock.tagNumber=21}};Ql=Ns;k.VideotexString=Ql;Ns.NAME="VideotexString";var eu,Ls=class extends Ce{constructor(e={}){super(e),this.idBlock.tagClass=1,this.idBlock.tagNumber=22}};eu=Ls;k.IA5String=eu;Ls.NAME="IA5String";var tu,Rs=class extends Ce{constructor(e={}){super(e),this.idBlock.tagClass=1,this.idBlock.tagNumber=25}};tu=Rs;k.GraphicString=tu;Rs.NAME="GraphicString";var ru,an=class extends Ce{constructor(e={}){super(e),this.idBlock.tagClass=1,this.idBlock.tagNumber=26}};ru=an;k.VisibleString=ru;an.NAME="VisibleString";var nu,Us=class extends Ce{constructor(e={}){super(e),this.idBlock.tagClass=1,this.idBlock.tagNumber=27}};nu=Us;k.GeneralString=nu;Us.NAME="GeneralString";var su,Ds=class extends Ce{constructor(e={}){super(e),this.idBlock.tagClass=1,this.idBlock.tagNumber=29}};su=Ds;k.CharacterString=su;Ds.NAME="CharacterString";var iu,cn=class extends an{constructor({value:e,valueDate:t,...n}={}){if(super(n),this.year=0,this.month=0,this.day=0,this.hour=0,this.minute=0,this.second=0,e){this.fromString(e),this.valueBlock.valueHexView=new Uint8Array(e.length);for(let s=0;s<e.length;s++)this.valueBlock.valueHexView[s]=e.charCodeAt(s)}t&&(this.fromDate(t),this.valueBlock.valueHexView=new Uint8Array(this.toBuffer())),this.idBlock.tagClass=1,this.idBlock.tagNumber=23}fromBuffer(e){this.fromString(String.fromCharCode.apply(null,z.BufferSourceConverter.toUint8Array(e)))}toBuffer(){let e=this.toString(),t=new ArrayBuffer(e.length),n=new Uint8Array(t);for(let s=0;s<e.length;s++)n[s]=e.charCodeAt(s);return t}fromDate(e){this.year=e.getUTCFullYear(),this.month=e.getUTCMonth()+1,this.day=e.getUTCDate(),this.hour=e.getUTCHours(),this.minute=e.getUTCMinutes(),this.second=e.getUTCSeconds()}toDate(){return new Date(Date.UTC(this.year,this.month-1,this.day,this.hour,this.minute,this.second))}fromString(e){let n=/(\d{2})(\d{2})(\d{2})(\d{2})(\d{2})(\d{2})Z/ig.exec(e);if(n===null){this.error="Wrong input string for conversion";return}let s=parseInt(n[1],10);s>=50?this.year=1900+s:this.year=2e3+s,this.month=parseInt(n[2],10),this.day=parseInt(n[3],10),this.hour=parseInt(n[4],10),this.minute=parseInt(n[5],10),this.second=parseInt(n[6],10)}toString(e="iso"){if(e==="iso"){let t=new Array(7);return t[0]=Ve(this.year<2e3?this.year-1900:this.year-2e3,2),t[1]=Ve(this.month,2),t[2]=Ve(this.day,2),t[3]=Ve(this.hour,2),t[4]=Ve(this.minute,2),t[5]=Ve(this.second,2),t[6]="Z",t.join("")}return super.toString(e)}onAsciiEncoding(){return`${this.constructor.NAME} : ${this.toDate().toISOString()}`}toJSON(){return{...super.toJSON(),year:this.year,month:this.month,day:this.day,hour:this.hour,minute:this.minute,second:this.second}}};iu=cn;k.UTCTime=iu;cn.NAME="UTCTime";var ou,Os=class extends cn{constructor(e={}){var t;super(e),(t=this.millisecond)!==null&&t!==void 0||(this.millisecond=0),this.idBlock.tagClass=1,this.idBlock.tagNumber=24}fromDate(e){super.fromDate(e),this.millisecond=e.getUTCMilliseconds()}toDate(){return new Date(Date.UTC(this.year,this.month-1,this.day,this.hour,this.minute,this.second,this.millisecond))}fromString(e){let t=!1,n="",s="",i=0,o,a=0,c=0;if(e[e.length-1]==="Z")n=e.substring(0,e.length-1),t=!0;else{let u=new Number(e[e.length-1]);if(isNaN(u.valueOf()))throw new Error("Wrong input string for conversion");n=e}if(t){if(n.indexOf("+")!==-1)throw new Error("Wrong input string for conversion");if(n.indexOf("-")!==-1)throw new Error("Wrong input string for conversion")}else{let u=1,m=n.indexOf("+"),l="";if(m===-1&&(m=n.indexOf("-"),u=-1),m!==-1){if(l=n.substring(m+1),n=n.substring(0,m),l.length!==2&&l.length!==4)throw new Error("Wrong input string for conversion");let d=parseInt(l.substring(0,2),10);if(isNaN(d.valueOf()))throw new Error("Wrong input string for conversion");if(a=u*d,l.length===4){if(d=parseInt(l.substring(2,4),10),isNaN(d.valueOf()))throw new Error("Wrong input string for conversion");c=u*d}}}let h=n.indexOf(".");if(h===-1&&(h=n.indexOf(",")),h!==-1){let u=new Number(`0${n.substring(h)}`);if(isNaN(u.valueOf()))throw new Error("Wrong input string for conversion");i=u.valueOf(),s=n.substring(0,h)}else s=n;switch(!0){case s.length===8:if(o=/(\d{4})(\d{2})(\d{2})/ig,h!==-1)throw new Error("Wrong input string for conversion");break;case s.length===10:if(o=/(\d{4})(\d{2})(\d{2})(\d{2})/ig,h!==-1){let u=60*i;this.minute=Math.floor(u),u=60*(u-this.minute),this.second=Math.floor(u),u=1e3*(u-this.second),this.millisecond=Math.floor(u)}break;case s.length===12:if(o=/(\d{4})(\d{2})(\d{2})(\d{2})(\d{2})/ig,h!==-1){let u=60*i;this.second=Math.floor(u),u=1e3*(u-this.second),this.millisecond=Math.floor(u)}break;case s.length===14:if(o=/(\d{4})(\d{2})(\d{2})(\d{2})(\d{2})(\d{2})/ig,h!==-1){let u=1e3*i;this.millisecond=Math.floor(u)}break;default:throw new Error("Wrong input string for conversion")}let f=o.exec(s);if(f===null)throw new Error("Wrong input string for conversion");for(let u=1;u<f.length;u++)switch(u){case 1:this.year=parseInt(f[u],10);break;case 2:this.month=parseInt(f[u],10);break;case 3:this.day=parseInt(f[u],10);break;case 4:this.hour=parseInt(f[u],10)+a;break;case 5:this.minute=parseInt(f[u],10)+c;break;case 6:this.second=parseInt(f[u],10);break;default:throw new Error("Wrong input string for conversion")}if(t===!1){let u=new Date(this.year,this.month,this.day,this.hour,this.minute,this.second,this.millisecond);this.year=u.getUTCFullYear(),this.month=u.getUTCMonth(),this.day=u.getUTCDay(),this.hour=u.getUTCHours(),this.minute=u.getUTCMinutes(),this.second=u.getUTCSeconds(),this.millisecond=u.getUTCMilliseconds()}}toString(e="iso"){if(e==="iso"){let t=[];return t.push(Ve(this.year,4)),t.push(Ve(this.month,2)),t.push(Ve(this.day,2)),t.push(Ve(this.hour,2)),t.push(Ve(this.minute,2)),t.push(Ve(this.second,2)),this.millisecond!==0&&(t.push("."),t.push(Ve(this.millisecond,3))),t.push("Z"),t.join("")}return super.toString(e)}toJSON(){return{...super.toJSON(),millisecond:this.millisecond}}};ou=Os;k.GeneralizedTime=ou;Os.NAME="GeneralizedTime";var au,Ms=class extends At{constructor(e={}){super(e),this.idBlock.tagClass=1,this.idBlock.tagNumber=31}};au=Ms;k.DATE=au;Ms.NAME="DATE";var cu,Ps=class extends At{constructor(e={}){super(e),this.idBlock.tagClass=1,this.idBlock.tagNumber=32}};cu=Ps;k.TimeOfDay=cu;Ps.NAME="TimeOfDay";var lu,Vs=class extends At{constructor(e={}){super(e),this.idBlock.tagClass=1,this.idBlock.tagNumber=33}};lu=Vs;k.DateTime=lu;Vs.NAME="DateTime";var uu,Hs=class extends At{constructor(e={}){super(e),this.idBlock.tagClass=1,this.idBlock.tagNumber=34}};uu=Hs;k.Duration=uu;Hs.NAME="Duration";var fu,Fs=class extends At{constructor(e={}){super(e),this.idBlock.tagClass=1,this.idBlock.tagNumber=14}};fu=Fs;k.TIME=fu;Fs.NAME="TIME";function ce(r,e="utf8"){let t=Wn[e];if(t==null)throw new Error(`Unsupported encoding "${e}"`);return t.encoder.encode(r).substring(1)}var ln=class extends Error{constructor(e="An error occurred while verifying a message"){super(e),this.name="VerificationError"}},qs=class extends Error{constructor(e="Missing Web Crypto API"){super(e),this.name="WebCryptoMissingError"}};var hu={get(r=globalThis){let e=r.crypto;if(e?.subtle==null)throw new qs("Missing Web Crypto API. The most likely cause of this error is that this page is being accessed from an insecure context (i.e. not HTTPS). For more information and possible resolutions see https://github.com/libp2p/js-libp2p/blob/main/packages/crypto/README.md#web-crypto-api");return e}};var qt=hu;async function du(r){let e=await qt.get().subtle.generateKey({name:"RSASSA-PKCS1-v1_5",modulusLength:r,publicExponent:new Uint8Array([1,0,1]),hash:{name:"SHA-256"}},!0,["sign","verify"]),t=await Kp(e);return{privateKey:t[0],publicKey:t[1]}}async function pu(r,e){let t=await qt.get().subtle.importKey("jwk",r,{name:"RSASSA-PKCS1-v1_5",hash:{name:"SHA-256"}},!1,["sign"]),n=await qt.get().subtle.sign({name:"RSASSA-PKCS1-v1_5"},t,e instanceof Uint8Array?e:e.subarray());return new Uint8Array(n,0,n.byteLength)}async function gu(r,e,t){let n=await qt.get().subtle.importKey("jwk",r,{name:"RSASSA-PKCS1-v1_5",hash:{name:"SHA-256"}},!1,["verify"]);return qt.get().subtle.verify({name:"RSASSA-PKCS1-v1_5"},n,e,t instanceof Uint8Array?t:t.subarray())}async function Kp(r){if(r.privateKey==null||r.publicKey==null)throw new ve("Private and public key are required");return Promise.all([qt.get().subtle.exportKey("jwk",r.privateKey),qt.get().subtle.exportKey("jwk",r.publicKey)])}function ca(r){if(r.kty!=="RSA")throw new ve("invalid key type");if(r.n==null)throw new ve("invalid key modulus");return G(r.n,"base64url").length*8}var kr=class{type="RSA";_key;_raw;_multihash;constructor(e,t){this._key=e,this._multihash=t}get raw(){return this._raw==null&&(this._raw=un.jwkToPkix(this._key)),this._raw}toMultihash(){return this._multihash}toCID(){return pe.createV1(114,this._multihash)}toString(){return ee.encode(this.toMultihash().bytes).substring(1)}equals(e){return e==null||!(e.raw instanceof Uint8Array)?!1:ge(this.raw,e.raw)}verify(e,t){return gu(this._key,t,e)}},fn=class{type="RSA";_key;_raw;publicKey;constructor(e,t){this._key=e,this.publicKey=t}get raw(){return this._raw==null&&(this._raw=un.jwkToPkcs1(this._key)),this._raw}equals(e){return e==null||!(e.raw instanceof Uint8Array)?!1:ge(this.raw,e.raw)}sign(e){return pu(this._key,e)}};var zs=8192,la=18;function mu(r){let{result:e}=aa(r),t=e.valueBlock.value;return{n:lt(t[1]),e:lt(t[2]),d:lt(t[3]),p:lt(t[4]),q:lt(t[5]),dp:lt(t[6]),dq:lt(t[7]),qi:lt(t[8]),kty:"RSA",alg:"RS256"}}function qp(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 ve("JWK was missing components");let t=new St({value:[new we({value:0}),we.fromBigInt(ut(G(r.n,"base64url"))),we.fromBigInt(ut(G(r.e,"base64url"))),we.fromBigInt(ut(G(r.d,"base64url"))),we.fromBigInt(ut(G(r.p,"base64url"))),we.fromBigInt(ut(G(r.q,"base64url"))),we.fromBigInt(ut(G(r.dp,"base64url"))),we.fromBigInt(ut(G(r.dq,"base64url"))),we.fromBigInt(ut(G(r.qi,"base64url")))]}).toBER();return new Uint8Array(t,0,t.byteLength)}function yu(r){let{result:e}=aa(r),t=e.valueBlock.value[1].valueBlock.value[0].valueBlock.value;return{kty:"RSA",n:lt(t[0]),e:lt(t[1])}}function ua(r){if(r.n==null||r.e==null)throw new ve("JWK was missing components");let t=new St({value:[new St({value:[new Ir({value:"1.2.840.113549.1.1.1"}),new Br]}),new _r({valueHex:new St({value:[we.fromBigInt(ut(G(r.n,"base64url"))),we.fromBigInt(ut(G(r.e,"base64url")))]}).toBER()})]}).toBER();return new Uint8Array(t,0,t.byteLength)}function lt(r){let e=r.valueBlock.valueHexView;for(;e[0]===0;)e=e.subarray(1);return ce(e,"base64url")}function ut(r){let e=[];return r.forEach(function(t){let n=t.toString(16);n.length%2>0&&(n=`0${n}`),e.push(n)}),BigInt("0x"+e.join(""))}function bu(r){let e=mu(r);return wu(e)}function fa(r){let e=yu(r);if(ca(e)>zs)throw new fr("Key size is too large");let t=Qn(at.encode({Type:fe.RSA,Data:r})),n=Ze(la,t);return new kr(e,n)}function wu(r){if(ca(r)>zs)throw new ve("Key size is too large");let e=vu(r),t=Qn(at.encode({Type:fe.RSA,Data:ua(e.publicKey)})),n=Ze(la,t);return new fn(e.privateKey,new kr(e.publicKey,n))}async function xu(r){if(r>zs)throw new ve("Key size is too large");let e=await du(r),t=Qn(at.encode({Type:fe.RSA,Data:ua(e.publicKey)})),n=Ze(la,t);return new fn(e.privateKey,new kr(e.publicKey,n))}function vu(r){if(r==null)throw new ve("Missing key parameter");return{privateKey:r,publicKey:{kty:r.kty,n:r.n,e:r.e}}}var zp=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]),zt=new Uint32Array([1779033703,3144134277,1013904242,2773480762,1359893119,2600822924,528734635,1541459225]),$t=new Uint32Array(64),ha=class extends xr{constructor(){super(64,32,8,!1),this.A=zt[0]|0,this.B=zt[1]|0,this.C=zt[2]|0,this.D=zt[3]|0,this.E=zt[4]|0,this.F=zt[5]|0,this.G=zt[6]|0,this.H=zt[7]|0}get(){let{A:e,B:t,C:n,D:s,E:i,F:o,G:a,H:c}=this;return[e,t,n,s,i,o,a,c]}set(e,t,n,s,i,o,a,c){this.A=e|0,this.B=t|0,this.C=n|0,this.D=s|0,this.E=i|0,this.F=o|0,this.G=a|0,this.H=c|0}process(e,t){for(let u=0;u<16;u++,t+=4)$t[u]=e.getUint32(t,!1);for(let u=16;u<64;u++){let m=$t[u-15],l=$t[u-2],d=je(m,7)^je(m,18)^m>>>3,p=je(l,17)^je(l,19)^l>>>10;$t[u]=p+$t[u-7]+d+$t[u-16]|0}let{A:n,B:s,C:i,D:o,E:a,F:c,G:h,H:f}=this;for(let u=0;u<64;u++){let m=je(a,6)^je(a,11)^je(a,25),l=f+m+Fc(a,c,h)+zp[u]+$t[u]|0,p=(je(n,2)^je(n,13)^je(n,22))+Kc(n,s,i)|0;f=h,h=c,c=a,a=o+l|0,o=i,i=s,s=n,n=l+p|0}n=n+this.A|0,s=s+this.B|0,i=i+this.C|0,o=o+this.D|0,a=a+this.E|0,c=c+this.F|0,h=h+this.G|0,f=f+this.H|0,this.set(n,s,i,o,a,c,h,f)}roundClean(){$t.fill(0)}destroy(){this.set(0,0,0,0,0,0,0,0),this.buffer.fill(0)}};var Eu=Ln(()=>new ha);var $s=class extends wr{constructor(e,t){super(),this.finished=!1,this.destroyed=!1,Pc(e);let n=Gr(t);if(this.iHash=e.create(),typeof this.iHash.update!="function")throw new Error("Expected instance of class which extends utils.Hash");this.blockLen=this.iHash.blockLen,this.outputLen=this.iHash.outputLen;let s=this.blockLen,i=new Uint8Array(s);i.set(n.length>s?e.create().update(n).digest():n);for(let o=0;o<i.length;o++)i[o]^=54;this.iHash.update(i),this.oHash=e.create();for(let o=0;o<i.length;o++)i[o]^=106;this.oHash.update(i),i.fill(0)}update(e){return br(this),this.iHash.update(e),this}digestInto(e){br(this),yr(e,this.outputLen),this.finished=!0,this.iHash.digestInto(e),this.oHash.update(e),this.oHash.digestInto(e),this.destroy()}digest(){let e=new Uint8Array(this.oHash.outputLen);return this.digestInto(e),e}_cloneInto(e){e||(e=Object.create(Object.getPrototypeOf(this),{}));let{oHash:t,iHash:n,finished:s,destroyed:i,blockLen:o,outputLen:a}=this;return e=e,e.finished=s,e.destroyed=i,e.blockLen=o,e.outputLen=a,e.oHash=t._cloneInto(e.oHash),e.iHash=n._cloneInto(e.iHash),e}destroy(){this.destroyed=!0,this.oHash.destroy(),this.iHash.destroy()}},da=(r,e,t)=>new $s(r,e).update(t).digest();da.create=(r,e)=>new $s(r,e);function Su(r){r.lowS!==void 0&&Ye("lowS",r.lowS),r.prehash!==void 0&&Ye("prehash",r.prehash)}function $p(r){let e=jr(r);ot(e,{a:"field",b:"field"},{allowedPrivateKeyLengths:"array",wrapPrivateKey:"boolean",isTorsionFree:"function",clearCofactor:"function",allowInfinityPoint:"boolean",fromBytes:"function",toBytes:"function"});let{endo:t,Fp:n,a:s}=e;if(t){if(!n.eql(s,n.ZERO))throw new Error("invalid endomorphism, can only be defined for Koblitz curves that have a=0");if(typeof t!="object"||typeof t.beta!="bigint"||typeof t.splitScalar!="function")throw new Error("invalid endomorphism, expected beta: bigint and splitScalar: function")}return Object.freeze({...e})}var{bytesToNumberBE:Gp,hexToBytes:Wp}=Mn,It={Err:class extends Error{constructor(e=""){super(e)}},_tlv:{encode:(r,e)=>{let{Err:t}=It;if(r<0||r>256)throw new t("tlv.encode: wrong tag");if(e.length&1)throw new t("tlv.encode: unpadded data");let n=e.length/2,s=Xt(n);if(s.length/2&128)throw new t("tlv.encode: long form length too big");let i=n>127?Xt(s.length/2|128):"";return Xt(r)+i+s+e},decode(r,e){let{Err:t}=It,n=0;if(r<0||r>256)throw new t("tlv.encode: wrong tag");if(e.length<2||e[n++]!==r)throw new t("tlv.decode: wrong tlv");let s=e[n++],i=!!(s&128),o=0;if(!i)o=s;else{let c=s&127;if(!c)throw new t("tlv.decode(long): indefinite length not supported");if(c>4)throw new t("tlv.decode(long): byte length is too big");let h=e.subarray(n,n+c);if(h.length!==c)throw new t("tlv.decode: length bytes not complete");if(h[0]===0)throw new t("tlv.decode(long): zero leftmost byte");for(let f of h)o=o<<8|f;if(n+=c,o<128)throw new t("tlv.decode(long): not minimal encoding")}let a=e.subarray(n,n+o);if(a.length!==o)throw new t("tlv.decode: wrong value length");return{v:a,l:e.subarray(n+o)}}},_int:{encode(r){let{Err:e}=It;if(r<Tt)throw new e("integer: negative integers are not allowed");let t=Xt(r);if(Number.parseInt(t[0],16)&8&&(t="00"+t),t.length&1)throw new e("unexpected DER parsing assertion: unpadded hex");return t},decode(r){let{Err:e}=It;if(r[0]&128)throw new e("invalid signature integer: negative");if(r[0]===0&&!(r[1]&128))throw new e("invalid signature integer: unnecessary leading zero");return Gp(r)}},toSig(r){let{Err:e,_int:t,_tlv:n}=It,s=typeof r=="string"?Wp(r):r;vr(s);let{v:i,l:o}=n.decode(48,s);if(o.length)throw new e("invalid signature: left bytes after parsing");let{v:a,l:c}=n.decode(2,i),{v:h,l:f}=n.decode(2,c);if(f.length)throw new e("invalid signature: left bytes after parsing");return{r:t.decode(a),s:t.decode(h)}},hexFromSig(r){let{_tlv:e,_int:t}=It,n=e.encode(2,t.encode(r.r)),s=e.encode(2,t.encode(r.s)),i=n+s;return e.encode(48,i)}},Tt=BigInt(0),me=BigInt(1),Vb=BigInt(2),Au=BigInt(3),Hb=BigInt(4);function Zp(r){let e=$p(r),{Fp:t}=e,n=Ot(e.n,e.nBitLength),s=e.toBytes||((p,y,b)=>{let w=y.toAffine();return wt(Uint8Array.from([4]),t.toBytes(w.x),t.toBytes(w.y))}),i=e.fromBytes||(p=>{let y=p.subarray(1),b=t.fromBytes(y.subarray(0,t.BYTES)),w=t.fromBytes(y.subarray(t.BYTES,2*t.BYTES));return{x:b,y:w}});function o(p){let{a:y,b}=e,w=t.sqr(p),g=t.mul(w,p);return t.add(t.add(g,t.mul(p,y)),b)}if(!t.eql(t.sqr(e.Gy),o(e.Gx)))throw new Error("bad generator point: equation left != right");function a(p){return Wr(p,me,e.n)}function c(p){let{allowedPrivateKeyLengths:y,nByteLength:b,wrapPrivateKey:w,n:g}=e;if(y&&typeof p!="bigint"){if(Rt(p)&&(p=yt(p)),typeof p!="string"||!y.includes(p.length))throw new Error("invalid private key");p=p.padStart(b*2,"0")}let E;try{E=typeof p=="bigint"?p:bt(oe("private key",p,b))}catch{throw new Error("invalid private key, expected hex or "+b+" bytes, got "+typeof p)}return w&&(E=J(E,g)),Re("private key",E,me,g),E}function h(p){if(!(p instanceof m))throw new Error("ProjectivePoint expected")}let f=er((p,y)=>{let{px:b,py:w,pz:g}=p;if(t.eql(g,t.ONE))return{x:b,y:w};let E=p.is0();y==null&&(y=E?t.ONE:t.inv(g));let A=t.mul(b,y),_=t.mul(w,y),x=t.mul(g,y);if(E)return{x:t.ZERO,y:t.ZERO};if(!t.eql(x,t.ONE))throw new Error("invZ was invalid");return{x:A,y:_}}),u=er(p=>{if(p.is0()){if(e.allowInfinityPoint&&!t.is0(p.py))return;throw new Error("bad point: ZERO")}let{x:y,y:b}=p.toAffine();if(!t.isValid(y)||!t.isValid(b))throw new Error("bad point: x or y not FE");let w=t.sqr(b),g=o(y);if(!t.eql(w,g))throw new Error("bad point: equation left != right");if(!p.isTorsionFree())throw new Error("bad point: not in prime-order subgroup");return!0});class m{constructor(y,b,w){if(this.px=y,this.py=b,this.pz=w,y==null||!t.isValid(y))throw new Error("x required");if(b==null||!t.isValid(b))throw new Error("y required");if(w==null||!t.isValid(w))throw new Error("z required");Object.freeze(this)}static fromAffine(y){let{x:b,y:w}=y||{};if(!y||!t.isValid(b)||!t.isValid(w))throw new Error("invalid affine point");if(y instanceof m)throw new Error("projective point not allowed");let g=E=>t.eql(E,t.ZERO);return g(b)&&g(w)?m.ZERO:new m(b,w,t.ONE)}get x(){return this.toAffine().x}get y(){return this.toAffine().y}static normalizeZ(y){let b=t.invertBatch(y.map(w=>w.pz));return y.map((w,g)=>w.toAffine(b[g])).map(m.fromAffine)}static fromHex(y){let b=m.fromAffine(i(oe("pointHex",y)));return b.assertValidity(),b}static fromPrivateKey(y){return m.BASE.multiply(c(y))}static msm(y,b){return Fn(m,n,y,b)}_setWindowSize(y){d.setWindowSize(this,y)}assertValidity(){u(this)}hasEvenY(){let{y}=this.toAffine();if(t.isOdd)return!t.isOdd(y);throw new Error("Field doesn't support isOdd")}equals(y){h(y);let{px:b,py:w,pz:g}=this,{px:E,py:A,pz:_}=y,x=t.eql(t.mul(b,_),t.mul(E,g)),I=t.eql(t.mul(w,_),t.mul(A,g));return x&&I}negate(){return new m(this.px,t.neg(this.py),this.pz)}double(){let{a:y,b}=e,w=t.mul(b,Au),{px:g,py:E,pz:A}=this,_=t.ZERO,x=t.ZERO,I=t.ZERO,C=t.mul(g,g),j=t.mul(E,E),V=t.mul(A,A),P=t.mul(g,E);return P=t.add(P,P),I=t.mul(g,A),I=t.add(I,I),_=t.mul(y,I),x=t.mul(w,V),x=t.add(_,x),_=t.sub(j,x),x=t.add(j,x),x=t.mul(_,x),_=t.mul(P,_),I=t.mul(w,I),V=t.mul(y,V),P=t.sub(C,V),P=t.mul(y,P),P=t.add(P,I),I=t.add(C,C),C=t.add(I,C),C=t.add(C,V),C=t.mul(C,P),x=t.add(x,C),V=t.mul(E,A),V=t.add(V,V),C=t.mul(V,P),_=t.sub(_,C),I=t.mul(V,j),I=t.add(I,I),I=t.add(I,I),new m(_,x,I)}add(y){h(y);let{px:b,py:w,pz:g}=this,{px:E,py:A,pz:_}=y,x=t.ZERO,I=t.ZERO,C=t.ZERO,j=e.a,V=t.mul(e.b,Au),P=t.mul(b,E),R=t.mul(w,A),T=t.mul(g,_),L=t.add(b,w),S=t.add(E,A);L=t.mul(L,S),S=t.add(P,R),L=t.sub(L,S),S=t.add(b,g);let v=t.add(E,_);return S=t.mul(S,v),v=t.add(P,T),S=t.sub(S,v),v=t.add(w,g),x=t.add(A,_),v=t.mul(v,x),x=t.add(R,T),v=t.sub(v,x),C=t.mul(j,S),x=t.mul(V,T),C=t.add(x,C),x=t.sub(R,C),C=t.add(R,C),I=t.mul(x,C),R=t.add(P,P),R=t.add(R,P),T=t.mul(j,T),S=t.mul(V,S),R=t.add(R,T),T=t.sub(P,T),T=t.mul(j,T),S=t.add(S,T),P=t.mul(R,S),I=t.add(I,P),P=t.mul(v,S),x=t.mul(L,x),x=t.sub(x,P),P=t.mul(L,R),C=t.mul(v,C),C=t.add(C,P),new m(x,I,C)}subtract(y){return this.add(y.negate())}is0(){return this.equals(m.ZERO)}wNAF(y){return d.wNAFCached(this,y,m.normalizeZ)}multiplyUnsafe(y){let{endo:b,n:w}=e;Re("scalar",y,Tt,w);let g=m.ZERO;if(y===Tt)return g;if(this.is0()||y===me)return this;if(!b||d.hasPrecomputes(this))return d.wNAFCachedUnsafe(this,y,m.normalizeZ);let{k1neg:E,k1:A,k2neg:_,k2:x}=b.splitScalar(y),I=g,C=g,j=this;for(;A>Tt||x>Tt;)A&me&&(I=I.add(j)),x&me&&(C=C.add(j)),j=j.double(),A>>=me,x>>=me;return E&&(I=I.negate()),_&&(C=C.negate()),C=new m(t.mul(C.px,b.beta),C.py,C.pz),I.add(C)}multiply(y){let{endo:b,n:w}=e;Re("scalar",y,me,w);let g,E;if(b){let{k1neg:A,k1:_,k2neg:x,k2:I}=b.splitScalar(y),{p:C,f:j}=this.wNAF(_),{p:V,f:P}=this.wNAF(I);C=d.constTimeNegate(A,C),V=d.constTimeNegate(x,V),V=new m(t.mul(V.px,b.beta),V.py,V.pz),g=C.add(V),E=j.add(P)}else{let{p:A,f:_}=this.wNAF(y);g=A,E=_}return m.normalizeZ([g,E])[0]}multiplyAndAddUnsafe(y,b,w){let g=m.BASE,E=(_,x)=>x===Tt||x===me||!_.equals(g)?_.multiplyUnsafe(x):_.multiply(x),A=E(this,b).add(E(y,w));return A.is0()?void 0:A}toAffine(y){return f(this,y)}isTorsionFree(){let{h:y,isTorsionFree:b}=e;if(y===me)return!0;if(b)return b(m,this);throw new Error("isTorsionFree() has not been declared for the elliptic curve")}clearCofactor(){let{h:y,clearCofactor:b}=e;return y===me?this:b?b(m,this):this.multiplyUnsafe(e.h)}toRawBytes(y=!0){return Ye("isCompressed",y),this.assertValidity(),s(m,this,y)}toHex(y=!0){return Ye("isCompressed",y),yt(this.toRawBytes(y))}}m.BASE=new m(e.Gx,e.Gy,t.ONE),m.ZERO=new m(t.ZERO,t.ONE,t.ZERO);let l=e.nBitLength,d=Hn(m,e.endo?Math.ceil(l/2):l);return{CURVE:e,ProjectivePoint:m,normPrivateKeyToScalar:c,weierstrassEquation:o,isWithinCurveOrder:a}}function jp(r){let e=jr(r);return ot(e,{hash:"hash",hmac:"function",randomBytes:"function"},{bits2int:"function",bits2int_modN:"function",lowS:"boolean"}),Object.freeze({lowS:!0,...e})}function Bu(r){let e=jp(r),{Fp:t,n}=e,s=t.BYTES+1,i=2*t.BYTES+1;function o(T){return J(T,n)}function a(T){return Pn(T,n)}let{ProjectivePoint:c,normPrivateKeyToScalar:h,weierstrassEquation:f,isWithinCurveOrder:u}=Zp({...e,toBytes(T,L,S){let v=L.toAffine(),B=t.toBytes(v.x),N=wt;return Ye("isCompressed",S),S?N(Uint8Array.from([L.hasEvenY()?2:3]),B):N(Uint8Array.from([4]),B,t.toBytes(v.y))},fromBytes(T){let L=T.length,S=T[0],v=T.subarray(1);if(L===s&&(S===2||S===3)){let B=bt(v);if(!Wr(B,me,t.ORDER))throw new Error("Point is not on curve");let N=f(B),U;try{U=t.sqrt(N)}catch($){let O=$ instanceof Error?": "+$.message:"";throw new Error("Point is not on curve"+O)}let D=(U&me)===me;return(S&1)===1!==D&&(U=t.neg(U)),{x:B,y:U}}else if(L===i&&S===4){let B=t.fromBytes(v.subarray(0,t.BYTES)),N=t.fromBytes(v.subarray(t.BYTES,2*t.BYTES));return{x:B,y:N}}else{let B=s,N=i;throw new Error("invalid Point, expected length of "+B+", or uncompressed "+N+", got "+L)}}}),m=T=>yt(Dt(T,e.nByteLength));function l(T){let L=n>>me;return T>L}function d(T){return l(T)?o(-T):T}let p=(T,L,S)=>bt(T.slice(L,S));class y{constructor(L,S,v){this.r=L,this.s=S,this.recovery=v,this.assertValidity()}static fromCompact(L){let S=e.nByteLength;return L=oe("compactSignature",L,S*2),new y(p(L,0,S),p(L,S,2*S))}static fromDER(L){let{r:S,s:v}=It.toSig(oe("DER",L));return new y(S,v)}assertValidity(){Re("r",this.r,me,n),Re("s",this.s,me,n)}addRecoveryBit(L){return new y(this.r,this.s,L)}recoverPublicKey(L){let{r:S,s:v,recovery:B}=this,N=_(oe("msgHash",L));if(B==null||![0,1,2,3].includes(B))throw new Error("recovery id invalid");let U=B===2||B===3?S+e.n:S;if(U>=t.ORDER)throw new Error("recovery id 2 or 3 invalid");let D=B&1?"03":"02",H=c.fromHex(D+m(U)),$=a(U),O=o(-N*$),Y=o(v*$),re=c.BASE.multiplyAndAddUnsafe(H,O,Y);if(!re)throw new Error("point at infinify");return re.assertValidity(),re}hasHighS(){return l(this.s)}normalizeS(){return this.hasHighS()?new y(this.r,o(-this.s),this.recovery):this}toDERRawBytes(){return Jt(this.toDERHex())}toDERHex(){return It.hexFromSig({r:this.r,s:this.s})}toCompactRawBytes(){return Jt(this.toCompactHex())}toCompactHex(){return m(this.r)+m(this.s)}}let b={isValidPrivateKey(T){try{return h(T),!0}catch{return!1}},normPrivateKeyToScalar:h,randomPrivateKey:()=>{let T=po(e.n);return Xc(e.randomBytes(T),e.n)},precompute(T=8,L=c.BASE){return L._setWindowSize(T),L.multiply(BigInt(3)),L}};function w(T,L=!0){return c.fromPrivateKey(T).toRawBytes(L)}function g(T){let L=Rt(T),S=typeof T=="string",v=(L||S)&&T.length;return L?v===s||v===i:S?v===2*s||v===2*i:T instanceof c}function E(T,L,S=!0){if(g(T))throw new Error("first arg must be private key");if(!g(L))throw new Error("second arg must be public key");return c.fromHex(L).multiply(h(T)).toRawBytes(S)}let A=e.bits2int||function(T){if(T.length>8192)throw new Error("input is too large");let L=bt(T),S=T.length*8-e.nBitLength;return S>0?L>>BigInt(S):L},_=e.bits2int_modN||function(T){return o(A(T))},x=Zr(e.nBitLength);function I(T){return Re("num < 2^"+e.nBitLength,T,Tt,x),Dt(T,e.nByteLength)}function C(T,L,S=j){if(["recovered","canonical"].some(de=>de in S))throw new Error("sign() legacy options not supported");let{hash:v,randomBytes:B}=e,{lowS:N,prehash:U,extraEntropy:D}=S;N==null&&(N=!0),T=oe("msgHash",T),Su(S),U&&(T=oe("prehashed msgHash",v(T)));let H=_(T),$=h(L),O=[I($),I(H)];if(D!=null&&D!==!1){let de=D===!0?B(t.BYTES):D;O.push(oe("extraEntropy",de))}let Y=wt(...O),re=H;function he(de){let ye=A(de);if(!u(ye))return;let xe=a(ye),Ne=c.BASE.multiply(ye).toAffine(),Te=o(Ne.x);if(Te===Tt)return;let st=o(xe*o(re+Te*$));if(st===Tt)return;let ft=(Ne.x===Te?0:2)|Number(Ne.y&me),Hr=st;return N&&l(st)&&(Hr=d(st),ft^=1),new y(Te,Hr,ft)}return{seed:Y,k2sig:he}}let j={lowS:e.lowS,prehash:!1},V={lowS:e.lowS,prehash:!1};function P(T,L,S=j){let{seed:v,k2sig:B}=C(T,L,S),N=e;return lo(N.hash.outputLen,N.nByteLength,N.hmac)(v,B)}c.BASE._setWindowSize(8);function R(T,L,S,v=V){let B=T;L=oe("msgHash",L),S=oe("publicKey",S);let{lowS:N,prehash:U,format:D}=v;if(Su(v),"strict"in v)throw new Error("options.strict was renamed to lowS");if(D!==void 0&&D!=="compact"&&D!=="der")throw new Error("format must be compact or der");let H=typeof B=="string"||Rt(B),$=!H&&!D&&typeof B=="object"&&B!==null&&typeof B.r=="bigint"&&typeof B.s=="bigint";if(!H&&!$)throw new Error("invalid signature, expected Uint8Array, hex string or Signature instance");let O,Y;try{if($&&(O=new y(B.r,B.s)),H){try{D!=="compact"&&(O=y.fromDER(B))}catch(ft){if(!(ft instanceof It.Err))throw ft}!O&&D!=="der"&&(O=y.fromCompact(B))}Y=c.fromHex(S)}catch{return!1}if(!O||N&&O.hasHighS())return!1;U&&(L=e.hash(L));let{r:re,s:he}=O,de=_(L),ye=a(he),xe=o(de*ye),Ne=o(re*ye),Te=c.BASE.multiplyAndAddUnsafe(Y,xe,Ne)?.toAffine();return Te?o(Te.x)===re:!1}return{CURVE:e,getPublicKey:w,getSharedSecret:E,sign:P,verify:R,ProjectivePoint:c,Signature:y,utils:b}}function Yp(r){return{hash:r,hmac:(e,...t)=>da(r,e,ro(...t)),randomBytes:Rn}}function _u(r,e){let t=n=>Bu({...r,...Yp(n)});return Object.freeze({...t(e),create:t})}var ku=BigInt("0xfffffffffffffffffffffffffffffffffffffffffffffffffffffffefffffc2f"),Iu=BigInt("0xfffffffffffffffffffffffffffffffebaaedce6af48a03bbfd25e8cd0364141"),Xp=BigInt(1),pa=BigInt(2),Tu=(r,e)=>(r+e/pa)/e;function Jp(r){let e=ku,t=BigInt(3),n=BigInt(6),s=BigInt(11),i=BigInt(22),o=BigInt(23),a=BigInt(44),c=BigInt(88),h=r*r*r%e,f=h*h*r%e,u=ie(f,t,e)*f%e,m=ie(u,t,e)*f%e,l=ie(m,pa,e)*h%e,d=ie(l,s,e)*l%e,p=ie(d,i,e)*d%e,y=ie(p,a,e)*p%e,b=ie(y,c,e)*y%e,w=ie(b,a,e)*p%e,g=ie(w,t,e)*f%e,E=ie(g,o,e)*d%e,A=ie(E,n,e)*h%e,_=ie(A,pa,e);if(!ga.eql(ga.sqr(_),r))throw new Error("Cannot find square root");return _}var ga=Ot(ku,void 0,void 0,{sqrt:Jp}),or=_u({a:BigInt(0),b:BigInt(7),Fp:ga,n:Iu,Gx:BigInt("55066263022277343669578718895168534326250603453777594175500187360389116729240"),Gy:BigInt("32670510020758816978083085130507043184471273380659243275938904335757337482424"),h:BigInt(1),lowS:!0,endo:{beta:BigInt("0x7ae96a2b657c07106e64479eac3434e99cf0497512f58995c1396c28719501ee"),splitScalar:r=>{let e=Iu,t=BigInt("0x3086d221a7d46bcde86c90e49284eb15"),n=-Xp*BigInt("0xe4437ed6010e88286f547fa90abfe4c3"),s=BigInt("0x114ca50f7a8e2f3f657c1108d9d44cfd8"),i=t,o=BigInt("0x100000000000000000000000000000000"),a=Tu(i*r,e),c=Tu(-n*r,e),h=J(r-a*t-c*s,e),f=J(-a*n-c*i,e),u=h>o,m=f>o;if(u&&(h=e-h),m&&(f=e-f),h>o||f>o)throw new Error("splitScalar: Endomorphism failed, k="+r);return{k1neg:u,k1:h,k2neg:m,k2:f}}}},Eu),jb=BigInt(0);var Yb=or.ProjectivePoint;function Fe(r,e){e==null&&(e=r.reduce((s,i)=>s+i.length,0));let t=De(e),n=0;for(let s of r)t.set(s,n),n+=s.length;return t}function Cu(r){return r==null?!1:typeof r.then=="function"&&typeof r.catch=="function"&&typeof r.finally=="function"}function Nu(r,e,t){let n=Er.digest(t instanceof Uint8Array?t:t.subarray());if(Cu(n))return n.then(({digest:s})=>or.verify(e,s,r)).catch(s=>{throw new ln(String(s))});try{return or.verify(e,n.digest,r)}catch(s){throw new ln(String(s))}}var Gs=class{type="secp256k1";raw;_key;constructor(e){this._key=Ru(e),this.raw=Lu(this._key)}toMultihash(){return gt.digest(Mt(this))}toCID(){return pe.createV1(114,this.toMultihash())}toString(){return ee.encode(this.toMultihash().bytes).substring(1)}equals(e){return e==null||!(e.raw instanceof Uint8Array)?!1:ge(this.raw,e.raw)}verify(e,t){return Nu(this._key,t,e)}};function ma(r){return new Gs(r)}function Lu(r){return or.ProjectivePoint.fromHex(r).toRawBytes(!0)}function Ru(r){try{return or.ProjectivePoint.fromHex(r),r}catch(e){throw new fr(String(e))}}function Uu(r){let{Type:e,Data:t}=at.decode(r),n=t??new Uint8Array;switch(e){case fe.RSA:return fa(n);case fe.Ed25519:return vo(n);case fe.secp256k1:return ma(n);default:throw new hr}}function Du(r){let{Type:e,Data:t}=at.decode(r.digest),n=t??new Uint8Array;switch(e){case fe.Ed25519:return vo(n);case fe.secp256k1:return ma(n);default:throw new hr}}function Mt(r){return at.encode({Type:fe[r.type],Data:r.raw})}var Ou=Symbol.for("nodejs.util.inspect.custom"),Qp=114,hn=class{type;multihash;publicKey;string;constructor(e){this.type=e.type,this.multihash=e.multihash,Object.defineProperty(this,"string",{enumerable:!1,writable:!0})}get[Symbol.toStringTag](){return`PeerId(${this.toString()})`}[zi]=!0;toString(){return this.string==null&&(this.string=ee.encode(this.multihash.bytes).slice(1)),this.string}toMultihash(){return this.multihash}toCID(){return pe.createV1(Qp,this.multihash)}toJSON(){return this.toString()}equals(e){if(e==null)return!1;if(e instanceof Uint8Array)return ge(this.multihash.bytes,e);if(typeof e=="string")return this.toString()===e;if(e?.toMultihash()?.bytes!=null)return ge(this.multihash.bytes,e.toMultihash().bytes);throw new Error("not valid Id")}[Ou](){return`PeerId(${this.toString()})`}},Ws=class extends hn{type="RSA";publicKey;constructor(e){super({...e,type:"RSA"}),this.publicKey=e.publicKey}},Zs=class extends hn{type="Ed25519";publicKey;constructor(e){super({...e,type:"Ed25519"}),this.publicKey=e.publicKey}},js=class extends hn{type="secp256k1";publicKey;constructor(e){super({...e,type:"secp256k1"}),this.publicKey=e.publicKey}},e0=2336,Ys=class{type="url";multihash;publicKey;url;constructor(e){this.url=e.toString(),this.multihash=gt.digest(G(this.url))}[Ou](){return`PeerId(${this.url})`}[zi]=!0;toString(){return this.toCID().toString()}toMultihash(){return this.multihash}toCID(){return pe.createV1(e0,this.toMultihash())}toJSON(){return this.toString()}equals(e){return e==null?!1:(e instanceof Uint8Array&&(e=ce(e)),e.toString()===this.toString())}};function ya(r,e){let t;if(r.charAt(0)==="1"||r.charAt(0)==="Q")t=ze(ee.decode(`z${r}`));else{if(e==null)throw new ve('Please pass a multibase decoder for strings that do not start with "1" or "Q"');t=ze(e.decode(r))}return dn(t)}function dn(r){if(r0(r))return new Ws({multihash:r});if(t0(r))try{let e=Du(r);if(e.type==="Ed25519")return new Zs({multihash:r,publicKey:e});if(e.type==="secp256k1")return new js({multihash:r,publicKey:e})}catch{let t=ce(r.digest);return new Ys(new URL(t))}throw new Tn("Supplied PeerID Multihash is invalid")}function t0(r){return r.code===gt.code}function r0(r){return r.code===Er.code}var Pu=Symbol.for("@achingbrain/uint8arraylist");function Mu(r,e){if(e==null||e<0)throw new RangeError("index is out of bounds");let t=0;for(let n of r){let s=t+n.byteLength;if(e<s)return{buf:n,index:e-t};t=s}throw new RangeError("index is out of bounds")}function Xs(r){return!!r?.[Pu]}var tt=class r{bufs;length;[Pu]=!0;constructor(...e){this.bufs=[],this.length=0,e.length>0&&this.appendAll(e)}*[Symbol.iterator](){yield*this.bufs}get byteLength(){return this.length}append(...e){this.appendAll(e)}appendAll(e){let t=0;for(let n of e)if(n instanceof Uint8Array)t+=n.byteLength,this.bufs.push(n);else if(Xs(n))t+=n.byteLength,this.bufs.push(...n.bufs);else throw new Error("Could not append value, must be an Uint8Array or a Uint8ArrayList");this.length+=t}prepend(...e){this.prependAll(e)}prependAll(e){let t=0;for(let n of e.reverse())if(n instanceof Uint8Array)t+=n.byteLength,this.bufs.unshift(n);else if(Xs(n))t+=n.byteLength,this.bufs.unshift(...n.bufs);else throw new Error("Could not prepend value, must be an Uint8Array or a Uint8ArrayList");this.length+=t}get(e){let t=Mu(this.bufs,e);return t.buf[t.index]}set(e,t){let n=Mu(this.bufs,e);n.buf[n.index]=t}write(e,t=0){if(e instanceof Uint8Array)for(let n=0;n<e.length;n++)this.set(t+n,e[n]);else if(Xs(e))for(let n=0;n<e.length;n++)this.set(t+n,e.get(n));else throw new Error("Could not write value, must be an Uint8Array or a Uint8ArrayList")}consume(e){if(e=Math.trunc(e),!(Number.isNaN(e)||e<=0)){if(e===this.byteLength){this.bufs=[],this.length=0;return}for(;this.bufs.length>0;)if(e>=this.bufs[0].byteLength)e-=this.bufs[0].byteLength,this.length-=this.bufs[0].byteLength,this.bufs.shift();else{this.bufs[0]=this.bufs[0].subarray(e),this.length-=e;break}}}slice(e,t){let{bufs:n,length:s}=this._subList(e,t);return Fe(n,s)}subarray(e,t){let{bufs:n,length:s}=this._subList(e,t);return n.length===1?n[0]:Fe(n,s)}sublist(e,t){let{bufs:n,length:s}=this._subList(e,t),i=new r;return i.length=s,i.bufs=[...n],i}_subList(e,t){if(e=e??0,t=t??this.length,e<0&&(e=this.length+e),t<0&&(t=this.length+t),e<0||t>this.length)throw new RangeError("index is out of bounds");if(e===t)return{bufs:[],length:0};if(e===0&&t===this.length)return{bufs:this.bufs,length:this.length};let n=[],s=0;for(let i=0;i<this.bufs.length;i++){let o=this.bufs[i],a=s,c=a+o.byteLength;if(s=c,e>=c)continue;let h=e>=a&&e<c,f=t>a&&t<=c;if(h&&f){if(e===a&&t===c){n.push(o);break}let u=e-a;n.push(o.subarray(u,u+(t-e)));break}if(h){if(e===0){n.push(o);continue}n.push(o.subarray(e-a));continue}if(f){if(t===c){n.push(o);break}n.push(o.subarray(0,t-a));break}n.push(o)}return{bufs:n,length:t-e}}indexOf(e,t=0){if(!Xs(e)&&!(e instanceof Uint8Array))throw new TypeError('The "value" argument must be a Uint8ArrayList or Uint8Array');let n=e instanceof Uint8Array?e:e.subarray();if(t=Number(t??0),isNaN(t)&&(t=0),t<0&&(t=this.length+t),t<0&&(t=0),e.length===0)return t>this.length?this.length:t;let s=n.byteLength;if(s===0)throw new TypeError("search must be at least 1 byte long");let i=256,o=new Int32Array(i);for(let u=0;u<i;u++)o[u]=-1;for(let u=0;u<s;u++)o[n[u]]=u;let a=o,c=this.byteLength-n.byteLength,h=n.byteLength-1,f;for(let u=t;u<=c;u+=f){f=0;for(let m=h;m>=0;m--){let l=this.get(u+m);if(n[m]!==l){f=Math.max(1,m-a[l]);break}}if(f===0)return u}return-1}getInt8(e){let t=this.subarray(e,e+1);return new DataView(t.buffer,t.byteOffset,t.byteLength).getInt8(0)}setInt8(e,t){let n=De(1);new DataView(n.buffer,n.byteOffset,n.byteLength).setInt8(0,t),this.write(n,e)}getInt16(e,t){let n=this.subarray(e,e+2);return new DataView(n.buffer,n.byteOffset,n.byteLength).getInt16(0,t)}setInt16(e,t,n){let s=ae(2);new DataView(s.buffer,s.byteOffset,s.byteLength).setInt16(0,t,n),this.write(s,e)}getInt32(e,t){let n=this.subarray(e,e+4);return new DataView(n.buffer,n.byteOffset,n.byteLength).getInt32(0,t)}setInt32(e,t,n){let s=ae(4);new DataView(s.buffer,s.byteOffset,s.byteLength).setInt32(0,t,n),this.write(s,e)}getBigInt64(e,t){let n=this.subarray(e,e+8);return new DataView(n.buffer,n.byteOffset,n.byteLength).getBigInt64(0,t)}setBigInt64(e,t,n){let s=ae(8);new DataView(s.buffer,s.byteOffset,s.byteLength).setBigInt64(0,t,n),this.write(s,e)}getUint8(e){let t=this.subarray(e,e+1);return new DataView(t.buffer,t.byteOffset,t.byteLength).getUint8(0)}setUint8(e,t){let n=De(1);new DataView(n.buffer,n.byteOffset,n.byteLength).setUint8(0,t),this.write(n,e)}getUint16(e,t){let n=this.subarray(e,e+2);return new DataView(n.buffer,n.byteOffset,n.byteLength).getUint16(0,t)}setUint16(e,t,n){let s=ae(2);new DataView(s.buffer,s.byteOffset,s.byteLength).setUint16(0,t,n),this.write(s,e)}getUint32(e,t){let n=this.subarray(e,e+4);return new DataView(n.buffer,n.byteOffset,n.byteLength).getUint32(0,t)}setUint32(e,t,n){let s=ae(4);new DataView(s.buffer,s.byteOffset,s.byteLength).setUint32(0,t,n),this.write(s,e)}getBigUint64(e,t){let n=this.subarray(e,e+8);return new DataView(n.buffer,n.byteOffset,n.byteLength).getBigUint64(0,t)}setBigUint64(e,t,n){let s=ae(8);new DataView(s.buffer,s.byteOffset,s.byteLength).setBigUint64(0,t,n),this.write(s,e)}getFloat32(e,t){let n=this.subarray(e,e+4);return new DataView(n.buffer,n.byteOffset,n.byteLength).getFloat32(0,t)}setFloat32(e,t,n){let s=ae(4);new DataView(s.buffer,s.byteOffset,s.byteLength).setFloat32(0,t,n),this.write(s,e)}getFloat64(e,t){let n=this.subarray(e,e+8);return new DataView(n.buffer,n.byteOffset,n.byteLength).getFloat64(0,t)}setFloat64(e,t,n){let s=ae(8);new DataView(s.buffer,s.byteOffset,s.byteLength).setFloat64(0,t,n),this.write(s,e)}equals(e){if(e==null||!(e instanceof r)||e.bufs.length!==this.bufs.length)return!1;for(let t=0;t<this.bufs.length;t++)if(!ge(this.bufs[t],e.bufs[t]))return!1;return!0}static fromUint8Arrays(e,t){let n=new r;return n.bufs=e,t==null&&(t=e.reduce((s,i)=>s+i.byteLength,0)),n.length=t,n}};var pn;(function(r){let e;r.codec=()=>(e==null&&(e=Pe((t,n,s={})=>{s.lengthDelimited!==!1&&n.fork(),t.publicKey!=null&&t.publicKey.byteLength>0&&(n.uint32(10),n.bytes(t.publicKey)),t.payloadType!=null&&t.payloadType.byteLength>0&&(n.uint32(18),n.bytes(t.payloadType)),t.payload!=null&&t.payload.byteLength>0&&(n.uint32(26),n.bytes(t.payload)),t.signature!=null&&t.signature.byteLength>0&&(n.uint32(42),n.bytes(t.signature)),s.lengthDelimited!==!1&&n.ldelim()},(t,n,s={})=>{let i={publicKey:ae(0),payloadType:ae(0),payload:ae(0),signature:ae(0)},o=n==null?t.len:t.pos+n;for(;t.pos<o;){let a=t.uint32();switch(a>>>3){case 1:{i.publicKey=t.bytes();break}case 2:{i.payloadType=t.bytes();break}case 3:{i.payload=t.bytes();break}case 5:{i.signature=t.bytes();break}default:{t.skipType(a&7);break}}}return i})),e),r.encode=t=>Me(t,r.codec()),r.decode=(t,n)=>Oe(t,r.codec(),n)})(pn||(pn={}));var Js=class extends Error{constructor(e="Invalid signature"){super(e),this.name="InvalidSignatureError"}};var gn=class r{static createFromProtobuf=async e=>{let t=pn.decode(e),n=Uu(t.publicKey);return new r({publicKey:n,payloadType:t.payloadType,payload:t.payload,signature:t.signature})};static seal=async(e,t)=>{if(t==null)throw new Error("Missing private key");let n=e.domain,s=e.codec,i=e.marshal(),o=Vu(n,s,i),a=await t.sign(o.subarray());return new r({publicKey:t.publicKey,payloadType:s,payload:i,signature:a})};static openAndCertify=async(e,t)=>{let n=await r.createFromProtobuf(e);if(!await n.validate(t))throw new Js("Envelope signature is not valid for the given domain");return n};publicKey;payloadType;payload;signature;marshaled;constructor(e){let{publicKey:t,payloadType:n,payload:s,signature:i}=e;this.publicKey=t,this.payloadType=n,this.payload=s,this.signature=i}marshal(){return this.marshaled==null&&(this.marshaled=pn.encode({publicKey:Mt(this.publicKey),payloadType:this.payloadType,payload:this.payload.subarray(),signature:this.signature})),this.marshaled}equals(e){return ge(this.marshal(),e.marshal())}async validate(e){let t=Vu(e,this.payloadType,this.payload);return this.publicKey.verify(t.subarray(),this.signature)}},Vu=(r,e,t)=>{let n=G(r),s=$e(n.byteLength),i=$e(e.length),o=$e(t.length);return new tt(s,n,i,e,o,t)};var Qs=class{index=0;input="";new(e){return this.index=0,this.input=e,this}readAtomically(e){let t=this.index,n=e();return n===void 0&&(this.index=t),n}parseWith(e){let t=e();if(this.index===this.input.length)return t}peekChar(){if(!(this.index>=this.input.length))return this.input[this.index]}readChar(){if(!(this.index>=this.input.length))return this.input[this.index++]}readGivenChar(e){return this.readAtomically(()=>{let t=this.readChar();if(t===e)return t})}readSeparator(e,t,n){return this.readAtomically(()=>{if(!(t>0&&this.readGivenChar(e)===void 0))return n()})}readNumber(e,t,n,s){return this.readAtomically(()=>{let i=0,o=0,a=this.peekChar();if(a===void 0)return;let c=a==="0",h=2**(8*s)-1;for(;;){let f=this.readAtomically(()=>{let u=this.readChar();if(u===void 0)return;let m=Number.parseInt(u,e);if(!Number.isNaN(m))return m});if(f===void 0)break;if(i*=e,i+=f,i>h||(o+=1,t!==void 0&&o>t))return}if(o!==0)return!n&&c&&o>1?void 0:i})}readIPv4Addr(){return this.readAtomically(()=>{let e=new Uint8Array(4);for(let t=0;t<e.length;t++){let n=this.readSeparator(".",t,()=>this.readNumber(10,3,!1,1));if(n===void 0)return;e[t]=n}return e})}readIPv6Addr(){let e=t=>{for(let n=0;n<t.length/2;n++){let s=n*2;if(n<t.length-3){let o=this.readSeparator(":",n,()=>this.readIPv4Addr());if(o!==void 0)return t[s]=o[0],t[s+1]=o[1],t[s+2]=o[2],t[s+3]=o[3],[s+4,!0]}let i=this.readSeparator(":",n,()=>this.readNumber(16,4,!0,2));if(i===void 0)return[s,!1];t[s]=i>>8,t[s+1]=i&255}return[t.length,!1]};return this.readAtomically(()=>{let t=new Uint8Array(16),[n,s]=e(t);if(n===16)return t;if(s||this.readGivenChar(":")===void 0||this.readGivenChar(":")===void 0)return;let i=new Uint8Array(14),o=16-(n+2),[a]=e(i.subarray(0,o));return t.set(i.subarray(0,a),16-a),t})}readIPAddr(){return this.readIPv4Addr()??this.readIPv6Addr()}};var Hu=45,n0=15,Cr=new Qs;function ba(r){if(!(r.length>n0))return Cr.new(r).parseWith(()=>Cr.readIPv4Addr())}function wa(r){if(r.includes("%")&&(r=r.split("%")[0]),!(r.length>Hu))return Cr.new(r).parseWith(()=>Cr.readIPv6Addr())}function ei(r){if(r.includes("%")&&(r=r.split("%")[0]),!(r.length>Hu))return Cr.new(r).parseWith(()=>Cr.readIPAddr())}var Ix=parseInt("0xFFFF",16),Tx=new Uint8Array([0,0,0,0,0,0,0,0,0,0,255,255]);function ti(r){return!!ba(r)}function ri(r){return!!wa(r)}function ni(r){return!!ei(r)}var qu=ti,c0=ri,xa=function(r){let e=0;if(r=r.toString().trim(),qu(r)){let t=new Uint8Array(e+4);return r.split(/\./g).forEach(n=>{t[e++]=parseInt(n,10)&255}),t}if(c0(r)){let t=r.split(":",8),n;for(n=0;n<t.length;n++){let i=qu(t[n]),o;i&&(o=xa(t[n]),t[n]=ce(o.slice(0,2),"base16")),o!=null&&++n<8&&t.splice(n,0,ce(o.slice(2,4),"base16"))}if(t[0]==="")for(;t.length<8;)t.unshift("0");else if(t[t.length-1]==="")for(;t.length<8;)t.push("0");else if(t.length<8){for(n=0;n<t.length&&t[n]!=="";n++);let i=[n,1];for(n=9-t.length;n>0;n--)i.push("0");t.splice.apply(t,i)}let s=new Uint8Array(e+16);for(n=0;n<t.length;n++){let i=parseInt(t[n],16);s[e++]=i>>8&255,s[e++]=i&255}return s}throw new Error("invalid ip address")},zu=function(r,e=0,t){e=~~e,t=t??r.length-e;let n=new DataView(r.buffer);if(t===4){let s=[];for(let i=0;i<t;i++)s.push(r[e+i]);return s.join(".")}if(t===16){let s=[];for(let i=0;i<t;i+=2)s.push(n.getUint16(e+i).toString(16));return s.join(":").replace(/(^|:)0(:0)*:0(:|$)/,"$1::$3").replace(/:{3,4}/,"::")}return""};var Nr={},va={},u0=[[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"]];u0.forEach(r=>{let e=f0(...r);va[e.code]=e,Nr[e.name]=e});function f0(r,e,t,n,s){return{code:r,size:e,name:t,resolvable:!!n,path:!!s}}function te(r){if(typeof r=="number"){if(va[r]!=null)return va[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 f1=te("ip4"),h1=te("ip6"),d1=te("ipcidr");function Ba(r,e){switch(te(r).code){case 4:case 41:return d0(e);case 42:return Aa(e);case 43:return ce(e,"base10");case 6:case 273:case 33:case 132:return Wu(e).toString();case 53:case 54:case 55:case 56:case 400:case 449:case 777:return Aa(e);case 421:return y0(e);case 444:return Gu(e);case 445:return Gu(e);case 466:return m0(e);case 481:return globalThis.encodeURIComponent(Aa(e));default:return ce(e,"base16")}}function _a(r,e){switch(te(r).code){case 4:return $u(e);case 41:return $u(e);case 42:return Sa(e);case 43:return G(e,"base10");case 6:case 273:case 33:case 132:return Ia(parseInt(e,10));case 53:case 54:case 55:case 56:case 400:case 449:case 777:return Sa(e);case 421:return p0(e);case 444:return b0(e);case 445:return w0(e);case 466:return g0(e);case 481:return Sa(globalThis.decodeURIComponent(e));default:return G(e,"base16")}}var Ea=Object.values(Yr).map(r=>r.decoder),h0=function(){let r=Ea[0].or(Ea[1]);return Ea.slice(2).forEach(e=>r=r.or(e)),r}();function $u(r){if(!ni(r))throw new Error("invalid ip address");return xa(r)}function d0(r){let e=zu(r,0,r.length);if(e==null)throw new Error("ipBuff is required");if(!ni(e))throw new Error("invalid ip address");return e}function Ia(r){let e=new ArrayBuffer(2);return new DataView(e).setUint16(0,r),new Uint8Array(e)}function Wu(r){return new DataView(r.buffer).getUint16(r.byteOffset)}function Sa(r){let e=G(r),t=Uint8Array.from($e(e.length));return Fe([t,e],t.length+e.length)}function Aa(r){let e=xt(r);if(r=r.slice(Se(e)),r.length!==e)throw new Error("inconsistent lengths");return ce(r)}function p0(r){let e;r[0]==="Q"||r[0]==="1"?e=ze(ee.decode(`z${r}`)).bytes:e=pe.parse(r).multihash.bytes;let t=Uint8Array.from($e(e.length));return Fe([t,e],t.length+e.length)}function g0(r){let e=h0.decode(r),t=Uint8Array.from($e(e.length));return Fe([t,e],t.length+e.length)}function m0(r){let e=xt(r),t=r.slice(Se(e));if(t.length!==e)throw new Error("inconsistent lengths");return"u"+ce(t,"base64url")}function y0(r){let e=xt(r),t=r.slice(Se(e));if(t.length!==e)throw new Error("inconsistent lengths");return ce(t,"base58btc")}function b0(r){let e=r.split(":");if(e.length!==2)throw new Error(`failed to parse onion addr: ["'${e.join('", "')}'"]' does not contain a port number`);if(e[0].length!==16)throw new Error(`failed to parse onion addr: ${e[0]} not a Tor onion address.`);let t=pt.decode("b"+e[0]),n=parseInt(e[1],10);if(n<1||n>65536)throw new Error("Port number is not in range(1, 65536)");let s=Ia(n);return Fe([t,s],t.length+s.length)}function w0(r){let e=r.split(":");if(e.length!==2)throw new Error(`failed to parse onion addr: ["'${e.join('", "')}'"]' does not contain a port number`);if(e[0].length!==56)throw new Error(`failed to parse onion addr: ${e[0]} not a Tor onion3 address.`);let t=pt.decode(`b${e[0]}`),n=parseInt(e[1],10);if(n<1||n>65536)throw new Error("Port number is not in range(1, 65536)");let s=Ia(n);return Fe([t,s],t.length+s.length)}function Gu(r){let e=r.slice(0,r.length-2),t=r.slice(r.length-2),n=ce(e,"base32"),s=Wu(t);return`${n}:${s}`}function Zu(r){r=Ta(r);let e=[],t=[],n=null,s=r.split("/").slice(1);if(s.length===1&&s[0]==="")return{bytes:new Uint8Array,string:"/",tuples:[],stringTuples:[],path:null};for(let i=0;i<s.length;i++){let o=s[i],a=te(o);if(a.size===0){e.push([a.code]),t.push([a.code]);continue}if(i++,i>=s.length)throw Yu("invalid address: "+r);if(a.path===!0){n=Ta(s.slice(i).join("/")),e.push([a.code,_a(a.code,n)]),t.push([a.code,n]);break}let c=_a(a.code,s[i]);e.push([a.code,c]),t.push([a.code,Ba(a.code,c)])}return{string:ju(t),bytes:Ca(e),tuples:e,stringTuples:t,path:n}}function ka(r){let e=[],t=[],n=null,s=0;for(;s<r.length;){let i=xt(r,s),o=Se(i),a=te(i),c=x0(a,r.slice(s+o));if(c===0){e.push([i]),t.push([i]),s+=o;continue}let h=r.slice(s+o,s+o+c);if(s+=c+o,s>r.length)throw Yu("Invalid address Uint8Array: "+ce(r,"base16"));e.push([i,h]);let f=Ba(i,h);if(t.push([i,f]),a.path===!0){n=f;break}}return{bytes:Uint8Array.from(r),string:ju(t),tuples:e,stringTuples:t,path:n}}function ju(r){let e=[];return r.map(t=>{let n=te(t[0]);return e.push(n.name),t.length>1&&t[1]!=null&&e.push(t[1]),null}),Ta(e.join("/"))}function Ca(r){return Fe(r.map(e=>{let t=te(e[0]),n=Uint8Array.from($e(t.code));return e.length>1&&e[1]!=null&&(n=Fe([n,e[1]])),n}))}function x0(r,e){if(r.size>0)return r.size/8;if(r.size===0)return 0;{let t=xt(e instanceof Uint8Array?e:Uint8Array.from(e));return t+Se(t)}}function Ta(r){return"/"+r.trim().split("/").filter(e=>e).join("/")}function Yu(r){return new Error("Error parsing address: "+r)}var v0=Symbol.for("nodejs.util.inspect.custom"),La=Symbol.for("@multiformats/js-multiaddr/multiaddr"),E0=[te("dns").code,te("dns4").code,te("dns6").code,te("dnsaddr").code],Na=class extends Error{constructor(e="No available resolver"){super(e),this.name="NoAvailableResolverError"}},si=class r{bytes;#e;#t;#r;#n;[La]=!0;constructor(e){e==null&&(e="");let t;if(e instanceof Uint8Array)t=ka(e);else if(typeof e=="string"){if(e.length>0&&e.charAt(0)!=="/")throw new Error(`multiaddr "${e}" must start with a "/"`);t=Zu(e)}else if(Ju(e))t=ka(e.bytes);else throw new Error("addr must be a string, Buffer, or another Multiaddr");this.bytes=t.bytes,this.#e=t.string,this.#t=t.tuples,this.#r=t.stringTuples,this.#n=t.path}toString(){return this.#e}toJSON(){return this.toString()}toOptions(){let e,t,n,s,i="",o=te("tcp"),a=te("udp"),c=te("ip4"),h=te("ip6"),f=te("dns6"),u=te("ip6zone");for(let[l,d]of this.stringTuples())l===u.code&&(i=`%${d??""}`),E0.includes(l)&&(t=o.name,s=443,n=`${d??""}${i}`,e=l===f.code?6:4),(l===o.code||l===a.code)&&(t=te(l).name,s=parseInt(d??"")),(l===c.code||l===h.code)&&(t=te(l).name,n=`${d??""}${i}`,e=l===h.code?6:4);if(e==null||t==null||n==null||s==null)throw new Error('multiaddr must have a valid format: "/{ip4, ip6, dns4, dns6, dnsaddr}/{address}/{tcp, udp}/{port}".');return{family:e,host:n,transport:t,port:s}}protos(){return this.#t.map(([e])=>Object.assign({},te(e)))}protoCodes(){return this.#t.map(([e])=>e)}protoNames(){return this.#t.map(([e])=>te(e).name)}tuples(){return this.#t.map(([e,t])=>t==null?[e]:[e,t])}stringTuples(){return this.#r.map(([e,t])=>t==null?[e]:[e,t])}encapsulate(e){return e=new r(e),new r(this.toString()+e.toString())}decapsulate(e){let t=e.toString(),n=this.toString(),s=n.lastIndexOf(t);if(s<0)throw new Error(`Address ${this.toString()} does not contain subaddress: ${e.toString()}`);return new r(n.slice(0,s))}decapsulateCode(e){let t=this.tuples();for(let n=t.length-1;n>=0;n--)if(t[n][0]===e)return new r(Ca(t.slice(0,n)));return this}getPeerId(){try{let e=[];this.stringTuples().forEach(([n,s])=>{n===Nr.p2p.code&&e.push([n,s]),n===Nr["p2p-circuit"].code&&(e=[])});let t=e.pop();if(t?.[1]!=null){let n=t[1];return n[0]==="Q"||n[0]==="1"?ce(ee.decode(`z${n}`),"base58btc"):ce(pe.parse(n).multihash.bytes,"base58btc")}return null}catch{return null}}getPath(){return this.#n}equals(e){return ge(this.bytes,e.bytes)}async resolve(e){let t=this.protos().find(i=>i.resolvable);if(t==null)return[this];let n=Xu.get(t.name);if(n==null)throw new Na(`no available resolver for ${t.name}`);return(await n(this,e)).map(i=>_e(i))}nodeAddress(){let e=this.toOptions();if(e.transport!=="tcp"&&e.transport!=="udp")throw new Error(`multiaddr must have a valid format - no protocol with name: "${e.transport}". Must have a valid transport protocol: "{tcp, udp}"`);return{family:e.family,address:e.host,port:e.port}}isThinWaistAddress(e){let t=(e??this).protos();return!(t.length!==2||t[0].code!==4&&t[0].code!==41||t[1].code!==6&&t[1].code!==273)}[v0](){return`Multiaddr(${this.#e})`}};var Xu=new Map;function Ju(r){return!!r?.[La]}function _e(r){return new si(r)}function rt(){let r={};return r.promise=new Promise((e,t)=>{r.resolve=e,r.reject=t}),r}var ii=class extends Error{type;code;constructor(e,t,n){super(e??"The operation was aborted"),this.type="aborted",this.name=n??"AbortError",this.code=t??"ABORT_ERR"}};async function oi(r,e,t){if(e==null)return r;if(e.aborted)return Promise.reject(new ii(t?.errorMessage,t?.errorCode,t?.errorName));let n,s=new ii(t?.errorMessage,t?.errorCode,t?.errorName);try{return await Promise.race([r,new Promise((i,o)=>{n=()=>{o(s)},e.addEventListener("abort",n)})])}finally{n!=null&&e.removeEventListener("abort",n)}}var Ra=class{readNext;haveNext;ended;nextResult;constructor(){this.ended=!1,this.readNext=rt(),this.haveNext=rt()}[Symbol.asyncIterator](){return this}async next(){if(this.nextResult==null&&await this.haveNext.promise,this.nextResult==null)throw new Error("HaveNext promise resolved but nextResult was undefined");let e=this.nextResult;return this.nextResult=void 0,this.readNext.resolve(),this.readNext=rt(),e}async throw(e){return this.ended=!0,e!=null&&(this.haveNext.promise.catch(()=>{}),this.haveNext.reject(e)),{done:!0,value:void 0}}async return(){let e={done:!0,value:void 0};return await this._push(void 0),e}async push(e,t){await this._push(e,t)}async end(e,t){e!=null?await this.throw(e):await this._push(void 0,t)}async _push(e,t){if(e!=null&&this.ended)throw new Error("Cannot push value onto an ended pushable");for(;this.nextResult!=null;)await this.readNext.promise;e!=null?this.nextResult={done:!1,value:e}:(this.ended=!0,this.nextResult={done:!0,value:void 0}),this.haveNext.resolve(),this.haveNext=rt(),await oi(this.readNext.promise,t?.signal,t)}};function Qu(){return new Ra}var ai=class extends Error{name="UnexpectedEOFError";code="ERR_UNEXPECTED_EOF"};var Ua=class extends Error{code;constructor(e,t){super(e),this.code=t}},Da=class extends Ua{type;constructor(e){super(e,"ABORT_ERR"),this.type="aborted",this.name="AbortError"}};function ef(r,e){let t=Qu();r.sink(t).catch(async o=>{await t.end(o)}),r.sink=async o=>{for await(let a of o)await t.push(a);await t.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 s=new tt;return{read:async(o,a)=>{a?.signal?.throwIfAborted();let c,h=new Promise((f,u)=>{c=()=>{u(new Da("Read aborted"))},a?.signal?.addEventListener("abort",c)});try{if(o==null){let{done:u,value:m}=await Promise.race([n.next(),h]);return u===!0?new tt:m}for(;s.byteLength<o;){let{value:u,done:m}=await Promise.race([n.next(),h]);if(m===!0)throw new ai("unexpected end of input");s.append(u)}let f=s.sublist(0,o);return s.consume(o),f}finally{c!=null&&a?.signal?.removeEventListener("abort",c)}},write:async(o,a)=>{a?.signal?.throwIfAborted(),o instanceof Uint8Array?await t.push(o,a):await t.push(o.subarray(),a)},unwrap:()=>{if(s.byteLength>0){let o=r.source;r.source=async function*(){e?.yieldBytes===!1?yield s:yield*s,yield*o}()}return r}}}var ci=class extends Error{name="InvalidMessageLengthError";code="ERR_INVALID_MSG_LENGTH"},li=class extends Error{name="InvalidDataLengthError";code="ERR_MSG_DATA_TOO_LONG"},ui=class extends Error{name="InvalidDataLengthLengthError";code="ERR_MSG_LENGTH_TOO_LONG"};function tf(r,e={}){let t=ef(r,e);e.maxDataLength!=null&&e.maxLengthLength==null&&(e.maxLengthLength=Se(e.maxDataLength));let n=e?.lengthDecoder??xt,s=e?.lengthEncoder??$e;return{read:async o=>{let a=-1,c=new tt;for(;;){c.append(await t.read(1,o));try{a=n(c)}catch(h){if(h instanceof RangeError)continue;throw h}if(a<0)throw new ci("Invalid message length");if(e?.maxLengthLength!=null&&c.byteLength>e.maxLengthLength)throw new ui("message length length too long");if(a>-1)break}if(e?.maxDataLength!=null&&a>e.maxDataLength)throw new li("message length too long");return t.read(a,o)},write:async(o,a)=>{await t.write(new tt(s(o.byteLength),o),a)},writeV:async(o,a)=>{let c=new tt(...o.flatMap(h=>[s(h.byteLength),h]));await t.write(c,a)},unwrap:()=>t.unwrap()}}function Gt(r,e){let t=tf(r,e),n={read:async(s,i)=>{let o=await t.read(i);return s.decode(o)},write:async(s,i,o)=>{await t.write(i.encode(s),o)},writeV:async(s,i,o)=>{await t.writeV(s.map(a=>i.encode(a)),o)},pb:s=>({read:async i=>n.read(s,i),write:async(i,o)=>n.write(i,s,o),writeV:async(i,o)=>n.writeV(i,s,o),unwrap:()=>n}),unwrap:()=>t.unwrap()};return n}var Oa=1e3,rf=60*Oa,fi=290,nf=15,sf=2*60*rf,of=1,hi=2e3,af=100,Ma="circuit-relay-source",mn=`${$i}-circuit-relay`,Pa=`${$i}-circuit-relay-source`,cf=2*rf,lf=BigInt(1<<17),We="/libp2p/circuit/relay/0.2.0/hop",ar="/libp2p/circuit/relay/0.2.0/stop",uf=30*Oa,n2=30*Oa,yn=300,ff=4096,hf=.001;var X;(function(r){let e;(function(s){s.RESERVE="RESERVE",s.CONNECT="CONNECT",s.STATUS="STATUS"})(e=r.Type||(r.Type={}));let t;(function(s){s[s.RESERVE=0]="RESERVE",s[s.CONNECT=1]="CONNECT",s[s.STATUS=2]="STATUS"})(t||(t={})),function(s){s.codec=()=>sr(t)}(e=r.Type||(r.Type={}));let n;r.codec=()=>(n==null&&(n=Pe((s,i,o={})=>{o.lengthDelimited!==!1&&i.fork(),s.type!=null&&(i.uint32(8),r.Type.codec().encode(s.type,i)),s.peer!=null&&(i.uint32(18),Lr.codec().encode(s.peer,i)),s.reservation!=null&&(i.uint32(26),di.codec().encode(s.reservation,i)),s.limit!=null&&(i.uint32(34),Rr.codec().encode(s.limit,i)),s.status!=null&&(i.uint32(40),K.codec().encode(s.status,i)),o.lengthDelimited!==!1&&i.ldelim()},(s,i,o={})=>{let a={},c=i==null?s.len:s.pos+i;for(;s.pos<c;){let h=s.uint32();switch(h>>>3){case 1:{a.type=r.Type.codec().decode(s);break}case 2:{a.peer=Lr.codec().decode(s,s.uint32(),{limits:o.limits?.peer});break}case 3:{a.reservation=di.codec().decode(s,s.uint32(),{limits:o.limits?.reservation});break}case 4:{a.limit=Rr.codec().decode(s,s.uint32(),{limits:o.limits?.limit});break}case 5:{a.status=K.codec().decode(s);break}default:{s.skipType(h&7);break}}}return a})),n),r.encode=s=>Me(s,r.codec()),r.decode=(s,i)=>Oe(s,r.codec(),i)})(X||(X={}));var Ke;(function(r){let e;(function(s){s.CONNECT="CONNECT",s.STATUS="STATUS"})(e=r.Type||(r.Type={}));let t;(function(s){s[s.CONNECT=0]="CONNECT",s[s.STATUS=1]="STATUS"})(t||(t={})),function(s){s.codec=()=>sr(t)}(e=r.Type||(r.Type={}));let n;r.codec=()=>(n==null&&(n=Pe((s,i,o={})=>{o.lengthDelimited!==!1&&i.fork(),s.type!=null&&(i.uint32(8),r.Type.codec().encode(s.type,i)),s.peer!=null&&(i.uint32(18),Lr.codec().encode(s.peer,i)),s.limit!=null&&(i.uint32(26),Rr.codec().encode(s.limit,i)),s.status!=null&&(i.uint32(32),K.codec().encode(s.status,i)),o.lengthDelimited!==!1&&i.ldelim()},(s,i,o={})=>{let a={},c=i==null?s.len:s.pos+i;for(;s.pos<c;){let h=s.uint32();switch(h>>>3){case 1:{a.type=r.Type.codec().decode(s);break}case 2:{a.peer=Lr.codec().decode(s,s.uint32(),{limits:o.limits?.peer});break}case 3:{a.limit=Rr.codec().decode(s,s.uint32(),{limits:o.limits?.limit});break}case 4:{a.status=K.codec().decode(s);break}default:{s.skipType(h&7);break}}}return a})),n),r.encode=s=>Me(s,r.codec()),r.decode=(s,i)=>Oe(s,r.codec(),i)})(Ke||(Ke={}));var Lr;(function(r){let e;r.codec=()=>(e==null&&(e=Pe((t,n,s={})=>{if(s.lengthDelimited!==!1&&n.fork(),t.id!=null&&t.id.byteLength>0&&(n.uint32(10),n.bytes(t.id)),t.addrs!=null)for(let i of t.addrs)n.uint32(18),n.bytes(i);s.lengthDelimited!==!1&&n.ldelim()},(t,n,s={})=>{let i={id:ae(0),addrs:[]},o=n==null?t.len:t.pos+n;for(;t.pos<o;){let a=t.uint32();switch(a>>>3){case 1:{i.id=t.bytes();break}case 2:{if(s.limits?.addrs!=null&&i.addrs.length===s.limits.addrs)throw new Qr('Decode error - map field "addrs" had too many elements');i.addrs.push(t.bytes());break}default:{t.skipType(a&7);break}}}return i})),e),r.encode=t=>Me(t,r.codec()),r.decode=(t,n)=>Oe(t,r.codec(),n)})(Lr||(Lr={}));var di;(function(r){let e;r.codec=()=>(e==null&&(e=Pe((t,n,s={})=>{if(s.lengthDelimited!==!1&&n.fork(),t.expire!=null&&t.expire!==0n&&(n.uint32(8),n.uint64(t.expire)),t.addrs!=null)for(let i of t.addrs)n.uint32(18),n.bytes(i);t.voucher!=null&&(n.uint32(26),pi.codec().encode(t.voucher,n)),s.lengthDelimited!==!1&&n.ldelim()},(t,n,s={})=>{let i={expire:0n,addrs:[]},o=n==null?t.len:t.pos+n;for(;t.pos<o;){let a=t.uint32();switch(a>>>3){case 1:{i.expire=t.uint64();break}case 2:{if(s.limits?.addrs!=null&&i.addrs.length===s.limits.addrs)throw new Qr('Decode error - map field "addrs" had too many elements');i.addrs.push(t.bytes());break}case 3:{i.voucher=pi.codec().decode(t,t.uint32(),{limits:s.limits?.voucher});break}default:{t.skipType(a&7);break}}}return i})),e),r.encode=t=>Me(t,r.codec()),r.decode=(t,n)=>Oe(t,r.codec(),n)})(di||(di={}));var Rr;(function(r){let e;r.codec=()=>(e==null&&(e=Pe((t,n,s={})=>{s.lengthDelimited!==!1&&n.fork(),t.duration!=null&&(n.uint32(8),n.uint32(t.duration)),t.data!=null&&(n.uint32(16),n.uint64(t.data)),s.lengthDelimited!==!1&&n.ldelim()},(t,n,s={})=>{let i={},o=n==null?t.len:t.pos+n;for(;t.pos<o;){let a=t.uint32();switch(a>>>3){case 1:{i.duration=t.uint32();break}case 2:{i.data=t.uint64();break}default:{t.skipType(a&7);break}}}return i})),e),r.encode=t=>Me(t,r.codec()),r.decode=(t,n)=>Oe(t,r.codec(),n)})(Rr||(Rr={}));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 Va;(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"})(Va||(Va={}));(function(r){r.codec=()=>sr(Va)})(K||(K={}));var Ur;(function(r){let e;r.codec=()=>(e==null&&(e=Pe((t,n,s={})=>{s.lengthDelimited!==!1&&n.fork(),t.relay!=null&&t.relay.byteLength>0&&(n.uint32(10),n.bytes(t.relay)),t.peer!=null&&t.peer.byteLength>0&&(n.uint32(18),n.bytes(t.peer)),t.expiration!=null&&t.expiration!==0n&&(n.uint32(24),n.uint64(t.expiration)),s.lengthDelimited!==!1&&n.ldelim()},(t,n,s={})=>{let i={relay:ae(0),peer:ae(0),expiration:0n},o=n==null?t.len:t.pos+n;for(;t.pos<o;){let a=t.uint32();switch(a>>>3){case 1:{i.relay=t.bytes();break}case 2:{i.peer=t.bytes();break}case 3:{i.expiration=t.uint64();break}default:{t.skipType(a&7);break}}}return i})),e),r.encode=t=>Me(t,r.codec()),r.decode=(t,n)=>Oe(t,r.codec(),n)})(Ur||(Ur={}));var pi;(function(r){let e;r.codec=()=>(e==null&&(e=Pe((t,n,s={})=>{s.lengthDelimited!==!1&&n.fork(),t.publicKey!=null&&t.publicKey.byteLength>0&&(n.uint32(10),n.bytes(t.publicKey)),t.payloadType!=null&&t.payloadType.byteLength>0&&(n.uint32(18),n.bytes(t.payloadType)),t.payload!=null&&(n.uint32(26),Ur.codec().encode(t.payload,n)),t.signature!=null&&t.signature.byteLength>0&&(n.uint32(42),n.bytes(t.signature)),s.lengthDelimited!==!1&&n.ldelim()},(t,n,s={})=>{let i={publicKey:ae(0),payloadType:ae(0),signature:ae(0)},o=n==null?t.len:t.pos+n;for(;t.pos<o;){let a=t.uint32();switch(a>>>3){case 1:{i.publicKey=t.bytes();break}case 2:{i.payloadType=t.bytes();break}case 3:{i.payload=Ur.codec().decode(t,t.uint32(),{limits:s.limits?.payload});break}case 5:{i.signature=t.bytes();break}default:{t.skipType(a&7);break}}}return i})),e),r.encode=t=>Me(t,r.codec()),r.decode=(t,n)=>Oe(t,r.codec(),n)})(pi||(pi={}));var S0=r=>r.toString().split("/").slice(1),Dr=r=>({match:e=>e.length<1?!1:r(e[0])?e.slice(1):!1,pattern:"fn"}),F=r=>({match:e=>Dr(t=>t===r).match(e),pattern:r}),cr=()=>({match:r=>Dr(e=>typeof e=="string").match(r),pattern:"{string}"}),bn=()=>({match:r=>Dr(e=>!isNaN(parseInt(e))).match(r),pattern:"{number}"}),Q=()=>({match:r=>{if(r.length<2||r[0]!=="p2p"&&r[0]!=="ipfs")return!1;if(r[1].startsWith("Q")||r[1].startsWith("1"))try{ee.decode(`z${r[1]}`)}catch{return!1}else return!1;return r.slice(2)},pattern:"/p2p/{peerid}"}),wn=()=>({match:r=>{if(r.length<2||r[0]!=="certhash")return!1;try{Mo.decode(r[1])}catch{return!1}return r.slice(2)},pattern:"/certhash/{certhash}"}),W=r=>({match:e=>{let t=r.match(e);return t===!1?e:t},pattern:`optional(${r.pattern})`}),Ie=(...r)=>({match:e=>{let t;for(let n of r){let s=n.match(e);s!==!1&&(t==null||s.length<t.length)&&(t=s)}return t??!1},pattern:`or(${r.map(e=>e.pattern).join(", ")})`}),q=(...r)=>({match:e=>{for(let t of r){let n=t.match(e);if(n===!1)return!1;e=n}return e},pattern:`and(${r.map(e=>e.pattern).join(", ")})`});function ne(...r){function e(s){let i=S0(s);for(let o of r){let a=o.match(i);if(a===!1)return!1;i=a}return i}function t(s){return e(s)!==!1}function n(s){let i=e(s);return i===!1?!1:i.length===0}return{matchers:r,matches:t,exactMatch:n}}var mi=q(F("dns4"),cr()),yi=q(F("dns6"),cr()),bi=q(F("dnsaddr"),cr()),Fa=q(F("dns"),cr()),d2=ne(mi,W(Q())),p2=ne(yi,W(Q())),g2=ne(bi,W(Q())),m2=ne(Ie(Fa,bi,mi,yi),W(Q())),df=q(F("ip4"),Dr(ti)),pf=q(F("ip6"),Dr(ri)),Ka=Ie(df,pf),kt=Ie(Ka,Fa,mi,yi,bi),y2=ne(Ie(Ka,q(Ie(Fa,bi,mi,yi),W(Q())))),b2=ne(df),w2=ne(pf),x2=ne(Ka),qa=q(kt,F("tcp"),bn()),xn=q(kt,F("udp"),bn()),v2=ne(q(qa,W(Q()))),E2=ne(xn),za=q(xn,F("quic"),W(Q())),wi=q(xn,F("quic-v1"),W(Q())),A0=Ie(za,wi),S2=ne(za),A2=ne(wi),Ha=Ie(kt,qa,xn,za,wi),gf=Ie(q(Ha,F("ws"),W(Q()))),B2=ne(gf),mf=Ie(q(Ha,F("wss"),W(Q())),q(Ha,F("tls"),W(q(F("sni"),cr())),F("ws"),W(Q()))),_2=ne(mf),yf=q(xn,F("webrtc-direct"),W(wn()),W(wn()),W(Q())),I2=ne(yf),bf=q(wi,F("webtransport"),W(wn()),W(wn()),W(Q())),T2=ne(bf),gi=Ie(gf,mf,q(qa,W(Q())),q(A0,W(Q())),q(kt,W(Q())),yf,bf,Q()),wf=ne(gi),B0=q(gi,F("p2p-circuit"),Q()),xi=ne(B0),_0=Ie(q(gi,F("p2p-circuit"),F("webrtc"),W(Q())),q(gi,F("webrtc"),W(Q())),q(F("webrtc"),W(Q()))),k2=ne(_0),I0=Ie(q(kt,F("tcp"),bn(),F("http"),W(Q())),q(kt,F("http"),W(Q()))),C2=ne(I0),T0=Ie(q(kt,F("tcp"),Ie(q(F("443"),F("http")),q(bn(),F("https"))),W(Q())),q(kt,F("tls"),F("http"),W(Q())),q(kt,F("https"),W(Q()))),N2=ne(T0),k0=Ie(q(F("memory"),cr(),W(Q()))),L2=ne(k0);function vi(r){let e=new globalThis.AbortController;function t(){e.abort();for(let i of r)i?.removeEventListener!=null&&i.removeEventListener("abort",t)}for(let i of r){if(i?.aborted===!0){t();break}i?.addEventListener!=null&&i.addEventListener("abort",t)}function n(){for(let i of r)i?.removeEventListener!=null&&i.removeEventListener("abort",t)}let s=e.signal;return s.clear=n,s}var Ei=class extends Error{constructor(e="Transfer limit error"){super(e),this.name="TransferLimitError"}},vn=class extends Error{constructor(e="Duration limit error"){super(e),this.name="DurationLimitError"}},En=class extends Error{static name="HadEnoughRelaysError";name="HadEnoughRelaysError"},Si=class extends Error{static name="DoubleRelayError";name="DoubleRelayError"},Ai=class extends Error{static name="RelayQueueFullError";name="RelayQueueFullError"};async function*xf(r,e,t){let n=e.remaining;for await(let s of r){let i=BigInt(s.byteLength);if(e.remaining-i<0){let o=Number(e.remaining);e.remaining=0n;try{o!==0&&(yield s.subarray(0,o))}catch(a){t.log.error(a)}throw new Ei(`data limit of ${n} bytes exceeded`)}e.remaining-=i,yield s}}function vf(r,e,t,n,s){function i(u){r.abort(u),e.abort(u)}let o=[t,n.signal];n.limit?.duration!=null&&(s.log("limiting relayed connection duration to %dms",n.limit.duration),o.push(AbortSignal.timeout(n.limit.duration)));let a=vi(o),c=!1,h=!1,f;n.limit?.data!=null&&(f={remaining:n.limit.data}),queueMicrotask(()=>{let u=()=>{s.log("relayed connection reached time limit"),e.abort(new vn(`duration limit of ${n.limit?.duration} ms exceeded`))};a.addEventListener("abort",u,{once:!0}),e.sink(f==null?r.source:xf(r.source,f,s)).catch(m=>{s.log.error("error while relaying streams src -> dst",m),i(m)}).finally(()=>{c=!0,h&&(a.removeEventListener("abort",u),a.clear())})}),queueMicrotask(()=>{let u=()=>{s.log("relayed connection reached time limit"),r.abort(new vn(`duration limit of ${n.limit?.duration} ms exceeded`))};a.addEventListener("abort",u,{once:!0}),r.sink(f==null?e.source:xf(e.source,f,s)).catch(m=>{s.log.error("error while relaying streams dst -> src",m),i(m)}).finally(()=>{h=!0,c&&(a.removeEventListener("abort",u),a.clear())})})}function $a(r){let e=r*BigInt(1e3),t=new Date().getTime();return Number(e-BigInt(t))}var Sn=class{expires;bytes;constructor(e){e?.duration!=null&&e?.duration!==0&&(this.expires=Date.now()+e.duration*1e3),this.bytes=e?.data,this.bytes===0n&&(this.bytes=void 0),this.onData=this.onData.bind(this)}onData(e){this.bytes!=null&&(this.bytes-=BigInt(e.byteLength),this.bytes<0n&&(this.bytes=0n))}getLimits(){if(this.expires==null&&this.bytes==null)return;let e={};if(this.bytes!=null){let t=this;Object.defineProperty(e,"bytes",{get(){return t.bytes}})}if(this.expires!=null){let t=this;Object.defineProperty(e,"seconds",{get(){return Math.round(((t.expires??0)-Date.now())/1e3)}})}return e}},Bi=ne(q(wf.matchers[0],F("p2p-circuit"))),_i=ne(F("p2p-circuit"));function Ii(r,e){let t={[Symbol.iterator]:()=>t,next:()=>{let n=r.next(),s=n.value;return n.done===!0||s==null?{done:!0,value:void 0}:{done:!1,value:e(s)}}};return t}var Wt=class{map;constructor(e){if(this.map=new Map,e!=null)for(let[t,n]of e.entries())this.map.set(t.toString(),{key:t,value:n})}[Symbol.iterator](){return this.entries()}clear(){this.map.clear()}delete(e){return this.map.delete(e.toString())}entries(){return Ii(this.map.entries(),e=>[e[1].key,e[1].value])}forEach(e){this.map.forEach((t,n)=>{e(t.value,t.key,this)})}get(e){return this.map.get(e.toString())?.value}has(e){return this.map.has(e.toString())}set(e,t){this.map.set(e.toString(),{key:e,value:t})}keys(){return Ii(this.map.values(),e=>e.key)}values(){return Ii(this.map.values(),e=>e.value)}get size(){return this.map.size}};var Ga=64,nt=class{fp;h;seed;constructor(e,t,n,s=2){if(s>Ga)throw new TypeError("Invalid Fingerprint Size");let i=t.hashV(e,n),o=ae(s);for(let a=0;a<o.length;a++)o[a]=i[a];o.length===0&&(o[0]=7),this.fp=o,this.h=t,this.seed=n}hash(){return this.h.hash(this.fp,this.seed)}equals(e){return e?.fp instanceof Uint8Array?ge(this.fp,e.fp):!1}};function lr(r,e){return Math.floor(Math.random()*(e-r))+r}var ur=class{contents;constructor(e){this.contents=new Array(e).fill(null)}has(e){if(!(e instanceof nt))throw new TypeError("Invalid Fingerprint");return this.contents.some(t=>e.equals(t))}add(e){if(!(e instanceof nt))throw new TypeError("Invalid Fingerprint");for(let t=0;t<this.contents.length;t++)if(this.contents[t]==null)return this.contents[t]=e,!0;return!0}swap(e){if(!(e instanceof nt))throw new TypeError("Invalid Fingerprint");let t=lr(0,this.contents.length-1),n=this.contents[t];return this.contents[t]=e,n}remove(e){if(!(e instanceof nt))throw new TypeError("Invalid Fingerprint");let t=this.contents.findIndex(n=>e.equals(n));return t>-1?(this.contents[t]=null,!0):!1}};var Wa={32:16777619n,64:1099511628211n,128:309485009821345068724781371n,256:374144419156711147060143317175368453031918731002211n,512:35835915874844867368919076489095108449946327955754392558399825615420669938882575126094039892345713852759n,1024:5016456510113118655434598811035278955030765345404790744303017523831112055108147451509157692220295382716162651878526895249385292291816524375083746691371804094271873160484737966720260389217684476157468082573n},Bf={32:2166136261n,64:14695981039346656037n,128:144066263297769815596495629667062367629n,256:100029257958052580907070968620625704837092796014241193945225284501741471925557n,512:9659303129496669498009435400716310466090418745672637896108374329434462657994582932197716438449813051892206539805784495328239340083876191928701583869517785n,1024:14197795064947621068722070641403218320880622795441933960878474914617582723252296732303717722150864096521202355549365628174669108571814760471015076148029755969804077320157692458563003215304957150157403644460363550505412711285966361610267868082893823963790439336411086884584107735010676915n},_f=new globalThis.TextEncoder;function C0(r,e){let t=Wa[e],n=Bf[e];for(let s=0;s<r.length;s++)n^=BigInt(r[s]),n=BigInt.asUintN(e,n*t);return n}function N0(r,e,t){if(t.length===0)throw new Error("The `utf8Buffer` option must have a length greater than zero");let n=Wa[e],s=Bf[e],i=r;for(;i.length>0;){let o=_f.encodeInto(i,t);i=i.slice(o.read);for(let a=0;a<o.written;a++)s^=BigInt(t[a]),s=BigInt.asUintN(e,s*n)}return s}function Za(r,{size:e=32,utf8Buffer:t}={}){if(!Wa[e])throw new Error("The `size` option must be one of 32, 64, 128, 256, 512, or 1024");if(typeof r=="string"){if(t)return N0(r,e,t);r=_f.encode(r)}return C0(r,e)}var L0=pc(Af(),1);var Bn={hash:r=>Number(Za(r,{size:32})),hashV:(r,e)=>R0(Bn.hash(r,e))};function R0(r){let e=r.toString(16);return e.length%2===1&&(e=`0${e}`),G(e,"base16")}var U0=500,_n=class{bucketSize;filterSize;fingerprintSize;buckets;count;hash;seed;constructor(e){this.filterSize=e.filterSize,this.bucketSize=e.bucketSize??4,this.fingerprintSize=e.fingerprintSize??2,this.count=0,this.buckets=[],this.hash=e.hash??Bn,this.seed=e.seed??lr(0,Math.pow(2,10))}add(e){typeof e=="string"&&(e=G(e));let t=new nt(e,this.hash,this.seed,this.fingerprintSize),n=this.hash.hash(e,this.seed)%this.filterSize,s=(n^t.hash())%this.filterSize;if(this.buckets[n]==null&&(this.buckets[n]=new ur(this.bucketSize)),this.buckets[s]==null&&(this.buckets[s]=new ur(this.bucketSize)),this.buckets[n].add(t)||this.buckets[s].add(t))return this.count++,!0;let i=[n,s],o=i[lr(0,i.length-1)];this.buckets[o]==null&&(this.buckets[o]=new ur(this.bucketSize));for(let a=0;a<U0;a++){let c=this.buckets[o].swap(t);if(c!=null&&(o=(o^c.hash())%this.filterSize,this.buckets[o]==null&&(this.buckets[o]=new ur(this.bucketSize)),this.buckets[o].add(c)))return this.count++,!0}return!1}has(e){typeof e=="string"&&(e=G(e));let t=new nt(e,this.hash,this.seed,this.fingerprintSize),n=this.hash.hash(e,this.seed)%this.filterSize,s=this.buckets[n]?.has(t)??!1;if(s)return s;let i=(n^t.hash())%this.filterSize;return this.buckets[i]?.has(t)??!1}remove(e){typeof e=="string"&&(e=G(e));let t=new nt(e,this.hash,this.seed,this.fingerprintSize),n=this.hash.hash(e,this.seed)%this.filterSize,s=this.buckets[n]?.remove(t)??!1;if(s)return this.count--,s;let i=(n^t.hash())%this.filterSize,o=this.buckets[i]?.remove(t)??!1;return o&&this.count--,o}get reliable(){return Math.floor(100*(this.count/this.filterSize))<=90}},D0={1:.5,2:.84,4:.95,8:.98};function O0(r=.001){return r>.002?2:r>1e-5?4:8}function If(r,e=.001){let t=O0(e),n=D0[t],s=Math.round(r/n),i=Math.min(Math.ceil(Math.log2(1/e)+Math.log2(2*t)),Ga);return{filterSize:s,bucketSize:t,fingerprintSize:i}}var ki=class{filterSize;bucketSize;fingerprintSize;scale;filterSeries;hash;seed;constructor(e){this.bucketSize=e.bucketSize??4,this.filterSize=e.filterSize??(1<<18)/this.bucketSize,this.fingerprintSize=e.fingerprintSize??2,this.scale=e.scale??2,this.hash=e.hash??Bn,this.seed=e.seed??lr(0,Math.pow(2,10)),this.filterSeries=[new _n({filterSize:this.filterSize,bucketSize:this.bucketSize,fingerprintSize:this.fingerprintSize,hash:this.hash,seed:this.seed})]}add(e){if(typeof e=="string"&&(e=G(e)),this.has(e))return!0;let t=this.filterSeries.find(n=>n.reliable);if(t==null){let n=this.filterSize*Math.pow(this.scale,this.filterSeries.length);t=new _n({filterSize:n,bucketSize:this.bucketSize,fingerprintSize:this.fingerprintSize,hash:this.hash,seed:this.seed}),this.filterSeries.push(t)}return t.add(e)}has(e){typeof e=="string"&&(e=G(e));for(let t=0;t<this.filterSeries.length;t++)if(this.filterSeries[t].has(e))return!0;return!1}remove(e){typeof e=="string"&&(e=G(e));for(let t=0;t<this.filterSeries.length;t++)if(this.filterSeries[t].remove(e))return!0;return!1}get count(){return this.filterSeries.reduce((e,t)=>e+t.count,0)}};function Or(r,e=.001,t){return new ki({...If(r,e),...t??{}})}var Ci=class{filter;constructor(e,t){this.filter=Or(e,t)}has(e){return this.filter.has(e.toMultihash().bytes)}add(e){this.filter.add(e.toMultihash().bytes)}remove(e){this.filter.remove?.(e.toMultihash().bytes)}};function ja(r,e=.001){return new Ci(r,e)}var Ya=class extends Wt{metric;constructor(e){super();let{name:t,metrics:n}=e;this.metric=n.registerMetric(t),this.updateComponentMetric()}set(e,t){return super.set(e,t),this.updateComponentMetric(),this}delete(e){let t=super.delete(e);return this.updateComponentMetric(),t}clear(){super.clear(),this.updateComponentMetric()}updateComponentMetric(){this.metric.update(this.size)}};function Xa(r){let{name:e,metrics:t}=r,n;return t!=null?n=new Ya({name:e,metrics:t}):n=new Wt,n}var Ja=class extends Error{type;code;constructor(e,t,n){super(e??"The operation was aborted"),this.type="aborted",this.name=n??"AbortError",this.code=t??"ABORT_ERR"}};function Tf(r,e){let t=new Ja(e?.errorMessage,e?.errorCode,e?.errorName),n=new AbortController,s=()=>{n.abort(t)},i=AbortSignal.timeout(r);i.addEventListener("abort",s);let o=n.signal;return o.reset=a=>{i?.removeEventListener("abort",s),i=AbortSignal.timeout(a??r),i.addEventListener("abort",()=>{n.abort(t)})},o.clear=()=>{i?.removeEventListener("abort",s),i=void 0},o}var Ni=class{reservations;maxReservations;applyDefaultLimit;reservationTtl;defaultDurationLimit;defaultDataLimit;log;constructor(e,t={}){this.log=e.logger.forComponent("libp2p:circuit-relay:server:reservation-store"),this.maxReservations=t.maxReservations??nf,this.applyDefaultLimit=t.applyDefaultLimit!==!1,this.reservationTtl=t.reservationTtl??sf,this.defaultDurationLimit=t.defaultDurationLimit??cf,this.defaultDataLimit=t.defaultDataLimit??lf,this.reservations=Xa({metrics:e.metrics,name:"libp2p_circuit_relay_server_reservations_total"})}reserve(e,t,n){let s=this.reservations.get(e);if(this.reservations.size>=this.maxReservations&&s==null)return{status:K.RESERVATION_REFUSED};let i=new Date(Date.now()+this.reservationTtl),o;return this.applyDefaultLimit&&(o=n??{data:this.defaultDataLimit,duration:this.defaultDurationLimit}),s!=null?(this.log("refreshing reservation for client %p",e),s.signal.reset(this.reservationTtl)):(this.log("creating new reservation for client %p",e),s={addr:t,expiry:i,limit:o,signal:Tf(this.reservationTtl)}),this.reservations.set(e,s),s.signal.addEventListener("abort",()=>{this.reservations.delete(e)}),{status:K.OK,expire:Math.round(i.getTime()/1e3)}}removeReservation(e){this.reservations.delete(e)}get(e){return this.reservations.get(e)}clear(){this.reservations.clear()}};var Li=class r{domain="libp2p-relay-rsvp";codec=new Uint8Array([3,2]);relay;peer;expiration;constructor({relay:e,peer:t,expiration:n}){this.relay=e,this.peer=t,this.expiration=n}marshal(){return Ur.encode({relay:this.relay.toMultihash().bytes,peer:this.peer.toMultihash().bytes,expiration:BigInt(this.expiration)})}equals(e){return!(!(e instanceof r)||!this.peer.equals(e.peer)||!this.relay.equals(e.relay)||this.expiration!==e.expiration)}};var kf=r=>r.protoCodes().includes(fi),M0={maxOutboundStopStreams:yn},Qa=class extends qe{registrar;peerStore;addressManager;peerId;privateKey;connectionManager;connectionGater;reservationStore;started;hopTimeout;shutdownController;maxInboundHopStreams;maxOutboundHopStreams;maxOutboundStopStreams;log;constructor(e,t={}){super(),this.log=e.logger.forComponent("libp2p:circuit-relay:server"),this.registrar=e.registrar,this.peerStore=e.peerStore,this.addressManager=e.addressManager,this.peerId=e.peerId,this.privateKey=e.privateKey,this.connectionManager=e.connectionManager,this.connectionGater=e.connectionGater,this.started=!1,this.hopTimeout=t?.hopTimeout??uf,this.maxInboundHopStreams=t.maxInboundHopStreams,this.maxOutboundHopStreams=t.maxOutboundHopStreams,this.maxOutboundStopStreams=t.maxOutboundStopStreams??M0.maxOutboundStopStreams,this.reservationStore=new Ni(e,t.reservations),this.shutdownController=new AbortController,Le(1/0,this.shutdownController.signal)}[Symbol.toStringTag]="@libp2p/circuit-relay-v2-server";isStarted(){return this.started}async start(){this.started||(await this.registrar.handle(We,e=>{this.onHop(e).catch(t=>{this.log.error(t)})},{maxInboundStreams:this.maxInboundHopStreams,maxOutboundStreams:this.maxOutboundHopStreams,runOnLimitedConnection:!0}),this.started=!0)}async stop(){this.reservationStore.clear(),this.shutdownController.abort(),await this.registrar.unhandle(We),this.started=!1}async onHop({connection:e,stream:t}){this.log("received circuit v2 hop protocol stream from %p",e.remotePeer);let n={signal:AbortSignal.timeout(this.hopTimeout)},s=Gt(t);try{let i=await s.pb(X).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:e,stream:s,request:i},n)}catch(i){this.log.error("error while handling hop",i),await s.pb(X).write({type:X.Type.STATUS,status:K.MALFORMED_MESSAGE},n),t.abort(i)}}async handleHopProtocol({stream:e,request:t,connection:n},s){switch(this.log("received hop message"),t.type){case X.Type.RESERVE:await this.handleReserve({stream:e,request:t,connection:n},s);break;case X.Type.CONNECT:await this.handleConnect({stream:e,request:t,connection:n},s);break;default:this.log.error("invalid hop request type %s via peer %p",t.type,n.remotePeer),await e.pb(X).write({type:X.Type.STATUS,status:K.UNEXPECTED_MESSAGE})}}async handleReserve({stream:e,connection:t},n){let s=e.pb(X);if(this.log("hop reserve request from %p",t.remotePeer),kf(t.remoteAddr)){this.log.error("relay reservation over circuit connection denied for peer: %p",t.remotePeer),await s.write({type:X.Type.STATUS,status:K.PERMISSION_DENIED},n);return}if(await this.connectionGater.denyInboundRelayReservation?.(t.remotePeer)===!0){this.log.error("reservation for %p denied by connection gater",t.remotePeer),await s.write({type:X.Type.STATUS,status:K.PERMISSION_DENIED},n);return}let i=this.reservationStore.reserve(t.remotePeer,t.remoteAddr);try{if(i.status!==K.OK){await s.write({type:X.Type.STATUS,status:i.status},n);return}if(i.expire!=null){let o=i.expire*1e3-Date.now();await this.peerStore.merge(t.remotePeer,{tags:{[Ma]:{value:1,ttl:o},[Pa]:{value:1,ttl:o}}})}await s.write({type:X.Type.STATUS,status:K.OK,reservation:await this.makeReservation(t.remotePeer,BigInt(i.expire??0)),limit:this.reservationStore.get(t.remotePeer)?.limit},n),this.log("sent confirmation response to %s",t.remotePeer)}catch(o){this.log.error("failed to send confirmation response to %p - %e",t.remotePeer,o),this.reservationStore.removeReservation(t.remotePeer);try{await this.peerStore.merge(t.remotePeer,{tags:{[Ma]:void 0,[Pa]:void 0}})}catch(a){this.log.error("failed to untag relay source peer %p - %e",t.remotePeer,a)}}}async makeReservation(e,t){let n=[];for(let i of this.addressManager.getAddresses())i.toString().includes("/p2p-circuit")||n.push(i.bytes);let s=await gn.seal(new Li({peer:e,relay:this.peerId,expiration:t}),this.privateKey);return{addrs:n,expire:t,voucher:{publicKey:Mt(s.publicKey),payloadType:s.payloadType,payload:{peer:e.toMultihash().bytes,relay:this.peerId.toMultihash().bytes,expiration:t},signature:s.signature}}}async handleConnect({stream:e,request:t,connection:n},s){let i=e.pb(X);if(kf(n.remoteAddr)){this.log.error("relay reservation over circuit connection denied for peer: %p",n.remotePeer),await i.write({type:X.Type.STATUS,status:K.PERMISSION_DENIED},s);return}this.log("hop connect request from %p",n.remotePeer);let o;try{if(t.peer==null)throw this.log.error("no peer info in hop connect request"),new Error("no peer info in request");t.peer.addrs.forEach(_e),o=dn(ze(t.peer.id))}catch(m){this.log.error("invalid hop connect request via peer %p %s",n.remotePeer,m),await i.write({type:X.Type.STATUS,status:K.MALFORMED_MESSAGE},s);return}let a=this.reservationStore.get(o);if(a==null){this.log.error("hop connect denied for destination peer %p not having a reservation for %p with status %s",o,n.remotePeer,K.NO_RESERVATION),await i.write({type:X.Type.STATUS,status:K.NO_RESERVATION},s);return}if(await this.connectionGater.denyOutboundRelayedConnection?.(n.remotePeer,o)===!0){this.log.error("hop connect for %p to %p denied by connection gater",n.remotePeer,o),await i.write({type:X.Type.STATUS,status:K.PERMISSION_DENIED},s);return}let c=this.connectionManager.getConnections(o);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",o,n.remotePeer),await i.write({type:X.Type.STATUS,status:K.NO_RESERVATION},s);return}let h=c[0],f=await this.stopHop({connection:h,request:{type:Ke.Type.CONNECT,peer:{id:n.remotePeer.toMultihash().bytes,addrs:[]},limit:a?.limit}},s);if(f==null){this.log.error("failed to open stream to destination peer %p",h?.remotePeer),await i.write({type:X.Type.STATUS,status:K.CONNECTION_FAILED},s);return}await i.write({type:X.Type.STATUS,status:K.OK,limit:a?.limit},s);let u=e.unwrap();this.log("connection from %p to %p established - merging streams",n.remotePeer,o),vf(u,f,this.shutdownController.signal,a,{log:this.log})}async stopHop({connection:e,request:t},n){this.log("starting circuit relay v2 stop request to %s",e.remotePeer);let s=await e.newStream([ar],{maxOutboundStreams:this.maxOutboundStopStreams,runOnLimitedConnection:!0,...n}),i=Gt(s),o=i.pb(Ke);await o.write(t,n);let a;try{a=await o.read(n)}catch{this.log.error("error parsing stop message response from %p",e.remotePeer)}if(a==null){this.log.error("could not read response from %p",e.remotePeer),await s.close(n);return}if(a.status===K.OK)return this.log("stop request to %p was successful",e.remotePeer),i.unwrap();this.log("stop request failed with code %d",a.status),await s.close(n)}get reservations(){return this.reservationStore.reservations}};function Cf(r={}){return e=>new Qa(e,r)}function P0(r){let[e,t]=r[Symbol.asyncIterator]!=null?[r[Symbol.asyncIterator](),Symbol.asyncIterator]:[r[Symbol.iterator](),Symbol.iterator],n=[];return{peek:()=>e.next(),push:s=>{n.push(s)},next:()=>n.length>0?{done:!1,value:n.shift()}:e.next(),[t](){return this}}}var Nf=P0;function V0(r){return r[Symbol.asyncIterator]!=null}function Lf(r){return r?.then!=null}function H0(r,e){let t=0;if(V0(r))return async function*(){for await(let c of r){let h=e(c,t++);Lf(h)&&await h,yield c}}();let n=Nf(r),{value:s,done:i}=n.next();if(i===!0)return function*(){}();if(typeof e(s,t++)?.then=="function")return async function*(){yield s;for await(let c of n){let h=e(c,t++);Lf(h)&&await h,yield c}}();let a=e;return function*(){yield s;for(let c of n)a(c,t++),yield c}()}var Rf=H0;var Ri=class{buffer;mask;top;btm;next;constructor(e){if(!(e>0)||e-1&e)throw new Error("Max size for a FixedFIFO should be a power of two");this.buffer=new Array(e),this.mask=e-1,this.top=0,this.btm=0,this.next=null}push(e){return this.buffer[this.top]!==void 0?!1:(this.buffer[this.top]=e,this.top=this.top+1&this.mask,!0)}shift(){let e=this.buffer[this.btm];if(e!==void 0)return this.buffer[this.btm]=void 0,this.btm=this.btm+1&this.mask,e}isEmpty(){return this.buffer[this.btm]===void 0}},Mr=class{size;hwm;head;tail;constructor(e={}){this.hwm=e.splitLimit??16,this.head=new Ri(this.hwm),this.tail=this.head,this.size=0}calculateSize(e){return e?.byteLength!=null?e.byteLength:1}push(e){if(e?.value!=null&&(this.size+=this.calculateSize(e.value)),!this.head.push(e)){let t=this.head;this.head=t.next=new Ri(2*this.head.buffer.length),this.head.push(e)}}shift(){let e=this.tail.shift();if(e===void 0&&this.tail.next!=null){let t=this.tail.next;this.tail.next=null,this.tail=t,e=this.tail.shift()}return e?.value!=null&&(this.size-=this.calculateSize(e.value)),e}isEmpty(){return this.head.isEmpty()}};var ec=class extends Error{type;code;constructor(e,t){super(e??"The operation was aborted"),this.type="aborted",this.code=t??"ABORT_ERR"}};function Pr(r={}){return F0(t=>{let n=t.shift();if(n==null)return{done:!0};if(n.error!=null)throw n.error;return{done:n.done===!0,value:n.value}},r)}function F0(r,e){e=e??{};let t=e.onEnd,n=new Mr,s,i,o,a=rt(),c=async()=>{try{return n.isEmpty()?o?{done:!0}:await new Promise((y,b)=>{i=w=>{i=null,n.push(w);try{y(r(n))}catch(g){b(g)}return s}}):r(n)}finally{n.isEmpty()&&queueMicrotask(()=>{a.resolve(),a=rt()})}},h=y=>i!=null?i(y):(n.push(y),s),f=y=>(n=new Mr,i!=null?i({error:y}):(n.push({error:y}),s)),u=y=>{if(o)return s;if(e?.objectMode!==!0&&y?.byteLength==null)throw new Error("objectMode was not true but tried to push non-Uint8Array value");return h({done:!1,value:y})},m=y=>o?s:(o=!0,y!=null?f(y):h({done:!0})),l=()=>(n=new Mr,m(),{done:!0}),d=y=>(m(y),{done:!0});if(s={[Symbol.asyncIterator](){return this},next:c,return:l,throw:d,push:u,end:m,get readableLength(){return n.size},onEmpty:async y=>{let b=y?.signal;if(b?.throwIfAborted(),n.isEmpty())return;let w,g;b!=null&&(w=new Promise((E,A)=>{g=()=>{A(new ec)},b.addEventListener("abort",g)}));try{await Promise.race([a.promise,w])}finally{g!=null&&b!=null&&b?.removeEventListener("abort",g)}}},t==null)return s;let p=s;return s={[Symbol.asyncIterator](){return this},next(){return p.next()},throw(y){return p.throw(y),t!=null&&(t(y),t=void 0),{done:!0}},return(){return p.return(),t!=null&&(t(),t=void 0),{done:!0}},push:u,end(y){return p.end(y),t!=null&&(t(y),t=void 0),s},get readableLength(){return p.readableLength},onEmpty:y=>p.onEmpty(y)},s}function K0(r){return r[Symbol.asyncIterator]!=null}function q0(...r){let e=[];for(let t of r)K0(t)||e.push(t);return e.length===r.length?function*(){for(let t of e)yield*t}():async function*(){let t=Pr({objectMode:!0});Promise.resolve().then(async()=>{try{await Promise.all(r.map(async n=>{for await(let s of n)t.push(s)})),t.end()}catch(n){t.end(n)}}),yield*t}()}var Uf=q0;function Df(r,...e){if(r==null)throw new Error("Empty pipeline");if(tc(r)){let n=r;r=()=>n.source}else if(Mf(r)||Of(r)){let n=r;r=()=>n}let t=[r,...e];if(t.length>1&&tc(t[t.length-1])&&(t[t.length-1]=t[t.length-1].sink),t.length>2)for(let n=1;n<t.length-1;n++)tc(t[n])&&(t[n]=$0(t[n]));return z0(...t)}var z0=(...r)=>{let e;for(;r.length>0;)e=r.shift()(e);return e},Of=r=>r?.[Symbol.asyncIterator]!=null,Mf=r=>r?.[Symbol.iterator]!=null,tc=r=>r==null?!1:r.sink!=null&&r.source!=null,$0=r=>e=>{let t=r.sink(e);if(t?.then!=null){let n=Pr({objectMode:!0});t.then(()=>{n.end()},o=>{n.end(o)});let s,i=r.source;if(Of(i))s=async function*(){yield*i,n.end()};else if(Mf(i))s=function*(){yield*i,n.end()};else throw new Error("Unknown duplex source type - must be Iterable or AsyncIterable");return Uf(n,s())}return r.source};function rc(r){let{stream:e,remoteAddr:t,logger:n,onDataRead:s,onDataWrite:i}=r,o=n.forComponent("libp2p:stream:converter"),a=!1,c=!1,h=e.close.bind(e);e.close=async d=>{await h(d),l(!0)};let f=e.abort.bind(e);e.abort=d=>{f(d),l(!0)};let u=e.sink.bind(e);e.sink=async d=>{try{await u(Df(d,p=>Rf(p,y=>i?.(y))))}catch(p){p.type!=="aborted"&&o.error("%s error in sink",t,p)}finally{c=!0,l()}};let m={log:o,sink:e.sink,source:async function*(){try{for await(let d of e.source)s?.(d),yield d}finally{a=!0,l()}}(),remoteAddr:t,timeline:{open:Date.now(),close:void 0},close:e.close,abort:e.abort};function l(d){d===!0&&(a=!0,c=!0),a&&c&&m.timeline.close==null&&(m.timeline.close=Date.now())}return m}var Zt=class extends Event{type;detail;constructor(e,t){super(e),this.type=e,this.detail=t}};var nc=class extends Error{type;code;constructor(e,t){super(e??"The operation was aborted"),this.type="aborted",this.name="AbortError",this.code=t??"ABORT_ERR"}};async function Ui(r,e,t,n){let s=new nc(n?.errorMessage,n?.errorCode);return t?.aborted===!0?Promise.reject(s):new Promise((i,o)=>{function a(){t?.removeEventListener("abort",f),r.removeEventListener(e,c),n?.errorEvent!=null&&r.removeEventListener(n.errorEvent,h)}let c=u=>{try{if(n?.filter?.(u)===!1)return}catch(m){a(),o(m);return}a(),i(u)},h=u=>{a(),o(u.detail)},f=()=>{a(),o(s)};t?.addEventListener("abort",f),r.addEventListener(e,c),n?.errorEvent!=null&&r.addEventListener(n.errorEvent,h)})}var Di=class extends Error{static name="QueueFullError";constructor(e="The queue was full"){super(e),this.name="QueueFullError"}};var Oi=class{deferred;signal;constructor(e){this.signal=e,this.deferred=rt(),this.onAbort=this.onAbort.bind(this),this.signal?.addEventListener("abort",this.onAbort)}onAbort(){this.deferred.reject(this.signal?.reason??new ht)}cleanup(){this.signal?.removeEventListener("abort",this.onAbort)}};function G0(){return`${parseInt(String(Math.random()*1e9),10).toString()}${Date.now()}`}var Mi=class{id;fn;options;recipients;status;timeline;controller;constructor(e,t){this.id=G0(),this.status="queued",this.fn=e,this.options=t,this.recipients=[],this.timeline={created:Date.now()},this.controller=new AbortController,Le(1/0,this.controller.signal),this.onAbort=this.onAbort.bind(this)}abort(e){this.controller.abort(e)}onAbort(){this.recipients.reduce((t,n)=>t&&n.signal?.aborted===!0,!0)&&(this.controller.abort(new ht),this.cleanup())}async join(e={}){let t=new Oi(e.signal);return this.recipients.push(t),e.signal?.addEventListener("abort",this.onAbort),t.deferred.promise}async run(){this.status="running",this.timeline.started=Date.now();try{this.controller.signal.throwIfAborted();let e=await oi(this.fn({...this.options??{},signal:this.controller.signal}),this.controller.signal);this.recipients.forEach(t=>{t.deferred.resolve(e)}),this.status="complete"}catch(e){this.recipients.forEach(t=>{t.deferred.reject(e)}),this.status="errored"}finally{this.timeline.finished=Date.now(),this.cleanup()}}cleanup(){this.recipients.forEach(e=>{e.cleanup(),e.signal?.removeEventListener("abort",this.onAbort)})}};var Pi=class extends qe{concurrency;maxSize;queue;pending;sort;constructor(e={}){super(),this.concurrency=e.concurrency??Number.POSITIVE_INFINITY,this.maxSize=e.maxSize??Number.POSITIVE_INFINITY,this.pending=0,e.metricName!=null&&e.metrics?.registerMetricGroup(e.metricName,{calculate:()=>({size:this.queue.length,running:this.pending,queued:this.queue.length-this.pending})}),this.sort=e.sort,this.queue=[]}tryToStartAnother(){if(this.size===0)return queueMicrotask(()=>{this.safeDispatchEvent("empty")}),this.running===0&&queueMicrotask(()=>{this.safeDispatchEvent("idle")}),!1;if(this.pending<this.concurrency){let e;for(let t of this.queue)if(t.status==="queued"){e=t;break}return e==null?!1:(this.safeDispatchEvent("active"),this.pending++,e.run().finally(()=>{for(let t=0;t<this.queue.length;t++)if(this.queue[t]===e){this.queue.splice(t,1);break}this.pending--,this.tryToStartAnother(),this.safeDispatchEvent("next")}),!0)}return!1}enqueue(e){this.queue.push(e),this.sort!=null&&this.queue.sort(this.sort)}async add(e,t){if(t?.signal?.throwIfAborted(),this.size===this.maxSize)throw new Di;let n=new Mi(e,t);return this.enqueue(n),this.safeDispatchEvent("add"),this.tryToStartAnother(),n.join(t).then(s=>(this.safeDispatchEvent("completed",{detail:s}),this.safeDispatchEvent("success",{detail:{job:n,result:s}}),s)).catch(s=>{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:s}),this.safeDispatchEvent("failure",{detail:{job:n,error:s}}),s})}clear(){this.queue.splice(0,this.queue.length)}abort(){this.queue.forEach(e=>{e.abort(new ht)}),this.clear()}async onEmpty(e){this.size!==0&&await Ui(this,"empty",e?.signal)}async onSizeLessThan(e,t){this.size<e||await Ui(this,"next",t?.signal,{filter:()=>this.size<e})}async onIdle(e){this.pending===0&&this.size===0||await Ui(this,"idle",e?.signal)}get size(){return this.queue.length}get queued(){return this.queue.length-this.pending}get running(){return this.pending}async*toGenerator(e){e?.signal?.throwIfAborted();let t=Pr({objectMode:!0}),n=c=>{c!=null?this.abort():this.clear(),t.end(c)},s=c=>{c.detail!=null&&t.push(c.detail)},i=c=>{n(c.detail)},o=()=>{n()},a=()=>{n(new ht("Queue aborted"))};this.addEventListener("completed",s),this.addEventListener("error",i),this.addEventListener("idle",o),e?.signal?.addEventListener("abort",a);try{yield*t}finally{this.removeEventListener("completed",s),this.removeEventListener("error",i),this.removeEventListener("idle",o),e?.signal?.removeEventListener("abort",a),n()}}};var Vr=class extends Pi{has(e){return this.find(e)!=null}find(e){return this.queue.find(t=>e.equals(t.options.peerId))}};var Vi=class extends qe{peerStore;registrar;connectionManager;randomWalk;started;running;topologyId;log;discoveryController;filter;queue;constructor(e,t={}){super(),this.log=e.logger.forComponent("libp2p:circuit-relay:discover-relays"),this.started=!1,this.running=!1,this.peerStore=e.peerStore,this.registrar=e.registrar,this.connectionManager=e.connectionManager,this.randomWalk=e.randomWalk,this.filter=t.filter,this.discoveryController=new AbortController,Le(1/0,this.discoveryController.signal)}isStarted(){return this.started}async start(){this.topologyId=await this.registrar.register(We,{filter:this.filter,onConnect:e=>{this.log.trace("discovered relay %p queue (length: %d, active %d)",e,this.queue?.size,this.queue?.running),this.safeDispatchEvent("relay:discover",{detail:e})}}),this.started=!0}stop(){this.topologyId!=null&&this.registrar.unregister(this.topologyId),this.discoveryController?.abort(),this.started=!1}startDiscovery(){this.running||(this.log("start discovery"),this.running=!0,this.discoveryController=new AbortController,Le(1/0,this.discoveryController.signal),Promise.resolve().then(async()=>{this.log("searching peer store for relays");let e=await this.peerStore.all({filters:[n=>n.protocols.includes(We)],orders:[()=>Math.random()<.5?1:-1,(n,s)=>{let i=Pf(n),o=Pf(s);return i>o?-1:o>i?1:0}]});for(let n of e)this.log.trace("found relay peer %p in peer store",n.id),this.safeDispatchEvent("relay:discover",{detail:n.id});this.log("found %d relay peers in peer store",e.length);let t=this.queue=new Vr({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),t.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(s=>s.toString()));continue}t.queued>10&&(this.log.trace("wait for space in queue for %p",n.id),await t.onSizeLessThan(10,{signal:this.discoveryController.signal})),this.log("adding random peer %p to dial queue (length: %d, active %d)",n.id,t.size,t.running),t.add(async()=>{let s=vi([this.discoveryController.signal,AbortSignal.timeout(5e3)]);Le(1/0,s);try{await this.connectionManager.openConnection(n.id,{signal:s})}finally{s.clear()}},{peerId:n.id,signal:this.discoveryController.signal}).catch(s=>{this.log.error("error opening connection to random peer %p",n.id,s)})}this.log("stop random walk"),await t.onIdle()}).catch(e=>{this.discoveryController.signal.aborted||this.log.error("failed when finding relays on the network",e)}))}stopDiscovery(){this.log("stop discovery"),this.running=!1,this.discoveryController?.abort()}};function Pf(r){let e=r.metadata.get("last-dial-success");return e==null?0:new Date(ce(e)).getTime()}var sc=class extends qe{peerId;connectionManager;addressManager;reservationStore;listeningAddrs;log;listenTimeout;reservationId;relay;constructor(e,t={}){super(),this.log=e.logger.forComponent("libp2p:circuit-relay:transport:listener"),this.peerId=e.peerId,this.connectionManager=e.connectionManager,this.addressManager=e.addressManager,this.reservationStore=e.reservationStore,this.listeningAddrs=[],this.listenTimeout=t.listenTimeout??hi,this.reservationStore.addEventListener("relay:removed",this._onRemoveRelayPeer),this.reservationStore.addEventListener("relay:created-reservation",this._onAddRelayPeer)}_onRemoveRelayPeer=e=>{this.log("relay removed %p our relay %p",e.detail.relay,this.relay,this.relay?.equals(e.detail.relay)),this.relay?.equals(e.detail.relay)===!0&&(this.log("relay peer removed %p",e.detail.relay),this.listeningAddrs.forEach(t=>{this.addressManager.removeObservedAddr(t)}),this.listeningAddrs=[],this.safeDispatchEvent("listening"))};_onAddRelayPeer=e=>{let{details:t}=e.detail;t.type!=="configured"&&t.id===this.reservationId&&this.addedRelay(e.detail)};async listen(e){if(this.log("listen on %a",e),_i.exactMatch(e))this.reservationId=this.reservationStore.reserveRelay();else if(Bi.exactMatch(e)){let t=AbortSignal.timeout(this.listenTimeout);Le(1/0,t);let n=e.decapsulate("/p2p-circuit"),s=await this.connectionManager.openConnection(n,{signal:t});if(!this.reservationStore.hasReservation(s.remotePeer)){this.log("making reservation on peer %p",s.remotePeer);let i=await this.reservationStore.addRelay(s.remotePeer,"configured");this.addedRelay(i)}}else throw new jt(`Could not listen on p2p-circuit address "${e}"`)}getAddrs(){return[...this.listeningAddrs.values()].flat()}async close(){this.reservationStore.cancelReservations(),this.listeningAddrs=[],this.reservationStore.removeEventListener("relay:removed",this._onRemoveRelayPeer),queueMicrotask(()=>{this.safeDispatchEvent("close")})}addedRelay(e){this.log("relay peer added %p",e.relay),this.relay=e.relay,this.listeningAddrs=e.details.reservation.addrs.map(t=>_e(t).encapsulate("/p2p-circuit")),this.listeningAddrs.forEach(t=>{this.addressManager.confirmObservedAddr(t,{type:"transport"})}),queueMicrotask(()=>{this.safeDispatchEvent("listening")})}};function Vf(r){return new sc(r)}var Hf="useandom-26T198340PX75pxJACKVERYMINDBUSHWOLF_GQZbfghjklqvwyzrict";var Ff=(r=21)=>{let e="",t=crypto.getRandomValues(new Uint8Array(r|=0));for(;r--;)e+=Hf[t[r]&63];return e};var W0=60*1e3*10,Z0=60*1e3*5,j0=30*1e3,Hi=class extends qe{peerId;connectionManager;peerStore;events;reserveQueue;reservations;pendingReservations;maxReservationQueueLength;reservationCompletionTimeout;started;log;relayFilter;constructor(e,t){super(),this.log=e.logger.forComponent("libp2p:circuit-relay:transport:reservation-store"),this.peerId=e.peerId,this.connectionManager=e.connectionManager,this.peerStore=e.peerStore,this.events=e.events,this.reservations=new Wt,this.pendingReservations=[],this.maxReservationQueueLength=t?.maxReservationQueueLength??af,this.reservationCompletionTimeout=t?.reservationCompletionTimeout??hi,this.started=!1,this.relayFilter=Or(100),this.reserveQueue=new Vr({concurrency:t?.reservationConcurrency??of,metricName:"libp2p_relay_reservation_queue",metrics:e.metrics}),this.events.addEventListener("connection:close",n=>{[...this.reservations.values()].find(i=>i.connection===n.detail.id)!=null&&this.#t(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 e=await this.peerStore.all({filters:[t=>t.tags.has(mn)]});this.log("removing tag from %d old relays",e.length),await Promise.all(e.map(async t=>{await this.peerStore.merge(t.id,{tags:{[mn]:void 0}})})),this.log("redialing %d old relays",e.length),await Promise.all(e.map(async t=>this.addRelay(t.id,"discovered"))),this.#r()}).catch(e=>{this.log.error(e)})}stop(){this.reserveQueue.clear(),this.reservations.forEach(({timeout:e})=>{clearTimeout(e)}),this.reservations.clear(),this.started=!1}reserveRelay(){let e=Ff();return this.pendingReservations.push(e),this.#r(),e}async addRelay(e,t){if(this.peerId.equals(e))throw this.log.trace("not trying to use self as relay"),new jt("Cannot use self as relay");if(this.reserveQueue.size>this.maxReservationQueueLength)throw new Ai("The reservation queue is full");let n=this.reserveQueue.find(e);if(n!=null)return this.log.trace("potential relay peer %p is already in the reservation queue",e),n.join();if(this.relayFilter.has(e.toMultihash().bytes))throw new jt("The relay was previously invalid");return this.log.trace("try to reserve relay slot with %p",e),this.reserveQueue.add(async()=>{let s=Date.now();try{let i=this.reservations.get(e);if(i!=null){let d=this.connectionManager.getConnections(e),p=!1;if(d.length===0&&this.log("already have relay reservation with %p but we are no longer connected",e),d.map(y=>y.id).includes(i.connection)&&(this.log("already have relay reservation with %p and the original connection is still open",e),p=!0),p&&$a(i.reservation.expire)>W0)return this.log("already have relay reservation with %p but we are still connected and it does not expire soon",e),{relay:e,details:i};await this.#t(e)}if(t==="discovered"&&this.pendingReservations.length===0)throw new En("Not making reservation on discovered relay because we do not need any more relays");let o=AbortSignal.timeout(this.reservationCompletionTimeout);Le(1/0,o);let a=await this.connectionManager.openConnection(e,{signal:o});if(xi.matches(a.remoteAddr))throw new Si("not creating reservation over relayed connection");let c=await this.#e(a,{signal:o}),h=$a(c.expire);this.log("created reservation on relay peer %p, expiry date is %s",e,new Date(Date.now()+h).toString());let f=Math.min(Math.max(h-Z0,j0),Math.pow(2,31)-1),u=setTimeout(()=>{this.log("refresh reservation to relay %p",e),this.addRelay(e,t).catch(async d=>{this.log.error("could not refresh reservation to relay %p - %e",e,d),await this.#t(e)}).catch(d=>{this.log.error("could not remove expired reservation to relay %p - %e",e,d)})},f),m;if(t==="discovered"){let d=this.pendingReservations.pop();if(d==null)throw new En("Made reservation on relay but did not need any more discovered relays");m={timeout:u,reservation:c,type:t,connection:a.id,id:d}}else m={timeout:u,reservation:c,type:t,connection:a.id};this.reservations.set(e,m),await this.peerStore.merge(e,{tags:{[mn]:{value:1,ttl:h}}}),this.#r();let l={relay:e,details:m};return this.safeDispatchEvent("relay:created-reservation",{detail:l}),l}catch(i){throw t==="discovered"&&i.name==="HadEnoughRelaysError"||this.log.error("could not reserve slot on %p after %dms - %e",e,Date.now()-s,i),(i.name==="DialError"||i.name==="UnsupportedProtocolError")&&this.relayFilter.add(e.toMultihash().bytes),this.#t(e).catch(o=>{this.log.error("could not remove reservation on %p after reserving slot failed - %e",e,o)}),i}},{peerId:e})}hasReservation(e){return this.reservations.has(e)}getReservation(e){return this.reservations.get(e)?.reservation}reservationCount(e){return e==null?this.reservations.size:[...this.reservations.values()].reduce((t,n)=>(n.type===e&&t++,t),0)}cancelReservations(){[...this.reservations.values()].forEach(e=>{clearTimeout(e.timeout)}),this.reservations.clear()}async#e(e,t){t.signal?.throwIfAborted(),this.log("requesting reservation from %p",e.remotePeer);let n=await e.newStream(We,t),i=Gt(n).pb(X);this.log.trace("send RESERVE to %p",e.remotePeer),await i.write({type:X.Type.RESERVE},t);let o;try{this.log.trace("reading response from %p",e.remotePeer),o=await i.read(t)}catch(c){throw n.abort(c),c}finally{n.status!=="closed"&&await n.close(t)}if(this.log.trace("read response %o",o),o.status===K.OK&&o.reservation!=null){let c=new Set;c.add(e.remoteAddr.toString());for(let h of o.reservation.addrs){let f=_e(h);f.getPeerId()==null&&(f=f.encapsulate(`/p2p/${e.remotePeer}`)),f=_e(f.toString().replace(`/p2p/${e.remotePeer}/p2p/${e.remotePeer}`,`/p2p/${e.remotePeer}`)),c.add(f.toString())}return o.reservation.addrs=[...c].map(h=>_e(h).bytes),o.reservation}let a=`reservation failed with status ${o.status??"undefined"}`;throw this.log.error(a),new Error(a)}async#t(e){let t=this.reservations.get(e);t!=null&&(this.log("removing relay reservation with %p from local store",e),clearTimeout(t.timeout),this.reservations.delete(e),t.type==="discovered"&&this.pendingReservations.push(t.id),await this.peerStore.merge(e,{tags:{[mn]:void 0}}),this.safeDispatchEvent("relay:removed",{detail:{relay:e,details:t}}),this.#r())}#r(){if(this.pendingReservations.length===0){this.log.trace("have discovered enough relays"),this.reserveQueue.clear(),this.safeDispatchEvent("relay:found-enough-relays");return}this.relayFilter=Or(100),this.log("not discovered enough relays %d/%d",this.reservations.size,this.pendingReservations.length),this.safeDispatchEvent("relay:not-enough-relays")}};var Y0=r=>{if(r.peer==null)return!1;try{r.peer.addrs.forEach(_e)}catch{return!1}return!0},ic={maxInboundStopStreams:yn,maxOutboundStopStreams:yn,stopTimeout:3e4},Fi=class{discovery;registrar;peerStore;connectionManager;transportManager;peerId;upgrader;addressManager;connectionGater;reservationStore;logger;maxInboundStopStreams;maxOutboundStopStreams;stopTimeout;started;log;constructor(e,t){this.log=e.logger.forComponent("libp2p:circuit-relay:transport"),this.registrar=e.registrar,this.peerStore=e.peerStore,this.connectionManager=e.connectionManager,this.transportManager=e.transportManager,this.logger=e.logger,this.peerId=e.peerId,this.upgrader=e.upgrader,this.addressManager=e.addressManager,this.connectionGater=e.connectionGater,this.maxInboundStopStreams=t.maxInboundStopStreams??ic.maxInboundStopStreams,this.maxOutboundStopStreams=t.maxOutboundStopStreams??ic.maxOutboundStopStreams,this.stopTimeout=t.stopTimeout??ic.stopTimeout,this.discovery=new Vi(e,{filter:t.discoveryFilter??ja(ff,hf)}),this.discovery.addEventListener("relay:discover",n=>{this.reservationStore.addRelay(n.detail,"discovered").catch(s=>{s.name!=="HadEnoughRelaysError"&&s.name!=="RelayQueueFullError"&&this.log.error("could not add discovered relay %p",n.detail,s)})}),this.reservationStore=new Hi(e,t),this.reservationStore.addEventListener("relay:not-enough-relays",()=>{this.discovery?.startDiscovery()}),this.reservationStore.addEventListener("relay:found-enough-relays",()=>{this.discovery?.stopDiscovery()}),this.started=!1}[Symbol.toStringTag]="@libp2p/circuit-relay-v2-transport";[xc]=["@libp2p/transport","@libp2p/circuit-relay-v2-transport"];get[vc](){return this.discovery!=null?["@libp2p/identify"]:[]}[mc]=!0;isStarted(){return this.started}async start(){await this.registrar.handle(ar,e=>{this.onStop(e).catch(t=>{this.log.error("error while handling STOP protocol",t),e.stream.abort(t)})},{maxInboundStreams:this.maxInboundStopStreams,maxOutboundStreams:this.maxOutboundStopStreams,runOnLimitedConnection:!0}),await bc(this.discovery,this.reservationStore),this.started=!0}async stop(){await wc(this.discovery,this.reservationStore),await this.registrar.unhandle(ar),this.started=!1}async dial(e,t){if(e.protoCodes().filter(l=>l===fi).length!==1){let l="Invalid circuit relay address";throw this.log.error(l,e),new Fr(l)}let n=e.toString().split("/p2p-circuit"),s=_e(n[0]),i=_e(n[n.length-1]),o=s.getPeerId(),a=i.getPeerId();if(o==null||a==null){let l=`ircuit relay dial to ${e.toString()} failed as address did not have both relay and destination PeerIDs`;throw this.log.error(`c${l}`),new Fr(`C${l}`)}let c=ya(o),h=ya(a),u=this.connectionManager.getConnections(c)[0];u==null?(await this.peerStore.merge(c,{multiaddrs:[s]}),t.onProgress?.(new Zt("circuit-relay:open-connection")),u=await this.connectionManager.openConnection(c,t)):t.onProgress?.(new Zt("circuit-relay:reuse-connection"));let m;try{t.onProgress?.(new Zt("circuit-relay:open-hop-stream")),m=await u.newStream(We,t);let l=Gt(m),d=l.pb(X);t.onProgress?.(new Zt("circuit-relay:write-connect-message")),await d.write({type:X.Type.CONNECT,peer:{id:h.toMultihash().bytes,addrs:[_e(i).bytes]}},t),t.onProgress?.(new Zt("circuit-relay:read-connect-response"));let p=await d.read(t);if(p.status!==K.OK)throw new kn(`failed to connect via relay with status ${p?.status?.toString()??"undefined"}`);let y=new Sn(p.limit),b=rc({stream:l.unwrap(),remoteAddr:e,localAddr:s.encapsulate(`/p2p-circuit/p2p/${this.peerId.toString()}`),logger:this.logger,onDataRead:y.onData,onDataWrite:y.onData});return this.log("new outbound relayed connection %a",b.remoteAddr),await this.upgrader.upgradeOutbound(b,{...t,limits:y.getLimits()})}catch(l){throw this.log.error("circuit relay dial to destination %p via relay %p failed",h,c,l),m?.abort(l),l}}createListener(e){return Vf({peerId:this.peerId,connectionManager:this.connectionManager,addressManager:this.addressManager,reservationStore:this.reservationStore,logger:this.logger})}listenFilter(e){return e=Array.isArray(e)?e:[e],e.filter(t=>Bi.exactMatch(t)||_i.exactMatch(t))}dialFilter(e){return e=Array.isArray(e)?e:[e],e.filter(t=>xi.exactMatch(t))}async onStop({connection:e,stream:t}){if(!this.reservationStore.hasReservation(e.remotePeer))try{this.log("dialed via relay we did not have a reservation on, start listening on that relay address"),await this.transportManager.listen([e.remoteAddr.encapsulate("/p2p-circuit")])}catch(u){this.log.error("failed to listen on a relay peer we were dialed via but did not have a reservation on",u)}let n=AbortSignal.timeout(this.stopTimeout),s=Gt(t).pb(Ke),i=await s.read({signal:n});if(this.log("new circuit relay v2 stop stream from %p with type %s",e.remotePeer,i.type),i?.type===void 0){this.log.error("type was missing from circuit v2 stop protocol request from %s",e.remotePeer),await s.write({type:Ke.Type.STATUS,status:K.MALFORMED_MESSAGE},{signal:n}),await t.close();return}if(i.type!==Ke.Type.CONNECT){this.log.error("invalid stop connect request via peer %p",e.remotePeer),await s.write({type:Ke.Type.STATUS,status:K.UNEXPECTED_MESSAGE},{signal:n}),await t.close();return}if(!Y0(i)){this.log.error("invalid stop connect request via peer %p",e.remotePeer),await s.write({type:Ke.Type.STATUS,status:K.MALFORMED_MESSAGE},{signal:n}),await t.close();return}let o=dn(ze(i.peer.id));if(await this.connectionGater.denyInboundRelayedConnection?.(e.remotePeer,o)===!0){this.log.error("connection gater denied inbound relayed connection from %p",e.remotePeer),await s.write({type:Ke.Type.STATUS,status:K.PERMISSION_DENIED},{signal:n}),await t.close();return}this.log.trace("sending success response to %p",e.remotePeer),await s.write({type:Ke.Type.STATUS,status:K.OK},{signal:n});let a=new Sn(i.limit),c=e.remoteAddr.encapsulate(`/p2p-circuit/p2p/${o.toString()}`),h=this.addressManager.getAddresses()[0],f=rc({stream:s.unwrap().unwrap(),remoteAddr:c,localAddr:h,logger:this.logger,onDataRead:a.onData,onDataWrite:a.onData});this.log("new inbound relayed connection %a",f.remoteAddr),await this.upgrader.upgradeInbound(f,{limits:a.getLimits()}),this.log("%s connection %a upgraded","inbound",f.remoteAddr)}};function Kf(r={}){return e=>new Fi(e,r)}return rh(X0);})();
|
7
7
|
/*! Bundled license information:
|
8
8
|
|
9
9
|
pvtsutils/build/index.js:
|