@libp2p/circuit-relay-v2 1.0.25-863b3de03 → 1.0.25-d1f1c2be7
Sign up to get free protection for your applications and to get access to all the features.
- package/dist/index.min.js +3 -3
- package/dist/src/server/index.d.ts.map +1 -1
- package/dist/src/server/index.js +1 -0
- package/dist/src/server/index.js.map +1 -1
- package/dist/src/server/reservation-store.d.ts +2 -3
- package/dist/src/server/reservation-store.d.ts.map +1 -1
- package/dist/src/server/reservation-store.js.map +1 -1
- package/dist/src/transport/transport.d.ts +6 -3
- package/dist/src/transport/transport.d.ts.map +1 -1
- package/dist/src/transport/transport.js +16 -4
- package/dist/src/transport/transport.js.map +1 -1
- package/package.json +10 -10
- package/src/server/index.ts +2 -0
- package/src/server/reservation-store.ts +2 -4
- package/src/transport/transport.ts +22 -6
package/dist/index.min.js
CHANGED
@@ -1,10 +1,10 @@
|
|
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 ef=Object.create;var In=Object.defineProperty;var tf=Object.getOwnPropertyDescriptor;var rf=Object.getOwnPropertyNames;var nf=Object.getPrototypeOf,sf=Object.prototype.hasOwnProperty;var gi=(r,e)=>()=>(e||r((e={exports:{}}).exports,e),e.exports),ge=(r,e)=>{for(var t in e)In(r,t,{get:e[t],enumerable:!0})},Na=(r,e,t,n)=>{if(e&&typeof e=="object"||typeof e=="function")for(let s of rf(e))!sf.call(r,s)&&s!==t&&In(r,s,{get:()=>e[s],enumerable:!(n=tf(e,s))||n.enumerable});return r};var mi=(r,e,t)=>(t=r!=null?ef(nf(r)):{},Na(e||!r||!r.__esModule?In(t,"default",{value:r,enumerable:!0}):t,r)),of=r=>Na(In({},"__esModule",{value:!0}),r);var Kc=gi(Dr=>{"use strict";var Hd="[object ArrayBuffer]",vt=class r{static isArrayBuffer(e){return Object.prototype.toString.call(e)===Hd}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}},So="string",Fd=/^[0-9a-f]+$/i,Kd=/^(?:[A-Za-z0-9+/]{4})*(?:[A-Za-z0-9+/]{2}==|[A-Za-z0-9+/]{3}=)?$/,qd=/^[a-zA-Z0-9-_]+$/,Yn=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))}},je=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}},Zn=class r{static isHex(e){return typeof e===So&&Fd.test(e)}static isBase64(e){return typeof e===So&&Kd.test(e)}static isBase64Url(e){return typeof e===So&&qd.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 je.toString(n,!0);case"utf16":case"utf16be":return je.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 je.fromString(e,!0);case"utf16":case"utf16be":return je.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 Yn.fromString(e);case"utf16":case"utf16be":return je.fromString(e);case"utf16le":case"usc2":return je.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 Yn.toString(e);case"utf16":case"utf16be":return je.toString(e);case"utf16le":case"usc2":return je.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 je.toString(e,t)}static FromUtf16String(e,t=!1){return je.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,"")||""}};Zn.DEFAULT_UTF8_ENCODING="utf8";function zd(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 $d(...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 Gd(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}Dr.BufferSourceConverter=vt;Dr.Convert=Zn;Dr.assign=zd;Dr.combine=$d;Dr.isEqual=Gd});var Iu=gi((Sn,Zs)=>{(function(r,e){"use strict";var t={version:"3.0.0",x86:{},x64:{},inputValidation:!0};function n(u){if(!Array.isArray(u)&&!ArrayBuffer.isView(u))return!1;for(var d=0;d<u.length;d++)if(!Number.isInteger(u[d])||u[d]<0||u[d]>255)return!1;return!0}function s(u,d){return(u&65535)*d+(((u>>>16)*d&65535)<<16)}function i(u,d){return u<<d|u>>>32-d}function o(u){return u^=u>>>16,u=s(u,2246822507),u^=u>>>13,u=s(u,3266489909),u^=u>>>16,u}function a(u,d){u=[u[0]>>>16,u[0]&65535,u[1]>>>16,u[1]&65535],d=[d[0]>>>16,d[0]&65535,d[1]>>>16,d[1]&65535];var p=[0,0,0,0];return p[3]+=u[3]+d[3],p[2]+=p[3]>>>16,p[3]&=65535,p[2]+=u[2]+d[2],p[1]+=p[2]>>>16,p[2]&=65535,p[1]+=u[1]+d[1],p[0]+=p[1]>>>16,p[1]&=65535,p[0]+=u[0]+d[0],p[0]&=65535,[p[0]<<16|p[1],p[2]<<16|p[3]]}function c(u,d){u=[u[0]>>>16,u[0]&65535,u[1]>>>16,u[1]&65535],d=[d[0]>>>16,d[0]&65535,d[1]>>>16,d[1]&65535];var p=[0,0,0,0];return p[3]+=u[3]*d[3],p[2]+=p[3]>>>16,p[3]&=65535,p[2]+=u[2]*d[3],p[1]+=p[2]>>>16,p[2]&=65535,p[2]+=u[3]*d[2],p[1]+=p[2]>>>16,p[2]&=65535,p[1]+=u[1]*d[3],p[0]+=p[1]>>>16,p[1]&=65535,p[1]+=u[2]*d[2],p[0]+=p[1]>>>16,p[1]&=65535,p[1]+=u[3]*d[1],p[0]+=p[1]>>>16,p[1]&=65535,p[0]+=u[0]*d[3]+u[1]*d[2]+u[2]*d[1]+u[3]*d[0],p[0]&=65535,[p[0]<<16|p[1],p[2]<<16|p[3]]}function h(u,d){return d%=64,d===32?[u[1],u[0]]:d<32?[u[0]<<d|u[1]>>>32-d,u[1]<<d|u[0]>>>32-d]:(d-=32,[u[1]<<d|u[0]>>>32-d,u[0]<<d|u[1]>>>32-d])}function f(u,d){return d%=64,d===0?u:d<32?[u[0]<<d|u[1]>>>32-d,u[1]<<d]:[u[1]<<d-32,0]}function l(u,d){return[u[0]^d[0],u[1]^d[1]]}function m(u){return u=l(u,[0,u[0]>>>1]),u=c(u,[4283543511,3981806797]),u=l(u,[0,u[0]>>>1]),u=c(u,[3301882366,444984403]),u=l(u,[0,u[0]>>>1]),u}t.x86.hash32=function(u,d){if(t.inputValidation&&!n(u))return e;d=d||0;for(var p=u.length%4,b=u.length-p,g=d,w=0,y=3432918353,E=461845907,x=0;x<b;x=x+4)w=u[x]|u[x+1]<<8|u[x+2]<<16|u[x+3]<<24,w=s(w,y),w=i(w,15),w=s(w,E),g^=w,g=i(g,13),g=s(g,5)+3864292196;switch(w=0,p){case 3:w^=u[x+2]<<16;case 2:w^=u[x+1]<<8;case 1:w^=u[x],w=s(w,y),w=i(w,15),w=s(w,E),g^=w}return g^=u.length,g=o(g),g>>>0},t.x86.hash128=function(u,d){if(t.inputValidation&&!n(u))return e;d=d||0;for(var p=u.length%16,b=u.length-p,g=d,w=d,y=d,E=d,x=0,S=0,v=0,B=0,$=597399067,q=2869860233,P=951274213,te=2716044179,C=0;C<b;C=C+16)x=u[C]|u[C+1]<<8|u[C+2]<<16|u[C+3]<<24,S=u[C+4]|u[C+5]<<8|u[C+6]<<16|u[C+7]<<24,v=u[C+8]|u[C+9]<<8|u[C+10]<<16|u[C+11]<<24,B=u[C+12]|u[C+13]<<8|u[C+14]<<16|u[C+15]<<24,x=s(x,$),x=i(x,15),x=s(x,q),g^=x,g=i(g,19),g+=w,g=s(g,5)+1444728091,S=s(S,q),S=i(S,16),S=s(S,P),w^=S,w=i(w,17),w+=y,w=s(w,5)+197830471,v=s(v,P),v=i(v,17),v=s(v,te),y^=v,y=i(y,15),y+=E,y=s(y,5)+2530024501,B=s(B,te),B=i(B,18),B=s(B,$),E^=B,E=i(E,13),E+=g,E=s(E,5)+850148119;switch(x=0,S=0,v=0,B=0,p){case 15:B^=u[C+14]<<16;case 14:B^=u[C+13]<<8;case 13:B^=u[C+12],B=s(B,te),B=i(B,18),B=s(B,$),E^=B;case 12:v^=u[C+11]<<24;case 11:v^=u[C+10]<<16;case 10:v^=u[C+9]<<8;case 9:v^=u[C+8],v=s(v,P),v=i(v,17),v=s(v,te),y^=v;case 8:S^=u[C+7]<<24;case 7:S^=u[C+6]<<16;case 6:S^=u[C+5]<<8;case 5:S^=u[C+4],S=s(S,q),S=i(S,16),S=s(S,P),w^=S;case 4:x^=u[C+3]<<24;case 3:x^=u[C+2]<<16;case 2:x^=u[C+1]<<8;case 1:x^=u[C],x=s(x,$),x=i(x,15),x=s(x,q),g^=x}return g^=u.length,w^=u.length,y^=u.length,E^=u.length,g+=w,g+=y,g+=E,w+=g,y+=g,E+=g,g=o(g),w=o(w),y=o(y),E=o(E),g+=w,g+=y,g+=E,w+=g,y+=g,E+=g,("00000000"+(g>>>0).toString(16)).slice(-8)+("00000000"+(w>>>0).toString(16)).slice(-8)+("00000000"+(y>>>0).toString(16)).slice(-8)+("00000000"+(E>>>0).toString(16)).slice(-8)},t.x64.hash128=function(u,d){if(t.inputValidation&&!n(u))return e;d=d||0;for(var p=u.length%16,b=u.length-p,g=[0,d],w=[0,d],y=[0,0],E=[0,0],x=[2277735313,289559509],S=[1291169091,658871167],v=0;v<b;v=v+16)y=[u[v+4]|u[v+5]<<8|u[v+6]<<16|u[v+7]<<24,u[v]|u[v+1]<<8|u[v+2]<<16|u[v+3]<<24],E=[u[v+12]|u[v+13]<<8|u[v+14]<<16|u[v+15]<<24,u[v+8]|u[v+9]<<8|u[v+10]<<16|u[v+11]<<24],y=c(y,x),y=h(y,31),y=c(y,S),g=l(g,y),g=h(g,27),g=a(g,w),g=a(c(g,[0,5]),[0,1390208809]),E=c(E,S),E=h(E,33),E=c(E,x),w=l(w,E),w=h(w,31),w=a(w,g),w=a(c(w,[0,5]),[0,944331445]);switch(y=[0,0],E=[0,0],p){case 15:E=l(E,f([0,u[v+14]],48));case 14:E=l(E,f([0,u[v+13]],40));case 13:E=l(E,f([0,u[v+12]],32));case 12:E=l(E,f([0,u[v+11]],24));case 11:E=l(E,f([0,u[v+10]],16));case 10:E=l(E,f([0,u[v+9]],8));case 9:E=l(E,[0,u[v+8]]),E=c(E,S),E=h(E,33),E=c(E,x),w=l(w,E);case 8:y=l(y,f([0,u[v+7]],56));case 7:y=l(y,f([0,u[v+6]],48));case 6:y=l(y,f([0,u[v+5]],40));case 5:y=l(y,f([0,u[v+4]],32));case 4:y=l(y,f([0,u[v+3]],24));case 3:y=l(y,f([0,u[v+2]],16));case 2:y=l(y,f([0,u[v+1]],8));case 1:y=l(y,[0,u[v]]),y=c(y,x),y=h(y,31),y=c(y,S),g=l(g,y)}return g=l(g,[0,u.length]),w=l(w,[0,u.length]),g=a(g,w),w=a(w,g),g=m(g),w=m(w),g=a(g,w),w=a(w,g),("00000000"+(g[0]>>>0).toString(16)).slice(-8)+("00000000"+(g[1]>>>0).toString(16)).slice(-8)+("00000000"+(w[0]>>>0).toString(16)).slice(-8)+("00000000"+(w[1]>>>0).toString(16)).slice(-8)},typeof Sn<"u"?(typeof Zs<"u"&&Zs.exports&&(Sn=Zs.exports=t),Sn.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)})(Sn)});var sa=gi((z1,ku)=>{ku.exports=Iu()});var E0={};ge(E0,{RELAY_V2_HOP_CODEC:()=>Ye,RELAY_V2_STOP_CODEC:()=>lr,circuitRelayServer:()=>Lu,circuitRelayTransport:()=>$u});var Ca=Symbol.for("@libp2p/peer-id");var Ua=Symbol.for("@libp2p/transport");var La;(function(r){r[r.FATAL_ALL=0]="FATAL_ALL",r[r.NO_FATAL=1]="NO_FATAL"})(La||(La={}));var Rt=class r extends Error{code;type;constructor(e="The operation was aborted"){super(e),this.name="AbortError",this.code=r.code,this.type=r.type}static code="ABORT_ERR";static type="aborted"},U=class extends Error{code;props;constructor(e,t,n){super(e),this.code=t,this.name=n?.name??"CodeError",this.props=n??{}}};var Ke=(r,...e)=>{try{[...e]}catch{}};var qe=class extends EventTarget{#e=new Map;constructor(){super(),Ke(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 af(e,t))}},yi=class extends Event{detail;constructor(e,t){super(e,t),this.detail=t?.detail}},af=globalThis.CustomEvent??yi;function Da(r){return r!=null&&typeof r.start=="function"&&typeof r.stop=="function"}async function Oa(...r){let e=[];for(let t of r)Da(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 Pa(...r){let e=[];for(let t of r)Da(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 Ei={};ge(Ei,{base58btc:()=>de,base58flickr:()=>df});var N0=new Uint8Array(0);function Ma(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 ht(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 Va(r){return new TextEncoder().encode(r)}function Ha(r){return new TextDecoder().decode(r)}function cf(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 l(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,b=0,g=0,w=d.length;g!==w&&d[g]===0;)g++,p++;for(var y=(w-g)*f+1>>>0,E=new Uint8Array(y);g!==w;){for(var x=d[g],S=0,v=y-1;(x!==0||S<b)&&v!==-1;v--,S++)x+=256*E[v]>>>0,E[v]=x%a>>>0,x=x/a>>>0;if(x!==0)throw new Error("Non-zero carry");b=S,g++}for(var B=y-b;B!==y&&E[B]===0;)B++;for(var $=c.repeat(p);B<y;++B)$+=r.charAt(E[B]);return $}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 b=0,g=0;d[p]===c;)b++,p++;for(var w=(d.length-p)*h+1>>>0,y=new Uint8Array(w);d[p];){var E=t[d.charCodeAt(p)];if(E===255)return;for(var x=0,S=w-1;(E!==0||x<g)&&S!==-1;S--,x++)E+=a*y[S]>>>0,y[S]=E%256>>>0,E=E/256>>>0;if(E!==0)throw new Error("Non-zero carry");g=x,p++}if(d[p]!==" "){for(var v=w-g;v!==w&&y[v]===0;)v++;for(var B=new Uint8Array(b+(w-v)),$=b;v!==w;)B[$++]=y[v++];return B}}}function u(d){var p=m(d);if(p)return p;throw new Error(`Non-${e} character`)}return{encode:l,decodeUnsafe:m,decode:u}}var lf=cf,uf=lf,Ka=uf;var bi=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){if(this.name=e,this.prefix=t,t.codePointAt(0)===void 0)throw new Error("Invalid prefix character");this.prefixCodePoint=t.codePointAt(0),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 qa(this,e)}},xi=class{decoders;constructor(e){this.decoders=e}or(e){return qa(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 qa(r,e){return new xi({...r.decoders??{[r.prefix]:r},...e.decoders??{[e.prefix]:e}})}var vi=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 bi(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 pr({name:r,prefix:e,encode:t,decode:n}){return new vi(r,e,t,n)}function Nt({name:r,prefix:e,alphabet:t}){let{encode:n,decode:s}=Ka(t,r);return pr({prefix:e,name:r,encode:n,decode:i=>ht(s(i))})}function ff(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 l=s[r[f]];if(l===void 0)throw new SyntaxError(`Non-${n} character`);c=c<<t|l,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 hf(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 oe({name:r,prefix:e,bitsPerChar:t,alphabet:n}){return pr({prefix:e,name:r,encode(s){return hf(s,n,t)},decode(s){return ff(s,n,t,r)}})}var de=Nt({name:"base58btc",prefix:"z",alphabet:"123456789ABCDEFGHJKLMNPQRSTUVWXYZabcdefghijkmnopqrstuvwxyz"}),df=Nt({name:"base58flickr",prefix:"Z",alphabet:"123456789abcdefghijkmnopqrstuvwxyzABCDEFGHJKLMNPQRSTUVWXYZ"});var Ai={};ge(Ai,{base10:()=>pf});var pf=Nt({prefix:"9",name:"base10",alphabet:"0123456789"});var Si={};ge(Si,{base16:()=>gf,base16upper:()=>mf});var gf=oe({prefix:"f",name:"base16",alphabet:"0123456789abcdef",bitsPerChar:4}),mf=oe({prefix:"F",name:"base16upper",alphabet:"0123456789ABCDEF",bitsPerChar:4});var Bi={};ge(Bi,{base2:()=>yf});var yf=oe({prefix:"0",name:"base2",alphabet:"01",bitsPerChar:1});var _i={};ge(_i,{base256emoji:()=>Ef});var za=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}"),bf=za.reduce((r,e,t)=>(r[t]=e,r),[]),wf=za.reduce((r,e,t)=>(r[e.codePointAt(0)]=t,r),[]);function xf(r){return r.reduce((e,t)=>(e+=bf[t],e),"")}function vf(r){let e=[];for(let t of r){let n=wf[t.codePointAt(0)];if(n===void 0)throw new Error(`Non-base256emoji character: ${t}`);e.push(n)}return new Uint8Array(e)}var Ef=pr({prefix:"\u{1F680}",name:"base256emoji",encode:xf,decode:vf});var Ii={};ge(Ii,{base32:()=>dt,base32hex:()=>_f,base32hexpad:()=>kf,base32hexpadupper:()=>Tf,base32hexupper:()=>If,base32pad:()=>Sf,base32padupper:()=>Bf,base32upper:()=>Af,base32z:()=>Rf});var dt=oe({prefix:"b",name:"base32",alphabet:"abcdefghijklmnopqrstuvwxyz234567",bitsPerChar:5}),Af=oe({prefix:"B",name:"base32upper",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZ234567",bitsPerChar:5}),Sf=oe({prefix:"c",name:"base32pad",alphabet:"abcdefghijklmnopqrstuvwxyz234567=",bitsPerChar:5}),Bf=oe({prefix:"C",name:"base32padupper",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZ234567=",bitsPerChar:5}),_f=oe({prefix:"v",name:"base32hex",alphabet:"0123456789abcdefghijklmnopqrstuv",bitsPerChar:5}),If=oe({prefix:"V",name:"base32hexupper",alphabet:"0123456789ABCDEFGHIJKLMNOPQRSTUV",bitsPerChar:5}),kf=oe({prefix:"t",name:"base32hexpad",alphabet:"0123456789abcdefghijklmnopqrstuv=",bitsPerChar:5}),Tf=oe({prefix:"T",name:"base32hexpadupper",alphabet:"0123456789ABCDEFGHIJKLMNOPQRSTUV=",bitsPerChar:5}),Rf=oe({prefix:"h",name:"base32z",alphabet:"ybndrfg8ejkmcpqxot1uwisza345h769",bitsPerChar:5});var ki={};ge(ki,{base36:()=>Nf,base36upper:()=>Cf});var Nf=Nt({prefix:"k",name:"base36",alphabet:"0123456789abcdefghijklmnopqrstuvwxyz"}),Cf=Nt({prefix:"K",name:"base36upper",alphabet:"0123456789ABCDEFGHIJKLMNOPQRSTUVWXYZ"});var Ri={};ge(Ri,{base64:()=>Ti,base64pad:()=>Lf,base64url:()=>Uf,base64urlpad:()=>Df});var Ti=oe({prefix:"m",name:"base64",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/",bitsPerChar:6}),Lf=oe({prefix:"M",name:"base64pad",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/=",bitsPerChar:6}),Uf=oe({prefix:"u",name:"base64url",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789-_",bitsPerChar:6}),Df=oe({prefix:"U",name:"base64urlpad",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789-_=",bitsPerChar:6});var Ni={};ge(Ni,{base8:()=>Of});var Of=oe({prefix:"7",name:"base8",alphabet:"01234567",bitsPerChar:3});var Ci={};ge(Ci,{identity:()=>Pf});var Pf=pr({prefix:"\0",name:"identity",encode:r=>Ha(r),decode:r=>Va(r)});var j0=new TextEncoder,W0=new TextDecoder;var Ui={};ge(Ui,{identity:()=>Ct});var Hf=ja,$a=128,Ff=127,Kf=~Ff,qf=Math.pow(2,31);function ja(r,e,t){e=e||[],t=t||0;for(var n=t;r>=qf;)e[t++]=r&255|$a,r/=128;for(;r&Kf;)e[t++]=r&255|$a,r>>>=7;return e[t]=r|0,ja.bytes=t-n+1,e}var zf=Li,$f=128,Ga=127;function Li(r,n){var t=0,n=n||0,s=0,i=n,o,a=r.length;do{if(i>=a)throw Li.bytes=0,new RangeError("Could not decode varint");o=r[i++],t+=s<28?(o&Ga)<<s:(o&Ga)*Math.pow(2,s),s+=7}while(o>=$f);return Li.bytes=i-n,t}var Gf=Math.pow(2,7),jf=Math.pow(2,14),Wf=Math.pow(2,21),Yf=Math.pow(2,28),Zf=Math.pow(2,35),Xf=Math.pow(2,42),Jf=Math.pow(2,49),Qf=Math.pow(2,56),eh=Math.pow(2,63),th=function(r){return r<Gf?1:r<jf?2:r<Wf?3:r<Yf?4:r<Zf?5:r<Xf?6:r<Jf?7:r<Qf?8:r<eh?9:10},rh={encode:Hf,decode:zf,encodingLength:th},nh=rh,Yr=nh;function Zr(r,e=0){return[Yr.decode(r,e),Yr.decode.bytes]}function gr(r,e,t=0){return Yr.encode(r,e,t),e}function mr(r){return Yr.encodingLength(r)}function nt(r,e){let t=e.byteLength,n=mr(r),s=n+mr(t),i=new Uint8Array(s+t);return gr(r,i,0),gr(t,i,n),i.set(e,s),new yr(r,t,e,i)}function Xt(r){let e=ht(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 yr(t,s,o,e)}function Wa(r,e){if(r===e)return!0;{let t=e;return r.code===t.code&&r.size===t.size&&t.bytes instanceof Uint8Array&&Ma(r.bytes,t.bytes)}}var yr=class{code;size;digest;bytes;constructor(e,t,n,s){this.code=e,this.size=t,this.digest=n,this.bytes=s}};var Ya=0,sh="identity",Za=ht;function ih(r){return nt(Ya,Za(r))}var Ct={code:Ya,name:sh,encode:Za,digest:ih};var Pi={};ge(Pi,{sha256:()=>me,sha512:()=>oh});function Oi({name:r,code:e,encode:t}){return new Di(r,e,t)}var Di=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?nt(this.code,t):t.then(n=>nt(this.code,n))}else throw Error("Unknown type, must be binary type")}};function Ja(r){return async e=>new Uint8Array(await crypto.subtle.digest(r,e))}var me=Oi({name:"sha2-256",code:18,encode:Ja("SHA-256")}),oh=Oi({name:"sha2-512",code:19,encode:Ja("SHA-512")});function Qa(r,e){let{bytes:t,version:n}=r;switch(n){case 0:return ch(t,Mi(r),e??de.encoder);default:return lh(t,Mi(r),e??dt.encoder)}}var ec=new WeakMap;function Mi(r){let e=ec.get(r);if(e==null){let t=new Map;return ec.set(r,t),t}return e}var ze=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!==Xr)throw new Error("Cannot convert a non dag-pb CID to CIDv0");if(t.code!==uh)throw new Error("Cannot convert non sha2-256 multihash CID to CIDv0");return r.createV0(t)}default:throw Error(`Can not convert CID version ${this.version} to version 0. This is a bug please report`)}}toV1(){switch(this.version){case 0:{let{code:e,digest:t}=this.multihash,n=nt(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&&Wa(e.multihash,n.multihash)}toString(e){return Qa(this,e)}toJSON(){return{"/":Qa(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??tc(n,s,i.bytes))}else if(t[fh]===!0){let{version:n,multihash:s,code:i}=t,o=Xt(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!==Xr)throw new Error(`Version 0 CID must use dag-pb (code: ${Xr}) block encoding`);return new r(e,t,n,n.bytes)}case 1:{let s=tc(e,t,n.bytes);return new r(e,t,n,s)}default:throw new Error("Invalid version")}}static createV0(e){return r.create(0,Xr,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=ht(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 yr(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[l,m]=Zr(e.subarray(t));return t+=m,l},s=n(),i=Xr;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]=ah(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 Mi(i).set(n,e),i}};function ah(r,e){switch(r[0]){case"Q":{let t=e??de;return[de.prefix,t.decode(`${de.prefix}${r}`)]}case de.prefix:{let t=e??de;return[de.prefix,t.decode(r)]}case dt.prefix:{let t=e??dt;return[dt.prefix,t.decode(r)]}default:{if(e==null)throw Error("To parse non base32 or base58btc encoded CID multibase decoder must be provided");return[r[0],e.decode(r)]}}}function ch(r,e,t){let{prefix:n}=t;if(n!==de.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 lh(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 Xr=112,uh=18;function tc(r,e,t){let n=mr(r),s=n+mr(e),i=new Uint8Array(s+t.byteLength);return gr(r,i,0),gr(e,i,n),i.set(t,s),i}var fh=Symbol.for("@ipld/js-cid/CID");var Lt={...Ci,...Bi,...Ni,...Ai,...Si,...Ii,...ki,...Ei,...Ri,..._i},gg={...Pi,...Ui};function ae(r,e){if(r===e)return!0;if(r.byteLength!==e.byteLength)return!1;for(let t=0;t<r.byteLength;t++)if(r[t]!==e[t])return!1;return!0}var hh=Symbol.for("nodejs.util.inspect.custom"),rc=Object.values(Lt).map(r=>r.decoder).reduce((r,e)=>r.or(e),Lt.identity.decoder),nc=114,Vi=36,Hi=37,Jr=class{type;multihash;privateKey;publicKey;string;constructor(e){this.type=e.type,this.multihash=e.multihash,this.privateKey=e.privateKey,Object.defineProperty(this,"string",{enumerable:!1,writable:!0})}get[Symbol.toStringTag](){return`PeerId(${this.toString()})`}[Ca]=!0;toString(){return this.string==null&&(this.string=de.encode(this.multihash.bytes).slice(1)),this.string}toCID(){return ze.createV1(nc,this.multihash)}toBytes(){return this.multihash.bytes}toJSON(){return this.toString()}equals(e){if(e==null)return!1;if(e instanceof Uint8Array)return ae(this.multihash.bytes,e);if(typeof e=="string")return Ut(e).equals(this);if(e?.multihash?.bytes!=null)return ae(this.multihash.bytes,e.multihash.bytes);throw new Error("not valid Id")}[hh](){return`PeerId(${this.toString()})`}},br=class extends Jr{type="RSA";publicKey;constructor(e){super({...e,type:"RSA"}),this.publicKey=e.publicKey}},wr=class extends Jr{type="Ed25519";publicKey;constructor(e){super({...e,type:"Ed25519"}),this.publicKey=e.multihash.digest}},xr=class extends Jr{type="secp256k1";publicKey;constructor(e){super({...e,type:"secp256k1"}),this.publicKey=e.multihash.digest}};function Ut(r,e){if(e=e??rc,r.charAt(0)==="1"||r.charAt(0)==="Q"){let t=Xt(de.decode(`z${r}`));return r.startsWith("12D")?new wr({multihash:t}):r.startsWith("16U")?new xr({multihash:t}):new br({multihash:t})}return Qr(rc.decode(r))}function Qr(r){try{let e=Xt(r);if(e.code===Ct.code){if(e.digest.length===Vi)return new wr({multihash:e});if(e.digest.length===Hi)return new xr({multihash:e})}if(e.code===me.code)return new br({multihash:e})}catch{return dh(ze.decode(r))}throw new Error("Supplied PeerID CID is invalid")}function dh(r){if(r==null||r.multihash==null||r.version==null||r.version===1&&r.code!==nc)throw new Error("Supplied PeerID CID is invalid");let e=r.multihash;if(e.code===me.code)return new br({multihash:r.multihash});if(e.code===Ct.code){if(e.digest.length===Vi)return new wr({multihash:r.multihash});if(e.digest.length===Hi)return new xr({multihash:r.multihash})}throw new Error("Supplied PeerID CID is invalid")}async function sc(r,e){return r.length===Vi?new wr({multihash:nt(Ct.code,r),privateKey:e}):r.length===Hi?new xr({multihash:nt(Ct.code,r),privateKey:e}):new br({multihash:await me.digest(r),publicKey:r,privateKey:e})}var Eo={};ge(Eo,{Ed25519PrivateKey:()=>ir,Ed25519PublicKey:()=>on,generateKeyPair:()=>Pd,generateKeyPairFromSeed:()=>Fc,unmarshalEd25519PrivateKey:()=>Dd,unmarshalEd25519PublicKey:()=>Od});function xe(r=0){return new Uint8Array(r)}function Ne(r=0){return new Uint8Array(r)}function ke(r,e){e==null&&(e=r.reduce((s,i)=>s+i.length,0));let t=Ne(e),n=0;for(let s of r)t.set(s,n),n+=s.length;return t}function oc(r,e,t,n){return{name:r,prefix:e,encoder:{name:r,prefix:e,encode:t},decoder:{decode:n}}}var ic=oc("utf8","u",r=>"u"+new TextDecoder("utf8").decode(r),r=>new TextEncoder().encode(r.substring(1))),Fi=oc("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=Ne(r.length);for(let t=0;t<r.length;t++)e[t]=r.charCodeAt(t);return e}),ph={utf8:ic,"utf-8":ic,hex:Lt.base16,latin1:Fi,ascii:Fi,binary:Fi,...Lt},Tn=ph;function V(r,e="utf8"){let t=Tn[e];if(t==null)throw new Error(`Unsupported encoding "${e}"`);return t.decoder.decode(`${t.prefix}${r}`)}function $e(r){return r==null?!1:typeof r.then=="function"&&typeof r.catch=="function"&&typeof r.finally=="function"}function vr(r){if(!Number.isSafeInteger(r)||r<0)throw new Error(`positive integer expected, not ${r}`)}function gh(r){return r instanceof Uint8Array||r!=null&&typeof r=="object"&&r.constructor.name==="Uint8Array"}function Er(r,...e){if(!gh(r))throw new Error("Uint8Array expected");if(e.length>0&&!e.includes(r.length))throw new Error(`Uint8Array expected of length ${e}, not of length=${r.length}`)}function Rn(r){if(typeof r!="function"||typeof r.create!="function")throw new Error("Hash should be wrapped by utils.wrapConstructor");vr(r.outputLen),vr(r.blockLen)}function Ar(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 ac(r,e){Er(r);let t=e.outputLen;if(r.length<t)throw new Error(`digestInto() expects output buffer of length at least ${t}`)}var Nn=typeof globalThis=="object"&&"crypto"in globalThis?globalThis.crypto:void 0;var Br=r=>new DataView(r.buffer,r.byteOffset,r.byteLength),Ze=(r,e)=>r<<32-e|r>>>e;var zg=new Uint8Array(new Uint32Array([287454020]).buffer)[0]===68;var mh=async()=>{};async function cc(r,e,t){let n=Date.now();for(let s=0;s<r;s++){t(s);let i=Date.now()-n;i>=0&&i<e||(await mh(),n+=i)}}function Ki(r){if(typeof r!="string")throw new Error(`utf8ToBytes expected string, got ${typeof r}`);return new Uint8Array(new TextEncoder().encode(r))}function Dt(r){return typeof r=="string"&&(r=Ki(r)),Er(r),r}function Cn(...r){let e=0;for(let n=0;n<r.length;n++){let s=r[n];Er(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 Sr=class{clone(){return this._cloneInto()}},yh={}.toString;function lc(r,e){if(e!==void 0&&yh.call(e)!=="[object Object]")throw new Error("Options should be object or undefined");return Object.assign(r,e)}function Ln(r){let e=n=>r().update(Dt(n)).digest(),t=r();return e.outputLen=t.outputLen,e.blockLen=t.blockLen,e.create=()=>r(),e}function _r(r=32){if(Nn&&typeof Nn.getRandomValues=="function")return Nn.getRandomValues(new Uint8Array(r));throw new Error("crypto.getRandomValues must be defined")}function bh(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 uc=(r,e,t)=>r&e^~r&t,fc=(r,e,t)=>r&e^r&t^e&t,Ir=class extends Sr{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=Br(this.buffer)}update(e){Ar(this);let{view:t,buffer:n,blockLen:s}=this;e=Dt(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=Br(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){Ar(this),ac(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 l=o;l<s;l++)t[l]=0;bh(n,s-8,BigInt(this.length*8),i),this.process(n,0);let a=Br(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 l=0;l<h;l++)a.setUint32(4*l,f[l],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),qi=BigInt(32);function hc(r,e=!1){return e?{h:Number(r&Un),l:Number(r>>qi&Un)}:{h:Number(r>>qi&Un)|0,l:Number(r&Un)|0}}function wh(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}=hc(r[s],e);[t[s],n[s]]=[i,o]}return[t,n]}var xh=(r,e)=>BigInt(r>>>0)<<qi|BigInt(e>>>0),vh=(r,e,t)=>r>>>t,Eh=(r,e,t)=>r<<32-t|e>>>t,Ah=(r,e,t)=>r>>>t|e<<32-t,Sh=(r,e,t)=>r<<32-t|e>>>t,Bh=(r,e,t)=>r<<64-t|e>>>t-32,_h=(r,e,t)=>r>>>t-32|e<<64-t,Ih=(r,e)=>e,kh=(r,e)=>r,Th=(r,e,t)=>r<<t|e>>>32-t,Rh=(r,e,t)=>e<<t|r>>>32-t,Nh=(r,e,t)=>e<<t-32|r>>>64-t,Ch=(r,e,t)=>r<<t-32|e>>>64-t;function Lh(r,e,t,n){let s=(e>>>0)+(n>>>0);return{h:r+t+(s/2**32|0)|0,l:s|0}}var Uh=(r,e,t)=>(r>>>0)+(e>>>0)+(t>>>0),Dh=(r,e,t,n)=>e+t+n+(r/2**32|0)|0,Oh=(r,e,t,n)=>(r>>>0)+(e>>>0)+(t>>>0)+(n>>>0),Ph=(r,e,t,n,s)=>e+t+n+s+(r/2**32|0)|0,Mh=(r,e,t,n,s)=>(r>>>0)+(e>>>0)+(t>>>0)+(n>>>0)+(s>>>0),Vh=(r,e,t,n,s,i)=>e+t+n+s+i+(r/2**32|0)|0;var Hh={fromBig:hc,split:wh,toBig:xh,shrSH:vh,shrSL:Eh,rotrSH:Ah,rotrSL:Sh,rotrBH:Bh,rotrBL:_h,rotr32H:Ih,rotr32L:kh,rotlSH:Th,rotlSL:Rh,rotlBH:Nh,rotlBL:Ch,add:Lh,add3L:Uh,add3H:Dh,add4L:Oh,add4H:Ph,add5H:Vh,add5L:Mh},M=Hh;var[Fh,Kh]=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))),Ot=new Uint32Array(80),Pt=new Uint32Array(80),zi=class extends Ir{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:l,Fl:m,Gh:u,Gl:d,Hh:p,Hl:b}=this;return[e,t,n,s,i,o,a,c,h,f,l,m,u,d,p,b]}set(e,t,n,s,i,o,a,c,h,f,l,m,u,d,p,b){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=l|0,this.Fl=m|0,this.Gh=u|0,this.Gl=d|0,this.Hh=p|0,this.Hl=b|0}process(e,t){for(let y=0;y<16;y++,t+=4)Ot[y]=e.getUint32(t),Pt[y]=e.getUint32(t+=4);for(let y=16;y<80;y++){let E=Ot[y-15]|0,x=Pt[y-15]|0,S=M.rotrSH(E,x,1)^M.rotrSH(E,x,8)^M.shrSH(E,x,7),v=M.rotrSL(E,x,1)^M.rotrSL(E,x,8)^M.shrSL(E,x,7),B=Ot[y-2]|0,$=Pt[y-2]|0,q=M.rotrSH(B,$,19)^M.rotrBH(B,$,61)^M.shrSH(B,$,6),P=M.rotrSL(B,$,19)^M.rotrBL(B,$,61)^M.shrSL(B,$,6),te=M.add4L(v,P,Pt[y-7],Pt[y-16]),C=M.add4H(te,S,q,Ot[y-7],Ot[y-16]);Ot[y]=C|0,Pt[y]=te|0}let{Ah:n,Al:s,Bh:i,Bl:o,Ch:a,Cl:c,Dh:h,Dl:f,Eh:l,El:m,Fh:u,Fl:d,Gh:p,Gl:b,Hh:g,Hl:w}=this;for(let y=0;y<80;y++){let E=M.rotrSH(l,m,14)^M.rotrSH(l,m,18)^M.rotrBH(l,m,41),x=M.rotrSL(l,m,14)^M.rotrSL(l,m,18)^M.rotrBL(l,m,41),S=l&u^~l&p,v=m&d^~m&b,B=M.add5L(w,x,v,Kh[y],Pt[y]),$=M.add5H(B,g,E,S,Fh[y],Ot[y]),q=B|0,P=M.rotrSH(n,s,28)^M.rotrBH(n,s,34)^M.rotrBH(n,s,39),te=M.rotrSL(n,s,28)^M.rotrBL(n,s,34)^M.rotrBL(n,s,39),C=n&i^n&a^i&a,Fe=s&o^s&c^o&c;g=p|0,w=b|0,p=u|0,b=d|0,u=l|0,d=m|0,{h:l,l:m}=M.add(h|0,f|0,$|0,q|0),h=a|0,f=c|0,a=i|0,c=o|0,i=n|0,o=s|0;let _=M.add3L(q,te,Fe);n=M.add3H(_,$,P,C),s=_|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:l,l:m}=M.add(this.Eh|0,this.El|0,l|0,m|0),{h:u,l:d}=M.add(this.Fh|0,this.Fl|0,u|0,d|0),{h:p,l:b}=M.add(this.Gh|0,this.Gl|0,p|0,b|0),{h:g,l:w}=M.add(this.Hh|0,this.Hl|0,g|0,w|0),this.set(n,s,i,o,a,c,h,f,l,m,u,d,p,b,g,w)}roundClean(){Ot.fill(0),Pt.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 kr=Ln(()=>new zi);var On={};ge(On,{abytes:()=>Tr,bitGet:()=>Yh,bitLen:()=>Wh,bitMask:()=>en,bitSet:()=>Zh,bytesToHex:()=>gt,bytesToNumberBE:()=>mt,bytesToNumberLE:()=>Vt,concatBytes:()=>yt,createHmacDrbg:()=>ji,ensureBytes:()=>ce,equalBytes:()=>Gh,hexToBytes:()=>Qt,hexToNumber:()=>Gi,isBytes:()=>Mt,numberToBytesBE:()=>Ht,numberToBytesLE:()=>er,numberToHexUnpadded:()=>mc,numberToVarBytesBE:()=>$h,utf8ToBytes:()=>jh,validateObject:()=>st});var gc=BigInt(0),Dn=BigInt(1),qh=BigInt(2);function Mt(r){return r instanceof Uint8Array||r!=null&&typeof r=="object"&&r.constructor.name==="Uint8Array"}function Tr(r){if(!Mt(r))throw new Error("Uint8Array expected")}var zh=Array.from({length:256},(r,e)=>e.toString(16).padStart(2,"0"));function gt(r){Tr(r);let e="";for(let t=0;t<r.length;t++)e+=zh[r[t]];return e}function mc(r){let e=r.toString(16);return e.length&1?`0${e}`:e}function Gi(r){if(typeof r!="string")throw new Error("hex string expected, got "+typeof r);return BigInt(r===""?"0":`0x${r}`)}var pt={_0:48,_9:57,_A:65,_F:70,_a:97,_f:102};function dc(r){if(r>=pt._0&&r<=pt._9)return r-pt._0;if(r>=pt._A&&r<=pt._F)return r-(pt._A-10);if(r>=pt._a&&r<=pt._f)return r-(pt._a-10)}function Qt(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("padded 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=dc(r.charCodeAt(i)),a=dc(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 mt(r){return Gi(gt(r))}function Vt(r){return Tr(r),Gi(gt(Uint8Array.from(r).reverse()))}function Ht(r,e){return Qt(r.toString(16).padStart(e*2,"0"))}function er(r,e){return Ht(r,e).reverse()}function $h(r){return Qt(mc(r))}function ce(r,e,t){let n;if(typeof e=="string")try{n=Qt(e)}catch(i){throw new Error(`${r} must be valid hex string, got "${e}". Cause: ${i}`)}else if(Mt(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} expected ${t} bytes, got ${s}`);return n}function yt(...r){let e=0;for(let n=0;n<r.length;n++){let s=r[n];Tr(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 Gh(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 jh(r){if(typeof r!="string")throw new Error(`utf8ToBytes expected string, got ${typeof r}`);return new Uint8Array(new TextEncoder().encode(r))}function Wh(r){let e;for(e=0;r>gc;r>>=Dn,e+=1);return e}function Yh(r,e){return r>>BigInt(e)&Dn}function Zh(r,e,t){return r|(t?Dn:gc)<<BigInt(e)}var en=r=>(qh<<BigInt(r-1))-Dn,$i=r=>new Uint8Array(r),pc=r=>Uint8Array.from(r);function ji(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=$i(r),s=$i(r),i=0,o=()=>{n.fill(1),s.fill(0),i=0},a=(...l)=>t(s,n,...l),c=(l=$i())=>{s=a(pc([0]),l),n=a(),l.length!==0&&(s=a(pc([1]),l),n=a())},h=()=>{if(i++>=1e3)throw new Error("drbg: tried 1000 values");let l=0,m=[];for(;l<e;){n=a();let u=n.slice();m.push(u),l+=n.length}return yt(...m)};return(l,m)=>{o(),c(l);let u;for(;!(u=m(h()));)c();return o(),u}}var Xh={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"||Mt(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 st(r,e,t={}){let n=(s,i,o)=>{let a=Xh[i];if(typeof a!="function")throw new Error(`Invalid validator "${i}", expected function`);let c=r[s];if(!(o&&c===void 0)&&!a(c,r))throw new Error(`Invalid param ${String(s)}=${c} (${typeof c}), expected ${i}`)};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 pe=BigInt(0),re=BigInt(1),tr=BigInt(2),Jh=BigInt(3),Wi=BigInt(4),yc=BigInt(5),bc=BigInt(8),Qh=BigInt(9),ed=BigInt(16);function Q(r,e){let t=r%e;return t>=pe?t:e+t}function td(r,e,t){if(t<=pe||e<pe)throw new Error("Expected power/modulo > 0");if(t===re)return pe;let n=re;for(;e>pe;)e&re&&(n=n*r%t),r=r*r%t,e>>=re;return n}function ne(r,e,t){let n=r;for(;e-- >pe;)n*=n,n%=t;return n}function Pn(r,e){if(r===pe||e<=pe)throw new Error(`invert: expected positive integers, got n=${r} mod=${e}`);let t=Q(r,e),n=e,s=pe,i=re,o=re,a=pe;for(;t!==pe;){let h=n/t,f=n%t,l=s-o*h,m=i-a*h;n=t,t=f,s=o,i=a,o=l,a=m}if(n!==re)throw new Error("invert: does not exist");return Q(s,e)}function rd(r){let e=(r-re)/tr,t,n,s;for(t=r-re,n=0;t%tr===pe;t/=tr,n++);for(s=tr;s<r&&td(s,e,r)!==r-re;s++);if(n===1){let o=(r+re)/Wi;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+re)/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),l=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 u=1;for(let p=a.sqr(m);u<h&&!a.eql(p,a.ONE);u++)p=a.sqr(p);let d=a.pow(f,re<<BigInt(h-u-1));f=a.sqr(d),l=a.mul(l,d),m=a.mul(m,f),h=u}return l}}function nd(r){if(r%Wi===Jh){let e=(r+re)/Wi;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%bc===yc){let e=(r-yc)/bc;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%ed,rd(r)}var wc=(r,e)=>(Q(r,e)&re)===re,sd=["create","isValid","is0","neg","inv","sqrt","sqr","eql","add","sub","mul","pow","div","addN","subN","mulN","sqrN"];function Yi(r){let e={ORDER:"bigint",MASK:"bigint",BYTES:"isSafeInteger",BITS:"isSafeInteger"},t=sd.reduce((n,s)=>(n[s]="function",n),e);return st(r,t)}function id(r,e,t){if(t<pe)throw new Error("Expected power > 0");if(t===pe)return r.ONE;if(t===re)return e;let n=r.ONE,s=e;for(;t>pe;)t&re&&(n=r.mul(n,s)),s=r.sqr(s),t>>=re;return n}function od(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 Zi(r,e){let t=e!==void 0?e:r.toString(2).length,n=Math.ceil(t/8);return{nBitLength:t,nByteLength:n}}function Mn(r,e,t=!1,n={}){if(r<=pe)throw new Error(`Expected Field ORDER > 0, got ${r}`);let{nBitLength:s,nByteLength:i}=Zi(r,e);if(i>2048)throw new Error("Field lengths over 2048 bytes are not supported");let o=nd(r),a=Object.freeze({ORDER:r,BITS:s,BYTES:i,MASK:en(s),ZERO:pe,ONE:re,create:c=>Q(c,r),isValid:c=>{if(typeof c!="bigint")throw new Error(`Invalid field element: expected bigint, got ${typeof c}`);return pe<=c&&c<r},is0:c=>c===pe,isOdd:c=>(c&re)===re,neg:c=>Q(-c,r),eql:(c,h)=>c===h,sqr:c=>Q(c*c,r),add:(c,h)=>Q(c+h,r),sub:(c,h)=>Q(c-h,r),mul:(c,h)=>Q(c*h,r),pow:(c,h)=>id(a,c,h),div:(c,h)=>Q(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(a,c)),invertBatch:c=>od(a,c),cmov:(c,h,f)=>f?h:c,toBytes:c=>t?er(c,i):Ht(c,i),fromBytes:c=>{if(c.length!==i)throw new Error(`Fp.fromBytes: expected ${i}, got ${c.length}`);return t?Vt(c):mt(c)}});return Object.freeze(a)}function xc(r,e){if(!r.isOdd)throw new Error("Field doesn't have isOdd");let t=r.sqrt(e);return r.isOdd(t)?r.neg(t):t}function vc(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 Xi(r){let e=vc(r);return e+Math.ceil(e/2)}function Ec(r,e,t=!1){let n=r.length,s=vc(e),i=Xi(e);if(n<16||n<i||n>1024)throw new Error(`expected ${i}-1024 bytes of input, got ${n}`);let o=t?mt(r):Vt(r),a=Q(o,e-re)+re;return t?er(a,s):Ht(a,s)}var cd=BigInt(0),Ji=BigInt(1);function Vn(r,e){let t=(s,i)=>{let o=i.negate();return s?o:i},n=s=>{let i=Math.ceil(e/s)+1,o=2**(s-1);return{windows:i,windowSize:o}};return{constTimeNegate:t,unsafeLadder(s,i){let o=r.ZERO,a=s;for(;i>cd;)i&Ji&&(o=o.add(a)),a=a.double(),i>>=Ji;return o},precomputeWindow(s,i){let{windows:o,windowSize:a}=n(i),c=[],h=s,f=h;for(let l=0;l<o;l++){f=h,c.push(f);for(let m=1;m<a;m++)f=f.add(h),c.push(f);h=f.double()}return c},wNAF(s,i,o){let{windows:a,windowSize:c}=n(s),h=r.ZERO,f=r.BASE,l=BigInt(2**s-1),m=2**s,u=BigInt(s);for(let d=0;d<a;d++){let p=d*c,b=Number(o&l);o>>=u,b>c&&(b-=m,o+=Ji);let g=p,w=p+Math.abs(b)-1,y=d%2!==0,E=b<0;b===0?f=f.add(t(y,i[g])):h=h.add(t(E,i[w]))}return{p:h,f}},wNAFCached(s,i,o,a){let c=s._WINDOW_SIZE||1,h=i.get(s);return h||(h=this.precomputeWindow(s,c),c!==1&&i.set(s,a(h))),this.wNAF(c,h,o)}}}function tn(r){return Yi(r.Fp),st(r,{n:"bigint",h:"bigint",Gx:"field",Gy:"field"},{nBitLength:"isSafeInteger",nByteLength:"isSafeInteger"}),Object.freeze({...Zi(r.n,r.nBitLength),...r,p:r.Fp.ORDER})}var Xe=BigInt(0),Le=BigInt(1),Hn=BigInt(2),ld=BigInt(8),ud={zip215:!0};function fd(r){let e=tn(r);return st(r,{hash:"function",a:"bigint",d:"bigint",randomBytes:"function"},{adjustScalarBytes:"function",domain:"function",uvRatio:"function",mapToCurve:"function"}),Object.freeze({...e})}function Fn(r){let e=fd(r),{Fp:t,n,prehash:s,hash:i,randomBytes:o,nByteLength:a,h:c}=e,h=Hn<<BigInt(a*8)-Le,f=t.create,l=e.uvRatio||((I,A)=>{try{return{isValid:!0,value:t.sqrt(I*t.inv(A))}}catch{return{isValid:!1,value:Xe}}}),m=e.adjustScalarBytes||(I=>I),u=e.domain||((I,A,R)=>{if(A.length||R)throw new Error("Contexts/pre-hash are not supported");return I}),d=I=>typeof I=="bigint"&&Xe<I,p=(I,A)=>d(I)&&d(A)&&I<A,b=I=>I===Xe||p(I,h);function g(I,A){if(p(I,A))return I;throw new Error(`Expected valid scalar < ${A}, got ${typeof I} ${I}`)}function w(I){return I===Xe?I:g(I,n)}let y=new Map;function E(I){if(!(I instanceof x))throw new Error("ExtendedPoint expected")}class x{constructor(A,R,L,O){if(this.ex=A,this.ey=R,this.ez=L,this.et=O,!b(A))throw new Error("x required");if(!b(R))throw new Error("y required");if(!b(L))throw new Error("z required");if(!b(O))throw new Error("t required")}get x(){return this.toAffine().x}get y(){return this.toAffine().y}static fromAffine(A){if(A instanceof x)throw new Error("extended point not allowed");let{x:R,y:L}=A||{};if(!b(R)||!b(L))throw new Error("invalid affine point");return new x(R,L,Le,f(R*L))}static normalizeZ(A){let R=t.invertBatch(A.map(L=>L.ez));return A.map((L,O)=>L.toAffine(R[O])).map(x.fromAffine)}_setWindowSize(A){this._WINDOW_SIZE=A,y.delete(this)}assertValidity(){let{a:A,d:R}=e;if(this.is0())throw new Error("bad point: ZERO");let{ex:L,ey:O,ez:F,et:K}=this,Y=f(L*L),j=f(O*O),W=f(F*F),ue=f(W*W),ie=f(Y*A),be=f(W*f(ie+j)),we=f(ue+f(R*f(Y*j)));if(be!==we)throw new Error("bad point: equation left != right (1)");let he=f(L*O),Ae=f(F*K);if(he!==Ae)throw new Error("bad point: equation left != right (2)")}equals(A){E(A);let{ex:R,ey:L,ez:O}=this,{ex:F,ey:K,ez:Y}=A,j=f(R*Y),W=f(F*O),ue=f(L*Y),ie=f(K*O);return j===W&&ue===ie}is0(){return this.equals(x.ZERO)}negate(){return new x(f(-this.ex),this.ey,this.ez,f(-this.et))}double(){let{a:A}=e,{ex:R,ey:L,ez:O}=this,F=f(R*R),K=f(L*L),Y=f(Hn*f(O*O)),j=f(A*F),W=R+L,ue=f(f(W*W)-F-K),ie=j+K,be=ie-Y,we=j-K,he=f(ue*be),Ae=f(ie*we),ft=f(ue*we),Zt=f(be*ie);return new x(he,Ae,Zt,ft)}add(A){E(A);let{a:R,d:L}=e,{ex:O,ey:F,ez:K,et:Y}=this,{ex:j,ey:W,ez:ue,et:ie}=A;if(R===BigInt(-1)){let Sa=f((F-O)*(W+j)),Ba=f((F+O)*(W-j)),pi=f(Ba-Sa);if(pi===Xe)return this.double();let _a=f(K*Hn*ie),Ia=f(Y*Hn*ue),ka=Ia+_a,Ta=Ba+Sa,Ra=Ia-_a,Zu=f(ka*pi),Xu=f(Ta*Ra),Ju=f(ka*Ra),Qu=f(pi*Ta);return new x(Zu,Xu,Qu,Ju)}let be=f(O*j),we=f(F*W),he=f(Y*L*ie),Ae=f(K*ue),ft=f((O+F)*(j+W)-be-we),Zt=Ae-he,Wr=Ae+he,Aa=f(we-R*be),Gu=f(ft*Zt),ju=f(Wr*Aa),Wu=f(ft*Aa),Yu=f(Zt*Wr);return new x(Gu,ju,Yu,Wu)}subtract(A){return this.add(A.negate())}wNAF(A){return B.wNAFCached(this,y,A,x.normalizeZ)}multiply(A){let{p:R,f:L}=this.wNAF(g(A,n));return x.normalizeZ([R,L])[0]}multiplyUnsafe(A){let R=w(A);return R===Xe?v:this.equals(v)||R===Le?this:this.equals(S)?this.wNAF(R).p:B.unsafeLadder(this,R)}isSmallOrder(){return this.multiplyUnsafe(c).is0()}isTorsionFree(){return B.unsafeLadder(this,n).is0()}toAffine(A){let{ex:R,ey:L,ez:O}=this,F=this.is0();A==null&&(A=F?ld:t.inv(O));let K=f(R*A),Y=f(L*A),j=f(O*A);if(F)return{x:Xe,y:Le};if(j!==Le)throw new Error("invZ was invalid");return{x:K,y:Y}}clearCofactor(){let{h:A}=e;return A===Le?this:this.multiplyUnsafe(A)}static fromHex(A,R=!1){let{d:L,a:O}=e,F=t.BYTES;A=ce("pointHex",A,F);let K=A.slice(),Y=A[F-1];K[F-1]=Y&-129;let j=Vt(K);j===Xe||(R?g(j,h):g(j,t.ORDER));let W=f(j*j),ue=f(W-Le),ie=f(L*W-O),{isValid:be,value:we}=l(ue,ie);if(!be)throw new Error("Point.fromHex: invalid y coordinate");let he=(we&Le)===Le,Ae=(Y&128)!==0;if(!R&&we===Xe&&Ae)throw new Error("Point.fromHex: x=0 and x_0=1");return Ae!==he&&(we=f(-we)),x.fromAffine({x:we,y:j})}static fromPrivateKey(A){return P(A).point}toRawBytes(){let{x:A,y:R}=this.toAffine(),L=er(R,t.BYTES);return L[L.length-1]|=A&Le?128:0,L}toHex(){return gt(this.toRawBytes())}}x.BASE=new x(e.Gx,e.Gy,Le,f(e.Gx*e.Gy)),x.ZERO=new x(Xe,Le,Le,Xe);let{BASE:S,ZERO:v}=x,B=Vn(x,a*8);function $(I){return Q(I,n)}function q(I){return $(Vt(I))}function P(I){let A=a;I=ce("private key",I,A);let R=ce("hashed private key",i(I),2*A),L=m(R.slice(0,A)),O=R.slice(A,2*A),F=q(L),K=S.multiply(F),Y=K.toRawBytes();return{head:L,prefix:O,scalar:F,point:K,pointBytes:Y}}function te(I){return P(I).pointBytes}function C(I=new Uint8Array,...A){let R=yt(...A);return q(i(u(R,ce("context",I),!!s)))}function Fe(I,A,R={}){I=ce("message",I),s&&(I=s(I));let{prefix:L,scalar:O,pointBytes:F}=P(A),K=C(R.context,L,I),Y=S.multiply(K).toRawBytes(),j=C(R.context,Y,F,I),W=$(K+j*O);w(W);let ue=yt(Y,er(W,t.BYTES));return ce("result",ue,a*2)}let _=ud;function N(I,A,R,L=_){let{context:O,zip215:F}=L,K=t.BYTES;I=ce("signature",I,2*K),A=ce("message",A),s&&(A=s(A));let Y=Vt(I.slice(K,2*K)),j,W,ue;try{j=x.fromHex(R,F),W=x.fromHex(I.slice(0,K),F),ue=S.multiplyUnsafe(Y)}catch{return!1}if(!F&&j.isSmallOrder())return!1;let ie=C(O,W.toRawBytes(),j.toRawBytes(),A);return W.add(j.multiplyUnsafe(ie)).subtract(ue).clearCofactor().equals(x.ZERO)}return S._setWindowSize(8),{CURVE:e,getPublicKey:te,sign:Fe,verify:N,ExtendedPoint:x,utils:{getExtendedPublicKey:P,randomPrivateKey:()=>o(t.BYTES),precompute(I=8,A=x.BASE){return A._setWindowSize(I),A.multiply(BigInt(3)),A}}}}var eo=BigInt("57896044618658097711785492504343953926634992332820282019728792003956564819949"),Ac=BigInt("19681161376707505956807079304988542015446066515923890162744021073123829784752"),hm=BigInt(0),hd=BigInt(1),Qi=BigInt(2),dd=BigInt(5),Sc=BigInt(10),pd=BigInt(20),gd=BigInt(40),Bc=BigInt(80);function md(r){let e=eo,n=r*r%e*r%e,s=ne(n,Qi,e)*n%e,i=ne(s,hd,e)*r%e,o=ne(i,dd,e)*i%e,a=ne(o,Sc,e)*o%e,c=ne(a,pd,e)*a%e,h=ne(c,gd,e)*c%e,f=ne(h,Bc,e)*h%e,l=ne(f,Bc,e)*h%e,m=ne(l,Sc,e)*o%e;return{pow_p_5_8:ne(m,Qi,e)*r%e,b2:n}}function yd(r){return r[0]&=248,r[31]&=127,r[31]|=64,r}function bd(r,e){let t=eo,n=Q(e*e*e,t),s=Q(n*n*e,t),i=md(r*s).pow_p_5_8,o=Q(r*n*i,t),a=Q(e*o*o,t),c=o,h=Q(o*Ac,t),f=a===r,l=a===Q(-r,t),m=a===Q(-r*Ac,t);return f&&(o=c),(l||m)&&(o=h),wc(o,t)&&(o=Q(-o,t)),{isValid:f||l,value:o}}var bt=Mn(eo,void 0,!0),to={a:BigInt(-1),d:BigInt("37095705934669439343138083508754565189542113879843219016388785533085940283555"),Fp:bt,n:BigInt("7237005577332262213973186563042994240857116359379907606001950938285454250989"),h:BigInt(8),Gx:BigInt("15112221349535400772501151409588531511454012693041857206046113283949847762202"),Gy:BigInt("46316835694926478169428394003475163141307993866256225615783033603165251855960"),hash:kr,randomBytes:_r,adjustScalarBytes:yd,uvRatio:bd},Rr=Fn(to);function _c(r,e,t){if(e.length>255)throw new Error("Context is too big");return Cn(Ki("SigEd25519 no Ed25519 collisions"),new Uint8Array([t?1:0,e.length]),e,r)}var dm=Fn({...to,domain:_c}),pm=Fn({...to,domain:_c,prehash:kr});var wd=(bt.ORDER+BigInt(3))/BigInt(8),gm=bt.pow(Qi,wd),mm=bt.sqrt(bt.neg(bt.ONE)),ym=(bt.ORDER-BigInt(5))/BigInt(8),bm=BigInt(486662);var wm=xc(bt,bt.neg(BigInt(486664)));var xm=BigInt("25063068953384623474111414158702152701244531502492656460079210482610430750235"),vm=BigInt("54469307008909316920995813868745141605393597292927456921205312896311721017578"),Em=BigInt("1159843021668779879193775521855586647937357759715417654439879720876111806838"),Am=BigInt("40440834346308536858101042469323190826248399146238708352240133220865137265952");var Sm=BigInt("0x7fffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffff");var Nr=32,wt=64,Kn=32;function Ic(){let r=Rr.utils.randomPrivateKey(),e=Rr.getPublicKey(r);return{privateKey:Nc(r,e),publicKey:e}}function kc(r){if(r.length!==Kn)throw new TypeError('"seed" must be 32 bytes in length.');if(!(r instanceof Uint8Array))throw new TypeError('"seed" must be a node.js Buffer, or Uint8Array.');let e=r,t=Rr.getPublicKey(e);return{privateKey:Nc(e,t),publicKey:t}}function Tc(r,e){let t=r.subarray(0,Kn);return Rr.sign(e instanceof Uint8Array?e:e.subarray(),t)}function Rc(r,e,t){return Rr.verify(e,t instanceof Uint8Array?t:t.subarray(),r)}function Nc(r,e){let t=new Uint8Array(wt);for(let n=0;n<Kn;n++)t[n]=r[n],t[Kn+n]=e[n];return t}var Te={get(r=globalThis){let e=r.crypto;if(e==null||e.subtle==null)throw Object.assign(new Error("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"),{code:"ERR_MISSING_WEB_CRYPTO"});return e}};var ro={alg:"A128GCM",ext:!0,k:"scm9jmO_4BJAgdwWGVulLg",key_ops:["encrypt","decrypt"],kty:"oct"};function Cc(r){let e=r?.algorithm??"AES-GCM",t=r?.keyLength??16,n=r?.nonceLength??12,s=r?.digest??"SHA-256",i=r?.saltLength??16,o=r?.iterations??32767,a=Te.get();t*=8;async function c(l,m){let u=a.getRandomValues(new Uint8Array(i)),d=a.getRandomValues(new Uint8Array(n)),p={name:e,iv:d};typeof m=="string"&&(m=V(m));let b;if(m.length===0){b=await a.subtle.importKey("jwk",ro,{name:"AES-GCM"},!0,["encrypt"]);try{let w={name:"PBKDF2",salt:u,iterations:o,hash:{name:s}},y=await a.subtle.importKey("raw",m,{name:"PBKDF2"},!1,["deriveKey"]);b=await a.subtle.deriveKey(w,y,{name:e,length:t},!0,["encrypt"])}catch{b=await a.subtle.importKey("jwk",ro,{name:"AES-GCM"},!0,["encrypt"])}}else{let w={name:"PBKDF2",salt:u,iterations:o,hash:{name:s}},y=await a.subtle.importKey("raw",m,{name:"PBKDF2"},!1,["deriveKey"]);b=await a.subtle.deriveKey(w,y,{name:e,length:t},!0,["encrypt"])}let g=await a.subtle.encrypt(p,b,l);return ke([u,p.iv,new Uint8Array(g)])}async function h(l,m){let u=l.subarray(0,i),d=l.subarray(i,i+n),p=l.subarray(i+n),b={name:e,iv:d};typeof m=="string"&&(m=V(m));let g;if(m.length===0)try{let y={name:"PBKDF2",salt:u,iterations:o,hash:{name:s}},E=await a.subtle.importKey("raw",m,{name:"PBKDF2"},!1,["deriveKey"]);g=await a.subtle.deriveKey(y,E,{name:e,length:t},!0,["decrypt"])}catch{g=await a.subtle.importKey("jwk",ro,{name:"AES-GCM"},!0,["decrypt"])}else{let y={name:"PBKDF2",salt:u,iterations:o,hash:{name:s}},E=await a.subtle.importKey("raw",m,{name:"PBKDF2"},!1,["deriveKey"]);g=await a.subtle.deriveKey(y,E,{name:e,length:t},!0,["decrypt"])}let w=await a.subtle.decrypt(b,g,p);return new Uint8Array(w)}return{encrypt:c,decrypt:h}}async function Cr(r,e){let n=await Cc().encrypt(r,e);return Ti.encode(n)}var Ed=Math.pow(2,7),Ad=Math.pow(2,14),Sd=Math.pow(2,21),no=Math.pow(2,28),so=Math.pow(2,35),io=Math.pow(2,42),oo=Math.pow(2,49),Z=128,Se=127;function Be(r){if(r<Ed)return 1;if(r<Ad)return 2;if(r<Sd)return 3;if(r<no)return 4;if(r<so)return 5;if(r<io)return 6;if(r<oo)return 7;if(Number.MAX_SAFE_INTEGER!=null&&r>Number.MAX_SAFE_INTEGER)throw new RangeError("Could not encode varint");return 8}function ao(r,e,t=0){switch(Be(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 Bd(r,e,t=0){switch(Be(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 co(r,e){let t=r[e],n=0;if(n+=t&Se,t<Z||(t=r[e+1],n+=(t&Se)<<7,t<Z)||(t=r[e+2],n+=(t&Se)<<14,t<Z)||(t=r[e+3],n+=(t&Se)<<21,t<Z)||(t=r[e+4],n+=(t&Se)*no,t<Z)||(t=r[e+5],n+=(t&Se)*so,t<Z)||(t=r[e+6],n+=(t&Se)*io,t<Z)||(t=r[e+7],n+=(t&Se)*oo,t<Z))return n;throw new RangeError("Could not decode varint")}function _d(r,e){let t=r.get(e),n=0;if(n+=t&Se,t<Z||(t=r.get(e+1),n+=(t&Se)<<7,t<Z)||(t=r.get(e+2),n+=(t&Se)<<14,t<Z)||(t=r.get(e+3),n+=(t&Se)<<21,t<Z)||(t=r.get(e+4),n+=(t&Se)*no,t<Z)||(t=r.get(e+5),n+=(t&Se)*so,t<Z)||(t=r.get(e+6),n+=(t&Se)*io,t<Z)||(t=r.get(e+7),n+=(t&Se)*oo,t<Z))return n;throw new RangeError("Could not decode varint")}function Ge(r,e,t=0){return e==null&&(e=Ne(Be(r))),e instanceof Uint8Array?ao(r,e,t):Bd(r,e,t)}function xt(r,e=0){return r instanceof Uint8Array?co(r,e):_d(r,e)}var lo=new Float32Array([-0]),Ft=new Uint8Array(lo.buffer);function Lc(r,e,t){lo[0]=r,e[t]=Ft[0],e[t+1]=Ft[1],e[t+2]=Ft[2],e[t+3]=Ft[3]}function Uc(r,e){return Ft[0]=r[e],Ft[1]=r[e+1],Ft[2]=r[e+2],Ft[3]=r[e+3],lo[0]}var uo=new Float64Array([-0]),_e=new Uint8Array(uo.buffer);function Dc(r,e,t){uo[0]=r,e[t]=_e[0],e[t+1]=_e[1],e[t+2]=_e[2],e[t+3]=_e[3],e[t+4]=_e[4],e[t+5]=_e[5],e[t+6]=_e[6],e[t+7]=_e[7]}function Oc(r,e){return _e[0]=r[e],_e[1]=r[e+1],_e[2]=r[e+2],_e[3]=r[e+3],_e[4]=r[e+4],_e[5]=r[e+5],_e[6]=r[e+6],_e[7]=r[e+7],uo[0]}var Id=BigInt(Number.MAX_SAFE_INTEGER),kd=BigInt(Number.MIN_SAFE_INTEGER),Ue=class r{lo;hi;constructor(e,t){this.lo=e|0,this.hi=t|0}toNumber(e=!1){if(!e&&this.hi>>>31>0){let t=~this.lo+1>>>0,n=~this.hi>>>0;return t===0&&(n=n+1>>>0),-(t+n*4294967296)}return this.lo+this.hi*4294967296}toBigInt(e=!1){if(e)return BigInt(this.lo>>>0)+(BigInt(this.hi>>>0)<<32n);if(this.hi>>>31){let t=~this.lo+1>>>0,n=~this.hi>>>0;return t===0&&(n=n+1>>>0),-(BigInt(t)+(BigInt(n)<<32n))}return BigInt(this.lo>>>0)+(BigInt(this.hi>>>0)<<32n)}toString(e=!1){return this.toBigInt(e).toString()}zzEncode(){let e=this.hi>>31;return this.hi=((this.hi<<1|this.lo>>>31)^e)>>>0,this.lo=(this.lo<<1^e)>>>0,this}zzDecode(){let e=-(this.lo&1);return this.lo=((this.lo>>>1|this.hi<<31)^e)>>>0,this.hi=(this.hi>>>1^e)>>>0,this}length(){let e=this.lo,t=(this.lo>>>28|this.hi<<4)>>>0,n=this.hi>>>24;return n===0?t===0?e<16384?e<128?1:2:e<2097152?3:4:t<16384?t<128?5:6:t<2097152?7:8:n<128?9:10}static fromBigInt(e){if(e===0n)return rr;if(e<Id&&e>kd)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>Pc&&(s=0n,++n>Pc&&(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 Ue(0,0);rr.toBigInt=function(){return 0n};rr.zzEncode=rr.zzDecode=function(){return this};rr.length=function(){return 1};var Pc=4294967296n;function Mc(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 Vc(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 fo(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 zn(r,e){return(r[e-4]|r[e-3]<<8|r[e-2]<<16|r[e-1]<<24)>>>0}var ho=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 zn(this.buf,this.pos+=4)}sfixed32(){if(this.pos+4>this.len)throw Je(this,4);return zn(this.buf,this.pos+=4)|0}float(){if(this.pos+4>this.len)throw Je(this,4);let e=Uc(this.buf,this.pos);return this.pos+=4,e}double(){if(this.pos+8>this.len)throw Je(this,4);let e=Oc(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 Vc(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 Ue(0,0),t=0;if(this.len-this.pos>4){for(;t<4;++t)if(e.lo=(e.lo|(this.buf[this.pos]&127)<<t*7)>>>0,this.buf[this.pos++]<128)return e;if(e.lo=(e.lo|(this.buf[this.pos]&127)<<28)>>>0,e.hi=(e.hi|(this.buf[this.pos]&127)>>4)>>>0,this.buf[this.pos++]<128)return e;t=0}else{for(;t<3;++t){if(this.pos>=this.len)throw Je(this);if(e.lo=(e.lo|(this.buf[this.pos]&127)<<t*7)>>>0,this.buf[this.pos++]<128)return e}return e.lo=(e.lo|(this.buf[this.pos++]&127)<<t*7)>>>0,e}if(this.len-this.pos>4){for(;t<5;++t)if(e.hi=(e.hi|(this.buf[this.pos]&127)<<t*7+3)>>>0,this.buf[this.pos++]<128)return e}else for(;t<5;++t){if(this.pos>=this.len)throw Je(this);if(e.hi=(e.hi|(this.buf[this.pos]&127)<<t*7+3)>>>0,this.buf[this.pos++]<128)return e}throw Error("invalid varint encoding")}readFixed64(){if(this.pos+8>this.len)throw Je(this,8);let e=zn(this.buf,this.pos+=4),t=zn(this.buf,this.pos+=4);return new Ue(e,t)}int64(){return this.readLongVarint().toBigInt()}int64Number(){return this.readLongVarint().toNumber()}int64String(){return this.readLongVarint().toString()}uint64(){return this.readLongVarint().toBigInt(!0)}uint64Number(){let e=co(this.buf,this.pos);return this.pos+=Be(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 po(r){return new ho(r instanceof Uint8Array?r:r.subarray())}function De(r,e,t){let n=po(r);return e.decode(n,void 0,t)}function go(r){let e=r??8192,t=e>>>1,n,s=e;return function(o){if(o<1||o>t)return Ne(o);s+o>e&&(n=Ne(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 mo(){}var bo=class{head;tail;len;next;constructor(e){this.head=e.head,this.tail=e.tail,this.len=e.len,this.next=e.states}},Td=go();function Rd(r){return globalThis.Buffer!=null?Ne(r):Td(r)}var nn=class{len;head;tail;states;constructor(){this.len=0,this.head=new nr(mo,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 wo((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($n,10,Ue.fromNumber(e)):this.uint32(e)}sint32(e){return this.uint32((e<<1^e>>31)>>>0)}uint64(e){let t=Ue.fromBigInt(e);return this._push($n,t.length(),t)}uint64Number(e){return this._push(ao,Be(e),e)}uint64String(e){return this.uint64(BigInt(e))}int64(e){return this.uint64(e)}int64Number(e){return this.uint64Number(e)}int64String(e){return this.uint64String(e)}sint64(e){let t=Ue.fromBigInt(e).zzEncode();return this._push($n,t.length(),t)}sint64Number(e){let t=Ue.fromNumber(e).zzEncode();return this._push($n,t.length(),t)}sint64String(e){return this.sint64(BigInt(e))}bool(e){return this._push(yo,1,e?1:0)}fixed32(e){return this._push(rn,4,e>>>0)}sfixed32(e){return this.fixed32(e)}fixed64(e){let t=Ue.fromBigInt(e);return this._push(rn,4,t.lo)._push(rn,4,t.hi)}fixed64Number(e){let t=Ue.fromNumber(e);return this._push(rn,4,t.lo)._push(rn,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(Lc,4,e)}double(e){return this._push(Dc,8,e)}bytes(e){let t=e.length>>>0;return t===0?this._push(yo,1,0):this.uint32(t)._push(Cd,t,e)}string(e){let t=Mc(e);return t!==0?this.uint32(t)._push(fo,t,e):this._push(yo,1,0)}fork(){return this.states=new bo(this),this.head=this.tail=new nr(mo,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(mo,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=Rd(this.len),n=0;for(;e!=null;)e.fn(e.val,t,n),n+=e.len,e=e.next;return t}};function yo(r,e,t){e[t]=r&255}function Nd(r,e,t){for(;r>127;)e[t++]=r&127|128,r>>>=7;e[t]=r}var wo=class extends nr{next;constructor(e,t){super(Nd,e,t),this.next=void 0}};function $n(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 rn(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 Cd(r,e,t){e.set(r,t)}globalThis.Buffer!=null&&(nn.prototype.bytes=function(r){let e=r.length>>>0;return this.uint32(e),e>0&&this._push(Ld,e,r),this},nn.prototype.string=function(r){let e=globalThis.Buffer.byteLength(r);return this.uint32(e),e>0&&this._push(Ud,e,r),this});function Ld(r,e,t){e.set(r,t)}function Ud(r,e,t){r.length<40?fo(r,e,t):e.utf8Write!=null?e.utf8Write(r,t):e.set(V(r),t)}function xo(){return new nn}function Oe(r,e){let t=xo();return e.encode(r,t,{lengthDelimited:!1}),t.finish()}var Lr;(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"})(Lr||(Lr={}));function Gn(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 Gn("enum",Lr.VARINT,t,n)}function Pe(r,e){return Gn("message",Lr.LENGTH_DELIMITED,r,e)}var sn=class extends Error{code;constructor(e,t,n){super(e,n),this.code=t}};var se;(function(r){r.RSA="RSA",r.Ed25519="Ed25519",r.Secp256k1="Secp256k1"})(se||(se={}));var vo;(function(r){r[r.RSA=0]="RSA",r[r.Ed25519=1]="Ed25519",r[r.Secp256k1=2]="Secp256k1"})(vo||(vo={}));(function(r){r.codec=()=>sr(vo)})(se||(se={}));var it;(function(r){let e;r.codec=()=>(e==null&&(e=Pe((t,n,s={})=>{s.lengthDelimited!==!1&&n.fork(),t.Type!=null&&(n.uint32(8),se.codec().encode(t.Type,n)),t.Data!=null&&(n.uint32(18),n.bytes(t.Data)),s.lengthDelimited!==!1&&n.ldelim()},(t,n)=>{let s={},i=n==null?t.len:t.pos+n;for(;t.pos<i;){let o=t.uint32();switch(o>>>3){case 1:s.Type=se.codec().decode(t);break;case 2:s.Data=t.bytes();break;default:t.skipType(o&7);break}}return s})),e),r.encode=t=>Oe(t,r.codec()),r.decode=t=>De(t,r.codec())})(it||(it={}));var ot;(function(r){let e;r.codec=()=>(e==null&&(e=Pe((t,n,s={})=>{s.lengthDelimited!==!1&&n.fork(),t.Type!=null&&(n.uint32(8),se.codec().encode(t.Type,n)),t.Data!=null&&(n.uint32(18),n.bytes(t.Data)),s.lengthDelimited!==!1&&n.ldelim()},(t,n)=>{let s={},i=n==null?t.len:t.pos+n;for(;t.pos<i;){let o=t.uint32();switch(o>>>3){case 1:s.Type=se.codec().decode(t);break;case 2:s.Data=t.bytes();break;default:t.skipType(o&7);break}}return s})),e),r.encode=t=>Oe(t,r.codec()),r.decode=t=>De(t,r.codec())})(ot||(ot={}));var on=class{_key;constructor(e){this._key=Ur(e,Nr)}verify(e,t){return Rc(this._key,t,e)}marshal(){return this._key}get bytes(){return it.encode({Type:se.Ed25519,Data:this.marshal()}).subarray()}equals(e){return ae(this.bytes,e.bytes)}hash(){let e=me.digest(this.bytes);return $e(e)?e.then(({bytes:t})=>t):e.bytes}},ir=class{_key;_publicKey;constructor(e,t){this._key=Ur(e,wt),this._publicKey=Ur(t,Nr)}sign(e){return Tc(this._key,e)}get public(){return new on(this._publicKey)}marshal(){return this._key}get bytes(){return ot.encode({Type:se.Ed25519,Data:this.marshal()}).subarray()}equals(e){return ae(this.bytes,e.bytes)}async hash(){let e=me.digest(this.bytes),t;return $e(e)?{bytes:t}=await e:t=e.bytes,t}async id(){let e=Ct.digest(this.public.bytes);return de.encode(e.bytes).substring(1)}async export(e,t="libp2p-key"){if(t==="libp2p-key")return Cr(this.bytes,e);throw new U(`export format '${t}' is not supported`,"ERR_INVALID_EXPORT_FORMAT")}};function Dd(r){if(r.length>wt){r=Ur(r,wt+Nr);let n=r.subarray(0,wt),s=r.subarray(wt,r.length);return new ir(n,s)}r=Ur(r,wt);let e=r.subarray(0,wt),t=r.subarray(Nr);return new ir(e,t)}function Od(r){return r=Ur(r,Nr),new on(r)}async function Pd(){let{privateKey:r,publicKey:e}=Ic();return new ir(r,e)}async function Fc(r){let{privateKey:e,publicKey:t}=kc(r);return new ir(e,t)}function Ur(r,e){if(r=Uint8Array.from(r??[]),r.length!==e)throw new U(`Key must be a Uint8Array of length ${e}, got ${r.length}`,"ERR_INVALID_KEY_TYPE");return r}function X(r,e="utf8"){let t=Tn[e];if(t==null)throw new Error(`Unsupported encoding "${e}"`);return t.encoder.encode(r).substring(1)}var Co={};ge(Co,{MAX_RSA_KEY_SIZE:()=>bn,RsaPrivateKey:()=>Vr,RsaPublicKey:()=>yn,fromJwk:()=>up,generateKeyPair:()=>fp,unmarshalRsaPrivateKey:()=>Ro,unmarshalRsaPublicKey:()=>lp});function at(r){if(isNaN(r)||r<=0)throw new U("random bytes length must be a Number bigger than 0","ERR_INVALID_LENGTH");return _r(r)}var $t={};ge($t,{exportToPem:()=>sp,importFromPem:()=>ip,jwkToPkcs1:()=>ep,jwkToPkix:()=>rp,pkcs1ToJwk:()=>Qd,pkixToJwk:()=>tp});var Wn=class extends Sr{constructor(e,t){super(),this.finished=!1,this.destroyed=!1,Rn(e);let n=Dt(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 Ar(this),this.iHash.update(e),this}digestInto(e){Ar(this),Er(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()}},an=(r,e,t)=>new Wn(r,e).update(t).digest();an.create=(r,e)=>new Wn(r,e);function Md(r,e,t,n){Rn(r);let s=lc({dkLen:32,asyncTick:10},n),{c:i,dkLen:o,asyncTick:a}=s;if(vr(i),vr(o),vr(a),i<1)throw new Error("PBKDF2: iterations (c) should be >= 1");let c=Dt(e),h=Dt(t),f=new Uint8Array(o),l=an.create(r,c),m=l._cloneInto().update(h);return{c:i,dkLen:o,asyncTick:a,DK:f,PRF:l,PRFSalt:m}}function Vd(r,e,t,n,s){return r.destroy(),e.destroy(),n&&n.destroy(),s.fill(0),t}async function Ao(r,e,t,n){let{c:s,dkLen:i,asyncTick:o,DK:a,PRF:c,PRFSalt:h}=Md(r,e,t,n),f,l=new Uint8Array(4),m=Br(l),u=new Uint8Array(c.outputLen);for(let d=1,p=0;p<i;d++,p+=c.outputLen){let b=a.subarray(p,p+c.outputLen);m.setInt32(0,d,!1),(f=h._cloneInto(f)).update(l).digestInto(u),b.set(u.subarray(0,b.length)),await cc(s-1,o,()=>{c._cloneInto(f).update(u).digestInto(u);for(let g=0;g<b.length;g++)b[g]^=u[g]})}return Vd(c,h,a,f,u)}var G=mi(Kc());function or(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 Kt(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 l=Math.pow(2,f*e);h[i-f-1]=Math.floor(s/l),s-=h[i-f-1]*l}return c}o*=Math.pow(2,e)}return new ArrayBuffer(0)}function Xn(...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 Bo(){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=or(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,or(i,8)-n}function qc(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=Kt(o,8,n),c=new Uint8Array(a);return c[0]|=128,a}let s=Kt(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 zc(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 Ce(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 Cy=Math.log(2);function Jn(){if(typeof BigInt>"u")throw new Error("BigInt is not defined. Your environment doesn't implement BigInt.")}function _o(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 ln=class{constructor(){this.items=[]}write(e){this.items.push(e)}final(){return _o(this.items)}},cn=[new Uint8Array([1])],$c="0123456789";var Pr="",et=new ArrayBuffer(0),Io=new Uint8Array(0),un="EndOfContent",jc="OCTET STRING",Wc="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?G.BufferSourceConverter.toUint8Array(i.valueHex):Io}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:G.Convert.ToHex(this.valueHexView)}}},e.NAME="hexBlock",e}var Et=class{constructor({blockLength:e=0,error:t=Pr,warnings:n=[],valueBeforeDecode:s=Io}={}){this.blockLength=e,this.error=t,this.warnings=n,this.valueBeforeDecodeView=G.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:G.Convert.ToHex(this.valueBeforeDecodeView)}}};Et.NAME="baseBlock";var Ie=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'")}};Ie.NAME="valueBlock";var Qn=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?G.BufferSourceConverter.toUint8Array(e.valueHex):Io,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=Kt(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=G.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 u=0;u<h.length;u++)m[u]=h[u];h=this.valueHexView=new Uint8Array(f)}}this.blockLength=c+1,h[c-1]=i[c]&127;let l=new Uint8Array(c);for(let m=0;m<c;m++)l[m]=h[m];h=this.valueHexView=new Uint8Array(c),h.set(l),this.blockLength<=9?this.tagNumber=or(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}}};Qn.NAME="identificationBlock";var es=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=G.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=or(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=Kt(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}}};es.NAME="lengthBlock";var T={},ve=class extends Et{constructor({name:e=Pr,optional:t=!1,primitiveSchema:n,...s}={},i){super(s),this.name=e,this.optional=t,n&&(this.primitiveSchema=n),this.idBlock=new Qn(s),this.lenBlock=new es(s),this.valueBlock=i?new i(s):new Ie(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 ln;t||Yc(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():G.Convert.ToHex(this.toBER())}onAsciiEncoding(){return`${this.constructor.NAME} : ${G.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 zc(t,n)}};ve.NAME="BaseBlock";function Yc(r){if(r instanceof T.Constructed)for(let e of r.valueBlock.value)Yc(e)&&(r.lenBlock.isIndefiniteForm=!0);return!!r.lenBlock.isIndefiniteForm}var ts=class extends ve{constructor({value:e=Pr,...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}'`}};ts.NAME="BaseStringBlock";var rs=class extends _t(Ie){constructor({isHexOnly:e=!0,...t}={}){super(t),this.isHexOnly=e}};rs.NAME="PrimitiveValueBlock";var Zc,ns=class extends ve{constructor(e={}){super(e,rs),this.idBlock.isConstructed=!1}};Zc=ns;T.Primitive=Zc;ns.NAME="PRIMITIVE";function Wd(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 Os(r,e=0,t=r.length){let n=e,s=new ve({},Ie),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=ve;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=T.EndOfContent;break;case 1:c=T.Boolean;break;case 2:c=T.Integer;break;case 3:c=T.BitString;break;case 4:c=T.OctetString;break;case 5:c=T.Null;break;case 6:c=T.ObjectIdentifier;break;case 10:c=T.Enumerated;break;case 12:c=T.Utf8String;break;case 13:c=T.RelativeObjectIdentifier;break;case 14:c=T.TIME;break;case 15:return s.error="[UNIVERSAL 15] is reserved by ASN.1 standard",{offset:-1,result:s};case 16:c=T.Sequence;break;case 17:c=T.Set;break;case 18:c=T.NumericString;break;case 19:c=T.PrintableString;break;case 20:c=T.TeletexString;break;case 21:c=T.VideotexString;break;case 22:c=T.IA5String;break;case 23:c=T.UTCTime;break;case 24:c=T.GeneralizedTime;break;case 25:c=T.GraphicString;break;case 26:c=T.VisibleString;break;case 27:c=T.GeneralString;break;case 28:c=T.UniversalString;break;case 29:c=T.CharacterString;break;case 30:c=T.BmpString;break;case 31:c=T.DATE;break;case 32:c=T.TimeOfDay;break;case 33:c=T.DateTime;break;case 34:c=T.Duration;break;default:{let h=s.idBlock.isConstructed?new T.Constructed:new T.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?T.Constructed:T.Primitive}return s=Wd(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 Mr(r){if(!r.byteLength){let e=new ve({},Ie);return e.error="Input buffer has zero length",{offset:-1,result:e}}return Os(G.BufferSourceConverter.toUint8Array(r).slice(),0,r.byteLength)}function Yd(r,e){return r?1:e}var ct=class extends Ie{constructor({value:e=[],isIndefiniteForm:t=!1,...n}={}){super(n),this.value=e,this.isIndefiniteForm=t}fromBER(e,t,n){let s=G.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(;Yd(this.isIndefiniteForm,n)>0;){let o=Os(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===un)break}return this.isIndefiniteForm&&(this.value[this.value.length-1].constructor.NAME===un?this.value.pop():this.warnings.push("No EndOfContent block encoded")),i}toBER(e,t){let n=t||new ln;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 Xc,qt=class extends ve{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(`
|
2
|
+
"use strict";var Libp2PCircuitRelayV2=(()=>{var rf=Object.create;var In=Object.defineProperty;var nf=Object.getOwnPropertyDescriptor;var sf=Object.getOwnPropertyNames;var of=Object.getPrototypeOf,af=Object.prototype.hasOwnProperty;var gi=(r,e)=>()=>(e||r((e={exports:{}}).exports,e),e.exports),ge=(r,e)=>{for(var t in e)In(r,t,{get:e[t],enumerable:!0})},Na=(r,e,t,n)=>{if(e&&typeof e=="object"||typeof e=="function")for(let s of sf(e))!af.call(r,s)&&s!==t&&In(r,s,{get:()=>e[s],enumerable:!(n=nf(e,s))||n.enumerable});return r};var mi=(r,e,t)=>(t=r!=null?rf(of(r)):{},Na(e||!r||!r.__esModule?In(t,"default",{value:r,enumerable:!0}):t,r)),cf=r=>Na(In({},"__esModule",{value:!0}),r);var zc=gi(Dr=>{"use strict";var Kd="[object ArrayBuffer]",vt=class r{static isArrayBuffer(e){return Object.prototype.toString.call(e)===Kd}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}},So="string",qd=/^[0-9a-f]+$/i,zd=/^(?:[A-Za-z0-9+/]{4})*(?:[A-Za-z0-9+/]{2}==|[A-Za-z0-9+/]{3}=)?$/,$d=/^[a-zA-Z0-9-_]+$/,Yn=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))}},je=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}},Zn=class r{static isHex(e){return typeof e===So&&qd.test(e)}static isBase64(e){return typeof e===So&&zd.test(e)}static isBase64Url(e){return typeof e===So&&$d.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 je.toString(n,!0);case"utf16":case"utf16be":return je.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 je.fromString(e,!0);case"utf16":case"utf16be":return je.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 Yn.fromString(e);case"utf16":case"utf16be":return je.fromString(e);case"utf16le":case"usc2":return je.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 Yn.toString(e);case"utf16":case"utf16be":return je.toString(e);case"utf16le":case"usc2":return je.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 je.toString(e,t)}static FromUtf16String(e,t=!1){return je.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,"")||""}};Zn.DEFAULT_UTF8_ENCODING="utf8";function Gd(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 jd(...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 Wd(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}Dr.BufferSourceConverter=vt;Dr.Convert=Zn;Dr.assign=Gd;Dr.combine=jd;Dr.isEqual=Wd});var Tu=gi((Sn,Zs)=>{(function(r,e){"use strict";var t={version:"3.0.0",x86:{},x64:{},inputValidation:!0};function n(u){if(!Array.isArray(u)&&!ArrayBuffer.isView(u))return!1;for(var d=0;d<u.length;d++)if(!Number.isInteger(u[d])||u[d]<0||u[d]>255)return!1;return!0}function s(u,d){return(u&65535)*d+(((u>>>16)*d&65535)<<16)}function i(u,d){return u<<d|u>>>32-d}function o(u){return u^=u>>>16,u=s(u,2246822507),u^=u>>>13,u=s(u,3266489909),u^=u>>>16,u}function a(u,d){u=[u[0]>>>16,u[0]&65535,u[1]>>>16,u[1]&65535],d=[d[0]>>>16,d[0]&65535,d[1]>>>16,d[1]&65535];var p=[0,0,0,0];return p[3]+=u[3]+d[3],p[2]+=p[3]>>>16,p[3]&=65535,p[2]+=u[2]+d[2],p[1]+=p[2]>>>16,p[2]&=65535,p[1]+=u[1]+d[1],p[0]+=p[1]>>>16,p[1]&=65535,p[0]+=u[0]+d[0],p[0]&=65535,[p[0]<<16|p[1],p[2]<<16|p[3]]}function c(u,d){u=[u[0]>>>16,u[0]&65535,u[1]>>>16,u[1]&65535],d=[d[0]>>>16,d[0]&65535,d[1]>>>16,d[1]&65535];var p=[0,0,0,0];return p[3]+=u[3]*d[3],p[2]+=p[3]>>>16,p[3]&=65535,p[2]+=u[2]*d[3],p[1]+=p[2]>>>16,p[2]&=65535,p[2]+=u[3]*d[2],p[1]+=p[2]>>>16,p[2]&=65535,p[1]+=u[1]*d[3],p[0]+=p[1]>>>16,p[1]&=65535,p[1]+=u[2]*d[2],p[0]+=p[1]>>>16,p[1]&=65535,p[1]+=u[3]*d[1],p[0]+=p[1]>>>16,p[1]&=65535,p[0]+=u[0]*d[3]+u[1]*d[2]+u[2]*d[1]+u[3]*d[0],p[0]&=65535,[p[0]<<16|p[1],p[2]<<16|p[3]]}function h(u,d){return d%=64,d===32?[u[1],u[0]]:d<32?[u[0]<<d|u[1]>>>32-d,u[1]<<d|u[0]>>>32-d]:(d-=32,[u[1]<<d|u[0]>>>32-d,u[0]<<d|u[1]>>>32-d])}function f(u,d){return d%=64,d===0?u:d<32?[u[0]<<d|u[1]>>>32-d,u[1]<<d]:[u[1]<<d-32,0]}function l(u,d){return[u[0]^d[0],u[1]^d[1]]}function m(u){return u=l(u,[0,u[0]>>>1]),u=c(u,[4283543511,3981806797]),u=l(u,[0,u[0]>>>1]),u=c(u,[3301882366,444984403]),u=l(u,[0,u[0]>>>1]),u}t.x86.hash32=function(u,d){if(t.inputValidation&&!n(u))return e;d=d||0;for(var p=u.length%4,b=u.length-p,g=d,w=0,y=3432918353,E=461845907,x=0;x<b;x=x+4)w=u[x]|u[x+1]<<8|u[x+2]<<16|u[x+3]<<24,w=s(w,y),w=i(w,15),w=s(w,E),g^=w,g=i(g,13),g=s(g,5)+3864292196;switch(w=0,p){case 3:w^=u[x+2]<<16;case 2:w^=u[x+1]<<8;case 1:w^=u[x],w=s(w,y),w=i(w,15),w=s(w,E),g^=w}return g^=u.length,g=o(g),g>>>0},t.x86.hash128=function(u,d){if(t.inputValidation&&!n(u))return e;d=d||0;for(var p=u.length%16,b=u.length-p,g=d,w=d,y=d,E=d,x=0,S=0,v=0,B=0,$=597399067,q=2869860233,P=951274213,te=2716044179,C=0;C<b;C=C+16)x=u[C]|u[C+1]<<8|u[C+2]<<16|u[C+3]<<24,S=u[C+4]|u[C+5]<<8|u[C+6]<<16|u[C+7]<<24,v=u[C+8]|u[C+9]<<8|u[C+10]<<16|u[C+11]<<24,B=u[C+12]|u[C+13]<<8|u[C+14]<<16|u[C+15]<<24,x=s(x,$),x=i(x,15),x=s(x,q),g^=x,g=i(g,19),g+=w,g=s(g,5)+1444728091,S=s(S,q),S=i(S,16),S=s(S,P),w^=S,w=i(w,17),w+=y,w=s(w,5)+197830471,v=s(v,P),v=i(v,17),v=s(v,te),y^=v,y=i(y,15),y+=E,y=s(y,5)+2530024501,B=s(B,te),B=i(B,18),B=s(B,$),E^=B,E=i(E,13),E+=g,E=s(E,5)+850148119;switch(x=0,S=0,v=0,B=0,p){case 15:B^=u[C+14]<<16;case 14:B^=u[C+13]<<8;case 13:B^=u[C+12],B=s(B,te),B=i(B,18),B=s(B,$),E^=B;case 12:v^=u[C+11]<<24;case 11:v^=u[C+10]<<16;case 10:v^=u[C+9]<<8;case 9:v^=u[C+8],v=s(v,P),v=i(v,17),v=s(v,te),y^=v;case 8:S^=u[C+7]<<24;case 7:S^=u[C+6]<<16;case 6:S^=u[C+5]<<8;case 5:S^=u[C+4],S=s(S,q),S=i(S,16),S=s(S,P),w^=S;case 4:x^=u[C+3]<<24;case 3:x^=u[C+2]<<16;case 2:x^=u[C+1]<<8;case 1:x^=u[C],x=s(x,$),x=i(x,15),x=s(x,q),g^=x}return g^=u.length,w^=u.length,y^=u.length,E^=u.length,g+=w,g+=y,g+=E,w+=g,y+=g,E+=g,g=o(g),w=o(w),y=o(y),E=o(E),g+=w,g+=y,g+=E,w+=g,y+=g,E+=g,("00000000"+(g>>>0).toString(16)).slice(-8)+("00000000"+(w>>>0).toString(16)).slice(-8)+("00000000"+(y>>>0).toString(16)).slice(-8)+("00000000"+(E>>>0).toString(16)).slice(-8)},t.x64.hash128=function(u,d){if(t.inputValidation&&!n(u))return e;d=d||0;for(var p=u.length%16,b=u.length-p,g=[0,d],w=[0,d],y=[0,0],E=[0,0],x=[2277735313,289559509],S=[1291169091,658871167],v=0;v<b;v=v+16)y=[u[v+4]|u[v+5]<<8|u[v+6]<<16|u[v+7]<<24,u[v]|u[v+1]<<8|u[v+2]<<16|u[v+3]<<24],E=[u[v+12]|u[v+13]<<8|u[v+14]<<16|u[v+15]<<24,u[v+8]|u[v+9]<<8|u[v+10]<<16|u[v+11]<<24],y=c(y,x),y=h(y,31),y=c(y,S),g=l(g,y),g=h(g,27),g=a(g,w),g=a(c(g,[0,5]),[0,1390208809]),E=c(E,S),E=h(E,33),E=c(E,x),w=l(w,E),w=h(w,31),w=a(w,g),w=a(c(w,[0,5]),[0,944331445]);switch(y=[0,0],E=[0,0],p){case 15:E=l(E,f([0,u[v+14]],48));case 14:E=l(E,f([0,u[v+13]],40));case 13:E=l(E,f([0,u[v+12]],32));case 12:E=l(E,f([0,u[v+11]],24));case 11:E=l(E,f([0,u[v+10]],16));case 10:E=l(E,f([0,u[v+9]],8));case 9:E=l(E,[0,u[v+8]]),E=c(E,S),E=h(E,33),E=c(E,x),w=l(w,E);case 8:y=l(y,f([0,u[v+7]],56));case 7:y=l(y,f([0,u[v+6]],48));case 6:y=l(y,f([0,u[v+5]],40));case 5:y=l(y,f([0,u[v+4]],32));case 4:y=l(y,f([0,u[v+3]],24));case 3:y=l(y,f([0,u[v+2]],16));case 2:y=l(y,f([0,u[v+1]],8));case 1:y=l(y,[0,u[v]]),y=c(y,x),y=h(y,31),y=c(y,S),g=l(g,y)}return g=l(g,[0,u.length]),w=l(w,[0,u.length]),g=a(g,w),w=a(w,g),g=m(g),w=m(w),g=a(g,w),w=a(w,g),("00000000"+(g[0]>>>0).toString(16)).slice(-8)+("00000000"+(g[1]>>>0).toString(16)).slice(-8)+("00000000"+(w[0]>>>0).toString(16)).slice(-8)+("00000000"+(w[1]>>>0).toString(16)).slice(-8)},typeof Sn<"u"?(typeof Zs<"u"&&Zs.exports&&(Sn=Zs.exports=t),Sn.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)})(Sn)});var sa=gi((gx,Ru)=>{Ru.exports=Tu()});var S0={};ge(S0,{RELAY_V2_HOP_CODEC:()=>Ye,RELAY_V2_STOP_CODEC:()=>lr,circuitRelayServer:()=>Du,circuitRelayTransport:()=>ju});var Ca=Symbol.for("@libp2p/peer-id");var Ua=Symbol.for("@libp2p/transport");var La;(function(r){r[r.FATAL_ALL=0]="FATAL_ALL",r[r.NO_FATAL=1]="NO_FATAL"})(La||(La={}));var Rt=class r extends Error{code;type;constructor(e="The operation was aborted"){super(e),this.name="AbortError",this.code=r.code,this.type=r.type}static code="ABORT_ERR";static type="aborted"},U=class extends Error{code;props;constructor(e,t,n){super(e),this.code=t,this.name=n?.name??"CodeError",this.props=n??{}}};var Ke=(r,...e)=>{try{[...e]}catch{}};var qe=class extends EventTarget{#e=new Map;constructor(){super(),Ke(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 lf(e,t))}},yi=class extends Event{detail;constructor(e,t){super(e,t),this.detail=t?.detail}},lf=globalThis.CustomEvent??yi;function Da(r){return r!=null&&typeof r.start=="function"&&typeof r.stop=="function"}async function Oa(...r){let e=[];for(let t of r)Da(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 Pa(...r){let e=[];for(let t of r)Da(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 Ma=Symbol.for("@libp2p/service-capabilities"),Va=Symbol.for("@libp2p/service-dependencies");var Ei={};ge(Ei,{base58btc:()=>de,base58flickr:()=>gf});var rg=new Uint8Array(0);function Ha(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 ht(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 Fa(r){return new TextEncoder().encode(r)}function Ka(r){return new TextDecoder().decode(r)}function uf(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 l(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,b=0,g=0,w=d.length;g!==w&&d[g]===0;)g++,p++;for(var y=(w-g)*f+1>>>0,E=new Uint8Array(y);g!==w;){for(var x=d[g],S=0,v=y-1;(x!==0||S<b)&&v!==-1;v--,S++)x+=256*E[v]>>>0,E[v]=x%a>>>0,x=x/a>>>0;if(x!==0)throw new Error("Non-zero carry");b=S,g++}for(var B=y-b;B!==y&&E[B]===0;)B++;for(var $=c.repeat(p);B<y;++B)$+=r.charAt(E[B]);return $}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 b=0,g=0;d[p]===c;)b++,p++;for(var w=(d.length-p)*h+1>>>0,y=new Uint8Array(w);d[p];){var E=t[d.charCodeAt(p)];if(E===255)return;for(var x=0,S=w-1;(E!==0||x<g)&&S!==-1;S--,x++)E+=a*y[S]>>>0,y[S]=E%256>>>0,E=E/256>>>0;if(E!==0)throw new Error("Non-zero carry");g=x,p++}if(d[p]!==" "){for(var v=w-g;v!==w&&y[v]===0;)v++;for(var B=new Uint8Array(b+(w-v)),$=b;v!==w;)B[$++]=y[v++];return B}}}function u(d){var p=m(d);if(p)return p;throw new Error(`Non-${e} character`)}return{encode:l,decodeUnsafe:m,decode:u}}var ff=uf,hf=ff,za=hf;var bi=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){if(this.name=e,this.prefix=t,t.codePointAt(0)===void 0)throw new Error("Invalid prefix character");this.prefixCodePoint=t.codePointAt(0),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 $a(this,e)}},xi=class{decoders;constructor(e){this.decoders=e}or(e){return $a(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 $a(r,e){return new xi({...r.decoders??{[r.prefix]:r},...e.decoders??{[e.prefix]:e}})}var vi=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 bi(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 pr({name:r,prefix:e,encode:t,decode:n}){return new vi(r,e,t,n)}function Nt({name:r,prefix:e,alphabet:t}){let{encode:n,decode:s}=za(t,r);return pr({prefix:e,name:r,encode:n,decode:i=>ht(s(i))})}function df(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 l=s[r[f]];if(l===void 0)throw new SyntaxError(`Non-${n} character`);c=c<<t|l,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 pf(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 oe({name:r,prefix:e,bitsPerChar:t,alphabet:n}){return pr({prefix:e,name:r,encode(s){return pf(s,n,t)},decode(s){return df(s,n,t,r)}})}var de=Nt({name:"base58btc",prefix:"z",alphabet:"123456789ABCDEFGHJKLMNPQRSTUVWXYZabcdefghijkmnopqrstuvwxyz"}),gf=Nt({name:"base58flickr",prefix:"Z",alphabet:"123456789abcdefghijkmnopqrstuvwxyzABCDEFGHJKLMNPQRSTUVWXYZ"});var Ai={};ge(Ai,{base10:()=>mf});var mf=Nt({prefix:"9",name:"base10",alphabet:"0123456789"});var Si={};ge(Si,{base16:()=>yf,base16upper:()=>bf});var yf=oe({prefix:"f",name:"base16",alphabet:"0123456789abcdef",bitsPerChar:4}),bf=oe({prefix:"F",name:"base16upper",alphabet:"0123456789ABCDEF",bitsPerChar:4});var Bi={};ge(Bi,{base2:()=>wf});var wf=oe({prefix:"0",name:"base2",alphabet:"01",bitsPerChar:1});var _i={};ge(_i,{base256emoji:()=>Sf});var Ga=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}"),xf=Ga.reduce((r,e,t)=>(r[t]=e,r),[]),vf=Ga.reduce((r,e,t)=>(r[e.codePointAt(0)]=t,r),[]);function Ef(r){return r.reduce((e,t)=>(e+=xf[t],e),"")}function Af(r){let e=[];for(let t of r){let n=vf[t.codePointAt(0)];if(n===void 0)throw new Error(`Non-base256emoji character: ${t}`);e.push(n)}return new Uint8Array(e)}var Sf=pr({prefix:"\u{1F680}",name:"base256emoji",encode:Ef,decode:Af});var Ii={};ge(Ii,{base32:()=>dt,base32hex:()=>kf,base32hexpad:()=>Rf,base32hexpadupper:()=>Nf,base32hexupper:()=>Tf,base32pad:()=>_f,base32padupper:()=>If,base32upper:()=>Bf,base32z:()=>Cf});var dt=oe({prefix:"b",name:"base32",alphabet:"abcdefghijklmnopqrstuvwxyz234567",bitsPerChar:5}),Bf=oe({prefix:"B",name:"base32upper",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZ234567",bitsPerChar:5}),_f=oe({prefix:"c",name:"base32pad",alphabet:"abcdefghijklmnopqrstuvwxyz234567=",bitsPerChar:5}),If=oe({prefix:"C",name:"base32padupper",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZ234567=",bitsPerChar:5}),kf=oe({prefix:"v",name:"base32hex",alphabet:"0123456789abcdefghijklmnopqrstuv",bitsPerChar:5}),Tf=oe({prefix:"V",name:"base32hexupper",alphabet:"0123456789ABCDEFGHIJKLMNOPQRSTUV",bitsPerChar:5}),Rf=oe({prefix:"t",name:"base32hexpad",alphabet:"0123456789abcdefghijklmnopqrstuv=",bitsPerChar:5}),Nf=oe({prefix:"T",name:"base32hexpadupper",alphabet:"0123456789ABCDEFGHIJKLMNOPQRSTUV=",bitsPerChar:5}),Cf=oe({prefix:"h",name:"base32z",alphabet:"ybndrfg8ejkmcpqxot1uwisza345h769",bitsPerChar:5});var ki={};ge(ki,{base36:()=>Lf,base36upper:()=>Uf});var Lf=Nt({prefix:"k",name:"base36",alphabet:"0123456789abcdefghijklmnopqrstuvwxyz"}),Uf=Nt({prefix:"K",name:"base36upper",alphabet:"0123456789ABCDEFGHIJKLMNOPQRSTUVWXYZ"});var Ri={};ge(Ri,{base64:()=>Ti,base64pad:()=>Df,base64url:()=>Of,base64urlpad:()=>Pf});var Ti=oe({prefix:"m",name:"base64",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/",bitsPerChar:6}),Df=oe({prefix:"M",name:"base64pad",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/=",bitsPerChar:6}),Of=oe({prefix:"u",name:"base64url",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789-_",bitsPerChar:6}),Pf=oe({prefix:"U",name:"base64urlpad",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789-_=",bitsPerChar:6});var Ni={};ge(Ni,{base8:()=>Mf});var Mf=oe({prefix:"7",name:"base8",alphabet:"01234567",bitsPerChar:3});var Ci={};ge(Ci,{identity:()=>Vf});var Vf=pr({prefix:"\0",name:"identity",encode:r=>Ka(r),decode:r=>Fa(r)});var bg=new TextEncoder,wg=new TextDecoder;var Ui={};ge(Ui,{identity:()=>Ct});var Kf=Ya,ja=128,qf=127,zf=~qf,$f=Math.pow(2,31);function Ya(r,e,t){e=e||[],t=t||0;for(var n=t;r>=$f;)e[t++]=r&255|ja,r/=128;for(;r&zf;)e[t++]=r&255|ja,r>>>=7;return e[t]=r|0,Ya.bytes=t-n+1,e}var Gf=Li,jf=128,Wa=127;function Li(r,n){var t=0,n=n||0,s=0,i=n,o,a=r.length;do{if(i>=a)throw Li.bytes=0,new RangeError("Could not decode varint");o=r[i++],t+=s<28?(o&Wa)<<s:(o&Wa)*Math.pow(2,s),s+=7}while(o>=jf);return Li.bytes=i-n,t}var Wf=Math.pow(2,7),Yf=Math.pow(2,14),Zf=Math.pow(2,21),Xf=Math.pow(2,28),Jf=Math.pow(2,35),Qf=Math.pow(2,42),eh=Math.pow(2,49),th=Math.pow(2,56),rh=Math.pow(2,63),nh=function(r){return r<Wf?1:r<Yf?2:r<Zf?3:r<Xf?4:r<Jf?5:r<Qf?6:r<eh?7:r<th?8:r<rh?9:10},sh={encode:Kf,decode:Gf,encodingLength:nh},ih=sh,Yr=ih;function Zr(r,e=0){return[Yr.decode(r,e),Yr.decode.bytes]}function gr(r,e,t=0){return Yr.encode(r,e,t),e}function mr(r){return Yr.encodingLength(r)}function nt(r,e){let t=e.byteLength,n=mr(r),s=n+mr(t),i=new Uint8Array(s+t);return gr(r,i,0),gr(t,i,n),i.set(e,s),new yr(r,t,e,i)}function Xt(r){let e=ht(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 yr(t,s,o,e)}function Za(r,e){if(r===e)return!0;{let t=e;return r.code===t.code&&r.size===t.size&&t.bytes instanceof Uint8Array&&Ha(r.bytes,t.bytes)}}var yr=class{code;size;digest;bytes;constructor(e,t,n,s){this.code=e,this.size=t,this.digest=n,this.bytes=s}};var Xa=0,oh="identity",Ja=ht;function ah(r){return nt(Xa,Ja(r))}var Ct={code:Xa,name:oh,encode:Ja,digest:ah};var Pi={};ge(Pi,{sha256:()=>me,sha512:()=>ch});function Oi({name:r,code:e,encode:t}){return new Di(r,e,t)}var Di=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?nt(this.code,t):t.then(n=>nt(this.code,n))}else throw Error("Unknown type, must be binary type")}};function ec(r){return async e=>new Uint8Array(await crypto.subtle.digest(r,e))}var me=Oi({name:"sha2-256",code:18,encode:ec("SHA-256")}),ch=Oi({name:"sha2-512",code:19,encode:ec("SHA-512")});function tc(r,e){let{bytes:t,version:n}=r;switch(n){case 0:return uh(t,Mi(r),e??de.encoder);default:return fh(t,Mi(r),e??dt.encoder)}}var rc=new WeakMap;function Mi(r){let e=rc.get(r);if(e==null){let t=new Map;return rc.set(r,t),t}return e}var ze=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!==Xr)throw new Error("Cannot convert a non dag-pb CID to CIDv0");if(t.code!==hh)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=nt(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&&Za(e.multihash,n.multihash)}toString(e){return tc(this,e)}toJSON(){return{"/":tc(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??nc(n,s,i.bytes))}else if(t[dh]===!0){let{version:n,multihash:s,code:i}=t,o=Xt(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!==Xr)throw new Error(`Version 0 CID must use dag-pb (code: ${Xr}) block encoding`);return new r(e,t,n,n.bytes)}case 1:{let s=nc(e,t,n.bytes);return new r(e,t,n,s)}default:throw new Error("Invalid version")}}static createV0(e){return r.create(0,Xr,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=ht(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 yr(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[l,m]=Zr(e.subarray(t));return t+=m,l},s=n(),i=Xr;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]=lh(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 Mi(i).set(n,e),i}};function lh(r,e){switch(r[0]){case"Q":{let t=e??de;return[de.prefix,t.decode(`${de.prefix}${r}`)]}case de.prefix:{let t=e??de;return[de.prefix,t.decode(r)]}case dt.prefix:{let t=e??dt;return[dt.prefix,t.decode(r)]}default:{if(e==null)throw Error("To parse non base32 or base58btc encoded CID multibase decoder must be provided");return[r[0],e.decode(r)]}}}function uh(r,e,t){let{prefix:n}=t;if(n!==de.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 fh(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 Xr=112,hh=18;function nc(r,e,t){let n=mr(r),s=n+mr(e),i=new Uint8Array(s+t.byteLength);return gr(r,i,0),gr(e,i,n),i.set(t,s),i}var dh=Symbol.for("@ipld/js-cid/CID");var Lt={...Ci,...Bi,...Ni,...Ai,...Si,...Ii,...ki,...Ei,...Ri,..._i},Hg={...Pi,...Ui};function ae(r,e){if(r===e)return!0;if(r.byteLength!==e.byteLength)return!1;for(let t=0;t<r.byteLength;t++)if(r[t]!==e[t])return!1;return!0}var ph=Symbol.for("nodejs.util.inspect.custom"),sc=Object.values(Lt).map(r=>r.decoder).reduce((r,e)=>r.or(e),Lt.identity.decoder),ic=114,Vi=36,Hi=37,Jr=class{type;multihash;privateKey;publicKey;string;constructor(e){this.type=e.type,this.multihash=e.multihash,this.privateKey=e.privateKey,Object.defineProperty(this,"string",{enumerable:!1,writable:!0})}get[Symbol.toStringTag](){return`PeerId(${this.toString()})`}[Ca]=!0;toString(){return this.string==null&&(this.string=de.encode(this.multihash.bytes).slice(1)),this.string}toCID(){return ze.createV1(ic,this.multihash)}toBytes(){return this.multihash.bytes}toJSON(){return this.toString()}equals(e){if(e==null)return!1;if(e instanceof Uint8Array)return ae(this.multihash.bytes,e);if(typeof e=="string")return Ut(e).equals(this);if(e?.multihash?.bytes!=null)return ae(this.multihash.bytes,e.multihash.bytes);throw new Error("not valid Id")}[ph](){return`PeerId(${this.toString()})`}},br=class extends Jr{type="RSA";publicKey;constructor(e){super({...e,type:"RSA"}),this.publicKey=e.publicKey}},wr=class extends Jr{type="Ed25519";publicKey;constructor(e){super({...e,type:"Ed25519"}),this.publicKey=e.multihash.digest}},xr=class extends Jr{type="secp256k1";publicKey;constructor(e){super({...e,type:"secp256k1"}),this.publicKey=e.multihash.digest}};function Ut(r,e){if(e=e??sc,r.charAt(0)==="1"||r.charAt(0)==="Q"){let t=Xt(de.decode(`z${r}`));return r.startsWith("12D")?new wr({multihash:t}):r.startsWith("16U")?new xr({multihash:t}):new br({multihash:t})}return Qr(sc.decode(r))}function Qr(r){try{let e=Xt(r);if(e.code===Ct.code){if(e.digest.length===Vi)return new wr({multihash:e});if(e.digest.length===Hi)return new xr({multihash:e})}if(e.code===me.code)return new br({multihash:e})}catch{return gh(ze.decode(r))}throw new Error("Supplied PeerID CID is invalid")}function gh(r){if(r==null||r.multihash==null||r.version==null||r.version===1&&r.code!==ic)throw new Error("Supplied PeerID CID is invalid");let e=r.multihash;if(e.code===me.code)return new br({multihash:r.multihash});if(e.code===Ct.code){if(e.digest.length===Vi)return new wr({multihash:r.multihash});if(e.digest.length===Hi)return new xr({multihash:r.multihash})}throw new Error("Supplied PeerID CID is invalid")}async function oc(r,e){return r.length===Vi?new wr({multihash:nt(Ct.code,r),privateKey:e}):r.length===Hi?new xr({multihash:nt(Ct.code,r),privateKey:e}):new br({multihash:await me.digest(r),publicKey:r,privateKey:e})}var Eo={};ge(Eo,{Ed25519PrivateKey:()=>ir,Ed25519PublicKey:()=>on,generateKeyPair:()=>Vd,generateKeyPairFromSeed:()=>qc,unmarshalEd25519PrivateKey:()=>Pd,unmarshalEd25519PublicKey:()=>Md});function xe(r=0){return new Uint8Array(r)}function Ne(r=0){return new Uint8Array(r)}function ke(r,e){e==null&&(e=r.reduce((s,i)=>s+i.length,0));let t=Ne(e),n=0;for(let s of r)t.set(s,n),n+=s.length;return t}function cc(r,e,t,n){return{name:r,prefix:e,encoder:{name:r,prefix:e,encode:t},decoder:{decode:n}}}var ac=cc("utf8","u",r=>"u"+new TextDecoder("utf8").decode(r),r=>new TextEncoder().encode(r.substring(1))),Fi=cc("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=Ne(r.length);for(let t=0;t<r.length;t++)e[t]=r.charCodeAt(t);return e}),mh={utf8:ac,"utf-8":ac,hex:Lt.base16,latin1:Fi,ascii:Fi,binary:Fi,...Lt},Tn=mh;function V(r,e="utf8"){let t=Tn[e];if(t==null)throw new Error(`Unsupported encoding "${e}"`);return t.decoder.decode(`${t.prefix}${r}`)}function $e(r){return r==null?!1:typeof r.then=="function"&&typeof r.catch=="function"&&typeof r.finally=="function"}function vr(r){if(!Number.isSafeInteger(r)||r<0)throw new Error(`positive integer expected, not ${r}`)}function yh(r){return r instanceof Uint8Array||r!=null&&typeof r=="object"&&r.constructor.name==="Uint8Array"}function Er(r,...e){if(!yh(r))throw new Error("Uint8Array expected");if(e.length>0&&!e.includes(r.length))throw new Error(`Uint8Array expected of length ${e}, not of length=${r.length}`)}function Rn(r){if(typeof r!="function"||typeof r.create!="function")throw new Error("Hash should be wrapped by utils.wrapConstructor");vr(r.outputLen),vr(r.blockLen)}function Ar(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 lc(r,e){Er(r);let t=e.outputLen;if(r.length<t)throw new Error(`digestInto() expects output buffer of length at least ${t}`)}var Nn=typeof globalThis=="object"&&"crypto"in globalThis?globalThis.crypto:void 0;var Br=r=>new DataView(r.buffer,r.byteOffset,r.byteLength),Ze=(r,e)=>r<<32-e|r>>>e;var gm=new Uint8Array(new Uint32Array([287454020]).buffer)[0]===68;var bh=async()=>{};async function uc(r,e,t){let n=Date.now();for(let s=0;s<r;s++){t(s);let i=Date.now()-n;i>=0&&i<e||(await bh(),n+=i)}}function Ki(r){if(typeof r!="string")throw new Error(`utf8ToBytes expected string, got ${typeof r}`);return new Uint8Array(new TextEncoder().encode(r))}function Dt(r){return typeof r=="string"&&(r=Ki(r)),Er(r),r}function Cn(...r){let e=0;for(let n=0;n<r.length;n++){let s=r[n];Er(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 Sr=class{clone(){return this._cloneInto()}},wh={}.toString;function fc(r,e){if(e!==void 0&&wh.call(e)!=="[object Object]")throw new Error("Options should be object or undefined");return Object.assign(r,e)}function Ln(r){let e=n=>r().update(Dt(n)).digest(),t=r();return e.outputLen=t.outputLen,e.blockLen=t.blockLen,e.create=()=>r(),e}function _r(r=32){if(Nn&&typeof Nn.getRandomValues=="function")return Nn.getRandomValues(new Uint8Array(r));throw new Error("crypto.getRandomValues must be defined")}function xh(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 hc=(r,e,t)=>r&e^~r&t,dc=(r,e,t)=>r&e^r&t^e&t,Ir=class extends Sr{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=Br(this.buffer)}update(e){Ar(this);let{view:t,buffer:n,blockLen:s}=this;e=Dt(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=Br(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){Ar(this),lc(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 l=o;l<s;l++)t[l]=0;xh(n,s-8,BigInt(this.length*8),i),this.process(n,0);let a=Br(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 l=0;l<h;l++)a.setUint32(4*l,f[l],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),qi=BigInt(32);function pc(r,e=!1){return e?{h:Number(r&Un),l:Number(r>>qi&Un)}:{h:Number(r>>qi&Un)|0,l:Number(r&Un)|0}}function vh(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}=pc(r[s],e);[t[s],n[s]]=[i,o]}return[t,n]}var Eh=(r,e)=>BigInt(r>>>0)<<qi|BigInt(e>>>0),Ah=(r,e,t)=>r>>>t,Sh=(r,e,t)=>r<<32-t|e>>>t,Bh=(r,e,t)=>r>>>t|e<<32-t,_h=(r,e,t)=>r<<32-t|e>>>t,Ih=(r,e,t)=>r<<64-t|e>>>t-32,kh=(r,e,t)=>r>>>t-32|e<<64-t,Th=(r,e)=>e,Rh=(r,e)=>r,Nh=(r,e,t)=>r<<t|e>>>32-t,Ch=(r,e,t)=>e<<t|r>>>32-t,Lh=(r,e,t)=>e<<t-32|r>>>64-t,Uh=(r,e,t)=>r<<t-32|e>>>64-t;function Dh(r,e,t,n){let s=(e>>>0)+(n>>>0);return{h:r+t+(s/2**32|0)|0,l:s|0}}var Oh=(r,e,t)=>(r>>>0)+(e>>>0)+(t>>>0),Ph=(r,e,t,n)=>e+t+n+(r/2**32|0)|0,Mh=(r,e,t,n)=>(r>>>0)+(e>>>0)+(t>>>0)+(n>>>0),Vh=(r,e,t,n,s)=>e+t+n+s+(r/2**32|0)|0,Hh=(r,e,t,n,s)=>(r>>>0)+(e>>>0)+(t>>>0)+(n>>>0)+(s>>>0),Fh=(r,e,t,n,s,i)=>e+t+n+s+i+(r/2**32|0)|0;var Kh={fromBig:pc,split:vh,toBig:Eh,shrSH:Ah,shrSL:Sh,rotrSH:Bh,rotrSL:_h,rotrBH:Ih,rotrBL:kh,rotr32H:Th,rotr32L:Rh,rotlSH:Nh,rotlSL:Ch,rotlBH:Lh,rotlBL:Uh,add:Dh,add3L:Oh,add3H:Ph,add4L:Mh,add4H:Vh,add5H:Fh,add5L:Hh},M=Kh;var[qh,zh]=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))),Ot=new Uint32Array(80),Pt=new Uint32Array(80),zi=class extends Ir{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:l,Fl:m,Gh:u,Gl:d,Hh:p,Hl:b}=this;return[e,t,n,s,i,o,a,c,h,f,l,m,u,d,p,b]}set(e,t,n,s,i,o,a,c,h,f,l,m,u,d,p,b){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=l|0,this.Fl=m|0,this.Gh=u|0,this.Gl=d|0,this.Hh=p|0,this.Hl=b|0}process(e,t){for(let y=0;y<16;y++,t+=4)Ot[y]=e.getUint32(t),Pt[y]=e.getUint32(t+=4);for(let y=16;y<80;y++){let E=Ot[y-15]|0,x=Pt[y-15]|0,S=M.rotrSH(E,x,1)^M.rotrSH(E,x,8)^M.shrSH(E,x,7),v=M.rotrSL(E,x,1)^M.rotrSL(E,x,8)^M.shrSL(E,x,7),B=Ot[y-2]|0,$=Pt[y-2]|0,q=M.rotrSH(B,$,19)^M.rotrBH(B,$,61)^M.shrSH(B,$,6),P=M.rotrSL(B,$,19)^M.rotrBL(B,$,61)^M.shrSL(B,$,6),te=M.add4L(v,P,Pt[y-7],Pt[y-16]),C=M.add4H(te,S,q,Ot[y-7],Ot[y-16]);Ot[y]=C|0,Pt[y]=te|0}let{Ah:n,Al:s,Bh:i,Bl:o,Ch:a,Cl:c,Dh:h,Dl:f,Eh:l,El:m,Fh:u,Fl:d,Gh:p,Gl:b,Hh:g,Hl:w}=this;for(let y=0;y<80;y++){let E=M.rotrSH(l,m,14)^M.rotrSH(l,m,18)^M.rotrBH(l,m,41),x=M.rotrSL(l,m,14)^M.rotrSL(l,m,18)^M.rotrBL(l,m,41),S=l&u^~l&p,v=m&d^~m&b,B=M.add5L(w,x,v,zh[y],Pt[y]),$=M.add5H(B,g,E,S,qh[y],Ot[y]),q=B|0,P=M.rotrSH(n,s,28)^M.rotrBH(n,s,34)^M.rotrBH(n,s,39),te=M.rotrSL(n,s,28)^M.rotrBL(n,s,34)^M.rotrBL(n,s,39),C=n&i^n&a^i&a,Fe=s&o^s&c^o&c;g=p|0,w=b|0,p=u|0,b=d|0,u=l|0,d=m|0,{h:l,l:m}=M.add(h|0,f|0,$|0,q|0),h=a|0,f=c|0,a=i|0,c=o|0,i=n|0,o=s|0;let _=M.add3L(q,te,Fe);n=M.add3H(_,$,P,C),s=_|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:l,l:m}=M.add(this.Eh|0,this.El|0,l|0,m|0),{h:u,l:d}=M.add(this.Fh|0,this.Fl|0,u|0,d|0),{h:p,l:b}=M.add(this.Gh|0,this.Gl|0,p|0,b|0),{h:g,l:w}=M.add(this.Hh|0,this.Hl|0,g|0,w|0),this.set(n,s,i,o,a,c,h,f,l,m,u,d,p,b,g,w)}roundClean(){Ot.fill(0),Pt.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 kr=Ln(()=>new zi);var On={};ge(On,{abytes:()=>Tr,bitGet:()=>Xh,bitLen:()=>Zh,bitMask:()=>en,bitSet:()=>Jh,bytesToHex:()=>gt,bytesToNumberBE:()=>mt,bytesToNumberLE:()=>Vt,concatBytes:()=>yt,createHmacDrbg:()=>ji,ensureBytes:()=>ce,equalBytes:()=>Wh,hexToBytes:()=>Qt,hexToNumber:()=>Gi,isBytes:()=>Mt,numberToBytesBE:()=>Ht,numberToBytesLE:()=>er,numberToHexUnpadded:()=>bc,numberToVarBytesBE:()=>jh,utf8ToBytes:()=>Yh,validateObject:()=>st});var yc=BigInt(0),Dn=BigInt(1),$h=BigInt(2);function Mt(r){return r instanceof Uint8Array||r!=null&&typeof r=="object"&&r.constructor.name==="Uint8Array"}function Tr(r){if(!Mt(r))throw new Error("Uint8Array expected")}var Gh=Array.from({length:256},(r,e)=>e.toString(16).padStart(2,"0"));function gt(r){Tr(r);let e="";for(let t=0;t<r.length;t++)e+=Gh[r[t]];return e}function bc(r){let e=r.toString(16);return e.length&1?`0${e}`:e}function Gi(r){if(typeof r!="string")throw new Error("hex string expected, got "+typeof r);return BigInt(r===""?"0":`0x${r}`)}var pt={_0:48,_9:57,_A:65,_F:70,_a:97,_f:102};function gc(r){if(r>=pt._0&&r<=pt._9)return r-pt._0;if(r>=pt._A&&r<=pt._F)return r-(pt._A-10);if(r>=pt._a&&r<=pt._f)return r-(pt._a-10)}function Qt(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("padded 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=gc(r.charCodeAt(i)),a=gc(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 mt(r){return Gi(gt(r))}function Vt(r){return Tr(r),Gi(gt(Uint8Array.from(r).reverse()))}function Ht(r,e){return Qt(r.toString(16).padStart(e*2,"0"))}function er(r,e){return Ht(r,e).reverse()}function jh(r){return Qt(bc(r))}function ce(r,e,t){let n;if(typeof e=="string")try{n=Qt(e)}catch(i){throw new Error(`${r} must be valid hex string, got "${e}". Cause: ${i}`)}else if(Mt(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} expected ${t} bytes, got ${s}`);return n}function yt(...r){let e=0;for(let n=0;n<r.length;n++){let s=r[n];Tr(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 Wh(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 Yh(r){if(typeof r!="string")throw new Error(`utf8ToBytes expected string, got ${typeof r}`);return new Uint8Array(new TextEncoder().encode(r))}function Zh(r){let e;for(e=0;r>yc;r>>=Dn,e+=1);return e}function Xh(r,e){return r>>BigInt(e)&Dn}function Jh(r,e,t){return r|(t?Dn:yc)<<BigInt(e)}var en=r=>($h<<BigInt(r-1))-Dn,$i=r=>new Uint8Array(r),mc=r=>Uint8Array.from(r);function ji(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=$i(r),s=$i(r),i=0,o=()=>{n.fill(1),s.fill(0),i=0},a=(...l)=>t(s,n,...l),c=(l=$i())=>{s=a(mc([0]),l),n=a(),l.length!==0&&(s=a(mc([1]),l),n=a())},h=()=>{if(i++>=1e3)throw new Error("drbg: tried 1000 values");let l=0,m=[];for(;l<e;){n=a();let u=n.slice();m.push(u),l+=n.length}return yt(...m)};return(l,m)=>{o(),c(l);let u;for(;!(u=m(h()));)c();return o(),u}}var Qh={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"||Mt(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 st(r,e,t={}){let n=(s,i,o)=>{let a=Qh[i];if(typeof a!="function")throw new Error(`Invalid validator "${i}", expected function`);let c=r[s];if(!(o&&c===void 0)&&!a(c,r))throw new Error(`Invalid param ${String(s)}=${c} (${typeof c}), expected ${i}`)};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 pe=BigInt(0),re=BigInt(1),tr=BigInt(2),ed=BigInt(3),Wi=BigInt(4),wc=BigInt(5),xc=BigInt(8),td=BigInt(9),rd=BigInt(16);function Q(r,e){let t=r%e;return t>=pe?t:e+t}function nd(r,e,t){if(t<=pe||e<pe)throw new Error("Expected power/modulo > 0");if(t===re)return pe;let n=re;for(;e>pe;)e&re&&(n=n*r%t),r=r*r%t,e>>=re;return n}function ne(r,e,t){let n=r;for(;e-- >pe;)n*=n,n%=t;return n}function Pn(r,e){if(r===pe||e<=pe)throw new Error(`invert: expected positive integers, got n=${r} mod=${e}`);let t=Q(r,e),n=e,s=pe,i=re,o=re,a=pe;for(;t!==pe;){let h=n/t,f=n%t,l=s-o*h,m=i-a*h;n=t,t=f,s=o,i=a,o=l,a=m}if(n!==re)throw new Error("invert: does not exist");return Q(s,e)}function sd(r){let e=(r-re)/tr,t,n,s;for(t=r-re,n=0;t%tr===pe;t/=tr,n++);for(s=tr;s<r&&nd(s,e,r)!==r-re;s++);if(n===1){let o=(r+re)/Wi;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+re)/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),l=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 u=1;for(let p=a.sqr(m);u<h&&!a.eql(p,a.ONE);u++)p=a.sqr(p);let d=a.pow(f,re<<BigInt(h-u-1));f=a.sqr(d),l=a.mul(l,d),m=a.mul(m,f),h=u}return l}}function id(r){if(r%Wi===ed){let e=(r+re)/Wi;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%xc===wc){let e=(r-wc)/xc;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%rd,sd(r)}var vc=(r,e)=>(Q(r,e)&re)===re,od=["create","isValid","is0","neg","inv","sqrt","sqr","eql","add","sub","mul","pow","div","addN","subN","mulN","sqrN"];function Yi(r){let e={ORDER:"bigint",MASK:"bigint",BYTES:"isSafeInteger",BITS:"isSafeInteger"},t=od.reduce((n,s)=>(n[s]="function",n),e);return st(r,t)}function ad(r,e,t){if(t<pe)throw new Error("Expected power > 0");if(t===pe)return r.ONE;if(t===re)return e;let n=r.ONE,s=e;for(;t>pe;)t&re&&(n=r.mul(n,s)),s=r.sqr(s),t>>=re;return n}function cd(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 Zi(r,e){let t=e!==void 0?e:r.toString(2).length,n=Math.ceil(t/8);return{nBitLength:t,nByteLength:n}}function Mn(r,e,t=!1,n={}){if(r<=pe)throw new Error(`Expected Field ORDER > 0, got ${r}`);let{nBitLength:s,nByteLength:i}=Zi(r,e);if(i>2048)throw new Error("Field lengths over 2048 bytes are not supported");let o=id(r),a=Object.freeze({ORDER:r,BITS:s,BYTES:i,MASK:en(s),ZERO:pe,ONE:re,create:c=>Q(c,r),isValid:c=>{if(typeof c!="bigint")throw new Error(`Invalid field element: expected bigint, got ${typeof c}`);return pe<=c&&c<r},is0:c=>c===pe,isOdd:c=>(c&re)===re,neg:c=>Q(-c,r),eql:(c,h)=>c===h,sqr:c=>Q(c*c,r),add:(c,h)=>Q(c+h,r),sub:(c,h)=>Q(c-h,r),mul:(c,h)=>Q(c*h,r),pow:(c,h)=>ad(a,c,h),div:(c,h)=>Q(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(a,c)),invertBatch:c=>cd(a,c),cmov:(c,h,f)=>f?h:c,toBytes:c=>t?er(c,i):Ht(c,i),fromBytes:c=>{if(c.length!==i)throw new Error(`Fp.fromBytes: expected ${i}, got ${c.length}`);return t?Vt(c):mt(c)}});return Object.freeze(a)}function Ec(r,e){if(!r.isOdd)throw new Error("Field doesn't have isOdd");let t=r.sqrt(e);return r.isOdd(t)?r.neg(t):t}function Ac(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 Xi(r){let e=Ac(r);return e+Math.ceil(e/2)}function Sc(r,e,t=!1){let n=r.length,s=Ac(e),i=Xi(e);if(n<16||n<i||n>1024)throw new Error(`expected ${i}-1024 bytes of input, got ${n}`);let o=t?mt(r):Vt(r),a=Q(o,e-re)+re;return t?er(a,s):Ht(a,s)}var ud=BigInt(0),Ji=BigInt(1);function Vn(r,e){let t=(s,i)=>{let o=i.negate();return s?o:i},n=s=>{let i=Math.ceil(e/s)+1,o=2**(s-1);return{windows:i,windowSize:o}};return{constTimeNegate:t,unsafeLadder(s,i){let o=r.ZERO,a=s;for(;i>ud;)i&Ji&&(o=o.add(a)),a=a.double(),i>>=Ji;return o},precomputeWindow(s,i){let{windows:o,windowSize:a}=n(i),c=[],h=s,f=h;for(let l=0;l<o;l++){f=h,c.push(f);for(let m=1;m<a;m++)f=f.add(h),c.push(f);h=f.double()}return c},wNAF(s,i,o){let{windows:a,windowSize:c}=n(s),h=r.ZERO,f=r.BASE,l=BigInt(2**s-1),m=2**s,u=BigInt(s);for(let d=0;d<a;d++){let p=d*c,b=Number(o&l);o>>=u,b>c&&(b-=m,o+=Ji);let g=p,w=p+Math.abs(b)-1,y=d%2!==0,E=b<0;b===0?f=f.add(t(y,i[g])):h=h.add(t(E,i[w]))}return{p:h,f}},wNAFCached(s,i,o,a){let c=s._WINDOW_SIZE||1,h=i.get(s);return h||(h=this.precomputeWindow(s,c),c!==1&&i.set(s,a(h))),this.wNAF(c,h,o)}}}function tn(r){return Yi(r.Fp),st(r,{n:"bigint",h:"bigint",Gx:"field",Gy:"field"},{nBitLength:"isSafeInteger",nByteLength:"isSafeInteger"}),Object.freeze({...Zi(r.n,r.nBitLength),...r,p:r.Fp.ORDER})}var Xe=BigInt(0),Le=BigInt(1),Hn=BigInt(2),fd=BigInt(8),hd={zip215:!0};function dd(r){let e=tn(r);return st(r,{hash:"function",a:"bigint",d:"bigint",randomBytes:"function"},{adjustScalarBytes:"function",domain:"function",uvRatio:"function",mapToCurve:"function"}),Object.freeze({...e})}function Fn(r){let e=dd(r),{Fp:t,n,prehash:s,hash:i,randomBytes:o,nByteLength:a,h:c}=e,h=Hn<<BigInt(a*8)-Le,f=t.create,l=e.uvRatio||((I,A)=>{try{return{isValid:!0,value:t.sqrt(I*t.inv(A))}}catch{return{isValid:!1,value:Xe}}}),m=e.adjustScalarBytes||(I=>I),u=e.domain||((I,A,R)=>{if(A.length||R)throw new Error("Contexts/pre-hash are not supported");return I}),d=I=>typeof I=="bigint"&&Xe<I,p=(I,A)=>d(I)&&d(A)&&I<A,b=I=>I===Xe||p(I,h);function g(I,A){if(p(I,A))return I;throw new Error(`Expected valid scalar < ${A}, got ${typeof I} ${I}`)}function w(I){return I===Xe?I:g(I,n)}let y=new Map;function E(I){if(!(I instanceof x))throw new Error("ExtendedPoint expected")}class x{constructor(A,R,L,O){if(this.ex=A,this.ey=R,this.ez=L,this.et=O,!b(A))throw new Error("x required");if(!b(R))throw new Error("y required");if(!b(L))throw new Error("z required");if(!b(O))throw new Error("t required")}get x(){return this.toAffine().x}get y(){return this.toAffine().y}static fromAffine(A){if(A instanceof x)throw new Error("extended point not allowed");let{x:R,y:L}=A||{};if(!b(R)||!b(L))throw new Error("invalid affine point");return new x(R,L,Le,f(R*L))}static normalizeZ(A){let R=t.invertBatch(A.map(L=>L.ez));return A.map((L,O)=>L.toAffine(R[O])).map(x.fromAffine)}_setWindowSize(A){this._WINDOW_SIZE=A,y.delete(this)}assertValidity(){let{a:A,d:R}=e;if(this.is0())throw new Error("bad point: ZERO");let{ex:L,ey:O,ez:F,et:K}=this,Y=f(L*L),j=f(O*O),W=f(F*F),ue=f(W*W),ie=f(Y*A),be=f(W*f(ie+j)),we=f(ue+f(R*f(Y*j)));if(be!==we)throw new Error("bad point: equation left != right (1)");let he=f(L*O),Ae=f(F*K);if(he!==Ae)throw new Error("bad point: equation left != right (2)")}equals(A){E(A);let{ex:R,ey:L,ez:O}=this,{ex:F,ey:K,ez:Y}=A,j=f(R*Y),W=f(F*O),ue=f(L*Y),ie=f(K*O);return j===W&&ue===ie}is0(){return this.equals(x.ZERO)}negate(){return new x(f(-this.ex),this.ey,this.ez,f(-this.et))}double(){let{a:A}=e,{ex:R,ey:L,ez:O}=this,F=f(R*R),K=f(L*L),Y=f(Hn*f(O*O)),j=f(A*F),W=R+L,ue=f(f(W*W)-F-K),ie=j+K,be=ie-Y,we=j-K,he=f(ue*be),Ae=f(ie*we),ft=f(ue*we),Zt=f(be*ie);return new x(he,Ae,Zt,ft)}add(A){E(A);let{a:R,d:L}=e,{ex:O,ey:F,ez:K,et:Y}=this,{ex:j,ey:W,ez:ue,et:ie}=A;if(R===BigInt(-1)){let Sa=f((F-O)*(W+j)),Ba=f((F+O)*(W-j)),pi=f(Ba-Sa);if(pi===Xe)return this.double();let _a=f(K*Hn*ie),Ia=f(Y*Hn*ue),ka=Ia+_a,Ta=Ba+Sa,Ra=Ia-_a,Ju=f(ka*pi),Qu=f(Ta*Ra),ef=f(ka*Ra),tf=f(pi*Ta);return new x(Ju,Qu,tf,ef)}let be=f(O*j),we=f(F*W),he=f(Y*L*ie),Ae=f(K*ue),ft=f((O+F)*(j+W)-be-we),Zt=Ae-he,Wr=Ae+he,Aa=f(we-R*be),Wu=f(ft*Zt),Yu=f(Wr*Aa),Zu=f(ft*Aa),Xu=f(Zt*Wr);return new x(Wu,Yu,Xu,Zu)}subtract(A){return this.add(A.negate())}wNAF(A){return B.wNAFCached(this,y,A,x.normalizeZ)}multiply(A){let{p:R,f:L}=this.wNAF(g(A,n));return x.normalizeZ([R,L])[0]}multiplyUnsafe(A){let R=w(A);return R===Xe?v:this.equals(v)||R===Le?this:this.equals(S)?this.wNAF(R).p:B.unsafeLadder(this,R)}isSmallOrder(){return this.multiplyUnsafe(c).is0()}isTorsionFree(){return B.unsafeLadder(this,n).is0()}toAffine(A){let{ex:R,ey:L,ez:O}=this,F=this.is0();A==null&&(A=F?fd:t.inv(O));let K=f(R*A),Y=f(L*A),j=f(O*A);if(F)return{x:Xe,y:Le};if(j!==Le)throw new Error("invZ was invalid");return{x:K,y:Y}}clearCofactor(){let{h:A}=e;return A===Le?this:this.multiplyUnsafe(A)}static fromHex(A,R=!1){let{d:L,a:O}=e,F=t.BYTES;A=ce("pointHex",A,F);let K=A.slice(),Y=A[F-1];K[F-1]=Y&-129;let j=Vt(K);j===Xe||(R?g(j,h):g(j,t.ORDER));let W=f(j*j),ue=f(W-Le),ie=f(L*W-O),{isValid:be,value:we}=l(ue,ie);if(!be)throw new Error("Point.fromHex: invalid y coordinate");let he=(we&Le)===Le,Ae=(Y&128)!==0;if(!R&&we===Xe&&Ae)throw new Error("Point.fromHex: x=0 and x_0=1");return Ae!==he&&(we=f(-we)),x.fromAffine({x:we,y:j})}static fromPrivateKey(A){return P(A).point}toRawBytes(){let{x:A,y:R}=this.toAffine(),L=er(R,t.BYTES);return L[L.length-1]|=A&Le?128:0,L}toHex(){return gt(this.toRawBytes())}}x.BASE=new x(e.Gx,e.Gy,Le,f(e.Gx*e.Gy)),x.ZERO=new x(Xe,Le,Le,Xe);let{BASE:S,ZERO:v}=x,B=Vn(x,a*8);function $(I){return Q(I,n)}function q(I){return $(Vt(I))}function P(I){let A=a;I=ce("private key",I,A);let R=ce("hashed private key",i(I),2*A),L=m(R.slice(0,A)),O=R.slice(A,2*A),F=q(L),K=S.multiply(F),Y=K.toRawBytes();return{head:L,prefix:O,scalar:F,point:K,pointBytes:Y}}function te(I){return P(I).pointBytes}function C(I=new Uint8Array,...A){let R=yt(...A);return q(i(u(R,ce("context",I),!!s)))}function Fe(I,A,R={}){I=ce("message",I),s&&(I=s(I));let{prefix:L,scalar:O,pointBytes:F}=P(A),K=C(R.context,L,I),Y=S.multiply(K).toRawBytes(),j=C(R.context,Y,F,I),W=$(K+j*O);w(W);let ue=yt(Y,er(W,t.BYTES));return ce("result",ue,a*2)}let _=hd;function N(I,A,R,L=_){let{context:O,zip215:F}=L,K=t.BYTES;I=ce("signature",I,2*K),A=ce("message",A),s&&(A=s(A));let Y=Vt(I.slice(K,2*K)),j,W,ue;try{j=x.fromHex(R,F),W=x.fromHex(I.slice(0,K),F),ue=S.multiplyUnsafe(Y)}catch{return!1}if(!F&&j.isSmallOrder())return!1;let ie=C(O,W.toRawBytes(),j.toRawBytes(),A);return W.add(j.multiplyUnsafe(ie)).subtract(ue).clearCofactor().equals(x.ZERO)}return S._setWindowSize(8),{CURVE:e,getPublicKey:te,sign:Fe,verify:N,ExtendedPoint:x,utils:{getExtendedPublicKey:P,randomPrivateKey:()=>o(t.BYTES),precompute(I=8,A=x.BASE){return A._setWindowSize(I),A.multiply(BigInt(3)),A}}}}var eo=BigInt("57896044618658097711785492504343953926634992332820282019728792003956564819949"),Bc=BigInt("19681161376707505956807079304988542015446066515923890162744021073123829784752"),Pm=BigInt(0),pd=BigInt(1),Qi=BigInt(2),gd=BigInt(5),_c=BigInt(10),md=BigInt(20),yd=BigInt(40),Ic=BigInt(80);function bd(r){let e=eo,n=r*r%e*r%e,s=ne(n,Qi,e)*n%e,i=ne(s,pd,e)*r%e,o=ne(i,gd,e)*i%e,a=ne(o,_c,e)*o%e,c=ne(a,md,e)*a%e,h=ne(c,yd,e)*c%e,f=ne(h,Ic,e)*h%e,l=ne(f,Ic,e)*h%e,m=ne(l,_c,e)*o%e;return{pow_p_5_8:ne(m,Qi,e)*r%e,b2:n}}function wd(r){return r[0]&=248,r[31]&=127,r[31]|=64,r}function xd(r,e){let t=eo,n=Q(e*e*e,t),s=Q(n*n*e,t),i=bd(r*s).pow_p_5_8,o=Q(r*n*i,t),a=Q(e*o*o,t),c=o,h=Q(o*Bc,t),f=a===r,l=a===Q(-r,t),m=a===Q(-r*Bc,t);return f&&(o=c),(l||m)&&(o=h),vc(o,t)&&(o=Q(-o,t)),{isValid:f||l,value:o}}var bt=Mn(eo,void 0,!0),to={a:BigInt(-1),d:BigInt("37095705934669439343138083508754565189542113879843219016388785533085940283555"),Fp:bt,n:BigInt("7237005577332262213973186563042994240857116359379907606001950938285454250989"),h:BigInt(8),Gx:BigInt("15112221349535400772501151409588531511454012693041857206046113283949847762202"),Gy:BigInt("46316835694926478169428394003475163141307993866256225615783033603165251855960"),hash:kr,randomBytes:_r,adjustScalarBytes:wd,uvRatio:xd},Rr=Fn(to);function kc(r,e,t){if(e.length>255)throw new Error("Context is too big");return Cn(Ki("SigEd25519 no Ed25519 collisions"),new Uint8Array([t?1:0,e.length]),e,r)}var Mm=Fn({...to,domain:kc}),Vm=Fn({...to,domain:kc,prehash:kr});var vd=(bt.ORDER+BigInt(3))/BigInt(8),Hm=bt.pow(Qi,vd),Fm=bt.sqrt(bt.neg(bt.ONE)),Km=(bt.ORDER-BigInt(5))/BigInt(8),qm=BigInt(486662);var zm=Ec(bt,bt.neg(BigInt(486664)));var $m=BigInt("25063068953384623474111414158702152701244531502492656460079210482610430750235"),Gm=BigInt("54469307008909316920995813868745141605393597292927456921205312896311721017578"),jm=BigInt("1159843021668779879193775521855586647937357759715417654439879720876111806838"),Wm=BigInt("40440834346308536858101042469323190826248399146238708352240133220865137265952");var Ym=BigInt("0x7fffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffff");var Nr=32,wt=64,Kn=32;function Tc(){let r=Rr.utils.randomPrivateKey(),e=Rr.getPublicKey(r);return{privateKey:Lc(r,e),publicKey:e}}function Rc(r){if(r.length!==Kn)throw new TypeError('"seed" must be 32 bytes in length.');if(!(r instanceof Uint8Array))throw new TypeError('"seed" must be a node.js Buffer, or Uint8Array.');let e=r,t=Rr.getPublicKey(e);return{privateKey:Lc(e,t),publicKey:t}}function Nc(r,e){let t=r.subarray(0,Kn);return Rr.sign(e instanceof Uint8Array?e:e.subarray(),t)}function Cc(r,e,t){return Rr.verify(e,t instanceof Uint8Array?t:t.subarray(),r)}function Lc(r,e){let t=new Uint8Array(wt);for(let n=0;n<Kn;n++)t[n]=r[n],t[Kn+n]=e[n];return t}var Te={get(r=globalThis){let e=r.crypto;if(e==null||e.subtle==null)throw Object.assign(new Error("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"),{code:"ERR_MISSING_WEB_CRYPTO"});return e}};var ro={alg:"A128GCM",ext:!0,k:"scm9jmO_4BJAgdwWGVulLg",key_ops:["encrypt","decrypt"],kty:"oct"};function Uc(r){let e=r?.algorithm??"AES-GCM",t=r?.keyLength??16,n=r?.nonceLength??12,s=r?.digest??"SHA-256",i=r?.saltLength??16,o=r?.iterations??32767,a=Te.get();t*=8;async function c(l,m){let u=a.getRandomValues(new Uint8Array(i)),d=a.getRandomValues(new Uint8Array(n)),p={name:e,iv:d};typeof m=="string"&&(m=V(m));let b;if(m.length===0){b=await a.subtle.importKey("jwk",ro,{name:"AES-GCM"},!0,["encrypt"]);try{let w={name:"PBKDF2",salt:u,iterations:o,hash:{name:s}},y=await a.subtle.importKey("raw",m,{name:"PBKDF2"},!1,["deriveKey"]);b=await a.subtle.deriveKey(w,y,{name:e,length:t},!0,["encrypt"])}catch{b=await a.subtle.importKey("jwk",ro,{name:"AES-GCM"},!0,["encrypt"])}}else{let w={name:"PBKDF2",salt:u,iterations:o,hash:{name:s}},y=await a.subtle.importKey("raw",m,{name:"PBKDF2"},!1,["deriveKey"]);b=await a.subtle.deriveKey(w,y,{name:e,length:t},!0,["encrypt"])}let g=await a.subtle.encrypt(p,b,l);return ke([u,p.iv,new Uint8Array(g)])}async function h(l,m){let u=l.subarray(0,i),d=l.subarray(i,i+n),p=l.subarray(i+n),b={name:e,iv:d};typeof m=="string"&&(m=V(m));let g;if(m.length===0)try{let y={name:"PBKDF2",salt:u,iterations:o,hash:{name:s}},E=await a.subtle.importKey("raw",m,{name:"PBKDF2"},!1,["deriveKey"]);g=await a.subtle.deriveKey(y,E,{name:e,length:t},!0,["decrypt"])}catch{g=await a.subtle.importKey("jwk",ro,{name:"AES-GCM"},!0,["decrypt"])}else{let y={name:"PBKDF2",salt:u,iterations:o,hash:{name:s}},E=await a.subtle.importKey("raw",m,{name:"PBKDF2"},!1,["deriveKey"]);g=await a.subtle.deriveKey(y,E,{name:e,length:t},!0,["decrypt"])}let w=await a.subtle.decrypt(b,g,p);return new Uint8Array(w)}return{encrypt:c,decrypt:h}}async function Cr(r,e){let n=await Uc().encrypt(r,e);return Ti.encode(n)}var Sd=Math.pow(2,7),Bd=Math.pow(2,14),_d=Math.pow(2,21),no=Math.pow(2,28),so=Math.pow(2,35),io=Math.pow(2,42),oo=Math.pow(2,49),Z=128,Se=127;function Be(r){if(r<Sd)return 1;if(r<Bd)return 2;if(r<_d)return 3;if(r<no)return 4;if(r<so)return 5;if(r<io)return 6;if(r<oo)return 7;if(Number.MAX_SAFE_INTEGER!=null&&r>Number.MAX_SAFE_INTEGER)throw new RangeError("Could not encode varint");return 8}function ao(r,e,t=0){switch(Be(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 Id(r,e,t=0){switch(Be(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 co(r,e){let t=r[e],n=0;if(n+=t&Se,t<Z||(t=r[e+1],n+=(t&Se)<<7,t<Z)||(t=r[e+2],n+=(t&Se)<<14,t<Z)||(t=r[e+3],n+=(t&Se)<<21,t<Z)||(t=r[e+4],n+=(t&Se)*no,t<Z)||(t=r[e+5],n+=(t&Se)*so,t<Z)||(t=r[e+6],n+=(t&Se)*io,t<Z)||(t=r[e+7],n+=(t&Se)*oo,t<Z))return n;throw new RangeError("Could not decode varint")}function kd(r,e){let t=r.get(e),n=0;if(n+=t&Se,t<Z||(t=r.get(e+1),n+=(t&Se)<<7,t<Z)||(t=r.get(e+2),n+=(t&Se)<<14,t<Z)||(t=r.get(e+3),n+=(t&Se)<<21,t<Z)||(t=r.get(e+4),n+=(t&Se)*no,t<Z)||(t=r.get(e+5),n+=(t&Se)*so,t<Z)||(t=r.get(e+6),n+=(t&Se)*io,t<Z)||(t=r.get(e+7),n+=(t&Se)*oo,t<Z))return n;throw new RangeError("Could not decode varint")}function Ge(r,e,t=0){return e==null&&(e=Ne(Be(r))),e instanceof Uint8Array?ao(r,e,t):Id(r,e,t)}function xt(r,e=0){return r instanceof Uint8Array?co(r,e):kd(r,e)}var lo=new Float32Array([-0]),Ft=new Uint8Array(lo.buffer);function Dc(r,e,t){lo[0]=r,e[t]=Ft[0],e[t+1]=Ft[1],e[t+2]=Ft[2],e[t+3]=Ft[3]}function Oc(r,e){return Ft[0]=r[e],Ft[1]=r[e+1],Ft[2]=r[e+2],Ft[3]=r[e+3],lo[0]}var uo=new Float64Array([-0]),_e=new Uint8Array(uo.buffer);function Pc(r,e,t){uo[0]=r,e[t]=_e[0],e[t+1]=_e[1],e[t+2]=_e[2],e[t+3]=_e[3],e[t+4]=_e[4],e[t+5]=_e[5],e[t+6]=_e[6],e[t+7]=_e[7]}function Mc(r,e){return _e[0]=r[e],_e[1]=r[e+1],_e[2]=r[e+2],_e[3]=r[e+3],_e[4]=r[e+4],_e[5]=r[e+5],_e[6]=r[e+6],_e[7]=r[e+7],uo[0]}var Td=BigInt(Number.MAX_SAFE_INTEGER),Rd=BigInt(Number.MIN_SAFE_INTEGER),Ue=class r{lo;hi;constructor(e,t){this.lo=e|0,this.hi=t|0}toNumber(e=!1){if(!e&&this.hi>>>31>0){let t=~this.lo+1>>>0,n=~this.hi>>>0;return t===0&&(n=n+1>>>0),-(t+n*4294967296)}return this.lo+this.hi*4294967296}toBigInt(e=!1){if(e)return BigInt(this.lo>>>0)+(BigInt(this.hi>>>0)<<32n);if(this.hi>>>31){let t=~this.lo+1>>>0,n=~this.hi>>>0;return t===0&&(n=n+1>>>0),-(BigInt(t)+(BigInt(n)<<32n))}return BigInt(this.lo>>>0)+(BigInt(this.hi>>>0)<<32n)}toString(e=!1){return this.toBigInt(e).toString()}zzEncode(){let e=this.hi>>31;return this.hi=((this.hi<<1|this.lo>>>31)^e)>>>0,this.lo=(this.lo<<1^e)>>>0,this}zzDecode(){let e=-(this.lo&1);return this.lo=((this.lo>>>1|this.hi<<31)^e)>>>0,this.hi=(this.hi>>>1^e)>>>0,this}length(){let e=this.lo,t=(this.lo>>>28|this.hi<<4)>>>0,n=this.hi>>>24;return n===0?t===0?e<16384?e<128?1:2:e<2097152?3:4:t<16384?t<128?5:6:t<2097152?7:8:n<128?9:10}static fromBigInt(e){if(e===0n)return rr;if(e<Td&&e>Rd)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>Vc&&(s=0n,++n>Vc&&(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 Ue(0,0);rr.toBigInt=function(){return 0n};rr.zzEncode=rr.zzDecode=function(){return this};rr.length=function(){return 1};var Vc=4294967296n;function Hc(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 Fc(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 fo(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 zn(r,e){return(r[e-4]|r[e-3]<<8|r[e-2]<<16|r[e-1]<<24)>>>0}var ho=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 zn(this.buf,this.pos+=4)}sfixed32(){if(this.pos+4>this.len)throw Je(this,4);return zn(this.buf,this.pos+=4)|0}float(){if(this.pos+4>this.len)throw Je(this,4);let e=Oc(this.buf,this.pos);return this.pos+=4,e}double(){if(this.pos+8>this.len)throw Je(this,4);let e=Mc(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 Fc(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 Ue(0,0),t=0;if(this.len-this.pos>4){for(;t<4;++t)if(e.lo=(e.lo|(this.buf[this.pos]&127)<<t*7)>>>0,this.buf[this.pos++]<128)return e;if(e.lo=(e.lo|(this.buf[this.pos]&127)<<28)>>>0,e.hi=(e.hi|(this.buf[this.pos]&127)>>4)>>>0,this.buf[this.pos++]<128)return e;t=0}else{for(;t<3;++t){if(this.pos>=this.len)throw Je(this);if(e.lo=(e.lo|(this.buf[this.pos]&127)<<t*7)>>>0,this.buf[this.pos++]<128)return e}return e.lo=(e.lo|(this.buf[this.pos++]&127)<<t*7)>>>0,e}if(this.len-this.pos>4){for(;t<5;++t)if(e.hi=(e.hi|(this.buf[this.pos]&127)<<t*7+3)>>>0,this.buf[this.pos++]<128)return e}else for(;t<5;++t){if(this.pos>=this.len)throw Je(this);if(e.hi=(e.hi|(this.buf[this.pos]&127)<<t*7+3)>>>0,this.buf[this.pos++]<128)return e}throw Error("invalid varint encoding")}readFixed64(){if(this.pos+8>this.len)throw Je(this,8);let e=zn(this.buf,this.pos+=4),t=zn(this.buf,this.pos+=4);return new Ue(e,t)}int64(){return this.readLongVarint().toBigInt()}int64Number(){return this.readLongVarint().toNumber()}int64String(){return this.readLongVarint().toString()}uint64(){return this.readLongVarint().toBigInt(!0)}uint64Number(){let e=co(this.buf,this.pos);return this.pos+=Be(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 po(r){return new ho(r instanceof Uint8Array?r:r.subarray())}function De(r,e,t){let n=po(r);return e.decode(n,void 0,t)}function go(r){let e=r??8192,t=e>>>1,n,s=e;return function(o){if(o<1||o>t)return Ne(o);s+o>e&&(n=Ne(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 mo(){}var bo=class{head;tail;len;next;constructor(e){this.head=e.head,this.tail=e.tail,this.len=e.len,this.next=e.states}},Nd=go();function Cd(r){return globalThis.Buffer!=null?Ne(r):Nd(r)}var nn=class{len;head;tail;states;constructor(){this.len=0,this.head=new nr(mo,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 wo((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($n,10,Ue.fromNumber(e)):this.uint32(e)}sint32(e){return this.uint32((e<<1^e>>31)>>>0)}uint64(e){let t=Ue.fromBigInt(e);return this._push($n,t.length(),t)}uint64Number(e){return this._push(ao,Be(e),e)}uint64String(e){return this.uint64(BigInt(e))}int64(e){return this.uint64(e)}int64Number(e){return this.uint64Number(e)}int64String(e){return this.uint64String(e)}sint64(e){let t=Ue.fromBigInt(e).zzEncode();return this._push($n,t.length(),t)}sint64Number(e){let t=Ue.fromNumber(e).zzEncode();return this._push($n,t.length(),t)}sint64String(e){return this.sint64(BigInt(e))}bool(e){return this._push(yo,1,e?1:0)}fixed32(e){return this._push(rn,4,e>>>0)}sfixed32(e){return this.fixed32(e)}fixed64(e){let t=Ue.fromBigInt(e);return this._push(rn,4,t.lo)._push(rn,4,t.hi)}fixed64Number(e){let t=Ue.fromNumber(e);return this._push(rn,4,t.lo)._push(rn,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(Dc,4,e)}double(e){return this._push(Pc,8,e)}bytes(e){let t=e.length>>>0;return t===0?this._push(yo,1,0):this.uint32(t)._push(Ud,t,e)}string(e){let t=Hc(e);return t!==0?this.uint32(t)._push(fo,t,e):this._push(yo,1,0)}fork(){return this.states=new bo(this),this.head=this.tail=new nr(mo,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(mo,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=Cd(this.len),n=0;for(;e!=null;)e.fn(e.val,t,n),n+=e.len,e=e.next;return t}};function yo(r,e,t){e[t]=r&255}function Ld(r,e,t){for(;r>127;)e[t++]=r&127|128,r>>>=7;e[t]=r}var wo=class extends nr{next;constructor(e,t){super(Ld,e,t),this.next=void 0}};function $n(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 rn(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 Ud(r,e,t){e.set(r,t)}globalThis.Buffer!=null&&(nn.prototype.bytes=function(r){let e=r.length>>>0;return this.uint32(e),e>0&&this._push(Dd,e,r),this},nn.prototype.string=function(r){let e=globalThis.Buffer.byteLength(r);return this.uint32(e),e>0&&this._push(Od,e,r),this});function Dd(r,e,t){e.set(r,t)}function Od(r,e,t){r.length<40?fo(r,e,t):e.utf8Write!=null?e.utf8Write(r,t):e.set(V(r),t)}function xo(){return new nn}function Oe(r,e){let t=xo();return e.encode(r,t,{lengthDelimited:!1}),t.finish()}var Lr;(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"})(Lr||(Lr={}));function Gn(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 Gn("enum",Lr.VARINT,t,n)}function Pe(r,e){return Gn("message",Lr.LENGTH_DELIMITED,r,e)}var sn=class extends Error{code;constructor(e,t,n){super(e,n),this.code=t}};var se;(function(r){r.RSA="RSA",r.Ed25519="Ed25519",r.Secp256k1="Secp256k1"})(se||(se={}));var vo;(function(r){r[r.RSA=0]="RSA",r[r.Ed25519=1]="Ed25519",r[r.Secp256k1=2]="Secp256k1"})(vo||(vo={}));(function(r){r.codec=()=>sr(vo)})(se||(se={}));var it;(function(r){let e;r.codec=()=>(e==null&&(e=Pe((t,n,s={})=>{s.lengthDelimited!==!1&&n.fork(),t.Type!=null&&(n.uint32(8),se.codec().encode(t.Type,n)),t.Data!=null&&(n.uint32(18),n.bytes(t.Data)),s.lengthDelimited!==!1&&n.ldelim()},(t,n)=>{let s={},i=n==null?t.len:t.pos+n;for(;t.pos<i;){let o=t.uint32();switch(o>>>3){case 1:s.Type=se.codec().decode(t);break;case 2:s.Data=t.bytes();break;default:t.skipType(o&7);break}}return s})),e),r.encode=t=>Oe(t,r.codec()),r.decode=t=>De(t,r.codec())})(it||(it={}));var ot;(function(r){let e;r.codec=()=>(e==null&&(e=Pe((t,n,s={})=>{s.lengthDelimited!==!1&&n.fork(),t.Type!=null&&(n.uint32(8),se.codec().encode(t.Type,n)),t.Data!=null&&(n.uint32(18),n.bytes(t.Data)),s.lengthDelimited!==!1&&n.ldelim()},(t,n)=>{let s={},i=n==null?t.len:t.pos+n;for(;t.pos<i;){let o=t.uint32();switch(o>>>3){case 1:s.Type=se.codec().decode(t);break;case 2:s.Data=t.bytes();break;default:t.skipType(o&7);break}}return s})),e),r.encode=t=>Oe(t,r.codec()),r.decode=t=>De(t,r.codec())})(ot||(ot={}));var on=class{_key;constructor(e){this._key=Ur(e,Nr)}verify(e,t){return Cc(this._key,t,e)}marshal(){return this._key}get bytes(){return it.encode({Type:se.Ed25519,Data:this.marshal()}).subarray()}equals(e){return ae(this.bytes,e.bytes)}hash(){let e=me.digest(this.bytes);return $e(e)?e.then(({bytes:t})=>t):e.bytes}},ir=class{_key;_publicKey;constructor(e,t){this._key=Ur(e,wt),this._publicKey=Ur(t,Nr)}sign(e){return Nc(this._key,e)}get public(){return new on(this._publicKey)}marshal(){return this._key}get bytes(){return ot.encode({Type:se.Ed25519,Data:this.marshal()}).subarray()}equals(e){return ae(this.bytes,e.bytes)}async hash(){let e=me.digest(this.bytes),t;return $e(e)?{bytes:t}=await e:t=e.bytes,t}async id(){let e=Ct.digest(this.public.bytes);return de.encode(e.bytes).substring(1)}async export(e,t="libp2p-key"){if(t==="libp2p-key")return Cr(this.bytes,e);throw new U(`export format '${t}' is not supported`,"ERR_INVALID_EXPORT_FORMAT")}};function Pd(r){if(r.length>wt){r=Ur(r,wt+Nr);let n=r.subarray(0,wt),s=r.subarray(wt,r.length);return new ir(n,s)}r=Ur(r,wt);let e=r.subarray(0,wt),t=r.subarray(Nr);return new ir(e,t)}function Md(r){return r=Ur(r,Nr),new on(r)}async function Vd(){let{privateKey:r,publicKey:e}=Tc();return new ir(r,e)}async function qc(r){let{privateKey:e,publicKey:t}=Rc(r);return new ir(e,t)}function Ur(r,e){if(r=Uint8Array.from(r??[]),r.length!==e)throw new U(`Key must be a Uint8Array of length ${e}, got ${r.length}`,"ERR_INVALID_KEY_TYPE");return r}function X(r,e="utf8"){let t=Tn[e];if(t==null)throw new Error(`Unsupported encoding "${e}"`);return t.encoder.encode(r).substring(1)}var Co={};ge(Co,{MAX_RSA_KEY_SIZE:()=>bn,RsaPrivateKey:()=>Vr,RsaPublicKey:()=>yn,fromJwk:()=>hp,generateKeyPair:()=>dp,unmarshalRsaPrivateKey:()=>Ro,unmarshalRsaPublicKey:()=>fp});function at(r){if(isNaN(r)||r<=0)throw new U("random bytes length must be a Number bigger than 0","ERR_INVALID_LENGTH");return _r(r)}var $t={};ge($t,{exportToPem:()=>op,importFromPem:()=>ap,jwkToPkcs1:()=>rp,jwkToPkix:()=>sp,pkcs1ToJwk:()=>tp,pkixToJwk:()=>np});var Wn=class extends Sr{constructor(e,t){super(),this.finished=!1,this.destroyed=!1,Rn(e);let n=Dt(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 Ar(this),this.iHash.update(e),this}digestInto(e){Ar(this),Er(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()}},an=(r,e,t)=>new Wn(r,e).update(t).digest();an.create=(r,e)=>new Wn(r,e);function Hd(r,e,t,n){Rn(r);let s=fc({dkLen:32,asyncTick:10},n),{c:i,dkLen:o,asyncTick:a}=s;if(vr(i),vr(o),vr(a),i<1)throw new Error("PBKDF2: iterations (c) should be >= 1");let c=Dt(e),h=Dt(t),f=new Uint8Array(o),l=an.create(r,c),m=l._cloneInto().update(h);return{c:i,dkLen:o,asyncTick:a,DK:f,PRF:l,PRFSalt:m}}function Fd(r,e,t,n,s){return r.destroy(),e.destroy(),n&&n.destroy(),s.fill(0),t}async function Ao(r,e,t,n){let{c:s,dkLen:i,asyncTick:o,DK:a,PRF:c,PRFSalt:h}=Hd(r,e,t,n),f,l=new Uint8Array(4),m=Br(l),u=new Uint8Array(c.outputLen);for(let d=1,p=0;p<i;d++,p+=c.outputLen){let b=a.subarray(p,p+c.outputLen);m.setInt32(0,d,!1),(f=h._cloneInto(f)).update(l).digestInto(u),b.set(u.subarray(0,b.length)),await uc(s-1,o,()=>{c._cloneInto(f).update(u).digestInto(u);for(let g=0;g<b.length;g++)b[g]^=u[g]})}return Fd(c,h,a,f,u)}var G=mi(zc());function or(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 Kt(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 l=Math.pow(2,f*e);h[i-f-1]=Math.floor(s/l),s-=h[i-f-1]*l}return c}o*=Math.pow(2,e)}return new ArrayBuffer(0)}function Xn(...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 Bo(){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=or(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,or(i,8)-n}function $c(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=Kt(o,8,n),c=new Uint8Array(a);return c[0]|=128,a}let s=Kt(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 Gc(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 Ce(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 nb=Math.log(2);function Jn(){if(typeof BigInt>"u")throw new Error("BigInt is not defined. Your environment doesn't implement BigInt.")}function _o(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 ln=class{constructor(){this.items=[]}write(e){this.items.push(e)}final(){return _o(this.items)}},cn=[new Uint8Array([1])],jc="0123456789";var Pr="",et=new ArrayBuffer(0),Io=new Uint8Array(0),un="EndOfContent",Yc="OCTET STRING",Zc="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?G.BufferSourceConverter.toUint8Array(i.valueHex):Io}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:G.Convert.ToHex(this.valueHexView)}}},e.NAME="hexBlock",e}var Et=class{constructor({blockLength:e=0,error:t=Pr,warnings:n=[],valueBeforeDecode:s=Io}={}){this.blockLength=e,this.error=t,this.warnings=n,this.valueBeforeDecodeView=G.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:G.Convert.ToHex(this.valueBeforeDecodeView)}}};Et.NAME="baseBlock";var Ie=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'")}};Ie.NAME="valueBlock";var Qn=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?G.BufferSourceConverter.toUint8Array(e.valueHex):Io,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=Kt(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=G.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 u=0;u<h.length;u++)m[u]=h[u];h=this.valueHexView=new Uint8Array(f)}}this.blockLength=c+1,h[c-1]=i[c]&127;let l=new Uint8Array(c);for(let m=0;m<c;m++)l[m]=h[m];h=this.valueHexView=new Uint8Array(c),h.set(l),this.blockLength<=9?this.tagNumber=or(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}}};Qn.NAME="identificationBlock";var es=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=G.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=or(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=Kt(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}}};es.NAME="lengthBlock";var T={},ve=class extends Et{constructor({name:e=Pr,optional:t=!1,primitiveSchema:n,...s}={},i){super(s),this.name=e,this.optional=t,n&&(this.primitiveSchema=n),this.idBlock=new Qn(s),this.lenBlock=new es(s),this.valueBlock=i?new i(s):new Ie(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 ln;t||Xc(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():G.Convert.ToHex(this.toBER())}onAsciiEncoding(){return`${this.constructor.NAME} : ${G.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 Gc(t,n)}};ve.NAME="BaseBlock";function Xc(r){if(r instanceof T.Constructed)for(let e of r.valueBlock.value)Xc(e)&&(r.lenBlock.isIndefiniteForm=!0);return!!r.lenBlock.isIndefiniteForm}var ts=class extends ve{constructor({value:e=Pr,...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}'`}};ts.NAME="BaseStringBlock";var rs=class extends _t(Ie){constructor({isHexOnly:e=!0,...t}={}){super(t),this.isHexOnly=e}};rs.NAME="PrimitiveValueBlock";var Jc,ns=class extends ve{constructor(e={}){super(e,rs),this.idBlock.isConstructed=!1}};Jc=ns;T.Primitive=Jc;ns.NAME="PRIMITIVE";function Zd(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 Os(r,e=0,t=r.length){let n=e,s=new ve({},Ie),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=ve;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=T.EndOfContent;break;case 1:c=T.Boolean;break;case 2:c=T.Integer;break;case 3:c=T.BitString;break;case 4:c=T.OctetString;break;case 5:c=T.Null;break;case 6:c=T.ObjectIdentifier;break;case 10:c=T.Enumerated;break;case 12:c=T.Utf8String;break;case 13:c=T.RelativeObjectIdentifier;break;case 14:c=T.TIME;break;case 15:return s.error="[UNIVERSAL 15] is reserved by ASN.1 standard",{offset:-1,result:s};case 16:c=T.Sequence;break;case 17:c=T.Set;break;case 18:c=T.NumericString;break;case 19:c=T.PrintableString;break;case 20:c=T.TeletexString;break;case 21:c=T.VideotexString;break;case 22:c=T.IA5String;break;case 23:c=T.UTCTime;break;case 24:c=T.GeneralizedTime;break;case 25:c=T.GraphicString;break;case 26:c=T.VisibleString;break;case 27:c=T.GeneralString;break;case 28:c=T.UniversalString;break;case 29:c=T.CharacterString;break;case 30:c=T.BmpString;break;case 31:c=T.DATE;break;case 32:c=T.TimeOfDay;break;case 33:c=T.DateTime;break;case 34:c=T.Duration;break;default:{let h=s.idBlock.isConstructed?new T.Constructed:new T.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?T.Constructed:T.Primitive}return s=Zd(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 Mr(r){if(!r.byteLength){let e=new ve({},Ie);return e.error="Input buffer has zero length",{offset:-1,result:e}}return Os(G.BufferSourceConverter.toUint8Array(r).slice(),0,r.byteLength)}function Xd(r,e){return r?1:e}var ct=class extends Ie{constructor({value:e=[],isIndefiniteForm:t=!1,...n}={}){super(n),this.value=e,this.isIndefiniteForm=t}fromBER(e,t,n){let s=G.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(;Xd(this.isIndefiniteForm,n)>0;){let o=Os(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===un)break}return this.isIndefiniteForm&&(this.value[this.value.length-1].constructor.NAME===un?this.value.pop():this.warnings.push("No EndOfContent block encoded")),i}toBER(e,t){let n=t||new ln;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 Qc,qt=class extends ve{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
4
|
`));let t=this.idBlock.tagClass===3?`[${this.idBlock.tagNumber}]`:this.constructor.NAME;return e.length?`${t} :
|
5
5
|
${e.join(`
|
6
|
-
`)}`:`${t} :`}};Xc=qt;T.Constructed=Xc;qt.NAME="CONSTRUCTED";var ss=class extends Ie{fromBER(e,t,n){return t}toBER(e){return et}};ss.override="EndOfContentValueBlock";var Jc,is=class extends ve{constructor(e={}){super(e,ss),this.idBlock.tagClass=1,this.idBlock.tagNumber=0}};Jc=is;T.EndOfContent=Jc;is.NAME=un;var Qc,zt=class extends ve{constructor(e={}){super(e,Ie),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}`}};Qc=zt;T.Null=Qc;zt.NAME="NULL";var os=class extends _t(Ie){constructor({value:e,...t}={}){super(t),t.valueHex?this.valueHexView=G.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=G.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,Bo.call(this),this.blockLength=n,t+n):-1}toBER(){return this.valueHexView.slice()}toJSON(){return{...super.toJSON(),value:this.value}}};os.NAME="BooleanValueBlock";var el,as=class extends ve{constructor(e={}){super(e,os),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}`}};el=as;T.Boolean=el;as.NAME="BOOLEAN";var cs=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===un){if(this.isIndefiniteForm)break;return this.error="EndOfContent is unexpected, OCTET STRING may consists of OCTET STRINGs only",-1}if(o!==jc)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}}};cs.NAME="OctetStringValueBlock";var tl,At=class r extends ve{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},cs),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=Os(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?qt.prototype.onAsciiEncoding.call(this):`${this.constructor.NAME} : ${G.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 G.BufferSourceConverter.concat(e)}};tl=At;T.OctetString=tl;At.NAME=jc;var ls=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===un){if(this.isIndefiniteForm)break;return this.error="EndOfContent is unexpected, BIT STRING may consists of BIT STRINGs only",-1}if(c!==Wc)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=G.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=Os(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}}};ls.NAME="BitStringValueBlock";var rl,Or=class extends ve{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},ls),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 qt.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)}`}}};rl=Or;T.BitString=rl;Or.NAME=Wc;var nl;function Zd(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,l=0;for(let m=f;m>=0;m--,l++){switch(!0){case l<a.length:h=i[o-l]+a[c-l]+t[0];break;default:h=i[o-l]+t[0]}switch(t[0]=h/10,!0){case l>=i.length:i=Xn(new Uint8Array([h%10]),i);break;default:i[o-l]=h%10}}return t[0]>0&&(i=Xn(t,i)),i}function Gc(r){if(r>=cn.length)for(let e=cn.length;e<=r;e++){let t=new Uint8Array([0]),n=cn[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=Xn(t,n)),cn.push(n)}return cn[r]}function Xd(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 l=c;l>=0;l--,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 l=o-c+1;l>=0;l--,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 fn=class extends _t(Ie){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=Bo.call(this)))}set valueDec(e){this._valueDec=e,this.isHexOnly=!1,this.valueHexView=new Uint8Array(qc(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=Xd(Gc(n),t),o="-";break;default:t=Zd(t,Gc(n))}n++,s>>=1}}for(let c=0;c<t.length;c++)t[c]&&(a=!0),a&&(o+=$c.charAt(t[c]));return a===!1&&(o+=$c.charAt(0)),o}};nl=fn;fn.NAME="IntegerValueBlock";Object.defineProperty(nl.prototype,"valueHex",{set:function(r){this.valueHexView=new Uint8Array(r),this.setValueHex()},get:function(){return this.valueHexView.slice().buffer}});var sl,fe=class r extends ve{constructor(e={}){super(e,fn),this.idBlock.tagClass=1,this.idBlock.tagNumber=2}toBigInt(){return Jn(),BigInt(this.valueBlock.toString())}static fromBigInt(e){Jn();let t=BigInt(e),n=new ln,s=t.toString(16).replace(/^-/,""),i=new Uint8Array(G.Convert.FromHex(s));if(t<0){let a=new Uint8Array(i.length+(i[0]&128?1:0));a[0]|=128;let h=BigInt(`0x${G.Convert.ToHex(a)}`)+t,f=G.BufferSourceConverter.toUint8Array(G.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()}`}};sl=fe;T.Integer=sl;fe.NAME="INTEGER";var il,us=class extends fe{constructor(e={}){super(e),this.idBlock.tagClass=1,this.idBlock.tagNumber=10}};il=us;T.Enumerated=il;us.NAME="ENUMERATED";var hn=class extends _t(Ie){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=G.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=or(this.valueHexView,7):(this.isHexOnly=!0,this.warnings.push("Too big SID for decoding, hex only")),t+this.blockLength)}set valueBigInt(e){Jn();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=Kt(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=G.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}}};hn.NAME="sidBlock";var fs=class extends Ie{constructor({value:e=Pr,...t}={}){super(t),this.value=[],e&&this.fromString(e)}fromBER(e,t,n){let s=t;for(;n>0;){let i=new hn;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 _o(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 hn;if(s>Number.MAX_SAFE_INTEGER){Jn();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}};fs.NAME="ObjectIdentifierValueBlock";var ol,Qe=class extends ve{constructor(e={}){super(e,fs),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()}}};ol=Qe;T.ObjectIdentifier=ol;Qe.NAME="OBJECT IDENTIFIER";var dn=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=G.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=or(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=Kt(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=G.Convert.ToHex(this.valueHexView):e=this.valueDec.toString(),e}toJSON(){return{...super.toJSON(),valueDec:this.valueDec}}};dn.NAME="relativeSidBlock";var hs=class extends Ie{constructor({value:e=Pr,...t}={}){super(t),this.value=[],e&&this.fromString(e)}fromBER(e,t,n){let s=t;for(;n>0;){let i=new dn;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 _o(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 dn;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}};hs.NAME="RelativeObjectIdentifierValueBlock";var al,ds=class extends ve{constructor(e={}){super(e,hs),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()}}};al=ds;T.RelativeObjectIdentifier=al;ds.NAME="RelativeObjectIdentifier";var cl,ye=class extends qt{constructor(e={}){super(e),this.idBlock.tagClass=1,this.idBlock.tagNumber=16}};cl=ye;T.Sequence=cl;ye.NAME="SEQUENCE";var ll,ps=class extends qt{constructor(e={}){super(e),this.idBlock.tagClass=1,this.idBlock.tagNumber=17}};ll=ps;T.Set=ll;ps.NAME="SET";var gs=class extends _t(Ie){constructor({...e}={}){super(e),this.isHexOnly=!0,this.value=Pr}toJSON(){return{...super.toJSON(),value:this.value}}};gs.NAME="StringValueBlock";var ms=class extends gs{};ms.NAME="SimpleStringValueBlock";var Re=class extends ts{constructor({...e}={}){super(e,ms)}fromBuffer(e){this.valueBlock.value=String.fromCharCode.apply(null,G.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}};Re.NAME="SIMPLE STRING";var ys=class extends Re{fromBuffer(e){this.valueBlock.valueHexView=G.BufferSourceConverter.toUint8Array(e);try{this.valueBlock.value=G.Convert.ToUtf8String(e)}catch(t){this.warnings.push(`Error during "decodeURIComponent": ${t}, using raw string`),this.valueBlock.value=G.Convert.ToBinary(e)}}fromString(e){this.valueBlock.valueHexView=new Uint8Array(G.Convert.FromUtf8String(e)),this.valueBlock.value=e}};ys.NAME="Utf8StringValueBlock";var ul,St=class extends ys{constructor(e={}){super(e),this.idBlock.tagClass=1,this.idBlock.tagNumber=12}};ul=St;T.Utf8String=ul;St.NAME="UTF8String";var bs=class extends Re{fromBuffer(e){this.valueBlock.value=G.Convert.ToUtf16String(e),this.valueBlock.valueHexView=G.BufferSourceConverter.toUint8Array(e)}fromString(e){this.valueBlock.value=e,this.valueBlock.valueHexView=new Uint8Array(G.Convert.FromUtf16String(e))}};bs.NAME="BmpStringValueBlock";var fl,ws=class extends bs{constructor({...e}={}){super(e),this.idBlock.tagClass=1,this.idBlock.tagNumber=30}};fl=ws;T.BmpString=fl;ws.NAME="BMPString";var xs=class extends Re{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=Kt(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}};xs.NAME="UniversalStringValueBlock";var hl,vs=class extends xs{constructor({...e}={}){super(e),this.idBlock.tagClass=1,this.idBlock.tagNumber=28}};hl=vs;T.UniversalString=hl;vs.NAME="UniversalString";var dl,Es=class extends Re{constructor(e={}){super(e),this.idBlock.tagClass=1,this.idBlock.tagNumber=18}};dl=Es;T.NumericString=dl;Es.NAME="NumericString";var pl,As=class extends Re{constructor(e={}){super(e),this.idBlock.tagClass=1,this.idBlock.tagNumber=19}};pl=As;T.PrintableString=pl;As.NAME="PrintableString";var gl,Ss=class extends Re{constructor(e={}){super(e),this.idBlock.tagClass=1,this.idBlock.tagNumber=20}};gl=Ss;T.TeletexString=gl;Ss.NAME="TeletexString";var ml,Bs=class extends Re{constructor(e={}){super(e),this.idBlock.tagClass=1,this.idBlock.tagNumber=21}};ml=Bs;T.VideotexString=ml;Bs.NAME="VideotexString";var yl,_s=class extends Re{constructor(e={}){super(e),this.idBlock.tagClass=1,this.idBlock.tagNumber=22}};yl=_s;T.IA5String=yl;_s.NAME="IA5String";var bl,Is=class extends Re{constructor(e={}){super(e),this.idBlock.tagClass=1,this.idBlock.tagNumber=25}};bl=Is;T.GraphicString=bl;Is.NAME="GraphicString";var wl,pn=class extends Re{constructor(e={}){super(e),this.idBlock.tagClass=1,this.idBlock.tagNumber=26}};wl=pn;T.VisibleString=wl;pn.NAME="VisibleString";var xl,ks=class extends Re{constructor(e={}){super(e),this.idBlock.tagClass=1,this.idBlock.tagNumber=27}};xl=ks;T.GeneralString=xl;ks.NAME="GeneralString";var vl,Ts=class extends Re{constructor(e={}){super(e),this.idBlock.tagClass=1,this.idBlock.tagNumber=29}};vl=Ts;T.CharacterString=vl;Ts.NAME="CharacterString";var El,gn=class extends pn{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,G.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]=Ce(this.year<2e3?this.year-1900:this.year-2e3,2),t[1]=Ce(this.month,2),t[2]=Ce(this.day,2),t[3]=Ce(this.hour,2),t[4]=Ce(this.minute,2),t[5]=Ce(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}}};El=gn;T.UTCTime=El;gn.NAME="UTCTime";var Al,Rs=class extends gn{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 l=new Number(e[e.length-1]);if(isNaN(l.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 l=1,m=n.indexOf("+"),u="";if(m===-1&&(m=n.indexOf("-"),l=-1),m!==-1){if(u=n.substring(m+1),n=n.substring(0,m),u.length!==2&&u.length!==4)throw new Error("Wrong input string for conversion");let d=parseInt(u.substring(0,2),10);if(isNaN(d.valueOf()))throw new Error("Wrong input string for conversion");if(a=l*d,u.length===4){if(d=parseInt(u.substring(2,4),10),isNaN(d.valueOf()))throw new Error("Wrong input string for conversion");c=l*d}}}let h=n.indexOf(".");if(h===-1&&(h=n.indexOf(",")),h!==-1){let l=new Number(`0${n.substring(h)}`);if(isNaN(l.valueOf()))throw new Error("Wrong input string for conversion");i=l.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 l=60*i;this.minute=Math.floor(l),l=60*(l-this.minute),this.second=Math.floor(l),l=1e3*(l-this.second),this.millisecond=Math.floor(l)}break;case s.length===12:if(o=/(\d{4})(\d{2})(\d{2})(\d{2})(\d{2})/ig,h!==-1){let l=60*i;this.second=Math.floor(l),l=1e3*(l-this.second),this.millisecond=Math.floor(l)}break;case s.length===14:if(o=/(\d{4})(\d{2})(\d{2})(\d{2})(\d{2})(\d{2})/ig,h!==-1){let l=1e3*i;this.millisecond=Math.floor(l)}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 l=1;l<f.length;l++)switch(l){case 1:this.year=parseInt(f[l],10);break;case 2:this.month=parseInt(f[l],10);break;case 3:this.day=parseInt(f[l],10);break;case 4:this.hour=parseInt(f[l],10)+a;break;case 5:this.minute=parseInt(f[l],10)+c;break;case 6:this.second=parseInt(f[l],10);break;default:throw new Error("Wrong input string for conversion")}if(t===!1){let l=new Date(this.year,this.month,this.day,this.hour,this.minute,this.second,this.millisecond);this.year=l.getUTCFullYear(),this.month=l.getUTCMonth(),this.day=l.getUTCDay(),this.hour=l.getUTCHours(),this.minute=l.getUTCMinutes(),this.second=l.getUTCSeconds(),this.millisecond=l.getUTCMilliseconds()}}toString(e="iso"){if(e==="iso"){let t=[];return t.push(Ce(this.year,4)),t.push(Ce(this.month,2)),t.push(Ce(this.day,2)),t.push(Ce(this.hour,2)),t.push(Ce(this.minute,2)),t.push(Ce(this.second,2)),this.millisecond!==0&&(t.push("."),t.push(Ce(this.millisecond,3))),t.push("Z"),t.join("")}return super.toString(e)}toJSON(){return{...super.toJSON(),millisecond:this.millisecond}}};Al=Rs;T.GeneralizedTime=Al;Rs.NAME="GeneralizedTime";var Sl,Ns=class extends St{constructor(e={}){super(e),this.idBlock.tagClass=1,this.idBlock.tagNumber=31}};Sl=Ns;T.DATE=Sl;Ns.NAME="DATE";var Bl,Cs=class extends St{constructor(e={}){super(e),this.idBlock.tagClass=1,this.idBlock.tagNumber=32}};Bl=Cs;T.TimeOfDay=Bl;Cs.NAME="TimeOfDay";var _l,Ls=class extends St{constructor(e={}){super(e),this.idBlock.tagClass=1,this.idBlock.tagNumber=33}};_l=Ls;T.DateTime=_l;Ls.NAME="DateTime";var Il,Us=class extends St{constructor(e={}){super(e),this.idBlock.tagClass=1,this.idBlock.tagNumber=34}};Il=Us;T.Duration=Il;Us.NAME="Duration";var kl,Ds=class extends St{constructor(e={}){super(e),this.idBlock.tagClass=1,this.idBlock.tagNumber=14}};kl=Ds;T.TIME=kl;Ds.NAME="TIME";function Qd(r){let{result:e}=Mr(r),t=e.valueBlock.value;return{n:X(lt(t[1].toBigInt()),"base64url"),e:X(lt(t[2].toBigInt()),"base64url"),d:X(lt(t[3].toBigInt()),"base64url"),p:X(lt(t[4].toBigInt()),"base64url"),q:X(lt(t[5].toBigInt()),"base64url"),dp:X(lt(t[6].toBigInt()),"base64url"),dq:X(lt(t[7].toBigInt()),"base64url"),qi:X(lt(t[8].toBigInt()),"base64url"),kty:"RSA",alg:"RS256"}}function ep(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 U("JWK was missing components","ERR_INVALID_PARAMETERS");let t=new ye({value:[new fe({value:0}),fe.fromBigInt(ut(V(r.n,"base64url"))),fe.fromBigInt(ut(V(r.e,"base64url"))),fe.fromBigInt(ut(V(r.d,"base64url"))),fe.fromBigInt(ut(V(r.p,"base64url"))),fe.fromBigInt(ut(V(r.q,"base64url"))),fe.fromBigInt(ut(V(r.dp,"base64url"))),fe.fromBigInt(ut(V(r.dq,"base64url"))),fe.fromBigInt(ut(V(r.qi,"base64url")))]}).toBER();return new Uint8Array(t,0,t.byteLength)}function tp(r){let{result:e}=Mr(r),t=e.valueBlock.value[1].valueBlock.value[0].valueBlock.value;return{kty:"RSA",n:X(lt(t[0].toBigInt()),"base64url"),e:X(lt(t[1].toBigInt()),"base64url")}}function rp(r){if(r.n==null||r.e==null)throw new U("JWK was missing components","ERR_INVALID_PARAMETERS");let t=new ye({value:[new ye({value:[new Qe({value:"1.2.840.113549.1.1.1"}),new zt]}),new Or({valueHex:new ye({value:[fe.fromBigInt(ut(V(r.n,"base64url"))),fe.fromBigInt(ut(V(r.e,"base64url")))]}).toBER()})]}).toBER();return new Uint8Array(t,0,t.byteLength)}function lt(r){let e=r.toString(16);e.length%2>0&&(e=`0${e}`);let t=e.length/2,n=new Uint8Array(t),s=0,i=0;for(;s<t;)n[s]=parseInt(e.slice(i,i+2),16),s+=1,i+=2;return n}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(""))}var np=16,ko=32,To=1e4;async function sp(r,e){let t=Te.get(),s=new ye({value:[new fe({value:0}),new ye({value:[new Qe({value:"1.2.840.113549.1.1.1"}),new zt]}),new At({valueHex:r.marshal()})]}).toBER(),i=new Uint8Array(s,0,s.byteLength),o=at(np),a=await Ao(kr,e,o,{c:To,dkLen:ko}),c=at(16),h=await t.subtle.importKey("raw",a,"AES-CBC",!1,["encrypt"]),f=await t.subtle.encrypt({name:"AES-CBC",iv:c},h,i),l=new ye({value:[new At({valueHex:o}),new fe({value:To}),new fe({value:ko}),new ye({value:[new Qe({value:"1.2.840.113549.2.11"}),new zt]})]}),m=new ye({value:[new Qe({value:"1.2.840.113549.1.5.13"}),new ye({value:[new ye({value:[new Qe({value:"1.2.840.113549.1.5.12"}),l]}),new ye({value:[new Qe({value:"2.16.840.1.101.3.4.1.42"}),new At({valueHex:c})]})]})]}),d=new ye({value:[m,new At({valueHex:f})]}).toBER(),p=new Uint8Array(d,0,d.byteLength);return["-----BEGIN ENCRYPTED PRIVATE KEY-----",...X(p,"base64pad").split(/(.{64})/).filter(Boolean),"-----END ENCRYPTED PRIVATE KEY-----"].join(`
|
7
|
-
`)}async function ip(r,e){let t=Te.get(),n;if(r.includes("-----BEGIN ENCRYPTED PRIVATE KEY-----")){let s=V(r.replace("-----BEGIN ENCRYPTED PRIVATE KEY-----","").replace("-----END ENCRYPTED PRIVATE KEY-----","").replace(/\n/g,"").trim(),"base64pad"),{result:i}=Mr(s),{iv:o,salt:a,iterations:c,keySize:h,cipherText:f}=op(i),l=await Ao(kr,e,a,{c,dkLen:h}),m=await t.subtle.importKey("raw",l,"AES-CBC",!1,["decrypt"]),u=mn(await t.subtle.decrypt({name:"AES-CBC",iv:o},m,f)),{result:d}=Mr(u);n=Tl(d)}else if(r.includes("-----BEGIN PRIVATE KEY-----")){let s=V(r.replace("-----BEGIN PRIVATE KEY-----","").replace("-----END PRIVATE KEY-----","").replace(/\n/g,"").trim(),"base64pad"),{result:i}=Mr(s);n=Tl(i)}else throw new U("Could not parse private key from PEM data","ERR_INVALID_PARAMETERS");return Ro(n)}function op(r){let e=r.valueBlock.value[0];if(e.valueBlock.value[0].toString()!=="OBJECT IDENTIFIER : 1.2.840.113549.1.5.13")throw new U("Only pkcs5PBES2 encrypted private keys are supported","ERR_INVALID_PARAMS");let n=e.valueBlock.value[1].valueBlock.value[0];if(n.valueBlock.value[0].toString()!=="OBJECT IDENTIFIER : 1.2.840.113549.1.5.12")throw new U("Only pkcs5PBKDF2 key derivation functions are supported","ERR_INVALID_PARAMS");let i=n.valueBlock.value[1],o=mn(i.valueBlock.value[0].getValue()),a=To,c=ko;if(i.valueBlock.value.length===3)a=Number(i.valueBlock.value[1].toBigInt()),c=Number(i.valueBlock.value[2].toBigInt());else if(i.valueBlock.value.length===2)throw new U("Could not derive key size and iterations from PEM file - please use @libp2p/rsa to re-import your key","ERR_INVALID_PARAMS");let h=e.valueBlock.value[1].valueBlock.value[1],f=h.valueBlock.value[0].toString();if(f!=="OBJECT IDENTIFIER : 1.2.840.113549.3.7"){if(f!=="OBJECT IDENTIFIER : 1.3.14.3.2.7"){if(f!=="OBJECT IDENTIFIER : 2.16.840.1.101.3.4.1.2"){if(f!=="OBJECT IDENTIFIER : 2.16.840.1.101.3.4.1.22"){if(f!=="OBJECT IDENTIFIER : 2.16.840.1.101.3.4.1.42")throw new U("Only AES-CBC encryption schemes are supported","ERR_INVALID_PARAMS")}}}}let l=mn(h.valueBlock.value[1].getValue());return{cipherText:mn(r.valueBlock.value[1].getValue()),salt:o,iterations:a,keySize:c,iv:l}}function Tl(r){return mn(r.valueBlock.value[2].getValue())}function mn(r){return new Uint8Array(r,0,r.byteLength)}async function Rl(r){let e=await Te.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 Ll(e);return{privateKey:t[0],publicKey:t[1]}}async function No(r){let t=[await Te.get().subtle.importKey("jwk",r,{name:"RSASSA-PKCS1-v1_5",hash:{name:"SHA-256"}},!0,["sign"]),await ap(r)],n=await Ll({privateKey:t[0],publicKey:t[1]});return{privateKey:n[0],publicKey:n[1]}}async function Nl(r,e){let t=await Te.get().subtle.importKey("jwk",r,{name:"RSASSA-PKCS1-v1_5",hash:{name:"SHA-256"}},!1,["sign"]),n=await Te.get().subtle.sign({name:"RSASSA-PKCS1-v1_5"},t,e instanceof Uint8Array?e:e.subarray());return new Uint8Array(n,0,n.byteLength)}async function Cl(r,e,t){let n=await Te.get().subtle.importKey("jwk",r,{name:"RSASSA-PKCS1-v1_5",hash:{name:"SHA-256"}},!1,["verify"]);return Te.get().subtle.verify({name:"RSASSA-PKCS1-v1_5"},n,e,t instanceof Uint8Array?t:t.subarray())}async function Ll(r){if(r.privateKey==null||r.publicKey==null)throw new U("Private and public key are required","ERR_INVALID_PARAMETERS");return Promise.all([Te.get().subtle.exportKey("jwk",r.privateKey),Te.get().subtle.exportKey("jwk",r.publicKey)])}async function ap(r){return Te.get().subtle.importKey("jwk",{kty:r.kty,n:r.n,e:r.e},{name:"RSASSA-PKCS1-v1_5",hash:{name:"SHA-256"}},!0,["verify"])}function Ps(r){if(r.kty!=="RSA")throw new U("invalid key type","ERR_INVALID_KEY_TYPE");if(r.n==null)throw new U("invalid key modulus","ERR_INVALID_KEY_MODULUS");return V(r.n,"base64url").length*8}var bn=8192,yn=class{_key;constructor(e){this._key=e}verify(e,t){return Cl(this._key,t,e)}marshal(){return $t.jwkToPkix(this._key)}get bytes(){return it.encode({Type:se.RSA,Data:this.marshal()}).subarray()}equals(e){return ae(this.bytes,e.bytes)}hash(){let e=me.digest(this.bytes);return $e(e)?e.then(({bytes:t})=>t):e.bytes}},Vr=class{_key;_publicKey;constructor(e,t){this._key=e,this._publicKey=t}genSecret(){return at(16)}sign(e){return Nl(this._key,e)}get public(){if(this._publicKey==null)throw new U("public key not provided","ERR_PUBKEY_NOT_PROVIDED");return new yn(this._publicKey)}marshal(){return $t.jwkToPkcs1(this._key)}get bytes(){return ot.encode({Type:se.RSA,Data:this.marshal()}).subarray()}equals(e){return ae(this.bytes,e.bytes)}hash(){let e=me.digest(this.bytes);return $e(e)?e.then(({bytes:t})=>t):e.bytes}async id(){let e=await this.public.hash();return X(e,"base58btc")}async export(e,t="pkcs-8"){if(t==="pkcs-8")return $t.exportToPem(this,e);if(t==="libp2p-key")return Cr(this.bytes,e);throw new U(`export format '${t}' is not supported`,"ERR_INVALID_EXPORT_FORMAT")}};async function Ro(r){let e=$t.pkcs1ToJwk(r);if(Ps(e)>bn)throw new U("key size is too large","ERR_KEY_SIZE_TOO_LARGE");let t=await No(e);return new Vr(t.privateKey,t.publicKey)}function lp(r){let e=$t.pkixToJwk(r);if(Ps(e)>bn)throw new U("key size is too large","ERR_KEY_SIZE_TOO_LARGE");return new yn(e)}async function up(r){if(Ps(r)>bn)throw new U("key size is too large","ERR_KEY_SIZE_TOO_LARGE");let e=await No(r);return new Vr(e.privateKey,e.publicKey)}async function fp(r){if(r>bn)throw new U("key size is too large","ERR_KEY_SIZE_TOO_LARGE");let e=await Rl(r);return new Vr(e.privateKey,e.publicKey)}var Po={};ge(Po,{Secp256k1PrivateKey:()=>xn,Secp256k1PublicKey:()=>wn,generateKeyPair:()=>Sp,unmarshalSecp256k1PrivateKey:()=>Ep,unmarshalSecp256k1PublicKey:()=>Ap});var hp=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]),Gt=new Uint32Array([1779033703,3144134277,1013904242,2773480762,1359893119,2600822924,528734635,1541459225]),jt=new Uint32Array(64),Lo=class extends Ir{constructor(){super(64,32,8,!1),this.A=Gt[0]|0,this.B=Gt[1]|0,this.C=Gt[2]|0,this.D=Gt[3]|0,this.E=Gt[4]|0,this.F=Gt[5]|0,this.G=Gt[6]|0,this.H=Gt[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 l=0;l<16;l++,t+=4)jt[l]=e.getUint32(t,!1);for(let l=16;l<64;l++){let m=jt[l-15],u=jt[l-2],d=Ze(m,7)^Ze(m,18)^m>>>3,p=Ze(u,17)^Ze(u,19)^u>>>10;jt[l]=p+jt[l-7]+d+jt[l-16]|0}let{A:n,B:s,C:i,D:o,E:a,F:c,G:h,H:f}=this;for(let l=0;l<64;l++){let m=Ze(a,6)^Ze(a,11)^Ze(a,25),u=f+m+uc(a,c,h)+hp[l]+jt[l]|0,p=(Ze(n,2)^Ze(n,13)^Ze(n,22))+fc(n,s,i)|0;f=h,h=c,c=a,a=o+u|0,o=i,i=s,s=n,n=u+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(){jt.fill(0)}destroy(){this.set(0,0,0,0,0,0,0,0),this.buffer.fill(0)}};var Ul=Ln(()=>new Lo);function dp(r){let e=tn(r);st(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("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("Expected endomorphism with beta: bigint and splitScalar: function")}return Object.freeze({...e})}var{bytesToNumberBE:pp,hexToBytes:gp}=On,ar={Err:class extends Error{constructor(e=""){super(e)}},_parseInt(r){let{Err:e}=ar;if(r.length<2||r[0]!==2)throw new e("Invalid signature integer tag");let t=r[1],n=r.subarray(2,t+2);if(!t||n.length!==t)throw new e("Invalid signature integer: wrong length");if(n[0]&128)throw new e("Invalid signature integer: negative");if(n[0]===0&&!(n[1]&128))throw new e("Invalid signature integer: unnecessary leading zero");return{d:pp(n),l:r.subarray(t+2)}},toSig(r){let{Err:e}=ar,t=typeof r=="string"?gp(r):r;Tr(t);let n=t.length;if(n<2||t[0]!=48)throw new e("Invalid signature tag");if(t[1]!==n-2)throw new e("Invalid signature: incorrect length");let{d:s,l:i}=ar._parseInt(t.subarray(2)),{d:o,l:a}=ar._parseInt(i);if(a.length)throw new e("Invalid signature: left bytes after parsing");return{r:s,s:o}},hexFromSig(r){let e=h=>Number.parseInt(h[0],16)&8?"00"+h:h,t=h=>{let f=h.toString(16);return f.length&1?`0${f}`:f},n=e(t(r.s)),s=e(t(r.r)),i=n.length/2,o=s.length/2,a=t(i),c=t(o);return`30${t(o+i+4)}02${c}${s}02${a}${n}`}},It=BigInt(0),We=BigInt(1),sb=BigInt(2),Dl=BigInt(3),ib=BigInt(4);function mp(r){let e=dp(r),{Fp:t}=e,n=e.toBytes||((d,p,b)=>{let g=p.toAffine();return yt(Uint8Array.from([4]),t.toBytes(g.x),t.toBytes(g.y))}),s=e.fromBytes||(d=>{let p=d.subarray(1),b=t.fromBytes(p.subarray(0,t.BYTES)),g=t.fromBytes(p.subarray(t.BYTES,2*t.BYTES));return{x:b,y:g}});function i(d){let{a:p,b}=e,g=t.sqr(d),w=t.mul(g,d);return t.add(t.add(w,t.mul(d,p)),b)}if(!t.eql(t.sqr(e.Gy),i(e.Gx)))throw new Error("bad generator point: equation left != right");function o(d){return typeof d=="bigint"&&It<d&&d<e.n}function a(d){if(!o(d))throw new Error("Expected valid bigint: 0 < bigint < curve.n")}function c(d){let{allowedPrivateKeyLengths:p,nByteLength:b,wrapPrivateKey:g,n:w}=e;if(p&&typeof d!="bigint"){if(Mt(d)&&(d=gt(d)),typeof d!="string"||!p.includes(d.length))throw new Error("Invalid key");d=d.padStart(b*2,"0")}let y;try{y=typeof d=="bigint"?d:mt(ce("private key",d,b))}catch{throw new Error(`private key must be ${b} bytes, hex or bigint, not ${typeof d}`)}return g&&(y=Q(y,w)),a(y),y}let h=new Map;function f(d){if(!(d instanceof l))throw new Error("ProjectivePoint expected")}class l{constructor(p,b,g){if(this.px=p,this.py=b,this.pz=g,p==null||!t.isValid(p))throw new Error("x required");if(b==null||!t.isValid(b))throw new Error("y required");if(g==null||!t.isValid(g))throw new Error("z required")}static fromAffine(p){let{x:b,y:g}=p||{};if(!p||!t.isValid(b)||!t.isValid(g))throw new Error("invalid affine point");if(p instanceof l)throw new Error("projective point not allowed");let w=y=>t.eql(y,t.ZERO);return w(b)&&w(g)?l.ZERO:new l(b,g,t.ONE)}get x(){return this.toAffine().x}get y(){return this.toAffine().y}static normalizeZ(p){let b=t.invertBatch(p.map(g=>g.pz));return p.map((g,w)=>g.toAffine(b[w])).map(l.fromAffine)}static fromHex(p){let b=l.fromAffine(s(ce("pointHex",p)));return b.assertValidity(),b}static fromPrivateKey(p){return l.BASE.multiply(c(p))}_setWindowSize(p){this._WINDOW_SIZE=p,h.delete(this)}assertValidity(){if(this.is0()){if(e.allowInfinityPoint&&!t.is0(this.py))return;throw new Error("bad point: ZERO")}let{x:p,y:b}=this.toAffine();if(!t.isValid(p)||!t.isValid(b))throw new Error("bad point: x or y not FE");let g=t.sqr(b),w=i(p);if(!t.eql(g,w))throw new Error("bad point: equation left != right");if(!this.isTorsionFree())throw new Error("bad point: not in prime-order subgroup")}hasEvenY(){let{y:p}=this.toAffine();if(t.isOdd)return!t.isOdd(p);throw new Error("Field doesn't support isOdd")}equals(p){f(p);let{px:b,py:g,pz:w}=this,{px:y,py:E,pz:x}=p,S=t.eql(t.mul(b,x),t.mul(y,w)),v=t.eql(t.mul(g,x),t.mul(E,w));return S&&v}negate(){return new l(this.px,t.neg(this.py),this.pz)}double(){let{a:p,b}=e,g=t.mul(b,Dl),{px:w,py:y,pz:E}=this,x=t.ZERO,S=t.ZERO,v=t.ZERO,B=t.mul(w,w),$=t.mul(y,y),q=t.mul(E,E),P=t.mul(w,y);return P=t.add(P,P),v=t.mul(w,E),v=t.add(v,v),x=t.mul(p,v),S=t.mul(g,q),S=t.add(x,S),x=t.sub($,S),S=t.add($,S),S=t.mul(x,S),x=t.mul(P,x),v=t.mul(g,v),q=t.mul(p,q),P=t.sub(B,q),P=t.mul(p,P),P=t.add(P,v),v=t.add(B,B),B=t.add(v,B),B=t.add(B,q),B=t.mul(B,P),S=t.add(S,B),q=t.mul(y,E),q=t.add(q,q),B=t.mul(q,P),x=t.sub(x,B),v=t.mul(q,$),v=t.add(v,v),v=t.add(v,v),new l(x,S,v)}add(p){f(p);let{px:b,py:g,pz:w}=this,{px:y,py:E,pz:x}=p,S=t.ZERO,v=t.ZERO,B=t.ZERO,$=e.a,q=t.mul(e.b,Dl),P=t.mul(b,y),te=t.mul(g,E),C=t.mul(w,x),Fe=t.add(b,g),_=t.add(y,E);Fe=t.mul(Fe,_),_=t.add(P,te),Fe=t.sub(Fe,_),_=t.add(b,w);let N=t.add(y,x);return _=t.mul(_,N),N=t.add(P,C),_=t.sub(_,N),N=t.add(g,w),S=t.add(E,x),N=t.mul(N,S),S=t.add(te,C),N=t.sub(N,S),B=t.mul($,_),S=t.mul(q,C),B=t.add(S,B),S=t.sub(te,B),B=t.add(te,B),v=t.mul(S,B),te=t.add(P,P),te=t.add(te,P),C=t.mul($,C),_=t.mul(q,_),te=t.add(te,C),C=t.sub(P,C),C=t.mul($,C),_=t.add(_,C),P=t.mul(te,_),v=t.add(v,P),P=t.mul(N,_),S=t.mul(Fe,S),S=t.sub(S,P),P=t.mul(Fe,te),B=t.mul(N,B),B=t.add(B,P),new l(S,v,B)}subtract(p){return this.add(p.negate())}is0(){return this.equals(l.ZERO)}wNAF(p){return u.wNAFCached(this,h,p,b=>{let g=t.invertBatch(b.map(w=>w.pz));return b.map((w,y)=>w.toAffine(g[y])).map(l.fromAffine)})}multiplyUnsafe(p){let b=l.ZERO;if(p===It)return b;if(a(p),p===We)return this;let{endo:g}=e;if(!g)return u.unsafeLadder(this,p);let{k1neg:w,k1:y,k2neg:E,k2:x}=g.splitScalar(p),S=b,v=b,B=this;for(;y>It||x>It;)y&We&&(S=S.add(B)),x&We&&(v=v.add(B)),B=B.double(),y>>=We,x>>=We;return w&&(S=S.negate()),E&&(v=v.negate()),v=new l(t.mul(v.px,g.beta),v.py,v.pz),S.add(v)}multiply(p){a(p);let b=p,g,w,{endo:y}=e;if(y){let{k1neg:E,k1:x,k2neg:S,k2:v}=y.splitScalar(b),{p:B,f:$}=this.wNAF(x),{p:q,f:P}=this.wNAF(v);B=u.constTimeNegate(E,B),q=u.constTimeNegate(S,q),q=new l(t.mul(q.px,y.beta),q.py,q.pz),g=B.add(q),w=$.add(P)}else{let{p:E,f:x}=this.wNAF(b);g=E,w=x}return l.normalizeZ([g,w])[0]}multiplyAndAddUnsafe(p,b,g){let w=l.BASE,y=(x,S)=>S===It||S===We||!x.equals(w)?x.multiplyUnsafe(S):x.multiply(S),E=y(this,b).add(y(p,g));return E.is0()?void 0:E}toAffine(p){let{px:b,py:g,pz:w}=this,y=this.is0();p==null&&(p=y?t.ONE:t.inv(w));let E=t.mul(b,p),x=t.mul(g,p),S=t.mul(w,p);if(y)return{x:t.ZERO,y:t.ZERO};if(!t.eql(S,t.ONE))throw new Error("invZ was invalid");return{x:E,y:x}}isTorsionFree(){let{h:p,isTorsionFree:b}=e;if(p===We)return!0;if(b)return b(l,this);throw new Error("isTorsionFree() has not been declared for the elliptic curve")}clearCofactor(){let{h:p,clearCofactor:b}=e;return p===We?this:b?b(l,this):this.multiplyUnsafe(e.h)}toRawBytes(p=!0){return this.assertValidity(),n(l,this,p)}toHex(p=!0){return gt(this.toRawBytes(p))}}l.BASE=new l(e.Gx,e.Gy,t.ONE),l.ZERO=new l(t.ZERO,t.ONE,t.ZERO);let m=e.nBitLength,u=Vn(l,e.endo?Math.ceil(m/2):m);return{CURVE:e,ProjectivePoint:l,normPrivateKeyToScalar:c,weierstrassEquation:i,isWithinCurveOrder:o}}function yp(r){let e=tn(r);return st(e,{hash:"hash",hmac:"function",randomBytes:"function"},{bits2int:"function",bits2int_modN:"function",lowS:"boolean"}),Object.freeze({lowS:!0,...e})}function Ol(r){let e=yp(r),{Fp:t,n}=e,s=t.BYTES+1,i=2*t.BYTES+1;function o(_){return It<_&&_<t.ORDER}function a(_){return Q(_,n)}function c(_){return Pn(_,n)}let{ProjectivePoint:h,normPrivateKeyToScalar:f,weierstrassEquation:l,isWithinCurveOrder:m}=mp({...e,toBytes(_,N,H){let I=N.toAffine(),A=t.toBytes(I.x),R=yt;return H?R(Uint8Array.from([N.hasEvenY()?2:3]),A):R(Uint8Array.from([4]),A,t.toBytes(I.y))},fromBytes(_){let N=_.length,H=_[0],I=_.subarray(1);if(N===s&&(H===2||H===3)){let A=mt(I);if(!o(A))throw new Error("Point is not on curve");let R=l(A),L;try{L=t.sqrt(R)}catch(K){let Y=K instanceof Error?": "+K.message:"";throw new Error("Point is not on curve"+Y)}let O=(L&We)===We;return(H&1)===1!==O&&(L=t.neg(L)),{x:A,y:L}}else if(N===i&&H===4){let A=t.fromBytes(I.subarray(0,t.BYTES)),R=t.fromBytes(I.subarray(t.BYTES,2*t.BYTES));return{x:A,y:R}}else throw new Error(`Point of length ${N} was invalid. Expected ${s} compressed bytes or ${i} uncompressed bytes`)}}),u=_=>gt(Ht(_,e.nByteLength));function d(_){let N=n>>We;return _>N}function p(_){return d(_)?a(-_):_}let b=(_,N,H)=>mt(_.slice(N,H));class g{constructor(N,H,I){this.r=N,this.s=H,this.recovery=I,this.assertValidity()}static fromCompact(N){let H=e.nByteLength;return N=ce("compactSignature",N,H*2),new g(b(N,0,H),b(N,H,2*H))}static fromDER(N){let{r:H,s:I}=ar.toSig(ce("DER",N));return new g(H,I)}assertValidity(){if(!m(this.r))throw new Error("r must be 0 < r < CURVE.n");if(!m(this.s))throw new Error("s must be 0 < s < CURVE.n")}addRecoveryBit(N){return new g(this.r,this.s,N)}recoverPublicKey(N){let{r:H,s:I,recovery:A}=this,R=v(ce("msgHash",N));if(A==null||![0,1,2,3].includes(A))throw new Error("recovery id invalid");let L=A===2||A===3?H+e.n:H;if(L>=t.ORDER)throw new Error("recovery id 2 or 3 invalid");let O=A&1?"03":"02",F=h.fromHex(O+u(L)),K=c(L),Y=a(-R*K),j=a(I*K),W=h.BASE.multiplyAndAddUnsafe(F,Y,j);if(!W)throw new Error("point at infinify");return W.assertValidity(),W}hasHighS(){return d(this.s)}normalizeS(){return this.hasHighS()?new g(this.r,a(-this.s),this.recovery):this}toDERRawBytes(){return Qt(this.toDERHex())}toDERHex(){return ar.hexFromSig({r:this.r,s:this.s})}toCompactRawBytes(){return Qt(this.toCompactHex())}toCompactHex(){return u(this.r)+u(this.s)}}let w={isValidPrivateKey(_){try{return f(_),!0}catch{return!1}},normPrivateKeyToScalar:f,randomPrivateKey:()=>{let _=Xi(e.n);return Ec(e.randomBytes(_),e.n)},precompute(_=8,N=h.BASE){return N._setWindowSize(_),N.multiply(BigInt(3)),N}};function y(_,N=!0){return h.fromPrivateKey(_).toRawBytes(N)}function E(_){let N=Mt(_),H=typeof _=="string",I=(N||H)&&_.length;return N?I===s||I===i:H?I===2*s||I===2*i:_ instanceof h}function x(_,N,H=!0){if(E(_))throw new Error("first arg must be private key");if(!E(N))throw new Error("second arg must be public key");return h.fromHex(N).multiply(f(_)).toRawBytes(H)}let S=e.bits2int||function(_){let N=mt(_),H=_.length*8-e.nBitLength;return H>0?N>>BigInt(H):N},v=e.bits2int_modN||function(_){return a(S(_))},B=en(e.nBitLength);function $(_){if(typeof _!="bigint")throw new Error("bigint expected");if(!(It<=_&&_<B))throw new Error(`bigint expected < 2^${e.nBitLength}`);return Ht(_,e.nByteLength)}function q(_,N,H=P){if(["recovered","canonical"].some(ie=>ie in H))throw new Error("sign() legacy options not supported");let{hash:I,randomBytes:A}=e,{lowS:R,prehash:L,extraEntropy:O}=H;R==null&&(R=!0),_=ce("msgHash",_),L&&(_=ce("prehashed msgHash",I(_)));let F=v(_),K=f(N),Y=[$(K),$(F)];if(O!=null&&O!==!1){let ie=O===!0?A(t.BYTES):O;Y.push(ce("extraEntropy",ie))}let j=yt(...Y),W=F;function ue(ie){let be=S(ie);if(!m(be))return;let we=c(be),he=h.BASE.multiply(be).toAffine(),Ae=a(he.x);if(Ae===It)return;let ft=a(we*a(W+Ae*K));if(ft===It)return;let Zt=(he.x===Ae?0:2)|Number(he.y&We),Wr=ft;return R&&d(ft)&&(Wr=p(ft),Zt^=1),new g(Ae,Wr,Zt)}return{seed:j,k2sig:ue}}let P={lowS:e.lowS,prehash:!1},te={lowS:e.lowS,prehash:!1};function C(_,N,H=P){let{seed:I,k2sig:A}=q(_,N,H),R=e;return ji(R.hash.outputLen,R.nByteLength,R.hmac)(I,A)}h.BASE._setWindowSize(8);function Fe(_,N,H,I=te){let A=_;if(N=ce("msgHash",N),H=ce("publicKey",H),"strict"in I)throw new Error("options.strict was renamed to lowS");let{lowS:R,prehash:L}=I,O,F;try{if(typeof A=="string"||Mt(A))try{O=g.fromDER(A)}catch(he){if(!(he instanceof ar.Err))throw he;O=g.fromCompact(A)}else if(typeof A=="object"&&typeof A.r=="bigint"&&typeof A.s=="bigint"){let{r:he,s:Ae}=A;O=new g(he,Ae)}else throw new Error("PARSE");F=h.fromHex(H)}catch(he){if(he.message==="PARSE")throw new Error("signature must be Signature instance, Uint8Array or hex string");return!1}if(R&&O.hasHighS())return!1;L&&(N=e.hash(N));let{r:K,s:Y}=O,j=v(N),W=c(Y),ue=a(j*W),ie=a(K*W),be=h.BASE.multiplyAndAddUnsafe(F,ue,ie)?.toAffine();return be?a(be.x)===K:!1}return{CURVE:e,getPublicKey:y,getSharedSecret:x,sign:C,verify:Fe,ProjectivePoint:h,Signature:g,utils:w}}function bp(r){return{hash:r,hmac:(e,...t)=>an(r,e,Cn(...t)),randomBytes:_r}}function Pl(r,e){let t=n=>Ol({...r,...bp(n)});return Object.freeze({...t(e),create:t})}var Hl=BigInt("0xfffffffffffffffffffffffffffffffffffffffffffffffffffffffefffffc2f"),Ml=BigInt("0xfffffffffffffffffffffffffffffffebaaedce6af48a03bbfd25e8cd0364141"),wp=BigInt(1),Uo=BigInt(2),Vl=(r,e)=>(r+e/Uo)/e;function xp(r){let e=Hl,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,l=ne(f,t,e)*f%e,m=ne(l,t,e)*f%e,u=ne(m,Uo,e)*h%e,d=ne(u,s,e)*u%e,p=ne(d,i,e)*d%e,b=ne(p,a,e)*p%e,g=ne(b,c,e)*b%e,w=ne(g,a,e)*p%e,y=ne(w,t,e)*f%e,E=ne(y,o,e)*d%e,x=ne(E,n,e)*h%e,S=ne(x,Uo,e);if(!Do.eql(Do.sqr(S),r))throw new Error("Cannot find square root");return S}var Do=Mn(Hl,void 0,void 0,{sqrt:xp}),tt=Pl({a:BigInt(0),b:BigInt(7),Fp:Do,n:Ml,Gx:BigInt("55066263022277343669578718895168534326250603453777594175500187360389116729240"),Gy:BigInt("32670510020758816978083085130507043184471273380659243275938904335757337482424"),h:BigInt(1),lowS:!0,endo:{beta:BigInt("0x7ae96a2b657c07106e64479eac3434e99cf0497512f58995c1396c28719501ee"),splitScalar:r=>{let e=Ml,t=BigInt("0x3086d221a7d46bcde86c90e49284eb15"),n=-wp*BigInt("0xe4437ed6010e88286f547fa90abfe4c3"),s=BigInt("0x114ca50f7a8e2f3f657c1108d9d44cfd8"),i=t,o=BigInt("0x100000000000000000000000000000000"),a=Vl(i*r,e),c=Vl(-n*r,e),h=Q(r-a*t-c*s,e),f=Q(-a*n-c*i,e),l=h>o,m=f>o;if(l&&(h=e-h),m&&(f=e-f),h>o||f>o)throw new Error("splitScalar: Endomorphism failed, k="+r);return{k1neg:l,k1:h,k2neg:m,k2:f}}}},Ul),pb=BigInt(0);var gb=tt.ProjectivePoint;function Fl(){return tt.utils.randomPrivateKey()}function Kl(r,e){let t=me.digest(e instanceof Uint8Array?e:e.subarray());if($e(t))return t.then(({digest:n})=>tt.sign(n,r).toDERRawBytes()).catch(n=>{throw new U(String(n),"ERR_INVALID_INPUT")});try{return tt.sign(t.digest,r).toDERRawBytes()}catch(n){throw new U(String(n),"ERR_INVALID_INPUT")}}function ql(r,e,t){let n=me.digest(t instanceof Uint8Array?t:t.subarray());if($e(n))return n.then(({digest:s})=>tt.verify(e,s,r)).catch(s=>{throw new U(String(s),"ERR_INVALID_INPUT")});try{return tt.verify(e,n.digest,r)}catch(s){throw new U(String(s),"ERR_INVALID_INPUT")}}function zl(r){return tt.ProjectivePoint.fromHex(r).toRawBytes(!0)}function $l(r){try{tt.getPublicKey(r,!0)}catch(e){throw new U(String(e),"ERR_INVALID_PRIVATE_KEY")}}function Oo(r){try{tt.ProjectivePoint.fromHex(r)}catch(e){throw new U(String(e),"ERR_INVALID_PUBLIC_KEY")}}function Gl(r){try{return tt.getPublicKey(r,!0)}catch(e){throw new U(String(e),"ERR_INVALID_PRIVATE_KEY")}}var wn=class{_key;constructor(e){Oo(e),this._key=e}verify(e,t){return ql(this._key,t,e)}marshal(){return zl(this._key)}get bytes(){return it.encode({Type:se.Secp256k1,Data:this.marshal()}).subarray()}equals(e){return ae(this.bytes,e.bytes)}async hash(){let e=me.digest(this.bytes),t;return $e(e)?{bytes:t}=await e:t=e.bytes,t}},xn=class{_key;_publicKey;constructor(e,t){this._key=e,this._publicKey=t??Gl(e),$l(this._key),Oo(this._publicKey)}sign(e){return Kl(this._key,e)}get public(){return new wn(this._publicKey)}marshal(){return this._key}get bytes(){return ot.encode({Type:se.Secp256k1,Data:this.marshal()}).subarray()}equals(e){return ae(this.bytes,e.bytes)}hash(){let e=me.digest(this.bytes);return $e(e)?e.then(({bytes:t})=>t):e.bytes}async id(){let e=await this.public.hash();return X(e,"base58btc")}async export(e,t="libp2p-key"){if(t==="libp2p-key")return Cr(this.bytes,e);throw new U(`export format '${t}' is not supported`,"ERR_INVALID_EXPORT_FORMAT")}};function Ep(r){return new xn(r)}function Ap(r){return new wn(r)}async function Sp(){let r=Fl();return new xn(r)}var cr={rsa:Co,ed25519:Eo,secp256k1:Po};function jl(r){let e=Object.keys(cr).join(" / ");return new U(`invalid or unsupported key type ${r}. Must be ${e}`,"ERR_UNSUPPORTED_KEY_TYPE")}function Wl(r){let e=it.decode(r),t=e.Data??new Uint8Array;switch(e.Type){case se.RSA:return cr.rsa.unmarshalRsaPublicKey(t);case se.Ed25519:return cr.ed25519.unmarshalEd25519PublicKey(t);case se.Secp256k1:return cr.secp256k1.unmarshalSecp256k1PublicKey(t);default:throw jl(e.Type??"unknown")}}async function Yl(r){let e=ot.decode(r),t=e.Data??new Uint8Array;switch(e.Type){case se.RSA:return cr.rsa.unmarshalRsaPrivateKey(t);case se.Ed25519:return cr.ed25519.unmarshalEd25519PrivateKey(t);case se.Secp256k1:return cr.secp256k1.unmarshalSecp256k1PrivateKey(t);default:throw jl(e.Type??"RSA")}}var Xl=Symbol.for("@achingbrain/uint8arraylist");function Zl(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 Ms(r){return!!r?.[Xl]}var Me=class r{bufs;length;[Xl]=!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(Ms(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(Ms(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=Zl(this.bufs,e);return t.buf[t.index]}set(e,t){let n=Zl(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(Ms(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 ke(n,s)}subarray(e,t){let{bufs:n,length:s}=this._subList(e,t);return n.length===1?n[0]:ke(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 l=e-a;n.push(o.subarray(l,l+(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(!Ms(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 l=0;l<i;l++)o[l]=-1;for(let l=0;l<s;l++)o[n[l]]=l;let a=o,c=this.byteLength-n.byteLength,h=n.byteLength-1,f;for(let l=t;l<=c;l+=f){f=0;for(let m=h;m>=0;m--){let u=this.get(l+m);if(n[m]!==u){f=Math.max(1,m-a[u]);break}}if(f===0)return l}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=Ne(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=xe(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=xe(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=xe(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=Ne(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=xe(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=xe(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=xe(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=xe(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=xe(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(!ae(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 Jl={ERR_SIGNATURE_NOT_VALID:"ERR_SIGNATURE_NOT_VALID"};var vn;(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)=>{let s={publicKey:new Uint8Array(0),payloadType:new Uint8Array(0),payload:new Uint8Array(0),signature:new Uint8Array(0)},i=n==null?t.len:t.pos+n;for(;t.pos<i;){let o=t.uint32();switch(o>>>3){case 1:s.publicKey=t.bytes();break;case 2:s.payloadType=t.bytes();break;case 3:s.payload=t.bytes();break;case 5:s.signature=t.bytes();break;default:t.skipType(o&7);break}}return s})),e),r.encode=t=>Oe(t,r.codec()),r.decode=t=>De(t,r.codec())})(vn||(vn={}));var En=class r{static createFromProtobuf=async e=>{let t=vn.decode(e),n=await sc(t.publicKey);return new r({peerId:n,payloadType:t.payloadType,payload:t.payload,signature:t.signature})};static seal=async(e,t)=>{if(t.privateKey==null)throw new Error("Missing private key");let n=e.domain,s=e.codec,i=e.marshal(),o=Ql(n,s,i),c=await(await Yl(t.privateKey)).sign(o.subarray());return new r({peerId:t,payloadType:s,payload:i,signature:c})};static openAndCertify=async(e,t)=>{let n=await r.createFromProtobuf(e);if(!await n.validate(t))throw new U("envelope signature is not valid for the given domain",Jl.ERR_SIGNATURE_NOT_VALID);return n};peerId;payloadType;payload;signature;marshaled;constructor(e){let{peerId:t,payloadType:n,payload:s,signature:i}=e;this.peerId=t,this.payloadType=n,this.payload=s,this.signature=i}marshal(){if(this.peerId.publicKey==null)throw new Error("Missing public key");return this.marshaled==null&&(this.marshaled=vn.encode({publicKey:this.peerId.publicKey,payloadType:this.payloadType,payload:this.payload.subarray(),signature:this.signature})),this.marshaled}equals(e){return ae(this.marshal(),e.marshal())}async validate(e){let t=Ql(e,this.payloadType,this.payload);if(this.peerId.publicKey==null)throw new Error("Missing public key");return Wl(this.peerId.publicKey).verify(t.subarray(),this.signature)}},Ql=(r,e,t)=>{let n=V(r),s=Ge(n.byteLength),i=Ge(e.length),o=Ge(t.length);return new Me(s,n,i,e,o,t)};var Vs=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 l=this.readChar();if(l===void 0)return;let m=Number.parseInt(l,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 eu=45,Bp=15,Hr=new Vs;function Mo(r){if(!(r.length>Bp))return Hr.new(r).parseWith(()=>Hr.readIPv4Addr())}function Vo(r){if(r.includes("%")&&(r=r.split("%")[0]),!(r.length>eu))return Hr.new(r).parseWith(()=>Hr.readIPv6Addr())}function Hs(r){if(r.includes("%")&&(r=r.split("%")[0]),!(r.length>eu))return Hr.new(r).parseWith(()=>Hr.readIPAddr())}var ew=parseInt("0xFFFF",16),tw=new Uint8Array([0,0,0,0,0,0,0,0,0,0,255,255]);function nu(r){return!!Mo(r)}function su(r){return!!Vo(r)}function Fs(r){return!!Hs(r)}var iu=nu,Rp=su,Ho=function(r){let e=0;if(r=r.toString().trim(),iu(r)){let t=new Uint8Array(e+4);return r.split(/\./g).forEach(n=>{t[e++]=parseInt(n,10)&255}),t}if(Rp(r)){let t=r.split(":",8),n;for(n=0;n<t.length;n++){let i=iu(t[n]),o;i&&(o=Ho(t[n]),t[n]=X(o.slice(0,2),"base16")),o!=null&&++n<8&&t.splice(n,0,X(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")},ou=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 Fr={},Fo={},Cp=[[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"]];Cp.forEach(r=>{let e=Lp(...r);Fo[e.code]=e,Fr[e.name]=e});function Lp(r,e,t,n,s){return{code:r,size:e,name:t,resolvable:!!n,path:!!s}}function ee(r){if(typeof r=="number"){if(Fo[r]!=null)return Fo[r];throw new Error(`no protocol with code: ${r}`)}else if(typeof r=="string"){if(Fr[r]!=null)return Fr[r];throw new Error(`no protocol with name: ${r}`)}throw new Error(`invalid protocol id type: ${typeof r}`)}var Mw=ee("ip4"),Vw=ee("ip6"),Hw=ee("ipcidr");function $o(r,e){switch(ee(r).code){case 4:case 41:return Dp(e);case 42:return zo(e);case 6:case 273:case 33:case 132:return lu(e).toString();case 53:case 54:case 55:case 56:case 400:case 449:case 777:return zo(e);case 421:return Vp(e);case 444:return cu(e);case 445:return cu(e);case 466:return Mp(e);case 481:return globalThis.encodeURIComponent(zo(e));default:return X(e,"base16")}}function Go(r,e){switch(ee(r).code){case 4:return au(e);case 41:return au(e);case 42:return qo(e);case 6:case 273:case 33:case 132:return jo(parseInt(e,10));case 53:case 54:case 55:case 56:case 400:case 449:case 777:return qo(e);case 421:return Op(e);case 444:return Hp(e);case 445:return Fp(e);case 466:return Pp(e);case 481:return qo(globalThis.decodeURIComponent(e));default:return V(e,"base16")}}var Ko=Object.values(Lt).map(r=>r.decoder),Up=function(){let r=Ko[0].or(Ko[1]);return Ko.slice(2).forEach(e=>r=r.or(e)),r}();function au(r){if(!Fs(r))throw new Error("invalid ip address");return Ho(r)}function Dp(r){let e=ou(r,0,r.length);if(e==null)throw new Error("ipBuff is required");if(!Fs(e))throw new Error("invalid ip address");return e}function jo(r){let e=new ArrayBuffer(2);return new DataView(e).setUint16(0,r),new Uint8Array(e)}function lu(r){return new DataView(r.buffer).getUint16(r.byteOffset)}function qo(r){let e=V(r),t=Uint8Array.from(Ge(e.length));return ke([t,e],t.length+e.length)}function zo(r){let e=xt(r);if(r=r.slice(Be(e)),r.length!==e)throw new Error("inconsistent lengths");return X(r)}function Op(r){let e;r[0]==="Q"||r[0]==="1"?e=Xt(de.decode(`z${r}`)).bytes:e=ze.parse(r).multihash.bytes;let t=Uint8Array.from(Ge(e.length));return ke([t,e],t.length+e.length)}function Pp(r){let e=Up.decode(r),t=Uint8Array.from(Ge(e.length));return ke([t,e],t.length+e.length)}function Mp(r){let e=xt(r),t=r.slice(Be(e));if(t.length!==e)throw new Error("inconsistent lengths");return"u"+X(t,"base64url")}function Vp(r){let e=xt(r),t=r.slice(Be(e));if(t.length!==e)throw new Error("inconsistent lengths");return X(t,"base58btc")}function Hp(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=dt.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=jo(n);return ke([t,s],t.length+s.length)}function Fp(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=dt.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=jo(n);return ke([t,s],t.length+s.length)}function cu(r){let e=r.slice(0,r.length-2),t=r.slice(r.length-2),n=X(e,"base32"),s=lu(t);return`${n}:${s}`}function uu(r){r=Wo(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=ee(o);if(a.size===0){e.push([a.code]),t.push([a.code]);continue}if(i++,i>=s.length)throw hu("invalid address: "+r);if(a.path===!0){n=Wo(s.slice(i).join("/")),e.push([a.code,Go(a.code,n)]),t.push([a.code,n]);break}let c=Go(a.code,s[i]);e.push([a.code,c]),t.push([a.code,$o(a.code,c)])}return{string:fu(t),bytes:Zo(e),tuples:e,stringTuples:t,path:n}}function Yo(r){let e=[],t=[],n=null,s=0;for(;s<r.length;){let i=xt(r,s),o=Be(i),a=ee(i),c=Kp(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 hu("Invalid address Uint8Array: "+X(r,"base16"));e.push([i,h]);let f=$o(i,h);if(t.push([i,f]),a.path===!0){n=f;break}}return{bytes:Uint8Array.from(r),string:fu(t),tuples:e,stringTuples:t,path:n}}function fu(r){let e=[];return r.map(t=>{let n=ee(t[0]);return e.push(n.name),t.length>1&&t[1]!=null&&e.push(t[1]),null}),Wo(e.join("/"))}function Zo(r){return ke(r.map(e=>{let t=ee(e[0]),n=Uint8Array.from(Ge(t.code));return e.length>1&&e[1]!=null&&(n=ke([n,e[1]])),n}))}function Kp(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+Be(t)}}function Wo(r){return"/"+r.trim().split("/").filter(e=>e).join("/")}function hu(r){return new Error("Error parsing address: "+r)}var qp=Symbol.for("nodejs.util.inspect.custom"),Xo=Symbol.for("@multiformats/js-multiaddr/multiaddr"),zp=[ee("dns").code,ee("dns4").code,ee("dns6").code,ee("dnsaddr").code],Ks=class r{bytes;#e;#t;#r;#n;[Xo]=!0;constructor(e){e==null&&(e="");let t;if(e instanceof Uint8Array)t=Yo(e);else if(typeof e=="string"){if(e.length>0&&e.charAt(0)!=="/")throw new Error(`multiaddr "${e}" must start with a "/"`);t=uu(e)}else if(pu(e))t=Yo(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=ee("tcp"),a=ee("udp"),c=ee("ip4"),h=ee("ip6"),f=ee("dns6"),l=ee("ip6zone");for(let[u,d]of this.stringTuples())u===l.code&&(i=`%${d??""}`),zp.includes(u)&&(t=o.name,s=443,n=`${d??""}${i}`,e=u===f.code?6:4),(u===o.code||u===a.code)&&(t=ee(u).name,s=parseInt(d??"")),(u===c.code||u===h.code)&&(t=ee(u).name,n=`${d??""}${i}`,e=u===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({},ee(e)))}protoCodes(){return this.#t.map(([e])=>e)}protoNames(){return this.#t.map(([e])=>ee(e).name)}tuples(){return this.#t}stringTuples(){return this.#r}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(Zo(t.slice(0,n)));return this}getPeerId(){try{let e=[];this.stringTuples().forEach(([n,s])=>{n===Fr.p2p.code&&e.push([n,s]),n===Fr["p2p-circuit"].code&&(e=[])});let t=e.pop();if(t?.[1]!=null){let n=t[1];return n[0]==="Q"||n[0]==="1"?X(de.decode(`z${n}`),"base58btc"):X(ze.parse(n).multihash.bytes,"base58btc")}return null}catch{return null}}getPath(){return this.#n}equals(e){return ae(this.bytes,e.bytes)}async resolve(e){let t=this.protos().find(i=>i.resolvable);if(t==null)return[this];let n=du.get(t.name);if(n==null)throw new U(`no available resolver for ${t.name}`,"ERR_NO_AVAILABLE_RESOLVER");return(await n(this,e)).map(i=>Ee(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)}[qp](){return`Multiaddr(${this.#e})`}};var du=new Map;function pu(r){return!!r?.[Xo]}function Ee(r){return new Ks(r)}function Ve(){let r={};return r.promise=new Promise((e,t)=>{r.resolve=e,r.reject=t}),r}var qs=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 Kr(r,e,t){if(e==null)return r;if(e.aborted)return Promise.reject(new qs(t?.errorMessage,t?.errorCode));let n,s=new qs(t?.errorMessage,t?.errorCode);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 Jo=class{readNext;haveNext;ended;nextResult;constructor(){this.ended=!1,this.readNext=Ve(),this.haveNext=Ve()}[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=Ve(),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=Ve(),await Kr(this.readNext.promise,t?.signal,t)}};function gu(){return new Jo}var zs=class extends Error{code;constructor(e,t){super(e),this.code=t}},Qo=class extends zs{type;constructor(e){super(e,"ABORT_ERR"),this.type="aborted"}};function mu(r,e){let t=gu();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 Me;return{read:async(o,a)=>{a?.signal?.throwIfAborted();let c,h=new Promise((f,l)=>{c=()=>{l(new Qo("Read aborted"))},a?.signal?.addEventListener("abort",c)});try{if(o==null){let{done:l,value:m}=await Promise.race([n.next(),h]);return l===!0?new Me:m}for(;s.byteLength<o;){let{value:l,done:m}=await Promise.race([n.next(),h]);if(m===!0)throw new zs("unexpected end of input","ERR_UNEXPECTED_EOF");s.append(l)}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 $s=class extends Error{code;constructor(e,t){super(e),this.code=t}};function yu(r,e={}){let t=mu(r,e);e.maxDataLength!=null&&e.maxLengthLength==null&&(e.maxLengthLength=Be(e.maxDataLength));let n=e?.lengthDecoder??xt,s=e?.lengthEncoder??Ge;return{read:async o=>{let a=-1,c=new Me;for(;;){c.append(await t.read(1,o));try{a=n(c)}catch(h){if(h instanceof RangeError)continue;throw h}if(e?.maxLengthLength!=null&&c.byteLength>e.maxLengthLength)throw new $s("message length length too long","ERR_MSG_LENGTH_TOO_LONG");if(a>-1)break}if(e?.maxDataLength!=null&&a>e.maxDataLength)throw new $s("message length too long","ERR_MSG_DATA_TOO_LONG");return t.read(a,o)},write:async(o,a)=>{await t.write(new Me(s(o.byteLength),o),a)},writeV:async(o,a)=>{let c=new Me(...o.flatMap(h=>[s(h.byteLength),h]));await t.write(c,a)},unwrap:()=>t.unwrap()}}function Wt(r,e){let t=yu(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 bu="circuit-relay-source",wu="circuit-relay-relay";var xu=BigInt(131072),Ye="/libp2p/circuit/relay/0.2.0/hop",lr="/libp2p/circuit/relay/0.2.0/stop",vu=30*1e3,_1=30*1e3,An=300;var ea="ERR_RELAYED_DIAL",Eu="ERR_HOP_REQUEST_FAILED",Gs="ERR_TRANSFER_LIMIT_EXCEEDED",Au=4096,Su=.001;var J;(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),qr.codec().encode(s.peer,i)),s.reservation!=null&&(i.uint32(26),js.codec().encode(s.reservation,i)),s.limit!=null&&(i.uint32(34),zr.codec().encode(s.limit,i)),s.status!=null&&(i.uint32(40),z.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=qr.codec().decode(s,s.uint32(),{limits:o.limits?.peer});break}case 3:{a.reservation=js.codec().decode(s,s.uint32(),{limits:o.limits?.reservation});break}case 4:{a.limit=zr.codec().decode(s,s.uint32(),{limits:o.limits?.limit});break}case 5:{a.status=z.codec().decode(s);break}default:{s.skipType(h&7);break}}}return a})),n),r.encode=s=>Oe(s,r.codec()),r.decode=(s,i)=>De(s,r.codec(),i)})(J||(J={}));var He;(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),qr.codec().encode(s.peer,i)),s.limit!=null&&(i.uint32(26),zr.codec().encode(s.limit,i)),s.status!=null&&(i.uint32(32),z.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=qr.codec().decode(s,s.uint32(),{limits:o.limits?.peer});break}case 3:{a.limit=zr.codec().decode(s,s.uint32(),{limits:o.limits?.limit});break}case 4:{a.status=z.codec().decode(s);break}default:{s.skipType(h&7);break}}}return a})),n),r.encode=s=>Oe(s,r.codec()),r.decode=(s,i)=>De(s,r.codec(),i)})(He||(He={}));var qr;(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:xe(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 sn('decode error - map field "addrs" had too many elements',"ERR_MAX_LENGTH");i.addrs.push(t.bytes());break}default:{t.skipType(a&7);break}}}return i})),e),r.encode=t=>Oe(t,r.codec()),r.decode=(t,n)=>De(t,r.codec(),n)})(qr||(qr={}));var js;(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),n.bytes(t.voucher)),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 sn('decode error - map field "addrs" had too many elements',"ERR_MAX_LENGTH");i.addrs.push(t.bytes());break}case 3:{i.voucher=t.bytes();break}default:{t.skipType(a&7);break}}}return i})),e),r.encode=t=>Oe(t,r.codec()),r.decode=(t,n)=>De(t,r.codec(),n)})(js||(js={}));var zr;(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=>Oe(t,r.codec()),r.decode=(t,n)=>De(t,r.codec(),n)})(zr||(zr={}));var z;(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"})(z||(z={}));var ta;(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"})(ta||(ta={}));(function(r){r.codec=()=>sr(ta)})(z||(z={}));var Ws;(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:xe(0),peer:xe(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=>Oe(t,r.codec()),r.decode=(t,n)=>De(t,r.codec(),n)})(Ws||(Ws={}));function Ys(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}async function*Bu(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 U(`data limit of ${n} bytes exceeded`,Gs)}e.remaining-=i,yield s}}function _u(r,e,t,n,s){function i(l){r.abort(l),e.abort(l)}let o=[t];n?.duration!=null&&o.push(AbortSignal.timeout(n.duration));let a=Ys(o),c=!1,h=!1,f;n?.data!=null&&(f={remaining:n.data}),queueMicrotask(()=>{let l=()=>{e.abort(new U(`duration limit of ${n?.duration} ms exceeded`,Gs))};a.addEventListener("abort",l,{once:!0}),e.sink(f==null?r.source:Bu(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",l),a.clear())})}),queueMicrotask(()=>{let l=()=>{r.abort(new U(`duration limit of ${n?.duration} ms exceeded`,Gs))};a.addEventListener("abort",l,{once:!0}),r.sink(f==null?e.source:Bu(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",l),a.clear())})})}function ra(r){let e=r*BigInt(1e3),t=new Date().getTime();return Number(e-BigInt(t))}function na(r,e){let t={[Symbol.iterator]:()=>t,next:()=>{let n=r.next(),s=n.value;return n.done===!0||s==null?{done:!0,value:void 0}:{done:!1,value:e(s)}}};return t}var kt=class{map;constructor(e){if(this.map=new Map,e!=null)for(let[t,n]of e.entries())this.map.set(t.toString(),n)}[Symbol.iterator](){return this.entries()}clear(){this.map.clear()}delete(e){return this.map.delete(e.toString())}entries(){return na(this.map.entries(),e=>[Ut(e[0]),e[1]])}forEach(e){this.map.forEach((t,n)=>{e(t,Ut(n),this)})}get(e){return this.map.get(e.toString())}has(e){return this.map.has(e.toString())}set(e,t){this.map.set(e.toString(),t)}keys(){return na(this.map.keys(),e=>Ut(e))}values(){return this.map.values()}get size(){return this.map.size}};var ia=mi(sa(),1);var $p=Math.LN2*Math.LN2,Xs=class{seeds;bits;buffer;constructor(e={}){e.seeds!=null?this.seeds=e.seeds:this.seeds=jp(e.hashes??8),this.bits=e.bits??1024,this.buffer=xe(Math.ceil(this.bits/8))}add(e){typeof e=="string"&&(e=V(e));for(let t=0;t<this.seeds.length;t++){let s=ia.default.x86.hash32(e,this.seeds[t])%this.bits;this.setbit(s)}}has(e){typeof e=="string"&&(e=V(e));for(let t=0;t<this.seeds.length;t++){let s=ia.default.x86.hash32(e,this.seeds[t])%this.bits;if(!this.getbit(s))return!1}return!0}clear(){this.buffer.fill(0)}setbit(e){let t=0,n=e;for(;n>7;)t++,n-=8;let s=this.buffer[t];s|=1<<n,this.buffer[t]=s}getbit(e){let t=0,n=e;for(;n>7;)t++,n-=8;return(this.buffer[t]&1<<n)!==0}};function oa(r,e=.005){let t=Gp(r,e);return new Xs(t)}function Gp(r,e=.005){let t=Math.round(-1*r*Math.log(e)/$p),n=Math.round(t/r*Math.LN2);return{bits:t,hashes:n}}function jp(r){let e,t,n=[];for(let s=0;s<r;s++)for(e=new Me(at(4)),n[s]=e.getUint32(0,!0),t=0;t<s;t++)if(n[s]===n[t]){s--;break}return n}var aa=64,rt=class{fp;h;seed;constructor(e,t,n,s=2){if(s>aa)throw new TypeError("Invalid Fingerprint Size");let i=t.hashV(e,n),o=xe(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?ae(this.fp,e.fp):!1}};function ur(r,e){return Math.floor(Math.random()*(e-r))+r}var fr=class{contents;constructor(e){this.contents=new Array(e).fill(null)}has(e){if(!(e instanceof rt))throw new TypeError("Invalid Fingerprint");return this.contents.some(t=>e.equals(t))}add(e){if(!(e instanceof rt))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 rt))throw new TypeError("Invalid Fingerprint");let t=ur(0,this.contents.length-1),n=this.contents[t];return this.contents[t]=e,n}remove(e){if(!(e instanceof rt))throw new TypeError("Invalid Fingerprint");let t=this.contents.findIndex(n=>e.equals(n));return t>-1?(this.contents[t]=null,!0):!1}};var ca={32:16777619n,64:1099511628211n,128:309485009821345068724781371n,256:374144419156711147060143317175368453031918731002211n,512:35835915874844867368919076489095108449946327955754392558399825615420669938882575126094039892345713852759n,1024:5016456510113118655434598811035278955030765345404790744303017523831112055108147451509157692220295382716162651878526895249385292291816524375083746691371804094271873160484737966720260389217684476157468082573n},Tu={32:2166136261n,64:14695981039346656037n,128:144066263297769815596495629667062367629n,256:100029257958052580907070968620625704837092796014241193945225284501741471925557n,512:9659303129496669498009435400716310466090418745672637896108374329434462657994582932197716438449813051892206539805784495328239340083876191928701583869517785n,1024:14197795064947621068722070641403218320880622795441933960878474914617582723252296732303717722150864096521202355549365628174669108571814760471015076148029755969804077320157692458563003215304957150157403644460363550505412711285966361610267868082893823963790439336411086884584107735010676915n},Ru=new globalThis.TextEncoder;function Wp(r,e){let t=ca[e],n=Tu[e];for(let s=0;s<r.length;s++)n^=BigInt(r[s]),n=BigInt.asUintN(e,n*t);return n}function Yp(r,e,t){if(t.length===0)throw new Error("The `utf8Buffer` option must have a length greater than zero");let n=ca[e],s=Tu[e],i=r;for(;i.length>0;){let o=Ru.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 la(r,{size:e=32,utf8Buffer:t}={}){if(!ca[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 Yp(r,e,t);r=Ru.encode(r)}return Wp(r,e)}var Zp=mi(sa(),1);var Bn={hash:r=>Number(la(r,{size:32})),hashV:(r,e)=>Xp(Bn.hash(r,e))};function Xp(r){let e=r.toString(16);return e.length%2===1&&(e=`0${e}`),V(e,"base16")}var Jp=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??ur(0,Math.pow(2,10))}add(e){typeof e=="string"&&(e=V(e));let t=new rt(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 fr(this.bucketSize)),this.buckets[s]==null&&(this.buckets[s]=new fr(this.bucketSize)),this.buckets[n].add(t)||this.buckets[s].add(t))return this.count++,!0;let i=[n,s],o=i[ur(0,i.length-1)];this.buckets[o]==null&&(this.buckets[o]=new fr(this.bucketSize));for(let a=0;a<Jp;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 fr(this.bucketSize)),this.buckets[o].add(c)))return this.count++,!0}return!1}has(e){typeof e=="string"&&(e=V(e));let t=new rt(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=V(e));let t=new rt(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))<=95}},Qp={1:.5,2:.84,4:.95,8:.98};function e0(r=.001){return r>.002?2:r>1e-5?4:8}function Nu(r,e=.001){let t=e0(e),n=Qp[t],s=Math.round(r/n),i=Math.min(Math.ceil(Math.log(s/t))+2,aa);return{filterSize:s,bucketSize:t,fingerprintSize:i}}var Js=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??ur(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=V(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=V(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=V(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 ua(r,e=.001,t){return new Js({...Nu(r,e),...t??{}})}var Qs=class{filter;constructor(e,t){this.filter=ua(e,t)}has(e){return this.filter.has(e.toBytes())}add(e){this.filter.add(e.toBytes())}remove(e){this.filter.remove?.(e.toBytes())}};function fa(r,e=.001){return new Qs(r,e)}var ei=class{reservations=new kt;_started=!1;interval;maxReservations;reservationClearInterval;applyDefaultLimit;reservationTtl;defaultDurationLimit;defaultDataLimit;constructor(e={}){this.maxReservations=e.maxReservations??15,this.reservationClearInterval=e.reservationClearInterval??3e5,this.applyDefaultLimit=e.applyDefaultLimit!==!1,this.reservationTtl=e.reservationTtl??72e5,this.defaultDurationLimit=e.defaultDurationLimit??12e4,this.defaultDataLimit=e.defaultDataLimit??xu}isStarted(){return this._started}start(){this._started||(this._started=!0,this.interval=setInterval(()=>{let e=new Date().getTime();this.reservations.forEach((t,n)=>{t.expire.getTime()<e&&this.reservations.delete(n)})},this.reservationClearInterval))}stop(){clearInterval(this.interval)}reserve(e,t,n){if(this.reservations.size>=this.maxReservations&&!this.reservations.has(e))return{status:z.RESERVATION_REFUSED};let s=new Date(Date.now()+this.reservationTtl),i;return this.applyDefaultLimit&&(i=n??{data:this.defaultDataLimit,duration:this.defaultDurationLimit}),this.reservations.set(e,{addr:t,expire:s,limit:i}),{status:z.OK,expire:Math.round(s.getTime()/1e3)}}removeReservation(e){this.reservations.delete(e)}hasReservation(e){return this.reservations.has(e)}get(e){return this.reservations.get(e)}};var ti=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 Ws.encode({relay:this.relay.toBytes(),peer:this.peer.toBytes(),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 Cu=r=>r.protoCodes().includes(290),i0={maxOutboundStopStreams:An},ha=class extends qe{registrar;peerStore;addressManager;peerId;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.connectionManager=e.connectionManager,this.connectionGater=e.connectionGater,this.started=!1,this.hopTimeout=t?.hopTimeout??vu,this.maxInboundHopStreams=t.maxInboundHopStreams,this.maxOutboundHopStreams=t.maxOutboundHopStreams,this.maxOutboundStopStreams=t.maxOutboundStopStreams??i0.maxOutboundStopStreams,this.reservationStore=new ei(t.reservations),this.shutdownController=new AbortController,Ke(1/0,this.shutdownController.signal)}isStarted(){return this.started}async start(){this.started||(await this.registrar.handle(Ye,e=>{this.onHop(e).catch(t=>{this.log.error(t)})},{maxInboundStreams:this.maxInboundHopStreams,maxOutboundStreams:this.maxOutboundHopStreams,runOnTransientConnection:!0}),this.reservationStore.start(),this.started=!0)}async stop(){this.reservationStore.stop(),this.shutdownController.abort(),await this.registrar.unhandle(Ye),this.started=!1}async onHop({connection:e,stream:t}){this.log("received circuit v2 hop protocol stream from %p",e.remotePeer);let n=Ve(),s=setTimeout(()=>{n.reject("timed out")},this.hopTimeout),i=Wt(t);try{let o=await Promise.race([i.pb(J).read(),n.promise]);if(o?.type==null)throw new Error("request was invalid, could not read from stream");this.log("received",o.type),await Promise.race([this.handleHopProtocol({connection:e,stream:i,request:o}),n.promise])}catch(o){this.log.error("error while handling hop",o),await i.pb(J).write({type:J.Type.STATUS,status:z.MALFORMED_MESSAGE}),t.abort(o)}finally{clearTimeout(s)}}async handleHopProtocol({stream:e,request:t,connection:n}){switch(this.log("received hop message"),t.type){case J.Type.RESERVE:await this.handleReserve({stream:e,request:t,connection:n});break;case J.Type.CONNECT:await this.handleConnect({stream:e,request:t,connection:n});break;default:this.log.error("invalid hop request type %s via peer %p",t.type,n.remotePeer),await e.pb(J).write({type:J.Type.STATUS,status:z.UNEXPECTED_MESSAGE})}}async handleReserve({stream:e,request:t,connection:n}){let s=e.pb(J);if(this.log("hop reserve request from %p",n.remotePeer),Cu(n.remoteAddr)){this.log.error("relay reservation over circuit connection denied for peer: %p",n.remotePeer),await s.write({type:J.Type.STATUS,status:z.PERMISSION_DENIED});return}if(await this.connectionGater.denyInboundRelayReservation?.(n.remotePeer)===!0){this.log.error("reservation for %p denied by connection gater",n.remotePeer),await s.write({type:J.Type.STATUS,status:z.PERMISSION_DENIED});return}let i=this.reservationStore.reserve(n.remotePeer,n.remoteAddr);if(i.status!==z.OK){await s.write({type:J.Type.STATUS,status:i.status});return}try{if(i.expire!=null){let o=i.expire*1e3-Date.now();await this.peerStore.merge(n.remotePeer,{tags:{[bu]:{value:1,ttl:o}}})}await s.write({type:J.Type.STATUS,status:z.OK,reservation:await this.makeReservation(n.remotePeer,BigInt(i.expire??0)),limit:this.reservationStore.get(n.remotePeer)?.limit}),this.log("sent confirmation response to %s",n.remotePeer)}catch(o){this.log.error("failed to send confirmation response to %p",n.remotePeer,o),this.reservationStore.removeReservation(n.remotePeer)}}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 En.seal(new ti({peer:e,relay:this.peerId,expiration:Number(t)}),this.peerId);return{addrs:n,expire:t,voucher:s.marshal()}}async handleConnect({stream:e,request:t,connection:n}){let s=e.pb(J);if(Cu(n.remoteAddr)){this.log.error("relay reservation over circuit connection denied for peer: %p",n.remotePeer),await s.write({type:J.Type.STATUS,status:z.PERMISSION_DENIED});return}this.log("hop connect request from %p",n.remotePeer);let i;try{if(t.peer==null)throw this.log.error("no peer info in hop connect request"),new Error("no peer info in request");t.peer.addrs.forEach(Ee),i=Qr(t.peer.id)}catch(l){this.log.error("invalid hop connect request via peer %p %s",n.remotePeer,l),await s.write({type:J.Type.STATUS,status:z.MALFORMED_MESSAGE});return}if(!this.reservationStore.hasReservation(i)){this.log.error("hop connect denied for destination peer %p not having a reservation for %p with status %s",i,n.remotePeer,z.NO_RESERVATION),await s.write({type:J.Type.STATUS,status:z.NO_RESERVATION});return}if(await this.connectionGater.denyOutboundRelayedConnection?.(n.remotePeer,i)===!0){this.log.error("hop connect for %p to %p denied by connection gater",n.remotePeer,i),await s.write({type:J.Type.STATUS,status:z.PERMISSION_DENIED});return}let o=this.connectionManager.getConnections(i);if(o.length===0){this.log("hop connect denied for destination peer %p not having a connection for %p as there is no destination connection",i,n.remotePeer),await s.write({type:J.Type.STATUS,status:z.NO_RESERVATION});return}let a=this.reservationStore.get(i)?.limit,c=o[0],h=await this.stopHop({connection:c,request:{type:He.Type.CONNECT,peer:{id:n.remotePeer.toBytes(),addrs:[]},limit:a}});if(h==null){this.log.error("failed to open stream to destination peer %p",c?.remotePeer),await s.write({type:J.Type.STATUS,status:z.CONNECTION_FAILED});return}await s.write({type:J.Type.STATUS,status:z.OK,limit:a});let f=e.unwrap();this.log("connection from %p to %p established - merging streams",n.remotePeer,i),_u(f,h,this.shutdownController.signal,a,{log:this.log})}async stopHop({connection:e,request:t}){this.log("starting circuit relay v2 stop request to %s",e.remotePeer);let n=await e.newStream([lr],{maxOutboundStreams:this.maxOutboundStopStreams,runOnTransientConnection:!0}),s=Wt(n),i=s.pb(He);await i.write(t);let o;try{o=await i.read()}catch{this.log.error("error parsing stop message response from %p",e.remotePeer)}if(o==null){this.log.error("could not read response from %p",e.remotePeer),await n.close();return}if(o.status===z.OK)return this.log("stop request to %p was successful",e.remotePeer),s.unwrap();this.log("stop request failed with code %d",o.status),await n.close()}get reservations(){return this.reservationStore.reservations}};function Lu(r={}){return e=>new ha(e,r)}function pa(r){let{stream:e,remoteAddr:t,logger:n}=r,s=n.forComponent("libp2p:stream:converter"),i=!1,o=!1,a=e.close.bind(e);e.close=async m=>{await a(m),l(!0)};let c=e.abort.bind(e);e.abort=m=>{c(m),l(!0)};let h=e.sink.bind(e);e.sink=async m=>{try{await h(m)}catch(u){u.type!=="aborted"&&s.error("%s error in sink",t,u)}finally{o=!0,l()}};let f={log:s,sink:e.sink,source:async function*(){try{for await(let m of e.source)m instanceof Uint8Array?yield m:yield*m}finally{i=!0,l()}}(),remoteAddr:t,timeline:{open:Date.now(),close:void 0},close:e.close,abort:e.abort};function l(m){m===!0&&(i=!0,o=!0),i&&o&&f.timeline.close==null&&(f.timeline.close=Date.now())}return f}var o0=k("dns4"),a0=k("dns6"),c0=k("dnsaddr"),hr=le(k("dns"),c0,o0,a0),si=le(k("ip4"),k("ip6")),$r=le(D(si,k("tcp")),D(hr,k("tcp"))),ii=D(si,k("udp")),l0=D(ii,k("utp")),u0=D(ii,k("quic")),f0=D(ii,k("quic-v1")),ga=le(D($r,k("ws")),D(hr,k("ws"))),ri=le(D(ga,k("p2p")),ga),ma=le(D($r,k("wss")),D(hr,k("wss")),D($r,k("tls"),k("ws")),D(hr,k("tls"),k("ws"))),ni=le(D(ma,k("p2p")),ma),ya=le(D($r,k("http")),D(si,k("http")),D(hr,k("http"))),ba=le(D($r,k("https")),D(si,k("https")),D(hr,k("https"))),Uu=D(ii,k("webrtc-direct"),k("certhash")),Pu=le(D(Uu,k("p2p")),Uu),Du=D(f0,k("webtransport"),k("certhash"),k("certhash")),Mu=le(D(Du,k("p2p")),Du),Vu=le(D(ri,k("p2p-webrtc-star"),k("p2p")),D(ni,k("p2p-webrtc-star"),k("p2p")),D(ri,k("p2p-webrtc-star")),D(ni,k("p2p-webrtc-star"))),jx=le(D(ri,k("p2p-websocket-star"),k("p2p")),D(ni,k("p2p-websocket-star"),k("p2p")),D(ri,k("p2p-websocket-star")),D(ni,k("p2p-websocket-star"))),Hu=le(D(ya,k("p2p-webrtc-direct"),k("p2p")),D(ba,k("p2p-webrtc-direct"),k("p2p")),D(ya,k("p2p-webrtc-direct")),D(ba,k("p2p-webrtc-direct"))),dr=le(ga,ma,ya,ba,Vu,Hu,$r,l0,u0,hr,Pu,Mu),Wx=le(D(dr,k("p2p-stardust"),k("p2p")),D(dr,k("p2p-stardust"))),Yt=le(D(dr,k("p2p")),Vu,Hu,Pu,Mu,k("p2p")),Ou=le(D(Yt,k("p2p-circuit"),Yt),D(Yt,k("p2p-circuit")),D(k("p2p-circuit"),Yt),D(dr,k("p2p-circuit")),D(k("p2p-circuit"),dr),k("p2p-circuit")),Fu=()=>le(D(Ou,Fu),Ou),Tt=Fu(),Yx=le(D(Tt,Yt,Tt),D(Yt,Tt),D(Tt,Yt),Tt,Yt);var Zx=le(D(Tt,k("webrtc"),k("p2p")),D(Tt,k("webrtc")),D(dr,k("webrtc"),k("p2p")),D(dr,k("webrtc")),k("webrtc"));function Ku(r){function e(t){let n;try{n=Ee(t)}catch{return!1}let s=r(n.protoNames());return s===null?!1:s===!0||s===!1?s:s.length===0}return e}function D(...r){function e(t){if(t.length<r.length)return null;let n=t;return r.some(s=>(n=typeof s=="function"?s().partialMatch(t):s.partialMatch(t),Array.isArray(n)&&(t=n),n===null)),n}return{toString:function(){return"{ "+r.join(" ")+" }"},input:r,matches:Ku(e),partialMatch:e}}function le(...r){function e(n){let s=null;return r.some(i=>{let o=typeof i=="function"?i().partialMatch(n):i.partialMatch(n);return o!=null?(s=o,!0):!1}),s}return{toString:function(){return"{ "+r.join(" ")+" }"},input:r,matches:Ku(e),partialMatch:e}}function k(r){let e=r;function t(s){let i;try{i=Ee(s)}catch{return!1}let o=i.protoNames();return o.length===1&&o[0]===e}function n(s){return s.length===0?null:s[0]===e?s.slice(1):null}return{toString:function(){return e},matches:t,partialMatch:n}}var oi=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}},Gr=class{size;hwm;head;tail;constructor(e={}){this.hwm=e.splitLimit??16,this.head=new oi(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 oi(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 wa=class extends Error{type;code;constructor(e,t){super(e??"The operation was aborted"),this.type="aborted",this.code=t??"ABORT_ERR"}};function qu(r={}){return d0(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 d0(r,e){e=e??{};let t=e.onEnd,n=new Gr,s,i,o,a=Ve(),c=async()=>{try{return n.isEmpty()?o?{done:!0}:await new Promise((b,g)=>{i=w=>{i=null,n.push(w);try{b(r(n))}catch(y){g(y)}return s}}):r(n)}finally{n.isEmpty()&&queueMicrotask(()=>{a.resolve(),a=Ve()})}},h=b=>i!=null?i(b):(n.push(b),s),f=b=>(n=new Gr,i!=null?i({error:b}):(n.push({error:b}),s)),l=b=>{if(o)return s;if(e?.objectMode!==!0&&b?.byteLength==null)throw new Error("objectMode was not true but tried to push non-Uint8Array value");return h({done:!1,value:b})},m=b=>o?s:(o=!0,b!=null?f(b):h({done:!0})),u=()=>(n=new Gr,m(),{done:!0}),d=b=>(m(b),{done:!0});if(s={[Symbol.asyncIterator](){return this},next:c,return:u,throw:d,push:l,end:m,get readableLength(){return n.size},onEmpty:async b=>{let g=b?.signal;if(g?.throwIfAborted(),n.isEmpty())return;let w,y;g!=null&&(w=new Promise((E,x)=>{y=()=>{x(new wa)},g.addEventListener("abort",y)}));try{await Promise.race([a.promise,w])}finally{y!=null&&g!=null&&g?.removeEventListener("abort",y)}}},t==null)return s;let p=s;return s={[Symbol.asyncIterator](){return this},next(){return p.next()},throw(b){return p.throw(b),t!=null&&(t(b),t=void 0),{done:!0}},return(){return p.return(),t!=null&&(t(),t=void 0),{done:!0}},push:l,end(b){return p.end(b),t!=null&&(t(b),t=void 0),s},get readableLength(){return p.readableLength},onEmpty:b=>p.onEmpty(b)},s}var xa=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 ai(r,e,t,n){let s=new xa(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=l=>{try{if(n?.filter?.(l)===!1)return}catch(m){a(),o(m);return}a(),i(l)},h=l=>{a(),o(l.detail)},f=()=>{a(),o(s)};t?.addEventListener("abort",f),r.addEventListener(e,c),n?.errorEvent!=null&&r.addEventListener(n.errorEvent,h)})}var ci=class{deferred;signal;where;constructor(e,t){this.signal=t,this.deferred=Ve(),this.where=e,this.onAbort=this.onAbort.bind(this),this.signal?.addEventListener("abort",this.onAbort)}onAbort(){this.deferred.reject(this.signal?.reason??new Rt)}cleanup(){this.signal?.removeEventListener("abort",this.onAbort)}};function p0(){return`${parseInt(String(Math.random()*1e9),10).toString()}${Date.now()}`}var li=class{id;fn;options;recipients;status;timeline;controller;constructor(e,t){this.id=p0(),this.status="queued",this.fn=e,this.options=t,this.recipients=[],this.timeline={created:Date.now()},this.controller=new AbortController,Ke(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 Rt),this.cleanup())}async join(e={}){let t=new ci(new Error("where").stack,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 Kr(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 ui=class extends qe{concurrency;queue;pending;sort;constructor(e={}){super(),this.concurrency=e.concurrency??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){t?.signal?.throwIfAborted();let n=new li(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 Rt)}),this.clear()}async onEmpty(e){this.size!==0&&await ai(this,"empty",e?.signal)}async onSizeLessThan(e,t){this.size<e||await ai(this,"next",t?.signal,{filter:()=>this.size<e})}async onIdle(e){this.pending===0&&this.size===0||await ai(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=qu({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 U("Queue aborted","ERR_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 jr=class extends ui{has(e){return this.find(e)!=null}find(e){return this.queue.find(t=>e.equals(t.options.peerId))}};var fi=class extends qe{peerStore;registrar;connectionManager;randomWalk;started;running;topologyId;log;discoveryController;filter;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,Ke(1/0,this.discoveryController.signal)}isStarted(){return this.started}async start(){this.topologyId=await this.registrar.register(Ye,{filter:this.filter,onConnect:e=>{this.log("discovered relay %p",e),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,Ke(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(Ye)],orders:[()=>Math.random()<.5?1:-1]});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=new jr({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}this.log.trace("wait for space in queue for %p",n.id),await Kr(t.onSizeLessThan(10),this.discoveryController.signal),this.log("adding random peer %p to dial queue (length: %d)",n.id,t.size),t.add(async()=>{let s=Ys([this.discoveryController.signal,AbortSignal.timeout(5e3)]);Ke(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)})}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()}};var va=class extends qe{connectionManager;relayStore;listeningAddrs;log;constructor(e){super(),this.log=e.logger.forComponent("libp2p:circuit-relay:transport:listener"),this.connectionManager=e.connectionManager,this.relayStore=e.relayStore,this.listeningAddrs=new kt,this.relayStore.addEventListener("relay:removed",this._onRemoveRelayPeer)}_onRemoveRelayPeer=e=>{this.#e(e.detail)};async listen(e){this.log("listen on %a",e);let t=e.decapsulate("/p2p-circuit"),n=await this.connectionManager.openConnection(t);if(!this.relayStore.hasReservation(n.remotePeer)){this.log("making reservation on peer %p",n.remotePeer),await this.relayStore.addRelay(n.remotePeer,"configured");return}let s=this.relayStore.getReservation(n.remotePeer);if(s==null)throw new U("Did not have reservation after making reservation","ERR_NO_RESERVATION");if(this.listeningAddrs.has(n.remotePeer)){this.log("already listening on relay %p",n.remotePeer);return}this.listeningAddrs.set(n.remotePeer,s.addrs.map(i=>Ee(i).encapsulate("/p2p-circuit"))),this.safeDispatchEvent("listening",{})}getAddrs(){return[...this.listeningAddrs.values()].flat()}async close(){}#e(e){let t=this.listeningAddrs.has(e);this.log("relay peer removed %p - had reservation",e,t),this.listeningAddrs.delete(e),t&&(this.log.trace("removing relay event listener for peer %p",e),this.relayStore.removeEventListener("relay:removed",this._onRemoveRelayPeer),this.safeDispatchEvent("close",{}))}};function zu(r){return new va(r)}var b0=60*1e3*10,w0=60*1e3*5,x0=30*1e3,hi=class extends qe{peerId;connectionManager;transportManager;peerStore;events;reserveQueue;reservations;maxDiscoveredRelays;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.transportManager=e.transportManager,this.peerStore=e.peerStore,this.events=e.events,this.reservations=new kt,this.maxDiscoveredRelays=t?.discoverRelays??0,this.maxReservationQueueLength=t?.maxReservationQueueLength??100,this.reservationCompletionTimeout=t?.reservationCompletionTimeout??1e3,this.started=!1,this.relayFilter=oa(100),this.reserveQueue=new jr({concurrency:t?.reservationConcurrency??1,metricName:"libp2p_relay_reservation_queue",metrics:e.metrics}),this.events.addEventListener("peer:disconnect",n=>{this.#t(n.detail)})}isStarted(){return this.started}start(){this.started=!0}afterStart(){this.reservations.size<this.maxDiscoveredRelays&&(this.log("not enough relays %d/%d",this.reservations.size,this.maxDiscoveredRelays),this.safeDispatchEvent("relay:not-enough-relays",{}))}stop(){this.reserveQueue.clear(),this.reservations.forEach(({timeout:e})=>{clearTimeout(e)}),this.reservations.clear(),this.started=!1}async addRelay(e,t){if(this.peerId.equals(e)){this.log("not trying to use self as relay");return}if(this.reserveQueue.size>this.maxReservationQueueLength){this.log("not adding potential relay peer %p as the queue is full",e);return}if(this.reserveQueue.has(e)){this.log("potential relay peer %p is already in the reservation queue",e);return}if(this.relayFilter.has(e.toBytes())){this.log("potential relay peer %p has failed previously, not trying again",e,new Error("where").stack);return}this.log("try to reserve relay slot with %p",e),await this.reserveQueue.add(async()=>{let n=Date.now();try{let s=this.reservations.get(e);if(s!=null){if(ra(s.reservation.expire)>b0){this.log("already have reservation on relay peer %p and it expires in more than 10 minutes",e);return}clearTimeout(s.timeout),this.reservations.delete(e)}if(t==="discovered"&&[...this.reservations.values()].reduce((l,m)=>(m.type==="discovered"&&l++,l),0)>=this.maxDiscoveredRelays){this.log("already have enough discovered relays");return}let i=AbortSignal.timeout(this.reservationCompletionTimeout);Ke(1/0,i);let o=await this.connectionManager.openConnection(e,{signal:i});if(o.remoteAddr.protoNames().includes("p2p-circuit")){this.log("not creating reservation over relayed connection");return}let a=await this.#e(o,{signal:i});this.log("created reservation on relay peer %p",e);let c=ra(a.expire),h=Math.min(Math.max(c-w0,x0),Math.pow(2,31)-1),f=setTimeout(()=>{this.addRelay(e,t).catch(l=>{this.log.error("could not refresh reservation to relay %p",e,l)})},h);this.reservations.set(e,{timeout:f,reservation:a,type:t}),await this.peerStore.merge(e,{tags:{[wu]:{value:1,ttl:c}}}),await this.transportManager.listen([Ee(`/p2p/${e.toString()}/p2p-circuit`)]),this.safeDispatchEvent("relay:created-reservation",{detail:e})}catch(s){this.log.error("could not reserve slot on %p after %dms",e,Date.now()-n,s);let i=this.reservations.get(e);i!=null&&clearTimeout(i.timeout),this.reservations.delete(e),this.relayFilter.add(e.toBytes())}},{peerId:e})}hasReservation(e){return this.reservations.has(e)}getReservation(e){return this.reservations.get(e)?.reservation}reservationCount(){return this.reservations.size}async#e(e,t){t.signal?.throwIfAborted(),this.log("requesting reservation from %p",e.remotePeer);let n=await e.newStream(Ye,t),i=Wt(n).pb(J);await i.write({type:J.Type.RESERVE},t);let o;try{o=await i.read(t)}catch(c){throw n.abort(c),c}finally{n.status!=="closed"&&await n.close(t)}if(o.status===z.OK&&o.reservation!=null){let c=!1,h=e.remoteAddr.bytes;for(let f of o.reservation.addrs)if(ae(h,f)){c=!0;break}return c||o.reservation.addrs.push(h),o.reservation}let a=`reservation failed with status ${o.status??"undefined"}`;throw this.log.error(a),new Error(a)}#t(e){let t=this.reservations.get(e);t!=null&&(this.log("connection to relay %p closed, removing reservation from local store",e),clearTimeout(t.timeout),this.reservations.delete(e),this.safeDispatchEvent("relay:removed",{detail:e}),this.reservations.size<this.maxDiscoveredRelays&&(this.log("not enough relays %d/%d",this.reservations.size,this.maxDiscoveredRelays),this.safeDispatchEvent("relay:not-enough-relays",{})))}};var v0=r=>{if(r.peer==null)return!1;try{r.peer.addrs.forEach(Ee)}catch{return!1}return!0},Ea={maxInboundStopStreams:An,maxOutboundStopStreams:An,stopTimeout:3e4},di=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??Ea.maxInboundStopStreams,this.maxOutboundStopStreams=t.maxOutboundStopStreams??Ea.maxOutboundStopStreams,this.stopTimeout=t.stopTimeout??Ea.stopTimeout;let n=t.discoverRelays??0;n>0&&(this.discovery=new fi(e,{filter:t.discoveryFilter??fa(Au,Su)}),this.discovery.addEventListener("relay:discover",s=>{this.reservationStore.addRelay(s.detail,"discovered").catch(i=>{this.log.error("could not add discovered relay %p",s.detail,i)})})),this.reservationStore=new hi(e,t),this.reservationStore.addEventListener("relay:not-enough-relays",()=>{this.discovery?.startDiscovery()}),this.reservationStore.addEventListener("relay:created-reservation",()=>{this.reservationStore.reservationCount()>=n&&this.discovery?.stopDiscovery()}),this.started=!1}isStarted(){return this.started}async start(){await this.registrar.handle(lr,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,runOnTransientConnection:!0}),await Oa(this.discovery,this.reservationStore),this.started=!0}async stop(){await Pa(this.discovery,this.reservationStore),await this.registrar.unhandle(lr),this.started=!1}[Ua]=!0;[Symbol.toStringTag]="libp2p/circuit-relay-v2";async dial(e,t={}){if(e.protoCodes().filter(d=>d===290).length!==1){let d="Invalid circuit relay address";throw this.log.error(d,e),new U(d,ea)}let n=e.toString().split("/p2p-circuit"),s=Ee(n[0]),i=Ee(n[n.length-1]),o=s.getPeerId(),a=i.getPeerId();if(o==null||a==null){let d=`Circuit relay dial to ${e.toString()} failed as address did not have peer ids`;throw this.log.error(d),new U(d,ea)}let c=Ut(o),h=Ut(a),f=!1,m=this.connectionManager.getConnections(c)[0];m==null&&(await this.peerStore.merge(c,{multiaddrs:[s]}),m=await this.connectionManager.openConnection(c,t),f=!0);let u;try{return u=await m.newStream(Ye),await this.connectV2({stream:u,connection:m,destinationPeer:h,destinationAddr:i,relayAddr:s,ma:e,disconnectOnFailure:f})}catch(d){throw this.log.error("circuit relay dial to destination %p via relay %p failed",h,c,d),u?.abort(d),f&&await m.close(),d}}async connectV2({stream:e,connection:t,destinationPeer:n,destinationAddr:s,relayAddr:i,ma:o,disconnectOnFailure:a}){try{let c=Wt(e),h=c.pb(J);await h.write({type:J.Type.CONNECT,peer:{id:n.toBytes(),addrs:[Ee(s).bytes]}});let f=await h.read();if(f.status!==z.OK)throw new U(`failed to connect via relay with status ${f?.status?.toString()??"undefined"}`,Eu);let l=pa({stream:c.unwrap(),remoteAddr:o,localAddr:i.encapsulate(`/p2p-circuit/p2p/${this.peerId.toString()}`),logger:this.logger});return this.log("new outbound relayed connection %a",l.remoteAddr),await this.upgrader.upgradeOutbound(l,{transient:f.limit!=null})}catch(c){throw this.log.error(`Circuit relay dial to destination ${n.toString()} via relay ${t.remotePeer.toString()} failed`,c),a&&await t.close(),c}}createListener(e){return zu({connectionManager:this.connectionManager,relayStore:this.reservationStore,logger:this.logger})}listenFilter(e){return e=Array.isArray(e)?e:[e],e.filter(t=>Tt.matches(t))}dialFilter(e){return this.listenFilter(e)}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(f){this.log.error("failed to listen on a relay peer we were dialed via but did not have a reservation on",f)}let n=AbortSignal.timeout(this.stopTimeout),s=Wt(t).pb(He),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:He.Type.STATUS,status:z.MALFORMED_MESSAGE},{signal:n}),await t.close();return}if(i.type!==He.Type.CONNECT){this.log.error("invalid stop connect request via peer %p",e.remotePeer),await s.write({type:He.Type.STATUS,status:z.UNEXPECTED_MESSAGE},{signal:n}),await t.close();return}if(!v0(i)){this.log.error("invalid stop connect request via peer %p",e.remotePeer),await s.write({type:He.Type.STATUS,status:z.MALFORMED_MESSAGE},{signal:n}),await t.close();return}let o=Qr(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:He.Type.STATUS,status:z.PERMISSION_DENIED},{signal:n}),await t.close();return}this.log.trace("sending success response to %p",e.remotePeer),await s.write({type:He.Type.STATUS,status:z.OK},{signal:n});let a=e.remoteAddr.encapsulate(`/p2p-circuit/p2p/${o.toString()}`),c=this.addressManager.getAddresses()[0],h=pa({stream:s.unwrap().unwrap(),remoteAddr:a,localAddr:c,logger:this.logger});this.log("new inbound relayed connection %a",h.remoteAddr),await this.upgrader.upgradeInbound(h,{transient:i.limit!=null}),this.log("%s connection %a upgraded","inbound",h.remoteAddr)}};function $u(r={}){return e=>new di(e,r)}return of(E0);})();
|
6
|
+
`)}`:`${t} :`}};Qc=qt;T.Constructed=Qc;qt.NAME="CONSTRUCTED";var ss=class extends Ie{fromBER(e,t,n){return t}toBER(e){return et}};ss.override="EndOfContentValueBlock";var el,is=class extends ve{constructor(e={}){super(e,ss),this.idBlock.tagClass=1,this.idBlock.tagNumber=0}};el=is;T.EndOfContent=el;is.NAME=un;var tl,zt=class extends ve{constructor(e={}){super(e,Ie),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}`}};tl=zt;T.Null=tl;zt.NAME="NULL";var os=class extends _t(Ie){constructor({value:e,...t}={}){super(t),t.valueHex?this.valueHexView=G.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=G.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,Bo.call(this),this.blockLength=n,t+n):-1}toBER(){return this.valueHexView.slice()}toJSON(){return{...super.toJSON(),value:this.value}}};os.NAME="BooleanValueBlock";var rl,as=class extends ve{constructor(e={}){super(e,os),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}`}};rl=as;T.Boolean=rl;as.NAME="BOOLEAN";var cs=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===un){if(this.isIndefiniteForm)break;return this.error="EndOfContent is unexpected, OCTET STRING may consists of OCTET STRINGs only",-1}if(o!==Yc)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}}};cs.NAME="OctetStringValueBlock";var nl,At=class r extends ve{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},cs),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=Os(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?qt.prototype.onAsciiEncoding.call(this):`${this.constructor.NAME} : ${G.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 G.BufferSourceConverter.concat(e)}};nl=At;T.OctetString=nl;At.NAME=Yc;var ls=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===un){if(this.isIndefiniteForm)break;return this.error="EndOfContent is unexpected, BIT STRING may consists of BIT STRINGs only",-1}if(c!==Zc)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=G.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=Os(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}}};ls.NAME="BitStringValueBlock";var sl,Or=class extends ve{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},ls),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 qt.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)}`}}};sl=Or;T.BitString=sl;Or.NAME=Zc;var il;function Jd(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,l=0;for(let m=f;m>=0;m--,l++){switch(!0){case l<a.length:h=i[o-l]+a[c-l]+t[0];break;default:h=i[o-l]+t[0]}switch(t[0]=h/10,!0){case l>=i.length:i=Xn(new Uint8Array([h%10]),i);break;default:i[o-l]=h%10}}return t[0]>0&&(i=Xn(t,i)),i}function Wc(r){if(r>=cn.length)for(let e=cn.length;e<=r;e++){let t=new Uint8Array([0]),n=cn[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=Xn(t,n)),cn.push(n)}return cn[r]}function Qd(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 l=c;l>=0;l--,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 l=o-c+1;l>=0;l--,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 fn=class extends _t(Ie){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=Bo.call(this)))}set valueDec(e){this._valueDec=e,this.isHexOnly=!1,this.valueHexView=new Uint8Array($c(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=Qd(Wc(n),t),o="-";break;default:t=Jd(t,Wc(n))}n++,s>>=1}}for(let c=0;c<t.length;c++)t[c]&&(a=!0),a&&(o+=jc.charAt(t[c]));return a===!1&&(o+=jc.charAt(0)),o}};il=fn;fn.NAME="IntegerValueBlock";Object.defineProperty(il.prototype,"valueHex",{set:function(r){this.valueHexView=new Uint8Array(r),this.setValueHex()},get:function(){return this.valueHexView.slice().buffer}});var ol,fe=class r extends ve{constructor(e={}){super(e,fn),this.idBlock.tagClass=1,this.idBlock.tagNumber=2}toBigInt(){return Jn(),BigInt(this.valueBlock.toString())}static fromBigInt(e){Jn();let t=BigInt(e),n=new ln,s=t.toString(16).replace(/^-/,""),i=new Uint8Array(G.Convert.FromHex(s));if(t<0){let a=new Uint8Array(i.length+(i[0]&128?1:0));a[0]|=128;let h=BigInt(`0x${G.Convert.ToHex(a)}`)+t,f=G.BufferSourceConverter.toUint8Array(G.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()}`}};ol=fe;T.Integer=ol;fe.NAME="INTEGER";var al,us=class extends fe{constructor(e={}){super(e),this.idBlock.tagClass=1,this.idBlock.tagNumber=10}};al=us;T.Enumerated=al;us.NAME="ENUMERATED";var hn=class extends _t(Ie){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=G.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=or(this.valueHexView,7):(this.isHexOnly=!0,this.warnings.push("Too big SID for decoding, hex only")),t+this.blockLength)}set valueBigInt(e){Jn();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=Kt(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=G.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}}};hn.NAME="sidBlock";var fs=class extends Ie{constructor({value:e=Pr,...t}={}){super(t),this.value=[],e&&this.fromString(e)}fromBER(e,t,n){let s=t;for(;n>0;){let i=new hn;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 _o(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 hn;if(s>Number.MAX_SAFE_INTEGER){Jn();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}};fs.NAME="ObjectIdentifierValueBlock";var cl,Qe=class extends ve{constructor(e={}){super(e,fs),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()}}};cl=Qe;T.ObjectIdentifier=cl;Qe.NAME="OBJECT IDENTIFIER";var dn=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=G.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=or(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=Kt(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=G.Convert.ToHex(this.valueHexView):e=this.valueDec.toString(),e}toJSON(){return{...super.toJSON(),valueDec:this.valueDec}}};dn.NAME="relativeSidBlock";var hs=class extends Ie{constructor({value:e=Pr,...t}={}){super(t),this.value=[],e&&this.fromString(e)}fromBER(e,t,n){let s=t;for(;n>0;){let i=new dn;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 _o(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 dn;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}};hs.NAME="RelativeObjectIdentifierValueBlock";var ll,ds=class extends ve{constructor(e={}){super(e,hs),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()}}};ll=ds;T.RelativeObjectIdentifier=ll;ds.NAME="RelativeObjectIdentifier";var ul,ye=class extends qt{constructor(e={}){super(e),this.idBlock.tagClass=1,this.idBlock.tagNumber=16}};ul=ye;T.Sequence=ul;ye.NAME="SEQUENCE";var fl,ps=class extends qt{constructor(e={}){super(e),this.idBlock.tagClass=1,this.idBlock.tagNumber=17}};fl=ps;T.Set=fl;ps.NAME="SET";var gs=class extends _t(Ie){constructor({...e}={}){super(e),this.isHexOnly=!0,this.value=Pr}toJSON(){return{...super.toJSON(),value:this.value}}};gs.NAME="StringValueBlock";var ms=class extends gs{};ms.NAME="SimpleStringValueBlock";var Re=class extends ts{constructor({...e}={}){super(e,ms)}fromBuffer(e){this.valueBlock.value=String.fromCharCode.apply(null,G.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}};Re.NAME="SIMPLE STRING";var ys=class extends Re{fromBuffer(e){this.valueBlock.valueHexView=G.BufferSourceConverter.toUint8Array(e);try{this.valueBlock.value=G.Convert.ToUtf8String(e)}catch(t){this.warnings.push(`Error during "decodeURIComponent": ${t}, using raw string`),this.valueBlock.value=G.Convert.ToBinary(e)}}fromString(e){this.valueBlock.valueHexView=new Uint8Array(G.Convert.FromUtf8String(e)),this.valueBlock.value=e}};ys.NAME="Utf8StringValueBlock";var hl,St=class extends ys{constructor(e={}){super(e),this.idBlock.tagClass=1,this.idBlock.tagNumber=12}};hl=St;T.Utf8String=hl;St.NAME="UTF8String";var bs=class extends Re{fromBuffer(e){this.valueBlock.value=G.Convert.ToUtf16String(e),this.valueBlock.valueHexView=G.BufferSourceConverter.toUint8Array(e)}fromString(e){this.valueBlock.value=e,this.valueBlock.valueHexView=new Uint8Array(G.Convert.FromUtf16String(e))}};bs.NAME="BmpStringValueBlock";var dl,ws=class extends bs{constructor({...e}={}){super(e),this.idBlock.tagClass=1,this.idBlock.tagNumber=30}};dl=ws;T.BmpString=dl;ws.NAME="BMPString";var xs=class extends Re{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=Kt(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}};xs.NAME="UniversalStringValueBlock";var pl,vs=class extends xs{constructor({...e}={}){super(e),this.idBlock.tagClass=1,this.idBlock.tagNumber=28}};pl=vs;T.UniversalString=pl;vs.NAME="UniversalString";var gl,Es=class extends Re{constructor(e={}){super(e),this.idBlock.tagClass=1,this.idBlock.tagNumber=18}};gl=Es;T.NumericString=gl;Es.NAME="NumericString";var ml,As=class extends Re{constructor(e={}){super(e),this.idBlock.tagClass=1,this.idBlock.tagNumber=19}};ml=As;T.PrintableString=ml;As.NAME="PrintableString";var yl,Ss=class extends Re{constructor(e={}){super(e),this.idBlock.tagClass=1,this.idBlock.tagNumber=20}};yl=Ss;T.TeletexString=yl;Ss.NAME="TeletexString";var bl,Bs=class extends Re{constructor(e={}){super(e),this.idBlock.tagClass=1,this.idBlock.tagNumber=21}};bl=Bs;T.VideotexString=bl;Bs.NAME="VideotexString";var wl,_s=class extends Re{constructor(e={}){super(e),this.idBlock.tagClass=1,this.idBlock.tagNumber=22}};wl=_s;T.IA5String=wl;_s.NAME="IA5String";var xl,Is=class extends Re{constructor(e={}){super(e),this.idBlock.tagClass=1,this.idBlock.tagNumber=25}};xl=Is;T.GraphicString=xl;Is.NAME="GraphicString";var vl,pn=class extends Re{constructor(e={}){super(e),this.idBlock.tagClass=1,this.idBlock.tagNumber=26}};vl=pn;T.VisibleString=vl;pn.NAME="VisibleString";var El,ks=class extends Re{constructor(e={}){super(e),this.idBlock.tagClass=1,this.idBlock.tagNumber=27}};El=ks;T.GeneralString=El;ks.NAME="GeneralString";var Al,Ts=class extends Re{constructor(e={}){super(e),this.idBlock.tagClass=1,this.idBlock.tagNumber=29}};Al=Ts;T.CharacterString=Al;Ts.NAME="CharacterString";var Sl,gn=class extends pn{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,G.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]=Ce(this.year<2e3?this.year-1900:this.year-2e3,2),t[1]=Ce(this.month,2),t[2]=Ce(this.day,2),t[3]=Ce(this.hour,2),t[4]=Ce(this.minute,2),t[5]=Ce(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}}};Sl=gn;T.UTCTime=Sl;gn.NAME="UTCTime";var Bl,Rs=class extends gn{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 l=new Number(e[e.length-1]);if(isNaN(l.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 l=1,m=n.indexOf("+"),u="";if(m===-1&&(m=n.indexOf("-"),l=-1),m!==-1){if(u=n.substring(m+1),n=n.substring(0,m),u.length!==2&&u.length!==4)throw new Error("Wrong input string for conversion");let d=parseInt(u.substring(0,2),10);if(isNaN(d.valueOf()))throw new Error("Wrong input string for conversion");if(a=l*d,u.length===4){if(d=parseInt(u.substring(2,4),10),isNaN(d.valueOf()))throw new Error("Wrong input string for conversion");c=l*d}}}let h=n.indexOf(".");if(h===-1&&(h=n.indexOf(",")),h!==-1){let l=new Number(`0${n.substring(h)}`);if(isNaN(l.valueOf()))throw new Error("Wrong input string for conversion");i=l.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 l=60*i;this.minute=Math.floor(l),l=60*(l-this.minute),this.second=Math.floor(l),l=1e3*(l-this.second),this.millisecond=Math.floor(l)}break;case s.length===12:if(o=/(\d{4})(\d{2})(\d{2})(\d{2})(\d{2})/ig,h!==-1){let l=60*i;this.second=Math.floor(l),l=1e3*(l-this.second),this.millisecond=Math.floor(l)}break;case s.length===14:if(o=/(\d{4})(\d{2})(\d{2})(\d{2})(\d{2})(\d{2})/ig,h!==-1){let l=1e3*i;this.millisecond=Math.floor(l)}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 l=1;l<f.length;l++)switch(l){case 1:this.year=parseInt(f[l],10);break;case 2:this.month=parseInt(f[l],10);break;case 3:this.day=parseInt(f[l],10);break;case 4:this.hour=parseInt(f[l],10)+a;break;case 5:this.minute=parseInt(f[l],10)+c;break;case 6:this.second=parseInt(f[l],10);break;default:throw new Error("Wrong input string for conversion")}if(t===!1){let l=new Date(this.year,this.month,this.day,this.hour,this.minute,this.second,this.millisecond);this.year=l.getUTCFullYear(),this.month=l.getUTCMonth(),this.day=l.getUTCDay(),this.hour=l.getUTCHours(),this.minute=l.getUTCMinutes(),this.second=l.getUTCSeconds(),this.millisecond=l.getUTCMilliseconds()}}toString(e="iso"){if(e==="iso"){let t=[];return t.push(Ce(this.year,4)),t.push(Ce(this.month,2)),t.push(Ce(this.day,2)),t.push(Ce(this.hour,2)),t.push(Ce(this.minute,2)),t.push(Ce(this.second,2)),this.millisecond!==0&&(t.push("."),t.push(Ce(this.millisecond,3))),t.push("Z"),t.join("")}return super.toString(e)}toJSON(){return{...super.toJSON(),millisecond:this.millisecond}}};Bl=Rs;T.GeneralizedTime=Bl;Rs.NAME="GeneralizedTime";var _l,Ns=class extends St{constructor(e={}){super(e),this.idBlock.tagClass=1,this.idBlock.tagNumber=31}};_l=Ns;T.DATE=_l;Ns.NAME="DATE";var Il,Cs=class extends St{constructor(e={}){super(e),this.idBlock.tagClass=1,this.idBlock.tagNumber=32}};Il=Cs;T.TimeOfDay=Il;Cs.NAME="TimeOfDay";var kl,Ls=class extends St{constructor(e={}){super(e),this.idBlock.tagClass=1,this.idBlock.tagNumber=33}};kl=Ls;T.DateTime=kl;Ls.NAME="DateTime";var Tl,Us=class extends St{constructor(e={}){super(e),this.idBlock.tagClass=1,this.idBlock.tagNumber=34}};Tl=Us;T.Duration=Tl;Us.NAME="Duration";var Rl,Ds=class extends St{constructor(e={}){super(e),this.idBlock.tagClass=1,this.idBlock.tagNumber=14}};Rl=Ds;T.TIME=Rl;Ds.NAME="TIME";function tp(r){let{result:e}=Mr(r),t=e.valueBlock.value;return{n:X(lt(t[1].toBigInt()),"base64url"),e:X(lt(t[2].toBigInt()),"base64url"),d:X(lt(t[3].toBigInt()),"base64url"),p:X(lt(t[4].toBigInt()),"base64url"),q:X(lt(t[5].toBigInt()),"base64url"),dp:X(lt(t[6].toBigInt()),"base64url"),dq:X(lt(t[7].toBigInt()),"base64url"),qi:X(lt(t[8].toBigInt()),"base64url"),kty:"RSA",alg:"RS256"}}function rp(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 U("JWK was missing components","ERR_INVALID_PARAMETERS");let t=new ye({value:[new fe({value:0}),fe.fromBigInt(ut(V(r.n,"base64url"))),fe.fromBigInt(ut(V(r.e,"base64url"))),fe.fromBigInt(ut(V(r.d,"base64url"))),fe.fromBigInt(ut(V(r.p,"base64url"))),fe.fromBigInt(ut(V(r.q,"base64url"))),fe.fromBigInt(ut(V(r.dp,"base64url"))),fe.fromBigInt(ut(V(r.dq,"base64url"))),fe.fromBigInt(ut(V(r.qi,"base64url")))]}).toBER();return new Uint8Array(t,0,t.byteLength)}function np(r){let{result:e}=Mr(r),t=e.valueBlock.value[1].valueBlock.value[0].valueBlock.value;return{kty:"RSA",n:X(lt(t[0].toBigInt()),"base64url"),e:X(lt(t[1].toBigInt()),"base64url")}}function sp(r){if(r.n==null||r.e==null)throw new U("JWK was missing components","ERR_INVALID_PARAMETERS");let t=new ye({value:[new ye({value:[new Qe({value:"1.2.840.113549.1.1.1"}),new zt]}),new Or({valueHex:new ye({value:[fe.fromBigInt(ut(V(r.n,"base64url"))),fe.fromBigInt(ut(V(r.e,"base64url")))]}).toBER()})]}).toBER();return new Uint8Array(t,0,t.byteLength)}function lt(r){let e=r.toString(16);e.length%2>0&&(e=`0${e}`);let t=e.length/2,n=new Uint8Array(t),s=0,i=0;for(;s<t;)n[s]=parseInt(e.slice(i,i+2),16),s+=1,i+=2;return n}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(""))}var ip=16,ko=32,To=1e4;async function op(r,e){let t=Te.get(),s=new ye({value:[new fe({value:0}),new ye({value:[new Qe({value:"1.2.840.113549.1.1.1"}),new zt]}),new At({valueHex:r.marshal()})]}).toBER(),i=new Uint8Array(s,0,s.byteLength),o=at(ip),a=await Ao(kr,e,o,{c:To,dkLen:ko}),c=at(16),h=await t.subtle.importKey("raw",a,"AES-CBC",!1,["encrypt"]),f=await t.subtle.encrypt({name:"AES-CBC",iv:c},h,i),l=new ye({value:[new At({valueHex:o}),new fe({value:To}),new fe({value:ko}),new ye({value:[new Qe({value:"1.2.840.113549.2.11"}),new zt]})]}),m=new ye({value:[new Qe({value:"1.2.840.113549.1.5.13"}),new ye({value:[new ye({value:[new Qe({value:"1.2.840.113549.1.5.12"}),l]}),new ye({value:[new Qe({value:"2.16.840.1.101.3.4.1.42"}),new At({valueHex:c})]})]})]}),d=new ye({value:[m,new At({valueHex:f})]}).toBER(),p=new Uint8Array(d,0,d.byteLength);return["-----BEGIN ENCRYPTED PRIVATE KEY-----",...X(p,"base64pad").split(/(.{64})/).filter(Boolean),"-----END ENCRYPTED PRIVATE KEY-----"].join(`
|
7
|
+
`)}async function ap(r,e){let t=Te.get(),n;if(r.includes("-----BEGIN ENCRYPTED PRIVATE KEY-----")){let s=V(r.replace("-----BEGIN ENCRYPTED PRIVATE KEY-----","").replace("-----END ENCRYPTED PRIVATE KEY-----","").replace(/\n/g,"").trim(),"base64pad"),{result:i}=Mr(s),{iv:o,salt:a,iterations:c,keySize:h,cipherText:f}=cp(i),l=await Ao(kr,e,a,{c,dkLen:h}),m=await t.subtle.importKey("raw",l,"AES-CBC",!1,["decrypt"]),u=mn(await t.subtle.decrypt({name:"AES-CBC",iv:o},m,f)),{result:d}=Mr(u);n=Nl(d)}else if(r.includes("-----BEGIN PRIVATE KEY-----")){let s=V(r.replace("-----BEGIN PRIVATE KEY-----","").replace("-----END PRIVATE KEY-----","").replace(/\n/g,"").trim(),"base64pad"),{result:i}=Mr(s);n=Nl(i)}else throw new U("Could not parse private key from PEM data","ERR_INVALID_PARAMETERS");return Ro(n)}function cp(r){let e=r.valueBlock.value[0];if(e.valueBlock.value[0].toString()!=="OBJECT IDENTIFIER : 1.2.840.113549.1.5.13")throw new U("Only pkcs5PBES2 encrypted private keys are supported","ERR_INVALID_PARAMS");let n=e.valueBlock.value[1].valueBlock.value[0];if(n.valueBlock.value[0].toString()!=="OBJECT IDENTIFIER : 1.2.840.113549.1.5.12")throw new U("Only pkcs5PBKDF2 key derivation functions are supported","ERR_INVALID_PARAMS");let i=n.valueBlock.value[1],o=mn(i.valueBlock.value[0].getValue()),a=To,c=ko;if(i.valueBlock.value.length===3)a=Number(i.valueBlock.value[1].toBigInt()),c=Number(i.valueBlock.value[2].toBigInt());else if(i.valueBlock.value.length===2)throw new U("Could not derive key size and iterations from PEM file - please use @libp2p/rsa to re-import your key","ERR_INVALID_PARAMS");let h=e.valueBlock.value[1].valueBlock.value[1],f=h.valueBlock.value[0].toString();if(f!=="OBJECT IDENTIFIER : 1.2.840.113549.3.7"){if(f!=="OBJECT IDENTIFIER : 1.3.14.3.2.7"){if(f!=="OBJECT IDENTIFIER : 2.16.840.1.101.3.4.1.2"){if(f!=="OBJECT IDENTIFIER : 2.16.840.1.101.3.4.1.22"){if(f!=="OBJECT IDENTIFIER : 2.16.840.1.101.3.4.1.42")throw new U("Only AES-CBC encryption schemes are supported","ERR_INVALID_PARAMS")}}}}let l=mn(h.valueBlock.value[1].getValue());return{cipherText:mn(r.valueBlock.value[1].getValue()),salt:o,iterations:a,keySize:c,iv:l}}function Nl(r){return mn(r.valueBlock.value[2].getValue())}function mn(r){return new Uint8Array(r,0,r.byteLength)}async function Cl(r){let e=await Te.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 Dl(e);return{privateKey:t[0],publicKey:t[1]}}async function No(r){let t=[await Te.get().subtle.importKey("jwk",r,{name:"RSASSA-PKCS1-v1_5",hash:{name:"SHA-256"}},!0,["sign"]),await lp(r)],n=await Dl({privateKey:t[0],publicKey:t[1]});return{privateKey:n[0],publicKey:n[1]}}async function Ll(r,e){let t=await Te.get().subtle.importKey("jwk",r,{name:"RSASSA-PKCS1-v1_5",hash:{name:"SHA-256"}},!1,["sign"]),n=await Te.get().subtle.sign({name:"RSASSA-PKCS1-v1_5"},t,e instanceof Uint8Array?e:e.subarray());return new Uint8Array(n,0,n.byteLength)}async function Ul(r,e,t){let n=await Te.get().subtle.importKey("jwk",r,{name:"RSASSA-PKCS1-v1_5",hash:{name:"SHA-256"}},!1,["verify"]);return Te.get().subtle.verify({name:"RSASSA-PKCS1-v1_5"},n,e,t instanceof Uint8Array?t:t.subarray())}async function Dl(r){if(r.privateKey==null||r.publicKey==null)throw new U("Private and public key are required","ERR_INVALID_PARAMETERS");return Promise.all([Te.get().subtle.exportKey("jwk",r.privateKey),Te.get().subtle.exportKey("jwk",r.publicKey)])}async function lp(r){return Te.get().subtle.importKey("jwk",{kty:r.kty,n:r.n,e:r.e},{name:"RSASSA-PKCS1-v1_5",hash:{name:"SHA-256"}},!0,["verify"])}function Ps(r){if(r.kty!=="RSA")throw new U("invalid key type","ERR_INVALID_KEY_TYPE");if(r.n==null)throw new U("invalid key modulus","ERR_INVALID_KEY_MODULUS");return V(r.n,"base64url").length*8}var bn=8192,yn=class{_key;constructor(e){this._key=e}verify(e,t){return Ul(this._key,t,e)}marshal(){return $t.jwkToPkix(this._key)}get bytes(){return it.encode({Type:se.RSA,Data:this.marshal()}).subarray()}equals(e){return ae(this.bytes,e.bytes)}hash(){let e=me.digest(this.bytes);return $e(e)?e.then(({bytes:t})=>t):e.bytes}},Vr=class{_key;_publicKey;constructor(e,t){this._key=e,this._publicKey=t}genSecret(){return at(16)}sign(e){return Ll(this._key,e)}get public(){if(this._publicKey==null)throw new U("public key not provided","ERR_PUBKEY_NOT_PROVIDED");return new yn(this._publicKey)}marshal(){return $t.jwkToPkcs1(this._key)}get bytes(){return ot.encode({Type:se.RSA,Data:this.marshal()}).subarray()}equals(e){return ae(this.bytes,e.bytes)}hash(){let e=me.digest(this.bytes);return $e(e)?e.then(({bytes:t})=>t):e.bytes}async id(){let e=await this.public.hash();return X(e,"base58btc")}async export(e,t="pkcs-8"){if(t==="pkcs-8")return $t.exportToPem(this,e);if(t==="libp2p-key")return Cr(this.bytes,e);throw new U(`export format '${t}' is not supported`,"ERR_INVALID_EXPORT_FORMAT")}};async function Ro(r){let e=$t.pkcs1ToJwk(r);if(Ps(e)>bn)throw new U("key size is too large","ERR_KEY_SIZE_TOO_LARGE");let t=await No(e);return new Vr(t.privateKey,t.publicKey)}function fp(r){let e=$t.pkixToJwk(r);if(Ps(e)>bn)throw new U("key size is too large","ERR_KEY_SIZE_TOO_LARGE");return new yn(e)}async function hp(r){if(Ps(r)>bn)throw new U("key size is too large","ERR_KEY_SIZE_TOO_LARGE");let e=await No(r);return new Vr(e.privateKey,e.publicKey)}async function dp(r){if(r>bn)throw new U("key size is too large","ERR_KEY_SIZE_TOO_LARGE");let e=await Cl(r);return new Vr(e.privateKey,e.publicKey)}var Po={};ge(Po,{Secp256k1PrivateKey:()=>xn,Secp256k1PublicKey:()=>wn,generateKeyPair:()=>_p,unmarshalSecp256k1PrivateKey:()=>Sp,unmarshalSecp256k1PublicKey:()=>Bp});var pp=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]),Gt=new Uint32Array([1779033703,3144134277,1013904242,2773480762,1359893119,2600822924,528734635,1541459225]),jt=new Uint32Array(64),Lo=class extends Ir{constructor(){super(64,32,8,!1),this.A=Gt[0]|0,this.B=Gt[1]|0,this.C=Gt[2]|0,this.D=Gt[3]|0,this.E=Gt[4]|0,this.F=Gt[5]|0,this.G=Gt[6]|0,this.H=Gt[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 l=0;l<16;l++,t+=4)jt[l]=e.getUint32(t,!1);for(let l=16;l<64;l++){let m=jt[l-15],u=jt[l-2],d=Ze(m,7)^Ze(m,18)^m>>>3,p=Ze(u,17)^Ze(u,19)^u>>>10;jt[l]=p+jt[l-7]+d+jt[l-16]|0}let{A:n,B:s,C:i,D:o,E:a,F:c,G:h,H:f}=this;for(let l=0;l<64;l++){let m=Ze(a,6)^Ze(a,11)^Ze(a,25),u=f+m+hc(a,c,h)+pp[l]+jt[l]|0,p=(Ze(n,2)^Ze(n,13)^Ze(n,22))+dc(n,s,i)|0;f=h,h=c,c=a,a=o+u|0,o=i,i=s,s=n,n=u+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(){jt.fill(0)}destroy(){this.set(0,0,0,0,0,0,0,0),this.buffer.fill(0)}};var Ol=Ln(()=>new Lo);function gp(r){let e=tn(r);st(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("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("Expected endomorphism with beta: bigint and splitScalar: function")}return Object.freeze({...e})}var{bytesToNumberBE:mp,hexToBytes:yp}=On,ar={Err:class extends Error{constructor(e=""){super(e)}},_parseInt(r){let{Err:e}=ar;if(r.length<2||r[0]!==2)throw new e("Invalid signature integer tag");let t=r[1],n=r.subarray(2,t+2);if(!t||n.length!==t)throw new e("Invalid signature integer: wrong length");if(n[0]&128)throw new e("Invalid signature integer: negative");if(n[0]===0&&!(n[1]&128))throw new e("Invalid signature integer: unnecessary leading zero");return{d:mp(n),l:r.subarray(t+2)}},toSig(r){let{Err:e}=ar,t=typeof r=="string"?yp(r):r;Tr(t);let n=t.length;if(n<2||t[0]!=48)throw new e("Invalid signature tag");if(t[1]!==n-2)throw new e("Invalid signature: incorrect length");let{d:s,l:i}=ar._parseInt(t.subarray(2)),{d:o,l:a}=ar._parseInt(i);if(a.length)throw new e("Invalid signature: left bytes after parsing");return{r:s,s:o}},hexFromSig(r){let e=h=>Number.parseInt(h[0],16)&8?"00"+h:h,t=h=>{let f=h.toString(16);return f.length&1?`0${f}`:f},n=e(t(r.s)),s=e(t(r.r)),i=n.length/2,o=s.length/2,a=t(i),c=t(o);return`30${t(o+i+4)}02${c}${s}02${a}${n}`}},It=BigInt(0),We=BigInt(1),Tb=BigInt(2),Pl=BigInt(3),Rb=BigInt(4);function bp(r){let e=gp(r),{Fp:t}=e,n=e.toBytes||((d,p,b)=>{let g=p.toAffine();return yt(Uint8Array.from([4]),t.toBytes(g.x),t.toBytes(g.y))}),s=e.fromBytes||(d=>{let p=d.subarray(1),b=t.fromBytes(p.subarray(0,t.BYTES)),g=t.fromBytes(p.subarray(t.BYTES,2*t.BYTES));return{x:b,y:g}});function i(d){let{a:p,b}=e,g=t.sqr(d),w=t.mul(g,d);return t.add(t.add(w,t.mul(d,p)),b)}if(!t.eql(t.sqr(e.Gy),i(e.Gx)))throw new Error("bad generator point: equation left != right");function o(d){return typeof d=="bigint"&&It<d&&d<e.n}function a(d){if(!o(d))throw new Error("Expected valid bigint: 0 < bigint < curve.n")}function c(d){let{allowedPrivateKeyLengths:p,nByteLength:b,wrapPrivateKey:g,n:w}=e;if(p&&typeof d!="bigint"){if(Mt(d)&&(d=gt(d)),typeof d!="string"||!p.includes(d.length))throw new Error("Invalid key");d=d.padStart(b*2,"0")}let y;try{y=typeof d=="bigint"?d:mt(ce("private key",d,b))}catch{throw new Error(`private key must be ${b} bytes, hex or bigint, not ${typeof d}`)}return g&&(y=Q(y,w)),a(y),y}let h=new Map;function f(d){if(!(d instanceof l))throw new Error("ProjectivePoint expected")}class l{constructor(p,b,g){if(this.px=p,this.py=b,this.pz=g,p==null||!t.isValid(p))throw new Error("x required");if(b==null||!t.isValid(b))throw new Error("y required");if(g==null||!t.isValid(g))throw new Error("z required")}static fromAffine(p){let{x:b,y:g}=p||{};if(!p||!t.isValid(b)||!t.isValid(g))throw new Error("invalid affine point");if(p instanceof l)throw new Error("projective point not allowed");let w=y=>t.eql(y,t.ZERO);return w(b)&&w(g)?l.ZERO:new l(b,g,t.ONE)}get x(){return this.toAffine().x}get y(){return this.toAffine().y}static normalizeZ(p){let b=t.invertBatch(p.map(g=>g.pz));return p.map((g,w)=>g.toAffine(b[w])).map(l.fromAffine)}static fromHex(p){let b=l.fromAffine(s(ce("pointHex",p)));return b.assertValidity(),b}static fromPrivateKey(p){return l.BASE.multiply(c(p))}_setWindowSize(p){this._WINDOW_SIZE=p,h.delete(this)}assertValidity(){if(this.is0()){if(e.allowInfinityPoint&&!t.is0(this.py))return;throw new Error("bad point: ZERO")}let{x:p,y:b}=this.toAffine();if(!t.isValid(p)||!t.isValid(b))throw new Error("bad point: x or y not FE");let g=t.sqr(b),w=i(p);if(!t.eql(g,w))throw new Error("bad point: equation left != right");if(!this.isTorsionFree())throw new Error("bad point: not in prime-order subgroup")}hasEvenY(){let{y:p}=this.toAffine();if(t.isOdd)return!t.isOdd(p);throw new Error("Field doesn't support isOdd")}equals(p){f(p);let{px:b,py:g,pz:w}=this,{px:y,py:E,pz:x}=p,S=t.eql(t.mul(b,x),t.mul(y,w)),v=t.eql(t.mul(g,x),t.mul(E,w));return S&&v}negate(){return new l(this.px,t.neg(this.py),this.pz)}double(){let{a:p,b}=e,g=t.mul(b,Pl),{px:w,py:y,pz:E}=this,x=t.ZERO,S=t.ZERO,v=t.ZERO,B=t.mul(w,w),$=t.mul(y,y),q=t.mul(E,E),P=t.mul(w,y);return P=t.add(P,P),v=t.mul(w,E),v=t.add(v,v),x=t.mul(p,v),S=t.mul(g,q),S=t.add(x,S),x=t.sub($,S),S=t.add($,S),S=t.mul(x,S),x=t.mul(P,x),v=t.mul(g,v),q=t.mul(p,q),P=t.sub(B,q),P=t.mul(p,P),P=t.add(P,v),v=t.add(B,B),B=t.add(v,B),B=t.add(B,q),B=t.mul(B,P),S=t.add(S,B),q=t.mul(y,E),q=t.add(q,q),B=t.mul(q,P),x=t.sub(x,B),v=t.mul(q,$),v=t.add(v,v),v=t.add(v,v),new l(x,S,v)}add(p){f(p);let{px:b,py:g,pz:w}=this,{px:y,py:E,pz:x}=p,S=t.ZERO,v=t.ZERO,B=t.ZERO,$=e.a,q=t.mul(e.b,Pl),P=t.mul(b,y),te=t.mul(g,E),C=t.mul(w,x),Fe=t.add(b,g),_=t.add(y,E);Fe=t.mul(Fe,_),_=t.add(P,te),Fe=t.sub(Fe,_),_=t.add(b,w);let N=t.add(y,x);return _=t.mul(_,N),N=t.add(P,C),_=t.sub(_,N),N=t.add(g,w),S=t.add(E,x),N=t.mul(N,S),S=t.add(te,C),N=t.sub(N,S),B=t.mul($,_),S=t.mul(q,C),B=t.add(S,B),S=t.sub(te,B),B=t.add(te,B),v=t.mul(S,B),te=t.add(P,P),te=t.add(te,P),C=t.mul($,C),_=t.mul(q,_),te=t.add(te,C),C=t.sub(P,C),C=t.mul($,C),_=t.add(_,C),P=t.mul(te,_),v=t.add(v,P),P=t.mul(N,_),S=t.mul(Fe,S),S=t.sub(S,P),P=t.mul(Fe,te),B=t.mul(N,B),B=t.add(B,P),new l(S,v,B)}subtract(p){return this.add(p.negate())}is0(){return this.equals(l.ZERO)}wNAF(p){return u.wNAFCached(this,h,p,b=>{let g=t.invertBatch(b.map(w=>w.pz));return b.map((w,y)=>w.toAffine(g[y])).map(l.fromAffine)})}multiplyUnsafe(p){let b=l.ZERO;if(p===It)return b;if(a(p),p===We)return this;let{endo:g}=e;if(!g)return u.unsafeLadder(this,p);let{k1neg:w,k1:y,k2neg:E,k2:x}=g.splitScalar(p),S=b,v=b,B=this;for(;y>It||x>It;)y&We&&(S=S.add(B)),x&We&&(v=v.add(B)),B=B.double(),y>>=We,x>>=We;return w&&(S=S.negate()),E&&(v=v.negate()),v=new l(t.mul(v.px,g.beta),v.py,v.pz),S.add(v)}multiply(p){a(p);let b=p,g,w,{endo:y}=e;if(y){let{k1neg:E,k1:x,k2neg:S,k2:v}=y.splitScalar(b),{p:B,f:$}=this.wNAF(x),{p:q,f:P}=this.wNAF(v);B=u.constTimeNegate(E,B),q=u.constTimeNegate(S,q),q=new l(t.mul(q.px,y.beta),q.py,q.pz),g=B.add(q),w=$.add(P)}else{let{p:E,f:x}=this.wNAF(b);g=E,w=x}return l.normalizeZ([g,w])[0]}multiplyAndAddUnsafe(p,b,g){let w=l.BASE,y=(x,S)=>S===It||S===We||!x.equals(w)?x.multiplyUnsafe(S):x.multiply(S),E=y(this,b).add(y(p,g));return E.is0()?void 0:E}toAffine(p){let{px:b,py:g,pz:w}=this,y=this.is0();p==null&&(p=y?t.ONE:t.inv(w));let E=t.mul(b,p),x=t.mul(g,p),S=t.mul(w,p);if(y)return{x:t.ZERO,y:t.ZERO};if(!t.eql(S,t.ONE))throw new Error("invZ was invalid");return{x:E,y:x}}isTorsionFree(){let{h:p,isTorsionFree:b}=e;if(p===We)return!0;if(b)return b(l,this);throw new Error("isTorsionFree() has not been declared for the elliptic curve")}clearCofactor(){let{h:p,clearCofactor:b}=e;return p===We?this:b?b(l,this):this.multiplyUnsafe(e.h)}toRawBytes(p=!0){return this.assertValidity(),n(l,this,p)}toHex(p=!0){return gt(this.toRawBytes(p))}}l.BASE=new l(e.Gx,e.Gy,t.ONE),l.ZERO=new l(t.ZERO,t.ONE,t.ZERO);let m=e.nBitLength,u=Vn(l,e.endo?Math.ceil(m/2):m);return{CURVE:e,ProjectivePoint:l,normPrivateKeyToScalar:c,weierstrassEquation:i,isWithinCurveOrder:o}}function wp(r){let e=tn(r);return st(e,{hash:"hash",hmac:"function",randomBytes:"function"},{bits2int:"function",bits2int_modN:"function",lowS:"boolean"}),Object.freeze({lowS:!0,...e})}function Ml(r){let e=wp(r),{Fp:t,n}=e,s=t.BYTES+1,i=2*t.BYTES+1;function o(_){return It<_&&_<t.ORDER}function a(_){return Q(_,n)}function c(_){return Pn(_,n)}let{ProjectivePoint:h,normPrivateKeyToScalar:f,weierstrassEquation:l,isWithinCurveOrder:m}=bp({...e,toBytes(_,N,H){let I=N.toAffine(),A=t.toBytes(I.x),R=yt;return H?R(Uint8Array.from([N.hasEvenY()?2:3]),A):R(Uint8Array.from([4]),A,t.toBytes(I.y))},fromBytes(_){let N=_.length,H=_[0],I=_.subarray(1);if(N===s&&(H===2||H===3)){let A=mt(I);if(!o(A))throw new Error("Point is not on curve");let R=l(A),L;try{L=t.sqrt(R)}catch(K){let Y=K instanceof Error?": "+K.message:"";throw new Error("Point is not on curve"+Y)}let O=(L&We)===We;return(H&1)===1!==O&&(L=t.neg(L)),{x:A,y:L}}else if(N===i&&H===4){let A=t.fromBytes(I.subarray(0,t.BYTES)),R=t.fromBytes(I.subarray(t.BYTES,2*t.BYTES));return{x:A,y:R}}else throw new Error(`Point of length ${N} was invalid. Expected ${s} compressed bytes or ${i} uncompressed bytes`)}}),u=_=>gt(Ht(_,e.nByteLength));function d(_){let N=n>>We;return _>N}function p(_){return d(_)?a(-_):_}let b=(_,N,H)=>mt(_.slice(N,H));class g{constructor(N,H,I){this.r=N,this.s=H,this.recovery=I,this.assertValidity()}static fromCompact(N){let H=e.nByteLength;return N=ce("compactSignature",N,H*2),new g(b(N,0,H),b(N,H,2*H))}static fromDER(N){let{r:H,s:I}=ar.toSig(ce("DER",N));return new g(H,I)}assertValidity(){if(!m(this.r))throw new Error("r must be 0 < r < CURVE.n");if(!m(this.s))throw new Error("s must be 0 < s < CURVE.n")}addRecoveryBit(N){return new g(this.r,this.s,N)}recoverPublicKey(N){let{r:H,s:I,recovery:A}=this,R=v(ce("msgHash",N));if(A==null||![0,1,2,3].includes(A))throw new Error("recovery id invalid");let L=A===2||A===3?H+e.n:H;if(L>=t.ORDER)throw new Error("recovery id 2 or 3 invalid");let O=A&1?"03":"02",F=h.fromHex(O+u(L)),K=c(L),Y=a(-R*K),j=a(I*K),W=h.BASE.multiplyAndAddUnsafe(F,Y,j);if(!W)throw new Error("point at infinify");return W.assertValidity(),W}hasHighS(){return d(this.s)}normalizeS(){return this.hasHighS()?new g(this.r,a(-this.s),this.recovery):this}toDERRawBytes(){return Qt(this.toDERHex())}toDERHex(){return ar.hexFromSig({r:this.r,s:this.s})}toCompactRawBytes(){return Qt(this.toCompactHex())}toCompactHex(){return u(this.r)+u(this.s)}}let w={isValidPrivateKey(_){try{return f(_),!0}catch{return!1}},normPrivateKeyToScalar:f,randomPrivateKey:()=>{let _=Xi(e.n);return Sc(e.randomBytes(_),e.n)},precompute(_=8,N=h.BASE){return N._setWindowSize(_),N.multiply(BigInt(3)),N}};function y(_,N=!0){return h.fromPrivateKey(_).toRawBytes(N)}function E(_){let N=Mt(_),H=typeof _=="string",I=(N||H)&&_.length;return N?I===s||I===i:H?I===2*s||I===2*i:_ instanceof h}function x(_,N,H=!0){if(E(_))throw new Error("first arg must be private key");if(!E(N))throw new Error("second arg must be public key");return h.fromHex(N).multiply(f(_)).toRawBytes(H)}let S=e.bits2int||function(_){let N=mt(_),H=_.length*8-e.nBitLength;return H>0?N>>BigInt(H):N},v=e.bits2int_modN||function(_){return a(S(_))},B=en(e.nBitLength);function $(_){if(typeof _!="bigint")throw new Error("bigint expected");if(!(It<=_&&_<B))throw new Error(`bigint expected < 2^${e.nBitLength}`);return Ht(_,e.nByteLength)}function q(_,N,H=P){if(["recovered","canonical"].some(ie=>ie in H))throw new Error("sign() legacy options not supported");let{hash:I,randomBytes:A}=e,{lowS:R,prehash:L,extraEntropy:O}=H;R==null&&(R=!0),_=ce("msgHash",_),L&&(_=ce("prehashed msgHash",I(_)));let F=v(_),K=f(N),Y=[$(K),$(F)];if(O!=null&&O!==!1){let ie=O===!0?A(t.BYTES):O;Y.push(ce("extraEntropy",ie))}let j=yt(...Y),W=F;function ue(ie){let be=S(ie);if(!m(be))return;let we=c(be),he=h.BASE.multiply(be).toAffine(),Ae=a(he.x);if(Ae===It)return;let ft=a(we*a(W+Ae*K));if(ft===It)return;let Zt=(he.x===Ae?0:2)|Number(he.y&We),Wr=ft;return R&&d(ft)&&(Wr=p(ft),Zt^=1),new g(Ae,Wr,Zt)}return{seed:j,k2sig:ue}}let P={lowS:e.lowS,prehash:!1},te={lowS:e.lowS,prehash:!1};function C(_,N,H=P){let{seed:I,k2sig:A}=q(_,N,H),R=e;return ji(R.hash.outputLen,R.nByteLength,R.hmac)(I,A)}h.BASE._setWindowSize(8);function Fe(_,N,H,I=te){let A=_;if(N=ce("msgHash",N),H=ce("publicKey",H),"strict"in I)throw new Error("options.strict was renamed to lowS");let{lowS:R,prehash:L}=I,O,F;try{if(typeof A=="string"||Mt(A))try{O=g.fromDER(A)}catch(he){if(!(he instanceof ar.Err))throw he;O=g.fromCompact(A)}else if(typeof A=="object"&&typeof A.r=="bigint"&&typeof A.s=="bigint"){let{r:he,s:Ae}=A;O=new g(he,Ae)}else throw new Error("PARSE");F=h.fromHex(H)}catch(he){if(he.message==="PARSE")throw new Error("signature must be Signature instance, Uint8Array or hex string");return!1}if(R&&O.hasHighS())return!1;L&&(N=e.hash(N));let{r:K,s:Y}=O,j=v(N),W=c(Y),ue=a(j*W),ie=a(K*W),be=h.BASE.multiplyAndAddUnsafe(F,ue,ie)?.toAffine();return be?a(be.x)===K:!1}return{CURVE:e,getPublicKey:y,getSharedSecret:x,sign:C,verify:Fe,ProjectivePoint:h,Signature:g,utils:w}}function xp(r){return{hash:r,hmac:(e,...t)=>an(r,e,Cn(...t)),randomBytes:_r}}function Vl(r,e){let t=n=>Ml({...r,...xp(n)});return Object.freeze({...t(e),create:t})}var Kl=BigInt("0xfffffffffffffffffffffffffffffffffffffffffffffffffffffffefffffc2f"),Hl=BigInt("0xfffffffffffffffffffffffffffffffebaaedce6af48a03bbfd25e8cd0364141"),vp=BigInt(1),Uo=BigInt(2),Fl=(r,e)=>(r+e/Uo)/e;function Ep(r){let e=Kl,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,l=ne(f,t,e)*f%e,m=ne(l,t,e)*f%e,u=ne(m,Uo,e)*h%e,d=ne(u,s,e)*u%e,p=ne(d,i,e)*d%e,b=ne(p,a,e)*p%e,g=ne(b,c,e)*b%e,w=ne(g,a,e)*p%e,y=ne(w,t,e)*f%e,E=ne(y,o,e)*d%e,x=ne(E,n,e)*h%e,S=ne(x,Uo,e);if(!Do.eql(Do.sqr(S),r))throw new Error("Cannot find square root");return S}var Do=Mn(Kl,void 0,void 0,{sqrt:Ep}),tt=Vl({a:BigInt(0),b:BigInt(7),Fp:Do,n:Hl,Gx:BigInt("55066263022277343669578718895168534326250603453777594175500187360389116729240"),Gy:BigInt("32670510020758816978083085130507043184471273380659243275938904335757337482424"),h:BigInt(1),lowS:!0,endo:{beta:BigInt("0x7ae96a2b657c07106e64479eac3434e99cf0497512f58995c1396c28719501ee"),splitScalar:r=>{let e=Hl,t=BigInt("0x3086d221a7d46bcde86c90e49284eb15"),n=-vp*BigInt("0xe4437ed6010e88286f547fa90abfe4c3"),s=BigInt("0x114ca50f7a8e2f3f657c1108d9d44cfd8"),i=t,o=BigInt("0x100000000000000000000000000000000"),a=Fl(i*r,e),c=Fl(-n*r,e),h=Q(r-a*t-c*s,e),f=Q(-a*n-c*i,e),l=h>o,m=f>o;if(l&&(h=e-h),m&&(f=e-f),h>o||f>o)throw new Error("splitScalar: Endomorphism failed, k="+r);return{k1neg:l,k1:h,k2neg:m,k2:f}}}},Ol),Vb=BigInt(0);var Hb=tt.ProjectivePoint;function ql(){return tt.utils.randomPrivateKey()}function zl(r,e){let t=me.digest(e instanceof Uint8Array?e:e.subarray());if($e(t))return t.then(({digest:n})=>tt.sign(n,r).toDERRawBytes()).catch(n=>{throw new U(String(n),"ERR_INVALID_INPUT")});try{return tt.sign(t.digest,r).toDERRawBytes()}catch(n){throw new U(String(n),"ERR_INVALID_INPUT")}}function $l(r,e,t){let n=me.digest(t instanceof Uint8Array?t:t.subarray());if($e(n))return n.then(({digest:s})=>tt.verify(e,s,r)).catch(s=>{throw new U(String(s),"ERR_INVALID_INPUT")});try{return tt.verify(e,n.digest,r)}catch(s){throw new U(String(s),"ERR_INVALID_INPUT")}}function Gl(r){return tt.ProjectivePoint.fromHex(r).toRawBytes(!0)}function jl(r){try{tt.getPublicKey(r,!0)}catch(e){throw new U(String(e),"ERR_INVALID_PRIVATE_KEY")}}function Oo(r){try{tt.ProjectivePoint.fromHex(r)}catch(e){throw new U(String(e),"ERR_INVALID_PUBLIC_KEY")}}function Wl(r){try{return tt.getPublicKey(r,!0)}catch(e){throw new U(String(e),"ERR_INVALID_PRIVATE_KEY")}}var wn=class{_key;constructor(e){Oo(e),this._key=e}verify(e,t){return $l(this._key,t,e)}marshal(){return Gl(this._key)}get bytes(){return it.encode({Type:se.Secp256k1,Data:this.marshal()}).subarray()}equals(e){return ae(this.bytes,e.bytes)}async hash(){let e=me.digest(this.bytes),t;return $e(e)?{bytes:t}=await e:t=e.bytes,t}},xn=class{_key;_publicKey;constructor(e,t){this._key=e,this._publicKey=t??Wl(e),jl(this._key),Oo(this._publicKey)}sign(e){return zl(this._key,e)}get public(){return new wn(this._publicKey)}marshal(){return this._key}get bytes(){return ot.encode({Type:se.Secp256k1,Data:this.marshal()}).subarray()}equals(e){return ae(this.bytes,e.bytes)}hash(){let e=me.digest(this.bytes);return $e(e)?e.then(({bytes:t})=>t):e.bytes}async id(){let e=await this.public.hash();return X(e,"base58btc")}async export(e,t="libp2p-key"){if(t==="libp2p-key")return Cr(this.bytes,e);throw new U(`export format '${t}' is not supported`,"ERR_INVALID_EXPORT_FORMAT")}};function Sp(r){return new xn(r)}function Bp(r){return new wn(r)}async function _p(){let r=ql();return new xn(r)}var cr={rsa:Co,ed25519:Eo,secp256k1:Po};function Yl(r){let e=Object.keys(cr).join(" / ");return new U(`invalid or unsupported key type ${r}. Must be ${e}`,"ERR_UNSUPPORTED_KEY_TYPE")}function Zl(r){let e=it.decode(r),t=e.Data??new Uint8Array;switch(e.Type){case se.RSA:return cr.rsa.unmarshalRsaPublicKey(t);case se.Ed25519:return cr.ed25519.unmarshalEd25519PublicKey(t);case se.Secp256k1:return cr.secp256k1.unmarshalSecp256k1PublicKey(t);default:throw Yl(e.Type??"unknown")}}async function Xl(r){let e=ot.decode(r),t=e.Data??new Uint8Array;switch(e.Type){case se.RSA:return cr.rsa.unmarshalRsaPrivateKey(t);case se.Ed25519:return cr.ed25519.unmarshalEd25519PrivateKey(t);case se.Secp256k1:return cr.secp256k1.unmarshalSecp256k1PrivateKey(t);default:throw Yl(e.Type??"RSA")}}var Ql=Symbol.for("@achingbrain/uint8arraylist");function Jl(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 Ms(r){return!!r?.[Ql]}var Me=class r{bufs;length;[Ql]=!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(Ms(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(Ms(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=Jl(this.bufs,e);return t.buf[t.index]}set(e,t){let n=Jl(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(Ms(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 ke(n,s)}subarray(e,t){let{bufs:n,length:s}=this._subList(e,t);return n.length===1?n[0]:ke(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 l=e-a;n.push(o.subarray(l,l+(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(!Ms(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 l=0;l<i;l++)o[l]=-1;for(let l=0;l<s;l++)o[n[l]]=l;let a=o,c=this.byteLength-n.byteLength,h=n.byteLength-1,f;for(let l=t;l<=c;l+=f){f=0;for(let m=h;m>=0;m--){let u=this.get(l+m);if(n[m]!==u){f=Math.max(1,m-a[u]);break}}if(f===0)return l}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=Ne(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=xe(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=xe(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=xe(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=Ne(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=xe(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=xe(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=xe(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=xe(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=xe(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(!ae(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 eu={ERR_SIGNATURE_NOT_VALID:"ERR_SIGNATURE_NOT_VALID"};var vn;(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)=>{let s={publicKey:new Uint8Array(0),payloadType:new Uint8Array(0),payload:new Uint8Array(0),signature:new Uint8Array(0)},i=n==null?t.len:t.pos+n;for(;t.pos<i;){let o=t.uint32();switch(o>>>3){case 1:s.publicKey=t.bytes();break;case 2:s.payloadType=t.bytes();break;case 3:s.payload=t.bytes();break;case 5:s.signature=t.bytes();break;default:t.skipType(o&7);break}}return s})),e),r.encode=t=>Oe(t,r.codec()),r.decode=t=>De(t,r.codec())})(vn||(vn={}));var En=class r{static createFromProtobuf=async e=>{let t=vn.decode(e),n=await oc(t.publicKey);return new r({peerId:n,payloadType:t.payloadType,payload:t.payload,signature:t.signature})};static seal=async(e,t)=>{if(t.privateKey==null)throw new Error("Missing private key");let n=e.domain,s=e.codec,i=e.marshal(),o=tu(n,s,i),c=await(await Xl(t.privateKey)).sign(o.subarray());return new r({peerId:t,payloadType:s,payload:i,signature:c})};static openAndCertify=async(e,t)=>{let n=await r.createFromProtobuf(e);if(!await n.validate(t))throw new U("envelope signature is not valid for the given domain",eu.ERR_SIGNATURE_NOT_VALID);return n};peerId;payloadType;payload;signature;marshaled;constructor(e){let{peerId:t,payloadType:n,payload:s,signature:i}=e;this.peerId=t,this.payloadType=n,this.payload=s,this.signature=i}marshal(){if(this.peerId.publicKey==null)throw new Error("Missing public key");return this.marshaled==null&&(this.marshaled=vn.encode({publicKey:this.peerId.publicKey,payloadType:this.payloadType,payload:this.payload.subarray(),signature:this.signature})),this.marshaled}equals(e){return ae(this.marshal(),e.marshal())}async validate(e){let t=tu(e,this.payloadType,this.payload);if(this.peerId.publicKey==null)throw new Error("Missing public key");return Zl(this.peerId.publicKey).verify(t.subarray(),this.signature)}},tu=(r,e,t)=>{let n=V(r),s=Ge(n.byteLength),i=Ge(e.length),o=Ge(t.length);return new Me(s,n,i,e,o,t)};var Vs=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 l=this.readChar();if(l===void 0)return;let m=Number.parseInt(l,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 ru=45,Ip=15,Hr=new Vs;function Mo(r){if(!(r.length>Ip))return Hr.new(r).parseWith(()=>Hr.readIPv4Addr())}function Vo(r){if(r.includes("%")&&(r=r.split("%")[0]),!(r.length>ru))return Hr.new(r).parseWith(()=>Hr.readIPv6Addr())}function Hs(r){if(r.includes("%")&&(r=r.split("%")[0]),!(r.length>ru))return Hr.new(r).parseWith(()=>Hr.readIPAddr())}var Bw=parseInt("0xFFFF",16),_w=new Uint8Array([0,0,0,0,0,0,0,0,0,0,255,255]);function iu(r){return!!Mo(r)}function ou(r){return!!Vo(r)}function Fs(r){return!!Hs(r)}var au=iu,Cp=ou,Ho=function(r){let e=0;if(r=r.toString().trim(),au(r)){let t=new Uint8Array(e+4);return r.split(/\./g).forEach(n=>{t[e++]=parseInt(n,10)&255}),t}if(Cp(r)){let t=r.split(":",8),n;for(n=0;n<t.length;n++){let i=au(t[n]),o;i&&(o=Ho(t[n]),t[n]=X(o.slice(0,2),"base16")),o!=null&&++n<8&&t.splice(n,0,X(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")},cu=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 Fr={},Fo={},Up=[[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"]];Up.forEach(r=>{let e=Dp(...r);Fo[e.code]=e,Fr[e.name]=e});function Dp(r,e,t,n,s){return{code:r,size:e,name:t,resolvable:!!n,path:!!s}}function ee(r){if(typeof r=="number"){if(Fo[r]!=null)return Fo[r];throw new Error(`no protocol with code: ${r}`)}else if(typeof r=="string"){if(Fr[r]!=null)return Fr[r];throw new Error(`no protocol with name: ${r}`)}throw new Error(`invalid protocol id type: ${typeof r}`)}var l1=ee("ip4"),u1=ee("ip6"),f1=ee("ipcidr");function $o(r,e){switch(ee(r).code){case 4:case 41:return Pp(e);case 42:return zo(e);case 6:case 273:case 33:case 132:return fu(e).toString();case 53:case 54:case 55:case 56:case 400:case 449:case 777:return zo(e);case 421:return Fp(e);case 444:return uu(e);case 445:return uu(e);case 466:return Hp(e);case 481:return globalThis.encodeURIComponent(zo(e));default:return X(e,"base16")}}function Go(r,e){switch(ee(r).code){case 4:return lu(e);case 41:return lu(e);case 42:return qo(e);case 6:case 273:case 33:case 132:return jo(parseInt(e,10));case 53:case 54:case 55:case 56:case 400:case 449:case 777:return qo(e);case 421:return Mp(e);case 444:return Kp(e);case 445:return qp(e);case 466:return Vp(e);case 481:return qo(globalThis.decodeURIComponent(e));default:return V(e,"base16")}}var Ko=Object.values(Lt).map(r=>r.decoder),Op=function(){let r=Ko[0].or(Ko[1]);return Ko.slice(2).forEach(e=>r=r.or(e)),r}();function lu(r){if(!Fs(r))throw new Error("invalid ip address");return Ho(r)}function Pp(r){let e=cu(r,0,r.length);if(e==null)throw new Error("ipBuff is required");if(!Fs(e))throw new Error("invalid ip address");return e}function jo(r){let e=new ArrayBuffer(2);return new DataView(e).setUint16(0,r),new Uint8Array(e)}function fu(r){return new DataView(r.buffer).getUint16(r.byteOffset)}function qo(r){let e=V(r),t=Uint8Array.from(Ge(e.length));return ke([t,e],t.length+e.length)}function zo(r){let e=xt(r);if(r=r.slice(Be(e)),r.length!==e)throw new Error("inconsistent lengths");return X(r)}function Mp(r){let e;r[0]==="Q"||r[0]==="1"?e=Xt(de.decode(`z${r}`)).bytes:e=ze.parse(r).multihash.bytes;let t=Uint8Array.from(Ge(e.length));return ke([t,e],t.length+e.length)}function Vp(r){let e=Op.decode(r),t=Uint8Array.from(Ge(e.length));return ke([t,e],t.length+e.length)}function Hp(r){let e=xt(r),t=r.slice(Be(e));if(t.length!==e)throw new Error("inconsistent lengths");return"u"+X(t,"base64url")}function Fp(r){let e=xt(r),t=r.slice(Be(e));if(t.length!==e)throw new Error("inconsistent lengths");return X(t,"base58btc")}function Kp(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=dt.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=jo(n);return ke([t,s],t.length+s.length)}function qp(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=dt.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=jo(n);return ke([t,s],t.length+s.length)}function uu(r){let e=r.slice(0,r.length-2),t=r.slice(r.length-2),n=X(e,"base32"),s=fu(t);return`${n}:${s}`}function hu(r){r=Wo(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=ee(o);if(a.size===0){e.push([a.code]),t.push([a.code]);continue}if(i++,i>=s.length)throw pu("invalid address: "+r);if(a.path===!0){n=Wo(s.slice(i).join("/")),e.push([a.code,Go(a.code,n)]),t.push([a.code,n]);break}let c=Go(a.code,s[i]);e.push([a.code,c]),t.push([a.code,$o(a.code,c)])}return{string:du(t),bytes:Zo(e),tuples:e,stringTuples:t,path:n}}function Yo(r){let e=[],t=[],n=null,s=0;for(;s<r.length;){let i=xt(r,s),o=Be(i),a=ee(i),c=zp(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 pu("Invalid address Uint8Array: "+X(r,"base16"));e.push([i,h]);let f=$o(i,h);if(t.push([i,f]),a.path===!0){n=f;break}}return{bytes:Uint8Array.from(r),string:du(t),tuples:e,stringTuples:t,path:n}}function du(r){let e=[];return r.map(t=>{let n=ee(t[0]);return e.push(n.name),t.length>1&&t[1]!=null&&e.push(t[1]),null}),Wo(e.join("/"))}function Zo(r){return ke(r.map(e=>{let t=ee(e[0]),n=Uint8Array.from(Ge(t.code));return e.length>1&&e[1]!=null&&(n=ke([n,e[1]])),n}))}function zp(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+Be(t)}}function Wo(r){return"/"+r.trim().split("/").filter(e=>e).join("/")}function pu(r){return new Error("Error parsing address: "+r)}var $p=Symbol.for("nodejs.util.inspect.custom"),Xo=Symbol.for("@multiformats/js-multiaddr/multiaddr"),Gp=[ee("dns").code,ee("dns4").code,ee("dns6").code,ee("dnsaddr").code],Ks=class r{bytes;#e;#t;#r;#n;[Xo]=!0;constructor(e){e==null&&(e="");let t;if(e instanceof Uint8Array)t=Yo(e);else if(typeof e=="string"){if(e.length>0&&e.charAt(0)!=="/")throw new Error(`multiaddr "${e}" must start with a "/"`);t=hu(e)}else if(mu(e))t=Yo(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=ee("tcp"),a=ee("udp"),c=ee("ip4"),h=ee("ip6"),f=ee("dns6"),l=ee("ip6zone");for(let[u,d]of this.stringTuples())u===l.code&&(i=`%${d??""}`),Gp.includes(u)&&(t=o.name,s=443,n=`${d??""}${i}`,e=u===f.code?6:4),(u===o.code||u===a.code)&&(t=ee(u).name,s=parseInt(d??"")),(u===c.code||u===h.code)&&(t=ee(u).name,n=`${d??""}${i}`,e=u===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({},ee(e)))}protoCodes(){return this.#t.map(([e])=>e)}protoNames(){return this.#t.map(([e])=>ee(e).name)}tuples(){return this.#t}stringTuples(){return this.#r}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(Zo(t.slice(0,n)));return this}getPeerId(){try{let e=[];this.stringTuples().forEach(([n,s])=>{n===Fr.p2p.code&&e.push([n,s]),n===Fr["p2p-circuit"].code&&(e=[])});let t=e.pop();if(t?.[1]!=null){let n=t[1];return n[0]==="Q"||n[0]==="1"?X(de.decode(`z${n}`),"base58btc"):X(ze.parse(n).multihash.bytes,"base58btc")}return null}catch{return null}}getPath(){return this.#n}equals(e){return ae(this.bytes,e.bytes)}async resolve(e){let t=this.protos().find(i=>i.resolvable);if(t==null)return[this];let n=gu.get(t.name);if(n==null)throw new U(`no available resolver for ${t.name}`,"ERR_NO_AVAILABLE_RESOLVER");return(await n(this,e)).map(i=>Ee(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)}[$p](){return`Multiaddr(${this.#e})`}};var gu=new Map;function mu(r){return!!r?.[Xo]}function Ee(r){return new Ks(r)}function Ve(){let r={};return r.promise=new Promise((e,t)=>{r.resolve=e,r.reject=t}),r}var qs=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 Kr(r,e,t){if(e==null)return r;if(e.aborted)return Promise.reject(new qs(t?.errorMessage,t?.errorCode));let n,s=new qs(t?.errorMessage,t?.errorCode);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 Jo=class{readNext;haveNext;ended;nextResult;constructor(){this.ended=!1,this.readNext=Ve(),this.haveNext=Ve()}[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=Ve(),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=Ve(),await Kr(this.readNext.promise,t?.signal,t)}};function yu(){return new Jo}var zs=class extends Error{code;constructor(e,t){super(e),this.code=t}},Qo=class extends zs{type;constructor(e){super(e,"ABORT_ERR"),this.type="aborted"}};function bu(r,e){let t=yu();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 Me;return{read:async(o,a)=>{a?.signal?.throwIfAborted();let c,h=new Promise((f,l)=>{c=()=>{l(new Qo("Read aborted"))},a?.signal?.addEventListener("abort",c)});try{if(o==null){let{done:l,value:m}=await Promise.race([n.next(),h]);return l===!0?new Me:m}for(;s.byteLength<o;){let{value:l,done:m}=await Promise.race([n.next(),h]);if(m===!0)throw new zs("unexpected end of input","ERR_UNEXPECTED_EOF");s.append(l)}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 $s=class extends Error{code;constructor(e,t){super(e),this.code=t}};function wu(r,e={}){let t=bu(r,e);e.maxDataLength!=null&&e.maxLengthLength==null&&(e.maxLengthLength=Be(e.maxDataLength));let n=e?.lengthDecoder??xt,s=e?.lengthEncoder??Ge;return{read:async o=>{let a=-1,c=new Me;for(;;){c.append(await t.read(1,o));try{a=n(c)}catch(h){if(h instanceof RangeError)continue;throw h}if(e?.maxLengthLength!=null&&c.byteLength>e.maxLengthLength)throw new $s("message length length too long","ERR_MSG_LENGTH_TOO_LONG");if(a>-1)break}if(e?.maxDataLength!=null&&a>e.maxDataLength)throw new $s("message length too long","ERR_MSG_DATA_TOO_LONG");return t.read(a,o)},write:async(o,a)=>{await t.write(new Me(s(o.byteLength),o),a)},writeV:async(o,a)=>{let c=new Me(...o.flatMap(h=>[s(h.byteLength),h]));await t.write(c,a)},unwrap:()=>t.unwrap()}}function Wt(r,e){let t=wu(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 xu="circuit-relay-source",vu="circuit-relay-relay";var Eu=BigInt(131072),Ye="/libp2p/circuit/relay/0.2.0/hop",lr="/libp2p/circuit/relay/0.2.0/stop",Au=30*1e3,X1=30*1e3,An=300;var ea="ERR_RELAYED_DIAL",Su="ERR_HOP_REQUEST_FAILED",Gs="ERR_TRANSFER_LIMIT_EXCEEDED",Bu=4096,_u=.001;var J;(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),qr.codec().encode(s.peer,i)),s.reservation!=null&&(i.uint32(26),js.codec().encode(s.reservation,i)),s.limit!=null&&(i.uint32(34),zr.codec().encode(s.limit,i)),s.status!=null&&(i.uint32(40),z.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=qr.codec().decode(s,s.uint32(),{limits:o.limits?.peer});break}case 3:{a.reservation=js.codec().decode(s,s.uint32(),{limits:o.limits?.reservation});break}case 4:{a.limit=zr.codec().decode(s,s.uint32(),{limits:o.limits?.limit});break}case 5:{a.status=z.codec().decode(s);break}default:{s.skipType(h&7);break}}}return a})),n),r.encode=s=>Oe(s,r.codec()),r.decode=(s,i)=>De(s,r.codec(),i)})(J||(J={}));var He;(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),qr.codec().encode(s.peer,i)),s.limit!=null&&(i.uint32(26),zr.codec().encode(s.limit,i)),s.status!=null&&(i.uint32(32),z.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=qr.codec().decode(s,s.uint32(),{limits:o.limits?.peer});break}case 3:{a.limit=zr.codec().decode(s,s.uint32(),{limits:o.limits?.limit});break}case 4:{a.status=z.codec().decode(s);break}default:{s.skipType(h&7);break}}}return a})),n),r.encode=s=>Oe(s,r.codec()),r.decode=(s,i)=>De(s,r.codec(),i)})(He||(He={}));var qr;(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:xe(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 sn('decode error - map field "addrs" had too many elements',"ERR_MAX_LENGTH");i.addrs.push(t.bytes());break}default:{t.skipType(a&7);break}}}return i})),e),r.encode=t=>Oe(t,r.codec()),r.decode=(t,n)=>De(t,r.codec(),n)})(qr||(qr={}));var js;(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),n.bytes(t.voucher)),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 sn('decode error - map field "addrs" had too many elements',"ERR_MAX_LENGTH");i.addrs.push(t.bytes());break}case 3:{i.voucher=t.bytes();break}default:{t.skipType(a&7);break}}}return i})),e),r.encode=t=>Oe(t,r.codec()),r.decode=(t,n)=>De(t,r.codec(),n)})(js||(js={}));var zr;(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=>Oe(t,r.codec()),r.decode=(t,n)=>De(t,r.codec(),n)})(zr||(zr={}));var z;(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"})(z||(z={}));var ta;(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"})(ta||(ta={}));(function(r){r.codec=()=>sr(ta)})(z||(z={}));var Ws;(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:xe(0),peer:xe(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=>Oe(t,r.codec()),r.decode=(t,n)=>De(t,r.codec(),n)})(Ws||(Ws={}));function Ys(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}async function*Iu(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 U(`data limit of ${n} bytes exceeded`,Gs)}e.remaining-=i,yield s}}function ku(r,e,t,n,s){function i(l){r.abort(l),e.abort(l)}let o=[t];n?.duration!=null&&o.push(AbortSignal.timeout(n.duration));let a=Ys(o),c=!1,h=!1,f;n?.data!=null&&(f={remaining:n.data}),queueMicrotask(()=>{let l=()=>{e.abort(new U(`duration limit of ${n?.duration} ms exceeded`,Gs))};a.addEventListener("abort",l,{once:!0}),e.sink(f==null?r.source:Iu(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",l),a.clear())})}),queueMicrotask(()=>{let l=()=>{r.abort(new U(`duration limit of ${n?.duration} ms exceeded`,Gs))};a.addEventListener("abort",l,{once:!0}),r.sink(f==null?e.source:Iu(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",l),a.clear())})})}function ra(r){let e=r*BigInt(1e3),t=new Date().getTime();return Number(e-BigInt(t))}function na(r,e){let t={[Symbol.iterator]:()=>t,next:()=>{let n=r.next(),s=n.value;return n.done===!0||s==null?{done:!0,value:void 0}:{done:!1,value:e(s)}}};return t}var kt=class{map;constructor(e){if(this.map=new Map,e!=null)for(let[t,n]of e.entries())this.map.set(t.toString(),n)}[Symbol.iterator](){return this.entries()}clear(){this.map.clear()}delete(e){return this.map.delete(e.toString())}entries(){return na(this.map.entries(),e=>[Ut(e[0]),e[1]])}forEach(e){this.map.forEach((t,n)=>{e(t,Ut(n),this)})}get(e){return this.map.get(e.toString())}has(e){return this.map.has(e.toString())}set(e,t){this.map.set(e.toString(),t)}keys(){return na(this.map.keys(),e=>Ut(e))}values(){return this.map.values()}get size(){return this.map.size}};var ia=mi(sa(),1);var jp=Math.LN2*Math.LN2,Xs=class{seeds;bits;buffer;constructor(e={}){e.seeds!=null?this.seeds=e.seeds:this.seeds=Yp(e.hashes??8),this.bits=e.bits??1024,this.buffer=xe(Math.ceil(this.bits/8))}add(e){typeof e=="string"&&(e=V(e));for(let t=0;t<this.seeds.length;t++){let s=ia.default.x86.hash32(e,this.seeds[t])%this.bits;this.setbit(s)}}has(e){typeof e=="string"&&(e=V(e));for(let t=0;t<this.seeds.length;t++){let s=ia.default.x86.hash32(e,this.seeds[t])%this.bits;if(!this.getbit(s))return!1}return!0}clear(){this.buffer.fill(0)}setbit(e){let t=0,n=e;for(;n>7;)t++,n-=8;let s=this.buffer[t];s|=1<<n,this.buffer[t]=s}getbit(e){let t=0,n=e;for(;n>7;)t++,n-=8;return(this.buffer[t]&1<<n)!==0}};function oa(r,e=.005){let t=Wp(r,e);return new Xs(t)}function Wp(r,e=.005){let t=Math.round(-1*r*Math.log(e)/jp),n=Math.round(t/r*Math.LN2);return{bits:t,hashes:n}}function Yp(r){let e,t,n=[];for(let s=0;s<r;s++)for(e=new Me(at(4)),n[s]=e.getUint32(0,!0),t=0;t<s;t++)if(n[s]===n[t]){s--;break}return n}var aa=64,rt=class{fp;h;seed;constructor(e,t,n,s=2){if(s>aa)throw new TypeError("Invalid Fingerprint Size");let i=t.hashV(e,n),o=xe(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?ae(this.fp,e.fp):!1}};function ur(r,e){return Math.floor(Math.random()*(e-r))+r}var fr=class{contents;constructor(e){this.contents=new Array(e).fill(null)}has(e){if(!(e instanceof rt))throw new TypeError("Invalid Fingerprint");return this.contents.some(t=>e.equals(t))}add(e){if(!(e instanceof rt))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 rt))throw new TypeError("Invalid Fingerprint");let t=ur(0,this.contents.length-1),n=this.contents[t];return this.contents[t]=e,n}remove(e){if(!(e instanceof rt))throw new TypeError("Invalid Fingerprint");let t=this.contents.findIndex(n=>e.equals(n));return t>-1?(this.contents[t]=null,!0):!1}};var ca={32:16777619n,64:1099511628211n,128:309485009821345068724781371n,256:374144419156711147060143317175368453031918731002211n,512:35835915874844867368919076489095108449946327955754392558399825615420669938882575126094039892345713852759n,1024:5016456510113118655434598811035278955030765345404790744303017523831112055108147451509157692220295382716162651878526895249385292291816524375083746691371804094271873160484737966720260389217684476157468082573n},Nu={32:2166136261n,64:14695981039346656037n,128:144066263297769815596495629667062367629n,256:100029257958052580907070968620625704837092796014241193945225284501741471925557n,512:9659303129496669498009435400716310466090418745672637896108374329434462657994582932197716438449813051892206539805784495328239340083876191928701583869517785n,1024:14197795064947621068722070641403218320880622795441933960878474914617582723252296732303717722150864096521202355549365628174669108571814760471015076148029755969804077320157692458563003215304957150157403644460363550505412711285966361610267868082893823963790439336411086884584107735010676915n},Cu=new globalThis.TextEncoder;function Zp(r,e){let t=ca[e],n=Nu[e];for(let s=0;s<r.length;s++)n^=BigInt(r[s]),n=BigInt.asUintN(e,n*t);return n}function Xp(r,e,t){if(t.length===0)throw new Error("The `utf8Buffer` option must have a length greater than zero");let n=ca[e],s=Nu[e],i=r;for(;i.length>0;){let o=Cu.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 la(r,{size:e=32,utf8Buffer:t}={}){if(!ca[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 Xp(r,e,t);r=Cu.encode(r)}return Zp(r,e)}var Jp=mi(sa(),1);var Bn={hash:r=>Number(la(r,{size:32})),hashV:(r,e)=>Qp(Bn.hash(r,e))};function Qp(r){let e=r.toString(16);return e.length%2===1&&(e=`0${e}`),V(e,"base16")}var e0=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??ur(0,Math.pow(2,10))}add(e){typeof e=="string"&&(e=V(e));let t=new rt(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 fr(this.bucketSize)),this.buckets[s]==null&&(this.buckets[s]=new fr(this.bucketSize)),this.buckets[n].add(t)||this.buckets[s].add(t))return this.count++,!0;let i=[n,s],o=i[ur(0,i.length-1)];this.buckets[o]==null&&(this.buckets[o]=new fr(this.bucketSize));for(let a=0;a<e0;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 fr(this.bucketSize)),this.buckets[o].add(c)))return this.count++,!0}return!1}has(e){typeof e=="string"&&(e=V(e));let t=new rt(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=V(e));let t=new rt(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))<=95}},t0={1:.5,2:.84,4:.95,8:.98};function r0(r=.001){return r>.002?2:r>1e-5?4:8}function Lu(r,e=.001){let t=r0(e),n=t0[t],s=Math.round(r/n),i=Math.min(Math.ceil(Math.log(s/t))+2,aa);return{filterSize:s,bucketSize:t,fingerprintSize:i}}var Js=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??ur(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=V(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=V(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=V(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 ua(r,e=.001,t){return new Js({...Lu(r,e),...t??{}})}var Qs=class{filter;constructor(e,t){this.filter=ua(e,t)}has(e){return this.filter.has(e.toBytes())}add(e){this.filter.add(e.toBytes())}remove(e){this.filter.remove?.(e.toBytes())}};function fa(r,e=.001){return new Qs(r,e)}var ei=class{reservations=new kt;_started=!1;interval;maxReservations;reservationClearInterval;applyDefaultLimit;reservationTtl;defaultDurationLimit;defaultDataLimit;constructor(e={}){this.maxReservations=e.maxReservations??15,this.reservationClearInterval=e.reservationClearInterval??3e5,this.applyDefaultLimit=e.applyDefaultLimit!==!1,this.reservationTtl=e.reservationTtl??72e5,this.defaultDurationLimit=e.defaultDurationLimit??12e4,this.defaultDataLimit=e.defaultDataLimit??Eu}isStarted(){return this._started}start(){this._started||(this._started=!0,this.interval=setInterval(()=>{let e=new Date().getTime();this.reservations.forEach((t,n)=>{t.expire.getTime()<e&&this.reservations.delete(n)})},this.reservationClearInterval))}stop(){clearInterval(this.interval)}reserve(e,t,n){if(this.reservations.size>=this.maxReservations&&!this.reservations.has(e))return{status:z.RESERVATION_REFUSED};let s=new Date(Date.now()+this.reservationTtl),i;return this.applyDefaultLimit&&(i=n??{data:this.defaultDataLimit,duration:this.defaultDurationLimit}),this.reservations.set(e,{addr:t,expire:s,limit:i}),{status:z.OK,expire:Math.round(s.getTime()/1e3)}}removeReservation(e){this.reservations.delete(e)}hasReservation(e){return this.reservations.has(e)}get(e){return this.reservations.get(e)}};var ti=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 Ws.encode({relay:this.relay.toBytes(),peer:this.peer.toBytes(),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 Uu=r=>r.protoCodes().includes(290),a0={maxOutboundStopStreams:An},ha=class extends qe{registrar;peerStore;addressManager;peerId;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.connectionManager=e.connectionManager,this.connectionGater=e.connectionGater,this.started=!1,this.hopTimeout=t?.hopTimeout??Au,this.maxInboundHopStreams=t.maxInboundHopStreams,this.maxOutboundHopStreams=t.maxOutboundHopStreams,this.maxOutboundStopStreams=t.maxOutboundStopStreams??a0.maxOutboundStopStreams,this.reservationStore=new ei(t.reservations),this.shutdownController=new AbortController,Ke(1/0,this.shutdownController.signal)}[Symbol.toStringTag]="@libp2p/circuit-relay-v2-server";isStarted(){return this.started}async start(){this.started||(await this.registrar.handle(Ye,e=>{this.onHop(e).catch(t=>{this.log.error(t)})},{maxInboundStreams:this.maxInboundHopStreams,maxOutboundStreams:this.maxOutboundHopStreams,runOnTransientConnection:!0}),this.reservationStore.start(),this.started=!0)}async stop(){this.reservationStore.stop(),this.shutdownController.abort(),await this.registrar.unhandle(Ye),this.started=!1}async onHop({connection:e,stream:t}){this.log("received circuit v2 hop protocol stream from %p",e.remotePeer);let n=Ve(),s=setTimeout(()=>{n.reject("timed out")},this.hopTimeout),i=Wt(t);try{let o=await Promise.race([i.pb(J).read(),n.promise]);if(o?.type==null)throw new Error("request was invalid, could not read from stream");this.log("received",o.type),await Promise.race([this.handleHopProtocol({connection:e,stream:i,request:o}),n.promise])}catch(o){this.log.error("error while handling hop",o),await i.pb(J).write({type:J.Type.STATUS,status:z.MALFORMED_MESSAGE}),t.abort(o)}finally{clearTimeout(s)}}async handleHopProtocol({stream:e,request:t,connection:n}){switch(this.log("received hop message"),t.type){case J.Type.RESERVE:await this.handleReserve({stream:e,request:t,connection:n});break;case J.Type.CONNECT:await this.handleConnect({stream:e,request:t,connection:n});break;default:this.log.error("invalid hop request type %s via peer %p",t.type,n.remotePeer),await e.pb(J).write({type:J.Type.STATUS,status:z.UNEXPECTED_MESSAGE})}}async handleReserve({stream:e,request:t,connection:n}){let s=e.pb(J);if(this.log("hop reserve request from %p",n.remotePeer),Uu(n.remoteAddr)){this.log.error("relay reservation over circuit connection denied for peer: %p",n.remotePeer),await s.write({type:J.Type.STATUS,status:z.PERMISSION_DENIED});return}if(await this.connectionGater.denyInboundRelayReservation?.(n.remotePeer)===!0){this.log.error("reservation for %p denied by connection gater",n.remotePeer),await s.write({type:J.Type.STATUS,status:z.PERMISSION_DENIED});return}let i=this.reservationStore.reserve(n.remotePeer,n.remoteAddr);if(i.status!==z.OK){await s.write({type:J.Type.STATUS,status:i.status});return}try{if(i.expire!=null){let o=i.expire*1e3-Date.now();await this.peerStore.merge(n.remotePeer,{tags:{[xu]:{value:1,ttl:o}}})}await s.write({type:J.Type.STATUS,status:z.OK,reservation:await this.makeReservation(n.remotePeer,BigInt(i.expire??0)),limit:this.reservationStore.get(n.remotePeer)?.limit}),this.log("sent confirmation response to %s",n.remotePeer)}catch(o){this.log.error("failed to send confirmation response to %p",n.remotePeer,o),this.reservationStore.removeReservation(n.remotePeer)}}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 En.seal(new ti({peer:e,relay:this.peerId,expiration:Number(t)}),this.peerId);return{addrs:n,expire:t,voucher:s.marshal()}}async handleConnect({stream:e,request:t,connection:n}){let s=e.pb(J);if(Uu(n.remoteAddr)){this.log.error("relay reservation over circuit connection denied for peer: %p",n.remotePeer),await s.write({type:J.Type.STATUS,status:z.PERMISSION_DENIED});return}this.log("hop connect request from %p",n.remotePeer);let i;try{if(t.peer==null)throw this.log.error("no peer info in hop connect request"),new Error("no peer info in request");t.peer.addrs.forEach(Ee),i=Qr(t.peer.id)}catch(l){this.log.error("invalid hop connect request via peer %p %s",n.remotePeer,l),await s.write({type:J.Type.STATUS,status:z.MALFORMED_MESSAGE});return}if(!this.reservationStore.hasReservation(i)){this.log.error("hop connect denied for destination peer %p not having a reservation for %p with status %s",i,n.remotePeer,z.NO_RESERVATION),await s.write({type:J.Type.STATUS,status:z.NO_RESERVATION});return}if(await this.connectionGater.denyOutboundRelayedConnection?.(n.remotePeer,i)===!0){this.log.error("hop connect for %p to %p denied by connection gater",n.remotePeer,i),await s.write({type:J.Type.STATUS,status:z.PERMISSION_DENIED});return}let o=this.connectionManager.getConnections(i);if(o.length===0){this.log("hop connect denied for destination peer %p not having a connection for %p as there is no destination connection",i,n.remotePeer),await s.write({type:J.Type.STATUS,status:z.NO_RESERVATION});return}let a=this.reservationStore.get(i)?.limit,c=o[0],h=await this.stopHop({connection:c,request:{type:He.Type.CONNECT,peer:{id:n.remotePeer.toBytes(),addrs:[]},limit:a}});if(h==null){this.log.error("failed to open stream to destination peer %p",c?.remotePeer),await s.write({type:J.Type.STATUS,status:z.CONNECTION_FAILED});return}await s.write({type:J.Type.STATUS,status:z.OK,limit:a});let f=e.unwrap();this.log("connection from %p to %p established - merging streams",n.remotePeer,i),ku(f,h,this.shutdownController.signal,a,{log:this.log})}async stopHop({connection:e,request:t}){this.log("starting circuit relay v2 stop request to %s",e.remotePeer);let n=await e.newStream([lr],{maxOutboundStreams:this.maxOutboundStopStreams,runOnTransientConnection:!0}),s=Wt(n),i=s.pb(He);await i.write(t);let o;try{o=await i.read()}catch{this.log.error("error parsing stop message response from %p",e.remotePeer)}if(o==null){this.log.error("could not read response from %p",e.remotePeer),await n.close();return}if(o.status===z.OK)return this.log("stop request to %p was successful",e.remotePeer),s.unwrap();this.log("stop request failed with code %d",o.status),await n.close()}get reservations(){return this.reservationStore.reservations}};function Du(r={}){return e=>new ha(e,r)}function pa(r){let{stream:e,remoteAddr:t,logger:n}=r,s=n.forComponent("libp2p:stream:converter"),i=!1,o=!1,a=e.close.bind(e);e.close=async m=>{await a(m),l(!0)};let c=e.abort.bind(e);e.abort=m=>{c(m),l(!0)};let h=e.sink.bind(e);e.sink=async m=>{try{await h(m)}catch(u){u.type!=="aborted"&&s.error("%s error in sink",t,u)}finally{o=!0,l()}};let f={log:s,sink:e.sink,source:async function*(){try{for await(let m of e.source)m instanceof Uint8Array?yield m:yield*m}finally{i=!0,l()}}(),remoteAddr:t,timeline:{open:Date.now(),close:void 0},close:e.close,abort:e.abort};function l(m){m===!0&&(i=!0,o=!0),i&&o&&f.timeline.close==null&&(f.timeline.close=Date.now())}return f}var c0=k("dns4"),l0=k("dns6"),u0=k("dnsaddr"),hr=le(k("dns"),u0,c0,l0),si=le(k("ip4"),k("ip6")),$r=le(D(si,k("tcp")),D(hr,k("tcp"))),ii=D(si,k("udp")),f0=D(ii,k("utp")),h0=D(ii,k("quic")),d0=D(ii,k("quic-v1")),ga=le(D($r,k("ws")),D(hr,k("ws"))),ri=le(D(ga,k("p2p")),ga),ma=le(D($r,k("wss")),D(hr,k("wss")),D($r,k("tls"),k("ws")),D(hr,k("tls"),k("ws"))),ni=le(D(ma,k("p2p")),ma),ya=le(D($r,k("http")),D(si,k("http")),D(hr,k("http"))),ba=le(D($r,k("https")),D(si,k("https")),D(hr,k("https"))),Ou=D(ii,k("webrtc-direct"),k("certhash")),Vu=le(D(Ou,k("p2p")),Ou),Pu=D(d0,k("webtransport"),k("certhash"),k("certhash")),Hu=le(D(Pu,k("p2p")),Pu),Fu=le(D(ri,k("p2p-webrtc-star"),k("p2p")),D(ni,k("p2p-webrtc-star"),k("p2p")),D(ri,k("p2p-webrtc-star")),D(ni,k("p2p-webrtc-star"))),b2=le(D(ri,k("p2p-websocket-star"),k("p2p")),D(ni,k("p2p-websocket-star"),k("p2p")),D(ri,k("p2p-websocket-star")),D(ni,k("p2p-websocket-star"))),Ku=le(D(ya,k("p2p-webrtc-direct"),k("p2p")),D(ba,k("p2p-webrtc-direct"),k("p2p")),D(ya,k("p2p-webrtc-direct")),D(ba,k("p2p-webrtc-direct"))),dr=le(ga,ma,ya,ba,Fu,Ku,$r,f0,h0,hr,Vu,Hu),w2=le(D(dr,k("p2p-stardust"),k("p2p")),D(dr,k("p2p-stardust"))),Yt=le(D(dr,k("p2p")),Fu,Ku,Vu,Hu,k("p2p")),Mu=le(D(Yt,k("p2p-circuit"),Yt),D(Yt,k("p2p-circuit")),D(k("p2p-circuit"),Yt),D(dr,k("p2p-circuit")),D(k("p2p-circuit"),dr),k("p2p-circuit")),qu=()=>le(D(Mu,qu),Mu),Tt=qu(),x2=le(D(Tt,Yt,Tt),D(Yt,Tt),D(Tt,Yt),Tt,Yt);var v2=le(D(Tt,k("webrtc"),k("p2p")),D(Tt,k("webrtc")),D(dr,k("webrtc"),k("p2p")),D(dr,k("webrtc")),k("webrtc"));function zu(r){function e(t){let n;try{n=Ee(t)}catch{return!1}let s=r(n.protoNames());return s===null?!1:s===!0||s===!1?s:s.length===0}return e}function D(...r){function e(t){if(t.length<r.length)return null;let n=t;return r.some(s=>(n=typeof s=="function"?s().partialMatch(t):s.partialMatch(t),Array.isArray(n)&&(t=n),n===null)),n}return{toString:function(){return"{ "+r.join(" ")+" }"},input:r,matches:zu(e),partialMatch:e}}function le(...r){function e(n){let s=null;return r.some(i=>{let o=typeof i=="function"?i().partialMatch(n):i.partialMatch(n);return o!=null?(s=o,!0):!1}),s}return{toString:function(){return"{ "+r.join(" ")+" }"},input:r,matches:zu(e),partialMatch:e}}function k(r){let e=r;function t(s){let i;try{i=Ee(s)}catch{return!1}let o=i.protoNames();return o.length===1&&o[0]===e}function n(s){return s.length===0?null:s[0]===e?s.slice(1):null}return{toString:function(){return e},matches:t,partialMatch:n}}var oi=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}},Gr=class{size;hwm;head;tail;constructor(e={}){this.hwm=e.splitLimit??16,this.head=new oi(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 oi(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 wa=class extends Error{type;code;constructor(e,t){super(e??"The operation was aborted"),this.type="aborted",this.code=t??"ABORT_ERR"}};function $u(r={}){return g0(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 g0(r,e){e=e??{};let t=e.onEnd,n=new Gr,s,i,o,a=Ve(),c=async()=>{try{return n.isEmpty()?o?{done:!0}:await new Promise((b,g)=>{i=w=>{i=null,n.push(w);try{b(r(n))}catch(y){g(y)}return s}}):r(n)}finally{n.isEmpty()&&queueMicrotask(()=>{a.resolve(),a=Ve()})}},h=b=>i!=null?i(b):(n.push(b),s),f=b=>(n=new Gr,i!=null?i({error:b}):(n.push({error:b}),s)),l=b=>{if(o)return s;if(e?.objectMode!==!0&&b?.byteLength==null)throw new Error("objectMode was not true but tried to push non-Uint8Array value");return h({done:!1,value:b})},m=b=>o?s:(o=!0,b!=null?f(b):h({done:!0})),u=()=>(n=new Gr,m(),{done:!0}),d=b=>(m(b),{done:!0});if(s={[Symbol.asyncIterator](){return this},next:c,return:u,throw:d,push:l,end:m,get readableLength(){return n.size},onEmpty:async b=>{let g=b?.signal;if(g?.throwIfAborted(),n.isEmpty())return;let w,y;g!=null&&(w=new Promise((E,x)=>{y=()=>{x(new wa)},g.addEventListener("abort",y)}));try{await Promise.race([a.promise,w])}finally{y!=null&&g!=null&&g?.removeEventListener("abort",y)}}},t==null)return s;let p=s;return s={[Symbol.asyncIterator](){return this},next(){return p.next()},throw(b){return p.throw(b),t!=null&&(t(b),t=void 0),{done:!0}},return(){return p.return(),t!=null&&(t(),t=void 0),{done:!0}},push:l,end(b){return p.end(b),t!=null&&(t(b),t=void 0),s},get readableLength(){return p.readableLength},onEmpty:b=>p.onEmpty(b)},s}var xa=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 ai(r,e,t,n){let s=new xa(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=l=>{try{if(n?.filter?.(l)===!1)return}catch(m){a(),o(m);return}a(),i(l)},h=l=>{a(),o(l.detail)},f=()=>{a(),o(s)};t?.addEventListener("abort",f),r.addEventListener(e,c),n?.errorEvent!=null&&r.addEventListener(n.errorEvent,h)})}var ci=class{deferred;signal;where;constructor(e,t){this.signal=t,this.deferred=Ve(),this.where=e,this.onAbort=this.onAbort.bind(this),this.signal?.addEventListener("abort",this.onAbort)}onAbort(){this.deferred.reject(this.signal?.reason??new Rt)}cleanup(){this.signal?.removeEventListener("abort",this.onAbort)}};function m0(){return`${parseInt(String(Math.random()*1e9),10).toString()}${Date.now()}`}var li=class{id;fn;options;recipients;status;timeline;controller;constructor(e,t){this.id=m0(),this.status="queued",this.fn=e,this.options=t,this.recipients=[],this.timeline={created:Date.now()},this.controller=new AbortController,Ke(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 Rt),this.cleanup())}async join(e={}){let t=new ci(new Error("where").stack,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 Kr(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 ui=class extends qe{concurrency;queue;pending;sort;constructor(e={}){super(),this.concurrency=e.concurrency??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){t?.signal?.throwIfAborted();let n=new li(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 Rt)}),this.clear()}async onEmpty(e){this.size!==0&&await ai(this,"empty",e?.signal)}async onSizeLessThan(e,t){this.size<e||await ai(this,"next",t?.signal,{filter:()=>this.size<e})}async onIdle(e){this.pending===0&&this.size===0||await ai(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=$u({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 U("Queue aborted","ERR_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 jr=class extends ui{has(e){return this.find(e)!=null}find(e){return this.queue.find(t=>e.equals(t.options.peerId))}};var fi=class extends qe{peerStore;registrar;connectionManager;randomWalk;started;running;topologyId;log;discoveryController;filter;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,Ke(1/0,this.discoveryController.signal)}isStarted(){return this.started}async start(){this.topologyId=await this.registrar.register(Ye,{filter:this.filter,onConnect:e=>{this.log("discovered relay %p",e),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,Ke(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(Ye)],orders:[()=>Math.random()<.5?1:-1]});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=new jr({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}this.log.trace("wait for space in queue for %p",n.id),await Kr(t.onSizeLessThan(10),this.discoveryController.signal),this.log("adding random peer %p to dial queue (length: %d)",n.id,t.size),t.add(async()=>{let s=Ys([this.discoveryController.signal,AbortSignal.timeout(5e3)]);Ke(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)})}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()}};var va=class extends qe{connectionManager;relayStore;listeningAddrs;log;constructor(e){super(),this.log=e.logger.forComponent("libp2p:circuit-relay:transport:listener"),this.connectionManager=e.connectionManager,this.relayStore=e.relayStore,this.listeningAddrs=new kt,this.relayStore.addEventListener("relay:removed",this._onRemoveRelayPeer)}_onRemoveRelayPeer=e=>{this.#e(e.detail)};async listen(e){this.log("listen on %a",e);let t=e.decapsulate("/p2p-circuit"),n=await this.connectionManager.openConnection(t);if(!this.relayStore.hasReservation(n.remotePeer)){this.log("making reservation on peer %p",n.remotePeer),await this.relayStore.addRelay(n.remotePeer,"configured");return}let s=this.relayStore.getReservation(n.remotePeer);if(s==null)throw new U("Did not have reservation after making reservation","ERR_NO_RESERVATION");if(this.listeningAddrs.has(n.remotePeer)){this.log("already listening on relay %p",n.remotePeer);return}this.listeningAddrs.set(n.remotePeer,s.addrs.map(i=>Ee(i).encapsulate("/p2p-circuit"))),this.safeDispatchEvent("listening",{})}getAddrs(){return[...this.listeningAddrs.values()].flat()}async close(){}#e(e){let t=this.listeningAddrs.has(e);this.log("relay peer removed %p - had reservation",e,t),this.listeningAddrs.delete(e),t&&(this.log.trace("removing relay event listener for peer %p",e),this.relayStore.removeEventListener("relay:removed",this._onRemoveRelayPeer),this.safeDispatchEvent("close",{}))}};function Gu(r){return new va(r)}var x0=60*1e3*10,v0=60*1e3*5,E0=30*1e3,hi=class extends qe{peerId;connectionManager;transportManager;peerStore;events;reserveQueue;reservations;maxDiscoveredRelays;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.transportManager=e.transportManager,this.peerStore=e.peerStore,this.events=e.events,this.reservations=new kt,this.maxDiscoveredRelays=t?.discoverRelays??0,this.maxReservationQueueLength=t?.maxReservationQueueLength??100,this.reservationCompletionTimeout=t?.reservationCompletionTimeout??1e3,this.started=!1,this.relayFilter=oa(100),this.reserveQueue=new jr({concurrency:t?.reservationConcurrency??1,metricName:"libp2p_relay_reservation_queue",metrics:e.metrics}),this.events.addEventListener("peer:disconnect",n=>{this.#t(n.detail)})}isStarted(){return this.started}start(){this.started=!0}afterStart(){this.reservations.size<this.maxDiscoveredRelays&&(this.log("not enough relays %d/%d",this.reservations.size,this.maxDiscoveredRelays),this.safeDispatchEvent("relay:not-enough-relays",{}))}stop(){this.reserveQueue.clear(),this.reservations.forEach(({timeout:e})=>{clearTimeout(e)}),this.reservations.clear(),this.started=!1}async addRelay(e,t){if(this.peerId.equals(e)){this.log("not trying to use self as relay");return}if(this.reserveQueue.size>this.maxReservationQueueLength){this.log("not adding potential relay peer %p as the queue is full",e);return}if(this.reserveQueue.has(e)){this.log("potential relay peer %p is already in the reservation queue",e);return}if(this.relayFilter.has(e.toBytes())){this.log("potential relay peer %p has failed previously, not trying again",e,new Error("where").stack);return}this.log("try to reserve relay slot with %p",e),await this.reserveQueue.add(async()=>{let n=Date.now();try{let s=this.reservations.get(e);if(s!=null){if(ra(s.reservation.expire)>x0){this.log("already have reservation on relay peer %p and it expires in more than 10 minutes",e);return}clearTimeout(s.timeout),this.reservations.delete(e)}if(t==="discovered"&&[...this.reservations.values()].reduce((l,m)=>(m.type==="discovered"&&l++,l),0)>=this.maxDiscoveredRelays){this.log("already have enough discovered relays");return}let i=AbortSignal.timeout(this.reservationCompletionTimeout);Ke(1/0,i);let o=await this.connectionManager.openConnection(e,{signal:i});if(o.remoteAddr.protoNames().includes("p2p-circuit")){this.log("not creating reservation over relayed connection");return}let a=await this.#e(o,{signal:i});this.log("created reservation on relay peer %p",e);let c=ra(a.expire),h=Math.min(Math.max(c-v0,E0),Math.pow(2,31)-1),f=setTimeout(()=>{this.addRelay(e,t).catch(l=>{this.log.error("could not refresh reservation to relay %p",e,l)})},h);this.reservations.set(e,{timeout:f,reservation:a,type:t}),await this.peerStore.merge(e,{tags:{[vu]:{value:1,ttl:c}}}),await this.transportManager.listen([Ee(`/p2p/${e.toString()}/p2p-circuit`)]),this.safeDispatchEvent("relay:created-reservation",{detail:e})}catch(s){this.log.error("could not reserve slot on %p after %dms",e,Date.now()-n,s);let i=this.reservations.get(e);i!=null&&clearTimeout(i.timeout),this.reservations.delete(e),this.relayFilter.add(e.toBytes())}},{peerId:e})}hasReservation(e){return this.reservations.has(e)}getReservation(e){return this.reservations.get(e)?.reservation}reservationCount(){return this.reservations.size}async#e(e,t){t.signal?.throwIfAborted(),this.log("requesting reservation from %p",e.remotePeer);let n=await e.newStream(Ye,t),i=Wt(n).pb(J);await i.write({type:J.Type.RESERVE},t);let o;try{o=await i.read(t)}catch(c){throw n.abort(c),c}finally{n.status!=="closed"&&await n.close(t)}if(o.status===z.OK&&o.reservation!=null){let c=!1,h=e.remoteAddr.bytes;for(let f of o.reservation.addrs)if(ae(h,f)){c=!0;break}return c||o.reservation.addrs.push(h),o.reservation}let a=`reservation failed with status ${o.status??"undefined"}`;throw this.log.error(a),new Error(a)}#t(e){let t=this.reservations.get(e);t!=null&&(this.log("connection to relay %p closed, removing reservation from local store",e),clearTimeout(t.timeout),this.reservations.delete(e),this.safeDispatchEvent("relay:removed",{detail:e}),this.reservations.size<this.maxDiscoveredRelays&&(this.log("not enough relays %d/%d",this.reservations.size,this.maxDiscoveredRelays),this.safeDispatchEvent("relay:not-enough-relays",{})))}};var A0=r=>{if(r.peer==null)return!1;try{r.peer.addrs.forEach(Ee)}catch{return!1}return!0},Ea={maxInboundStopStreams:An,maxOutboundStopStreams:An,stopTimeout:3e4},di=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??Ea.maxInboundStopStreams,this.maxOutboundStopStreams=t.maxOutboundStopStreams??Ea.maxOutboundStopStreams,this.stopTimeout=t.stopTimeout??Ea.stopTimeout;let n=t.discoverRelays??0;n>0&&(this.discovery=new fi(e,{filter:t.discoveryFilter??fa(Bu,_u)}),this.discovery.addEventListener("relay:discover",s=>{this.reservationStore.addRelay(s.detail,"discovered").catch(i=>{this.log.error("could not add discovered relay %p",s.detail,i)})})),this.reservationStore=new hi(e,t),this.reservationStore.addEventListener("relay:not-enough-relays",()=>{this.discovery?.startDiscovery()}),this.reservationStore.addEventListener("relay:created-reservation",()=>{this.reservationStore.reservationCount()>=n&&this.discovery?.stopDiscovery()}),this.started=!1}[Symbol.toStringTag]="@libp2p/circuit-relay-v2-transport";[Ma]=["@libp2p/transport","@libp2p/circuit-relay-v2-transport"];get[Va](){return this.discovery!=null?["@libp2p/identify"]:[]}[Ua]=!0;isStarted(){return this.started}async start(){await this.registrar.handle(lr,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,runOnTransientConnection:!0}),await Oa(this.discovery,this.reservationStore),this.started=!0}async stop(){await Pa(this.discovery,this.reservationStore),await this.registrar.unhandle(lr),this.started=!1}async dial(e,t={}){if(e.protoCodes().filter(d=>d===290).length!==1){let d="Invalid circuit relay address";throw this.log.error(d,e),new U(d,ea)}let n=e.toString().split("/p2p-circuit"),s=Ee(n[0]),i=Ee(n[n.length-1]),o=s.getPeerId(),a=i.getPeerId();if(o==null||a==null){let d=`Circuit relay dial to ${e.toString()} failed as address did not have peer ids`;throw this.log.error(d),new U(d,ea)}let c=Ut(o),h=Ut(a),f=!1,m=this.connectionManager.getConnections(c)[0];m==null&&(await this.peerStore.merge(c,{multiaddrs:[s]}),m=await this.connectionManager.openConnection(c,t),f=!0);let u;try{return u=await m.newStream(Ye),await this.connectV2({stream:u,connection:m,destinationPeer:h,destinationAddr:i,relayAddr:s,ma:e,disconnectOnFailure:f})}catch(d){throw this.log.error("circuit relay dial to destination %p via relay %p failed",h,c,d),u?.abort(d),f&&await m.close(),d}}async connectV2({stream:e,connection:t,destinationPeer:n,destinationAddr:s,relayAddr:i,ma:o,disconnectOnFailure:a}){try{let c=Wt(e),h=c.pb(J);await h.write({type:J.Type.CONNECT,peer:{id:n.toBytes(),addrs:[Ee(s).bytes]}});let f=await h.read();if(f.status!==z.OK)throw new U(`failed to connect via relay with status ${f?.status?.toString()??"undefined"}`,Su);let l=pa({stream:c.unwrap(),remoteAddr:o,localAddr:i.encapsulate(`/p2p-circuit/p2p/${this.peerId.toString()}`),logger:this.logger});return this.log("new outbound relayed connection %a",l.remoteAddr),await this.upgrader.upgradeOutbound(l,{transient:f.limit!=null})}catch(c){throw this.log.error(`Circuit relay dial to destination ${n.toString()} via relay ${t.remotePeer.toString()} failed`,c),a&&await t.close(),c}}createListener(e){return Gu({connectionManager:this.connectionManager,relayStore:this.reservationStore,logger:this.logger})}listenFilter(e){return e=Array.isArray(e)?e:[e],e.filter(t=>Tt.matches(t))}dialFilter(e){return this.listenFilter(e)}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(f){this.log.error("failed to listen on a relay peer we were dialed via but did not have a reservation on",f)}let n=AbortSignal.timeout(this.stopTimeout),s=Wt(t).pb(He),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:He.Type.STATUS,status:z.MALFORMED_MESSAGE},{signal:n}),await t.close();return}if(i.type!==He.Type.CONNECT){this.log.error("invalid stop connect request via peer %p",e.remotePeer),await s.write({type:He.Type.STATUS,status:z.UNEXPECTED_MESSAGE},{signal:n}),await t.close();return}if(!A0(i)){this.log.error("invalid stop connect request via peer %p",e.remotePeer),await s.write({type:He.Type.STATUS,status:z.MALFORMED_MESSAGE},{signal:n}),await t.close();return}let o=Qr(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:He.Type.STATUS,status:z.PERMISSION_DENIED},{signal:n}),await t.close();return}this.log.trace("sending success response to %p",e.remotePeer),await s.write({type:He.Type.STATUS,status:z.OK},{signal:n});let a=e.remoteAddr.encapsulate(`/p2p-circuit/p2p/${o.toString()}`),c=this.addressManager.getAddresses()[0],h=pa({stream:s.unwrap().unwrap(),remoteAddr:a,localAddr:c,logger:this.logger});this.log("new inbound relayed connection %a",h.remoteAddr),await this.upgrader.upgradeInbound(h,{transient:i.limit!=null}),this.log("%s connection %a upgraded","inbound",h.remoteAddr)}};function ju(r={}){return e=>new di(e,r)}return cf(S0);})();
|
8
8
|
/*! Bundled license information:
|
9
9
|
|
10
10
|
pvtsutils/build/index.js:
|