@helia/http 3.1.2-210059d3 → 3.1.2-eb1908b3
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/index.min.js +1 -1
- package/dist/index.min.js.map +2 -2
- package/package.json +5 -5
package/dist/index.min.js
CHANGED
|
@@ -29,7 +29,7 @@ ${e}[Error list was empty]`,t.trim()}return u1(r,e)}Pt.formatters.e=r=>r==null?"
|
|
|
29
29
|
HTTP/1.1 %d %s
|
|
30
30
|
%s
|
|
31
31
|
`,d.status,d.statusText,[...d.headers.entries()].map(([m,y])=>`${m}: ${y}`).join(`
|
|
32
|
-
`)),!d.ok)throw this.#t++,new Error(`Unable to fetch raw block for CID ${e} from gateway ${this.url}, received ${d.status} ${d.statusText}`);t.onProgress?.(new $("helia:block-broker:connected",{broker:"trustless-gateway",type:"connected",provider:this.peer,address:zd(n.toString()),cid:e})),t.onProgress?.(new $("helia:block-broker:request-block",{broker:"trustless-gateway",type:"request-block",provider:this.peer,cid:e}));let h=await FS(d,o,{signal:s.signal,log:this.log});return t.onProgress?.(new $("helia:block-broker:receive-block",{broker:"trustless-gateway",type:"receive-block",provider:this.peer,cid:e})),this.#a++,h}),this.#c.set(i,c)}return await c}catch(c){throw signal?.aborted===!0?new Error(`Fetching raw block for CID ${e} from gateway ${this.url} was aborted`):(this.#t++,new Error(`Unable to fetch raw block for CID ${e} - ${c.message}`))}finally{t.signal?.removeEventListener("abort",a),this.#c.delete(i)}}reliability(){return this.#e===0?1:this.#r>0?-1/0:this.#a/(this.#e+this.#t*3)}incrementInvalidBlocks(){this.#r++}getStats(){return{attempts:this.#e,errors:this.#t,invalidBlocks:this.#r,successes:this.#a,pendingResponses:this.#c.size}}toString(){return`TrustlessGateway(${this.url})`}};var bw=class extends iu{name="trustless-gateway-session";routing;allowInsecure;allowLocal;transformRequestInit;constructor(e,t){super(e,{...t,name:"helia:trustless-gateway:session"}),this.routing=e.routing,this.allowInsecure=t.allowInsecure??Jd,this.allowLocal=t.allowLocal??Qd,this.transformRequestInit=t.transformRequestInit}async queryProvider(e,t,n){this.log("fetching BLOCK for %c from %s",e,t.url),n?.onProgress?.(new $("helia:block-brokers:query-provider:start",{blockBroker:"trustless-gateway",provider:t.url,transport:"http",cid:e}));let o;try{o=await t.getRawBlock(e,n),this.log.trace("got block for %c from %s",e,t.url)}finally{n?.onProgress?.(new $("helia:block-brokers:query-provider:end",{blockBroker:"trustless-gateway",provider:t.url,transport:"http",cid:e}))}return await n.validateFn?.(o),o}async*findNewProviders(e,t={}){yield*Zd(e,this.routing,this.logger,this.allowInsecure,this.allowLocal,{...t,transformRequestInit:this.transformRequestInit})}toFilterKey(e){return e.url.toString()}equals(e,t){return e.url.toString()===t.url.toString()}async convertToProvider(e,t,n){if(nr(e))return;let o=ww(Array.isArray(e)?e:[e],this.allowInsecure,this.allowLocal);if(o.length===0)return;let i=qd(o[0]);return new ra(i,{logger:this.logger,transformRequestInit:this.transformRequestInit,routing:t})}emitFoundProviderProgressEvent(e,t,n){n?.onProgress?.(new $("trustless-gateway:found-provider",{type:"trustless-gateway",cid:e,url:t.url.toJSON(),routing:t.routing}))}};function VS(r,e){return new bw(r,e)}var eh=class{name="trustless-gateway";allowInsecure;allowLocal;transformRequestInit;routing;log;logger;constructor(e,t={}){this.log=e.logger.forComponent("helia:trustless-gateway-block-broker"),this.logger=e.logger,this.routing=e.routing,this.allowInsecure=t.allowInsecure??Jd,this.allowLocal=t.allowLocal??Qd,this.transformRequestInit=t.transformRequestInit}async retrieve(e,t={}){let n=[];for await(let o of Zd(e,this.routing,this.logger,this.allowInsecure,this.allowLocal,{...t,transformRequestInit:this.transformRequestInit})){this.log("getting block for %c from %s",e,o.url);try{let i=await o.getRawBlock(e,t);this.log.trace("got block for %c from %s",e,o.url);try{await t.validateFn?.(i)}catch(s){this.log.error("failed to validate block for %c from %s - %e",e,o.url,s);continue}return i}catch(i){if(this.log.error("failed to get block for %c from %s - %e",e,o.url,i),i instanceof Error?n.push(i):n.push(new Error(`Unable to fetch raw block for CID ${e} from gateway ${o.url}`)),t.signal?.aborted===!0){this.log.trace("request aborted while fetching raw block for CID %c from gateway %s",e,o.url);break}}}throw n.length>0?new AggregateError(n,`Unable to fetch raw block for CID ${e} from any gateway`):new Error(`Unable to fetch raw block for CID ${e} from any gateway`)}createSession(e={}){return VS({logger:this.logger,routing:this.routing},{...e,allowLocal:this.allowLocal,allowInsecure:this.allowInsecure,transformRequestInit:this.transformRequestInit})}};var Jd=!1,Qd=!1,$S=2097152;function xw(r={}){return e=>new eh(e,r)}async function*uu(r,e={}){let t=r.getReader();try{for(;;){let n=await t.read();if(n.done)return;yield n.value}}finally{e.preventCancel!==!0&&await t.cancel(),t.releaseLock()}}var xP=Ro(vw(),1);var Jr=class extends Error{static name="SignatureVerificationError";constructor(e="Record signature verification failed"){super(e),this.name="SignatureVerificationError"}},th=class extends Error{static name="RecordExpiredError";constructor(e="Record has expired"){super(e),this.name="RecordExpiredError"}},na=class extends Error{static name="UnsupportedValidityError";constructor(e="The validity type is unsupported"){super(e),this.name="UnsupportedValidityError"}},rh=class extends Error{static name="RecordTooLargeError";constructor(e="The record is too large"){super(e),this.name="RecordTooLargeError"}},nh=class extends Error{static name="InvalidValueError";constructor(e="Value must be a valid content path starting with /"){super(e),this.name="InvalidValueError"}},oh=class extends Error{static name="InvalidRecordDataError";constructor(e="Invalid record data"){super(e),this.name="InvalidRecordDataError"}},lu=class extends Error{static name="InvalidEmbeddedPublicKeyError";constructor(e="Invalid embedded public key"){super(e),this.name="InvalidEmbeddedPublicKeyError"}};var Qr;(function(r){let e;(function(a){a.EOL="EOL"})(e=r.ValidityType||(r.ValidityType={}));let t;(function(a){a[a.EOL=0]="EOL"})(t||(t={})),(function(a){a.codec=()=>Za(t)})(e=r.ValidityType||(r.ValidityType={}));let n;r.codec=()=>(n==null&&(n=ft((a,c,u={})=>{u.lengthDelimited!==!1&&c.fork(),a.value!=null&&(c.uint32(10),c.bytes(a.value)),a.signatureV1!=null&&(c.uint32(18),c.bytes(a.signatureV1)),a.validityType!=null&&(c.uint32(24),r.ValidityType.codec().encode(a.validityType,c)),a.validity!=null&&(c.uint32(34),c.bytes(a.validity)),a.sequence!=null&&(c.uint32(40),c.uint64(a.sequence)),a.ttl!=null&&(c.uint32(48),c.uint64(a.ttl)),a.pubKey!=null&&(c.uint32(58),c.bytes(a.pubKey)),a.signatureV2!=null&&(c.uint32(66),c.bytes(a.signatureV2)),a.data!=null&&(c.uint32(74),c.bytes(a.data)),u.lengthDelimited!==!1&&c.ldelim()},(a,c,u={})=>{let l={},f=c==null?a.len:a.pos+c;for(;a.pos<f;){let d=a.uint32();switch(d>>>3){case 1:{l.value=a.bytes();break}case 2:{l.signatureV1=a.bytes();break}case 3:{l.validityType=r.ValidityType.codec().decode(a);break}case 4:{l.validity=a.bytes();break}case 5:{l.sequence=a.uint64();break}case 6:{l.ttl=a.uint64();break}case 7:{l.pubKey=a.bytes();break}case 8:{l.signatureV2=a.bytes();break}case 9:{l.data=a.bytes();break}default:{a.skipType(d&7);break}}}return l},function*(a,c,u,l={}){let f=c==null?a.len:a.pos+c;for(;a.pos<f;){let d=a.uint32();switch(d>>>3){case 1:{yield{field:`${u}.value`,value:a.bytes()};break}case 2:{yield{field:`${u}.signatureV1`,value:a.bytes()};break}case 3:{yield{field:`${u}.validityType`,value:r.ValidityType.codec().decode(a)};break}case 4:{yield{field:`${u}.validity`,value:a.bytes()};break}case 5:{yield{field:`${u}.sequence`,value:a.uint64()};break}case 6:{yield{field:`${u}.ttl`,value:a.uint64()};break}case 7:{yield{field:`${u}.pubKey`,value:a.bytes()};break}case 8:{yield{field:`${u}.signatureV2`,value:a.bytes()};break}case 9:{yield{field:`${u}.data`,value:a.bytes()};break}default:{a.skipType(d&7);break}}}})),n);function o(a){return ut(a,r.codec())}r.encode=o;function i(a,c){return ct(a,r.codec(),c)}r.decode=i;function s(a,c){return lt(a,r.codec(),c)}r.stream=s})(Qr||(Qr={}));var F3=["Object","RegExp","Date","Error","Map","Set","WeakMap","WeakSet","ArrayBuffer","SharedArrayBuffer","DataView","Promise","URL","HTMLElement","Int8Array","Uint8ClampedArray","Int16Array","Uint16Array","Int32Array","Uint32Array","Float32Array","Float64Array","BigInt64Array","BigUint64Array","Tagged"];function KS(r){if(r===null)return"null";if(r===void 0)return"undefined";if(r===!0||r===!1)return"boolean";let e=typeof r;if(e==="string"||e==="number"||e==="bigint"||e==="symbol")return e;if(e==="function")return"Function";if(Array.isArray(r))return"Array";if(r instanceof Uint8Array)return"Uint8Array";if(r.constructor===Object)return"Object";let t=$3(r);return t||"Object"}function $3(r){let e=Object.prototype.toString.call(r).slice(8,-1);if(F3.includes(e))return e}var v=class{constructor(e,t,n){this.major=e,this.majorEncoded=e<<5,this.name=t,this.terminal=n}toString(){return`Type[${this.major}].${this.name}`}compare(e){return this.major<e.major?-1:this.major>e.major?1:0}static equals(e,t){return e===t||e.major===t.major&&e.name===t.name}};v.uint=new v(0,"uint",!0);v.negint=new v(1,"negint",!0);v.bytes=new v(2,"bytes",!0);v.string=new v(3,"string",!0);v.array=new v(4,"array",!1);v.map=new v(5,"map",!1);v.tag=new v(6,"tag",!1);v.float=new v(7,"float",!0);v.false=new v(7,"false",!0);v.true=new v(7,"true",!0);v.null=new v(7,"null",!0);v.undefined=new v(7,"undefined",!0);v.break=new v(7,"break",!0);var G=class{constructor(e,t,n){this.type=e,this.value=t,this.encodedLength=n,this.encodedBytes=void 0,this.byteValue=void 0}toString(){return`Token[${this.type}].${this.value}`}};var fu=globalThis.process&&!globalThis.process.browser&&globalThis.Buffer&&typeof globalThis.Buffer.isBuffer=="function",V3=new TextEncoder;function ih(r){return fu&&globalThis.Buffer.isBuffer(r)}function du(r){return r instanceof Uint8Array?ih(r)?new Uint8Array(r.buffer,r.byteOffset,r.byteLength):r:Uint8Array.from(r)}var K3=24,q3=200,Aw=fu?r=>r.length>=K3?globalThis.Buffer.from(r):qS(r):r=>r.length>=q3?V3.encode(r):qS(r),wn=r=>Uint8Array.from(r),HS=fu?(r,e,t)=>ih(r)?new Uint8Array(r.subarray(e,t)):r.slice(e,t):(r,e,t)=>r.slice(e,t),zS=fu?(r,e)=>(r=r.map(t=>t instanceof Uint8Array?t:globalThis.Buffer.from(t)),du(globalThis.Buffer.concat(r,e))):(r,e)=>{let t=new Uint8Array(e),n=0;for(let o of r)n+o.length>t.length&&(o=o.subarray(0,t.length-n)),t.set(o,n),n+=o.length;return t},jS=fu?r=>globalThis.Buffer.allocUnsafe(r):r=>new Uint8Array(r);function sh(r,e){if(ih(r)&&ih(e))return r.compare(e);for(let t=0;t<r.length;t++)if(r[t]!==e[t])return r[t]<e[t]?-1:1;return 0}function qS(r){let e=[],t=0;for(let n=0;n<r.length;n++){let o=r.charCodeAt(n);o<128?e[t++]=o:o<2048?(e[t++]=o>>6|192,e[t++]=o&63|128):(o&64512)===55296&&n+1<r.length&&(r.charCodeAt(n+1)&64512)===56320?(o=65536+((o&1023)<<10)+(r.charCodeAt(++n)&1023),e[t++]=o>>18|240,e[t++]=o>>12&63|128,e[t++]=o>>6&63|128,e[t++]=o&63|128):(o>=55296&&o<=57343&&(o=65533),e[t++]=o>>12|224,e[t++]=o>>6&63|128,e[t++]=o&63|128)}return e}var H3=256,hu=class{constructor(e=H3){this.chunkSize=e,this.cursor=0,this.maxCursor=-1,this.chunks=[],this._initReuseChunk=null}reset(){this.cursor=0,this.maxCursor=-1,this.chunks.length&&(this.chunks=[]),this._initReuseChunk!==null&&(this.chunks.push(this._initReuseChunk),this.maxCursor=this._initReuseChunk.length-1)}push(e){let t=this.chunks[this.chunks.length-1];if(this.cursor+e.length<=this.maxCursor+1){let o=t.length-(this.maxCursor-this.cursor)-1;t.set(e,o)}else{if(t){let o=t.length-(this.maxCursor-this.cursor)-1;o<t.length&&(this.chunks[this.chunks.length-1]=t.subarray(0,o),this.maxCursor=this.cursor-1)}e.length<64&&e.length<this.chunkSize?(t=jS(this.chunkSize),this.chunks.push(t),this.maxCursor+=t.length,this._initReuseChunk===null&&(this._initReuseChunk=t),t.set(e,0)):(this.chunks.push(e),this.maxCursor+=e.length)}this.cursor+=e.length}toBytes(e=!1){let t;if(this.chunks.length===1){let n=this.chunks[0];e&&this.cursor>n.length/2?(t=this.cursor===n.length?n:n.subarray(0,this.cursor),this._initReuseChunk=null,this.chunks=[]):t=HS(n,0,this.cursor)}else t=zS(this.chunks,this.cursor);return e&&this.reset(),t}},ah=class{constructor(e){this.dest=e,this.cursor=0,this.chunks=[e]}reset(){this.cursor=0}push(e){if(this.cursor+e.length>this.dest.length)throw new Error("write out of bounds, destination buffer is too small");this.dest.set(e,this.cursor),this.cursor+=e.length}toBytes(e=!1){let t=this.dest.subarray(0,this.cursor);return e&&this.reset(),t}};var ne="CBOR decode error:",Sw="CBOR encode error:",pu=[];pu[23]=1;pu[24]=2;pu[25]=3;pu[26]=5;pu[27]=9;function On(r,e,t){if(r.length-e<t)throw new Error(`${ne} not enough data for type`)}var ot=[24,256,65536,4294967296,BigInt("18446744073709551616")];function Qt(r,e,t){On(r,e,1);let n=r[e];if(t.strict===!0&&n<ot[0])throw new Error(`${ne} integer encoded in more bytes than necessary (strict decode)`);return n}function er(r,e,t){On(r,e,2);let n=r[e]<<8|r[e+1];if(t.strict===!0&&n<ot[1])throw new Error(`${ne} integer encoded in more bytes than necessary (strict decode)`);return n}function tr(r,e,t){On(r,e,4);let n=r[e]*16777216+(r[e+1]<<16)+(r[e+2]<<8)+r[e+3];if(t.strict===!0&&n<ot[2])throw new Error(`${ne} integer encoded in more bytes than necessary (strict decode)`);return n}function rr(r,e,t){On(r,e,8);let n=r[e]*16777216+(r[e+1]<<16)+(r[e+2]<<8)+r[e+3],o=r[e+4]*16777216+(r[e+5]<<16)+(r[e+6]<<8)+r[e+7],i=(BigInt(n)<<BigInt(32))+BigInt(o);if(t.strict===!0&&i<ot[3])throw new Error(`${ne} integer encoded in more bytes than necessary (strict decode)`);if(i<=Number.MAX_SAFE_INTEGER)return Number(i);if(t.allowBigInt===!0)return i;throw new Error(`${ne} integers outside of the safe integer range are not supported`)}function GS(r,e,t,n){return new G(v.uint,Qt(r,e+1,n),2)}function WS(r,e,t,n){return new G(v.uint,er(r,e+1,n),3)}function YS(r,e,t,n){return new G(v.uint,tr(r,e+1,n),5)}function XS(r,e,t,n){return new G(v.uint,rr(r,e+1,n),9)}function br(r,e){return it(r,0,e.value)}function it(r,e,t){if(t<ot[0]){let n=Number(t);r.push([e|n])}else if(t<ot[1]){let n=Number(t);r.push([e|24,n])}else if(t<ot[2]){let n=Number(t);r.push([e|25,n>>>8,n&255])}else if(t<ot[3]){let n=Number(t);r.push([e|26,n>>>24&255,n>>>16&255,n>>>8&255,n&255])}else{let n=BigInt(t);if(n<ot[4]){let o=[e|27,0,0,0,0,0,0,0],i=Number(n&BigInt(4294967295)),s=Number(n>>BigInt(32)&BigInt(4294967295));o[8]=i&255,i=i>>8,o[7]=i&255,i=i>>8,o[6]=i&255,i=i>>8,o[5]=i&255,o[4]=s&255,s=s>>8,o[3]=s&255,s=s>>8,o[2]=s&255,s=s>>8,o[1]=s&255,r.push(o)}else throw new Error(`${ne} encountered BigInt larger than allowable range`)}}br.encodedSize=function(e){return it.encodedSize(e.value)};it.encodedSize=function(e){return e<ot[0]?1:e<ot[1]?2:e<ot[2]?3:e<ot[3]?5:9};br.compareTokens=function(e,t){return e.value<t.value?-1:e.value>t.value?1:0};function ZS(r,e,t,n){return new G(v.negint,-1-Qt(r,e+1,n),2)}function JS(r,e,t,n){return new G(v.negint,-1-er(r,e+1,n),3)}function QS(r,e,t,n){return new G(v.negint,-1-tr(r,e+1,n),5)}var kw=BigInt(-1),ek=BigInt(1);function tk(r,e,t,n){let o=rr(r,e+1,n);if(typeof o!="bigint"){let i=-1-o;if(i>=Number.MIN_SAFE_INTEGER)return new G(v.negint,i,9)}if(n.allowBigInt!==!0)throw new Error(`${ne} integers outside of the safe integer range are not supported`);return new G(v.negint,kw-BigInt(o),9)}function ch(r,e){let t=e.value,n=typeof t=="bigint"?t*kw-ek:t*-1-1;it(r,e.type.majorEncoded,n)}ch.encodedSize=function(e){let t=e.value,n=typeof t=="bigint"?t*kw-ek:t*-1-1;return n<ot[0]?1:n<ot[1]?2:n<ot[2]?3:n<ot[3]?5:9};ch.compareTokens=function(e,t){return e.value<t.value?1:e.value>t.value?-1:0};function mu(r,e,t,n){On(r,e,t+n);let o=r.slice(e+t,e+t+n);return new G(v.bytes,o,t+n)}function rk(r,e,t,n){return mu(r,e,1,t)}function nk(r,e,t,n){return mu(r,e,2,Qt(r,e+1,n))}function ok(r,e,t,n){return mu(r,e,3,er(r,e+1,n))}function ik(r,e,t,n){return mu(r,e,5,tr(r,e+1,n))}function sk(r,e,t,n){let o=rr(r,e+1,n);if(typeof o=="bigint")throw new Error(`${ne} 64-bit integer bytes lengths not supported`);return mu(r,e,9,o)}function uh(r){return r.encodedBytes===void 0&&(r.encodedBytes=v.equals(r.type,v.string)?Aw(r.value):r.value),r.encodedBytes}function oa(r,e){let t=uh(e);it(r,e.type.majorEncoded,t.length),r.push(t)}oa.encodedSize=function(e){let t=uh(e);return it.encodedSize(t.length)+t.length};oa.compareTokens=function(e,t){return j3(uh(e),uh(t))};function j3(r,e){return r.length<e.length?-1:r.length>e.length?1:sh(r,e)}var ak=new TextDecoder,W3=32;function Y3(r,e,t){if(t-e<W3){let o="";for(let i=e;i<t;i++){let s=r[i];if(s&128)return ak.decode(r.subarray(e,t));o+=String.fromCharCode(s)}return o}return ak.decode(r.subarray(e,t))}function gu(r,e,t,n,o){let i=t+n;On(r,e,i);let s=new G(v.string,Y3(r,e+t,e+i),i);return o.retainStringBytes===!0&&(s.byteValue=r.slice(e+t,e+i)),s}function ck(r,e,t,n){return gu(r,e,1,t,n)}function uk(r,e,t,n){return gu(r,e,2,Qt(r,e+1,n),n)}function lk(r,e,t,n){return gu(r,e,3,er(r,e+1,n),n)}function fk(r,e,t,n){return gu(r,e,5,tr(r,e+1,n),n)}function dk(r,e,t,n){let o=rr(r,e+1,n);if(typeof o=="bigint")throw new Error(`${ne} 64-bit integer string lengths not supported`);return gu(r,e,9,o,n)}var hk=oa;function ia(r,e,t,n){return new G(v.array,n,t)}function pk(r,e,t,n){return ia(r,e,1,t)}function mk(r,e,t,n){return ia(r,e,2,Qt(r,e+1,n))}function gk(r,e,t,n){return ia(r,e,3,er(r,e+1,n))}function yk(r,e,t,n){return ia(r,e,5,tr(r,e+1,n))}function wk(r,e,t,n){let o=rr(r,e+1,n);if(typeof o=="bigint")throw new Error(`${ne} 64-bit integer array lengths not supported`);return ia(r,e,9,o)}function bk(r,e,t,n){if(n.allowIndefinite===!1)throw new Error(`${ne} indefinite length items not allowed`);return ia(r,e,1,1/0)}function lh(r,e){it(r,v.array.majorEncoded,e.value)}lh.compareTokens=br.compareTokens;lh.encodedSize=function(e){return it.encodedSize(e.value)};function sa(r,e,t,n){return new G(v.map,n,t)}function xk(r,e,t,n){return sa(r,e,1,t)}function Ek(r,e,t,n){return sa(r,e,2,Qt(r,e+1,n))}function vk(r,e,t,n){return sa(r,e,3,er(r,e+1,n))}function Ak(r,e,t,n){return sa(r,e,5,tr(r,e+1,n))}function Sk(r,e,t,n){let o=rr(r,e+1,n);if(typeof o=="bigint")throw new Error(`${ne} 64-bit integer map lengths not supported`);return sa(r,e,9,o)}function kk(r,e,t,n){if(n.allowIndefinite===!1)throw new Error(`${ne} indefinite length items not allowed`);return sa(r,e,1,1/0)}function fh(r,e){it(r,v.map.majorEncoded,e.value)}fh.compareTokens=br.compareTokens;fh.encodedSize=function(e){return it.encodedSize(e.value)};function _k(r,e,t,n){return new G(v.tag,t,1)}function Ik(r,e,t,n){return new G(v.tag,Qt(r,e+1,n),2)}function Tk(r,e,t,n){return new G(v.tag,er(r,e+1,n),3)}function Ck(r,e,t,n){return new G(v.tag,tr(r,e+1,n),5)}function Bk(r,e,t,n){return new G(v.tag,rr(r,e+1,n),9)}function dh(r,e){it(r,v.tag.majorEncoded,e.value)}dh.compareTokens=br.compareTokens;dh.encodedSize=function(e){return it.encodedSize(e.value)};var _w=20,Iw=21,Tw=22,Cw=23;function Nk(r,e,t,n){if(n.allowUndefined===!1)throw new Error(`${ne} undefined values are not supported`);return n.coerceUndefinedToNull===!0?new G(v.null,null,1):new G(v.undefined,void 0,1)}function Pk(r,e,t,n){if(n.allowIndefinite===!1)throw new Error(`${ne} indefinite length items not allowed`);return new G(v.break,void 0,1)}function Bw(r,e,t){if(t){if(t.allowNaN===!1&&Number.isNaN(r))throw new Error(`${ne} NaN values are not supported`);if(t.allowInfinity===!1&&(r===1/0||r===-1/0))throw new Error(`${ne} Infinity values are not supported`)}return new G(v.float,r,e)}function Lk(r,e,t,n){return Bw(Nw(r,e+1),3,n)}function Dk(r,e,t,n){return Bw(Pw(r,e+1),5,n)}function Rk(r,e,t,n){return Bw(Fk(r,e+1),9,n)}function hh(r,e,t){let n=e.value;if(n===!1)r.push([v.float.majorEncoded|_w]);else if(n===!0)r.push([v.float.majorEncoded|Iw]);else if(n===null)r.push([v.float.majorEncoded|Tw]);else if(n===void 0)r.push([v.float.majorEncoded|Cw]);else{let o,i=!1;(!t||t.float64!==!0)&&(Ok(n),o=Nw(en,1),n===o||Number.isNaN(n)?(en[0]=249,r.push(en.slice(0,3)),i=!0):(Mk(n),o=Pw(en,1),n===o&&(en[0]=250,r.push(en.slice(0,5)),i=!0))),i||(eP(n),o=Fk(en,1),en[0]=251,r.push(en.slice(0,9)))}}hh.encodedSize=function(e,t){let n=e.value;if(n===!1||n===!0||n===null||n===void 0)return 1;if(!t||t.float64!==!0){Ok(n);let o=Nw(en,1);if(n===o||Number.isNaN(n))return 3;if(Mk(n),o=Pw(en,1),n===o)return 5}return 9};var Uk=new ArrayBuffer(9),xr=new DataView(Uk,1),en=new Uint8Array(Uk,0);function Ok(r){if(r===1/0)xr.setUint16(0,31744,!1);else if(r===-1/0)xr.setUint16(0,64512,!1);else if(Number.isNaN(r))xr.setUint16(0,32256,!1);else{xr.setFloat32(0,r);let e=xr.getUint32(0),t=(e&2139095040)>>23,n=e&8388607;if(t===255)xr.setUint16(0,31744,!1);else if(t===0)xr.setUint16(0,(e&2147483648)>>16|n>>13,!1);else{let o=t-127;o<-24?xr.setUint16(0,0):o<-14?xr.setUint16(0,(e&2147483648)>>16|1<<24+o,!1):xr.setUint16(0,(e&2147483648)>>16|o+15<<10|n>>13,!1)}}}function Nw(r,e){if(r.length-e<2)throw new Error(`${ne} not enough data for float16`);let t=(r[e]<<8)+r[e+1];if(t===31744)return 1/0;if(t===64512)return-1/0;if(t===32256)return NaN;let n=t>>10&31,o=t&1023,i;return n===0?i=o*2**-24:n!==31?i=(o+1024)*2**(n-25):i=o===0?1/0:NaN,t&32768?-i:i}function Mk(r){xr.setFloat32(0,r,!1)}function Pw(r,e){if(r.length-e<4)throw new Error(`${ne} not enough data for float32`);let t=(r.byteOffset||0)+e;return new DataView(r.buffer,t,4).getFloat32(0,!1)}function eP(r){xr.setFloat64(0,r,!1)}function Fk(r,e){if(r.length-e<8)throw new Error(`${ne} not enough data for float64`);let t=(r.byteOffset||0)+e;return new DataView(r.buffer,t,8).getFloat64(0,!1)}hh.compareTokens=br.compareTokens;function Ee(r,e,t){throw new Error(`${ne} encountered invalid minor (${t}) for major ${r[e]>>>5}`)}function ph(r){return()=>{throw new Error(`${ne} ${r}`)}}var M=[];for(let r=0;r<=23;r++)M[r]=Ee;M[24]=GS;M[25]=WS;M[26]=YS;M[27]=XS;M[28]=Ee;M[29]=Ee;M[30]=Ee;M[31]=Ee;for(let r=32;r<=55;r++)M[r]=Ee;M[56]=ZS;M[57]=JS;M[58]=QS;M[59]=tk;M[60]=Ee;M[61]=Ee;M[62]=Ee;M[63]=Ee;for(let r=64;r<=87;r++)M[r]=rk;M[88]=nk;M[89]=ok;M[90]=ik;M[91]=sk;M[92]=Ee;M[93]=Ee;M[94]=Ee;M[95]=ph("indefinite length bytes/strings are not supported");for(let r=96;r<=119;r++)M[r]=ck;M[120]=uk;M[121]=lk;M[122]=fk;M[123]=dk;M[124]=Ee;M[125]=Ee;M[126]=Ee;M[127]=ph("indefinite length bytes/strings are not supported");for(let r=128;r<=151;r++)M[r]=pk;M[152]=mk;M[153]=gk;M[154]=yk;M[155]=wk;M[156]=Ee;M[157]=Ee;M[158]=Ee;M[159]=bk;for(let r=160;r<=183;r++)M[r]=xk;M[184]=Ek;M[185]=vk;M[186]=Ak;M[187]=Sk;M[188]=Ee;M[189]=Ee;M[190]=Ee;M[191]=kk;for(let r=192;r<=215;r++)M[r]=_k;M[216]=Ik;M[217]=Tk;M[218]=Ck;M[219]=Bk;M[220]=Ee;M[221]=Ee;M[222]=Ee;M[223]=Ee;for(let r=224;r<=243;r++)M[r]=ph("simple values are not supported");M[244]=Ee;M[245]=Ee;M[246]=Ee;M[247]=Nk;M[248]=ph("simple values are not supported");M[249]=Lk;M[250]=Dk;M[251]=Rk;M[252]=Ee;M[253]=Ee;M[254]=Ee;M[255]=Pk;var tn=[];for(let r=0;r<24;r++)tn[r]=new G(v.uint,r,1);for(let r=-1;r>=-24;r--)tn[31-r]=new G(v.negint,r,1);tn[64]=new G(v.bytes,new Uint8Array(0),1);tn[96]=new G(v.string,"",1);tn[128]=new G(v.array,0,1);tn[160]=new G(v.map,0,1);tn[244]=new G(v.false,!1,1);tn[245]=new G(v.true,!0,1);tn[246]=new G(v.null,null,1);function $k(r){switch(r.type){case v.false:return wn([244]);case v.true:return wn([245]);case v.null:return wn([246]);case v.bytes:return r.value.length?void 0:wn([64]);case v.string:return r.value===""?wn([96]):void 0;case v.array:return r.value===0?wn([128]):void 0;case v.map:return r.value===0?wn([160]):void 0;case v.uint:return r.value<24?wn([Number(r.value)]):void 0;case v.negint:if(r.value>=-24)return wn([31-Number(r.value)])}}var Kk=Object.freeze({float64:!0,mapSorter:sP,quickEncodeToken:$k});function rP(){let r=[];return r[v.uint.major]=br,r[v.negint.major]=ch,r[v.bytes.major]=oa,r[v.string.major]=hk,r[v.array.major]=lh,r[v.map.major]=fh,r[v.tag.major]=dh,r[v.float.major]=hh,r}var nP=rP(),oP=new hu,mh=class r{constructor(e,t){this.obj=e,this.parent=t}includes(e){let t=this;do if(t.obj===e)return!0;while(t=t.parent);return!1}static createCheck(e,t){if(e&&e.includes(t))throw new Error(`${Sw} object contains circular references`);return new r(t,e)}},Io={null:new G(v.null,null),undefined:new G(v.undefined,void 0),true:new G(v.true,!0),false:new G(v.false,!1),emptyArray:new G(v.array,0),emptyMap:new G(v.map,0)},To={number(r,e,t,n){return!Number.isInteger(r)||!Number.isSafeInteger(r)?new G(v.float,r):r>=0?new G(v.uint,r):new G(v.negint,r)},bigint(r,e,t,n){return r>=BigInt(0)?new G(v.uint,r):new G(v.negint,r)},Uint8Array(r,e,t,n){return new G(v.bytes,r)},string(r,e,t,n){return new G(v.string,r)},boolean(r,e,t,n){return r?Io.true:Io.false},null(r,e,t,n){return Io.null},undefined(r,e,t,n){return Io.undefined},ArrayBuffer(r,e,t,n){return new G(v.bytes,new Uint8Array(r))},DataView(r,e,t,n){return new G(v.bytes,new Uint8Array(r.buffer,r.byteOffset,r.byteLength))},Array(r,e,t,n){if(!r.length)return t.addBreakTokens===!0?[Io.emptyArray,new G(v.break)]:Io.emptyArray;n=mh.createCheck(n,r);let o=[],i=0;for(let s of r)o[i++]=aa(s,t,n);return t.addBreakTokens?[new G(v.array,r.length),o,new G(v.break)]:[new G(v.array,r.length),o]},Object(r,e,t,n){let o=e!=="Object",i=o?r.keys():Object.keys(r),s=o?r.size:i.length,a;if(s){a=new Array(s),n=mh.createCheck(n,r);let c=!o&&t.ignoreUndefinedProperties,u=0;for(let l of i){let f=o?r.get(l):r[l];c&&f===void 0||(a[u++]=[aa(l,t,n),aa(f,t,n)])}u<s&&(a.length=u)}return a?.length?(iP(a,t),t.addBreakTokens?[new G(v.map,a.length),a,new G(v.break)]:[new G(v.map,a.length),a]):t.addBreakTokens===!0?[Io.emptyMap,new G(v.break)]:Io.emptyMap},Tagged(r,e,t,n){return[new G(v.tag,r.tag),aa(r.value,t,n)]}};To.Map=To.Object;To.Buffer=To.Uint8Array;for(let r of"Uint8Clamped Uint16 Uint32 Int8 Int16 Int32 BigUint64 BigInt64 Float32 Float64".split(" "))To[`${r}Array`]=To.DataView;function aa(r,e={},t){let n=KS(r),o=e&&e.typeEncoders&&e.typeEncoders[n]||To[n];if(typeof o=="function"){let s=o(r,n,e,t);if(s!=null)return s}let i=To[n];if(!i)throw new Error(`${Sw} unsupported type: ${n}`);return i(r,n,e,t)}function iP(r,e){e.mapSorter&&r.sort(e.mapSorter)}function sP(r,e){if(r[0]instanceof G&&e[0]instanceof G){let t=r[0],n=e[0];return t._keyBytes||(t._keyBytes=Vk(t.value)),n._keyBytes||(n._keyBytes=Vk(n.value)),sh(t._keyBytes,n._keyBytes)}throw new Error("rfc8949MapSorter: complex key types are not supported yet")}function Vk(r){return aP(r,nP,Kk)}function qk(r,e,t,n){if(Array.isArray(e))for(let o of e)qk(r,o,t,n);else t[e.type.major](r,e,n)}var DY=v.uint.majorEncoded,RY=v.negint.majorEncoded,UY=v.bytes.majorEncoded,OY=v.string.majorEncoded,MY=v.array.majorEncoded,FY=v.float.majorEncoded|_w,$Y=v.float.majorEncoded|Iw,VY=v.float.majorEncoded|Tw,KY=v.float.majorEncoded|Cw,qY=BigInt(-1),HY=BigInt(1);function aP(r,e,t,n){let o=n instanceof Uint8Array,i=o?new ah(n):oP,s=aa(r,t);if(!Array.isArray(s)&&t.quickEncodeToken){let a=t.quickEncodeToken(s);if(a)return o?(i.push(a),i.toBytes()):a;let c=e[s.type.major];if(c.encodedSize){let u=c.encodedSize(s,t);if(o||(i=new hu(u)),c(i,s,t),i.chunks.length!==1)throw new Error(`Unexpected error: pre-calculated length for ${s} was wrong`);return o?i.toBytes():du(i.chunks[0])}}return i.reset(),qk(i,s,e,t),i.toBytes(!0)}var cP={strict:!1,allowIndefinite:!0,allowUndefined:!0,allowBigInt:!0},gh=class{constructor(e,t={}){this._pos=0,this.data=e,this.options=t}pos(){return this._pos}done(){return this._pos>=this.data.length}next(){let e=this.data[this._pos],t=tn[e];if(t===void 0){let n=M[e];if(!n)throw new Error(`${ne} no decoder for major type ${e>>>5} (byte 0x${e.toString(16).padStart(2,"0")})`);let o=e&31;t=n(this.data,this._pos,o,this.options)}return this._pos+=t.encodedLength,t}},Co=Symbol.for("DONE"),ca=Symbol.for("BREAK");function uP(r,e,t){let n=[];for(let o=0;o<r.value;o++){let i=Bo(e,t);if(i===ca){if(r.value===1/0)break;throw new Error(`${ne} got unexpected break to lengthed array`)}if(i===Co)throw new Error(`${ne} found array but not enough entries (got ${o}, expected ${r.value})`);n[o]=i}return n}function lP(r,e,t){let n=t.useMaps===!0,o=t.rejectDuplicateMapKeys===!0,i=n?void 0:{},s=n?new Map:void 0;for(let a=0;a<r.value;a++){let c=Bo(e,t);if(c===ca){if(r.value===1/0)break;throw new Error(`${ne} got unexpected break to lengthed map`)}if(c===Co)throw new Error(`${ne} found map but not enough entries (got ${a} [no key], expected ${r.value})`);if(!n&&typeof c!="string")throw new Error(`${ne} non-string keys not supported (got ${typeof c})`);if(o&&(n&&s.has(c)||!n&&Object.hasOwn(i,c)))throw new Error(`${ne} found repeat map key "${c}"`);let u=Bo(e,t);if(u===Co)throw new Error(`${ne} found map but not enough entries (got ${a} [no value], expected ${r.value})`);n?s.set(c,u):i[c]=u}return n?s:i}function*fP(r,e,t){for(let n=0;n<r.value;n++){let o=Bo(e,t);if(o===ca){if(r.value===1/0)break;throw new Error(`${ne} got unexpected break to lengthed map`)}if(o===Co)throw new Error(`${ne} found map but not enough entries (got ${n} [no key], expected ${r.value})`);let i=Bo(e,t);if(i===Co)throw new Error(`${ne} found map but not enough entries (got ${n} [no value], expected ${r.value})`);yield[o,i]}}function dP(r,e){let t=!1,n=function(){if(t)throw new Error(`${ne} tag decode() may only be called once`);t=!0;let o=Bo(r,e);if(o===Co)throw new Error(`${ne} tag content missing`);if(o===ca)throw new Error(`${ne} got unexpected break in tag content`);return o};return n.entries=function(){if(t)throw new Error(`${ne} tag decode() may only be called once`);t=!0;let o=r.next();if(!v.equals(o.type,v.map))throw new Error(`${ne} entries() requires map content, got ${o.type.name}`);let i=[];for(let s of fP(o,r,e))i.push(s);return i},Object.defineProperty(n,"_called",{get(){return t},enumerable:!1}),n}function Bo(r,e){if(r.done())return Co;let t=r.next();if(v.equals(t.type,v.break))return ca;if(t.type.terminal)return t.value;if(v.equals(t.type,v.array))return uP(t,r,e);if(v.equals(t.type,v.map))return lP(t,r,e);if(v.equals(t.type,v.tag)){if(e.tags&&typeof e.tags[t.value]=="function"){let n=dP(r,e),o=e.tags[t.value](n);if(!n._called)throw new Error(`${ne} tag decoder must call decode() or entries()`);return o}throw new Error(`${ne} tag not supported (${t.value})`)}throw new Error("unsupported")}function Hk(r,e){if(!(r instanceof Uint8Array))throw new Error(`${ne} data to decode must be a Uint8Array`);e=Object.assign({},cP,e);let t=du(r),n=e.tokenizer||new gh(t,e),o=Bo(n,e);if(o===Co)throw new Error(`${ne} did not find any content to decode`);if(o===ca)throw new Error(`${ne} got unexpected break`);return[o,r.subarray(n.pos())]}function Lw(r,e){let[t,n]=Hk(r,e);if(n.length>0)throw new Error(`${ne} too many terminals, data makes no sense`);return t}var yh=class r{constructor(e,t){if(typeof e!="number"||!Number.isInteger(e)||e<0)throw new TypeError("Tagged: tag must be a non-negative integer");this.tag=e,this.value=t}static decoder(e){return t=>new r(e,t())}static preserve(...e){let t={};for(let n of e)t[n]=r.decoder(n);return t}};Object.defineProperty(yh.prototype,Symbol.toStringTag,{value:"Tagged"});var mP=ur("ipns:utils"),zk=L("/ipns/");var gP=0,yP=18;function jk(r){let e;if(r.pubKey!=null)try{e=ao(r.pubKey)}catch(t){throw mP.error(t),t}if(e!=null)return e}function Gk(r){let e=L("ipns-signature:");return je([e,r])}function yu(r){return"signatureV1"in r?Qr.encode({value:L(r.value),signatureV1:r.signatureV1,validityType:r.validityType,validity:L(r.validity),sequence:r.sequence,ttl:r.ttl,pubKey:r.pubKey,signatureV2:r.signatureV2,data:r.data}):Qr.encode({pubKey:r.pubKey,signatureV2:r.signatureV2,data:r.data})}function No(r){let e=Qr.decode(r);if(e.sequence!=null&&(e.sequence=BigInt(e.sequence)),e.ttl!=null&&(e.ttl=BigInt(e.ttl)),e.signatureV2==null||e.data==null)throw new Jr("Missing data or signatureV2");let t=Wk(e.data),n=wP(t.Value),o=j(t.Validity);if(e.value!=null&&e.signatureV1!=null)return bP(e),{value:n,validityType:Qr.ValidityType.EOL,validity:o,sequence:t.Sequence,ttl:t.TTL,pubKey:e.pubKey,signatureV1:e.signatureV1,signatureV2:e.signatureV2,data:e.data};if(e.signatureV2!=null)return{value:n,validityType:Qr.ValidityType.EOL,validity:o,sequence:t.Sequence,ttl:t.TTL,pubKey:e.pubKey,signatureV2:e.signatureV2,data:e.data};throw new Error("invalid record: does not include signatureV1 or signatureV2")}function wu(r){return je([zk,r.bytes])}function ua(r){let e=Ct(r.slice(zk.length));if(!wh(e,gP)&&!wh(e,yP))throw new Wn("Multihash in IPNS key was not identity or sha2-256");return e}function Wk(r){let e=Lw(r);if(e.ValidityType===0)e.ValidityType=Qr.ValidityType.EOL;else throw new na("The validity type is unsupported");return Number.isInteger(e.Sequence)&&(e.Sequence=BigInt(e.Sequence)),Number.isInteger(e.TTL)&&(e.TTL=BigInt(e.TTL)),e}function wP(r){let e=j(r).trim();if(e.startsWith("/"))return e;try{return`/ipfs/${Q.decode(r).toV1().toString()}`}catch{}try{return`/ipfs/${Q.parse(e).toV1().toString()}`}catch{}throw new nh("Value must be a valid content path starting with /")}function bP(r){if(r.data==null)throw new oh("Record data is missing");let e=Wk(r.data);if(!ce(e.Value,r.value??new Uint8Array(0)))throw new Jr('Field "value" did not match between protobuf and CBOR');if(!ce(e.Validity,r.validity??new Uint8Array(0)))throw new Jr('Field "validity" did not match between protobuf and CBOR');if(e.ValidityType!==r.validityType)throw new Jr('Field "validityType" did not match between protobuf and CBOR');if(e.Sequence!==r.sequence)throw new Jr('Field "sequence" did not match between protobuf and CBOR');if(e.TTL!==r.ttl)throw new Jr('Field "ttl" did not match between protobuf and CBOR')}function wh(r,e){return r.code===e}var yX=ur("ipns"),wX=300*1e9,EP="/ipns/",bX=EP.length;var Yk=Ro(vw(),1);var bh=ur("ipns:validator"),vP=1024*10;async function AP(r,e){let t=No(e),n;try{let o=Gk(t.data);n=await r.verify(o,t.signatureV2)}catch{n=!1}if(!n)throw bh.error("record signature verification failed"),new Jr("Record signature verification failed");if(t.validityType===Qr.ValidityType.EOL){if(Yk.default.fromString(t.validity).toDate().getTime()<Date.now())throw bh.error("record has expired"),new th("record has expired")}else if(t.validityType!=null)throw bh.error("the validity type is unsupported"),new na("The validity type is unsupported");bh("ipns record for %s is valid",t.value)}async function Xk(r,e){if(e.byteLength>vP)throw new rh("The record is too large");let t=ua(r),n;wh(t,0)&&(n=Pl(t));let o=No(e),i=jk(o)??n;if(i==null)throw new lu("Could not extract public key from IPNS record or routing key");let s=wu(i.toMultihash());if(!ce(s,r))throw new lu("Embedded public key did not match routing key");await AP(i,e)}var xh=class extends Error{name="InvalidMessageLengthError";code="ERR_INVALID_MESSAGE_LENGTH"};async function*la(r,e={}){let t=/\r?\n/,n=new TextDecoder("utf8"),o="";for await(let i of r){if(typeof i=="string"&&(i=new TextEncoder().encode(i)),zi(i)&&(i=i.subarray()),o+=n.decode(i,{stream:!0}),o.length>(e?.maxMessageLength??o.length))throw new xh("Incoming message too long");let s=o.split(t);o=s.pop()??"";for(let a=0;a<s.length;a++)yield JSON.parse(s[a])}o+=n.decode(),o!==""&&(yield JSON.parse(o))}var Ci=class extends Error{static name="InvalidRequestError";constructor(e="Invalid request"){super(e),this.name="InvalidRequestError"}},Er=class extends Error{static name="BadResponseError";constructor(e="Bad response"){super(e),this.name="BadResponseError"}};function SP(r){return r[Symbol.asyncIterator]!=null}function kP(r){if(SP(r))return(async()=>{for await(let e of r)return e})();for(let e of r)return e}var Zk=kP;var Jk=L("/ipns/");function Qk(r){return ce(r.subarray(0,Jk.byteLength),Jk)}var Eh=class{client;constructor(e){this.client=e}async*findProviders(e,t={}){try{yield*hf(this.client.getProviders(e,t),n=>({id:n.ID,multiaddrs:n.Addrs??[],routing:"delegated-http-routing-v1"}))}catch(n){if(n instanceof He)return;throw n}}async provide(){}async cancelReprovide(){}async put(e,t,n){if(!Qk(e))return;let o=ua(e),i=Q.createV1(114,o),s=No(t);await this.client.putIPNS(i,s,n)}async get(e,t){if(!Qk(e))throw new He("Not found");let n=ua(e),o=Q.createV1(114,n);try{let i=await this.client.getIPNS(o,t);return yu(i)}catch(i){throw i.name==="BadResponseError"?new He("Not found"):i}}toString(){return`DelegatedRoutingV1HttpApiClientContentRouting(${this.client.url})`}},vh=class{client;constructor(e){this.client=e}async findPeer(e,t={}){let n=await Zk(this.client.getPeers(e,t));if(n!=null)return{id:n.ID,multiaddrs:n.Addrs??[]};throw new He("Not found")}async*getClosestPeers(e,t={}){let n;try{n=Q.decode(e)}catch{try{n=po(Ut.decode(e))}catch{n=Q.createV1(Vo,Ve.digest(e))}}for await(let o of this.client.getClosestPeers(n,t))yield{id:o.ID,multiaddrs:o.Addrs??[]}}toString(){return`DelegatedRoutingV1HttpApiClientPeerRouting(${this.client.url})`}};var Ah={concurrentRequests:4,timeout:3e4,cacheTTL:300*1e3,cacheName:"delegated-routing-v1-cache"},Sh=class{url;started;httpQueue;shutDownController;timeout;contentRouting;peerRouting;filterAddrs;filterProtocols;inFlightRequests;cacheName;cache;cacheTTL;log;constructor(e,t){this.log=e.logger.forComponent("delegated-routing-v1-http-api-client"),this.started=!1,this.shutDownController=new AbortController,this.shutDownController.signal,this.httpQueue=new yi({concurrency:t.concurrentRequests??Ah.concurrentRequests}),this.inFlightRequests=new Map,this.url=t.url instanceof URL?t.url:new URL(t.url),this.timeout=t.timeout??Ah.timeout,this.filterAddrs=t.filterAddrs,this.filterProtocols=t.filterProtocols,this.contentRouting=new Eh(this),this.peerRouting=new vh(this),this.cacheName=t.cacheName??Ah.cacheName,this.cacheTTL=t.cacheTTL??Ah.cacheTTL}get[Uo](){return this.contentRouting}get[Mo](){return this.peerRouting}isStarted(){return this.started}async start(){this.started||(this.started=!0,this.cacheTTL>0&&(this.cache=await globalThis.caches?.open(this.cacheName),this.cache!=null&&this.log("cache enabled with ttl %d",this.cacheTTL)))}async stop(){this.httpQueue.clear(),this.shutDownController.abort(),await globalThis.caches?.delete(this.cacheName),this.started=!1}async*getProviders(e,t={}){this.log("getProviders starts: %c",e);let n=AbortSignal.timeout(this.timeout),o=Ie([this.shutDownController.signal,n,t.signal]);let i=ge(),s=ge(),a=0;this.httpQueue.add(async()=>(i.resolve(),s.promise));try{await i.promise;let c=new URL(`${this.url}routing/v1/providers/${e}`);this.#t(c,t.filterAddrs,t.filterProtocols);let u={headers:{accept:"application/x-ndjson, application/json;q=0.8"},signal:o},l=await this.#r(c.toString(),u);if(!l.ok){if(l.status===404)return;throw l.status===422?new Ci("Request does not conform to schema or semantic constraints"):new Er(`Unexpected status code: ${l.status}`)}let f=l.headers.get("Content-Type");if(f==null)throw new Er("No Content-Type header received");if(l.body==null){if(f!=="application/x-ndjson")throw new Er("Routing response had no body");return}if(f.startsWith("application/json")){let h=(await l.json()).Providers??[];for(let m of h){let y=this.#e(m);y!=null&&(a++,yield y)}}else if(f.includes("application/x-ndjson"))for await(let d of la(uu(l.body))){let h=this.#e(d);h!=null&&(a++,yield h)}else throw new Er(`Unsupported Content-Type: ${f}`)}finally{o.clear(),s.resolve(),this.log("getProviders finished found %d providers for %c",a,e)}}async*getPeers(e,t={}){this.log("getPeers starts: %c",e);let n=AbortSignal.timeout(this.timeout),o=Ie([this.shutDownController.signal,n,t.signal]);let i=ge(),s=ge();this.httpQueue.add(async()=>(i.resolve(),s.promise));try{await i.promise;let a=new URL(`${this.url}routing/v1/peers/${e.toCID().toString()}`);this.#t(a,t.filterAddrs,t.filterProtocols);let c={headers:{Accept:"application/x-ndjson"},signal:o},u=await this.#r(a.toString(),c);if(u.status===404)return;if(u.status===422)throw new Ci("Request does not conform to schema or semantic constraints");if(u.body==null)throw new Er("Routing response had no body");if(u.headers.get("Content-Type")?.startsWith("application/json")){let d=(await u.json()).Peers??[];for(let h of d){let m=this.#e(h);m!=null&&(yield m)}}else for await(let f of la(uu(u.body))){let d=this.#e(f);d!=null&&(yield d)}}catch(a){this.log.error("getPeers errored - %e",a)}finally{o.clear(),s.resolve(),this.log("getPeers finished: %c",e)}}async*getClosestPeers(e,t={}){let n;if(nr(e))n=e.toCID().toString();else if(Q.asCID(e)===e||e instanceof Q)n=e.toV1().toString();else throw new T("Key must be CID or PeerId");this.log("getClosestPeers starts: %s",n);let o=AbortSignal.timeout(this.timeout),i=Ie([this.shutDownController.signal,o,t.signal]);let s=ge(),a=ge();this.httpQueue.add(async()=>(s.resolve(),a.promise));try{await s.promise;let c=new URL(`${this.url}routing/v1/dht/closest/peers/${n}`);this.#t(c,t.filterAddrs,t.filterProtocols);let u={headers:{Accept:"application/x-ndjson"},signal:i},l=await this.#r(c.toString(),u);if(l.status===404)return;if(l.status===422)throw new Ci("Request does not conform to schema or semantic constraints");if(l.body==null)throw new Er("Routing response had no body");if(l.headers.get("Content-Type")?.startsWith("application/json")){let h=(await l.json()).Peers??[];for(let m of h){let y=this.#e(m);y!=null&&(yield y)}}else for await(let d of la(uu(l.body))){let h=this.#e(d);h!=null&&(yield h)}}catch(c){this.log.error("getClosestPeers errored - %e",c)}finally{i.clear(),a.resolve(),this.log("getClosestPeers finished: %s",n)}}async getIPNS(e,t={}){this.log("getIPNS starts: %s",e);let n=AbortSignal.timeout(this.timeout),o=Ie([this.shutDownController.signal,n,t.signal]);let i=ge(),s=ge();this.httpQueue.add(async()=>(i.resolve(),s.promise));let a=`${this.url}routing/v1/ipns/${e}`;try{await i.promise;let c={headers:{Accept:"application/vnd.ipfs.ipns-record"},signal:o},u=await this.#r(a,c);if(this.log("getIPNS GET %s %d",a,u.status),u.status===404)throw new He("No matching records found");if(u.status===422)throw new Ci("Request does not conform to schema or semantic constraints");if(!u.ok)throw new Er(`Unexpected status code: ${u.status}`);let l=u.headers.get("Content-Type");if(l==null||!l.includes("application/vnd.ipfs.ipns-record"))throw new He("No matching records found");if(u.body==null)throw new Er("GET ipns response had no body");let f=await u.arrayBuffer(),d=new Uint8Array(f,0,f.byteLength);return t.validate!==!1&&await Xk(wu(e.multihash),d),No(d)}catch(c){throw this.log.error("getIPNS GET %s error - %e",a,c),c}finally{o.clear(),s.resolve(),this.log("getIPNS finished: %s",e)}}async putIPNS(e,t,n={}){this.log("putIPNS starts: %c",e);let o=AbortSignal.timeout(this.timeout),i=Ie([this.shutDownController.signal,o,n.signal]);let s=ge(),a=ge();this.httpQueue.add(async()=>(s.resolve(),a.promise));let c=`${this.url}routing/v1/ipns/${e}`;try{await s.promise;let u=yu(t),l={method:"PUT",headers:{"Content-Type":"application/vnd.ipfs.ipns-record"},body:u,signal:i},f=await this.#r(c,l);if(this.log("putIPNS PUT %s %d",c,f.status),f.status!==200)throw new Er("PUT ipns response had status other than 200")}catch(u){throw this.log.error("putIPNS PUT %s error - %e",c,u.stack),u}finally{i.clear(),a.resolve(),this.log("putIPNS finished: %c",e)}}#e(e){try{let t=[],n=e.Addrs?.map(fe)??[];return e.Protocols!=null&&t.push(...e.Protocols),e.Protocol!=null&&(t.push(e.Protocol),delete e.Protocol),{...e,Schema:"peer",ID:lr(e.ID),Addrs:n,Protocols:t}}catch(t){this.log.error("could not conform record to peer schema - %e",t)}}#t(e,t,n){if(t!=null||this.filterAddrs!=null){let o=t?.join(",")??this.filterAddrs?.join(",")??"";o!==""&&e.searchParams.set("filter-addrs",o)}if(n!=null||this.filterProtocols!=null){let o=n?.join(",")??this.filterProtocols?.join(",")??"";o!==""&&e.searchParams.set("filter-protocols",o)}}async#r(e,t){let n=t.method??"GET",o=`${n}-${e}`;if(n==="GET"){let c=await this.cache?.match(e);if(c!=null){if(parseInt(c.headers.get("x-cache-expires")??"0",10)>Date.now())return this.log("returning cached response for %s",o),this.logResponse(c),c;this.log("evicting cached response for %s",o),await this.cache?.delete(e)}else this.cache!=null&&this.log("cache miss for %s",o)}let i=this.inFlightRequests.get(o);if(i!=null){let c=await i;return this.log("deduplicating outgoing request for %s",o),c.clone()}this.log("outgoing request:"),this.logRequest(e,t);let s=fetch(e,t).then(async c=>{if(this.log("incoming response:"),this.logResponse(c),this.cache!=null&&c.ok&&n==="GET"){let u=Date.now()+this.cacheTTL,l=new Headers(c.headers);l.set("x-cache-expires",u.toString());let f=new Response(c.clone().body,{status:c.status,statusText:c.statusText,headers:l});await this.cache.put(e,f)}return c}).finally(()=>{this.inFlightRequests.delete(o)});return this.inFlightRequests.set(o,s),await s}toString(){return`DefaultDelegatedRoutingV1HttpApiClient(${this.url})`}logRequest(e,t){let n=new Headers(t.headers);this.log("%s %s HTTP/1.1",t.method??"GET",e);for(let[o,i]of n.entries())this.log("%s: %s",o,i)}logResponse(e){this.log("HTTP/1.1 %d %s",e.status,e.statusText);for(let[t,n]of e.headers.entries())this.log("%s: %s",t,n)}};function e_(r){return e=>new Sh(e,r)}var _P=["https://trustless-gateway.link","https://4everland.io"],IP=2336;function TP(r){return r=r.toString(),{id:Bn(Q.createV1(IP,Ve.digest(L(r)))),multiaddrs:[zd(r)]}}function CP(r){return new URL(j(r.id.toMultihash().digest))}var Dw=class{name="http-gateway-router";gateways;shuffle;constructor(e={}){this.gateways=(e.gateways??_P).map(t=>TP(t)),this.shuffle=e.shuffle??!0}async*findProviders(e,t){yield*(this.shuffle?this.gateways.toSorted(()=>Math.random()>.5?1:-1):this.gateways).map(n=>({...n,protocols:["transport-ipfs-gateway-http"],routing:"http-gateway-routing"}))}toString(){return`HTTPGatewayRouter([${this.gateways.map(e=>CP(e)).join(", ")}])`}};function Rw(r={}){return new Dw(r)}var Uw=class{name="libp2p-router";libp2p;constructor(e){this.libp2p=e}async provide(e,t){await this.libp2p.contentRouting.provide(e,t)}async cancelReprovide(e,t){await this.libp2p.contentRouting.cancelReprovide(e,t)}async*findProviders(e,t){yield*this.libp2p.contentRouting.findProviders(e,t)}async put(e,t,n){await this.libp2p.contentRouting.put(e,t,n)}async get(e,t){return this.libp2p.contentRouting.get(e,t)}async findPeer(e,t){return this.libp2p.peerRouting.findPeer(e,t)}async*getClosestPeers(e,t){yield*this.libp2p.peerRouting.getClosestPeers(e,t)}toString(){return"Libp2pRouter()"}};function Ow(r){return new Uw(r)}function BP(r){return r[Symbol.asyncIterator]!=null}function NP(r){if(BP(r))return(async()=>{let t=[];for await(let n of r)t.push(n);return t})();let e=[];for(let t of r)e.push(t);return e}var Bi=NP;function PP(r){return typeof r?.then=="function"}var bu=class extends Un{data;constructor(){super(),this.data=new Map}put(e,t,n){n?.signal?.throwIfAborted();let o;if(t instanceof Uint8Array)o=[t];else{let i=Bi(t);if(PP(i))return i.then(s=>this._put(e,s,n));o=i}return this._put(e,o,n)}_put(e,t,n){return n?.signal?.throwIfAborted(),this.data.set(Xe.encode(e.multihash.bytes),t),e}*get(e,t){t?.signal?.throwIfAborted();let n=this.data.get(Xe.encode(e.multihash.bytes));if(n==null)throw new wr;yield*n}has(e,t){return t?.signal?.throwIfAborted(),this.data.has(Xe.encode(e.multihash.bytes))}async delete(e,t){t?.signal?.throwIfAborted(),this.data.delete(Xe.encode(e.multihash.bytes))}*getAll(e){e?.signal?.throwIfAborted();for(let[t,n]of this.data.entries())yield{cid:Q.createV1(Vo,Ct(Xe.decode(t))),bytes:(async function*(){yield*n})()},e?.signal?.throwIfAborted()}};var KZ=ur("blockstore:core:tiered");var t_="SHARDING";function DP(r){return r[Symbol.asyncIterator]!=null}function RP(r,e){return DP(r)?(async function*(){yield*(await Bi(r)).sort(e)})():(function*(){yield*Bi(r).sort(e)})()}var kh=RP;var Mn=class{put(e,t,n){return Promise.reject(new Error(".put is not implemented"))}get(e,t){return Promise.reject(new Error(".get is not implemented"))}has(e,t){return Promise.reject(new Error(".has is not implemented"))}delete(e,t){return Promise.reject(new Error(".delete is not implemented"))}async*putMany(e,t={}){for await(let{key:n,value:o}of e)await this.put(n,o,t),yield n}async*getMany(e,t={}){for await(let n of e)yield{key:n,value:await this.get(n,t)}}async*deleteMany(e,t={}){for await(let n of e)await this.delete(n,t),yield n}batch(){let e=[],t=[];return{put(n,o){e.push({key:n,value:o})},delete(n){t.push(n)},commit:async n=>{await yc(this.putMany(e,n)),e=[],await yc(this.deleteMany(t,n)),t=[]}}}async*_all(e,t){throw new Error("._all is not implemented")}async*_allKeys(e,t){throw new Error("._allKeys is not implemented")}query(e,t){let n=this._all(e,t);if(e.prefix!=null){let o=e.prefix;n=Yr(n,i=>i.key.toString().startsWith(o))}if(Array.isArray(e.filters)&&(n=e.filters.reduce((o,i)=>Yr(o,i),n)),Array.isArray(e.orders)&&(n=e.orders.reduce((o,i)=>kh(o,i),n)),e.offset!=null){let o=0,i=e.offset;n=Yr(n,()=>o++>=i)}return e.limit!=null&&(n=pf(n,e.limit)),n}queryKeys(e,t){let n=this._allKeys(e,t);if(e.prefix!=null){let o=e.prefix;n=Yr(n,i=>i.toString().startsWith(o))}if(Array.isArray(e.filters)&&(n=e.filters.reduce((o,i)=>Yr(o,i),n)),Array.isArray(e.orders)&&(n=e.orders.reduce((o,i)=>kh(o,i),n)),e.offset!=null){let o=e.offset,i=0;n=Yr(n,()=>i++>=o)}return e.limit!=null&&(n=pf(n,e.limit)),n}};var Ni=class extends Mn{data;constructor(){super(),this.data=new Map}put(e,t,n){return n?.signal?.throwIfAborted(),this.data.set(e.toString(),t),e}get(e,t){t?.signal?.throwIfAborted();let n=this.data.get(e.toString());if(n==null)throw new wr;return n}has(e,t){return t?.signal?.throwIfAborted(),this.data.has(e.toString())}delete(e,t){t?.signal?.throwIfAborted(),this.data.delete(e.toString())}*_all(e,t){t?.signal?.throwIfAborted();for(let[n,o]of this.data.entries())yield{key:new Le(n),value:o},t?.signal?.throwIfAborted()}*_allKeys(e,t){t?.signal?.throwIfAborted();for(let n of this.data.keys())yield new Le(n),t?.signal?.throwIfAborted()}};var xJ=new Le(t_);var DJ=ur("datastore:core:tiered");async function n_(r){if(r.connectionProtector===null&&globalThis.process?.env?.LIBP2P_FORCE_PNET!=null)throw new T("Private network is enforced, but no protector was provided");return r}var xu;(function(r){let e;r.codec=()=>(e==null&&(e=ft((i,s,a={})=>{a.lengthDelimited!==!1&&s.fork(),i.publicKey!=null&&i.publicKey.byteLength>0&&(s.uint32(10),s.bytes(i.publicKey)),i.payloadType!=null&&i.payloadType.byteLength>0&&(s.uint32(18),s.bytes(i.payloadType)),i.payload!=null&&i.payload.byteLength>0&&(s.uint32(26),s.bytes(i.payload)),i.signature!=null&&i.signature.byteLength>0&&(s.uint32(42),s.bytes(i.signature)),a.lengthDelimited!==!1&&s.ldelim()},(i,s,a={})=>{let c={publicKey:Re(0),payloadType:Re(0),payload:Re(0),signature:Re(0)},u=s==null?i.len:i.pos+s;for(;i.pos<u;){let l=i.uint32();switch(l>>>3){case 1:{c.publicKey=i.bytes();break}case 2:{c.payloadType=i.bytes();break}case 3:{c.payload=i.bytes();break}case 5:{c.signature=i.bytes();break}default:{i.skipType(l&7);break}}}return c},function*(i,s,a,c={}){let u=s==null?i.len:i.pos+s;for(;i.pos<u;){let l=i.uint32();switch(l>>>3){case 1:{yield{field:`${a}.publicKey`,value:i.bytes()};break}case 2:{yield{field:`${a}.payloadType`,value:i.bytes()};break}case 3:{yield{field:`${a}.payload`,value:i.bytes()};break}case 5:{yield{field:`${a}.signature`,value:i.bytes()};break}default:{i.skipType(l&7);break}}}})),e);function t(i){return ut(i,r.codec())}r.encode=t;function n(i,s){return ct(i,r.codec(),s)}r.decode=n;function o(i,s){return lt(i,r.codec(),s)}r.stream=o})(xu||(xu={}));var _h=class extends Error{constructor(e="Invalid signature"){super(e),this.name="InvalidSignatureError"}};var fa=class r{static createFromProtobuf=e=>{let t=xu.decode(e),n=ao(t.publicKey);return new r({publicKey:n,payloadType:t.payloadType,payload:t.payload,signature:t.signature})};static seal=async(e,t,n)=>{if(t==null)throw new Error("Missing private key");let o=e.domain,i=e.codec,s=e.marshal(),a=o_(o,i,s),c=await t.sign(a.subarray(),n);return new r({publicKey:t.publicKey,payloadType:i,payload:s,signature:c})};static openAndCertify=async(e,t,n)=>{let o=r.createFromProtobuf(e);if(!await o.validate(t,n))throw new _h("Envelope signature is not valid for the given domain");return o};publicKey;payloadType;payload;signature;marshaled;constructor(e){let{publicKey:t,payloadType:n,payload:o,signature:i}=e;this.publicKey=t,this.payloadType=n,this.payload=o,this.signature=i}marshal(){return this.marshaled==null&&(this.marshaled=xu.encode({publicKey:ir(this.publicKey),payloadType:this.payloadType,payload:this.payload.subarray(),signature:this.signature})),this.marshaled}equals(e){return e==null?!1:ce(this.marshal(),e.marshal())}async validate(e,t){let n=o_(e,this.payloadType,this.payload);return this.publicKey.verify(n.subarray(),this.signature,t)}},o_=(r,e,t)=>{let n=L(r),o=oo(n.byteLength),i=oo(e.length),s=oo(t.length);return new Ae(o,n,i,e,s,t)};var i_="libp2p-peer-record",s_=Uint8Array.from([3,1]);var Eu;(function(r){let e;(function(s){let a;s.codec=()=>(a==null&&(a=ft((f,d,h={})=>{h.lengthDelimited!==!1&&d.fork(),f.multiaddr!=null&&f.multiaddr.byteLength>0&&(d.uint32(10),d.bytes(f.multiaddr)),h.lengthDelimited!==!1&&d.ldelim()},(f,d,h={})=>{let m={multiaddr:Re(0)},y=d==null?f.len:f.pos+d;for(;f.pos<y;){let g=f.uint32();g>>>3===1?m.multiaddr=f.bytes():f.skipType(g&7)}return m},function*(f,d,h,m={}){let y=d==null?f.len:f.pos+d;for(;f.pos<y;){let g=f.uint32();g>>>3===1?yield{field:`${h}.multiaddr`,value:f.bytes()}:f.skipType(g&7)}})),a);function c(f){return ut(f,s.codec())}s.encode=c;function u(f,d){return ct(f,s.codec(),d)}s.decode=u;function l(f,d){return lt(f,s.codec(),d)}s.stream=l})(e=r.AddressInfo||(r.AddressInfo={}));let t;r.codec=()=>(t==null&&(t=ft((s,a,c={})=>{if(c.lengthDelimited!==!1&&a.fork(),s.peerId!=null&&s.peerId.byteLength>0&&(a.uint32(10),a.bytes(s.peerId)),s.seq!=null&&s.seq!==0n&&(a.uint32(16),a.uint64(s.seq)),s.addresses!=null&&s.addresses.length>0)for(let u of s.addresses)a.uint32(26),r.AddressInfo.codec().encode(u,a);c.lengthDelimited!==!1&&a.ldelim()},(s,a,c={})=>{let u={peerId:Re(0),seq:0n,addresses:[]},l=a==null?s.len:s.pos+a;for(;s.pos<l;){let f=s.uint32();switch(f>>>3){case 1:{u.peerId=s.bytes();break}case 2:{u.seq=s.uint64();break}case 3:{if(c.limits?.addresses!=null&&u.addresses.length===c.limits.addresses)throw new ar('Decode error - repeated field "addresses" had too many elements');u.addresses.push(r.AddressInfo.codec().decode(s,s.uint32(),{limits:c.limits?.addresses$}));break}default:{s.skipType(f&7);break}}}return u},function*(s,a,c,u={}){let l={addresses:0},f=a==null?s.len:s.pos+a;for(;s.pos<f;){let d=s.uint32();switch(d>>>3){case 1:{yield{field:`${c}.peerId`,value:s.bytes()};break}case 2:{yield{field:`${c}.seq`,value:s.uint64()};break}case 3:{if(u.limits?.addresses!=null&&l.addresses===u.limits.addresses)throw new ar('Streaming decode error - repeated field "addresses" had too many elements');for(let h of r.AddressInfo.codec().stream(s,s.uint32(),`${c}.addresses[]`,{limits:u.limits?.addresses$}))yield{...h,index:l.addresses};l.addresses++;break}default:{s.skipType(d&7);break}}}})),t);function n(s){return ut(s,r.codec())}r.encode=n;function o(s,a){return ct(s,r.codec(),a)}r.decode=o;function i(s,a){return lt(s,r.codec(),a)}r.stream=i})(Eu||(Eu={}));function a_(r,e){let t=(n,o)=>n.toString().localeCompare(o.toString());return r.length!==e.length?!1:(e.sort(t),r.sort(t).every((n,o)=>e[o].equals(n)))}var Pi=class r{static createFromProtobuf=e=>{let t=Eu.decode(e),n=po(Ct(t.peerId)),o=(t.addresses??[]).map(s=>fe(s.multiaddr)),i=t.seq;return new r({peerId:n,multiaddrs:o,seqNumber:i})};static DOMAIN=i_;static CODEC=s_;peerId;multiaddrs;seqNumber;domain=r.DOMAIN;codec=r.CODEC;marshaled;constructor(e){let{peerId:t,multiaddrs:n,seqNumber:o}=e;this.peerId=t,this.multiaddrs=n??[],this.seqNumber=o??BigInt(Date.now())}marshal(){return this.marshaled==null&&(this.marshaled=Eu.encode({peerId:this.peerId.toMultihash().bytes,seq:BigInt(this.seqNumber),addresses:this.multiaddrs.map(e=>({multiaddr:e.bytes}))})),this.marshaled}equals(e){return!(!(e instanceof r)||!this.peerId.equals(e.peerId)||this.seqNumber!==e.seqNumber||!a_(this.multiaddrs,e.multiaddrs))}};var Fn;(function(r){let e;(function(a){let c;a.codec=()=>(c==null&&(c=ft((d,h,m={})=>{m.lengthDelimited!==!1&&h.fork(),d.key!=null&&d.key!==""&&(h.uint32(10),h.string(d.key)),d.value!=null&&d.value.byteLength>0&&(h.uint32(18),h.bytes(d.value)),m.lengthDelimited!==!1&&h.ldelim()},(d,h,m={})=>{let y={key:"",value:Re(0)},g=h==null?d.len:d.pos+h;for(;d.pos<g;){let b=d.uint32();switch(b>>>3){case 1:{y.key=d.string();break}case 2:{y.value=d.bytes();break}default:{d.skipType(b&7);break}}}return y},function*(d,h,m,y={}){let g=h==null?d.len:d.pos+h;for(;d.pos<g;){let b=d.uint32();switch(b>>>3){case 1:{yield{field:`${m}.key`,value:d.string()};break}case 2:{yield{field:`${m}.value`,value:d.bytes()};break}default:{d.skipType(b&7);break}}}})),c);function u(d){return ut(d,a.codec())}a.encode=u;function l(d,h){return ct(d,a.codec(),h)}a.decode=l;function f(d,h){return lt(d,a.codec(),h)}a.stream=f})(e=r.Peer$metadataEntry||(r.Peer$metadataEntry={}));let t;(function(a){let c;a.codec=()=>(c==null&&(c=ft((d,h,m={})=>{m.lengthDelimited!==!1&&h.fork(),d.key!=null&&d.key!==""&&(h.uint32(10),h.string(d.key)),d.value!=null&&(h.uint32(18),Au.codec().encode(d.value,h)),m.lengthDelimited!==!1&&h.ldelim()},(d,h,m={})=>{let y={key:""},g=h==null?d.len:d.pos+h;for(;d.pos<g;){let b=d.uint32();switch(b>>>3){case 1:{y.key=d.string();break}case 2:{y.value=Au.codec().decode(d,d.uint32(),{limits:m.limits?.value});break}default:{d.skipType(b&7);break}}}return y},function*(d,h,m,y={}){let g=h==null?d.len:d.pos+h;for(;d.pos<g;){let b=d.uint32();switch(b>>>3){case 1:{yield{field:`${m}.key`,value:d.string()};break}case 2:{yield*Au.codec().stream(d,d.uint32(),`${m}.value`,{limits:y.limits?.value});break}default:{d.skipType(b&7);break}}}})),c);function u(d){return ut(d,a.codec())}a.encode=u;function l(d,h){return ct(d,a.codec(),h)}a.decode=l;function f(d,h){return lt(d,a.codec(),h)}a.stream=f})(t=r.Peer$tagsEntry||(r.Peer$tagsEntry={}));let n;r.codec=()=>(n==null&&(n=ft((a,c,u={})=>{if(u.lengthDelimited!==!1&&c.fork(),a.addresses!=null&&a.addresses.length>0)for(let l of a.addresses)c.uint32(10),vu.codec().encode(l,c);if(a.protocols!=null&&a.protocols.length>0)for(let l of a.protocols)c.uint32(18),c.string(l);if(a.publicKey!=null&&(c.uint32(34),c.bytes(a.publicKey)),a.peerRecordEnvelope!=null&&(c.uint32(42),c.bytes(a.peerRecordEnvelope)),a.metadata!=null&&a.metadata.size>0)for(let[l,f]of a.metadata.entries())c.uint32(50),r.Peer$metadataEntry.codec().encode({key:l,value:f},c);if(a.tags!=null&&a.tags.size>0)for(let[l,f]of a.tags.entries())c.uint32(58),r.Peer$tagsEntry.codec().encode({key:l,value:f},c);a.updated!=null&&(c.uint32(64),c.uint64Number(a.updated)),u.lengthDelimited!==!1&&c.ldelim()},(a,c,u={})=>{let l={addresses:[],protocols:[],metadata:new Map,tags:new Map},f=c==null?a.len:a.pos+c;for(;a.pos<f;){let d=a.uint32();switch(d>>>3){case 1:{if(u.limits?.addresses!=null&&l.addresses.length===u.limits.addresses)throw new ar('Decode error - repeated field "addresses" had too many elements');l.addresses.push(vu.codec().decode(a,a.uint32(),{limits:u.limits?.addresses$}));break}case 2:{if(u.limits?.protocols!=null&&l.protocols.length===u.limits.protocols)throw new ar('Decode error - repeated field "protocols" had too many elements');l.protocols.push(a.string());break}case 4:{l.publicKey=a.bytes();break}case 5:{l.peerRecordEnvelope=a.bytes();break}case 6:{if(u.limits?.metadata!=null&&l.metadata.size===u.limits.metadata)throw new Ja('Decode error - map field "metadata" had too many elements');let h=r.Peer$metadataEntry.codec().decode(a,a.uint32(),{limits:{value:u.limits?.metadata$value}});l.metadata.set(h.key,h.value);break}case 7:{if(u.limits?.tags!=null&&l.tags.size===u.limits.tags)throw new Ja('Decode error - map field "tags" had too many elements');let h=r.Peer$tagsEntry.codec().decode(a,a.uint32(),{limits:{value:u.limits?.tags$value}});l.tags.set(h.key,h.value);break}case 8:{l.updated=a.uint64Number();break}default:{a.skipType(d&7);break}}}return l},function*(a,c,u,l={}){let f={addresses:0,protocols:0,metadata:0,tags:0},d=c==null?a.len:a.pos+c;for(;a.pos<d;){let h=a.uint32();switch(h>>>3){case 1:{if(l.limits?.addresses!=null&&f.addresses===l.limits.addresses)throw new ar('Streaming decode error - repeated field "addresses" had too many elements');for(let m of vu.codec().stream(a,a.uint32(),`${u}.addresses[]`,{limits:l.limits?.addresses$}))yield{...m,index:f.addresses};f.addresses++;break}case 2:{if(l.limits?.protocols!=null&&f.protocols===l.limits.protocols)throw new ar('Streaming decode error - repeated field "protocols" had too many elements');yield{field:`${u}.protocols[]`,index:f.protocols,value:a.string()},f.protocols++;break}case 4:{yield{field:`${u}.publicKey`,value:a.bytes()};break}case 5:{yield{field:`${u}.peerRecordEnvelope`,value:a.bytes()};break}case 6:{if(l.limits?.metadata!=null&&f.metadata===l.limits.metadata)throw new ar('Decode error - map field "metadata" had too many elements');yield*r.Peer$metadataEntry.codec().stream(a,a.uint32(),`${u}.metadata{}`,{limits:{value:l.limits?.metadata$value}}),f.metadata++;break}case 7:{if(l.limits?.tags!=null&&f.tags===l.limits.tags)throw new ar('Decode error - map field "tags" had too many elements');yield*r.Peer$tagsEntry.codec().stream(a,a.uint32(),`${u}.tags{}`,{limits:{value:l.limits?.tags$value}}),f.tags++;break}case 8:{yield{field:`${u}.updated`,value:a.uint64Number()};break}default:{a.skipType(h&7);break}}}})),n);function o(a){return ut(a,r.codec())}r.encode=o;function i(a,c){return ct(a,r.codec(),c)}r.decode=i;function s(a,c){return lt(a,r.codec(),c)}r.stream=s})(Fn||(Fn={}));var vu;(function(r){let e;r.codec=()=>(e==null&&(e=ft((i,s,a={})=>{a.lengthDelimited!==!1&&s.fork(),i.multiaddr!=null&&i.multiaddr.byteLength>0&&(s.uint32(10),s.bytes(i.multiaddr)),i.isCertified!=null&&(s.uint32(16),s.bool(i.isCertified)),i.observed!=null&&(s.uint32(24),s.uint64Number(i.observed)),a.lengthDelimited!==!1&&s.ldelim()},(i,s,a={})=>{let c={multiaddr:Re(0)},u=s==null?i.len:i.pos+s;for(;i.pos<u;){let l=i.uint32();switch(l>>>3){case 1:{c.multiaddr=i.bytes();break}case 2:{c.isCertified=i.bool();break}case 3:{c.observed=i.uint64Number();break}default:{i.skipType(l&7);break}}}return c},function*(i,s,a,c={}){let u=s==null?i.len:i.pos+s;for(;i.pos<u;){let l=i.uint32();switch(l>>>3){case 1:{yield{field:`${a}.multiaddr`,value:i.bytes()};break}case 2:{yield{field:`${a}.isCertified`,value:i.bool()};break}case 3:{yield{field:`${a}.observed`,value:i.uint64Number()};break}default:{i.skipType(l&7);break}}}})),e);function t(i){return ut(i,r.codec())}r.encode=t;function n(i,s){return ct(i,r.codec(),s)}r.decode=n;function o(i,s){return lt(i,r.codec(),s)}r.stream=o})(vu||(vu={}));var Au;(function(r){let e;r.codec=()=>(e==null&&(e=ft((i,s,a={})=>{a.lengthDelimited!==!1&&s.fork(),i.value!=null&&i.value!==0&&(s.uint32(8),s.uint32(i.value)),i.expiry!=null&&(s.uint32(16),s.uint64(i.expiry)),a.lengthDelimited!==!1&&s.ldelim()},(i,s,a={})=>{let c={value:0},u=s==null?i.len:i.pos+s;for(;i.pos<u;){let l=i.uint32();switch(l>>>3){case 1:{c.value=i.uint32();break}case 2:{c.expiry=i.uint64();break}default:{i.skipType(l&7);break}}}return c},function*(i,s,a,c={}){let u=s==null?i.len:i.pos+s;for(;i.pos<u;){let l=i.uint32();switch(l>>>3){case 1:{yield{field:`${a}.value`,value:i.uint32()};break}case 2:{yield{field:`${a}.expiry`,value:i.uint64()};break}default:{i.skipType(l&7);break}}}})),e);function t(i){return ut(i,r.codec())}r.encode=t;function n(i,s){return ct(i,r.codec(),s)}r.decode=n;function o(i,s){return lt(i,r.codec(),s)}r.stream=o})(Au||(Au={}));function UP(r,e){if(r.publicKey!=null||e.publicKey==null)return r;let t;r.type==="RSA"&&(t=r.toMultihash());let n=ao(e.publicKey,t);return My(n)}function c_(r,e,t){let n=Fn.decode(e);return da(r,n,t)}function da(r,e,t){let n=new Map,o=BigInt(Date.now());for(let[i,s]of e.tags.entries())s.expiry!=null&&s.expiry<o||n.set(i,s);return{...e,id:UP(r,e),addresses:e.addresses.filter(({observed:i})=>i!=null&&i>Date.now()-t).map(({multiaddr:i,isCertified:s})=>({multiaddr:fe(i),isCertified:s??!1})),metadata:e.metadata,peerRecordEnvelope:e.peerRecordEnvelope??void 0,tags:n}}function u_(r,e){return OP(r.addresses,e.addresses)&&MP(r.protocols,e.protocols)&&FP(r.publicKey,e.publicKey)&&$P(r.peerRecordEnvelope,e.peerRecordEnvelope)&&VP(r.metadata,e.metadata)&&KP(r.tags,e.tags)}function OP(r,e){return f_(r,e,(t,n)=>!(t.isCertified!==n.isCertified||!ce(t.multiaddr,n.multiaddr)))}function MP(r,e){return f_(r,e,(t,n)=>t===n)}function FP(r,e){return l_(r,e)}function $P(r,e){return l_(r,e)}function VP(r,e){return d_(r,e,(t,n)=>ce(t,n))}function KP(r,e){return d_(r,e,(t,n)=>t.value===n.value&&t.expiry===n.expiry)}function l_(r,e){return r==null&&e==null?!0:r!=null&&e!=null?ce(r,e):!1}function f_(r,e,t){if(r.length!==e.length)return!1;for(let n=0;n<r.length;n++)if(!t(r[n],e[n]))return!1;return!0}function d_(r,e,t){if(r.size!==e.size)return!1;for(let[n,o]of r.entries()){let i=e.get(n);if(i==null||!t(o,i))return!1}return!0}var Mw="/peers/";function Su(r){if(!nr(r)||r.type==null)throw new T("Invalid PeerId");let e=r.toCID().toString();return new Le(`${Mw}${e}`)}async function h_(r,e,t,n,o){let i=new Map;for(let s of t){if(s==null)continue;if(s.multiaddr instanceof Uint8Array&&(s.multiaddr=fe(s.multiaddr)),!ho(s.multiaddr))throw new T("Multiaddr was invalid");if(!await e(r,s.multiaddr,o))continue;let a=s.isCertified??!1,c=s.multiaddr.toString(),u=i.get(c);u!=null?s.isCertified=u.isCertified||a:i.set(c,{multiaddr:s.multiaddr,isCertified:a})}return[...i.values()].sort((s,a)=>s.multiaddr.toString().localeCompare(a.multiaddr.toString())).map(({isCertified:s,multiaddr:a})=>{let c=a.getComponents().find(u=>u.code===421)?.value;return r.equals(c)&&(a=a.decapsulate(fe(`/p2p/${r}`))),{isCertified:s,multiaddr:a.bytes}})}async function Th(r,e,t,n){if(e==null)throw new T("Invalid PeerData");if(e.publicKey!=null&&r.publicKey!=null&&!e.publicKey.equals(r.publicKey))throw new T("publicKey bytes do not match peer id publicKey bytes");let o=n.existingPeer?.peer;if(o!=null&&!r.equals(o.id))throw new T("peer id did not match existing peer id");let i=o?.addresses??[],s=new Set(o?.protocols??[]),a=o?.metadata??new Map,c=o?.tags??new Map,u=o?.peerRecordEnvelope;if(t==="patch"){if((e.multiaddrs!=null||e.addresses!=null)&&(i=[],e.multiaddrs!=null&&i.push(...e.multiaddrs.map(d=>({isCertified:!1,multiaddr:d}))),e.addresses!=null&&i.push(...e.addresses)),e.protocols!=null&&(s=new Set(e.protocols)),e.metadata!=null){let d=e.metadata instanceof Map?[...e.metadata.entries()]:Object.entries(e.metadata);a=Ih(d,{validate:p_})}if(e.tags!=null){let d=e.tags instanceof Map?[...e.tags.entries()]:Object.entries(e.tags);c=Ih(d,{validate:m_,map:g_})}e.peerRecordEnvelope!=null&&(u=e.peerRecordEnvelope)}if(t==="merge"){if(e.multiaddrs!=null&&i.push(...e.multiaddrs.map(d=>({isCertified:!1,multiaddr:d}))),e.addresses!=null&&i.push(...e.addresses),e.protocols!=null&&(s=new Set([...s,...e.protocols])),e.metadata!=null){let d=e.metadata instanceof Map?[...e.metadata.entries()]:Object.entries(e.metadata);for(let[h,m]of d)m==null?a.delete(h):a.set(h,m);a=Ih([...a.entries()],{validate:p_})}if(e.tags!=null){let d=e.tags instanceof Map?[...e.tags.entries()]:Object.entries(e.tags),h=new Map(c);for(let[m,y]of d)y==null?h.delete(m):h.set(m,y);c=Ih([...h.entries()],{validate:m_,map:g_})}e.peerRecordEnvelope!=null&&(u=e.peerRecordEnvelope)}let l;o?.id.publicKey!=null?l=ir(o.id.publicKey):e.publicKey!=null?l=ir(e.publicKey):r.publicKey!=null&&(l=ir(r.publicKey));let f={addresses:await h_(r,n.addressFilter??(async()=>!0),i,n.existingPeer?.peerPB.addresses,n),protocols:[...s.values()].sort((d,h)=>d.localeCompare(h)),metadata:a,tags:c,publicKey:l,peerRecordEnvelope:u};return f.addresses.forEach(d=>{d.observed=n.existingPeer?.peerPB.addresses?.find(h=>ce(h.multiaddr,h.multiaddr))?.observed??Date.now()}),r.type!=="RSA"&&delete f.publicKey,f}function Ih(r,e){let t=new Map;for(let[n,o]of r)o!=null&&e.validate(n,o);for(let[n,o]of r.sort(([i],[s])=>i.localeCompare(s)))o!=null&&t.set(n,e.map?.(n,o)??o);return t}function p_(r,e){if(typeof r!="string")throw new T("Metadata key must be a string");if(!(e instanceof Uint8Array))throw new T("Metadata value must be a Uint8Array")}function m_(r,e){if(typeof r!="string")throw new T("Tag name must be a string");if(e.value!=null){if(parseInt(`${e.value}`,10)!==e.value)throw new T("Tag value must be an integer");if(e.value<0||e.value>100)throw new T("Tag value must be between 0-100")}if(e.ttl!=null){if(parseInt(`${e.ttl}`,10)!==e.ttl)throw new T("Tag ttl must be an integer");if(e.ttl<0)throw new T("Tag ttl must be between greater than 0")}}function g_(r,e){let t;e.expiry!=null&&(t=e.expiry),e.ttl!=null&&(t=BigInt(Date.now()+Number(e.ttl)));let n={value:e.value??0};return t!=null&&(n.expiry=t),n}function y_(r){let e=r.toString().split("/")[2],t=Q.parse(e,Xe);return Bn(t)}function Fw(r,e,t){let n=y_(r);return c_(n,e,t)}function qP(r,e){return{prefix:Mw,filters:(r.filters??[]).map(t=>({key:n,value:o})=>t(Fw(n,o,e))),orders:(r.orders??[]).map(t=>(n,o)=>t(Fw(n.key,n.value,e),Fw(o.key,o.value,e)))}}var Ch=class{peerId;datastore;locks;addressFilter;log;maxAddressAge;maxPeerAge;constructor(e,t={}){this.log=e.logger.forComponent("libp2p:peer-store"),this.peerId=e.peerId,this.datastore=e.datastore,this.addressFilter=t.addressFilter,this.locks=$y({name:"libp2p_peer_store_locks",metrics:e.metrics}),this.maxAddressAge=t.maxAddressAge??36e5,this.maxPeerAge=t.maxPeerAge??216e5}getLock(e){let t=this.locks.get(e);return t==null&&(t={refs:0,lock:Vc({name:e.toString(),singleProcess:!0})},this.locks.set(e,t)),t.refs++,t}maybeRemoveLock(e,t){t.refs--,t.refs===0&&(t.lock.finalize(),this.locks.delete(e))}async getReadLock(e,t){let n=this.getLock(e);try{let o=await n.lock.readLock(t);return()=>{o(),this.maybeRemoveLock(e,n)}}catch(o){throw this.maybeRemoveLock(e,n),o}}async getWriteLock(e,t){let n=this.getLock(e);try{let o=await n.lock.writeLock(t);return()=>{o(),this.maybeRemoveLock(e,n)}}catch(o){throw this.maybeRemoveLock(e,n),o}}async has(e,t){try{return await this.load(e,t),!0}catch(n){if(n.name!=="NotFoundError")throw n}return!1}async delete(e,t){this.peerId.equals(e)||await this.datastore.delete(Su(e),t)}async load(e,t){let n=Su(e),o=await this.datastore.get(n,t),i=Fn.decode(o);if(this.#r(e,i))throw await this.datastore.delete(n,t),new He;return da(e,i,this.peerId.equals(e)?1/0:this.maxAddressAge)}async save(e,t,n){let o=await this.#e(e,n),i=await Th(e,t,"patch",{...n,addressFilter:this.addressFilter});return this.#t(e,i,o)}async patch(e,t,n){let o=await this.#e(e,n),i=await Th(e,t,"patch",{...n,addressFilter:this.addressFilter,existingPeer:o});return this.#t(e,i,o)}async merge(e,t,n){let o=await this.#e(e,n),i=await Th(e,t,"merge",{addressFilter:this.addressFilter,existingPeer:o});return this.#t(e,i,o)}async*all(e){for await(let{key:t,value:n}of this.datastore.query(qP(e??{},this.maxAddressAge),e)){let o=y_(t);if(o.equals(this.peerId))continue;let i=Fn.decode(n);if(this.#r(o,i)){await this.datastore.delete(t,e);continue}yield da(o,i,this.peerId.equals(o)?1/0:this.maxAddressAge)}}async#e(e,t){try{let n=Su(e),o=await this.datastore.get(n,t),i=Fn.decode(o);if(this.#r(e,i))throw await this.datastore.delete(n,t),new He;return{peerPB:i,peer:da(e,i,this.maxAddressAge)}}catch(n){n.name!=="NotFoundError"&&this.log.error("invalid peer data found in peer store - %e",n)}}async#t(e,t,n,o){t.updated=Date.now();let i=Fn.encode(t);return await this.datastore.put(Su(e),i,o),{peer:da(e,t,this.maxAddressAge),previous:n?.peer,updated:n==null||!u_(t,n.peerPB)}}#r(e,t){if(t.updated==null)return!0;if(this.peerId.equals(e))return!1;let n=t.updated<Date.now()-this.maxPeerAge,o=Date.now()-this.maxAddressAge,i=t.addresses.filter(s=>s.observed!=null&&s.observed>o);return n&&i.length===0}};var $w=class{store;events;peerId;log;constructor(e,t={}){this.log=e.logger.forComponent("libp2p:peer-store"),this.events=e.events,this.peerId=e.peerId,this.store=new Ch(e,t)}[Symbol.toStringTag]="@libp2p/peer-store";async forEach(e,t){for await(let n of this.store.all(t))e(n)}async all(e){return Bi(this.store.all(e))}async delete(e,t){let n=await this.store.getReadLock(e,t);try{await this.store.delete(e,t)}finally{n()}}async has(e,t){let n=await this.store.getReadLock(e,t);try{return await this.store.has(e,t)}finally{this.log.trace("has release read lock"),n?.()}}async get(e,t){let n=await this.store.getReadLock(e,t);try{return await this.store.load(e,t)}finally{n?.()}}async getInfo(e,t){let n=await this.get(e,t);return{id:n.id,multiaddrs:n.addresses.map(({multiaddr:o})=>o)}}async save(e,t,n){let o=await this.store.getWriteLock(e,n);try{let i=await this.store.save(e,t,n);return this.#e(e,i),i.peer}finally{o?.()}}async patch(e,t,n){let o=await this.store.getWriteLock(e,n);try{let i=await this.store.patch(e,t,n);return this.#e(e,i),i.peer}finally{o?.()}}async merge(e,t,n){let o=await this.store.getWriteLock(e,n);try{let i=await this.store.merge(e,t,n);return this.#e(e,i),i.peer}finally{o?.()}}async consumePeerRecord(e,t,n){let o=nr(t)?t:nr(t?.expectedPeer)?t.expectedPeer:void 0,i=nr(t)||t===void 0?n:t,s=await fa.openAndCertify(e,Pi.DOMAIN,i),a=Bn(s.publicKey.toCID());if(o?.equals(a)===!1)return this.log("envelope peer id was not the expected peer id - expected: %p received: %p",o,a),!1;let c=Pi.createFromProtobuf(s.payload),u;try{u=await this.get(a,i)}catch(l){if(l.name!=="NotFoundError")throw l}if(u?.peerRecordEnvelope!=null){let l=fa.createFromProtobuf(u.peerRecordEnvelope),f=Pi.createFromProtobuf(l.payload);if(f.seqNumber>=c.seqNumber)return this.log("sequence number was lower or equal to existing sequence number - stored: %d received: %d",f.seqNumber,c.seqNumber),!1}return await this.patch(c.peerId,{peerRecordEnvelope:e,addresses:c.multiaddrs.map(l=>({isCertified:!0,multiaddr:l}))},i),!0}#e(e,t){t.updated&&(this.peerId.equals(e)?this.events.safeDispatchEvent("self:peer:update",{detail:t}):this.events.safeDispatchEvent("peer:update",{detail:t}))}};function w_(r,e={}){return new $w(r,e)}var b_=864e13;var Bh=class{log;mappings;constructor(e,t={}){this.log=e.logger.forComponent("libp2p:address-manager:dns-mappings"),this.mappings=xt({name:"libp2p_address_manager_dns_mappings",metrics:e.metrics})}has(e){let t=ue(e),n=t.host;(t.type==="ip4"||t.type==="ip6")&&t.sni!=null&&(n=t.sni);for(let o of this.mappings.values())if(o.domain===n)return!0;return!1}add(e,t){t.forEach(n=>{this.log("add DNS mapping %s to %s",n,e);let o=ws(n)===!0;this.mappings.set(n,{domain:e,verified:o,expires:o?b_-Date.now():0,lastVerified:o?b_-Date.now():void 0})})}remove(e){let t=ue(e);if(t.type!=="ip4"&&t.type!=="ip6")return!1;let n=!1;for(let[o,i]of this.mappings.entries())i.domain===t.sni&&(this.log("removing %s to %s DNS mapping %e",o,i.domain),this.mappings.delete(o),n=n||i.verified);return n}getAll(e){let t=[];for(let n=0;n<e.length;n++){let o=e[n].multiaddr;if(!dt(o))continue;let i=ue(o);for(let[s,a]of this.mappings.entries()){if(i.host!==s)continue;let c=this.maybeAddSNIComponent(o,a.domain);c!=null&&(e.splice(n,1),n--,t.push({multiaddr:c,verified:a.verified,type:"dns-mapping",expires:a.expires,lastVerified:a.lastVerified}))}}return t}maybeAddSNIComponent(e,t){let n=e.getComponents();for(let o=0;o<n.length;o++)if(n[o].code===448&&n[o+1]?.code!==449)return n.splice(o+1,0,{name:"sni",code:449,value:t}),fe(n)}confirm(e,t){let n=ue(e),o=n.host;(n.type==="ip4"||n.type==="ip6")&&n.sni!=null&&(o=n.sni);let i=!1;for(let[s,a]of this.mappings.entries())a.domain===o&&(this.log("marking %s to %s DNS mapping as verified",s,a.domain),i=a.verified,a.verified=!0,a.expires=Date.now()+t,a.lastVerified=Date.now());return i}unconfirm(e,t){let n=ue(e);if(n.type!=="ip4"&&n.type!=="ip6")return!1;let o=n.sni??n.host,i=!1;for(let[s,a]of this.mappings.entries())a.domain===o&&(this.log("removing verification of %s to %s DNS mapping",s,a.domain),i=i||a.verified,a.verified=!1,a.expires=Date.now()+t);return i}};var Nh=class{log;mappings;constructor(e,t={}){this.log=e.logger.forComponent("libp2p:address-manager:ip-mappings"),this.mappings=xt({name:"libp2p_address_manager_ip_mappings",metrics:e.metrics})}has(e){let t=ue(e);if(t.type!=="ip4"&&t.type!=="ip6")return!1;for(let n of this.mappings.values())for(let o of n)if(o.externalIp===t.host)return!0;return!1}add(e,t,n,o=t,i="tcp"){let s=`${e}-${t}-${i}`,a=this.mappings.get(s)??[],c={internalIp:e,internalPort:t,externalIp:n,externalPort:o,externalFamily:Mr(n)?4:6,protocol:i,verified:!1,expires:0};a.push(c),this.mappings.set(s,a)}remove(e){let t=ue(e);if(t.type!=="ip4"&&t.type!=="ip6")return!1;let n=!1;for(let[o,i]of this.mappings.entries()){for(let s=0;s<i.length;s++){let a=i[s];a.externalIp===t.host&&a.externalPort===t.port&&a.protocol===t.protocol&&(this.log("removing %s:%s to %s:%s %s IP mapping",a.externalIp,a.externalPort,t.host,t.port,t.protocol),n=n||a.verified,i.splice(s,1),s--)}i.length===0&&this.mappings.delete(o)}return n}getAll(e){let t=[];for(let{multiaddr:n}of e){if(!dt(n))continue;let o=ue(n);if(o.type!=="ip4"&&o.type!=="ip6")continue;let i;if(o.protocol==="tcp"?i=`${o.host}-${o.port}-tcp`:o.protocol==="udp"&&(i=`${o.host}-${o.port}-udp`),i==null)continue;let s=this.mappings.get(i);if(s!=null)for(let a of s)t.push({multiaddr:this.maybeOverrideIp(n,a.externalIp,a.externalFamily,a.protocol,a.externalPort),verified:a.verified,type:"ip-mapping",expires:a.expires,lastVerified:a.lastVerified})}return t}maybeOverrideIp(e,t,n,o,i){let s=e.getComponents(),a=s.findIndex(u=>u.code===4||u.code===41),c=s.findIndex(u=>u.name===o);return a>-1&&c>-1?(s[a].value=t,s[a].code=n===4?4:41,s[c].value=`${i}`,fe(s)):e}confirm(e,t){if(!dt(e))return!1;let n=ue(e),o=!1;for(let i of this.mappings.values())for(let s of i)s.externalIp===n.host&&(this.log("marking %s to %s IP mapping as verified",s.internalIp,s.externalIp),o=s.verified,s.verified=!0,s.expires=Date.now()+t,s.lastVerified=Date.now());return o}unconfirm(e,t){if(!dt(e))return!1;let n=ue(e),o=!1;for(let i of this.mappings.values())for(let s=0;s<i.length;s++){let a=i[s];a.externalIp===n.host&&a.externalPort===n.port&&a.protocol===n.protocol&&(this.log("removing verification of %s:%s to %s:%s %s IP mapping",a.externalIp,a.externalPort,n.host,n.port,n.protocol),o=o||a.verified,a.verified=!1,a.expires=Date.now()+t)}return o}};var HP={maxObservedAddresses:10},Ph=class{log;addresses;maxObservedAddresses;constructor(e,t={}){this.log=e.logger.forComponent("libp2p:address-manager:observed-addresses"),this.addresses=xt({name:"libp2p_address_manager_observed_addresses",metrics:e.metrics}),this.maxObservedAddresses=t.maxObservedAddresses??HP.maxObservedAddresses}has(e){return this.addresses.has(e.toString())}removePrefixed(e){for(let t of this.addresses.keys())t.toString().startsWith(e)&&this.addresses.delete(t)}add(e){this.addresses.size!==this.maxObservedAddresses&&(Fr(e)||VE(e)||(this.log("adding observed address %a",e),this.addresses.set(e.toString(),{verified:!1,expires:0})))}getAll(){return Array.from(this.addresses).map(([e,t])=>({multiaddr:fe(e),verified:t.verified,type:"observed",expires:t.expires,lastVerified:t.lastVerified}))}remove(e){let t=this.addresses.get(e.toString())?.verified??!1;return this.log("removing observed address %a",e),this.addresses.delete(e.toString()),t}confirm(e,t){let n=e.toString(),o=this.addresses.get(n)??{verified:!1,expires:Date.now()+t,lastVerified:Date.now()},i=o.verified;return o.verified=!0,o.expires=Date.now()+t,o.lastVerified=Date.now(),this.log("marking observed address %a as verified",n),this.addresses.set(n,o),i}};var zP={maxObservedAddresses:10},Lh=class{log;addresses;maxObservedAddresses;constructor(e,t={}){this.log=e.logger.forComponent("libp2p:address-manager:observed-addresses"),this.addresses=xt({name:"libp2p_address_manager_transport_addresses",metrics:e.metrics}),this.maxObservedAddresses=t.maxObservedAddresses??zP.maxObservedAddresses}get(e,t){if(Fr(e))return{multiaddr:e,verified:!0,type:"transport",expires:Date.now()+t,lastVerified:Date.now()};let n=this.toKey(e),o=this.addresses.get(n);return o==null&&(o={verified:!dt(e),expires:0},this.addresses.set(n,o)),{multiaddr:e,verified:o.verified,type:"transport",expires:o.expires,lastVerified:o.lastVerified}}has(e){let t=this.toKey(e);return this.addresses.has(t)}remove(e){let t=this.toKey(e),n=this.addresses.get(t)?.verified??!1;return this.log("removing observed address %a",e),this.addresses.delete(t),n}confirm(e,t){let n=this.toKey(e),o=this.addresses.get(n)??{verified:!1,expires:0,lastVerified:0},i=o.verified;return o.verified=!0,o.expires=Date.now()+t,o.lastVerified=Date.now(),this.addresses.set(n,o),i}unconfirm(e,t){let n=this.toKey(e),o=this.addresses.get(n)??{verified:!1,expires:0},i=o.verified;return o.verified=!1,o.expires=Date.now()+t,this.addresses.set(n,o),i}toKey(e){if(!dt(e))return e.toString();let t=ue(e);return`${t.host}-${t.port}-${t.protocol}`}};var x_=6e4,E_={maxObservedAddresses:10,addressVerificationTTL:x_*10,addressVerificationRetry:x_*5},jP=r=>r;function Vw(r,e){let t=r.getComponents().findLast(n=>n.code===421)?.value;return t!=null&&lr(t).equals(e)&&(r=r.decapsulate(fe(`/p2p/${e.toString()}`))),r}var Dh=class{log;components;listen;announce;appendAnnounce;announceFilter;observed;dnsMappings;ipMappings;transportAddresses;observedAddressFilter;addressVerificationTTL;addressVerificationRetry;constructor(e,t={}){let{listen:n=[],announce:o=[],appendAnnounce:i=[]}=t;this.components=e,this.log=e.logger.forComponent("libp2p:address-manager"),this.listen=n.map(s=>s.toString()),this.announce=new Set(o.map(s=>s.toString())),this.appendAnnounce=new Set(i.map(s=>s.toString())),this.observed=new Ph(e,t),this.dnsMappings=new Bh(e,t),this.ipMappings=new Nh(e,t),this.transportAddresses=new Lh(e,t),this.announceFilter=t.announceFilter??jP,this.observedAddressFilter=uo(1024),this.addressVerificationTTL=t.addressVerificationTTL??E_.addressVerificationTTL,this.addressVerificationRetry=t.addressVerificationRetry??E_.addressVerificationRetry,this._updatePeerStoreAddresses=lc(this._updatePeerStoreAddresses.bind(this),1e3),e.events.addEventListener("transport:listening",()=>{this._updatePeerStoreAddresses()}),e.events.addEventListener("transport:close",()=>{this._updatePeerStoreAddresses()})}[Symbol.toStringTag]="@libp2p/address-manager";_updatePeerStoreAddresses(){let e=this.getAddresses().map(t=>t.getComponents().findLast(n=>n.code===421)?.value===this.components.peerId.toString()?t.decapsulate(`/p2p/${this.components.peerId.toString()}`):t);this.components.peerStore.patch(this.components.peerId,{multiaddrs:e}).catch(t=>{this.log.error("error updating addresses - %e",t)})}getListenAddrs(){return Array.from(this.listen).map(e=>fe(e))}getAnnounceAddrs(){return Array.from(this.announce).map(e=>fe(e))}getAppendAnnounceAddrs(){return Array.from(this.appendAnnounce).map(e=>fe(e))}getObservedAddrs(){return this.observed.getAll().map(e=>e.multiaddr)}addObservedAddr(e){let t=ue(e),n;switch(t.type){case"ip4":{n=`${t.host}:${t.port}`;break}case"ip6":{n=`[${t.host}]:${t.port}`;break}default:return}this.observedAddressFilter.has(n)||(this.observedAddressFilter.add(n),e=Vw(e,this.components.peerId),!this.ipMappings.has(e)&&(this.dnsMappings.has(e)||this.observed.add(e)))}confirmObservedAddr(e,t){e=Vw(e,this.components.peerId);let n=!0;(t?.type==="transport"||this.transportAddresses.has(e))&&!this.transportAddresses.confirm(e,t?.ttl??this.addressVerificationTTL)&&n&&(n=!1),(t?.type==="dns-mapping"||this.dnsMappings.has(e))&&!this.dnsMappings.confirm(e,t?.ttl??this.addressVerificationTTL)&&n&&(n=!1),(t?.type==="ip-mapping"||this.ipMappings.has(e))&&!this.ipMappings.confirm(e,t?.ttl??this.addressVerificationTTL)&&n&&(n=!1),(t?.type==="observed"||this.observed.has(e))&&(this.maybeUpgradeToIPMapping(e)?(this.ipMappings.confirm(e,t?.ttl??this.addressVerificationTTL),n=!1):!this.observed.confirm(e,t?.ttl??this.addressVerificationTTL)&&n&&(n=!1)),n||this._updatePeerStoreAddresses()}removeObservedAddr(e,t){e=Vw(e,this.components.peerId);let n=!1;this.observed.has(e)&&!this.observed.remove(e)&&n&&(n=!1),this.transportAddresses.has(e)&&!this.transportAddresses.unconfirm(e,t?.ttl??this.addressVerificationRetry)&&n&&(n=!1),this.dnsMappings.has(e)&&!this.dnsMappings.unconfirm(e,t?.ttl??this.addressVerificationRetry)&&n&&(n=!1),this.ipMappings.has(e)&&!this.ipMappings.unconfirm(e,t?.ttl??this.addressVerificationRetry)&&n&&(n=!1),n&&this._updatePeerStoreAddresses()}getAddresses(){let e=new Set,t=this.getAddressesWithMetadata().filter(n=>{if(!n.verified)return!1;let o=n.multiaddr.toString();return e.has(o)?!1:(e.add(o),!0)}).map(n=>n.multiaddr);return this.announceFilter(t.map(n=>{let o=fe(n);return o.getComponents().pop()?.value===this.components.peerId.toString()?o:o.encapsulate(`/p2p/${this.components.peerId.toString()}`)}))}getAddressesWithMetadata(){let e=this.getAnnounceAddrs();if(e.length>0)return this.components.transportManager.getListeners().forEach(o=>{o.updateAnnounceAddrs(e)}),e.map(o=>({multiaddr:o,verified:!0,type:"announce",expires:Date.now()+this.addressVerificationTTL,lastVerified:Date.now()}));let t=[];t=t.concat(this.components.transportManager.getAddrs().map(o=>this.transportAddresses.get(o,this.addressVerificationTTL)));let n=this.getAppendAnnounceAddrs();return n.length>0&&(this.components.transportManager.getListeners().forEach(o=>{o.updateAnnounceAddrs(n)}),t=t.concat(n.map(o=>({multiaddr:o,verified:!0,type:"announce",expires:Date.now()+this.addressVerificationTTL,lastVerified:Date.now()})))),t=t.concat(this.observed.getAll()),t=t.concat(this.ipMappings.getAll(t)),t=t.concat(this.dnsMappings.getAll(t)),t}addDNSMapping(e,t){this.dnsMappings.add(e,t)}removeDNSMapping(e){this.dnsMappings.remove(fe(`/dns/${e}`))&&this._updatePeerStoreAddresses()}addPublicAddressMapping(e,t,n,o=t,i="tcp"){this.ipMappings.add(e,t,n,o,i),this.observed.removePrefixed(`/ip${Mr(n)?4:6}/${n}/${i}/${o}`)}removePublicAddressMapping(e,t,n,o=t,i="tcp"){this.ipMappings.remove(fe(`/ip${Mr(n)?4:6}/${n}/${i}/${o}`))&&this._updatePeerStoreAddresses()}maybeUpgradeToIPMapping(e){if(this.ipMappings.has(e)||!dt(e))return!1;let t=ue(e);if(t.type!=="ip4"||ws(t.host)===!0)return!1;let n=this.components.transportManager.getListeners(),o=[i=>_i.exactMatch(i)||cu.exactMatch(i),i=>au.exactMatch(i),i=>PS.exactMatch(i)];for(let i of o){if(!i(e))continue;let s=n.filter(u=>u.getAddrs().filter(l=>ue(l).type==="ip4"&&i(l)).length>0);if(s.length!==1)continue;let a=s[0].getAddrs().filter(u=>!uc(u)).pop();if(a==null)continue;let c=ue(a);return c.port==null?!1:(this.observed.remove(e),this.ipMappings.add(c.host,c.port,t.host,t.port,t.protocol),!0)}return!1}};var v_;(function(r){r.NOT_STARTED_YET="The libp2p node is not started yet",r.NOT_FOUND="Not found"})(v_||(v_={}));var Rh=class extends Error{constructor(e="Missing service"){super(e),this.name="MissingServiceError"}},Uh=class extends Error{constructor(e="Unmet service dependencies"){super(e),this.name="UnmetServiceDependenciesError"}},ha=class extends Error{constructor(e="No content routers available"){super(e),this.name="NoContentRoutersError"}},ku=class extends Error{constructor(e="No peer routers available"){super(e),this.name="NoPeerRoutersError"}},Oh=class extends Error{constructor(e="Should not try to find self"){super(e),this.name="QueriedForSelfError"}},Mh=class extends Error{constructor(e="Unhandled protocol error"){super(e),this.name="UnhandledProtocolError"}},Fh=class extends Error{constructor(e="Duplicate protocol handler error"){super(e),this.name="DuplicateProtocolHandlerError"}},_u=class extends Error{constructor(e="Dial denied error"){super(e),this.name="DialDeniedError"}},$h=class extends Error{constructor(e="No transport was configured to listen on this address"){super(e),this.name="UnsupportedListenAddressError"}},Vh=class extends Error{constructor(e="Configured listen addresses could not be listened on"){super(e),this.name="UnsupportedListenAddressesError"}},Kh=class extends Error{constructor(e="No valid addresses"){super(e),this.name="NoValidAddressesError"}},qh=class extends Error{constructor(e="Connection intercepted"){super(e),this.name="ConnectionInterceptedError"}},Hh=class extends Error{constructor(e="Connection denied"){super(e),this.name="ConnectionDeniedError"}},Po=class extends Error{constructor(e="Stream is not multiplexed"){super(e),this.name="MuxerUnavailableError"}},Li=class extends Error{constructor(e="Encryption failed"){super(e),this.name="EncryptionFailedError"}},zh=class extends Error{constructor(e="Transport unavailable"){super(e),this.name="TransportUnavailableError"}},jh=class extends Error{constructor(e="Max recursive depth reached"){super(e),this.name="RecursionLimitError"}};var Kw=class{components={};_started=!1;constructor(e={}){this.components={};for(let[t,n]of Object.entries(e))this.components[t]=n;this.components.logger==null&&(this.components.logger=Cs())}isStarted(){return this._started}async _invokeStartableMethod(e){await Promise.all(Object.values(this.components).filter(t=>el(t)).map(async t=>{await t[e]?.()}))}async beforeStart(){await this._invokeStartableMethod("beforeStart")}async start(){await this._invokeStartableMethod("start"),this._started=!0}async afterStart(){await this._invokeStartableMethod("afterStart")}async beforeStop(){await this._invokeStartableMethod("beforeStop")}async stop(){await this._invokeStartableMethod("stop"),this._started=!1}async afterStop(){await this._invokeStartableMethod("afterStop")}},GP=["metrics","connectionProtector","dns"],WP=["components","isStarted","beforeStart","start","afterStart","beforeStop","stop","afterStop","then","_invokeStartableMethod"];function A_(r={}){let e=new Kw(r);return new Proxy(e,{get(n,o,i){if(typeof o=="string"&&!WP.includes(o)){let s=e.components[o];if(s==null&&!GP.includes(o))throw new Rh(`${o} not set`);return s}return Reflect.get(n,o,i)},set(n,o,i){return typeof o=="string"?e.components[o]=i:Reflect.set(n,o,i),!0}})}function S_(r){let e={};for(let t of Object.values(r.components))for(let n of YP(t))e[n]=!0;for(let t of Object.values(r.components))for(let n of XP(t))if(e[n]!==!0)throw new Uh(`Service "${ZP(t)}" required capability "${n}" but it was not provided by any component, you may need to add additional configuration when creating your node.`)}function YP(r){return Array.isArray(r?.[Fo])?r[Fo]:[]}function XP(r){return Array.isArray(r?.[cm])?r[cm]:[]}function ZP(r){return r?.[Symbol.toStringTag]??r?.toString()??"unknown"}function k_(r={}){return r.denyDialMultiaddr==null&&(r.denyDialMultiaddr=e=>_i.matches(e)?!0:Fr(e)),r}var JP=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 QP(r,e,t){let n,o=new Promise((i,s)=>{if(t={rejectionEvents:["error"],multiArgs:!1,rejectionMultiArgs:!1,resolveImmediately:!1,...t},!(t.count>=0&&(t.count===Number.POSITIVE_INFINITY||Number.isInteger(t.count))))throw new TypeError("The `count` option should be at least 0 or more");t.signal?.throwIfAborted();let a=[e].flat(),c=[],{addListener:u,removeListener:l}=JP(r),f=async(...h)=>{let m=t.multiArgs?h:h[0];if(t.filter)try{if(!await t.filter(m))return}catch(y){n(),s(y);return}c.push(m),t.count===c.length&&(n(),i(c))},d=(...h)=>{n(),s(t.rejectionMultiArgs?h:h[0])};n=()=>{for(let h of a)l(h,f);for(let h of t.rejectionEvents)a.includes(h)||l(h,d)};for(let h of a)u(h,f);for(let h of t.rejectionEvents)a.includes(h)||u(h,d);t.signal&&t.signal.addEventListener("abort",()=>{d(t.signal.reason)},{once:!0}),t.resolveImmediately&&i(c)});if(o.cancel=n,typeof t.timeout=="number"){let i=ui(o,{milliseconds:t.timeout});return i.cancel=()=>{n(),i.clear()},i}return o}function Iu(r,e,t){typeof t=="function"&&(t={filter:t}),t={...t,count:1,resolveImmediately:!1};let n=QP(r,e,t),o=n.then(i=>i[0]);return o.cancel=n.cancel,o}function Gh(r){if(nr(r))return{peerId:r,multiaddrs:[]};let e=Array.isArray(r)?r:[r],t;if(e.length>0){let n=e[0].getComponents().findLast(o=>o.code===421)?.value;t=n==null?void 0:lr(n),e.forEach(o=>{if(!ho(o))throw new Gn("Invalid multiaddr");let i=o.getComponents().findLast(s=>s.code===421)?.value;if(i==null){if(t!=null)throw new T("Multiaddrs must all have the same peer id or have no peer id")}else{let s=lr(i);if(t?.equals(s)!==!0)throw new T("Multiaddrs must all have the same peer id or have no peer id")}})}return e=e.filter(n=>!TS.exactMatch(n)),{peerId:t,multiaddrs:e}}var eL=["/ipfs/id/1.0.0","/ipfs/id/push/1.0.0","/libp2p/autonat/1.0.0","/libp2p/dcutr"];async function __(r,e){let t=r?.streams?.map(o=>o.protocol)??[],n=e?.closableProtocols??eL;if(!(t.filter(o=>o!=null&&!n.includes(o)).length>0))try{await r?.close(e)}catch(o){r?.abort(o)}}function Tu(r){let e=ue(r),t=e.cidr;if(e.type!=="ip4"&&e.type!=="ip6")throw new T(`Multiaddr ${r} was not an IPv4 or IPv6 address`);if(t==null)switch(e.type){case"ip4":{t=32;break}case"ip6":{t=128;break}default:throw new T(`Multiaddr ${r} was not an IPv4 or IPv6 address`)}return new ps(e.host,t)}function qw(r){return!Ii.exactMatch(r)}function Wh(r,e,t){if(r==null||e==null)return;let n=e.filter(i=>i.status==="open").sort((i,s)=>i.direct?-1:s.direct?1:0).find(i=>i.limits==null);if(n==null||n.direct||t==null)return n;if(!t.some(i=>qw(i)))return n}var Yh=class{connectionManager;peerStore;allow;events;log;constructor(e,t={}){this.allow=(t.allow??[]).map(n=>Tu(n)),this.connectionManager=e.connectionManager,this.peerStore=e.peerStore,this.events=e.events,this.log=e.logger.forComponent("libp2p:connection-manager:connection-pruner"),this.maybePruneConnections=this.maybePruneConnections.bind(this)}start(){this.events.addEventListener("connection:open",this.maybePruneConnections)}stop(){this.events.removeEventListener("connection:open",this.maybePruneConnections)}maybePruneConnections(){this._maybePruneConnections().catch(e=>{this.log.error("error while pruning connections - %e",e)})}async _maybePruneConnections(){let e=this.connectionManager.getConnections(),t=e.length,n=this.connectionManager.getMaxConnections();if(this.log("checking max connections limit %d/%d",t,n),t<=n)return;let o=new fr;for(let c of e){let u=c.remotePeer;if(!o.has(u)){o.set(u,0);try{let l=await this.peerStore.get(u);o.set(u,[...l.tags.values()].reduce((f,d)=>f+d.value,0))}catch(l){l.name!=="NotFoundError"&&this.log.error("error loading peer tags - %e",l)}}}let i=this.sortConnections(e,o),s=Math.max(t-n,0),a=[];for(let c of i)if(this.log("too many connections open - closing a connection to %p",c.remotePeer),this.allow.some(l=>{if(dt(c.remoteAddr)){let f=ue(c.remoteAddr);return l.contains(f.host)}return!0})||a.push(c),a.length===s)break;await Promise.all(a.map(async c=>{await __(c,{signal:AbortSignal.timeout(1e3)})})),this.events.safeDispatchEvent("connection:prune",{detail:a})}sortConnections(e,t){return e.sort((n,o)=>{let i=n.timeline.open,s=o.timeline.open;return i<s?1:i>s?-1:0}).sort((n,o)=>n.direction==="outbound"&&o.direction==="inbound"?1:n.direction==="inbound"&&o.direction==="outbound"?-1:0).sort((n,o)=>n.streams.length>o.streams.length?1:n.streams.length<o.streams.length?-1:0).sort((n,o)=>{let i=t.get(n.remotePeer)??0,s=t.get(o.remotePeer)??0;return i>s?1:i<s?-1:0})}};var I_="last-dial-failure",T_="last-dial-success";var C_=100,Xh=50;function tL(r,e){let t=au.exactMatch(r.multiaddr),n=au.exactMatch(e.multiaddr);if(t&&!n)return-1;if(!t&&n)return 1;let o=cu.exactMatch(r.multiaddr),i=cu.exactMatch(e.multiaddr);if(o&&!i)return-1;if(!o&&i)return 1;let s=_i.exactMatch(r.multiaddr),a=_i.exactMatch(e.multiaddr);if(s&&!a)return-1;if(!s&&a)return 1;let c=yw.exactMatch(r.multiaddr),u=yw.exactMatch(e.multiaddr);if(c&&!u)return-1;if(!c&&u)return 1;let l=mw.exactMatch(r.multiaddr),f=mw.exactMatch(e.multiaddr);if(l&&!f)return-1;if(!l&&f)return 1;let d=gw.exactMatch(r.multiaddr),h=gw.exactMatch(e.multiaddr);return d&&!h?-1:!d&&h?1:0}function rL(r,e){let t=uc(r.multiaddr),n=uc(e.multiaddr);return t&&!n?1:!t&&n?-1:0}function nL(r,e){let t=Fr(r.multiaddr),n=Fr(e.multiaddr);return t&&!n?1:!t&&n?-1:0}function oL(r,e){return r.isCertified&&!e.isCertified?-1:!r.isCertified&&e.isCertified?1:0}function iL(r,e){let t=Ii.exactMatch(r.multiaddr),n=Ii.exactMatch(e.multiaddr);return t&&!n?1:!t&&n?-1:0}function B_(r){return r.sort(tL).sort(oL).sort(iL).sort(nL).sort(rL)}var Hw=class{dns;canResolve(e){return e.getComponents().some(({name:t})=>t==="dnsaddr")}async resolve(e,t){let n=e.getComponents().find(c=>c.name==="dnsaddr")?.value;if(n==null)return[e];let i=await this.getDNS(t).query(`_dnsaddr.${n}`,{signal:t?.signal,types:[$t.TXT]}),s=e.getComponents().find(c=>c.name==="p2p")?.value,a=[];for(let c of i.Answer){let u=c.data.replace(/["']/g,"").trim().split("=")[1];u!=null&&(s!=null&&!u.includes(s)||a.push(fe(u)))}return a}getDNS(e){return e.dns!=null?e.dns:(this.dns==null&&(this.dns=vf()),this.dns)}},Cu=new Hw;async function zw(r,e,t){let n=t.depth??0;if(n>(t.maxRecursiveDepth??32))throw new jh("Max recursive depth reached");let o=!1,i=[];for(let s of Object.values(e))if(s.canResolve(r)){o=!0;let a=await s.resolve(r,t);for(let c of a)i.push(...await zw(c,e,{...t,depth:n+1}))}return o===!1&&i.push(r),i}var Bu={maxParallelDials:Xh,maxDialQueueLength:500,maxPeerAddrsToDial:25,dialTimeout:1e4,resolvers:{dnsaddr:Cu}},Zh=class{queue;components;addressSorter;maxPeerAddrsToDial;maxDialQueueLength;dialTimeout;shutDownController;connections;log;resolvers;constructor(e,t={}){this.addressSorter=t.addressSorter,this.maxPeerAddrsToDial=t.maxPeerAddrsToDial??Bu.maxPeerAddrsToDial,this.maxDialQueueLength=t.maxDialQueueLength??Bu.maxDialQueueLength,this.dialTimeout=t.dialTimeout??Bu.dialTimeout,this.connections=t.connections??new fr,this.log=e.logger.forComponent("libp2p:connection-manager:dial-queue"),this.components=e,this.resolvers=t.resolvers??Bu.resolvers,this.shutDownController=new AbortController,this.shutDownController.signal,this.queue=new ff({concurrency:t.maxParallelDials??Bu.maxParallelDials,metricName:"libp2p_dial_queue",metrics:e.metrics}),this.queue.addEventListener("failure",n=>{n.detail?.error.name!==Rt.name&&this.log.error("error in dial queue - %e",n.detail.error)})}start(){this.shutDownController=new AbortController,this.shutDownController.signal}stop(){this.shutDownController.abort(),this.queue.abort()}async dial(e,t={}){let{peerId:n,multiaddrs:o}=Gh(e);if(n!=null&&t.force!==!0){let s=Wh(n,this.connections.get(n),o);if(s!=null)return this.log("already connected to %a",s.remoteAddr),t.onProgress?.(new $("dial-queue:already-connected",s)),s}let i=this.queue.queue.find(s=>{if(n?.equals(s.options.peerId)===!0)return!0;let a=s.options.multiaddrs;if(a==null)return!1;for(let c of o)if(a.has(c.toString()))return!0;return!1});if(i!=null){this.log("joining existing dial target for %p",n);for(let s of o)i.options.multiaddrs.add(s.toString());return t.onProgress?.(new $("dial-queue:already-in-dial-queue")),i.join(t)}if(this.queue.size>=this.maxDialQueueLength)throw new Vi("Dial queue is full");return this.log("creating dial target for %p",n,o.map(s=>s.toString())),t.onProgress?.(new $("dial-queue:add-to-dial-queue")),this.queue.add(async s=>{s.onProgress?.(new $("dial-queue:start-dial"));let a=Ie([this.shutDownController.signal,s.signal]);try{return await this.dialPeer(s,a)}finally{a.clear()}},{peerId:n,priority:t.priority??Yw,multiaddrs:new Set(o.map(s=>s.toString())),signal:t.signal??AbortSignal.timeout(this.dialTimeout),onProgress:t.onProgress})}async dialPeer(e,t){let n=e.peerId,o=e.multiaddrs,i=new Set,s=e.multiaddrs.size===0,a=0,c=0,u=[];for(this.log("starting dial to %p",n);s||o.size>0;){c++,s=!1;let l=[],f=new Set(e.multiaddrs);o.clear(),this.log("calculating addrs to dial %p from %s",n,[...f]);let d=await this.calculateMultiaddrs(n,f,{...e,signal:t});for(let h of d){if(i.has(h.multiaddr.toString())){this.log.trace("skipping previously failed multiaddr %a while dialing %p",h.multiaddr,n);continue}l.push(h)}this.log("%s dial to %p with %s",c===1?"starting":"continuing",n,l.map(h=>h.multiaddr.toString())),e?.onProgress?.(new $("dial-queue:calculated-addresses",l));for(let h of l){if(a===this.maxPeerAddrsToDial)throw this.log("dialed maxPeerAddrsToDial (%d) addresses for %p, not trying any others",a,e.peerId),new Vi("Peer had more than maxPeerAddrsToDial");a++;try{let m=await this.components.transportManager.dial(h.multiaddr,{...e,signal:t});this.log("dial to %a succeeded",h.multiaddr);try{await this.components.peerStore.merge(m.remotePeer,{multiaddrs:[m.remoteAddr],metadata:{[T_]:L(Date.now().toString())}})}catch(y){this.log.error("could not update last dial failure key for %p - %e",n,y)}return m}catch(m){if(this.log.error("dial failed to %a - %e",h.multiaddr,m),i.add(h.multiaddr.toString()),n!=null)try{await this.components.peerStore.merge(n,{metadata:{[I_]:L(Date.now().toString())}})}catch(y){this.log.error("could not update last dial failure key for %p - %e",n,y)}if(t.aborted)throw new Yu(m.message);u.push(m)}}}throw u.length===1?u[0]:new AggregateError(u,"All multiaddr dials failed")}async calculateMultiaddrs(e,t=new Set,n={}){let o=[...t].map(f=>({multiaddr:fe(f),isCertified:!1}));if(e!=null){if(this.components.peerId.equals(e))throw new Vi("Tried to dial self");if(await this.components.connectionGater.denyDialPeer?.(e)===!0)throw new _u("The dial request is blocked by gater.allowDialPeer");if(o.length===0){this.log("loading multiaddrs for %p",e);try{let f=await this.components.peerStore.get(e);o.push(...f.addresses),this.log("loaded multiaddrs for %p",e,o.map(({multiaddr:d})=>d.toString()))}catch(f){if(f.name!=="NotFoundError")throw f}}if(o.length===0){this.log("looking up multiaddrs for %p in the peer routing",e);try{let f=await this.components.peerRouting.findPeer(e,n);this.log("found multiaddrs for %p in the peer routing",e,o.map(({multiaddr:d})=>d.toString())),o.push(...f.multiaddrs.map(d=>({multiaddr:d,isCertified:!1})))}catch(f){f.name==="NoPeerRoutersError"?this.log("no peer routers configured",e):this.log.error("looking up multiaddrs for %p in the peer routing failed - %e",e,f)}}}let i=(await Promise.all(o.map(async f=>{let d=await zw(f.multiaddr,this.resolvers,{dns:this.components.dns,log:this.log,...n});return d.length===1&&d[0].equals(f.multiaddr)?f:d.map(h=>({multiaddr:h,isCertified:!1}))}))).flat();if(e!=null){let f=`/p2p/${e.toString()}`;i=i.map(d=>d.multiaddr.getComponents().pop()?.name!=="p2p"?{multiaddr:d.multiaddr.encapsulate(f),isCertified:d.isCertified}:d)}let s=i.filter(f=>{if(this.components.transportManager.dialTransportForMultiaddr(f.multiaddr)==null)return!1;let d=f.multiaddr.getComponents().findLast(h=>h.code===421)?.value;return e!=null&&d!=null?e.equals(d):!0}),a=new Map;for(let f of s){let d=f.multiaddr.toString(),h=a.get(d);if(h!=null){h.isCertified=h.isCertified||f.isCertified||!1;continue}a.set(d,f)}let c=[...a.values()];if(c.length===0)throw new Kh("The dial request has no valid addresses");let u=[];for(let f of c)this.components.connectionGater.denyDialMultiaddr!=null&&await this.components.connectionGater.denyDialMultiaddr(f.multiaddr)||u.push(f);let l=this.addressSorter==null?B_(u):u.sort(this.addressSorter);if(l.length===0)throw new _u("The connection gater denied all addresses in the dial request");return this.log.trace("addresses for %p before filtering",e??"unknown peer",i.map(({multiaddr:f})=>f.toString())),this.log.trace("addresses for %p after filtering",e??"unknown peer",l.map(({multiaddr:f})=>f.toString())),l}async isDialable(e,t={}){Array.isArray(e)||(e=[e]);try{let n=await this.calculateMultiaddrs(void 0,new Set(e.map(o=>o.toString())),t);return t.runOnLimitedConnection===!1?n.find(o=>!Ii.matches(o.multiaddr))!=null:!0}catch{}return!1}};var sL=Object.prototype.toString,aL=r=>sL.call(r)==="[object Error]",cL=new Set(["network error","NetworkError when attempting to fetch resource.","The Internet connection appears to be offline.","Network request failed","fetch failed","terminated"," A network error occurred.","Network connection lost"]);function Xw(r){if(!(r&&aL(r)&&r.name==="TypeError"&&typeof r.message=="string"))return!1;let{message:t,stack:n}=r;return t==="Load failed"?n===void 0||"__sentry_captured__"in r:t.startsWith("error sending request for url")||t==="Failed to fetch"||t.startsWith("Failed to fetch (")&&t.endsWith(")")?!0:cL.has(t)}function uL(r){if(typeof r=="number"){if(r<0)throw new TypeError("Expected `retries` to be a non-negative number.");if(Number.isNaN(r))throw new TypeError("Expected `retries` to be a valid number or Infinity, got NaN.")}else if(r!==void 0)throw new TypeError("Expected `retries` to be a number or Infinity.")}function Jh(r,e,{min:t=0,allowInfinity:n=!1}={}){if(e!==void 0){if(typeof e!="number"||Number.isNaN(e))throw new TypeError(`Expected \`${r}\` to be a number${n?" or Infinity":""}.`);if(!n&&!Number.isFinite(e))throw new TypeError(`Expected \`${r}\` to be a finite number.`);if(e<t)throw new TypeError(`Expected \`${r}\` to be \u2265 ${t}.`)}}var Zw=class extends Error{constructor(e){super(),e instanceof Error?(this.originalError=e,{message:e}=e):(this.originalError=new Error(e),this.originalError.stack=this.stack),this.name="AbortError",this.message=e}};function lL(r,e){let t=Math.max(1,r+1),n=e.randomize?Math.random()+1:1,o=Math.round(n*e.minTimeout*e.factor**(t-1));return o=Math.min(o,e.maxTimeout),o}function N_(r,e){return Number.isFinite(e)?e-(performance.now()-r):e}async function fL({error:r,attemptNumber:e,retriesConsumed:t,startTime:n,options:o}){let i=r instanceof Error?r:new TypeError(`Non-error was thrown: "${r}". You should only throw errors.`);if(i instanceof Zw)throw i.originalError;let s=Number.isFinite(o.retries)?Math.max(0,o.retries-t):o.retries,a=o.maxRetryTime??Number.POSITIVE_INFINITY,c=Object.freeze({error:i,attemptNumber:e,retriesLeft:s,retriesConsumed:t});if(await o.onFailedAttempt(c),N_(n,a)<=0)throw i;let u=await o.shouldConsumeRetry(c),l=N_(n,a);if(l<=0||s<=0)throw i;if(i instanceof TypeError&&!Xw(i)){if(u)throw i;return o.signal?.throwIfAborted(),!1}if(!await o.shouldRetry(c))throw i;if(!u)return o.signal?.throwIfAborted(),!1;let f=lL(t,o),d=Math.min(f,l);return o.signal?.throwIfAborted(),d>0&&await new Promise((h,m)=>{let y=()=>{clearTimeout(g),o.signal?.removeEventListener("abort",y),m(o.signal.reason)},g=setTimeout(()=>{o.signal?.removeEventListener("abort",y),h()},d);o.unref&&g.unref?.(),o.signal?.addEventListener("abort",y,{once:!0})}),o.signal?.throwIfAborted(),!0}async function Jw(r,e={}){if(e={...e},uL(e.retries),Object.hasOwn(e,"forever"))throw new Error("The `forever` option is no longer supported. For many use-cases, you can set `retries: Infinity` instead.");e.retries??=10,e.factor??=2,e.minTimeout??=1e3,e.maxTimeout??=Number.POSITIVE_INFINITY,e.maxRetryTime??=Number.POSITIVE_INFINITY,e.randomize??=!1,e.onFailedAttempt??=()=>{},e.shouldRetry??=()=>!0,e.shouldConsumeRetry??=()=>!0,Jh("factor",e.factor,{min:0,allowInfinity:!1}),Jh("minTimeout",e.minTimeout,{min:0,allowInfinity:!1}),Jh("maxTimeout",e.maxTimeout,{min:0,allowInfinity:!0}),Jh("maxRetryTime",e.maxRetryTime,{min:0,allowInfinity:!0}),e.factor>0||(e.factor=1),e.signal?.throwIfAborted();let t=0,n=0,o=performance.now();for(;!Number.isFinite(e.retries)||n<=e.retries;){t++;try{e.signal?.throwIfAborted();let i=await r(t);return e.signal?.throwIfAborted(),i}catch(i){await fL({error:i,attemptNumber:t,retriesConsumed:n,startTime:o,options:e})&&n++}}throw new Error("Retry attempts exhausted without throwing an error.")}var Qh=class{log;queue;started;peerStore;retries;retryInterval;backoffFactor;connectionManager;events;constructor(e,t={}){this.log=e.logger.forComponent("libp2p:reconnect-queue"),this.peerStore=e.peerStore,this.connectionManager=e.connectionManager,this.queue=new Bs({concurrency:t.maxParallelReconnects??5,metricName:"libp2p_reconnect_queue",metrics:e.metrics}),this.started=!1,this.retries=t.retries??5,this.backoffFactor=t.backoffFactor,this.retryInterval=t.retryInterval,this.events=e.events,e.events.addEventListener("peer:disconnect",n=>{this.maybeReconnect(n.detail).catch(o=>{this.log.error("failed to maybe reconnect to %p - %e",n.detail,o)})})}async maybeReconnect(e){if(!this.started)return;let t=await this.peerStore.get(e);P_(t)&&(this.queue.has(e)||this.queue.add(async n=>{await Jw(async o=>{if(this.started)try{await this.connectionManager.openConnection(e,{signal:n?.signal})}catch(i){throw this.log("reconnecting to %p attempt %d of %d failed - %e",e,o,this.retries,i),i}},{signal:n?.signal,retries:this.retries,factor:this.backoffFactor,minTimeout:this.retryInterval})},{peerId:e}).catch(async n=>{this.log.error("failed to reconnect to %p - %e",e,n);let o={};[...t.tags.keys()].forEach(i=>{i.startsWith(am)&&(o[i]=void 0)}),await this.peerStore.merge(e,{tags:o}),this.events.safeDispatchEvent("peer:reconnect-failure",{detail:e})}).catch(async n=>{this.log.error("failed to remove keep-alive tag from %p - %e",e,n)}))}start(){this.started=!0}async afterStart(){Promise.resolve().then(async()=>{let e=await this.peerStore.all({filters:[t=>P_(t)]});await Promise.all(e.map(async t=>{await this.connectionManager.openConnection(t.id).catch(n=>{this.log.error("could not open connection to keepalive peer - %e",n)})}))}).catch(e=>{this.log.error("error reconnect to peers after start - %e",e)})}stop(){this.started=!1,this.queue.abort()}};function P_(r){for(let e of r.tags.keys())if(e.startsWith(am))return!0;return!1}var Yw=50,Qw={maxConnections:C_,inboundConnectionThreshold:5,maxIncomingPendingConnections:10},ep=class{started;connections;allow;deny;maxIncomingPendingConnections;incomingPendingConnections;outboundPendingConnections;maxConnections;dialQueue;reconnectQueue;connectionPruner;inboundConnectionRateLimiter;peerStore;metrics;events;log;peerId;constructor(e,t={}){if(this.maxConnections=t.maxConnections??Qw.maxConnections,this.maxConnections<1)throw new T("Connection Manager maxConnections must be greater than 0");this.connections=new fr,this.started=!1,this.peerId=e.peerId,this.peerStore=e.peerStore,this.metrics=e.metrics,this.events=e.events,this.log=e.logger.forComponent("libp2p:connection-manager"),this.onConnect=this.onConnect.bind(this),this.onDisconnect=this.onDisconnect.bind(this),this.allow=(t.allow??[]).map(n=>Tu(fe(n))),this.deny=(t.deny??[]).map(n=>Tu(fe(n))),this.incomingPendingConnections=0,this.maxIncomingPendingConnections=t.maxIncomingPendingConnections??Qw.maxIncomingPendingConnections,this.outboundPendingConnections=0,this.inboundConnectionRateLimiter=new df({points:t.inboundConnectionThreshold??Qw.inboundConnectionThreshold,duration:1}),this.connectionPruner=new Yh({connectionManager:this,peerStore:e.peerStore,events:e.events,logger:e.logger},{allow:t.allow?.map(n=>fe(n))}),this.dialQueue=new Zh(e,{addressSorter:t.addressSorter,maxParallelDials:t.maxParallelDials??Xh,maxDialQueueLength:t.maxDialQueueLength??500,maxPeerAddrsToDial:t.maxPeerAddrsToDial??25,dialTimeout:t.dialTimeout??1e4,resolvers:t.resolvers??{dnsaddr:Cu},connections:this.connections}),this.reconnectQueue=new Qh({events:e.events,peerStore:e.peerStore,logger:e.logger,connectionManager:this},{retries:t.reconnectRetries,retryInterval:t.reconnectRetryInterval,backoffFactor:t.reconnectBackoffFactor,maxParallelReconnects:t.maxParallelReconnects})}[Symbol.toStringTag]="@libp2p/connection-manager";async start(){this.metrics?.registerMetricGroup("libp2p_connection_manager_connections",{calculate:()=>{let e={inbound:0,"inbound pending":this.incomingPendingConnections,outbound:0,"outbound pending":this.outboundPendingConnections};for(let t of this.connections.values())for(let n of t)e[n.direction]++;return e}}),this.metrics?.registerMetricGroup("libp2p_protocol_streams_total",{label:"protocol",calculate:()=>{let e={};for(let t of this.connections.values())for(let n of t)for(let o of n.streams){let i=`${o.direction} ${o.protocol??"unnegotiated"}`;e[i]=(e[i]??0)+1}return e}}),this.metrics?.registerMetricGroup("libp2p_connection_manager_protocol_streams_per_connection_90th_percentile",{label:"protocol",calculate:()=>{let e={};for(let n of this.connections.values())for(let o of n){let i={};for(let s of o.streams){let a=`${s.direction} ${s.protocol??"unnegotiated"}`;i[a]=(i[a]??0)+1}for(let[s,a]of Object.entries(i))e[s]=e[s]??[],e[s].push(a)}let t={};for(let[n,o]of Object.entries(e)){o=o.sort((s,a)=>s-a);let i=Math.floor(o.length*.9);t[n]=o[i]}return t}}),this.events.addEventListener("connection:open",this.onConnect),this.events.addEventListener("connection:close",this.onDisconnect),await rn(this.dialQueue,this.reconnectQueue,this.connectionPruner),this.started=!0,this.log("started")}async stop(){this.events.removeEventListener("connection:open",this.onConnect),this.events.removeEventListener("connection:close",this.onDisconnect),await nn(this.reconnectQueue,this.dialQueue,this.connectionPruner);let e=[];for(let t of this.connections.values())for(let n of t)e.push(Promise.all([Iu(n,"close",{signal:AbortSignal.timeout(500)}),n.close({signal:AbortSignal.timeout(500)})]).catch(o=>{n.abort(o)}));this.log("closing %d connections",e.length),await Promise.all(e),this.connections.clear(),this.log("stopped")}getMaxConnections(){return this.maxConnections}setMaxConnections(e){if(e<1)throw new T("Connection Manager maxConnections must be greater than 0");let t=!1;e<this.maxConnections&&(t=!0),this.maxConnections=e,t&&this.connectionPruner.maybePruneConnections()}onConnect(e){this._onConnect(e).catch(t=>{this.log.error("could not connect - %e",t)})}async _onConnect(e){let{detail:t}=e;if(!this.started){await t.close();return}if(t.status!=="open")return;let n=t.remotePeer,o=!this.connections.has(n),i=this.connections.get(n)??[];i.push(t),this.connections.set(n,i),n.publicKey!=null&&n.type==="RSA"&&await this.peerStore.patch(n,{publicKey:n.publicKey}),o&&this.events.safeDispatchEvent("peer:connect",{detail:t.remotePeer})}onDisconnect(e){let{detail:t}=e,n=t.remotePeer,i=(this.connections.get(n)??[]).filter(s=>s.id!==t.id);this.connections.set(n,i),i.length===0&&(this.log.trace("peer %p disconnected, removing connection map entry",n),this.connections.delete(n),this.events.safeDispatchEvent("peer:disconnect",{detail:n}))}getConnections(e){if(e!=null)return this.connections.get(e)??[];let t=[];for(let n of this.connections.values())t=t.concat(n);return t}getConnectionsMap(){return this.connections}async openConnection(e,t={}){if(!this.started)throw new An("Not started");this.outboundPendingConnections++;try{t.signal?.throwIfAborted(),t?.onProgress?.(new $("connection:open",e));let{peerId:n,multiaddrs:o}=Gh(e);if(this.peerId.equals(n))throw new $i("Can not dial self");if(n!=null&&t.force!==!0){this.log("dial %p",n);let c=Wh(n,this.getConnections(n),o);if(c!=null)return this.log("had an existing connection to %p as %a",n,c.remoteAddr),t.onProgress?.(new $("dial-queue:already-connected")),t.onProgress?.(new $("connection:opened",c)),c}let i=await this.dialQueue.dial(e,{...t,priority:t.priority??Yw});if(i.status!=="open")throw new Oo("Remote closed connection during opening");let s=this.connections.get(i.remotePeer);s==null&&(s=[],this.connections.set(i.remotePeer,s));let a=!1;for(let c of s)if(c.id===i.id&&(a=!0),t.force!==!0&&c.id!==i.id&&c.remoteAddr.equals(i.remoteAddr))return i.abort(new Gn("Duplicate multiaddr connection")),c;return a||s.push(i),t.onProgress?.(new $("connection:opened",i)),i}finally{this.outboundPendingConnections--}}async openStream(e,t,n={}){return(await this.openConnection(e,n)).newStream(t,n)}async closeConnections(e,t={}){let n=this.connections.get(e)??[];await Promise.all(n.map(async o=>{try{await Promise.all([Iu(o,"close",t),o.close(t)])}catch(i){o.abort(i)}}))}acceptIncomingConnection(e){if(this.deny.some(o=>{if(dt(e.remoteAddr)){let i=ue(e.remoteAddr);return o.contains(i.host)}return!1}))return this.log("connection from %a refused - connection remote address was in deny list",e.remoteAddr),!1;if(this.allow.some(o=>{if(dt(e.remoteAddr)){let i=ue(e.remoteAddr);return o.contains(i.host)}return!0}))return this.incomingPendingConnections++,!0;if(this.incomingPendingConnections===this.maxIncomingPendingConnections)return this.log("connection from %a refused - incomingPendingConnections exceeded by host",e.remoteAddr),!1;if(dt(e.remoteAddr)){let o=ue(e.remoteAddr);try{this.inboundConnectionRateLimiter.consume(o.host,1)}catch{return this.log("connection from %a refused - inboundConnectionThreshold exceeded by host %s",e.remoteAddr,o.host),!1}}return this.getConnections().length<this.maxConnections?(this.incomingPendingConnections++,!0):(this.log("connection from %a refused - maxConnections exceeded",e.remoteAddr),!1)}afterUpgradeInbound(){this.incomingPendingConnections--}getDialQueue(){let e={queued:"queued",running:"active",errored:"error",complete:"success"};return this.dialQueue.queue.queue.map(t=>({id:t.id,status:e[t.status],peerId:t.options.peerId,multiaddrs:[...t.options.multiaddrs].map(n=>fe(n))}))}async isDialable(e,t={}){return this.dialQueue.isDialable(e,t)}};var pL=1e4,mL="1.0.0",gL="ping",yL="ipfs",L_=32,wL=!0,tp=class{protocol;components;log;heartbeatInterval;pingIntervalMs;abortController;timeout;abortConnectionOnPingFailure;constructor(e,t={}){this.components=e,this.protocol=`/${t.protocolPrefix??yL}/${gL}/${mL}`,this.log=e.logger.forComponent("libp2p:connection-monitor"),this.pingIntervalMs=t.pingInterval??pL,this.abortConnectionOnPingFailure=t.abortConnectionOnPingFailure??wL,this.timeout=new zl({...t.pingTimeout??{},metrics:e.metrics,metricName:"libp2p_connection_monitor_ping_time_milliseconds"})}[Symbol.toStringTag]="@libp2p/connection-monitor";[Fo]=["@libp2p/connection-monitor"];start(){this.abortController=new AbortController,this.abortController.signal,this.heartbeatInterval=setInterval(()=>{this.components.connectionManager.getConnections().forEach(e=>{Promise.resolve().then(async()=>{let t=Date.now(),n=this.timeout.getTimeoutSignal({signal:this.abortController?.signal});try{let o=await e.newStream(this.protocol,{signal:n,runOnLimitedConnection:!0}),i=By(o);t=Date.now(),await Promise.all([i.write(Dr(L_),{signal:n}),i.read({bytes:L_,signal:n})]),e.rtt=Date.now()-t,await o.close({signal:n})}catch(o){if(o.name!=="UnsupportedProtocolError")throw o;e.rtt=(Date.now()-t)/2}finally{this.timeout.cleanUp(n)}}).catch(t=>{this.log.error("error during heartbeat - %e",t),this.abortConnectionOnPingFailure?(this.log.error("aborting connection due to ping failure"),e.abort(t)):this.log("connection ping failed, but not aborting due to abortConnectionOnPingFailure flag")})})},this.pingIntervalMs)}stop(){this.abortController?.abort(),this.heartbeatInterval!=null&&clearInterval(this.heartbeatInterval)}};var rp=class{routers;started;components;constructor(e,t){this.routers=t.routers??[],this.started=!1,this.components=e,this.findProviders=e.metrics?.traceFunction("libp2p.contentRouting.findProviders",this.findProviders.bind(this),{optionsIndex:1,getAttributesFromArgs:([n],o)=>({...o,cid:n.toString()}),getAttributesFromYieldedValue:(n,o)=>({...o,providers:[...Array.isArray(o.providers)?o.providers:[],n.id.toString()]})})??this.findProviders,this.provide=e.metrics?.traceFunction("libp2p.contentRouting.provide",this.provide.bind(this),{optionsIndex:1,getAttributesFromArgs:([n],o)=>({...o,cid:n.toString()})})??this.provide,this.cancelReprovide=e.metrics?.traceFunction("libp2p.contentRouting.cancelReprovide",this.cancelReprovide.bind(this),{optionsIndex:1,getAttributesFromArgs:([n],o)=>({...o,cid:n.toString()})})??this.cancelReprovide,this.put=e.metrics?.traceFunction("libp2p.contentRouting.put",this.put.bind(this),{optionsIndex:2,getAttributesFromArgs:([n])=>({key:j(n,"base36")})})??this.put,this.get=e.metrics?.traceFunction("libp2p.contentRouting.get",this.get.bind(this),{optionsIndex:1,getAttributesFromArgs:([n])=>({key:j(n,"base36")})})??this.get}[Symbol.toStringTag]="@libp2p/content-routing";isStarted(){return this.started}async start(){this.started=!0}async stop(){this.started=!1}async*findProviders(e,t={}){if(this.routers.length===0)throw new ha("No content routers available");let n=this,o=new gi;for await(let i of cr(...n.routers.filter(s=>s.findProviders instanceof Function).map(s=>s.findProviders(e,t))))i!=null&&(i.multiaddrs.length>0&&await this.components.peerStore.merge(i.id,{multiaddrs:i.multiaddrs},t),!o.has(i.id)&&(o.add(i.id),yield i))}async provide(e,t={}){if(this.routers.length===0)throw new ha("No content routers available");await Promise.all(this.routers.filter(n=>n.provide instanceof Function).map(async n=>{await n.provide(e,t)}))}async cancelReprovide(e,t={}){if(this.routers.length===0)throw new ha("No content routers available");await Promise.all(this.routers.filter(n=>n.cancelReprovide instanceof Function).map(async n=>{await n.cancelReprovide(e,t)}))}async put(e,t,n){if(!this.isStarted())throw new An;await Promise.all(this.routers.filter(o=>o.put instanceof Function).map(async o=>{await o.put(e,t,n)}))}async get(e,t){if(!this.isStarted())throw new An;return Promise.any(this.routers.filter(n=>n.get instanceof Function).map(async n=>n.get(e,t)))}};var np=globalThis.CustomEvent??Event;async function*eb(r,e={}){let t=e.concurrency??1/0;t<1&&(t=1/0);let n=e.ordered??!1,o=new EventTarget,i=[],s=ge(),a=ge(),c=!1,u,l=!1;o.addEventListener("task-complete",()=>{a.resolve()}),Promise.resolve().then(async()=>{try{for await(let m of r){if(i.length===t&&(s=ge(),await s.promise),l)break;let y={done:!1};i.push(y),m().then(g=>{y.done=!0,y.ok=!0,y.value=g,o.dispatchEvent(new np("task-complete"))},g=>{y.done=!0,y.err=g,o.dispatchEvent(new np("task-complete"))})}c=!0,o.dispatchEvent(new np("task-complete"))}catch(m){u=m,o.dispatchEvent(new np("task-complete"))}});function f(){return n?i[0]?.done:!!i.find(m=>m.done)}function*d(){for(;i.length>0&&i[0].done;){let m=i[0];if(i.shift(),m.ok)yield m.value;else throw l=!0,s.resolve(),m.err;s.resolve()}}function*h(){for(;f();)for(let m=0;m<i.length;m++)if(i[m].done){let y=i[m];if(i.splice(m,1),m--,y.ok)yield y.value;else throw l=!0,s.resolve(),y.err;s.resolve()}}for(;;){if(f()||(a=ge(),await a.promise),u!=null||(n?yield*d():yield*h(),u!=null))throw u;if(c&&i.length===0)break}}var op=class{log;peerId;peerStore;routers;constructor(e,t={}){this.log=e.logger.forComponent("libp2p:peer-routing"),this.peerId=e.peerId,this.peerStore=e.peerStore,this.routers=t.routers??[],this.findPeer=e.metrics?.traceFunction("libp2p.peerRouting.findPeer",this.findPeer.bind(this),{optionsIndex:1,getAttributesFromArgs:([n],o)=>({...o,peer:n.toString()})})??this.findPeer,this.getClosestPeers=e.metrics?.traceFunction("libp2p.peerRouting.getClosestPeers",this.getClosestPeers.bind(this),{optionsIndex:1,getAttributesFromArgs:([n],o)=>({...o,key:j(n,"base36")}),getAttributesFromYieldedValue:(n,o)=>({...o,peers:[...Array.isArray(o.peers)?o.peers:[],n.id.toString()]})})??this.getClosestPeers}[Symbol.toStringTag]="@libp2p/peer-routing";async findPeer(e,t){if(this.routers.length===0)throw new ku("No peer routers available");if(e.toString()===this.peerId.toString())throw new Oh("Should not try to find self");let n=this,o=cr(...this.routers.filter(i=>i.findPeer instanceof Function).map(i=>(async function*(){try{yield await i.findPeer(e,t)}catch(s){n.log.error("router failed to find peer - %e",s)}})()));for await(let i of o)if(i!=null)return i.multiaddrs.length>0&&await this.peerStore.merge(i.id,{multiaddrs:i.multiaddrs},t),i;throw new He}async*getClosestPeers(e,t={}){if(this.routers.length===0)throw new ku("No peer routers available");let n=this,o=uo(1024);for await(let i of eb((async function*(){let s=cr(...n.routers.filter(a=>a.getClosestPeers instanceof Function).map(a=>a.getClosestPeers(e,t)));for await(let a of s)yield async()=>{if(a.multiaddrs.length===0)try{a=await n.findPeer(a.id,{...t,useCache:!1})}catch(c){n.log.error("could not find peer multiaddrs - %e",c);return}return a}})()))i!=null&&(i.multiaddrs.length>0&&await this.peerStore.merge(i.id,{multiaddrs:i.multiaddrs},t),!o.has(i.id.toMultihash().bytes)&&(o.add(i.id.toMultihash().bytes),yield i))}};var ip=class extends ze{peerRouting;log;walking;walkers;shutdownController;walkController;needNext;constructor(e){super(),this.log=e.logger.forComponent("libp2p:random-walk"),this.peerRouting=e.peerRouting,this.walkers=0,this.walking=!1,this.shutdownController=new AbortController,this.shutdownController.signal}[Symbol.toStringTag]="@libp2p/random-walk";start(){this.shutdownController=new AbortController,this.shutdownController.signal}stop(){this.shutdownController.abort()}async*walk(e){this.walking||this.startWalk(),this.walkers++;let t=Ie([this.shutdownController.signal,e?.signal]);try{for(;;)this.needNext?.resolve(),this.needNext=ge(),yield(await Iu(this,"walk:peer",{signal:t,rejectionEvents:["walk:error"]})).detail}catch(n){throw n.detail!=null?n.detail:n}finally{t.clear(),this.walkers--,this.walkers===0&&(this.walkController?.abort(),this.walkController=void 0)}}startWalk(){this.walking=!0,this.walkController=new AbortController,this.walkController.signal;let e=Ie([this.walkController.signal,this.shutdownController.signal]);let t=Date.now(),n=0;Promise.resolve().then(async()=>{for(this.log("start walk");this.walkers>0;)try{let o=Dr(32),i=Date.now();for await(let s of this.peerRouting.getClosestPeers(o,{signal:e}))e.aborted&&this.log("aborting walk"),e.throwIfAborted(),this.log("found peer %p after %dms for %d walkers",s.id,Date.now()-i,this.walkers),n++,this.safeDispatchEvent("walk:peer",{detail:s}),this.walkers===1&&this.needNext!=null&&(this.log("wait for need next"),await kt(this.needNext.promise,e)),i=Date.now();this.log("walk iteration for %b and %d walkers finished, found %d peers",o,this.walkers,n)}catch(o){this.log.error("random walk errored - %e",o),this.safeDispatchEvent("walk:error",{detail:o})}this.log("no walkers left, ended walk")}).catch(o=>{this.log.error("random walk errored - %e",o)}).finally(()=>{this.log("finished walk, found %d peers after %dms",n,Date.now()-t),this.walking=!1})}};var tb=32,rb=64,sp=class{log;topologies;handlers;components;middleware;constructor(e){this.components=e,this.log=e.logger.forComponent("libp2p:registrar"),this.middleware=new Map,this.topologies=new Map,e.metrics?.registerMetricGroup("libp2p_registrar_topologies",{calculate:()=>{let t={};for(let[n,o]of this.topologies)t[n]=o.size;return t}}),this.handlers=xt({name:"libp2p_registrar_protocol_handlers",metrics:e.metrics}),this._onDisconnect=this._onDisconnect.bind(this),this._onPeerUpdate=this._onPeerUpdate.bind(this),this._onPeerIdentify=this._onPeerIdentify.bind(this),this.components.events.addEventListener("peer:disconnect",this._onDisconnect),this.components.events.addEventListener("peer:update",this._onPeerUpdate),this.components.events.addEventListener("peer:identify",this._onPeerIdentify)}[Symbol.toStringTag]="@libp2p/registrar";getProtocols(){return Array.from(new Set([...this.handlers.keys()])).sort()}getHandler(e){let t=this.handlers.get(e);if(t==null)throw new Mh(`No handler registered for protocol ${e}`);return t}getTopologies(e){let t=this.topologies.get(e);return t==null?[]:[...t.values()]}async handle(e,t,n){if(this.handlers.has(e)&&n?.force!==!0)throw new Fh(`Handler already registered for protocol ${e}`);this.handlers.set(e,{handler:t,options:{maxInboundStreams:tb,maxOutboundStreams:rb,...n}}),await this.components.peerStore.merge(this.components.peerId,{protocols:[e]},n)}async unhandle(e,t){(Array.isArray(e)?e:[e]).forEach(o=>{this.handlers.delete(o)}),await this.components.peerStore.patch(this.components.peerId,{protocols:this.getProtocols()},t)}async register(e,t){if(t==null)throw new T("invalid topology");let n=`${(Math.random()*1e9).toString(36)}${Date.now()}`,o=this.topologies.get(e);return o==null&&(o=new Map,this.topologies.set(e,o)),o.set(n,t),n}unregister(e){for(let[t,n]of this.topologies.entries())n.has(e)&&(n.delete(e),n.size===0&&this.topologies.delete(t))}use(e,t){this.middleware.set(e,t)}unuse(e){this.middleware.delete(e)}getMiddleware(e){return this.middleware.get(e)??[]}async _onDisconnect(e){let t=e.detail,n={signal:AbortSignal.timeout(5e3)};try{let o=await this.components.peerStore.get(t,n);for(let i of o.protocols){let s=this.topologies.get(i);s!=null&&await Promise.all([...s.values()].map(async a=>{a.filter!=null&&a.filter.has(t)!==!0||(a.filter?.remove(t),await a.onDisconnect?.(t))}))}}catch(o){if(o.name==="NotFoundError")return;this.log.error("could not inform topologies of disconnecting peer %p - %e",t,o)}}async _onPeerUpdate(e){let{peer:t,previous:n}=e.detail,o=(n?.protocols??[]).filter(i=>!t.protocols.includes(i));try{for(let i of o){let s=this.topologies.get(i);s!=null&&await Promise.all([...s.values()].map(async a=>{a.filter!=null&&a.filter.has(t.id)!==!0||(a.filter?.remove(t.id),await a.onDisconnect?.(t.id))}))}}catch(i){this.log.error("could not inform topologies of updated peer %p - %e",t.id,i)}}async _onPeerIdentify(e){let t=e.detail.protocols,n=e.detail.connection,o=e.detail.peerId;try{for(let i of t){let s=this.topologies.get(i);s!=null&&await Promise.all([...s.values()].map(async a=>{n.limits!=null&&a.notifyOnLimitedConnection!==!0||a.filter?.has(o)!==!0&&(a.filter?.add(o),await a.onConnect?.(o,n))}))}}catch(i){this.log.error("could not inform topologies of updated peer after identify %p - %e",o,i)}}};var ap=class{log;components;transports;listeners;faultTolerance;started;constructor(e,t={}){this.log=e.logger.forComponent("libp2p:transports"),this.components=e,this.started=!1,this.transports=xt({name:"libp2p_transport_manager_transports",metrics:this.components.metrics}),this.listeners=xt({name:"libp2p_transport_manager_listeners",metrics:this.components.metrics}),this.faultTolerance=t.faultTolerance??Sa.FATAL_ALL}[Symbol.toStringTag]="@libp2p/transport-manager";add(e){let t=e[Symbol.toStringTag];if(t==null)throw new T("Transport must have a valid tag");if(this.transports.has(t))throw new T(`There is already a transport with the tag ${t}`);this.log("adding transport %s",t),this.transports.set(t,e),this.listeners.has(t)||this.listeners.set(t,[])}isStarted(){return this.started}start(){this.started=!0}async afterStart(){let e=this.components.addressManager.getListenAddrs();await this.listen(e)}async stop(){let e=[];for(let[t,n]of this.listeners)for(this.log("closing listeners for %s",t);n.length>0;){let o=n.pop();o!=null&&e.push(o.close())}await Promise.all(e),this.log("all listeners closed");for(let t of this.listeners.keys())this.listeners.set(t,[]);this.started=!1}async dial(e,t){let n=this.dialTransportForMultiaddr(e);if(n==null)throw new zh(`No transport available for address ${String(e)}`);return t?.onProgress?.(new $("transport-manager:selected-transport",n[Symbol.toStringTag])),n.dial(e,{...t,upgrader:this.components.upgrader})}getAddrs(){let e=[];for(let t of this.listeners.values())for(let n of t)e=[...e,...n.getAddrs()];return e}getTransports(){return Array.of(...this.transports.values())}getListeners(){return Array.of(...this.listeners.values()).flat()}dialTransportForMultiaddr(e){for(let t of this.transports.values())if(t.dialFilter([e]).length>0)return t}listenTransportForMultiaddr(e){for(let t of this.transports.values())if(t.listenFilter([e]).length>0)return t}async listen(e){if(!this.isStarted())throw new An("Not started");if(e==null||e.length===0){this.log("no addresses were provided for listening, this node is dial only");return}let t={errors:new Map,ipv4:{success:0,attempts:0},ipv6:{success:0,attempts:0}};e.forEach(i=>{t.errors.set(i.toString(),new $h)});let n=[];for(let[i,s]of this.transports.entries()){let a=s.listenFilter(e);for(let c of a){this.log("creating listener for %s on %a",i,c);let u=s.createListener({upgrader:this.components.upgrader}),l=this.listeners.get(i)??[];l==null&&(l=[],this.listeners.set(i,l)),l.push(u),u.addEventListener("listening",()=>{this.components.events.safeDispatchEvent("transport:listening",{detail:u})}),u.addEventListener("close",()=>{let f=l.findIndex(d=>d===u);l.splice(f,1),this.components.events.safeDispatchEvent("transport:close",{detail:u})}),fw.matches(c)?t.ipv4.attempts++:dw.matches(c)&&t.ipv6.attempts++,n.push(u.listen(c).then(()=>{t.errors.delete(c.toString()),fw.matches(c)&&t.ipv4.success++,dw.matches(c)&&t.ipv6.success++},f=>{throw this.log.error("transport %s could not listen on address %a - %e",i,c,f),t.errors.set(c.toString(),f),f}))}}let o=await Promise.allSettled(n);if(!(o.length>0&&o.every(i=>i.status==="fulfilled"))){if(this.ipv6Unsupported(t)){this.log("all IPv4 addresses succeed but all IPv6 failed");return}if(this.faultTolerance===Sa.NO_FATAL){this.log("failed to listen on any address but fault tolerance allows this");return}throw new Vh(`Some configured addresses failed to be listened on, you may need to remove one or more listen addresses from your configuration or set \`transportManager.faultTolerance\` to NO_FATAL:
|
|
32
|
+
`)),!d.ok)throw this.#t++,new Error(`Unable to fetch raw block for CID ${e} from gateway ${this.url}, received ${d.status} ${d.statusText}`);t.onProgress?.(new $("helia:block-broker:connected",{broker:"trustless-gateway",type:"connected",provider:this.peer,address:zd(n.toString()),cid:e})),t.onProgress?.(new $("helia:block-broker:request-block",{broker:"trustless-gateway",type:"request-block",provider:this.peer,cid:e}));let h=await FS(d,o,{signal:s.signal,log:this.log});return t.onProgress?.(new $("helia:block-broker:receive-block",{broker:"trustless-gateway",type:"receive-block",provider:this.peer,cid:e})),this.#a++,h}),this.#c.set(i,c)}return await c}catch(c){throw t.signal?.aborted===!0?new Error(`Fetching raw block for CID ${e} from gateway ${this.url} was aborted`):(this.#t++,new Error(`Unable to fetch raw block for CID ${e} - ${c.message}`))}finally{t.signal?.removeEventListener("abort",a),this.#c.delete(i)}}reliability(){return this.#e===0?1:this.#r>0?-1/0:this.#a/(this.#e+this.#t*3)}incrementInvalidBlocks(){this.#r++}getStats(){return{attempts:this.#e,errors:this.#t,invalidBlocks:this.#r,successes:this.#a,pendingResponses:this.#c.size}}toString(){return`TrustlessGateway(${this.url})`}};var bw=class extends iu{name="trustless-gateway-session";routing;allowInsecure;allowLocal;transformRequestInit;constructor(e,t){super(e,{...t,name:"helia:trustless-gateway:session"}),this.routing=e.routing,this.allowInsecure=t.allowInsecure??Jd,this.allowLocal=t.allowLocal??Qd,this.transformRequestInit=t.transformRequestInit}async queryProvider(e,t,n){this.log("fetching BLOCK for %c from %s",e,t.url),n?.onProgress?.(new $("helia:block-brokers:query-provider:start",{blockBroker:"trustless-gateway",provider:t.url,transport:"http",cid:e}));let o;try{o=await t.getRawBlock(e,n),this.log.trace("got block for %c from %s",e,t.url)}finally{n?.onProgress?.(new $("helia:block-brokers:query-provider:end",{blockBroker:"trustless-gateway",provider:t.url,transport:"http",cid:e}))}return await n.validateFn?.(o),o}async*findNewProviders(e,t={}){yield*Zd(e,this.routing,this.logger,this.allowInsecure,this.allowLocal,{...t,transformRequestInit:this.transformRequestInit})}toFilterKey(e){return e.url.toString()}equals(e,t){return e.url.toString()===t.url.toString()}async convertToProvider(e,t,n){if(nr(e))return;let o=ww(Array.isArray(e)?e:[e],this.allowInsecure,this.allowLocal);if(o.length===0)return;let i=qd(o[0]);return new ra(i,{logger:this.logger,transformRequestInit:this.transformRequestInit,routing:t})}emitFoundProviderProgressEvent(e,t,n){n?.onProgress?.(new $("trustless-gateway:found-provider",{type:"trustless-gateway",cid:e,url:t.url.toJSON(),routing:t.routing}))}};function VS(r,e){return new bw(r,e)}var eh=class{name="trustless-gateway";allowInsecure;allowLocal;transformRequestInit;routing;log;logger;constructor(e,t={}){this.log=e.logger.forComponent("helia:trustless-gateway-block-broker"),this.logger=e.logger,this.routing=e.routing,this.allowInsecure=t.allowInsecure??Jd,this.allowLocal=t.allowLocal??Qd,this.transformRequestInit=t.transformRequestInit}async retrieve(e,t={}){let n=[];for await(let o of Zd(e,this.routing,this.logger,this.allowInsecure,this.allowLocal,{...t,transformRequestInit:this.transformRequestInit})){this.log("getting block for %c from %s",e,o.url);try{let i=await o.getRawBlock(e,t);this.log.trace("got block for %c from %s",e,o.url);try{await t.validateFn?.(i)}catch(s){this.log.error("failed to validate block for %c from %s - %e",e,o.url,s);continue}return i}catch(i){if(this.log.error("failed to get block for %c from %s - %e",e,o.url,i),i instanceof Error?n.push(i):n.push(new Error(`Unable to fetch raw block for CID ${e} from gateway ${o.url}`)),t.signal?.aborted===!0){this.log.trace("request aborted while fetching raw block for CID %c from gateway %s",e,o.url);break}}}throw n.length>0?new AggregateError(n,`Unable to fetch raw block for CID ${e} from any gateway`):new Error(`Unable to fetch raw block for CID ${e} from any gateway`)}createSession(e={}){return VS({logger:this.logger,routing:this.routing},{...e,allowLocal:this.allowLocal,allowInsecure:this.allowInsecure,transformRequestInit:this.transformRequestInit})}};var Jd=!1,Qd=!1,$S=2097152;function xw(r={}){return e=>new eh(e,r)}async function*uu(r,e={}){let t=r.getReader();try{for(;;){let n=await t.read();if(n.done)return;yield n.value}}finally{e.preventCancel!==!0&&await t.cancel(),t.releaseLock()}}var xP=Ro(vw(),1);var Jr=class extends Error{static name="SignatureVerificationError";constructor(e="Record signature verification failed"){super(e),this.name="SignatureVerificationError"}},th=class extends Error{static name="RecordExpiredError";constructor(e="Record has expired"){super(e),this.name="RecordExpiredError"}},na=class extends Error{static name="UnsupportedValidityError";constructor(e="The validity type is unsupported"){super(e),this.name="UnsupportedValidityError"}},rh=class extends Error{static name="RecordTooLargeError";constructor(e="The record is too large"){super(e),this.name="RecordTooLargeError"}},nh=class extends Error{static name="InvalidValueError";constructor(e="Value must be a valid content path starting with /"){super(e),this.name="InvalidValueError"}},oh=class extends Error{static name="InvalidRecordDataError";constructor(e="Invalid record data"){super(e),this.name="InvalidRecordDataError"}},lu=class extends Error{static name="InvalidEmbeddedPublicKeyError";constructor(e="Invalid embedded public key"){super(e),this.name="InvalidEmbeddedPublicKeyError"}};var Qr;(function(r){let e;(function(a){a.EOL="EOL"})(e=r.ValidityType||(r.ValidityType={}));let t;(function(a){a[a.EOL=0]="EOL"})(t||(t={})),(function(a){a.codec=()=>Za(t)})(e=r.ValidityType||(r.ValidityType={}));let n;r.codec=()=>(n==null&&(n=ft((a,c,u={})=>{u.lengthDelimited!==!1&&c.fork(),a.value!=null&&(c.uint32(10),c.bytes(a.value)),a.signatureV1!=null&&(c.uint32(18),c.bytes(a.signatureV1)),a.validityType!=null&&(c.uint32(24),r.ValidityType.codec().encode(a.validityType,c)),a.validity!=null&&(c.uint32(34),c.bytes(a.validity)),a.sequence!=null&&(c.uint32(40),c.uint64(a.sequence)),a.ttl!=null&&(c.uint32(48),c.uint64(a.ttl)),a.pubKey!=null&&(c.uint32(58),c.bytes(a.pubKey)),a.signatureV2!=null&&(c.uint32(66),c.bytes(a.signatureV2)),a.data!=null&&(c.uint32(74),c.bytes(a.data)),u.lengthDelimited!==!1&&c.ldelim()},(a,c,u={})=>{let l={},f=c==null?a.len:a.pos+c;for(;a.pos<f;){let d=a.uint32();switch(d>>>3){case 1:{l.value=a.bytes();break}case 2:{l.signatureV1=a.bytes();break}case 3:{l.validityType=r.ValidityType.codec().decode(a);break}case 4:{l.validity=a.bytes();break}case 5:{l.sequence=a.uint64();break}case 6:{l.ttl=a.uint64();break}case 7:{l.pubKey=a.bytes();break}case 8:{l.signatureV2=a.bytes();break}case 9:{l.data=a.bytes();break}default:{a.skipType(d&7);break}}}return l},function*(a,c,u,l={}){let f=c==null?a.len:a.pos+c;for(;a.pos<f;){let d=a.uint32();switch(d>>>3){case 1:{yield{field:`${u}.value`,value:a.bytes()};break}case 2:{yield{field:`${u}.signatureV1`,value:a.bytes()};break}case 3:{yield{field:`${u}.validityType`,value:r.ValidityType.codec().decode(a)};break}case 4:{yield{field:`${u}.validity`,value:a.bytes()};break}case 5:{yield{field:`${u}.sequence`,value:a.uint64()};break}case 6:{yield{field:`${u}.ttl`,value:a.uint64()};break}case 7:{yield{field:`${u}.pubKey`,value:a.bytes()};break}case 8:{yield{field:`${u}.signatureV2`,value:a.bytes()};break}case 9:{yield{field:`${u}.data`,value:a.bytes()};break}default:{a.skipType(d&7);break}}}})),n);function o(a){return ut(a,r.codec())}r.encode=o;function i(a,c){return ct(a,r.codec(),c)}r.decode=i;function s(a,c){return lt(a,r.codec(),c)}r.stream=s})(Qr||(Qr={}));var F3=["Object","RegExp","Date","Error","Map","Set","WeakMap","WeakSet","ArrayBuffer","SharedArrayBuffer","DataView","Promise","URL","HTMLElement","Int8Array","Uint8ClampedArray","Int16Array","Uint16Array","Int32Array","Uint32Array","Float32Array","Float64Array","BigInt64Array","BigUint64Array","Tagged"];function KS(r){if(r===null)return"null";if(r===void 0)return"undefined";if(r===!0||r===!1)return"boolean";let e=typeof r;if(e==="string"||e==="number"||e==="bigint"||e==="symbol")return e;if(e==="function")return"Function";if(Array.isArray(r))return"Array";if(r instanceof Uint8Array)return"Uint8Array";if(r.constructor===Object)return"Object";let t=$3(r);return t||"Object"}function $3(r){let e=Object.prototype.toString.call(r).slice(8,-1);if(F3.includes(e))return e}var v=class{constructor(e,t,n){this.major=e,this.majorEncoded=e<<5,this.name=t,this.terminal=n}toString(){return`Type[${this.major}].${this.name}`}compare(e){return this.major<e.major?-1:this.major>e.major?1:0}static equals(e,t){return e===t||e.major===t.major&&e.name===t.name}};v.uint=new v(0,"uint",!0);v.negint=new v(1,"negint",!0);v.bytes=new v(2,"bytes",!0);v.string=new v(3,"string",!0);v.array=new v(4,"array",!1);v.map=new v(5,"map",!1);v.tag=new v(6,"tag",!1);v.float=new v(7,"float",!0);v.false=new v(7,"false",!0);v.true=new v(7,"true",!0);v.null=new v(7,"null",!0);v.undefined=new v(7,"undefined",!0);v.break=new v(7,"break",!0);var G=class{constructor(e,t,n){this.type=e,this.value=t,this.encodedLength=n,this.encodedBytes=void 0,this.byteValue=void 0}toString(){return`Token[${this.type}].${this.value}`}};var fu=globalThis.process&&!globalThis.process.browser&&globalThis.Buffer&&typeof globalThis.Buffer.isBuffer=="function",V3=new TextEncoder;function ih(r){return fu&&globalThis.Buffer.isBuffer(r)}function du(r){return r instanceof Uint8Array?ih(r)?new Uint8Array(r.buffer,r.byteOffset,r.byteLength):r:Uint8Array.from(r)}var K3=24,q3=200,Aw=fu?r=>r.length>=K3?globalThis.Buffer.from(r):qS(r):r=>r.length>=q3?V3.encode(r):qS(r),wn=r=>Uint8Array.from(r),HS=fu?(r,e,t)=>ih(r)?new Uint8Array(r.subarray(e,t)):r.slice(e,t):(r,e,t)=>r.slice(e,t),zS=fu?(r,e)=>(r=r.map(t=>t instanceof Uint8Array?t:globalThis.Buffer.from(t)),du(globalThis.Buffer.concat(r,e))):(r,e)=>{let t=new Uint8Array(e),n=0;for(let o of r)n+o.length>t.length&&(o=o.subarray(0,t.length-n)),t.set(o,n),n+=o.length;return t},jS=fu?r=>globalThis.Buffer.allocUnsafe(r):r=>new Uint8Array(r);function sh(r,e){if(ih(r)&&ih(e))return r.compare(e);for(let t=0;t<r.length;t++)if(r[t]!==e[t])return r[t]<e[t]?-1:1;return 0}function qS(r){let e=[],t=0;for(let n=0;n<r.length;n++){let o=r.charCodeAt(n);o<128?e[t++]=o:o<2048?(e[t++]=o>>6|192,e[t++]=o&63|128):(o&64512)===55296&&n+1<r.length&&(r.charCodeAt(n+1)&64512)===56320?(o=65536+((o&1023)<<10)+(r.charCodeAt(++n)&1023),e[t++]=o>>18|240,e[t++]=o>>12&63|128,e[t++]=o>>6&63|128,e[t++]=o&63|128):(o>=55296&&o<=57343&&(o=65533),e[t++]=o>>12|224,e[t++]=o>>6&63|128,e[t++]=o&63|128)}return e}var H3=256,hu=class{constructor(e=H3){this.chunkSize=e,this.cursor=0,this.maxCursor=-1,this.chunks=[],this._initReuseChunk=null}reset(){this.cursor=0,this.maxCursor=-1,this.chunks.length&&(this.chunks=[]),this._initReuseChunk!==null&&(this.chunks.push(this._initReuseChunk),this.maxCursor=this._initReuseChunk.length-1)}push(e){let t=this.chunks[this.chunks.length-1];if(this.cursor+e.length<=this.maxCursor+1){let o=t.length-(this.maxCursor-this.cursor)-1;t.set(e,o)}else{if(t){let o=t.length-(this.maxCursor-this.cursor)-1;o<t.length&&(this.chunks[this.chunks.length-1]=t.subarray(0,o),this.maxCursor=this.cursor-1)}e.length<64&&e.length<this.chunkSize?(t=jS(this.chunkSize),this.chunks.push(t),this.maxCursor+=t.length,this._initReuseChunk===null&&(this._initReuseChunk=t),t.set(e,0)):(this.chunks.push(e),this.maxCursor+=e.length)}this.cursor+=e.length}toBytes(e=!1){let t;if(this.chunks.length===1){let n=this.chunks[0];e&&this.cursor>n.length/2?(t=this.cursor===n.length?n:n.subarray(0,this.cursor),this._initReuseChunk=null,this.chunks=[]):t=HS(n,0,this.cursor)}else t=zS(this.chunks,this.cursor);return e&&this.reset(),t}},ah=class{constructor(e){this.dest=e,this.cursor=0,this.chunks=[e]}reset(){this.cursor=0}push(e){if(this.cursor+e.length>this.dest.length)throw new Error("write out of bounds, destination buffer is too small");this.dest.set(e,this.cursor),this.cursor+=e.length}toBytes(e=!1){let t=this.dest.subarray(0,this.cursor);return e&&this.reset(),t}};var ne="CBOR decode error:",Sw="CBOR encode error:",pu=[];pu[23]=1;pu[24]=2;pu[25]=3;pu[26]=5;pu[27]=9;function On(r,e,t){if(r.length-e<t)throw new Error(`${ne} not enough data for type`)}var ot=[24,256,65536,4294967296,BigInt("18446744073709551616")];function Qt(r,e,t){On(r,e,1);let n=r[e];if(t.strict===!0&&n<ot[0])throw new Error(`${ne} integer encoded in more bytes than necessary (strict decode)`);return n}function er(r,e,t){On(r,e,2);let n=r[e]<<8|r[e+1];if(t.strict===!0&&n<ot[1])throw new Error(`${ne} integer encoded in more bytes than necessary (strict decode)`);return n}function tr(r,e,t){On(r,e,4);let n=r[e]*16777216+(r[e+1]<<16)+(r[e+2]<<8)+r[e+3];if(t.strict===!0&&n<ot[2])throw new Error(`${ne} integer encoded in more bytes than necessary (strict decode)`);return n}function rr(r,e,t){On(r,e,8);let n=r[e]*16777216+(r[e+1]<<16)+(r[e+2]<<8)+r[e+3],o=r[e+4]*16777216+(r[e+5]<<16)+(r[e+6]<<8)+r[e+7],i=(BigInt(n)<<BigInt(32))+BigInt(o);if(t.strict===!0&&i<ot[3])throw new Error(`${ne} integer encoded in more bytes than necessary (strict decode)`);if(i<=Number.MAX_SAFE_INTEGER)return Number(i);if(t.allowBigInt===!0)return i;throw new Error(`${ne} integers outside of the safe integer range are not supported`)}function GS(r,e,t,n){return new G(v.uint,Qt(r,e+1,n),2)}function WS(r,e,t,n){return new G(v.uint,er(r,e+1,n),3)}function YS(r,e,t,n){return new G(v.uint,tr(r,e+1,n),5)}function XS(r,e,t,n){return new G(v.uint,rr(r,e+1,n),9)}function br(r,e){return it(r,0,e.value)}function it(r,e,t){if(t<ot[0]){let n=Number(t);r.push([e|n])}else if(t<ot[1]){let n=Number(t);r.push([e|24,n])}else if(t<ot[2]){let n=Number(t);r.push([e|25,n>>>8,n&255])}else if(t<ot[3]){let n=Number(t);r.push([e|26,n>>>24&255,n>>>16&255,n>>>8&255,n&255])}else{let n=BigInt(t);if(n<ot[4]){let o=[e|27,0,0,0,0,0,0,0],i=Number(n&BigInt(4294967295)),s=Number(n>>BigInt(32)&BigInt(4294967295));o[8]=i&255,i=i>>8,o[7]=i&255,i=i>>8,o[6]=i&255,i=i>>8,o[5]=i&255,o[4]=s&255,s=s>>8,o[3]=s&255,s=s>>8,o[2]=s&255,s=s>>8,o[1]=s&255,r.push(o)}else throw new Error(`${ne} encountered BigInt larger than allowable range`)}}br.encodedSize=function(e){return it.encodedSize(e.value)};it.encodedSize=function(e){return e<ot[0]?1:e<ot[1]?2:e<ot[2]?3:e<ot[3]?5:9};br.compareTokens=function(e,t){return e.value<t.value?-1:e.value>t.value?1:0};function ZS(r,e,t,n){return new G(v.negint,-1-Qt(r,e+1,n),2)}function JS(r,e,t,n){return new G(v.negint,-1-er(r,e+1,n),3)}function QS(r,e,t,n){return new G(v.negint,-1-tr(r,e+1,n),5)}var kw=BigInt(-1),ek=BigInt(1);function tk(r,e,t,n){let o=rr(r,e+1,n);if(typeof o!="bigint"){let i=-1-o;if(i>=Number.MIN_SAFE_INTEGER)return new G(v.negint,i,9)}if(n.allowBigInt!==!0)throw new Error(`${ne} integers outside of the safe integer range are not supported`);return new G(v.negint,kw-BigInt(o),9)}function ch(r,e){let t=e.value,n=typeof t=="bigint"?t*kw-ek:t*-1-1;it(r,e.type.majorEncoded,n)}ch.encodedSize=function(e){let t=e.value,n=typeof t=="bigint"?t*kw-ek:t*-1-1;return n<ot[0]?1:n<ot[1]?2:n<ot[2]?3:n<ot[3]?5:9};ch.compareTokens=function(e,t){return e.value<t.value?1:e.value>t.value?-1:0};function mu(r,e,t,n){On(r,e,t+n);let o=r.slice(e+t,e+t+n);return new G(v.bytes,o,t+n)}function rk(r,e,t,n){return mu(r,e,1,t)}function nk(r,e,t,n){return mu(r,e,2,Qt(r,e+1,n))}function ok(r,e,t,n){return mu(r,e,3,er(r,e+1,n))}function ik(r,e,t,n){return mu(r,e,5,tr(r,e+1,n))}function sk(r,e,t,n){let o=rr(r,e+1,n);if(typeof o=="bigint")throw new Error(`${ne} 64-bit integer bytes lengths not supported`);return mu(r,e,9,o)}function uh(r){return r.encodedBytes===void 0&&(r.encodedBytes=v.equals(r.type,v.string)?Aw(r.value):r.value),r.encodedBytes}function oa(r,e){let t=uh(e);it(r,e.type.majorEncoded,t.length),r.push(t)}oa.encodedSize=function(e){let t=uh(e);return it.encodedSize(t.length)+t.length};oa.compareTokens=function(e,t){return j3(uh(e),uh(t))};function j3(r,e){return r.length<e.length?-1:r.length>e.length?1:sh(r,e)}var ak=new TextDecoder,W3=32;function Y3(r,e,t){if(t-e<W3){let o="";for(let i=e;i<t;i++){let s=r[i];if(s&128)return ak.decode(r.subarray(e,t));o+=String.fromCharCode(s)}return o}return ak.decode(r.subarray(e,t))}function gu(r,e,t,n,o){let i=t+n;On(r,e,i);let s=new G(v.string,Y3(r,e+t,e+i),i);return o.retainStringBytes===!0&&(s.byteValue=r.slice(e+t,e+i)),s}function ck(r,e,t,n){return gu(r,e,1,t,n)}function uk(r,e,t,n){return gu(r,e,2,Qt(r,e+1,n),n)}function lk(r,e,t,n){return gu(r,e,3,er(r,e+1,n),n)}function fk(r,e,t,n){return gu(r,e,5,tr(r,e+1,n),n)}function dk(r,e,t,n){let o=rr(r,e+1,n);if(typeof o=="bigint")throw new Error(`${ne} 64-bit integer string lengths not supported`);return gu(r,e,9,o,n)}var hk=oa;function ia(r,e,t,n){return new G(v.array,n,t)}function pk(r,e,t,n){return ia(r,e,1,t)}function mk(r,e,t,n){return ia(r,e,2,Qt(r,e+1,n))}function gk(r,e,t,n){return ia(r,e,3,er(r,e+1,n))}function yk(r,e,t,n){return ia(r,e,5,tr(r,e+1,n))}function wk(r,e,t,n){let o=rr(r,e+1,n);if(typeof o=="bigint")throw new Error(`${ne} 64-bit integer array lengths not supported`);return ia(r,e,9,o)}function bk(r,e,t,n){if(n.allowIndefinite===!1)throw new Error(`${ne} indefinite length items not allowed`);return ia(r,e,1,1/0)}function lh(r,e){it(r,v.array.majorEncoded,e.value)}lh.compareTokens=br.compareTokens;lh.encodedSize=function(e){return it.encodedSize(e.value)};function sa(r,e,t,n){return new G(v.map,n,t)}function xk(r,e,t,n){return sa(r,e,1,t)}function Ek(r,e,t,n){return sa(r,e,2,Qt(r,e+1,n))}function vk(r,e,t,n){return sa(r,e,3,er(r,e+1,n))}function Ak(r,e,t,n){return sa(r,e,5,tr(r,e+1,n))}function Sk(r,e,t,n){let o=rr(r,e+1,n);if(typeof o=="bigint")throw new Error(`${ne} 64-bit integer map lengths not supported`);return sa(r,e,9,o)}function kk(r,e,t,n){if(n.allowIndefinite===!1)throw new Error(`${ne} indefinite length items not allowed`);return sa(r,e,1,1/0)}function fh(r,e){it(r,v.map.majorEncoded,e.value)}fh.compareTokens=br.compareTokens;fh.encodedSize=function(e){return it.encodedSize(e.value)};function _k(r,e,t,n){return new G(v.tag,t,1)}function Ik(r,e,t,n){return new G(v.tag,Qt(r,e+1,n),2)}function Tk(r,e,t,n){return new G(v.tag,er(r,e+1,n),3)}function Ck(r,e,t,n){return new G(v.tag,tr(r,e+1,n),5)}function Bk(r,e,t,n){return new G(v.tag,rr(r,e+1,n),9)}function dh(r,e){it(r,v.tag.majorEncoded,e.value)}dh.compareTokens=br.compareTokens;dh.encodedSize=function(e){return it.encodedSize(e.value)};var _w=20,Iw=21,Tw=22,Cw=23;function Nk(r,e,t,n){if(n.allowUndefined===!1)throw new Error(`${ne} undefined values are not supported`);return n.coerceUndefinedToNull===!0?new G(v.null,null,1):new G(v.undefined,void 0,1)}function Pk(r,e,t,n){if(n.allowIndefinite===!1)throw new Error(`${ne} indefinite length items not allowed`);return new G(v.break,void 0,1)}function Bw(r,e,t){if(t){if(t.allowNaN===!1&&Number.isNaN(r))throw new Error(`${ne} NaN values are not supported`);if(t.allowInfinity===!1&&(r===1/0||r===-1/0))throw new Error(`${ne} Infinity values are not supported`)}return new G(v.float,r,e)}function Lk(r,e,t,n){return Bw(Nw(r,e+1),3,n)}function Dk(r,e,t,n){return Bw(Pw(r,e+1),5,n)}function Rk(r,e,t,n){return Bw(Fk(r,e+1),9,n)}function hh(r,e,t){let n=e.value;if(n===!1)r.push([v.float.majorEncoded|_w]);else if(n===!0)r.push([v.float.majorEncoded|Iw]);else if(n===null)r.push([v.float.majorEncoded|Tw]);else if(n===void 0)r.push([v.float.majorEncoded|Cw]);else{let o,i=!1;(!t||t.float64!==!0)&&(Ok(n),o=Nw(en,1),n===o||Number.isNaN(n)?(en[0]=249,r.push(en.slice(0,3)),i=!0):(Mk(n),o=Pw(en,1),n===o&&(en[0]=250,r.push(en.slice(0,5)),i=!0))),i||(eP(n),o=Fk(en,1),en[0]=251,r.push(en.slice(0,9)))}}hh.encodedSize=function(e,t){let n=e.value;if(n===!1||n===!0||n===null||n===void 0)return 1;if(!t||t.float64!==!0){Ok(n);let o=Nw(en,1);if(n===o||Number.isNaN(n))return 3;if(Mk(n),o=Pw(en,1),n===o)return 5}return 9};var Uk=new ArrayBuffer(9),xr=new DataView(Uk,1),en=new Uint8Array(Uk,0);function Ok(r){if(r===1/0)xr.setUint16(0,31744,!1);else if(r===-1/0)xr.setUint16(0,64512,!1);else if(Number.isNaN(r))xr.setUint16(0,32256,!1);else{xr.setFloat32(0,r);let e=xr.getUint32(0),t=(e&2139095040)>>23,n=e&8388607;if(t===255)xr.setUint16(0,31744,!1);else if(t===0)xr.setUint16(0,(e&2147483648)>>16|n>>13,!1);else{let o=t-127;o<-24?xr.setUint16(0,0):o<-14?xr.setUint16(0,(e&2147483648)>>16|1<<24+o,!1):xr.setUint16(0,(e&2147483648)>>16|o+15<<10|n>>13,!1)}}}function Nw(r,e){if(r.length-e<2)throw new Error(`${ne} not enough data for float16`);let t=(r[e]<<8)+r[e+1];if(t===31744)return 1/0;if(t===64512)return-1/0;if(t===32256)return NaN;let n=t>>10&31,o=t&1023,i;return n===0?i=o*2**-24:n!==31?i=(o+1024)*2**(n-25):i=o===0?1/0:NaN,t&32768?-i:i}function Mk(r){xr.setFloat32(0,r,!1)}function Pw(r,e){if(r.length-e<4)throw new Error(`${ne} not enough data for float32`);let t=(r.byteOffset||0)+e;return new DataView(r.buffer,t,4).getFloat32(0,!1)}function eP(r){xr.setFloat64(0,r,!1)}function Fk(r,e){if(r.length-e<8)throw new Error(`${ne} not enough data for float64`);let t=(r.byteOffset||0)+e;return new DataView(r.buffer,t,8).getFloat64(0,!1)}hh.compareTokens=br.compareTokens;function Ee(r,e,t){throw new Error(`${ne} encountered invalid minor (${t}) for major ${r[e]>>>5}`)}function ph(r){return()=>{throw new Error(`${ne} ${r}`)}}var M=[];for(let r=0;r<=23;r++)M[r]=Ee;M[24]=GS;M[25]=WS;M[26]=YS;M[27]=XS;M[28]=Ee;M[29]=Ee;M[30]=Ee;M[31]=Ee;for(let r=32;r<=55;r++)M[r]=Ee;M[56]=ZS;M[57]=JS;M[58]=QS;M[59]=tk;M[60]=Ee;M[61]=Ee;M[62]=Ee;M[63]=Ee;for(let r=64;r<=87;r++)M[r]=rk;M[88]=nk;M[89]=ok;M[90]=ik;M[91]=sk;M[92]=Ee;M[93]=Ee;M[94]=Ee;M[95]=ph("indefinite length bytes/strings are not supported");for(let r=96;r<=119;r++)M[r]=ck;M[120]=uk;M[121]=lk;M[122]=fk;M[123]=dk;M[124]=Ee;M[125]=Ee;M[126]=Ee;M[127]=ph("indefinite length bytes/strings are not supported");for(let r=128;r<=151;r++)M[r]=pk;M[152]=mk;M[153]=gk;M[154]=yk;M[155]=wk;M[156]=Ee;M[157]=Ee;M[158]=Ee;M[159]=bk;for(let r=160;r<=183;r++)M[r]=xk;M[184]=Ek;M[185]=vk;M[186]=Ak;M[187]=Sk;M[188]=Ee;M[189]=Ee;M[190]=Ee;M[191]=kk;for(let r=192;r<=215;r++)M[r]=_k;M[216]=Ik;M[217]=Tk;M[218]=Ck;M[219]=Bk;M[220]=Ee;M[221]=Ee;M[222]=Ee;M[223]=Ee;for(let r=224;r<=243;r++)M[r]=ph("simple values are not supported");M[244]=Ee;M[245]=Ee;M[246]=Ee;M[247]=Nk;M[248]=ph("simple values are not supported");M[249]=Lk;M[250]=Dk;M[251]=Rk;M[252]=Ee;M[253]=Ee;M[254]=Ee;M[255]=Pk;var tn=[];for(let r=0;r<24;r++)tn[r]=new G(v.uint,r,1);for(let r=-1;r>=-24;r--)tn[31-r]=new G(v.negint,r,1);tn[64]=new G(v.bytes,new Uint8Array(0),1);tn[96]=new G(v.string,"",1);tn[128]=new G(v.array,0,1);tn[160]=new G(v.map,0,1);tn[244]=new G(v.false,!1,1);tn[245]=new G(v.true,!0,1);tn[246]=new G(v.null,null,1);function $k(r){switch(r.type){case v.false:return wn([244]);case v.true:return wn([245]);case v.null:return wn([246]);case v.bytes:return r.value.length?void 0:wn([64]);case v.string:return r.value===""?wn([96]):void 0;case v.array:return r.value===0?wn([128]):void 0;case v.map:return r.value===0?wn([160]):void 0;case v.uint:return r.value<24?wn([Number(r.value)]):void 0;case v.negint:if(r.value>=-24)return wn([31-Number(r.value)])}}var Kk=Object.freeze({float64:!0,mapSorter:sP,quickEncodeToken:$k});function rP(){let r=[];return r[v.uint.major]=br,r[v.negint.major]=ch,r[v.bytes.major]=oa,r[v.string.major]=hk,r[v.array.major]=lh,r[v.map.major]=fh,r[v.tag.major]=dh,r[v.float.major]=hh,r}var nP=rP(),oP=new hu,mh=class r{constructor(e,t){this.obj=e,this.parent=t}includes(e){let t=this;do if(t.obj===e)return!0;while(t=t.parent);return!1}static createCheck(e,t){if(e&&e.includes(t))throw new Error(`${Sw} object contains circular references`);return new r(t,e)}},Io={null:new G(v.null,null),undefined:new G(v.undefined,void 0),true:new G(v.true,!0),false:new G(v.false,!1),emptyArray:new G(v.array,0),emptyMap:new G(v.map,0)},To={number(r,e,t,n){return!Number.isInteger(r)||!Number.isSafeInteger(r)?new G(v.float,r):r>=0?new G(v.uint,r):new G(v.negint,r)},bigint(r,e,t,n){return r>=BigInt(0)?new G(v.uint,r):new G(v.negint,r)},Uint8Array(r,e,t,n){return new G(v.bytes,r)},string(r,e,t,n){return new G(v.string,r)},boolean(r,e,t,n){return r?Io.true:Io.false},null(r,e,t,n){return Io.null},undefined(r,e,t,n){return Io.undefined},ArrayBuffer(r,e,t,n){return new G(v.bytes,new Uint8Array(r))},DataView(r,e,t,n){return new G(v.bytes,new Uint8Array(r.buffer,r.byteOffset,r.byteLength))},Array(r,e,t,n){if(!r.length)return t.addBreakTokens===!0?[Io.emptyArray,new G(v.break)]:Io.emptyArray;n=mh.createCheck(n,r);let o=[],i=0;for(let s of r)o[i++]=aa(s,t,n);return t.addBreakTokens?[new G(v.array,r.length),o,new G(v.break)]:[new G(v.array,r.length),o]},Object(r,e,t,n){let o=e!=="Object",i=o?r.keys():Object.keys(r),s=o?r.size:i.length,a;if(s){a=new Array(s),n=mh.createCheck(n,r);let c=!o&&t.ignoreUndefinedProperties,u=0;for(let l of i){let f=o?r.get(l):r[l];c&&f===void 0||(a[u++]=[aa(l,t,n),aa(f,t,n)])}u<s&&(a.length=u)}return a?.length?(iP(a,t),t.addBreakTokens?[new G(v.map,a.length),a,new G(v.break)]:[new G(v.map,a.length),a]):t.addBreakTokens===!0?[Io.emptyMap,new G(v.break)]:Io.emptyMap},Tagged(r,e,t,n){return[new G(v.tag,r.tag),aa(r.value,t,n)]}};To.Map=To.Object;To.Buffer=To.Uint8Array;for(let r of"Uint8Clamped Uint16 Uint32 Int8 Int16 Int32 BigUint64 BigInt64 Float32 Float64".split(" "))To[`${r}Array`]=To.DataView;function aa(r,e={},t){let n=KS(r),o=e&&e.typeEncoders&&e.typeEncoders[n]||To[n];if(typeof o=="function"){let s=o(r,n,e,t);if(s!=null)return s}let i=To[n];if(!i)throw new Error(`${Sw} unsupported type: ${n}`);return i(r,n,e,t)}function iP(r,e){e.mapSorter&&r.sort(e.mapSorter)}function sP(r,e){if(r[0]instanceof G&&e[0]instanceof G){let t=r[0],n=e[0];return t._keyBytes||(t._keyBytes=Vk(t.value)),n._keyBytes||(n._keyBytes=Vk(n.value)),sh(t._keyBytes,n._keyBytes)}throw new Error("rfc8949MapSorter: complex key types are not supported yet")}function Vk(r){return aP(r,nP,Kk)}function qk(r,e,t,n){if(Array.isArray(e))for(let o of e)qk(r,o,t,n);else t[e.type.major](r,e,n)}var DY=v.uint.majorEncoded,RY=v.negint.majorEncoded,UY=v.bytes.majorEncoded,OY=v.string.majorEncoded,MY=v.array.majorEncoded,FY=v.float.majorEncoded|_w,$Y=v.float.majorEncoded|Iw,VY=v.float.majorEncoded|Tw,KY=v.float.majorEncoded|Cw,qY=BigInt(-1),HY=BigInt(1);function aP(r,e,t,n){let o=n instanceof Uint8Array,i=o?new ah(n):oP,s=aa(r,t);if(!Array.isArray(s)&&t.quickEncodeToken){let a=t.quickEncodeToken(s);if(a)return o?(i.push(a),i.toBytes()):a;let c=e[s.type.major];if(c.encodedSize){let u=c.encodedSize(s,t);if(o||(i=new hu(u)),c(i,s,t),i.chunks.length!==1)throw new Error(`Unexpected error: pre-calculated length for ${s} was wrong`);return o?i.toBytes():du(i.chunks[0])}}return i.reset(),qk(i,s,e,t),i.toBytes(!0)}var cP={strict:!1,allowIndefinite:!0,allowUndefined:!0,allowBigInt:!0},gh=class{constructor(e,t={}){this._pos=0,this.data=e,this.options=t}pos(){return this._pos}done(){return this._pos>=this.data.length}next(){let e=this.data[this._pos],t=tn[e];if(t===void 0){let n=M[e];if(!n)throw new Error(`${ne} no decoder for major type ${e>>>5} (byte 0x${e.toString(16).padStart(2,"0")})`);let o=e&31;t=n(this.data,this._pos,o,this.options)}return this._pos+=t.encodedLength,t}},Co=Symbol.for("DONE"),ca=Symbol.for("BREAK");function uP(r,e,t){let n=[];for(let o=0;o<r.value;o++){let i=Bo(e,t);if(i===ca){if(r.value===1/0)break;throw new Error(`${ne} got unexpected break to lengthed array`)}if(i===Co)throw new Error(`${ne} found array but not enough entries (got ${o}, expected ${r.value})`);n[o]=i}return n}function lP(r,e,t){let n=t.useMaps===!0,o=t.rejectDuplicateMapKeys===!0,i=n?void 0:{},s=n?new Map:void 0;for(let a=0;a<r.value;a++){let c=Bo(e,t);if(c===ca){if(r.value===1/0)break;throw new Error(`${ne} got unexpected break to lengthed map`)}if(c===Co)throw new Error(`${ne} found map but not enough entries (got ${a} [no key], expected ${r.value})`);if(!n&&typeof c!="string")throw new Error(`${ne} non-string keys not supported (got ${typeof c})`);if(o&&(n&&s.has(c)||!n&&Object.hasOwn(i,c)))throw new Error(`${ne} found repeat map key "${c}"`);let u=Bo(e,t);if(u===Co)throw new Error(`${ne} found map but not enough entries (got ${a} [no value], expected ${r.value})`);n?s.set(c,u):i[c]=u}return n?s:i}function*fP(r,e,t){for(let n=0;n<r.value;n++){let o=Bo(e,t);if(o===ca){if(r.value===1/0)break;throw new Error(`${ne} got unexpected break to lengthed map`)}if(o===Co)throw new Error(`${ne} found map but not enough entries (got ${n} [no key], expected ${r.value})`);let i=Bo(e,t);if(i===Co)throw new Error(`${ne} found map but not enough entries (got ${n} [no value], expected ${r.value})`);yield[o,i]}}function dP(r,e){let t=!1,n=function(){if(t)throw new Error(`${ne} tag decode() may only be called once`);t=!0;let o=Bo(r,e);if(o===Co)throw new Error(`${ne} tag content missing`);if(o===ca)throw new Error(`${ne} got unexpected break in tag content`);return o};return n.entries=function(){if(t)throw new Error(`${ne} tag decode() may only be called once`);t=!0;let o=r.next();if(!v.equals(o.type,v.map))throw new Error(`${ne} entries() requires map content, got ${o.type.name}`);let i=[];for(let s of fP(o,r,e))i.push(s);return i},Object.defineProperty(n,"_called",{get(){return t},enumerable:!1}),n}function Bo(r,e){if(r.done())return Co;let t=r.next();if(v.equals(t.type,v.break))return ca;if(t.type.terminal)return t.value;if(v.equals(t.type,v.array))return uP(t,r,e);if(v.equals(t.type,v.map))return lP(t,r,e);if(v.equals(t.type,v.tag)){if(e.tags&&typeof e.tags[t.value]=="function"){let n=dP(r,e),o=e.tags[t.value](n);if(!n._called)throw new Error(`${ne} tag decoder must call decode() or entries()`);return o}throw new Error(`${ne} tag not supported (${t.value})`)}throw new Error("unsupported")}function Hk(r,e){if(!(r instanceof Uint8Array))throw new Error(`${ne} data to decode must be a Uint8Array`);e=Object.assign({},cP,e);let t=du(r),n=e.tokenizer||new gh(t,e),o=Bo(n,e);if(o===Co)throw new Error(`${ne} did not find any content to decode`);if(o===ca)throw new Error(`${ne} got unexpected break`);return[o,r.subarray(n.pos())]}function Lw(r,e){let[t,n]=Hk(r,e);if(n.length>0)throw new Error(`${ne} too many terminals, data makes no sense`);return t}var yh=class r{constructor(e,t){if(typeof e!="number"||!Number.isInteger(e)||e<0)throw new TypeError("Tagged: tag must be a non-negative integer");this.tag=e,this.value=t}static decoder(e){return t=>new r(e,t())}static preserve(...e){let t={};for(let n of e)t[n]=r.decoder(n);return t}};Object.defineProperty(yh.prototype,Symbol.toStringTag,{value:"Tagged"});var mP=ur("ipns:utils"),zk=L("/ipns/");var gP=0,yP=18;function jk(r){let e;if(r.pubKey!=null)try{e=ao(r.pubKey)}catch(t){throw mP.error(t),t}if(e!=null)return e}function Gk(r){let e=L("ipns-signature:");return je([e,r])}function yu(r){return"signatureV1"in r?Qr.encode({value:L(r.value),signatureV1:r.signatureV1,validityType:r.validityType,validity:L(r.validity),sequence:r.sequence,ttl:r.ttl,pubKey:r.pubKey,signatureV2:r.signatureV2,data:r.data}):Qr.encode({pubKey:r.pubKey,signatureV2:r.signatureV2,data:r.data})}function No(r){let e=Qr.decode(r);if(e.sequence!=null&&(e.sequence=BigInt(e.sequence)),e.ttl!=null&&(e.ttl=BigInt(e.ttl)),e.signatureV2==null||e.data==null)throw new Jr("Missing data or signatureV2");let t=Wk(e.data),n=wP(t.Value),o=j(t.Validity);if(e.value!=null&&e.signatureV1!=null)return bP(e),{value:n,validityType:Qr.ValidityType.EOL,validity:o,sequence:t.Sequence,ttl:t.TTL,pubKey:e.pubKey,signatureV1:e.signatureV1,signatureV2:e.signatureV2,data:e.data};if(e.signatureV2!=null)return{value:n,validityType:Qr.ValidityType.EOL,validity:o,sequence:t.Sequence,ttl:t.TTL,pubKey:e.pubKey,signatureV2:e.signatureV2,data:e.data};throw new Error("invalid record: does not include signatureV1 or signatureV2")}function wu(r){return je([zk,r.bytes])}function ua(r){let e=Ct(r.slice(zk.length));if(!wh(e,gP)&&!wh(e,yP))throw new Wn("Multihash in IPNS key was not identity or sha2-256");return e}function Wk(r){let e=Lw(r);if(e.ValidityType===0)e.ValidityType=Qr.ValidityType.EOL;else throw new na("The validity type is unsupported");return Number.isInteger(e.Sequence)&&(e.Sequence=BigInt(e.Sequence)),Number.isInteger(e.TTL)&&(e.TTL=BigInt(e.TTL)),e}function wP(r){let e=j(r).trim();if(e.startsWith("/"))return e;try{return`/ipfs/${Q.decode(r).toV1().toString()}`}catch{}try{return`/ipfs/${Q.parse(e).toV1().toString()}`}catch{}throw new nh("Value must be a valid content path starting with /")}function bP(r){if(r.data==null)throw new oh("Record data is missing");let e=Wk(r.data);if(!ce(e.Value,r.value??new Uint8Array(0)))throw new Jr('Field "value" did not match between protobuf and CBOR');if(!ce(e.Validity,r.validity??new Uint8Array(0)))throw new Jr('Field "validity" did not match between protobuf and CBOR');if(e.ValidityType!==r.validityType)throw new Jr('Field "validityType" did not match between protobuf and CBOR');if(e.Sequence!==r.sequence)throw new Jr('Field "sequence" did not match between protobuf and CBOR');if(e.TTL!==r.ttl)throw new Jr('Field "ttl" did not match between protobuf and CBOR')}function wh(r,e){return r.code===e}var yX=ur("ipns"),wX=300*1e9,EP="/ipns/",bX=EP.length;var Yk=Ro(vw(),1);var bh=ur("ipns:validator"),vP=1024*10;async function AP(r,e){let t=No(e),n;try{let o=Gk(t.data);n=await r.verify(o,t.signatureV2)}catch{n=!1}if(!n)throw bh.error("record signature verification failed"),new Jr("Record signature verification failed");if(t.validityType===Qr.ValidityType.EOL){if(Yk.default.fromString(t.validity).toDate().getTime()<Date.now())throw bh.error("record has expired"),new th("record has expired")}else if(t.validityType!=null)throw bh.error("the validity type is unsupported"),new na("The validity type is unsupported");bh("ipns record for %s is valid",t.value)}async function Xk(r,e){if(e.byteLength>vP)throw new rh("The record is too large");let t=ua(r),n;wh(t,0)&&(n=Pl(t));let o=No(e),i=jk(o)??n;if(i==null)throw new lu("Could not extract public key from IPNS record or routing key");let s=wu(i.toMultihash());if(!ce(s,r))throw new lu("Embedded public key did not match routing key");await AP(i,e)}var xh=class extends Error{name="InvalidMessageLengthError";code="ERR_INVALID_MESSAGE_LENGTH"};async function*la(r,e={}){let t=/\r?\n/,n=new TextDecoder("utf8"),o="";for await(let i of r){if(typeof i=="string"&&(i=new TextEncoder().encode(i)),zi(i)&&(i=i.subarray()),o+=n.decode(i,{stream:!0}),o.length>(e?.maxMessageLength??o.length))throw new xh("Incoming message too long");let s=o.split(t);o=s.pop()??"";for(let a=0;a<s.length;a++)yield JSON.parse(s[a])}o+=n.decode(),o!==""&&(yield JSON.parse(o))}var Ci=class extends Error{static name="InvalidRequestError";constructor(e="Invalid request"){super(e),this.name="InvalidRequestError"}},Er=class extends Error{static name="BadResponseError";constructor(e="Bad response"){super(e),this.name="BadResponseError"}};function SP(r){return r[Symbol.asyncIterator]!=null}function kP(r){if(SP(r))return(async()=>{for await(let e of r)return e})();for(let e of r)return e}var Zk=kP;var Jk=L("/ipns/");function Qk(r){return ce(r.subarray(0,Jk.byteLength),Jk)}var Eh=class{client;constructor(e){this.client=e}async*findProviders(e,t={}){try{yield*hf(this.client.getProviders(e,t),n=>({id:n.ID,multiaddrs:n.Addrs??[],routing:"delegated-http-routing-v1"}))}catch(n){if(n instanceof He)return;throw n}}async provide(){}async cancelReprovide(){}async put(e,t,n){if(!Qk(e))return;let o=ua(e),i=Q.createV1(114,o),s=No(t);await this.client.putIPNS(i,s,n)}async get(e,t){if(!Qk(e))throw new He("Not found");let n=ua(e),o=Q.createV1(114,n);try{let i=await this.client.getIPNS(o,t);return yu(i)}catch(i){throw i.name==="BadResponseError"?new He("Not found"):i}}toString(){return`DelegatedRoutingV1HttpApiClientContentRouting(${this.client.url})`}},vh=class{client;constructor(e){this.client=e}async findPeer(e,t={}){let n=await Zk(this.client.getPeers(e,t));if(n!=null)return{id:n.ID,multiaddrs:n.Addrs??[]};throw new He("Not found")}async*getClosestPeers(e,t={}){let n;try{n=Q.decode(e)}catch{try{n=po(Ut.decode(e))}catch{n=Q.createV1(Vo,Ve.digest(e))}}for await(let o of this.client.getClosestPeers(n,t))yield{id:o.ID,multiaddrs:o.Addrs??[]}}toString(){return`DelegatedRoutingV1HttpApiClientPeerRouting(${this.client.url})`}};var Ah={concurrentRequests:4,timeout:3e4,cacheTTL:300*1e3,cacheName:"delegated-routing-v1-cache"},Sh=class{url;started;httpQueue;shutDownController;timeout;contentRouting;peerRouting;filterAddrs;filterProtocols;inFlightRequests;cacheName;cache;cacheTTL;log;constructor(e,t){this.log=e.logger.forComponent("delegated-routing-v1-http-api-client"),this.started=!1,this.shutDownController=new AbortController,this.shutDownController.signal,this.httpQueue=new yi({concurrency:t.concurrentRequests??Ah.concurrentRequests}),this.inFlightRequests=new Map,this.url=t.url instanceof URL?t.url:new URL(t.url),this.timeout=t.timeout??Ah.timeout,this.filterAddrs=t.filterAddrs,this.filterProtocols=t.filterProtocols,this.contentRouting=new Eh(this),this.peerRouting=new vh(this),this.cacheName=t.cacheName??Ah.cacheName,this.cacheTTL=t.cacheTTL??Ah.cacheTTL}get[Uo](){return this.contentRouting}get[Mo](){return this.peerRouting}isStarted(){return this.started}async start(){this.started||(this.started=!0,this.cacheTTL>0&&(this.cache=await globalThis.caches?.open(this.cacheName),this.cache!=null&&this.log("cache enabled with ttl %d",this.cacheTTL)))}async stop(){this.httpQueue.clear(),this.shutDownController.abort(),await globalThis.caches?.delete(this.cacheName),this.started=!1}async*getProviders(e,t={}){this.log("getProviders starts: %c",e);let n=AbortSignal.timeout(this.timeout),o=Ie([this.shutDownController.signal,n,t.signal]);let i=ge(),s=ge(),a=0;this.httpQueue.add(async()=>(i.resolve(),s.promise));try{await i.promise;let c=new URL(`${this.url}routing/v1/providers/${e}`);this.#t(c,t.filterAddrs,t.filterProtocols);let u={headers:{accept:"application/x-ndjson, application/json;q=0.8"},signal:o},l=await this.#r(c.toString(),u);if(!l.ok){if(l.status===404)return;throw l.status===422?new Ci("Request does not conform to schema or semantic constraints"):new Er(`Unexpected status code: ${l.status}`)}let f=l.headers.get("Content-Type");if(f==null)throw new Er("No Content-Type header received");if(l.body==null){if(f!=="application/x-ndjson")throw new Er("Routing response had no body");return}if(f.startsWith("application/json")){let h=(await l.json()).Providers??[];for(let m of h){let y=this.#e(m);y!=null&&(a++,yield y)}}else if(f.includes("application/x-ndjson"))for await(let d of la(uu(l.body))){let h=this.#e(d);h!=null&&(a++,yield h)}else throw new Er(`Unsupported Content-Type: ${f}`)}finally{o.clear(),s.resolve(),this.log("getProviders finished found %d providers for %c",a,e)}}async*getPeers(e,t={}){this.log("getPeers starts: %c",e);let n=AbortSignal.timeout(this.timeout),o=Ie([this.shutDownController.signal,n,t.signal]);let i=ge(),s=ge();this.httpQueue.add(async()=>(i.resolve(),s.promise));try{await i.promise;let a=new URL(`${this.url}routing/v1/peers/${e.toCID().toString()}`);this.#t(a,t.filterAddrs,t.filterProtocols);let c={headers:{Accept:"application/x-ndjson"},signal:o},u=await this.#r(a.toString(),c);if(u.status===404)return;if(u.status===422)throw new Ci("Request does not conform to schema or semantic constraints");if(u.body==null)throw new Er("Routing response had no body");if(u.headers.get("Content-Type")?.startsWith("application/json")){let d=(await u.json()).Peers??[];for(let h of d){let m=this.#e(h);m!=null&&(yield m)}}else for await(let f of la(uu(u.body))){let d=this.#e(f);d!=null&&(yield d)}}catch(a){this.log.error("getPeers errored - %e",a)}finally{o.clear(),s.resolve(),this.log("getPeers finished: %c",e)}}async*getClosestPeers(e,t={}){let n;if(nr(e))n=e.toCID().toString();else if(Q.asCID(e)===e||e instanceof Q)n=e.toV1().toString();else throw new T("Key must be CID or PeerId");this.log("getClosestPeers starts: %s",n);let o=AbortSignal.timeout(this.timeout),i=Ie([this.shutDownController.signal,o,t.signal]);let s=ge(),a=ge();this.httpQueue.add(async()=>(s.resolve(),a.promise));try{await s.promise;let c=new URL(`${this.url}routing/v1/dht/closest/peers/${n}`);this.#t(c,t.filterAddrs,t.filterProtocols);let u={headers:{Accept:"application/x-ndjson"},signal:i},l=await this.#r(c.toString(),u);if(l.status===404)return;if(l.status===422)throw new Ci("Request does not conform to schema or semantic constraints");if(l.body==null)throw new Er("Routing response had no body");if(l.headers.get("Content-Type")?.startsWith("application/json")){let h=(await l.json()).Peers??[];for(let m of h){let y=this.#e(m);y!=null&&(yield y)}}else for await(let d of la(uu(l.body))){let h=this.#e(d);h!=null&&(yield h)}}catch(c){this.log.error("getClosestPeers errored - %e",c)}finally{i.clear(),a.resolve(),this.log("getClosestPeers finished: %s",n)}}async getIPNS(e,t={}){this.log("getIPNS starts: %s",e);let n=AbortSignal.timeout(this.timeout),o=Ie([this.shutDownController.signal,n,t.signal]);let i=ge(),s=ge();this.httpQueue.add(async()=>(i.resolve(),s.promise));let a=`${this.url}routing/v1/ipns/${e}`;try{await i.promise;let c={headers:{Accept:"application/vnd.ipfs.ipns-record"},signal:o},u=await this.#r(a,c);if(this.log("getIPNS GET %s %d",a,u.status),u.status===404)throw new He("No matching records found");if(u.status===422)throw new Ci("Request does not conform to schema or semantic constraints");if(!u.ok)throw new Er(`Unexpected status code: ${u.status}`);let l=u.headers.get("Content-Type");if(l==null||!l.includes("application/vnd.ipfs.ipns-record"))throw new He("No matching records found");if(u.body==null)throw new Er("GET ipns response had no body");let f=await u.arrayBuffer(),d=new Uint8Array(f,0,f.byteLength);return t.validate!==!1&&await Xk(wu(e.multihash),d),No(d)}catch(c){throw this.log.error("getIPNS GET %s error - %e",a,c),c}finally{o.clear(),s.resolve(),this.log("getIPNS finished: %s",e)}}async putIPNS(e,t,n={}){this.log("putIPNS starts: %c",e);let o=AbortSignal.timeout(this.timeout),i=Ie([this.shutDownController.signal,o,n.signal]);let s=ge(),a=ge();this.httpQueue.add(async()=>(s.resolve(),a.promise));let c=`${this.url}routing/v1/ipns/${e}`;try{await s.promise;let u=yu(t),l={method:"PUT",headers:{"Content-Type":"application/vnd.ipfs.ipns-record"},body:u,signal:i},f=await this.#r(c,l);if(this.log("putIPNS PUT %s %d",c,f.status),f.status!==200)throw new Er("PUT ipns response had status other than 200")}catch(u){throw this.log.error("putIPNS PUT %s error - %e",c,u.stack),u}finally{i.clear(),a.resolve(),this.log("putIPNS finished: %c",e)}}#e(e){try{let t=[],n=e.Addrs?.map(fe)??[];return e.Protocols!=null&&t.push(...e.Protocols),e.Protocol!=null&&(t.push(e.Protocol),delete e.Protocol),{...e,Schema:"peer",ID:lr(e.ID),Addrs:n,Protocols:t}}catch(t){this.log.error("could not conform record to peer schema - %e",t)}}#t(e,t,n){if(t!=null||this.filterAddrs!=null){let o=t?.join(",")??this.filterAddrs?.join(",")??"";o!==""&&e.searchParams.set("filter-addrs",o)}if(n!=null||this.filterProtocols!=null){let o=n?.join(",")??this.filterProtocols?.join(",")??"";o!==""&&e.searchParams.set("filter-protocols",o)}}async#r(e,t){let n=t.method??"GET",o=`${n}-${e}`;if(n==="GET"){let c=await this.cache?.match(e);if(c!=null){if(parseInt(c.headers.get("x-cache-expires")??"0",10)>Date.now())return this.log("returning cached response for %s",o),this.logResponse(c),c;this.log("evicting cached response for %s",o),await this.cache?.delete(e)}else this.cache!=null&&this.log("cache miss for %s",o)}let i=this.inFlightRequests.get(o);if(i!=null){let c=await i;return this.log("deduplicating outgoing request for %s",o),c.clone()}this.log("outgoing request:"),this.logRequest(e,t);let s=fetch(e,t).then(async c=>{if(this.log("incoming response:"),this.logResponse(c),this.cache!=null&&c.ok&&n==="GET"){let u=Date.now()+this.cacheTTL,l=new Headers(c.headers);l.set("x-cache-expires",u.toString());let f=new Response(c.clone().body,{status:c.status,statusText:c.statusText,headers:l});await this.cache.put(e,f)}return c}).finally(()=>{this.inFlightRequests.delete(o)});return this.inFlightRequests.set(o,s),await s}toString(){return`DefaultDelegatedRoutingV1HttpApiClient(${this.url})`}logRequest(e,t){let n=new Headers(t.headers);this.log("%s %s HTTP/1.1",t.method??"GET",e);for(let[o,i]of n.entries())this.log("%s: %s",o,i)}logResponse(e){this.log("HTTP/1.1 %d %s",e.status,e.statusText);for(let[t,n]of e.headers.entries())this.log("%s: %s",t,n)}};function e_(r){return e=>new Sh(e,r)}var _P=["https://trustless-gateway.link","https://4everland.io"],IP=2336;function TP(r){return r=r.toString(),{id:Bn(Q.createV1(IP,Ve.digest(L(r)))),multiaddrs:[zd(r)]}}function CP(r){return new URL(j(r.id.toMultihash().digest))}var Dw=class{name="http-gateway-router";gateways;shuffle;constructor(e={}){this.gateways=(e.gateways??_P).map(t=>TP(t)),this.shuffle=e.shuffle??!0}async*findProviders(e,t){yield*(this.shuffle?this.gateways.toSorted(()=>Math.random()>.5?1:-1):this.gateways).map(n=>({...n,protocols:["transport-ipfs-gateway-http"],routing:"http-gateway-routing"}))}toString(){return`HTTPGatewayRouter([${this.gateways.map(e=>CP(e)).join(", ")}])`}};function Rw(r={}){return new Dw(r)}var Uw=class{name="libp2p-router";libp2p;constructor(e){this.libp2p=e}async provide(e,t){await this.libp2p.contentRouting.provide(e,t)}async cancelReprovide(e,t){await this.libp2p.contentRouting.cancelReprovide(e,t)}async*findProviders(e,t){yield*this.libp2p.contentRouting.findProviders(e,t)}async put(e,t,n){await this.libp2p.contentRouting.put(e,t,n)}async get(e,t){return this.libp2p.contentRouting.get(e,t)}async findPeer(e,t){return this.libp2p.peerRouting.findPeer(e,t)}async*getClosestPeers(e,t){yield*this.libp2p.peerRouting.getClosestPeers(e,t)}toString(){return"Libp2pRouter()"}};function Ow(r){return new Uw(r)}function BP(r){return r[Symbol.asyncIterator]!=null}function NP(r){if(BP(r))return(async()=>{let t=[];for await(let n of r)t.push(n);return t})();let e=[];for(let t of r)e.push(t);return e}var Bi=NP;function PP(r){return typeof r?.then=="function"}var bu=class extends Un{data;constructor(){super(),this.data=new Map}put(e,t,n){n?.signal?.throwIfAborted();let o;if(t instanceof Uint8Array)o=[t];else{let i=Bi(t);if(PP(i))return i.then(s=>this._put(e,s,n));o=i}return this._put(e,o,n)}_put(e,t,n){return n?.signal?.throwIfAborted(),this.data.set(Xe.encode(e.multihash.bytes),t),e}*get(e,t){t?.signal?.throwIfAborted();let n=this.data.get(Xe.encode(e.multihash.bytes));if(n==null)throw new wr;yield*n}has(e,t){return t?.signal?.throwIfAborted(),this.data.has(Xe.encode(e.multihash.bytes))}async delete(e,t){t?.signal?.throwIfAborted(),this.data.delete(Xe.encode(e.multihash.bytes))}*getAll(e){e?.signal?.throwIfAborted();for(let[t,n]of this.data.entries())yield{cid:Q.createV1(Vo,Ct(Xe.decode(t))),bytes:(async function*(){yield*n})()},e?.signal?.throwIfAborted()}};var KZ=ur("blockstore:core:tiered");var t_="SHARDING";function DP(r){return r[Symbol.asyncIterator]!=null}function RP(r,e){return DP(r)?(async function*(){yield*(await Bi(r)).sort(e)})():(function*(){yield*Bi(r).sort(e)})()}var kh=RP;var Mn=class{put(e,t,n){return Promise.reject(new Error(".put is not implemented"))}get(e,t){return Promise.reject(new Error(".get is not implemented"))}has(e,t){return Promise.reject(new Error(".has is not implemented"))}delete(e,t){return Promise.reject(new Error(".delete is not implemented"))}async*putMany(e,t={}){for await(let{key:n,value:o}of e)await this.put(n,o,t),yield n}async*getMany(e,t={}){for await(let n of e)yield{key:n,value:await this.get(n,t)}}async*deleteMany(e,t={}){for await(let n of e)await this.delete(n,t),yield n}batch(){let e=[],t=[];return{put(n,o){e.push({key:n,value:o})},delete(n){t.push(n)},commit:async n=>{await yc(this.putMany(e,n)),e=[],await yc(this.deleteMany(t,n)),t=[]}}}async*_all(e,t){throw new Error("._all is not implemented")}async*_allKeys(e,t){throw new Error("._allKeys is not implemented")}query(e,t){let n=this._all(e,t);if(e.prefix!=null){let o=e.prefix;n=Yr(n,i=>i.key.toString().startsWith(o))}if(Array.isArray(e.filters)&&(n=e.filters.reduce((o,i)=>Yr(o,i),n)),Array.isArray(e.orders)&&(n=e.orders.reduce((o,i)=>kh(o,i),n)),e.offset!=null){let o=0,i=e.offset;n=Yr(n,()=>o++>=i)}return e.limit!=null&&(n=pf(n,e.limit)),n}queryKeys(e,t){let n=this._allKeys(e,t);if(e.prefix!=null){let o=e.prefix;n=Yr(n,i=>i.toString().startsWith(o))}if(Array.isArray(e.filters)&&(n=e.filters.reduce((o,i)=>Yr(o,i),n)),Array.isArray(e.orders)&&(n=e.orders.reduce((o,i)=>kh(o,i),n)),e.offset!=null){let o=e.offset,i=0;n=Yr(n,()=>i++>=o)}return e.limit!=null&&(n=pf(n,e.limit)),n}};var Ni=class extends Mn{data;constructor(){super(),this.data=new Map}put(e,t,n){return n?.signal?.throwIfAborted(),this.data.set(e.toString(),t),e}get(e,t){t?.signal?.throwIfAborted();let n=this.data.get(e.toString());if(n==null)throw new wr;return n}has(e,t){return t?.signal?.throwIfAborted(),this.data.has(e.toString())}delete(e,t){t?.signal?.throwIfAborted(),this.data.delete(e.toString())}*_all(e,t){t?.signal?.throwIfAborted();for(let[n,o]of this.data.entries())yield{key:new Le(n),value:o},t?.signal?.throwIfAborted()}*_allKeys(e,t){t?.signal?.throwIfAborted();for(let n of this.data.keys())yield new Le(n),t?.signal?.throwIfAborted()}};var xJ=new Le(t_);var DJ=ur("datastore:core:tiered");async function n_(r){if(r.connectionProtector===null&&globalThis.process?.env?.LIBP2P_FORCE_PNET!=null)throw new T("Private network is enforced, but no protector was provided");return r}var xu;(function(r){let e;r.codec=()=>(e==null&&(e=ft((i,s,a={})=>{a.lengthDelimited!==!1&&s.fork(),i.publicKey!=null&&i.publicKey.byteLength>0&&(s.uint32(10),s.bytes(i.publicKey)),i.payloadType!=null&&i.payloadType.byteLength>0&&(s.uint32(18),s.bytes(i.payloadType)),i.payload!=null&&i.payload.byteLength>0&&(s.uint32(26),s.bytes(i.payload)),i.signature!=null&&i.signature.byteLength>0&&(s.uint32(42),s.bytes(i.signature)),a.lengthDelimited!==!1&&s.ldelim()},(i,s,a={})=>{let c={publicKey:Re(0),payloadType:Re(0),payload:Re(0),signature:Re(0)},u=s==null?i.len:i.pos+s;for(;i.pos<u;){let l=i.uint32();switch(l>>>3){case 1:{c.publicKey=i.bytes();break}case 2:{c.payloadType=i.bytes();break}case 3:{c.payload=i.bytes();break}case 5:{c.signature=i.bytes();break}default:{i.skipType(l&7);break}}}return c},function*(i,s,a,c={}){let u=s==null?i.len:i.pos+s;for(;i.pos<u;){let l=i.uint32();switch(l>>>3){case 1:{yield{field:`${a}.publicKey`,value:i.bytes()};break}case 2:{yield{field:`${a}.payloadType`,value:i.bytes()};break}case 3:{yield{field:`${a}.payload`,value:i.bytes()};break}case 5:{yield{field:`${a}.signature`,value:i.bytes()};break}default:{i.skipType(l&7);break}}}})),e);function t(i){return ut(i,r.codec())}r.encode=t;function n(i,s){return ct(i,r.codec(),s)}r.decode=n;function o(i,s){return lt(i,r.codec(),s)}r.stream=o})(xu||(xu={}));var _h=class extends Error{constructor(e="Invalid signature"){super(e),this.name="InvalidSignatureError"}};var fa=class r{static createFromProtobuf=e=>{let t=xu.decode(e),n=ao(t.publicKey);return new r({publicKey:n,payloadType:t.payloadType,payload:t.payload,signature:t.signature})};static seal=async(e,t,n)=>{if(t==null)throw new Error("Missing private key");let o=e.domain,i=e.codec,s=e.marshal(),a=o_(o,i,s),c=await t.sign(a.subarray(),n);return new r({publicKey:t.publicKey,payloadType:i,payload:s,signature:c})};static openAndCertify=async(e,t,n)=>{let o=r.createFromProtobuf(e);if(!await o.validate(t,n))throw new _h("Envelope signature is not valid for the given domain");return o};publicKey;payloadType;payload;signature;marshaled;constructor(e){let{publicKey:t,payloadType:n,payload:o,signature:i}=e;this.publicKey=t,this.payloadType=n,this.payload=o,this.signature=i}marshal(){return this.marshaled==null&&(this.marshaled=xu.encode({publicKey:ir(this.publicKey),payloadType:this.payloadType,payload:this.payload.subarray(),signature:this.signature})),this.marshaled}equals(e){return e==null?!1:ce(this.marshal(),e.marshal())}async validate(e,t){let n=o_(e,this.payloadType,this.payload);return this.publicKey.verify(n.subarray(),this.signature,t)}},o_=(r,e,t)=>{let n=L(r),o=oo(n.byteLength),i=oo(e.length),s=oo(t.length);return new Ae(o,n,i,e,s,t)};var i_="libp2p-peer-record",s_=Uint8Array.from([3,1]);var Eu;(function(r){let e;(function(s){let a;s.codec=()=>(a==null&&(a=ft((f,d,h={})=>{h.lengthDelimited!==!1&&d.fork(),f.multiaddr!=null&&f.multiaddr.byteLength>0&&(d.uint32(10),d.bytes(f.multiaddr)),h.lengthDelimited!==!1&&d.ldelim()},(f,d,h={})=>{let m={multiaddr:Re(0)},y=d==null?f.len:f.pos+d;for(;f.pos<y;){let g=f.uint32();g>>>3===1?m.multiaddr=f.bytes():f.skipType(g&7)}return m},function*(f,d,h,m={}){let y=d==null?f.len:f.pos+d;for(;f.pos<y;){let g=f.uint32();g>>>3===1?yield{field:`${h}.multiaddr`,value:f.bytes()}:f.skipType(g&7)}})),a);function c(f){return ut(f,s.codec())}s.encode=c;function u(f,d){return ct(f,s.codec(),d)}s.decode=u;function l(f,d){return lt(f,s.codec(),d)}s.stream=l})(e=r.AddressInfo||(r.AddressInfo={}));let t;r.codec=()=>(t==null&&(t=ft((s,a,c={})=>{if(c.lengthDelimited!==!1&&a.fork(),s.peerId!=null&&s.peerId.byteLength>0&&(a.uint32(10),a.bytes(s.peerId)),s.seq!=null&&s.seq!==0n&&(a.uint32(16),a.uint64(s.seq)),s.addresses!=null&&s.addresses.length>0)for(let u of s.addresses)a.uint32(26),r.AddressInfo.codec().encode(u,a);c.lengthDelimited!==!1&&a.ldelim()},(s,a,c={})=>{let u={peerId:Re(0),seq:0n,addresses:[]},l=a==null?s.len:s.pos+a;for(;s.pos<l;){let f=s.uint32();switch(f>>>3){case 1:{u.peerId=s.bytes();break}case 2:{u.seq=s.uint64();break}case 3:{if(c.limits?.addresses!=null&&u.addresses.length===c.limits.addresses)throw new ar('Decode error - repeated field "addresses" had too many elements');u.addresses.push(r.AddressInfo.codec().decode(s,s.uint32(),{limits:c.limits?.addresses$}));break}default:{s.skipType(f&7);break}}}return u},function*(s,a,c,u={}){let l={addresses:0},f=a==null?s.len:s.pos+a;for(;s.pos<f;){let d=s.uint32();switch(d>>>3){case 1:{yield{field:`${c}.peerId`,value:s.bytes()};break}case 2:{yield{field:`${c}.seq`,value:s.uint64()};break}case 3:{if(u.limits?.addresses!=null&&l.addresses===u.limits.addresses)throw new ar('Streaming decode error - repeated field "addresses" had too many elements');for(let h of r.AddressInfo.codec().stream(s,s.uint32(),`${c}.addresses[]`,{limits:u.limits?.addresses$}))yield{...h,index:l.addresses};l.addresses++;break}default:{s.skipType(d&7);break}}}})),t);function n(s){return ut(s,r.codec())}r.encode=n;function o(s,a){return ct(s,r.codec(),a)}r.decode=o;function i(s,a){return lt(s,r.codec(),a)}r.stream=i})(Eu||(Eu={}));function a_(r,e){let t=(n,o)=>n.toString().localeCompare(o.toString());return r.length!==e.length?!1:(e.sort(t),r.sort(t).every((n,o)=>e[o].equals(n)))}var Pi=class r{static createFromProtobuf=e=>{let t=Eu.decode(e),n=po(Ct(t.peerId)),o=(t.addresses??[]).map(s=>fe(s.multiaddr)),i=t.seq;return new r({peerId:n,multiaddrs:o,seqNumber:i})};static DOMAIN=i_;static CODEC=s_;peerId;multiaddrs;seqNumber;domain=r.DOMAIN;codec=r.CODEC;marshaled;constructor(e){let{peerId:t,multiaddrs:n,seqNumber:o}=e;this.peerId=t,this.multiaddrs=n??[],this.seqNumber=o??BigInt(Date.now())}marshal(){return this.marshaled==null&&(this.marshaled=Eu.encode({peerId:this.peerId.toMultihash().bytes,seq:BigInt(this.seqNumber),addresses:this.multiaddrs.map(e=>({multiaddr:e.bytes}))})),this.marshaled}equals(e){return!(!(e instanceof r)||!this.peerId.equals(e.peerId)||this.seqNumber!==e.seqNumber||!a_(this.multiaddrs,e.multiaddrs))}};var Fn;(function(r){let e;(function(a){let c;a.codec=()=>(c==null&&(c=ft((d,h,m={})=>{m.lengthDelimited!==!1&&h.fork(),d.key!=null&&d.key!==""&&(h.uint32(10),h.string(d.key)),d.value!=null&&d.value.byteLength>0&&(h.uint32(18),h.bytes(d.value)),m.lengthDelimited!==!1&&h.ldelim()},(d,h,m={})=>{let y={key:"",value:Re(0)},g=h==null?d.len:d.pos+h;for(;d.pos<g;){let b=d.uint32();switch(b>>>3){case 1:{y.key=d.string();break}case 2:{y.value=d.bytes();break}default:{d.skipType(b&7);break}}}return y},function*(d,h,m,y={}){let g=h==null?d.len:d.pos+h;for(;d.pos<g;){let b=d.uint32();switch(b>>>3){case 1:{yield{field:`${m}.key`,value:d.string()};break}case 2:{yield{field:`${m}.value`,value:d.bytes()};break}default:{d.skipType(b&7);break}}}})),c);function u(d){return ut(d,a.codec())}a.encode=u;function l(d,h){return ct(d,a.codec(),h)}a.decode=l;function f(d,h){return lt(d,a.codec(),h)}a.stream=f})(e=r.Peer$metadataEntry||(r.Peer$metadataEntry={}));let t;(function(a){let c;a.codec=()=>(c==null&&(c=ft((d,h,m={})=>{m.lengthDelimited!==!1&&h.fork(),d.key!=null&&d.key!==""&&(h.uint32(10),h.string(d.key)),d.value!=null&&(h.uint32(18),Au.codec().encode(d.value,h)),m.lengthDelimited!==!1&&h.ldelim()},(d,h,m={})=>{let y={key:""},g=h==null?d.len:d.pos+h;for(;d.pos<g;){let b=d.uint32();switch(b>>>3){case 1:{y.key=d.string();break}case 2:{y.value=Au.codec().decode(d,d.uint32(),{limits:m.limits?.value});break}default:{d.skipType(b&7);break}}}return y},function*(d,h,m,y={}){let g=h==null?d.len:d.pos+h;for(;d.pos<g;){let b=d.uint32();switch(b>>>3){case 1:{yield{field:`${m}.key`,value:d.string()};break}case 2:{yield*Au.codec().stream(d,d.uint32(),`${m}.value`,{limits:y.limits?.value});break}default:{d.skipType(b&7);break}}}})),c);function u(d){return ut(d,a.codec())}a.encode=u;function l(d,h){return ct(d,a.codec(),h)}a.decode=l;function f(d,h){return lt(d,a.codec(),h)}a.stream=f})(t=r.Peer$tagsEntry||(r.Peer$tagsEntry={}));let n;r.codec=()=>(n==null&&(n=ft((a,c,u={})=>{if(u.lengthDelimited!==!1&&c.fork(),a.addresses!=null&&a.addresses.length>0)for(let l of a.addresses)c.uint32(10),vu.codec().encode(l,c);if(a.protocols!=null&&a.protocols.length>0)for(let l of a.protocols)c.uint32(18),c.string(l);if(a.publicKey!=null&&(c.uint32(34),c.bytes(a.publicKey)),a.peerRecordEnvelope!=null&&(c.uint32(42),c.bytes(a.peerRecordEnvelope)),a.metadata!=null&&a.metadata.size>0)for(let[l,f]of a.metadata.entries())c.uint32(50),r.Peer$metadataEntry.codec().encode({key:l,value:f},c);if(a.tags!=null&&a.tags.size>0)for(let[l,f]of a.tags.entries())c.uint32(58),r.Peer$tagsEntry.codec().encode({key:l,value:f},c);a.updated!=null&&(c.uint32(64),c.uint64Number(a.updated)),u.lengthDelimited!==!1&&c.ldelim()},(a,c,u={})=>{let l={addresses:[],protocols:[],metadata:new Map,tags:new Map},f=c==null?a.len:a.pos+c;for(;a.pos<f;){let d=a.uint32();switch(d>>>3){case 1:{if(u.limits?.addresses!=null&&l.addresses.length===u.limits.addresses)throw new ar('Decode error - repeated field "addresses" had too many elements');l.addresses.push(vu.codec().decode(a,a.uint32(),{limits:u.limits?.addresses$}));break}case 2:{if(u.limits?.protocols!=null&&l.protocols.length===u.limits.protocols)throw new ar('Decode error - repeated field "protocols" had too many elements');l.protocols.push(a.string());break}case 4:{l.publicKey=a.bytes();break}case 5:{l.peerRecordEnvelope=a.bytes();break}case 6:{if(u.limits?.metadata!=null&&l.metadata.size===u.limits.metadata)throw new Ja('Decode error - map field "metadata" had too many elements');let h=r.Peer$metadataEntry.codec().decode(a,a.uint32(),{limits:{value:u.limits?.metadata$value}});l.metadata.set(h.key,h.value);break}case 7:{if(u.limits?.tags!=null&&l.tags.size===u.limits.tags)throw new Ja('Decode error - map field "tags" had too many elements');let h=r.Peer$tagsEntry.codec().decode(a,a.uint32(),{limits:{value:u.limits?.tags$value}});l.tags.set(h.key,h.value);break}case 8:{l.updated=a.uint64Number();break}default:{a.skipType(d&7);break}}}return l},function*(a,c,u,l={}){let f={addresses:0,protocols:0,metadata:0,tags:0},d=c==null?a.len:a.pos+c;for(;a.pos<d;){let h=a.uint32();switch(h>>>3){case 1:{if(l.limits?.addresses!=null&&f.addresses===l.limits.addresses)throw new ar('Streaming decode error - repeated field "addresses" had too many elements');for(let m of vu.codec().stream(a,a.uint32(),`${u}.addresses[]`,{limits:l.limits?.addresses$}))yield{...m,index:f.addresses};f.addresses++;break}case 2:{if(l.limits?.protocols!=null&&f.protocols===l.limits.protocols)throw new ar('Streaming decode error - repeated field "protocols" had too many elements');yield{field:`${u}.protocols[]`,index:f.protocols,value:a.string()},f.protocols++;break}case 4:{yield{field:`${u}.publicKey`,value:a.bytes()};break}case 5:{yield{field:`${u}.peerRecordEnvelope`,value:a.bytes()};break}case 6:{if(l.limits?.metadata!=null&&f.metadata===l.limits.metadata)throw new ar('Decode error - map field "metadata" had too many elements');yield*r.Peer$metadataEntry.codec().stream(a,a.uint32(),`${u}.metadata{}`,{limits:{value:l.limits?.metadata$value}}),f.metadata++;break}case 7:{if(l.limits?.tags!=null&&f.tags===l.limits.tags)throw new ar('Decode error - map field "tags" had too many elements');yield*r.Peer$tagsEntry.codec().stream(a,a.uint32(),`${u}.tags{}`,{limits:{value:l.limits?.tags$value}}),f.tags++;break}case 8:{yield{field:`${u}.updated`,value:a.uint64Number()};break}default:{a.skipType(h&7);break}}}})),n);function o(a){return ut(a,r.codec())}r.encode=o;function i(a,c){return ct(a,r.codec(),c)}r.decode=i;function s(a,c){return lt(a,r.codec(),c)}r.stream=s})(Fn||(Fn={}));var vu;(function(r){let e;r.codec=()=>(e==null&&(e=ft((i,s,a={})=>{a.lengthDelimited!==!1&&s.fork(),i.multiaddr!=null&&i.multiaddr.byteLength>0&&(s.uint32(10),s.bytes(i.multiaddr)),i.isCertified!=null&&(s.uint32(16),s.bool(i.isCertified)),i.observed!=null&&(s.uint32(24),s.uint64Number(i.observed)),a.lengthDelimited!==!1&&s.ldelim()},(i,s,a={})=>{let c={multiaddr:Re(0)},u=s==null?i.len:i.pos+s;for(;i.pos<u;){let l=i.uint32();switch(l>>>3){case 1:{c.multiaddr=i.bytes();break}case 2:{c.isCertified=i.bool();break}case 3:{c.observed=i.uint64Number();break}default:{i.skipType(l&7);break}}}return c},function*(i,s,a,c={}){let u=s==null?i.len:i.pos+s;for(;i.pos<u;){let l=i.uint32();switch(l>>>3){case 1:{yield{field:`${a}.multiaddr`,value:i.bytes()};break}case 2:{yield{field:`${a}.isCertified`,value:i.bool()};break}case 3:{yield{field:`${a}.observed`,value:i.uint64Number()};break}default:{i.skipType(l&7);break}}}})),e);function t(i){return ut(i,r.codec())}r.encode=t;function n(i,s){return ct(i,r.codec(),s)}r.decode=n;function o(i,s){return lt(i,r.codec(),s)}r.stream=o})(vu||(vu={}));var Au;(function(r){let e;r.codec=()=>(e==null&&(e=ft((i,s,a={})=>{a.lengthDelimited!==!1&&s.fork(),i.value!=null&&i.value!==0&&(s.uint32(8),s.uint32(i.value)),i.expiry!=null&&(s.uint32(16),s.uint64(i.expiry)),a.lengthDelimited!==!1&&s.ldelim()},(i,s,a={})=>{let c={value:0},u=s==null?i.len:i.pos+s;for(;i.pos<u;){let l=i.uint32();switch(l>>>3){case 1:{c.value=i.uint32();break}case 2:{c.expiry=i.uint64();break}default:{i.skipType(l&7);break}}}return c},function*(i,s,a,c={}){let u=s==null?i.len:i.pos+s;for(;i.pos<u;){let l=i.uint32();switch(l>>>3){case 1:{yield{field:`${a}.value`,value:i.uint32()};break}case 2:{yield{field:`${a}.expiry`,value:i.uint64()};break}default:{i.skipType(l&7);break}}}})),e);function t(i){return ut(i,r.codec())}r.encode=t;function n(i,s){return ct(i,r.codec(),s)}r.decode=n;function o(i,s){return lt(i,r.codec(),s)}r.stream=o})(Au||(Au={}));function UP(r,e){if(r.publicKey!=null||e.publicKey==null)return r;let t;r.type==="RSA"&&(t=r.toMultihash());let n=ao(e.publicKey,t);return My(n)}function c_(r,e,t){let n=Fn.decode(e);return da(r,n,t)}function da(r,e,t){let n=new Map,o=BigInt(Date.now());for(let[i,s]of e.tags.entries())s.expiry!=null&&s.expiry<o||n.set(i,s);return{...e,id:UP(r,e),addresses:e.addresses.filter(({observed:i})=>i!=null&&i>Date.now()-t).map(({multiaddr:i,isCertified:s})=>({multiaddr:fe(i),isCertified:s??!1})),metadata:e.metadata,peerRecordEnvelope:e.peerRecordEnvelope??void 0,tags:n}}function u_(r,e){return OP(r.addresses,e.addresses)&&MP(r.protocols,e.protocols)&&FP(r.publicKey,e.publicKey)&&$P(r.peerRecordEnvelope,e.peerRecordEnvelope)&&VP(r.metadata,e.metadata)&&KP(r.tags,e.tags)}function OP(r,e){return f_(r,e,(t,n)=>!(t.isCertified!==n.isCertified||!ce(t.multiaddr,n.multiaddr)))}function MP(r,e){return f_(r,e,(t,n)=>t===n)}function FP(r,e){return l_(r,e)}function $P(r,e){return l_(r,e)}function VP(r,e){return d_(r,e,(t,n)=>ce(t,n))}function KP(r,e){return d_(r,e,(t,n)=>t.value===n.value&&t.expiry===n.expiry)}function l_(r,e){return r==null&&e==null?!0:r!=null&&e!=null?ce(r,e):!1}function f_(r,e,t){if(r.length!==e.length)return!1;for(let n=0;n<r.length;n++)if(!t(r[n],e[n]))return!1;return!0}function d_(r,e,t){if(r.size!==e.size)return!1;for(let[n,o]of r.entries()){let i=e.get(n);if(i==null||!t(o,i))return!1}return!0}var Mw="/peers/";function Su(r){if(!nr(r)||r.type==null)throw new T("Invalid PeerId");let e=r.toCID().toString();return new Le(`${Mw}${e}`)}async function h_(r,e,t,n,o){let i=new Map;for(let s of t){if(s==null)continue;if(s.multiaddr instanceof Uint8Array&&(s.multiaddr=fe(s.multiaddr)),!ho(s.multiaddr))throw new T("Multiaddr was invalid");if(!await e(r,s.multiaddr,o))continue;let a=s.isCertified??!1,c=s.multiaddr.toString(),u=i.get(c);u!=null?s.isCertified=u.isCertified||a:i.set(c,{multiaddr:s.multiaddr,isCertified:a})}return[...i.values()].sort((s,a)=>s.multiaddr.toString().localeCompare(a.multiaddr.toString())).map(({isCertified:s,multiaddr:a})=>{let c=a.getComponents().find(u=>u.code===421)?.value;return r.equals(c)&&(a=a.decapsulate(fe(`/p2p/${r}`))),{isCertified:s,multiaddr:a.bytes}})}async function Th(r,e,t,n){if(e==null)throw new T("Invalid PeerData");if(e.publicKey!=null&&r.publicKey!=null&&!e.publicKey.equals(r.publicKey))throw new T("publicKey bytes do not match peer id publicKey bytes");let o=n.existingPeer?.peer;if(o!=null&&!r.equals(o.id))throw new T("peer id did not match existing peer id");let i=o?.addresses??[],s=new Set(o?.protocols??[]),a=o?.metadata??new Map,c=o?.tags??new Map,u=o?.peerRecordEnvelope;if(t==="patch"){if((e.multiaddrs!=null||e.addresses!=null)&&(i=[],e.multiaddrs!=null&&i.push(...e.multiaddrs.map(d=>({isCertified:!1,multiaddr:d}))),e.addresses!=null&&i.push(...e.addresses)),e.protocols!=null&&(s=new Set(e.protocols)),e.metadata!=null){let d=e.metadata instanceof Map?[...e.metadata.entries()]:Object.entries(e.metadata);a=Ih(d,{validate:p_})}if(e.tags!=null){let d=e.tags instanceof Map?[...e.tags.entries()]:Object.entries(e.tags);c=Ih(d,{validate:m_,map:g_})}e.peerRecordEnvelope!=null&&(u=e.peerRecordEnvelope)}if(t==="merge"){if(e.multiaddrs!=null&&i.push(...e.multiaddrs.map(d=>({isCertified:!1,multiaddr:d}))),e.addresses!=null&&i.push(...e.addresses),e.protocols!=null&&(s=new Set([...s,...e.protocols])),e.metadata!=null){let d=e.metadata instanceof Map?[...e.metadata.entries()]:Object.entries(e.metadata);for(let[h,m]of d)m==null?a.delete(h):a.set(h,m);a=Ih([...a.entries()],{validate:p_})}if(e.tags!=null){let d=e.tags instanceof Map?[...e.tags.entries()]:Object.entries(e.tags),h=new Map(c);for(let[m,y]of d)y==null?h.delete(m):h.set(m,y);c=Ih([...h.entries()],{validate:m_,map:g_})}e.peerRecordEnvelope!=null&&(u=e.peerRecordEnvelope)}let l;o?.id.publicKey!=null?l=ir(o.id.publicKey):e.publicKey!=null?l=ir(e.publicKey):r.publicKey!=null&&(l=ir(r.publicKey));let f={addresses:await h_(r,n.addressFilter??(async()=>!0),i,n.existingPeer?.peerPB.addresses,n),protocols:[...s.values()].sort((d,h)=>d.localeCompare(h)),metadata:a,tags:c,publicKey:l,peerRecordEnvelope:u};return f.addresses.forEach(d=>{d.observed=n.existingPeer?.peerPB.addresses?.find(h=>ce(h.multiaddr,h.multiaddr))?.observed??Date.now()}),r.type!=="RSA"&&delete f.publicKey,f}function Ih(r,e){let t=new Map;for(let[n,o]of r)o!=null&&e.validate(n,o);for(let[n,o]of r.sort(([i],[s])=>i.localeCompare(s)))o!=null&&t.set(n,e.map?.(n,o)??o);return t}function p_(r,e){if(typeof r!="string")throw new T("Metadata key must be a string");if(!(e instanceof Uint8Array))throw new T("Metadata value must be a Uint8Array")}function m_(r,e){if(typeof r!="string")throw new T("Tag name must be a string");if(e.value!=null){if(parseInt(`${e.value}`,10)!==e.value)throw new T("Tag value must be an integer");if(e.value<0||e.value>100)throw new T("Tag value must be between 0-100")}if(e.ttl!=null){if(parseInt(`${e.ttl}`,10)!==e.ttl)throw new T("Tag ttl must be an integer");if(e.ttl<0)throw new T("Tag ttl must be between greater than 0")}}function g_(r,e){let t;e.expiry!=null&&(t=e.expiry),e.ttl!=null&&(t=BigInt(Date.now()+Number(e.ttl)));let n={value:e.value??0};return t!=null&&(n.expiry=t),n}function y_(r){let e=r.toString().split("/")[2],t=Q.parse(e,Xe);return Bn(t)}function Fw(r,e,t){let n=y_(r);return c_(n,e,t)}function qP(r,e){return{prefix:Mw,filters:(r.filters??[]).map(t=>({key:n,value:o})=>t(Fw(n,o,e))),orders:(r.orders??[]).map(t=>(n,o)=>t(Fw(n.key,n.value,e),Fw(o.key,o.value,e)))}}var Ch=class{peerId;datastore;locks;addressFilter;log;maxAddressAge;maxPeerAge;constructor(e,t={}){this.log=e.logger.forComponent("libp2p:peer-store"),this.peerId=e.peerId,this.datastore=e.datastore,this.addressFilter=t.addressFilter,this.locks=$y({name:"libp2p_peer_store_locks",metrics:e.metrics}),this.maxAddressAge=t.maxAddressAge??36e5,this.maxPeerAge=t.maxPeerAge??216e5}getLock(e){let t=this.locks.get(e);return t==null&&(t={refs:0,lock:Vc({name:e.toString(),singleProcess:!0})},this.locks.set(e,t)),t.refs++,t}maybeRemoveLock(e,t){t.refs--,t.refs===0&&(t.lock.finalize(),this.locks.delete(e))}async getReadLock(e,t){let n=this.getLock(e);try{let o=await n.lock.readLock(t);return()=>{o(),this.maybeRemoveLock(e,n)}}catch(o){throw this.maybeRemoveLock(e,n),o}}async getWriteLock(e,t){let n=this.getLock(e);try{let o=await n.lock.writeLock(t);return()=>{o(),this.maybeRemoveLock(e,n)}}catch(o){throw this.maybeRemoveLock(e,n),o}}async has(e,t){try{return await this.load(e,t),!0}catch(n){if(n.name!=="NotFoundError")throw n}return!1}async delete(e,t){this.peerId.equals(e)||await this.datastore.delete(Su(e),t)}async load(e,t){let n=Su(e),o=await this.datastore.get(n,t),i=Fn.decode(o);if(this.#r(e,i))throw await this.datastore.delete(n,t),new He;return da(e,i,this.peerId.equals(e)?1/0:this.maxAddressAge)}async save(e,t,n){let o=await this.#e(e,n),i=await Th(e,t,"patch",{...n,addressFilter:this.addressFilter});return this.#t(e,i,o)}async patch(e,t,n){let o=await this.#e(e,n),i=await Th(e,t,"patch",{...n,addressFilter:this.addressFilter,existingPeer:o});return this.#t(e,i,o)}async merge(e,t,n){let o=await this.#e(e,n),i=await Th(e,t,"merge",{addressFilter:this.addressFilter,existingPeer:o});return this.#t(e,i,o)}async*all(e){for await(let{key:t,value:n}of this.datastore.query(qP(e??{},this.maxAddressAge),e)){let o=y_(t);if(o.equals(this.peerId))continue;let i=Fn.decode(n);if(this.#r(o,i)){await this.datastore.delete(t,e);continue}yield da(o,i,this.peerId.equals(o)?1/0:this.maxAddressAge)}}async#e(e,t){try{let n=Su(e),o=await this.datastore.get(n,t),i=Fn.decode(o);if(this.#r(e,i))throw await this.datastore.delete(n,t),new He;return{peerPB:i,peer:da(e,i,this.maxAddressAge)}}catch(n){n.name!=="NotFoundError"&&this.log.error("invalid peer data found in peer store - %e",n)}}async#t(e,t,n,o){t.updated=Date.now();let i=Fn.encode(t);return await this.datastore.put(Su(e),i,o),{peer:da(e,t,this.maxAddressAge),previous:n?.peer,updated:n==null||!u_(t,n.peerPB)}}#r(e,t){if(t.updated==null)return!0;if(this.peerId.equals(e))return!1;let n=t.updated<Date.now()-this.maxPeerAge,o=Date.now()-this.maxAddressAge,i=t.addresses.filter(s=>s.observed!=null&&s.observed>o);return n&&i.length===0}};var $w=class{store;events;peerId;log;constructor(e,t={}){this.log=e.logger.forComponent("libp2p:peer-store"),this.events=e.events,this.peerId=e.peerId,this.store=new Ch(e,t)}[Symbol.toStringTag]="@libp2p/peer-store";async forEach(e,t){for await(let n of this.store.all(t))e(n)}async all(e){return Bi(this.store.all(e))}async delete(e,t){let n=await this.store.getReadLock(e,t);try{await this.store.delete(e,t)}finally{n()}}async has(e,t){let n=await this.store.getReadLock(e,t);try{return await this.store.has(e,t)}finally{this.log.trace("has release read lock"),n?.()}}async get(e,t){let n=await this.store.getReadLock(e,t);try{return await this.store.load(e,t)}finally{n?.()}}async getInfo(e,t){let n=await this.get(e,t);return{id:n.id,multiaddrs:n.addresses.map(({multiaddr:o})=>o)}}async save(e,t,n){let o=await this.store.getWriteLock(e,n);try{let i=await this.store.save(e,t,n);return this.#e(e,i),i.peer}finally{o?.()}}async patch(e,t,n){let o=await this.store.getWriteLock(e,n);try{let i=await this.store.patch(e,t,n);return this.#e(e,i),i.peer}finally{o?.()}}async merge(e,t,n){let o=await this.store.getWriteLock(e,n);try{let i=await this.store.merge(e,t,n);return this.#e(e,i),i.peer}finally{o?.()}}async consumePeerRecord(e,t,n){let o=nr(t)?t:nr(t?.expectedPeer)?t.expectedPeer:void 0,i=nr(t)||t===void 0?n:t,s=await fa.openAndCertify(e,Pi.DOMAIN,i),a=Bn(s.publicKey.toCID());if(o?.equals(a)===!1)return this.log("envelope peer id was not the expected peer id - expected: %p received: %p",o,a),!1;let c=Pi.createFromProtobuf(s.payload),u;try{u=await this.get(a,i)}catch(l){if(l.name!=="NotFoundError")throw l}if(u?.peerRecordEnvelope!=null){let l=fa.createFromProtobuf(u.peerRecordEnvelope),f=Pi.createFromProtobuf(l.payload);if(f.seqNumber>=c.seqNumber)return this.log("sequence number was lower or equal to existing sequence number - stored: %d received: %d",f.seqNumber,c.seqNumber),!1}return await this.patch(c.peerId,{peerRecordEnvelope:e,addresses:c.multiaddrs.map(l=>({isCertified:!0,multiaddr:l}))},i),!0}#e(e,t){t.updated&&(this.peerId.equals(e)?this.events.safeDispatchEvent("self:peer:update",{detail:t}):this.events.safeDispatchEvent("peer:update",{detail:t}))}};function w_(r,e={}){return new $w(r,e)}var b_=864e13;var Bh=class{log;mappings;constructor(e,t={}){this.log=e.logger.forComponent("libp2p:address-manager:dns-mappings"),this.mappings=xt({name:"libp2p_address_manager_dns_mappings",metrics:e.metrics})}has(e){let t=ue(e),n=t.host;(t.type==="ip4"||t.type==="ip6")&&t.sni!=null&&(n=t.sni);for(let o of this.mappings.values())if(o.domain===n)return!0;return!1}add(e,t){t.forEach(n=>{this.log("add DNS mapping %s to %s",n,e);let o=ws(n)===!0;this.mappings.set(n,{domain:e,verified:o,expires:o?b_-Date.now():0,lastVerified:o?b_-Date.now():void 0})})}remove(e){let t=ue(e);if(t.type!=="ip4"&&t.type!=="ip6")return!1;let n=!1;for(let[o,i]of this.mappings.entries())i.domain===t.sni&&(this.log("removing %s to %s DNS mapping %e",o,i.domain),this.mappings.delete(o),n=n||i.verified);return n}getAll(e){let t=[];for(let n=0;n<e.length;n++){let o=e[n].multiaddr;if(!dt(o))continue;let i=ue(o);for(let[s,a]of this.mappings.entries()){if(i.host!==s)continue;let c=this.maybeAddSNIComponent(o,a.domain);c!=null&&(e.splice(n,1),n--,t.push({multiaddr:c,verified:a.verified,type:"dns-mapping",expires:a.expires,lastVerified:a.lastVerified}))}}return t}maybeAddSNIComponent(e,t){let n=e.getComponents();for(let o=0;o<n.length;o++)if(n[o].code===448&&n[o+1]?.code!==449)return n.splice(o+1,0,{name:"sni",code:449,value:t}),fe(n)}confirm(e,t){let n=ue(e),o=n.host;(n.type==="ip4"||n.type==="ip6")&&n.sni!=null&&(o=n.sni);let i=!1;for(let[s,a]of this.mappings.entries())a.domain===o&&(this.log("marking %s to %s DNS mapping as verified",s,a.domain),i=a.verified,a.verified=!0,a.expires=Date.now()+t,a.lastVerified=Date.now());return i}unconfirm(e,t){let n=ue(e);if(n.type!=="ip4"&&n.type!=="ip6")return!1;let o=n.sni??n.host,i=!1;for(let[s,a]of this.mappings.entries())a.domain===o&&(this.log("removing verification of %s to %s DNS mapping",s,a.domain),i=i||a.verified,a.verified=!1,a.expires=Date.now()+t);return i}};var Nh=class{log;mappings;constructor(e,t={}){this.log=e.logger.forComponent("libp2p:address-manager:ip-mappings"),this.mappings=xt({name:"libp2p_address_manager_ip_mappings",metrics:e.metrics})}has(e){let t=ue(e);if(t.type!=="ip4"&&t.type!=="ip6")return!1;for(let n of this.mappings.values())for(let o of n)if(o.externalIp===t.host)return!0;return!1}add(e,t,n,o=t,i="tcp"){let s=`${e}-${t}-${i}`,a=this.mappings.get(s)??[],c={internalIp:e,internalPort:t,externalIp:n,externalPort:o,externalFamily:Mr(n)?4:6,protocol:i,verified:!1,expires:0};a.push(c),this.mappings.set(s,a)}remove(e){let t=ue(e);if(t.type!=="ip4"&&t.type!=="ip6")return!1;let n=!1;for(let[o,i]of this.mappings.entries()){for(let s=0;s<i.length;s++){let a=i[s];a.externalIp===t.host&&a.externalPort===t.port&&a.protocol===t.protocol&&(this.log("removing %s:%s to %s:%s %s IP mapping",a.externalIp,a.externalPort,t.host,t.port,t.protocol),n=n||a.verified,i.splice(s,1),s--)}i.length===0&&this.mappings.delete(o)}return n}getAll(e){let t=[];for(let{multiaddr:n}of e){if(!dt(n))continue;let o=ue(n);if(o.type!=="ip4"&&o.type!=="ip6")continue;let i;if(o.protocol==="tcp"?i=`${o.host}-${o.port}-tcp`:o.protocol==="udp"&&(i=`${o.host}-${o.port}-udp`),i==null)continue;let s=this.mappings.get(i);if(s!=null)for(let a of s)t.push({multiaddr:this.maybeOverrideIp(n,a.externalIp,a.externalFamily,a.protocol,a.externalPort),verified:a.verified,type:"ip-mapping",expires:a.expires,lastVerified:a.lastVerified})}return t}maybeOverrideIp(e,t,n,o,i){let s=e.getComponents(),a=s.findIndex(u=>u.code===4||u.code===41),c=s.findIndex(u=>u.name===o);return a>-1&&c>-1?(s[a].value=t,s[a].code=n===4?4:41,s[c].value=`${i}`,fe(s)):e}confirm(e,t){if(!dt(e))return!1;let n=ue(e),o=!1;for(let i of this.mappings.values())for(let s of i)s.externalIp===n.host&&(this.log("marking %s to %s IP mapping as verified",s.internalIp,s.externalIp),o=s.verified,s.verified=!0,s.expires=Date.now()+t,s.lastVerified=Date.now());return o}unconfirm(e,t){if(!dt(e))return!1;let n=ue(e),o=!1;for(let i of this.mappings.values())for(let s=0;s<i.length;s++){let a=i[s];a.externalIp===n.host&&a.externalPort===n.port&&a.protocol===n.protocol&&(this.log("removing verification of %s:%s to %s:%s %s IP mapping",a.externalIp,a.externalPort,n.host,n.port,n.protocol),o=o||a.verified,a.verified=!1,a.expires=Date.now()+t)}return o}};var HP={maxObservedAddresses:10},Ph=class{log;addresses;maxObservedAddresses;constructor(e,t={}){this.log=e.logger.forComponent("libp2p:address-manager:observed-addresses"),this.addresses=xt({name:"libp2p_address_manager_observed_addresses",metrics:e.metrics}),this.maxObservedAddresses=t.maxObservedAddresses??HP.maxObservedAddresses}has(e){return this.addresses.has(e.toString())}removePrefixed(e){for(let t of this.addresses.keys())t.toString().startsWith(e)&&this.addresses.delete(t)}add(e){this.addresses.size!==this.maxObservedAddresses&&(Fr(e)||VE(e)||(this.log("adding observed address %a",e),this.addresses.set(e.toString(),{verified:!1,expires:0})))}getAll(){return Array.from(this.addresses).map(([e,t])=>({multiaddr:fe(e),verified:t.verified,type:"observed",expires:t.expires,lastVerified:t.lastVerified}))}remove(e){let t=this.addresses.get(e.toString())?.verified??!1;return this.log("removing observed address %a",e),this.addresses.delete(e.toString()),t}confirm(e,t){let n=e.toString(),o=this.addresses.get(n)??{verified:!1,expires:Date.now()+t,lastVerified:Date.now()},i=o.verified;return o.verified=!0,o.expires=Date.now()+t,o.lastVerified=Date.now(),this.log("marking observed address %a as verified",n),this.addresses.set(n,o),i}};var zP={maxObservedAddresses:10},Lh=class{log;addresses;maxObservedAddresses;constructor(e,t={}){this.log=e.logger.forComponent("libp2p:address-manager:observed-addresses"),this.addresses=xt({name:"libp2p_address_manager_transport_addresses",metrics:e.metrics}),this.maxObservedAddresses=t.maxObservedAddresses??zP.maxObservedAddresses}get(e,t){if(Fr(e))return{multiaddr:e,verified:!0,type:"transport",expires:Date.now()+t,lastVerified:Date.now()};let n=this.toKey(e),o=this.addresses.get(n);return o==null&&(o={verified:!dt(e),expires:0},this.addresses.set(n,o)),{multiaddr:e,verified:o.verified,type:"transport",expires:o.expires,lastVerified:o.lastVerified}}has(e){let t=this.toKey(e);return this.addresses.has(t)}remove(e){let t=this.toKey(e),n=this.addresses.get(t)?.verified??!1;return this.log("removing observed address %a",e),this.addresses.delete(t),n}confirm(e,t){let n=this.toKey(e),o=this.addresses.get(n)??{verified:!1,expires:0,lastVerified:0},i=o.verified;return o.verified=!0,o.expires=Date.now()+t,o.lastVerified=Date.now(),this.addresses.set(n,o),i}unconfirm(e,t){let n=this.toKey(e),o=this.addresses.get(n)??{verified:!1,expires:0},i=o.verified;return o.verified=!1,o.expires=Date.now()+t,this.addresses.set(n,o),i}toKey(e){if(!dt(e))return e.toString();let t=ue(e);return`${t.host}-${t.port}-${t.protocol}`}};var x_=6e4,E_={maxObservedAddresses:10,addressVerificationTTL:x_*10,addressVerificationRetry:x_*5},jP=r=>r;function Vw(r,e){let t=r.getComponents().findLast(n=>n.code===421)?.value;return t!=null&&lr(t).equals(e)&&(r=r.decapsulate(fe(`/p2p/${e.toString()}`))),r}var Dh=class{log;components;listen;announce;appendAnnounce;announceFilter;observed;dnsMappings;ipMappings;transportAddresses;observedAddressFilter;addressVerificationTTL;addressVerificationRetry;constructor(e,t={}){let{listen:n=[],announce:o=[],appendAnnounce:i=[]}=t;this.components=e,this.log=e.logger.forComponent("libp2p:address-manager"),this.listen=n.map(s=>s.toString()),this.announce=new Set(o.map(s=>s.toString())),this.appendAnnounce=new Set(i.map(s=>s.toString())),this.observed=new Ph(e,t),this.dnsMappings=new Bh(e,t),this.ipMappings=new Nh(e,t),this.transportAddresses=new Lh(e,t),this.announceFilter=t.announceFilter??jP,this.observedAddressFilter=uo(1024),this.addressVerificationTTL=t.addressVerificationTTL??E_.addressVerificationTTL,this.addressVerificationRetry=t.addressVerificationRetry??E_.addressVerificationRetry,this._updatePeerStoreAddresses=lc(this._updatePeerStoreAddresses.bind(this),1e3),e.events.addEventListener("transport:listening",()=>{this._updatePeerStoreAddresses()}),e.events.addEventListener("transport:close",()=>{this._updatePeerStoreAddresses()})}[Symbol.toStringTag]="@libp2p/address-manager";_updatePeerStoreAddresses(){let e=this.getAddresses().map(t=>t.getComponents().findLast(n=>n.code===421)?.value===this.components.peerId.toString()?t.decapsulate(`/p2p/${this.components.peerId.toString()}`):t);this.components.peerStore.patch(this.components.peerId,{multiaddrs:e}).catch(t=>{this.log.error("error updating addresses - %e",t)})}getListenAddrs(){return Array.from(this.listen).map(e=>fe(e))}getAnnounceAddrs(){return Array.from(this.announce).map(e=>fe(e))}getAppendAnnounceAddrs(){return Array.from(this.appendAnnounce).map(e=>fe(e))}getObservedAddrs(){return this.observed.getAll().map(e=>e.multiaddr)}addObservedAddr(e){let t=ue(e),n;switch(t.type){case"ip4":{n=`${t.host}:${t.port}`;break}case"ip6":{n=`[${t.host}]:${t.port}`;break}default:return}this.observedAddressFilter.has(n)||(this.observedAddressFilter.add(n),e=Vw(e,this.components.peerId),!this.ipMappings.has(e)&&(this.dnsMappings.has(e)||this.observed.add(e)))}confirmObservedAddr(e,t){e=Vw(e,this.components.peerId);let n=!0;(t?.type==="transport"||this.transportAddresses.has(e))&&!this.transportAddresses.confirm(e,t?.ttl??this.addressVerificationTTL)&&n&&(n=!1),(t?.type==="dns-mapping"||this.dnsMappings.has(e))&&!this.dnsMappings.confirm(e,t?.ttl??this.addressVerificationTTL)&&n&&(n=!1),(t?.type==="ip-mapping"||this.ipMappings.has(e))&&!this.ipMappings.confirm(e,t?.ttl??this.addressVerificationTTL)&&n&&(n=!1),(t?.type==="observed"||this.observed.has(e))&&(this.maybeUpgradeToIPMapping(e)?(this.ipMappings.confirm(e,t?.ttl??this.addressVerificationTTL),n=!1):!this.observed.confirm(e,t?.ttl??this.addressVerificationTTL)&&n&&(n=!1)),n||this._updatePeerStoreAddresses()}removeObservedAddr(e,t){e=Vw(e,this.components.peerId);let n=!1;this.observed.has(e)&&!this.observed.remove(e)&&n&&(n=!1),this.transportAddresses.has(e)&&!this.transportAddresses.unconfirm(e,t?.ttl??this.addressVerificationRetry)&&n&&(n=!1),this.dnsMappings.has(e)&&!this.dnsMappings.unconfirm(e,t?.ttl??this.addressVerificationRetry)&&n&&(n=!1),this.ipMappings.has(e)&&!this.ipMappings.unconfirm(e,t?.ttl??this.addressVerificationRetry)&&n&&(n=!1),n&&this._updatePeerStoreAddresses()}getAddresses(){let e=new Set,t=this.getAddressesWithMetadata().filter(n=>{if(!n.verified)return!1;let o=n.multiaddr.toString();return e.has(o)?!1:(e.add(o),!0)}).map(n=>n.multiaddr);return this.announceFilter(t.map(n=>{let o=fe(n);return o.getComponents().pop()?.value===this.components.peerId.toString()?o:o.encapsulate(`/p2p/${this.components.peerId.toString()}`)}))}getAddressesWithMetadata(){let e=this.getAnnounceAddrs();if(e.length>0)return this.components.transportManager.getListeners().forEach(o=>{o.updateAnnounceAddrs(e)}),e.map(o=>({multiaddr:o,verified:!0,type:"announce",expires:Date.now()+this.addressVerificationTTL,lastVerified:Date.now()}));let t=[];t=t.concat(this.components.transportManager.getAddrs().map(o=>this.transportAddresses.get(o,this.addressVerificationTTL)));let n=this.getAppendAnnounceAddrs();return n.length>0&&(this.components.transportManager.getListeners().forEach(o=>{o.updateAnnounceAddrs(n)}),t=t.concat(n.map(o=>({multiaddr:o,verified:!0,type:"announce",expires:Date.now()+this.addressVerificationTTL,lastVerified:Date.now()})))),t=t.concat(this.observed.getAll()),t=t.concat(this.ipMappings.getAll(t)),t=t.concat(this.dnsMappings.getAll(t)),t}addDNSMapping(e,t){this.dnsMappings.add(e,t)}removeDNSMapping(e){this.dnsMappings.remove(fe(`/dns/${e}`))&&this._updatePeerStoreAddresses()}addPublicAddressMapping(e,t,n,o=t,i="tcp"){this.ipMappings.add(e,t,n,o,i),this.observed.removePrefixed(`/ip${Mr(n)?4:6}/${n}/${i}/${o}`)}removePublicAddressMapping(e,t,n,o=t,i="tcp"){this.ipMappings.remove(fe(`/ip${Mr(n)?4:6}/${n}/${i}/${o}`))&&this._updatePeerStoreAddresses()}maybeUpgradeToIPMapping(e){if(this.ipMappings.has(e)||!dt(e))return!1;let t=ue(e);if(t.type!=="ip4"||ws(t.host)===!0)return!1;let n=this.components.transportManager.getListeners(),o=[i=>_i.exactMatch(i)||cu.exactMatch(i),i=>au.exactMatch(i),i=>PS.exactMatch(i)];for(let i of o){if(!i(e))continue;let s=n.filter(u=>u.getAddrs().filter(l=>ue(l).type==="ip4"&&i(l)).length>0);if(s.length!==1)continue;let a=s[0].getAddrs().filter(u=>!uc(u)).pop();if(a==null)continue;let c=ue(a);return c.port==null?!1:(this.observed.remove(e),this.ipMappings.add(c.host,c.port,t.host,t.port,t.protocol),!0)}return!1}};var v_;(function(r){r.NOT_STARTED_YET="The libp2p node is not started yet",r.NOT_FOUND="Not found"})(v_||(v_={}));var Rh=class extends Error{constructor(e="Missing service"){super(e),this.name="MissingServiceError"}},Uh=class extends Error{constructor(e="Unmet service dependencies"){super(e),this.name="UnmetServiceDependenciesError"}},ha=class extends Error{constructor(e="No content routers available"){super(e),this.name="NoContentRoutersError"}},ku=class extends Error{constructor(e="No peer routers available"){super(e),this.name="NoPeerRoutersError"}},Oh=class extends Error{constructor(e="Should not try to find self"){super(e),this.name="QueriedForSelfError"}},Mh=class extends Error{constructor(e="Unhandled protocol error"){super(e),this.name="UnhandledProtocolError"}},Fh=class extends Error{constructor(e="Duplicate protocol handler error"){super(e),this.name="DuplicateProtocolHandlerError"}},_u=class extends Error{constructor(e="Dial denied error"){super(e),this.name="DialDeniedError"}},$h=class extends Error{constructor(e="No transport was configured to listen on this address"){super(e),this.name="UnsupportedListenAddressError"}},Vh=class extends Error{constructor(e="Configured listen addresses could not be listened on"){super(e),this.name="UnsupportedListenAddressesError"}},Kh=class extends Error{constructor(e="No valid addresses"){super(e),this.name="NoValidAddressesError"}},qh=class extends Error{constructor(e="Connection intercepted"){super(e),this.name="ConnectionInterceptedError"}},Hh=class extends Error{constructor(e="Connection denied"){super(e),this.name="ConnectionDeniedError"}},Po=class extends Error{constructor(e="Stream is not multiplexed"){super(e),this.name="MuxerUnavailableError"}},Li=class extends Error{constructor(e="Encryption failed"){super(e),this.name="EncryptionFailedError"}},zh=class extends Error{constructor(e="Transport unavailable"){super(e),this.name="TransportUnavailableError"}},jh=class extends Error{constructor(e="Max recursive depth reached"){super(e),this.name="RecursionLimitError"}};var Kw=class{components={};_started=!1;constructor(e={}){this.components={};for(let[t,n]of Object.entries(e))this.components[t]=n;this.components.logger==null&&(this.components.logger=Cs())}isStarted(){return this._started}async _invokeStartableMethod(e){await Promise.all(Object.values(this.components).filter(t=>el(t)).map(async t=>{await t[e]?.()}))}async beforeStart(){await this._invokeStartableMethod("beforeStart")}async start(){await this._invokeStartableMethod("start"),this._started=!0}async afterStart(){await this._invokeStartableMethod("afterStart")}async beforeStop(){await this._invokeStartableMethod("beforeStop")}async stop(){await this._invokeStartableMethod("stop"),this._started=!1}async afterStop(){await this._invokeStartableMethod("afterStop")}},GP=["metrics","connectionProtector","dns"],WP=["components","isStarted","beforeStart","start","afterStart","beforeStop","stop","afterStop","then","_invokeStartableMethod"];function A_(r={}){let e=new Kw(r);return new Proxy(e,{get(n,o,i){if(typeof o=="string"&&!WP.includes(o)){let s=e.components[o];if(s==null&&!GP.includes(o))throw new Rh(`${o} not set`);return s}return Reflect.get(n,o,i)},set(n,o,i){return typeof o=="string"?e.components[o]=i:Reflect.set(n,o,i),!0}})}function S_(r){let e={};for(let t of Object.values(r.components))for(let n of YP(t))e[n]=!0;for(let t of Object.values(r.components))for(let n of XP(t))if(e[n]!==!0)throw new Uh(`Service "${ZP(t)}" required capability "${n}" but it was not provided by any component, you may need to add additional configuration when creating your node.`)}function YP(r){return Array.isArray(r?.[Fo])?r[Fo]:[]}function XP(r){return Array.isArray(r?.[cm])?r[cm]:[]}function ZP(r){return r?.[Symbol.toStringTag]??r?.toString()??"unknown"}function k_(r={}){return r.denyDialMultiaddr==null&&(r.denyDialMultiaddr=e=>_i.matches(e)?!0:Fr(e)),r}var JP=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 QP(r,e,t){let n,o=new Promise((i,s)=>{if(t={rejectionEvents:["error"],multiArgs:!1,rejectionMultiArgs:!1,resolveImmediately:!1,...t},!(t.count>=0&&(t.count===Number.POSITIVE_INFINITY||Number.isInteger(t.count))))throw new TypeError("The `count` option should be at least 0 or more");t.signal?.throwIfAborted();let a=[e].flat(),c=[],{addListener:u,removeListener:l}=JP(r),f=async(...h)=>{let m=t.multiArgs?h:h[0];if(t.filter)try{if(!await t.filter(m))return}catch(y){n(),s(y);return}c.push(m),t.count===c.length&&(n(),i(c))},d=(...h)=>{n(),s(t.rejectionMultiArgs?h:h[0])};n=()=>{for(let h of a)l(h,f);for(let h of t.rejectionEvents)a.includes(h)||l(h,d)};for(let h of a)u(h,f);for(let h of t.rejectionEvents)a.includes(h)||u(h,d);t.signal&&t.signal.addEventListener("abort",()=>{d(t.signal.reason)},{once:!0}),t.resolveImmediately&&i(c)});if(o.cancel=n,typeof t.timeout=="number"){let i=ui(o,{milliseconds:t.timeout});return i.cancel=()=>{n(),i.clear()},i}return o}function Iu(r,e,t){typeof t=="function"&&(t={filter:t}),t={...t,count:1,resolveImmediately:!1};let n=QP(r,e,t),o=n.then(i=>i[0]);return o.cancel=n.cancel,o}function Gh(r){if(nr(r))return{peerId:r,multiaddrs:[]};let e=Array.isArray(r)?r:[r],t;if(e.length>0){let n=e[0].getComponents().findLast(o=>o.code===421)?.value;t=n==null?void 0:lr(n),e.forEach(o=>{if(!ho(o))throw new Gn("Invalid multiaddr");let i=o.getComponents().findLast(s=>s.code===421)?.value;if(i==null){if(t!=null)throw new T("Multiaddrs must all have the same peer id or have no peer id")}else{let s=lr(i);if(t?.equals(s)!==!0)throw new T("Multiaddrs must all have the same peer id or have no peer id")}})}return e=e.filter(n=>!TS.exactMatch(n)),{peerId:t,multiaddrs:e}}var eL=["/ipfs/id/1.0.0","/ipfs/id/push/1.0.0","/libp2p/autonat/1.0.0","/libp2p/dcutr"];async function __(r,e){let t=r?.streams?.map(o=>o.protocol)??[],n=e?.closableProtocols??eL;if(!(t.filter(o=>o!=null&&!n.includes(o)).length>0))try{await r?.close(e)}catch(o){r?.abort(o)}}function Tu(r){let e=ue(r),t=e.cidr;if(e.type!=="ip4"&&e.type!=="ip6")throw new T(`Multiaddr ${r} was not an IPv4 or IPv6 address`);if(t==null)switch(e.type){case"ip4":{t=32;break}case"ip6":{t=128;break}default:throw new T(`Multiaddr ${r} was not an IPv4 or IPv6 address`)}return new ps(e.host,t)}function qw(r){return!Ii.exactMatch(r)}function Wh(r,e,t){if(r==null||e==null)return;let n=e.filter(i=>i.status==="open").sort((i,s)=>i.direct?-1:s.direct?1:0).find(i=>i.limits==null);if(n==null||n.direct||t==null)return n;if(!t.some(i=>qw(i)))return n}var Yh=class{connectionManager;peerStore;allow;events;log;constructor(e,t={}){this.allow=(t.allow??[]).map(n=>Tu(n)),this.connectionManager=e.connectionManager,this.peerStore=e.peerStore,this.events=e.events,this.log=e.logger.forComponent("libp2p:connection-manager:connection-pruner"),this.maybePruneConnections=this.maybePruneConnections.bind(this)}start(){this.events.addEventListener("connection:open",this.maybePruneConnections)}stop(){this.events.removeEventListener("connection:open",this.maybePruneConnections)}maybePruneConnections(){this._maybePruneConnections().catch(e=>{this.log.error("error while pruning connections - %e",e)})}async _maybePruneConnections(){let e=this.connectionManager.getConnections(),t=e.length,n=this.connectionManager.getMaxConnections();if(this.log("checking max connections limit %d/%d",t,n),t<=n)return;let o=new fr;for(let c of e){let u=c.remotePeer;if(!o.has(u)){o.set(u,0);try{let l=await this.peerStore.get(u);o.set(u,[...l.tags.values()].reduce((f,d)=>f+d.value,0))}catch(l){l.name!=="NotFoundError"&&this.log.error("error loading peer tags - %e",l)}}}let i=this.sortConnections(e,o),s=Math.max(t-n,0),a=[];for(let c of i)if(this.log("too many connections open - closing a connection to %p",c.remotePeer),this.allow.some(l=>{if(dt(c.remoteAddr)){let f=ue(c.remoteAddr);return l.contains(f.host)}return!0})||a.push(c),a.length===s)break;await Promise.all(a.map(async c=>{await __(c,{signal:AbortSignal.timeout(1e3)})})),this.events.safeDispatchEvent("connection:prune",{detail:a})}sortConnections(e,t){return e.sort((n,o)=>{let i=n.timeline.open,s=o.timeline.open;return i<s?1:i>s?-1:0}).sort((n,o)=>n.direction==="outbound"&&o.direction==="inbound"?1:n.direction==="inbound"&&o.direction==="outbound"?-1:0).sort((n,o)=>n.streams.length>o.streams.length?1:n.streams.length<o.streams.length?-1:0).sort((n,o)=>{let i=t.get(n.remotePeer)??0,s=t.get(o.remotePeer)??0;return i>s?1:i<s?-1:0})}};var I_="last-dial-failure",T_="last-dial-success";var C_=100,Xh=50;function tL(r,e){let t=au.exactMatch(r.multiaddr),n=au.exactMatch(e.multiaddr);if(t&&!n)return-1;if(!t&&n)return 1;let o=cu.exactMatch(r.multiaddr),i=cu.exactMatch(e.multiaddr);if(o&&!i)return-1;if(!o&&i)return 1;let s=_i.exactMatch(r.multiaddr),a=_i.exactMatch(e.multiaddr);if(s&&!a)return-1;if(!s&&a)return 1;let c=yw.exactMatch(r.multiaddr),u=yw.exactMatch(e.multiaddr);if(c&&!u)return-1;if(!c&&u)return 1;let l=mw.exactMatch(r.multiaddr),f=mw.exactMatch(e.multiaddr);if(l&&!f)return-1;if(!l&&f)return 1;let d=gw.exactMatch(r.multiaddr),h=gw.exactMatch(e.multiaddr);return d&&!h?-1:!d&&h?1:0}function rL(r,e){let t=uc(r.multiaddr),n=uc(e.multiaddr);return t&&!n?1:!t&&n?-1:0}function nL(r,e){let t=Fr(r.multiaddr),n=Fr(e.multiaddr);return t&&!n?1:!t&&n?-1:0}function oL(r,e){return r.isCertified&&!e.isCertified?-1:!r.isCertified&&e.isCertified?1:0}function iL(r,e){let t=Ii.exactMatch(r.multiaddr),n=Ii.exactMatch(e.multiaddr);return t&&!n?1:!t&&n?-1:0}function B_(r){return r.sort(tL).sort(oL).sort(iL).sort(nL).sort(rL)}var Hw=class{dns;canResolve(e){return e.getComponents().some(({name:t})=>t==="dnsaddr")}async resolve(e,t){let n=e.getComponents().find(c=>c.name==="dnsaddr")?.value;if(n==null)return[e];let i=await this.getDNS(t).query(`_dnsaddr.${n}`,{signal:t?.signal,types:[$t.TXT]}),s=e.getComponents().find(c=>c.name==="p2p")?.value,a=[];for(let c of i.Answer){let u=c.data.replace(/["']/g,"").trim().split("=")[1];u!=null&&(s!=null&&!u.includes(s)||a.push(fe(u)))}return a}getDNS(e){return e.dns!=null?e.dns:(this.dns==null&&(this.dns=vf()),this.dns)}},Cu=new Hw;async function zw(r,e,t){let n=t.depth??0;if(n>(t.maxRecursiveDepth??32))throw new jh("Max recursive depth reached");let o=!1,i=[];for(let s of Object.values(e))if(s.canResolve(r)){o=!0;let a=await s.resolve(r,t);for(let c of a)i.push(...await zw(c,e,{...t,depth:n+1}))}return o===!1&&i.push(r),i}var Bu={maxParallelDials:Xh,maxDialQueueLength:500,maxPeerAddrsToDial:25,dialTimeout:1e4,resolvers:{dnsaddr:Cu}},Zh=class{queue;components;addressSorter;maxPeerAddrsToDial;maxDialQueueLength;dialTimeout;shutDownController;connections;log;resolvers;constructor(e,t={}){this.addressSorter=t.addressSorter,this.maxPeerAddrsToDial=t.maxPeerAddrsToDial??Bu.maxPeerAddrsToDial,this.maxDialQueueLength=t.maxDialQueueLength??Bu.maxDialQueueLength,this.dialTimeout=t.dialTimeout??Bu.dialTimeout,this.connections=t.connections??new fr,this.log=e.logger.forComponent("libp2p:connection-manager:dial-queue"),this.components=e,this.resolvers=t.resolvers??Bu.resolvers,this.shutDownController=new AbortController,this.shutDownController.signal,this.queue=new ff({concurrency:t.maxParallelDials??Bu.maxParallelDials,metricName:"libp2p_dial_queue",metrics:e.metrics}),this.queue.addEventListener("failure",n=>{n.detail?.error.name!==Rt.name&&this.log.error("error in dial queue - %e",n.detail.error)})}start(){this.shutDownController=new AbortController,this.shutDownController.signal}stop(){this.shutDownController.abort(),this.queue.abort()}async dial(e,t={}){let{peerId:n,multiaddrs:o}=Gh(e);if(n!=null&&t.force!==!0){let s=Wh(n,this.connections.get(n),o);if(s!=null)return this.log("already connected to %a",s.remoteAddr),t.onProgress?.(new $("dial-queue:already-connected",s)),s}let i=this.queue.queue.find(s=>{if(n?.equals(s.options.peerId)===!0)return!0;let a=s.options.multiaddrs;if(a==null)return!1;for(let c of o)if(a.has(c.toString()))return!0;return!1});if(i!=null){this.log("joining existing dial target for %p",n);for(let s of o)i.options.multiaddrs.add(s.toString());return t.onProgress?.(new $("dial-queue:already-in-dial-queue")),i.join(t)}if(this.queue.size>=this.maxDialQueueLength)throw new Vi("Dial queue is full");return this.log("creating dial target for %p",n,o.map(s=>s.toString())),t.onProgress?.(new $("dial-queue:add-to-dial-queue")),this.queue.add(async s=>{s.onProgress?.(new $("dial-queue:start-dial"));let a=Ie([this.shutDownController.signal,s.signal]);try{return await this.dialPeer(s,a)}finally{a.clear()}},{peerId:n,priority:t.priority??Yw,multiaddrs:new Set(o.map(s=>s.toString())),signal:t.signal??AbortSignal.timeout(this.dialTimeout),onProgress:t.onProgress})}async dialPeer(e,t){let n=e.peerId,o=e.multiaddrs,i=new Set,s=e.multiaddrs.size===0,a=0,c=0,u=[];for(this.log("starting dial to %p",n);s||o.size>0;){c++,s=!1;let l=[],f=new Set(e.multiaddrs);o.clear(),this.log("calculating addrs to dial %p from %s",n,[...f]);let d=await this.calculateMultiaddrs(n,f,{...e,signal:t});for(let h of d){if(i.has(h.multiaddr.toString())){this.log.trace("skipping previously failed multiaddr %a while dialing %p",h.multiaddr,n);continue}l.push(h)}this.log("%s dial to %p with %s",c===1?"starting":"continuing",n,l.map(h=>h.multiaddr.toString())),e?.onProgress?.(new $("dial-queue:calculated-addresses",l));for(let h of l){if(a===this.maxPeerAddrsToDial)throw this.log("dialed maxPeerAddrsToDial (%d) addresses for %p, not trying any others",a,e.peerId),new Vi("Peer had more than maxPeerAddrsToDial");a++;try{let m=await this.components.transportManager.dial(h.multiaddr,{...e,signal:t});this.log("dial to %a succeeded",h.multiaddr);try{await this.components.peerStore.merge(m.remotePeer,{multiaddrs:[m.remoteAddr],metadata:{[T_]:L(Date.now().toString())}})}catch(y){this.log.error("could not update last dial failure key for %p - %e",n,y)}return m}catch(m){if(this.log.error("dial failed to %a - %e",h.multiaddr,m),i.add(h.multiaddr.toString()),n!=null)try{await this.components.peerStore.merge(n,{metadata:{[I_]:L(Date.now().toString())}})}catch(y){this.log.error("could not update last dial failure key for %p - %e",n,y)}if(t.aborted)throw new Yu(m.message);u.push(m)}}}throw u.length===1?u[0]:new AggregateError(u,"All multiaddr dials failed")}async calculateMultiaddrs(e,t=new Set,n={}){let o=[...t].map(f=>({multiaddr:fe(f),isCertified:!1}));if(e!=null){if(this.components.peerId.equals(e))throw new Vi("Tried to dial self");if(await this.components.connectionGater.denyDialPeer?.(e)===!0)throw new _u("The dial request is blocked by gater.allowDialPeer");if(o.length===0){this.log("loading multiaddrs for %p",e);try{let f=await this.components.peerStore.get(e);o.push(...f.addresses),this.log("loaded multiaddrs for %p",e,o.map(({multiaddr:d})=>d.toString()))}catch(f){if(f.name!=="NotFoundError")throw f}}if(o.length===0){this.log("looking up multiaddrs for %p in the peer routing",e);try{let f=await this.components.peerRouting.findPeer(e,n);this.log("found multiaddrs for %p in the peer routing",e,o.map(({multiaddr:d})=>d.toString())),o.push(...f.multiaddrs.map(d=>({multiaddr:d,isCertified:!1})))}catch(f){f.name==="NoPeerRoutersError"?this.log("no peer routers configured",e):this.log.error("looking up multiaddrs for %p in the peer routing failed - %e",e,f)}}}let i=(await Promise.all(o.map(async f=>{let d=await zw(f.multiaddr,this.resolvers,{dns:this.components.dns,log:this.log,...n});return d.length===1&&d[0].equals(f.multiaddr)?f:d.map(h=>({multiaddr:h,isCertified:!1}))}))).flat();if(e!=null){let f=`/p2p/${e.toString()}`;i=i.map(d=>d.multiaddr.getComponents().pop()?.name!=="p2p"?{multiaddr:d.multiaddr.encapsulate(f),isCertified:d.isCertified}:d)}let s=i.filter(f=>{if(this.components.transportManager.dialTransportForMultiaddr(f.multiaddr)==null)return!1;let d=f.multiaddr.getComponents().findLast(h=>h.code===421)?.value;return e!=null&&d!=null?e.equals(d):!0}),a=new Map;for(let f of s){let d=f.multiaddr.toString(),h=a.get(d);if(h!=null){h.isCertified=h.isCertified||f.isCertified||!1;continue}a.set(d,f)}let c=[...a.values()];if(c.length===0)throw new Kh("The dial request has no valid addresses");let u=[];for(let f of c)this.components.connectionGater.denyDialMultiaddr!=null&&await this.components.connectionGater.denyDialMultiaddr(f.multiaddr)||u.push(f);let l=this.addressSorter==null?B_(u):u.sort(this.addressSorter);if(l.length===0)throw new _u("The connection gater denied all addresses in the dial request");return this.log.trace("addresses for %p before filtering",e??"unknown peer",i.map(({multiaddr:f})=>f.toString())),this.log.trace("addresses for %p after filtering",e??"unknown peer",l.map(({multiaddr:f})=>f.toString())),l}async isDialable(e,t={}){Array.isArray(e)||(e=[e]);try{let n=await this.calculateMultiaddrs(void 0,new Set(e.map(o=>o.toString())),t);return t.runOnLimitedConnection===!1?n.find(o=>!Ii.matches(o.multiaddr))!=null:!0}catch{}return!1}};var sL=Object.prototype.toString,aL=r=>sL.call(r)==="[object Error]",cL=new Set(["network error","NetworkError when attempting to fetch resource.","The Internet connection appears to be offline.","Network request failed","fetch failed","terminated"," A network error occurred.","Network connection lost"]);function Xw(r){if(!(r&&aL(r)&&r.name==="TypeError"&&typeof r.message=="string"))return!1;let{message:t,stack:n}=r;return t==="Load failed"?n===void 0||"__sentry_captured__"in r:t.startsWith("error sending request for url")||t==="Failed to fetch"||t.startsWith("Failed to fetch (")&&t.endsWith(")")?!0:cL.has(t)}function uL(r){if(typeof r=="number"){if(r<0)throw new TypeError("Expected `retries` to be a non-negative number.");if(Number.isNaN(r))throw new TypeError("Expected `retries` to be a valid number or Infinity, got NaN.")}else if(r!==void 0)throw new TypeError("Expected `retries` to be a number or Infinity.")}function Jh(r,e,{min:t=0,allowInfinity:n=!1}={}){if(e!==void 0){if(typeof e!="number"||Number.isNaN(e))throw new TypeError(`Expected \`${r}\` to be a number${n?" or Infinity":""}.`);if(!n&&!Number.isFinite(e))throw new TypeError(`Expected \`${r}\` to be a finite number.`);if(e<t)throw new TypeError(`Expected \`${r}\` to be \u2265 ${t}.`)}}var Zw=class extends Error{constructor(e){super(),e instanceof Error?(this.originalError=e,{message:e}=e):(this.originalError=new Error(e),this.originalError.stack=this.stack),this.name="AbortError",this.message=e}};function lL(r,e){let t=Math.max(1,r+1),n=e.randomize?Math.random()+1:1,o=Math.round(n*e.minTimeout*e.factor**(t-1));return o=Math.min(o,e.maxTimeout),o}function N_(r,e){return Number.isFinite(e)?e-(performance.now()-r):e}async function fL({error:r,attemptNumber:e,retriesConsumed:t,startTime:n,options:o}){let i=r instanceof Error?r:new TypeError(`Non-error was thrown: "${r}". You should only throw errors.`);if(i instanceof Zw)throw i.originalError;let s=Number.isFinite(o.retries)?Math.max(0,o.retries-t):o.retries,a=o.maxRetryTime??Number.POSITIVE_INFINITY,c=Object.freeze({error:i,attemptNumber:e,retriesLeft:s,retriesConsumed:t});if(await o.onFailedAttempt(c),N_(n,a)<=0)throw i;let u=await o.shouldConsumeRetry(c),l=N_(n,a);if(l<=0||s<=0)throw i;if(i instanceof TypeError&&!Xw(i)){if(u)throw i;return o.signal?.throwIfAborted(),!1}if(!await o.shouldRetry(c))throw i;if(!u)return o.signal?.throwIfAborted(),!1;let f=lL(t,o),d=Math.min(f,l);return o.signal?.throwIfAborted(),d>0&&await new Promise((h,m)=>{let y=()=>{clearTimeout(g),o.signal?.removeEventListener("abort",y),m(o.signal.reason)},g=setTimeout(()=>{o.signal?.removeEventListener("abort",y),h()},d);o.unref&&g.unref?.(),o.signal?.addEventListener("abort",y,{once:!0})}),o.signal?.throwIfAborted(),!0}async function Jw(r,e={}){if(e={...e},uL(e.retries),Object.hasOwn(e,"forever"))throw new Error("The `forever` option is no longer supported. For many use-cases, you can set `retries: Infinity` instead.");e.retries??=10,e.factor??=2,e.minTimeout??=1e3,e.maxTimeout??=Number.POSITIVE_INFINITY,e.maxRetryTime??=Number.POSITIVE_INFINITY,e.randomize??=!1,e.onFailedAttempt??=()=>{},e.shouldRetry??=()=>!0,e.shouldConsumeRetry??=()=>!0,Jh("factor",e.factor,{min:0,allowInfinity:!1}),Jh("minTimeout",e.minTimeout,{min:0,allowInfinity:!1}),Jh("maxTimeout",e.maxTimeout,{min:0,allowInfinity:!0}),Jh("maxRetryTime",e.maxRetryTime,{min:0,allowInfinity:!0}),e.factor>0||(e.factor=1),e.signal?.throwIfAborted();let t=0,n=0,o=performance.now();for(;!Number.isFinite(e.retries)||n<=e.retries;){t++;try{e.signal?.throwIfAborted();let i=await r(t);return e.signal?.throwIfAborted(),i}catch(i){await fL({error:i,attemptNumber:t,retriesConsumed:n,startTime:o,options:e})&&n++}}throw new Error("Retry attempts exhausted without throwing an error.")}var Qh=class{log;queue;started;peerStore;retries;retryInterval;backoffFactor;connectionManager;events;constructor(e,t={}){this.log=e.logger.forComponent("libp2p:reconnect-queue"),this.peerStore=e.peerStore,this.connectionManager=e.connectionManager,this.queue=new Bs({concurrency:t.maxParallelReconnects??5,metricName:"libp2p_reconnect_queue",metrics:e.metrics}),this.started=!1,this.retries=t.retries??5,this.backoffFactor=t.backoffFactor,this.retryInterval=t.retryInterval,this.events=e.events,e.events.addEventListener("peer:disconnect",n=>{this.maybeReconnect(n.detail).catch(o=>{this.log.error("failed to maybe reconnect to %p - %e",n.detail,o)})})}async maybeReconnect(e){if(!this.started)return;let t=await this.peerStore.get(e);P_(t)&&(this.queue.has(e)||this.queue.add(async n=>{await Jw(async o=>{if(this.started)try{await this.connectionManager.openConnection(e,{signal:n?.signal})}catch(i){throw this.log("reconnecting to %p attempt %d of %d failed - %e",e,o,this.retries,i),i}},{signal:n?.signal,retries:this.retries,factor:this.backoffFactor,minTimeout:this.retryInterval})},{peerId:e}).catch(async n=>{this.log.error("failed to reconnect to %p - %e",e,n);let o={};[...t.tags.keys()].forEach(i=>{i.startsWith(am)&&(o[i]=void 0)}),await this.peerStore.merge(e,{tags:o}),this.events.safeDispatchEvent("peer:reconnect-failure",{detail:e})}).catch(async n=>{this.log.error("failed to remove keep-alive tag from %p - %e",e,n)}))}start(){this.started=!0}async afterStart(){Promise.resolve().then(async()=>{let e=await this.peerStore.all({filters:[t=>P_(t)]});await Promise.all(e.map(async t=>{await this.connectionManager.openConnection(t.id).catch(n=>{this.log.error("could not open connection to keepalive peer - %e",n)})}))}).catch(e=>{this.log.error("error reconnect to peers after start - %e",e)})}stop(){this.started=!1,this.queue.abort()}};function P_(r){for(let e of r.tags.keys())if(e.startsWith(am))return!0;return!1}var Yw=50,Qw={maxConnections:C_,inboundConnectionThreshold:5,maxIncomingPendingConnections:10},ep=class{started;connections;allow;deny;maxIncomingPendingConnections;incomingPendingConnections;outboundPendingConnections;maxConnections;dialQueue;reconnectQueue;connectionPruner;inboundConnectionRateLimiter;peerStore;metrics;events;log;peerId;constructor(e,t={}){if(this.maxConnections=t.maxConnections??Qw.maxConnections,this.maxConnections<1)throw new T("Connection Manager maxConnections must be greater than 0");this.connections=new fr,this.started=!1,this.peerId=e.peerId,this.peerStore=e.peerStore,this.metrics=e.metrics,this.events=e.events,this.log=e.logger.forComponent("libp2p:connection-manager"),this.onConnect=this.onConnect.bind(this),this.onDisconnect=this.onDisconnect.bind(this),this.allow=(t.allow??[]).map(n=>Tu(fe(n))),this.deny=(t.deny??[]).map(n=>Tu(fe(n))),this.incomingPendingConnections=0,this.maxIncomingPendingConnections=t.maxIncomingPendingConnections??Qw.maxIncomingPendingConnections,this.outboundPendingConnections=0,this.inboundConnectionRateLimiter=new df({points:t.inboundConnectionThreshold??Qw.inboundConnectionThreshold,duration:1}),this.connectionPruner=new Yh({connectionManager:this,peerStore:e.peerStore,events:e.events,logger:e.logger},{allow:t.allow?.map(n=>fe(n))}),this.dialQueue=new Zh(e,{addressSorter:t.addressSorter,maxParallelDials:t.maxParallelDials??Xh,maxDialQueueLength:t.maxDialQueueLength??500,maxPeerAddrsToDial:t.maxPeerAddrsToDial??25,dialTimeout:t.dialTimeout??1e4,resolvers:t.resolvers??{dnsaddr:Cu},connections:this.connections}),this.reconnectQueue=new Qh({events:e.events,peerStore:e.peerStore,logger:e.logger,connectionManager:this},{retries:t.reconnectRetries,retryInterval:t.reconnectRetryInterval,backoffFactor:t.reconnectBackoffFactor,maxParallelReconnects:t.maxParallelReconnects})}[Symbol.toStringTag]="@libp2p/connection-manager";async start(){this.metrics?.registerMetricGroup("libp2p_connection_manager_connections",{calculate:()=>{let e={inbound:0,"inbound pending":this.incomingPendingConnections,outbound:0,"outbound pending":this.outboundPendingConnections};for(let t of this.connections.values())for(let n of t)e[n.direction]++;return e}}),this.metrics?.registerMetricGroup("libp2p_protocol_streams_total",{label:"protocol",calculate:()=>{let e={};for(let t of this.connections.values())for(let n of t)for(let o of n.streams){let i=`${o.direction} ${o.protocol??"unnegotiated"}`;e[i]=(e[i]??0)+1}return e}}),this.metrics?.registerMetricGroup("libp2p_connection_manager_protocol_streams_per_connection_90th_percentile",{label:"protocol",calculate:()=>{let e={};for(let n of this.connections.values())for(let o of n){let i={};for(let s of o.streams){let a=`${s.direction} ${s.protocol??"unnegotiated"}`;i[a]=(i[a]??0)+1}for(let[s,a]of Object.entries(i))e[s]=e[s]??[],e[s].push(a)}let t={};for(let[n,o]of Object.entries(e)){o=o.sort((s,a)=>s-a);let i=Math.floor(o.length*.9);t[n]=o[i]}return t}}),this.events.addEventListener("connection:open",this.onConnect),this.events.addEventListener("connection:close",this.onDisconnect),await rn(this.dialQueue,this.reconnectQueue,this.connectionPruner),this.started=!0,this.log("started")}async stop(){this.events.removeEventListener("connection:open",this.onConnect),this.events.removeEventListener("connection:close",this.onDisconnect),await nn(this.reconnectQueue,this.dialQueue,this.connectionPruner);let e=[];for(let t of this.connections.values())for(let n of t)e.push(Promise.all([Iu(n,"close",{signal:AbortSignal.timeout(500)}),n.close({signal:AbortSignal.timeout(500)})]).catch(o=>{n.abort(o)}));this.log("closing %d connections",e.length),await Promise.all(e),this.connections.clear(),this.log("stopped")}getMaxConnections(){return this.maxConnections}setMaxConnections(e){if(e<1)throw new T("Connection Manager maxConnections must be greater than 0");let t=!1;e<this.maxConnections&&(t=!0),this.maxConnections=e,t&&this.connectionPruner.maybePruneConnections()}onConnect(e){this._onConnect(e).catch(t=>{this.log.error("could not connect - %e",t)})}async _onConnect(e){let{detail:t}=e;if(!this.started){await t.close();return}if(t.status!=="open")return;let n=t.remotePeer,o=!this.connections.has(n),i=this.connections.get(n)??[];i.push(t),this.connections.set(n,i),n.publicKey!=null&&n.type==="RSA"&&await this.peerStore.patch(n,{publicKey:n.publicKey}),o&&this.events.safeDispatchEvent("peer:connect",{detail:t.remotePeer})}onDisconnect(e){let{detail:t}=e,n=t.remotePeer,i=(this.connections.get(n)??[]).filter(s=>s.id!==t.id);this.connections.set(n,i),i.length===0&&(this.log.trace("peer %p disconnected, removing connection map entry",n),this.connections.delete(n),this.events.safeDispatchEvent("peer:disconnect",{detail:n}))}getConnections(e){if(e!=null)return this.connections.get(e)??[];let t=[];for(let n of this.connections.values())t=t.concat(n);return t}getConnectionsMap(){return this.connections}async openConnection(e,t={}){if(!this.started)throw new An("Not started");this.outboundPendingConnections++;try{t.signal?.throwIfAborted(),t?.onProgress?.(new $("connection:open",e));let{peerId:n,multiaddrs:o}=Gh(e);if(this.peerId.equals(n))throw new $i("Can not dial self");if(n!=null&&t.force!==!0){this.log("dial %p",n);let c=Wh(n,this.getConnections(n),o);if(c!=null)return this.log("had an existing connection to %p as %a",n,c.remoteAddr),t.onProgress?.(new $("dial-queue:already-connected")),t.onProgress?.(new $("connection:opened",c)),c}let i=await this.dialQueue.dial(e,{...t,priority:t.priority??Yw});if(i.status!=="open")throw new Oo("Remote closed connection during opening");let s=this.connections.get(i.remotePeer);s==null&&(s=[],this.connections.set(i.remotePeer,s));let a=!1;for(let c of s)if(c.id===i.id&&(a=!0),t.force!==!0&&c.id!==i.id&&c.remoteAddr.equals(i.remoteAddr))return i.abort(new Gn("Duplicate multiaddr connection")),c;return a||s.push(i),t.onProgress?.(new $("connection:opened",i)),i}finally{this.outboundPendingConnections--}}async openStream(e,t,n={}){return(await this.openConnection(e,n)).newStream(t,n)}async closeConnections(e,t={}){let n=this.connections.get(e)??[];await Promise.all(n.map(async o=>{try{await Promise.all([Iu(o,"close",t),o.close(t)])}catch(i){o.abort(i)}}))}acceptIncomingConnection(e){if(this.deny.some(o=>{if(dt(e.remoteAddr)){let i=ue(e.remoteAddr);return o.contains(i.host)}return!1}))return this.log("connection from %a refused - connection remote address was in deny list",e.remoteAddr),!1;if(this.allow.some(o=>{if(dt(e.remoteAddr)){let i=ue(e.remoteAddr);return o.contains(i.host)}return!0}))return this.incomingPendingConnections++,!0;if(this.incomingPendingConnections===this.maxIncomingPendingConnections)return this.log("connection from %a refused - incomingPendingConnections exceeded by host",e.remoteAddr),!1;if(dt(e.remoteAddr)){let o=ue(e.remoteAddr);try{this.inboundConnectionRateLimiter.consume(o.host,1)}catch{return this.log("connection from %a refused - inboundConnectionThreshold exceeded by host %s",e.remoteAddr,o.host),!1}}return this.getConnections().length<this.maxConnections?(this.incomingPendingConnections++,!0):(this.log("connection from %a refused - maxConnections exceeded",e.remoteAddr),!1)}afterUpgradeInbound(){this.incomingPendingConnections--}getDialQueue(){let e={queued:"queued",running:"active",errored:"error",complete:"success"};return this.dialQueue.queue.queue.map(t=>({id:t.id,status:e[t.status],peerId:t.options.peerId,multiaddrs:[...t.options.multiaddrs].map(n=>fe(n))}))}async isDialable(e,t={}){return this.dialQueue.isDialable(e,t)}};var pL=1e4,mL="1.0.0",gL="ping",yL="ipfs",L_=32,wL=!0,tp=class{protocol;components;log;heartbeatInterval;pingIntervalMs;abortController;timeout;abortConnectionOnPingFailure;constructor(e,t={}){this.components=e,this.protocol=`/${t.protocolPrefix??yL}/${gL}/${mL}`,this.log=e.logger.forComponent("libp2p:connection-monitor"),this.pingIntervalMs=t.pingInterval??pL,this.abortConnectionOnPingFailure=t.abortConnectionOnPingFailure??wL,this.timeout=new zl({...t.pingTimeout??{},metrics:e.metrics,metricName:"libp2p_connection_monitor_ping_time_milliseconds"})}[Symbol.toStringTag]="@libp2p/connection-monitor";[Fo]=["@libp2p/connection-monitor"];start(){this.abortController=new AbortController,this.abortController.signal,this.heartbeatInterval=setInterval(()=>{this.components.connectionManager.getConnections().forEach(e=>{Promise.resolve().then(async()=>{let t=Date.now(),n=this.timeout.getTimeoutSignal({signal:this.abortController?.signal});try{let o=await e.newStream(this.protocol,{signal:n,runOnLimitedConnection:!0}),i=By(o);t=Date.now(),await Promise.all([i.write(Dr(L_),{signal:n}),i.read({bytes:L_,signal:n})]),e.rtt=Date.now()-t,await o.close({signal:n})}catch(o){if(o.name!=="UnsupportedProtocolError")throw o;e.rtt=(Date.now()-t)/2}finally{this.timeout.cleanUp(n)}}).catch(t=>{this.log.error("error during heartbeat - %e",t),this.abortConnectionOnPingFailure?(this.log.error("aborting connection due to ping failure"),e.abort(t)):this.log("connection ping failed, but not aborting due to abortConnectionOnPingFailure flag")})})},this.pingIntervalMs)}stop(){this.abortController?.abort(),this.heartbeatInterval!=null&&clearInterval(this.heartbeatInterval)}};var rp=class{routers;started;components;constructor(e,t){this.routers=t.routers??[],this.started=!1,this.components=e,this.findProviders=e.metrics?.traceFunction("libp2p.contentRouting.findProviders",this.findProviders.bind(this),{optionsIndex:1,getAttributesFromArgs:([n],o)=>({...o,cid:n.toString()}),getAttributesFromYieldedValue:(n,o)=>({...o,providers:[...Array.isArray(o.providers)?o.providers:[],n.id.toString()]})})??this.findProviders,this.provide=e.metrics?.traceFunction("libp2p.contentRouting.provide",this.provide.bind(this),{optionsIndex:1,getAttributesFromArgs:([n],o)=>({...o,cid:n.toString()})})??this.provide,this.cancelReprovide=e.metrics?.traceFunction("libp2p.contentRouting.cancelReprovide",this.cancelReprovide.bind(this),{optionsIndex:1,getAttributesFromArgs:([n],o)=>({...o,cid:n.toString()})})??this.cancelReprovide,this.put=e.metrics?.traceFunction("libp2p.contentRouting.put",this.put.bind(this),{optionsIndex:2,getAttributesFromArgs:([n])=>({key:j(n,"base36")})})??this.put,this.get=e.metrics?.traceFunction("libp2p.contentRouting.get",this.get.bind(this),{optionsIndex:1,getAttributesFromArgs:([n])=>({key:j(n,"base36")})})??this.get}[Symbol.toStringTag]="@libp2p/content-routing";isStarted(){return this.started}async start(){this.started=!0}async stop(){this.started=!1}async*findProviders(e,t={}){if(this.routers.length===0)throw new ha("No content routers available");let n=this,o=new gi;for await(let i of cr(...n.routers.filter(s=>s.findProviders instanceof Function).map(s=>s.findProviders(e,t))))i!=null&&(i.multiaddrs.length>0&&await this.components.peerStore.merge(i.id,{multiaddrs:i.multiaddrs},t),!o.has(i.id)&&(o.add(i.id),yield i))}async provide(e,t={}){if(this.routers.length===0)throw new ha("No content routers available");await Promise.all(this.routers.filter(n=>n.provide instanceof Function).map(async n=>{await n.provide(e,t)}))}async cancelReprovide(e,t={}){if(this.routers.length===0)throw new ha("No content routers available");await Promise.all(this.routers.filter(n=>n.cancelReprovide instanceof Function).map(async n=>{await n.cancelReprovide(e,t)}))}async put(e,t,n){if(!this.isStarted())throw new An;await Promise.all(this.routers.filter(o=>o.put instanceof Function).map(async o=>{await o.put(e,t,n)}))}async get(e,t){if(!this.isStarted())throw new An;return Promise.any(this.routers.filter(n=>n.get instanceof Function).map(async n=>n.get(e,t)))}};var np=globalThis.CustomEvent??Event;async function*eb(r,e={}){let t=e.concurrency??1/0;t<1&&(t=1/0);let n=e.ordered??!1,o=new EventTarget,i=[],s=ge(),a=ge(),c=!1,u,l=!1;o.addEventListener("task-complete",()=>{a.resolve()}),Promise.resolve().then(async()=>{try{for await(let m of r){if(i.length===t&&(s=ge(),await s.promise),l)break;let y={done:!1};i.push(y),m().then(g=>{y.done=!0,y.ok=!0,y.value=g,o.dispatchEvent(new np("task-complete"))},g=>{y.done=!0,y.err=g,o.dispatchEvent(new np("task-complete"))})}c=!0,o.dispatchEvent(new np("task-complete"))}catch(m){u=m,o.dispatchEvent(new np("task-complete"))}});function f(){return n?i[0]?.done:!!i.find(m=>m.done)}function*d(){for(;i.length>0&&i[0].done;){let m=i[0];if(i.shift(),m.ok)yield m.value;else throw l=!0,s.resolve(),m.err;s.resolve()}}function*h(){for(;f();)for(let m=0;m<i.length;m++)if(i[m].done){let y=i[m];if(i.splice(m,1),m--,y.ok)yield y.value;else throw l=!0,s.resolve(),y.err;s.resolve()}}for(;;){if(f()||(a=ge(),await a.promise),u!=null||(n?yield*d():yield*h(),u!=null))throw u;if(c&&i.length===0)break}}var op=class{log;peerId;peerStore;routers;constructor(e,t={}){this.log=e.logger.forComponent("libp2p:peer-routing"),this.peerId=e.peerId,this.peerStore=e.peerStore,this.routers=t.routers??[],this.findPeer=e.metrics?.traceFunction("libp2p.peerRouting.findPeer",this.findPeer.bind(this),{optionsIndex:1,getAttributesFromArgs:([n],o)=>({...o,peer:n.toString()})})??this.findPeer,this.getClosestPeers=e.metrics?.traceFunction("libp2p.peerRouting.getClosestPeers",this.getClosestPeers.bind(this),{optionsIndex:1,getAttributesFromArgs:([n],o)=>({...o,key:j(n,"base36")}),getAttributesFromYieldedValue:(n,o)=>({...o,peers:[...Array.isArray(o.peers)?o.peers:[],n.id.toString()]})})??this.getClosestPeers}[Symbol.toStringTag]="@libp2p/peer-routing";async findPeer(e,t){if(this.routers.length===0)throw new ku("No peer routers available");if(e.toString()===this.peerId.toString())throw new Oh("Should not try to find self");let n=this,o=cr(...this.routers.filter(i=>i.findPeer instanceof Function).map(i=>(async function*(){try{yield await i.findPeer(e,t)}catch(s){n.log.error("router failed to find peer - %e",s)}})()));for await(let i of o)if(i!=null)return i.multiaddrs.length>0&&await this.peerStore.merge(i.id,{multiaddrs:i.multiaddrs},t),i;throw new He}async*getClosestPeers(e,t={}){if(this.routers.length===0)throw new ku("No peer routers available");let n=this,o=uo(1024);for await(let i of eb((async function*(){let s=cr(...n.routers.filter(a=>a.getClosestPeers instanceof Function).map(a=>a.getClosestPeers(e,t)));for await(let a of s)yield async()=>{if(a.multiaddrs.length===0)try{a=await n.findPeer(a.id,{...t,useCache:!1})}catch(c){n.log.error("could not find peer multiaddrs - %e",c);return}return a}})()))i!=null&&(i.multiaddrs.length>0&&await this.peerStore.merge(i.id,{multiaddrs:i.multiaddrs},t),!o.has(i.id.toMultihash().bytes)&&(o.add(i.id.toMultihash().bytes),yield i))}};var ip=class extends ze{peerRouting;log;walking;walkers;shutdownController;walkController;needNext;constructor(e){super(),this.log=e.logger.forComponent("libp2p:random-walk"),this.peerRouting=e.peerRouting,this.walkers=0,this.walking=!1,this.shutdownController=new AbortController,this.shutdownController.signal}[Symbol.toStringTag]="@libp2p/random-walk";start(){this.shutdownController=new AbortController,this.shutdownController.signal}stop(){this.shutdownController.abort()}async*walk(e){this.walking||this.startWalk(),this.walkers++;let t=Ie([this.shutdownController.signal,e?.signal]);try{for(;;)this.needNext?.resolve(),this.needNext=ge(),yield(await Iu(this,"walk:peer",{signal:t,rejectionEvents:["walk:error"]})).detail}catch(n){throw n.detail!=null?n.detail:n}finally{t.clear(),this.walkers--,this.walkers===0&&(this.walkController?.abort(),this.walkController=void 0)}}startWalk(){this.walking=!0,this.walkController=new AbortController,this.walkController.signal;let e=Ie([this.walkController.signal,this.shutdownController.signal]);let t=Date.now(),n=0;Promise.resolve().then(async()=>{for(this.log("start walk");this.walkers>0;)try{let o=Dr(32),i=Date.now();for await(let s of this.peerRouting.getClosestPeers(o,{signal:e}))e.aborted&&this.log("aborting walk"),e.throwIfAborted(),this.log("found peer %p after %dms for %d walkers",s.id,Date.now()-i,this.walkers),n++,this.safeDispatchEvent("walk:peer",{detail:s}),this.walkers===1&&this.needNext!=null&&(this.log("wait for need next"),await kt(this.needNext.promise,e)),i=Date.now();this.log("walk iteration for %b and %d walkers finished, found %d peers",o,this.walkers,n)}catch(o){this.log.error("random walk errored - %e",o),this.safeDispatchEvent("walk:error",{detail:o})}this.log("no walkers left, ended walk")}).catch(o=>{this.log.error("random walk errored - %e",o)}).finally(()=>{this.log("finished walk, found %d peers after %dms",n,Date.now()-t),this.walking=!1})}};var tb=32,rb=64,sp=class{log;topologies;handlers;components;middleware;constructor(e){this.components=e,this.log=e.logger.forComponent("libp2p:registrar"),this.middleware=new Map,this.topologies=new Map,e.metrics?.registerMetricGroup("libp2p_registrar_topologies",{calculate:()=>{let t={};for(let[n,o]of this.topologies)t[n]=o.size;return t}}),this.handlers=xt({name:"libp2p_registrar_protocol_handlers",metrics:e.metrics}),this._onDisconnect=this._onDisconnect.bind(this),this._onPeerUpdate=this._onPeerUpdate.bind(this),this._onPeerIdentify=this._onPeerIdentify.bind(this),this.components.events.addEventListener("peer:disconnect",this._onDisconnect),this.components.events.addEventListener("peer:update",this._onPeerUpdate),this.components.events.addEventListener("peer:identify",this._onPeerIdentify)}[Symbol.toStringTag]="@libp2p/registrar";getProtocols(){return Array.from(new Set([...this.handlers.keys()])).sort()}getHandler(e){let t=this.handlers.get(e);if(t==null)throw new Mh(`No handler registered for protocol ${e}`);return t}getTopologies(e){let t=this.topologies.get(e);return t==null?[]:[...t.values()]}async handle(e,t,n){if(this.handlers.has(e)&&n?.force!==!0)throw new Fh(`Handler already registered for protocol ${e}`);this.handlers.set(e,{handler:t,options:{maxInboundStreams:tb,maxOutboundStreams:rb,...n}}),await this.components.peerStore.merge(this.components.peerId,{protocols:[e]},n)}async unhandle(e,t){(Array.isArray(e)?e:[e]).forEach(o=>{this.handlers.delete(o)}),await this.components.peerStore.patch(this.components.peerId,{protocols:this.getProtocols()},t)}async register(e,t){if(t==null)throw new T("invalid topology");let n=`${(Math.random()*1e9).toString(36)}${Date.now()}`,o=this.topologies.get(e);return o==null&&(o=new Map,this.topologies.set(e,o)),o.set(n,t),n}unregister(e){for(let[t,n]of this.topologies.entries())n.has(e)&&(n.delete(e),n.size===0&&this.topologies.delete(t))}use(e,t){this.middleware.set(e,t)}unuse(e){this.middleware.delete(e)}getMiddleware(e){return this.middleware.get(e)??[]}async _onDisconnect(e){let t=e.detail,n={signal:AbortSignal.timeout(5e3)};try{let o=await this.components.peerStore.get(t,n);for(let i of o.protocols){let s=this.topologies.get(i);s!=null&&await Promise.all([...s.values()].map(async a=>{a.filter!=null&&a.filter.has(t)!==!0||(a.filter?.remove(t),await a.onDisconnect?.(t))}))}}catch(o){if(o.name==="NotFoundError")return;this.log.error("could not inform topologies of disconnecting peer %p - %e",t,o)}}async _onPeerUpdate(e){let{peer:t,previous:n}=e.detail,o=(n?.protocols??[]).filter(i=>!t.protocols.includes(i));try{for(let i of o){let s=this.topologies.get(i);s!=null&&await Promise.all([...s.values()].map(async a=>{a.filter!=null&&a.filter.has(t.id)!==!0||(a.filter?.remove(t.id),await a.onDisconnect?.(t.id))}))}}catch(i){this.log.error("could not inform topologies of updated peer %p - %e",t.id,i)}}async _onPeerIdentify(e){let t=e.detail.protocols,n=e.detail.connection,o=e.detail.peerId;try{for(let i of t){let s=this.topologies.get(i);s!=null&&await Promise.all([...s.values()].map(async a=>{n.limits!=null&&a.notifyOnLimitedConnection!==!0||a.filter?.has(o)!==!0&&(a.filter?.add(o),await a.onConnect?.(o,n))}))}}catch(i){this.log.error("could not inform topologies of updated peer after identify %p - %e",o,i)}}};var ap=class{log;components;transports;listeners;faultTolerance;started;constructor(e,t={}){this.log=e.logger.forComponent("libp2p:transports"),this.components=e,this.started=!1,this.transports=xt({name:"libp2p_transport_manager_transports",metrics:this.components.metrics}),this.listeners=xt({name:"libp2p_transport_manager_listeners",metrics:this.components.metrics}),this.faultTolerance=t.faultTolerance??Sa.FATAL_ALL}[Symbol.toStringTag]="@libp2p/transport-manager";add(e){let t=e[Symbol.toStringTag];if(t==null)throw new T("Transport must have a valid tag");if(this.transports.has(t))throw new T(`There is already a transport with the tag ${t}`);this.log("adding transport %s",t),this.transports.set(t,e),this.listeners.has(t)||this.listeners.set(t,[])}isStarted(){return this.started}start(){this.started=!0}async afterStart(){let e=this.components.addressManager.getListenAddrs();await this.listen(e)}async stop(){let e=[];for(let[t,n]of this.listeners)for(this.log("closing listeners for %s",t);n.length>0;){let o=n.pop();o!=null&&e.push(o.close())}await Promise.all(e),this.log("all listeners closed");for(let t of this.listeners.keys())this.listeners.set(t,[]);this.started=!1}async dial(e,t){let n=this.dialTransportForMultiaddr(e);if(n==null)throw new zh(`No transport available for address ${String(e)}`);return t?.onProgress?.(new $("transport-manager:selected-transport",n[Symbol.toStringTag])),n.dial(e,{...t,upgrader:this.components.upgrader})}getAddrs(){let e=[];for(let t of this.listeners.values())for(let n of t)e=[...e,...n.getAddrs()];return e}getTransports(){return Array.of(...this.transports.values())}getListeners(){return Array.of(...this.listeners.values()).flat()}dialTransportForMultiaddr(e){for(let t of this.transports.values())if(t.dialFilter([e]).length>0)return t}listenTransportForMultiaddr(e){for(let t of this.transports.values())if(t.listenFilter([e]).length>0)return t}async listen(e){if(!this.isStarted())throw new An("Not started");if(e==null||e.length===0){this.log("no addresses were provided for listening, this node is dial only");return}let t={errors:new Map,ipv4:{success:0,attempts:0},ipv6:{success:0,attempts:0}};e.forEach(i=>{t.errors.set(i.toString(),new $h)});let n=[];for(let[i,s]of this.transports.entries()){let a=s.listenFilter(e);for(let c of a){this.log("creating listener for %s on %a",i,c);let u=s.createListener({upgrader:this.components.upgrader}),l=this.listeners.get(i)??[];l==null&&(l=[],this.listeners.set(i,l)),l.push(u),u.addEventListener("listening",()=>{this.components.events.safeDispatchEvent("transport:listening",{detail:u})}),u.addEventListener("close",()=>{let f=l.findIndex(d=>d===u);l.splice(f,1),this.components.events.safeDispatchEvent("transport:close",{detail:u})}),fw.matches(c)?t.ipv4.attempts++:dw.matches(c)&&t.ipv6.attempts++,n.push(u.listen(c).then(()=>{t.errors.delete(c.toString()),fw.matches(c)&&t.ipv4.success++,dw.matches(c)&&t.ipv6.success++},f=>{throw this.log.error("transport %s could not listen on address %a - %e",i,c,f),t.errors.set(c.toString(),f),f}))}}let o=await Promise.allSettled(n);if(!(o.length>0&&o.every(i=>i.status==="fulfilled"))){if(this.ipv6Unsupported(t)){this.log("all IPv4 addresses succeed but all IPv6 failed");return}if(this.faultTolerance===Sa.NO_FATAL){this.log("failed to listen on any address but fault tolerance allows this");return}throw new Vh(`Some configured addresses failed to be listened on, you may need to remove one or more listen addresses from your configuration or set \`transportManager.faultTolerance\` to NO_FATAL:
|
|
33
33
|
${[...t.errors.entries()].map(([i,s])=>`
|
|
34
34
|
${i}: ${`${bL(s)}`.split(`
|
|
35
35
|
`).join(`
|