@libp2p/daemon-client 10.0.10 → 10.0.11

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
package/dist/index.min.js CHANGED
@@ -10,8 +10,8 @@ ${e}${n.split(`
10
10
  `).join(`
11
11
  ${e}`)}`:n!=null?`${n.split(`
12
12
  `).join(`
13
- ${e}`)}`:t!=null?`${t}`:`${r.toString()}`}function Dl(r){return r instanceof AggregateError||r?.name==="AggregateError"&&Array.isArray(r.errors)}function na(r,e=""){if(Dl(r)){let t=ta(r,e);return r.errors.length>0?(e=`${e} `,t+=`${r.errors.map(n=>`
14
- ${e}${na(n,`${e}`)}`).join(`
13
+ ${e}`)}`:t!=null?`${t}`:`${r.toString()}`}function Dl(r){return r instanceof AggregateError||r?.name==="AggregateError"&&Array.isArray(r.errors)}function na(r,e=""){if(Dl(r)){let t=ta(r,e);return r.errors.length>0?(e=`${e} `,t+=`
14
+ ${e}${r.errors.map(n=>`${na(n,`${e}`)}`).join(`
15
15
  ${e}`)}`):t+=`
16
16
  ${e}[Error list was empty]`,t.trim()}return ta(r,e)}ve.formatters.e=r=>r==null?"undefined":na(r);function Ll(r){let e=()=>{};return e.enabled=!1,e.color="",e.diff=0,e.log=()=>{},e.namespace=r,e.destroy=()=>!0,e.extend=()=>e,e}function oa(r){return{forComponent(e){return Kt(e,r)}}}function Kt(r,e){let t=Ll(`${r}:trace`);return ve.enabled(`${r}:trace`)&&ve.names.map(n=>n.toString()).find(n=>n.includes(":trace"))!=null&&(t=ve(`${r}:trace`,e)),Object.assign(ve(r,e),{error:ve(`${r}:error`,e),trace:t,newScope:n=>Kt(`${r}:${n}`,e)})}function ra(r){if(r!=null&&(r=r.trim(),r.length!==0))return r}function Te(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 sa=ie("node:buffer");function ze(r,e){return ft(sa.Buffer.concat(r,e))}var aa=Symbol.for("@achingbrain/uint8arraylist");function ia(r,e){if(e==null||e<0)throw new RangeError("index is out of bounds");let t=0;for(let n of r){let o=t+n.byteLength;if(e<o)return{buf:n,index:e-t};t=o}throw new RangeError("index is out of bounds")}function an(r){return!!r?.[aa]}var te=class r{bufs;length;[aa]=!0;constructor(...e){this.bufs=[],this.length=0,e.length>0&&this.appendAll(e)}*[Symbol.iterator](){yield*this.bufs}get byteLength(){return this.length}append(...e){this.appendAll(e)}appendAll(e){let t=0;for(let n of e)if(n instanceof Uint8Array)t+=n.byteLength,this.bufs.push(n);else if(an(n))t+=n.byteLength,this.bufs.push(...n.bufs);else throw new Error("Could not append value, must be an Uint8Array or a Uint8ArrayList");this.length+=t}prepend(...e){this.prependAll(e)}prependAll(e){let t=0;for(let n of e.reverse())if(n instanceof Uint8Array)t+=n.byteLength,this.bufs.unshift(n);else if(an(n))t+=n.byteLength,this.bufs.unshift(...n.bufs);else throw new Error("Could not prepend value, must be an Uint8Array or a Uint8ArrayList");this.length+=t}get(e){let t=ia(this.bufs,e);return t.buf[t.index]}set(e,t){let n=ia(this.bufs,e);n.buf[n.index]=t}write(e,t=0){if(e instanceof Uint8Array)for(let n=0;n<e.length;n++)this.set(t+n,e[n]);else if(an(e))for(let n=0;n<e.length;n++)this.set(t+n,e.get(n));else throw new Error("Could not write value, must be an Uint8Array or a Uint8ArrayList")}consume(e){if(e=Math.trunc(e),!(Number.isNaN(e)||e<=0)){if(e===this.byteLength){this.bufs=[],this.length=0;return}for(;this.bufs.length>0;)if(e>=this.bufs[0].byteLength)e-=this.bufs[0].byteLength,this.length-=this.bufs[0].byteLength,this.bufs.shift();else{this.bufs[0]=this.bufs[0].subarray(e),this.length-=e;break}}}slice(e,t){let{bufs:n,length:o}=this._subList(e,t);return ze(n,o)}subarray(e,t){let{bufs:n,length:o}=this._subList(e,t);return n.length===1?n[0]:ze(n,o)}sublist(e,t){let{bufs:n,length:o}=this._subList(e,t),s=new r;return s.length=o,s.bufs=[...n],s}_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=[],o=0;for(let s=0;s<this.bufs.length;s++){let i=this.bufs[s],a=o,c=a+i.byteLength;if(o=c,e>=c)continue;let f=e>=a&&e<c,u=t>a&&t<=c;if(f&&u){if(e===a&&t===c){n.push(i);break}let l=e-a;n.push(i.subarray(l,l+(t-e)));break}if(f){if(e===0){n.push(i);continue}n.push(i.subarray(e-a));continue}if(u){if(t===c){n.push(i);break}n.push(i.subarray(0,t-a));break}n.push(i)}return{bufs:n,length:t-e}}indexOf(e,t=0){if(!an(e)&&!(e instanceof Uint8Array))throw new TypeError('The "value" argument must be a Uint8ArrayList or Uint8Array');let n=e instanceof Uint8Array?e:e.subarray();if(t=Number(t??0),isNaN(t)&&(t=0),t<0&&(t=this.length+t),t<0&&(t=0),e.length===0)return t>this.length?this.length:t;let o=n.byteLength;if(o===0)throw new TypeError("search must be at least 1 byte long");let s=256,i=new Int32Array(s);for(let l=0;l<s;l++)i[l]=-1;for(let l=0;l<o;l++)i[n[l]]=l;let a=i,c=this.byteLength-n.byteLength,f=n.byteLength-1,u;for(let l=t;l<=c;l+=u){u=0;for(let p=f;p>=0;p--){let d=this.get(l+p);if(n[p]!==d){u=Math.max(1,p-a[d]);break}}if(u===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=Oe(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 o=Ye(2);new DataView(o.buffer,o.byteOffset,o.byteLength).setInt16(0,t,n),this.write(o,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 o=Ye(4);new DataView(o.buffer,o.byteOffset,o.byteLength).setInt32(0,t,n),this.write(o,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 o=Ye(8);new DataView(o.buffer,o.byteOffset,o.byteLength).setBigInt64(0,t,n),this.write(o,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=Oe(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 o=Ye(2);new DataView(o.buffer,o.byteOffset,o.byteLength).setUint16(0,t,n),this.write(o,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 o=Ye(4);new DataView(o.buffer,o.byteOffset,o.byteLength).setUint32(0,t,n),this.write(o,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 o=Ye(8);new DataView(o.buffer,o.byteOffset,o.byteLength).setBigUint64(0,t,n),this.write(o,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 o=Ye(4);new DataView(o.buffer,o.byteOffset,o.byteLength).setFloat32(0,t,n),this.write(o,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 o=Ye(8);new DataView(o.buffer,o.byteOffset,o.byteLength).setFloat64(0,t,n),this.write(o,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(!Te(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((o,s)=>o+s.byteLength,0)),n.length=t,n}};var ca=ie("node:buffer");function ne(r,e="utf8"){let t=Br[e];if(t==null)throw new Error(`Unsupported encoding "${e}"`);return e==="utf8"||e==="utf-8"?ca.Buffer.from(r.buffer,r.byteOffset,r.byteLength).toString("utf8"):t.encoder.encode(r).substring(1)}var Bl=parseInt("11111",2),Qo=parseInt("10000000",2),Ol=parseInt("01111111",2),ua={0:fr,1:fr,2:_l,3:Rl,4:kl,5:Nl,6:Pl,16:fr,22:fr,48:fr};function jo(r,e={offset:0}){let t=r[e.offset]&Bl;if(e.offset++,ua[t]!=null)return ua[t](r,e);throw new Error("No decoder for tag "+t)}function dr(r,e){let t=0;if((r[e.offset]&Qo)===Qo){let n=r[e.offset]&Ol,o="0x";e.offset++;for(let s=0;s<n;s++,e.offset++)o+=r[e.offset].toString(16).padStart(2,"0");t=parseInt(o,16)}else t=r[e.offset],e.offset++;return t}function fr(r,e){dr(r,e);let t=[];for(;!(e.offset>=r.byteLength);){let n=jo(r,e);if(n===null)break;t.push(n)}return t}function _l(r,e){let t=dr(r,e),n=e.offset,o=e.offset+t,s=[];for(let i=n;i<o;i++)i===n&&r[i]===0||s.push(r[i]);return e.offset+=t,Uint8Array.from(s)}function Pl(r,e){let t=dr(r,e),n=e.offset+t,o=r[e.offset];e.offset++;let s=0,i=0;o<40?(s=0,i=o):o<80?(s=1,i=o-40):(s=2,i=o-80);let a=`${s}.${i}`,c=[];for(;e.offset<n;){let f=r[e.offset];if(e.offset++,c.push(f&127),f<128){c.reverse();let u=0;for(let l=0;l<c.length;l++)u+=c[l]<<l*7;a+=`.${u}`,c=[]}}return a}function Nl(r,e){return e.offset++,null}function Rl(r,e){let t=dr(r,e),n=r[e.offset];e.offset++;let o=r.subarray(e.offset,e.offset+t-1);if(e.offset+=t,n!==0)throw new Error("Unused bits in bit string is unimplemented");return o}function kl(r,e){let t=dr(r,e),n=r.subarray(e.offset,e.offset+t);return e.offset+=t,n}function Ul(r){let e=r.toString(16);e.length%2===1&&(e="0"+e);let t=new te;for(let n=0;n<e.length;n+=2)t.append(Uint8Array.from([parseInt(`${e[n]}${e[n+1]}`,16)]));return t}function Jo(r){if(r.byteLength<128)return Uint8Array.from([r.byteLength]);let e=Ul(r.byteLength);return new te(Uint8Array.from([e.byteLength|Qo]),e)}function la(r){let e=new te,t=128;return(r.subarray()[0]&t)===t&&e.append(Uint8Array.from([0])),e.append(r),new te(Uint8Array.from([2]),Jo(e),e)}function fa(r){let e=Uint8Array.from([0]),t=new te(e,r);return new te(Uint8Array.from([3]),Jo(t),t)}function cn(r,e=48){let t=new te;for(let n of r)t.append(n);return new te(Uint8Array.from([e]),Jo(t),t)}async function da(r,e,t,n){let o=await crypto.subtle.importKey("jwk",r,{name:"ECDSA",namedCurve:r.crv??"P-256"},!1,["verify"]);n?.signal?.throwIfAborted();let s=await crypto.subtle.verify({name:"ECDSA",hash:{name:"SHA-256"}},o,e,t.subarray());return n?.signal?.throwIfAborted(),s}var Ml=Uint8Array.from([6,8,42,134,72,206,61,3,1,7]),Kl=Uint8Array.from([6,5,43,129,4,0,34]),$l=Uint8Array.from([6,5,43,129,4,0,35]),Hl={ext:!0,kty:"EC",crv:"P-256"},Vl={ext:!0,kty:"EC",crv:"P-384"},Fl={ext:!0,kty:"EC",crv:"P-521"},es=32,ts=48,rs=66;function ha(r){let e=jo(r);return pa(e)}function pa(r){let e=r[1][1][0],t=1,n,o;if(e.byteLength===es*2+1)return n=ne(e.subarray(t,t+es),"base64url"),o=ne(e.subarray(t+es),"base64url"),new $t({...Hl,key_ops:["verify"],x:n,y:o});if(e.byteLength===ts*2+1)return n=ne(e.subarray(t,t+ts),"base64url"),o=ne(e.subarray(t+ts),"base64url"),new $t({...Vl,key_ops:["verify"],x:n,y:o});if(e.byteLength===rs*2+1)return n=ne(e.subarray(t,t+rs),"base64url"),o=ne(e.subarray(t+rs),"base64url"),new $t({...Fl,key_ops:["verify"],x:n,y:o});throw new D(`coordinates were wrong length, got ${e.byteLength}, expected 65, 97 or 133`)}function ma(r){return cn([la(Uint8Array.from([1])),cn([Gl(r.crv)],160),cn([fa(new te(Uint8Array.from([4]),Ee(r.x??"","base64url"),Ee(r.y??"","base64url")))],161)]).subarray()}function Gl(r){if(r==="P-256")return Ml;if(r==="P-384")return Kl;if(r==="P-521")return $l;throw new D(`Invalid curve ${r}`)}var $t=class{type="ECDSA";jwk;_raw;constructor(e){this.jwk=e}get raw(){return this._raw==null&&(this._raw=ma(this.jwk)),this._raw}toMultihash(){return Ue.digest(Ht(this))}toCID(){return ae.createV1(114,this.toMultihash())}toString(){return re.encode(this.toMultihash().bytes).substring(1)}equals(e){return e==null||!(e.raw instanceof Uint8Array)?!1:Te(this.raw,e.raw)}async verify(e,t,n){return da(this.jwk,t,e,n)}};var un=Ae(ie("crypto"),1);var Em=un.default.generateKeyPairSync,hr=32;var zl=64;function ya(r,e,t){if(r.byteLength!==hr)throw new TypeError('"key" must be 32 bytes in length.');if(!(r instanceof Uint8Array))throw new TypeError('"key" must be a node.js Buffer, or Uint8Array.');if(e.byteLength!==zl)throw new TypeError('"sig" must be 64 bytes in length.');if(!(e instanceof Uint8Array))throw new TypeError('"sig" must be a node.js Buffer, or Uint8Array.');let n=un.default.createPublicKey({format:"jwk",key:{crv:"Ed25519",x:ne(r,"base64url"),kty:"OKP"}});return un.default.verify(null,t instanceof Uint8Array?t:t.subarray(),n,e)}function ga(r){return r==null?!1:typeof r.then=="function"&&typeof r.catch=="function"&&typeof r.finally=="function"}var ln=class{type="Ed25519";raw;constructor(e){this.raw=ns(e,hr)}toMultihash(){return Ue.digest(Ht(this))}toCID(){return ae.createV1(114,this.toMultihash())}toString(){return re.encode(this.toMultihash().bytes).substring(1)}equals(e){return e==null||!(e.raw instanceof Uint8Array)?!1:Te(this.raw,e.raw)}verify(e,t,n){n?.signal?.throwIfAborted();let o=ya(this.raw,t,e);return ga(o)?o.then(s=>(n?.signal?.throwIfAborted(),s)):o}};function wa(r){return r=ns(r,hr),new ln(r)}function ns(r,e){if(r=Uint8Array.from(r??[]),r.length!==e)throw new D(`Key must be a Uint8Array of length ${e}, got ${r.length}`);return r}var Ce;(function(r){r.RSA="RSA",r.Ed25519="Ed25519",r.secp256k1="secp256k1",r.ECDSA="ECDSA"})(Ce||(Ce={}));var os;(function(r){r[r.RSA=0]="RSA",r[r.Ed25519=1]="Ed25519",r[r.secp256k1=2]="secp256k1",r[r.ECDSA=3]="ECDSA"})(os||(os={}));(function(r){r.codec=()=>Me(os)})(Ce||(Ce={}));var pr;(function(r){let e;r.codec=()=>(e==null&&(e=Q((t,n,o={})=>{o.lengthDelimited!==!1&&n.fork(),t.Type!=null&&(n.uint32(8),Ce.codec().encode(t.Type,n)),t.Data!=null&&(n.uint32(18),n.bytes(t.Data)),o.lengthDelimited!==!1&&n.ldelim()},(t,n,o={})=>{let s={},i=n==null?t.len:t.pos+n;for(;t.pos<i;){let a=t.uint32();switch(a>>>3){case 1:{s.Type=Ce.codec().decode(t);break}case 2:{s.Data=t.bytes();break}default:{t.skipType(a&7);break}}}return s})),e),r.encode=t=>X(t,r.codec()),r.decode=(t,n)=>Z(t,r.codec(),n)})(pr||(pr={}));var ss;(function(r){let e;r.codec=()=>(e==null&&(e=Q((t,n,o={})=>{o.lengthDelimited!==!1&&n.fork(),t.Type!=null&&(n.uint32(8),Ce.codec().encode(t.Type,n)),t.Data!=null&&(n.uint32(18),n.bytes(t.Data)),o.lengthDelimited!==!1&&n.ldelim()},(t,n,o={})=>{let s={},i=n==null?t.len:t.pos+n;for(;t.pos<i;){let a=t.uint32();switch(a>>>3){case 1:{s.Type=Ce.codec().decode(t);break}case 2:{s.Data=t.bytes();break}default:{t.skipType(a&7);break}}}return s})),e),r.encode=t=>X(t,r.codec()),r.decode=(t,n)=>Z(t,r.codec(),n)})(ss||(ss={}));function mr(r){return r instanceof Uint8Array||ArrayBuffer.isView(r)&&r.constructor.name==="Uint8Array"}function We(r,e=""){if(!Number.isSafeInteger(r)||r<0){let t=e&&`"${e}" `;throw new Error(`${t}expected integer >= 0, got ${r}`)}}function V(r,e,t=""){let n=mr(r),o=r?.length,s=e!==void 0;if(!n||s&&o!==e){let i=t&&`"${t}" `,a=s?` of length ${e}`:"",c=n?`length=${o}`:`type=${typeof r}`;throw new Error(i+"expected Uint8Array"+a+", got "+c)}return r}function fn(r){if(typeof r!="function"||typeof r.create!="function")throw new Error("Hash must wrapped by utils.createHasher");We(r.outputLen),We(r.blockLen)}function Vt(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 Ea(r,e){V(r,void 0,"digestInto() output");let t=e.outputLen;if(r.length<t)throw new Error('"digestInto() output" expected to be of length >='+t)}function mt(...r){for(let e=0;e<r.length;e++)r[e].fill(0)}function dn(r){return new DataView(r.buffer,r.byteOffset,r.byteLength)}function $e(r,e){return r<<32-e|r>>>e}var va=typeof Uint8Array.from([]).toHex=="function"&&typeof Uint8Array.fromHex=="function",Yl=Array.from({length:256},(r,e)=>e.toString(16).padStart(2,"0"));function yt(r){if(V(r),va)return r.toHex();let e="";for(let t=0;t<r.length;t++)e+=Yl[r[t]];return e}var Qe={_0:48,_9:57,A:65,F:70,a:97,f:102};function xa(r){if(r>=Qe._0&&r<=Qe._9)return r-Qe._0;if(r>=Qe.A&&r<=Qe.F)return r-(Qe.A-10);if(r>=Qe.a&&r<=Qe.f)return r-(Qe.a-10)}function bt(r){if(typeof r!="string")throw new Error("hex string expected, got "+typeof r);if(va)return Uint8Array.fromHex(r);let e=r.length,t=e/2;if(e%2)throw new Error("hex string expected, got unpadded hex of length "+e);let n=new Uint8Array(t);for(let o=0,s=0;o<t;o++,s+=2){let i=xa(r.charCodeAt(s)),a=xa(r.charCodeAt(s+1));if(i===void 0||a===void 0){let c=r[s]+r[s+1];throw new Error('hex string expected, got non-hex character "'+c+'" at index '+s)}n[o]=i*16+a}return n}function He(...r){let e=0;for(let n=0;n<r.length;n++){let o=r[n];V(o),e+=o.length}let t=new Uint8Array(e);for(let n=0,o=0;n<r.length;n++){let s=r[n];t.set(s,o),o+=s.length}return t}function Sa(r,e={}){let t=(o,s)=>r(s).update(o).digest(),n=r(void 0);return t.outputLen=n.outputLen,t.blockLen=n.blockLen,t.create=o=>r(o),Object.assign(t,e),Object.freeze(t)}function hn(r=32){let e=typeof globalThis=="object"?globalThis.crypto:null;if(typeof e?.getRandomValues!="function")throw new Error("crypto.getRandomValues must be defined");return e.getRandomValues(new Uint8Array(r))}var Aa=r=>({oid:Uint8Array.from([6,9,96,134,72,1,101,3,4,2,r])});function Ia(r,e,t){return r&e^~r&t}function Ta(r,e,t){return r&e^r&t^e&t}var pn=class{blockLen;outputLen;padOffset;isLE;buffer;view;finished=!1;length=0;pos=0;destroyed=!1;constructor(e,t,n,o){this.blockLen=e,this.outputLen=t,this.padOffset=n,this.isLE=o,this.buffer=new Uint8Array(e),this.view=dn(this.buffer)}update(e){Vt(this),V(e);let{view:t,buffer:n,blockLen:o}=this,s=e.length;for(let i=0;i<s;){let a=Math.min(o-this.pos,s-i);if(a===o){let c=dn(e);for(;o<=s-i;i+=o)this.process(c,i);continue}n.set(e.subarray(i,i+a),this.pos),this.pos+=a,i+=a,this.pos===o&&(this.process(t,0),this.pos=0)}return this.length+=e.length,this.roundClean(),this}digestInto(e){Vt(this),Ea(e,this),this.finished=!0;let{buffer:t,view:n,blockLen:o,isLE:s}=this,{pos:i}=this;t[i++]=128,mt(this.buffer.subarray(i)),this.padOffset>o-i&&(this.process(n,0),i=0);for(let l=i;l<o;l++)t[l]=0;n.setBigUint64(o-8,BigInt(this.length*8),s),this.process(n,0);let a=dn(e),c=this.outputLen;if(c%4)throw new Error("_sha2: outputLen must be aligned to 32bit");let f=c/4,u=this.get();if(f>u.length)throw new Error("_sha2: outputLen bigger than state");for(let l=0;l<f;l++)a.setUint32(4*l,u[l],s)}digest(){let{buffer:e,outputLen:t}=this;this.digestInto(e);let n=e.slice(0,t);return this.destroy(),n}_cloneInto(e){e||=new this.constructor,e.set(...this.get());let{blockLen:t,buffer:n,length:o,finished:s,destroyed:i,pos:a}=this;return e.destroyed=i,e.finished=s,e.length=o,e.pos=a,o%t&&e.buffer.set(n),e}clone(){return this._cloneInto()}},je=Uint32Array.from([1779033703,3144134277,1013904242,2773480762,1359893119,2600822924,528734635,1541459225]);var Zl=Uint32Array.from([1116352408,1899447441,3049323471,3921009573,961987163,1508970993,2453635748,2870763221,3624381080,310598401,607225278,1426881987,1925078388,2162078206,2614888103,3248222580,3835390401,4022224774,264347078,604807628,770255983,1249150122,1555081692,1996064986,2554220882,2821834349,2952996808,3210313671,3336571891,3584528711,113926993,338241895,666307205,773529912,1294757372,1396182291,1695183700,1986661051,2177026350,2456956037,2730485921,2820302411,3259730800,3345764771,3516065817,3600352804,4094571909,275423344,430227734,506948616,659060556,883997877,958139571,1322822218,1537002063,1747873779,1955562222,2024104815,2227730452,2361852424,2428436474,2756734187,3204031479,3329325298]),at=new Uint32Array(64),is=class extends pn{constructor(e){super(64,e,8,!1)}get(){let{A:e,B:t,C:n,D:o,E:s,F:i,G:a,H:c}=this;return[e,t,n,o,s,i,a,c]}set(e,t,n,o,s,i,a,c){this.A=e|0,this.B=t|0,this.C=n|0,this.D=o|0,this.E=s|0,this.F=i|0,this.G=a|0,this.H=c|0}process(e,t){for(let l=0;l<16;l++,t+=4)at[l]=e.getUint32(t,!1);for(let l=16;l<64;l++){let p=at[l-15],d=at[l-2],g=$e(p,7)^$e(p,18)^p>>>3,E=$e(d,17)^$e(d,19)^d>>>10;at[l]=E+at[l-7]+g+at[l-16]|0}let{A:n,B:o,C:s,D:i,E:a,F:c,G:f,H:u}=this;for(let l=0;l<64;l++){let p=$e(a,6)^$e(a,11)^$e(a,25),d=u+p+Ia(a,c,f)+Zl[l]+at[l]|0,E=($e(n,2)^$e(n,13)^$e(n,22))+Ta(n,o,s)|0;u=f,f=c,c=a,a=i+d|0,i=s,s=o,o=n,n=d+E|0}n=n+this.A|0,o=o+this.B|0,s=s+this.C|0,i=i+this.D|0,a=a+this.E|0,c=c+this.F|0,f=f+this.G|0,u=u+this.H|0,this.set(n,o,s,i,a,c,f,u)}roundClean(){mt(at)}destroy(){this.set(0,0,0,0,0,0,0,0),mt(this.buffer)}},as=class extends is{A=je[0]|0;B=je[1]|0;C=je[2]|0;D=je[3]|0;E=je[4]|0;F=je[5]|0;G=je[6]|0;H=je[7]|0;constructor(){super(32)}};var Ca=Sa(()=>new as,Aa(1));var nc=Ae(ie("node:crypto"),1);var us=BigInt(0),cs=BigInt(1);function yr(r,e=""){if(typeof r!="boolean"){let t=e&&`"${e}" `;throw new Error(t+"expected boolean, got type="+typeof r)}return r}function Da(r){if(typeof r=="bigint"){if(!mn(r))throw new Error("positive bigint expected, got "+r)}else We(r);return r}function br(r){let e=Da(r).toString(16);return e.length&1?"0"+e:e}function La(r){if(typeof r!="string")throw new Error("hex string expected, got "+typeof r);return r===""?us:BigInt("0x"+r)}function Ft(r){return La(yt(r))}function ls(r){return La(yt(Xl(V(r)).reverse()))}function yn(r,e){We(e),r=Da(r);let t=bt(r.toString(16).padStart(e*2,"0"));if(t.length!==e)throw new Error("number too large");return t}function fs(r,e){return yn(r,e).reverse()}function Xl(r){return Uint8Array.from(r)}var mn=r=>typeof r=="bigint"&&us<=r;function Ql(r,e,t){return mn(r)&&mn(e)&&mn(t)&&e<=r&&r<t}function Ba(r,e,t,n){if(!Ql(e,t,n))throw new Error("expected valid "+r+": "+t+" <= n < "+n+", got "+e)}function ds(r){let e;for(e=0;r>us;r>>=cs,e+=1);return e}var gr=r=>(cs<<BigInt(r))-cs;function Oa(r,e,t){if(We(r,"hashLen"),We(e,"qByteLen"),typeof t!="function")throw new Error("hmacFn must be a function");let n=y=>new Uint8Array(y),o=Uint8Array.of(),s=Uint8Array.of(0),i=Uint8Array.of(1),a=1e3,c=n(r),f=n(r),u=0,l=()=>{c.fill(1),f.fill(0),u=0},p=(...y)=>t(f,He(c,...y)),d=(y=o)=>{f=p(s,y),c=p(),y.length!==0&&(f=p(i,y),c=p())},g=()=>{if(u++>=a)throw new Error("drbg: tried max amount of iterations");let y=0,x=[];for(;y<e;){c=p();let _=c.slice();x.push(_),y+=c.length}return He(...x)};return(y,x)=>{l(),d(y);let _;for(;!(_=x(g()));)d();return l(),_}}function wr(r,e={},t={}){if(!r||typeof r!="object")throw new Error("expected valid options object");function n(s,i,a){let c=r[s];if(a&&c===void 0)return;let f=typeof c;if(f!==i||c===null)throw new Error(`param "${s}" is invalid: expected ${i}, got ${f}`)}let o=(s,i)=>Object.entries(s).forEach(([a,c])=>n(a,c,i));o(e,!1),o(t,!0)}function hs(r){let e=new WeakMap;return(t,...n)=>{let o=e.get(t);if(o!==void 0)return o;let s=r(t,...n);return e.set(t,s),s}}var we=BigInt(0),be=BigInt(1),gt=BigInt(2),Na=BigInt(3),Ra=BigInt(4),ka=BigInt(5),jl=BigInt(7),Ua=BigInt(8),Jl=BigInt(9),Ma=BigInt(16);function Ve(r,e){let t=r%e;return t>=we?t:e+t}function De(r,e,t){let n=r;for(;e-- >we;)n*=n,n%=t;return n}function _a(r,e){if(r===we)throw new Error("invert: expected non-zero number");if(e<=we)throw new Error("invert: expected positive modulus, got "+e);let t=Ve(r,e),n=e,o=we,s=be,i=be,a=we;for(;t!==we;){let f=n/t,u=n%t,l=o-i*f,p=s-a*f;n=t,t=u,o=i,s=a,i=l,a=p}if(n!==be)throw new Error("invert: does not exist");return Ve(o,e)}function ms(r,e,t){if(!r.eql(r.sqr(e),t))throw new Error("Cannot find square root")}function Ka(r,e){let t=(r.ORDER+be)/Ra,n=r.pow(e,t);return ms(r,n,e),n}function ef(r,e){let t=(r.ORDER-ka)/Ua,n=r.mul(e,gt),o=r.pow(n,t),s=r.mul(e,o),i=r.mul(r.mul(s,gt),o),a=r.mul(s,r.sub(i,r.ONE));return ms(r,a,e),a}function tf(r){let e=Gt(r),t=$a(r),n=t(e,e.neg(e.ONE)),o=t(e,n),s=t(e,e.neg(n)),i=(r+jl)/Ma;return(a,c)=>{let f=a.pow(c,i),u=a.mul(f,n),l=a.mul(f,o),p=a.mul(f,s),d=a.eql(a.sqr(u),c),g=a.eql(a.sqr(l),c);f=a.cmov(f,u,d),u=a.cmov(p,l,g);let E=a.eql(a.sqr(u),c),y=a.cmov(f,u,E);return ms(a,y,c),y}}function $a(r){if(r<Na)throw new Error("sqrt is not defined for small field");let e=r-be,t=0;for(;e%gt===we;)e/=gt,t++;let n=gt,o=Gt(r);for(;Pa(o,n)===1;)if(n++>1e3)throw new Error("Cannot find square root: probably non-prime P");if(t===1)return Ka;let s=o.pow(n,e),i=(e+be)/gt;return function(c,f){if(c.is0(f))return f;if(Pa(c,f)!==1)throw new Error("Cannot find square root");let u=t,l=c.mul(c.ONE,s),p=c.pow(f,e),d=c.pow(f,i);for(;!c.eql(p,c.ONE);){if(c.is0(p))return c.ZERO;let g=1,E=c.sqr(p);for(;!c.eql(E,c.ONE);)if(g++,E=c.sqr(E),g===u)throw new Error("Cannot find square root");let y=be<<BigInt(u-g-1),x=c.pow(l,y);u=g,l=c.sqr(x),p=c.mul(p,l),d=c.mul(d,x)}return d}}function rf(r){return r%Ra===Na?Ka:r%Ua===ka?ef:r%Ma===Jl?tf(r):$a(r)}var nf=["create","isValid","is0","neg","inv","sqrt","sqr","eql","add","sub","mul","pow","div","addN","subN","mulN","sqrN"];function ys(r){let e={ORDER:"bigint",BYTES:"number",BITS:"number"},t=nf.reduce((n,o)=>(n[o]="function",n),e);return wr(r,t),r}function of(r,e,t){if(t<we)throw new Error("invalid exponent, negatives unsupported");if(t===we)return r.ONE;if(t===be)return e;let n=r.ONE,o=e;for(;t>we;)t&be&&(n=r.mul(n,o)),o=r.sqr(o),t>>=be;return n}function bn(r,e,t=!1){let n=new Array(e.length).fill(t?r.ZERO:void 0),o=e.reduce((i,a,c)=>r.is0(a)?i:(n[c]=i,r.mul(i,a)),r.ONE),s=r.inv(o);return e.reduceRight((i,a,c)=>r.is0(a)?i:(n[c]=r.mul(i,n[c]),r.mul(i,a)),s),n}function Pa(r,e){let t=(r.ORDER-be)/gt,n=r.pow(e,t),o=r.eql(n,r.ONE),s=r.eql(n,r.ZERO),i=r.eql(n,r.neg(r.ONE));if(!o&&!s&&!i)throw new Error("invalid Legendre symbol result");return o?1:s?0:-1}function sf(r,e){e!==void 0&&We(e);let t=e!==void 0?e:r.toString(2).length,n=Math.ceil(t/8);return{nBitLength:t,nByteLength:n}}var ps=class{ORDER;BITS;BYTES;isLE;ZERO=we;ONE=be;_lengths;_sqrt;_mod;constructor(e,t={}){if(e<=we)throw new Error("invalid field: expected ORDER > 0, got "+e);let n;this.isLE=!1,t!=null&&typeof t=="object"&&(typeof t.BITS=="number"&&(n=t.BITS),typeof t.sqrt=="function"&&(this.sqrt=t.sqrt),typeof t.isLE=="boolean"&&(this.isLE=t.isLE),t.allowedLengths&&(this._lengths=t.allowedLengths?.slice()),typeof t.modFromBytes=="boolean"&&(this._mod=t.modFromBytes));let{nBitLength:o,nByteLength:s}=sf(e,n);if(s>2048)throw new Error("invalid field: expected ORDER of <= 2048 bytes");this.ORDER=e,this.BITS=o,this.BYTES=s,this._sqrt=void 0,Object.preventExtensions(this)}create(e){return Ve(e,this.ORDER)}isValid(e){if(typeof e!="bigint")throw new Error("invalid field element: expected bigint, got "+typeof e);return we<=e&&e<this.ORDER}is0(e){return e===we}isValidNot0(e){return!this.is0(e)&&this.isValid(e)}isOdd(e){return(e&be)===be}neg(e){return Ve(-e,this.ORDER)}eql(e,t){return e===t}sqr(e){return Ve(e*e,this.ORDER)}add(e,t){return Ve(e+t,this.ORDER)}sub(e,t){return Ve(e-t,this.ORDER)}mul(e,t){return Ve(e*t,this.ORDER)}pow(e,t){return of(this,e,t)}div(e,t){return Ve(e*_a(t,this.ORDER),this.ORDER)}sqrN(e){return e*e}addN(e,t){return e+t}subN(e,t){return e-t}mulN(e,t){return e*t}inv(e){return _a(e,this.ORDER)}sqrt(e){return this._sqrt||(this._sqrt=rf(this.ORDER)),this._sqrt(this,e)}toBytes(e){return this.isLE?fs(e,this.BYTES):yn(e,this.BYTES)}fromBytes(e,t=!1){V(e);let{_lengths:n,BYTES:o,isLE:s,ORDER:i,_mod:a}=this;if(n){if(!n.includes(e.length)||e.length>o)throw new Error("Field.fromBytes: expected "+n+" bytes, got "+e.length);let f=new Uint8Array(o);f.set(e,s?0:f.length-e.length),e=f}if(e.length!==o)throw new Error("Field.fromBytes: expected "+o+" bytes, got "+e.length);let c=s?ls(e):Ft(e);if(a&&(c=Ve(c,i)),!t&&!this.isValid(c))throw new Error("invalid field element: outside of range 0..ORDER");return c}invertBatch(e){return bn(this,e)}cmov(e,t,n){return n?t:e}};function Gt(r,e={}){return new ps(r,e)}function Ha(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 bs(r){let e=Ha(r);return e+Math.ceil(e/2)}function gs(r,e,t=!1){V(r);let n=r.length,o=Ha(e),s=bs(e);if(n<16||n<s||n>1024)throw new Error("expected "+s+"-1024 bytes of input, got "+n);let i=t?ls(r):Ft(r),a=Ve(i,e-be)+be;return t?fs(a,o):yn(a,o)}var zt=BigInt(0),wt=BigInt(1);function xr(r,e){let t=e.negate();return r?t:e}function vs(r,e){let t=bn(r.Fp,e.map(n=>n.Z));return e.map((n,o)=>r.fromAffine(n.toAffine(t[o])))}function za(r,e){if(!Number.isSafeInteger(r)||r<=0||r>e)throw new Error("invalid window size, expected [1.."+e+"], got W="+r)}function ws(r,e){za(r,e);let t=Math.ceil(e/r)+1,n=2**(r-1),o=2**r,s=gr(r),i=BigInt(r);return{windows:t,windowSize:n,mask:s,maxNumber:o,shiftBy:i}}function Va(r,e,t){let{windowSize:n,mask:o,maxNumber:s,shiftBy:i}=t,a=Number(r&o),c=r>>i;a>n&&(a-=s,c+=wt);let f=e*n,u=f+Math.abs(a)-1,l=a===0,p=a<0,d=e%2!==0;return{nextN:c,offset:u,isZero:l,isNeg:p,isNegF:d,offsetF:f}}var xs=new WeakMap,Wa=new WeakMap;function Es(r){return Wa.get(r)||1}function Fa(r){if(r!==zt)throw new Error("invalid wNAF")}var gn=class{BASE;ZERO;Fn;bits;constructor(e,t){this.BASE=e.BASE,this.ZERO=e.ZERO,this.Fn=e.Fn,this.bits=t}_unsafeLadder(e,t,n=this.ZERO){let o=e;for(;t>zt;)t&wt&&(n=n.add(o)),o=o.double(),t>>=wt;return n}precomputeWindow(e,t){let{windows:n,windowSize:o}=ws(t,this.bits),s=[],i=e,a=i;for(let c=0;c<n;c++){a=i,s.push(a);for(let f=1;f<o;f++)a=a.add(i),s.push(a);i=a.double()}return s}wNAF(e,t,n){if(!this.Fn.isValid(n))throw new Error("invalid scalar");let o=this.ZERO,s=this.BASE,i=ws(e,this.bits);for(let a=0;a<i.windows;a++){let{nextN:c,offset:f,isZero:u,isNeg:l,isNegF:p,offsetF:d}=Va(n,a,i);n=c,u?s=s.add(xr(p,t[d])):o=o.add(xr(l,t[f]))}return Fa(n),{p:o,f:s}}wNAFUnsafe(e,t,n,o=this.ZERO){let s=ws(e,this.bits);for(let i=0;i<s.windows&&n!==zt;i++){let{nextN:a,offset:c,isZero:f,isNeg:u}=Va(n,i,s);if(n=a,!f){let l=t[c];o=o.add(u?l.negate():l)}}return Fa(n),o}getPrecomputes(e,t,n){let o=xs.get(t);return o||(o=this.precomputeWindow(t,e),e!==1&&(typeof n=="function"&&(o=n(o)),xs.set(t,o))),o}cached(e,t,n){let o=Es(e);return this.wNAF(o,this.getPrecomputes(o,e,n),t)}unsafe(e,t,n,o){let s=Es(e);return s===1?this._unsafeLadder(e,t,o):this.wNAFUnsafe(s,this.getPrecomputes(s,e,n),t,o)}createCache(e,t){za(t,this.bits),Wa.set(e,t),xs.delete(e)}hasCache(e){return Es(e)!==1}};function qa(r,e,t,n){let o=e,s=r.ZERO,i=r.ZERO;for(;t>zt||n>zt;)t&wt&&(s=s.add(o)),n&wt&&(i=i.add(o)),o=o.double(),t>>=wt,n>>=wt;return{p1:s,p2:i}}function Ga(r,e,t){if(e){if(e.ORDER!==r)throw new Error("Field.ORDER must match order: Fp == p, Fn == n");return ys(e),e}else return Gt(r,{isLE:t})}function Ya(r,e,t={},n){if(n===void 0&&(n=r==="edwards"),!e||typeof e!="object")throw new Error(`expected valid ${r} CURVE object`);for(let c of["p","n","h"]){let f=e[c];if(!(typeof f=="bigint"&&f>zt))throw new Error(`CURVE.${c} must be positive bigint`)}let o=Ga(e.p,t.Fp,n),s=Ga(e.n,t.Fn,n),a=["Gx","Gy","a",r==="weierstrass"?"b":"d"];for(let c of a)if(!o.isValid(e[c]))throw new Error(`CURVE.${c} must be valid field element of CURVE.Fp`);return e=Object.freeze(Object.assign({},e)),{CURVE:e,Fp:o,Fn:s}}function Za(r,e){return function(n){let o=r(n);return{secretKey:o,publicKey:e(o)}}}var wn=class{oHash;iHash;blockLen;outputLen;finished=!1;destroyed=!1;constructor(e,t){if(fn(e),V(t,void 0,"key"),this.iHash=e.create(),typeof this.iHash.update!="function")throw new Error("Expected instance of class which extends utils.Hash");this.blockLen=this.iHash.blockLen,this.outputLen=this.iHash.outputLen;let n=this.blockLen,o=new Uint8Array(n);o.set(t.length>n?e.create().update(t).digest():t);for(let s=0;s<o.length;s++)o[s]^=54;this.iHash.update(o),this.oHash=e.create();for(let s=0;s<o.length;s++)o[s]^=106;this.oHash.update(o),mt(o)}update(e){return Vt(this),this.iHash.update(e),this}digestInto(e){Vt(this),V(e,this.outputLen,"output"),this.finished=!0,this.iHash.digestInto(e),this.oHash.update(e),this.oHash.digestInto(e),this.destroy()}digest(){let e=new Uint8Array(this.oHash.outputLen);return this.digestInto(e),e}_cloneInto(e){e||=Object.create(Object.getPrototypeOf(this),{});let{oHash:t,iHash:n,finished:o,destroyed:s,blockLen:i,outputLen:a}=this;return e=e,e.finished=o,e.destroyed=s,e.blockLen=i,e.outputLen=a,e.oHash=t._cloneInto(e.oHash),e.iHash=n._cloneInto(e.iHash),e}clone(){return this._cloneInto()}destroy(){this.destroyed=!0,this.oHash.destroy(),this.iHash.destroy()}},Ss=(r,e,t)=>new wn(r,e).update(t).digest();Ss.create=(r,e)=>new wn(r,e);var Xa=(r,e)=>(r+(r>=0?e:-e)/Qa)/e;function af(r,e,t){let[[n,o],[s,i]]=e,a=Xa(i*r,t),c=Xa(-o*r,t),f=r-a*n-c*s,u=-a*o-c*i,l=f<Je,p=u<Je;l&&(f=-f),p&&(u=-u);let d=gr(Math.ceil(ds(t)/2))+Wt;if(f<Je||f>=d||u<Je||u>=d)throw new Error("splitScalar (endomorphism): failed, k="+r);return{k1neg:l,k1:f,k2neg:p,k2:u}}function Is(r){if(!["compact","recovered","der"].includes(r))throw new Error('Signature format must be "compact", "recovered", or "der"');return r}function As(r,e){let t={};for(let n of Object.keys(e))t[n]=r[n]===void 0?e[n]:r[n];return yr(t.lowS,"lowS"),yr(t.prehash,"prehash"),t.format!==void 0&&Is(t.format),t}var Ts=class extends Error{constructor(e=""){super(e)}},ct={Err:Ts,_tlv:{encode:(r,e)=>{let{Err:t}=ct;if(r<0||r>256)throw new t("tlv.encode: wrong tag");if(e.length&1)throw new t("tlv.encode: unpadded data");let n=e.length/2,o=br(n);if(o.length/2&128)throw new t("tlv.encode: long form length too big");let s=n>127?br(o.length/2|128):"";return br(r)+s+o+e},decode(r,e){let{Err:t}=ct,n=0;if(r<0||r>256)throw new t("tlv.encode: wrong tag");if(e.length<2||e[n++]!==r)throw new t("tlv.decode: wrong tlv");let o=e[n++],s=!!(o&128),i=0;if(!s)i=o;else{let c=o&127;if(!c)throw new t("tlv.decode(long): indefinite length not supported");if(c>4)throw new t("tlv.decode(long): byte length is too big");let f=e.subarray(n,n+c);if(f.length!==c)throw new t("tlv.decode: length bytes not complete");if(f[0]===0)throw new t("tlv.decode(long): zero leftmost byte");for(let u of f)i=i<<8|u;if(n+=c,i<128)throw new t("tlv.decode(long): not minimal encoding")}let a=e.subarray(n,n+i);if(a.length!==i)throw new t("tlv.decode: wrong value length");return{v:a,l:e.subarray(n+i)}}},_int:{encode(r){let{Err:e}=ct;if(r<Je)throw new e("integer: negative integers are not allowed");let t=br(r);if(Number.parseInt(t[0],16)&8&&(t="00"+t),t.length&1)throw new e("unexpected DER parsing assertion: unpadded hex");return t},decode(r){let{Err:e}=ct;if(r[0]&128)throw new e("invalid signature integer: negative");if(r[0]===0&&!(r[1]&128))throw new e("invalid signature integer: unnecessary leading zero");return Ft(r)}},toSig(r){let{Err:e,_int:t,_tlv:n}=ct,o=V(r,void 0,"signature"),{v:s,l:i}=n.decode(48,o);if(i.length)throw new e("invalid signature: left bytes after parsing");let{v:a,l:c}=n.decode(2,s),{v:f,l:u}=n.decode(2,c);if(u.length)throw new e("invalid signature: left bytes after parsing");return{r:t.decode(a),s:t.decode(f)}},hexFromSig(r){let{_tlv:e,_int:t}=ct,n=e.encode(2,t.encode(r.r)),o=e.encode(2,t.encode(r.s)),s=n+o;return e.encode(48,s)}},Je=BigInt(0),Wt=BigInt(1),Qa=BigInt(2),xn=BigInt(3),cf=BigInt(4);function ja(r,e={}){let t=Ya("weierstrass",r,e),{Fp:n,Fn:o}=t,s=t.CURVE,{h:i,n:a}=s;wr(e,{},{allowInfinityPoint:"boolean",clearCofactor:"function",isTorsionFree:"function",fromBytes:"function",toBytes:"function",endo:"object"});let{endo:c}=e;if(c&&(!n.is0(s.a)||typeof c.beta!="bigint"||!Array.isArray(c.basises)))throw new Error('invalid endo: expected "beta": bigint and "basises": array');let f=ec(n,o);function u(){if(!n.isOdd)throw new Error("compression is not supported: Field does not have .isOdd()")}function l(K,b,m){let{x:h,y:w}=b.toAffine(),S=n.toBytes(h);if(yr(m,"isCompressed"),m){u();let T=!n.isOdd(w);return He(Ja(T),S)}else return He(Uint8Array.of(4),S,n.toBytes(w))}function p(K){V(K,void 0,"Point");let{publicKey:b,publicKeyUncompressed:m}=f,h=K.length,w=K[0],S=K.subarray(1);if(h===b&&(w===2||w===3)){let T=n.fromBytes(S);if(!n.isValid(T))throw new Error("bad point: is not on curve, wrong x");let I=E(T),v;try{v=n.sqrt(I)}catch(se){let q=se instanceof Error?": "+se.message:"";throw new Error("bad point: is not on curve, sqrt error"+q)}u();let C=n.isOdd(v);return(w&1)===1!==C&&(v=n.neg(v)),{x:T,y:v}}else if(h===m&&w===4){let T=n.BYTES,I=n.fromBytes(S.subarray(0,T)),v=n.fromBytes(S.subarray(T,T*2));if(!y(I,v))throw new Error("bad point: is not on curve");return{x:I,y:v}}else throw new Error(`bad point: got length ${h}, expected compressed=${b} or uncompressed=${m}`)}let d=e.toBytes||l,g=e.fromBytes||p;function E(K){let b=n.sqr(K),m=n.mul(b,K);return n.add(n.add(m,n.mul(K,s.a)),s.b)}function y(K,b){let m=n.sqr(b),h=E(K);return n.eql(m,h)}if(!y(s.Gx,s.Gy))throw new Error("bad curve params: generator point");let x=n.mul(n.pow(s.a,xn),cf),_=n.mul(n.sqr(s.b),BigInt(27));if(n.is0(n.add(x,_)))throw new Error("bad curve params: a or b");function R(K,b,m=!1){if(!n.isValid(b)||m&&n.is0(b))throw new Error(`bad point coordinate ${K}`);return b}function k(K){if(!(K instanceof O))throw new Error("Weierstrass Point expected")}function G(K){if(!c||!c.basises)throw new Error("no endo");return af(K,c.basises,o.ORDER)}let ce=hs((K,b)=>{let{X:m,Y:h,Z:w}=K;if(n.eql(w,n.ONE))return{x:m,y:h};let S=K.is0();b==null&&(b=S?n.ONE:n.inv(w));let T=n.mul(m,b),I=n.mul(h,b),v=n.mul(w,b);if(S)return{x:n.ZERO,y:n.ZERO};if(!n.eql(v,n.ONE))throw new Error("invZ was invalid");return{x:T,y:I}}),oe=hs(K=>{if(K.is0()){if(e.allowInfinityPoint&&!n.is0(K.Y))return;throw new Error("bad point: ZERO")}let{x:b,y:m}=K.toAffine();if(!n.isValid(b)||!n.isValid(m))throw new Error("bad point: x or y not field elements");if(!y(b,m))throw new Error("bad point: equation left != right");if(!K.isTorsionFree())throw new Error("bad point: not in prime-order subgroup");return!0});function fe(K,b,m,h,w){return m=new O(n.mul(m.X,K),m.Y,m.Z),b=xr(h,b),m=xr(w,m),b.add(m)}class O{static BASE=new O(s.Gx,s.Gy,n.ONE);static ZERO=new O(n.ZERO,n.ONE,n.ZERO);static Fp=n;static Fn=o;X;Y;Z;constructor(b,m,h){this.X=R("x",b),this.Y=R("y",m,!0),this.Z=R("z",h),Object.freeze(this)}static CURVE(){return s}static fromAffine(b){let{x:m,y:h}=b||{};if(!b||!n.isValid(m)||!n.isValid(h))throw new Error("invalid affine point");if(b instanceof O)throw new Error("projective point not allowed");return n.is0(m)&&n.is0(h)?O.ZERO:new O(m,h,n.ONE)}static fromBytes(b){let m=O.fromAffine(g(V(b,void 0,"point")));return m.assertValidity(),m}static fromHex(b){return O.fromBytes(bt(b))}get x(){return this.toAffine().x}get y(){return this.toAffine().y}precompute(b=8,m=!0){return lt.createCache(this,b),m||this.multiply(xn),this}assertValidity(){oe(this)}hasEvenY(){let{y:b}=this.toAffine();if(!n.isOdd)throw new Error("Field doesn't support isOdd");return!n.isOdd(b)}equals(b){k(b);let{X:m,Y:h,Z:w}=this,{X:S,Y:T,Z:I}=b,v=n.eql(n.mul(m,I),n.mul(S,w)),C=n.eql(n.mul(h,I),n.mul(T,w));return v&&C}negate(){return new O(this.X,n.neg(this.Y),this.Z)}double(){let{a:b,b:m}=s,h=n.mul(m,xn),{X:w,Y:S,Z:T}=this,I=n.ZERO,v=n.ZERO,C=n.ZERO,L=n.mul(w,w),se=n.mul(S,S),q=n.mul(T,T),N=n.mul(w,S);return N=n.add(N,N),C=n.mul(w,T),C=n.add(C,C),I=n.mul(b,C),v=n.mul(h,q),v=n.add(I,v),I=n.sub(se,v),v=n.add(se,v),v=n.mul(I,v),I=n.mul(N,I),C=n.mul(h,C),q=n.mul(b,q),N=n.sub(L,q),N=n.mul(b,N),N=n.add(N,C),C=n.add(L,L),L=n.add(C,L),L=n.add(L,q),L=n.mul(L,N),v=n.add(v,L),q=n.mul(S,T),q=n.add(q,q),L=n.mul(q,N),I=n.sub(I,L),C=n.mul(q,se),C=n.add(C,C),C=n.add(C,C),new O(I,v,C)}add(b){k(b);let{X:m,Y:h,Z:w}=this,{X:S,Y:T,Z:I}=b,v=n.ZERO,C=n.ZERO,L=n.ZERO,se=s.a,q=n.mul(s.b,xn),N=n.mul(m,S),j=n.mul(h,T),de=n.mul(w,I),Fe=n.add(m,h),J=n.add(S,T);Fe=n.mul(Fe,J),J=n.add(N,j),Fe=n.sub(Fe,J),J=n.add(m,w);let pe=n.add(S,I);return J=n.mul(J,pe),pe=n.add(N,de),J=n.sub(J,pe),pe=n.add(h,w),v=n.add(T,I),pe=n.mul(pe,v),v=n.add(j,de),pe=n.sub(pe,v),L=n.mul(se,J),v=n.mul(q,de),L=n.add(v,L),v=n.sub(j,L),L=n.add(j,L),C=n.mul(v,L),j=n.add(N,N),j=n.add(j,N),de=n.mul(se,de),J=n.mul(q,J),j=n.add(j,de),de=n.sub(N,de),de=n.mul(se,de),J=n.add(J,de),N=n.mul(j,J),C=n.add(C,N),N=n.mul(pe,J),v=n.mul(Fe,v),v=n.sub(v,N),N=n.mul(Fe,j),L=n.mul(pe,L),L=n.add(L,N),new O(v,C,L)}subtract(b){return this.add(b.negate())}is0(){return this.equals(O.ZERO)}multiply(b){let{endo:m}=e;if(!o.isValidNot0(b))throw new Error("invalid scalar: out of range");let h,w,S=T=>lt.cached(this,T,I=>vs(O,I));if(m){let{k1neg:T,k1:I,k2neg:v,k2:C}=G(b),{p:L,f:se}=S(I),{p:q,f:N}=S(C);w=se.add(N),h=fe(m.beta,L,q,T,v)}else{let{p:T,f:I}=S(b);h=T,w=I}return vs(O,[h,w])[0]}multiplyUnsafe(b){let{endo:m}=e,h=this;if(!o.isValid(b))throw new Error("invalid scalar: out of range");if(b===Je||h.is0())return O.ZERO;if(b===Wt)return h;if(lt.hasCache(this))return this.multiply(b);if(m){let{k1neg:w,k1:S,k2neg:T,k2:I}=G(b),{p1:v,p2:C}=qa(O,h,S,I);return fe(m.beta,v,C,w,T)}else return lt.unsafe(h,b)}toAffine(b){return ce(this,b)}isTorsionFree(){let{isTorsionFree:b}=e;return i===Wt?!0:b?b(O,this):lt.unsafe(this,a).is0()}clearCofactor(){let{clearCofactor:b}=e;return i===Wt?this:b?b(O,this):this.multiplyUnsafe(i)}isSmallOrder(){return this.multiplyUnsafe(i).is0()}toBytes(b=!0){return yr(b,"isCompressed"),this.assertValidity(),d(O,this,b)}toHex(b=!0){return yt(this.toBytes(b))}toString(){return`<Point ${this.is0()?"ZERO":this.toHex()}>`}}let It=o.BITS,lt=new gn(O,e.endo?Math.ceil(It/2):It);return O.BASE.precompute(8),O}function Ja(r){return Uint8Array.of(r?2:3)}function ec(r,e){return{secretKey:e.BYTES,publicKey:1+r.BYTES,publicKeyUncompressed:1+2*r.BYTES,publicKeyHasPrefix:!0,signature:2*e.BYTES}}function uf(r,e={}){let{Fn:t}=r,n=e.randomBytes||hn,o=Object.assign(ec(r.Fp,t),{seed:bs(t.ORDER)});function s(d){try{let g=t.fromBytes(d);return t.isValidNot0(g)}catch{return!1}}function i(d,g){let{publicKey:E,publicKeyUncompressed:y}=o;try{let x=d.length;return g===!0&&x!==E||g===!1&&x!==y?!1:!!r.fromBytes(d)}catch{return!1}}function a(d=n(o.seed)){return gs(V(d,o.seed,"seed"),t.ORDER)}function c(d,g=!0){return r.BASE.multiply(t.fromBytes(d)).toBytes(g)}function f(d){let{secretKey:g,publicKey:E,publicKeyUncompressed:y}=o;if(!mr(d)||"_lengths"in t&&t._lengths||g===E)return;let x=V(d,void 0,"key").length;return x===E||x===y}function u(d,g,E=!0){if(f(d)===!0)throw new Error("first arg must be private key");if(f(g)===!1)throw new Error("second arg must be public key");let y=t.fromBytes(d);return r.fromBytes(g).multiply(y).toBytes(E)}let l={isValidSecretKey:s,isValidPublicKey:i,randomSecretKey:a},p=Za(a,c);return Object.freeze({getPublicKey:c,getSharedSecret:u,keygen:p,Point:r,utils:l,lengths:o})}function tc(r,e,t={}){fn(e),wr(t,{},{hmac:"function",lowS:"boolean",randomBytes:"function",bits2int:"function",bits2int_modN:"function"}),t=Object.assign({},t);let n=t.randomBytes||hn,o=t.hmac||((m,h)=>Ss(e,m,h)),{Fp:s,Fn:i}=r,{ORDER:a,BITS:c}=i,{keygen:f,getPublicKey:u,getSharedSecret:l,utils:p,lengths:d}=uf(r,t),g={prehash:!0,lowS:typeof t.lowS=="boolean"?t.lowS:!0,format:"compact",extraEntropy:!1},E=a*Qa<s.ORDER;function y(m){let h=a>>Wt;return m>h}function x(m,h){if(!i.isValidNot0(h))throw new Error(`invalid signature ${m}: out of range 1..Point.Fn.ORDER`);return h}function _(){if(E)throw new Error('"recovered" sig type is not supported for cofactor >2 curves')}function R(m,h){Is(h);let w=d.signature,S=h==="compact"?w:h==="recovered"?w+1:void 0;return V(m,S)}class k{r;s;recovery;constructor(h,w,S){if(this.r=x("r",h),this.s=x("s",w),S!=null){if(_(),![0,1,2,3].includes(S))throw new Error("invalid recovery id");this.recovery=S}Object.freeze(this)}static fromBytes(h,w=g.format){R(h,w);let S;if(w==="der"){let{r:C,s:L}=ct.toSig(V(h));return new k(C,L)}w==="recovered"&&(S=h[0],w="compact",h=h.subarray(1));let T=d.signature/2,I=h.subarray(0,T),v=h.subarray(T,T*2);return new k(i.fromBytes(I),i.fromBytes(v),S)}static fromHex(h,w){return this.fromBytes(bt(h),w)}assertRecovery(){let{recovery:h}=this;if(h==null)throw new Error("invalid recovery id: must be present");return h}addRecoveryBit(h){return new k(this.r,this.s,h)}recoverPublicKey(h){let{r:w,s:S}=this,T=this.assertRecovery(),I=T===2||T===3?w+a:w;if(!s.isValid(I))throw new Error("invalid recovery id: sig.r+curve.n != R.x");let v=s.toBytes(I),C=r.fromBytes(He(Ja((T&1)===0),v)),L=i.inv(I),se=ce(V(h,void 0,"msgHash")),q=i.create(-se*L),N=i.create(S*L),j=r.BASE.multiplyUnsafe(q).add(C.multiplyUnsafe(N));if(j.is0())throw new Error("invalid recovery: point at infinify");return j.assertValidity(),j}hasHighS(){return y(this.s)}toBytes(h=g.format){if(Is(h),h==="der")return bt(ct.hexFromSig(this));let{r:w,s:S}=this,T=i.toBytes(w),I=i.toBytes(S);return h==="recovered"?(_(),He(Uint8Array.of(this.assertRecovery()),T,I)):He(T,I)}toHex(h){return yt(this.toBytes(h))}}let G=t.bits2int||function(h){if(h.length>8192)throw new Error("input is too large");let w=Ft(h),S=h.length*8-c;return S>0?w>>BigInt(S):w},ce=t.bits2int_modN||function(h){return i.create(G(h))},oe=gr(c);function fe(m){return Ba("num < 2^"+c,m,Je,oe),i.toBytes(m)}function O(m,h){return V(m,void 0,"message"),h?V(e(m),void 0,"prehashed message"):m}function It(m,h,w){let{lowS:S,prehash:T,extraEntropy:I}=As(w,g);m=O(m,T);let v=ce(m),C=i.fromBytes(h);if(!i.isValidNot0(C))throw new Error("invalid private key");let L=[fe(C),fe(v)];if(I!=null&&I!==!1){let j=I===!0?n(d.secretKey):I;L.push(V(j,void 0,"extraEntropy"))}let se=He(...L),q=v;function N(j){let de=G(j);if(!i.isValidNot0(de))return;let Fe=i.inv(de),J=r.BASE.multiply(de).toAffine(),pe=i.create(J.x);if(pe===Je)return;let Tr=i.create(Fe*i.create(q+pe*C));if(Tr===Je)return;let fi=(J.x===pe?0:2)|Number(J.y&Wt),di=Tr;return S&&y(Tr)&&(di=i.neg(Tr),fi^=1),new k(pe,di,E?void 0:fi)}return{seed:se,k2sig:N}}function lt(m,h,w={}){let{seed:S,k2sig:T}=It(m,h,w);return Oa(e.outputLen,i.BYTES,o)(S,T).toBytes(w.format)}function K(m,h,w,S={}){let{lowS:T,prehash:I,format:v}=As(S,g);if(w=V(w,void 0,"publicKey"),h=O(h,I),!mr(m)){let C=m instanceof k?", use sig.toBytes()":"";throw new Error("verify expects Uint8Array signature"+C)}R(m,v);try{let C=k.fromBytes(m,v),L=r.fromBytes(w);if(T&&C.hasHighS())return!1;let{r:se,s:q}=C,N=ce(h),j=i.inv(q),de=i.create(N*j),Fe=i.create(se*j),J=r.BASE.multiplyUnsafe(de).add(L.multiplyUnsafe(Fe));return J.is0()?!1:i.create(J.x)===se}catch{return!1}}function b(m,h,w={}){let{prehash:S}=As(w,g);return h=O(h,S),k.fromBytes(m,"recovered").recoverPublicKey(h).toBytes()}return Object.freeze({keygen:f,getPublicKey:u,getSharedSecret:l,utils:p,lengths:d,Point:r,sign:lt,verify:K,recoverPublicKey:b,Signature:k,hash:e})}var Ds={p:BigInt("0xfffffffffffffffffffffffffffffffffffffffffffffffffffffffefffffc2f"),n:BigInt("0xfffffffffffffffffffffffffffffffebaaedce6af48a03bbfd25e8cd0364141"),h:BigInt(1),a:BigInt(0),b:BigInt(7),Gx:BigInt("0x79be667ef9dcbbac55a06295ce870b07029bfcdb2dce28d959f2815b16f81798"),Gy:BigInt("0x483ada7726a3c4655da4fbfc0e1108a8fd17b448a68554199c47d08ffb10d4b8")},lf={beta:BigInt("0x7ae96a2b657c07106e64479eac3434e99cf0497512f58995c1396c28719501ee"),basises:[[BigInt("0x3086d221a7d46bcde86c90e49284eb15"),-BigInt("0xe4437ed6010e88286f547fa90abfe4c3")],[BigInt("0x114ca50f7a8e2f3f657c1108d9d44cfd8"),BigInt("0x3086d221a7d46bcde86c90e49284eb15")]]};var rc=BigInt(2);function ff(r){let e=Ds.p,t=BigInt(3),n=BigInt(6),o=BigInt(11),s=BigInt(22),i=BigInt(23),a=BigInt(44),c=BigInt(88),f=r*r*r%e,u=f*f*r%e,l=De(u,t,e)*u%e,p=De(l,t,e)*u%e,d=De(p,rc,e)*f%e,g=De(d,o,e)*d%e,E=De(g,s,e)*g%e,y=De(E,a,e)*E%e,x=De(y,c,e)*y%e,_=De(x,a,e)*E%e,R=De(_,t,e)*u%e,k=De(R,i,e)*g%e,G=De(k,n,e)*f%e,ce=De(G,rc,e);if(!Cs.eql(Cs.sqr(ce),r))throw new Error("Cannot find square root");return ce}var Cs=Gt(Ds.p,{sqrt:ff}),df=ja(Ds,{Fp:Cs,endo:lf}),Er=tc(df,Ca);var En=class extends Error{constructor(e="An error occurred while verifying a message"){super(e),this.name="VerificationError"}};function oc(r,e,t,n){n?.signal?.throwIfAborted();let o=nc.default.createHash("sha256");if(t instanceof Uint8Array)o.update(t);else for(let i of t)o.update(i);let s=o.digest();try{return Er.verify(e,s,r,{prehash:!1,format:"der"})}catch(i){throw new En(String(i))}}var vn=class{type="secp256k1";raw;_key;constructor(e){this._key=ic(e),this.raw=sc(this._key)}toMultihash(){return Ue.digest(Ht(this))}toCID(){return ae.createV1(114,this.toMultihash())}toString(){return re.encode(this.toMultihash().bytes).substring(1)}equals(e){return e==null||!(e.raw instanceof Uint8Array)?!1:Te(this.raw,e.raw)}verify(e,t,n){return oc(this._key,t,e,n)}};function ac(r){return new vn(r)}function sc(r){return Er.Point.fromBytes(r).toBytes()}function ic(r){try{return Er.Point.fromBytes(r),r}catch(e){throw new zr(String(e))}}function cc(r){let{Type:e,Data:t}=pr.decode(r.digest),n=t??new Uint8Array;switch(e){case Ce.Ed25519:return wa(n);case Ce.secp256k1:return ac(n);case Ce.ECDSA:return ha(n);default:throw new lr}}function Ht(r){return pr.encode({Type:Ce[r.type],Data:r.raw})}var uc=Symbol.for("nodejs.util.inspect.custom"),hf=114,vr=class{type;multihash;publicKey;string;constructor(e){this.type=e.type,this.multihash=e.multihash,Object.defineProperty(this,"string",{enumerable:!1,writable:!0})}get[Symbol.toStringTag](){return`PeerId(${this.toString()})`}[Jr]=!0;toString(){return this.string==null&&(this.string=re.encode(this.multihash.bytes).slice(1)),this.string}toMultihash(){return this.multihash}toCID(){return ae.createV1(hf,this.multihash)}toJSON(){return this.toString()}equals(e){if(e==null)return!1;if(e instanceof Uint8Array)return Te(this.multihash.bytes,e);if(typeof e=="string")return this.toString()===e;if(e?.toMultihash()?.bytes!=null)return Te(this.multihash.bytes,e.toMultihash().bytes);throw new Error("not valid Id")}[uc](){return`PeerId(${this.toString()})`}},Sn=class extends vr{type="RSA";publicKey;constructor(e){super({...e,type:"RSA"}),this.publicKey=e.publicKey}},An=class extends vr{type="Ed25519";publicKey;constructor(e){super({...e,type:"Ed25519"}),this.publicKey=e.publicKey}},In=class extends vr{type="secp256k1";publicKey;constructor(e){super({...e,type:"secp256k1"}),this.publicKey=e.publicKey}},pf=2336,Tn=class{type="url";multihash;publicKey;url;constructor(e){this.url=e.toString(),this.multihash=Ue.digest(Ee(this.url))}[uc](){return`PeerId(${this.url})`}[Jr]=!0;toString(){return this.toCID().toString()}toMultihash(){return this.multihash}toCID(){return ae.createV1(pf,this.toMultihash())}toJSON(){return this.toString()}equals(e){return e==null?!1:(e instanceof Uint8Array&&(e=ne(e)),e.toString()===this.toString())}};function et(r){if(yf(r))return new Sn({multihash:r});if(mf(r))try{let e=cc(r);if(e.type==="Ed25519")return new An({multihash:r,publicKey:e});if(e.type==="secp256k1")return new In({multihash:r,publicKey:e})}catch{let t=ne(r.digest);return new Tn(new URL(t))}throw new qr("Supplied PeerID Multihash is invalid")}function mf(r){return r.code===Ue.code}function yf(r){return r.code===Ko.code}var Kc=Ae(ie("net"),1);var he=class extends Error{static name="InvalidMultiaddrError";name="InvalidMultiaddrError"},tt=class extends Error{static name="ValidationError";name="ValidationError"},Cn=class extends Error{static name="InvalidParametersError";name="InvalidParametersError"},Dn=class extends Error{static name="UnknownProtocolError";name="UnknownProtocolError"};var Le=ie("node:net");function Bs(r){return e=>ne(e,r)}function Os(r){return e=>Ee(e,r)}function qt(r){return new DataView(r.buffer).getUint16(r.byteOffset).toString()}function xt(r){let e=new ArrayBuffer(2);return new DataView(e).setUint16(0,typeof r=="string"?parseInt(r):r),new Uint8Array(e)}function lc(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=Ee(e[0],"base32"),n=parseInt(e[1],10);if(n<1||n>65536)throw new Error("Port number is not in range(1, 65536)");let o=xt(n);return ze([t,o],t.length+o.length)}function fc(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=Ge.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 o=xt(n);return ze([t,o],t.length+o.length)}function _s(r){let e=r.subarray(0,r.length-2),t=r.subarray(r.length-2),n=ne(e,"base32"),o=qt(t);return`${n}:${o}`}var Ps=function(r){r=r.toString().trim();let e=new Uint8Array(4);return r.split(/\./g).forEach((t,n)=>{let o=parseInt(t,10);if(isNaN(o)||o<0||o>255)throw new he("Invalid byte value in IP address");e[n]=o}),e},dc=function(r){let e=0;r=r.toString().trim();let t=r.split(":",8),n;for(n=0;n<t.length;n++){let s=(0,Le.isIPv4)(t[n]),i;s&&(i=Ps(t[n]),t[n]=ne(i.subarray(0,2),"base16")),i!=null&&++n<8&&t.splice(n,0,ne(i.subarray(2,4),"base16"))}if(t[0]==="")for(;t.length<8;)t.unshift("0");else if(t[t.length-1]==="")for(;t.length<8;)t.push("0");else if(t.length<8){for(n=0;n<t.length&&t[n]!=="";n++);let s=[n,1];for(n=9-t.length;n>0;n--)s.push("0");t.splice.apply(t,s)}let o=new Uint8Array(e+16);for(n=0;n<t.length;n++){t[n]===""&&(t[n]="0");let s=parseInt(t[n],16);if(isNaN(s)||s<0||s>65535)throw new he("Invalid byte value in IP address");o[e++]=s>>8&255,o[e++]=s&255}return o},hc=function(r){if(r.byteLength!==4)throw new he("IPv4 address was incorrect length");let e=[];for(let t=0;t<r.byteLength;t++)e.push(r[t]);return e.join(".")},pc=function(r){if(r.byteLength!==16)throw new he("IPv6 address was incorrect length");let e=[];for(let n=0;n<r.byteLength;n+=2){let o=r[n],s=r[n+1],i=`${o.toString(16).padStart(2,"0")}${s.toString(16).padStart(2,"0")}`;e.push(i)}let t=e.join(":");try{let n=new URL(`http://[${t}]`);return n.hostname.substring(1,n.hostname.length-1)}catch{throw new he(`Invalid IPv6 address "${t}"`)}};function mc(r){try{let e=new URL(`http://[${r}]`);return e.hostname.substring(1,e.hostname.length-1)}catch{throw new he(`Invalid IPv6 address "${r}"`)}}var Ls=Object.values(nr).map(r=>r.decoder),bf=(function(){let r=Ls[0].or(Ls[1]);return Ls.slice(2).forEach(e=>r=r.or(e)),r})();function yc(r){return bf.decode(r)}function bc(r){return e=>r.encoder.encode(e)}function gf(r){if(parseInt(r).toString()!==r)throw new tt("Value must be an integer")}function wf(r){if(r<0)throw new tt("Value must be a positive integer, or zero")}function xf(r){return e=>{if(e>r)throw new tt(`Value must be smaller than or equal to ${r}`)}}function Ef(...r){return e=>{for(let t of r)t(e)}}var Sr=Ef(gf,wf,xf(65535));var ue=-1,Ns=class{protocolsByCode=new Map;protocolsByName=new Map;getProtocol(e){let t;if(typeof e=="string"?t=this.protocolsByName.get(e):t=this.protocolsByCode.get(e),t==null)throw new Dn(`Protocol ${e} was unknown`);return t}addProtocol(e){this.protocolsByCode.set(e.code,e),this.protocolsByName.set(e.name,e),e.aliases?.forEach(t=>{this.protocolsByName.set(t,e)})}removeProtocol(e){let t=this.protocolsByCode.get(e);t!=null&&(this.protocolsByCode.delete(t.code),this.protocolsByName.delete(t.name),t.aliases?.forEach(n=>{this.protocolsByName.delete(n)}))}},rt=new Ns,kf=[{code:4,name:"ip4",size:32,valueToBytes:Ps,bytesToValue:hc,validate:r=>{if(!(0,Le.isIPv4)(r))throw new tt(`Invalid IPv4 address "${r}"`)}},{code:6,name:"tcp",size:16,valueToBytes:xt,bytesToValue:qt,validate:Sr},{code:273,name:"udp",size:16,valueToBytes:xt,bytesToValue:qt,validate:Sr},{code:33,name:"dccp",size:16,valueToBytes:xt,bytesToValue:qt,validate:Sr},{code:41,name:"ip6",size:128,valueToBytes:dc,bytesToValue:pc,stringToValue:mc,validate:r=>{if(!(0,Le.isIPv6)(r))throw new tt(`Invalid IPv6 address "${r}"`)}},{code:42,name:"ip6zone",size:ue},{code:43,name:"ipcidr",size:8,bytesToValue:Bs("base10"),valueToBytes:Os("base10")},{code:53,name:"dns",size:ue},{code:54,name:"dns4",size:ue},{code:55,name:"dns6",size:ue},{code:56,name:"dnsaddr",size:ue},{code:132,name:"sctp",size:16,valueToBytes:xt,bytesToValue:qt,validate:Sr},{code:301,name:"udt"},{code:302,name:"utp"},{code:400,name:"unix",size:ue,stringToValue:r=>decodeURIComponent(r),valueToString:r=>encodeURIComponent(r)},{code:421,name:"p2p",aliases:["ipfs"],size:ue,bytesToValue:Bs("base58btc"),valueToBytes:r=>r.startsWith("Q")||r.startsWith("1")?Os("base58btc")(r):ae.parse(r).multihash.bytes},{code:444,name:"onion",size:96,bytesToValue:_s,valueToBytes:lc},{code:445,name:"onion3",size:296,bytesToValue:_s,valueToBytes:fc},{code:446,name:"garlic64",size:ue},{code:447,name:"garlic32",size:ue},{code:448,name:"tls"},{code:449,name:"sni",size:ue},{code:454,name:"noise"},{code:460,name:"quic"},{code:461,name:"quic-v1"},{code:465,name:"webtransport"},{code:466,name:"certhash",size:ue,bytesToValue:bc(Bo),valueToBytes:yc},{code:480,name:"http"},{code:481,name:"http-path",size:ue,stringToValue:r=>`/${decodeURIComponent(r)}`,valueToString:r=>encodeURIComponent(r.substring(1))},{code:443,name:"https"},{code:477,name:"ws"},{code:478,name:"wss"},{code:479,name:"p2p-websocket-star"},{code:277,name:"p2p-stardust"},{code:275,name:"p2p-webrtc-star"},{code:276,name:"p2p-webrtc-direct"},{code:280,name:"webrtc-direct"},{code:281,name:"webrtc"},{code:290,name:"p2p-circuit"},{code:777,name:"memory",size:ue}];kf.forEach(r=>{rt.addProtocol(r)});function gc(r){let e=[],t=0;for(;t<r.length;){let n=jt(r,t),o=rt.getProtocol(n),s=xe(n),i=Uf(o,r,t+s),a=0;i>0&&o.size===ue&&(a=xe(i));let c=s+a+i,f={code:n,name:o.name,bytes:r.subarray(t,t+c)};if(i>0){let u=t+s+a,l=r.subarray(u,u+i);f.value=o.bytesToValue?.(l)??ne(l)}e.push(f),t+=c}return e}function wc(r){let e=0,t=[];for(let n of r){if(n.bytes==null){let o=rt.getProtocol(n.code),s=xe(n.code),i,a=0,c=0;n.value!=null&&(i=o.valueToBytes?.(n.value)??Ee(n.value),a=i.byteLength,o.size===ue&&(c=xe(a)));let f=new Uint8Array(s+c+a),u=0;Tt(n.code,f,u),u+=s,i!=null&&(o.size===ue&&(Tt(a,f,u),u+=c),f.set(i,u)),n.bytes=f}t.push(n.bytes),e+=n.bytes.byteLength}return ze(t,e)}function xc(r){if(r.charAt(0)!=="/")throw new he('String multiaddr must start with "/"');let e=[],t="protocol",n="",o="";for(let s=1;s<r.length;s++){let i=r.charAt(s);i!=="/"&&(t==="protocol"?o+=r.charAt(s):n+=r.charAt(s));let a=s===r.length-1;if(i==="/"||a){let c=rt.getProtocol(o);if(t==="protocol"){if(c.size==null||c.size===0){e.push({code:c.code,name:c.name}),n="",o="",t="protocol";continue}else if(a)throw new he(`Component ${o} was missing value`);t="value"}else if(t==="value"){let f={code:c.code,name:c.name};if(c.size!=null&&c.size!==0){if(n==="")throw new he(`Component ${o} was missing value`);f.value=c.stringToValue?.(n)??n}e.push(f),n="",o="",t="protocol"}}}if(o!==""&&n!=="")throw new he("Incomplete multiaddr");return e}function Ec(r){return`/${r.flatMap(e=>{if(e.value==null)return e.name;let t=rt.getProtocol(e.code);if(t==null)throw new he(`Unknown protocol code ${e.code}`);return[e.name,t.valueToString?.(e.value)??e.value]}).join("/")}`}function Uf(r,e,t){return r.size==null||r.size===0?0:r.size>0?r.size/8:jt(e,t)}var Mf=Symbol.for("nodejs.util.inspect.custom"),qs=Symbol.for("@multiformats/multiaddr");function Kf(r){if(r==null&&(r="/"),Un(r))return r.getComponents();if(r instanceof Uint8Array)return gc(r);if(typeof r=="string")return r=r.replace(/\/(\/)+/,"/").replace(/(\/)+$/,""),r===""&&(r="/"),xc(r);if(Array.isArray(r))return r;throw new he("Must be a string, Uint8Array, Component[], or another Multiaddr")}var kn=class r{[qs]=!0;#e;#t;#r;constructor(e="/",t={}){this.#e=Kf(e),t.validate!==!1&&$f(this)}get bytes(){return this.#r==null&&(this.#r=wc(this.#e)),this.#r}toString(){return this.#t==null&&(this.#t=Ec(this.#e)),this.#t}toJSON(){return this.toString()}getComponents(){return[...this.#e.map(e=>({...e}))]}encapsulate(e){let t=new r(e);return new r([...this.#e,...t.getComponents()],{validate:!1})}decapsulate(e){let t=e.toString(),n=this.toString(),o=n.lastIndexOf(t);if(o<0)throw new Cn(`Address ${this.toString()} does not contain subaddress: ${t}`);return new r(n.slice(0,o),{validate:!1})}decapsulateCode(e){let t;for(let n=this.#e.length-1;n>-1;n--)if(this.#e[n].code===e){t=n;break}return new r(this.#e.slice(0,t),{validate:!1})}equals(e){return Te(this.bytes,e.bytes)}[Mf](){return`Multiaddr(${this.toString()})`}};function $f(r){r.getComponents().forEach(e=>{let t=rt.getProtocol(e.code);e.value!=null&&t.validate?.(e.value)})}function Un(r){return!!r?.[qs]}function Be(r){return new kn(r)}var z=r=>({match:e=>{let t=e[0];return t==null||t.code!==r||t.value!=null?!1:e.slice(1)}}),A=(r,e)=>({match:t=>{let n=t[0];return n?.code!==r||n.value==null||e!=null&&n.value!==e?!1:t.slice(1)}}),vc=r=>({match:e=>r.match(e)===!1?e:!1}),P=r=>({match:e=>{let t=r.match(e);return t===!1?e:t}}),ge=(...r)=>({match:e=>{let t;for(let n of r){let o=n.match(e);o!==!1&&(t==null||o.length<t.length)&&(t=o)}return t??!1}}),M=(...r)=>({match:e=>{for(let t of r){let n=t.match(e);if(n===!1)return!1;e=n}return e}});function W(...r){function e(o){if(o==null)return!1;let s=o.getComponents();for(let i of r){let a=i.match(s);if(a===!1)return!1;s=a}return s}function t(o){return e(o)!==!1}function n(o){let s=e(o);return s===!1?!1:s.length===0}return{matchers:r,matches:t,exactMatch:n}}var Hf=A(421),rb=W(Hf),Kn=A(54),$n=A(55),Hn=A(56),Zs=A(53),nb=W(Kn,P(A(421))),ob=W($n,P(A(421))),sb=W(Hn,P(A(421))),ib=W(ge(Zs,Hn,Kn,$n),P(A(421))),Sc=M(A(4),P(A(43))),Ac=M(P(A(42)),A(41),P(A(43))),Xs=ge(Sc,Ac),St=ge(Xs,Zs,Kn,$n,Hn),ab=W(ge(Xs,M(ge(Zs,Hn,Kn,$n),P(A(421))))),cb=W(Sc),ub=W(Ac),lb=W(Xs),Qs=M(St,A(6)),Ir=M(St,A(273)),Ic=W(M(Qs,P(A(421)))),fb=W(Ir),js=M(Ir,z(460),P(A(421))),Vn=M(Ir,z(461),P(A(421))),Vf=ge(js,Vn),db=W(js),hb=W(Vn),Ys=ge(St,Qs,Ir,js,Vn),Tc=ge(M(Ys,z(477),P(A(421)))),pb=W(Tc),Cc=ge(M(Ys,z(478),P(A(421))),M(Ys,z(448),P(A(449)),z(477),P(A(421)))),mb=W(Cc),Dc=M(Ir,z(280),P(A(466)),P(A(466)),P(A(421))),yb=W(Dc),Lc=M(Vn,z(465),P(A(466)),P(A(466)),P(A(421))),bb=W(Lc),Mn=ge(Tc,Cc,M(Qs,P(A(421))),M(Vf,P(A(421))),M(St,P(A(421))),Dc,Lc,A(421)),gb=W(Mn),Ff=M(P(Mn),z(290),vc(z(281)),P(A(421))),wb=W(Ff),Gf=ge(M(Mn,z(290),z(281),P(A(421))),M(Mn,z(281),P(A(421))),M(z(281),P(A(421)))),xb=W(Gf),zf=ge(M(St,A(6),z(480),P(A(421))),M(St,z(480),P(A(421)))),Eb=W(zf),Wf=M(St,ge(M(A(6,"443"),z(480)),M(A(6),z(443)),M(A(6),z(448),z(480)),M(z(448),z(480)),z(448),z(443)),P(A(421))),vb=W(Wf),qf=ge(M(A(777),P(A(421)))),Sb=W(qf),Yf=ge(M(A(400),P(A(421)))),Fn=W(Yf);var Gn=class extends Event{type;detail;constructor(e,t){super(e),this.type=e,this.detail=t}};var Mc=Ae(ie("node:net"),1);function zn(r){let e=r.getComponents(),t={},n=0;if(e[n]?.name==="ip6zone"&&(t.zone=`${e[n].value}`,n++),e[n].name==="ip4"||e[n].name==="ip6"||e[n].name==="dns"||e[n].name==="dns4"||e[n].name==="dns6"?(t.type=e[n].name,t.host=e[n].value,n++):e[n].name==="dnsaddr"&&(t.type=e[n].name,t.host=`_dnsaddr.${e[n].value}`,n++),(e[n]?.name==="tcp"||e[n]?.name==="udp")&&(t.protocol=e[n].name==="tcp"?"tcp":"udp",t.port=parseInt(`${e[n].value}`),n++),e[n]?.name==="ipcidr"&&(t.type==="ip4"?t.cidr=parseInt(`${e[n].value}`):t.type==="ip6"&&(t.cidr=`${e[n].value}`),n++),t.type==null||t.host==null)throw new D(`Multiaddr ${r} was not an IPv4, IPv6, DNS, DNS4, DNS6 or DNSADDR address`);return e[n]?.name==="tls"&&e[n+1]?.name==="sni"&&(t.sni=e[n+1].value,n+=2),t}function Wn(){let r={};return r.promise=new Promise((e,t)=>{r.resolve=e,r.reject=t}),r}var qn=class{buffer;mask;top;btm;next;constructor(e){if(!(e>0)||(e-1&e)!==0)throw new Error("Max size for a FixedFIFO should be a power of two");this.buffer=new Array(e),this.mask=e-1,this.top=0,this.btm=0,this.next=null}push(e){return this.buffer[this.top]!==void 0?!1:(this.buffer[this.top]=e,this.top=this.top+1&this.mask,!0)}shift(){let e=this.buffer[this.btm];if(e!==void 0)return this.buffer[this.btm]=void 0,this.btm=this.btm+1&this.mask,e}isEmpty(){return this.buffer[this.btm]===void 0}},Qt=class{size;hwm;head;tail;constructor(e={}){this.hwm=e.splitLimit??16,this.head=new qn(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 qn(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 Js=class extends Error{type;code;constructor(e,t){super(e??"The operation was aborted"),this.type="aborted",this.code=t??"ABORT_ERR"}};function Yn(r={}){return Zf(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 Zf(r,e){e=e??{};let t=e.onEnd,n=new Qt,o,s,i,a=Wn(),c=async()=>{try{return n.isEmpty()?i?{done:!0}:await new Promise((y,x)=>{s=_=>{s=null,n.push(_);try{y(r(n))}catch(R){x(R)}return o}}):r(n)}finally{n.isEmpty()&&queueMicrotask(()=>{a.resolve(),a=Wn()})}},f=y=>s!=null?s(y):(n.push(y),o),u=y=>(n=new Qt,s!=null?s({error:y}):(n.push({error:y}),o)),l=y=>{if(i)return o;if(e?.objectMode!==!0&&y?.byteLength==null)throw new Error("objectMode was not true but tried to push non-Uint8Array value");return f({done:!1,value:y})},p=y=>i?o:(i=!0,y!=null?u(y):f({done:!0})),d=()=>(n=new Qt,p(),{done:!0}),g=y=>(p(y),{done:!0});if(o={[Symbol.asyncIterator](){return this},next:c,return:d,throw:g,push:l,end:p,get readableLength(){return n.size},onEmpty:async y=>{let x=y?.signal;if(x?.throwIfAborted(),n.isEmpty())return;let _,R;x!=null&&(_=new Promise((k,G)=>{R=()=>{G(new Js)},x.addEventListener("abort",R)}));try{await Promise.race([a.promise,_])}finally{R!=null&&x!=null&&x?.removeEventListener("abort",R)}}},t==null)return o;let E=o;return o={[Symbol.asyncIterator](){return this},next(){return E.next()},throw(y){return E.throw(y),t!=null&&(t(y),t=void 0),{done:!0}},return(){return E.return(),t!=null&&(t(),t=void 0),{done:!0}},push:l,end(y){return E.end(y),t!=null&&(t(y),t=void 0),o},get readableLength(){return E.readableLength},onEmpty:y=>E.onEmpty(y)},o}var ei=class extends Error{constructor(e){super(e),this.name="TimeoutError"}},ti=class extends Error{constructor(e){super(),this.name="AbortError",this.message=e}},Bc=r=>globalThis.DOMException===void 0?new ti(r):new DOMException(r),Oc=r=>{let e=r.reason===void 0?Bc("This operation was aborted."):r.reason;return e instanceof Error?e:Bc(e)};function ri(r,e){let{milliseconds:t,fallback:n,message:o,customTimers:s={setTimeout,clearTimeout}}=e,i,a,f=new Promise((u,l)=>{if(typeof t!="number"||Math.sign(t)!==1)throw new TypeError(`Expected \`milliseconds\` to be a positive number, got \`${t}\``);if(e.signal){let{signal:d}=e;d.aborted&&l(Oc(d)),a=()=>{l(Oc(d))},d.addEventListener("abort",a,{once:!0})}if(t===Number.POSITIVE_INFINITY){r.then(u,l);return}let p=new ei;i=s.setTimeout.call(void 0,()=>{if(n){try{u(n())}catch(d){l(d)}return}typeof r.cancel=="function"&&r.cancel(),o===!1?u():o instanceof Error?l(o):(p.message=o??`Promise timed out after ${t} milliseconds`,l(p))},t),(async()=>{try{u(await r)}catch(d){l(d)}})()}).finally(()=>{f.clear(),a&&e.signal&&e.signal.removeEventListener("abort",a)});return f.clear=()=>{s.clearTimeout.call(void 0,i),i=void 0},f}var Xf=r=>{let e=r.addEventListener||r.on||r.addListener,t=r.removeEventListener||r.off||r.removeListener;if(!e||!t)throw new TypeError("Emitter is not compatible");return{addListener:e.bind(r),removeListener:t.bind(r)}};function Qf(r,e,t){let n,o=new Promise((s,i)=>{if(t={rejectionEvents:["error"],multiArgs:!1,rejectionMultiArgs:!1,resolveImmediately:!1,...t},!(t.count>=0&&(t.count===Number.POSITIVE_INFINITY||Number.isInteger(t.count))))throw new TypeError("The `count` option should be at least 0 or more");t.signal?.throwIfAborted();let a=[e].flat(),c=[],{addListener:f,removeListener:u}=Xf(r),l=async(...d)=>{let g=t.multiArgs?d:d[0];if(t.filter)try{if(!await t.filter(g))return}catch(E){n(),i(E);return}c.push(g),t.count===c.length&&(n(),s(c))},p=(...d)=>{n(),i(t.rejectionMultiArgs?d:d[0])};n=()=>{for(let d of a)u(d,l);for(let d of t.rejectionEvents)a.includes(d)||u(d,p)};for(let d of a)f(d,l);for(let d of t.rejectionEvents)a.includes(d)||f(d,p);t.signal&&t.signal.addEventListener("abort",()=>{p(t.signal.reason)},{once:!0}),t.resolveImmediately&&s(c)});if(o.cancel=n,typeof t.timeout=="number"){let s=ri(o,{milliseconds:t.timeout});return s.cancel=()=>{n(),s.clear()},s}return o}function qe(r,e,t){typeof t=="function"&&(t={filter:t}),t={...t,count:1,resolveImmediately:!1};let n=Qf(r,e,t),o=n.then(s=>s[0]);return o.cancel=n.cancel,o}var At=class extends Error{static name="UnexpectedEOFError";name="UnexpectedEOFError"};var Zn=class extends Error{static name="StreamClosedError";name="StreamClosedError"};function jf(r){return r.reason}async function Xn(r,e,t){if(e==null)return r;let n=t?.translateError??jf;if(e.aborted)return r.catch(()=>{}),Promise.reject(n(e));let o;try{return await Promise.race([r,new Promise((s,i)=>{o=()=>{i(n(e))},e.addEventListener("abort",o)})])}finally{o!=null&&e.removeEventListener("abort",o)}}var Jf=Math.pow(2,20)*4,Qn=class extends Ut{status;timeline;inactivityTimeout;maxReadBufferLength;maxWriteBufferLength;log;direction;maxMessageSize;readStatus;writeStatus;remoteReadStatus;remoteWriteStatus;writableNeedsDrain;readBuffer;writeBuffer;sendingData;onDrainPromise;constructor(e){super(),this.status="open",this.log=e.log,this.direction=e.direction??"outbound",this.inactivityTimeout=e.inactivityTimeout??12e4,this.maxReadBufferLength=e.maxReadBufferLength??Jf,this.maxWriteBufferLength=e.maxWriteBufferLength,this.maxMessageSize=e.maxMessageSize,this.readBuffer=new te,this.writeBuffer=new te,this.readStatus="readable",this.remoteReadStatus="readable",this.writeStatus="writable",this.remoteWriteStatus="writable",this.sendingData=!1,this.writableNeedsDrain=!1,this.timeline={open:Date.now()},this.processSendQueue=this.processSendQueue.bind(this);let t=()=>{this.writableNeedsDrain&&(this.log.trace("drain event received, continue sending data"),this.writableNeedsDrain=!1,this.processSendQueue()),this.onDrainPromise?.resolve()};this.addEventListener("drain",t);let n=o=>{this.onDrainPromise?.reject(o.error??new Zn)};this.addEventListener("close",n)}get readBufferLength(){return this.readBuffer.byteLength}get writeBufferLength(){return this.writeBuffer.byteLength}async onDrain(e){return this.writableNeedsDrain!==!0?Promise.resolve():(this.onDrainPromise==null&&(this.onDrainPromise=Promise.withResolvers()),Xn(this.onDrainPromise.promise,e?.signal))}async*[Symbol.asyncIterator](){if(this.readStatus!=="readable"&&this.readStatus!=="paused")return;let e=Yn(),t=s=>{e.push(s.data)};this.addEventListener("message",t);let n=s=>{e.end(s.error)};this.addEventListener("close",n);let o=()=>{e.end()};this.addEventListener("remoteCloseWrite",o);try{yield*e}finally{this.removeEventListener("message",t),this.removeEventListener("close",n),this.removeEventListener("remoteCloseWrite",o)}}isReadable(){return this.status==="open"}send(e){if(this.writeStatus==="closed"||this.writeStatus==="closing")throw new it(`Cannot write to a stream that is ${this.writeStatus}`);return this.log.trace("append %d bytes to write buffer",e.byteLength),this.writeBuffer.append(e),this.processSendQueue()}abort(e){if(!(this.status==="aborted"||this.status==="reset"||this.status==="closed")){this.log.error("abort with error - %e",e),this.status="aborted",this.readBuffer.byteLength>0&&this.readBuffer.consume(this.readBuffer.byteLength),this.writeBuffer.byteLength>0&&(this.writeBuffer.consume(this.writeBuffer.byteLength),this.safeDispatchEvent("idle")),this.writeStatus="closed",this.remoteWriteStatus="closed",this.readStatus="closed",this.remoteReadStatus="closed",this.timeline.close=Date.now();try{this.sendReset(e)}catch(t){this.log("failed to send reset to remote - %e",t)}this.dispatchEvent(new Qr(e))}}pause(){if(this.readStatus==="closed"||this.readStatus==="closing")throw new it("Cannot pause a stream that is closing/closed");this.readStatus!=="paused"&&(this.readStatus="paused",this.sendPause())}resume(){if(this.readStatus==="closed"||this.readStatus==="closing")throw new it("Cannot resume a stream that is closing/closed");this.readStatus!=="readable"&&(this.readStatus="readable",this.dispatchReadBuffer(),this.sendResume())}push(e){if(this.readStatus==="closed"||this.readStatus==="closing")throw new it(`Cannot push data onto a stream that is ${this.readStatus}`);if(e.byteLength!==0){if(this.readBuffer.append(e),this.readStatus==="paused"||this.listenerCount("message")===0){this.checkReadBufferLength();return}setTimeout(()=>{this.dispatchReadBuffer()},0)}}unshift(e){if(this.readStatus==="closed"||this.readStatus==="closing")throw new it(`Cannot push data onto a stream that is ${this.readStatus}`);if(e.byteLength!==0){if(this.readBuffer.prepend(e),this.readStatus==="paused"||this.listenerCount("message")===0){this.checkReadBufferLength();return}setTimeout(()=>{this.dispatchReadBuffer()},0)}}onData(e){if(e.byteLength!==0){if(this.readStatus==="closing"||this.readStatus==="closed"){this.log("ignoring data - read status %s",this.readStatus);return}this.readBuffer.append(e),this.dispatchReadBuffer()}}addEventListener(...e){super.addEventListener.apply(this,e),e[0]==="message"&&this.readBuffer.byteLength>0&&queueMicrotask(()=>{this.dispatchReadBuffer()})}onRemoteReset(){this.log("remote reset"),this.status="reset",this.writeStatus="closed",this.remoteWriteStatus="closed",this.remoteReadStatus="closed",this.timeline.close=Date.now(),this.readBuffer.byteLength===0&&(this.readStatus="closed");let e=new Wr;this.dispatchEvent(new jr(e))}onTransportClosed(e){this.log("transport closed"),this.readStatus==="readable"&&this.readBuffer.byteLength===0&&(this.log("close readable end after transport closed and read buffer is empty"),this.readStatus="closed"),this.remoteReadStatus!=="closed"&&(this.remoteReadStatus="closed"),this.remoteWriteStatus!=="closed"&&(this.remoteWriteStatus="closed"),this.writeStatus!=="closed"&&(this.writeStatus="closed"),e!=null?this.abort(e):(this.status==="open"||this.status==="closing")&&(this.timeline.close=Date.now(),this.status="closed",this.writeStatus="closed",this.remoteWriteStatus="closed",this.remoteReadStatus="closed",this.dispatchEvent(new Rt))}onRemoteCloseWrite(){this.remoteWriteStatus!=="closed"&&(this.log.trace("on remote close write"),this.remoteWriteStatus="closed",this.safeDispatchEvent("remoteCloseWrite"),this.writeStatus==="closed"&&this.onTransportClosed())}onRemoteCloseRead(){this.log.trace("on remote close read"),this.remoteReadStatus="closed",this.writeBuffer.byteLength>0&&(this.writeBuffer.consume(this.writeBuffer.byteLength),this.safeDispatchEvent("idle"))}processSendQueue(){if(this.writableNeedsDrain)return this.log.trace("not processing send queue as drain is required"),this.checkWriteBufferLength(),!1;if(this.writeBuffer.byteLength===0)return this.log.trace("not processing send queue as no bytes to send"),!0;if(this.sendingData)return this.log.trace("not processing send queue as already sending data"),!0;this.sendingData=!0,this.log.trace("processing send queue with %d queued bytes",this.writeBuffer.byteLength);try{let e=!0,t=this.writeBuffer.byteLength,n=0;for(;this.writeBuffer.byteLength>0;){let o=Math.min(this.maxMessageSize??this.writeBuffer.byteLength,this.writeBuffer.byteLength);if(o===0){e=!1;break}let s=this.writeBuffer.sublist(0,o),i=new te(s);this.writeBuffer.consume(s.byteLength);let a=this.sendData(s);if(e=a.canSendMore,n+=a.sentBytes,a.sentBytes!==i.byteLength&&(i.consume(a.sentBytes),this.writeBuffer.prepend(i)),!e)break}return e||(this.log.trace("sent %d/%d bytes, pausing sending because underlying stream is full, %d bytes left in the write buffer",n,t,this.writeBuffer.byteLength),this.writableNeedsDrain=!0,this.checkWriteBufferLength()),this.writeBuffer.byteLength===0&&this.safeDispatchEvent("idle"),e}finally{this.sendingData=!1}}dispatchReadBuffer(){try{if(this.listenerCount("message")===0){this.log.trace("not dispatching pause buffer as there are no listeners for the message event");return}if(this.readBuffer.byteLength===0){this.log.trace("not dispatching pause buffer as there is no data to dispatch");return}if(this.readStatus==="paused"){this.log.trace("not dispatching pause buffer we are paused");return}if(this.readStatus==="closing"||this.readStatus==="closed"){this.log("dropping %d bytes because the readable end is %s",this.readBuffer.byteLength,this.readStatus),this.readBuffer.consume(this.readBuffer.byteLength);return}let e=this.readBuffer.sublist();this.readBuffer.consume(e.byteLength),this.dispatchEvent(new Xr(e))}finally{this.readBuffer.byteLength===0&&this.remoteWriteStatus==="closed"&&(this.log("close readable end after dispatching read buffer and remote writable end is closed"),this.readStatus="closed"),this.checkReadBufferLength()}}checkReadBufferLength(){this.readBuffer.byteLength>this.maxReadBufferLength&&this.abort(new ar(`Read buffer length of ${this.readBuffer.byteLength} exceeded limit of ${this.maxReadBufferLength}, read status is ${this.readStatus}`))}checkWriteBufferLength(){this.maxWriteBufferLength!=null&&this.writeBuffer.byteLength>this.maxWriteBufferLength&&this.abort(new ar(`Write buffer length of ${this.writeBuffer.byteLength} exceeded limit of ${this.maxWriteBufferLength}, write status is ${this.writeStatus}`))}onMuxerNeedsDrain(){this.writableNeedsDrain=!0}onMuxerDrain(){this.safeDispatchEvent("drain")}};var jn=class extends Qn{remoteAddr;metricPrefix;metrics;constructor(e){super(e),this.metricPrefix=e.metricPrefix??"",this.metrics=e.metrics,this.remoteAddr=e.remoteAddr,this.addEventListener("close",t=>{this.metrics?.increment({[`${this.metricPrefix}end`]:!0}),t.error!=null?t.local?this.metrics?.increment({[`${this.metricPrefix}abort`]:!0}):this.metrics?.increment({[`${this.metricPrefix}reset`]:!0}):t.local?this.metrics?.increment({[`${this.metricPrefix}_local_close`]:!0}):this.metrics?.increment({[`${this.metricPrefix}_remote_close`]:!0})})}async close(e){this.status==="open"&&(this.status="closing",this.writeStatus="closing",this.remoteWriteStatus="closing",this.remoteReadStatus="closing",(this.sendingData||this.writeBuffer.byteLength>0)&&(this.log("waiting for write queue to become idle before closing writable end of stream, %d unsent bytes",this.writeBuffer.byteLength),await qe(this,"idle",{...e,rejectionEvents:["close"]})),this.writableNeedsDrain&&(this.log("waiting for write queue to drain before closing writable end of stream, %d unsent bytes",this.writeBuffer.byteLength),await qe(this,"drain",{...e,rejectionEvents:["close"]})),await this.sendClose(e),this.onTransportClosed())}};var Pc=Ae(ie("node:os"),1);function _c(r){return!!(r.startsWith("169.254.")||r.toLowerCase().startsWith("fe80"))}function ni(r,e,t){let n=[r.type,t??r.host];if(r.protocol!=null){let o=e??r.port;o!=null&&n.push(r.protocol,o)}return r.type==="ip6"&&r.zone!=null&&n.unshift("ip6zone",r.zone),r.cidr!=null&&n.push("ipcidr",r.cidr),Be(`/${n.join("/")}`)}var ed={4:"IPv4",6:"IPv6"};function td(r){return["0.0.0.0","::"].includes(r)}function rd(r){let e=[],t=Pc.default.networkInterfaces();for(let[,n]of Object.entries(t))if(n!=null)for(let o of n)_c(o.address)||o.family===ed[r]&&e.push(o.address);return e}function Nc(r,e){if(r==null)return[];let t=zn(r);return(t.type==="ip4"||t.type==="ip6")&&td(t.host)?rd(t.type==="ip4"?4:6).map(n=>ni(t,e,n)):[ni(t,e)]}function Rc(r,e){if(typeof r!="string")throw new D(`invalid ip provided: ${r}`);if(typeof e=="string"&&(e=parseInt(e)),isNaN(e))throw new D(`invalid port provided: ${e}`);if((0,Le.isIPv4)(r))return Be(`/ip4/${r}/tcp/${e}`);if((0,Le.isIPv6)(r))return Be(`/ip6/${r}/tcp/${e}`);throw new D(`invalid ip:port for creating a multiaddr: ${r}:${e}`)}var nd=4194304,Jn=class extends Error{static name="UnwrappedError";name="UnwrappedError"},si=class extends Error{name="InvalidMessageLengthError";code="ERR_INVALID_MSG_LENGTH"},ii=class extends Error{name="InvalidDataLengthError";code="ERR_MSG_DATA_TOO_LONG"},ai=class extends Error{name="InvalidDataLengthLengthError";code="ERR_MSG_LENGTH_TOO_LONG"};function od(r){return typeof r?.closeRead=="function"}function sd(r){return typeof r?.close=="function"}function oi(r){return od(r)?r.remoteWriteStatus!=="writable"&&r.readBufferLength===0:sd(r)?r.status!=="open":!1}function id(r){return r?.addEventListener!=null&&r?.removeEventListener!=null&&r?.send!=null&&r?.push!=null&&r?.log!=null}function ad(r,e){let t=e?.maxBufferSize??nd,n=new te,o,s=!1;if(!id(r))throw new D("Argument should be a Stream or a Multiaddr");let i=u=>{if(n.append(u.data),n.byteLength>t){let l=n.byteLength;n.consume(n.byteLength),o?.reject(new Error(`Read buffer overflow - ${l} > ${t}`))}o?.resolve()};r.addEventListener("message",i);let a=u=>{u.error!=null?o?.reject(u.error):o?.resolve()};r.addEventListener("close",a);let c=()=>{o?.resolve()};r.addEventListener("remoteCloseWrite",c);let f={readBuffer:n,async read(u){if(s===!0)throw new Jn("Stream was unwrapped");if(oi(r)){if(u?.bytes==null)return null;if(n.byteLength<u.bytes)throw r.log.error("closed after reading %d/%d bytes",n.byteLength,u.bytes),new At(`Unexpected EOF - stream closed after reading ${n.byteLength}/${u.bytes} bytes`)}let l=u?.bytes??1;for(o=Promise.withResolvers();;){if(n.byteLength>=l){o.resolve();break}if(await Xn(o.promise,u?.signal),oi(r)){if(n.byteLength===0&&u?.bytes==null)return null;break}o=Promise.withResolvers()}let p=u?.bytes??n.byteLength;if(n.byteLength<p){if(oi(r))throw r.log.error("closed while reading %d/%d bytes",n.byteLength,p),new At(`Unexpected EOF - stream closed while reading ${n.byteLength}/${p} bytes`);return f.read(u)}let d=n.sublist(0,p);return n.consume(p),d},async write(u,l){if(s===!0)throw new Jn("Stream was unwrapped");r.send(u)||await qe(r,"drain",{signal:l?.signal,rejectionEvents:["close"]})},unwrap(){return s||(s=!0,r.removeEventListener("message",i),r.removeEventListener("close",a),r.removeEventListener("remoteCloseWrite",c),n.byteLength>0&&(r.log("stream unwrapped with %d unread bytes",n.byteLength),r.push(n))),r}};return f}function cd(r,e={}){let t=ad(r,e);e.maxDataLength!=null&&e.maxLengthLength==null&&(e.maxLengthLength=xe(e.maxDataLength));let n=e?.lengthDecoder??jt,o=e?.lengthEncoder??pi;return{async read(i){let a=-1,c=new te;for(;;){let u=await t.read({...i,bytes:1});if(u==null)break;c.append(u);try{a=n(c)}catch(l){if(l instanceof RangeError)continue;throw l}if(a<0)throw new si("Invalid message length");if(e?.maxLengthLength!=null&&c.byteLength>e.maxLengthLength)throw new ai(`Message length length too long - ${c.byteLength} > ${e.maxLengthLength}`);if(a>-1)break}if(e?.maxDataLength!=null&&a>e.maxDataLength)throw new ii(`Message length too long - ${a} > ${e.maxDataLength}`);let f=await t.read({...i,bytes:a});if(f==null)throw r.log.error("tried to read %d bytes but the stream closed",a),new At(`Unexpected EOF - tried to read ${a} bytes but the stream closed`);if(f.byteLength!==a)throw r.log.error("read %d/%d bytes before the stream closed",f.byteLength,a),new At(`Unexpected EOF - read ${f.byteLength}/${a} bytes before the stream closed`);return f},async write(i,a){await t.write(new te(o(i.byteLength),i),a)},async writeV(i,a){let c=new te(...i.flatMap(f=>[o(f.byteLength),f]));await t.write(c,a)},unwrap(){return t.unwrap()}}}function ci(r,e){let t=cd(r,e),n={read:async(o,s)=>{let i=await t.read(s);return o.decode(i)},write:async(o,s,i)=>{await t.write(s.encode(o),i)},writeV:async(o,s,i)=>{await t.writeV(o.map(a=>s.encode(a)),i)},pb:o=>({read:async s=>n.read(o,s),write:async(s,i)=>n.write(s,o,i),writeV:async(s,i)=>n.writeV(s,o,i),unwrap:()=>n}),unwrap:()=>t.unwrap()};return n}var ui=class extends jn{socket;constructor(e){let t=e.remoteAddr;if(e.localAddr!=null&&Fn.matches(e.localAddr))t=e.localAddr;else if(t==null){if(e.socket.remoteAddress==null||e.socket.remotePort==null)throw new D("Could not determine remote address or port");t=Rc(e.socket.remoteAddress,e.socket.remotePort)}super({...e,remoteAddr:t}),this.socket=e.socket,this.socket.on("data",n=>{this.onData(n)}),this.socket.on("error",n=>{this.log("tcp error",t,n),this.abort(n)}),this.socket.setTimeout(e.inactivityTimeout??120*1e3),this.socket.once("timeout",()=>{this.log("tcp timeout",t),this.abort(new Nt)}),this.socket.once("end",()=>{this.log("tcp end",t),this.onTransportClosed()}),this.socket.once("close",n=>{if(this.log("tcp close",t),n){this.abort(new Error("TCP transmission error"));return}this.onTransportClosed()}),this.socket.on("drain",()=>{this.log("tcp drain"),this.safeDispatchEvent("drain")})}sendData(e){let t=0,n=!0;for(let o of e)if(t+=o.byteLength,n=this.socket.write(o),!n)break;return{sentBytes:t,canSendMore:n}}async sendClose(e){this.socket.destroyed||(this.socket.destroySoon(),await qe(this.socket,"close",e))}sendReset(){this.socket.resetAndDestroy()}sendPause(){this.socket.pause()}sendResume(){this.socket.resume()}},eo=r=>new ui(r);var kc=Ae(ie("os"),1),Uc=Ae(ie("path"),1);function to(r,e={}){if(Fn.exactMatch(r)){let s=r.getComponents().find(i=>i.code===400)?.value;if(s==null)throw new D(`Multiaddr ${r} was not a Unix address`);return kc.default.platform()==="win32"?{path:Uc.default.join("\\\\.\\pipe\\",s)}:{path:s}}let t=zn(r),n=t.host,o=t.port;return{host:n,port:o,ipv6Only:t.type==="ip6",...e}}var le;(function(r){r[r.INACTIVE=0]="INACTIVE",r[r.ACTIVE=1]="ACTIVE",r[r.PAUSED=2]="PAUSED"})(le||(le={}));var ro=class extends Ut{context;server;sockets=new Set;status={code:le.INACTIVE};metrics;addr;log;shutdownController;constructor(e){if(super(),this.context=e,e.keepAlive=e.keepAlive??!0,e.noDelay=e.noDelay??!0,e.allowHalfOpen=e.allowHalfOpen??!1,this.shutdownController=new AbortController,en(1/0,this.shutdownController.signal),this.log=e.logger.forComponent("libp2p:tcp:listener"),this.addr="unknown",this.server=Mc.default.createServer(e,this.onSocket.bind(this)),e.maxConnections!==void 0&&(this.server.maxConnections=e.maxConnections),e.closeServerOnMaxConnections!=null&&e.closeServerOnMaxConnections.closeAbove<e.closeServerOnMaxConnections.listenBelow)throw new D("closeAbove must be >= listenBelow");e.metrics?.registerMetricGroup("libp2p_tcp_inbound_connections_total",{label:"address",help:"Current active connections in TCP listener",calculate:()=>({[this.addr]:this.sockets.size})}),this.metrics={status:e.metrics?.registerMetricGroup("libp2p_tcp_listener_status_info",{label:"address",help:"Current status of the TCP listener socket"}),errors:e.metrics?.registerMetricGroup("libp2p_tcp_listener_errors_total",{label:"address",help:"Total count of TCP listener errors by type"}),events:e.metrics?.registerMetricGroup("libp2p_tcp_listener_events_total",{label:"address",help:"Total count of TCP listener events by type"})},this.server.on("listening",()=>{let t=this.server.address();t==null?this.addr="unknown":typeof t=="string"?this.addr=t:this.addr=`${t.address}:${t.port}`,this.metrics.status?.update({[this.addr]:le.ACTIVE}),this.safeDispatchEvent("listening")}).on("error",t=>{this.metrics.errors?.increment({[`${this.addr} listen_error`]:!0}),this.safeDispatchEvent("error",{detail:t})}).on("close",()=>{this.metrics.status?.update({[this.addr]:this.status.code}),this.status.code!==le.PAUSED&&this.safeDispatchEvent("close")}).on("drop",()=>{this.metrics.events?.increment({[`${this.addr} drop`]:!0})})}onSocket(e){if(this.metrics.events?.increment({[`${this.addr} connection`]:!0}),this.status.code!==le.ACTIVE)throw e.destroy(),new Yr("Server is not listening yet");let t;try{t=eo({socket:e,inactivityTimeout:this.context.inactivityTimeout,metrics:this.metrics?.events,metricPrefix:`${this.addr} `,direction:"inbound",localAddr:this.status.listeningAddr,log:this.context.logger.forComponent("libp2p:tcp:connection")})}catch(n){this.log.error("inbound connection failed - %e",n),this.metrics.errors?.increment({[`${this.addr} inbound_to_connection`]:!0}),e.destroy();return}this.log("new inbound connection %s",t.remoteAddr),this.sockets.add(e),this.context.upgrader.upgradeInbound(t,{signal:this.shutdownController.signal}).then(()=>{this.log("inbound connection upgraded %s",t.remoteAddr),e.once("close",()=>{this.sockets.delete(e),this.context.closeServerOnMaxConnections!=null&&this.sockets.size<this.context.closeServerOnMaxConnections.listenBelow&&this.resume().catch(n=>{this.log.error("error attempting to listen server once connection count under limit - %e",n),this.context.closeServerOnMaxConnections?.onListenError?.(n)})}),this.context.closeServerOnMaxConnections!=null&&this.sockets.size>=this.context.closeServerOnMaxConnections.closeAbove&&(this.log("pausing incoming connections as limit is exceeded - %d/%d",this.sockets.size,this.context.closeServerOnMaxConnections.closeAbove),this.pause())}).catch(async n=>{this.log.error("inbound connection upgrade failed - %e",n),this.metrics.errors?.increment({[`${this.addr} inbound_upgrade`]:!0}),this.sockets.delete(e),t.abort(n)})}getAddrs(){if(this.status.code===le.INACTIVE)return[];let e=this.server.address();return e==null?[]:typeof e=="string"?[Be(`/unix/${encodeURIComponent(e)}`)]:Nc(this.status.listeningAddr,e.port)}updateAnnounceAddrs(){}async listen(e){if(this.status.code===le.ACTIVE||this.status.code===le.PAUSED)throw new Zr("server is already listening");try{this.status={code:le.ACTIVE,listeningAddr:e,netConfig:to(e,this.context)},await this.resume()}catch(t){throw this.status={code:le.INACTIVE},t}}async close(e){let t=[];this.server.listening&&t.push(qe(this.server,"close",e)),this.pause(!0),this.shutdownController.abort(),this.sockets.forEach(n=>{n.readable&&(t.push(qe(n,"close",e)),n.destroy())}),await Promise.all(t)}async resume(){if(this.server.listening||this.status.code===le.INACTIVE)return;let e=this.status.netConfig;await new Promise((t,n)=>{this.server.once("error",n),this.server.listen(e,t)}),this.status={...this.status,code:le.ACTIVE},this.log("listening on %s",this.server.address())}pause(e=!1){if(!this.server.listening&&this.status.code===le.PAUSED&&e){this.status={code:le.INACTIVE};return}!this.server.listening||this.status.code!==le.ACTIVE||(this.log("%s server on %s",e?"closing":"pausing",this.server.address()),this.status=e?{code:le.INACTIVE}:{...this.status,code:le.PAUSED},this.server.close())}};var no=class{opts;metrics;components;log;constructor(e,t={}){this.log=e.logger.forComponent("libp2p:tcp"),this.opts=t,this.components=e,e.metrics!=null&&(this.metrics={events:e.metrics.registerCounterGroup("libp2p_tcp_dialer_events_total",{label:"event",help:"Total count of TCP dialer events by type"}),errors:e.metrics.registerCounterGroup("libp2p_tcp_dialer_errors_total",{label:"event",help:"Total count of TCP dialer events by type"})})}[qi]=!0;[Symbol.toStringTag]="@libp2p/tcp";[Zi]=["@libp2p/transport"];async dial(e,t){t.keepAlive=t.keepAlive??!0,t.noDelay=t.noDelay??!0,t.allowHalfOpen=t.allowHalfOpen??!1;let n=await this._connect(e,t),o;try{o=eo({socket:n,inactivityTimeout:this.opts.outboundSocketInactivityTimeout,metrics:this.metrics?.events,direction:"outbound",remoteAddr:e,log:this.log.newScope("connection")})}catch(s){throw this.metrics?.errors.increment({outbound_to_connection:!0}),n.destroy(s),s}try{return this.log("new outbound connection %s",o.remoteAddr),await t.upgrader.upgradeOutbound(o,t)}catch(s){throw this.metrics?.errors.increment({outbound_upgrade:!0}),this.log.error("error upgrading outbound connection - %e",s),o.abort(s),s}}async _connect(e,t){t.signal.throwIfAborted(),t.onProgress?.(new Gn("tcp:open-connection"));let n;return new Promise((o,s)=>{let i=Date.now(),a=to(e,{...this.opts.dialOpts??{},...t});this.log("dialing %a with opts %o",e,a),n=Kc.default.connect(a);let c=d=>{this.log.error("dial to %a errored - %e",e,d);let g=a.path??`${a.host??""}:${a.port}`;d.message=`connection error ${g}: ${d.message}`,this.metrics?.events.increment({error:!0}),p(d)},f=()=>{this.log("connection timeout %a",e),this.metrics?.events.increment({timeout:!0});let d=new Nt(`Connection timeout after ${Date.now()-i}ms`);n.emit("error",d)},u=()=>{this.log("connection opened %a",e),this.metrics?.events.increment({connect:!0}),p()},l=()=>{this.log("connection aborted %a",e),this.metrics?.events.increment({abort:!0}),p(new Gr)},p=d=>{if(n.removeListener("error",c),n.removeListener("timeout",f),n.removeListener("connect",u),t.signal!=null&&t.signal.removeEventListener("abort",l),d!=null){s(d);return}o(n)};n.on("error",c),n.on("timeout",f),n.on("connect",u),t.signal.addEventListener("abort",l)}).catch(o=>{throw n?.destroy(),o})}createListener(e){return new ro({...this.opts.listenOpts??{},...e,maxConnections:this.opts.maxConnections,backlog:this.opts.backlog,closeServerOnMaxConnections:this.opts.closeServerOnMaxConnections,inactivityTimeout:this.opts.inboundSocketInactivityTimeout,metrics:this.components.metrics,logger:this.components.logger})}listenFilter(e){return e.filter(t=>Ic.exactMatch(t)||t.toString().startsWith("/unix/"))}dialFilter(e){return this.listenFilter(e)}};function $c(r={}){return e=>new no(e,r)}var ud=Kt("libp2p:daemon-client:dht"),oo=class{client;constructor(e){this.client=e}async put(e,t){if(!(e instanceof Uint8Array))throw new D("invalid key received");if(!(t instanceof Uint8Array))throw new D("value received is not a Uint8Array");let n=await this.client.send({type:H.Type.DHT,dht:{type:Ne.Type.PUT_VALUE,key:e,value:t}}),o=await n.read(B);if(ud("read",o),await n.unwrap().close(),o.type!==B.Type.OK)throw new ur(o.error?.msg??"DHT put failed")}async get(e){if(!(e instanceof Uint8Array))throw new D("invalid key received");let t=await this.client.send({type:H.Type.DHT,dht:{type:Ne.Type.GET_VALUE,key:e}}),n=await t.read(B);if(await t.unwrap().close(),n.type!==B.Type.OK)throw new F(n.error?.msg??"DHT get failed");if(n.dht?.value==null)throw new F("Invalid DHT get response");return n.dht.value}async findPeer(e){if(!kt(e))throw new D("invalid peer id received");let t=await this.client.send({type:H.Type.DHT,dht:{type:Ne.Type.FIND_PEER,peer:e.toMultihash().bytes}}),n=await t.read(B);if(await t.unwrap().close(),n.type!==B.Type.OK)throw new F(n.error?.msg??"DHT find peer failed");if(n.dht?.peer?.addrs==null)throw new F("Invalid response");return{id:et(Pe(n.dht.peer.id)),multiaddrs:n.dht.peer.addrs.map(o=>Be(o))}}async provide(e){if(e==null||ae.asCID(e)==null)throw new D("invalid cid received");let t=await this.client.send({type:H.Type.DHT,dht:{type:Ne.Type.PROVIDE,cid:e.bytes}}),n=await t.read(B);if(await t.unwrap().close(),n.type!==B.Type.OK)throw new F(n.error?.msg??"DHT provide failed")}async*findProviders(e,t=1){if(e==null||ae.asCID(e)==null)throw new D("invalid cid received");let n=await this.client.send({type:H.Type.DHT,dht:{type:Ne.Type.FIND_PROVIDERS,cid:e.bytes,count:t}}),o=await n.read(B);if(o.type!==B.Type.OK)throw await n.unwrap().close(),new F(o.error?.msg??"DHT find providers failed");for(;;){let s=await n.read(Ke);if(s.type===Ke.Type.END){await n.unwrap().close();return}if(s.type===Ke.Type.VALUE&&s.peer?.addrs!=null)yield{id:et(Pe(s.peer.id)),multiaddrs:s.peer.addrs.map(i=>Be(i))};else throw await n.unwrap().close(),new ur("unexpected message received")}}async*getClosestPeers(e){if(!(e instanceof Uint8Array))throw new D("invalid key received");let t=await this.client.send({type:H.Type.DHT,dht:{type:Ne.Type.GET_CLOSEST_PEERS,key:e}}),n=await t.read(B);if(n.type!==B.Type.OK)throw await t.unwrap().close(),new F(n.error?.msg??"DHT find providers failed");for(;;){let o=await t.read(Ke);if(o.type===Ke.Type.END){await t.unwrap().close();return}if(o.type===Ke.Type.VALUE&&o.value!=null)yield{id:et(Pe(o.value)),multiaddrs:[]};else throw await t.unwrap().close(),new cr("unexpected message received")}}async getPublicKey(e){if(!kt(e))throw new D("invalid peer id received");let t=await this.client.send({type:H.Type.DHT,dht:{type:Ne.Type.GET_PUBLIC_KEY,peer:e.toMultihash().bytes}}),n=await t.read(B);if(await t.unwrap().close(),n.type!==B.Type.OK)throw new F(n.error?.msg??"DHT get public key failed");if(n.dht==null)throw new cr("Invalid response");return n.dht.value}};var so=class{client;constructor(e){this.client=e}async getTopics(){let e=await this.client.send({type:H.Type.PUBSUB,pubsub:{type:Xe.Type.GET_TOPICS}}),t=await e.read(B);if(await e.unwrap().close(),t.type!==B.Type.OK)throw new F(t.error?.msg??"Pubsub get topics failed");if(t.pubsub?.topics==null)throw new F("Invalid response");return t.pubsub.topics}async publish(e,t){if(typeof e!="string")throw new D("invalid topic received");if(!(t instanceof Uint8Array))throw new D("data received is not a Uint8Array");let n=await this.client.send({type:H.Type.PUBSUB,pubsub:{type:Xe.Type.PUBLISH,topic:e,data:t}}),o=await n.read(B);if(await n.unwrap().close(),o.type!==B.Type.OK)throw new F(o.error?.msg??"Pubsub publish failed")}async subscribe(e){if(typeof e!="string")throw new D("invalid topic received");let t=await this.client.send({type:H.Type.PUBSUB,pubsub:{type:Xe.Type.SUBSCRIBE,topic:e}}),n=await t.read(B);if(n.type!==B.Type.OK)throw new F(n.error?.msg??"Pubsub publish failed");let o=!0;return{async*messages(){for(;o;)yield await t.read($r)},async cancel(){o=!1,await t.unwrap().close()}}}async getSubscribers(e){if(typeof e!="string")throw new D("invalid topic received");let t=await this.client.send({type:H.Type.PUBSUB,pubsub:{type:Xe.Type.LIST_PEERS,topic:e}}),n=await t.read(B);if(await t.unwrap().close(),n.type!==B.Type.OK)throw new F(n.error?.msg??"Pubsub get subscribers failed");if(n.pubsub?.topics==null)throw new F("Invalid response");return n.pubsub.peerIDs.map(o=>et(Pe(o)))}};var ut=Kt("libp2p:daemon-client"),F=class extends Error{constructor(e="Operation failed"){super(e),this.name="OperationFailedError"}},li=class{multiaddr;dht;pubsub;tcp;constructor(e){this.multiaddr=e,this.tcp=$c()({logger:oa()}),this.dht=new oo(this),this.pubsub=new so(this)}async connectDaemon(e){return this.tcp.dial(this.multiaddr,{upgrader:new ir,signal:e??AbortSignal.timeout(1e4)})}async send(e){let t=await this.connectDaemon(),n=e.pubsub?.type??e.dht?.type??e.peerStore?.type??"";ut("send",e.type,n);let o=ci(t);return await o.write(e,H),o}async connect(e,t){if(!kt(e))throw new D("invalid peer id received");if(!Array.isArray(t))throw new D("addrs received are not in an array");t.forEach(s=>{if(!Un(s))throw new D("received an address that is not a multiaddr")});let n=await this.send({type:H.Type.CONNECT,connect:{peer:e.toMultihash().bytes,addrs:t.map(s=>s.bytes)}}),o=await n.read(B);if(ut("%s response %s",H.Type.CONNECT,o.type),o.type!==B.Type.OK){let s=o.error??{msg:"unspecified"};throw new F(s.msg??"unspecified")}await n.unwrap().close()}async identify(){let e=await this.send({type:H.Type.IDENTIFY}),t=await e.read(B);if(ut("%s response %s",H.Type.IDENTIFY,t.type),t.type!==B.Type.OK)throw new F(t.error?.msg??"Identify failed");if(t.identify?.addrs==null)throw new F("Invalid response");let n=et(Pe(t.identify?.id)),o=t.identify.addrs.map(s=>Be(s));return await e.unwrap().close(),{peerId:n,addrs:o}}async listPeers(){let e=await this.send({type:H.Type.LIST_PEERS}),t=await e.read(B);if(ut("%s response %s",H.Type.LIST_PEERS,t.type),t.type!==B.Type.OK)throw new F(t.error?.msg??"List peers failed");return await e.unwrap().close(),t.peers.map(n=>et(Pe(n.id)))}async openStream(e,t){if(!kt(e))throw new D("invalid peer id received");if(typeof t!="string")throw new D("invalid protocol received");let n=await this.send({type:H.Type.STREAM_OPEN,streamOpen:{peer:e.toMultihash().bytes,proto:[t]}}),o=await n.read(B);if(ut("%s response %s",H.Type.STREAM_OPEN,o.type),o.type!==B.Type.OK){let s=new F(o.error?.msg??"Open stream failed");throw n.unwrap().abort(s),s}return n.unwrap()}async registerStreamHandler(e,t){if(typeof e!="string")throw new D("invalid protocol received");let n=this.tcp.createListener({upgrader:new ir(a=>{this.onConnection(e,n,t,a)})});await n.listen(Be("/ip4/127.0.0.1/tcp/0"));let o=n.getAddrs()[0];if(o==null)throw new F("Could not listen on port");let s=await this.send({type:H.Type.STREAM_HANDLER,streamHandler:{addr:o.bytes,proto:[e]}}),i=await s.read(B);if(ut("%s response %s",H.Type.STREAM_HANDLER,i.type),await s.unwrap().close(),i.type!==B.Type.OK)throw new F(i.error?.msg??"Register stream handler failed")}onConnection(e,t,n,o){Promise.resolve().then(async()=>{let s=ci(o).pb(Pt);if((await s.read()).proto!==e)throw new F("Incorrect protocol");await n(s.unwrap().unwrap())}).catch(s=>{o.abort(s)}).finally(()=>{o.close().catch(s=>{ut.error("error closing connection - %e",s)}),t.close().catch(s=>{ut.error("error closing listener - %e",s)})})}};function ld(r){return new li(r)}return Wc(fd);})();
17
17
  /*! Bundled license information: